Repository: juanro49/rtl88x2ce-dkms
Branch: master
Commit: 477ecdf712e3
Files: 641
Total size: 26.3 MB
Directory structure:
gitextract_ori71sv_/
├── Kconfig
├── Makefile
├── README.md
├── clean
├── core/
│ ├── efuse/
│ │ └── rtw_efuse.c
│ ├── mesh/
│ │ ├── rtw_mesh.c
│ │ ├── rtw_mesh.h
│ │ ├── rtw_mesh_hwmp.c
│ │ ├── rtw_mesh_hwmp.h
│ │ ├── rtw_mesh_pathtbl.c
│ │ └── rtw_mesh_pathtbl.h
│ ├── rtw_ap.c
│ ├── rtw_beamforming.c
│ ├── rtw_br_ext.c
│ ├── rtw_bt_mp.c
│ ├── rtw_btcoex.c
│ ├── rtw_btcoex_wifionly.c
│ ├── rtw_chplan.c
│ ├── rtw_chplan.h
│ ├── rtw_cmd.c
│ ├── rtw_debug.c
│ ├── rtw_eeprom.c
│ ├── rtw_ieee80211.c
│ ├── rtw_io.c
│ ├── rtw_ioctl_query.c
│ ├── rtw_ioctl_set.c
│ ├── rtw_iol.c
│ ├── rtw_mem.c
│ ├── rtw_mi.c
│ ├── rtw_mlme.c
│ ├── rtw_mlme_ext.c
│ ├── rtw_mp.c
│ ├── rtw_odm.c
│ ├── rtw_p2p.c
│ ├── rtw_pwrctrl.c
│ ├── rtw_recv.c
│ ├── rtw_rf.c
│ ├── rtw_rm.c
│ ├── rtw_rm_fsm.c
│ ├── rtw_rson.c
│ ├── rtw_sdio.c
│ ├── rtw_security.c
│ ├── rtw_sreset.c
│ ├── rtw_sta_mgt.c
│ ├── rtw_tdls.c
│ ├── rtw_vht.c
│ ├── rtw_wapi.c
│ ├── rtw_wapi_sms4.c
│ ├── rtw_wlan_util.c
│ └── rtw_xmit.c
├── dkms.conf
├── hal/
│ ├── HalPwrSeqCmd.c
│ ├── btc/
│ │ ├── btc_basic_types.h
│ │ ├── halbtc8822c.c
│ │ ├── halbtc8822c.h
│ │ ├── halbtc8822cwifionly.c
│ │ ├── halbtc8822cwifionly.h
│ │ ├── halbtccommon.c
│ │ ├── halbtccommon.h
│ │ ├── halbtcoutsrc.h
│ │ └── mp_precomp.h
│ ├── efuse/
│ │ ├── efuse_mask.h
│ │ └── rtl8822c/
│ │ ├── HalEfuseMask8822C_PCIE.c
│ │ ├── HalEfuseMask8822C_PCIE.h
│ │ ├── HalEfuseMask8822C_SDIO.c
│ │ ├── HalEfuseMask8822C_SDIO.h
│ │ ├── HalEfuseMask8822C_USB.c
│ │ └── HalEfuseMask8822C_USB.h
│ ├── hal_btcoex.c
│ ├── hal_btcoex_wifionly.c
│ ├── hal_com.c
│ ├── hal_com_c2h.h
│ ├── hal_com_phycfg.c
│ ├── hal_dm.c
│ ├── hal_dm.h
│ ├── hal_dm_acs.c
│ ├── hal_dm_acs.h
│ ├── hal_halmac.c
│ ├── hal_halmac.h
│ ├── hal_hci/
│ │ └── hal_pci.c
│ ├── hal_intf.c
│ ├── hal_mcc.c
│ ├── hal_mp.c
│ ├── hal_phy.c
│ ├── halmac/
│ │ ├── halmac_2_platform.h
│ │ ├── halmac_88xx/
│ │ │ ├── halmac_8822c/
│ │ │ │ ├── halmac_8822c_cfg.h
│ │ │ │ ├── halmac_cfg_wmac_8822c.c
│ │ │ │ ├── halmac_cfg_wmac_8822c.h
│ │ │ │ ├── halmac_common_8822c.c
│ │ │ │ ├── halmac_common_8822c.h
│ │ │ │ ├── halmac_gpio_8822c.c
│ │ │ │ ├── halmac_gpio_8822c.h
│ │ │ │ ├── halmac_init_8822c.c
│ │ │ │ ├── halmac_init_8822c.h
│ │ │ │ ├── halmac_pcie_8822c.c
│ │ │ │ ├── halmac_pcie_8822c.h
│ │ │ │ ├── halmac_phy_8822c.c
│ │ │ │ ├── halmac_pwr_seq_8822c.c
│ │ │ │ └── halmac_pwr_seq_8822c.h
│ │ │ ├── halmac_88xx_cfg.h
│ │ │ ├── halmac_bb_rf_88xx.c
│ │ │ ├── halmac_bb_rf_88xx.h
│ │ │ ├── halmac_cfg_wmac_88xx.c
│ │ │ ├── halmac_cfg_wmac_88xx.h
│ │ │ ├── halmac_common_88xx.c
│ │ │ ├── halmac_common_88xx.h
│ │ │ ├── halmac_efuse_88xx.c
│ │ │ ├── halmac_efuse_88xx.h
│ │ │ ├── halmac_flash_88xx.c
│ │ │ ├── halmac_flash_88xx.h
│ │ │ ├── halmac_fw_88xx.c
│ │ │ ├── halmac_fw_88xx.h
│ │ │ ├── halmac_gpio_88xx.c
│ │ │ ├── halmac_gpio_88xx.h
│ │ │ ├── halmac_init_88xx.c
│ │ │ ├── halmac_init_88xx.h
│ │ │ ├── halmac_mimo_88xx.c
│ │ │ ├── halmac_mimo_88xx.h
│ │ │ ├── halmac_pcie_88xx.c
│ │ │ └── halmac_pcie_88xx.h
│ │ ├── halmac_api.c
│ │ ├── halmac_api.h
│ │ ├── halmac_bit2.h
│ │ ├── halmac_bit_8197f.h
│ │ ├── halmac_bit_8814b.h
│ │ ├── halmac_bit_8821c.h
│ │ ├── halmac_bit_8822b.h
│ │ ├── halmac_bit_8822c.h
│ │ ├── halmac_fw_info.h
│ │ ├── halmac_fw_offload_c2h_ap.h
│ │ ├── halmac_fw_offload_c2h_nic.h
│ │ ├── halmac_fw_offload_h2c_ap.h
│ │ ├── halmac_fw_offload_h2c_nic.h
│ │ ├── halmac_gpio_cmd.h
│ │ ├── halmac_h2c_extra_info_ap.h
│ │ ├── halmac_h2c_extra_info_nic.h
│ │ ├── halmac_hw_cfg.h
│ │ ├── halmac_intf_phy_cmd.h
│ │ ├── halmac_original_c2h_ap.h
│ │ ├── halmac_original_c2h_nic.h
│ │ ├── halmac_original_h2c_ap.h
│ │ ├── halmac_original_h2c_nic.h
│ │ ├── halmac_pcie_reg.h
│ │ ├── halmac_pwr_seq_cmd.h
│ │ ├── halmac_reg2.h
│ │ ├── halmac_reg_8197f.h
│ │ ├── halmac_reg_8814b.h
│ │ ├── halmac_reg_8821c.h
│ │ ├── halmac_reg_8822b.h
│ │ ├── halmac_reg_8822c.h
│ │ ├── halmac_rx_bd_nic.h
│ │ ├── halmac_rx_desc_ap.h
│ │ ├── halmac_rx_desc_chip.h
│ │ ├── halmac_rx_desc_nic.h
│ │ ├── halmac_sdio_reg.h
│ │ ├── halmac_state_machine.h
│ │ ├── halmac_tx_bd_nic.h
│ │ ├── halmac_tx_desc_ap.h
│ │ ├── halmac_tx_desc_buffer_ap.h
│ │ ├── halmac_tx_desc_buffer_chip.h
│ │ ├── halmac_tx_desc_buffer_nic.h
│ │ ├── halmac_tx_desc_chip.h
│ │ ├── halmac_tx_desc_ie_ap.h
│ │ ├── halmac_tx_desc_ie_chip.h
│ │ ├── halmac_tx_desc_ie_nic.h
│ │ ├── halmac_tx_desc_nic.h
│ │ ├── halmac_type.h
│ │ └── halmac_usb_reg.h
│ ├── led/
│ │ ├── hal_led.c
│ │ └── hal_pci_led.c
│ ├── phydm/
│ │ ├── ap_makefile.mk
│ │ ├── halhwimg.h
│ │ ├── halrf/
│ │ │ ├── halphyrf_ap.c
│ │ │ ├── halphyrf_ap.h
│ │ │ ├── halphyrf_ce.c
│ │ │ ├── halphyrf_ce.h
│ │ │ ├── halphyrf_iot.c
│ │ │ ├── halphyrf_iot.h
│ │ │ ├── halphyrf_win.c
│ │ │ ├── halphyrf_win.h
│ │ │ ├── halrf.c
│ │ │ ├── halrf.h
│ │ │ ├── halrf_debug.c
│ │ │ ├── halrf_debug.h
│ │ │ ├── halrf_dpk.h
│ │ │ ├── halrf_features.h
│ │ │ ├── halrf_iqk.h
│ │ │ ├── halrf_kfree.c
│ │ │ ├── halrf_kfree.h
│ │ │ ├── halrf_powertracking.c
│ │ │ ├── halrf_powertracking.h
│ │ │ ├── halrf_powertracking_ap.c
│ │ │ ├── halrf_powertracking_ap.h
│ │ │ ├── halrf_powertracking_ce.c
│ │ │ ├── halrf_powertracking_ce.h
│ │ │ ├── halrf_powertracking_iot.c
│ │ │ ├── halrf_powertracking_iot.h
│ │ │ ├── halrf_powertracking_win.c
│ │ │ ├── halrf_powertracking_win.h
│ │ │ ├── halrf_psd.c
│ │ │ ├── halrf_psd.h
│ │ │ ├── halrf_txgapcal.c
│ │ │ ├── halrf_txgapcal.h
│ │ │ └── rtl8822c/
│ │ │ ├── halhwimg8822c_rf.c
│ │ │ ├── halhwimg8822c_rf.h
│ │ │ ├── halrf_8822c.c
│ │ │ ├── halrf_8822c.h
│ │ │ ├── halrf_dpk_8822c.c
│ │ │ ├── halrf_dpk_8822c.h
│ │ │ ├── halrf_iqk_8822c.c
│ │ │ ├── halrf_iqk_8822c.h
│ │ │ ├── halrf_rfk_init_8822c.c
│ │ │ ├── halrf_rfk_init_8822c.h
│ │ │ ├── halrf_tssi_8822c.c
│ │ │ ├── halrf_tssi_8822c.h
│ │ │ └── version_rtl8822c_rf.h
│ │ ├── mp_precomp.h
│ │ ├── phydm.c
│ │ ├── phydm.h
│ │ ├── phydm.mk
│ │ ├── phydm_adaptivity.c
│ │ ├── phydm_adaptivity.h
│ │ ├── phydm_adc_sampling.c
│ │ ├── phydm_adc_sampling.h
│ │ ├── phydm_antdect.c
│ │ ├── phydm_antdect.h
│ │ ├── phydm_antdiv.c
│ │ ├── phydm_antdiv.h
│ │ ├── phydm_api.c
│ │ ├── phydm_api.h
│ │ ├── phydm_auto_dbg.c
│ │ ├── phydm_auto_dbg.h
│ │ ├── phydm_beamforming.c
│ │ ├── phydm_beamforming.h
│ │ ├── phydm_cck_pd.c
│ │ ├── phydm_cck_pd.h
│ │ ├── phydm_ccx.c
│ │ ├── phydm_ccx.h
│ │ ├── phydm_cfotracking.c
│ │ ├── phydm_cfotracking.h
│ │ ├── phydm_debug.c
│ │ ├── phydm_debug.h
│ │ ├── phydm_dfs.c
│ │ ├── phydm_dfs.h
│ │ ├── phydm_dig.c
│ │ ├── phydm_dig.h
│ │ ├── phydm_direct_bf.c
│ │ ├── phydm_direct_bf.h
│ │ ├── phydm_dynamictxpower.c
│ │ ├── phydm_dynamictxpower.h
│ │ ├── phydm_features.h
│ │ ├── phydm_features_ap.h
│ │ ├── phydm_features_ce.h
│ │ ├── phydm_features_ce2_kernel.h
│ │ ├── phydm_features_iot.h
│ │ ├── phydm_features_win.h
│ │ ├── phydm_hwconfig.c
│ │ ├── phydm_hwconfig.h
│ │ ├── phydm_interface.c
│ │ ├── phydm_interface.h
│ │ ├── phydm_lna_sat.c
│ │ ├── phydm_lna_sat.h
│ │ ├── phydm_math_lib.c
│ │ ├── phydm_math_lib.h
│ │ ├── phydm_mp.c
│ │ ├── phydm_mp.h
│ │ ├── phydm_noisemonitor.c
│ │ ├── phydm_noisemonitor.h
│ │ ├── phydm_pathdiv.c
│ │ ├── phydm_pathdiv.h
│ │ ├── phydm_phystatus.c
│ │ ├── phydm_phystatus.h
│ │ ├── phydm_pmac_tx_setting.c
│ │ ├── phydm_pmac_tx_setting.h
│ │ ├── phydm_pow_train.c
│ │ ├── phydm_pow_train.h
│ │ ├── phydm_pre_define.h
│ │ ├── phydm_precomp.h
│ │ ├── phydm_primary_cca.c
│ │ ├── phydm_primary_cca.h
│ │ ├── phydm_psd.c
│ │ ├── phydm_psd.h
│ │ ├── phydm_rainfo.c
│ │ ├── phydm_rainfo.h
│ │ ├── phydm_reg.h
│ │ ├── phydm_regdefine11ac.h
│ │ ├── phydm_regdefine11n.h
│ │ ├── phydm_regtable.h
│ │ ├── phydm_rssi_monitor.c
│ │ ├── phydm_rssi_monitor.h
│ │ ├── phydm_smt_ant.c
│ │ ├── phydm_smt_ant.h
│ │ ├── phydm_soml.c
│ │ ├── phydm_soml.h
│ │ ├── phydm_types.h
│ │ ├── rtl8822c/
│ │ │ ├── halhwimg8822c_bb.c
│ │ │ ├── halhwimg8822c_bb.h
│ │ │ ├── mp_precomp.h
│ │ │ ├── phydm_hal_api8822c.c
│ │ │ ├── phydm_hal_api8822c.h
│ │ │ ├── phydm_regconfig8822c.c
│ │ │ ├── phydm_regconfig8822c.h
│ │ │ ├── phydm_rtl8822c.c
│ │ │ ├── phydm_rtl8822c.h
│ │ │ └── version_rtl8822c.h
│ │ ├── sd4_phydm_2_kernel.mk
│ │ └── txbf/
│ │ ├── halcomtxbf.c
│ │ ├── halcomtxbf.h
│ │ ├── haltxbf8192e.c
│ │ ├── haltxbf8192e.h
│ │ ├── haltxbf8814a.c
│ │ ├── haltxbf8814a.h
│ │ ├── haltxbf8822b.c
│ │ ├── haltxbf8822b.h
│ │ ├── haltxbfinterface.c
│ │ ├── haltxbfinterface.h
│ │ ├── haltxbfjaguar.c
│ │ ├── haltxbfjaguar.h
│ │ ├── phydm_hal_txbf_api.c
│ │ └── phydm_hal_txbf_api.h
│ └── rtl8822c/
│ ├── hal8822c_fw.c
│ ├── hal8822c_fw.h
│ ├── pci/
│ │ ├── rtl8822ce.h
│ │ ├── rtl8822ce_halinit.c
│ │ ├── rtl8822ce_halmac.c
│ │ ├── rtl8822ce_io.c
│ │ ├── rtl8822ce_led.c
│ │ ├── rtl8822ce_ops.c
│ │ ├── rtl8822ce_recv.c
│ │ └── rtl8822ce_xmit.c
│ ├── rtl8822c.h
│ ├── rtl8822c_cmd.c
│ ├── rtl8822c_halinit.c
│ ├── rtl8822c_mac.c
│ ├── rtl8822c_ops.c
│ └── rtl8822c_phy.c
├── halmac.mk
├── ifcfg-wlan0
├── include/
│ ├── Hal8188EPhyCfg.h
│ ├── Hal8188EPhyReg.h
│ ├── Hal8188EPwrSeq.h
│ ├── Hal8188FPhyCfg.h
│ ├── Hal8188FPhyReg.h
│ ├── Hal8188FPwrSeq.h
│ ├── Hal8192EPhyCfg.h
│ ├── Hal8192EPhyReg.h
│ ├── Hal8192EPwrSeq.h
│ ├── Hal8192FPhyCfg.h
│ ├── Hal8192FPhyReg.h
│ ├── Hal8192FPwrSeq.h
│ ├── Hal8703BPhyCfg.h
│ ├── Hal8703BPhyReg.h
│ ├── Hal8703BPwrSeq.h
│ ├── Hal8710BPhyCfg.h
│ ├── Hal8710BPhyReg.h
│ ├── Hal8710BPwrSeq.h
│ ├── Hal8723BPhyCfg.h
│ ├── Hal8723BPhyReg.h
│ ├── Hal8723BPwrSeq.h
│ ├── Hal8723DPhyCfg.h
│ ├── Hal8723DPhyReg.h
│ ├── Hal8723DPwrSeq.h
│ ├── Hal8723PwrSeq.h
│ ├── Hal8812PhyCfg.h
│ ├── Hal8812PhyReg.h
│ ├── Hal8812PwrSeq.h
│ ├── Hal8814PhyCfg.h
│ ├── Hal8814PhyReg.h
│ ├── Hal8814PwrSeq.h
│ ├── Hal8821APwrSeq.h
│ ├── HalPwrSeqCmd.h
│ ├── HalVerDef.h
│ ├── autoconf.h
│ ├── basic_types.h
│ ├── byteorder/
│ │ ├── big_endian.h
│ │ ├── generic.h
│ │ ├── little_endian.h
│ │ ├── swab.h
│ │ └── swabb.h
│ ├── circ_buf.h
│ ├── cmd_osdep.h
│ ├── cmn_info/
│ │ └── rtw_sta_info.h
│ ├── custom_gpio.h
│ ├── drv_conf.h
│ ├── drv_types.h
│ ├── drv_types_ce.h
│ ├── drv_types_gspi.h
│ ├── drv_types_linux.h
│ ├── drv_types_pci.h
│ ├── drv_types_sdio.h
│ ├── drv_types_xp.h
│ ├── ethernet.h
│ ├── gspi_hal.h
│ ├── gspi_ops.h
│ ├── gspi_ops_linux.h
│ ├── gspi_osintf.h
│ ├── h2clbk.h
│ ├── hal_btcoex.h
│ ├── hal_btcoex_wifionly.h
│ ├── hal_com.h
│ ├── hal_com_h2c.h
│ ├── hal_com_led.h
│ ├── hal_com_phycfg.h
│ ├── hal_com_reg.h
│ ├── hal_data.h
│ ├── hal_gspi.h
│ ├── hal_ic_cfg.h
│ ├── hal_intf.h
│ ├── hal_pg.h
│ ├── hal_phy.h
│ ├── hal_phy_reg.h
│ ├── hal_sdio.h
│ ├── hal_sdio_coex.h
│ ├── ieee80211.h
│ ├── ieee80211_ext.h
│ ├── if_ether.h
│ ├── ip.h
│ ├── linux/
│ │ └── wireless.h
│ ├── mlme_osdep.h
│ ├── nic_spec.h
│ ├── osdep_intf.h
│ ├── osdep_service.h
│ ├── osdep_service_bsd.h
│ ├── osdep_service_ce.h
│ ├── osdep_service_linux.h
│ ├── osdep_service_xp.h
│ ├── pci_hal.h
│ ├── pci_ops.h
│ ├── pci_osintf.h
│ ├── recv_osdep.h
│ ├── rtl8188e_cmd.h
│ ├── rtl8188e_dm.h
│ ├── rtl8188e_hal.h
│ ├── rtl8188e_led.h
│ ├── rtl8188e_recv.h
│ ├── rtl8188e_rf.h
│ ├── rtl8188e_spec.h
│ ├── rtl8188e_sreset.h
│ ├── rtl8188e_xmit.h
│ ├── rtl8188f_cmd.h
│ ├── rtl8188f_dm.h
│ ├── rtl8188f_hal.h
│ ├── rtl8188f_led.h
│ ├── rtl8188f_recv.h
│ ├── rtl8188f_rf.h
│ ├── rtl8188f_spec.h
│ ├── rtl8188f_sreset.h
│ ├── rtl8188f_xmit.h
│ ├── rtl8192e_cmd.h
│ ├── rtl8192e_dm.h
│ ├── rtl8192e_hal.h
│ ├── rtl8192e_led.h
│ ├── rtl8192e_recv.h
│ ├── rtl8192e_rf.h
│ ├── rtl8192e_spec.h
│ ├── rtl8192e_sreset.h
│ ├── rtl8192e_xmit.h
│ ├── rtl8192f_cmd.h
│ ├── rtl8192f_dm.h
│ ├── rtl8192f_hal.h
│ ├── rtl8192f_led.h
│ ├── rtl8192f_recv.h
│ ├── rtl8192f_rf.h
│ ├── rtl8192f_spec.h
│ ├── rtl8192f_sreset.h
│ ├── rtl8192f_xmit.h
│ ├── rtl8703b_cmd.h
│ ├── rtl8703b_dm.h
│ ├── rtl8703b_hal.h
│ ├── rtl8703b_led.h
│ ├── rtl8703b_recv.h
│ ├── rtl8703b_rf.h
│ ├── rtl8703b_spec.h
│ ├── rtl8703b_sreset.h
│ ├── rtl8703b_xmit.h
│ ├── rtl8710b_cmd.h
│ ├── rtl8710b_dm.h
│ ├── rtl8710b_hal.h
│ ├── rtl8710b_led.h
│ ├── rtl8710b_lps_poff.h
│ ├── rtl8710b_recv.h
│ ├── rtl8710b_rf.h
│ ├── rtl8710b_spec.h
│ ├── rtl8710b_sreset.h
│ ├── rtl8710b_xmit.h
│ ├── rtl8723b_cmd.h
│ ├── rtl8723b_dm.h
│ ├── rtl8723b_hal.h
│ ├── rtl8723b_led.h
│ ├── rtl8723b_recv.h
│ ├── rtl8723b_rf.h
│ ├── rtl8723b_spec.h
│ ├── rtl8723b_sreset.h
│ ├── rtl8723b_xmit.h
│ ├── rtl8723d_cmd.h
│ ├── rtl8723d_dm.h
│ ├── rtl8723d_hal.h
│ ├── rtl8723d_led.h
│ ├── rtl8723d_lps_poff.h
│ ├── rtl8723d_recv.h
│ ├── rtl8723d_rf.h
│ ├── rtl8723d_spec.h
│ ├── rtl8723d_sreset.h
│ ├── rtl8723d_xmit.h
│ ├── rtl8812a_cmd.h
│ ├── rtl8812a_dm.h
│ ├── rtl8812a_hal.h
│ ├── rtl8812a_led.h
│ ├── rtl8812a_recv.h
│ ├── rtl8812a_rf.h
│ ├── rtl8812a_spec.h
│ ├── rtl8812a_sreset.h
│ ├── rtl8812a_xmit.h
│ ├── rtl8814a_cmd.h
│ ├── rtl8814a_dm.h
│ ├── rtl8814a_hal.h
│ ├── rtl8814a_led.h
│ ├── rtl8814a_recv.h
│ ├── rtl8814a_rf.h
│ ├── rtl8814a_spec.h
│ ├── rtl8814a_sreset.h
│ ├── rtl8814a_xmit.h
│ ├── rtl8821a_spec.h
│ ├── rtl8821a_xmit.h
│ ├── rtl8821c_dm.h
│ ├── rtl8821c_hal.h
│ ├── rtl8821c_spec.h
│ ├── rtl8821ce_hal.h
│ ├── rtl8821cs_hal.h
│ ├── rtl8821cu_hal.h
│ ├── rtl8822b_hal.h
│ ├── rtl8822be_hal.h
│ ├── rtl8822bs_hal.h
│ ├── rtl8822bu_hal.h
│ ├── rtl8822c_hal.h
│ ├── rtl8822ce_hal.h
│ ├── rtl8822cs_hal.h
│ ├── rtl8822cu_hal.h
│ ├── rtw_android.h
│ ├── rtw_ap.h
│ ├── rtw_beamforming.h
│ ├── rtw_br_ext.h
│ ├── rtw_bt_mp.h
│ ├── rtw_btcoex.h
│ ├── rtw_btcoex_wifionly.h
│ ├── rtw_byteorder.h
│ ├── rtw_cmd.h
│ ├── rtw_debug.h
│ ├── rtw_eeprom.h
│ ├── rtw_efuse.h
│ ├── rtw_event.h
│ ├── rtw_ht.h
│ ├── rtw_io.h
│ ├── rtw_ioctl.h
│ ├── rtw_ioctl_query.h
│ ├── rtw_ioctl_set.h
│ ├── rtw_iol.h
│ ├── rtw_mcc.h
│ ├── rtw_mem.h
│ ├── rtw_mi.h
│ ├── rtw_mlme.h
│ ├── rtw_mlme_ext.h
│ ├── rtw_mp.h
│ ├── rtw_mp_phy_regdef.h
│ ├── rtw_odm.h
│ ├── rtw_p2p.h
│ ├── rtw_pwrctrl.h
│ ├── rtw_qos.h
│ ├── rtw_recv.h
│ ├── rtw_rf.h
│ ├── rtw_rm.h
│ ├── rtw_rm_fsm.h
│ ├── rtw_rson.h
│ ├── rtw_sdio.h
│ ├── rtw_security.h
│ ├── rtw_sreset.h
│ ├── rtw_tdls.h
│ ├── rtw_version.h
│ ├── rtw_vht.h
│ ├── rtw_wapi.h
│ ├── rtw_wifi_regd.h
│ ├── rtw_xmit.h
│ ├── sdio_hal.h
│ ├── sdio_ops.h
│ ├── sdio_ops_ce.h
│ ├── sdio_ops_linux.h
│ ├── sdio_ops_xp.h
│ ├── sdio_osintf.h
│ ├── sta_info.h
│ ├── usb_hal.h
│ ├── usb_ops.h
│ ├── usb_ops_linux.h
│ ├── usb_osintf.h
│ ├── usb_vendor_req.h
│ ├── wifi.h
│ ├── wlan_bssdef.h
│ └── xmit_osdep.h
├── os_dep/
│ ├── linux/
│ │ ├── .rtw_proc.o.d
│ │ ├── custom_gpio_linux.c
│ │ ├── ioctl_cfg80211.c
│ │ ├── ioctl_cfg80211.h
│ │ ├── ioctl_linux.c
│ │ ├── ioctl_mp.c
│ │ ├── mlme_linux.c
│ │ ├── os_intfs.c
│ │ ├── pci_intf.c
│ │ ├── pci_ops_linux.c
│ │ ├── recv_linux.c
│ │ ├── rhashtable.c
│ │ ├── rhashtable.h
│ │ ├── rtw_android.c
│ │ ├── rtw_cfgvendor.c
│ │ ├── rtw_cfgvendor.h
│ │ ├── rtw_proc.c
│ │ ├── rtw_proc.h
│ │ ├── rtw_rhashtable.c
│ │ ├── rtw_rhashtable.h
│ │ ├── wifi_regd.c
│ │ └── xmit_linux.c
│ └── osdep_service.c
├── platform/
│ ├── custom_country_chplan.h
│ ├── platform_ARM_SUN50IW1P1_sdio.c
│ ├── platform_ARM_SUNnI_sdio.c
│ ├── platform_ARM_SUNxI_sdio.c
│ ├── platform_ARM_SUNxI_usb.c
│ ├── platform_ARM_WMT_sdio.c
│ ├── platform_RTK_DMP_usb.c
│ ├── platform_aml_s905_sdio.c
│ ├── platform_aml_s905_sdio.h
│ ├── platform_arm_act_sdio.c
│ ├── platform_hisilicon_hi3798_sdio.c
│ ├── platform_hisilicon_hi3798_sdio.h
│ ├── platform_ops.c
│ ├── platform_ops.h
│ ├── platform_sprd_sdio.c
│ ├── platform_zte_zx296716_sdio.c
│ └── platform_zte_zx296716_sdio.h
├── rtl8822c.mk
├── rtw88_blacklist.conf
├── runwpa
└── wlan0dhcp
================================================
FILE CONTENTS
================================================
================================================
FILE: Kconfig
================================================
config RTL8822CE
tristate "Realtek 8822C PCIE WiFi"
depends on PCI
---help---
Help message of RTL8822CE
================================================
FILE: Makefile
================================================
EXTRA_CFLAGS += $(USER_EXTRA_CFLAGS)
EXTRA_CFLAGS += -O1
#EXTRA_CFLAGS += -O3
#EXTRA_CFLAGS += -Wall
#EXTRA_CFLAGS += -Wextra
#EXTRA_CFLAGS += -Werror
#EXTRA_CFLAGS += -pedantic
#EXTRA_CFLAGS += -Wshadow -Wpointer-arith -Wcast-qual -Wstrict-prototypes -Wmissing-prototypes
EXTRA_CFLAGS += -Wno-unused-variable
#EXTRA_CFLAGS += -Wno-unused-value
#EXTRA_CFLAGS += -Wno-unused-label
#EXTRA_CFLAGS += -Wno-unused-parameter
EXTRA_CFLAGS += -Wno-unused-function
EXTRA_CFLAGS += -Wno-unused
#EXTRA_CFLAGS += -Wno-uninitialized
GCC_VER_49 := $(shell echo `$(CC) -dumpversion | cut -f1-2 -d.` \>= 4.9 | bc )
ifeq ($(GCC_VER_49),1)
EXTRA_CFLAGS += -Wno-date-time # Fix compile error && warning on gcc 4.9 and later
endif
EXTRA_CFLAGS += -I$(src)/include
EXTRA_LDFLAGS += --strip-debug
CONFIG_AUTOCFG_CP = n
########################## WIFI IC ############################
CONFIG_MULTIDRV = n
CONFIG_RTL8188E = n
CONFIG_RTL8812A = n
CONFIG_RTL8821A = n
CONFIG_RTL8192E = n
CONFIG_RTL8723B = n
CONFIG_RTL8814A = n
CONFIG_RTL8723C = n
CONFIG_RTL8188F = n
CONFIG_RTL8188GTV = n
CONFIG_RTL8822B = n
CONFIG_RTL8723D = n
CONFIG_RTL8821C = n
CONFIG_RTL8710B = n
CONFIG_RTL8192F = n
CONFIG_RTL8822C = y
######################### Interface ###########################
CONFIG_USB_HCI = n
CONFIG_PCI_HCI = y
CONFIG_SDIO_HCI = n
CONFIG_GSPI_HCI = n
########################## Features ###########################
CONFIG_MP_INCLUDED = y
CONFIG_POWER_SAVING = y
CONFIG_IPS_MODE = default
CONFIG_LPS_MODE = default
CONFIG_USB_AUTOSUSPEND = n
CONFIG_HW_PWRP_DETECTION = n
CONFIG_BT_COEXIST = y
CONFIG_WAPI_SUPPORT = n
CONFIG_EFUSE_CONFIG_FILE = y
CONFIG_EXT_CLK = n
CONFIG_TRAFFIC_PROTECT = n
CONFIG_LOAD_PHY_PARA_FROM_FILE = y
CONFIG_TXPWR_BY_RATE = y
CONFIG_TXPWR_BY_RATE_EN = auto
CONFIG_TXPWR_LIMIT = y
CONFIG_TXPWR_LIMIT_EN = n
CONFIG_RTW_CHPLAN = 0xFF
CONFIG_RTW_ADAPTIVITY_EN = enable
CONFIG_RTW_ADAPTIVITY_MODE = normal
CONFIG_SIGNAL_SCALE_MAPPING = n
CONFIG_80211W = y
CONFIG_REDUCE_TX_CPU_LOADING = n
CONFIG_BR_EXT = y
CONFIG_TDLS = n
CONFIG_WIFI_MONITOR = n
CONFIG_MCC_MODE = n
CONFIG_APPEND_VENDOR_IE_ENABLE = n
CONFIG_RTW_NAPI = y
CONFIG_RTW_GRO = y
CONFIG_RTW_NETIF_SG = y
CONFIG_RTW_IPCAM_APPLICATION = n
CONFIG_RTW_REPEATER_SON = n
CONFIG_RTW_WIFI_HAL = n
CONFIG_ICMP_VOQ = n
CONFIG_IP_R_MONITOR = n #arp VOQ and high rate
CONFIG_RTW_DISABLE_HW_PDN = n
CONFIG_RTW_IOT_CCK_PD_INIT = n
########################## Debug ###########################
CONFIG_RTW_DEBUG = y
# default log level is _DRV_INFO_ = 4,
# please refer to "How_to_set_driver_debug_log_level.doc" to set the available level.
CONFIG_RTW_LOG_LEVEL = 4
######################## Wake On Lan ##########################
CONFIG_WOWLAN = n
#bit2: deauth, bit1: unicast, bit0: magic pkt.
CONFIG_WAKEUP_TYPE = 0x7
CONFIG_WOW_LPS_MODE = default
#bit0: disBBRF off, #bit1: Wireless remote controller (WRC)
CONFIG_SUSPEND_TYPE = 0
CONFIG_WOW_STA_MIX = n
CONFIG_GPIO_WAKEUP = n
CONFIG_WAKEUP_GPIO_IDX = default
CONFIG_HIGH_ACTIVE_DEV2HST = n
######### only for USB #########
CONFIG_ONE_PIN_GPIO = n
CONFIG_HIGH_ACTIVE_HST2DEV = n
CONFIG_PNO_SUPPORT = n
CONFIG_PNO_SET_DEBUG = n
CONFIG_AP_WOWLAN = n
######### Notify SDIO Host Keep Power During Syspend ##########
CONFIG_RTW_SDIO_PM_KEEP_POWER = y
###################### MP HW TX MODE FOR VHT #######################
CONFIG_MP_VHT_HW_TX_MODE = n
###################### Platform Related #######################
CONFIG_PLATFORM_I386_PC = y
CONFIG_PLATFORM_ANDROID_X86 = n
CONFIG_PLATFORM_ANDROID_INTEL_X86 = n
CONFIG_PLATFORM_JB_X86 = n
CONFIG_PLATFORM_ARM_S3C2K4 = n
CONFIG_PLATFORM_ARM_PXA2XX = n
CONFIG_PLATFORM_ARM_S3C6K4 = n
CONFIG_PLATFORM_MIPS_RMI = n
CONFIG_PLATFORM_RTD2880B = n
CONFIG_PLATFORM_MIPS_AR9132 = n
CONFIG_PLATFORM_RTK_DMP = n
CONFIG_PLATFORM_MIPS_PLM = n
CONFIG_PLATFORM_MSTAR389 = n
CONFIG_PLATFORM_MT53XX = n
CONFIG_PLATFORM_ARM_MX51_241H = n
CONFIG_PLATFORM_FS_MX61 = n
CONFIG_PLATFORM_ACTIONS_ATJ227X = n
CONFIG_PLATFORM_TEGRA3_CARDHU = n
CONFIG_PLATFORM_TEGRA4_DALMORE = n
CONFIG_PLATFORM_ARM_TCC8900 = n
CONFIG_PLATFORM_ARM_TCC8920 = n
CONFIG_PLATFORM_ARM_TCC8920_JB42 = n
CONFIG_PLATFORM_ARM_TCC8930_JB42 = n
CONFIG_PLATFORM_ARM_RK2818 = n
CONFIG_PLATFORM_ARM_RK3066 = n
CONFIG_PLATFORM_ARM_RK3188 = n
CONFIG_PLATFORM_ARM_URBETTER = n
CONFIG_PLATFORM_ARM_TI_PANDA = n
CONFIG_PLATFORM_MIPS_JZ4760 = n
CONFIG_PLATFORM_DMP_PHILIPS = n
CONFIG_PLATFORM_MSTAR_TITANIA12 = n
CONFIG_PLATFORM_MSTAR = n
CONFIG_PLATFORM_SZEBOOK = n
CONFIG_PLATFORM_ARM_SUNxI = n
CONFIG_PLATFORM_ARM_SUN6I = n
CONFIG_PLATFORM_ARM_SUN7I = n
CONFIG_PLATFORM_ARM_SUN8I_W3P1 = n
CONFIG_PLATFORM_ARM_SUN8I_W5P1 = n
CONFIG_PLATFORM_ACTIONS_ATM702X = n
CONFIG_PLATFORM_ACTIONS_ATV5201 = n
CONFIG_PLATFORM_ACTIONS_ATM705X = n
CONFIG_PLATFORM_ARM_SUN50IW1P1 = n
CONFIG_PLATFORM_ARM_RTD299X = n
CONFIG_PLATFORM_ARM_LGE = n
CONFIG_PLATFORM_ARM_SPREADTRUM_6820 = n
CONFIG_PLATFORM_ARM_SPREADTRUM_8810 = n
CONFIG_PLATFORM_ARM_WMT = n
CONFIG_PLATFORM_TI_DM365 = n
CONFIG_PLATFORM_MOZART = n
CONFIG_PLATFORM_RTK119X = n
CONFIG_PLATFORM_RTK119X_AM = n
CONFIG_PLATFORM_RTK129X = n
CONFIG_PLATFORM_RTK390X = n
CONFIG_PLATFORM_NOVATEK_NT72668 = n
CONFIG_PLATFORM_HISILICON = n
CONFIG_PLATFORM_HISILICON_HI3798 = n
CONFIG_PLATFORM_NV_TK1 = n
CONFIG_PLATFORM_NV_TK1_UBUNTU = n
CONFIG_PLATFORM_RTL8197D = n
CONFIG_PLATFORM_AML_S905 = n
CONFIG_PLATFORM_ZTE_ZX296716 = n
########### CUSTOMER ################################
CONFIG_CUSTOMER_HUAWEI_GENERAL = n
CONFIG_DRVEXT_MODULE = n
export TopDIR ?= $(shell pwd)
########### COMMON #################################
ifeq ($(CONFIG_GSPI_HCI), y)
HCI_NAME = gspi
endif
ifeq ($(CONFIG_SDIO_HCI), y)
HCI_NAME = sdio
endif
ifeq ($(CONFIG_USB_HCI), y)
HCI_NAME = usb
endif
ifeq ($(CONFIG_PCI_HCI), y)
HCI_NAME = pci
endif
_OS_INTFS_FILES := os_dep/osdep_service.o \
os_dep/linux/os_intfs.o \
os_dep/linux/$(HCI_NAME)_intf.o \
os_dep/linux/$(HCI_NAME)_ops_linux.o \
os_dep/linux/ioctl_linux.o \
os_dep/linux/xmit_linux.o \
os_dep/linux/mlme_linux.o \
os_dep/linux/recv_linux.o \
os_dep/linux/ioctl_cfg80211.o \
os_dep/linux/rtw_cfgvendor.o \
os_dep/linux/wifi_regd.o \
os_dep/linux/rtw_android.o \
os_dep/linux/rtw_proc.o \
os_dep/linux/rtw_rhashtable.o
ifeq ($(CONFIG_MP_INCLUDED), y)
_OS_INTFS_FILES += os_dep/linux/ioctl_mp.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_OS_INTFS_FILES += os_dep/linux/custom_gpio_linux.o
_OS_INTFS_FILES += os_dep/linux/$(HCI_NAME)_ops_linux.o
endif
ifeq ($(CONFIG_GSPI_HCI), y)
_OS_INTFS_FILES += os_dep/linux/custom_gpio_linux.o
_OS_INTFS_FILES += os_dep/linux/$(HCI_NAME)_ops_linux.o
endif
_HAL_INTFS_FILES := hal/hal_intf.o \
hal/hal_com.o \
hal/hal_com_phycfg.o \
hal/hal_phy.o \
hal/hal_dm.o \
hal/hal_dm_acs.o \
hal/hal_btcoex_wifionly.o \
hal/hal_btcoex.o \
hal/hal_mp.o \
hal/hal_mcc.o \
hal/hal_hci/hal_$(HCI_NAME).o \
hal/led/hal_led.o \
hal/led/hal_$(HCI_NAME)_led.o
EXTRA_CFLAGS += -I$(src)/platform
_PLATFORM_FILES := platform/platform_ops.o
EXTRA_CFLAGS += -I$(src)/hal/btc
########### HAL_RTL8188E #################################
ifeq ($(CONFIG_RTL8188E), y)
RTL871X = rtl8188e
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8189es
endif
ifeq ($(CONFIG_GSPI_HCI), y)
MODULE_NAME = 8189es
endif
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8188eu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8188ee
endif
EXTRA_CFLAGS += -DCONFIG_RTL8188E
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8188EPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_xmit.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8188e_s_fw.o \
hal/$(RTL871X)/hal8188e_t_fw.o \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
ifeq ($(CONFIG_GSPI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
endif
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188E_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188E_PCIE.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188E_SDIO.o
endif
endif
########### HAL_RTL8192E #################################
ifeq ($(CONFIG_RTL8192E), y)
RTL871X = rtl8192e
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8192es
endif
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8192eu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8192ee
endif
EXTRA_CFLAGS += -DCONFIG_RTL8192E
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8192EPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_xmit.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8192e_fw.o \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
ifeq ($(CONFIG_GSPI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
endif
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8192E_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8192E_PCIE.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8192E_SDIO.o
endif
ifeq ($(CONFIG_BT_COEXIST), y)
_BTC_FILES += hal/btc/halbtc8192e1ant.o \
hal/btc/halbtc8192e2ant.o
endif
endif
########### HAL_RTL8812A_RTL8821A #################################
ifneq ($(CONFIG_RTL8812A)_$(CONFIG_RTL8821A), n_n)
RTL871X = rtl8812a
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8812au
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8812ae
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8812as
endif
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8812PwrSeq.o \
hal/$(RTL871X)/Hal8821APwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_xmit.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
ifeq ($(CONFIG_GSPI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
endif
endif
ifeq ($(CONFIG_RTL8812A), y)
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8812A_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8812A_PCIE.o
endif
endif
ifeq ($(CONFIG_RTL8821A), y)
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8821A_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8821A_PCIE.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8821A_SDIO.o
endif
endif
ifeq ($(CONFIG_RTL8812A), y)
EXTRA_CFLAGS += -DCONFIG_RTL8812A
_HAL_INTFS_FILES += hal/rtl8812a/hal8812a_fw.o
endif
ifeq ($(CONFIG_RTL8821A), y)
ifeq ($(CONFIG_RTL8812A), n)
RTL871X = rtl8821a
ifeq ($(CONFIG_USB_HCI), y)
ifeq ($(CONFIG_BT_COEXIST), y)
MODULE_NAME := 8821au
else
MODULE_NAME := 8811au
endif
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME := 8821ae
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME := 8821as
endif
endif
EXTRA_CFLAGS += -DCONFIG_RTL8821A
_HAL_INTFS_FILES += hal/rtl8812a/hal8821a_fw.o
endif
ifeq ($(CONFIG_BT_COEXIST), y)
ifeq ($(CONFIG_RTL8812A), y)
_BTC_FILES += hal/btc/halbtc8812a1ant.o \
hal/btc/halbtc8812a2ant.o
endif
ifeq ($(CONFIG_RTL8821A), y)
_BTC_FILES += hal/btc/halbtc8821a1ant.o \
hal/btc/halbtc8821a2ant.o
endif
endif
endif
########### HAL_RTL8723B #################################
ifeq ($(CONFIG_RTL8723B), y)
RTL871X = rtl8723b
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8723bu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8723be
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8723bs
endif
EXTRA_CFLAGS += -DCONFIG_RTL8723B
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8723BPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8723b_fw.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723B_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723B_PCIE.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723B_SDIO.o
endif
_BTC_FILES += hal/btc/halbtc8723bwifionly.o
ifeq ($(CONFIG_BT_COEXIST), y)
_BTC_FILES += hal/btc/halbtc8723b1ant.o \
hal/btc/halbtc8723b2ant.o
endif
endif
########### HAL_RTL8814A #################################
ifeq ($(CONFIG_RTL8814A), y)
## ADD NEW VHT MP HW TX MODE ##
#EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
#CONFIG_MP_VHT_HW_TX_MODE = y
##########################################
RTL871X = rtl8814a
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8814au
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8814ae
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8814as
endif
EXTRA_CFLAGS += -DCONFIG_RTL8814A
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8814PwrSeq.o \
hal/$(RTL871X)/$(RTL871X)_xmit.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8814a_fw.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
ifeq ($(CONFIG_GSPI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
endif
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8814A_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8814A_PCIE.o
endif
ifeq ($(CONFIG_BT_COEXIST), y)
_BTC_FILES += hal/btc/halbtc8814a2ant.o
endif
endif
########### HAL_RTL8723C #################################
ifeq ($(CONFIG_RTL8723C), y)
RTL871X = rtl8703b
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8723cu
MODULE_SUB_NAME = 8703bu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8723ce
MODULE_SUB_NAME = 8703be
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8723cs
MODULE_SUB_NAME = 8703bs
endif
EXTRA_CFLAGS += -DCONFIG_RTL8703B
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8703BPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8703b_fw.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8703B_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8703B_PCIE.o
endif
ifeq ($(CONFIG_BT_COEXIST), y)
_BTC_FILES += hal/btc/halbtc8703b1ant.o
endif
endif
########### HAL_RTL8723D #################################
ifeq ($(CONFIG_RTL8723D), y)
RTL871X = rtl8723d
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8723du
MODULE_SUB_NAME = 8723du
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8723de
MODULE_SUB_NAME = 8723de
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8723ds
MODULE_SUB_NAME = 8723ds
endif
EXTRA_CFLAGS += -DCONFIG_RTL8723D
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8723DPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8723d_fw.o \
hal/$(RTL871X)/$(RTL871X)_lps_poff.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723D_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8723D_PCIE.o
endif
ifeq ($(CONFIG_BT_COEXIST), y)
_BTC_FILES += hal/btc/halbtc8723d1ant.o \
hal/btc/halbtc8723d2ant.o
endif
endif
########### HAL_RTL8188F #################################
ifeq ($(CONFIG_RTL8188F), y)
RTL871X = rtl8188f
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8188fu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8188fe
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8189fs
endif
EXTRA_CFLAGS += -DCONFIG_RTL8188F
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8188FPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8188f_fw.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188F_USB.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188F_SDIO.o
endif
endif
########### HAL_RTL8188GTV #################################
ifeq ($(CONFIG_RTL8188GTV), y)
RTL871X = rtl8188gtv
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8188gtvu
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8189gtvs
endif
EXTRA_CFLAGS += -DCONFIG_RTL8188GTV
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8188GTVPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8188gtv_fw.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_NAME)_recv.o
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188GTV_USB.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8188GTV_SDIO.o
endif
endif
########### HAL_RTL8822B #################################
ifeq ($(CONFIG_RTL8822B), y)
RTL871X := rtl8822b
ifeq ($(CONFIG_USB_HCI), y)
ifeq ($(CONFIG_BT_COEXIST), n)
MODULE_NAME = 8812bu
else
MODULE_NAME = 88x2bu
endif
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 88x2be
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 88x2bs
endif
endif
########### HAL_RTL8821C #################################
ifeq ($(CONFIG_RTL8821C), y)
RTL871X := rtl8821c
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8821cu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8821ce
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8821cs
endif
endif
########### HAL_RTL8710B #################################
ifeq ($(CONFIG_RTL8710B), y)
RTL871X = rtl8710b
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8710bu
MODULE_SUB_NAME = 8710bu
endif
EXTRA_CFLAGS += -DCONFIG_RTL8710B
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8710BPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8710b_fw.o \
hal/$(RTL871X)/$(RTL871X)_lps_poff.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES +=hal/efuse/$(RTL871X)/HalEfuseMask8710B_USB.o
endif
endif
########### HAL_RTL8192F #################################
ifeq ($(CONFIG_RTL8192F), y)
RTL871X = rtl8192f
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME = 8192fu
MODULE_SUB_NAME = 8192fu
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = 8192fe
MODULE_SUB_NAME = 8192fe
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 8192fs
MODULE_SUB_NAME = 8192fs
endif
EXTRA_CFLAGS += -DCONFIG_RTL8192F
_HAL_INTFS_FILES += hal/HalPwrSeqCmd.o \
hal/$(RTL871X)/Hal8192FPwrSeq.o\
hal/$(RTL871X)/$(RTL871X)_sreset.o
_HAL_INTFS_FILES += hal/$(RTL871X)/$(RTL871X)_hal_init.o \
hal/$(RTL871X)/$(RTL871X)_phycfg.o \
hal/$(RTL871X)/$(RTL871X)_rf6052.o \
hal/$(RTL871X)/$(RTL871X)_dm.o \
hal/$(RTL871X)/$(RTL871X)_rxdesc.o \
hal/$(RTL871X)/$(RTL871X)_cmd.o \
hal/$(RTL871X)/hal8192f_fw.o \
hal/$(RTL871X)/$(RTL871X)_lps_poff.o
_HAL_INTFS_FILES += \
hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_halinit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_led.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_xmit.o \
hal/$(RTL871X)/$(HCI_NAME)/rtl$(MODULE_SUB_NAME)_recv.o
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops_linux.o
else
_HAL_INTFS_FILES += hal/$(RTL871X)/$(HCI_NAME)/$(HCI_NAME)_ops.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_HAL_INTFS_FILES += hal/efuse/$(RTL871X)/HalEfuseMask8192F_SDIO.o
endif
ifeq ($(CONFIG_USB_HCI), y)
_HAL_INTFS_FILES += hal/efuse/$(RTL871X)/HalEfuseMask8192F_USB.o
endif
ifeq ($(CONFIG_PCI_HCI), y)
_HAL_INTFS_FILES += hal/efuse/$(RTL871X)/HalEfuseMask8192F_PCIE.o
endif
endif
########### HAL_RTL8822C #################################
ifeq ($(CONFIG_RTL8822C), y)
RTL871X := rtl8822c
ifeq ($(CONFIG_USB_HCI), y)
ifeq ($(CONFIG_BT_COEXIST), n)
MODULE_NAME = 8812cu
else
MODULE_NAME = 88x2cu
endif
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME = rtl88x2ce
endif
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME = 88x2cs
endif
endif
########### AUTO_CFG #################################
ifeq ($(CONFIG_AUTOCFG_CP), y)
ifeq ($(CONFIG_MULTIDRV), y)
$(shell cp $(TopDIR)/autoconf_multidrv_$(HCI_NAME)_linux.h $(TopDIR)/include/autoconf.h)
else
ifeq ($(CONFIG_RTL8188E)$(CONFIG_SDIO_HCI),yy)
$(shell cp $(TopDIR)/autoconf_rtl8189e_$(HCI_NAME)_linux.h $(TopDIR)/include/autoconf.h)
else ifeq ($(CONFIG_RTL8188F)$(CONFIG_SDIO_HCI),yy)
$(shell cp $(TopDIR)/autoconf_rtl8189f_$(HCI_NAME)_linux.h $(TopDIR)/include/autoconf.h)
else ifeq ($(CONFIG_RTL8723C),y)
$(shell cp $(TopDIR)/autoconf_rtl8723c_$(HCI_NAME)_linux.h $(TopDIR)/include/autoconf.h)
else
$(shell cp $(TopDIR)/autoconf_$(RTL871X)_$(HCI_NAME)_linux.h $(TopDIR)/include/autoconf.h)
endif
endif
endif
########### END OF PATH #################################
ifeq ($(CONFIG_USB_HCI), y)
ifeq ($(CONFIG_USB_AUTOSUSPEND), y)
EXTRA_CFLAGS += -DCONFIG_USB_AUTOSUSPEND
endif
endif
ifeq ($(CONFIG_MP_INCLUDED), y)
#MODULE_NAME := $(MODULE_NAME)_mp
EXTRA_CFLAGS += -DCONFIG_MP_INCLUDED
endif
ifeq ($(CONFIG_POWER_SAVING), y)
ifneq ($(CONFIG_IPS_MODE), default)
EXTRA_CFLAGS += -DRTW_IPS_MODE=$(CONFIG_IPS_MODE)
endif
ifneq ($(CONFIG_LPS_MODE), default)
EXTRA_CFLAGS += -DRTW_LPS_MODE=$(CONFIG_LPS_MODE)
endif
ifneq ($(CONFIG_WOW_LPS_MODE), default)
EXTRA_CFLAGS += -DRTW_WOW_LPS_MODE=$(CONFIG_WOW_LPS_MODE)
endif
EXTRA_CFLAGS += -DCONFIG_POWER_SAVING
endif
ifeq ($(CONFIG_HW_PWRP_DETECTION), y)
EXTRA_CFLAGS += -DCONFIG_HW_PWRP_DETECTION
endif
ifeq ($(CONFIG_BT_COEXIST), y)
EXTRA_CFLAGS += -DCONFIG_BT_COEXIST
endif
ifeq ($(CONFIG_WAPI_SUPPORT), y)
EXTRA_CFLAGS += -DCONFIG_WAPI_SUPPORT
endif
ifeq ($(CONFIG_EFUSE_CONFIG_FILE), y)
EXTRA_CFLAGS += -DCONFIG_EFUSE_CONFIG_FILE
#EFUSE_MAP_PATH
USER_EFUSE_MAP_PATH ?=
ifneq ($(USER_EFUSE_MAP_PATH),)
EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"$(USER_EFUSE_MAP_PATH)\"
else ifeq ($(MODULE_NAME), 8189es)
EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/system/etc/wifi/wifi_efuse_8189e.map\"
else ifeq ($(MODULE_NAME), 8723bs)
EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/system/etc/wifi/wifi_efuse_8723bs.map\"
else
EXTRA_CFLAGS += -DEFUSE_MAP_PATH=\"/system/etc/wifi/wifi_efuse_$(MODULE_NAME).map\"
endif
#WIFIMAC_PATH
USER_WIFIMAC_PATH ?=
ifneq ($(USER_WIFIMAC_PATH),)
EXTRA_CFLAGS += -DWIFIMAC_PATH=\"$(USER_WIFIMAC_PATH)\"
else
EXTRA_CFLAGS += -DWIFIMAC_PATH=\"/data/wifimac.txt\"
endif
endif
ifeq ($(CONFIG_EXT_CLK), y)
EXTRA_CFLAGS += -DCONFIG_EXT_CLK
endif
ifeq ($(CONFIG_TRAFFIC_PROTECT), y)
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
endif
ifeq ($(CONFIG_LOAD_PHY_PARA_FROM_FILE), y)
EXTRA_CFLAGS += -DCONFIG_LOAD_PHY_PARA_FROM_FILE
#EXTRA_CFLAGS += -DREALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER
EXTRA_CFLAGS += -DREALTEK_CONFIG_PATH=\"/lib/firmware/\"
endif
ifeq ($(CONFIG_TXPWR_BY_RATE), n)
EXTRA_CFLAGS += -DCONFIG_TXPWR_BY_RATE=0
else ifeq ($(CONFIG_TXPWR_BY_RATE), y)
EXTRA_CFLAGS += -DCONFIG_TXPWR_BY_RATE=1
endif
ifeq ($(CONFIG_TXPWR_BY_RATE_EN), n)
EXTRA_CFLAGS += -DCONFIG_TXPWR_BY_RATE_EN=0
else ifeq ($(CONFIG_TXPWR_BY_RATE_EN), y)
EXTRA_CFLAGS += -DCONFIG_TXPWR_BY_RATE_EN=1
else ifeq ($(CONFIG_TXPWR_BY_RATE_EN), auto)
EXTRA_CFLAGS += -DCONFIG_TXPWR_BY_RATE_EN=2
endif
ifeq ($(CONFIG_TXPWR_LIMIT), n)
EXTRA_CFLAGS += -DCONFIG_TXPWR_LIMIT=0
else ifeq ($(CONFIG_TXPWR_LIMIT), y)
EXTRA_CFLAGS += -DCONFIG_TXPWR_LIMIT=1
endif
ifeq ($(CONFIG_TXPWR_LIMIT_EN), n)
EXTRA_CFLAGS += -DCONFIG_TXPWR_LIMIT_EN=0
else ifeq ($(CONFIG_TXPWR_LIMIT_EN), y)
EXTRA_CFLAGS += -DCONFIG_TXPWR_LIMIT_EN=1
else ifeq ($(CONFIG_TXPWR_LIMIT_EN), auto)
EXTRA_CFLAGS += -DCONFIG_TXPWR_LIMIT_EN=2
endif
ifneq ($(CONFIG_RTW_CHPLAN), 0xFF)
EXTRA_CFLAGS += -DCONFIG_RTW_CHPLAN=$(CONFIG_RTW_CHPLAN)
endif
ifeq ($(CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY), y)
EXTRA_CFLAGS += -DCONFIG_CALIBRATE_TX_POWER_BY_REGULATORY
endif
ifeq ($(CONFIG_CALIBRATE_TX_POWER_TO_MAX), y)
EXTRA_CFLAGS += -DCONFIG_CALIBRATE_TX_POWER_TO_MAX
endif
ifeq ($(CONFIG_RTW_ADAPTIVITY_EN), disable)
EXTRA_CFLAGS += -DCONFIG_RTW_ADAPTIVITY_EN=0
else ifeq ($(CONFIG_RTW_ADAPTIVITY_EN), enable)
EXTRA_CFLAGS += -DCONFIG_RTW_ADAPTIVITY_EN=1
endif
ifeq ($(CONFIG_RTW_ADAPTIVITY_MODE), normal)
EXTRA_CFLAGS += -DCONFIG_RTW_ADAPTIVITY_MODE=0
else ifeq ($(CONFIG_RTW_ADAPTIVITY_MODE), carrier_sense)
EXTRA_CFLAGS += -DCONFIG_RTW_ADAPTIVITY_MODE=1
endif
ifeq ($(CONFIG_SIGNAL_SCALE_MAPPING), y)
EXTRA_CFLAGS += -DCONFIG_SIGNAL_SCALE_MAPPING
endif
ifeq ($(CONFIG_80211W), y)
EXTRA_CFLAGS += -DCONFIG_IEEE80211W
endif
ifeq ($(CONFIG_WOWLAN), y)
EXTRA_CFLAGS += -DCONFIG_WOWLAN -DRTW_WAKEUP_EVENT=$(CONFIG_WAKEUP_TYPE)
EXTRA_CFLAGS += -DRTW_SUSPEND_TYPE=$(CONFIG_SUSPEND_TYPE)
ifeq ($(CONFIG_WOW_STA_MIX), y)
EXTRA_CFLAGS += -DRTW_WOW_STA_MIX
endif
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_RTW_SDIO_PM_KEEP_POWER
endif
endif
ifeq ($(CONFIG_AP_WOWLAN), y)
EXTRA_CFLAGS += -DCONFIG_AP_WOWLAN
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_RTW_SDIO_PM_KEEP_POWER
endif
endif
ifeq ($(CONFIG_PNO_SUPPORT), y)
EXTRA_CFLAGS += -DCONFIG_PNO_SUPPORT
ifeq ($(CONFIG_PNO_SET_DEBUG), y)
EXTRA_CFLAGS += -DCONFIG_PNO_SET_DEBUG
endif
endif
ifeq ($(CONFIG_GPIO_WAKEUP), y)
EXTRA_CFLAGS += -DCONFIG_GPIO_WAKEUP
ifeq ($(CONFIG_ONE_PIN_GPIO), y)
EXTRA_CFLAGS += -DCONFIG_RTW_ONE_PIN_GPIO
endif
ifeq ($(CONFIG_HIGH_ACTIVE_DEV2HST), y)
EXTRA_CFLAGS += -DHIGH_ACTIVE_DEV2HST=1
else
EXTRA_CFLAGS += -DHIGH_ACTIVE_DEV2HST=0
endif
endif
ifeq ($(CONFIG_HIGH_ACTIVE_HST2DEV), y)
EXTRA_CFLAGS += -DHIGH_ACTIVE_HST2DEV=1
else
EXTRA_CFLAGS += -DHIGH_ACTIVE_HST2DEV=0
endif
ifneq ($(CONFIG_WAKEUP_GPIO_IDX), default)
EXTRA_CFLAGS += -DWAKEUP_GPIO_IDX=$(CONFIG_WAKEUP_GPIO_IDX)
endif
ifeq ($(CONFIG_RTW_SDIO_PM_KEEP_POWER), y)
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_RTW_SDIO_PM_KEEP_POWER
endif
endif
ifeq ($(CONFIG_REDUCE_TX_CPU_LOADING), y)
EXTRA_CFLAGS += -DCONFIG_REDUCE_TX_CPU_LOADING
endif
ifeq ($(CONFIG_BR_EXT), y)
BR_NAME = br0
EXTRA_CFLAGS += -DCONFIG_BR_EXT
EXTRA_CFLAGS += '-DCONFIG_BR_EXT_BRNAME="'$(BR_NAME)'"'
endif
ifeq ($(CONFIG_TDLS), y)
EXTRA_CFLAGS += -DCONFIG_TDLS
endif
ifeq ($(CONFIG_WIFI_MONITOR), y)
EXTRA_CFLAGS += -DCONFIG_WIFI_MONITOR
endif
ifeq ($(CONFIG_MCC_MODE), y)
EXTRA_CFLAGS += -DCONFIG_MCC_MODE
endif
ifeq ($(CONFIG_RTW_NAPI), y)
EXTRA_CFLAGS += -DCONFIG_RTW_NAPI
endif
ifeq ($(CONFIG_RTW_GRO), y)
EXTRA_CFLAGS += -DCONFIG_RTW_GRO
endif
ifeq ($(CONFIG_RTW_REPEATER_SON), y)
EXTRA_CFLAGS += -DCONFIG_RTW_REPEATER_SON
endif
ifeq ($(CONFIG_RTW_IPCAM_APPLICATION), y)
EXTRA_CFLAGS += -DCONFIG_RTW_IPCAM_APPLICATION
ifeq ($(CONFIG_WIFI_MONITOR), n)
EXTRA_CFLAGS += -DCONFIG_WIFI_MONITOR
endif
endif
ifeq ($(CONFIG_RTW_NETIF_SG), y)
EXTRA_CFLAGS += -DCONFIG_RTW_NETIF_SG
endif
ifeq ($(CONFIG_ICMP_VOQ), y)
EXTRA_CFLAGS += -DCONFIG_ICMP_VOQ
endif
ifeq ($(CONFIG_IP_R_MONITOR), y)
EXTRA_CFLAGS += -DCONFIG_IP_R_MONITOR
endif
ifeq ($(CONFIG_RTW_DISABLE_HW_PDN), y)
EXTRA_CFLAGS += -DCONFIG_RTW_DISABLE_HW_PDN
endif
ifeq ($(CONFIG_RTW_IOT_CCK_PD_INIT), y)
EXTRA_CFLAGS += -DCONFIG_RTW_IOT_CCK_PD_INIT
endif
ifeq ($(CONFIG_RTW_WIFI_HAL), y)
#EXTRA_CFLAGS += -DCONFIG_RTW_WIFI_HAL_DEBUG
EXTRA_CFLAGS += -DCONFIG_RTW_WIFI_HAL
EXTRA_CFLAGS += -DCONFIG_RTW_CFGVEDNOR_LLSTATS
EXTRA_CFLAGS += -DCONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
EXTRA_CFLAGS += -DCONFIG_RTW_CFGVEDNOR_RSSIMONITOR
EXTRA_CFLAGS += -DCONFIG_RTW_CFGVENDOR_WIFI_LOGGER
endif
ifeq ($(CONFIG_MP_VHT_HW_TX_MODE), y)
EXTRA_CFLAGS += -DCONFIG_MP_VHT_HW_TX_MODE
ifeq ($(CONFIG_PLATFORM_I386_PC), y)
## For I386 X86 ToolChain use Hardware FLOATING
EXTRA_CFLAGS += -mhard-float
else
## For ARM ToolChain use Hardware FLOATING
EXTRA_CFLAGS += -mfloat-abi=hard
endif
endif
ifeq ($(CONFIG_APPEND_VENDOR_IE_ENABLE), y)
EXTRA_CFLAGS += -DCONFIG_APPEND_VENDOR_IE_ENABLE
endif
ifeq ($(CONFIG_RTW_DEBUG), y)
EXTRA_CFLAGS += -DCONFIG_RTW_DEBUG
EXTRA_CFLAGS += -DRTW_LOG_LEVEL=$(CONFIG_RTW_LOG_LEVEL)
endif
EXTRA_CFLAGS += -DDM_ODM_SUPPORT_TYPE=0x04
ifeq ($(CONFIG_PLATFORM_I386_PC), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
SUBARCH := $(shell uname -m | sed -e s/i.86/i386/)
ARCH ?= $(SUBARCH)
CROSS_COMPILE ?=
KVER := $(shell uname -r)
KSRC := /lib/modules/$(KVER)/build
MODDESTDIR := /lib/modules/$(KVER)/kernel/drivers/net/wireless/
INSTALL_PREFIX :=
STAGINGMODDIR := /lib/modules/$(KVER)/kernel/drivers/staging
endif
ifeq ($(CONFIG_PLATFORM_NV_TK1), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_NV_TK1
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_P2P_IPS -DCONFIG_PLATFORM_ANDROID
# Enable this for Android 5.0
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
EXTRA_CFLAGS += -DRTW_VENDOR_EXT_SUPPORT
EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
ARCH ?= arm
CROSS_COMPILE := /mnt/newdisk/android_sdk/nvidia_tk1/android_L/prebuilts/gcc/linux-x86/arm/arm-eabi-4.8/bin/arm-eabi-
KSRC :=/mnt/newdisk/android_sdk/nvidia_tk1/android_L/out/target/product/shieldtablet/obj/KERNEL/
MODULE_NAME = wlan
endif
ifeq ($(CONFIG_PLATFORM_NV_TK1_UBUNTU), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_NV_TK1
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ARCH ?= arm
CROSS_COMPILE ?=
KVER := $(shell uname -r)
KSRC := /lib/modules/$(KVER)/build
MODDESTDIR := /lib/modules/$(KVER)/kernel/drivers/net/wireless/
INSTALL_PREFIX :=
endif
ifeq ($(CONFIG_PLATFORM_ACTIONS_ATM702X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID -DCONFIG_PLATFORM_ACTIONS_ATM702X
#ARCH := arm
ARCH := $(R_ARCH)
#CROSS_COMPILE := arm-none-linux-gnueabi-
CROSS_COMPILE := $(R_CROSS_COMPILE)
KVER:= 3.4.0
#KSRC := ../../../../build/out/kernel
KSRC := $(KERNEL_BUILD_PATH)
MODULE_NAME :=wlan
endif
ifeq ($(CONFIG_PLATFORM_ACTIONS_ATM705X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
#EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
# default setting for Android 4.1, 4.2, 4.3, 4.4
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ACTIONS_ATM705X
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
# Enable this for Android 5.0
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
_PLATFORM_FILES += platform/platform_arm_act_sdio.o
endif
ARCH := arm
CROSS_COMPILE := /opt/arm-2011.09/bin/arm-none-linux-gnueabi-
KSRC := /home/android_sdk/Action-semi/705a_android_L/android/kernel
endif
ifeq ($(CONFIG_PLATFORM_ARM_SUN50IW1P1), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN50IW1P1
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_RESUME_IN_WORKQUEUE
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
# Enable this for Android 5.0
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_PLATFORM_FILES += platform/platform_ARM_SUN50IW1P1_sdio.o
endif
ARCH := arm64
# ===Cross compile setting for Android 5.1(64) SDK ===
CROSS_COMPILE := /home/android_sdk/Allwinner/a64/android-51/lichee/out/sun50iw1p1/android/common/buildroot/external-toolchain/bin/aarch64-linux-gnu-
KSRC :=/home/android_sdk/Allwinner/a64/android-51/lichee/linux-3.10/
endif
ifeq ($(CONFIG_PLATFORM_TI_AM3517), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID -DCONFIG_PLATFORM_SHUTTLE
CROSS_COMPILE := arm-eabi-
KSRC := $(shell pwd)/../../../Android/kernel
ARCH := arm
endif
ifeq ($(CONFIG_PLATFORM_MSTAR_TITANIA12), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_MSTAR -DCONFIG_PLATFORM_MSTAR_TITANIA12
ARCH:=mips
CROSS_COMPILE:= /usr/src/Mstar_kernel/mips-4.3/bin/mips-linux-gnu-
KVER:= 2.6.28.9
KSRC:= /usr/src/Mstar_kernel/2.6.28.9/
endif
ifeq ($(CONFIG_PLATFORM_MSTAR), y)
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_MSTAR
EXTRA_CFLAGS += -DCONFIG_PLATFORM_MSTAR_HIGH
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX -DCONFIG_FIX_NR_BULKIN_BUFFER
endif
ARCH:=arm
CROSS_COMPILE:= /usr/src/bin/arm-none-linux-gnueabi-
KVER:= 3.1.10
KSRC:= /usr/src/Mstar_kernel/3.1.10/
endif
ifeq ($(CONFIG_PLATFORM_ANDROID_X86), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
SUBARCH := $(shell uname -m | sed -e s/i.86/i386/)
ARCH := $(SUBARCH)
CROSS_COMPILE := /media/DATA-2/android-x86/ics-x86_20120130/prebuilt/linux-x86/toolchain/i686-unknown-linux-gnu-4.2.1/bin/i686-unknown-linux-gnu-
KSRC := /media/DATA-2/android-x86/ics-x86_20120130/out/target/product/generic_x86/obj/kernel
MODULE_NAME :=wlan
endif
ifeq ($(CONFIG_PLATFORM_ANDROID_INTEL_X86), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ANDROID_INTEL_X86
EXTRA_CFLAGS += -DCONFIG_PLATFORM_INTEL_BYT
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_SKIP_SIGNAL_SCALE_MAPPING
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_RESUME_IN_WORKQUEUE
endif
endif
ifeq ($(CONFIG_PLATFORM_JB_X86), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
SUBARCH := $(shell uname -m | sed -e s/i.86/i386/)
ARCH := $(SUBARCH)
CROSS_COMPILE := /home/android_sdk/android-x86_JB/prebuilts/gcc/linux-x86/x86/i686-linux-android-4.7/bin/i686-linux-android-
KSRC := /home/android_sdk/android-x86_JB/out/target/product/x86/obj/kernel/
MODULE_NAME :=wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_PXA2XX), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH := arm
CROSS_COMPILE := arm-none-linux-gnueabi-
KVER := 2.6.34.1
KSRC ?= /usr/src/linux-2.6.34.1
endif
ifeq ($(CONFIG_PLATFORM_ARM_S3C2K4), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH := arm
CROSS_COMPILE := arm-linux-
KVER := 2.6.24.7_$(ARCH)
KSRC := /usr/src/kernels/linux-$(KVER)
endif
ifeq ($(CONFIG_PLATFORM_ARM_S3C6K4), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH := arm
CROSS_COMPILE := arm-none-linux-gnueabi-
KVER := 2.6.34.1
KSRC ?= /usr/src/linux-2.6.34.1
endif
ifeq ($(CONFIG_PLATFORM_RTD2880B), y)
EXTRA_CFLAGS += -DCONFIG_BIG_ENDIAN -DCONFIG_PLATFORM_RTD2880B
ARCH:=
CROSS_COMPILE:=
KVER:=
KSRC:=
endif
ifeq ($(CONFIG_PLATFORM_MIPS_RMI), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH:=mips
CROSS_COMPILE:=mipsisa32r2-uclibc-
KVER:=
KSRC:= /root/work/kernel_realtek
endif
ifeq ($(CONFIG_PLATFORM_MIPS_PLM), y)
EXTRA_CFLAGS += -DCONFIG_BIG_ENDIAN
ARCH:=mips
CROSS_COMPILE:=mipsisa32r2-uclibc-
KVER:=
KSRC:= /root/work/kernel_realtek
endif
ifeq ($(CONFIG_PLATFORM_MSTAR389), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_MSTAR389
ARCH:=mips
CROSS_COMPILE:= mips-linux-gnu-
KVER:= 2.6.28.10
KSRC:= /home/mstar/mstar_linux/2.6.28.9/
endif
ifeq ($(CONFIG_PLATFORM_MIPS_AR9132), y)
EXTRA_CFLAGS += -DCONFIG_BIG_ENDIAN
ARCH := mips
CROSS_COMPILE := mips-openwrt-linux-
KSRC := /home/alex/test_openwrt/tmp/linux-2.6.30.9
endif
ifeq ($(CONFIG_PLATFORM_DMP_PHILIPS), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DRTK_DMP_PLATFORM
ARCH := mips
#CROSS_COMPILE:=/usr/local/msdk-4.3.6-mips-EL-2.6.12.6-0.9.30.3/bin/mipsel-linux-
CROSS_COMPILE:=/usr/local/toolchain_mipsel/bin/mipsel-linux-
KSRC ?=/usr/local/Jupiter/linux-2.6.12
endif
ifeq ($(CONFIG_PLATFORM_RTK_DMP), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DRTK_DMP_PLATFORM -DCONFIG_WIRELESS_EXT
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
_PLATFORM_FILES += platform/platform_RTK_DMP_usb.o
endif
ARCH:=mips
CROSS_COMPILE:=mipsel-linux-
KVER:=
KSRC ?= /usr/src/DMP_Kernel/jupiter/linux-2.6.12
endif
ifeq ($(CONFIG_PLATFORM_MT53XX), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_MT53XX
ARCH:= arm
CROSS_COMPILE:= arm11_mtk_le-
KVER:= 2.6.27
KSRC?= /proj/mtk00802/BD_Compare/BDP/Dev/BDP_V301/BDP_Linux/linux-2.6.27
endif
ifeq ($(CONFIG_PLATFORM_ARM_MX51_241H), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_WISTRON_PLATFORM
ARCH := arm
CROSS_COMPILE := /opt/freescale/usr/local/gcc-4.1.2-glibc-2.5-nptl-3/arm-none-linux-gnueabi/bin/arm-none-linux-gnueabi-
KVER := 2.6.31
KSRC ?= /lib/modules/2.6.31-770-g0e46b52/source
endif
ifeq ($(CONFIG_PLATFORM_FS_MX61), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH := arm
CROSS_COMPILE := /home/share/CusEnv/FreeScale/arm-eabi-4.4.3/bin/arm-eabi-
KSRC ?= /home/share/CusEnv/FreeScale/FS_kernel_env
endif
ifeq ($(CONFIG_PLATFORM_ACTIONS_ATJ227X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ACTIONS_ATJ227X
ARCH := mips
CROSS_COMPILE := /home/cnsd4/project/actions/tools-2.6.27/bin/mipsel-linux-gnu-
KVER := 2.6.27
KSRC := /home/cnsd4/project/actions/linux-2.6.27.28
endif
ifeq ($(CONFIG_PLATFORM_TI_DM365), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_TI_DM365
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_RX
EXTRA_CFLAGS += -DCONFIG_SINGLE_XMIT_BUF -DCONFIG_SINGLE_RECV_BUF
ARCH := arm
#CROSS_COMPILE := /home/cnsd4/Appro/mv_pro_5.0/montavista/pro/devkit/arm/v5t_le/bin/arm_v5t_le-
#KSRC := /home/cnsd4/Appro/mv_pro_5.0/montavista/pro/devkit/lsp/ti-davinci/linux-dm365
CROSS_COMPILE := /opt/montavista/pro5.0/devkit/arm/v5t_le/bin/arm-linux-
KSRC:= /home/vivotek/lsp/DM365/kernel_platform/kernel/linux-2.6.18
KERNELOUTPUT := ${PRODUCTDIR}/tmp
KVER := 2.6.18
endif
ifeq ($(CONFIG_PLATFORM_MOZART), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_MOZART
ARCH := arm
CROSS_COMPILE := /home/vivotek/lsp/mozart3v2/Mozart3e_Toolchain/build_arm_nofpu/usr/bin/arm-linux-
KVER := $(shell uname -r)
KSRC:= /opt/Vivotek/lsp/mozart3v2/kernel_platform/kernel/mozart_kernel-1.17
KERNELOUTPUT := /home/pink/sample/ODM/IP8136W-VINT/tmp/kernel
endif
ifeq ($(CONFIG_PLATFORM_TEGRA3_CARDHU), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ARCH := arm
CROSS_COMPILE := /home/android_sdk/nvidia/tegra-16r3-partner-android-4.1_20120723/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
KSRC := /home/android_sdk/nvidia/tegra-16r3-partner-android-4.1_20120723/out/target/product/cardhu/obj/KERNEL
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_TEGRA4_DALMORE), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ARCH := arm
CROSS_COMPILE := /home/android_sdk/nvidia/tegra-17r9-partner-android-4.2-dalmore_20130131/prebuilts/gcc/linux-x86/arm/arm-eabi-4.6/bin/arm-eabi-
KSRC := /home/android_sdk/nvidia/tegra-17r9-partner-android-4.2-dalmore_20130131/out/target/product/dalmore/obj/KERNEL
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_TCC8900), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH := arm
CROSS_COMPILE := /home/android_sdk/Telechips/SDK_2304_20110613/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
KSRC := /home/android_sdk/Telechips/SDK_2304_20110613/kernel
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_TCC8920), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ARCH := arm
CROSS_COMPILE := /home/android_sdk/Telechips/v12.06_r1-tcc-android-4.0.4/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
KSRC := /home/android_sdk/Telechips/v12.06_r1-tcc-android-4.0.4/kernel
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_TCC8920_JB42), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ARCH := arm
CROSS_COMPILE := /home/android_sdk/Telechips/v13.03_r1-tcc-android-4.2.2_ds_patched/prebuilts/gcc/linux-x86/arm/arm-eabi-4.6/bin/arm-eabi-
KSRC := /home/android_sdk/Telechips/v13.03_r1-tcc-android-4.2.2_ds_patched/kernel
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_RK2818), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID -DCONFIG_PLATFORM_ROCKCHIPS
ARCH := arm
CROSS_COMPILE := /usr/src/release_fae_version/toolchain/arm-eabi-4.4.0/bin/arm-eabi-
KSRC := /usr/src/release_fae_version/kernel25_A7_281x
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_RK3188), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ANDROID -DCONFIG_PLATFORM_ROCKCHIPS
# default setting for Android 4.1, 4.2, 4.3, 4.4
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
# default setting for Power control
EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
EXTRA_CFLAGS += -DRTW_SUPPORT_PLATFORM_SHUTDOWN
# default setting for Special function
ARCH := arm
CROSS_COMPILE := /home/android_sdk/Rockchip/Rk3188/prebuilts/gcc/linux-x86/arm/arm-eabi-4.6/bin/arm-eabi-
KSRC := /home/android_sdk/Rockchip/Rk3188/kernel
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_RK3066), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_RK3066
EXTRA_CFLAGS += -DRTW_ENABLE_WIFI_CONTROL_FUNC
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DRTW_SUPPORT_PLATFORM_SHUTDOWN
endif
EXTRA_CFLAGS += -fno-pic
ARCH := arm
CROSS_COMPILE := /home/android_sdk/Rockchip/rk3066_20130607/prebuilts/gcc/linux-x86/arm/arm-linux-androideabi-4.6/bin/arm-linux-androideabi-
#CROSS_COMPILE := /home/android_sdk/Rockchip/Rk3066sdk/prebuilts/gcc/linux-x86/arm/arm-linux-androideabi-4.6/bin/arm-linux-androideabi-
KSRC := /home/android_sdk/Rockchip/Rk3066sdk/kernel
MODULE_NAME :=wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_URBETTER), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN #-DCONFIG_MINIMAL_MEMORY_USAGE
ARCH := arm
CROSS_COMPILE := /media/DATA-1/urbetter/arm-2009q3/bin/arm-none-linux-gnueabi-
KSRC := /media/DATA-1/urbetter/ics-urbetter/kernel
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_ARM_TI_PANDA), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN #-DCONFIG_MINIMAL_MEMORY_USAGE
ARCH := arm
#CROSS_COMPILE := /media/DATA-1/aosp/ics-aosp_20111227/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
#KSRC := /media/DATA-1/aosp/android-omap-panda-3.0_20120104
CROSS_COMPILE := /media/DATA-1/android-4.0/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
KSRC := /media/DATA-1/android-4.0/panda_kernel/omap
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_MIPS_JZ4760), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_MINIMAL_MEMORY_USAGE
ARCH ?= mips
CROSS_COMPILE ?= /mnt/sdb5/Ingenic/Umido/mips-4.3/bin/mips-linux-gnu-
KSRC ?= /mnt/sdb5/Ingenic/Umido/kernel
endif
ifeq ($(CONFIG_PLATFORM_SZEBOOK), y)
EXTRA_CFLAGS += -DCONFIG_BIG_ENDIAN
ARCH:=arm
CROSS_COMPILE:=/opt/crosstool2/bin/armeb-unknown-linux-gnueabi-
KVER:= 2.6.31.6
KSRC:= ../code/linux-2.6.31.6-2020/
endif
ifeq ($(CONFIG_PLATFORM_ARM_SUNxI), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUNxI
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
# default setting for A10-EVB mmc0
#EXTRA_CFLAGS += -DCONFIG_WITS_EVB_V13
_PLATFORM_FILES += platform/platform_ARM_SUNxI_sdio.o
endif
ARCH := arm
#CROSS_COMPILE := arm-none-linux-gnueabi-
CROSS_COMPILE=/home/android_sdk/Allwinner/a10/android-jb42/lichee-jb42/buildroot/output/external-toolchain/bin/arm-none-linux-gnueabi-
KVER := 3.0.8
#KSRC:= ../lichee/linux-3.0/
KSRC=/home/android_sdk/Allwinner/a10/android-jb42/lichee-jb42/linux-3.0
endif
ifeq ($(CONFIG_PLATFORM_ARM_SUN6I), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN6I
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2, 4.3, 4.4
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
# default setting for A31-EVB mmc0
EXTRA_CFLAGS += -DCONFIG_A31_EVB
_PLATFORM_FILES += platform/platform_ARM_SUNnI_sdio.o
endif
ARCH := arm
#Android-JB42
#CROSS_COMPILE := /home/android_sdk/Allwinner/a31/android-jb42/lichee/buildroot/output/external-toolchain/bin/arm-linux-gnueabi-
#KSRC :=/home/android_sdk/Allwinner/a31/android-jb42/lichee/linux-3.3
#ifeq ($(CONFIG_USB_HCI), y)
#MODULE_NAME := 8188eu_sw
#endif
# ==== Cross compile setting for kitkat-a3x_v4.5 =====
CROSS_COMPILE := /home/android_sdk/Allwinner/a31/kitkat-a3x_v4.5/lichee/buildroot/output/external-toolchain/bin/arm-linux-gnueabi-
KSRC :=/home/android_sdk/Allwinner/a31/kitkat-a3x_v4.5/lichee/linux-3.3
endif
ifeq ($(CONFIG_PLATFORM_ARM_SUN7I), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN7I
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2, 4.3, 4.4
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_PLATFORM_FILES += platform/platform_ARM_SUNnI_sdio.o
endif
ARCH := arm
# ===Cross compile setting for Android 4.2 SDK ===
#CROSS_COMPILE := /home/android_sdk/Allwinner/a20_evb/lichee/out/android/common/buildroot/external-toolchain/bin/arm-linux-gnueabi-
#KSRC := /home/android_sdk/Allwinner/a20_evb/lichee/linux-3.3
# ==== Cross compile setting for Android 4.3 SDK =====
#CROSS_COMPILE := /home/android_sdk/Allwinner/a20/android-jb43/lichee/out/android/common/buildroot/external-toolchain/bin/arm-linux-gnueabi-
#KSRC := /home/android_sdk/Allwinner/a20/android-jb43/lichee/linux-3.4
# ==== Cross compile setting for kitkat-a20_v4.4 =====
CROSS_COMPILE := /home/android_sdk/Allwinner/a20/kitkat-a20_v4.4/lichee/out/android/common/buildroot/external-toolchain/bin/arm-linux-gnueabi-
KSRC := /home/android_sdk/Allwinner/a20/kitkat-a20_v4.4/lichee/linux-3.4
endif
ifeq ($(CONFIG_PLATFORM_ARM_SUN8I_W3P1), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN8I
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN8I_W3P1
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_PLATFORM_FILES += platform/platform_ARM_SUNnI_sdio.o
endif
ARCH := arm
# ===Cross compile setting for Android 4.2 SDK ===
#CROSS_COMPILE := /home/android_sdk/Allwinner/a23/android-jb42/lichee/out/android/common/buildroot/external-toolchain/bin/arm-linux-gnueabi-
#KSRC :=/home/android_sdk/Allwinner/a23/android-jb42/lichee/linux-3.4
# ===Cross compile setting for Android 4.4 SDK ===
CROSS_COMPILE := /home/android_sdk/Allwinner/a23/android-kk44/lichee/out/android/common/buildroot/external-toolchain/bin/arm-linux-gnueabi-
KSRC :=/home/android_sdk/Allwinner/a23/android-kk44/lichee/linux-3.4
endif
ifeq ($(CONFIG_PLATFORM_ARM_SUN8I_W5P1), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN8I
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN8I_W5P1
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
# Enable this for Android 5.0
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_PLATFORM_FILES += platform/platform_ARM_SUNnI_sdio.o
endif
ARCH := arm
# ===Cross compile setting for Android L SDK ===
CROSS_COMPILE := /home/android_sdk/Allwinner/a33/android-L/lichee/out/sun8iw5p1/android/common/buildroot/external-toolchain/bin/arm-linux-gnueabi-
KSRC :=/home/android_sdk/Allwinner/a33/android-L/lichee/linux-3.4
endif
ifeq ($(CONFIG_PLATFORM_ACTIONS_ATV5201), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_ACTIONS_ATV5201
EXTRA_CFLAGS += -DCONFIG_SDIO_DISABLE_RXFIFO_POLLING_LOOP
ARCH := mips
CROSS_COMPILE := mipsel-linux-gnu-
KVER := $(KERNEL_VER)
KSRC:= $(CFGDIR)/../../kernel/linux-$(KERNEL_VER)
endif
ifeq ($(CONFIG_PLATFORM_ARM_RTD299X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ifeq ($(CONFIG_ANDROID), y)
# Enable this for Android 5.0
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
endif
#ARCH, CROSS_COMPILE, KSRC,and MODDESTDIR are provided by external makefile
INSTALL_PREFIX :=
endif
ifeq ($(CONFIG_PLATFORM_ARM_RTD299X_LG), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DRTW_P2P_GROUP_INTERFACE=1
EXTRA_CFLAGS += -DCONFIG_IFACE_NUMBER=3
#EXTRA_CFLAGS += -DCONFIG_FIX_HWPORT
EXTRA_CFLAGS += -DLGE_PRIVATE
EXTRA_CFLAGS += -DPURE_SUPPLICANT
EXTRA_CFLAGS += -DCONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP -DCONFIG_RTW_IOCTL_SET_COUNTRY
EXTRA_CFLAGS += -DDBG_RX_DFRAME_RAW_DATA
EXTRA_CFLAGS += -DRTW_REDUCE_SCAN_SWITCH_CH_TIME
ARCH ?= arm
KVER ?=
ifneq ($(PLATFORM), WEBOS)
$(info PLATFORM is empty)
CROSS_COMPILE ?= /mnt/newdisk/LGE/arm-lg115x-linux-gnueabi-4.8-2016.03-x86_64/bin/arm-lg115x-linux-gnueabi-
KSRC ?= /mnt/newdisk/LGE/linux-rockhopper_k3lp_drd4tv_423
endif
CROSS_COMPILE ?=
KSRC ?= $(LINUX_SRC)
INSTALL_PREFIX ?=
endif
ifeq ($(CONFIG_PLATFORM_HISILICON), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -DCONFIG_PLATFORM_HISILICON
ifeq ($(SUPPORT_CONCURRENT),y)
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
endif
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ARCH := arm
ifeq ($(CROSS_COMPILE),)
CROSS_COMPILE = arm-hisiv200-linux-
endif
MODULE_NAME := rtl8192eu
ifeq ($(KSRC),)
KSRC := ../../../../../../kernel/linux-3.4.y
endif
endif
ifeq ($(CONFIG_PLATFORM_HISILICON_HI3798), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON
EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON_HI3798
#EXTRA_CFLAGS += -DCONFIG_PLATFORM_HISILICON_HI3798_MV200_HDMI_DONGLE
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
# default setting for Android 5.x and later
#EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
# If system could power on and recognize Wi-Fi SDIO automatically,
# platfrom operations are not necessary.
#ifeq ($(CONFIG_SDIO_HCI), y)
#EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
#_PLATFORM_FILES += platform/platform_hisilicon_hi3798_sdio.o
#EXTRA_CFLAGS += -DCONFIG_HISI_SDIO_ID=1
#endif
ARCH ?= arm
CROSS_COMPILE ?= /HiSTBAndroidV600R003C00SPC021_git_0512/device/hisilicon/bigfish/sdk/tools/linux/toolchains/arm-histbv310-linux/bin/arm-histbv310-linux-
ifndef KSRC
KSRC := /HiSTBAndroidV600R003C00SPC021_git_0512/device/hisilicon/bigfish/sdk/source/kernel/linux-3.18.y
KSRC += O=/HiSTBAndroidV600R003C00SPC021_git_0512/out/target/product/Hi3798MV200/obj/KERNEL_OBJ
endif
ifeq ($(CONFIG_RTL8822B), y)
ifeq ($(CONFIG_SDIO_HCI), y)
CONFIG_RTL8822BS ?= m
USER_MODULE_NAME := rtl8822bs
endif
endif
endif
# Platform setting
ifeq ($(CONFIG_PLATFORM_ARM_SPREADTRUM_6820), y)
ifeq ($(CONFIG_ANDROID_2X), y)
EXTRA_CFLAGS += -DANDROID_2X
endif
EXTRA_CFLAGS += -DCONFIG_PLATFORM_SPRD
EXTRA_CFLAGS += -DPLATFORM_SPREADTRUM_6820
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ifeq ($(RTL871X), rtl8188e)
EXTRA_CFLAGS += -DSOFTAP_PS_DURATION=50
endif
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
_PLATFORM_FILES += platform/platform_sprd_sdio.o
endif
endif
ifeq ($(CONFIG_PLATFORM_ARM_SPREADTRUM_8810), y)
ifeq ($(CONFIG_ANDROID_2X), y)
EXTRA_CFLAGS += -DANDROID_2X
endif
EXTRA_CFLAGS += -DCONFIG_PLATFORM_SPRD
EXTRA_CFLAGS += -DPLATFORM_SPREADTRUM_8810
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
ifeq ($(RTL871X), rtl8188e)
EXTRA_CFLAGS += -DSOFTAP_PS_DURATION=50
endif
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
_PLATFORM_FILES += platform/platform_sprd_sdio.o
endif
endif
ifeq ($(CONFIG_PLATFORM_ARM_WMT), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
ifeq ($(CONFIG_SDIO_HCI), y)
_PLATFORM_FILES += platform/platform_ARM_WMT_sdio.o
endif
ARCH := arm
CROSS_COMPILE := /home/android_sdk/WonderMedia/wm8880-android4.4/toolchain/arm_201103_gcc4.5.2/mybin/arm_1103_le-
KSRC := /home/android_sdk/WonderMedia/wm8880-android4.4/kernel4.4/
MODULE_NAME :=8189es_kk
endif
ifeq ($(CONFIG_PLATFORM_RTK119X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
#EXTRA_CFLAGS += -DCONFIG_PLATFORM_ARM_SUN7I
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
#EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
#EXTRA_CFLAGS += -DCONFIG_#PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
#_PLATFORM_FILES += platform/platform_ARM_SUNxI_usb.o
endif
ifeq ($(CONFIG_SDIO_HCI), y)
_PLATFORM_FILES += platform/platform_ARM_SUNnI_sdio.o
endif
ARCH := arm
# ==== Cross compile setting for Android 4.4 SDK =====
#CROSS_COMPILE := arm-linux-gnueabihf-
KVER := 3.10.24
#KSRC :=/home/android_sdk/Allwinner/a20/android-kitkat44/lichee/linux-3.4
CROSS_COMPILE := /home/realtek/software_phoenix/phoenix/toolchain/usr/local/arm-2013.11/bin/arm-linux-gnueabihf-
KSRC := /home/realtek/software_phoenix/linux-kernel
MODULE_NAME := 8192eu
endif
ifeq ($(CONFIG_PLATFORM_RTK119X_AM), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_RTK119X_AM
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE -DCONFIG_FULL_CH_IN_P2P_HANDSHAKE
EXTRA_CFLAGS += -DCONFIG_IFACE_NUMBER=3
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
endif
ARCH := arm
#CROSS_COMPILE := arm-linux-gnueabihf-
KVER := 3.10.24
#KSRC :=
CROSS_COMPILE :=
endif
ifeq ($(CONFIG_PLATFORM_RTK129X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DRTK_129X_PLATFORM
EXTRA_CFLAGS += -DCONFIG_TRAFFIC_PROTECT
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
#EXTRA_CFLAGS += -DCONFIG_P2P_IPS -DCONFIG_QOS_OPTIMIZATION
EXTRA_CFLAGS += -DCONFIG_QOS_OPTIMIZATION
# Enable this for Android 5.0
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
ifeq ($(CONFIG_RTL8821C)$(CONFIG_SDIO_HCI),yy)
EXTRA_CFLAGS += -DCONFIG_WAKEUP_GPIO_INPUT_MODE
EXTRA_CFLAGS += -DCONFIG_BT_WAKE_HST_OPEN_DRAIN
endif
EXTRA_CFLAGS += -Wno-error=date-time
# default setting for Android 7.0
ifeq ($(RTK_ANDROID_VERSION), nougat)
EXTRA_CFLAGS += -DRTW_P2P_GROUP_INTERFACE=1
endif
#EXTRA_CFLAGS += -DCONFIG_#PLATFORM_OPS
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
endif
ARCH := arm64
# ==== Cross compile setting for Android 4.4 SDK =====
#CROSS_COMPILE := arm-linux-gnueabihf-
#KVER := 4.1.10
#CROSS_COMPILE := $(CROSS)
#KSRC := $(LINUX_KERNEL_PATH)
CROSS_COMPILE := /home/android_sdk/DHC/trunk-6.0.0_r1-QA160627/phoenix/toolchain/asdk64-4.9.4-a53-EL-3.10-g2.19-a64nt-160307/bin/asdk64-linux-
KSRC := /home/android_sdk/DHC/trunk-6.0.0_r1-QA160627/linux-kernel
endif
ifeq ($(CONFIG_PLATFORM_RTK390X), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_PLATFORM_RTK390X
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_RTW_NETIF_SG
ifeq ($(CONFIG_USB_HCI), y)
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
endif
ARCH:=rlx
CROSS_COMPILE:=mips-linux-
KSRC:= /home/realtek/share/Develop/IPCAM_SDK/RealSil/rts3901_sdk_v1.2_vanilla/linux-3.10
endif
ifeq ($(CONFIG_PLATFORM_NOVATEK_NT72668), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_NOVATEK_NT72668
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_RX
EXTRA_CFLAGS += -DCONFIG_USE_USB_BUFFER_ALLOC_TX
ARCH ?= arm
CROSS_COMPILE := arm-linux-gnueabihf-
KVER := 3.8.0
KSRC := /Custom/Novatek/TCL/linux-3.8_header
#KSRC := $(KERNELDIR)
endif
ifeq ($(CONFIG_PLATFORM_ARM_TCC8930_JB42), y)
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android 4.1, 4.2
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211 -DRTW_USE_CFG80211_STA_EVENT
ARCH := arm
CROSS_COMPILE := /home/android_sdk/Telechips/v13.05_r1-tcc-android-4.2.2_tcc893x-evm_build/prebuilts/gcc/linux-x86/arm/arm-eabi-4.6/bin/arm-eabi-
KSRC := /home/android_sdk/Telechips/v13.05_r1-tcc-android-4.2.2_tcc893x-evm_build/kernel
MODULE_NAME := wlan
endif
ifeq ($(CONFIG_PLATFORM_RTL8197D), y)
EXTRA_CFLAGS += -DCONFIG_BIG_ENDIAN -DCONFIG_PLATFORM_RTL8197D
export DIR_LINUX=$(shell pwd)/../SDK/rlxlinux-sdk321-v50/linux-2.6.30
ARCH ?= rlx
CROSS_COMPILE:= $(DIR_LINUX)/../toolchain/rsdk-1.5.5-5281-EB-2.6.30-0.9.30.3-110714/bin/rsdk-linux-
KSRC := $(DIR_LINUX)
endif
ifeq ($(CONFIG_PLATFORM_AML_S905), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_AML_S905
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN -fno-pic
# default setting for Android
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
# default setting for Android 5.x and later
EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
ifeq ($(CONFIG_SDIO_HCI), y)
EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
_PLATFORM_FILES += platform/platform_aml_s905_sdio.o
endif
ARCH ?= arm64
CROSS_COMPILE ?= /4.4_S905L_8822bs_compile/gcc-linaro-aarch64-linux-gnu-4.9-2014.09_linux/bin/aarch64-linux-gnu-
ifndef KSRC
KSRC := /4.4_S905L_8822bs_compile/common
# To locate output files in a separate directory.
KSRC += O=/4.4_S905L_8822bs_compile/KERNEL_OBJ
endif
ifeq ($(CONFIG_RTL8822B), y)
ifeq ($(CONFIG_SDIO_HCI), y)
CONFIG_RTL8822BS ?= m
USER_MODULE_NAME := 8822bs
endif
endif
endif
ifeq ($(CONFIG_PLATFORM_ZTE_ZX296716), y)
EXTRA_CFLAGS += -Wno-error=date-time
EXTRA_CFLAGS += -DCONFIG_PLATFORM_ZTE_ZX296716
EXTRA_CFLAGS += -DCONFIG_LITTLE_ENDIAN
# default setting for Android
EXTRA_CFLAGS += -DCONFIG_CONCURRENT_MODE
EXTRA_CFLAGS += -DCONFIG_IOCTL_CFG80211
EXTRA_CFLAGS += -DRTW_USE_CFG80211_STA_EVENT
# default setting for Android 5.x and later
#EXTRA_CFLAGS += -DCONFIG_RADIO_WORK
ifeq ($(CONFIG_SDIO_HCI), y)
# mark this temporarily
#EXTRA_CFLAGS += -DCONFIG_PLATFORM_OPS
#_PLATFORM_FILES += platform/platform_zte_zx296716_sdio.o
endif
ARCH ?= arm64
CROSS_COMPILE ?=
KSRC ?=
ifeq ($(CONFIG_RTL8822B), y)
ifeq ($(CONFIG_SDIO_HCI), y)
CONFIG_RTL8822BS ?= m
USER_MODULE_NAME := 8822bs
endif
endif
endif
########### CUSTOMER ################################
ifeq ($(CONFIG_CUSTOMER_HUAWEI_GENERAL), y)
CONFIG_CUSTOMER_HUAWEI = y
endif
ifeq ($(CONFIG_CUSTOMER_HUAWEI), y)
EXTRA_CFLAGS += -DCONFIG_HUAWEI_PROC
endif
ifeq ($(CONFIG_MULTIDRV), y)
ifeq ($(CONFIG_SDIO_HCI), y)
MODULE_NAME := rtw_sdio
endif
ifeq ($(CONFIG_USB_HCI), y)
MODULE_NAME := rtw_usb
endif
ifeq ($(CONFIG_PCI_HCI), y)
MODULE_NAME := rtw_pci
endif
endif
USER_MODULE_NAME ?=
ifneq ($(USER_MODULE_NAME),)
MODULE_NAME := $(USER_MODULE_NAME)
endif
ifneq ($(KERNELRELEASE),)
########### this part for *.mk ############################
include $(src)/hal/phydm/phydm.mk
########### HAL_RTL8822B #################################
ifeq ($(CONFIG_RTL8822B), y)
include $(src)/rtl8822b.mk
endif
########### HAL_RTL8821C #################################
ifeq ($(CONFIG_RTL8821C), y)
include $(src)/rtl8821c.mk
endif
########### HAL_RTL8822C #################################
ifeq ($(CONFIG_RTL8822C), y)
include $(src)/rtl8822c.mk
endif
rtk_core := core/rtw_cmd.o \
core/rtw_security.o \
core/rtw_debug.o \
core/rtw_io.o \
core/rtw_ioctl_query.o \
core/rtw_ioctl_set.o \
core/rtw_ieee80211.o \
core/rtw_mlme.o \
core/rtw_mlme_ext.o \
core/rtw_mi.o \
core/rtw_wlan_util.o \
core/rtw_vht.o \
core/rtw_pwrctrl.o \
core/rtw_rf.o \
core/rtw_chplan.o \
core/rtw_recv.o \
core/rtw_sta_mgt.o \
core/rtw_ap.o \
core/mesh/rtw_mesh.o \
core/mesh/rtw_mesh_pathtbl.o \
core/mesh/rtw_mesh_hwmp.o \
core/rtw_xmit.o \
core/rtw_p2p.o \
core/rtw_rson.o \
core/rtw_tdls.o \
core/rtw_br_ext.o \
core/rtw_iol.o \
core/rtw_sreset.o \
core/rtw_btcoex_wifionly.o \
core/rtw_btcoex.o \
core/rtw_beamforming.o \
core/rtw_odm.o \
core/rtw_rm.o \
core/rtw_rm_fsm.o \
core/efuse/rtw_efuse.o
ifeq ($(CONFIG_SDIO_HCI), y)
rtk_core += core/rtw_sdio.o
endif
$(MODULE_NAME)-y += $(rtk_core)
$(MODULE_NAME)-$(CONFIG_WAPI_SUPPORT) += core/rtw_wapi.o \
core/rtw_wapi_sms4.o
$(MODULE_NAME)-y += $(_OS_INTFS_FILES)
$(MODULE_NAME)-y += $(_HAL_INTFS_FILES)
$(MODULE_NAME)-y += $(_PHYDM_FILES)
$(MODULE_NAME)-y += $(_BTC_FILES)
$(MODULE_NAME)-y += $(_PLATFORM_FILES)
$(MODULE_NAME)-$(CONFIG_MP_INCLUDED) += core/rtw_mp.o
ifeq ($(CONFIG_RTL8723B), y)
$(MODULE_NAME)-$(CONFIG_MP_INCLUDED)+= core/rtw_bt_mp.o
endif
obj-$(CONFIG_RTL8822CE) := $(MODULE_NAME).o
else
export CONFIG_RTL8822CE = m
all: modules
modules:
$(MAKE) ARCH=$(ARCH) CROSS_COMPILE=$(CROSS_COMPILE) -C $(KSRC) M=$(shell pwd) modules
strip:
$(CROSS_COMPILE)strip $(MODULE_NAME).ko --strip-unneeded
install:
install -p -m 644 $(MODULE_NAME).ko $(MODDESTDIR)
/sbin/depmod -a ${KVER}
uninstall:
rm -f $(MODDESTDIR)/$(MODULE_NAME).ko
/sbin/depmod -a ${KVER}
backup_rtlwifi:
@echo "Making backup rtlwifi drivers"
ifneq (,$(wildcard $(STAGINGMODDIR)/rtl*))
@tar cPf $(wildcard $(STAGINGMODDIR))/backup_rtlwifi_driver.tar $(wildcard $(STAGINGMODDIR)/rtl*)
@rm -rf $(wildcard $(STAGINGMODDIR)/rtl*)
endif
ifneq (,$(wildcard $(MODDESTDIR)realtek))
@tar cPf $(MODDESTDIR)backup_rtlwifi_driver.tar $(MODDESTDIR)realtek
@rm -fr $(MODDESTDIR)realtek
endif
ifneq (,$(wildcard $(MODDESTDIR)rtl*))
@tar cPf $(MODDESTDIR)../backup_rtlwifi_driver.tar $(wildcard $(MODDESTDIR)rtl*)
@rm -fr $(wildcard $(MODDESTDIR)rtl*)
endif
@/sbin/depmod -a ${KVER}
@echo "Please reboot your system"
restore_rtlwifi:
@echo "Restoring backups"
ifneq (,$(wildcard $(STAGINGMODDIR)/backup_rtlwifi_driver.tar))
@tar xPf $(STAGINGMODDIR)/backup_rtlwifi_driver.tar
@rm $(STAGINGMODDIR)/backup_rtlwifi_driver.tar
endif
ifneq (,$(wildcard $(MODDESTDIR)backup_rtlwifi_driver.tar))
@tar xPf $(MODDESTDIR)backup_rtlwifi_driver.tar
@rm $(MODDESTDIR)backup_rtlwifi_driver.tar
endif
ifneq (,$(wildcard $(MODDESTDIR)../backup_rtlwifi_driver.tar))
@tar xPf $(MODDESTDIR)../backup_rtlwifi_driver.tar
@rm $(MODDESTDIR)../backup_rtlwifi_driver.tar
endif
@/sbin/depmod -a ${KVER}
@echo "Please reboot your system"
config_r:
@echo "make config"
/bin/bash script/Configure script/config.in
.PHONY: modules clean
clean:
#$(MAKE) -C $(KSRC) M=$(shell pwd) clean
cd hal ; rm -fr */*/*/*.mod.c */*/*/*.mod */*/*/*.o */*/*/.*.cmd */*/*/*.ko
cd hal ; rm -fr */*/*.mod.c */*/*.mod */*/*.o */*/.*.cmd */*/*.ko
cd hal ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
cd hal ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
cd core ; rm -fr */*.mod.c */*.mod */*.o */.*.cmd */*.ko
cd core ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
cd os_dep/linux ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
cd os_dep ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
cd platform ; rm -fr *.mod.c *.mod *.o .*.cmd *.ko
rm -fr Module.symvers ; rm -fr Module.markers ; rm -fr modules.order
rm -fr *.mod.c *.mod *.o .*.cmd *.ko *~
rm -fr .tmp_versions
endif
================================================
FILE: README.md
================================================
[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/0)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/1)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/2)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/3)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/4)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/5)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/6)[](https://sourcerer.io/fame/juanro49/juanro49/rtl88x2ce-dkms/links/7)
# RTL88x2CE dkms module driver
Download complete driver package with guides [from this repo](https://github.com/XAIOThaifeng/realtek-linux/tree/master/RTL8822CE).
## Instalación
### [PatoJAD Repo](https://patojad.com.ar/repositorio/) (desactualizado)
```
echo 'deb https://gitlab.com/patojad/repository/raw/patojad/debs/ patojad main
' | sudo tee /etc/apt/sources.list.d/patojad.list
wget -qO - https://gitlab.com/LynxOS/repository/raw/lynxos/LynxPub.gpg | apt-key add -
sudo apt update
sudo apt install rtl88x2ce-dkms
```
### Paquete deb
```
wget https://github.com/juanro49/rtl88x2ce-dkms/releases/download/5.7.3_35403_20210523/rtl88x2ce-dkms_35403_amd64.deb
sudo dpkg -i rtl88x2ce-dkms_35403_amd64.deb
```
### Desde código fuente
```
git clone https://github.com/juanro49/rtl88x2ce-dkms.git
sudo cp rtl88x2ce-dkms/rtw88_blacklist.conf /etc/modprobe.d/rtw88_blacklist.conf
sudo mkdir /usr/src/rtl88x2ce-35403
sudo cp -Rv rtl88x2ce-dkms/* /usr/src/rtl88x2ce-35403/
sudo dkms add -m rtl88x2ce -v 35403
sudo dkms build -m rtl88x2ce -v 35403
sudo dkms install -m rtl88x2ce -v 35403
```
## Iniciar módulo
`sudo modprobe rtl88x2ce`
Driver testeado en:
[MSI Alpha 15](https://plume.nogafam.es/~/ElBlogDeJuanro/Review%20portatil%20MSI%20Alpha%2015%20A3DDK) con [SparkyLinux Rolling](https://sparkylinux.org/)
Network controller: Realtek Semiconductor Co., Ltd. RTL8822CE 802.11ac PCIe Wireless Network Adapter
## Donaciones
[
](https://coindrop.to/juanro49) [
](https://liberapay.com/juanro49/donate) [
](https://cesium.duniter.io/api/#/v1/payment/5eETo8btrVGYTTyC5nAvqCPmLBok4aRLhxiGP7dy3Wqw?comment=Donaci%C3%B3n%20github)
================================================
FILE: clean
================================================
#!/bin/bash
rmmod 8192cu
rmmod 8192ce
rmmod 8192du
rmmod 8192de
================================================
FILE: core/efuse/rtw_efuse.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_EFUSE_C_
#include
#include
#include "../hal/efuse/efuse_mask.h"
/*------------------------Define local variable------------------------------*/
u8 fakeEfuseBank = {0};
u32 fakeEfuseUsedBytes = {0};
u8 fakeEfuseContent[EFUSE_MAX_HW_SIZE] = {0};
u8 fakeEfuseInitMap[EFUSE_MAX_MAP_LEN] = {0};
u8 fakeEfuseModifiedMap[EFUSE_MAX_MAP_LEN] = {0};
u32 BTEfuseUsedBytes = {0};
u8 BTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
u8 BTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN] = {0};
u8 BTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN] = {0};
u32 fakeBTEfuseUsedBytes = {0};
u8 fakeBTEfuseContent[EFUSE_MAX_BT_BANK][EFUSE_MAX_HW_SIZE];
u8 fakeBTEfuseInitMap[EFUSE_BT_MAX_MAP_LEN] = {0};
u8 fakeBTEfuseModifiedMap[EFUSE_BT_MAX_MAP_LEN] = {0};
u8 maskfileBuffer[64];
u8 btmaskfileBuffer[64];
/*------------------------Define local variable------------------------------*/
BOOLEAN rtw_file_efuse_IsMasked(PADAPTER pAdapter, u16 Offset, u8 *maskbuf)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (pAdapter->registrypriv.boffefusemask)
return FALSE;
if (c < 4) /* Upper double word */
result = (maskbuf[r] & (0x10 << c));
else
result = (maskbuf[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
BOOLEAN efuse_IsBT_Masked(PADAPTER pAdapter, u16 Offset)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
if (pAdapter->registrypriv.boffefusemask)
return FALSE;
#ifdef CONFIG_USB_HCI
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return (IS_BT_MASKED(8822C, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#ifdef CONFIG_PCI_HCI
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return (IS_BT_MASKED(8822C, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#ifdef CONFIG_SDIO_HCI
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return (IS_BT_MASKED(8822C, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
return FALSE;
}
void rtw_bt_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
#ifdef CONFIG_USB_HCI
if (IS_HARDWARE_TYPE_8822CU(pAdapter))
GET_MASK_ARRAY(8822C, _MUSB, pArray);
#endif
#ifdef CONFIG_PCI_HCI
if (IS_HARDWARE_TYPE_8822CE(pAdapter))
GET_MASK_ARRAY(8822C, _MPCIE, pArray);
#endif
#ifdef CONFIG_SDIO_HCI
if (IS_HARDWARE_TYPE_8822CS(pAdapter))
GET_MASK_ARRAY(8822C, _MSDIO, pArray);
#endif
}
u16 rtw_get_bt_efuse_mask_arraylen(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
#ifdef CONFIG_USB_HCI
if (IS_HARDWARE_TYPE_8822CU(pAdapter))
return GET_BT_MASK_ARRAY_LEN(8822C, _MUSB);
#endif
#ifdef CONFIG_PCI_HCI
if (IS_HARDWARE_TYPE_8822CE(pAdapter))
return GET_BT_MASK_ARRAY_LEN(8822C, _MPCIE);
#endif
#ifdef CONFIG_SDIO_HCI
if (IS_HARDWARE_TYPE_8822CS(pAdapter))
return GET_BT_MASK_ARRAY_LEN(8822C, _MSDIO);
#endif
return 0;
}
BOOLEAN efuse_IsMasked(PADAPTER pAdapter, u16 Offset)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
if (pAdapter->registrypriv.boffefusemask)
return FALSE;
#ifdef CONFIG_USB_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
return (IS_MASKED(8188E, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8812A)
if (IS_HARDWARE_TYPE_8812(pAdapter))
return (IS_MASKED(8812A, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8821A)
#if 0
if (IS_HARDWARE_TYPE_8811AU(pAdapter))
return (IS_MASKED(8811A, _MUSB, Offset)) ? TRUE : FALSE;
#endif
if (IS_HARDWARE_TYPE_8821(pAdapter))
return (IS_MASKED(8821A, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(pAdapter))
return (IS_MASKED(8192E, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(pAdapter))
return (IS_MASKED(8723B, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8703B)
if (IS_HARDWARE_TYPE_8703B(pAdapter))
return (IS_MASKED(8703B, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(pAdapter))
return (IS_MASKED(8814A, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8188F)
if (IS_HARDWARE_TYPE_8188F(pAdapter))
return (IS_MASKED(8188F, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8188GTV)
if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
return (IS_MASKED(8188GTV, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
return (IS_MASKED(8822B, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8723D)
if (IS_HARDWARE_TYPE_8723D(pAdapter))
return (IS_MASKED(8723D, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8710B)
if (IS_HARDWARE_TYPE_8710B(pAdapter))
return (IS_MASKED(8710B, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CU(pAdapter))
return (IS_MASKED(8821C, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FU(pAdapter))
return (IS_MASKED(8192F, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return (IS_MASKED(8822C, _MUSB, Offset)) ? TRUE : FALSE;
#endif
#endif /*CONFIG_USB_HCI*/
#ifdef CONFIG_PCI_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
return (IS_MASKED(8188E, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(pAdapter))
return (IS_MASKED(8192E, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8812A)
if (IS_HARDWARE_TYPE_8812(pAdapter))
return (IS_MASKED(8812A, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821(pAdapter))
return (IS_MASKED(8821A, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(pAdapter))
return (IS_MASKED(8723B, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(pAdapter))
return (IS_MASKED(8814A, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
return (IS_MASKED(8822B, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CE(pAdapter))
return (IS_MASKED(8821C, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FE(pAdapter))
return (IS_MASKED(8192F, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return (IS_MASKED(8822C, _MPCIE, Offset)) ? TRUE : FALSE;
#endif
#endif /*CONFIG_PCI_HCI*/
#ifdef CONFIG_SDIO_HCI
#ifdef CONFIG_RTL8188E_SDIO
if (IS_HARDWARE_TYPE_8188E(pAdapter))
return (IS_MASKED(8188E, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#ifdef CONFIG_RTL8723B
if (IS_HARDWARE_TYPE_8723BS(pAdapter))
return (IS_MASKED(8723B, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#ifdef CONFIG_RTL8188F
if (IS_HARDWARE_TYPE_8188F(pAdapter))
return (IS_MASKED(8188F, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#ifdef CONFIG_RTL8188GTV
if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
return (IS_MASKED(8188GTV, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#ifdef CONFIG_RTL8192E
if (IS_HARDWARE_TYPE_8192ES(pAdapter))
return (IS_MASKED(8192E, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821S(pAdapter))
return (IS_MASKED(8821A, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CS(pAdapter))
return (IS_MASKED(8821C, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
return (IS_MASKED(8822B, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FS(pAdapter))
return (IS_MASKED(8192F, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return (IS_MASKED(8822C, _MSDIO, Offset)) ? TRUE : FALSE;
#endif
#endif /*CONFIG_SDIO_HCI*/
return FALSE;
}
void rtw_efuse_mask_array(PADAPTER pAdapter, u8 *pArray)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
#ifdef CONFIG_USB_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
GET_MASK_ARRAY(8188E, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8812A)
if (IS_HARDWARE_TYPE_8812(pAdapter))
GET_MASK_ARRAY(8812A, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821(pAdapter))
GET_MASK_ARRAY(8821A, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(pAdapter))
GET_MASK_ARRAY(8192E, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(pAdapter))
GET_MASK_ARRAY(8723B, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8703B)
if (IS_HARDWARE_TYPE_8703B(pAdapter))
GET_MASK_ARRAY(8703B, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8188F)
if (IS_HARDWARE_TYPE_8188F(pAdapter))
GET_MASK_ARRAY(8188F, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8188GTV)
if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
GET_MASK_ARRAY(8188GTV, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(pAdapter))
GET_MASK_ARRAY(8814A, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
GET_MASK_ARRAY(8822B, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CU(pAdapter))
GET_MASK_ARRAY(8821C, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FU(pAdapter))
GET_MASK_ARRAY(8192F, _MUSB, pArray);
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
GET_MASK_ARRAY(8822C, _MUSB, pArray);
#endif
#endif /*CONFIG_USB_HCI*/
#ifdef CONFIG_PCI_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
GET_MASK_ARRAY(8188E, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(pAdapter))
GET_MASK_ARRAY(8192E, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8812A)
if (IS_HARDWARE_TYPE_8812(pAdapter))
GET_MASK_ARRAY(8812A, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821(pAdapter))
GET_MASK_ARRAY(8821A, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(pAdapter))
GET_MASK_ARRAY(8723B, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(pAdapter))
GET_MASK_ARRAY(8814A, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
GET_MASK_ARRAY(8822B, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CE(pAdapter))
GET_MASK_ARRAY(8821C, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FE(pAdapter))
GET_MASK_ARRAY(8192F, _MPCIE, pArray);
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
GET_MASK_ARRAY(8822C, _MPCIE, pArray);
#endif
#endif /*CONFIG_PCI_HCI*/
#ifdef CONFIG_SDIO_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
GET_MASK_ARRAY(8188E, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723BS(pAdapter))
GET_MASK_ARRAY(8723B, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8188F)
if (IS_HARDWARE_TYPE_8188F(pAdapter))
GET_MASK_ARRAY(8188F, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8188GTV)
if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
GET_MASK_ARRAY(8188GTV, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192ES(pAdapter))
GET_MASK_ARRAY(8192E, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821S(pAdapter))
GET_MASK_ARRAY(8821A, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CS(pAdapter))
GET_MASK_ARRAY(8821C , _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
GET_MASK_ARRAY(8822B , _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FS(pAdapter))
GET_MASK_ARRAY(8192F, _MSDIO, pArray);
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
GET_MASK_ARRAY(8822C , _MSDIO, pArray);
#endif
#endif /*CONFIG_SDIO_HCI*/
}
u16 rtw_get_efuse_mask_arraylen(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
#ifdef CONFIG_USB_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
return GET_MASK_ARRAY_LEN(8188E, _MUSB);
#endif
#if defined(CONFIG_RTL8812A)
if (IS_HARDWARE_TYPE_8812(pAdapter))
return GET_MASK_ARRAY_LEN(8812A, _MUSB);
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821(pAdapter))
return GET_MASK_ARRAY_LEN(8821A, _MUSB);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(pAdapter))
return GET_MASK_ARRAY_LEN(8192E, _MUSB);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(pAdapter))
return GET_MASK_ARRAY_LEN(8723B, _MUSB);
#endif
#if defined(CONFIG_RTL8703B)
if (IS_HARDWARE_TYPE_8703B(pAdapter))
return GET_MASK_ARRAY_LEN(8703B, _MUSB);
#endif
#if defined(CONFIG_RTL8188F)
if (IS_HARDWARE_TYPE_8188F(pAdapter))
return GET_MASK_ARRAY_LEN(8188F, _MUSB);
#endif
#if defined(CONFIG_RTL8188GTV)
if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
return GET_MASK_ARRAY_LEN(8188GTV, _MUSB);
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(pAdapter))
return GET_MASK_ARRAY_LEN(8814A, _MUSB);
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
return GET_MASK_ARRAY_LEN(8822B, _MUSB);
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CU(pAdapter))
return GET_MASK_ARRAY_LEN(8821C, _MUSB);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FU(pAdapter))
return GET_MASK_ARRAY_LEN(8192F, _MUSB);
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return GET_MASK_ARRAY_LEN(8822C, _MUSB);
#endif
#endif /*CONFIG_USB_HCI*/
#ifdef CONFIG_PCI_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
return GET_MASK_ARRAY_LEN(8188E, _MPCIE);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(pAdapter))
return GET_MASK_ARRAY_LEN(8192E, _MPCIE);
#endif
#if defined(CONFIG_RTL8812A)
if (IS_HARDWARE_TYPE_8812(pAdapter))
return GET_MASK_ARRAY_LEN(8812A, _MPCIE);
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821(pAdapter))
return GET_MASK_ARRAY_LEN(8821A, _MPCIE);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(pAdapter))
return GET_MASK_ARRAY_LEN(8723B, _MPCIE);
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(pAdapter))
return GET_MASK_ARRAY_LEN(8814A, _MPCIE);
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
return GET_MASK_ARRAY_LEN(8822B, _MPCIE);
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CE(pAdapter))
return GET_MASK_ARRAY_LEN(8821C, _MPCIE);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FE(pAdapter))
return GET_MASK_ARRAY_LEN(8192F, _MPCIE);
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return GET_MASK_ARRAY_LEN(8822C, _MPCIE);
#endif
#endif /*CONFIG_PCI_HCI*/
#ifdef CONFIG_SDIO_HCI
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(pAdapter))
return GET_MASK_ARRAY_LEN(8188E, _MSDIO);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723BS(pAdapter))
return GET_MASK_ARRAY_LEN(8723B, _MSDIO);
#endif
#if defined(CONFIG_RTL8188F)
if (IS_HARDWARE_TYPE_8188F(pAdapter))
return GET_MASK_ARRAY_LEN(8188F, _MSDIO);
#endif
#if defined(CONFIG_RTL8188GTV)
if (IS_HARDWARE_TYPE_8188GTV(pAdapter))
return GET_MASK_ARRAY_LEN(8188GTV, _MSDIO);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192ES(pAdapter))
return GET_MASK_ARRAY_LEN(8192E, _MSDIO);
#endif
#if defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8821S(pAdapter))
return GET_MASK_ARRAY_LEN(8821A, _MSDIO);
#endif
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821CS(pAdapter))
return GET_MASK_ARRAY_LEN(8821C, _MSDIO);
#endif
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(pAdapter))
return GET_MASK_ARRAY_LEN(8822B, _MSDIO);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192FS(pAdapter))
return GET_MASK_ARRAY_LEN(8192F, _MSDIO);
#endif
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(pAdapter))
return GET_MASK_ARRAY_LEN(8822C, _MSDIO);
#endif
#endif/*CONFIG_SDIO_HCI*/
return 0;
}
static void rtw_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
u16 i = 0;
if (padapter->registrypriv.boffefusemask == 0) {
for (i = 0; i < cnts; i++) {
if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
if (rtw_file_efuse_IsMasked(padapter, addr + i, maskfileBuffer)) /*use file efuse mask.*/
data[i] = 0xff;
else
RTW_DBG("data[%x] = %x\n", i, data[i]);
} else {
if (efuse_IsMasked(padapter, addr + i))
data[i] = 0xff;
else
RTW_DBG("data[%x] = %x\n", i, data[i]);
}
}
}
}
static void rtw_bt_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
u16 i = 0;
if (padapter->registrypriv.boffefusemask == 0) {
for (i = 0; i < cnts; i++) {
if (padapter->registrypriv.bBTFileMaskEfuse == _TRUE) {
if (rtw_file_efuse_IsMasked(padapter, addr + i, btmaskfileBuffer)) /*use BT file efuse mask.*/
data[i] = 0xff;
else
RTW_DBG("data[%x] = %x\n", i, data[i]);
} else {
if (efuse_IsBT_Masked(padapter, addr + i)) /*use drv internal efuse mask.*/
data[i] = 0xff;
else
RTW_DBG("data[%x] = %x\n", i, data[i]);
}
}
}
}
u8 rtw_efuse_mask_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
u8 ret = _SUCCESS;
u16 mapLen = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
ret = rtw_efuse_map_read(padapter, addr, cnts , data);
rtw_mask_map_read(padapter, addr, cnts , data);
return ret;
}
/* ***********************************************************
* Efuse related code
* *********************************************************** */
static u8 hal_EfuseSwitchToBank(
PADAPTER padapter,
u8 bank,
u8 bPseudoTest)
{
u8 bRet = _FALSE;
u32 value32 = 0;
#ifdef HAL_EFUSE_MEMORY
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
#endif
RTW_INFO("%s: Efuse switch bank to %d\n", __FUNCTION__, bank);
if (bPseudoTest) {
#ifdef HAL_EFUSE_MEMORY
pEfuseHal->fakeEfuseBank = bank;
#else
fakeEfuseBank = bank;
#endif
bRet = _TRUE;
} else {
value32 = rtw_read32(padapter, 0x34);
bRet = _TRUE;
switch (bank) {
case 0:
value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_WIFI_SEL_0);
break;
case 1:
value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_BT_SEL_0);
break;
case 2:
value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_BT_SEL_1);
break;
case 3:
value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_BT_SEL_2);
break;
default:
value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_WIFI_SEL_0);
bRet = _FALSE;
break;
}
rtw_write32(padapter, 0x34, value32);
}
return bRet;
}
void rtw_efuse_analyze(PADAPTER padapter, u8 Type, u8 Fake)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
PEFUSE_HAL pEfuseHal = &(pHalData->EfuseHal);
u16 eFuse_Addr = 0;
u8 offset, wden;
u16 i, j;
u8 u1temp = 0;
u8 efuseHeader = 0, efuseExtHdr = 0, efuseData[EFUSE_MAX_WORD_UNIT*2] = {0}, dataCnt = 0;
u16 efuseHeader2Byte = 0;
u8 *eFuseWord = NULL;// [EFUSE_MAX_SECTION_NUM][EFUSE_MAX_WORD_UNIT];
u8 offset_2_0 = 0;
u8 pgSectionCnt = 0;
u8 wd_cnt = 0;
u8 max_section = 64;
u16 mapLen = 0, maprawlen = 0;
boolean bExtHeader = _FALSE;
u8 efuseType = EFUSE_WIFI;
boolean bPseudoTest = _FALSE;
u8 bank = 0, startBank = 0, endBank = 1-1;
boolean bCheckNextBank = FALSE;
u8 protectBytesBank = 0;
u16 efuse_max = 0;
u8 ParseEfuseExtHdr, ParseEfuseHeader, ParseOffset, ParseWDEN, ParseOffset2_0;
eFuseWord = rtw_zmalloc(EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
RTW_INFO("\n");
if (Type == 0) {
if (Fake == 0) {
RTW_INFO("\n\tEFUSE_Analyze Wifi Content\n");
efuseType = EFUSE_WIFI;
bPseudoTest = FALSE;
startBank = 0;
endBank = 0;
} else {
RTW_INFO("\n\tEFUSE_Analyze Wifi Pseudo Content\n");
efuseType = EFUSE_WIFI;
bPseudoTest = TRUE;
startBank = 0;
endBank = 0;
}
} else {
if (Fake == 0) {
RTW_INFO("\n\tEFUSE_Analyze BT Content\n");
efuseType = EFUSE_BT;
bPseudoTest = FALSE;
startBank = 1;
endBank = EFUSE_MAX_BANK - 1;
} else {
RTW_INFO("\n\tEFUSE_Analyze BT Pseudo Content\n");
efuseType = EFUSE_BT;
bPseudoTest = TRUE;
startBank = 1;
endBank = EFUSE_MAX_BANK - 1;
if (IS_HARDWARE_TYPE_8821(padapter))
endBank = 3 - 1;/*EFUSE_MAX_BANK_8821A - 1;*/
}
}
RTW_INFO("\n\r 1Byte header, [7:4]=offset, [3:0]=word enable\n");
RTW_INFO("\n\r 2Byte header, header[7:5]=offset[2:0], header[4:0]=0x0F\n");
RTW_INFO("\n\r 2Byte header, extHeader[7:4]=offset[6:3], extHeader[3:0]=word enable\n");
EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, bPseudoTest);
EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_MAX_SECTION, (void *)&max_section, bPseudoTest);
EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_PROTECT_BYTES_BANK, (void *)&protectBytesBank, bPseudoTest);
EFUSE_GetEfuseDefinition(padapter, efuseType, TYPE_EFUSE_CONTENT_LEN_BANK, (void *)&efuse_max, bPseudoTest);
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_REAL_CONTENT_LEN, (void *)&maprawlen, _FALSE);
_rtw_memset(eFuseWord, 0xff, EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
_rtw_memset(pEfuseHal->fakeEfuseInitMap, 0xff, EFUSE_MAX_MAP_LEN);
if (IS_HARDWARE_TYPE_8821(padapter))
endBank = 3 - 1;/*EFUSE_MAX_BANK_8821A - 1;*/
for (bank = startBank; bank <= endBank; bank++) {
if (!hal_EfuseSwitchToBank(padapter, bank, bPseudoTest)) {
RTW_INFO("EFUSE_SwitchToBank() Fail!!\n");
goto out_free_buffer;
}
eFuse_Addr = bank * EFUSE_MAX_BANK_SIZE;
efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
if (efuseHeader == 0xFF && bank == startBank && Fake != TRUE) {
RTW_INFO("Non-PGed Efuse\n");
goto out_free_buffer;
}
RTW_INFO("EFUSE_REAL_CONTENT_LEN = %d\n", maprawlen);
while ((efuseHeader != 0xFF) && ((efuseType == EFUSE_WIFI && (eFuse_Addr < maprawlen)) || (efuseType == EFUSE_BT && (eFuse_Addr < (endBank + 1) * EFUSE_MAX_BANK_SIZE)))) {
RTW_INFO("Analyzing: Offset: 0x%X\n", eFuse_Addr);
/* Check PG header for section num.*/
if (EXT_HEADER(efuseHeader)) {
bExtHeader = TRUE;
offset_2_0 = GET_HDR_OFFSET_2_0(efuseHeader);
efuse_OneByteRead(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest);
if (efuseExtHdr != 0xff) {
if (ALL_WORDS_DISABLED(efuseExtHdr)) {
/* Read next pg header*/
efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
continue;
} else {
offset = ((efuseExtHdr & 0xF0) >> 1) | offset_2_0;
wden = (efuseExtHdr & 0x0F);
efuseHeader2Byte = (efuseExtHdr<<8)|efuseHeader;
RTW_INFO("Find efuseHeader2Byte = 0x%04X, offset=%d, wden=0x%x\n",
efuseHeader2Byte, offset, wden);
}
} else {
RTW_INFO("Error, efuse[%d]=0xff, efuseExtHdr=0xff\n", eFuse_Addr-1);
break;
}
} else {
offset = ((efuseHeader >> 4) & 0x0f);
wden = (efuseHeader & 0x0f);
}
_rtw_memset(efuseData, '\0', EFUSE_MAX_WORD_UNIT * 2);
dataCnt = 0;
if (offset < max_section) {
for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
/* Check word enable condition in the section */
if (!(wden & (0x01<> 8;
ParseEfuseHeader = (efuseHeader2Byte & 0xff);
ParseOffset2_0 = GET_HDR_OFFSET_2_0(ParseEfuseHeader);
ParseOffset = ((ParseEfuseExtHdr & 0xF0) >> 1) | ParseOffset2_0;
ParseWDEN = (ParseEfuseExtHdr & 0x0F);
RTW_INFO("Header=0x%x, ExtHeader=0x%x, ", ParseEfuseHeader, ParseEfuseExtHdr);
} else {
ParseEfuseHeader = efuseHeader;
ParseOffset = ((ParseEfuseHeader >> 4) & 0x0f);
ParseWDEN = (ParseEfuseHeader & 0x0f);
RTW_INFO("Header=0x%x, ", ParseEfuseHeader);
}
RTW_INFO("offset=0x%x(%d), word enable=0x%x\n", ParseOffset, ParseOffset, ParseWDEN);
wd_cnt = 0;
for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
if (!(wden & (0x01 << i))) {
RTW_INFO("Map[ %02X ] = %02X %02X\n", ((offset * EFUSE_MAX_WORD_UNIT * 2) + (i * 2)), efuseData[wd_cnt * 2 + 0], efuseData[wd_cnt * 2 + 1]);
wd_cnt++;
}
}
pgSectionCnt++;
bExtHeader = FALSE;
efuse_OneByteRead(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest);
if (efuseHeader == 0xFF) {
if ((eFuse_Addr + protectBytesBank) >= efuse_max)
bCheckNextBank = TRUE;
else
bCheckNextBank = FALSE;
}
}
if (!bCheckNextBank) {
RTW_INFO("Not need to check next bank, eFuse_Addr=%d, protectBytesBank=%d, efuse_max=%d\n",
eFuse_Addr, protectBytesBank, efuse_max);
break;
}
}
/* switch bank back to 0 for BT/wifi later use*/
hal_EfuseSwitchToBank(padapter, 0, bPseudoTest);
/* 3. Collect 16 sections and 4 word unit into Efuse map.*/
for (i = 0; i < max_section; i++) {
for (j = 0; j < EFUSE_MAX_WORD_UNIT; j++) {
pEfuseHal->fakeEfuseInitMap[(i*8)+(j*2)] = (eFuseWord[(i*8)+(j*2)]);
pEfuseHal->fakeEfuseInitMap[(i*8)+((j*2)+1)] = (eFuseWord[(i*8)+((j*2)+1)]);
}
}
RTW_INFO("\n\tEFUSE Analyze Map\n");
i = 0;
j = 0;
for (i = 0; i < mapLen; i++) {
if (i % 16 == 0)
RTW_PRINT_SEL(RTW_DBGDUMP, "0x%03x: ", i);
_RTW_PRINT_SEL(RTW_DBGDUMP, "%02X%s"
, pEfuseHal->fakeEfuseInitMap[i]
, ((i + 1) % 16 == 0) ? "\n" : (((i + 1) % 8 == 0) ? " " : " ")
);
}
_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
out_free_buffer:
if (eFuseWord)
rtw_mfree((u8 *)eFuseWord, EFUSE_MAX_SECTION_NUM * (EFUSE_MAX_WORD_UNIT * 2));
}
void efuse_PreUpdateAction(
PADAPTER pAdapter,
u32 *BackupRegs)
{
if (IS_HARDWARE_TYPE_8812AU(pAdapter) || IS_HARDWARE_TYPE_8822BU(pAdapter)) {
/* <20131115, Kordan> Turn off Rx to prevent from being busy when writing the EFUSE. (Asked by Chunchu.)*/
BackupRegs[0] = phy_query_mac_reg(pAdapter, REG_RCR, bMaskDWord);
BackupRegs[1] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord);
BackupRegs[2] = phy_query_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord);
#ifdef CONFIG_RTL8812A
BackupRegs[3] = phy_query_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord);
#endif
PlatformEFIOWrite4Byte(pAdapter, REG_RCR, 0x1);
PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0, 0);
PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+1, 0);
PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+2, 0);
PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+3, 0);
PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+4, 0);
PlatformEFIOWrite1Byte(pAdapter, REG_RXFLTMAP0+5, 0);
#ifdef CONFIG_RTL8812A
/* <20140410, Kordan> 0x11 = 0x4E, lower down LX_SPS0 voltage. (Asked by Chunchu)*/
phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskByte1, 0x4E);
#endif
RTW_INFO(" %s , done\n", __func__);
}
}
void efuse_PostUpdateAction(
PADAPTER pAdapter,
u32 *BackupRegs)
{
if (IS_HARDWARE_TYPE_8812AU(pAdapter) || IS_HARDWARE_TYPE_8822BU(pAdapter)) {
/* <20131115, Kordan> Turn on Rx and restore the registers. (Asked by Chunchu.)*/
phy_set_mac_reg(pAdapter, REG_RCR, bMaskDWord, BackupRegs[0]);
phy_set_mac_reg(pAdapter, REG_RXFLTMAP0, bMaskDWord, BackupRegs[1]);
phy_set_mac_reg(pAdapter, REG_RXFLTMAP0+4, bMaskDWord, BackupRegs[2]);
#ifdef CONFIG_RTL8812A
phy_set_mac_reg(pAdapter, REG_AFE_MISC, bMaskDWord, BackupRegs[3]);
#endif
RTW_INFO(" %s , done\n", __func__);
}
}
#ifdef RTW_HALMAC
#include "../../hal/hal_halmac.h"
void Efuse_PowerSwitch(PADAPTER adapter, u8 write, u8 pwrstate)
{
}
void BTEfuse_PowerSwitch(PADAPTER adapter, u8 write, u8 pwrstate)
{
}
u8 efuse_GetCurrentSize(PADAPTER adapter, u16 *size)
{
*size = 0;
return _FAIL;
}
u16 efuse_GetMaxSize(PADAPTER adapter)
{
struct dvobj_priv *d;
u32 size = 0;
int err;
d = adapter_to_dvobj(adapter);
err = rtw_halmac_get_physical_efuse_size(d, &size);
if (err)
return 0;
return size;
}
u16 efuse_GetavailableSize(PADAPTER adapter)
{
struct dvobj_priv *d;
u32 size = 0;
int err;
d = adapter_to_dvobj(adapter);
err = rtw_halmac_get_available_efuse_size(d, &size);
if (err)
return 0;
return size;
}
u8 efuse_bt_GetCurrentSize(PADAPTER adapter, u16 *usesize)
{
u8 *efuse_map;
*usesize = 0;
efuse_map = rtw_malloc(EFUSE_BT_MAP_LEN);
if (efuse_map == NULL) {
RTW_DBG("%s: malloc FAIL\n", __FUNCTION__);
return _FAIL;
}
/* for get bt phy efuse last use byte */
hal_ReadEFuse_BT_logic_map(adapter, 0x00, EFUSE_BT_MAP_LEN, efuse_map);
*usesize = fakeBTEfuseUsedBytes;
if (efuse_map)
rtw_mfree(efuse_map, EFUSE_BT_MAP_LEN);
return _SUCCESS;
}
u16 efuse_bt_GetMaxSize(PADAPTER adapter)
{
return EFUSE_BT_REAL_CONTENT_LEN - EFUSE_PROTECT_BYTES_BANK;
}
void EFUSE_GetEfuseDefinition(PADAPTER adapter, u8 efusetype, u8 type, void *out, BOOLEAN test)
{
struct dvobj_priv *d;
u32 v32 = 0;
d = adapter_to_dvobj(adapter);
if (adapter->hal_func.EFUSEGetEfuseDefinition) {
adapter->hal_func.EFUSEGetEfuseDefinition(adapter, efusetype, type, out, test);
return;
}
if (EFUSE_WIFI == efusetype) {
switch (type) {
case TYPE_EFUSE_MAP_LEN:
rtw_halmac_get_logical_efuse_size(d, &v32);
*(u16 *)out = (u16)v32;
return;
case TYPE_EFUSE_REAL_CONTENT_LEN:
rtw_halmac_get_physical_efuse_size(d, &v32);
*(u16 *)out = (u16)v32;
return;
}
} else if (EFUSE_BT == efusetype) {
switch (type) {
case TYPE_EFUSE_MAP_LEN:
*(u16 *)out = EFUSE_BT_MAP_LEN;
return;
case TYPE_EFUSE_REAL_CONTENT_LEN:
*(u16 *)out = EFUSE_BT_REAL_CONTENT_LEN;
return;
}
}
}
/*
* read/write raw efuse data
*/
u8 rtw_efuse_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data)
{
struct dvobj_priv *d;
u8 *efuse = NULL;
u32 size, i;
int err;
d = adapter_to_dvobj(adapter);
err = rtw_halmac_get_physical_efuse_size(d, &size);
if (err){
size = EFUSE_MAX_SIZE;
RTW_INFO(" physical_efuse_size err size %d\n", size);
}
if ((addr + cnts) > size)
return _FAIL;
if (_TRUE == write) {
err = rtw_halmac_write_physical_efuse(d, addr, cnts, data);
if (err)
return _FAIL;
} else {
if (cnts > 16)
efuse = rtw_zmalloc(size);
if (efuse) {
err = rtw_halmac_read_physical_efuse_map(d, efuse, size);
if (err) {
rtw_mfree(efuse, size);
return _FAIL;
}
_rtw_memcpy(data, efuse + addr, cnts);
rtw_mfree(efuse, size);
} else {
err = rtw_halmac_read_physical_efuse(d, addr, cnts, data);
if (err)
return _FAIL;
}
}
return _SUCCESS;
}
static inline void dump_buf(u8 *buf, u32 len)
{
u32 i;
RTW_INFO("-----------------Len %d----------------\n", len);
for (i = 0; i < len; i++)
printk("%2.2x-", *(buf + i));
printk("\n");
}
/*
* read/write raw efuse data
*/
u8 rtw_efuse_bt_access(PADAPTER adapter, u8 write, u16 addr, u16 cnts, u8 *data)
{
struct dvobj_priv *d;
u8 *efuse = NULL;
u32 size, i;
int err = _FAIL;
d = adapter_to_dvobj(adapter);
size = EFUSE_BT_REAL_CONTENT_LEN;
if ((addr + cnts) > size)
return _FAIL;
if (_TRUE == write) {
err = rtw_halmac_write_bt_physical_efuse(d, addr, cnts, data);
if (err == -1) {
RTW_ERR("%s: rtw_halmac_write_bt_physical_efuse fail!\n", __FUNCTION__);
return _FAIL;
}
RTW_INFO("%s: rtw_halmac_write_bt_physical_efuse OK! data 0x%x\n", __FUNCTION__, *data);
} else {
efuse = rtw_zmalloc(size);
if (efuse) {
err = rtw_halmac_read_bt_physical_efuse_map(d, efuse, size);
if (err == -1) {
RTW_ERR("%s: rtw_halmac_read_bt_physical_efuse_map fail!\n", __FUNCTION__);
rtw_mfree(efuse, size);
return _FAIL;
}
dump_buf(efuse + addr, cnts);
_rtw_memcpy(data, efuse + addr, cnts);
RTW_INFO("%s: rtw_halmac_read_bt_physical_efuse_map ok! data 0x%x\n", __FUNCTION__, *data);
rtw_mfree(efuse, size);
}
}
return _SUCCESS;
}
u8 rtw_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
{
struct dvobj_priv *d;
u8 *efuse = NULL;
u32 size, i;
int err;
u32 backupRegs[4] = {0};
u8 status = _SUCCESS;
efuse_PreUpdateAction(adapter, backupRegs);
d = adapter_to_dvobj(adapter);
err = rtw_halmac_get_logical_efuse_size(d, &size);
if (err) {
status = _FAIL;
RTW_DBG("halmac_get_logical_efuse_size fail\n");
goto exit;
}
/* size error handle */
if ((addr + cnts) > size) {
if (addr < size)
cnts = size - addr;
else {
status = _FAIL;
RTW_DBG(" %s() ,addr + cnts) > size fail\n", __func__);
goto exit;
}
}
if (cnts > 16)
efuse = rtw_zmalloc(size);
if (efuse) {
err = rtw_halmac_read_logical_efuse_map(d, efuse, size, NULL, 0);
if (err) {
rtw_mfree(efuse, size);
status = _FAIL;
RTW_DBG(" %s() ,halmac_read_logical_efus map fail\n", __func__);
goto exit;
}
_rtw_memcpy(data, efuse + addr, cnts);
rtw_mfree(efuse, size);
} else {
err = rtw_halmac_read_logical_efuse(d, addr, cnts, data);
if (err) {
status = _FAIL;
RTW_DBG(" %s() ,halmac_read_logical_efus data fail\n", __func__);
goto exit;
}
}
status = _SUCCESS;
exit:
efuse_PostUpdateAction(adapter, backupRegs);
return status;
}
u8 rtw_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
{
struct dvobj_priv *d;
u8 *efuse = NULL;
u32 size, i;
int err;
u8 mask_buf[64] = "";
u16 mask_len = sizeof(u8) * rtw_get_efuse_mask_arraylen(adapter);
u32 backupRegs[4] = {0};
u8 status = _SUCCESS;;
efuse_PreUpdateAction(adapter, backupRegs);
d = adapter_to_dvobj(adapter);
err = rtw_halmac_get_logical_efuse_size(d, &size);
if (err) {
status = _FAIL;
goto exit;
}
if ((addr + cnts) > size) {
status = _FAIL;
goto exit;
}
efuse = rtw_zmalloc(size);
if (!efuse) {
status = _FAIL;
goto exit;
}
err = rtw_halmac_read_logical_efuse_map(d, efuse, size, NULL, 0);
if (err) {
rtw_mfree(efuse, size);
status = _FAIL;
goto exit;
}
_rtw_memcpy(efuse + addr, data, cnts);
if (adapter->registrypriv.boffefusemask == 0) {
RTW_INFO("Use mask Array Len: %d\n", mask_len);
if (mask_len != 0) {
if (adapter->registrypriv.bFileMaskEfuse == _TRUE)
_rtw_memcpy(mask_buf, maskfileBuffer, mask_len);
else
rtw_efuse_mask_array(adapter, mask_buf);
err = rtw_halmac_write_logical_efuse_map(d, efuse, size, mask_buf, mask_len);
} else
err = rtw_halmac_write_logical_efuse_map(d, efuse, size, NULL, 0);
} else {
_rtw_memset(mask_buf, 0xFF, sizeof(mask_buf));
RTW_INFO("Efuse mask off\n");
err = rtw_halmac_write_logical_efuse_map(d, efuse, size, mask_buf, size/16);
}
if (err) {
rtw_mfree(efuse, size);
status = _FAIL;
goto exit;
}
rtw_mfree(efuse, size);
status = _SUCCESS;
exit :
efuse_PostUpdateAction(adapter, backupRegs);
return status;
}
int Efuse_PgPacketRead(PADAPTER adapter, u8 offset, u8 *data, BOOLEAN test)
{
return _FALSE;
}
int Efuse_PgPacketWrite(PADAPTER adapter, u8 offset, u8 word_en, u8 *data, BOOLEAN test)
{
return _FALSE;
}
u8 rtw_BT_efuse_map_read(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
{
hal_ReadEFuse_BT_logic_map(adapter, addr, cnts, data);
rtw_bt_mask_map_read(adapter, addr, cnts, data);
return _SUCCESS;
}
static u16
hal_EfuseGetCurrentSize_BT(
PADAPTER padapter,
u8 bPseudoTest)
{
#ifdef HAL_EFUSE_MEMORY
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
#endif
u16 btusedbytes;
u16 efuse_addr;
u8 bank, startBank;
u8 hoffset = 0, hworden = 0;
u8 efuse_data, word_cnts = 0;
u16 retU2 = 0;
u8 bContinual = _TRUE;
btusedbytes = fakeBTEfuseUsedBytes;
efuse_addr = (u16)((btusedbytes % EFUSE_BT_REAL_BANK_CONTENT_LEN));
startBank = (u8)(1 + (btusedbytes / EFUSE_BT_REAL_BANK_CONTENT_LEN));
RTW_INFO("%s: start from bank=%d addr=0x%X\n", __FUNCTION__, startBank, efuse_addr);
retU2 = EFUSE_BT_REAL_CONTENT_LEN - EFUSE_PROTECT_BYTES_BANK;
for (bank = startBank; bank < 3; bank++) {
if (hal_EfuseSwitchToBank(padapter, bank, bPseudoTest) == _FALSE) {
RTW_ERR("%s: switch bank(%d) Fail!!\n", __FUNCTION__, bank);
/* bank = EFUSE_MAX_BANK; */
break;
}
/* only when bank is switched we have to reset the efuse_addr. */
if (bank != startBank)
efuse_addr = 0;
while (AVAILABLE_EFUSE_ADDR(efuse_addr)) {
if (rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &efuse_data) == _FALSE) {
RTW_ERR("%s: efuse_OneByteRead Fail! addr=0x%X !!\n", __FUNCTION__, efuse_addr);
/* bank = EFUSE_MAX_BANK; */
break;
}
RTW_INFO("%s: efuse_OneByteRead ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __FUNCTION__, efuse_addr, efuse_data, bank);
if (efuse_data == 0xFF)
break;
if (EXT_HEADER(efuse_data)) {
hoffset = GET_HDR_OFFSET_2_0(efuse_data);
efuse_addr++;
rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &efuse_data);
RTW_INFO("%s: efuse_OneByteRead EXT_HEADER ! addr=0x%X !efuse_data=0x%X! bank =%d\n", __FUNCTION__, efuse_addr, efuse_data, bank);
if (ALL_WORDS_DISABLED(efuse_data)) {
efuse_addr++;
continue;
}
/* hoffset = ((hoffset & 0xE0) >> 5) | ((efuse_data & 0xF0) >> 1); */
hoffset |= ((efuse_data & 0xF0) >> 1);
hworden = efuse_data & 0x0F;
} else {
hoffset = (efuse_data >> 4) & 0x0F;
hworden = efuse_data & 0x0F;
}
RTW_INFO(FUNC_ADPT_FMT": Offset=%d Worden=%#X\n",
FUNC_ADPT_ARG(padapter), hoffset, hworden);
word_cnts = Efuse_CalculateWordCnts(hworden);
/* read next header */
efuse_addr += (word_cnts * 2) + 1;
}
/* Check if we need to check next bank efuse */
if (efuse_addr < retU2)
break;/* don't need to check next bank. */
}
retU2 = ((bank - 1) * EFUSE_BT_REAL_BANK_CONTENT_LEN) + efuse_addr;
fakeBTEfuseUsedBytes = retU2;
RTW_INFO("%s: CurrentSize=%d\n", __FUNCTION__, retU2);
return retU2;
}
u8 rtw_BT_efuse_map_write(PADAPTER adapter, u16 addr, u16 cnts, u8 *data)
{
#define RT_ASSERT_RET(expr) \
if (!(expr)) { \
printk("Assertion failed! %s at ......\n", #expr); \
printk(" ......%s,%s, line=%d\n",__FILE__, __FUNCTION__, __LINE__); \
return _FAIL; \
}
u8 offset, word_en;
u8 *efuse = NULL;
u8 *map;
u8 newdata[PGPKT_DATA_SIZE];
s32 i = 0, j = 0, idx = 0, chk_total_byte = 0;
u8 ret = _SUCCESS;
u16 mapLen = 1024;
u16 startAddr = 0;
if ((addr + cnts) > mapLen)
return _FAIL;
RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); /* have to be 8 byte alignment */
RT_ASSERT_RET((mapLen & 0x7) == 0); /* have to be PGPKT_DATA_SIZE alignment for memcpy */
efuse = rtw_zmalloc(mapLen);
if (!efuse)
return _FAIL;
map = rtw_zmalloc(mapLen);
if (map == NULL) {
rtw_mfree(efuse, mapLen);
return _FAIL;
}
_rtw_memset(map, 0xFF, mapLen);
ret = rtw_BT_efuse_map_read(adapter, 0, mapLen, map);
if (ret == _FAIL)
goto exit;
_rtw_memcpy(efuse , map, mapLen);
_rtw_memcpy(efuse + addr, data, cnts);
if (adapter->registrypriv.boffefusemask == 0) {
for (i = 0; i < cnts; i++) {
if (adapter->registrypriv.bFileMaskEfuse == _TRUE) {
if (rtw_file_efuse_IsMasked(adapter, addr + i, btmaskfileBuffer)) /*use file efuse mask. */
efuse[addr + i] = map[addr + i];
} else {
if (efuse_IsBT_Masked(adapter, addr + i))
efuse[addr + i] = map[addr + i];
}
RTW_INFO("%s , efuse[%x] = %x, map = %x\n", __func__, addr + i, efuse[ addr + i], map[addr + i]);
}
}
/* precheck pg efuse data byte*/
chk_total_byte = 0;
idx = 0;
offset = (addr >> 3);
while (idx < cnts) {
word_en = 0xF;
j = (addr + idx) & 0x7;
for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
if (efuse[addr + idx] != map[addr + idx])
word_en &= ~BIT(i >> 1);
}
if (word_en != 0xF) {
chk_total_byte += Efuse_CalculateWordCnts(word_en) * 2;
if (offset >= EFUSE_MAX_SECTION_BASE) /* Over EFUSE_MAX_SECTION 16 for 2 ByteHeader */
chk_total_byte += 2;
else
chk_total_byte += 1;
}
offset++;
}
RTW_INFO("Total PG bytes Count = %d\n", chk_total_byte);
startAddr = hal_EfuseGetCurrentSize_BT(adapter, _FALSE);
RTW_INFO("%s: startAddr=%#X\n", __func__, startAddr);
if (!AVAILABLE_EFUSE_ADDR(startAddr + chk_total_byte)) {
RTW_INFO("%s: startAddr(0x%X) + PG data len %d >= efuse BT available offset (0x%X)\n",
__func__, startAddr, chk_total_byte, EFUSE_BT_REAL_CONTENT_LEN - EFUSE_PROTECT_BYTES_BANK);
ret = _FAIL;
goto exit;
}
idx = 0;
offset = (addr >> 3);
while (idx < cnts) {
word_en = 0xF;
j = (addr + idx) & 0x7;
_rtw_memcpy(newdata, &map[offset << 3], PGPKT_DATA_SIZE);
for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
if (efuse[addr + idx] != map[addr + idx]) {
word_en &= ~BIT(i >> 1);
newdata[i] = efuse[addr + idx];
}
}
if (word_en != 0xF) {
ret = EfusePgPacketWrite_BT(adapter, offset, word_en, newdata, _FALSE);
RTW_INFO("offset=%x\n", offset);
RTW_INFO("word_en=%x\n", word_en);
RTW_INFO("%s: data=", __FUNCTION__);
for (i = 0; i < PGPKT_DATA_SIZE; i++)
RTW_INFO("0x%02X ", newdata[i]);
RTW_INFO("\n");
if (ret == _FAIL)
break;
}
offset++;
}
exit:
rtw_mfree(map, mapLen);
return ret;
}
void hal_ReadEFuse_BT_logic_map(
PADAPTER padapter,
u16 _offset,
u16 _size_byte,
u8 *pbuf
)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
u8 *efuseTbl, *phyefuse;
u8 bank;
u16 eFuse_Addr = 0;
u8 efuseHeader, efuseExtHdr, efuseData;
u8 offset, wden;
u16 i, total, used;
u8 efuse_usage;
/* */
/* Do NOT excess total size of EFuse table. Added by Roger, 2008.11.10. */
/* */
if ((_offset + _size_byte) > EFUSE_BT_MAP_LEN) {
RTW_INFO("%s: Invalid offset(%#x) with read bytes(%#x)!!\n", __FUNCTION__, _offset, _size_byte);
return;
}
efuseTbl = rtw_malloc(EFUSE_BT_MAP_LEN);
phyefuse = rtw_malloc(EFUSE_BT_REAL_CONTENT_LEN);
if (efuseTbl == NULL || phyefuse == NULL) {
RTW_INFO("%s: efuseTbl or phyefuse malloc fail!\n", __FUNCTION__);
goto exit;
}
/* 0xff will be efuse default value instead of 0x00. */
_rtw_memset(efuseTbl, 0xFF, EFUSE_BT_MAP_LEN);
_rtw_memset(phyefuse, 0xFF, EFUSE_BT_REAL_CONTENT_LEN);
if (rtw_efuse_bt_access(padapter, _FALSE, 0, EFUSE_BT_REAL_CONTENT_LEN, phyefuse))
dump_buf(phyefuse, EFUSE_BT_REAL_BANK_CONTENT_LEN);
total = BANK_NUM;
for (bank = 1; bank <= total; bank++) { /* 8723d Max bake 0~2 */
eFuse_Addr = 0;
while (AVAILABLE_EFUSE_ADDR(eFuse_Addr)) {
/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseHeader, bPseudoTest); */
efuseHeader = phyefuse[eFuse_Addr++];
if (efuseHeader == 0xFF)
break;
RTW_INFO("%s: efuse[%#X]=0x%02x (header)\n", __FUNCTION__, (((bank - 1) * EFUSE_BT_REAL_CONTENT_LEN) + eFuse_Addr - 1), efuseHeader);
/* Check PG header for section num. */
if (EXT_HEADER(efuseHeader)) { /* extended header */
offset = GET_HDR_OFFSET_2_0(efuseHeader);
RTW_INFO("%s: extended header offset_2_0=0x%X\n", __FUNCTION__, offset);
/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseExtHdr, bPseudoTest); */
efuseExtHdr = phyefuse[eFuse_Addr++];
RTW_INFO("%s: efuse[%#X]=0x%02x (ext header)\n", __FUNCTION__, (((bank - 1) * EFUSE_BT_REAL_CONTENT_LEN) + eFuse_Addr - 1), efuseExtHdr);
if (ALL_WORDS_DISABLED(efuseExtHdr))
continue;
offset |= ((efuseExtHdr & 0xF0) >> 1);
wden = (efuseExtHdr & 0x0F);
} else {
offset = ((efuseHeader >> 4) & 0x0f);
wden = (efuseHeader & 0x0f);
}
if (offset < EFUSE_BT_MAX_SECTION) {
u16 addr;
/* Get word enable value from PG header */
RTW_INFO("%s: Offset=%d Worden=%#X\n", __FUNCTION__, offset, wden);
addr = offset * PGPKT_DATA_SIZE;
for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
/* Check word enable condition in the section */
if (!(wden & (0x01 << i))) {
efuseData = 0;
/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
efuseData = phyefuse[eFuse_Addr++];
RTW_INFO("%s: efuse[%#X]=0x%02X\n", __FUNCTION__, eFuse_Addr - 1, efuseData);
efuseTbl[addr] = efuseData;
efuseData = 0;
/* ReadEFuseByte(padapter, eFuse_Addr++, &efuseData, bPseudoTest); */
efuseData = phyefuse[eFuse_Addr++];
RTW_INFO("%s: efuse[%#X]=0x%02X\n", __FUNCTION__, eFuse_Addr - 1, efuseData);
efuseTbl[addr + 1] = efuseData;
}
addr += 2;
}
} else {
RTW_INFO("%s: offset(%d) is illegal!!\n", __FUNCTION__, offset);
eFuse_Addr += Efuse_CalculateWordCnts(wden) * 2;
}
}
if ((eFuse_Addr - 1) < total) {
RTW_INFO("%s: bank(%d) data end at %#x\n", __FUNCTION__, bank, eFuse_Addr - 1);
break;
}
}
/* switch bank back to bank 0 for later BT and wifi use. */
//hal_EfuseSwitchToBank(padapter, 0, bPseudoTest);
/* Copy from Efuse map to output pointer memory!!! */
for (i = 0; i < _size_byte; i++)
pbuf[i] = efuseTbl[_offset + i];
/* Calculate Efuse utilization */
total = EFUSE_BT_REAL_BANK_CONTENT_LEN;
used = eFuse_Addr - 1;
if (total)
efuse_usage = (u8)((used * 100) / total);
else
efuse_usage = 100;
fakeBTEfuseUsedBytes = used;
RTW_INFO("%s: BTEfuseUsed last Bytes = %#x\n", __FUNCTION__, fakeBTEfuseUsedBytes);
exit:
if (efuseTbl)
rtw_mfree(efuseTbl, EFUSE_BT_MAP_LEN);
if (phyefuse)
rtw_mfree(phyefuse, EFUSE_BT_REAL_BANK_CONTENT_LEN);
}
static u8 hal_EfusePartialWriteCheck(
PADAPTER padapter,
u8 efuseType,
u16 *pAddr,
PPGPKT_STRUCT pTargetPkt,
u8 bPseudoTest)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
u8 bRet = _FALSE;
u16 startAddr = 0, efuse_max_available_len = EFUSE_BT_REAL_BANK_CONTENT_LEN, efuse_max = EFUSE_BT_REAL_BANK_CONTENT_LEN;
u8 efuse_data = 0;
startAddr = (u16)fakeBTEfuseUsedBytes;
startAddr %= efuse_max;
RTW_INFO("%s: startAddr=%#X\n", __FUNCTION__, startAddr);
while (1) {
if (startAddr >= efuse_max_available_len) {
bRet = _FALSE;
RTW_INFO("%s: startAddr(%d) >= efuse_max_available_len(%d)\n",
__FUNCTION__, startAddr, efuse_max_available_len);
break;
}
if (rtw_efuse_bt_access(padapter, _FALSE, startAddr, 1, &efuse_data)&& (efuse_data != 0xFF)) {
bRet = _FALSE;
RTW_INFO("%s: Something Wrong! last bytes(%#X=0x%02X) is not 0xFF\n",
__FUNCTION__, startAddr, efuse_data);
break;
} else {
/* not used header, 0xff */
*pAddr = startAddr;
/* RTW_INFO("%s: Started from unused header offset=%d\n", __FUNCTION__, startAddr)); */
bRet = _TRUE;
break;
}
}
return bRet;
}
static u8 hal_EfusePgPacketWrite2ByteHeader(
PADAPTER padapter,
u8 efuseType,
u16 *pAddr,
PPGPKT_STRUCT pTargetPkt,
u8 bPseudoTest)
{
u16 efuse_addr, efuse_max_available_len = EFUSE_BT_REAL_BANK_CONTENT_LEN;
u8 pg_header = 0, tmp_header = 0;
u8 repeatcnt = 0;
/* RTW_INFO("%s\n", __FUNCTION__); */
efuse_addr = *pAddr;
if (efuse_addr >= efuse_max_available_len) {
RTW_INFO("%s: addr(%d) over avaliable(%d)!!\n", __FUNCTION__, efuse_addr, efuse_max_available_len);
return _FALSE;
}
pg_header = ((pTargetPkt->offset & 0x07) << 5) | 0x0F;
/* RTW_INFO("%s: pg_header=0x%x\n", __FUNCTION__, pg_header); */
do {
rtw_efuse_bt_access(padapter, _TRUE, efuse_addr, 1, &pg_header);
rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &tmp_header);
if (tmp_header != 0xFF)
break;
if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
RTW_INFO("%s: Repeat over limit for pg_header!!\n", __FUNCTION__);
return _FALSE;
}
} while (1);
if (tmp_header != pg_header) {
RTW_ERR("%s: PG Header Fail!!(pg=0x%02X read=0x%02X)\n", __FUNCTION__, pg_header, tmp_header);
return _FALSE;
}
/* to write ext_header */
efuse_addr++;
pg_header = ((pTargetPkt->offset & 0x78) << 1) | pTargetPkt->word_en;
do {
rtw_efuse_bt_access(padapter, _TRUE, efuse_addr, 1, &pg_header);
rtw_efuse_bt_access(padapter, _FALSE, efuse_addr, 1, &tmp_header);
if (tmp_header != 0xFF)
break;
if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
RTW_INFO("%s: Repeat over limit for ext_header!!\n", __FUNCTION__);
return _FALSE;
}
} while (1);
if (tmp_header != pg_header) { /* offset PG fail */
RTW_ERR("%s: PG EXT Header Fail!!(pg=0x%02X read=0x%02X)\n", __FUNCTION__, pg_header, tmp_header);
return _FALSE;
}
*pAddr = efuse_addr;
return _TRUE;
}
static u8 hal_EfusePgPacketWrite1ByteHeader(
PADAPTER pAdapter,
u8 efuseType,
u16 *pAddr,
PPGPKT_STRUCT pTargetPkt,
u8 bPseudoTest)
{
u8 bRet = _FALSE;
u8 pg_header = 0, tmp_header = 0;
u16 efuse_addr = *pAddr;
u8 repeatcnt = 0;
/* RTW_INFO("%s\n", __FUNCTION__); */
pg_header = ((pTargetPkt->offset << 4) & 0xf0) | pTargetPkt->word_en;
do {
rtw_efuse_bt_access(pAdapter, _TRUE, efuse_addr, 1, &pg_header);
rtw_efuse_bt_access(pAdapter, _FALSE, efuse_addr, 1, &tmp_header);
if (tmp_header != 0xFF)
break;
if (repeatcnt++ > EFUSE_REPEAT_THRESHOLD_) {
RTW_INFO("%s: Repeat over limit for pg_header!!\n", __FUNCTION__);
return _FALSE;
}
} while (1);
if (tmp_header != pg_header) {
RTW_ERR("%s: PG Header Fail!!(pg=0x%02X read=0x%02X)\n", __FUNCTION__, pg_header, tmp_header);
return _FALSE;
}
*pAddr = efuse_addr;
return _TRUE;
}
static u8 hal_EfusePgPacketWriteHeader(
PADAPTER padapter,
u8 efuseType,
u16 *pAddr,
PPGPKT_STRUCT pTargetPkt,
u8 bPseudoTest)
{
u8 bRet = _FALSE;
if (pTargetPkt->offset >= EFUSE_MAX_SECTION_BASE)
bRet = hal_EfusePgPacketWrite2ByteHeader(padapter, efuseType, pAddr, pTargetPkt, bPseudoTest);
else
bRet = hal_EfusePgPacketWrite1ByteHeader(padapter, efuseType, pAddr, pTargetPkt, bPseudoTest);
return bRet;
}
static u8
Hal_EfuseWordEnableDataWrite(
PADAPTER padapter,
u16 efuse_addr,
u8 word_en,
u8 *data,
u8 bPseudoTest)
{
u16 tmpaddr = 0;
u16 start_addr = efuse_addr;
u8 badworden = 0x0F;
u8 tmpdata[PGPKT_DATA_SIZE];
/* RTW_INFO("%s: efuse_addr=%#x word_en=%#x\n", __FUNCTION__, efuse_addr, word_en); */
_rtw_memset(tmpdata, 0xFF, PGPKT_DATA_SIZE);
if (!(word_en & BIT(0))) {
tmpaddr = start_addr;
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[0]);
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[1]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[0]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[1]);
if ((data[0] != tmpdata[0]) || (data[1] != tmpdata[1]))
badworden &= (~BIT(0));
}
if (!(word_en & BIT(1))) {
tmpaddr = start_addr;
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[2]);
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[3]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[2]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[3]);
if ((data[2] != tmpdata[2]) || (data[3] != tmpdata[3]))
badworden &= (~BIT(1));
}
if (!(word_en & BIT(2))) {
tmpaddr = start_addr;
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[4]);
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[5]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[4]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[5]);
if ((data[4] != tmpdata[4]) || (data[5] != tmpdata[5]))
badworden &= (~BIT(2));
}
if (!(word_en & BIT(3))) {
tmpaddr = start_addr;
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[6]);
rtw_efuse_bt_access(padapter, _TRUE, start_addr++, 1, &data[7]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr, 1, &tmpdata[6]);
rtw_efuse_bt_access(padapter, _FALSE, tmpaddr + 1, 1, &tmpdata[7]);
if ((data[6] != tmpdata[6]) || (data[7] != tmpdata[7]))
badworden &= (~BIT(3));
}
return badworden;
}
static void
hal_EfuseConstructPGPkt(
u8 offset,
u8 word_en,
u8 *pData,
PPGPKT_STRUCT pTargetPkt)
{
_rtw_memset(pTargetPkt->data, 0xFF, PGPKT_DATA_SIZE);
pTargetPkt->offset = offset;
pTargetPkt->word_en = word_en;
efuse_WordEnableDataRead(word_en, pData, pTargetPkt->data);
pTargetPkt->word_cnts = Efuse_CalculateWordCnts(pTargetPkt->word_en);
}
static u8
hal_EfusePgPacketWriteData(
PADAPTER pAdapter,
u8 efuseType,
u16 *pAddr,
PPGPKT_STRUCT pTargetPkt,
u8 bPseudoTest)
{
u16 efuse_addr;
u8 badworden;
efuse_addr = *pAddr;
badworden = Hal_EfuseWordEnableDataWrite(pAdapter, efuse_addr + 1, pTargetPkt->word_en, pTargetPkt->data, bPseudoTest);
if (badworden != 0x0F) {
RTW_INFO("%s: Fail!!\n", __FUNCTION__);
return _FALSE;
} else
RTW_INFO("%s: OK!!\n", __FUNCTION__);
return _TRUE;
}
u8 efuse_OneByteRead(struct _ADAPTER *a, u16 addr, u8 *data, u8 bPseudoTest)
{
struct dvobj_priv *d;
int err;
u8 ret = _TRUE;
d = adapter_to_dvobj(a);
err = rtw_halmac_read_physical_efuse(d, addr, 1, data);
if (err) {
RTW_ERR("%s: addr=0x%x FAIL!!!\n", __FUNCTION__, addr);
ret = _FALSE;
}
return ret;
}
static u8
hal_BT_EfusePgCheckAvailableAddr(
PADAPTER pAdapter,
u8 bPseudoTest)
{
u16 max_available = EFUSE_BT_REAL_CONTENT_LEN - EFUSE_PROTECT_BYTES_BANK;
u16 current_size = 0;
RTW_INFO("%s: max_available=%d\n", __FUNCTION__, max_available);
current_size = hal_EfuseGetCurrentSize_BT(pAdapter, bPseudoTest);
if (current_size >= max_available) {
RTW_INFO("%s: Error!! current_size(%d)>max_available(%d)\n", __FUNCTION__, current_size, max_available);
return _FALSE;
}
return _TRUE;
}
u8 EfusePgPacketWrite_BT(
PADAPTER pAdapter,
u8 offset,
u8 word_en,
u8 *pData,
u8 bPseudoTest)
{
PGPKT_STRUCT targetPkt;
u16 startAddr = 0;
u8 efuseType = EFUSE_BT;
if (!hal_BT_EfusePgCheckAvailableAddr(pAdapter, bPseudoTest))
return _FALSE;
hal_EfuseConstructPGPkt(offset, word_en, pData, &targetPkt);
if (!hal_EfusePartialWriteCheck(pAdapter, efuseType, &startAddr, &targetPkt, bPseudoTest))
return _FALSE;
if (!hal_EfusePgPacketWriteHeader(pAdapter, efuseType, &startAddr, &targetPkt, bPseudoTest))
return _FALSE;
if (!hal_EfusePgPacketWriteData(pAdapter, efuseType, &startAddr, &targetPkt, bPseudoTest))
return _FALSE;
return _TRUE;
}
#else /* !RTW_HALMAC */
/* ------------------------------------------------------------------------------ */
#define REG_EFUSE_CTRL 0x0030
#define EFUSE_CTRL REG_EFUSE_CTRL /* E-Fuse Control. */
/* ------------------------------------------------------------------------------ */
BOOLEAN
Efuse_Read1ByteFromFakeContent(
PADAPTER pAdapter,
u16 Offset,
u8 *Value);
BOOLEAN
Efuse_Read1ByteFromFakeContent(
PADAPTER pAdapter,
u16 Offset,
u8 *Value)
{
if (Offset >= EFUSE_MAX_HW_SIZE)
return _FALSE;
/* DbgPrint("Read fake content, offset = %d\n", Offset); */
if (fakeEfuseBank == 0)
*Value = fakeEfuseContent[Offset];
else
*Value = fakeBTEfuseContent[fakeEfuseBank - 1][Offset];
return _TRUE;
}
BOOLEAN
Efuse_Write1ByteToFakeContent(
PADAPTER pAdapter,
u16 Offset,
u8 Value);
BOOLEAN
Efuse_Write1ByteToFakeContent(
PADAPTER pAdapter,
u16 Offset,
u8 Value)
{
if (Offset >= EFUSE_MAX_HW_SIZE)
return _FALSE;
if (fakeEfuseBank == 0)
fakeEfuseContent[Offset] = Value;
else
fakeBTEfuseContent[fakeEfuseBank - 1][Offset] = Value;
return _TRUE;
}
/*-----------------------------------------------------------------------------
* Function: Efuse_PowerSwitch
*
* Overview: When we want to enable write operation, we should change to
* pwr on state. When we stop write, we should switch to 500k mode
* and disable LDO 2.5V.
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/17/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
void
Efuse_PowerSwitch(
PADAPTER pAdapter,
u8 bWrite,
u8 PwrState)
{
pAdapter->hal_func.EfusePowerSwitch(pAdapter, bWrite, PwrState);
}
void
BTEfuse_PowerSwitch(
PADAPTER pAdapter,
u8 bWrite,
u8 PwrState)
{
if (pAdapter->hal_func.BTEfusePowerSwitch)
pAdapter->hal_func.BTEfusePowerSwitch(pAdapter, bWrite, PwrState);
}
/*-----------------------------------------------------------------------------
* Function: efuse_GetCurrentSize
*
* Overview: Get current efuse size!!!
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/16/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
u16
Efuse_GetCurrentSize(
PADAPTER pAdapter,
u8 efuseType,
BOOLEAN bPseudoTest)
{
u16 ret = 0;
ret = pAdapter->hal_func.EfuseGetCurrentSize(pAdapter, efuseType, bPseudoTest);
return ret;
}
/*
* Description:
* Execute E-Fuse read byte operation.
* Refered from SD1 Richard.
*
* Assumption:
* 1. Boot from E-Fuse and successfully auto-load.
* 2. PASSIVE_LEVEL (USB interface)
*
* Created by Roger, 2008.10.21.
* */
void
ReadEFuseByte(
PADAPTER Adapter,
u16 _offset,
u8 *pbuf,
BOOLEAN bPseudoTest)
{
u32 value32;
u8 readbyte;
u16 retry;
/* systime start=rtw_get_current_time(); */
if (bPseudoTest) {
Efuse_Read1ByteFromFakeContent(Adapter, _offset, pbuf);
return;
}
if (IS_HARDWARE_TYPE_8723B(Adapter)) {
/* <20130121, Kordan> For SMIC S55 EFUSE specificatoin. */
/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8]) */
phy_set_mac_reg(Adapter, EFUSE_TEST, BIT11, 0);
}
/* Write Address */
rtw_write8(Adapter, EFUSE_CTRL + 1, (_offset & 0xff));
readbyte = rtw_read8(Adapter, EFUSE_CTRL + 2);
rtw_write8(Adapter, EFUSE_CTRL + 2, ((_offset >> 8) & 0x03) | (readbyte & 0xfc));
/* Write bit 32 0 */
readbyte = rtw_read8(Adapter, EFUSE_CTRL + 3);
rtw_write8(Adapter, EFUSE_CTRL + 3, (readbyte & 0x7f));
/* Check bit 32 read-ready */
retry = 0;
value32 = rtw_read32(Adapter, EFUSE_CTRL);
/* while(!(((value32 >> 24) & 0xff) & 0x80) && (retry<10)) */
while (!(((value32 >> 24) & 0xff) & 0x80) && (retry < 10000)) {
value32 = rtw_read32(Adapter, EFUSE_CTRL);
retry++;
}
/* 20100205 Joseph: Add delay suggested by SD1 Victor. */
/* This fix the problem that Efuse read error in high temperature condition. */
/* Designer says that there shall be some delay after ready bit is set, or the */
/* result will always stay on last data we read. */
rtw_udelay_os(50);
value32 = rtw_read32(Adapter, EFUSE_CTRL);
*pbuf = (u8)(value32 & 0xff);
/* RTW_INFO("ReadEFuseByte _offset:%08u, in %d ms\n",_offset ,rtw_get_passing_time_ms(start)); */
}
/*
* Description:
* 1. Execute E-Fuse read byte operation according as map offset and
* save to E-Fuse table.
* 2. Refered from SD1 Richard.
*
* Assumption:
* 1. Boot from E-Fuse and successfully auto-load.
* 2. PASSIVE_LEVEL (USB interface)
*
* Created by Roger, 2008.10.21.
*
* 2008/12/12 MH 1. Reorganize code flow and reserve bytes. and add description.
* 2. Add efuse utilization collect.
* 2008/12/22 MH Read Efuse must check if we write section 1 data again!!! Sec1
* write addr must be after sec5.
* */
void
efuse_ReadEFuse(
PADAPTER Adapter,
u8 efuseType,
u16 _offset,
u16 _size_byte,
u8 *pbuf,
BOOLEAN bPseudoTest
);
void
efuse_ReadEFuse(
PADAPTER Adapter,
u8 efuseType,
u16 _offset,
u16 _size_byte,
u8 *pbuf,
BOOLEAN bPseudoTest
)
{
Adapter->hal_func.ReadEFuse(Adapter, efuseType, _offset, _size_byte, pbuf, bPseudoTest);
}
void
EFUSE_GetEfuseDefinition(
PADAPTER pAdapter,
u8 efuseType,
u8 type,
void *pOut,
BOOLEAN bPseudoTest
)
{
pAdapter->hal_func.EFUSEGetEfuseDefinition(pAdapter, efuseType, type, pOut, bPseudoTest);
}
/* 11/16/2008 MH Read one byte from real Efuse. */
u8
efuse_OneByteRead(
PADAPTER pAdapter,
u16 addr,
u8 *data,
BOOLEAN bPseudoTest)
{
u32 tmpidx = 0;
u8 bResult;
u8 readbyte;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
/* RTW_INFO("===> EFUSE_OneByteRead(), addr = %x\n", addr); */
/* RTW_INFO("===> EFUSE_OneByteRead() start, 0x34 = 0x%X\n", rtw_read32(pAdapter, EFUSE_TEST)); */
if (bPseudoTest) {
bResult = Efuse_Read1ByteFromFakeContent(pAdapter, addr, data);
return bResult;
}
#ifdef CONFIG_RTL8710B
/* <20171208, Peter>, Dont do the following write16(0x34) */
if (IS_HARDWARE_TYPE_8710B(pAdapter)) {
bResult = pAdapter->hal_func.efuse_indirect_read4(pAdapter, addr, data);
return bResult;
}
#endif
if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
(IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
(IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
) {
/* <20130121, Kordan> For SMIC EFUSE specificatoin. */
/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8]) */
/* phy_set_mac_reg(pAdapter, 0x34, BIT11, 0); */
rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter, 0x34) & (~BIT11));
}
/* -----------------e-fuse reg ctrl --------------------------------- */
/* address */
rtw_write8(pAdapter, EFUSE_CTRL + 1, (u8)(addr & 0xff));
rtw_write8(pAdapter, EFUSE_CTRL + 2, ((u8)((addr >> 8) & 0x03)) |
(rtw_read8(pAdapter, EFUSE_CTRL + 2) & 0xFC));
/* rtw_write8(pAdapter, EFUSE_CTRL+3, 0x72); */ /* read cmd */
/* Write bit 32 0 */
readbyte = rtw_read8(pAdapter, EFUSE_CTRL + 3);
rtw_write8(pAdapter, EFUSE_CTRL + 3, (readbyte & 0x7f));
while (!(0x80 & rtw_read8(pAdapter, EFUSE_CTRL + 3)) && (tmpidx < 1000)) {
rtw_mdelay_os(1);
tmpidx++;
}
if (tmpidx < 100) {
*data = rtw_read8(pAdapter, EFUSE_CTRL);
bResult = _TRUE;
} else {
*data = 0xff;
bResult = _FALSE;
RTW_INFO("%s: [ERROR] addr=0x%x bResult=%d time out 1s !!!\n", __FUNCTION__, addr, bResult);
RTW_INFO("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
}
return bResult;
}
/* 11/16/2008 MH Write one byte to reald Efuse. */
u8
efuse_OneByteWrite(
PADAPTER pAdapter,
u16 addr,
u8 data,
BOOLEAN bPseudoTest)
{
u8 tmpidx = 0;
u8 bResult = _FALSE;
u32 efuseValue = 0;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
/* RTW_INFO("===> EFUSE_OneByteWrite(), addr = %x data=%x\n", addr, data); */
/* RTW_INFO("===> EFUSE_OneByteWrite() start, 0x34 = 0x%X\n", rtw_read32(pAdapter, EFUSE_TEST)); */
if (bPseudoTest) {
bResult = Efuse_Write1ByteToFakeContent(pAdapter, addr, data);
return bResult;
}
Efuse_PowerSwitch(pAdapter, _TRUE, _TRUE);
/* -----------------e-fuse reg ctrl --------------------------------- */
/* address */
efuseValue = rtw_read32(pAdapter, EFUSE_CTRL);
efuseValue |= (BIT21 | BIT31);
efuseValue &= ~(0x3FFFF);
efuseValue |= ((addr << 8 | data) & 0x3FFFF);
/* <20130227, Kordan> 8192E MP chip A-cut had better not set 0x34[11] until B-Cut. */
if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
(IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
(IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
) {
/* <20130121, Kordan> For SMIC EFUSE specificatoin. */
/* 0x34[11]: SW force PGMEN input of efuse to high. (for the bank selected by 0x34[9:8]) */
/* phy_set_mac_reg(pAdapter, 0x34, BIT11, 1); */
rtw_write16(pAdapter, 0x34, rtw_read16(pAdapter, 0x34) | (BIT11));
rtw_write32(pAdapter, EFUSE_CTRL, 0x90600000 | ((addr << 8 | data)));
} else
rtw_write32(pAdapter, EFUSE_CTRL, efuseValue);
rtw_mdelay_os(1);
while ((0x80 & rtw_read8(pAdapter, EFUSE_CTRL + 3)) && (tmpidx < 100)) {
rtw_mdelay_os(1);
tmpidx++;
}
if (tmpidx < 100)
bResult = _TRUE;
else {
bResult = _FALSE;
RTW_INFO("%s: [ERROR] addr=0x%x ,efuseValue=0x%x ,bResult=%d time out 1s !!!\n",
__FUNCTION__, addr, efuseValue, bResult);
RTW_INFO("%s: [ERROR] EFUSE_CTRL =0x%08x !!!\n", __FUNCTION__, rtw_read32(pAdapter, EFUSE_CTRL));
}
/* disable Efuse program enable */
if (IS_HARDWARE_TYPE_8723B(pAdapter) ||
(IS_HARDWARE_TYPE_8192E(pAdapter) && (!IS_A_CUT(pHalData->version_id))) ||
(IS_VENDOR_8188E_I_CUT_SERIES(pAdapter)) || (IS_CHIP_VENDOR_SMIC(pHalData->version_id))
)
phy_set_mac_reg(pAdapter, EFUSE_TEST, BIT(11), 0);
Efuse_PowerSwitch(pAdapter, _TRUE, _FALSE);
return bResult;
}
int
Efuse_PgPacketRead(PADAPTER pAdapter,
u8 offset,
u8 *data,
BOOLEAN bPseudoTest)
{
int ret = 0;
ret = pAdapter->hal_func.Efuse_PgPacketRead(pAdapter, offset, data, bPseudoTest);
return ret;
}
int
Efuse_PgPacketWrite(PADAPTER pAdapter,
u8 offset,
u8 word_en,
u8 *data,
BOOLEAN bPseudoTest)
{
int ret;
ret = pAdapter->hal_func.Efuse_PgPacketWrite(pAdapter, offset, word_en, data, bPseudoTest);
return ret;
}
int
Efuse_PgPacketWrite_BT(PADAPTER pAdapter,
u8 offset,
u8 word_en,
u8 *data,
BOOLEAN bPseudoTest)
{
int ret;
ret = pAdapter->hal_func.Efuse_PgPacketWrite_BT(pAdapter, offset, word_en, data, bPseudoTest);
return ret;
}
u8
Efuse_WordEnableDataWrite(PADAPTER pAdapter,
u16 efuse_addr,
u8 word_en,
u8 *data,
BOOLEAN bPseudoTest)
{
u8 ret = 0;
ret = pAdapter->hal_func.Efuse_WordEnableDataWrite(pAdapter, efuse_addr, word_en, data, bPseudoTest);
return ret;
}
static u8 efuse_read8(PADAPTER padapter, u16 address, u8 *value)
{
return efuse_OneByteRead(padapter, address, value, _FALSE);
}
static u8 efuse_write8(PADAPTER padapter, u16 address, u8 *value)
{
return efuse_OneByteWrite(padapter, address, *value, _FALSE);
}
/*
* read/wirte raw efuse data
*/
u8 rtw_efuse_access(PADAPTER padapter, u8 bWrite, u16 start_addr, u16 cnts, u8 *data)
{
int i = 0;
u16 real_content_len = 0, max_available_size = 0;
u8 res = _FAIL ;
u8(*rw8)(PADAPTER, u16, u8 *);
u32 backupRegs[4] = {0};
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_REAL_CONTENT_LEN, (void *)&real_content_len, _FALSE);
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (void *)&max_available_size, _FALSE);
if (start_addr > real_content_len)
return _FAIL;
if (_TRUE == bWrite) {
if ((start_addr + cnts) > max_available_size)
return _FAIL;
rw8 = &efuse_write8;
} else
rw8 = &efuse_read8;
efuse_PreUpdateAction(padapter, backupRegs);
Efuse_PowerSwitch(padapter, bWrite, _TRUE);
/* e-fuse one byte read / write */
for (i = 0; i < cnts; i++) {
if (start_addr >= real_content_len) {
res = _FAIL;
break;
}
res = rw8(padapter, start_addr++, data++);
if (_FAIL == res)
break;
}
Efuse_PowerSwitch(padapter, bWrite, _FALSE);
efuse_PostUpdateAction(padapter, backupRegs);
return res;
}
/* ------------------------------------------------------------------------------ */
u16 efuse_GetMaxSize(PADAPTER padapter)
{
u16 max_size;
max_size = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI , TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (void *)&max_size, _FALSE);
return max_size;
}
/* ------------------------------------------------------------------------------ */
u8 efuse_GetCurrentSize(PADAPTER padapter, u16 *size)
{
Efuse_PowerSwitch(padapter, _FALSE, _TRUE);
*size = Efuse_GetCurrentSize(padapter, EFUSE_WIFI, _FALSE);
Efuse_PowerSwitch(padapter, _FALSE, _FALSE);
return _SUCCESS;
}
/* ------------------------------------------------------------------------------ */
u16 efuse_bt_GetMaxSize(PADAPTER padapter)
{
u16 max_size;
max_size = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_BT , TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, (void *)&max_size, _FALSE);
return max_size;
}
u8 efuse_bt_GetCurrentSize(PADAPTER padapter, u16 *size)
{
Efuse_PowerSwitch(padapter, _FALSE, _TRUE);
*size = Efuse_GetCurrentSize(padapter, EFUSE_BT, _FALSE);
Efuse_PowerSwitch(padapter, _FALSE, _FALSE);
return _SUCCESS;
}
u8 rtw_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
u16 mapLen = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
if ((addr + cnts) > mapLen)
return _FAIL;
Efuse_PowerSwitch(padapter, _FALSE, _TRUE);
efuse_ReadEFuse(padapter, EFUSE_WIFI, addr, cnts, data, _FALSE);
Efuse_PowerSwitch(padapter, _FALSE, _FALSE);
return _SUCCESS;
}
u8 rtw_BT_efuse_map_read(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
u16 mapLen = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
if ((addr + cnts) > mapLen)
return _FAIL;
Efuse_PowerSwitch(padapter, _FALSE, _TRUE);
efuse_ReadEFuse(padapter, EFUSE_BT, addr, cnts, data, _FALSE);
Efuse_PowerSwitch(padapter, _FALSE, _FALSE);
return _SUCCESS;
}
/* ------------------------------------------------------------------------------ */
u8 rtw_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
#define RT_ASSERT_RET(expr) \
if (!(expr)) { \
printk("Assertion failed! %s at ......\n", #expr); \
printk(" ......%s,%s, line=%d\n",__FILE__, __FUNCTION__, __LINE__); \
return _FAIL; \
}
u8 *efuse = NULL;
u8 offset, word_en;
u8 *map = NULL;
u8 newdata[PGPKT_DATA_SIZE];
s32 i, j, idx, chk_total_byte;
u8 ret = _SUCCESS;
u16 mapLen = 0, startAddr = 0, efuse_max_available_len = 0;
u32 backupRegs[4] = {0};
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &efuse_max_available_len, _FALSE);
if ((addr + cnts) > mapLen)
return _FAIL;
RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); /* have to be 8 byte alignment */
RT_ASSERT_RET((mapLen & 0x7) == 0); /* have to be PGPKT_DATA_SIZE alignment for memcpy */
efuse = rtw_zmalloc(mapLen);
if (!efuse)
return _FAIL;
map = rtw_zmalloc(mapLen);
if (map == NULL) {
rtw_mfree(efuse, mapLen);
return _FAIL;
}
_rtw_memset(map, 0xFF, mapLen);
ret = rtw_efuse_map_read(padapter, 0, mapLen, map);
if (ret == _FAIL)
goto exit;
_rtw_memcpy(efuse , map, mapLen);
_rtw_memcpy(efuse + addr, data, cnts);
if (padapter->registrypriv.boffefusemask == 0) {
for (i = 0; i < cnts; i++) {
if (padapter->registrypriv.bFileMaskEfuse == _TRUE) {
if (rtw_file_efuse_IsMasked(padapter, addr + i), maskfileBuffer) /*use file efuse mask. */
efuse[addr + i] = map[addr + i];
} else {
if (efuse_IsMasked(padapter, addr + i))
efuse[addr + i] = map[addr + i];
}
RTW_INFO("%s , data[%d] = %x, map[addr+i]= %x\n", __func__, addr + i, efuse[ addr + i], map[addr + i]);
}
}
/*Efuse_PowerSwitch(padapter, _TRUE, _TRUE);*/
chk_total_byte = 0;
idx = 0;
offset = (addr >> 3);
while (idx < cnts) {
word_en = 0xF;
j = (addr + idx) & 0x7;
for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
if (efuse[addr + idx] != map[addr + idx])
word_en &= ~BIT(i >> 1);
}
if (word_en != 0xF) {
chk_total_byte += Efuse_CalculateWordCnts(word_en) * 2;
if (offset >= EFUSE_MAX_SECTION_BASE) /* Over EFUSE_MAX_SECTION 16 for 2 ByteHeader */
chk_total_byte += 2;
else
chk_total_byte += 1;
}
offset++;
}
RTW_INFO("Total PG bytes Count = %d\n", chk_total_byte);
rtw_hal_get_hwreg(padapter, HW_VAR_EFUSE_BYTES, (u8 *)&startAddr);
if (startAddr == 0) {
startAddr = Efuse_GetCurrentSize(padapter, EFUSE_WIFI, _FALSE);
RTW_INFO("%s: Efuse_GetCurrentSize startAddr=%#X\n", __func__, startAddr);
}
RTW_DBG("%s: startAddr=%#X\n", __func__, startAddr);
if ((startAddr + chk_total_byte) >= efuse_max_available_len) {
RTW_INFO("%s: startAddr(0x%X) + PG data len %d >= efuse_max_available_len(0x%X)\n",
__func__, startAddr, chk_total_byte, efuse_max_available_len);
ret = _FAIL;
goto exit;
}
efuse_PreUpdateAction(padapter, backupRegs);
idx = 0;
offset = (addr >> 3);
while (idx < cnts) {
word_en = 0xF;
j = (addr + idx) & 0x7;
_rtw_memcpy(newdata, &map[offset << 3], PGPKT_DATA_SIZE);
for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
if (efuse[addr + idx] != map[addr + idx]) {
word_en &= ~BIT(i >> 1);
newdata[i] = efuse[addr + idx];
#ifdef CONFIG_RTL8723B
if (addr + idx == 0x8) {
if (IS_C_CUT(pHalData->version_id) || IS_B_CUT(pHalData->version_id)) {
if (pHalData->adjuseVoltageVal == 6) {
newdata[i] = map[addr + idx];
RTW_INFO(" %s ,\n adjuseVoltageVal = %d ,newdata[%d] = %x\n", __func__, pHalData->adjuseVoltageVal, i, newdata[i]);
}
}
}
#endif
}
}
if (word_en != 0xF) {
ret = Efuse_PgPacketWrite(padapter, offset, word_en, newdata, _FALSE);
RTW_INFO("offset=%x\n", offset);
RTW_INFO("word_en=%x\n", word_en);
for (i = 0; i < PGPKT_DATA_SIZE; i++)
RTW_INFO("data=%x \t", newdata[i]);
if (ret == _FAIL)
break;
}
offset++;
}
/*Efuse_PowerSwitch(padapter, _TRUE, _FALSE);*/
efuse_PostUpdateAction(padapter, backupRegs);
exit:
rtw_mfree(map, mapLen);
rtw_mfree(efuse, mapLen);
return ret;
}
u8 rtw_BT_efuse_map_write(PADAPTER padapter, u16 addr, u16 cnts, u8 *data)
{
#define RT_ASSERT_RET(expr) \
if (!(expr)) { \
printk("Assertion failed! %s at ......\n", #expr); \
printk(" ......%s,%s, line=%d\n",__FILE__, __FUNCTION__, __LINE__); \
return _FAIL; \
}
u8 offset, word_en;
u8 *map;
u8 newdata[PGPKT_DATA_SIZE];
s32 i = 0, j = 0, idx;
u8 ret = _SUCCESS;
u16 mapLen = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_BT, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
if ((addr + cnts) > mapLen)
return _FAIL;
RT_ASSERT_RET(PGPKT_DATA_SIZE == 8); /* have to be 8 byte alignment */
RT_ASSERT_RET((mapLen & 0x7) == 0); /* have to be PGPKT_DATA_SIZE alignment for memcpy */
map = rtw_zmalloc(mapLen);
if (map == NULL)
return _FAIL;
ret = rtw_BT_efuse_map_read(padapter, 0, mapLen, map);
if (ret == _FAIL)
goto exit;
RTW_INFO("OFFSET\tVALUE(hex)\n");
for (i = 0; i < 1024; i += 16) { /* set 512 because the iwpriv's extra size have limit 0x7FF */
RTW_INFO("0x%03x\t", i);
for (j = 0; j < 8; j++)
RTW_INFO("%02X ", map[i + j]);
RTW_INFO("\t");
for (; j < 16; j++)
RTW_INFO("%02X ", map[i + j]);
RTW_INFO("\n");
}
RTW_INFO("\n");
Efuse_PowerSwitch(padapter, _TRUE, _TRUE);
idx = 0;
offset = (addr >> 3);
while (idx < cnts) {
word_en = 0xF;
j = (addr + idx) & 0x7;
_rtw_memcpy(newdata, &map[offset << 3], PGPKT_DATA_SIZE);
for (i = j; i < PGPKT_DATA_SIZE && idx < cnts; i++, idx++) {
if (data[idx] != map[addr + idx]) {
word_en &= ~BIT(i >> 1);
newdata[i] = data[idx];
}
}
if (word_en != 0xF) {
RTW_INFO("offset=%x\n", offset);
RTW_INFO("word_en=%x\n", word_en);
RTW_INFO("%s: data=", __FUNCTION__);
for (i = 0; i < PGPKT_DATA_SIZE; i++)
RTW_INFO("0x%02X ", newdata[i]);
RTW_INFO("\n");
ret = Efuse_PgPacketWrite_BT(padapter, offset, word_en, newdata, _FALSE);
if (ret == _FAIL)
break;
}
offset++;
}
Efuse_PowerSwitch(padapter, _TRUE, _FALSE);
exit:
rtw_mfree(map, mapLen);
return ret;
}
/*-----------------------------------------------------------------------------
* Function: Efuse_ReadAllMap
*
* Overview: Read All Efuse content
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/11/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
void
Efuse_ReadAllMap(
PADAPTER pAdapter,
u8 efuseType,
u8 *Efuse,
BOOLEAN bPseudoTest);
void
Efuse_ReadAllMap(
PADAPTER pAdapter,
u8 efuseType,
u8 *Efuse,
BOOLEAN bPseudoTest)
{
u16 mapLen = 0;
Efuse_PowerSwitch(pAdapter, _FALSE, _TRUE);
EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, bPseudoTest);
efuse_ReadEFuse(pAdapter, efuseType, 0, mapLen, Efuse, bPseudoTest);
Efuse_PowerSwitch(pAdapter, _FALSE, _FALSE);
}
/*-----------------------------------------------------------------------------
* Function: efuse_ShadowWrite1Byte
* efuse_ShadowWrite2Byte
* efuse_ShadowWrite4Byte
*
* Overview: Write efuse modify map by one/two/four byte.
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/12/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
#ifdef PLATFORM
static void
efuse_ShadowWrite1Byte(
PADAPTER pAdapter,
u16 Offset,
u8 Value);
#endif /* PLATFORM */
static void
efuse_ShadowWrite1Byte(
PADAPTER pAdapter,
u16 Offset,
u8 Value)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
pHalData->efuse_eeprom_data[Offset] = Value;
} /* efuse_ShadowWrite1Byte */
/* ---------------Write Two Bytes */
static void
efuse_ShadowWrite2Byte(
PADAPTER pAdapter,
u16 Offset,
u16 Value)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
pHalData->efuse_eeprom_data[Offset] = Value & 0x00FF;
pHalData->efuse_eeprom_data[Offset + 1] = Value >> 8;
} /* efuse_ShadowWrite1Byte */
/* ---------------Write Four Bytes */
static void
efuse_ShadowWrite4Byte(
PADAPTER pAdapter,
u16 Offset,
u32 Value)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
pHalData->efuse_eeprom_data[Offset] = (u8)(Value & 0x000000FF);
pHalData->efuse_eeprom_data[Offset + 1] = (u8)((Value >> 8) & 0x0000FF);
pHalData->efuse_eeprom_data[Offset + 2] = (u8)((Value >> 16) & 0x00FF);
pHalData->efuse_eeprom_data[Offset + 3] = (u8)((Value >> 24) & 0xFF);
} /* efuse_ShadowWrite1Byte */
/*-----------------------------------------------------------------------------
* Function: EFUSE_ShadowWrite
*
* Overview: Write efuse modify map for later update operation to use!!!!!
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/12/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
void
EFUSE_ShadowWrite(
PADAPTER pAdapter,
u8 Type,
u16 Offset,
u32 Value);
void
EFUSE_ShadowWrite(
PADAPTER pAdapter,
u8 Type,
u16 Offset,
u32 Value)
{
#if (MP_DRIVER == 0)
return;
#endif
if (pAdapter->registrypriv.mp_mode == 0)
return;
if (Type == 1)
efuse_ShadowWrite1Byte(pAdapter, Offset, (u8)Value);
else if (Type == 2)
efuse_ShadowWrite2Byte(pAdapter, Offset, (u16)Value);
else if (Type == 4)
efuse_ShadowWrite4Byte(pAdapter, Offset, (u32)Value);
} /* EFUSE_ShadowWrite */
#endif /* !RTW_HALMAC */
/*-----------------------------------------------------------------------------
* Function: efuse_ShadowRead1Byte
* efuse_ShadowRead2Byte
* efuse_ShadowRead4Byte
*
* Overview: Read from efuse init map by one/two/four bytes !!!!!
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/12/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
static void
efuse_ShadowRead1Byte(
PADAPTER pAdapter,
u16 Offset,
u8 *Value)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
*Value = pHalData->efuse_eeprom_data[Offset];
} /* EFUSE_ShadowRead1Byte */
/* ---------------Read Two Bytes */
static void
efuse_ShadowRead2Byte(
PADAPTER pAdapter,
u16 Offset,
u16 *Value)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
*Value = pHalData->efuse_eeprom_data[Offset];
*Value |= pHalData->efuse_eeprom_data[Offset + 1] << 8;
} /* EFUSE_ShadowRead2Byte */
/* ---------------Read Four Bytes */
static void
efuse_ShadowRead4Byte(
PADAPTER pAdapter,
u16 Offset,
u32 *Value)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
*Value = pHalData->efuse_eeprom_data[Offset];
*Value |= pHalData->efuse_eeprom_data[Offset + 1] << 8;
*Value |= pHalData->efuse_eeprom_data[Offset + 2] << 16;
*Value |= pHalData->efuse_eeprom_data[Offset + 3] << 24;
} /* efuse_ShadowRead4Byte */
/*-----------------------------------------------------------------------------
* Function: EFUSE_ShadowRead
*
* Overview: Read from pHalData->efuse_eeprom_data
*---------------------------------------------------------------------------*/
void
EFUSE_ShadowRead(
PADAPTER pAdapter,
u8 Type,
u16 Offset,
u32 *Value)
{
if (Type == 1)
efuse_ShadowRead1Byte(pAdapter, Offset, (u8 *)Value);
else if (Type == 2)
efuse_ShadowRead2Byte(pAdapter, Offset, (u16 *)Value);
else if (Type == 4)
efuse_ShadowRead4Byte(pAdapter, Offset, (u32 *)Value);
} /* EFUSE_ShadowRead */
/* 11/16/2008 MH Add description. Get current efuse area enabled word!!. */
u8
Efuse_CalculateWordCnts(u8 word_en)
{
u8 word_cnts = 0;
if (!(word_en & BIT(0)))
word_cnts++; /* 0 : write enable */
if (!(word_en & BIT(1)))
word_cnts++;
if (!(word_en & BIT(2)))
word_cnts++;
if (!(word_en & BIT(3)))
word_cnts++;
return word_cnts;
}
/*-----------------------------------------------------------------------------
* Function: efuse_WordEnableDataRead
*
* Overview: Read allowed word in current efuse section data.
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/16/2008 MHC Create Version 0.
* 11/21/2008 MHC Fix Write bug when we only enable late word.
*
*---------------------------------------------------------------------------*/
void
efuse_WordEnableDataRead(u8 word_en,
u8 *sourdata,
u8 *targetdata)
{
if (!(word_en & BIT(0))) {
targetdata[0] = sourdata[0];
targetdata[1] = sourdata[1];
}
if (!(word_en & BIT(1))) {
targetdata[2] = sourdata[2];
targetdata[3] = sourdata[3];
}
if (!(word_en & BIT(2))) {
targetdata[4] = sourdata[4];
targetdata[5] = sourdata[5];
}
if (!(word_en & BIT(3))) {
targetdata[6] = sourdata[6];
targetdata[7] = sourdata[7];
}
}
/*-----------------------------------------------------------------------------
* Function: EFUSE_ShadowMapUpdate
*
* Overview: Transfer current EFUSE content to shadow init and modify map.
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/13/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
void EFUSE_ShadowMapUpdate(
PADAPTER pAdapter,
u8 efuseType,
BOOLEAN bPseudoTest)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
u16 mapLen = 0;
#ifdef RTW_HALMAC
u8 *efuse_map = NULL;
int err;
mapLen = EEPROM_MAX_SIZE;
efuse_map = pHalData->efuse_eeprom_data;
/* efuse default content is 0xFF */
_rtw_memset(efuse_map, 0xFF, EEPROM_MAX_SIZE);
EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, bPseudoTest);
if (!mapLen) {
RTW_WARN("%s: fail to get efuse size!\n", __FUNCTION__);
mapLen = EEPROM_MAX_SIZE;
}
if (mapLen > EEPROM_MAX_SIZE) {
RTW_WARN("%s: size of efuse data(%d) is large than expected(%d)!\n",
__FUNCTION__, mapLen, EEPROM_MAX_SIZE);
mapLen = EEPROM_MAX_SIZE;
}
if (pHalData->bautoload_fail_flag == _FALSE) {
err = rtw_halmac_read_logical_efuse_map(adapter_to_dvobj(pAdapter), efuse_map, mapLen, NULL, 0);
if (err)
RTW_ERR("%s: fail to get efuse map!\n", __FUNCTION__);
}
#else /* !RTW_HALMAC */
EFUSE_GetEfuseDefinition(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, bPseudoTest);
if (pHalData->bautoload_fail_flag == _TRUE)
_rtw_memset(pHalData->efuse_eeprom_data, 0xFF, mapLen);
else {
#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
if (_SUCCESS != retriveAdaptorInfoFile(pAdapter->registrypriv.adaptor_info_caching_file_path, pHalData->efuse_eeprom_data)) {
#endif
Efuse_ReadAllMap(pAdapter, efuseType, pHalData->efuse_eeprom_data, bPseudoTest);
#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
storeAdaptorInfoFile(pAdapter->registrypriv.adaptor_info_caching_file_path, pHalData->efuse_eeprom_data);
}
#endif
}
/* PlatformMoveMemory((void *)&pHalData->EfuseMap[EFUSE_MODIFY_MAP][0], */
/* (void *)&pHalData->EfuseMap[EFUSE_INIT_MAP][0], mapLen); */
#endif /* !RTW_HALMAC */
rtw_mask_map_read(pAdapter, 0x00, mapLen, pHalData->efuse_eeprom_data);
rtw_dump_cur_efuse(pAdapter);
} /* EFUSE_ShadowMapUpdate */
const u8 _mac_hidden_max_bw_to_hal_bw_cap[MAC_HIDDEN_MAX_BW_NUM] = {
0,
0,
(BW_CAP_160M | BW_CAP_80M | BW_CAP_40M | BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
(BW_CAP_5M),
(BW_CAP_10M | BW_CAP_5M),
(BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
(BW_CAP_40M | BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
(BW_CAP_80M | BW_CAP_40M | BW_CAP_20M | BW_CAP_10M | BW_CAP_5M),
};
const u8 _mac_hidden_proto_to_hal_proto_cap[MAC_HIDDEN_PROTOCOL_NUM] = {
0,
0,
(PROTO_CAP_11N | PROTO_CAP_11G | PROTO_CAP_11B),
(PROTO_CAP_11AC | PROTO_CAP_11N | PROTO_CAP_11G | PROTO_CAP_11B),
};
u8 mac_hidden_wl_func_to_hal_wl_func(u8 func)
{
u8 wl_func = 0;
if (func & BIT0)
wl_func |= WL_FUNC_MIRACAST;
if (func & BIT1)
wl_func |= WL_FUNC_P2P;
if (func & BIT2)
wl_func |= WL_FUNC_TDLS;
if (func & BIT3)
wl_func |= WL_FUNC_FTM;
return wl_func;
}
#ifdef PLATFORM_LINUX
#ifdef CONFIG_ADAPTOR_INFO_CACHING_FILE
/* #include */
int isAdaptorInfoFileValid(void)
{
return _TRUE;
}
int storeAdaptorInfoFile(char *path, u8 *efuse_data)
{
int ret = _SUCCESS;
if (path && efuse_data) {
ret = rtw_store_to_file(path, efuse_data, EEPROM_MAX_SIZE_512);
if (ret == EEPROM_MAX_SIZE)
ret = _SUCCESS;
else
ret = _FAIL;
} else {
RTW_INFO("%s NULL pointer\n", __FUNCTION__);
ret = _FAIL;
}
return ret;
}
int retriveAdaptorInfoFile(char *path, u8 *efuse_data)
{
int ret = _SUCCESS;
mm_segment_t oldfs;
struct file *fp;
if (path && efuse_data) {
ret = rtw_retrieve_from_file(path, efuse_data, EEPROM_MAX_SIZE);
if (ret == EEPROM_MAX_SIZE)
ret = _SUCCESS;
else
ret = _FAIL;
#if 0
if (isAdaptorInfoFileValid())
return 0;
else
return _FAIL;
#endif
} else {
RTW_INFO("%s NULL pointer\n", __FUNCTION__);
ret = _FAIL;
}
return ret;
}
#endif /* CONFIG_ADAPTOR_INFO_CACHING_FILE */
u8 rtw_efuse_file_read(PADAPTER padapter, u8 *filepatch, u8 *buf, u32 len)
{
char *ptmpbuf = NULL, *ptr;
u8 val8;
u32 count, i, j;
int err;
u32 bufsize = 4096;
ptmpbuf = rtw_zmalloc(bufsize);
if (ptmpbuf == NULL)
return _FALSE;
count = rtw_retrieve_from_file(filepatch, ptmpbuf, bufsize);
if (count <= 90) {
rtw_mfree(ptmpbuf, bufsize);
RTW_ERR("%s, filepatch %s, size=%d, FAIL!!\n", __FUNCTION__, filepatch, count);
return _FALSE;
}
i = 0;
j = 0;
ptr = ptmpbuf;
while ((j < len) && (i < count)) {
if (ptmpbuf[i] == '\0')
break;
ptr = strpbrk(&ptmpbuf[i], " \t\n\r");
if (ptr) {
if (ptr == &ptmpbuf[i]) {
i++;
continue;
}
/* Add string terminating null */
*ptr = 0;
} else {
ptr = &ptmpbuf[count-1];
}
err = sscanf(&ptmpbuf[i], "%hhx", &val8);
if (err != 1) {
RTW_WARN("Something wrong to parse efuse file, string=%s\n", &ptmpbuf[i]);
} else {
buf[j] = val8;
RTW_DBG("i=%d, j=%d, 0x%02x\n", i, j, buf[j]);
j++;
}
i = ptr - ptmpbuf + 1;
}
rtw_mfree(ptmpbuf, bufsize);
RTW_INFO("%s, filepatch %s, size=%d, done\n", __FUNCTION__, filepatch, count);
return _TRUE;
}
#ifdef CONFIG_EFUSE_CONFIG_FILE
u32 rtw_read_efuse_from_file(const char *path, u8 *buf, int map_size)
{
u32 i;
u8 c;
u8 temp[3];
u8 temp_i;
u8 end = _FALSE;
u32 ret = _FAIL;
u8 *file_data = NULL;
u32 file_size, read_size, pos = 0;
u8 *map = NULL;
if (rtw_is_file_readable_with_size(path, &file_size) != _TRUE) {
RTW_PRINT("%s %s is not readable\n", __func__, path);
goto exit;
}
file_data = rtw_vmalloc(file_size);
if (!file_data) {
RTW_ERR("%s rtw_vmalloc(%d) fail\n", __func__, file_size);
goto exit;
}
read_size = rtw_retrieve_from_file(path, file_data, file_size);
if (read_size == 0) {
RTW_ERR("%s read from %s fail\n", __func__, path);
goto exit;
}
map = rtw_vmalloc(map_size);
if (!map) {
RTW_ERR("%s rtw_vmalloc(%d) fail\n", __func__, map_size);
goto exit;
}
_rtw_memset(map, 0xff, map_size);
temp[2] = 0; /* end of string '\0' */
for (i = 0 ; i < map_size ; i++) {
temp_i = 0;
while (1) {
if (pos >= read_size) {
end = _TRUE;
break;
}
c = file_data[pos++];
/* bypass spece or eol or null before first hex digit */
if (temp_i == 0 && (is_eol(c) == _TRUE || is_space(c) == _TRUE || is_null(c) == _TRUE))
continue;
if (IsHexDigit(c) == _FALSE) {
RTW_ERR("%s invalid 8-bit hex format for offset:0x%03x\n", __func__, i);
goto exit;
}
temp[temp_i++] = c;
if (temp_i == 2) {
/* parse value */
if (sscanf(temp, "%hhx", &map[i]) != 1) {
RTW_ERR("%s sscanf fail for offset:0x%03x\n", __func__, i);
goto exit;
}
break;
}
}
if (end == _TRUE) {
if (temp_i != 0) {
RTW_ERR("%s incomplete 8-bit hex format for offset:0x%03x\n", __func__, i);
goto exit;
}
break;
}
}
RTW_PRINT("efuse file:%s, 0x%03x byte content read\n", path, i);
_rtw_memcpy(buf, map, map_size);
ret = _SUCCESS;
exit:
if (file_data)
rtw_vmfree(file_data, file_size);
if (map)
rtw_vmfree(map, map_size);
return ret;
}
u32 rtw_read_macaddr_from_file(const char *path, u8 *buf)
{
u32 i;
u8 temp[3];
u32 ret = _FAIL;
u8 file_data[17];
u32 read_size, pos = 0;
u8 addr[ETH_ALEN];
if (rtw_is_file_readable(path) != _TRUE) {
RTW_PRINT("%s %s is not readable\n", __func__, path);
goto exit;
}
read_size = rtw_retrieve_from_file(path, file_data, 17);
if (read_size != 17) {
RTW_ERR("%s read from %s fail\n", __func__, path);
goto exit;
}
temp[2] = 0; /* end of string '\0' */
for (i = 0 ; i < ETH_ALEN ; i++) {
if (IsHexDigit(file_data[i * 3]) == _FALSE || IsHexDigit(file_data[i * 3 + 1]) == _FALSE) {
RTW_ERR("%s invalid 8-bit hex format for address offset:%u\n", __func__, i);
goto exit;
}
if (i < ETH_ALEN - 1 && file_data[i * 3 + 2] != ':') {
RTW_ERR("%s invalid separator after address offset:%u\n", __func__, i);
goto exit;
}
temp[0] = file_data[i * 3];
temp[1] = file_data[i * 3 + 1];
if (sscanf(temp, "%hhx", &addr[i]) != 1) {
RTW_ERR("%s sscanf fail for address offset:0x%03x\n", __func__, i);
goto exit;
}
}
_rtw_memcpy(buf, addr, ETH_ALEN);
RTW_PRINT("wifi_mac file: %s\n", path);
#ifdef CONFIG_RTW_DEBUG
RTW_INFO(MAC_FMT"\n", MAC_ARG(buf));
#endif
ret = _SUCCESS;
exit:
return ret;
}
#endif /* CONFIG_EFUSE_CONFIG_FILE */
#endif /* PLATFORM_LINUX */
================================================
FILE: core/mesh/rtw_mesh.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_MESH_C_
#ifdef CONFIG_RTW_MESH
#include
const char *_rtw_mesh_plink_str[] = {
"UNKNOWN",
"LISTEN",
"OPN_SNT",
"OPN_RCVD",
"CNF_RCVD",
"ESTAB",
"HOLDING",
"BLOCKED",
};
const char *_rtw_mesh_ps_str[] = {
"UNKNOWN",
"ACTIVE",
"LSLEEP",
"DSLEEP",
};
const char *_action_self_protected_str[] = {
"ACT_SELF_PROTECTED_RSVD",
"MESH_OPEN",
"MESH_CONF",
"MESH_CLOSE",
"MESH_GK_INFORM",
"MESH_GK_ACK",
};
inline u8 *rtw_set_ie_mesh_id(u8 *buf, u32 *buf_len, const char *mesh_id, u8 id_len)
{
return rtw_set_ie(buf, WLAN_EID_MESH_ID, id_len, mesh_id, buf_len);
}
inline u8 *rtw_set_ie_mesh_config(u8 *buf, u32 *buf_len
, u8 path_sel_proto, u8 path_sel_metric, u8 congest_ctl_mode, u8 sync_method, u8 auth_proto
, u8 num_of_peerings, bool cto_mgate, bool cto_as
, bool accept_peerings, bool mcca_sup, bool mcca_en, bool forwarding
, bool mbca_en, bool tbtt_adj, bool ps_level)
{
u8 conf[7] = {0};
SET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(conf, path_sel_proto);
SET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(conf, path_sel_metric);
SET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(conf, congest_ctl_mode);
SET_MESH_CONF_ELE_SYNC_METHOD_ID(conf, sync_method);
SET_MESH_CONF_ELE_AUTH_PROTO_ID(conf, auth_proto);
SET_MESH_CONF_ELE_CTO_MGATE(conf, cto_mgate);
SET_MESH_CONF_ELE_NUM_OF_PEERINGS(conf, num_of_peerings);
SET_MESH_CONF_ELE_CTO_AS(conf, cto_as);
SET_MESH_CONF_ELE_ACCEPT_PEERINGS(conf, accept_peerings);
SET_MESH_CONF_ELE_MCCA_SUP(conf, mcca_sup);
SET_MESH_CONF_ELE_MCCA_EN(conf, mcca_en);
SET_MESH_CONF_ELE_FORWARDING(conf, forwarding);
SET_MESH_CONF_ELE_MBCA_EN(conf, mbca_en);
SET_MESH_CONF_ELE_TBTT_ADJ(conf, tbtt_adj);
SET_MESH_CONF_ELE_PS_LEVEL(conf, ps_level);
return rtw_set_ie(buf, WLAN_EID_MESH_CONFIG, 7, conf, buf_len);
}
inline u8 *rtw_set_ie_mpm(u8 *buf, u32 *buf_len
, u8 proto_id, u16 llid, u16 *plid, u16 *reason, u8 *chosen_pmk)
{
u8 data[24] = {0};
u8 *pos = data;
RTW_PUT_LE16(pos, proto_id);
pos += 2;
RTW_PUT_LE16(pos, llid);
pos += 2;
if (plid) {
RTW_PUT_LE16(pos, *plid);
pos += 2;
}
if (reason) {
RTW_PUT_LE16(pos, *reason);
pos += 2;
}
if (chosen_pmk) {
_rtw_memcpy(pos, chosen_pmk, 16);
pos += 16;
}
return rtw_set_ie(buf, WLAN_EID_MPM, pos - data, data, buf_len);
}
bool rtw_bss_is_forwarding(WLAN_BSSID_EX *bss)
{
u8 *ie;
int ie_len;
bool ret = 0;
ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
BSS_EX_TLV_IES_LEN(bss));
if (!ie || ie_len != 7)
goto exit;
ret = GET_MESH_CONF_ELE_FORWARDING(ie + 2);
exit:
return ret;
}
bool rtw_bss_is_cto_mgate(WLAN_BSSID_EX *bss)
{
u8 *ie;
int ie_len;
bool ret = 0;
ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
BSS_EX_TLV_IES_LEN(bss));
if (!ie || ie_len != 7)
goto exit;
ret = GET_MESH_CONF_ELE_CTO_MGATE(ie + 2);
exit:
return ret;
}
int rtw_bss_is_same_mbss(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b)
{
int ret = 0;
u8 *a_mconf_ie, *b_mconf_ie;
sint a_mconf_ie_len, b_mconf_ie_len;
if (a->InfrastructureMode != Ndis802_11_mesh)
goto exit;
a_mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(a), WLAN_EID_MESH_CONFIG, &a_mconf_ie_len, BSS_EX_TLV_IES_LEN(a));
if (!a_mconf_ie || a_mconf_ie_len != 7)
goto exit;
if (b->InfrastructureMode != Ndis802_11_mesh)
goto exit;
b_mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(b), WLAN_EID_MESH_CONFIG, &b_mconf_ie_len, BSS_EX_TLV_IES_LEN(b));
if (!b_mconf_ie || b_mconf_ie_len != 7)
goto exit;
if (a->mesh_id.SsidLength != b->mesh_id.SsidLength
|| _rtw_memcmp(a->mesh_id.Ssid, b->mesh_id.Ssid, a->mesh_id.SsidLength) == _FALSE)
goto exit;
if (_rtw_memcmp(a_mconf_ie + 2, b_mconf_ie + 2, 5) == _FALSE)
goto exit;
ret = 1;
exit:
return ret;
}
int rtw_bss_is_candidate_mesh_peer(WLAN_BSSID_EX *self, WLAN_BSSID_EX *target, u8 ch, u8 add_peer)
{
int ret = 0;
u8 *mconf_ie;
sint mconf_ie_len;
int i, j;
if (!rtw_bss_is_same_mbss(self, target))
goto exit;
if (ch && self->Configuration.DSConfig != target->Configuration.DSConfig)
goto exit;
if (add_peer) {
/* Accept additional mesh peerings */
mconf_ie = rtw_get_ie(BSS_EX_TLV_IES(target), WLAN_EID_MESH_CONFIG, &mconf_ie_len, BSS_EX_TLV_IES_LEN(target));
if (!mconf_ie || mconf_ie_len != 7)
goto exit;
if (GET_MESH_CONF_ELE_ACCEPT_PEERINGS(mconf_ie + 2) == 0)
goto exit;
}
/* BSSBasicRateSet */
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
if (target->SupportedRates[i] == 0)
break;
if (target->SupportedRates[i] & 0x80) {
u8 match = 0;
if (!ch) {
/* off-channel, check target with our hardcode capability */
if (target->Configuration.DSConfig > 14)
match = rtw_is_basic_rate_ofdm(target->SupportedRates[i]);
else
match = rtw_is_basic_rate_mix(target->SupportedRates[i]);
} else {
for (j = 0; j < NDIS_802_11_LENGTH_RATES_EX; j++) {
if (self->SupportedRates[j] == 0)
break;
if (self->SupportedRates[j] == target->SupportedRates[i]) {
match = 1;
break;
}
}
}
if (!match)
goto exit;
}
}
/* BSSBasicMCSSet */
/* 802.1X connected to AS ? */
ret = 1;
exit:
return ret;
}
void rtw_mesh_bss_peering_status(WLAN_BSSID_EX *bss, u8 *nop, u8 *accept)
{
u8 *ie;
int ie_len;
if (nop)
*nop = 0;
if (accept)
*accept = 0;
ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
BSS_EX_TLV_IES_LEN(bss));
if (!ie || ie_len != 7)
goto exit;
if (nop)
*nop = GET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2);
if (accept)
*accept = GET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2);
exit:
return;
}
#if CONFIG_RTW_MESH_ACNODE_PREVENT
void rtw_mesh_update_scanned_acnode_status(_adapter *adapter, struct wlan_network *scanned)
{
bool acnode;
u8 nop, accept;
rtw_mesh_bss_peering_status(&scanned->network, &nop, &accept);
acnode = !nop && accept;
if (acnode && scanned->acnode_stime == 0) {
scanned->acnode_stime = rtw_get_current_time();
if (scanned->acnode_stime == 0)
scanned->acnode_stime++;
} else if (!acnode) {
scanned->acnode_stime = 0;
scanned->acnode_notify_etime = 0;
}
}
bool rtw_mesh_scanned_is_acnode_confirmed(_adapter *adapter, struct wlan_network *scanned)
{
return scanned->acnode_stime
&& rtw_get_passing_time_ms(scanned->acnode_stime)
> adapter->mesh_cfg.peer_sel_policy.acnode_conf_timeout_ms;
}
static bool rtw_mesh_scanned_is_acnode_allow_notify(_adapter *adapter, struct wlan_network *scanned)
{
return scanned->acnode_notify_etime
&& rtw_time_after(scanned->acnode_notify_etime, rtw_get_current_time());
}
bool rtw_mesh_acnode_prevent_allow_sacrifice(_adapter *adapter)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct sta_priv *stapriv = &adapter->stapriv;
bool allow = 0;
if (!mcfg->peer_sel_policy.acnode_prevent
|| mcfg->max_peer_links <= 1
|| stapriv->asoc_list_cnt < mcfg->max_peer_links)
goto exit;
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
if (rtw_mesh_cto_mgate_required(adapter))
goto exit;
#endif
allow = 1;
exit:
return allow;
}
static bool rtw_mesh_acnode_candidate_exist(_adapter *adapter)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct sta_priv *stapriv = &adapter->stapriv;
struct mlme_priv *mlme = &adapter->mlmepriv;
_queue *queue = &(mlme->scanned_queue);
_list *head, *list;
_irqL irqL;
struct wlan_network *scanned = NULL;
struct sta_info *sta = NULL;
bool need = 0;
_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
head = get_list_head(queue);
list = get_next(head);
while (!rtw_end_of_queue_search(head, list)) {
scanned = LIST_CONTAINOR(list, struct wlan_network, list);
list = get_next(list);
if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
&& rtw_mesh_scanned_is_acnode_confirmed(adapter, scanned)
&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
#if CONFIG_RTW_MACADDR_ACL
&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
#endif
&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
#if CONFIG_RTW_MESH_PEER_BLACKLIST
&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
&& rtw_mesh_cto_mgate_network_filter(adapter, scanned)
#endif
) {
need = 1;
break;
}
}
_exit_critical_bh(&(mlme->scanned_queue.lock), &irqL);
return need;
}
static int rtw_mesh_acnode_prevent_sacrifice_chk(_adapter *adapter, struct sta_info **sac, struct sta_info *com)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
int updated = 0;
/*
* TODO: compare next_hop reference cnt of forwarding info
* don't sacrifice working next_hop or choose sta with least cnt
*/
if (*sac == NULL) {
updated = 1;
goto exit;
}
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
if (mcfg->peer_sel_policy.cto_mgate_require
&& !mcfg->dot11MeshGateAnnouncementProtocol
) {
if (IS_CTO_MGATE_CONF_TIMEOUT(com->plink)) {
if (!IS_CTO_MGATE_CONF_TIMEOUT((*sac)->plink)) {
/* blacklist > not blacklist */
updated = 1;
goto exit;
}
} else if (!IS_CTO_MGATE_CONF_DISABLED(com->plink)) {
if (IS_CTO_MGATE_CONF_DISABLED((*sac)->plink)) {
/* confirming > disabled */
updated = 1;
goto exit;
}
}
}
#endif
exit:
if (updated)
*sac = com;
return updated;
}
struct sta_info *_rtw_mesh_acnode_prevent_pick_sacrifice(_adapter *adapter)
{
struct sta_priv *stapriv = &adapter->stapriv;
_list *head, *list;
struct sta_info *sta, *sacrifice = NULL;
u8 nop;
head = &stapriv->asoc_list;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
list = get_next(list);
if (!sta->plink || !sta->plink->scanned) {
rtw_warn_on(1);
continue;
}
rtw_mesh_bss_peering_status(&sta->plink->scanned->network, &nop, NULL);
if (nop < 2)
continue;
rtw_mesh_acnode_prevent_sacrifice_chk(adapter, &sacrifice, sta);
}
return sacrifice;
}
struct sta_info *rtw_mesh_acnode_prevent_pick_sacrifice(_adapter *adapter)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct sta_info *sacrifice = NULL;
enter_critical_bh(&stapriv->asoc_list_lock);
sacrifice = _rtw_mesh_acnode_prevent_pick_sacrifice(adapter);
exit_critical_bh(&stapriv->asoc_list_lock);
return sacrifice;
}
static void rtw_mesh_acnode_rsvd_chk(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
u8 acnode_rsvd = 0;
if (rtw_mesh_acnode_prevent_allow_sacrifice(adapter)
&& rtw_mesh_acnode_prevent_pick_sacrifice(adapter)
&& rtw_mesh_acnode_candidate_exist(adapter))
acnode_rsvd = 1;
if (plink_ctl->acnode_rsvd != acnode_rsvd) {
plink_ctl->acnode_rsvd = acnode_rsvd;
RTW_INFO(FUNC_ADPT_FMT" acnode_rsvd = %d\n", FUNC_ADPT_ARG(adapter), plink_ctl->acnode_rsvd);
update_beacon(adapter, WLAN_EID_MESH_CONFIG, NULL, 1, 0);
}
}
static void rtw_mesh_acnode_set_notify_etime(_adapter *adapter, u8 *rframe_whdr)
{
if (adapter->mesh_info.plink_ctl.acnode_rsvd) {
struct wlan_network *scanned = rtw_find_network(&adapter->mlmepriv.scanned_queue, get_addr2_ptr(rframe_whdr));
if (rtw_mesh_scanned_is_acnode_confirmed(adapter, scanned)) {
scanned->acnode_notify_etime = rtw_get_current_time()
+ rtw_ms_to_systime(adapter->mesh_cfg.peer_sel_policy.acnode_notify_timeout_ms);
if (scanned->acnode_notify_etime == 0)
scanned->acnode_notify_etime++;
}
}
}
void dump_mesh_acnode_prevent_settings(void *sel, _adapter *adapter)
{
struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
RTW_PRINT_SEL(sel, "%-6s %-12s %-14s\n"
, "enable", "conf_timeout", "nofity_timeout");
RTW_PRINT_SEL(sel, "%6u %12u %14u\n"
, peer_sel_policy->acnode_prevent
, peer_sel_policy->acnode_conf_timeout_ms
, peer_sel_policy->acnode_notify_timeout_ms);
}
#endif /* CONFIG_RTW_MESH_ACNODE_PREVENT */
#if CONFIG_RTW_MESH_PEER_BLACKLIST
int rtw_mesh_peer_blacklist_add(_adapter *adapter, const u8 *addr)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
return rtw_blacklist_add(&plink_ctl->peer_blacklist, addr
, mcfg->peer_sel_policy.peer_blacklist_timeout_ms);
}
int rtw_mesh_peer_blacklist_del(_adapter *adapter, const u8 *addr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
return rtw_blacklist_del(&plink_ctl->peer_blacklist, addr);
}
int rtw_mesh_peer_blacklist_search(_adapter *adapter, const u8 *addr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
return rtw_blacklist_search(&plink_ctl->peer_blacklist, addr);
}
void rtw_mesh_peer_blacklist_flush(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
rtw_blacklist_flush(&plink_ctl->peer_blacklist);
}
void dump_mesh_peer_blacklist(void *sel, _adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
dump_blacklist(sel, &plink_ctl->peer_blacklist, "blacklist");
}
void dump_mesh_peer_blacklist_settings(void *sel, _adapter *adapter)
{
struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
RTW_PRINT_SEL(sel, "%-12s %-17s\n"
, "conf_timeout", "blacklist_timeout");
RTW_PRINT_SEL(sel, "%12u %17u\n"
, peer_sel_policy->peer_conf_timeout_ms
, peer_sel_policy->peer_blacklist_timeout_ms);
}
#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
u8 rtw_mesh_cto_mgate_required(_adapter *adapter)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
return mcfg->peer_sel_policy.cto_mgate_require
&& !rtw_bss_is_cto_mgate(&(mlmeext->mlmext_info.network));
}
u8 rtw_mesh_cto_mgate_network_filter(_adapter *adapter, struct wlan_network *scanned)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
return !rtw_mesh_cto_mgate_required(adapter)
|| (rtw_bss_is_cto_mgate(&scanned->network)
&& !rtw_mesh_cto_mgate_blacklist_search(adapter, scanned->network.MacAddress));
}
int rtw_mesh_cto_mgate_blacklist_add(_adapter *adapter, const u8 *addr)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
return rtw_blacklist_add(&plink_ctl->cto_mgate_blacklist, addr
, mcfg->peer_sel_policy.cto_mgate_blacklist_timeout_ms);
}
int rtw_mesh_cto_mgate_blacklist_del(_adapter *adapter, const u8 *addr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
return rtw_blacklist_del(&plink_ctl->cto_mgate_blacklist, addr);
}
int rtw_mesh_cto_mgate_blacklist_search(_adapter *adapter, const u8 *addr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
return rtw_blacklist_search(&plink_ctl->cto_mgate_blacklist, addr);
}
void rtw_mesh_cto_mgate_blacklist_flush(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
rtw_blacklist_flush(&plink_ctl->cto_mgate_blacklist);
}
void dump_mesh_cto_mgate_blacklist(void *sel, _adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
dump_blacklist(sel, &plink_ctl->cto_mgate_blacklist, "blacklist");
}
void dump_mesh_cto_mgate_blacklist_settings(void *sel, _adapter *adapter)
{
struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
RTW_PRINT_SEL(sel, "%-12s %-17s\n"
, "conf_timeout", "blacklist_timeout");
RTW_PRINT_SEL(sel, "%12u %17u\n"
, peer_sel_policy->cto_mgate_conf_timeout_ms
, peer_sel_policy->cto_mgate_blacklist_timeout_ms);
}
static void rtw_mesh_cto_mgate_blacklist_chk(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
_queue *blist = &plink_ctl->cto_mgate_blacklist;
_list *list, *head;
struct blacklist_ent *ent = NULL;
struct wlan_network *scanned = NULL;
enter_critical_bh(&blist->lock);
head = &blist->queue;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
ent = LIST_CONTAINOR(list, struct blacklist_ent, list);
list = get_next(list);
if (rtw_time_after(rtw_get_current_time(), ent->exp_time)) {
rtw_list_delete(&ent->list);
rtw_mfree(ent, sizeof(struct blacklist_ent));
continue;
}
scanned = rtw_find_network(&adapter->mlmepriv.scanned_queue, ent->addr);
if (!scanned)
continue;
if (rtw_bss_is_forwarding(&scanned->network)) {
rtw_list_delete(&ent->list);
rtw_mfree(ent, sizeof(struct blacklist_ent));
}
}
exit_critical_bh(&blist->lock);
}
#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
void rtw_chk_candidate_peer_notify(_adapter *adapter, struct wlan_network *scanned)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct mlme_priv *mlme = &adapter->mlmepriv;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
bool acnode = 0;
if (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl))
goto exit;
if (plink_ctl->num >= RTW_MESH_MAX_PEER_CANDIDATES)
goto exit;
#if CONFIG_RTW_MESH_ACNODE_PREVENT
if (plink_ctl->acnode_rsvd) {
acnode = rtw_mesh_scanned_is_acnode_confirmed(adapter, scanned);
if (acnode && !rtw_mesh_scanned_is_acnode_allow_notify(adapter, scanned))
goto exit;
}
#endif
/* wpa_supplicant's auto peer will initiate peering when candidate peer is reported without max_peer_links consideration */
if (plink_ctl->num >= mcfg->max_peer_links + acnode ? 1 : 0)
goto exit;
if (rtw_get_passing_time_ms(scanned->last_scanned) >= mcfg->peer_sel_policy.scanr_exp_ms
|| (mcfg->rssi_threshold && mcfg->rssi_threshold > scanned->network.Rssi)
|| !rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
#if CONFIG_RTW_MACADDR_ACL
|| rtw_access_ctrl(adapter, scanned->network.MacAddress) == _FALSE
#endif
|| rtw_mesh_plink_get(adapter, scanned->network.MacAddress)
#if CONFIG_RTW_MESH_PEER_BLACKLIST
|| rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
|| !rtw_mesh_cto_mgate_network_filter(adapter, scanned)
#endif
)
goto exit;
#if CONFIG_RTW_MESH_ACNODE_PREVENT
if (acnode) {
scanned->acnode_notify_etime = 0;
RTW_INFO(FUNC_ADPT_FMT" acnode "MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(scanned->network.MacAddress));
}
#endif
#ifdef CONFIG_IOCTL_CFG80211
rtw_cfg80211_notify_new_peer_candidate(adapter->rtw_wdev
, scanned->network.MacAddress
, BSS_EX_TLV_IES(&scanned->network)
, BSS_EX_TLV_IES_LEN(&scanned->network)
, scanned->network.Rssi
, GFP_ATOMIC
);
#endif
exit:
return;
}
void rtw_mesh_peer_status_chk(_adapter *adapter)
{
struct mlme_priv *mlme = &adapter->mlmepriv;
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *plink;
_list *head, *list;
struct sta_info *sta = NULL;
struct sta_priv *stapriv = &adapter->stapriv;
int stainfo_offset;
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
u8 cto_mgate, forwarding, mgate;
#endif
u8 flush;
s8 flush_list[NUM_STA];
u8 flush_num = 0;
int i;
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
if (rtw_mesh_cto_mgate_required(adapter)) {
/* active scan on operating channel */
issue_probereq_ex(adapter, &adapter->mlmepriv.cur_network.network.mesh_id, NULL, 0, 0, 0, 0);
}
#endif
enter_critical_bh(&(plink_ctl->lock));
/* check established peers */
enter_critical_bh(&stapriv->asoc_list_lock);
head = &stapriv->asoc_list;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
list = get_next(list);
if (!sta->plink || !sta->plink->scanned) {
rtw_warn_on(1);
continue;
}
plink = sta->plink;
flush = 0;
/* remove unsuitable peer */
if (!rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &plink->scanned->network, 1, 0)
#if CONFIG_RTW_MACADDR_ACL
|| rtw_access_ctrl(adapter, plink->addr) == _FALSE
#endif
) {
flush = 1;
goto flush_add;
}
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
cto_mgate = rtw_bss_is_cto_mgate(&(plink->scanned->network));
forwarding = rtw_bss_is_forwarding(&(plink->scanned->network));
mgate = rtw_mesh_gate_search(minfo->mesh_paths, sta->cmn.mac_addr);
/* CTO_MGATE required, remove peer without CTO_MGATE */
if (rtw_mesh_cto_mgate_required(adapter) && !cto_mgate) {
flush = 1;
goto flush_add;
}
/* cto_mgate_conf status update */
if (IS_CTO_MGATE_CONF_DISABLED(plink)) {
if (cto_mgate && !forwarding && !mgate)
SET_CTO_MGATE_CONF_END_TIME(plink, mcfg->peer_sel_policy.cto_mgate_conf_timeout_ms);
else
rtw_mesh_cto_mgate_blacklist_del(adapter, sta->cmn.mac_addr);
} else {
/* cto_mgate_conf ongoing */
if (cto_mgate && !forwarding && !mgate) {
if (IS_CTO_MGATE_CONF_TIMEOUT(plink)) {
rtw_mesh_cto_mgate_blacklist_add(adapter, sta->cmn.mac_addr);
/* CTO_MGATE required, remove peering can't achieve CTO_MGATE */
if (rtw_mesh_cto_mgate_required(adapter)) {
flush = 1;
goto flush_add;
}
}
} else {
SET_CTO_MGATE_CONF_DISABLED(plink);
rtw_mesh_cto_mgate_blacklist_del(adapter, sta->cmn.mac_addr);
}
}
#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
flush_add:
if (flush) {
rtw_list_delete(&sta->asoc_list);
stapriv->asoc_list_cnt--;
STA_SET_MESH_PLINK(sta, NULL);
stainfo_offset = rtw_stainfo_offset(stapriv, sta);
if (stainfo_offset_valid(stainfo_offset))
flush_list[flush_num++] = stainfo_offset;
else
rtw_warn_on(1);
}
}
exit_critical_bh(&stapriv->asoc_list_lock);
/* check non-established peers */
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
plink = &plink_ctl->ent[i];
if (plink->valid != _TRUE || plink->plink_state == RTW_MESH_PLINK_ESTAB)
continue;
/* remove unsuitable peer */
if (!rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &plink->scanned->network, 1, 1)
#if CONFIG_RTW_MACADDR_ACL
|| rtw_access_ctrl(adapter, plink->addr) == _FALSE
#endif
) {
_rtw_mesh_expire_peer_ent(adapter, plink);
continue;
}
#if CONFIG_RTW_MESH_PEER_BLACKLIST
/* peer confirm check timeout, add to black list */
if (IS_PEER_CONF_TIMEOUT(plink)) {
rtw_mesh_peer_blacklist_add(adapter, plink->addr);
_rtw_mesh_expire_peer_ent(adapter, plink);
}
#endif
}
exit_critical_bh(&(plink_ctl->lock));
if (flush_num) {
u8 sta_addr[ETH_ALEN];
u8 updated = _FALSE;
for (i = 0; i < flush_num; i++) {
sta = rtw_get_stainfo_by_offset(stapriv, flush_list[i]);
_rtw_memcpy(sta_addr, sta->cmn.mac_addr, ETH_ALEN);
updated |= ap_free_sta(adapter, sta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, _FALSE);
rtw_mesh_expire_peer(adapter, sta_addr);
}
associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
}
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
/* loop cto_mgate_blacklist to remove ent according to scan_r */
rtw_mesh_cto_mgate_blacklist_chk(adapter);
#endif
#if CONFIG_RTW_MESH_ACNODE_PREVENT
rtw_mesh_acnode_rsvd_chk(adapter);
#endif
return;
}
#if CONFIG_RTW_MESH_OFFCH_CAND
static u8 rtw_mesh_offch_cto_mgate_required(_adapter *adapter)
{
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct mlme_priv *mlme = &adapter->mlmepriv;
_queue *queue = &(mlme->scanned_queue);
_list *head, *pos;
struct wlan_network *scanned = NULL;
u8 ret = 0;
if (!rtw_mesh_cto_mgate_required(adapter))
goto exit;
enter_critical_bh(&(mlme->scanned_queue.lock));
head = get_list_head(queue);
pos = get_next(head);
while (!rtw_end_of_queue_search(head, pos)) {
scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
#if CONFIG_RTW_MACADDR_ACL
&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
#endif
&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 1, 1)
&& rtw_bss_is_cto_mgate(&scanned->network)
#if CONFIG_RTW_MESH_PEER_BLACKLIST
&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
#endif
&& !rtw_mesh_cto_mgate_blacklist_search(adapter, scanned->network.MacAddress)
)
break;
pos = get_next(pos);
}
if (rtw_end_of_queue_search(head, pos))
ret = 1;
exit_critical_bh(&(mlme->scanned_queue.lock));
exit:
return ret;
#else
return 0;
#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
}
u8 rtw_mesh_offch_candidate_accepted(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
u8 ret = 0;
if (!adapter->mesh_cfg.peer_sel_policy.offch_cand)
goto exit;
ret = MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)
&& (!plink_ctl->num || rtw_mesh_offch_cto_mgate_required(adapter))
;
#ifdef CONFIG_CONCURRENT_MODE
if (ret) {
struct mi_state mstate_no_self;
rtw_mi_status_no_self(adapter, &mstate_no_self);
if (MSTATE_STA_LD_NUM(&mstate_no_self))
ret = 0;
}
#endif
exit:
return ret;
}
/*
* this function is called under off channel candidate is required
* the channel with maximum candidate count is selected
*/
u8 rtw_mesh_select_operating_ch(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct mlme_priv *mlme = &adapter->mlmepriv;
_queue *queue = &(mlme->scanned_queue);
_list *head, *pos;
_irqL irqL;
struct wlan_network *scanned = NULL;
int i;
/* statistics for candidate accept peering */
u8 cand_ap_cnt[MAX_CHANNEL_NUM] = {0};
u8 max_cand_ap_ch = 0;
u8 max_cand_ap_cnt = 0;
/* statistics for candidate including not accept peering */
u8 cand_cnt[MAX_CHANNEL_NUM] = {0};
u8 max_cand_ch = 0;
u8 max_cand_cnt = 0;
_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
head = get_list_head(queue);
pos = get_next(head);
while (!rtw_end_of_queue_search(head, pos)) {
scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
pos = get_next(pos);
if (rtw_get_passing_time_ms(scanned->last_scanned) < mcfg->peer_sel_policy.scanr_exp_ms
&& (!mcfg->rssi_threshold || mcfg->rssi_threshold <= scanned->network.Rssi)
#if CONFIG_RTW_MACADDR_ACL
&& rtw_access_ctrl(adapter, scanned->network.MacAddress) == _TRUE
#endif
&& rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &scanned->network, 0, 0)
#if CONFIG_RTW_MESH_PEER_BLACKLIST
&& !rtw_mesh_peer_blacklist_search(adapter, scanned->network.MacAddress)
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
&& rtw_mesh_cto_mgate_network_filter(adapter, scanned)
#endif
) {
int ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, scanned->network.Configuration.DSConfig);
if (ch_set_idx >= 0
&& !CH_IS_NON_OCP(&rfctl->channel_set[ch_set_idx])
) {
u8 nop, accept;
rtw_mesh_bss_peering_status(&scanned->network, &nop, &accept);
cand_cnt[ch_set_idx]++;
if (max_cand_cnt < cand_cnt[ch_set_idx]) {
max_cand_cnt = cand_cnt[ch_set_idx];
max_cand_ch = rfctl->channel_set[ch_set_idx].ChannelNum;
}
if (accept) {
cand_ap_cnt[ch_set_idx]++;
if (max_cand_ap_cnt < cand_ap_cnt[ch_set_idx]) {
max_cand_ap_cnt = cand_ap_cnt[ch_set_idx];
max_cand_ap_ch = rfctl->channel_set[ch_set_idx].ChannelNum;
}
}
}
}
}
_exit_critical_bh(&(mlme->scanned_queue.lock), &irqL);
return max_cand_ap_ch ? max_cand_ap_ch : max_cand_ch;
}
void dump_mesh_offch_cand_settings(void *sel, _adapter *adapter)
{
struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
RTW_PRINT_SEL(sel, "%-6s %-11s\n"
, "enable", "find_int_ms");
RTW_PRINT_SEL(sel, "%6u %11u\n"
, peer_sel_policy->offch_cand, peer_sel_policy->offch_find_int_ms);
}
#endif /* CONFIG_RTW_MESH_OFFCH_CAND */
void dump_mesh_peer_sel_policy(void *sel, _adapter *adapter)
{
struct mesh_peer_sel_policy *peer_sel_policy = &adapter->mesh_cfg.peer_sel_policy;
RTW_PRINT_SEL(sel, "%-12s\n", "scanr_exp_ms");
RTW_PRINT_SEL(sel, "%12u\n", peer_sel_policy->scanr_exp_ms);
}
void dump_mesh_networks(void *sel, _adapter *adapter)
{
#if CONFIG_RTW_MESH_ACNODE_PREVENT
#define NSTATE_TITLE_FMT_ACN " %-5s"
#define NSTATE_VALUE_FMT_ACN " %5d"
#define NSTATE_TITLE_ARG_ACN , "acn"
#define NSTATE_VALUE_ARG_ACN , (acn_ms < 99999 ? acn_ms : 99999)
#else
#define NSTATE_TITLE_FMT_ACN ""
#define NSTATE_VALUE_FMT_ACN ""
#define NSTATE_TITLE_ARG_ACN
#define NSTATE_VALUE_ARG_ACN
#endif
struct mlme_priv *mlme = &(adapter->mlmepriv);
_queue *queue = &(mlme->scanned_queue);
struct wlan_network *network;
_list *list, *head;
u8 same_mbss;
u8 candidate;
struct mesh_plink_ent *plink;
u8 blocked;
u8 established;
s32 age_ms;
#if CONFIG_RTW_MESH_ACNODE_PREVENT
s32 acn_ms;
#endif
u8 *mesh_conf_ie;
sint mesh_conf_ie_len;
struct wlan_network **mesh_networks;
u8 mesh_network_cnt = 0;
int i;
mesh_networks = rtw_zvmalloc(mlme->max_bss_cnt * sizeof(struct wlan_network *));
if (!mesh_networks)
return;
enter_critical_bh(&queue->lock);
head = get_list_head(queue);
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
network = LIST_CONTAINOR(list, struct wlan_network, list);
list = get_next(list);
if (network->network.InfrastructureMode != Ndis802_11_mesh)
continue;
mesh_conf_ie = rtw_get_ie(BSS_EX_TLV_IES(&network->network), WLAN_EID_MESH_CONFIG
, &mesh_conf_ie_len, BSS_EX_TLV_IES_LEN(&network->network));
if (!mesh_conf_ie || mesh_conf_ie_len != 7)
continue;
mesh_networks[mesh_network_cnt++] = network;
}
exit_critical_bh(&queue->lock);
RTW_PRINT_SEL(sel, " %-17s %-3s %-4s %-5s %-32s %-3s %-3s %-3s"
NSTATE_TITLE_FMT_ACN
"\n"
, "bssid", "ch", "rssi", "age", "mesh_id", "nop", "fwd", "cto"
NSTATE_TITLE_ARG_ACN
);
for (i = 0; i < mesh_network_cnt; i++) {
network = mesh_networks[i];
if (network->network.InfrastructureMode != Ndis802_11_mesh)
continue;
mesh_conf_ie = rtw_get_ie(BSS_EX_TLV_IES(&network->network), WLAN_EID_MESH_CONFIG
, &mesh_conf_ie_len, BSS_EX_TLV_IES_LEN(&network->network));
if (!mesh_conf_ie || mesh_conf_ie_len != 7)
continue;
age_ms = rtw_get_passing_time_ms(network->last_scanned);
#if CONFIG_RTW_MESH_ACNODE_PREVENT
if (network->acnode_stime == 0)
acn_ms = 0;
else
acn_ms = rtw_get_passing_time_ms(network->acnode_stime);
#endif
same_mbss = 0;
candidate = 0;
plink = NULL;
blocked = 0;
established = 0;
if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)) {
plink = rtw_mesh_plink_get(adapter, network->network.MacAddress);
if (plink && plink->plink_state == RTW_MESH_PLINK_ESTAB)
established = 1;
else if (plink && plink->plink_state == RTW_MESH_PLINK_BLOCKED)
blocked = 1;
else if (plink)
;
else if (rtw_bss_is_candidate_mesh_peer(&mlme->cur_network.network, &network->network, 0, 1))
candidate = 1;
else if (rtw_bss_is_same_mbss(&mlme->cur_network.network, &network->network))
same_mbss = 1;
}
RTW_PRINT_SEL(sel, "%c "MAC_FMT" %3d %4ld %5d %-32s %c%2u %3u %c%c "
NSTATE_VALUE_FMT_ACN
"\n"
, established ? 'E' : (blocked ? 'B' : (plink ? 'N' : (candidate ? 'C' : (same_mbss ? 'S' : ' '))))
, MAC_ARG(network->network.MacAddress)
, network->network.Configuration.DSConfig
, network->network.Rssi
, age_ms < 99999 ? age_ms : 99999
, network->network.mesh_id.Ssid
, GET_MESH_CONF_ELE_ACCEPT_PEERINGS(mesh_conf_ie + 2) ? '+' : ' '
, GET_MESH_CONF_ELE_NUM_OF_PEERINGS(mesh_conf_ie + 2)
, GET_MESH_CONF_ELE_FORWARDING(mesh_conf_ie + 2)
, GET_MESH_CONF_ELE_CTO_MGATE(mesh_conf_ie + 2) ? 'G' : ' '
, GET_MESH_CONF_ELE_CTO_AS(mesh_conf_ie + 2) ? 'A' : ' '
NSTATE_VALUE_ARG_ACN
);
}
rtw_vmfree(mesh_networks, mlme->max_bss_cnt * sizeof(struct wlan_network *));
}
void rtw_mesh_adjust_chbw(u8 req_ch, u8 *req_bw, u8 *req_offset)
{
if (req_ch >= 5 && req_ch <= 9) {
/* prevent secondary channel offset mismatch */
if (*req_bw > CHANNEL_WIDTH_20) {
*req_bw = CHANNEL_WIDTH_20;
*req_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
}
}
void rtw_mesh_sae_check_frames(_adapter *adapter, const u8 *buf, u32 len, u8 tx, u16 alg, u16 seq, u16 status)
{
#if CONFIG_RTW_MESH_PEER_BLACKLIST
if (tx && seq == 1)
rtw_mesh_plink_set_peer_conf_timeout(adapter, GetAddr1Ptr(buf));
#endif
}
#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
#ifdef CONFIG_RTW_MESH_AEK
static int rtw_mpm_ampe_dec(_adapter *adapter, struct mesh_plink_ent *plink
, u8 *fhead, size_t flen, u8* fbody, u8 *mic_ie, u8 *ampe_buf)
{
int ret = _FAIL, verify_ret;
const u8 *aad[] = {adapter_mac_addr(adapter), plink->addr, fbody};
const size_t aad_len[] = {ETH_ALEN, ETH_ALEN, mic_ie - fbody};
u8 *iv_crypt;
size_t iv_crypt_len = flen - (mic_ie + 2 - fhead);
iv_crypt = rtw_malloc(iv_crypt_len);
if (!iv_crypt)
goto exit;
_rtw_memcpy(iv_crypt, mic_ie + 2, iv_crypt_len);
verify_ret = aes_siv_decrypt(plink->aek, iv_crypt, iv_crypt_len
, 3, aad, aad_len, ampe_buf);
rtw_mfree(iv_crypt, iv_crypt_len);
if (verify_ret) {
RTW_WARN("verify error, aek_valid=%u\n", plink->aek_valid);
goto exit;
} else if (*ampe_buf != WLAN_EID_AMPE) {
RTW_WARN("plaintext is not AMPE IE\n");
goto exit;
} else if (AES_BLOCK_SIZE + 2 + *(ampe_buf + 1) > iv_crypt_len) {
RTW_WARN("plaintext AMPE IE length is not valid\n");
goto exit;
}
ret = _SUCCESS;
exit:
return ret;
}
static int rtw_mpm_ampe_enc(_adapter *adapter, struct mesh_plink_ent *plink
, u8* fbody, u8 *mic_ie, u8 *ampe_buf, bool inverse)
{
int ret = _FAIL, protect_ret;
const u8 *aad[3];
const size_t aad_len[3] = {ETH_ALEN, ETH_ALEN, mic_ie - fbody};
u8 *ampe_ie;
size_t ampe_ie_len = *(ampe_buf + 1) + 2; /* including id & len */
if (inverse) {
aad[0] = plink->addr;
aad[1] = adapter_mac_addr(adapter);
} else {
aad[0] = adapter_mac_addr(adapter);
aad[1] = plink->addr;
}
aad[2] = fbody;
ampe_ie = rtw_malloc(ampe_ie_len);
if (!ampe_ie)
goto exit;
_rtw_memcpy(ampe_ie, ampe_buf, ampe_ie_len);
protect_ret = aes_siv_encrypt(plink->aek, ampe_ie, ampe_ie_len
, 3, aad, aad_len, mic_ie + 2);
rtw_mfree(ampe_ie, ampe_ie_len);
if (protect_ret) {
RTW_WARN("protect error, aek_valid=%u\n", plink->aek_valid);
goto exit;
}
ret = _SUCCESS;
exit:
return ret;
}
#endif /* CONFIG_RTW_MESH_AEK */
static int rtw_mpm_tx_ies_sync_bss(_adapter *adapter, struct mesh_plink_ent *plink
, u8 *fhead, size_t flen, u8* fbody, u8 tlv_ies_offset, u8 *mpm_ie, u8 *mic_ie
, u8 **nbuf, size_t *nlen)
{
int ret = _FAIL;
struct mlme_priv *mlme = &(adapter->mlmepriv);
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
WLAN_BSSID_EX *network = &(mlmeinfo->network);
uint left;
u8 *pos;
uint mpm_ielen = *(mpm_ie + 1);
u8 *fpos;
u8 *new_buf = NULL;
size_t new_len = 0;
u8 *new_fhead;
size_t new_flen;
u8 *new_fbody;
u8 *new_mic_ie;
#ifdef CONFIG_RTW_MESH_AEK
u8 *ampe_buf = NULL;
size_t ampe_buf_len = 0;
/* decode */
if (mic_ie) {
ampe_buf_len = flen - (mic_ie + 2 + AES_BLOCK_SIZE - fhead);
ampe_buf = rtw_malloc(ampe_buf_len);
if (!ampe_buf)
goto exit;
if (rtw_mpm_ampe_dec(adapter, plink, fhead, flen, fbody, mic_ie, ampe_buf) != _SUCCESS)
goto exit;
if (*(ampe_buf + 1) >= 68) {
_rtw_memcpy(plink->sel_pcs, ampe_buf + 2, 4);
_rtw_memcpy(plink->l_nonce, ampe_buf + 6, 32);
_rtw_memcpy(plink->p_nonce, ampe_buf + 38, 32);
}
}
#endif
/* count for new frame length */
new_len = sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset;
left = BSS_EX_TLV_IES_LEN(network);
pos = BSS_EX_TLV_IES(network);
while (left >= 2) {
u8 id, elen;
id = *pos++;
elen = *pos++;
left -= 2;
if (elen > left)
break;
switch (id) {
case WLAN_EID_SSID:
case WLAN_EID_DS_PARAMS:
case WLAN_EID_TIM:
break;
default:
new_len += 2 + elen;
}
left -= elen;
pos += elen;
}
new_len += mpm_ielen + 2;
if (mic_ie)
new_len += AES_BLOCK_SIZE + 2 + ampe_buf_len;
/* alloc new frame */
new_buf = rtw_malloc(new_len);
if (!new_buf) {
rtw_warn_on(1);
goto exit;
}
/* build new frame */
_rtw_memcpy(new_buf, fhead, sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset);
new_fhead = new_buf;
new_flen = new_len;
new_fbody = new_fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
fpos = new_fbody + tlv_ies_offset;
left = BSS_EX_TLV_IES_LEN(network);
pos = BSS_EX_TLV_IES(network);
while (left >= 2) {
u8 id, elen;
id = *pos++;
elen = *pos++;
left -= 2;
if (elen > left)
break;
switch (id) {
case WLAN_EID_SSID:
case WLAN_EID_DS_PARAMS:
case WLAN_EID_TIM:
break;
default:
fpos = rtw_set_ie(fpos, id, elen, pos, NULL);
if (id == WLAN_EID_MESH_CONFIG)
fpos = rtw_set_ie(fpos, WLAN_EID_MPM, mpm_ielen, mpm_ie + 2, NULL);
}
left -= elen;
pos += elen;
}
if (mic_ie) {
new_mic_ie = fpos;
*fpos++ = WLAN_EID_MIC;
*fpos++ = AES_BLOCK_SIZE;
}
#ifdef CONFIG_RTW_MESH_AEK
/* encode */
if (mic_ie) {
int enc_ret = rtw_mpm_ampe_enc(adapter, plink, new_fbody, new_mic_ie, ampe_buf, 0);
if (enc_ret != _SUCCESS)
goto exit;
}
#endif
*nlen = new_len;
*nbuf = new_buf;
ret = _SUCCESS;
exit:
if (ret != _SUCCESS && new_buf)
rtw_mfree(new_buf, new_len);
#ifdef CONFIG_RTW_MESH_AEK
if (ampe_buf)
rtw_mfree(ampe_buf, ampe_buf_len);
#endif
return ret;
}
#endif /* CONFIG_RTW_MPM_TX_IES_SYNC_BSS */
struct mpm_frame_info {
u8 *aid;
u16 aid_v;
u8 *pid;
u16 pid_v;
u8 *llid;
u16 llid_v;
u8 *plid;
u16 plid_v;
u8 *reason;
u16 reason_v;
u8 *chosen_pmk;
};
/*
* pid:00000 llid:00000 chosen_pmk:0x00000000000000000000000000000000
* aid:00000 pid:00000 llid:00000 plid:00000 chosen_pmk:0x00000000000000000000000000000000
* pid:00000 llid:00000 plid:00000 reason:00000 chosen_pmk:0x00000000000000000000000000000000
*/
#define MPM_LOG_BUF_LEN 92 /* this length is limited for legal combination */
static void rtw_mpm_info_msg(struct mpm_frame_info *mpm_info, u8 *mpm_log_buf)
{
int cnt = 0;
if (mpm_info->aid) {
cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "aid:%u ", mpm_info->aid_v);
if (cnt >= MPM_LOG_BUF_LEN - 1)
goto exit;
}
if (mpm_info->pid) {
cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "pid:%u ", mpm_info->pid_v);
if (cnt >= MPM_LOG_BUF_LEN - 1)
goto exit;
}
if (mpm_info->llid) {
cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "llid:%u ", mpm_info->llid_v);
if (cnt >= MPM_LOG_BUF_LEN - 1)
goto exit;
}
if (mpm_info->plid) {
cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "plid:%u ", mpm_info->plid_v);
if (cnt >= MPM_LOG_BUF_LEN - 1)
goto exit;
}
if (mpm_info->reason) {
cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "reason:%u ", mpm_info->reason_v);
if (cnt >= MPM_LOG_BUF_LEN - 1)
goto exit;
}
if (mpm_info->chosen_pmk) {
cnt += snprintf(mpm_log_buf + cnt, MPM_LOG_BUF_LEN - cnt - 1, "chosen_pmk:0x"KEY_FMT, KEY_ARG(mpm_info->chosen_pmk));
if (cnt >= MPM_LOG_BUF_LEN - 1)
goto exit;
}
exit:
return;
}
static int rtw_mpm_check_frames(_adapter *adapter, u8 action, const u8 **buf, size_t *len, u8 tx)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *plink = NULL;
u8 *nbuf = NULL;
size_t nlen = 0;
u8 *fhead = (u8 *)*buf;
size_t flen = *len;
u8 *peer_addr = tx ? GetAddr1Ptr(fhead) : get_addr2_ptr(fhead);
u8 *frame_body = fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
struct mpm_frame_info mpm_info;
u8 tlv_ies_offset;
u8 *mpm_ie = NULL;
uint mpm_ielen = 0;
u8 *mic_ie = NULL;
uint mic_ielen = 0;
int ret = 0;
u8 mpm_log_buf[MPM_LOG_BUF_LEN] = {0};
if (action == RTW_ACT_SELF_PROTECTED_MESH_OPEN)
tlv_ies_offset = 4;
else if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF)
tlv_ies_offset = 6;
else if (action == RTW_ACT_SELF_PROTECTED_MESH_CLOSE)
tlv_ies_offset = 2;
else {
rtw_warn_on(1);
goto exit;
}
plink = rtw_mesh_plink_get(adapter, peer_addr);
if (!plink && (tx == _TRUE || action == RTW_ACT_SELF_PROTECTED_MESH_CONF)) {
/* warning message if no plink when: 1.TX all MPM or 2.RX CONF */
RTW_WARN("RTW_%s:%s without plink of "MAC_FMT"\n"
, (tx == _TRUE) ? "Tx" : "Rx", action_self_protected_str(action), MAC_ARG(peer_addr));
goto exit;
}
_rtw_memset(&mpm_info, 0, sizeof(struct mpm_frame_info));
if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF) {
mpm_info.aid = (u8 *)frame_body + 4;
mpm_info.aid_v = RTW_GET_LE16(mpm_info.aid);
}
mpm_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
, WLAN_EID_MPM, &mpm_ielen
, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
if (!mpm_ie || mpm_ielen < 2 + 2)
goto exit;
mpm_info.pid = mpm_ie + 2;
mpm_info.pid_v = RTW_GET_LE16(mpm_info.pid);
mpm_info.llid = mpm_info.pid + 2;
mpm_info.llid_v = RTW_GET_LE16(mpm_info.llid);
switch (action) {
case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
/* pid:2, llid:2, (chosen_pmk:16) */
if (mpm_info.pid_v == 0 && mpm_ielen == 4)
;
else if (mpm_info.pid_v == 1 && mpm_ielen == 20)
mpm_info.chosen_pmk = mpm_info.llid + 2;
else
goto exit;
break;
case RTW_ACT_SELF_PROTECTED_MESH_CONF:
/* pid:2, llid:2, plid:2, (chosen_pmk:16) */
mpm_info.plid = mpm_info.llid + 2;
mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
if (mpm_info.pid_v == 0 && mpm_ielen == 6)
;
else if (mpm_info.pid_v == 1 && mpm_ielen == 22)
mpm_info.chosen_pmk = mpm_info.plid + 2;
else
goto exit;
break;
case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
/* pid:2, llid:2, (plid:2), reason:2, (chosen_pmk:16) */
if (mpm_info.pid_v == 0 && mpm_ielen == 6) {
/* MPM, without plid */
mpm_info.reason = mpm_info.llid + 2;
mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
} else if (mpm_info.pid_v == 0 && mpm_ielen == 8) {
/* MPM, with plid */
mpm_info.plid = mpm_info.llid + 2;
mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
mpm_info.reason = mpm_info.plid + 2;
mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
} else if (mpm_info.pid_v == 1 && mpm_ielen == 22) {
/* AMPE, without plid */
mpm_info.reason = mpm_info.llid + 2;
mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
mpm_info.chosen_pmk = mpm_info.reason + 2;
} else if (mpm_info.pid_v == 1 && mpm_ielen == 24) {
/* AMPE, with plid */
mpm_info.plid = mpm_info.llid + 2;
mpm_info.plid_v = RTW_GET_LE16(mpm_info.plid);
mpm_info.reason = mpm_info.plid + 2;
mpm_info.reason_v = RTW_GET_LE16(mpm_info.reason);
mpm_info.chosen_pmk = mpm_info.reason + 2;
} else
goto exit;
break;
};
if (mpm_info.pid_v == 1) {
mic_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
, WLAN_EID_MIC, &mic_ielen
, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
if (!mic_ie || mic_ielen != AES_BLOCK_SIZE)
goto exit;
}
#if CONFIG_RTW_MPM_TX_IES_SYNC_BSS
if ((action == RTW_ACT_SELF_PROTECTED_MESH_OPEN || action == RTW_ACT_SELF_PROTECTED_MESH_CONF)
&& tx == _TRUE
) {
#define DBG_RTW_MPM_TX_IES_SYNC_BSS 0
if (mpm_info.pid_v == 1 && (!plink || !MESH_PLINK_AEK_VALID(plink))) {
RTW_WARN("AEK not ready, IEs can't sync with BSS\n");
goto bypass_sync_bss;
}
if (DBG_RTW_MPM_TX_IES_SYNC_BSS) {
RTW_INFO(FUNC_ADPT_FMT" before:\n", FUNC_ADPT_ARG(adapter));
dump_ies(RTW_DBGDUMP
, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
}
rtw_mpm_tx_ies_sync_bss(adapter, plink
, fhead, flen, frame_body, tlv_ies_offset, mpm_ie, mic_ie
, &nbuf, &nlen);
if (!nbuf)
goto exit;
/* update pointer & len for new frame */
fhead = nbuf;
flen = nlen;
frame_body = fhead + sizeof(struct rtw_ieee80211_hdr_3addr);
if (mpm_info.pid_v == 1) {
mic_ie = rtw_get_ie(fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
, WLAN_EID_MIC, &mic_ielen
, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
}
if (DBG_RTW_MPM_TX_IES_SYNC_BSS) {
RTW_INFO(FUNC_ADPT_FMT" after:\n", FUNC_ADPT_ARG(adapter));
dump_ies(RTW_DBGDUMP
, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + tlv_ies_offset
, flen - sizeof(struct rtw_ieee80211_hdr_3addr) - tlv_ies_offset);
}
}
bypass_sync_bss:
#endif /* CONFIG_RTW_MPM_TX_IES_SYNC_BSS */
if (!plink)
goto mpm_log;
#if CONFIG_RTW_MESH_PEER_BLACKLIST
if (action == RTW_ACT_SELF_PROTECTED_MESH_OPEN) {
if (tx)
rtw_mesh_plink_set_peer_conf_timeout(adapter, peer_addr);
} else
#endif
#if CONFIG_RTW_MESH_ACNODE_PREVENT
if (action == RTW_ACT_SELF_PROTECTED_MESH_CLOSE) {
if (tx && mpm_info.reason && mpm_info.reason_v == WLAN_REASON_MESH_MAX_PEERS) {
if (rtw_mesh_scanned_is_acnode_confirmed(adapter, plink->scanned)
&& rtw_mesh_acnode_prevent_allow_sacrifice(adapter)
) {
struct sta_info *sac = rtw_mesh_acnode_prevent_pick_sacrifice(adapter);
if (sac) {
struct sta_priv *stapriv = &adapter->stapriv;
_irqL irqL;
u8 sta_addr[ETH_ALEN];
u8 updated = _FALSE;
_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
if (!rtw_is_list_empty(&sac->asoc_list)) {
rtw_list_delete(&sac->asoc_list);
stapriv->asoc_list_cnt--;
STA_SET_MESH_PLINK(sac, NULL);
}
_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
RTW_INFO(FUNC_ADPT_FMT" sacrifice "MAC_FMT" for acnode\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sac->cmn.mac_addr));
_rtw_memcpy(sta_addr, sac->cmn.mac_addr, ETH_ALEN);
updated = ap_free_sta(adapter, sac, 0, 0, 1);
rtw_mesh_expire_peer(stapriv->padapter, sta_addr);
associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
}
}
}
} else
#endif
if (action == RTW_ACT_SELF_PROTECTED_MESH_CONF) {
_irqL irqL;
u8 *ies = NULL;
u16 ies_len = 0;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
plink = _rtw_mesh_plink_get(adapter, peer_addr);
if (!plink)
goto release_plink_ctl;
if (tx == _FALSE) {
ies = plink->rx_conf_ies;
ies_len = plink->rx_conf_ies_len;
plink->rx_conf_ies = NULL;
plink->rx_conf_ies_len = 0;
plink->llid = mpm_info.plid_v;
plink->plid = mpm_info.llid_v;
plink->peer_aid = mpm_info.aid_v;
if (mpm_info.pid_v == 1)
_rtw_memcpy(plink->chosen_pmk, mpm_info.chosen_pmk, 16);
}
#ifdef CONFIG_RTW_MESH_DRIVER_AID
else {
ies = plink->tx_conf_ies;
ies_len = plink->tx_conf_ies_len;
plink->tx_conf_ies = NULL;
plink->tx_conf_ies_len = 0;
}
#endif
if (ies && ies_len)
rtw_mfree(ies, ies_len);
#ifndef CONFIG_RTW_MESH_DRIVER_AID
if (tx == _TRUE)
goto release_plink_ctl; /* no need to copy tx conf ies */
#endif
/* copy mesh confirm IEs */
if (mpm_info.pid_v == 1) /* not include MIC & encrypted AMPE */
ies_len = (mic_ie - fhead) - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
else
ies_len = flen - sizeof(struct rtw_ieee80211_hdr_3addr) - 2;
ies = rtw_zmalloc(ies_len);
if (ies) {
_rtw_memcpy(ies, fhead + sizeof(struct rtw_ieee80211_hdr_3addr) + 2, ies_len);
if (tx == _FALSE) {
plink->rx_conf_ies = ies;
plink->rx_conf_ies_len = ies_len;
}
#ifdef CONFIG_RTW_MESH_DRIVER_AID
else {
plink->tx_conf_ies = ies;
plink->tx_conf_ies_len = ies_len;
}
#endif
}
release_plink_ctl:
_exit_critical_bh(&(plink_ctl->lock), &irqL);
}
mpm_log:
rtw_mpm_info_msg(&mpm_info, mpm_log_buf);
RTW_INFO("RTW_%s:%s %s\n"
, (tx == _TRUE) ? "Tx" : "Rx"
, action_self_protected_str(action)
, mpm_log_buf
);
ret = 1;
exit:
if (nbuf) {
if (ret == 1) {
*buf = nbuf;
*len = nlen;
} else
rtw_mfree(nbuf, nlen);
}
return ret;
}
static int rtw_mesh_check_frames(_adapter *adapter, const u8 **buf, size_t *len, u8 tx)
{
int is_mesh_frame = -1;
const u8 *frame_body;
u8 category, action;
frame_body = *buf + sizeof(struct rtw_ieee80211_hdr_3addr);
category = frame_body[0];
if (category == RTW_WLAN_CATEGORY_SELF_PROTECTED) {
action = frame_body[1];
switch (action) {
case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
case RTW_ACT_SELF_PROTECTED_MESH_CONF:
case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
rtw_mpm_check_frames(adapter, action, buf, len, tx);
is_mesh_frame = action;
break;
case RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM:
case RTW_ACT_SELF_PROTECTED_MESH_GK_ACK:
RTW_INFO("RTW_%s:%s\n", (tx == _TRUE) ? "Tx" : "Rx", action_self_protected_str(action));
is_mesh_frame = action;
break;
default:
break;
};
}
return is_mesh_frame;
}
int rtw_mesh_check_frames_tx(_adapter *adapter, const u8 **buf, size_t *len)
{
return rtw_mesh_check_frames(adapter, buf, len, _TRUE);
}
int rtw_mesh_check_frames_rx(_adapter *adapter, const u8 *buf, size_t len)
{
return rtw_mesh_check_frames(adapter, &buf, &len, _FALSE);
}
int rtw_mesh_on_auth(_adapter *adapter, union recv_frame *rframe)
{
u8 *whdr = rframe->u.hdr.rx_data;
#if CONFIG_RTW_MACADDR_ACL
if (rtw_access_ctrl(adapter, get_addr2_ptr(whdr)) == _FALSE)
return _SUCCESS;
#endif
if (!rtw_mesh_plink_get(adapter, get_addr2_ptr(whdr))) {
#if CONFIG_RTW_MESH_ACNODE_PREVENT
rtw_mesh_acnode_set_notify_etime(adapter, whdr);
#endif
if (adapter_to_rfctl(adapter)->offch_state == OFFCHS_NONE)
issue_probereq(adapter, &adapter->mlmepriv.cur_network.network.mesh_id, get_addr2_ptr(whdr));
/* only peer being added (checked by notify conditions) is allowed */
return _SUCCESS;
}
rtw_cfg80211_rx_mframe(adapter, rframe, NULL);
return _SUCCESS;
}
unsigned int on_action_self_protected(_adapter *adapter, union recv_frame *rframe)
{
unsigned int ret = _FAIL;
struct sta_info *sta = NULL;
u8 *pframe = rframe->u.hdr.rx_data;
uint frame_len = rframe->u.hdr.len;
u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
u8 category;
u8 action;
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(adapter), GetAddr1Ptr(pframe), ETH_ALEN))
goto exit;
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_SELF_PROTECTED)
goto exit;
action = frame_body[1];
switch (action) {
case RTW_ACT_SELF_PROTECTED_MESH_OPEN:
case RTW_ACT_SELF_PROTECTED_MESH_CONF:
case RTW_ACT_SELF_PROTECTED_MESH_CLOSE:
case RTW_ACT_SELF_PROTECTED_MESH_GK_INFORM:
case RTW_ACT_SELF_PROTECTED_MESH_GK_ACK:
if (!(MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter)))
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
#if CONFIG_RTW_MACADDR_ACL
if (rtw_access_ctrl(adapter, get_addr2_ptr(pframe)) == _FALSE)
goto exit;
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
if (rtw_mesh_cto_mgate_required(adapter)
/* only peer being added (checked by notify conditions) is allowed */
&& !rtw_mesh_plink_get(adapter, get_addr2_ptr(pframe)))
goto exit;
#endif
rtw_cfg80211_rx_action(adapter, rframe, NULL);
ret = _SUCCESS;
#endif /* CONFIG_IOCTL_CFG80211 */
break;
default:
break;
}
exit:
return ret;
}
const u8 ae_to_mesh_ctrl_len[] = {
6,
12, /* MESH_FLAGS_AE_A4 */
18, /* MESH_FLAGS_AE_A5_A6 */
0,
};
unsigned int on_action_mesh(_adapter *adapter, union recv_frame *rframe)
{
unsigned int ret = _FAIL;
struct sta_info *sta = NULL;
struct sta_priv *stapriv = &adapter->stapriv;
u8 *pframe = rframe->u.hdr.rx_data;
uint frame_len = rframe->u.hdr.len;
u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
u8 category;
u8 action;
if (!MLME_IS_MESH(adapter))
goto exit;
/* check stainfo exist? */
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_MESH)
goto exit;
action = frame_body[1];
switch (action) {
case RTW_ACT_MESH_HWMP_PATH_SELECTION:
rtw_mesh_rx_path_sel_frame(adapter, rframe);
ret = _SUCCESS;
break;
default:
break;
}
exit:
return ret;
}
bool rtw_mesh_update_bss_peering_status(_adapter *adapter, WLAN_BSSID_EX *bss)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
u8 num_of_peerings = stapriv->asoc_list_cnt;
bool accept_peerings = stapriv->asoc_list_cnt < mcfg->max_peer_links;
u8 *ie;
int ie_len;
bool updated = 0;
#if CONFIG_RTW_MESH_ACNODE_PREVENT
accept_peerings |= plink_ctl->acnode_rsvd;
#endif
ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len, BSS_EX_TLV_IES_LEN(bss));
if (!ie || ie_len != 7) {
rtw_warn_on(1);
goto exit;
}
if (GET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2) != num_of_peerings) {
SET_MESH_CONF_ELE_NUM_OF_PEERINGS(ie + 2, num_of_peerings);
updated = 1;
}
if (GET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2) != accept_peerings) {
SET_MESH_CONF_ELE_ACCEPT_PEERINGS(ie + 2, accept_peerings);
updated = 1;
}
exit:
return updated;
}
bool rtw_mesh_update_bss_formation_info(_adapter *adapter, WLAN_BSSID_EX *bss)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
u8 cto_mgate = (minfo->num_gates || mcfg->dot11MeshGateAnnouncementProtocol);
u8 cto_as = 0;
u8 *ie;
int ie_len;
bool updated = 0;
ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
BSS_EX_TLV_IES_LEN(bss));
if (!ie || ie_len != 7) {
rtw_warn_on(1);
goto exit;
}
if (GET_MESH_CONF_ELE_CTO_MGATE(ie + 2) != cto_mgate) {
SET_MESH_CONF_ELE_CTO_MGATE(ie + 2, cto_mgate);
updated = 1;
}
if (GET_MESH_CONF_ELE_CTO_AS(ie + 2) != cto_as) {
SET_MESH_CONF_ELE_CTO_AS(ie + 2, cto_as);
updated = 1;
}
exit:
return updated;
}
bool rtw_mesh_update_bss_forwarding_state(_adapter *adapter, WLAN_BSSID_EX *bss)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
u8 forward = mcfg->dot11MeshForwarding;
u8 *ie;
int ie_len;
bool updated = 0;
ie = rtw_get_ie(BSS_EX_TLV_IES(bss), WLAN_EID_MESH_CONFIG, &ie_len,
BSS_EX_TLV_IES_LEN(bss));
if (!ie || ie_len != 7) {
rtw_warn_on(1);
goto exit;
}
if (GET_MESH_CONF_ELE_FORWARDING(ie + 2) != forward) {
SET_MESH_CONF_ELE_FORWARDING(ie + 2, forward);
updated = 1;
}
exit:
return updated;
}
struct mesh_plink_ent *_rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
int i;
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
if (plink_ctl->ent[i].valid == _TRUE
&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
) {
ent = &plink_ctl->ent[i];
break;
}
}
return ent;
}
struct mesh_plink_ent *rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
ent = _rtw_mesh_plink_get(adapter, hwaddr);
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return ent;
}
struct mesh_plink_ent *rtw_mesh_plink_get_no_estab_by_idx(_adapter *adapter, u8 idx)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
int i, j = 0;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
if (plink_ctl->ent[i].valid == _TRUE
&& plink_ctl->ent[i].plink_state != RTW_MESH_PLINK_ESTAB
) {
if (j == idx) {
ent = &plink_ctl->ent[i];
break;
}
j++;
}
}
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return ent;
}
int _rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
u8 exist = _FALSE;
int i;
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
if (plink_ctl->ent[i].valid == _TRUE
&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
) {
ent = &plink_ctl->ent[i];
exist = _TRUE;
break;
}
if (ent == NULL && plink_ctl->ent[i].valid == _FALSE)
ent = &plink_ctl->ent[i];
}
if (exist == _FALSE && ent) {
_rtw_memcpy(ent->addr, hwaddr, ETH_ALEN);
ent->valid = _TRUE;
#ifdef CONFIG_RTW_MESH_AEK
ent->aek_valid = 0;
#endif
ent->llid = 0;
ent->plid = 0;
_rtw_memset(ent->chosen_pmk, 0, 16);
#ifdef CONFIG_RTW_MESH_AEK
_rtw_memset(ent->sel_pcs, 0, 4);
_rtw_memset(ent->l_nonce, 0, 32);
_rtw_memset(ent->p_nonce, 0, 32);
#endif
ent->plink_state = RTW_MESH_PLINK_LISTEN;
#ifndef CONFIG_RTW_MESH_DRIVER_AID
ent->aid = 0;
#endif
ent->peer_aid = 0;
SET_PEER_CONF_DISABLED(ent);
SET_CTO_MGATE_CONF_DISABLED(ent);
plink_ctl->num++;
}
return exist == _TRUE ? RTW_ALREADY : (ent ? _SUCCESS : _FAIL);
}
int rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
_irqL irqL;
int ret;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
ret = _rtw_mesh_plink_add(adapter, hwaddr);
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return ret;
}
int rtw_mesh_plink_set_state(_adapter *adapter, const u8 *hwaddr, u8 state)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
ent = _rtw_mesh_plink_get(adapter, hwaddr);
if (ent)
ent->plink_state = state;
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return ent ? _SUCCESS : _FAIL;
}
#ifdef CONFIG_RTW_MESH_AEK
int rtw_mesh_plink_set_aek(_adapter *adapter, const u8 *hwaddr, const u8 *aek)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
ent = _rtw_mesh_plink_get(adapter, hwaddr);
if (ent) {
_rtw_memcpy(ent->aek, aek, 32);
ent->aek_valid = 1;
}
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return ent ? _SUCCESS : _FAIL;
}
#endif
#if CONFIG_RTW_MESH_PEER_BLACKLIST
int rtw_mesh_plink_set_peer_conf_timeout(_adapter *adapter, const u8 *hwaddr)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
ent = _rtw_mesh_plink_get(adapter, hwaddr);
if (ent) {
if (IS_PEER_CONF_DISABLED(ent))
SET_PEER_CONF_END_TIME(ent, mcfg->peer_sel_policy.peer_conf_timeout_ms);
}
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return ent ? _SUCCESS : _FAIL;
}
#endif
void _rtw_mesh_plink_del_ent(_adapter *adapter, struct mesh_plink_ent *ent)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
ent->valid = _FALSE;
#ifdef CONFIG_RTW_MESH_DRIVER_AID
if (ent->tx_conf_ies && ent->tx_conf_ies_len)
rtw_mfree(ent->tx_conf_ies, ent->tx_conf_ies_len);
ent->tx_conf_ies = NULL;
ent->tx_conf_ies_len = 0;
#endif
if (ent->rx_conf_ies && ent->rx_conf_ies_len)
rtw_mfree(ent->rx_conf_ies, ent->rx_conf_ies_len);
ent->rx_conf_ies = NULL;
ent->rx_conf_ies_len = 0;
if (ent->scanned)
ent->scanned = NULL;
plink_ctl->num--;
}
int rtw_mesh_plink_del(_adapter *adapter, const u8 *hwaddr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent = NULL;
u8 exist = _FALSE;
int i;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
if (plink_ctl->ent[i].valid == _TRUE
&& _rtw_memcmp(plink_ctl->ent[i].addr, hwaddr, ETH_ALEN) == _TRUE
) {
ent = &plink_ctl->ent[i];
exist = _TRUE;
break;
}
}
if (exist == _TRUE)
_rtw_mesh_plink_del_ent(adapter, ent);
_exit_critical_bh(&(plink_ctl->lock), &irqL);
return exist == _TRUE ? _SUCCESS : RTW_ALREADY;
}
void rtw_mesh_plink_ctl_init(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
int i;
_rtw_spinlock_init(&plink_ctl->lock);
plink_ctl->num = 0;
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++)
plink_ctl->ent[i].valid = _FALSE;
#if CONFIG_RTW_MESH_PEER_BLACKLIST
_rtw_init_queue(&plink_ctl->peer_blacklist);
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
_rtw_init_queue(&plink_ctl->cto_mgate_blacklist);
#endif
}
void rtw_mesh_plink_ctl_deinit(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent;
int i;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
ent = &plink_ctl->ent[i];
#ifdef CONFIG_RTW_MESH_DRIVER_AID
if (ent->tx_conf_ies && ent->tx_conf_ies_len)
rtw_mfree(ent->tx_conf_ies, ent->tx_conf_ies_len);
#endif
if (ent->rx_conf_ies && ent->rx_conf_ies_len)
rtw_mfree(ent->rx_conf_ies, ent->rx_conf_ies_len);
}
_exit_critical_bh(&(plink_ctl->lock), &irqL);
_rtw_spinlock_free(&plink_ctl->lock);
#if CONFIG_RTW_MESH_PEER_BLACKLIST
rtw_mesh_peer_blacklist_flush(adapter);
_rtw_deinit_queue(&plink_ctl->peer_blacklist);
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
rtw_mesh_cto_mgate_blacklist_flush(adapter);
_rtw_deinit_queue(&plink_ctl->cto_mgate_blacklist);
#endif
}
void dump_mesh_plink_ctl(void *sel, _adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *ent;
int i;
RTW_PRINT_SEL(sel, "num:%u\n", plink_ctl->num);
#if CONFIG_RTW_MESH_ACNODE_PREVENT
RTW_PRINT_SEL(sel, "acnode_rsvd:%u\n", plink_ctl->acnode_rsvd);
#endif
for (i = 0; i < RTW_MESH_MAX_PEER_CANDIDATES; i++) {
ent = &plink_ctl->ent[i];
if (!ent->valid)
continue;
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "peer:"MAC_FMT"\n", MAC_ARG(ent->addr));
RTW_PRINT_SEL(sel, "plink_state:%s\n", rtw_mesh_plink_str(ent->plink_state));
#ifdef CONFIG_RTW_MESH_AEK
if (ent->aek_valid)
RTW_PRINT_SEL(sel, "aek:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->aek), KEY_ARG(ent->aek + 16));
#endif
RTW_PRINT_SEL(sel, "llid:%u, plid:%u\n", ent->llid, ent->plid);
#ifndef CONFIG_RTW_MESH_DRIVER_AID
RTW_PRINT_SEL(sel, "aid:%u\n", ent->aid);
#endif
RTW_PRINT_SEL(sel, "peer_aid:%u\n", ent->peer_aid);
RTW_PRINT_SEL(sel, "chosen_pmk:"KEY_FMT"\n", KEY_ARG(ent->chosen_pmk));
#ifdef CONFIG_RTW_MESH_AEK
RTW_PRINT_SEL(sel, "sel_pcs:%02x%02x%02x%02x\n"
, ent->sel_pcs[0], ent->sel_pcs[1], ent->sel_pcs[2], ent->sel_pcs[3]);
RTW_PRINT_SEL(sel, "l_nonce:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->l_nonce), KEY_ARG(ent->l_nonce + 16));
RTW_PRINT_SEL(sel, "p_nonce:"KEY_FMT KEY_FMT"\n", KEY_ARG(ent->p_nonce), KEY_ARG(ent->p_nonce + 16));
#endif
#ifdef CONFIG_RTW_MESH_DRIVER_AID
RTW_PRINT_SEL(sel, "tx_conf_ies:%p, len:%u\n", ent->tx_conf_ies, ent->tx_conf_ies_len);
#endif
RTW_PRINT_SEL(sel, "rx_conf_ies:%p, len:%u\n", ent->rx_conf_ies, ent->rx_conf_ies_len);
RTW_PRINT_SEL(sel, "scanned:%p\n", ent->scanned);
#if CONFIG_RTW_MESH_PEER_BLACKLIST
if (!IS_PEER_CONF_DISABLED(ent)) {
if (!IS_PEER_CONF_TIMEOUT(ent))
RTW_PRINT_SEL(sel, "peer_conf:%d\n", rtw_systime_to_ms(ent->peer_conf_end_time - rtw_get_current_time()));
else
RTW_PRINT_SEL(sel, "peer_conf:TIMEOUT\n");
}
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
if (!IS_CTO_MGATE_CONF_DISABLED(ent)) {
if (!IS_CTO_MGATE_CONF_TIMEOUT(ent))
RTW_PRINT_SEL(sel, "cto_mgate_conf:%d\n", rtw_systime_to_ms(ent->cto_mgate_conf_end_time - rtw_get_current_time()));
else
RTW_PRINT_SEL(sel, "cto_mgate_conf:TIMEOUT\n");
}
#endif
}
}
/* this function is called with plink_ctl being locked */
int rtw_mesh_peer_establish(_adapter *adapter, struct mesh_plink_ent *plink, struct sta_info *sta)
{
#ifndef DBG_RTW_MESH_PEER_ESTABLISH
#define DBG_RTW_MESH_PEER_ESTABLISH 0
#endif
struct sta_priv *stapriv = &adapter->stapriv;
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
u8 *tlv_ies;
u16 tlv_ieslen;
struct rtw_ieee802_11_elems elems;
_irqL irqL;
int i;
int ret = _FAIL;
if (!plink->rx_conf_ies || !plink->rx_conf_ies_len) {
RTW_INFO(FUNC_ADPT_FMT" no rx confirm from sta "MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
goto exit;
}
if (plink->rx_conf_ies_len < 4) {
RTW_INFO(FUNC_ADPT_FMT" confirm from sta "MAC_FMT" too short\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
goto exit;
}
#ifdef CONFIG_RTW_MESH_DRIVER_AID
if (!plink->tx_conf_ies || !plink->tx_conf_ies_len) {
RTW_INFO(FUNC_ADPT_FMT" no tx confirm to sta "MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
goto exit;
}
if (plink->tx_conf_ies_len < 4) {
RTW_INFO(FUNC_ADPT_FMT" confirm to sta "MAC_FMT" too short\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
goto exit;
}
#endif
tlv_ies = plink->rx_conf_ies + 4;
tlv_ieslen = plink->rx_conf_ies_len - 4;
if (DBG_RTW_MESH_PEER_ESTABLISH)
dump_ies(RTW_DBGDUMP, tlv_ies, tlv_ieslen);
if (rtw_ieee802_11_parse_elems(tlv_ies, tlv_ieslen, &elems, 1) == ParseFailed) {
RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" sent invalid confirm\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
goto exit;
}
SET_PEER_CONF_DISABLED(plink);
if (rtw_bss_is_cto_mgate(&plink->scanned->network)
&& !rtw_bss_is_forwarding(&plink->scanned->network))
SET_CTO_MGATE_CONF_END_TIME(plink, mcfg->peer_sel_policy.cto_mgate_conf_timeout_ms);
else
SET_CTO_MGATE_CONF_DISABLED(plink);
sta->state &= (~WIFI_FW_AUTH_SUCCESS);
sta->state |= WIFI_FW_ASSOC_STATE;
rtw_ap_parse_sta_capability(adapter, sta, plink->rx_conf_ies);
if (rtw_ap_parse_sta_supported_rates(adapter, sta, tlv_ies, tlv_ieslen) != _STATS_SUCCESSFUL_)
goto exit;
if (rtw_ap_parse_sta_security_ie(adapter, sta, &elems) != _STATS_SUCCESSFUL_)
goto exit;
rtw_ap_parse_sta_wmm_ie(adapter, sta, tlv_ies, tlv_ieslen);
#ifdef CONFIG_RTS_FULL_BW
/*check vendor IE*/
rtw_parse_sta_vendor_ie_8812(adapter, sta, tlv_ies, tlv_ieslen);
#endif/*CONFIG_RTS_FULL_BW*/
rtw_ap_parse_sta_ht_ie(adapter, sta, &elems);
rtw_ap_parse_sta_vht_ie(adapter, sta, &elems);
/* AID */
#ifdef CONFIG_RTW_MESH_DRIVER_AID
sta->cmn.aid = RTW_GET_LE16(plink->tx_conf_ies + 2);
#else
sta->cmn.aid = plink->aid;
#endif
stapriv->sta_aid[sta->cmn.aid - 1] = sta;
RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" aid:%u\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr), sta->cmn.aid);
sta->state &= (~WIFI_FW_ASSOC_STATE);
sta->state |= WIFI_FW_ASSOC_SUCCESS;
sta->local_mps = RTW_MESH_PS_ACTIVE;
rtw_ewma_err_rate_init(&sta->metrics.err_rate);
rtw_ewma_err_rate_add(&sta->metrics.err_rate, 1);
/* init data_rate to 1M */
sta->metrics.data_rate = 10;
sta->alive = _TRUE;
_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&sta->asoc_list)) {
STA_SET_MESH_PLINK(sta, plink);
/* TBD: up layer timeout mechanism */
/* sta->expire_to = mcfg->plink_timeout / 2; */
rtw_list_insert_tail(&sta->asoc_list, &stapriv->asoc_list);
stapriv->asoc_list_cnt++;
}
_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
bss_cap_update_on_sta_join(adapter, sta);
sta_info_update(adapter, sta);
report_add_sta_event(adapter, sta->cmn.mac_addr);
ret = _SUCCESS;
exit:
return ret;
}
void rtw_mesh_expire_peer_notify(_adapter *adapter, const u8 *peer_addr)
{
u8 null_ssid[2] = {0, 0};
#ifdef CONFIG_IOCTL_CFG80211
rtw_cfg80211_notify_new_peer_candidate(adapter->rtw_wdev
, peer_addr
, null_ssid
, 2
, 0
, GFP_ATOMIC
);
#endif
return;
}
static u8 *rtw_mesh_construct_peer_mesh_close(_adapter *adapter, struct mesh_plink_ent *plink, u16 reason, u32 *len)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
u8 *frame = NULL, *pos;
u32 flen;
struct rtw_ieee80211_hdr *whdr;
if (minfo->mesh_auth_id && !MESH_PLINK_AEK_VALID(plink))
goto exit;
flen = sizeof(struct rtw_ieee80211_hdr_3addr)
+ 2 /* category, action */
+ 2 + minfo->mesh_id_len /* mesh id */
+ 2 + 8 + (minfo->mesh_auth_id ? 16 : 0) /* mpm */
+ (minfo->mesh_auth_id ? 2 + AES_BLOCK_SIZE : 0) /* mic */
+ (minfo->mesh_auth_id ? 70 : 0) /* ampe */
;
pos = frame = rtw_zmalloc(flen);
if (!frame)
goto exit;
whdr = (struct rtw_ieee80211_hdr *)frame;
_rtw_memcpy(whdr->addr1, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memcpy(whdr->addr2, plink->addr, ETH_ALEN);
_rtw_memcpy(whdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
set_frame_sub_type(frame, WIFI_ACTION);
pos += sizeof(struct rtw_ieee80211_hdr_3addr);
*(pos++) = RTW_WLAN_CATEGORY_SELF_PROTECTED;
*(pos++) = RTW_ACT_SELF_PROTECTED_MESH_CLOSE;
pos = rtw_set_ie_mesh_id(pos, NULL, minfo->mesh_id, minfo->mesh_id_len);
pos = rtw_set_ie_mpm(pos, NULL
, minfo->mesh_auth_id ? 1 : 0
, plink->plid
, &plink->llid
, &reason
, minfo->mesh_auth_id ? plink->chosen_pmk : NULL);
#ifdef CONFIG_RTW_MESH_AEK
if (minfo->mesh_auth_id) {
u8 ampe_buf[70];
int enc_ret;
*pos = WLAN_EID_MIC;
*(pos + 1) = AES_BLOCK_SIZE;
ampe_buf[0] = WLAN_EID_AMPE;
ampe_buf[1] = 68;
_rtw_memcpy(ampe_buf + 2, plink->sel_pcs, 4);
_rtw_memcpy(ampe_buf + 6, plink->p_nonce, 32);
_rtw_memcpy(ampe_buf + 38, plink->l_nonce, 32);
enc_ret = rtw_mpm_ampe_enc(adapter, plink
, frame + sizeof(struct rtw_ieee80211_hdr_3addr)
, pos, ampe_buf, 1);
if (enc_ret != _SUCCESS) {
rtw_mfree(frame, flen);
frame = NULL;
goto exit;
}
}
#endif
*len = flen;
exit:
return frame;
}
void _rtw_mesh_expire_peer_ent(_adapter *adapter, struct mesh_plink_ent *plink)
{
#if defined(CONFIG_RTW_MESH_STA_DEL_DISASOC)
_rtw_mesh_plink_del_ent(adapter, plink);
rtw_cfg80211_indicate_sta_disassoc(adapter, plink->addr, 0);
#else
u8 *frame = NULL;
u32 flen;
if (plink->plink_state == RTW_MESH_PLINK_ESTAB)
frame = rtw_mesh_construct_peer_mesh_close(adapter, plink, WLAN_REASON_MESH_CLOSE, &flen);
if (frame) {
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct wireless_dev *wdev = adapter->rtw_wdev;
s32 freq = rtw_ch2freq(mlmeext->cur_channel);
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) || defined(COMPAT_KERNEL_RELEASE)
rtw_cfg80211_rx_mgmt(wdev, freq, 0, frame, flen, GFP_ATOMIC);
#else
cfg80211_rx_action(adapter->pnetdev, freq, frame, flen, GFP_ATOMIC);
#endif
rtw_mfree(frame, flen);
} else {
rtw_mesh_expire_peer_notify(adapter, plink->addr);
RTW_INFO(FUNC_ADPT_FMT" set "MAC_FMT" plink unknown\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(plink->addr));
plink->plink_state = RTW_MESH_PLINK_UNKNOWN;
}
#endif
}
void rtw_mesh_expire_peer(_adapter *adapter, const u8 *peer_addr)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct mesh_plink_pool *plink_ctl = &minfo->plink_ctl;
struct mesh_plink_ent *plink;
_irqL irqL;
_enter_critical_bh(&(plink_ctl->lock), &irqL);
plink = _rtw_mesh_plink_get(adapter, peer_addr);
if (!plink)
goto exit;
_rtw_mesh_expire_peer_ent(adapter, plink);
exit:
_exit_critical_bh(&(plink_ctl->lock), &irqL);
}
u8 rtw_mesh_ps_annc(_adapter *adapter, u8 ps)
{
_irqL irqL;
_list *head, *list;
struct sta_info *sta;
struct sta_priv *stapriv = &adapter->stapriv;
u8 sta_alive_num = 0, i;
char sta_alive_list[NUM_STA];
u8 annc_cnt = 0;
if (rtw_linked_check(adapter) == _FALSE)
goto exit;
_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
head = &stapriv->asoc_list;
list = get_next(head);
while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
int stainfo_offset;
sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
list = get_next(list);
stainfo_offset = rtw_stainfo_offset(stapriv, sta);
if (stainfo_offset_valid(stainfo_offset))
sta_alive_list[sta_alive_num++] = stainfo_offset;
}
_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
for (i = 0; i < sta_alive_num; i++) {
sta = rtw_get_stainfo_by_offset(stapriv, sta_alive_list[i]);
if (!sta)
continue;
issue_qos_nulldata(adapter, sta->cmn.mac_addr, 7, ps, 3, 500);
annc_cnt++;
}
exit:
return annc_cnt;
}
static void mpath_tx_tasklet_hdl(void *priv)
{
_adapter *adapter = (_adapter *)priv;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct xmit_frame *xframe;
_list *list, *head;
_list tmp;
u32 tmp_len;
s32 res;
_rtw_init_listhead(&tmp);
while (1) {
tmp_len = 0;
enter_critical_bh(&minfo->mpath_tx_queue.lock);
if (minfo->mpath_tx_queue_len) {
rtw_list_splice_init(&minfo->mpath_tx_queue.queue, &tmp);
tmp_len = minfo->mpath_tx_queue_len;
minfo->mpath_tx_queue_len = 0;
}
exit_critical_bh(&minfo->mpath_tx_queue.lock);
if (!tmp_len)
break;
head = &tmp;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&xframe->list);
res = rtw_xmit_posthandle(adapter, xframe, xframe->pkt);
if (res < 0) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit fail\n", __FUNCTION__);
#endif
adapter->xmitpriv.tx_drop++;
}
}
}
}
static void rtw_mpath_tx_queue_flush(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct xmit_frame *xframe;
_list *list, *head;
_list tmp;
_rtw_init_listhead(&tmp);
enter_critical_bh(&minfo->mpath_tx_queue.lock);
rtw_list_splice_init(&minfo->mpath_tx_queue.queue, &tmp);
minfo->mpath_tx_queue_len = 0;
exit_critical_bh(&minfo->mpath_tx_queue.lock);
head = &tmp;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&xframe->list);
rtw_free_xmitframe(&adapter->xmitpriv, xframe);
}
}
#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
#if defined(CONFIG_SLUB)
#include
#elif defined(CONFIG_SLAB)
#include
#endif
typedef struct kmem_cache rtw_mcache;
#endif
rtw_mcache *rtw_mcache_create(const char *name, size_t size)
{
#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
return kmem_cache_create(name, size, 0, 0, NULL);
#else
#error "TBD\n";
#endif
}
void rtw_mcache_destroy(rtw_mcache *s)
{
#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
kmem_cache_destroy(s);
#else
#error "TBD\n";
#endif
}
void *_rtw_mcache_alloc(rtw_mcache *cachep)
{
#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
return kmem_cache_alloc(cachep, GFP_ATOMIC);
#else
#error "TBD\n";
#endif
}
void _rtw_mcache_free(rtw_mcache *cachep, void *objp)
{
#ifdef PLATFORM_LINUX /* 3.10 ~ 4.13 checked */
kmem_cache_free(cachep, objp);
#else
#error "TBD\n";
#endif
}
#ifdef DBG_MEM_ALLOC
inline void *dbg_rtw_mcache_alloc(rtw_mcache *cachep, const enum mstat_f flags, const char *func, const int line)
{
void *p;
u32 sz = cachep->size;
if (match_mstat_sniff_rules(flags, sz))
RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u)\n", func, line, __func__, sz);
p = _rtw_mcache_alloc(cachep);
rtw_mstat_update(
flags
, p ? MSTAT_ALLOC_SUCCESS : MSTAT_ALLOC_FAIL
, sz
);
return p;
}
inline void dbg_rtw_mcache_free(rtw_mcache *cachep, void *pbuf, const enum mstat_f flags, const char *func, const int line)
{
u32 sz = cachep->size;
if (match_mstat_sniff_rules(flags, sz))
RTW_INFO("DBG_MEM_ALLOC %s:%d %s(%u)\n", func, line, __func__, sz);
_rtw_mcache_free(cachep, pbuf);
rtw_mstat_update(
flags
, MSTAT_FREE
, sz
);
}
#define rtw_mcache_alloc(cachep) dbg_rtw_mcache_alloc(cachep, MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
#define rtw_mcache_free(cachep, objp) dbg_rtw_mcache_free(cachep, objp, MSTAT_TYPE_PHY, __FUNCTION__, __LINE__)
#else
#define rtw_mcache_alloc(cachep) _rtw_mcache_alloc(cachep)
#define rtw_mcache_free(cachep, objp) _rtw_mcache_free(cachep, objp)
#endif /* DBG_MEM_ALLOC */
/* Mesh Received Cache */
#define RTW_MRC_BUCKETS 256 /* must be a power of 2 */
#define RTW_MRC_QUEUE_MAX_LEN 4
#define RTW_MRC_TIMEOUT_MS (3 * 1000)
/**
* struct rtw_mrc_entry - entry in the Mesh Received Cache
*
* @seqnum: mesh sequence number of the frame
* @exp_time: expiration time of the entry
* @msa: mesh source address of the frame
* @list: hashtable list pointer
*
* The Mesh Received Cache keeps track of the latest received frames that
* have been received by a mesh interface and discards received frames
* that are found in the cache.
*/
struct rtw_mrc_entry {
rtw_hlist_node list;
systime exp_time;
u32 seqnum;
u8 msa[ETH_ALEN];
};
struct rtw_mrc {
rtw_hlist_head bucket[RTW_MRC_BUCKETS];
u32 idx_mask;
rtw_mcache *cache;
};
static int rtw_mrc_init(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
char cache_name[IFNAMSIZ + 8 + 1];
int i;
minfo->mrc = rtw_malloc(sizeof(struct rtw_mrc));
if (!minfo->mrc)
return -ENOMEM;
minfo->mrc->idx_mask = RTW_MRC_BUCKETS - 1;
for (i = 0; i < RTW_MRC_BUCKETS; i++)
rtw_hlist_head_init(&minfo->mrc->bucket[i]);
sprintf(cache_name, "rtw_mrc_%s", ADPT_ARG(adapter));
minfo->mrc->cache = rtw_mcache_create(cache_name, sizeof(struct rtw_mrc_entry));
return 0;
}
static void rtw_mrc_free(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mrc *mrc = minfo->mrc;
struct rtw_mrc_entry *p;
rtw_hlist_node *np, *n;
int i;
if (!mrc)
return;
for (i = 0; i < RTW_MRC_BUCKETS; i++) {
rtw_hlist_for_each_entry_safe(p, np, n, &mrc->bucket[i], list) {
rtw_hlist_del(&p->list);
rtw_mcache_free(mrc->cache, p);
}
}
rtw_mcache_destroy(mrc->cache);
rtw_mfree(mrc, sizeof(struct rtw_mrc));
minfo->mrc = NULL;
}
/**
* rtw_mrc_check - Check frame in mesh received cache and add if absent.
*
* @adapter: interface
* @msa: mesh source address
* @seq: mesh seq number
*
* Returns: 0 if the frame is not in the cache, nonzero otherwise.
*
* Checks using the mesh source address and the mesh sequence number if we have
* received this frame lately. If the frame is not in the cache, it is added to
* it.
*/
static int rtw_mrc_check(_adapter *adapter, const u8 *msa, u32 seq)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mrc *mrc = minfo->mrc;
int entries = 0;
u8 idx;
struct rtw_mrc_entry *p;
rtw_hlist_node *np, *n;
u8 timeout;
if (!mrc)
return -1;
idx = seq & mrc->idx_mask;
rtw_hlist_for_each_entry_safe(p, np, n, &mrc->bucket[idx], list) {
++entries;
timeout = rtw_time_after(rtw_get_current_time(), p->exp_time);
if (timeout || entries == RTW_MRC_QUEUE_MAX_LEN) {
if (!timeout)
minfo->mshstats.mrc_del_qlen++;
rtw_hlist_del(&p->list);
rtw_mcache_free(mrc->cache, p);
--entries;
} else if ((seq == p->seqnum) && _rtw_memcmp(msa, p->msa, ETH_ALEN) == _TRUE)
return -1;
}
p = rtw_mcache_alloc(mrc->cache);
if (!p)
return 0;
p->seqnum = seq;
p->exp_time = rtw_get_current_time() + rtw_ms_to_systime(RTW_MRC_TIMEOUT_MS);
_rtw_memcpy(p->msa, msa, ETH_ALEN);
rtw_hlist_add_head(&p->list, &mrc->bucket[idx]);
return 0;
}
static int rtw_mesh_decache(_adapter *adapter, const u8 *msa, u32 seq)
{
return rtw_mrc_check(adapter, msa, seq);
}
#ifndef RTW_MESH_SCAN_RESULT_EXP_MS
#define RTW_MESH_SCAN_RESULT_EXP_MS (10 * 1000)
#endif
#ifndef RTW_MESH_ACNODE_PREVENT
#define RTW_MESH_ACNODE_PREVENT 0
#endif
#ifndef RTW_MESH_ACNODE_CONF_TIMEOUT_MS
#define RTW_MESH_ACNODE_CONF_TIMEOUT_MS (20 * 1000)
#endif
#ifndef RTW_MESH_ACNODE_NOTIFY_TIMEOUT_MS
#define RTW_MESH_ACNODE_NOTIFY_TIMEOUT_MS (2 * 1000)
#endif
#ifndef RTW_MESH_OFFCH_CAND
#define RTW_MESH_OFFCH_CAND 1
#endif
#ifndef RTW_MESH_OFFCH_CAND_FIND_INT_MS
#define RTW_MESH_OFFCH_CAND_FIND_INT_MS (10 * 1000)
#endif
#ifndef RTW_MESH_PEER_CONF_TIMEOUT_MS
#define RTW_MESH_PEER_CONF_TIMEOUT_MS (20 * 1000)
#endif
#ifndef RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS
#define RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS (20 * 1000)
#endif
#ifndef RTW_MESH_CTO_MGATE_REQUIRE
#define RTW_MESH_CTO_MGATE_REQUIRE 0
#endif
#ifndef RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS
#define RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS (20 * 1000)
#endif
#ifndef RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS
#define RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS (20 * 1000)
#endif
void rtw_mesh_cfg_init_peer_sel_policy(struct rtw_mesh_cfg *mcfg)
{
struct mesh_peer_sel_policy *sel_policy = &mcfg->peer_sel_policy;
sel_policy->scanr_exp_ms = RTW_MESH_SCAN_RESULT_EXP_MS;
#if CONFIG_RTW_MESH_ACNODE_PREVENT
sel_policy->acnode_prevent = RTW_MESH_ACNODE_PREVENT;
sel_policy->acnode_conf_timeout_ms = RTW_MESH_ACNODE_CONF_TIMEOUT_MS;
sel_policy->acnode_notify_timeout_ms = RTW_MESH_ACNODE_NOTIFY_TIMEOUT_MS;
#endif
#if CONFIG_RTW_MESH_OFFCH_CAND
sel_policy->offch_cand = RTW_MESH_OFFCH_CAND;
sel_policy->offch_find_int_ms = RTW_MESH_OFFCH_CAND_FIND_INT_MS;
#endif
#if CONFIG_RTW_MESH_PEER_BLACKLIST
sel_policy->peer_conf_timeout_ms = RTW_MESH_PEER_CONF_TIMEOUT_MS;
sel_policy->peer_blacklist_timeout_ms = RTW_MESH_PEER_BLACKLIST_TIMEOUT_MS;
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
sel_policy->cto_mgate_require = RTW_MESH_CTO_MGATE_REQUIRE;
sel_policy->cto_mgate_conf_timeout_ms = RTW_MESH_CTO_MGATE_CONF_TIMEOUT_MS;
sel_policy->cto_mgate_blacklist_timeout_ms = RTW_MESH_CTO_MGATE_BLACKLIST_TIMEOUT_MS;
#endif
}
void rtw_mesh_cfg_init(_adapter *adapter)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
mcfg->max_peer_links = RTW_MESH_MAX_PEER_LINKS;
mcfg->plink_timeout = RTW_MESH_PEER_LINK_TIMEOUT;
mcfg->dot11MeshTTL = RTW_MESH_TTL;
mcfg->element_ttl = RTW_MESH_DEFAULT_ELEMENT_TTL;
mcfg->dot11MeshHWMPmaxPREQretries = RTW_MESH_MAX_PREQ_RETRIES;
mcfg->path_refresh_time = RTW_MESH_PATH_REFRESH_TIME;
mcfg->min_discovery_timeout = RTW_MESH_MIN_DISCOVERY_TIMEOUT;
mcfg->dot11MeshHWMPactivePathTimeout = RTW_MESH_PATH_TIMEOUT;
mcfg->dot11MeshHWMPpreqMinInterval = RTW_MESH_PREQ_MIN_INT;
mcfg->dot11MeshHWMPperrMinInterval = RTW_MESH_PERR_MIN_INT;
mcfg->dot11MeshHWMPnetDiameterTraversalTime = RTW_MESH_DIAM_TRAVERSAL_TIME;
mcfg->dot11MeshHWMPRootMode = RTW_IEEE80211_ROOTMODE_NO_ROOT;
mcfg->dot11MeshHWMPRannInterval = RTW_MESH_RANN_INTERVAL;
mcfg->dot11MeshGateAnnouncementProtocol = _FALSE;
mcfg->dot11MeshForwarding = _TRUE;
mcfg->rssi_threshold = 0;
mcfg->dot11MeshHWMPactivePathToRootTimeout = RTW_MESH_PATH_TO_ROOT_TIMEOUT;
mcfg->dot11MeshHWMProotInterval = RTW_MESH_ROOT_INTERVAL;
mcfg->dot11MeshHWMPconfirmationInterval = RTW_MESH_ROOT_CONFIRMATION_INTERVAL;
mcfg->path_gate_timeout_factor = 3;
rtw_mesh_cfg_init_peer_sel_policy(mcfg);
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
mcfg->sane_metric_delta = RTW_MESH_SANE_METRIC_DELTA;
mcfg->max_root_add_chk_cnt = RTW_MESH_MAX_ROOT_ADD_CHK_CNT;
#endif
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
mcfg->b2u_flags_msrc = 0;
mcfg->b2u_flags_mfwd = RTW_MESH_B2U_GA_UCAST;
#endif
}
void rtw_mesh_cfg_init_max_peer_links(_adapter *adapter, u8 stack_conf)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
mcfg->max_peer_links = RTW_MESH_MAX_PEER_LINKS;
if (mcfg->max_peer_links > stack_conf)
mcfg->max_peer_links = stack_conf;
}
void rtw_mesh_cfg_init_plink_timeout(_adapter *adapter, u32 stack_conf)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
mcfg->plink_timeout = stack_conf;
}
void rtw_mesh_init_mesh_info(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
_rtw_memset(minfo, 0, sizeof(struct rtw_mesh_info));
rtw_mesh_plink_ctl_init(adapter);
minfo->last_preq = rtw_get_current_time();
/* minfo->last_sn_update = rtw_get_current_time(); */
minfo->next_perr = rtw_get_current_time();
ATOMIC_SET(&minfo->mpaths, 0);
rtw_mesh_pathtbl_init(adapter);
_rtw_init_queue(&minfo->mpath_tx_queue);
tasklet_init(&minfo->mpath_tx_tasklet
, (void(*)(unsigned long))mpath_tx_tasklet_hdl
, (unsigned long)adapter);
rtw_mrc_init(adapter);
_rtw_init_listhead(&minfo->preq_queue.list);
_rtw_spinlock_init(&minfo->mesh_preq_queue_lock);
rtw_init_timer(&adapter->mesh_path_timer, adapter, rtw_ieee80211_mesh_path_timer, adapter);
rtw_init_timer(&adapter->mesh_path_root_timer, adapter, rtw_ieee80211_mesh_path_root_timer, adapter);
rtw_init_timer(&adapter->mesh_atlm_param_req_timer, adapter, rtw_mesh_atlm_param_req_timer, adapter);
_init_workitem(&adapter->mesh_work, rtw_mesh_work_hdl, NULL);
}
void rtw_mesh_deinit_mesh_info(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
tasklet_kill(&minfo->mpath_tx_tasklet);
rtw_mpath_tx_queue_flush(adapter);
_rtw_deinit_queue(&adapter->mesh_info.mpath_tx_queue);
rtw_mrc_free(adapter);
rtw_mesh_pathtbl_unregister(adapter);
rtw_mesh_plink_ctl_deinit(adapter);
_cancel_workitem_sync(&adapter->mesh_work);
_cancel_timer_ex(&adapter->mesh_path_timer);
_cancel_timer_ex(&adapter->mesh_path_root_timer);
_cancel_timer_ex(&adapter->mesh_atlm_param_req_timer);
}
/**
* rtw_mesh_nexthop_resolve - lookup next hop; conditionally start path discovery
*
* @skb: 802.11 frame to be sent
* @sdata: network subif the frame will be sent through
*
* Lookup next hop for given skb and start path discovery if no
* forwarding information is found.
*
* Returns: 0 if the next hop was found and -ENOENT if the frame was queued.
* skb is freeed here if no mpath could be allocated.
*/
int rtw_mesh_nexthop_resolve(_adapter *adapter,
struct xmit_frame *xframe)
{
struct pkt_attrib *attrib = &xframe->attrib;
struct rtw_mesh_path *mpath;
struct xmit_frame *xframe_to_free = NULL;
u8 *target_addr = attrib->mda;
int err = 0;
int ret = _SUCCESS;
rtw_rcu_read_lock();
err = rtw_mesh_nexthop_lookup(adapter, target_addr, attrib->msa, attrib->ra);
if (!err)
goto endlookup;
/* no nexthop found, start resolving */
mpath = rtw_mesh_path_lookup(adapter, target_addr);
if (!mpath) {
mpath = rtw_mesh_path_add(adapter, target_addr);
if (IS_ERR(mpath)) {
xframe->pkt = NULL; /* free pkt outside */
rtw_mesh_path_discard_frame(adapter, xframe);
err = PTR_ERR(mpath);
ret = _FAIL;
goto endlookup;
}
}
if (!(mpath->flags & RTW_MESH_PATH_RESOLVING))
rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START);
enter_critical_bh(&mpath->frame_queue.lock);
if (mpath->frame_queue_len >= RTW_MESH_FRAME_QUEUE_LEN) {
xframe_to_free = LIST_CONTAINOR(get_next(get_list_head(&mpath->frame_queue)), struct xmit_frame, list);
rtw_list_delete(&(xframe_to_free->list));
mpath->frame_queue_len--;
}
rtw_list_insert_tail(&xframe->list, get_list_head(&mpath->frame_queue));
mpath->frame_queue_len++;
exit_critical_bh(&mpath->frame_queue.lock);
ret = RTW_RA_RESOLVING;
if (xframe_to_free)
rtw_mesh_path_discard_frame(adapter, xframe_to_free);
endlookup:
rtw_rcu_read_unlock();
return ret;
}
/**
* rtw_mesh_nexthop_lookup - put the appropriate next hop on a mesh frame. Calling
* this function is considered "using" the associated mpath, so preempt a path
* refresh if this mpath expires soon.
*
* @skb: 802.11 frame to be sent
* @sdata: network subif the frame will be sent through
*
* Returns: 0 if the next hop was found. Nonzero otherwise.
*/
int rtw_mesh_nexthop_lookup(_adapter *adapter,
const u8 *mda, const u8 *msa, u8 *ra)
{
struct rtw_mesh_path *mpath;
struct sta_info *next_hop;
const u8 *target_addr = mda;
int err = -ENOENT;
struct registry_priv *registry_par = &adapter->registrypriv;
u8 peer_alive_based_preq = registry_par->peer_alive_based_preq;
BOOLEAN nexthop_alive = _TRUE;
rtw_rcu_read_lock();
mpath = rtw_mesh_path_lookup(adapter, target_addr);
if (!mpath || !(mpath->flags & RTW_MESH_PATH_ACTIVE))
goto endlookup;
next_hop = rtw_rcu_dereference(mpath->next_hop);
if (next_hop) {
_rtw_memcpy(ra, next_hop->cmn.mac_addr, ETH_ALEN);
err = 0;
}
if (peer_alive_based_preq && next_hop)
nexthop_alive = next_hop->alive;
if (_rtw_memcmp(adapter_mac_addr(adapter), msa, ETH_ALEN) == _TRUE &&
!(mpath->flags & RTW_MESH_PATH_RESOLVING) &&
!(mpath->flags & RTW_MESH_PATH_FIXED)) {
u8 flags = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH;
if (peer_alive_based_preq && nexthop_alive == _FALSE) {
flags |= RTW_PREQ_Q_F_BCAST_PREQ;
rtw_mesh_queue_preq(mpath, flags);
} else if (rtw_time_after(rtw_get_current_time(),
mpath->exp_time -
rtw_ms_to_systime(adapter->mesh_cfg.path_refresh_time))) {
rtw_mesh_queue_preq(mpath, flags);
}
/* Avoid keeping trying unicast PREQ toward root,
when next_hop leaves */
} else if (peer_alive_based_preq &&
_rtw_memcmp(adapter_mac_addr(adapter), msa, ETH_ALEN) == _TRUE &&
(mpath->flags & RTW_MESH_PATH_RESOLVING) &&
!(mpath->flags & RTW_MESH_PATH_FIXED) &&
!(mpath->flags & RTW_MESH_PATH_BCAST_PREQ) &&
mpath->is_root && nexthop_alive == _FALSE) {
enter_critical_bh(&mpath->state_lock);
mpath->flags |= RTW_MESH_PATH_BCAST_PREQ;
exit_critical_bh(&mpath->state_lock);
}
endlookup:
rtw_rcu_read_unlock();
return err;
}
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
static bool rtw_mesh_data_bmc_to_uc(_adapter *adapter
, const u8 *da, const u8 *sa, const u8 *mda, const u8 *msa
, u8 ae_need, const u8 *ori_ta, u8 mfwd_ttl
, _list *b2u_list, u8 *b2u_num, u32 *b2u_mseq)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct xmit_priv *xmitpriv = &adapter->xmitpriv;
_irqL irqL;
_list *head, *list;
struct sta_info *sta;
char b2u_sta_id[NUM_STA];
u8 b2u_sta_num = 0;
bool bmc_need = _FALSE;
int i;
_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
head = &stapriv->asoc_list;
list = get_next(head);
while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
int stainfo_offset;
sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
list = get_next(list);
stainfo_offset = rtw_stainfo_offset(stapriv, sta);
if (stainfo_offset_valid(stainfo_offset))
b2u_sta_id[b2u_sta_num++] = stainfo_offset;
}
_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
if (!b2u_sta_num)
goto exit;
for (i = 0; i < b2u_sta_num; i++) {
struct xmit_frame *b2uframe;
struct pkt_attrib *attrib;
sta = rtw_get_stainfo_by_offset(stapriv, b2u_sta_id[i]);
if (!(sta->state & _FW_LINKED)
|| _rtw_memcmp(sta->cmn.mac_addr, msa, ETH_ALEN) == _TRUE
|| (ori_ta && _rtw_memcmp(sta->cmn.mac_addr, ori_ta, ETH_ALEN) == _TRUE)
|| is_broadcast_mac_addr(sta->cmn.mac_addr)
|| is_zero_mac_addr(sta->cmn.mac_addr))
continue;
b2uframe = rtw_alloc_xmitframe(xmitpriv);
if (!b2uframe) {
bmc_need = _TRUE;
break;
}
if ((*b2u_num)++ == 0 && !ori_ta) {
*b2u_mseq = (cpu_to_le32(adapter->mesh_info.mesh_seqnum));
adapter->mesh_info.mesh_seqnum++;
}
attrib = &b2uframe->attrib;
attrib->mb2u = 1;
attrib->mseq = *b2u_mseq;
attrib->mfwd_ttl = ori_ta ? mfwd_ttl : 0;
_rtw_memcpy(attrib->ra, sta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(attrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memcpy(attrib->mda, mda, ETH_ALEN);
_rtw_memcpy(attrib->msa, msa, ETH_ALEN);
_rtw_memcpy(attrib->dst, da, ETH_ALEN);
_rtw_memcpy(attrib->src, sa, ETH_ALEN);
attrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
rtw_list_insert_tail(&b2uframe->list, b2u_list);
}
exit:
return bmc_need;
}
void dump_mesh_b2u_flags(void *sel, _adapter *adapter)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
RTW_PRINT_SEL(sel, "%4s %4s\n", "msrc", "mfwd");
RTW_PRINT_SEL(sel, "0x%02x 0x%02x\n", mcfg->b2u_flags_msrc, mcfg->b2u_flags_mfwd);
}
#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
int rtw_mesh_addr_resolve(_adapter *adapter, struct xmit_frame *xframe, _pkt *pkt, _list *b2u_list)
{
struct pkt_file pktfile;
struct ethhdr etherhdr;
struct pkt_attrib *attrib;
struct rtw_mesh_path *mpath = NULL, *mppath = NULL;
u8 is_da_mcast;
u8 ae_need;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
bool bmc_need = _TRUE;
u8 b2u_num = 0;
u32 b2u_mseq = 0;
#endif
int res = _SUCCESS;
_rtw_open_pktfile(pkt, &pktfile);
if (_rtw_pktfile_read(&pktfile, (u8 *)ðerhdr, ETH_HLEN) != ETH_HLEN) {
res = _FAIL;
goto exit;
}
xframe->pkt = pkt;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
_rtw_init_listhead(b2u_list);
#endif
is_da_mcast = IS_MCAST(etherhdr.h_dest);
if (!is_da_mcast) {
struct sta_info *next_hop;
bool mpp_lookup = 1;
mpath = rtw_mesh_path_lookup(adapter, etherhdr.h_dest);
if (mpath) {
mpp_lookup = 0;
next_hop = rtw_rcu_dereference(mpath->next_hop);
if (!next_hop
|| !(mpath->flags & (RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVING))
) {
/* mpath is not valid, search mppath */
mpp_lookup = 1;
}
}
if (mpp_lookup) {
mppath = rtw_mpp_path_lookup(adapter, etherhdr.h_dest);
if (mppath)
mppath->exp_time = rtw_get_current_time();
}
if (mppath && mpath)
rtw_mesh_path_del(adapter, mpath->dst);
ae_need = _rtw_memcmp(adapter_mac_addr(adapter), etherhdr.h_source, ETH_ALEN) == _FALSE
|| (mppath && _rtw_memcmp(mppath->mpp, etherhdr.h_dest, ETH_ALEN) == _FALSE);
} else {
ae_need = _rtw_memcmp(adapter_mac_addr(adapter), etherhdr.h_source, ETH_ALEN) == _FALSE;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (rtw_msrc_b2u_policy_chk(adapter->mesh_cfg.b2u_flags_msrc, etherhdr.h_dest)) {
bmc_need = rtw_mesh_data_bmc_to_uc(adapter
, etherhdr.h_dest, etherhdr.h_source
, etherhdr.h_dest, adapter_mac_addr(adapter), ae_need, NULL, 0
, b2u_list, &b2u_num, &b2u_mseq);
if (bmc_need == _FALSE) {
res = RTW_BMC_NO_NEED;
goto exit;
}
}
#endif
}
attrib = &xframe->attrib;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (b2u_num) {
attrib->mb2u = 1;
attrib->mseq = b2u_mseq;
} else
attrib->mb2u = 0;
#endif
attrib->mfwd_ttl = 0;
_rtw_memcpy(attrib->dst, etherhdr.h_dest, ETH_ALEN);
_rtw_memcpy(attrib->src, etherhdr.h_source, ETH_ALEN);
_rtw_memcpy(attrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
if (is_da_mcast) {
attrib->mesh_frame_mode = ae_need ? MESH_BMCAST_PX_DATA : MESH_BMCAST_DATA;
_rtw_memcpy(attrib->ra, attrib->dst, ETH_ALEN);
_rtw_memcpy(attrib->msa, adapter_mac_addr(adapter), ETH_ALEN);
} else {
attrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
_rtw_memcpy(attrib->mda, (mppath && ae_need) ? mppath->mpp : attrib->dst, ETH_ALEN);
_rtw_memcpy(attrib->msa, adapter_mac_addr(adapter), ETH_ALEN);
/* RA needs to be resolved */
res = rtw_mesh_nexthop_resolve(adapter, xframe);
}
exit:
return res;
}
s8 rtw_mesh_tx_set_whdr_mctrl_len(u8 mesh_frame_mode, struct pkt_attrib *attrib)
{
u8 ret = 0;
switch (mesh_frame_mode) {
case MESH_UCAST_DATA:
attrib->hdrlen = WLAN_HDR_A4_QOS_LEN;
/* mesh flag + mesh TTL + Mesh SN. no ext addr. */
attrib->meshctrl_len = 6;
break;
case MESH_BMCAST_DATA:
attrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
/* mesh flag + mesh TTL + Mesh SN. no ext addr. */
attrib->meshctrl_len = 6;
break;
case MESH_UCAST_PX_DATA:
attrib->hdrlen = WLAN_HDR_A4_QOS_LEN;
/* mesh flag + mesh TTL + Mesh SN + extaddr1 + extaddr2. */
attrib->meshctrl_len = 18;
break;
case MESH_BMCAST_PX_DATA:
attrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
/* mesh flag + mesh TTL + Mesh SN + extaddr1 */
attrib->meshctrl_len = 12;
break;
default:
RTW_WARN("Invalid mesh frame mode:%u\n", mesh_frame_mode);
ret = -1;
break;
}
return ret;
}
void rtw_mesh_tx_build_mctrl(_adapter *adapter, struct pkt_attrib *attrib, u8 *buf)
{
struct rtw_ieee80211s_hdr *mctrl = (struct rtw_ieee80211s_hdr *)buf;
_rtw_memset(mctrl, 0, XATTRIB_GET_MCTRL_LEN(attrib));
if (attrib->mfwd_ttl
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
|| attrib->mb2u
#endif
) {
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (!attrib->mfwd_ttl)
mctrl->ttl = adapter->mesh_cfg.dot11MeshTTL;
else
#endif
mctrl->ttl = attrib->mfwd_ttl;
mctrl->seqnum = (cpu_to_le32(attrib->mseq));
} else {
mctrl->ttl = adapter->mesh_cfg.dot11MeshTTL;
mctrl->seqnum = (cpu_to_le32(adapter->mesh_info.mesh_seqnum));
adapter->mesh_info.mesh_seqnum++;
}
switch (attrib->mesh_frame_mode){
case MESH_UCAST_DATA:
case MESH_BMCAST_DATA:
break;
case MESH_UCAST_PX_DATA:
mctrl->flags |= MESH_FLAGS_AE_A5_A6;
_rtw_memcpy(mctrl->eaddr1, attrib->dst, ETH_ALEN);
_rtw_memcpy(mctrl->eaddr2, attrib->src, ETH_ALEN);
break;
case MESH_BMCAST_PX_DATA:
mctrl->flags |= MESH_FLAGS_AE_A4;
_rtw_memcpy(mctrl->eaddr1, attrib->src, ETH_ALEN);
break;
case MESH_MHOP_UCAST_ACT:
/* TBD */
break;
case MESH_MHOP_BMCAST_ACT:
/* TBD */
break;
default:
break;
}
}
u8 rtw_mesh_tx_build_whdr(_adapter *adapter, struct pkt_attrib *attrib
, u16 *fctrl, struct rtw_ieee80211_hdr *whdr)
{
switch (attrib->mesh_frame_mode) {
case MESH_UCAST_DATA: /* 1, 1, RA, TA, mDA(=DA), mSA(=SA) */
case MESH_UCAST_PX_DATA: /* 1, 1, RA, TA, mDA, mSA, [DA, SA] */
SetToDs(fctrl);
SetFrDs(fctrl);
_rtw_memcpy(whdr->addr1, attrib->ra, ETH_ALEN);
_rtw_memcpy(whdr->addr2, attrib->ta, ETH_ALEN);
_rtw_memcpy(whdr->addr3, attrib->mda, ETH_ALEN);
_rtw_memcpy(whdr->addr4, attrib->msa, ETH_ALEN);
break;
case MESH_BMCAST_DATA: /* 0, 1, RA(DA), TA, mSA(SA) */
case MESH_BMCAST_PX_DATA: /* 0, 1, RA(DA), TA, mSA, [SA] */
SetFrDs(fctrl);
_rtw_memcpy(whdr->addr1, attrib->ra, ETH_ALEN);
_rtw_memcpy(whdr->addr2, attrib->ta, ETH_ALEN);
_rtw_memcpy(whdr->addr3, attrib->msa, ETH_ALEN);
break;
case MESH_MHOP_UCAST_ACT:
/* TBD */
RTW_INFO("MESH_MHOP_UCAST_ACT\n");
break;
case MESH_MHOP_BMCAST_ACT:
/* TBD */
RTW_INFO("MESH_MHOP_BMCAST_ACT\n");
break;
default:
RTW_WARN("Invalid mesh frame mode\n");
break;
}
return 0;
}
int rtw_mesh_rx_data_validate_hdr(_adapter *adapter, union recv_frame *rframe, struct sta_info **sta)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
u8 *whdr = get_recvframe_data(rframe);
u8 is_ra_bmc = 0;
u8 a4_shift = 0;
u8 ps;
u8 *qc;
u8 mps_mode = RTW_MESH_PS_UNKNOWN;
sint ret = _FAIL;
if (!(MLME_STATE(adapter) & WIFI_ASOC_STATE))
goto exit;
if (!rattrib->qos)
goto exit;
switch (rattrib->to_fr_ds) {
case 1:
if (!IS_MCAST(GetAddr1Ptr(whdr)))
goto exit;
*sta = rtw_get_stainfo(stapriv, get_addr2_ptr(whdr));
if (*sta == NULL) {
ret = _SUCCESS; /* return _SUCCESS to drop at sta checking */
goto exit;
}
_rtw_memcpy(rattrib->ra, GetAddr1Ptr(whdr), ETH_ALEN);
_rtw_memcpy(rattrib->ta, get_addr2_ptr(whdr), ETH_ALEN);
_rtw_memcpy(rattrib->mda, GetAddr1Ptr(whdr), ETH_ALEN);
_rtw_memcpy(rattrib->msa, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
_rtw_memcpy(rattrib->dst, GetAddr1Ptr(whdr), ETH_ALEN);
_rtw_memcpy(rattrib->src, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
_rtw_memcpy(rattrib->bssid, get_addr2_ptr(whdr), ETH_ALEN);
is_ra_bmc = 1;
break;
case 3:
if (IS_MCAST(GetAddr1Ptr(whdr)))
goto exit;
*sta = rtw_get_stainfo(stapriv, get_addr2_ptr(whdr));
if (*sta == NULL) {
ret = _SUCCESS; /* return _SUCCESS to drop at sta checking */
goto exit;
}
_rtw_memcpy(rattrib->ra, GetAddr1Ptr(whdr), ETH_ALEN);
_rtw_memcpy(rattrib->ta, get_addr2_ptr(whdr), ETH_ALEN);
_rtw_memcpy(rattrib->mda, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
_rtw_memcpy(rattrib->msa, GetAddr4Ptr(whdr), ETH_ALEN); /* may change after checking AMSDU subframe header */
_rtw_memcpy(rattrib->dst, GetAddr3Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
_rtw_memcpy(rattrib->src, GetAddr4Ptr(whdr), ETH_ALEN); /* may change after checking mesh ctrl field */
_rtw_memcpy(rattrib->bssid, get_addr2_ptr(whdr), ETH_ALEN);
a4_shift = ETH_ALEN;
break;
default:
goto exit;
}
qc = whdr + WLAN_HDR_A3_LEN + a4_shift;
ps = GetPwrMgt(whdr);
mps_mode = ps ? (is_ra_bmc || (get_mps_lv(qc)) ? RTW_MESH_PS_DSLEEP : RTW_MESH_PS_LSLEEP) : RTW_MESH_PS_ACTIVE;
if (ps) {
if (!((*sta)->state & WIFI_SLEEP_STATE))
stop_sta_xmit(adapter, *sta);
} else {
if ((*sta)->state & WIFI_SLEEP_STATE)
wakeup_sta_to_xmit(adapter, *sta);
}
if (is_ra_bmc)
(*sta)->nonpeer_mps = mps_mode;
else {
(*sta)->peer_mps = mps_mode;
if (mps_mode != RTW_MESH_PS_ACTIVE && (*sta)->nonpeer_mps == RTW_MESH_PS_ACTIVE)
(*sta)->nonpeer_mps = RTW_MESH_PS_DSLEEP;
}
if (get_frame_sub_type(whdr) & BIT(6)) {
/* No data, will not indicate to upper layer, temporily count it here */
count_rx_stats(adapter, rframe, *sta);
ret = RTW_RX_HANDLED;
goto exit;
}
rattrib->mesh_ctrl_present = get_mctrl_present(qc) ? 1 : 0;
if (!rattrib->mesh_ctrl_present)
goto exit;
ret = _SUCCESS;
exit:
return ret;
}
int rtw_mesh_rx_data_validate_mctrl(_adapter *adapter, union recv_frame *rframe
, const struct rtw_ieee80211s_hdr *mctrl, const u8 *mda, const u8 *msa
, u8 *mctrl_len
, const u8 **da, const u8 **sa)
{
struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
u8 mlen;
u8 ae;
int ret = _SUCCESS;
ae = mctrl->flags & MESH_FLAGS_AE;
mlen = ae_to_mesh_ctrl_len[ae];
switch (rattrib->to_fr_ds) {
case 1:
*da = mda;
if (ae == MESH_FLAGS_AE_A4)
*sa = mctrl->eaddr1;
else if (ae == 0)
*sa = msa;
else
ret = _FAIL;
break;
case 3:
if (ae == MESH_FLAGS_AE_A5_A6) {
*da = mctrl->eaddr1;
*sa = mctrl->eaddr2;
} else if (ae == 0) {
*da = mda;
*sa = msa;
} else
ret = _FAIL;
break;
default:
ret = _FAIL;
}
if (ret == _FAIL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" invalid tfDS:%u AE:%u combination ra="MAC_FMT" ta="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), rattrib->to_fr_ds, ae, MAC_ARG(rattrib->ra), MAC_ARG(rattrib->ta));
#endif
*mctrl_len = 0;
} else
*mctrl_len = mlen;
return ret;
}
inline int rtw_mesh_rx_validate_mctrl_non_amsdu(_adapter *adapter, union recv_frame *rframe)
{
struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
const u8 *da, *sa;
int ret;
ret = rtw_mesh_rx_data_validate_mctrl(adapter, rframe
, (struct rtw_ieee80211s_hdr *)(get_recvframe_data(rframe) + rattrib->hdrlen + rattrib->iv_len)
, rattrib->mda, rattrib->msa
, &rattrib->mesh_ctrl_len
, &da, &sa);
if (ret == _SUCCESS) {
_rtw_memcpy(rattrib->dst, da, ETH_ALEN);
_rtw_memcpy(rattrib->src, sa, ETH_ALEN);
}
return ret;
}
/**
* rtw_mesh_rx_nexthop_resolve - lookup next hop; conditionally start path discovery
*
* @skb: 802.11 frame to be sent
* @sdata: network subif the frame will be sent through
*
* Lookup next hop for given skb and start path discovery if no
* forwarding information is found.
*
* Returns: 0 if the next hop was found and -ENOENT if the frame was queued.
* skb is freeed here if no mpath could be allocated.
*/
static int rtw_mesh_rx_nexthop_resolve(_adapter *adapter,
const u8 *mda, const u8 *msa, u8 *ra)
{
struct rtw_mesh_path *mpath;
struct xmit_frame *xframe_to_free = NULL;
int err = 0;
int ret = _SUCCESS;
rtw_rcu_read_lock();
err = rtw_mesh_nexthop_lookup(adapter, mda, msa, ra);
if (!err)
goto endlookup;
/* no nexthop found, start resolving */
mpath = rtw_mesh_path_lookup(adapter, mda);
if (!mpath) {
mpath = rtw_mesh_path_add(adapter, mda);
if (IS_ERR(mpath)) {
err = PTR_ERR(mpath);
ret = _FAIL;
goto endlookup;
}
}
if (!(mpath->flags & RTW_MESH_PATH_RESOLVING))
rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START);
ret = _FAIL;
endlookup:
rtw_rcu_read_unlock();
return ret;
}
#define RTW_MESH_DECACHE_BMC 1
#define RTW_MESH_DECACHE_UC 0
#define RTW_MESH_FORWARD_MDA_SELF_COND 0
#define DBG_RTW_MESH_FORWARD_MDA_SELF_COND 0
int rtw_mesh_rx_msdu_act_check(union recv_frame *rframe
, const u8 *mda, const u8 *msa
, const u8 *da, const u8 *sa
, struct rtw_ieee80211s_hdr *mctrl
, struct xmit_frame **fwd_frame, _list *b2u_list)
{
_adapter *adapter = rframe->u.hdr.adapter;
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rx_pkt_attrib *rattrib = &rframe->u.hdr.attrib;
struct rtw_mesh_path *mppath;
u8 is_mda_bmc = IS_MCAST(mda);
u8 is_mda_self = !is_mda_bmc && _rtw_memcmp(mda, adapter_mac_addr(adapter), ETH_ALEN);
struct xmit_frame *xframe;
struct pkt_attrib *xattrib;
u8 fwd_ra[ETH_ALEN] = {0};
u8 fwd_mpp[ETH_ALEN] = {0}; /* forward to other gate */
u32 fwd_mseq;
int act = 0;
u8 ae_need;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
bool bmc_need = _TRUE;
u8 b2u_num = 0;
#endif
/* fwd info lifetime update */
#if 0
if (!is_mda_self)
mDA(A3) fwinfo.lifetime
mSA(A4) fwinfo.lifetime
Precursor-to-mDA(A2) fwinfo.lifetime
#endif
/* update/create pxoxy info for SA, mSA */
if ((mctrl->flags & MESH_FLAGS_AE)
&& sa != msa && _rtw_memcmp(sa, msa, ETH_ALEN) == _FALSE
) {
const u8 *proxied_addr = sa;
const u8 *mpp_addr = msa;
rtw_rcu_read_lock();
mppath = rtw_mpp_path_lookup(adapter, proxied_addr);
if (!mppath)
rtw_mpp_path_add(adapter, proxied_addr, mpp_addr);
else {
enter_critical_bh(&mppath->state_lock);
if (_rtw_memcmp(mppath->mpp, mpp_addr, ETH_ALEN) == _FALSE)
_rtw_memcpy(mppath->mpp, mpp_addr, ETH_ALEN);
mppath->exp_time = rtw_get_current_time();
exit_critical_bh(&mppath->state_lock);
}
rtw_rcu_read_unlock();
}
/* mSA is self, need no further process */
if (_rtw_memcmp(msa, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
goto exit;
fwd_mseq = le32_to_cpu(mctrl->seqnum);
/* check duplicate MSDU from mSA */
if (((RTW_MESH_DECACHE_BMC && is_mda_bmc)
|| (RTW_MESH_DECACHE_UC && !is_mda_bmc))
&& rtw_mesh_decache(adapter, msa, fwd_mseq)
) {
minfo->mshstats.dropped_frames_duplicate++;
goto exit;
}
if (is_mda_bmc) {
/* mDA is bmc addr */
act |= RTW_RX_MSDU_ACT_INDICATE;
if (!mcfg->dot11MeshForwarding)
goto exit;
goto fwd_chk;
} else if (!is_mda_self) {
/* mDA is unicast but not self */
if (!mcfg->dot11MeshForwarding) {
rtw_mesh_path_error_tx(adapter
, adapter->mesh_cfg.element_ttl
, mda, 0
, WLAN_REASON_MESH_PATH_NOFORWARD
, rattrib->ta
);
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" mDA("MAC_FMT") not self, !dot11MeshForwarding\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(mda));
#endif
goto exit;
}
if (rtw_mesh_rx_nexthop_resolve(adapter, mda, msa, fwd_ra) != _SUCCESS) {
/* mDA is unknown */
rtw_mesh_path_error_tx(adapter
, adapter->mesh_cfg.element_ttl
, mda, 0
, WLAN_REASON_MESH_PATH_NOFORWARD
, rattrib->ta
);
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" mDA("MAC_FMT") unknown\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(mda));
#endif
minfo->mshstats.dropped_frames_no_route++;
goto exit;
} else {
/* mDA is known in fwd info */
#if 0
if (TA is not in precursors)
goto exit;
#endif
goto fwd_chk;
}
} else {
/* mDA is self */
#if RTW_MESH_FORWARD_MDA_SELF_COND
if (da == mda
|| _rtw_memcmp(da, adapter_mac_addr(adapter), ETH_ALEN)
) {
/* DA is self, indicate */
act |= RTW_RX_MSDU_ACT_INDICATE;
goto exit;
}
if (rtw_get_iface_by_macddr(adapter, da)) {
/* DA is buddy, indicate */
act |= RTW_RX_MSDU_ACT_INDICATE;
#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is buddy("ADPT_FMT")\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da), ADPT_ARG(rtw_get_iface_by_macddr(adapter, da)));
#endif
goto exit;
}
/* DA is not self or buddy */
if (rtw_mesh_nexthop_lookup(adapter, da, msa, fwd_ra) == 0) {
/* DA is known in fwd info */
if (!mcfg->dot11MeshForwarding) {
/* path error to? */
#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") not self, !dot11MeshForwarding\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
#endif
goto exit;
}
mda = da;
#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO(FUNC_ADPT_FMT" fwd to DA("MAC_FMT"), fwd_RA("MAC_FMT")\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(fwd_ra));
#endif
goto fwd_chk;
}
rtw_rcu_read_lock();
mppath = rtw_mpp_path_lookup(adapter, da);
if (mppath) {
if (_rtw_memcmp(mppath->mpp, adapter_mac_addr(adapter), ETH_ALEN) == _FALSE) {
/* DA is proxied by others */
if (!mcfg->dot11MeshForwarding) {
/* path error to? */
#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), !dot11MeshForwarding\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp));
#endif
rtw_rcu_read_unlock();
goto exit;
}
_rtw_memcpy(fwd_mpp, mppath->mpp, ETH_ALEN);
mda = fwd_mpp;
msa = adapter_mac_addr(adapter);
rtw_rcu_read_unlock();
/* resolve RA */
if (rtw_mesh_nexthop_lookup(adapter, mda, msa, fwd_ra) != 0) {
minfo->mshstats.dropped_frames_no_route++;
#if defined(DBG_RX_DROP_FRAME) || DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), RA resolve fail\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp));
#endif
goto exit;
}
#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by ("MAC_FMT"), fwd_RA("MAC_FMT")\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da), MAC_ARG(mppath->mpp), MAC_ARG(fwd_ra));
#endif
goto fwd_chk; /* forward to other gate */
} else {
#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") is proxied by self\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
#endif
}
}
rtw_rcu_read_unlock();
if (!mppath) {
#if DBG_RTW_MESH_FORWARD_MDA_SELF_COND
RTW_INFO(FUNC_ADPT_FMT" DA("MAC_FMT") unknown\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(da));
#endif
/* DA is unknown */
#if 0 /* TODO: flags with AE bit */
rtw_mesh_path_error_tx(adapter
, adapter->mesh_cfg.element_ttl
, mda, adapter->mesh_info.last_sn_update
, WLAN_REASON_MESH_PATH_NOPROXY
, msa
);
#endif
}
/*
* indicate to DS for both cases:
* 1.) DA is proxied by self
* 2.) DA is unknown
*/
#endif /* RTW_MESH_FORWARD_MDA_SELF_COND */
act |= RTW_RX_MSDU_ACT_INDICATE;
goto exit;
}
fwd_chk:
if (adapter->stapriv.asoc_list_cnt <= 1)
goto exit;
if (mctrl->ttl == 1) {
minfo->mshstats.dropped_frames_ttl++;
if (!act) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" ttl reaches 0, not forwarding\n"
, FUNC_ADPT_ARG(adapter));
#endif
}
goto exit;
}
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
_rtw_init_listhead(b2u_list);
#endif
ae_need = _rtw_memcmp(da , mda, ETH_ALEN) == _FALSE
|| _rtw_memcmp(sa , msa, ETH_ALEN) == _FALSE;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (is_mda_bmc
&& rtw_mfwd_b2u_policy_chk(mcfg->b2u_flags_mfwd, mda, rattrib->to_fr_ds == 3)
) {
bmc_need = rtw_mesh_data_bmc_to_uc(adapter
, da, sa, mda, msa, ae_need, rframe->u.hdr.psta->cmn.mac_addr, mctrl->ttl - 1
, b2u_list, &b2u_num, &fwd_mseq);
}
if (bmc_need == _TRUE)
#endif
{
xframe = rtw_alloc_xmitframe(&adapter->xmitpriv);
if (!xframe) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME "FUNC_ADPT_FMT" rtw_alloc_xmitframe fail\n"
, FUNC_ADPT_ARG(adapter));
#endif
goto exit;
}
xattrib = &xframe->attrib;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (b2u_num)
xattrib->mb2u = 1;
else
xattrib->mb2u = 0;
#endif
xattrib->mfwd_ttl = mctrl->ttl - 1;
xattrib->mseq = fwd_mseq;
_rtw_memcpy(xattrib->dst, da, ETH_ALEN);
_rtw_memcpy(xattrib->src, sa, ETH_ALEN);
_rtw_memcpy(xattrib->mda, mda, ETH_ALEN);
_rtw_memcpy(xattrib->msa, msa, ETH_ALEN);
_rtw_memcpy(xattrib->ta, adapter_mac_addr(adapter), ETH_ALEN);
if (is_mda_bmc) {
xattrib->mesh_frame_mode = ae_need ? MESH_BMCAST_PX_DATA : MESH_BMCAST_DATA;
_rtw_memcpy(xattrib->ra, mda, ETH_ALEN);
} else {
xattrib->mesh_frame_mode = ae_need ? MESH_UCAST_PX_DATA : MESH_UCAST_DATA;
_rtw_memcpy(xattrib->ra, fwd_ra, ETH_ALEN);
}
*fwd_frame = xframe;
}
act |= RTW_RX_MSDU_ACT_FORWARD;
if (is_mda_bmc)
minfo->mshstats.fwded_mcast++;
else
minfo->mshstats.fwded_unicast++;
minfo->mshstats.fwded_frames++;
exit:
return act;
}
void dump_mesh_stats(void *sel, _adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mesh_stats *stats = &minfo->mshstats;
RTW_PRINT_SEL(sel, "fwd_bmc:%u\n", stats->fwded_mcast);
RTW_PRINT_SEL(sel, "fwd_uc:%u\n", stats->fwded_unicast);
RTW_PRINT_SEL(sel, "drop_ttl:%u\n", stats->dropped_frames_ttl);
RTW_PRINT_SEL(sel, "drop_no_route:%u\n", stats->dropped_frames_no_route);
RTW_PRINT_SEL(sel, "drop_congestion:%u\n", stats->dropped_frames_congestion);
RTW_PRINT_SEL(sel, "drop_dup:%u\n", stats->dropped_frames_duplicate);
RTW_PRINT_SEL(sel, "mrc_del_qlen:%u\n", stats->mrc_del_qlen);
}
#endif /* CONFIG_RTW_MESH */
================================================
FILE: core/mesh/rtw_mesh.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __RTW_MESH_H_
#define __RTW_MESH_H_
#ifndef CONFIG_AP_MODE
#error "CONFIG_RTW_MESH can't be enabled when CONFIG_AP_MODE is not defined\n"
#endif
#define RTW_MESH_TTL 31
#define RTW_MESH_PERR_MIN_INT 100
#define RTW_MESH_DEFAULT_ELEMENT_TTL 31
#define RTW_MESH_RANN_INTERVAL 5000
#define RTW_MESH_PATH_TO_ROOT_TIMEOUT 6000
#define RTW_MESH_DIAM_TRAVERSAL_TIME 50
#define RTW_MESH_PATH_TIMEOUT 5000
#define RTW_MESH_PREQ_MIN_INT 10
#define RTW_MESH_MAX_PREQ_RETRIES 4
#define RTW_MESH_MIN_DISCOVERY_TIMEOUT (2 * RTW_MESH_DIAM_TRAVERSAL_TIME)
#define RTW_MESH_ROOT_CONFIRMATION_INTERVAL 2000
#define RTW_MESH_PATH_REFRESH_TIME 1000
#define RTW_MESH_ROOT_INTERVAL 5000
#define RTW_MESH_SANE_METRIC_DELTA 100
#define RTW_MESH_MAX_ROOT_ADD_CHK_CNT 2
#define RTW_MESH_PLINK_UNKNOWN 0
#define RTW_MESH_PLINK_LISTEN 1
#define RTW_MESH_PLINK_OPN_SNT 2
#define RTW_MESH_PLINK_OPN_RCVD 3
#define RTW_MESH_PLINK_CNF_RCVD 4
#define RTW_MESH_PLINK_ESTAB 5
#define RTW_MESH_PLINK_HOLDING 6
#define RTW_MESH_PLINK_BLOCKED 7
extern const char *_rtw_mesh_plink_str[];
#define rtw_mesh_plink_str(s) ((s <= RTW_MESH_PLINK_BLOCKED) ? _rtw_mesh_plink_str[s] : _rtw_mesh_plink_str[RTW_MESH_PLINK_UNKNOWN])
#define RTW_MESH_PS_UNKNOWN 0
#define RTW_MESH_PS_ACTIVE 1
#define RTW_MESH_PS_LSLEEP 2
#define RTW_MESH_PS_DSLEEP 3
extern const char *_rtw_mesh_ps_str[];
#define rtw_mesh_ps_str(mps) ((mps <= RTW_MESH_PS_DSLEEP) ? _rtw_mesh_ps_str[mps] : _rtw_mesh_ps_str[RTW_MESH_PS_UNKNOWN])
#define GET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 0, 0, 8)
#define GET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 1, 0, 8)
#define GET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 2, 0, 8)
#define GET_MESH_CONF_ELE_SYNC_METHOD_ID(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 3, 0, 8)
#define GET_MESH_CONF_ELE_AUTH_PROTO_ID(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 4, 0, 8)
#define GET_MESH_CONF_ELE_MESH_FORMATION(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 0, 8)
#define GET_MESH_CONF_ELE_CTO_MGATE(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 0, 1)
#define GET_MESH_CONF_ELE_NUM_OF_PEERINGS(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 1, 6)
#define GET_MESH_CONF_ELE_CTO_AS(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 5, 7, 1)
#define GET_MESH_CONF_ELE_MESH_CAP(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 0, 8)
#define GET_MESH_CONF_ELE_ACCEPT_PEERINGS(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 0, 1)
#define GET_MESH_CONF_ELE_MCCA_SUP(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 1, 1)
#define GET_MESH_CONF_ELE_MCCA_EN(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 2, 1)
#define GET_MESH_CONF_ELE_FORWARDING(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 3, 1)
#define GET_MESH_CONF_ELE_MBCA_EN(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 4, 1)
#define GET_MESH_CONF_ELE_TBTT_ADJ(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 5, 1)
#define GET_MESH_CONF_ELE_PS_LEVEL(_iec) LE_BITS_TO_1BYTE(((u8 *)(_iec)) + 6, 6, 1)
#define SET_MESH_CONF_ELE_PATH_SEL_PROTO_ID(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 0, 0, 8, _val)
#define SET_MESH_CONF_ELE_PATH_SEL_METRIC_ID(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 1, 0, 8, _val)
#define SET_MESH_CONF_ELE_CONGEST_CTRL_MODE_ID(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 2, 0, 8, _val)
#define SET_MESH_CONF_ELE_SYNC_METHOD_ID(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 3, 0, 8, _val)
#define SET_MESH_CONF_ELE_AUTH_PROTO_ID(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 4, 0, 8, _val)
#define SET_MESH_CONF_ELE_CTO_MGATE(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 0, 1, _val)
#define SET_MESH_CONF_ELE_NUM_OF_PEERINGS(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 1, 6, _val)
#define SET_MESH_CONF_ELE_CTO_AS(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 5, 7, 1, _val)
#define SET_MESH_CONF_ELE_ACCEPT_PEERINGS(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 0, 1, _val)
#define SET_MESH_CONF_ELE_MCCA_SUP(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 1, 1, _val)
#define SET_MESH_CONF_ELE_MCCA_EN(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 2, 1, _val)
#define SET_MESH_CONF_ELE_FORWARDING(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 3, 1, _val)
#define SET_MESH_CONF_ELE_MBCA_EN(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 4, 1, _val)
#define SET_MESH_CONF_ELE_TBTT_ADJ(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 5, 1, _val)
#define SET_MESH_CONF_ELE_PS_LEVEL(_iec, _val) SET_BITS_TO_LE_1BYTE(((u8 *)(_iec)) + 6, 6, 1, _val)
/* Mesh flags */
#define MESH_FLAGS_AE 0x3 /* mask */
#define MESH_FLAGS_AE_A4 0x1
#define MESH_FLAGS_AE_A5_A6 0x2
/* Max number of paths */
#define RTW_MESH_MAX_PATHS 1024
#define RTW_PREQ_Q_F_START 0x1
#define RTW_PREQ_Q_F_REFRESH 0x2
#define RTW_PREQ_Q_F_CHK 0x4
#define RTW_PREQ_Q_F_PEER_AKA 0x8
#define RTW_PREQ_Q_F_BCAST_PREQ 0x10 /* force path_dicover using broadcast */
struct rtw_mesh_preq_queue {
_list list;
u8 dst[ETH_ALEN];
u8 flags;
};
extern const u8 ae_to_mesh_ctrl_len[];
enum mesh_frame_type {
MESH_UCAST_DATA = 0x0,
MESH_BMCAST_DATA = 0x1,
MESH_UCAST_PX_DATA = 0x2,
MESH_BMCAST_PX_DATA = 0x3,
MESH_MHOP_UCAST_ACT = 0x4,
MESH_MHOP_BMCAST_ACT = 0x5,
};
enum mpath_sel_frame_type {
MPATH_PREQ = 0,
MPATH_PREP,
MPATH_PERR,
MPATH_RANN
};
/**
* enum rtw_mesh_deferred_task_flags - mesh deferred tasks
*
*
*
* @RTW_MESH_WORK_HOUSEKEEPING: run the periodic mesh housekeeping tasks
* @RTW_MESH_WORK_ROOT: the mesh root station needs to send a frame
* @RTW_MESH_WORK_DRIFT_ADJUST: time to compensate for clock drift relative to other
* mesh nodes
* @RTW_MESH_WORK_MBSS_CHANGED: rebuild beacon and notify driver of BSS changes
*/
enum rtw_mesh_deferred_task_flags {
RTW_MESH_WORK_HOUSEKEEPING,
RTW_MESH_WORK_ROOT,
RTW_MESH_WORK_DRIFT_ADJUST,
RTW_MESH_WORK_MBSS_CHANGED,
};
#define RTW_MESH_MAX_PEER_CANDIDATES 15 /* aid consideration */
#define RTW_MESH_MAX_PEER_LINKS 8
#define RTW_MESH_PEER_LINK_TIMEOUT 20
#define RTW_MESH_PEER_CONF_DISABLED 0 /* special time value means no confirmation ongoing */
#if CONFIG_RTW_MESH_PEER_BLACKLIST
#define IS_PEER_CONF_DISABLED(plink) ((plink)->peer_conf_end_time == RTW_MESH_PEER_CONF_DISABLED)
#define IS_PEER_CONF_TIMEOUT(plink)(!IS_PEER_CONF_DISABLED(plink) && rtw_time_after(rtw_get_current_time(), (plink)->peer_conf_end_time))
#define SET_PEER_CONF_DISABLED(plink) (plink)->peer_conf_end_time = RTW_MESH_PEER_CONF_DISABLED
#define SET_PEER_CONF_END_TIME(plink, timeout_ms) \
do { \
(plink)->peer_conf_end_time = rtw_get_current_time() + rtw_ms_to_systime(timeout_ms); \
if ((plink)->peer_conf_end_time == RTW_MESH_PEER_CONF_DISABLED) \
(plink)->peer_conf_end_time++; \
} while (0)
#else
#define IS_PEER_CONF_DISABLED(plink) 1
#define IS_PEER_CONF_TIMEOUT(plink) 0
#define SET_PEER_CONF_DISABLED(plink) do {} while (0)
#define SET_PEER_CONF_END_TIME(plink, timeout_ms) do {} while (0)
#endif /* CONFIG_RTW_MESH_PEER_BLACKLIST */
#define RTW_MESH_CTO_MGATE_CONF_DISABLED 0 /* special time value means no confirmation ongoing */
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
#define IS_CTO_MGATE_CONF_DISABLED(plink) ((plink)->cto_mgate_conf_end_time == RTW_MESH_CTO_MGATE_CONF_DISABLED)
#define IS_CTO_MGATE_CONF_TIMEOUT(plink)(!IS_CTO_MGATE_CONF_DISABLED(plink) && rtw_time_after(rtw_get_current_time(), (plink)->cto_mgate_conf_end_time))
#define SET_CTO_MGATE_CONF_DISABLED(plink) (plink)->cto_mgate_conf_end_time = RTW_MESH_CTO_MGATE_CONF_DISABLED
#define SET_CTO_MGATE_CONF_END_TIME(plink, timeout_ms) \
do { \
(plink)->cto_mgate_conf_end_time = rtw_get_current_time() + rtw_ms_to_systime(timeout_ms); \
if ((plink)->cto_mgate_conf_end_time == RTW_MESH_CTO_MGATE_CONF_DISABLED) \
(plink)->cto_mgate_conf_end_time++; \
} while (0)
#else
#define IS_CTO_MGATE_CONF_DISABLED(plink) 1
#define IS_CTO_MGATE_CONF_TIMEOUT(plink) 0
#define SET_CTO_MGATE_CONF_DISABLED(plink) do {} while (0)
#define SET_CTO_MGATE_CONF_END_TIME(plink, timeout_ms) do {} while (0)
#endif /* CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST */
struct mesh_plink_ent {
u8 valid;
u8 addr[ETH_ALEN];
u8 plink_state;
#ifdef CONFIG_RTW_MESH_AEK
u8 aek_valid;
u8 aek[32];
#endif
u16 llid;
u16 plid;
#ifndef CONFIG_RTW_MESH_DRIVER_AID
u16 aid; /* aid assigned from upper layer */
#endif
u16 peer_aid; /* aid assigned from peer */
u8 chosen_pmk[16];
#ifdef CONFIG_RTW_MESH_AEK
u8 sel_pcs[4];
u8 l_nonce[32];
u8 p_nonce[32];
#endif
#ifdef CONFIG_RTW_MESH_DRIVER_AID
u8 *tx_conf_ies;
u16 tx_conf_ies_len;
#endif
u8 *rx_conf_ies;
u16 rx_conf_ies_len;
struct wlan_network *scanned;
#if CONFIG_RTW_MESH_PEER_BLACKLIST
systime peer_conf_end_time;
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
systime cto_mgate_conf_end_time;
#endif
};
#ifdef CONFIG_RTW_MESH_AEK
#define MESH_PLINK_AEK_VALID(ent) ent->aek_valid
#else
#define MESH_PLINK_AEK_VALID(ent) 0
#endif
struct mesh_plink_pool {
_lock lock;
u8 num; /* current ent being used */
struct mesh_plink_ent ent[RTW_MESH_MAX_PEER_CANDIDATES];
#if CONFIG_RTW_MESH_ACNODE_PREVENT
u8 acnode_rsvd;
#endif
#if CONFIG_RTW_MESH_PEER_BLACKLIST
_queue peer_blacklist;
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
_queue cto_mgate_blacklist;
#endif
};
struct mesh_peer_sel_policy {
u32 scanr_exp_ms;
#if CONFIG_RTW_MESH_ACNODE_PREVENT
u8 acnode_prevent;
u32 acnode_conf_timeout_ms;
u32 acnode_notify_timeout_ms;
#endif
#if CONFIG_RTW_MESH_OFFCH_CAND
u8 offch_cand;
u32 offch_find_int_ms; /* 0 means no offch find triggerred by driver self*/
#endif
#if CONFIG_RTW_MESH_PEER_BLACKLIST
u32 peer_conf_timeout_ms;
u32 peer_blacklist_timeout_ms;
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
u8 cto_mgate_require;
u32 cto_mgate_conf_timeout_ms;
u32 cto_mgate_blacklist_timeout_ms;
#endif
};
/* b2u flags */
#define RTW_MESH_B2U_ALL BIT0
#define RTW_MESH_B2U_GA_UCAST BIT1 /* Group addressed unicast frame, forward only */
#define RTW_MESH_B2U_BCAST BIT2
#define RTW_MESH_B2U_IP_MCAST BIT3
#define rtw_msrc_b2u_policy_chk(flags, mda) ( \
(flags & RTW_MESH_B2U_ALL) \
|| ((flags & RTW_MESH_B2U_BCAST) && is_broadcast_mac_addr(mda)) \
|| ((flags & RTW_MESH_B2U_IP_MCAST) && (IP_MCAST_MAC(mda) || ICMPV6_MCAST_MAC(mda))) \
)
#define rtw_mfwd_b2u_policy_chk(flags, mda, ucst) ( \
(flags & RTW_MESH_B2U_ALL) \
|| ((flags & RTW_MESH_B2U_GA_UCAST) && ucst) \
|| ((flags & RTW_MESH_B2U_BCAST) && is_broadcast_mac_addr(mda)) \
|| ((flags & RTW_MESH_B2U_IP_MCAST) && (IP_MCAST_MAC(mda) || ICMPV6_MCAST_MAC(mda))) \
)
/**
* @sane_metric_delta: Controlling if trigger additional path check mechanism
* @max_root_add_chk_cnt: The retry cnt to send additional root confirmation
* PREQ through old(last) path
*/
struct rtw_mesh_cfg {
u8 max_peer_links; /* peering limit */
u32 plink_timeout; /* seconds */
u8 dot11MeshTTL;
u8 element_ttl;
u32 path_refresh_time;
u16 dot11MeshHWMPpreqMinInterval;
u16 dot11MeshHWMPnetDiameterTraversalTime;
u32 dot11MeshHWMPactivePathTimeout;
u8 dot11MeshHWMPmaxPREQretries;
u16 min_discovery_timeout;
u16 dot11MeshHWMPconfirmationInterval;
u16 dot11MeshHWMPperrMinInterval;
u8 dot11MeshHWMPRootMode;
BOOLEAN dot11MeshForwarding;
s32 rssi_threshold; /* in dBm, 0: no specified */
u16 dot11MeshHWMPRannInterval;
BOOLEAN dot11MeshGateAnnouncementProtocol;
u32 dot11MeshHWMPactivePathToRootTimeout;
u16 dot11MeshHWMProotInterval;
u8 path_gate_timeout_factor;
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
u16 sane_metric_delta;
u8 max_root_add_chk_cnt;
#endif
struct mesh_peer_sel_policy peer_sel_policy;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
u8 b2u_flags_msrc;
u8 b2u_flags_mfwd;
#endif
};
struct rtw_mesh_stats {
u32 fwded_mcast; /* Mesh forwarded multicast frames */
u32 fwded_unicast; /* Mesh forwarded unicast frames */
u32 fwded_frames; /* Mesh total forwarded frames */
u32 dropped_frames_ttl; /* Not transmitted since mesh_ttl == 0*/
u32 dropped_frames_no_route; /* Not transmitted, no route found */
u32 dropped_frames_congestion;/* Not forwarded due to congestion */
u32 dropped_frames_duplicate;
u32 mrc_del_qlen; /* MRC entry deleted cause by queue length limit */
};
struct rtw_mrc;
struct rtw_mesh_info {
u8 mesh_id[NDIS_802_11_LENGTH_SSID];
size_t mesh_id_len;
/* Active Path Selection Protocol Identifier */
u8 mesh_pp_id;
/* Active Path Selection Metric Identifier */
u8 mesh_pm_id;
/* Congestion Control Mode Identifier */
u8 mesh_cc_id;
/* Synchronization Protocol Identifier */
u8 mesh_sp_id;
/* Authentication Protocol Identifier */
u8 mesh_auth_id;
struct mesh_plink_pool plink_ctl;
u32 mesh_seqnum;
/* MSTA's own hwmp sequence number */
u32 sn;
systime last_preq;
systime last_sn_update;
systime next_perr;
/* Last used Path Discovery ID */
u32 preq_id;
ATOMIC_T mpaths;
struct rtw_mesh_table *mesh_paths;
struct rtw_mesh_table *mpp_paths;
int mesh_paths_generation;
int mpp_paths_generation;
int num_gates;
struct rtw_mesh_path *max_addr_gate;
bool max_addr_gate_is_larger_than_self;
struct rtw_mesh_stats mshstats;
_queue mpath_tx_queue;
u32 mpath_tx_queue_len;
_tasklet mpath_tx_tasklet;
struct rtw_mrc *mrc;
_lock mesh_preq_queue_lock;
struct rtw_mesh_preq_queue preq_queue;
int preq_queue_len;
};
extern const char *_action_self_protected_str[];
#define action_self_protected_str(action) ((action < RTW_ACT_SELF_PROTECTED_NUM) ? _action_self_protected_str[action] : _action_self_protected_str[0])
u8 *rtw_set_ie_mesh_id(u8 *buf, u32 *buf_len, const char *mesh_id, u8 id_len);
u8 *rtw_set_ie_mesh_config(u8 *buf, u32 *buf_len
, u8 path_sel_proto, u8 path_sel_metric, u8 congest_ctl_mode, u8 sync_method, u8 auth_proto
, u8 num_of_peerings, bool cto_mgate, bool cto_as
, bool accept_peerings, bool mcca_sup, bool mcca_en, bool forwarding
, bool mbca_en, bool tbtt_adj, bool ps_level);
int rtw_bss_is_same_mbss(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b);
int rtw_bss_is_candidate_mesh_peer(WLAN_BSSID_EX *self, WLAN_BSSID_EX *target, u8 ch, u8 add_peer);
void rtw_chk_candidate_peer_notify(_adapter *adapter, struct wlan_network *scanned);
void rtw_mesh_peer_status_chk(_adapter *adapter);
#if CONFIG_RTW_MESH_ACNODE_PREVENT
void rtw_mesh_update_scanned_acnode_status(_adapter *adapter, struct wlan_network *scanned);
bool rtw_mesh_scanned_is_acnode_confirmed(_adapter *adapter, struct wlan_network *scanned);
bool rtw_mesh_acnode_prevent_allow_sacrifice(_adapter *adapter);
struct sta_info *rtw_mesh_acnode_prevent_pick_sacrifice(_adapter *adapter);
void dump_mesh_acnode_prevent_settings(void *sel, _adapter *adapter);
#endif
#if CONFIG_RTW_MESH_OFFCH_CAND
u8 rtw_mesh_offch_candidate_accepted(_adapter *adapter);
u8 rtw_mesh_select_operating_ch(_adapter *adapter);
void dump_mesh_offch_cand_settings(void *sel, _adapter *adapter);
#endif
#if CONFIG_RTW_MESH_PEER_BLACKLIST
int rtw_mesh_peer_blacklist_add(_adapter *adapter, const u8 *addr);
int rtw_mesh_peer_blacklist_del(_adapter *adapter, const u8 *addr);
int rtw_mesh_peer_blacklist_search(_adapter *adapter, const u8 *addr);
void rtw_mesh_peer_blacklist_flush(_adapter *adapter);
void dump_mesh_peer_blacklist(void *sel, _adapter *adapter);
void dump_mesh_peer_blacklist_settings(void *sel, _adapter *adapter);
#endif
#if CONFIG_RTW_MESH_CTO_MGATE_BLACKLIST
u8 rtw_mesh_cto_mgate_required(_adapter *adapter);
u8 rtw_mesh_cto_mgate_network_filter(_adapter *adapter, struct wlan_network *scanned);
int rtw_mesh_cto_mgate_blacklist_add(_adapter *adapter, const u8 *addr);
int rtw_mesh_cto_mgate_blacklist_del(_adapter *adapter, const u8 *addr);
int rtw_mesh_cto_mgate_blacklist_search(_adapter *adapter, const u8 *addr);
void rtw_mesh_cto_mgate_blacklist_flush(_adapter *adapter);
void dump_mesh_cto_mgate_blacklist(void *sel, _adapter *adapter);
void dump_mesh_cto_mgate_blacklist_settings(void *sel, _adapter *adapter);
#endif
void dump_mesh_peer_sel_policy(void *sel, _adapter *adapter);
void dump_mesh_networks(void *sel, _adapter *adapter);
void rtw_mesh_adjust_chbw(u8 req_ch, u8 *req_bw, u8 *req_offset);
void rtw_mesh_sae_check_frames(_adapter *adapter, const u8 *buf, u32 len, u8 tx, u16 alg, u16 seq, u16 status);
int rtw_mesh_check_frames_tx(_adapter *adapter, const u8 **buf, size_t *len);
int rtw_mesh_check_frames_rx(_adapter *adapter, const u8 *buf, size_t len);
int rtw_mesh_on_auth(_adapter *adapter, union recv_frame *rframe);
unsigned int on_action_self_protected(_adapter *adapter, union recv_frame *rframe);
bool rtw_mesh_update_bss_peering_status(_adapter *adapter, WLAN_BSSID_EX *bss);
bool rtw_mesh_update_bss_formation_info(_adapter *adapter, WLAN_BSSID_EX *bss);
bool rtw_mesh_update_bss_forwarding_state(_adapter *adapter, WLAN_BSSID_EX *bss);
struct mesh_plink_ent *_rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr);
struct mesh_plink_ent *rtw_mesh_plink_get(_adapter *adapter, const u8 *hwaddr);
struct mesh_plink_ent *rtw_mesh_plink_get_no_estab_by_idx(_adapter *adapter, u8 idx);
int _rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr);
int rtw_mesh_plink_add(_adapter *adapter, const u8 *hwaddr);
int rtw_mesh_plink_set_state(_adapter *adapter, const u8 *hwaddr, u8 state);
#ifdef CONFIG_RTW_MESH_AEK
int rtw_mesh_plink_set_aek(_adapter *adapter, const u8 *hwaddr, const u8 *aek);
#endif
#if CONFIG_RTW_MESH_PEER_BLACKLIST
int rtw_mesh_plink_set_peer_conf_timeout(_adapter *adapter, const u8 *hwaddr);
#endif
void _rtw_mesh_plink_del_ent(_adapter *adapter, struct mesh_plink_ent *ent);
int rtw_mesh_plink_del(_adapter *adapter, const u8 *hwaddr);
void rtw_mesh_plink_ctl_init(_adapter *adapter);
void rtw_mesh_plink_ctl_deinit(_adapter *adapter);
void dump_mesh_plink_ctl(void *sel, _adapter *adapter);
int rtw_mesh_peer_establish(_adapter *adapter, struct mesh_plink_ent *plink, struct sta_info *sta);
void _rtw_mesh_expire_peer_ent(_adapter *adapter, struct mesh_plink_ent *plink);
void rtw_mesh_expire_peer(_adapter *adapter, const u8 *peer_addr);
u8 rtw_mesh_ps_annc(_adapter *adapter, u8 ps);
unsigned int on_action_mesh(_adapter *adapter, union recv_frame *rframe);
void rtw_mesh_cfg_init(_adapter *adapter);
void rtw_mesh_cfg_init_max_peer_links(_adapter *adapter, u8 stack_conf);
void rtw_mesh_cfg_init_plink_timeout(_adapter *adapter, u32 stack_conf);
void rtw_mesh_init_mesh_info(_adapter *adapter);
void rtw_mesh_deinit_mesh_info(_adapter *adapter);
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
void dump_mesh_b2u_flags(void *sel, _adapter *adapter);
#endif
int rtw_mesh_addr_resolve(_adapter *adapter, struct xmit_frame *xframe, _pkt *pkt, _list *b2u_list);
s8 rtw_mesh_tx_set_whdr_mctrl_len(u8 mesh_frame_mode, struct pkt_attrib *attrib);
void rtw_mesh_tx_build_mctrl(_adapter *adapter, struct pkt_attrib *attrib, u8 *buf);
u8 rtw_mesh_tx_build_whdr(_adapter *adapter, struct pkt_attrib *attrib
, u16 *fctrl, struct rtw_ieee80211_hdr *whdr);
int rtw_mesh_rx_data_validate_hdr(_adapter *adapter, union recv_frame *rframe, struct sta_info **sta);
int rtw_mesh_rx_data_validate_mctrl(_adapter *adapter, union recv_frame *rframe
, const struct rtw_ieee80211s_hdr *mctrl, const u8 *mda, const u8 *msa
, u8 *mctrl_len, const u8 **da, const u8 **sa);
int rtw_mesh_rx_validate_mctrl_non_amsdu(_adapter *adapter, union recv_frame *rframe);
int rtw_mesh_rx_msdu_act_check(union recv_frame *rframe
, const u8 *mda, const u8 *msa
, const u8 *da, const u8 *sa
, struct rtw_ieee80211s_hdr *mctrl
, struct xmit_frame **fwd_frame, _list *b2u_list);
void dump_mesh_stats(void *sel, _adapter *adapter);
#if defined(PLATFORM_LINUX) && (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 32))
#define rtw_lockdep_assert_held(l) lockdep_assert_held(l)
#define rtw_lockdep_is_held(l) lockdep_is_held(l)
#else
#error "TBD\n"
#endif
#include "rtw_mesh_pathtbl.h"
#include "rtw_mesh_hwmp.h"
#endif /* __RTW_MESH_H_ */
================================================
FILE: core/mesh/rtw_mesh_hwmp.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_HWMP_C_
#ifdef CONFIG_RTW_MESH
#include
#include
#define RTW_TEST_FRAME_LEN 8192
#define RTW_MAX_METRIC 0xffffffff
#define RTW_ARITH_SHIFT 8
#define RTW_LINK_FAIL_THRESH 95
#define RTW_MAX_PREQ_QUEUE_LEN 64
#define RTW_ATLM_REQ_CYCLE 1000
#define rtw_ilog2(n) \
( \
(n) < 2 ? 0 : \
(n) & (1ULL << 63) ? 63 : \
(n) & (1ULL << 62) ? 62 : \
(n) & (1ULL << 61) ? 61 : \
(n) & (1ULL << 60) ? 60 : \
(n) & (1ULL << 59) ? 59 : \
(n) & (1ULL << 58) ? 58 : \
(n) & (1ULL << 57) ? 57 : \
(n) & (1ULL << 56) ? 56 : \
(n) & (1ULL << 55) ? 55 : \
(n) & (1ULL << 54) ? 54 : \
(n) & (1ULL << 53) ? 53 : \
(n) & (1ULL << 52) ? 52 : \
(n) & (1ULL << 51) ? 51 : \
(n) & (1ULL << 50) ? 50 : \
(n) & (1ULL << 49) ? 49 : \
(n) & (1ULL << 48) ? 48 : \
(n) & (1ULL << 47) ? 47 : \
(n) & (1ULL << 46) ? 46 : \
(n) & (1ULL << 45) ? 45 : \
(n) & (1ULL << 44) ? 44 : \
(n) & (1ULL << 43) ? 43 : \
(n) & (1ULL << 42) ? 42 : \
(n) & (1ULL << 41) ? 41 : \
(n) & (1ULL << 40) ? 40 : \
(n) & (1ULL << 39) ? 39 : \
(n) & (1ULL << 38) ? 38 : \
(n) & (1ULL << 37) ? 37 : \
(n) & (1ULL << 36) ? 36 : \
(n) & (1ULL << 35) ? 35 : \
(n) & (1ULL << 34) ? 34 : \
(n) & (1ULL << 33) ? 33 : \
(n) & (1ULL << 32) ? 32 : \
(n) & (1ULL << 31) ? 31 : \
(n) & (1ULL << 30) ? 30 : \
(n) & (1ULL << 29) ? 29 : \
(n) & (1ULL << 28) ? 28 : \
(n) & (1ULL << 27) ? 27 : \
(n) & (1ULL << 26) ? 26 : \
(n) & (1ULL << 25) ? 25 : \
(n) & (1ULL << 24) ? 24 : \
(n) & (1ULL << 23) ? 23 : \
(n) & (1ULL << 22) ? 22 : \
(n) & (1ULL << 21) ? 21 : \
(n) & (1ULL << 20) ? 20 : \
(n) & (1ULL << 19) ? 19 : \
(n) & (1ULL << 18) ? 18 : \
(n) & (1ULL << 17) ? 17 : \
(n) & (1ULL << 16) ? 16 : \
(n) & (1ULL << 15) ? 15 : \
(n) & (1ULL << 14) ? 14 : \
(n) & (1ULL << 13) ? 13 : \
(n) & (1ULL << 12) ? 12 : \
(n) & (1ULL << 11) ? 11 : \
(n) & (1ULL << 10) ? 10 : \
(n) & (1ULL << 9) ? 9 : \
(n) & (1ULL << 8) ? 8 : \
(n) & (1ULL << 7) ? 7 : \
(n) & (1ULL << 6) ? 6 : \
(n) & (1ULL << 5) ? 5 : \
(n) & (1ULL << 4) ? 4 : \
(n) & (1ULL << 3) ? 3 : \
(n) & (1ULL << 2) ? 2 : \
1 \
)
enum rtw_mpath_frame_type {
RTW_MPATH_PREQ = 0,
RTW_MPATH_PREP,
RTW_MPATH_PERR,
RTW_MPATH_RANN
};
static inline u32 rtw_u32_field_get(const u8 *preq_elem, int shift, BOOLEAN ae)
{
if (ae)
shift += 6;
return LE_BITS_TO_4BYTE(preq_elem + shift, 0, 32);
}
static inline u16 rtw_u16_field_get(const u8 *preq_elem, int shift, BOOLEAN ae)
{
if (ae)
shift += 6;
return LE_BITS_TO_2BYTE(preq_elem + shift, 0, 16);
}
/* HWMP IE processing macros */
#define RTW_AE_F (1<<6)
#define RTW_AE_F_SET(x) (*x & RTW_AE_F)
#define RTW_PREQ_IE_FLAGS(x) (*(x))
#define RTW_PREQ_IE_HOPCOUNT(x) (*(x + 1))
#define RTW_PREQ_IE_TTL(x) (*(x + 2))
#define RTW_PREQ_IE_PREQ_ID(x) rtw_u32_field_get(x, 3, 0)
#define RTW_PREQ_IE_ORIG_ADDR(x) (x + 7)
#define RTW_PREQ_IE_ORIG_SN(x) rtw_u32_field_get(x, 13, 0)
#define RTW_PREQ_IE_LIFETIME(x) rtw_u32_field_get(x, 17, RTW_AE_F_SET(x))
#define RTW_PREQ_IE_METRIC(x) rtw_u32_field_get(x, 21, RTW_AE_F_SET(x))
#define RTW_PREQ_IE_TARGET_F(x) (*(RTW_AE_F_SET(x) ? x + 32 : x + 26))
#define RTW_PREQ_IE_TARGET_ADDR(x) (RTW_AE_F_SET(x) ? x + 33 : x + 27)
#define RTW_PREQ_IE_TARGET_SN(x) rtw_u32_field_get(x, 33, RTW_AE_F_SET(x))
#define RTW_PREP_IE_FLAGS(x) RTW_PREQ_IE_FLAGS(x)
#define RTW_PREP_IE_HOPCOUNT(x) RTW_PREQ_IE_HOPCOUNT(x)
#define RTW_PREP_IE_TTL(x) RTW_PREQ_IE_TTL(x)
#define RTW_PREP_IE_ORIG_ADDR(x) (RTW_AE_F_SET(x) ? x + 27 : x + 21)
#define RTW_PREP_IE_ORIG_SN(x) rtw_u32_field_get(x, 27, RTW_AE_F_SET(x))
#define RTW_PREP_IE_LIFETIME(x) rtw_u32_field_get(x, 13, RTW_AE_F_SET(x))
#define RTW_PREP_IE_METRIC(x) rtw_u32_field_get(x, 17, RTW_AE_F_SET(x))
#define RTW_PREP_IE_TARGET_ADDR(x) (x + 3)
#define RTW_PREP_IE_TARGET_SN(x) rtw_u32_field_get(x, 9, 0)
#define RTW_PERR_IE_TTL(x) (*(x))
#define RTW_PERR_IE_TARGET_FLAGS(x) (*(x + 2))
#define RTW_PERR_IE_TARGET_ADDR(x) (x + 3)
#define RTW_PERR_IE_TARGET_SN(x) rtw_u32_field_get(x, 9, 0)
#define RTW_PERR_IE_TARGET_RCODE(x) rtw_u16_field_get(x, 13, 0)
#define RTW_TU_TO_SYSTIME(x) (rtw_us_to_systime((x) * 1024))
#define RTW_TU_TO_EXP_TIME(x) (rtw_get_current_time() + RTW_TU_TO_SYSTIME(x))
#define RTW_MSEC_TO_TU(x) (x*1000/1024)
#define RTW_SN_GT(x, y) ((s32)(y - x) < 0)
#define RTW_SN_LT(x, y) ((s32)(x - y) < 0)
#define RTW_MAX_SANE_SN_DELTA 32
static inline u32 RTW_SN_DELTA(u32 x, u32 y)
{
return x >= y ? x - y : y - x;
}
#define rtw_net_traversal_jiffies(adapter) \
rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPnetDiameterTraversalTime)
#define rtw_default_lifetime(adapter) \
RTW_MSEC_TO_TU(adapter->mesh_cfg.dot11MeshHWMPactivePathTimeout)
#define rtw_min_preq_int_jiff(adapter) \
(rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPpreqMinInterval))
#define rtw_max_preq_retries(adapter) (adapter->mesh_cfg.dot11MeshHWMPmaxPREQretries)
#define rtw_disc_timeout_jiff(adapter) \
rtw_ms_to_systime(adapter->mesh_cfg.min_discovery_timeout)
#define rtw_root_path_confirmation_jiffies(adapter) \
rtw_ms_to_systime(adapter->mesh_cfg.dot11MeshHWMPconfirmationInterval)
static inline BOOLEAN rtw_ether_addr_equal(const u8 *addr1, const u8 *addr2)
{
return _rtw_memcmp(addr1, addr2, ETH_ALEN);
}
#ifdef PLATFORM_LINUX
#define rtw_print_ratelimit() printk_ratelimit()
#define rtw_mod_timer(ptimer, expires) mod_timer(&(ptimer)->timer, expires)
#else
#endif
#define RTW_MESH_EWMA_PRECISION 20
#define RTW_MESH_EWMA_WEIGHT_RCP 8
#define RTW_TOTAL_PKT_MIN_THRESHOLD 1
inline void rtw_ewma_err_rate_init(struct rtw_ewma_err_rate *e)
{
e->internal = 0;
}
inline unsigned long rtw_ewma_err_rate_read(struct rtw_ewma_err_rate *e)
{
return e->internal >> (RTW_MESH_EWMA_PRECISION);
}
inline void rtw_ewma_err_rate_add(struct rtw_ewma_err_rate *e,
unsigned long val)
{
unsigned long internal = e->internal;
unsigned long weight_rcp = rtw_ilog2(RTW_MESH_EWMA_WEIGHT_RCP);
unsigned long precision = RTW_MESH_EWMA_PRECISION;
(e->internal) = internal ? (((internal << weight_rcp) - internal) +
(val << precision)) >> weight_rcp :
(val << precision);
}
static const u8 bcast_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
static int rtw_mesh_path_sel_frame_tx(enum rtw_mpath_frame_type mpath_action, u8 flags,
const u8 *originator_addr, u32 originator_sn,
u8 target_flags, const u8 *target,
u32 target_sn, const u8 *da, u8 hopcount, u8 ttl,
u32 lifetime, u32 metric, u32 preq_id,
_adapter *adapter)
{
struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct xmit_frame *pmgntframe = NULL;
struct rtw_ieee80211_hdr *pwlanhdr = NULL;
struct pkt_attrib *pattrib = NULL;
u8 category = RTW_WLAN_CATEGORY_MESH;
u8 action = RTW_ACT_MESH_HWMP_PATH_SELECTION;
u16 *fctrl = NULL;
u8 *pos, ie_len;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return -1;
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pos = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pos;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pos, WIFI_ACTION);
pos += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pos = rtw_set_fixed_ie(pos, 1, &(category), &(pattrib->pktlen));
pos = rtw_set_fixed_ie(pos, 1, &(action), &(pattrib->pktlen));
switch (mpath_action) {
case RTW_MPATH_PREQ:
RTW_HWMP_DBG("sending PREQ to "MAC_FMT"\n", MAC_ARG(target));
ie_len = 37;
pattrib->pktlen += (ie_len + 2);
*pos++ = WLAN_EID_PREQ;
break;
case RTW_MPATH_PREP:
RTW_HWMP_DBG("sending PREP to "MAC_FMT"\n", MAC_ARG(originator_addr));
ie_len = 31;
pattrib->pktlen += (ie_len + 2);
*pos++ = WLAN_EID_PREP;
break;
case RTW_MPATH_RANN:
RTW_HWMP_DBG("sending RANN from "MAC_FMT"\n", MAC_ARG(originator_addr));
ie_len = sizeof(struct rtw_ieee80211_rann_ie);
pattrib->pktlen += (ie_len + 2);
*pos++ = WLAN_EID_RANN;
break;
default:
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
return _FAIL;
}
*pos++ = ie_len;
*pos++ = flags;
*pos++ = hopcount;
*pos++ = ttl;
if (mpath_action == RTW_MPATH_PREP) {
_rtw_memcpy(pos, target, ETH_ALEN);
pos += ETH_ALEN;
*(u32 *)pos = cpu_to_le32(target_sn);
pos += 4;
} else {
if (mpath_action == RTW_MPATH_PREQ) {
*(u32 *)pos = cpu_to_le32(preq_id);
pos += 4;
}
_rtw_memcpy(pos, originator_addr, ETH_ALEN);
pos += ETH_ALEN;
*(u32 *)pos = cpu_to_le32(originator_sn);
pos += 4;
}
*(u32 *)pos = cpu_to_le32(lifetime);
pos += 4;
*(u32 *)pos = cpu_to_le32(metric);
pos += 4;
if (mpath_action == RTW_MPATH_PREQ) {
*pos++ = 1; /* support only 1 destination now */
*pos++ = target_flags;
_rtw_memcpy(pos, target, ETH_ALEN);
pos += ETH_ALEN;
*(u32 *)pos = cpu_to_le32(target_sn);
pos += 4;
} else if (mpath_action == RTW_MPATH_PREP) {
_rtw_memcpy(pos, originator_addr, ETH_ALEN);
pos += ETH_ALEN;
*(u32 *)pos = cpu_to_le32(originator_sn);
pos += 4;
}
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(adapter, pmgntframe);
return 0;
}
int rtw_mesh_path_error_tx(_adapter *adapter,
u8 ttl, const u8 *target, u32 target_sn,
u16 perr_reason_code, const u8 *ra)
{
struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct xmit_frame *pmgntframe = NULL;
struct rtw_ieee80211_hdr *pwlanhdr = NULL;
struct pkt_attrib *pattrib = NULL;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
u8 category = RTW_WLAN_CATEGORY_MESH;
u8 action = RTW_ACT_MESH_HWMP_PATH_SELECTION;
u8 *pos, ie_len;
u16 *fctrl = NULL;
if (rtw_time_before(rtw_get_current_time(), minfo->next_perr))
return -1;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return -1;
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pos = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pos;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(adapter), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pos, WIFI_ACTION);
pos += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pos = rtw_set_fixed_ie(pos, 1, &(category), &(pattrib->pktlen));
pos = rtw_set_fixed_ie(pos, 1, &(action), &(pattrib->pktlen));
ie_len = 15;
pattrib->pktlen += (2 + ie_len);
*pos++ = WLAN_EID_PERR;
*pos++ = ie_len;
/* ttl */
*pos++ = ttl;
/* The Number of Destinations N */
*pos++ = 1;
/* Flags format | B7 | B6 | B5:B0 | = | rsvd | AE | rsvd | */
*pos = 0;
pos++;
_rtw_memcpy(pos, target, ETH_ALEN);
pos += ETH_ALEN;
*(u32 *)pos = cpu_to_le32(target_sn);
pos += 4;
*(u16 *)pos = cpu_to_le16(perr_reason_code);
adapter->mesh_info.next_perr = RTW_TU_TO_EXP_TIME(
adapter->mesh_cfg.dot11MeshHWMPperrMinInterval);
pattrib->last_txcmdsz = pattrib->pktlen;
/* Send directly. Rewrite it if deferred tx is needed */
dump_mgntframe(adapter, pmgntframe);
RTW_HWMP_DBG("TX PERR toward "MAC_FMT", ra = "MAC_FMT"\n", MAC_ARG(target), MAC_ARG(ra));
return 0;
}
static u32 rtw_get_vht_bitrate(u8 mcs, u8 bw, u8 nss, u8 sgi)
{
static const u32 base[4][10] = {
{ 6500000,
13000000,
19500000,
26000000,
39000000,
52000000,
58500000,
65000000,
78000000,
/* not in the spec, but some devices use this: */
86500000,
},
{ 13500000,
27000000,
40500000,
54000000,
81000000,
108000000,
121500000,
135000000,
162000000,
180000000,
},
{ 29300000,
58500000,
87800000,
117000000,
175500000,
234000000,
263300000,
292500000,
351000000,
390000000,
},
{ 58500000,
117000000,
175500000,
234000000,
351000000,
468000000,
526500000,
585000000,
702000000,
780000000,
},
};
u32 bitrate;
int bw_idx;
if (mcs > 9) {
RTW_HWMP_INFO("Invalid mcs = %d\n", mcs);
return 0;
}
if (nss > 4 || nss < 1) {
RTW_HWMP_INFO("Now only support nss = 1, 2, 3, 4\n");
}
switch (bw) {
case CHANNEL_WIDTH_160:
bw_idx = 3;
break;
case CHANNEL_WIDTH_80:
bw_idx = 2;
break;
case CHANNEL_WIDTH_40:
bw_idx = 1;
break;
case CHANNEL_WIDTH_20:
bw_idx = 0;
break;
default:
RTW_HWMP_INFO("bw = %d currently not supported\n", bw);
return 0;
}
bitrate = base[bw_idx][mcs];
bitrate *= nss;
if (sgi)
bitrate = (bitrate / 9) * 10;
/* do NOT round down here */
return (bitrate + 50000) / 100000;
}
static u32 rtw_get_ht_bitrate(u8 mcs, u8 bw, u8 sgi)
{
int modulation, streams, bitrate;
/* the formula below does only work for MCS values smaller than 32 */
if (mcs >= 32) {
RTW_HWMP_INFO("Invalid mcs = %d\n", mcs);
return 0;
}
if (bw > 1) {
RTW_HWMP_INFO("Now HT only support bw = 0(20Mhz), 1(40Mhz)\n");
return 0;
}
modulation = mcs & 7;
streams = (mcs >> 3) + 1;
bitrate = (bw == 1) ? 13500000 : 6500000;
if (modulation < 4)
bitrate *= (modulation + 1);
else if (modulation == 4)
bitrate *= (modulation + 2);
else
bitrate *= (modulation + 3);
bitrate *= streams;
if (sgi)
bitrate = (bitrate / 9) * 10;
/* do NOT round down here */
return (bitrate + 50000) / 100000;
}
/**
* @bw: 0(20Mhz), 1(40Mhz), 2(80Mhz), 3(160Mhz)
* @rate_idx: DESC_RATEXXXX & 0x7f
* @sgi: DESC_RATEXXXX >> 7
* Returns: bitrate in 100kbps
*/
static u32 rtw_desc_rate_to_bitrate(u8 bw, u8 rate_idx, u8 sgi)
{
u32 bitrate;
if (rate_idx <= DESC_RATE54M){
u16 ofdm_rate[12] = {10, 20, 55, 110,
60, 90, 120, 180, 240, 360, 480, 540};
bitrate = ofdm_rate[rate_idx];
} else if ((DESC_RATEMCS0 <= rate_idx) &&
(rate_idx <= DESC_RATEMCS31)) {
u8 mcs = rate_idx - DESC_RATEMCS0;
bitrate = rtw_get_ht_bitrate(mcs, bw, sgi);
} else if ((DESC_RATEVHTSS1MCS0 <= rate_idx) &&
(rate_idx <= DESC_RATEVHTSS4MCS9)) {
u8 mcs = (rate_idx - DESC_RATEVHTSS1MCS0) % 10;
u8 nss = ((rate_idx - DESC_RATEVHTSS1MCS0) / 10) + 1;
bitrate = rtw_get_vht_bitrate(mcs, bw, nss, sgi);
} else {
/* 60Ghz ??? */
bitrate = 1;
}
return bitrate;
}
static u32 rtw_airtime_link_metric_get(_adapter *adapter, struct sta_info *sta)
{
struct dm_struct *dm = adapter_to_phydm(adapter);
int device_constant = phydm_get_plcp(dm, sta->cmn.mac_id) << RTW_ARITH_SHIFT;
u32 test_frame_len = RTW_TEST_FRAME_LEN << RTW_ARITH_SHIFT;
u32 s_unit = 1 << RTW_ARITH_SHIFT;
u32 err;
u16 rate;
u32 tx_time, estimated_retx;
u64 result;
/* The fail_avg should <= 100 here */
u32 fail_avg = (u32)rtw_ewma_err_rate_read(&sta->metrics.err_rate);
if (fail_avg > RTW_LINK_FAIL_THRESH)
return RTW_MAX_METRIC;
rate = sta->metrics.data_rate;
/* rate unit is 100Kbps, min rate = 10 */
if (rate < 10) {
RTW_HWMP_INFO("rate = %d\n", rate);
return RTW_MAX_METRIC;
}
err = (fail_avg << RTW_ARITH_SHIFT) / 100;
/* test_frame_len*10 to adjust the unit of rate(100kbps/unit) */
tx_time = (device_constant + 10 * test_frame_len / rate);
estimated_retx = ((1 << (2 * RTW_ARITH_SHIFT)) / (s_unit - err));
result = (tx_time * estimated_retx) >> (2 * RTW_ARITH_SHIFT);
/* Convert us to 0.01 TU(10.24us). x/10.24 = x*100/1024 */
result = (result * 100) >> 10;
return (u32)result;
}
void rtw_ieee80211s_update_metric(_adapter *adapter, u8 mac_id,
u8 per, u8 rate,
u8 bw, u8 total_pkt)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct sta_info *sta;
u8 rate_idx;
u8 sgi;
sta = macid_ctl->sta[mac_id];
if (!sta)
return;
/* if RA, use reported rate */
if (adapter->fix_rate == 0xff) {
rate_idx = rate & 0x7f;
sgi = rate >> 7;
} else {
rate_idx = adapter->fix_rate & 0x7f;
sgi = adapter->fix_rate >> 7;
}
sta->metrics.data_rate = rtw_desc_rate_to_bitrate(bw, rate_idx, sgi);
if (total_pkt < RTW_TOTAL_PKT_MIN_THRESHOLD)
return;
/* TBD: sta->metrics.overhead = phydm_get_plcp(void *dm_void, u16 macid); */
sta->metrics.total_pkt = total_pkt;
rtw_ewma_err_rate_add(&sta->metrics.err_rate, per);
if (rtw_ewma_err_rate_read(&sta->metrics.err_rate) >
RTW_LINK_FAIL_THRESH)
rtw_mesh_plink_broken(sta);
}
static void rtw_hwmp_preq_frame_process(_adapter *adapter,
struct rtw_ieee80211_hdr_3addr *mgmt,
const u8 *preq_elem, u32 originator_metric)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
struct rtw_mesh_path *path = NULL;
const u8 *target_addr, *originator_addr;
const u8 *da;
u8 target_flags, ttl, flags, to_gate_ask = 0;
u32 originator_sn, target_sn, lifetime, target_metric = 0;
BOOLEAN reply = _FALSE;
BOOLEAN forward = _TRUE;
BOOLEAN preq_is_gate;
/* Update target SN, if present */
target_addr = RTW_PREQ_IE_TARGET_ADDR(preq_elem);
originator_addr = RTW_PREQ_IE_ORIG_ADDR(preq_elem);
target_sn = RTW_PREQ_IE_TARGET_SN(preq_elem);
originator_sn = RTW_PREQ_IE_ORIG_SN(preq_elem);
target_flags = RTW_PREQ_IE_TARGET_F(preq_elem);
/* PREQ gate announcements */
flags = RTW_PREQ_IE_FLAGS(preq_elem);
preq_is_gate = !!(flags & RTW_IEEE80211_PREQ_IS_GATE_FLAG);
RTW_HWMP_DBG("received PREQ from "MAC_FMT"\n", MAC_ARG(originator_addr));
if (rtw_ether_addr_equal(target_addr, adapter_mac_addr(adapter))) {
RTW_HWMP_DBG("PREQ is for us\n");
#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
rtw_rcu_read_lock();
path = rtw_mesh_path_lookup(adapter, originator_addr);
if (path) {
if (preq_is_gate)
rtw_mesh_path_add_gate(path);
else if (path->is_gate) {
enter_critical_bh(&path->state_lock);
rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
exit_critical_bh(&path->state_lock);
}
}
path = NULL;
rtw_rcu_read_unlock();
#endif
forward = _FALSE;
reply = _TRUE;
to_gate_ask = 1;
target_metric = 0;
if (rtw_time_after(rtw_get_current_time(), minfo->last_sn_update +
rtw_net_traversal_jiffies(adapter)) ||
rtw_time_before(rtw_get_current_time(), minfo->last_sn_update)) {
++minfo->sn;
minfo->last_sn_update = rtw_get_current_time();
}
target_sn = minfo->sn;
} else if (is_broadcast_mac_addr(target_addr) &&
(target_flags & RTW_IEEE80211_PREQ_TO_FLAG)) {
rtw_rcu_read_lock();
path = rtw_mesh_path_lookup(adapter, originator_addr);
if (path) {
if (flags & RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG) {
reply = _TRUE;
target_addr = adapter_mac_addr(adapter);
target_sn = ++minfo->sn;
target_metric = 0;
minfo->last_sn_update = rtw_get_current_time();
}
if (preq_is_gate) {
lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
path->gate_ann_int = lifetime;
path->gate_asked = false;
rtw_mesh_path_add_gate(path);
} else if (path->is_gate) {
enter_critical_bh(&path->state_lock);
rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
exit_critical_bh(&path->state_lock);
}
}
rtw_rcu_read_unlock();
} else {
rtw_rcu_read_lock();
#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
path = rtw_mesh_path_lookup(adapter, originator_addr);
if (path) {
if (preq_is_gate)
rtw_mesh_path_add_gate(path);
else if (path->is_gate) {
enter_critical_bh(&path->state_lock);
rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
exit_critical_bh(&path->state_lock);
}
}
path = NULL;
#endif
path = rtw_mesh_path_lookup(adapter, target_addr);
if (path) {
if ((!(path->flags & RTW_MESH_PATH_SN_VALID)) ||
RTW_SN_LT(path->sn, target_sn)) {
path->sn = target_sn;
path->flags |= RTW_MESH_PATH_SN_VALID;
} else if ((!(target_flags & RTW_IEEE80211_PREQ_TO_FLAG)) &&
(path->flags & RTW_MESH_PATH_ACTIVE)) {
reply = _TRUE;
target_metric = path->metric;
target_sn = path->sn;
/* Case E2 of sec 13.10.9.3 IEEE 802.11-2012*/
target_flags |= RTW_IEEE80211_PREQ_TO_FLAG;
}
}
rtw_rcu_read_unlock();
}
if (reply) {
lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
ttl = mshcfg->element_ttl;
if (ttl != 0 && !to_gate_ask) {
RTW_HWMP_DBG("replying to the PREQ\n");
rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, 0, originator_addr,
originator_sn, 0, target_addr,
target_sn, mgmt->addr2, 0, ttl,
lifetime, target_metric, 0,
adapter);
} else if (ttl != 0 && to_gate_ask) {
RTW_HWMP_DBG("replying to the PREQ (PREQ for us)\n");
if (mshcfg->dot11MeshGateAnnouncementProtocol) {
/* BIT 7 is used to identify the prep is from mesh gate */
to_gate_ask = RTW_IEEE80211_PREQ_IS_GATE_FLAG | BIT(7);
} else {
to_gate_ask = 0;
}
rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, to_gate_ask, originator_addr,
originator_sn, 0, target_addr,
target_sn, mgmt->addr2, 0, ttl,
lifetime, target_metric, 0,
adapter);
} else {
minfo->mshstats.dropped_frames_ttl++;
}
}
if (forward && mshcfg->dot11MeshForwarding) {
u32 preq_id;
u8 hopcount;
ttl = RTW_PREQ_IE_TTL(preq_elem);
lifetime = RTW_PREQ_IE_LIFETIME(preq_elem);
if (ttl <= 1) {
minfo->mshstats.dropped_frames_ttl++;
return;
}
RTW_HWMP_DBG("forwarding the PREQ from "MAC_FMT"\n", MAC_ARG(originator_addr));
--ttl;
preq_id = RTW_PREQ_IE_PREQ_ID(preq_elem);
hopcount = RTW_PREQ_IE_HOPCOUNT(preq_elem) + 1;
da = (path && path->is_root) ?
path->rann_snd_addr : bcast_addr;
if (flags & RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG) {
target_addr = RTW_PREQ_IE_TARGET_ADDR(preq_elem);
target_sn = RTW_PREQ_IE_TARGET_SN(preq_elem);
}
rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, originator_addr,
originator_sn, target_flags, target_addr,
target_sn, da, hopcount, ttl, lifetime,
originator_metric, preq_id, adapter);
if (!is_multicast_mac_addr(da))
minfo->mshstats.fwded_unicast++;
else
minfo->mshstats.fwded_mcast++;
minfo->mshstats.fwded_frames++;
}
}
static inline struct sta_info *
rtw_next_hop_deref_protected(struct rtw_mesh_path *path)
{
return rtw_rcu_dereference_protected(path->next_hop,
rtw_lockdep_is_held(&path->state_lock));
}
static void rtw_hwmp_prep_frame_process(_adapter *adapter,
struct rtw_ieee80211_hdr_3addr *mgmt,
const u8 *prep_elem, u32 metric)
{
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
struct rtw_mesh_path *path;
const u8 *target_addr, *originator_addr;
u8 ttl, hopcount, flags;
u8 next_hop[ETH_ALEN];
u32 target_sn, originator_sn, lifetime;
RTW_HWMP_DBG("received PREP from "MAC_FMT"\n",
MAC_ARG(RTW_PREP_IE_TARGET_ADDR(prep_elem)));
originator_addr = RTW_PREP_IE_ORIG_ADDR(prep_elem);
if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter))) {
/* destination, no forwarding required */
rtw_rcu_read_lock();
target_addr = RTW_PREP_IE_TARGET_ADDR(prep_elem);
path = rtw_mesh_path_lookup(adapter, target_addr);
if (path && path->gate_asked) {
flags = RTW_PREP_IE_FLAGS(prep_elem);
if (flags & BIT(7)) {
enter_critical_bh(&path->state_lock);
path->gate_asked = false;
exit_critical_bh(&path->state_lock);
if (!(flags & RTW_IEEE80211_PREQ_IS_GATE_FLAG)) {
enter_critical_bh(&path->state_lock);
rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
exit_critical_bh(&path->state_lock);
}
}
}
rtw_rcu_read_unlock();
return;
}
if (!mshcfg->dot11MeshForwarding)
return;
ttl = RTW_PREP_IE_TTL(prep_elem);
if (ttl <= 1) {
mshstats->dropped_frames_ttl++;
return;
}
rtw_rcu_read_lock();
path = rtw_mesh_path_lookup(adapter, originator_addr);
if (path)
enter_critical_bh(&path->state_lock);
else
goto fail;
if (!(path->flags & RTW_MESH_PATH_ACTIVE)) {
exit_critical_bh(&path->state_lock);
goto fail;
}
_rtw_memcpy(next_hop, rtw_next_hop_deref_protected(path)->cmn.mac_addr, ETH_ALEN);
exit_critical_bh(&path->state_lock);
--ttl;
flags = RTW_PREP_IE_FLAGS(prep_elem);
lifetime = RTW_PREP_IE_LIFETIME(prep_elem);
hopcount = RTW_PREP_IE_HOPCOUNT(prep_elem) + 1;
target_addr = RTW_PREP_IE_TARGET_ADDR(prep_elem);
target_sn = RTW_PREP_IE_TARGET_SN(prep_elem);
originator_sn = RTW_PREP_IE_ORIG_SN(prep_elem);
rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREP, flags, originator_addr, originator_sn, 0,
target_addr, target_sn, next_hop, hopcount,
ttl, lifetime, metric, 0, adapter);
rtw_rcu_read_unlock();
mshstats->fwded_unicast++;
mshstats->fwded_frames++;
return;
fail:
rtw_rcu_read_unlock();
mshstats->dropped_frames_no_route++;
}
static void rtw_hwmp_perr_frame_process(_adapter *adapter,
struct rtw_ieee80211_hdr_3addr *mgmt,
const u8 *perr_elem)
{
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
struct rtw_mesh_path *path;
u8 ttl;
const u8 *ta, *target_addr;
u32 target_sn;
u16 perr_reason_code;
ta = mgmt->addr2;
ttl = RTW_PERR_IE_TTL(perr_elem);
if (ttl <= 1) {
mshstats->dropped_frames_ttl++;
return;
}
ttl--;
target_addr = RTW_PERR_IE_TARGET_ADDR(perr_elem);
target_sn = RTW_PERR_IE_TARGET_SN(perr_elem);
perr_reason_code = RTW_PERR_IE_TARGET_RCODE(perr_elem);
RTW_HWMP_DBG("received PERR toward target "MAC_FMT"\n", MAC_ARG(target_addr));
rtw_rcu_read_lock();
path = rtw_mesh_path_lookup(adapter, target_addr);
if (path) {
struct sta_info *sta;
enter_critical_bh(&path->state_lock);
sta = rtw_next_hop_deref_protected(path);
if (path->flags & RTW_MESH_PATH_ACTIVE &&
rtw_ether_addr_equal(ta, sta->cmn.mac_addr) &&
!(path->flags & RTW_MESH_PATH_FIXED) &&
(!(path->flags & RTW_MESH_PATH_SN_VALID) ||
RTW_SN_GT(target_sn, path->sn) || target_sn == 0)) {
path->flags &= ~RTW_MESH_PATH_ACTIVE;
if (target_sn != 0)
path->sn = target_sn;
else
path->sn += 1;
exit_critical_bh(&path->state_lock);
if (!mshcfg->dot11MeshForwarding)
goto endperr;
rtw_mesh_path_error_tx(adapter, ttl, target_addr,
target_sn, perr_reason_code,
bcast_addr);
} else
exit_critical_bh(&path->state_lock);
}
endperr:
rtw_rcu_read_unlock();
}
static void rtw_hwmp_rann_frame_process(_adapter *adapter,
struct rtw_ieee80211_hdr_3addr *mgmt,
const struct rtw_ieee80211_rann_ie *rann)
{
struct sta_info *sta;
struct sta_priv *pstapriv = &adapter->stapriv;
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
struct rtw_mesh_stats *mshstats = &adapter->mesh_info.mshstats;
struct rtw_mesh_path *path;
u8 ttl, flags, hopcount;
const u8 *originator_addr;
u32 originator_sn, metric, metric_txsta, interval;
BOOLEAN root_is_gate;
ttl = rann->rann_ttl;
flags = rann->rann_flags;
root_is_gate = !!(flags & RTW_RANN_FLAG_IS_GATE);
originator_addr = rann->rann_addr;
originator_sn = le32_to_cpu(rann->rann_seq);
interval = le32_to_cpu(rann->rann_interval);
hopcount = rann->rann_hopcount;
hopcount++;
metric = le32_to_cpu(rann->rann_metric);
/* Ignore our own RANNs */
if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter)))
return;
RTW_HWMP_DBG("received RANN from "MAC_FMT" via neighbour "MAC_FMT" (is_gate=%d)\n",
MAC_ARG(originator_addr), MAC_ARG(mgmt->addr2), root_is_gate);
rtw_rcu_read_lock();
sta = rtw_get_stainfo(pstapriv, mgmt->addr2);
if (!sta) {
rtw_rcu_read_unlock();
return;
}
metric_txsta = rtw_airtime_link_metric_get(adapter, sta);
path = rtw_mesh_path_lookup(adapter, originator_addr);
if (!path) {
path = rtw_mesh_path_add(adapter, originator_addr);
if (IS_ERR(path)) {
rtw_rcu_read_unlock();
mshstats->dropped_frames_no_route++;
return;
}
}
if (!(RTW_SN_LT(path->sn, originator_sn)) &&
!(path->sn == originator_sn && metric < path->rann_metric)) {
rtw_rcu_read_unlock();
return;
}
if ((!(path->flags & (RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVING)) ||
(rtw_time_after(rtw_get_current_time(), path->last_preq_to_root +
rtw_root_path_confirmation_jiffies(adapter)) ||
rtw_time_before(rtw_get_current_time(), path->last_preq_to_root))) &&
!(path->flags & RTW_MESH_PATH_FIXED) && (ttl != 0)) {
u8 preq_node_flag = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH;
RTW_HWMP_DBG("time to refresh root path "MAC_FMT"\n",
MAC_ARG(originator_addr));
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
if (RTW_SN_LT(path->sn, originator_sn) &&
(path->rann_metric + mshcfg->sane_metric_delta < metric) &&
_rtw_memcmp(bcast_addr, path->rann_snd_addr, ETH_ALEN) == _FALSE) {
RTW_HWMP_DBG("Trigger additional check for root "
"confirm PREQ. rann_snd_addr = "MAC_FMT
"add_chk_rann_snd_addr= "MAC_FMT"\n",
MAC_ARG(mgmt->addr2),
MAC_ARG(path->rann_snd_addr));
_rtw_memcpy(path->add_chk_rann_snd_addr,
path->rann_snd_addr, ETH_ALEN);
preq_node_flag |= RTW_PREQ_Q_F_CHK;
}
#endif
rtw_mesh_queue_preq(path, preq_node_flag);
path->last_preq_to_root = rtw_get_current_time();
}
path->sn = originator_sn;
path->rann_metric = metric + metric_txsta;
path->is_root = _TRUE;
/* Recording RANNs sender address to send individually
* addressed PREQs destined for root mesh STA */
_rtw_memcpy(path->rann_snd_addr, mgmt->addr2, ETH_ALEN);
if (root_is_gate) {
path->gate_ann_int = interval;
path->gate_asked = false;
rtw_mesh_path_add_gate(path);
} else if (path->is_gate) {
enter_critical_bh(&path->state_lock);
rtw_mesh_gate_del(adapter->mesh_info.mesh_paths, path);
exit_critical_bh(&path->state_lock);
}
if (ttl <= 1) {
mshstats->dropped_frames_ttl++;
rtw_rcu_read_unlock();
return;
}
ttl--;
if (mshcfg->dot11MeshForwarding) {
rtw_mesh_path_sel_frame_tx(RTW_MPATH_RANN, flags, originator_addr,
originator_sn, 0, NULL, 0, bcast_addr,
hopcount, ttl, interval,
metric + metric_txsta, 0, adapter);
}
rtw_rcu_read_unlock();
}
static u32 rtw_hwmp_route_info_get(_adapter *adapter,
struct rtw_ieee80211_hdr_3addr *mgmt,
const u8 *hwmp_ie, enum rtw_mpath_frame_type action)
{
struct rtw_mesh_path *path;
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *sta;
BOOLEAN fresh_info;
const u8 *originator_addr, *ta;
u32 originator_sn, originator_metric;
unsigned long originator_lifetime, exp_time;
u32 last_hop_metric, new_metric;
BOOLEAN process = _TRUE;
rtw_rcu_read_lock();
sta = rtw_get_stainfo(pstapriv, mgmt->addr2);
if (!sta) {
rtw_rcu_read_unlock();
return 0;
}
last_hop_metric = rtw_airtime_link_metric_get(adapter, sta);
/* Update and check originator routing info */
fresh_info = _TRUE;
switch (action) {
case RTW_MPATH_PREQ:
originator_addr = RTW_PREQ_IE_ORIG_ADDR(hwmp_ie);
originator_sn = RTW_PREQ_IE_ORIG_SN(hwmp_ie);
originator_lifetime = RTW_PREQ_IE_LIFETIME(hwmp_ie);
originator_metric = RTW_PREQ_IE_METRIC(hwmp_ie);
break;
case RTW_MPATH_PREP:
/* Note: For coding, the naming is not consist with spec */
originator_addr = RTW_PREP_IE_TARGET_ADDR(hwmp_ie);
originator_sn = RTW_PREP_IE_TARGET_SN(hwmp_ie);
originator_lifetime = RTW_PREP_IE_LIFETIME(hwmp_ie);
originator_metric = RTW_PREP_IE_METRIC(hwmp_ie);
break;
default:
rtw_rcu_read_unlock();
return 0;
}
new_metric = originator_metric + last_hop_metric;
if (new_metric < originator_metric)
new_metric = RTW_MAX_METRIC;
exp_time = RTW_TU_TO_EXP_TIME(originator_lifetime);
if (rtw_ether_addr_equal(originator_addr, adapter_mac_addr(adapter))) {
process = _FALSE;
fresh_info = _FALSE;
} else {
path = rtw_mesh_path_lookup(adapter, originator_addr);
if (path) {
enter_critical_bh(&path->state_lock);
if (path->flags & RTW_MESH_PATH_FIXED)
fresh_info = _FALSE;
else if ((path->flags & RTW_MESH_PATH_ACTIVE) &&
(path->flags & RTW_MESH_PATH_SN_VALID)) {
if (RTW_SN_GT(path->sn, originator_sn) ||
(path->sn == originator_sn &&
new_metric >= path->metric)) {
process = _FALSE;
fresh_info = _FALSE;
}
} else if (!(path->flags & RTW_MESH_PATH_ACTIVE)) {
BOOLEAN have_sn, newer_sn, bounced;
have_sn = path->flags & RTW_MESH_PATH_SN_VALID;
newer_sn = have_sn && RTW_SN_GT(originator_sn, path->sn);
bounced = have_sn &&
(RTW_SN_DELTA(originator_sn, path->sn) >
RTW_MAX_SANE_SN_DELTA);
if (!have_sn || newer_sn) {
} else if (bounced) {
} else {
process = _FALSE;
fresh_info = _FALSE;
}
}
} else {
path = rtw_mesh_path_add(adapter, originator_addr);
if (IS_ERR(path)) {
rtw_rcu_read_unlock();
return 0;
}
enter_critical_bh(&path->state_lock);
}
if (fresh_info) {
rtw_mesh_path_assign_nexthop(path, sta);
path->flags |= RTW_MESH_PATH_SN_VALID;
path->metric = new_metric;
path->sn = originator_sn;
path->exp_time = rtw_time_after(path->exp_time, exp_time)
? path->exp_time : exp_time;
rtw_mesh_path_activate(path);
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
if (path->is_root && (action == RTW_MPATH_PREP)) {
_rtw_memcpy(path->rann_snd_addr,
mgmt->addr2, ETH_ALEN);
path->rann_metric = new_metric;
}
#endif
exit_critical_bh(&path->state_lock);
rtw_mesh_path_tx_pending(path);
} else
exit_critical_bh(&path->state_lock);
}
/* Update and check transmitter routing info */
ta = mgmt->addr2;
if (rtw_ether_addr_equal(originator_addr, ta))
fresh_info = _FALSE;
else {
fresh_info = _TRUE;
path = rtw_mesh_path_lookup(adapter, ta);
if (path) {
enter_critical_bh(&path->state_lock);
if ((path->flags & RTW_MESH_PATH_FIXED) ||
((path->flags & RTW_MESH_PATH_ACTIVE) &&
(last_hop_metric > path->metric)))
fresh_info = _FALSE;
} else {
path = rtw_mesh_path_add(adapter, ta);
if (IS_ERR(path)) {
rtw_rcu_read_unlock();
return 0;
}
enter_critical_bh(&path->state_lock);
}
if (fresh_info) {
rtw_mesh_path_assign_nexthop(path, sta);
path->metric = last_hop_metric;
path->exp_time = rtw_time_after(path->exp_time, exp_time)
? path->exp_time : exp_time;
rtw_mesh_path_activate(path);
exit_critical_bh(&path->state_lock);
rtw_mesh_path_tx_pending(path);
} else
exit_critical_bh(&path->state_lock);
}
rtw_rcu_read_unlock();
return process ? new_metric : 0;
}
static void rtw_mesh_rx_hwmp_frame_cnts(_adapter *adapter, u8 *addr)
{
struct sta_info *sta;
sta = rtw_get_stainfo(&adapter->stapriv, addr);
if (sta)
sta->sta_stats.rx_hwmp_pkts++;
}
void rtw_mesh_rx_path_sel_frame(_adapter *adapter, union recv_frame *rframe)
{
struct mesh_plink_ent *plink = NULL;
struct rtw_ieee802_11_elems elems;
u32 path_metric;
struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
u8 *pframe = rframe->u.hdr.rx_data, *start;
uint frame_len = rframe->u.hdr.len, left;
struct rtw_ieee80211_hdr_3addr *frame_hdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
ParseRes parse_res;
plink = rtw_mesh_plink_get(adapter, get_addr2_ptr(pframe));
if (!plink || plink->plink_state != RTW_MESH_PLINK_ESTAB)
return;
rtw_mesh_rx_hwmp_frame_cnts(adapter, get_addr2_ptr(pframe));
/* Mesh action frame IE offset = 2 */
attrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
left = frame_len - attrib->hdrlen - attrib->iv_len - attrib->icv_len - 2;
start = pframe + attrib->hdrlen + 2;
parse_res = rtw_ieee802_11_parse_elems(start, left, &elems, 1);
if (parse_res == ParseFailed)
RTW_HWMP_INFO(FUNC_ADPT_FMT" Path Select Frame ParseFailed\n"
, FUNC_ADPT_ARG(adapter));
else if (parse_res == ParseUnknown)
RTW_HWMP_INFO(FUNC_ADPT_FMT" Path Select Frame ParseUnknown\n"
, FUNC_ADPT_ARG(adapter));
if (elems.preq) {
if (elems.preq_len != 37)
/* Right now we support just 1 destination and no AE */
return;
path_metric = rtw_hwmp_route_info_get(adapter, frame_hdr, elems.preq,
MPATH_PREQ);
if (path_metric)
rtw_hwmp_preq_frame_process(adapter, frame_hdr, elems.preq,
path_metric);
}
if (elems.prep) {
if (elems.prep_len != 31)
/* Right now we support no AE */
return;
path_metric = rtw_hwmp_route_info_get(adapter, frame_hdr, elems.prep,
MPATH_PREP);
if (path_metric)
rtw_hwmp_prep_frame_process(adapter, frame_hdr, elems.prep,
path_metric);
}
if (elems.perr) {
if (elems.perr_len != 15)
/* Right now we support only one destination per PERR */
return;
rtw_hwmp_perr_frame_process(adapter, frame_hdr, elems.perr);
}
if (elems.rann)
rtw_hwmp_rann_frame_process(adapter, frame_hdr, (struct rtw_ieee80211_rann_ie *)elems.rann);
}
void rtw_mesh_queue_preq(struct rtw_mesh_path *path, u8 flags)
{
_adapter *adapter = path->adapter;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mesh_preq_queue *preq_node;
preq_node = rtw_malloc(sizeof(struct rtw_mesh_preq_queue));
if (!preq_node) {
RTW_HWMP_INFO("could not allocate PREQ node\n");
return;
}
enter_critical_bh(&minfo->mesh_preq_queue_lock);
if (minfo->preq_queue_len == RTW_MAX_PREQ_QUEUE_LEN) {
exit_critical_bh(&minfo->mesh_preq_queue_lock);
rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
if (rtw_print_ratelimit())
RTW_HWMP_INFO("PREQ node queue full\n");
return;
}
_rtw_spinlock(&path->state_lock);
if (path->flags & RTW_MESH_PATH_REQ_QUEUED) {
_rtw_spinunlock(&path->state_lock);
exit_critical_bh(&minfo->mesh_preq_queue_lock);
rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
return;
}
_rtw_memcpy(preq_node->dst, path->dst, ETH_ALEN);
preq_node->flags = flags;
path->flags |= RTW_MESH_PATH_REQ_QUEUED;
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
if (flags & RTW_PREQ_Q_F_CHK)
path->flags |= RTW_MESH_PATH_ROOT_ADD_CHK;
#endif
if (flags & RTW_PREQ_Q_F_PEER_AKA)
path->flags |= RTW_MESH_PATH_PEER_AKA;
if (flags & RTW_PREQ_Q_F_BCAST_PREQ)
path->flags |= RTW_MESH_PATH_BCAST_PREQ;
_rtw_spinunlock(&path->state_lock);
rtw_list_insert_tail(&preq_node->list, &minfo->preq_queue.list);
++minfo->preq_queue_len;
exit_critical_bh(&minfo->mesh_preq_queue_lock);
if (rtw_time_after(rtw_get_current_time(), minfo->last_preq + rtw_min_preq_int_jiff(adapter)))
rtw_mesh_work(&adapter->mesh_work);
else if (rtw_time_before(rtw_get_current_time(), minfo->last_preq)) {
/* systime wrapped around issue */
minfo->last_preq = rtw_get_current_time() - rtw_min_preq_int_jiff(adapter) - 1;
rtw_mesh_work(&adapter->mesh_work);
} else
rtw_mod_timer(&adapter->mesh_path_timer, minfo->last_preq +
rtw_min_preq_int_jiff(adapter) + 1);
}
static const u8 *rtw_hwmp_preq_da(struct rtw_mesh_path *path,
BOOLEAN is_root_add_chk, BOOLEAN da_is_peer,
BOOLEAN force_preq_bcast)
{
const u8 *da;
if (da_is_peer)
da = path->dst;
else if (force_preq_bcast)
da = bcast_addr;
else if (path->is_root)
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
da = is_root_add_chk ? path->add_chk_rann_snd_addr:
path->rann_snd_addr;
#else
da = path->rann_snd_addr;
#endif
else
da = bcast_addr;
return da;
}
void rtw_mesh_path_start_discovery(_adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
struct rtw_mesh_preq_queue *preq_node;
struct rtw_mesh_path *path;
u8 ttl, target_flags = 0;
const u8 *da;
u32 lifetime;
u8 flags = 0;
BOOLEAN is_root_add_chk = _FALSE;
BOOLEAN da_is_peer, force_preq_bcast;
enter_critical_bh(&minfo->mesh_preq_queue_lock);
if (!minfo->preq_queue_len ||
rtw_time_before(rtw_get_current_time(), minfo->last_preq +
rtw_min_preq_int_jiff(adapter))) {
exit_critical_bh(&minfo->mesh_preq_queue_lock);
return;
}
preq_node = rtw_list_first_entry(&minfo->preq_queue.list,
struct rtw_mesh_preq_queue, list);
rtw_list_delete(&preq_node->list); /* list_del_init(&preq_node->list); */
--minfo->preq_queue_len;
exit_critical_bh(&minfo->mesh_preq_queue_lock);
rtw_rcu_read_lock();
path = rtw_mesh_path_lookup(adapter, preq_node->dst);
if (!path)
goto enddiscovery;
enter_critical_bh(&path->state_lock);
if (path->flags & (RTW_MESH_PATH_DELETED | RTW_MESH_PATH_FIXED)) {
exit_critical_bh(&path->state_lock);
goto enddiscovery;
}
path->flags &= ~RTW_MESH_PATH_REQ_QUEUED;
if (preq_node->flags & RTW_PREQ_Q_F_START) {
if (path->flags & RTW_MESH_PATH_RESOLVING) {
exit_critical_bh(&path->state_lock);
goto enddiscovery;
} else {
path->flags &= ~RTW_MESH_PATH_RESOLVED;
path->flags |= RTW_MESH_PATH_RESOLVING;
path->discovery_retries = 0;
path->discovery_timeout = rtw_disc_timeout_jiff(adapter);
}
} else if (!(path->flags & RTW_MESH_PATH_RESOLVING) ||
path->flags & RTW_MESH_PATH_RESOLVED) {
path->flags &= ~RTW_MESH_PATH_RESOLVING;
exit_critical_bh(&path->state_lock);
goto enddiscovery;
}
minfo->last_preq = rtw_get_current_time();
if (rtw_time_after(rtw_get_current_time(), minfo->last_sn_update +
rtw_net_traversal_jiffies(adapter)) ||
rtw_time_before(rtw_get_current_time(), minfo->last_sn_update)) {
++minfo->sn;
minfo->last_sn_update = rtw_get_current_time();
}
lifetime = rtw_default_lifetime(adapter);
ttl = mshcfg->element_ttl;
if (ttl == 0) {
minfo->mshstats.dropped_frames_ttl++;
exit_critical_bh(&path->state_lock);
goto enddiscovery;
}
if (preq_node->flags & RTW_PREQ_Q_F_REFRESH)
target_flags |= RTW_IEEE80211_PREQ_TO_FLAG;
else
target_flags &= ~RTW_IEEE80211_PREQ_TO_FLAG;
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
is_root_add_chk = !!(path->flags & RTW_MESH_PATH_ROOT_ADD_CHK);
#endif
da_is_peer = !!(path->flags & RTW_MESH_PATH_PEER_AKA);
force_preq_bcast = !!(path->flags & RTW_MESH_PATH_BCAST_PREQ);
exit_critical_bh(&path->state_lock);
da = rtw_hwmp_preq_da(path, is_root_add_chk,
da_is_peer, force_preq_bcast);
#ifdef CONFIG_RTW_MESH_ON_DMD_GANN
flags = (mshcfg->dot11MeshGateAnnouncementProtocol)
? RTW_IEEE80211_PREQ_IS_GATE_FLAG : 0;
#endif
rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, adapter_mac_addr(adapter), minfo->sn,
target_flags, path->dst, path->sn, da, 0,
ttl, lifetime, 0, minfo->preq_id++, adapter);
rtw_mod_timer(&path->timer, rtw_get_current_time() + path->discovery_timeout);
enddiscovery:
rtw_rcu_read_unlock();
rtw_mfree(preq_node, sizeof(struct rtw_mesh_preq_queue));
}
void rtw_mesh_path_timer(void *ctx)
{
struct rtw_mesh_path *path = (void *) ctx;
_adapter *adapter = path->adapter;
int ret;
u8 retry = 0;
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
#endif
/* TBD: Proctect for suspend */
#if 0
if (suspending)
return;
#endif
enter_critical_bh(&path->state_lock);
if (path->flags & RTW_MESH_PATH_RESOLVED ||
(!(path->flags & RTW_MESH_PATH_RESOLVING))) {
path->flags &= ~(RTW_MESH_PATH_RESOLVING |
RTW_MESH_PATH_RESOLVED |
RTW_MESH_PATH_ROOT_ADD_CHK |
RTW_MESH_PATH_PEER_AKA |
RTW_MESH_PATH_BCAST_PREQ);
exit_critical_bh(&path->state_lock);
} else if (path->discovery_retries < rtw_max_preq_retries(adapter)) {
++path->discovery_retries;
path->discovery_timeout *= 2;
path->flags &= ~RTW_MESH_PATH_REQ_QUEUED;
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
if (path->discovery_retries > mshcfg->max_root_add_chk_cnt)
path->flags &= ~RTW_MESH_PATH_ROOT_ADD_CHK;
#endif
if (path->gate_asked)
retry |= RTW_PREQ_Q_F_REFRESH;
exit_critical_bh(&path->state_lock);
rtw_mesh_queue_preq(path, retry);
} else {
path->flags &= ~(RTW_MESH_PATH_RESOLVING |
RTW_MESH_PATH_RESOLVED |
RTW_MESH_PATH_REQ_QUEUED |
RTW_MESH_PATH_ROOT_ADD_CHK |
RTW_MESH_PATH_PEER_AKA |
RTW_MESH_PATH_BCAST_PREQ);
path->exp_time = rtw_get_current_time();
exit_critical_bh(&path->state_lock);
if (!path->is_gate && rtw_mesh_gate_num(adapter) > 0) {
ret = rtw_mesh_path_send_to_gates(path);
if (ret)
RTW_HWMP_DBG("no gate was reachable\n");
} else
rtw_mesh_path_flush_pending(path);
}
}
void rtw_mesh_path_tx_root_frame(_adapter *adapter)
{
struct rtw_mesh_cfg *mshcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
u32 interval = mshcfg->dot11MeshHWMPRannInterval;
u8 flags, target_flags = 0;
flags = (mshcfg->dot11MeshGateAnnouncementProtocol)
? RTW_RANN_FLAG_IS_GATE : 0;
switch (mshcfg->dot11MeshHWMPRootMode) {
case RTW_IEEE80211_PROACTIVE_RANN:
rtw_mesh_path_sel_frame_tx(RTW_MPATH_RANN, flags, adapter_mac_addr(adapter),
++minfo->sn, 0, NULL, 0, bcast_addr,
0, mshcfg->element_ttl,
interval, 0, 0, adapter);
break;
case RTW_IEEE80211_PROACTIVE_PREQ_WITH_PREP:
flags |= RTW_IEEE80211_PREQ_PROACTIVE_PREP_FLAG;
case RTW_IEEE80211_PROACTIVE_PREQ_NO_PREP:
interval = mshcfg->dot11MeshHWMPactivePathToRootTimeout;
target_flags |= RTW_IEEE80211_PREQ_TO_FLAG |
RTW_IEEE80211_PREQ_USN_FLAG;
rtw_mesh_path_sel_frame_tx(RTW_MPATH_PREQ, flags, adapter_mac_addr(adapter),
++minfo->sn, target_flags,
(u8 *) bcast_addr, 0, bcast_addr,
0, mshcfg->element_ttl, interval,
0, minfo->preq_id++, adapter);
break;
default:
RTW_HWMP_INFO("Proactive mechanism not supported\n");
return;
}
}
void rtw_mesh_work(_workitem *work)
{
/* use kernel global workqueue */
_set_workitem(work);
}
void rtw_ieee80211_mesh_path_timer(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
rtw_mesh_work(&adapter->mesh_work);
}
void rtw_ieee80211_mesh_path_root_timer(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
rtw_set_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
rtw_mesh_work(&adapter->mesh_work);
}
static void rtw_ieee80211_mesh_rootpath(_adapter *adapter)
{
u32 interval;
rtw_mesh_path_tx_root_frame(adapter);
if (adapter->mesh_cfg.dot11MeshHWMPRootMode == RTW_IEEE80211_PROACTIVE_RANN)
interval = adapter->mesh_cfg.dot11MeshHWMPRannInterval;
else
interval = adapter->mesh_cfg.dot11MeshHWMProotInterval;
rtw_mod_timer(&adapter->mesh_path_root_timer,
RTW_TU_TO_EXP_TIME(interval));
}
BOOLEAN rtw_ieee80211_mesh_root_setup(_adapter *adapter)
{
BOOLEAN root_enabled = _FALSE;
if (adapter->mesh_cfg.dot11MeshHWMPRootMode > RTW_IEEE80211_ROOTMODE_ROOT) {
rtw_set_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
root_enabled = _TRUE;
}
else {
rtw_clear_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags);
/* stop running timer */
_cancel_timer_ex(&adapter->mesh_path_root_timer);
root_enabled = _FALSE;
}
return root_enabled;
}
void rtw_mesh_work_hdl(_workitem *work)
{
_adapter *adapter = container_of(work, _adapter, mesh_work);
while(adapter->mesh_info.preq_queue_len) {
if (rtw_time_after(rtw_get_current_time(),
adapter->mesh_info.last_preq + rtw_min_preq_int_jiff(adapter)))
/* It will consume preq_queue_len */
rtw_mesh_path_start_discovery(adapter);
else {
struct rtw_mesh_info *minfo = &adapter->mesh_info;
rtw_mod_timer(&adapter->mesh_path_timer,
minfo->last_preq + rtw_min_preq_int_jiff(adapter) + 1);
break;
}
}
if (rtw_test_and_clear_bit(RTW_MESH_WORK_ROOT, &adapter->wrkq_flags))
rtw_ieee80211_mesh_rootpath(adapter);
}
#ifndef RTW_PER_CMD_SUPPORT_FW
static void rtw_update_metric_directly(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
u8 i;
for (i = 0; i < macid_ctl->num; i++) {
u8 role;
role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]);
if (role == H2C_MSR_ROLE_MESH) {
struct sta_info *sta = macid_ctl->sta[i];
u8 rate_idx, sgi, bw;
u32 rate;
if (!sta)
continue;
rate_idx = rtw_get_current_tx_rate(adapter, sta);
sgi = rtw_get_current_tx_sgi(adapter, sta);
bw = sta->cmn.bw_mode;
rate = rtw_desc_rate_to_bitrate(bw, rate_idx, sgi);
sta->metrics.data_rate = rate;
}
}
}
#endif
void rtw_mesh_atlm_param_req_timer(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
u8 ret = _FAIL;
#ifdef RTW_PER_CMD_SUPPORT_FW
ret = rtw_req_per_cmd(adapter);
if (ret == _FAIL)
RTW_HWMP_INFO("rtw_req_per_cmd fail\n");
#else
rtw_update_metric_directly(adapter);
#endif
_set_timer(&adapter->mesh_atlm_param_req_timer, RTW_ATLM_REQ_CYCLE);
}
#endif /* CONFIG_RTW_MESH */
================================================
FILE: core/mesh/rtw_mesh_hwmp.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __RTW_MESH_HWMP_H_
#define __RTW_MESH_HWMP_H_
#ifndef DBG_RTW_HWMP
#define DBG_RTW_HWMP 0
#endif
#if DBG_RTW_HWMP
#define RTW_HWMP_DBG(fmt, arg...) RTW_PRINT(fmt, ##arg)
#else
#define RTW_HWMP_DBG(fmt, arg...) RTW_DBG(fmt, ##arg)
#endif
#ifndef INFO_RTW_HWMP
#define INFO_RTW_HWMP 0
#endif
#if INFO_RTW_HWMP
#define RTW_HWMP_INFO(fmt, arg...) RTW_PRINT(fmt, ##arg)
#else
#define RTW_HWMP_INFO(fmt, arg...) RTW_INFO(fmt, ##arg)
#endif
void rtw_ewma_err_rate_init(struct rtw_ewma_err_rate *e);
unsigned long rtw_ewma_err_rate_read(struct rtw_ewma_err_rate *e);
void rtw_ewma_err_rate_add(struct rtw_ewma_err_rate *e, unsigned long val);
int rtw_mesh_path_error_tx(_adapter *adapter,
u8 ttl, const u8 *target, u32 target_sn,
u16 target_rcode, const u8 *ra);
void rtw_ieee80211s_update_metric(_adapter *adapter, u8 mac_id,
u8 per, u8 rate,
u8 bw, u8 total_pkt);
void rtw_mesh_rx_path_sel_frame(_adapter *adapter, union recv_frame *rframe);
void rtw_mesh_queue_preq(struct rtw_mesh_path *mpath, u8 flags);
void rtw_mesh_path_start_discovery(_adapter *adapter);
void rtw_mesh_path_timer(void *ctx);
void rtw_mesh_path_tx_root_frame(_adapter *adapter);
void rtw_mesh_work_hdl(_workitem *work);
void rtw_ieee80211_mesh_path_timer(void *ctx);
void rtw_ieee80211_mesh_path_root_timer(void *ctx);
BOOLEAN rtw_ieee80211_mesh_root_setup(_adapter *adapter);
void rtw_mesh_work(_workitem *work);
void rtw_mesh_atlm_param_req_timer(void *ctx);
#endif /* __RTW_MESH_HWMP_H_ */
================================================
FILE: core/mesh/rtw_mesh_pathtbl.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_MESH_PATHTBL_C_
#ifdef CONFIG_RTW_MESH
#include
#include
#ifdef PLATFORM_LINUX
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0))
static void rtw_mpath_free_rcu(struct rtw_mesh_path *mpath)
{
kfree_rcu(mpath, rcu);
rtw_mstat_update(MSTAT_TYPE_PHY, MSTAT_FREE, sizeof(struct rtw_mesh_path));
}
#else
static void rtw_mpath_free_rcu_callback(rtw_rcu_head *head)
{
struct rtw_mesh_path *mpath;
mpath = container_of(head, struct rtw_mesh_path, rcu);
rtw_mfree(mpath, sizeof(struct rtw_mesh_path));
}
static void rtw_mpath_free_rcu(struct rtw_mesh_path *mpath)
{
call_rcu(&mpath->rcu, rtw_mpath_free_rcu_callback);
}
#endif
#endif /* PLATFORM_LINUX */
static void rtw_mesh_path_free_rcu(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath);
static u32 rtw_mesh_table_hash(const void *addr, u32 len, u32 seed)
{
/* Use last four bytes of hw addr as hash index */
return jhash_1word(*(u32 *)(addr+2), seed);
}
static const rtw_rhashtable_params rtw_mesh_rht_params = {
.nelem_hint = 2,
.automatic_shrinking = true,
.key_len = ETH_ALEN,
.key_offset = offsetof(struct rtw_mesh_path, dst),
.head_offset = offsetof(struct rtw_mesh_path, rhash),
.hashfn = rtw_mesh_table_hash,
};
static inline bool rtw_mpath_expired(struct rtw_mesh_path *mpath)
{
return (mpath->flags & RTW_MESH_PATH_ACTIVE) &&
rtw_time_after(rtw_get_current_time(), mpath->exp_time) &&
!(mpath->flags & RTW_MESH_PATH_FIXED);
}
static void rtw_mesh_path_rht_free(void *ptr, void *tblptr)
{
struct rtw_mesh_path *mpath = ptr;
struct rtw_mesh_table *tbl = tblptr;
rtw_mesh_path_free_rcu(tbl, mpath);
}
static struct rtw_mesh_table *rtw_mesh_table_alloc(void)
{
struct rtw_mesh_table *newtbl;
newtbl = rtw_malloc(sizeof(struct rtw_mesh_table));
if (!newtbl)
return NULL;
rtw_hlist_head_init(&newtbl->known_gates);
ATOMIC_SET(&newtbl->entries, 0);
_rtw_spinlock_init(&newtbl->gates_lock);
return newtbl;
}
static void rtw_mesh_table_free(struct rtw_mesh_table *tbl)
{
rtw_rhashtable_free_and_destroy(&tbl->rhead,
rtw_mesh_path_rht_free, tbl);
rtw_mfree(tbl, sizeof(struct rtw_mesh_table));
}
/**
*
* rtw_mesh_path_assign_nexthop - update mesh path next hop
*
* @mpath: mesh path to update
* @sta: next hop to assign
*
* Locking: mpath->state_lock must be held when calling this function
*/
void rtw_mesh_path_assign_nexthop(struct rtw_mesh_path *mpath, struct sta_info *sta)
{
struct xmit_frame *xframe;
_list *list, *head;
rtw_rcu_assign_pointer(mpath->next_hop, sta);
enter_critical_bh(&mpath->frame_queue.lock);
head = &mpath->frame_queue.queue;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
_rtw_memcpy(xframe->attrib.ra, sta->cmn.mac_addr, ETH_ALEN);
}
exit_critical_bh(&mpath->frame_queue.lock);
}
static void rtw_prepare_for_gate(struct xmit_frame *xframe, char *dst_addr,
struct rtw_mesh_path *gate_mpath)
{
struct pkt_attrib *attrib = &xframe->attrib;
char *next_hop;
if (attrib->mesh_frame_mode == MESH_UCAST_DATA)
attrib->mesh_frame_mode = MESH_UCAST_PX_DATA;
/* update next hop */
rtw_rcu_read_lock();
next_hop = rtw_rcu_dereference(gate_mpath->next_hop)->cmn.mac_addr;
_rtw_memcpy(attrib->ra, next_hop, ETH_ALEN);
rtw_rcu_read_unlock();
_rtw_memcpy(attrib->mda, dst_addr, ETH_ALEN);
}
/**
*
* rtw_mesh_path_move_to_queue - Move or copy frames from one mpath queue to another
*
* This function is used to transfer or copy frames from an unresolved mpath to
* a gate mpath. The function also adds the Address Extension field and
* updates the next hop.
*
* If a frame already has an Address Extension field, only the next hop and
* destination addresses are updated.
*
* The gate mpath must be an active mpath with a valid mpath->next_hop.
*
* @mpath: An active mpath the frames will be sent to (i.e. the gate)
* @from_mpath: The failed mpath
* @copy: When true, copy all the frames to the new mpath queue. When false,
* move them.
*/
static void rtw_mesh_path_move_to_queue(struct rtw_mesh_path *gate_mpath,
struct rtw_mesh_path *from_mpath,
bool copy)
{
struct xmit_frame *fskb;
_list *list, *head;
_list failq;
u32 failq_len;
_irqL flags;
if (rtw_warn_on(gate_mpath == from_mpath))
return;
if (rtw_warn_on(!gate_mpath->next_hop))
return;
_rtw_init_listhead(&failq);
_enter_critical_bh(&from_mpath->frame_queue.lock, &flags);
rtw_list_splice_init(&from_mpath->frame_queue.queue, &failq);
failq_len = from_mpath->frame_queue_len;
from_mpath->frame_queue_len = 0;
_exit_critical_bh(&from_mpath->frame_queue.lock, &flags);
head = &failq;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
if (gate_mpath->frame_queue_len >= RTW_MESH_FRAME_QUEUE_LEN) {
RTW_MPATH_DBG(FUNC_ADPT_FMT" mpath queue for gate %pM is full!\n"
, FUNC_ADPT_ARG(gate_mpath->adapter), gate_mpath->dst);
break;
}
fskb = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&fskb->list);
failq_len--;
rtw_prepare_for_gate(fskb, gate_mpath->dst, gate_mpath);
_enter_critical_bh(&gate_mpath->frame_queue.lock, &flags);
rtw_list_insert_tail(&fskb->list, get_list_head(&gate_mpath->frame_queue));
gate_mpath->frame_queue_len++;
_exit_critical_bh(&gate_mpath->frame_queue.lock, &flags);
#if 0 /* TODO: copy */
skb = rtw_skb_copy(fskb);
if (rtw_warn_on(!skb))
break;
rtw_prepare_for_gate(skb, gate_mpath->dst, gate_mpath);
skb_queue_tail(&gate_mpath->frame_queue, skb);
if (copy)
continue;
__skb_unlink(fskb, &failq);
rtw_skb_free(fskb);
#endif
}
RTW_MPATH_DBG(FUNC_ADPT_FMT" mpath queue for gate %pM has %d frames\n"
, FUNC_ADPT_ARG(gate_mpath->adapter), gate_mpath->dst, gate_mpath->frame_queue_len);
if (!copy)
return;
_enter_critical_bh(&from_mpath->frame_queue.lock, &flags);
rtw_list_splice(&failq, &from_mpath->frame_queue.queue);
from_mpath->frame_queue_len += failq_len;
_exit_critical_bh(&from_mpath->frame_queue.lock, &flags);
}
static struct rtw_mesh_path *rtw_mpath_lookup(struct rtw_mesh_table *tbl, const u8 *dst)
{
struct rtw_mesh_path *mpath;
if (!tbl)
return NULL;
mpath = rtw_rhashtable_lookup_fast(&tbl->rhead, dst, rtw_mesh_rht_params);
if (mpath && rtw_mpath_expired(mpath)) {
enter_critical_bh(&mpath->state_lock);
mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
exit_critical_bh(&mpath->state_lock);
}
return mpath;
}
/**
* rtw_mesh_path_lookup - look up a path in the mesh path table
* @sdata: local subif
* @dst: hardware address (ETH_ALEN length) of destination
*
* Returns: pointer to the mesh path structure, or NULL if not found
*
* Locking: must be called within a read rcu section.
*/
struct rtw_mesh_path *
rtw_mesh_path_lookup(_adapter *adapter, const u8 *dst)
{
return rtw_mpath_lookup(adapter->mesh_info.mesh_paths, dst);
}
struct rtw_mesh_path *
rtw_mpp_path_lookup(_adapter *adapter, const u8 *dst)
{
return rtw_mpath_lookup(adapter->mesh_info.mpp_paths, dst);
}
static struct rtw_mesh_path *
__rtw_mesh_path_lookup_by_idx(struct rtw_mesh_table *tbl, int idx)
{
int i = 0, ret;
struct rtw_mesh_path *mpath = NULL;
rtw_rhashtable_iter iter;
if (!tbl)
return NULL;
ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
if (ret)
return NULL;
ret = rtw_rhashtable_walk_start(&iter);
if (ret && ret != -EAGAIN)
goto err;
while ((mpath = rtw_rhashtable_walk_next(&iter))) {
if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
continue;
if (IS_ERR(mpath))
break;
if (i++ == idx)
break;
}
err:
rtw_rhashtable_walk_stop(&iter);
rtw_rhashtable_walk_exit(&iter);
if (IS_ERR(mpath) || !mpath)
return NULL;
if (rtw_mpath_expired(mpath)) {
enter_critical_bh(&mpath->state_lock);
mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
exit_critical_bh(&mpath->state_lock);
}
return mpath;
}
/**
* rtw_mesh_path_lookup_by_idx - look up a path in the mesh path table by its index
* @idx: index
* @sdata: local subif, or NULL for all entries
*
* Returns: pointer to the mesh path structure, or NULL if not found.
*
* Locking: must be called within a read rcu section.
*/
struct rtw_mesh_path *
rtw_mesh_path_lookup_by_idx(_adapter *adapter, int idx)
{
return __rtw_mesh_path_lookup_by_idx(adapter->mesh_info.mesh_paths, idx);
}
void dump_mpath(void *sel, _adapter *adapter)
{
struct rtw_mesh_path *mpath;
int idx = 0;
char dst[ETH_ALEN];
char next_hop[ETH_ALEN];
u32 sn, metric, qlen;
u32 exp_ms = 0, dto_ms;
u8 drty;
enum rtw_mesh_path_flags flags;
RTW_PRINT_SEL(sel, "%-17s %-17s %-10s %-10s %-4s %-6s %-6s %-4s flags\n"
, "dst", "next_hop", "sn", "metric", "qlen", "exp_ms", "dto_ms", "drty"
);
do {
rtw_rcu_read_lock();
mpath = rtw_mesh_path_lookup_by_idx(adapter, idx);
if (mpath) {
_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
_rtw_memcpy(next_hop, mpath->next_hop->cmn.mac_addr, ETH_ALEN);
sn = mpath->sn;
metric = mpath->metric;
qlen = mpath->frame_queue_len;
if (rtw_time_after(mpath->exp_time, rtw_get_current_time()))
exp_ms = rtw_get_remaining_time_ms(mpath->exp_time);
dto_ms = rtw_systime_to_ms(mpath->discovery_timeout);
drty = mpath->discovery_retries;
flags = mpath->flags;
}
rtw_rcu_read_unlock();
if (mpath) {
RTW_PRINT_SEL(sel, MAC_FMT" "MAC_FMT" %10u %10u %4u %6u %6u %4u%s%s%s%s%s%s%s%s%s%s\n"
, MAC_ARG(dst), MAC_ARG(next_hop), sn, metric, qlen
, exp_ms < 999999 ? exp_ms : 999999
, dto_ms < 999999 ? dto_ms : 999999
, drty
, (flags & RTW_MESH_PATH_ACTIVE) ? " ACT" : ""
, (flags & RTW_MESH_PATH_RESOLVING) ? " RSVING" : ""
, (flags & RTW_MESH_PATH_SN_VALID) ? " SN_VALID" : ""
, (flags & RTW_MESH_PATH_FIXED) ? " FIXED" : ""
, (flags & RTW_MESH_PATH_RESOLVED) ? " RSVED" : ""
, (flags & RTW_MESH_PATH_REQ_QUEUED) ? " REQ_IN_Q" : ""
, (flags & RTW_MESH_PATH_DELETED) ? " DELETED" : ""
, (flags & RTW_MESH_PATH_ROOT_ADD_CHK) ? " R_ADD_CHK" : ""
, (flags & RTW_MESH_PATH_PEER_AKA) ? " PEER_AKA" : ""
, (flags & RTW_MESH_PATH_BCAST_PREQ) ? " BC_PREQ" : ""
);
}
idx++;
} while (mpath);
}
/**
* rtw_mpp_path_lookup_by_idx - look up a path in the proxy path table by its index
* @idx: index
* @sdata: local subif, or NULL for all entries
*
* Returns: pointer to the proxy path structure, or NULL if not found.
*
* Locking: must be called within a read rcu section.
*/
struct rtw_mesh_path *
rtw_mpp_path_lookup_by_idx(_adapter *adapter, int idx)
{
return __rtw_mesh_path_lookup_by_idx(adapter->mesh_info.mpp_paths, idx);
}
/**
* rtw_mesh_path_add_gate - add the given mpath to a mesh gate to our path table
* @mpath: gate path to add to table
*/
int rtw_mesh_path_add_gate(struct rtw_mesh_path *mpath)
{
struct rtw_mesh_cfg *mcfg;
struct rtw_mesh_info *minfo;
struct rtw_mesh_table *tbl;
int err, ori_num_gates;
rtw_rcu_read_lock();
tbl = mpath->adapter->mesh_info.mesh_paths;
if (!tbl) {
err = -ENOENT;
goto err_rcu;
}
enter_critical_bh(&mpath->state_lock);
mcfg = &mpath->adapter->mesh_cfg;
mpath->gate_timeout = rtw_get_current_time() +
rtw_ms_to_systime(mcfg->path_gate_timeout_factor *
mpath->gate_ann_int);
if (mpath->is_gate) {
err = -EEXIST;
exit_critical_bh(&mpath->state_lock);
goto err_rcu;
}
minfo = &mpath->adapter->mesh_info;
mpath->is_gate = true;
_rtw_spinlock(&tbl->gates_lock);
ori_num_gates = minfo->num_gates;
minfo->num_gates++;
rtw_hlist_add_head_rcu(&mpath->gate_list, &tbl->known_gates);
if (ori_num_gates == 0
|| rtw_macaddr_is_larger(mpath->dst, minfo->max_addr_gate->dst)
) {
minfo->max_addr_gate = mpath;
minfo->max_addr_gate_is_larger_than_self =
rtw_macaddr_is_larger(mpath->dst, adapter_mac_addr(mpath->adapter));
}
_rtw_spinunlock(&tbl->gates_lock);
exit_critical_bh(&mpath->state_lock);
if (ori_num_gates == 0) {
update_beacon(mpath->adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE, 0);
#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
if (!rtw_mesh_cto_mgate_required(mpath->adapter))
rtw_netif_carrier_on(mpath->adapter->pnetdev);
#endif
}
RTW_MPATH_DBG(
FUNC_ADPT_FMT" Mesh path: Recorded new gate: %pM. %d known gates\n",
FUNC_ADPT_ARG(mpath->adapter),
mpath->dst, mpath->adapter->mesh_info.num_gates);
err = 0;
err_rcu:
rtw_rcu_read_unlock();
return err;
}
/**
* rtw_mesh_gate_del - remove a mesh gate from the list of known gates
* @tbl: table which holds our list of known gates
* @mpath: gate mpath
*/
void rtw_mesh_gate_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath)
{
struct rtw_mesh_cfg *mcfg;
struct rtw_mesh_info *minfo;
int ori_num_gates;
rtw_lockdep_assert_held(&mpath->state_lock);
if (!mpath->is_gate)
return;
mcfg = &mpath->adapter->mesh_cfg;
minfo = &mpath->adapter->mesh_info;
mpath->is_gate = false;
enter_critical_bh(&tbl->gates_lock);
rtw_hlist_del_rcu(&mpath->gate_list);
ori_num_gates = minfo->num_gates;
minfo->num_gates--;
if (ori_num_gates == 1) {
minfo->max_addr_gate = NULL;
minfo->max_addr_gate_is_larger_than_self = 0;
} else if (minfo->max_addr_gate == mpath) {
struct rtw_mesh_path *gate, *max_addr_gate = NULL;
rtw_hlist_node *node;
rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
if (!max_addr_gate || rtw_macaddr_is_larger(gate->dst, max_addr_gate->dst))
max_addr_gate = gate;
}
minfo->max_addr_gate = max_addr_gate;
minfo->max_addr_gate_is_larger_than_self =
rtw_macaddr_is_larger(max_addr_gate->dst, adapter_mac_addr(mpath->adapter));
}
exit_critical_bh(&tbl->gates_lock);
if (ori_num_gates == 1) {
update_beacon(mpath->adapter, WLAN_EID_MESH_CONFIG, NULL, _TRUE, 0);
#if CONFIG_RTW_MESH_CTO_MGATE_CARRIER
if (rtw_mesh_cto_mgate_required(mpath->adapter))
rtw_netif_carrier_off(mpath->adapter->pnetdev);
#endif
}
RTW_MPATH_DBG(
FUNC_ADPT_FMT" Mesh path: Deleted gate: %pM. %d known gates\n",
FUNC_ADPT_ARG(mpath->adapter),
mpath->dst, mpath->adapter->mesh_info.num_gates);
}
/**
* rtw_mesh_gate_search - search a mesh gate from the list of known gates
* @tbl: table which holds our list of known gates
* @addr: address of gate
*/
bool rtw_mesh_gate_search(struct rtw_mesh_table *tbl, const u8 *addr)
{
struct rtw_mesh_path *gate;
rtw_hlist_node *node;
bool exist = 0;
rtw_rcu_read_lock();
rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
if (_rtw_memcmp(gate->dst, addr, ETH_ALEN) == _TRUE) {
exist = 1;
break;
}
}
rtw_rcu_read_unlock();
return exist;
}
/**
* rtw_mesh_gate_num - number of gates known to this interface
* @sdata: subif data
*/
int rtw_mesh_gate_num(_adapter *adapter)
{
return adapter->mesh_info.num_gates;
}
bool rtw_mesh_is_primary_gate(_adapter *adapter)
{
struct rtw_mesh_cfg *mcfg = &adapter->mesh_cfg;
struct rtw_mesh_info *minfo = &adapter->mesh_info;
return mcfg->dot11MeshGateAnnouncementProtocol
&& !minfo->max_addr_gate_is_larger_than_self;
}
void dump_known_gates(void *sel, _adapter *adapter)
{
struct rtw_mesh_info *minfo = &adapter->mesh_info;
struct rtw_mesh_table *tbl;
struct rtw_mesh_path *gate;
rtw_hlist_node *node;
if (!rtw_mesh_gate_num(adapter))
goto exit;
rtw_rcu_read_lock();
tbl = minfo->mesh_paths;
if (!tbl)
goto unlock;
RTW_PRINT_SEL(sel, "num:%d\n", rtw_mesh_gate_num(adapter));
rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
RTW_PRINT_SEL(sel, "%c"MAC_FMT"\n"
, gate == minfo->max_addr_gate ? '*' : ' '
, MAC_ARG(gate->dst));
}
unlock:
rtw_rcu_read_unlock();
exit:
return;
}
static
struct rtw_mesh_path *rtw_mesh_path_new(_adapter *adapter,
const u8 *dst)
{
struct rtw_mesh_path *new_mpath;
new_mpath = rtw_zmalloc(sizeof(struct rtw_mesh_path));
if (!new_mpath)
return NULL;
_rtw_memcpy(new_mpath->dst, dst, ETH_ALEN);
_rtw_memset(new_mpath->rann_snd_addr, 0xFF, ETH_ALEN);
new_mpath->is_root = false;
new_mpath->adapter = adapter;
new_mpath->flags = 0;
new_mpath->gate_asked = false;
_rtw_init_queue(&new_mpath->frame_queue);
new_mpath->frame_queue_len = 0;
new_mpath->exp_time = rtw_get_current_time();
_rtw_spinlock_init(&new_mpath->state_lock);
rtw_init_timer(&new_mpath->timer, adapter, rtw_mesh_path_timer, new_mpath);
return new_mpath;
}
/**
* rtw_mesh_path_add - allocate and add a new path to the mesh path table
* @dst: destination address of the path (ETH_ALEN length)
* @sdata: local subif
*
* Returns: 0 on success
*
* State: the initial state of the new path is set to 0
*/
struct rtw_mesh_path *rtw_mesh_path_add(_adapter *adapter,
const u8 *dst)
{
struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
struct rtw_mesh_path *mpath, *new_mpath;
int ret;
if (!tbl)
return ERR_PTR(-ENOTSUPP);
if (_rtw_memcmp(dst, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
/* never add ourselves as neighbours */
return ERR_PTR(-ENOTSUPP);
if (is_multicast_mac_addr(dst))
return ERR_PTR(-ENOTSUPP);
if (ATOMIC_INC_UNLESS(&adapter->mesh_info.mpaths, RTW_MESH_MAX_MPATHS) == 0)
return ERR_PTR(-ENOSPC);
new_mpath = rtw_mesh_path_new(adapter, dst);
if (!new_mpath)
return ERR_PTR(-ENOMEM);
do {
ret = rtw_rhashtable_lookup_insert_fast(&tbl->rhead,
&new_mpath->rhash,
rtw_mesh_rht_params);
if (ret == -EEXIST)
mpath = rtw_rhashtable_lookup_fast(&tbl->rhead,
dst,
rtw_mesh_rht_params);
} while (unlikely(ret == -EEXIST && !mpath));
if (ret && ret != -EEXIST)
return ERR_PTR(ret);
/* At this point either new_mpath was added, or we found a
* matching entry already in the table; in the latter case
* free the unnecessary new entry.
*/
if (ret == -EEXIST) {
rtw_mfree(new_mpath, sizeof(struct rtw_mesh_path));
new_mpath = mpath;
}
adapter->mesh_info.mesh_paths_generation++;
return new_mpath;
}
int rtw_mpp_path_add(_adapter *adapter,
const u8 *dst, const u8 *mpp)
{
struct rtw_mesh_table *tbl = adapter->mesh_info.mpp_paths;
struct rtw_mesh_path *new_mpath;
int ret;
if (!tbl)
return -ENOTSUPP;
if (_rtw_memcmp(dst, adapter_mac_addr(adapter), ETH_ALEN) == _TRUE)
/* never add ourselves as neighbours */
return -ENOTSUPP;
if (is_multicast_mac_addr(dst))
return -ENOTSUPP;
new_mpath = rtw_mesh_path_new(adapter, dst);
if (!new_mpath)
return -ENOMEM;
_rtw_memcpy(new_mpath->mpp, mpp, ETH_ALEN);
ret = rtw_rhashtable_lookup_insert_fast(&tbl->rhead,
&new_mpath->rhash,
rtw_mesh_rht_params);
adapter->mesh_info.mpp_paths_generation++;
return ret;
}
void dump_mpp(void *sel, _adapter *adapter)
{
struct rtw_mesh_path *mpath;
int idx = 0;
char dst[ETH_ALEN];
char mpp[ETH_ALEN];
RTW_PRINT_SEL(sel, "%-17s %-17s\n", "dst", "mpp");
do {
rtw_rcu_read_lock();
mpath = rtw_mpp_path_lookup_by_idx(adapter, idx);
if (mpath) {
_rtw_memcpy(dst, mpath->dst, ETH_ALEN);
_rtw_memcpy(mpp, mpath->mpp, ETH_ALEN);
}
rtw_rcu_read_unlock();
if (mpath) {
RTW_PRINT_SEL(sel, MAC_FMT" "MAC_FMT"\n"
, MAC_ARG(dst), MAC_ARG(mpp));
}
idx++;
} while (mpath);
}
/**
* rtw_mesh_plink_broken - deactivates paths and sends perr when a link breaks
*
* @sta: broken peer link
*
* This function must be called from the rate control algorithm if enough
* delivery errors suggest that a peer link is no longer usable.
*/
void rtw_mesh_plink_broken(struct sta_info *sta)
{
_adapter *adapter = sta->padapter;
struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
static const u8 bcast[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct rtw_mesh_path *mpath;
rtw_rhashtable_iter iter;
int ret;
if (!tbl)
return;
ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
if (ret)
return;
ret = rtw_rhashtable_walk_start(&iter);
if (ret && ret != -EAGAIN)
goto out;
while ((mpath = rtw_rhashtable_walk_next(&iter))) {
if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
continue;
if (IS_ERR(mpath))
break;
if (rtw_rcu_access_pointer(mpath->next_hop) == sta &&
mpath->flags & RTW_MESH_PATH_ACTIVE &&
!(mpath->flags & RTW_MESH_PATH_FIXED)) {
enter_critical_bh(&mpath->state_lock);
mpath->flags &= ~RTW_MESH_PATH_ACTIVE;
++mpath->sn;
exit_critical_bh(&mpath->state_lock);
rtw_mesh_path_error_tx(adapter,
adapter->mesh_cfg.element_ttl,
mpath->dst, mpath->sn,
WLAN_REASON_MESH_PATH_DEST_UNREACHABLE, bcast);
}
}
out:
rtw_rhashtable_walk_stop(&iter);
rtw_rhashtable_walk_exit(&iter);
}
static void rtw_mesh_path_free_rcu(struct rtw_mesh_table *tbl,
struct rtw_mesh_path *mpath)
{
_adapter *adapter = mpath->adapter;
enter_critical_bh(&mpath->state_lock);
mpath->flags |= RTW_MESH_PATH_RESOLVING | RTW_MESH_PATH_DELETED;
rtw_mesh_gate_del(tbl, mpath);
exit_critical_bh(&mpath->state_lock);
_cancel_timer_ex(&mpath->timer);
ATOMIC_DEC(&adapter->mesh_info.mpaths);
ATOMIC_DEC(&tbl->entries);
_rtw_spinlock_free(&mpath->state_lock);
rtw_mesh_path_flush_pending(mpath);
rtw_mpath_free_rcu(mpath);
}
static void __rtw_mesh_path_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath)
{
rtw_rhashtable_remove_fast(&tbl->rhead, &mpath->rhash, rtw_mesh_rht_params);
rtw_mesh_path_free_rcu(tbl, mpath);
}
/**
* rtw_mesh_path_flush_by_nexthop - Deletes mesh paths if their next hop matches
*
* @sta: mesh peer to match
*
* RCU notes: this function is called when a mesh plink transitions from
* PLINK_ESTAB to any other state, since PLINK_ESTAB state is the only one that
* allows path creation. This will happen before the sta can be freed (because
* sta_info_destroy() calls this) so any reader in a rcu read block will be
* protected against the plink disappearing.
*/
void rtw_mesh_path_flush_by_nexthop(struct sta_info *sta)
{
_adapter *adapter = sta->padapter;
struct rtw_mesh_table *tbl = adapter->mesh_info.mesh_paths;
struct rtw_mesh_path *mpath;
rtw_rhashtable_iter iter;
int ret;
if (!tbl)
return;
ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
if (ret)
return;
ret = rtw_rhashtable_walk_start(&iter);
if (ret && ret != -EAGAIN)
goto out;
while ((mpath = rtw_rhashtable_walk_next(&iter))) {
if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
continue;
if (IS_ERR(mpath))
break;
if (rtw_rcu_access_pointer(mpath->next_hop) == sta)
__rtw_mesh_path_del(tbl, mpath);
}
out:
rtw_rhashtable_walk_stop(&iter);
rtw_rhashtable_walk_exit(&iter);
}
static void rtw_mpp_flush_by_proxy(_adapter *adapter,
const u8 *proxy)
{
struct rtw_mesh_table *tbl = adapter->mesh_info.mpp_paths;
struct rtw_mesh_path *mpath;
rtw_rhashtable_iter iter;
int ret;
if (!tbl)
return;
ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
if (ret)
return;
ret = rtw_rhashtable_walk_start(&iter);
if (ret && ret != -EAGAIN)
goto out;
while ((mpath = rtw_rhashtable_walk_next(&iter))) {
if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
continue;
if (IS_ERR(mpath))
break;
if (_rtw_memcmp(mpath->mpp, proxy, ETH_ALEN) == _TRUE)
__rtw_mesh_path_del(tbl, mpath);
}
out:
rtw_rhashtable_walk_stop(&iter);
rtw_rhashtable_walk_exit(&iter);
}
static void rtw_table_flush_by_iface(struct rtw_mesh_table *tbl)
{
struct rtw_mesh_path *mpath;
rtw_rhashtable_iter iter;
int ret;
if (!tbl)
return;
ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
if (ret)
return;
ret = rtw_rhashtable_walk_start(&iter);
if (ret && ret != -EAGAIN)
goto out;
while ((mpath = rtw_rhashtable_walk_next(&iter))) {
if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
continue;
if (IS_ERR(mpath))
break;
__rtw_mesh_path_del(tbl, mpath);
}
out:
rtw_rhashtable_walk_stop(&iter);
rtw_rhashtable_walk_exit(&iter);
}
/**
* rtw_mesh_path_flush_by_iface - Deletes all mesh paths associated with a given iface
*
* This function deletes both mesh paths as well as mesh portal paths.
*
* @sdata: interface data to match
*
*/
void rtw_mesh_path_flush_by_iface(_adapter *adapter)
{
rtw_table_flush_by_iface(adapter->mesh_info.mesh_paths);
rtw_table_flush_by_iface(adapter->mesh_info.mpp_paths);
}
/**
* rtw_table_path_del - delete a path from the mesh or mpp table
*
* @tbl: mesh or mpp path table
* @sdata: local subif
* @addr: dst address (ETH_ALEN length)
*
* Returns: 0 if successful
*/
static int rtw_table_path_del(struct rtw_mesh_table *tbl,
const u8 *addr)
{
struct rtw_mesh_path *mpath;
if (!tbl)
return -ENXIO;
rtw_rcu_read_lock();
mpath = rtw_rhashtable_lookup_fast(&tbl->rhead, addr, rtw_mesh_rht_params);
if (!mpath) {
rtw_rcu_read_unlock();
return -ENXIO;
}
__rtw_mesh_path_del(tbl, mpath);
rtw_rcu_read_unlock();
return 0;
}
/**
* rtw_mesh_path_del - delete a mesh path from the table
*
* @addr: dst address (ETH_ALEN length)
* @sdata: local subif
*
* Returns: 0 if successful
*/
int rtw_mesh_path_del(_adapter *adapter, const u8 *addr)
{
int err;
/* flush relevant mpp entries first */
rtw_mpp_flush_by_proxy(adapter, addr);
err = rtw_table_path_del(adapter->mesh_info.mesh_paths, addr);
adapter->mesh_info.mesh_paths_generation++;
return err;
}
/**
* rtw_mesh_path_tx_pending - sends pending frames in a mesh path queue
*
* @mpath: mesh path to activate
*
* Locking: the state_lock of the mpath structure must NOT be held when calling
* this function.
*/
void rtw_mesh_path_tx_pending(struct rtw_mesh_path *mpath)
{
if (mpath->flags & RTW_MESH_PATH_ACTIVE) {
struct rtw_mesh_info *minfo = &mpath->adapter->mesh_info;
_list q;
u32 q_len = 0;
_rtw_init_listhead(&q);
/* move to local queue */
enter_critical_bh(&mpath->frame_queue.lock);
if (mpath->frame_queue_len) {
rtw_list_splice_init(&mpath->frame_queue.queue, &q);
q_len = mpath->frame_queue_len;
mpath->frame_queue_len = 0;
}
exit_critical_bh(&mpath->frame_queue.lock);
if (q_len) {
/* move to mpath_tx_queue */
enter_critical_bh(&minfo->mpath_tx_queue.lock);
rtw_list_splice_tail(&q, &minfo->mpath_tx_queue.queue);
minfo->mpath_tx_queue_len += q_len;
exit_critical_bh(&minfo->mpath_tx_queue.lock);
/* schedule mpath_tx_tasklet */
tasklet_hi_schedule(&minfo->mpath_tx_tasklet);
}
}
}
/**
* rtw_mesh_path_send_to_gates - sends pending frames to all known mesh gates
*
* @mpath: mesh path whose queue will be emptied
*
* If there is only one gate, the frames are transferred from the failed mpath
* queue to that gate's queue. If there are more than one gates, the frames
* are copied from each gate to the next. After frames are copied, the
* mpath queues are emptied onto the transmission queue.
*/
int rtw_mesh_path_send_to_gates(struct rtw_mesh_path *mpath)
{
_adapter *adapter = mpath->adapter;
struct rtw_mesh_table *tbl;
struct rtw_mesh_path *from_mpath = mpath;
struct rtw_mesh_path *gate;
bool copy = false;
rtw_hlist_node *node;
tbl = adapter->mesh_info.mesh_paths;
if (!tbl)
return 0;
rtw_rcu_read_lock();
rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
if (gate->flags & RTW_MESH_PATH_ACTIVE) {
RTW_MPATH_DBG(FUNC_ADPT_FMT" Forwarding to %pM\n",
FUNC_ADPT_ARG(adapter), gate->dst);
rtw_mesh_path_move_to_queue(gate, from_mpath, copy);
from_mpath = gate;
copy = true;
} else {
RTW_MPATH_DBG(
FUNC_ADPT_FMT" Not forwarding to %pM (flags %#x)\n",
FUNC_ADPT_ARG(adapter), gate->dst, gate->flags);
}
}
rtw_hlist_for_each_entry_rcu(gate, node, &tbl->known_gates, gate_list) {
RTW_MPATH_DBG(FUNC_ADPT_FMT" Sending to %pM\n",
FUNC_ADPT_ARG(adapter), gate->dst);
rtw_mesh_path_tx_pending(gate);
}
rtw_rcu_read_unlock();
return (from_mpath == mpath) ? -EHOSTUNREACH : 0;
}
/**
* rtw_mesh_path_discard_frame - discard a frame whose path could not be resolved
*
* @skb: frame to discard
* @sdata: network subif the frame was to be sent through
*
* Locking: the function must me called within a rcu_read_lock region
*/
void rtw_mesh_path_discard_frame(_adapter *adapter,
struct xmit_frame *xframe)
{
rtw_free_xmitframe(&adapter->xmitpriv, xframe);
adapter->mesh_info.mshstats.dropped_frames_no_route++;
}
/**
* rtw_mesh_path_flush_pending - free the pending queue of a mesh path
*
* @mpath: mesh path whose queue has to be freed
*
* Locking: the function must me called within a rcu_read_lock region
*/
void rtw_mesh_path_flush_pending(struct rtw_mesh_path *mpath)
{
struct xmit_frame *xframe;
_list *list, *head;
_list tmp;
_rtw_init_listhead(&tmp);
enter_critical_bh(&mpath->frame_queue.lock);
rtw_list_splice_init(&mpath->frame_queue.queue, &tmp);
mpath->frame_queue_len = 0;
exit_critical_bh(&mpath->frame_queue.lock);
head = &tmp;
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
xframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&xframe->list);
rtw_mesh_path_discard_frame(mpath->adapter, xframe);
}
}
/**
* rtw_mesh_path_fix_nexthop - force a specific next hop for a mesh path
*
* @mpath: the mesh path to modify
* @next_hop: the next hop to force
*
* Locking: this function must be called holding mpath->state_lock
*/
void rtw_mesh_path_fix_nexthop(struct rtw_mesh_path *mpath, struct sta_info *next_hop)
{
enter_critical_bh(&mpath->state_lock);
rtw_mesh_path_assign_nexthop(mpath, next_hop);
mpath->sn = 0xffff;
mpath->metric = 0;
mpath->hop_count = 0;
mpath->exp_time = 0;
mpath->flags = RTW_MESH_PATH_FIXED | RTW_MESH_PATH_SN_VALID;
rtw_mesh_path_activate(mpath);
exit_critical_bh(&mpath->state_lock);
rtw_ewma_err_rate_init(&next_hop->metrics.err_rate);
/* init it at a low value - 0 start is tricky */
rtw_ewma_err_rate_add(&next_hop->metrics.err_rate, 1);
rtw_mesh_path_tx_pending(mpath);
}
int rtw_mesh_pathtbl_init(_adapter *adapter)
{
struct rtw_mesh_table *tbl_path, *tbl_mpp;
int ret;
tbl_path = rtw_mesh_table_alloc();
if (!tbl_path)
return -ENOMEM;
tbl_mpp = rtw_mesh_table_alloc();
if (!tbl_mpp) {
ret = -ENOMEM;
goto free_path;
}
rtw_rhashtable_init(&tbl_path->rhead, &rtw_mesh_rht_params);
rtw_rhashtable_init(&tbl_mpp->rhead, &rtw_mesh_rht_params);
adapter->mesh_info.mesh_paths = tbl_path;
adapter->mesh_info.mpp_paths = tbl_mpp;
return 0;
free_path:
rtw_mesh_table_free(tbl_path);
return ret;
}
static
void rtw_mesh_path_tbl_expire(_adapter *adapter,
struct rtw_mesh_table *tbl)
{
struct rtw_mesh_path *mpath;
rtw_rhashtable_iter iter;
int ret;
if (!tbl)
return;
ret = rtw_rhashtable_walk_enter(&tbl->rhead, &iter);
if (ret)
return;
ret = rtw_rhashtable_walk_start(&iter);
if (ret && ret != -EAGAIN)
goto out;
while ((mpath = rtw_rhashtable_walk_next(&iter))) {
if (IS_ERR(mpath) && PTR_ERR(mpath) == -EAGAIN)
continue;
if (IS_ERR(mpath))
break;
if ((!(mpath->flags & RTW_MESH_PATH_RESOLVING)) &&
(!(mpath->flags & RTW_MESH_PATH_FIXED)) &&
rtw_time_after(rtw_get_current_time(), mpath->exp_time + RTW_MESH_PATH_EXPIRE))
__rtw_mesh_path_del(tbl, mpath);
if (mpath->is_gate && /* need not to deal with non-gate case */
rtw_time_after(rtw_get_current_time(), mpath->gate_timeout)) {
RTW_MPATH_DBG(FUNC_ADPT_FMT"mpath [%pM] expired systime is %lu systime is %lu\n",
FUNC_ADPT_ARG(adapter), mpath->dst,
mpath->gate_timeout, rtw_get_current_time());
enter_critical_bh(&mpath->state_lock);
if (mpath->gate_asked) { /* asked gate before */
rtw_mesh_gate_del(tbl, mpath);
exit_critical_bh(&mpath->state_lock);
} else {
mpath->gate_asked = true;
mpath->gate_timeout = rtw_get_current_time() + rtw_ms_to_systime(mpath->gate_ann_int);
exit_critical_bh(&mpath->state_lock);
rtw_mesh_queue_preq(mpath, RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_REFRESH);
RTW_MPATH_DBG(FUNC_ADPT_FMT"mpath [%pM] ask mesh gate existence (is_root=%d)\n",
FUNC_ADPT_ARG(adapter), mpath->dst, mpath->is_root);
}
}
}
out:
rtw_rhashtable_walk_stop(&iter);
rtw_rhashtable_walk_exit(&iter);
}
void rtw_mesh_path_expire(_adapter *adapter)
{
rtw_mesh_path_tbl_expire(adapter, adapter->mesh_info.mesh_paths);
rtw_mesh_path_tbl_expire(adapter, adapter->mesh_info.mpp_paths);
}
void rtw_mesh_pathtbl_unregister(_adapter *adapter)
{
if (adapter->mesh_info.mesh_paths) {
rtw_mesh_table_free(adapter->mesh_info.mesh_paths);
adapter->mesh_info.mesh_paths = NULL;
}
if (adapter->mesh_info.mpp_paths) {
rtw_mesh_table_free(adapter->mesh_info.mpp_paths);
adapter->mesh_info.mpp_paths = NULL;
}
}
#endif /* CONFIG_RTW_MESH */
================================================
FILE: core/mesh/rtw_mesh_pathtbl.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __RTW_MESH_PATHTBL_H_
#define __RTW_MESH_PATHTBL_H_
#ifndef DBG_RTW_MPATH
#define DBG_RTW_MPATH 1
#endif
#if DBG_RTW_MPATH
#define RTW_MPATH_DBG(fmt, arg...) RTW_PRINT(fmt, ##arg)
#else
#define RTW_MPATH_DBG(fmt, arg...) do {} while (0)
#endif
/**
* enum rtw_mesh_path_flags - mesh path flags
*
* @RTW_MESH_PATH_ACTIVE: the mesh path can be used for forwarding
* @RTW_MESH_PATH_RESOLVING: the discovery process is running for this mesh path
* @RTW_MESH_PATH_SN_VALID: the mesh path contains a valid destination sequence
* number
* @RTW_MESH_PATH_FIXED: the mesh path has been manually set and should not be
* modified
* @RTW_MESH_PATH_RESOLVED: the mesh path can has been resolved
* @RTW_MESH_PATH_REQ_QUEUED: there is an unsent path request for this destination
* already queued up, waiting for the discovery process to start.
* @RTW_MESH_PATH_DELETED: the mesh path has been deleted and should no longer
* be used
* @RTW_MESH_PATH_ROOT_ADD_CHK: root additional check in root mode.
* With this flag, It will try the last used rann_snd_addr
* @RTW_MESH_PATH_PEER_AKA: only used toward a peer, only used in active keep
* alive mechanism. PREQ's da = path dst
* @RTW_MESH_PATH_BCAST_PREQ: for re-checking next hop resolve toward root.
* Use it to force path_discover sending broadcast PREQ for root.
*
* RTW_MESH_PATH_RESOLVED is used by the mesh path timer to
* decide when to stop or cancel the mesh path discovery.
*/
enum rtw_mesh_path_flags {
RTW_MESH_PATH_ACTIVE = BIT(0),
RTW_MESH_PATH_RESOLVING = BIT(1),
RTW_MESH_PATH_SN_VALID = BIT(2),
RTW_MESH_PATH_FIXED = BIT(3),
RTW_MESH_PATH_RESOLVED = BIT(4),
RTW_MESH_PATH_REQ_QUEUED = BIT(5),
RTW_MESH_PATH_DELETED = BIT(6),
RTW_MESH_PATH_ROOT_ADD_CHK = BIT(7),
RTW_MESH_PATH_PEER_AKA = BIT(8),
RTW_MESH_PATH_BCAST_PREQ = BIT(9),
};
/**
* struct rtw_mesh_path - mesh path structure
*
* @dst: mesh path destination mac address
* @mpp: mesh proxy mac address
* @rhash: rhashtable list pointer
* @gate_list: list pointer for known gates list
* @sdata: mesh subif
* @next_hop: mesh neighbor to which frames for this destination will be
* forwarded
* @timer: mesh path discovery timer
* @frame_queue: pending queue for frames sent to this destination while the
* path is unresolved
* @rcu: rcu head for freeing mesh path
* @sn: target sequence number
* @metric: current metric to this destination
* @hop_count: hops to destination
* @exp_time: in jiffies, when the path will expire or when it expired
* @discovery_timeout: timeout (lapse in jiffies) used for the last discovery
* retry
* @discovery_retries: number of discovery retries
* @flags: mesh path flags, as specified on &enum rtw_mesh_path_flags
* @state_lock: mesh path state lock used to protect changes to the
* mpath itself. No need to take this lock when adding or removing
* an mpath to a hash bucket on a path table.
* @rann_snd_addr: the RANN sender address
* @rann_metric: the aggregated path metric towards the root node
* @last_preq_to_root: Timestamp of last PREQ sent to root
* @is_root: the destination station of this path is a root node
* @is_gate: the destination station of this path is a mesh gate
*
*
* The dst address is unique in the mesh path table. Since the mesh_path is
* protected by RCU, deleting the next_hop STA must remove / substitute the
* mesh_path structure and wait until that is no longer reachable before
* destroying the STA completely.
*/
struct rtw_mesh_path {
u8 dst[ETH_ALEN];
u8 mpp[ETH_ALEN]; /* used for MPP or MAP */
rtw_rhash_head rhash;
rtw_hlist_node gate_list;
_adapter *adapter;
struct sta_info __rcu *next_hop;
_timer timer;
_queue frame_queue;
u32 frame_queue_len;
rtw_rcu_head rcu;
u32 sn;
u32 metric;
u8 hop_count;
systime exp_time;
systime discovery_timeout;
systime gate_timeout;
u32 gate_ann_int; /* gate announce interval */
u8 discovery_retries;
enum rtw_mesh_path_flags flags;
_lock state_lock;
u8 rann_snd_addr[ETH_ALEN];
#ifdef CONFIG_RTW_MESH_ADD_ROOT_CHK
u8 add_chk_rann_snd_addr[ETH_ALEN];
#endif
u32 rann_metric;
unsigned long last_preq_to_root;
bool is_root;
bool is_gate;
bool gate_asked;
};
/**
* struct rtw_mesh_table
*
* @known_gates: list of known mesh gates and their mpaths by the station. The
* gate's mpath may or may not be resolved and active.
* @gates_lock: protects updates to known_gates
* @rhead: the rhashtable containing struct mesh_paths, keyed by dest addr
* @entries: number of entries in the table
*/
struct rtw_mesh_table {
rtw_hlist_head known_gates;
_lock gates_lock;
rtw_rhashtable rhead;
ATOMIC_T entries;
};
#define RTW_MESH_PATH_EXPIRE (600 * HZ)
/* Maximum number of paths per interface */
#define RTW_MESH_MAX_MPATHS 1024
/* Number of frames buffered per destination for unresolved destinations */
#define RTW_MESH_FRAME_QUEUE_LEN 10
int rtw_mesh_nexthop_lookup(_adapter *adapter,
const u8 *mda, const u8 *msa, u8 *ra);
int rtw_mesh_nexthop_resolve(_adapter *adapter,
struct xmit_frame *xframe);
struct rtw_mesh_path *rtw_mesh_path_lookup(_adapter *adapter,
const u8 *dst);
struct rtw_mesh_path *rtw_mpp_path_lookup(_adapter *adapter,
const u8 *dst);
int rtw_mpp_path_add(_adapter *adapter,
const u8 *dst, const u8 *mpp);
void dump_mpp(void *sel, _adapter *adapter);
struct rtw_mesh_path *
rtw_mesh_path_lookup_by_idx(_adapter *adapter, int idx);
void dump_mpath(void *sel, _adapter *adapter);
struct rtw_mesh_path *
rtw_mpp_path_lookup_by_idx(_adapter *adapter, int idx);
void rtw_mesh_path_fix_nexthop(struct rtw_mesh_path *mpath, struct sta_info *next_hop);
void rtw_mesh_path_expire(_adapter *adapter);
struct rtw_mesh_path *
rtw_mesh_path_add(_adapter *adapter, const u8 *dst);
int rtw_mesh_path_add_gate(struct rtw_mesh_path *mpath);
void rtw_mesh_gate_del(struct rtw_mesh_table *tbl, struct rtw_mesh_path *mpath);
bool rtw_mesh_gate_search(struct rtw_mesh_table *tbl, const u8 *addr);
int rtw_mesh_path_send_to_gates(struct rtw_mesh_path *mpath);
int rtw_mesh_gate_num(_adapter *adapter);
bool rtw_mesh_is_primary_gate(_adapter *adapter);
void dump_known_gates(void *sel, _adapter *adapter);
void rtw_mesh_plink_broken(struct sta_info *sta);
void rtw_mesh_path_assign_nexthop(struct rtw_mesh_path *mpath, struct sta_info *sta);
void rtw_mesh_path_flush_pending(struct rtw_mesh_path *mpath);
void rtw_mesh_path_tx_pending(struct rtw_mesh_path *mpath);
int rtw_mesh_pathtbl_init(_adapter *adapter);
void rtw_mesh_pathtbl_unregister(_adapter *adapter);
int rtw_mesh_path_del(_adapter *adapter, const u8 *addr);
void rtw_mesh_path_flush_by_nexthop(struct sta_info *sta);
void rtw_mesh_path_discard_frame(_adapter *adapter,
struct xmit_frame *xframe);
static inline void rtw_mesh_path_activate(struct rtw_mesh_path *mpath)
{
mpath->flags |= RTW_MESH_PATH_ACTIVE | RTW_MESH_PATH_RESOLVED;
}
void rtw_mesh_path_flush_by_iface(_adapter *adapter);
#endif /* __RTW_MESH_PATHTBL_H_ */
================================================
FILE: core/rtw_ap.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_AP_C_
#include
#include
#ifdef CONFIG_AP_MODE
extern unsigned char RTW_WPA_OUI[];
extern unsigned char WMM_OUI[];
extern unsigned char WPS_OUI[];
extern unsigned char P2P_OUI[];
extern unsigned char WFD_OUI[];
void init_mlme_ap_info(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
_rtw_spinlock_init(&pmlmepriv->bcn_update_lock);
/* pmlmeext->bstart_bss = _FALSE; */
}
void free_mlme_ap_info(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
stop_ap_mode(padapter);
_rtw_spinlock_free(&pmlmepriv->bcn_update_lock);
}
/*
* Set TIM IE
* return length of total TIM IE
*/
u8 rtw_set_tim_ie(u8 dtim_cnt, u8 dtim_period
, const u8 *tim_bmp, u8 tim_bmp_len, u8 *tim_ie)
{
u8 *p = tim_ie;
u8 i, n1, n2;
u8 bmp_len;
if (rtw_bmp_not_empty(tim_bmp, tim_bmp_len)) {
/* find the first nonzero octet in tim_bitmap */
for (i = 0; i < tim_bmp_len; i++)
if (tim_bmp[i])
break;
n1 = i & 0xFE;
/* find the last nonzero octet in tim_bitmap, except octet 0 */
for (i = tim_bmp_len - 1; i > 0; i--)
if (tim_bmp[i])
break;
n2 = i;
bmp_len = n2 - n1 + 1;
} else {
n1 = n2 = 0;
bmp_len = 1;
}
*p++ = WLAN_EID_TIM;
*p++ = 2 + 1 + bmp_len;
*p++ = dtim_cnt;
*p++ = dtim_period;
*p++ = (rtw_bmp_is_set(tim_bmp, tim_bmp_len, 0) ? BIT0 : 0) | n1;
_rtw_memcpy(p, tim_bmp + n1, bmp_len);
#if 0
RTW_INFO("n1:%u, n2:%u, bmp_offset:%u, bmp_len:%u\n", n1, n2, n1 / 2, bmp_len);
RTW_INFO_DUMP("tim_ie: ", tim_ie + 2, 2 + 1 + bmp_len);
#endif
return 2 + 2 + 1 + bmp_len;
}
static void update_BCNTIM(_adapter *padapter)
{
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
unsigned char *pie = pnetwork_mlmeext->IEs;
#if 0
/* update TIM IE */
/* if(rtw_tim_map_anyone_be_set(padapter, pstapriv->tim_bitmap)) */
#endif
if (_TRUE) {
u8 *p, *dst_ie, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
uint offset, tmp_len, tim_ielen, tim_ie_offset, remainder_ielen;
p = rtw_get_ie(pie + _FIXED_IE_LENGTH_, _TIM_IE_, &tim_ielen, pnetwork_mlmeext->IELength - _FIXED_IE_LENGTH_);
if (p != NULL && tim_ielen > 0) {
tim_ielen += 2;
premainder_ie = p + tim_ielen;
tim_ie_offset = (sint)(p - pie);
remainder_ielen = pnetwork_mlmeext->IELength - tim_ie_offset - tim_ielen;
/*append TIM IE from dst_ie offset*/
dst_ie = p;
} else {
tim_ielen = 0;
/*calculate head_len*/
offset = _FIXED_IE_LENGTH_;
/* get ssid_ie len */
p = rtw_get_ie(pie + _BEACON_IE_OFFSET_, _SSID_IE_, &tmp_len, (pnetwork_mlmeext->IELength - _BEACON_IE_OFFSET_));
if (p != NULL)
offset += tmp_len + 2;
/*get supported rates len*/
p = rtw_get_ie(pie + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &tmp_len, (pnetwork_mlmeext->IELength - _BEACON_IE_OFFSET_));
if (p != NULL)
offset += tmp_len + 2;
/*DS Parameter Set IE, len=3*/
offset += 3;
premainder_ie = pie + offset;
remainder_ielen = pnetwork_mlmeext->IELength - offset - tim_ielen;
/*append TIM IE from offset*/
dst_ie = pie + offset;
}
if (remainder_ielen > 0) {
pbackup_remainder_ie = rtw_malloc(remainder_ielen);
if (pbackup_remainder_ie && premainder_ie)
_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
}
/* append TIM IE */
dst_ie += rtw_set_tim_ie(0, 1, pstapriv->tim_bitmap, pstapriv->aid_bmp_len, dst_ie);
/*copy remainder IE*/
if (pbackup_remainder_ie) {
_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
rtw_mfree(pbackup_remainder_ie, remainder_ielen);
}
offset = (uint)(dst_ie - pie);
pnetwork_mlmeext->IELength = offset + remainder_ielen;
}
}
void rtw_add_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index, u8 *data, u8 len)
{
PNDIS_802_11_VARIABLE_IEs pIE;
u8 bmatch = _FALSE;
u8 *pie = pnetwork->IEs;
u8 *p = NULL, *dst_ie = NULL, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
u32 i, offset, ielen, ie_offset, remainder_ielen = 0;
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pnetwork->IELength;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pnetwork->IEs + i);
if (pIE->ElementID > index)
break;
else if (pIE->ElementID == index) { /* already exist the same IE */
p = (u8 *)pIE;
ielen = pIE->Length;
bmatch = _TRUE;
break;
}
p = (u8 *)pIE;
ielen = pIE->Length;
i += (pIE->Length + 2);
}
if (p != NULL && ielen > 0) {
ielen += 2;
premainder_ie = p + ielen;
ie_offset = (sint)(p - pie);
remainder_ielen = pnetwork->IELength - ie_offset - ielen;
if (bmatch)
dst_ie = p;
else
dst_ie = (p + ielen);
}
if (dst_ie == NULL)
return;
if (remainder_ielen > 0) {
pbackup_remainder_ie = rtw_malloc(remainder_ielen);
if (pbackup_remainder_ie && premainder_ie)
_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
}
*dst_ie++ = index;
*dst_ie++ = len;
_rtw_memcpy(dst_ie, data, len);
dst_ie += len;
/* copy remainder IE */
if (pbackup_remainder_ie) {
_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
rtw_mfree(pbackup_remainder_ie, remainder_ielen);
}
offset = (uint)(dst_ie - pie);
pnetwork->IELength = offset + remainder_ielen;
}
void rtw_remove_bcn_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 index)
{
u8 *p, *dst_ie = NULL, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
uint offset, ielen, ie_offset, remainder_ielen = 0;
u8 *pie = pnetwork->IEs;
p = rtw_get_ie(pie + _FIXED_IE_LENGTH_, index, &ielen, pnetwork->IELength - _FIXED_IE_LENGTH_);
if (p != NULL && ielen > 0) {
ielen += 2;
premainder_ie = p + ielen;
ie_offset = (sint)(p - pie);
remainder_ielen = pnetwork->IELength - ie_offset - ielen;
dst_ie = p;
} else
return;
if (remainder_ielen > 0) {
pbackup_remainder_ie = rtw_malloc(remainder_ielen);
if (pbackup_remainder_ie && premainder_ie)
_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
}
/* copy remainder IE */
if (pbackup_remainder_ie) {
_rtw_memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
rtw_mfree(pbackup_remainder_ie, remainder_ielen);
}
offset = (uint)(dst_ie - pie);
pnetwork->IELength = offset + remainder_ielen;
}
u8 chk_sta_is_alive(struct sta_info *psta);
u8 chk_sta_is_alive(struct sta_info *psta)
{
u8 ret = _FALSE;
#ifdef DBG_EXPIRATION_CHK
RTW_INFO("sta:"MAC_FMT", rssi:%d, rx:"STA_PKTS_FMT", expire_to:%u, %s%ssq_len:%u\n"
, MAC_ARG(psta->cmn.mac_addr)
, psta->cmn.rssi_stat.rssi
/* , STA_RX_PKTS_ARG(psta) */
, STA_RX_PKTS_DIFF_ARG(psta)
, psta->expire_to
, psta->state & WIFI_SLEEP_STATE ? "PS, " : ""
, psta->state & WIFI_STA_ALIVE_CHK_STATE ? "SAC, " : ""
, psta->sleepq_len
);
#endif
/* if(sta_last_rx_pkts(psta) == sta_rx_pkts(psta)) */
if ((psta->sta_stats.last_rx_data_pkts + psta->sta_stats.last_rx_ctrl_pkts) == (psta->sta_stats.rx_data_pkts + psta->sta_stats.rx_ctrl_pkts)) {
#if 0
if (psta->state & WIFI_SLEEP_STATE)
ret = _TRUE;
#endif
} else
ret = _TRUE;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(psta->padapter)) {
u8 bcn_alive, hwmp_alive;
hwmp_alive = (psta->sta_stats.rx_hwmp_pkts !=
psta->sta_stats.last_rx_hwmp_pkts);
bcn_alive = (psta->sta_stats.rx_beacon_pkts !=
psta->sta_stats.last_rx_beacon_pkts);
/* The reference for nexthop_lookup */
psta->alive = ret || hwmp_alive || bcn_alive;
/* The reference for expire_timeout_chk */
/* Exclude bcn_alive to avoid a misjudge condition
that a peer unexpectedly leave and restart quickly*/
ret = ret || hwmp_alive;
}
#endif
sta_update_last_rx_pkts(psta);
return ret;
}
/**
* issue_aka_chk_frame - issue active keep alive check frame
* aka = active keep alive
*/
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
static int issue_aka_chk_frame(_adapter *adapter, struct sta_info *psta)
{
int ret = _FAIL;
u8 *target_addr = psta->cmn.mac_addr;
if (MLME_IS_AP(adapter)) {
/* issue null data to check sta alive */
if (psta->state & WIFI_SLEEP_STATE)
ret = issue_nulldata(adapter, target_addr, 0, 1, 50);
else
ret = issue_nulldata(adapter, target_addr, 0, 3, 50);
}
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
struct rtw_mesh_path *mpath;
rtw_rcu_read_lock();
mpath = rtw_mesh_path_lookup(adapter, target_addr);
if (!mpath) {
mpath = rtw_mesh_path_add(adapter, target_addr);
if (IS_ERR(mpath)) {
rtw_rcu_read_unlock();
RTW_ERR(FUNC_ADPT_FMT" rtw_mesh_path_add for "MAC_FMT" fail.\n",
FUNC_ADPT_ARG(adapter), MAC_ARG(target_addr));
return _FAIL;
}
}
if (mpath->flags & RTW_MESH_PATH_ACTIVE)
ret = _SUCCESS;
else {
u8 flags = RTW_PREQ_Q_F_START | RTW_PREQ_Q_F_PEER_AKA;
/* issue PREQ to check peer alive */
rtw_mesh_queue_preq(mpath, flags);
ret = _FALSE;
}
rtw_rcu_read_unlock();
}
#endif
return ret;
}
#endif
#ifdef RTW_CONFIG_RFREG18_WA
static void rtw_check_restore_rf18(_adapter *padapter)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
u32 reg;
u8 union_ch = 0, union_bw = 0, union_offset = 0, setchbw = _FALSE;
reg = rtw_hal_read_rfreg(padapter, 0, 0x18, 0x3FF);
if ((reg & 0xFF) == 0)
setchbw = _TRUE;
reg = rtw_hal_read_rfreg(padapter, 1, 0x18, 0x3FF);
if ((reg & 0xFF) == 0)
setchbw = _TRUE;
if (setchbw) {
if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)) {
RTW_INFO("Hit RF(0x18)=0!! restore original channel setting.\n");
union_ch = pmlmeext->cur_channel;
union_offset = pmlmeext->cur_ch_offset ;
union_bw = pmlmeext->cur_bwmode;
} else {
RTW_INFO("Hit RF(0x18)=0!! set ch(%x) offset(%x) bwmode(%x)\n", union_ch, union_offset, union_bw);
}
/* Initial the channel_bw setting procedure. */
pHalData->current_channel = 0;
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
}
}
#endif
void expire_timeout_chk(_adapter *padapter)
{
_irqL irqL;
_list *phead, *plist;
u8 updated = _FALSE;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 chk_alive_num = 0;
char chk_alive_list[NUM_STA];
int i;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)
&& check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE)
) {
struct rtw_mesh_cfg *mcfg = &padapter->mesh_cfg;
rtw_mesh_path_expire(padapter);
/* TBD: up layer timeout mechanism */
/* if (!mcfg->plink_timeout)
return; */
#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
return;
#endif
}
#endif
#ifdef CONFIG_MCC_MODE
/* then driver may check fail due to not recv client's frame under sitesurvey,
* don't expire timeout chk under MCC under sitesurvey */
if (rtw_hal_mcc_link_status_chk(padapter, __func__) == _FALSE)
return;
#endif
_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
phead = &pstapriv->auth_list;
plist = get_next(phead);
/* check auth_queue */
#ifdef DBG_EXPIRATION_CHK
if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
RTW_INFO(FUNC_ADPT_FMT" auth_list, cnt:%u\n"
, FUNC_ADPT_ARG(padapter), pstapriv->auth_list_cnt);
}
#endif
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, auth_list);
plist = get_next(plist);
#ifdef CONFIG_ATMEL_RC_PATCH
if (_rtw_memcmp((void *)(pstapriv->atmel_rc_pattern), (void *)(psta->cmn.mac_addr), ETH_ALEN) == _TRUE)
continue;
if (psta->flag_atmel_rc)
continue;
#endif
if (psta->expire_to > 0) {
psta->expire_to--;
if (psta->expire_to == 0) {
rtw_list_delete(&psta->auth_list);
pstapriv->auth_list_cnt--;
RTW_INFO(FUNC_ADPT_FMT" auth expire "MAC_FMT"\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
rtw_free_stainfo(padapter, psta);
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
}
}
}
_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
psta = NULL;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
/* check asoc_queue */
#ifdef DBG_EXPIRATION_CHK
if (rtw_end_of_queue_search(phead, plist) == _FALSE) {
RTW_INFO(FUNC_ADPT_FMT" asoc_list, cnt:%u\n"
, FUNC_ADPT_ARG(padapter), pstapriv->asoc_list_cnt);
}
#endif
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
#ifdef CONFIG_ATMEL_RC_PATCH
RTW_INFO("%s:%d psta=%p, %02x,%02x||%02x,%02x \n\n", __func__, __LINE__,
psta, pstapriv->atmel_rc_pattern[0], pstapriv->atmel_rc_pattern[5], psta->cmn.mac_addr[0], psta->cmn.mac_addr[5]);
if (_rtw_memcmp((void *)pstapriv->atmel_rc_pattern, (void *)(psta->cmn.mac_addr), ETH_ALEN) == _TRUE)
continue;
if (psta->flag_atmel_rc)
continue;
RTW_INFO("%s: debug line:%d\n", __func__, __LINE__);
#endif
#ifdef CONFIG_AUTO_AP_MODE
if (psta->isrc)
continue;
#endif
if (chk_sta_is_alive(psta) || !psta->expire_to) {
psta->expire_to = pstapriv->expire_to;
psta->keep_alive_trycnt = 0;
#ifdef CONFIG_TX_MCAST2UNI
psta->under_exist_checking = 0;
#endif /* CONFIG_TX_MCAST2UNI */
} else
psta->expire_to--;
#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_TX_MCAST2UNI
if ((psta->flags & WLAN_STA_HT) && (psta->htpriv.agg_enable_bitmap || psta->under_exist_checking)) {
/* check sta by delba(addba) for 11n STA */
/* ToDo: use CCX report to check for all STAs */
/* RTW_INFO("asoc check by DELBA/ADDBA! (pstapriv->expire_to=%d s)(psta->expire_to=%d s), [%02x, %d]\n", pstapriv->expire_to*2, psta->expire_to*2, psta->htpriv.agg_enable_bitmap, psta->under_exist_checking); */
if (psta->expire_to <= (pstapriv->expire_to - 50)) {
RTW_INFO("asoc expire by DELBA/ADDBA! (%d s)\n", (pstapriv->expire_to - psta->expire_to) * 2);
psta->under_exist_checking = 0;
psta->expire_to = 0;
} else if (psta->expire_to <= (pstapriv->expire_to - 3) && (psta->under_exist_checking == 0)) {
RTW_INFO("asoc check by DELBA/ADDBA! (%d s)\n", (pstapriv->expire_to - psta->expire_to) * 2);
psta->under_exist_checking = 1;
/* tear down TX AMPDU */
send_delba(padapter, 1, psta->cmn.mac_addr);/* */ /* originator */
psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
}
}
#endif /* CONFIG_TX_MCAST2UNI */
#endif /* CONFIG_80211N_HT */
#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
if (psta->expire_to <= 0) {
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
if (padapter->registrypriv.wifi_spec == 1) {
psta->expire_to = pstapriv->expire_to;
continue;
}
#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
#ifdef CONFIG_80211N_HT
#define KEEP_ALIVE_TRYCNT (3)
if (psta->keep_alive_trycnt > 0 && psta->keep_alive_trycnt <= KEEP_ALIVE_TRYCNT) {
if (psta->state & WIFI_STA_ALIVE_CHK_STATE)
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
else
psta->keep_alive_trycnt = 0;
} else if ((psta->keep_alive_trycnt > KEEP_ALIVE_TRYCNT) && !(psta->state & WIFI_STA_ALIVE_CHK_STATE))
psta->keep_alive_trycnt = 0;
if ((psta->htpriv.ht_option == _TRUE) && (psta->htpriv.ampdu_enable == _TRUE)) {
uint priority = 1; /* test using BK */
u8 issued = 0;
/* issued = (psta->htpriv.agg_enable_bitmap>>priority)&0x1; */
issued |= (psta->htpriv.candidate_tid_bitmap >> priority) & 0x1;
if (0 == issued) {
if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE)) {
psta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
if (psta->state & WIFI_SLEEP_STATE)
psta->expire_to = 2; /* 2x2=4 sec */
else
psta->expire_to = 1; /* 2 sec */
psta->state |= WIFI_STA_ALIVE_CHK_STATE;
/* add_ba_hdl(padapter, (u8*)paddbareq_parm); */
RTW_INFO("issue addba_req to check if sta alive, keep_alive_trycnt=%d\n", psta->keep_alive_trycnt);
issue_addba_req(padapter, psta->cmn.mac_addr, (u8)priority);
_set_timer(&psta->addba_retry_timer, ADDBA_TO);
psta->keep_alive_trycnt++;
continue;
}
}
}
if (psta->keep_alive_trycnt > 0 && psta->state & WIFI_STA_ALIVE_CHK_STATE) {
psta->keep_alive_trycnt = 0;
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
RTW_INFO("change to another methods to check alive if staion is at ps mode\n");
}
#endif /* CONFIG_80211N_HT */
#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
if (psta->state & WIFI_SLEEP_STATE) {
if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE)) {
/* to check if alive by another methods if staion is at ps mode. */
psta->expire_to = pstapriv->expire_to;
psta->state |= WIFI_STA_ALIVE_CHK_STATE;
/* RTW_INFO("alive chk, sta:" MAC_FMT " is at ps mode!\n", MAC_ARG(psta->cmn.mac_addr)); */
/* to update bcn with tim_bitmap for this station */
rtw_tim_map_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0);
if (!pmlmeext->active_keep_alive_check)
continue;
}
}
{
int stainfo_offset;
stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
if (stainfo_offset_valid(stainfo_offset))
chk_alive_list[chk_alive_num++] = stainfo_offset;
continue;
}
} else {
/* TODO: Aging mechanism to digest frames in sleep_q to avoid running out of xmitframe */
if (psta->sleepq_len > (NR_XMITFRAME / pstapriv->asoc_list_cnt)
&& padapter->xmitpriv.free_xmitframe_cnt < ((NR_XMITFRAME / pstapriv->asoc_list_cnt) / 2)
) {
RTW_INFO(FUNC_ADPT_FMT" sta:"MAC_FMT", sleepq_len:%u, free_xmitframe_cnt:%u, asoc_list_cnt:%u, clear sleep_q\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr)
, psta->sleepq_len, padapter->xmitpriv.free_xmitframe_cnt, pstapriv->asoc_list_cnt);
wakeup_sta_to_xmit(padapter, psta);
}
}
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (chk_alive_num) {
#if defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK)
u8 backup_ch = 0, backup_bw = 0, backup_offset = 0;
u8 union_ch = 0, union_bw = 0, union_offset = 0;
u8 switch_channel_by_drv = _TRUE;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
#endif
char del_asoc_list[NUM_STA];
_rtw_memset(del_asoc_list, NUM_STA, NUM_STA);
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
if (pmlmeext->active_keep_alive_check) {
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter)) {
/* driver doesn't switch channel under MCC */
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
switch_channel_by_drv = _FALSE;
}
#endif
if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
|| pmlmeext->cur_channel != union_ch)
switch_channel_by_drv = _FALSE;
/* switch to correct channel of current network before issue keep-alive frames */
if (switch_channel_by_drv == _TRUE && rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
backup_ch = rtw_get_oper_ch(padapter);
backup_bw = rtw_get_oper_bw(padapter);
backup_offset = rtw_get_oper_choffset(padapter);
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
}
}
#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
/* check loop */
for (i = 0; i < chk_alive_num; i++) {
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
int ret = _FAIL;
#endif
psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
#ifdef CONFIG_ATMEL_RC_PATCH
if (_rtw_memcmp(pstapriv->atmel_rc_pattern, psta->cmn.mac_addr, ETH_ALEN) == _TRUE)
continue;
if (psta->flag_atmel_rc)
continue;
#endif
if (!(psta->state & _FW_LINKED))
continue;
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
if (pmlmeext->active_keep_alive_check) {
/* issue active keep alive frame to check */
ret = issue_aka_chk_frame(padapter, psta);
psta->keep_alive_trycnt++;
if (ret == _SUCCESS) {
RTW_INFO(FUNC_ADPT_FMT" asoc check, "MAC_FMT" is alive\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
psta->expire_to = pstapriv->expire_to;
psta->keep_alive_trycnt = 0;
continue;
} else if (psta->keep_alive_trycnt <= 3) {
RTW_INFO(FUNC_ADPT_FMT" asoc check, "MAC_FMT" keep_alive_trycnt=%d\n"
, FUNC_ADPT_ARG(padapter) , MAC_ARG(psta->cmn.mac_addr), psta->keep_alive_trycnt);
psta->expire_to = 1;
continue;
}
}
#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
psta->keep_alive_trycnt = 0;
del_asoc_list[i] = chk_alive_list[i];
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
rtw_list_delete(&psta->asoc_list);
pstapriv->asoc_list_cnt--;
STA_SET_MESH_PLINK(psta, NULL);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
}
/* delete loop */
for (i = 0; i < chk_alive_num; i++) {
u8 sta_addr[ETH_ALEN];
if (del_asoc_list[i] >= NUM_STA)
continue;
psta = rtw_get_stainfo_by_offset(pstapriv, del_asoc_list[i]);
_rtw_memcpy(sta_addr, psta->cmn.mac_addr, ETH_ALEN);
RTW_INFO(FUNC_ADPT_FMT" asoc expire "MAC_FMT", state=0x%x\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr), psta->state);
updated |= ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_DEAUTH_LEAVING, _FALSE);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter))
rtw_mesh_expire_peer(padapter, sta_addr);
#endif
}
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
if (pmlmeext->active_keep_alive_check) {
/* back to the original operation channel */
if (switch_channel_by_drv == _TRUE && backup_ch > 0)
set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
}
#endif
}
#ifdef RTW_CONFIG_RFREG18_WA
rtw_check_restore_rf18(padapter);
#endif
associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
}
void rtw_ap_update_sta_ra_info(_adapter *padapter, struct sta_info *psta)
{
unsigned char sta_band = 0;
u64 tx_ra_bitmap = 0;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
if (!psta)
return;
if (!(psta->state & _FW_LINKED))
return;
rtw_hal_update_sta_ra_info(padapter, psta);
tx_ra_bitmap = psta->cmn.ra_info.ramask;
if (pcur_network->Configuration.DSConfig > 14) {
if (tx_ra_bitmap & 0xffff000)
sta_band |= WIRELESS_11_5N;
if (tx_ra_bitmap & 0xff0)
sta_band |= WIRELESS_11A;
/* 5G band */
#ifdef CONFIG_80211AC_VHT
if (psta->vhtpriv.vht_option)
sta_band = WIRELESS_11_5AC;
#endif
} else {
if (tx_ra_bitmap & 0xffff000)
sta_band |= WIRELESS_11_24N;
if (tx_ra_bitmap & 0xff0)
sta_band |= WIRELESS_11G;
if (tx_ra_bitmap & 0x0f)
sta_band |= WIRELESS_11B;
}
psta->wireless_mode = sta_band;
rtw_hal_update_sta_wset(padapter, psta);
RTW_INFO("%s=> mac_id:%d , tx_ra_bitmap:0x%016llx, networkType:0x%02x\n",
__FUNCTION__, psta->cmn.mac_id, tx_ra_bitmap, psta->wireless_mode);
}
#ifdef CONFIG_BMC_TX_RATE_SELECT
u8 rtw_ap_find_mini_tx_rate(_adapter *adapter)
{
_irqL irqL;
_list *phead, *plist;
u8 miini_tx_rate = ODM_RATEVHTSS4MCS9, sta_tx_rate;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &adapter->stapriv;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
sta_tx_rate = psta->cmn.ra_info.curr_tx_rate & 0x7F;
if (sta_tx_rate < miini_tx_rate)
miini_tx_rate = sta_tx_rate;
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
return miini_tx_rate;
}
u8 rtw_ap_find_bmc_rate(_adapter *adapter, u8 tx_rate)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
u8 tx_ini_rate = ODM_RATE6M;
switch (tx_rate) {
case ODM_RATEVHTSS3MCS9:
case ODM_RATEVHTSS3MCS8:
case ODM_RATEVHTSS3MCS7:
case ODM_RATEVHTSS3MCS6:
case ODM_RATEVHTSS3MCS5:
case ODM_RATEVHTSS3MCS4:
case ODM_RATEVHTSS3MCS3:
case ODM_RATEVHTSS2MCS9:
case ODM_RATEVHTSS2MCS8:
case ODM_RATEVHTSS2MCS7:
case ODM_RATEVHTSS2MCS6:
case ODM_RATEVHTSS2MCS5:
case ODM_RATEVHTSS2MCS4:
case ODM_RATEVHTSS2MCS3:
case ODM_RATEVHTSS1MCS9:
case ODM_RATEVHTSS1MCS8:
case ODM_RATEVHTSS1MCS7:
case ODM_RATEVHTSS1MCS6:
case ODM_RATEVHTSS1MCS5:
case ODM_RATEVHTSS1MCS4:
case ODM_RATEVHTSS1MCS3:
case ODM_RATEMCS15:
case ODM_RATEMCS14:
case ODM_RATEMCS13:
case ODM_RATEMCS12:
case ODM_RATEMCS11:
case ODM_RATEMCS7:
case ODM_RATEMCS6:
case ODM_RATEMCS5:
case ODM_RATEMCS4:
case ODM_RATEMCS3:
case ODM_RATE54M:
case ODM_RATE48M:
case ODM_RATE36M:
case ODM_RATE24M:
tx_ini_rate = ODM_RATE24M;
break;
case ODM_RATEVHTSS3MCS2:
case ODM_RATEVHTSS3MCS1:
case ODM_RATEVHTSS2MCS2:
case ODM_RATEVHTSS2MCS1:
case ODM_RATEVHTSS1MCS2:
case ODM_RATEVHTSS1MCS1:
case ODM_RATEMCS10:
case ODM_RATEMCS9:
case ODM_RATEMCS2:
case ODM_RATEMCS1:
case ODM_RATE18M:
case ODM_RATE12M:
tx_ini_rate = ODM_RATE12M;
break;
case ODM_RATEVHTSS3MCS0:
case ODM_RATEVHTSS2MCS0:
case ODM_RATEVHTSS1MCS0:
case ODM_RATEMCS8:
case ODM_RATEMCS0:
case ODM_RATE9M:
case ODM_RATE6M:
tx_ini_rate = ODM_RATE6M;
break;
case ODM_RATE11M:
case ODM_RATE5_5M:
case ODM_RATE2M:
case ODM_RATE1M:
tx_ini_rate = ODM_RATE1M;
break;
default:
tx_ini_rate = ODM_RATE6M;
break;
}
if (hal_data->current_band_type == BAND_ON_5G)
if (tx_ini_rate < ODM_RATE6M)
tx_ini_rate = ODM_RATE6M;
return tx_ini_rate;
}
void rtw_update_bmc_sta_tx_rate(_adapter *adapter)
{
struct sta_info *psta = NULL;
u8 tx_rate;
psta = rtw_get_bcmc_stainfo(adapter);
if (psta == NULL) {
RTW_ERR(ADPT_FMT "could not get bmc_sta !!\n", ADPT_ARG(adapter));
return;
}
if (adapter->bmc_tx_rate != MGN_UNKNOWN) {
psta->init_rate = adapter->bmc_tx_rate;
goto _exit;
}
if (adapter->stapriv.asoc_sta_count <= 2)
goto _exit;
tx_rate = rtw_ap_find_mini_tx_rate(adapter);
#ifdef CONFIG_BMC_TX_LOW_RATE
tx_rate = rtw_ap_find_bmc_rate(adapter, tx_rate);
#endif
psta->init_rate = hw_rate_to_m_rate(tx_rate);
_exit:
RTW_INFO(ADPT_FMT" BMC Tx rate - %s\n", ADPT_ARG(adapter), MGN_RATE_STR(psta->init_rate));
}
#endif
void rtw_init_bmc_sta_tx_rate(_adapter *padapter, struct sta_info *psta)
{
#ifdef CONFIG_BMC_TX_LOW_RATE
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
#endif
u8 rate_idx = 0;
u8 brate_table[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M,
MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M};
if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
return;
if (padapter->bmc_tx_rate != MGN_UNKNOWN)
psta->init_rate = padapter->bmc_tx_rate;
else {
#ifdef CONFIG_BMC_TX_LOW_RATE
if (IsEnableHWOFDM(pmlmeext->cur_wireless_mode) && (psta->cmn.ra_info.ramask && 0xFF0))
rate_idx = get_lowest_rate_idx_ex(psta->cmn.ra_info.ramask, 4); /*from basic rate*/
else
rate_idx = get_lowest_rate_idx(psta->cmn.ra_info.ramask); /*from basic rate*/
#else
rate_idx = get_highest_rate_idx(psta->cmn.ra_info.ramask); /*from basic rate*/
#endif
if (rate_idx < 12)
psta->init_rate = brate_table[rate_idx];
else
psta->init_rate = MGN_1M;
}
RTW_INFO(ADPT_FMT" BMC Init Tx rate - %s\n", ADPT_ARG(padapter), MGN_RATE_STR(psta->init_rate));
}
void update_bmc_sta(_adapter *padapter)
{
_irqL irqL;
unsigned char network_type;
int supportRateNum = 0;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
WLAN_BSSID_EX *pcur_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
struct sta_info *psta = rtw_get_bcmc_stainfo(padapter);
if (psta) {
psta->cmn.aid = 0;/* default set to 0 */
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter))
psta->qos_option = 1;
else
#endif
psta->qos_option = 0;
#ifdef CONFIG_80211N_HT
psta->htpriv.ht_option = _FALSE;
#endif /* CONFIG_80211N_HT */
psta->ieee8021x_blocked = 0;
_rtw_memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
/* psta->dot118021XPrivacy = _NO_PRIVACY_; */ /* !!! remove it, because it has been set before this. */
supportRateNum = rtw_get_rateset_len((u8 *)&pcur_network->SupportedRates);
network_type = rtw_check_network_type((u8 *)&pcur_network->SupportedRates, supportRateNum, pcur_network->Configuration.DSConfig);
if (IsSupportedTxCCK(network_type))
network_type = WIRELESS_11B;
else if (network_type == WIRELESS_INVALID) { /* error handling */
if (pcur_network->Configuration.DSConfig > 14)
network_type = WIRELESS_11A;
else
network_type = WIRELESS_11B;
}
update_sta_basic_rate(psta, network_type);
psta->wireless_mode = network_type;
rtw_hal_update_sta_ra_info(padapter, psta);
_enter_critical_bh(&psta->lock, &irqL);
psta->state = _FW_LINKED;
_exit_critical_bh(&psta->lock, &irqL);
rtw_sta_media_status_rpt(padapter, psta, 1);
rtw_init_bmc_sta_tx_rate(padapter, psta);
} else
RTW_INFO("add_RATid_bmc_sta error!\n");
}
#if defined(CONFIG_80211N_HT) && defined(CONFIG_BEAMFORMING)
void update_sta_info_apmode_ht_bf_cap(_adapter *padapter, struct sta_info *psta)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct ht_priv *phtpriv_ap = &pmlmepriv->htpriv;
struct ht_priv *phtpriv_sta = &psta->htpriv;
u8 cur_beamform_cap = 0;
/*Config Tx beamforming setting*/
if (TEST_FLAG(phtpriv_ap->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP((u8 *)(&phtpriv_sta->ht_cap))) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
/*Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS((u8 *)(&phtpriv_sta->ht_cap)) << 6);
}
if (TEST_FLAG(phtpriv_ap->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP((u8 *)(&phtpriv_sta->ht_cap))) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
/*Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS((u8 *)(&phtpriv_sta->ht_cap)) << 4);
}
if (cur_beamform_cap)
RTW_INFO("Client STA(%d) HT Beamforming Cap = 0x%02X\n", psta->cmn.aid, cur_beamform_cap);
phtpriv_sta->beamform_cap = cur_beamform_cap;
psta->cmn.bf_info.ht_beamform_cap = cur_beamform_cap;
}
#endif /*CONFIG_80211N_HT && CONFIG_BEAMFORMING*/
/* notes:
* AID: 1~MAX for sta and 0 for bc/mc in ap/adhoc mode */
void update_sta_info_apmode(_adapter *padapter, struct sta_info *psta)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
#ifdef CONFIG_80211N_HT
struct ht_priv *phtpriv_ap = &pmlmepriv->htpriv;
struct ht_priv *phtpriv_sta = &psta->htpriv;
#endif /* CONFIG_80211N_HT */
u8 cur_ldpc_cap = 0, cur_stbc_cap = 0;
/* set intf_tag to if1 */
/* psta->intf_tag = 0; */
RTW_INFO("%s\n", __FUNCTION__);
/*alloc macid when call rtw_alloc_stainfo(),release macid when call rtw_free_stainfo()*/
if (!MLME_IS_MESH(padapter) && psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
psta->ieee8021x_blocked = _TRUE;
else
psta->ieee8021x_blocked = _FALSE;
/* update sta's cap */
/* ERP */
VCS_update(padapter, psta);
#ifdef CONFIG_80211N_HT
/* HT related cap */
if (phtpriv_sta->ht_option) {
/* check if sta supports rx ampdu */
phtpriv_sta->ampdu_enable = phtpriv_ap->ampdu_enable;
phtpriv_sta->rx_ampdu_min_spacing = (phtpriv_sta->ht_cap.ampdu_params_info & IEEE80211_HT_CAP_AMPDU_DENSITY) >> 2;
/* bwmode */
if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH))
psta->cmn.bw_mode = CHANNEL_WIDTH_40;
else
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
if (phtpriv_sta->op_present
&& !GET_HT_OP_ELE_STA_CHL_WIDTH(phtpriv_sta->ht_op))
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
if (psta->ht_40mhz_intolerant)
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
if (pmlmeext->cur_bwmode < psta->cmn.bw_mode)
psta->cmn.bw_mode = pmlmeext->cur_bwmode;
phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;
/* check if sta support s Short GI 20M */
if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
phtpriv_sta->sgi_20m = _TRUE;
/* check if sta support s Short GI 40M */
if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_40)) {
if (psta->cmn.bw_mode == CHANNEL_WIDTH_40) /* according to psta->bw_mode */
phtpriv_sta->sgi_40m = _TRUE;
else
phtpriv_sta->sgi_40m = _FALSE;
}
psta->qos_option = _TRUE;
/* B0 Config LDPC Coding Capability */
if (TEST_FLAG(phtpriv_ap->ldpc_cap, LDPC_HT_ENABLE_TX) &&
GET_HT_CAP_ELE_LDPC_CAP((u8 *)(&phtpriv_sta->ht_cap))) {
SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
RTW_INFO("Enable HT Tx LDPC for STA(%d)\n", psta->cmn.aid);
}
/* B7 B8 B9 Config STBC setting */
if (TEST_FLAG(phtpriv_ap->stbc_cap, STBC_HT_ENABLE_TX) &&
GET_HT_CAP_ELE_RX_STBC((u8 *)(&phtpriv_sta->ht_cap))) {
SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
RTW_INFO("Enable HT Tx STBC for STA(%d)\n", psta->cmn.aid);
}
#ifdef CONFIG_BEAMFORMING
update_sta_info_apmode_ht_bf_cap(padapter, psta);
#endif
} else {
phtpriv_sta->ampdu_enable = _FALSE;
phtpriv_sta->sgi_20m = _FALSE;
phtpriv_sta->sgi_40m = _FALSE;
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
phtpriv_sta->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
phtpriv_sta->ldpc_cap = cur_ldpc_cap;
phtpriv_sta->stbc_cap = cur_stbc_cap;
/* Rx AMPDU */
send_delba(padapter, 0, psta->cmn.mac_addr);/* recipient */
/* TX AMPDU */
send_delba(padapter, 1, psta->cmn.mac_addr);/* */ /* originator */
phtpriv_sta->agg_enable_bitmap = 0x0;/* reset */
phtpriv_sta->candidate_tid_bitmap = 0x0;/* reset */
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
update_sta_vht_info_apmode(padapter, psta);
#endif
psta->cmn.ra_info.is_support_sgi = query_ra_short_GI(psta, rtw_get_tx_bw_mode(padapter, psta));
update_ldpc_stbc_cap(psta);
/* todo: init other variables */
_rtw_memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
/* add ratid */
/* add_RATid(padapter, psta); */ /* move to ap_sta_info_defer_update() */
/* ap mode */
rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
_enter_critical_bh(&psta->lock, &irqL);
/* Check encryption */
if (!MLME_IS_MESH(padapter) && psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
psta->state |= WIFI_UNDER_KEY_HANDSHAKE;
psta->state |= _FW_LINKED;
_exit_critical_bh(&psta->lock, &irqL);
}
static void update_ap_info(_adapter *padapter, struct sta_info *psta)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
#ifdef CONFIG_80211N_HT
struct ht_priv *phtpriv_ap = &pmlmepriv->htpriv;
#endif /* CONFIG_80211N_HT */
psta->wireless_mode = pmlmeext->cur_wireless_mode;
psta->bssratelen = rtw_get_rateset_len(pnetwork->SupportedRates);
_rtw_memcpy(psta->bssrateset, pnetwork->SupportedRates, psta->bssratelen);
#ifdef CONFIG_80211N_HT
/* HT related cap */
if (phtpriv_ap->ht_option) {
/* check if sta supports rx ampdu */
/* phtpriv_ap->ampdu_enable = phtpriv_ap->ampdu_enable; */
/* check if sta support s Short GI 20M */
if ((phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20))
phtpriv_ap->sgi_20m = _TRUE;
/* check if sta support s Short GI 40M */
if ((phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_40))
phtpriv_ap->sgi_40m = _TRUE;
psta->qos_option = _TRUE;
} else {
phtpriv_ap->ampdu_enable = _FALSE;
phtpriv_ap->sgi_20m = _FALSE;
phtpriv_ap->sgi_40m = _FALSE;
}
psta->cmn.bw_mode = pmlmeext->cur_bwmode;
phtpriv_ap->ch_offset = pmlmeext->cur_ch_offset;
phtpriv_ap->agg_enable_bitmap = 0x0;/* reset */
phtpriv_ap->candidate_tid_bitmap = 0x0;/* reset */
_rtw_memcpy(&psta->htpriv, &pmlmepriv->htpriv, sizeof(struct ht_priv));
#ifdef CONFIG_80211AC_VHT
_rtw_memcpy(&psta->vhtpriv, &pmlmepriv->vhtpriv, sizeof(struct vht_priv));
#endif /* CONFIG_80211AC_VHT */
#endif /* CONFIG_80211N_HT */
psta->state |= WIFI_AP_STATE; /* Aries, add,fix bug of flush_cam_entry at STOP AP mode , 0724 */
}
static void rtw_set_hw_wmm_param(_adapter *padapter)
{
u8 AIFS, ECWMin, ECWMax, aSifsTime;
u8 acm_mask;
u16 TXOP;
u32 acParm, i;
u32 edca[4], inx[4];
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct registry_priv *pregpriv = &padapter->registrypriv;
acm_mask = 0;
#ifdef CONFIG_80211N_HT
if (pregpriv->ht_enable &&
(is_supported_5g(pmlmeext->cur_wireless_mode) ||
(pmlmeext->cur_wireless_mode & WIRELESS_11_24N)))
aSifsTime = 16;
else
#endif /* CONFIG_80211N_HT */
aSifsTime = 10;
if (pmlmeinfo->WMM_enable == 0) {
padapter->mlmepriv.acm_mask = 0;
AIFS = aSifsTime + (2 * pmlmeinfo->slotTime);
if (pmlmeext->cur_wireless_mode & (WIRELESS_11G | WIRELESS_11A)) {
ECWMin = 4;
ECWMax = 10;
} else if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
ECWMin = 5;
ECWMax = 10;
} else {
ECWMin = 4;
ECWMax = 10;
}
TXOP = 0;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
ECWMin = 2;
ECWMax = 3;
TXOP = 0x2f;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
} else {
edca[0] = edca[1] = edca[2] = edca[3] = 0;
/*TODO:*/
acm_mask = 0;
padapter->mlmepriv.acm_mask = acm_mask;
#if 0
/* BK */
/* AIFS = AIFSN * slot time + SIFS - r2t phy delay */
#endif
AIFS = (7 * pmlmeinfo->slotTime) + aSifsTime;
ECWMin = 4;
ECWMax = 10;
TXOP = 0;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
edca[XMIT_BK_QUEUE] = acParm;
RTW_INFO("WMM(BK): %x\n", acParm);
/* BE */
AIFS = (3 * pmlmeinfo->slotTime) + aSifsTime;
ECWMin = 4;
ECWMax = 6;
TXOP = 0;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
edca[XMIT_BE_QUEUE] = acParm;
RTW_INFO("WMM(BE): %x\n", acParm);
/* VI */
AIFS = (1 * pmlmeinfo->slotTime) + aSifsTime;
ECWMin = 3;
ECWMax = 4;
TXOP = 94;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
edca[XMIT_VI_QUEUE] = acParm;
RTW_INFO("WMM(VI): %x\n", acParm);
/* VO */
AIFS = (1 * pmlmeinfo->slotTime) + aSifsTime;
ECWMin = 2;
ECWMax = 3;
TXOP = 47;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
edca[XMIT_VO_QUEUE] = acParm;
RTW_INFO("WMM(VO): %x\n", acParm);
if (padapter->registrypriv.acm_method == 1)
rtw_hal_set_hwreg(padapter, HW_VAR_ACM_CTRL, (u8 *)(&acm_mask));
else
padapter->mlmepriv.acm_mask = acm_mask;
inx[0] = 0;
inx[1] = 1;
inx[2] = 2;
inx[3] = 3;
if (pregpriv->wifi_spec == 1) {
u32 j, tmp, change_inx = _FALSE;
/* entry indx: 0->vo, 1->vi, 2->be, 3->bk. */
for (i = 0 ; i < 4 ; i++) {
for (j = i + 1 ; j < 4 ; j++) {
/* compare CW and AIFS */
if ((edca[j] & 0xFFFF) < (edca[i] & 0xFFFF))
change_inx = _TRUE;
else if ((edca[j] & 0xFFFF) == (edca[i] & 0xFFFF)) {
/* compare TXOP */
if ((edca[j] >> 16) > (edca[i] >> 16))
change_inx = _TRUE;
}
if (change_inx) {
tmp = edca[i];
edca[i] = edca[j];
edca[j] = tmp;
tmp = inx[i];
inx[i] = inx[j];
inx[j] = tmp;
change_inx = _FALSE;
}
}
}
}
for (i = 0 ; i < 4 ; i++) {
pxmitpriv->wmm_para_seq[i] = inx[i];
RTW_INFO("wmm_para_seq(%d): %d\n", i, pxmitpriv->wmm_para_seq[i]);
}
}
}
#ifdef CONFIG_80211N_HT
static void update_hw_ht_param(_adapter *padapter)
{
unsigned char max_AMPDU_len;
unsigned char min_MPDU_spacing;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
RTW_INFO("%s\n", __FUNCTION__);
/* handle A-MPDU parameter field */
/*
AMPDU_para [1:0]:Max AMPDU Len => 0:8k , 1:16k, 2:32k, 3:64k
AMPDU_para [4:2]:Min MPDU Start Spacing
*/
max_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
/* */
/* Config SM Power Save setting */
/* */
pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC) {
#if 0
u8 i;
/* update the MCS rates */
for (i = 0; i < 16; i++)
pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
#endif
RTW_INFO("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __FUNCTION__);
}
/* */
/* Config current HT Protection mode. */
/* */
/* pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3; */
}
#endif /* CONFIG_80211N_HT */
static void rtw_ap_check_scan(_adapter *padapter)
{
_irqL irqL;
_list *plist, *phead;
u32 delta_time, lifetime;
struct wlan_network *pnetwork = NULL;
WLAN_BSSID_EX *pbss = NULL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
_queue *queue = &(pmlmepriv->scanned_queue);
u8 do_scan = _FALSE;
u8 reason = RTW_AUTO_SCAN_REASON_UNSPECIFIED;
lifetime = SCANQUEUE_LIFETIME; /* 20 sec */
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
if (rtw_end_of_queue_search(phead, get_next(phead)) == _TRUE)
if (padapter->registrypriv.wifi_spec) {
do_scan = _TRUE;
reason |= RTW_AUTO_SCAN_REASON_2040_BSS;
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
#ifdef CONFIG_RTW_ACS
if (padapter->registrypriv.acs_auto_scan) {
do_scan = _TRUE;
reason |= RTW_AUTO_SCAN_REASON_ACS;
rtw_acs_start(padapter);
}
#endif/*CONFIG_RTW_ACS*/
if (_TRUE == do_scan) {
RTW_INFO("%s : drv scans by itself and wait_completed\n", __func__);
rtw_drv_scan_by_self(padapter, reason);
rtw_scan_wait_completed(padapter);
}
#ifdef CONFIG_RTW_ACS
if (padapter->registrypriv.acs_auto_scan)
rtw_acs_stop(padapter);
#endif
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
if (rtw_chset_search_ch(adapter_to_chset(padapter), pnetwork->network.Configuration.DSConfig) >= 0
&& rtw_mlme_band_check(padapter, pnetwork->network.Configuration.DSConfig) == _TRUE
&& _TRUE == rtw_validate_ssid(&(pnetwork->network.Ssid))) {
delta_time = (u32) rtw_get_passing_time_ms(pnetwork->last_scanned);
if (delta_time < lifetime) {
uint ie_len = 0;
u8 *pbuf = NULL;
u8 *ie = NULL;
pbss = &pnetwork->network;
ie = pbss->IEs;
/*check if HT CAP INFO IE exists or not*/
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss->IELength - _BEACON_IE_OFFSET_));
if (pbuf == NULL) {
/* HT CAP INFO IE don't exist, it is b/g mode bss.*/
if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc))
ATOMIC_SET(&pmlmepriv->olbc, _TRUE);
if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc_ht))
ATOMIC_SET(&pmlmepriv->olbc_ht, _TRUE);
if (padapter->registrypriv.wifi_spec)
RTW_INFO("%s: %s is a/b/g ap\n", __func__, pnetwork->network.Ssid.Ssid);
}
}
}
plist = get_next(plist);
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
#ifdef CONFIG_80211N_HT
pmlmepriv->num_sta_no_ht = 0; /* reset to 0 after ap do scanning*/
#endif
}
void rtw_start_bss_hdl_after_chbw_decided(_adapter *adapter)
{
WLAN_BSSID_EX *pnetwork = &(adapter->mlmepriv.cur_network.network);
struct sta_info *sta = NULL;
/* update cur_wireless_mode */
update_wireless_mode(adapter);
/* update RRSR and RTS_INIT_RATE register after set channel and bandwidth */
UpdateBrateTbl(adapter, pnetwork->SupportedRates);
rtw_hal_set_hwreg(adapter, HW_VAR_BASIC_RATE, pnetwork->SupportedRates);
/* update capability after cur_wireless_mode updated */
update_capinfo(adapter, rtw_get_capability(pnetwork));
/* update bc/mc sta_info */
update_bmc_sta(adapter);
/* update AP's sta info */
sta = rtw_get_stainfo(&adapter->stapriv, pnetwork->MacAddress);
if (!sta) {
RTW_INFO(FUNC_ADPT_FMT" !sta for macaddr="MAC_FMT"\n", FUNC_ADPT_ARG(adapter), MAC_ARG(pnetwork->MacAddress));
rtw_warn_on(1);
return;
}
update_ap_info(adapter, sta);
}
#ifdef CONFIG_FW_HANDLE_TXBCN
bool rtw_ap_nums_check(_adapter *adapter)
{
if (rtw_ap_get_nums(adapter) < CONFIG_LIMITED_AP_NUM)
return _TRUE;
return _FALSE;
}
u8 rtw_ap_allocate_vapid(struct dvobj_priv *dvobj)
{
u8 vap_id;
for (vap_id = 0; vap_id < CONFIG_LIMITED_AP_NUM; vap_id++) {
if (!(dvobj->vap_map & BIT(vap_id)))
break;
}
if (vap_id < CONFIG_LIMITED_AP_NUM)
dvobj->vap_map |= BIT(vap_id);
return vap_id;
}
u8 rtw_ap_release_vapid(struct dvobj_priv *dvobj, u8 vap_id)
{
if (vap_id >= CONFIG_LIMITED_AP_NUM) {
RTW_ERR("%s - vapid(%d) failed\n", __func__, vap_id);
rtw_warn_on(1);
return _FAIL;
}
dvobj->vap_map &= ~ BIT(vap_id);
return _SUCCESS;
}
#endif
static void _rtw_iface_undersurvey_chk(const char *func, _adapter *adapter)
{
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mlme_priv *pmlmepriv;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
pmlmepriv = &iface->mlmepriv;
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
RTW_ERR("%s ("ADPT_FMT") under survey\n", func, ADPT_ARG(iface));
}
}
}
void start_bss_network(_adapter *padapter, struct createbss_parm *parm)
{
#define DUMP_ADAPTERS_STATUS 0
u8 mlme_act = MLME_ACTION_UNKNOWN;
u8 val8;
u16 bcn_interval;
u32 acparm;
struct registry_priv *pregpriv = &padapter->registrypriv;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct security_priv *psecuritypriv = &(padapter->securitypriv);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network; /* used as input */
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork_mlmeext = &(pmlmeinfo->network);
struct dvobj_priv *pdvobj = padapter->dvobj;
s16 req_ch = REQ_CH_NONE, req_bw = REQ_BW_NONE, req_offset = REQ_OFFSET_NONE;
u8 ch_to_set = 0, bw_to_set, offset_to_set;
u8 doiqk = _FALSE;
/* use for check ch bw offset can be allowed or not */
u8 chbw_allow = _TRUE;
int i;
u8 ifbmp_ch_changed = 0;
if (parm->req_ch != 0) {
/* bypass other setting, go checking ch, bw, offset */
mlme_act = MLME_OPCH_SWITCH;
req_ch = parm->req_ch;
req_bw = parm->req_bw;
req_offset = parm->req_offset;
goto chbw_decision;
} else {
/* request comes from upper layer */
if (MLME_IS_AP(padapter))
mlme_act = MLME_AP_STARTED;
else if (MLME_IS_MESH(padapter))
mlme_act = MLME_MESH_STARTED;
else
rtw_warn_on(1);
req_ch = 0;
_rtw_memcpy(pnetwork_mlmeext, pnetwork, pnetwork->Length);
}
bcn_interval = (u16)pnetwork->Configuration.BeaconPeriod;
/* check if there is wps ie, */
/* if there is wpsie in beacon, the hostapd will update beacon twice when stating hostapd, */
/* and at first time the security ie ( RSN/WPA IE) will not include in beacon. */
if (NULL == rtw_get_wps_ie(pnetwork->IEs + _FIXED_IE_LENGTH_, pnetwork->IELength - _FIXED_IE_LENGTH_, NULL, NULL))
pmlmeext->bstart_bss = _TRUE;
/* todo: update wmm, ht cap */
/* pmlmeinfo->WMM_enable; */
/* pmlmeinfo->HT_enable; */
if (pmlmepriv->qospriv.qos_option)
pmlmeinfo->WMM_enable = _TRUE;
#ifdef CONFIG_80211N_HT
if (pmlmepriv->htpriv.ht_option) {
pmlmeinfo->WMM_enable = _TRUE;
pmlmeinfo->HT_enable = _TRUE;
/* pmlmeinfo->HT_info_enable = _TRUE; */
/* pmlmeinfo->HT_caps_enable = _TRUE; */
update_hw_ht_param(padapter);
}
#endif /* #CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
if (pmlmepriv->vhtpriv.vht_option) {
pmlmeinfo->VHT_enable = _TRUE;
update_hw_vht_param(padapter);
}
#endif /* CONFIG_80211AC_VHT */
if (pmlmepriv->cur_network.join_res != _TRUE) { /* setting only at first time */
/* WEP Key will be set before this function, do not clear CAM. */
if ((psecuritypriv->dot11PrivacyAlgrthm != _WEP40_) && (psecuritypriv->dot11PrivacyAlgrthm != _WEP104_)
&& !MLME_IS_MESH(padapter) /* mesh group key is set before this function */
)
flush_all_cam_entry(padapter); /* clear CAM */
}
/* set MSR to AP_Mode */
Set_MSR(padapter, _HW_STATE_AP_);
/* Set BSSID REG */
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pnetwork->MacAddress);
/* Set Security */
val8 = (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) ? 0xcc : 0xcf;
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
/* Beacon Control related register */
rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&bcn_interval));
rtw_hal_rcr_set_chk_bssid(padapter, mlme_act);
chbw_decision:
ifbmp_ch_changed = rtw_ap_chbw_decision(padapter, parm->ifbmp, parm->excl_ifbmp
, req_ch, req_bw, req_offset
, &ch_to_set, &bw_to_set, &offset_to_set, &chbw_allow);
for (i = 0; i < pdvobj->iface_nums; i++) {
if (!(parm->ifbmp & BIT(i)) || !pdvobj->padapters[i])
continue;
/* let pnetwork_mlme == pnetwork_mlmeext */
_rtw_memcpy(&(pdvobj->padapters[i]->mlmepriv.cur_network.network)
, &(pdvobj->padapters[i]->mlmeextpriv.mlmext_info.network)
, pdvobj->padapters[i]->mlmeextpriv.mlmext_info.network.Length);
rtw_start_bss_hdl_after_chbw_decided(pdvobj->padapters[i]);
/* Set EDCA param reg after update cur_wireless_mode & update_capinfo */
if (pregpriv->wifi_spec == 1)
rtw_set_hw_wmm_param(pdvobj->padapters[i]);
}
#if defined(CONFIG_DFS_MASTER)
rtw_dfs_rd_en_decision(padapter, mlme_act, parm->excl_ifbmp);
#endif
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter)) {
/*
* due to check under rtw_ap_chbw_decision
* if under MCC mode, means req channel setting is the same as current channel setting
* if not under MCC mode, mean req channel setting is not the same as current channel setting
*/
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
RTW_INFO(FUNC_ADPT_FMT": req channel setting is the same as current channel setting, go to update BCN\n"
, FUNC_ADPT_ARG(padapter));
goto update_beacon;
}
}
/* issue null data to AP for all interface connecting to AP before switch channel setting for softap */
rtw_hal_mcc_issue_null_data(padapter, chbw_allow, 1);
#endif /* CONFIG_MCC_MODE */
if (!IS_CH_WAITING(adapter_to_rfctl(padapter))) {
doiqk = _TRUE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
}
if (ch_to_set != 0) {
set_channel_bwmode(padapter, ch_to_set, offset_to_set, bw_to_set);
rtw_mi_update_union_chan_inf(padapter, ch_to_set, offset_to_set, bw_to_set);
}
doiqk = _FALSE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
#ifdef CONFIG_MCC_MODE
/* after set_channel_bwmode for backup IQK */
rtw_hal_set_mcc_setting_start_bss_network(padapter, chbw_allow);
#endif
#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
for (i = 0; i < pdvobj->iface_nums; i++) {
if (!(ifbmp_ch_changed & BIT(i)) || !pdvobj->padapters[i])
continue;
{
u8 ht_option = 0;
#ifdef CONFIG_80211N_HT
ht_option = pdvobj->padapters[i]->mlmepriv.htpriv.ht_option;
#endif
rtw_cfg80211_ch_switch_notify(pdvobj->padapters[i]
, pdvobj->padapters[i]->mlmeextpriv.cur_channel
, pdvobj->padapters[i]->mlmeextpriv.cur_bwmode
, pdvobj->padapters[i]->mlmeextpriv.cur_ch_offset
, ht_option);
}
}
#endif /* defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0)) */
if (DUMP_ADAPTERS_STATUS) {
RTW_INFO(FUNC_ADPT_FMT" done\n", FUNC_ADPT_ARG(padapter));
dump_adapters_status(RTW_DBGDUMP , adapter_to_dvobj(padapter));
}
#ifdef CONFIG_MCC_MODE
update_beacon:
#endif
for (i = 0; i < pdvobj->iface_nums; i++) {
struct mlme_priv *mlme;
if (!(parm->ifbmp & BIT(i)) || !pdvobj->padapters[i])
continue;
/* update beacon content only if bstart_bss is _TRUE */
if (pdvobj->padapters[i]->mlmeextpriv.bstart_bss != _TRUE)
continue;
mlme = &(pdvobj->padapters[i]->mlmepriv);
#ifdef CONFIG_80211N_HT
if ((ATOMIC_READ(&mlme->olbc) == _TRUE) || (ATOMIC_READ(&mlme->olbc_ht) == _TRUE)) {
/* AP is not starting a 40 MHz BSS in presence of an 802.11g BSS. */
mlme->ht_op_mode &= (~HT_INFO_OPERATION_MODE_OP_MODE_MASK);
mlme->ht_op_mode |= OP_MODE_MAY_BE_LEGACY_STAS;
update_beacon(pdvobj->padapters[i], _HT_ADD_INFO_IE_, NULL, _FALSE, 0);
}
#endif
update_beacon(pdvobj->padapters[i], _TIM_IE_, NULL, _FALSE, 0);
}
if (mlme_act != MLME_OPCH_SWITCH
&& pmlmeext->bstart_bss == _TRUE
) {
#ifdef CONFIG_SUPPORT_MULTI_BCN
_irqL irqL;
_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
if (rtw_is_list_empty(&padapter->list)) {
#ifdef CONFIG_FW_HANDLE_TXBCN
padapter->vap_id = rtw_ap_allocate_vapid(pdvobj);
#endif
rtw_list_insert_tail(&padapter->list, get_list_head(&pdvobj->ap_if_q));
pdvobj->nr_ap_if++;
pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL / pdvobj->nr_ap_if;
}
_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
#ifdef CONFIG_SWTIMER_BASED_TXBCN
rtw_ap_set_mbid_num(padapter, pdvobj->nr_ap_if);
rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pdvobj->inter_bcn_space));
#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
#endif /*CONFIG_SUPPORT_MULTI_BCN*/
#ifdef CONFIG_HW_P0_TSF_SYNC
correct_TSF(padapter, mlme_act);
#endif
}
rtw_scan_wait_completed(padapter);
_rtw_iface_undersurvey_chk(__func__, padapter);
/* send beacon */
ResumeTxBeacon(padapter);
{
#if !defined(CONFIG_INTERRUPT_BASED_TXBCN)
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_PCI_BCN_POLLING)
#ifdef CONFIG_SWTIMER_BASED_TXBCN
if (pdvobj->nr_ap_if == 1
&& mlme_act != MLME_OPCH_SWITCH
) {
RTW_INFO("start SW BCN TIMER!\n");
_set_timer(&pdvobj->txbcn_timer, bcn_interval);
}
#else
for (i = 0; i < pdvobj->iface_nums; i++) {
if (!(parm->ifbmp & BIT(i)) || !pdvobj->padapters[i])
continue;
if (send_beacon(pdvobj->padapters[i]) == _FAIL)
RTW_INFO(ADPT_FMT" issue_beacon, fail!\n", ADPT_ARG(pdvobj->padapters[i]));
}
#endif
#endif
#endif /* !defined(CONFIG_INTERRUPT_BASED_TXBCN) */
#ifdef CONFIG_FW_HANDLE_TXBCN
if (mlme_act != MLME_OPCH_SWITCH)
rtw_ap_mbid_bcn_en(padapter, padapter->vap_id);
#endif
}
}
int rtw_check_beacon_data(_adapter *padapter, u8 *pbuf, int len)
{
int ret = _SUCCESS;
u8 *p;
u8 *pHT_caps_ie = NULL;
u8 *pHT_info_ie = NULL;
u16 cap, ht_cap = _FALSE;
uint ie_len = 0;
int group_cipher, pairwise_cipher;
u32 akm;
u8 mfp_opt = MFP_NO;
u8 channel, network_type;
u8 OUI1[] = {0x00, 0x50, 0xf2, 0x01};
u8 WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
HT_CAP_AMPDU_DENSITY best_ampdu_density;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
WLAN_BSSID_EX *pbss_network = (WLAN_BSSID_EX *)&pmlmepriv->cur_network.network;
u8 *ie = pbss_network->IEs;
u8 vht_cap = _FALSE;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
u8 rf_num = 0;
int ret_rm;
/* SSID */
/* Supported rates */
/* DS Params */
/* WLAN_EID_COUNTRY */
/* ERP Information element */
/* Extended supported rates */
/* WPA/WPA2 */
/* Wi-Fi Wireless Multimedia Extensions */
/* ht_capab, ht_oper */
/* WPS IE */
RTW_INFO("%s, len=%d\n", __FUNCTION__, len);
if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
return _FAIL;
if (len > MAX_IE_SZ)
return _FAIL;
pbss_network->IELength = len;
_rtw_memset(ie, 0, MAX_IE_SZ);
_rtw_memcpy(ie, pbuf, pbss_network->IELength);
if (pbss_network->InfrastructureMode != Ndis802_11APMode
&& pbss_network->InfrastructureMode != Ndis802_11_mesh
) {
rtw_warn_on(1);
return _FAIL;
}
rtw_ap_check_scan(padapter);
pbss_network->Rssi = 0;
_rtw_memcpy(pbss_network->MacAddress, adapter_mac_addr(padapter), ETH_ALEN);
/* beacon interval */
p = rtw_get_beacon_interval_from_ie(ie);/* ie + 8; */ /* 8: TimeStamp, 2: Beacon Interval 2:Capability */
/* pbss_network->Configuration.BeaconPeriod = le16_to_cpu(*(unsigned short*)p); */
pbss_network->Configuration.BeaconPeriod = RTW_GET_LE16(p);
/* capability */
/* cap = *(unsigned short *)rtw_get_capability_from_ie(ie); */
/* cap = le16_to_cpu(cap); */
cap = RTW_GET_LE16(ie);
/* SSID */
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _SSID_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0) {
_rtw_memset(&pbss_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
_rtw_memcpy(pbss_network->Ssid.Ssid, (p + 2), ie_len);
pbss_network->Ssid.SsidLength = ie_len;
#ifdef CONFIG_P2P
_rtw_memcpy(padapter->wdinfo.p2p_group_ssid, pbss_network->Ssid.Ssid, pbss_network->Ssid.SsidLength);
padapter->wdinfo.p2p_group_ssid_len = pbss_network->Ssid.SsidLength;
#endif
}
#ifdef CONFIG_RTW_MESH
/* Mesh ID */
if (MLME_IS_MESH(padapter)) {
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, WLAN_EID_MESH_ID, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0) {
_rtw_memset(&pbss_network->mesh_id, 0, sizeof(NDIS_802_11_SSID));
_rtw_memcpy(pbss_network->mesh_id.Ssid, (p + 2), ie_len);
pbss_network->mesh_id.SsidLength = ie_len;
}
}
#endif
/* chnnel */
channel = 0;
pbss_network->Configuration.Length = 0;
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _DSSET_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0)
channel = *(p + 2);
pbss_network->Configuration.DSConfig = channel;
/* support rate ie & ext support ie & IElen & SupportedRates */
network_type = rtw_update_rate_bymode(pbss_network, pregistrypriv->wireless_mode);
/* parsing ERP_IE */
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0) {
if(padapter->registrypriv.wireless_mode == WIRELESS_11B ) {
pbss_network->IELength = pbss_network->IELength - *(p+1) - 2;
ret_rm = rtw_ies_remove_ie(ie , &len, _BEACON_IE_OFFSET_, _ERPINFO_IE_,NULL,0);
RTW_DBG("%s, remove_ie of ERP_IE=%d\n", __FUNCTION__, ret_rm);
} else
ERP_IE_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
}
/* update privacy/security */
if (cap & BIT(4))
pbss_network->Privacy = 1;
else
pbss_network->Privacy = 0;
psecuritypriv->wpa_psk = 0;
/* wpa2 */
akm = 0;
group_cipher = 0;
pairwise_cipher = 0;
psecuritypriv->wpa2_group_cipher = _NO_PRIVACY_;
psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0) {
if (rtw_parse_wpa2_ie(p, ie_len + 2, &group_cipher, &pairwise_cipher, &akm, &mfp_opt) == _SUCCESS) {
psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK;
psecuritypriv->dot8021xalg = 1;/* psk, todo:802.1x */
psecuritypriv->wpa_psk |= BIT(1);
psecuritypriv->wpa2_group_cipher = group_cipher;
psecuritypriv->wpa2_pairwise_cipher = pairwise_cipher;
/*
Kernel < v5.1, the auth_type set as NL80211_AUTHTYPE_AUTOMATIC
in cfg80211_rtw_start_ap().
if the AKM SAE in the RSN IE, we have to update the auth_type for SAE
in rtw_check_beacon_data().
*/
if (CHECK_BIT(WLAN_AKM_TYPE_SAE, akm))
psecuritypriv->auth_type = NL80211_AUTHTYPE_SAE;
#if 0
switch (group_cipher) {
case WPA_CIPHER_NONE:
psecuritypriv->wpa2_group_cipher = _NO_PRIVACY_;
break;
case WPA_CIPHER_WEP40:
psecuritypriv->wpa2_group_cipher = _WEP40_;
break;
case WPA_CIPHER_TKIP:
psecuritypriv->wpa2_group_cipher = _TKIP_;
break;
case WPA_CIPHER_CCMP:
psecuritypriv->wpa2_group_cipher = _AES_;
break;
case WPA_CIPHER_WEP104:
psecuritypriv->wpa2_group_cipher = _WEP104_;
break;
}
switch (pairwise_cipher) {
case WPA_CIPHER_NONE:
psecuritypriv->wpa2_pairwise_cipher = _NO_PRIVACY_;
break;
case WPA_CIPHER_WEP40:
psecuritypriv->wpa2_pairwise_cipher = _WEP40_;
break;
case WPA_CIPHER_TKIP:
psecuritypriv->wpa2_pairwise_cipher = _TKIP_;
break;
case WPA_CIPHER_CCMP:
psecuritypriv->wpa2_pairwise_cipher = _AES_;
break;
case WPA_CIPHER_WEP104:
psecuritypriv->wpa2_pairwise_cipher = _WEP104_;
break;
}
#endif
}
}
/* wpa */
ie_len = 0;
group_cipher = 0;
pairwise_cipher = 0;
psecuritypriv->wpa_group_cipher = _NO_PRIVACY_;
psecuritypriv->wpa_pairwise_cipher = _NO_PRIVACY_;
for (p = ie + _BEACON_IE_OFFSET_; ; p += (ie_len + 2)) {
p = rtw_get_ie(p, _SSN_IE_1_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
if ((p) && (_rtw_memcmp(p + 2, OUI1, 4))) {
if (rtw_parse_wpa_ie(p, ie_len + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPAPSK;
psecuritypriv->dot8021xalg = 1;/* psk, todo:802.1x */
psecuritypriv->wpa_psk |= BIT(0);
psecuritypriv->wpa_group_cipher = group_cipher;
psecuritypriv->wpa_pairwise_cipher = pairwise_cipher;
#if 0
switch (group_cipher) {
case WPA_CIPHER_NONE:
psecuritypriv->wpa_group_cipher = _NO_PRIVACY_;
break;
case WPA_CIPHER_WEP40:
psecuritypriv->wpa_group_cipher = _WEP40_;
break;
case WPA_CIPHER_TKIP:
psecuritypriv->wpa_group_cipher = _TKIP_;
break;
case WPA_CIPHER_CCMP:
psecuritypriv->wpa_group_cipher = _AES_;
break;
case WPA_CIPHER_WEP104:
psecuritypriv->wpa_group_cipher = _WEP104_;
break;
}
switch (pairwise_cipher) {
case WPA_CIPHER_NONE:
psecuritypriv->wpa_pairwise_cipher = _NO_PRIVACY_;
break;
case WPA_CIPHER_WEP40:
psecuritypriv->wpa_pairwise_cipher = _WEP40_;
break;
case WPA_CIPHER_TKIP:
psecuritypriv->wpa_pairwise_cipher = _TKIP_;
break;
case WPA_CIPHER_CCMP:
psecuritypriv->wpa_pairwise_cipher = _AES_;
break;
case WPA_CIPHER_WEP104:
psecuritypriv->wpa_pairwise_cipher = _WEP104_;
break;
}
#endif
}
break;
}
if ((p == NULL) || (ie_len == 0))
break;
}
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
/* MFP is mandatory for secure mesh */
if (padapter->mesh_info.mesh_auth_id)
mfp_opt = MFP_REQUIRED;
} else
#endif
if (mfp_opt == MFP_INVALID) {
RTW_INFO(FUNC_ADPT_FMT" invalid MFP setting\n", FUNC_ADPT_ARG(padapter));
return _FAIL;
}
psecuritypriv->mfp_opt = mfp_opt;
/* wmm */
ie_len = 0;
pmlmepriv->qospriv.qos_option = 0;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter))
pmlmepriv->qospriv.qos_option = 1;
#endif
if (pregistrypriv->wmm_enable) {
for (p = ie + _BEACON_IE_OFFSET_; ; p += (ie_len + 2)) {
p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
if ((p) && _rtw_memcmp(p + 2, WMM_PARA_IE, 6)) {
pmlmepriv->qospriv.qos_option = 1;
*(p + 8) |= BIT(7); /* QoS Info, support U-APSD */
/* disable all ACM bits since the WMM admission control is not supported */
*(p + 10) &= ~BIT(4); /* BE */
*(p + 14) &= ~BIT(4); /* BK */
*(p + 18) &= ~BIT(4); /* VI */
*(p + 22) &= ~BIT(4); /* VO */
WMM_param_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)p);
break;
}
if ((p == NULL) || (ie_len == 0))
break;
}
}
#ifdef CONFIG_80211N_HT
if(padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode)) {
/* parsing HT_CAP_IE */
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0) {
u8 rf_type = 0;
HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor = MAX_AMPDU_FACTOR_64K;
struct rtw_ieee80211_ht_cap *pht_cap = (struct rtw_ieee80211_ht_cap *)(p + 2);
if (0) {
RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE from upper layer:\n", FUNC_ADPT_ARG(padapter));
dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
}
pHT_caps_ie = p;
ht_cap = _TRUE;
network_type |= WIRELESS_11_24N;
rtw_ht_use_default_setting(padapter);
/* Update HT Capabilities Info field */
if (pmlmepriv->htpriv.sgi_20m == _FALSE)
pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_20);
if (pmlmepriv->htpriv.sgi_40m == _FALSE)
pht_cap->cap_info &= ~(IEEE80211_HT_CAP_SGI_40);
if (!TEST_FLAG(pmlmepriv->htpriv.ldpc_cap, LDPC_HT_ENABLE_RX))
pht_cap->cap_info &= ~(IEEE80211_HT_CAP_LDPC_CODING);
if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
pht_cap->cap_info &= ~(IEEE80211_HT_CAP_TX_STBC);
if (!TEST_FLAG(pmlmepriv->htpriv.stbc_cap, STBC_HT_ENABLE_RX))
pht_cap->cap_info &= ~(IEEE80211_HT_CAP_RX_STBC_3R);
/* Update A-MPDU Parameters field */
pht_cap->ampdu_params_info &= ~(IEEE80211_HT_CAP_AMPDU_FACTOR | IEEE80211_HT_CAP_AMPDU_DENSITY);
if ((psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_CCMP) ||
(psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_CCMP)) {
rtw_hal_get_def_var(padapter, HW_VAR_BEST_AMPDU_DENSITY, &best_ampdu_density);
pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & (best_ampdu_density << 2));
} else
pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & 0x00);
rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
pht_cap->ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_FACTOR & max_rx_ampdu_factor); /* set Max Rx AMPDU size to 64K */
_rtw_memcpy(&(pmlmeinfo->HT_caps), pht_cap, sizeof(struct HT_caps_element));
/* Update Supported MCS Set field */
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
u8 rx_nss = 0;
int i;
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
/* RX MCS Bitmask */
switch (rx_nss) {
case 1:
set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_1R);
break;
case 2:
set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_2R);
break;
case 3:
set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_3R);
break;
case 4:
set_mcs_rate_by_mask(HT_CAP_ELE_RX_MCS_MAP(pht_cap), MCS_RATE_4R);
break;
default:
RTW_WARN("rf_type:%d or rx_nss:%u is not expected\n", rf_type, hal_spec->rx_nss_num);
}
for (i = 0; i < 10; i++)
*(HT_CAP_ELE_RX_MCS_MAP(pht_cap) + i) &= padapter->mlmeextpriv.default_supported_mcs_set[i];
}
#ifdef CONFIG_BEAMFORMING
/* Use registry value to enable HT Beamforming. */
/* ToDo: use configure file to set these capability. */
pht_cap->tx_BF_cap_info = 0;
/* HT Beamformer */
if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
/* Transmit NDP Capable */
SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(pht_cap, 1);
/* Explicit Compressed Steering Capable */
SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pht_cap, 1);
/* Compressed Steering Number Antennas */
SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, 1);
rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pht_cap, rf_num);
}
/* HT Beamformee */
if (TEST_FLAG(pmlmepriv->htpriv.beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
/* Receive NDP Capable */
SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(pht_cap, 1);
/* Explicit Compressed Beamforming Feedback Capable */
SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pht_cap, 2);
rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pht_cap, rf_num);
}
#endif /* CONFIG_BEAMFORMING */
_rtw_memcpy(&pmlmepriv->htpriv.ht_cap, p + 2, ie_len);
if (0) {
RTW_INFO(FUNC_ADPT_FMT" HT_CAP_IE driver masked:\n", FUNC_ADPT_ARG(padapter));
dump_ht_cap_ie_content(RTW_DBGDUMP, p + 2, ie_len);
}
}
/* parsing HT_INFO_IE */
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0) {
pHT_info_ie = p;
if (channel == 0)
pbss_network->Configuration.DSConfig = GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2);
else if (channel != GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2)) {
RTW_INFO(FUNC_ADPT_FMT" ch inconsistent, DSSS:%u, HT primary:%u\n"
, FUNC_ADPT_ARG(padapter), channel, GET_HT_OP_ELE_PRI_CHL(pHT_info_ie + 2));
}
}
}
#endif /* CONFIG_80211N_HT */
pmlmepriv->cur_network.network_type = network_type;
#ifdef CONFIG_80211N_HT
pmlmepriv->htpriv.ht_option = _FALSE;
if ((psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_TKIP) ||
(psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_TKIP)) {
/* todo: */
/* ht_cap = _FALSE; */
}
/* ht_cap */
if (padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode) && ht_cap == _TRUE) {
pmlmepriv->htpriv.ht_option = _TRUE;
pmlmepriv->qospriv.qos_option = 1;
pmlmepriv->htpriv.ampdu_enable = pregistrypriv->ampdu_enable ? _TRUE : _FALSE;
HT_caps_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)pHT_caps_ie);
HT_info_handler(padapter, (PNDIS_802_11_VARIABLE_IEs)pHT_info_ie);
}
#endif
#ifdef CONFIG_80211AC_VHT
pmlmepriv->ori_vht_en = 0;
pmlmepriv->vhtpriv.vht_option = _FALSE;
if (pmlmepriv->htpriv.ht_option == _TRUE
&& pbss_network->Configuration.DSConfig > 14
&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
&& is_supported_vht(pregistrypriv->wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
) {
/* Parsing VHT CAP IE */
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0)
vht_cap = _TRUE;
/* Parsing VHT OPERATION IE */
if (vht_cap == _TRUE
&& MLME_IS_MESH(padapter) /* allow only mesh temporarily before VHT IE checking is ready */
) {
rtw_check_for_vht20(padapter, ie + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_);
pmlmepriv->ori_vht_en = 1;
pmlmepriv->vhtpriv.vht_option = _TRUE;
} else if (REGSTY_IS_11AC_AUTO(pregistrypriv)) {
rtw_vht_ies_detach(padapter, pbss_network);
rtw_vht_ies_attach(padapter, pbss_network);
}
}
if (pmlmepriv->vhtpriv.vht_option == _FALSE)
rtw_vht_ies_detach(padapter, pbss_network);
#endif /* CONFIG_80211AC_VHT */
#ifdef CONFIG_80211N_HT
if(padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode) &&
pbss_network->Configuration.DSConfig <= 14 && padapter->registrypriv.wifi_spec == 1 &&
pbss_network->IELength + 10 <= MAX_IE_SZ) {
uint len = 0;
SET_EXT_CAPABILITY_ELE_BSS_COEXIST(pmlmepriv->ext_capab_ie_data, 1);
pmlmepriv->ext_capab_ie_len = 10;
rtw_set_ie(pbss_network->IEs + pbss_network->IELength, EID_EXTCapability, 8, pmlmepriv->ext_capab_ie_data, &len);
pbss_network->IELength += pmlmepriv->ext_capab_ie_len;
}
#endif /* CONFIG_80211N_HT */
pbss_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX *)pbss_network);
rtw_ies_get_chbw(pbss_network->IEs + _BEACON_IE_OFFSET_, pbss_network->IELength - _BEACON_IE_OFFSET_
, &pmlmepriv->ori_ch, &pmlmepriv->ori_bw, &pmlmepriv->ori_offset, 1, 1);
rtw_warn_on(pmlmepriv->ori_ch == 0);
{
/* alloc sta_info for ap itself */
struct sta_info *sta;
sta = rtw_get_stainfo(&padapter->stapriv, pbss_network->MacAddress);
if (!sta) {
sta = rtw_alloc_stainfo(&padapter->stapriv, pbss_network->MacAddress);
if (sta == NULL)
return _FAIL;
}
}
rtw_startbss_cmd(padapter, RTW_CMDF_WAIT_ACK);
{
int sk_band = RTW_GET_SCAN_BAND_SKIP(padapter);
if (sk_band)
RTW_CLR_SCAN_BAND_SKIP(padapter, sk_band);
}
rtw_indicate_connect(padapter);
pmlmepriv->cur_network.join_res = _TRUE;/* for check if already set beacon */
/* update bc/mc sta_info */
/* update_bmc_sta(padapter); */
return ret;
}
#if CONFIG_RTW_MACADDR_ACL
void rtw_macaddr_acl_init(_adapter *adapter, u8 period)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
_queue *acl_node_q;
int i;
_irqL irqL;
if (period >= RTW_ACL_PERIOD_NUM) {
rtw_warn_on(1);
return;
}
acl = &stapriv->acl_list[period];
acl_node_q = &acl->acl_node_q;
_rtw_spinlock_init(&(acl_node_q->lock));
_enter_critical_bh(&(acl_node_q->lock), &irqL);
_rtw_init_listhead(&(acl_node_q->queue));
acl->num = 0;
acl->mode = RTW_ACL_MODE_DISABLED;
for (i = 0; i < NUM_ACL; i++) {
_rtw_init_listhead(&acl->aclnode[i].list);
acl->aclnode[i].valid = _FALSE;
}
_exit_critical_bh(&(acl_node_q->lock), &irqL);
}
static void _rtw_macaddr_acl_deinit(_adapter *adapter, u8 period, bool clear_only)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
_queue *acl_node_q;
_irqL irqL;
_list *head, *list;
struct rtw_wlan_acl_node *acl_node;
if (period >= RTW_ACL_PERIOD_NUM) {
rtw_warn_on(1);
return;
}
acl = &stapriv->acl_list[period];
acl_node_q = &acl->acl_node_q;
_enter_critical_bh(&(acl_node_q->lock), &irqL);
head = get_list_head(acl_node_q);
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
list = get_next(list);
if (acl_node->valid == _TRUE) {
acl_node->valid = _FALSE;
rtw_list_delete(&acl_node->list);
acl->num--;
}
}
_exit_critical_bh(&(acl_node_q->lock), &irqL);
if (!clear_only)
_rtw_spinlock_free(&(acl_node_q->lock));
rtw_warn_on(acl->num);
acl->mode = RTW_ACL_MODE_DISABLED;
}
void rtw_macaddr_acl_deinit(_adapter *adapter, u8 period)
{
_rtw_macaddr_acl_deinit(adapter, period, 0);
}
void rtw_macaddr_acl_clear(_adapter *adapter, u8 period)
{
_rtw_macaddr_acl_deinit(adapter, period, 1);
}
void rtw_set_macaddr_acl(_adapter *adapter, u8 period, int mode)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
if (period >= RTW_ACL_PERIOD_NUM) {
rtw_warn_on(1);
return;
}
acl = &stapriv->acl_list[period];
RTW_INFO(FUNC_ADPT_FMT" p=%u, mode=%d\n"
, FUNC_ADPT_ARG(adapter), period, mode);
acl->mode = mode;
}
int rtw_acl_add_sta(_adapter *adapter, u8 period, const u8 *addr)
{
_irqL irqL;
_list *list, *head;
u8 existed = 0;
int i = -1, ret = 0;
struct rtw_wlan_acl_node *acl_node;
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
_queue *acl_node_q;
if (period >= RTW_ACL_PERIOD_NUM) {
rtw_warn_on(1);
ret = -1;
goto exit;
}
acl = &stapriv->acl_list[period];
acl_node_q = &acl->acl_node_q;
_enter_critical_bh(&(acl_node_q->lock), &irqL);
head = get_list_head(acl_node_q);
list = get_next(head);
/* search for existed entry */
while (rtw_end_of_queue_search(head, list) == _FALSE) {
acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
list = get_next(list);
if (_rtw_memcmp(acl_node->addr, addr, ETH_ALEN)) {
if (acl_node->valid == _TRUE) {
existed = 1;
break;
}
}
}
if (existed)
goto release_lock;
if (acl->num >= NUM_ACL)
goto release_lock;
/* find empty one and use */
for (i = 0; i < NUM_ACL; i++) {
acl_node = &acl->aclnode[i];
if (acl_node->valid == _FALSE) {
_rtw_init_listhead(&acl_node->list);
_rtw_memcpy(acl_node->addr, addr, ETH_ALEN);
acl_node->valid = _TRUE;
rtw_list_insert_tail(&acl_node->list, get_list_head(acl_node_q));
acl->num++;
break;
}
}
release_lock:
_exit_critical_bh(&(acl_node_q->lock), &irqL);
if (!existed && (i < 0 || i >= NUM_ACL))
ret = -1;
RTW_INFO(FUNC_ADPT_FMT" p=%u "MAC_FMT" %s (acl_num=%d)\n"
, FUNC_ADPT_ARG(adapter), period, MAC_ARG(addr)
, (existed ? "existed" : ((i < 0 || i >= NUM_ACL) ? "no room" : "added"))
, acl->num);
exit:
return ret;
}
int rtw_acl_remove_sta(_adapter *adapter, u8 period, const u8 *addr)
{
_irqL irqL;
_list *list, *head;
int ret = 0;
struct rtw_wlan_acl_node *acl_node;
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
_queue *acl_node_q;
u8 is_baddr = is_broadcast_mac_addr(addr);
u8 match = 0;
if (period >= RTW_ACL_PERIOD_NUM) {
rtw_warn_on(1);
goto exit;
}
acl = &stapriv->acl_list[period];
acl_node_q = &acl->acl_node_q;
_enter_critical_bh(&(acl_node_q->lock), &irqL);
head = get_list_head(acl_node_q);
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
list = get_next(list);
if (is_baddr || _rtw_memcmp(acl_node->addr, addr, ETH_ALEN)) {
if (acl_node->valid == _TRUE) {
acl_node->valid = _FALSE;
rtw_list_delete(&acl_node->list);
acl->num--;
match = 1;
}
}
}
_exit_critical_bh(&(acl_node_q->lock), &irqL);
RTW_INFO(FUNC_ADPT_FMT" p=%u "MAC_FMT" %s (acl_num=%d)\n"
, FUNC_ADPT_ARG(adapter), period, MAC_ARG(addr)
, is_baddr ? "clear all" : (match ? "match" : "no found")
, acl->num);
exit:
return ret;
}
#endif /* CONFIG_RTW_MACADDR_ACL */
u8 rtw_ap_set_sta_key(_adapter *adapter, const u8 *addr, u8 alg, const u8 *key, u8 keyid, u8 gk)
{
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
struct cmd_obj *cmd;
struct set_stakey_parm *param;
u8 res = _SUCCESS;
cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmd == NULL) {
res = _FAIL;
goto exit;
}
param = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
if (param == NULL) {
rtw_mfree((u8 *) cmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmd, param, _SetStaKey_CMD_);
_rtw_memcpy(param->addr, addr, ETH_ALEN);
param->algorithm = alg;
param->keyid = keyid;
_rtw_memcpy(param->key, key, 16);
param->gk = gk;
res = rtw_enqueue_cmd(cmdpriv, cmd);
exit:
return res;
}
u8 rtw_ap_set_pairwise_key(_adapter *padapter, struct sta_info *psta)
{
return rtw_ap_set_sta_key(padapter
, psta->cmn.mac_addr
, psta->dot118021XPrivacy
, psta->dot118021x_UncstKey.skey
, 0
, 0
);
}
static int rtw_ap_set_key(_adapter *padapter, u8 *key, u8 alg, int keyid, u8 set_tx)
{
u8 keylen;
struct cmd_obj *pcmd;
struct setkey_parm *psetkeyparm;
struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
int res = _SUCCESS;
/* RTW_INFO("%s\n", __FUNCTION__); */
pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd == NULL) {
res = _FAIL;
goto exit;
}
psetkeyparm = (struct setkey_parm *)rtw_zmalloc(sizeof(struct setkey_parm));
if (psetkeyparm == NULL) {
rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
_rtw_memset(psetkeyparm, 0, sizeof(struct setkey_parm));
psetkeyparm->keyid = (u8)keyid;
if (is_wep_enc(alg))
padapter->securitypriv.key_mask |= BIT(psetkeyparm->keyid);
psetkeyparm->algorithm = alg;
psetkeyparm->set_tx = set_tx;
switch (alg) {
case _WEP40_:
keylen = 5;
break;
case _WEP104_:
keylen = 13;
break;
case _TKIP_:
case _TKIP_WTMIC_:
case _AES_:
default:
keylen = 16;
}
_rtw_memcpy(&(psetkeyparm->key[0]), key, keylen);
pcmd->cmdcode = _SetKey_CMD_;
pcmd->parmbuf = (u8 *)psetkeyparm;
pcmd->cmdsz = (sizeof(struct setkey_parm));
pcmd->rsp = NULL;
pcmd->rspsz = 0;
_rtw_init_listhead(&pcmd->list);
res = rtw_enqueue_cmd(pcmdpriv, pcmd);
exit:
return res;
}
int rtw_ap_set_group_key(_adapter *padapter, u8 *key, u8 alg, int keyid)
{
RTW_INFO("%s\n", __FUNCTION__);
return rtw_ap_set_key(padapter, key, alg, keyid, 1);
}
int rtw_ap_set_wep_key(_adapter *padapter, u8 *key, u8 keylen, int keyid, u8 set_tx)
{
u8 alg;
switch (keylen) {
case 5:
alg = _WEP40_;
break;
case 13:
alg = _WEP104_;
break;
default:
alg = _NO_PRIVACY_;
}
RTW_INFO("%s\n", __FUNCTION__);
return rtw_ap_set_key(padapter, key, alg, keyid, set_tx);
}
u8 rtw_ap_bmc_frames_hdl(_adapter *padapter)
{
#define HIQ_XMIT_COUNTS (6)
_irqL irqL;
struct sta_info *psta_bmc;
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct sta_priv *pstapriv = &padapter->stapriv;
bool update_tim = _FALSE;
if (padapter->registrypriv.wifi_spec != 1)
return H2C_SUCCESS;
psta_bmc = rtw_get_bcmc_stainfo(padapter);
if (!psta_bmc)
return H2C_SUCCESS;
_enter_critical_bh(&pxmitpriv->lock, &irqL);
if ((rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) && (psta_bmc->sleepq_len > 0)) {
int tx_counts = 0;
_update_beacon(padapter, _TIM_IE_, NULL, _FALSE, 0, "update TIM with TIB=1");
RTW_INFO("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);
xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
rtw_list_delete(&pxmitframe->list);
psta_bmc->sleepq_len--;
tx_counts++;
if (psta_bmc->sleepq_len > 0)
pxmitframe->attrib.mdata = 1;
else
pxmitframe->attrib.mdata = 0;
if (tx_counts == HIQ_XMIT_COUNTS)
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.triggered = 1;
if (xmitframe_hiq_filter(pxmitframe) == _TRUE)
pxmitframe->attrib.qsel = QSLT_HIGH;/*HIQ*/
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
if (tx_counts == HIQ_XMIT_COUNTS)
break;
}
} else {
if (psta_bmc->sleepq_len == 0) {
/*RTW_INFO("sleepq_len of bmc_sta = %d\n", psta_bmc->sleepq_len);*/
if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0))
update_tim = _TRUE;
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
if (update_tim == _TRUE) {
RTW_INFO("clear TIB\n");
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "bmc sleepq and HIQ empty");
}
}
}
_exit_critical_bh(&pxmitpriv->lock, &irqL);
#if 0
/* HIQ Check */
rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
while (_FALSE == empty && rtw_get_passing_time_ms(start) < 3000) {
rtw_msleep_os(100);
rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
}
printk("check if hiq empty=%d\n", empty);
#endif
return H2C_SUCCESS;
}
#ifdef CONFIG_NATIVEAP_MLME
static void associated_stainfo_update(_adapter *padapter, struct sta_info *psta, u32 sta_info_type)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
RTW_INFO("%s: "MAC_FMT", updated_type=0x%x\n", __func__, MAC_ARG(psta->cmn.mac_addr), sta_info_type);
#ifdef CONFIG_80211N_HT
if (sta_info_type & STA_INFO_UPDATE_BW) {
if ((psta->flags & WLAN_STA_HT) && !psta->ht_20mhz_set) {
if (pmlmepriv->sw_to_20mhz) {
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
/*psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;*/
psta->htpriv.sgi_40m = _FALSE;
} else {
/*TODO: Switch back to 40MHZ?80MHZ*/
}
}
}
#endif /* CONFIG_80211N_HT */
/*
if (sta_info_type & STA_INFO_UPDATE_RATE) {
}
*/
if (sta_info_type & STA_INFO_UPDATE_PROTECTION_MODE)
VCS_update(padapter, psta);
/*
if (sta_info_type & STA_INFO_UPDATE_CAP) {
}
if (sta_info_type & STA_INFO_UPDATE_HT_CAP) {
}
if (sta_info_type & STA_INFO_UPDATE_VHT_CAP) {
}
*/
}
static void update_bcn_ext_capab_ie(_adapter *padapter)
{
sint ie_len = 0;
unsigned char *pbuf;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
u8 *ie = pnetwork->IEs;
u8 null_extcap_data[8] = {0};
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_CAP_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (pbuf && ie_len > 0)
rtw_remove_bcn_ie(padapter, pnetwork, _EXT_CAP_IE_);
if ((pmlmepriv->ext_capab_ie_len > 0) &&
(_rtw_memcmp(pmlmepriv->ext_capab_ie_data, null_extcap_data, sizeof(null_extcap_data)) == _FALSE))
rtw_add_bcn_ie(padapter, pnetwork, _EXT_CAP_IE_, pmlmepriv->ext_capab_ie_data, pmlmepriv->ext_capab_ie_len);
}
static void update_bcn_erpinfo_ie(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
unsigned char *p, *ie = pnetwork->IEs;
u32 len = 0;
RTW_INFO("%s, ERP_enable=%d\n", __FUNCTION__, pmlmeinfo->ERP_enable);
if (!pmlmeinfo->ERP_enable)
return;
/* parsing ERP_IE */
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _ERPINFO_IE_, &len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (p && len > 0) {
PNDIS_802_11_VARIABLE_IEs pIE = (PNDIS_802_11_VARIABLE_IEs)p;
if (pmlmepriv->num_sta_non_erp == 1)
pIE->data[0] |= RTW_ERP_INFO_NON_ERP_PRESENT | RTW_ERP_INFO_USE_PROTECTION;
else
pIE->data[0] &= ~(RTW_ERP_INFO_NON_ERP_PRESENT | RTW_ERP_INFO_USE_PROTECTION);
if (pmlmepriv->num_sta_no_short_preamble > 0)
pIE->data[0] |= RTW_ERP_INFO_BARKER_PREAMBLE_MODE;
else
pIE->data[0] &= ~(RTW_ERP_INFO_BARKER_PREAMBLE_MODE);
ERP_IE_handler(padapter, pIE);
}
}
static void update_bcn_htcap_ie(_adapter *padapter)
{
RTW_INFO("%s\n", __FUNCTION__);
}
static void update_bcn_htinfo_ie(_adapter *padapter)
{
#ifdef CONFIG_80211N_HT
/*
u8 beacon_updated = _FALSE;
u32 sta_info_update_type = STA_INFO_UPDATE_NONE;
*/
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
unsigned char *p, *ie = pnetwork->IEs;
u32 len = 0;
if (pmlmepriv->htpriv.ht_option == _FALSE)
return;
if (pmlmeinfo->HT_info_enable != 1)
return;
RTW_INFO("%s current operation mode=0x%X\n",
__FUNCTION__, pmlmepriv->ht_op_mode);
RTW_INFO("num_sta_40mhz_intolerant(%d), 20mhz_width_req(%d), intolerant_ch_rpt(%d), olbc(%d)\n",
pmlmepriv->num_sta_40mhz_intolerant, pmlmepriv->ht_20mhz_width_req, pmlmepriv->ht_intolerant_ch_reported, ATOMIC_READ(&pmlmepriv->olbc));
/*parsing HT_INFO_IE, currently only update ht_op_mode - pht_info->infos[1] & pht_info->infos[2] for wifi logo test*/
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (p && len > 0) {
struct HT_info_element *pht_info = NULL;
pht_info = (struct HT_info_element *)(p + 2);
/* for STA Channel Width/Secondary Channel Offset*/
if ((pmlmepriv->sw_to_20mhz == 0) && (pmlmeext->cur_channel <= 14)) {
if ((pmlmepriv->num_sta_40mhz_intolerant > 0) || (pmlmepriv->ht_20mhz_width_req == _TRUE)
|| (pmlmepriv->ht_intolerant_ch_reported == _TRUE) || (ATOMIC_READ(&pmlmepriv->olbc) == _TRUE)) {
SET_HT_OP_ELE_2ND_CHL_OFFSET(pht_info, 0);
SET_HT_OP_ELE_STA_CHL_WIDTH(pht_info, 0);
pmlmepriv->sw_to_20mhz = 1;
/*
sta_info_update_type |= STA_INFO_UPDATE_BW;
beacon_updated = _TRUE;
*/
RTW_INFO("%s:switching to 20Mhz\n", __FUNCTION__);
/*TODO : cur_bwmode/cur_ch_offset switches to 20Mhz*/
}
} else {
if ((pmlmepriv->num_sta_40mhz_intolerant == 0) && (pmlmepriv->ht_20mhz_width_req == _FALSE)
&& (pmlmepriv->ht_intolerant_ch_reported == _FALSE) && (ATOMIC_READ(&pmlmepriv->olbc) == _FALSE)) {
if (pmlmeext->cur_bwmode >= CHANNEL_WIDTH_40) {
SET_HT_OP_ELE_STA_CHL_WIDTH(pht_info, 1);
SET_HT_OP_ELE_2ND_CHL_OFFSET(pht_info,
(pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER) ?
HT_INFO_HT_PARAM_SECONDARY_CHNL_ABOVE : HT_INFO_HT_PARAM_SECONDARY_CHNL_BELOW);
pmlmepriv->sw_to_20mhz = 0;
/*
sta_info_update_type |= STA_INFO_UPDATE_BW;
beacon_updated = _TRUE;
*/
RTW_INFO("%s:switching back to 40Mhz\n", __FUNCTION__);
}
}
}
/* to update ht_op_mode*/
*(u16 *)(pht_info->infos + 1) = cpu_to_le16(pmlmepriv->ht_op_mode);
}
/*associated_clients_update(padapter, beacon_updated, sta_info_update_type);*/
#endif /* CONFIG_80211N_HT */
}
static void update_bcn_rsn_ie(_adapter *padapter)
{
RTW_INFO("%s\n", __FUNCTION__);
}
static void update_bcn_wpa_ie(_adapter *padapter)
{
RTW_INFO("%s\n", __FUNCTION__);
}
static void update_bcn_wmm_ie(_adapter *padapter)
{
RTW_INFO("%s\n", __FUNCTION__);
}
static void update_bcn_wps_ie(_adapter *padapter)
{
u8 *pwps_ie = NULL, *pwps_ie_src, *premainder_ie, *pbackup_remainder_ie = NULL;
uint wps_ielen = 0, wps_offset, remainder_ielen;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
unsigned char *ie = pnetwork->IEs;
u32 ielen = pnetwork->IELength;
RTW_INFO("%s\n", __FUNCTION__);
pwps_ie = rtw_get_wps_ie(ie + _FIXED_IE_LENGTH_, ielen - _FIXED_IE_LENGTH_, NULL, &wps_ielen);
if (pwps_ie == NULL || wps_ielen == 0)
return;
pwps_ie_src = pmlmepriv->wps_beacon_ie;
if (pwps_ie_src == NULL)
return;
wps_offset = (uint)(pwps_ie - ie);
premainder_ie = pwps_ie + wps_ielen;
remainder_ielen = ielen - wps_offset - wps_ielen;
if (remainder_ielen > 0) {
pbackup_remainder_ie = rtw_malloc(remainder_ielen);
if (pbackup_remainder_ie)
_rtw_memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
}
wps_ielen = (uint)pwps_ie_src[1];/* to get ie data len */
if ((wps_offset + wps_ielen + 2 + remainder_ielen) <= MAX_IE_SZ) {
_rtw_memcpy(pwps_ie, pwps_ie_src, wps_ielen + 2);
pwps_ie += (wps_ielen + 2);
if (pbackup_remainder_ie)
_rtw_memcpy(pwps_ie, pbackup_remainder_ie, remainder_ielen);
/* update IELength */
pnetwork->IELength = wps_offset + (wps_ielen + 2) + remainder_ielen;
}
if (pbackup_remainder_ie)
rtw_mfree(pbackup_remainder_ie, remainder_ielen);
/* deal with the case without set_tx_beacon_cmd() in update_beacon() */
#if defined(CONFIG_INTERRUPT_BASED_TXBCN) || defined(CONFIG_PCI_HCI)
if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
u8 sr = 0;
rtw_get_wps_attr_content(pwps_ie_src, wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
if (sr) {
set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
RTW_INFO("%s, set WIFI_UNDER_WPS\n", __func__);
} else {
clr_fwstate(pmlmepriv, WIFI_UNDER_WPS);
RTW_INFO("%s, clr WIFI_UNDER_WPS\n", __func__);
}
}
#endif
}
static void update_bcn_p2p_ie(_adapter *padapter)
{
}
static void update_bcn_vendor_spec_ie(_adapter *padapter, u8 *oui)
{
RTW_INFO("%s\n", __FUNCTION__);
if (_rtw_memcmp(RTW_WPA_OUI, oui, 4))
update_bcn_wpa_ie(padapter);
else if (_rtw_memcmp(WMM_OUI, oui, 4))
update_bcn_wmm_ie(padapter);
else if (_rtw_memcmp(WPS_OUI, oui, 4))
update_bcn_wps_ie(padapter);
else if (_rtw_memcmp(P2P_OUI, oui, 4))
update_bcn_p2p_ie(padapter);
else
RTW_INFO("unknown OUI type!\n");
}
void _update_beacon(_adapter *padapter, u8 ie_id, u8 *oui, u8 tx, u8 flags, const char *tag)
{
_irqL irqL;
struct mlme_priv *pmlmepriv;
struct mlme_ext_priv *pmlmeext;
bool updated = 1; /* treat as upadated by default */
if (!padapter)
return;
pmlmepriv = &(padapter->mlmepriv);
pmlmeext = &(padapter->mlmeextpriv);
if (pmlmeext->bstart_bss == _FALSE)
return;
_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
switch (ie_id) {
case _TIM_IE_:
update_BCNTIM(padapter);
break;
case _ERPINFO_IE_:
update_bcn_erpinfo_ie(padapter);
break;
case _HT_CAPABILITY_IE_:
update_bcn_htcap_ie(padapter);
break;
case _RSN_IE_2_:
update_bcn_rsn_ie(padapter);
break;
case _HT_ADD_INFO_IE_:
update_bcn_htinfo_ie(padapter);
break;
case _EXT_CAP_IE_:
update_bcn_ext_capab_ie(padapter);
break;
#ifdef CONFIG_RTW_MESH
case WLAN_EID_MESH_CONFIG:
updated = rtw_mesh_update_bss_peering_status(padapter, &(pmlmeext->mlmext_info.network));
updated |= rtw_mesh_update_bss_formation_info(padapter, &(pmlmeext->mlmext_info.network));
updated |= rtw_mesh_update_bss_forwarding_state(padapter, &(pmlmeext->mlmext_info.network));
break;
#endif
case _VENDOR_SPECIFIC_IE_:
update_bcn_vendor_spec_ie(padapter, oui);
break;
case 0xFF:
default:
break;
}
if (updated)
pmlmepriv->update_bcn = _TRUE;
_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
#ifndef CONFIG_INTERRUPT_BASED_TXBCN
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_PCI_BCN_POLLING)
if (tx && updated) {
/* send_beacon(padapter); */ /* send_beacon must execute on TSR level */
if (0)
RTW_INFO(FUNC_ADPT_FMT" ie_id:%u - %s\n", FUNC_ADPT_ARG(padapter), ie_id, tag);
if(flags == RTW_CMDF_WAIT_ACK)
set_tx_beacon_cmd(padapter, RTW_CMDF_WAIT_ACK);
else
set_tx_beacon_cmd(padapter, 0);
}
#else
{
/* PCI will issue beacon when BCN interrupt occurs. */
}
#endif
#endif /* !CONFIG_INTERRUPT_BASED_TXBCN */
}
#ifdef CONFIG_80211N_HT
void rtw_process_public_act_bsscoex(_adapter *padapter, u8 *pframe, uint frame_len)
{
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 beacon_updated = _FALSE;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
uint frame_body_len = frame_len - sizeof(struct rtw_ieee80211_hdr_3addr);
u8 category, action;
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta == NULL)
return;
category = frame_body[0];
action = frame_body[1];
if (frame_body_len > 0) {
if ((frame_body[2] == EID_BSSCoexistence) && (frame_body[3] > 0)) {
u8 ie_data = frame_body[4];
if (ie_data & RTW_WLAN_20_40_BSS_COEX_40MHZ_INTOL) {
if (psta->ht_40mhz_intolerant == 0) {
psta->ht_40mhz_intolerant = 1;
pmlmepriv->num_sta_40mhz_intolerant++;
beacon_updated = _TRUE;
}
} else if (ie_data & RTW_WLAN_20_40_BSS_COEX_20MHZ_WIDTH_REQ) {
if (pmlmepriv->ht_20mhz_width_req == _FALSE) {
pmlmepriv->ht_20mhz_width_req = _TRUE;
beacon_updated = _TRUE;
}
} else
beacon_updated = _FALSE;
}
}
if (frame_body_len > 8) {
/* if EID_BSSIntolerantChlReport ie exists */
if ((frame_body[5] == EID_BSSIntolerantChlReport) && (frame_body[6] > 0)) {
/*todo:*/
if (pmlmepriv->ht_intolerant_ch_reported == _FALSE) {
pmlmepriv->ht_intolerant_ch_reported = _TRUE;
beacon_updated = _TRUE;
}
}
}
if (beacon_updated) {
update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE, 0);
associated_stainfo_update(padapter, psta, STA_INFO_UPDATE_BW);
}
}
void rtw_process_ht_action_smps(_adapter *padapter, u8 *ta, u8 ctrl_field)
{
u8 e_field, m_field;
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
psta = rtw_get_stainfo(pstapriv, ta);
if (psta == NULL)
return;
e_field = (ctrl_field & BIT(0)) ? 1 : 0; /*SM Power Save Enabled*/
m_field = (ctrl_field & BIT(1)) ? 1 : 0; /*SM Mode, 0:static SMPS, 1:dynamic SMPS*/
if (e_field) {
if (m_field) { /*mode*/
psta->htpriv.smps_cap = WLAN_HT_CAP_SM_PS_DYNAMIC;
RTW_ERR("Don't support dynamic SMPS\n");
}
else
psta->htpriv.smps_cap = WLAN_HT_CAP_SM_PS_STATIC;
} else {
/*disable*/
psta->htpriv.smps_cap = WLAN_HT_CAP_SM_PS_DISABLED;
}
if (psta->htpriv.smps_cap != WLAN_HT_CAP_SM_PS_DYNAMIC)
rtw_ssmps_wk_cmd(padapter, psta, e_field, 1);
}
/*
op_mode
Set to 0 (HT pure) under the followign conditions
- all STAs in the BSS are 20/40 MHz HT in 20/40 MHz BSS or
- all STAs in the BSS are 20 MHz HT in 20 MHz BSS
Set to 1 (HT non-member protection) if there may be non-HT STAs
in both the primary and the secondary channel
Set to 2 if only HT STAs are associated in BSS,
however and at least one 20 MHz HT STA is associated
Set to 3 (HT mixed mode) when one or more non-HT STAs are associated
(currently non-GF HT station is considered as non-HT STA also)
*/
int rtw_ht_operation_update(_adapter *padapter)
{
u16 cur_op_mode, new_op_mode;
int op_mode_changes = 0;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct ht_priv *phtpriv_ap = &pmlmepriv->htpriv;
if (pmlmepriv->htpriv.ht_option == _FALSE)
return 0;
/*if (!iface->conf->ieee80211n || iface->conf->ht_op_mode_fixed)
return 0;*/
RTW_INFO("%s current operation mode=0x%X\n",
__FUNCTION__, pmlmepriv->ht_op_mode);
if (!(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)
&& pmlmepriv->num_sta_ht_no_gf) {
pmlmepriv->ht_op_mode |=
HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT;
op_mode_changes++;
} else if ((pmlmepriv->ht_op_mode &
HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT) &&
pmlmepriv->num_sta_ht_no_gf == 0) {
pmlmepriv->ht_op_mode &=
~HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT;
op_mode_changes++;
}
if (!(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT) &&
(pmlmepriv->num_sta_no_ht || ATOMIC_READ(&pmlmepriv->olbc_ht))) {
pmlmepriv->ht_op_mode |= HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT;
op_mode_changes++;
} else if ((pmlmepriv->ht_op_mode &
HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT) &&
(pmlmepriv->num_sta_no_ht == 0 && !ATOMIC_READ(&pmlmepriv->olbc_ht))) {
pmlmepriv->ht_op_mode &=
~HT_INFO_OPERATION_MODE_NON_HT_STA_PRESENT;
op_mode_changes++;
}
/* Note: currently we switch to the MIXED op mode if HT non-greenfield
* station is associated. Probably it's a theoretical case, since
* it looks like all known HT STAs support greenfield.
*/
new_op_mode = 0;
if (pmlmepriv->num_sta_no_ht /*||
(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)*/)
new_op_mode = OP_MODE_MIXED;
else if ((phtpriv_ap->ht_cap.cap_info & IEEE80211_HT_CAP_SUP_WIDTH)
&& pmlmepriv->num_sta_ht_20mhz)
new_op_mode = OP_MODE_20MHZ_HT_STA_ASSOCED;
else if (ATOMIC_READ(&pmlmepriv->olbc_ht))
new_op_mode = OP_MODE_MAY_BE_LEGACY_STAS;
else
new_op_mode = OP_MODE_PURE;
cur_op_mode = pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_OP_MODE_MASK;
if (cur_op_mode != new_op_mode) {
pmlmepriv->ht_op_mode &= ~HT_INFO_OPERATION_MODE_OP_MODE_MASK;
pmlmepriv->ht_op_mode |= new_op_mode;
op_mode_changes++;
}
RTW_INFO("%s new operation mode=0x%X changes=%d\n",
__FUNCTION__, pmlmepriv->ht_op_mode, op_mode_changes);
return op_mode_changes;
}
#endif /* CONFIG_80211N_HT */
void associated_clients_update(_adapter *padapter, u8 updated, u32 sta_info_type)
{
/* update associcated stations cap. */
if (updated == _TRUE) {
_irqL irqL;
_list *phead, *plist;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
/* check asoc_queue */
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
associated_stainfo_update(padapter, psta, sta_info_type);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
}
}
/* called > TSR LEVEL for USB or SDIO Interface*/
void bss_cap_update_on_sta_join(_adapter *padapter, struct sta_info *psta)
{
u8 beacon_updated = _FALSE;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
#if 0
if (!(psta->capability & WLAN_CAPABILITY_SHORT_PREAMBLE) &&
!psta->no_short_preamble_set) {
psta->no_short_preamble_set = 1;
pmlmepriv->num_sta_no_short_preamble++;
if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
(pmlmepriv->num_sta_no_short_preamble == 1))
ieee802_11_set_beacons(hapd->iface);
}
#endif
if (!(psta->flags & WLAN_STA_SHORT_PREAMBLE)) {
if (!psta->no_short_preamble_set) {
psta->no_short_preamble_set = 1;
pmlmepriv->num_sta_no_short_preamble++;
if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
(pmlmepriv->num_sta_no_short_preamble == 1))
beacon_updated = _TRUE;
}
} else {
if (psta->no_short_preamble_set) {
psta->no_short_preamble_set = 0;
pmlmepriv->num_sta_no_short_preamble--;
if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
(pmlmepriv->num_sta_no_short_preamble == 0))
beacon_updated = _TRUE;
}
}
#if 0
if (psta->flags & WLAN_STA_NONERP && !psta->nonerp_set) {
psta->nonerp_set = 1;
pmlmepriv->num_sta_non_erp++;
if (pmlmepriv->num_sta_non_erp == 1)
ieee802_11_set_beacons(hapd->iface);
}
#endif
if (psta->flags & WLAN_STA_NONERP) {
if (!psta->nonerp_set) {
psta->nonerp_set = 1;
pmlmepriv->num_sta_non_erp++;
if (pmlmepriv->num_sta_non_erp == 1) {
beacon_updated = _TRUE;
update_beacon(padapter, _ERPINFO_IE_, NULL, _FALSE, 0);
}
}
} else {
if (psta->nonerp_set) {
psta->nonerp_set = 0;
pmlmepriv->num_sta_non_erp--;
if (pmlmepriv->num_sta_non_erp == 0) {
beacon_updated = _TRUE;
update_beacon(padapter, _ERPINFO_IE_, NULL, _FALSE, 0);
}
}
}
#if 0
if (!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT) &&
!psta->no_short_slot_time_set) {
psta->no_short_slot_time_set = 1;
pmlmepriv->num_sta_no_short_slot_time++;
if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
(pmlmepriv->num_sta_no_short_slot_time == 1))
ieee802_11_set_beacons(hapd->iface);
}
#endif
if (!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT)) {
if (!psta->no_short_slot_time_set) {
psta->no_short_slot_time_set = 1;
pmlmepriv->num_sta_no_short_slot_time++;
if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
(pmlmepriv->num_sta_no_short_slot_time == 1))
beacon_updated = _TRUE;
}
} else {
if (psta->no_short_slot_time_set) {
psta->no_short_slot_time_set = 0;
pmlmepriv->num_sta_no_short_slot_time--;
if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
(pmlmepriv->num_sta_no_short_slot_time == 0))
beacon_updated = _TRUE;
}
}
#ifdef CONFIG_80211N_HT
if(padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode)) {
if (psta->flags & WLAN_STA_HT) {
u16 ht_capab = le16_to_cpu(psta->htpriv.ht_cap.cap_info);
RTW_INFO("HT: STA " MAC_FMT " HT Capabilities Info: 0x%04x\n",
MAC_ARG(psta->cmn.mac_addr), ht_capab);
if (psta->no_ht_set) {
psta->no_ht_set = 0;
pmlmepriv->num_sta_no_ht--;
}
if ((ht_capab & IEEE80211_HT_CAP_GRN_FLD) == 0) {
if (!psta->no_ht_gf_set) {
psta->no_ht_gf_set = 1;
pmlmepriv->num_sta_ht_no_gf++;
}
RTW_INFO("%s STA " MAC_FMT " - no "
"greenfield, num of non-gf stations %d\n",
__FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
pmlmepriv->num_sta_ht_no_gf);
}
if ((ht_capab & IEEE80211_HT_CAP_SUP_WIDTH) == 0) {
if (!psta->ht_20mhz_set) {
psta->ht_20mhz_set = 1;
pmlmepriv->num_sta_ht_20mhz++;
}
RTW_INFO("%s STA " MAC_FMT " - 20 MHz HT, "
"num of 20MHz HT STAs %d\n",
__FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
pmlmepriv->num_sta_ht_20mhz);
}
if (((ht_capab & RTW_IEEE80211_HT_CAP_40MHZ_INTOLERANT) != 0) &&
(psta->ht_40mhz_intolerant == 0)) {
psta->ht_40mhz_intolerant = 1;
pmlmepriv->num_sta_40mhz_intolerant++;
RTW_INFO("%s STA " MAC_FMT " - 40MHZ_INTOLERANT, ",
__FUNCTION__, MAC_ARG(psta->cmn.mac_addr));
}
} else {
if (!psta->no_ht_set) {
psta->no_ht_set = 1;
pmlmepriv->num_sta_no_ht++;
}
if (pmlmepriv->htpriv.ht_option == _TRUE) {
RTW_INFO("%s STA " MAC_FMT
" - no HT, num of non-HT stations %d\n",
__FUNCTION__, MAC_ARG(psta->cmn.mac_addr),
pmlmepriv->num_sta_no_ht);
}
}
if (rtw_ht_operation_update(padapter) > 0) {
update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE, 0);
update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE, 0);
beacon_updated = _TRUE;
}
}
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
struct sta_priv *pstapriv = &padapter->stapriv;
update_beacon(padapter, WLAN_EID_MESH_CONFIG, NULL, _FALSE, 0);
if (pstapriv->asoc_list_cnt == 1)
_set_timer(&padapter->mesh_atlm_param_req_timer, 0);
beacon_updated = _TRUE;
}
#endif
if (beacon_updated)
update_beacon(padapter, 0xFF, NULL, _TRUE, 0);
/* update associcated stations cap. */
associated_clients_update(padapter, beacon_updated, STA_INFO_UPDATE_ALL);
RTW_INFO("%s, updated=%d\n", __func__, beacon_updated);
}
u8 bss_cap_update_on_sta_leave(_adapter *padapter, struct sta_info *psta)
{
u8 beacon_updated = _FALSE;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
if (!psta)
return beacon_updated;
if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
beacon_updated = _TRUE;
update_beacon(padapter, _TIM_IE_, NULL, _FALSE, 0);
}
if (psta->no_short_preamble_set) {
psta->no_short_preamble_set = 0;
pmlmepriv->num_sta_no_short_preamble--;
if (pmlmeext->cur_wireless_mode > WIRELESS_11B
&& pmlmepriv->num_sta_no_short_preamble == 0)
beacon_updated = _TRUE;
}
if (psta->nonerp_set) {
psta->nonerp_set = 0;
pmlmepriv->num_sta_non_erp--;
if (pmlmepriv->num_sta_non_erp == 0) {
beacon_updated = _TRUE;
update_beacon(padapter, _ERPINFO_IE_, NULL, _FALSE, 0);
}
}
if (psta->no_short_slot_time_set) {
psta->no_short_slot_time_set = 0;
pmlmepriv->num_sta_no_short_slot_time--;
if (pmlmeext->cur_wireless_mode > WIRELESS_11B
&& pmlmepriv->num_sta_no_short_slot_time == 0)
beacon_updated = _TRUE;
}
#ifdef CONFIG_80211N_HT
if (psta->no_ht_gf_set) {
psta->no_ht_gf_set = 0;
pmlmepriv->num_sta_ht_no_gf--;
}
if (psta->no_ht_set) {
psta->no_ht_set = 0;
pmlmepriv->num_sta_no_ht--;
}
if (psta->ht_20mhz_set) {
psta->ht_20mhz_set = 0;
pmlmepriv->num_sta_ht_20mhz--;
}
if (psta->ht_40mhz_intolerant) {
psta->ht_40mhz_intolerant = 0;
if (pmlmepriv->num_sta_40mhz_intolerant > 0)
pmlmepriv->num_sta_40mhz_intolerant--;
else
rtw_warn_on(1);
}
if (rtw_ht_operation_update(padapter) > 0) {
update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE, 0);
update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _FALSE, 0);
}
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
update_beacon(padapter, WLAN_EID_MESH_CONFIG, NULL, _FALSE, 0);
if (pstapriv->asoc_list_cnt == 0)
_cancel_timer_ex(&padapter->mesh_atlm_param_req_timer);
beacon_updated = _TRUE;
}
#endif
if (beacon_updated == _TRUE)
update_beacon(padapter, 0xFF, NULL, _TRUE, 0);
#if 0
/* update associated stations cap. */
associated_clients_update(padapter, beacon_updated, STA_INFO_UPDATE_ALL); /* move it to avoid deadlock */
#endif
RTW_INFO("%s, updated=%d\n", __func__, beacon_updated);
return beacon_updated;
}
u8 ap_free_sta(_adapter *padapter, struct sta_info *psta, bool active, u16 reason, bool enqueue)
{
_irqL irqL;
u8 beacon_updated = _FALSE;
if (!psta)
return beacon_updated;
if (active == _TRUE) {
#ifdef CONFIG_80211N_HT
/* tear down Rx AMPDU */
send_delba(padapter, 0, psta->cmn.mac_addr);/* recipient */
/* tear down TX AMPDU */
send_delba(padapter, 1, psta->cmn.mac_addr);/* */ /* originator */
#endif /* CONFIG_80211N_HT */
if (!MLME_IS_MESH(padapter))
issue_deauth(padapter, psta->cmn.mac_addr, reason);
}
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter))
rtw_mesh_path_flush_by_nexthop(psta);
#endif
#ifdef CONFIG_BEAMFORMING
beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_LEAVE, psta->cmn.mac_addr, ETH_ALEN, 1);
#endif
#ifdef CONFIG_80211N_HT
psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
#endif
/* clear cam entry / key */
rtw_clearstakey_cmd(padapter, psta, enqueue);
_enter_critical_bh(&psta->lock, &irqL);
psta->state &= ~(_FW_LINKED | WIFI_UNDER_KEY_HANDSHAKE);
if ((psta->auth_len != 0) && (psta->pauth_frame != NULL)) {
rtw_mfree(psta->pauth_frame, psta->auth_len);
psta->pauth_frame = NULL;
psta->auth_len = 0;
}
_exit_critical_bh(&psta->lock, &irqL);
if (!MLME_IS_MESH(padapter)) {
#ifdef CONFIG_IOCTL_CFG80211
#ifdef COMPAT_KERNEL_RELEASE
rtw_cfg80211_indicate_sta_disassoc(padapter, psta->cmn.mac_addr, reason);
#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
rtw_cfg80211_indicate_sta_disassoc(padapter, psta->cmn.mac_addr, reason);
#else /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
/* will call rtw_cfg80211_indicate_sta_disassoc() in cmd_thread for old API context */
#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 37)) && !defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
#else
rtw_indicate_sta_disassoc_event(padapter, psta);
#endif
}
beacon_updated = bss_cap_update_on_sta_leave(padapter, psta);
report_del_sta_event(padapter, psta->cmn.mac_addr, reason, enqueue, _FALSE);
return beacon_updated;
}
int rtw_ap_inform_ch_switch(_adapter *padapter, u8 new_ch, u8 ch_offset)
{
_irqL irqL;
_list *phead, *plist;
int ret = 0;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
return ret;
RTW_INFO(FUNC_NDEV_FMT" with ch:%u, offset:%u\n",
FUNC_NDEV_ARG(padapter->pnetdev), new_ch, ch_offset);
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
/* for each sta in asoc_queue */
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
issue_action_spct_ch_switch(padapter, psta->cmn.mac_addr, new_ch, ch_offset);
psta->expire_to = ((pstapriv->expire_to * 2) > 5) ? 5 : (pstapriv->expire_to * 2);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
issue_action_spct_ch_switch(padapter, bc_addr, new_ch, ch_offset);
return ret;
}
int rtw_sta_flush(_adapter *padapter, bool enqueue)
{
_irqL irqL;
_list *phead, *plist;
int ret = 0;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 flush_num = 0;
char flush_list[NUM_STA];
int i;
if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
return ret;
RTW_INFO(FUNC_NDEV_FMT"\n", FUNC_NDEV_ARG(padapter->pnetdev));
/* pick sta from sta asoc_queue */
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
int stainfo_offset;
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
rtw_list_delete(&psta->asoc_list);
pstapriv->asoc_list_cnt--;
STA_SET_MESH_PLINK(psta, NULL);
stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
if (stainfo_offset_valid(stainfo_offset))
flush_list[flush_num++] = stainfo_offset;
else
rtw_warn_on(1);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
/* call ap_free_sta() for each sta picked */
for (i = 0; i < flush_num; i++) {
u8 sta_addr[ETH_ALEN];
psta = rtw_get_stainfo_by_offset(pstapriv, flush_list[i]);
_rtw_memcpy(sta_addr, psta->cmn.mac_addr, ETH_ALEN);
ap_free_sta(padapter, psta, _TRUE, WLAN_REASON_DEAUTH_LEAVING, enqueue);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter))
rtw_mesh_expire_peer(padapter, sta_addr);
#endif
}
if (!MLME_IS_MESH(padapter))
issue_deauth(padapter, bc_addr, WLAN_REASON_DEAUTH_LEAVING);
associated_clients_update(padapter, _TRUE, STA_INFO_UPDATE_ALL);
return ret;
}
/* called > TSR LEVEL for USB or SDIO Interface*/
void sta_info_update(_adapter *padapter, struct sta_info *psta)
{
int flags = psta->flags;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
/* update wmm cap. */
if (WLAN_STA_WME & flags)
psta->qos_option = 1;
else
psta->qos_option = 0;
if (pmlmepriv->qospriv.qos_option == 0)
psta->qos_option = 0;
#ifdef CONFIG_80211N_HT
/* update 802.11n ht cap. */
if (WLAN_STA_HT & flags) {
psta->htpriv.ht_option = _TRUE;
psta->qos_option = 1;
psta->htpriv.smps_cap = (psta->htpriv.ht_cap.cap_info & IEEE80211_HT_CAP_SM_PS) >> 2;
} else
psta->htpriv.ht_option = _FALSE;
if (pmlmepriv->htpriv.ht_option == _FALSE)
psta->htpriv.ht_option = _FALSE;
#endif
#ifdef CONFIG_80211AC_VHT
/* update 802.11AC vht cap. */
if (WLAN_STA_VHT & flags)
psta->vhtpriv.vht_option = _TRUE;
else
psta->vhtpriv.vht_option = _FALSE;
if (pmlmepriv->vhtpriv.vht_option == _FALSE)
psta->vhtpriv.vht_option = _FALSE;
#endif
update_sta_info_apmode(padapter, psta);
}
/* called >= TSR LEVEL for USB or SDIO Interface*/
void ap_sta_info_defer_update(_adapter *padapter, struct sta_info *psta)
{
if (psta->state & _FW_LINKED)
rtw_hal_update_ra_mask(psta); /* DM_RATR_STA_INIT */
}
/* restore hw setting from sw data structures */
void rtw_ap_restore_network(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
struct security_priv *psecuritypriv = &(padapter->securitypriv);
_irqL irqL;
_list *phead, *plist;
u8 chk_alive_num = 0;
char chk_alive_list[NUM_STA];
int i;
rtw_setopmode_cmd(padapter
, MLME_IS_AP(padapter) ? Ndis802_11APMode : Ndis802_11_mesh
, RTW_CMDF_DIRECTLY
);
set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
rtw_startbss_cmd(padapter, RTW_CMDF_DIRECTLY);
if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
/* restore group key, WEP keys is restored in ips_leave() */
rtw_set_key(padapter, psecuritypriv, psecuritypriv->dot118021XGrpKeyid, 0, _FALSE);
}
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
int stainfo_offset;
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
if (stainfo_offset_valid(stainfo_offset))
chk_alive_list[chk_alive_num++] = stainfo_offset;
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
for (i = 0; i < chk_alive_num; i++) {
psta = rtw_get_stainfo_by_offset(pstapriv, chk_alive_list[i]);
if (psta == NULL)
RTW_INFO(FUNC_ADPT_FMT" sta_info is null\n", FUNC_ADPT_ARG(padapter));
else if (psta->state & _FW_LINKED) {
rtw_sta_media_status_rpt(padapter, psta, 1);
Update_RA_Entry(padapter, psta);
/* pairwise key */
/* per sta pairwise key and settings */
if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_))
rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _FALSE);
}
}
}
void start_ap_mode(_adapter *padapter)
{
int i;
struct sta_info *psta = NULL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
#ifdef CONFIG_CONCURRENT_MODE
struct security_priv *psecuritypriv = &padapter->securitypriv;
#endif
pmlmepriv->update_bcn = _FALSE;
/*init_mlme_ap_info(padapter);*/
pmlmeext->bstart_bss = _FALSE;
pmlmepriv->num_sta_non_erp = 0;
pmlmepriv->num_sta_no_short_slot_time = 0;
pmlmepriv->num_sta_no_short_preamble = 0;
pmlmepriv->num_sta_ht_no_gf = 0;
#ifdef CONFIG_80211N_HT
pmlmepriv->num_sta_no_ht = 0;
#endif /* CONFIG_80211N_HT */
pmlmeinfo->HT_info_enable = 0;
pmlmeinfo->HT_caps_enable = 0;
pmlmeinfo->HT_enable = 0;
pmlmepriv->num_sta_ht_20mhz = 0;
pmlmepriv->num_sta_40mhz_intolerant = 0;
ATOMIC_SET(&pmlmepriv->olbc, _FALSE);
ATOMIC_SET(&pmlmepriv->olbc_ht, _FALSE);
#ifdef CONFIG_80211N_HT
pmlmepriv->ht_20mhz_width_req = _FALSE;
pmlmepriv->ht_intolerant_ch_reported = _FALSE;
pmlmepriv->ht_op_mode = 0;
pmlmepriv->sw_to_20mhz = 0;
#endif
_rtw_memset(pmlmepriv->ext_capab_ie_data, 0, sizeof(pmlmepriv->ext_capab_ie_data));
pmlmepriv->ext_capab_ie_len = 0;
#ifdef CONFIG_CONCURRENT_MODE
psecuritypriv->dot118021x_bmc_cam_id = INVALID_SEC_MAC_CAM_ID;
#endif
for (i = 0 ; i < pstapriv->max_aid; i++)
pstapriv->sta_aid[i] = NULL;
psta = rtw_get_bcmc_stainfo(padapter);
/*_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
if (psta)
rtw_free_stainfo(padapter, psta);
/*_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
rtw_init_bcmc_stainfo(padapter);
if (rtw_mi_get_ap_num(padapter))
RTW_SET_SCAN_BAND_SKIP(padapter, BAND_5G);
}
void rtw_ap_bcmc_sta_flush(_adapter *padapter)
{
#ifdef CONFIG_CONCURRENT_MODE
int cam_id = -1;
u8 *addr = adapter_mac_addr(padapter);
cam_id = rtw_iface_bcmc_id_get(padapter);
if (cam_id != INVALID_SEC_MAC_CAM_ID) {
RTW_PRINT("clear group key for "ADPT_FMT" addr:"MAC_FMT", camid:%d\n",
ADPT_ARG(padapter), MAC_ARG(addr), cam_id);
clear_cam_entry(padapter, cam_id);
rtw_camid_free(padapter, cam_id);
rtw_iface_bcmc_id_set(padapter, INVALID_SEC_MAC_CAM_ID); /*init default value*/
}
#else
invalidate_cam_all(padapter);
#endif
}
void stop_ap_mode(_adapter *padapter)
{
u8 self_action = MLME_ACTION_UNKNOWN;
struct sta_info *psta = NULL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
#ifdef CONFIG_SUPPORT_MULTI_BCN
struct dvobj_priv *pdvobj = padapter->dvobj;
_irqL irqL;
#endif
RTW_INFO("%s -"ADPT_FMT"\n", __func__, ADPT_ARG(padapter));
if (MLME_IS_AP(padapter))
self_action = MLME_AP_STOPPED;
else if (MLME_IS_MESH(padapter))
self_action = MLME_MESH_STOPPED;
else
rtw_warn_on(1);
pmlmepriv->update_bcn = _FALSE;
/*pmlmeext->bstart_bss = _FALSE;*/
padapter->netif_up = _FALSE;
/* _rtw_spinlock_free(&pmlmepriv->bcn_update_lock); */
/* reset and init security priv , this can refine with rtw_reset_securitypriv */
_rtw_memset((unsigned char *)&padapter->securitypriv, 0, sizeof(struct security_priv));
padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
padapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
#ifdef CONFIG_DFS_MASTER
rtw_dfs_rd_en_decision(padapter, self_action, 0);
#endif
/* free scan queue */
rtw_free_network_queue(padapter, _TRUE);
#if CONFIG_RTW_MACADDR_ACL
rtw_macaddr_acl_clear(padapter, RTW_ACL_PERIOD_BSS);
#endif
rtw_sta_flush(padapter, _TRUE);
rtw_ap_bcmc_sta_flush(padapter);
/* free_assoc_sta_resources */
rtw_free_all_stainfo(padapter);
psta = rtw_get_bcmc_stainfo(padapter);
if (psta) {
rtw_sta_mstatus_disc_rpt(padapter, psta->cmn.mac_id);
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
rtw_free_stainfo(padapter, psta);
/*_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);*/
}
rtw_free_mlme_priv_ie_data(pmlmepriv);
#ifdef CONFIG_SUPPORT_MULTI_BCN
if (pmlmeext->bstart_bss == _TRUE) {
#ifdef CONFIG_FW_HANDLE_TXBCN
u8 free_apid = CONFIG_LIMITED_AP_NUM;
#endif
_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
pdvobj->nr_ap_if--;
if (pdvobj->nr_ap_if > 0)
pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL / pdvobj->nr_ap_if;
else
pdvobj->inter_bcn_space = DEFAULT_BCN_INTERVAL;
#ifdef CONFIG_FW_HANDLE_TXBCN
rtw_ap_release_vapid(pdvobj, padapter->vap_id);
free_apid = padapter->vap_id;
padapter->vap_id = CONFIG_LIMITED_AP_NUM;
#endif
rtw_list_delete(&padapter->list);
_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
#ifdef CONFIG_FW_HANDLE_TXBCN
rtw_ap_mbid_bcn_dis(padapter, free_apid);
#endif
#ifdef CONFIG_SWTIMER_BASED_TXBCN
rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pdvobj->inter_bcn_space));
if (pdvobj->nr_ap_if == 0)
_cancel_timer_ex(&pdvobj->txbcn_timer);
#endif
}
#endif
pmlmeext->bstart_bss = _FALSE;
rtw_hal_rcr_set_chk_bssid(padapter, self_action);
#ifdef CONFIG_HW_P0_TSF_SYNC
correct_TSF(padapter, self_action);
#endif
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_MediaStatusNotify(padapter, 0); /* disconnect */
#endif
}
#endif /* CONFIG_NATIVEAP_MLME */
void rtw_ap_update_bss_chbw(_adapter *adapter, WLAN_BSSID_EX *bss, u8 ch, u8 bw, u8 offset)
{
#define UPDATE_VHT_CAP 1
#define UPDATE_HT_CAP 1
#ifdef CONFIG_80211AC_VHT
struct vht_priv *vhtpriv = &adapter->mlmepriv.vhtpriv;
#endif
{
u8 *p;
int ie_len;
u8 old_ch = bss->Configuration.DSConfig;
bool change_band = _FALSE;
if ((ch <= 14 && old_ch >= 36) || (ch >= 36 && old_ch <= 14))
change_band = _TRUE;
/* update channel in IE */
p = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), _DSSET_IE_, &ie_len, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
if (p && ie_len > 0)
*(p + 2) = ch;
bss->Configuration.DSConfig = ch;
/* band is changed, update ERP, support rate, ext support rate IE */
if (change_band == _TRUE)
change_band_update_ie(adapter, bss, ch);
}
#ifdef CONFIG_80211AC_VHT
if (vhtpriv->vht_option == _TRUE) {
u8 *vht_cap_ie, *vht_op_ie;
int vht_cap_ielen, vht_op_ielen;
u8 center_freq;
vht_cap_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_VHTCapability, &vht_cap_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
vht_op_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_VHTOperation, &vht_op_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
center_freq = rtw_get_center_ch(ch, bw, offset);
/* update vht cap ie */
if (vht_cap_ie && vht_cap_ielen) {
#if UPDATE_VHT_CAP
/* if ((bw == CHANNEL_WIDTH_160 || bw == CHANNEL_WIDTH_80_80) && pvhtpriv->sgi_160m)
SET_VHT_CAPABILITY_ELE_SHORT_GI160M(pvht_cap_ie + 2, 1);
else */
SET_VHT_CAPABILITY_ELE_SHORT_GI160M(vht_cap_ie + 2, 0);
if (bw >= CHANNEL_WIDTH_80 && vhtpriv->sgi_80m)
SET_VHT_CAPABILITY_ELE_SHORT_GI80M(vht_cap_ie + 2, 1);
else
SET_VHT_CAPABILITY_ELE_SHORT_GI80M(vht_cap_ie + 2, 0);
#endif
}
/* update vht op ie */
if (vht_op_ie && vht_op_ielen) {
if (bw < CHANNEL_WIDTH_80) {
SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
} else if (bw == CHANNEL_WIDTH_80) {
SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 1);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, center_freq);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
} else {
RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(adapter), bw);
rtw_warn_on(1);
}
}
}
#endif /* CONFIG_80211AC_VHT */
#ifdef CONFIG_80211N_HT
{
struct ht_priv *htpriv = &adapter->mlmepriv.htpriv;
u8 *ht_cap_ie, *ht_op_ie;
int ht_cap_ielen, ht_op_ielen;
ht_cap_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_HTCapability, &ht_cap_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
ht_op_ie = rtw_get_ie((bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)), EID_HTInfo, &ht_op_ielen, (bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)));
/* update ht cap ie */
if (ht_cap_ie && ht_cap_ielen) {
#if UPDATE_HT_CAP
if (bw >= CHANNEL_WIDTH_40)
SET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2, 1);
else
SET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2, 0);
if (bw >= CHANNEL_WIDTH_40 && htpriv->sgi_40m)
SET_HT_CAP_ELE_SHORT_GI40M(ht_cap_ie + 2, 1);
else
SET_HT_CAP_ELE_SHORT_GI40M(ht_cap_ie + 2, 0);
if (htpriv->sgi_20m)
SET_HT_CAP_ELE_SHORT_GI20M(ht_cap_ie + 2, 1);
else
SET_HT_CAP_ELE_SHORT_GI20M(ht_cap_ie + 2, 0);
#endif
}
/* update ht op ie */
if (ht_op_ie && ht_op_ielen) {
SET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2, ch);
switch (offset) {
case HAL_PRIME_CHNL_OFFSET_LOWER:
SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCA);
break;
case HAL_PRIME_CHNL_OFFSET_UPPER:
SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCB);
break;
case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
default:
SET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2, SCN);
break;
}
if (bw >= CHANNEL_WIDTH_40)
SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2, 1);
else
SET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2, 0);
}
}
#endif /* CONFIG_80211N_HT */
}
static u8 rtw_ap_update_chbw_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp
, u8 cur_ie_ch[], u8 cur_ie_bw[], u8 cur_ie_offset[]
, u8 dec_ch[], u8 dec_bw[], u8 dec_offset[]
, const char *caller)
{
_adapter *iface;
struct mlme_ext_priv *mlmeext;
WLAN_BSSID_EX *network;
u8 ifbmp_ch_changed = 0;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters)
continue;
iface = dvobj->padapters[i];
mlmeext = &(iface->mlmeextpriv);
if (MLME_IS_ASOC(iface)) {
RTW_INFO(FUNC_ADPT_FMT" %u,%u,%u => %u,%u,%u%s\n", caller, ADPT_ARG(iface)
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset
, dec_ch[i], dec_bw[i], dec_offset[i]
, MLME_IS_OPCH_SW(iface) ? " OPCH_SW" : "");
} else {
RTW_INFO(FUNC_ADPT_FMT" %u,%u,%u => %u,%u,%u%s\n", caller, ADPT_ARG(iface)
, cur_ie_ch[i], cur_ie_bw[i], cur_ie_offset[i]
, dec_ch[i], dec_bw[i], dec_offset[i]
, MLME_IS_OPCH_SW(iface) ? " OPCH_SW" : "");
}
}
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters)
continue;
iface = dvobj->padapters[i];
mlmeext = &(iface->mlmeextpriv);
network = &(mlmeext->mlmext_info.network);
/* ch setting differs from mlmeext.network IE */
if (cur_ie_ch[i] != dec_ch[i]
|| cur_ie_bw[i] != dec_bw[i]
|| cur_ie_offset[i] != dec_offset[i])
ifbmp_ch_changed |= BIT(i);
/* ch setting differs from existing one */
if (MLME_IS_ASOC(iface)
&& (mlmeext->cur_channel != dec_ch[i]
|| mlmeext->cur_bwmode != dec_bw[i]
|| mlmeext->cur_ch_offset != dec_offset[i])
) {
if (rtw_linked_check(iface) == _TRUE) {
#ifdef CONFIG_SPCT_CH_SWITCH
if (1)
rtw_ap_inform_ch_switch(iface, dec_ch[i], dec_offset[i]);
else
#endif
rtw_sta_flush(iface, _FALSE);
}
}
mlmeext->cur_channel = dec_ch[i];
mlmeext->cur_bwmode = dec_bw[i];
mlmeext->cur_ch_offset = dec_offset[i];
rtw_ap_update_bss_chbw(iface, network, dec_ch[i], dec_bw[i], dec_offset[i]);
}
return ifbmp_ch_changed;
}
static u8 rtw_ap_ch_specific_chk(_adapter *adapter, u8 ch, u8 *bw, u8 *offset, const char *caller)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
u8 ret = _SUCCESS;
if (rtw_chset_search_ch(chset, ch) < 0) {
RTW_WARN("%s ch:%u doesn't fit in chplan\n", caller, ch);
ret = _FAIL;
goto exit;
}
rtw_adjust_chbw(adapter, ch, bw, offset);
if (!rtw_get_offset_by_chbw(ch, *bw, offset)) {
RTW_WARN("%s %u,%u has no valid offset\n", caller, ch, *bw);
ret = _FAIL;
goto exit;
}
while (!rtw_chset_is_chbw_valid(chset, ch, *bw, *offset)
|| (rtw_odm_dfs_domain_unknown(dvobj) && rtw_is_dfs_chbw(ch, *bw, *offset))
) {
if (*bw > CHANNEL_WIDTH_20)
(*bw)--;
if (*bw == CHANNEL_WIDTH_20) {
*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
break;
}
}
if (rtw_odm_dfs_domain_unknown(dvobj) && rtw_is_dfs_chbw(ch, *bw, *offset)) {
RTW_WARN("%s DFS channel %u can't be used\n", caller, ch);
ret = _FAIL;
goto exit;
}
exit:
return ret;
}
static bool rtw_ap_choose_chbw(_adapter *adapter, u8 sel_ch, u8 max_bw, u8 cur_ch
, u8 *ch, u8 *bw, u8 *offset, u8 mesh_only, const char *caller)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
bool ch_avail = _FALSE;
#if defined(CONFIG_DFS_MASTER)
if (!rtw_odm_dfs_domain_unknown(dvobj)) {
if (rfctl->radar_detected
&& rfctl->dbg_dfs_choose_dfs_ch_first
) {
ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
, ch, bw, offset
, RTW_CHF_2G | RTW_CHF_NON_DFS
, cur_ch
, rfctl->ch_sel_same_band_prefer, mesh_only);
if (ch_avail == _TRUE) {
RTW_INFO("%s choose 5G DFS channel for debug\n", caller);
goto exit;
}
}
if (rfctl->radar_detected
&& rfctl->dfs_ch_sel_d_flags
) {
ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
, ch, bw, offset
, rfctl->dfs_ch_sel_d_flags
, cur_ch
, rfctl->ch_sel_same_band_prefer, mesh_only);
if (ch_avail == _TRUE) {
RTW_INFO("%s choose with dfs_ch_sel_d_flags:0x%02x for debug\n"
, caller, rfctl->dfs_ch_sel_d_flags);
goto exit;
}
}
ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
, ch, bw, offset
, 0
, cur_ch
, rfctl->ch_sel_same_band_prefer, mesh_only);
} else
#endif /* defined(CONFIG_DFS_MASTER) */
{
ch_avail = rtw_choose_shortest_waiting_ch(rfctl, sel_ch, max_bw
, ch, bw, offset
, RTW_CHF_DFS
, cur_ch
, rfctl->ch_sel_same_band_prefer, mesh_only);
}
#if defined(CONFIG_DFS_MASTER)
exit:
#endif
if (ch_avail == _FALSE)
RTW_WARN("%s no available channel\n", caller);
return ch_avail;
}
u8 rtw_ap_chbw_decision(_adapter *adapter, u8 ifbmp, u8 excl_ifbmp
, s16 req_ch, s8 req_bw, s8 req_offset
, u8 *ch, u8 *bw, u8 *offset, u8 *chbw_allow)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
bool ch_avail = _FALSE;
u8 cur_ie_ch[CONFIG_IFACE_NUMBER] = {0};
u8 cur_ie_bw[CONFIG_IFACE_NUMBER] = {0};
u8 cur_ie_offset[CONFIG_IFACE_NUMBER] = {0};
u8 dec_ch[CONFIG_IFACE_NUMBER] = {0};
u8 dec_bw[CONFIG_IFACE_NUMBER] = {0};
u8 dec_offset[CONFIG_IFACE_NUMBER] = {0};
u8 u_ch = 0, u_bw = 0, u_offset = 0;
struct mlme_ext_priv *mlmeext;
WLAN_BSSID_EX *network;
struct mi_state mstate;
struct mi_state mstate_others;
bool set_u_ch = _FALSE;
u8 ifbmp_others = 0xFF & ~ifbmp & ~excl_ifbmp;
u8 ifbmp_ch_changed = 0;
bool ifbmp_all_mesh = 0;
_adapter *iface;
int i;
#ifdef CONFIG_RTW_MESH
for (i = 0; i < dvobj->iface_nums; i++)
if ((ifbmp & BIT(i)) && dvobj->padapters)
if (!MLME_IS_MESH(dvobj->padapters[i]))
break;
ifbmp_all_mesh = i >= dvobj->iface_nums ? 1 : 0;
#endif
RTW_INFO("%s ifbmp:0x%02x excl_ifbmp:0x%02x req:%d,%d,%d\n", __func__
, ifbmp, excl_ifbmp, req_ch, req_bw, req_offset);
rtw_mi_status_by_ifbmp(dvobj, ifbmp, &mstate);
rtw_mi_status_by_ifbmp(dvobj, ifbmp_others, &mstate_others);
RTW_INFO("%s others ld_sta_num:%u, lg_sta_num:%u, ap_num:%u, mesh_num:%u\n"
, __func__, MSTATE_STA_LD_NUM(&mstate_others), MSTATE_STA_LG_NUM(&mstate_others)
, MSTATE_AP_NUM(&mstate_others), MSTATE_MESH_NUM(&mstate_others));
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
continue;
iface = dvobj->padapters[i];
mlmeext = &(iface->mlmeextpriv);
network = &(mlmeext->mlmext_info.network);
/* get current IE channel settings */
rtw_ies_get_chbw(BSS_EX_TLV_IES(network), BSS_EX_TLV_IES_LEN(network)
, &cur_ie_ch[i], &cur_ie_bw[i], &cur_ie_offset[i], 1, 1);
/* prepare temporary channel setting decision */
if (req_ch == 0) {
/* request comes from upper layer, use cur_ie values */
dec_ch[i] = cur_ie_ch[i];
dec_bw[i] = cur_ie_bw[i];
dec_offset[i] = cur_ie_offset[i];
} else {
/* use chbw of cur_ie updated with specifying req as temporary decision */
dec_ch[i] = (req_ch <= REQ_CH_NONE) ? cur_ie_ch[i] : req_ch;
if (req_bw <= REQ_BW_NONE) {
if (req_bw == REQ_BW_ORI)
dec_bw[i] = iface->mlmepriv.ori_bw;
else
dec_bw[i] = cur_ie_bw[i];
} else
dec_bw[i] = req_bw;
dec_offset[i] = (req_offset <= REQ_OFFSET_NONE) ? cur_ie_offset[i] : req_offset;
}
}
if (MSTATE_STA_LD_NUM(&mstate_others) || MSTATE_STA_LG_NUM(&mstate_others)
|| MSTATE_AP_NUM(&mstate_others) || MSTATE_MESH_NUM(&mstate_others)
) {
/* has linked/linking STA or has AP/Mesh mode */
rtw_warn_on(!rtw_mi_get_ch_setting_union_by_ifbmp(dvobj, ifbmp_others, &u_ch, &u_bw, &u_offset));
RTW_INFO("%s others union:%u,%u,%u\n", __func__, u_ch, u_bw, u_offset);
}
#ifdef CONFIG_MCC_MODE
if (MCC_EN(adapter) && req_ch == 0) {
if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
u8 if_id = adapter->iface_id;
mlmeext = &(adapter->mlmeextpriv);
/* check channel settings are the same */
if (cur_ie_ch[if_id] == mlmeext->cur_channel
&& cur_ie_bw[if_id] == mlmeext->cur_bwmode
&& cur_ie_offset[if_id] == mlmeext->cur_ch_offset) {
RTW_INFO(FUNC_ADPT_FMT"req ch settings are the same as current ch setting, go to exit\n"
, FUNC_ADPT_ARG(adapter));
*chbw_allow = _FALSE;
goto exit;
} else {
RTW_INFO(FUNC_ADPT_FMT"request channel settings are not the same as current channel setting(%d,%d,%d,%d,%d,%d), restart MCC\n"
, FUNC_ADPT_ARG(adapter)
, cur_ie_ch[if_id], cur_ie_bw[if_id], cur_ie_offset[if_id]
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
rtw_hal_set_mcc_setting_disconnect(adapter);
}
}
}
#endif /* CONFIG_MCC_MODE */
if (MSTATE_STA_LG_NUM(&mstate_others) && !MSTATE_STA_LD_NUM(&mstate_others)) {
/* has linking STA but no linked STA */
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
continue;
iface = dvobj->padapters[i];
rtw_adjust_chbw(iface, dec_ch[i], &dec_bw[i], &dec_offset[i]);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(iface))
rtw_mesh_adjust_chbw(dec_ch[i], &dec_bw[i], &dec_offset[i]);
#endif
if (rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch[i], dec_bw[i], dec_offset[i])) {
rtw_chset_sync_chbw(chset
, &dec_ch[i], &dec_bw[i], &dec_offset[i]
, &u_ch, &u_bw, &u_offset);
set_u_ch = _TRUE;
/* channel bw offset can be allowed, not need MCC */
*chbw_allow = _TRUE;
} else {
#ifdef CONFIG_MCC_MODE
if (MCC_EN(iface)) {
mlmeext = &(iface->mlmeextpriv);
mlmeext->cur_channel = *ch = dec_ch[i];
mlmeext->cur_bwmode = *bw = dec_bw[i];
mlmeext->cur_ch_offset = *offset = dec_offset[i];
/* channel bw offset can not be allowed, need MCC */
*chbw_allow = _FALSE;
RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(iface)
, *ch, *bw, *offset);
goto exit;
}
#endif /* CONFIG_MCC_MODE */
/* set this for possible ch change when join down*/
set_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING);
}
}
} else if (MSTATE_STA_LD_NUM(&mstate_others)
|| MSTATE_AP_NUM(&mstate_others) || MSTATE_MESH_NUM(&mstate_others)
) {
/* has linked STA mode or AP/Mesh mode */
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
continue;
iface = dvobj->padapters[i];
rtw_adjust_chbw(iface, u_ch, &dec_bw[i], &dec_offset[i]);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(iface))
rtw_mesh_adjust_chbw(u_ch, &dec_bw[i], &dec_offset[i]);
#endif
#ifdef CONFIG_MCC_MODE
if (MCC_EN(iface)) {
if (!rtw_is_chbw_grouped(u_ch, u_bw, u_offset, dec_ch[i], dec_bw[i], dec_offset[i])) {
mlmeext = &(iface->mlmeextpriv);
mlmeext->cur_channel = *ch = dec_ch[i] = cur_ie_ch[i];
mlmeext->cur_bwmode = *bw = dec_bw[i] = cur_ie_bw[i];
mlmeext->cur_ch_offset = *offset = dec_offset[i] = cur_ie_offset[i];
/* channel bw offset can not be allowed, need MCC */
*chbw_allow = _FALSE;
RTW_INFO(FUNC_ADPT_FMT" enable mcc: %u,%u,%u\n", FUNC_ADPT_ARG(iface)
, *ch, *bw, *offset);
goto exit;
} else
/* channel bw offset can be allowed, not need MCC */
*chbw_allow = _TRUE;
}
#endif /* CONFIG_MCC_MODE */
if (req_ch == 0 && dec_bw[i] > u_bw
&& rtw_is_dfs_chbw(u_ch, u_bw, u_offset)
) {
/* request comes from upper layer, prevent from additional channel waiting */
dec_bw[i] = u_bw;
if (dec_bw[i] == CHANNEL_WIDTH_20)
dec_offset[i] = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
/* follow */
rtw_chset_sync_chbw(chset
, &dec_ch[i], &dec_bw[i], &dec_offset[i]
, &u_ch, &u_bw, &u_offset);
}
set_u_ch = _TRUE;
} else {
/* autonomous decision */
u8 ori_ch = 0;
u8 max_bw;
/* autonomous decision, not need MCC */
*chbw_allow = _TRUE;
if (req_ch <= REQ_CH_NONE) /* channel is not specified */
goto choose_chbw;
/* get tmp dec union of ifbmp */
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
continue;
if (u_ch == 0) {
u_ch = dec_ch[i];
u_bw = dec_bw[i];
u_offset = dec_offset[i];
rtw_adjust_chbw(adapter, u_ch, &u_bw, &u_offset);
rtw_get_offset_by_chbw(u_ch, u_bw, &u_offset);
} else {
u8 tmp_ch = dec_ch[i];
u8 tmp_bw = dec_bw[i];
u8 tmp_offset = dec_offset[i];
rtw_adjust_chbw(adapter, tmp_ch, &tmp_bw, &tmp_offset);
rtw_get_offset_by_chbw(tmp_ch, tmp_bw, &tmp_offset);
rtw_warn_on(!rtw_is_chbw_grouped(u_ch, u_bw, u_offset, tmp_ch, tmp_bw, tmp_offset));
rtw_sync_chbw(&tmp_ch, &tmp_bw, &tmp_offset, &u_ch, &u_bw, &u_offset);
}
}
#ifdef CONFIG_RTW_MESH
/* if ifbmp are all mesh, apply bw restriction */
if (ifbmp_all_mesh)
rtw_mesh_adjust_chbw(u_ch, &u_bw, &u_offset);
#endif
RTW_INFO("%s ifbmp:0x%02x tmp union:%u,%u,%u\n", __func__, ifbmp, u_ch, u_bw, u_offset);
/* check if tmp dec union is usable */
if (rtw_ap_ch_specific_chk(adapter, u_ch, &u_bw, &u_offset, __func__) == _FAIL) {
/* channel can't be used */
if (req_ch > 0) {
/* specific channel and not from IE => don't change channel setting */
goto exit;
}
goto choose_chbw;
} else if (rtw_chset_is_chbw_non_ocp(chset, u_ch, u_bw, u_offset)) {
RTW_WARN("%s DFS channel %u,%u under non ocp\n", __func__, u_ch, u_bw);
if (req_ch > 0 && req_bw > REQ_BW_NONE) {
/* change_chbw with specific channel and specific bw, goto update_bss_chbw directly */
goto update_bss_chbw;
}
} else
goto update_bss_chbw;
choose_chbw:
req_ch = req_ch > 0 ? req_ch : 0;
max_bw = req_bw > REQ_BW_NONE ? req_bw : CHANNEL_WIDTH_20;
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
continue;
iface = dvobj->padapters[i];
mlmeext = &(iface->mlmeextpriv);
if (req_bw <= REQ_BW_NONE) {
if (req_bw == REQ_BW_ORI) {
if (max_bw < iface->mlmepriv.ori_bw)
max_bw = iface->mlmepriv.ori_bw;
} else {
if (max_bw < cur_ie_bw[i])
max_bw = cur_ie_bw[i];
}
}
if (MSTATE_AP_NUM(&mstate) || MSTATE_MESH_NUM(&mstate)) {
if (ori_ch == 0)
ori_ch = mlmeext->cur_channel;
else if (ori_ch != mlmeext->cur_channel)
rtw_warn_on(1);
} else {
if (ori_ch == 0)
ori_ch = cur_ie_ch[i];
else if (ori_ch != cur_ie_ch[i])
rtw_warn_on(1);
}
}
ch_avail = rtw_ap_choose_chbw(adapter, req_ch, max_bw
, ori_ch, &u_ch, &u_bw, &u_offset, ifbmp_all_mesh, __func__);
if (ch_avail == _FALSE)
goto exit;
update_bss_chbw:
for (i = 0; i < dvobj->iface_nums; i++) {
if (!(ifbmp & BIT(i)) || !dvobj->padapters[i])
continue;
iface = dvobj->padapters[i];
dec_ch[i] = u_ch;
if (dec_bw[i] > u_bw)
dec_bw[i] = u_bw;
if (dec_bw[i] == CHANNEL_WIDTH_20)
dec_offset[i] = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
else
dec_offset[i] = u_offset;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(iface))
rtw_mesh_adjust_chbw(dec_ch[i], &dec_bw[i], &dec_offset[i]);
#endif
}
set_u_ch = _TRUE;
}
ifbmp_ch_changed = rtw_ap_update_chbw_by_ifbmp(dvobj, ifbmp
, cur_ie_ch, cur_ie_bw, cur_ie_offset
, dec_ch, dec_bw, dec_offset
, __func__);
if (u_ch != 0)
RTW_INFO("%s union:%u,%u,%u\n", __func__, u_ch, u_bw, u_offset);
if (rtw_mi_check_fwstate(adapter, _FW_UNDER_SURVEY)) {
/* scanning, leave ch setting to scan state machine */
set_u_ch = _FALSE;
}
if (set_u_ch == _TRUE) {
*ch = u_ch;
*bw = u_bw;
*offset = u_offset;
}
exit:
return ifbmp_ch_changed;
}
u8 rtw_ap_sta_states_check(_adapter *adapter)
{
struct sta_info *psta;
struct sta_priv *pstapriv = &adapter->stapriv;
_list *plist, *phead;
_irqL irqL;
u8 rst = _FALSE;
if (!MLME_IS_AP(adapter) && !MLME_IS_MESH(adapter))
return _FALSE;
if (pstapriv->auth_list_cnt !=0)
return _TRUE;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
if (!(psta->state & _FW_LINKED)) {
RTW_INFO(ADPT_FMT"- SoftAP/Mesh - sta under linking, its state = 0x%x\n", ADPT_ARG(adapter), psta->state);
rst = _TRUE;
break;
} else if (psta->state & WIFI_UNDER_KEY_HANDSHAKE) {
RTW_INFO(ADPT_FMT"- SoftAP/Mesh - sta under key handshaking, its state = 0x%x\n", ADPT_ARG(adapter), psta->state);
rst = _TRUE;
break;
}
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
return rst;
}
/*#define DBG_SWTIMER_BASED_TXBCN*/
#ifdef CONFIG_SWTIMER_BASED_TXBCN
void tx_beacon_handlder(struct dvobj_priv *pdvobj)
{
#define BEACON_EARLY_TIME 20 /* unit:TU*/
_irqL irqL;
_list *plist, *phead;
u32 timestamp[2];
u32 bcn_interval_us; /* unit : usec */
u64 time;
u32 cur_tick, time_offset; /* unit : usec */
u32 inter_bcn_space_us; /* unit : usec */
u32 txbcn_timer_ms; /* unit : ms */
int nr_vap, idx, bcn_idx;
int i;
u8 val8, late = 0;
_adapter *padapter = NULL;
i = 0;
/* get first ap mode interface */
_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
if (rtw_is_list_empty(&pdvobj->ap_if_q.queue) || (pdvobj->nr_ap_if == 0)) {
RTW_INFO("[%s] ERROR: ap_if_q is empty!or nr_ap = %d\n", __func__, pdvobj->nr_ap_if);
_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
return;
} else
padapter = LIST_CONTAINOR(get_next(&(pdvobj->ap_if_q.queue)), struct _ADAPTER, list);
_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
if (NULL == padapter) {
RTW_INFO("[%s] ERROR: no any ap interface!\n", __func__);
return;
}
bcn_interval_us = DEFAULT_BCN_INTERVAL * NET80211_TU_TO_US;
if (0 == bcn_interval_us) {
RTW_INFO("[%s] ERROR: beacon interval = 0\n", __func__);
return;
}
/* read TSF */
timestamp[1] = rtw_read32(padapter, 0x560 + 4);
timestamp[0] = rtw_read32(padapter, 0x560);
while (timestamp[1]) {
time = (0xFFFFFFFF % bcn_interval_us + 1) * timestamp[1] + timestamp[0];
timestamp[0] = (u32)time;
timestamp[1] = (u32)(time >> 32);
}
cur_tick = timestamp[0] % bcn_interval_us;
_enter_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
nr_vap = (pdvobj->nr_ap_if - 1);
if (nr_vap > 0) {
inter_bcn_space_us = pdvobj->inter_bcn_space * NET80211_TU_TO_US; /* beacon_interval / (nr_vap+1); */
idx = cur_tick / inter_bcn_space_us;
if (idx < nr_vap) /* if (idx < (nr_vap+1))*/
bcn_idx = idx + 1; /* bcn_idx = (idx + 1) % (nr_vap+1);*/
else
bcn_idx = 0;
/* to get padapter based on bcn_idx */
padapter = NULL;
phead = get_list_head(&pdvobj->ap_if_q);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
padapter = LIST_CONTAINOR(plist, struct _ADAPTER, list);
plist = get_next(plist);
if (i == bcn_idx)
break;
i++;
}
if ((NULL == padapter) || (i > pdvobj->nr_ap_if)) {
RTW_INFO("[%s] ERROR: nr_ap_if = %d, padapter=%p, bcn_idx=%d, index=%d\n",
__func__, pdvobj->nr_ap_if, padapter, bcn_idx, i);
_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
return;
}
#ifdef DBG_SWTIMER_BASED_TXBCN
RTW_INFO("BCN_IDX=%d, cur_tick=%d, padapter=%p\n", bcn_idx, cur_tick, padapter);
#endif
if (((idx + 2 == nr_vap + 1) && (idx < nr_vap + 1)) || (0 == bcn_idx)) {
time_offset = bcn_interval_us - cur_tick - BEACON_EARLY_TIME * NET80211_TU_TO_US;
if ((s32)time_offset < 0)
time_offset += inter_bcn_space_us;
} else {
time_offset = (idx + 2) * inter_bcn_space_us - cur_tick - BEACON_EARLY_TIME * NET80211_TU_TO_US;
if (time_offset > (inter_bcn_space_us + (inter_bcn_space_us >> 1))) {
time_offset -= inter_bcn_space_us;
late = 1;
}
}
} else
/*#endif*/ { /* MBSSID */
time_offset = 2 * bcn_interval_us - cur_tick - BEACON_EARLY_TIME * NET80211_TU_TO_US;
if (time_offset > (bcn_interval_us + (bcn_interval_us >> 1))) {
time_offset -= bcn_interval_us;
late = 1;
}
}
_exit_critical_bh(&pdvobj->ap_if_q.lock, &irqL);
#ifdef DBG_SWTIMER_BASED_TXBCN
RTW_INFO("set sw bcn timer %d us\n", time_offset);
#endif
txbcn_timer_ms = time_offset / NET80211_TU_TO_US;
_set_timer(&pdvobj->txbcn_timer, txbcn_timer_ms);
if (padapter) {
#ifdef CONFIG_BCN_RECOVERY
rtw_ap_bcn_recovery(padapter);
#endif /*CONFIG_BCN_RECOVERY*/
#ifdef CONFIG_BCN_XMIT_PROTECT
rtw_ap_bcn_queue_empty_check(padapter, txbcn_timer_ms);
#endif /*CONFIG_BCN_XMIT_PROTECT*/
#ifdef DBG_SWTIMER_BASED_TXBCN
RTW_INFO("padapter=%p, PORT=%d\n", padapter, padapter->hw_port);
#endif
/* bypass TX BCN queue if op ch is switching/waiting */
if (!check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
&& !IS_CH_WAITING(adapter_to_rfctl(padapter))
) {
/*update_beacon(padapter, _TIM_IE_, NULL, _FALSE, 0);*/
/*issue_beacon(padapter, 0);*/
send_beacon(padapter);
}
}
#if 0
/* handle any buffered BC/MC frames*/
/* Don't dynamically change DIS_ATIM due to HW will auto send ACQ after HIQ empty.*/
val8 = *((unsigned char *)priv->beaconbuf + priv->timoffset + 4);
if (val8 & 0x01) {
process_mcast_dzqueue(priv);
priv->pkt_in_dtimQ = 0;
}
#endif
}
void tx_beacon_timer_handlder(void *ctx)
{
struct dvobj_priv *pdvobj = (struct dvobj_priv *)ctx;
_adapter *padapter = pdvobj->padapters[0];
if (padapter)
set_tx_beacon_cmd(padapter, 0);
}
#endif
void rtw_ap_parse_sta_capability(_adapter *adapter, struct sta_info *sta, u8 *cap)
{
sta->capability = RTW_GET_LE16(cap);
if (sta->capability & WLAN_CAPABILITY_SHORT_PREAMBLE)
sta->flags |= WLAN_STA_SHORT_PREAMBLE;
else
sta->flags &= ~WLAN_STA_SHORT_PREAMBLE;
}
u16 rtw_ap_parse_sta_supported_rates(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
{
u8 rate_set[12];
u8 rate_num;
int i;
u16 status = _STATS_SUCCESSFUL_;
rtw_ies_get_supported_rate(tlv_ies, tlv_ies_len, rate_set, &rate_num);
if (rate_num == 0) {
RTW_INFO(FUNC_ADPT_FMT" sta "MAC_FMT" with no supported rate\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
status = _STATS_FAILURE_;
goto exit;
}
_rtw_memcpy(sta->bssrateset, rate_set, rate_num);
sta->bssratelen = rate_num;
if (MLME_IS_AP(adapter)) {
/* this function force only CCK rates to be bassic rate... */
UpdateBrateTblForSoftAP(sta->bssrateset, sta->bssratelen);
}
/* if (hapd->iface->current_mode->mode == HOSTAPD_MODE_IEEE80211G) */ /* ? */
sta->flags |= WLAN_STA_NONERP;
for (i = 0; i < sta->bssratelen; i++) {
if ((sta->bssrateset[i] & 0x7f) > 22) {
sta->flags &= ~WLAN_STA_NONERP;
break;
}
}
exit:
return status;
}
u16 rtw_ap_parse_sta_security_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems)
{
struct security_priv *sec = &adapter->securitypriv;
u8 *wpa_ie;
int wpa_ie_len;
int group_cipher = 0, pairwise_cipher = 0;
u32 akm = 0;
u8 mfp_opt = MFP_NO;
u16 status = _STATS_SUCCESSFUL_;
sta->dot8021xalg = 0;
sta->wpa_psk = 0;
sta->wpa_group_cipher = 0;
sta->wpa2_group_cipher = 0;
sta->wpa_pairwise_cipher = 0;
sta->wpa2_pairwise_cipher = 0;
_rtw_memset(sta->wpa_ie, 0, sizeof(sta->wpa_ie));
if ((sec->wpa_psk & BIT(1)) && elems->rsn_ie) {
wpa_ie = elems->rsn_ie;
wpa_ie_len = elems->rsn_ie_len;
if (rtw_parse_wpa2_ie(wpa_ie - 2, wpa_ie_len + 2, &group_cipher, &pairwise_cipher, &akm, &mfp_opt) == _SUCCESS) {
sta->dot8021xalg = 1;/* psk, todo:802.1x */
sta->wpa_psk |= BIT(1);
sta->wpa2_group_cipher = group_cipher & sec->wpa2_group_cipher;
sta->wpa2_pairwise_cipher = pairwise_cipher & sec->wpa2_pairwise_cipher;
sta->akm_suite_type = akm;
if ((CHECK_BIT(WLAN_AKM_TYPE_SAE, akm)) && (MFP_NO == mfp_opt))
status = WLAN_STATUS_ROBUST_MGMT_FRAME_POLICY_VIOLATION;
if (!sta->wpa2_group_cipher)
status = WLAN_STATUS_GROUP_CIPHER_NOT_VALID;
if (!sta->wpa2_pairwise_cipher)
status = WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID;
} else
status = WLAN_STATUS_INVALID_IE;
}
else if ((sec->wpa_psk & BIT(0)) && elems->wpa_ie) {
wpa_ie = elems->wpa_ie;
wpa_ie_len = elems->wpa_ie_len;
if (rtw_parse_wpa_ie(wpa_ie - 2, wpa_ie_len + 2, &group_cipher, &pairwise_cipher, NULL) == _SUCCESS) {
sta->dot8021xalg = 1;/* psk, todo:802.1x */
sta->wpa_psk |= BIT(0);
sta->wpa_group_cipher = group_cipher & sec->wpa_group_cipher;
sta->wpa_pairwise_cipher = pairwise_cipher & sec->wpa_pairwise_cipher;
if (!sta->wpa_group_cipher)
status = WLAN_STATUS_GROUP_CIPHER_NOT_VALID;
if (!sta->wpa_pairwise_cipher)
status = WLAN_STATUS_PAIRWISE_CIPHER_NOT_VALID;
} else
status = WLAN_STATUS_INVALID_IE;
} else {
wpa_ie = NULL;
wpa_ie_len = 0;
}
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
/* MFP is mandatory for secure mesh */
if (adapter->mesh_info.mesh_auth_id)
sta->flags |= WLAN_STA_MFP;
} else
#endif
if ((sec->mfp_opt == MFP_REQUIRED && mfp_opt == MFP_NO) || mfp_opt == MFP_INVALID)
status = WLAN_STATUS_ROBUST_MGMT_FRAME_POLICY_VIOLATION;
else if (sec->mfp_opt >= MFP_OPTIONAL && mfp_opt >= MFP_OPTIONAL)
sta->flags |= WLAN_STA_MFP;
if ((sec->auth_type == NL80211_AUTHTYPE_SAE) &&
(CHECK_BIT(WLAN_AKM_TYPE_SAE, sta->akm_suite_type)) &&
(WLAN_AUTH_OPEN == sta->authalg)) {
/* WPA3-SAE, PMK caching */
if (rtw_cached_pmkid(adapter, sta->cmn.mac_addr) == -1) {
RTW_INFO("SAE: No PMKSA cache entry found\n");
status = WLAN_STATUS_INVALID_PMKID;
} else {
RTW_INFO("SAE: PMKSA cache entry found\n");
}
}
if (status != _STATS_SUCCESSFUL_)
goto exit;
if (!MLME_IS_AP(adapter))
goto exit;
sta->flags &= ~(WLAN_STA_WPS | WLAN_STA_MAYBE_WPS);
/* if (hapd->conf->wps_state && wpa_ie == NULL) { */ /* todo: to check ap if supporting WPS */
if (wpa_ie == NULL) {
if (elems->wps_ie) {
RTW_INFO("STA included WPS IE in "
"(Re)Association Request - assume WPS is "
"used\n");
sta->flags |= WLAN_STA_WPS;
/* wpabuf_free(sta->wps_ie); */
/* sta->wps_ie = wpabuf_alloc_copy(elems.wps_ie + 4, */
/* elems.wps_ie_len - 4); */
} else {
RTW_INFO("STA did not include WPA/RSN IE "
"in (Re)Association Request - possible WPS "
"use\n");
sta->flags |= WLAN_STA_MAYBE_WPS;
}
/* AP support WPA/RSN, and sta is going to do WPS, but AP is not ready */
/* that the selected registrar of AP is _FLASE */
if ((sec->wpa_psk > 0)
&& (sta->flags & (WLAN_STA_WPS | WLAN_STA_MAYBE_WPS))
) {
struct mlme_priv *mlme = &adapter->mlmepriv;
if (mlme->wps_beacon_ie) {
u8 selected_registrar = 0;
rtw_get_wps_attr_content(mlme->wps_beacon_ie, mlme->wps_beacon_ie_len, WPS_ATTR_SELECTED_REGISTRAR, &selected_registrar, NULL);
if (!selected_registrar) {
RTW_INFO("selected_registrar is _FALSE , or AP is not ready to do WPS\n");
status = _STATS_UNABLE_HANDLE_STA_;
goto exit;
}
}
}
} else {
int copy_len;
if (sec->wpa_psk == 0) {
RTW_INFO("STA " MAC_FMT
": WPA/RSN IE in association request, but AP don't support WPA/RSN\n",
MAC_ARG(sta->cmn.mac_addr));
status = WLAN_STATUS_INVALID_IE;
goto exit;
}
if (elems->wps_ie) {
RTW_INFO("STA included WPS IE in "
"(Re)Association Request - WPS is "
"used\n");
sta->flags |= WLAN_STA_WPS;
copy_len = 0;
} else
copy_len = ((wpa_ie_len + 2) > sizeof(sta->wpa_ie)) ? (sizeof(sta->wpa_ie)) : (wpa_ie_len + 2);
if (copy_len > 0)
_rtw_memcpy(sta->wpa_ie, wpa_ie - 2, copy_len);
}
exit:
return status;
}
void rtw_ap_parse_sta_wmm_ie(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
{
struct mlme_priv *mlme = &adapter->mlmepriv;
unsigned char WMM_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};
u8 *p;
sta->flags &= ~WLAN_STA_WME;
sta->qos_option = 0;
sta->qos_info = 0;
sta->has_legacy_ac = _TRUE;
sta->uapsd_vo = 0;
sta->uapsd_vi = 0;
sta->uapsd_be = 0;
sta->uapsd_bk = 0;
if (!mlme->qospriv.qos_option)
goto exit;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
/* QoS is mandatory in mesh */
sta->flags |= WLAN_STA_WME;
}
#endif
p = rtw_get_ie_ex(tlv_ies, tlv_ies_len, WLAN_EID_VENDOR_SPECIFIC, WMM_IE, 6, NULL, NULL);
if (!p)
goto exit;
sta->flags |= WLAN_STA_WME;
sta->qos_option = 1;
sta->qos_info = *(p + 8);
sta->max_sp_len = (sta->qos_info >> 5) & 0x3;
if ((sta->qos_info & 0xf) != 0xf)
sta->has_legacy_ac = _TRUE;
else
sta->has_legacy_ac = _FALSE;
if (sta->qos_info & 0xf) {
if (sta->qos_info & BIT(0))
sta->uapsd_vo = BIT(0) | BIT(1);
else
sta->uapsd_vo = 0;
if (sta->qos_info & BIT(1))
sta->uapsd_vi = BIT(0) | BIT(1);
else
sta->uapsd_vi = 0;
if (sta->qos_info & BIT(2))
sta->uapsd_bk = BIT(0) | BIT(1);
else
sta->uapsd_bk = 0;
if (sta->qos_info & BIT(3))
sta->uapsd_be = BIT(0) | BIT(1);
else
sta->uapsd_be = 0;
}
exit:
return;
}
void rtw_ap_parse_sta_ht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems)
{
struct mlme_priv *mlme = &adapter->mlmepriv;
sta->flags &= ~WLAN_STA_HT;
#ifdef CONFIG_80211N_HT
if (mlme->htpriv.ht_option == _FALSE)
goto exit;
/* save HT capabilities in the sta object */
_rtw_memset(&sta->htpriv.ht_cap, 0, sizeof(struct rtw_ieee80211_ht_cap));
if (elems->ht_capabilities && elems->ht_capabilities_len >= sizeof(struct rtw_ieee80211_ht_cap)) {
sta->flags |= WLAN_STA_HT;
sta->flags |= WLAN_STA_WME;
_rtw_memcpy(&sta->htpriv.ht_cap, elems->ht_capabilities, sizeof(struct rtw_ieee80211_ht_cap));
if (elems->ht_operation && elems->ht_operation_len == HT_OP_IE_LEN) {
_rtw_memcpy(sta->htpriv.ht_op, elems->ht_operation, HT_OP_IE_LEN);
sta->htpriv.op_present = 1;
}
}
exit:
#endif
return;
}
void rtw_ap_parse_sta_vht_ie(_adapter *adapter, struct sta_info *sta, struct rtw_ieee802_11_elems *elems)
{
struct mlme_priv *mlme = &adapter->mlmepriv;
sta->flags &= ~WLAN_STA_VHT;
#ifdef CONFIG_80211AC_VHT
if (mlme->vhtpriv.vht_option == _FALSE)
goto exit;
_rtw_memset(&sta->vhtpriv, 0, sizeof(struct vht_priv));
if (elems->vht_capabilities && elems->vht_capabilities_len == VHT_CAP_IE_LEN) {
sta->flags |= WLAN_STA_VHT;
_rtw_memcpy(sta->vhtpriv.vht_cap, elems->vht_capabilities, VHT_CAP_IE_LEN);
if (elems->vht_operation && elems->vht_operation_len== VHT_OP_IE_LEN) {
_rtw_memcpy(sta->vhtpriv.vht_op, elems->vht_operation, VHT_OP_IE_LEN);
sta->vhtpriv.op_present = 1;
}
if (elems->vht_op_mode_notify && elems->vht_op_mode_notify_len == 1) {
_rtw_memcpy(&sta->vhtpriv.vht_op_mode_notify, elems->vht_op_mode_notify, 1);
sta->vhtpriv.notify_present = 1;
}
}
exit:
#endif
return;
}
#endif /* CONFIG_AP_MODE */
================================================
FILE: core/rtw_beamforming.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_BEAMFORMING_C_
#include
#include
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
struct ndpa_sta_info {
u16 aid:12;
u16 feedback_type:1;
u16 nc_index:3;
};
static void _get_txvector_parameter(PADAPTER adapter, struct sta_info *sta, u8 *g_id, u16 *p_aid)
{
struct mlme_priv *mlme;
u16 aid;
u8 *bssid;
u16 val16;
u8 i;
mlme = &adapter->mlmepriv;
if (check_fwstate(mlme, WIFI_AP_STATE)) {
/*
* Sent by an AP and addressed to a STA associated with that AP
* or sent by a DLS or TDLS STA in a direct path to
* a DLS or TDLS peer STA
*/
aid = sta->cmn.aid;
bssid = adapter_mac_addr(adapter);
RTW_INFO("%s: AID=0x%x BSSID=" MAC_FMT "\n",
__FUNCTION__, sta->cmn.aid, MAC_ARG(bssid));
/* AID[0:8] */
aid &= 0x1FF;
/* BSSID[44:47] xor BSSID[40:43] */
val16 = ((bssid[5] & 0xF0) >> 4) ^ (bssid[5] & 0xF);
/* (dec(AID[0:8]) + dec(BSSID)*2^5) mod 2^9 */
*p_aid = (aid + (val16 << 5)) & 0x1FF;
*g_id = 63;
} else if ((check_fwstate(mlme, WIFI_ADHOC_STATE) == _TRUE)
|| (check_fwstate(mlme, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
/*
* Otherwise, includes
* 1. Sent to an IBSS STA
* 2. Sent by an AP to a non associated STA
* 3. Sent to a STA for which it is not known
* which condition is applicable
*/
*p_aid = 0;
*g_id = 63;
} else {
/* Addressed to AP */
bssid = sta->cmn.mac_addr;
RTW_INFO("%s: BSSID=" MAC_FMT "\n", __FUNCTION__, MAC_ARG(bssid));
/* BSSID[39:47] */
*p_aid = (bssid[5] << 1) | (bssid[4] >> 7);
*g_id = 0;
}
RTW_INFO("%s: GROUP_ID=0x%02x PARTIAL_AID=0x%04x\n",
__FUNCTION__, *g_id, *p_aid);
}
/*
* Parameters
* adapter struct _adapter*
* sta struct sta_info*
* sta_bf_cap beamforming capabe of sta
* sounding_dim Number of Sounding Dimensions
* comp_steering Compressed Steering Number of Beamformer Antennas Supported
*/
static void _get_sta_beamform_cap(PADAPTER adapter, struct sta_info *sta,
u8 *sta_bf_cap, u8 *sounding_dim, u8 *comp_steering)
{
struct beamforming_info *info;
struct ht_priv *ht;
#ifdef CONFIG_80211AC_VHT
struct vht_priv *vht;
#endif /* CONFIG_80211AC_VHT */
u16 bf_cap;
*sta_bf_cap = 0;
*sounding_dim = 0;
*comp_steering = 0;
info = GET_BEAMFORM_INFO(adapter);
ht = &adapter->mlmepriv.htpriv;
#ifdef CONFIG_80211AC_VHT
vht = &adapter->mlmepriv.vhtpriv;
#endif /* CONFIG_80211AC_VHT */
if (is_supported_ht(sta->wireless_mode) == _TRUE) {
/* HT */
bf_cap = ht->beamform_cap;
if (TEST_FLAG(bf_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
info->beamforming_cap |= BEAMFORMEE_CAP_HT_EXPLICIT;
*sta_bf_cap |= BEAMFORMER_CAP_HT_EXPLICIT;
*sounding_dim = (bf_cap & BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP) >> 6;
}
if (TEST_FLAG(bf_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
info->beamforming_cap |= BEAMFORMER_CAP_HT_EXPLICIT;
*sta_bf_cap |= BEAMFORMEE_CAP_HT_EXPLICIT;
*comp_steering = (bf_cap & BEAMFORMING_HT_BEAMFORMER_STEER_NUM) >> 4;
}
}
#ifdef CONFIG_80211AC_VHT
if (is_supported_vht(sta->wireless_mode) == _TRUE) {
/* VHT */
bf_cap = vht->beamform_cap;
/* We are SU Beamformee because the STA is SU Beamformer */
if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
info->beamforming_cap |= BEAMFORMEE_CAP_VHT_SU;
*sta_bf_cap |= BEAMFORMER_CAP_VHT_SU;
/* We are MU Beamformee because the STA is MU Beamformer */
if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)) {
info->beamforming_cap |= BEAMFORMEE_CAP_VHT_MU;
*sta_bf_cap |= BEAMFORMER_CAP_VHT_MU;
}
*sounding_dim = (bf_cap & BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM) >> 12;
}
/* We are SU Beamformer because the STA is SU Beamformee */
if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
info->beamforming_cap |= BEAMFORMER_CAP_VHT_SU;
*sta_bf_cap |= BEAMFORMEE_CAP_VHT_SU;
/* We are MU Beamformer because the STA is MU Beamformee */
if (TEST_FLAG(bf_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
info->beamforming_cap |= BEAMFORMER_CAP_VHT_MU;
*sta_bf_cap |= BEAMFORMEE_CAP_VHT_MU;
}
*comp_steering = (bf_cap & BEAMFORMING_VHT_BEAMFORMER_STS_CAP) >> 8;
}
}
#endif /* CONFIG_80211AC_VHT */
}
static u8 _send_ht_ndpa_packet(PADAPTER adapter, u8 *ra, enum channel_width bw)
{
/* General */
struct xmit_priv *pxmitpriv;
struct mlme_ext_priv *pmlmeext;
struct mlme_ext_info *pmlmeinfo;
struct xmit_frame *pmgntframe;
/* Beamforming */
struct beamforming_info *info;
struct beamformee_entry *bfee;
struct ndpa_sta_info sta_info;
u8 ActionHdr[4] = {ACT_CAT_VENDOR, 0x00, 0xE0, 0x4C};
/* MISC */
struct pkt_attrib *attrib;
struct rtw_ieee80211_hdr *pwlanhdr;
enum MGN_RATE txrate;
u8 *pframe;
u16 duration = 0;
u8 aSifsTime = 0;
RTW_INFO("+%s: Send to " MAC_FMT "\n", __FUNCTION__, MAC_ARG(ra));
pxmitpriv = &adapter->xmitpriv;
pmlmeext = &adapter->mlmeextpriv;
pmlmeinfo = &pmlmeext->mlmext_info;
bfee = rtw_bf_bfee_get_entry_by_addr(adapter, ra);
if (!bfee) {
RTW_ERR("%s: Cann't find beamformee entry!\n", __FUNCTION__);
return _FALSE;
}
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (!pmgntframe) {
RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
return _FALSE;
}
txrate = beamforming_get_htndp_tx_rate(GET_PDM_ODM(adapter), bfee->comp_steering_num_of_bfer);
/* update attribute */
attrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, attrib);
/*attrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
attrib->subtype = WIFI_ACTION_NOACK;
attrib->bwmode = bw;
/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
attrib->order = 1;
attrib->rate = (u8)txrate;
attrib->bf_pkt_type = 0;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
/* Frame control */
pwlanhdr->frame_ctl = 0;
set_frame_sub_type(pframe, attrib->subtype);
set_order_bit(pframe);
/* Duration */
if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
aSifsTime = 10;
else
aSifsTime = 16;
duration = 2 * aSifsTime + 40;
if (bw == CHANNEL_WIDTH_40)
duration += 87;
else
duration += 180;
set_duration(pframe, duration);
/* DA */
_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
/* SA */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
/* BSSID */
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
/* HT control field */
SET_HT_CTRL_CSI_STEERING(pframe + 24, 3);
SET_HT_CTRL_NDP_ANNOUNCEMENT(pframe + 24, 1);
/*
* Frame Body
* Category field: vender-specific value, 0x7F
* OUI: 0x00E04C
*/
_rtw_memcpy(pframe + 28, ActionHdr, 4);
attrib->pktlen = 32;
attrib->last_txcmdsz = attrib->pktlen;
dump_mgntframe(adapter, pmgntframe);
return _TRUE;
}
static u8 _send_vht_ndpa_packet(PADAPTER adapter, u8 *ra, u16 aid, enum channel_width bw)
{
/* General */
struct xmit_priv *pxmitpriv;
struct mlme_ext_priv *pmlmeext;
struct xmit_frame *pmgntframe;
/* Beamforming */
struct beamforming_info *info;
struct beamformee_entry *bfee;
struct ndpa_sta_info sta_info;
/* MISC */
struct pkt_attrib *attrib;
struct rtw_ieee80211_hdr *pwlanhdr;
u8 *pframe;
enum MGN_RATE txrate;
u16 duration = 0;
u8 sequence = 0, aSifsTime = 0;
RTW_INFO("+%s: Send to " MAC_FMT "\n", __FUNCTION__, MAC_ARG(ra));
pxmitpriv = &adapter->xmitpriv;
pmlmeext = &adapter->mlmeextpriv;
info = GET_BEAMFORM_INFO(adapter);
bfee = rtw_bf_bfee_get_entry_by_addr(adapter, ra);
if (!bfee) {
RTW_ERR("%s: Cann't find beamformee entry!\n", __FUNCTION__);
return _FALSE;
}
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (!pmgntframe) {
RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
return _FALSE;
}
txrate = beamforming_get_vht_ndp_tx_rate(GET_PDM_ODM(adapter), bfee->comp_steering_num_of_bfer);
/* update attribute */
attrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, attrib);
/*pattrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
attrib->subtype = WIFI_NDPA;
attrib->bwmode = bw;
/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
attrib->rate = (u8)txrate;
attrib->bf_pkt_type = 0;
_rtw_memset(pmgntframe->buf_addr, 0, TXDESC_OFFSET + WLANHDR_OFFSET);
pframe = pmgntframe->buf_addr + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
/* Frame control */
pwlanhdr->frame_ctl = 0;
set_frame_sub_type(pframe, attrib->subtype);
/* Duration */
if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
aSifsTime = 16;
else
aSifsTime = 10;
duration = 2 * aSifsTime + 44;
if (bw == CHANNEL_WIDTH_80)
duration += 40;
else if (bw == CHANNEL_WIDTH_40)
duration += 87;
else
duration += 180;
set_duration(pframe, duration);
/* RA */
_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
/* TA */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
/* Sounding Sequence, bit0~1 is reserved */
sequence = info->sounding_sequence << 2;
if (info->sounding_sequence >= 0x3f)
info->sounding_sequence = 0;
else
info->sounding_sequence++;
_rtw_memcpy(pframe + 16, &sequence, 1);
/* STA Info */
/*
* "AID12" Equal to 0 if the STA is an AP, mesh STA or
* STA that is a member of an IBSS
*/
if (check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _FALSE)
aid = 0;
sta_info.aid = aid;
/* "Feedback Type" set to 0 for SU */
sta_info.feedback_type = 0;
/* "Nc Index" reserved if the Feedback Type field indicates SU */
sta_info.nc_index = 0;
_rtw_memcpy(pframe + 17, (u8 *)&sta_info, 2);
attrib->pktlen = 19;
attrib->last_txcmdsz = attrib->pktlen;
dump_mgntframe(adapter, pmgntframe);
return _TRUE;
}
static u8 _send_vht_mu_ndpa_packet(PADAPTER adapter, enum channel_width bw)
{
/* General */
struct xmit_priv *pxmitpriv;
struct mlme_ext_priv *pmlmeext;
struct xmit_frame *pmgntframe;
/* Beamforming */
struct beamforming_info *info;
struct sounding_info *sounding;
struct beamformee_entry *bfee;
struct ndpa_sta_info sta_info;
/* MISC */
struct pkt_attrib *attrib;
struct rtw_ieee80211_hdr *pwlanhdr;
enum MGN_RATE txrate;
u8 *pframe;
u8 *ra = NULL;
u16 duration = 0;
u8 sequence = 0, aSifsTime = 0;
u8 i;
RTW_INFO("+%s\n", __FUNCTION__);
pxmitpriv = &adapter->xmitpriv;
pmlmeext = &adapter->mlmeextpriv;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
txrate = MGN_VHT2SS_MCS0;
/*
* Fill the first MU BFee entry (STA1) MAC addr to destination address then
* HW will change A1 to broadcast addr.
* 2015.05.28. Suggested by SD1 Chunchu.
*/
bfee = &info->bfee_entry[sounding->mu_sounding_list[0]];
ra = bfee->mac_addr;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (!pmgntframe) {
RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
return _FALSE;
}
/* update attribute */
attrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, attrib);
/*attrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
attrib->subtype = WIFI_NDPA;
attrib->bwmode = bw;
/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
attrib->rate = (u8)txrate;
/* Set TxBFPktType of Tx desc to unicast type if there is only one MU STA for HW design */
if (info->sounding_info.candidate_mu_bfee_cnt > 1)
attrib->bf_pkt_type = 1;
else
attrib->bf_pkt_type = 0;
_rtw_memset(pmgntframe->buf_addr, 0, TXDESC_OFFSET + WLANHDR_OFFSET);
pframe = pmgntframe->buf_addr + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
/* Frame control */
pwlanhdr->frame_ctl = 0;
set_frame_sub_type(pframe, attrib->subtype);
/* Duration */
if (is_supported_5g(pmlmeext->cur_wireless_mode) || is_supported_ht(pmlmeext->cur_wireless_mode))
aSifsTime = 16;
else
aSifsTime = 10;
duration = 2 * aSifsTime + 44;
if (bw == CHANNEL_WIDTH_80)
duration += 40;
else if (bw == CHANNEL_WIDTH_40)
duration += 87;
else
duration += 180;
set_duration(pframe, duration);
/* RA */
_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
/* TA */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
/* Sounding Sequence, bit0~1 is reserved */
sequence = info->sounding_sequence << 2;
if (info->sounding_sequence >= 0x3f)
info->sounding_sequence = 0;
else
info->sounding_sequence++;
_rtw_memcpy(pframe + 16, &sequence, 1);
attrib->pktlen = 17;
/*
* Construct STA info. for multiple STAs
* STA Info1, ..., STA Info n
*/
for (i = 0; i < sounding->candidate_mu_bfee_cnt; i++) {
bfee = &info->bfee_entry[sounding->mu_sounding_list[i]];
sta_info.aid = bfee->aid;
sta_info.feedback_type = 1; /* 1'b1: MU */
sta_info.nc_index = 0;
_rtw_memcpy(pframe + attrib->pktlen, (u8 *)&sta_info, 2);
attrib->pktlen += 2;
}
attrib->last_txcmdsz = attrib->pktlen;
dump_mgntframe(adapter, pmgntframe);
return _TRUE;
}
static u8 _send_bf_report_poll(PADAPTER adapter, u8 *ra, u8 bFinalPoll)
{
/* General */
struct xmit_priv *pxmitpriv;
struct xmit_frame *pmgntframe;
/* MISC */
struct pkt_attrib *attrib;
struct rtw_ieee80211_hdr *pwlanhdr;
u8 *pframe;
RTW_INFO("+%s: Send to " MAC_FMT "\n", __FUNCTION__, MAC_ARG(ra));
pxmitpriv = &adapter->xmitpriv;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (!pmgntframe) {
RTW_ERR("%s: alloc mgnt frame fail!\n", __FUNCTION__);
return _FALSE;
}
/* update attribute */
attrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, attrib);
/*attrib->type = WIFI_MGT_TYPE;*/ /* set in update_mgntframe_attrib() */
attrib->subtype = WIFI_BF_REPORT_POLL;
attrib->bwmode = CHANNEL_WIDTH_20;
/*attrib->qsel = QSLT_MGNT;*/ /* set in update_mgntframe_attrib() */
attrib->rate = MGN_6M;
if (bFinalPoll)
attrib->bf_pkt_type = 3;
else
attrib->bf_pkt_type = 2;
_rtw_memset(pmgntframe->buf_addr, 0, TXDESC_OFFSET + WLANHDR_OFFSET);
pframe = pmgntframe->buf_addr + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
/* Frame control */
pwlanhdr->frame_ctl = 0;
set_frame_sub_type(pframe, attrib->subtype);
/* Duration */
set_duration(pframe, 100);
/* RA */
_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN);
/* TA */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
/* Feedback Segment Retransmission Bitmap */
pframe[16] = 0xFF;
attrib->pktlen = 17;
attrib->last_txcmdsz = attrib->pktlen;
dump_mgntframe(adapter, pmgntframe);
return _TRUE;
}
static void _sounding_update_min_period(PADAPTER adapter, u16 period, u8 leave)
{
struct beamforming_info *info;
struct beamformee_entry *bfee;
u8 i = 0;
u16 min_val = 0xFFFF;
info = GET_BEAMFORM_INFO(adapter);
if (_TRUE == leave) {
/*
* When a BFee left,
* we need to find the latest min sounding period
* from the remaining BFees
*/
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if ((bfee->used == _TRUE)
&& (bfee->sound_period < min_val))
min_val = bfee->sound_period;
}
if (min_val == 0xFFFF)
info->sounding_info.min_sounding_period = 0;
else
info->sounding_info.min_sounding_period = min_val;
} else {
if ((info->sounding_info.min_sounding_period == 0)
|| (period < info->sounding_info.min_sounding_period))
info->sounding_info.min_sounding_period = period;
}
}
static void _sounding_init(struct sounding_info *sounding)
{
_rtw_memset(sounding->su_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_SU);
_rtw_memset(sounding->mu_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_MU);
sounding->state = SOUNDING_STATE_NONE;
sounding->su_bfee_curidx = 0xFF;
sounding->candidate_mu_bfee_cnt = 0;
sounding->min_sounding_period = 0;
sounding->sound_remain_cnt_per_period = 0;
}
static void _sounding_reset_vars(PADAPTER adapter)
{
struct beamforming_info *info;
struct sounding_info *sounding;
u8 idx;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
_rtw_memset(sounding->su_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_SU);
_rtw_memset(sounding->mu_sounding_list, 0xFF, MAX_NUM_BEAMFORMEE_MU);
sounding->su_bfee_curidx = 0xFF;
sounding->candidate_mu_bfee_cnt = 0;
/* Clear bSound flag for the new period */
for (idx = 0; idx < MAX_BEAMFORMEE_ENTRY_NUM; idx++) {
if ((info->bfee_entry[idx].used == _TRUE)
&& (info->bfee_entry[idx].sounding == _TRUE)) {
info->bfee_entry[idx].sounding = _FALSE;
info->bfee_entry[idx].bCandidateSoundingPeer = _FALSE;
}
}
}
/*
* Return
* 0 Prepare sounding list OK
* -1 Fail to prepare sounding list, because no beamformee need to souding
* -2 Fail to prepare sounding list, because beamformee state not ready
*
*/
static int _sounding_get_list(PADAPTER adapter)
{
struct beamforming_info *info;
struct sounding_info *sounding;
struct beamformee_entry *bfee;
u8 i, mu_idx = 0, su_idx = 0, not_ready = 0;
int ret = 0;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
/* Add MU BFee list first because MU priority is higher than SU */
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (bfee->used == _FALSE)
continue;
if (bfee->state != BEAMFORM_ENTRY_HW_STATE_ADDED) {
RTW_ERR("%s: Invalid BFee idx(%d) Hw state=%d\n", __FUNCTION__, i, bfee->state);
not_ready++;
continue;
}
/*
* Decrease BFee's SoundCnt per period
* If the remain count is 0,
* then it can be sounded at this time
*/
if (bfee->SoundCnt) {
bfee->SoundCnt--;
if (bfee->SoundCnt)
continue;
}
/*
*
* If the STA supports MU BFee capability then we add it to MUSoundingList directly
* because we can only sound one STA by unicast NDPA with MU cap enabled to get correct channel info.
* Suggested by BB team Luke Lee. 2015.11.25.
*/
if (bfee->cap & BEAMFORMEE_CAP_VHT_MU) {
/* MU BFee */
if (mu_idx >= MAX_NUM_BEAMFORMEE_MU) {
RTW_ERR("%s: Too much MU bfee entry(Limit:%d)\n", __FUNCTION__, MAX_NUM_BEAMFORMEE_MU);
continue;
}
if (bfee->bApplySounding == _TRUE) {
bfee->bCandidateSoundingPeer = _TRUE;
bfee->SoundCnt = GetInitSoundCnt(bfee->sound_period, sounding->min_sounding_period);
sounding->mu_sounding_list[mu_idx] = i;
mu_idx++;
}
} else if (bfee->cap & (BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT)) {
/* SU BFee (HT/VHT) */
if (su_idx >= MAX_NUM_BEAMFORMEE_SU) {
RTW_ERR("%s: Too much SU bfee entry(Limit:%d)\n", __FUNCTION__, MAX_NUM_BEAMFORMEE_SU);
continue;
}
if (bfee->bDeleteSounding == _TRUE) {
sounding->su_sounding_list[su_idx] = i;
su_idx++;
} else if ((bfee->bApplySounding == _TRUE)
&& (bfee->bSuspendSUCap == _FALSE)) {
bfee->bCandidateSoundingPeer = _TRUE;
bfee->SoundCnt = GetInitSoundCnt(bfee->sound_period, sounding->min_sounding_period);
sounding->su_sounding_list[su_idx] = i;
su_idx++;
}
}
}
sounding->candidate_mu_bfee_cnt = mu_idx;
if (su_idx + mu_idx == 0) {
ret = -1;
if (not_ready)
ret = -2;
}
RTW_INFO("-%s: There are %d SU and %d MU BFees in this sounding period\n", __FUNCTION__, su_idx, mu_idx);
return ret;
}
static void _sounding_handler(PADAPTER adapter)
{
struct beamforming_info *info;
struct sounding_info *sounding;
struct beamformee_entry *bfee;
u8 su_idx, i;
u32 timeout_period = 0;
u8 set_timer = _FALSE;
int ret = 0;
static u16 wait_cnt = 0;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
RTW_DBG("+%s: state=%d\n", __FUNCTION__, sounding->state);
if ((sounding->state != SOUNDING_STATE_INIT)
&& (sounding->state != SOUNDING_STATE_SU_SOUNDDOWN)
&& (sounding->state != SOUNDING_STATE_MU_SOUNDDOWN)
&& (sounding->state != SOUNDING_STATE_SOUNDING_TIMEOUT)) {
RTW_WARN("%s: Invalid State(%d) and return!\n", __FUNCTION__, sounding->state);
return;
}
if (sounding->state == SOUNDING_STATE_INIT) {
RTW_INFO("%s: Sounding start\n", __FUNCTION__);
/* Init Var */
_sounding_reset_vars(adapter);
/* Get the sounding list of this sounding period */
ret = _sounding_get_list(adapter);
if (ret == -1) {
wait_cnt = 0;
sounding->state = SOUNDING_STATE_NONE;
RTW_ERR("%s: No BFees found, set to SOUNDING_STATE_NONE\n", __FUNCTION__);
info->sounding_running--;
return;
}
if (ret == -2) {
RTW_WARN("%s: Temporarily cann't find BFee to sounding\n", __FUNCTION__);
if (wait_cnt < 5) {
wait_cnt++;
} else {
wait_cnt = 0;
sounding->state = SOUNDING_STATE_NONE;
RTW_ERR("%s: Wait changing state timeout!! Set to SOUNDING_STATE_NONE\n", __FUNCTION__);
}
info->sounding_running--;
return;
}
if (ret != 0) {
wait_cnt = 0;
RTW_ERR("%s: Unkown state(%d)!\n", __FUNCTION__, ret);
info->sounding_running--;
return;
}
wait_cnt = 0;
if (check_fwstate(&adapter->mlmepriv, WIFI_SITE_MONITOR) == _TRUE) {
RTW_INFO("%s: Sounding abort! scanning APs...\n", __FUNCTION__);
info->sounding_running--;
return;
}
rtw_ps_deny(adapter, PS_DENY_BEAMFORMING);
LeaveAllPowerSaveModeDirect(adapter);
}
/* Get non-sound SU BFee index */
for (i = 0; i < MAX_NUM_BEAMFORMEE_SU; i++) {
su_idx = sounding->su_sounding_list[i];
if (su_idx >= MAX_BEAMFORMEE_ENTRY_NUM)
continue;
bfee = &info->bfee_entry[su_idx];
if (_FALSE == bfee->sounding)
break;
}
if (i < MAX_NUM_BEAMFORMEE_SU) {
sounding->su_bfee_curidx = su_idx;
/* Set to sounding start state */
sounding->state = SOUNDING_STATE_SU_START;
RTW_DBG("%s: Set to SOUNDING_STATE_SU_START\n", __FUNCTION__);
bfee->sounding = _TRUE;
/* Reset sounding timeout flag for the new sounding */
bfee->bSoundingTimeout = _FALSE;
if (_TRUE == bfee->bDeleteSounding) {
u8 res = _FALSE;
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_END_PERIOD, &res, 1, 0);
return;
}
/* Start SU sounding */
if (bfee->cap & BEAMFORMEE_CAP_VHT_SU)
_send_vht_ndpa_packet(adapter, bfee->mac_addr, bfee->aid, bfee->sound_bw);
else if (bfee->cap & BEAMFORMEE_CAP_HT_EXPLICIT)
_send_ht_ndpa_packet(adapter, bfee->mac_addr, bfee->sound_bw);
/* Set sounding timeout timer */
_set_timer(&info->sounding_timeout_timer, SU_SOUNDING_TIMEOUT);
return;
}
if (sounding->candidate_mu_bfee_cnt > 0) {
/*
* If there is no SU BFee then find MU BFee and perform MU sounding
*
* Need to check the MU starting condition. 2015.12.15.
*/
sounding->state = SOUNDING_STATE_MU_START;
RTW_DBG("%s: Set to SOUNDING_STATE_MU_START\n", __FUNCTION__);
/* Update MU BFee info */
for (i = 0; i < sounding->candidate_mu_bfee_cnt; i++) {
bfee = &info->bfee_entry[sounding->mu_sounding_list[i]];
bfee->sounding = _TRUE;
}
/* Send MU NDPA */
bfee = &info->bfee_entry[sounding->mu_sounding_list[0]];
_send_vht_mu_ndpa_packet(adapter, bfee->sound_bw);
/* Send BF report poll if more than 1 MU STA */
for (i = 1; i < sounding->candidate_mu_bfee_cnt; i++) {
bfee = &info->bfee_entry[sounding->mu_sounding_list[i]];
if (i == (sounding->candidate_mu_bfee_cnt - 1))/* The last STA*/
_send_bf_report_poll(adapter, bfee->mac_addr, _TRUE);
else
_send_bf_report_poll(adapter, bfee->mac_addr, _FALSE);
}
sounding->candidate_mu_bfee_cnt = 0;
/* Set sounding timeout timer */
_set_timer(&info->sounding_timeout_timer, MU_SOUNDING_TIMEOUT);
return;
}
info->sounding_running--;
sounding->state = SOUNDING_STATE_INIT;
RTW_INFO("%s: Sounding finished!\n", __FUNCTION__);
rtw_ps_deny_cancel(adapter, PS_DENY_BEAMFORMING);
}
static void _sounding_force_stop(PADAPTER adapter)
{
struct beamforming_info *info;
struct sounding_info *sounding;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
if ((sounding->state == SOUNDING_STATE_SU_START)
|| (sounding->state == SOUNDING_STATE_MU_START)) {
u8 res = _FALSE;
_cancel_timer_ex(&info->sounding_timeout_timer);
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_END_PERIOD, &res, 1, 1);
return;
}
info->sounding_running--;
sounding->state = SOUNDING_STATE_INIT;
RTW_INFO("%s: Sounding finished!\n", __FUNCTION__);
rtw_ps_deny_cancel(adapter, PS_DENY_BEAMFORMING);
}
static void _sounding_timer_handler(void *FunctionContext)
{
PADAPTER adapter;
struct beamforming_info *info;
struct sounding_info *sounding;
static u8 delay = 0;
RTW_DBG("+%s\n", __FUNCTION__);
adapter = (PADAPTER)FunctionContext;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
if (SOUNDING_STATE_NONE == sounding->state) {
RTW_INFO("%s: Stop!\n", __FUNCTION__);
if (info->sounding_running)
RTW_WARN("%s: souding_running=%d when thread stop!\n",
__FUNCTION__, info->sounding_running);
return;
}
_set_timer(&info->sounding_timer, sounding->min_sounding_period);
if (!info->sounding_running) {
if (SOUNDING_STATE_INIT != sounding->state) {
RTW_WARN("%s: state(%d) != SOUNDING_STATE_INIT!!\n", __FUNCTION__, sounding->state);
sounding->state = SOUNDING_STATE_INIT;
}
delay = 0;
info->sounding_running++;
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_START_PERIOD, NULL, 0, 1);
} else {
if (delay != 0xFF)
delay++;
RTW_WARN("%s: souding is still processing...(state:%d, running:%d, delay:%d)\n",
__FUNCTION__, sounding->state, info->sounding_running, delay);
if (delay > 3) {
RTW_WARN("%s: Stop sounding!!\n", __FUNCTION__);
_sounding_force_stop(adapter);
}
}
}
static void _sounding_timeout_timer_handler(void *FunctionContext)
{
PADAPTER adapter;
struct beamforming_info *info;
struct sounding_info *sounding;
struct beamformee_entry *bfee;
RTW_WARN("+%s\n", __FUNCTION__);
adapter = (PADAPTER)FunctionContext;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
if (SOUNDING_STATE_SU_START == sounding->state) {
sounding->state = SOUNDING_STATE_SOUNDING_TIMEOUT;
RTW_ERR("%s: Set to SU SOUNDING_STATE_SOUNDING_TIMEOUT\n", __FUNCTION__);
/* SU BFee */
bfee = &info->bfee_entry[sounding->su_bfee_curidx];
bfee->bSoundingTimeout = _TRUE;
RTW_WARN("%s: The BFee entry[%d] is Sounding Timeout!\n", __FUNCTION__, sounding->su_bfee_curidx);
} else if (SOUNDING_STATE_MU_START == sounding->state) {
sounding->state = SOUNDING_STATE_SOUNDING_TIMEOUT;
RTW_ERR("%s: Set to MU SOUNDING_STATE_SOUNDING_TIMEOUT\n", __FUNCTION__);
} else {
RTW_WARN("%s: unexpected sounding state:0x%02x\n", __FUNCTION__, sounding->state);
return;
}
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_START_PERIOD, NULL, 0, 1);
}
static struct beamformer_entry *_bfer_get_free_entry(PADAPTER adapter)
{
u8 i = 0;
struct beamforming_info *info;
struct beamformer_entry *bfer;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMER_ENTRY_NUM; i++) {
bfer = &info->bfer_entry[i];
if (bfer->used == _FALSE)
return bfer;
}
return NULL;
}
static struct beamformer_entry *_bfer_get_entry_by_addr(PADAPTER adapter, u8 *ra)
{
u8 i = 0;
struct beamforming_info *info;
struct beamformer_entry *bfer;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMER_ENTRY_NUM; i++) {
bfer = &info->bfer_entry[i];
if (bfer->used == _FALSE)
continue;
if (_rtw_memcmp(ra, bfer->mac_addr, ETH_ALEN) == _TRUE)
return bfer;
}
return NULL;
}
static struct beamformer_entry *_bfer_add_entry(PADAPTER adapter,
struct sta_info *sta, u8 bf_cap, u8 sounding_dim, u8 comp_steering)
{
struct mlme_priv *mlme;
struct beamforming_info *info;
struct beamformer_entry *bfer;
u8 *bssid;
u16 val16;
u8 i;
mlme = &adapter->mlmepriv;
info = GET_BEAMFORM_INFO(adapter);
bfer = _bfer_get_entry_by_addr(adapter, sta->cmn.mac_addr);
if (!bfer) {
bfer = _bfer_get_free_entry(adapter);
if (!bfer)
return NULL;
}
bfer->used = _TRUE;
_get_txvector_parameter(adapter, sta, &bfer->g_id, &bfer->p_aid);
_rtw_memcpy(bfer->mac_addr, sta->cmn.mac_addr, ETH_ALEN);
bfer->cap = bf_cap;
bfer->state = BEAMFORM_ENTRY_HW_STATE_ADD_INIT;
bfer->NumofSoundingDim = sounding_dim;
if (TEST_FLAG(bf_cap, BEAMFORMER_CAP_VHT_MU)) {
info->beamformer_mu_cnt += 1;
bfer->aid = sta->cmn.aid;
} else if (TEST_FLAG(bf_cap, BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT)) {
info->beamformer_su_cnt += 1;
/* Record HW idx info */
for (i = 0; i < MAX_NUM_BEAMFORMER_SU; i++) {
if ((info->beamformer_su_reg_maping & BIT(i)) == 0) {
info->beamformer_su_reg_maping |= BIT(i);
bfer->su_reg_index = i;
break;
}
}
RTW_INFO("%s: Add BFer entry beamformer_su_reg_maping=%#x, su_reg_index=%d\n",
__FUNCTION__, info->beamformer_su_reg_maping, bfer->su_reg_index);
}
return bfer;
}
static void _bfer_remove_entry(PADAPTER adapter, struct beamformer_entry *entry)
{
struct beamforming_info *info;
info = GET_BEAMFORM_INFO(adapter);
entry->state = BEAMFORM_ENTRY_HW_STATE_DELETE_INIT;
if (TEST_FLAG(entry->cap, BEAMFORMER_CAP_VHT_MU)) {
info->beamformer_mu_cnt -= 1;
_rtw_memset(entry->gid_valid, 0, 8);
_rtw_memset(entry->user_position, 0, 16);
} else if (TEST_FLAG(entry->cap, BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT)) {
info->beamformer_su_cnt -= 1;
}
if (info->beamformer_mu_cnt == 0)
info->beamforming_cap &= ~BEAMFORMEE_CAP_VHT_MU;
if (info->beamformer_su_cnt == 0)
info->beamforming_cap &= ~(BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT);
}
static u8 _bfer_set_entry_gid(PADAPTER adapter, u8 *addr, u8 *gid, u8 *position)
{
struct beamformer_entry bfer;
memset(&bfer, 0, sizeof(bfer));
memcpy(bfer.mac_addr, addr, ETH_ALEN);
/* Parsing Membership Status Array */
memcpy(bfer.gid_valid, gid, 8);
/* Parsing User Position Array */
memcpy(bfer.user_position, position, 16);
/* Config HW GID table */
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_GID_TABLE, (u8 *) &bfer,
sizeof(bfer), 1);
return _SUCCESS;
}
static struct beamformee_entry *_bfee_get_free_entry(PADAPTER adapter)
{
u8 i = 0;
struct beamforming_info *info;
struct beamformee_entry *bfee;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (bfee->used == _FALSE)
return bfee;
}
return NULL;
}
static struct beamformee_entry *_bfee_get_entry_by_addr(PADAPTER adapter, u8 *ra)
{
u8 i = 0;
struct beamforming_info *info;
struct beamformee_entry *bfee;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (bfee->used == _FALSE)
continue;
if (_rtw_memcmp(ra, bfee->mac_addr, ETH_ALEN) == _TRUE)
return bfee;
}
return NULL;
}
static u8 _bfee_get_first_su_entry_idx(PADAPTER adapter, struct beamformee_entry *ignore)
{
struct beamforming_info *info;
struct beamformee_entry *bfee;
u8 i;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (ignore && (bfee == ignore))
continue;
if (bfee->used == _FALSE)
continue;
if ((!TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU))
&& TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT))
return i;
}
return 0xFF;
}
/*
* Description:
* Get the first entry index of MU Beamformee.
*
* Return Value:
* Index of the first MU sta, or 0xFF for invalid index.
*
* 2015.05.25. Created by tynli.
*
*/
static u8 _bfee_get_first_mu_entry_idx(PADAPTER adapter, struct beamformee_entry *ignore)
{
struct beamforming_info *info;
struct beamformee_entry *bfee;
u8 i;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (ignore && (bfee == ignore))
continue;
if (bfee->used == _FALSE)
continue;
if (TEST_FLAG(bfee->cap, BEAMFORMEE_CAP_VHT_MU))
return i;
}
return 0xFF;
}
static struct beamformee_entry *_bfee_add_entry(PADAPTER adapter,
struct sta_info *sta, u8 bf_cap, u8 sounding_dim, u8 comp_steering)
{
struct mlme_priv *mlme;
struct beamforming_info *info;
struct beamformee_entry *bfee;
u8 *bssid;
u16 val16;
u8 i;
mlme = &adapter->mlmepriv;
info = GET_BEAMFORM_INFO(adapter);
bfee = _bfee_get_entry_by_addr(adapter, sta->cmn.mac_addr);
if (!bfee) {
bfee = _bfee_get_free_entry(adapter);
if (!bfee)
return NULL;
}
bfee->used = _TRUE;
bfee->aid = sta->cmn.aid;
bfee->mac_id = sta->cmn.mac_id;
bfee->sound_bw = sta->cmn.bw_mode;
_get_txvector_parameter(adapter, sta, &bfee->g_id, &bfee->p_aid);
sta->cmn.bf_info.g_id = bfee->g_id;
sta->cmn.bf_info.p_aid = bfee->p_aid;
_rtw_memcpy(bfee->mac_addr, sta->cmn.mac_addr, ETH_ALEN);
bfee->txbf = _FALSE;
bfee->sounding = _FALSE;
bfee->sound_period = 40;
_sounding_update_min_period(adapter, bfee->sound_period, _FALSE);
bfee->SoundCnt = GetInitSoundCnt(bfee->sound_period, info->sounding_info.min_sounding_period);
bfee->cap = bf_cap;
bfee->state = BEAMFORM_ENTRY_HW_STATE_ADD_INIT;
bfee->bCandidateSoundingPeer = _FALSE;
bfee->bSoundingTimeout = _FALSE;
bfee->bDeleteSounding = _FALSE;
bfee->bApplySounding = _TRUE;
bfee->tx_timestamp = 0;
bfee->tx_bytes = 0;
bfee->LogStatusFailCnt = 0;
bfee->NumofSoundingDim = sounding_dim;
bfee->comp_steering_num_of_bfer = comp_steering;
bfee->bSuspendSUCap = _FALSE;
if (TEST_FLAG(bf_cap, BEAMFORMEE_CAP_VHT_MU)) {
info->beamformee_mu_cnt += 1;
info->first_mu_bfee_index = _bfee_get_first_mu_entry_idx(adapter, NULL);
if (_TRUE == info->bEnableSUTxBFWorkAround) {
/* When the first MU BFee added, discard SU BFee bfee's capability */
if ((info->beamformee_mu_cnt == 1) && (info->beamformee_su_cnt > 0)) {
if (info->TargetSUBFee) {
info->TargetSUBFee->bSuspendSUCap = _TRUE;
info->TargetSUBFee->bDeleteSounding = _TRUE;
} else {
RTW_ERR("%s: UNEXPECTED!! info->TargetSUBFee is NULL!", __FUNCTION__);
}
info->TargetSUBFee = NULL;
_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_CSI_REPORT, (u8*)&info->TargetCSIInfo, sizeof(struct _RT_CSI_INFO), 0);
}
}
/* Record HW idx info */
for (i = 0; i < MAX_NUM_BEAMFORMEE_MU; i++) {
if ((info->beamformee_mu_reg_maping & BIT(i)) == 0) {
info->beamformee_mu_reg_maping |= BIT(i);
bfee->mu_reg_index = i;
break;
}
}
RTW_INFO("%s: Add BFee entry beamformee_mu_reg_maping=%#x, mu_reg_index=%d\n",
__FUNCTION__, info->beamformee_mu_reg_maping, bfee->mu_reg_index);
} else if (TEST_FLAG(bf_cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT)) {
info->beamformee_su_cnt += 1;
if (_TRUE == info->bEnableSUTxBFWorkAround) {
/* Record the first SU BFee index. We only allow the first SU BFee to be sound */
if ((info->beamformee_su_cnt == 1) && (info->beamformee_mu_cnt == 0)) {
info->TargetSUBFee = bfee;
_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
bfee->bSuspendSUCap = _FALSE;
} else {
bfee->bSuspendSUCap = _TRUE;
}
}
/* Record HW idx info */
for (i = 0; i < MAX_NUM_BEAMFORMEE_SU; i++) {
if ((info->beamformee_su_reg_maping & BIT(i)) == 0) {
info->beamformee_su_reg_maping |= BIT(i);
bfee->su_reg_index = i;
break;
}
}
RTW_INFO("%s: Add BFee entry beamformee_su_reg_maping=%#x, su_reg_index=%d\n",
__FUNCTION__, info->beamformee_su_reg_maping, bfee->su_reg_index);
}
return bfee;
}
static void _bfee_remove_entry(PADAPTER adapter, struct beamformee_entry *entry)
{
struct beamforming_info *info;
u8 idx;
info = GET_BEAMFORM_INFO(adapter);
entry->state = BEAMFORM_ENTRY_HW_STATE_DELETE_INIT;
if (TEST_FLAG(entry->cap, BEAMFORMEE_CAP_VHT_MU)) {
info->beamformee_mu_cnt -= 1;
info->first_mu_bfee_index = _bfee_get_first_mu_entry_idx(adapter, entry);
if (_TRUE == info->bEnableSUTxBFWorkAround) {
if ((info->beamformee_mu_cnt == 0) && (info->beamformee_su_cnt > 0)) {
idx = _bfee_get_first_su_entry_idx(adapter, NULL);
info->TargetSUBFee = &info->bfee_entry[idx];
_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
info->TargetSUBFee->bSuspendSUCap = _FALSE;
}
}
} else if (TEST_FLAG(entry->cap, BEAMFORMEE_CAP_VHT_SU|BEAMFORMEE_CAP_HT_EXPLICIT)) {
info->beamformee_su_cnt -= 1;
/* When the target SU BFee leaves, disable workaround */
if ((_TRUE == info->bEnableSUTxBFWorkAround)
&& (entry == info->TargetSUBFee)) {
entry->bSuspendSUCap = _TRUE;
info->TargetSUBFee = NULL;
_rtw_memset(&info->TargetCSIInfo, 0, sizeof(struct _RT_CSI_INFO));
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_CSI_REPORT, (u8*)&info->TargetCSIInfo, sizeof(struct _RT_CSI_INFO), 0);
}
}
if (info->beamformee_mu_cnt == 0)
info->beamforming_cap &= ~BEAMFORMER_CAP_VHT_MU;
if (info->beamformee_su_cnt == 0)
info->beamforming_cap &= ~(BEAMFORMER_CAP_VHT_SU|BEAMFORMER_CAP_HT_EXPLICIT);
_sounding_update_min_period(adapter, 0, _TRUE);
}
static enum beamforming_cap _bfee_get_entry_cap_by_macid(PADAPTER adapter, u8 macid)
{
struct beamforming_info *info;
struct beamformee_entry *bfee;
u8 i;
info = GET_BEAMFORM_INFO(adapter);
for (i = 0; i < MAX_BEAMFORMER_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (bfee->used == _FALSE)
continue;
if (bfee->mac_id == macid)
return bfee->cap;
}
return BEAMFORMING_CAP_NONE;
}
static void _beamforming_enter(PADAPTER adapter, void *p)
{
struct mlme_priv *mlme;
struct ht_priv *htpriv;
#ifdef CONFIG_80211AC_VHT
struct vht_priv *vhtpriv;
#endif
struct mlme_ext_priv *mlme_ext;
struct sta_info *sta, *sta_copy;
struct beamforming_info *info;
struct beamformer_entry *bfer = NULL;
struct beamformee_entry *bfee = NULL;
u8 wireless_mode;
u8 sta_bf_cap;
u8 sounding_dim = 0; /* number of sounding dimensions */
u8 comp_steering_num = 0; /* compressed steering number */
mlme = &adapter->mlmepriv;
htpriv = &mlme->htpriv;
#ifdef CONFIG_80211AC_VHT
vhtpriv = &mlme->vhtpriv;
#endif
mlme_ext = &adapter->mlmeextpriv;
info = GET_BEAMFORM_INFO(adapter);
sta_copy = (struct sta_info *)p;
sta = rtw_get_stainfo(&adapter->stapriv, sta_copy->cmn.mac_addr);
if (!sta) {
RTW_ERR("%s: Cann't find STA info for " MAC_FMT "\n",
__FUNCTION__, MAC_ARG(sta_copy->cmn.mac_addr));
return;
}
if (sta != sta_copy) {
RTW_WARN("%s: Origin sta(fake)=%p realsta=%p for " MAC_FMT "\n",
__FUNCTION__, sta_copy, sta, MAC_ARG(sta_copy->cmn.mac_addr));
}
/* The current setting does not support Beaforming */
wireless_mode = sta->wireless_mode;
if ((is_supported_ht(wireless_mode) == _FALSE)
&& (is_supported_vht(wireless_mode) == _FALSE)) {
RTW_WARN("%s: Not support HT or VHT mode\n", __FUNCTION__);
return;
}
if ((0 == htpriv->beamform_cap)
#ifdef CONFIG_80211AC_VHT
&& (0 == vhtpriv->beamform_cap)
#endif
) {
RTW_INFO("The configuration disabled Beamforming! Skip...\n");
return;
}
_get_sta_beamform_cap(adapter, sta,
&sta_bf_cap, &sounding_dim, &comp_steering_num);
RTW_INFO("STA Beamforming Capability=0x%02X\n", sta_bf_cap);
if (sta_bf_cap == BEAMFORMING_CAP_NONE)
return;
if ((sta_bf_cap & BEAMFORMEE_CAP_HT_EXPLICIT)
|| (sta_bf_cap & BEAMFORMEE_CAP_VHT_SU)
|| (sta_bf_cap & BEAMFORMEE_CAP_VHT_MU))
sta_bf_cap |= BEAMFORMEE_CAP;
if ((sta_bf_cap & BEAMFORMER_CAP_HT_EXPLICIT)
|| (sta_bf_cap & BEAMFORMER_CAP_VHT_SU)
|| (sta_bf_cap & BEAMFORMER_CAP_VHT_MU))
sta_bf_cap |= BEAMFORMER_CAP;
if (sta_bf_cap & BEAMFORMER_CAP) {
/* The other side is beamformer */
bfer = _bfer_add_entry(adapter, sta, sta_bf_cap, sounding_dim, comp_steering_num);
if (!bfer)
RTW_ERR("%s: Fail to allocate bfer entry!\n", __FUNCTION__);
}
if (sta_bf_cap & BEAMFORMEE_CAP) {
/* The other side is beamformee */
bfee = _bfee_add_entry(adapter, sta, sta_bf_cap, sounding_dim, comp_steering_num);
if (!bfee)
RTW_ERR("%s: Fail to allocate bfee entry!\n", __FUNCTION__);
}
if (!bfer && !bfee)
return;
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_ENTER, (u8*)sta);
/* Perform sounding if there is BFee */
if ((info->beamformee_su_cnt != 0)
|| (info->beamformee_mu_cnt != 0)) {
if (SOUNDING_STATE_NONE == info->sounding_info.state) {
info->sounding_info.state = SOUNDING_STATE_INIT;
/* Start sounding after 2 sec */
_set_timer(&info->sounding_timer, 2000);
}
}
}
static void _beamforming_reset(PADAPTER adapter)
{
RTW_ERR("%s: Not ready!!\n", __FUNCTION__);
}
static void _beamforming_leave(PADAPTER adapter, u8 *ra)
{
struct beamforming_info *info;
struct beamformer_entry *bfer = NULL;
struct beamformee_entry *bfee = NULL;
u8 bHwStateAddInit = _FALSE;
RTW_INFO("+%s\n", __FUNCTION__);
info = GET_BEAMFORM_INFO(adapter);
bfer = _bfer_get_entry_by_addr(adapter, ra);
bfee = _bfee_get_entry_by_addr(adapter, ra);
if (!bfer && !bfee) {
RTW_WARN("%s: " MAC_FMT " is neither beamforming ee or er!!\n",
__FUNCTION__, MAC_ARG(ra));
return;
}
if (bfer)
_bfer_remove_entry(adapter, bfer);
if (bfee)
_bfee_remove_entry(adapter, bfee);
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_LEAVE, ra);
/* Stop sounding if there is no any BFee */
if ((info->beamformee_su_cnt == 0)
&& (info->beamformee_mu_cnt == 0)) {
_cancel_timer_ex(&info->sounding_timer);
_sounding_init(&info->sounding_info);
}
RTW_INFO("-%s\n", __FUNCTION__);
}
static void _beamforming_sounding_down(PADAPTER adapter, u8 status)
{
struct beamforming_info *info;
struct sounding_info *sounding;
struct beamformee_entry *bfee;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
RTW_INFO("+%s: sounding=%d, status=0x%02x\n", __FUNCTION__, sounding->state, status);
if (sounding->state == SOUNDING_STATE_MU_START) {
RTW_INFO("%s: MU sounding done\n", __FUNCTION__);
sounding->state = SOUNDING_STATE_MU_SOUNDDOWN;
RTW_INFO("%s: Set to SOUNDING_STATE_MU_SOUNDDOWN\n", __FUNCTION__);
info->SetHalSoundownOnDemandCnt++;
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_STATUS, &status);
} else if (sounding->state == SOUNDING_STATE_SU_START) {
RTW_INFO("%s: SU entry[%d] sounding down\n", __FUNCTION__, sounding->su_bfee_curidx);
bfee = &info->bfee_entry[sounding->su_bfee_curidx];
sounding->state = SOUNDING_STATE_SU_SOUNDDOWN;
RTW_INFO("%s: Set to SOUNDING_STATE_SU_SOUNDDOWN\n", __FUNCTION__);
/*
*
* bfee->bSoundingTimeout this flag still cannot avoid
* old sound down event happens in the new sounding period.
* 2015.12.10
*/
if (_TRUE == bfee->bSoundingTimeout) {
RTW_WARN("%s: The entry[%d] is bSoundingTimeout!\n", __FUNCTION__, sounding->su_bfee_curidx);
bfee->bSoundingTimeout = _FALSE;
return;
}
if (_TRUE == status) {
/* success */
bfee->LogStatusFailCnt = 0;
info->SetHalSoundownOnDemandCnt++;
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_STATUS, &status);
} else if (_TRUE == bfee->bDeleteSounding) {
RTW_WARN("%s: Delete entry[%d] sounding info!\n", __FUNCTION__, sounding->su_bfee_curidx);
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_STATUS, &status);
bfee->bDeleteSounding = _FALSE;
} else {
bfee->LogStatusFailCnt++;
RTW_WARN("%s: LogStatusFailCnt=%d\n", __FUNCTION__, bfee->LogStatusFailCnt);
if (bfee->LogStatusFailCnt > 30) {
RTW_ERR("%s: LogStatusFailCnt > 30, Stop SOUNDING!!\n", __FUNCTION__);
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_LEAVE, bfee->mac_addr, ETH_ALEN, 1);
}
}
} else {
RTW_WARN("%s: unexpected sounding state:0x%02x\n", __FUNCTION__, sounding->state);
return;
}
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_START_PERIOD, NULL, 0, 0);
}
static void _c2h_snd_txbf(PADAPTER adapter, u8 *buf, u8 buf_len)
{
struct beamforming_info *info;
u8 res;
info = GET_BEAMFORM_INFO(adapter);
_cancel_timer_ex(&info->sounding_timeout_timer);
res = C2H_SND_TXBF_GET_SND_RESULT(buf) ? _TRUE : _FALSE;
RTW_INFO("+%s: %s\n", __FUNCTION__, res==_TRUE?"Success":"Fail!");
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_END_PERIOD, &res, 1, 1);
}
/*
* Description:
* This function is for phydm only
*/
enum beamforming_cap rtw_bf_bfee_get_entry_cap_by_macid(void *mlme, u8 macid)
{
PADAPTER adapter;
enum beamforming_cap cap = BEAMFORMING_CAP_NONE;
adapter = mlme_to_adapter((struct mlme_priv *)mlme);
cap = _bfee_get_entry_cap_by_macid(adapter, macid);
return cap;
}
struct beamformer_entry *rtw_bf_bfer_get_entry_by_addr(PADAPTER adapter, u8 *ra)
{
return _bfer_get_entry_by_addr(adapter, ra);
}
struct beamformee_entry *rtw_bf_bfee_get_entry_by_addr(PADAPTER adapter, u8 *ra)
{
return _bfee_get_entry_by_addr(adapter, ra);
}
void rtw_bf_get_ndpa_packet(PADAPTER adapter, union recv_frame *precv_frame)
{
RTW_DBG("+%s\n", __FUNCTION__);
}
u32 rtw_bf_get_report_packet(PADAPTER adapter, union recv_frame *precv_frame)
{
u32 ret = _SUCCESS;
struct beamforming_info *info;
struct beamformee_entry *bfee = NULL;
u8 *pframe;
u32 frame_len;
u8 *ta;
u8 *frame_body;
u8 category, action;
u8 *pMIMOCtrlField, *pCSIMatrix;
u8 Nc = 0, Nr = 0, CH_W = 0, Ng = 0, CodeBook = 0;
u16 CSIMatrixLen = 0;
RTW_INFO("+%s\n", __FUNCTION__);
info = GET_BEAMFORM_INFO(adapter);
pframe = precv_frame->u.hdr.rx_data;
frame_len = precv_frame->u.hdr.len;
/* Memory comparison to see if CSI report is the same with previous one */
ta = get_addr2_ptr(pframe);
bfee = _bfee_get_entry_by_addr(adapter, ta);
if (!bfee)
return _FAIL;
frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
category = frame_body[0];
action = frame_body[1];
if ((category == RTW_WLAN_CATEGORY_VHT)
&& (action == RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING)) {
pMIMOCtrlField = pframe + 26;
Nc = (*pMIMOCtrlField) & 0x7;
Nr = ((*pMIMOCtrlField) & 0x38) >> 3;
CH_W = (((*pMIMOCtrlField) & 0xC0) >> 6);
Ng = (*(pMIMOCtrlField+1)) & 0x3;
CodeBook = ((*(pMIMOCtrlField+1)) & 0x4) >> 2;
/*
* 24+(1+1+3)+2
* ==> MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)
*/
pCSIMatrix = pMIMOCtrlField + 3 + Nc;
CSIMatrixLen = frame_len - 26 - 3 - Nc;
info->TargetCSIInfo.bVHT = _TRUE;
} else if ((category == RTW_WLAN_CATEGORY_HT)
&& (action == RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING)) {
pMIMOCtrlField = pframe + 26;
Nc = (*pMIMOCtrlField) & 0x3;
Nr = ((*pMIMOCtrlField) & 0xC) >> 2;
CH_W = ((*pMIMOCtrlField) & 0x10) >> 4;
Ng = ((*pMIMOCtrlField) & 0x60) >> 5;
CodeBook = ((*(pMIMOCtrlField+1)) & 0x6) >> 1;
/*
* 24+(1+1+6)+2
* ==> MAC header+(Category+ActionCode+MIMOControlField)+SNR(Nc=2)
*/
pCSIMatrix = pMIMOCtrlField + 6 + Nr;
CSIMatrixLen = frame_len - 26 - 6 - Nr;
info->TargetCSIInfo.bVHT = _FALSE;
}
/* Update current CSI report info */
if ((_TRUE == info->bEnableSUTxBFWorkAround)
&& (info->TargetSUBFee == bfee)) {
if ((info->TargetCSIInfo.Nc != Nc) || (info->TargetCSIInfo.Nr != Nr) ||
(info->TargetCSIInfo.ChnlWidth != CH_W) || (info->TargetCSIInfo.Ng != Ng) ||
(info->TargetCSIInfo.CodeBook != CodeBook)) {
info->TargetCSIInfo.Nc = Nc;
info->TargetCSIInfo.Nr = Nr;
info->TargetCSIInfo.ChnlWidth = CH_W;
info->TargetCSIInfo.Ng = Ng;
info->TargetCSIInfo.CodeBook = CodeBook;
rtw_bf_cmd(adapter, BEAMFORMING_CTRL_SET_CSI_REPORT, (u8*)&info->TargetCSIInfo, sizeof(struct _RT_CSI_INFO), 1);
}
}
RTW_INFO("%s: pkt type=%d-%d, Nc=%d, Nr=%d, CH_W=%d, Ng=%d, CodeBook=%d\n",
__FUNCTION__, category, action, Nc, Nr, CH_W, Ng, CodeBook);
return ret;
}
u8 rtw_bf_send_vht_gid_mgnt_packet(PADAPTER adapter, u8 *ra, u8 *gid, u8 *position)
{
/* General */
struct xmit_priv *xmitpriv;
struct mlme_priv *mlmepriv;
struct xmit_frame *pmgntframe;
/* MISC */
struct pkt_attrib *attrib;
struct rtw_ieee80211_hdr *wlanhdr;
u8 *pframe, *ptr;
xmitpriv = &adapter->xmitpriv;
mlmepriv = &adapter->mlmepriv;
pmgntframe = alloc_mgtxmitframe(xmitpriv);
if (!pmgntframe)
return _FALSE;
/* update attribute */
attrib = &pmgntframe->attrib;
update_mgntframe_attrib(adapter, attrib);
attrib->rate = MGN_6M;
attrib->bwmode = CHANNEL_WIDTH_20;
attrib->subtype = WIFI_ACTION;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)pmgntframe->buf_addr + TXDESC_OFFSET;
wlanhdr = (struct rtw_ieee80211_hdr *)pframe;
wlanhdr->frame_ctl = 0;
set_frame_sub_type(pframe, attrib->subtype);
set_duration(pframe, 0);
SetFragNum(pframe, 0);
SetSeqNum(pframe, 0);
_rtw_memcpy(wlanhdr->addr1, ra, ETH_ALEN);
_rtw_memcpy(wlanhdr->addr2, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memcpy(wlanhdr->addr3, get_bssid(mlmepriv), ETH_ALEN);
pframe[24] = RTW_WLAN_CATEGORY_VHT;
pframe[25] = RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT;
/* Set Membership Status Array */
ptr = pframe + 26;
_rtw_memcpy(ptr, gid, 8);
/* Set User Position Array */
ptr = pframe + 34;
_rtw_memcpy(ptr, position, 16);
attrib->pktlen = 54;
attrib->last_txcmdsz = attrib->pktlen;
dump_mgntframe(adapter, pmgntframe);
return _TRUE;
}
/*
* Description:
* On VHT GID management frame by an MU beamformee.
*/
void rtw_bf_get_vht_gid_mgnt_packet(PADAPTER adapter, union recv_frame *precv_frame)
{
u8 *pframe;
u8 *ta, *gid, *position;
RTW_DBG("+%s\n", __FUNCTION__);
pframe = precv_frame->u.hdr.rx_data;
/* Get address by Addr2 */
ta = get_addr2_ptr(pframe);
/* Remove signaling TA */
ta[0] &= 0xFE;
/* Membership Status Array */
gid = pframe + 26;
/* User Position Array */
position= pframe + 34;
_bfer_set_entry_gid(adapter, ta, gid, position);
}
void rtw_bf_init(PADAPTER adapter)
{
struct beamforming_info *info;
info = GET_BEAMFORM_INFO(adapter);
info->beamforming_cap = BEAMFORMING_CAP_NONE;
info->beamforming_state = BEAMFORMING_STATE_IDLE;
/*
info->bfee_entry[MAX_BEAMFORMEE_ENTRY_NUM];
info->bfer_entry[MAX_BEAMFORMER_ENTRY_NUM];
*/
info->sounding_sequence = 0;
info->beamformee_su_cnt = 0;
info->beamformer_su_cnt = 0;
info->beamformee_su_reg_maping = 0;
info->beamformer_su_reg_maping = 0;
info->beamformee_mu_cnt = 0;
info->beamformer_mu_cnt = 0;
info->beamformee_mu_reg_maping = 0;
info->first_mu_bfee_index = 0xFF;
info->mu_bfer_curidx = 0xFF;
info->cur_csi_rpt_rate = HALMAC_OFDM24;
_sounding_init(&info->sounding_info);
rtw_init_timer(&info->sounding_timer, adapter, _sounding_timer_handler, adapter);
rtw_init_timer(&info->sounding_timeout_timer, adapter, _sounding_timeout_timer_handler, adapter);
info->SetHalBFEnterOnDemandCnt = 0;
info->SetHalBFLeaveOnDemandCnt = 0;
info->SetHalSoundownOnDemandCnt = 0;
info->bEnableSUTxBFWorkAround = _TRUE;
info->TargetSUBFee = NULL;
info->sounding_running = 0;
}
void rtw_bf_cmd_hdl(PADAPTER adapter, u8 type, u8 *pbuf)
{
switch (type) {
case BEAMFORMING_CTRL_ENTER:
_beamforming_enter(adapter, pbuf);
break;
case BEAMFORMING_CTRL_LEAVE:
if (pbuf == NULL)
_beamforming_reset(adapter);
else
_beamforming_leave(adapter, pbuf);
break;
case BEAMFORMING_CTRL_START_PERIOD:
_sounding_handler(adapter);
break;
case BEAMFORMING_CTRL_END_PERIOD:
_beamforming_sounding_down(adapter, *pbuf);
break;
case BEAMFORMING_CTRL_SET_GID_TABLE:
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_SET_GID_TABLE, pbuf);
break;
case BEAMFORMING_CTRL_SET_CSI_REPORT:
rtw_hal_set_hwreg(adapter, HW_VAR_SOUNDING_CSI_REPORT, pbuf);
break;
default:
break;
}
}
u8 rtw_bf_cmd(PADAPTER adapter, s32 type, u8 *pbuf, s32 size, u8 enqueue)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 *wk_buf;
u8 res = _SUCCESS;
if (!enqueue) {
rtw_bf_cmd_hdl(adapter, type, pbuf);
goto exit;
}
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
if (pbuf != NULL) {
wk_buf = rtw_zmalloc(size);
if (wk_buf == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
_rtw_memcpy(wk_buf, pbuf, size);
} else {
wk_buf = NULL;
size = 0;
}
pdrvextra_cmd_parm->ec_id = BEAMFORMING_WK_CID;
pdrvextra_cmd_parm->type = type;
pdrvextra_cmd_parm->size = size;
pdrvextra_cmd_parm->pbuf = wk_buf;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void rtw_bf_update_attrib(PADAPTER adapter, struct pkt_attrib *attrib, struct sta_info *sta)
{
if (sta) {
attrib->txbf_g_id = sta->cmn.bf_info.g_id;
attrib->txbf_p_aid = sta->cmn.bf_info.p_aid;
}
}
void rtw_bf_c2h_handler(PADAPTER adapter, u8 id, u8 *buf, u8 buf_len)
{
switch (id) {
case CMD_ID_C2H_SND_TXBF:
_c2h_snd_txbf(adapter, buf, buf_len);
break;
}
}
#define toMbps(bytes, secs) (rtw_division64(bytes >> 17, secs))
void rtw_bf_update_traffic(PADAPTER adapter)
{
struct beamforming_info *info;
struct sounding_info *sounding;
struct beamformee_entry *bfee;
struct sta_info *sta;
u8 bfee_cnt, sounding_idx, i;
u16 tp[MAX_BEAMFORMEE_ENTRY_NUM] = {0};
u8 tx_rate[MAX_BEAMFORMEE_ENTRY_NUM] = {0};
u64 tx_bytes, last_bytes;
u32 time;
systime last_timestamp;
u8 set_timer = _FALSE;
info = GET_BEAMFORM_INFO(adapter);
sounding = &info->sounding_info;
/* Check any bfee exist? */
bfee_cnt = info->beamformee_su_cnt + info->beamformee_mu_cnt;
if (bfee_cnt == 0)
return;
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (_FALSE == bfee->used)
continue;
sta = rtw_get_stainfo(&adapter->stapriv, bfee->mac_addr);
if (!sta) {
RTW_ERR("%s: Cann't find sta_info for " MAC_FMT "!\n", __FUNCTION__, MAC_ARG(bfee->mac_addr));
continue;
}
last_timestamp = bfee->tx_timestamp;
last_bytes = bfee->tx_bytes;
bfee->tx_timestamp = rtw_get_current_time();
bfee->tx_bytes = sta->sta_stats.tx_bytes;
if (last_timestamp) {
if (bfee->tx_bytes >= last_bytes)
tx_bytes = bfee->tx_bytes - last_bytes;
else
tx_bytes = bfee->tx_bytes + (~last_bytes);
time = rtw_get_time_interval_ms(last_timestamp, bfee->tx_timestamp);
time = (time > 1000) ? time/1000 : 1;
tp[i] = toMbps(tx_bytes, time);
tx_rate[i] = rtw_get_current_tx_rate(adapter, sta);
RTW_INFO("%s: BFee idx(%d), MadId(%d), TxTP=%lld bytes (%d Mbps), txrate=%d\n",
__FUNCTION__, i, bfee->mac_id, tx_bytes, tp[i], tx_rate[i]);
}
}
sounding_idx = phydm_get_beamforming_sounding_info(GET_PDM_ODM(adapter), tp, MAX_BEAMFORMEE_ENTRY_NUM, tx_rate);
for (i = 0; i < MAX_BEAMFORMEE_ENTRY_NUM; i++) {
bfee = &info->bfee_entry[i];
if (_FALSE == bfee->used) {
if (sounding_idx & BIT(i))
RTW_WARN("%s: bfee(%d) not in used but need sounding?!\n", __FUNCTION__, i);
continue;
}
if (sounding_idx & BIT(i)) {
if (_FALSE == bfee->bApplySounding) {
bfee->bApplySounding = _TRUE;
bfee->SoundCnt = 0;
set_timer = _TRUE;
}
} else {
if (_TRUE == bfee->bApplySounding) {
bfee->bApplySounding = _FALSE;
bfee->bDeleteSounding = _TRUE;
bfee->SoundCnt = 0;
set_timer = _TRUE;
}
}
}
if (_TRUE == set_timer) {
if (SOUNDING_STATE_NONE == info->sounding_info.state) {
info->sounding_info.state = SOUNDING_STATE_INIT;
_set_timer(&info->sounding_timer, 0);
}
}
}
#else /* !RTW_BEAMFORMING_VERSION_2 */
/*PHYDM_BF - (BEAMFORMING_SUPPORT == 1)*/
u32 rtw_beamforming_get_report_frame(PADAPTER Adapter, union recv_frame *precv_frame)
{
u32 ret = _SUCCESS;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
ret = beamforming_get_report_frame(pDM_Odm, precv_frame);
return ret;
}
void rtw_beamforming_get_ndpa_frame(PADAPTER Adapter, union recv_frame *precv_frame)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
beamforming_get_ndpa_frame(pDM_Odm, precv_frame);
}
void beamforming_wk_hdl(_adapter *padapter, u8 type, u8 *pbuf)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
/*(BEAMFORMING_SUPPORT == 1)- for PHYDM beamfoming*/
switch (type) {
case BEAMFORMING_CTRL_ENTER: {
struct sta_info *psta = (void *)pbuf;
u16 staIdx = psta->cmn.mac_id;
beamforming_enter(pDM_Odm, staIdx, adapter_mac_addr(psta->padapter));
break;
}
case BEAMFORMING_CTRL_LEAVE:
beamforming_leave(pDM_Odm, pbuf);
break;
default:
break;
}
}
u8 beamforming_wk_cmd(_adapter *padapter, s32 type, u8 *pbuf, s32 size, u8 enqueue)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 res = _SUCCESS;
/*20170214 ad_hoc mode and mp_mode not support BF*/
if ((padapter->registrypriv.mp_mode == 1)
|| (pmlmeinfo->state == WIFI_FW_ADHOC_STATE))
return res;
if (enqueue) {
u8 *wk_buf;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
if (pbuf != NULL) {
wk_buf = rtw_zmalloc(size);
if (wk_buf == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
_rtw_memcpy(wk_buf, pbuf, size);
} else {
wk_buf = NULL;
size = 0;
}
pdrvextra_cmd_parm->ec_id = BEAMFORMING_WK_CID;
pdrvextra_cmd_parm->type = type;
pdrvextra_cmd_parm->size = size;
pdrvextra_cmd_parm->pbuf = wk_buf;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
} else
beamforming_wk_hdl(padapter, type, pbuf);
exit:
return res;
}
void update_attrib_txbf_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)
{
if (psta) {
pattrib->txbf_g_id = psta->cmn.bf_info.g_id;
pattrib->txbf_p_aid = psta->cmn.bf_info.p_aid;
}
}
#endif /* !RTW_BEAMFORMING_VERSION_2 */
#endif /* CONFIG_BEAMFORMING */
================================================
FILE: core/rtw_br_ext.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_BR_EXT_C_
#ifdef __KERNEL__
#include
#include
#include
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 15, 0))
#include
#include
#endif
#include
#include
#endif
#if 1 /* rtw_wifi_driver */
#include
#else /* rtw_wifi_driver */
#include "./8192cd_cfg.h"
#ifndef __KERNEL__
#include "./sys-support.h"
#endif
#include "./8192cd.h"
#include "./8192cd_headers.h"
#include "./8192cd_br_ext.h"
#include "./8192cd_debug.h"
#endif /* rtw_wifi_driver */
#ifdef CL_IPV6_PASS
#ifdef __KERNEL__
#include
#include
#include
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
#include
#else
#include
#endif
#endif
#endif
#ifdef CONFIG_BR_EXT
/* #define BR_EXT_DEBUG */
#define NAT25_IPV4 01
#define NAT25_IPV6 02
#define NAT25_IPX 03
#define NAT25_APPLE 04
#define NAT25_PPPOE 05
#define RTL_RELAY_TAG_LEN (ETH_ALEN)
#define TAG_HDR_LEN 4
#define MAGIC_CODE 0x8186
#define MAGIC_CODE_LEN 2
#define WAIT_TIME_PPPOE 5 /* waiting time for pppoe server in sec */
/*-----------------------------------------------------------------
How database records network address:
0 1 2 3 4 5 6 7 8 9 10
|----|----|----|----|----|----|----|----|----|----|----|
IPv4 |type| | IP addr |
IPX |type| Net addr | Node addr |
IPX |type| Net addr |Sckt addr|
Apple |type| Network |node|
PPPoE |type| SID | AC MAC |
-----------------------------------------------------------------*/
/* Find a tag in pppoe frame and return the pointer */
static __inline__ unsigned char *__nat25_find_pppoe_tag(struct pppoe_hdr *ph, unsigned short type)
{
unsigned char *cur_ptr, *start_ptr;
unsigned short tagLen, tagType;
start_ptr = cur_ptr = (unsigned char *)ph->tag;
while ((cur_ptr - start_ptr) < ntohs(ph->length)) {
/* prevent un-alignment access */
tagType = (unsigned short)((cur_ptr[0] << 8) + cur_ptr[1]);
tagLen = (unsigned short)((cur_ptr[2] << 8) + cur_ptr[3]);
if (tagType == type)
return cur_ptr;
cur_ptr = cur_ptr + TAG_HDR_LEN + tagLen;
}
return 0;
}
static __inline__ int __nat25_add_pppoe_tag(struct sk_buff *skb, struct pppoe_tag *tag)
{
struct pppoe_hdr *ph = (struct pppoe_hdr *)(skb->data + ETH_HLEN);
int data_len;
data_len = tag->tag_len + TAG_HDR_LEN;
if (skb_tailroom(skb) < data_len) {
_DEBUG_ERR("skb_tailroom() failed in add SID tag!\n");
return -1;
}
skb_put(skb, data_len);
/* have a room for new tag */
memmove(((unsigned char *)ph->tag + data_len), (unsigned char *)ph->tag, ntohs(ph->length));
ph->length = htons(ntohs(ph->length) + data_len);
memcpy((unsigned char *)ph->tag, tag, data_len);
return data_len;
}
static int skb_pull_and_merge(struct sk_buff *skb, unsigned char *src, int len)
{
int tail_len;
unsigned long end, tail;
if ((src + len) > skb_tail_pointer(skb) || skb->len < len)
return -1;
tail = (unsigned long)skb_tail_pointer(skb);
end = (unsigned long)src + len;
if (tail < end)
return -1;
tail_len = (int)(tail - end);
if (tail_len > 0)
memmove(src, src + len, tail_len);
skb_trim(skb, skb->len - len);
return 0;
}
static __inline__ unsigned long __nat25_timeout(_adapter *priv)
{
unsigned long timeout;
timeout = jiffies - NAT25_AGEING_TIME * HZ;
return timeout;
}
static __inline__ int __nat25_has_expired(_adapter *priv,
struct nat25_network_db_entry *fdb)
{
if (time_before_eq(fdb->ageing_timer, __nat25_timeout(priv)))
return 1;
return 0;
}
static __inline__ void __nat25_generate_ipv4_network_addr(unsigned char *networkAddr,
unsigned int *ipAddr)
{
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
networkAddr[0] = NAT25_IPV4;
memcpy(networkAddr + 7, (unsigned char *)ipAddr, 4);
}
#ifdef _NET_INET_IPX_H_
static __inline__ void __nat25_generate_ipx_network_addr_with_node(unsigned char *networkAddr,
unsigned int *ipxNetAddr, unsigned char *ipxNodeAddr)
{
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
networkAddr[0] = NAT25_IPX;
memcpy(networkAddr + 1, (unsigned char *)ipxNetAddr, 4);
memcpy(networkAddr + 5, ipxNodeAddr, 6);
}
static __inline__ void __nat25_generate_ipx_network_addr_with_socket(unsigned char *networkAddr,
unsigned int *ipxNetAddr, unsigned short *ipxSocketAddr)
{
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
networkAddr[0] = NAT25_IPX;
memcpy(networkAddr + 1, (unsigned char *)ipxNetAddr, 4);
memcpy(networkAddr + 5, (unsigned char *)ipxSocketAddr, 2);
}
static __inline__ void __nat25_generate_apple_network_addr(unsigned char *networkAddr,
unsigned short *network, unsigned char *node)
{
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
networkAddr[0] = NAT25_APPLE;
memcpy(networkAddr + 1, (unsigned char *)network, 2);
networkAddr[3] = *node;
}
#endif
static __inline__ void __nat25_generate_pppoe_network_addr(unsigned char *networkAddr,
unsigned char *ac_mac, unsigned short *sid)
{
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
networkAddr[0] = NAT25_PPPOE;
memcpy(networkAddr + 1, (unsigned char *)sid, 2);
memcpy(networkAddr + 3, (unsigned char *)ac_mac, 6);
}
#ifdef CL_IPV6_PASS
static void __nat25_generate_ipv6_network_addr(unsigned char *networkAddr,
unsigned int *ipAddr)
{
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
networkAddr[0] = NAT25_IPV6;
memcpy(networkAddr + 1, (unsigned char *)ipAddr, 16);
}
static unsigned char *scan_tlv(unsigned char *data, int len, unsigned char tag, unsigned char len8b)
{
while (len > 0) {
if (*data == tag && *(data + 1) == len8b && len >= len8b * 8)
return data + 2;
len -= (*(data + 1)) * 8;
data += (*(data + 1)) * 8;
}
return NULL;
}
static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char *replace_mac)
{
struct icmp6hdr *icmphdr = (struct icmp6hdr *)data;
unsigned char *mac;
if (icmphdr->icmp6_type == NDISC_ROUTER_SOLICITATION) {
if (len >= 8) {
mac = scan_tlv(&data[8], len - 8, 1, 1);
if (mac) {
RTW_INFO("Router Solicitation, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
memcpy(mac, replace_mac, 6);
return 1;
}
}
} else if (icmphdr->icmp6_type == NDISC_ROUTER_ADVERTISEMENT) {
if (len >= 16) {
mac = scan_tlv(&data[16], len - 16, 1, 1);
if (mac) {
RTW_INFO("Router Advertisement, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
memcpy(mac, replace_mac, 6);
return 1;
}
}
} else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_SOLICITATION) {
if (len >= 24) {
mac = scan_tlv(&data[24], len - 24, 1, 1);
if (mac) {
RTW_INFO("Neighbor Solicitation, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
memcpy(mac, replace_mac, 6);
return 1;
}
}
} else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_ADVERTISEMENT) {
if (len >= 24) {
mac = scan_tlv(&data[24], len - 24, 2, 1);
if (mac) {
RTW_INFO("Neighbor Advertisement, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
memcpy(mac, replace_mac, 6);
return 1;
}
}
} else if (icmphdr->icmp6_type == NDISC_REDIRECT) {
if (len >= 40) {
mac = scan_tlv(&data[40], len - 40, 2, 1);
if (mac) {
RTW_INFO("Redirect, replace MAC From: %02x:%02x:%02x:%02x:%02x:%02x, To: %02x:%02x:%02x:%02x:%02x:%02x\n",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5],
replace_mac[0], replace_mac[1], replace_mac[2], replace_mac[3], replace_mac[4], replace_mac[5]);
memcpy(mac, replace_mac, 6);
return 1;
}
}
}
return 0;
}
#ifdef SUPPORT_RX_UNI2MCAST
static void convert_ipv6_mac_to_mc(struct sk_buff *skb)
{
struct ipv6hdr *iph = (struct ipv6hdr *)(skb->data + ETH_HLEN);
unsigned char *dst_mac = skb->data;
/* dst_mac[0] = 0xff; */
/* dst_mac[1] = 0xff; */
/*modified by qinjunjie,ipv6 multicast address ix 0x33-33-xx-xx-xx-xx*/
dst_mac[0] = 0x33;
dst_mac[1] = 0x33;
memcpy(&dst_mac[2], &iph->daddr.s6_addr32[3], 4);
#if defined(__LINUX_2_6__)
/*modified by qinjunjie,warning:should not remove next line*/
skb->pkt_type = PACKET_MULTICAST;
#endif
}
#endif /* CL_IPV6_PASS */
#endif /* SUPPORT_RX_UNI2MCAST */
static __inline__ int __nat25_network_hash(unsigned char *networkAddr)
{
if (networkAddr[0] == NAT25_IPV4) {
unsigned long x;
x = networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10];
#ifdef _NET_INET_IPX_H_
return x & (NAT25_HASH_SIZE - 1);
} else if (networkAddr[0] == NAT25_IPX) {
unsigned long x;
x = networkAddr[1] ^ networkAddr[2] ^ networkAddr[3] ^ networkAddr[4] ^ networkAddr[5] ^
networkAddr[6] ^ networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10];
return x & (NAT25_HASH_SIZE - 1);
} else if (networkAddr[0] == NAT25_APPLE) {
unsigned long x;
x = networkAddr[1] ^ networkAddr[2] ^ networkAddr[3];
return x & (NAT25_HASH_SIZE - 1);
} else if (networkAddr[0] == NAT25_PPPOE) {
unsigned long x;
x = networkAddr[0] ^ networkAddr[1] ^ networkAddr[2] ^ networkAddr[3] ^ networkAddr[4] ^ networkAddr[5] ^ networkAddr[6] ^ networkAddr[7] ^ networkAddr[8];
#endif
return x & (NAT25_HASH_SIZE - 1);
}
#ifdef CL_IPV6_PASS
else if (networkAddr[0] == NAT25_IPV6) {
unsigned long x;
x = networkAddr[1] ^ networkAddr[2] ^ networkAddr[3] ^ networkAddr[4] ^ networkAddr[5] ^
networkAddr[6] ^ networkAddr[7] ^ networkAddr[8] ^ networkAddr[9] ^ networkAddr[10] ^
networkAddr[11] ^ networkAddr[12] ^ networkAddr[13] ^ networkAddr[14] ^ networkAddr[15] ^
networkAddr[16];
return x & (NAT25_HASH_SIZE - 1);
}
#endif
else {
unsigned long x = 0;
int i;
for (i = 0; i < MAX_NETWORK_ADDR_LEN; i++)
x ^= networkAddr[i];
return x & (NAT25_HASH_SIZE - 1);
}
}
static __inline__ void __network_hash_link(_adapter *priv,
struct nat25_network_db_entry *ent, int hash)
{
/* Caller must _enter_critical_bh already! */
/* _irqL irqL; */
/* _enter_critical_bh(&priv->br_ext_lock, &irqL); */
ent->next_hash = priv->nethash[hash];
if (ent->next_hash != NULL)
ent->next_hash->pprev_hash = &ent->next_hash;
priv->nethash[hash] = ent;
ent->pprev_hash = &priv->nethash[hash];
/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
}
static __inline__ void __network_hash_unlink(struct nat25_network_db_entry *ent)
{
/* Caller must _enter_critical_bh already! */
/* _irqL irqL; */
/* _enter_critical_bh(&priv->br_ext_lock, &irqL); */
*(ent->pprev_hash) = ent->next_hash;
if (ent->next_hash != NULL)
ent->next_hash->pprev_hash = ent->pprev_hash;
ent->next_hash = NULL;
ent->pprev_hash = NULL;
/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
}
static int __nat25_db_network_lookup_and_replace(_adapter *priv,
struct sk_buff *skb, unsigned char *networkAddr)
{
struct nat25_network_db_entry *db;
_irqL irqL;
_enter_critical_bh(&priv->br_ext_lock, &irqL);
db = priv->nethash[__nat25_network_hash(networkAddr)];
while (db != NULL) {
if (!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
if (!__nat25_has_expired(priv, db)) {
/* replace the destination mac address */
memcpy(skb->data, db->macAddr, ETH_ALEN);
atomic_inc(&db->use_count);
#ifdef CL_IPV6_PASS
RTW_INFO("NAT25: Lookup M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
"%02x%02x%02x%02x%02x%02x\n",
db->macAddr[0],
db->macAddr[1],
db->macAddr[2],
db->macAddr[3],
db->macAddr[4],
db->macAddr[5],
db->networkAddr[0],
db->networkAddr[1],
db->networkAddr[2],
db->networkAddr[3],
db->networkAddr[4],
db->networkAddr[5],
db->networkAddr[6],
db->networkAddr[7],
db->networkAddr[8],
db->networkAddr[9],
db->networkAddr[10],
db->networkAddr[11],
db->networkAddr[12],
db->networkAddr[13],
db->networkAddr[14],
db->networkAddr[15],
db->networkAddr[16]);
#else
RTW_INFO("NAT25: Lookup M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
db->macAddr[0],
db->macAddr[1],
db->macAddr[2],
db->macAddr[3],
db->macAddr[4],
db->macAddr[5],
db->networkAddr[0],
db->networkAddr[1],
db->networkAddr[2],
db->networkAddr[3],
db->networkAddr[4],
db->networkAddr[5],
db->networkAddr[6],
db->networkAddr[7],
db->networkAddr[8],
db->networkAddr[9],
db->networkAddr[10]);
#endif
}
_exit_critical_bh(&priv->br_ext_lock, &irqL);
return 1;
}
db = db->next_hash;
}
_exit_critical_bh(&priv->br_ext_lock, &irqL);
return 0;
}
static void __nat25_db_network_insert(_adapter *priv,
unsigned char *macAddr, unsigned char *networkAddr)
{
struct nat25_network_db_entry *db;
int hash;
_irqL irqL;
_enter_critical_bh(&priv->br_ext_lock, &irqL);
hash = __nat25_network_hash(networkAddr);
db = priv->nethash[hash];
while (db != NULL) {
if (!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
memcpy(db->macAddr, macAddr, ETH_ALEN);
db->ageing_timer = jiffies;
_exit_critical_bh(&priv->br_ext_lock, &irqL);
return;
}
db = db->next_hash;
}
db = (struct nat25_network_db_entry *) rtw_malloc(sizeof(*db));
if (db == NULL) {
_exit_critical_bh(&priv->br_ext_lock, &irqL);
return;
}
memcpy(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN);
memcpy(db->macAddr, macAddr, ETH_ALEN);
atomic_set(&db->use_count, 1);
db->ageing_timer = jiffies;
__network_hash_link(priv, db, hash);
_exit_critical_bh(&priv->br_ext_lock, &irqL);
}
static void __nat25_db_print(_adapter *priv)
{
_irqL irqL;
_enter_critical_bh(&priv->br_ext_lock, &irqL);
#ifdef BR_EXT_DEBUG
static int counter = 0;
int i, j;
struct nat25_network_db_entry *db;
counter++;
if ((counter % 16) != 0)
return;
for (i = 0, j = 0; i < NAT25_HASH_SIZE; i++) {
db = priv->nethash[i];
while (db != NULL) {
#ifdef CL_IPV6_PASS
panic_printk("NAT25: DB(%d) H(%02d) C(%d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
"%02x%02x%02x%02x%02x%02x\n",
j,
i,
atomic_read(&db->use_count),
db->macAddr[0],
db->macAddr[1],
db->macAddr[2],
db->macAddr[3],
db->macAddr[4],
db->macAddr[5],
db->networkAddr[0],
db->networkAddr[1],
db->networkAddr[2],
db->networkAddr[3],
db->networkAddr[4],
db->networkAddr[5],
db->networkAddr[6],
db->networkAddr[7],
db->networkAddr[8],
db->networkAddr[9],
db->networkAddr[10],
db->networkAddr[11],
db->networkAddr[12],
db->networkAddr[13],
db->networkAddr[14],
db->networkAddr[15],
db->networkAddr[16]);
#else
panic_printk("NAT25: DB(%d) H(%02d) C(%d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
j,
i,
atomic_read(&db->use_count),
db->macAddr[0],
db->macAddr[1],
db->macAddr[2],
db->macAddr[3],
db->macAddr[4],
db->macAddr[5],
db->networkAddr[0],
db->networkAddr[1],
db->networkAddr[2],
db->networkAddr[3],
db->networkAddr[4],
db->networkAddr[5],
db->networkAddr[6],
db->networkAddr[7],
db->networkAddr[8],
db->networkAddr[9],
db->networkAddr[10]);
#endif
j++;
db = db->next_hash;
}
}
#endif
_exit_critical_bh(&priv->br_ext_lock, &irqL);
}
/*
* NAT2.5 interface
*/
void nat25_db_cleanup(_adapter *priv)
{
int i;
_irqL irqL;
_enter_critical_bh(&priv->br_ext_lock, &irqL);
for (i = 0; i < NAT25_HASH_SIZE; i++) {
struct nat25_network_db_entry *f;
f = priv->nethash[i];
while (f != NULL) {
struct nat25_network_db_entry *g;
g = f->next_hash;
if (priv->scdb_entry == f) {
memset(priv->scdb_mac, 0, ETH_ALEN);
memset(priv->scdb_ip, 0, 4);
priv->scdb_entry = NULL;
}
__network_hash_unlink(f);
rtw_mfree((u8 *) f, sizeof(struct nat25_network_db_entry));
f = g;
}
}
_exit_critical_bh(&priv->br_ext_lock, &irqL);
}
void nat25_db_expire(_adapter *priv)
{
int i;
_irqL irqL;
_enter_critical_bh(&priv->br_ext_lock, &irqL);
/* if(!priv->ethBrExtInfo.nat25_disable) */
{
for (i = 0; i < NAT25_HASH_SIZE; i++) {
struct nat25_network_db_entry *f;
f = priv->nethash[i];
while (f != NULL) {
struct nat25_network_db_entry *g;
g = f->next_hash;
if (__nat25_has_expired(priv, f)) {
if (atomic_dec_and_test(&f->use_count)) {
#ifdef BR_EXT_DEBUG
#ifdef CL_IPV6_PASS
panic_printk("NAT25 Expire H(%02d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x"
"%02x%02x%02x%02x%02x%02x\n",
i,
f->macAddr[0],
f->macAddr[1],
f->macAddr[2],
f->macAddr[3],
f->macAddr[4],
f->macAddr[5],
f->networkAddr[0],
f->networkAddr[1],
f->networkAddr[2],
f->networkAddr[3],
f->networkAddr[4],
f->networkAddr[5],
f->networkAddr[6],
f->networkAddr[7],
f->networkAddr[8],
f->networkAddr[9],
f->networkAddr[10],
f->networkAddr[11],
f->networkAddr[12],
f->networkAddr[13],
f->networkAddr[14],
f->networkAddr[15],
f->networkAddr[16]);
#else
panic_printk("NAT25 Expire H(%02d) M:%02x%02x%02x%02x%02x%02x N:%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
i,
f->macAddr[0],
f->macAddr[1],
f->macAddr[2],
f->macAddr[3],
f->macAddr[4],
f->macAddr[5],
f->networkAddr[0],
f->networkAddr[1],
f->networkAddr[2],
f->networkAddr[3],
f->networkAddr[4],
f->networkAddr[5],
f->networkAddr[6],
f->networkAddr[7],
f->networkAddr[8],
f->networkAddr[9],
f->networkAddr[10]);
#endif
#endif
if (priv->scdb_entry == f) {
memset(priv->scdb_mac, 0, ETH_ALEN);
memset(priv->scdb_ip, 0, 4);
priv->scdb_entry = NULL;
}
__network_hash_unlink(f);
rtw_mfree((u8 *) f, sizeof(struct nat25_network_db_entry));
}
}
f = g;
}
}
}
_exit_critical_bh(&priv->br_ext_lock, &irqL);
}
#ifdef SUPPORT_TX_MCAST2UNI
static int checkIPMcAndReplace(_adapter *priv, struct sk_buff *skb, unsigned int *dst_ip)
{
struct stat_info *pstat;
struct list_head *phead, *plist;
int i;
phead = &priv->asoc_list;
plist = phead->next;
while (plist != phead) {
pstat = list_entry(plist, struct stat_info, asoc_list);
plist = plist->next;
if (pstat->ipmc_num == 0)
continue;
for (i = 0; i < MAX_IP_MC_ENTRY; i++) {
if (pstat->ipmc[i].used && !memcmp(&pstat->ipmc[i].mcmac[3], ((unsigned char *)dst_ip) + 1, 3)) {
memcpy(skb->data, pstat->ipmc[i].mcmac, ETH_ALEN);
return 1;
}
}
}
return 0;
}
#endif
int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method)
{
unsigned short protocol;
unsigned char networkAddr[MAX_NETWORK_ADDR_LEN];
if (skb == NULL)
return -1;
if ((method <= NAT25_MIN) || (method >= NAT25_MAX))
return -1;
protocol = *((unsigned short *)(skb->data + 2 * ETH_ALEN));
/*---------------------------------------------------*/
/* Handle IP frame */
/*---------------------------------------------------*/
if (protocol == __constant_htons(ETH_P_IP)) {
struct iphdr *iph = (struct iphdr *)(skb->data + ETH_HLEN);
if (((unsigned char *)(iph) + (iph->ihl << 2)) >= (skb->data + ETH_HLEN + skb->len)) {
DEBUG_WARN("NAT25: malformed IP packet !\n");
return -1;
}
switch (method) {
case NAT25_CHECK:
return -1;
case NAT25_INSERT: {
/* some muticast with source IP is all zero, maybe other case is illegal */
/* in class A, B, C, host address is all zero or all one is illegal */
if (iph->saddr == 0)
return 0;
RTW_INFO("NAT25: Insert IP, SA=%08x, DA=%08x\n", iph->saddr, iph->daddr);
__nat25_generate_ipv4_network_addr(networkAddr, &iph->saddr);
/* record source IP address and , source mac address into db */
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
}
return 0;
case NAT25_LOOKUP: {
RTW_INFO("NAT25: Lookup IP, SA=%08x, DA=%08x\n", iph->saddr, iph->daddr);
#ifdef SUPPORT_TX_MCAST2UNI
if (priv->pshare->rf_ft_var.mc2u_disable ||
((((OPMODE & (WIFI_STATION_STATE | WIFI_ASOC_STATE))
== (WIFI_STATION_STATE | WIFI_ASOC_STATE)) &&
!checkIPMcAndReplace(priv, skb, &iph->daddr)) ||
(OPMODE & WIFI_ADHOC_STATE)))
#endif
{
__nat25_generate_ipv4_network_addr(networkAddr, &iph->daddr);
if (!__nat25_db_network_lookup_and_replace(priv, skb, networkAddr)) {
if (*((unsigned char *)&iph->daddr + 3) == 0xff) {
/* L2 is unicast but L3 is broadcast, make L2 bacome broadcast */
RTW_INFO("NAT25: Set DA as boardcast\n");
memset(skb->data, 0xff, ETH_ALEN);
} else {
/* forward unknow IP packet to upper TCP/IP */
RTW_INFO("NAT25: Replace DA with BR's MAC\n");
if ((*(u32 *)priv->br_mac) == 0 && (*(u16 *)(priv->br_mac + 4)) == 0) {
void netdev_br_init(struct net_device *netdev);
printk("Re-init netdev_br_init() due to br_mac==0!\n");
netdev_br_init(priv->pnetdev);
}
memcpy(skb->data, priv->br_mac, ETH_ALEN);
}
}
}
}
return 0;
default:
return -1;
}
}
/*---------------------------------------------------*/
/* Handle ARP frame */
/*---------------------------------------------------*/
else if (protocol == __constant_htons(ETH_P_ARP)) {
struct arphdr *arp = (struct arphdr *)(skb->data + ETH_HLEN);
unsigned char *arp_ptr = (unsigned char *)(arp + 1);
unsigned int *sender, *target;
if (arp->ar_pro != __constant_htons(ETH_P_IP)) {
DEBUG_WARN("NAT25: arp protocol unknown (%4x)!\n", htons(arp->ar_pro));
return -1;
}
switch (method) {
case NAT25_CHECK:
return 0; /* skb_copy for all ARP frame */
case NAT25_INSERT: {
RTW_INFO("NAT25: Insert ARP, MAC=%02x%02x%02x%02x%02x%02x\n", arp_ptr[0],
arp_ptr[1], arp_ptr[2], arp_ptr[3], arp_ptr[4], arp_ptr[5]);
/* change to ARP sender mac address to wlan STA address */
memcpy(arp_ptr, GET_MY_HWADDR(priv), ETH_ALEN);
arp_ptr += arp->ar_hln;
sender = (unsigned int *)arp_ptr;
__nat25_generate_ipv4_network_addr(networkAddr, sender);
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
}
return 0;
case NAT25_LOOKUP: {
RTW_INFO("NAT25: Lookup ARP\n");
arp_ptr += arp->ar_hln;
sender = (unsigned int *)arp_ptr;
arp_ptr += (arp->ar_hln + arp->ar_pln);
target = (unsigned int *)arp_ptr;
__nat25_generate_ipv4_network_addr(networkAddr, target);
__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
/* change to ARP target mac address to Lookup result */
arp_ptr = (unsigned char *)(arp + 1);
arp_ptr += (arp->ar_hln + arp->ar_pln);
memcpy(arp_ptr, skb->data, ETH_ALEN);
}
return 0;
default:
return -1;
}
}
#ifdef _NET_INET_IPX_H_
/*---------------------------------------------------*/
/* Handle IPX and Apple Talk frame */
/*---------------------------------------------------*/
else if ((protocol == __constant_htons(ETH_P_IPX)) ||
(protocol == __constant_htons(ETH_P_ATALK)) ||
(protocol == __constant_htons(ETH_P_AARP))) {
unsigned char ipx_header[2] = {0xFF, 0xFF};
struct ipxhdr *ipx = NULL;
struct elapaarp *ea = NULL;
struct ddpehdr *ddp = NULL;
unsigned char *framePtr = skb->data + ETH_HLEN;
if (protocol == __constant_htons(ETH_P_IPX)) {
RTW_INFO("NAT25: Protocol=IPX (Ethernet II)\n");
ipx = (struct ipxhdr *)framePtr;
} else { /* if(protocol <= __constant_htons(ETH_FRAME_LEN)) */
if (!memcmp(ipx_header, framePtr, 2)) {
RTW_INFO("NAT25: Protocol=IPX (Ethernet 802.3)\n");
ipx = (struct ipxhdr *)framePtr;
} else {
unsigned char ipx_8022_type = 0xE0;
unsigned char snap_8022_type = 0xAA;
if (*framePtr == snap_8022_type) {
unsigned char ipx_snap_id[5] = {0x0, 0x0, 0x0, 0x81, 0x37}; /* IPX SNAP ID */
unsigned char aarp_snap_id[5] = {0x00, 0x00, 0x00, 0x80, 0xF3}; /* Apple Talk AARP SNAP ID */
unsigned char ddp_snap_id[5] = {0x08, 0x00, 0x07, 0x80, 0x9B}; /* Apple Talk DDP SNAP ID */
framePtr += 3; /* eliminate the 802.2 header */
if (!memcmp(ipx_snap_id, framePtr, 5)) {
framePtr += 5; /* eliminate the SNAP header */
RTW_INFO("NAT25: Protocol=IPX (Ethernet SNAP)\n");
ipx = (struct ipxhdr *)framePtr;
} else if (!memcmp(aarp_snap_id, framePtr, 5)) {
framePtr += 5; /* eliminate the SNAP header */
ea = (struct elapaarp *)framePtr;
} else if (!memcmp(ddp_snap_id, framePtr, 5)) {
framePtr += 5; /* eliminate the SNAP header */
ddp = (struct ddpehdr *)framePtr;
} else {
DEBUG_WARN("NAT25: Protocol=Ethernet SNAP %02x%02x%02x%02x%02x\n", framePtr[0],
framePtr[1], framePtr[2], framePtr[3], framePtr[4]);
return -1;
}
} else if (*framePtr == ipx_8022_type) {
framePtr += 3; /* eliminate the 802.2 header */
if (!memcmp(ipx_header, framePtr, 2)) {
RTW_INFO("NAT25: Protocol=IPX (Ethernet 802.2)\n");
ipx = (struct ipxhdr *)framePtr;
} else
return -1;
}
}
}
/* IPX */
if (ipx != NULL) {
switch (method) {
case NAT25_CHECK:
if (!memcmp(skb->data + ETH_ALEN, ipx->ipx_source.node, ETH_ALEN)) {
RTW_INFO("NAT25: Check IPX skb_copy\n");
return 0;
}
return -1;
case NAT25_INSERT: {
RTW_INFO("NAT25: Insert IPX, Dest=%08x,%02x%02x%02x%02x%02x%02x,%04x Source=%08x,%02x%02x%02x%02x%02x%02x,%04x\n",
ipx->ipx_dest.net,
ipx->ipx_dest.node[0],
ipx->ipx_dest.node[1],
ipx->ipx_dest.node[2],
ipx->ipx_dest.node[3],
ipx->ipx_dest.node[4],
ipx->ipx_dest.node[5],
ipx->ipx_dest.sock,
ipx->ipx_source.net,
ipx->ipx_source.node[0],
ipx->ipx_source.node[1],
ipx->ipx_source.node[2],
ipx->ipx_source.node[3],
ipx->ipx_source.node[4],
ipx->ipx_source.node[5],
ipx->ipx_source.sock);
if (!memcmp(skb->data + ETH_ALEN, ipx->ipx_source.node, ETH_ALEN)) {
RTW_INFO("NAT25: Use IPX Net, and Socket as network addr\n");
__nat25_generate_ipx_network_addr_with_socket(networkAddr, &ipx->ipx_source.net, &ipx->ipx_source.sock);
/* change IPX source node addr to wlan STA address */
memcpy(ipx->ipx_source.node, GET_MY_HWADDR(priv), ETH_ALEN);
} else
__nat25_generate_ipx_network_addr_with_node(networkAddr, &ipx->ipx_source.net, ipx->ipx_source.node);
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
}
return 0;
case NAT25_LOOKUP: {
if (!memcmp(GET_MY_HWADDR(priv), ipx->ipx_dest.node, ETH_ALEN)) {
RTW_INFO("NAT25: Lookup IPX, Modify Destination IPX Node addr\n");
__nat25_generate_ipx_network_addr_with_socket(networkAddr, &ipx->ipx_dest.net, &ipx->ipx_dest.sock);
__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
/* replace IPX destination node addr with Lookup destination MAC addr */
memcpy(ipx->ipx_dest.node, skb->data, ETH_ALEN);
} else {
__nat25_generate_ipx_network_addr_with_node(networkAddr, &ipx->ipx_dest.net, ipx->ipx_dest.node);
__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
}
}
return 0;
default:
return -1;
}
}
/* AARP */
else if (ea != NULL) {
/* Sanity check fields. */
if (ea->hw_len != ETH_ALEN || ea->pa_len != AARP_PA_ALEN) {
DEBUG_WARN("NAT25: Appletalk AARP Sanity check fail!\n");
return -1;
}
switch (method) {
case NAT25_CHECK:
return 0;
case NAT25_INSERT: {
/* change to AARP source mac address to wlan STA address */
memcpy(ea->hw_src, GET_MY_HWADDR(priv), ETH_ALEN);
RTW_INFO("NAT25: Insert AARP, Source=%d,%d Destination=%d,%d\n",
ea->pa_src_net,
ea->pa_src_node,
ea->pa_dst_net,
ea->pa_dst_node);
__nat25_generate_apple_network_addr(networkAddr, &ea->pa_src_net, &ea->pa_src_node);
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
}
return 0;
case NAT25_LOOKUP: {
RTW_INFO("NAT25: Lookup AARP, Source=%d,%d Destination=%d,%d\n",
ea->pa_src_net,
ea->pa_src_node,
ea->pa_dst_net,
ea->pa_dst_node);
__nat25_generate_apple_network_addr(networkAddr, &ea->pa_dst_net, &ea->pa_dst_node);
__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
/* change to AARP destination mac address to Lookup result */
memcpy(ea->hw_dst, skb->data, ETH_ALEN);
}
return 0;
default:
return -1;
}
}
/* DDP */
else if (ddp != NULL) {
switch (method) {
case NAT25_CHECK:
return -1;
case NAT25_INSERT: {
RTW_INFO("NAT25: Insert DDP, Source=%d,%d Destination=%d,%d\n",
ddp->deh_snet,
ddp->deh_snode,
ddp->deh_dnet,
ddp->deh_dnode);
__nat25_generate_apple_network_addr(networkAddr, &ddp->deh_snet, &ddp->deh_snode);
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
}
return 0;
case NAT25_LOOKUP: {
RTW_INFO("NAT25: Lookup DDP, Source=%d,%d Destination=%d,%d\n",
ddp->deh_snet,
ddp->deh_snode,
ddp->deh_dnet,
ddp->deh_dnode);
__nat25_generate_apple_network_addr(networkAddr, &ddp->deh_dnet, &ddp->deh_dnode);
__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
}
return 0;
default:
return -1;
}
}
return -1;
}
#endif
/*---------------------------------------------------*/
/* Handle PPPoE frame */
/*---------------------------------------------------*/
else if ((protocol == __constant_htons(ETH_P_PPP_DISC)) ||
(protocol == __constant_htons(ETH_P_PPP_SES))) {
struct pppoe_hdr *ph = (struct pppoe_hdr *)(skb->data + ETH_HLEN);
unsigned short *pMagic;
switch (method) {
case NAT25_CHECK:
if (ph->sid == 0)
return 0;
return 1;
case NAT25_INSERT:
if (ph->sid == 0) { /* Discovery phase according to tag */
if (ph->code == PADI_CODE || ph->code == PADR_CODE) {
if (priv->ethBrExtInfo.addPPPoETag) {
struct pppoe_tag *tag, *pOldTag;
unsigned char tag_buf[40];
int old_tag_len = 0;
tag = (struct pppoe_tag *)tag_buf;
pOldTag = (struct pppoe_tag *)__nat25_find_pppoe_tag(ph, ntohs(PTT_RELAY_SID));
if (pOldTag) { /* if SID existed, copy old value and delete it */
old_tag_len = ntohs(pOldTag->tag_len);
if (old_tag_len + TAG_HDR_LEN + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN > sizeof(tag_buf)) {
DEBUG_ERR("SID tag length too long!\n");
return -1;
}
memcpy(tag->tag_data + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN,
pOldTag->tag_data, old_tag_len);
if (skb_pull_and_merge(skb, (unsigned char *)pOldTag, TAG_HDR_LEN + old_tag_len) < 0) {
DEBUG_ERR("call skb_pull_and_merge() failed in PADI/R packet!\n");
return -1;
}
ph->length = htons(ntohs(ph->length) - TAG_HDR_LEN - old_tag_len);
}
tag->tag_type = PTT_RELAY_SID;
tag->tag_len = htons(MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN + old_tag_len);
/* insert the magic_code+client mac in relay tag */
pMagic = (unsigned short *)tag->tag_data;
*pMagic = htons(MAGIC_CODE);
memcpy(tag->tag_data + MAGIC_CODE_LEN, skb->data + ETH_ALEN, ETH_ALEN);
/* Add relay tag */
if (__nat25_add_pppoe_tag(skb, tag) < 0)
return -1;
RTW_INFO("NAT25: Insert PPPoE, forward %s packet\n",
(ph->code == PADI_CODE ? "PADI" : "PADR"));
} else { /* not add relay tag */
if (priv->pppoe_connection_in_progress &&
memcmp(skb->data + ETH_ALEN, priv->pppoe_addr, ETH_ALEN)) {
DEBUG_ERR("Discard PPPoE packet due to another PPPoE connection is in progress!\n");
return -2;
}
if (priv->pppoe_connection_in_progress == 0)
memcpy(priv->pppoe_addr, skb->data + ETH_ALEN, ETH_ALEN);
priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
}
} else
return -1;
} else { /* session phase */
RTW_INFO("NAT25: Insert PPPoE, insert session packet to %s\n", skb->dev->name);
__nat25_generate_pppoe_network_addr(networkAddr, skb->data, &(ph->sid));
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
if (!priv->ethBrExtInfo.addPPPoETag &&
priv->pppoe_connection_in_progress &&
!memcmp(skb->data + ETH_ALEN, priv->pppoe_addr, ETH_ALEN))
priv->pppoe_connection_in_progress = 0;
}
return 0;
case NAT25_LOOKUP:
if (ph->code == PADO_CODE || ph->code == PADS_CODE) {
if (priv->ethBrExtInfo.addPPPoETag) {
struct pppoe_tag *tag;
unsigned char *ptr;
unsigned short tagType, tagLen;
int offset = 0;
ptr = __nat25_find_pppoe_tag(ph, ntohs(PTT_RELAY_SID));
if (ptr == 0) {
DEBUG_ERR("Fail to find PTT_RELAY_SID in FADO!\n");
return -1;
}
tag = (struct pppoe_tag *)ptr;
tagType = (unsigned short)((ptr[0] << 8) + ptr[1]);
tagLen = (unsigned short)((ptr[2] << 8) + ptr[3]);
if ((tagType != ntohs(PTT_RELAY_SID)) || (tagLen < (MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN))) {
DEBUG_ERR("Invalid PTT_RELAY_SID tag length [%d]!\n", tagLen);
return -1;
}
pMagic = (unsigned short *)tag->tag_data;
if (ntohs(*pMagic) != MAGIC_CODE) {
DEBUG_ERR("Can't find MAGIC_CODE in %s packet!\n",
(ph->code == PADO_CODE ? "PADO" : "PADS"));
return -1;
}
memcpy(skb->data, tag->tag_data + MAGIC_CODE_LEN, ETH_ALEN);
if (tagLen > MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN)
offset = TAG_HDR_LEN;
if (skb_pull_and_merge(skb, ptr + offset, TAG_HDR_LEN + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN - offset) < 0) {
DEBUG_ERR("call skb_pull_and_merge() failed in PADO packet!\n");
return -1;
}
ph->length = htons(ntohs(ph->length) - (TAG_HDR_LEN + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN - offset));
if (offset > 0)
tag->tag_len = htons(tagLen - MAGIC_CODE_LEN - RTL_RELAY_TAG_LEN);
RTW_INFO("NAT25: Lookup PPPoE, forward %s Packet from %s\n",
(ph->code == PADO_CODE ? "PADO" : "PADS"), skb->dev->name);
} else { /* not add relay tag */
if (!priv->pppoe_connection_in_progress) {
DEBUG_ERR("Discard PPPoE packet due to no connection in progresss!\n");
return -1;
}
memcpy(skb->data, priv->pppoe_addr, ETH_ALEN);
priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
}
} else {
if (ph->sid != 0) {
RTW_INFO("NAT25: Lookup PPPoE, lookup session packet from %s\n", skb->dev->name);
__nat25_generate_pppoe_network_addr(networkAddr, skb->data + ETH_ALEN, &(ph->sid));
__nat25_db_network_lookup_and_replace(priv, skb, networkAddr);
__nat25_db_print(priv);
} else
return -1;
}
return 0;
default:
return -1;
}
}
/*---------------------------------------------------*/
/* Handle EAP frame */
/*---------------------------------------------------*/
else if (protocol == __constant_htons(0x888e)) {
switch (method) {
case NAT25_CHECK:
return -1;
case NAT25_INSERT:
return 0;
case NAT25_LOOKUP:
return 0;
default:
return -1;
}
}
/*---------------------------------------------------*/
/* Handle C-Media proprietary frame */
/*---------------------------------------------------*/
else if ((protocol == __constant_htons(0xe2ae)) ||
(protocol == __constant_htons(0xe2af))) {
switch (method) {
case NAT25_CHECK:
return -1;
case NAT25_INSERT:
return 0;
case NAT25_LOOKUP:
return 0;
default:
return -1;
}
}
/*---------------------------------------------------*/
/* Handle IPV6 frame */
/*---------------------------------------------------*/
#ifdef CL_IPV6_PASS
else if (protocol == __constant_htons(ETH_P_IPV6)) {
struct ipv6hdr *iph = (struct ipv6hdr *)(skb->data + ETH_HLEN);
if (sizeof(*iph) >= (skb->len - ETH_HLEN)) {
DEBUG_WARN("NAT25: malformed IPv6 packet !\n");
return -1;
}
switch (method) {
case NAT25_CHECK:
if (skb->data[0] & 1)
return 0;
return -1;
case NAT25_INSERT: {
RTW_INFO("NAT25: Insert IP, SA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x,"
" DA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x\n",
iph->saddr.s6_addr16[0], iph->saddr.s6_addr16[1], iph->saddr.s6_addr16[2], iph->saddr.s6_addr16[3],
iph->saddr.s6_addr16[4], iph->saddr.s6_addr16[5], iph->saddr.s6_addr16[6], iph->saddr.s6_addr16[7],
iph->daddr.s6_addr16[0], iph->daddr.s6_addr16[1], iph->daddr.s6_addr16[2], iph->daddr.s6_addr16[3],
iph->daddr.s6_addr16[4], iph->daddr.s6_addr16[5], iph->daddr.s6_addr16[6], iph->daddr.s6_addr16[7]);
if (memcmp(&iph->saddr, "\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0", 16)) {
__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->saddr);
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
__nat25_db_print(priv);
if (iph->nexthdr == IPPROTO_ICMPV6 &&
skb->len > (ETH_HLEN + sizeof(*iph) + 4)) {
if (update_nd_link_layer_addr(skb->data + ETH_HLEN + sizeof(*iph),
skb->len - ETH_HLEN - sizeof(*iph), GET_MY_HWADDR(priv))) {
struct icmp6hdr *hdr = (struct icmp6hdr *)(skb->data + ETH_HLEN + sizeof(*iph));
hdr->icmp6_cksum = 0;
hdr->icmp6_cksum = csum_ipv6_magic(&iph->saddr, &iph->daddr,
iph->payload_len,
IPPROTO_ICMPV6,
csum_partial((__u8 *)hdr, iph->payload_len, 0));
}
}
}
}
return 0;
case NAT25_LOOKUP:
RTW_INFO("NAT25: Lookup IP, SA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x,"
" DA=%4x:%4x:%4x:%4x:%4x:%4x:%4x:%4x\n",
iph->saddr.s6_addr16[0], iph->saddr.s6_addr16[1], iph->saddr.s6_addr16[2], iph->saddr.s6_addr16[3],
iph->saddr.s6_addr16[4], iph->saddr.s6_addr16[5], iph->saddr.s6_addr16[6], iph->saddr.s6_addr16[7],
iph->daddr.s6_addr16[0], iph->daddr.s6_addr16[1], iph->daddr.s6_addr16[2], iph->daddr.s6_addr16[3],
iph->daddr.s6_addr16[4], iph->daddr.s6_addr16[5], iph->daddr.s6_addr16[6], iph->daddr.s6_addr16[7]);
__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->daddr);
if (!__nat25_db_network_lookup_and_replace(priv, skb, networkAddr)) {
#ifdef SUPPORT_RX_UNI2MCAST
if (iph->daddr.s6_addr[0] == 0xff)
convert_ipv6_mac_to_mc(skb);
#endif
}
return 0;
default:
return -1;
}
}
#endif /* CL_IPV6_PASS */
return -1;
}
int nat25_handle_frame(_adapter *priv, struct sk_buff *skb)
{
#ifdef BR_EXT_DEBUG
if ((!priv->ethBrExtInfo.nat25_disable) && (!(skb->data[0] & 1))) {
panic_printk("NAT25: Input Frame: DA=%02x%02x%02x%02x%02x%02x SA=%02x%02x%02x%02x%02x%02x\n",
skb->data[0],
skb->data[1],
skb->data[2],
skb->data[3],
skb->data[4],
skb->data[5],
skb->data[6],
skb->data[7],
skb->data[8],
skb->data[9],
skb->data[10],
skb->data[11]);
}
#endif
if (!(skb->data[0] & 1)) {
int is_vlan_tag = 0, i, retval = 0;
unsigned short vlan_hdr = 0;
if (*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_8021Q)) {
is_vlan_tag = 1;
vlan_hdr = *((unsigned short *)(skb->data + ETH_ALEN * 2 + 2));
for (i = 0; i < 6; i++)
*((unsigned short *)(skb->data + ETH_ALEN * 2 + 2 - i * 2)) = *((unsigned short *)(skb->data + ETH_ALEN * 2 - 2 - i * 2));
skb_pull(skb, 4);
}
if (!priv->ethBrExtInfo.nat25_disable) {
_irqL irqL;
_enter_critical_bh(&priv->br_ext_lock, &irqL);
/*
* This function look up the destination network address from
* the NAT2.5 database. Return value = -1 means that the
* corresponding network protocol is NOT support.
*/
if (!priv->ethBrExtInfo.nat25sc_disable &&
(*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_IP)) &&
!memcmp(priv->scdb_ip, skb->data + ETH_HLEN + 16, 4)) {
memcpy(skb->data, priv->scdb_mac, ETH_ALEN);
_exit_critical_bh(&priv->br_ext_lock, &irqL);
} else {
_exit_critical_bh(&priv->br_ext_lock, &irqL);
retval = nat25_db_handle(priv, skb, NAT25_LOOKUP);
}
} else {
if (((*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_IP)) &&
!memcmp(priv->br_ip, skb->data + ETH_HLEN + 16, 4)) ||
((*((unsigned short *)(skb->data + ETH_ALEN * 2)) == __constant_htons(ETH_P_ARP)) &&
!memcmp(priv->br_ip, skb->data + ETH_HLEN + 24, 4))) {
/* for traffic to upper TCP/IP */
retval = nat25_db_handle(priv, skb, NAT25_LOOKUP);
}
}
if (is_vlan_tag) {
skb_push(skb, 4);
for (i = 0; i < 6; i++)
*((unsigned short *)(skb->data + i * 2)) = *((unsigned short *)(skb->data + 4 + i * 2));
*((unsigned short *)(skb->data + ETH_ALEN * 2)) = __constant_htons(ETH_P_8021Q);
*((unsigned short *)(skb->data + ETH_ALEN * 2 + 2)) = vlan_hdr;
}
if (retval == -1) {
/* DEBUG_ERR("NAT25: Lookup fail!\n"); */
return -1;
}
}
return 0;
}
#if 0
void mac_clone(_adapter *priv, unsigned char *addr)
{
struct sockaddr sa;
memcpy(sa.sa_data, addr, ETH_ALEN);
RTW_INFO("MAC Clone: Addr=%02x%02x%02x%02x%02x%02x\n",
addr[0], addr[1], addr[2], addr[3], addr[4], addr[5]);
rtl8192cd_set_hwaddr(priv->dev, &sa);
}
int mac_clone_handle_frame(_adapter *priv, struct sk_buff *skb)
{
if (priv->ethBrExtInfo.macclone_enable && !priv->macclone_completed) {
if (!(skb->data[ETH_ALEN] & 1)) { /* check any other particular MAC add */
if (memcmp(skb->data + ETH_ALEN, GET_MY_HWADDR(priv), ETH_ALEN) &&
((priv->dev->br_port) &&
memcmp(skb->data + ETH_ALEN, priv->br_mac, ETH_ALEN))) {
mac_clone(priv, skb->data + ETH_ALEN);
priv->macclone_completed = 1;
}
}
}
return 0;
}
#endif /* 0 */
#define SERVER_PORT 67
#define CLIENT_PORT 68
#define DHCP_MAGIC 0x63825363
#define BROADCAST_FLAG 0x8000
struct dhcpMessage {
u_int8_t op;
u_int8_t htype;
u_int8_t hlen;
u_int8_t hops;
u_int32_t xid;
u_int16_t secs;
u_int16_t flags;
u_int32_t ciaddr;
u_int32_t yiaddr;
u_int32_t siaddr;
u_int32_t giaddr;
u_int8_t chaddr[16];
u_int8_t sname[64];
u_int8_t file[128];
u_int32_t cookie;
u_int8_t options[308]; /* 312 - cookie */
};
void dhcp_flag_bcast(_adapter *priv, struct sk_buff *skb)
{
if (skb == NULL)
return;
if (!priv->ethBrExtInfo.dhcp_bcst_disable) {
unsigned short protocol = *((unsigned short *)(skb->data + 2 * ETH_ALEN));
if (protocol == __constant_htons(ETH_P_IP)) { /* IP */
struct iphdr *iph = (struct iphdr *)(skb->data + ETH_HLEN);
if (iph->protocol == IPPROTO_UDP) { /* UDP */
struct udphdr *udph = (struct udphdr *)((SIZE_PTR)iph + (iph->ihl << 2));
if ((udph->source == __constant_htons(CLIENT_PORT))
&& (udph->dest == __constant_htons(SERVER_PORT))) { /* DHCP request */
struct dhcpMessage *dhcph =
(struct dhcpMessage *)((SIZE_PTR)udph + sizeof(struct udphdr));
if (dhcph->cookie == __constant_htonl(DHCP_MAGIC)) { /* match magic word */
if (!(dhcph->flags & htons(BROADCAST_FLAG))) { /* if not broadcast */
register int sum = 0;
RTW_INFO("DHCP: change flag of DHCP request to broadcast.\n");
/* or BROADCAST flag */
dhcph->flags |= htons(BROADCAST_FLAG);
/* recalculate checksum */
sum = ~(udph->check) & 0xffff;
sum += dhcph->flags;
while (sum >> 16)
sum = (sum & 0xffff) + (sum >> 16);
udph->check = ~sum;
}
}
}
}
}
}
}
void *scdb_findEntry(_adapter *priv, unsigned char *macAddr,
unsigned char *ipAddr)
{
unsigned char networkAddr[MAX_NETWORK_ADDR_LEN];
struct nat25_network_db_entry *db;
int hash;
/* _irqL irqL; */
/* _enter_critical_bh(&priv->br_ext_lock, &irqL); */
__nat25_generate_ipv4_network_addr(networkAddr, (unsigned int *)ipAddr);
hash = __nat25_network_hash(networkAddr);
db = priv->nethash[hash];
while (db != NULL) {
if (!memcmp(db->networkAddr, networkAddr, MAX_NETWORK_ADDR_LEN)) {
/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
return (void *)db;
}
db = db->next_hash;
}
/* _exit_critical_bh(&priv->br_ext_lock, &irqL); */
return NULL;
}
#endif /* CONFIG_BR_EXT */
================================================
FILE: core/rtw_bt_mp.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#if defined(CONFIG_RTL8723B)
#include
#endif
#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8821A)
void MPh2c_timeout_handle(void *FunctionContext)
{
PADAPTER pAdapter;
PMPT_CONTEXT pMptCtx;
RTW_INFO("[MPT], MPh2c_timeout_handle\n");
pAdapter = (PADAPTER)FunctionContext;
pMptCtx = &pAdapter->mppriv.mpt_ctx;
pMptCtx->bMPh2c_timeout = _TRUE;
if ((_FALSE == pMptCtx->MptH2cRspEvent)
|| ((_TRUE == pMptCtx->MptH2cRspEvent)
&& (_FALSE == pMptCtx->MptBtC2hEvent)))
_rtw_up_sema(&pMptCtx->MPh2c_Sema);
}
u32 WaitC2Hevent(PADAPTER pAdapter, u8 *C2H_event, u32 delay_time)
{
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
pMptCtx->bMPh2c_timeout = _FALSE;
if (pAdapter->registrypriv.mp_mode == 0) {
RTW_INFO("[MPT], Error!! WaitC2Hevent mp_mode == 0!!\n");
return _FALSE;
}
_set_timer(&pMptCtx->MPh2c_timeout_timer, delay_time);
_rtw_down_sema(&pMptCtx->MPh2c_Sema);
if (pMptCtx->bMPh2c_timeout == _TRUE) {
*C2H_event = _FALSE;
return _FALSE;
}
/* for safty, cancel timer here again */
_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
return _TRUE;
}
BT_CTRL_STATUS
mptbt_CheckC2hFrame(
PADAPTER Adapter,
PBT_H2C pH2c,
PBT_EXT_C2H pExtC2h
)
{
BT_CTRL_STATUS c2hStatus = BT_STATUS_C2H_SUCCESS;
/* RTW_INFO("[MPT], MPT rsp C2H hex: %x %x %x %x %x %x\n"), pExtC2h , pExtC2h+1 ,pExtC2h+2 ,pExtC2h+3 ,pExtC2h+4 ,pExtC2h+5); */
RTW_INFO("[MPT], statusCode = 0x%x\n", pExtC2h->statusCode);
RTW_INFO("[MPT], retLen = %d\n", pExtC2h->retLen);
RTW_INFO("[MPT], opCodeVer : req/rsp=%d/%d\n", pH2c->opCodeVer, pExtC2h->opCodeVer);
RTW_INFO("[MPT], reqNum : req/rsp=%d/%d\n", pH2c->reqNum, pExtC2h->reqNum);
if (pExtC2h->reqNum != pH2c->reqNum) {
c2hStatus = BT_STATUS_C2H_REQNUM_MISMATCH;
RTW_INFO("[MPT], Error!! C2H reqNum Mismatch!!\n");
} else if (pExtC2h->opCodeVer != pH2c->opCodeVer) {
c2hStatus = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
RTW_INFO("[MPT], Error!! OPCode version L mismatch!!\n");
}
return c2hStatus;
}
BT_CTRL_STATUS
mptbt_SendH2c(
PADAPTER Adapter,
PBT_H2C pH2c,
u16 h2cCmdLen
)
{
/* KIRQL OldIrql = KeGetCurrentIrql(); */
BT_CTRL_STATUS h2cStatus = BT_STATUS_H2C_SUCCESS;
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
u8 i;
RTW_INFO("[MPT], mptbt_SendH2c()=========>\n");
/* PlatformResetEvent(&pMptCtx->MptH2cRspEvent); */
/* PlatformResetEvent(&pMptCtx->MptBtC2hEvent); */
/* if(OldIrql == PASSIVE_LEVEL)
* { */
/* RTPRINT_DATA(FMPBT, FMPBT_H2C_CONTENT, ("[MPT], MPT H2C hex:\n"), pH2c, h2cCmdLen); */
for (i = 0; i < BT_H2C_MAX_RETRY; i++) {
RTW_INFO("[MPT], Send H2C command to wifi!!!\n");
pMptCtx->MptH2cRspEvent = _FALSE;
pMptCtx->MptBtC2hEvent = _FALSE;
#if defined(CONFIG_RTL8723B)
rtl8723b_set_FwBtMpOper_cmd(Adapter, pH2c->opCode, pH2c->opCodeVer, pH2c->reqNum, pH2c->buf);
#endif
pMptCtx->h2cReqNum++;
pMptCtx->h2cReqNum %= 16;
if (WaitC2Hevent(Adapter, &pMptCtx->MptH2cRspEvent, 100)) {
RTW_INFO("[MPT], Received WiFi MptH2cRspEvent!!!\n");
if (WaitC2Hevent(Adapter, &pMptCtx->MptBtC2hEvent, 400)) {
RTW_INFO("[MPT], Received MptBtC2hEvent!!!\n");
break;
} else {
RTW_INFO("[MPT], Error!!BT MptBtC2hEvent timeout!!\n");
h2cStatus = BT_STATUS_H2C_BT_NO_RSP;
}
} else {
RTW_INFO("[MPT], Error!!WiFi MptH2cRspEvent timeout!!\n");
h2cStatus = BT_STATUS_H2C_TIMTOUT;
}
}
/* }
* else
* {
* RT_ASSERT(FALSE, ("[MPT], mptbt_SendH2c() can only run under PASSIVE_LEVEL!!\n"));
* h2cStatus = BT_STATUS_WRONG_LEVEL;
* } */
RTW_INFO("[MPT], mptbt_SendH2c()<=========\n");
return h2cStatus;
}
BT_CTRL_STATUS
mptbt_CheckBtRspStatus(
PADAPTER Adapter,
PBT_EXT_C2H pExtC2h
)
{
BT_CTRL_STATUS retStatus = BT_OP_STATUS_SUCCESS;
switch (pExtC2h->statusCode) {
case BT_OP_STATUS_SUCCESS:
retStatus = BT_STATUS_BT_OP_SUCCESS;
RTW_INFO("[MPT], BT status : BT_STATUS_SUCCESS\n");
break;
case BT_OP_STATUS_VERSION_MISMATCH:
retStatus = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
RTW_INFO("[MPT], BT status : BT_STATUS_OPCODE_L_VERSION_MISMATCH\n");
break;
case BT_OP_STATUS_UNKNOWN_OPCODE:
retStatus = BT_STATUS_UNKNOWN_OPCODE_L;
RTW_INFO("[MPT], BT status : BT_STATUS_UNKNOWN_OPCODE_L\n");
break;
case BT_OP_STATUS_ERROR_PARAMETER:
retStatus = BT_STATUS_PARAMETER_FORMAT_ERROR_L;
RTW_INFO("[MPT], BT status : BT_STATUS_PARAMETER_FORMAT_ERROR_L\n");
break;
default:
retStatus = BT_STATUS_UNKNOWN_STATUS_L;
RTW_INFO("[MPT], BT status : BT_STATUS_UNKNOWN_STATUS_L\n");
break;
}
return retStatus;
}
BT_CTRL_STATUS
mptbt_BtFwOpCodeProcess(
PADAPTER Adapter,
u8 btFwOpCode,
u8 opCodeVer,
u8 *pH2cPar,
u8 h2cParaLen
)
{
u8 H2C_Parameter[6] = {0};
PBT_H2C pH2c = (PBT_H2C)&H2C_Parameter[0];
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
PBT_EXT_C2H pExtC2h = (PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
u16 paraLen = 0, i;
BT_CTRL_STATUS h2cStatus = BT_STATUS_H2C_SUCCESS, c2hStatus = BT_STATUS_C2H_SUCCESS;
BT_CTRL_STATUS retStatus = BT_STATUS_H2C_BT_NO_RSP;
if (Adapter->registrypriv.mp_mode == 0) {
RTW_INFO("[MPT], Error!! mptbt_BtFwOpCodeProces mp_mode == 0!!\n");
return _FALSE;
}
pH2c->opCode = btFwOpCode;
pH2c->opCodeVer = opCodeVer;
pH2c->reqNum = pMptCtx->h2cReqNum;
/* PlatformMoveMemory(&pH2c->buf[0], pH2cPar, h2cParaLen); */
/* _rtw_memcpy(&pH2c->buf[0], pH2cPar, h2cParaLen); */
_rtw_memcpy(pH2c->buf, pH2cPar, h2cParaLen);
RTW_INFO("[MPT], pH2c->opCode=%d\n", pH2c->opCode);
RTW_INFO("[MPT], pH2c->opCodeVer=%d\n", pH2c->opCodeVer);
RTW_INFO("[MPT], pH2c->reqNum=%d\n", pH2c->reqNum);
RTW_INFO("[MPT], h2c parameter length=%d\n", h2cParaLen);
for (i = 0; i < h2cParaLen; i++)
RTW_INFO("[MPT], parameter[%d]=0x%02x\n", i, pH2c->buf[i]);
h2cStatus = mptbt_SendH2c(Adapter, pH2c, h2cParaLen + 2);
if (BT_STATUS_H2C_SUCCESS == h2cStatus) {
/* if reach here, it means H2C get the correct c2h response, */
c2hStatus = mptbt_CheckC2hFrame(Adapter, pH2c, pExtC2h);
if (BT_STATUS_C2H_SUCCESS == c2hStatus)
retStatus = mptbt_CheckBtRspStatus(Adapter, pExtC2h);
else {
RTW_INFO("[MPT], Error!! C2H failed for pH2c->opCode=%d\n", pH2c->opCode);
/* check c2h status error, return error status code to upper layer. */
retStatus = c2hStatus;
}
} else {
RTW_INFO("[MPT], Error!! H2C failed for pH2c->opCode=%d\n", pH2c->opCode);
/* check h2c status error, return error status code to upper layer. */
retStatus = h2cStatus;
}
return retStatus;
}
u16
mptbt_BtReady(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode;
u8 btOpcodeVer = 0;
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
PBT_EXT_C2H pExtC2h = (PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
u8 i;
u8 btFwVer = 0, bdAddr[6] = {0};
u16 btRealFwVer = 0;
u16 *pu2Tmp = NULL;
/* */
/* check upper layer parameters */
/* */
/* 1. check upper layer opcode version */
if (pBtReq->opCodeVer != 1) {
RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
return paraLen;
}
pBtRsp->pParamStart[0] = MP_BT_NOT_READY;
paraLen = 10;
/* */
/* execute lower layer opcodes */
/* */
/* Get BT FW version */
/* fill h2c parameters */
btOpcode = BT_LO_OP_GET_BT_VERSION;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
} else {
pu2Tmp = (u16 *)&pExtC2h->buf[0];
btRealFwVer = *pu2Tmp;
btFwVer = pExtC2h->buf[1];
RTW_INFO("[MPT], btRealFwVer=0x%x, btFwVer=0x%x\n", btRealFwVer, btFwVer);
}
/* Get BD Address */
/* fill h2c parameters */
btOpcode = BT_LO_OP_GET_BD_ADDR_L;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
} else {
bdAddr[5] = pExtC2h->buf[0];
bdAddr[4] = pExtC2h->buf[1];
bdAddr[3] = pExtC2h->buf[2];
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_GET_BD_ADDR_H;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
} else {
bdAddr[2] = pExtC2h->buf[0];
bdAddr[1] = pExtC2h->buf[1];
bdAddr[0] = pExtC2h->buf[2];
}
RTW_INFO("[MPT], Local BDAddr:");
for (i = 0; i < 6; i++)
RTW_INFO(" 0x%x ", bdAddr[i]);
pBtRsp->status = BT_STATUS_SUCCESS;
pBtRsp->pParamStart[0] = MP_BT_READY;
pu2Tmp = (u16 *)&pBtRsp->pParamStart[1];
*pu2Tmp = btRealFwVer;
pBtRsp->pParamStart[3] = btFwVer;
for (i = 0; i < 6; i++)
pBtRsp->pParamStart[4 + i] = bdAddr[5 - i];
return paraLen;
}
void mptbt_close_WiFiRF(PADAPTER Adapter)
{
phy_set_bb_reg(Adapter, 0x824, 0xF, 0x0);
phy_set_bb_reg(Adapter, 0x824, 0x700000, 0x0);
phy_set_rf_reg(Adapter, RF_PATH_A, 0x0, 0xF0000, 0x0);
}
void mptbt_open_WiFiRF(PADAPTER Adapter)
{
phy_set_bb_reg(Adapter, 0x824, 0x700000, 0x3);
phy_set_bb_reg(Adapter, 0x824, 0xF, 0x2);
phy_set_rf_reg(Adapter, RF_PATH_A, 0x0, 0xF0000, 0x3);
}
u32 mptbt_switch_RF(PADAPTER Adapter, u8 Enter)
{
u16 tmp_2byte = 0;
/* Enter test mode */
if (Enter) {
/* 1>. close WiFi RF */
mptbt_close_WiFiRF(Adapter);
/* 2>. change ant switch to BT */
tmp_2byte = rtw_read16(Adapter, 0x860);
tmp_2byte = tmp_2byte | BIT(9);
tmp_2byte = tmp_2byte & (~BIT(8));
rtw_write16(Adapter, 0x860, tmp_2byte);
rtw_write16(Adapter, 0x870, 0x300);
} else {
/* 1>. Open WiFi RF */
mptbt_open_WiFiRF(Adapter);
/* 2>. change ant switch back */
tmp_2byte = rtw_read16(Adapter, 0x860);
tmp_2byte = tmp_2byte | BIT(8);
tmp_2byte = tmp_2byte & (~BIT(9));
rtw_write16(Adapter, 0x860, tmp_2byte);
rtw_write16(Adapter, 0x870, 0x300);
}
return 0;
}
u16
mptbt_BtSetMode(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode;
u8 btOpcodeVer = 0;
u8 btModeToSet = 0;
/* */
/* check upper layer parameters */
/* */
/* 1. check upper layer opcode version */
if (pBtReq->opCodeVer != 1) {
RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
return paraLen;
}
/* 2. check upper layer parameter length */
if (1 == pBtReq->paraLength) {
btModeToSet = pBtReq->pParamStart[0];
RTW_INFO("[MPT], BtTestMode=%d\n", btModeToSet);
} else {
RTW_INFO("[MPT], Error!! wrong parameter length=%d (should be 1)\n", pBtReq->paraLength);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
/* */
/* execute lower layer opcodes */
/* */
/* 1. fill h2c parameters */
/* check bt mode */
btOpcode = BT_LO_OP_SET_BT_MODE;
if (btModeToSet >= MP_BT_MODE_MAX) {
pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
mptbt_switch_RF(Adapter, 1);
h2cParaBuf[0] = btModeToSet;
h2cParaLen = 1;
/* 2. execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* 3. construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS == retStatus)
pBtRsp->status = BT_STATUS_SUCCESS;
else {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
}
return paraLen;
}
void
MPTBT_FwC2hBtMpCtrl(
PADAPTER Adapter,
u8 *tmpBuf,
u8 length
)
{
u32 i;
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
PBT_EXT_C2H pExtC2h = (PBT_EXT_C2H)tmpBuf;
if (GET_HAL_DATA(Adapter)->bBTFWReady == _FALSE || Adapter->registrypriv.mp_mode == 0) {
/* RTW_INFO("Ignore C2H BT MP Info since not in MP mode\n"); */
return;
}
if (length > 32 || length < 3) {
RTW_INFO("\n [MPT], pExtC2h->buf hex: length=%d > 32 || < 3\n", length);
return;
}
/* cancel_timeout for h2c handle */
_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
for (i = 0; i < length; i++)
RTW_INFO("[MPT], %s, buf[%d]=0x%02x ", __FUNCTION__, i, tmpBuf[i]);
RTW_INFO("[MPT], pExtC2h->extendId=0x%x\n", pExtC2h->extendId);
switch (pExtC2h->extendId) {
case EXT_C2H_WIFI_FW_ACTIVE_RSP:
RTW_INFO("[MPT], EXT_C2H_WIFI_FW_ACTIVE_RSP\n");
#if 0
RTW_INFO("[MPT], pExtC2h->buf hex:\n");
for (i = 0; i < (length - 3); i++)
RTW_INFO(" 0x%x ", pExtC2h->buf[i]);
#endif
if ((_FALSE == pMptCtx->bMPh2c_timeout)
&& (_FALSE == pMptCtx->MptH2cRspEvent)) {
pMptCtx->MptH2cRspEvent = _TRUE;
_rtw_up_sema(&pMptCtx->MPh2c_Sema);
}
break;
case EXT_C2H_TRIG_BY_BT_FW:
RTW_INFO("[MPT], EXT_C2H_TRIG_BY_BT_FW\n");
_rtw_memcpy(&pMptCtx->c2hBuf[0], tmpBuf, length);
RTW_INFO("[MPT], pExtC2h->statusCode=0x%x\n", pExtC2h->statusCode);
RTW_INFO("[MPT], pExtC2h->retLen=0x%x\n", pExtC2h->retLen);
RTW_INFO("[MPT], pExtC2h->opCodeVer=0x%x\n", pExtC2h->opCodeVer);
RTW_INFO("[MPT], pExtC2h->reqNum=0x%x\n", pExtC2h->reqNum);
for (i = 0; i < (length - 3); i++)
RTW_INFO("[MPT], pExtC2h->buf[%d]=0x%02x\n", i, pExtC2h->buf[i]);
if ((_FALSE == pMptCtx->bMPh2c_timeout)
&& (_TRUE == pMptCtx->MptH2cRspEvent)
&& (_FALSE == pMptCtx->MptBtC2hEvent)) {
pMptCtx->MptBtC2hEvent = _TRUE;
_rtw_up_sema(&pMptCtx->MPh2c_Sema);
}
break;
default:
RTW_INFO("[MPT], EXT_C2H Target not found,pExtC2h->extendId =%d ,pExtC2h->reqNum=%d\n", pExtC2h->extendId, pExtC2h->reqNum);
break;
}
}
u16
mptbt_BtGetGeneral(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
PBT_EXT_C2H pExtC2h = (PBT_EXT_C2H)&pMptCtx->c2hBuf[0];
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode, bdAddr[6] = {0};
u8 btOpcodeVer = 0;
u8 getType = 0, i;
u16 getParaLen = 0, validParaLen = 0;
u8 regType = 0, reportType = 0;
u32 regAddr = 0, regValue = 0;
u32 *pu4Tmp;
u16 *pu2Tmp;
u8 *pu1Tmp;
/* */
/* check upper layer parameters */
/* */
/* check upper layer opcode version */
if (pBtReq->opCodeVer != 1) {
RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
return paraLen;
}
/* check upper layer parameter length */
if (pBtReq->paraLength < 1) {
RTW_INFO("[MPT], Error!! wrong parameter length=%d (should larger than 1)\n", pBtReq->paraLength);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
getParaLen = pBtReq->paraLength - 1;
getType = pBtReq->pParamStart[0];
RTW_INFO("[MPT], getType=%d, getParaLen=%d\n", getType, getParaLen);
/* check parameter first */
switch (getType) {
case BT_GGET_REG:
RTW_INFO("[MPT], [BT_GGET_REG]\n");
validParaLen = 5;
if (getParaLen == validParaLen) {
btOpcode = BT_LO_OP_READ_REG;
regType = pBtReq->pParamStart[1];
pu4Tmp = (u32 *)&pBtReq->pParamStart[2];
regAddr = *pu4Tmp;
RTW_INFO("[MPT], BT_GGET_REG regType=0x%02x, regAddr=0x%08x!!\n",
regType, regAddr);
if (regType >= BT_REG_MAX) {
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
if (((BT_REG_RF == regType) && (regAddr > 0x7f)) ||
((BT_REG_MODEM == regType) && (regAddr > 0x1ff)) ||
((BT_REG_BLUEWIZE == regType) && (regAddr > 0xfff)) ||
((BT_REG_VENDOR == regType) && (regAddr > 0xfff)) ||
((BT_REG_LE == regType) && (regAddr > 0xfff))) {
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
}
}
break;
case BT_GGET_STATUS:
RTW_INFO("[MPT], [BT_GGET_STATUS]\n");
validParaLen = 0;
break;
case BT_GGET_REPORT:
RTW_INFO("[MPT], [BT_GGET_REPORT]\n");
validParaLen = 1;
if (getParaLen == validParaLen) {
reportType = pBtReq->pParamStart[1];
RTW_INFO("[MPT], BT_GGET_REPORT reportType=0x%x!!\n", reportType);
if (reportType >= BT_REPORT_MAX) {
pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
}
break;
default: {
RTW_INFO("[MPT], Error!! getType=%d, out of range\n", getType);
pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
break;
}
if (getParaLen != validParaLen) {
RTW_INFO("[MPT], Error!! wrong parameter length=%d for BT_GET_GEN_CMD cmd id=0x%x, paraLen should=0x%x\n",
getParaLen, getType, validParaLen);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
/* */
/* execute lower layer opcodes */
/* */
if (BT_GGET_REG == getType) {
/* fill h2c parameters */
/* here we should write reg value first then write the address, adviced by Austin */
btOpcode = BT_LO_OP_READ_REG;
h2cParaBuf[0] = regType;
h2cParaBuf[1] = pBtReq->pParamStart[2];
h2cParaBuf[2] = pBtReq->pParamStart[3];
h2cParaLen = 3;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pu2Tmp = (u16 *)&pExtC2h->buf[0];
regValue = *pu2Tmp;
RTW_INFO("[MPT], read reg regType=0x%02x, regAddr=0x%08x, regValue=0x%04x\n",
regType, regAddr, regValue);
pu4Tmp = (u32 *)&pBtRsp->pParamStart[0];
*pu4Tmp = regValue;
paraLen = 4;
} else if (BT_GGET_STATUS == getType) {
btOpcode = BT_LO_OP_GET_BT_STATUS;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[0] = pExtC2h->buf[0];
pBtRsp->pParamStart[1] = pExtC2h->buf[1];
RTW_INFO("[MPT], read bt status, testMode=0x%x, testStatus=0x%x\n",
pBtRsp->pParamStart[0], pBtRsp->pParamStart[1]);
paraLen = 2;
} else if (BT_GGET_REPORT == getType) {
switch (reportType) {
case BT_REPORT_RX_PACKET_CNT: {
RTW_INFO("[MPT], [Rx Packet Counts]\n");
btOpcode = BT_LO_OP_GET_RX_PKT_CNT_L;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[0] = pExtC2h->buf[0];
pBtRsp->pParamStart[1] = pExtC2h->buf[1];
btOpcode = BT_LO_OP_GET_RX_PKT_CNT_H;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[2] = pExtC2h->buf[0];
pBtRsp->pParamStart[3] = pExtC2h->buf[1];
paraLen = 4;
}
break;
case BT_REPORT_RX_ERROR_BITS: {
RTW_INFO("[MPT], [Rx Error Bits]\n");
btOpcode = BT_LO_OP_GET_RX_ERROR_BITS_L;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[0] = pExtC2h->buf[0];
pBtRsp->pParamStart[1] = pExtC2h->buf[1];
btOpcode = BT_LO_OP_GET_RX_ERROR_BITS_H;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[2] = pExtC2h->buf[0];
pBtRsp->pParamStart[3] = pExtC2h->buf[1];
paraLen = 4;
}
break;
case BT_REPORT_RSSI: {
RTW_INFO("[MPT], [RSSI]\n");
btOpcode = BT_LO_OP_GET_RSSI;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[0] = pExtC2h->buf[0];
pBtRsp->pParamStart[1] = pExtC2h->buf[1];
paraLen = 2;
}
break;
case BT_REPORT_CFO_HDR_QUALITY: {
RTW_INFO("[MPT], [CFO & Header Quality]\n");
btOpcode = BT_LO_OP_GET_CFO_HDR_QUALITY_L;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[0] = pExtC2h->buf[0];
pBtRsp->pParamStart[1] = pExtC2h->buf[1];
btOpcode = BT_LO_OP_GET_CFO_HDR_QUALITY_H;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->pParamStart[2] = pExtC2h->buf[0];
pBtRsp->pParamStart[3] = pExtC2h->buf[1];
paraLen = 4;
}
break;
case BT_REPORT_CONNECT_TARGET_BD_ADDR: {
RTW_INFO("[MPT], [Connected Target BD ADDR]\n");
btOpcode = BT_LO_OP_GET_TARGET_BD_ADDR_L;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
bdAddr[5] = pExtC2h->buf[0];
bdAddr[4] = pExtC2h->buf[1];
bdAddr[3] = pExtC2h->buf[2];
btOpcode = BT_LO_OP_GET_TARGET_BD_ADDR_H;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
bdAddr[2] = pExtC2h->buf[0];
bdAddr[1] = pExtC2h->buf[1];
bdAddr[0] = pExtC2h->buf[2];
RTW_INFO("[MPT], Connected Target BDAddr:%s", bdAddr);
for (i = 0; i < 6; i++)
pBtRsp->pParamStart[i] = bdAddr[5 - i];
paraLen = 6;
}
break;
default:
pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
break;
}
}
pBtRsp->status = BT_STATUS_SUCCESS;
return paraLen;
}
u16
mptbt_BtSetGeneral(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode;
u8 btOpcodeVer = 0;
u8 setType = 0;
u16 setParaLen = 0, validParaLen = 0;
u8 regType = 0, bdAddr[6] = {0}, calVal = 0;
u32 regAddr = 0, regValue = 0;
u32 *pu4Tmp;
u16 *pu2Tmp;
u8 *pu1Tmp;
/* */
/* check upper layer parameters */
/* */
/* check upper layer opcode version */
if (pBtReq->opCodeVer != 1) {
RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
return paraLen;
}
/* check upper layer parameter length */
if (pBtReq->paraLength < 1) {
RTW_INFO("[MPT], Error!! wrong parameter length=%d (should larger than 1)\n", pBtReq->paraLength);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
setParaLen = pBtReq->paraLength - 1;
setType = pBtReq->pParamStart[0];
RTW_INFO("[MPT], setType=%d, setParaLen=%d\n", setType, setParaLen);
/* check parameter first */
switch (setType) {
case BT_GSET_REG:
RTW_INFO("[MPT], [BT_GSET_REG]\n");
validParaLen = 9;
if (setParaLen == validParaLen) {
btOpcode = BT_LO_OP_WRITE_REG_VALUE;
regType = pBtReq->pParamStart[1];
pu4Tmp = (u32 *)&pBtReq->pParamStart[2];
regAddr = *pu4Tmp;
pu4Tmp = (u32 *)&pBtReq->pParamStart[6];
regValue = *pu4Tmp;
RTW_INFO("[MPT], BT_GSET_REG regType=0x%x, regAddr=0x%x, regValue=0x%x!!\n",
regType, regAddr, regValue);
if (regType >= BT_REG_MAX) {
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
if (((BT_REG_RF == regType) && (regAddr > 0x7f)) ||
((BT_REG_MODEM == regType) && (regAddr > 0x1ff)) ||
((BT_REG_BLUEWIZE == regType) && (regAddr > 0xfff)) ||
((BT_REG_VENDOR == regType) && (regAddr > 0xfff)) ||
((BT_REG_LE == regType) && (regAddr > 0xfff))) {
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
}
}
break;
case BT_GSET_RESET:
RTW_INFO("[MPT], [BT_GSET_RESET]\n");
validParaLen = 0;
break;
case BT_GSET_TARGET_BD_ADDR:
RTW_INFO("[MPT], [BT_GSET_TARGET_BD_ADDR]\n");
validParaLen = 6;
if (setParaLen == validParaLen) {
btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_H;
if ((pBtReq->pParamStart[1] == 0) &&
(pBtReq->pParamStart[2] == 0) &&
(pBtReq->pParamStart[3] == 0) &&
(pBtReq->pParamStart[4] == 0) &&
(pBtReq->pParamStart[5] == 0) &&
(pBtReq->pParamStart[6] == 0)) {
RTW_INFO("[MPT], Error!! targetBDAddr=all zero\n");
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
if ((pBtReq->pParamStart[1] == 0xff) &&
(pBtReq->pParamStart[2] == 0xff) &&
(pBtReq->pParamStart[3] == 0xff) &&
(pBtReq->pParamStart[4] == 0xff) &&
(pBtReq->pParamStart[5] == 0xff) &&
(pBtReq->pParamStart[6] == 0xff)) {
RTW_INFO("[MPT], Error!! targetBDAddr=all 0xf\n");
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
bdAddr[0] = pBtReq->pParamStart[6];
bdAddr[1] = pBtReq->pParamStart[5];
bdAddr[2] = pBtReq->pParamStart[4];
bdAddr[3] = pBtReq->pParamStart[3];
bdAddr[4] = pBtReq->pParamStart[2];
bdAddr[5] = pBtReq->pParamStart[1];
RTW_INFO("[MPT], target BDAddr:%x,%x,%x,%x,%x,%x\n",
bdAddr[0], bdAddr[1], bdAddr[2], bdAddr[3], bdAddr[4], bdAddr[5]);
}
break;
case BT_GSET_TX_PWR_FINETUNE:
RTW_INFO("[MPT], [BT_GSET_TX_PWR_FINETUNE]\n");
validParaLen = 1;
if (setParaLen == validParaLen) {
btOpcode = BT_LO_OP_SET_TX_POWER_CALIBRATION;
calVal = pBtReq->pParamStart[1];
if ((calVal < 1) || (calVal > 9)) {
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
RTW_INFO("[MPT], calVal=%d\n", calVal);
}
break;
case BT_SET_TRACKING_INTERVAL:
RTW_INFO("[MPT], [BT_SET_TRACKING_INTERVAL] setParaLen =%d\n", setParaLen);
validParaLen = 1;
if (setParaLen == validParaLen)
calVal = pBtReq->pParamStart[1];
break;
case BT_SET_THERMAL_METER:
RTW_INFO("[MPT], [BT_SET_THERMAL_METER] setParaLen =%d\n", setParaLen);
validParaLen = 1;
if (setParaLen == validParaLen)
calVal = pBtReq->pParamStart[1];
break;
case BT_ENABLE_CFO_TRACKING:
RTW_INFO("[MPT], [BT_ENABLE_CFO_TRACKING] setParaLen =%d\n", setParaLen);
validParaLen = 1;
if (setParaLen == validParaLen)
calVal = pBtReq->pParamStart[1];
break;
case BT_GSET_UPDATE_BT_PATCH:
break;
default: {
RTW_INFO("[MPT], Error!! setType=%d, out of range\n", setType);
pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
break;
}
if (setParaLen != validParaLen) {
RTW_INFO("[MPT], Error!! wrong parameter length=%d for BT_SET_GEN_CMD cmd id=0x%x, paraLen should=0x%x\n",
setParaLen, setType, validParaLen);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
/* */
/* execute lower layer opcodes */
/* */
if (BT_GSET_REG == setType) {
/* fill h2c parameters */
/* here we should write reg value first then write the address, adviced by Austin */
btOpcode = BT_LO_OP_WRITE_REG_VALUE;
h2cParaBuf[0] = pBtReq->pParamStart[6];
h2cParaBuf[1] = pBtReq->pParamStart[7];
h2cParaBuf[2] = pBtReq->pParamStart[8];
h2cParaLen = 3;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* write reg address */
btOpcode = BT_LO_OP_WRITE_REG_ADDR;
h2cParaBuf[0] = regType;
h2cParaBuf[1] = pBtReq->pParamStart[2];
h2cParaBuf[2] = pBtReq->pParamStart[3];
h2cParaLen = 3;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
} else if (BT_GSET_RESET == setType) {
btOpcode = BT_LO_OP_RESET;
h2cParaLen = 0;
/* execute h2c and check respond c2h from bt fw is correct or not */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
} else if (BT_GSET_TARGET_BD_ADDR == setType) {
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_L;
h2cParaBuf[0] = pBtReq->pParamStart[1];
h2cParaBuf[1] = pBtReq->pParamStart[2];
h2cParaBuf[2] = pBtReq->pParamStart[3];
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
btOpcode = BT_LO_OP_SET_TARGET_BD_ADDR_H;
h2cParaBuf[0] = pBtReq->pParamStart[4];
h2cParaBuf[1] = pBtReq->pParamStart[5];
h2cParaBuf[2] = pBtReq->pParamStart[6];
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
} else if (BT_GSET_TX_PWR_FINETUNE == setType) {
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_TX_POWER_CALIBRATION;
h2cParaBuf[0] = calVal;
h2cParaLen = 1;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
} else if (BT_SET_TRACKING_INTERVAL == setType) {
/* BT_LO_OP_SET_TRACKING_INTERVAL = 0x22, */
/* BT_LO_OP_SET_THERMAL_METER = 0x23, */
/* BT_LO_OP_ENABLE_CFO_TRACKING = 0x24, */
btOpcode = BT_LO_OP_SET_TRACKING_INTERVAL;
h2cParaBuf[0] = calVal;
h2cParaLen = 1;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
} else if (BT_SET_THERMAL_METER == setType) {
btOpcode = BT_LO_OP_SET_THERMAL_METER;
h2cParaBuf[0] = calVal;
h2cParaLen = 1;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
} else if (BT_ENABLE_CFO_TRACKING == setType) {
btOpcode = BT_LO_OP_ENABLE_CFO_TRACKING;
h2cParaBuf[0] = calVal;
h2cParaLen = 1;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
}
pBtRsp->status = BT_STATUS_SUCCESS;
return paraLen;
}
u16
mptbt_BtSetTxRxPars(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode;
u8 btOpcodeVer = 0;
PBT_TXRX_PARAMETERS pTxRxPars = (PBT_TXRX_PARAMETERS)&pBtReq->pParamStart[0];
u16 lenTxRx = sizeof(BT_TXRX_PARAMETERS);
u8 i;
u8 bdAddr[6] = {0};
/* */
/* check upper layer parameters */
/* */
/* 1. check upper layer opcode version */
if (pBtReq->opCodeVer != 1) {
RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
return paraLen;
}
/* 2. check upper layer parameter length */
if (pBtReq->paraLength == sizeof(BT_TXRX_PARAMETERS)) {
RTW_INFO("[MPT], pTxRxPars->txrxChannel=0x%x\n", pTxRxPars->txrxChannel);
RTW_INFO("[MPT], pTxRxPars->txrxTxPktCnt=0x%8x\n", pTxRxPars->txrxTxPktCnt);
RTW_INFO("[MPT], pTxRxPars->txrxTxPktInterval=0x%x\n", pTxRxPars->txrxTxPktInterval);
RTW_INFO("[MPT], pTxRxPars->txrxPayloadType=0x%x\n", pTxRxPars->txrxPayloadType);
RTW_INFO("[MPT], pTxRxPars->txrxPktType=0x%x\n", pTxRxPars->txrxPktType);
RTW_INFO("[MPT], pTxRxPars->txrxPayloadLen=0x%x\n", pTxRxPars->txrxPayloadLen);
RTW_INFO("[MPT], pTxRxPars->txrxPktHeader=0x%x\n", pTxRxPars->txrxPktHeader);
RTW_INFO("[MPT], pTxRxPars->txrxWhitenCoeff=0x%x\n", pTxRxPars->txrxWhitenCoeff);
bdAddr[0] = pTxRxPars->txrxBdaddr[5];
bdAddr[1] = pTxRxPars->txrxBdaddr[4];
bdAddr[2] = pTxRxPars->txrxBdaddr[3];
bdAddr[3] = pTxRxPars->txrxBdaddr[2];
bdAddr[4] = pTxRxPars->txrxBdaddr[1];
bdAddr[5] = pTxRxPars->txrxBdaddr[0];
RTW_INFO("[MPT], pTxRxPars->txrxBdaddr: %s", &bdAddr[0]);
RTW_INFO("[MPT], pTxRxPars->txrxTxGainIndex=0x%x\n", pTxRxPars->txrxTxGainIndex);
} else {
RTW_INFO("[MPT], Error!! pBtReq->paraLength=%d, correct Len=%d\n", pBtReq->paraLength, lenTxRx);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
/* */
/* execute lower layer opcodes */
/* */
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_PKT_HEADER;
if (pTxRxPars->txrxPktHeader > 0x3ffff) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxPktHeader=0x%x is out of range, (should be between 0x0~0x3ffff)\n", pTxRxPars->txrxPktHeader);
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
h2cParaBuf[0] = (u8)(pTxRxPars->txrxPktHeader & 0xff);
h2cParaBuf[1] = (u8)((pTxRxPars->txrxPktHeader & 0xff00) >> 8);
h2cParaBuf[2] = (u8)((pTxRxPars->txrxPktHeader & 0xff0000) >> 16);
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_PKT_TYPE_LEN;
{
u16 payloadLenLimit = 0;
switch (pTxRxPars->txrxPktType) {
case MP_BT_PKT_DH1:
payloadLenLimit = 27 * 8;
break;
case MP_BT_PKT_DH3:
payloadLenLimit = 183 * 8;
break;
case MP_BT_PKT_DH5:
payloadLenLimit = 339 * 8;
break;
case MP_BT_PKT_2DH1:
payloadLenLimit = 54 * 8;
break;
case MP_BT_PKT_2DH3:
payloadLenLimit = 367 * 8;
break;
case MP_BT_PKT_2DH5:
payloadLenLimit = 679 * 8;
break;
case MP_BT_PKT_3DH1:
payloadLenLimit = 83 * 8;
break;
case MP_BT_PKT_3DH3:
payloadLenLimit = 552 * 8;
break;
case MP_BT_PKT_3DH5:
payloadLenLimit = 1021 * 8;
break;
case MP_BT_PKT_LE:
payloadLenLimit = 39 * 8;
break;
default: {
RTW_INFO("[MPT], Error!! Unknown pTxRxPars->txrxPktType=0x%x\n", pTxRxPars->txrxPktType);
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
break;
}
if (pTxRxPars->txrxPayloadLen > payloadLenLimit) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxPayloadLen=0x%x, (should smaller than %d)\n",
pTxRxPars->txrxPayloadLen, payloadLenLimit);
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
h2cParaBuf[0] = pTxRxPars->txrxPktType;
h2cParaBuf[1] = (u8)((pTxRxPars->txrxPayloadLen & 0xff));
h2cParaBuf[2] = (u8)((pTxRxPars->txrxPayloadLen & 0xff00) >> 8);
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_PKT_CNT_L_PL_TYPE;
if (pTxRxPars->txrxPayloadType > MP_BT_PAYLOAD_MAX) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxPayloadType=0x%x, (should be between 0~4)\n", pTxRxPars->txrxPayloadType);
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
h2cParaBuf[0] = (u8)((pTxRxPars->txrxTxPktCnt & 0xff));
h2cParaBuf[1] = (u8)((pTxRxPars->txrxTxPktCnt & 0xff00) >> 8);
h2cParaBuf[2] = pTxRxPars->txrxPayloadType;
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_PKT_CNT_H_PKT_INTV;
if (pTxRxPars->txrxTxPktInterval > 15) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxTxPktInterval=0x%x, (should be between 0~15)\n", pTxRxPars->txrxTxPktInterval);
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
h2cParaBuf[0] = (u8)((pTxRxPars->txrxTxPktCnt & 0xff0000) >> 16);
h2cParaBuf[1] = (u8)((pTxRxPars->txrxTxPktCnt & 0xff000000) >> 24);
h2cParaBuf[2] = pTxRxPars->txrxTxPktInterval;
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_WHITENCOEFF;
{
h2cParaBuf[0] = pTxRxPars->txrxWhitenCoeff;
h2cParaLen = 1;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_CHNL_TX_GAIN;
if ((pTxRxPars->txrxChannel > 78) ||
(pTxRxPars->txrxTxGainIndex > 7)) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxChannel=0x%x, (should be between 0~78)\n", pTxRxPars->txrxChannel);
RTW_INFO("[MPT], Error!! pTxRxPars->txrxTxGainIndex=0x%x, (should be between 0~7)\n", pTxRxPars->txrxTxGainIndex);
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
h2cParaBuf[0] = pTxRxPars->txrxChannel;
h2cParaBuf[1] = pTxRxPars->txrxTxGainIndex;
h2cParaLen = 2;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
/* fill h2c parameters */
btOpcode = BT_LO_OP_SET_BD_ADDR_L;
if ((pTxRxPars->txrxBdaddr[0] == 0) &&
(pTxRxPars->txrxBdaddr[1] == 0) &&
(pTxRxPars->txrxBdaddr[2] == 0) &&
(pTxRxPars->txrxBdaddr[3] == 0) &&
(pTxRxPars->txrxBdaddr[4] == 0) &&
(pTxRxPars->txrxBdaddr[5] == 0)) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxBdaddr=all zero\n");
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
if ((pTxRxPars->txrxBdaddr[0] == 0xff) &&
(pTxRxPars->txrxBdaddr[1] == 0xff) &&
(pTxRxPars->txrxBdaddr[2] == 0xff) &&
(pTxRxPars->txrxBdaddr[3] == 0xff) &&
(pTxRxPars->txrxBdaddr[4] == 0xff) &&
(pTxRxPars->txrxBdaddr[5] == 0xff)) {
RTW_INFO("[MPT], Error!! pTxRxPars->txrxBdaddr=all 0xf\n");
pBtRsp->status = (btOpcode << 8) | BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
}
{
h2cParaBuf[0] = pTxRxPars->txrxBdaddr[0];
h2cParaBuf[1] = pTxRxPars->txrxBdaddr[1];
h2cParaBuf[2] = pTxRxPars->txrxBdaddr[2];
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
btOpcode = BT_LO_OP_SET_BD_ADDR_H;
{
h2cParaBuf[0] = pTxRxPars->txrxBdaddr[3];
h2cParaBuf[1] = pTxRxPars->txrxBdaddr[4];
h2cParaBuf[2] = pTxRxPars->txrxBdaddr[5];
h2cParaLen = 3;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* ckeck bt return status. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->status = BT_STATUS_SUCCESS;
return paraLen;
}
u16
mptbt_BtTestCtrl(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode;
u8 btOpcodeVer = 0;
u8 testCtrl = 0;
/* */
/* check upper layer parameters */
/* */
/* 1. check upper layer opcode version */
if (pBtReq->opCodeVer != 1) {
RTW_INFO("[MPT], Error!! Upper OP code version not match!!!\n");
pBtRsp->status = BT_STATUS_OPCODE_U_VERSION_MISMATCH;
return paraLen;
}
/* 2. check upper layer parameter length */
if (1 == pBtReq->paraLength) {
testCtrl = pBtReq->pParamStart[0];
RTW_INFO("[MPT], testCtrl=%d\n", testCtrl);
} else {
RTW_INFO("[MPT], Error!! wrong parameter length=%d (should be 1)\n", pBtReq->paraLength);
pBtRsp->status = BT_STATUS_PARAMETER_FORMAT_ERROR_U;
return paraLen;
}
/* */
/* execute lower layer opcodes */
/* */
/* 1. fill h2c parameters */
/* check bt mode */
btOpcode = BT_LO_OP_TEST_CTRL;
if (testCtrl >= MP_BT_TEST_MAX) {
RTW_INFO("[MPT], Error!! testCtrl=0x%x, (should be between smaller or equal to 0x%x)\n",
testCtrl, MP_BT_TEST_MAX - 1);
pBtRsp->status = BT_STATUS_PARAMETER_OUT_OF_RANGE_U;
return paraLen;
} else {
h2cParaBuf[0] = testCtrl;
h2cParaLen = 1;
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen);
}
/* 3. construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->status = BT_STATUS_SUCCESS;
return paraLen;
}
u16
mptbt_TestBT(
PADAPTER Adapter,
PBT_REQ_CMD pBtReq,
PBT_RSP_CMD pBtRsp
)
{
u8 h2cParaBuf[6] = {0};
u8 h2cParaLen = 0;
u16 paraLen = 0;
u8 retStatus = BT_STATUS_BT_OP_SUCCESS;
u8 btOpcode;
u8 btOpcodeVer = 0;
u8 testCtrl = 0;
/* 1. fill h2c parameters */
btOpcode = 0x11;
h2cParaBuf[0] = 0x11;
h2cParaBuf[1] = 0x0;
h2cParaBuf[2] = 0x0;
h2cParaBuf[3] = 0x0;
h2cParaBuf[4] = 0x0;
h2cParaLen = 1;
/* retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, &h2cParaBuf[0], h2cParaLen); */
retStatus = mptbt_BtFwOpCodeProcess(Adapter, btOpcode, btOpcodeVer, h2cParaBuf, h2cParaLen);
/* 3. construct respond status code and data. */
if (BT_STATUS_BT_OP_SUCCESS != retStatus) {
pBtRsp->status = ((btOpcode << 8) | retStatus);
RTW_INFO("[MPT], Error!! status code=0x%x\n", pBtRsp->status);
return paraLen;
}
pBtRsp->status = BT_STATUS_SUCCESS;
return paraLen;
}
void
mptbt_BtControlProcess(
PADAPTER Adapter,
void *pInBuf
)
{
u8 H2C_Parameter[6] = {0};
PBT_H2C pH2c = (PBT_H2C)&H2C_Parameter[0];
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
PBT_REQ_CMD pBtReq = (PBT_REQ_CMD)pInBuf;
PBT_RSP_CMD pBtRsp;
u8 i;
RTW_INFO("[MPT], mptbt_BtControlProcess()=========>\n");
RTW_INFO("[MPT], input opCodeVer=%d\n", pBtReq->opCodeVer);
RTW_INFO("[MPT], input OpCode=%d\n", pBtReq->OpCode);
RTW_INFO("[MPT], paraLength=%d\n", pBtReq->paraLength);
if (pBtReq->paraLength) {
/* RTW_INFO("[MPT], parameters(hex):0x%x %d\n",&pBtReq->pParamStart[0], pBtReq->paraLength); */
}
_rtw_memset((void *)pMptCtx->mptOutBuf, 0, 100);
pMptCtx->mptOutLen = 4; /* length of (BT_RSP_CMD.status+BT_RSP_CMD.paraLength) */
pBtRsp = (PBT_RSP_CMD)pMptCtx->mptOutBuf;
pBtRsp->status = BT_STATUS_SUCCESS;
pBtRsp->paraLength = 0x0;
/* The following we should maintain the User OP codes sent by upper layer */
switch (pBtReq->OpCode) {
case BT_UP_OP_BT_READY:
RTW_INFO("[MPT], OPcode : [BT_READY]\n");
pBtRsp->paraLength = mptbt_BtReady(Adapter, pBtReq, pBtRsp);
break;
case BT_UP_OP_BT_SET_MODE:
RTW_INFO("[MPT], OPcode : [BT_SET_MODE]\n");
pBtRsp->paraLength = mptbt_BtSetMode(Adapter, pBtReq, pBtRsp);
break;
case BT_UP_OP_BT_SET_TX_RX_PARAMETER:
RTW_INFO("[MPT], OPcode : [BT_SET_TXRX_PARAMETER]\n");
pBtRsp->paraLength = mptbt_BtSetTxRxPars(Adapter, pBtReq, pBtRsp);
break;
case BT_UP_OP_BT_SET_GENERAL:
RTW_INFO("[MPT], OPcode : [BT_SET_GENERAL]\n");
pBtRsp->paraLength = mptbt_BtSetGeneral(Adapter, pBtReq, pBtRsp);
break;
case BT_UP_OP_BT_GET_GENERAL:
RTW_INFO("[MPT], OPcode : [BT_GET_GENERAL]\n");
pBtRsp->paraLength = mptbt_BtGetGeneral(Adapter, pBtReq, pBtRsp);
break;
case BT_UP_OP_BT_TEST_CTRL:
RTW_INFO("[MPT], OPcode : [BT_TEST_CTRL]\n");
pBtRsp->paraLength = mptbt_BtTestCtrl(Adapter, pBtReq, pBtRsp);
break;
case BT_UP_OP_TEST_BT:
RTW_INFO("[MPT], OPcode : [TEST_BT]\n");
pBtRsp->paraLength = mptbt_TestBT(Adapter, pBtReq, pBtRsp);
break;
default:
RTW_INFO("[MPT], Error!! OPcode : UNDEFINED!!!!\n");
pBtRsp->status = BT_STATUS_UNKNOWN_OPCODE_U;
pBtRsp->paraLength = 0x0;
break;
}
pMptCtx->mptOutLen += pBtRsp->paraLength;
RTW_INFO("[MPT], pMptCtx->mptOutLen=%d, pBtRsp->paraLength=%d\n", pMptCtx->mptOutLen, pBtRsp->paraLength);
RTW_INFO("[MPT], mptbt_BtControlProcess()<=========\n");
}
#endif
================================================
FILE: core/rtw_btcoex.c
================================================
/******************************************************************************
*
* Copyright(c) 2013 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#ifdef CONFIG_BT_COEXIST
#include
void rtw_btcoex_Initialize(PADAPTER padapter)
{
hal_btcoex_Initialize(padapter);
}
void rtw_btcoex_PowerOnSetting(PADAPTER padapter)
{
hal_btcoex_PowerOnSetting(padapter);
}
void rtw_btcoex_AntInfoSetting(PADAPTER padapter)
{
hal_btcoex_AntInfoSetting(padapter);
}
void rtw_btcoex_PowerOffSetting(PADAPTER padapter)
{
hal_btcoex_PowerOffSetting(padapter);
}
void rtw_btcoex_PreLoadFirmware(PADAPTER padapter)
{
hal_btcoex_PreLoadFirmware(padapter);
}
void rtw_btcoex_HAL_Initialize(PADAPTER padapter, u8 bWifiOnly)
{
hal_btcoex_InitHwConfig(padapter, bWifiOnly);
}
void rtw_btcoex_IpsNotify(PADAPTER padapter, u8 type)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_IpsNotify(padapter, type);
}
void rtw_btcoex_LpsNotify(PADAPTER padapter, u8 type)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_LpsNotify(padapter, type);
}
void rtw_btcoex_ScanNotify(PADAPTER padapter, u8 type)
{
PHAL_DATA_TYPE pHalData;
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
struct bt_coex_info *pcoex_info = &padapter->coex_info;
PBT_MGNT pBtMgnt = &pcoex_info->BtMgnt;
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
if (_FALSE == type) {
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(padapter, WIFI_SITE_MONITOR))
return;
#endif
if (DEV_MGMT_TX_NUM(adapter_to_dvobj(padapter))
|| DEV_ROCH_NUM(adapter_to_dvobj(padapter)))
return;
}
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
if (pBtMgnt->ExtConfig.bEnableWifiScanNotify)
rtw_btcoex_SendScanNotify(padapter, type);
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
hal_btcoex_ScanNotify(padapter, type);
}
void rtw_btcoex_ConnectNotify(PADAPTER padapter, u8 action)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
#ifdef DBG_CONFIG_ERROR_RESET
if (_TRUE == rtw_hal_sreset_inprogress(padapter)) {
RTW_INFO(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
FUNC_ADPT_ARG(padapter));
return;
}
#endif /* DBG_CONFIG_ERROR_RESET */
#ifdef CONFIG_CONCURRENT_MODE
if (_FALSE == action) {
if (rtw_mi_buddy_check_fwstate(padapter, WIFI_UNDER_LINKING))
return;
}
#endif
hal_btcoex_ConnectNotify(padapter, action);
}
void rtw_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
#ifdef DBG_CONFIG_ERROR_RESET
if (_TRUE == rtw_hal_sreset_inprogress(padapter)) {
RTW_INFO(FUNC_ADPT_FMT ": [BTCoex] under reset, skip notify!\n",
FUNC_ADPT_ARG(padapter));
return;
}
#endif /* DBG_CONFIG_ERROR_RESET */
#ifdef CONFIG_CONCURRENT_MODE
if (RT_MEDIA_DISCONNECT == mediaStatus) {
if (rtw_mi_buddy_check_fwstate(padapter, WIFI_ASOC_STATE))
return;
}
#endif /* CONFIG_CONCURRENT_MODE */
if ((RT_MEDIA_CONNECT == mediaStatus)
&& (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE))
rtw_hal_set_hwreg(padapter, HW_VAR_DL_RSVD_PAGE, NULL);
hal_btcoex_MediaStatusNotify(padapter, mediaStatus);
}
void rtw_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_SpecialPacketNotify(padapter, pktType);
}
void rtw_btcoex_IQKNotify(PADAPTER padapter, u8 state)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_IQKNotify(padapter, state);
}
void rtw_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_BtInfoNotify(padapter, length, tmpBuf);
}
void rtw_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
if (padapter->registrypriv.mp_mode == 1)
return;
hal_btcoex_BtMpRptNotify(padapter, length, tmpBuf);
}
void rtw_btcoex_SuspendNotify(PADAPTER padapter, u8 state)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_SuspendNotify(padapter, state);
}
void rtw_btcoex_HaltNotify(PADAPTER padapter)
{
PHAL_DATA_TYPE pHalData;
u8 do_halt = 1;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
do_halt = 0;
if (_FALSE == padapter->bup) {
RTW_INFO(FUNC_ADPT_FMT ": bup=%d Skip!\n",
FUNC_ADPT_ARG(padapter), padapter->bup);
do_halt = 0;
}
if (rtw_is_surprise_removed(padapter)) {
RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=%s Skip!\n",
FUNC_ADPT_ARG(padapter), rtw_is_surprise_removed(padapter) ? "True" : "False");
do_halt = 0;
}
hal_btcoex_HaltNotify(padapter, do_halt);
}
void rtw_btcoex_switchband_notify(u8 under_scan, u8 band_type)
{
hal_btcoex_switchband_notify(under_scan, band_type);
}
void rtw_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length)
{
hal_btcoex_WlFwDbgInfoNotify(padapter, tmpBuf, length);
}
void rtw_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id)
{
hal_btcoex_rx_rate_change_notify(padapter, is_data_frame, rate_id);
}
void rtw_btcoex_SwitchBtTRxMask(PADAPTER padapter)
{
hal_btcoex_SwitchBtTRxMask(padapter);
}
void rtw_btcoex_Switch(PADAPTER padapter, u8 enable)
{
hal_btcoex_SetBTCoexist(padapter, enable);
}
u8 rtw_btcoex_IsBtDisabled(PADAPTER padapter)
{
return hal_btcoex_IsBtDisabled(padapter);
}
void rtw_btcoex_Handler(PADAPTER padapter)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
if (_FALSE == pHalData->EEPROMBluetoothCoexist)
return;
hal_btcoex_Hanlder(padapter);
}
s32 rtw_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter)
{
s32 coexctrl;
coexctrl = hal_btcoex_IsBTCoexRejectAMPDU(padapter);
return coexctrl;
}
s32 rtw_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter)
{
s32 coexctrl;
coexctrl = hal_btcoex_IsBTCoexCtrlAMPDUSize(padapter);
return coexctrl;
}
u32 rtw_btcoex_GetAMPDUSize(PADAPTER padapter)
{
u32 size;
size = hal_btcoex_GetAMPDUSize(padapter);
return size;
}
void rtw_btcoex_SetManualControl(PADAPTER padapter, u8 manual)
{
if (_TRUE == manual)
hal_btcoex_SetManualControl(padapter, _TRUE);
else
hal_btcoex_SetManualControl(padapter, _FALSE);
}
u8 rtw_btcoex_1Ant(PADAPTER padapter)
{
return hal_btcoex_1Ant(padapter);
}
u8 rtw_btcoex_IsBtControlLps(PADAPTER padapter)
{
return hal_btcoex_IsBtControlLps(padapter);
}
u8 rtw_btcoex_IsLpsOn(PADAPTER padapter)
{
return hal_btcoex_IsLpsOn(padapter);
}
u8 rtw_btcoex_RpwmVal(PADAPTER padapter)
{
return hal_btcoex_RpwmVal(padapter);
}
u8 rtw_btcoex_LpsVal(PADAPTER padapter)
{
return hal_btcoex_LpsVal(padapter);
}
u32 rtw_btcoex_GetRaMask(PADAPTER padapter)
{
return hal_btcoex_GetRaMask(padapter);
}
u8 rtw_btcoex_query_reduced_wl_pwr_lvl(PADAPTER padapter)
{
return hal_btcoex_query_reduced_wl_pwr_lvl(padapter);
}
void rtw_btcoex_set_reduced_wl_pwr_lvl(PADAPTER padapter, u8 val)
{
hal_btcoex_set_reduced_wl_pwr_lvl(padapter, val);
}
void rtw_btcoex_do_reduce_wl_pwr_lvl(PADAPTER padapter)
{
hal_btcoex_do_reduce_wl_pwr_lvl(padapter);
}
void rtw_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen)
{
hal_btcoex_RecordPwrMode(padapter, pCmdBuf, cmdLen);
}
void rtw_btcoex_DisplayBtCoexInfo(PADAPTER padapter, u8 *pbuf, u32 bufsize)
{
hal_btcoex_DisplayBtCoexInfo(padapter, pbuf, bufsize);
}
void rtw_btcoex_SetDBG(PADAPTER padapter, u32 *pDbgModule)
{
hal_btcoex_SetDBG(padapter, pDbgModule);
}
u32 rtw_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
{
return hal_btcoex_GetDBG(padapter, pStrBuf, bufSize);
}
u8 rtw_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)
{
return hal_btcoex_IncreaseScanDeviceNum(padapter);
}
u8 rtw_btcoex_IsBtLinkExist(PADAPTER padapter)
{
return hal_btcoex_IsBtLinkExist(padapter);
}
void rtw_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer)
{
hal_btcoex_SetBtPatchVersion(padapter, btHciVer, btPatchVer);
}
void rtw_btcoex_SetHciVersion(PADAPTER padapter, u16 hciVersion)
{
hal_btcoex_SetHciVersion(padapter, hciVersion);
}
void rtw_btcoex_StackUpdateProfileInfo(void)
{
hal_btcoex_StackUpdateProfileInfo();
}
void rtw_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON)
{
hal_btcoex_pta_off_on_notify(padapter, bBTON);
}
#ifdef CONFIG_RF4CE_COEXIST
void rtw_btcoex_SetRf4ceLinkState(PADAPTER padapter, u8 state)
{
hal_btcoex_set_rf4ce_link_state(state);
}
u8 rtw_btcoex_GetRf4ceLinkState(PADAPTER padapter)
{
return hal_btcoex_get_rf4ce_link_state();
}
#endif
/* ==================================================
* Below Functions are called by BT-Coex
* ================================================== */
void rtw_btcoex_rx_ampdu_apply(PADAPTER padapter)
{
rtw_rx_ampdu_apply(padapter);
}
void rtw_btcoex_LPS_Enter(PADAPTER padapter)
{
struct pwrctrl_priv *pwrpriv;
u8 lpsVal;
pwrpriv = adapter_to_pwrctl(padapter);
pwrpriv->bpower_saving = _TRUE;
lpsVal = rtw_btcoex_LpsVal(padapter);
rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, lpsVal, "BTCOEX");
}
u8 rtw_btcoex_LPS_Leave(PADAPTER padapter)
{
struct pwrctrl_priv *pwrpriv;
pwrpriv = adapter_to_pwrctl(padapter);
if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "BTCOEX");
pwrpriv->bpower_saving = _FALSE;
}
return _TRUE;
}
u16 rtw_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)
{
return hal_btcoex_btreg_read(padapter, type, addr, data);
}
u16 rtw_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val)
{
return hal_btcoex_btreg_write(padapter, type, addr, val);
}
u16 rtw_btcoex_btset_testmode(PADAPTER padapter, u8 type)
{
return hal_btcoex_btset_testode(padapter, type);
}
u8 rtw_btcoex_get_reduce_wl_txpwr(PADAPTER padapter)
{
return rtw_btcoex_query_reduced_wl_pwr_lvl(padapter);
}
u8 rtw_btcoex_get_bt_coexist(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
return pHalData->EEPROMBluetoothCoexist;
}
u8 rtw_btcoex_get_chip_type(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
return pHalData->EEPROMBluetoothType;
}
u8 rtw_btcoex_get_pg_ant_num(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
return pHalData->EEPROMBluetoothAntNum == Ant_x2 ? 2 : 1;
}
u8 rtw_btcoex_get_pg_single_ant_path(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
return pHalData->ant_path;
}
u8 rtw_btcoex_get_pg_rfe_type(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
return pHalData->rfe_type;
}
u8 rtw_btcoex_is_tfbga_package_type(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
#ifdef CONFIG_RTL8723B
if ((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA80)
|| (pHalData->PackageType == PACKAGE_TFBGA90))
return _TRUE;
#endif
return _FALSE;
}
u8 rtw_btcoex_get_ant_div_cfg(PADAPTER padapter)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
return (pHalData->AntDivCfg == 0) ? _FALSE : _TRUE;
}
/* ==================================================
* Below Functions are BT-Coex socket related function
* ================================================== */
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
_adapter *pbtcoexadapter; /* = NULL; */ /* do not initialise globals to 0 or NULL */
u8 rtw_btcoex_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
u8 *btinfo;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
btinfo = rtw_zmalloc(len);
if (btinfo == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = BTINFO_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = len;
pdrvextra_cmd_parm->pbuf = btinfo;
_rtw_memcpy(btinfo, buf, len);
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_btcoex_send_event_to_BT(_adapter *padapter, u8 status, u8 event_code, u8 opcode_low, u8 opcode_high, u8 *dbg_msg)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = event_code;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = opcode_low;
pEvent->Data[2] = opcode_high;
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
#if 0
rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, dbg_msg);
#endif
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
}
/*
Ref:
Realtek Wi-Fi Driver
Host Controller Interface for
Bluetooth 3.0 + HS V1.4 2013/02/07
Window team code & BT team code
*/
u8 rtw_btcoex_parse_BT_info_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
#define BT_INFO_LENGTH 8
u8 curPollEnable = pcmd[0];
u8 curPollTime = pcmd[1];
u8 btInfoReason = pcmd[2];
u8 btInfoLen = pcmd[3];
u8 btinfo[BT_INFO_LENGTH];
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
rtw_HCI_event *pEvent;
/* RTW_INFO("%s\n",__func__);
RTW_INFO("current Poll Enable: %d, currrent Poll Time: %d\n",curPollEnable,curPollTime);
RTW_INFO("BT Info reason: %d, BT Info length: %d\n",btInfoReason,btInfoLen);
RTW_INFO("%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x\n"
,pcmd[4],pcmd[5],pcmd[6],pcmd[7],pcmd[8],pcmd[9],pcmd[10],pcmd[11]);*/
_rtw_memset(btinfo, 0, BT_INFO_LENGTH);
#if 1
if (BT_INFO_LENGTH != btInfoLen) {
status = HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE;
RTW_INFO("Error BT Info Length: %d\n", btInfoLen);
/* return _FAIL; */
} else
#endif
{
if (0x1 == btInfoReason || 0x2 == btInfoReason) {
_rtw_memcpy(btinfo, &pcmd[4], btInfoLen);
btinfo[0] = btInfoReason;
rtw_btcoex_btinfo_cmd(padapter, btinfo, btInfoLen);
} else
RTW_INFO("Other BT info reason\n");
}
/* send complete event to BT */
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_INFO_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_INFO_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
#if 0
rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT_info_event");
#endif
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_BT_patch_ver_info_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
u16 btPatchVer = 0x0, btHciVer = 0x0;
/* u16 *pU2tmp; */
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
btHciVer = pcmd[0] | pcmd[1] << 8;
btPatchVer = pcmd[2] | pcmd[3] << 8;
RTW_INFO("%s, cmd:%02x %02x %02x %02x\n", __func__, pcmd[0] , pcmd[1] , pcmd[2] , pcmd[3]);
RTW_INFO("%s, HCI Ver:%d, Patch Ver:%d\n", __func__, btHciVer, btPatchVer);
rtw_btcoex_SetBtPatchVersion(padapter, btHciVer, btPatchVer);
/* send complete event to BT */
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_PATCH_VERSION_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_PATCH_VERSION_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
#if 0
rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT_patch_event");
#endif
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_HCI_Ver_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
u16 hciver = pcmd[0] | pcmd[1] << 8;
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
PBT_MGNT pBtMgnt = &pcoex_info->BtMgnt;
pBtMgnt->ExtConfig.HCIExtensionVer = hciver;
RTW_INFO("%s, HCI Version: %d\n", __func__, pBtMgnt->ExtConfig.HCIExtensionVer);
if (pBtMgnt->ExtConfig.HCIExtensionVer < 4) {
status = HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE;
RTW_INFO("%s, Version = %d, HCI Version < 4\n", __func__, pBtMgnt->ExtConfig.HCIExtensionVer);
} else
rtw_btcoex_SetHciVersion(padapter, hciver);
/* send complete event to BT */
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_EXTENSION_VERSION_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_EXTENSION_VERSION_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_WIFI_scan_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
PBT_MGNT pBtMgnt = &pcoex_info->BtMgnt;
pBtMgnt->ExtConfig.bEnableWifiScanNotify = pcmd[0];
RTW_INFO("%s, bEnableWifiScanNotify: %d\n", __func__, pBtMgnt->ExtConfig.bEnableWifiScanNotify);
/* send complete event to BT */
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_ENABLE_WIFI_SCAN_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_ENABLE_WIFI_SCAN_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_HCI_link_status_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
PBT_MGNT pBtMgnt = &pcoex_info->BtMgnt;
/* PBT_DBG pBtDbg=&padapter->MgntInfo.BtInfo.BtDbg; */
u8 i, numOfHandle = 0, numOfAcl = 0;
u16 conHandle;
u8 btProfile, btCoreSpec, linkRole;
u8 *pTriple;
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
/* pBtDbg->dbgHciInfo.hciCmdCntLinkStatusNotify++; */
/* RT_DISP_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "LinkStatusNotify, Hex Data :\n", */
/* &pHciCmd->Data[0], pHciCmd->Length); */
RTW_INFO("BTLinkStatusNotify\n");
/* Current only RTL8723 support this command. */
/* pBtMgnt->bSupportProfile = TRUE; */
pBtMgnt->bSupportProfile = _FALSE;
pBtMgnt->ExtConfig.NumberOfACL = 0;
pBtMgnt->ExtConfig.NumberOfSCO = 0;
numOfHandle = pcmd[0];
/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, ("numOfHandle = 0x%x\n", numOfHandle)); */
/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer)); */
RTW_INFO("numOfHandle = 0x%x\n", numOfHandle);
RTW_INFO("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer);
pTriple = &pcmd[1];
for (i = 0; i < numOfHandle; i++) {
if (pBtMgnt->ExtConfig.HCIExtensionVer < 1) {
conHandle = *((u8 *)&pTriple[0]);
btProfile = pTriple[2];
btCoreSpec = pTriple[3];
if (BT_PROFILE_SCO == btProfile)
pBtMgnt->ExtConfig.NumberOfSCO++;
else {
pBtMgnt->ExtConfig.NumberOfACL++;
pBtMgnt->ExtConfig.aclLink[i].ConnectHandle = conHandle;
pBtMgnt->ExtConfig.aclLink[i].BTProfile = btProfile;
pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec = btCoreSpec;
}
/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, */
/* ("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d\n", */
/* conHandle, btProfile, btCoreSpec)); */
RTW_INFO("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d\n", conHandle, btProfile, btCoreSpec);
pTriple += 4;
} else if (pBtMgnt->ExtConfig.HCIExtensionVer >= 1) {
conHandle = *((u16 *)&pTriple[0]);
btProfile = pTriple[2];
btCoreSpec = pTriple[3];
linkRole = pTriple[4];
if (BT_PROFILE_SCO == btProfile)
pBtMgnt->ExtConfig.NumberOfSCO++;
else {
pBtMgnt->ExtConfig.NumberOfACL++;
pBtMgnt->ExtConfig.aclLink[i].ConnectHandle = conHandle;
pBtMgnt->ExtConfig.aclLink[i].BTProfile = btProfile;
pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec = btCoreSpec;
pBtMgnt->ExtConfig.aclLink[i].linkRole = linkRole;
}
/* RT_DISP(FIOCTL, IOCTL_BT_HCICMD_EXT, */
RTW_INFO("Connection_Handle=0x%x, BTProfile=%d, BTSpec=%d, LinkRole=%d\n",
conHandle, btProfile, btCoreSpec, linkRole);
pTriple += 5;
}
}
rtw_btcoex_StackUpdateProfileInfo();
/* send complete event to BT */
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_LINK_STATUS_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_LINK_STATUS_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_HCI_BT_coex_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_COEX_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_COEX_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_HCI_BT_operation_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
RTW_INFO("%s, OP code: %d\n", __func__, pcmd[0]);
switch (pcmd[0]) {
case HCI_BT_OP_NONE:
RTW_INFO("[bt operation] : Operation None!!\n");
break;
case HCI_BT_OP_INQUIRY_START:
RTW_INFO("[bt operation] : Inquiry start!!\n");
break;
case HCI_BT_OP_INQUIRY_FINISH:
RTW_INFO("[bt operation] : Inquiry finished!!\n");
break;
case HCI_BT_OP_PAGING_START:
RTW_INFO("[bt operation] : Paging is started!!\n");
break;
case HCI_BT_OP_PAGING_SUCCESS:
RTW_INFO("[bt operation] : Paging complete successfully!!\n");
break;
case HCI_BT_OP_PAGING_UNSUCCESS:
RTW_INFO("[bt operation] : Paging complete unsuccessfully!!\n");
break;
case HCI_BT_OP_PAIRING_START:
RTW_INFO("[bt operation] : Pairing start!!\n");
break;
case HCI_BT_OP_PAIRING_FINISH:
RTW_INFO("[bt operation] : Pairing finished!!\n");
break;
case HCI_BT_OP_BT_DEV_ENABLE:
RTW_INFO("[bt operation] : BT Device is enabled!!\n");
break;
case HCI_BT_OP_BT_DEV_DISABLE:
RTW_INFO("[bt operation] : BT Device is disabled!!\n");
break;
default:
RTW_INFO("[bt operation] : Unknown, error!!\n");
break;
}
/* send complete event to BT */
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_OPERATION_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_OPERATION_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_BT_AFH_MAP_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_AFH_MAP_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_AFH_MAP_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_BT_register_val_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_REGISTER_VALUE_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_REGISTER_VALUE_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_BT_ABNORMAL_NOTIFY, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_BT_ABNORMAL_NOTIFY, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
u8 rtw_btcoex_parse_HCI_query_RF_status_cmd(_adapter *padapter, u8 *pcmd, u16 cmdlen)
{
u8 localBuf[6] = "";
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
rtw_HCI_event *pEvent;
RTW_HCI_STATUS status = HCI_STATUS_SUCCESS;
{
pEvent = (rtw_HCI_event *)(&localBuf[0]);
pEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
pEvent->Data[0] = 0x1; /* packet # */
pEvent->Data[1] = HCIOPCODELOW(HCI_QUERY_RF_STATUS, OGF_EXTENSION);
pEvent->Data[2] = HCIOPCODEHIGHT(HCI_QUERY_RF_STATUS, OGF_EXTENSION);
len = len + 3;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
pRetPar[0] = status; /* status */
len++;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
status = rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
return status;
/* bthci_IndicateEvent(Adapter, PPacketIrpEvent, len+2); */
}
}
/*****************************************
* HCI cmd format :
*| 15 - 0 |
*| OPcode (OCF|OGF<<10) |
*| 15 - 8 |7 - 0 |
*|Cmd para |Cmd para Length |
*|Cmd para...... |
******************************************/
/* bit 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
* | OCF | OGF | */
void rtw_btcoex_parse_hci_extend_cmd(_adapter *padapter, u8 *pcmd, u16 len, const u16 hci_OCF)
{
RTW_INFO("%s: OCF: %x\n", __func__, hci_OCF);
switch (hci_OCF) {
case HCI_EXTENSION_VERSION_NOTIFY:
RTW_INFO("HCI_EXTENSION_VERSION_NOTIFY\n");
rtw_btcoex_parse_HCI_Ver_notify_cmd(padapter, pcmd, len);
break;
case HCI_LINK_STATUS_NOTIFY:
RTW_INFO("HCI_LINK_STATUS_NOTIFY\n");
rtw_btcoex_parse_HCI_link_status_notify_cmd(padapter, pcmd, len);
break;
case HCI_BT_OPERATION_NOTIFY:
/* only for 8723a 2ant */
RTW_INFO("HCI_BT_OPERATION_NOTIFY\n");
rtw_btcoex_parse_HCI_BT_operation_notify_cmd(padapter, pcmd, len);
/* */
break;
case HCI_ENABLE_WIFI_SCAN_NOTIFY:
RTW_INFO("HCI_ENABLE_WIFI_SCAN_NOTIFY\n");
rtw_btcoex_parse_WIFI_scan_notify_cmd(padapter, pcmd, len);
break;
case HCI_QUERY_RF_STATUS:
/* only for 8723b 2ant */
RTW_INFO("HCI_QUERY_RF_STATUS\n");
rtw_btcoex_parse_HCI_query_RF_status_cmd(padapter, pcmd, len);
break;
case HCI_BT_ABNORMAL_NOTIFY:
RTW_INFO("HCI_BT_ABNORMAL_NOTIFY\n");
rtw_btcoex_parse_HCI_BT_abnormal_notify_cmd(padapter, pcmd, len);
break;
case HCI_BT_INFO_NOTIFY:
RTW_INFO("HCI_BT_INFO_NOTIFY\n");
rtw_btcoex_parse_BT_info_notify_cmd(padapter, pcmd, len);
break;
case HCI_BT_COEX_NOTIFY:
RTW_INFO("HCI_BT_COEX_NOTIFY\n");
rtw_btcoex_parse_HCI_BT_coex_notify_cmd(padapter, pcmd, len);
break;
case HCI_BT_PATCH_VERSION_NOTIFY:
RTW_INFO("HCI_BT_PATCH_VERSION_NOTIFY\n");
rtw_btcoex_parse_BT_patch_ver_info_cmd(padapter, pcmd, len);
break;
case HCI_BT_AFH_MAP_NOTIFY:
RTW_INFO("HCI_BT_AFH_MAP_NOTIFY\n");
rtw_btcoex_parse_BT_AFH_MAP_notify_cmd(padapter, pcmd, len);
break;
case HCI_BT_REGISTER_VALUE_NOTIFY:
RTW_INFO("HCI_BT_REGISTER_VALUE_NOTIFY\n");
rtw_btcoex_parse_BT_register_val_notify_cmd(padapter, pcmd, len);
break;
default:
RTW_INFO("ERROR!!! Unknown OCF: %x\n", hci_OCF);
break;
}
}
void rtw_btcoex_parse_hci_cmd(_adapter *padapter, u8 *pcmd, u16 len)
{
u16 opcode = pcmd[0] | pcmd[1] << 8;
u16 hci_OGF = HCI_OGF(opcode);
u16 hci_OCF = HCI_OCF(opcode);
u8 cmdlen = len - 3;
u8 pare_len = pcmd[2];
RTW_INFO("%s OGF: %x,OCF: %x\n", __func__, hci_OGF, hci_OCF);
switch (hci_OGF) {
case OGF_EXTENSION:
RTW_INFO("HCI_EXTENSION_CMD_OGF\n");
rtw_btcoex_parse_hci_extend_cmd(padapter, &pcmd[3], cmdlen, hci_OCF);
break;
default:
RTW_INFO("Other OGF: %x\n", hci_OGF);
break;
}
}
u16 rtw_btcoex_parse_recv_data(u8 *msg, u8 msg_size)
{
u8 cmp_msg1[32] = attend_ack;
u8 cmp_msg2[32] = leave_ack;
u8 cmp_msg3[32] = bt_leave;
u8 cmp_msg4[32] = invite_req;
u8 cmp_msg5[32] = attend_req;
u8 cmp_msg6[32] = invite_rsp;
u8 res = OTHER;
if (_rtw_memcmp(cmp_msg1, msg, msg_size) == _TRUE) {
/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
res = RX_ATTEND_ACK;
} else if (_rtw_memcmp(cmp_msg2, msg, msg_size) == _TRUE) {
/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
res = RX_LEAVE_ACK;
} else if (_rtw_memcmp(cmp_msg3, msg, msg_size) == _TRUE) {
/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
res = RX_BT_LEAVE;
} else if (_rtw_memcmp(cmp_msg4, msg, msg_size) == _TRUE) {
/*RTW_INFO("%s, msg:%s\n",__func__,msg);*/
res = RX_INVITE_REQ;
} else if (_rtw_memcmp(cmp_msg5, msg, msg_size) == _TRUE)
res = RX_ATTEND_REQ;
else if (_rtw_memcmp(cmp_msg6, msg, msg_size) == _TRUE)
res = RX_INVITE_RSP;
else {
/*RTW_INFO("%s, %s\n", __func__, msg);*/
res = OTHER;
}
/*RTW_INFO("%s, res:%d\n", __func__, res);*/
return res;
}
void rtw_btcoex_recvmsgbysocket(void *data)
{
u8 recv_data[255];
u8 tx_msg[255] = leave_ack;
u32 len = 0;
u16 recv_length = 0;
u16 parse_res = 0;
#if 0
u8 para_len = 0, polling_enable = 0, poling_interval = 0, reason = 0, btinfo_len = 0;
u8 btinfo[BT_INFO_LEN] = {0};
#endif
struct bt_coex_info *pcoex_info = NULL;
struct sock *sk = NULL;
struct sk_buff *skb = NULL;
/*RTW_INFO("%s\n",__func__);*/
if (pbtcoexadapter == NULL) {
RTW_INFO("%s: btcoexadapter NULL!\n", __func__);
return;
}
pcoex_info = &pbtcoexadapter->coex_info;
sk = pcoex_info->sk_store;
if (sk == NULL) {
RTW_INFO("%s: critical error when receive socket data!\n", __func__);
return;
}
len = skb_queue_len(&sk->sk_receive_queue);
while (len > 0) {
skb = skb_dequeue(&sk->sk_receive_queue);
/*important: cut the udp header from skb->data! header length is 8 byte*/
recv_length = skb->len - 8;
_rtw_memset(recv_data, 0, sizeof(recv_data));
_rtw_memcpy(recv_data, skb->data + 8, recv_length);
parse_res = rtw_btcoex_parse_recv_data(recv_data, recv_length);
#if 0
if (RX_ATTEND_ACK == parse_res) {
/* attend ack */
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_ATTEND_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
} else if (RX_ATTEND_REQ == parse_res) {
/* attend req from BT */
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_BT_ATTEND_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_sendmsgbysocket(pbtcoexadapter, attend_ack, sizeof(attend_ack), _FALSE);
} else if (RX_INVITE_REQ == parse_res) {
/* invite req from BT */
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_INVITE_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_sendmsgbysocket(pbtcoexadapter, invite_rsp, sizeof(invite_rsp), _FALSE);
} else if (RX_INVITE_RSP == parse_res) {
/* invite rsp */
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_INVITE_RSP!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
} else if (RX_LEAVE_ACK == parse_res) {
/* mean BT know wifi will leave */
pcoex_info->BT_attend = _FALSE;
RTW_INFO("RX_LEAVE_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
} else if (RX_BT_LEAVE == parse_res) {
/* BT leave */
rtw_btcoex_sendmsgbysocket(pbtcoexadapter, leave_ack, sizeof(leave_ack), _FALSE); /* no ack */
pcoex_info->BT_attend = _FALSE;
RTW_INFO("RX_BT_LEAVE!sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
} else {
/* todo: check if recv data are really hci cmds */
if (_TRUE == pcoex_info->BT_attend)
rtw_btcoex_parse_hci_cmd(pbtcoexadapter, recv_data, recv_length);
}
#endif
switch (parse_res) {
case RX_ATTEND_ACK:
/* attend ack */
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_ATTEND_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
break;
case RX_ATTEND_REQ:
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_BT_ATTEND_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_sendmsgbysocket(pbtcoexadapter, attend_ack, sizeof(attend_ack), _FALSE);
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
break;
case RX_INVITE_REQ:
/* invite req from BT */
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_INVITE_REQ!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_sendmsgbysocket(pbtcoexadapter, invite_rsp, sizeof(invite_rsp), _FALSE);
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
break;
case RX_INVITE_RSP:
/*invite rsp*/
pcoex_info->BT_attend = _TRUE;
RTW_INFO("RX_INVITE_RSP!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
break;
case RX_LEAVE_ACK:
/* mean BT know wifi will leave */
pcoex_info->BT_attend = _FALSE;
RTW_INFO("RX_LEAVE_ACK!,sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
break;
case RX_BT_LEAVE:
/* BT leave */
rtw_btcoex_sendmsgbysocket(pbtcoexadapter, leave_ack, sizeof(leave_ack), _FALSE); /* no ack */
pcoex_info->BT_attend = _FALSE;
RTW_INFO("RX_BT_LEAVE!sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, pcoex_info->BT_attend);
break;
default:
if (_TRUE == pcoex_info->BT_attend)
rtw_btcoex_parse_hci_cmd(pbtcoexadapter, recv_data, recv_length);
else
RTW_INFO("ERROR!! BT is UP\n");
break;
}
len--;
kfree_skb(skb);
}
}
#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 15, 0))
void rtw_btcoex_recvmsg_init(struct sock *sk_in, s32 bytes)
#else
void rtw_btcoex_recvmsg_init(struct sock *sk_in)
#endif
{
struct bt_coex_info *pcoex_info = NULL;
if (pbtcoexadapter == NULL) {
RTW_INFO("%s: btcoexadapter NULL\n", __func__);
return;
}
pcoex_info = &pbtcoexadapter->coex_info;
pcoex_info->sk_store = sk_in;
if (pcoex_info->btcoex_wq != NULL)
queue_delayed_work(pcoex_info->btcoex_wq, &pcoex_info->recvmsg_work, 0);
else
RTW_INFO("%s: BTCOEX workqueue NULL\n", __func__);
}
u8 rtw_btcoex_sendmsgbysocket(_adapter *padapter, u8 *msg, u8 msg_size, bool force)
{
u8 error;
struct msghdr udpmsg;
mm_segment_t oldfs;
struct iovec iov;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
/* RTW_INFO("%s: msg:%s, force:%s\n", __func__, msg, force == _TRUE?"TRUE":"FALSE"); */
if (_FALSE == force) {
if (_FALSE == pcoex_info->BT_attend) {
RTW_INFO("TX Blocked: WiFi-BT disconnected\n");
return _FAIL;
}
}
iov.iov_base = (void *)msg;
iov.iov_len = msg_size;
udpmsg.msg_name = &pcoex_info->bt_sockaddr;
udpmsg.msg_namelen = sizeof(struct sockaddr_in);
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 19, 0))
/* referece:sock_xmit in kernel code
* WRITE for sock_sendmsg, READ for sock_recvmsg
* third parameter for msg_iovlen
* last parameter for iov_len
*/
iov_iter_init(&udpmsg.msg_iter, WRITE, &iov, 1, msg_size);
#else
udpmsg.msg_iov = &iov;
udpmsg.msg_iovlen = 1;
#endif
udpmsg.msg_control = NULL;
udpmsg.msg_controllen = 0;
udpmsg.msg_flags = MSG_DONTWAIT | MSG_NOSIGNAL;
oldfs = get_fs();
set_fs(KERNEL_DS);
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(4, 1, 0))
error = sock_sendmsg(pcoex_info->udpsock, &udpmsg);
#else
error = sock_sendmsg(pcoex_info->udpsock, &udpmsg, msg_size);
#endif
set_fs(oldfs);
if (error < 0) {
RTW_INFO("Error when sendimg msg, error:%d\n", error);
return _FAIL;
} else
return _SUCCESS;
}
u8 rtw_btcoex_create_kernel_socket(_adapter *padapter)
{
s8 kernel_socket_err;
u8 tx_msg[255] = attend_req;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
s32 sock_reuse = 1;
u8 status = _FAIL;
RTW_INFO("%s CONNECT_PORT %d\n", __func__, CONNECT_PORT);
if (NULL == pcoex_info) {
RTW_INFO("coex_info: NULL\n");
status = _FAIL;
}
kernel_socket_err = sock_create(PF_INET, SOCK_DGRAM, 0, &pcoex_info->udpsock);
if (kernel_socket_err < 0) {
RTW_INFO("Error during creation of socket error:%d\n", kernel_socket_err);
status = _FAIL;
} else {
_rtw_memset(&(pcoex_info->wifi_sockaddr), 0, sizeof(pcoex_info->wifi_sockaddr));
pcoex_info->wifi_sockaddr.sin_family = AF_INET;
pcoex_info->wifi_sockaddr.sin_port = htons(CONNECT_PORT);
pcoex_info->wifi_sockaddr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
_rtw_memset(&(pcoex_info->bt_sockaddr), 0, sizeof(pcoex_info->bt_sockaddr));
pcoex_info->bt_sockaddr.sin_family = AF_INET;
pcoex_info->bt_sockaddr.sin_port = htons(CONNECT_PORT_BT);
pcoex_info->bt_sockaddr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
pcoex_info->sk_store = NULL;
kernel_socket_err = pcoex_info->udpsock->ops->bind(pcoex_info->udpsock, (struct sockaddr *)&pcoex_info->wifi_sockaddr,
sizeof(pcoex_info->wifi_sockaddr));
if (kernel_socket_err == 0) {
RTW_INFO("binding socket success\n");
pcoex_info->udpsock->sk->sk_data_ready = rtw_btcoex_recvmsg_init;
pcoex_info->sock_open |= KERNEL_SOCKET_OK;
pcoex_info->BT_attend = _FALSE;
RTW_INFO("WIFI sending attend_req\n");
rtw_btcoex_sendmsgbysocket(padapter, attend_req, sizeof(attend_req), _TRUE);
status = _SUCCESS;
} else {
pcoex_info->BT_attend = _FALSE;
sock_release(pcoex_info->udpsock); /* bind fail release socket */
RTW_INFO("Error binding socket: %d\n", kernel_socket_err);
status = _FAIL;
}
}
return status;
}
void rtw_btcoex_close_kernel_socket(_adapter *padapter)
{
struct bt_coex_info *pcoex_info = &padapter->coex_info;
if (pcoex_info->sock_open & KERNEL_SOCKET_OK) {
RTW_INFO("release kernel socket\n");
sock_release(pcoex_info->udpsock);
pcoex_info->sock_open &= ~(KERNEL_SOCKET_OK);
if (_TRUE == pcoex_info->BT_attend)
pcoex_info->BT_attend = _FALSE;
RTW_INFO("sock_open:%d, BT_attend:%d\n", pcoex_info->sock_open, pcoex_info->BT_attend);
}
}
void rtw_btcoex_init_socket(_adapter *padapter)
{
u8 is_invite = _FALSE;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
RTW_INFO("%s\n", __func__);
if (_FALSE == pcoex_info->is_exist) {
_rtw_memset(pcoex_info, 0, sizeof(struct bt_coex_info));
pcoex_info->btcoex_wq = create_workqueue("BTCOEX");
INIT_DELAYED_WORK(&pcoex_info->recvmsg_work,
(void *)rtw_btcoex_recvmsgbysocket);
pbtcoexadapter = padapter;
/* We expect BT is off if BT don't send ack to wifi */
RTW_INFO("We expect BT is off if BT send ack to wifi\n");
rtw_btcoex_pta_off_on_notify(pbtcoexadapter, _FALSE);
if (rtw_btcoex_create_kernel_socket(padapter) == _SUCCESS)
pcoex_info->is_exist = _TRUE;
else {
pcoex_info->is_exist = _FALSE;
pbtcoexadapter = NULL;
}
RTW_INFO("%s: pbtcoexadapter:%p, coex_info->is_exist: %s\n"
, __func__, pbtcoexadapter, pcoex_info->is_exist == _TRUE ? "TRUE" : "FALSE");
}
}
void rtw_btcoex_close_socket(_adapter *padapter)
{
struct bt_coex_info *pcoex_info = &padapter->coex_info;
RTW_INFO("%s--coex_info->is_exist: %s, pcoex_info->BT_attend:%s\n"
, __func__, pcoex_info->is_exist == _TRUE ? "TRUE" : "FALSE", pcoex_info->BT_attend == _TRUE ? "TRUE" : "FALSE");
if (_TRUE == pcoex_info->is_exist) {
if (_TRUE == pcoex_info->BT_attend) {
/*inform BT wifi leave*/
rtw_btcoex_sendmsgbysocket(padapter, wifi_leave, sizeof(wifi_leave), _FALSE);
msleep(50);
}
if (pcoex_info->btcoex_wq != NULL) {
flush_workqueue(pcoex_info->btcoex_wq);
destroy_workqueue(pcoex_info->btcoex_wq);
}
rtw_btcoex_close_kernel_socket(padapter);
pbtcoexadapter = NULL;
pcoex_info->is_exist = _FALSE;
}
}
void rtw_btcoex_dump_tx_msg(u8 *tx_msg, u8 len, u8 *msg_name)
{
u8 i = 0;
RTW_INFO("======> Msg name: %s\n", msg_name);
for (i = 0; i < len; i++)
printk("%02x ", tx_msg[i]);
printk("\n");
RTW_INFO("Msg name: %s <======\n", msg_name);
}
/* Porting from Windows team */
void rtw_btcoex_SendEventExtBtCoexControl(PADAPTER padapter, u8 bNeedDbgRsp, u8 dataLen, void *pData)
{
u8 len = 0, tx_event_length = 0;
u8 localBuf[32] = "";
u8 *pRetPar;
u8 opCode = 0;
u8 *pInBuf = (u8 *)pData;
u8 *pOpCodeContent;
rtw_HCI_event *pEvent;
opCode = pInBuf[0];
RTW_INFO("%s, OPCode:%02x\n", __func__, opCode);
pEvent = (rtw_HCI_event *)(&localBuf[0]);
/* len += bthci_ExtensionEventHeaderRtk(&localBuf[0], */
/* HCI_EVENT_EXT_BT_COEX_CONTROL); */
pEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
pEvent->Data[0] = HCI_EVENT_EXT_BT_COEX_CONTROL; /* extension event code */
len++;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
_rtw_memcpy(&pRetPar[0], pData, dataLen);
len += dataLen;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
#if 0
rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT COEX CONTROL", _FALSE);
#endif
rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
}
/* Porting from Windows team */
void rtw_btcoex_SendEventExtBtInfoControl(PADAPTER padapter, u8 dataLen, void *pData)
{
rtw_HCI_event *pEvent;
u8 *pRetPar;
u8 len = 0, tx_event_length = 0;
u8 localBuf[32] = "";
struct bt_coex_info *pcoex_info = &padapter->coex_info;
PBT_MGNT pBtMgnt = &pcoex_info->BtMgnt;
/* RTW_INFO("%s\n",__func__);*/
if (pBtMgnt->ExtConfig.HCIExtensionVer < 4) { /* not support */
RTW_INFO("ERROR: HCIExtensionVer = %d, HCIExtensionVer<4 !!!!\n", pBtMgnt->ExtConfig.HCIExtensionVer);
return;
}
pEvent = (rtw_HCI_event *)(&localBuf[0]);
/* len += bthci_ExtensionEventHeaderRtk(&localBuf[0], */
/* HCI_EVENT_EXT_BT_INFO_CONTROL); */
pEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
pEvent->Data[0] = HCI_EVENT_EXT_BT_INFO_CONTROL; /* extension event code */
len++;
/* Return parameters starts from here */
pRetPar = &pEvent->Data[len];
_rtw_memcpy(&pRetPar[0], pData, dataLen);
len += dataLen;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
#if 0
rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "BT INFO CONTROL");
#endif
rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
}
void rtw_btcoex_SendScanNotify(PADAPTER padapter, u8 scanType)
{
u8 len = 0, tx_event_length = 0;
u8 localBuf[7] = "";
u8 *pRetPar;
u8 *pu1Temp;
rtw_HCI_event *pEvent;
struct bt_coex_info *pcoex_info = &padapter->coex_info;
PBT_MGNT pBtMgnt = &pcoex_info->BtMgnt;
/* if(!pBtMgnt->BtOperationOn)
* return; */
pEvent = (rtw_HCI_event *)(&localBuf[0]);
/* len += bthci_ExtensionEventHeaderRtk(&localBuf[0],
* HCI_EVENT_EXT_WIFI_SCAN_NOTIFY); */
pEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
pEvent->Data[0] = HCI_EVENT_EXT_WIFI_SCAN_NOTIFY; /* extension event code */
len++;
/* Return parameters starts from here */
/* pRetPar = &PPacketIrpEvent->Data[len]; */
/* pu1Temp = (u8 *)&pRetPar[0]; */
/* *pu1Temp = scanType; */
pEvent->Data[len] = scanType;
len += 1;
pEvent->Length = len;
/* total tx event length + EventCode length + sizeof(length) */
tx_event_length = pEvent->Length + 2;
#if 0
rtw_btcoex_dump_tx_msg((u8 *)pEvent, tx_event_length, "WIFI SCAN OPERATION");
#endif
rtw_btcoex_sendmsgbysocket(padapter, (u8 *)pEvent, tx_event_length, _FALSE);
}
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
#endif /* CONFIG_BT_COEXIST */
void rtw_btcoex_set_ant_info(PADAPTER padapter)
{
#ifdef CONFIG_BT_COEXIST
PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
if (hal->EEPROMBluetoothCoexist == _TRUE) {
u8 bMacPwrCtrlOn = _FALSE;
rtw_btcoex_AntInfoSetting(padapter);
rtw_hal_get_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
if (bMacPwrCtrlOn == _TRUE)
rtw_btcoex_PowerOnSetting(padapter);
}
else
#endif
rtw_btcoex_wifionly_AntInfoSetting(padapter);
}
================================================
FILE: core/rtw_btcoex_wifionly.c
================================================
/******************************************************************************
*
* Copyright(c) 2013 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#include
void rtw_btcoex_wifionly_switchband_notify(PADAPTER padapter)
{
hal_btcoex_wifionly_switchband_notify(padapter);
}
void rtw_btcoex_wifionly_scan_notify(PADAPTER padapter)
{
hal_btcoex_wifionly_scan_notify(padapter);
}
void rtw_btcoex_wifionly_connect_notify(PADAPTER padapter)
{
hal_btcoex_wifionly_connect_notify(padapter);
}
void rtw_btcoex_wifionly_hw_config(PADAPTER padapter)
{
hal_btcoex_wifionly_hw_config(padapter);
}
void rtw_btcoex_wifionly_initialize(PADAPTER padapter)
{
hal_btcoex_wifionly_initlizevariables(padapter);
}
void rtw_btcoex_wifionly_AntInfoSetting(PADAPTER padapter)
{
hal_btcoex_wifionly_AntInfoSetting(padapter);
}
================================================
FILE: core/rtw_chplan.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2018 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_CHPLAN_C_
#include
#define RTW_DOMAIN_MAP_VER "41e"
#define RTW_COUNTRY_MAP_VER "24"
#ifdef LEGACY_CHANNEL_PLAN_REF
/********************************************************
ChannelPlan definitions
*********************************************************/
static RT_CHANNEL_PLAN legacy_channel_plan[] = {
/* 0x00, RTW_CHPLAN_FCC */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165}, 32},
/* 0x01, RTW_CHPLAN_IC */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 31},
/* 0x02, RTW_CHPLAN_ETSI */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 32},
/* 0x03, RTW_CHPLAN_SPAIN */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
/* 0x04, RTW_CHPLAN_FRANCE */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
/* 0x05, RTW_CHPLAN_MKK */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
/* 0x06, RTW_CHPLAN_MKK1 */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
/* 0x07, RTW_CHPLAN_ISRAEL */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64}, 21},
/* 0x08, RTW_CHPLAN_TELEC */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 36, 40, 44, 48, 52, 56, 60, 64}, 22},
/* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}, 14},
/* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
/* 0x0B, RTW_CHPLAN_TAIWAN */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165}, 26},
/* 0x0C, RTW_CHPLAN_CHINA */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 149, 153, 157, 161, 165}, 18},
/* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165}, 24},
/* 0x0E, RTW_CHPLAN_KOREA */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165}, 31},
/* 0x0F, RTW_CHPLAN_TURKEY */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 52, 56, 60, 64}, 19},
/* 0x10, RTW_CHPLAN_JAPAN */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 32},
/* 0x11, RTW_CHPLAN_FCC_NO_DFS */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 36, 40, 44, 48, 149, 153, 157, 161, 165}, 20},
/* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48}, 17},
/* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165}, 37},
/* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */ {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 56, 60, 64, 149, 153, 157, 161, 165}, 19},
};
#endif
enum rtw_rd_2g {
RTW_RD_2G_NULL = 0,
RTW_RD_2G_WORLD = 1, /* Worldwird 13 */
RTW_RD_2G_ETSI1 = 2, /* Europe */
RTW_RD_2G_FCC1 = 3, /* US */
RTW_RD_2G_MKK1 = 4, /* Japan */
RTW_RD_2G_ETSI2 = 5, /* France */
RTW_RD_2G_GLOBAL = 6, /* Global domain */
RTW_RD_2G_MKK2 = 7, /* Japan */
RTW_RD_2G_FCC2 = 8, /* US */
RTW_RD_2G_IC1 = 9, /* Canada */
RTW_RD_2G_WORLD1 = 10, /* Worldwide 11 */
RTW_RD_2G_KCC1 = 11, /* Korea */
RTW_RD_2G_IC2 = 12, /* Canada */
RTW_RD_2G_MAX,
};
enum rtw_rd_5g {
RTW_RD_5G_NULL = 0, /* */
RTW_RD_5G_ETSI1 = 1, /* Europe */
RTW_RD_5G_ETSI2 = 2, /* Australia, New Zealand */
RTW_RD_5G_ETSI3 = 3, /* Russia */
RTW_RD_5G_FCC1 = 4, /* US */
RTW_RD_5G_FCC2 = 5, /* FCC w/o DFS Channels */
RTW_RD_5G_FCC3 = 6, /* Bolivia, Chile, El Salvador, Venezuela */
RTW_RD_5G_FCC4 = 7, /* Venezuela */
RTW_RD_5G_FCC5 = 8, /* China */
RTW_RD_5G_FCC6 = 9, /* */
RTW_RD_5G_FCC7 = 10, /* US(w/o Weather radar) */
RTW_RD_5G_IC1 = 11, /* Canada(w/o Weather radar) */
RTW_RD_5G_KCC1 = 12, /* Korea */
RTW_RD_5G_MKK1 = 13, /* Japan */
RTW_RD_5G_MKK2 = 14, /* Japan (W52, W53) */
RTW_RD_5G_MKK3 = 15, /* Japan (W56) */
RTW_RD_5G_NCC1 = 16, /* Taiwan, (w/o Weather radar) */
RTW_RD_5G_NCC2 = 17, /* Taiwan, Band2, Band4 */
RTW_RD_5G_NCC3 = 18, /* Taiwan w/o DFS, Band4 only */
RTW_RD_5G_ETSI4 = 19, /* Europe w/o DFS, Band1 only */
RTW_RD_5G_ETSI5 = 20, /* Australia, New Zealand(w/o Weather radar) */
RTW_RD_5G_FCC8 = 21, /* Latin America */
RTW_RD_5G_ETSI6 = 22, /* Israel, Bahrain, Egypt, India, China, Malaysia */
RTW_RD_5G_ETSI7 = 23, /* China */
RTW_RD_5G_ETSI8 = 24, /* Jordan */
RTW_RD_5G_ETSI9 = 25, /* Lebanon */
RTW_RD_5G_ETSI10 = 26, /* Qatar */
RTW_RD_5G_ETSI11 = 27, /* Russia */
RTW_RD_5G_NCC4 = 28, /* Taiwan, (w/o Weather radar) */
RTW_RD_5G_ETSI12 = 29, /* Indonesia */
RTW_RD_5G_FCC9 = 30, /* (w/o Weather radar) */
RTW_RD_5G_ETSI13 = 31, /* (w/o Weather radar) */
RTW_RD_5G_FCC10 = 32, /* Argentina(w/o Weather radar) */
RTW_RD_5G_MKK4 = 33, /* Japan (W52) */
RTW_RD_5G_ETSI14 = 34, /* Russia */
RTW_RD_5G_FCC11 = 35, /* US(include CH144) */
RTW_RD_5G_ETSI15 = 36, /* Malaysia */
RTW_RD_5G_MKK5 = 37, /* Japan */
RTW_RD_5G_ETSI16 = 38, /* Europe */
RTW_RD_5G_ETSI17 = 39, /* Europe */
RTW_RD_5G_FCC12 = 40, /* FCC */
RTW_RD_5G_FCC13 = 41, /* FCC */
RTW_RD_5G_FCC14 = 42, /* FCC w/o Weather radar(w/o 5600~5650MHz) */
RTW_RD_5G_FCC15 = 43, /* FCC w/o Band3 */
RTW_RD_5G_FCC16 = 44, /* FCC w/o Band3 */
RTW_RD_5G_ETSI18 = 45, /* ETSI w/o DFS Band2&3 */
RTW_RD_5G_ETSI19 = 46, /* Europe */
RTW_RD_5G_FCC17 = 47, /* FCC w/o Weather radar(w/o 5600~5650MHz) */
RTW_RD_5G_ETSI20 = 48, /* Europe */
RTW_RD_5G_IC2 = 49, /* Canada(w/o Weather radar), include ch144 */
RTW_RD_5G_ETSI21 = 50, /* Australia, New Zealand(w/o Weather radar) */
RTW_RD_5G_FCC18 = 51, /* */
RTW_RD_5G_WORLD = 52, /* Worldwide */
RTW_RD_5G_CHILE1 = 53, /* Chile */
RTW_RD_5G_ACMA1 = 54, /* Australia, New Zealand (w/o Weather radar) (w/o Ch120~Ch128) */
RTW_RD_5G_WORLD1 = 55, /* 5G Worldwide Band1&2 */
RTW_RD_5G_CHILE2 = 56, /* Chile (Band2,Band3) */
RTW_RD_5G_KCC2 = 57, /* Korea (New standard) */
RTW_RD_5G_KCC3 = 58, /* Korea (2018 Dec 05 New standard, include ch144) */
RTW_RD_5G_MKK6 = 59, /* Japan */
RTW_RD_5G_MKK7 = 60, /* Japan */
RTW_RD_5G_MKK8 = 61, /* Japan */
RTW_RD_5G_MEX1 = 62, /* Mexico */
RTW_RD_5G_ETSI22 = 63, /* Europe */
/* === Below are driver defined for legacy channel plan compatible, DON'T assign index ==== */
RTW_RD_5G_OLD_FCC1,
RTW_RD_5G_OLD_NCC1,
RTW_RD_5G_OLD_KCC1,
RTW_RD_5G_MAX,
};
struct ch_list_t {
u8 *len_ch;
};
#define CH_LIST_ENT(_len, arg...) \
{.len_ch = (u8[_len + 1]) {_len, ##arg}, }
#define CH_LIST_LEN(_ch_list) (_ch_list.len_ch[0])
#define CH_LIST_CH(_ch_list, _i) (_ch_list.len_ch[_i + 1])
struct chplan_ent_t {
u8 rd_2g;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
u8 rd_5g;
#endif
u8 regd; /* value of REGULATION_TXPWR_LMT */
};
#ifdef CONFIG_IEEE80211_BAND_5GHZ
#define CHPLAN_ENT(i2g, i5g, regd) {i2g, i5g, regd}
#else
#define CHPLAN_ENT(i2g, i5g, regd) {i2g, regd}
#endif
static struct ch_list_t RTW_ChannelPlan2G[] = {
/* 0, RTW_RD_2G_NULL */ CH_LIST_ENT(0),
/* 1, RTW_RD_2G_WORLD */ CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
/* 2, RTW_RD_2G_ETSI1 */ CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
/* 3, RTW_RD_2G_FCC1 */ CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
/* 4, RTW_RD_2G_MKK1 */ CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
/* 5, RTW_RD_2G_ETSI2 */ CH_LIST_ENT(4, 10, 11, 12, 13),
/* 6, RTW_RD_2G_GLOBAL */ CH_LIST_ENT(14, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14),
/* 7, RTW_RD_2G_MKK2 */ CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
/* 8, RTW_RD_2G_FCC2 */ CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
/* 9, RTW_RD_2G_IC1 */ CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
/* 10, RTW_RD_2G_WORLD1 */ CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
/* 11, RTW_RD_2G_KCC1 */ CH_LIST_ENT(13, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13),
/* 12, RTW_RD_2G_IC2 */ CH_LIST_ENT(11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11),
};
#ifdef CONFIG_IEEE80211_BAND_5GHZ
static struct ch_list_t RTW_ChannelPlan5G[] = {
/* 0, RTW_RD_5G_NULL */ CH_LIST_ENT(0),
/* 1, RTW_RD_5G_ETSI1 */ CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
/* 2, RTW_RD_5G_ETSI2 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 3, RTW_RD_5G_ETSI3 */ CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 149, 153, 157, 161, 165),
/* 4, RTW_RD_5G_FCC1 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 5, RTW_RD_5G_FCC2 */ CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
/* 6, RTW_RD_5G_FCC3 */ CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
/* 7, RTW_RD_5G_FCC4 */ CH_LIST_ENT(12, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161),
/* 8, RTW_RD_5G_FCC5 */ CH_LIST_ENT(5, 149, 153, 157, 161, 165),
/* 9, RTW_RD_5G_FCC6 */ CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
/* 10, RTW_RD_5G_FCC7 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 11, RTW_RD_5G_IC1 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 12, RTW_RD_5G_KCC1 */ CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161),
/* 13, RTW_RD_5G_MKK1 */ CH_LIST_ENT(19, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
/* 14, RTW_RD_5G_MKK2 */ CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
/* 15, RTW_RD_5G_MKK3 */ CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
/* 16, RTW_RD_5G_NCC1 */ CH_LIST_ENT(16, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 17, RTW_RD_5G_NCC2 */ CH_LIST_ENT(8, 56, 60, 64, 149, 153, 157, 161, 165),
/* 18, RTW_RD_5G_NCC3 */ CH_LIST_ENT(5, 149, 153, 157, 161, 165),
/* 19, RTW_RD_5G_ETSI4 */ CH_LIST_ENT(4, 36, 40, 44, 48),
/* 20, RTW_RD_5G_ETSI5 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 21, RTW_RD_5G_FCC8 */ CH_LIST_ENT(4, 149, 153, 157, 161),
/* 22, RTW_RD_5G_ETSI6 */ CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
/* 23, RTW_RD_5G_ETSI7 */ CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
/* 24, RTW_RD_5G_ETSI8 */ CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
/* 25, RTW_RD_5G_ETSI9 */ CH_LIST_ENT(11, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140),
/* 26, RTW_RD_5G_ETSI10 */ CH_LIST_ENT(5, 149, 153, 157, 161, 165),
/* 27, RTW_RD_5G_ETSI11 */ CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140, 149, 153, 157, 161, 165),
/* 28, RTW_RD_5G_NCC4 */ CH_LIST_ENT(17, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 29, RTW_RD_5G_ETSI12 */ CH_LIST_ENT(4, 149, 153, 157, 161),
/* 30, RTW_RD_5G_FCC9 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 31, RTW_RD_5G_ETSI13 */ CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
/* 32, RTW_RD_5G_FCC10 */ CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161),
/* 33, RTW_RD_5G_MKK4 */ CH_LIST_ENT(4, 36, 40, 44, 48),
/* 34, RTW_RD_5G_ETSI14 */ CH_LIST_ENT(11, 36, 40, 44, 48, 52, 56, 60, 64, 132, 136, 140),
/* 35, RTW_RD_5G_FCC11 */ CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
/* 36, RTW_RD_5G_ETSI15 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 149, 153, 157, 161, 165),
/* 37, RTW_RD_5G_MKK5 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 38, RTW_RD_5G_ETSI16 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 39, RTW_RD_5G_ETSI17 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 40, RTW_RD_5G_FCC12*/ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 41, RTW_RD_5G_FCC13 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 42, RTW_RD_5G_FCC14 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 43, RTW_RD_5G_FCC15 */ CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
/* 44, RTW_RD_5G_FCC16 */ CH_LIST_ENT(13, 36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165),
/* 45, RTW_RD_5G_ETSI18 */ CH_LIST_ENT(9, 36, 40, 44, 48, 149, 153, 157, 161, 165),
/* 46, RTW_RD_5G_ETSI19 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 47, RTW_RD_5G_FCC17 */ CH_LIST_ENT(16, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140),
/* 48, RTW_RD_5G_ETSI20 */ CH_LIST_ENT(9, 52, 56, 60, 64, 149, 153, 157, 161, 165),
/* 49, RTW_RD_5G_IC2 */ CH_LIST_ENT(22, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 144, 149, 153, 157, 161, 165),
/* 50, RTW_RD_5G_ETSI21 */ CH_LIST_ENT(13, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 51, RTW_RD_5G_FCC18 */ CH_LIST_ENT(8, 100, 104, 108, 112, 116, 132, 136, 140),
/* 52, RTW_RD_5G_WORLD */ CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
/* 53, RTW_RD_5G_CHILE1 */ CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
/* 54, RTW_RD_5G_ACMA1 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 55, RTW_RD_5G_WORLD1 */ CH_LIST_ENT(8, 36, 40, 44, 48, 52, 56, 60, 64),
/* 56, RTW_RD_5G_CHILE2 */ CH_LIST_ENT(16, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144),
/* 57, RTW_RD_5G_KCC2 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* 58, RTW_RD_5G_KCC3 */ CH_LIST_ENT(25, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144, 149, 153, 157, 161, 165),
/* 59, RTW_RD_5G_MKK6 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 149, 153, 157, 161, 165),
/* 60, RTW_RD_5G_MKK7 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 61, RTW_RD_5G_MKK8 */ CH_LIST_ENT(23, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 136, 140, 149, 153, 157, 161, 165),
/* 62, RTW_RD_5G_MEX1 */ CH_LIST_ENT(21, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 132, 136, 140, 149, 153, 157, 161, 165),
/* 63, RTW_RD_5G_ETSI22 */ CH_LIST_ENT(24, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165),
/* === Below are driver defined for legacy channel plan compatible, NO static index assigned ==== */
/* RTW_RD_5G_OLD_FCC1 */ CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
/* RTW_RD_5G_OLD_NCC1 */ CH_LIST_ENT(15, 56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149, 153, 157, 161, 165),
/* RTW_RD_5G_OLD_KCC1 */ CH_LIST_ENT(20, 36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112, 116, 120, 124, 149, 153, 157, 161, 165),
};
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
static struct chplan_ent_t RTW_ChannelPlanMap[RTW_CHPLAN_MAX] = {
/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_KCC1, TXPWR_LMT_FCC), /* 0x00, RTW_CHPLAN_FCC */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_OLD_FCC1, TXPWR_LMT_FCC), /* 0x01, RTW_CHPLAN_IC */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI1, TXPWR_LMT_ETSI), /* 0x02, RTW_CHPLAN_ETSI */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_NULL, TXPWR_LMT_ETSI), /* 0x03, RTW_CHPLAN_SPAIN */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_NULL, TXPWR_LMT_ETSI), /* 0x04, RTW_CHPLAN_FRANCE */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_NULL, TXPWR_LMT_MKK), /* 0x05, RTW_CHPLAN_MKK */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_NULL, TXPWR_LMT_MKK), /* 0x06, RTW_CHPLAN_MKK1 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_FCC6, TXPWR_LMT_ETSI), /* 0x07, RTW_CHPLAN_ISRAEL */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_FCC6, TXPWR_LMT_MKK), /* 0x08, RTW_CHPLAN_TELEC */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x09, RTW_CHPLAN_GLOBAL_DOAMIN */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x0A, RTW_CHPLAN_WORLD_WIDE_13 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_OLD_NCC1, TXPWR_LMT_FCC), /* 0x0B, RTW_CHPLAN_TAIWAN */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_FCC5, TXPWR_LMT_ETSI), /* 0x0C, RTW_CHPLAN_CHINA */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC3, TXPWR_LMT_WW), /* 0x0D, RTW_CHPLAN_SINGAPORE_INDIA_MEXICO */ /* ETSI:Singapore, India. FCC:Mexico => WW */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_OLD_KCC1, TXPWR_LMT_ETSI), /* 0x0E, RTW_CHPLAN_KOREA */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC6, TXPWR_LMT_ETSI), /* 0x0F, RTW_CHPLAN_TURKEY */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI1, TXPWR_LMT_MKK), /* 0x10, RTW_CHPLAN_JAPAN */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC2, TXPWR_LMT_FCC), /* 0x11, RTW_CHPLAN_FCC_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_FCC7, TXPWR_LMT_MKK), /* 0x12, RTW_CHPLAN_JAPAN_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC1, TXPWR_LMT_WW), /* 0x13, RTW_CHPLAN_WORLD_WIDE_5G */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_NCC2, TXPWR_LMT_FCC), /* 0x14, RTW_CHPLAN_TAIWAN_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC7, TXPWR_LMT_ETSI), /* 0x15, RTW_CHPLAN_ETSI_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_NCC1, TXPWR_LMT_ETSI), /* 0x16, RTW_CHPLAN_KOREA_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_FCC7, TXPWR_LMT_MKK), /* 0x17, RTW_CHPLAN_JAPAN_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_FCC5, TXPWR_LMT_ETSI), /* 0x18, RTW_CHPLAN_PAKISTAN_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC5, TXPWR_LMT_FCC), /* 0x19, RTW_CHPLAN_TAIWAN2_NO_DFS */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x1A, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x1B, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x1C, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x1D, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x1E, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_FCC1, TXPWR_LMT_WW), /* 0x1F, RTW_CHPLAN_WORLD_WIDE_ONLY_5G */
/* ===== 0x20 ~ 0x7F, new channel plan ===== */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x20, RTW_CHPLAN_WORLD_NULL */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_NULL, TXPWR_LMT_ETSI), /* 0x21, RTW_CHPLAN_ETSI1_NULL */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_NULL, TXPWR_LMT_FCC), /* 0x22, RTW_CHPLAN_FCC1_NULL */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_NULL, TXPWR_LMT_MKK), /* 0x23, RTW_CHPLAN_MKK1_NULL */
CHPLAN_ENT(RTW_RD_2G_ETSI2, RTW_RD_5G_NULL, TXPWR_LMT_ETSI), /* 0x24, RTW_CHPLAN_ETSI2_NULL */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC1, TXPWR_LMT_FCC), /* 0x25, RTW_CHPLAN_FCC1_FCC1 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI1, TXPWR_LMT_ETSI), /* 0x26, RTW_CHPLAN_WORLD_ETSI1 */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_MKK1, TXPWR_LMT_MKK), /* 0x27, RTW_CHPLAN_MKK1_MKK1 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_KCC1, TXPWR_LMT_KCC), /* 0x28, RTW_CHPLAN_WORLD_KCC1 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC2, TXPWR_LMT_FCC), /* 0x29, RTW_CHPLAN_WORLD_FCC2 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_NULL, TXPWR_LMT_FCC), /* 0x2A, RTW_CHPLAN_FCC2_NULL */
CHPLAN_ENT(RTW_RD_2G_IC1, RTW_RD_5G_IC2, TXPWR_LMT_IC), /* 0x2B, RTW_CHPLAN_IC1_IC2 */
CHPLAN_ENT(RTW_RD_2G_MKK2, RTW_RD_5G_NULL, TXPWR_LMT_MKK), /* 0x2C, RTW_CHPLAN_MKK2_NULL */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_CHILE1, TXPWR_LMT_CHILE), /* 0x2D, RTW_CHPLAN_WORLD_CHILE1 */
CHPLAN_ENT(RTW_RD_2G_WORLD1, RTW_RD_5G_WORLD1, TXPWR_LMT_WW), /* 0x2E, RTW_CHPLAN_WORLD1_WORLD1 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_CHILE2, TXPWR_LMT_CHILE), /* 0x2F, RTW_CHPLAN_WORLD_CHILE2 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC3, TXPWR_LMT_FCC), /* 0x30, RTW_CHPLAN_WORLD_FCC3 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC4, TXPWR_LMT_FCC), /* 0x31, RTW_CHPLAN_WORLD_FCC4 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC5, TXPWR_LMT_FCC), /* 0x32, RTW_CHPLAN_WORLD_FCC5 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC6, TXPWR_LMT_FCC), /* 0x33, RTW_CHPLAN_WORLD_FCC6 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC7, TXPWR_LMT_FCC), /* 0x34, RTW_CHPLAN_FCC1_FCC7 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI2, TXPWR_LMT_ETSI), /* 0x35, RTW_CHPLAN_WORLD_ETSI2 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI3, TXPWR_LMT_ETSI), /* 0x36, RTW_CHPLAN_WORLD_ETSI3 */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_MKK2, TXPWR_LMT_MKK), /* 0x37, RTW_CHPLAN_MKK1_MKK2 */
CHPLAN_ENT(RTW_RD_2G_MKK1, RTW_RD_5G_MKK3, TXPWR_LMT_MKK), /* 0x38, RTW_CHPLAN_MKK1_MKK3 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_NCC1, TXPWR_LMT_FCC), /* 0x39, RTW_CHPLAN_FCC1_NCC1 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI1, TXPWR_LMT_ETSI), /* 0x3A, RTW_CHPLAN_ETSI1_ETSI1 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ACMA1, TXPWR_LMT_ACMA), /* 0x3B, RTW_CHPLAN_ETSI1_ACMA1 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI6, TXPWR_LMT_ETSI), /* 0x3C, RTW_CHPLAN_ETSI1_ETSI6 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI12, TXPWR_LMT_ETSI), /* 0x3D, RTW_CHPLAN_ETSI1_ETSI12 */
CHPLAN_ENT(RTW_RD_2G_KCC1, RTW_RD_5G_KCC2, TXPWR_LMT_KCC), /* 0x3E, RTW_CHPLAN_KCC1_KCC2 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC11, TXPWR_LMT_FCC), /* 0x3F, RTW_CHPLAN_FCC1_FCC11*/
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_NCC2, TXPWR_LMT_FCC), /* 0x40, RTW_CHPLAN_FCC1_NCC2 */
CHPLAN_ENT(RTW_RD_2G_GLOBAL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x41, RTW_CHPLAN_GLOBAL_NULL */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI4, TXPWR_LMT_ETSI), /* 0x42, RTW_CHPLAN_ETSI1_ETSI4 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC2, TXPWR_LMT_FCC), /* 0x43, RTW_CHPLAN_FCC1_FCC2 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_NCC3, TXPWR_LMT_FCC), /* 0x44, RTW_CHPLAN_FCC1_NCC3 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ACMA1, TXPWR_LMT_ACMA), /* 0x45, RTW_CHPLAN_WORLD_ACMA1 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC8, TXPWR_LMT_FCC), /* 0x46, RTW_CHPLAN_FCC1_FCC8 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI6, TXPWR_LMT_ETSI), /* 0x47, RTW_CHPLAN_WORLD_ETSI6 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI7, TXPWR_LMT_ETSI), /* 0x48, RTW_CHPLAN_WORLD_ETSI7 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI8, TXPWR_LMT_ETSI), /* 0x49, RTW_CHPLAN_WORLD_ETSI8 */
CHPLAN_ENT(RTW_RD_2G_IC2, RTW_RD_5G_IC2, TXPWR_LMT_IC), /* 0x4A, RTW_CHPLAN_IC2_IC2 */
CHPLAN_ENT(RTW_RD_2G_KCC1, RTW_RD_5G_KCC3, TXPWR_LMT_KCC), /* 0x4B, RTW_CHPLAN_KCC1_KCC3 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC15, TXPWR_LMT_FCC), /* 0x4C, RTW_CHPLAN_FCC1_FCC15 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_MEX1, TXPWR_LMT_MEXICO), /* 0x4D, RTW_CHPLAN_FCC2_MEX1 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI22, TXPWR_LMT_ETSI), /* 0x4E, RTW_CHPLAN_ETSI1_ETSI22 */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x4F, */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI9, TXPWR_LMT_ETSI), /* 0x50, RTW_CHPLAN_WORLD_ETSI9 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI10, TXPWR_LMT_ETSI), /* 0x51, RTW_CHPLAN_WORLD_ETSI10 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI11, TXPWR_LMT_ETSI), /* 0x52, RTW_CHPLAN_WORLD_ETSI11 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_NCC4, TXPWR_LMT_FCC), /* 0x53, RTW_CHPLAN_FCC1_NCC4 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI12, TXPWR_LMT_ETSI), /* 0x54, RTW_CHPLAN_WORLD_ETSI12 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC9, TXPWR_LMT_FCC), /* 0x55, RTW_CHPLAN_FCC1_FCC9 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI13, TXPWR_LMT_ETSI), /* 0x56, RTW_CHPLAN_WORLD_ETSI13 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC10, TXPWR_LMT_FCC), /* 0x57, RTW_CHPLAN_FCC1_FCC10 */
CHPLAN_ENT(RTW_RD_2G_MKK2, RTW_RD_5G_MKK4, TXPWR_LMT_MKK), /* 0x58, RTW_CHPLAN_MKK2_MKK4 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI14, TXPWR_LMT_ETSI), /* 0x59, RTW_CHPLAN_WORLD_ETSI14 */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x5A, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x5B, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x5C, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x5D, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x5E, */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_NULL, TXPWR_LMT_WW), /* 0x5F, */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC5, TXPWR_LMT_FCC), /* 0x60, RTW_CHPLAN_FCC1_FCC5 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC7, TXPWR_LMT_FCC), /* 0x61, RTW_CHPLAN_FCC2_FCC7 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC1, TXPWR_LMT_FCC), /* 0x62, RTW_CHPLAN_FCC2_FCC1 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI15, TXPWR_LMT_ETSI), /* 0x63, RTW_CHPLAN_WORLD_ETSI15 */
CHPLAN_ENT(RTW_RD_2G_MKK2, RTW_RD_5G_MKK5, TXPWR_LMT_MKK), /* 0x64, RTW_CHPLAN_MKK2_MKK5 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI16, TXPWR_LMT_ETSI), /* 0x65, RTW_CHPLAN_ETSI1_ETSI16 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC14, TXPWR_LMT_FCC), /* 0x66, RTW_CHPLAN_FCC1_FCC14 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC12, TXPWR_LMT_FCC), /* 0x67, RTW_CHPLAN_FCC1_FCC12 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC14, TXPWR_LMT_FCC), /* 0x68, RTW_CHPLAN_FCC2_FCC14 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC12, TXPWR_LMT_FCC), /* 0x69, RTW_CHPLAN_FCC2_FCC12 */
CHPLAN_ENT(RTW_RD_2G_ETSI1, RTW_RD_5G_ETSI17, TXPWR_LMT_ETSI), /* 0x6A, RTW_CHPLAN_ETSI1_ETSI17 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC16, TXPWR_LMT_FCC), /* 0x6B, RTW_CHPLAN_WORLD_FCC16 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC13, TXPWR_LMT_FCC), /* 0x6C, RTW_CHPLAN_WORLD_FCC13 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC15, TXPWR_LMT_FCC), /* 0x6D, RTW_CHPLAN_FCC2_FCC15 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC12, TXPWR_LMT_FCC), /* 0x6E, RTW_CHPLAN_WORLD_FCC12 */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_ETSI8, TXPWR_LMT_ETSI), /* 0x6F, RTW_CHPLAN_NULL_ETSI8 */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_ETSI18, TXPWR_LMT_ETSI), /* 0x70, RTW_CHPLAN_NULL_ETSI18 */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_ETSI17, TXPWR_LMT_ETSI), /* 0x71, RTW_CHPLAN_NULL_ETSI17 */
CHPLAN_ENT(RTW_RD_2G_NULL, RTW_RD_5G_ETSI19, TXPWR_LMT_ETSI), /* 0x72, RTW_CHPLAN_NULL_ETSI19 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC7, TXPWR_LMT_FCC), /* 0x73, RTW_CHPLAN_WORLD_FCC7 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC17, TXPWR_LMT_FCC), /* 0x74, RTW_CHPLAN_FCC2_FCC17 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI20, TXPWR_LMT_ETSI), /* 0x75, RTW_CHPLAN_WORLD_ETSI20 */
CHPLAN_ENT(RTW_RD_2G_FCC2, RTW_RD_5G_FCC11, TXPWR_LMT_FCC), /* 0x76, RTW_CHPLAN_FCC2_FCC11 */
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_ETSI21, TXPWR_LMT_ETSI), /* 0x77, RTW_CHPLAN_WORLD_ETSI21 */
CHPLAN_ENT(RTW_RD_2G_FCC1, RTW_RD_5G_FCC18, TXPWR_LMT_FCC), /* 0x78, RTW_CHPLAN_FCC1_FCC18 */
CHPLAN_ENT(RTW_RD_2G_MKK2, RTW_RD_5G_MKK1, TXPWR_LMT_MKK), /* 0x79, RTW_CHPLAN_MKK2_MKK1 */
};
static struct chplan_ent_t RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE =
CHPLAN_ENT(RTW_RD_2G_WORLD, RTW_RD_5G_FCC1, TXPWR_LMT_FCC); /* 0x7F, Realtek Define */
u8 rtw_chplan_get_default_regd(u8 id)
{
u8 regd;
if (id == RTW_CHPLAN_REALTEK_DEFINE)
regd = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.regd;
else
regd = RTW_ChannelPlanMap[id].regd;
return regd;
}
bool rtw_chplan_is_empty(u8 id)
{
struct chplan_ent_t *chplan_map;
if (id == RTW_CHPLAN_REALTEK_DEFINE)
chplan_map = &RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE;
else
chplan_map = &RTW_ChannelPlanMap[id];
if (chplan_map->rd_2g == RTW_RD_2G_NULL
#ifdef CONFIG_IEEE80211_BAND_5GHZ
&& chplan_map->rd_5g == RTW_RD_5G_NULL
#endif
)
return _TRUE;
return _FALSE;
}
bool rtw_regsty_is_excl_chs(struct registry_priv *regsty, u8 ch)
{
int i;
for (i = 0; i < MAX_CHANNEL_NUM; i++) {
if (regsty->excl_chs[i] == 0)
break;
if (regsty->excl_chs[i] == ch)
return _TRUE;
}
return _FALSE;
}
inline static u8 rtw_rd_5g_band1_passive(u8 rtw_rd_5g)
{
u8 passive = 0;
switch (rtw_rd_5g) {
case RTW_RD_5G_FCC13:
case RTW_RD_5G_FCC16:
case RTW_RD_5G_ETSI18:
case RTW_RD_5G_ETSI19:
case RTW_RD_5G_WORLD:
case RTW_RD_5G_WORLD1:
case RTW_RD_5G_MKK6:
case RTW_RD_5G_MKK7:
case RTW_RD_5G_ETSI22:
passive = 1;
};
return passive;
}
inline static u8 rtw_rd_5g_band4_passive(u8 rtw_rd_5g)
{
u8 passive = 0;
switch (rtw_rd_5g) {
case RTW_RD_5G_MKK5:
case RTW_RD_5G_ETSI16:
case RTW_RD_5G_ETSI18:
case RTW_RD_5G_ETSI19:
case RTW_RD_5G_WORLD:
case RTW_RD_5G_MKK8:
case RTW_RD_5G_ETSI22:
passive = 1;
};
return passive;
}
u8 init_channel_set(_adapter *padapter, u8 ChannelPlan, RT_CHANNEL_INFO *channel_set)
{
struct registry_priv *regsty = adapter_to_regsty(padapter);
u8 index, chanset_size = 0;
u8 b5GBand = _FALSE, b2_4GBand = _FALSE;
u8 rd_2g = 0, rd_5g = 0;
#ifdef CONFIG_DFS_MASTER
int i;
#endif
if (!rtw_is_channel_plan_valid(ChannelPlan)) {
RTW_ERR("ChannelPlan ID 0x%02X error !!!!!\n", ChannelPlan);
return chanset_size;
}
_rtw_memset(channel_set, 0, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
if (IsSupported24G(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_2G))
b2_4GBand = _TRUE;
if (is_supported_5g(regsty->wireless_mode) && hal_chk_band_cap(padapter, BAND_CAP_5G))
b5GBand = _TRUE;
if (b2_4GBand == _FALSE && b5GBand == _FALSE) {
RTW_WARN("HW band_cap has no intersection with SW wireless_mode setting\n");
return chanset_size;
}
if (b2_4GBand) {
if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
rd_2g = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.rd_2g;
else
rd_2g = RTW_ChannelPlanMap[ChannelPlan].rd_2g;
for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan2G[rd_2g]); index++) {
if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan2G[rd_2g], index)) == _TRUE)
continue;
if (chanset_size >= MAX_CHANNEL_NUM) {
RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
break;
}
channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan2G[rd_2g], index);
if (ChannelPlan == RTW_CHPLAN_GLOBAL_DOAMIN
|| rd_2g == RTW_RD_2G_GLOBAL
) {
/* Channel 1~11 is active, and 12~14 is passive */
if (channel_set[chanset_size].ChannelNum >= 1 && channel_set[chanset_size].ChannelNum <= 11)
channel_set[chanset_size].ScanType = SCAN_ACTIVE;
else if ((channel_set[chanset_size].ChannelNum >= 12 && channel_set[chanset_size].ChannelNum <= 14))
channel_set[chanset_size].ScanType = SCAN_PASSIVE;
} else if (ChannelPlan == RTW_CHPLAN_WORLD_WIDE_13
|| ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G
|| rd_2g == RTW_RD_2G_WORLD
) {
/* channel 12~13, passive scan */
if (channel_set[chanset_size].ChannelNum <= 11)
channel_set[chanset_size].ScanType = SCAN_ACTIVE;
else
channel_set[chanset_size].ScanType = SCAN_PASSIVE;
} else
channel_set[chanset_size].ScanType = SCAN_ACTIVE;
chanset_size++;
}
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (b5GBand) {
if (ChannelPlan == RTW_CHPLAN_REALTEK_DEFINE)
rd_5g = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.rd_5g;
else
rd_5g = RTW_ChannelPlanMap[ChannelPlan].rd_5g;
for (index = 0; index < CH_LIST_LEN(RTW_ChannelPlan5G[rd_5g]); index++) {
if (rtw_regsty_is_excl_chs(regsty, CH_LIST_CH(RTW_ChannelPlan5G[rd_5g], index)) == _TRUE)
continue;
#ifndef CONFIG_DFS
if (rtw_is_dfs_ch(CH_LIST_CH(RTW_ChannelPlan5G[rd_5g], index)))
continue;
#endif
if (chanset_size >= MAX_CHANNEL_NUM) {
RTW_WARN("chset size can't exceed MAX_CHANNEL_NUM(%u)\n", MAX_CHANNEL_NUM);
break;
}
channel_set[chanset_size].ChannelNum = CH_LIST_CH(RTW_ChannelPlan5G[rd_5g], index);
if ((ChannelPlan == RTW_CHPLAN_WORLD_WIDE_5G) /* all channels passive */
|| (rtw_is_5g_band1(channel_set[chanset_size].ChannelNum)
&& rtw_rd_5g_band1_passive(rd_5g)) /* band1 passive */
|| (rtw_is_5g_band4(channel_set[chanset_size].ChannelNum)
&& rtw_rd_5g_band4_passive(rd_5g)) /* band4 passive */
|| (rtw_is_dfs_ch(channel_set[chanset_size].ChannelNum)) /* DFS channel(band2, 3) passive */
)
channel_set[chanset_size].ScanType = SCAN_PASSIVE;
else
channel_set[chanset_size].ScanType = SCAN_ACTIVE;
chanset_size++;
}
}
#ifdef CONFIG_DFS_MASTER
for (i = 0; i < chanset_size; i++)
channel_set[i].non_ocp_end_time = rtw_get_current_time();
#endif
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
if (chanset_size)
RTW_INFO(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, ch num:%d\n"
, FUNC_ADPT_ARG(padapter), ChannelPlan, chanset_size);
else
RTW_WARN(FUNC_ADPT_FMT" ChannelPlan ID:0x%02x, final chset has no channel\n"
, FUNC_ADPT_ARG(padapter), ChannelPlan);
return chanset_size;
}
#ifdef CONFIG_80211AC_VHT
#define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val) , .en_11ac = (_val)
#else
#define COUNTRY_CHPLAN_ASSIGN_EN_11AC(_val)
#endif
#if RTW_DEF_MODULE_REGULATORY_CERT
#define COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_val) , .def_module_flags = (_val)
#else
#define COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_val)
#endif
/* has def_module_flags specified, used by common map and HAL dfference map */
#define COUNTRY_CHPLAN_ENT(_alpha2, _chplan, _en_11ac, _def_module_flags) \
{.alpha2 = (_alpha2), .chplan = (_chplan) \
COUNTRY_CHPLAN_ASSIGN_EN_11AC(_en_11ac) \
COUNTRY_CHPLAN_ASSIGN_DEF_MODULE_FLAGS(_def_module_flags) \
}
#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
#include "../platform/custom_country_chplan.h"
#elif RTW_DEF_MODULE_REGULATORY_CERT
/* leave def_module_flags empty, def_module_flags check is done on country_chplan_map */
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AE_HMC_M2) /* 2013 certify */
static const struct country_chplan RTL8821AE_HMC_M2_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("CL", 0x30, 1, 0), /* Chile */
COUNTRY_CHPLAN_ENT("CN", 0x51, 1, 0), /* China */
COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
COUNTRY_CHPLAN_ENT("MY", 0x47, 1, 0), /* Malaysia */
COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821AU) /* 2014 certify */
static const struct country_chplan RTL8821AU_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0), /* Russia(fac/gost), Kaliningrad */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AENF_NGFF) /* 2014 certify */
static const struct country_chplan RTL8812AENF_NGFF_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8812AEBT_HMC) /* 2013 certify */
static const struct country_chplan RTL8812AEBT_HMC_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("CA", 0x34, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("RU", 0x59, 0, 0), /* Russia(fac/gost), Kaliningrad */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("UA", 0x36, 0, 0), /* Ukraine */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8188EE_HMC_M2) /* 2012 certify */
static const struct country_chplan RTL8188EE_HMC_M2_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0), /* Barbados */
COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0), /* Haiti */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0), /* Seychelles */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
COUNTRY_CHPLAN_ENT("VC", 0x34, 1, 0), /* Saint Vincent and the Grenadines */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BE_HMC_M2) /* 2013 certify */
static const struct country_chplan RTL8723BE_HMC_M2_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
COUNTRY_CHPLAN_ENT("BS", 0x34, 1, 0), /* Bahamas */
COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723BS_NGFF1216) /* 2014 certify */
static const struct country_chplan RTL8723BS_NGFF1216_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("BB", 0x34, 1, 0), /* Barbados */
COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
COUNTRY_CHPLAN_ENT("HT", 0x34, 1, 0), /* Haiti */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8192EEBT_HMC_M2) /* 2013 certify */
static const struct country_chplan RTL8192EEBT_HMC_M2_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("AW", 0x34, 1, 0), /* Aruba */
COUNTRY_CHPLAN_ENT("CA", 0x20, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("CO", 0x34, 1, 0), /* Colombia */
COUNTRY_CHPLAN_ENT("CR", 0x34, 1, 0), /* Costa Rica */
COUNTRY_CHPLAN_ENT("DO", 0x34, 1, 0), /* Dominican Republic */
COUNTRY_CHPLAN_ENT("EC", 0x34, 1, 0), /* Ecuador */
COUNTRY_CHPLAN_ENT("GT", 0x34, 1, 0), /* Guatemala */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
COUNTRY_CHPLAN_ENT("NI", 0x34, 1, 0), /* Nicaragua */
COUNTRY_CHPLAN_ENT("PA", 0x34, 1, 0), /* Panama */
COUNTRY_CHPLAN_ENT("PE", 0x34, 1, 0), /* Peru */
COUNTRY_CHPLAN_ENT("PR", 0x34, 1, 0), /* Puerto Rico */
COUNTRY_CHPLAN_ENT("PY", 0x34, 1, 0), /* Paraguay */
COUNTRY_CHPLAN_ENT("SC", 0x34, 1, 0), /* Seychelles */
COUNTRY_CHPLAN_ENT("ST", 0x34, 1, 0), /* Sao Tome and Principe */
COUNTRY_CHPLAN_ENT("TW", 0x39, 1, 0), /* Taiwan */
COUNTRY_CHPLAN_ENT("US", 0x34, 1, 0), /* United States of America (USA) */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8723DE_NGFF1630) /* 2016 certify */
static const struct country_chplan RTL8723DE_NGFF1630_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("CA", 0x2A, 1, 0), /* Canada */
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
COUNTRY_CHPLAN_ENT("MX", 0x34, 1, 0), /* Mexico */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8822BE) /* 2016 certify */
static const struct country_chplan RTL8822BE_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
};
#endif
#if (RTW_DEF_MODULE_REGULATORY_CERT & RTW_MODULE_RTL8821CE) /* 2016 certify */
static const struct country_chplan RTL8821CE_country_chplan_exc_map[] = {
COUNTRY_CHPLAN_ENT("KR", 0x28, 1, 0), /* South Korea */
};
#endif
/**
* rtw_def_module_get_chplan_from_country -
* @country_code: string of country code
* @return:
* Return NULL for case referring to common map
*/
static const struct country_chplan *rtw_def_module_get_chplan_from_country(const char *country_code)
{
const struct country_chplan *ent = NULL;
const struct country_chplan *hal_map = NULL;
u16 hal_map_sz = 0;
int i;
/* TODO: runtime selection for multi driver */
#if (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AE_HMC_M2)
hal_map = RTL8821AE_HMC_M2_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8821AE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821AU)
hal_map = RTL8821AU_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8821AU_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AENF_NGFF)
hal_map = RTL8812AENF_NGFF_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8812AENF_NGFF_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8812AEBT_HMC)
hal_map = RTL8812AEBT_HMC_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8812AEBT_HMC_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8188EE_HMC_M2)
hal_map = RTL8188EE_HMC_M2_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8188EE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BE_HMC_M2)
hal_map = RTL8723BE_HMC_M2_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8723BE_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723BS_NGFF1216)
hal_map = RTL8723BS_NGFF1216_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8723BS_NGFF1216_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8192EEBT_HMC_M2)
hal_map = RTL8192EEBT_HMC_M2_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8192EEBT_HMC_M2_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8723DE_NGFF1630)
hal_map = RTL8723DE_NGFF1630_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8723DE_NGFF1630_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8822BE)
hal_map = RTL8822BE_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8822BE_country_chplan_exc_map) / sizeof(struct country_chplan);
#elif (RTW_DEF_MODULE_REGULATORY_CERT == RTW_MODULE_RTL8821CE)
hal_map = RTL8821CE_country_chplan_exc_map;
hal_map_sz = sizeof(RTL8821CE_country_chplan_exc_map) / sizeof(struct country_chplan);
#endif
if (hal_map == NULL || hal_map_sz == 0)
goto exit;
for (i = 0; i < hal_map_sz; i++) {
if (strncmp(country_code, hal_map[i].alpha2, 2) == 0) {
ent = &hal_map[i];
break;
}
}
exit:
return ent;
}
#endif /* CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP or RTW_DEF_MODULE_REGULATORY_CERT */
static const struct country_chplan country_chplan_map[] = {
COUNTRY_CHPLAN_ENT("AD", 0x26, 1, 0x000), /* Andorra */
COUNTRY_CHPLAN_ENT("AE", 0x35, 1, 0x7FB), /* United Arab Emirates */
COUNTRY_CHPLAN_ENT("AF", 0x42, 1, 0x000), /* Afghanistan */
COUNTRY_CHPLAN_ENT("AG", 0x76, 1, 0x000), /* Antigua & Barbuda */
COUNTRY_CHPLAN_ENT("AI", 0x26, 1, 0x000), /* Anguilla(UK) */
COUNTRY_CHPLAN_ENT("AL", 0x26, 1, 0x7F1), /* Albania */
COUNTRY_CHPLAN_ENT("AM", 0x26, 1, 0x6B0), /* Armenia */
COUNTRY_CHPLAN_ENT("AN", 0x76, 1, 0x7F1), /* Netherlands Antilles */
COUNTRY_CHPLAN_ENT("AO", 0x47, 1, 0x6E0), /* Angola */
COUNTRY_CHPLAN_ENT("AQ", 0x26, 1, 0x000), /* Antarctica */
COUNTRY_CHPLAN_ENT("AR", 0x61, 1, 0x7F3), /* Argentina */
COUNTRY_CHPLAN_ENT("AS", 0x76, 1, 0x000), /* American Samoa */
COUNTRY_CHPLAN_ENT("AT", 0x26, 1, 0x7FB), /* Austria */
COUNTRY_CHPLAN_ENT("AU", 0x45, 1, 0x7FB), /* Australia */
COUNTRY_CHPLAN_ENT("AW", 0x76, 1, 0x0B0), /* Aruba */
COUNTRY_CHPLAN_ENT("AZ", 0x26, 1, 0x7F1), /* Azerbaijan */
COUNTRY_CHPLAN_ENT("BA", 0x26, 1, 0x7F1), /* Bosnia & Herzegovina */
COUNTRY_CHPLAN_ENT("BB", 0x76, 1, 0x650), /* Barbados */
COUNTRY_CHPLAN_ENT("BD", 0x26, 1, 0x7F1), /* Bangladesh */
COUNTRY_CHPLAN_ENT("BE", 0x26, 1, 0x7FB), /* Belgium */
COUNTRY_CHPLAN_ENT("BF", 0x26, 1, 0x6B0), /* Burkina Faso */
COUNTRY_CHPLAN_ENT("BG", 0x26, 1, 0x7F1), /* Bulgaria */
COUNTRY_CHPLAN_ENT("BH", 0x48, 1, 0x7F1), /* Bahrain */
COUNTRY_CHPLAN_ENT("BI", 0x26, 1, 0x6B0), /* Burundi */
COUNTRY_CHPLAN_ENT("BJ", 0x26, 1, 0x6B0), /* Benin */
COUNTRY_CHPLAN_ENT("BM", 0x76, 1, 0x600), /* Bermuda (UK) */
COUNTRY_CHPLAN_ENT("BN", 0x47, 1, 0x610), /* Brunei */
COUNTRY_CHPLAN_ENT("BO", 0x73, 1, 0x7F1), /* Bolivia */
COUNTRY_CHPLAN_ENT("BR", 0x62, 1, 0x7F1), /* Brazil */
COUNTRY_CHPLAN_ENT("BS", 0x76, 1, 0x620), /* Bahamas */
COUNTRY_CHPLAN_ENT("BT", 0x26, 1, 0x000), /* Bhutan */
COUNTRY_CHPLAN_ENT("BV", 0x26, 1, 0x000), /* Bouvet Island (Norway) */
COUNTRY_CHPLAN_ENT("BW", 0x35, 1, 0x6F1), /* Botswana */
COUNTRY_CHPLAN_ENT("BY", 0x26, 1, 0x7F1), /* Belarus */
COUNTRY_CHPLAN_ENT("BZ", 0x76, 1, 0x000), /* Belize */
COUNTRY_CHPLAN_ENT("CA", 0x2B, 1, 0x7FB), /* Canada */
COUNTRY_CHPLAN_ENT("CC", 0x26, 1, 0x000), /* Cocos (Keeling) Islands (Australia) */
COUNTRY_CHPLAN_ENT("CD", 0x26, 1, 0x6B0), /* Congo, Republic of the */
COUNTRY_CHPLAN_ENT("CF", 0x26, 1, 0x6B0), /* Central African Republic */
COUNTRY_CHPLAN_ENT("CG", 0x26, 1, 0x6B0), /* Congo, Democratic Republic of the. Zaire */
COUNTRY_CHPLAN_ENT("CH", 0x26, 1, 0x7FB), /* Switzerland */
COUNTRY_CHPLAN_ENT("CI", 0x42, 1, 0x7F1), /* Cote d'Ivoire */
COUNTRY_CHPLAN_ENT("CK", 0x26, 1, 0x000), /* Cook Islands */
COUNTRY_CHPLAN_ENT("CL", 0x2D, 1, 0x7F1), /* Chile */
COUNTRY_CHPLAN_ENT("CM", 0x26, 1, 0x6B0), /* Cameroon */
COUNTRY_CHPLAN_ENT("CN", 0x48, 1, 0x7FB), /* China */
COUNTRY_CHPLAN_ENT("CO", 0x76, 1, 0x7F1), /* Colombia */
COUNTRY_CHPLAN_ENT("CR", 0x76, 1, 0x7F1), /* Costa Rica */
COUNTRY_CHPLAN_ENT("CV", 0x26, 1, 0x6B0), /* Cape Verde */
COUNTRY_CHPLAN_ENT("CX", 0x45, 1, 0x000), /* Christmas Island (Australia) */
COUNTRY_CHPLAN_ENT("CY", 0x26, 1, 0x7FB), /* Cyprus */
COUNTRY_CHPLAN_ENT("CZ", 0x26, 1, 0x7FB), /* Czech Republic */
COUNTRY_CHPLAN_ENT("DE", 0x26, 1, 0x7FB), /* Germany */
COUNTRY_CHPLAN_ENT("DJ", 0x26, 1, 0x680), /* Djibouti */
COUNTRY_CHPLAN_ENT("DK", 0x26, 1, 0x7FB), /* Denmark */
COUNTRY_CHPLAN_ENT("DM", 0x76, 1, 0x000), /* Dominica */
COUNTRY_CHPLAN_ENT("DO", 0x76, 1, 0x7F1), /* Dominican Republic */
COUNTRY_CHPLAN_ENT("DZ", 0x26, 1, 0x7F1), /* Algeria */
COUNTRY_CHPLAN_ENT("EC", 0x76, 1, 0x7F1), /* Ecuador */
COUNTRY_CHPLAN_ENT("EE", 0x26, 1, 0x7FB), /* Estonia */
COUNTRY_CHPLAN_ENT("EG", 0x47, 1, 0x7F1), /* Egypt */
COUNTRY_CHPLAN_ENT("EH", 0x47, 1, 0x680), /* Western Sahara */
COUNTRY_CHPLAN_ENT("ER", 0x26, 1, 0x000), /* Eritrea */
COUNTRY_CHPLAN_ENT("ES", 0x26, 1, 0x7FB), /* Spain, Canary Islands, Ceuta, Melilla */
COUNTRY_CHPLAN_ENT("ET", 0x26, 1, 0x4B0), /* Ethiopia */
COUNTRY_CHPLAN_ENT("FI", 0x26, 1, 0x7FB), /* Finland */
COUNTRY_CHPLAN_ENT("FJ", 0x76, 1, 0x600), /* Fiji */
COUNTRY_CHPLAN_ENT("FK", 0x26, 1, 0x000), /* Falkland Islands (Islas Malvinas) (UK) */
COUNTRY_CHPLAN_ENT("FM", 0x76, 1, 0x000), /* Micronesia, Federated States of (USA) */
COUNTRY_CHPLAN_ENT("FO", 0x26, 1, 0x000), /* Faroe Islands (Denmark) */
COUNTRY_CHPLAN_ENT("FR", 0x26, 1, 0x7FB), /* France */
COUNTRY_CHPLAN_ENT("GA", 0x26, 1, 0x6B0), /* Gabon */
COUNTRY_CHPLAN_ENT("GB", 0x26, 1, 0x7FB), /* Great Britain (United Kingdom; England) */
COUNTRY_CHPLAN_ENT("GD", 0x76, 1, 0x0B0), /* Grenada */
COUNTRY_CHPLAN_ENT("GE", 0x26, 1, 0x600), /* Georgia */
COUNTRY_CHPLAN_ENT("GF", 0x26, 1, 0x080), /* French Guiana */
COUNTRY_CHPLAN_ENT("GG", 0x26, 1, 0x000), /* Guernsey (UK) */
COUNTRY_CHPLAN_ENT("GH", 0x26, 1, 0x7F1), /* Ghana */
COUNTRY_CHPLAN_ENT("GI", 0x26, 1, 0x600), /* Gibraltar (UK) */
COUNTRY_CHPLAN_ENT("GL", 0x26, 1, 0x600), /* Greenland (Denmark) */
COUNTRY_CHPLAN_ENT("GM", 0x26, 1, 0x6B0), /* Gambia */
COUNTRY_CHPLAN_ENT("GN", 0x26, 1, 0x610), /* Guinea */
COUNTRY_CHPLAN_ENT("GP", 0x26, 1, 0x600), /* Guadeloupe (France) */
COUNTRY_CHPLAN_ENT("GQ", 0x26, 1, 0x6B0), /* Equatorial Guinea */
COUNTRY_CHPLAN_ENT("GR", 0x26, 1, 0x7FB), /* Greece */
COUNTRY_CHPLAN_ENT("GS", 0x26, 1, 0x000), /* South Georgia and the Sandwich Islands (UK) */
COUNTRY_CHPLAN_ENT("GT", 0x61, 1, 0x7F1), /* Guatemala */
COUNTRY_CHPLAN_ENT("GU", 0x76, 1, 0x600), /* Guam (USA) */
COUNTRY_CHPLAN_ENT("GW", 0x26, 1, 0x6B0), /* Guinea-Bissau */
COUNTRY_CHPLAN_ENT("GY", 0x44, 1, 0x000), /* Guyana */
COUNTRY_CHPLAN_ENT("HK", 0x35, 1, 0x7FB), /* Hong Kong */
COUNTRY_CHPLAN_ENT("HM", 0x45, 1, 0x000), /* Heard and McDonald Islands (Australia) */
COUNTRY_CHPLAN_ENT("HN", 0x32, 1, 0x7F1), /* Honduras */
COUNTRY_CHPLAN_ENT("HR", 0x26, 1, 0x7F9), /* Croatia */
COUNTRY_CHPLAN_ENT("HT", 0x76, 1, 0x650), /* Haiti */
COUNTRY_CHPLAN_ENT("HU", 0x26, 1, 0x7FB), /* Hungary */
COUNTRY_CHPLAN_ENT("ID", 0x3D, 0, 0x7F3), /* Indonesia */
COUNTRY_CHPLAN_ENT("IE", 0x26, 1, 0x7FB), /* Ireland */
COUNTRY_CHPLAN_ENT("IL", 0x47, 1, 0x7F1), /* Israel */
COUNTRY_CHPLAN_ENT("IM", 0x26, 1, 0x000), /* Isle of Man (UK) */
COUNTRY_CHPLAN_ENT("IN", 0x48, 1, 0x7F1), /* India */
COUNTRY_CHPLAN_ENT("IO", 0x26, 1, 0x000), /* British Indian Ocean Territory (UK) */
COUNTRY_CHPLAN_ENT("IQ", 0x26, 1, 0x000), /* Iraq */
COUNTRY_CHPLAN_ENT("IR", 0x26, 0, 0x000), /* Iran */
COUNTRY_CHPLAN_ENT("IS", 0x26, 1, 0x7FB), /* Iceland */
COUNTRY_CHPLAN_ENT("IT", 0x26, 1, 0x7FB), /* Italy */
COUNTRY_CHPLAN_ENT("JE", 0x26, 1, 0x000), /* Jersey (UK) */
COUNTRY_CHPLAN_ENT("JM", 0x32, 1, 0x7F1), /* Jamaica */
COUNTRY_CHPLAN_ENT("JO", 0x49, 1, 0x7FB), /* Jordan */
COUNTRY_CHPLAN_ENT("JP", 0x27, 1, 0x7FF), /* Japan- Telec */
COUNTRY_CHPLAN_ENT("KE", 0x47, 1, 0x7F9), /* Kenya */
COUNTRY_CHPLAN_ENT("KG", 0x26, 1, 0x7F1), /* Kyrgyzstan */
COUNTRY_CHPLAN_ENT("KH", 0x26, 1, 0x7F1), /* Cambodia */
COUNTRY_CHPLAN_ENT("KI", 0x26, 1, 0x000), /* Kiribati */
COUNTRY_CHPLAN_ENT("KM", 0x26, 1, 0x000), /* Comoros */
COUNTRY_CHPLAN_ENT("KN", 0x76, 1, 0x000), /* Saint Kitts and Nevis */
COUNTRY_CHPLAN_ENT("KR", 0x4B, 1, 0x7FB), /* South Korea */
COUNTRY_CHPLAN_ENT("KW", 0x47, 1, 0x7FB), /* Kuwait */
COUNTRY_CHPLAN_ENT("KY", 0x76, 1, 0x000), /* Cayman Islands (UK) */
COUNTRY_CHPLAN_ENT("KZ", 0x26, 1, 0x700), /* Kazakhstan */
COUNTRY_CHPLAN_ENT("LA", 0x26, 1, 0x000), /* Laos */
COUNTRY_CHPLAN_ENT("LB", 0x26, 1, 0x7F1), /* Lebanon */
COUNTRY_CHPLAN_ENT("LC", 0x76, 1, 0x000), /* Saint Lucia */
COUNTRY_CHPLAN_ENT("LI", 0x26, 1, 0x7FB), /* Liechtenstein */
COUNTRY_CHPLAN_ENT("LK", 0x26, 1, 0x7F1), /* Sri Lanka */
COUNTRY_CHPLAN_ENT("LR", 0x26, 1, 0x6B0), /* Liberia */
COUNTRY_CHPLAN_ENT("LS", 0x26, 1, 0x7F1), /* Lesotho */
COUNTRY_CHPLAN_ENT("LT", 0x26, 1, 0x7FB), /* Lithuania */
COUNTRY_CHPLAN_ENT("LU", 0x26, 1, 0x7FB), /* Luxembourg */
COUNTRY_CHPLAN_ENT("LV", 0x26, 1, 0x7FB), /* Latvia */
COUNTRY_CHPLAN_ENT("LY", 0x26, 1, 0x000), /* Libya */
COUNTRY_CHPLAN_ENT("MA", 0x47, 1, 0x7F1), /* Morocco */
COUNTRY_CHPLAN_ENT("MC", 0x26, 1, 0x7FB), /* Monaco */
COUNTRY_CHPLAN_ENT("MD", 0x26, 1, 0x7F1), /* Moldova */
COUNTRY_CHPLAN_ENT("ME", 0x26, 1, 0x7F1), /* Montenegro */
COUNTRY_CHPLAN_ENT("MF", 0x76, 1, 0x000), /* Saint Martin */
COUNTRY_CHPLAN_ENT("MG", 0x26, 1, 0x620), /* Madagascar */
COUNTRY_CHPLAN_ENT("MH", 0x76, 1, 0x000), /* Marshall Islands (USA) */
COUNTRY_CHPLAN_ENT("MK", 0x26, 1, 0x7F1), /* Republic of Macedonia (FYROM) */
COUNTRY_CHPLAN_ENT("ML", 0x26, 1, 0x6B0), /* Mali */
COUNTRY_CHPLAN_ENT("MM", 0x26, 1, 0x000), /* Burma (Myanmar) */
COUNTRY_CHPLAN_ENT("MN", 0x26, 1, 0x000), /* Mongolia */
COUNTRY_CHPLAN_ENT("MO", 0x35, 1, 0x600), /* Macau */
COUNTRY_CHPLAN_ENT("MP", 0x76, 1, 0x000), /* Northern Mariana Islands (USA) */
COUNTRY_CHPLAN_ENT("MQ", 0x26, 1, 0x640), /* Martinique (France) */
COUNTRY_CHPLAN_ENT("MR", 0x26, 1, 0x6A0), /* Mauritania */
COUNTRY_CHPLAN_ENT("MS", 0x26, 1, 0x000), /* Montserrat (UK) */
COUNTRY_CHPLAN_ENT("MT", 0x26, 1, 0x7FB), /* Malta */
COUNTRY_CHPLAN_ENT("MU", 0x26, 1, 0x6B0), /* Mauritius */
COUNTRY_CHPLAN_ENT("MV", 0x47, 1, 0x000), /* Maldives */
COUNTRY_CHPLAN_ENT("MW", 0x26, 1, 0x6B0), /* Malawi */
COUNTRY_CHPLAN_ENT("MX", 0x4D, 1, 0x7F1), /* Mexico */
COUNTRY_CHPLAN_ENT("MY", 0x63, 1, 0x7F1), /* Malaysia */
COUNTRY_CHPLAN_ENT("MZ", 0x26, 1, 0x7F1), /* Mozambique */
COUNTRY_CHPLAN_ENT("NA", 0x26, 1, 0x700), /* Namibia */
COUNTRY_CHPLAN_ENT("NC", 0x26, 1, 0x000), /* New Caledonia */
COUNTRY_CHPLAN_ENT("NE", 0x26, 1, 0x6B0), /* Niger */
COUNTRY_CHPLAN_ENT("NF", 0x45, 1, 0x000), /* Norfolk Island (Australia) */
COUNTRY_CHPLAN_ENT("NG", 0x75, 1, 0x7F9), /* Nigeria */
COUNTRY_CHPLAN_ENT("NI", 0x76, 1, 0x7F1), /* Nicaragua */
COUNTRY_CHPLAN_ENT("NL", 0x26, 1, 0x7FB), /* Netherlands */
COUNTRY_CHPLAN_ENT("NO", 0x26, 1, 0x7FB), /* Norway */
COUNTRY_CHPLAN_ENT("NP", 0x48, 1, 0x6F0), /* Nepal */
COUNTRY_CHPLAN_ENT("NR", 0x26, 1, 0x000), /* Nauru */
COUNTRY_CHPLAN_ENT("NU", 0x45, 1, 0x000), /* Niue */
COUNTRY_CHPLAN_ENT("NZ", 0x45, 1, 0x7FB), /* New Zealand */
COUNTRY_CHPLAN_ENT("OM", 0x26, 1, 0x7F9), /* Oman */
COUNTRY_CHPLAN_ENT("PA", 0x76, 1, 0x7F1), /* Panama */
COUNTRY_CHPLAN_ENT("PE", 0x76, 1, 0x7F1), /* Peru */
COUNTRY_CHPLAN_ENT("PF", 0x26, 1, 0x000), /* French Polynesia (France) */
COUNTRY_CHPLAN_ENT("PG", 0x35, 1, 0x7F1), /* Papua New Guinea */
COUNTRY_CHPLAN_ENT("PH", 0x35, 1, 0x7F1), /* Philippines */
COUNTRY_CHPLAN_ENT("PK", 0x51, 1, 0x7F1), /* Pakistan */
COUNTRY_CHPLAN_ENT("PL", 0x26, 1, 0x7FB), /* Poland */
COUNTRY_CHPLAN_ENT("PM", 0x26, 1, 0x000), /* Saint Pierre and Miquelon (France) */
COUNTRY_CHPLAN_ENT("PR", 0x76, 1, 0x7F1), /* Puerto Rico */
COUNTRY_CHPLAN_ENT("PT", 0x26, 1, 0x7FB), /* Portugal */
COUNTRY_CHPLAN_ENT("PW", 0x76, 1, 0x000), /* Palau */
COUNTRY_CHPLAN_ENT("PY", 0x76, 1, 0x7F1), /* Paraguay */
COUNTRY_CHPLAN_ENT("QA", 0x35, 1, 0x7F9), /* Qatar */
COUNTRY_CHPLAN_ENT("RE", 0x26, 1, 0x000), /* Reunion (France) */
COUNTRY_CHPLAN_ENT("RO", 0x26, 1, 0x7F1), /* Romania */
COUNTRY_CHPLAN_ENT("RS", 0x26, 1, 0x7F1), /* Serbia, Kosovo */
COUNTRY_CHPLAN_ENT("RU", 0x59, 1, 0x7FB), /* Russia(fac/gost), Kaliningrad */
COUNTRY_CHPLAN_ENT("RW", 0x26, 1, 0x0B0), /* Rwanda */
COUNTRY_CHPLAN_ENT("SA", 0x35, 1, 0x7FB), /* Saudi Arabia */
COUNTRY_CHPLAN_ENT("SB", 0x26, 1, 0x000), /* Solomon Islands */
COUNTRY_CHPLAN_ENT("SC", 0x76, 1, 0x690), /* Seychelles */
COUNTRY_CHPLAN_ENT("SE", 0x26, 1, 0x7FB), /* Sweden */
COUNTRY_CHPLAN_ENT("SG", 0x35, 1, 0x7FB), /* Singapore */
COUNTRY_CHPLAN_ENT("SH", 0x26, 1, 0x000), /* Saint Helena (UK) */
COUNTRY_CHPLAN_ENT("SI", 0x26, 1, 0x7FB), /* Slovenia */
COUNTRY_CHPLAN_ENT("SJ", 0x26, 1, 0x000), /* Svalbard (Norway) */
COUNTRY_CHPLAN_ENT("SK", 0x26, 1, 0x7FB), /* Slovakia */
COUNTRY_CHPLAN_ENT("SL", 0x26, 1, 0x6B0), /* Sierra Leone */
COUNTRY_CHPLAN_ENT("SM", 0x26, 1, 0x000), /* San Marino */
COUNTRY_CHPLAN_ENT("SN", 0x26, 1, 0x7F1), /* Senegal */
COUNTRY_CHPLAN_ENT("SO", 0x26, 1, 0x000), /* Somalia */
COUNTRY_CHPLAN_ENT("SR", 0x74, 1, 0x000), /* Suriname */
COUNTRY_CHPLAN_ENT("ST", 0x76, 1, 0x680), /* Sao Tome and Principe */
COUNTRY_CHPLAN_ENT("SV", 0x30, 1, 0x7F1), /* El Salvador */
COUNTRY_CHPLAN_ENT("SX", 0x76, 1, 0x000), /* Sint Marteen */
COUNTRY_CHPLAN_ENT("SZ", 0x26, 1, 0x020), /* Swaziland */
COUNTRY_CHPLAN_ENT("TC", 0x26, 1, 0x000), /* Turks and Caicos Islands (UK) */
COUNTRY_CHPLAN_ENT("TD", 0x26, 1, 0x6B0), /* Chad */
COUNTRY_CHPLAN_ENT("TF", 0x26, 1, 0x680), /* French Southern and Antarctic Lands (FR Southern Territories) */
COUNTRY_CHPLAN_ENT("TG", 0x26, 1, 0x6B0), /* Togo */
COUNTRY_CHPLAN_ENT("TH", 0x35, 1, 0x7F1), /* Thailand */
COUNTRY_CHPLAN_ENT("TJ", 0x26, 1, 0x640), /* Tajikistan */
COUNTRY_CHPLAN_ENT("TK", 0x45, 1, 0x000), /* Tokelau */
COUNTRY_CHPLAN_ENT("TM", 0x26, 1, 0x000), /* Turkmenistan */
COUNTRY_CHPLAN_ENT("TN", 0x47, 1, 0x7F1), /* Tunisia */
COUNTRY_CHPLAN_ENT("TO", 0x26, 1, 0x000), /* Tonga */
COUNTRY_CHPLAN_ENT("TR", 0x26, 1, 0x7F1), /* Turkey, Northern Cyprus */
COUNTRY_CHPLAN_ENT("TT", 0x76, 1, 0x3F1), /* Trinidad & Tobago */
COUNTRY_CHPLAN_ENT("TV", 0x21, 0, 0x000), /* Tuvalu */
COUNTRY_CHPLAN_ENT("TW", 0x76, 1, 0x7FF), /* Taiwan */
COUNTRY_CHPLAN_ENT("TZ", 0x26, 1, 0x6F0), /* Tanzania */
COUNTRY_CHPLAN_ENT("UA", 0x36, 1, 0x7FB), /* Ukraine */
COUNTRY_CHPLAN_ENT("UG", 0x26, 1, 0x6F1), /* Uganda */
COUNTRY_CHPLAN_ENT("US", 0x76, 1, 0x7FF), /* United States of America (USA) */
COUNTRY_CHPLAN_ENT("UY", 0x30, 1, 0x7F1), /* Uruguay */
COUNTRY_CHPLAN_ENT("UZ", 0x47, 1, 0x6F0), /* Uzbekistan */
COUNTRY_CHPLAN_ENT("VA", 0x26, 1, 0x000), /* Holy See (Vatican City) */
COUNTRY_CHPLAN_ENT("VC", 0x76, 1, 0x010), /* Saint Vincent and the Grenadines */
COUNTRY_CHPLAN_ENT("VE", 0x30, 1, 0x7F1), /* Venezuela */
COUNTRY_CHPLAN_ENT("VG", 0x76, 1, 0x000), /* British Virgin Islands (UK) */
COUNTRY_CHPLAN_ENT("VI", 0x76, 1, 0x000), /* United States Virgin Islands (USA) */
COUNTRY_CHPLAN_ENT("VN", 0x35, 1, 0x7F1), /* Vietnam */
COUNTRY_CHPLAN_ENT("VU", 0x26, 1, 0x000), /* Vanuatu */
COUNTRY_CHPLAN_ENT("WF", 0x26, 1, 0x000), /* Wallis and Futuna (France) */
COUNTRY_CHPLAN_ENT("WS", 0x76, 1, 0x000), /* Samoa */
COUNTRY_CHPLAN_ENT("YE", 0x26, 1, 0x040), /* Yemen */
COUNTRY_CHPLAN_ENT("YT", 0x26, 1, 0x680), /* Mayotte (France) */
COUNTRY_CHPLAN_ENT("ZA", 0x35, 1, 0x7F1), /* South Africa */
COUNTRY_CHPLAN_ENT("ZM", 0x26, 1, 0x6B0), /* Zambia */
COUNTRY_CHPLAN_ENT("ZW", 0x26, 1, 0x7F1), /* Zimbabwe */
};
/*
* rtw_get_chplan_from_country -
* @country_code: string of country code
*
* Return pointer of struct country_chplan entry or NULL when unsupported country_code is given
*/
const struct country_chplan *rtw_get_chplan_from_country(const char *country_code)
{
#if RTW_DEF_MODULE_REGULATORY_CERT
const struct country_chplan *exc_ent = NULL;
#endif
const struct country_chplan *ent = NULL;
const struct country_chplan *map = NULL;
u16 map_sz = 0;
char code[2];
int i;
code[0] = alpha_to_upper(country_code[0]);
code[1] = alpha_to_upper(country_code[1]);
#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
map = CUSTOMIZED_country_chplan_map;
map_sz = sizeof(CUSTOMIZED_country_chplan_map) / sizeof(struct country_chplan);
#else
#if RTW_DEF_MODULE_REGULATORY_CERT
exc_ent = rtw_def_module_get_chplan_from_country(code);
#endif
map = country_chplan_map;
map_sz = sizeof(country_chplan_map) / sizeof(struct country_chplan);
#endif
for (i = 0; i < map_sz; i++) {
if (strncmp(code, map[i].alpha2, 2) == 0) {
ent = &map[i];
break;
}
}
#if RTW_DEF_MODULE_REGULATORY_CERT
if (!ent || !(COUNTRY_CHPLAN_DEF_MODULE_FALGS(ent) & RTW_DEF_MODULE_REGULATORY_CERT))
exc_ent = ent = NULL;
if (exc_ent)
ent = exc_ent;
#endif
return ent;
}
void dump_country_chplan(void *sel, const struct country_chplan *ent)
{
RTW_PRINT_SEL(sel, "\"%c%c\", 0x%02X%s\n"
, ent->alpha2[0], ent->alpha2[1], ent->chplan
, COUNTRY_CHPLAN_EN_11AC(ent) ? " ac" : ""
);
}
void dump_country_chplan_map(void *sel)
{
const struct country_chplan *ent;
u8 code[2];
#if RTW_DEF_MODULE_REGULATORY_CERT
RTW_PRINT_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT:0x%x\n", RTW_DEF_MODULE_REGULATORY_CERT);
#endif
#ifdef CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP
RTW_PRINT_SEL(sel, "CONFIG_CUSTOMIZED_COUNTRY_CHPLAN_MAP\n");
#endif
for (code[0] = 'A'; code[0] <= 'Z'; code[0]++) {
for (code[1] = 'A'; code[1] <= 'Z'; code[1]++) {
ent = rtw_get_chplan_from_country(code);
if (!ent)
continue;
dump_country_chplan(sel, ent);
}
}
}
void dump_chplan_id_list(void *sel)
{
u8 first = 1;
int i;
for (i = 0; i < RTW_CHPLAN_MAX; i++) {
if (!rtw_is_channel_plan_valid(i))
continue;
if (first) {
RTW_PRINT_SEL(sel, "0x%02X ", i);
first = 0;
} else
_RTW_PRINT_SEL(sel, "0x%02X ", i);
}
_RTW_PRINT_SEL(sel, "0x7F\n");
}
void dump_chplan_test(void *sel)
{
int i, j;
/* check invalid channel */
for (i = 0; i < RTW_RD_2G_MAX; i++) {
for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan2G[i]); j++) {
if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan2G[i], j)) == 0)
RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan2G[i], j), i, j);
}
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
for (i = 0; i < RTW_RD_5G_MAX; i++) {
for (j = 0; j < CH_LIST_LEN(RTW_ChannelPlan5G[i]); j++) {
if (rtw_ch2freq(CH_LIST_CH(RTW_ChannelPlan5G[i], j)) == 0)
RTW_PRINT_SEL(sel, "invalid ch:%u at (%d,%d)\n", CH_LIST_CH(RTW_ChannelPlan5G[i], j), i, j);
}
}
#endif
}
void dump_chplan_ver(void *sel)
{
RTW_PRINT_SEL(sel, "%s-%s\n", RTW_DOMAIN_MAP_VER, RTW_COUNTRY_MAP_VER);
}
================================================
FILE: core/rtw_chplan.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2018 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __RTW_CHPLAN_H__
#define __RTW_CHPLAN_H__
enum rtw_chplan_id {
/* ===== 0x00 ~ 0x1F, legacy channel plan ===== */
RTW_CHPLAN_FCC = 0x00,
RTW_CHPLAN_IC = 0x01,
RTW_CHPLAN_ETSI = 0x02,
RTW_CHPLAN_SPAIN = 0x03,
RTW_CHPLAN_FRANCE = 0x04,
RTW_CHPLAN_MKK = 0x05,
RTW_CHPLAN_MKK1 = 0x06,
RTW_CHPLAN_ISRAEL = 0x07,
RTW_CHPLAN_TELEC = 0x08,
RTW_CHPLAN_GLOBAL_DOAMIN = 0x09,
RTW_CHPLAN_WORLD_WIDE_13 = 0x0A,
RTW_CHPLAN_TAIWAN = 0x0B,
RTW_CHPLAN_CHINA = 0x0C,
RTW_CHPLAN_SINGAPORE_INDIA_MEXICO = 0x0D,
RTW_CHPLAN_KOREA = 0x0E,
RTW_CHPLAN_TURKEY = 0x0F,
RTW_CHPLAN_JAPAN = 0x10,
RTW_CHPLAN_FCC_NO_DFS = 0x11,
RTW_CHPLAN_JAPAN_NO_DFS = 0x12,
RTW_CHPLAN_WORLD_WIDE_5G = 0x13,
RTW_CHPLAN_TAIWAN_NO_DFS = 0x14,
/* ===== 0x20 ~ 0x7F, new channel plan ===== */
RTW_CHPLAN_WORLD_NULL = 0x20,
RTW_CHPLAN_ETSI1_NULL = 0x21,
RTW_CHPLAN_FCC1_NULL = 0x22,
RTW_CHPLAN_MKK1_NULL = 0x23,
RTW_CHPLAN_ETSI2_NULL = 0x24,
RTW_CHPLAN_FCC1_FCC1 = 0x25,
RTW_CHPLAN_WORLD_ETSI1 = 0x26,
RTW_CHPLAN_MKK1_MKK1 = 0x27,
RTW_CHPLAN_WORLD_KCC1 = 0x28,
RTW_CHPLAN_WORLD_FCC2 = 0x29,
RTW_CHPLAN_FCC2_NULL = 0x2A,
RTW_CHPLAN_IC1_IC2 = 0x2B,
RTW_CHPLAN_MKK2_NULL = 0x2C,
RTW_CHPLAN_WORLD_CHILE1= 0x2D,
RTW_CHPLAN_WORLD1_WORLD1 = 0x2E,
RTW_CHPLAN_WORLD_CHILE2 = 0x2F,
RTW_CHPLAN_WORLD_FCC3 = 0x30,
RTW_CHPLAN_WORLD_FCC4 = 0x31,
RTW_CHPLAN_WORLD_FCC5 = 0x32,
RTW_CHPLAN_WORLD_FCC6 = 0x33,
RTW_CHPLAN_FCC1_FCC7 = 0x34,
RTW_CHPLAN_WORLD_ETSI2 = 0x35,
RTW_CHPLAN_WORLD_ETSI3 = 0x36,
RTW_CHPLAN_MKK1_MKK2 = 0x37,
RTW_CHPLAN_MKK1_MKK3 = 0x38,
RTW_CHPLAN_FCC1_NCC1 = 0x39,
RTW_CHPLAN_ETSI1_ETSI1 = 0x3A,
RTW_CHPLAN_ETSI1_ACMA1 = 0x3B,
RTW_CHPLAN_ETSI1_ETSI6 = 0x3C,
RTW_CHPLAN_ETSI1_ETSI12 = 0x3D,
RTW_CHPLAN_KCC1_KCC2 = 0x3E,
RTW_CHPLAN_FCC1_FCC11 = 0x3F,
RTW_CHPLAN_FCC1_NCC2 = 0x40,
RTW_CHPLAN_GLOBAL_NULL = 0x41,
RTW_CHPLAN_ETSI1_ETSI4 = 0x42,
RTW_CHPLAN_FCC1_FCC2 = 0x43,
RTW_CHPLAN_FCC1_NCC3 = 0x44,
RTW_CHPLAN_WORLD_ACMA1 = 0x45,
RTW_CHPLAN_FCC1_FCC8 = 0x46,
RTW_CHPLAN_WORLD_ETSI6 = 0x47,
RTW_CHPLAN_WORLD_ETSI7 = 0x48,
RTW_CHPLAN_WORLD_ETSI8 = 0x49,
RTW_CHPLAN_IC2_IC2 = 0x4A,
RTW_CHPLAN_KCC1_KCC3 = 0x4B,
RTW_CHPLAN_FCC1_FCC15 = 0x4C,
RTW_CHPLAN_FCC2_MEX1 = 0x4D,
RTW_CHPLAN_ETSI1_ETSI22 = 0x4E,
RTW_CHPLAN_WORLD_ETSI9 = 0x50,
RTW_CHPLAN_WORLD_ETSI10 = 0x51,
RTW_CHPLAN_WORLD_ETSI11 = 0x52,
RTW_CHPLAN_FCC1_NCC4 = 0x53,
RTW_CHPLAN_WORLD_ETSI12 = 0x54,
RTW_CHPLAN_FCC1_FCC9 = 0x55,
RTW_CHPLAN_WORLD_ETSI13 = 0x56,
RTW_CHPLAN_FCC1_FCC10 = 0x57,
RTW_CHPLAN_MKK2_MKK4 = 0x58,
RTW_CHPLAN_WORLD_ETSI14 = 0x59,
RTW_CHPLAN_FCC1_FCC5 = 0x60,
RTW_CHPLAN_FCC2_FCC7 = 0x61,
RTW_CHPLAN_FCC2_FCC1 = 0x62,
RTW_CHPLAN_WORLD_ETSI15 = 0x63,
RTW_CHPLAN_MKK2_MKK5 = 0x64,
RTW_CHPLAN_ETSI1_ETSI16 = 0x65,
RTW_CHPLAN_FCC1_FCC14 = 0x66,
RTW_CHPLAN_FCC1_FCC12 = 0x67,
RTW_CHPLAN_FCC2_FCC14 = 0x68,
RTW_CHPLAN_FCC2_FCC12 = 0x69,
RTW_CHPLAN_ETSI1_ETSI17 = 0x6A,
RTW_CHPLAN_WORLD_FCC16 = 0x6B,
RTW_CHPLAN_WORLD_FCC13 = 0x6C,
RTW_CHPLAN_FCC2_FCC15 = 0x6D,
RTW_CHPLAN_WORLD_FCC12 = 0x6E,
RTW_CHPLAN_NULL_ETSI8 = 0x6F,
RTW_CHPLAN_NULL_ETSI18 = 0x70,
RTW_CHPLAN_NULL_ETSI17 = 0x71,
RTW_CHPLAN_NULL_ETSI19 = 0x72,
RTW_CHPLAN_WORLD_FCC7 = 0x73,
RTW_CHPLAN_FCC2_FCC17 = 0x74,
RTW_CHPLAN_WORLD_ETSI20 = 0x75,
RTW_CHPLAN_FCC2_FCC11 = 0x76,
RTW_CHPLAN_WORLD_ETSI21 = 0x77,
RTW_CHPLAN_FCC1_FCC18 = 0x78,
RTW_CHPLAN_MKK2_MKK1 = 0x79,
RTW_CHPLAN_MAX,
RTW_CHPLAN_REALTEK_DEFINE = 0x7F,
RTW_CHPLAN_UNSPECIFIED = 0xFF,
};
u8 rtw_chplan_get_default_regd(u8 id);
bool rtw_chplan_is_empty(u8 id);
#define rtw_is_channel_plan_valid(chplan) (((chplan) < RTW_CHPLAN_MAX || (chplan) == RTW_CHPLAN_REALTEK_DEFINE) && !rtw_chplan_is_empty(chplan))
#define rtw_is_legacy_channel_plan(chplan) ((chplan) < 0x20)
struct _RT_CHANNEL_INFO;
u8 init_channel_set(_adapter *padapter, u8 ChannelPlan, struct _RT_CHANNEL_INFO *channel_set);
#define IS_ALPHA2_NO_SPECIFIED(_alpha2) ((*((u16 *)(_alpha2))) == 0xFFFF)
#define RTW_MODULE_RTL8821AE_HMC_M2 BIT0 /* RTL8821AE(HMC + M.2) */
#define RTW_MODULE_RTL8821AU BIT1 /* RTL8821AU */
#define RTW_MODULE_RTL8812AENF_NGFF BIT2 /* RTL8812AENF(8812AE+8761)_NGFF */
#define RTW_MODULE_RTL8812AEBT_HMC BIT3 /* RTL8812AEBT(8812AE+8761)_HMC */
#define RTW_MODULE_RTL8188EE_HMC_M2 BIT4 /* RTL8188EE(HMC + M.2) */
#define RTW_MODULE_RTL8723BE_HMC_M2 BIT5 /* RTL8723BE(HMC + M.2) */
#define RTW_MODULE_RTL8723BS_NGFF1216 BIT6 /* RTL8723BS(NGFF1216) */
#define RTW_MODULE_RTL8192EEBT_HMC_M2 BIT7 /* RTL8192EEBT(8192EE+8761AU)_(HMC + M.2) */
#define RTW_MODULE_RTL8723DE_NGFF1630 BIT8 /* RTL8723DE(NGFF1630) */
#define RTW_MODULE_RTL8822BE BIT9 /* RTL8822BE */
#define RTW_MODULE_RTL8821CE BIT10 /* RTL8821CE */
struct country_chplan {
char alpha2[2];
u8 chplan;
#ifdef CONFIG_80211AC_VHT
u8 en_11ac;
#endif
#if RTW_DEF_MODULE_REGULATORY_CERT
u16 def_module_flags; /* RTW_MODULE_RTLXXX */
#endif
};
#ifdef CONFIG_80211AC_VHT
#define COUNTRY_CHPLAN_EN_11AC(_ent) ((_ent)->en_11ac)
#else
#define COUNTRY_CHPLAN_EN_11AC(_ent) 0
#endif
#if RTW_DEF_MODULE_REGULATORY_CERT
#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) ((_ent)->def_module_flags)
#else
#define COUNTRY_CHPLAN_DEF_MODULE_FALGS(_ent) 0
#endif
const struct country_chplan *rtw_get_chplan_from_country(const char *country_code);
void dump_country_chplan(void *sel, const struct country_chplan *ent);
void dump_country_chplan_map(void *sel);
void dump_chplan_id_list(void *sel);
void dump_chplan_test(void *sel);
void dump_chplan_ver(void *sel);
#endif /* __RTW_CHPLAN_H__ */
================================================
FILE: core/rtw_cmd.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_CMD_C_
#include
#include
#ifndef DBG_CMD_EXECUTE
#define DBG_CMD_EXECUTE 0
#endif
/*
Caller and the rtw_cmd_thread can protect cmd_q by spin_lock.
No irqsave is necessary.
*/
sint _rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
{
sint res = _SUCCESS;
_rtw_init_sema(&(pcmdpriv->cmd_queue_sema), 0);
/* _rtw_init_sema(&(pcmdpriv->cmd_done_sema), 0); */
_rtw_init_sema(&(pcmdpriv->start_cmdthread_sema), 0);
_rtw_init_queue(&(pcmdpriv->cmd_queue));
/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
pcmdpriv->cmd_seq = 1;
pcmdpriv->cmd_allocated_buf = rtw_zmalloc(MAX_CMDSZ + CMDBUFF_ALIGN_SZ);
if (pcmdpriv->cmd_allocated_buf == NULL) {
res = _FAIL;
goto exit;
}
pcmdpriv->cmd_buf = pcmdpriv->cmd_allocated_buf + CMDBUFF_ALIGN_SZ - ((SIZE_PTR)(pcmdpriv->cmd_allocated_buf) & (CMDBUFF_ALIGN_SZ - 1));
pcmdpriv->rsp_allocated_buf = rtw_zmalloc(MAX_RSPSZ + 4);
if (pcmdpriv->rsp_allocated_buf == NULL) {
res = _FAIL;
goto exit;
}
pcmdpriv->rsp_buf = pcmdpriv->rsp_allocated_buf + 4 - ((SIZE_PTR)(pcmdpriv->rsp_allocated_buf) & 3);
pcmdpriv->cmd_issued_cnt = pcmdpriv->cmd_done_cnt = pcmdpriv->rsp_cnt = 0;
_rtw_mutex_init(&pcmdpriv->sctx_mutex);
exit:
return res;
}
#ifdef CONFIG_C2H_WK
static void c2h_wk_callback(_workitem *work)
{
struct evt_priv *evtpriv = container_of(work, struct evt_priv, c2h_wk);
_adapter *adapter = container_of(evtpriv, _adapter, evtpriv);
u8 *c2h_evt;
c2h_id_filter direct_hdl_filter = rtw_hal_c2h_id_handle_directly;
u8 id, seq, plen;
u8 *payload;
evtpriv->c2h_wk_alive = _TRUE;
while (!rtw_cbuf_empty(evtpriv->c2h_queue)) {
c2h_evt = (u8 *)rtw_cbuf_pop(evtpriv->c2h_queue);
if (c2h_evt != NULL) {
/* This C2H event is read, clear it */
c2h_evt_clear(adapter);
} else {
c2h_evt = (u8 *)rtw_malloc(C2H_REG_LEN);
if (c2h_evt == NULL) {
rtw_warn_on(1);
continue;
}
/* This C2H event is not read, read & clear now */
if (rtw_hal_c2h_evt_read(adapter, c2h_evt) != _SUCCESS) {
rtw_mfree(c2h_evt, C2H_REG_LEN);
continue;
}
}
/* Special pointer to trigger c2h_evt_clear only */
if ((void *)c2h_evt == (void *)evtpriv)
continue;
if (!rtw_hal_c2h_valid(adapter, c2h_evt)
|| rtw_hal_c2h_reg_hdr_parse(adapter, c2h_evt, &id, &seq, &plen, &payload) != _SUCCESS
) {
rtw_mfree(c2h_evt, C2H_REG_LEN);
continue;
}
if (direct_hdl_filter(adapter, id, seq, plen, payload) == _TRUE) {
/* Handle directly */
rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
rtw_mfree(c2h_evt, C2H_REG_LEN);
} else {
/* Enqueue into cmd_thread for others */
rtw_c2h_reg_wk_cmd(adapter, c2h_evt);
rtw_mfree(c2h_evt, C2H_REG_LEN);
}
}
evtpriv->c2h_wk_alive = _FALSE;
}
#endif /* CONFIG_C2H_WK */
sint _rtw_init_evt_priv(struct evt_priv *pevtpriv)
{
sint res = _SUCCESS;
#ifdef CONFIG_H2CLBK
_rtw_init_sema(&(pevtpriv->lbkevt_done), 0);
pevtpriv->lbkevt_limit = 0;
pevtpriv->lbkevt_num = 0;
pevtpriv->cmdevt_parm = NULL;
#endif
/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
ATOMIC_SET(&pevtpriv->event_seq, 0);
pevtpriv->evt_done_cnt = 0;
#ifdef CONFIG_EVENT_THREAD_MODE
_rtw_init_sema(&(pevtpriv->evt_notify), 0);
pevtpriv->evt_allocated_buf = rtw_zmalloc(MAX_EVTSZ + 4);
if (pevtpriv->evt_allocated_buf == NULL) {
res = _FAIL;
goto exit;
}
pevtpriv->evt_buf = pevtpriv->evt_allocated_buf + 4 - ((unsigned int)(pevtpriv->evt_allocated_buf) & 3);
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pevtpriv->allocated_c2h_mem = rtw_zmalloc(C2H_MEM_SZ + 4);
if (pevtpriv->allocated_c2h_mem == NULL) {
res = _FAIL;
goto exit;
}
pevtpriv->c2h_mem = pevtpriv->allocated_c2h_mem + 4\
- ((u32)(pevtpriv->allocated_c2h_mem) & 3);
#endif /* end of CONFIG_SDIO_HCI */
_rtw_init_queue(&(pevtpriv->evt_queue));
exit:
#endif /* end of CONFIG_EVENT_THREAD_MODE */
#ifdef CONFIG_C2H_WK
_init_workitem(&pevtpriv->c2h_wk, c2h_wk_callback, NULL);
pevtpriv->c2h_wk_alive = _FALSE;
pevtpriv->c2h_queue = rtw_cbuf_alloc(C2H_QUEUE_MAX_LEN + 1);
#endif
return res;
}
void _rtw_free_evt_priv(struct evt_priv *pevtpriv)
{
#ifdef CONFIG_EVENT_THREAD_MODE
_rtw_free_sema(&(pevtpriv->evt_notify));
if (pevtpriv->evt_allocated_buf)
rtw_mfree(pevtpriv->evt_allocated_buf, MAX_EVTSZ + 4);
#endif
#ifdef CONFIG_C2H_WK
_cancel_workitem_sync(&pevtpriv->c2h_wk);
while (pevtpriv->c2h_wk_alive)
rtw_msleep_os(10);
while (!rtw_cbuf_empty(pevtpriv->c2h_queue)) {
void *c2h;
c2h = rtw_cbuf_pop(pevtpriv->c2h_queue);
if (c2h != NULL && c2h != (void *)pevtpriv)
rtw_mfree(c2h, 16);
}
rtw_cbuf_free(pevtpriv->c2h_queue);
#endif
}
void _rtw_free_cmd_priv(struct cmd_priv *pcmdpriv)
{
if (pcmdpriv) {
_rtw_spinlock_free(&(pcmdpriv->cmd_queue.lock));
_rtw_free_sema(&(pcmdpriv->cmd_queue_sema));
/* _rtw_free_sema(&(pcmdpriv->cmd_done_sema)); */
_rtw_free_sema(&(pcmdpriv->start_cmdthread_sema));
if (pcmdpriv->cmd_allocated_buf)
rtw_mfree(pcmdpriv->cmd_allocated_buf, MAX_CMDSZ + CMDBUFF_ALIGN_SZ);
if (pcmdpriv->rsp_allocated_buf)
rtw_mfree(pcmdpriv->rsp_allocated_buf, MAX_RSPSZ + 4);
_rtw_mutex_free(&pcmdpriv->sctx_mutex);
}
}
/*
Calling Context:
rtw_enqueue_cmd can only be called between kernel thread,
since only spin_lock is used.
ISR/Call-Back functions can't call this sub-function.
*/
#ifdef DBG_CMD_QUEUE
extern u8 dump_cmd_id;
#endif
sint _rtw_enqueue_cmd(_queue *queue, struct cmd_obj *obj, bool to_head)
{
_irqL irqL;
if (obj == NULL)
goto exit;
/* _enter_critical_bh(&queue->lock, &irqL); */
_enter_critical(&queue->lock, &irqL);
if (to_head)
rtw_list_insert_head(&obj->list, &queue->queue);
else
rtw_list_insert_tail(&obj->list, &queue->queue);
#ifdef DBG_CMD_QUEUE
if (dump_cmd_id) {
printk("%s===> cmdcode:0x%02x\n", __FUNCTION__, obj->cmdcode);
if (obj->cmdcode == GEN_CMD_CODE(_Set_MLME_EVT)) {
if (obj->parmbuf) {
struct C2HEvent_Header *pc2h_evt_hdr = (struct C2HEvent_Header *)(obj->parmbuf);
printk("pc2h_evt_hdr->ID:0x%02x(%d)\n", pc2h_evt_hdr->ID, pc2h_evt_hdr->ID);
}
}
if (obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
if (obj->parmbuf) {
struct drvextra_cmd_parm *pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)(obj->parmbuf);
printk("pdrvextra_cmd_parm->ec_id:0x%02x\n", pdrvextra_cmd_parm->ec_id);
}
}
}
if (queue->queue.prev->next != &queue->queue) {
RTW_INFO("[%d] head %p, tail %p, tail->prev->next %p[tail], tail->next %p[head]\n", __LINE__,
&queue->queue, queue->queue.prev, queue->queue.prev->prev->next, queue->queue.prev->next);
RTW_INFO("==========%s============\n", __FUNCTION__);
RTW_INFO("head:%p,obj_addr:%p\n", &queue->queue, obj);
RTW_INFO("padapter: %p\n", obj->padapter);
RTW_INFO("cmdcode: 0x%02x\n", obj->cmdcode);
RTW_INFO("res: %d\n", obj->res);
RTW_INFO("parmbuf: %p\n", obj->parmbuf);
RTW_INFO("cmdsz: %d\n", obj->cmdsz);
RTW_INFO("rsp: %p\n", obj->rsp);
RTW_INFO("rspsz: %d\n", obj->rspsz);
RTW_INFO("sctx: %p\n", obj->sctx);
RTW_INFO("list->next: %p\n", obj->list.next);
RTW_INFO("list->prev: %p\n", obj->list.prev);
}
#endif /* DBG_CMD_QUEUE */
/* _exit_critical_bh(&queue->lock, &irqL); */
_exit_critical(&queue->lock, &irqL);
exit:
return _SUCCESS;
}
struct cmd_obj *_rtw_dequeue_cmd(_queue *queue)
{
_irqL irqL;
struct cmd_obj *obj;
/* _enter_critical_bh(&(queue->lock), &irqL); */
_enter_critical(&queue->lock, &irqL);
#ifdef DBG_CMD_QUEUE
if (queue->queue.prev->next != &queue->queue) {
RTW_INFO("[%d] head %p, tail %p, tail->prev->next %p[tail], tail->next %p[head]\n", __LINE__,
&queue->queue, queue->queue.prev, queue->queue.prev->prev->next, queue->queue.prev->next);
}
#endif /* DBG_CMD_QUEUE */
if (rtw_is_list_empty(&(queue->queue)))
obj = NULL;
else {
obj = LIST_CONTAINOR(get_next(&(queue->queue)), struct cmd_obj, list);
#ifdef DBG_CMD_QUEUE
if (queue->queue.prev->next != &queue->queue) {
RTW_INFO("==========%s============\n", __FUNCTION__);
RTW_INFO("head:%p,obj_addr:%p\n", &queue->queue, obj);
RTW_INFO("padapter: %p\n", obj->padapter);
RTW_INFO("cmdcode: 0x%02x\n", obj->cmdcode);
RTW_INFO("res: %d\n", obj->res);
RTW_INFO("parmbuf: %p\n", obj->parmbuf);
RTW_INFO("cmdsz: %d\n", obj->cmdsz);
RTW_INFO("rsp: %p\n", obj->rsp);
RTW_INFO("rspsz: %d\n", obj->rspsz);
RTW_INFO("sctx: %p\n", obj->sctx);
RTW_INFO("list->next: %p\n", obj->list.next);
RTW_INFO("list->prev: %p\n", obj->list.prev);
}
if (dump_cmd_id) {
RTW_INFO("%s===> cmdcode:0x%02x\n", __FUNCTION__, obj->cmdcode);
if (obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
if (obj->parmbuf) {
struct drvextra_cmd_parm *pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)(obj->parmbuf);
printk("pdrvextra_cmd_parm->ec_id:0x%02x\n", pdrvextra_cmd_parm->ec_id);
}
}
}
#endif /* DBG_CMD_QUEUE */
rtw_list_delete(&obj->list);
}
/* _exit_critical_bh(&(queue->lock), &irqL); */
_exit_critical(&queue->lock, &irqL);
return obj;
}
u32 rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
{
u32 res;
res = _rtw_init_cmd_priv(pcmdpriv);
return res;
}
u32 rtw_init_evt_priv(struct evt_priv *pevtpriv)
{
int res;
res = _rtw_init_evt_priv(pevtpriv);
return res;
}
void rtw_free_evt_priv(struct evt_priv *pevtpriv)
{
_rtw_free_evt_priv(pevtpriv);
}
void rtw_free_cmd_priv(struct cmd_priv *pcmdpriv)
{
_rtw_free_cmd_priv(pcmdpriv);
}
int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj);
int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
{
u8 bAllow = _FALSE; /* set to _TRUE to allow enqueuing cmd when hw_init_completed is _FALSE */
#ifdef SUPPORT_HW_RFOFF_DETECTED
/* To decide allow or not */
if ((adapter_to_pwrctl(pcmdpriv->padapter)->bHWPwrPindetect)
&& (!pcmdpriv->padapter->registrypriv.usbss_enable)
) {
if (cmd_obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
struct drvextra_cmd_parm *pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)cmd_obj->parmbuf;
if (pdrvextra_cmd_parm->ec_id == POWER_SAVING_CTRL_WK_CID) {
/* RTW_INFO("==>enqueue POWER_SAVING_CTRL_WK_CID\n"); */
bAllow = _TRUE;
}
}
}
#endif
if (cmd_obj->cmdcode == GEN_CMD_CODE(_SetChannelPlan))
bAllow = _TRUE;
if (cmd_obj->no_io)
bAllow = _TRUE;
if ((!rtw_is_hw_init_completed(pcmdpriv->padapter) && (bAllow == _FALSE))
|| ATOMIC_READ(&(pcmdpriv->cmdthd_running)) == _FALSE /* com_thread not running */
) {
if (DBG_CMD_EXECUTE)
RTW_INFO(ADPT_FMT" drop "CMD_FMT" hw_init_completed:%u, cmdthd_running:%u\n", ADPT_ARG(cmd_obj->padapter)
, CMD_ARG(cmd_obj), rtw_get_hw_init_completed(cmd_obj->padapter), ATOMIC_READ(&pcmdpriv->cmdthd_running));
if (0)
rtw_warn_on(1);
return _FAIL;
}
return _SUCCESS;
}
u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
{
int res = _FAIL;
PADAPTER padapter = pcmdpriv->padapter;
if (cmd_obj == NULL)
goto exit;
cmd_obj->padapter = padapter;
#ifdef CONFIG_CONCURRENT_MODE
/* change pcmdpriv to primary's pcmdpriv */
if (!is_primary_adapter(padapter))
pcmdpriv = &(GET_PRIMARY_ADAPTER(padapter)->cmdpriv);
#endif
res = rtw_cmd_filter(pcmdpriv, cmd_obj);
if ((_FAIL == res) || (cmd_obj->cmdsz > MAX_CMDSZ)) {
if (cmd_obj->cmdsz > MAX_CMDSZ) {
RTW_INFO("%s failed due to obj->cmdsz(%d) > MAX_CMDSZ(%d)\n", __func__, cmd_obj->cmdsz, MAX_CMDSZ);
rtw_warn_on(1);
}
if (cmd_obj->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
struct drvextra_cmd_parm *extra_parm = (struct drvextra_cmd_parm *)cmd_obj->parmbuf;
if (extra_parm->pbuf && extra_parm->size > 0)
rtw_mfree(extra_parm->pbuf, extra_parm->size);
}
rtw_free_cmd_obj(cmd_obj);
goto exit;
}
res = _rtw_enqueue_cmd(&pcmdpriv->cmd_queue, cmd_obj, 0);
if (res == _SUCCESS)
_rtw_up_sema(&pcmdpriv->cmd_queue_sema);
exit:
return res;
}
struct cmd_obj *rtw_dequeue_cmd(struct cmd_priv *pcmdpriv)
{
struct cmd_obj *cmd_obj;
cmd_obj = _rtw_dequeue_cmd(&pcmdpriv->cmd_queue);
return cmd_obj;
}
void rtw_cmd_clr_isr(struct cmd_priv *pcmdpriv)
{
pcmdpriv->cmd_done_cnt++;
/* _rtw_up_sema(&(pcmdpriv->cmd_done_sema)); */
}
void rtw_free_cmd_obj(struct cmd_obj *pcmd)
{
if (pcmd->parmbuf != NULL) {
/* free parmbuf in cmd_obj */
rtw_mfree((unsigned char *)pcmd->parmbuf, pcmd->cmdsz);
}
if (pcmd->rsp != NULL) {
if (pcmd->rspsz != 0) {
/* free rsp in cmd_obj */
rtw_mfree((unsigned char *)pcmd->rsp, pcmd->rspsz);
}
}
/* free cmd_obj */
rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
}
void rtw_stop_cmd_thread(_adapter *adapter)
{
if (adapter->cmdThread) {
_rtw_up_sema(&adapter->cmdpriv.cmd_queue_sema);
rtw_thread_stop(adapter->cmdThread);
adapter->cmdThread = NULL;
}
}
thread_return rtw_cmd_thread(thread_context context)
{
u8 ret;
struct cmd_obj *pcmd;
u8 *pcmdbuf, *prspbuf;
systime cmd_start_time;
u32 cmd_process_time;
u8(*cmd_hdl)(_adapter *padapter, u8 *pbuf);
void (*pcmd_callback)(_adapter *dev, struct cmd_obj *pcmd);
PADAPTER padapter = (PADAPTER)context;
struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
struct drvextra_cmd_parm *extra_parm = NULL;
_irqL irqL;
thread_enter("RTW_CMD_THREAD");
pcmdbuf = pcmdpriv->cmd_buf;
prspbuf = pcmdpriv->rsp_buf;
ATOMIC_SET(&(pcmdpriv->cmdthd_running), _TRUE);
_rtw_up_sema(&pcmdpriv->start_cmdthread_sema);
while (1) {
if (_rtw_down_sema(&pcmdpriv->cmd_queue_sema) == _FAIL) {
RTW_PRINT(FUNC_ADPT_FMT" _rtw_down_sema(&pcmdpriv->cmd_queue_sema) return _FAIL, break\n", FUNC_ADPT_ARG(padapter));
break;
}
if (RTW_CANNOT_RUN(padapter)) {
RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
FUNC_ADPT_ARG(padapter),
rtw_is_drv_stopped(padapter) ? "True" : "False",
rtw_is_surprise_removed(padapter) ? "True" : "False");
break;
}
_enter_critical(&pcmdpriv->cmd_queue.lock, &irqL);
if (rtw_is_list_empty(&(pcmdpriv->cmd_queue.queue))) {
/* RTW_INFO("%s: cmd queue is empty!\n", __func__); */
_exit_critical(&pcmdpriv->cmd_queue.lock, &irqL);
continue;
}
_exit_critical(&pcmdpriv->cmd_queue.lock, &irqL);
_next:
if (RTW_CANNOT_RUN(padapter)) {
RTW_PRINT("%s: DriverStopped(%s) SurpriseRemoved(%s) break at line %d\n",
__func__
, rtw_is_drv_stopped(padapter) ? "True" : "False"
, rtw_is_surprise_removed(padapter) ? "True" : "False"
, __LINE__);
break;
}
pcmd = rtw_dequeue_cmd(pcmdpriv);
if (!pcmd) {
#ifdef CONFIG_LPS_LCLK
rtw_unregister_cmd_alive(padapter);
#endif
continue;
}
cmd_start_time = rtw_get_current_time();
pcmdpriv->cmd_issued_cnt++;
if (pcmd->cmdsz > MAX_CMDSZ) {
RTW_ERR("%s cmdsz:%d > MAX_CMDSZ:%d\n", __func__, pcmd->cmdsz, MAX_CMDSZ);
pcmd->res = H2C_PARAMETERS_ERROR;
goto post_process;
}
if (pcmd->cmdcode >= (sizeof(wlancmds) / sizeof(struct cmd_hdl))) {
RTW_ERR("%s undefined cmdcode:%d\n", __func__, pcmd->cmdcode);
pcmd->res = H2C_PARAMETERS_ERROR;
goto post_process;
}
cmd_hdl = wlancmds[pcmd->cmdcode].h2cfuns;
if (!cmd_hdl) {
RTW_ERR("%s no cmd_hdl for cmdcode:%d\n", __func__, pcmd->cmdcode);
pcmd->res = H2C_PARAMETERS_ERROR;
goto post_process;
}
if (_FAIL == rtw_cmd_filter(pcmdpriv, pcmd)) {
pcmd->res = H2C_DROPPED;
if (pcmd->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
extra_parm = (struct drvextra_cmd_parm *)pcmd->parmbuf;
if (extra_parm && extra_parm->pbuf && extra_parm->size > 0)
rtw_mfree(extra_parm->pbuf, extra_parm->size);
}
#ifdef CONFIG_DFS
else if (pcmd->cmdcode == GEN_CMD_CODE(_SetChannelSwitch))
adapter_to_rfctl(padapter)->csa_ch = 0;
#endif
goto post_process;
}
#ifdef CONFIG_LPS_LCLK
if (pcmd->no_io)
rtw_unregister_cmd_alive(padapter);
else {
if (rtw_register_cmd_alive(padapter) != _SUCCESS) {
if (DBG_CMD_EXECUTE)
RTW_PRINT("%s: wait to leave LPS_LCLK\n", __func__);
pcmd->res = H2C_ENQ_HEAD;
ret = _rtw_enqueue_cmd(&pcmdpriv->cmd_queue, pcmd, 1);
if (ret == _SUCCESS) {
if (DBG_CMD_EXECUTE)
RTW_INFO(ADPT_FMT" "CMD_FMT" ENQ_HEAD\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd));
continue;
}
RTW_INFO(ADPT_FMT" "CMD_FMT" ENQ_HEAD_FAIL\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd));
pcmd->res = H2C_ENQ_HEAD_FAIL;
rtw_warn_on(1);
}
}
#endif /* CONFIG_LPS_LCLK */
if (DBG_CMD_EXECUTE)
RTW_INFO(ADPT_FMT" "CMD_FMT" %sexecute\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd)
, pcmd->res == H2C_ENQ_HEAD ? "ENQ_HEAD " : (pcmd->res == H2C_ENQ_HEAD_FAIL ? "ENQ_HEAD_FAIL " : ""));
_rtw_memcpy(pcmdbuf, pcmd->parmbuf, pcmd->cmdsz);
ret = cmd_hdl(pcmd->padapter, pcmdbuf);
pcmd->res = ret;
pcmdpriv->cmd_seq++;
post_process:
_enter_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
if (pcmd->sctx) {
if (0)
RTW_PRINT(FUNC_ADPT_FMT" pcmd->sctx\n", FUNC_ADPT_ARG(pcmd->padapter));
if (pcmd->res == H2C_SUCCESS)
rtw_sctx_done(&pcmd->sctx);
else
rtw_sctx_done_err(&pcmd->sctx, RTW_SCTX_DONE_CMD_ERROR);
}
_exit_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
cmd_process_time = rtw_get_passing_time_ms(cmd_start_time);
if (cmd_process_time > 1000) {
RTW_INFO(ADPT_FMT" "CMD_FMT" process_time=%d\n", ADPT_ARG(pcmd->padapter), CMD_ARG(pcmd), cmd_process_time);
if (0)
rtw_warn_on(1);
}
/* call callback function for post-processed */
if (pcmd->cmdcode < (sizeof(rtw_cmd_callback) / sizeof(struct _cmd_callback))) {
pcmd_callback = rtw_cmd_callback[pcmd->cmdcode].callback;
if (pcmd_callback == NULL) {
rtw_free_cmd_obj(pcmd);
} else {
/* todo: !!! fill rsp_buf to pcmd->rsp if (pcmd->rsp!=NULL) */
pcmd_callback(pcmd->padapter, pcmd);/* need conider that free cmd_obj in rtw_cmd_callback */
}
} else {
rtw_free_cmd_obj(pcmd);
}
flush_signals_thread();
goto _next;
}
#ifdef CONFIG_LPS_LCLK
rtw_unregister_cmd_alive(padapter);
#endif
/* to avoid enqueue cmd after free all cmd_obj */
ATOMIC_SET(&(pcmdpriv->cmdthd_running), _FALSE);
/* free all cmd_obj resources */
do {
pcmd = rtw_dequeue_cmd(pcmdpriv);
if (pcmd == NULL)
break;
if (0)
RTW_INFO("%s: leaving... drop "CMD_FMT"\n", __func__, CMD_ARG(pcmd));
if (pcmd->cmdcode == GEN_CMD_CODE(_Set_Drv_Extra)) {
extra_parm = (struct drvextra_cmd_parm *)pcmd->parmbuf;
if (extra_parm->pbuf && extra_parm->size > 0)
rtw_mfree(extra_parm->pbuf, extra_parm->size);
}
#ifdef CONFIG_DFS
else if (pcmd->cmdcode == GEN_CMD_CODE(_SetChannelSwitch))
adapter_to_rfctl(padapter)->csa_ch = 0;
#endif
_enter_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
if (pcmd->sctx) {
if (0)
RTW_PRINT(FUNC_ADPT_FMT" pcmd->sctx\n", FUNC_ADPT_ARG(pcmd->padapter));
rtw_sctx_done_err(&pcmd->sctx, RTW_SCTX_DONE_CMD_DROP);
}
_exit_critical_mutex(&(pcmd->padapter->cmdpriv.sctx_mutex), NULL);
rtw_free_cmd_obj(pcmd);
} while (1);
RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(padapter));
rtw_thread_wait_stop();
return 0;
}
#ifdef CONFIG_EVENT_THREAD_MODE
u32 rtw_enqueue_evt(struct evt_priv *pevtpriv, struct evt_obj *obj)
{
_irqL irqL;
int res;
_queue *queue = &pevtpriv->evt_queue;
res = _SUCCESS;
if (obj == NULL) {
res = _FAIL;
goto exit;
}
_enter_critical_bh(&queue->lock, &irqL);
rtw_list_insert_tail(&obj->list, &queue->queue);
_exit_critical_bh(&queue->lock, &irqL);
/* rtw_evt_notify_isr(pevtpriv); */
exit:
return res;
}
struct evt_obj *rtw_dequeue_evt(_queue *queue)
{
_irqL irqL;
struct evt_obj *pevtobj;
_enter_critical_bh(&queue->lock, &irqL);
if (rtw_is_list_empty(&(queue->queue)))
pevtobj = NULL;
else {
pevtobj = LIST_CONTAINOR(get_next(&(queue->queue)), struct evt_obj, list);
rtw_list_delete(&pevtobj->list);
}
_exit_critical_bh(&queue->lock, &irqL);
return pevtobj;
}
void rtw_free_evt_obj(struct evt_obj *pevtobj)
{
if (pevtobj->parmbuf)
rtw_mfree((unsigned char *)pevtobj->parmbuf, pevtobj->evtsz);
rtw_mfree((unsigned char *)pevtobj, sizeof(struct evt_obj));
}
void rtw_evt_notify_isr(struct evt_priv *pevtpriv)
{
pevtpriv->evt_done_cnt++;
_rtw_up_sema(&(pevtpriv->evt_notify));
}
#endif
/*
u8 rtw_setstandby_cmd(unsigned char *adapter)
*/
u8 rtw_setstandby_cmd(_adapter *padapter, uint action)
{
struct cmd_obj *ph2c;
struct usb_suspend_parm *psetusbsuspend;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 ret = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
ret = _FAIL;
goto exit;
}
psetusbsuspend = (struct usb_suspend_parm *)rtw_zmalloc(sizeof(struct usb_suspend_parm));
if (psetusbsuspend == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
ret = _FAIL;
goto exit;
}
psetusbsuspend->action = action;
init_h2fwcmd_w_parm_no_rsp(ph2c, psetusbsuspend, GEN_CMD_CODE(_SetUsbSuspend));
ret = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return ret;
}
void rtw_init_sitesurvey_parm(_adapter *padapter, struct sitesurvey_parm *pparm)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
_rtw_memset(pparm, 0, sizeof(struct sitesurvey_parm));
pparm->scan_mode = pmlmepriv->scan_mode;
}
/*
rtw_sitesurvey_cmd(~)
### NOTE:#### (!!!!)
MUST TAKE CARE THAT BEFORE CALLING THIS FUNC, YOU SHOULD HAVE LOCKED pmlmepriv->lock
*/
u8 rtw_sitesurvey_cmd(_adapter *padapter, struct sitesurvey_parm *pparm)
{
u8 res = _FAIL;
struct cmd_obj *ph2c;
struct sitesurvey_parm *psurveyPara;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
#ifdef CONFIG_LPS
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_SCAN, 0);
#endif
#ifdef CONFIG_P2P_PS
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
p2p_ps_wk_cmd(padapter, P2P_PS_SCAN, 1);
#endif /* CONFIG_P2P_PS */
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL)
return _FAIL;
psurveyPara = (struct sitesurvey_parm *)rtw_zmalloc(sizeof(struct sitesurvey_parm));
if (psurveyPara == NULL) {
rtw_mfree((unsigned char *) ph2c, sizeof(struct cmd_obj));
return _FAIL;
}
if (pparm)
_rtw_memcpy(psurveyPara, pparm, sizeof(struct sitesurvey_parm));
else
psurveyPara->scan_mode = pmlmepriv->scan_mode;
rtw_free_network_queue(padapter, _FALSE);
init_h2fwcmd_w_parm_no_rsp(ph2c, psurveyPara, GEN_CMD_CODE(_SiteSurvey));
set_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
if (res == _SUCCESS) {
u32 scan_timeout_ms;
pmlmepriv->scan_start_time = rtw_get_current_time();
scan_timeout_ms = rtw_scan_timeout_decision(padapter);
mlme_set_scan_to_timer(pmlmepriv,scan_timeout_ms);
rtw_led_control(padapter, LED_CTL_SITE_SURVEY);
} else
_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
return res;
}
u8 rtw_setdatarate_cmd(_adapter *padapter, u8 *rateset)
{
struct cmd_obj *ph2c;
struct setdatarate_parm *pbsetdataratepara;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pbsetdataratepara = (struct setdatarate_parm *)rtw_zmalloc(sizeof(struct setdatarate_parm));
if (pbsetdataratepara == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, pbsetdataratepara, GEN_CMD_CODE(_SetDataRate));
#ifdef MP_FIRMWARE_OFFLOAD
pbsetdataratepara->curr_rateidx = *(u32 *)rateset;
/* _rtw_memcpy(pbsetdataratepara, rateset, sizeof(u32)); */
#else
pbsetdataratepara->mac_id = 5;
_rtw_memcpy(pbsetdataratepara->datarates, rateset, NumRates);
#endif
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_setbasicrate_cmd(_adapter *padapter, u8 *rateset)
{
struct cmd_obj *ph2c;
struct setbasicrate_parm *pssetbasicratepara;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pssetbasicratepara = (struct setbasicrate_parm *)rtw_zmalloc(sizeof(struct setbasicrate_parm));
if (pssetbasicratepara == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, pssetbasicratepara, _SetBasicRate_CMD_);
_rtw_memcpy(pssetbasicratepara->basicrates, rateset, NumRates);
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
/*
unsigned char rtw_setphy_cmd(unsigned char *adapter)
1. be called only after rtw_update_registrypriv_dev_network( ~) or mp testing program
2. for AdHoc/Ap mode or mp mode?
*/
u8 rtw_setphy_cmd(_adapter *padapter, u8 modem, u8 ch)
{
struct cmd_obj *ph2c;
struct setphy_parm *psetphypara;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
/* struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
* struct registry_priv* pregistry_priv = &padapter->registrypriv; */
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
psetphypara = (struct setphy_parm *)rtw_zmalloc(sizeof(struct setphy_parm));
if (psetphypara == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, psetphypara, _SetPhy_CMD_);
psetphypara->modem = modem;
psetphypara->rfchannel = ch;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_getmacreg_cmd(_adapter *padapter, u8 len, u32 addr)
{
struct cmd_obj *ph2c;
struct readMAC_parm *preadmacparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
preadmacparm = (struct readMAC_parm *)rtw_zmalloc(sizeof(struct readMAC_parm));
if (preadmacparm == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, preadmacparm, GEN_CMD_CODE(_GetMACReg));
preadmacparm->len = len;
preadmacparm->addr = addr;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void rtw_usb_catc_trigger_cmd(_adapter *padapter, const char *caller)
{
RTW_INFO("%s caller:%s\n", __func__, caller);
rtw_getmacreg_cmd(padapter, 1, 0x1c4);
}
u8 rtw_setbbreg_cmd(_adapter *padapter, u8 offset, u8 val)
{
struct cmd_obj *ph2c;
struct writeBB_parm *pwritebbparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pwritebbparm = (struct writeBB_parm *)rtw_zmalloc(sizeof(struct writeBB_parm));
if (pwritebbparm == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, pwritebbparm, GEN_CMD_CODE(_SetBBReg));
pwritebbparm->offset = offset;
pwritebbparm->value = val;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_getbbreg_cmd(_adapter *padapter, u8 offset, u8 *pval)
{
struct cmd_obj *ph2c;
struct readBB_parm *prdbbparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
prdbbparm = (struct readBB_parm *)rtw_zmalloc(sizeof(struct readBB_parm));
if (prdbbparm == NULL) {
rtw_mfree((unsigned char *) ph2c, sizeof(struct cmd_obj));
return _FAIL;
}
_rtw_init_listhead(&ph2c->list);
ph2c->cmdcode = GEN_CMD_CODE(_GetBBReg);
ph2c->parmbuf = (unsigned char *)prdbbparm;
ph2c->cmdsz = sizeof(struct readBB_parm);
ph2c->rsp = pval;
ph2c->rspsz = sizeof(struct readBB_rsp);
prdbbparm->offset = offset;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_setrfreg_cmd(_adapter *padapter, u8 offset, u32 val)
{
struct cmd_obj *ph2c;
struct writeRF_parm *pwriterfparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pwriterfparm = (struct writeRF_parm *)rtw_zmalloc(sizeof(struct writeRF_parm));
if (pwriterfparm == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, pwriterfparm, GEN_CMD_CODE(_SetRFReg));
pwriterfparm->offset = offset;
pwriterfparm->value = val;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_getrfreg_cmd(_adapter *padapter, u8 offset, u8 *pval)
{
struct cmd_obj *ph2c;
struct readRF_parm *prdrfparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
prdrfparm = (struct readRF_parm *)rtw_zmalloc(sizeof(struct readRF_parm));
if (prdrfparm == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
_rtw_init_listhead(&ph2c->list);
ph2c->cmdcode = GEN_CMD_CODE(_GetRFReg);
ph2c->parmbuf = (unsigned char *)prdrfparm;
ph2c->cmdsz = sizeof(struct readRF_parm);
ph2c->rsp = pval;
ph2c->rspsz = sizeof(struct readRF_rsp);
prdrfparm->offset = offset;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void rtw_getbbrfreg_cmdrsp_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
/* rtw_free_cmd_obj(pcmd); */
rtw_mfree((unsigned char *) pcmd->parmbuf, pcmd->cmdsz);
rtw_mfree((unsigned char *) pcmd, sizeof(struct cmd_obj));
#ifdef CONFIG_MP_INCLUDED
if (padapter->registrypriv.mp_mode == 1)
padapter->mppriv.workparam.bcompleted = _TRUE;
#endif
}
void rtw_readtssi_cmdrsp_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
rtw_mfree((unsigned char *) pcmd->parmbuf, pcmd->cmdsz);
rtw_mfree((unsigned char *) pcmd, sizeof(struct cmd_obj));
#ifdef CONFIG_MP_INCLUDED
if (padapter->registrypriv.mp_mode == 1)
padapter->mppriv.workparam.bcompleted = _TRUE;
#endif
}
static u8 rtw_createbss_cmd(_adapter *adapter, int flags, bool adhoc
, u8 ifbmp, u8 excl_ifbmp, s16 req_ch, s8 req_bw, s8 req_offset)
{
struct cmd_obj *cmdobj;
struct createbss_parm *parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
if (req_ch > 0 && req_bw >= 0 && req_offset >= 0) {
if (!rtw_chset_is_chbw_valid(adapter_to_chset(adapter), req_ch, req_bw, req_offset)) {
res = _FAIL;
goto exit;
}
}
/* prepare cmd parameter */
parm = (struct createbss_parm *)rtw_zmalloc(sizeof(*parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
if (adhoc) {
/* for now, adhoc doesn't support ch,bw,offset request */
parm->adhoc = 1;
} else {
parm->adhoc = 0;
parm->ifbmp = ifbmp;
parm->excl_ifbmp = excl_ifbmp;
parm->req_ch = req_ch;
parm->req_bw = req_bw;
parm->req_offset = req_offset;
}
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != createbss_hdl(adapter, (u8 *)parm))
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_CreateBss));
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 2000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
}
}
exit:
return res;
}
inline u8 rtw_create_ibss_cmd(_adapter *adapter, int flags)
{
return rtw_createbss_cmd(adapter, flags
, 1
, 0, 0
, 0, REQ_BW_NONE, REQ_OFFSET_NONE /* for now, adhoc doesn't support ch,bw,offset request */
);
}
inline u8 rtw_startbss_cmd(_adapter *adapter, int flags)
{
return rtw_createbss_cmd(adapter, flags
, 0
, BIT(adapter->iface_id), 0
, 0, REQ_BW_NONE, REQ_OFFSET_NONE /* excute entire AP setup cmd */
);
}
inline u8 rtw_change_bss_chbw_cmd(_adapter *adapter, int flags
, u8 ifbmp, u8 excl_ifbmp, s16 req_ch, s8 req_bw, s8 req_offset)
{
return rtw_createbss_cmd(adapter, flags
, 0
, ifbmp, excl_ifbmp
, req_ch, req_bw, req_offset
);
}
#ifdef CONFIG_RTW_80211R
static void rtw_ft_validate_akm_type(_adapter *padapter,
struct wlan_network *pnetwork)
{
struct security_priv *psecuritypriv = &(padapter->securitypriv);
struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
u32 tmp_len;
u8 *ptmp;
/*IEEE802.11-2012 Std. Table 8-101-AKM suite selectors*/
if (rtw_ft_valid_akm(padapter, psecuritypriv->rsn_akm_suite_type)) {
ptmp = rtw_get_ie(&pnetwork->network.IEs[12],
_MDIE_, &tmp_len, (pnetwork->network.IELength-12));
if (ptmp) {
pft_roam->mdid = *(u16 *)(ptmp+2);
pft_roam->ft_cap = *(ptmp+4);
RTW_INFO("FT: target " MAC_FMT " mdid=(0x%2x), capacity=(0x%2x)\n",
MAC_ARG(pnetwork->network.MacAddress), pft_roam->mdid, pft_roam->ft_cap);
rtw_ft_set_flags(padapter, RTW_FT_PEER_EN);
if (rtw_ft_otd_roam_en(padapter))
rtw_ft_set_flags(padapter, RTW_FT_PEER_OTD_EN);
} else {
/* Don't use FT roaming if target AP cannot support FT */
rtw_ft_clr_flags(padapter, (RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN));
rtw_ft_reset_status(padapter);
}
} else {
/* It could be a non-FT connection */
rtw_ft_clr_flags(padapter, (RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN));
rtw_ft_reset_status(padapter);
}
}
#endif
u8 rtw_joinbss_cmd(_adapter *padapter, struct wlan_network *pnetwork)
{
u8 *auth, res = _SUCCESS;
uint t_len = 0;
WLAN_BSSID_EX *psecnetwork;
struct cmd_obj *pcmd;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
#ifdef CONFIG_80211N_HT
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
#endif /* CONFIG_80211AC_VHT */
NDIS_802_11_NETWORK_INFRASTRUCTURE ndis_network_mode = pnetwork->network.InfrastructureMode;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
u32 tmp_len;
u8 *ptmp = NULL;
rtw_led_control(padapter, LED_CTL_START_TO_LINK);
pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd == NULL) {
res = _FAIL;
goto exit;
}
#if 0
/* for IEs is pointer */
t_len = sizeof(u32) + sizeof(NDIS_802_11_MAC_ADDRESS) + 2 +
sizeof(NDIS_802_11_SSID) + sizeof(u32) +
sizeof(NDIS_802_11_RSSI) + sizeof(NDIS_802_11_NETWORK_TYPE) +
sizeof(NDIS_802_11_CONFIGURATION) +
sizeof(NDIS_802_11_NETWORK_INFRASTRUCTURE) +
sizeof(NDIS_802_11_RATES_EX) + sizeof(WLAN_PHY_INFO) + sizeof(u32) + MAX_IE_SZ;
#endif
/* for IEs is fix buf size */
t_len = sizeof(WLAN_BSSID_EX);
/* for hidden ap to set fw_state here */
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) != _TRUE) {
switch (ndis_network_mode) {
case Ndis802_11IBSS:
set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
break;
case Ndis802_11Infrastructure:
set_fwstate(pmlmepriv, WIFI_STATION_STATE);
break;
default:
rtw_warn_on(1);
break;
}
}
pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pnetwork->network.IEs, pnetwork->network.IELength);
#ifdef CONFIG_80211AC_VHT
/* save AP beamform_cap info for BCM IOT issue */
if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM)
pvhtpriv->ap_is_mu_bfer =
get_vht_mu_bfer_cap(pnetwork->network.IEs,
pnetwork->network.IELength);
#endif
/*
Modified by Arvin 2015/05/13
Solution for allocating a new WLAN_BSSID_EX to avoid race condition issue between disconnect and joinbss
*/
psecnetwork = (WLAN_BSSID_EX *)rtw_zmalloc(sizeof(WLAN_BSSID_EX));
if (psecnetwork == NULL) {
if (pcmd != NULL)
rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
_rtw_memset(psecnetwork, 0, t_len);
_rtw_memcpy(psecnetwork, &pnetwork->network, get_WLAN_BSSID_EX_sz(&pnetwork->network));
auth = &psecuritypriv->authenticator_ie[0];
psecuritypriv->authenticator_ie[0] = (unsigned char)psecnetwork->IELength;
if ((psecnetwork->IELength - 12) < (256 - 1))
_rtw_memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], psecnetwork->IELength - 12);
else
_rtw_memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], (256 - 1));
psecnetwork->IELength = 0;
/* Added by Albert 2009/02/18 */
/* If the the driver wants to use the bssid to create the connection. */
/* If not, we have to copy the connecting AP's MAC address to it so that */
/* the driver just has the bssid information for PMKIDList searching. */
if (pmlmepriv->assoc_by_bssid == _FALSE)
_rtw_memcpy(&pmlmepriv->assoc_bssid[0], &pnetwork->network.MacAddress[0], ETH_ALEN);
/* copy fixed ie */
_rtw_memcpy(psecnetwork->IEs, pnetwork->network.IEs, 12);
psecnetwork->IELength = 12;
psecnetwork->IELength += rtw_restruct_sec_ie(padapter, psecnetwork->IEs + psecnetwork->IELength);
pqospriv->qos_option = 0;
if (pregistrypriv->wmm_enable) {
#ifdef CONFIG_WMMPS_STA
rtw_uapsd_use_default_setting(padapter);
#endif /* CONFIG_WMMPS_STA */
tmp_len = rtw_restruct_wmm_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0], pnetwork->network.IELength, psecnetwork->IELength);
if (psecnetwork->IELength != tmp_len) {
psecnetwork->IELength = tmp_len;
pqospriv->qos_option = 1; /* There is WMM IE in this corresp. beacon */
} else {
pqospriv->qos_option = 0;/* There is no WMM IE in this corresp. beacon */
}
}
#ifdef CONFIG_80211N_HT
phtpriv->ht_option = _FALSE;
if (pregistrypriv->ht_enable && is_supported_ht(pregistrypriv->wireless_mode)) {
ptmp = rtw_get_ie(&pnetwork->network.IEs[12], _HT_CAPABILITY_IE_, &tmp_len, pnetwork->network.IELength - 12);
if (ptmp && tmp_len > 0) {
/* Added by Albert 2010/06/23 */
/* For the WEP mode, we will use the bg mode to do the connection to avoid some IOT issue. */
/* Especially for Realtek 8192u SoftAP. */
if ((padapter->securitypriv.dot11PrivacyAlgrthm != _WEP40_) &&
(padapter->securitypriv.dot11PrivacyAlgrthm != _WEP104_) &&
(padapter->securitypriv.dot11PrivacyAlgrthm != _TKIP_)) {
rtw_ht_use_default_setting(padapter);
/* rtw_restructure_ht_ie */
rtw_restructure_ht_ie(padapter, &pnetwork->network.IEs[12], &psecnetwork->IEs[0],
pnetwork->network.IELength - 12, &psecnetwork->IELength,
pnetwork->network.Configuration.DSConfig);
}
}
}
#ifdef CONFIG_80211AC_VHT
pvhtpriv->vht_option = _FALSE;
if (phtpriv->ht_option
&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
&& is_supported_vht(pregistrypriv->wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
&& ((padapter->registrypriv.wifi_spec == 0) || (pnetwork->network.Configuration.DSConfig > 14))
) {
rtw_restructure_vht_ie(padapter, &pnetwork->network.IEs[0], &psecnetwork->IEs[0],
pnetwork->network.IELength, &psecnetwork->IELength);
}
#endif
#endif /* CONFIG_80211N_HT */
rtw_append_exented_cap(padapter, &psecnetwork->IEs[0], &psecnetwork->IELength);
#ifdef CONFIG_RTW_80211R
rtw_ft_validate_akm_type(padapter, pnetwork);
#endif
#if 0
psecuritypriv->supplicant_ie[0] = (u8)psecnetwork->IELength;
if (psecnetwork->IELength < (256 - 1))
_rtw_memcpy(&psecuritypriv->supplicant_ie[1], &psecnetwork->IEs[0], psecnetwork->IELength);
else
_rtw_memcpy(&psecuritypriv->supplicant_ie[1], &psecnetwork->IEs[0], (256 - 1));
#endif
pcmd->cmdsz = sizeof(WLAN_BSSID_EX);
_rtw_init_listhead(&pcmd->list);
pcmd->cmdcode = _JoinBss_CMD_;/* GEN_CMD_CODE(_JoinBss) */
pcmd->parmbuf = (unsigned char *)psecnetwork;
pcmd->rsp = NULL;
pcmd->rspsz = 0;
res = rtw_enqueue_cmd(pcmdpriv, pcmd);
exit:
return res;
}
u8 rtw_disassoc_cmd(_adapter *padapter, u32 deauth_timeout_ms, int flags) /* for sta_mode */
{
struct cmd_obj *cmdobj = NULL;
struct disconnect_parm *param = NULL;
struct cmd_priv *cmdpriv = &padapter->cmdpriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
/* prepare cmd parameter */
param = (struct disconnect_parm *)rtw_zmalloc(sizeof(*param));
if (param == NULL) {
res = _FAIL;
goto exit;
}
param->deauth_timeout_ms = deauth_timeout_ms;
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (disconnect_hdl(padapter, (u8 *)param) != H2C_SUCCESS)
res = _FAIL;
rtw_mfree((u8 *)param, sizeof(*param));
} else {
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)param, sizeof(*param));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, param, _DisConnect_CMD_);
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 2000);
}
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
}
}
exit:
return res;
}
u8 rtw_setopmode_cmd(_adapter *adapter, NDIS_802_11_NETWORK_INFRASTRUCTURE networktype, u8 flags)
{
struct cmd_obj *cmdobj;
struct setopmode_parm *parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
/* prepare cmd parameter */
parm = (struct setopmode_parm *)rtw_zmalloc(sizeof(*parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
parm->mode = (u8)networktype;
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != setopmode_hdl(adapter, (u8 *)parm))
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, _SetOpMode_CMD_);
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 2000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
}
}
exit:
return res;
}
u8 rtw_setstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 key_type, bool enqueue)
{
struct cmd_obj *ph2c;
struct set_stakey_parm *psetstakey_para;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct set_stakey_rsp *psetstakey_rsp = NULL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
u8 res = _SUCCESS;
psetstakey_para = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
if (psetstakey_para == NULL) {
res = _FAIL;
goto exit;
}
_rtw_memcpy(psetstakey_para->addr, sta->cmn.mac_addr, ETH_ALEN);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
psetstakey_para->algorithm = (unsigned char) psecuritypriv->dot11PrivacyAlgrthm;
else
GET_ENCRY_ALGO(psecuritypriv, sta, psetstakey_para->algorithm, _FALSE);
if (key_type == GROUP_KEY) {
_rtw_memcpy(&psetstakey_para->key, &psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey, 16);
psetstakey_para->gk = 1;
} else if (key_type == UNICAST_KEY)
_rtw_memcpy(&psetstakey_para->key, &sta->dot118021x_UncstKey, 16);
#ifdef CONFIG_TDLS
else if (key_type == TDLS_KEY) {
_rtw_memcpy(&psetstakey_para->key, sta->tpk.tk, 16);
psetstakey_para->algorithm = (u8)sta->dot118021XPrivacy;
}
#endif /* CONFIG_TDLS */
/* jeff: set this becasue at least sw key is ready */
padapter->securitypriv.busetkipkey = _TRUE;
if (enqueue) {
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
res = _FAIL;
goto exit;
}
psetstakey_rsp = (struct set_stakey_rsp *)rtw_zmalloc(sizeof(struct set_stakey_rsp));
if (psetstakey_rsp == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para, _SetStaKey_CMD_);
ph2c->rsp = (u8 *) psetstakey_rsp;
ph2c->rspsz = sizeof(struct set_stakey_rsp);
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
} else {
set_stakey_hdl(padapter, (u8 *)psetstakey_para);
rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
}
exit:
return res;
}
u8 rtw_clearstakey_cmd(_adapter *padapter, struct sta_info *sta, u8 enqueue)
{
struct cmd_obj *ph2c;
struct set_stakey_parm *psetstakey_para;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct set_stakey_rsp *psetstakey_rsp = NULL;
s16 cam_id = 0;
u8 res = _SUCCESS;
if (!sta) {
RTW_ERR("%s sta == NULL\n", __func__);
goto exit;
}
if (!enqueue) {
while ((cam_id = rtw_camid_search(padapter, sta->cmn.mac_addr, -1, -1)) >= 0) {
RTW_PRINT("clear key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(sta->cmn.mac_addr), cam_id);
clear_cam_entry(padapter, cam_id);
rtw_camid_free(padapter, cam_id);
}
} else {
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
psetstakey_para = (struct set_stakey_parm *)rtw_zmalloc(sizeof(struct set_stakey_parm));
if (psetstakey_para == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
psetstakey_rsp = (struct set_stakey_rsp *)rtw_zmalloc(sizeof(struct set_stakey_rsp));
if (psetstakey_rsp == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *) psetstakey_para, sizeof(struct set_stakey_parm));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para, _SetStaKey_CMD_);
ph2c->rsp = (u8 *) psetstakey_rsp;
ph2c->rspsz = sizeof(struct set_stakey_rsp);
_rtw_memcpy(psetstakey_para->addr, sta->cmn.mac_addr, ETH_ALEN);
psetstakey_para->algorithm = _NO_PRIVACY_;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
}
exit:
return res;
}
u8 rtw_setrttbl_cmd(_adapter *padapter, struct setratable_parm *prate_table)
{
struct cmd_obj *ph2c;
struct setratable_parm *psetrttblparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
psetrttblparm = (struct setratable_parm *)rtw_zmalloc(sizeof(struct setratable_parm));
if (psetrttblparm == NULL) {
rtw_mfree((unsigned char *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, psetrttblparm, GEN_CMD_CODE(_SetRaTable));
_rtw_memcpy(psetrttblparm, prate_table, sizeof(struct setratable_parm));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_getrttbl_cmd(_adapter *padapter, struct getratable_rsp *pval)
{
struct cmd_obj *ph2c;
struct getratable_parm *pgetrttblparm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pgetrttblparm = (struct getratable_parm *)rtw_zmalloc(sizeof(struct getratable_parm));
if (pgetrttblparm == NULL) {
rtw_mfree((unsigned char *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
/* init_h2fwcmd_w_parm_no_rsp(ph2c, psetrttblparm, GEN_CMD_CODE(_SetRaTable)); */
_rtw_init_listhead(&ph2c->list);
ph2c->cmdcode = GEN_CMD_CODE(_GetRaTable);
ph2c->parmbuf = (unsigned char *)pgetrttblparm;
ph2c->cmdsz = sizeof(struct getratable_parm);
ph2c->rsp = (u8 *)pval;
ph2c->rspsz = sizeof(struct getratable_rsp);
pgetrttblparm->rsvd = 0x0;
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_setassocsta_cmd(_adapter *padapter, u8 *mac_addr)
{
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct cmd_obj *ph2c;
struct set_assocsta_parm *psetassocsta_para;
struct set_stakey_rsp *psetassocsta_rsp = NULL;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
psetassocsta_para = (struct set_assocsta_parm *)rtw_zmalloc(sizeof(struct set_assocsta_parm));
if (psetassocsta_para == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
psetassocsta_rsp = (struct set_stakey_rsp *)rtw_zmalloc(sizeof(struct set_assocsta_rsp));
if (psetassocsta_rsp == NULL) {
rtw_mfree((u8 *) ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *) psetassocsta_para, sizeof(struct set_assocsta_parm));
return _FAIL;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, psetassocsta_para, _SetAssocSta_CMD_);
ph2c->rsp = (u8 *) psetassocsta_rsp;
ph2c->rspsz = sizeof(struct set_assocsta_rsp);
_rtw_memcpy(psetassocsta_para->addr, mac_addr, ETH_ALEN);
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_addbareq_cmd(_adapter *padapter, u8 tid, u8 *addr)
{
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct cmd_obj *ph2c;
struct addBaReq_parm *paddbareq_parm;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
paddbareq_parm = (struct addBaReq_parm *)rtw_zmalloc(sizeof(struct addBaReq_parm));
if (paddbareq_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
paddbareq_parm->tid = tid;
_rtw_memcpy(paddbareq_parm->addr, addr, ETH_ALEN);
init_h2fwcmd_w_parm_no_rsp(ph2c, paddbareq_parm, GEN_CMD_CODE(_AddBAReq));
/* RTW_INFO("rtw_addbareq_cmd, tid=%d\n", tid); */
/* rtw_enqueue_cmd(pcmdpriv, ph2c); */
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_addbarsp_cmd(_adapter *padapter, u8 *addr, u16 tid, u8 status, u8 size, u16 start_seq)
{
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct cmd_obj *ph2c;
struct addBaRsp_parm *paddBaRsp_parm;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
paddBaRsp_parm = (struct addBaRsp_parm *)rtw_zmalloc(sizeof(struct addBaRsp_parm));
if (paddBaRsp_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
_rtw_memcpy(paddBaRsp_parm->addr, addr, ETH_ALEN);
paddBaRsp_parm->tid = tid;
paddBaRsp_parm->status = status;
paddBaRsp_parm->size = size;
paddBaRsp_parm->start_seq = start_seq;
init_h2fwcmd_w_parm_no_rsp(ph2c, paddBaRsp_parm, GEN_CMD_CODE(_AddBARsp));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
/* add for CONFIG_IEEE80211W, none 11w can use it */
u8 rtw_reset_securitypriv_cmd(_adapter *padapter)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = RESET_SECURITYPRIV;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
/* rtw_enqueue_cmd(pcmdpriv, ph2c); */
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void free_assoc_resources_hdl(_adapter *padapter, u8 lock_scanned_queue)
{
rtw_free_assoc_resources(padapter, lock_scanned_queue);
}
u8 rtw_free_assoc_resources_cmd(_adapter *padapter, u8 lock_scanned_queue, int flags)
{
struct cmd_obj *cmd;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
if (flags & RTW_CMDF_DIRECTLY) {
free_assoc_resources_hdl(padapter, lock_scanned_queue);
}
else {
cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmd == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)cmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = FREE_ASSOC_RESOURCES;
pdrvextra_cmd_parm->type = lock_scanned_queue;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(cmd, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
if (flags & RTW_CMDF_WAIT_ACK) {
cmd->sctx = &sctx;
rtw_sctx_init(&sctx, 2000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmd);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmd->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
}
}
exit:
return res;
}
u8 rtw_dynamic_chk_wk_cmd(_adapter *padapter)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
/* only primary padapter does this cmd */
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = DYNAMIC_CHK_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
/* rtw_enqueue_cmd(pcmdpriv, ph2c); */
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_set_chbw_cmd(_adapter *padapter, u8 ch, u8 bw, u8 ch_offset, u8 flags)
{
struct cmd_obj *pcmdobj;
struct set_ch_parm *set_ch_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
RTW_INFO(FUNC_NDEV_FMT" ch:%u, bw:%u, ch_offset:%u\n",
FUNC_NDEV_ARG(padapter->pnetdev), ch, bw, ch_offset);
/* check input parameter */
/* prepare cmd parameter */
set_ch_parm = (struct set_ch_parm *)rtw_zmalloc(sizeof(*set_ch_parm));
if (set_ch_parm == NULL) {
res = _FAIL;
goto exit;
}
set_ch_parm->ch = ch;
set_ch_parm->bw = bw;
set_ch_parm->ch_offset = ch_offset;
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != rtw_set_chbw_hdl(padapter, (u8 *)set_ch_parm))
res = _FAIL;
rtw_mfree((u8 *)set_ch_parm, sizeof(*set_ch_parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmdobj == NULL) {
rtw_mfree((u8 *)set_ch_parm, sizeof(*set_ch_parm));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(pcmdobj, set_ch_parm, GEN_CMD_CODE(_SetChannel));
if (flags & RTW_CMDF_WAIT_ACK) {
pcmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 10 * 1000);
}
res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
pcmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
}
}
/* do something based on res... */
exit:
RTW_INFO(FUNC_NDEV_FMT" res:%u\n", FUNC_NDEV_ARG(padapter->pnetdev), res);
return res;
}
u8 _rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, const struct country_chplan *country_ent, u8 swconfig)
{
struct cmd_obj *cmdobj;
struct SetChannelPlan_param *parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
/* check if allow software config */
if (swconfig && rtw_hal_is_disable_sw_channel_plan(adapter) == _TRUE) {
res = _FAIL;
goto exit;
}
/* if country_entry is provided, replace chplan */
if (country_ent)
chplan = country_ent->chplan;
/* check input parameter */
if (!rtw_is_channel_plan_valid(chplan)) {
res = _FAIL;
goto exit;
}
/* prepare cmd parameter */
parm = (struct SetChannelPlan_param *)rtw_zmalloc(sizeof(*parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
parm->country_ent = country_ent;
parm->channel_plan = chplan;
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != set_chplan_hdl(adapter, (u8 *)parm))
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_SetChannelPlan));
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 2000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
/* allow set channel plan when cmd_thread is not running */
if (res != _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
parm = (struct SetChannelPlan_param *)rtw_zmalloc(sizeof(*parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
parm->country_ent = country_ent;
parm->channel_plan = chplan;
if (H2C_SUCCESS != set_chplan_hdl(adapter, (u8 *)parm))
res = _FAIL;
else
res = _SUCCESS;
rtw_mfree((u8 *)parm, sizeof(*parm));
}
}
exit:
return res;
}
inline u8 rtw_set_chplan_cmd(_adapter *adapter, int flags, u8 chplan, u8 swconfig)
{
return _rtw_set_chplan_cmd(adapter, flags, chplan, NULL, swconfig);
}
inline u8 rtw_set_country_cmd(_adapter *adapter, int flags, const char *country_code, u8 swconfig)
{
const struct country_chplan *ent;
if (is_alpha(country_code[0]) == _FALSE
|| is_alpha(country_code[1]) == _FALSE
) {
RTW_PRINT("%s input country_code is not alpha2\n", __func__);
return _FAIL;
}
ent = rtw_get_chplan_from_country(country_code);
if (ent == NULL) {
RTW_PRINT("%s unsupported country_code:\"%c%c\"\n", __func__, country_code[0], country_code[1]);
return _FAIL;
}
RTW_PRINT("%s country_code:\"%c%c\" mapping to chplan:0x%02x\n", __func__, country_code[0], country_code[1], ent->chplan);
return _rtw_set_chplan_cmd(adapter, flags, RTW_CHPLAN_UNSPECIFIED, ent, swconfig);
}
u8 rtw_led_blink_cmd(_adapter *padapter, void *pLed)
{
struct cmd_obj *pcmdobj;
struct LedBlink_param *ledBlink_param;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmdobj == NULL) {
res = _FAIL;
goto exit;
}
ledBlink_param = (struct LedBlink_param *)rtw_zmalloc(sizeof(struct LedBlink_param));
if (ledBlink_param == NULL) {
rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
ledBlink_param->pLed = pLed;
init_h2fwcmd_w_parm_no_rsp(pcmdobj, ledBlink_param, GEN_CMD_CODE(_LedBlink));
res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
exit:
return res;
}
u8 rtw_set_csa_cmd(_adapter *adapter)
{
struct cmd_obj *cmdobj;
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
cmdobj = rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_parm_rsp(cmdobj, GEN_CMD_CODE(_SetChannelSwitch));
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
exit:
return res;
}
u8 rtw_tdls_cmd(_adapter *padapter, u8 *addr, u8 option)
{
u8 res = _SUCCESS;
#ifdef CONFIG_TDLS
struct cmd_obj *pcmdobj;
struct TDLSoption_param *TDLSoption;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmdobj == NULL) {
res = _FAIL;
goto exit;
}
TDLSoption = (struct TDLSoption_param *)rtw_zmalloc(sizeof(struct TDLSoption_param));
if (TDLSoption == NULL) {
rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
_rtw_spinlock(&(padapter->tdlsinfo.cmd_lock));
if (addr != NULL)
_rtw_memcpy(TDLSoption->addr, addr, 6);
TDLSoption->option = option;
_rtw_spinunlock(&(padapter->tdlsinfo.cmd_lock));
init_h2fwcmd_w_parm_no_rsp(pcmdobj, TDLSoption, GEN_CMD_CODE(_TDLS));
res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
exit:
#endif /* CONFIG_TDLS */
return res;
}
u8 rtw_enable_hw_update_tsf_cmd(_adapter *padapter)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = EN_HW_UPDATE_TSF_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 rtw_periodic_tsf_update_end_cmd(_adapter *adapter)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
rtw_mfree((unsigned char *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
parm->ec_id = PERIOD_TSF_UPDATE_END_WK_CID;
parm->type = 0;
parm->size = 0;
parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
exit:
return res;
}
u8 rtw_ssmps_wk_hdl(_adapter *adapter, struct ssmps_cmd_parm *ssmp_param)
{
u8 res = _SUCCESS;
struct sta_info *sta = ssmp_param->sta;
u8 smps = ssmp_param->smps;
if (sta == NULL)
return _FALSE;
if (smps)
rtw_ssmps_enter(adapter, sta);
else
rtw_ssmps_leave(adapter, sta);
return res;
}
u8 rtw_ssmps_wk_cmd(_adapter *adapter, struct sta_info *sta, u8 smps, u8 enqueue)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *cmd_parm;
struct ssmps_cmd_parm *ssmp_param;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
if (enqueue) {
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (cmd_parm == NULL) {
rtw_mfree((unsigned char *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
ssmp_param = (struct ssmps_cmd_parm *)rtw_zmalloc(sizeof(struct ssmps_cmd_parm));
if (ssmp_param == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
ssmp_param->smps = smps;
ssmp_param->sta = sta;
cmd_parm->ec_id = SSMPS_WK_CID;
cmd_parm->type = 0;
cmd_parm->size = sizeof(struct ssmps_cmd_parm);
cmd_parm->pbuf = (u8 *)ssmp_param;
init_h2fwcmd_w_parm_no_rsp(cmdobj, cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
} else {
struct ssmps_cmd_parm tmp_ssmp_param;
tmp_ssmp_param.smps = smps;
tmp_ssmp_param.sta = sta;
rtw_ssmps_wk_hdl(adapter, &tmp_ssmp_param);
}
exit:
return res;
}
#ifdef CONFIG_SUPPORT_STATIC_SMPS
u8 _ssmps_chk_by_tp(_adapter *adapter, u8 from_timer)
{
u8 enter_smps = _FALSE;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta;
u32 tx_tp_mbits, rx_tp_mbits;
if (!MLME_IS_STA(adapter) ||
!hal_is_mimo_support(adapter) ||
!pmlmeext->ssmps_en ||
(pmlmeext->cur_channel > 14)
)
return enter_smps;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL) {
RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
rtw_warn_on(1);
return enter_smps;
}
if (psta->cmn.mimo_type == RF_1T1R)
return enter_smps;
tx_tp_mbits = psta->sta_stats.tx_tp_kbits >> 10;
rx_tp_mbits = psta->sta_stats.rx_tp_kbits >> 10;
#ifdef DBG_STATIC_SMPS
if (pmlmeext->ssmps_test) {
enter_smps = (pmlmeext->ssmps_test_en == 1) ? _TRUE : _FALSE;
}
else
#endif
{
if ((tx_tp_mbits <= pmlmeext->ssmps_tx_tp_th) &&
(rx_tp_mbits <= pmlmeext->ssmps_rx_tp_th))
enter_smps = _TRUE;
else
enter_smps = _FALSE;
}
if (1) {
RTW_INFO(FUNC_ADPT_FMT" tx_tp:%d [%d], rx_tp:%d [%d] , SSMPS enter :%s\n",
FUNC_ADPT_ARG(adapter),
tx_tp_mbits, pmlmeext->ssmps_tx_tp_th,
rx_tp_mbits, pmlmeext->ssmps_rx_tp_th,
(enter_smps == _TRUE) ? "True" : "False");
#ifdef DBG_STATIC_SMPS
RTW_INFO(FUNC_ADPT_FMT" test:%d test_en:%d\n",
FUNC_ADPT_ARG(adapter),
pmlmeext->ssmps_test,
pmlmeext->ssmps_test_en);
#endif
}
if (enter_smps) {
if (!from_timer && psta->cmn.sm_ps != SM_PS_STATIC)
rtw_ssmps_enter(adapter, psta);
} else {
if (!from_timer && psta->cmn.sm_ps != SM_PS_DISABLE)
rtw_ssmps_leave(adapter, psta);
else {
u8 ps_change = _FALSE;
if (enter_smps && psta->cmn.sm_ps != SM_PS_STATIC)
ps_change = _TRUE;
else if (!enter_smps && psta->cmn.sm_ps != SM_PS_DISABLE)
ps_change = _TRUE;
if (ps_change)
rtw_ssmps_wk_cmd(adapter, psta, enter_smps, 1);
}
}
return enter_smps;
}
#endif /*CONFIG_SUPPORT_STATIC_SMPS*/
#ifdef CONFIG_CTRL_TXSS_BY_TP
void rtw_ctrl_txss_update_mimo_type(_adapter *adapter, struct sta_info *sta)
{
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
pmlmeext->txss_momi_type_bk = sta->cmn.mimo_type;
}
u8 rtw_ctrl_txss(_adapter *adapter, struct sta_info *sta, bool tx_1ss)
{
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
u8 lps_changed = _FALSE;
u8 rst = _SUCCESS;
if (pmlmeext->txss_1ss == tx_1ss)
return _FALSE;
if (pwrpriv->bLeisurePs && pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
lps_changed = _TRUE;
LPS_Leave(adapter, "LPS_CTRL_TXSS");
}
RTW_INFO(ADPT_FMT" STA [" MAC_FMT "] set tx to %d ss\n",
ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr),
(tx_1ss) ? 1 : rtw_get_sta_tx_nss(adapter, sta));
/*ra re-registed*/
sta->cmn.mimo_type = (tx_1ss) ? RF_1T1R : pmlmeext->txss_momi_type_bk;
rtw_phydm_ra_registed(adapter, sta);
/*configure trx mode*/
rtw_phydm_trx_cfg(adapter, tx_1ss);
pmlmeext->txss_1ss = tx_1ss;
if (lps_changed)
LPS_Enter(adapter, "LPS_CTRL_TXSS");
return rst;
}
u8 rtw_ctrl_txss_wk_hdl(_adapter *adapter, struct txss_cmd_parm *txss_param)
{
if (!txss_param->sta)
return _FALSE;
return rtw_ctrl_txss(adapter, txss_param->sta, txss_param->tx_1ss);
}
u8 rtw_ctrl_txss_wk_cmd(_adapter *adapter, struct sta_info *sta, bool tx_1ss, u8 flag)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *cmd_parm;
struct txss_cmd_parm *txss_param;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
txss_param = (struct txss_cmd_parm *)rtw_zmalloc(sizeof(struct txss_cmd_parm));
if (txss_param == NULL) {
res = _FAIL;
goto exit;
}
txss_param->tx_1ss = tx_1ss;
txss_param->sta = sta;
if (flag & RTW_CMDF_DIRECTLY) {
res = rtw_ctrl_txss_wk_hdl(adapter, txss_param);
rtw_mfree((u8 *)txss_param, sizeof(*txss_param));
} else {
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (cmd_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
cmd_parm->ec_id = TXSS_WK_CID;
cmd_parm->type = 0;
cmd_parm->size = sizeof(struct txss_cmd_parm);
cmd_parm->pbuf = (u8 *)txss_param;
init_h2fwcmd_w_parm_no_rsp(cmdobj, cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
if (flag & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 10 * 1000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flag & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
}
exit:
return res;
}
void rtw_ctrl_tx_ss_by_tp(_adapter *adapter, u8 from_timer)
{
bool tx_1ss = _FALSE; /*change tx from 2ss to 1ss*/
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta;
u32 tx_tp_mbits;
if (!MLME_IS_STA(adapter) ||
!hal_is_mimo_support(adapter) ||
!pmlmeext->txss_ctrl_en
)
return;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL) {
RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
rtw_warn_on(1);
return;
}
tx_tp_mbits = psta->sta_stats.tx_tp_kbits >> 10;
if (tx_tp_mbits >= pmlmeext->txss_tp_th) {
tx_1ss = _FALSE;
} else {
if (pmlmeext->txss_tp_chk_cnt && --pmlmeext->txss_tp_chk_cnt)
tx_1ss = _FALSE;
else
tx_1ss = _TRUE;
}
if (1) {
RTW_INFO(FUNC_ADPT_FMT" tx_tp:%d [%d] tx_1ss(%d):%s\n",
FUNC_ADPT_ARG(adapter),
tx_tp_mbits, pmlmeext->txss_tp_th,
pmlmeext->txss_tp_chk_cnt,
(tx_1ss == _TRUE) ? "True" : "False");
}
if (pmlmeext->txss_1ss != tx_1ss) {
if (from_timer)
rtw_ctrl_txss_wk_cmd(adapter, psta, tx_1ss, 0);
else
rtw_ctrl_txss(adapter, psta, tx_1ss);
}
}
#ifdef DBG_CTRL_TXSS
void dbg_ctrl_txss(_adapter *adapter, bool tx_1ss)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta;
if (!MLME_IS_STA(adapter) ||
!hal_is_mimo_support(adapter)
)
return;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL) {
RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
rtw_warn_on(1);
return;
}
rtw_ctrl_txss(adapter, psta, tx_1ss);
}
#endif
#endif /*CONFIG_CTRL_TXSS_BY_TP*/
#ifdef CONFIG_LPS
#ifdef CONFIG_LPS_CHK_BY_TP
#ifdef LPS_BCN_CNT_MONITOR
static u8 _bcn_cnt_expected(struct sta_info *psta)
{
_adapter *adapter = psta->padapter;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 dtim = rtw_get_bcn_dtim_period(adapter);
u8 bcn_cnt = 0;
if ((pmlmeinfo->bcn_interval !=0) && (dtim != 0))
bcn_cnt = 2000 / pmlmeinfo->bcn_interval / dtim * 4 / 5; /*2s*/
if (0)
RTW_INFO("%s bcn_cnt:%d\n", __func__, bcn_cnt);
if (bcn_cnt == 0) {
RTW_ERR(FUNC_ADPT_FMT" bcn_cnt == 0\n", FUNC_ADPT_ARG(adapter));
rtw_warn_on(1);
}
return bcn_cnt;
}
#endif
u8 _lps_chk_by_tp(_adapter *adapter, u8 from_timer)
{
u8 enter_ps = _FALSE;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
u32 tx_tp_mbits, rx_tp_mbits, bi_tp_mbits;
u8 rx_bcn_cnt;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL) {
RTW_ERR(ADPT_FMT" sta == NULL\n", ADPT_ARG(adapter));
rtw_warn_on(1);
return enter_ps;
}
rx_bcn_cnt = rtw_get_bcn_cnt(psta->padapter);
psta->sta_stats.acc_tx_bytes = psta->sta_stats.tx_bytes;
psta->sta_stats.acc_rx_bytes = psta->sta_stats.rx_bytes;
#if 1
tx_tp_mbits = psta->sta_stats.tx_tp_kbits >> 10;
rx_tp_mbits = psta->sta_stats.rx_tp_kbits >> 10;
bi_tp_mbits = tx_tp_mbits + rx_tp_mbits;
#else
tx_tp_mbits = psta->sta_stats.smooth_tx_tp_kbits >> 10;
rx_tp_mbits = psta->sta_stats.smooth_rx_tp_kbits >> 10;
bi_tp_mbits = tx_tp_mbits + rx_tp_mbits;
#endif
if ((bi_tp_mbits >= pwrpriv->lps_bi_tp_th) ||
(tx_tp_mbits >= pwrpriv->lps_tx_tp_th) ||
(rx_tp_mbits >= pwrpriv->lps_rx_tp_th)) {
enter_ps = _FALSE;
pwrpriv->lps_chk_cnt = pwrpriv->lps_chk_cnt_th;
}
else {
#ifdef LPS_BCN_CNT_MONITOR
u8 bcn_cnt = _bcn_cnt_expected(psta);
if (bcn_cnt && (rx_bcn_cnt < bcn_cnt)) {
pwrpriv->lps_chk_cnt = 2;
RTW_ERR(FUNC_ADPT_FMT" BCN_CNT:%d(%d) invalid\n",
FUNC_ADPT_ARG(adapter), rx_bcn_cnt, bcn_cnt);
}
#endif
if (pwrpriv->lps_chk_cnt && --pwrpriv->lps_chk_cnt)
enter_ps = _FALSE;
else
enter_ps = _TRUE;
}
if (1) {
RTW_INFO(FUNC_ADPT_FMT" tx_tp:%d [%d], rx_tp:%d [%d], bi_tp:%d [%d], enter_ps(%d):%s\n",
FUNC_ADPT_ARG(adapter),
tx_tp_mbits, pwrpriv->lps_tx_tp_th,
rx_tp_mbits, pwrpriv->lps_rx_tp_th,
bi_tp_mbits, pwrpriv->lps_bi_tp_th,
pwrpriv->lps_chk_cnt,
(enter_ps == _TRUE) ? "True" : "False");
RTW_INFO(FUNC_ADPT_FMT" tx_pkt_cnt :%d [%d], rx_pkt_cnt :%d [%d]\n",
FUNC_ADPT_ARG(adapter),
pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,
pwrpriv->lps_tx_pkts,
pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod,
pwrpriv->lps_rx_pkts);
if (!adapter->bsta_tp_dump)
RTW_INFO(FUNC_ADPT_FMT" bcn_cnt:%d (per-%d second)\n",
FUNC_ADPT_ARG(adapter),
rx_bcn_cnt,
2);
}
if (enter_ps) {
if (!from_timer)
LPS_Enter(adapter, "TRAFFIC_IDLE");
} else {
if (!from_timer)
LPS_Leave(adapter, "TRAFFIC_BUSY");
else {
#ifdef CONFIG_CONCURRENT_MODE
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
if (adapter->hw_port == HW_PORT0)
#endif
#endif
rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_TRAFFIC_BUSY, 0);
}
}
return enter_ps;
}
#endif
static u8 _lps_chk_by_pkt_cnts(_adapter *padapter, u8 from_timer, u8 bBusyTraffic)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
u8 bEnterPS = _FALSE;
/* check traffic for powersaving. */
if (((pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod + pmlmepriv->LinkDetectInfo.NumTxOkInPeriod) > 8) ||
#ifdef CONFIG_LPS_SLOW_TRANSITION
(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 2)
#else /* CONFIG_LPS_SLOW_TRANSITION */
(pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4)
#endif /* CONFIG_LPS_SLOW_TRANSITION */
) {
#ifdef DBG_RX_COUNTER_DUMP
if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
RTW_INFO("(-)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
#endif
bEnterPS = _FALSE;
#ifdef CONFIG_LPS_SLOW_TRANSITION
if (bBusyTraffic == _TRUE) {
if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount <= 4)
pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 4;
pmlmepriv->LinkDetectInfo.TrafficTransitionCount++;
/* RTW_INFO("Set TrafficTransitionCount to %d\n", pmlmepriv->LinkDetectInfo.TrafficTransitionCount); */
if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount > 30/*TrafficTransitionLevel*/)
pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 30;
}
#endif /* CONFIG_LPS_SLOW_TRANSITION */
} else {
#ifdef DBG_RX_COUNTER_DUMP
if (padapter->dump_rx_cnt_mode & DUMP_DRV_TRX_COUNTER_DATA)
RTW_INFO("(+)Tx = %d, Rx = %d\n", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod, pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod);
#endif
#ifdef CONFIG_LPS_SLOW_TRANSITION
if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount >= 2)
pmlmepriv->LinkDetectInfo.TrafficTransitionCount -= 2;
else
pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
if (pmlmepriv->LinkDetectInfo.TrafficTransitionCount == 0)
bEnterPS = _TRUE;
#else /* CONFIG_LPS_SLOW_TRANSITION */
bEnterPS = _TRUE;
#endif /* CONFIG_LPS_SLOW_TRANSITION */
}
#ifdef CONFIG_DYNAMIC_DTIM
if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount == 8)
bEnterPS = _FALSE;
RTW_INFO("LowPowerTransitionCount=%d\n", pmlmepriv->LinkDetectInfo.LowPowerTransitionCount);
#endif /* CONFIG_DYNAMIC_DTIM */
/* LeisurePS only work in infra mode. */
if (bEnterPS) {
if (!from_timer) {
#ifdef CONFIG_DYNAMIC_DTIM
if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount < 8)
adapter_to_pwrctl(padapter)->dtim = 1;
else
adapter_to_pwrctl(padapter)->dtim = 3;
#endif /* CONFIG_DYNAMIC_DTIM */
LPS_Enter(padapter, "TRAFFIC_IDLE");
} else {
/* do this at caller */
/* rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 0); */
/* rtw_hal_dm_watchdog_in_lps(padapter); */
}
#ifdef CONFIG_DYNAMIC_DTIM
if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
#endif /* CONFIG_DYNAMIC_DTIM */
} else {
#ifdef CONFIG_DYNAMIC_DTIM
if (pmlmepriv->LinkDetectInfo.LowPowerTransitionCount != 8)
pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
else
pmlmepriv->LinkDetectInfo.LowPowerTransitionCount++;
#endif /* CONFIG_DYNAMIC_DTIM */
if (!from_timer)
LPS_Leave(padapter, "TRAFFIC_BUSY");
else {
#ifdef CONFIG_CONCURRENT_MODE
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
if (padapter->hw_port == HW_PORT0)
#endif
#endif
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_TRAFFIC_BUSY, 0);
}
}
return bEnterPS;
}
#endif /* CONFIG_LPS */
/* from_timer == 1 means driver is in LPS */
u8 traffic_status_watchdog(_adapter *padapter, u8 from_timer)
{
u8 bEnterPS = _FALSE;
u16 BusyThresholdHigh;
u16 BusyThresholdLow;
u16 BusyThreshold;
u8 bBusyTraffic = _FALSE, bTxBusyTraffic = _FALSE, bRxBusyTraffic = _FALSE;
u8 bHigherBusyTraffic = _FALSE, bHigherBusyRxTraffic = _FALSE, bHigherBusyTxTraffic = _FALSE;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &(padapter->tdlsinfo);
struct tdls_txmgmt txmgmt;
u8 baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
#endif /* CONFIG_TDLS */
#ifdef CONFIG_TRAFFIC_PROTECT
RT_LINK_DETECT_T *link_detect = &pmlmepriv->LinkDetectInfo;
#endif
#ifdef CONFIG_BT_COEXIST
if (padapter->registrypriv.wifi_spec != 1) {
BusyThresholdHigh = 25;
BusyThresholdLow = 10;
} else
#endif /* CONFIG_BT_COEXIST */
{
BusyThresholdHigh = 100;
BusyThresholdLow = 75;
}
BusyThreshold = BusyThresholdHigh;
/* */
/* Determine if our traffic is busy now */
/* */
if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
/*&& !MgntInitAdapterInProgress(pMgntInfo)*/) {
/* if we raise bBusyTraffic in last watchdog, using lower threshold. */
if (pmlmepriv->LinkDetectInfo.bBusyTraffic)
BusyThreshold = BusyThresholdLow;
if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > BusyThreshold ||
pmlmepriv->LinkDetectInfo.NumTxOkInPeriod > BusyThreshold) {
bBusyTraffic = _TRUE;
if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > pmlmepriv->LinkDetectInfo.NumTxOkInPeriod)
bRxBusyTraffic = _TRUE;
else
bTxBusyTraffic = _TRUE;
}
/* Higher Tx/Rx data. */
if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > 4000 ||
pmlmepriv->LinkDetectInfo.NumTxOkInPeriod > 4000) {
bHigherBusyTraffic = _TRUE;
if (pmlmepriv->LinkDetectInfo.NumRxOkInPeriod > pmlmepriv->LinkDetectInfo.NumTxOkInPeriod)
bHigherBusyRxTraffic = _TRUE;
else
bHigherBusyTxTraffic = _TRUE;
}
#ifdef CONFIG_TRAFFIC_PROTECT
#define TX_ACTIVE_TH 10
#define RX_ACTIVE_TH 20
#define TRAFFIC_PROTECT_PERIOD_MS 4500
if (link_detect->NumTxOkInPeriod > TX_ACTIVE_TH
|| link_detect->NumRxUnicastOkInPeriod > RX_ACTIVE_TH) {
RTW_INFO(FUNC_ADPT_FMT" acqiure wake_lock for %u ms(tx:%d,rx_unicast:%d)\n",
FUNC_ADPT_ARG(padapter),
TRAFFIC_PROTECT_PERIOD_MS,
link_detect->NumTxOkInPeriod,
link_detect->NumRxUnicastOkInPeriod);
rtw_lock_traffic_suspend_timeout(TRAFFIC_PROTECT_PERIOD_MS);
}
#endif
#ifdef CONFIG_TDLS
#ifdef CONFIG_TDLS_AUTOSETUP
/* TDLS_WATCHDOG_PERIOD * 2sec, periodically send */
if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _TRUE) {
if ((ptdlsinfo->watchdog_count % TDLS_WATCHDOG_PERIOD) == 0) {
_rtw_memcpy(txmgmt.peer, baddr, ETH_ALEN);
issue_tdls_dis_req(padapter, &txmgmt);
}
ptdlsinfo->watchdog_count++;
}
#endif /* CONFIG_TDLS_AUTOSETUP */
#endif /* CONFIG_TDLS */
#ifdef CONFIG_SUPPORT_STATIC_SMPS
_ssmps_chk_by_tp(padapter, from_timer);
#endif
#ifdef CONFIG_CTRL_TXSS_BY_TP
rtw_ctrl_tx_ss_by_tp(padapter, from_timer);
#endif
#ifdef CONFIG_LPS
if (adapter_to_pwrctl(padapter)->bLeisurePs && MLME_IS_STA(padapter)) {
#ifdef CONFIG_LPS_CHK_BY_TP
if (adapter_to_pwrctl(padapter)->lps_chk_by_tp)
bEnterPS = _lps_chk_by_tp(padapter, from_timer);
else
#endif /*CONFIG_LPS_CHK_BY_TP*/
bEnterPS = _lps_chk_by_pkt_cnts(padapter, from_timer, bBusyTraffic);
}
#endif /* CONFIG_LPS */
} else {
#ifdef CONFIG_LPS
if (!from_timer && rtw_mi_get_assoc_if_num(padapter) == 0)
LPS_Leave(padapter, "NON_LINKED");
#endif
}
session_tracker_chk_cmd(padapter, NULL);
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
rtw_bf_update_traffic(padapter);
#endif /* RTW_BEAMFORMING_VERSION_2 */
#endif /* CONFIG_BEAMFORMING */
pmlmepriv->LinkDetectInfo.NumRxOkInPeriod = 0;
pmlmepriv->LinkDetectInfo.NumTxOkInPeriod = 0;
pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod = 0;
pmlmepriv->LinkDetectInfo.bBusyTraffic = bBusyTraffic;
pmlmepriv->LinkDetectInfo.bTxBusyTraffic = bTxBusyTraffic;
pmlmepriv->LinkDetectInfo.bRxBusyTraffic = bRxBusyTraffic;
pmlmepriv->LinkDetectInfo.bHigherBusyTraffic = bHigherBusyTraffic;
pmlmepriv->LinkDetectInfo.bHigherBusyRxTraffic = bHigherBusyRxTraffic;
pmlmepriv->LinkDetectInfo.bHigherBusyTxTraffic = bHigherBusyTxTraffic;
return bEnterPS;
}
/* for 11n Logo 4.2.31/4.2.32 */
static void dynamic_update_bcn_check(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
if (!padapter->registrypriv.wifi_spec)
return;
if (!padapter->registrypriv.ht_enable || !is_supported_ht(padapter->registrypriv.wireless_mode))
return;
if (!MLME_IS_AP(padapter))
return;
if (pmlmeext->bstart_bss) {
/* In 10 * 2 = 20s, there are no legacy AP, update HT info */
static u8 count = 1;
if (count % 10 == 0) {
count = 1;
#ifdef CONFIG_80211N_HT
if (_FALSE == ATOMIC_READ(&pmlmepriv->olbc)
&& _FALSE == ATOMIC_READ(&pmlmepriv->olbc_ht)) {
if (rtw_ht_operation_update(padapter) > 0) {
update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE, 0);
update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE, 0);
}
}
#endif /* CONFIG_80211N_HT */
}
#ifdef CONFIG_80211N_HT
/* In 2s, there are any legacy AP, update HT info, and then reset count */
if (_FALSE != ATOMIC_READ(&pmlmepriv->olbc)
&& _FALSE != ATOMIC_READ(&pmlmepriv->olbc_ht)) {
if (rtw_ht_operation_update(padapter) > 0) {
update_beacon(padapter, _HT_CAPABILITY_IE_, NULL, _FALSE, 0);
update_beacon(padapter, _HT_ADD_INFO_IE_, NULL, _TRUE, 0);
}
ATOMIC_SET(&pmlmepriv->olbc, _FALSE);
ATOMIC_SET(&pmlmepriv->olbc_ht, _FALSE);
count = 0;
}
#endif /* CONFIG_80211N_HT */
count ++;
}
}
void rtw_iface_dynamic_chk_wk_hdl(_adapter *padapter)
{
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
#ifdef CONFIG_AP_MODE
if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
expire_timeout_chk(padapter);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter) && MLME_IS_ASOC(padapter))
rtw_mesh_peer_status_chk(padapter);
#endif
}
#endif
#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
dynamic_update_bcn_check(padapter);
linked_status_chk(padapter, 0);
traffic_status_watchdog(padapter, 0);
/* for debug purpose */
_linked_info_dump(padapter);
#ifdef CONFIG_RTW_CFGVEDNOR_RSSIMONITOR
rtw_cfgvendor_rssi_monitor_evt(padapter);
#endif
}
void rtw_dynamic_chk_wk_hdl(_adapter *padapter)
{
rtw_mi_dynamic_chk_wk_hdl(padapter);
#ifdef CONFIG_MP_INCLUDED
if (rtw_mp_mode_check(padapter) == _FALSE)
#endif
{
#ifdef DBG_CONFIG_ERROR_DETECT
rtw_hal_sreset_xmit_status_check(padapter);
rtw_hal_sreset_linked_status_check(padapter);
#endif
}
/* if(check_fwstate(pmlmepriv, _FW_UNDER_LINKING|_FW_UNDER_SURVEY)==_FALSE) */
{
#ifdef DBG_RX_COUNTER_DUMP
rtw_dump_rx_counters(padapter);
#endif
dm_DynamicUsbTxAgg(padapter, 0);
}
rtw_hal_dm_watchdog(padapter);
/* check_hw_pbc(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->type); */
#ifdef CONFIG_BT_COEXIST
/* BT-Coexist */
rtw_btcoex_Handler(padapter);
#endif
#ifdef CONFIG_IPS_CHECK_IN_WD
/* always call rtw_ps_processor() at last one. */
rtw_ps_processor(padapter);
#endif
#ifdef CONFIG_MCC_MODE
rtw_hal_mcc_sw_status_check(padapter);
#endif /* CONFIG_MCC_MODE */
rtw_hal_periodic_tsf_update_chk(padapter);
}
#ifdef CONFIG_LPS
struct lps_ctrl_wk_parm {
s8 lps_level;
#ifdef CONFIG_LPS_1T1R
s8 lps_1t1r;
#endif
};
void lps_ctrl_wk_hdl(_adapter *padapter, u8 lps_ctrl_type, u8 *buf)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct lps_ctrl_wk_parm *parm = (struct lps_ctrl_wk_parm *)buf;
u8 mstatus;
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)
|| (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
return;
switch (lps_ctrl_type) {
case LPS_CTRL_SCAN:
/* RTW_INFO("LPS_CTRL_SCAN\n"); */
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_ScanNotify(padapter, _TRUE);
#endif /* CONFIG_BT_COEXIST */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
/* connect */
LPS_Leave(padapter, "LPS_CTRL_SCAN");
}
break;
case LPS_CTRL_JOINBSS:
/* RTW_INFO("LPS_CTRL_JOINBSS\n"); */
LPS_Leave(padapter, "LPS_CTRL_JOINBSS");
break;
case LPS_CTRL_CONNECT:
/* RTW_INFO("LPS_CTRL_CONNECT\n"); */
mstatus = 1;/* connect */
/* Reset LPS Setting */
pwrpriv->LpsIdleCount = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_MediaStatusNotify(padapter, mstatus);
#endif /* CONFIG_BT_COEXIST */
break;
case LPS_CTRL_DISCONNECT:
/* RTW_INFO("LPS_CTRL_DISCONNECT\n"); */
mstatus = 0;/* disconnect */
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_MediaStatusNotify(padapter, mstatus);
#endif /* CONFIG_BT_COEXIST */
LPS_Leave(padapter, "LPS_CTRL_DISCONNECT");
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
break;
case LPS_CTRL_SPECIAL_PACKET:
/* RTW_INFO("LPS_CTRL_SPECIAL_PACKET\n"); */
rtw_set_lps_deny(padapter, LPS_DELAY_MS);
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_SpecialPacketNotify(padapter, PACKET_DHCP);
#endif /* CONFIG_BT_COEXIST */
LPS_Leave(padapter, "LPS_CTRL_SPECIAL_PACKET");
break;
case LPS_CTRL_LEAVE:
LPS_Leave(padapter, "LPS_CTRL_LEAVE");
break;
case LPS_CTRL_LEAVE_SET_OPTION:
LPS_Leave(padapter, "LPS_CTRL_LEAVE_SET_OPTION");
if (parm) {
if (parm->lps_level >= 0)
pwrpriv->lps_level = parm->lps_level;
#ifdef CONFIG_LPS_1T1R
if (parm->lps_1t1r >= 0)
pwrpriv->lps_1t1r = parm->lps_1t1r;
#endif
}
break;
case LPS_CTRL_LEAVE_CFG80211_PWRMGMT:
LPS_Leave(padapter, "CFG80211_PWRMGMT");
break;
case LPS_CTRL_TRAFFIC_BUSY:
LPS_Leave(padapter, "LPS_CTRL_TRAFFIC_BUSY");
break;
case LPS_CTRL_TX_TRAFFIC_LEAVE:
LPS_Leave(padapter, "LPS_CTRL_TX_TRAFFIC_LEAVE");
break;
case LPS_CTRL_RX_TRAFFIC_LEAVE:
LPS_Leave(padapter, "LPS_CTRL_RX_TRAFFIC_LEAVE");
break;
case LPS_CTRL_ENTER:
LPS_Enter(padapter, "TRAFFIC_IDLE_1");
break;
default:
break;
}
}
static u8 _rtw_lps_ctrl_wk_cmd(_adapter *adapter, u8 lps_ctrl_type, s8 lps_level, s8 lps_1t1r, u8 flags)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct lps_ctrl_wk_parm *wk_parm = NULL;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
if (lps_ctrl_type == LPS_CTRL_LEAVE_SET_OPTION) {
wk_parm = rtw_zmalloc(sizeof(*wk_parm));
if (wk_parm == NULL) {
res = _FAIL;
goto exit;
}
wk_parm->lps_level = lps_level;
#ifdef CONFIG_LPS_1T1R
wk_parm->lps_1t1r = lps_1t1r;
#endif
}
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly */
lps_ctrl_wk_hdl(adapter, lps_ctrl_type, (u8 *)wk_parm);
if (wk_parm)
rtw_mfree(wk_parm, sizeof(*wk_parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
parm = rtw_zmalloc(sizeof(*parm));
if (parm == NULL) {
if (wk_parm)
rtw_mfree(wk_parm, sizeof(*wk_parm));
res = _FAIL;
goto exit;
}
parm->ec_id = LPS_CTRL_WK_CID;
parm->type = lps_ctrl_type;
parm->size = wk_parm ? sizeof(*wk_parm) : 0;
parm->pbuf = (u8 *)wk_parm;
cmdobj = rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
rtw_mfree(parm, sizeof(*parm));
if (wk_parm)
rtw_mfree(wk_parm, sizeof(*wk_parm));
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 2000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
}
exit:
return res;
}
u8 rtw_lps_ctrl_wk_cmd(_adapter *adapter, u8 lps_ctrl_type, u8 flags)
{
return _rtw_lps_ctrl_wk_cmd(adapter, lps_ctrl_type, -1, -1, flags);
}
u8 rtw_lps_ctrl_leave_set_level_cmd(_adapter *adapter, u8 lps_level, u8 flags)
{
return _rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_LEAVE_SET_OPTION, lps_level, -1, flags);
}
#ifdef CONFIG_LPS_1T1R
u8 rtw_lps_ctrl_leave_set_1t1r_cmd(_adapter *adapter, u8 lps_1t1r, u8 flags)
{
return _rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_LEAVE_SET_OPTION, -1, lps_1t1r, flags);
}
#endif
void rtw_dm_in_lps_hdl(_adapter *padapter)
{
rtw_hal_set_hwreg(padapter, HW_VAR_DM_IN_LPS_LCLK, NULL);
}
u8 rtw_dm_in_lps_wk_cmd(_adapter *padapter)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = DM_IN_LPS_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void rtw_lps_change_dtim_hdl(_adapter *padapter, u8 dtim)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
if (dtim <= 0 || dtim > 16)
return;
#ifdef CONFIG_BT_COEXIST
if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
return;
#endif
#ifdef CONFIG_LPS_LCLK
_enter_pwrlock(&pwrpriv->lock);
#endif
if (pwrpriv->dtim != dtim) {
RTW_INFO("change DTIM from %d to %d, bFwCurrentInPSMode=%d, ps_mode=%d\n", pwrpriv->dtim, dtim,
pwrpriv->bFwCurrentInPSMode, pwrpriv->pwr_mode);
pwrpriv->dtim = dtim;
}
if ((pwrpriv->bFwCurrentInPSMode == _TRUE) && (pwrpriv->pwr_mode > PS_MODE_ACTIVE)) {
u8 ps_mode = pwrpriv->pwr_mode;
/* RTW_INFO("change DTIM from %d to %d, ps_mode=%d\n", pwrpriv->dtim, dtim, ps_mode); */
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
}
#ifdef CONFIG_LPS_LCLK
_exit_pwrlock(&pwrpriv->lock);
#endif
}
#endif
u8 rtw_lps_change_dtim_cmd(_adapter *padapter, u8 dtim)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
/*
#ifdef CONFIG_CONCURRENT_MODE
if (padapter->hw_port != HW_PORT0)
return res;
#endif
*/
{
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = LPS_CHANGE_DTIM_CID;
pdrvextra_cmd_parm->type = dtim;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
}
exit:
return res;
}
#if (RATE_ADAPTIVE_SUPPORT == 1)
void rpt_timer_setting_wk_hdl(_adapter *padapter, u16 minRptTime)
{
rtw_hal_set_hwreg(padapter, HW_VAR_RPT_TIMER_SETTING, (u8 *)(&minRptTime));
}
u8 rtw_rpt_timer_cfg_cmd(_adapter *padapter, u16 minRptTime)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = RTP_TIMER_CFG_WK_CID;
pdrvextra_cmd_parm->type = minRptTime;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
#endif
#ifdef CONFIG_ANTENNA_DIVERSITY
void antenna_select_wk_hdl(_adapter *padapter, u8 antenna)
{
rtw_hal_set_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &antenna, _TRUE);
}
u8 rtw_antenna_select_cmd(_adapter *padapter, u8 antenna, u8 enqueue)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 bSupportAntDiv = _FALSE;
u8 res = _SUCCESS;
int i;
rtw_hal_get_def_var(padapter, HAL_DEF_IS_SUPPORT_ANT_DIV, &(bSupportAntDiv));
if (_FALSE == bSupportAntDiv)
return _FAIL;
for (i = 0; i < dvobj->iface_nums; i++) {
if (rtw_linked_check(dvobj->padapters[i]))
return _FAIL;
}
if (_TRUE == enqueue) {
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = ANT_SELECT_WK_CID;
pdrvextra_cmd_parm->type = antenna;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
} else
antenna_select_wk_hdl(padapter, antenna);
exit:
return res;
}
#endif
void rtw_dm_ra_mask_hdl(_adapter *padapter, struct sta_info *psta)
{
if (psta)
set_sta_rate(padapter, psta);
}
u8 rtw_dm_ra_mask_wk_cmd(_adapter *padapter, u8 *psta)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = DM_RA_MSK_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = psta;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void power_saving_wk_hdl(_adapter *padapter)
{
rtw_ps_processor(padapter);
}
/* add for CONFIG_IEEE80211W, none 11w can use it */
void reset_securitypriv_hdl(_adapter *padapter)
{
rtw_reset_securitypriv(padapter);
}
#ifdef CONFIG_P2P
u8 p2p_protocol_wk_cmd(_adapter *padapter, int intCmdType)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return res;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = P2P_PROTO_WK_CID;
pdrvextra_cmd_parm->type = intCmdType; /* As the command tppe. */
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL; /* Must be NULL here */
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
#ifdef CONFIG_IOCTL_CFG80211
static u8 _p2p_roch_cmd(_adapter *adapter
, u64 cookie, struct wireless_dev *wdev
, struct ieee80211_channel *ch, enum nl80211_channel_type ch_type
, unsigned int duration
, u8 flags
)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct p2p_roch_parm *roch_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 cancel = duration ? 0 : 1;
u8 res = _SUCCESS;
roch_parm = (struct p2p_roch_parm *)rtw_zmalloc(sizeof(struct p2p_roch_parm));
if (roch_parm == NULL) {
res = _FAIL;
goto exit;
}
roch_parm->cookie = cookie;
roch_parm->wdev = wdev;
if (!cancel) {
_rtw_memcpy(&roch_parm->ch, ch, sizeof(struct ieee80211_channel));
roch_parm->ch_type = ch_type;
roch_parm->duration = duration;
}
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != p2p_protocol_wk_hdl(adapter, cancel ? P2P_CANCEL_RO_CH_WK : P2P_RO_CH_WK, (u8 *)roch_parm))
res = _FAIL;
rtw_mfree((u8 *)roch_parm, sizeof(*roch_parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
rtw_mfree((u8 *)roch_parm, sizeof(*roch_parm));
res = _FAIL;
goto exit;
}
parm->ec_id = P2P_PROTO_WK_CID;
parm->type = cancel ? P2P_CANCEL_RO_CH_WK : P2P_RO_CH_WK;
parm->size = sizeof(*roch_parm);
parm->pbuf = (u8 *)roch_parm;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)roch_parm, sizeof(*roch_parm));
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 10 * 1000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
}
exit:
return res;
}
inline u8 p2p_roch_cmd(_adapter *adapter
, u64 cookie, struct wireless_dev *wdev
, struct ieee80211_channel *ch, enum nl80211_channel_type ch_type
, unsigned int duration
, u8 flags
)
{
return _p2p_roch_cmd(adapter, cookie, wdev, ch, ch_type, duration, flags);
}
inline u8 p2p_cancel_roch_cmd(_adapter *adapter, u64 cookie, struct wireless_dev *wdev, u8 flags)
{
return _p2p_roch_cmd(adapter, cookie, wdev, NULL, 0, 0, flags);
}
#endif /* CONFIG_IOCTL_CFG80211 */
#endif /* CONFIG_P2P */
#ifdef CONFIG_IOCTL_CFG80211
inline u8 rtw_mgnt_tx_cmd(_adapter *adapter, u8 tx_ch, u8 no_cck, const u8 *buf, size_t len, int wait_ack, u8 flags)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct mgnt_tx_parm *mgnt_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
mgnt_parm = (struct mgnt_tx_parm *)rtw_zmalloc(sizeof(struct mgnt_tx_parm));
if (mgnt_parm == NULL) {
res = _FAIL;
goto exit;
}
mgnt_parm->tx_ch = tx_ch;
mgnt_parm->no_cck = no_cck;
mgnt_parm->buf = buf;
mgnt_parm->len = len;
mgnt_parm->wait_ack = wait_ack;
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != rtw_mgnt_tx_handler(adapter, (u8 *)mgnt_parm))
res = _FAIL;
rtw_mfree((u8 *)mgnt_parm, sizeof(*mgnt_parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
rtw_mfree((u8 *)mgnt_parm, sizeof(*mgnt_parm));
res = _FAIL;
goto exit;
}
parm->ec_id = MGNT_TX_WK_CID;
parm->type = 0;
parm->size = sizeof(*mgnt_parm);
parm->pbuf = (u8 *)mgnt_parm;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)mgnt_parm, sizeof(*mgnt_parm));
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 10 * 1000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
}
exit:
return res;
}
#endif
u8 rtw_ps_cmd(_adapter *padapter)
{
struct cmd_obj *ppscmd;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
#ifdef CONFIG_CONCURRENT_MODE
if (!is_primary_adapter(padapter))
goto exit;
#endif
ppscmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ppscmd == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ppscmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = POWER_SAVING_CTRL_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ppscmd, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ppscmd);
exit:
return res;
}
#ifdef CONFIG_DFS
void rtw_dfs_ch_switch_hdl(struct dvobj_priv *dvobj)
{
struct rf_ctl_t *rfctl = dvobj_to_rfctl(dvobj);
_adapter *pri_adapter = dvobj_get_primary_adapter(dvobj);
u8 ifbmp_m = rtw_mi_get_ap_mesh_ifbmp(pri_adapter);
u8 ifbmp_s = rtw_mi_get_ld_sta_ifbmp(pri_adapter);
s16 req_ch;
rtw_hal_macid_sleep_all_used(pri_adapter);
if (rtw_chset_search_ch(rfctl->channel_set, rfctl->csa_ch) >= 0
&& !rtw_chset_is_ch_non_ocp(rfctl->channel_set, rfctl->csa_ch)
) {
/* CSA channel available and valid */
req_ch = rfctl->csa_ch;
RTW_INFO("%s valid CSA ch%u\n", __func__, rfctl->csa_ch);
} else if (ifbmp_m) {
/* no available or valid CSA channel, having AP/MESH ifaces */
req_ch = REQ_CH_NONE;
RTW_INFO("%s ch sel by AP/MESH ifaces\n", __func__);
} else {
/* no available or valid CSA channel and no AP/MESH ifaces */
if (!IsSupported24G(dvobj_to_regsty(dvobj)->wireless_mode)
#ifdef CONFIG_DFS_MASTER
|| rfctl->radar_detected
#endif
)
req_ch = 36;
else
req_ch = 1;
RTW_INFO("%s switch to ch%d\n", __func__, req_ch);
}
/* issue deauth for all asoc STA ifaces */
if (ifbmp_s) {
_adapter *iface;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface || !(ifbmp_s & BIT(iface->iface_id)))
continue;
set_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING);
/* TODO: true op ch switching */
issue_deauth(iface, get_bssid(&iface->mlmepriv), WLAN_REASON_DEAUTH_LEAVING);
}
}
#ifdef CONFIG_AP_MODE
if (ifbmp_m) {
/* trigger channel selection without consideraton of asoc STA ifaces */
rtw_change_bss_chbw_cmd(dvobj_get_primary_adapter(dvobj), RTW_CMDF_DIRECTLY
, ifbmp_m, ifbmp_s, req_ch, REQ_BW_ORI, REQ_OFFSET_NONE);
} else
#endif
{
/* no AP/MESH iface, switch DFS status and channel directly */
rtw_warn_on(req_ch <= 0);
#ifdef CONFIG_DFS_MASTER
rtw_dfs_rd_en_decision(pri_adapter, MLME_OPCH_SWITCH, ifbmp_s);
#endif
set_channel_bwmode(pri_adapter, req_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
}
/* make asoc STA ifaces disconnect */
/* TODO: true op ch switching */
if (ifbmp_s) {
_adapter *iface;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface || !(ifbmp_s & BIT(iface->iface_id)))
continue;
rtw_disassoc_cmd(iface, 0, RTW_CMDF_DIRECTLY);
rtw_indicate_disconnect(iface, 0, _FALSE);
rtw_free_assoc_resources(iface, _TRUE);
rtw_free_network_queue(iface, _TRUE);
}
}
rfctl->csa_ch = 0;
rtw_hal_macid_wakeup_all_used(pri_adapter);
rtw_mi_os_xmit_schedule(pri_adapter);
}
#endif /* CONFIG_DFS */
#ifdef CONFIG_AP_MODE
static void rtw_chk_hi_queue_hdl(_adapter *padapter)
{
struct sta_info *psta_bmc;
struct sta_priv *pstapriv = &padapter->stapriv;
systime start = rtw_get_current_time();
u8 empty = _FALSE;
psta_bmc = rtw_get_bcmc_stainfo(padapter);
if (!psta_bmc)
return;
rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
while (_FALSE == empty && rtw_get_passing_time_ms(start) < rtw_get_wait_hiq_empty_ms()) {
rtw_msleep_os(100);
rtw_hal_get_hwreg(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &empty);
}
if (psta_bmc->sleepq_len == 0) {
if (empty == _SUCCESS) {
bool update_tim = _FALSE;
if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0))
update_tim = _TRUE;
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
if (update_tim == _TRUE)
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0,"bmc sleepq and HIQ empty");
} else /* re check again */
rtw_chk_hi_queue_cmd(padapter);
}
}
u8 rtw_chk_hi_queue_cmd(_adapter *padapter)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = CHECK_HIQ_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
#ifdef CONFIG_DFS_MASTER
u8 rtw_dfs_rd_hdl(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
if (!rfctl->radar_detect_enabled)
goto exit;
if (dvobj->oper_channel != rfctl->radar_detect_ch
|| rtw_get_passing_time_ms(rtw_get_on_oper_ch_time(adapter)) < 300
) {
/* offchannel, bypass radar detect */
goto cac_status_chk;
}
if (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl)) {
/* non_ocp, bypass radar detect */
goto cac_status_chk;
}
if (!rfctl->dbg_dfs_fake_radar_detect_cnt
&& rtw_odm_radar_detect(adapter) != _TRUE)
goto cac_status_chk;
if (!rfctl->dbg_dfs_fake_radar_detect_cnt
&& rfctl->dbg_dfs_radar_detect_trigger_non
) {
/* radar detect debug mode, trigger no mlme flow */
RTW_INFO("%s radar detected on test mode, trigger no mlme flow\n", __func__);
goto cac_status_chk;
}
if (rfctl->dbg_dfs_fake_radar_detect_cnt != 0) {
RTW_INFO("%s fake radar detected, cnt:%d\n", __func__
, rfctl->dbg_dfs_fake_radar_detect_cnt);
rfctl->dbg_dfs_fake_radar_detect_cnt--;
} else
RTW_INFO("%s radar detected\n", __func__);
rfctl->radar_detected = 1;
rtw_chset_update_non_ocp(rfctl->channel_set
, rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
rtw_dfs_ch_switch_hdl(dvobj);
if (rfctl->radar_detect_enabled)
goto set_timer;
goto exit;
cac_status_chk:
if (!IS_CAC_STOPPED(rfctl)
&& ((IS_UNDER_CAC(rfctl) && rfctl->cac_force_stop)
|| !IS_CH_WAITING(rfctl)
)
) {
u8 pause = 0x00;
rtw_hal_set_hwreg(adapter, HW_VAR_TXPAUSE, &pause);
rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
if (rtw_mi_check_fwstate(adapter, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == _FALSE) {
u8 doiqk = _TRUE;
u8 u_ch, u_bw, u_offset;
rtw_hal_set_hwreg(adapter , HW_VAR_DO_IQK , &doiqk);
if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset))
set_channel_bwmode(adapter, u_ch, u_offset, u_bw);
else
rtw_warn_on(1);
doiqk = _FALSE;
rtw_hal_set_hwreg(adapter , HW_VAR_DO_IQK , &doiqk);
ResumeTxBeacon(adapter);
rtw_mi_tx_beacon_hdl(adapter);
}
}
set_timer:
_set_timer(&rfctl->radar_detect_timer
, rtw_odm_radar_detect_polling_int_ms(dvobj));
exit:
return H2C_SUCCESS;
}
u8 rtw_dfs_rd_cmd(_adapter *adapter, bool enqueue)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
u8 res = _FAIL;
if (enqueue) {
cmdobj = rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL)
goto exit;
parm = rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
rtw_mfree(cmdobj, sizeof(struct cmd_obj));
goto exit;
}
parm->ec_id = DFS_RADAR_DETECT_WK_CID;
parm->type = 0;
parm->size = 0;
parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
} else {
rtw_dfs_rd_hdl(adapter);
res = _SUCCESS;
}
exit:
return res;
}
void rtw_dfs_rd_timer_hdl(void *ctx)
{
struct rf_ctl_t *rfctl = (struct rf_ctl_t *)ctx;
struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
rtw_dfs_rd_cmd(dvobj_get_primary_adapter(dvobj), _TRUE);
}
static void rtw_dfs_rd_enable(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, bool bypass_cac)
{
struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
RTW_INFO("%s on %u,%u,%u\n", __func__, ch, bw, offset);
if (bypass_cac)
rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
else if (rtw_is_cac_reset_needed(rfctl, ch, bw, offset) == _TRUE)
rtw_reset_cac(rfctl, ch, bw, offset);
rfctl->radar_detect_by_others = _FALSE;
rfctl->radar_detect_ch = ch;
rfctl->radar_detect_bw = bw;
rfctl->radar_detect_offset = offset;
rfctl->radar_detected = 0;
if (IS_CH_WAITING(rfctl))
StopTxBeacon(adapter);
if (!rfctl->radar_detect_enabled) {
RTW_INFO("%s set radar_detect_enabled\n", __func__);
rfctl->radar_detect_enabled = 1;
#ifdef CONFIG_LPS
LPS_Leave(adapter, "RADAR_DETECT_EN");
#endif
_set_timer(&rfctl->radar_detect_timer
, rtw_odm_radar_detect_polling_int_ms(dvobj));
if (rtw_rfctl_overlap_radar_detect_ch(rfctl)) {
if (IS_CH_WAITING(rfctl)) {
u8 pause = 0xFF;
rtw_hal_set_hwreg(adapter, HW_VAR_TXPAUSE, &pause);
}
rtw_odm_radar_detect_enable(adapter);
}
}
}
static void rtw_dfs_rd_disable(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, bool by_others)
{
_adapter *adapter = dvobj_get_primary_adapter(rfctl_to_dvobj(rfctl));
rfctl->radar_detect_by_others = by_others;
if (rfctl->radar_detect_enabled) {
bool overlap_radar_detect_ch = rtw_rfctl_overlap_radar_detect_ch(rfctl);
RTW_INFO("%s clear radar_detect_enabled\n", __func__);
rfctl->radar_detect_enabled = 0;
rfctl->radar_detected = 0;
rfctl->radar_detect_ch = 0;
rfctl->radar_detect_bw = 0;
rfctl->radar_detect_offset = 0;
rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
_cancel_timer_ex(&rfctl->radar_detect_timer);
if (rtw_mi_check_fwstate(adapter, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == _FALSE) {
ResumeTxBeacon(adapter);
rtw_mi_tx_beacon_hdl(adapter);
}
if (overlap_radar_detect_ch) {
u8 pause = 0x00;
rtw_hal_set_hwreg(adapter, HW_VAR_TXPAUSE, &pause);
rtw_odm_radar_detect_disable(adapter);
}
}
if (by_others) {
rfctl->radar_detect_ch = ch;
rfctl->radar_detect_bw = bw;
rfctl->radar_detect_offset = offset;
}
}
void rtw_dfs_rd_en_decision(_adapter *adapter, u8 mlme_act, u8 excl_ifbmp)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct mi_state mstate;
u8 ifbmp;
u8 u_ch, u_bw, u_offset;
bool ld_sta_in_dfs = _FALSE;
bool sync_ch = _FALSE; /* _FALSE: asign channel directly */
bool needed = _FALSE;
if (mlme_act == MLME_OPCH_SWITCH
|| mlme_act == MLME_ACTION_NONE
) {
ifbmp = ~excl_ifbmp;
rtw_mi_status_by_ifbmp(dvobj, ifbmp, &mstate);
rtw_mi_get_ch_setting_union_by_ifbmp(dvobj, ifbmp, &u_ch, &u_bw, &u_offset);
} else {
ifbmp = ~excl_ifbmp & ~BIT(adapter->iface_id);
rtw_mi_status_by_ifbmp(dvobj, ifbmp, &mstate);
rtw_mi_get_ch_setting_union_by_ifbmp(dvobj, ifbmp, &u_ch, &u_bw, &u_offset);
if (u_ch != 0)
sync_ch = _TRUE;
switch (mlme_act) {
case MLME_STA_CONNECTING:
MSTATE_STA_LG_NUM(&mstate)++;
break;
case MLME_STA_CONNECTED:
MSTATE_STA_LD_NUM(&mstate)++;
break;
case MLME_STA_DISCONNECTED:
break;
#ifdef CONFIG_AP_MODE
case MLME_AP_STARTED:
MSTATE_AP_NUM(&mstate)++;
break;
case MLME_AP_STOPPED:
break;
#endif
#ifdef CONFIG_RTW_MESH
case MLME_MESH_STARTED:
MSTATE_MESH_NUM(&mstate)++;
break;
case MLME_MESH_STOPPED:
break;
#endif
default:
rtw_warn_on(1);
break;
}
if (sync_ch == _TRUE) {
if (!MLME_IS_OPCH_SW(adapter)) {
if (!rtw_is_chbw_grouped(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset)) {
RTW_INFO(FUNC_ADPT_FMT" can't sync %u,%u,%u with %u,%u,%u\n", FUNC_ADPT_ARG(adapter)
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset, u_ch, u_bw, u_offset);
goto apply;
}
rtw_sync_chbw(&mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
, &u_ch, &u_bw, &u_offset);
}
} else {
u_ch = mlmeext->cur_channel;
u_bw = mlmeext->cur_bwmode;
u_offset = mlmeext->cur_ch_offset;
}
}
if (MSTATE_STA_LG_NUM(&mstate) > 0) {
/* STA mode is linking */
goto apply;
}
if (MSTATE_STA_LD_NUM(&mstate) > 0) {
if (rtw_is_dfs_chbw(u_ch, u_bw, u_offset)) {
/*
* if operate as slave w/o radar detect,
* rely on AP on which STA mode connects
*/
if (IS_DFS_SLAVE_WITH_RD(rfctl) && !rtw_odm_dfs_domain_unknown(dvobj))
needed = _TRUE;
ld_sta_in_dfs = _TRUE;
}
goto apply;
}
if (!MSTATE_AP_NUM(&mstate) && !MSTATE_MESH_NUM(&mstate)) {
/* No working AP/Mesh mode */
goto apply;
}
if (rtw_is_dfs_chbw(u_ch, u_bw, u_offset))
needed = _TRUE;
apply:
RTW_INFO(FUNC_ADPT_FMT" needed:%d, mlme_act:%u, excl_ifbmp:0x%02x\n"
, FUNC_ADPT_ARG(adapter), needed, mlme_act, excl_ifbmp);
RTW_INFO(FUNC_ADPT_FMT" ld_sta_num:%u, lg_sta_num:%u, ap_num:%u, mesh_num:%u, %u,%u,%u\n"
, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate), MSTATE_STA_LG_NUM(&mstate)
, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate)
, u_ch, u_bw, u_offset);
if (needed == _TRUE)
rtw_dfs_rd_enable(rfctl, u_ch, u_bw, u_offset, ld_sta_in_dfs);
else
rtw_dfs_rd_disable(rfctl, u_ch, u_bw, u_offset, ld_sta_in_dfs);
}
u8 rtw_dfs_rd_en_decision_cmd(_adapter *adapter)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
u8 res = _FAIL;
cmdobj = rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL)
goto exit;
parm = rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
rtw_mfree(cmdobj, sizeof(struct cmd_obj));
goto exit;
}
parm->ec_id = DFS_RADAR_DETECT_EN_DEC_WK_CID;
parm->type = 0;
parm->size = 0;
parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
exit:
return res;
}
#endif /* CONFIG_DFS_MASTER */
#endif /* CONFIG_AP_MODE */
#ifdef CONFIG_BT_COEXIST
struct btinfo {
u8 cid;
u8 len;
u8 bConnection:1;
u8 bSCOeSCO:1;
u8 bInQPage:1;
u8 bACLBusy:1;
u8 bSCOBusy:1;
u8 bHID:1;
u8 bA2DP:1;
u8 bFTP:1;
u8 retry_cnt:4;
u8 rsvd_34:1;
u8 rsvd_35:1;
u8 rsvd_36:1;
u8 rsvd_37:1;
u8 rssi;
u8 rsvd_50:1;
u8 rsvd_51:1;
u8 rsvd_52:1;
u8 rsvd_53:1;
u8 rsvd_54:1;
u8 rsvd_55:1;
u8 eSCO_SCO:1;
u8 Master_Slave:1;
u8 rsvd_6;
u8 rsvd_7;
};
void btinfo_evt_dump(void *sel, void *buf)
{
struct btinfo *info = (struct btinfo *)buf;
RTW_PRINT_SEL(sel, "cid:0x%02x, len:%u\n", info->cid, info->len);
if (info->len > 2)
RTW_PRINT_SEL(sel, "byte2:%s%s%s%s%s%s%s%s\n"
, info->bConnection ? "bConnection " : ""
, info->bSCOeSCO ? "bSCOeSCO " : ""
, info->bInQPage ? "bInQPage " : ""
, info->bACLBusy ? "bACLBusy " : ""
, info->bSCOBusy ? "bSCOBusy " : ""
, info->bHID ? "bHID " : ""
, info->bA2DP ? "bA2DP " : ""
, info->bFTP ? "bFTP" : ""
);
if (info->len > 3)
RTW_PRINT_SEL(sel, "retry_cnt:%u\n", info->retry_cnt);
if (info->len > 4)
RTW_PRINT_SEL(sel, "rssi:%u\n", info->rssi);
if (info->len > 5)
RTW_PRINT_SEL(sel, "byte5:%s%s\n"
, info->eSCO_SCO ? "eSCO_SCO " : ""
, info->Master_Slave ? "Master_Slave " : ""
);
}
static void rtw_btinfo_hdl(_adapter *adapter, u8 *buf, u16 buf_len)
{
#define BTINFO_WIFI_FETCH 0x23
#define BTINFO_BT_AUTO_RPT 0x27
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
struct btinfo_8761ATV *info = (struct btinfo_8761ATV *)buf;
#else /* !CONFIG_BT_COEXIST_SOCKET_TRX */
struct btinfo *info = (struct btinfo *)buf;
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
u8 cmd_idx;
u8 len;
cmd_idx = info->cid;
if (info->len > buf_len - 2) {
rtw_warn_on(1);
len = buf_len - 2;
} else
len = info->len;
/* #define DBG_PROC_SET_BTINFO_EVT */
#ifdef DBG_PROC_SET_BTINFO_EVT
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
RTW_INFO("%s: btinfo[0]=%x,btinfo[1]=%x,btinfo[2]=%x,btinfo[3]=%x btinfo[4]=%x,btinfo[5]=%x,btinfo[6]=%x,btinfo[7]=%x\n"
, __func__, buf[0], buf[1], buf[2], buf[3], buf[4], buf[5], buf[6], buf[7]);
#else/* !CONFIG_BT_COEXIST_SOCKET_TRX */
btinfo_evt_dump(RTW_DBGDUMP, info);
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
#endif /* DBG_PROC_SET_BTINFO_EVT */
/* transform BT-FW btinfo to WiFI-FW C2H format and notify */
if (cmd_idx == BTINFO_WIFI_FETCH)
buf[1] = 0;
else if (cmd_idx == BTINFO_BT_AUTO_RPT)
buf[1] = 2;
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
else if (0x01 == cmd_idx || 0x02 == cmd_idx)
buf[1] = buf[0];
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
rtw_btcoex_BtInfoNotify(adapter , len + 1, &buf[1]);
}
u8 rtw_btinfo_cmd(_adapter *adapter, u8 *buf, u16 len)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
u8 *btinfo;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
btinfo = rtw_zmalloc(len);
if (btinfo == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = BTINFO_WK_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = len;
pdrvextra_cmd_parm->pbuf = btinfo;
_rtw_memcpy(btinfo, buf, len);
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
static void rtw_btc_reduce_wl_txpwr_hdl(_adapter *adapter, u32 pwr_lvl)
{
rtw_btcoex_set_reduced_wl_pwr_lvl(adapter, pwr_lvl);
rtw_btcoex_do_reduce_wl_pwr_lvl(adapter);
RTW_INFO(FUNC_ADPT_FMT ": BTC reduce WL TxPwr %d dB!\n",
FUNC_ADPT_ARG(adapter), pwr_lvl);
}
u8 rtw_btc_reduce_wl_txpwr_cmd(_adapter *adapter, u32 val)
{
struct cmd_obj *pcmdobj;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmdobj == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = BTC_REDUCE_WL_TXPWR_CID;
pdrvextra_cmd_parm->type = val;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(pcmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
exit:
return res;
}
#endif /* CONFIG_BT_COEXIST */
u8 rtw_test_h2c_cmd(_adapter *adapter, u8 *buf, u8 len)
{
struct cmd_obj *pcmdobj;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
u8 *ph2c_content;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 res = _SUCCESS;
pcmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmdobj == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
ph2c_content = rtw_zmalloc(len);
if (ph2c_content == NULL) {
rtw_mfree((u8 *)pcmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = TEST_H2C_CID;
pdrvextra_cmd_parm->type = 0;
pdrvextra_cmd_parm->size = len;
pdrvextra_cmd_parm->pbuf = ph2c_content;
_rtw_memcpy(ph2c_content, buf, len);
init_h2fwcmd_w_parm_no_rsp(pcmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, pcmdobj);
exit:
return res;
}
#ifdef CONFIG_MP_INCLUDED
static s32 rtw_mp_cmd_hdl(_adapter *padapter, u8 mp_cmd_id)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
int ret = H2C_SUCCESS;
uint status = _SUCCESS;
if (mp_cmd_id == MP_START) {
if (padapter->registrypriv.mp_mode == 0) {
rtw_intf_stop(padapter);
rtw_hal_deinit(padapter);
padapter->registrypriv.mp_mode = 1;
#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
padapter->mppriv.CureFuseBTCoex = pHalData->EEPROMBluetoothCoexist;
pHalData->EEPROMBluetoothCoexist = _FALSE;
#endif
#ifdef CONFIG_RF_POWER_TRIM
if (!IS_HARDWARE_TYPE_8814A(padapter) && !IS_HARDWARE_TYPE_8822B(padapter) && !IS_HARDWARE_TYPE_8822C(padapter)) {
padapter->registrypriv.RegPwrTrimEnable = 1;
rtw_hal_read_chip_info(padapter);
}
#endif /*CONFIG_RF_POWER_TRIM*/
rtw_reset_drv_sw(padapter);
#ifdef CONFIG_NEW_NETDEV_HDL
if (!rtw_is_hw_init_completed(padapter)) {
status = rtw_hal_init(padapter);
if (status == _FAIL) {
ret = H2C_REJECTED;
goto exit;
}
rtw_hal_iface_init(padapter);
}
#else
status = rtw_hal_init(padapter);
if (status == _FAIL) {
ret = H2C_REJECTED;
goto exit;
}
#endif /*CONFIG_NEW_NETDEV_HDL*/
#ifndef RTW_HALMAC
rtw_intf_start(padapter);
#endif /* !RTW_HALMAC */
#ifdef RTW_HALMAC /*for New IC*/
MPT_InitializeAdapter(padapter, 1);
#endif /* CONFIG_MP_INCLUDED */
}
if (padapter->registrypriv.mp_mode == 0) {
ret = H2C_REJECTED;
goto exit;
}
if (padapter->mppriv.mode == MP_OFF) {
if (mp_start_test(padapter) == _FAIL) {
ret = H2C_REJECTED;
goto exit;
}
padapter->mppriv.mode = MP_ON;
MPT_PwrCtlDM(padapter, 0);
}
padapter->mppriv.bmac_filter = _FALSE;
#ifdef CONFIG_RTL8723B
#ifdef CONFIG_USB_HCI
rtw_write32(padapter, 0x765, 0x0000);
rtw_write32(padapter, 0x948, 0x0280);
#else
rtw_write32(padapter, 0x765, 0x0000);
rtw_write32(padapter, 0x948, 0x0000);
#endif
#ifdef CONFIG_FOR_RTL8723BS_VQ0
rtw_write32(padapter, 0x765, 0x0000);
rtw_write32(padapter, 0x948, 0x0280);
#endif
rtw_write8(padapter, 0x66, 0x27); /*Open BT uart Log*/
rtw_write8(padapter, 0xc50, 0x20); /*for RX init Gain*/
#endif
odm_write_dig(&pHalData->odmpriv, 0x20);
} else if (mp_cmd_id == MP_STOP) {
if (padapter->registrypriv.mp_mode == 1) {
MPT_DeInitAdapter(padapter);
rtw_intf_stop(padapter);
rtw_hal_deinit(padapter);
padapter->registrypriv.mp_mode = 0;
#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
pHalData->EEPROMBluetoothCoexist = padapter->mppriv.CureFuseBTCoex;
#endif
rtw_reset_drv_sw(padapter);
#ifdef CONFIG_NEW_NETDEV_HDL
if (!rtw_is_hw_init_completed(padapter)) {
status = rtw_hal_init(padapter);
if (status == _FAIL) {
ret = H2C_REJECTED;
goto exit;
}
rtw_hal_iface_init(padapter);
}
#else
status = rtw_hal_init(padapter);
if (status == _FAIL) {
ret = H2C_REJECTED;
goto exit;
}
#endif /*CONFIG_NEW_NETDEV_HDL*/
#ifndef RTW_HALMAC
rtw_intf_start(padapter);
#endif /* !RTW_HALMAC */
}
if (padapter->mppriv.mode != MP_OFF) {
mp_stop_test(padapter);
padapter->mppriv.mode = MP_OFF;
}
} else {
RTW_INFO(FUNC_ADPT_FMT"invalid id:%d\n", FUNC_ADPT_ARG(padapter), mp_cmd_id);
ret = H2C_PARAMETERS_ERROR;
rtw_warn_on(1);
}
exit:
return ret;
}
u8 rtw_mp_cmd(_adapter *adapter, u8 mp_cmd_id, u8 flags)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
parm->ec_id = MP_CMD_WK_CID;
parm->type = mp_cmd_id;
parm->size = 0;
parm->pbuf = NULL;
if (flags & RTW_CMDF_DIRECTLY) {
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
if (H2C_SUCCESS != rtw_mp_cmd_hdl(adapter, mp_cmd_id))
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
} else {
/* need enqueue, prepare cmd_obj and enqueue */
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
if (flags & RTW_CMDF_WAIT_ACK) {
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 10 * 1000);
}
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
}
exit:
return res;
}
#endif /*CONFIG_MP_INCLUDED*/
#ifdef CONFIG_RTW_CUSTOMER_STR
static s32 rtw_customer_str_cmd_hdl(_adapter *adapter, u8 write, const u8 *cstr)
{
int ret = H2C_SUCCESS;
if (write)
ret = rtw_hal_h2c_customer_str_write(adapter, cstr);
else
ret = rtw_hal_h2c_customer_str_req(adapter);
return ret == _SUCCESS ? H2C_SUCCESS : H2C_REJECTED;
}
static u8 rtw_customer_str_cmd(_adapter *adapter, u8 write, const u8 *cstr)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
u8 *str = NULL;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
if (write) {
str = rtw_zmalloc(RTW_CUSTOMER_STR_LEN);
if (str == NULL) {
rtw_mfree((u8 *)parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
}
parm->ec_id = CUSTOMER_STR_WK_CID;
parm->type = write;
parm->size = write ? RTW_CUSTOMER_STR_LEN : 0;
parm->pbuf = write ? str : NULL;
if (write)
_rtw_memcpy(str, cstr, RTW_CUSTOMER_STR_LEN);
/* need enqueue, prepare cmd_obj and enqueue */
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
if (write)
rtw_mfree(str, RTW_CUSTOMER_STR_LEN);
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
cmdobj->sctx = &sctx;
rtw_sctx_init(&sctx, 2 * 1000);
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
if (res == _SUCCESS) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
cmdobj->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status != RTW_SCTX_DONE_SUCCESS)
res = _FAIL;
}
exit:
return res;
}
inline u8 rtw_customer_str_req_cmd(_adapter *adapter)
{
return rtw_customer_str_cmd(adapter, 0, NULL);
}
inline u8 rtw_customer_str_write_cmd(_adapter *adapter, const u8 *cstr)
{
return rtw_customer_str_cmd(adapter, 1, cstr);
}
#endif /* CONFIG_RTW_CUSTOMER_STR */
u8 rtw_c2h_wk_cmd(PADAPTER padapter, u8 *pbuf, u16 length, u8 type)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 *extra_cmd_buf;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
extra_cmd_buf = rtw_zmalloc(length);
if (extra_cmd_buf == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
_rtw_memcpy(extra_cmd_buf, pbuf, length);
pdrvextra_cmd_parm->ec_id = C2H_WK_CID;
pdrvextra_cmd_parm->type = type;
pdrvextra_cmd_parm->size = length;
pdrvextra_cmd_parm->pbuf = extra_cmd_buf;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
#ifdef CONFIG_FW_C2H_REG
inline u8 rtw_c2h_reg_wk_cmd(_adapter *adapter, u8 *c2h_evt)
{
return rtw_c2h_wk_cmd(adapter, c2h_evt, c2h_evt ? C2H_REG_LEN : 0, C2H_TYPE_REG);
}
#endif
#ifdef CONFIG_FW_C2H_PKT
inline u8 rtw_c2h_packet_wk_cmd(_adapter *adapter, u8 *c2h_evt, u16 length)
{
return rtw_c2h_wk_cmd(adapter, c2h_evt, length, C2H_TYPE_PKT);
}
#endif
u8 rtw_run_in_thread_cmd(PADAPTER padapter, void (*func)(void *), void *context)
{
struct cmd_priv *pcmdpriv;
struct cmd_obj *ph2c;
struct RunInThread_param *parm;
s32 res = _SUCCESS;
pcmdpriv = &padapter->cmdpriv;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (NULL == ph2c) {
res = _FAIL;
goto exit;
}
parm = (struct RunInThread_param *)rtw_zmalloc(sizeof(struct RunInThread_param));
if (NULL == parm) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
parm->func = func;
parm->context = context;
init_h2fwcmd_w_parm_no_rsp(ph2c, parm, GEN_CMD_CODE(_RunInThreadCMD));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
#ifdef CONFIG_FW_C2H_REG
s32 c2h_evt_hdl(_adapter *adapter, u8 *c2h_evt, c2h_id_filter filter)
{
s32 ret = _FAIL;
u8 buf[C2H_REG_LEN] = {0};
u8 id, seq, plen;
u8 *payload;
if (!c2h_evt) {
/* No c2h event in cmd_obj, read c2h event before handling*/
if (rtw_hal_c2h_evt_read(adapter, buf) != _SUCCESS)
goto exit;
c2h_evt = buf;
}
rtw_hal_c2h_reg_hdr_parse(adapter, c2h_evt, &id, &seq, &plen, &payload);
if (filter && filter(adapter, id, seq, plen, payload) == _FALSE)
goto exit;
ret = rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
exit:
return ret;
}
#endif /* CONFIG_FW_C2H_REG */
u8 session_tracker_cmd(_adapter *adapter, u8 cmd, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
{
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *cmd_parm;
struct st_cmd_parm *st_parm;
u8 res = _SUCCESS;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (cmd_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
st_parm = (struct st_cmd_parm *)rtw_zmalloc(sizeof(struct st_cmd_parm));
if (st_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
st_parm->cmd = cmd;
st_parm->sta = sta;
if (cmd != ST_CMD_CHK) {
_rtw_memcpy(&st_parm->local_naddr, local_naddr, 4);
_rtw_memcpy(&st_parm->local_port, local_port, 2);
_rtw_memcpy(&st_parm->remote_naddr, remote_naddr, 4);
_rtw_memcpy(&st_parm->remote_port, remote_port, 2);
}
cmd_parm->ec_id = SESSION_TRACKER_WK_CID;
cmd_parm->type = 0;
cmd_parm->size = sizeof(struct st_cmd_parm);
cmd_parm->pbuf = (u8 *)st_parm;
init_h2fwcmd_w_parm_no_rsp(cmdobj, cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
cmdobj->no_io = 1;
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
exit:
return res;
}
inline u8 session_tracker_chk_cmd(_adapter *adapter, struct sta_info *sta)
{
return session_tracker_cmd(adapter, ST_CMD_CHK, sta, NULL, NULL, NULL, NULL);
}
inline u8 session_tracker_add_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
{
return session_tracker_cmd(adapter, ST_CMD_ADD, sta, local_naddr, local_port, remote_naddr, remote_port);
}
inline u8 session_tracker_del_cmd(_adapter *adapter, struct sta_info *sta, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
{
return session_tracker_cmd(adapter, ST_CMD_DEL, sta, local_naddr, local_port, remote_naddr, remote_port);
}
void session_tracker_chk_for_sta(_adapter *adapter, struct sta_info *sta)
{
struct st_ctl_t *st_ctl = &sta->st_ctl;
int i;
_irqL irqL;
_list *plist, *phead, *pnext;
_list dlist;
struct session_tracker *st = NULL;
u8 op_wfd_mode = MIRACAST_DISABLED;
if (DBG_SESSION_TRACKER)
RTW_INFO(FUNC_ADPT_FMT" sta:%p\n", FUNC_ADPT_ARG(adapter), sta);
if (!(sta->state & _FW_LINKED))
goto exit;
for (i = 0; i < SESSION_TRACKER_REG_ID_NUM; i++) {
if (st_ctl->reg[i].s_proto != 0)
break;
}
if (i >= SESSION_TRACKER_REG_ID_NUM)
goto chk_sta;
_rtw_init_listhead(&dlist);
_enter_critical_bh(&st_ctl->tracker_q.lock, &irqL);
phead = &st_ctl->tracker_q.queue;
plist = get_next(phead);
pnext = get_next(plist);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
st = LIST_CONTAINOR(plist, struct session_tracker, list);
plist = pnext;
pnext = get_next(pnext);
if (st->status != ST_STATUS_ESTABLISH
&& rtw_get_passing_time_ms(st->set_time) > ST_EXPIRE_MS
) {
rtw_list_delete(&st->list);
rtw_list_insert_tail(&st->list, &dlist);
}
/* TODO: check OS for status update */
if (st->status == ST_STATUS_CHECK)
st->status = ST_STATUS_ESTABLISH;
if (st->status != ST_STATUS_ESTABLISH)
continue;
#ifdef CONFIG_WFD
if (0)
RTW_INFO(FUNC_ADPT_FMT" local:%u, remote:%u, rtsp:%u, %u, %u\n", FUNC_ADPT_ARG(adapter)
, ntohs(st->local_port), ntohs(st->remote_port), adapter->wfd_info.rtsp_ctrlport, adapter->wfd_info.tdls_rtsp_ctrlport
, adapter->wfd_info.peer_rtsp_ctrlport);
if (ntohs(st->local_port) == adapter->wfd_info.rtsp_ctrlport)
op_wfd_mode |= MIRACAST_SINK;
if (ntohs(st->local_port) == adapter->wfd_info.tdls_rtsp_ctrlport)
op_wfd_mode |= MIRACAST_SINK;
if (ntohs(st->remote_port) == adapter->wfd_info.peer_rtsp_ctrlport)
op_wfd_mode |= MIRACAST_SOURCE;
#endif
}
_exit_critical_bh(&st_ctl->tracker_q.lock, &irqL);
plist = get_next(&dlist);
while (rtw_end_of_queue_search(&dlist, plist) == _FALSE) {
st = LIST_CONTAINOR(plist, struct session_tracker, list);
plist = get_next(plist);
rtw_mfree((u8 *)st, sizeof(struct session_tracker));
}
chk_sta:
if (STA_OP_WFD_MODE(sta) != op_wfd_mode) {
STA_SET_OP_WFD_MODE(sta, op_wfd_mode);
rtw_sta_media_status_rpt_cmd(adapter, sta, 1);
}
exit:
return;
}
void session_tracker_chk_for_adapter(_adapter *adapter)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct sta_info *sta;
int i;
_irqL irqL;
_list *plist, *phead;
u8 op_wfd_mode = MIRACAST_DISABLED;
_enter_critical_bh(&stapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(stapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
sta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
session_tracker_chk_for_sta(adapter, sta);
op_wfd_mode |= STA_OP_WFD_MODE(sta);
}
}
_exit_critical_bh(&stapriv->sta_hash_lock, &irqL);
#ifdef CONFIG_WFD
adapter->wfd_info.op_wfd_mode = MIRACAST_MODE_REVERSE(op_wfd_mode);
#endif
}
void session_tracker_cmd_hdl(_adapter *adapter, struct st_cmd_parm *parm)
{
u8 cmd = parm->cmd;
struct sta_info *sta = parm->sta;
if (cmd == ST_CMD_CHK) {
if (sta)
session_tracker_chk_for_sta(adapter, sta);
else
session_tracker_chk_for_adapter(adapter);
goto exit;
} else if (cmd == ST_CMD_ADD || cmd == ST_CMD_DEL) {
struct st_ctl_t *st_ctl;
u32 local_naddr = parm->local_naddr;
u16 local_port = parm->local_port;
u32 remote_naddr = parm->remote_naddr;
u16 remote_port = parm->remote_port;
struct session_tracker *st = NULL;
_irqL irqL;
_list *plist, *phead;
u8 free_st = 0;
u8 alloc_st = 0;
if (DBG_SESSION_TRACKER)
RTW_INFO(FUNC_ADPT_FMT" cmd:%u, sta:%p, local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT"\n"
, FUNC_ADPT_ARG(adapter), cmd, sta
, IP_ARG(&local_naddr), PORT_ARG(&local_port)
, IP_ARG(&remote_naddr), PORT_ARG(&remote_port)
);
if (!(sta->state & _FW_LINKED))
goto exit;
st_ctl = &sta->st_ctl;
_enter_critical_bh(&st_ctl->tracker_q.lock, &irqL);
phead = &st_ctl->tracker_q.queue;
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
st = LIST_CONTAINOR(plist, struct session_tracker, list);
if (st->local_naddr == local_naddr
&& st->local_port == local_port
&& st->remote_naddr == remote_naddr
&& st->remote_port == remote_port)
break;
plist = get_next(plist);
}
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
st = NULL;
switch (cmd) {
case ST_CMD_DEL:
if (st) {
rtw_list_delete(plist);
free_st = 1;
}
goto unlock;
case ST_CMD_ADD:
if (!st)
alloc_st = 1;
}
unlock:
_exit_critical_bh(&st_ctl->tracker_q.lock, &irqL);
if (free_st) {
rtw_mfree((u8 *)st, sizeof(struct session_tracker));
goto exit;
}
if (alloc_st) {
st = (struct session_tracker *)rtw_zmalloc(sizeof(struct session_tracker));
if (!st)
goto exit;
st->local_naddr = local_naddr;
st->local_port = local_port;
st->remote_naddr = remote_naddr;
st->remote_port = remote_port;
st->set_time = rtw_get_current_time();
st->status = ST_STATUS_CHECK;
_enter_critical_bh(&st_ctl->tracker_q.lock, &irqL);
rtw_list_insert_tail(&st->list, phead);
_exit_critical_bh(&st_ctl->tracker_q.lock, &irqL);
}
}
exit:
return;
}
#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
static s32 rtw_req_per_cmd_hdl(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct macid_bmp req_macid_bmp, *macid_bmp;
u8 i, ret = _FAIL;
macid_bmp = &macid_ctl->if_g[adapter->iface_id];
_rtw_memcpy(&req_macid_bmp, macid_bmp, sizeof(struct macid_bmp));
/* Clear none mesh's macid */
for (i = 0; i < macid_ctl->num; i++) {
u8 role;
role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]);
if (role != H2C_MSR_ROLE_MESH)
rtw_macid_map_clr(&req_macid_bmp, i);
}
/* group_macid: always be 0 in NIC, so only pass macid_bitmap.m0
* rpt_type: 0 includes all info in 1, use 0 for now
* macid_bitmap: pass m0 only for NIC
*/
ret = rtw_hal_set_req_per_rpt_cmd(adapter, 0, 0, req_macid_bmp.m0);
return ret;
}
u8 rtw_req_per_cmd(_adapter *adapter)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
struct submit_ctx sctx;
u8 res = _SUCCESS;
parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (parm == NULL) {
res = _FAIL;
goto exit;
}
parm->ec_id = REQ_PER_CMD_WK_CID;
parm->type = 0;
parm->size = 0;
parm->pbuf = NULL;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(*cmdobj));
if (cmdobj == NULL) {
res = _FAIL;
rtw_mfree((u8 *)parm, sizeof(*parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmdobj, parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
exit:
return res;
}
#endif
u8 rtw_drvextra_cmd_hdl(_adapter *padapter, unsigned char *pbuf)
{
int ret = H2C_SUCCESS;
struct drvextra_cmd_parm *pdrvextra_cmd;
if (!pbuf)
return H2C_PARAMETERS_ERROR;
pdrvextra_cmd = (struct drvextra_cmd_parm *)pbuf;
switch (pdrvextra_cmd->ec_id) {
case STA_MSTATUS_RPT_WK_CID:
rtw_sta_media_status_rpt_cmd_hdl(padapter, (struct sta_media_status_rpt_cmd_parm *)pdrvextra_cmd->pbuf);
break;
case DYNAMIC_CHK_WK_CID:/*only primary padapter go to this cmd, but execute dynamic_chk_wk_hdl() for two interfaces */
rtw_dynamic_chk_wk_hdl(padapter);
break;
case POWER_SAVING_CTRL_WK_CID:
power_saving_wk_hdl(padapter);
break;
#ifdef CONFIG_LPS
case LPS_CTRL_WK_CID:
lps_ctrl_wk_hdl(padapter, (u8)pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
break;
case DM_IN_LPS_WK_CID:
rtw_dm_in_lps_hdl(padapter);
break;
case LPS_CHANGE_DTIM_CID:
rtw_lps_change_dtim_hdl(padapter, (u8)pdrvextra_cmd->type);
break;
#endif
#if (RATE_ADAPTIVE_SUPPORT == 1)
case RTP_TIMER_CFG_WK_CID:
rpt_timer_setting_wk_hdl(padapter, pdrvextra_cmd->type);
break;
#endif
#ifdef CONFIG_ANTENNA_DIVERSITY
case ANT_SELECT_WK_CID:
antenna_select_wk_hdl(padapter, pdrvextra_cmd->type);
break;
#endif
#ifdef CONFIG_P2P_PS
case P2P_PS_WK_CID:
p2p_ps_wk_hdl(padapter, pdrvextra_cmd->type);
break;
#endif
#ifdef CONFIG_P2P
case P2P_PROTO_WK_CID:
/*
* Commented by Albert 2011/07/01
* I used the type_size as the type command
*/
ret = p2p_protocol_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
break;
#endif
#ifdef CONFIG_AP_MODE
case CHECK_HIQ_WK_CID:
rtw_chk_hi_queue_hdl(padapter);
break;
#endif
/* add for CONFIG_IEEE80211W, none 11w can use it */
case RESET_SECURITYPRIV:
reset_securitypriv_hdl(padapter);
break;
case FREE_ASSOC_RESOURCES:
free_assoc_resources_hdl(padapter, (u8)pdrvextra_cmd->type);
break;
case C2H_WK_CID:
switch (pdrvextra_cmd->type) {
#ifdef CONFIG_FW_C2H_REG
case C2H_TYPE_REG:
c2h_evt_hdl(padapter, pdrvextra_cmd->pbuf, NULL);
break;
#endif
#ifdef CONFIG_FW_C2H_PKT
case C2H_TYPE_PKT:
rtw_hal_c2h_pkt_hdl(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
break;
#endif
default:
RTW_ERR("unknown C2H type:%d\n", pdrvextra_cmd->type);
rtw_warn_on(1);
break;
}
break;
#ifdef CONFIG_BEAMFORMING
case BEAMFORMING_WK_CID:
beamforming_wk_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
break;
#endif
case DM_RA_MSK_WK_CID:
rtw_dm_ra_mask_hdl(padapter, (struct sta_info *)pdrvextra_cmd->pbuf);
break;
#ifdef CONFIG_BT_COEXIST
case BTINFO_WK_CID:
rtw_btinfo_hdl(padapter, pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
break;
case BTC_REDUCE_WL_TXPWR_CID:
rtw_btc_reduce_wl_txpwr_hdl(padapter, pdrvextra_cmd->type);
break;
#endif
#ifdef CONFIG_DFS_MASTER
case DFS_RADAR_DETECT_WK_CID:
rtw_dfs_rd_hdl(padapter);
break;
case DFS_RADAR_DETECT_EN_DEC_WK_CID:
rtw_dfs_rd_en_decision(padapter, MLME_ACTION_NONE, 0);
break;
#endif
case SESSION_TRACKER_WK_CID:
session_tracker_cmd_hdl(padapter, (struct st_cmd_parm *)pdrvextra_cmd->pbuf);
break;
case EN_HW_UPDATE_TSF_WK_CID:
rtw_hal_set_hwreg(padapter, HW_VAR_EN_HW_UPDATE_TSF, NULL);
break;
case PERIOD_TSF_UPDATE_END_WK_CID:
rtw_hal_periodic_tsf_update_chk(padapter);
break;
case TEST_H2C_CID:
rtw_hal_fill_h2c_cmd(padapter, pdrvextra_cmd->pbuf[0], pdrvextra_cmd->size - 1, &pdrvextra_cmd->pbuf[1]);
break;
case MP_CMD_WK_CID:
#ifdef CONFIG_MP_INCLUDED
ret = rtw_mp_cmd_hdl(padapter, pdrvextra_cmd->type);
#endif
break;
#ifdef CONFIG_RTW_CUSTOMER_STR
case CUSTOMER_STR_WK_CID:
ret = rtw_customer_str_cmd_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
break;
#endif
#ifdef CONFIG_RTW_REPEATER_SON
case RSON_SCAN_WK_CID:
rtw_rson_scan_cmd_hdl(padapter, pdrvextra_cmd->type);
break;
#endif
#ifdef CONFIG_IOCTL_CFG80211
case MGNT_TX_WK_CID:
ret = rtw_mgnt_tx_handler(padapter, pdrvextra_cmd->pbuf);
break;
#endif /* CONFIG_IOCTL_CFG80211 */
#ifdef CONFIG_MCC_MODE
case MCC_CMD_WK_CID:
ret = rtw_mcc_cmd_hdl(padapter, pdrvextra_cmd->type, pdrvextra_cmd->pbuf);
break;
#endif /* CONFIG_MCC_MODE */
#if defined(CONFIG_RTW_MESH) && defined(RTW_PER_CMD_SUPPORT_FW)
case REQ_PER_CMD_WK_CID:
ret = rtw_req_per_cmd_hdl(padapter);
break;
#endif
#ifdef CONFIG_SUPPORT_STATIC_SMPS
case SSMPS_WK_CID :
rtw_ssmps_wk_hdl(padapter, (struct ssmps_cmd_parm *)pdrvextra_cmd->pbuf);
break;
#endif
#ifdef CONFIG_CTRL_TXSS_BY_TP
case TXSS_WK_CID :
rtw_ctrl_txss_wk_hdl(padapter, (struct txss_cmd_parm *)pdrvextra_cmd->pbuf);
break;
#endif
default:
break;
}
if (pdrvextra_cmd->pbuf && pdrvextra_cmd->size > 0)
rtw_mfree(pdrvextra_cmd->pbuf, pdrvextra_cmd->size);
return ret;
}
void rtw_survey_cmd_callback(_adapter *padapter , struct cmd_obj *pcmd)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (pcmd->res == H2C_DROPPED) {
/* TODO: cancel timer and do timeout handler directly... */
/* need to make timeout handlerOS independent */
mlme_set_scan_to_timer(pmlmepriv, 1);
} else if (pcmd->res != H2C_SUCCESS) {
mlme_set_scan_to_timer(pmlmepriv, 1);
}
/* free cmd */
rtw_free_cmd_obj(pcmd);
}
void rtw_disassoc_cmd_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (pcmd->res != H2C_SUCCESS) {
_enter_critical_bh(&pmlmepriv->lock, &irqL);
set_fwstate(pmlmepriv, _FW_LINKED);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
goto exit;
}
#ifdef CONFIG_BR_EXT
else /* clear bridge database */
nat25_db_cleanup(padapter);
#endif /* CONFIG_BR_EXT */
/* free cmd */
rtw_free_cmd_obj(pcmd);
exit:
return;
}
void rtw_getmacreg_cmdrsp_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
rtw_free_cmd_obj(pcmd);
}
void rtw_joinbss_cmd_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (pcmd->res == H2C_DROPPED) {
/* TODO: cancel timer and do timeout handler directly... */
/* need to make timeout handlerOS independent */
_set_timer(&pmlmepriv->assoc_timer, 1);
} else if (pcmd->res != H2C_SUCCESS)
_set_timer(&pmlmepriv->assoc_timer, 1);
rtw_free_cmd_obj(pcmd);
}
void rtw_create_ibss_post_hdl(_adapter *padapter, int status)
{
_irqL irqL;
struct wlan_network *pwlan = NULL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
WLAN_BSSID_EX *pdev_network = &padapter->registrypriv.dev_network;
struct wlan_network *mlme_cur_network = &(pmlmepriv->cur_network);
if (status != H2C_SUCCESS)
_set_timer(&pmlmepriv->assoc_timer, 1);
_cancel_timer_ex(&pmlmepriv->assoc_timer);
_enter_critical_bh(&pmlmepriv->lock, &irqL);
{
_irqL irqL;
pwlan = _rtw_alloc_network(pmlmepriv);
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
if (pwlan == NULL) {
pwlan = rtw_get_oldest_wlan_network(&pmlmepriv->scanned_queue);
if (pwlan == NULL) {
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
goto createbss_cmd_fail;
}
pwlan->last_scanned = rtw_get_current_time();
} else
rtw_list_insert_tail(&(pwlan->list), &pmlmepriv->scanned_queue.queue);
pdev_network->Length = get_WLAN_BSSID_EX_sz(pdev_network);
_rtw_memcpy(&(pwlan->network), pdev_network, pdev_network->Length);
/* pwlan->fixed = _TRUE; */
/* copy pdev_network information to pmlmepriv->cur_network */
_rtw_memcpy(&mlme_cur_network->network, pdev_network, (get_WLAN_BSSID_EX_sz(pdev_network)));
#if 0
/* reset DSConfig */
mlme_cur_network->network.Configuration.DSConfig = (u32)rtw_ch2freq(pdev_network->Configuration.DSConfig);
#endif
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
/* we will set _FW_LINKED when there is one more sat to join us (rtw_stassoc_event_callback) */
}
createbss_cmd_fail:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
return;
}
void rtw_setstaKey_cmdrsp_callback(_adapter *padapter , struct cmd_obj *pcmd)
{
struct sta_priv *pstapriv = &padapter->stapriv;
struct set_stakey_rsp *psetstakey_rsp = (struct set_stakey_rsp *)(pcmd->rsp);
struct sta_info *psta = rtw_get_stainfo(pstapriv, psetstakey_rsp->addr);
if (psta == NULL) {
goto exit;
}
/* psta->cmn.aid = psta->cmn.mac_id = psetstakey_rsp->keyid; */ /* CAM_ID(CAM_ENTRY) */
exit:
rtw_free_cmd_obj(pcmd);
}
void rtw_setassocsta_cmdrsp_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
_irqL irqL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct set_assocsta_parm *passocsta_parm = (struct set_assocsta_parm *)(pcmd->parmbuf);
struct set_assocsta_rsp *passocsta_rsp = (struct set_assocsta_rsp *)(pcmd->rsp);
struct sta_info *psta = rtw_get_stainfo(pstapriv, passocsta_parm->addr);
if (psta == NULL) {
goto exit;
}
psta->cmn.aid = psta->cmn.mac_id = passocsta_rsp->cam_id;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) && (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE))
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
set_fwstate(pmlmepriv, _FW_LINKED);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
exit:
rtw_free_cmd_obj(pcmd);
}
void rtw_getrttbl_cmd_cmdrsp_callback(_adapter *padapter, struct cmd_obj *pcmd);
void rtw_getrttbl_cmd_cmdrsp_callback(_adapter *padapter, struct cmd_obj *pcmd)
{
rtw_free_cmd_obj(pcmd);
#ifdef CONFIG_MP_INCLUDED
if (padapter->registrypriv.mp_mode == 1)
padapter->mppriv.workparam.bcompleted = _TRUE;
#endif
}
================================================
FILE: core/rtw_debug.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_DEBUG_C_
#include
#include
#ifdef CONFIG_SDIO_MONITOR
#include "../hal/hal_halmac.h"
#endif
#ifdef CONFIG_RTW_DEBUG
const char *rtw_log_level_str[] = {
"_DRV_NONE_ = 0",
"_DRV_ALWAYS_ = 1",
"_DRV_ERR_ = 2",
"_DRV_WARNING_ = 3",
"_DRV_INFO_ = 4",
"_DRV_DEBUG_ = 5",
"_DRV_MAX_ = 6",
};
#endif
#ifdef CONFIG_DEBUG_RTL871X
u64 GlobalDebugComponents = 0;
#endif /* CONFIG_DEBUG_RTL871X */
#include
#ifdef CONFIG_TDLS
#define TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE 41
#endif
void dump_drv_version(void *sel)
{
RTW_PRINT_SEL(sel, "%s %s\n", DRV_NAME, DRIVERVERSION);
RTW_PRINT_SEL(sel, "build time: %s %s\n", __DATE__, __TIME__);
}
void dump_drv_cfg(void *sel)
{
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
char *kernel_version = utsname()->release;
RTW_PRINT_SEL(sel, "\nKernel Version: %s\n", kernel_version);
#endif
RTW_PRINT_SEL(sel, "Driver Version: %s\n", DRIVERVERSION);
RTW_PRINT_SEL(sel, "------------------------------------------------\n");
#ifdef CONFIG_IOCTL_CFG80211
RTW_PRINT_SEL(sel, "CFG80211\n");
#ifdef RTW_USE_CFG80211_STA_EVENT
RTW_PRINT_SEL(sel, "RTW_USE_CFG80211_STA_EVENT\n");
#endif
#ifdef CONFIG_RADIO_WORK
RTW_PRINT_SEL(sel, "CONFIG_RADIO_WORK\n");
#endif
#else
RTW_PRINT_SEL(sel, "WEXT\n");
#endif
RTW_PRINT_SEL(sel, "DBG:%d\n", DBG);
#ifdef CONFIG_RTW_DEBUG
RTW_PRINT_SEL(sel, "CONFIG_RTW_DEBUG\n");
#endif
#ifdef CONFIG_CONCURRENT_MODE
RTW_PRINT_SEL(sel, "CONFIG_CONCURRENT_MODE\n");
#endif
#ifdef CONFIG_POWER_SAVING
RTW_PRINT_SEL(sel, "CONFIG_POWER_SAVING\n");
#endif
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
RTW_PRINT_SEL(sel, "LOAD_PHY_PARA_FROM_FILE - REALTEK_CONFIG_PATH=%s\n", REALTEK_CONFIG_PATH);
#if defined(CONFIG_MULTIDRV) || defined(REALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER)
RTW_PRINT_SEL(sel, "LOAD_PHY_PARA_FROM_FILE - REALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER\n");
#endif
/* configurations about TX power */
#ifdef CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY
RTW_PRINT_SEL(sel, "CONFIG_CALIBRATE_TX_POWER_BY_REGULATORY\n");
#endif
#ifdef CONFIG_CALIBRATE_TX_POWER_TO_MAX
RTW_PRINT_SEL(sel, "CONFIG_CALIBRATE_TX_POWER_TO_MAX\n");
#endif
#endif
RTW_PRINT_SEL(sel, "RTW_DEF_MODULE_REGULATORY_CERT=0x%02x\n", RTW_DEF_MODULE_REGULATORY_CERT);
RTW_PRINT_SEL(sel, "CONFIG_TXPWR_BY_RATE=%d\n", CONFIG_TXPWR_BY_RATE);
RTW_PRINT_SEL(sel, "CONFIG_TXPWR_BY_RATE_EN=%d\n", CONFIG_TXPWR_BY_RATE_EN);
RTW_PRINT_SEL(sel, "CONFIG_TXPWR_LIMIT=%d\n", CONFIG_TXPWR_LIMIT);
RTW_PRINT_SEL(sel, "CONFIG_TXPWR_LIMIT_EN=%d\n", CONFIG_TXPWR_LIMIT_EN);
#ifdef CONFIG_DISABLE_ODM
RTW_PRINT_SEL(sel, "CONFIG_DISABLE_ODM\n");
#endif
#ifdef CONFIG_MINIMAL_MEMORY_USAGE
RTW_PRINT_SEL(sel, "CONFIG_MINIMAL_MEMORY_USAGE\n");
#endif
RTW_PRINT_SEL(sel, "CONFIG_RTW_ADAPTIVITY_EN = %d\n", CONFIG_RTW_ADAPTIVITY_EN);
#if (CONFIG_RTW_ADAPTIVITY_EN)
RTW_PRINT_SEL(sel, "ADAPTIVITY_MODE = %s\n", (CONFIG_RTW_ADAPTIVITY_MODE) ? "carrier_sense" : "normal");
#endif
#ifdef CONFIG_WOWLAN
RTW_PRINT_SEL(sel, "CONFIG_WOWLAN - ");
#ifdef CONFIG_GPIO_WAKEUP
RTW_PRINT_SEL(sel, "CONFIG_GPIO_WAKEUP - WAKEUP_GPIO_IDX:%d\n", WAKEUP_GPIO_IDX);
#endif
#endif
#ifdef CONFIG_TDLS
RTW_PRINT_SEL(sel, "CONFIG_TDLS\n");
#endif
#ifdef CONFIG_RTW_80211R
RTW_PRINT_SEL(sel, "CONFIG_RTW_80211R\n");
#endif
#ifdef CONFIG_RTW_NETIF_SG
RTW_PRINT_SEL(sel, "CONFIG_RTW_NETIF_SG\n");
#endif
#ifdef CONFIG_RTW_WIFI_HAL
RTW_PRINT_SEL(sel, "CONFIG_RTW_WIFI_HAL\n");
#endif
#ifdef CONFIG_RTW_TPT_MODE
RTW_PRINT_SEL(sel, "CONFIG_RTW_TPT_MODE\n");
#endif
#ifdef CONFIG_USB_HCI
#ifdef CONFIG_SUPPORT_USB_INT
RTW_PRINT_SEL(sel, "CONFIG_SUPPORT_USB_INT\n");
#endif
#ifdef CONFIG_USB_INTERRUPT_IN_PIPE
RTW_PRINT_SEL(sel, "CONFIG_USB_INTERRUPT_IN_PIPE\n");
#endif
#ifdef CONFIG_USB_TX_AGGREGATION
RTW_PRINT_SEL(sel, "CONFIG_USB_TX_AGGREGATION\n");
#endif
#ifdef CONFIG_USB_RX_AGGREGATION
RTW_PRINT_SEL(sel, "CONFIG_USB_RX_AGGREGATION\n");
#endif
#ifdef CONFIG_USE_USB_BUFFER_ALLOC_TX
RTW_PRINT_SEL(sel, "CONFIG_USE_USB_BUFFER_ALLOC_TX\n");
#endif
#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
RTW_PRINT_SEL(sel, "CONFIG_USE_USB_BUFFER_ALLOC_RX\n");
#endif
#ifdef CONFIG_PREALLOC_RECV_SKB
RTW_PRINT_SEL(sel, "CONFIG_PREALLOC_RECV_SKB\n");
#endif
#ifdef CONFIG_FIX_NR_BULKIN_BUFFER
RTW_PRINT_SEL(sel, "CONFIG_FIX_NR_BULKIN_BUFFER\n");
#endif
#endif /*CONFIG_USB_HCI*/
#ifdef CONFIG_SDIO_HCI
#ifdef CONFIG_TX_AGGREGATION
RTW_PRINT_SEL(sel, "CONFIG_TX_AGGREGATION\n");
#endif
#ifdef CONFIG_RX_AGGREGATION
RTW_PRINT_SEL(sel, "CONFIG_RX_AGGREGATION\n");
#endif
#ifdef RTW_XMIT_THREAD_HIGH_PRIORITY
RTW_PRINT_SEL(sel, "RTW_XMIT_THREAD_HIGH_PRIORITY\n");
#endif
#ifdef RTW_XMIT_THREAD_HIGH_PRIORITY_AGG
RTW_PRINT_SEL(sel, "RTW_XMIT_THREAD_HIGH_PRIORITY_AGG\n");
#endif
#ifdef DBG_SDIO
RTW_PRINT_SEL(sel, "DBG_SDIO = %d\n", DBG_SDIO);
#endif
#ifdef CONFIG_RTW_DISABLE_HW_PDN
RTW_PRINT_SEL(sel, "CONFIG_RTW_DISABLE_HW_PDN\n");
#endif
#endif /*CONFIG_SDIO_HCI*/
#ifdef CONFIG_PCI_HCI
#endif
RTW_PRINT_SEL(sel, "CONFIG_IFACE_NUMBER = %d\n", CONFIG_IFACE_NUMBER);
#ifdef CONFIG_MI_WITH_MBSSID_CAM
RTW_PRINT_SEL(sel, "CONFIG_MI_WITH_MBSSID_CAM\n");
#endif
#ifdef CONFIG_SWTIMER_BASED_TXBCN
RTW_PRINT_SEL(sel, "CONFIG_SWTIMER_BASED_TXBCN\n");
#endif
#ifdef CONFIG_FW_HANDLE_TXBCN
RTW_PRINT_SEL(sel, "CONFIG_FW_HANDLE_TXBCN\n");
RTW_PRINT_SEL(sel, "CONFIG_LIMITED_AP_NUM = %d\n", CONFIG_LIMITED_AP_NUM);
#endif
#ifdef CONFIG_CLIENT_PORT_CFG
RTW_PRINT_SEL(sel, "CONFIG_CLIENT_PORT_CFG\n");
#endif
#ifdef CONFIG_PCI_TX_POLLING
RTW_PRINT_SEL(sel, "CONFIG_PCI_TX_POLLING\n");
#endif
#ifdef CONFIG_PCI_TX_POLLING_V2
RTW_PRINT_SEL(sel, "CONFIG_PCI_TX_POLLING_V2\n");
#endif
RTW_PRINT_SEL(sel, "\n=== XMIT-INFO ===\n");
RTW_PRINT_SEL(sel, "NR_XMITFRAME = %d\n", NR_XMITFRAME);
RTW_PRINT_SEL(sel, "NR_XMITBUFF = %d\n", NR_XMITBUFF);
RTW_PRINT_SEL(sel, "MAX_XMITBUF_SZ = %d\n", MAX_XMITBUF_SZ);
RTW_PRINT_SEL(sel, "NR_XMIT_EXTBUFF = %d\n", NR_XMIT_EXTBUFF);
RTW_PRINT_SEL(sel, "MAX_XMIT_EXTBUF_SZ = %d\n", MAX_XMIT_EXTBUF_SZ);
RTW_PRINT_SEL(sel, "MAX_CMDBUF_SZ = %d\n", MAX_CMDBUF_SZ);
RTW_PRINT_SEL(sel, "\n=== RECV-INFO ===\n");
RTW_PRINT_SEL(sel, "NR_RECVFRAME = %d\n", NR_RECVFRAME);
RTW_PRINT_SEL(sel, "NR_RECVBUFF = %d\n", NR_RECVBUFF);
RTW_PRINT_SEL(sel, "MAX_RECVBUF_SZ = %d\n", MAX_RECVBUF_SZ);
}
void dump_log_level(void *sel)
{
#ifdef CONFIG_RTW_DEBUG
int i;
RTW_PRINT_SEL(sel, "drv_log_level:%d\n", rtw_drv_log_level);
for (i = 0; i <= _DRV_MAX_; i++) {
if (rtw_log_level_str[i])
RTW_PRINT_SEL(sel, "%c %s = %d\n",
(rtw_drv_log_level == i) ? '+' : ' ', rtw_log_level_str[i], i);
}
#else
RTW_PRINT_SEL(sel, "CONFIG_RTW_DEBUG is disabled\n");
#endif
}
#ifdef CONFIG_SDIO_HCI
void sd_f0_reg_dump(void *sel, _adapter *adapter)
{
int i;
for (i = 0x0; i <= 0xff; i++) {
if (i % 16 == 0)
RTW_PRINT_SEL(sel, "0x%02x ", i);
_RTW_PRINT_SEL(sel, "%02x ", rtw_sd_f0_read8(adapter, i));
if (i % 16 == 15)
_RTW_PRINT_SEL(sel, "\n");
else if (i % 8 == 7)
_RTW_PRINT_SEL(sel, "\t");
}
}
void sdio_local_reg_dump(void *sel, _adapter *adapter)
{
int i, j = 1;
for (i = 0x0; i < 0x100; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%02x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, (0x1025 << 16) | i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
}
#ifdef CONFIG_SDIO_MONITOR
u32 sd_monitor_sdio_clk(_adapter *adapter, u8 clk_moni_mode)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u32 try_cnt = 0, clk_cnt = 0;
/* switch to sdio clk monitor mode */
rtw_halmac_set_sdio_clk_monitor(dvobj, clk_moni_mode);
do {
clk_cnt = rtw_halmac_sdio_get_lk_cnt(dvobj);
if (clk_cnt > 0)
break;
if (try_cnt >= 100) {
clk_cnt = 0;
break;
}
rtw_msleep_os(1);
try_cnt++;
} while (1);
return clk_cnt;
}
#endif
#endif /* CONFIG_SDIO_HCI */
void mac_reg_dump(void *sel, _adapter *adapter)
{
int i, j = 1;
RTW_PRINT_SEL(sel, "======= MAC REG =======\n");
for (i = 0x0; i < 0x800; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
#ifdef CONFIG_RTL8814A
{
for (i = 0x1000; i < 0x1650; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
}
#endif /* CONFIG_RTL8814A */
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) ||defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8822C)
for (i = 0x1000; i < 0x1800; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
#endif /* CONFIG_RTL8822B or 8821c or 8192f*/
}
void bb_reg_dump(void *sel, _adapter *adapter)
{
int i, j = 1;
RTW_PRINT_SEL(sel, "======= BB REG =======\n");
for (i = 0x800; i < 0x1000; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
for (i = 0x1800; i < 0x2000; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
#endif /* CONFIG_RTL8822B */
#if defined(CONFIG_RTL8822C)
for (i = 0x2c00; i < 0x2c60; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
for (i = 0x2d00; i < 0x2df0; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
for (i = 0x4000; i < 0x4060; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
for (i = 0x4100; i < 0x4200; i += 4) {
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
#endif /* CONFIG_RTL8822C */
}
void bb_reg_dump_ex(void *sel, _adapter *adapter)
{
int i;
RTW_PRINT_SEL(sel, "======= BB REG =======\n");
for (i = 0x800; i < 0x1000; i += 4) {
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
_RTW_PRINT_SEL(sel, "\n");
}
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
for (i = 0x1800; i < 0x2000; i += 4) {
RTW_PRINT_SEL(sel, "0x%04x", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", rtw_read32(adapter, i));
_RTW_PRINT_SEL(sel, "\n");
}
#endif /* CONFIG_RTL8822B */
}
void rf_reg_dump(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
int i, j = 1, path;
u32 value;
u8 rf_type = 0;
u8 path_nums = hal->NumTotalRFPath;
RTW_PRINT_SEL(sel, "======= RF REG =======\n");
for (path = 0; path < path_nums; path++) {
RTW_PRINT_SEL(sel, "RF_Path(%x)\n", path);
for (i = 0; i < 0x100; i++) {
value = rtw_hal_read_rfreg(adapter, path, i, 0xffffffff);
if (j % 4 == 1)
RTW_PRINT_SEL(sel, "0x%02x ", i);
_RTW_PRINT_SEL(sel, " 0x%08x ", value);
if ((j++) % 4 == 0)
_RTW_PRINT_SEL(sel, "\n");
}
}
}
void rtw_sink_rtp_seq_dbg(_adapter *adapter, u8 *ehdr_pos)
{
struct recv_priv *precvpriv = &(adapter->recvpriv);
if (precvpriv->sink_udpport > 0) {
if (*((u16 *)(ehdr_pos + 0x24)) == cpu_to_be16(precvpriv->sink_udpport)) {
precvpriv->pre_rtp_rxseq = precvpriv->cur_rtp_rxseq;
precvpriv->cur_rtp_rxseq = be16_to_cpu(*((u16 *)(ehdr_pos + 0x2C)));
if (precvpriv->pre_rtp_rxseq + 1 != precvpriv->cur_rtp_rxseq)
RTW_INFO("%s : RTP Seq num from %d to %d\n", __FUNCTION__, precvpriv->pre_rtp_rxseq, precvpriv->cur_rtp_rxseq);
}
}
}
void sta_rx_reorder_ctl_dump(void *sel, struct sta_info *sta)
{
struct recv_reorder_ctrl *reorder_ctl;
int i;
for (i = 0; i < 16; i++) {
reorder_ctl = &sta->recvreorder_ctrl[i];
if (reorder_ctl->ampdu_size != RX_AMPDU_SIZE_INVALID || reorder_ctl->indicate_seq != 0xFFFF) {
RTW_PRINT_SEL(sel, "tid=%d, enable=%d, ampdu_size=%u, indicate_seq=%u\n"
, i, reorder_ctl->enable, reorder_ctl->ampdu_size, reorder_ctl->indicate_seq
);
}
}
}
void dump_tx_rate_bmp(void *sel, struct dvobj_priv *dvobj)
{
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
struct rf_ctl_t *rfctl = dvobj_to_rfctl(dvobj);
u8 bw;
RTW_PRINT_SEL(sel, "%-6s", "bw");
if (hal_chk_proto_cap(adapter, PROTO_CAP_11AC))
_RTW_PRINT_SEL(sel, " %-11s", "vht");
_RTW_PRINT_SEL(sel, " %-11s %-4s %-3s\n", "ht", "ofdm", "cck");
for (bw = CHANNEL_WIDTH_20; bw <= CHANNEL_WIDTH_160; bw++) {
if (!hal_is_bw_support(adapter, bw))
continue;
RTW_PRINT_SEL(sel, "%6s", ch_width_str(bw));
if (hal_chk_proto_cap(adapter, PROTO_CAP_11AC)) {
_RTW_PRINT_SEL(sel, " %03x %03x %03x"
, RATE_BMP_GET_VHT_3SS(rfctl->rate_bmp_vht_by_bw[bw])
, RATE_BMP_GET_VHT_2SS(rfctl->rate_bmp_vht_by_bw[bw])
, RATE_BMP_GET_VHT_1SS(rfctl->rate_bmp_vht_by_bw[bw])
);
}
_RTW_PRINT_SEL(sel, " %02x %02x %02x %02x"
, bw <= CHANNEL_WIDTH_40 ? RATE_BMP_GET_HT_4SS(rfctl->rate_bmp_ht_by_bw[bw]) : 0
, bw <= CHANNEL_WIDTH_40 ? RATE_BMP_GET_HT_3SS(rfctl->rate_bmp_ht_by_bw[bw]) : 0
, bw <= CHANNEL_WIDTH_40 ? RATE_BMP_GET_HT_2SS(rfctl->rate_bmp_ht_by_bw[bw]) : 0
, bw <= CHANNEL_WIDTH_40 ? RATE_BMP_GET_HT_1SS(rfctl->rate_bmp_ht_by_bw[bw]) : 0
);
_RTW_PRINT_SEL(sel, " %03x %01x\n"
, bw <= CHANNEL_WIDTH_20 ? RATE_BMP_GET_OFDM(rfctl->rate_bmp_cck_ofdm) : 0
, bw <= CHANNEL_WIDTH_20 ? RATE_BMP_GET_CCK(rfctl->rate_bmp_cck_ofdm) : 0
);
}
}
void dump_adapters_status(void *sel, struct dvobj_priv *dvobj)
{
struct rf_ctl_t *rfctl = dvobj_to_rfctl(dvobj);
int i;
_adapter *iface;
u8 u_ch, u_bw, u_offset;
#if (defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)) || defined(CONFIG_CLIENT_PORT_CFG)
char str_val[64] = {'\0'};
#endif
dump_mi_status(sel, dvobj);
#if defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)
RTW_PRINT_SEL(sel, "[AP] LIMITED_AP_NUM:%d\n", CONFIG_LIMITED_AP_NUM);
RTW_PRINT_SEL(sel, "[AP] vap_map:0x%02x\n", dvobj->vap_map);
#endif
#ifdef CONFIG_HW_P0_TSF_SYNC
RTW_PRINT_SEL(sel, "[AP] p0 tsf sync port = %d\n", dvobj->p0_tsf.sync_port);
RTW_PRINT_SEL(sel, "[AP] p0 tsf timer offset = %d\n", dvobj->p0_tsf.offset);
#endif
#ifdef CONFIG_CLIENT_PORT_CFG
RTW_PRINT_SEL(sel, "[CLT] clt_num = %d\n", dvobj->clt_port.num);
RTW_PRINT_SEL(sel, "[CLT] clt_map = 0x%02x\n", dvobj->clt_port.bmp);
#endif
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
RTW_PRINT_SEL(sel, "[MI] default port id:%d\n\n", dvobj->dft.port_id);
#endif /* CONFIG_FW_MULTI_PORT_SUPPORT */
RTW_PRINT_SEL(sel, "dev status:%s%s\n\n"
, dev_is_surprise_removed(dvobj) ? " SR" : ""
, dev_is_drv_stopped(dvobj) ? " DS" : ""
);
#ifdef CONFIG_P2P
#define P2P_INFO_TITLE_FMT " %-3s %-4s"
#define P2P_INFO_TITLE_ARG , "lch", "p2ps"
#ifdef CONFIG_IOCTL_CFG80211
#define P2P_INFO_VALUE_FMT " %3u %c%3u"
#define P2P_INFO_VALUE_ARG , iface->wdinfo.listen_channel, iface->wdev_data.p2p_enabled ? 'e' : ' ', rtw_p2p_state(&iface->wdinfo)
#else
#define P2P_INFO_VALUE_FMT " %3u %4u"
#define P2P_INFO_VALUE_ARG , iface->wdinfo.listen_channel, rtw_p2p_state(&iface->wdinfo)
#endif
#define P2P_INFO_DASH "---------"
#else
#define P2P_INFO_TITLE_FMT ""
#define P2P_INFO_TITLE_ARG
#define P2P_INFO_VALUE_FMT ""
#define P2P_INFO_VALUE_ARG
#define P2P_INFO_DASH
#endif
#ifdef DBG_TSF_UPDATE
#define TSF_PAUSE_TIME_TITLE_FMT " %-5s"
#define TSF_PAUSE_TIME_TITLE_ARG , "tsfup"
#define TSF_PAUSE_TIME_VALUE_FMT " %5d"
#define TSF_PAUSE_TIME_VALUE_ARG , ((iface->mlmeextpriv.tsf_update_required && iface->mlmeextpriv.tsf_update_pause_stime) ? (rtw_get_passing_time_ms(iface->mlmeextpriv.tsf_update_pause_stime) > 99999 ? 99999 : rtw_get_passing_time_ms(iface->mlmeextpriv.tsf_update_pause_stime)) : 0)
#else
#define TSF_PAUSE_TIME_TITLE_FMT ""
#define TSF_PAUSE_TIME_TITLE_ARG
#define TSF_PAUSE_TIME_VALUE_FMT ""
#define TSF_PAUSE_TIME_VALUE_ARG
#endif
#if (defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)) || defined(CONFIG_CLIENT_PORT_CFG)
#define INFO_FMT " %-4s"
#define INFO_ARG , "info"
#define INFO_CNT_FMT " %-20s"
#define INFO_CNT_ARG , str_val
#else
#define INFO_FMT ""
#define INFO_ARG
#define INFO_CNT_FMT ""
#define INFO_CNT_ARG
#endif
RTW_PRINT_SEL(sel, "%-2s %-15s %c %-3s %-3s %-3s %-17s %-4s %-7s"
P2P_INFO_TITLE_FMT
TSF_PAUSE_TIME_TITLE_FMT
" %s"INFO_FMT"\n"
, "id", "ifname", ' ', "bup", "nup", "ncd", "macaddr", "port", "ch"
P2P_INFO_TITLE_ARG
TSF_PAUSE_TIME_TITLE_ARG
, "status"INFO_ARG);
RTW_PRINT_SEL(sel, "---------------------------------------------------------------"
P2P_INFO_DASH
"-------\n");
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface) {
#if (defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)) || defined(CONFIG_CLIENT_PORT_CFG)
_rtw_memset(&str_val, '\0', sizeof(str_val));
#endif
#if defined(CONFIG_SUPPORT_MULTI_BCN) && defined(CONFIG_FW_HANDLE_TXBCN)
if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
u8 len;
char *p = str_val;
char tmp_str[10] = {'\0'};
len = snprintf(tmp_str, sizeof(tmp_str), "%s", "ap_id:");
strncpy(p, tmp_str, len);
p += len;
_rtw_memset(&tmp_str, '\0', sizeof(tmp_str));
#ifdef DBG_HW_PORT
len = snprintf(tmp_str, sizeof(tmp_str), "%d (%d,%d)", iface->vap_id, iface->hw_port, iface->client_port);
#else
len = snprintf(tmp_str, sizeof(tmp_str), "%d", iface->vap_id);
#endif
strncpy(p, tmp_str, len);
}
#endif
#ifdef CONFIG_CLIENT_PORT_CFG
if (MLME_IS_STA(iface)) {
u8 len;
char *p = str_val;
char tmp_str[10] = {'\0'};
len = snprintf(tmp_str, sizeof(tmp_str), "%s", "c_pid:");
strncpy(p, tmp_str, len);
p += len;
_rtw_memset(&tmp_str, '\0', sizeof(tmp_str));
#ifdef DBG_HW_PORT
len = snprintf(tmp_str, sizeof(tmp_str), "%d (%d,%d)", iface->client_port, iface->hw_port, iface->client_port);
#else
len = snprintf(tmp_str, sizeof(tmp_str), "%d", iface->client_port);
#endif
strncpy(p, tmp_str, len);
}
#endif
RTW_PRINT_SEL(sel, "%2d %-15s %c %3u %3u %3u "MAC_FMT" %4hhu %3u,%u,%u"
P2P_INFO_VALUE_FMT
TSF_PAUSE_TIME_VALUE_FMT
" "MLME_STATE_FMT" " INFO_CNT_FMT"\n"
, i, iface->registered ? ADPT_ARG(iface) : NULL
, iface->registered ? 'R' : ' '
, iface->bup
, iface->netif_up
, iface->net_closed
, MAC_ARG(adapter_mac_addr(iface))
, rtw_hal_get_port(iface)
, iface->mlmeextpriv.cur_channel
, iface->mlmeextpriv.cur_bwmode
, iface->mlmeextpriv.cur_ch_offset
P2P_INFO_VALUE_ARG
TSF_PAUSE_TIME_VALUE_ARG
, MLME_STATE_ARG(iface)
INFO_CNT_ARG
);
}
}
RTW_PRINT_SEL(sel, "---------------------------------------------------------------"
P2P_INFO_DASH
"-------\n");
rtw_mi_get_ch_setting_union(dvobj_get_primary_adapter(dvobj), &u_ch, &u_bw, &u_offset);
RTW_PRINT_SEL(sel, "%55s %3u,%u,%u\n"
, "union:"
, u_ch, u_bw, u_offset
);
RTW_PRINT_SEL(sel, "%55s %3u,%u,%u offch_state:%d\n"
, "oper:"
, dvobj->oper_channel
, dvobj->oper_bwmode
, dvobj->oper_ch_offset
, rfctl->offch_state
);
#ifdef CONFIG_DFS_MASTER
if (rfctl->radar_detect_ch != 0) {
RTW_PRINT_SEL(sel, "%55s %3u,%u,%u"
, "radar_detect:"
, rfctl->radar_detect_ch
, rfctl->radar_detect_bw
, rfctl->radar_detect_offset
);
if (rfctl->radar_detect_by_others)
_RTW_PRINT_SEL(sel, ", by AP of STA link");
else {
u32 non_ocp_ms;
u32 cac_ms;
u8 dfs_domain = rtw_odm_get_dfs_domain(dvobj);
_RTW_PRINT_SEL(sel, ", domain:%u", dfs_domain);
rtw_get_ch_waiting_ms(rfctl
, rfctl->radar_detect_ch
, rfctl->radar_detect_bw
, rfctl->radar_detect_offset
, &non_ocp_ms
, &cac_ms
);
if (non_ocp_ms)
_RTW_PRINT_SEL(sel, ", non_ocp:%d", non_ocp_ms);
if (cac_ms)
_RTW_PRINT_SEL(sel, ", cac:%d", cac_ms);
}
_RTW_PRINT_SEL(sel, "\n");
}
#endif /* CONFIG_DFS_MASTER */
}
#define SEC_CAM_ENT_ID_TITLE_FMT "%-2s"
#define SEC_CAM_ENT_ID_TITLE_ARG "id"
#define SEC_CAM_ENT_ID_VALUE_FMT "%2u"
#define SEC_CAM_ENT_ID_VALUE_ARG(id) (id)
#define SEC_CAM_ENT_TITLE_FMT "%-6s %-17s %-32s %-3s %-7s %-2s %-2s %-5s"
#define SEC_CAM_ENT_TITLE_ARG "ctrl", "addr", "key", "kid", "type", "MK", "GK", "valid"
#define SEC_CAM_ENT_VALUE_FMT "0x%04x "MAC_FMT" "KEY_FMT" %3u %-7s %2u %2u %5u"
#define SEC_CAM_ENT_VALUE_ARG(ent) \
(ent)->ctrl \
, MAC_ARG((ent)->mac) \
, KEY_ARG((ent)->key) \
, ((ent)->ctrl) & 0x03 \
, security_type_str((((ent)->ctrl) >> 2) & 0x07) \
, (((ent)->ctrl) >> 5) & 0x01 \
, (((ent)->ctrl) >> 6) & 0x01 \
, (((ent)->ctrl) >> 15) & 0x01
void dump_sec_cam_ent(void *sel, struct sec_cam_ent *ent, int id)
{
if (id >= 0) {
RTW_PRINT_SEL(sel, SEC_CAM_ENT_ID_VALUE_FMT " " SEC_CAM_ENT_VALUE_FMT"\n"
, SEC_CAM_ENT_ID_VALUE_ARG(id), SEC_CAM_ENT_VALUE_ARG(ent));
} else
RTW_PRINT_SEL(sel, SEC_CAM_ENT_VALUE_FMT"\n", SEC_CAM_ENT_VALUE_ARG(ent));
}
void dump_sec_cam_ent_title(void *sel, u8 has_id)
{
if (has_id) {
RTW_PRINT_SEL(sel, SEC_CAM_ENT_ID_TITLE_FMT " " SEC_CAM_ENT_TITLE_FMT"\n"
, SEC_CAM_ENT_ID_TITLE_ARG, SEC_CAM_ENT_TITLE_ARG);
} else
RTW_PRINT_SEL(sel, SEC_CAM_ENT_TITLE_FMT"\n", SEC_CAM_ENT_TITLE_ARG);
}
void dump_sec_cam(void *sel, _adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
struct sec_cam_ent ent;
int i;
RTW_PRINT_SEL(sel, "HW sec cam:\n");
dump_sec_cam_ent_title(sel, 1);
for (i = 0; i < cam_ctl->num; i++) {
rtw_sec_read_cam_ent(adapter, i, (u8 *)(&ent.ctrl), ent.mac, ent.key);
dump_sec_cam_ent(sel , &ent, i);
}
}
void dump_sec_cam_cache(void *sel, _adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
int i;
RTW_PRINT_SEL(sel, "SW sec cam cache:\n");
dump_sec_cam_ent_title(sel, 1);
for (i = 0; i < cam_ctl->num; i++) {
if (dvobj->cam_cache[i].ctrl != 0)
dump_sec_cam_ent(sel, &dvobj->cam_cache[i], i);
}
}
static u8 fwdl_test_chksum_fail = 0;
static u8 fwdl_test_wintint_rdy_fail = 0;
bool rtw_fwdl_test_trigger_chksum_fail(void)
{
if (fwdl_test_chksum_fail) {
RTW_PRINT("fwdl test case: trigger chksum_fail\n");
fwdl_test_chksum_fail--;
return _TRUE;
}
return _FALSE;
}
bool rtw_fwdl_test_trigger_wintint_rdy_fail(void)
{
if (fwdl_test_wintint_rdy_fail) {
RTW_PRINT("fwdl test case: trigger wintint_rdy_fail\n");
fwdl_test_wintint_rdy_fail--;
return _TRUE;
}
return _FALSE;
}
static u8 del_rx_ampdu_test_no_tx_fail = 0;
bool rtw_del_rx_ampdu_test_trigger_no_tx_fail(void)
{
if (del_rx_ampdu_test_no_tx_fail) {
RTW_PRINT("del_rx_ampdu test case: trigger no_tx_fail\n");
del_rx_ampdu_test_no_tx_fail--;
return _TRUE;
}
return _FALSE;
}
static u32 g_wait_hiq_empty_ms = 0;
u32 rtw_get_wait_hiq_empty_ms(void)
{
return g_wait_hiq_empty_ms;
}
static systime sta_linking_test_start_time = 0;
static u32 sta_linking_test_wait_ms = 0;
static u8 sta_linking_test_force_fail = 0;
void rtw_sta_linking_test_set_start(void)
{
sta_linking_test_start_time = rtw_get_current_time();
}
bool rtw_sta_linking_test_wait_done(void)
{
return rtw_get_passing_time_ms(sta_linking_test_start_time) >= sta_linking_test_wait_ms;
}
bool rtw_sta_linking_test_force_fail(void)
{
return sta_linking_test_force_fail;
}
#ifdef CONFIG_AP_MODE
static u16 ap_linking_test_force_auth_fail = 0;
static u16 ap_linking_test_force_asoc_fail = 0;
u16 rtw_ap_linking_test_force_auth_fail(void)
{
return ap_linking_test_force_auth_fail;
}
u16 rtw_ap_linking_test_force_asoc_fail(void)
{
return ap_linking_test_force_asoc_fail;
}
#endif
#ifdef CONFIG_PROC_DEBUG
ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 addr, val, len;
if (count < 3) {
RTW_INFO("argument size is less than 3\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%x %x %x", &addr, &val, &len);
if (num != 3) {
RTW_INFO("invalid write_reg parameter!\n");
return count;
}
switch (len) {
case 1:
rtw_write8(padapter, addr, (u8)val);
break;
case 2:
rtw_write16(padapter, addr, (u16)val);
break;
case 4:
rtw_write32(padapter, addr, val);
break;
default:
RTW_INFO("error write length=%d", len);
break;
}
}
return count;
}
static u32 proc_get_read_addr = 0xeeeeeeee;
static u32 proc_get_read_len = 0x4;
int proc_get_read_reg(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if (proc_get_read_addr == 0xeeeeeeee) {
RTW_PRINT_SEL(m, "address not initialized\n");
return 0;
}
switch (proc_get_read_len) {
case 1:
RTW_PRINT_SEL(m, "rtw_read8(0x%x)=0x%x\n", proc_get_read_addr, rtw_read8(padapter, proc_get_read_addr));
break;
case 2:
RTW_PRINT_SEL(m, "rtw_read16(0x%x)=0x%x\n", proc_get_read_addr, rtw_read16(padapter, proc_get_read_addr));
break;
case 4:
RTW_PRINT_SEL(m, "rtw_read32(0x%x)=0x%x\n", proc_get_read_addr, rtw_read32(padapter, proc_get_read_addr));
break;
default:
RTW_PRINT_SEL(m, "error read length=%d\n", proc_get_read_len);
break;
}
return 0;
}
ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[16];
u32 addr, len;
if (count < 2) {
RTW_INFO("argument size is less than 2\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%x %x", &addr, &len);
if (num != 2) {
RTW_INFO("invalid read_reg parameter!\n");
return count;
}
proc_get_read_addr = addr;
proc_get_read_len = len;
}
return count;
}
int proc_get_rx_stat(struct seq_file *m, void *v)
{
_irqL irqL;
_list *plist, *phead;
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct sta_info *psta = NULL;
struct stainfo_stats *pstats = NULL;
struct sta_priv *pstapriv = &(adapter->stapriv);
u32 i, j;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
pstats = &psta->sta_stats;
if (pstats == NULL)
continue;
if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
RTW_PRINT_SEL(m, "MAC :\t\t"MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
RTW_PRINT_SEL(m, "data_rx_cnt :\t%llu\n", sta_rx_data_uc_pkts(psta) - pstats->last_rx_data_uc_pkts);
pstats->last_rx_data_uc_pkts = sta_rx_data_uc_pkts(psta);
RTW_PRINT_SEL(m, "duplicate_cnt :\t%u\n", pstats->duplicate_cnt);
pstats->duplicate_cnt = 0;
RTW_PRINT_SEL(m, "rx_per_rate_cnt :\n");
for (j = 0; j < 0x60; j++) {
RTW_PRINT_SEL(m, "%08u ", pstats->rxratecnt[j]);
pstats->rxratecnt[j] = 0;
if ((j%8) == 7)
RTW_PRINT_SEL(m, "\n");
}
RTW_PRINT_SEL(m, "\n");
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
return 0;
}
int proc_get_tx_stat(struct seq_file *m, void *v)
{
_irqL irqL;
_list *plist, *phead;
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct sta_info *psta = NULL;
u8 sta_mac[NUM_STA][ETH_ALEN] = {{0}};
uint mac_id[NUM_STA];
struct stainfo_stats *pstats = NULL;
struct sta_priv *pstapriv = &(adapter->stapriv);
struct sta_priv *pstapriv_primary = &(GET_PRIMARY_ADAPTER(adapter))->stapriv;
u32 i, macid_rec_idx = 0;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
struct submit_ctx gotc2h;
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
_rtw_memcpy(&sta_mac[macid_rec_idx][0], psta->cmn.mac_addr, ETH_ALEN);
mac_id[macid_rec_idx] = psta->cmn.mac_id;
macid_rec_idx++;
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < macid_rec_idx; i++) {
_rtw_memcpy(pstapriv_primary->c2h_sta_mac, &sta_mac[i][0], ETH_ALEN);
pstapriv_primary->c2h_adapter_id = adapter->iface_id;
rtw_sctx_init(&gotc2h, 60);
pstapriv_primary->gotc2h = &gotc2h;
rtw_hal_reqtxrpt(adapter, mac_id[i]);
if (rtw_sctx_wait(&gotc2h, __func__)) {
psta = rtw_get_stainfo(pstapriv, &sta_mac[i][0]);
if(psta) {
pstats = &psta->sta_stats;
#ifndef ROKU_PRIVATE
RTW_PRINT_SEL(m, "data_sent_cnt :\t%u\n", pstats->tx_ok_cnt + pstats->tx_fail_cnt);
RTW_PRINT_SEL(m, "success_cnt :\t%u\n", pstats->tx_ok_cnt);
RTW_PRINT_SEL(m, "failure_cnt :\t%u\n", pstats->tx_fail_cnt);
RTW_PRINT_SEL(m, "retry_cnt :\t%u\n\n", pstats->tx_retry_cnt);
#else
RTW_PRINT_SEL(m, "MAC: " MAC_FMT " sent: %u fail: %u retry: %u\n",
MAC_ARG(&sta_mac[i][0]), pstats->tx_ok_cnt, pstats->tx_fail_cnt, pstats->tx_retry_cnt);
#endif /* ROKU_PRIVATE */
} else
RTW_PRINT_SEL(m, "STA is gone\n");
} else {
//to avoid c2h modify counters
pstapriv_primary->gotc2h = NULL;
_rtw_memset(pstapriv_primary->c2h_sta_mac, 0, ETH_ALEN);
pstapriv_primary->c2h_adapter_id = CONFIG_IFACE_NUMBER;
RTW_PRINT_SEL(m, "Warming : Query timeout, operation abort!!\n");
break;
}
pstapriv_primary->gotc2h = NULL;
_rtw_memset(pstapriv_primary->c2h_sta_mac, 0, ETH_ALEN);
pstapriv_primary->c2h_adapter_id = CONFIG_IFACE_NUMBER;
}
return 0;
}
int proc_get_fwstate(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
RTW_PRINT_SEL(m, "fwstate=0x%x\n", get_fwstate(pmlmepriv));
return 0;
}
int proc_get_sec_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct security_priv *sec = &padapter->securitypriv;
RTW_PRINT_SEL(m, "auth_alg=0x%x, enc_alg=0x%x, auth_type=0x%x, enc_type=0x%x\n",
sec->dot11AuthAlgrthm, sec->dot11PrivacyAlgrthm,
sec->ndisauthtype, sec->ndisencryptstatus);
RTW_PRINT_SEL(m, "hw_decrypted=%d\n", sec->hw_decrypted);
#ifdef DBG_SW_SEC_CNT
RTW_PRINT_SEL(m, "wep_sw_enc_cnt=%llu, %llu, %llu\n"
, sec->wep_sw_enc_cnt_bc , sec->wep_sw_enc_cnt_mc, sec->wep_sw_enc_cnt_uc);
RTW_PRINT_SEL(m, "wep_sw_dec_cnt=%llu, %llu, %llu\n"
, sec->wep_sw_dec_cnt_bc , sec->wep_sw_dec_cnt_mc, sec->wep_sw_dec_cnt_uc);
RTW_PRINT_SEL(m, "tkip_sw_enc_cnt=%llu, %llu, %llu\n"
, sec->tkip_sw_enc_cnt_bc , sec->tkip_sw_enc_cnt_mc, sec->tkip_sw_enc_cnt_uc);
RTW_PRINT_SEL(m, "tkip_sw_dec_cnt=%llu, %llu, %llu\n"
, sec->tkip_sw_dec_cnt_bc , sec->tkip_sw_dec_cnt_mc, sec->tkip_sw_dec_cnt_uc);
RTW_PRINT_SEL(m, "aes_sw_enc_cnt=%llu, %llu, %llu\n"
, sec->aes_sw_enc_cnt_bc , sec->aes_sw_enc_cnt_mc, sec->aes_sw_enc_cnt_uc);
RTW_PRINT_SEL(m, "aes_sw_dec_cnt=%llu, %llu, %llu\n"
, sec->aes_sw_dec_cnt_bc , sec->aes_sw_dec_cnt_mc, sec->aes_sw_dec_cnt_uc);
#endif /* DBG_SW_SEC_CNT */
return 0;
}
int proc_get_mlmext_state(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
RTW_PRINT_SEL(m, "pmlmeinfo->state=0x%x\n", pmlmeinfo->state);
return 0;
}
#ifdef CONFIG_LAYER2_ROAMING
int proc_get_roam_flags(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "0x%02x\n", rtw_roam_flags(adapter));
return 0;
}
ssize_t proc_set_roam_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 flags;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx", &flags);
if (num == 1)
rtw_assign_roam_flags(adapter, flags);
}
return count;
}
int proc_get_roam_param(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *mlme = &adapter->mlmepriv;
RTW_PRINT_SEL(m, "%12s %15s %26s %16s\n", "rssi_diff_th", "scanr_exp_ms", "scan_interval(unit:2 sec)", "rssi_threshold");
RTW_PRINT_SEL(m, "%-15u %-13u %-27u %-11u\n"
, mlme->roam_rssi_diff_th
, mlme->roam_scanr_exp_ms
, mlme->roam_scan_int
, mlme->roam_rssi_threshold
);
return 0;
}
ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *mlme = &adapter->mlmepriv;
char tmp[32];
u8 rssi_diff_th;
u32 scanr_exp_ms;
u32 scan_int;
u8 rssi_threshold;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhu %u %u %hhu", &rssi_diff_th, &scanr_exp_ms, &scan_int, &rssi_threshold);
if (num >= 1)
mlme->roam_rssi_diff_th = rssi_diff_th;
if (num >= 2)
mlme->roam_scanr_exp_ms = scanr_exp_ms;
if (num >= 3)
mlme->roam_scan_int = scan_int;
if (num >= 4)
mlme->roam_rssi_threshold = rssi_threshold;
}
return count;
}
ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 addr[ETH_ALEN];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx:%hhx:%hhx:%hhx:%hhx:%hhx", addr, addr + 1, addr + 2, addr + 3, addr + 4, addr + 5);
if (num == 6)
_rtw_memcpy(adapter->mlmepriv.roam_tgt_addr, addr, ETH_ALEN);
RTW_INFO("set roam_tgt_addr to "MAC_FMT"\n", MAC_ARG(adapter->mlmepriv.roam_tgt_addr));
}
return count;
}
#endif /* CONFIG_LAYER2_ROAMING */
#ifdef CONFIG_RTW_80211R
ssize_t proc_set_ft_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 flags;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx", &flags);
if (num == 1)
adapter->mlmepriv.ft_roam.ft_flags = flags;
}
return count;
}
int proc_get_ft_flags(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "0x%02x\n", adapter->mlmepriv.ft_roam.ft_flags);
return 0;
}
#endif
int proc_get_qos_option(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
RTW_PRINT_SEL(m, "qos_option=%d\n", pmlmepriv->qospriv.qos_option);
return 0;
}
int proc_get_ht_option(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
#ifdef CONFIG_80211N_HT
RTW_PRINT_SEL(m, "ht_option=%d\n", pmlmepriv->htpriv.ht_option);
#endif /* CONFIG_80211N_HT */
return 0;
}
int proc_get_rf_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
RTW_PRINT_SEL(m, "cur_ch=%d, cur_bw=%d, cur_ch_offet=%d\n",
pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
RTW_PRINT_SEL(m, "oper_ch=%d, oper_bw=%d, oper_ch_offet=%d\n",
rtw_get_oper_ch(padapter), rtw_get_oper_bw(padapter), rtw_get_oper_choffset(padapter));
return 0;
}
int proc_get_scan_param(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct ss_res *ss = &mlmeext->sitesurvey_res;
#define SCAN_PARAM_TITLE_FMT "%10s"
#define SCAN_PARAM_VALUE_FMT "%-10u"
#define SCAN_PARAM_TITLE_ARG , "scan_ch_ms"
#define SCAN_PARAM_VALUE_ARG , ss->scan_ch_ms
#ifdef CONFIG_80211N_HT
#define SCAN_PARAM_TITLE_FMT_HT " %15s %13s"
#define SCAN_PARAM_VALUE_FMT_HT " %-15u %-13u"
#define SCAN_PARAM_TITLE_ARG_HT , "rx_ampdu_accept", "rx_ampdu_size"
#define SCAN_PARAM_VALUE_ARG_HT , ss->rx_ampdu_accept, ss->rx_ampdu_size
#else
#define SCAN_PARAM_TITLE_FMT_HT ""
#define SCAN_PARAM_VALUE_FMT_HT ""
#define SCAN_PARAM_TITLE_ARG_HT
#define SCAN_PARAM_VALUE_ARG_HT
#endif
#ifdef CONFIG_SCAN_BACKOP
#define SCAN_PARAM_TITLE_FMT_BACKOP " %9s %12s"
#define SCAN_PARAM_VALUE_FMT_BACKOP " %-9u %-12u"
#define SCAN_PARAM_TITLE_ARG_BACKOP , "backop_ms", "scan_cnt_max"
#define SCAN_PARAM_VALUE_ARG_BACKOP , ss->backop_ms, ss->scan_cnt_max
#else
#define SCAN_PARAM_TITLE_FMT_BACKOP ""
#define SCAN_PARAM_VALUE_FMT_BACKOP ""
#define SCAN_PARAM_TITLE_ARG_BACKOP
#define SCAN_PARAM_VALUE_ARG_BACKOP
#endif
RTW_PRINT_SEL(m,
SCAN_PARAM_TITLE_FMT
SCAN_PARAM_TITLE_FMT_HT
SCAN_PARAM_TITLE_FMT_BACKOP
"\n"
SCAN_PARAM_TITLE_ARG
SCAN_PARAM_TITLE_ARG_HT
SCAN_PARAM_TITLE_ARG_BACKOP
);
RTW_PRINT_SEL(m,
SCAN_PARAM_VALUE_FMT
SCAN_PARAM_VALUE_FMT_HT
SCAN_PARAM_VALUE_FMT_BACKOP
"\n"
SCAN_PARAM_VALUE_ARG
SCAN_PARAM_VALUE_ARG_HT
SCAN_PARAM_VALUE_ARG_BACKOP
);
return 0;
}
ssize_t proc_set_scan_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct ss_res *ss = &mlmeext->sitesurvey_res;
char tmp[32] = {0};
u16 scan_ch_ms;
#define SCAN_PARAM_INPUT_FMT "%hu"
#define SCAN_PARAM_INPUT_ARG , &scan_ch_ms
#ifdef CONFIG_80211N_HT
u8 rx_ampdu_accept;
u8 rx_ampdu_size;
#define SCAN_PARAM_INPUT_FMT_HT " %hhu %hhu"
#define SCAN_PARAM_INPUT_ARG_HT , &rx_ampdu_accept, &rx_ampdu_size
#else
#define SCAN_PARAM_INPUT_FMT_HT ""
#define SCAN_PARAM_INPUT_ARG_HT
#endif
#ifdef CONFIG_SCAN_BACKOP
u16 backop_ms;
u8 scan_cnt_max;
#define SCAN_PARAM_INPUT_FMT_BACKOP " %hu %hhu"
#define SCAN_PARAM_INPUT_ARG_BACKOP , &backop_ms, &scan_cnt_max
#else
#define SCAN_PARAM_INPUT_FMT_BACKOP ""
#define SCAN_PARAM_INPUT_ARG_BACKOP
#endif
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp,
SCAN_PARAM_INPUT_FMT
SCAN_PARAM_INPUT_FMT_HT
SCAN_PARAM_INPUT_FMT_BACKOP
SCAN_PARAM_INPUT_ARG
SCAN_PARAM_INPUT_ARG_HT
SCAN_PARAM_INPUT_ARG_BACKOP
);
if (num-- > 0)
ss->scan_ch_ms = scan_ch_ms;
#ifdef CONFIG_80211N_HT
if (num-- > 0)
ss->rx_ampdu_accept = rx_ampdu_accept;
if (num-- > 0)
ss->rx_ampdu_size = rx_ampdu_size;
#endif
#ifdef CONFIG_SCAN_BACKOP
if (num-- > 0)
ss->backop_ms = backop_ms;
if (num-- > 0)
ss->scan_cnt_max = scan_cnt_max;
#endif
}
return count;
}
int proc_get_scan_abort(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
u32 pass_ms;
pass_ms = rtw_scan_abort_timeout(adapter, 10000);
RTW_PRINT_SEL(m, "%u\n", pass_ms);
return 0;
}
#ifdef CONFIG_RTW_REPEATER_SON
int proc_get_rson_data(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char rson_data_str[256];
rtw_rson_get_property_str(padapter, rson_data_str);
RTW_PRINT_SEL(m, "%s\n", rson_data_str);
return 0;
}
ssize_t proc_set_rson_data(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
char tmp[64] = {0};
int num;
u8 field[10], value[64];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
num = sscanf(tmp, "%s %s", field, value);
if (num != 2) {
RTW_INFO("Invalid format : echo > son_data\n");
return count;
}
RTW_INFO("field=%s value=%s\n", field, value);
num = rtw_rson_set_property(padapter, field, value);
if (num != 1) {
RTW_INFO("Invalid field(%s) or value(%s)\n", field, value);
return count;
}
}
return count;
}
#endif /*CONFIG_RTW_REPEATER_SON*/
int proc_get_survey_info(struct seq_file *m, void *v)
{
_irqL irqL;
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
_queue *queue = &(pmlmepriv->scanned_queue);
struct wlan_network *pnetwork = NULL;
_list *plist, *phead;
s32 notify_signal;
s16 notify_noise = 0;
u16 index = 0, ie_cap = 0;
unsigned char *ie_wpa = NULL, *ie_wpa2 = NULL, *ie_wps = NULL;
unsigned char *ie_p2p = NULL, *ssid = NULL;
char flag_str[64];
int ielen = 0;
u32 wpsielen = 0;
#ifdef CONFIG_RTW_MESH
const char *ssid_title_str = "ssid/mesh_id";
#else
const char *ssid_title_str = "ssid";
#endif
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
if (!phead)
goto _exit;
plist = get_next(phead);
if (!plist)
goto _exit;
#ifdef CONFIG_RTW_REPEATER_SON
rtw_rson_show_survey_info(m, plist, phead);
#else
RTW_PRINT_SEL(m, "%5s %-17s %3s %-3s %-4s %-4s %5s %32s %32s\n", "index", "bssid", "ch", "RSSI", "SdBm", "Noise", "age", "flag", ssid_title_str);
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
if (!pnetwork)
break;
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
is_same_network(&pmlmepriv->cur_network.network, &pnetwork->network, 0)) {
notify_signal = translate_percentage_to_dbm(padapter->recvpriv.signal_strength);/* dbm */
} else {
notify_signal = translate_percentage_to_dbm(pnetwork->network.PhyInfo.SignalStrength);/* dbm */
}
#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
if (IS_NM_ENABLE(padapter))
notify_noise = rtw_noise_query_by_chan_num(padapter, pnetwork->network.Configuration.DSConfig);
#endif
ie_wpa = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &ielen, pnetwork->network.IELength - 12);
ie_wpa2 = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &ielen, pnetwork->network.IELength - 12);
ie_cap = rtw_get_capability(&pnetwork->network);
ie_wps = rtw_get_wps_ie(&pnetwork->network.IEs[12], pnetwork->network.IELength - 12, NULL, &wpsielen);
ie_p2p = rtw_get_p2p_ie(&pnetwork->network.IEs[12], pnetwork->network.IELength - 12, NULL, &ielen);
ssid = pnetwork->network.Ssid.Ssid;
sprintf(flag_str, "%s%s%s%s%s%s%s",
(ie_wpa) ? "[WPA]" : "",
(ie_wpa2) ? "[WPA2]" : "",
(!ie_wpa && !ie_wpa && ie_cap & BIT(4)) ? "[WEP]" : "",
(ie_wps) ? "[WPS]" : "",
(pnetwork->network.InfrastructureMode == Ndis802_11IBSS) ? "[IBSS]" :
(pnetwork->network.InfrastructureMode == Ndis802_11_mesh) ? "[MESH]" : "",
(ie_cap & BIT(0)) ? "[ESS]" : "",
(ie_p2p) ? "[P2P]" : "");
RTW_PRINT_SEL(m, "%5d "MAC_FMT" %3d %3d %4d %4d %5d %32s %32s\n",
++index,
MAC_ARG(pnetwork->network.MacAddress),
pnetwork->network.Configuration.DSConfig,
(int)pnetwork->network.Rssi,
notify_signal,
notify_noise,
rtw_get_passing_time_ms(pnetwork->last_scanned),
flag_str,
pnetwork->network.InfrastructureMode == Ndis802_11_mesh ? pnetwork->network.mesh_id.Ssid : pnetwork->network.Ssid.Ssid
);
plist = get_next(plist);
}
#endif
_exit:
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
return 0;
}
ssize_t proc_set_survey_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
u8 _status = _FALSE;
u8 ssc_chk;
if (count < 1)
return -EFAULT;
#if 1
ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
if (ssc_chk != SS_ALLOW)
goto exit;
rtw_ps_deny(padapter, PS_DENY_SCAN);
if (_FAIL == rtw_pwr_wakeup(padapter))
goto cancel_ps_deny;
if (!rtw_is_adapter_up(padapter)) {
RTW_INFO("scan abort!! adapter cannot use\n");
goto cancel_ps_deny;
}
#else
#ifdef CONFIG_MP_INCLUDED
if (rtw_mp_mode_check(padapter)) {
RTW_INFO("MP mode block Scan request\n");
goto exit;
}
#endif
if (rtw_is_scan_deny(padapter)) {
RTW_INFO(FUNC_ADPT_FMT ": scan deny\n", FUNC_ADPT_ARG(padapter));
goto exit;
}
rtw_ps_deny(padapter, PS_DENY_SCAN);
if (_FAIL == rtw_pwr_wakeup(padapter))
goto cancel_ps_deny;
if (!rtw_is_adapter_up(padapter)) {
RTW_INFO("scan abort!! adapter cannot use\n");
goto cancel_ps_deny;
}
if (rtw_mi_busy_traffic_check(padapter, _FALSE)) {
RTW_INFO("scan abort!! BusyTraffic == _TRUE\n");
goto cancel_ps_deny;
}
if (check_fwstate(pmlmepriv, WIFI_AP_STATE) && check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
RTW_INFO("scan abort!! AP mode process WPS\n");
goto cancel_ps_deny;
}
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) {
RTW_INFO("scan abort!! fwstate=0x%x\n", pmlmepriv->fw_state);
goto cancel_ps_deny;
}
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(padapter,
_FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
RTW_INFO("scan abort!! buddy_fwstate check failed\n");
goto cancel_ps_deny;
}
#endif
#endif
_status = rtw_set_802_11_bssid_list_scan(padapter, NULL);
cancel_ps_deny:
rtw_ps_deny_cancel(padapter, PS_DENY_SCAN);
exit:
return count;
}
#ifdef ROKU_PRIVATE
int proc_get_infra_ap(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
struct sta_info *psta;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct ht_priv_infra_ap *phtpriv = &pmlmepriv->htpriv_infra_ap;
#ifdef CONFIG_80211AC_VHT
struct vht_priv_infra_ap *pvhtpriv = &pmlmepriv->vhtpriv_infra_ap;
#endif
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
struct sta_priv *pstapriv = &padapter->stapriv;
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
if (psta) {
unsigned int i, j;
unsigned int Rx_ss = 0, Tx_ss = 0;
struct recv_reorder_ctrl *preorder_ctrl;
RTW_PRINT_SEL(m, "SSID=%s\n", pmlmeinfo->network.Ssid.Ssid);
RTW_PRINT_SEL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
RTW_PRINT_SEL(m, "Supported rate=");
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
if (pmlmeinfo->SupportedRates_infra_ap[i] == 0)
break;
RTW_PRINT_SEL(m, " 0x%x", pmlmeinfo->SupportedRates_infra_ap[i]);
}
RTW_PRINT_SEL(m, "\n");
#ifdef CONFIG_80211N_HT
if (pmlmeinfo->ht_vht_received & BIT(0)) {
RTW_PRINT_SEL(m, "Supported MCS set=");
for (i = 0; i < 16 ; i++)
RTW_PRINT_SEL(m, " 0x%02x", phtpriv->MCS_set_infra_ap[i]);
RTW_PRINT_SEL(m, "\n");
RTW_PRINT_SEL(m, "highest supported data rate=0x%x\n", phtpriv->rx_highest_data_rate_infra_ap);
RTW_PRINT_SEL(m, "HT_supported_channel_width_set=0x%x\n", phtpriv->channel_width_infra_ap);
RTW_PRINT_SEL(m, "sgi_20m=%d, sgi_40m=%d\n", phtpriv->sgi_20m_infra_ap, phtpriv->sgi_40m_infra_ap);
RTW_PRINT_SEL(m, "ldpc_cap=0x%x, stbc_cap=0x%x\n", phtpriv->ldpc_cap_infra_ap, phtpriv->stbc_cap_infra_ap);
RTW_PRINT_SEL(m, "HT_number_of_stream=%d\n", phtpriv->Rx_ss_infra_ap);
}
#endif
#ifdef CONFIG_80211AC_VHT
if (pmlmeinfo->ht_vht_received & BIT(1)) {
RTW_PRINT_SEL(m, "VHT_supported_channel_width_set=0x%x\n", pvhtpriv->channel_width_infra_ap);
RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", pvhtpriv->ldpc_cap_infra_ap, pvhtpriv->stbc_cap_infra_ap, pvhtpriv->beamform_cap_infra_ap);
RTW_PRINT_SEL(m, "Rx_vht_mcs_map=0x%x, Tx_vht_mcs_map=0x%x\n", *(u16 *)pvhtpriv->vht_mcs_map_infra_ap, *(u16 *)pvhtpriv->vht_mcs_map_tx_infra_ap);
RTW_PRINT_SEL(m, "VHT_number_of_stream=%d\n", pvhtpriv->number_of_streams_infra_ap);
}
#endif
} else
RTW_PRINT_SEL(m, "can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
} else
RTW_PRINT_SEL(m, "this only applies to STA mode\n");
return 0;
}
#endif /* ROKU_PRIVATE */
int proc_get_ap_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
struct sta_info *psta;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_priv *pstapriv = &padapter->stapriv;
/* ap vendor */
char vendor[VENDOR_NAME_LEN] = {0};
get_assoc_AP_Vendor(vendor,pmlmeinfo->assoc_AP_vendor);
RTW_PRINT_SEL(m,"AP Vendor %s\n", vendor);
psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
if (psta) {
RTW_PRINT_SEL(m, "SSID=%s\n", cur_network->network.Ssid.Ssid);
RTW_PRINT_SEL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
RTW_PRINT_SEL(m, "cur_channel=%d, cur_bwmode=%d, cur_ch_offset=%d\n", pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
RTW_PRINT_SEL(m, "wireless_mode=0x%x, rtsen=%d, cts2slef=%d\n", psta->wireless_mode, psta->rtsen, psta->cts2self);
RTW_PRINT_SEL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n",
psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
#ifdef CONFIG_80211N_HT
RTW_PRINT_SEL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
RTW_PRINT_SEL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
, psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
RTW_PRINT_SEL(m, "ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
RTW_PRINT_SEL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
RTW_PRINT_SEL(m, "ldpc_cap=0x%x, stbc_cap=0x%x, beamform_cap=0x%x\n", psta->htpriv.ldpc_cap, psta->htpriv.stbc_cap, psta->htpriv.beamform_cap);
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
RTW_PRINT_SEL(m, "vht_en=%d, vht_sgi_80m=%d\n", psta->vhtpriv.vht_option, psta->vhtpriv.sgi_80m);
RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
RTW_PRINT_SEL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16 *)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
#endif
sta_rx_reorder_ctl_dump(m, psta);
} else
RTW_PRINT_SEL(m, "can't get sta's macaddr, cur_network's macaddr:" MAC_FMT "\n", MAC_ARG(cur_network->network.MacAddress));
return 0;
}
ssize_t proc_reset_trx_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct recv_priv *precvpriv = &padapter->recvpriv;
char cmd[32] = {0};
u8 cnt = 0;
if (count > sizeof(cmd)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(cmd, buffer, count)) {
int num = sscanf(cmd, "%hhx", &cnt);
if (num == 1 && cnt == 0) {
precvpriv->dbg_rx_ampdu_drop_count = 0;
precvpriv->dbg_rx_ampdu_forced_indicate_count = 0;
precvpriv->dbg_rx_ampdu_loss_count = 0;
precvpriv->dbg_rx_dup_mgt_frame_drop_count = 0;
precvpriv->dbg_rx_ampdu_window_shift_cnt = 0;
precvpriv->dbg_rx_conflic_mac_addr_cnt = 0;
precvpriv->dbg_rx_drop_count = 0;
}
}
return count;
}
int proc_get_trx_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
int i;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct recv_priv *precvpriv = &padapter->recvpriv;
struct hw_xmit *phwxmit;
u16 vo_params[4], vi_params[4], be_params[4], bk_params[4];
padapter->hal_func.read_wmmedca_reg(padapter, vo_params, vi_params, be_params, bk_params);
RTW_PRINT_SEL(m, "wmm_edca_vo, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", vo_params[0], vo_params[1], vo_params[2], vo_params[3]);
RTW_PRINT_SEL(m, "wmm_edca_vi, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", vi_params[0], vi_params[1], vi_params[2], vi_params[3]);
RTW_PRINT_SEL(m, "wmm_edca_be, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", be_params[0], be_params[1], be_params[2], be_params[3]);
RTW_PRINT_SEL(m, "wmm_edca_bk, aifs = %u us, cw_min = %u, cw_max = %u, txop_limit = %u us\n", bk_params[0], bk_params[1], bk_params[2], bk_params[3]);
dump_os_queue(m, padapter);
RTW_PRINT_SEL(m, "free_xmitbuf_cnt=%d, free_xmitframe_cnt=%d\n"
, pxmitpriv->free_xmitbuf_cnt, pxmitpriv->free_xmitframe_cnt);
RTW_PRINT_SEL(m, "free_ext_xmitbuf_cnt=%d, free_xframe_ext_cnt=%d\n"
, pxmitpriv->free_xmit_extbuf_cnt, pxmitpriv->free_xframe_ext_cnt);
RTW_PRINT_SEL(m, "free_recvframe_cnt=%d\n"
, precvpriv->free_recvframe_cnt);
for (i = 0; i < 4; i++) {
phwxmit = pxmitpriv->hwxmits + i;
RTW_PRINT_SEL(m, "%d, hwq.accnt=%d\n", i, phwxmit->accnt);
}
rtw_hal_get_hwreg(padapter, HW_VAR_DUMP_MAC_TXFIFO, (u8 *)m);
#ifdef CONFIG_USB_HCI
RTW_PRINT_SEL(m, "rx_urb_pending_cn=%d\n", ATOMIC_READ(&(precvpriv->rx_pending_cnt)));
#endif
dump_rx_bh_tk(m, &GET_PRIMARY_ADAPTER(padapter)->recvpriv);
/* Folowing are RX info */
RTW_PRINT_SEL(m, "RX: Count of Packets dropped by Driver: %llu\n", (unsigned long long)precvpriv->dbg_rx_drop_count);
/* Counts of packets whose seq_num is less than preorder_ctrl->indicate_seq, Ex delay, retransmission, redundant packets and so on */
RTW_PRINT_SEL(m, "Rx: Counts of Packets Whose Seq_Num Less Than Reorder Control Seq_Num: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_drop_count);
/* How many times the Rx Reorder Timer is triggered. */
RTW_PRINT_SEL(m, "Rx: Reorder Time-out Trigger Counts: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_forced_indicate_count);
/* Total counts of packets loss */
RTW_PRINT_SEL(m, "Rx: Packet Loss Counts: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_loss_count);
RTW_PRINT_SEL(m, "Rx: Duplicate Management Frame Drop Count: %llu\n", (unsigned long long)precvpriv->dbg_rx_dup_mgt_frame_drop_count);
RTW_PRINT_SEL(m, "Rx: AMPDU BA window shift Count: %llu\n", (unsigned long long)precvpriv->dbg_rx_ampdu_window_shift_cnt);
/*The same mac addr counts*/
RTW_PRINT_SEL(m, "Rx: Conflict MAC Address Frames Count: %llu\n", (unsigned long long)precvpriv->dbg_rx_conflic_mac_addr_cnt);
return 0;
}
int proc_get_rate_ctl(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
u8 data_rate = 0, sgi = 0, data_fb = 0;
if (adapter->fix_rate != 0xff) {
data_rate = adapter->fix_rate & 0x7F;
sgi = adapter->fix_rate >> 7;
data_fb = adapter->data_fb ? 1 : 0;
RTW_PRINT_SEL(m, "FIXED %s%s%s\n"
, HDATA_RATE(data_rate)
, data_rate > DESC_RATE54M ? (sgi ? " SGI" : " LGI") : ""
, data_fb ? " FB" : ""
);
RTW_PRINT_SEL(m, "0x%02x %u\n", adapter->fix_rate, adapter->data_fb);
} else
RTW_PRINT_SEL(m, "RA\n");
return 0;
}
#ifdef CONFIG_PHDYM_FW_FIXRATE
void phydm_fw_fix_rate(void *dm_void, u8 en, u8 macid, u8 bw, u8 rate);
#endif
ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
char tmp[32];
u8 fix_rate = 0xFF;
#ifdef CONFIG_PHDYM_FW_FIXRATE
u8 bw = 0;
#else
u8 data_fb = 0;
#endif
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
#ifdef CONFIG_PHDYM_FW_FIXRATE
struct dm_struct *dm = adapter_to_phydm(adapter);
u8 en = 1, macid = 255;
_irqL irqL;
_list *plist, *phead;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &(adapter->stapriv);
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
uint mac_id[NUM_STA];
int i, macid_rec_idx = 0;
int num = sscanf(tmp, "%hhx %hhu %hhu", &fix_rate, &bw, &macid);
if (num < 1) {
RTW_INFO("Invalid input!! \"ex: echo > /proc/.../rate_ctl\"\n");
return count;
}
if ((fix_rate == 0) || (fix_rate == 0xFF))
en = 0;
if (macid != 255) {
RTW_INFO("Call phydm_fw_fix_rate()--en[%d] mac_id[%d] bw[%d] fix_rate[%d]\n", en, macid, bw, fix_rate);
phydm_fw_fix_rate(dm, en, macid, bw, fix_rate);
return count;
}
/* no specific macid, apply to all macids except bc/mc macid */
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(adapter), ETH_ALEN) != _TRUE)) {
mac_id[macid_rec_idx] = psta->cmn.mac_id;
macid_rec_idx++;
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < macid_rec_idx; i++) {
RTW_INFO("Call phydm_fw_fix_rate()--en[%d] mac_id[%d] bw[%d] fix_rate[%d]\n", en, mac_id[i], bw, fix_rate);
phydm_fw_fix_rate(dm, en, mac_id[i], bw, fix_rate);
}
#else
int num = sscanf(tmp, "%hhx %hhu", &fix_rate, &data_fb);
if (num >= 1) {
u8 fix_rate_ori = adapter->fix_rate;
adapter->fix_rate = fix_rate;
if (fix_rate == 0xFF)
hal_data->ForcedDataRate = 0;
else
hal_data->ForcedDataRate = hw_rate_to_m_rate(fix_rate & 0x7F);
if (adapter->fix_bw != 0xFF && fix_rate_ori != fix_rate)
rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
}
if (num >= 2)
adapter->data_fb = data_fb ? 1 : 0;
#endif
}
return count;
}
#ifdef CONFIG_AP_MODE
int proc_get_bmc_tx_rate(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
if (!MLME_IS_AP(adapter) && !MLME_IS_MESH(adapter)) {
RTW_PRINT_SEL(m, "[ERROR] Not in SoftAP/Mesh mode !!\n");
return 0;
}
RTW_PRINT_SEL(m, " BMC Tx rate - %s\n", MGN_RATE_STR(adapter->bmc_tx_rate));
return 0;
}
ssize_t proc_set_bmc_tx_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 bmc_tx_rate;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx", &bmc_tx_rate);
if (num >= 1)
/*adapter->bmc_tx_rate = hw_rate_to_m_rate(bmc_tx_rate);*/
adapter->bmc_tx_rate = bmc_tx_rate;
}
return count;
}
#endif /*CONFIG_AP_MODE*/
int proc_get_tx_power_offset(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "Tx power offset - %u\n", adapter->power_offset);
return 0;
}
ssize_t proc_set_tx_power_offset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 power_offset = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhu", &power_offset);
if (num >= 1) {
if (power_offset > 5)
power_offset = 0;
adapter->power_offset = power_offset;
}
}
return count;
}
int proc_get_bw_ctl(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
u8 data_bw = 0;
if (adapter->fix_bw != 0xff) {
data_bw = adapter->fix_bw;
RTW_PRINT_SEL(m, "FIXED %s\n", ch_width_str(data_bw));
} else
RTW_PRINT_SEL(m, "Auto\n");
return 0;
}
ssize_t proc_set_bw_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 fix_bw;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhu", &fix_bw);
if (num >= 1) {
u8 fix_bw_ori = adapter->fix_bw;
adapter->fix_bw = fix_bw;
if (adapter->fix_rate != 0xFF && fix_bw_ori != fix_bw)
rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
}
}
return count;
}
#ifdef DBG_RX_COUNTER_DUMP
int proc_get_rx_cnt_dump(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
int i;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "BIT0- Dump RX counters of DRV\n");
RTW_PRINT_SEL(m, "BIT1- Dump RX counters of MAC\n");
RTW_PRINT_SEL(m, "BIT2- Dump RX counters of PHY\n");
RTW_PRINT_SEL(m, "BIT3- Dump TRX data frame of DRV\n");
RTW_PRINT_SEL(m, "dump_rx_cnt_mode = 0x%02x\n", adapter->dump_rx_cnt_mode);
return 0;
}
ssize_t proc_set_rx_cnt_dump(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 dump_rx_cnt_mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx", &dump_rx_cnt_mode);
if (num == 1) {
rtw_dump_phy_rxcnts_preprocess(adapter, dump_rx_cnt_mode);
adapter->dump_rx_cnt_mode = dump_rx_cnt_mode;
}
}
return count;
}
#endif
ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count))
sscanf(tmp, "%hhu %hhu", &fwdl_test_chksum_fail, &fwdl_test_wintint_rdy_fail);
return count;
}
ssize_t proc_set_del_rx_ampdu_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count))
sscanf(tmp, "%hhu", &del_rx_ampdu_test_no_tx_fail);
return count;
}
ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count))
sscanf(tmp, "%u", &g_wait_hiq_empty_ms);
return count;
}
ssize_t proc_set_sta_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
u32 wait_ms = 0;
u8 force_fail = 0;
int num = sscanf(tmp, "%u %hhu", &wait_ms, &force_fail);
if (num >= 1)
sta_linking_test_wait_ms = wait_ms;
if (num >= 2)
sta_linking_test_force_fail = force_fail;
}
return count;
}
#ifdef CONFIG_AP_MODE
ssize_t proc_set_ap_linking_test(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
u16 force_auth_fail = 0;
u16 force_asoc_fail = 0;
int num = sscanf(tmp, "%hu %hu", &force_auth_fail, &force_asoc_fail);
if (num >= 1)
ap_linking_test_force_auth_fail = force_auth_fail;
if (num >= 2)
ap_linking_test_force_asoc_fail = force_asoc_fail;
}
return count;
}
#endif /* CONFIG_AP_MODE */
int proc_get_ps_dbg_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *dvobj = padapter->dvobj;
struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
RTW_PRINT_SEL(m, "dbg_sdio_alloc_irq_cnt=%d\n", pdbgpriv->dbg_sdio_alloc_irq_cnt);
RTW_PRINT_SEL(m, "dbg_sdio_free_irq_cnt=%d\n", pdbgpriv->dbg_sdio_free_irq_cnt);
RTW_PRINT_SEL(m, "dbg_sdio_alloc_irq_error_cnt=%d\n", pdbgpriv->dbg_sdio_alloc_irq_error_cnt);
RTW_PRINT_SEL(m, "dbg_sdio_free_irq_error_cnt=%d\n", pdbgpriv->dbg_sdio_free_irq_error_cnt);
RTW_PRINT_SEL(m, "dbg_sdio_init_error_cnt=%d\n", pdbgpriv->dbg_sdio_init_error_cnt);
RTW_PRINT_SEL(m, "dbg_sdio_deinit_error_cnt=%d\n", pdbgpriv->dbg_sdio_deinit_error_cnt);
RTW_PRINT_SEL(m, "dbg_suspend_error_cnt=%d\n", pdbgpriv->dbg_suspend_error_cnt);
RTW_PRINT_SEL(m, "dbg_suspend_cnt=%d\n", pdbgpriv->dbg_suspend_cnt);
RTW_PRINT_SEL(m, "dbg_resume_cnt=%d\n", pdbgpriv->dbg_resume_cnt);
RTW_PRINT_SEL(m, "dbg_resume_error_cnt=%d\n", pdbgpriv->dbg_resume_error_cnt);
RTW_PRINT_SEL(m, "dbg_deinit_fail_cnt=%d\n", pdbgpriv->dbg_deinit_fail_cnt);
RTW_PRINT_SEL(m, "dbg_carddisable_cnt=%d\n", pdbgpriv->dbg_carddisable_cnt);
RTW_PRINT_SEL(m, "dbg_ps_insuspend_cnt=%d\n", pdbgpriv->dbg_ps_insuspend_cnt);
RTW_PRINT_SEL(m, "dbg_dev_unload_inIPS_cnt=%d\n", pdbgpriv->dbg_dev_unload_inIPS_cnt);
RTW_PRINT_SEL(m, "dbg_scan_pwr_state_cnt=%d\n", pdbgpriv->dbg_scan_pwr_state_cnt);
RTW_PRINT_SEL(m, "dbg_downloadfw_pwr_state_cnt=%d\n", pdbgpriv->dbg_downloadfw_pwr_state_cnt);
RTW_PRINT_SEL(m, "dbg_carddisable_error_cnt=%d\n", pdbgpriv->dbg_carddisable_error_cnt);
RTW_PRINT_SEL(m, "dbg_fw_read_ps_state_fail_cnt=%d\n", pdbgpriv->dbg_fw_read_ps_state_fail_cnt);
RTW_PRINT_SEL(m, "dbg_leave_ips_fail_cnt=%d\n", pdbgpriv->dbg_leave_ips_fail_cnt);
RTW_PRINT_SEL(m, "dbg_leave_lps_fail_cnt=%d\n", pdbgpriv->dbg_leave_lps_fail_cnt);
RTW_PRINT_SEL(m, "dbg_h2c_leave32k_fail_cnt=%d\n", pdbgpriv->dbg_h2c_leave32k_fail_cnt);
RTW_PRINT_SEL(m, "dbg_diswow_dload_fw_fail_cnt=%d\n", pdbgpriv->dbg_diswow_dload_fw_fail_cnt);
RTW_PRINT_SEL(m, "dbg_enwow_dload_fw_fail_cnt=%d\n", pdbgpriv->dbg_enwow_dload_fw_fail_cnt);
RTW_PRINT_SEL(m, "dbg_ips_drvopen_fail_cnt=%d\n", pdbgpriv->dbg_ips_drvopen_fail_cnt);
RTW_PRINT_SEL(m, "dbg_poll_fail_cnt=%d\n", pdbgpriv->dbg_poll_fail_cnt);
RTW_PRINT_SEL(m, "dbg_rpwm_toogle_cnt=%d\n", pdbgpriv->dbg_rpwm_toogle_cnt);
RTW_PRINT_SEL(m, "dbg_rpwm_timeout_fail_cnt=%d\n", pdbgpriv->dbg_rpwm_timeout_fail_cnt);
RTW_PRINT_SEL(m, "dbg_sreset_cnt=%d\n", pdbgpriv->dbg_sreset_cnt);
RTW_PRINT_SEL(m, "dbg_fw_mem_dl_error_cnt=%d\n", pdbgpriv->dbg_fw_mem_dl_error_cnt);
return 0;
}
ssize_t proc_set_ps_dbg_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *dvobj = adapter->dvobj;
struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
char tmp[32];
u8 ps_dbg_cmd_id;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx", &ps_dbg_cmd_id);
if (num == 1 && ps_dbg_cmd_id == 1) /*Clean all*/
_rtw_memset(pdbgpriv, 0, sizeof(struct debug_priv));
}
return count;
}
#ifdef CONFIG_DBG_COUNTER
int proc_get_rx_logs(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct rx_logs *rx_logs = &padapter->rx_logs;
RTW_PRINT_SEL(m,
"intf_rx=%d\n"
"intf_rx_err_recvframe=%d\n"
"intf_rx_err_skb=%d\n"
"intf_rx_report=%d\n"
"core_rx=%d\n"
"core_rx_pre=%d\n"
"core_rx_pre_ver_err=%d\n"
"core_rx_pre_mgmt=%d\n"
"core_rx_pre_mgmt_err_80211w=%d\n"
"core_rx_pre_mgmt_err=%d\n"
"core_rx_pre_ctrl=%d\n"
"core_rx_pre_ctrl_err=%d\n"
"core_rx_pre_data=%d\n"
"core_rx_pre_data_wapi_seq_err=%d\n"
"core_rx_pre_data_wapi_key_err=%d\n"
"core_rx_pre_data_handled=%d\n"
"core_rx_pre_data_err=%d\n"
"core_rx_pre_data_unknown=%d\n"
"core_rx_pre_unknown=%d\n"
"core_rx_enqueue=%d\n"
"core_rx_dequeue=%d\n"
"core_rx_post=%d\n"
"core_rx_post_decrypt=%d\n"
"core_rx_post_decrypt_wep=%d\n"
"core_rx_post_decrypt_tkip=%d\n"
"core_rx_post_decrypt_aes=%d\n"
"core_rx_post_decrypt_wapi=%d\n"
"core_rx_post_decrypt_hw=%d\n"
"core_rx_post_decrypt_unknown=%d\n"
"core_rx_post_decrypt_err=%d\n"
"core_rx_post_defrag_err=%d\n"
"core_rx_post_portctrl_err=%d\n"
"core_rx_post_indicate=%d\n"
"core_rx_post_indicate_in_oder=%d\n"
"core_rx_post_indicate_reoder=%d\n"
"core_rx_post_indicate_err=%d\n"
"os_indicate=%d\n"
"os_indicate_ap_mcast=%d\n"
"os_indicate_ap_forward=%d\n"
"os_indicate_ap_self=%d\n"
"os_indicate_err=%d\n"
"os_netif_ok=%d\n"
"os_netif_err=%d\n",
rx_logs->intf_rx,
rx_logs->intf_rx_err_recvframe,
rx_logs->intf_rx_err_skb,
rx_logs->intf_rx_report,
rx_logs->core_rx,
rx_logs->core_rx_pre,
rx_logs->core_rx_pre_ver_err,
rx_logs->core_rx_pre_mgmt,
rx_logs->core_rx_pre_mgmt_err_80211w,
rx_logs->core_rx_pre_mgmt_err,
rx_logs->core_rx_pre_ctrl,
rx_logs->core_rx_pre_ctrl_err,
rx_logs->core_rx_pre_data,
rx_logs->core_rx_pre_data_wapi_seq_err,
rx_logs->core_rx_pre_data_wapi_key_err,
rx_logs->core_rx_pre_data_handled,
rx_logs->core_rx_pre_data_err,
rx_logs->core_rx_pre_data_unknown,
rx_logs->core_rx_pre_unknown,
rx_logs->core_rx_enqueue,
rx_logs->core_rx_dequeue,
rx_logs->core_rx_post,
rx_logs->core_rx_post_decrypt,
rx_logs->core_rx_post_decrypt_wep,
rx_logs->core_rx_post_decrypt_tkip,
rx_logs->core_rx_post_decrypt_aes,
rx_logs->core_rx_post_decrypt_wapi,
rx_logs->core_rx_post_decrypt_hw,
rx_logs->core_rx_post_decrypt_unknown,
rx_logs->core_rx_post_decrypt_err,
rx_logs->core_rx_post_defrag_err,
rx_logs->core_rx_post_portctrl_err,
rx_logs->core_rx_post_indicate,
rx_logs->core_rx_post_indicate_in_oder,
rx_logs->core_rx_post_indicate_reoder,
rx_logs->core_rx_post_indicate_err,
rx_logs->os_indicate,
rx_logs->os_indicate_ap_mcast,
rx_logs->os_indicate_ap_forward,
rx_logs->os_indicate_ap_self,
rx_logs->os_indicate_err,
rx_logs->os_netif_ok,
rx_logs->os_netif_err
);
return 0;
}
int proc_get_tx_logs(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct tx_logs *tx_logs = &padapter->tx_logs;
RTW_PRINT_SEL(m,
"os_tx=%d\n"
"os_tx_err_up=%d\n"
"os_tx_err_xmit=%d\n"
"os_tx_m2u=%d\n"
"os_tx_m2u_ignore_fw_linked=%d\n"
"os_tx_m2u_ignore_self=%d\n"
"os_tx_m2u_entry=%d\n"
"os_tx_m2u_entry_err_xmit=%d\n"
"os_tx_m2u_entry_err_skb=%d\n"
"os_tx_m2u_stop=%d\n"
"core_tx=%d\n"
"core_tx_err_pxmitframe=%d\n"
"core_tx_err_brtx=%d\n"
"core_tx_upd_attrib=%d\n"
"core_tx_upd_attrib_adhoc=%d\n"
"core_tx_upd_attrib_sta=%d\n"
"core_tx_upd_attrib_ap=%d\n"
"core_tx_upd_attrib_unknown=%d\n"
"core_tx_upd_attrib_dhcp=%d\n"
"core_tx_upd_attrib_icmp=%d\n"
"core_tx_upd_attrib_active=%d\n"
"core_tx_upd_attrib_err_ucast_sta=%d\n"
"core_tx_upd_attrib_err_ucast_ap_link=%d\n"
"core_tx_upd_attrib_err_sta=%d\n"
"core_tx_upd_attrib_err_link=%d\n"
"core_tx_upd_attrib_err_sec=%d\n"
"core_tx_ap_enqueue_warn_fwstate=%d\n"
"core_tx_ap_enqueue_warn_sta=%d\n"
"core_tx_ap_enqueue_warn_nosta=%d\n"
"core_tx_ap_enqueue_warn_link=%d\n"
"core_tx_ap_enqueue_warn_trigger=%d\n"
"core_tx_ap_enqueue_mcast=%d\n"
"core_tx_ap_enqueue_ucast=%d\n"
"core_tx_ap_enqueue=%d\n"
"intf_tx=%d\n"
"intf_tx_pending_ac=%d\n"
"intf_tx_pending_fw_under_survey=%d\n"
"intf_tx_pending_fw_under_linking=%d\n"
"intf_tx_pending_xmitbuf=%d\n"
"intf_tx_enqueue=%d\n"
"core_tx_enqueue=%d\n"
"core_tx_enqueue_class=%d\n"
"core_tx_enqueue_class_err_sta=%d\n"
"core_tx_enqueue_class_err_nosta=%d\n"
"core_tx_enqueue_class_err_fwlink=%d\n"
"intf_tx_direct=%d\n"
"intf_tx_direct_err_coalesce=%d\n"
"intf_tx_dequeue=%d\n"
"intf_tx_dequeue_err_coalesce=%d\n"
"intf_tx_dump_xframe=%d\n"
"intf_tx_dump_xframe_err_txdesc=%d\n"
"intf_tx_dump_xframe_err_port=%d\n",
tx_logs->os_tx,
tx_logs->os_tx_err_up,
tx_logs->os_tx_err_xmit,
tx_logs->os_tx_m2u,
tx_logs->os_tx_m2u_ignore_fw_linked,
tx_logs->os_tx_m2u_ignore_self,
tx_logs->os_tx_m2u_entry,
tx_logs->os_tx_m2u_entry_err_xmit,
tx_logs->os_tx_m2u_entry_err_skb,
tx_logs->os_tx_m2u_stop,
tx_logs->core_tx,
tx_logs->core_tx_err_pxmitframe,
tx_logs->core_tx_err_brtx,
tx_logs->core_tx_upd_attrib,
tx_logs->core_tx_upd_attrib_adhoc,
tx_logs->core_tx_upd_attrib_sta,
tx_logs->core_tx_upd_attrib_ap,
tx_logs->core_tx_upd_attrib_unknown,
tx_logs->core_tx_upd_attrib_dhcp,
tx_logs->core_tx_upd_attrib_icmp,
tx_logs->core_tx_upd_attrib_active,
tx_logs->core_tx_upd_attrib_err_ucast_sta,
tx_logs->core_tx_upd_attrib_err_ucast_ap_link,
tx_logs->core_tx_upd_attrib_err_sta,
tx_logs->core_tx_upd_attrib_err_link,
tx_logs->core_tx_upd_attrib_err_sec,
tx_logs->core_tx_ap_enqueue_warn_fwstate,
tx_logs->core_tx_ap_enqueue_warn_sta,
tx_logs->core_tx_ap_enqueue_warn_nosta,
tx_logs->core_tx_ap_enqueue_warn_link,
tx_logs->core_tx_ap_enqueue_warn_trigger,
tx_logs->core_tx_ap_enqueue_mcast,
tx_logs->core_tx_ap_enqueue_ucast,
tx_logs->core_tx_ap_enqueue,
tx_logs->intf_tx,
tx_logs->intf_tx_pending_ac,
tx_logs->intf_tx_pending_fw_under_survey,
tx_logs->intf_tx_pending_fw_under_linking,
tx_logs->intf_tx_pending_xmitbuf,
tx_logs->intf_tx_enqueue,
tx_logs->core_tx_enqueue,
tx_logs->core_tx_enqueue_class,
tx_logs->core_tx_enqueue_class_err_sta,
tx_logs->core_tx_enqueue_class_err_nosta,
tx_logs->core_tx_enqueue_class_err_fwlink,
tx_logs->intf_tx_direct,
tx_logs->intf_tx_direct_err_coalesce,
tx_logs->intf_tx_dequeue,
tx_logs->intf_tx_dequeue_err_coalesce,
tx_logs->intf_tx_dump_xframe,
tx_logs->intf_tx_dump_xframe_err_txdesc,
tx_logs->intf_tx_dump_xframe_err_port
);
return 0;
}
int proc_get_int_logs(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m,
"all=%d\n"
"err=%d\n"
"tbdok=%d\n"
"tbder=%d\n"
"bcnderr=%d\n"
"bcndma=%d\n"
"bcndma_e=%d\n"
"rx=%d\n"
"rx_rdu=%d\n"
"rx_fovw=%d\n"
"txfovw=%d\n"
"mgntok=%d\n"
"highdok=%d\n"
"bkdok=%d\n"
"bedok=%d\n"
"vidok=%d\n"
"vodok=%d\n",
padapter->int_logs.all,
padapter->int_logs.err,
padapter->int_logs.tbdok,
padapter->int_logs.tbder,
padapter->int_logs.bcnderr,
padapter->int_logs.bcndma,
padapter->int_logs.bcndma_e,
padapter->int_logs.rx,
padapter->int_logs.rx_rdu,
padapter->int_logs.rx_fovw,
padapter->int_logs.txfovw,
padapter->int_logs.mgntok,
padapter->int_logs.highdok,
padapter->int_logs.bkdok,
padapter->int_logs.bedok,
padapter->int_logs.vidok,
padapter->int_logs.vodok
);
return 0;
}
#endif /* CONFIG_DBG_COUNTER */
int proc_get_hw_status(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *dvobj = padapter->dvobj;
struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
struct registry_priv *regsty = dvobj_to_regsty(dvobj);
if (regsty->check_hw_status == 0)
RTW_PRINT_SEL(m, "RX FIFO full count: not check in watch dog\n");
else if (pdbgpriv->dbg_rx_fifo_last_overflow == 1
&& pdbgpriv->dbg_rx_fifo_curr_overflow == 1
&& pdbgpriv->dbg_rx_fifo_diff_overflow == 1
)
RTW_PRINT_SEL(m, "RX FIFO full count: no implementation\n");
else {
RTW_PRINT_SEL(m, "RX FIFO full count: last_time=%llu, current_time=%llu, differential=%llu\n"
, pdbgpriv->dbg_rx_fifo_last_overflow, pdbgpriv->dbg_rx_fifo_curr_overflow, pdbgpriv->dbg_rx_fifo_diff_overflow);
}
return 0;
}
ssize_t proc_set_hw_status(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *dvobj = padapter->dvobj;
struct registry_priv *regsty = dvobj_to_regsty(dvobj);
char tmp[32];
u32 enable;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &enable);
if (num == 1 && regsty && enable <= 1) {
regsty->check_hw_status = enable;
RTW_INFO("check_hw_status=%d\n", regsty->check_hw_status);
}
}
return count;
}
#ifdef CONFIG_HUAWEI_PROC
int proc_get_huawei_trx_info(struct seq_file *sel, void *v)
{
struct net_device *dev = sel->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dm_struct *dm = adapter_to_phydm(padapter);
struct sta_info *psta;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct ra_sta_info *ra_info;
u8 curr_tx_sgi = _FALSE;
u8 curr_tx_rate = 0;
u8 mac_id;
#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
u8 isCCKrate, rf_path;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
#endif
if (!dm->is_linked) {
RTW_PRINT_SEL(sel, "NO link\n\n");
return 0;
}
/*============ tx info ============ */
for (mac_id = 0; mac_id < macid_ctl->num; mac_id++) {
if (rtw_macid_is_used(macid_ctl, mac_id) && !rtw_macid_is_bmc(macid_ctl, mac_id)) {
psta = macid_ctl->sta[mac_id];
if (!psta)
continue;
RTW_PRINT_SEL(sel, "STA [" MAC_FMT "]\n", MAC_ARG(psta->cmn.mac_addr));
ra_info = &psta->cmn.ra_info;
curr_tx_sgi = rtw_get_current_tx_sgi(padapter, psta);
curr_tx_rate = rtw_get_current_tx_rate(padapter, psta);
RTW_PRINT_SEL(sel, "curr_tx_rate : %s (%s)\n",
HDATA_RATE(curr_tx_rate), (curr_tx_sgi) ? "S" : "L");
RTW_PRINT_SEL(sel, "curr_tx_bw : %s\n", ch_width_str(ra_info->curr_tx_bw));
}
}
/*============ rx info ============ */
RTW_PRINT_SEL(sel, "rx_rate : %s\n", HDATA_RATE(dm->rx_rate));
#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
if (!isCCKrate)
_RTW_PRINT_SEL(sel , "RF_PATH_%d : rx_ofdm_pwr:%d(dBm), rx_ofdm_snr:%d(dB)\n",
rf_path, psample_pkt_rssi->ofdm_pwr[rf_path], psample_pkt_rssi->ofdm_snr[rf_path]);
}
#endif
RTW_PRINT_SEL(sel, "\n");
return 0;
}
#endif /* CONFIG_HUAWEI_PROC */
int proc_get_trx_info_debug(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
/*============ tx info ============ */
rtw_hal_get_def_var(padapter, HW_DEF_RA_INFO_DUMP, m);
/*============ rx info ============ */
rtw_hal_set_odm_var(padapter, HAL_ODM_RX_INFO_DUMP, m, _FALSE);
return 0;
}
int proc_get_rx_signal(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "rssi:%d\n", padapter->recvpriv.rssi);
#ifdef CONFIG_MP_INCLUDED
if (padapter->registrypriv.mp_mode == 1) {
struct dm_struct *odm = adapter_to_phydm(padapter);
if (padapter->mppriv.antenna_rx == ANTENNA_A)
RTW_PRINT_SEL(m, "Antenna: A\n");
else if (padapter->mppriv.antenna_rx == ANTENNA_B)
RTW_PRINT_SEL(m, "Antenna: B\n");
else if (padapter->mppriv.antenna_rx == ANTENNA_C)
RTW_PRINT_SEL(m, "Antenna: C\n");
else if (padapter->mppriv.antenna_rx == ANTENNA_D)
RTW_PRINT_SEL(m, "Antenna: D\n");
else if (padapter->mppriv.antenna_rx == ANTENNA_AB)
RTW_PRINT_SEL(m, "Antenna: AB\n");
else if (padapter->mppriv.antenna_rx == ANTENNA_BC)
RTW_PRINT_SEL(m, "Antenna: BC\n");
else if (padapter->mppriv.antenna_rx == ANTENNA_CD)
RTW_PRINT_SEL(m, "Antenna: CD\n");
else
RTW_PRINT_SEL(m, "Antenna: __\n");
RTW_PRINT_SEL(m, "rx_rate = %s\n", HDATA_RATE(odm->rx_rate));
return 0;
} else
#endif
{
/* RTW_PRINT_SEL(m, "rxpwdb:%d\n", padapter->recvpriv.rxpwdb); */
RTW_PRINT_SEL(m, "signal_strength:%u\n", padapter->recvpriv.signal_strength);
RTW_PRINT_SEL(m, "signal_qual:%u\n", padapter->recvpriv.signal_qual);
}
#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
rtw_odm_get_perpkt_rssi(m, padapter);
rtw_get_raw_rssi_info(m, padapter);
#endif
return 0;
}
ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 is_signal_dbg, signal_strength;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u", &is_signal_dbg, &signal_strength);
if (num < 1)
return count;
is_signal_dbg = is_signal_dbg == 0 ? 0 : 1;
if (is_signal_dbg && num < 2)
return count;
signal_strength = signal_strength > 100 ? 100 : signal_strength;
padapter->recvpriv.is_signal_dbg = is_signal_dbg;
padapter->recvpriv.signal_strength_dbg = signal_strength;
if (is_signal_dbg)
RTW_INFO("set %s %u\n", "DBG_SIGNAL_STRENGTH", signal_strength);
else
RTW_INFO("set %s\n", "HW_SIGNAL_STRENGTH");
}
return count;
}
int proc_get_mac_rptbuf(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
u16 i;
u16 mac_id;
u32 shcut_addr = 0;
u32 read_addr = 0;
#ifdef CONFIG_RTL8814A
RTW_PRINT_SEL(m, "TX ShortCut:\n");
for (mac_id = 0; mac_id < 64; mac_id++) {
rtw_write16(padapter, 0x140, 0x662 | ((mac_id & BIT5) >> 5));
shcut_addr = 0x8000;
shcut_addr = shcut_addr | ((mac_id & 0x1f) << 7);
RTW_PRINT_SEL(m, "mac_id=%d, 0x140=%x =>\n", mac_id, 0x662 | ((mac_id & BIT5) >> 5));
for (i = 0; i < 30; i++) {
read_addr = 0;
read_addr = shcut_addr | (i << 2);
RTW_PRINT_SEL(m, "i=%02d: MAC_%04x= %08x ", i, read_addr, rtw_read32(padapter, read_addr));
if (!((i + 1) % 4))
RTW_PRINT_SEL(m, "\n");
if (i == 29)
RTW_PRINT_SEL(m, "\n");
}
}
#endif /* CONFIG_RTL8814A */
return 0;
}
#ifdef CONFIG_80211N_HT
int proc_get_ht_enable(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "%d\n", pregpriv->ht_enable);
return 0;
}
ssize_t proc_set_ht_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if ( num == 1 && pregpriv && mode < 2) {
pregpriv->ht_enable = mode;
RTW_INFO("ht_enable=%d\n", pregpriv->ht_enable);
}
}
return count;
}
int proc_get_bw_mode(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->bw_mode);
return 0;
}
ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
u8 bw_2g;
u8 bw_5g;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%x ", &mode);
bw_5g = mode >> 4;
bw_2g = mode & 0x0f;
if (num == 1 && pregpriv && bw_2g <= 4 && bw_5g <= 4) {
pregpriv->bw_mode = mode;
printk("bw_mode=0x%x\n", mode);
}
}
return count;
}
int proc_get_ampdu_enable(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "%d\n", pregpriv->ampdu_enable);
return 0;
}
ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if (num == 1 && pregpriv && mode < 2) {
pregpriv->ampdu_enable = mode;
printk("ampdu_enable=%d\n", mode);
}
}
return count;
}
void dump_regsty_rx_ampdu_size_limit(void *sel, _adapter *adapter)
{
struct registry_priv *regsty = adapter_to_regsty(adapter);
int i;
RTW_PRINT_SEL(sel, "%-3s %-3s %-3s %-3s %-4s\n"
, "", "20M", "40M", "80M", "160M");
for (i = 0; i < 4; i++)
RTW_PRINT_SEL(sel, "%dSS %3u %3u %3u %4u\n", i + 1
, regsty->rx_ampdu_sz_limit_by_nss_bw[i][0]
, regsty->rx_ampdu_sz_limit_by_nss_bw[i][1]
, regsty->rx_ampdu_sz_limit_by_nss_bw[i][2]
, regsty->rx_ampdu_sz_limit_by_nss_bw[i][3]);
}
int proc_get_rx_ampdu(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
_RTW_PRINT_SEL(m, "accept: ");
if (padapter->fix_rx_ampdu_accept == RX_AMPDU_ACCEPT_INVALID)
RTW_PRINT_SEL(m, "%u%s\n", rtw_rx_ampdu_is_accept(padapter), "(auto)");
else
RTW_PRINT_SEL(m, "%u%s\n", padapter->fix_rx_ampdu_accept, "(fixed)");
_RTW_PRINT_SEL(m, "size: ");
if (padapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID) {
RTW_PRINT_SEL(m, "%u%s\n", rtw_rx_ampdu_size(padapter), "(auto) with conditional limit:");
dump_regsty_rx_ampdu_size_limit(m, padapter);
} else
RTW_PRINT_SEL(m, "%u%s\n", padapter->fix_rx_ampdu_size, "(fixed)");
RTW_PRINT_SEL(m, "\n");
RTW_PRINT_SEL(m, "%19s %17s\n", "fix_rx_ampdu_accept", "fix_rx_ampdu_size");
_RTW_PRINT_SEL(m, "%-19d %-17u\n"
, padapter->fix_rx_ampdu_accept
, padapter->fix_rx_ampdu_size);
return 0;
}
ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 accept;
u8 size;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhu %hhu", &accept, &size);
if (num >= 1)
rtw_rx_ampdu_set_accept(padapter, accept, RX_AMPDU_DRV_FIXED);
if (num >= 2)
rtw_rx_ampdu_set_size(padapter, size, RX_AMPDU_DRV_FIXED);
rtw_rx_ampdu_apply(padapter);
}
return count;
}
int proc_get_rx_ampdu_factor(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if (padapter)
RTW_PRINT_SEL(m, "rx ampdu factor = %x\n", padapter->driver_rx_ampdu_factor);
return 0;
}
ssize_t proc_set_rx_ampdu_factor(struct file *file, const char __user *buffer
, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 factor;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &factor);
if (padapter && (num == 1)) {
RTW_INFO("padapter->driver_rx_ampdu_factor = %x\n", factor);
if (factor > 0x03)
padapter->driver_rx_ampdu_factor = 0xFF;
else
padapter->driver_rx_ampdu_factor = factor;
}
}
return count;
}
int proc_get_tx_max_agg_num(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if (padapter)
RTW_PRINT_SEL(m, "tx max AMPDU num = 0x%02x\n", padapter->driver_tx_max_agg_num);
return 0;
}
ssize_t proc_set_tx_max_agg_num(struct file *file, const char __user *buffer
, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 agg_num;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx ", &agg_num);
if (padapter && (num == 1)) {
RTW_INFO("padapter->driver_tx_max_agg_num = 0x%02x\n", agg_num);
padapter->driver_tx_max_agg_num = agg_num;
}
}
return count;
}
int proc_get_rx_ampdu_density(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if (padapter)
RTW_PRINT_SEL(m, "rx ampdu densityg = %x\n", padapter->driver_rx_ampdu_spacing);
return 0;
}
ssize_t proc_set_rx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 density;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &density);
if (padapter && (num == 1)) {
RTW_INFO("padapter->driver_rx_ampdu_spacing = %x\n", density);
if (density > 0x07)
padapter->driver_rx_ampdu_spacing = 0xFF;
else
padapter->driver_rx_ampdu_spacing = density;
}
}
return count;
}
int proc_get_tx_ampdu_density(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if (padapter)
RTW_PRINT_SEL(m, "tx ampdu density = %x\n", padapter->driver_ampdu_spacing);
return 0;
}
ssize_t proc_set_tx_ampdu_density(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 density;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &density);
if (padapter && (num == 1)) {
RTW_INFO("padapter->driver_ampdu_spacing = %x\n", density);
if (density > 0x07)
padapter->driver_ampdu_spacing = 0xFF;
else
padapter->driver_ampdu_spacing = density;
}
}
return count;
}
int proc_get_tx_quick_addba_req(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (padapter)
RTW_PRINT_SEL(m, "tx_quick_addba_req = %x\n", pregpriv->tx_quick_addba_req);
return 0;
}
ssize_t proc_set_tx_quick_addba_req(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 enable;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &enable);
if (padapter && (num == 1)) {
pregpriv->tx_quick_addba_req = enable;
RTW_INFO("tx_quick_addba_req = %d\n", pregpriv->tx_quick_addba_req);
}
}
return count;
}
#ifdef CONFIG_TX_AMSDU
int proc_get_tx_amsdu(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
if (padapter)
{
RTW_PRINT_SEL(m, "tx amsdu = %d\n", padapter->tx_amsdu);
RTW_PRINT_SEL(m, "amsdu set timer conut = %u\n", pxmitpriv->amsdu_debug_set_timer);
RTW_PRINT_SEL(m, "amsdu time out count = %u\n", pxmitpriv->amsdu_debug_timeout);
RTW_PRINT_SEL(m, "amsdu coalesce one count = %u\n", pxmitpriv->amsdu_debug_coalesce_one);
RTW_PRINT_SEL(m, "amsdu coalesce two count = %u\n", pxmitpriv->amsdu_debug_coalesce_two);
}
return 0;
}
ssize_t proc_set_tx_amsdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
char tmp[32];
u32 amsdu;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &amsdu);
if (padapter && (num == 1)) {
RTW_INFO("padapter->tx_amsdu = %x\n", amsdu);
if (amsdu > 3)
padapter->tx_amsdu = 0;
else if(amsdu == 3)
{
pxmitpriv->amsdu_debug_set_timer = 0;
pxmitpriv->amsdu_debug_timeout = 0;
pxmitpriv->amsdu_debug_coalesce_one = 0;
pxmitpriv->amsdu_debug_coalesce_two = 0;
}
else
padapter->tx_amsdu = amsdu;
}
}
return count;
}
int proc_get_tx_amsdu_rate(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if (padapter)
RTW_PRINT_SEL(m, "tx amsdu rate = %d Mbps\n", padapter->tx_amsdu_rate);
return 0;
}
ssize_t proc_set_tx_amsdu_rate(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 amsdu_rate;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &amsdu_rate);
if (padapter && (num == 1)) {
RTW_INFO("padapter->tx_amsdu_rate = %x\n", amsdu_rate);
padapter->tx_amsdu_rate = amsdu_rate;
}
}
return count;
}
#endif /* CONFIG_TX_AMSDU */
#endif /* CONFIG_80211N_HT */
int proc_get_en_fwps(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "check_fw_ps = %d , 1:enable get FW PS state , 0: disable get FW PS state\n"
, pregpriv->check_fw_ps);
return 0;
}
ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if (num == 1 && pregpriv && mode < 2) {
pregpriv->check_fw_ps = mode;
RTW_INFO("pregpriv->check_fw_ps=%d\n", pregpriv->check_fw_ps);
}
}
return count;
}
/*
int proc_get_two_path_rssi(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
if(padapter)
RTW_PRINT_SEL(m, "%d %d\n",
padapter->recvpriv.RxRssi[0], padapter->recvpriv.RxRssi[1]);
return 0;
}
*/
#ifdef CONFIG_80211N_HT
void rtw_dump_dft_phy_cap(void *sel, _adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
#ifdef CONFIG_80211AC_VHT
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
#endif
#ifdef CONFIG_80211AC_VHT
RTW_PRINT_SEL(sel, "[DFT CAP] VHT STBC Tx : %s\n", (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] VHT STBC Rx : %s\n", (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX)) ? "V" : "X");
#endif
RTW_PRINT_SEL(sel, "[DFT CAP] HT STBC Tx : %s\n", (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] HT STBC Rx : %s\n\n", (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) ? "V" : "X");
#ifdef CONFIG_80211AC_VHT
RTW_PRINT_SEL(sel, "[DFT CAP] VHT LDPC Tx : %s\n", (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] VHT LDPC Rx : %s\n", (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX)) ? "V" : "X");
#endif
RTW_PRINT_SEL(sel, "[DFT CAP] HT LDPC Tx : %s\n", (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] HT LDPC Rx : %s\n\n", (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX)) ? "V" : "X");
#ifdef CONFIG_BEAMFORMING
#ifdef CONFIG_80211AC_VHT
RTW_PRINT_SEL(sel, "[DFT CAP] VHT MU Bfer : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] VHT MU Bfee : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] VHT SU Bfer : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] VHT SU Bfee : %s\n", (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) ? "V" : "X");
#endif
RTW_PRINT_SEL(sel, "[DFT CAP] HT Bfer : %s\n", (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DFT CAP] HT Bfee : %s\n", (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) ? "V" : "X");
#endif
}
void rtw_get_dft_phy_cap(void *sel, _adapter *adapter)
{
RTW_PRINT_SEL(sel, "\n ======== PHY CAP protocol ========\n");
rtw_ht_use_default_setting(adapter);
#ifdef CONFIG_80211AC_VHT
rtw_vht_use_default_setting(adapter);
#endif
#ifdef CONFIG_80211N_HT
rtw_dump_dft_phy_cap(sel, adapter);
#endif
}
void rtw_dump_drv_phy_cap(void *sel, _adapter *adapter)
{
struct registry_priv *pregistry_priv = &adapter->registrypriv;
RTW_PRINT_SEL(sel, "\n ======== DRV's configuration ========\n");
#if 0
RTW_PRINT_SEL(sel, "[DRV CAP] TRx Capability : 0x%08x\n", phy_spec->trx_cap);
RTW_PRINT_SEL(sel, "[DRV CAP] Tx Stream Num Index : %d\n", (phy_spec->trx_cap >> 24) & 0xFF); /*Tx Stream Num Index [31:24]*/
RTW_PRINT_SEL(sel, "[DRV CAP] Rx Stream Num Index : %d\n", (phy_spec->trx_cap >> 16) & 0xFF); /*Rx Stream Num Index [23:16]*/
RTW_PRINT_SEL(sel, "[DRV CAP] Tx Path Num Index : %d\n", (phy_spec->trx_cap >> 8) & 0xFF);/*Tx Path Num Index [15:8]*/
RTW_PRINT_SEL(sel, "[DRV CAP] Rx Path Num Index : %d\n", (phy_spec->trx_cap & 0xFF));/*Rx Path Num Index [7:0]*/
#endif
#ifdef CONFIG_80211N_HT
RTW_PRINT_SEL(sel, "[DRV CAP] STBC Capability : 0x%02x\n", pregistry_priv->stbc_cap);
RTW_PRINT_SEL(sel, "[DRV CAP] VHT STBC Tx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT1)) ? "V" : "X"); /*BIT1: Enable VHT STBC Tx*/
RTW_PRINT_SEL(sel, "[DRV CAP] VHT STBC Rx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT0)) ? "V" : "X"); /*BIT0: Enable VHT STBC Rx*/
RTW_PRINT_SEL(sel, "[DRV CAP] HT STBC Tx : %s\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT5)) ? "V" : "X"); /*BIT5: Enable HT STBC Tx*/
RTW_PRINT_SEL(sel, "[DRV CAP] HT STBC Rx : %s\n\n", (TEST_FLAG(pregistry_priv->stbc_cap, BIT4)) ? "V" : "X"); /*BIT4: Enable HT STBC Rx*/
RTW_PRINT_SEL(sel, "[DRV CAP] LDPC Capability : 0x%02x\n", pregistry_priv->ldpc_cap);
RTW_PRINT_SEL(sel, "[DRV CAP] VHT LDPC Tx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT1)) ? "V" : "X"); /*BIT1: Enable VHT LDPC Tx*/
RTW_PRINT_SEL(sel, "[DRV CAP] VHT LDPC Rx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT0)) ? "V" : "X"); /*BIT0: Enable VHT LDPC Rx*/
RTW_PRINT_SEL(sel, "[DRV CAP] HT LDPC Tx : %s\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT5)) ? "V" : "X"); /*BIT5: Enable HT LDPC Tx*/
RTW_PRINT_SEL(sel, "[DRV CAP] HT LDPC Rx : %s\n\n", (TEST_FLAG(pregistry_priv->ldpc_cap, BIT4)) ? "V" : "X"); /*BIT4: Enable HT LDPC Rx*/
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_BEAMFORMING
#if 0
RTW_PRINT_SEL(sel, "[DRV CAP] TxBF parameter : 0x%08x\n", phy_spec->txbf_param);
RTW_PRINT_SEL(sel, "[DRV CAP] VHT Sounding Dim : %d\n", (phy_spec->txbf_param >> 24) & 0xFF); /*VHT Sounding Dim [31:24]*/
RTW_PRINT_SEL(sel, "[DRV CAP] VHT Steering Ant : %d\n", (phy_spec->txbf_param >> 16) & 0xFF); /*VHT Steering Ant [23:16]*/
RTW_PRINT_SEL(sel, "[DRV CAP] HT Sounding Dim : %d\n", (phy_spec->txbf_param >> 8) & 0xFF); /*HT Sounding Dim [15:8]*/
RTW_PRINT_SEL(sel, "[DRV CAP] HT Steering Ant : %d\n", phy_spec->txbf_param & 0xFF); /*HT Steering Ant [7:0]*/
#endif
/*
* BIT0: Enable VHT SU Beamformer
* BIT1: Enable VHT SU Beamformee
* BIT2: Enable VHT MU Beamformer, depend on VHT SU Beamformer
* BIT3: Enable VHT MU Beamformee, depend on VHT SU Beamformee
* BIT4: Enable HT Beamformer
* BIT5: Enable HT Beamformee
*/
RTW_PRINT_SEL(sel, "[DRV CAP] TxBF Capability : 0x%02x\n", pregistry_priv->beamform_cap);
RTW_PRINT_SEL(sel, "[DRV CAP] VHT MU Bfer : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT2)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DRV CAP] VHT MU Bfee : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT3)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DRV CAP] VHT SU Bfer : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT0)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DRV CAP] VHT SU Bfee : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT1)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DRV CAP] HT Bfer : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT4)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DRV CAP] HT Bfee : %s\n", (TEST_FLAG(pregistry_priv->beamform_cap, BIT5)) ? "V" : "X");
RTW_PRINT_SEL(sel, "[DRV CAP] Tx Bfer rf_num : %d\n", pregistry_priv->beamformer_rf_num);
RTW_PRINT_SEL(sel, "[DRV CAP] Tx Bfee rf_num : %d\n", pregistry_priv->beamformee_rf_num);
#endif
}
int proc_get_stbc_cap(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->stbc_cap);
return 0;
}
ssize_t proc_set_stbc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if (num == 1 && pregpriv) {
pregpriv->stbc_cap = mode;
RTW_INFO("stbc_cap = 0x%02x\n", mode);
}
}
return count;
}
int proc_get_rx_stbc(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "%d\n", pregpriv->rx_stbc);
return 0;
}
ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if (num == 1 && pregpriv && (mode == 0 || mode == 1 || mode == 2 || mode == 3)) {
pregpriv->rx_stbc = mode;
printk("rx_stbc=%d\n", mode);
}
}
return count;
}
int proc_get_ldpc_cap(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->ldpc_cap);
return 0;
}
ssize_t proc_set_ldpc_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if (num == 1 && pregpriv) {
pregpriv->ldpc_cap = mode;
RTW_INFO("ldpc_cap = 0x%02x\n", mode);
}
}
return count;
}
#ifdef CONFIG_BEAMFORMING
int proc_get_txbf_cap(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "0x%02x\n", pregpriv->beamform_cap);
return 0;
}
ssize_t proc_set_txbf_cap(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 mode;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &mode);
if (num == 1 && pregpriv) {
pregpriv->beamform_cap = mode;
RTW_INFO("beamform_cap = 0x%02x\n", mode);
}
}
return count;
}
#endif
#endif /* CONFIG_80211N_HT */
/*int proc_get_rssi_disp(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
return 0;
}
*/
/*ssize_t proc_set_rssi_disp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 enable=0;
if (count < 1)
{
RTW_INFO("argument size is less than 1\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%x", &enable);
if (num != 1) {
RTW_INFO("invalid set_rssi_disp parameter!\n");
return count;
}
if(enable)
{
RTW_INFO("Linked info Function Enable\n");
padapter->bLinkInfoDump = enable ;
}
else
{
RTW_INFO("Linked info Function Disable\n");
padapter->bLinkInfoDump = 0 ;
}
}
return count;
}
*/
#ifdef CONFIG_AP_MODE
int proc_get_all_sta_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_irqL irqL;
struct sta_info *psta;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct sta_priv *pstapriv = &padapter->stapriv;
int i;
_list *plist, *phead;
RTW_MAP_DUMP_SEL(m, "sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
RTW_MAP_DUMP_SEL(m, "tim_bitmap=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
/* if(extra_arg == psta->cmn.aid) */
{
RTW_PRINT_SEL(m, "==============================\n");
RTW_PRINT_SEL(m, "sta's macaddr:" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
RTW_PRINT_SEL(m, "rtsen=%d, cts2slef=%d\n", psta->rtsen, psta->cts2self);
RTW_PRINT_SEL(m, "state=0x%x, aid=%d, macid=%d, raid=%d\n",
psta->state, psta->cmn.aid, psta->cmn.mac_id, psta->cmn.ra_info.rate_id);
#ifdef CONFIG_RTS_FULL_BW
if(psta->vendor_8812)
RTW_PRINT_SEL(m,"Vendor Realtek 8812\n");
#endif/*CONFIG_RTS_FULL_BW*/
#ifdef CONFIG_80211N_HT
RTW_PRINT_SEL(m, "qos_en=%d, ht_en=%d, init_rate=%d\n", psta->qos_option, psta->htpriv.ht_option, psta->init_rate);
RTW_PRINT_SEL(m, "bwmode=%d, ch_offset=%d, sgi_20m=%d,sgi_40m=%d\n"
, psta->cmn.bw_mode, psta->htpriv.ch_offset, psta->htpriv.sgi_20m, psta->htpriv.sgi_40m);
RTW_PRINT_SEL(m, "ampdu_enable = %d\n", psta->htpriv.ampdu_enable);
RTW_PRINT_SEL(m, "tx_amsdu_enable = %d\n", psta->htpriv.tx_amsdu_enable);
RTW_PRINT_SEL(m, "agg_enable_bitmap=%x, candidate_tid_bitmap=%x\n", psta->htpriv.agg_enable_bitmap, psta->htpriv.candidate_tid_bitmap);
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
RTW_PRINT_SEL(m, "vht_en=%d, vht_sgi_80m=%d\n", psta->vhtpriv.vht_option, psta->vhtpriv.sgi_80m);
RTW_PRINT_SEL(m, "vht_ldpc_cap=0x%x, vht_stbc_cap=0x%x, vht_beamform_cap=0x%x\n", psta->vhtpriv.ldpc_cap, psta->vhtpriv.stbc_cap, psta->vhtpriv.beamform_cap);
RTW_PRINT_SEL(m, "vht_mcs_map=0x%x, vht_highest_rate=0x%x, vht_ampdu_len=%d\n", *(u16 *)psta->vhtpriv.vht_mcs_map, psta->vhtpriv.vht_highest_rate, psta->vhtpriv.ampdu_len);
#endif
RTW_PRINT_SEL(m, "sleepq_len=%d\n", psta->sleepq_len);
RTW_PRINT_SEL(m, "sta_xmitpriv.vo_q_qcnt=%d\n", psta->sta_xmitpriv.vo_q.qcnt);
RTW_PRINT_SEL(m, "sta_xmitpriv.vi_q_qcnt=%d\n", psta->sta_xmitpriv.vi_q.qcnt);
RTW_PRINT_SEL(m, "sta_xmitpriv.be_q_qcnt=%d\n", psta->sta_xmitpriv.be_q.qcnt);
RTW_PRINT_SEL(m, "sta_xmitpriv.bk_q_qcnt=%d\n", psta->sta_xmitpriv.bk_q.qcnt);
RTW_PRINT_SEL(m, "capability=0x%x\n", psta->capability);
RTW_PRINT_SEL(m, "flags=0x%x\n", psta->flags);
RTW_PRINT_SEL(m, "wpa_psk=0x%x\n", psta->wpa_psk);
RTW_PRINT_SEL(m, "wpa2_group_cipher=0x%x\n", psta->wpa2_group_cipher);
RTW_PRINT_SEL(m, "wpa2_pairwise_cipher=0x%x\n", psta->wpa2_pairwise_cipher);
RTW_PRINT_SEL(m, "qos_info=0x%x\n", psta->qos_info);
RTW_PRINT_SEL(m, "dot118021XPrivacy=0x%x\n", psta->dot118021XPrivacy);
sta_rx_reorder_ctl_dump(m, psta);
#ifdef CONFIG_TDLS
RTW_PRINT_SEL(m, "tdls_sta_state=0x%08x\n", psta->tdls_sta_state);
RTW_PRINT_SEL(m, "PeerKey_Lifetime=%d\n", psta->TDLS_PeerKey_Lifetime);
#endif /* CONFIG_TDLS */
RTW_PRINT_SEL(m, "rx_data_uc_pkts=%llu\n", sta_rx_data_uc_pkts(psta));
RTW_PRINT_SEL(m, "rx_data_mc_pkts=%llu\n", psta->sta_stats.rx_data_mc_pkts);
RTW_PRINT_SEL(m, "rx_data_bc_pkts=%llu\n", psta->sta_stats.rx_data_bc_pkts);
RTW_PRINT_SEL(m, "rx_uc_bytes=%llu\n", sta_rx_uc_bytes(psta));
RTW_PRINT_SEL(m, "rx_mc_bytes=%llu\n", psta->sta_stats.rx_mc_bytes);
RTW_PRINT_SEL(m, "rx_bc_bytes=%llu\n", psta->sta_stats.rx_bc_bytes);
if (psta->sta_stats.rx_tp_kbits >> 10)
RTW_PRINT_SEL(m, "rx_tp =%d (Mbps)\n", psta->sta_stats.rx_tp_kbits >> 10);
else
RTW_PRINT_SEL(m, "rx_tp =%d (Kbps)\n", psta->sta_stats.rx_tp_kbits);
RTW_PRINT_SEL(m, "tx_data_pkts=%llu\n", psta->sta_stats.tx_pkts);
RTW_PRINT_SEL(m, "tx_bytes=%llu\n", psta->sta_stats.tx_bytes);
if (psta->sta_stats.tx_tp_kbits >> 10)
RTW_PRINT_SEL(m, "tx_tp =%d (Mbps)\n", psta->sta_stats.tx_tp_kbits >> 10);
else
RTW_PRINT_SEL(m, "tx_tp =%d (Kbps)\n", psta->sta_stats.tx_tp_kbits);
#ifdef CONFIG_RTW_80211K
RTW_PRINT_SEL(m, "rm_en_cap="RM_CAP_FMT"\n", RM_CAP_ARG(psta->rm_en_cap));
#endif
dump_st_ctl(m, &psta->st_ctl);
if (STA_OP_WFD_MODE(psta))
RTW_PRINT_SEL(m, "op_wfd_mode:0x%02x\n", STA_OP_WFD_MODE(psta));
RTW_PRINT_SEL(m, "==============================\n");
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
return 0;
}
#endif
#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
int proc_get_rtkm_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct recv_priv *precvpriv = &padapter->recvpriv;
struct recv_buf *precvbuf;
precvbuf = (struct recv_buf *)precvpriv->precv_buf;
RTW_PRINT_SEL(m, "============[RTKM Info]============\n");
RTW_PRINT_SEL(m, "MAX_RTKM_NR_PREALLOC_RECV_SKB: %d\n", rtw_rtkm_get_nr_recv_skb());
RTW_PRINT_SEL(m, "MAX_RTKM_RECVBUF_SZ: %d\n", rtw_rtkm_get_buff_size());
RTW_PRINT_SEL(m, "============[Driver Info]============\n");
RTW_PRINT_SEL(m, "NR_PREALLOC_RECV_SKB: %d\n", NR_PREALLOC_RECV_SKB);
RTW_PRINT_SEL(m, "MAX_RECVBUF_SZ: %d\n", precvbuf->alloc_sz);
return 0;
}
#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
#ifdef DBG_MEMORY_LEAK
#include
extern atomic_t _malloc_cnt;;
extern atomic_t _malloc_size;;
int proc_get_malloc_cnt(struct seq_file *m, void *v)
{
RTW_PRINT_SEL(m, "_malloc_cnt=%d\n", atomic_read(&_malloc_cnt));
RTW_PRINT_SEL(m, "_malloc_size=%d\n", atomic_read(&_malloc_size));
return 0;
}
#endif /* DBG_MEMORY_LEAK */
#ifdef CONFIG_FIND_BEST_CHANNEL
int proc_get_best_channel(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
u32 i, best_channel_24G = 1, best_channel_5G = 36, index_24G = 0, index_5G = 0;
for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
if (rfctl->channel_set[i].ChannelNum == 1)
index_24G = i;
if (rfctl->channel_set[i].ChannelNum == 36)
index_5G = i;
}
for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++) {
/* 2.4G */
if (rfctl->channel_set[i].ChannelNum == 6) {
if (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_24G].rx_count) {
index_24G = i;
best_channel_24G = rfctl->channel_set[i].ChannelNum;
}
}
/* 5G */
if (rfctl->channel_set[i].ChannelNum >= 36
&& rfctl->channel_set[i].ChannelNum < 140) {
/* Find primary channel */
if (((rfctl->channel_set[i].ChannelNum - 36) % 8 == 0)
&& (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
index_5G = i;
best_channel_5G = rfctl->channel_set[i].ChannelNum;
}
}
if (rfctl->channel_set[i].ChannelNum >= 149
&& rfctl->channel_set[i].ChannelNum < 165) {
/* find primary channel */
if (((rfctl->channel_set[i].ChannelNum - 149) % 8 == 0)
&& (rfctl->channel_set[i].rx_count < rfctl->channel_set[index_5G].rx_count)) {
index_5G = i;
best_channel_5G = rfctl->channel_set[i].ChannelNum;
}
}
#if 1 /* debug */
RTW_PRINT_SEL(m, "The rx cnt of channel %3d = %d\n",
rfctl->channel_set[i].ChannelNum, rfctl->channel_set[i].rx_count);
#endif
}
RTW_PRINT_SEL(m, "best_channel_5G = %d\n", best_channel_5G);
RTW_PRINT_SEL(m, "best_channel_24G = %d\n", best_channel_24G);
return 0;
}
ssize_t proc_set_best_channel(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
char tmp[32];
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int i;
for (i = 0; i < rfctl->max_chan_nums && rfctl->channel_set[i].ChannelNum != 0; i++)
rfctl->channel_set[i].rx_count = 0;
RTW_INFO("set %s\n", "Clean Best Channel Count");
}
return count;
}
#endif /* CONFIG_FIND_BEST_CHANNEL */
#ifdef CONFIG_BT_COEXIST
int proc_get_btcoex_dbg(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
PADAPTER padapter;
char buf[512] = {0};
padapter = (PADAPTER)rtw_netdev_priv(dev);
rtw_btcoex_GetDBG(padapter, buf, 512);
_RTW_PRINT_SEL(m, "%s", buf);
return 0;
}
ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
PADAPTER padapter;
u8 tmp[80] = {0};
u32 module[2] = {0};
u32 num;
padapter = (PADAPTER)rtw_netdev_priv(dev);
/* RTW_INFO("+" FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(padapter)); */
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n",
FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n",
FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
num = count;
if (num > (sizeof(tmp) - 1))
num = (sizeof(tmp) - 1);
if (copy_from_user(tmp, buffer, num)) {
RTW_INFO(FUNC_ADPT_FMT ": copy buffer from user space FAIL!\n",
FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
num = sscanf(tmp, "%x %x", module, module + 1);
if (1 == num) {
if (0 == module[0])
_rtw_memset(module, 0, sizeof(module));
else
_rtw_memset(module, 0xFF, sizeof(module));
} else if (2 != num) {
RTW_INFO(FUNC_ADPT_FMT ": input(\"%s\") format incorrect!\n",
FUNC_ADPT_ARG(padapter), tmp);
if (0 == num)
return -EFAULT;
}
RTW_INFO(FUNC_ADPT_FMT ": input 0x%08X 0x%08X\n",
FUNC_ADPT_ARG(padapter), module[0], module[1]);
rtw_btcoex_SetDBG(padapter, module);
return count;
}
int proc_get_btcoex_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
PADAPTER padapter;
const u32 bufsize = 40 * 100;
u8 *pbuf = NULL;
padapter = (PADAPTER)rtw_netdev_priv(dev);
pbuf = rtw_zmalloc(bufsize);
if (NULL == pbuf)
return -ENOMEM;
rtw_btcoex_DisplayBtCoexInfo(padapter, pbuf, bufsize);
_RTW_PRINT_SEL(m, "%s\n", pbuf);
rtw_mfree(pbuf, bufsize);
return 0;
}
#ifdef CONFIG_RF4CE_COEXIST
int proc_get_rf4ce_state(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
u8 state = 0, voice = 0;
state = rtw_btcoex_GetRf4ceLinkState(adapter);
RTW_PRINT_SEL(m, "RF4CE %s\n", state?"Connected":"Disconnect");
return 0;
}
/* This interface is designed for user space application to inform RF4CE state
* Initial define for DHC 1295 E387 project
*
* echo state voice > rf4ce_state
* state
* 0: RF4CE disconnected
* 1: RF4CE connected
*/
ssize_t proc_set_rf4ce_state(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 state;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx", &state);
if (num >= 1)
rtw_btcoex_SetRf4ceLinkState(adapter, state);
}
return count;
}
#endif /* CONFIG_RF4CE_COEXIST */
#endif /* CONFIG_BT_COEXIST */
#if defined(DBG_CONFIG_ERROR_DETECT)
int proc_get_sreset(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
if (psrtpriv->dbg_sreset_ctrl == _TRUE) {
RTW_PRINT_SEL(m, "self_dect_tx_cnt:%llu\n", psrtpriv->self_dect_tx_cnt);
RTW_PRINT_SEL(m, "self_dect_rx_cnt:%llu\n", psrtpriv->self_dect_rx_cnt);
RTW_PRINT_SEL(m, "self_dect_fw_cnt:%llu\n", psrtpriv->self_dect_fw_cnt);
RTW_PRINT_SEL(m, "tx_dma_status_cnt:%llu\n", psrtpriv->tx_dma_status_cnt);
RTW_PRINT_SEL(m, "rx_dma_status_cnt:%llu\n", psrtpriv->rx_dma_status_cnt);
RTW_PRINT_SEL(m, "self_dect_case:%d\n", psrtpriv->self_dect_case);
RTW_PRINT_SEL(m, "dbg_sreset_cnt:%d\n", pdbgpriv->dbg_sreset_cnt);
}
return 0;
}
ssize_t proc_set_sreset(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
char tmp[32];
s32 trigger_point;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d", &trigger_point);
if (num < 1)
return count;
if (trigger_point == SRESET_TGP_NULL)
rtw_hal_sreset_reset(padapter);
else if (trigger_point == SRESET_TGP_INFO)
psrtpriv->dbg_sreset_ctrl = _TRUE;
else
sreset_set_trigger_point(padapter, trigger_point);
}
return count;
}
#endif /* DBG_CONFIG_ERROR_DETECT */
#ifdef CONFIG_PCI_HCI
ssize_t proc_set_pci_bridge_conf_space(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct pci_dev *pdev = pdvobjpriv->ppcidev;
struct pci_dev *bridge_pdev = pdev->bus->self;
char tmp[32] = { 0 };
int num;
u32 reg = 0, value = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
num = sscanf(tmp, "%x %x", ®, &value);
if (num != 2) {
RTW_INFO("invalid parameter!\n");
return count;
}
if (reg >= 0x1000) {
RTW_INFO("invalid register!\n");
return count;
}
if (value > 0xFF) {
RTW_INFO("invalid value! Only one byte\n");
return count;
}
RTW_INFO(FUNC_ADPT_FMT ": register 0x%x value 0x%x\n",
FUNC_ADPT_ARG(padapter), reg, value);
pci_write_config_byte(bridge_pdev, reg, value);
}
return count;
}
int proc_get_pci_bridge_conf_space(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct pci_dev *pdev = pdvobjpriv->ppcidev;
struct pci_dev *bridge_pdev = pdev->bus->self;
u32 tmp[4] = { 0 };
u32 i, j;
RTW_PRINT_SEL(m, "\n***** PCI Host Device Configuration Space*****\n\n");
for (i = 0; i < 0x1000; i += 0x10) {
for (j = 0 ; j < 4 ; j++)
pci_read_config_dword(bridge_pdev, i + j * 4, tmp+j);
RTW_PRINT_SEL(m, "%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
}
return 0;
}
ssize_t proc_set_pci_conf_space(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct pci_dev *pdev = pdvobjpriv->ppcidev;
char tmp[32] = { 0 };
int num;
u32 reg = 0, value = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
num = sscanf(tmp, "%x %x", ®, &value);
if (num != 2) {
RTW_INFO("invalid parameter!\n");
return count;
}
if (reg >= 0x1000) {
RTW_INFO("invalid register!\n");
return count;
}
if (value > 0xFF) {
RTW_INFO("invalid value! Only one byte\n");
return count;
}
RTW_INFO(FUNC_ADPT_FMT ": register 0x%x value 0x%x\n",
FUNC_ADPT_ARG(padapter), reg, value);
pci_write_config_byte(pdev, reg, value);
}
return count;
}
int proc_get_pci_conf_space(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct pci_dev *pdev = pdvobjpriv->ppcidev;
struct pci_dev *bridge_pdev = pdev->bus->self;
u32 tmp[4] = { 0 };
u32 i, j;
RTW_PRINT_SEL(m, "\n***** PCI Device Configuration Space *****\n\n");
for (i = 0; i < 0x1000; i += 0x10) {
for (j = 0 ; j < 4 ; j++)
pci_read_config_dword(pdev, i + j * 4, tmp+j);
RTW_PRINT_SEL(m, "%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
}
return 0;
}
int proc_get_pci_aspm(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct pci_priv *pcipriv = &(pdvobjpriv->pcipriv);
u8 tmp8 = 0;
u16 tmp16 = 0;
u32 tmp32 = 0;
u8 l1_idle = 0;
RTW_PRINT_SEL(m, "***** ASPM Capability *****\n");
pci_read_config_dword(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCAP, &tmp32);
RTW_PRINT_SEL(m, "CLK REQ: %s\n", (tmp32&PCI_EXP_LNKCAP_CLKPM) ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "ASPM L0s: %s\n", (tmp32&BIT10) ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "ASPM L1: %s\n", (tmp32&BIT11) ? "Enable" : "Disable");
tmp8 = rtw_hal_pci_l1off_capability(padapter);
RTW_PRINT_SEL(m, "ASPM L1OFF: %s\n", tmp8 ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "***** ASPM CTRL Reg *****\n");
pci_read_config_word(pdvobjpriv->ppcidev, pcipriv->pciehdr_offset + PCI_EXP_LNKCTL, &tmp16);
RTW_PRINT_SEL(m, "CLK REQ: %s\n", (tmp16&PCI_EXP_LNKCTL_CLKREQ_EN) ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "ASPM L0s: %s\n", (tmp16&BIT0) ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "ASPM L1: %s\n", (tmp16&BIT1) ? "Enable" : "Disable");
tmp8 = rtw_hal_pci_l1off_nic_support(padapter);
RTW_PRINT_SEL(m, "ASPM L1OFF: %s\n", tmp8 ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "***** ASPM Backdoor *****\n");
tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
RTW_PRINT_SEL(m, "CLK REQ: %s\n", (tmp8 & BIT4) ? "Enable" : "Disable");
tmp8 = rtw_hal_pci_dbi_read(padapter, 0x70f);
l1_idle = tmp8 & 0x38;
RTW_PRINT_SEL(m, "ASPM L0s: %s\n", (tmp8&BIT7) ? "Enable" : "Disable");
tmp8 = rtw_hal_pci_dbi_read(padapter, 0x719);
RTW_PRINT_SEL(m, "ASPM L1: %s\n", (tmp8 & BIT3) ? "Enable" : "Disable");
tmp8 = rtw_hal_pci_dbi_read(padapter, 0x718);
RTW_PRINT_SEL(m, "ASPM L1OFF: %s\n", (tmp8 & BIT5) ? "Enable" : "Disable");
RTW_PRINT_SEL(m, "********* MISC **********\n");
RTW_PRINT_SEL(m, "ASPM L1 Idel Time: 0x%x\n", l1_idle>>3);
RTW_PRINT_SEL(m, "*************************\n");
return 0;
}
int proc_get_rx_ring(struct seq_file *m, void *v)
{
_irqL irqL;
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct recv_priv *precvpriv = &padapter->recvpriv;
struct rtw_rx_ring *rx_ring = &precvpriv->rx_ring[RX_MPDU_QUEUE];
int i, j;
RTW_PRINT_SEL(m, "rx ring (%p)\n", rx_ring);
RTW_PRINT_SEL(m, " dma: 0x%08x\n", (int) rx_ring->dma);
RTW_PRINT_SEL(m, " idx: %d\n", rx_ring->idx);
_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
for (i = 0; i < precvpriv->rxringcount; i++) {
#ifdef CONFIG_TRX_BD_ARCH
struct rx_buf_desc *entry = &rx_ring->buf_desc[i];
#else
struct recv_stat *entry = &rx_ring->desc[i];
#endif
struct sk_buff *skb = rx_ring->rx_buf[i];
RTW_PRINT_SEL(m, " desc[%03d]: %p, rx_buf[%03d]: 0x%08x\n",
i, entry, i, cpu_to_le32(*((dma_addr_t *)skb->cb)));
for (j = 0; j < sizeof(*entry) / 4; j++) {
if ((j % 4) == 0)
RTW_PRINT_SEL(m, " 0x%03x", j);
RTW_PRINT_SEL(m, " 0x%08x ", ((int *) entry)[j]);
if ((j % 4) == 3)
RTW_PRINT_SEL(m, "\n");
}
}
_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
return 0;
}
int proc_get_tx_ring(struct seq_file *m, void *v)
{
_irqL irqL;
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
int i, j, k;
_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
for (i = 0; i < PCI_MAX_TX_QUEUE_COUNT; i++) {
struct rtw_tx_ring *tx_ring = &pxmitpriv->tx_ring[i];
RTW_PRINT_SEL(m, "tx ring[%d] (%p)\n", i, tx_ring);
RTW_PRINT_SEL(m, " dma: 0x%08x\n", (int) tx_ring->dma);
RTW_PRINT_SEL(m, " idx: %d\n", tx_ring->idx);
RTW_PRINT_SEL(m, " entries: %d\n", tx_ring->entries);
/* RTW_PRINT_SEL(m, " queue: %d\n", tx_ring->queue); */
RTW_PRINT_SEL(m, " qlen: %d\n", tx_ring->qlen);
for (j = 0; j < pxmitpriv->txringcount[i]; j++) {
#ifdef CONFIG_TRX_BD_ARCH
struct tx_buf_desc *entry = &tx_ring->buf_desc[j];
RTW_PRINT_SEL(m, " buf_desc[%03d]: %p\n", j, entry);
#else
struct tx_desc *entry = &tx_ring->desc[j];
RTW_PRINT_SEL(m, " desc[%03d]: %p\n", j, entry);
#endif
for (k = 0; k < sizeof(*entry) / 4; k++) {
if ((k % 4) == 0)
RTW_PRINT_SEL(m, " 0x%03x", k);
RTW_PRINT_SEL(m, " 0x%08x ", ((int *) entry)[k]);
if ((k % 4) == 3)
RTW_PRINT_SEL(m, "\n");
}
}
}
_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
return 0;
}
#ifdef DBG_TXBD_DESC_DUMP
int proc_get_tx_ring_ext(struct seq_file *m, void *v)
{
_irqL irqL;
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *) rtw_netdev_priv(dev);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct rtw_tx_desc_backup *pbuf;
int i, j, k, idx;
RTW_PRINT_SEL(m, "<<<< tx ring ext dump settings >>>>\n");
RTW_PRINT_SEL(m, " - backup frame num: %d\n", TX_BAK_FRMAE_CNT);
RTW_PRINT_SEL(m, " - backup max. desc size: %d bytes\n", TX_BAK_DESC_LEN);
RTW_PRINT_SEL(m, " - backup data size: %d bytes\n\n", TX_BAK_DATA_LEN);
if (!pxmitpriv->dump_txbd_desc) {
RTW_PRINT_SEL(m, "Dump function is disabled.\n");
return 0;
}
_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
for (i = 0; i < HW_QUEUE_ENTRY; i++) {
struct rtw_tx_ring *tx_ring = &pxmitpriv->tx_ring[i];
idx = rtw_get_tx_desc_backup(padapter, i, &pbuf);
RTW_PRINT_SEL(m, "Tx ring[%d]", i);
switch (i) {
case 0:
RTW_PRINT_SEL(m, " (VO)\n");
break;
case 1:
RTW_PRINT_SEL(m, " (VI)\n");
break;
case 2:
RTW_PRINT_SEL(m, " (BE)\n");
break;
case 3:
RTW_PRINT_SEL(m, " (BK)\n");
break;
case 4:
RTW_PRINT_SEL(m, " (BCN)\n");
break;
case 5:
RTW_PRINT_SEL(m, " (MGT)\n");
break;
case 6:
RTW_PRINT_SEL(m, " (HIGH)\n");
break;
case 7:
RTW_PRINT_SEL(m, " (TXCMD)\n");
break;
default:
RTW_PRINT_SEL(m, " (?)\n");
break;
}
RTW_PRINT_SEL(m, " Entries: %d\n", TX_BAK_FRMAE_CNT);
RTW_PRINT_SEL(m, " Last idx: %d\n", idx);
for (j = 0; j < TX_BAK_FRMAE_CNT; j++) {
RTW_PRINT_SEL(m, " desc[%03d]:\n", j);
for (k = 0; k < (pbuf->tx_desc_size) / 4; k++) {
if ((k % 4) == 0)
RTW_PRINT_SEL(m, " 0x%03x", k);
RTW_PRINT_SEL(m, " 0x%08x ", ((int *)pbuf->tx_bak_desc)[k]);
if ((k % 4) == 3)
RTW_PRINT_SEL(m, "\n");
}
#if 1 /* data dump */
if (pbuf->tx_desc_size) {
RTW_PRINT_SEL(m, " data[%03d]:\n", j);
for (k = 0; k < (TX_BAK_DATA_LEN) / 4; k++) {
if ((k % 4) == 0)
RTW_PRINT_SEL(m, " 0x%03x", k);
RTW_PRINT_SEL(m, " 0x%08x ", ((int *)pbuf->tx_bak_data_hdr)[k]);
if ((k % 4) == 3)
RTW_PRINT_SEL(m, "\n");
}
RTW_PRINT_SEL(m, "\n");
}
#endif
RTW_PRINT_SEL(m, " R/W pointer: %d/%d\n", pbuf->tx_bak_rp, pbuf->tx_bak_wp);
pbuf = pbuf + 1;
}
RTW_PRINT_SEL(m, "\n");
}
_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
return 0;
}
ssize_t proc_set_tx_ring_ext(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
_irqL irqL;
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
char tmp[32];
u32 reset = 0;
u32 dump = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u", &dump, &reset);
if (num != 2) {
RTW_INFO("invalid parameter!\n");
return count;
}
_enter_critical(&pdvobjpriv->irq_th_lock, &irqL);
pxmitpriv->dump_txbd_desc = (BOOLEAN) dump;
if (reset == 1)
rtw_tx_desc_backup_reset();
_exit_critical(&pdvobjpriv->irq_th_lock, &irqL);
}
return count;
}
#endif
#endif
#ifdef CONFIG_WOWLAN
int proc_get_pattern_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct registry_priv *pregistrypriv = &padapter->registrypriv;
u8 pattern_num = 0, val8;
char str_1[128];
char *p_str;
int i = 0 , j = 0, k = 0;
int len = 0, max_len = 0, total = 0;
p_str = str_1;
max_len = sizeof(str_1);
total = pwrpriv->wowlan_pattern_idx;
rtw_set_default_pattern(padapter);
/*show pattern*/
RTW_PRINT_SEL(m, "\n======[Pattern Info.]======\n");
RTW_PRINT_SEL(m, "pattern number: %d\n", total);
RTW_PRINT_SEL(m, "support default patterns: %c\n",
(pwrpriv->default_patterns_en) ? 'Y' : 'N');
for (k = 0; k < total ; k++) {
RTW_PRINT_SEL(m, "\npattern idx: %d\n", k);
RTW_PRINT_SEL(m, "pattern content:\n");
p_str = str_1;
max_len = sizeof(str_1);
for (i = 0 ; i < MAX_WKFM_PATTERN_SIZE / 8 ; i++) {
_rtw_memset(p_str, 0, max_len);
len = 0;
for (j = 0 ; j < 8 ; j++) {
val8 = pwrpriv->patterns[k].content[i * 8 + j];
len += snprintf(p_str + len, max_len - len,
"%02x ", val8);
}
RTW_PRINT_SEL(m, "%s\n", p_str);
}
RTW_PRINT_SEL(m, "\npattern mask:\n");
for (i = 0 ; i < MAX_WKFM_SIZE / 8 ; i++) {
_rtw_memset(p_str, 0, max_len);
len = 0;
for (j = 0 ; j < 8 ; j++) {
val8 = pwrpriv->patterns[k].mask[i * 8 + j];
len += snprintf(p_str + len, max_len - len,
"%02x ", val8);
}
RTW_PRINT_SEL(m, "%s\n", p_str);
}
RTW_PRINT_SEL(m, "\npriv_pattern_len:\n");
RTW_PRINT_SEL(m, "pattern_len: %d\n", pwrpriv->patterns[k].len);
RTW_PRINT_SEL(m, "*****************\n");
}
return 0;
}
ssize_t proc_set_pattern_info(struct file *file, const char __user *buffer,
size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct wowlan_ioctl_param poidparam;
u8 tmp[MAX_WKFM_PATTERN_SIZE] = {0};
int ret = 0, num = 0;
u8 index = 0;
poidparam.subcode = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (pwrpriv->wowlan_pattern_idx >= MAX_WKFM_CAM_NUM) {
RTW_INFO("WARNING: priv-pattern is full(idx: %d)\n",
pwrpriv->wowlan_pattern_idx);
RTW_INFO("WARNING: please clean priv-pattern first\n");
return -ENOMEM;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
if (strncmp(tmp, "clean", 5) == 0) {
poidparam.subcode = WOWLAN_PATTERN_CLEAN;
rtw_hal_set_hwreg(padapter,
HW_VAR_WOWLAN, (u8 *)&poidparam);
} else {
index = pwrpriv->wowlan_pattern_idx;
ret = rtw_wowlan_parser_pattern_cmd(tmp,
pwrpriv->patterns[index].content,
&pwrpriv->patterns[index].len,
pwrpriv->patterns[index].mask);
if (ret == _TRUE)
pwrpriv->wowlan_pattern_idx++;
}
}
return count;
}
int proc_get_wakeup_event(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *registry_par = &padapter->registrypriv;
RTW_PRINT_SEL(m, "wakeup event: %#02x\n", registry_par->wakeup_event);
return 0;
}
ssize_t proc_set_wakeup_event(struct file *file, const char __user *buffer,
size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
struct registry_priv *registry_par = &padapter->registrypriv;
u32 wakeup_event = 0;
u8 tmp[8] = {0};
int ret = 0, num = 0;
u8 index = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count))
num = sscanf(tmp, "%u", &wakeup_event);
else
return -EFAULT;
if (num == 1 && wakeup_event <= 0x07) {
registry_par->wakeup_event = wakeup_event;
if (wakeup_event & BIT(1))
pwrctrlpriv->default_patterns_en = _TRUE;
else
pwrctrlpriv->default_patterns_en = _FALSE;
rtw_wow_pattern_sw_reset(padapter);
RTW_INFO("%s: wakeup_event: %#2x, default pattern: %d\n",
__func__, registry_par->wakeup_event,
pwrctrlpriv->default_patterns_en);
} else {
return -EINVAL;
}
return count;
}
int proc_get_wakeup_reason(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
u8 val = pwrpriv->wowlan_last_wake_reason;
RTW_PRINT_SEL(m, "last wake reason: %#02x\n", val);
return 0;
}
#endif /*CONFIG_WOWLAN*/
#ifdef CONFIG_GPIO_WAKEUP
int proc_get_wowlan_gpio_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
u8 val = pwrpriv->is_high_active;
RTW_PRINT_SEL(m, "wakeup_gpio_idx: %d\n", WAKEUP_GPIO_IDX);
RTW_PRINT_SEL(m, "high_active: %d\n", val);
return 0;
}
ssize_t proc_set_wowlan_gpio_info(struct file *file, const char __user *buffer,
size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
char tmp[32] = {0};
int num = 0;
u32 is_high_active = 0;
u8 val8 = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
num = sscanf(tmp, "%u", &is_high_active);
if (num != 1) {
RTW_INFO("Invalid format\n");
return count;
}
is_high_active = is_high_active == 0 ? 0 : 1;
pwrpriv->is_high_active = is_high_active;
rtw_ps_deny(padapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(padapter);
#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
if (pwrpriv->is_high_active == 0)
rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
else
rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
#else
val8 = (pwrpriv->is_high_active == 0) ? 1 : 0;
rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
#endif
rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
RTW_INFO("set %s %d\n", "gpio_high_active",
pwrpriv->is_high_active);
RTW_INFO("%s: set GPIO_%d %d as default.\n",
__func__, WAKEUP_GPIO_IDX, val8);
}
return count;
}
#endif /* CONFIG_GPIO_WAKEUP */
#ifdef CONFIG_P2P_WOWLAN
int proc_get_p2p_wowlan_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
struct p2p_wowlan_info peerinfo = pwdinfo->p2p_wow_info;
if (_TRUE == peerinfo.is_trigger) {
RTW_PRINT_SEL(m, "is_trigger: TRUE\n");
switch (peerinfo.wowlan_recv_frame_type) {
case P2P_WOWLAN_RECV_NEGO_REQ:
RTW_PRINT_SEL(m, "Frame Type: Nego Request\n");
break;
case P2P_WOWLAN_RECV_INVITE_REQ:
RTW_PRINT_SEL(m, "Frame Type: Invitation Request\n");
break;
case P2P_WOWLAN_RECV_PROVISION_REQ:
RTW_PRINT_SEL(m, "Frame Type: Provision Request\n");
break;
default:
break;
}
RTW_PRINT_SEL(m, "Peer Addr: "MAC_FMT"\n", MAC_ARG(peerinfo.wowlan_peer_addr));
RTW_PRINT_SEL(m, "Peer WPS Config: %x\n", peerinfo.wowlan_peer_wpsconfig);
RTW_PRINT_SEL(m, "Persistent Group: %d\n", peerinfo.wowlan_peer_is_persistent);
RTW_PRINT_SEL(m, "Intivation Type: %d\n", peerinfo.wowlan_peer_invitation_type);
} else
RTW_PRINT_SEL(m, "is_trigger: False\n");
return 0;
}
#endif /* CONFIG_P2P_WOWLAN */
#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
int proc_get_new_bcn_max(struct seq_file *m, void *v)
{
extern int new_bcn_max;
RTW_PRINT_SEL(m, "%d", new_bcn_max);
return 0;
}
ssize_t proc_set_new_bcn_max(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
extern int new_bcn_max;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count))
sscanf(tmp, "%d ", &new_bcn_max);
return count;
}
#endif
#ifdef CONFIG_POWER_SAVING
int proc_get_ps_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
u8 ips_mode = pwrpriv->ips_mode_req;
u8 lps_mode = pwrpriv->power_mgnt;
u8 lps_level = pwrpriv->lps_level;
#ifdef CONFIG_LPS_1T1R
u8 lps_1t1r = pwrpriv->lps_1t1r;
#endif
#ifdef CONFIG_WOWLAN
u8 wow_lps_mode = pwrpriv->wowlan_power_mgmt;
u8 wow_lps_level = pwrpriv->wowlan_lps_level;
#ifdef CONFIG_LPS_1T1R
u8 wow_lps_1t1r = pwrpriv->wowlan_lps_1t1r;
#endif
#endif /* CONFIG_WOWLAN */
char *str = "";
RTW_PRINT_SEL(m, "======Power Saving Info:======\n");
RTW_PRINT_SEL(m, "*IPS:\n");
if (ips_mode == IPS_NORMAL) {
#ifdef CONFIG_FWLPS_IN_IPS
str = "FW_LPS_IN_IPS";
#else
str = "Card Disable";
#endif
} else if (ips_mode == IPS_NONE)
str = "NO IPS";
else if (ips_mode == IPS_LEVEL_2)
str = "IPS_LEVEL_2";
else
str = "invalid ips_mode";
RTW_PRINT_SEL(m, " IPS mode: %s\n", str);
RTW_PRINT_SEL(m, " IPS enter count:%d, IPS leave count:%d\n",
pwrpriv->ips_enter_cnts, pwrpriv->ips_leave_cnts);
RTW_PRINT_SEL(m, "------------------------------\n");
RTW_PRINT_SEL(m, "*LPS:\n");
if (lps_mode == PS_MODE_ACTIVE)
str = "NO LPS";
else if (lps_mode == PS_MODE_MIN)
str = "MIN";
else if (lps_mode == PS_MODE_MAX)
str = "MAX";
else if (lps_mode == PS_MODE_DTIM)
str = "DTIM";
else
sprintf(str, "%d", lps_mode);
RTW_PRINT_SEL(m, " LPS mode: %s\n", str);
if (pwrpriv->dtim != 0)
RTW_PRINT_SEL(m, " DTIM: %d\n", pwrpriv->dtim);
RTW_PRINT_SEL(m, " LPS enter count:%d, LPS leave count:%d\n",
pwrpriv->lps_enter_cnts, pwrpriv->lps_leave_cnts);
if (lps_level == LPS_LCLK)
str = "LPS_LCLK";
else if (lps_level == LPS_PG)
str = "LPS_PG";
else
str = "LPS_NORMAL";
RTW_PRINT_SEL(m, " LPS level: %s\n", str);
#ifdef CONFIG_LPS_1T1R
RTW_PRINT_SEL(m, " LPS 1T1R: %d\n", lps_1t1r);
#endif
#ifdef CONFIG_WOWLAN
RTW_PRINT_SEL(m, "------------------------------\n");
RTW_PRINT_SEL(m, "*WOW LPS:\n");
if (wow_lps_mode == PS_MODE_ACTIVE)
str = "NO LPS";
else if (wow_lps_mode == PS_MODE_MIN)
str = "MIN";
else if (wow_lps_mode == PS_MODE_MAX)
str = "MAX";
else if (wow_lps_mode == PS_MODE_DTIM)
str = "DTIM";
else
sprintf(str, "%d", wow_lps_mode);
RTW_PRINT_SEL(m, " WOW LPS mode: %s\n", str);
if (wow_lps_level == LPS_LCLK)
str = "LPS_LCLK";
else if (wow_lps_level == LPS_PG)
str = "LPS_PG";
else
str = "LPS_NORMAL";
RTW_PRINT_SEL(m, " WOW LPS level: %s\n", str);
#ifdef CONFIG_LPS_1T1R
RTW_PRINT_SEL(m, " WOW LPS 1T1R: %d\n", wow_lps_1t1r);
#endif
#endif /* CONFIG_WOWLAN */
RTW_PRINT_SEL(m, "=============================\n");
return 0;
}
ssize_t proc_set_ps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
struct _ADAPTER *adapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
char tmp[8];
int num = 0;
int mode = 0;
int en = 0;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (!buffer || copy_from_user(tmp, buffer, count))
goto exit;
num = sscanf(tmp, "%d %d", &mode, &en);
if (num > 2) {
RTW_ERR("%s: invalid parameter!\n", __FUNCTION__);
goto exit;
}
if (num == 1 && mode == 0) {
/* back to original LPS/IPS Mode */
RTW_INFO("%s: back to original LPS/IPS Mode\n", __FUNCTION__);
rtw_pm_set_lps(adapter, adapter->registrypriv.power_mgnt);
rtw_pm_set_ips(adapter, adapter->registrypriv.ips_mode);
#ifdef CONFIG_WOWLAN
RTW_INFO("%s: back to original WOW LPS Mode\n", __FUNCTION__);
rtw_pm_set_wow_lps(adapter, adapter->registrypriv.wow_power_mgnt);
#endif /* CONFIG_WOWLAN */
goto exit;
}
if (mode == 1) {
/* LPS */
RTW_INFO("%s: LPS: %s, en=%d\n", __FUNCTION__, (en == 0) ? "disable":"enable", en);
if (rtw_pm_set_lps(adapter, en) != 0 )
RTW_ERR("%s: invalid parameter, mode=%d, level=%d\n", __FUNCTION__, mode, en);
} else if (mode == 2) {
/* IPS */
RTW_INFO("%s: IPS: %s, en=%d\n", __FUNCTION__, (en == 0) ? "disable":"enable", en);
if (rtw_pm_set_ips(adapter, en) != 0 )
RTW_ERR("%s: invalid parameter, mode=%d, level=%d\n", __FUNCTION__, mode, en);
}
#ifdef CONFIG_WOWLAN
else if (mode == 3) {
/* WOW LPS */
RTW_INFO("%s: WOW LPS: %s, en=%d\n", __FUNCTION__, (en == 0) ? "disable":"enable", en);
if (rtw_pm_set_wow_lps(adapter, en) != 0 )
RTW_ERR("%s: invalid parameter, mode=%d, level=%d\n", __FUNCTION__, mode, en);
}
#endif /* CONFIG_WOWLAN */
else
RTW_ERR("%s: invalid parameter, mode = %d!\n", __FUNCTION__, mode);
exit:
return count;
}
#ifdef CONFIG_WMMPS_STA
int proc_get_wmmps_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char *uapsd_max_sp_str="";
if (pregpriv){
switch(pregpriv->uapsd_max_sp_len) {
case 0:
uapsd_max_sp_str = "NO_LIMIT";
break;
case 1:
uapsd_max_sp_str = "TWO_MSDU";
break;
case 2:
uapsd_max_sp_str = "FOUR_MSDU";
break;
case 3:
uapsd_max_sp_str = "SIX_MSDU";
break;
default:
uapsd_max_sp_str = "UNSPECIFIED";
break;
}
RTW_PRINT_SEL(m, "====== WMMPS_STA Info:======\n");
RTW_PRINT_SEL(m, "uapsd_max_sp_len=0x%02x (%s)\n", pregpriv->uapsd_max_sp_len, uapsd_max_sp_str);
RTW_PRINT_SEL(m, "uapsd_ac_enable=0x%02x\n", pregpriv->uapsd_ac_enable);
RTW_PRINT_SEL(m, "BIT0 - AC_VO UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_VO) ? "Enabled" : "Disabled");
RTW_PRINT_SEL(m, "BIT1 - AC_VI UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_VI) ? "Enabled" : "Disabled");
RTW_PRINT_SEL(m, "BIT2 - AC_BK UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_BK) ? "Enabled" : "Disabled");
RTW_PRINT_SEL(m, "BIT3 - AC_BE UAPSD: %s\n", (pregpriv->uapsd_ac_enable & DRV_CFG_UAPSD_BE) ? "Enabled" : "Disabled");
RTW_PRINT_SEL(m, "============================\n");
}
return 0;
}
ssize_t proc_set_wmmps_info(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u8 uapsd_ac_setting;
u8 uapsd_max_sp_len_setting;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhu %hhx", &uapsd_max_sp_len_setting, &uapsd_ac_setting);
if (pregpriv) {
if (num >= 1) {
pregpriv->uapsd_max_sp_len = uapsd_max_sp_len_setting;
RTW_INFO("uapsd_max_sp_len = %d\n", pregpriv->uapsd_max_sp_len);
}
if (num >= 2) {
pregpriv->uapsd_ac_enable = uapsd_ac_setting;
RTW_INFO("uapsd_ac_enable = 0x%02x\n", pregpriv->uapsd_ac_enable);
}
}
}
return count;
}
#endif /* CONFIG_WMMPS_STA */
#endif /* CONFIG_POWER_SAVING */
#ifdef CONFIG_TDLS
int proc_get_tdls_enable(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
if (pregpriv)
RTW_PRINT_SEL(m, "TDLS is %s !\n", (rtw_is_tdls_enabled(padapter) == _TRUE) ? "enabled" : "disabled");
return 0;
}
ssize_t proc_set_tdls_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct registry_priv *pregpriv = &padapter->registrypriv;
char tmp[32];
u32 en_tdls = 0;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d ", &en_tdls);
if (num == 1 && pregpriv) {
if (en_tdls > 0)
rtw_enable_tdls_func(padapter);
else
rtw_disable_tdls_func(padapter, _TRUE);
}
}
return count;
}
static int proc_tdls_display_tdls_function_info(struct seq_file *m)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
u8 SpaceBtwnItemAndValueTmp = 0;
BOOLEAN FirstMatchFound = _FALSE;
int j = 0;
RTW_PRINT_SEL(m, "============[TDLS Function Info]============\n");
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Enable", (rtw_is_tdls_enabled(padapter) == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Driver Setup", (ptdlsinfo->driver_setup == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Prohibited", (ptdlsinfo->ap_prohibited == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Channel Switch Prohibited", (ptdlsinfo->ch_switch_prohibited == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Link Established", (ptdlsinfo->link_established == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %d/%d\n", SpaceBtwnItemAndValue, "TDLS STA Num (Linked/Allowed)", ptdlsinfo->sta_cnt, MAX_ALLOWED_TDLS_STA_NUM);
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Allowed STA Num Reached", (ptdlsinfo->sta_maximum == _TRUE) ? "_TRUE" : "_FALSE");
#ifdef CONFIG_TDLS_CH_SW
RTW_PRINT_SEL(m, "%-*s =", SpaceBtwnItemAndValue, "TDLS CH SW State");
if (ptdlsinfo->chsw_info.ch_sw_state == TDLS_STATE_NONE)
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_STATE_NONE");
else {
for (j = 0; j < 32; j++) {
if (ptdlsinfo->chsw_info.ch_sw_state & BIT(j)) {
if (FirstMatchFound == _FALSE) {
SpaceBtwnItemAndValueTmp = 1;
FirstMatchFound = _TRUE;
} else
SpaceBtwnItemAndValueTmp = SpaceBtwnItemAndValue + 3;
switch (BIT(j)) {
case TDLS_INITIATOR_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_INITIATOR_STATE");
break;
case TDLS_RESPONDER_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_RESPONDER_STATE");
break;
case TDLS_LINKED_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_LINKED_STATE");
break;
case TDLS_WAIT_PTR_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_WAIT_PTR_STATE");
break;
case TDLS_ALIVE_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_ALIVE_STATE");
break;
case TDLS_CH_SWITCH_ON_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SWITCH_ON_STATE");
break;
case TDLS_PEER_AT_OFF_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_PEER_AT_OFF_STATE");
break;
case TDLS_CH_SW_INITIATOR_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SW_INITIATOR_STATE");
break;
case TDLS_WAIT_CH_RSP_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValue, " ", "TDLS_WAIT_CH_RSP_STATE");
break;
default:
RTW_PRINT_SEL(m, "%-*sBIT(%d)\n", SpaceBtwnItemAndValueTmp, " ", j);
break;
}
}
}
}
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS CH SW On", (ATOMIC_READ(&ptdlsinfo->chsw_info.chsw_on) == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Off-Channel Num", ptdlsinfo->chsw_info.off_ch_num);
RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Channel Offset", ptdlsinfo->chsw_info.ch_offset);
RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Current Time", ptdlsinfo->chsw_info.cur_time);
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS CH SW Delay Switch Back", (ptdlsinfo->chsw_info.delay_switch_back == _TRUE) ? "_TRUE" : "_FALSE");
RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "TDLS CH SW Dump Back", ptdlsinfo->chsw_info.dump_stack);
#endif
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "TDLS Device Discovered", (ptdlsinfo->dev_discovered == _TRUE) ? "_TRUE" : "_FALSE");
return 0;
}
static int proc_tdls_display_network_info(struct seq_file *m)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
int i = 0;
u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
/* Display the linked AP/GO info */
RTW_PRINT_SEL(m, "============[Associated AP/GO Info]============\n");
if ((pmlmepriv->fw_state & WIFI_STATION_STATE) && (pmlmepriv->fw_state & _FW_LINKED)) {
RTW_PRINT_SEL(m, "%-*s = %s\n", SpaceBtwnItemAndValue, "BSSID", cur_network->network.Ssid.Ssid);
RTW_PRINT_SEL(m, "%-*s = "MAC_FMT"\n", SpaceBtwnItemAndValue, "Mac Address", MAC_ARG(cur_network->network.MacAddress));
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Wireless Mode");
for (i = 0; i < 8; i++) {
if (pmlmeext->cur_wireless_mode & BIT(i)) {
switch (BIT(i)) {
case WIRELESS_11B:
RTW_PRINT_SEL(m, "%4s", "11B ");
break;
case WIRELESS_11G:
RTW_PRINT_SEL(m, "%4s", "11G ");
break;
case WIRELESS_11A:
RTW_PRINT_SEL(m, "%4s", "11A ");
break;
case WIRELESS_11_24N:
RTW_PRINT_SEL(m, "%7s", "11_24N ");
break;
case WIRELESS_11_5N:
RTW_PRINT_SEL(m, "%6s", "11_5N ");
break;
case WIRELESS_AUTO:
RTW_PRINT_SEL(m, "%5s", "AUTO ");
break;
case WIRELESS_11AC:
RTW_PRINT_SEL(m, "%5s", "11AC ");
break;
}
}
}
RTW_PRINT_SEL(m, "\n");
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Privacy");
switch (padapter->securitypriv.dot11PrivacyAlgrthm) {
case _NO_PRIVACY_:
RTW_PRINT_SEL(m, "%s\n", "NO PRIVACY");
break;
case _WEP40_:
RTW_PRINT_SEL(m, "%s\n", "WEP 40");
break;
case _TKIP_:
RTW_PRINT_SEL(m, "%s\n", "TKIP");
break;
case _TKIP_WTMIC_:
RTW_PRINT_SEL(m, "%s\n", "TKIP WTMIC");
break;
case _AES_:
RTW_PRINT_SEL(m, "%s\n", "AES");
break;
case _WEP104_:
RTW_PRINT_SEL(m, "%s\n", "WEP 104");
break;
case _WEP_WPA_MIXED_:
RTW_PRINT_SEL(m, "%s\n", "WEP/WPA Mixed");
break;
case _SMS4_:
RTW_PRINT_SEL(m, "%s\n", "SMS4");
break;
#ifdef CONFIG_IEEE80211W
case _BIP_:
RTW_PRINT_SEL(m, "%s\n", "BIP");
break;
#endif /* CONFIG_IEEE80211W */
}
RTW_PRINT_SEL(m, "%-*s = %d\n", SpaceBtwnItemAndValue, "Channel", pmlmeext->cur_channel);
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Channel Offset");
switch (pmlmeext->cur_ch_offset) {
case HAL_PRIME_CHNL_OFFSET_DONT_CARE:
RTW_PRINT_SEL(m, "%s\n", "N/A");
break;
case HAL_PRIME_CHNL_OFFSET_LOWER:
RTW_PRINT_SEL(m, "%s\n", "Lower");
break;
case HAL_PRIME_CHNL_OFFSET_UPPER:
RTW_PRINT_SEL(m, "%s\n", "Upper");
break;
}
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Bandwidth Mode");
switch (pmlmeext->cur_bwmode) {
case CHANNEL_WIDTH_20:
RTW_PRINT_SEL(m, "%s\n", "20MHz");
break;
case CHANNEL_WIDTH_40:
RTW_PRINT_SEL(m, "%s\n", "40MHz");
break;
case CHANNEL_WIDTH_80:
RTW_PRINT_SEL(m, "%s\n", "80MHz");
break;
case CHANNEL_WIDTH_160:
RTW_PRINT_SEL(m, "%s\n", "160MHz");
break;
case CHANNEL_WIDTH_80_80:
RTW_PRINT_SEL(m, "%s\n", "80MHz + 80MHz");
break;
}
} else
RTW_PRINT_SEL(m, "No association with AP/GO exists!\n");
return 0;
}
static int proc_tdls_display_tdls_sta_info(struct seq_file *m)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct sta_priv *pstapriv = &padapter->stapriv;
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct sta_info *psta;
int i = 0, j = 0;
_irqL irqL;
_list *plist, *phead;
u8 SpaceBtwnItemAndValue = TDLS_DBG_INFO_SPACE_BTWN_ITEM_AND_VALUE;
u8 SpaceBtwnItemAndValueTmp = 0;
u8 NumOfTdlsStaToShow = 0;
BOOLEAN FirstMatchFound = _FALSE;
/* Search for TDLS sta info to display */
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if (psta->tdls_sta_state != TDLS_STATE_NONE) {
/* We got one TDLS sta info to show */
RTW_PRINT_SEL(m, "============[TDLS Peer STA Info: STA %d]============\n", ++NumOfTdlsStaToShow);
RTW_PRINT_SEL(m, "%-*s = "MAC_FMT"\n", SpaceBtwnItemAndValue, "Mac Address", MAC_ARG(psta->cmn.mac_addr));
RTW_PRINT_SEL(m, "%-*s =", SpaceBtwnItemAndValue, "TDLS STA State");
SpaceBtwnItemAndValueTmp = 0;
FirstMatchFound = _FALSE;
for (j = 0; j < 32; j++) {
if (psta->tdls_sta_state & BIT(j)) {
if (FirstMatchFound == _FALSE) {
SpaceBtwnItemAndValueTmp = 1;
FirstMatchFound = _TRUE;
} else
SpaceBtwnItemAndValueTmp = SpaceBtwnItemAndValue + 3;
switch (BIT(j)) {
case TDLS_INITIATOR_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_INITIATOR_STATE");
break;
case TDLS_RESPONDER_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_RESPONDER_STATE");
break;
case TDLS_LINKED_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_LINKED_STATE");
break;
case TDLS_WAIT_PTR_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_WAIT_PTR_STATE");
break;
case TDLS_ALIVE_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_ALIVE_STATE");
break;
case TDLS_CH_SWITCH_ON_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SWITCH_ON_STATE");
break;
case TDLS_PEER_AT_OFF_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_PEER_AT_OFF_STATE");
break;
case TDLS_CH_SW_INITIATOR_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValueTmp, " ", "TDLS_CH_SW_INITIATOR_STATE");
break;
case TDLS_WAIT_CH_RSP_STATE:
RTW_PRINT_SEL(m, "%-*s%s\n", SpaceBtwnItemAndValue, " ", "TDLS_WAIT_CH_RSP_STATE");
break;
default:
RTW_PRINT_SEL(m, "%-*sBIT(%d)\n", SpaceBtwnItemAndValueTmp, " ", j);
break;
}
}
}
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Wireless Mode");
for (j = 0; j < 8; j++) {
if (psta->wireless_mode & BIT(j)) {
switch (BIT(j)) {
case WIRELESS_11B:
RTW_PRINT_SEL(m, "%4s", "11B ");
break;
case WIRELESS_11G:
RTW_PRINT_SEL(m, "%4s", "11G ");
break;
case WIRELESS_11A:
RTW_PRINT_SEL(m, "%4s", "11A ");
break;
case WIRELESS_11_24N:
RTW_PRINT_SEL(m, "%7s", "11_24N ");
break;
case WIRELESS_11_5N:
RTW_PRINT_SEL(m, "%6s", "11_5N ");
break;
case WIRELESS_AUTO:
RTW_PRINT_SEL(m, "%5s", "AUTO ");
break;
case WIRELESS_11AC:
RTW_PRINT_SEL(m, "%5s", "11AC ");
break;
}
}
}
RTW_PRINT_SEL(m, "\n");
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Bandwidth Mode");
switch (psta->cmn.bw_mode) {
case CHANNEL_WIDTH_20:
RTW_PRINT_SEL(m, "%s\n", "20MHz");
break;
case CHANNEL_WIDTH_40:
RTW_PRINT_SEL(m, "%s\n", "40MHz");
break;
case CHANNEL_WIDTH_80:
RTW_PRINT_SEL(m, "%s\n", "80MHz");
break;
case CHANNEL_WIDTH_160:
RTW_PRINT_SEL(m, "%s\n", "160MHz");
break;
case CHANNEL_WIDTH_80_80:
RTW_PRINT_SEL(m, "%s\n", "80MHz + 80MHz");
break;
case CHANNEL_WIDTH_5:
RTW_PRINT_SEL(m, "%s\n", "5MHz");
break;
case CHANNEL_WIDTH_10:
RTW_PRINT_SEL(m, "%s\n", "10MHz");
break;
default:
RTW_PRINT_SEL(m, "(%d)%s\n", psta->cmn.bw_mode, "invalid");
break;
}
RTW_PRINT_SEL(m, "%-*s = ", SpaceBtwnItemAndValue, "Privacy");
switch (psta->dot118021XPrivacy) {
case _NO_PRIVACY_:
RTW_PRINT_SEL(m, "%s\n", "NO PRIVACY");
break;
case _WEP40_:
RTW_PRINT_SEL(m, "%s\n", "WEP 40");
break;
case _TKIP_:
RTW_PRINT_SEL(m, "%s\n", "TKIP");
break;
case _TKIP_WTMIC_:
RTW_PRINT_SEL(m, "%s\n", "TKIP WTMIC");
break;
case _AES_:
RTW_PRINT_SEL(m, "%s\n", "AES");
break;
case _WEP104_:
RTW_PRINT_SEL(m, "%s\n", "WEP 104");
break;
case _WEP_WPA_MIXED_:
RTW_PRINT_SEL(m, "%s\n", "WEP/WPA Mixed");
break;
case _SMS4_:
RTW_PRINT_SEL(m, "%s\n", "SMS4");
break;
#ifdef CONFIG_IEEE80211W
case _BIP_:
RTW_PRINT_SEL(m, "%s\n", "BIP");
break;
#endif /* CONFIG_IEEE80211W */
}
RTW_PRINT_SEL(m, "%-*s = %d sec/%d sec\n", SpaceBtwnItemAndValue, "TPK Lifetime (Current/Expire)", psta->TPK_count, psta->TDLS_PeerKey_Lifetime);
RTW_PRINT_SEL(m, "%-*s = %llu\n", SpaceBtwnItemAndValue, "Tx Packets Over Direct Link", psta->sta_stats.tx_pkts);
RTW_PRINT_SEL(m, "%-*s = %llu\n", SpaceBtwnItemAndValue, "Rx Packets Over Direct Link", psta->sta_stats.rx_data_pkts);
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
if (NumOfTdlsStaToShow == 0) {
RTW_PRINT_SEL(m, "============[TDLS Peer STA Info]============\n");
RTW_PRINT_SEL(m, "No TDLS direct link exists!\n");
}
return 0;
}
int proc_get_tdls_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
struct sta_priv *pstapriv = &padapter->stapriv;
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct sta_info *psta;
int i = 0, j = 0;
_irqL irqL;
_list *plist, *phead;
u8 SpaceBtwnItemAndValue = 41;
u8 SpaceBtwnItemAndValueTmp = 0;
u8 NumOfTdlsStaToShow = 0;
BOOLEAN FirstMatchFound = _FALSE;
if (hal_chk_wl_func(padapter, WL_FUNC_TDLS) == _FALSE) {
RTW_PRINT_SEL(m, "No tdls info can be shown since hal doesn't support tdls\n");
return 0;
}
proc_tdls_display_tdls_function_info(m);
proc_tdls_display_network_info(m);
proc_tdls_display_tdls_sta_info(m);
return 0;
}
#endif
int proc_get_monitor(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
if (WIFI_MONITOR_STATE == get_fwstate(pmlmepriv)) {
RTW_PRINT_SEL(m, "Monitor mode : Enable\n");
RTW_PRINT_SEL(m, "ch=%d, ch_offset=%d, bw=%d\n",
rtw_get_oper_ch(padapter), rtw_get_oper_choffset(padapter), rtw_get_oper_bw(padapter));
} else
RTW_PRINT_SEL(m, "Monitor mode : Disable\n");
return 0;
}
ssize_t proc_set_monitor(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
char tmp[32];
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
u8 target_chan, target_offset, target_bw;
if (count < 3) {
RTW_INFO("argument size is less than 3\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhu %hhu %hhu", &target_chan, &target_offset, &target_bw);
if (num != 3) {
RTW_INFO("invalid write_reg parameter!\n");
return count;
}
padapter->mlmeextpriv.cur_channel = target_chan;
set_channel_bwmode(padapter, target_chan, target_offset, target_bw);
}
return count;
}
#ifdef DBG_XMIT_BLOCK
int proc_get_xmit_block(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
dump_xmit_block(m, padapter);
return 0;
}
ssize_t proc_set_xmit_block(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u8 xb_mode, xb_reason;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%hhx %hhx", &xb_mode, &xb_reason);
if (num != 2) {
RTW_INFO("invalid parameter!\n");
return count;
}
if (xb_mode == 0)/*set*/
rtw_set_xmit_block(padapter, xb_reason);
else if (xb_mode == 1)/*clear*/
rtw_clr_xmit_block(padapter, xb_reason);
else
RTW_INFO("invalid parameter!\n");
}
return count;
}
#endif
#include
int proc_get_efuse_map(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
PEFUSE_HAL pEfuseHal = &pHalData->EfuseHal;
int i, j;
u8 ips_mode = IPS_NUM;
u16 mapLen;
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN, (void *)&mapLen, _FALSE);
if (mapLen > EFUSE_MAX_MAP_LEN)
mapLen = EFUSE_MAX_MAP_LEN;
ips_mode = pwrctrlpriv->ips_mode;
rtw_pm_set_ips(padapter, IPS_NONE);
if (pHalData->efuse_file_status == EFUSE_FILE_LOADED) {
RTW_PRINT_SEL(m, "File eFuse Map loaded! file path:%s\nDriver eFuse Map From File\n", EFUSE_MAP_PATH);
if (pHalData->bautoload_fail_flag)
RTW_PRINT_SEL(m, "File Autoload fail!!!\n");
} else if (pHalData->efuse_file_status == EFUSE_FILE_FAILED) {
RTW_PRINT_SEL(m, "Open File eFuse Map Fail ! file path:%s\nDriver eFuse Map From Default\n", EFUSE_MAP_PATH);
if (pHalData->bautoload_fail_flag)
RTW_PRINT_SEL(m, "HW Autoload fail!!!\n");
} else {
RTW_PRINT_SEL(m, "Driver eFuse Map From HW\n");
if (pHalData->bautoload_fail_flag)
RTW_PRINT_SEL(m, "HW Autoload fail!!!\n");
}
for (i = 0; i < mapLen; i += 16) {
RTW_PRINT_SEL(m, "0x%02x\t", i);
for (j = 0; j < 8; j++)
RTW_PRINT_SEL(m, "%02X ", pHalData->efuse_eeprom_data[i + j]);
RTW_PRINT_SEL(m, "\t");
for (; j < 16; j++)
RTW_PRINT_SEL(m, "%02X ", pHalData->efuse_eeprom_data[i + j]);
RTW_PRINT_SEL(m, "\n");
}
if (rtw_efuse_map_read(padapter, 0, mapLen, pEfuseHal->fakeEfuseInitMap) == _FAIL) {
RTW_PRINT_SEL(m, "WARN - Read Realmap Failed\n");
return 0;
}
RTW_PRINT_SEL(m, "\n");
RTW_PRINT_SEL(m, "HW eFuse Map\n");
for (i = 0; i < mapLen; i += 16) {
RTW_PRINT_SEL(m, "0x%02x\t", i);
for (j = 0; j < 8; j++)
RTW_PRINT_SEL(m, "%02X ", pEfuseHal->fakeEfuseInitMap[i + j]);
RTW_PRINT_SEL(m, "\t");
for (; j < 16; j++)
RTW_PRINT_SEL(m, "%02X ", pEfuseHal->fakeEfuseInitMap[i + j]);
RTW_PRINT_SEL(m, "\n");
}
rtw_pm_set_ips(padapter, ips_mode);
return 0;
}
ssize_t proc_set_efuse_map(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
#if 0
char tmp[256] = {0};
u32 addr, cnts;
u8 efuse_data;
int jj, kk;
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
u8 ips_mode = IPS_NUM;
if (count < 3) {
RTW_INFO("argument size is less than 3\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%x %d %x", &addr, &cnts, &efuse_data);
if (num != 3) {
RTW_INFO("invalid write_reg parameter!\n");
return count;
}
}
ips_mode = pwrctrlpriv->ips_mode;
rtw_pm_set_ips(padapter, IPS_NONE);
if (rtw_efuse_map_write(padapter, addr, cnts, &efuse_data) == _FAIL)
RTW_INFO("WARN - rtw_efuse_map_write error!!\n");
rtw_pm_set_ips(padapter, ips_mode);
#endif
return count;
}
#ifdef CONFIG_IEEE80211W
ssize_t proc_set_tx_sa_query(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct sta_priv *pstapriv = &padapter->stapriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct sta_info *psta;
_list *plist, *phead;
_irqL irqL;
char tmp[16];
u8 mac_addr[NUM_STA][ETH_ALEN];
u32 key_type;
u8 index;
if (count > 2) {
RTW_INFO("argument size is more than 2\n");
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {
int num = sscanf(tmp, "%x", &key_type);
if (num != 1) {
RTW_INFO("invalid read_reg parameter!\n");
return count;
}
RTW_INFO("0: set sa query request , key_type=%d\n", key_type);
}
if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
RTW_INFO("STA:"MAC_FMT"\n", MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
/* TX unicast sa_query to AP */
issue_action_SA_Query(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, 0, (u8)key_type);
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
/* TX unicast sa_query to every client STA */
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < NUM_STA; index++) {
psta = NULL;
phead = &(pstapriv->sta_hash[index]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
_rtw_memcpy(&mac_addr[psta->cmn.mac_id][0], psta->cmn.mac_addr, ETH_ALEN);
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < macid_ctl->num && index < NUM_STA; index++) {
if (rtw_macid_is_used(macid_ctl, index) && !rtw_macid_is_bmc(macid_ctl, index)) {
if (!_rtw_memcmp(get_my_bssid(&(pmlmeinfo->network)), &mac_addr[index][0], ETH_ALEN)
&& !IS_MCAST(&mac_addr[index][0])) {
issue_action_SA_Query(padapter, &mac_addr[index][0], 0, 0, (u8)key_type);
RTW_INFO("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
}
}
}
}
return count;
}
int proc_get_tx_sa_query(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "%s\n", __func__);
return 0;
}
ssize_t proc_set_tx_deauth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct sta_priv *pstapriv = &padapter->stapriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct sta_info *psta;
_list *plist, *phead;
_irqL irqL;
char tmp[16];
u8 mac_addr[NUM_STA][ETH_ALEN];
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u32 key_type;
u8 index;
if (count > 2) {
RTW_INFO("argument size is more than 2\n");
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {
int num = sscanf(tmp, "%x", &key_type);
if (num != 1) {
RTW_INFO("invalid read_reg parameter!\n");
return count;
}
RTW_INFO("key_type=%d\n", key_type);
}
if (key_type < 0 || key_type > 4)
return count;
if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
if (key_type == 3) /* key_type 3 only for AP mode */
return count;
/* TX unicast deauth to AP */
issue_deauth_11w(padapter, get_my_bssid(&(pmlmeinfo->network)), 0, (u8)key_type);
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
u8 updated = _FALSE;
if (key_type == 3)
issue_deauth_11w(padapter, bc_addr, 0, IEEE80211W_RIGHT_KEY);
/* TX unicast deauth to every client STA */
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < NUM_STA; index++) {
psta = NULL;
phead = &(pstapriv->sta_hash[index]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
_rtw_memcpy(&mac_addr[psta->cmn.mac_id][0], psta->cmn.mac_addr, ETH_ALEN);
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < macid_ctl->num && index < NUM_STA; index++) {
if (rtw_macid_is_used(macid_ctl, index) && !rtw_macid_is_bmc(macid_ctl, index)) {
if (!_rtw_memcmp(get_my_bssid(&(pmlmeinfo->network)), &mac_addr[index][0], ETH_ALEN)) {
if (key_type != 3)
issue_deauth_11w(padapter, &mac_addr[index][0], 0, (u8)key_type);
psta = rtw_get_stainfo(pstapriv, &mac_addr[index][0]);
if (psta && key_type != IEEE80211W_WRONG_KEY && key_type != IEEE80211W_NO_KEY) {
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
rtw_list_delete(&psta->asoc_list);
pstapriv->asoc_list_cnt--;
updated |= ap_free_sta(padapter, psta, _FALSE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
}
RTW_INFO("STA[%u]:"MAC_FMT"\n", index , MAC_ARG(&mac_addr[index][0]));
}
}
}
associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
}
return count;
}
int proc_get_tx_deauth(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "%s\n", __func__);
return 0;
}
ssize_t proc_set_tx_auth(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct sta_priv *pstapriv = &padapter->stapriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct sta_info *psta;
_list *plist, *phead;
_irqL irqL;
char tmp[16];
u8 mac_addr[NUM_STA][ETH_ALEN];
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u32 tx_auth;
u8 index;
if (count > 2) {
RTW_INFO("argument size is more than 2\n");
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, sizeof(tmp))) {
int num = sscanf(tmp, "%x", &tx_auth);
if (num != 1) {
RTW_INFO("invalid read_reg parameter!\n");
return count;
}
RTW_INFO("1: setnd auth, 2: send assoc request. tx_auth=%d\n", tx_auth);
}
if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
if (tx_auth == 1) {
/* TX unicast auth to AP */
issue_auth(padapter, NULL, 0);
} else if (tx_auth == 2) {
/* TX unicast auth to AP */
issue_assocreq(padapter);
}
}
return count;
}
int proc_get_tx_auth(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "%s\n", __func__);
return 0;
}
#endif /* CONFIG_IEEE80211W */
#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
static u32 phase_idx;
int proc_get_pathb_phase(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
RTW_PRINT_SEL(m, "PathB phase index =%d\n", phase_idx);
return 0;
}
ssize_t proc_set_pathb_phase(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
int num;
u32 tmp_idx;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
num = sscanf(tmp, "%u", &tmp_idx);
if ((tmp_idx < 0) || (tmp_idx > 11)) {
RTW_INFO(FUNC_ADPT_FMT "Invalid input value\n", FUNC_ADPT_ARG(padapter));
return count;
}
phase_idx = tmp_idx;
rtw_hal_set_pathb_phase(padapter, phase_idx);
}
return count;
}
#endif
#ifdef CONFIG_MCC_MODE
int proc_get_mcc_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
dump_adapters_status(m, adapter_to_dvobj(adapter));
rtw_hal_dump_mcc_info(m, adapter_to_dvobj(adapter));
return 0;
}
int proc_get_mcc_policy_table(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
rtw_hal_dump_mcc_policy_table(m);
return 0;
}
ssize_t proc_set_mcc_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 en_mcc = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface = NULL;
u8 i = 0;
int num = sscanf(tmp, "%u", &en_mcc);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: en_mcc = %d\n", __func__, en_mcc);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
iface->registrypriv.en_mcc = en_mcc;
}
}
return count;
}
ssize_t proc_set_mcc_duration(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 enable_runtime_duration = 0, mcc_duration = 0, type = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u %u", &enable_runtime_duration, &type, &mcc_duration);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
if (num > 3) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters > 2\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
if (num == 2) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters > 2\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
if (num >= 1) {
SET_MCC_RUNTIME_DURATION(padapter, enable_runtime_duration);
RTW_INFO("runtime duration:%s\n", enable_runtime_duration ? "enable":"disable");
}
if (num == 3) {
RTW_INFO("type:%d, mcc duration:%d\n", type, mcc_duration);
rtw_set_mcc_duration_cmd(padapter, type, mcc_duration);
}
}
return count;
}
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
ssize_t proc_set_mcc_phydm_offload_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_phydm_enable = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 i = 0;
int num = sscanf(tmp, "%u", &mcc_phydm_enable);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc phydm enable = %d\n", __func__, mcc_phydm_enable);
rtw_set_mcc_phydm_offload_enable_cmd(padapter, mcc_phydm_enable, _TRUE);
}
return count;
}
#endif
ssize_t proc_set_mcc_single_tx_criteria(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_single_tx_criteria = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface = NULL;
u8 i = 0;
int num = sscanf(tmp, "%u", &mcc_single_tx_criteria);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_single_tx_criteria = %d\n", __func__, mcc_single_tx_criteria);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
iface->registrypriv.rtw_mcc_single_tx_cri = mcc_single_tx_criteria;
}
}
return count;
}
ssize_t proc_set_mcc_ap_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_ap_bw20_target_tp = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &mcc_ap_bw20_target_tp);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_ap_bw20_target_tp = %d\n", __func__, mcc_ap_bw20_target_tp);
padapter->registrypriv.rtw_mcc_ap_bw20_target_tx_tp = mcc_ap_bw20_target_tp;
}
return count;
}
ssize_t proc_set_mcc_ap_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_ap_bw40_target_tp = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &mcc_ap_bw40_target_tp);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_ap_bw40_target_tp = %d\n", __func__, mcc_ap_bw40_target_tp);
padapter->registrypriv.rtw_mcc_ap_bw40_target_tx_tp = mcc_ap_bw40_target_tp;
}
return count;
}
ssize_t proc_set_mcc_ap_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_ap_bw80_target_tp = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &mcc_ap_bw80_target_tp);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_ap_bw80_target_tp = %d\n", __func__, mcc_ap_bw80_target_tp);
padapter->registrypriv.rtw_mcc_ap_bw80_target_tx_tp = mcc_ap_bw80_target_tp;
}
return count;
}
ssize_t proc_set_mcc_sta_bw20_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_sta_bw20_target_tp = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &mcc_sta_bw20_target_tp);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_sta_bw20_target_tp = %d\n", __func__, mcc_sta_bw20_target_tp);
padapter->registrypriv.rtw_mcc_sta_bw20_target_tx_tp = mcc_sta_bw20_target_tp;
}
return count;
}
ssize_t proc_set_mcc_sta_bw40_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_sta_bw40_target_tp = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &mcc_sta_bw40_target_tp);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_sta_bw40_target_tp = %d\n", __func__, mcc_sta_bw40_target_tp);
padapter->registrypriv.rtw_mcc_sta_bw40_target_tx_tp = mcc_sta_bw40_target_tp;
}
return count;
}
ssize_t proc_set_mcc_sta_bw80_target_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[255];
u32 mcc_sta_bw80_target_tp = 0;
if (NULL == buffer) {
RTW_INFO(FUNC_ADPT_FMT ": input buffer is NULL!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input length is 0!\n", FUNC_ADPT_ARG(padapter));
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO(FUNC_ADPT_FMT ": input length is too large\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &mcc_sta_bw80_target_tp);
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
RTW_INFO("%s: mcc_sta_bw80_target_tp = %d\n", __func__, mcc_sta_bw80_target_tp);
padapter->registrypriv.rtw_mcc_sta_bw80_target_tx_tp = mcc_sta_bw80_target_tp;
}
return count;
}
#endif /* CONFIG_MCC_MODE */
int proc_get_ack_timeout(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
u8 ack_timeout_val;
#ifdef CONFIG_RTL8821C
u8 ack_timeout_val_cck;
#endif
ack_timeout_val = rtw_read8(padapter, REG_ACKTO);
#ifdef CONFIG_RTL8821C
ack_timeout_val_cck = rtw_read8(padapter, REG_ACKTO_CCK_8821C);
RTW_PRINT_SEL(m, "Current CCK packet ACK Timeout = %d us (0x%x).\n", ack_timeout_val_cck, ack_timeout_val_cck);
RTW_PRINT_SEL(m, "Current non-CCK packet ACK Timeout = %d us (0x%x).\n", ack_timeout_val, ack_timeout_val);
#else
RTW_PRINT_SEL(m, "Current ACK Timeout = %d us (0x%x).\n", ack_timeout_val, ack_timeout_val);
#endif
return 0;
}
ssize_t proc_set_ack_timeout(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 ack_timeout_ms, ack_timeout_ms_cck;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u", &ack_timeout_ms, &ack_timeout_ms_cck);
#ifdef CONFIG_RTL8821C
if (num < 2) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 2\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
#else
if (num < 1) {
RTW_INFO(FUNC_ADPT_FMT ": input parameters < 1\n", FUNC_ADPT_ARG(padapter));
return -EINVAL;
}
#endif
/* This register sets the Ack time out value after Tx unicast packet. It is in units of us. */
rtw_write8(padapter, REG_ACKTO, (u8)ack_timeout_ms);
#ifdef CONFIG_RTL8821C
/* This register sets the Ack time out value after Tx unicast CCK packet. It is in units of us. */
rtw_write8(padapter, REG_ACKTO_CCK_8821C, (u8)ack_timeout_ms_cck);
RTW_INFO("Set CCK packet ACK Timeout to %d us.\n", ack_timeout_ms_cck);
RTW_INFO("Set non-CCK packet ACK Timeout to %d us.\n", ack_timeout_ms);
#else
RTW_INFO("Set ACK Timeout to %d us.\n", ack_timeout_ms);
#endif
}
return count;
}
ssize_t proc_set_fw_offload(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
char tmp[32];
u32 iqk_offload_enable = 0, ch_switch_offload_enable = 0;
if (buffer == NULL) {
RTW_INFO("input buffer is NULL!\n");
return -EFAULT;
}
if (count < 1) {
RTW_INFO("input length is 0!\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO("input length is too large\n");
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d %d", &iqk_offload_enable, &ch_switch_offload_enable);
if (num < 2) {
RTW_INFO("input parameters < 1\n");
return -EINVAL;
}
if (hal->RegIQKFWOffload != iqk_offload_enable) {
hal->RegIQKFWOffload = iqk_offload_enable;
rtw_run_in_thread_cmd(pri_adapter, ((void *)(rtw_hal_update_iqk_fw_offload_cap)), pri_adapter);
}
if (hal->ch_switch_offload != ch_switch_offload_enable)
hal->ch_switch_offload = ch_switch_offload_enable;
}
return count;
}
int proc_get_fw_offload(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
RTW_PRINT_SEL(m, "IQK FW offload:%s\n", hal->RegIQKFWOffload?"enable":"disable");
RTW_PRINT_SEL(m, "Channel switch FW offload:%s\n", hal->ch_switch_offload?"enable":"disable");
return 0;
}
#ifdef CONFIG_FW_HANDLE_TXBCN
extern void rtw_hal_set_fw_ap_bcn_offload_cmd(_adapter *adapter, bool fw_bcn_en, u8 tbtt_rpt_map);
ssize_t proc_set_fw_tbtt_rpt(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 fw_tbtt_rpt, fw_bcn_offload;
if (buffer == NULL) {
RTW_INFO("input buffer is NULL!\n");
return -EFAULT;
}
if (count < 1) {
RTW_INFO("input length is 0!\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO("input length is too large\n");
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d %x",&fw_bcn_offload, &fw_tbtt_rpt);
if (num < 2) {
RTW_INFO("input parameters < 2\n");
return -EINVAL;
}
rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, fw_bcn_offload, fw_tbtt_rpt);
}
return count;
}
int proc_get_fw_tbtt_rpt(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
RTW_PRINT_SEL(m, "FW BCN offload:%s\n", dvobj->fw_bcn_offload ? "enable" : "disable");
RTW_PRINT_SEL(m, "FW TBTT RPT:%x\n", dvobj->vap_tbtt_rpt_map);
return 0;
}
#endif
#ifdef CONFIG_CTRL_TXSS_BY_TP
ssize_t proc_set_txss_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
char tmp[32];
u32 enable = 0;
u32 txss_tx_tp = 0;
int txss_chk_cnt = 0;
if (buffer == NULL) {
RTW_INFO("input buffer is NULL!\n");
return -EFAULT;
}
if (count < 1) {
RTW_INFO("input length is 0!\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO("input length is too large\n");
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u %d",
&enable, &txss_tx_tp, &txss_chk_cnt);
if (num < 1) {
RTW_INFO("input parameters < 1\n");
return -EINVAL;
}
pmlmeext->txss_ctrl_en = enable;
if (txss_tx_tp)
pmlmeext->txss_tp_th = txss_tx_tp;
if (txss_chk_cnt)
pmlmeext->txss_tp_chk_cnt = txss_chk_cnt;
RTW_INFO("%s txss_ctl_en :%s , txss_tp_th:%d, tp_chk_cnt:%d\n",
__func__, pmlmeext->txss_tp_th ? "Y" : "N",
pmlmeext->txss_tp_th, pmlmeext->txss_tp_chk_cnt);
}
return count;
}
int proc_get_txss_tp(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
RTW_PRINT_SEL(m, "TXSS Control - %s\n", pmlmeext->txss_ctrl_en ? "enable" : "disable");
RTW_PRINT_SEL(m, "TXSS Tx TP TH - %d\n", pmlmeext->txss_tp_th);
RTW_PRINT_SEL(m, "TXSS check cnt - %d\n", pmlmeext->txss_tp_chk_cnt);
return 0;
}
#ifdef DBG_CTRL_TXSS
ssize_t proc_set_txss_ctrl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
char tmp[32];
u32 tx_1ss = 0;
if (buffer == NULL) {
RTW_INFO("input buffer is NULL!\n");
return -EFAULT;
}
if (count < 1) {
RTW_INFO("input length is 0!\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO("input length is too large\n");
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u", &tx_1ss);
if (num < 1) {
RTW_INFO("input parameters < 1\n");
return -EINVAL;
}
pmlmeext->txss_ctrl_en = _FALSE;
dbg_ctrl_txss(adapter, tx_1ss);
RTW_INFO("%s set tx to 1ss :%s\n", __func__, tx_1ss ? "Y" : "N");
}
return count;
}
int proc_get_txss_ctrl(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
RTW_PRINT_SEL(m, "TXSS 1ss - %s\n", pmlmeext->txss_1ss ? "Y" : "N");
return 0;
}
#endif
#endif
#ifdef CONFIG_DBG_RF_CAL
int proc_get_iqk_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
return 0;
}
ssize_t proc_set_iqk(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 recovery, clear, segment;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d %d %d", &recovery, &clear, &segment);
if (num != 3) {
RTW_INFO("Invalid format\n");
return count;
}
rtw_hal_iqk_test(padapter, recovery, clear, segment);
}
return count;
}
int proc_get_lck_info(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
return 0;
}
ssize_t proc_set_lck(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *padapter = (_adapter *)rtw_netdev_priv(dev);
char tmp[32];
u32 trigger;
if (count < 1)
return -EFAULT;
if (count > sizeof(tmp)) {
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%d", &trigger);
if (num != 1) {
RTW_INFO("Invalid format\n");
return count;
}
rtw_hal_lck_test(padapter);
}
return count;
}
#endif /* CONFIG_DBG_RF_CAL */
#ifdef CONFIG_LPS_CHK_BY_TP
ssize_t proc_set_lps_chk_tp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
char tmp[32];
u32 enable = 0;
u32 lps_tx_tp = 0, lps_rx_tp = 0, lps_bi_tp = 0;
int lps_chk_cnt_th = 0;
u32 lps_tx_pkts = 0, lps_rx_pkts = 0;
if (buffer == NULL) {
RTW_INFO("input buffer is NULL!\n");
return -EFAULT;
}
if (count < 1) {
RTW_INFO("input length is 0!\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO("input length is too large\n");
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u %u %u %d %u %u",
&enable, &lps_tx_tp, &lps_rx_tp, &lps_bi_tp,
&lps_chk_cnt_th, &lps_tx_pkts, &lps_rx_pkts);
if (num < 1) {
RTW_INFO("input parameters < 1\n");
return -EINVAL;
}
pwrpriv->lps_chk_by_tp = enable;
if (lps_tx_tp) {
pwrpriv->lps_tx_tp_th = lps_tx_tp;
pwrpriv->lps_rx_tp_th = lps_tx_tp;
pwrpriv->lps_bi_tp_th = lps_tx_tp;
}
if (lps_rx_tp)
pwrpriv->lps_rx_tp_th = lps_rx_tp;
if (lps_bi_tp)
pwrpriv->lps_bi_tp_th = lps_bi_tp;
if (lps_chk_cnt_th)
pwrpriv->lps_chk_cnt_th = lps_chk_cnt_th;
if (lps_tx_pkts)
pwrpriv->lps_tx_pkts = lps_tx_pkts;
if (lps_rx_pkts)
pwrpriv->lps_rx_pkts = lps_rx_pkts;
RTW_INFO("%s lps_chk_by_tp:%s , lps_tx_tp_th:%d, lps_tx_tp_th:%d, lps_bi_tp:%d\n",
__func__, pwrpriv->lps_chk_by_tp ? "Y" : "N",
pwrpriv->lps_tx_tp_th, pwrpriv->lps_tx_tp_th, pwrpriv->lps_bi_tp_th);
RTW_INFO("%s lps_chk_cnt_th:%d , lps_tx_pkts:%d, lps_rx_pkts:%d\n",
__func__, pwrpriv->lps_chk_cnt_th, pwrpriv->lps_tx_pkts, pwrpriv->lps_rx_pkts);
}
return count;
}
int proc_get_lps_chk_tp(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
RTW_PRINT_SEL(m, "LPS chk by tp - %s\n", pwrpriv->lps_chk_by_tp ? "enable" : "disable");
RTW_PRINT_SEL(m, "LPS Tx TP TH - %d(Mbps)\n", pwrpriv->lps_tx_tp_th);
RTW_PRINT_SEL(m, "LPS Rx TP TH - %d(Mbps)\n", pwrpriv->lps_rx_tp_th);
RTW_PRINT_SEL(m, "LPS BI TP TH - %d(Mbps)\n", pwrpriv->lps_bi_tp_th);
RTW_PRINT_SEL(m, "LPS CHK CNT - %d\n", pwrpriv->lps_chk_cnt_th);
RTW_PRINT_SEL(m, "LPS Tx PKTs - %d\n", pwrpriv->lps_tx_pkts);
RTW_PRINT_SEL(m, "LPS Rx PKTs - %d\n", pwrpriv->lps_rx_pkts);
return 0;
}
#endif /*CONFIG_LPS_CHK_BY_TP*/
#ifdef CONFIG_SUPPORT_STATIC_SMPS
ssize_t proc_set_smps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data)
{
struct net_device *dev = data;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
char tmp[32];
u32 enable = 0;
u32 smps_en, smps_tx_tp = 0, smps_rx_tp = 0;
u32 smps_test = 0, smps_test_en = 0;
if (buffer == NULL) {
RTW_INFO("input buffer is NULL!\n");
return -EFAULT;
}
if (count < 1) {
RTW_INFO("input length is 0!\n");
return -EFAULT;
}
if (count > sizeof(tmp)) {
RTW_INFO("input length is too large\n");
rtw_warn_on(1);
return -EFAULT;
}
if (buffer && !copy_from_user(tmp, buffer, count)) {
int num = sscanf(tmp, "%u %u %u %u %u", &smps_en, &smps_tx_tp, &smps_rx_tp,
&smps_test, &smps_test_en);
if (num < 1) {
RTW_INFO("input parameters < 1\n");
return -EINVAL;
}
pmlmeext->ssmps_en = smps_en;
if (smps_tx_tp) {
pmlmeext->ssmps_tx_tp_th= smps_tx_tp;
pmlmeext->ssmps_rx_tp_th= smps_tx_tp;
}
if (smps_rx_tp)
pmlmeext->ssmps_rx_tp_th = smps_rx_tp;
#ifdef DBG_STATIC_SMPS
if (num > 3) {
pmlmeext->ssmps_test = smps_test;
pmlmeext->ssmps_test_en = smps_test_en;
}
#endif
RTW_INFO("SM PS : %s tx_tp_th:%d, rx_tp_th:%d\n",
(smps_en) ? "Enable" : "Disable",
pmlmeext->ssmps_tx_tp_th,
pmlmeext->ssmps_rx_tp_th);
#ifdef DBG_STATIC_SMPS
RTW_INFO("SM PS : %s ssmps_test_en:%d\n",
(smps_test) ? "Enable" : "Disable",
pmlmeext->ssmps_test_en);
#endif
}
return count;
}
int proc_get_smps(struct seq_file *m, void *v)
{
struct net_device *dev = m->private;
_adapter *adapter = (_adapter *)rtw_netdev_priv(dev);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
RTW_PRINT_SEL(m, "Static SMPS %s\n", pmlmeext->ssmps_en ? "enable" : "disable");
RTW_PRINT_SEL(m, "Tx TP TH %d\n", pmlmeext->ssmps_tx_tp_th);
RTW_PRINT_SEL(m, "Rx TP TH %d\n", pmlmeext->ssmps_rx_tp_th);
#ifdef DBG_STATIC_SMPS
RTW_PRINT_SEL(m, "test %d, test_en:%d\n", pmlmeext->ssmps_test, pmlmeext->ssmps_test_en);
#endif
return 0;
}
#endif /*CONFIG_SUPPORT_STATIC_SMPS*/
#endif /* CONFIG_PROC_DEBUG */
#define RTW_BUFDUMP_BSIZE 16
#if 1
inline void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
bool _idx_show, const u8 *_hexdata, int _hexdatalen)
{
#ifdef CONFIG_RTW_DEBUG
int __i;
u8 *ptr = (u8 *)_hexdata;
if (_loglevel <= rtw_drv_log_level) {
if (_titlestring) {
if (sel == RTW_DBGDUMP)
RTW_PRINT("");
_RTW_PRINT_SEL(sel, "%s", _titlestring);
if (_hexdatalen >= RTW_BUFDUMP_BSIZE)
_RTW_PRINT_SEL(sel, "\n");
}
for (__i = 0; __i < _hexdatalen; __i++) {
if (((__i % RTW_BUFDUMP_BSIZE) == 0) && (_hexdatalen >= RTW_BUFDUMP_BSIZE)) {
if (sel == RTW_DBGDUMP)
RTW_PRINT("");
if (_idx_show)
_RTW_PRINT_SEL(sel, "0x%03X: ", __i);
}
_RTW_PRINT_SEL(sel, "%02X%s", ptr[__i], (((__i + 1) % 4) == 0) ? " " : " ");
if ((__i + 1 < _hexdatalen) && ((__i + 1) % RTW_BUFDUMP_BSIZE) == 0)
_RTW_PRINT_SEL(sel, "\n");
}
_RTW_PRINT_SEL(sel, "\n");
}
#endif
}
#else
inline void _RTW_STR_DUMP_SEL(void *sel, char *str_out)
{
if (sel == RTW_DBGDUMP)
_dbgdump("%s\n", str_out);
#if defined(_seqdump)
else
_seqdump(sel, "%s\n", str_out);
#endif /*_seqdump*/
}
inline void RTW_BUF_DUMP_SEL(uint _loglevel, void *sel, u8 *_titlestring,
bool _idx_show, u8 *_hexdata, int _hexdatalen)
{
int __i, len;
int __j, idx;
int block_num, remain_byte;
char str_out[128] = {'\0'};
char str_val[32] = {'\0'};
char *p = NULL;
u8 *ptr = (u8 *)_hexdata;
if (_loglevel <= rtw_drv_log_level) {
/*dump title*/
p = &str_out[0];
if (_titlestring) {
if (sel == RTW_DBGDUMP) {
len = snprintf(str_val, sizeof(str_val), "%s", DRIVER_PREFIX);
strncpy(p, str_val, len);
p += len;
}
len = snprintf(str_val, sizeof(str_val), "%s", _titlestring);
strncpy(p, str_val, len);
p += len;
}
if (p != &str_out[0]) {
_RTW_STR_DUMP_SEL(sel, str_out);
_rtw_memset(&str_out, '\0', sizeof(str_out));
}
/*dump buffer*/
block_num = _hexdatalen / RTW_BUFDUMP_BSIZE;
remain_byte = _hexdatalen % RTW_BUFDUMP_BSIZE;
for (__i = 0; __i < block_num; __i++) {
p = &str_out[0];
if (sel == RTW_DBGDUMP) {
len = snprintf(str_val, sizeof(str_val), "%s", DRIVER_PREFIX);
strncpy(p, str_val, len);
p += len;
}
if (_idx_show) {
len = snprintf(str_val, sizeof(str_val), "0x%03X: ", __i * RTW_BUFDUMP_BSIZE);
strncpy(p, str_val, len);
p += len;
}
for (__j =0; __j < RTW_BUFDUMP_BSIZE; __j++) {
idx = __i * RTW_BUFDUMP_BSIZE + __j;
len = snprintf(str_val, sizeof(str_val), "%02X%s", ptr[idx], (((__j + 1) % 4) == 0) ? " " : " ");
strncpy(p, str_val, len);
p += len;
}
_RTW_STR_DUMP_SEL(sel, str_out);
_rtw_memset(&str_out, '\0', sizeof(str_out));
}
p = &str_out[0];
if ((sel == RTW_DBGDUMP) && remain_byte) {
len = snprintf(str_val, sizeof(str_val), "%s", DRIVER_PREFIX);
strncpy(p, str_val, len);
p += len;
}
if (_idx_show && remain_byte) {
len = snprintf(str_val, sizeof(str_val), "0x%03X: ", block_num * RTW_BUFDUMP_BSIZE);
strncpy(p, str_val, len);
p += len;
}
for (__i = 0; __i < remain_byte; __i++) {
idx = block_num * RTW_BUFDUMP_BSIZE + __i;
len = snprintf(str_val, sizeof(str_val), "%02X%s", ptr[idx], (((__i + 1) % 4) == 0) ? " " : " ");
strncpy(p, str_val, len);
p += len;
}
_RTW_STR_DUMP_SEL(sel, str_out);
}
}
#endif
================================================
FILE: core/rtw_eeprom.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_EEPROM_C_
#include
#include
#include
void up_clk(_adapter *padapter, u16 *x)
{
*x = *x | _EESK;
rtw_write8(padapter, EE_9346CR, (u8)*x);
rtw_udelay_os(CLOCK_RATE);
}
void down_clk(_adapter *padapter, u16 *x)
{
*x = *x & ~_EESK;
rtw_write8(padapter, EE_9346CR, (u8)*x);
rtw_udelay_os(CLOCK_RATE);
}
void shift_out_bits(_adapter *padapter, u16 data, u16 count)
{
u16 x, mask;
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
mask = 0x01 << (count - 1);
x = rtw_read8(padapter, EE_9346CR);
x &= ~(_EEDO | _EEDI);
do {
x &= ~_EEDI;
if (data & mask)
x |= _EEDI;
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
rtw_write8(padapter, EE_9346CR, (u8)x);
rtw_udelay_os(CLOCK_RATE);
up_clk(padapter, &x);
down_clk(padapter, &x);
mask = mask >> 1;
} while (mask);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x &= ~_EEDI;
rtw_write8(padapter, EE_9346CR, (u8)x);
out:
return;
}
u16 shift_in_bits(_adapter *padapter)
{
u16 x, d = 0, i;
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x = rtw_read8(padapter, EE_9346CR);
x &= ~(_EEDO | _EEDI);
d = 0;
for (i = 0; i < 16; i++) {
d = d << 1;
up_clk(padapter, &x);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x = rtw_read8(padapter, EE_9346CR);
x &= ~(_EEDI);
if (x & _EEDO)
d |= 1;
down_clk(padapter, &x);
}
out:
return d;
}
void standby(_adapter *padapter)
{
u8 x;
x = rtw_read8(padapter, EE_9346CR);
x &= ~(_EECS | _EESK);
rtw_write8(padapter, EE_9346CR, x);
rtw_udelay_os(CLOCK_RATE);
x |= _EECS;
rtw_write8(padapter, EE_9346CR, x);
rtw_udelay_os(CLOCK_RATE);
}
u16 wait_eeprom_cmd_done(_adapter *padapter)
{
u8 x;
u16 i, res = _FALSE;
standby(padapter);
for (i = 0; i < 200; i++) {
x = rtw_read8(padapter, EE_9346CR);
if (x & _EEDO) {
res = _TRUE;
goto exit;
}
rtw_udelay_os(CLOCK_RATE);
}
exit:
return res;
}
void eeprom_clean(_adapter *padapter)
{
u16 x;
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x = rtw_read8(padapter, EE_9346CR);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x &= ~(_EECS | _EEDI);
rtw_write8(padapter, EE_9346CR, (u8)x);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
up_clk(padapter, &x);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
down_clk(padapter, &x);
out:
return;
}
void eeprom_write16(_adapter *padapter, u16 reg, u16 data)
{
u8 x;
x = rtw_read8(padapter, EE_9346CR);
x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
x |= _EEM1 | _EECS;
rtw_write8(padapter, EE_9346CR, x);
shift_out_bits(padapter, EEPROM_EWEN_OPCODE, 5);
if (padapter->EepromAddressSize == 8) /* CF+ and SDIO */
shift_out_bits(padapter, 0, 6);
else /* USB */
shift_out_bits(padapter, 0, 4);
standby(padapter);
/* Commented out by rcnjko, 2004.0
* Erase this particular word. Write the erase opcode and register
* number in that order. The opcode is 3bits in length; reg is 6 bits long. */
/* shift_out_bits(Adapter, EEPROM_ERASE_OPCODE, 3);
* shift_out_bits(Adapter, reg, Adapter->EepromAddressSize);
*
* if (wait_eeprom_cmd_done(Adapter ) == FALSE)
* {
* return;
* } */
standby(padapter);
/* write the new word to the EEPROM */
/* send the write opcode the EEPORM */
shift_out_bits(padapter, EEPROM_WRITE_OPCODE, 3);
/* select which word in the EEPROM that we are writing to. */
shift_out_bits(padapter, reg, padapter->EepromAddressSize);
/* write the data to the selected EEPROM word. */
shift_out_bits(padapter, data, 16);
if (wait_eeprom_cmd_done(padapter) == _FALSE)
goto exit;
standby(padapter);
shift_out_bits(padapter, EEPROM_EWDS_OPCODE, 5);
shift_out_bits(padapter, reg, 4);
eeprom_clean(padapter);
exit:
return;
}
u16 eeprom_read16(_adapter *padapter, u16 reg) /* ReadEEprom */
{
u16 x;
u16 data = 0;
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
/* select EEPROM, reset bits, set _EECS */
x = rtw_read8(padapter, EE_9346CR);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
x |= _EEM1 | _EECS;
rtw_write8(padapter, EE_9346CR, (unsigned char)x);
/* write the read opcode and register number in that order */
/* The opcode is 3bits in length, reg is 6 bits long */
shift_out_bits(padapter, EEPROM_READ_OPCODE, 3);
shift_out_bits(padapter, reg, padapter->EepromAddressSize);
/* Now read the data (16 bits) in from the selected EEPROM word */
data = shift_in_bits(padapter);
eeprom_clean(padapter);
out:
return data;
}
/* From even offset */
void eeprom_read_sz(_adapter *padapter, u16 reg, u8 *data, u32 sz)
{
u16 x, data16;
u32 i;
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
/* select EEPROM, reset bits, set _EECS */
x = rtw_read8(padapter, EE_9346CR);
if (rtw_is_surprise_removed(padapter)) {
goto out;
}
x &= ~(_EEDI | _EEDO | _EESK | _EEM0);
x |= _EEM1 | _EECS;
rtw_write8(padapter, EE_9346CR, (unsigned char)x);
/* write the read opcode and register number in that order */
/* The opcode is 3bits in length, reg is 6 bits long */
shift_out_bits(padapter, EEPROM_READ_OPCODE, 3);
shift_out_bits(padapter, reg, padapter->EepromAddressSize);
for (i = 0; i < sz; i += 2) {
data16 = shift_in_bits(padapter);
data[i] = data16 & 0xff;
data[i + 1] = data16 >> 8;
}
eeprom_clean(padapter);
out:
return;
}
/* addr_off : address offset of the entry in eeprom (not the tuple number of eeprom (reg); that is addr_off !=reg) */
u8 eeprom_read(_adapter *padapter, u32 addr_off, u8 sz, u8 *rbuf)
{
u8 quotient, remainder, addr_2align_odd;
u16 reg, stmp , i = 0, idx = 0;
reg = (u16)(addr_off >> 1);
addr_2align_odd = (u8)(addr_off & 0x1);
if (addr_2align_odd) { /* read that start at high part: e.g 1,3,5,7,9,... */
stmp = eeprom_read16(padapter, reg);
rbuf[idx++] = (u8)((stmp >> 8) & 0xff); /* return hogh-part of the short */
reg++;
sz--;
}
quotient = sz >> 1;
remainder = sz & 0x1;
for (i = 0 ; i < quotient; i++) {
stmp = eeprom_read16(padapter, reg + i);
rbuf[idx++] = (u8)(stmp & 0xff);
rbuf[idx++] = (u8)((stmp >> 8) & 0xff);
}
reg = reg + i;
if (remainder) { /* end of read at lower part of short : 0,2,4,6,... */
stmp = eeprom_read16(padapter, reg);
rbuf[idx] = (u8)(stmp & 0xff);
}
return _TRUE;
}
void read_eeprom_content(_adapter *padapter)
{
}
================================================
FILE: core/rtw_ieee80211.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _IEEE80211_C
#ifdef CONFIG_PLATFORM_INTEL_BYT
#include
#endif
#include
u8 RTW_WPA_OUI_TYPE[] = { 0x00, 0x50, 0xf2, 1 };
u16 RTW_WPA_VERSION = 1;
u8 WPA_AUTH_KEY_MGMT_NONE[] = { 0x00, 0x50, 0xf2, 0 };
u8 WPA_AUTH_KEY_MGMT_UNSPEC_802_1X[] = { 0x00, 0x50, 0xf2, 1 };
u8 WPA_AUTH_KEY_MGMT_PSK_OVER_802_1X[] = { 0x00, 0x50, 0xf2, 2 };
u8 WPA_CIPHER_SUITE_NONE[] = { 0x00, 0x50, 0xf2, 0 };
u8 WPA_CIPHER_SUITE_WEP40[] = { 0x00, 0x50, 0xf2, 1 };
u8 WPA_CIPHER_SUITE_TKIP[] = { 0x00, 0x50, 0xf2, 2 };
u8 WPA_CIPHER_SUITE_WRAP[] = { 0x00, 0x50, 0xf2, 3 };
u8 WPA_CIPHER_SUITE_CCMP[] = { 0x00, 0x50, 0xf2, 4 };
u8 WPA_CIPHER_SUITE_WEP104[] = { 0x00, 0x50, 0xf2, 5 };
u16 RSN_VERSION_BSD = 1;
u8 RSN_CIPHER_SUITE_NONE[] = { 0x00, 0x0f, 0xac, 0 };
u8 RSN_CIPHER_SUITE_WEP40[] = { 0x00, 0x0f, 0xac, 1 };
u8 RSN_CIPHER_SUITE_TKIP[] = { 0x00, 0x0f, 0xac, 2 };
u8 RSN_CIPHER_SUITE_WRAP[] = { 0x00, 0x0f, 0xac, 3 };
u8 RSN_CIPHER_SUITE_CCMP[] = { 0x00, 0x0f, 0xac, 4 };
u8 RSN_CIPHER_SUITE_WEP104[] = { 0x00, 0x0f, 0xac, 5 };
u8 WLAN_AKM_8021X[] = {0x00, 0x0f, 0xac, 1};
u8 WLAN_AKM_PSK[] = {0x00, 0x0f, 0xac, 2};
u8 WLAN_AKM_FT_8021X[] = {0x00, 0x0f, 0xac, 3};
u8 WLAN_AKM_FT_PSK[] = {0x00, 0x0f, 0xac, 4};
u8 WLAN_AKM_8021X_SHA256[] = {0x00, 0x0f, 0xac, 5};
u8 WLAN_AKM_PSK_SHA256[] = {0x00, 0x0f, 0xac, 6};
u8 WLAN_AKM_TDLS[] = {0x00, 0x0f, 0xac, 7};
u8 WLAN_AKM_SAE[] = {0x00, 0x0f, 0xac, 8};
u8 WLAN_AKM_FT_OVER_SAE[] = {0x00, 0x0f, 0xac, 9};
u8 WLAN_AKM_8021X_SUITE_B[] = {0x00, 0x0f, 0xac, 11};
u8 WLAN_AKM_8021X_SUITE_B_192[] = {0x00, 0x0f, 0xac, 12};
u8 WLAN_AKM_FILS_SHA256[] = {0x00, 0x0f, 0xac, 14};
u8 WLAN_AKM_FILS_SHA384[] = {0x00, 0x0f, 0xac, 15};
u8 WLAN_AKM_FT_FILS_SHA256[] = {0x00, 0x0f, 0xac, 16};
u8 WLAN_AKM_FT_FILS_SHA384[] = {0x00, 0x0f, 0xac, 17};
/* -----------------------------------------------------------
* for adhoc-master to generate ie and provide supported-rate to fw
* ----------------------------------------------------------- */
u8 WIFI_CCKRATES[] = {
(IEEE80211_CCK_RATE_1MB | IEEE80211_BASIC_RATE_MASK),
(IEEE80211_CCK_RATE_2MB | IEEE80211_BASIC_RATE_MASK),
(IEEE80211_CCK_RATE_5MB | IEEE80211_BASIC_RATE_MASK),
(IEEE80211_CCK_RATE_11MB | IEEE80211_BASIC_RATE_MASK)
};
u8 WIFI_OFDMRATES[] = {
(IEEE80211_OFDM_RATE_6MB),
(IEEE80211_OFDM_RATE_9MB),
(IEEE80211_OFDM_RATE_12MB),
(IEEE80211_OFDM_RATE_18MB),
(IEEE80211_OFDM_RATE_24MB),
IEEE80211_OFDM_RATE_36MB,
IEEE80211_OFDM_RATE_48MB,
IEEE80211_OFDM_RATE_54MB
};
u8 mgn_rates_cck[4] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};
u8 mgn_rates_ofdm[8] = {MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M};
u8 mgn_rates_mcs0_7[8] = {MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7};
u8 mgn_rates_mcs8_15[8] = {MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15};
u8 mgn_rates_mcs16_23[8] = {MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19, MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23};
u8 mgn_rates_mcs24_31[8] = {MGN_MCS24, MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29, MGN_MCS30, MGN_MCS31};
u8 mgn_rates_vht1ss[10] = {MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4
, MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9
};
u8 mgn_rates_vht2ss[10] = {MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4
, MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9
};
u8 mgn_rates_vht3ss[10] = {MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4
, MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9
};
u8 mgn_rates_vht4ss[10] = {MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4
, MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9
};
static const char *const _rate_section_str[] = {
"CCK",
"OFDM",
"HT_1SS",
"HT_2SS",
"HT_3SS",
"HT_4SS",
"VHT_1SS",
"VHT_2SS",
"VHT_3SS",
"VHT_4SS",
"RATE_SECTION_UNKNOWN",
};
const char *rate_section_str(u8 section)
{
section = (section >= RATE_SECTION_NUM) ? RATE_SECTION_NUM : section;
return _rate_section_str[section];
}
struct rate_section_ent rates_by_sections[RATE_SECTION_NUM] = {
{RF_1TX, 4, mgn_rates_cck},
{RF_1TX, 8, mgn_rates_ofdm},
{RF_1TX, 8, mgn_rates_mcs0_7},
{RF_2TX, 8, mgn_rates_mcs8_15},
{RF_3TX, 8, mgn_rates_mcs16_23},
{RF_4TX, 8, mgn_rates_mcs24_31},
{RF_1TX, 10, mgn_rates_vht1ss},
{RF_2TX, 10, mgn_rates_vht2ss},
{RF_3TX, 10, mgn_rates_vht3ss},
{RF_4TX, 10, mgn_rates_vht4ss},
};
int rtw_get_bit_value_from_ieee_value(u8 val)
{
unsigned char dot11_rate_table[] = {2, 4, 11, 22, 12, 18, 24, 36, 48, 72, 96, 108, 0}; /* last element must be zero!! */
int i = 0;
while (dot11_rate_table[i] != 0) {
if (dot11_rate_table[i] == val)
return BIT(i);
i++;
}
return 0;
}
uint rtw_get_cckrate_size(u8 *rate, u32 rate_length)
{
int i = 0;
while(i < rate_length){
RTW_DBG("%s, rate[%d]=%u\n", __FUNCTION__, i, rate[i]);
if (((rate[i] & 0x7f) == 2) || ((rate[i] & 0x7f) == 4) ||
((rate[i] & 0x7f) == 11) || ((rate[i] & 0x7f) == 22))
i++;
else
break;
}
return i;
}
uint rtw_is_cckrates_included(u8 *rate)
{
u32 i = 0;
while (rate[i] != 0) {
if ((((rate[i]) & 0x7f) == 2) || (((rate[i]) & 0x7f) == 4) ||
(((rate[i]) & 0x7f) == 11) || (((rate[i]) & 0x7f) == 22))
return _TRUE;
i++;
}
return _FALSE;
}
uint rtw_is_cckratesonly_included(u8 *rate)
{
u32 i = 0;
while (rate[i] != 0) {
if ((((rate[i]) & 0x7f) != 2) && (((rate[i]) & 0x7f) != 4) &&
(((rate[i]) & 0x7f) != 11) && (((rate[i]) & 0x7f) != 22))
return _FALSE;
i++;
}
return _TRUE;
}
int rtw_check_network_type(unsigned char *rate, int ratelen, int channel)
{
if (channel > 14) {
if ((rtw_is_cckrates_included(rate)) == _TRUE)
return WIRELESS_INVALID;
else
return WIRELESS_11A;
} else { /* could be pure B, pure G, or B/G */
if ((rtw_is_cckratesonly_included(rate)) == _TRUE)
return WIRELESS_11B;
else if ((rtw_is_cckrates_included(rate)) == _TRUE)
return WIRELESS_11BG;
else
return WIRELESS_11G;
}
}
u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source,
unsigned int *frlen)
{
_rtw_memcpy((void *)pbuf, (void *)source, len);
*frlen = *frlen + len;
return pbuf + len;
}
/* rtw_set_ie will update frame length */
u8 *rtw_set_ie
(
u8 *pbuf,
sint index,
uint len,
const u8 *source,
uint *frlen /* frame length */
)
{
*pbuf = (u8)index;
*(pbuf + 1) = (u8)len;
if (len > 0)
_rtw_memcpy((void *)(pbuf + 2), (void *)source, len);
if (frlen)
*frlen = *frlen + (len + 2);
return pbuf + len + 2;
}
inline u8 *rtw_set_ie_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode,
u8 new_ch, u8 ch_switch_cnt)
{
u8 ie_data[3];
ie_data[0] = ch_switch_mode;
ie_data[1] = new_ch;
ie_data[2] = ch_switch_cnt;
return rtw_set_ie(buf, WLAN_EID_CHANNEL_SWITCH, 3, ie_data, buf_len);
}
inline u8 secondary_ch_offset_to_hal_ch_offset(u8 ch_offset)
{
if (ch_offset == SCN)
return HAL_PRIME_CHNL_OFFSET_DONT_CARE;
else if (ch_offset == SCA)
return HAL_PRIME_CHNL_OFFSET_LOWER;
else if (ch_offset == SCB)
return HAL_PRIME_CHNL_OFFSET_UPPER;
return HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
inline u8 hal_ch_offset_to_secondary_ch_offset(u8 ch_offset)
{
if (ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE)
return SCN;
else if (ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
return SCA;
else if (ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
return SCB;
return SCN;
}
inline u8 *rtw_set_ie_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch_offset)
{
return rtw_set_ie(buf, WLAN_EID_SECONDARY_CHANNEL_OFFSET, 1, &secondary_ch_offset, buf_len);
}
inline u8 *rtw_set_ie_mesh_ch_switch_parm(u8 *buf, u32 *buf_len, u8 ttl,
u8 flags, u16 reason, u16 precedence)
{
u8 ie_data[6];
ie_data[0] = ttl;
ie_data[1] = flags;
RTW_PUT_LE16((u8 *)&ie_data[2], reason);
RTW_PUT_LE16((u8 *)&ie_data[4], precedence);
return rtw_set_ie(buf, 0x118, 6, ie_data, buf_len);
}
/*----------------------------------------------------------------------------
index: the information element id index, limit is the limit for search
-----------------------------------------------------------------------------*/
u8 *rtw_get_ie(const u8 *pbuf, sint index, sint *len, sint limit)
{
sint tmp, i;
const u8 *p;
if (limit < 1) {
return NULL;
}
p = pbuf;
i = 0;
*len = 0;
while (1) {
if (*p == index) {
*len = *(p + 1);
return (u8 *)p;
} else {
tmp = *(p + 1);
p += (tmp + 2);
i += (tmp + 2);
}
if (i >= limit)
break;
}
return NULL;
}
/**
* rtw_get_ie_ex - Search specific IE from a series of IEs
* @in_ie: Address of IEs to search
* @in_len: Length limit from in_ie
* @eid: Element ID to match
* @oui: OUI to match
* @oui_len: OUI length
* @ie: If not NULL and the specific IE is found, the IE will be copied to the buf starting from the specific IE
* @ielen: If not NULL and the specific IE is found, will set to the length of the entire IE
*
* Returns: The address of the specific IE found, or NULL
*/
u8 *rtw_get_ie_ex(const u8 *in_ie, uint in_len, u8 eid, const u8 *oui, u8 oui_len, u8 *ie, uint *ielen)
{
uint cnt;
const u8 *target_ie = NULL;
if (ielen)
*ielen = 0;
if (!in_ie || in_len <= 0)
return (u8 *)target_ie;
cnt = 0;
while (cnt < in_len) {
if (eid == in_ie[cnt]
&& (!oui || _rtw_memcmp(&in_ie[cnt + 2], oui, oui_len) == _TRUE)) {
target_ie = &in_ie[cnt];
if (ie)
_rtw_memcpy(ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
if (ielen)
*ielen = in_ie[cnt + 1] + 2;
break;
} else {
cnt += in_ie[cnt + 1] + 2; /* goto next */
}
}
return (u8 *)target_ie;
}
/**
* rtw_ies_remove_ie - Find matching IEs and remove
* @ies: Address of IEs to search
* @ies_len: Pointer of length of ies, will update to new length
* @offset: The offset to start scarch
* @eid: Element ID to match
* @oui: OUI to match
* @oui_len: OUI length
*
* Returns: _SUCCESS: ies is updated, _FAIL: not updated
*/
int rtw_ies_remove_ie(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 oui_len)
{
int ret = _FAIL;
u8 *target_ie;
u32 target_ielen;
u8 *start;
uint search_len;
if (!ies || !ies_len || *ies_len <= offset)
goto exit;
start = ies + offset;
search_len = *ies_len - offset;
while (1) {
target_ie = rtw_get_ie_ex(start, search_len, eid, oui, oui_len, NULL, &target_ielen);
if (target_ie && target_ielen) {
u8 *remain_ies = target_ie + target_ielen;
uint remain_len = search_len - (remain_ies - start);
_rtw_memmove(target_ie, remain_ies, remain_len);
*ies_len = *ies_len - target_ielen;
ret = _SUCCESS;
start = target_ie;
search_len = remain_len;
} else
break;
}
exit:
return ret;
}
void rtw_set_supported_rate(u8 *SupportedRates, uint mode)
{
_rtw_memset(SupportedRates, 0, NDIS_802_11_LENGTH_RATES_EX);
switch (mode) {
case WIRELESS_11B:
_rtw_memcpy(SupportedRates, WIFI_CCKRATES, IEEE80211_CCK_RATE_LEN);
break;
case WIRELESS_11G:
case WIRELESS_11A:
case WIRELESS_11_5N:
case WIRELESS_11A_5N: /* Todo: no basic rate for ofdm ? */
case WIRELESS_11_5AC:
_rtw_memcpy(SupportedRates, WIFI_OFDMRATES, IEEE80211_NUM_OFDM_RATESLEN);
break;
case WIRELESS_11BG:
case WIRELESS_11G_24N:
case WIRELESS_11_24N:
case WIRELESS_11BG_24N:
_rtw_memcpy(SupportedRates, WIFI_CCKRATES, IEEE80211_CCK_RATE_LEN);
_rtw_memcpy(SupportedRates + IEEE80211_CCK_RATE_LEN, WIFI_OFDMRATES, IEEE80211_NUM_OFDM_RATESLEN);
break;
}
}
void rtw_filter_suppport_rateie(WLAN_BSSID_EX *pbss_network, u8 keep)
{
u8 i, idx = 0, new_rate[NDIS_802_11_LENGTH_RATES_EX], *p;
int ret = 0;
uint iscck, isofdm, ie_orilen = 0, remain_len;
u8 *remain_ies;
p = rtw_get_ie(pbss_network->IEs + _BEACON_IE_OFFSET_, _SUPPORTEDRATES_IE_, &ie_orilen, (pbss_network->IELength - _BEACON_IE_OFFSET_));
if (!p)
return;
_rtw_memset(new_rate, 0, NDIS_802_11_LENGTH_RATES_EX);
for (i=0; i < ie_orilen; i++) {
iscck = rtw_is_cck_rate(p[i+2]);
isofdm= rtw_is_ofdm_rate(p[i+2]);
if (((keep == CCK) && iscck)
|| ((keep == OFDM) && isofdm))
new_rate[idx++]= rtw_is_basic_rate_ofdm(p[i+2]) ? p[i+2]|IEEE80211_BASIC_RATE_MASK : p[i+2];
}
/* update rate ie */
p[1] = idx;
_rtw_memcpy(p+2, new_rate, idx);
/* update remain ie & IELength*/
remain_ies = p + 2 + ie_orilen;
remain_len = pbss_network->IELength - (remain_ies - pbss_network->IEs);
_rtw_memmove(p+2+idx, remain_ies, remain_len);
pbss_network->IELength -= (ie_orilen - idx);
}
/*
Adjust those items by given wireless_mode
1. pbss_network->IELength
2. pbss_network->IE (SUPPORTRATE & EXT_SUPPORTRATE)
3. pbss_network->SupportedRates
*/
u8 rtw_update_rate_bymode(WLAN_BSSID_EX *pbss_network, u32 mode)
{
u8 network_type, *p, *ie = pbss_network->IEs;
sint ie_len;
uint network_ielen = pbss_network->IELength;
if (mode == WIRELESS_11B) {
/*only keep CCK in support_rate IE and remove whole ext_support_rate IE*/
rtw_filter_suppport_rateie(pbss_network, CCK);
p = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, &ie_len, pbss_network->IELength - _BEACON_IE_OFFSET_);
if (p) {
rtw_ies_remove_ie(ie , &network_ielen, _BEACON_IE_OFFSET_, _EXT_SUPPORTEDRATES_IE_, NULL, 0);
pbss_network->IELength -= ie_len;
}
network_type = WIRELESS_11B;
} else if ((mode & WIRELESS_11B) == 0) {
/* Remove CCK in support_rate IE */
rtw_filter_suppport_rateie(pbss_network, OFDM);
if (pbss_network->Configuration.DSConfig > 14)
network_type = WIRELESS_11A;
else
network_type = WIRELESS_11G;
} else
network_type = WIRELESS_11BG; /* do nothing */
rtw_set_supported_rate(pbss_network->SupportedRates, network_type);
return network_type;
}
uint rtw_get_rateset_len(u8 *rateset)
{
uint i = 0;
while (1) {
if ((rateset[i]) == 0)
break;
if (i > 12)
break;
i++;
}
return i;
}
int rtw_generate_ie(struct registry_priv *pregistrypriv)
{
u8 wireless_mode;
int sz = 0, rateLen;
WLAN_BSSID_EX *pdev_network = &pregistrypriv->dev_network;
u8 *ie = pdev_network->IEs;
/* timestamp will be inserted by hardware */
sz += 8;
ie += sz;
/* beacon interval : 2bytes */
*(u16 *)ie = cpu_to_le16((u16)pdev_network->Configuration.BeaconPeriod); /* BCN_INTERVAL; */
sz += 2;
ie += 2;
/* capability info */
*(u16 *)ie = 0;
*(u16 *)ie |= cpu_to_le16(cap_IBSS);
if (pregistrypriv->preamble == PREAMBLE_SHORT)
*(u16 *)ie |= cpu_to_le16(cap_ShortPremble);
if (pdev_network->Privacy)
*(u16 *)ie |= cpu_to_le16(cap_Privacy);
sz += 2;
ie += 2;
/* SSID */
ie = rtw_set_ie(ie, _SSID_IE_, pdev_network->Ssid.SsidLength, pdev_network->Ssid.Ssid, &sz);
/* supported rates */
if (pregistrypriv->wireless_mode == WIRELESS_11ABGN) {
if (pdev_network->Configuration.DSConfig > 14)
wireless_mode = WIRELESS_11A_5N;
else
wireless_mode = WIRELESS_11BG_24N;
} else if (pregistrypriv->wireless_mode == WIRELESS_MODE_MAX) { /* WIRELESS_11ABGN | WIRELESS_11AC */
if (pdev_network->Configuration.DSConfig > 14)
wireless_mode = WIRELESS_11_5AC;
else
wireless_mode = WIRELESS_11BG_24N;
} else
wireless_mode = pregistrypriv->wireless_mode;
rtw_set_supported_rate(pdev_network->SupportedRates, wireless_mode) ;
rateLen = rtw_get_rateset_len(pdev_network->SupportedRates);
if (rateLen > 8) {
ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, 8, pdev_network->SupportedRates, &sz);
/* ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (pdev_network->SupportedRates + 8), &sz); */
} else
ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, rateLen, pdev_network->SupportedRates, &sz);
/* DS parameter set */
ie = rtw_set_ie(ie, _DSSET_IE_, 1, (u8 *)&(pdev_network->Configuration.DSConfig), &sz);
/* IBSS Parameter Set */
ie = rtw_set_ie(ie, _IBSS_PARA_IE_, 2, (u8 *)&(pdev_network->Configuration.ATIMWindow), &sz);
if (rateLen > 8)
ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (pdev_network->SupportedRates + 8), &sz);
#ifdef CONFIG_80211N_HT
/* HT Cap. */
if (is_supported_ht(pregistrypriv->wireless_mode)
&& (pregistrypriv->ht_enable == _TRUE)) {
/* todo: */
}
#endif /* CONFIG_80211N_HT */
/* pdev_network->IELength = sz; */ /* update IELength */
/* return _SUCCESS; */
return sz;
}
unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit)
{
int len;
u16 val16;
unsigned char wpa_oui_type[] = {0x00, 0x50, 0xf2, 0x01};
u8 *pbuf = pie;
int limit_new = limit;
while (1) {
pbuf = rtw_get_ie(pbuf, _WPA_IE_ID_, &len, limit_new);
if (pbuf) {
/* check if oui matches... */
if (_rtw_memcmp((pbuf + 2), wpa_oui_type, sizeof(wpa_oui_type)) == _FALSE)
goto check_next_ie;
/* check version... */
_rtw_memcpy((u8 *)&val16, (pbuf + 6), sizeof(val16));
val16 = le16_to_cpu(val16);
if (val16 != 0x0001)
goto check_next_ie;
*wpa_ie_len = *(pbuf + 1);
return pbuf;
} else {
*wpa_ie_len = 0;
return NULL;
}
check_next_ie:
limit_new = limit - (pbuf - pie) - 2 - len;
if (limit_new <= 0)
break;
pbuf += (2 + len);
}
*wpa_ie_len = 0;
return NULL;
}
unsigned char *rtw_get_wpa2_ie(unsigned char *pie, int *rsn_ie_len, int limit)
{
return rtw_get_ie(pie, _WPA2_IE_ID_, rsn_ie_len, limit);
}
int rtw_get_wpa_cipher_suite(u8 *s)
{
if (_rtw_memcmp(s, WPA_CIPHER_SUITE_NONE, WPA_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_NONE;
if (_rtw_memcmp(s, WPA_CIPHER_SUITE_WEP40, WPA_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_WEP40;
if (_rtw_memcmp(s, WPA_CIPHER_SUITE_TKIP, WPA_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_TKIP;
if (_rtw_memcmp(s, WPA_CIPHER_SUITE_CCMP, WPA_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_CCMP;
if (_rtw_memcmp(s, WPA_CIPHER_SUITE_WEP104, WPA_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_WEP104;
return 0;
}
int rtw_get_wpa2_cipher_suite(u8 *s)
{
if (_rtw_memcmp(s, RSN_CIPHER_SUITE_NONE, RSN_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_NONE;
if (_rtw_memcmp(s, RSN_CIPHER_SUITE_WEP40, RSN_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_WEP40;
if (_rtw_memcmp(s, RSN_CIPHER_SUITE_TKIP, RSN_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_TKIP;
if (_rtw_memcmp(s, RSN_CIPHER_SUITE_CCMP, RSN_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_CCMP;
if (_rtw_memcmp(s, RSN_CIPHER_SUITE_WEP104, RSN_SELECTOR_LEN) == _TRUE)
return WPA_CIPHER_WEP104;
return 0;
}
u32 rtw_get_akm_suite_bitmap(u8 *s)
{
if (_rtw_memcmp(s, WLAN_AKM_8021X, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_8021X;
if (_rtw_memcmp(s, WLAN_AKM_PSK, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_PSK;
if (_rtw_memcmp(s, WLAN_AKM_FT_8021X, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FT_8021X;
if (_rtw_memcmp(s, WLAN_AKM_FT_PSK, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FT_PSK;
if (_rtw_memcmp(s, WLAN_AKM_8021X_SHA256, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_8021X_SHA256;
if (_rtw_memcmp(s, WLAN_AKM_PSK_SHA256, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_PSK_SHA256;
if (_rtw_memcmp(s, WLAN_AKM_TDLS, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_TDLS;
if (_rtw_memcmp(s, WLAN_AKM_SAE, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_SAE;
if (_rtw_memcmp(s, WLAN_AKM_FT_OVER_SAE, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FT_OVER_SAE;
if (_rtw_memcmp(s, WLAN_AKM_8021X_SUITE_B, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_8021X_SUITE_B;
if (_rtw_memcmp(s, WLAN_AKM_8021X_SUITE_B_192, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_8021X_SUITE_B_192;
if (_rtw_memcmp(s, WLAN_AKM_FILS_SHA256, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FILS_SHA256;
if (_rtw_memcmp(s, WLAN_AKM_FILS_SHA384, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FILS_SHA384;
if (_rtw_memcmp(s, WLAN_AKM_FT_FILS_SHA256, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FT_FILS_SHA256;
if (_rtw_memcmp(s, WLAN_AKM_FT_FILS_SHA384, RSN_SELECTOR_LEN) == _TRUE)
return WLAN_AKM_TYPE_FT_FILS_SHA384;
return 0;
}
int rtw_parse_wpa_ie(u8 *wpa_ie, int wpa_ie_len, int *group_cipher,
int *pairwise_cipher, u32 *akm)
{
int i, ret = _SUCCESS;
int left, count;
u8 *pos;
u8 SUITE_1X[4] = {0x00, 0x50, 0xf2, 1};
if (wpa_ie_len <= 0) {
/* No WPA IE - fail silently */
return _FAIL;
}
if ((*wpa_ie != _WPA_IE_ID_) || (*(wpa_ie + 1) != (u8)(wpa_ie_len - 2)) ||
(_rtw_memcmp(wpa_ie + 2, RTW_WPA_OUI_TYPE, WPA_SELECTOR_LEN) != _TRUE))
return _FAIL;
pos = wpa_ie;
pos += 8;
left = wpa_ie_len - 8;
/* group_cipher */
if (left >= WPA_SELECTOR_LEN) {
*group_cipher = rtw_get_wpa_cipher_suite(pos);
pos += WPA_SELECTOR_LEN;
left -= WPA_SELECTOR_LEN;
} else if (left > 0) {
return _FAIL;
}
/* pairwise_cipher */
if (left >= 2) {
/* count = le16_to_cpu(*(u16*)pos); */
count = RTW_GET_LE16(pos);
pos += 2;
left -= 2;
if (count == 0 || left < count * WPA_SELECTOR_LEN) {
return _FAIL;
}
for (i = 0; i < count; i++) {
*pairwise_cipher |= rtw_get_wpa_cipher_suite(pos);
pos += WPA_SELECTOR_LEN;
left -= WPA_SELECTOR_LEN;
}
} else if (left == 1) {
return _FAIL;
}
if (akm) {
if (left >= 6) {
pos += 2;
if (_rtw_memcmp(pos, SUITE_1X, 4) == 1) {
*akm = WLAN_AKM_TYPE_8021X;
}
}
}
return ret;
}
int rtw_rsne_info_parse(const u8 *ie, uint ie_len, struct rsne_info *info)
{
const u8 *pos = ie;
u16 cnt;
_rtw_memset(info, 0, sizeof(struct rsne_info));
if (ie + ie_len < pos + 4)
goto err;
if (*ie != WLAN_EID_RSN || *(ie + 1) != ie_len - 2)
goto err;
pos += 2 + 2;
/* Group CS */
if (ie + ie_len < pos + 4) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
info->gcs = (u8 *)pos;
pos += 4;
/* Pairwise CS */
if (ie + ie_len < pos + 2) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
cnt = RTW_GET_LE16(pos);
pos += 2;
if (ie + ie_len < pos + 4 * cnt) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
info->pcs_cnt = cnt;
info->pcs_list = (u8 *)pos;
pos += 4 * cnt;
/* AKM */
if (ie + ie_len < pos + 2) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
cnt = RTW_GET_LE16(pos);
pos += 2;
if (ie + ie_len < pos + 4 * cnt) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
info->akm_cnt = cnt;
info->akm_list = (u8 *)pos;
pos += 4 * cnt;
/* RSN cap */
if (ie + ie_len < pos + 2) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
info->cap = (u8 *)pos;
pos += 2;
/* PMKID */
if (ie + ie_len < pos + 2) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
cnt = RTW_GET_LE16(pos);
pos += 2;
if (ie + ie_len < pos + 16 * cnt) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
info->pmkid_cnt = cnt;
info->pmkid_list = (u8 *)pos;
pos += 16 * cnt;
/* Group Mgmt CS */
if (ie + ie_len < pos + 4) {
if (ie + ie_len != pos)
goto err;
goto exit;
}
info->gmcs = (u8 *)pos;
exit:
return _SUCCESS;
err:
info->err = 1;
return _FAIL;
}
int rtw_parse_wpa2_ie(u8 *rsn_ie, int rsn_ie_len, int *group_cipher,
int *pairwise_cipher, u32 *akm, u8 *mfp_opt)
{
struct rsne_info info;
int i, ret = _SUCCESS;
ret = rtw_rsne_info_parse(rsn_ie, rsn_ie_len, &info);
if (ret != _SUCCESS)
goto exit;
if (group_cipher) {
if (info.gcs)
*group_cipher = rtw_get_wpa2_cipher_suite(info.gcs);
else
*group_cipher = 0;
}
if (pairwise_cipher) {
*pairwise_cipher = 0;
for (i = 0; i < info.pcs_cnt; i++)
*pairwise_cipher |= rtw_get_wpa2_cipher_suite(info.pcs_list + 4 * i);
}
if (akm) {
*akm = 0;
for (i = 0; i < info.akm_cnt; i++)
*akm |= rtw_get_akm_suite_bitmap(info.akm_list + 4 * i);
}
if (mfp_opt) {
*mfp_opt = MFP_NO;
if (info.cap)
*mfp_opt = GET_RSN_CAP_MFP_OPTION(info.cap);
}
exit:
return ret;
}
/* #ifdef CONFIG_WAPI_SUPPORT */
int rtw_get_wapi_ie(u8 *in_ie, uint in_len, u8 *wapi_ie, u16 *wapi_len)
{
int len = 0;
u8 authmode;
uint cnt;
u8 wapi_oui1[4] = {0x0, 0x14, 0x72, 0x01};
u8 wapi_oui2[4] = {0x0, 0x14, 0x72, 0x02};
if (wapi_len)
*wapi_len = 0;
if (!in_ie || in_len <= 0)
return len;
cnt = (_TIMESTAMP_ + _BEACON_ITERVAL_ + _CAPABILITY_);
while (cnt < in_len) {
authmode = in_ie[cnt];
/* if(authmode==_WAPI_IE_) */
if (authmode == _WAPI_IE_ && (_rtw_memcmp(&in_ie[cnt + 6], wapi_oui1, 4) == _TRUE ||
_rtw_memcmp(&in_ie[cnt + 6], wapi_oui2, 4) == _TRUE)) {
if (wapi_ie)
_rtw_memcpy(wapi_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
if (wapi_len)
*wapi_len = in_ie[cnt + 1] + 2;
cnt += in_ie[cnt + 1] + 2; /* get next */
} else {
cnt += in_ie[cnt + 1] + 2; /* get next */
}
}
if (wapi_len)
len = *wapi_len;
return len;
}
/* #endif */
int rtw_get_sec_ie(u8 *in_ie, uint in_len, u8 *rsn_ie, u16 *rsn_len, u8 *wpa_ie, u16 *wpa_len)
{
u8 authmode, sec_idx;
u8 wpa_oui[4] = {0x0, 0x50, 0xf2, 0x01};
uint cnt;
/* Search required WPA or WPA2 IE and copy to sec_ie[ ] */
cnt = (_TIMESTAMP_ + _BEACON_ITERVAL_ + _CAPABILITY_);
sec_idx = 0;
while (cnt < in_len) {
authmode = in_ie[cnt];
if ((authmode == _WPA_IE_ID_) && (_rtw_memcmp(&in_ie[cnt + 2], &wpa_oui[0], 4) == _TRUE)) {
if (wpa_ie)
_rtw_memcpy(wpa_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
*wpa_len = in_ie[cnt + 1] + 2;
cnt += in_ie[cnt + 1] + 2; /* get next */
} else {
if (authmode == _WPA2_IE_ID_) {
if (rsn_ie)
_rtw_memcpy(rsn_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
*rsn_len = in_ie[cnt + 1] + 2;
cnt += in_ie[cnt + 1] + 2; /* get next */
} else {
cnt += in_ie[cnt + 1] + 2; /* get next */
}
}
}
return *rsn_len + *wpa_len;
}
u8 rtw_is_wps_ie(u8 *ie_ptr, uint *wps_ielen)
{
u8 match = _FALSE;
u8 eid, wps_oui[4] = {0x0, 0x50, 0xf2, 0x04};
if (ie_ptr == NULL)
return match;
eid = ie_ptr[0];
if ((eid == _WPA_IE_ID_) && (_rtw_memcmp(&ie_ptr[2], wps_oui, 4) == _TRUE)) {
/* RTW_INFO("==> found WPS_IE.....\n"); */
*wps_ielen = ie_ptr[1] + 2;
match = _TRUE;
}
return match;
}
u8 *rtw_get_wps_ie_from_scan_queue(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen, enum bss_type frame_type)
{
u8 *wps = NULL;
RTW_INFO("[%s] frame_type = %d\n", __FUNCTION__, frame_type);
switch (frame_type) {
case BSS_TYPE_BCN:
case BSS_TYPE_PROB_RSP: {
/* Beacon or Probe Response */
wps = rtw_get_wps_ie(in_ie + _PROBERSP_IE_OFFSET_, in_len - _PROBERSP_IE_OFFSET_, wps_ie, wps_ielen);
break;
}
case BSS_TYPE_PROB_REQ: {
/* Probe Request */
wps = rtw_get_wps_ie(in_ie + _PROBEREQ_IE_OFFSET_ , in_len - _PROBEREQ_IE_OFFSET_ , wps_ie, wps_ielen);
break;
}
default:
case BSS_TYPE_UNDEF:
break;
}
return wps;
}
/**
* rtw_get_wps_ie - Search WPS IE from a series of IEs
* @in_ie: Address of IEs to search
* @in_len: Length limit from in_ie
* @wps_ie: If not NULL and WPS IE is found, WPS IE will be copied to the buf starting from wps_ie
* @wps_ielen: If not NULL and WPS IE is found, will set to the length of the entire WPS IE
*
* Returns: The address of the WPS IE found, or NULL
*/
u8 *rtw_get_wps_ie(const u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
{
uint cnt;
const u8 *wpsie_ptr = NULL;
u8 eid, wps_oui[4] = {0x00, 0x50, 0xf2, 0x04};
if (wps_ielen)
*wps_ielen = 0;
if (!in_ie) {
rtw_warn_on(1);
return (u8 *)wpsie_ptr;
}
if (in_len <= 0)
return (u8 *)wpsie_ptr;
cnt = 0;
while (cnt + 1 + 4 < in_len) {
eid = in_ie[cnt];
if (cnt + 1 + 4 >= MAX_IE_SZ) {
rtw_warn_on(1);
return NULL;
}
if (eid == WLAN_EID_VENDOR_SPECIFIC && _rtw_memcmp(&in_ie[cnt + 2], wps_oui, 4) == _TRUE) {
wpsie_ptr = in_ie + cnt;
if (wps_ie)
_rtw_memcpy(wps_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
if (wps_ielen)
*wps_ielen = in_ie[cnt + 1] + 2;
break;
} else
cnt += in_ie[cnt + 1] + 2;
}
return (u8 *)wpsie_ptr;
}
/**
* rtw_get_wps_attr - Search a specific WPS attribute from a given WPS IE
* @wps_ie: Address of WPS IE to search
* @wps_ielen: Length limit from wps_ie
* @target_attr_id: The attribute ID of WPS attribute to search
* @buf_attr: If not NULL and the WPS attribute is found, WPS attribute will be copied to the buf starting from buf_attr
* @len_attr: If not NULL and the WPS attribute is found, will set to the length of the entire WPS attribute
*
* Returns: the address of the specific WPS attribute found, or NULL
*/
u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_attr, u32 *len_attr)
{
u8 *attr_ptr = NULL;
u8 *target_attr_ptr = NULL;
u8 wps_oui[4] = {0x00, 0x50, 0xF2, 0x04};
if (len_attr)
*len_attr = 0;
if ((wps_ie[0] != _VENDOR_SPECIFIC_IE_) ||
(_rtw_memcmp(wps_ie + 2, wps_oui , 4) != _TRUE))
return attr_ptr;
/* 6 = 1(Element ID) + 1(Length) + 4(WPS OUI) */
attr_ptr = wps_ie + 6; /* goto first attr */
while (attr_ptr - wps_ie < wps_ielen) {
/* 4 = 2(Attribute ID) + 2(Length) */
u16 attr_id = RTW_GET_BE16(attr_ptr);
u16 attr_data_len = RTW_GET_BE16(attr_ptr + 2);
u16 attr_len = attr_data_len + 4;
/* RTW_INFO("%s attr_ptr:%p, id:%u, length:%u\n", __FUNCTION__, attr_ptr, attr_id, attr_data_len); */
if (attr_id == target_attr_id) {
target_attr_ptr = attr_ptr;
if (buf_attr)
_rtw_memcpy(buf_attr, attr_ptr, attr_len);
if (len_attr)
*len_attr = attr_len;
break;
} else {
attr_ptr += attr_len; /* goto next */
}
}
return target_attr_ptr;
}
/**
* rtw_get_wps_attr_content - Search a specific WPS attribute content from a given WPS IE
* @wps_ie: Address of WPS IE to search
* @wps_ielen: Length limit from wps_ie
* @target_attr_id: The attribute ID of WPS attribute to search
* @buf_content: If not NULL and the WPS attribute is found, WPS attribute content will be copied to the buf starting from buf_content
* @len_content: If not NULL and the WPS attribute is found, will set to the length of the WPS attribute content
*
* Returns: the address of the specific WPS attribute content found, or NULL
*/
u8 *rtw_get_wps_attr_content(u8 *wps_ie, uint wps_ielen, u16 target_attr_id , u8 *buf_content, uint *len_content)
{
u8 *attr_ptr;
u32 attr_len;
if (len_content)
*len_content = 0;
attr_ptr = rtw_get_wps_attr(wps_ie, wps_ielen, target_attr_id, NULL, &attr_len);
if (attr_ptr && attr_len) {
if (buf_content)
_rtw_memcpy(buf_content, attr_ptr + 4, attr_len - 4);
if (len_content)
*len_content = attr_len - 4;
return attr_ptr + 4;
}
return NULL;
}
static int rtw_ieee802_11_parse_vendor_specific(u8 *pos, uint elen,
struct rtw_ieee802_11_elems *elems,
int show_errors)
{
unsigned int oui;
/* first 3 bytes in vendor specific information element are the IEEE
* OUI of the vendor. The following byte is used a vendor specific
* sub-type. */
if (elen < 4) {
if (show_errors) {
RTW_INFO("short vendor specific "
"information element ignored (len=%lu)\n",
(unsigned long) elen);
}
return -1;
}
oui = RTW_GET_BE24(pos);
switch (oui) {
case OUI_MICROSOFT:
/* Microsoft/Wi-Fi information elements are further typed and
* subtyped */
switch (pos[3]) {
case 1:
/* Microsoft OUI (00:50:F2) with OUI Type 1:
* real WPA information element */
elems->wpa_ie = pos;
elems->wpa_ie_len = elen;
break;
case WME_OUI_TYPE: /* this is a Wi-Fi WME info. element */
if (elen < 5) {
RTW_DBG("short WME "
"information element ignored "
"(len=%lu)\n",
(unsigned long) elen);
return -1;
}
switch (pos[4]) {
case WME_OUI_SUBTYPE_INFORMATION_ELEMENT:
case WME_OUI_SUBTYPE_PARAMETER_ELEMENT:
elems->wme = pos;
elems->wme_len = elen;
break;
case WME_OUI_SUBTYPE_TSPEC_ELEMENT:
elems->wme_tspec = pos;
elems->wme_tspec_len = elen;
break;
default:
RTW_DBG("unknown WME "
"information element ignored "
"(subtype=%d len=%lu)\n",
pos[4], (unsigned long) elen);
return -1;
}
break;
case 4:
/* Wi-Fi Protected Setup (WPS) IE */
elems->wps_ie = pos;
elems->wps_ie_len = elen;
break;
default:
RTW_DBG("Unknown Microsoft "
"information element ignored "
"(type=%d len=%lu)\n",
pos[3], (unsigned long) elen);
return -1;
}
break;
case OUI_BROADCOM:
switch (pos[3]) {
case VENDOR_HT_CAPAB_OUI_TYPE:
elems->vendor_ht_cap = pos;
elems->vendor_ht_cap_len = elen;
break;
default:
RTW_DBG("Unknown Broadcom "
"information element ignored "
"(type=%d len=%lu)\n",
pos[3], (unsigned long) elen);
return -1;
}
break;
default:
RTW_DBG("unknown vendor specific information "
"element ignored (vendor OUI %02x:%02x:%02x "
"len=%lu)\n",
pos[0], pos[1], pos[2], (unsigned long) elen);
return -1;
}
return 0;
}
/**
* ieee802_11_parse_elems - Parse information elements in management frames
* @start: Pointer to the start of IEs
* @len: Length of IE buffer in octets
* @elems: Data structure for parsed elements
* @show_errors: Whether to show parsing errors in debug log
* Returns: Parsing result
*/
ParseRes rtw_ieee802_11_parse_elems(u8 *start, uint len,
struct rtw_ieee802_11_elems *elems,
int show_errors)
{
uint left = len;
u8 *pos = start;
int unknown = 0;
_rtw_memset(elems, 0, sizeof(*elems));
while (left >= 2) {
u8 id, elen;
id = *pos++;
elen = *pos++;
left -= 2;
if (elen > left) {
if (show_errors) {
RTW_INFO("IEEE 802.11 element "
"parse failed (id=%d elen=%d "
"left=%lu)\n",
id, elen, (unsigned long) left);
}
return ParseFailed;
}
switch (id) {
case WLAN_EID_SSID:
elems->ssid = pos;
elems->ssid_len = elen;
break;
case WLAN_EID_SUPP_RATES:
elems->supp_rates = pos;
elems->supp_rates_len = elen;
break;
case WLAN_EID_FH_PARAMS:
elems->fh_params = pos;
elems->fh_params_len = elen;
break;
case WLAN_EID_DS_PARAMS:
elems->ds_params = pos;
elems->ds_params_len = elen;
break;
case WLAN_EID_CF_PARAMS:
elems->cf_params = pos;
elems->cf_params_len = elen;
break;
case WLAN_EID_TIM:
elems->tim = pos;
elems->tim_len = elen;
break;
case WLAN_EID_IBSS_PARAMS:
elems->ibss_params = pos;
elems->ibss_params_len = elen;
break;
case WLAN_EID_CHALLENGE:
elems->challenge = pos;
elems->challenge_len = elen;
break;
case WLAN_EID_ERP_INFO:
elems->erp_info = pos;
elems->erp_info_len = elen;
break;
case WLAN_EID_EXT_SUPP_RATES:
elems->ext_supp_rates = pos;
elems->ext_supp_rates_len = elen;
break;
case WLAN_EID_VENDOR_SPECIFIC:
if (rtw_ieee802_11_parse_vendor_specific(pos, elen,
elems,
show_errors))
unknown++;
break;
case WLAN_EID_RSN:
elems->rsn_ie = pos;
elems->rsn_ie_len = elen;
break;
case WLAN_EID_PWR_CAPABILITY:
elems->power_cap = pos;
elems->power_cap_len = elen;
break;
case WLAN_EID_SUPPORTED_CHANNELS:
elems->supp_channels = pos;
elems->supp_channels_len = elen;
break;
case WLAN_EID_MOBILITY_DOMAIN:
elems->mdie = pos;
elems->mdie_len = elen;
break;
case WLAN_EID_FAST_BSS_TRANSITION:
elems->ftie = pos;
elems->ftie_len = elen;
break;
case WLAN_EID_TIMEOUT_INTERVAL:
elems->timeout_int = pos;
elems->timeout_int_len = elen;
break;
case WLAN_EID_HT_CAP:
elems->ht_capabilities = pos;
elems->ht_capabilities_len = elen;
break;
case WLAN_EID_HT_OPERATION:
elems->ht_operation = pos;
elems->ht_operation_len = elen;
break;
case WLAN_EID_VHT_CAPABILITY:
elems->vht_capabilities = pos;
elems->vht_capabilities_len = elen;
break;
case WLAN_EID_VHT_OPERATION:
elems->vht_operation = pos;
elems->vht_operation_len = elen;
break;
case WLAN_EID_VHT_OP_MODE_NOTIFY:
elems->vht_op_mode_notify = pos;
elems->vht_op_mode_notify_len = elen;
break;
case _EID_RRM_EN_CAP_IE_:
elems->rm_en_cap = pos;
elems->rm_en_cap_len = elen;
break;
#ifdef CONFIG_RTW_MESH
case WLAN_EID_PREQ:
elems->preq = pos;
elems->preq_len = elen;
break;
case WLAN_EID_PREP:
elems->prep = pos;
elems->prep_len = elen;
break;
case WLAN_EID_PERR:
elems->perr = pos;
elems->perr_len = elen;
break;
case WLAN_EID_RANN:
elems->rann = pos;
elems->rann_len = elen;
break;
#endif
default:
unknown++;
if (!show_errors)
break;
RTW_DBG("IEEE 802.11 element parse "
"ignored unknown element (id=%d elen=%d)\n",
id, elen);
break;
}
left -= elen;
pos += elen;
}
if (left)
return ParseFailed;
return unknown ? ParseUnknown : ParseOK;
}
static u8 key_char2num(u8 ch);
static u8 key_char2num(u8 ch)
{
if ((ch >= '0') && (ch <= '9'))
return ch - '0';
else if ((ch >= 'a') && (ch <= 'f'))
return ch - 'a' + 10;
else if ((ch >= 'A') && (ch <= 'F'))
return ch - 'A' + 10;
else
return 0xff;
}
u8 str_2char2num(u8 hch, u8 lch);
u8 str_2char2num(u8 hch, u8 lch)
{
return (key_char2num(hch) * 10) + key_char2num(lch);
}
u8 key_2char2num(u8 hch, u8 lch);
u8 key_2char2num(u8 hch, u8 lch)
{
return (key_char2num(hch) << 4) | key_char2num(lch);
}
void macstr2num(u8 *dst, u8 *src);
void macstr2num(u8 *dst, u8 *src)
{
int jj, kk;
for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
dst[jj] = key_2char2num(src[kk], src[kk + 1]);
}
u8 convert_ip_addr(u8 hch, u8 mch, u8 lch)
{
return (key_char2num(hch) * 100) + (key_char2num(mch) * 10) + key_char2num(lch);
}
#ifdef CONFIG_PLATFORM_INTEL_BYT
#define MAC_ADDRESS_LEN 12
int rtw_get_mac_addr_intel(unsigned char *buf)
{
int ret = 0;
int i;
struct file *fp = NULL;
mm_segment_t oldfs;
unsigned char c_mac[MAC_ADDRESS_LEN];
char fname[] = "/config/wifi/mac.txt";
int jj, kk;
RTW_INFO("%s Enter\n", __FUNCTION__);
ret = rtw_retrieve_from_file(fname, c_mac, MAC_ADDRESS_LEN);
if (ret < MAC_ADDRESS_LEN)
return -1;
for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 2)
buf[jj] = key_2char2num(c_mac[kk], c_mac[kk + 1]);
RTW_INFO("%s: read from file mac address: "MAC_FMT"\n",
__FUNCTION__, MAC_ARG(buf));
return 0;
}
#endif /* CONFIG_PLATFORM_INTEL_BYT */
/*
* Description:
* rtw_check_invalid_mac_address:
* This is only used for checking mac address valid or not.
*
* Input:
* adapter: mac_address pointer.
* check_local_bit: check locally bit or not.
*
* Output:
* _TRUE: The mac address is invalid.
* _FALSE: The mac address is valid.
*
* Auther: Isaac.Li
*/
u8 rtw_check_invalid_mac_address(u8 *mac_addr, u8 check_local_bit)
{
u8 null_mac_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
u8 multi_mac_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 res = _FALSE;
if (_rtw_memcmp(mac_addr, null_mac_addr, ETH_ALEN)) {
res = _TRUE;
goto func_exit;
}
if (_rtw_memcmp(mac_addr, multi_mac_addr, ETH_ALEN)) {
res = _TRUE;
goto func_exit;
}
if (mac_addr[0] & BIT0) {
res = _TRUE;
goto func_exit;
}
if (check_local_bit == _TRUE) {
if (mac_addr[0] & BIT1) {
res = _TRUE;
goto func_exit;
}
}
func_exit:
return res;
}
extern char *rtw_initmac;
/**
* rtw_macaddr_cfg - Decide the mac address used
* @out: buf to store mac address decided
* @hw_mac_addr: mac address from efuse/epprom
*/
void rtw_macaddr_cfg(u8 *out, const u8 *hw_mac_addr)
{
#define DEFAULT_RANDOM_MACADDR 1
u8 mac[ETH_ALEN];
if (out == NULL) {
rtw_warn_on(1);
return;
}
/* Users specify the mac address */
if (rtw_initmac) {
int jj, kk;
for (jj = 0, kk = 0; jj < ETH_ALEN; jj++, kk += 3)
mac[jj] = key_2char2num(rtw_initmac[kk], rtw_initmac[kk + 1]);
goto err_chk;
}
/* platform specified */
#ifdef CONFIG_PLATFORM_INTEL_BYT
if (rtw_get_mac_addr_intel(mac) == 0)
goto err_chk;
#endif
/* Use the mac address stored in the Efuse */
if (hw_mac_addr) {
_rtw_memcpy(mac, hw_mac_addr, ETH_ALEN);
goto err_chk;
}
err_chk:
if (rtw_check_invalid_mac_address(mac, _TRUE) == _TRUE) {
#if DEFAULT_RANDOM_MACADDR
RTW_ERR("invalid mac addr:"MAC_FMT", assign random MAC\n", MAC_ARG(mac));
*((u32 *)(&mac[2])) = rtw_random32();
mac[0] = 0x00;
mac[1] = 0xe0;
mac[2] = 0x4c;
#else
RTW_ERR("invalid mac addr:"MAC_FMT", assign default one\n", MAC_ARG(mac));
mac[0] = 0x00;
mac[1] = 0xe0;
mac[2] = 0x4c;
mac[3] = 0x87;
mac[4] = 0x00;
mac[5] = 0x00;
#endif
}
_rtw_memcpy(out, mac, ETH_ALEN);
RTW_INFO("%s mac addr:"MAC_FMT"\n", __func__, MAC_ARG(out));
}
#ifdef CONFIG_80211N_HT
void dump_ht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len)
{
if (buf_len != HT_CAP_IE_LEN) {
RTW_PRINT_SEL(sel, "Invalid HT capability IE len:%d != %d\n", buf_len, HT_CAP_IE_LEN);
return;
}
RTW_PRINT_SEL(sel, "cap_info:%02x%02x:%s\n", *(buf), *(buf + 1)
, GET_HT_CAP_ELE_CHL_WIDTH(buf) ? " 40MHz" : " 20MHz");
RTW_PRINT_SEL(sel, "A-MPDU Parameters:"HT_AMPDU_PARA_FMT"\n"
, HT_AMPDU_PARA_ARG(HT_CAP_ELE_AMPDU_PARA(buf)));
RTW_PRINT_SEL(sel, "Supported MCS Set:"HT_SUP_MCS_SET_FMT"\n"
, HT_SUP_MCS_SET_ARG(HT_CAP_ELE_SUP_MCS_SET(buf)));
}
void dump_ht_cap_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *ht_cap_ie;
sint ht_cap_ielen;
ht_cap_ie = rtw_get_ie(ie, WLAN_EID_HT_CAP, &ht_cap_ielen, ie_len);
if (!ie || ht_cap_ie != ie)
return;
dump_ht_cap_ie_content(sel, ht_cap_ie + 2, ht_cap_ielen);
}
const char *const _ht_sc_offset_str[] = {
"SCN",
"SCA",
"SC-RSVD",
"SCB",
};
void dump_ht_op_ie_content(void *sel, const u8 *buf, u32 buf_len)
{
if (buf_len != HT_OP_IE_LEN) {
RTW_PRINT_SEL(sel, "Invalid HT operation IE len:%d != %d\n", buf_len, HT_OP_IE_LEN);
return;
}
RTW_PRINT_SEL(sel, "ch:%u%s %s\n"
, GET_HT_OP_ELE_PRI_CHL(buf)
, GET_HT_OP_ELE_STA_CHL_WIDTH(buf) ? "" : " 20MHz only"
, ht_sc_offset_str(GET_HT_OP_ELE_2ND_CHL_OFFSET(buf))
);
}
void dump_ht_op_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *ht_op_ie;
sint ht_op_ielen;
ht_op_ie = rtw_get_ie(ie, WLAN_EID_HT_OPERATION, &ht_op_ielen, ie_len);
if (!ie || ht_op_ie != ie)
return;
dump_ht_op_ie_content(sel, ht_op_ie + 2, ht_op_ielen);
}
#endif /* CONFIG_80211N_HT */
void dump_ies(void *sel, const u8 *buf, u32 buf_len)
{
const u8 *pos = buf;
u8 id, len;
while (pos - buf + 1 < buf_len) {
id = *pos;
len = *(pos + 1);
RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u\n", __FUNCTION__, id, len);
#ifdef CONFIG_80211N_HT
dump_ht_cap_ie(sel, pos, len + 2);
dump_ht_op_ie(sel, pos, len + 2);
#endif
#ifdef CONFIG_80211AC_VHT
dump_vht_cap_ie(sel, pos, len + 2);
dump_vht_op_ie(sel, pos, len + 2);
#endif
dump_wps_ie(sel, pos, len + 2);
#ifdef CONFIG_P2P
dump_p2p_ie(sel, pos, len + 2);
#ifdef CONFIG_WFD
dump_wfd_ie(sel, pos, len + 2);
#endif
#endif
pos += (2 + len);
}
}
void dump_wps_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *pos = ie;
u16 id;
u16 len;
const u8 *wps_ie;
uint wps_ielen;
wps_ie = rtw_get_wps_ie(ie, ie_len, NULL, &wps_ielen);
if (wps_ie != ie || wps_ielen == 0)
return;
pos += 6;
while (pos - ie + 4 <= ie_len) {
id = RTW_GET_BE16(pos);
len = RTW_GET_BE16(pos + 2);
RTW_PRINT_SEL(sel, "%s ID:0x%04x, LEN:%u%s\n", __func__, id, len
, ((pos - ie + 4 + len) <= ie_len) ? "" : "(exceed ie_len)");
pos += (4 + len);
}
}
/**
* rtw_ies_get_chbw - get operation ch, bw, offset from IEs of BSS.
* @ies: pointer of the first tlv IE
* @ies_len: length of @ies
* @ch: pointer of ch, used as output
* @bw: pointer of bw, used as output
* @offset: pointer of offset, used as output
* @ht: check HT IEs
* @vht: check VHT IEs, if true imply ht is true
*/
void rtw_ies_get_chbw(u8 *ies, int ies_len, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht)
{
u8 *p;
int ie_len;
*ch = 0;
*bw = CHANNEL_WIDTH_20;
*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
p = rtw_get_ie(ies, _DSSET_IE_, &ie_len, ies_len);
if (p && ie_len > 0)
*ch = *(p + 2);
#ifdef CONFIG_80211N_HT
if (ht || vht) {
u8 *ht_cap_ie, *ht_op_ie;
int ht_cap_ielen, ht_op_ielen;
ht_cap_ie = rtw_get_ie(ies, EID_HTCapability, &ht_cap_ielen, ies_len);
if (ht_cap_ie && ht_cap_ielen) {
if (GET_HT_CAP_ELE_CHL_WIDTH(ht_cap_ie + 2))
*bw = CHANNEL_WIDTH_40;
}
ht_op_ie = rtw_get_ie(ies, EID_HTInfo, &ht_op_ielen, ies_len);
if (ht_op_ie && ht_op_ielen) {
if (*ch == 0)
*ch = GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2);
else if (*ch != 0 && *ch != GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2)) {
RTW_INFO("%s ch inconsistent, DSSS:%u, HT primary:%u\n"
, __func__, *ch, GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2));
}
if (!GET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2))
*bw = CHANNEL_WIDTH_20;
if (*bw == CHANNEL_WIDTH_40) {
switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2)) {
case SCA:
*offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case SCB:
*offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
}
}
}
#ifdef CONFIG_80211AC_VHT
if (vht) {
u8 *vht_op_ie;
int vht_op_ielen;
vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
if (vht_op_ie && vht_op_ielen) {
if (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2) >= 1)
*bw = CHANNEL_WIDTH_80;
}
}
#endif /* CONFIG_80211AC_VHT */
}
#endif /* CONFIG_80211N_HT */
}
void rtw_bss_get_chbw(WLAN_BSSID_EX *bss, u8 *ch, u8 *bw, u8 *offset, u8 ht, u8 vht)
{
rtw_ies_get_chbw(bss->IEs + sizeof(NDIS_802_11_FIXED_IEs)
, bss->IELength - sizeof(NDIS_802_11_FIXED_IEs)
, ch, bw, offset, ht, vht);
if (*ch == 0)
*ch = bss->Configuration.DSConfig;
else if (*ch != bss->Configuration.DSConfig) {
RTW_INFO("inconsistent ch - ies:%u bss->Configuration.DSConfig:%u\n"
, *ch, bss->Configuration.DSConfig);
*ch = bss->Configuration.DSConfig;
rtw_warn_on(1);
}
}
/**
* rtw_is_chbw_grouped - test if the two ch settings can be grouped together
* @ch_a: ch of set a
* @bw_a: bw of set a
* @offset_a: offset of set a
* @ch_b: ch of set b
* @bw_b: bw of set b
* @offset_b: offset of set b
*/
bool rtw_is_chbw_grouped(u8 ch_a, u8 bw_a, u8 offset_a
, u8 ch_b, u8 bw_b, u8 offset_b)
{
bool is_grouped = _FALSE;
if (ch_a != ch_b) {
/* ch is different */
goto exit;
} else if ((bw_a == CHANNEL_WIDTH_40 || bw_a == CHANNEL_WIDTH_80)
&& (bw_b == CHANNEL_WIDTH_40 || bw_b == CHANNEL_WIDTH_80)
) {
if (offset_a != offset_b)
goto exit;
}
is_grouped = _TRUE;
exit:
return is_grouped;
}
/**
* rtw_sync_chbw - obey g_ch, adjust g_bw, g_offset, bw, offset
* @req_ch: pointer of the request ch, may be modified further
* @req_bw: pointer of the request bw, may be modified further
* @req_offset: pointer of the request offset, may be modified further
* @g_ch: pointer of the ongoing group ch
* @g_bw: pointer of the ongoing group bw, may be modified further
* @g_offset: pointer of the ongoing group offset, may be modified further
*/
void rtw_sync_chbw(u8 *req_ch, u8 *req_bw, u8 *req_offset
, u8 *g_ch, u8 *g_bw, u8 *g_offset)
{
*req_ch = *g_ch;
if (*req_bw == CHANNEL_WIDTH_80 && *g_ch <= 14) {
/*2.4G ch, downgrade to 40Mhz */
*req_bw = CHANNEL_WIDTH_40;
}
switch (*req_bw) {
case CHANNEL_WIDTH_80:
if (*g_bw == CHANNEL_WIDTH_40 || *g_bw == CHANNEL_WIDTH_80)
*req_offset = *g_offset;
else if (*g_bw == CHANNEL_WIDTH_20)
rtw_get_offset_by_chbw(*req_ch, *req_bw, req_offset);
if (*req_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
RTW_ERR("%s req 80MHz BW without offset, down to 20MHz\n", __func__);
rtw_warn_on(1);
*req_bw = CHANNEL_WIDTH_20;
}
break;
case CHANNEL_WIDTH_40:
if (*g_bw == CHANNEL_WIDTH_40 || *g_bw == CHANNEL_WIDTH_80)
*req_offset = *g_offset;
else if (*g_bw == CHANNEL_WIDTH_20)
rtw_get_offset_by_chbw(*req_ch, *req_bw, req_offset);
if (*req_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
RTW_ERR("%s req 40MHz BW without offset, down to 20MHz\n", __func__);
rtw_warn_on(1);
*req_bw = CHANNEL_WIDTH_20;
}
break;
case CHANNEL_WIDTH_20:
*req_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
break;
default:
RTW_ERR("%s req unsupported BW:%u\n", __func__, *req_bw);
rtw_warn_on(1);
}
if (*req_bw > *g_bw) {
*g_bw = *req_bw;
*g_offset = *req_offset;
}
}
/**
* rtw_get_p2p_merged_len - Get merged ie length from muitiple p2p ies.
* @in_ie: Pointer of the first p2p ie
* @in_len: Total len of muiltiple p2p ies
* Returns: Length of merged p2p ie length
*/
u32 rtw_get_p2p_merged_ies_len(u8 *in_ie, u32 in_len)
{
PNDIS_802_11_VARIABLE_IEs pIE;
u8 OUI[4] = { 0x50, 0x6f, 0x9a, 0x09 };
int i = 0;
int len = 0;
while (i < in_len) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie + i);
if (pIE->ElementID == _VENDOR_SPECIFIC_IE_ && _rtw_memcmp(pIE->data, OUI, 4)) {
len += pIE->Length - 4; /* 4 is P2P OUI length, don't count it in this loop */
}
i += (pIE->Length + 2);
}
return len + 4; /* Append P2P OUI length at last. */
}
/**
* rtw_p2p_merge_ies - Merge muitiple p2p ies into one
* @in_ie: Pointer of the first p2p ie
* @in_len: Total len of muiltiple p2p ies
* @merge_ie: Pointer of merged ie
* Returns: Length of merged p2p ie
*/
int rtw_p2p_merge_ies(u8 *in_ie, u32 in_len, u8 *merge_ie)
{
PNDIS_802_11_VARIABLE_IEs pIE;
u8 len = 0;
u8 OUI[4] = { 0x50, 0x6f, 0x9a, 0x09 };
u8 ELOUI[6] = { 0xDD, 0x00, 0x50, 0x6f, 0x9a, 0x09 }; /* EID;Len;OUI, Len would copy at the end of function */
int i = 0;
if (merge_ie != NULL) {
/* Set first P2P OUI */
_rtw_memcpy(merge_ie, ELOUI, 6);
merge_ie += 6;
while (i < in_len) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(in_ie + i);
/* Take out the rest of P2P OUIs */
if (pIE->ElementID == _VENDOR_SPECIFIC_IE_ && _rtw_memcmp(pIE->data, OUI, 4)) {
_rtw_memcpy(merge_ie, pIE->data + 4, pIE->Length - 4);
len += pIE->Length - 4;
merge_ie += pIE->Length - 4;
}
i += (pIE->Length + 2);
}
return len + 4; /* 4 is for P2P OUI */
}
return 0;
}
void dump_p2p_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *pos = ie;
u8 id;
u16 len;
const u8 *p2p_ie;
uint p2p_ielen;
p2p_ie = rtw_get_p2p_ie(ie, ie_len, NULL, &p2p_ielen);
if (p2p_ie != ie || p2p_ielen == 0)
return;
pos += 6;
while (pos - ie + 3 <= ie_len) {
id = *pos;
len = RTW_GET_LE16(pos + 1);
RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u%s\n", __func__, id, len
, ((pos - ie + 3 + len) <= ie_len) ? "" : "(exceed ie_len)");
pos += (3 + len);
}
}
/**
* rtw_get_p2p_ie - Search P2P IE from a series of IEs
* @in_ie: Address of IEs to search
* @in_len: Length limit from in_ie
* @p2p_ie: If not NULL and P2P IE is found, P2P IE will be copied to the buf starting from p2p_ie
* @p2p_ielen: If not NULL and P2P IE is found, will set to the length of the entire P2P IE
*
* Returns: The address of the P2P IE found, or NULL
*/
u8 *rtw_get_p2p_ie(const u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
{
uint cnt;
const u8 *p2p_ie_ptr = NULL;
u8 eid, p2p_oui[4] = {0x50, 0x6F, 0x9A, 0x09};
if (p2p_ielen)
*p2p_ielen = 0;
if (!in_ie || in_len < 0) {
rtw_warn_on(1);
return (u8 *)p2p_ie_ptr;
}
if (in_len <= 0)
return (u8 *)p2p_ie_ptr;
cnt = 0;
while (cnt + 1 + 4 < in_len) {
eid = in_ie[cnt];
if (cnt + 1 + 4 >= MAX_IE_SZ) {
rtw_warn_on(1);
return NULL;
}
if (eid == WLAN_EID_VENDOR_SPECIFIC && _rtw_memcmp(&in_ie[cnt + 2], p2p_oui, 4) == _TRUE) {
p2p_ie_ptr = in_ie + cnt;
if (p2p_ie)
_rtw_memcpy(p2p_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
if (p2p_ielen)
*p2p_ielen = in_ie[cnt + 1] + 2;
break;
} else
cnt += in_ie[cnt + 1] + 2;
}
return (u8 *)p2p_ie_ptr;
}
/**
* rtw_get_p2p_attr - Search a specific P2P attribute from a given P2P IE
* @p2p_ie: Address of P2P IE to search
* @p2p_ielen: Length limit from p2p_ie
* @target_attr_id: The attribute ID of P2P attribute to search
* @buf_attr: If not NULL and the P2P attribute is found, P2P attribute will be copied to the buf starting from buf_attr
* @len_attr: If not NULL and the P2P attribute is found, will set to the length of the entire P2P attribute
*
* Returns: the address of the specific WPS attribute found, or NULL
*/
u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id , u8 *buf_attr, u32 *len_attr)
{
u8 *attr_ptr = NULL;
u8 *target_attr_ptr = NULL;
u8 p2p_oui[4] = {0x50, 0x6F, 0x9A, 0x09};
if (len_attr)
*len_attr = 0;
if (!p2p_ie
|| p2p_ielen <= 6
|| (p2p_ie[0] != WLAN_EID_VENDOR_SPECIFIC)
|| (_rtw_memcmp(p2p_ie + 2, p2p_oui, 4) != _TRUE))
return attr_ptr;
/* 6 = 1(Element ID) + 1(Length) + 3 (OUI) + 1(OUI Type) */
attr_ptr = p2p_ie + 6; /* goto first attr */
while ((attr_ptr - p2p_ie + 3) <= p2p_ielen) {
/* 3 = 1(Attribute ID) + 2(Length) */
u8 attr_id = *attr_ptr;
u16 attr_data_len = RTW_GET_LE16(attr_ptr + 1);
u16 attr_len = attr_data_len + 3;
if (0)
RTW_INFO("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len);
if ((attr_ptr - p2p_ie + attr_len) > p2p_ielen)
break;
if (attr_id == target_attr_id) {
target_attr_ptr = attr_ptr;
if (buf_attr)
_rtw_memcpy(buf_attr, attr_ptr, attr_len);
if (len_attr)
*len_attr = attr_len;
break;
} else
attr_ptr += attr_len;
}
return target_attr_ptr;
}
/**
* rtw_get_p2p_attr_content - Search a specific P2P attribute content from a given P2P IE
* @p2p_ie: Address of P2P IE to search
* @p2p_ielen: Length limit from p2p_ie
* @target_attr_id: The attribute ID of P2P attribute to search
* @buf_content: If not NULL and the P2P attribute is found, P2P attribute content will be copied to the buf starting from buf_content
* @len_content: If not NULL and the P2P attribute is found, will set to the length of the P2P attribute content
*
* Returns: the address of the specific P2P attribute content found, or NULL
*/
u8 *rtw_get_p2p_attr_content(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id , u8 *buf_content, uint *len_content)
{
u8 *attr_ptr;
u32 attr_len;
if (len_content)
*len_content = 0;
attr_ptr = rtw_get_p2p_attr(p2p_ie, p2p_ielen, target_attr_id, NULL, &attr_len);
if (attr_ptr && attr_len) {
if (buf_content)
_rtw_memcpy(buf_content, attr_ptr + 3, attr_len - 3);
if (len_content)
*len_content = attr_len - 3;
return attr_ptr + 3;
}
return NULL;
}
u32 rtw_set_p2p_attr_content(u8 *pbuf, u8 attr_id, u16 attr_len, u8 *pdata_attr)
{
u32 a_len;
*pbuf = attr_id;
/* *(u16*)(pbuf + 1) = cpu_to_le16(attr_len); */
RTW_PUT_LE16(pbuf + 1, attr_len);
if (pdata_attr)
_rtw_memcpy(pbuf + 3, pdata_attr, attr_len);
a_len = attr_len + 3;
return a_len;
}
uint rtw_del_p2p_ie(u8 *ies, uint ies_len_ori, const char *msg)
{
#define DBG_DEL_P2P_IE 0
u8 *target_ie;
u32 target_ie_len;
uint ies_len = ies_len_ori;
int index = 0;
while (1) {
target_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &target_ie_len);
if (target_ie && target_ie_len) {
u8 *next_ie = target_ie + target_ie_len;
uint remain_len = ies_len - (next_ie - ies);
if (DBG_DEL_P2P_IE && msg) {
RTW_INFO("%s %d before\n", __func__, index);
dump_ies(RTW_DBGDUMP, ies, ies_len);
RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
RTW_INFO("target_ie:%p, target_ie_len:%u\n", target_ie, target_ie_len);
RTW_INFO("next_ie:%p, remain_len:%u\n", next_ie, remain_len);
}
_rtw_memmove(target_ie, next_ie, remain_len);
_rtw_memset(target_ie + remain_len, 0, target_ie_len);
ies_len -= target_ie_len;
if (DBG_DEL_P2P_IE && msg) {
RTW_INFO("%s %d after\n", __func__, index);
dump_ies(RTW_DBGDUMP, ies, ies_len);
}
index++;
} else
break;
}
return ies_len;
}
uint rtw_del_p2p_attr(u8 *ie, uint ielen_ori, u8 attr_id)
{
#define DBG_DEL_P2P_ATTR 0
u8 *target_attr;
u32 target_attr_len;
uint ielen = ielen_ori;
int index = 0;
while (1) {
target_attr = rtw_get_p2p_attr(ie, ielen, attr_id, NULL, &target_attr_len);
if (target_attr && target_attr_len) {
u8 *next_attr = target_attr + target_attr_len;
uint remain_len = ielen - (next_attr - ie);
if (DBG_DEL_P2P_ATTR) {
RTW_INFO("%s %d before\n", __func__, index);
dump_ies(RTW_DBGDUMP, ie, ielen);
RTW_INFO("ie:%p, ielen:%u\n", ie, ielen);
RTW_INFO("target_attr:%p, target_attr_len:%u\n", target_attr, target_attr_len);
RTW_INFO("next_attr:%p, remain_len:%u\n", next_attr, remain_len);
}
_rtw_memmove(target_attr, next_attr, remain_len);
_rtw_memset(target_attr + remain_len, 0, target_attr_len);
*(ie + 1) -= target_attr_len;
ielen -= target_attr_len;
if (DBG_DEL_P2P_ATTR) {
RTW_INFO("%s %d after\n", __func__, index);
dump_ies(RTW_DBGDUMP, ie, ielen);
}
index++;
} else
break;
}
return ielen;
}
inline u8 *rtw_bss_ex_get_p2p_ie(WLAN_BSSID_EX *bss_ex, u8 *p2p_ie, uint *p2p_ielen)
{
return rtw_get_p2p_ie(BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex), p2p_ie, p2p_ielen);
}
void rtw_bss_ex_del_p2p_ie(WLAN_BSSID_EX *bss_ex)
{
#define DBG_BSS_EX_DEL_P2P_IE 0
u8 *ies = BSS_EX_TLV_IES(bss_ex);
uint ies_len_ori = BSS_EX_TLV_IES_LEN(bss_ex);
uint ies_len;
ies_len = rtw_del_p2p_ie(ies, ies_len_ori, DBG_BSS_EX_DEL_P2P_IE ? __func__ : NULL);
bss_ex->IELength -= ies_len_ori - ies_len;
}
void rtw_bss_ex_del_p2p_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
{
#define DBG_BSS_EX_DEL_P2P_ATTR 0
u8 *ies = BSS_EX_TLV_IES(bss_ex);
uint ies_len = BSS_EX_TLV_IES_LEN(bss_ex);
u8 *ie;
uint ie_len, ie_len_ori;
int index = 0;
while (1) {
ie = rtw_get_p2p_ie(ies, ies_len, NULL, &ie_len_ori);
if (ie) {
u8 *next_ie_ori = ie + ie_len_ori;
uint remain_len = bss_ex->IELength - (next_ie_ori - bss_ex->IEs);
u8 has_target_attr = 0;
if (DBG_BSS_EX_DEL_P2P_ATTR) {
if (rtw_get_p2p_attr(ie, ie_len_ori, attr_id, NULL, NULL)) {
RTW_INFO("%s %d before\n", __func__, index);
dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
RTW_INFO("ie:%p, ie_len_ori:%u\n", ie, ie_len_ori);
RTW_INFO("next_ie_ori:%p, remain_len:%u\n", next_ie_ori, remain_len);
has_target_attr = 1;
}
}
ie_len = rtw_del_p2p_attr(ie, ie_len_ori, attr_id);
if (ie_len != ie_len_ori) {
u8 *next_ie = ie + ie_len;
_rtw_memmove(next_ie, next_ie_ori, remain_len);
_rtw_memset(next_ie + remain_len, 0, ie_len_ori - ie_len);
bss_ex->IELength -= ie_len_ori - ie_len;
ies = next_ie;
} else
ies = next_ie_ori;
if (DBG_BSS_EX_DEL_P2P_ATTR) {
if (has_target_attr) {
RTW_INFO("%s %d after\n", __func__, index);
dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
}
}
ies_len = remain_len;
index++;
} else
break;
}
}
void dump_wfd_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *pos = ie;
u8 id;
u16 len;
const u8 *wfd_ie;
uint wfd_ielen;
wfd_ie = rtw_get_wfd_ie(ie, ie_len, NULL, &wfd_ielen);
if (wfd_ie != ie || wfd_ielen == 0)
return;
pos += 6;
while (pos - ie + 3 <= ie_len) {
id = *pos;
len = RTW_GET_BE16(pos + 1);
RTW_PRINT_SEL(sel, "%s ID:%u, LEN:%u%s\n", __func__, id, len
, ((pos - ie + 3 + len) <= ie_len) ? "" : "(exceed ie_len)");
pos += (3 + len);
}
}
/**
* rtw_get_wfd_ie - Search WFD IE from a series of IEs
* @in_ie: Address of IEs to search
* @in_len: Length limit from in_ie
* @wfd_ie: If not NULL and WFD IE is found, WFD IE will be copied to the buf starting from wfd_ie
* @wfd_ielen: If not NULL and WFD IE is found, will set to the length of the entire WFD IE
*
* Returns: The address of the P2P IE found, or NULL
*/
u8 *rtw_get_wfd_ie(const u8 *in_ie, int in_len, u8 *wfd_ie, uint *wfd_ielen)
{
uint cnt;
const u8 *wfd_ie_ptr = NULL;
u8 eid, wfd_oui[4] = {0x50, 0x6F, 0x9A, 0x0A};
if (wfd_ielen)
*wfd_ielen = 0;
if (!in_ie || in_len < 0) {
rtw_warn_on(1);
return (u8 *)wfd_ie_ptr;
}
if (in_len <= 0)
return (u8 *)wfd_ie_ptr;
cnt = 0;
while (cnt + 1 + 4 < in_len) {
eid = in_ie[cnt];
if (cnt + 1 + 4 >= MAX_IE_SZ) {
rtw_warn_on(1);
return NULL;
}
if (eid == WLAN_EID_VENDOR_SPECIFIC && _rtw_memcmp(&in_ie[cnt + 2], wfd_oui, 4) == _TRUE) {
wfd_ie_ptr = in_ie + cnt;
if (wfd_ie)
_rtw_memcpy(wfd_ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
if (wfd_ielen)
*wfd_ielen = in_ie[cnt + 1] + 2;
break;
} else
cnt += in_ie[cnt + 1] + 2;
}
return (u8 *)wfd_ie_ptr;
}
/**
* rtw_get_wfd_attr - Search a specific WFD attribute from a given WFD IE
* @wfd_ie: Address of WFD IE to search
* @wfd_ielen: Length limit from wfd_ie
* @target_attr_id: The attribute ID of WFD attribute to search
* @buf_attr: If not NULL and the WFD attribute is found, WFD attribute will be copied to the buf starting from buf_attr
* @len_attr: If not NULL and the WFD attribute is found, will set to the length of the entire WFD attribute
*
* Returns: the address of the specific WPS attribute found, or NULL
*/
u8 *rtw_get_wfd_attr(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_attr, u32 *len_attr)
{
u8 *attr_ptr = NULL;
u8 *target_attr_ptr = NULL;
u8 wfd_oui[4] = {0x50, 0x6F, 0x9A, 0x0A};
if (len_attr)
*len_attr = 0;
if (!wfd_ie
|| wfd_ielen <= 6
|| (wfd_ie[0] != WLAN_EID_VENDOR_SPECIFIC)
|| (_rtw_memcmp(wfd_ie + 2, wfd_oui, 4) != _TRUE))
return attr_ptr;
/* 6 = 1(Element ID) + 1(Length) + 3 (OUI) + 1(OUI Type) */
attr_ptr = wfd_ie + 6; /* goto first attr */
while ((attr_ptr - wfd_ie + 3) <= wfd_ielen) {
/* 3 = 1(Attribute ID) + 2(Length) */
u8 attr_id = *attr_ptr;
u16 attr_data_len = RTW_GET_BE16(attr_ptr + 1);
u16 attr_len = attr_data_len + 3;
if (0)
RTW_INFO("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len);
if ((attr_ptr - wfd_ie + attr_len) > wfd_ielen)
break;
if (attr_id == target_attr_id) {
target_attr_ptr = attr_ptr;
if (buf_attr)
_rtw_memcpy(buf_attr, attr_ptr, attr_len);
if (len_attr)
*len_attr = attr_len;
break;
} else
attr_ptr += attr_len;
}
return target_attr_ptr;
}
/**
* rtw_get_wfd_attr_content - Search a specific WFD attribute content from a given WFD IE
* @wfd_ie: Address of WFD IE to search
* @wfd_ielen: Length limit from wfd_ie
* @target_attr_id: The attribute ID of WFD attribute to search
* @buf_content: If not NULL and the WFD attribute is found, WFD attribute content will be copied to the buf starting from buf_content
* @len_content: If not NULL and the WFD attribute is found, will set to the length of the WFD attribute content
*
* Returns: the address of the specific WFD attribute content found, or NULL
*/
u8 *rtw_get_wfd_attr_content(u8 *wfd_ie, uint wfd_ielen, u8 target_attr_id, u8 *buf_content, uint *len_content)
{
u8 *attr_ptr;
u32 attr_len;
if (len_content)
*len_content = 0;
attr_ptr = rtw_get_wfd_attr(wfd_ie, wfd_ielen, target_attr_id, NULL, &attr_len);
if (attr_ptr && attr_len) {
if (buf_content)
_rtw_memcpy(buf_content, attr_ptr + 3, attr_len - 3);
if (len_content)
*len_content = attr_len - 3;
return attr_ptr + 3;
}
return NULL;
}
uint rtw_del_wfd_ie(u8 *ies, uint ies_len_ori, const char *msg)
{
#define DBG_DEL_WFD_IE 0
u8 *target_ie;
u32 target_ie_len;
uint ies_len = ies_len_ori;
int index = 0;
while (1) {
target_ie = rtw_get_wfd_ie(ies, ies_len, NULL, &target_ie_len);
if (target_ie && target_ie_len) {
u8 *next_ie = target_ie + target_ie_len;
uint remain_len = ies_len - (next_ie - ies);
if (DBG_DEL_WFD_IE && msg) {
RTW_INFO("%s %d before\n", __func__, index);
dump_ies(RTW_DBGDUMP, ies, ies_len);
RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
RTW_INFO("target_ie:%p, target_ie_len:%u\n", target_ie, target_ie_len);
RTW_INFO("next_ie:%p, remain_len:%u\n", next_ie, remain_len);
}
_rtw_memmove(target_ie, next_ie, remain_len);
_rtw_memset(target_ie + remain_len, 0, target_ie_len);
ies_len -= target_ie_len;
if (DBG_DEL_WFD_IE && msg) {
RTW_INFO("%s %d after\n", __func__, index);
dump_ies(RTW_DBGDUMP, ies, ies_len);
}
index++;
} else
break;
}
return ies_len;
}
uint rtw_del_wfd_attr(u8 *ie, uint ielen_ori, u8 attr_id)
{
#define DBG_DEL_WFD_ATTR 0
u8 *target_attr;
u32 target_attr_len;
uint ielen = ielen_ori;
int index = 0;
while (1) {
target_attr = rtw_get_wfd_attr(ie, ielen, attr_id, NULL, &target_attr_len);
if (target_attr && target_attr_len) {
u8 *next_attr = target_attr + target_attr_len;
uint remain_len = ielen - (next_attr - ie);
if (DBG_DEL_WFD_ATTR) {
RTW_INFO("%s %d before\n", __func__, index);
dump_ies(RTW_DBGDUMP, ie, ielen);
RTW_INFO("ie:%p, ielen:%u\n", ie, ielen);
RTW_INFO("target_attr:%p, target_attr_len:%u\n", target_attr, target_attr_len);
RTW_INFO("next_attr:%p, remain_len:%u\n", next_attr, remain_len);
}
_rtw_memmove(target_attr, next_attr, remain_len);
_rtw_memset(target_attr + remain_len, 0, target_attr_len);
*(ie + 1) -= target_attr_len;
ielen -= target_attr_len;
if (DBG_DEL_WFD_ATTR) {
RTW_INFO("%s %d after\n", __func__, index);
dump_ies(RTW_DBGDUMP, ie, ielen);
}
index++;
} else
break;
}
return ielen;
}
inline u8 *rtw_bss_ex_get_wfd_ie(WLAN_BSSID_EX *bss_ex, u8 *wfd_ie, uint *wfd_ielen)
{
return rtw_get_wfd_ie(BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex), wfd_ie, wfd_ielen);
}
void rtw_bss_ex_del_wfd_ie(WLAN_BSSID_EX *bss_ex)
{
#define DBG_BSS_EX_DEL_WFD_IE 0
u8 *ies = BSS_EX_TLV_IES(bss_ex);
uint ies_len_ori = BSS_EX_TLV_IES_LEN(bss_ex);
uint ies_len;
ies_len = rtw_del_wfd_ie(ies, ies_len_ori, DBG_BSS_EX_DEL_WFD_IE ? __func__ : NULL);
bss_ex->IELength -= ies_len_ori - ies_len;
}
void rtw_bss_ex_del_wfd_attr(WLAN_BSSID_EX *bss_ex, u8 attr_id)
{
#define DBG_BSS_EX_DEL_WFD_ATTR 0
u8 *ies = BSS_EX_TLV_IES(bss_ex);
uint ies_len = BSS_EX_TLV_IES_LEN(bss_ex);
u8 *ie;
uint ie_len, ie_len_ori;
int index = 0;
while (1) {
ie = rtw_get_wfd_ie(ies, ies_len, NULL, &ie_len_ori);
if (ie) {
u8 *next_ie_ori = ie + ie_len_ori;
uint remain_len = bss_ex->IELength - (next_ie_ori - bss_ex->IEs);
u8 has_target_attr = 0;
if (DBG_BSS_EX_DEL_WFD_ATTR) {
if (rtw_get_wfd_attr(ie, ie_len_ori, attr_id, NULL, NULL)) {
RTW_INFO("%s %d before\n", __func__, index);
dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
RTW_INFO("ies:%p, ies_len:%u\n", ies, ies_len);
RTW_INFO("ie:%p, ie_len_ori:%u\n", ie, ie_len_ori);
RTW_INFO("next_ie_ori:%p, remain_len:%u\n", next_ie_ori, remain_len);
has_target_attr = 1;
}
}
ie_len = rtw_del_wfd_attr(ie, ie_len_ori, attr_id);
if (ie_len != ie_len_ori) {
u8 *next_ie = ie + ie_len;
_rtw_memmove(next_ie, next_ie_ori, remain_len);
_rtw_memset(next_ie + remain_len, 0, ie_len_ori - ie_len);
bss_ex->IELength -= ie_len_ori - ie_len;
ies = next_ie;
} else
ies = next_ie_ori;
if (DBG_BSS_EX_DEL_WFD_ATTR) {
if (has_target_attr) {
RTW_INFO("%s %d after\n", __func__, index);
dump_ies(RTW_DBGDUMP, BSS_EX_TLV_IES(bss_ex), BSS_EX_TLV_IES_LEN(bss_ex));
}
}
ies_len = remain_len;
index++;
} else
break;
}
}
/* Baron adds to avoid FreeBSD warning */
int ieee80211_is_empty_essid(const char *essid, int essid_len)
{
/* Single white space is for Linksys APs */
if (essid_len == 1 && essid[0] == ' ')
return 1;
/* Otherwise, if the entire essid is 0, we assume it is hidden */
while (essid_len) {
essid_len--;
if (essid[essid_len] != '\0')
return 0;
}
return 1;
}
int ieee80211_get_hdrlen(u16 fc)
{
int hdrlen = 24;
switch (WLAN_FC_GET_TYPE(fc)) {
case RTW_IEEE80211_FTYPE_DATA:
if (fc & RTW_IEEE80211_STYPE_QOS_DATA)
hdrlen += 2;
if ((fc & RTW_IEEE80211_FCTL_FROMDS) && (fc & RTW_IEEE80211_FCTL_TODS))
hdrlen += 6; /* Addr4 */
break;
case RTW_IEEE80211_FTYPE_CTL:
switch (WLAN_FC_GET_STYPE(fc)) {
case RTW_IEEE80211_STYPE_CTS:
case RTW_IEEE80211_STYPE_ACK:
hdrlen = 10;
break;
default:
hdrlen = 16;
break;
}
break;
}
return hdrlen;
}
u8 rtw_ht_mcsset_to_nss(u8 *supp_mcs_set)
{
u8 nss = 1;
if (supp_mcs_set[3])
nss = 4;
else if (supp_mcs_set[2])
nss = 3;
else if (supp_mcs_set[1])
nss = 2;
else if (supp_mcs_set[0])
nss = 1;
else
RTW_INFO("%s,%d, warning! supp_mcs_set is zero\n", __func__, __LINE__);
/* RTW_INFO("%s HT: %dSS\n", __FUNCTION__, nss); */
return nss;
}
u32 rtw_ht_mcs_set_to_bitmap(u8 *mcs_set, u8 nss)
{
u8 i;
u32 bitmap = 0;
for (i = 0; i < nss; i++)
bitmap |= mcs_set[i] << (i * 8);
RTW_INFO("ht_mcs_set=%02x %02x %02x %02x, nss=%u, bitmap=%08x\n"
, mcs_set[0], mcs_set[1], mcs_set[2], mcs_set[3], nss, bitmap);
return bitmap;
}
/* show MCS rate, unit: 100Kbps */
u16 rtw_mcs_rate(u8 rf_type, u8 bw_40MHz, u8 short_GI, unsigned char *MCS_rate)
{
u16 max_rate = 0;
if (MCS_rate[3]) {
if (MCS_rate[3] & BIT(7))
max_rate = (bw_40MHz) ? ((short_GI) ? 6000 : 5400) : ((short_GI) ? 2889 : 2600);
else if (MCS_rate[3] & BIT(6))
max_rate = (bw_40MHz) ? ((short_GI) ? 5400 : 4860) : ((short_GI) ? 2600 : 2340);
else if (MCS_rate[3] & BIT(5))
max_rate = (bw_40MHz) ? ((short_GI) ? 4800 : 4320) : ((short_GI) ? 2311 : 2080);
else if (MCS_rate[3] & BIT(4))
max_rate = (bw_40MHz) ? ((short_GI) ? 3600 : 3240) : ((short_GI) ? 1733 : 1560);
else if (MCS_rate[3] & BIT(3))
max_rate = (bw_40MHz) ? ((short_GI) ? 2400 : 2160) : ((short_GI) ? 1156 : 1040);
else if (MCS_rate[3] & BIT(2))
max_rate = (bw_40MHz) ? ((short_GI) ? 1800 : 1620) : ((short_GI) ? 867 : 780);
else if (MCS_rate[3] & BIT(1))
max_rate = (bw_40MHz) ? ((short_GI) ? 1200 : 1080) : ((short_GI) ? 578 : 520);
else if (MCS_rate[3] & BIT(0))
max_rate = (bw_40MHz) ? ((short_GI) ? 600 : 540) : ((short_GI) ? 289 : 260);
} else if (MCS_rate[2]) {
if (MCS_rate[2] & BIT(7))
max_rate = (bw_40MHz) ? ((short_GI) ? 4500 : 4050) : ((short_GI) ? 2167 : 1950);
else if (MCS_rate[2] & BIT(6))
max_rate = (bw_40MHz) ? ((short_GI) ? 4050 : 3645) : ((short_GI) ? 1950 : 1750);
else if (MCS_rate[2] & BIT(5))
max_rate = (bw_40MHz) ? ((short_GI) ? 3600 : 3240) : ((short_GI) ? 1733 : 1560);
else if (MCS_rate[2] & BIT(4))
max_rate = (bw_40MHz) ? ((short_GI) ? 2700 : 2430) : ((short_GI) ? 1300 : 1170);
else if (MCS_rate[2] & BIT(3))
max_rate = (bw_40MHz) ? ((short_GI) ? 1800 : 1620) : ((short_GI) ? 867 : 780);
else if (MCS_rate[2] & BIT(2))
max_rate = (bw_40MHz) ? ((short_GI) ? 1350 : 1215) : ((short_GI) ? 650 : 585);
else if (MCS_rate[2] & BIT(1))
max_rate = (bw_40MHz) ? ((short_GI) ? 900 : 810) : ((short_GI) ? 433 : 390);
else if (MCS_rate[2] & BIT(0))
max_rate = (bw_40MHz) ? ((short_GI) ? 450 : 405) : ((short_GI) ? 217 : 195);
} else if (MCS_rate[1]) {
if (MCS_rate[1] & BIT(7))
max_rate = (bw_40MHz) ? ((short_GI) ? 3000 : 2700) : ((short_GI) ? 1444 : 1300);
else if (MCS_rate[1] & BIT(6))
max_rate = (bw_40MHz) ? ((short_GI) ? 2700 : 2430) : ((short_GI) ? 1300 : 1170);
else if (MCS_rate[1] & BIT(5))
max_rate = (bw_40MHz) ? ((short_GI) ? 2400 : 2160) : ((short_GI) ? 1156 : 1040);
else if (MCS_rate[1] & BIT(4))
max_rate = (bw_40MHz) ? ((short_GI) ? 1800 : 1620) : ((short_GI) ? 867 : 780);
else if (MCS_rate[1] & BIT(3))
max_rate = (bw_40MHz) ? ((short_GI) ? 1200 : 1080) : ((short_GI) ? 578 : 520);
else if (MCS_rate[1] & BIT(2))
max_rate = (bw_40MHz) ? ((short_GI) ? 900 : 810) : ((short_GI) ? 433 : 390);
else if (MCS_rate[1] & BIT(1))
max_rate = (bw_40MHz) ? ((short_GI) ? 600 : 540) : ((short_GI) ? 289 : 260);
else if (MCS_rate[1] & BIT(0))
max_rate = (bw_40MHz) ? ((short_GI) ? 300 : 270) : ((short_GI) ? 144 : 130);
} else {
if (MCS_rate[0] & BIT(7))
max_rate = (bw_40MHz) ? ((short_GI) ? 1500 : 1350) : ((short_GI) ? 722 : 650);
else if (MCS_rate[0] & BIT(6))
max_rate = (bw_40MHz) ? ((short_GI) ? 1350 : 1215) : ((short_GI) ? 650 : 585);
else if (MCS_rate[0] & BIT(5))
max_rate = (bw_40MHz) ? ((short_GI) ? 1200 : 1080) : ((short_GI) ? 578 : 520);
else if (MCS_rate[0] & BIT(4))
max_rate = (bw_40MHz) ? ((short_GI) ? 900 : 810) : ((short_GI) ? 433 : 390);
else if (MCS_rate[0] & BIT(3))
max_rate = (bw_40MHz) ? ((short_GI) ? 600 : 540) : ((short_GI) ? 289 : 260);
else if (MCS_rate[0] & BIT(2))
max_rate = (bw_40MHz) ? ((short_GI) ? 450 : 405) : ((short_GI) ? 217 : 195);
else if (MCS_rate[0] & BIT(1))
max_rate = (bw_40MHz) ? ((short_GI) ? 300 : 270) : ((short_GI) ? 144 : 130);
else if (MCS_rate[0] & BIT(0))
max_rate = (bw_40MHz) ? ((short_GI) ? 150 : 135) : ((short_GI) ? 72 : 65);
}
return max_rate;
}
int rtw_action_frame_parse(const u8 *frame, u32 frame_len, u8 *category, u8 *action)
{
const u8 *frame_body = frame + sizeof(struct rtw_ieee80211_hdr_3addr);
u16 fc;
u8 c;
u8 a = ACT_PUBLIC_MAX;
fc = le16_to_cpu(((struct rtw_ieee80211_hdr_3addr *)frame)->frame_ctl);
if ((fc & (RTW_IEEE80211_FCTL_FTYPE | RTW_IEEE80211_FCTL_STYPE))
!= (RTW_IEEE80211_FTYPE_MGMT | RTW_IEEE80211_STYPE_ACTION)
)
return _FALSE;
c = frame_body[0];
switch (c) {
case RTW_WLAN_CATEGORY_P2P: /* vendor-specific */
break;
default:
a = frame_body[1];
}
if (category)
*category = c;
if (action)
*action = a;
return _TRUE;
}
static const char *_action_public_str[] = {
"ACT_PUB_BSSCOEXIST",
"ACT_PUB_DSE_ENABLE",
"ACT_PUB_DSE_DEENABLE",
"ACT_PUB_DSE_REG_LOCATION",
"ACT_PUB_EXT_CHL_SWITCH",
"ACT_PUB_DSE_MSR_REQ",
"ACT_PUB_DSE_MSR_RPRT",
"ACT_PUB_MP",
"ACT_PUB_DSE_PWR_CONSTRAINT",
"ACT_PUB_VENDOR",
"ACT_PUB_GAS_INITIAL_REQ",
"ACT_PUB_GAS_INITIAL_RSP",
"ACT_PUB_GAS_COMEBACK_REQ",
"ACT_PUB_GAS_COMEBACK_RSP",
"ACT_PUB_TDLS_DISCOVERY_RSP",
"ACT_PUB_LOCATION_TRACK",
"ACT_PUB_RSVD",
};
const char *action_public_str(u8 action)
{
action = (action >= ACT_PUBLIC_MAX) ? ACT_PUBLIC_MAX : action;
return _action_public_str[action];
}
================================================
FILE: core/rtw_io.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/*
The purpose of rtw_io.c
a. provides the API
b. provides the protocol engine
c. provides the software interface between caller and the hardware interface
Compiler Flag Option:
1. CONFIG_SDIO_HCI:
a. USE_SYNC_IRP: Only sync operations are provided.
b. USE_ASYNC_IRP:Both sync/async operations are provided.
2. CONFIG_USB_HCI:
a. USE_ASYNC_IRP: Both sync/async operations are provided.
3. CONFIG_CFIO_HCI:
b. USE_SYNC_IRP: Only sync operations are provided.
Only sync read/rtw_write_mem operations are provided.
jackson@realtek.com.tw
*/
#define _RTW_IO_C_
#include
#include
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_PLATFORM_RTL8197D)
#define rtw_le16_to_cpu(val) val
#define rtw_le32_to_cpu(val) val
#define rtw_cpu_to_le16(val) val
#define rtw_cpu_to_le32(val) val
#else
#define rtw_le16_to_cpu(val) le16_to_cpu(val)
#define rtw_le32_to_cpu(val) le32_to_cpu(val)
#define rtw_cpu_to_le16(val) cpu_to_le16(val)
#define rtw_cpu_to_le32(val) cpu_to_le32(val)
#endif
u8 _rtw_read8(_adapter *adapter, u32 addr)
{
u8 r_val;
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u8(*_read8)(struct intf_hdl *pintfhdl, u32 addr);
_read8 = pintfhdl->io_ops._read8;
r_val = _read8(pintfhdl, addr);
return r_val;
}
u16 _rtw_read16(_adapter *adapter, u32 addr)
{
u16 r_val;
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u16(*_read16)(struct intf_hdl *pintfhdl, u32 addr);
_read16 = pintfhdl->io_ops._read16;
r_val = _read16(pintfhdl, addr);
return rtw_le16_to_cpu(r_val);
}
u32 _rtw_read32(_adapter *adapter, u32 addr)
{
u32 r_val;
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u32(*_read32)(struct intf_hdl *pintfhdl, u32 addr);
_read32 = pintfhdl->io_ops._read32;
r_val = _read32(pintfhdl, addr);
return rtw_le32_to_cpu(r_val);
}
int _rtw_write8(_adapter *adapter, u32 addr, u8 val)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_write8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
int ret;
_write8 = pintfhdl->io_ops._write8;
ret = _write8(pintfhdl, addr, val);
return RTW_STATUS_CODE(ret);
}
int _rtw_write16(_adapter *adapter, u32 addr, u16 val)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_write16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
int ret;
_write16 = pintfhdl->io_ops._write16;
val = rtw_cpu_to_le16(val);
ret = _write16(pintfhdl, addr, val);
return RTW_STATUS_CODE(ret);
}
int _rtw_write32(_adapter *adapter, u32 addr, u32 val)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_write32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
int ret;
_write32 = pintfhdl->io_ops._write32;
val = rtw_cpu_to_le32(val);
ret = _write32(pintfhdl, addr, val);
return RTW_STATUS_CODE(ret);
}
int _rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *pdata)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = (struct intf_hdl *)(&(pio_priv->intf));
int (*_writeN)(struct intf_hdl *pintfhdl, u32 addr, u32 length, u8 *pdata);
int ret;
_writeN = pintfhdl->io_ops._writeN;
ret = _writeN(pintfhdl, addr, length, pdata);
return RTW_STATUS_CODE(ret);
}
#ifdef CONFIG_SDIO_HCI
u8 _rtw_sd_f0_read8(_adapter *adapter, u32 addr)
{
u8 r_val = 0x00;
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u8(*_sd_f0_read8)(struct intf_hdl *pintfhdl, u32 addr);
_sd_f0_read8 = pintfhdl->io_ops._sd_f0_read8;
if (_sd_f0_read8)
r_val = _sd_f0_read8(pintfhdl, addr);
else
RTW_WARN(FUNC_ADPT_FMT" _sd_f0_read8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return r_val;
}
#ifdef CONFIG_SDIO_INDIRECT_ACCESS
u8 _rtw_sd_iread8(_adapter *adapter, u32 addr)
{
u8 r_val = 0x00;
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u8(*_sd_iread8)(struct intf_hdl *pintfhdl, u32 addr);
_sd_iread8 = pintfhdl->io_ops._sd_iread8;
if (_sd_iread8)
r_val = _sd_iread8(pintfhdl, addr);
else
RTW_ERR(FUNC_ADPT_FMT" _sd_iread8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return r_val;
}
u16 _rtw_sd_iread16(_adapter *adapter, u32 addr)
{
u16 r_val = 0x00;
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u16(*_sd_iread16)(struct intf_hdl *pintfhdl, u32 addr);
_sd_iread16 = pintfhdl->io_ops._sd_iread16;
if (_sd_iread16)
r_val = _sd_iread16(pintfhdl, addr);
else
RTW_ERR(FUNC_ADPT_FMT" _sd_iread16 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return r_val;
}
u32 _rtw_sd_iread32(_adapter *adapter, u32 addr)
{
u32 r_val = 0x00;
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u32(*_sd_iread32)(struct intf_hdl *pintfhdl, u32 addr);
_sd_iread32 = pintfhdl->io_ops._sd_iread32;
if (_sd_iread32)
r_val = _sd_iread32(pintfhdl, addr);
else
RTW_ERR(FUNC_ADPT_FMT" _sd_iread32 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return r_val;
}
int _rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val)
{
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_sd_iwrite8)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
int ret = -1;
_sd_iwrite8 = pintfhdl->io_ops._sd_iwrite8;
if (_sd_iwrite8)
ret = _sd_iwrite8(pintfhdl, addr, val);
else
RTW_ERR(FUNC_ADPT_FMT" _sd_iwrite8 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return RTW_STATUS_CODE(ret);
}
int _rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val)
{
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_sd_iwrite16)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
int ret = -1;
_sd_iwrite16 = pintfhdl->io_ops._sd_iwrite16;
if (_sd_iwrite16)
ret = _sd_iwrite16(pintfhdl, addr, val);
else
RTW_ERR(FUNC_ADPT_FMT" _sd_iwrite16 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return RTW_STATUS_CODE(ret);
}
int _rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val)
{
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_sd_iwrite32)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
int ret = -1;
_sd_iwrite32 = pintfhdl->io_ops._sd_iwrite32;
if (_sd_iwrite32)
ret = _sd_iwrite32(pintfhdl, addr, val);
else
RTW_ERR(FUNC_ADPT_FMT" _sd_iwrite32 callback is NULL\n", FUNC_ADPT_ARG(adapter));
return RTW_STATUS_CODE(ret);
}
#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
#endif /* CONFIG_SDIO_HCI */
int _rtw_write8_async(_adapter *adapter, u32 addr, u8 val)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_write8_async)(struct intf_hdl *pintfhdl, u32 addr, u8 val);
int ret;
_write8_async = pintfhdl->io_ops._write8_async;
ret = _write8_async(pintfhdl, addr, val);
return RTW_STATUS_CODE(ret);
}
int _rtw_write16_async(_adapter *adapter, u32 addr, u16 val)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_write16_async)(struct intf_hdl *pintfhdl, u32 addr, u16 val);
int ret;
_write16_async = pintfhdl->io_ops._write16_async;
val = rtw_cpu_to_le16(val);
ret = _write16_async(pintfhdl, addr, val);
return RTW_STATUS_CODE(ret);
}
int _rtw_write32_async(_adapter *adapter, u32 addr, u32 val)
{
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
int (*_write32_async)(struct intf_hdl *pintfhdl, u32 addr, u32 val);
int ret;
_write32_async = pintfhdl->io_ops._write32_async;
val = rtw_cpu_to_le32(val);
ret = _write32_async(pintfhdl, addr, val);
return RTW_STATUS_CODE(ret);
}
void _rtw_read_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
{
void (*_read_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
if (RTW_CANNOT_RUN(adapter)) {
return;
}
_read_mem = pintfhdl->io_ops._read_mem;
_read_mem(pintfhdl, addr, cnt, pmem);
}
void _rtw_write_mem(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
{
void (*_write_mem)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
_write_mem = pintfhdl->io_ops._write_mem;
_write_mem(pintfhdl, addr, cnt, pmem);
}
void _rtw_read_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
{
u32(*_read_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
if (RTW_CANNOT_RUN(adapter)) {
return;
}
_read_port = pintfhdl->io_ops._read_port;
_read_port(pintfhdl, addr, cnt, pmem);
}
void _rtw_read_port_cancel(_adapter *adapter)
{
void (*_read_port_cancel)(struct intf_hdl *pintfhdl);
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
_read_port_cancel = pintfhdl->io_ops._read_port_cancel;
RTW_DISABLE_FUNC(adapter, DF_RX_BIT);
if (_read_port_cancel)
_read_port_cancel(pintfhdl);
}
u32 _rtw_write_port(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem)
{
u32(*_write_port)(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
/* struct io_queue *pio_queue = (struct io_queue *)adapter->pio_queue; */
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
u32 ret = _SUCCESS;
_write_port = pintfhdl->io_ops._write_port;
ret = _write_port(pintfhdl, addr, cnt, pmem);
return ret;
}
u32 _rtw_write_port_and_wait(_adapter *adapter, u32 addr, u32 cnt, u8 *pmem, int timeout_ms)
{
int ret = _SUCCESS;
struct xmit_buf *pxmitbuf = (struct xmit_buf *)pmem;
struct submit_ctx sctx;
rtw_sctx_init(&sctx, timeout_ms);
pxmitbuf->sctx = &sctx;
ret = _rtw_write_port(adapter, addr, cnt, pmem);
if (ret == _SUCCESS) {
ret = rtw_sctx_wait(&sctx, __func__);
if (ret != _SUCCESS)
pxmitbuf->sctx = NULL;
}
return ret;
}
void _rtw_write_port_cancel(_adapter *adapter)
{
void (*_write_port_cancel)(struct intf_hdl *pintfhdl);
struct io_priv *pio_priv = &adapter->iopriv;
struct intf_hdl *pintfhdl = &(pio_priv->intf);
_write_port_cancel = pintfhdl->io_ops._write_port_cancel;
RTW_DISABLE_FUNC(adapter, DF_TX_BIT);
if (_write_port_cancel)
_write_port_cancel(pintfhdl);
}
int rtw_init_io_priv(_adapter *padapter, void (*set_intf_ops)(_adapter *padapter, struct _io_ops *pops))
{
struct io_priv *piopriv = &padapter->iopriv;
struct intf_hdl *pintf = &piopriv->intf;
if (set_intf_ops == NULL)
return _FAIL;
piopriv->padapter = padapter;
pintf->padapter = padapter;
pintf->pintf_dev = adapter_to_dvobj(padapter);
set_intf_ops(padapter, &pintf->io_ops);
return _SUCCESS;
}
/*
* Increase and check if the continual_io_error of this @param dvobjprive is larger than MAX_CONTINUAL_IO_ERR
* @return _TRUE:
* @return _FALSE:
*/
int rtw_inc_and_chk_continual_io_error(struct dvobj_priv *dvobj)
{
int ret = _FALSE;
int value;
value = ATOMIC_INC_RETURN(&dvobj->continual_io_error);
if (value > MAX_CONTINUAL_IO_ERR) {
RTW_INFO("[dvobj:%p][ERROR] continual_io_error:%d > %d\n", dvobj, value, MAX_CONTINUAL_IO_ERR);
ret = _TRUE;
} else {
/* RTW_INFO("[dvobj:%p] continual_io_error:%d\n", dvobj, value); */
}
return ret;
}
/*
* Set the continual_io_error of this @param dvobjprive to 0
*/
void rtw_reset_continual_io_error(struct dvobj_priv *dvobj)
{
ATOMIC_SET(&dvobj->continual_io_error, 0);
}
#ifdef DBG_IO
#define RTW_IO_SNIFF_TYPE_RANGE 0 /* specific address range is accessed */
#define RTW_IO_SNIFF_TYPE_VALUE 1 /* value match for sniffed range */
struct rtw_io_sniff_ent {
u8 chip;
u8 hci;
u32 addr;
u8 type;
union {
u32 end_addr;
struct {
u32 mask;
u32 val;
bool equal;
} vm; /* value match */
} u;
bool trace;
char *tag;
};
#define RTW_IO_SNIFF_RANGE_ENT(_chip, _hci, _addr, _end_addr, _trace, _tag) \
{.chip = _chip, .hci = _hci, .addr = _addr, .u.end_addr = _end_addr, .trace = _trace, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_RANGE,}
#define RTW_IO_SNIFF_VALUE_ENT(_chip, _hci, _addr, _mask, _val, _equal, _trace, _tag) \
{.chip = _chip, .hci = _hci, .addr = _addr, .u.vm.mask = _mask, .u.vm.val = _val, .u.vm.equal = _equal, .trace = _trace, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_VALUE,}
/* part or all sniffed range is enabled (not all 0) */
#define RTW_IO_SNIFF_EN_ENT(_chip, _hci, _addr, _mask, _trace, _tag) \
{.chip = _chip, .hci = _hci, .addr = _addr, .u.vm.mask = _mask, .u.vm.val = 0, .u.vm.equal = 0, .trace = _trace, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_VALUE,}
/* part or all sniffed range is disabled (not all 1) */
#define RTW_IO_SNIFF_DIS_ENT(_chip, _hci, _addr, _mask, _trace, _tag) \
{.chip = _chip, .hci = _hci, .addr = _addr, .u.vm.mask = _mask, .u.vm.val = 0xFFFFFFFF, .u.vm.equal = 0, .trace = _trace, .tag = _tag, .type = RTW_IO_SNIFF_TYPE_VALUE,}
const struct rtw_io_sniff_ent read_sniff[] = {
#ifdef DBG_IO_HCI_EN_CHK
RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_SDIO, 0x02, 0x1FC, 1, "SDIO 0x02[8:2] not all 0"),
RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_USB, 0x02, 0x1E0, 1, "USB 0x02[8:5] not all 0"),
RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_PCIE, 0x02, 0x01C, 1, "PCI 0x02[4:2] not all 0"),
#endif
#ifdef DBG_IO_SNIFF_EXAMPLE
RTW_IO_SNIFF_RANGE_ENT(MAX_CHIP_TYPE, 0, 0x522, 0x522, 0, "read TXPAUSE"),
RTW_IO_SNIFF_DIS_ENT(MAX_CHIP_TYPE, 0, 0x02, 0x3, 0, "0x02[1:0] not all 1"),
#endif
};
const int read_sniff_num = sizeof(read_sniff) / sizeof(struct rtw_io_sniff_ent);
const struct rtw_io_sniff_ent write_sniff[] = {
#ifdef DBG_IO_HCI_EN_CHK
RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_SDIO, 0x02, 0x1FC, 1, "SDIO 0x02[8:2] not all 0"),
RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_USB, 0x02, 0x1E0, 1, "USB 0x02[8:5] not all 0"),
RTW_IO_SNIFF_EN_ENT(MAX_CHIP_TYPE, RTW_PCIE, 0x02, 0x01C, 1, "PCI 0x02[4:2] not all 0"),
#endif
#ifdef DBG_IO_8822C_1TX_PATH_EN
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x1a04, 0xc0000000, 0x02, 1, 0, "write tx_path_en_cck A enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x1a04, 0xc0000000, 0x01, 1, 0, "write tx_path_en_cck B enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x1a04, 0xc0000000, 0x03, 1, 1, "write tx_path_en_cck AB enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x820, 0x03, 0x01, 1, 0, "write tx_path_en_ofdm_1sts A enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x820, 0x03, 0x02, 1, 0, "write tx_path_en_ofdm_1sts B enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x820, 0x03, 0x03, 1, 1, "write tx_path_en_ofdm_1sts AB enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x820, 0x30, 0x01, 1, 0, "write tx_path_en_ofdm_2sts A enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x820, 0x30, 0x02, 1, 0, "write tx_path_en_ofdm_2sts B enabled"),
RTW_IO_SNIFF_VALUE_ENT(RTL8822C, 0, 0x820, 0x30, 0x03, 1, 1, "write tx_path_en_ofdm_2sts AB enabled"),
#endif
#ifdef DBG_IO_SNIFF_EXAMPLE
RTW_IO_SNIFF_RANGE_ENT(MAX_CHIP_TYPE, 0, 0x522, 0x522, 0, "write TXPAUSE"),
RTW_IO_SNIFF_DIS_ENT(MAX_CHIP_TYPE, 0, 0x02, 0x3, 0, "0x02[1:0] not all 1"),
#endif
};
const int write_sniff_num = sizeof(write_sniff) / sizeof(struct rtw_io_sniff_ent);
static bool match_io_sniff_ranges(_adapter *adapter
, const struct rtw_io_sniff_ent *sniff, int i, u32 addr, u16 len)
{
/* check if IO range after sniff end address */
if (addr > sniff->u.end_addr)
return 0;
return 1;
}
static bool match_io_sniff_value(_adapter *adapter
, const struct rtw_io_sniff_ent *sniff, int i, u32 addr, u8 len, u32 val)
{
u8 sniff_len;
s8 mask_shift;
u32 mask;
s8 value_shift;
u32 value;
bool ret = 0;
/* check if IO range after sniff end address */
sniff_len = 4;
while (!(sniff->u.vm.mask & (0xFF << ((sniff_len - 1) * 8)))) {
sniff_len--;
if (sniff_len == 0)
goto exit;
}
if (sniff->addr + sniff_len <= addr)
goto exit;
/* align to IO addr */
mask_shift = (sniff->addr - addr) * 8;
value_shift = mask_shift + bitshift(sniff->u.vm.mask);
if (mask_shift > 0)
mask = sniff->u.vm.mask << mask_shift;
else if (mask_shift < 0)
mask = sniff->u.vm.mask >> -mask_shift;
else
mask = sniff->u.vm.mask;
if (value_shift > 0)
value = sniff->u.vm.val << value_shift;
else if (mask_shift < 0)
value = sniff->u.vm.val >> -value_shift;
else
value = sniff->u.vm.val;
if ((sniff->u.vm.equal && (mask & val) == (mask & value))
|| (!sniff->u.vm.equal && (mask & val) != (mask & value))
) {
ret = 1;
if (0)
RTW_INFO(FUNC_ADPT_FMT" addr:0x%x len:%u val:0x%x (i:%d sniff_len:%u m_shift:%d mask:0x%x v_shifd:%d value:0x%x equal:%d)\n"
, FUNC_ADPT_ARG(adapter), addr, len, val, i, sniff_len, mask_shift, mask, value_shift, value, sniff->u.vm.equal);
}
exit:
return ret;
}
static bool match_io_sniff(_adapter *adapter
, const struct rtw_io_sniff_ent *sniff, int i, u32 addr, u8 len, u32 val)
{
bool ret = 0;
if (sniff->chip != MAX_CHIP_TYPE
&& sniff->chip != rtw_get_chip_type(adapter))
goto exit;
if (sniff->hci
&& !(sniff->hci & rtw_get_intf_type(adapter)))
goto exit;
if (sniff->addr >= addr + len) /* IO range below sniff start address */
goto exit;
switch (sniff->type) {
case RTW_IO_SNIFF_TYPE_RANGE:
ret = match_io_sniff_ranges(adapter, sniff, i, addr, len);
break;
case RTW_IO_SNIFF_TYPE_VALUE:
if (len == 1 || len == 2 || len == 4)
ret = match_io_sniff_value(adapter, sniff, i, addr, len, val);
break;
default:
rtw_warn_on(1);
break;
}
exit:
return ret;
}
u32 match_read_sniff(_adapter *adapter, u32 addr, u16 len, u32 val)
{
int i;
bool trace = 0;
u32 match = 0;
for (i = 0; i < read_sniff_num; i++) {
if (match_io_sniff(adapter, &read_sniff[i], i, addr, len, val)) {
match++;
trace |= read_sniff[i].trace;
if (read_sniff[i].tag)
RTW_INFO("DBG_IO TAG %s\n", read_sniff[i].tag);
}
}
rtw_warn_on(trace);
return match;
}
u32 match_write_sniff(_adapter *adapter, u32 addr, u16 len, u32 val)
{
int i;
bool trace = 0;
u32 match = 0;
for (i = 0; i < write_sniff_num; i++) {
if (match_io_sniff(adapter, &write_sniff[i], i, addr, len, val)) {
match++;
trace |= write_sniff[i].trace;
if (write_sniff[i].tag)
RTW_INFO("DBG_IO TAG %s\n", write_sniff[i].tag);
}
}
rtw_warn_on(trace);
return match;
}
struct rf_sniff_ent {
u8 path;
u16 reg;
u32 mask;
};
struct rf_sniff_ent rf_read_sniff_ranges[] = {
/* example for all path addr 0x55 with all RF Reg mask */
/* {MAX_RF_PATH, 0x55, bRFRegOffsetMask}, */
};
struct rf_sniff_ent rf_write_sniff_ranges[] = {
/* example for all path addr 0x55 with all RF Reg mask */
/* {MAX_RF_PATH, 0x55, bRFRegOffsetMask}, */
};
int rf_read_sniff_num = sizeof(rf_read_sniff_ranges) / sizeof(struct rf_sniff_ent);
int rf_write_sniff_num = sizeof(rf_write_sniff_ranges) / sizeof(struct rf_sniff_ent);
bool match_rf_read_sniff_ranges(_adapter *adapter, u8 path, u32 addr, u32 mask)
{
int i;
for (i = 0; i < rf_read_sniff_num; i++) {
if (rf_read_sniff_ranges[i].path == MAX_RF_PATH || rf_read_sniff_ranges[i].path == path)
if (addr == rf_read_sniff_ranges[i].reg && (mask & rf_read_sniff_ranges[i].mask))
return _TRUE;
}
return _FALSE;
}
bool match_rf_write_sniff_ranges(_adapter *adapter, u8 path, u32 addr, u32 mask)
{
int i;
for (i = 0; i < rf_write_sniff_num; i++) {
if (rf_write_sniff_ranges[i].path == MAX_RF_PATH || rf_write_sniff_ranges[i].path == path)
if (addr == rf_write_sniff_ranges[i].reg && (mask & rf_write_sniff_ranges[i].mask))
return _TRUE;
}
return _FALSE;
}
u8 dbg_rtw_read8(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u8 val = _rtw_read8(adapter, addr);
if (match_read_sniff(adapter, addr, 1, val)) {
RTW_INFO("DBG_IO %s:%d rtw_read8(0x%04x) return 0x%02x\n"
, caller, line, addr, val);
}
return val;
}
u16 dbg_rtw_read16(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u16 val = _rtw_read16(adapter, addr);
if (match_read_sniff(adapter, addr, 2, val)) {
RTW_INFO("DBG_IO %s:%d rtw_read16(0x%04x) return 0x%04x\n"
, caller, line, addr, val);
}
return val;
}
u32 dbg_rtw_read32(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u32 val = _rtw_read32(adapter, addr);
if (match_read_sniff(adapter, addr, 4, val)) {
RTW_INFO("DBG_IO %s:%d rtw_read32(0x%04x) return 0x%08x\n"
, caller, line, addr, val);
}
return val;
}
int dbg_rtw_write8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, 1, val)) {
RTW_INFO("DBG_IO %s:%d rtw_write8(0x%04x, 0x%02x)\n"
, caller, line, addr, val);
}
return _rtw_write8(adapter, addr, val);
}
int dbg_rtw_write16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, 2, val)) {
RTW_INFO("DBG_IO %s:%d rtw_write16(0x%04x, 0x%04x)\n"
, caller, line, addr, val);
}
return _rtw_write16(adapter, addr, val);
}
int dbg_rtw_write32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, 4, val)) {
RTW_INFO("DBG_IO %s:%d rtw_write32(0x%04x, 0x%08x)\n"
, caller, line, addr, val);
}
return _rtw_write32(adapter, addr, val);
}
int dbg_rtw_writeN(_adapter *adapter, u32 addr , u32 length , u8 *data, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, length, 0)) {
RTW_INFO("DBG_IO %s:%d rtw_writeN(0x%04x, %u)\n"
, caller, line, addr, length);
}
return _rtw_writeN(adapter, addr, length, data);
}
#ifdef CONFIG_SDIO_HCI
u8 dbg_rtw_sd_f0_read8(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u8 val = _rtw_sd_f0_read8(adapter, addr);
#if 0
if (match_read_sniff(adapter, addr, 1, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_f0_read8(0x%04x) return 0x%02x\n"
, caller, line, addr, val);
}
#endif
return val;
}
#ifdef CONFIG_SDIO_INDIRECT_ACCESS
u8 dbg_rtw_sd_iread8(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u8 val = rtw_sd_iread8(adapter, addr);
if (match_read_sniff(adapter, addr, 1, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_iread8(0x%04x) return 0x%02x\n"
, caller, line, addr, val);
}
return val;
}
u16 dbg_rtw_sd_iread16(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u16 val = _rtw_sd_iread16(adapter, addr);
if (match_read_sniff(adapter, addr, 2, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_iread16(0x%04x) return 0x%04x\n"
, caller, line, addr, val);
}
return val;
}
u32 dbg_rtw_sd_iread32(_adapter *adapter, u32 addr, const char *caller, const int line)
{
u32 val = _rtw_sd_iread32(adapter, addr);
if (match_read_sniff(adapter, addr, 4, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_iread32(0x%04x) return 0x%08x\n"
, caller, line, addr, val);
}
return val;
}
int dbg_rtw_sd_iwrite8(_adapter *adapter, u32 addr, u8 val, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, 1, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite8(0x%04x, 0x%02x)\n"
, caller, line, addr, val);
}
return _rtw_sd_iwrite8(adapter, addr, val);
}
int dbg_rtw_sd_iwrite16(_adapter *adapter, u32 addr, u16 val, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, 2, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite16(0x%04x, 0x%04x)\n"
, caller, line, addr, val);
}
return _rtw_sd_iwrite16(adapter, addr, val);
}
int dbg_rtw_sd_iwrite32(_adapter *adapter, u32 addr, u32 val, const char *caller, const int line)
{
if (match_write_sniff(adapter, addr, 4, val)) {
RTW_INFO("DBG_IO %s:%d rtw_sd_iwrite32(0x%04x, 0x%08x)\n"
, caller, line, addr, val);
}
return _rtw_sd_iwrite32(adapter, addr, val);
}
#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
#endif /* CONFIG_SDIO_HCI */
#endif
================================================
FILE: core/rtw_ioctl_query.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_IOCTL_QUERY_C_
#include
================================================
FILE: core/rtw_ioctl_set.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_IOCTL_SET_C_
#include
#include
extern void indicate_wx_scan_complete_event(_adapter *padapter);
#define IS_MAC_ADDRESS_BROADCAST(addr) \
(\
((addr[0] == 0xff) && (addr[1] == 0xff) && \
(addr[2] == 0xff) && (addr[3] == 0xff) && \
(addr[4] == 0xff) && (addr[5] == 0xff)) ? _TRUE : _FALSE \
)
u8 rtw_validate_bssid(u8 *bssid)
{
u8 ret = _TRUE;
if (is_zero_mac_addr(bssid)
|| is_broadcast_mac_addr(bssid)
|| is_multicast_mac_addr(bssid)
)
ret = _FALSE;
return ret;
}
u8 rtw_validate_ssid(NDIS_802_11_SSID *ssid)
{
#ifdef CONFIG_VALIDATE_SSID
u8 i;
#endif
u8 ret = _TRUE;
if (ssid->SsidLength > 32) {
ret = _FALSE;
goto exit;
}
#ifdef CONFIG_VALIDATE_SSID
for (i = 0; i < ssid->SsidLength; i++) {
/* wifi, printable ascii code must be supported */
if (!((ssid->Ssid[i] >= 0x20) && (ssid->Ssid[i] <= 0x7e))) {
ret = _FALSE;
break;
}
}
#endif /* CONFIG_VALIDATE_SSID */
exit:
return ret;
}
u8 rtw_do_join(_adapter *padapter);
u8 rtw_do_join(_adapter *padapter)
{
_irqL irqL;
_list *plist, *phead;
u8 *pibss = NULL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct sitesurvey_parm parm;
_queue *queue = &(pmlmepriv->scanned_queue);
u8 ret = _SUCCESS;
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
pmlmepriv->cur_network.join_res = -2;
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
pmlmepriv->pscanned = plist;
pmlmepriv->to_join = _TRUE;
rtw_init_sitesurvey_parm(padapter, &parm);
_rtw_memcpy(&parm.ssid[0], &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
parm.ssid_num = 1;
if (pmlmepriv->assoc_ch) {
parm.ch_num = 1;
parm.ch[0].hw_value = pmlmepriv->assoc_ch;
parm.ch[0].flags = 0;
}
if (_rtw_queue_empty(queue) == _TRUE) {
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
/* when set_ssid/set_bssid for rtw_do_join(), but scanning queue is empty */
/* we try to issue sitesurvey firstly */
if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE
|| rtw_to_roam(padapter) > 0
) {
u8 ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
if ((ssc_chk == SS_ALLOW) || (ssc_chk == SS_DENY_BUSY_TRAFFIC) ){
/* submit site_survey_cmd */
ret = rtw_sitesurvey_cmd(padapter, &parm);
if (_SUCCESS != ret)
pmlmepriv->to_join = _FALSE;
} else {
/*if (ssc_chk == SS_DENY_BUDDY_UNDER_SURVEY)*/
pmlmepriv->to_join = _FALSE;
ret = _FAIL;
}
} else {
pmlmepriv->to_join = _FALSE;
ret = _FAIL;
}
goto exit;
} else {
int select_ret;
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
select_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
if (select_ret == _SUCCESS) {
pmlmepriv->to_join = _FALSE;
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
} else {
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
/* submit createbss_cmd to change to a ADHOC_MASTER */
/* pmlmepriv->lock has been acquired by caller... */
WLAN_BSSID_EX *pdev_network = &(padapter->registrypriv.dev_network);
/*pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;*/
init_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
pibss = padapter->registrypriv.dev_network.MacAddress;
_rtw_memset(&pdev_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
_rtw_memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
rtw_update_registrypriv_dev_network(padapter);
rtw_generate_random_ibss(pibss);
if (rtw_create_ibss_cmd(padapter, 0) != _SUCCESS) {
ret = _FALSE;
goto exit;
}
pmlmepriv->to_join = _FALSE;
} else {
/* can't associate ; reset under-linking */
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
/* when set_ssid/set_bssid for rtw_do_join(), but there are no desired bss in scanning queue */
/* we try to issue sitesurvey firstly */
if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE
|| rtw_to_roam(padapter) > 0
) {
u8 ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
if ((ssc_chk == SS_ALLOW) || (ssc_chk == SS_DENY_BUSY_TRAFFIC)){
/* RTW_INFO(("rtw_do_join() when no desired bss in scanning queue\n"); */
ret = rtw_sitesurvey_cmd(padapter, &parm);
if (_SUCCESS != ret)
pmlmepriv->to_join = _FALSE;
} else {
/*if (ssc_chk == SS_DENY_BUDDY_UNDER_SURVEY) {
} else {*/
ret = _FAIL;
pmlmepriv->to_join = _FALSE;
}
} else {
ret = _FAIL;
pmlmepriv->to_join = _FALSE;
}
}
}
}
exit:
return ret;
}
u8 rtw_set_802_11_bssid(_adapter *padapter, u8 *bssid)
{
_irqL irqL;
u8 status = _SUCCESS;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
RTW_PRINT("set bssid:%pM\n", bssid);
if ((bssid[0] == 0x00 && bssid[1] == 0x00 && bssid[2] == 0x00 && bssid[3] == 0x00 && bssid[4] == 0x00 && bssid[5] == 0x00) ||
(bssid[0] == 0xFF && bssid[1] == 0xFF && bssid[2] == 0xFF && bssid[3] == 0xFF && bssid[4] == 0xFF && bssid[5] == 0xFF)) {
status = _FAIL;
goto exit;
}
_enter_critical_bh(&pmlmepriv->lock, &irqL);
RTW_INFO("Set BSSID under fw_state=0x%08x\n", get_fwstate(pmlmepriv));
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
goto handle_tkip_countermeasure;
else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
goto release_mlme_lock;
if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
if (_rtw_memcmp(&pmlmepriv->cur_network.network.MacAddress, bssid, ETH_ALEN) == _TRUE) {
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE)
goto release_mlme_lock;/* it means driver is in WIFI_ADHOC_MASTER_STATE, we needn't create bss again. */
} else {
rtw_disassoc_cmd(padapter, 0, 0);
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
rtw_indicate_disconnect(padapter, 0, _FALSE);
rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
}
}
}
handle_tkip_countermeasure:
if (rtw_handle_tkip_countermeasure(padapter, __func__) == _FAIL) {
status = _FAIL;
goto release_mlme_lock;
}
_rtw_memset(&pmlmepriv->assoc_ssid, 0, sizeof(NDIS_802_11_SSID));
_rtw_memcpy(&pmlmepriv->assoc_bssid, bssid, ETH_ALEN);
pmlmepriv->assoc_ch = 0;
pmlmepriv->assoc_by_bssid = _TRUE;
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
pmlmepriv->to_join = _TRUE;
else
status = rtw_do_join(padapter);
release_mlme_lock:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
exit:
return status;
}
u8 rtw_set_802_11_ssid(_adapter *padapter, NDIS_802_11_SSID *ssid)
{
_irqL irqL;
u8 status = _SUCCESS;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *pnetwork = &pmlmepriv->cur_network;
RTW_PRINT("set ssid [%s] fw_state=0x%08x\n",
ssid->Ssid, get_fwstate(pmlmepriv));
if (!rtw_is_hw_init_completed(padapter)) {
status = _FAIL;
goto exit;
}
_enter_critical_bh(&pmlmepriv->lock, &irqL);
RTW_INFO("Set SSID under fw_state=0x%08x\n", get_fwstate(pmlmepriv));
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
goto handle_tkip_countermeasure;
else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
goto release_mlme_lock;
if (check_fwstate(pmlmepriv, _FW_LINKED | WIFI_ADHOC_MASTER_STATE) == _TRUE) {
if ((pmlmepriv->assoc_ssid.SsidLength == ssid->SsidLength) &&
(_rtw_memcmp(&pmlmepriv->assoc_ssid.Ssid, ssid->Ssid, ssid->SsidLength) == _TRUE)) {
if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _FALSE)) {
if (rtw_is_same_ibss(padapter, pnetwork) == _FALSE) {
/* if in WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE, create bss or rejoin again */
rtw_disassoc_cmd(padapter, 0, 0);
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
rtw_indicate_disconnect(padapter, 0, _FALSE);
rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
}
} else {
goto release_mlme_lock;/* it means driver is in WIFI_ADHOC_MASTER_STATE, we needn't create bss again. */
}
}
#ifdef CONFIG_LPS
else
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_JOINBSS, 0);
#endif
} else {
rtw_disassoc_cmd(padapter, 0, 0);
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
rtw_indicate_disconnect(padapter, 0, _FALSE);
rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) {
_clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
}
}
}
handle_tkip_countermeasure:
if (rtw_handle_tkip_countermeasure(padapter, __func__) == _FAIL) {
status = _FAIL;
goto release_mlme_lock;
}
if (rtw_validate_ssid(ssid) == _FALSE) {
status = _FAIL;
goto release_mlme_lock;
}
_rtw_memcpy(&pmlmepriv->assoc_ssid, ssid, sizeof(NDIS_802_11_SSID));
pmlmepriv->assoc_by_bssid = _FALSE;
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
pmlmepriv->to_join = _TRUE;
else
status = rtw_do_join(padapter);
release_mlme_lock:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
exit:
return status;
}
u8 rtw_set_802_11_connect(_adapter *padapter,
u8 *bssid, NDIS_802_11_SSID *ssid, u16 ch)
{
_irqL irqL;
u8 status = _SUCCESS;
bool bssid_valid = _TRUE;
bool ssid_valid = _TRUE;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (!ssid || rtw_validate_ssid(ssid) == _FALSE)
ssid_valid = _FALSE;
if (!bssid || rtw_validate_bssid(bssid) == _FALSE)
bssid_valid = _FALSE;
if (ssid_valid == _FALSE && bssid_valid == _FALSE) {
RTW_INFO(FUNC_ADPT_FMT" ssid:%p, ssid_valid:%d, bssid:%p, bssid_valid:%d\n",
FUNC_ADPT_ARG(padapter), ssid, ssid_valid, bssid, bssid_valid);
status = _FAIL;
goto exit;
}
if (!rtw_is_hw_init_completed(padapter)) {
status = _FAIL;
goto exit;
}
_enter_critical_bh(&pmlmepriv->lock, &irqL);
RTW_PRINT(FUNC_ADPT_FMT" fw_state=0x%08x\n",
FUNC_ADPT_ARG(padapter), get_fwstate(pmlmepriv));
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
goto handle_tkip_countermeasure;
else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
goto release_mlme_lock;
handle_tkip_countermeasure:
if (rtw_handle_tkip_countermeasure(padapter, __func__) == _FAIL) {
status = _FAIL;
goto release_mlme_lock;
}
if (ssid && ssid_valid)
_rtw_memcpy(&pmlmepriv->assoc_ssid, ssid, sizeof(NDIS_802_11_SSID));
else
_rtw_memset(&pmlmepriv->assoc_ssid, 0, sizeof(NDIS_802_11_SSID));
if (bssid && bssid_valid) {
_rtw_memcpy(&pmlmepriv->assoc_bssid, bssid, ETH_ALEN);
pmlmepriv->assoc_by_bssid = _TRUE;
} else
pmlmepriv->assoc_by_bssid = _FALSE;
pmlmepriv->assoc_ch = ch;
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE)
pmlmepriv->to_join = _TRUE;
else
status = rtw_do_join(padapter);
release_mlme_lock:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
exit:
return status;
}
u8 rtw_set_802_11_infrastructure_mode(_adapter *padapter,
NDIS_802_11_NETWORK_INFRASTRUCTURE networktype)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
NDIS_802_11_NETWORK_INFRASTRUCTURE *pold_state = &(cur_network->network.InfrastructureMode);
u8 ap2sta_mode = _FALSE;
u8 ret = _TRUE;
if (*pold_state != networktype) {
/* RTW_INFO("change mode, old_mode=%d, new_mode=%d, fw_state=0x%x\n", *pold_state, networktype, get_fwstate(pmlmepriv)); */
if (*pold_state == Ndis802_11APMode
|| *pold_state == Ndis802_11_mesh
) {
/* change to other mode from Ndis802_11APMode/Ndis802_11_mesh */
cur_network->join_res = -1;
ap2sta_mode = _TRUE;
#ifdef CONFIG_NATIVEAP_MLME
stop_ap_mode(padapter);
#endif
}
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) || (*pold_state == Ndis802_11IBSS))
rtw_disassoc_cmd(padapter, 0, 0);
if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE))
rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
if ((*pold_state == Ndis802_11Infrastructure) || (*pold_state == Ndis802_11IBSS)) {
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
rtw_indicate_disconnect(padapter, 0, _FALSE); /*will clr Linked_state; before this function, we must have checked whether issue dis-assoc_cmd or not*/
}
}
*pold_state = networktype;
_clr_fwstate_(pmlmepriv, ~WIFI_NULL_STATE);
switch (networktype) {
case Ndis802_11IBSS:
set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
break;
case Ndis802_11Infrastructure:
set_fwstate(pmlmepriv, WIFI_STATION_STATE);
if (ap2sta_mode)
rtw_init_bcmc_stainfo(padapter);
break;
case Ndis802_11APMode:
set_fwstate(pmlmepriv, WIFI_AP_STATE);
#ifdef CONFIG_NATIVEAP_MLME
start_ap_mode(padapter);
/* rtw_indicate_connect(padapter); */
#endif
break;
#ifdef CONFIG_RTW_MESH
case Ndis802_11_mesh:
set_fwstate(pmlmepriv, WIFI_MESH_STATE);
start_ap_mode(padapter);
break;
#endif
case Ndis802_11AutoUnknown:
case Ndis802_11InfrastructureMax:
break;
case Ndis802_11Monitor:
set_fwstate(pmlmepriv, WIFI_MONITOR_STATE);
break;
default:
ret = _FALSE;
rtw_warn_on(1);
}
/* SecClearAllKeys(adapter); */
_exit_critical_bh(&pmlmepriv->lock, &irqL);
}
return ret;
}
u8 rtw_set_802_11_disassociate(_adapter *padapter)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
rtw_disassoc_cmd(padapter, 0, 0);
rtw_indicate_disconnect(padapter, 0, _FALSE);
/* modify for CONFIG_IEEE80211W, none 11w can use it */
rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
if (_FAIL == rtw_pwr_wakeup(padapter))
RTW_INFO("%s(): rtw_pwr_wakeup fail !!!\n", __FUNCTION__);
}
_exit_critical_bh(&pmlmepriv->lock, &irqL);
return _TRUE;
}
#if 1
u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 res = _TRUE;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
res = rtw_sitesurvey_cmd(padapter, pparm);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
return res;
}
#else
u8 rtw_set_802_11_bssid_list_scan(_adapter *padapter, struct sitesurvey_parm *pparm)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 res = _TRUE;
if (padapter == NULL) {
res = _FALSE;
goto exit;
}
if (!rtw_is_hw_init_completed(padapter)) {
res = _FALSE;
goto exit;
}
if ((check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) == _TRUE) ||
(pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE)) {
/* Scan or linking is in progress, do nothing. */
res = _TRUE;
} else {
if (rtw_is_scan_deny(padapter)) {
RTW_INFO(FUNC_ADPT_FMT": scan deny\n", FUNC_ADPT_ARG(padapter));
indicate_wx_scan_complete_event(padapter);
return _SUCCESS;
}
_enter_critical_bh(&pmlmepriv->lock, &irqL);
res = rtw_sitesurvey_cmd(padapter, pparm);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
}
exit:
return res;
}
#endif
u8 rtw_set_802_11_authentication_mode(_adapter *padapter, NDIS_802_11_AUTHENTICATION_MODE authmode)
{
struct security_priv *psecuritypriv = &padapter->securitypriv;
int res;
u8 ret;
psecuritypriv->ndisauthtype = authmode;
if (psecuritypriv->ndisauthtype > 3)
psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
#ifdef CONFIG_WAPI_SUPPORT
if (psecuritypriv->ndisauthtype == 6)
psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_WAPI;
#endif
res = rtw_set_auth(padapter, psecuritypriv);
if (res == _SUCCESS)
ret = _TRUE;
else
ret = _FALSE;
return ret;
}
u8 rtw_set_802_11_add_wep(_adapter *padapter, NDIS_802_11_WEP *wep)
{
u8 bdefaultkey;
u8 btransmitkey;
sint keyid, res;
struct security_priv *psecuritypriv = &(padapter->securitypriv);
u8 ret = _SUCCESS;
bdefaultkey = (wep->KeyIndex & 0x40000000) > 0 ? _FALSE : _TRUE; /* for ??? */
btransmitkey = (wep->KeyIndex & 0x80000000) > 0 ? _TRUE : _FALSE; /* for ??? */
keyid = wep->KeyIndex & 0x3fffffff;
if (keyid >= 4) {
ret = _FALSE;
goto exit;
}
switch (wep->KeyLength) {
case 5:
psecuritypriv->dot11PrivacyAlgrthm = _WEP40_;
break;
case 13:
psecuritypriv->dot11PrivacyAlgrthm = _WEP104_;
break;
default:
psecuritypriv->dot11PrivacyAlgrthm = _NO_PRIVACY_;
break;
}
_rtw_memcpy(&(psecuritypriv->dot11DefKey[keyid].skey[0]), &(wep->KeyMaterial), wep->KeyLength);
psecuritypriv->dot11DefKeylen[keyid] = wep->KeyLength;
psecuritypriv->dot11PrivacyKeyIndex = keyid;
res = rtw_set_key(padapter, psecuritypriv, keyid, 1, _TRUE);
if (res == _FAIL)
ret = _FALSE;
exit:
return ret;
}
/*
* rtw_get_cur_max_rate -
* @adapter: pointer to _adapter structure
*
* Return 0 or 100Kbps
*/
u16 rtw_get_cur_max_rate(_adapter *adapter)
{
int j;
int i = 0;
u16 rate = 0, max_rate = 0;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
WLAN_BSSID_EX *pcur_bss = &pmlmepriv->cur_network.network;
int sta_bssrate_len = 0;
unsigned char sta_bssrate[NumRates];
struct sta_info *psta = NULL;
u8 short_GI = 0;
#ifdef CONFIG_80211N_HT
u8 rf_type = 0;
#endif
#ifdef CONFIG_MP_INCLUDED
if (adapter->registrypriv.mp_mode == 1) {
if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
return 0;
}
#endif
if ((check_fwstate(pmlmepriv, _FW_LINKED) != _TRUE)
&& (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) != _TRUE))
return 0;
psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
if (psta == NULL)
return 0;
short_GI = query_ra_short_GI(psta, rtw_get_tx_bw_mode(adapter, psta));
#ifdef CONFIG_80211N_HT
if (is_supported_ht(psta->wireless_mode)) {
rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
max_rate = rtw_mcs_rate(rf_type
, (psta->cmn.bw_mode == CHANNEL_WIDTH_40) ? 1 : 0
, short_GI
, psta->htpriv.ht_cap.supp_mcs_set
);
}
#ifdef CONFIG_80211AC_VHT
else if (is_supported_vht(psta->wireless_mode))
max_rate = ((rtw_vht_mcs_to_data_rate(psta->cmn.bw_mode, short_GI, pmlmepriv->vhtpriv.vht_highest_rate) + 1) >> 1) * 10;
#endif /* CONFIG_80211AC_VHT */
else
#endif /* CONFIG_80211N_HT */
{
/*station mode show :station && ap support rate; softap :show ap support rate*/
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
get_rate_set(adapter, sta_bssrate, &sta_bssrate_len);/*get sta rate and length*/
while ((pcur_bss->SupportedRates[i] != 0) && (pcur_bss->SupportedRates[i] != 0xFF)) {
rate = pcur_bss->SupportedRates[i] & 0x7F;/*AP support rates*/
/*RTW_INFO("%s rate=%02X \n", __func__, rate);*/
/*check STA support rate or not */
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
for (j = 0; j < sta_bssrate_len; j++) {
/* Avoid the proprietary data rate (22Mbps) of Handlink WSG-4000 AP */
if ((rate | IEEE80211_BASIC_RATE_MASK)
== (sta_bssrate[j] | IEEE80211_BASIC_RATE_MASK)) {
if (rate > max_rate) {
max_rate = rate;
}
break;
}
}
} else {
if (rate > max_rate)
max_rate = rate;
}
i++;
}
max_rate = max_rate * 10 / 2;
}
return max_rate;
}
/*
* rtw_set_scan_mode -
* @adapter: pointer to _adapter structure
* @scan_mode:
*
* Return _SUCCESS or _FAIL
*/
int rtw_set_scan_mode(_adapter *adapter, RT_SCAN_TYPE scan_mode)
{
if (scan_mode != SCAN_ACTIVE && scan_mode != SCAN_PASSIVE)
return _FAIL;
adapter->mlmepriv.scan_mode = scan_mode;
return _SUCCESS;
}
/*
* rtw_set_channel_plan -
* @adapter: pointer to _adapter structure
* @channel_plan:
*
* Return _SUCCESS or _FAIL
*/
int rtw_set_channel_plan(_adapter *adapter, u8 channel_plan)
{
/* handle by cmd_thread to sync with scan operation */
return rtw_set_chplan_cmd(adapter, RTW_CMDF_WAIT_ACK, channel_plan, 1);
}
/*
* rtw_set_country -
* @adapter: pointer to _adapter structure
* @country_code: string of country code
*
* Return _SUCCESS or _FAIL
*/
int rtw_set_country(_adapter *adapter, const char *country_code)
{
#ifdef CONFIG_RTW_IOCTL_SET_COUNTRY
return rtw_set_country_cmd(adapter, RTW_CMDF_WAIT_ACK, country_code, 1);
#else
RTW_INFO("%s(): not applied\n", __func__);
return _SUCCESS;
#endif
}
/*
* rtw_set_band -
* @adapter: pointer to _adapter structure
* @band: band to set
*
* Return _SUCCESS or _FAIL
*/
int rtw_set_band(_adapter *adapter, u8 band)
{
if (rtw_band_valid(band)) {
RTW_INFO(FUNC_ADPT_FMT" band:%d\n", FUNC_ADPT_ARG(adapter), band);
adapter->setband = band;
return _SUCCESS;
}
RTW_PRINT(FUNC_ADPT_FMT" band:%d fail\n", FUNC_ADPT_ARG(adapter), band);
return _FAIL;
}
================================================
FILE: core/rtw_iol.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#ifdef CONFIG_IOL
struct xmit_frame *rtw_IOL_accquire_xmit_frame(ADAPTER *adapter)
{
struct xmit_frame *xmit_frame;
struct xmit_buf *xmitbuf;
struct pkt_attrib *pattrib;
struct xmit_priv *pxmitpriv = &(adapter->xmitpriv);
#if 1
xmit_frame = rtw_alloc_xmitframe(pxmitpriv);
if (xmit_frame == NULL) {
RTW_INFO("%s rtw_alloc_xmitframe return null\n", __FUNCTION__);
goto exit;
}
xmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
if (xmitbuf == NULL) {
RTW_INFO("%s rtw_alloc_xmitbuf return null\n", __FUNCTION__);
rtw_free_xmitframe(pxmitpriv, xmit_frame);
xmit_frame = NULL;
goto exit;
}
xmit_frame->frame_tag = MGNT_FRAMETAG;
xmit_frame->pxmitbuf = xmitbuf;
xmit_frame->buf_addr = xmitbuf->pbuf;
xmitbuf->priv_data = xmit_frame;
pattrib = &xmit_frame->attrib;
update_mgntframe_attrib(adapter, pattrib);
pattrib->qsel = QSLT_BEACON;/* Beacon */
pattrib->subtype = WIFI_BEACON;
pattrib->pktlen = pattrib->last_txcmdsz = 0;
#else
xmit_frame = alloc_mgtxmitframe(pxmitpriv);
if (xmit_frame == NULL)
RTW_INFO("%s alloc_mgtxmitframe return null\n", __FUNCTION__);
else {
pattrib = &xmit_frame->attrib;
update_mgntframe_attrib(adapter, pattrib);
pattrib->qsel = QSLT_BEACON;
pattrib->pktlen = pattrib->last_txcmdsz = 0;
}
#endif
exit:
return xmit_frame;
}
int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len)
{
struct pkt_attrib *pattrib = &xmit_frame->attrib;
u16 buf_offset;
u32 ori_len;
buf_offset = TXDESC_OFFSET;
ori_len = buf_offset + pattrib->pktlen;
/* check if the io_buf can accommodate new cmds */
if (ori_len + cmd_len + 8 > MAX_XMITBUF_SZ) {
RTW_INFO("%s %u is large than MAX_XMITBUF_SZ:%u, can't accommodate new cmds\n", __FUNCTION__
, ori_len + cmd_len + 8, MAX_XMITBUF_SZ);
return _FAIL;
}
_rtw_memcpy(xmit_frame->buf_addr + buf_offset + pattrib->pktlen, IOL_cmds, cmd_len);
pattrib->pktlen += cmd_len;
pattrib->last_txcmdsz += cmd_len;
/* RTW_INFO("%s ori:%u + cmd_len:%u = %u\n", __FUNCTION__, ori_len, cmd_len, buf_offset+pattrib->pktlen); */
return _SUCCESS;
}
bool rtw_IOL_applied(ADAPTER *adapter)
{
if (1 == adapter->registrypriv.fw_iol)
return _TRUE;
#ifdef CONFIG_USB_HCI
if ((2 == adapter->registrypriv.fw_iol) && (IS_FULL_SPEED_USB(adapter)))
return _TRUE;
#endif
return _FALSE;
}
int rtw_IOL_exec_cmds_sync(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt)
{
return rtw_hal_iol_cmd(adapter, xmit_frame, max_wating_ms, bndy_cnt);
}
#ifdef CONFIG_IOL_NEW_GENERATION
int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)
{
return _SUCCESS;
}
int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, u8 mask)
{
struct ioreg_cfg cmd = {8, IOREG_CMD_WB_REG, 0x0, 0x0, 0x0};
/* RTW_PUT_LE16((u8*)&cmd.address, addr); */
/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value); */
cmd.address = cpu_to_le16(addr);
cmd.data = cpu_to_le32(value);
if (mask != 0xFF) {
cmd.length = 12;
/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask); */
cmd.mask = cpu_to_le32(mask);
}
/* RTW_INFO("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
}
int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, u16 mask)
{
struct ioreg_cfg cmd = {8, IOREG_CMD_WW_REG, 0x0, 0x0, 0x0};
/* RTW_PUT_LE16((u8*)&cmd.address, addr); */
/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value); */
cmd.address = cpu_to_le16(addr);
cmd.data = cpu_to_le32(value);
if (mask != 0xFFFF) {
cmd.length = 12;
/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask); */
cmd.mask = cpu_to_le32(mask);
}
/* RTW_INFO("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FUNCTION__, addr,value,mask); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
}
int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, u32 mask)
{
struct ioreg_cfg cmd = {8, IOREG_CMD_WD_REG, 0x0, 0x0, 0x0};
/* RTW_PUT_LE16((u8*)&cmd.address, addr); */
/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value); */
cmd.address = cpu_to_le16(addr);
cmd.data = cpu_to_le32(value);
if (mask != 0xFFFFFFFF) {
cmd.length = 12;
/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask); */
cmd.mask = cpu_to_le32(mask);
}
/* RTW_INFO("%s addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__, addr,value,mask); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
}
int _rtw_IOL_append_WRF_cmd(struct xmit_frame *xmit_frame, u8 rf_path, u16 addr, u32 value, u32 mask)
{
struct ioreg_cfg cmd = {8, IOREG_CMD_W_RF, 0x0, 0x0, 0x0};
/* RTW_PUT_LE16((u8*)&cmd.address, addr); */
/* RTW_PUT_LE32((u8*)&cmd.value, (u32)value); */
cmd.address = (rf_path << 8) | ((addr) & 0xFF);
cmd.data = cpu_to_le32(value);
if (mask != 0x000FFFFF) {
cmd.length = 12;
/* RTW_PUT_LE32((u8*)&cmd.mask, (u32)mask); */
cmd.mask = cpu_to_le32(mask);
}
/* RTW_INFO("%s rf_path:0x%02x addr:0x%04x,value:0x%08x,mask:0x%08x\n", __FU2NCTION__,rf_path, addr,value,mask); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, cmd.length);
}
int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)
{
struct ioreg_cfg cmd = {4, IOREG_CMD_DELAY_US, 0x0, 0x0, 0x0};
/* RTW_PUT_LE16((u8*)&cmd.address, us); */
cmd.address = cpu_to_le16(us);
/* RTW_INFO("%s %u\n", __FUNCTION__, us); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 4);
}
int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)
{
struct ioreg_cfg cmd = {4, IOREG_CMD_DELAY_US, 0x0, 0x0, 0x0};
/* RTW_PUT_LE16((u8*)&cmd.address, ms); */
cmd.address = cpu_to_le16(ms);
/* RTW_INFO("%s %u\n", __FUNCTION__, ms); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 4);
}
int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)
{
struct ioreg_cfg cmd = {4, IOREG_CMD_END, 0xFFFF, 0xFF, 0x0};
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 4);
}
u8 rtw_IOL_cmd_boundary_handle(struct xmit_frame *pxmit_frame)
{
u8 is_cmd_bndy = _FALSE;
if (((pxmit_frame->attrib.pktlen + 32) % 256) + 8 >= 256) {
rtw_IOL_append_END_cmd(pxmit_frame);
pxmit_frame->attrib.pktlen = ((((pxmit_frame->attrib.pktlen + 32) / 256) + 1) * 256);
/* printk("==> %s, pktlen(%d)\n",__FUNCTION__,pxmit_frame->attrib.pktlen); */
pxmit_frame->attrib.last_txcmdsz = pxmit_frame->attrib.pktlen;
is_cmd_bndy = _TRUE;
}
return is_cmd_bndy;
}
void rtw_IOL_cmd_buf_dump(ADAPTER *Adapter, int buf_len, u8 *pbuf)
{
int i;
int j = 1;
printk("###### %s ######\n", __FUNCTION__);
for (i = 0; i < buf_len; i++) {
printk("%02x-", *(pbuf + i));
if (j % 32 == 0)
printk("\n");
j++;
}
printk("\n");
printk("============= ioreg_cmd len = %d ===============\n", buf_len);
}
#else /* CONFIG_IOL_NEW_GENERATION */
int rtw_IOL_append_LLT_cmd(struct xmit_frame *xmit_frame, u8 page_boundary)
{
IOL_CMD cmd = {0x0, IOL_CMD_LLT, 0x0, 0x0};
RTW_PUT_BE32((u8 *)&cmd.value, (u32)page_boundary);
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
}
int _rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value)
{
IOL_CMD cmd = {0x0, IOL_CMD_WB_REG, 0x0, 0x0};
RTW_PUT_BE16((u8 *)&cmd.address, (u16)addr);
RTW_PUT_BE32((u8 *)&cmd.value, (u32)value);
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
}
int _rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value)
{
IOL_CMD cmd = {0x0, IOL_CMD_WW_REG, 0x0, 0x0};
RTW_PUT_BE16((u8 *)&cmd.address, (u16)addr);
RTW_PUT_BE32((u8 *)&cmd.value, (u32)value);
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
}
int _rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value)
{
IOL_CMD cmd = {0x0, IOL_CMD_WD_REG, 0x0, 0x0};
u8 *pos = (u8 *)&cmd;
RTW_PUT_BE16((u8 *)&cmd.address, (u16)addr);
RTW_PUT_BE32((u8 *)&cmd.value, (u32)value);
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
}
#ifdef DBG_IO
int dbg_rtw_IOL_append_WB_cmd(struct xmit_frame *xmit_frame, u16 addr, u8 value, const char *caller, const int line)
{
if (match_write_sniff(xmit_frame->padapter, addr, 1, value)) {
RTW_INFO("DBG_IO %s:%d IOL_WB(0x%04x, 0x%02x)\n"
, caller, line, addr, value);
}
return _rtw_IOL_append_WB_cmd(xmit_frame, addr, value);
}
int dbg_rtw_IOL_append_WW_cmd(struct xmit_frame *xmit_frame, u16 addr, u16 value, const char *caller, const int line)
{
if (match_write_sniff(xmit_frame->padapter, addr, 2, value)) {
RTW_INFO("DBG_IO %s:%d IOL_WW(0x%04x, 0x%04x)\n"
, caller, line, addr, value);
}
return _rtw_IOL_append_WW_cmd(xmit_frame, addr, value);
}
int dbg_rtw_IOL_append_WD_cmd(struct xmit_frame *xmit_frame, u16 addr, u32 value, const char *caller, const int line)
{
if (match_write_sniff(xmit_frame->padapter, addr, 4, value)) {
RTW_INFO("DBG_IO %s:%d IOL_WD(0x%04x, 0x%08x)\n"
, caller, line, addr, value);
}
return _rtw_IOL_append_WD_cmd(xmit_frame, addr, value);
}
#endif
int rtw_IOL_append_DELAY_US_cmd(struct xmit_frame *xmit_frame, u16 us)
{
IOL_CMD cmd = {0x0, IOL_CMD_DELAY_US, 0x0, 0x0};
RTW_PUT_BE32((u8 *)&cmd.value, (u32)us);
/* RTW_INFO("%s %u\n", __FUNCTION__, us); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
}
int rtw_IOL_append_DELAY_MS_cmd(struct xmit_frame *xmit_frame, u16 ms)
{
IOL_CMD cmd = {0x0, IOL_CMD_DELAY_MS, 0x0, 0x0};
RTW_PUT_BE32((u8 *)&cmd.value, (u32)ms);
/* RTW_INFO("%s %u\n", __FUNCTION__, ms); */
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&cmd, 8);
}
int rtw_IOL_append_END_cmd(struct xmit_frame *xmit_frame)
{
IOL_CMD end_cmd = {0x0, IOL_CMD_END, 0x0, 0x0};
return rtw_IOL_append_cmds(xmit_frame, (u8 *)&end_cmd, 8);
}
int rtw_IOL_exec_cmd_array_sync(PADAPTER adapter, u8 *IOL_cmds, u32 cmd_num, u32 max_wating_ms)
{
struct xmit_frame *xmit_frame;
xmit_frame = rtw_IOL_accquire_xmit_frame(adapter);
if (xmit_frame == NULL)
return _FAIL;
if (rtw_IOL_append_cmds(xmit_frame, IOL_cmds, cmd_num << 3) == _FAIL)
return _FAIL;
return rtw_IOL_exec_cmds_sync(adapter, xmit_frame, max_wating_ms, 0);
}
int rtw_IOL_exec_empty_cmds_sync(ADAPTER *adapter, u32 max_wating_ms)
{
IOL_CMD end_cmd = {0x0, IOL_CMD_END, 0x0, 0x0};
return rtw_IOL_exec_cmd_array_sync(adapter, (u8 *)&end_cmd, 1, max_wating_ms);
}
#endif /* CONFIG_IOL_NEW_GENERATION */
#endif /* CONFIG_IOL */
================================================
FILE: core/rtw_mem.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
MODULE_LICENSE("GPL");
MODULE_DESCRIPTION("Realtek Wireless Lan Driver");
MODULE_AUTHOR("Realtek Semiconductor Corp.");
MODULE_VERSION("DRIVERVERSION");
struct sk_buff_head rtk_skb_mem_q;
struct u8 *rtk_buf_mem[NR_RECVBUFF];
struct u8 *rtw_get_buf_premem(int index)
{
printk("%s, rtk_buf_mem index : %d\n", __func__, index);
return rtk_buf_mem[index];
}
u16 rtw_rtkm_get_buff_size(void)
{
return MAX_RTKM_RECVBUF_SZ;
}
EXPORT_SYMBOL(rtw_rtkm_get_buff_size);
u8 rtw_rtkm_get_nr_recv_skb(void)
{
return MAX_RTKM_NR_PREALLOC_RECV_SKB;
}
EXPORT_SYMBOL(rtw_rtkm_get_nr_recv_skb);
struct sk_buff *rtw_alloc_skb_premem(u16 in_size)
{
struct sk_buff *skb = NULL;
if (in_size > MAX_RTKM_RECVBUF_SZ) {
pr_info("warning %s: driver buffer size(%d) > rtkm buffer size(%d)\n", __func__, in_size, MAX_RTKM_RECVBUF_SZ);
WARN_ON(1);
return skb;
}
skb = skb_dequeue(&rtk_skb_mem_q);
printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
return skb;
}
EXPORT_SYMBOL(rtw_alloc_skb_premem);
int rtw_free_skb_premem(struct sk_buff *pskb)
{
if (!pskb)
return -1;
if (skb_queue_len(&rtk_skb_mem_q) >= MAX_RTKM_NR_PREALLOC_RECV_SKB)
return -1;
skb_queue_tail(&rtk_skb_mem_q, pskb);
printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
return 0;
}
EXPORT_SYMBOL(rtw_free_skb_premem);
static int __init rtw_mem_init(void)
{
int i;
SIZE_PTR tmpaddr = 0;
SIZE_PTR alignment = 0;
struct sk_buff *pskb = NULL;
printk("%s\n", __func__);
pr_info("MAX_RTKM_NR_PREALLOC_RECV_SKB: %d\n", MAX_RTKM_NR_PREALLOC_RECV_SKB);
pr_info("MAX_RTKM_RECVBUF_SZ: %d\n", MAX_RTKM_RECVBUF_SZ);
#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
for (i = 0; i < NR_RECVBUFF; i++)
rtk_buf_mem[i] = usb_buffer_alloc(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);
#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
skb_queue_head_init(&rtk_skb_mem_q);
for (i = 0; i < MAX_RTKM_NR_PREALLOC_RECV_SKB; i++) {
pskb = __dev_alloc_skb(MAX_RTKM_RECVBUF_SZ + RECVBUFF_ALIGN_SZ, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);
if (pskb) {
tmpaddr = (SIZE_PTR)pskb->data;
alignment = tmpaddr & (RECVBUFF_ALIGN_SZ - 1);
skb_reserve(pskb, (RECVBUFF_ALIGN_SZ - alignment));
skb_queue_tail(&rtk_skb_mem_q, pskb);
} else
printk("%s, alloc skb memory fail!\n", __func__);
pskb = NULL;
}
printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
return 0;
}
static void __exit rtw_mem_exit(void)
{
if (skb_queue_len(&rtk_skb_mem_q))
printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));
skb_queue_purge(&rtk_skb_mem_q);
printk("%s\n", __func__);
}
module_init(rtw_mem_init);
module_exit(rtw_mem_exit);
================================================
FILE: core/rtw_mi.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_MI_C_
#include
#include
void rtw_mi_update_union_chan_inf(_adapter *adapter, u8 ch, u8 offset , u8 bw)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mi_state *iface_state = &dvobj->iface_state;
iface_state->union_ch = ch;
iface_state->union_bw = bw;
iface_state->union_offset = offset;
}
#ifdef DBG_IFACE_STATUS
#ifdef CONFIG_P2P
static u8 _rtw_mi_p2p_listen_scan_chk(_adapter *adapter)
{
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 p2p_listen_scan_state = _FALSE;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_LISTEN) ||
rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_SCAN)) {
p2p_listen_scan_state = _TRUE;
break;
}
}
return p2p_listen_scan_state;
}
#endif
#endif
u8 rtw_mi_stayin_union_ch_chk(_adapter *adapter)
{
u8 rst = _TRUE;
u8 u_ch, u_bw, u_offset;
u8 o_ch, o_bw, o_offset;
u_ch = rtw_mi_get_union_chan(adapter);
u_bw = rtw_mi_get_union_bw(adapter);
u_offset = rtw_mi_get_union_offset(adapter);
o_ch = rtw_get_oper_ch(adapter);
o_bw = rtw_get_oper_bw(adapter);
o_offset = rtw_get_oper_choffset(adapter);
if ((u_ch != o_ch) || (u_bw != o_bw) || (u_offset != o_offset))
rst = _FALSE;
#ifdef DBG_IFACE_STATUS
if (rst == _FALSE) {
RTW_ERR("%s Not stay in union channel\n", __func__);
if (GET_HAL_DATA(adapter)->bScanInProcess == _TRUE)
RTW_ERR("ScanInProcess\n");
#ifdef CONFIG_P2P
if (_rtw_mi_p2p_listen_scan_chk(adapter))
RTW_ERR("P2P in listen or scan state\n");
#endif
RTW_ERR("union ch, bw, offset: %u,%u,%u\n", u_ch, u_bw, u_offset);
RTW_ERR("oper ch, bw, offset: %u,%u,%u\n", o_ch, o_bw, o_offset);
RTW_ERR("=========================\n");
}
#endif
return rst;
}
u8 rtw_mi_stayin_union_band_chk(_adapter *adapter)
{
u8 rst = _TRUE;
u8 u_ch, o_ch;
u8 u_band, o_band;
u_ch = rtw_mi_get_union_chan(adapter);
o_ch = rtw_get_oper_ch(adapter);
u_band = (u_ch > 14) ? BAND_ON_5G : BAND_ON_2_4G;
o_band = (o_ch > 14) ? BAND_ON_5G : BAND_ON_2_4G;
if (u_ch != o_ch)
if(u_band != o_band)
rst = _FALSE;
#ifdef DBG_IFACE_STATUS
if (rst == _FALSE)
RTW_ERR("%s Not stay in union band\n", __func__);
#endif
return rst;
}
/* Find union about ch, bw, ch_offset of all linked/linking interfaces */
int rtw_mi_get_ch_setting_union_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp, u8 *ch, u8 *bw, u8 *offset)
{
_adapter *iface;
struct mlme_ext_priv *mlmeext;
int i;
u8 ch_ret = 0;
u8 bw_ret = CHANNEL_WIDTH_20;
u8 offset_ret = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
int num = 0;
if (ch)
*ch = 0;
if (bw)
*bw = CHANNEL_WIDTH_20;
if (offset)
*offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface || !(ifbmp & BIT(iface->iface_id)))
continue;
mlmeext = &iface->mlmeextpriv;
if (!check_fwstate(&iface->mlmepriv, _FW_LINKED | _FW_UNDER_LINKING))
continue;
if (check_fwstate(&iface->mlmepriv, WIFI_OP_CH_SWITCHING))
continue;
if (num == 0) {
ch_ret = mlmeext->cur_channel;
bw_ret = mlmeext->cur_bwmode;
offset_ret = mlmeext->cur_ch_offset;
num++;
continue;
}
if (ch_ret != mlmeext->cur_channel) {
num = 0;
break;
}
if (bw_ret < mlmeext->cur_bwmode) {
bw_ret = mlmeext->cur_bwmode;
offset_ret = mlmeext->cur_ch_offset;
} else if (bw_ret == mlmeext->cur_bwmode && offset_ret != mlmeext->cur_ch_offset) {
num = 0;
break;
}
num++;
}
if (num) {
if (ch)
*ch = ch_ret;
if (bw)
*bw = bw_ret;
if (offset)
*offset = offset_ret;
}
return num;
}
inline int rtw_mi_get_ch_setting_union(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
{
return rtw_mi_get_ch_setting_union_by_ifbmp(adapter_to_dvobj(adapter), 0xFF, ch, bw, offset);
}
inline int rtw_mi_get_ch_setting_union_no_self(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
{
return rtw_mi_get_ch_setting_union_by_ifbmp(adapter_to_dvobj(adapter), 0xFF & ~BIT(adapter->iface_id), ch, bw, offset);
}
/* For now, not return union_ch/bw/offset */
void rtw_mi_status_by_ifbmp(struct dvobj_priv *dvobj, u8 ifbmp, struct mi_state *mstate)
{
_adapter *iface;
int i;
_rtw_memset(mstate, 0, sizeof(struct mi_state));
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface || !(ifbmp & BIT(iface->iface_id)))
continue;
if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
MSTATE_STA_NUM(mstate)++;
if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
MSTATE_STA_LD_NUM(mstate)++;
#ifdef CONFIG_TDLS
if (iface->tdlsinfo.link_established == _TRUE)
MSTATE_TDLS_LD_NUM(mstate)++;
#endif
#ifdef CONFIG_P2P
if (MLME_IS_GC(iface))
MSTATE_P2P_GC_NUM(mstate)++;
#endif
}
if (check_fwstate(&iface->mlmepriv, _FW_UNDER_LINKING) == _TRUE)
MSTATE_STA_LG_NUM(mstate)++;
#ifdef CONFIG_AP_MODE
} else if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
MSTATE_AP_NUM(mstate)++;
if (iface->stapriv.asoc_sta_count > 2)
MSTATE_AP_LD_NUM(mstate)++;
#ifdef CONFIG_P2P
if (MLME_IS_GO(iface))
MSTATE_P2P_GO_NUM(mstate)++;
#endif
} else
MSTATE_AP_STARTING_NUM(mstate)++;
#endif
} else if (check_fwstate(&iface->mlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) == _TRUE
&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
) {
MSTATE_ADHOC_NUM(mstate)++;
if (iface->stapriv.asoc_sta_count > 2)
MSTATE_ADHOC_LD_NUM(mstate)++;
#ifdef CONFIG_RTW_MESH
} else if (check_fwstate(&iface->mlmepriv, WIFI_MESH_STATE) == _TRUE
&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
) {
MSTATE_MESH_NUM(mstate)++;
if (iface->stapriv.asoc_sta_count > 2)
MSTATE_MESH_LD_NUM(mstate)++;
#endif
}
if (check_fwstate(&iface->mlmepriv, WIFI_UNDER_WPS) == _TRUE)
MSTATE_WPS_NUM(mstate)++;
if (check_fwstate(&iface->mlmepriv, WIFI_SITE_MONITOR) == _TRUE) {
MSTATE_SCAN_NUM(mstate)++;
if (mlmeext_scan_state(&iface->mlmeextpriv) != SCAN_DISABLE
&& mlmeext_scan_state(&iface->mlmeextpriv) != SCAN_BACK_OP)
MSTATE_SCAN_ENTER_NUM(mstate)++;
}
#ifdef CONFIG_IOCTL_CFG80211
if (rtw_cfg80211_get_is_mgmt_tx(iface))
MSTATE_MGMT_TX_NUM(mstate)++;
#ifdef CONFIG_P2P
if (rtw_cfg80211_get_is_roch(iface) == _TRUE)
MSTATE_ROCH_NUM(mstate)++;
#endif
#endif /* CONFIG_IOCTL_CFG80211 */
#ifdef CONFIG_P2P
if (MLME_IS_PD(iface))
MSTATE_P2P_DV_NUM(mstate)++;
#endif
}
}
inline void rtw_mi_status(_adapter *adapter, struct mi_state *mstate)
{
return rtw_mi_status_by_ifbmp(adapter_to_dvobj(adapter), 0xFF, mstate);
}
inline void rtw_mi_status_no_self(_adapter *adapter, struct mi_state *mstate)
{
return rtw_mi_status_by_ifbmp(adapter_to_dvobj(adapter), 0xFF & ~BIT(adapter->iface_id), mstate);
}
inline void rtw_mi_status_no_others(_adapter *adapter, struct mi_state *mstate)
{
return rtw_mi_status_by_ifbmp(adapter_to_dvobj(adapter), BIT(adapter->iface_id), mstate);
}
/* For now, not handle union_ch/bw/offset */
inline void rtw_mi_status_merge(struct mi_state *d, struct mi_state *a)
{
d->sta_num += a->sta_num;
d->ld_sta_num += a->ld_sta_num;
d->lg_sta_num += a->lg_sta_num;
#ifdef CONFIG_TDLS
d->ld_tdls_num += a->ld_tdls_num;
#endif
#ifdef CONFIG_AP_MODE
d->ap_num += a->ap_num;
d->ld_ap_num += a->ld_ap_num;
#endif
d->adhoc_num += a->adhoc_num;
d->ld_adhoc_num += a->ld_adhoc_num;
#ifdef CONFIG_RTW_MESH
d->mesh_num += a->mesh_num;
d->ld_mesh_num += a->ld_mesh_num;
#endif
d->scan_num += a->scan_num;
d->scan_enter_num += a->scan_enter_num;
d->uwps_num += a->uwps_num;
#ifdef CONFIG_IOCTL_CFG80211
#ifdef CONFIG_P2P
d->roch_num += a->roch_num;
#endif
d->mgmt_tx_num += a->mgmt_tx_num;
#endif
}
void dump_mi_status(void *sel, struct dvobj_priv *dvobj)
{
RTW_PRINT_SEL(sel, "== dvobj-iface_state ==\n");
RTW_PRINT_SEL(sel, "sta_num:%d\n", DEV_STA_NUM(dvobj));
RTW_PRINT_SEL(sel, "linking_sta_num:%d\n", DEV_STA_LG_NUM(dvobj));
RTW_PRINT_SEL(sel, "linked_sta_num:%d\n", DEV_STA_LD_NUM(dvobj));
#ifdef CONFIG_TDLS
RTW_PRINT_SEL(sel, "linked_tdls_num:%d\n", DEV_TDLS_LD_NUM(dvobj));
#endif
#ifdef CONFIG_AP_MODE
RTW_PRINT_SEL(sel, "ap_num:%d\n", DEV_AP_NUM(dvobj));
RTW_PRINT_SEL(sel, "starting_ap_num:%d\n", DEV_AP_STARTING_NUM(dvobj));
RTW_PRINT_SEL(sel, "linked_ap_num:%d\n", DEV_AP_LD_NUM(dvobj));
#endif
RTW_PRINT_SEL(sel, "adhoc_num:%d\n", DEV_ADHOC_NUM(dvobj));
RTW_PRINT_SEL(sel, "linked_adhoc_num:%d\n", DEV_ADHOC_LD_NUM(dvobj));
#ifdef CONFIG_RTW_MESH
RTW_PRINT_SEL(sel, "mesh_num:%d\n", DEV_MESH_NUM(dvobj));
RTW_PRINT_SEL(sel, "linked_mesh_num:%d\n", DEV_MESH_LD_NUM(dvobj));
#endif
#ifdef CONFIG_P2P
RTW_PRINT_SEL(sel, "p2p_device_num:%d\n", DEV_P2P_DV_NUM(dvobj));
RTW_PRINT_SEL(sel, "p2p_gc_num:%d\n", DEV_P2P_GC_NUM(dvobj));
RTW_PRINT_SEL(sel, "p2p_go_num:%d\n", DEV_P2P_GO_NUM(dvobj));
#endif
RTW_PRINT_SEL(sel, "scan_num:%d\n", DEV_SCAN_NUM(dvobj));
RTW_PRINT_SEL(sel, "under_wps_num:%d\n", DEV_WPS_NUM(dvobj));
#if defined(CONFIG_IOCTL_CFG80211)
#if defined(CONFIG_P2P)
RTW_PRINT_SEL(sel, "roch_num:%d\n", DEV_ROCH_NUM(dvobj));
#endif
RTW_PRINT_SEL(sel, "mgmt_tx_num:%d\n", DEV_MGMT_TX_NUM(dvobj));
#endif
RTW_PRINT_SEL(sel, "union_ch:%d\n", DEV_U_CH(dvobj));
RTW_PRINT_SEL(sel, "union_bw:%d\n", DEV_U_BW(dvobj));
RTW_PRINT_SEL(sel, "union_offset:%d\n", DEV_U_OFFSET(dvobj));
RTW_PRINT_SEL(sel, "================\n\n");
}
void dump_dvobj_mi_status(void *sel, const char *fun_name, _adapter *adapter)
{
RTW_INFO("\n[ %s ] call %s\n", fun_name, __func__);
dump_mi_status(sel, adapter_to_dvobj(adapter));
}
inline void rtw_mi_update_iface_status(struct mlme_priv *pmlmepriv, sint state)
{
_adapter *adapter = container_of(pmlmepriv, _adapter, mlmepriv);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mi_state *iface_state = &dvobj->iface_state;
struct mi_state tmp_mstate;
u8 u_ch, u_offset, u_bw;
if (state == WIFI_MONITOR_STATE
|| state == 0xFFFFFFFF
)
return;
if (0)
RTW_INFO("%s => will change or clean state to 0x%08x\n", __func__, state);
rtw_mi_status(adapter, &tmp_mstate);
_rtw_memcpy(iface_state, &tmp_mstate, sizeof(struct mi_state));
if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset))
rtw_mi_update_union_chan_inf(adapter , u_ch, u_offset , u_bw);
else {
if (0) {
dump_adapters_status(RTW_DBGDUMP , dvobj);
RTW_INFO("%s-[ERROR] cannot get union channel\n", __func__);
rtw_warn_on(1);
}
}
#ifdef DBG_IFACE_STATUS
DBG_IFACE_STATUS_DUMP(adapter);
#endif
}
u8 rtw_mi_check_status(_adapter *adapter, u8 type)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mi_state *iface_state = &dvobj->iface_state;
u8 ret = _FALSE;
#ifdef DBG_IFACE_STATUS
DBG_IFACE_STATUS_DUMP(adapter);
RTW_INFO("%s-"ADPT_FMT" check type:%d\n", __func__, ADPT_ARG(adapter), type);
#endif
switch (type) {
case MI_LINKED:
if (MSTATE_STA_LD_NUM(iface_state) || MSTATE_AP_NUM(iface_state) || MSTATE_ADHOC_NUM(iface_state) || MSTATE_MESH_NUM(iface_state)) /*check_fwstate(&iface->mlmepriv, _FW_LINKED)*/
ret = _TRUE;
break;
case MI_ASSOC:
if (MSTATE_STA_LD_NUM(iface_state) || MSTATE_AP_LD_NUM(iface_state) || MSTATE_ADHOC_LD_NUM(iface_state) || MSTATE_MESH_LD_NUM(iface_state))
ret = _TRUE;
break;
case MI_UNDER_WPS:
if (MSTATE_WPS_NUM(iface_state))
ret = _TRUE;
break;
case MI_AP_MODE:
if (MSTATE_AP_NUM(iface_state))
ret = _TRUE;
break;
case MI_AP_ASSOC:
if (MSTATE_AP_LD_NUM(iface_state))
ret = _TRUE;
break;
case MI_ADHOC:
if (MSTATE_ADHOC_NUM(iface_state))
ret = _TRUE;
break;
case MI_ADHOC_ASSOC:
if (MSTATE_ADHOC_LD_NUM(iface_state))
ret = _TRUE;
break;
#ifdef CONFIG_RTW_MESH
case MI_MESH:
if (MSTATE_MESH_NUM(iface_state))
ret = _TRUE;
break;
case MI_MESH_ASSOC:
if (MSTATE_MESH_LD_NUM(iface_state))
ret = _TRUE;
break;
#endif
case MI_STA_NOLINK: /* this is misleading, but not used now */
if (MSTATE_STA_NUM(iface_state) && (!(MSTATE_STA_LD_NUM(iface_state) || MSTATE_STA_LG_NUM(iface_state))))
ret = _TRUE;
break;
case MI_STA_LINKED:
if (MSTATE_STA_LD_NUM(iface_state))
ret = _TRUE;
break;
case MI_STA_LINKING:
if (MSTATE_STA_LG_NUM(iface_state))
ret = _TRUE;
break;
default:
break;
}
return ret;
}
/*
* return value : 0 is failed or have not interface meet condition
* return value : !0 is success or interface numbers which meet condition
* return value of ops_func must be _TRUE or _FALSE
*/
static u8 _rtw_mi_process(_adapter *padapter, bool exclude_self,
void *data, u8(*ops_func)(_adapter *padapter, void *data))
{
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 ret = 0;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
if ((exclude_self) && (iface == padapter))
continue;
if (ops_func)
if (_TRUE == ops_func(iface, data))
ret++;
}
}
return ret;
}
static u8 _rtw_mi_process_without_schk(_adapter *padapter, bool exclude_self,
void *data, u8(*ops_func)(_adapter *padapter, void *data))
{
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 ret = 0;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface) {
if ((exclude_self) && (iface == padapter))
continue;
if (ops_func)
if (ops_func(iface, data) == _TRUE)
ret++;
}
}
return ret;
}
static u8 _rtw_mi_netif_caroff_qstop(_adapter *padapter, void *data)
{
struct net_device *pnetdev = padapter->pnetdev;
rtw_netif_carrier_off(pnetdev);
rtw_netif_stop_queue(pnetdev);
return _TRUE;
}
u8 rtw_mi_netif_caroff_qstop(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_caroff_qstop);
}
u8 rtw_mi_buddy_netif_caroff_qstop(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_caroff_qstop);
}
static u8 _rtw_mi_netif_caron_qstart(_adapter *padapter, void *data)
{
struct net_device *pnetdev = padapter->pnetdev;
rtw_netif_carrier_on(pnetdev);
rtw_netif_start_queue(pnetdev);
return _TRUE;
}
u8 rtw_mi_netif_caron_qstart(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_caron_qstart);
}
u8 rtw_mi_buddy_netif_caron_qstart(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_caron_qstart);
}
static u8 _rtw_mi_netif_stop_queue(_adapter *padapter, void *data)
{
struct net_device *pnetdev = padapter->pnetdev;
rtw_netif_stop_queue(pnetdev);
return _TRUE;
}
u8 rtw_mi_netif_stop_queue(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_stop_queue);
}
u8 rtw_mi_buddy_netif_stop_queue(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_stop_queue);
}
static u8 _rtw_mi_netif_wake_queue(_adapter *padapter, void *data)
{
struct net_device *pnetdev = padapter->pnetdev;
if (pnetdev)
rtw_netif_wake_queue(pnetdev);
return _TRUE;
}
u8 rtw_mi_netif_wake_queue(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_wake_queue);
}
u8 rtw_mi_buddy_netif_wake_queue(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_wake_queue);
}
static u8 _rtw_mi_netif_carrier_on(_adapter *padapter, void *data)
{
struct net_device *pnetdev = padapter->pnetdev;
if (pnetdev)
rtw_netif_carrier_on(pnetdev);
return _TRUE;
}
u8 rtw_mi_netif_carrier_on(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_carrier_on);
}
u8 rtw_mi_buddy_netif_carrier_on(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_carrier_on);
}
static u8 _rtw_mi_netif_carrier_off(_adapter *padapter, void *data)
{
struct net_device *pnetdev = padapter->pnetdev;
if (pnetdev)
rtw_netif_carrier_off(pnetdev);
return _TRUE;
}
u8 rtw_mi_netif_carrier_off(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_netif_carrier_off);
}
u8 rtw_mi_buddy_netif_carrier_off(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_netif_carrier_off);
}
static u8 _rtw_mi_scan_abort(_adapter *adapter, void *data)
{
bool bwait = *(bool *)data;
if (bwait)
rtw_scan_abort(adapter);
else
rtw_scan_abort_no_wait(adapter);
return _TRUE;
}
void rtw_mi_scan_abort(_adapter *adapter, bool bwait)
{
bool in_data = bwait;
_rtw_mi_process(adapter, _FALSE, &in_data, _rtw_mi_scan_abort);
}
void rtw_mi_buddy_scan_abort(_adapter *adapter, bool bwait)
{
bool in_data = bwait;
_rtw_mi_process(adapter, _TRUE, &in_data, _rtw_mi_scan_abort);
}
static u32 _rtw_mi_start_drv_threads(_adapter *adapter, bool exclude_self)
{
int i;
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u32 _status = _SUCCESS;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface) {
if ((exclude_self) && (iface == adapter))
continue;
if (rtw_start_drv_threads(iface) == _FAIL) {
_status = _FAIL;
break;
}
}
}
return _status;
}
u32 rtw_mi_start_drv_threads(_adapter *adapter)
{
return _rtw_mi_start_drv_threads(adapter, _FALSE);
}
u32 rtw_mi_buddy_start_drv_threads(_adapter *adapter)
{
return _rtw_mi_start_drv_threads(adapter, _TRUE);
}
static void _rtw_mi_stop_drv_threads(_adapter *adapter, bool exclude_self)
{
int i;
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface) {
if ((exclude_self) && (iface == adapter))
continue;
rtw_stop_drv_threads(iface);
}
}
}
void rtw_mi_stop_drv_threads(_adapter *adapter)
{
_rtw_mi_stop_drv_threads(adapter, _FALSE);
}
void rtw_mi_buddy_stop_drv_threads(_adapter *adapter)
{
_rtw_mi_stop_drv_threads(adapter, _TRUE);
}
static u8 _rtw_mi_cancel_all_timer(_adapter *adapter, void *data)
{
rtw_cancel_all_timer(adapter);
return _TRUE;
}
void rtw_mi_cancel_all_timer(_adapter *adapter)
{
_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_cancel_all_timer);
}
void rtw_mi_buddy_cancel_all_timer(_adapter *adapter)
{
_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_cancel_all_timer);
}
static u8 _rtw_mi_reset_drv_sw(_adapter *adapter, void *data)
{
rtw_reset_drv_sw(adapter);
return _TRUE;
}
void rtw_mi_reset_drv_sw(_adapter *adapter)
{
_rtw_mi_process_without_schk(adapter, _FALSE, NULL, _rtw_mi_reset_drv_sw);
}
void rtw_mi_buddy_reset_drv_sw(_adapter *adapter)
{
_rtw_mi_process_without_schk(adapter, _TRUE, NULL, _rtw_mi_reset_drv_sw);
}
static u8 _rtw_mi_intf_start(_adapter *adapter, void *data)
{
rtw_intf_start(adapter);
return _TRUE;
}
void rtw_mi_intf_start(_adapter *adapter)
{
_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_intf_start);
}
void rtw_mi_buddy_intf_start(_adapter *adapter)
{
_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_intf_start);
}
static u8 _rtw_mi_intf_stop(_adapter *adapter, void *data)
{
rtw_intf_stop(adapter);
return _TRUE;
}
void rtw_mi_intf_stop(_adapter *adapter)
{
_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_intf_stop);
}
void rtw_mi_buddy_intf_stop(_adapter *adapter)
{
_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_intf_stop);
}
#ifdef CONFIG_NEW_NETDEV_HDL
u8 rtw_mi_hal_iface_init(_adapter *padapter)
{
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 ret = _TRUE;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface && iface->netif_up)
rtw_hal_iface_init(padapter);
}
return ret;
}
#endif
static u8 _rtw_mi_suspend_free_assoc_resource(_adapter *padapter, void *data)
{
return rtw_suspend_free_assoc_resource(padapter);
}
void rtw_mi_suspend_free_assoc_resource(_adapter *adapter)
{
_rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_suspend_free_assoc_resource);
}
void rtw_mi_buddy_suspend_free_assoc_resource(_adapter *adapter)
{
_rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_suspend_free_assoc_resource);
}
static u8 _rtw_mi_is_scan_deny(_adapter *adapter, void *data)
{
return rtw_is_scan_deny(adapter);
}
u8 rtw_mi_is_scan_deny(_adapter *adapter)
{
return _rtw_mi_process(adapter, _FALSE, NULL, _rtw_mi_is_scan_deny);
}
u8 rtw_mi_buddy_is_scan_deny(_adapter *adapter)
{
return _rtw_mi_process(adapter, _TRUE, NULL, _rtw_mi_is_scan_deny);
}
#ifdef CONFIG_SET_SCAN_DENY_TIMER
static u8 _rtw_mi_set_scan_deny(_adapter *adapter, void *data)
{
u32 ms = *(u32 *)data;
rtw_set_scan_deny(adapter, ms);
return _TRUE;
}
void rtw_mi_set_scan_deny(_adapter *adapter, u32 ms)
{
u32 in_data = ms;
_rtw_mi_process(adapter, _FALSE, &in_data, _rtw_mi_set_scan_deny);
}
void rtw_mi_buddy_set_scan_deny(_adapter *adapter, u32 ms)
{
u32 in_data = ms;
_rtw_mi_process(adapter, _TRUE, &in_data, _rtw_mi_set_scan_deny);
}
#endif /*CONFIG_SET_SCAN_DENY_TIMER*/
static u8 _rtw_mi_beacon_update(_adapter *padapter, void *data)
{
if (!MLME_IS_STA(padapter)
&& check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE) {
RTW_INFO(ADPT_FMT" - update_beacon\n", ADPT_ARG(padapter));
update_beacon(padapter, 0xFF, NULL, _TRUE, 0);
}
return _TRUE;
}
void rtw_mi_beacon_update(_adapter *padapter)
{
_rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_beacon_update);
}
void rtw_mi_buddy_beacon_update(_adapter *padapter)
{
_rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_beacon_update);
}
static u8 _rtw_mi_hal_dump_macaddr(_adapter *padapter, void *data)
{
u8 mac_addr[ETH_ALEN] = {0};
rtw_hal_get_hwreg(padapter, HW_VAR_MAC_ADDR, mac_addr);
RTW_INFO(ADPT_FMT"MAC Address ="MAC_FMT"\n", ADPT_ARG(padapter), MAC_ARG(mac_addr));
return _TRUE;
}
void rtw_mi_hal_dump_macaddr(_adapter *padapter)
{
_rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_hal_dump_macaddr);
}
void rtw_mi_buddy_hal_dump_macaddr(_adapter *padapter)
{
_rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_hal_dump_macaddr);
}
#ifdef CONFIG_PCI_HCI
static u8 _rtw_mi_xmit_tasklet_schedule(_adapter *padapter, void *data)
{
if (rtw_txframes_pending(padapter)) {
/* try to deal with the pending packets */
tasklet_hi_schedule(&(padapter->xmitpriv.xmit_tasklet));
}
return _TRUE;
}
void rtw_mi_xmit_tasklet_schedule(_adapter *padapter)
{
_rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_xmit_tasklet_schedule);
}
void rtw_mi_buddy_xmit_tasklet_schedule(_adapter *padapter)
{
_rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_xmit_tasklet_schedule);
}
#endif
u8 _rtw_mi_busy_traffic_check(_adapter *padapter, void *data)
{
u32 passtime;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
bool check_sc_interval = *(bool *)data;
if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE) {
if (check_sc_interval) {
/* Miracast can't do AP scan*/
passtime = rtw_get_passing_time_ms(pmlmepriv->lastscantime);
if (passtime > BUSY_TRAFFIC_SCAN_DENY_PERIOD) {
RTW_INFO(ADPT_FMT" bBusyTraffic == _TRUE\n", ADPT_ARG(padapter));
return _TRUE;
}
} else
return _TRUE;
}
return _FALSE;
}
u8 rtw_mi_busy_traffic_check(_adapter *padapter, bool check_sc_interval)
{
bool in_data = check_sc_interval;
return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_busy_traffic_check);
}
u8 rtw_mi_buddy_busy_traffic_check(_adapter *padapter, bool check_sc_interval)
{
bool in_data = check_sc_interval;
return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_busy_traffic_check);
}
static u8 _rtw_mi_check_mlmeinfo_state(_adapter *padapter, void *data)
{
u32 state = *(u32 *)data;
struct mlme_ext_priv *mlmeext = &padapter->mlmeextpriv;
/*if (mlmeext_msr(mlmeext) == state)*/
if (check_mlmeinfo_state(mlmeext, state))
return _TRUE;
else
return _FALSE;
}
u8 rtw_mi_check_mlmeinfo_state(_adapter *padapter, u32 state)
{
u32 in_data = state;
return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_check_mlmeinfo_state);
}
u8 rtw_mi_buddy_check_mlmeinfo_state(_adapter *padapter, u32 state)
{
u32 in_data = state;
return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_check_mlmeinfo_state);
}
/*#define DBG_DUMP_FW_STATE*/
#ifdef DBG_DUMP_FW_STATE
static void rtw_dbg_dump_fwstate(_adapter *padapter, sint state)
{
u8 buf[32] = {0};
if (state & WIFI_FW_NULL_STATE) {
_rtw_memset(buf, 0, 32);
sprintf(buf, "WIFI_FW_NULL_STATE");
RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
}
if (state & _FW_LINKED) {
_rtw_memset(buf, 0, 32);
sprintf(buf, "_FW_LINKED");
RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
}
if (state & _FW_UNDER_LINKING) {
_rtw_memset(buf, 0, 32);
sprintf(buf, "_FW_UNDER_LINKING");
RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
}
if (state & _FW_UNDER_SURVEY) {
_rtw_memset(buf, 0, 32);
sprintf(buf, "_FW_UNDER_SURVEY");
RTW_INFO(FUNC_ADPT_FMT"fwstate-%s\n", FUNC_ADPT_ARG(padapter), buf);
}
}
#endif
static u8 _rtw_mi_check_fwstate(_adapter *padapter, void *data)
{
u8 ret = _FALSE;
sint state = *(sint *)data;
if ((state == WIFI_FW_NULL_STATE) &&
(padapter->mlmepriv.fw_state == WIFI_FW_NULL_STATE))
ret = _TRUE;
else if (_TRUE == check_fwstate(&padapter->mlmepriv, state))
ret = _TRUE;
#ifdef DBG_DUMP_FW_STATE
if (ret)
rtw_dbg_dump_fwstate(padapter, state);
#endif
return ret;
}
u8 rtw_mi_check_fwstate(_adapter *padapter, sint state)
{
sint in_data = state;
return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_check_fwstate);
}
u8 rtw_mi_buddy_check_fwstate(_adapter *padapter, sint state)
{
sint in_data = state;
return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_check_fwstate);
}
static u8 _rtw_mi_traffic_statistics(_adapter *padapter , void *data)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
/* Tx */
pdvobjpriv->traffic_stat.tx_bytes += padapter->xmitpriv.tx_bytes;
pdvobjpriv->traffic_stat.tx_pkts += padapter->xmitpriv.tx_pkts;
pdvobjpriv->traffic_stat.tx_drop += padapter->xmitpriv.tx_drop;
/* Rx */
pdvobjpriv->traffic_stat.rx_bytes += padapter->recvpriv.rx_bytes;
pdvobjpriv->traffic_stat.rx_pkts += padapter->recvpriv.rx_pkts;
pdvobjpriv->traffic_stat.rx_drop += padapter->recvpriv.rx_drop;
return _TRUE;
}
u8 rtw_mi_traffic_statistics(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_traffic_statistics);
}
static u8 _rtw_mi_check_miracast_enabled(_adapter *padapter , void *data)
{
return is_miracast_enabled(padapter);
}
u8 rtw_mi_check_miracast_enabled(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_check_miracast_enabled);
}
#ifdef CONFIG_XMIT_THREAD_MODE
static u8 _rtw_mi_check_pending_xmitbuf(_adapter *padapter , void *data)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
return check_pending_xmitbuf(pxmitpriv);
}
u8 rtw_mi_check_pending_xmitbuf(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_check_pending_xmitbuf);
}
u8 rtw_mi_buddy_check_pending_xmitbuf(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_check_pending_xmitbuf);
}
#endif
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
static u8 _rtw_mi_dequeue_writeport(_adapter *padapter , bool exclude_self)
{
int i;
u8 queue_empty = _TRUE;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
if ((exclude_self) && (iface == padapter))
continue;
queue_empty &= _dequeue_writeport(iface);
}
}
return queue_empty;
}
u8 rtw_mi_dequeue_writeport(_adapter *padapter)
{
return _rtw_mi_dequeue_writeport(padapter, _FALSE);
}
u8 rtw_mi_buddy_dequeue_writeport(_adapter *padapter)
{
return _rtw_mi_dequeue_writeport(padapter, _TRUE);
}
#endif
static void _rtw_mi_adapter_reset(_adapter *padapter , u8 exclude_self)
{
int i;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
for (i = 0; i < dvobj->iface_nums; i++) {
if (dvobj->padapters[i]) {
if ((exclude_self) && (dvobj->padapters[i] == padapter))
continue;
dvobj->padapters[i] = NULL;
}
}
}
void rtw_mi_adapter_reset(_adapter *padapter)
{
_rtw_mi_adapter_reset(padapter, _FALSE);
}
void rtw_mi_buddy_adapter_reset(_adapter *padapter)
{
_rtw_mi_adapter_reset(padapter, _TRUE);
}
static u8 _rtw_mi_dynamic_check_timer_handlder(_adapter *adapter, void *data)
{
rtw_iface_dynamic_check_timer_handlder(adapter);
return _TRUE;
}
u8 rtw_mi_dynamic_check_timer_handlder(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_dynamic_check_timer_handlder);
}
u8 rtw_mi_buddy_dynamic_check_timer_handlder(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dynamic_check_timer_handlder);
}
static u8 _rtw_mi_dynamic_chk_wk_hdl(_adapter *adapter, void *data)
{
rtw_iface_dynamic_chk_wk_hdl(adapter);
return _TRUE;
}
u8 rtw_mi_dynamic_chk_wk_hdl(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_dynamic_chk_wk_hdl);
}
u8 rtw_mi_buddy_dynamic_chk_wk_hdl(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_dynamic_chk_wk_hdl);
}
static u8 _rtw_mi_os_xmit_schedule(_adapter *adapter, void *data)
{
rtw_os_xmit_schedule(adapter);
return _TRUE;
}
u8 rtw_mi_os_xmit_schedule(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_os_xmit_schedule);
}
u8 rtw_mi_buddy_os_xmit_schedule(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_os_xmit_schedule);
}
static u8 _rtw_mi_report_survey_event(_adapter *adapter, void *data)
{
union recv_frame *precv_frame = (union recv_frame *)data;
report_survey_event(adapter, precv_frame);
return _TRUE;
}
u8 rtw_mi_report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
{
return _rtw_mi_process(padapter, _FALSE, precv_frame, _rtw_mi_report_survey_event);
}
u8 rtw_mi_buddy_report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
{
return _rtw_mi_process(padapter, _TRUE, precv_frame, _rtw_mi_report_survey_event);
}
static u8 _rtw_mi_sreset_adapter_hdl(_adapter *adapter, void *data)
{
u8 bstart = *(u8 *)data;
if (bstart)
sreset_start_adapter(adapter);
else
sreset_stop_adapter(adapter);
return _TRUE;
}
u8 rtw_mi_sreset_adapter_hdl(_adapter *padapter, u8 bstart)
{
u8 in_data = bstart;
return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_sreset_adapter_hdl);
}
u8 rtw_mi_buddy_sreset_adapter_hdl(_adapter *padapter, u8 bstart)
{
u8 in_data = bstart;
return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_sreset_adapter_hdl);
}
static u8 _rtw_mi_tx_beacon_hdl(_adapter *adapter, void *data)
{
if ((MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))
&& check_fwstate(&adapter->mlmepriv, WIFI_ASOC_STATE) == _TRUE
) {
adapter->mlmepriv.update_bcn = _TRUE;
#ifndef CONFIG_INTERRUPT_BASED_TXBCN
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) || defined(CONFIG_PCI_BCN_POLLING)
tx_beacon_hdl(adapter, NULL);
#endif
#endif
}
return _TRUE;
}
u8 rtw_mi_tx_beacon_hdl(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_tx_beacon_hdl);
}
u8 rtw_mi_buddy_tx_beacon_hdl(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_sreset_adapter_hdl);
}
static u8 _rtw_mi_set_tx_beacon_cmd(_adapter *adapter, void *data)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
if (pmlmepriv->update_bcn == _TRUE)
set_tx_beacon_cmd(adapter, 0);
}
return _TRUE;
}
u8 rtw_mi_set_tx_beacon_cmd(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_set_tx_beacon_cmd);
}
u8 rtw_mi_buddy_set_tx_beacon_cmd(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_set_tx_beacon_cmd);
}
#ifdef CONFIG_P2P
static u8 _rtw_mi_p2p_chk_state(_adapter *adapter, void *data)
{
struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
enum P2P_STATE state = *(enum P2P_STATE *)data;
return rtw_p2p_chk_state(pwdinfo, state);
}
u8 rtw_mi_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state)
{
u8 in_data = p2p_state;
return _rtw_mi_process(padapter, _FALSE, &in_data, _rtw_mi_p2p_chk_state);
}
u8 rtw_mi_buddy_p2p_chk_state(_adapter *padapter, enum P2P_STATE p2p_state)
{
u8 in_data = p2p_state;
return _rtw_mi_process(padapter, _TRUE, &in_data, _rtw_mi_p2p_chk_state);
}
static u8 _rtw_mi_stay_in_p2p_mode(_adapter *adapter, void *data)
{
struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
if (rtw_p2p_role(pwdinfo) != P2P_ROLE_DISABLE)
return _TRUE;
return _FALSE;
}
u8 rtw_mi_stay_in_p2p_mode(_adapter *padapter)
{
return _rtw_mi_process(padapter, _FALSE, NULL, _rtw_mi_stay_in_p2p_mode);
}
u8 rtw_mi_buddy_stay_in_p2p_mode(_adapter *padapter)
{
return _rtw_mi_process(padapter, _TRUE, NULL, _rtw_mi_stay_in_p2p_mode);
}
#endif /*CONFIG_P2P*/
_adapter *rtw_get_iface_by_id(_adapter *padapter, u8 iface_id)
{
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
if ((padapter == NULL) || (iface_id >= CONFIG_IFACE_NUMBER)) {
rtw_warn_on(1);
return iface;
}
return dvobj->padapters[iface_id];
}
_adapter *rtw_get_iface_by_macddr(_adapter *padapter, const u8 *mac_addr)
{
int i;
_adapter *iface = NULL;
u8 bmatch = _FALSE;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && (_rtw_memcmp(mac_addr, adapter_mac_addr(iface), ETH_ALEN))) {
bmatch = _TRUE;
break;
}
}
if (bmatch)
return iface;
else
return NULL;
}
_adapter *rtw_get_iface_by_hwport(_adapter *padapter, u8 hw_port)
{
int i;
_adapter *iface = NULL;
u8 bmatch = _FALSE;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && (hw_port == iface->hw_port)) {
bmatch = _TRUE;
break;
}
}
if (bmatch)
return iface;
else
return NULL;
}
/*#define CONFIG_SKB_ALLOCATED*/
#define DBG_SKB_PROCESS
#ifdef DBG_SKB_PROCESS
void rtw_dbg_skb_process(_adapter *padapter, union recv_frame *precvframe, union recv_frame *pcloneframe)
{
_pkt *pkt_copy, *pkt_org;
pkt_org = precvframe->u.hdr.pkt;
pkt_copy = pcloneframe->u.hdr.pkt;
/*
RTW_INFO("%s ===== ORG SKB =====\n", __func__);
RTW_INFO(" SKB head(%p)\n", pkt_org->head);
RTW_INFO(" SKB data(%p)\n", pkt_org->data);
RTW_INFO(" SKB tail(%p)\n", pkt_org->tail);
RTW_INFO(" SKB end(%p)\n", pkt_org->end);
RTW_INFO(" recv frame head(%p)\n", precvframe->u.hdr.rx_head);
RTW_INFO(" recv frame data(%p)\n", precvframe->u.hdr.rx_data);
RTW_INFO(" recv frame tail(%p)\n", precvframe->u.hdr.rx_tail);
RTW_INFO(" recv frame end(%p)\n", precvframe->u.hdr.rx_end);
RTW_INFO("%s ===== COPY SKB =====\n", __func__);
RTW_INFO(" SKB head(%p)\n", pkt_copy->head);
RTW_INFO(" SKB data(%p)\n", pkt_copy->data);
RTW_INFO(" SKB tail(%p)\n", pkt_copy->tail);
RTW_INFO(" SKB end(%p)\n", pkt_copy->end);
RTW_INFO(" recv frame head(%p)\n", pcloneframe->u.hdr.rx_head);
RTW_INFO(" recv frame data(%p)\n", pcloneframe->u.hdr.rx_data);
RTW_INFO(" recv frame tail(%p)\n", pcloneframe->u.hdr.rx_tail);
RTW_INFO(" recv frame end(%p)\n", pcloneframe->u.hdr.rx_end);
*/
/*
RTW_INFO("%s => recv_frame adapter(%p,%p)\n", __func__, precvframe->u.hdr.adapter, pcloneframe->u.hdr.adapter);
RTW_INFO("%s => recv_frame dev(%p,%p)\n", __func__, pkt_org->dev , pkt_copy->dev);
RTW_INFO("%s => recv_frame len(%d,%d)\n", __func__, precvframe->u.hdr.len, pcloneframe->u.hdr.len);
*/
if (precvframe->u.hdr.len != pcloneframe->u.hdr.len)
RTW_INFO("%s [WARN] recv_frame length(%d:%d) compare failed\n", __func__, precvframe->u.hdr.len, pcloneframe->u.hdr.len);
if (_rtw_memcmp(&precvframe->u.hdr.attrib, &pcloneframe->u.hdr.attrib, sizeof(struct rx_pkt_attrib)) == _FALSE)
RTW_INFO("%s [WARN] recv_frame attrib compare failed\n", __func__);
if (_rtw_memcmp(precvframe->u.hdr.rx_data, pcloneframe->u.hdr.rx_data, precvframe->u.hdr.len) == _FALSE)
RTW_INFO("%s [WARN] recv_frame rx_data compare failed\n", __func__);
}
#endif
static s32 _rtw_mi_buddy_clone_bcmc_packet(_adapter *adapter, union recv_frame *precvframe, u8 *pphy_status, union recv_frame *pcloneframe)
{
s32 ret = _SUCCESS;
#ifdef CONFIG_SKB_ALLOCATED
u8 *pbuf = precvframe->u.hdr.rx_data;
#endif
struct rx_pkt_attrib *pattrib = NULL;
if (pcloneframe) {
pcloneframe->u.hdr.adapter = adapter;
_rtw_init_listhead(&pcloneframe->u.hdr.list);
pcloneframe->u.hdr.precvbuf = NULL; /*can't access the precvbuf for new arch.*/
pcloneframe->u.hdr.len = 0;
_rtw_memcpy(&pcloneframe->u.hdr.attrib, &precvframe->u.hdr.attrib, sizeof(struct rx_pkt_attrib));
pattrib = &pcloneframe->u.hdr.attrib;
#ifdef CONFIG_SKB_ALLOCATED
if (rtw_os_alloc_recvframe(adapter, pcloneframe, pbuf, NULL) == _SUCCESS)
#else
if (rtw_os_recvframe_duplicate_skb(adapter, pcloneframe, precvframe->u.hdr.pkt) == _SUCCESS)
#endif
{
#ifdef CONFIG_SKB_ALLOCATED
recvframe_put(pcloneframe, pattrib->pkt_len);
#endif
#ifdef DBG_SKB_PROCESS
rtw_dbg_skb_process(adapter, precvframe, pcloneframe);
#endif
if (pphy_status)
rx_query_phy_status(pcloneframe, pphy_status);
ret = rtw_recv_entry(pcloneframe);
} else {
ret = -1;
RTW_INFO("%s()-%d: rtw_os_alloc_recvframe() failed!\n", __func__, __LINE__);
}
}
return ret;
}
void rtw_mi_buddy_clone_bcmc_packet(_adapter *padapter, union recv_frame *precvframe, u8 *pphy_status)
{
int i;
s32 ret = _SUCCESS;
_adapter *iface = NULL;
union recv_frame *pcloneframe = NULL;
struct recv_priv *precvpriv = &padapter->recvpriv;/*primary_padapter*/
_queue *pfree_recv_queue = &precvpriv->free_recv_queue;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 *fhead = get_recvframe_data(precvframe);
u8 type = GetFrameType(fhead);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface || iface == padapter)
continue;
if (rtw_is_adapter_up(iface) == _FALSE || iface->registered == 0)
continue;
if (type == WIFI_DATA_TYPE && !adapter_allow_bmc_data_rx(iface))
continue;
pcloneframe = rtw_alloc_recvframe(pfree_recv_queue);
if (pcloneframe) {
ret = _rtw_mi_buddy_clone_bcmc_packet(iface, precvframe, pphy_status, pcloneframe);
if (_SUCCESS != ret) {
if (ret == -1)
rtw_free_recvframe(pcloneframe, pfree_recv_queue);
/*RTW_INFO(ADPT_FMT"-clone BC/MC frame failed\n", ADPT_ARG(iface));*/
}
}
}
}
#ifdef CONFIG_PCI_HCI
/*API be created temporary for MI, caller is interrupt-handler, PCIE's interrupt handler cannot apply to multi-AP*/
_adapter *rtw_mi_get_ap_adapter(_adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
int i;
_adapter *iface = NULL;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE
&& check_fwstate(&iface->mlmepriv, WIFI_ASOC_STATE) == _TRUE)
break;
}
return iface;
}
#endif
u8 rtw_mi_get_ld_sta_ifbmp(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
int i;
_adapter *iface = NULL;
u8 ifbmp = 0;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (MLME_IS_STA(iface) && MLME_IS_ASOC(iface))
ifbmp |= BIT(i);
}
return ifbmp;
}
u8 rtw_mi_get_ap_mesh_ifbmp(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
int i;
_adapter *iface = NULL;
u8 ifbmp = 0;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (CHK_MLME_STATE(iface, WIFI_AP_STATE | WIFI_MESH_STATE)
&& MLME_IS_ASOC(iface))
ifbmp |= BIT(i);
}
return ifbmp;
}
void rtw_mi_update_ap_bmc_camid(_adapter *padapter, u8 camid_a, u8 camid_b)
{
#ifdef CONFIG_CONCURRENT_MODE
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
int i;
_adapter *iface = NULL;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (macid_ctl->iface_bmc[iface->iface_id] != INVALID_SEC_MAC_CAM_ID) {
if (macid_ctl->iface_bmc[iface->iface_id] == camid_a)
macid_ctl->iface_bmc[iface->iface_id] = camid_b;
else if (macid_ctl->iface_bmc[iface->iface_id] == camid_b)
macid_ctl->iface_bmc[iface->iface_id] = camid_a;
iface->securitypriv.dot118021x_bmc_cam_id = macid_ctl->iface_bmc[iface->iface_id];
}
}
#endif
}
u8 rtw_mi_get_assoc_if_num(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 n_assoc_iface = 0;
#if 1
u8 i;
for (i = 0; i < dvobj->iface_nums; i++) {
if (check_fwstate(&(dvobj->padapters[i]->mlmepriv), WIFI_ASOC_STATE))
n_assoc_iface++;
}
#else
n_assoc_iface = DEV_STA_LD_NUM(dvobj) + DEV_AP_NUM(dvobj) + DEV_ADHOC_NUM(dvobj) + DEV_MESH_NUM(dvobj);
#endif
return n_assoc_iface;
}
================================================
FILE: core/rtw_mlme.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_MLME_C_
#include
extern void indicate_wx_scan_complete_event(_adapter *padapter);
extern u8 rtw_do_join(_adapter *padapter);
void rtw_init_mlme_timer(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
rtw_init_timer(&(pmlmepriv->assoc_timer), padapter, rtw_join_timeout_handler, padapter);
rtw_init_timer(&(pmlmepriv->scan_to_timer), padapter, rtw_scan_timeout_handler, padapter);
#ifdef CONFIG_SET_SCAN_DENY_TIMER
rtw_init_timer(&(pmlmepriv->set_scan_deny_timer), padapter, rtw_set_scan_deny_timer_hdl, padapter);
#endif
#ifdef RTK_DMP_PLATFORM
_init_workitem(&(pmlmepriv->Linkup_workitem), Linkup_workitem_callback, padapter);
_init_workitem(&(pmlmepriv->Linkdown_workitem), Linkdown_workitem_callback, padapter);
#endif
}
sint _rtw_init_mlme_priv(_adapter *padapter)
{
sint i;
u8 *pbuf;
struct wlan_network *pnetwork;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
sint res = _SUCCESS;
/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
/* _rtw_memset((u8 *)pmlmepriv, 0, sizeof(struct mlme_priv)); */
/*qos_priv*/
/*pmlmepriv->qospriv.qos_option = pregistrypriv->wmm_enable;*/
/*ht_priv*/
#ifdef CONFIG_80211N_HT
pmlmepriv->htpriv.ampdu_enable = _FALSE;/*set to disabled*/
#endif
pmlmepriv->nic_hdl = (u8 *)padapter;
pmlmepriv->pscanned = NULL;
init_fwstate(pmlmepriv, WIFI_STATION_STATE);
pmlmepriv->cur_network.network.InfrastructureMode = Ndis802_11AutoUnknown;
pmlmepriv->scan_mode = SCAN_ACTIVE; /* 1: active, 0: pasive. Maybe someday we should rename this varable to "active_mode" (Jeff) */
_rtw_spinlock_init(&(pmlmepriv->lock));
_rtw_init_queue(&(pmlmepriv->free_bss_pool));
_rtw_init_queue(&(pmlmepriv->scanned_queue));
set_scanned_network_val(pmlmepriv, 0);
_rtw_memset(&pmlmepriv->assoc_ssid, 0, sizeof(NDIS_802_11_SSID));
if (padapter->registrypriv.max_bss_cnt != 0)
pmlmepriv->max_bss_cnt = padapter->registrypriv.max_bss_cnt;
else if (rfctl->max_chan_nums <= MAX_CHANNEL_NUM_2G)
pmlmepriv->max_bss_cnt = MAX_BSS_CNT;
else
pmlmepriv->max_bss_cnt = MAX_BSS_CNT + MAX_BSS_CNT;
pbuf = rtw_zvmalloc(pmlmepriv->max_bss_cnt * (sizeof(struct wlan_network)));
if (pbuf == NULL) {
res = _FAIL;
goto exit;
}
pmlmepriv->free_bss_buf = pbuf;
pnetwork = (struct wlan_network *)pbuf;
for (i = 0; i < pmlmepriv->max_bss_cnt; i++) {
_rtw_init_listhead(&(pnetwork->list));
rtw_list_insert_tail(&(pnetwork->list), &(pmlmepriv->free_bss_pool.queue));
pnetwork++;
}
/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
rtw_clear_scan_deny(padapter);
#ifdef CONFIG_ARP_KEEP_ALIVE
pmlmepriv->bGetGateway = 0;
pmlmepriv->GetGatewayTryCnt = 0;
#endif
#ifdef CONFIG_LAYER2_ROAMING
#define RTW_ROAM_SCAN_RESULT_EXP_MS (5*1000)
#define RTW_ROAM_RSSI_DIFF_TH 10
#define RTW_ROAM_SCAN_INTERVAL (5) /* 5*(2 second)*/
#define RTW_ROAM_RSSI_THRESHOLD 70
pmlmepriv->roam_flags = 0
| RTW_ROAM_ON_EXPIRED
#ifdef CONFIG_LAYER2_ROAMING_RESUME
| RTW_ROAM_ON_RESUME
#endif
#ifdef CONFIG_LAYER2_ROAMING_ACTIVE
| RTW_ROAM_ACTIVE
#endif
;
pmlmepriv->roam_scanr_exp_ms = RTW_ROAM_SCAN_RESULT_EXP_MS;
pmlmepriv->roam_rssi_diff_th = RTW_ROAM_RSSI_DIFF_TH;
pmlmepriv->roam_scan_int = RTW_ROAM_SCAN_INTERVAL;
pmlmepriv->roam_rssi_threshold = RTW_ROAM_RSSI_THRESHOLD;
pmlmepriv->need_to_roam = _FALSE;
pmlmepriv->last_roaming = rtw_get_current_time();
#endif /* CONFIG_LAYER2_ROAMING */
#ifdef CONFIG_RTW_80211R
rtw_ft_info_init(&pmlmepriv->ft_roam);
#endif
#ifdef CONFIG_LAYER2_ROAMING
#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
rtw_roam_nb_info_init(padapter);
pmlmepriv->ch_cnt = 0;
#endif
#endif
rtw_init_mlme_timer(padapter);
exit:
return res;
}
void rtw_mfree_mlme_priv_lock(struct mlme_priv *pmlmepriv);
void rtw_mfree_mlme_priv_lock(struct mlme_priv *pmlmepriv)
{
_rtw_spinlock_free(&pmlmepriv->lock);
_rtw_spinlock_free(&(pmlmepriv->free_bss_pool.lock));
_rtw_spinlock_free(&(pmlmepriv->scanned_queue.lock));
}
static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
{
if (*ppie) {
rtw_mfree(*ppie, *plen);
*plen = 0;
*ppie = NULL;
}
}
void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
{
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
rtw_buf_free(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len);
rtw_buf_free(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len);
rtw_free_mlme_ie_data(&pmlmepriv->wps_beacon_ie, &pmlmepriv->wps_beacon_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_req_ie, &pmlmepriv->wps_probe_req_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_resp_ie, &pmlmepriv->wps_probe_resp_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wps_assoc_resp_ie, &pmlmepriv->wps_assoc_resp_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->p2p_beacon_ie, &pmlmepriv->p2p_beacon_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->p2p_probe_req_ie, &pmlmepriv->p2p_probe_req_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->p2p_probe_resp_ie, &pmlmepriv->p2p_probe_resp_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->p2p_go_probe_resp_ie, &pmlmepriv->p2p_go_probe_resp_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->p2p_assoc_req_ie, &pmlmepriv->p2p_assoc_req_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->p2p_assoc_resp_ie, &pmlmepriv->p2p_assoc_resp_ie_len);
#endif
#if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
rtw_free_mlme_ie_data(&pmlmepriv->wfd_beacon_ie, &pmlmepriv->wfd_beacon_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_req_ie, &pmlmepriv->wfd_probe_req_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wfd_probe_resp_ie, &pmlmepriv->wfd_probe_resp_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wfd_go_probe_resp_ie, &pmlmepriv->wfd_go_probe_resp_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wfd_assoc_req_ie, &pmlmepriv->wfd_assoc_req_ie_len);
rtw_free_mlme_ie_data(&pmlmepriv->wfd_assoc_resp_ie, &pmlmepriv->wfd_assoc_resp_ie_len);
#endif
#ifdef CONFIG_RTW_80211R
rtw_free_mlme_ie_data(&pmlmepriv->auth_rsp, &pmlmepriv->auth_rsp_len);
#endif
}
#if defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211)
int rtw_mlme_update_wfd_ie_data(struct mlme_priv *mlme, u8 type, u8 *ie, u32 ie_len)
{
_adapter *adapter = mlme_to_adapter(mlme);
struct wifi_display_info *wfd_info = &adapter->wfd_info;
u8 clear = 0;
u8 **t_ie = NULL;
u32 *t_ie_len = NULL;
int ret = _FAIL;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
goto success;
if (wfd_info->wfd_enable == _TRUE)
goto success; /* WFD IE is build by self */
if (!ie && !ie_len)
clear = 1;
else if (!ie || !ie_len) {
RTW_PRINT(FUNC_ADPT_FMT" type:%u, ie:%p, ie_len:%u"
, FUNC_ADPT_ARG(adapter), type, ie, ie_len);
rtw_warn_on(1);
goto exit;
}
switch (type) {
case MLME_BEACON_IE:
t_ie = &mlme->wfd_beacon_ie;
t_ie_len = &mlme->wfd_beacon_ie_len;
break;
case MLME_PROBE_REQ_IE:
t_ie = &mlme->wfd_probe_req_ie;
t_ie_len = &mlme->wfd_probe_req_ie_len;
break;
case MLME_PROBE_RESP_IE:
t_ie = &mlme->wfd_probe_resp_ie;
t_ie_len = &mlme->wfd_probe_resp_ie_len;
break;
case MLME_GO_PROBE_RESP_IE:
t_ie = &mlme->wfd_go_probe_resp_ie;
t_ie_len = &mlme->wfd_go_probe_resp_ie_len;
break;
case MLME_ASSOC_REQ_IE:
t_ie = &mlme->wfd_assoc_req_ie;
t_ie_len = &mlme->wfd_assoc_req_ie_len;
break;
case MLME_ASSOC_RESP_IE:
t_ie = &mlme->wfd_assoc_resp_ie;
t_ie_len = &mlme->wfd_assoc_resp_ie_len;
break;
default:
RTW_PRINT(FUNC_ADPT_FMT" unsupported type:%u"
, FUNC_ADPT_ARG(adapter), type);
rtw_warn_on(1);
goto exit;
}
if (*t_ie) {
u32 free_len = *t_ie_len;
*t_ie_len = 0;
rtw_mfree(*t_ie, free_len);
*t_ie = NULL;
}
if (!clear) {
*t_ie = rtw_malloc(ie_len);
if (*t_ie == NULL) {
RTW_ERR(FUNC_ADPT_FMT" type:%u, rtw_malloc() fail\n"
, FUNC_ADPT_ARG(adapter), type);
goto exit;
}
_rtw_memcpy(*t_ie, ie, ie_len);
*t_ie_len = ie_len;
}
if (*t_ie && *t_ie_len) {
u8 *attr_content;
u32 attr_contentlen = 0;
attr_content = rtw_get_wfd_attr_content(*t_ie, *t_ie_len, WFD_ATTR_DEVICE_INFO, NULL, &attr_contentlen);
if (attr_content && attr_contentlen) {
if (RTW_GET_BE16(attr_content + 2) != wfd_info->rtsp_ctrlport) {
wfd_info->rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
RTW_INFO(FUNC_ADPT_FMT" type:%u, RTSP CTRL port = %u\n"
, FUNC_ADPT_ARG(adapter), type, wfd_info->rtsp_ctrlport);
}
}
}
success:
ret = _SUCCESS;
exit:
return ret;
}
#endif /* defined(CONFIG_WFD) && defined(CONFIG_IOCTL_CFG80211) */
void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
{
_adapter *adapter = mlme_to_adapter(pmlmepriv);
if (NULL == pmlmepriv) {
rtw_warn_on(1);
goto exit;
}
rtw_free_mlme_priv_ie_data(pmlmepriv);
if (pmlmepriv) {
rtw_mfree_mlme_priv_lock(pmlmepriv);
if (pmlmepriv->free_bss_buf)
rtw_vmfree(pmlmepriv->free_bss_buf, pmlmepriv->max_bss_cnt * sizeof(struct wlan_network));
}
exit:
return;
}
sint _rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork)
{
_irqL irqL;
if (pnetwork == NULL)
goto exit;
_enter_critical_bh(&queue->lock, &irqL);
rtw_list_insert_tail(&pnetwork->list, &queue->queue);
_exit_critical_bh(&queue->lock, &irqL);
exit:
return _SUCCESS;
}
/*
struct wlan_network *_rtw_dequeue_network(_queue *queue)
{
_irqL irqL;
struct wlan_network *pnetwork;
_enter_critical_bh(&queue->lock, &irqL);
if (_rtw_queue_empty(queue) == _TRUE)
pnetwork = NULL;
else
{
pnetwork = LIST_CONTAINOR(get_next(&queue->queue), struct wlan_network, list);
rtw_list_delete(&(pnetwork->list));
}
_exit_critical_bh(&queue->lock, &irqL);
return pnetwork;
}
*/
struct wlan_network *_rtw_alloc_network(struct mlme_priv *pmlmepriv) /* (_queue *free_queue) */
{
_irqL irqL;
struct wlan_network *pnetwork;
_queue *free_queue = &pmlmepriv->free_bss_pool;
_list *plist = NULL;
_enter_critical_bh(&free_queue->lock, &irqL);
if (_rtw_queue_empty(free_queue) == _TRUE) {
pnetwork = NULL;
goto exit;
}
plist = get_next(&(free_queue->queue));
pnetwork = LIST_CONTAINOR(plist , struct wlan_network, list);
rtw_list_delete(&pnetwork->list);
pnetwork->network_type = 0;
pnetwork->fixed = _FALSE;
pnetwork->last_scanned = rtw_get_current_time();
#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
pnetwork->acnode_stime = 0;
pnetwork->acnode_notify_etime = 0;
#endif
pnetwork->aid = 0;
pnetwork->join_res = 0;
pmlmepriv->num_of_scanned++;
exit:
_exit_critical_bh(&free_queue->lock, &irqL);
return pnetwork;
}
void _rtw_free_network(struct mlme_priv *pmlmepriv , struct wlan_network *pnetwork, u8 isfreeall)
{
u32 delta_time;
u32 lifetime = SCANQUEUE_LIFETIME;
_irqL irqL;
_queue *free_queue = &(pmlmepriv->free_bss_pool);
if (pnetwork == NULL)
goto exit;
if (pnetwork->fixed == _TRUE)
goto exit;
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE))
lifetime = 1;
if (!isfreeall) {
delta_time = (u32) rtw_get_passing_time_ms(pnetwork->last_scanned);
if (delta_time < lifetime) /* unit:msec */
goto exit;
}
_enter_critical_bh(&free_queue->lock, &irqL);
rtw_list_delete(&(pnetwork->list));
rtw_list_insert_tail(&(pnetwork->list), &(free_queue->queue));
pmlmepriv->num_of_scanned--;
/* RTW_INFO("_rtw_free_network:SSID=%s\n", pnetwork->network.Ssid.Ssid); */
_exit_critical_bh(&free_queue->lock, &irqL);
exit:
return;
}
void _rtw_free_network_nolock(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork)
{
_queue *free_queue = &(pmlmepriv->free_bss_pool);
if (pnetwork == NULL)
goto exit;
if (pnetwork->fixed == _TRUE)
goto exit;
/* _enter_critical(&free_queue->lock, &irqL); */
rtw_list_delete(&(pnetwork->list));
rtw_list_insert_tail(&(pnetwork->list), get_list_head(free_queue));
pmlmepriv->num_of_scanned--;
/* _exit_critical(&free_queue->lock, &irqL); */
exit:
return;
}
void _rtw_free_network_queue(_adapter *padapter, u8 isfreeall)
{
_irqL irqL;
_list *phead, *plist;
struct wlan_network *pnetwork;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
_queue *scanned_queue = &pmlmepriv->scanned_queue;
_enter_critical_bh(&scanned_queue->lock, &irqL);
phead = get_list_head(scanned_queue);
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
plist = get_next(plist);
_rtw_free_network(pmlmepriv, pnetwork, isfreeall);
}
_exit_critical_bh(&scanned_queue->lock, &irqL);
}
sint rtw_if_up(_adapter *padapter)
{
sint res;
if (RTW_CANNOT_RUN(padapter) ||
(check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
res = _FALSE;
} else
res = _TRUE;
return res;
}
void rtw_generate_random_ibss(u8 *pibss)
{
*((u32 *)(&pibss[2])) = rtw_random32();
pibss[0] = 0x02; /* in ad-hoc mode local bit must set to 1 */
pibss[1] = 0x11;
pibss[2] = 0x87;
}
u8 *rtw_get_capability_from_ie(u8 *ie)
{
return ie + 8 + 2;
}
u16 rtw_get_capability(WLAN_BSSID_EX *bss)
{
u16 val;
_rtw_memcpy((u8 *)&val, rtw_get_capability_from_ie(bss->IEs), 2);
return le16_to_cpu(val);
}
u8 *rtw_get_timestampe_from_ie(u8 *ie)
{
return ie + 0;
}
u8 *rtw_get_beacon_interval_from_ie(u8 *ie)
{
return ie + 8;
}
int rtw_init_mlme_priv(_adapter *padapter) /* (struct mlme_priv *pmlmepriv) */
{
int res;
res = _rtw_init_mlme_priv(padapter);/* (pmlmepriv); */
return res;
}
void rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
{
_rtw_free_mlme_priv(pmlmepriv);
}
int rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork);
int rtw_enqueue_network(_queue *queue, struct wlan_network *pnetwork)
{
int res;
res = _rtw_enqueue_network(queue, pnetwork);
return res;
}
/*
static struct wlan_network *rtw_dequeue_network(_queue *queue)
{
struct wlan_network *pnetwork;
pnetwork = _rtw_dequeue_network(queue);
return pnetwork;
}
*/
struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv);
struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv) /* (_queue *free_queue) */
{
struct wlan_network *pnetwork;
pnetwork = _rtw_alloc_network(pmlmepriv);
return pnetwork;
}
void rtw_free_network(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork, u8 is_freeall);
void rtw_free_network(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork, u8 is_freeall)/* (struct wlan_network *pnetwork, _queue *free_queue) */
{
_rtw_free_network(pmlmepriv, pnetwork, is_freeall);
}
void rtw_free_network_nolock(_adapter *padapter, struct wlan_network *pnetwork);
void rtw_free_network_nolock(_adapter *padapter, struct wlan_network *pnetwork)
{
_rtw_free_network_nolock(&(padapter->mlmepriv), pnetwork);
#ifdef CONFIG_IOCTL_CFG80211
rtw_cfg80211_unlink_bss(padapter, pnetwork);
#endif /* CONFIG_IOCTL_CFG80211 */
}
void rtw_free_network_queue(_adapter *dev, u8 isfreeall)
{
_rtw_free_network_queue(dev, isfreeall);
}
struct wlan_network *_rtw_find_network(_queue *scanned_queue, const u8 *addr)
{
_list *phead, *plist;
struct wlan_network *pnetwork = NULL;
u8 zero_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
if (_rtw_memcmp(zero_addr, addr, ETH_ALEN)) {
pnetwork = NULL;
goto exit;
}
phead = get_list_head(scanned_queue);
plist = get_next(phead);
while (plist != phead) {
pnetwork = LIST_CONTAINOR(plist, struct wlan_network , list);
if (_rtw_memcmp(addr, pnetwork->network.MacAddress, ETH_ALEN) == _TRUE)
break;
plist = get_next(plist);
}
if (plist == phead)
pnetwork = NULL;
exit:
return pnetwork;
}
struct wlan_network *rtw_find_network(_queue *scanned_queue, const u8 *addr)
{
struct wlan_network *pnetwork;
_irqL irqL;
_enter_critical_bh(&scanned_queue->lock, &irqL);
pnetwork = _rtw_find_network(scanned_queue, addr);
_exit_critical_bh(&scanned_queue->lock, &irqL);
return pnetwork;
}
int rtw_is_same_ibss(_adapter *adapter, struct wlan_network *pnetwork)
{
int ret = _TRUE;
struct security_priv *psecuritypriv = &adapter->securitypriv;
if ((psecuritypriv->dot11PrivacyAlgrthm != _NO_PRIVACY_) &&
(pnetwork->network.Privacy == 0))
ret = _FALSE;
else if ((psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_) &&
(pnetwork->network.Privacy == 1))
ret = _FALSE;
else
ret = _TRUE;
return ret;
}
inline int is_same_ess(WLAN_BSSID_EX *a, WLAN_BSSID_EX *b)
{
return (a->Ssid.SsidLength == b->Ssid.SsidLength)
&& _rtw_memcmp(a->Ssid.Ssid, b->Ssid.Ssid, a->Ssid.SsidLength) == _TRUE;
}
int is_same_network(WLAN_BSSID_EX *src, WLAN_BSSID_EX *dst, u8 feature)
{
u16 s_cap, d_cap;
if (rtw_bug_check(dst, src, &s_cap, &d_cap) == _FALSE)
return _FALSE;
_rtw_memcpy((u8 *)&s_cap, rtw_get_capability_from_ie(src->IEs), 2);
_rtw_memcpy((u8 *)&d_cap, rtw_get_capability_from_ie(dst->IEs), 2);
s_cap = le16_to_cpu(s_cap);
d_cap = le16_to_cpu(d_cap);
#ifdef CONFIG_P2P
if ((feature == 1) && /* 1: P2P supported */
(_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN) == _TRUE)
)
return _TRUE;
#endif
/* Wi-Fi driver doesn't consider the situation of BCN and ProbRsp sent from the same hidden AP,
* it considers these two packets are sent from different AP.
* Therefore, the scan queue may store two scan results of the same hidden AP, likes below.
*
* index bssid ch RSSI SdBm Noise age flag ssid
* 1 00:e0:4c:55:50:01 153 -73 -73 0 7044 [WPS][ESS] RTK5G
* 3 00:e0:4c:55:50:01 153 -73 -73 0 7044 [WPS][ESS]
*
* Original rules will compare Ssid, SsidLength, MacAddress, s_cap, d_cap at the same time.
* Wi-Fi driver will assume that the BCN and ProbRsp sent from the same hidden AP are the same network
* after we add an additional rule to compare SsidLength and Ssid.
* It means the scan queue will not store two scan results of the same hidden AP, it only store ProbRsp.
* For customer request.
*/
if (((_rtw_memcmp(src->MacAddress, dst->MacAddress, ETH_ALEN)) == _TRUE) &&
((s_cap & WLAN_CAPABILITY_IBSS) == (d_cap & WLAN_CAPABILITY_IBSS)) &&
((s_cap & WLAN_CAPABILITY_BSS) == (d_cap & WLAN_CAPABILITY_BSS))) {
if ((src->Ssid.SsidLength == dst->Ssid.SsidLength) &&
(((_rtw_memcmp(src->Ssid.Ssid, dst->Ssid.Ssid, src->Ssid.SsidLength)) == _TRUE) || //Case of normal AP
(is_all_null(src->Ssid.Ssid, src->Ssid.SsidLength) == _TRUE || is_all_null(dst->Ssid.Ssid, dst->Ssid.SsidLength) == _TRUE))) //Case of hidden AP
return _TRUE;
else if ((src->Ssid.SsidLength == 0 || dst->Ssid.SsidLength == 0)) //Case of hidden AP
return _TRUE;
else
return _FALSE;
} else {
return _FALSE;
}
}
struct wlan_network *_rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network)
{
_list *phead, *plist;
struct wlan_network *found = NULL;
phead = get_list_head(scanned_queue);
plist = get_next(phead);
while (plist != phead) {
found = LIST_CONTAINOR(plist, struct wlan_network , list);
if (is_same_network(&network->network, &found->network, 0))
break;
plist = get_next(plist);
}
if (plist == phead)
found = NULL;
return found;
}
struct wlan_network *rtw_find_same_network(_queue *scanned_queue, struct wlan_network *network)
{
_irqL irqL;
struct wlan_network *found = NULL;
if (scanned_queue == NULL || network == NULL)
goto exit;
_enter_critical_bh(&scanned_queue->lock, &irqL);
found = _rtw_find_same_network(scanned_queue, network);
_exit_critical_bh(&scanned_queue->lock, &irqL);
exit:
return found;
}
struct wlan_network *rtw_get_oldest_wlan_network(_queue *scanned_queue)
{
_list *plist, *phead;
struct wlan_network *pwlan = NULL;
struct wlan_network *oldest = NULL;
phead = get_list_head(scanned_queue);
plist = get_next(phead);
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pwlan = LIST_CONTAINOR(plist, struct wlan_network, list);
if (pwlan->fixed != _TRUE) {
if (oldest == NULL || rtw_time_after(oldest->last_scanned, pwlan->last_scanned))
oldest = pwlan;
}
plist = get_next(plist);
}
return oldest;
}
void update_network(WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src,
_adapter *padapter, bool update_ie)
{
#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
u8 ss_ori = dst->PhyInfo.SignalStrength;
u8 sq_ori = dst->PhyInfo.SignalQuality;
u8 ss_smp = src->PhyInfo.SignalStrength;
long rssi_smp = src->Rssi;
#endif
long rssi_ori = dst->Rssi;
u8 sq_smp = src->PhyInfo.SignalQuality;
u8 ss_final;
u8 sq_final;
long rssi_final;
#ifdef CONFIG_ANTENNA_DIVERSITY
rtw_hal_antdiv_rssi_compared(padapter, dst, src); /* this will update src.Rssi, need consider again */
#endif
#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
if (strcmp(dst->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
RTW_INFO(FUNC_ADPT_FMT" %s("MAC_FMT", ch%u) ss_ori:%3u, sq_ori:%3u, rssi_ori:%3ld, ss_smp:%3u, sq_smp:%3u, rssi_smp:%3ld\n"
, FUNC_ADPT_ARG(padapter)
, src->Ssid.Ssid, MAC_ARG(src->MacAddress), src->Configuration.DSConfig
, ss_ori, sq_ori, rssi_ori
, ss_smp, sq_smp, rssi_smp
);
}
#endif
/* The rule below is 1/5 for sample value, 4/5 for history value */
if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) && is_same_network(&(padapter->mlmepriv.cur_network.network), src, 0)) {
/* Take the recvpriv's value for the connected AP*/
ss_final = padapter->recvpriv.signal_strength;
sq_final = padapter->recvpriv.signal_qual;
/* the rssi value here is undecorated, and will be used for antenna diversity */
if (sq_smp != 101) /* from the right channel */
rssi_final = (src->Rssi + dst->Rssi * 4) / 5;
else
rssi_final = rssi_ori;
} else {
if (sq_smp != 101) { /* from the right channel */
ss_final = ((u32)(src->PhyInfo.SignalStrength) + (u32)(dst->PhyInfo.SignalStrength) * 4) / 5;
sq_final = ((u32)(src->PhyInfo.SignalQuality) + (u32)(dst->PhyInfo.SignalQuality) * 4) / 5;
rssi_final = (src->Rssi + dst->Rssi * 4) / 5;
} else {
/* bss info not receving from the right channel, use the original RX signal infos */
ss_final = dst->PhyInfo.SignalStrength;
sq_final = dst->PhyInfo.SignalQuality;
rssi_final = dst->Rssi;
}
}
if (update_ie) {
dst->Reserved[0] = src->Reserved[0];
dst->Reserved[1] = src->Reserved[1];
_rtw_memcpy((u8 *)dst, (u8 *)src, get_WLAN_BSSID_EX_sz(src));
}
dst->PhyInfo.SignalStrength = ss_final;
dst->PhyInfo.SignalQuality = sq_final;
dst->Rssi = rssi_final;
#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) && 1
if (strcmp(dst->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
RTW_INFO(FUNC_ADPT_FMT" %s("MAC_FMT"), SignalStrength:%u, SignalQuality:%u, RawRSSI:%ld\n"
, FUNC_ADPT_ARG(padapter)
, dst->Ssid.Ssid, MAC_ARG(dst->MacAddress), dst->PhyInfo.SignalStrength, dst->PhyInfo.SignalQuality, dst->Rssi);
}
#endif
#if 0 /* old codes, may be useful one day...
* RTW_INFO("update_network: rssi=0x%lx dst->Rssi=%d ,dst->Rssi=0x%lx , src->Rssi=0x%lx",(dst->Rssi+src->Rssi)/2,dst->Rssi,dst->Rssi,src->Rssi); */
if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) && is_same_network(&(padapter->mlmepriv.cur_network.network), src)) {
/* RTW_INFO("b:ssid=%s update_network: src->rssi=0x%d padapter->recvpriv.ui_rssi=%d\n",src->Ssid.Ssid,src->Rssi,padapter->recvpriv.signal); */
if (padapter->recvpriv.signal_qual_data.total_num++ >= PHY_LINKQUALITY_SLID_WIN_MAX) {
padapter->recvpriv.signal_qual_data.total_num = PHY_LINKQUALITY_SLID_WIN_MAX;
last_evm = padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index];
padapter->recvpriv.signal_qual_data.total_val -= last_evm;
}
padapter->recvpriv.signal_qual_data.total_val += query_rx_pwr_percentage(src->Rssi);
padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index++] = query_rx_pwr_percentage(src->Rssi);
if (padapter->recvpriv.signal_qual_data.index >= PHY_LINKQUALITY_SLID_WIN_MAX)
padapter->recvpriv.signal_qual_data.index = 0;
/* RTW_INFO("Total SQ=%d pattrib->signal_qual= %d\n", padapter->recvpriv.signal_qual_data.total_val, src->Rssi); */
/* <1> Showed on UI for user,in percentage. */
tmpVal = padapter->recvpriv.signal_qual_data.total_val / padapter->recvpriv.signal_qual_data.total_num;
padapter->recvpriv.signal = (u8)tmpVal; /* Link quality */
src->Rssi = translate_percentage_to_dbm(padapter->recvpriv.signal) ;
} else {
/* RTW_INFO("ELSE:ssid=%s update_network: src->rssi=0x%d dst->rssi=%d\n",src->Ssid.Ssid,src->Rssi,dst->Rssi); */
src->Rssi = (src->Rssi + dst->Rssi) / 2; /* dBM */
}
/* RTW_INFO("a:update_network: src->rssi=0x%d padapter->recvpriv.ui_rssi=%d\n",src->Rssi,padapter->recvpriv.signal); */
#endif
}
static void update_current_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)
{
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
rtw_bug_check(&(pmlmepriv->cur_network.network),
&(pmlmepriv->cur_network.network),
&(pmlmepriv->cur_network.network),
&(pmlmepriv->cur_network.network));
if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && (is_same_network(&(pmlmepriv->cur_network.network), pnetwork, 0))) {
/* if(pmlmepriv->cur_network.network.IELength<= pnetwork->IELength) */
{
update_network(&(pmlmepriv->cur_network.network), pnetwork, adapter, _TRUE);
rtw_update_protection(adapter, (pmlmepriv->cur_network.network.IEs) + sizeof(NDIS_802_11_FIXED_IEs),
pmlmepriv->cur_network.network.IELength);
}
}
}
/*
Caller must hold pmlmepriv->lock first.
*/
bool rtw_update_scanned_network(_adapter *adapter, WLAN_BSSID_EX *target)
{
_irqL irqL;
_list *plist, *phead;
u32 bssid_ex_sz;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
#endif /* CONFIG_P2P */
_queue *queue = &(pmlmepriv->scanned_queue);
struct wlan_network *pnetwork = NULL;
struct wlan_network *choice = NULL;
int target_find = 0;
u8 feature = 0;
bool update_ie = _FALSE;
_enter_critical_bh(&queue->lock, &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
#if 0
RTW_INFO("%s => ssid:%s , rssi:%ld , ss:%d\n",
__func__, target->Ssid.Ssid, target->Rssi, target->PhyInfo.SignalStrength);
#endif
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
feature = 1; /* p2p enable */
#endif
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
rtw_bug_check(pnetwork, pnetwork, pnetwork, pnetwork);
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) &&
(_rtw_memcmp(pnetwork->network.MacAddress, target->MacAddress, ETH_ALEN) == _TRUE)) {
target_find = 1;
break;
}
#endif
if (is_same_network(&(pnetwork->network), target, feature)) {
target_find = 1;
break;
}
if (rtw_roam_flags(adapter)) {
/* TODO: don't select netowrk in the same ess as choice if it's new enough*/
}
if (pnetwork->fixed) {
plist = get_next(plist);
continue;
}
#ifdef CONFIG_RSSI_PRIORITY
if ((choice == NULL) || (pnetwork->network.PhyInfo.SignalStrength < choice->network.PhyInfo.SignalStrength))
#ifdef CONFIG_RTW_MESH
if (!MLME_IS_MESH(adapter) || !MLME_IS_ASOC(adapter)
|| !rtw_bss_is_same_mbss(&pmlmepriv->cur_network.network, &pnetwork->network))
#endif
choice = pnetwork;
#else
if (choice == NULL || rtw_time_after(choice->last_scanned, pnetwork->last_scanned))
#ifdef CONFIG_RTW_MESH
if (!MLME_IS_MESH(adapter) || !MLME_IS_ASOC(adapter)
|| !rtw_bss_is_same_mbss(&pmlmepriv->cur_network.network, &pnetwork->network))
#endif
choice = pnetwork;
#endif
plist = get_next(plist);
}
/* If we didn't find a match, then get a new network slot to initialize
* with this beacon's information */
/* if (rtw_end_of_queue_search(phead,plist)== _TRUE) { */
if (!target_find) {
if (_rtw_queue_empty(&(pmlmepriv->free_bss_pool)) == _TRUE) {
/* If there are no more slots, expire the choice */
/* list_del_init(&choice->list); */
pnetwork = choice;
if (pnetwork == NULL)
goto unlock_scan_queue;
#ifdef CONFIG_RSSI_PRIORITY
RTW_DBG("%s => ssid:%s ,bssid:"MAC_FMT" will be deleted from scanned_queue (rssi:%ld , ss:%d)\n",
__func__, pnetwork->network.Ssid.Ssid, MAC_ARG(pnetwork->network.MacAddress), pnetwork->network.Rssi, pnetwork->network.PhyInfo.SignalStrength);
#else
RTW_DBG("%s => ssid:%s ,bssid:"MAC_FMT" will be deleted from scanned_queue\n",
__func__, pnetwork->network.Ssid.Ssid, MAC_ARG(pnetwork->network.MacAddress));
#endif
#ifdef CONFIG_ANTENNA_DIVERSITY
rtw_hal_get_odm_var(adapter, HAL_ODM_ANTDIV_SELECT, &(target->PhyInfo.Optimum_antenna), NULL);
#endif
_rtw_memcpy(&(pnetwork->network), target, get_WLAN_BSSID_EX_sz(target));
/* pnetwork->last_scanned = rtw_get_current_time(); */
/* variable initialize */
pnetwork->fixed = _FALSE;
pnetwork->last_scanned = rtw_get_current_time();
#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
pnetwork->acnode_stime = 0;
pnetwork->acnode_notify_etime = 0;
#endif
pnetwork->network_type = 0;
pnetwork->aid = 0;
pnetwork->join_res = 0;
/* bss info not receving from the right channel */
if (pnetwork->network.PhyInfo.SignalQuality == 101)
pnetwork->network.PhyInfo.SignalQuality = 0;
} else {
/* Otherwise just pull from the free list */
pnetwork = rtw_alloc_network(pmlmepriv); /* will update scan_time */
if (pnetwork == NULL)
goto unlock_scan_queue;
bssid_ex_sz = get_WLAN_BSSID_EX_sz(target);
target->Length = bssid_ex_sz;
#ifdef CONFIG_ANTENNA_DIVERSITY
rtw_hal_get_odm_var(adapter, HAL_ODM_ANTDIV_SELECT, &(target->PhyInfo.Optimum_antenna), NULL);
#endif
_rtw_memcpy(&(pnetwork->network), target, bssid_ex_sz);
pnetwork->last_scanned = rtw_get_current_time();
/* bss info not receving from the right channel */
if (pnetwork->network.PhyInfo.SignalQuality == 101)
pnetwork->network.PhyInfo.SignalQuality = 0;
rtw_list_insert_tail(&(pnetwork->list), &(queue->queue));
}
} else {
/* we have an entry and we are going to update it. But this entry may
* be already expired. In this case we do the same as we found a new
* net and call the new_net handler
*/
#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
systime last_scanned = pnetwork->last_scanned;
#endif
pnetwork->last_scanned = rtw_get_current_time();
/* target.Reserved[0]==BSS_TYPE_BCN, means that scanned network is a bcn frame. */
if ((pnetwork->network.IELength > target->IELength) && (target->Reserved[0] == BSS_TYPE_BCN))
update_ie = _FALSE;
if (MLME_IS_MESH(adapter)
/* probe resp(3) > beacon(1) > probe req(2) */
|| (target->Reserved[0] != BSS_TYPE_PROB_REQ
&& target->Reserved[0] >= pnetwork->network.Reserved[0])
)
update_ie = _TRUE;
else
update_ie = _FALSE;
#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
if (!MLME_IS_MESH(adapter) || !MLME_IS_ASOC(adapter)
|| pnetwork->network.Configuration.DSConfig != target->Configuration.DSConfig
|| rtw_get_passing_time_ms(last_scanned) > adapter->mesh_cfg.peer_sel_policy.scanr_exp_ms
|| !rtw_bss_is_same_mbss(&pnetwork->network, target)
) {
pnetwork->acnode_stime = 0;
pnetwork->acnode_notify_etime = 0;
}
#endif
update_network(&(pnetwork->network), target, adapter, update_ie);
}
#if defined(CONFIG_RTW_MESH) && CONFIG_RTW_MESH_ACNODE_PREVENT
if (MLME_IS_MESH(adapter) && MLME_IS_ASOC(adapter))
rtw_mesh_update_scanned_acnode_status(adapter, pnetwork);
#endif
unlock_scan_queue:
_exit_critical_bh(&queue->lock, &irqL);
#ifdef CONFIG_RTW_MESH
if (pnetwork && MLME_IS_MESH(adapter)
&& check_fwstate(pmlmepriv, WIFI_ASOC_STATE)
&& !check_fwstate(pmlmepriv, WIFI_SITE_MONITOR)
)
rtw_chk_candidate_peer_notify(adapter, pnetwork);
#endif
return update_ie;
}
void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork);
void rtw_add_network(_adapter *adapter, WLAN_BSSID_EX *pnetwork)
{
bool update_ie;
/* _queue *queue = &(pmlmepriv->scanned_queue); */
/* _enter_critical_bh(&queue->lock, &irqL); */
#if defined(CONFIG_P2P) && defined(CONFIG_P2P_REMOVE_GROUP_INFO)
if (adapter->registrypriv.wifi_spec == 0)
rtw_bss_ex_del_p2p_attr(pnetwork, P2P_ATTR_GROUP_INFO);
#endif
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
rtw_bss_ex_del_wfd_ie(pnetwork);
/* Wi-Fi driver will update the current network if the scan result of the connected AP be updated by scan. */
update_ie = rtw_update_scanned_network(adapter, pnetwork);
if (update_ie)
update_current_network(adapter, pnetwork);
/* _exit_critical_bh(&queue->lock, &irqL); */
}
/* select the desired network based on the capability of the (i)bss.
* check items: (1) security
* (2) network_type
* (3) WMM
* (4) HT
* (5) others */
int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork);
int rtw_is_desired_network(_adapter *adapter, struct wlan_network *pnetwork)
{
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
u32 desired_encmode;
u32 privacy;
/* u8 wps_ie[512]; */
uint wps_ielen;
int bselected = _TRUE;
desired_encmode = psecuritypriv->ndisencryptstatus;
privacy = pnetwork->network.Privacy;
if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
if (rtw_get_wps_ie(pnetwork->network.IEs + _FIXED_IE_LENGTH_, pnetwork->network.IELength - _FIXED_IE_LENGTH_, NULL, &wps_ielen) != NULL)
return _TRUE;
else
return _FALSE;
}
if (adapter->registrypriv.wifi_spec == 1) { /* for correct flow of 8021X to do.... */
u8 *p = NULL;
uint ie_len = 0;
if ((desired_encmode == Ndis802_11EncryptionDisabled) && (privacy != 0))
bselected = _FALSE;
if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
p = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, _RSN_IE_2_, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0)
bselected = _TRUE;
else
bselected = _FALSE;
}
}
if ((desired_encmode != Ndis802_11EncryptionDisabled) && (privacy == 0)) {
RTW_INFO("desired_encmode: %d, privacy: %d\n", desired_encmode, privacy);
bselected = _FALSE;
}
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) {
if (pnetwork->network.InfrastructureMode != pmlmepriv->cur_network.network.InfrastructureMode)
bselected = _FALSE;
}
return bselected;
}
/* TODO: Perry : For Power Management */
void rtw_atimdone_event_callback(_adapter *adapter , u8 *pbuf)
{
return;
}
void rtw_survey_event_callback(_adapter *adapter, u8 *pbuf)
{
_irqL irqL;
u32 len;
WLAN_BSSID_EX *pnetwork;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
pnetwork = (WLAN_BSSID_EX *)pbuf;
len = get_WLAN_BSSID_EX_sz(pnetwork);
if (len > (sizeof(WLAN_BSSID_EX))) {
return;
}
_enter_critical_bh(&pmlmepriv->lock, &irqL);
/* update IBSS_network 's timestamp */
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) == _TRUE) {
if (_rtw_memcmp(&(pmlmepriv->cur_network.network.MacAddress), pnetwork->MacAddress, ETH_ALEN)) {
struct wlan_network *ibss_wlan = NULL;
_irqL irqL;
_rtw_memcpy(pmlmepriv->cur_network.network.IEs, pnetwork->IEs, 8);
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
ibss_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, pnetwork->MacAddress);
if (ibss_wlan) {
_rtw_memcpy(ibss_wlan->network.IEs , pnetwork->IEs, 8);
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
goto exit;
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
}
}
/* lock pmlmepriv->lock when you accessing network_q */
if ((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _FALSE) {
if (pnetwork->Ssid.Ssid[0] == 0)
pnetwork->Ssid.SsidLength = 0;
rtw_add_network(adapter, pnetwork);
}
exit:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
return;
}
void rtw_surveydone_event_callback(_adapter *adapter, u8 *pbuf)
{
_irqL irqL;
struct sitesurvey_parm parm;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
#ifdef CONFIG_RTW_80211R
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
#endif
#ifdef CONFIG_MLME_EXT
mlmeext_surveydone_event_callback(adapter);
#endif
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if (pmlmepriv->wps_probe_req_ie) {
u32 free_len = pmlmepriv->wps_probe_req_ie_len;
pmlmepriv->wps_probe_req_ie_len = 0;
rtw_mfree(pmlmepriv->wps_probe_req_ie, free_len);
pmlmepriv->wps_probe_req_ie = NULL;
}
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _FALSE) {
RTW_INFO(FUNC_ADPT_FMT" fw_state:0x%x\n", FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
/* rtw_warn_on(1); */
}
_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
_cancel_timer_ex(&pmlmepriv->scan_to_timer);
_enter_critical_bh(&pmlmepriv->lock, &irqL);
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
rtw_set_signal_stat_timer(&adapter->recvpriv);
#endif
if (pmlmepriv->to_join == _TRUE) {
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)) {
if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
if (rtw_select_and_join_from_scanned_queue(pmlmepriv) == _SUCCESS)
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
else {
WLAN_BSSID_EX *pdev_network = &(adapter->registrypriv.dev_network);
u8 *pibss = adapter->registrypriv.dev_network.MacAddress;
/* pmlmepriv->fw_state ^= _FW_UNDER_SURVEY; */ /* because don't set assoc_timer */
_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
_rtw_memset(&pdev_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
_rtw_memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
rtw_update_registrypriv_dev_network(adapter);
rtw_generate_random_ibss(pibss);
/*pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;*/
init_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
if (rtw_create_ibss_cmd(adapter, 0) != _SUCCESS)
RTW_ERR("rtw_create_ibss_cmd FAIL\n");
pmlmepriv->to_join = _FALSE;
}
}
} else {
int s_ret;
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
pmlmepriv->to_join = _FALSE;
s_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
if (_SUCCESS == s_ret)
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
else if (s_ret == 2) { /* there is no need to wait for join */
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
rtw_indicate_connect(adapter);
} else {
RTW_INFO("try_to_join, but select scanning queue fail, to_roam:%d\n", rtw_to_roam(adapter));
if (rtw_to_roam(adapter) != 0) {
u8 ssc_chk = rtw_sitesurvey_condition_check(adapter, _FALSE);
rtw_init_sitesurvey_parm(adapter, &parm);
_rtw_memcpy(&parm.ssid[0], &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
parm.ssid_num = 1;
if (rtw_dec_to_roam(adapter) == 0
|| (ssc_chk != SS_ALLOW && ssc_chk != SS_DENY_BUSY_TRAFFIC)
|| _SUCCESS != rtw_sitesurvey_cmd(adapter, &parm)
) {
rtw_set_to_roam(adapter, 0);
rtw_free_assoc_resources(adapter, _TRUE);
rtw_indicate_disconnect(adapter, 0, _FALSE);
} else
pmlmepriv->to_join = _TRUE;
} else
rtw_indicate_disconnect(adapter, 0, _FALSE);
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
}
}
} else {
if (rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
&& check_fwstate(pmlmepriv, _FW_LINKED)) {
if (rtw_select_roaming_candidate(pmlmepriv) == _SUCCESS) {
#ifdef CONFIG_RTW_80211R
rtw_ft_start_roam(adapter,
(u8 *)pmlmepriv->roam_network->network.MacAddress);
#else
receive_disconnect(adapter, pmlmepriv->cur_network.network.MacAddress
, WLAN_REASON_ACTIVE_ROAM, _FALSE);
#endif
}
}
}
}
/* RTW_INFO("scan complete in %dms\n",rtw_get_passing_time_ms(pmlmepriv->scan_start_time)); */
_exit_critical_bh(&pmlmepriv->lock, &irqL);
#ifdef CONFIG_P2P_PS
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
p2p_ps_wk_cmd(adapter, P2P_PS_SCAN_DONE, 0);
#endif /* CONFIG_P2P_PS */
rtw_mi_os_xmit_schedule(adapter);
#ifdef CONFIG_DRVEXT_MODULE_WSC
drvext_surveydone_callback(&adapter->drvextpriv);
#endif
#ifdef DBG_CONFIG_ERROR_DETECT
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
if (pmlmeext->sitesurvey_res.bss_cnt == 0) {
/* rtw_hal_sreset_reset(adapter); */
}
}
#endif
#ifdef CONFIG_IOCTL_CFG80211
rtw_cfg80211_surveydone_event_callback(adapter);
#endif /* CONFIG_IOCTL_CFG80211 */
rtw_indicate_scan_done(adapter, _FALSE);
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_IOCTL_CFG80211)
rtw_cfg80211_indicate_scan_done_for_buddy(adapter, _FALSE);
#endif
#ifdef CONFIG_RTW_MESH
#if CONFIG_RTW_MESH_OFFCH_CAND
if (rtw_mesh_offch_candidate_accepted(adapter)) {
u8 ch;
ch = rtw_mesh_select_operating_ch(adapter);
if (ch && pmlmepriv->cur_network.network.Configuration.DSConfig != ch) {
u8 ifbmp = rtw_mi_get_ap_mesh_ifbmp(adapter);
if (ifbmp) {
/* switch to selected channel */
rtw_change_bss_chbw_cmd(adapter, RTW_CMDF_DIRECTLY, ifbmp, 0, ch, REQ_BW_ORI, REQ_OFFSET_NONE);
issue_probereq_ex(adapter, &pmlmepriv->cur_network.network.mesh_id, NULL, 0, 0, 0, 0);
} else
rtw_warn_on(1);
}
}
#endif
#endif /* CONFIG_RTW_MESH */
}
u8 _rtw_sitesurvey_condition_check(const char *caller, _adapter *adapter, bool check_sc_interval)
{
u8 ss_condition = SS_ALLOW;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct registry_priv *registry_par = &adapter->registrypriv;
#ifdef CONFIG_MP_INCLUDED
if (rtw_mp_mode_check(adapter)) {
RTW_INFO("%s ("ADPT_FMT") MP mode block Scan request\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_MP_MODE;
goto _exit;
}
#endif
#ifdef DBG_LA_MODE
if(registry_par->la_mode_en == 1 && MLME_IS_ASOC(adapter)) {
RTW_INFO("%s ("ADPT_FMT") LA debug mode block Scan request\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_LA_MODE;
goto _exit;
}
#endif
#ifdef CONFIG_RTW_REPEATER_SON
if (adapter->rtw_rson_scanstage == RSON_SCAN_PROCESS) {
RTW_INFO("%s ("ADPT_FMT") blocking scan for under rson scanning process\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_RSON_SCANING;
goto _exit;
}
#endif
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(adapter)->block_scan == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") wdev_priv.block_scan is set\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BLOCK_SCAN;
goto _exit;
}
#endif
if (adapter_to_dvobj(adapter)->scan_deny == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") tpt mode, scan deny!\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BLOCK_SCAN;
goto _exit;
}
if (rtw_is_scan_deny(adapter)) {
RTW_INFO("%s ("ADPT_FMT") : scan deny\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BY_DRV;
goto _exit;
}
if (registry_par->adaptivity_en
&& rtw_phydm_get_edcca_flag(adapter)
&& rtw_is_2g_ch(GET_HAL_DATA(adapter)->current_channel)) {
RTW_WARN(FUNC_ADPT_FMT": Adaptivity block scan! (ch=%u)\n",
FUNC_ADPT_ARG(adapter),
GET_HAL_DATA(adapter)->current_channel);
ss_condition = SS_DENY_ADAPTIVITY;
goto _exit;
}
if (check_fwstate(pmlmepriv, WIFI_AP_STATE)){
if(check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!! AP mode process WPS\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_SELF_AP_UNDER_WPS;
goto _exit;
} else if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!!AP mode under linking (fwstate=0x%x)\n",
caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
ss_condition = SS_DENY_SELF_AP_UNDER_LINKING;
goto _exit;
} else if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!!AP mode under survey (fwstate=0x%x)\n",
caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
ss_condition = SS_DENY_SELF_AP_UNDER_SURVEY;
goto _exit;
}
} else {
if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!!STA mode under linking (fwstate=0x%x)\n",
caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
ss_condition = SS_DENY_SELF_STA_UNDER_LINKING;
goto _exit;
} else if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!!STA mode under survey (fwstate=0x%x)\n",
caller, ADPT_ARG(adapter), pmlmepriv->fw_state);
ss_condition = SS_DENY_SELF_STA_UNDER_SURVEY;
goto _exit;
}
}
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(adapter, _FW_UNDER_LINKING | WIFI_UNDER_WPS)) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!! buddy_intf under linking or wps\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BUDDY_UNDER_LINK_WPS;
goto _exit;
} else if (rtw_mi_buddy_check_fwstate(adapter, _FW_UNDER_SURVEY)) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!! buddy_intf under survey\n", caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BUDDY_UNDER_SURVEY;
goto _exit;
}
#endif /* CONFIG_CONCURRENT_MODE */
if (pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!! BusyTraffic\n",
caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BUSY_TRAFFIC;
goto _exit;
}
/*
* Rule for Android.
* If scan interval > BUSY_TRAFFIC_SCAN_DENY_PERIOD,
* it is a periodical background scan.
* Skip background scan when other interface is busy.
*/
if ((rtw_get_passing_time_ms(pmlmepriv->lastscantime) > BUSY_TRAFFIC_SCAN_DENY_PERIOD)
&& rtw_mi_buddy_busy_traffic_check(adapter, _FALSE)) {
RTW_INFO("%s ("ADPT_FMT") : scan abort!! others BusyTraffic\n",
caller, ADPT_ARG(adapter));
ss_condition = SS_DENY_BUSY_TRAFFIC;
goto _exit;
}
_exit :
return ss_condition;
}
void rtw_dummy_event_callback(_adapter *adapter , u8 *pbuf)
{
}
void rtw_fwdbg_event_callback(_adapter *adapter , u8 *pbuf)
{
}
static void free_scanqueue(struct mlme_priv *pmlmepriv)
{
_irqL irqL, irqL0;
_queue *free_queue = &pmlmepriv->free_bss_pool;
_queue *scan_queue = &pmlmepriv->scanned_queue;
_list *plist, *phead, *ptemp;
_enter_critical_bh(&scan_queue->lock, &irqL0);
_enter_critical_bh(&free_queue->lock, &irqL);
phead = get_list_head(scan_queue);
plist = get_next(phead);
while (plist != phead) {
ptemp = get_next(plist);
rtw_list_delete(plist);
rtw_list_insert_tail(plist, &free_queue->queue);
plist = ptemp;
pmlmepriv->num_of_scanned--;
}
_exit_critical_bh(&free_queue->lock, &irqL);
_exit_critical_bh(&scan_queue->lock, &irqL0);
}
void rtw_reset_rx_info(_adapter *adapter)
{
struct recv_priv *precvpriv = &adapter->recvpriv;
precvpriv->dbg_rx_ampdu_drop_count = 0;
precvpriv->dbg_rx_ampdu_forced_indicate_count = 0;
precvpriv->dbg_rx_ampdu_loss_count = 0;
precvpriv->dbg_rx_dup_mgt_frame_drop_count = 0;
precvpriv->dbg_rx_ampdu_window_shift_cnt = 0;
precvpriv->dbg_rx_drop_count = 0;
precvpriv->dbg_rx_conflic_mac_addr_cnt = 0;
}
/*
*rtw_free_assoc_resources: the caller has to lock pmlmepriv->lock
*/
void rtw_free_assoc_resources(_adapter *adapter, u8 lock_scanned_queue)
{
_irqL irqL;
struct wlan_network *pwlan = NULL;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct wlan_network *tgt_network = &pmlmepriv->cur_network;
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &adapter->tdlsinfo;
#endif /* CONFIG_TDLS */
RTW_INFO("%s-"ADPT_FMT" tgt_network MacAddress=" MAC_FMT" ssid=%s\n",
__func__, ADPT_ARG(adapter), MAC_ARG(tgt_network->network.MacAddress), tgt_network->network.Ssid.Ssid);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
struct sta_info *psta;
psta = rtw_get_stainfo(&adapter->stapriv, tgt_network->network.MacAddress);
#ifdef CONFIG_TDLS
rtw_free_all_tdls_sta(adapter, _TRUE);
rtw_reset_tdls_info(adapter);
if (ptdlsinfo->link_established == _TRUE)
rtw_tdls_cmd(adapter, NULL, TDLS_RS_RCR);
#endif /* CONFIG_TDLS */
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
rtw_free_stainfo(adapter, psta);
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
}
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
struct sta_info *psta;
rtw_free_all_stainfo(adapter);
psta = rtw_get_bcmc_stainfo(adapter);
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
rtw_free_stainfo(adapter, psta);
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
rtw_init_bcmc_stainfo(adapter);
}
if (lock_scanned_queue)
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS) || (pmlmepriv->wpa_phase == _TRUE)){
RTW_INFO("Dont free disconnecting network of scanned_queue due to uner %s %s phase\n\n",
check_fwstate(pmlmepriv, WIFI_UNDER_WPS) ? "WPS" : "",
(pmlmepriv->wpa_phase == _TRUE) ? "WPA" : "");
} else {
pwlan = _rtw_find_same_network(&pmlmepriv->scanned_queue, tgt_network);
if (pwlan) {
pwlan->fixed = _FALSE;
RTW_INFO("Free disconnecting network of scanned_queue\n");
rtw_free_network_nolock(adapter, pwlan);
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
rtw_set_scan_deny(adapter, 2000);
/* rtw_clear_scan_deny(adapter); */
}
#endif /* CONFIG_P2P */
} else
RTW_ERR("Free disconnecting network of scanned_queue failed due to pwlan == NULL\n\n");
}
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) && (adapter->stapriv.asoc_sta_count == 1))
/*||check_fwstate(pmlmepriv, WIFI_STATION_STATE)*/) {
if (pwlan)
rtw_free_network_nolock(adapter, pwlan);
}
if (lock_scanned_queue)
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
adapter->securitypriv.key_mask = 0;
rtw_reset_rx_info(adapter);
}
/*
*rtw_indicate_connect: the caller has to lock pmlmepriv->lock
*/
void rtw_indicate_connect(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
pmlmepriv->to_join = _FALSE;
if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
set_fwstate(pmlmepriv, _FW_LINKED);
rtw_led_control(padapter, LED_CTL_LINK);
rtw_os_indicate_connect(padapter);
}
rtw_set_to_roam(padapter, 0);
if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
rtw_mi_set_scan_deny(padapter, 3000);
}
/*
*rtw_indicate_disconnect: the caller has to lock pmlmepriv->lock
*/
void rtw_indicate_disconnect(_adapter *padapter, u16 reason, u8 locally_generated)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
#ifdef CONFIG_WAPI_SUPPORT
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
#endif
u8 *wps_ie = NULL;
uint wpsie_len = 0;
if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
pmlmepriv->wpa_phase = _TRUE;
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS | WIFI_OP_CH_SWITCHING | WIFI_UNDER_KEY_HANDSHAKE);
/* force to clear cur_network_scanned's SELECTED REGISTRAR */
if (pmlmepriv->cur_network_scanned) {
WLAN_BSSID_EX *current_joined_bss = &(pmlmepriv->cur_network_scanned->network);
if (current_joined_bss) {
wps_ie = rtw_get_wps_ie(current_joined_bss->IEs + _FIXED_IE_LENGTH_,
current_joined_bss->IELength - _FIXED_IE_LENGTH_, NULL, &wpsie_len);
if (wps_ie && wpsie_len > 0) {
u8 *attr = NULL;
u32 attr_len;
attr = rtw_get_wps_attr(wps_ie, wpsie_len, WPS_ATTR_SELECTED_REGISTRAR,
NULL, &attr_len);
if (attr)
*(attr + 4) = 0;
}
}
}
/* RTW_INFO("clear wps when %s\n", __func__); */
if (rtw_to_roam(padapter) > 0)
_clr_fwstate_(pmlmepriv, _FW_LINKED);
#ifdef CONFIG_WAPI_SUPPORT
psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
rtw_wapi_return_one_sta_info(padapter, psta->cmn.mac_addr);
else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))
rtw_wapi_return_all_sta_info(padapter);
#endif
if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)
|| (rtw_to_roam(padapter) <= 0)
) {
rtw_os_indicate_disconnect(padapter, reason, locally_generated);
/* set ips_deny_time to avoid enter IPS before LPS leave */
rtw_set_ips_deny(padapter, 3000);
_clr_fwstate_(pmlmepriv, _FW_LINKED);
rtw_led_control(padapter, LED_CTL_NO_LINK);
rtw_clear_scan_deny(padapter);
}
#ifdef CONFIG_P2P_PS
p2p_ps_wk_cmd(padapter, P2P_PS_DISABLE, 1);
#endif /* CONFIG_P2P_PS */
#ifdef CONFIG_LPS
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_DISCONNECT, 0);
#endif
#ifdef CONFIG_BEAMFORMING
beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_LEAVE, cur_network->MacAddress, ETH_ALEN, 1);
#endif /*CONFIG_BEAMFORMING*/
}
inline void rtw_indicate_scan_done(_adapter *padapter, bool aborted)
{
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
rtw_os_indicate_scan_done(padapter, aborted);
#ifdef CONFIG_IPS
if (is_primary_adapter(padapter)
&& (_FALSE == adapter_to_pwrctl(padapter)->bInSuspend)
&& (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE | WIFI_UNDER_LINKING) == _FALSE)) {
struct pwrctrl_priv *pwrpriv;
pwrpriv = adapter_to_pwrctl(padapter);
rtw_set_ips_deny(padapter, 0);
#ifdef CONFIG_IPS_CHECK_IN_WD
_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 1);
#else /* !CONFIG_IPS_CHECK_IN_WD */
_rtw_set_pwr_state_check_timer(pwrpriv, 1);
#endif /* !CONFIG_IPS_CHECK_IN_WD */
}
#endif /* CONFIG_IPS */
}
static u32 _rtw_wait_scan_done(_adapter *adapter, u8 abort, u32 timeout_ms)
{
systime start;
u32 pass_ms;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
start = rtw_get_current_time();
pmlmeext->scan_abort = abort;
while (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)
&& rtw_get_passing_time_ms(start) <= timeout_ms) {
if (RTW_CANNOT_RUN(adapter))
break;
RTW_INFO(FUNC_NDEV_FMT"fw_state=_FW_UNDER_SURVEY!\n", FUNC_NDEV_ARG(adapter->pnetdev));
rtw_msleep_os(20);
}
if (_TRUE == abort) {
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
if (!RTW_CANNOT_RUN(adapter))
RTW_INFO(FUNC_NDEV_FMT"waiting for scan_abort time out!\n", FUNC_NDEV_ARG(adapter->pnetdev));
#ifdef CONFIG_PLATFORM_MSTAR
/*_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);*/
set_survey_timer(pmlmeext, 0);
mlme_set_scan_to_timer(pmlmepriv, 50);
#endif
rtw_indicate_scan_done(adapter, _TRUE);
}
}
pmlmeext->scan_abort = _FALSE;
pass_ms = rtw_get_passing_time_ms(start);
return pass_ms;
}
void rtw_scan_wait_completed(_adapter *adapter)
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct ss_res *ss = &pmlmeext->sitesurvey_res;
_rtw_wait_scan_done(adapter, _FALSE, ss->scan_timeout_ms);
}
u32 rtw_scan_abort_timeout(_adapter *adapter, u32 timeout_ms)
{
return _rtw_wait_scan_done(adapter, _TRUE, timeout_ms);
}
void rtw_scan_abort_no_wait(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
pmlmeext->scan_abort = _TRUE;
}
void rtw_scan_abort(_adapter *adapter)
{
rtw_scan_abort_timeout(adapter, 200);
}
static u32 _rtw_wait_join_done(_adapter *adapter, u8 abort, u32 timeout_ms)
{
systime start;
u32 pass_ms;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
start = rtw_get_current_time();
pmlmeext->join_abort = abort;
if (abort)
set_link_timer(pmlmeext, 1);
while (rtw_get_passing_time_ms(start) <= timeout_ms
&& (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)
#ifdef CONFIG_IOCTL_CFG80211
|| rtw_cfg80211_is_connect_requested(adapter)
#endif
)
) {
if (RTW_CANNOT_RUN(adapter))
break;
RTW_INFO(FUNC_ADPT_FMT" linking...\n", FUNC_ADPT_ARG(adapter));
rtw_msleep_os(20);
}
if (abort) {
if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)
#ifdef CONFIG_IOCTL_CFG80211
|| rtw_cfg80211_is_connect_requested(adapter)
#endif
) {
if (!RTW_CANNOT_RUN(adapter))
RTW_INFO(FUNC_ADPT_FMT" waiting for join_abort time out!\n", FUNC_ADPT_ARG(adapter));
}
}
pmlmeext->join_abort = 0;
pass_ms = rtw_get_passing_time_ms(start);
return pass_ms;
}
u32 rtw_join_abort_timeout(_adapter *adapter, u32 timeout_ms)
{
return _rtw_wait_join_done(adapter, _TRUE, timeout_ms);
}
static struct sta_info *rtw_joinbss_update_stainfo(_adapter *padapter, struct wlan_network *pnetwork)
{
int i;
struct sta_info *psta = NULL;
struct recv_reorder_ctrl *preorder_ctrl;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
#ifdef CONFIG_RTS_FULL_BW
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
#endif/*CONFIG_RTS_FULL_BW*/
psta = rtw_get_stainfo(pstapriv, pnetwork->network.MacAddress);
if (psta == NULL)
psta = rtw_alloc_stainfo(pstapriv, pnetwork->network.MacAddress);
if (psta) { /* update ptarget_sta */
RTW_INFO("%s\n", __FUNCTION__);
psta->cmn.aid = pnetwork->join_res;
update_sta_info(padapter, psta);
/* update station supportRate */
psta->bssratelen = rtw_get_rateset_len(pnetwork->network.SupportedRates);
_rtw_memcpy(psta->bssrateset, pnetwork->network.SupportedRates, psta->bssratelen);
rtw_hal_update_sta_ra_info(padapter, psta);
psta->wireless_mode = pmlmeext->cur_wireless_mode;
rtw_hal_update_sta_wset(padapter, psta);
/* sta mode */
rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
/* security related */
#ifdef CONFIG_RTW_80211R
if ((padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
&& (psta->ft_pairwise_key_installed == _FALSE)) {
#else
if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
#endif
u8 *ie;
sint ie_len;
u8 mfp_opt = MFP_NO;
padapter->securitypriv.binstallGrpkey = _FALSE;
padapter->securitypriv.busetkipkey = _FALSE;
padapter->securitypriv.bgrpkey_handshake = _FALSE;
ie = rtw_get_ie(pnetwork->network.IEs + _BEACON_IE_OFFSET_, WLAN_EID_RSN
, &ie_len, (pnetwork->network.IELength - _BEACON_IE_OFFSET_));
if (ie && ie_len > 0
&& rtw_parse_wpa2_ie(ie, ie_len + 2, NULL, NULL, NULL, &mfp_opt) == _SUCCESS
) {
if (padapter->securitypriv.mfp_opt >= MFP_OPTIONAL && mfp_opt >= MFP_OPTIONAL)
psta->flags |= WLAN_STA_MFP;
}
psta->ieee8021x_blocked = _TRUE;
psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof(union Keytype));
_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof(union Keytype));
_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof(union Keytype));
}
/* Commented by Albert 2012/07/21 */
/* When doing the WPS, the wps_ie_len won't equal to 0 */
/* And the Wi-Fi driver shouldn't allow the data packet to be tramsmitted. */
if (padapter->securitypriv.wps_ie_len != 0) {
psta->ieee8021x_blocked = _TRUE;
padapter->securitypriv.wps_ie_len = 0;
}
/* for A-MPDU Rx reordering buffer control for sta_info */
/* if A-MPDU Rx is enabled, reseting rx_ordering_ctrl wstart_b(indicate_seq) to default value=0xffff */
/* todo: check if AP can send A-MPDU packets */
for (i = 0; i < 16 ; i++) {
/* preorder_ctrl = &precvpriv->recvreorder_ctrl[i]; */
preorder_ctrl = &psta->recvreorder_ctrl[i];
preorder_ctrl->enable = _FALSE;
preorder_ctrl->indicate_seq = 0xffff;
rtw_clear_bit(RTW_RECV_ACK_OR_TIMEOUT, &preorder_ctrl->rec_abba_rsp_ack);
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_CLEAR indicate_seq:%u preorder_ctrl->rec_abba_rsp_ack:%lu\n"
, FUNC_ADPT_ARG(padapter)
, i
, preorder_ctrl->indicate_seq
,preorder_ctrl->rec_abba_rsp_ack
);
#endif
preorder_ctrl->wend_b = 0xffff;
preorder_ctrl->wsize_b = 64;/* max_ampdu_sz; */ /* ex. 32(kbytes) -> wsize_b=32 */
preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
}
}
#ifdef CONFIG_RTW_80211K
_rtw_memcpy(&psta->rm_en_cap, pnetwork->network.PhyInfo.rm_en_cap, 5);
#endif
#ifdef CONFIG_RTS_FULL_BW
rtw_parse_sta_vendor_ie_8812(padapter, psta, BSS_EX_TLV_IES(&cur_network->network), BSS_EX_TLV_IES_LEN(&cur_network->network));
#endif
return psta;
}
/* pnetwork : returns from rtw_joinbss_event_callback
* ptarget_wlan: found from scanned_queue */
static void rtw_joinbss_update_network(_adapter *padapter, struct wlan_network *ptarget_wlan, struct wlan_network *pnetwork)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
sint tmp_fw_state = 0x0;
RTW_INFO("%s\n", __FUNCTION__);
/* why not use ptarget_wlan?? */
_rtw_memcpy(&cur_network->network, &pnetwork->network, pnetwork->network.Length);
/* some IEs in pnetwork is wrong, so we should use ptarget_wlan IEs */
cur_network->network.IELength = ptarget_wlan->network.IELength;
_rtw_memcpy(&cur_network->network.IEs[0], &ptarget_wlan->network.IEs[0], MAX_IE_SZ);
cur_network->aid = pnetwork->join_res;
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
rtw_set_signal_stat_timer(&padapter->recvpriv);
#endif
padapter->recvpriv.signal_strength = ptarget_wlan->network.PhyInfo.SignalStrength;
padapter->recvpriv.signal_qual = ptarget_wlan->network.PhyInfo.SignalQuality;
/* the ptarget_wlan->network.Rssi is raw data, we use ptarget_wlan->network.PhyInfo.SignalStrength instead (has scaled) */
padapter->recvpriv.rssi = translate_percentage_to_dbm(ptarget_wlan->network.PhyInfo.SignalStrength);
#if defined(DBG_RX_SIGNAL_DISPLAY_PROCESSING) && 1
RTW_INFO(FUNC_ADPT_FMT" signal_strength:%3u, rssi:%3d, signal_qual:%3u"
"\n"
, FUNC_ADPT_ARG(padapter)
, padapter->recvpriv.signal_strength
, padapter->recvpriv.rssi
, padapter->recvpriv.signal_qual
);
#endif
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
rtw_set_signal_stat_timer(&padapter->recvpriv);
#endif
/* update fw_state */ /* will clr _FW_UNDER_LINKING here indirectly */
switch (pnetwork->network.InfrastructureMode) {
case Ndis802_11Infrastructure:
/* Check encryption */
if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
tmp_fw_state = tmp_fw_state | WIFI_UNDER_KEY_HANDSHAKE;
if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS))
tmp_fw_state = tmp_fw_state | WIFI_UNDER_WPS;
init_fwstate(pmlmepriv, WIFI_STATION_STATE | tmp_fw_state);
break;
case Ndis802_11IBSS:
/*pmlmepriv->fw_state = WIFI_ADHOC_STATE;*/
init_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
break;
default:
/*pmlmepriv->fw_state = WIFI_NULL_STATE;*/
init_fwstate(pmlmepriv, WIFI_NULL_STATE);
break;
}
rtw_update_protection(padapter, (cur_network->network.IEs) + sizeof(NDIS_802_11_FIXED_IEs),
(cur_network->network.IELength));
#ifdef CONFIG_80211N_HT
rtw_update_ht_cap(padapter, cur_network->network.IEs, cur_network->network.IELength, (u8) cur_network->network.Configuration.DSConfig);
#endif
}
/* Notes: the fucntion could be > passive_level (the same context as Rx tasklet)
* pnetwork : returns from rtw_joinbss_event_callback
* ptarget_wlan: found from scanned_queue
* if join_res > 0, for (fw_state==WIFI_STATION_STATE), we check if "ptarget_sta" & "ptarget_wlan" exist.
* if join_res > 0, for (fw_state==WIFI_ADHOC_STATE), we only check if "ptarget_wlan" exist.
* if join_res > 0, update "cur_network->network" from "pnetwork->network" if (ptarget_wlan !=NULL).
*/
/* #define REJOIN */
void rtw_joinbss_event_prehandle(_adapter *adapter, u8 *pbuf, u16 status)
{
_irqL irqL;
static u8 retry = 0;
struct sta_info *ptarget_sta = NULL, *pcur_sta = NULL;
struct sta_priv *pstapriv = &adapter->stapriv;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct wlan_network *pnetwork = (struct wlan_network *)pbuf;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
struct wlan_network *pcur_wlan = NULL, *ptarget_wlan = NULL;
unsigned int the_same_macaddr = _FALSE;
rtw_get_encrypt_decrypt_from_registrypriv(adapter);
the_same_macaddr = _rtw_memcmp(pnetwork->network.MacAddress, cur_network->network.MacAddress, ETH_ALEN);
pnetwork->network.Length = get_WLAN_BSSID_EX_sz(&pnetwork->network);
if (pnetwork->network.Length > sizeof(WLAN_BSSID_EX))
goto exit;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
if (pnetwork->join_res > 0) {
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
retry = 0;
if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
/* s1. find ptarget_wlan */
if (check_fwstate(pmlmepriv, _FW_LINKED)) {
if (the_same_macaddr == _TRUE)
ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
else {
pcur_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
if (pcur_wlan)
pcur_wlan->fixed = _FALSE;
pcur_sta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
if (pcur_sta) {
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
rtw_free_stainfo(adapter, pcur_sta);
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
}
ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, pnetwork->network.MacAddress);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
if (ptarget_wlan)
ptarget_wlan->fixed = _TRUE;
}
}
} else {
ptarget_wlan = _rtw_find_same_network(&pmlmepriv->scanned_queue, pnetwork);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
if (ptarget_wlan)
ptarget_wlan->fixed = _TRUE;
}
}
/* s2. update cur_network */
if (ptarget_wlan)
rtw_joinbss_update_network(adapter, ptarget_wlan, pnetwork);
else {
RTW_PRINT("Can't find ptarget_wlan when joinbss_event callback\n");
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
goto ignore_joinbss_callback;
}
/* s3. find ptarget_sta & update ptarget_sta after update cur_network only for station mode */
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
ptarget_sta = rtw_joinbss_update_stainfo(adapter, pnetwork);
if (ptarget_sta == NULL) {
RTW_ERR("Can't update stainfo when joinbss_event callback\n");
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
goto ignore_joinbss_callback;
}
/* Queue TX packets before FW/HW ready */
/* clear in mlmeext_joinbss_event_callback() */
rtw_xmit_queue_set(ptarget_sta);
}
/* s4. indicate connect */
if (MLME_IS_STA(adapter) || MLME_IS_ADHOC(adapter)) {
pmlmepriv->cur_network_scanned = ptarget_wlan;
rtw_indicate_connect(adapter);
}
/* s5. Cancle assoc_timer */
_cancel_timer_ex(&pmlmepriv->assoc_timer);
} else {
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
goto ignore_joinbss_callback;
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
} else if (pnetwork->join_res == -4) {
rtw_reset_securitypriv(adapter);
pmlmepriv->join_status = status;
_set_timer(&pmlmepriv->assoc_timer, 1);
/* rtw_free_assoc_resources(adapter, _TRUE); */
if ((check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) == _TRUE) {
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
}
} else { /* if join_res < 0 (join fails), then try again */
#ifdef REJOIN
res = _FAIL;
if (retry < 2) {
res = rtw_select_and_join_from_scanned_queue(pmlmepriv);
}
if (res == _SUCCESS) {
/* extend time of assoc_timer */
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
retry++;
} else if (res == 2) { /* there is no need to wait for join */
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
rtw_indicate_connect(adapter);
} else {
#endif
pmlmepriv->join_status = status;
_set_timer(&pmlmepriv->assoc_timer, 1);
/* rtw_free_assoc_resources(adapter, _TRUE); */
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
#ifdef REJOIN
retry = 0;
}
#endif
}
ignore_joinbss_callback:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
exit:
return;
}
void rtw_joinbss_event_callback(_adapter *adapter, u8 *pbuf)
{
struct wlan_network *pnetwork = (struct wlan_network *)pbuf;
mlmeext_joinbss_event_callback(adapter, pnetwork->join_res);
rtw_mi_os_xmit_schedule(adapter);
}
void rtw_sta_media_status_rpt(_adapter *adapter, struct sta_info *sta, bool connected)
{
struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
bool miracast_enabled = 0;
bool miracast_sink = 0;
u8 role = H2C_MSR_ROLE_RSVD;
if (sta == NULL) {
RTW_PRINT(FUNC_ADPT_FMT" sta is NULL\n"
, FUNC_ADPT_ARG(adapter));
rtw_warn_on(1);
return;
}
if (sta->cmn.mac_id >= macid_ctl->num) {
RTW_PRINT(FUNC_ADPT_FMT" invalid macid:%u\n"
, FUNC_ADPT_ARG(adapter), sta->cmn.mac_id);
rtw_warn_on(1);
return;
}
if (!rtw_macid_is_used(macid_ctl, sta->cmn.mac_id)) {
RTW_PRINT(FUNC_ADPT_FMT" macid:%u not is used, set connected to 0\n"
, FUNC_ADPT_ARG(adapter), sta->cmn.mac_id);
connected = 0;
rtw_warn_on(1);
}
if (connected && !rtw_macid_is_bmc(macid_ctl, sta->cmn.mac_id)) {
miracast_enabled = STA_OP_WFD_MODE(sta) != 0 && is_miracast_enabled(adapter);
miracast_sink = miracast_enabled && (STA_OP_WFD_MODE(sta) & MIRACAST_SINK);
#ifdef CONFIG_TDLS
if (sta->tdls_sta_state & TDLS_LINKED_STATE)
role = H2C_MSR_ROLE_TDLS;
else
#endif
if (MLME_IS_STA(adapter)) {
if (MLME_IS_GC(adapter))
role = H2C_MSR_ROLE_GO;
else
role = H2C_MSR_ROLE_AP;
} else if (MLME_IS_AP(adapter)) {
if (MLME_IS_GO(adapter))
role = H2C_MSR_ROLE_GC;
else
role = H2C_MSR_ROLE_STA;
} else if (MLME_IS_ADHOC(adapter) || MLME_IS_ADHOC_MASTER(adapter))
role = H2C_MSR_ROLE_ADHOC;
else if (MLME_IS_MESH(adapter))
role = H2C_MSR_ROLE_MESH;
#ifdef CONFIG_WFD
if (role == H2C_MSR_ROLE_GC
|| role == H2C_MSR_ROLE_GO
|| role == H2C_MSR_ROLE_TDLS
) {
if (adapter->wfd_info.rtsp_ctrlport
|| adapter->wfd_info.tdls_rtsp_ctrlport
|| adapter->wfd_info.peer_rtsp_ctrlport)
rtw_wfd_st_switch(sta, 1);
}
#endif
}
rtw_hal_set_FwMediaStatusRpt_single_cmd(adapter
, connected
, miracast_enabled
, miracast_sink
, role
, sta->cmn.mac_id
);
}
u8 rtw_sta_media_status_rpt_cmd(_adapter *adapter, struct sta_info *sta, bool connected)
{
struct cmd_priv *cmdpriv = &adapter->cmdpriv;
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *cmd_parm;
struct sta_media_status_rpt_cmd_parm *rpt_parm;
u8 res = _SUCCESS;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (cmd_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
rpt_parm = (struct sta_media_status_rpt_cmd_parm *)rtw_zmalloc(sizeof(struct sta_media_status_rpt_cmd_parm));
if (rpt_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
rpt_parm->sta = sta;
rpt_parm->connected = connected;
cmd_parm->ec_id = STA_MSTATUS_RPT_WK_CID;
cmd_parm->type = 0;
cmd_parm->size = sizeof(struct sta_media_status_rpt_cmd_parm);
cmd_parm->pbuf = (u8 *)rpt_parm;
init_h2fwcmd_w_parm_no_rsp(cmdobj, cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
exit:
return res;
}
inline void rtw_sta_media_status_rpt_cmd_hdl(_adapter *adapter, struct sta_media_status_rpt_cmd_parm *parm)
{
rtw_sta_media_status_rpt(adapter, parm->sta, parm->connected);
}
void rtw_stassoc_event_callback(_adapter *adapter, u8 *pbuf)
{
_irqL irqL;
struct sta_info *psta;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct stassoc_event *pstassoc = (struct stassoc_event *)pbuf;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
struct wlan_network *ptarget_wlan = NULL;
#if CONFIG_RTW_MACADDR_ACL
if (rtw_access_ctrl(adapter, pstassoc->macaddr) == _FALSE)
return;
#endif
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
psta = rtw_get_stainfo(&adapter->stapriv, pstassoc->macaddr);
if (psta) {
u8 *passoc_req = NULL;
u32 assoc_req_len = 0;
rtw_sta_media_status_rpt(adapter, psta, 1);
#ifdef CONFIG_MCC_MODE
rtw_hal_mcc_update_macid_bitmap(adapter, psta->cmn.mac_id, _TRUE);
#endif /* CONFIG_MCC_MODE */
#ifndef CONFIG_AUTO_AP_MODE
ap_sta_info_defer_update(adapter, psta);
if (!MLME_IS_MESH(adapter)) {
/* report to upper layer */
RTW_INFO("indicate_sta_assoc_event to upper layer - hostapd\n");
#ifdef CONFIG_IOCTL_CFG80211
_enter_critical_bh(&psta->lock, &irqL);
if (psta->passoc_req && psta->assoc_req_len > 0) {
passoc_req = rtw_zmalloc(psta->assoc_req_len);
if (passoc_req) {
assoc_req_len = psta->assoc_req_len;
_rtw_memcpy(passoc_req, psta->passoc_req, assoc_req_len);
rtw_mfree(psta->passoc_req , psta->assoc_req_len);
psta->passoc_req = NULL;
psta->assoc_req_len = 0;
}
}
_exit_critical_bh(&psta->lock, &irqL);
if (passoc_req && assoc_req_len > 0) {
rtw_cfg80211_indicate_sta_assoc(adapter, passoc_req, assoc_req_len);
rtw_mfree(passoc_req, assoc_req_len);
}
#else /* !CONFIG_IOCTL_CFG80211 */
rtw_indicate_sta_assoc_event(adapter, psta);
#endif /* !CONFIG_IOCTL_CFG80211 */
}
#endif /* !CONFIG_AUTO_AP_MODE */
#ifdef CONFIG_BEAMFORMING
beamforming_wk_cmd(adapter, BEAMFORMING_CTRL_ENTER, (u8 *)psta, sizeof(struct sta_info), 0);
#endif/*CONFIG_BEAMFORMING*/
if (is_wep_enc(adapter->securitypriv.dot11PrivacyAlgrthm))
rtw_ap_wep_pk_setting(adapter, psta);
}
goto exit;
}
#endif /* defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
/* for AD-HOC mode */
psta = rtw_get_stainfo(&adapter->stapriv, pstassoc->macaddr);
if (psta == NULL) {
RTW_ERR(FUNC_ADPT_FMT" get no sta_info with "MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(pstassoc->macaddr));
rtw_warn_on(1);
goto exit;
}
rtw_sta_media_status_rpt(adapter, psta, 1);
if (adapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
psta->dot118021XPrivacy = adapter->securitypriv.dot11PrivacyAlgrthm;
psta->ieee8021x_blocked = _FALSE;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE)) {
if (adapter->stapriv.asoc_sta_count == 2) {
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
ptarget_wlan = _rtw_find_network(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
pmlmepriv->cur_network_scanned = ptarget_wlan;
if (ptarget_wlan)
ptarget_wlan->fixed = _TRUE;
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
/* a sta + bc/mc_stainfo (not Ibss_stainfo) */
rtw_indicate_connect(adapter);
}
}
_exit_critical_bh(&pmlmepriv->lock, &irqL);
mlmeext_sta_add_event_callback(adapter, psta);
#ifdef CONFIG_RTL8711
/* submit SetStaKey_cmd to tell fw, fw will allocate an CAM entry for this sta */
rtw_setstakey_cmd(adapter, psta, GROUP_KEY, _TRUE);
#endif
exit:
#ifdef CONFIG_RTS_FULL_BW
rtw_set_rts_bw(adapter);
#endif/*CONFIG_RTS_FULL_BW*/
return;
}
#ifdef CONFIG_IEEE80211W
void rtw_sta_timeout_event_callback(_adapter *adapter, u8 *pbuf)
{
_irqL irqL;
struct sta_info *psta;
struct stadel_event *pstadel = (struct stadel_event *)pbuf;
struct sta_priv *pstapriv = &adapter->stapriv;
psta = rtw_get_stainfo(&adapter->stapriv, pstadel->macaddr);
if (psta) {
u8 updated = _FALSE;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
rtw_list_delete(&psta->asoc_list);
pstapriv->asoc_list_cnt--;
updated = ap_free_sta(adapter, psta, _TRUE, WLAN_REASON_PREV_AUTH_NOT_VALID, _TRUE);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
associated_clients_update(adapter, updated, STA_INFO_UPDATE_ALL);
}
}
#endif /* CONFIG_IEEE80211W */
#ifdef CONFIG_RTW_80211R
void rtw_ft_info_init(struct ft_roam_info *pft)
{
_rtw_memset(pft, 0, sizeof(struct ft_roam_info));
pft->ft_flags = 0
| RTW_FT_EN
| RTW_FT_OTD_EN
#ifdef CONFIG_RTW_BTM_ROAM
| RTW_FT_BTM_ROAM
#endif
;
pft->ft_updated_bcn = _FALSE;
}
u8 rtw_ft_chk_roaming_candidate(
_adapter *padapter, struct wlan_network *competitor)
{
u8 *pmdie;
u32 mdie_len = 0;
struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
if (!(pmdie = rtw_get_ie(&competitor->network.IEs[12],
_MDIE_, &mdie_len, competitor->network.IELength-12)))
return _FALSE;
if (!_rtw_memcmp(&pft_roam->mdid, (pmdie+2), 2))
return _FALSE;
/*The candidate don't support over-the-DS*/
if (rtw_ft_valid_otd_candidate(padapter, pmdie)) {
RTW_INFO("FT: ignore the candidate("
MAC_FMT ") for over-the-DS\n",
MAC_ARG(competitor->network.MacAddress));
rtw_ft_clr_flags(padapter, RTW_FT_PEER_OTD_EN);
return _FALSE;
}
return _TRUE;
}
void rtw_ft_update_stainfo(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
{
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta = NULL;
psta = rtw_get_stainfo(pstapriv, pnetwork->MacAddress);
if (psta == NULL)
psta = rtw_alloc_stainfo(pstapriv, pnetwork->MacAddress);
if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
padapter->securitypriv.binstallGrpkey = _FALSE;
padapter->securitypriv.busetkipkey = _FALSE;
padapter->securitypriv.bgrpkey_handshake = _FALSE;
psta->ieee8021x_blocked = _TRUE;
psta->dot118021XPrivacy = padapter->securitypriv.dot11PrivacyAlgrthm;
_rtw_memset((u8 *)&psta->dot118021x_UncstKey, 0, sizeof(union Keytype));
_rtw_memset((u8 *)&psta->dot11tkiprxmickey, 0, sizeof(union Keytype));
_rtw_memset((u8 *)&psta->dot11tkiptxmickey, 0, sizeof(union Keytype));
}
}
void rtw_ft_reassoc_event_callback(_adapter *padapter, u8 *pbuf)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct stassoc_event *pstassoc = (struct stassoc_event *)pbuf;
struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&(pmlmeinfo->network);
struct cfg80211_ft_event_params ft_evt_parms;
_irqL irqL;
_rtw_memset(&ft_evt_parms, 0, sizeof(ft_evt_parms));
rtw_ft_update_stainfo(padapter, pnetwork);
ft_evt_parms.ies_len = pft_roam->ft_event.ies_len;
ft_evt_parms.ies = rtw_zmalloc(ft_evt_parms.ies_len);
if (ft_evt_parms.ies)
_rtw_memcpy((void *)ft_evt_parms.ies, pft_roam->ft_event.ies, ft_evt_parms.ies_len);
else
goto err_2;
ft_evt_parms.target_ap = rtw_zmalloc(ETH_ALEN);
if (ft_evt_parms.target_ap)
_rtw_memcpy((void *)ft_evt_parms.target_ap, pstassoc->macaddr, ETH_ALEN);
else
goto err_1;
ft_evt_parms.ric_ies = pft_roam->ft_event.ric_ies;
ft_evt_parms.ric_ies_len = pft_roam->ft_event.ric_ies_len;
rtw_ft_lock_set_status(padapter, RTW_FT_AUTHENTICATED_STA, &irqL);
rtw_cfg80211_ft_event(padapter, &ft_evt_parms);
RTW_INFO("%s: to "MAC_FMT"\n", __func__, MAC_ARG(ft_evt_parms.target_ap));
rtw_mfree((u8 *)pft_roam->ft_event.target_ap, ETH_ALEN);
err_1:
rtw_mfree((u8 *)ft_evt_parms.ies, ft_evt_parms.ies_len);
err_2:
return;
}
#endif
#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
void rtw_roam_nb_info_init(_adapter *padapter)
{
struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
_rtw_memset(&pnb->nb_rpt, 0, sizeof(pnb->nb_rpt));
_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
_rtw_memset(&pnb->roam_target_addr, 0, ETH_ALEN);
pnb->nb_rpt_valid = _FALSE;
pnb->nb_rpt_ch_list_num = 0;
pnb->preference_en = _FALSE;
pnb->nb_rpt_is_same = _TRUE;
pnb->last_nb_rpt_entries = 0;
#ifdef CONFIG_RTW_WNM
rtw_init_timer(&pnb->roam_scan_timer,
padapter, rtw_wnm_roam_scan_hdl,
padapter);
#endif
}
u8 rtw_roam_nb_scan_list_set(
_adapter *padapter, struct sitesurvey_parm *pparm)
{
u8 ret = _FALSE;
u32 i;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct roam_nb_info *pnb = &(pmlmepriv->nb_info);
if (!rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE))
return ret;
if (!pmlmepriv->need_to_roam)
return ret;
if ((!pmlmepriv->nb_info.nb_rpt_valid) || (!pnb->nb_rpt_ch_list_num))
return ret;
if (!pparm)
return ret;
rtw_init_sitesurvey_parm(padapter, pparm);
if (rtw_roam_busy_scan(padapter, pnb)) {
pparm->ch_num = 1;
pparm->ch[pmlmepriv->ch_cnt].hw_value =
pnb->nb_rpt_ch_list[pmlmepriv->ch_cnt].hw_value;
pmlmepriv->ch_cnt++;
ret = _TRUE;
if (pmlmepriv->ch_cnt == pnb->nb_rpt_ch_list_num) {
pmlmepriv->nb_info.nb_rpt_valid = _FALSE;
pmlmepriv->ch_cnt = 0;
}
goto set_bssid_list;
}
pparm->ch_num = (pnb->nb_rpt_ch_list_num > RTW_CHANNEL_SCAN_AMOUNT)?
(RTW_CHANNEL_SCAN_AMOUNT):(pnb->nb_rpt_ch_list_num);
for (i=0; ich_num; i++) {
pparm->ch[i].hw_value = pnb->nb_rpt_ch_list[i].hw_value;
pparm->ch[i].flags = RTW_IEEE80211_CHAN_PASSIVE_SCAN;
}
pmlmepriv->nb_info.nb_rpt_valid = _FALSE;
pmlmepriv->ch_cnt = 0;
ret = _TRUE;
set_bssid_list:
rtw_set_802_11_bssid_list_scan(padapter, pparm);
return ret;
}
#endif
void rtw_sta_mstatus_disc_rpt(_adapter *adapter, u8 mac_id)
{
struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
if (mac_id >= 0 && mac_id < macid_ctl->num) {
u8 id_is_shared = mac_id == RTW_DEFAULT_MGMT_MACID; /* TODO: real shared macid judgment */
RTW_INFO(FUNC_ADPT_FMT" - mac_id=%d%s\n", FUNC_ADPT_ARG(adapter)
, mac_id, id_is_shared ? " shared" : "");
if (!id_is_shared) {
rtw_hal_set_FwMediaStatusRpt_single_cmd(adapter, 0, 0, 0, 0, mac_id);
/*
* For safety, prevent from keeping macid sleep.
* If we can sure all power mode enter/leave are paired,
* this check can be removed.
* Lucas@20131113
*/
/* wakeup macid after disconnect. */
/*if (MLME_IS_STA(adapter))*/
rtw_hal_macid_wakeup(adapter, mac_id);
}
} else {
RTW_PRINT(FUNC_ADPT_FMT" invalid macid:%u\n"
, FUNC_ADPT_ARG(adapter), mac_id);
rtw_warn_on(1);
}
}
void rtw_sta_mstatus_report(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct wlan_network *tgt_network = &pmlmepriv->cur_network;
struct sta_info *psta = NULL;
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) && check_fwstate(pmlmepriv, WIFI_ASOC_STATE)) {
psta = rtw_get_stainfo(&adapter->stapriv, tgt_network->network.MacAddress);
if (psta)
rtw_sta_mstatus_disc_rpt(adapter, psta->cmn.mac_id);
else {
RTW_INFO("%s "ADPT_FMT" - mac_addr: "MAC_FMT" psta == NULL\n", __func__, ADPT_ARG(adapter), MAC_ARG(tgt_network->network.MacAddress));
rtw_warn_on(1);
}
}
}
void rtw_stadel_event_callback(_adapter *adapter, u8 *pbuf)
{
_irqL irqL, irqL2;
struct sta_info *psta;
struct wlan_network *pwlan = NULL;
WLAN_BSSID_EX *pdev_network = NULL;
u8 *pibss = NULL;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct stadel_event *pstadel = (struct stadel_event *)pbuf;
struct wlan_network *tgt_network = &(pmlmepriv->cur_network);
RTW_INFO("%s(mac_id=%d)=" MAC_FMT "\n", __func__, pstadel->mac_id, MAC_ARG(pstadel->macaddr));
rtw_sta_mstatus_disc_rpt(adapter, pstadel->mac_id);
#ifdef CONFIG_MCC_MODE
rtw_hal_mcc_update_macid_bitmap(adapter, pstadel->mac_id, _FALSE);
#endif /* CONFIG_MCC_MODE */
psta = rtw_get_stainfo(&adapter->stapriv, pstadel->macaddr);
if (psta == NULL) {
RTW_INFO("%s(mac_id=%d)=" MAC_FMT " psta == NULL\n", __func__, pstadel->mac_id, MAC_ARG(pstadel->macaddr));
/*rtw_warn_on(1);*/
}
if (psta)
rtw_wfd_st_switch(psta, 0);
if (MLME_IS_MESH(adapter)) {
rtw_free_stainfo(adapter, psta);
goto exit;
}
if (MLME_IS_AP(adapter)) {
#ifdef CONFIG_IOCTL_CFG80211
#ifdef COMPAT_KERNEL_RELEASE
#elif (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER)
rtw_cfg80211_indicate_sta_disassoc(adapter, pstadel->macaddr, *(u16 *)pstadel->rsvd);
#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 37)) || defined(CONFIG_CFG80211_FORCE_COMPATIBLE_2_6_37_UNDER) */
#endif /* CONFIG_IOCTL_CFG80211 */
rtw_free_stainfo(adapter, psta);
goto exit;
}
mlmeext_sta_del_event_callback(adapter);
_enter_critical_bh(&pmlmepriv->lock, &irqL2);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
u16 reason = *((unsigned short *)(pstadel->rsvd));
bool roam = _FALSE;
struct wlan_network *roam_target = NULL;
#ifdef CONFIG_LAYER2_ROAMING
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam_expired(adapter, reason))
pmlmepriv->ft_roam.ft_roam_on_expired = _TRUE;
else
pmlmepriv->ft_roam.ft_roam_on_expired = _FALSE;
#endif
if (adapter->registrypriv.wifi_spec == 1)
roam = _FALSE;
else if (reason == WLAN_REASON_EXPIRATION_CHK && rtw_chk_roam_flags(adapter, RTW_ROAM_ON_EXPIRED))
roam = _TRUE;
else if (reason == WLAN_REASON_ACTIVE_ROAM && rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
roam = _TRUE;
roam_target = pmlmepriv->roam_network;
}
if (roam == _TRUE) {
if (rtw_to_roam(adapter) > 0)
rtw_dec_to_roam(adapter); /* this stadel_event is caused by roaming, decrease to_roam */
else if (rtw_to_roam(adapter) == 0)
rtw_set_to_roam(adapter, adapter->registrypriv.max_roaming_times);
} else
rtw_set_to_roam(adapter, 0);
#endif /* CONFIG_LAYER2_ROAMING */
rtw_free_uc_swdec_pending_queue(adapter);
rtw_free_assoc_resources(adapter, _TRUE);
rtw_free_mlme_priv_ie_data(pmlmepriv);
rtw_indicate_disconnect(adapter, *(u16 *)pstadel->rsvd, pstadel->locally_generated);
_rtw_roaming(adapter, roam_target);
}
if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
rtw_free_stainfo(adapter, psta);
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
if (adapter->stapriv.asoc_sta_count == 1) { /* a sta + bc/mc_stainfo (not Ibss_stainfo) */
/* rtw_indicate_disconnect(adapter); */ /* removed@20091105 */
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
/* free old ibss network */
/* pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, pstadel->macaddr); */
pwlan = _rtw_find_network(&pmlmepriv->scanned_queue, tgt_network->network.MacAddress);
if (pwlan) {
pwlan->fixed = _FALSE;
rtw_free_network_nolock(adapter, pwlan);
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
/* re-create ibss */
pdev_network = &(adapter->registrypriv.dev_network);
pibss = adapter->registrypriv.dev_network.MacAddress;
_rtw_memcpy(pdev_network, &tgt_network->network, get_WLAN_BSSID_EX_sz(&tgt_network->network));
_rtw_memset(&pdev_network->Ssid, 0, sizeof(NDIS_802_11_SSID));
_rtw_memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid, sizeof(NDIS_802_11_SSID));
rtw_update_registrypriv_dev_network(adapter);
rtw_generate_random_ibss(pibss);
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
set_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
_clr_fwstate_(pmlmepriv, WIFI_ADHOC_STATE);
}
if (rtw_create_ibss_cmd(adapter, 0) != _SUCCESS)
RTW_ERR("rtw_create_ibss_cmd FAIL\n");
}
}
_exit_critical_bh(&pmlmepriv->lock, &irqL2);
exit:
#ifdef CONFIG_RTS_FULL_BW
rtw_set_rts_bw(adapter);
#endif/*CONFIG_RTS_FULL_BW*/
return;
}
void rtw_cpwm_event_callback(PADAPTER padapter, u8 *pbuf)
{
#ifdef CONFIG_LPS_LCLK
struct reportpwrstate_parm *preportpwrstate;
#endif
#ifdef CONFIG_LPS_LCLK
preportpwrstate = (struct reportpwrstate_parm *)pbuf;
preportpwrstate->state |= (u8)(adapter_to_pwrctl(padapter)->cpwm_tog + 0x80);
cpwm_int_hdl(padapter, preportpwrstate);
#endif
}
void rtw_wmm_event_callback(PADAPTER padapter, u8 *pbuf)
{
WMMOnAssocRsp(padapter);
}
/*
* rtw_join_timeout_handler - Timeout/failure handler for CMD JoinBss
*/
void rtw_join_timeout_handler(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
_irqL irqL;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
#if 0
if (rtw_is_drv_stopped(adapter)) {
_rtw_up_sema(&pmlmepriv->assoc_terminate);
return;
}
#endif
RTW_INFO("%s, fw_state=%x\n", __FUNCTION__, get_fwstate(pmlmepriv));
if (RTW_CANNOT_RUN(adapter))
return;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
#ifdef CONFIG_LAYER2_ROAMING
if (rtw_to_roam(adapter) > 0) { /* join timeout caused by roaming */
while (1) {
rtw_dec_to_roam(adapter);
if (rtw_to_roam(adapter) != 0) { /* try another */
int do_join_r;
RTW_INFO("%s try another roaming\n", __FUNCTION__);
do_join_r = rtw_do_join(adapter);
if (_SUCCESS != do_join_r) {
RTW_INFO("%s roaming do_join return %d\n", __FUNCTION__ , do_join_r);
continue;
}
break;
} else {
RTW_INFO("%s We've try roaming but fail\n", __FUNCTION__);
#ifdef CONFIG_RTW_80211R
rtw_ft_clr_flags(adapter, RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN);
rtw_ft_reset_status(adapter);
#endif
rtw_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
break;
}
}
} else
#endif
{
rtw_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
free_scanqueue(pmlmepriv);/* ??? */
#ifdef CONFIG_IOCTL_CFG80211
/* indicate disconnect for the case that join_timeout and check_fwstate != FW_LINKED */
rtw_cfg80211_indicate_disconnect(adapter, pmlmepriv->join_status, _FALSE);
#endif /* CONFIG_IOCTL_CFG80211 */
}
pmlmepriv->join_status = 0; /* reset */
_exit_critical_bh(&pmlmepriv->lock, &irqL);
#ifdef CONFIG_DRVEXT_MODULE_WSC
drvext_assoc_fail_indicate(&adapter->drvextpriv);
#endif
}
/*
* rtw_scan_timeout_handler - Timeout/Faliure handler for CMD SiteSurvey
* @adapter: pointer to _adapter structure
*/
void rtw_scan_timeout_handler(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
_irqL irqL;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
RTW_INFO(FUNC_ADPT_FMT" fw_state=%x\n", FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
_enter_critical_bh(&pmlmepriv->lock, &irqL);
_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
#ifdef CONFIG_IOCTL_CFG80211
rtw_cfg80211_surveydone_event_callback(adapter);
#endif /* CONFIG_IOCTL_CFG80211 */
rtw_indicate_scan_done(adapter, _TRUE);
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_IOCTL_CFG80211)
rtw_cfg80211_indicate_scan_done_for_buddy(adapter, _TRUE);
#endif
}
void rtw_mlme_reset_auto_scan_int(_adapter *adapter, u8 *reason)
{
#if defined(CONFIG_RTW_MESH) && defined(CONFIG_DFS_MASTER)
#if CONFIG_RTW_MESH_OFFCH_CAND
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
#endif
#endif
u8 u_ch;
u32 interval_ms = 0xffffffff; /* 0xffffffff: special value to make min() works well, also means no auto scan */
*reason = RTW_AUTO_SCAN_REASON_UNSPECIFIED;
rtw_mi_get_ch_setting_union(adapter, &u_ch, NULL, NULL);
if (hal_chk_bw_cap(adapter, BW_CAP_40M)
&& is_client_associated_to_ap(adapter) == _TRUE
&& u_ch >= 1 && u_ch <= 14
&& adapter->registrypriv.wifi_spec
/* TODO: AP Connected is 40MHz capability? */
) {
interval_ms = rtw_min(interval_ms, 60 * 1000);
*reason |= RTW_AUTO_SCAN_REASON_2040_BSS;
}
#ifdef CONFIG_RTW_MESH
#if CONFIG_RTW_MESH_OFFCH_CAND
if (adapter->mesh_cfg.peer_sel_policy.offch_find_int_ms
&& rtw_mesh_offch_candidate_accepted(adapter)
#ifdef CONFIG_DFS_MASTER
&& (!rfctl->radar_detect_ch || (IS_CH_WAITING(rfctl) && !IS_UNDER_CAC(rfctl)))
#endif
) {
interval_ms = rtw_min(interval_ms, adapter->mesh_cfg.peer_sel_policy.offch_find_int_ms);
*reason |= RTW_AUTO_SCAN_REASON_MESH_OFFCH_CAND;
}
#endif
#endif /* CONFIG_RTW_MESH */
if (interval_ms == 0xffffffff)
interval_ms = 0;
rtw_mlme_set_auto_scan_int(adapter, interval_ms);
return;
}
void rtw_drv_scan_by_self(_adapter *padapter, u8 reason)
{
struct sitesurvey_parm parm;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
int i;
#if 1
u8 ssc_chk;
ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
if( ssc_chk == SS_DENY_BUSY_TRAFFIC) {
#ifdef CONFIG_LAYER2_ROAMING
if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE) && pmlmepriv->need_to_roam == _TRUE)
RTW_INFO(FUNC_ADPT_FMT" need to roam, don't care BusyTraffic\n", FUNC_ADPT_ARG(padapter));
else
#endif
RTW_INFO(FUNC_ADPT_FMT" exit BusyTraffic\n", FUNC_ADPT_ARG(padapter));
goto exit;
}
else if (ssc_chk != SS_ALLOW)
goto exit;
if (!rtw_is_adapter_up(padapter))
goto exit;
#else
if (rtw_is_scan_deny(padapter))
goto exit;
if (!rtw_is_adapter_up(padapter))
goto exit;
if (rtw_mi_busy_traffic_check(padapter, _FALSE)) {
#ifdef CONFIG_LAYER2_ROAMING
if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE) && pmlmepriv->need_to_roam == _TRUE) {
RTW_INFO("need to roam, don't care BusyTraffic\n");
} else
#endif
{
RTW_INFO(FUNC_ADPT_FMT" exit BusyTraffic\n", FUNC_ADPT_ARG(padapter));
goto exit;
}
}
if (check_fwstate(pmlmepriv, WIFI_AP_STATE) && check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
RTW_INFO(FUNC_ADPT_FMT" WIFI_AP_STATE && WIFI_UNDER_WPS\n", FUNC_ADPT_ARG(padapter));
goto exit;
}
if (check_fwstate(pmlmepriv, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING)) == _TRUE) {
RTW_INFO(FUNC_ADPT_FMT" _FW_UNDER_SURVEY|_FW_UNDER_LINKING\n", FUNC_ADPT_ARG(padapter));
goto exit;
}
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(padapter, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING | WIFI_UNDER_WPS))) {
RTW_INFO(FUNC_ADPT_FMT", but buddy_intf is under scanning or linking or wps_phase\n", FUNC_ADPT_ARG(padapter));
goto exit;
}
#endif
#endif
RTW_INFO(FUNC_ADPT_FMT" reason:0x%02x\n", FUNC_ADPT_ARG(padapter), reason);
/* only for 20/40 BSS */
if (reason == RTW_AUTO_SCAN_REASON_2040_BSS) {
rtw_init_sitesurvey_parm(padapter, &parm);
for (i=0;i<14;i++) {
parm.ch[i].hw_value = i + 1;
parm.ch[i].flags = RTW_IEEE80211_CHAN_PASSIVE_SCAN;
}
parm.ch_num = 14;
rtw_set_802_11_bssid_list_scan(padapter, &parm);
goto exit;
}
#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
if ((reason == RTW_AUTO_SCAN_REASON_ROAM)
&& (rtw_roam_nb_scan_list_set(padapter, &parm)))
goto exit;
#endif
rtw_set_802_11_bssid_list_scan(padapter, NULL);
exit:
return;
}
static void rtw_auto_scan_handler(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 reason = RTW_AUTO_SCAN_REASON_UNSPECIFIED;
rtw_mlme_reset_auto_scan_int(padapter, &reason);
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE))
goto exit;
#endif
#ifdef CONFIG_TDLS
if (padapter->tdlsinfo.link_established == _TRUE)
goto exit;
#endif
if (pmlmepriv->auto_scan_int_ms == 0
|| rtw_get_passing_time_ms(pmlmepriv->scan_start_time) < pmlmepriv->auto_scan_int_ms)
goto exit;
rtw_drv_scan_by_self(padapter, reason);
exit:
return;
}
static u8 is_drv_in_lps(_adapter *adapter)
{
u8 is_in_lps = _FALSE;
#ifdef CONFIG_LPS_LCLK_WD_TIMER /* to avoid leaving lps 32k frequently*/
if ((adapter_to_pwrctl(adapter)->bFwCurrentInPSMode == _TRUE)
#ifdef CONFIG_BT_COEXIST
&& (rtw_btcoex_IsBtControlLps(adapter) == _FALSE)
#endif
)
is_in_lps = _TRUE;
#endif /* CONFIG_LPS_LCLK_WD_TIMER*/
return is_in_lps;
}
void rtw_iface_dynamic_check_timer_handlder(_adapter *adapter)
{
#ifdef CONFIG_AP_MODE
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
#endif /* CONFIG_AP_MODE */
if (adapter->net_closed == _TRUE)
return;
#ifdef CONFIG_LPS_LCLK_WD_TIMER /* to avoid leaving lps 32k frequently*/
if (is_drv_in_lps(adapter)) {
u8 bEnterPS;
linked_status_chk(adapter, 1);
bEnterPS = traffic_status_watchdog(adapter, 1);
if (bEnterPS) {
/* rtw_lps_ctrl_wk_cmd(adapter, LPS_CTRL_ENTER, 0); */
rtw_hal_dm_watchdog_in_lps(adapter);
} else {
/* call rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 0) in traffic_status_watchdog() */
}
}
#endif /* CONFIG_LPS_LCLK_WD_TIMER */
/* auto site survey */
rtw_auto_scan_handler(adapter);
#ifdef CONFIG_AP_MODE
if (MLME_IS_AP(adapter)|| MLME_IS_MESH(adapter)) {
#ifndef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
expire_timeout_chk(adapter);
#endif /* !CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
#ifdef CONFIG_BMC_TX_RATE_SELECT
rtw_update_bmc_sta_tx_rate(adapter);
#endif /*CONFIG_BMC_TX_RATE_SELECT*/
}
#endif /*CONFIG_AP_MODE*/
#ifdef CONFIG_BR_EXT
#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
rcu_read_lock();
#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
if (adapter->pnetdev->br_port
#else /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
if (rcu_dereference(adapter->pnetdev->rx_handler_data)
#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
&& (check_fwstate(pmlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE)) {
/* expire NAT2.5 entry */
void nat25_db_expire(_adapter *priv);
nat25_db_expire(adapter);
if (adapter->pppoe_connection_in_progress > 0)
adapter->pppoe_connection_in_progress--;
/* due to rtw_dynamic_check_timer_handlder() is called every 2 seconds */
if (adapter->pppoe_connection_in_progress > 0)
adapter->pppoe_connection_in_progress--;
}
#if (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35))
rcu_read_unlock();
#endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 35)) */
#endif /* CONFIG_BR_EXT */
}
/*TP_avg(t) = (1/10) * TP_avg(t-1) + (9/10) * TP(t) MBps*/
static void collect_sta_traffic_statistics(_adapter *adapter)
{
struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
struct sta_info *sta;
u64 curr_tx_bytes = 0, curr_rx_bytes = 0;
u32 curr_tx_mbytes = 0, curr_rx_mbytes = 0;
int i;
for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
sta = macid_ctl->sta[i];
if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr)) {
if (sta->sta_stats.last_tx_bytes > sta->sta_stats.tx_bytes)
sta->sta_stats.last_tx_bytes = sta->sta_stats.tx_bytes;
if (sta->sta_stats.last_rx_bytes > sta->sta_stats.rx_bytes)
sta->sta_stats.last_rx_bytes = sta->sta_stats.rx_bytes;
if (sta->sta_stats.last_rx_bc_bytes > sta->sta_stats.rx_bc_bytes)
sta->sta_stats.last_rx_bc_bytes = sta->sta_stats.rx_bc_bytes;
if (sta->sta_stats.last_rx_mc_bytes > sta->sta_stats.rx_mc_bytes)
sta->sta_stats.last_rx_mc_bytes = sta->sta_stats.rx_mc_bytes;
curr_tx_bytes = sta->sta_stats.tx_bytes - sta->sta_stats.last_tx_bytes;
curr_rx_bytes = sta->sta_stats.rx_bytes - sta->sta_stats.last_rx_bytes;
sta->sta_stats.tx_tp_kbits = (curr_tx_bytes * 8 / 2) >> 10;/*Kbps*/
sta->sta_stats.rx_tp_kbits = (curr_rx_bytes * 8 / 2) >> 10;/*Kbps*/
sta->sta_stats.smooth_tx_tp_kbits = (sta->sta_stats.smooth_tx_tp_kbits * 6 / 10) + (sta->sta_stats.tx_tp_kbits * 4 / 10);/*Kbps*/
sta->sta_stats.smooth_rx_tp_kbits = (sta->sta_stats.smooth_rx_tp_kbits * 6 / 10) + (sta->sta_stats.rx_tp_kbits * 4 / 10);/*Kbps*/
curr_tx_mbytes = (curr_tx_bytes / 2) >> 20;/*MBps*/
curr_rx_mbytes = (curr_rx_bytes / 2) >> 20;/*MBps*/
sta->cmn.tx_moving_average_tp =
(sta->cmn.tx_moving_average_tp / 10) + (curr_tx_mbytes * 9 / 10); /*MBps*/
sta->cmn.rx_moving_average_tp =
(sta->cmn.rx_moving_average_tp / 10) + (curr_rx_mbytes * 9 /10); /*MBps*/
rtw_collect_bcn_info(sta->padapter);
if (adapter->bsta_tp_dump)
dump_sta_traffic(RTW_DBGDUMP, adapter, sta);
sta->sta_stats.last_tx_bytes = sta->sta_stats.tx_bytes;
sta->sta_stats.last_rx_bytes = sta->sta_stats.rx_bytes;
sta->sta_stats.last_rx_bc_bytes = sta->sta_stats.rx_bc_bytes;
sta->sta_stats.last_rx_mc_bytes = sta->sta_stats.rx_mc_bytes;
}
}
}
void rtw_sta_traffic_info(void *sel, _adapter *adapter)
{
struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
struct sta_info *sta;
int i;
for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
sta = macid_ctl->sta[i];
if (sta && !is_broadcast_mac_addr(sta->cmn.mac_addr))
dump_sta_traffic(sel, adapter, sta);
}
}
/*#define DBG_TRAFFIC_STATISTIC*/
static void collect_traffic_statistics(_adapter *padapter)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
/*_rtw_memset(&pdvobjpriv->traffic_stat, 0, sizeof(struct rtw_traffic_statistics));*/
/* Tx bytes reset*/
pdvobjpriv->traffic_stat.tx_bytes = 0;
pdvobjpriv->traffic_stat.tx_pkts = 0;
pdvobjpriv->traffic_stat.tx_drop = 0;
/* Rx bytes reset*/
pdvobjpriv->traffic_stat.rx_bytes = 0;
pdvobjpriv->traffic_stat.rx_pkts = 0;
pdvobjpriv->traffic_stat.rx_drop = 0;
rtw_mi_traffic_statistics(padapter);
/* Calculate throughput in last interval */
pdvobjpriv->traffic_stat.cur_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes - pdvobjpriv->traffic_stat.last_tx_bytes;
pdvobjpriv->traffic_stat.cur_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes - pdvobjpriv->traffic_stat.last_rx_bytes;
pdvobjpriv->traffic_stat.last_tx_bytes = pdvobjpriv->traffic_stat.tx_bytes;
pdvobjpriv->traffic_stat.last_rx_bytes = pdvobjpriv->traffic_stat.rx_bytes;
pdvobjpriv->traffic_stat.cur_tx_tp = (u32)(pdvobjpriv->traffic_stat.cur_tx_bytes * 8 / 2 / 1024 / 1024);/*Mbps*/
pdvobjpriv->traffic_stat.cur_rx_tp = (u32)(pdvobjpriv->traffic_stat.cur_rx_bytes * 8 / 2 / 1024 / 1024);/*Mbps*/
#ifdef DBG_TRAFFIC_STATISTIC
RTW_INFO("\n========================\n");
RTW_INFO("cur_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.cur_tx_bytes);
RTW_INFO("cur_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.cur_rx_bytes);
RTW_INFO("last_tx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_tx_bytes);
RTW_INFO("last_rx_bytes:%lld\n", pdvobjpriv->traffic_stat.last_rx_bytes);
RTW_INFO("cur_tx_tp:%d (Mbps)\n", pdvobjpriv->traffic_stat.cur_tx_tp);
RTW_INFO("cur_rx_tp:%d (Mbps)\n", pdvobjpriv->traffic_stat.cur_rx_tp);
#endif
#ifdef CONFIG_RTW_NAPI
#ifdef CONFIG_RTW_NAPI_DYNAMIC
dynamic_napi_th_chk (padapter);
#endif /* CONFIG_RTW_NAPI_DYNAMIC */
#endif
}
void rtw_dynamic_check_timer_handlder(void *ctx)
{
struct dvobj_priv *pdvobj = (struct dvobj_priv *)ctx;
_adapter *adapter = dvobj_get_primary_adapter(pdvobj);
#if (MP_DRIVER == 1)
if (adapter->registrypriv.mp_mode == 1 && adapter->mppriv.mp_dm == 0) { /* for MP ODM dynamic Tx power tracking */
/* RTW_INFO("%s mp_dm =0 return\n", __func__); */
goto exit;
}
#endif
if (!adapter)
goto exit;
if (!rtw_is_hw_init_completed(adapter))
goto exit;
if (RTW_CANNOT_RUN(adapter))
goto exit;
collect_traffic_statistics(adapter);
collect_sta_traffic_statistics(adapter);
rtw_mi_dynamic_check_timer_handlder(adapter);
if (!is_drv_in_lps(adapter))
rtw_dynamic_chk_wk_cmd(adapter);
exit:
_set_timer(&pdvobj->dynamic_chk_timer, 2000);
}
#ifdef CONFIG_SET_SCAN_DENY_TIMER
inline bool rtw_is_scan_deny(_adapter *adapter)
{
struct mlme_priv *mlmepriv = &adapter->mlmepriv;
return (ATOMIC_READ(&mlmepriv->set_scan_deny) != 0) ? _TRUE : _FALSE;
}
inline void rtw_clear_scan_deny(_adapter *adapter)
{
struct mlme_priv *mlmepriv = &adapter->mlmepriv;
ATOMIC_SET(&mlmepriv->set_scan_deny, 0);
if (0)
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
}
void rtw_set_scan_deny_timer_hdl(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
rtw_clear_scan_deny(adapter);
}
void rtw_set_scan_deny(_adapter *adapter, u32 ms)
{
struct mlme_priv *mlmepriv = &adapter->mlmepriv;
if (0)
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(adapter));
ATOMIC_SET(&mlmepriv->set_scan_deny, 1);
_set_timer(&mlmepriv->set_scan_deny_timer, ms);
}
#endif
#ifdef CONFIG_LAYER2_ROAMING
/*
* Select a new roaming candidate from the original @param candidate and @param competitor
* @return _TRUE: candidate is updated
* @return _FALSE: candidate is not updated
*/
static int rtw_check_roaming_candidate(struct mlme_priv *mlme
, struct wlan_network **candidate, struct wlan_network *competitor)
{
int updated = _FALSE;
_adapter *adapter = container_of(mlme, _adapter, mlmepriv);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
RT_CHANNEL_INFO *chset = rfctl->channel_set;
u8 ch = competitor->network.Configuration.DSConfig;
if (rtw_chset_search_ch(chset, ch) < 0)
goto exit;
if (IS_DFS_SLAVE_WITH_RD(rfctl)
&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
&& rtw_chset_is_ch_non_ocp(chset, ch))
goto exit;
#if defined(CONFIG_RTW_REPEATER_SON) && (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
if (rtw_rson_isupdate_roamcan(mlme, candidate, competitor))
goto update;
goto exit;
#endif
if (is_same_ess(&competitor->network, &mlme->cur_network.network) == _FALSE)
goto exit;
if (rtw_is_desired_network(adapter, competitor) == _FALSE)
goto exit;
#ifdef CONFIG_LAYER2_ROAMING
if (mlme->need_to_roam == _FALSE)
goto exit;
#endif
#ifdef CONFIG_RTW_80211R
if (rtw_ft_chk_flags(adapter, RTW_FT_PEER_EN)) {
if (rtw_ft_chk_roaming_candidate(adapter, competitor) == _FALSE)
goto exit;
}
#endif
RTW_INFO("roam candidate:%s %s("MAC_FMT", ch%3u) rssi:%d, age:%5d\n",
(competitor == mlme->cur_network_scanned) ? "*" : " " ,
competitor->network.Ssid.Ssid,
MAC_ARG(competitor->network.MacAddress),
competitor->network.Configuration.DSConfig,
(int)competitor->network.Rssi,
rtw_get_passing_time_ms(competitor->last_scanned)
);
/* got specific addr to roam */
if (!is_zero_mac_addr(mlme->roam_tgt_addr)) {
if (_rtw_memcmp(mlme->roam_tgt_addr, competitor->network.MacAddress, ETH_ALEN) == _TRUE)
goto update;
else
goto exit;
}
#if 1
if (rtw_get_passing_time_ms(competitor->last_scanned) >= mlme->roam_scanr_exp_ms)
goto exit;
#if defined(CONFIG_RTW_80211R) && defined(CONFIG_RTW_WNM)
if (rtw_wnm_btm_diff_bss(adapter) &&
rtw_wnm_btm_roam_candidate(adapter, competitor)) {
goto update;
}
#endif
if (competitor->network.Rssi - mlme->cur_network_scanned->network.Rssi < mlme->roam_rssi_diff_th)
goto exit;
if (*candidate != NULL && (*candidate)->network.Rssi >= competitor->network.Rssi)
goto exit;
#else
goto exit;
#endif
update:
*candidate = competitor;
updated = _TRUE;
exit:
return updated;
}
int rtw_select_roaming_candidate(struct mlme_priv *mlme)
{
_irqL irqL;
int ret = _FAIL;
_list *phead;
_adapter *adapter;
_queue *queue = &(mlme->scanned_queue);
struct wlan_network *pnetwork = NULL;
struct wlan_network *candidate = NULL;
if (mlme->cur_network_scanned == NULL) {
rtw_warn_on(1);
goto exit;
}
_enter_critical_bh(&(mlme->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
adapter = (_adapter *)mlme->nic_hdl;
mlme->pscanned = get_next(phead);
while (!rtw_end_of_queue_search(phead, mlme->pscanned)) {
pnetwork = LIST_CONTAINOR(mlme->pscanned, struct wlan_network, list);
if (pnetwork == NULL) {
ret = _FAIL;
goto exit;
}
mlme->pscanned = get_next(mlme->pscanned);
if (0)
RTW_INFO("%s("MAC_FMT", ch%u) rssi:%d\n"
, pnetwork->network.Ssid.Ssid
, MAC_ARG(pnetwork->network.MacAddress)
, pnetwork->network.Configuration.DSConfig
, (int)pnetwork->network.Rssi);
rtw_check_roaming_candidate(mlme, &candidate, pnetwork);
}
if (candidate == NULL) {
/* if parent note lost the path to root and there is no other cadidate, report disconnection */
#if defined(CONFIG_RTW_REPEATER_SON) && (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
struct rtw_rson_struct rson_curr;
u8 rson_score;
rtw_get_rson_struct(&(mlme->cur_network_scanned->network), &rson_curr);
rson_score = rtw_cal_rson_score(&rson_curr, mlme->cur_network_scanned->network.Rssi);
if (check_fwstate(mlme, _FW_LINKED)
&& ((rson_score == RTW_RSON_SCORE_NOTCNNT)
|| (rson_score == RTW_RSON_SCORE_NOTSUP)))
receive_disconnect(adapter, mlme->cur_network_scanned->network.MacAddress
, WLAN_REASON_EXPIRATION_CHK, _FALSE);
#endif
RTW_INFO("%s: return _FAIL(candidate == NULL)\n", __FUNCTION__);
ret = _FAIL;
goto exit;
} else {
#if defined(CONFIG_RTW_REPEATER_SON) && (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
struct rtw_rson_struct rson_curr;
u8 rson_score;
rtw_get_rson_struct(&(candidate->network), &rson_curr);
rson_score = rtw_cal_rson_score(&rson_curr, candidate->network.Rssi);
RTW_INFO("%s: candidate: %s("MAC_FMT", ch:%u) rson_score:%d\n", __FUNCTION__,
candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
candidate->network.Configuration.DSConfig, rson_score);
#else
RTW_INFO("%s: candidate: %s("MAC_FMT", ch:%u)\n", __FUNCTION__,
candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
candidate->network.Configuration.DSConfig);
#endif
mlme->roam_network = candidate;
if (_rtw_memcmp(candidate->network.MacAddress, mlme->roam_tgt_addr, ETH_ALEN) == _TRUE)
_rtw_memset(mlme->roam_tgt_addr, 0, ETH_ALEN);
}
ret = _SUCCESS;
exit:
_exit_critical_bh(&(mlme->scanned_queue.lock), &irqL);
return ret;
}
#endif /* CONFIG_LAYER2_ROAMING */
/*
* Select a new join candidate from the original @param candidate and @param competitor
* @return _TRUE: candidate is updated
* @return _FALSE: candidate is not updated
*/
static int rtw_check_join_candidate(struct mlme_priv *mlme
, struct wlan_network **candidate, struct wlan_network *competitor)
{
int updated = _FALSE;
_adapter *adapter = container_of(mlme, _adapter, mlmepriv);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
RT_CHANNEL_INFO *chset = rfctl->channel_set;
u8 ch = competitor->network.Configuration.DSConfig;
if (rtw_chset_search_ch(chset, ch) < 0)
goto exit;
if (IS_DFS_SLAVE_WITH_RD(rfctl)
&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
&& rtw_chset_is_ch_non_ocp(chset, ch))
goto exit;
#if defined(CONFIG_RTW_REPEATER_SON) && (!defined(CONFIG_RTW_REPEATER_SON_ROOT))
s16 rson_score;
struct rtw_rson_struct rson_data;
if (rtw_rson_choose(candidate, competitor)) {
*candidate = competitor;
rtw_get_rson_struct(&((*candidate)->network), &rson_data);
rson_score = rtw_cal_rson_score(&rson_data, (*candidate)->network.Rssi);
RTW_INFO("[assoc_ssid:%s] new candidate: %s("MAC_FMT", ch%u) rson_score:%d\n",
mlme->assoc_ssid.Ssid,
(*candidate)->network.Ssid.Ssid,
MAC_ARG((*candidate)->network.MacAddress),
(*candidate)->network.Configuration.DSConfig,
rson_score);
return _TRUE;
}
return _FALSE;
#endif
/* check bssid, if needed */
if (mlme->assoc_by_bssid == _TRUE) {
if (_rtw_memcmp(competitor->network.MacAddress, mlme->assoc_bssid, ETH_ALEN) == _FALSE)
goto exit;
}
/* check ssid, if needed */
if (mlme->assoc_ssid.Ssid[0] && mlme->assoc_ssid.SsidLength) {
if (competitor->network.Ssid.SsidLength != mlme->assoc_ssid.SsidLength
|| _rtw_memcmp(competitor->network.Ssid.Ssid, mlme->assoc_ssid.Ssid, mlme->assoc_ssid.SsidLength) == _FALSE
)
goto exit;
}
if (rtw_is_desired_network(adapter, competitor) == _FALSE)
goto exit;
#ifdef CONFIG_LAYER2_ROAMING
if (rtw_to_roam(adapter) > 0) {
if (rtw_get_passing_time_ms(competitor->last_scanned) >= mlme->roam_scanr_exp_ms
|| is_same_ess(&competitor->network, &mlme->cur_network.network) == _FALSE
)
goto exit;
}
#endif
if (*candidate == NULL || (*candidate)->network.Rssi < competitor->network.Rssi) {
*candidate = competitor;
updated = _TRUE;
}
if (updated) {
RTW_INFO("[by_bssid:%u][assoc_ssid:%s][to_roam:%u] "
"new candidate: %s("MAC_FMT", ch%u) rssi:%d\n",
mlme->assoc_by_bssid,
mlme->assoc_ssid.Ssid,
rtw_to_roam(adapter),
(*candidate)->network.Ssid.Ssid,
MAC_ARG((*candidate)->network.MacAddress),
(*candidate)->network.Configuration.DSConfig,
(int)(*candidate)->network.Rssi
);
}
exit:
return updated;
}
/*
Calling context:
The caller of the sub-routine will be in critical section...
The caller must hold the following spinlock
pmlmepriv->lock
*/
int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv)
{
_irqL irqL;
int ret;
_list *phead;
_adapter *adapter;
_queue *queue = &(pmlmepriv->scanned_queue);
struct wlan_network *pnetwork = NULL;
struct wlan_network *candidate = NULL;
#ifdef CONFIG_ANTENNA_DIVERSITY
u8 bSupportAntDiv = _FALSE;
#endif
adapter = (_adapter *)pmlmepriv->nic_hdl;
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
#ifdef CONFIG_LAYER2_ROAMING
if (pmlmepriv->roam_network) {
candidate = pmlmepriv->roam_network;
pmlmepriv->roam_network = NULL;
goto candidate_exist;
}
#endif
phead = get_list_head(queue);
pmlmepriv->pscanned = get_next(phead);
while (!rtw_end_of_queue_search(phead, pmlmepriv->pscanned)) {
pnetwork = LIST_CONTAINOR(pmlmepriv->pscanned, struct wlan_network, list);
if (pnetwork == NULL) {
ret = _FAIL;
goto exit;
}
pmlmepriv->pscanned = get_next(pmlmepriv->pscanned);
if (0)
RTW_INFO("%s("MAC_FMT", ch%u) rssi:%d\n"
, pnetwork->network.Ssid.Ssid
, MAC_ARG(pnetwork->network.MacAddress)
, pnetwork->network.Configuration.DSConfig
, (int)pnetwork->network.Rssi);
rtw_check_join_candidate(pmlmepriv, &candidate, pnetwork);
}
if (candidate == NULL) {
RTW_INFO("%s: return _FAIL(candidate == NULL)\n", __FUNCTION__);
#ifdef CONFIG_WOWLAN
_clr_fwstate_(pmlmepriv, _FW_LINKED | _FW_UNDER_LINKING);
#endif
ret = _FAIL;
goto exit;
} else {
RTW_INFO("%s: candidate: %s("MAC_FMT", ch:%u)\n", __FUNCTION__,
candidate->network.Ssid.Ssid, MAC_ARG(candidate->network.MacAddress),
candidate->network.Configuration.DSConfig);
goto candidate_exist;
}
candidate_exist:
/* check for situation of _FW_LINKED */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
RTW_INFO("%s: _FW_LINKED while ask_for_joinbss!!!\n", __FUNCTION__);
#if 0 /* for WPA/WPA2 authentication, wpa_supplicant will expect authentication from AP, it is needed to reconnect AP... */
if (is_same_network(&pmlmepriv->cur_network.network, &candidate->network)) {
RTW_INFO("%s: _FW_LINKED and is same network, it needn't join again\n", __FUNCTION__);
rtw_indicate_connect(adapter);/* rtw_indicate_connect again */
ret = 2;
goto exit;
} else
#endif
{
rtw_disassoc_cmd(adapter, 0, 0);
rtw_indicate_disconnect(adapter, 0, _FALSE);
rtw_free_assoc_resources_cmd(adapter, _TRUE, 0);
}
}
#ifdef CONFIG_ANTENNA_DIVERSITY
rtw_hal_get_def_var(adapter, HAL_DEF_IS_SUPPORT_ANT_DIV, &(bSupportAntDiv));
if (_TRUE == bSupportAntDiv) {
u8 CurrentAntenna;
rtw_hal_get_odm_var(adapter, HAL_ODM_ANTDIV_SELECT, &(CurrentAntenna), NULL);
RTW_INFO("#### Opt_Ant_(%s) , cur_Ant(%s)\n",
(MAIN_ANT == candidate->network.PhyInfo.Optimum_antenna) ? "MAIN_ANT" : "AUX_ANT",
(MAIN_ANT == CurrentAntenna) ? "MAIN_ANT" : "AUX_ANT"
);
}
#endif
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
ret = rtw_joinbss_cmd(adapter, candidate);
exit:
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
return ret;
}
sint rtw_set_auth(_adapter *adapter, struct security_priv *psecuritypriv)
{
struct cmd_obj *pcmd;
struct setauth_parm *psetauthparm;
struct cmd_priv *pcmdpriv = &(adapter->cmdpriv);
sint res = _SUCCESS;
pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd == NULL) {
res = _FAIL; /* try again */
goto exit;
}
psetauthparm = (struct setauth_parm *)rtw_zmalloc(sizeof(struct setauth_parm));
if (psetauthparm == NULL) {
rtw_mfree((unsigned char *)pcmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
_rtw_memset(psetauthparm, 0, sizeof(struct setauth_parm));
psetauthparm->mode = (unsigned char)psecuritypriv->dot11AuthAlgrthm;
pcmd->cmdcode = _SetAuth_CMD_;
pcmd->parmbuf = (unsigned char *)psetauthparm;
pcmd->cmdsz = (sizeof(struct setauth_parm));
pcmd->rsp = NULL;
pcmd->rspsz = 0;
_rtw_init_listhead(&pcmd->list);
res = rtw_enqueue_cmd(pcmdpriv, pcmd);
exit:
return res;
}
sint rtw_set_key(_adapter *adapter, struct security_priv *psecuritypriv, sint keyid, u8 set_tx, bool enqueue)
{
u8 keylen;
struct cmd_obj *pcmd;
struct setkey_parm *psetkeyparm;
struct cmd_priv *pcmdpriv = &(adapter->cmdpriv);
sint res = _SUCCESS;
psetkeyparm = (struct setkey_parm *)rtw_zmalloc(sizeof(struct setkey_parm));
if (psetkeyparm == NULL) {
res = _FAIL;
goto exit;
}
_rtw_memset(psetkeyparm, 0, sizeof(struct setkey_parm));
if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
psetkeyparm->algorithm = (unsigned char)psecuritypriv->dot118021XGrpPrivacy;
} else {
psetkeyparm->algorithm = (u8)psecuritypriv->dot11PrivacyAlgrthm;
}
psetkeyparm->keyid = (u8)keyid;/* 0~3 */
psetkeyparm->set_tx = set_tx;
if (is_wep_enc(psetkeyparm->algorithm))
adapter->securitypriv.key_mask |= BIT(psetkeyparm->keyid);
RTW_INFO("==> rtw_set_key algorithm(%x),keyid(%x),key_mask(%x)\n", psetkeyparm->algorithm, psetkeyparm->keyid, adapter->securitypriv.key_mask);
switch (psetkeyparm->algorithm) {
case _WEP40_:
keylen = 5;
_rtw_memcpy(&(psetkeyparm->key[0]), &(psecuritypriv->dot11DefKey[keyid].skey[0]), keylen);
break;
case _WEP104_:
keylen = 13;
_rtw_memcpy(&(psetkeyparm->key[0]), &(psecuritypriv->dot11DefKey[keyid].skey[0]), keylen);
break;
case _TKIP_:
keylen = 16;
_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
break;
case _AES_:
keylen = 16;
_rtw_memcpy(&psetkeyparm->key, &psecuritypriv->dot118021XGrpKey[keyid], keylen);
break;
default:
res = _FAIL;
rtw_mfree((unsigned char *)psetkeyparm, sizeof(struct setkey_parm));
goto exit;
}
if (enqueue) {
pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd == NULL) {
rtw_mfree((unsigned char *)psetkeyparm, sizeof(struct setkey_parm));
res = _FAIL; /* try again */
goto exit;
}
pcmd->cmdcode = _SetKey_CMD_;
pcmd->parmbuf = (u8 *)psetkeyparm;
pcmd->cmdsz = (sizeof(struct setkey_parm));
pcmd->rsp = NULL;
pcmd->rspsz = 0;
_rtw_init_listhead(&pcmd->list);
/* _rtw_init_sema(&(pcmd->cmd_sem), 0); */
res = rtw_enqueue_cmd(pcmdpriv, pcmd);
} else {
setkey_hdl(adapter, (u8 *)psetkeyparm);
rtw_mfree((u8 *) psetkeyparm, sizeof(struct setkey_parm));
}
exit:
return res;
}
#ifdef CONFIG_WMMPS_STA
/*
* rtw_uapsd_use_default_setting
* This function is used for setting default uapsd max sp length to uapsd_max_sp_len
* in qos_priv data structure from registry. In additional, it will also map default uapsd
* ac to each uapsd TID, delivery-enabled and trigger-enabled of corresponding TID.
*
* Arguments:
* @padapter: _adapter pointer.
*
* Auther: Arvin Liu
* Date: 2017/05/03
*/
void rtw_uapsd_use_default_setting(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
if (pregistrypriv->uapsd_ac_enable != 0) {
pqospriv->uapsd_max_sp_len = pregistrypriv->uapsd_max_sp_len;
CLEAR_FLAGS(pqospriv->uapsd_tid);
CLEAR_FLAGS(pqospriv->uapsd_tid_delivery_enabled);
CLEAR_FLAGS(pqospriv->uapsd_tid_trigger_enabled);
/* check the uapsd setting of AC_VO from registry then map these setting to each TID if necessary */
if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_VO)) {
SET_FLAG(pqospriv->uapsd_tid, WMM_TID7);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID7);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID7);
SET_FLAG(pqospriv->uapsd_tid, WMM_TID6);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID6);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID6);
}
/* check the uapsd setting of AC_VI from registry then map these setting to each TID if necessary */
if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_VI)) {
SET_FLAG(pqospriv->uapsd_tid, WMM_TID5);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID5);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID5);
SET_FLAG(pqospriv->uapsd_tid, WMM_TID4);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID4);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID4);
}
/* check the uapsd setting of AC_BK from registry then map these setting to each TID if necessary */
if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_BK)) {
SET_FLAG(pqospriv->uapsd_tid, WMM_TID2);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID2);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID2);
SET_FLAG(pqospriv->uapsd_tid, WMM_TID1);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID1);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID1);
}
/* check the uapsd setting of AC_BE from registry then map these setting to each TID if necessary */
if(TEST_FLAG(pregistrypriv->uapsd_ac_enable, DRV_CFG_UAPSD_BE)) {
SET_FLAG(pqospriv->uapsd_tid, WMM_TID3);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID3);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID3);
SET_FLAG(pqospriv->uapsd_tid, WMM_TID0);
SET_FLAG(pqospriv->uapsd_tid_delivery_enabled, WMM_TID0);
SET_FLAG(pqospriv->uapsd_tid_trigger_enabled, WMM_TID0);
}
RTW_INFO("[WMMPS] UAPSD MAX SP Len = 0x%02x, UAPSD TID enabled = 0x%02x\n",
pqospriv->uapsd_max_sp_len, (u8)pqospriv->uapsd_tid);
}
}
/*
* rtw_is_wmmps_mode
* This function is used for checking whether Driver and an AP support uapsd function or not.
* If both of them support uapsd function, it will return true. Otherwise returns false.
*
* Arguments:
* @padapter: _adapter pointer.
*
* Auther: Arvin Liu
* Date: 2017/06/12
*/
bool rtw_is_wmmps_mode(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
if ((pqospriv->uapsd_ap_supported) && ((pqospriv->uapsd_tid & BIT_MASK_TID_TC) != 0))
return _TRUE;
return _FALSE;
}
#endif /* CONFIG_WMMPS_STA */
/* adjust IEs for rtw_joinbss_cmd in WMM */
int rtw_restruct_wmm_ie(_adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_len, uint initial_out_len)
{
#ifdef CONFIG_WMMPS_STA
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
#endif /* CONFIG_WMMPS_STA */
unsigned int ielength = 0;
unsigned int i, j;
u8 qos_info = 0;
i = 12; /* after the fixed IE */
while (i < in_len) {
ielength = initial_out_len;
if (in_ie[i] == 0xDD && in_ie[i + 2] == 0x00 && in_ie[i + 3] == 0x50 && in_ie[i + 4] == 0xF2 && in_ie[i + 5] == 0x02 && i + 5 < in_len) { /* WMM element ID and OUI */
/* Append WMM IE to the last index of out_ie */
#if 0
for (j = i; j < i + (in_ie[i + 1] + 2); j++) {
out_ie[ielength] = in_ie[j];
ielength++;
}
out_ie[initial_out_len + 8] = 0x00; /* force the QoS Info Field to be zero */
#endif
for (j = i; j < i + 9; j++) {
out_ie[ielength] = in_ie[j];
ielength++;
}
out_ie[initial_out_len + 1] = 0x07;
out_ie[initial_out_len + 6] = 0x00;
#ifdef CONFIG_WMMPS_STA
switch(pqospriv->uapsd_max_sp_len) {
case NO_LIMIT:
/* do nothing */
break;
case TWO_MSDU:
SET_FLAG(qos_info, BIT5);
break;
case FOUR_MSDU:
SET_FLAG(qos_info, BIT6);
break;
case SIX_MSDU:
SET_FLAG(qos_info, BIT5);
SET_FLAG(qos_info, BIT6);
break;
default:
/* do nothing */
break;
};
/* check TID7 and TID6 for AC_VO to set corresponding Qos_info bit in WMM IE */
if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID7)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID6)))
SET_FLAG(qos_info, WMM_IE_UAPSD_VO);
/* check TID5 and TID4 for AC_VI to set corresponding Qos_info bit in WMM IE */
if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID5)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID4)))
SET_FLAG(qos_info, WMM_IE_UAPSD_VI);
/* check TID2 and TID1 for AC_BK to set corresponding Qos_info bit in WMM IE */
if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID2)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID1)))
SET_FLAG(qos_info, WMM_IE_UAPSD_BK);
/* check TID3 and TID0 for AC_BE to set corresponding Qos_info bit in WMM IE */
if((TEST_FLAG(pqospriv->uapsd_tid, WMM_TID3)) && (TEST_FLAG(pqospriv->uapsd_tid, WMM_TID0)))
SET_FLAG(qos_info, WMM_IE_UAPSD_BE);
#endif /* CONFIG_WMMPS_STA */
out_ie[initial_out_len + 8] = qos_info;
break;
}
i += (in_ie[i + 1] + 2); /* to the next IE element */
}
return ielength;
}
/*
* Ported from 8185: IsInPreAuthKeyList(). (Renamed from SecIsInPreAuthKeyList(), 2006-10-13.)
* Added by Annie, 2006-05-07.
*
* Search by BSSID,
* Return Value:
* -1 :if there is no pre-auth key in the table
* >=0 :if there is pre-auth key, and return the entry id
*
* */
static int SecIsInPMKIDList(_adapter *Adapter, u8 *bssid)
{
struct security_priv *psecuritypriv = &Adapter->securitypriv;
int i = 0;
do {
if ((psecuritypriv->PMKIDList[i].bUsed) &&
(_rtw_memcmp(psecuritypriv->PMKIDList[i].Bssid, bssid, ETH_ALEN) == _TRUE))
break;
else {
i++;
/* continue; */
}
} while (i < NUM_PMKID_CACHE);
if (i == NUM_PMKID_CACHE) {
i = -1;/* Could not find. */
} else {
/* There is one Pre-Authentication Key for the specific BSSID. */
}
return i;
}
int rtw_cached_pmkid(_adapter *Adapter, u8 *bssid)
{
return SecIsInPMKIDList(Adapter, bssid);
}
int rtw_rsn_sync_pmkid(_adapter *adapter, u8 *ie, uint ie_len, int i_ent)
{
struct security_priv *sec = &adapter->securitypriv;
struct rsne_info info;
u8 gm_cs[4];
int i;
rtw_rsne_info_parse(ie, ie_len, &info);
if (info.err) {
RTW_WARN(FUNC_ADPT_FMT" rtw_rsne_info_parse error\n"
, FUNC_ADPT_ARG(adapter));
return 0;
}
if (i_ent < 0 && info.pmkid_cnt == 0)
goto exit;
if (i_ent >= 0 && info.pmkid_cnt == 1 && _rtw_memcmp(info.pmkid_list, sec->PMKIDList[i_ent].PMKID, 16)) {
RTW_INFO(FUNC_ADPT_FMT" has carried the same PMKID:"KEY_FMT"\n"
, FUNC_ADPT_ARG(adapter), KEY_ARG(&sec->PMKIDList[i_ent].PMKID));
goto exit;
}
/* bakcup group mgmt cs */
if (info.gmcs)
_rtw_memcpy(gm_cs, info.gmcs, 4);
if (info.pmkid_cnt) {
RTW_INFO(FUNC_ADPT_FMT" remove original PMKID, count:%u\n"
, FUNC_ADPT_ARG(adapter), info.pmkid_cnt);
for (i = 0; i < info.pmkid_cnt; i++)
RTW_INFO(" "KEY_FMT"\n", KEY_ARG(info.pmkid_list + i * 16));
}
if (i_ent >= 0) {
RTW_INFO(FUNC_ADPT_FMT" append PMKID:"KEY_FMT"\n"
, FUNC_ADPT_ARG(adapter), KEY_ARG(sec->PMKIDList[i_ent].PMKID));
info.pmkid_cnt = 1; /* update new pmkid_cnt */
_rtw_memcpy(info.pmkid_list, sec->PMKIDList[i_ent].PMKID, 16);
} else
info.pmkid_cnt = 0; /* update new pmkid_cnt */
RTW_PUT_LE16(info.pmkid_list - 2, info.pmkid_cnt);
if (info.gmcs)
_rtw_memcpy(info.pmkid_list + 16 * info.pmkid_cnt, gm_cs, 4);
ie_len = 1 + 1 + 2 + 4
+ 2 + 4 * info.pcs_cnt
+ 2 + 4 * info.akm_cnt
+ 2
+ 2 + 16 * info.pmkid_cnt
+ (info.gmcs ? 4 : 0)
;
ie[1] = (u8)(ie_len - 2);
exit:
return ie_len;
}
sint rtw_restruct_sec_ie(_adapter *adapter, u8 *out_ie)
{
u8 authmode = 0x0;
uint ielength = 0;
int iEntry;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct security_priv *psecuritypriv = &adapter->securitypriv;
uint ndisauthmode = psecuritypriv->ndisauthtype;
if ((ndisauthmode == Ndis802_11AuthModeWPA) || (ndisauthmode == Ndis802_11AuthModeWPAPSK))
authmode = _WPA_IE_ID_;
if ((ndisauthmode == Ndis802_11AuthModeWPA2) || (ndisauthmode == Ndis802_11AuthModeWPA2PSK))
authmode = _WPA2_IE_ID_;
if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
_rtw_memcpy(out_ie, psecuritypriv->wps_ie, psecuritypriv->wps_ie_len);
ielength = psecuritypriv->wps_ie_len;
} else if ((authmode == _WPA_IE_ID_) || (authmode == _WPA2_IE_ID_)) {
/* copy RSN or SSN */
_rtw_memcpy(out_ie, psecuritypriv->supplicant_ie, psecuritypriv->supplicant_ie[1] + 2);
/* debug for CONFIG_IEEE80211W
{
int jj;
printk("supplicant_ie_length=%d &&&&&&&&&&&&&&&&&&&\n", psecuritypriv->supplicant_ie[1]+2);
for(jj=0; jj < psecuritypriv->supplicant_ie[1]+2; jj++)
printk(" %02x ", psecuritypriv->supplicant_ie[jj]);
printk("\n");
}*/
ielength = psecuritypriv->supplicant_ie[1] + 2;
rtw_report_sec_ie(adapter, authmode, psecuritypriv->supplicant_ie);
}
if (authmode == WLAN_EID_RSN) {
iEntry = SecIsInPMKIDList(adapter, pmlmepriv->assoc_bssid);
ielength = rtw_rsn_sync_pmkid(adapter, out_ie, ielength, iEntry);
}
return ielength;
}
void rtw_init_registrypriv_dev_network(_adapter *adapter)
{
struct registry_priv *pregistrypriv = &adapter->registrypriv;
WLAN_BSSID_EX *pdev_network = &pregistrypriv->dev_network;
u8 *myhwaddr = adapter_mac_addr(adapter);
_rtw_memcpy(pdev_network->MacAddress, myhwaddr, ETH_ALEN);
_rtw_memcpy(&pdev_network->Ssid, &pregistrypriv->ssid, sizeof(NDIS_802_11_SSID));
pdev_network->Configuration.Length = sizeof(NDIS_802_11_CONFIGURATION);
pdev_network->Configuration.BeaconPeriod = 100;
}
void rtw_update_registrypriv_dev_network(_adapter *adapter)
{
int sz = 0;
struct registry_priv *pregistrypriv = &adapter->registrypriv;
WLAN_BSSID_EX *pdev_network = &pregistrypriv->dev_network;
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct wlan_network *cur_network = &adapter->mlmepriv.cur_network;
/* struct xmit_priv *pxmitpriv = &adapter->xmitpriv; */
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
#if 0
pxmitpriv->vcs_setting = pregistrypriv->vrtl_carrier_sense;
pxmitpriv->vcs = pregistrypriv->vcs_type;
pxmitpriv->vcs_type = pregistrypriv->vcs_type;
/* pxmitpriv->rts_thresh = pregistrypriv->rts_thresh; */
pxmitpriv->frag_len = pregistrypriv->frag_thresh;
adapter->qospriv.qos_option = pregistrypriv->wmm_enable;
#endif
pdev_network->Privacy = (psecuritypriv->dot11PrivacyAlgrthm > 0 ? 1 : 0) ; /* adhoc no 802.1x */
pdev_network->Rssi = 0;
pdev_network->Configuration.DSConfig = (pregistrypriv->channel);
if (cur_network->network.InfrastructureMode == Ndis802_11IBSS) {
pdev_network->Configuration.ATIMWindow = (0);
if (pmlmeext->cur_channel != 0)
pdev_network->Configuration.DSConfig = pmlmeext->cur_channel;
else
pdev_network->Configuration.DSConfig = 1;
}
pdev_network->InfrastructureMode = (cur_network->network.InfrastructureMode);
/* 1. Supported rates */
/* 2. IE */
/* rtw_set_supported_rate(pdev_network->SupportedRates, pregistrypriv->wireless_mode) ; */ /* will be called in rtw_generate_ie */
sz = rtw_generate_ie(pregistrypriv);
pdev_network->IELength = sz;
pdev_network->Length = get_WLAN_BSSID_EX_sz((WLAN_BSSID_EX *)pdev_network);
/* notes: translate IELength & Length after assign the Length to cmdsz in createbss_cmd(); */
/* pdev_network->IELength = cpu_to_le32(sz); */
}
void rtw_get_encrypt_decrypt_from_registrypriv(_adapter *adapter)
{
}
/* the fucntion is at passive_level */
void rtw_joinbss_reset(_adapter *padapter)
{
u8 threshold;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
/* todo: if you want to do something io/reg/hw setting before join_bss, please add code here */
#ifdef CONFIG_80211N_HT
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
pmlmepriv->num_FortyMHzIntolerant = 0;
pmlmepriv->num_sta_no_ht = 0;
phtpriv->ampdu_enable = _FALSE;/* reset to disabled */
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI)
/* TH=1 => means that invalidate usb rx aggregation */
/* TH=0 => means that validate usb rx aggregation, use init value. */
if (phtpriv->ht_option) {
if (padapter->registrypriv.wifi_spec == 1)
threshold = 1;
else
threshold = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
} else {
threshold = 1;
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
}
#endif/* #if defined( CONFIG_USB_HCI) || defined (CONFIG_SDIO_HCI) */
#endif/* #ifdef CONFIG_80211N_HT */
}
#ifdef CONFIG_80211N_HT
void rtw_ht_use_default_setting(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
BOOLEAN bHwLDPCSupport = _FALSE, bHwSTBCSupport = _FALSE;
#ifdef CONFIG_BEAMFORMING
BOOLEAN bHwSupportBeamformer = _FALSE, bHwSupportBeamformee = _FALSE;
#endif /* CONFIG_BEAMFORMING */
if (pregistrypriv->wifi_spec)
phtpriv->bss_coexist = 1;
else
phtpriv->bss_coexist = 0;
phtpriv->sgi_40m = TEST_FLAG(pregistrypriv->short_gi, BIT1) ? _TRUE : _FALSE;
phtpriv->sgi_20m = TEST_FLAG(pregistrypriv->short_gi, BIT0) ? _TRUE : _FALSE;
/* LDPC support */
rtw_hal_get_def_var(padapter, HAL_DEF_RX_LDPC, (u8 *)&bHwLDPCSupport);
CLEAR_FLAGS(phtpriv->ldpc_cap);
if (bHwLDPCSupport) {
if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT4))
SET_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX);
}
rtw_hal_get_def_var(padapter, HAL_DEF_TX_LDPC, (u8 *)&bHwLDPCSupport);
if (bHwLDPCSupport) {
if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT5))
SET_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX);
}
if (phtpriv->ldpc_cap)
RTW_INFO("[HT] HAL Support LDPC = 0x%02X\n", phtpriv->ldpc_cap);
/* STBC */
rtw_hal_get_def_var(padapter, HAL_DEF_TX_STBC, (u8 *)&bHwSTBCSupport);
CLEAR_FLAGS(phtpriv->stbc_cap);
if (bHwSTBCSupport) {
if (TEST_FLAG(pregistrypriv->stbc_cap, BIT5))
SET_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX);
}
rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)&bHwSTBCSupport);
if (bHwSTBCSupport) {
if (TEST_FLAG(pregistrypriv->stbc_cap, BIT4))
SET_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX);
}
if (phtpriv->stbc_cap)
RTW_INFO("[HT] HAL Support STBC = 0x%02X\n", phtpriv->stbc_cap);
/* Beamforming setting */
CLEAR_FLAGS(phtpriv->beamform_cap);
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
/* only enable beamforming in STA client mode */
if (MLME_IS_STA(padapter) && !MLME_IS_GC(padapter)
&& !MLME_IS_ADHOC(padapter)
&& !MLME_IS_MESH(padapter))
#endif
{
rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&bHwSupportBeamformer);
rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&bHwSupportBeamformee);
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT4) && bHwSupportBeamformer) {
SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
RTW_INFO("[HT] HAL Support Beamformer\n");
}
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT5) && bHwSupportBeamformee) {
SET_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
RTW_INFO("[HT] HAL Support Beamformee\n");
}
}
#endif /* CONFIG_BEAMFORMING */
}
void rtw_build_wmm_ie_ht(_adapter *padapter, u8 *out_ie, uint *pout_len)
{
unsigned char WMM_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01, 0x00};
int out_len;
u8 *pframe;
if (padapter->mlmepriv.qospriv.qos_option == 0) {
out_len = *pout_len;
pframe = rtw_set_ie(out_ie + out_len, _VENDOR_SPECIFIC_IE_,
_WMM_IE_Length_, WMM_IE, pout_len);
padapter->mlmepriv.qospriv.qos_option = 1;
}
}
#if defined(CONFIG_80211N_HT)
/* the fucntion is >= passive_level */
unsigned int rtw_restructure_ht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len, u8 channel)
{
u32 ielen, out_len;
u32 rx_packet_offset, max_recvbuf_sz;
HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor;
HT_CAP_AMPDU_DENSITY best_ampdu_density;
unsigned char *p, *pframe;
struct rtw_ieee80211_ht_cap ht_capie;
u8 cbw40_enable = 0, rf_type = 0, rf_num = 0, rx_stbc_nss = 0, rx_nss = 0;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
#ifdef CONFIG_80211AC_VHT
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
#endif /* CONFIG_80211AC_VHT */
phtpriv->ht_option = _FALSE;
out_len = *pout_len;
_rtw_memset(&ht_capie, 0, sizeof(struct rtw_ieee80211_ht_cap));
ht_capie.cap_info = IEEE80211_HT_CAP_DSSSCCK40;
if (phtpriv->sgi_20m)
ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_20;
/* check if 40MHz is allowed according to hal cap and registry */
if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
if (channel > 14) {
if (REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
cbw40_enable = 1;
} else {
if (REGSTY_IS_BW_2G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
cbw40_enable = 1;
}
}
if (cbw40_enable) {
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
RT_CHANNEL_INFO *chset = rfctl->channel_set;
u8 oper_bw = CHANNEL_WIDTH_20, oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
if (in_ie == NULL) {
/* TDLS: TODO 20/40 issue */
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
oper_bw = padapter->mlmeextpriv.cur_bwmode;
if (oper_bw > CHANNEL_WIDTH_40)
oper_bw = CHANNEL_WIDTH_40;
} else
/* TDLS: TODO 40? */
oper_bw = CHANNEL_WIDTH_40;
} else {
p = rtw_get_ie(in_ie, WLAN_EID_HT_OPERATION, &ielen, in_len);
if (p && ielen == HT_OP_IE_LEN) {
if (GET_HT_OP_ELE_STA_CHL_WIDTH(p + 2)) {
switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(p + 2)) {
case SCA:
oper_bw = CHANNEL_WIDTH_40;
oper_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case SCB:
oper_bw = CHANNEL_WIDTH_40;
oper_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
}
}
}
// IOT issue : AP TP-Link WDR6500
if(oper_bw == CHANNEL_WIDTH_40){
p = rtw_get_ie(in_ie, WLAN_EID_HT_CAP, &ielen, in_len);
if (p && ielen == HT_CAP_IE_LEN) {
oper_bw = GET_HT_CAP_ELE_CHL_WIDTH(p + 2) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20;
if(oper_bw == CHANNEL_WIDTH_20)
oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
}
}
/* adjust bw to fit in channel plan setting */
if (oper_bw == CHANNEL_WIDTH_40
&& oper_offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE /* check this because TDLS has no info to set offset */
&& (!rtw_chset_is_chbw_valid(chset, channel, oper_bw, oper_offset)
|| (IS_DFS_SLAVE_WITH_RD(rfctl)
&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
&& rtw_chset_is_chbw_non_ocp(chset, channel, oper_bw, oper_offset))
)
) {
oper_bw = CHANNEL_WIDTH_20;
oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
rtw_warn_on(!rtw_chset_is_chbw_valid(chset, channel, oper_bw, oper_offset));
if (IS_DFS_SLAVE_WITH_RD(rfctl) && !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl)))
rtw_warn_on(rtw_chset_is_chbw_non_ocp(chset, channel, oper_bw, oper_offset));
}
if (oper_bw == CHANNEL_WIDTH_40) {
ht_capie.cap_info |= IEEE80211_HT_CAP_SUP_WIDTH;
if (phtpriv->sgi_40m)
ht_capie.cap_info |= IEEE80211_HT_CAP_SGI_40;
}
cbw40_enable = oper_bw == CHANNEL_WIDTH_40 ? 1 : 0;
}
/* todo: disable SM power save mode */
ht_capie.cap_info |= IEEE80211_HT_CAP_SM_PS;
/* RX LDPC */
if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_RX)) {
ht_capie.cap_info |= IEEE80211_HT_CAP_LDPC_CODING;
RTW_INFO("[HT] Declare supporting RX LDPC\n");
}
/* TX STBC */
if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX)) {
ht_capie.cap_info |= IEEE80211_HT_CAP_TX_STBC;
RTW_INFO("[HT] Declare supporting TX STBC\n");
}
/* RX STBC */
if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_RX)) {
if ((pregistrypriv->rx_stbc == 0x3) || /* enable for 2.4/5 GHz */
((channel <= 14) && (pregistrypriv->rx_stbc == 0x1)) || /* enable for 2.4GHz */
((channel > 14) && (pregistrypriv->rx_stbc == 0x2)) || /* enable for 5GHz */
(pregistrypriv->wifi_spec == 1)) {
/* HAL_DEF_RX_STBC means STBC RX spatial stream, todo: VHT 4 streams */
rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)(&rx_stbc_nss));
SET_HT_CAP_ELE_RX_STBC(&ht_capie, rx_stbc_nss);
RTW_INFO("[HT] Declare supporting RX STBC = %d\n", rx_stbc_nss);
}
}
/* fill default supported_mcs_set */
_rtw_memcpy(ht_capie.supp_mcs_set, pmlmeext->default_supported_mcs_set, 16);
/* update default supported_mcs_set */
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
switch (rx_nss) {
case 1:
set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_1R);
break;
case 2:
#ifdef CONFIG_DISABLE_MCS13TO15
if (cbw40_enable && pregistrypriv->wifi_spec != 1)
set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R_13TO15_OFF);
else
#endif
set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_2R);
break;
case 3:
set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_3R);
break;
case 4:
set_mcs_rate_by_mask(ht_capie.supp_mcs_set, MCS_RATE_4R);
break;
default:
RTW_WARN("rf_type:%d or rx_nss:%u is not expected\n", rf_type, hal_spec->rx_nss_num);
}
{
rtw_hal_get_def_var(padapter, HAL_DEF_RX_PACKET_OFFSET, &rx_packet_offset);
rtw_hal_get_def_var(padapter, HAL_DEF_MAX_RECVBUF_SZ, &max_recvbuf_sz);
if (max_recvbuf_sz - rx_packet_offset >= (8191 - 256)) {
RTW_INFO("%s IEEE80211_HT_CAP_MAX_AMSDU is set\n", __FUNCTION__);
ht_capie.cap_info = ht_capie.cap_info | IEEE80211_HT_CAP_MAX_AMSDU;
}
}
/*
AMPDU_para [1:0]:Max AMPDU Len => 0:8k , 1:16k, 2:32k, 3:64k
AMPDU_para [4:2]:Min MPDU Start Spacing
*/
/*
#if defined(CONFIG_RTL8188E) && defined(CONFIG_SDIO_HCI)
ht_capie.ampdu_params_info = 2;
#else
ht_capie.ampdu_params_info = (IEEE80211_HT_CAP_AMPDU_FACTOR&0x03);
#endif
*/
if (padapter->driver_rx_ampdu_factor != 0xFF)
max_rx_ampdu_factor = (HT_CAP_AMPDU_FACTOR)padapter->driver_rx_ampdu_factor;
else
rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
/* rtw_hal_get_def_var(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor); */
ht_capie.ampdu_params_info = (max_rx_ampdu_factor & 0x03);
if (padapter->driver_rx_ampdu_spacing != 0xFF)
ht_capie.ampdu_params_info |= ((padapter->driver_rx_ampdu_spacing & 0x07) << 2);
else {
if (padapter->securitypriv.dot11PrivacyAlgrthm == _AES_) {
/*
* Todo : Each chip must to ask DD , this chip best ampdu_density setting
* By yiwei.sun
*/
rtw_hal_get_def_var(padapter, HW_VAR_BEST_AMPDU_DENSITY, &best_ampdu_density);
ht_capie.ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & (best_ampdu_density << 2));
} else
ht_capie.ampdu_params_info |= (IEEE80211_HT_CAP_AMPDU_DENSITY & 0x00);
}
#ifdef CONFIG_BEAMFORMING
ht_capie.tx_BF_cap_info = 0;
/* HT Beamformer*/
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE)) {
/* Transmit NDP Capable */
SET_HT_CAP_TXBF_TRANSMIT_NDP_CAP(&ht_capie, 1);
/* Explicit Compressed Steering Capable */
SET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(&ht_capie, 1);
/* Compressed Steering Number Antennas */
SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(&ht_capie, 1);
rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
SET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(&ht_capie, rf_num);
}
/* HT Beamformee */
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE)) {
/* Receive NDP Capable */
SET_HT_CAP_TXBF_RECEIVE_NDP_CAP(&ht_capie, 1);
/* Explicit Compressed Beamforming Feedback Capable */
SET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(&ht_capie, 2);
rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
#ifdef CONFIG_80211AC_VHT
/* IOT action suggested by Yu Chen 2017/3/3 */
if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) &&
!pvhtpriv->ap_is_mu_bfer)
rf_num = (rf_num >= 2 ? 2 : rf_num);
#endif
SET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(&ht_capie, rf_num);
}
#endif/*CONFIG_BEAMFORMING*/
pframe = rtw_set_ie(out_ie + out_len, _HT_CAPABILITY_IE_,
sizeof(struct rtw_ieee80211_ht_cap), (unsigned char *)&ht_capie, pout_len);
phtpriv->ht_option = _TRUE;
if (in_ie != NULL) {
p = rtw_get_ie(in_ie, _HT_ADD_INFO_IE_, &ielen, in_len);
if (p && (ielen == sizeof(struct ieee80211_ht_addt_info))) {
out_len = *pout_len;
pframe = rtw_set_ie(out_ie + out_len, _HT_ADD_INFO_IE_, ielen, p + 2 , pout_len);
}
}
return phtpriv->ht_option;
}
/* the fucntion is > passive_level (in critical_section) */
void rtw_update_ht_cap(_adapter *padapter, u8 *pie, uint ie_len, u8 channel)
{
u8 *p, max_ampdu_sz;
int len;
/* struct sta_info *bmc_sta, *psta; */
struct rtw_ieee80211_ht_cap *pht_capie;
struct ieee80211_ht_addt_info *pht_addtinfo;
/* struct recv_reorder_ctrl *preorder_ctrl; */
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
/* struct recv_priv *precvpriv = &padapter->recvpriv; */
struct registry_priv *pregistrypriv = &padapter->registrypriv;
/* struct wlan_network *pcur_network = &(pmlmepriv->cur_network);; */
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 cbw40_enable = 0;
if (!phtpriv->ht_option)
return;
if ((!pmlmeinfo->HT_info_enable) || (!pmlmeinfo->HT_caps_enable))
return;
RTW_INFO("+rtw_update_ht_cap()\n");
/* maybe needs check if ap supports rx ampdu. */
if ((phtpriv->ampdu_enable == _FALSE) && (pregistrypriv->ampdu_enable == 1)) {
if (pregistrypriv->wifi_spec == 1) {
/* remove this part because testbed AP should disable RX AMPDU */
/* phtpriv->ampdu_enable = _FALSE; */
phtpriv->ampdu_enable = _TRUE;
} else
phtpriv->ampdu_enable = _TRUE;
}
/* check Max Rx A-MPDU Size */
len = 0;
p = rtw_get_ie(pie + sizeof(NDIS_802_11_FIXED_IEs), _HT_CAPABILITY_IE_, &len, ie_len - sizeof(NDIS_802_11_FIXED_IEs));
if (p && len > 0) {
pht_capie = (struct rtw_ieee80211_ht_cap *)(p + 2);
max_ampdu_sz = (pht_capie->ampdu_params_info & IEEE80211_HT_CAP_AMPDU_FACTOR);
max_ampdu_sz = 1 << (max_ampdu_sz + 3); /* max_ampdu_sz (kbytes); */
/* RTW_INFO("rtw_update_ht_cap(): max_ampdu_sz=%d\n", max_ampdu_sz); */
phtpriv->rx_ampdu_maxlen = max_ampdu_sz;
}
len = 0;
p = rtw_get_ie(pie + sizeof(NDIS_802_11_FIXED_IEs), _HT_ADD_INFO_IE_, &len, ie_len - sizeof(NDIS_802_11_FIXED_IEs));
if (p && len > 0) {
pht_addtinfo = (struct ieee80211_ht_addt_info *)(p + 2);
/* todo: */
}
if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
if (channel > 14) {
if (REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
cbw40_enable = 1;
} else {
if (REGSTY_IS_BW_2G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
cbw40_enable = 1;
}
}
/* update cur_bwmode & cur_ch_offset */
if ((cbw40_enable) &&
(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) &&
(pmlmeinfo->HT_info.infos[0] & BIT(2))) {
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
int i;
u8 rf_type = RF_1T1R;
u8 tx_nss = 0;
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
/* update the MCS set */
for (i = 0; i < 16; i++)
pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate[i] &= pmlmeext->default_supported_mcs_set[i];
/* update the MCS rates */
switch (tx_nss) {
case 1:
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_1R);
break;
case 2:
#ifdef CONFIG_DISABLE_MCS13TO15
if (pmlmeext->cur_bwmode == CHANNEL_WIDTH_40 && pregistrypriv->wifi_spec != 1)
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R_13TO15_OFF);
else
#endif
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R);
break;
case 3:
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_3R);
break;
case 4:
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_4R);
break;
default:
RTW_WARN("rf_type:%d or tx_nss_num:%u is not expected\n", rf_type, hal_spec->tx_nss_num);
}
/* switch to the 40M Hz mode accoring to the AP */
/* pmlmeext->cur_bwmode = CHANNEL_WIDTH_40; */
switch ((pmlmeinfo->HT_info.infos[0] & 0x3)) {
case EXTCHNL_OFFSET_UPPER:
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case EXTCHNL_OFFSET_LOWER:
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
default:
pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
RTW_INFO("%s : ch offset is not assigned for HT40 mod , update cur_bwmode=%u, cur_ch_offset=%u\n",
__func__, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
break;
}
}
/* */
/* Config SM Power Save setting */
/* */
pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC) {
#if 0
u8 i;
/* update the MCS rates */
for (i = 0; i < 16; i++)
pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
#endif
RTW_INFO("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __FUNCTION__);
}
/* */
/* Config current HT Protection mode. */
/* */
pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3;
}
#endif
#ifdef CONFIG_TDLS
void rtw_issue_addbareq_cmd_tdls(_adapter *padapter, struct xmit_frame *pxmitframe)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct sta_info *ptdls_sta = NULL;
u8 issued;
int priority;
struct ht_priv *phtpriv;
priority = pattrib->priority;
if (pattrib->direct_link == _TRUE) {
ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pattrib->dst);
if ((ptdls_sta != NULL) && (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)) {
phtpriv = &ptdls_sta->htpriv;
if ((phtpriv->ht_option == _TRUE) && (phtpriv->ampdu_enable == _TRUE)) {
issued = (phtpriv->agg_enable_bitmap >> priority) & 0x1;
issued |= (phtpriv->candidate_tid_bitmap >> priority) & 0x1;
if (0 == issued) {
RTW_INFO("[%s], p=%d\n", __FUNCTION__, priority);
ptdls_sta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
rtw_addbareq_cmd(padapter, (u8)priority, pattrib->dst);
}
}
}
}
}
#endif /* CONFIG_TDLS */
#ifdef CONFIG_80211N_HT
static u8 rtw_issue_addbareq_check(_adapter *padapter, struct xmit_frame *pxmitframe, u8 issue_when_busy)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct registry_priv *pregistry = &padapter->registrypriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
s32 bmcst = IS_MCAST(pattrib->ra);
if (bmcst)
return _FALSE;
if (pregistry->tx_quick_addba_req == 0) {
if ((issue_when_busy == _TRUE) && (pmlmepriv->LinkDetectInfo.bBusyTraffic == _FALSE))
return _FALSE;
if (pmlmepriv->LinkDetectInfo.NumTxOkInPeriod < 100)
return _FALSE;
}
return _TRUE;
}
void rtw_issue_addbareq_cmd(_adapter *padapter, struct xmit_frame *pxmitframe, u8 issue_when_busy)
{
u8 issued;
int priority;
struct sta_info *psta = NULL;
struct ht_priv *phtpriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
if (rtw_issue_addbareq_check(padapter,pxmitframe, issue_when_busy) == _FALSE)
return;
priority = pattrib->priority;
#ifdef CONFIG_TDLS
rtw_issue_addbareq_cmd_tdls(padapter, pxmitframe);
#endif /* CONFIG_TDLS */
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if (pattrib->psta != psta) {
RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
return;
}
if (psta == NULL) {
RTW_INFO("%s, psta==NUL\n", __func__);
return;
}
if (!(psta->state & _FW_LINKED)) {
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return;
}
phtpriv = &psta->htpriv;
if ((phtpriv->ht_option == _TRUE) && (phtpriv->ampdu_enable == _TRUE)) {
issued = (phtpriv->agg_enable_bitmap >> priority) & 0x1;
issued |= (phtpriv->candidate_tid_bitmap >> priority) & 0x1;
if (0 == issued) {
RTW_INFO("rtw_issue_addbareq_cmd, p=%d\n", priority);
psta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
rtw_addbareq_cmd(padapter, (u8) priority, pattrib->ra);
}
}
}
#endif /* CONFIG_80211N_HT */
void rtw_append_exented_cap(_adapter *padapter, u8 *out_ie, uint *pout_len)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
#ifdef CONFIG_80211AC_VHT
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
#endif /* CONFIG_80211AC_VHT */
u8 cap_content[8] = { 0 };
u8 *pframe;
u8 null_content[8] = {0};
if (phtpriv->bss_coexist)
SET_EXT_CAPABILITY_ELE_BSS_COEXIST(cap_content, 1);
#ifdef CONFIG_80211AC_VHT
if (pvhtpriv->vht_option)
SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(cap_content, 1);
#endif /* CONFIG_80211AC_VHT */
#ifdef CONFIG_RTW_WNM
rtw_wnm_set_ext_cap_btm(cap_content, 1);
#endif
/*
From 802.11 specification,if a STA does not support any of capabilities defined
in the Extended Capabilities element, then the STA is not required to
transmit the Extended Capabilities element.
*/
if (_FALSE == _rtw_memcmp(cap_content, null_content, 8))
pframe = rtw_set_ie(out_ie + *pout_len, EID_EXTCapability, 8, cap_content , pout_len);
}
#endif
#ifdef CONFIG_LAYER2_ROAMING
inline void rtw_set_to_roam(_adapter *adapter, u8 to_roam)
{
if (to_roam == 0)
adapter->mlmepriv.to_join = _FALSE;
adapter->mlmepriv.to_roam = to_roam;
}
inline u8 rtw_dec_to_roam(_adapter *adapter)
{
adapter->mlmepriv.to_roam--;
return adapter->mlmepriv.to_roam;
}
inline u8 rtw_to_roam(_adapter *adapter)
{
return adapter->mlmepriv.to_roam;
}
void rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
_rtw_roaming(padapter, tgt_network);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
}
void _rtw_roaming(_adapter *padapter, struct wlan_network *tgt_network)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
int do_join_r;
if (0 < rtw_to_roam(padapter)) {
RTW_INFO("roaming from %s("MAC_FMT"), length:%d\n",
cur_network->network.Ssid.Ssid, MAC_ARG(cur_network->network.MacAddress),
cur_network->network.Ssid.SsidLength);
_rtw_memcpy(&pmlmepriv->assoc_ssid, &cur_network->network.Ssid, sizeof(NDIS_802_11_SSID));
pmlmepriv->assoc_ch = 0;
pmlmepriv->assoc_by_bssid = _FALSE;
#ifdef CONFIG_WAPI_SUPPORT
rtw_wapi_return_all_sta_info(padapter);
#endif
while (1) {
do_join_r = rtw_do_join(padapter);
if (_SUCCESS == do_join_r)
break;
else {
RTW_INFO("roaming do_join return %d\n", do_join_r);
rtw_dec_to_roam(padapter);
if (rtw_to_roam(padapter) > 0)
continue;
else {
RTW_INFO("%s(%d) -to roaming fail, indicate_disconnect\n", __FUNCTION__, __LINE__);
#ifdef CONFIG_RTW_80211R
rtw_ft_clr_flags(padapter, RTW_FT_PEER_EN|RTW_FT_PEER_OTD_EN);
rtw_ft_reset_status(padapter);
#endif
rtw_indicate_disconnect(padapter, 0, _FALSE);
break;
}
}
}
}
}
#endif /* CONFIG_LAYER2_ROAMING */
bool rtw_adjust_chbw(_adapter *adapter, u8 req_ch, u8 *req_bw, u8 *req_offset)
{
struct registry_priv *regsty = adapter_to_regsty(adapter);
u8 allowed_bw;
if (req_ch < 14)
allowed_bw = REGSTY_BW_2G(regsty);
else if (req_ch == 14)
allowed_bw = CHANNEL_WIDTH_20;
else
allowed_bw = REGSTY_BW_5G(regsty);
allowed_bw = hal_largest_bw(adapter, allowed_bw);
if (allowed_bw == CHANNEL_WIDTH_80 && *req_bw > CHANNEL_WIDTH_80)
*req_bw = CHANNEL_WIDTH_80;
else if (allowed_bw == CHANNEL_WIDTH_40 && *req_bw > CHANNEL_WIDTH_40)
*req_bw = CHANNEL_WIDTH_40;
else if (allowed_bw == CHANNEL_WIDTH_20 && *req_bw > CHANNEL_WIDTH_20) {
*req_bw = CHANNEL_WIDTH_20;
*req_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
} else
return _FALSE;
return _TRUE;
}
sint rtw_linked_check(_adapter *padapter)
{
if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)
|| MLME_IS_ADHOC(padapter) || MLME_IS_ADHOC_MASTER(padapter)
) {
if (padapter->stapriv.asoc_sta_count > 2)
return _TRUE;
} else {
/* Station mode */
if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE)
return _TRUE;
}
return _FALSE;
}
/*#define DBG_ADAPTER_STATE_CHK*/
u8 rtw_is_adapter_up(_adapter *padapter)
{
if (padapter == NULL)
return _FALSE;
if (RTW_CANNOT_RUN(padapter)) {
#ifdef DBG_ADAPTER_STATE_CHK
RTW_INFO(FUNC_ADPT_FMT " FALSE -bDriverStopped(%s) bSurpriseRemoved(%s)\n"
, FUNC_ADPT_ARG(padapter)
, rtw_is_drv_stopped(padapter) ? "True" : "False"
, rtw_is_surprise_removed(padapter) ? "True" : "False");
#endif
return _FALSE;
}
if (!rtw_is_hw_init_completed(padapter)) {
#ifdef DBG_ADAPTER_STATE_CHK
RTW_INFO(FUNC_ADPT_FMT " FALSE -(hw_init_completed == _FALSE)\n", FUNC_ADPT_ARG(padapter));
#endif
return _FALSE;
}
if (padapter->bup == _FALSE) {
#ifdef DBG_ADAPTER_STATE_CHK
RTW_INFO(FUNC_ADPT_FMT " FALSE -(bup == _FALSE)\n", FUNC_ADPT_ARG(padapter));
#endif
return _FALSE;
}
return _TRUE;
}
bool is_miracast_enabled(_adapter *adapter)
{
bool enabled = 0;
#ifdef CONFIG_WFD
struct wifi_display_info *wfdinfo = &adapter->wfd_info;
enabled = (wfdinfo->stack_wfd_mode & (MIRACAST_SOURCE | MIRACAST_SINK))
|| (wfdinfo->op_wfd_mode & (MIRACAST_SOURCE | MIRACAST_SINK));
#endif
return enabled;
}
bool rtw_chk_miracast_mode(_adapter *adapter, u8 mode)
{
bool ret = 0;
#ifdef CONFIG_WFD
struct wifi_display_info *wfdinfo = &adapter->wfd_info;
ret = (wfdinfo->stack_wfd_mode & mode) || (wfdinfo->op_wfd_mode & mode);
#endif
return ret;
}
const char *get_miracast_mode_str(int mode)
{
if (mode == MIRACAST_SOURCE)
return "SOURCE";
else if (mode == MIRACAST_SINK)
return "SINK";
else if (mode == (MIRACAST_SOURCE | MIRACAST_SINK))
return "SOURCE&SINK";
else if (mode == MIRACAST_DISABLED)
return "DISABLED";
else
return "INVALID";
}
#ifdef CONFIG_WFD
static bool wfd_st_match_rule(_adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
{
struct wifi_display_info *wfdinfo = &adapter->wfd_info;
if (ntohs(*((u16 *)local_port)) == wfdinfo->rtsp_ctrlport
|| ntohs(*((u16 *)local_port)) == wfdinfo->tdls_rtsp_ctrlport
|| ntohs(*((u16 *)remote_port)) == wfdinfo->peer_rtsp_ctrlport)
return _TRUE;
return _FALSE;
}
static struct st_register wfd_st_reg = {
.s_proto = 0x06,
.rule = wfd_st_match_rule,
};
#endif /* CONFIG_WFD */
inline void rtw_wfd_st_switch(struct sta_info *sta, bool on)
{
#ifdef CONFIG_WFD
if (on)
rtw_st_ctl_register(&sta->st_ctl, SESSION_TRACKER_REG_ID_WFD, &wfd_st_reg);
else
rtw_st_ctl_unregister(&sta->st_ctl, SESSION_TRACKER_REG_ID_WFD);
#endif
}
void dump_arp_pkt(void *sel, u8 *da, u8 *sa, u8 *arp, bool tx)
{
RTW_PRINT_SEL(sel, "%s ARP da="MAC_FMT", sa="MAC_FMT"\n"
, tx ? "send" : "recv", MAC_ARG(da), MAC_ARG(sa));
RTW_PRINT_SEL(sel, "htype=%u, ptype=0x%04x, hlen=%u, plen=%u, oper=%u\n"
, GET_ARP_HTYPE(arp), GET_ARP_PTYPE(arp), GET_ARP_HLEN(arp)
, GET_ARP_PLEN(arp), GET_ARP_OPER(arp));
RTW_PRINT_SEL(sel, "sha="MAC_FMT", spa="IP_FMT"\n"
, MAC_ARG(ARP_SENDER_MAC_ADDR(arp)), IP_ARG(ARP_SENDER_IP_ADDR(arp)));
RTW_PRINT_SEL(sel, "tha="MAC_FMT", tpa="IP_FMT"\n"
, MAC_ARG(ARP_TARGET_MAC_ADDR(arp)), IP_ARG(ARP_TARGET_IP_ADDR(arp)));
}
================================================
FILE: core/rtw_mlme_ext.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_MLME_EXT_C_
#include
#ifdef CONFIG_IOCTL_CFG80211
#include
#endif /* CONFIG_IOCTL_CFG80211 */
#include
struct mlme_handler mlme_sta_tbl[] = {
{WIFI_ASSOCREQ, "OnAssocReq", &OnAssocReq},
{WIFI_ASSOCRSP, "OnAssocRsp", &OnAssocRsp},
{WIFI_REASSOCREQ, "OnReAssocReq", &OnAssocReq},
{WIFI_REASSOCRSP, "OnReAssocRsp", &OnAssocRsp},
{WIFI_PROBEREQ, "OnProbeReq", &OnProbeReq},
{WIFI_PROBERSP, "OnProbeRsp", &OnProbeRsp},
/*----------------------------------------------------------
below 2 are reserved
-----------------------------------------------------------*/
{0, "DoReserved", &DoReserved},
{0, "DoReserved", &DoReserved},
{WIFI_BEACON, "OnBeacon", &OnBeacon},
{WIFI_ATIM, "OnATIM", &OnAtim},
{WIFI_DISASSOC, "OnDisassoc", &OnDisassoc},
{WIFI_AUTH, "OnAuth", &OnAuthClient},
{WIFI_DEAUTH, "OnDeAuth", &OnDeAuth},
{WIFI_ACTION, "OnAction", &OnAction},
{WIFI_ACTION_NOACK, "OnActionNoAck", &OnAction},
};
#ifdef _CONFIG_NATIVEAP_MLME_
struct mlme_handler mlme_ap_tbl[] = {
{WIFI_ASSOCREQ, "OnAssocReq", &OnAssocReq},
{WIFI_ASSOCRSP, "OnAssocRsp", &OnAssocRsp},
{WIFI_REASSOCREQ, "OnReAssocReq", &OnAssocReq},
{WIFI_REASSOCRSP, "OnReAssocRsp", &OnAssocRsp},
{WIFI_PROBEREQ, "OnProbeReq", &OnProbeReq},
{WIFI_PROBERSP, "OnProbeRsp", &OnProbeRsp},
/*----------------------------------------------------------
below 2 are reserved
-----------------------------------------------------------*/
{0, "DoReserved", &DoReserved},
{0, "DoReserved", &DoReserved},
{WIFI_BEACON, "OnBeacon", &OnBeacon},
{WIFI_ATIM, "OnATIM", &OnAtim},
{WIFI_DISASSOC, "OnDisassoc", &OnDisassoc},
{WIFI_AUTH, "OnAuth", &OnAuth},
{WIFI_DEAUTH, "OnDeAuth", &OnDeAuth},
{WIFI_ACTION, "OnAction", &OnAction},
{WIFI_ACTION_NOACK, "OnActionNoAck", &OnAction},
};
#endif
struct action_handler OnAction_tbl[] = {
{RTW_WLAN_CATEGORY_SPECTRUM_MGMT, "ACTION_SPECTRUM_MGMT", on_action_spct},
{RTW_WLAN_CATEGORY_QOS, "ACTION_QOS", &OnAction_qos},
{RTW_WLAN_CATEGORY_DLS, "ACTION_DLS", &OnAction_dls},
{RTW_WLAN_CATEGORY_BACK, "ACTION_BACK", &OnAction_back},
{RTW_WLAN_CATEGORY_PUBLIC, "ACTION_PUBLIC", on_action_public},
{RTW_WLAN_CATEGORY_RADIO_MEAS, "ACTION_RADIO_MEAS", &on_action_rm},
{RTW_WLAN_CATEGORY_FT, "ACTION_FT", &OnAction_ft},
{RTW_WLAN_CATEGORY_HT, "ACTION_HT", &OnAction_ht},
#ifdef CONFIG_IEEE80211W
{RTW_WLAN_CATEGORY_SA_QUERY, "ACTION_SA_QUERY", &OnAction_sa_query},
#else
{RTW_WLAN_CATEGORY_SA_QUERY, "ACTION_SA_QUERY", &DoReserved},
#endif /* CONFIG_IEEE80211W */
#ifdef CONFIG_RTW_WNM
{RTW_WLAN_CATEGORY_WNM, "ACTION_WNM", &on_action_wnm},
#endif
{RTW_WLAN_CATEGORY_UNPROTECTED_WNM, "ACTION_UNPROTECTED_WNM", &DoReserved},
#ifdef CONFIG_RTW_MESH
{RTW_WLAN_CATEGORY_MESH, "ACTION_MESH", &on_action_mesh},
{RTW_WLAN_CATEGORY_SELF_PROTECTED, "ACTION_SELF_PROTECTED", &on_action_self_protected},
#endif
{RTW_WLAN_CATEGORY_WMM, "ACTION_WMM", &OnAction_wmm},
{RTW_WLAN_CATEGORY_VHT, "ACTION_VHT", &OnAction_vht},
{RTW_WLAN_CATEGORY_P2P, "ACTION_P2P", &OnAction_p2p},
};
u8 null_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
/**************************************************
OUI definitions for the vendor specific IE
***************************************************/
unsigned char RTW_WPA_OUI[] = {0x00, 0x50, 0xf2, 0x01};
unsigned char WMM_OUI[] = {0x00, 0x50, 0xf2, 0x02};
unsigned char WPS_OUI[] = {0x00, 0x50, 0xf2, 0x04};
unsigned char P2P_OUI[] = {0x50, 0x6F, 0x9A, 0x09};
unsigned char WFD_OUI[] = {0x50, 0x6F, 0x9A, 0x0A};
unsigned char WMM_INFO_OUI[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};
unsigned char WMM_PARA_OUI[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
unsigned char WPA_TKIP_CIPHER[4] = {0x00, 0x50, 0xf2, 0x02};
unsigned char RSN_TKIP_CIPHER[4] = {0x00, 0x0f, 0xac, 0x02};
extern unsigned char REALTEK_96B_IE[];
static void init_channel_list(_adapter *padapter, RT_CHANNEL_INFO *channel_set
, struct p2p_channels *channel_list)
{
struct registry_priv *regsty = adapter_to_regsty(padapter);
struct p2p_oper_class_map op_class[] = {
{ IEEE80211G, 81, 1, 13, 1, BW20 },
{ IEEE80211G, 82, 14, 14, 1, BW20 },
#if 0 /* Do not enable HT40 on 2 GHz */
{ IEEE80211G, 83, 1, 9, 1, BW40PLUS },
{ IEEE80211G, 84, 5, 13, 1, BW40MINUS },
#endif
{ IEEE80211A, 115, 36, 48, 4, BW20 },
{ IEEE80211A, 116, 36, 44, 8, BW40PLUS },
{ IEEE80211A, 117, 40, 48, 8, BW40MINUS },
{ IEEE80211A, 124, 149, 161, 4, BW20 },
{ IEEE80211A, 125, 149, 169, 4, BW20 },
{ IEEE80211A, 126, 149, 157, 8, BW40PLUS },
{ IEEE80211A, 127, 153, 161, 8, BW40MINUS },
{ -1, 0, 0, 0, 0, BW20 }
};
int cla, op;
cla = 0;
for (op = 0; op_class[op].op_class; op++) {
u8 ch;
struct p2p_oper_class_map *o = &op_class[op];
struct p2p_reg_class *reg = NULL;
for (ch = o->min_chan; ch <= o->max_chan; ch += o->inc) {
if (rtw_chset_search_ch(channel_set, ch) == -1)
continue;
#if defined(CONFIG_80211N_HT) || defined(CONFIG_80211AC_VHT)
if ((padapter->registrypriv.ht_enable == 0) && (o->inc == 8))
continue;
if ((REGSTY_IS_BW_5G_SUPPORT(regsty, CHANNEL_WIDTH_40)) &&
((o->bw == BW40MINUS) || (o->bw == BW40PLUS)))
continue;
#endif
if (reg == NULL) {
reg = &channel_list->reg_class[cla];
cla++;
reg->reg_class = o->op_class;
reg->channels = 0;
}
reg->channel[reg->channels] = ch;
reg->channels++;
}
}
channel_list->reg_classes = cla;
}
#if CONFIG_TXPWR_LIMIT
void rtw_txpwr_init_regd(struct rf_ctl_t *rfctl)
{
u8 regd;
struct regd_exc_ent *exc;
struct txpwr_lmt_ent *ent;
_irqL irqL;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
rfctl->regd_name = NULL;
if (rfctl->txpwr_regd_num == 0) {
RTW_PRINT("there is no any txpwr_regd\n");
goto release_lock;
}
/* search from exception mapping */
exc = _rtw_regd_exc_search(rfctl
, rfctl->country_ent ? rfctl->country_ent->alpha2 : NULL
, rfctl->ChannelPlan);
if (exc) {
u8 has_country = (exc->country[0] == '\0' && exc->country[1] == '\0') ? 0 : 1;
if (strcmp(exc->regd_name, regd_str(TXPWR_LMT_NONE)) == 0)
rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
else if (strcmp(exc->regd_name, regd_str(TXPWR_LMT_WW)) == 0)
rfctl->regd_name = regd_str(TXPWR_LMT_WW);
else {
ent = _rtw_txpwr_lmt_get_by_name(rfctl, exc->regd_name);
if (ent)
rfctl->regd_name = ent->regd_name;
}
RTW_PRINT("exception mapping country:%c%c domain:0x%02x to%s regd_name:%s\n"
, has_country ? exc->country[0] : '0'
, has_country ? exc->country[1] : '0'
, exc->domain
, rfctl->regd_name ? "" : " unknown"
, exc->regd_name
);
if (rfctl->regd_name)
goto release_lock;
}
/* follow default channel plan mapping */
regd = rtw_chplan_get_default_regd(rfctl->ChannelPlan);
if (regd == TXPWR_LMT_NONE)
rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
else if (regd == TXPWR_LMT_WW)
rfctl->regd_name = regd_str(TXPWR_LMT_WW);
else {
ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_str(regd));
if (ent)
rfctl->regd_name = ent->regd_name;
}
RTW_PRINT("default mapping domain:0x%02x to%s regd_name:%s\n"
, rfctl->ChannelPlan
, rfctl->regd_name ? "" : " unknown"
, regd_str(regd)
);
if (rfctl->regd_name)
goto release_lock;
switch (regd) {
/*
* To support older chips without new predefined regd:
* - use FCC if IC or CHILE or MEXICO not found
* - use ETSI if KCC or ACMA not found
*/
case TXPWR_LMT_IC:
case TXPWR_LMT_KCC:
case TXPWR_LMT_ACMA:
case TXPWR_LMT_CHILE:
case TXPWR_LMT_MEXICO:
if (regd == TXPWR_LMT_IC || regd == TXPWR_LMT_CHILE || regd == TXPWR_LMT_MEXICO)
regd = TXPWR_LMT_FCC;
else if (regd == TXPWR_LMT_KCC || regd == TXPWR_LMT_ACMA)
regd = TXPWR_LMT_ETSI;
ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_str(regd));
if (ent)
rfctl->regd_name = ent->regd_name;
RTW_PRINT("alternate regd_name:%s %s\n"
, regd_str(regd)
, rfctl->regd_name ? "is used" : "not found"
);
if (rfctl->regd_name)
break;
default:
rfctl->regd_name = regd_str(TXPWR_LMT_WW);
RTW_PRINT("assign %s for default case\n", regd_str(TXPWR_LMT_WW));
break;
};
release_lock:
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
}
#endif /* CONFIG_TXPWR_LIMIT */
void rtw_rfctl_init(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
rfctl->max_chan_nums = init_channel_set(adapter, rfctl->ChannelPlan, rfctl->channel_set);
init_channel_list(adapter, rfctl->channel_set, &rfctl->channel_list);
_rtw_mutex_init(&rfctl->offch_mutex);
#if CONFIG_TXPWR_LIMIT
_rtw_mutex_init(&rfctl->txpwr_lmt_mutex);
_rtw_init_listhead(&rfctl->reg_exc_list);
_rtw_init_listhead(&rfctl->txpwr_lmt_list);
#endif
rfctl->ch_sel_same_band_prefer = 1;
#ifdef CONFIG_DFS_MASTER
rfctl->cac_start_time = rfctl->cac_end_time = RTW_CAC_STOPPED;
rtw_init_timer(&(rfctl->radar_detect_timer), adapter, rtw_dfs_rd_timer_hdl, rfctl);
#endif
#ifdef CONFIG_DFS_SLAVE_WITH_RADAR_DETECT
rfctl->dfs_slave_with_rd = 1;
#endif
}
void rtw_rfctl_deinit(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
_rtw_mutex_free(&rfctl->offch_mutex);
#if CONFIG_TXPWR_LIMIT
rtw_regd_exc_list_free(rfctl);
rtw_txpwr_lmt_list_free(rfctl);
_rtw_mutex_free(&rfctl->txpwr_lmt_mutex);
#endif
}
#ifdef CONFIG_DFS_MASTER
/*
* called in rtw_dfs_rd_enable()
* assume the request channel coverage is DFS range
* base on the current status and the request channel coverage to check if need to reset complete CAC time
*/
bool rtw_is_cac_reset_needed(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset)
{
bool needed = _FALSE;
u32 cur_hi, cur_lo, hi, lo;
if (rfctl->radar_detected == 1) {
needed = _TRUE;
goto exit;
}
if (rfctl->radar_detect_ch == 0) {
needed = _TRUE;
goto exit;
}
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE) {
RTW_ERR("request detection range ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
rtw_warn_on(1);
}
if (rtw_chbw_to_freq_range(rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset, &cur_hi, &cur_lo) == _FALSE) {
RTW_ERR("cur detection range ch:%u, bw:%u, offset:%u\n", rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
rtw_warn_on(1);
}
if (hi <= lo || cur_hi <= cur_lo) {
RTW_ERR("hi:%u, lo:%u, cur_hi:%u, cur_lo:%u\n", hi, lo, cur_hi, cur_lo);
rtw_warn_on(1);
}
if (rtw_is_range_a_in_b(hi, lo, cur_hi, cur_lo)) {
/* request is in current detect range */
goto exit;
}
/* check if request channel coverage has new range and the new range is in DFS range */
if (!rtw_is_range_overlap(hi, lo, cur_hi, cur_lo)) {
/* request has no overlap with current */
needed = _TRUE;
} else if (rtw_is_range_a_in_b(cur_hi, cur_lo, hi, lo)) {
/* request is supper set of current */
if ((hi != cur_hi && rtw_is_dfs_range(hi, cur_hi)) || (lo != cur_lo && rtw_is_dfs_range(cur_lo, lo)))
needed = _TRUE;
} else {
/* request is not supper set of current, but has overlap */
if ((lo < cur_lo && rtw_is_dfs_range(cur_lo, lo)) || (hi > cur_hi && rtw_is_dfs_range(hi, cur_hi)))
needed = _TRUE;
}
exit:
return needed;
}
bool _rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset)
{
bool ret = _FALSE;
u32 hi = 0, lo = 0;
u32 r_hi = 0, r_lo = 0;
int i;
if (rfctl->radar_detect_by_others)
goto exit;
if (rfctl->radar_detect_ch == 0)
goto exit;
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE) {
rtw_warn_on(1);
goto exit;
}
if (rtw_chbw_to_freq_range(rfctl->radar_detect_ch
, rfctl->radar_detect_bw, rfctl->radar_detect_offset
, &r_hi, &r_lo) == _FALSE) {
rtw_warn_on(1);
goto exit;
}
if (rtw_is_range_overlap(hi, lo, r_hi, r_lo))
ret = _TRUE;
exit:
return ret;
}
bool rtw_rfctl_overlap_radar_detect_ch(struct rf_ctl_t *rfctl)
{
return _rtw_rfctl_overlap_radar_detect_ch(rfctl
, rfctl_to_dvobj(rfctl)->oper_channel
, rfctl_to_dvobj(rfctl)->oper_bwmode
, rfctl_to_dvobj(rfctl)->oper_ch_offset);
}
bool rtw_rfctl_is_tx_blocked_by_ch_waiting(struct rf_ctl_t *rfctl)
{
return rtw_rfctl_overlap_radar_detect_ch(rfctl) && IS_CH_WAITING(rfctl);
}
bool rtw_chset_is_chbw_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
{
bool ret = _FALSE;
u32 hi = 0, lo = 0;
int i;
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
goto exit;
for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
if (!rtw_ch2freq(ch_set[i].ChannelNum)) {
rtw_warn_on(1);
continue;
}
if (!CH_IS_NON_OCP(&ch_set[i]))
continue;
if (lo <= rtw_ch2freq(ch_set[i].ChannelNum)
&& rtw_ch2freq(ch_set[i].ChannelNum) <= hi
) {
ret = _TRUE;
break;
}
}
exit:
return ret;
}
bool rtw_chset_is_ch_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch)
{
return rtw_chset_is_chbw_non_ocp(ch_set, ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE);
}
u32 rtw_chset_get_ch_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
{
int ms = 0;
systime current_time;
u32 hi = 0, lo = 0;
int i;
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
goto exit;
current_time = rtw_get_current_time();
for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
if (!rtw_ch2freq(ch_set[i].ChannelNum)) {
rtw_warn_on(1);
continue;
}
if (!CH_IS_NON_OCP(&ch_set[i]))
continue;
if (lo <= rtw_ch2freq(ch_set[i].ChannelNum)
&& rtw_ch2freq(ch_set[i].ChannelNum) <= hi
) {
if (rtw_systime_to_ms(ch_set[i].non_ocp_end_time - current_time) > ms)
ms = rtw_systime_to_ms(ch_set[i].non_ocp_end_time - current_time);
}
}
exit:
return ms;
}
/**
* rtw_chset_update_non_ocp - update non_ocp_end_time according to the given @ch, @bw, @offset into @ch_set
* @ch_set: the given channel set
* @ch: channel number on which radar is detected
* @bw: bandwidth on which radar is detected
* @offset: bandwidth offset on which radar is detected
* @ms: ms to add from now to update non_ocp_end_time, ms < 0 means use NON_OCP_TIME_MS
*/
static void _rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms)
{
u32 hi = 0, lo = 0;
int i;
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
goto exit;
for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
if (!rtw_ch2freq(ch_set[i].ChannelNum)) {
rtw_warn_on(1);
continue;
}
if (lo <= rtw_ch2freq(ch_set[i].ChannelNum)
&& rtw_ch2freq(ch_set[i].ChannelNum) <= hi
) {
if (ms >= 0)
ch_set[i].non_ocp_end_time = rtw_get_current_time() + rtw_ms_to_systime(ms);
else
ch_set[i].non_ocp_end_time = rtw_get_current_time() + rtw_ms_to_systime(NON_OCP_TIME_MS);
}
}
exit:
return;
}
inline void rtw_chset_update_non_ocp(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
{
_rtw_chset_update_non_ocp(ch_set, ch, bw, offset, -1);
}
inline void rtw_chset_update_non_ocp_ms(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset, int ms)
{
_rtw_chset_update_non_ocp(ch_set, ch, bw, offset, ms);
}
u32 rtw_get_ch_waiting_ms(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset, u32 *r_non_ocp_ms, u32 *r_cac_ms)
{
struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
u32 non_ocp_ms;
u32 cac_ms;
u8 in_rd_range = 0; /* if in current radar detection range*/
if (rtw_chset_is_chbw_non_ocp(rfctl->channel_set, ch, bw, offset))
non_ocp_ms = rtw_chset_get_ch_non_ocp_ms(rfctl->channel_set, ch, bw, offset);
else
non_ocp_ms = 0;
if (rfctl->radar_detect_enabled) {
u32 cur_hi, cur_lo, hi, lo;
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE) {
RTW_ERR("input range ch:%u, bw:%u, offset:%u\n", ch, bw, offset);
rtw_warn_on(1);
}
if (rtw_chbw_to_freq_range(rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset, &cur_hi, &cur_lo) == _FALSE) {
RTW_ERR("cur detection range ch:%u, bw:%u, offset:%u\n", rfctl->radar_detect_ch, rfctl->radar_detect_bw, rfctl->radar_detect_offset);
rtw_warn_on(1);
}
if (rtw_is_range_a_in_b(hi, lo, cur_hi, cur_lo))
in_rd_range = 1;
}
if (!rtw_is_dfs_chbw(ch, bw, offset))
cac_ms = 0;
else if (in_rd_range && !non_ocp_ms) {
if (IS_CH_WAITING(rfctl))
cac_ms = rtw_systime_to_ms(rfctl->cac_end_time - rtw_get_current_time());
else
cac_ms = 0;
} else if (rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(dvobj)))
cac_ms = CAC_TIME_CE_MS;
else
cac_ms = CAC_TIME_MS;
if (r_non_ocp_ms)
*r_non_ocp_ms = non_ocp_ms;
if (r_cac_ms)
*r_cac_ms = cac_ms;
return non_ocp_ms + cac_ms;
}
void rtw_reset_cac(struct rf_ctl_t *rfctl, u8 ch, u8 bw, u8 offset)
{
u32 non_ocp_ms;
u32 cac_ms;
rtw_get_ch_waiting_ms(rfctl
, ch
, bw
, offset
, &non_ocp_ms
, &cac_ms
);
rfctl->cac_start_time = rtw_get_current_time() + rtw_ms_to_systime(non_ocp_ms);
rfctl->cac_end_time = rfctl->cac_start_time + rtw_ms_to_systime(cac_ms);
/* skip special value */
if (rfctl->cac_start_time == RTW_CAC_STOPPED) {
rfctl->cac_start_time++;
rfctl->cac_end_time++;
}
if (rfctl->cac_end_time == RTW_CAC_STOPPED)
rfctl->cac_end_time++;
}
u32 rtw_force_stop_cac(struct rf_ctl_t *rfctl, u32 timeout_ms)
{
struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
systime start;
u32 pass_ms;
start = rtw_get_current_time();
rfctl->cac_force_stop = 1;
while (rtw_get_passing_time_ms(start) <= timeout_ms
&& IS_UNDER_CAC(rfctl)
) {
if (dev_is_surprise_removed(dvobj) || dev_is_drv_stopped(dvobj))
break;
rtw_msleep_os(20);
}
if (IS_UNDER_CAC(rfctl)) {
if (!dev_is_surprise_removed(dvobj) && !dev_is_drv_stopped(dvobj))
RTW_INFO("%s waiting for cac stop timeout!\n", __func__);
}
rfctl->cac_force_stop = 0;
pass_ms = rtw_get_passing_time_ms(start);
return pass_ms;
}
#endif /* CONFIG_DFS_MASTER */
/* choose channel with shortest waiting (non ocp + cac) time */
bool rtw_choose_shortest_waiting_ch(struct rf_ctl_t *rfctl, u8 sel_ch, u8 max_bw
, u8 *dec_ch, u8 *dec_bw, u8 *dec_offset
, u8 d_flags, u8 cur_ch, u8 same_band_prefer, u8 mesh_only)
{
#ifndef DBG_CHOOSE_SHORTEST_WAITING_CH
#define DBG_CHOOSE_SHORTEST_WAITING_CH 0
#endif
struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
struct registry_priv *regsty = dvobj_to_regsty(dvobj);
u8 ch, bw, offset;
u8 ch_c = 0, bw_c = 0, offset_c = 0;
int i;
u32 min_waiting_ms = 0;
if (!dec_ch || !dec_bw || !dec_offset) {
rtw_warn_on(1);
return _FALSE;
}
/* full search and narrow bw judegement first to avoid potetial judegement timing issue */
for (bw = CHANNEL_WIDTH_20; bw <= max_bw; bw++) {
if (!hal_is_bw_support(dvobj_get_primary_adapter(dvobj), bw))
continue;
for (i = 0; i < rfctl->max_chan_nums; i++) {
u32 non_ocp_ms = 0;
u32 cac_ms = 0;
u32 waiting_ms = 0;
ch = rfctl->channel_set[i].ChannelNum;
if (sel_ch > 0 && ch != sel_ch)
continue;
if ((d_flags & RTW_CHF_2G) && ch <= 14)
continue;
if ((d_flags & RTW_CHF_5G) && ch > 14)
continue;
if (ch > 14) {
if (bw > REGSTY_BW_5G(regsty))
continue;
} else {
if (bw > REGSTY_BW_2G(regsty))
continue;
}
if (mesh_only && ch >= 5 && ch <= 9 && bw > CHANNEL_WIDTH_20)
continue;
if (!rtw_get_offset_by_chbw(ch, bw, &offset))
continue;
if (!rtw_chset_is_chbw_valid(rfctl->channel_set, ch, bw, offset))
continue;
if ((d_flags & RTW_CHF_NON_OCP) && rtw_chset_is_chbw_non_ocp(rfctl->channel_set, ch, bw, offset))
continue;
if ((d_flags & RTW_CHF_DFS) && rtw_is_dfs_chbw(ch, bw, offset))
continue;
if ((d_flags & RTW_CHF_LONG_CAC) && rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(dvobj)))
continue;
if ((d_flags & RTW_CHF_NON_DFS) && !rtw_is_dfs_chbw(ch, bw, offset))
continue;
if ((d_flags & RTW_CHF_NON_LONG_CAC) && !rtw_is_long_cac_ch(ch, bw, offset, rtw_odm_get_dfs_domain(dvobj)))
continue;
#ifdef CONFIG_DFS_MASTER
waiting_ms = rtw_get_ch_waiting_ms(rfctl, ch, bw, offset, &non_ocp_ms, &cac_ms);
#endif
if (DBG_CHOOSE_SHORTEST_WAITING_CH)
RTW_INFO("%s:%u,%u,%u %u(non_ocp:%u, cac:%u)\n"
, __func__, ch, bw, offset, waiting_ms, non_ocp_ms, cac_ms);
if (ch_c == 0
/* first: smaller wating time */
|| min_waiting_ms > waiting_ms
/* then: wider bw */
|| (min_waiting_ms == waiting_ms && bw > bw_c)
/* then: same band if requested */
|| (same_band_prefer && min_waiting_ms == waiting_ms && bw == bw_c
&& !rtw_is_same_band(cur_ch, ch_c) && rtw_is_same_band(cur_ch, ch))
) {
ch_c = ch;
bw_c = bw;
offset_c = offset;
min_waiting_ms = waiting_ms;
}
}
}
if (ch_c != 0) {
RTW_INFO("%s: d_flags:0x%02x cur_ch:%u sb_prefer:%u%s %u,%u,%u waiting_ms:%u\n"
, __func__, d_flags, cur_ch, same_band_prefer
, mesh_only ? " mesh_only" : ""
, ch_c, bw_c, offset_c, min_waiting_ms);
*dec_ch = ch_c;
*dec_bw = bw_c;
*dec_offset = offset_c;
return _TRUE;
}
if (d_flags == 0) {
RTW_INFO("%s: sel_ch:%u max_bw:%u d_flags:0x%02x cur_ch:%u sb_prefer:%u%s\n"
, __func__, sel_ch, max_bw, d_flags, cur_ch, same_band_prefer
, mesh_only ? " mesh_only" : "");
rtw_warn_on(1);
}
return _FALSE;
}
void dump_chset(void *sel, RT_CHANNEL_INFO *ch_set)
{
u8 i;
for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
RTW_PRINT_SEL(sel, "ch:%3u, freq:%u, scan_type:%d"
, ch_set[i].ChannelNum, rtw_ch2freq(ch_set[i].ChannelNum), ch_set[i].ScanType);
#ifdef CONFIG_FIND_BEST_CHANNEL
_RTW_PRINT_SEL(sel, ", rx_count:%u", ch_set[i].rx_count);
#endif
#ifdef CONFIG_DFS_MASTER
if (rtw_is_dfs_ch(ch_set[i].ChannelNum)) {
if (CH_IS_NON_OCP(&ch_set[i]))
_RTW_PRINT_SEL(sel, ", non_ocp:%d"
, rtw_systime_to_ms(ch_set[i].non_ocp_end_time - rtw_get_current_time()));
else
_RTW_PRINT_SEL(sel, ", non_ocp:N/A");
}
#endif
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "total ch number:%d\n", i);
}
void dump_cur_chset(void *sel, struct rf_ctl_t *rfctl)
{
struct dvobj_priv *dvobj = rfctl_to_dvobj(rfctl);
struct registry_priv *regsty = dvobj_to_regsty(dvobj);
int i;
if (rfctl->country_ent)
dump_country_chplan(sel, rfctl->country_ent);
else
RTW_PRINT_SEL(sel, "chplan:0x%02X\n", rfctl->ChannelPlan);
#if CONFIG_TXPWR_LIMIT
RTW_PRINT_SEL(sel, "PLS regd:%s\n", rfctl->regd_name);
#endif
#ifdef CONFIG_DFS_MASTER
RTW_PRINT_SEL(sel, "dfs_domain:%u\n", rtw_odm_get_dfs_domain(dvobj));
#endif
for (i = 0; i < MAX_CHANNEL_NUM; i++)
if (regsty->excl_chs[i] != 0)
break;
if (i < MAX_CHANNEL_NUM) {
RTW_PRINT_SEL(sel, "excl_chs:");
for (i = 0; i < MAX_CHANNEL_NUM; i++) {
if (regsty->excl_chs[i] == 0)
break;
_RTW_PRINT_SEL(sel, "%u ", regsty->excl_chs[i]);
}
_RTW_PRINT_SEL(sel, "\n");
}
dump_chset(sel, rfctl->channel_set);
}
/*
* Search the @param ch in given @param ch_set
* @ch_set: the given channel set
* @ch: the given channel number
*
* return the index of channel_num in channel_set, -1 if not found
*/
int rtw_chset_search_ch(RT_CHANNEL_INFO *ch_set, const u32 ch)
{
int i;
if (ch == 0)
return -1;
for (i = 0; i < MAX_CHANNEL_NUM && ch_set[i].ChannelNum != 0; i++) {
if (ch == ch_set[i].ChannelNum)
return i;
}
return -1;
}
/*
* Check if the @param ch, bw, offset is valid for the given @param ch_set
* @ch_set: the given channel set
* @ch: the given channel number
* @bw: the given bandwidth
* @offset: the given channel offset
*
* return valid (1) or not (0)
*/
u8 rtw_chset_is_chbw_valid(RT_CHANNEL_INFO *ch_set, u8 ch, u8 bw, u8 offset)
{
u8 cch;
u8 *op_chs;
u8 op_ch_num;
u8 valid = 0;
int i;
cch = rtw_get_center_ch(ch, bw, offset);
if (!rtw_get_op_chs_by_cch_bw(cch, bw, &op_chs, &op_ch_num))
goto exit;
for (i = 0; i < op_ch_num; i++) {
if (0)
RTW_INFO("%u,%u,%u - cch:%u, bw:%u, op_ch:%u\n", ch, bw, offset, cch, bw, *(op_chs + i));
if (rtw_chset_search_ch(ch_set, *(op_chs + i)) == -1)
break;
}
if (op_ch_num != 0 && i == op_ch_num)
valid = 1;
exit:
return valid;
}
/**
* rtw_chset_sync_chbw - obey g_ch, adjust g_bw, g_offset, bw, offset to fit in channel plan
* @ch_set: channel plan to check
* @req_ch: pointer of the request ch, may be modified further
* @req_bw: pointer of the request bw, may be modified further
* @req_offset: pointer of the request offset, may be modified further
* @g_ch: pointer of the ongoing group ch
* @g_bw: pointer of the ongoing group bw, may be modified further
* @g_offset: pointer of the ongoing group offset, may be modified further
*/
void rtw_chset_sync_chbw(RT_CHANNEL_INFO *ch_set, u8 *req_ch, u8 *req_bw, u8 *req_offset
, u8 *g_ch, u8 *g_bw, u8 *g_offset)
{
u8 r_ch, r_bw, r_offset;
u8 u_ch, u_bw, u_offset;
u8 cur_bw = *req_bw;
while (1) {
r_ch = *req_ch;
r_bw = cur_bw;
r_offset = *req_offset;
u_ch = *g_ch;
u_bw = *g_bw;
u_offset = *g_offset;
rtw_sync_chbw(&r_ch, &r_bw, &r_offset, &u_ch, &u_bw, &u_offset);
if (rtw_chset_is_chbw_valid(ch_set, r_ch, r_bw, r_offset))
break;
if (cur_bw == CHANNEL_WIDTH_20) {
rtw_warn_on(1);
break;
}
cur_bw--;
};
*req_ch = r_ch;
*req_bw = r_bw;
*req_offset = r_offset;
*g_ch = u_ch;
*g_bw = u_bw;
*g_offset = u_offset;
}
/*
* Check the @param ch is fit with setband setting of @param adapter
* @adapter: the given adapter
* @ch: the given channel number
*
* return _TRUE when check valid, _FALSE not valid
*/
bool rtw_mlme_band_check(_adapter *adapter, const u32 ch)
{
if (adapter->setband == WIFI_FREQUENCY_BAND_AUTO /* 2.4G and 5G */
|| (adapter->setband == WIFI_FREQUENCY_BAND_2GHZ && ch < 35) /* 2.4G only */
|| (adapter->setband == WIFI_FREQUENCY_BAND_5GHZ && ch > 35) /* 5G only */
)
return _TRUE;
return _FALSE;
}
inline void RTW_SET_SCAN_BAND_SKIP(_adapter *padapter, int skip_band)
{
int bs = ATOMIC_READ(&padapter->bandskip);
bs |= skip_band;
ATOMIC_SET(&padapter->bandskip, bs);
}
inline void RTW_CLR_SCAN_BAND_SKIP(_adapter *padapter, int skip_band)
{
int bs = ATOMIC_READ(&padapter->bandskip);
bs &= ~(skip_band);
ATOMIC_SET(&padapter->bandskip, bs);
}
inline int RTW_GET_SCAN_BAND_SKIP(_adapter *padapter)
{
return ATOMIC_READ(&padapter->bandskip);
}
#define RTW_IS_SCAN_BAND_SKIP(padapter, skip_band) (ATOMIC_READ(&padapter->bandskip) & (skip_band))
bool rtw_mlme_ignore_chan(_adapter *adapter, const u32 ch)
{
if (RTW_IS_SCAN_BAND_SKIP(adapter, BAND_24G) && ch < 35) /* SKIP 2.4G Band channel */
return _TRUE;
if (RTW_IS_SCAN_BAND_SKIP(adapter, BAND_5G) && ch > 35) /* SKIP 5G Band channel */
return _TRUE;
return _FALSE;
}
/****************************************************************************
Following are the initialization functions for WiFi MLME
*****************************************************************************/
int init_hw_mlme_ext(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 rx_bar_enble = _TRUE;
/*
* Sync driver status and hardware setting
*/
/* Modify to make sure first time change channel(band) would be done properly */
pHalData->current_channel = 0;
pHalData->current_channel_bw = CHANNEL_WIDTH_MAX;
pHalData->current_band_type = BAND_MAX;
/* set_opmode_cmd(padapter, infra_client_with_mlme); */ /* removed */
rtw_hal_set_hwreg(padapter, HW_VAR_ENABLE_RX_BAR, &rx_bar_enble);
set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
return _SUCCESS;
}
void init_mlme_default_rate_set(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
unsigned char end_set[1] = {0xff};
u8 offset_datarate = 0;
u8 offset_basicrate = 0;
#ifdef CONFIG_80211N_HT
unsigned char supported_mcs_set[16] = {0xff, 0xff, 0xff, 0x00, 0x00, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
#endif
if (IsSupportedTxCCK(padapter->registrypriv.wireless_mode)) {
unsigned char datarate_b[B_MODE_RATE_NUM] ={_1M_RATE_, _2M_RATE_, _5M_RATE_, _11M_RATE_};
_rtw_memcpy(pmlmeext->datarate, datarate_b, B_MODE_RATE_NUM);
_rtw_memcpy(pmlmeext->basicrate, datarate_b, B_MODE_RATE_NUM);
offset_datarate += B_MODE_RATE_NUM;
offset_basicrate += B_MODE_RATE_NUM;
RTW_INFO("%s: support CCK\n", __func__);
}
if(IsSupportedTxOFDM(padapter->registrypriv.wireless_mode)) {
unsigned char datarate_g[G_MODE_RATE_NUM] ={_6M_RATE_, _9M_RATE_, _12M_RATE_, _18M_RATE_,_24M_RATE_, _36M_RATE_, _48M_RATE_, _54M_RATE_};
unsigned char basicrate_g[G_MODE_BASIC_RATE_NUM] = {_6M_RATE_, _12M_RATE_, _24M_RATE_};
_rtw_memcpy(pmlmeext->datarate + offset_datarate, datarate_g, G_MODE_RATE_NUM);
_rtw_memcpy(pmlmeext->basicrate + offset_basicrate,basicrate_g, G_MODE_BASIC_RATE_NUM);
offset_datarate += G_MODE_RATE_NUM;
offset_basicrate += G_MODE_BASIC_RATE_NUM;
RTW_INFO("%s: support OFDM\n", __func__);
}
_rtw_memcpy(pmlmeext->datarate + offset_datarate, end_set, 1);
_rtw_memcpy(pmlmeext->basicrate + offset_basicrate, end_set, 1);
#ifdef CONFIG_80211N_HT
if( padapter->registrypriv.ht_enable && is_supported_ht(padapter->registrypriv.wireless_mode))
_rtw_memcpy(pmlmeext->default_supported_mcs_set, supported_mcs_set, sizeof(pmlmeext->default_supported_mcs_set));
#endif
}
static void init_mlme_ext_priv_value(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
ATOMIC_SET(&pmlmeext->event_seq, 0);
pmlmeext->mgnt_seq = 0;/* reset to zero when disconnect at client mode */
#ifdef CONFIG_IEEE80211W
pmlmeext->sa_query_seq = 0;
#endif
pmlmeext->cur_channel = padapter->registrypriv.channel;
pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
pmlmeext->retry = 0;
pmlmeext->cur_wireless_mode = padapter->registrypriv.wireless_mode;
init_mlme_default_rate_set(padapter);
if ((pmlmeext->cur_channel > 14) || ((padapter->registrypriv.wireless_mode & WIRELESS_11B) == 0))
pmlmeext->tx_rate = IEEE80211_OFDM_RATE_6MB;
else
pmlmeext->tx_rate = IEEE80211_CCK_RATE_1MB;
mlmeext_set_scan_state(pmlmeext, SCAN_DISABLE);
pmlmeext->sitesurvey_res.channel_idx = 0;
pmlmeext->sitesurvey_res.bss_cnt = 0;
pmlmeext->sitesurvey_res.scan_ch_ms = SURVEY_TO;
pmlmeext->sitesurvey_res.rx_ampdu_accept = RX_AMPDU_ACCEPT_INVALID;
pmlmeext->sitesurvey_res.rx_ampdu_size = RX_AMPDU_SIZE_INVALID;
#ifdef CONFIG_SCAN_BACKOP
mlmeext_assign_scan_backop_flags_sta(pmlmeext, /*SS_BACKOP_EN|*/SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
#ifdef CONFIG_AP_MODE
mlmeext_assign_scan_backop_flags_ap(pmlmeext, SS_BACKOP_EN | SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
#endif
#ifdef CONFIG_RTW_MESH
mlmeext_assign_scan_backop_flags_mesh(pmlmeext, /*SS_BACKOP_EN | */SS_BACKOP_PS_ANNC | SS_BACKOP_TX_RESUME);
#endif
pmlmeext->sitesurvey_res.scan_cnt = 0;
pmlmeext->sitesurvey_res.scan_cnt_max = RTW_SCAN_NUM_OF_CH;
pmlmeext->sitesurvey_res.backop_ms = RTW_BACK_OP_CH_MS;
#endif
#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
pmlmeext->sitesurvey_res.is_sw_antdiv_bl_scan = 0;
#endif
pmlmeext->scan_abort = _FALSE;
pmlmeinfo->state = WIFI_FW_NULL_STATE;
pmlmeinfo->reauth_count = 0;
pmlmeinfo->reassoc_count = 0;
pmlmeinfo->link_count = 0;
pmlmeinfo->auth_seq = 0;
pmlmeinfo->auth_algo = dot11AuthAlgrthm_Open;
pmlmeinfo->key_index = 0;
pmlmeinfo->iv = 0;
pmlmeinfo->enc_algo = _NO_PRIVACY_;
pmlmeinfo->authModeToggle = 0;
_rtw_memset(pmlmeinfo->chg_txt, 0, 128);
pmlmeinfo->slotTime = SHORT_SLOT_TIME;
pmlmeinfo->preamble_mode = PREAMBLE_AUTO;
pmlmeinfo->dialogToken = 0;
pmlmeext->action_public_rxseq = 0xffff;
pmlmeext->action_public_dialog_token = 0xff;
#ifdef ROKU_PRIVATE
/*infra mode, used to store AP's info*/
_rtw_memset(pmlmeinfo->SupportedRates_infra_ap, 0, NDIS_802_11_LENGTH_RATES_EX);
pmlmeinfo->ht_vht_received = 0;
#endif /* ROKU_PRIVATE */
}
void init_mlme_ext_timer(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
rtw_init_timer(&pmlmeext->survey_timer, padapter, survey_timer_hdl, padapter);
rtw_init_timer(&pmlmeext->link_timer, padapter, link_timer_hdl, padapter);
#ifdef CONFIG_RTW_80211R
rtw_init_timer(&pmlmeext->ft_link_timer, padapter, rtw_ft_link_timer_hdl, padapter);
rtw_init_timer(&pmlmeext->ft_roam_timer, padapter, rtw_ft_roam_timer_hdl, padapter);
#endif
#ifdef CONFIG_RTW_REPEATER_SON
rtw_init_timer(&pmlmeext->rson_scan_timer, padapter, rson_timer_hdl, padapter);
#endif
}
int init_mlme_ext_priv(_adapter *padapter)
{
int res = _SUCCESS;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
/* _rtw_memset((u8 *)pmlmeext, 0, sizeof(struct mlme_ext_priv)); */
pmlmeext->padapter = padapter;
/* fill_fwpriv(padapter, &(pmlmeext->fwpriv)); */
init_mlme_ext_priv_value(padapter);
pmlmeinfo->bAcceptAddbaReq = pregistrypriv->bAcceptAddbaReq;
init_mlme_ext_timer(padapter);
#ifdef CONFIG_AP_MODE
init_mlme_ap_info(padapter);
#endif
pmlmeext->last_scan_time = 0;
pmlmeext->mlmeext_init = _TRUE;
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
pmlmeext->active_keep_alive_check = _TRUE;
#else
pmlmeext->active_keep_alive_check = _FALSE;
#endif
#ifdef DBG_FIXED_CHAN
pmlmeext->fixed_chan = 0xFF;
#endif
pmlmeext->tsf_update_pause_factor = pregistrypriv->tsf_update_pause_factor;
pmlmeext->tsf_update_restore_factor = pregistrypriv->tsf_update_restore_factor;
#ifdef CONFIG_SUPPORT_STATIC_SMPS
pmlmeext->ssmps_en = _FALSE;
pmlmeext->ssmps_tx_tp_th = SSMPS_TX_TP_TH;/*Mbps*/
pmlmeext->ssmps_rx_tp_th = SSMPS_RX_TP_TH;/*Mbps*/
#ifdef DBG_STATIC_SMPS
pmlmeext->ssmps_test = _FALSE;
#endif
#endif
#ifdef CONFIG_CTRL_TXSS_BY_TP
pmlmeext->txss_ctrl_en = _TRUE;
pmlmeext->txss_tp_th = TXSS_TP_TH;
pmlmeext->txss_tp_chk_cnt = TXSS_TP_CHK_CNT;
#endif
return res;
}
void free_mlme_ext_priv(struct mlme_ext_priv *pmlmeext)
{
_adapter *padapter = pmlmeext->padapter;
if (!padapter)
return;
if (rtw_is_drv_stopped(padapter)) {
_cancel_timer_ex(&pmlmeext->survey_timer);
_cancel_timer_ex(&pmlmeext->link_timer);
}
}
#ifdef CONFIG_PATCH_JOIN_WRONG_CHANNEL
static u8 cmp_pkt_chnl_diff(_adapter *padapter, u8 *pframe, uint packet_len)
{
/* if the channel is same, return 0. else return channel differential */
uint len;
u8 channel;
u8 *p;
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, _DSSET_IE_, &len, packet_len - _BEACON_IE_OFFSET_);
if (p) {
channel = *(p + 2);
if (padapter->mlmeextpriv.cur_channel >= channel)
return padapter->mlmeextpriv.cur_channel - channel;
else
return channel - padapter->mlmeextpriv.cur_channel;
} else
return 0;
}
#endif /* CONFIG_PATCH_JOIN_WRONG_CHANNEL */
static void _mgt_dispatcher(_adapter *padapter, struct mlme_handler *ptable, union recv_frame *precv_frame)
{
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 *pframe = precv_frame->u.hdr.rx_data;
if (ptable->func) {
/* receive the frames that ra(a1) is my address or ra(a1) is bc address. */
if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN) &&
!_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
{
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) != _TRUE)
return;
if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE)
return;
if ( pwdev_priv->pno_mac_addr[0] == 0xFF)
return;
if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_pno_mac_addr(padapter), ETH_ALEN))
return;
}
#else
return;
#endif
ptable->func(padapter, precv_frame);
}
}
void mgt_dispatcher(_adapter *padapter, union recv_frame *precv_frame)
{
int index;
struct mlme_handler *ptable;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 *pframe = precv_frame->u.hdr.rx_data;
struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(pframe));
struct recv_priv *precvpriv = &padapter->recvpriv;
#if 0
{
u8 *pbuf;
pbuf = GetAddr1Ptr(pframe);
RTW_INFO("A1-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf + 1), *(pbuf + 2), *(pbuf + 3), *(pbuf + 4), *(pbuf + 5));
pbuf = get_addr2_ptr(pframe);
RTW_INFO("A2-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf + 1), *(pbuf + 2), *(pbuf + 3), *(pbuf + 4), *(pbuf + 5));
pbuf = GetAddr3Ptr(pframe);
RTW_INFO("A3-%x:%x:%x:%x:%x:%x\n", *pbuf, *(pbuf + 1), *(pbuf + 2), *(pbuf + 3), *(pbuf + 4), *(pbuf + 5));
}
#endif
if (GetFrameType(pframe) != WIFI_MGT_TYPE) {
return;
}
/* receive the frames that ra(a1) is my address or ra(a1) is bc address. */
if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN) &&
!_rtw_memcmp(GetAddr1Ptr(pframe), bc_addr, ETH_ALEN))
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
{
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) != _TRUE)
return;
if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _TRUE)
return;
if ( pwdev_priv->pno_mac_addr[0] == 0xFF)
return;
if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_pno_mac_addr(padapter), ETH_ALEN))
return;
}
#else
return;
#endif
ptable = mlme_sta_tbl;
index = get_frame_sub_type(pframe) >> 4;
#ifdef CONFIG_TDLS
if ((index << 4) == WIFI_ACTION) {
/* category==public (4), action==TDLS_DISCOVERY_RESPONSE */
if (*(pframe + 24) == RTW_WLAN_CATEGORY_PUBLIC && *(pframe + 25) == TDLS_DISCOVERY_RESPONSE) {
RTW_INFO("[TDLS] Recv %s from "MAC_FMT"\n", rtw_tdls_action_txt(TDLS_DISCOVERY_RESPONSE), MAC_ARG(get_addr2_ptr(pframe)));
On_TDLS_Dis_Rsp(padapter, precv_frame);
}
}
#endif /* CONFIG_TDLS */
if (index >= (sizeof(mlme_sta_tbl) / sizeof(struct mlme_handler))) {
return;
}
ptable += index;
#if 1
if (psta != NULL) {
if (GetRetry(pframe)) {
if (precv_frame->u.hdr.attrib.seq_num == psta->RxMgmtFrameSeqNum) {
/* drop the duplicate management frame */
precvpriv->dbg_rx_dup_mgt_frame_drop_count++;
RTW_INFO("Drop duplicate management frame with seq_num = %d.\n", precv_frame->u.hdr.attrib.seq_num);
return;
}
}
psta->RxMgmtFrameSeqNum = precv_frame->u.hdr.attrib.seq_num;
}
#else
if (GetRetry(pframe)) {
/* return; */
}
#endif
#ifdef CONFIG_AP_MODE
switch (get_frame_sub_type(pframe)) {
case WIFI_AUTH:
if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter))
ptable->func = &OnAuth;
else
ptable->func = &OnAuthClient;
/* pass through */
case WIFI_ASSOCREQ:
case WIFI_REASSOCREQ:
_mgt_dispatcher(padapter, ptable, precv_frame);
#ifdef CONFIG_HOSTAPD_MLME
if (MLME_IS_AP(padapter))
rtw_hostapd_mlme_rx(padapter, precv_frame);
#endif
break;
case WIFI_PROBEREQ:
_mgt_dispatcher(padapter, ptable, precv_frame);
#ifdef CONFIG_HOSTAPD_MLME
if (MLME_IS_AP(padapter))
rtw_hostapd_mlme_rx(padapter, precv_frame);
#endif
break;
case WIFI_BEACON:
_mgt_dispatcher(padapter, ptable, precv_frame);
break;
case WIFI_ACTION:
_mgt_dispatcher(padapter, ptable, precv_frame);
break;
default:
_mgt_dispatcher(padapter, ptable, precv_frame);
#ifdef CONFIG_HOSTAPD_MLME
if (MLME_IS_AP(padapter))
rtw_hostapd_mlme_rx(padapter, precv_frame);
#endif
break;
}
#else
_mgt_dispatcher(padapter, ptable, precv_frame);
#endif
}
#ifdef CONFIG_P2P
u32 p2p_listen_state_process(_adapter *padapter, unsigned char *da)
{
bool response = _TRUE;
#ifdef CONFIG_IOCTL_CFG80211
if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
if (rtw_cfg80211_get_is_roch(padapter) == _FALSE
|| rtw_get_oper_ch(padapter) != padapter->wdinfo.listen_channel
|| adapter_wdev_data(padapter)->p2p_enabled == _FALSE
|| padapter->mlmepriv.wps_probe_resp_ie == NULL
|| padapter->mlmepriv.p2p_probe_resp_ie == NULL
) {
#ifdef CONFIG_DEBUG_CFG80211
RTW_INFO(ADPT_FMT" DON'T issue_probersp_p2p: p2p_enabled:%d, wps_probe_resp_ie:%p, p2p_probe_resp_ie:%p\n"
, ADPT_ARG(padapter)
, adapter_wdev_data(padapter)->p2p_enabled
, padapter->mlmepriv.wps_probe_resp_ie
, padapter->mlmepriv.p2p_probe_resp_ie);
RTW_INFO(ADPT_FMT" DON'T issue_probersp_p2p: is_ro_ch:%d, op_ch:%d, p2p_listen_channel:%d\n"
, ADPT_ARG(padapter)
, rtw_cfg80211_get_is_roch(padapter)
, rtw_get_oper_ch(padapter)
, padapter->wdinfo.listen_channel);
#endif
response = _FALSE;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
if (padapter->wdinfo.driver_interface == DRIVER_WEXT) {
/* do nothing if the device name is empty */
if (!padapter->wdinfo.device_name_len)
response = _FALSE;
}
if (response == _TRUE)
issue_probersp_p2p(padapter, da);
return _SUCCESS;
}
#endif /* CONFIG_P2P */
/****************************************************************************
Following are the callback functions for each subtype of the management frames
*****************************************************************************/
unsigned int OnProbeReq(_adapter *padapter, union recv_frame *precv_frame)
{
unsigned int ielen;
unsigned char *p;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur = &(pmlmeinfo->network);
u8 *pframe = precv_frame->u.hdr.rx_data;
uint len = precv_frame->u.hdr.len;
u8 is_valid_p2p_probereq = _FALSE;
#ifdef CONFIG_ATMEL_RC_PATCH
u8 *target_ie = NULL, *wps_ie = NULL;
u8 *start;
uint search_len = 0, wps_ielen = 0, target_ielen = 0;
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
#endif
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
u8 wifi_test_chk_rate = 1;
#ifdef CONFIG_IOCTL_CFG80211
if ((pwdinfo->driver_interface == DRIVER_CFG80211)
&& !rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
&& (GET_CFG80211_REPORT_MGMT(adapter_wdev_data(padapter), IEEE80211_STYPE_PROBE_REQ) == _TRUE)
) {
rtw_cfg80211_rx_probe_request(padapter, precv_frame);
return _SUCCESS;
}
#endif /* CONFIG_IOCTL_CFG80211 */
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) &&
!rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE) &&
!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT) &&
!rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH) &&
!rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
) {
/* Commented by Albert 2011/03/17 */
/* mcs_rate = 0->CCK 1M rate */
/* mcs_rate = 1->CCK 2M rate */
/* mcs_rate = 2->CCK 5.5M rate */
/* mcs_rate = 3->CCK 11M rate */
/* In the P2P mode, the driver should not support the CCK rate */
/* Commented by Kurt 2012/10/16 */
/* IOT issue: Google Nexus7 use 1M rate to send p2p_probe_req after GO nego completed and Nexus7 is client */
if (padapter->registrypriv.wifi_spec == 1) {
if (pattrib->data_rate <= DESC_RATE11M)
wifi_test_chk_rate = 0;
}
if (wifi_test_chk_rate == 1) {
is_valid_p2p_probereq = process_probe_req_p2p_ie(pwdinfo, pframe, len);
if (is_valid_p2p_probereq == _TRUE) {
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)) {
/* FIXME */
if (padapter->wdinfo.driver_interface == DRIVER_WEXT)
report_survey_event(padapter, precv_frame);
p2p_listen_state_process(padapter, get_sa(pframe));
return _SUCCESS;
}
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
goto _continue;
}
}
}
_continue:
#endif /* CONFIG_P2P */
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
return _SUCCESS;
if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE &&
check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_AP_STATE | WIFI_MESH_STATE) == _FALSE)
return _SUCCESS;
/* RTW_INFO("+OnProbeReq\n"); */
#ifdef CONFIG_ATMEL_RC_PATCH
wps_ie = rtw_get_wps_ie(
pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_,
len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_,
NULL, &wps_ielen);
if (wps_ie)
target_ie = rtw_get_wps_attr_content(wps_ie, wps_ielen, WPS_ATTR_MANUFACTURER, NULL, &target_ielen);
if ((target_ie && (target_ielen == 4)) && (_TRUE == _rtw_memcmp((void *)target_ie, "Ozmo", 4))) {
/* psta->flag_atmel_rc = 1; */
unsigned char *sa_addr = get_sa(pframe);
printk("%s: Find Ozmo RC -- %02x:%02x:%02x:%02x:%02x:%02x \n\n",
__func__, *sa_addr, *(sa_addr + 1), *(sa_addr + 2), *(sa_addr + 3), *(sa_addr + 4), *(sa_addr + 5));
_rtw_memcpy(pstapriv->atmel_rc_pattern, get_sa(pframe), ETH_ALEN);
}
#endif
#ifdef CONFIG_AUTO_AP_MODE
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
pmlmepriv->cur_network.join_res == _TRUE) {
_irqL irqL;
struct sta_info *psta;
u8 *mac_addr, *peer_addr;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 RC_OUI[4] = {0x00, 0xE0, 0x4C, 0x0A};
/* EID[1] + EID_LEN[1] + RC_OUI[4] + MAC[6] + PairingID[2] + ChannelNum[2] */
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _VENDOR_SPECIFIC_IE_, (int *)&ielen,
len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
if (!p || ielen != 14)
goto _non_rc_device;
if (!_rtw_memcmp(p + 2, RC_OUI, sizeof(RC_OUI)))
goto _non_rc_device;
if (!_rtw_memcmp(p + 6, get_sa(pframe), ETH_ALEN)) {
RTW_INFO("%s, do rc pairing ("MAC_FMT"), but mac addr mismatch!("MAC_FMT")\n", __FUNCTION__,
MAC_ARG(get_sa(pframe)), MAC_ARG(p + 6));
goto _non_rc_device;
}
RTW_INFO("%s, got the pairing device("MAC_FMT")\n", __FUNCTION__, MAC_ARG(get_sa(pframe)));
/* new a station */
psta = rtw_get_stainfo(pstapriv, get_sa(pframe));
if (psta == NULL) {
/* allocate a new one */
RTW_INFO("going to alloc stainfo for rc="MAC_FMT"\n", MAC_ARG(get_sa(pframe)));
psta = rtw_alloc_stainfo(pstapriv, get_sa(pframe));
if (psta == NULL) {
/* TODO: */
RTW_INFO(" Exceed the upper limit of supported clients...\n");
return _SUCCESS;
}
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&psta->asoc_list)) {
psta->expire_to = pstapriv->expire_to;
rtw_list_insert_tail(&psta->asoc_list, &pstapriv->asoc_list);
pstapriv->asoc_list_cnt++;
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
/* generate pairing ID */
mac_addr = adapter_mac_addr(padapter);
peer_addr = psta->cmn.mac_addr;
psta->pid = (u16)(((mac_addr[4] << 8) + mac_addr[5]) + ((peer_addr[4] << 8) + peer_addr[5]));
/* update peer stainfo */
psta->isrc = _TRUE;
/* AID assignment */
if (psta->cmn.aid > 0)
RTW_INFO(FUNC_ADPT_FMT" old AID=%d\n", FUNC_ADPT_ARG(padapter), psta->cmn.aid);
else {
if (!rtw_aid_alloc(padapter, psta)) {
RTW_INFO(FUNC_ADPT_FMT" no room for more AIDs\n", FUNC_ADPT_ARG(padapter));
return _SUCCESS;
}
RTW_INFO(FUNC_ADPT_FMT" allocate new AID=%d\n", FUNC_ADPT_ARG(padapter), psta->cmn.aid);
}
psta->qos_option = 1;
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
psta->ieee8021x_blocked = _FALSE;
#ifdef CONFIG_80211N_HT
if(padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode)) {
psta->htpriv.ht_option = _TRUE;
psta->htpriv.ampdu_enable = _FALSE;
psta->htpriv.sgi_20m = _FALSE;
psta->htpriv.sgi_40m = _FALSE;
psta->htpriv.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
}
#endif
rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
_rtw_memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
_enter_critical_bh(&psta->lock, &irqL);
psta->state |= _FW_LINKED;
_exit_critical_bh(&psta->lock, &irqL);
report_add_sta_event(padapter, psta->cmn.mac_addr);
}
issue_probersp(padapter, get_sa(pframe), _FALSE);
return _SUCCESS;
}
_non_rc_device:
return _SUCCESS;
#endif /* CONFIG_AUTO_AP_MODE */
#ifdef CONFIG_CONCURRENT_MODE
if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) &&
rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | _FW_UNDER_SURVEY)) {
/* don't process probe req */
return _SUCCESS;
}
#endif
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _SSID_IE_, (int *)&ielen,
len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
/* check (wildcard) SSID */
if (p != NULL) {
if (is_valid_p2p_probereq == _TRUE)
goto _issue_probersp;
if ((ielen != 0 && _FALSE == _rtw_memcmp((void *)(p + 2), (void *)cur->Ssid.Ssid, cur->Ssid.SsidLength))
|| (ielen == 0 && pmlmeinfo->hidden_ssid_mode))
goto exit;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, WLAN_EID_MESH_ID, (int *)&ielen,
len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
if (!p)
goto exit;
if (ielen != 0 && _rtw_memcmp((void *)(p + 2), (void *)cur->mesh_id.Ssid, cur->mesh_id.SsidLength) == _FALSE)
goto exit;
}
#endif
_issue_probersp:
if (((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE &&
pmlmepriv->cur_network.join_res == _TRUE)) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
/* RTW_INFO("+issue_probersp during ap mode\n"); */
issue_probersp(padapter, get_sa(pframe), is_valid_p2p_probereq);
}
}
exit:
return _SUCCESS;
}
unsigned int OnProbeRsp(_adapter *padapter, union recv_frame *precv_frame)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
#endif
#ifdef CONFIG_P2P
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ)) {
if (_TRUE == pwdinfo->tx_prov_disc_info.benable) {
if (_rtw_memcmp(pwdinfo->tx_prov_disc_info.peerIFAddr, get_addr2_ptr(pframe), ETH_ALEN)) {
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
pwdinfo->tx_prov_disc_info.benable = _FALSE;
issue_p2p_provision_request(padapter,
pwdinfo->tx_prov_disc_info.ssid.Ssid,
pwdinfo->tx_prov_disc_info.ssid.SsidLength,
pwdinfo->tx_prov_disc_info.peerDevAddr);
} else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
pwdinfo->tx_prov_disc_info.benable = _FALSE;
issue_p2p_provision_request(padapter,
NULL,
0,
pwdinfo->tx_prov_disc_info.peerDevAddr);
}
}
}
return _SUCCESS;
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING)) {
if (_TRUE == pwdinfo->nego_req_info.benable) {
RTW_INFO("[%s] P2P State is GONEGO ING!\n", __FUNCTION__);
if (_rtw_memcmp(pwdinfo->nego_req_info.peerDevAddr, get_addr2_ptr(pframe), ETH_ALEN)) {
pwdinfo->nego_req_info.benable = _FALSE;
issue_p2p_GO_request(padapter, pwdinfo->nego_req_info.peerDevAddr);
}
}
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ)) {
if (_TRUE == pwdinfo->invitereq_info.benable) {
RTW_INFO("[%s] P2P_STATE_TX_INVITE_REQ!\n", __FUNCTION__);
if (_rtw_memcmp(pwdinfo->invitereq_info.peer_macaddr, get_addr2_ptr(pframe), ETH_ALEN)) {
pwdinfo->invitereq_info.benable = _FALSE;
issue_p2p_invitation_request(padapter, pwdinfo->invitereq_info.peer_macaddr);
}
}
}
#endif
if ((mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS))
|| (MLME_IS_MESH(padapter) && check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE))
#ifdef CONFIG_RTW_REPEATER_SON
|| (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS)
#endif
) {
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)
&& (pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE && (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
) {
if (!rtw_check_bcn_info(padapter, pframe, precv_frame->u.hdr.len)) {
RTW_PRINT(FUNC_ADPT_FMT" ap has changed, disconnect now\n", FUNC_ADPT_ARG(padapter));
receive_disconnect(padapter, pmlmeinfo->network.MacAddress , 0, _FALSE);
}
}
rtw_mi_report_survey_event(padapter, precv_frame);
return _SUCCESS;
}
#if 0 /* move to validate_recv_mgnt_frame */
if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)) {
if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta != NULL)
psta->sta_stats.rx_mgnt_pkts++;
}
}
#endif
return _SUCCESS;
}
/* for 11n Logo 4.2.31/4.2.32 */
static void rtw_check_legacy_ap(_adapter *padapter, u8 *pframe, u32 len)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (!padapter->registrypriv.wifi_spec)
return;
if(!MLME_IS_AP(padapter))
return;
if (pmlmeext->bstart_bss == _TRUE) {
int left;
unsigned char *pos;
struct rtw_ieee802_11_elems elems;
#ifdef CONFIG_80211N_HT
u16 cur_op_mode;
#endif
/* checking IEs */
left = len - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_;
pos = pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_;
if (rtw_ieee802_11_parse_elems(pos, left, &elems, 1) == ParseFailed) {
RTW_INFO("%s: parse fail for "MAC_FMT"\n", __func__, MAC_ARG(GetAddr3Ptr(pframe)));
return;
}
#ifdef CONFIG_80211N_HT
cur_op_mode = pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_OP_MODE_MASK;
#endif
/* for legacy ap */
if (elems.ht_capabilities == NULL && elems.ht_capabilities_len == 0) {
if (0)
RTW_INFO("%s: "MAC_FMT" is legacy ap\n", __func__, MAC_ARG(GetAddr3Ptr(pframe)));
ATOMIC_SET(&pmlmepriv->olbc, _TRUE);
ATOMIC_SET(&pmlmepriv->olbc_ht, _TRUE);
}
}
}
unsigned int OnBeacon(_adapter *padapter, union recv_frame *precv_frame)
{
struct sta_info *psta;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint len = precv_frame->u.hdr.len;
WLAN_BSSID_EX *pbss;
int ret = _SUCCESS;
#ifdef CONFIG_TDLS
struct sta_info *ptdls_sta;
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
#ifdef CONFIG_TDLS_CH_SW
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
#endif
#endif /* CONFIG_TDLS */
if (validate_beacon_len(pframe, len) == _FALSE)
return _SUCCESS;
if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS)
|| (MLME_IS_MESH(padapter) && check_fwstate(pmlmepriv, WIFI_ASOC_STATE))
) {
if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)
&& (pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE && (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
) {
if (!rtw_check_bcn_info(padapter, pframe, len)) {
RTW_PRINT(FUNC_ADPT_FMT" ap has changed, disconnect now\n", FUNC_ADPT_ARG(padapter));
receive_disconnect(padapter, pmlmeinfo->network.MacAddress , 0, _FALSE);
}
}
rtw_mi_report_survey_event(padapter, precv_frame);
return _SUCCESS;
}
#ifdef CONFIG_RTW_REPEATER_SON
if (padapter->rtw_rson_scanstage == RSON_SCAN_PROCESS)
rtw_mi_report_survey_event(padapter, precv_frame);
#endif
rtw_check_legacy_ap(padapter, pframe, len);
if (_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)) {
if ((pmlmeinfo->state & WIFI_FW_AUTH_NULL)
&& (rtw_sta_linking_test_wait_done() || pmlmeext->join_abort)
) {
if (rtw_sta_linking_test_force_fail() || pmlmeext->join_abort) {
set_link_timer(pmlmeext, 1);
return _SUCCESS;
}
/* we should update current network before auth, or some IE is wrong */
pbss = (WLAN_BSSID_EX *)rtw_malloc(sizeof(WLAN_BSSID_EX));
if (pbss) {
if (collect_bss_info(padapter, precv_frame, pbss) == _SUCCESS) {
struct beacon_keys recv_beacon;
update_network(&(pmlmepriv->cur_network.network), pbss, padapter, _TRUE);
/* update bcn keys */
if (rtw_get_bcn_keys(padapter, pframe, len, &recv_beacon) == _TRUE) {
RTW_INFO("%s: beacon keys ready\n", __func__);
_rtw_memcpy(&pmlmepriv->cur_beacon_keys,
&recv_beacon, sizeof(recv_beacon));
if (is_hidden_ssid(recv_beacon.ssid, recv_beacon.ssid_len)) {
_rtw_memcpy(pmlmepriv->cur_beacon_keys.ssid, pmlmeinfo->network.Ssid.Ssid, IW_ESSID_MAX_SIZE);
pmlmepriv->cur_beacon_keys.ssid_len = pmlmeinfo->network.Ssid.SsidLength;
}
} else {
RTW_ERR("%s: get beacon keys failed\n", __func__);
_rtw_memset(&pmlmepriv->cur_beacon_keys, 0, sizeof(recv_beacon));
}
#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
pmlmepriv->new_beacon_cnts = 0;
#endif
}
rtw_mfree((u8 *)pbss, sizeof(WLAN_BSSID_EX));
}
/* check the vendor of the assoc AP */
pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pframe + sizeof(struct rtw_ieee80211_hdr_3addr), len - sizeof(struct rtw_ieee80211_hdr_3addr));
/* update TSF Value */
update_TSF(pmlmeext, pframe, len);
pmlmeext->bcn_cnt = 0;
pmlmeext->last_bcn_cnt = 0;
#ifdef CONFIG_P2P_PS
/* Comment by YiWei , in wifi p2p spec the "3.3 P2P Power Management" , "These mechanisms are available in a P2P Group in which only P2P Devices are associated." */
/* process_p2p_ps_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN)); */
#endif /* CONFIG_P2P_PS */
#if defined(CONFIG_P2P) && defined(CONFIG_CONCURRENT_MODE)
if (padapter->registrypriv.wifi_spec) {
if (process_p2p_cross_connect_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN)) == _FALSE) {
if (rtw_mi_buddy_check_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
RTW_PRINT("no issue auth, P2P cross-connect does not permit\n ");
return _SUCCESS;
}
}
}
#endif /* CONFIG_P2P CONFIG_P2P and CONFIG_CONCURRENT_MODE */
/* start auth */
start_clnt_auth(padapter);
return _SUCCESS;
}
if (((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) && (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta != NULL) {
#ifdef CONFIG_PATCH_JOIN_WRONG_CHANNEL
/* Merge from 8712 FW code */
if (cmp_pkt_chnl_diff(padapter, pframe, len) != 0) {
/* join wrong channel, deauth and reconnect */
issue_deauth(padapter, (&(pmlmeinfo->network))->MacAddress, WLAN_REASON_DEAUTH_LEAVING);
report_del_sta_event(padapter, (&(pmlmeinfo->network))->MacAddress, WLAN_REASON_JOIN_WRONG_CHANNEL, _TRUE, _FALSE);
pmlmeinfo->state &= (~WIFI_FW_ASSOC_SUCCESS);
return _SUCCESS;
}
#endif /* CONFIG_PATCH_JOIN_WRONG_CHANNEL */
#ifdef CONFIG_RTW_80211R
rtw_ft_update_bcn(padapter, precv_frame);
#endif
ret = rtw_check_bcn_info(padapter, pframe, len);
if (!ret) {
RTW_PRINT(FUNC_ADPT_FMT" ap has changed, disconnect now\n", FUNC_ADPT_ARG(padapter));
receive_disconnect(padapter, pmlmeinfo->network.MacAddress , 0, _FALSE);
return _SUCCESS;
}
/* update WMM, ERP in the beacon */
/* todo: the timer is used instead of the number of the beacon received */
if ((sta_rx_pkts(psta) & 0xf) == 0) {
/* RTW_INFO("update_bcn_info\n"); */
update_beacon_info(padapter, pframe, len, psta);
}
pmlmepriv->cur_network_scanned->network.Rssi = precv_frame->u.hdr.attrib.phy_info.recv_signal_power;
pmlmeext->bcn_cnt++;
#ifdef CONFIG_BCN_RECV_TIME
rtw_rx_bcn_time_update(padapter, len, precv_frame->u.hdr.attrib.data_rate);
#endif
#ifdef CONFIG_TDLS
#ifdef CONFIG_TDLS_CH_SW
if (rtw_tdls_is_chsw_allowed(padapter) == _TRUE) {
/* Send TDLS Channel Switch Request when receiving Beacon */
if ((padapter->tdlsinfo.chsw_info.ch_sw_state & TDLS_CH_SW_INITIATOR_STATE) && (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE)
&& (pmlmeext->cur_channel == rtw_get_oper_ch(padapter))) {
ptdls_sta = rtw_get_stainfo(&padapter->stapriv, padapter->tdlsinfo.chsw_info.addr);
if (ptdls_sta != NULL) {
if (ptdls_sta->tdls_sta_state | TDLS_LINKED_STATE)
_set_timer(&ptdls_sta->stay_on_base_chnl_timer, TDLS_CH_SW_STAY_ON_BASE_CHNL_TIMEOUT);
}
}
}
#endif
#endif /* CONFIG_TDLS */
#ifdef CONFIG_DFS
process_csa_ie(padapter
, pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_
, len - (WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_));
#endif
#ifdef CONFIG_P2P_PS
process_p2p_ps_ie(padapter, (pframe + WLAN_HDR_A3_LEN), (len - WLAN_HDR_A3_LEN));
#endif /* CONFIG_P2P_PS */
if (pmlmeext->tsf_update_required && pmlmeext->en_hw_update_tsf)
rtw_enable_hw_update_tsf_cmd(padapter);
#if 0 /* move to validate_recv_mgnt_frame */
psta->sta_stats.rx_mgnt_pkts++;
#endif
}
} else if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
u8 rate_set[16];
u8 rate_num = 0;
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta != NULL) {
/*
* update WMM, ERP in the beacon
* todo: the timer is used instead of the number of the beacon received
*/
if ((sta_rx_pkts(psta) & 0xf) == 0)
update_beacon_info(padapter, pframe, len, psta);
if (pmlmeext->tsf_update_required && pmlmeext->en_hw_update_tsf)
rtw_enable_hw_update_tsf_cmd(padapter);
} else {
rtw_ies_get_supported_rate(pframe + WLAN_HDR_A3_LEN + _BEACON_IE_OFFSET_, len - WLAN_HDR_A3_LEN - _BEACON_IE_OFFSET_, rate_set, &rate_num);
if (rate_num == 0) {
RTW_INFO(FUNC_ADPT_FMT" RX beacon with no supported rate\n", FUNC_ADPT_ARG(padapter));
goto _END_ONBEACON_;
}
psta = rtw_alloc_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta == NULL) {
RTW_INFO(FUNC_ADPT_FMT" Exceed the upper limit of supported clients\n", FUNC_ADPT_ARG(padapter));
goto _END_ONBEACON_;
}
psta->expire_to = pstapriv->adhoc_expire_to;
_rtw_memcpy(psta->bssrateset, rate_set, rate_num);
psta->bssratelen = rate_num;
/* update TSF Value */
update_TSF(pmlmeext, pframe, len);
/* report sta add event */
report_add_sta_event(padapter, get_addr2_ptr(pframe));
}
}
}
_END_ONBEACON_:
return _SUCCESS;
}
unsigned int OnAuth(_adapter *padapter, union recv_frame *precv_frame)
{
#ifdef CONFIG_AP_MODE
_irqL irqL;
unsigned int auth_mode, seq, ie_len;
unsigned char *sa, *p;
u16 algorithm;
int status;
static struct sta_info stat;
struct sta_info *pstat = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 *pframe = precv_frame->u.hdr.rx_data;
uint len = precv_frame->u.hdr.len;
u8 offset = 0;
#ifdef CONFIG_CONCURRENT_MODE
if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) &&
rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | _FW_UNDER_SURVEY)) {
/* don't process auth request; */
return _SUCCESS;
}
#endif /* CONFIG_CONCURRENT_MODE */
if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
return _FAIL;
if (!MLME_IS_ASOC(padapter))
return _SUCCESS;
#if defined(CONFIG_IOCTL_CFG80211) && defined(CONFIG_RTW_MESH)
if (MLME_IS_MESH(padapter))
return rtw_mesh_on_auth(padapter, precv_frame);
#endif
RTW_INFO("+OnAuth\n");
sa = get_addr2_ptr(pframe);
auth_mode = psecuritypriv->dot11AuthAlgrthm;
if (GetPrivacy(pframe)) {
u8 *iv;
struct rx_pkt_attrib *prxattrib = &(precv_frame->u.hdr.attrib);
prxattrib->hdrlen = WLAN_HDR_A3_LEN;
prxattrib->encrypt = _WEP40_;
iv = pframe + prxattrib->hdrlen;
prxattrib->key_index = ((iv[3] >> 6) & 0x3);
prxattrib->iv_len = 4;
prxattrib->icv_len = 4;
rtw_wep_decrypt(padapter, (u8 *)precv_frame);
offset = 4;
}
algorithm = le16_to_cpu(*(u16 *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset));
seq = le16_to_cpu(*(u16 *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 2));
RTW_INFO("auth alg=%x, seq=%X\n", algorithm, seq);
if (rtw_ap_linking_test_force_auth_fail()) {
status = rtw_ap_linking_test_force_auth_fail();
RTW_INFO(FUNC_ADPT_FMT" force auth fail with status:%u\n"
, FUNC_ADPT_ARG(padapter), status);
goto auth_fail;
}
if ((auth_mode == 2) && (algorithm != WLAN_AUTH_SAE) &&
(psecuritypriv->dot11PrivacyAlgrthm != _WEP40_) &&
(psecuritypriv->dot11PrivacyAlgrthm != _WEP104_))
auth_mode = 0;
if ((algorithm > 0 && auth_mode == 0) || /* rx a shared-key auth but shared not enabled */
(algorithm == 0 && auth_mode == 1)) { /* rx a open-system auth but shared-key is enabled */
RTW_INFO("auth rejected due to bad alg [alg=%d, auth_mib=%d] %02X%02X%02X%02X%02X%02X\n",
algorithm, auth_mode, sa[0], sa[1], sa[2], sa[3], sa[4], sa[5]);
status = _STATS_NO_SUPP_ALG_;
goto auth_fail;
}
#if CONFIG_RTW_MACADDR_ACL
if (rtw_access_ctrl(padapter, sa) == _FALSE) {
status = _STATS_UNABLE_HANDLE_STA_;
goto auth_fail;
}
#endif
pstat = rtw_get_stainfo(pstapriv, sa);
if (pstat == NULL) {
/* allocate a new one */
RTW_INFO("going to alloc stainfo for sa="MAC_FMT"\n", MAC_ARG(sa));
pstat = rtw_alloc_stainfo(pstapriv, sa);
if (pstat == NULL) {
RTW_INFO(" Exceed the upper limit of supported clients...\n");
status = _STATS_UNABLE_HANDLE_STA_;
goto auth_fail;
}
pstat->state = WIFI_FW_AUTH_NULL;
pstat->auth_seq = 0;
/* pstat->flags = 0; */
/* pstat->capability = 0; */
} else {
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
#endif /* CONFIG_IEEE80211W */
{
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&pstat->asoc_list) == _FALSE) {
rtw_list_delete(&pstat->asoc_list);
pstapriv->asoc_list_cnt--;
if (pstat->expire_to > 0)
;/* TODO: STA re_auth within expire_to */
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (seq == 1)
; /* TODO: STA re_auth and auth timeout */
}
}
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
#endif /* CONFIG_IEEE80211W */
{
_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
if (rtw_is_list_empty(&pstat->auth_list)) {
rtw_list_insert_tail(&pstat->auth_list, &pstapriv->auth_list);
pstapriv->auth_list_cnt++;
}
_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
}
if (pstat->auth_seq == 0)
pstat->expire_to = pstapriv->auth_to;
#ifdef CONFIG_IOCTL_CFG80211
if (GET_CFG80211_REPORT_MGMT(adapter_wdev_data(padapter), IEEE80211_STYPE_AUTH) == _TRUE) {
if ((algorithm == WLAN_AUTH_SAE) &&
(auth_mode == dot11AuthAlgrthm_8021X)) {
pstat->authalg = algorithm;
rtw_cfg80211_rx_mframe(padapter, precv_frame, NULL);
return _SUCCESS;
}
}
#endif /* CONFIG_IOCTL_CFG80211 */
if ((pstat->auth_seq + 1) != seq) {
RTW_INFO("(1)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
seq, pstat->auth_seq + 1);
status = _STATS_OUT_OF_AUTH_SEQ_;
goto auth_fail;
}
if (algorithm == 0 && (auth_mode == 0 || auth_mode == 2 || auth_mode == 3)) {
if (seq == 1) {
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
#endif /* CONFIG_IEEE80211W */
{
pstat->state &= ~WIFI_FW_AUTH_NULL;
pstat->state |= WIFI_FW_AUTH_SUCCESS;
pstat->expire_to = pstapriv->assoc_to;
}
pstat->authalg = algorithm;
} else {
RTW_INFO("(2)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
seq, pstat->auth_seq + 1);
status = _STATS_OUT_OF_AUTH_SEQ_;
goto auth_fail;
}
} else { /* shared system or auto authentication */
if (seq == 1) {
/* prepare for the challenging txt... */
/* get_random_bytes((void *)pstat->chg_txt, 128); */ /* TODO: */
_rtw_memset((void *)pstat->chg_txt, 78, 128);
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
#endif /* CONFIG_IEEE80211W */
{
pstat->state &= ~WIFI_FW_AUTH_NULL;
pstat->state |= WIFI_FW_AUTH_STATE;
}
pstat->authalg = algorithm;
pstat->auth_seq = 2;
} else if (seq == 3) {
/* checking for challenging txt... */
RTW_INFO("checking for challenging txt...\n");
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + 4 + _AUTH_IE_OFFSET_ , _CHLGETXT_IE_, (int *)&ie_len,
len - WLAN_HDR_A3_LEN - _AUTH_IE_OFFSET_ - 4);
if ((p == NULL) || (ie_len <= 0)) {
RTW_INFO("auth rejected because challenge failure!(1)\n");
status = _STATS_CHALLENGE_FAIL_;
goto auth_fail;
}
if (_rtw_memcmp((void *)(p + 2), pstat->chg_txt, 128)) {
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE && !(pstat->state & WIFI_FW_ASSOC_SUCCESS))
#endif /* CONFIG_IEEE80211W */
{
pstat->state &= (~WIFI_FW_AUTH_STATE);
pstat->state |= WIFI_FW_AUTH_SUCCESS;
/* challenging txt is correct... */
pstat->expire_to = pstapriv->assoc_to;
}
} else {
RTW_INFO("auth rejected because challenge failure!\n");
status = _STATS_CHALLENGE_FAIL_;
goto auth_fail;
}
} else {
RTW_INFO("(3)auth rejected because out of seq [rx_seq=%d, exp_seq=%d]!\n",
seq, pstat->auth_seq + 1);
status = _STATS_OUT_OF_AUTH_SEQ_;
goto auth_fail;
}
}
/* Now, we are going to issue_auth... */
pstat->auth_seq = seq + 1;
#ifdef CONFIG_NATIVEAP_MLME
issue_auth(padapter, pstat, (unsigned short)(_STATS_SUCCESSFUL_));
#endif
if ((pstat->state & WIFI_FW_AUTH_SUCCESS) || (pstat->state & WIFI_FW_ASSOC_SUCCESS))
pstat->auth_seq = 0;
return _SUCCESS;
auth_fail:
if (pstat)
rtw_free_stainfo(padapter , pstat);
pstat = &stat;
_rtw_memset((char *)pstat, '\0', sizeof(stat));
pstat->auth_seq = 2;
_rtw_memcpy(pstat->cmn.mac_addr, sa, ETH_ALEN);
#ifdef CONFIG_NATIVEAP_MLME
issue_auth(padapter, pstat, (unsigned short)status);
#endif
#endif
return _FAIL;
}
unsigned int OnAuthClient(_adapter *padapter, union recv_frame *precv_frame)
{
unsigned int seq, len, status, algthm, offset;
unsigned char *p;
unsigned int go2asoc = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 *pframe = precv_frame->u.hdr.rx_data;
uint pkt_len = precv_frame->u.hdr.len;
RTW_INFO("%s\n", __FUNCTION__);
#ifdef CONFIG_IOCTL_CFG80211
if (GET_CFG80211_REPORT_MGMT(adapter_wdev_data(padapter), IEEE80211_STYPE_AUTH) == _TRUE) {
if (rtw_sec_chk_auth_type(padapter, NL80211_AUTHTYPE_SAE)) {
if (rtw_cached_pmkid(padapter, get_my_bssid(&pmlmeinfo->network)) != -1) {
RTW_INFO("SAE: PMKSA cache entry found\n");
goto normal;
}
rtw_cfg80211_rx_mframe(padapter, precv_frame, NULL);
return _SUCCESS;
}
}
normal:
#endif /* CONFIG_IOCTL_CFG80211 */
/* check A1 matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
return _SUCCESS;
if (!(pmlmeinfo->state & WIFI_FW_AUTH_STATE) || pmlmeext->join_abort)
return _SUCCESS;
offset = (GetPrivacy(pframe)) ? 4 : 0;
algthm = le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset));
seq = le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 2));
status = le16_to_cpu(*(unsigned short *)((SIZE_PTR)pframe + WLAN_HDR_A3_LEN + offset + 4));
if (status != 0) {
RTW_INFO("clnt auth fail, status: %d\n", status);
if (status == 13) { /* && pmlmeinfo->auth_algo == dot11AuthAlgrthm_Auto) */
if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
pmlmeinfo->auth_algo = dot11AuthAlgrthm_Open;
else
pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared;
/* pmlmeinfo->reauth_count = 0; */
}
pmlmeinfo->auth_status = status;
set_link_timer(pmlmeext, 1);
goto authclnt_fail;
}
if (seq == 2) {
if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) {
/* legendary shared system */
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _AUTH_IE_OFFSET_, _CHLGETXT_IE_, (int *)&len,
pkt_len - WLAN_HDR_A3_LEN - _AUTH_IE_OFFSET_);
if (p == NULL) {
/* RTW_INFO("marc: no challenge text?\n"); */
goto authclnt_fail;
}
_rtw_memcpy((void *)(pmlmeinfo->chg_txt), (void *)(p + 2), len);
pmlmeinfo->auth_seq = 3;
issue_auth(padapter, NULL, 0);
set_link_timer(pmlmeext, REAUTH_TO);
return _SUCCESS;
} else {
/* open, or 802.11r FTAA system */
go2asoc = 1;
}
} else if (seq == 4) {
if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
go2asoc = 1;
else
goto authclnt_fail;
} else {
/* this is also illegal */
/* RTW_INFO("marc: clnt auth failed due to illegal seq=%x\n", seq); */
goto authclnt_fail;
}
if (go2asoc) {
#ifdef CONFIG_RTW_80211R
if (rtw_ft_update_auth_rsp_ies(padapter, pframe, pkt_len))
return _SUCCESS;
#endif
RTW_PRINT("auth success, start assoc\n");
start_clnt_assoc(padapter);
return _SUCCESS;
}
authclnt_fail:
/* pmlmeinfo->state &= ~(WIFI_FW_AUTH_STATE); */
return _FAIL;
}
unsigned int OnAssocReq(_adapter *padapter, union recv_frame *precv_frame)
{
#ifdef CONFIG_AP_MODE
_irqL irqL;
u16 listen_interval;
struct rtw_ieee802_11_elems elems;
struct sta_info *pstat;
unsigned char reassoc, *pos;
int left;
unsigned short status = _STATS_SUCCESSFUL_;
unsigned short frame_type, ie_offset = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur = &(pmlmeinfo->network);
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint pkt_len = precv_frame->u.hdr.len;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 p2p_status_code = P2P_STATUS_SUCCESS;
u8 *p2pie;
u32 p2pielen = 0;
#endif /* CONFIG_P2P */
#ifdef CONFIG_CONCURRENT_MODE
if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) &&
rtw_mi_buddy_check_fwstate(padapter, _FW_UNDER_LINKING | _FW_UNDER_SURVEY)) {
/* don't process assoc request; */
return _SUCCESS;
}
#endif /* CONFIG_CONCURRENT_MODE */
if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
return _FAIL;
frame_type = get_frame_sub_type(pframe);
if (frame_type == WIFI_ASSOCREQ) {
reassoc = 0;
ie_offset = _ASOCREQ_IE_OFFSET_;
} else { /* WIFI_REASSOCREQ */
reassoc = 1;
ie_offset = _REASOCREQ_IE_OFFSET_;
}
if (pkt_len < IEEE80211_3ADDR_LEN + ie_offset) {
RTW_INFO("handle_assoc(reassoc=%d) - too short payload (len=%lu)"
"\n", reassoc, (unsigned long)pkt_len);
return _FAIL;
}
pstat = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (pstat == (struct sta_info *)NULL) {
status = _RSON_CLS2_;
goto asoc_class2_error;
}
RTW_INFO("%s\n", __FUNCTION__);
if (pstat->authalg == WLAN_AUTH_SAE) {
/* WPA3-SAE */
if (((pstat->state) & WIFI_FW_AUTH_NULL)) {
/* TODO:
Queue AssocReq and Proccess
by external auth trigger. */
RTW_INFO("%s: wait external auth trigger\n", __func__);
return _SUCCESS;
}
}
/* check if this stat has been successfully authenticated/assocated */
if (!((pstat->state) & WIFI_FW_AUTH_SUCCESS)) {
if (!((pstat->state) & WIFI_FW_ASSOC_SUCCESS)) {
status = _RSON_CLS2_;
goto asoc_class2_error;
} else {
pstat->state &= (~WIFI_FW_ASSOC_SUCCESS);
pstat->state |= WIFI_FW_ASSOC_STATE;
}
} else {
pstat->state &= (~WIFI_FW_AUTH_SUCCESS);
pstat->state |= WIFI_FW_ASSOC_STATE;
}
#if 0/* todo:tkip_countermeasures */
if (hapd->tkip_countermeasures) {
resp = WLAN_REASON_MICHAEL_MIC_FAILURE;
goto fail;
}
#endif
if (rtw_ap_linking_test_force_asoc_fail()) {
status = rtw_ap_linking_test_force_asoc_fail();
RTW_INFO(FUNC_ADPT_FMT" force asoc fail with status:%u\n"
, FUNC_ADPT_ARG(padapter), status);
goto OnAssocReqFail;
}
/* now parse all ieee802_11 ie to point to elems */
left = pkt_len - (IEEE80211_3ADDR_LEN + ie_offset);
pos = pframe + (IEEE80211_3ADDR_LEN + ie_offset);
if (rtw_ieee802_11_parse_elems(pos, left, &elems, 1) == ParseFailed) {
RTW_INFO("STA " MAC_FMT " sent invalid association request\n",
MAC_ARG(pstat->cmn.mac_addr));
status = _STATS_FAILURE_;
goto OnAssocReqFail;
}
rtw_ap_parse_sta_capability(padapter, pstat, pframe + WLAN_HDR_A3_LEN);
listen_interval = RTW_GET_LE16(pframe + WLAN_HDR_A3_LEN + 2);
#if 0/* todo: */
/* check listen_interval */
if (listen_interval > hapd->conf->max_listen_interval) {
hostapd_logger(hapd, mgmt->sa, HOSTAPD_MODULE_IEEE80211,
HOSTAPD_LEVEL_DEBUG,
"Too large Listen Interval (%d)",
listen_interval);
resp = WLAN_STATUS_ASSOC_DENIED_LISTEN_INT_TOO_LARGE;
goto fail;
}
pstat->listen_interval = listen_interval;
#endif
/* now we should check all the fields... */
/* checking SSID */
if (elems.ssid == NULL
|| elems.ssid_len == 0
|| elems.ssid_len != cur->Ssid.SsidLength
|| _rtw_memcmp(elems.ssid, cur->Ssid.Ssid, cur->Ssid.SsidLength) == _FALSE
) {
status = _STATS_FAILURE_;
goto OnAssocReqFail;
}
/* (Extended) Supported rates */
status = rtw_ap_parse_sta_supported_rates(padapter, pstat
, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
if (status != _STATS_SUCCESSFUL_)
goto OnAssocReqFail;
/* check RSN/WPA/WPS */
status = rtw_ap_parse_sta_security_ie(padapter, pstat, &elems);
if (status != _STATS_SUCCESSFUL_)
goto OnAssocReqFail;
/* check if there is WMM IE & support WWM-PS */
rtw_ap_parse_sta_wmm_ie(padapter, pstat
, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
#ifdef CONFIG_RTS_FULL_BW
/*check vendor IE*/
rtw_parse_sta_vendor_ie_8812(padapter, pstat
, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
#endif/*CONFIG_RTS_FULL_BW*/
rtw_ap_parse_sta_ht_ie(padapter, pstat, &elems);
rtw_ap_parse_sta_vht_ie(padapter, pstat, &elems);
if (((pstat->flags & WLAN_STA_HT) || (pstat->flags & WLAN_STA_VHT)) &&
((pstat->wpa2_pairwise_cipher & WPA_CIPHER_TKIP) ||
(pstat->wpa_pairwise_cipher & WPA_CIPHER_TKIP))) {
RTW_INFO("(V)HT: " MAC_FMT " tried to use TKIP with (V)HT association\n", MAC_ARG(pstat->cmn.mac_addr));
pstat->flags &= ~WLAN_STA_HT;
pstat->flags &= ~WLAN_STA_VHT;
/*status = WLAN_STATUS_CIPHER_REJECTED_PER_POLICY;
* goto OnAssocReqFail;
*/
}
if (status != _STATS_SUCCESSFUL_)
goto OnAssocReqFail;
#ifdef CONFIG_P2P
pstat->is_p2p_device = _FALSE;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
p2pie = rtw_get_p2p_ie(pframe + WLAN_HDR_A3_LEN + ie_offset , pkt_len - WLAN_HDR_A3_LEN - ie_offset , NULL, &p2pielen);
if (p2pie) {
pstat->is_p2p_device = _TRUE;
p2p_status_code = (u8)process_assoc_req_p2p_ie(pwdinfo, pframe, pkt_len, pstat);
if (p2p_status_code > 0) {
pstat->p2p_status_code = p2p_status_code;
status = _STATS_CAP_FAIL_;
goto OnAssocReqFail;
}
}
#ifdef CONFIG_WFD
rtw_process_wfd_ies(padapter, pframe + WLAN_HDR_A3_LEN + ie_offset, pkt_len - WLAN_HDR_A3_LEN - ie_offset, __func__);
#endif
}
pstat->p2p_status_code = p2p_status_code;
#endif /* CONFIG_P2P */
#ifdef CONFIG_RTW_REPEATER_SON
if (rtw_rson_ap_check_sta(padapter, pframe, pkt_len, ie_offset))
goto OnAssocReqFail;
#endif
/* TODO: identify_proprietary_vendor_ie(); */
/* Realtek proprietary IE */
/* identify if this is Broadcom sta */
/* identify if this is ralink sta */
/* Customer proprietary IE */
#ifdef CONFIG_RTW_80211K
rtw_ap_parse_sta_rm_en_cap(padapter, pstat, &elems);
#endif
/* AID assignment */
if (pstat->cmn.aid > 0)
RTW_INFO(FUNC_ADPT_FMT" old AID=%d\n", FUNC_ADPT_ARG(padapter), pstat->cmn.aid);
else {
if (!rtw_aid_alloc(padapter, pstat)) {
RTW_INFO(FUNC_ADPT_FMT" no room for more AIDs\n", FUNC_ADPT_ARG(padapter));
status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
goto OnAssocReqFail;
}
RTW_INFO(FUNC_ADPT_FMT" allocate new AID=%d\n", FUNC_ADPT_ARG(padapter), pstat->cmn.aid);
}
pstat->state &= (~WIFI_FW_ASSOC_STATE);
pstat->state |= WIFI_FW_ASSOC_SUCCESS;
/* RTW_INFO("==================%s, %d, (%x), bpairwise_key_installed=%d, MAC:"MAC_FMT"\n"
, __func__, __LINE__, pstat->state, pstat->bpairwise_key_installed, MAC_ARG(pstat->cmn.mac_addr)); */
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE)
#endif /* CONFIG_IEEE80211W */
{
_enter_critical_bh(&pstapriv->auth_list_lock, &irqL);
if (!rtw_is_list_empty(&pstat->auth_list)) {
rtw_list_delete(&pstat->auth_list);
pstapriv->auth_list_cnt--;
}
_exit_critical_bh(&pstapriv->auth_list_lock, &irqL);
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&pstat->asoc_list)) {
pstat->expire_to = pstapriv->expire_to;
rtw_list_insert_tail(&pstat->asoc_list, &pstapriv->asoc_list);
pstapriv->asoc_list_cnt++;
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
}
/* now the station is qualified to join our BSS... */
if (pstat && (pstat->state & WIFI_FW_ASSOC_SUCCESS) && (_STATS_SUCCESSFUL_ == status)) {
#ifdef CONFIG_NATIVEAP_MLME
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE)
#endif /* CONFIG_IEEE80211W */
{
/* .1 bss_cap_update & sta_info_update */
bss_cap_update_on_sta_join(padapter, pstat);
sta_info_update(padapter, pstat);
}
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed == _TRUE)
status = _STATS_REFUSED_TEMPORARILY_;
#endif /* CONFIG_IEEE80211W */
/* .2 issue assoc rsp before notify station join event. */
if (frame_type == WIFI_ASSOCREQ)
issue_asocrsp(padapter, status, pstat, WIFI_ASSOCRSP);
else
issue_asocrsp(padapter, status, pstat, WIFI_REASSOCRSP);
#ifdef CONFIG_IOCTL_CFG80211
_enter_critical_bh(&pstat->lock, &irqL);
if (pstat->passoc_req) {
rtw_mfree(pstat->passoc_req, pstat->assoc_req_len);
pstat->passoc_req = NULL;
pstat->assoc_req_len = 0;
}
pstat->passoc_req = rtw_zmalloc(pkt_len);
if (pstat->passoc_req) {
_rtw_memcpy(pstat->passoc_req, pframe, pkt_len);
pstat->assoc_req_len = pkt_len;
}
_exit_critical_bh(&pstat->lock, &irqL);
#endif /* CONFIG_IOCTL_CFG80211 */
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed != _TRUE)
#endif /* CONFIG_IEEE80211W */
{
/* .3-(1) report sta add event */
report_add_sta_event(padapter, pstat->cmn.mac_addr);
}
#ifdef CONFIG_IEEE80211W
if (pstat->bpairwise_key_installed == _TRUE && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE) {
RTW_INFO(MAC_FMT"\n", MAC_ARG(pstat->cmn.mac_addr));
issue_action_SA_Query(padapter, pstat->cmn.mac_addr, 0, 0, IEEE80211W_RIGHT_KEY);
}
#endif /* CONFIG_IEEE80211W */
#endif /* CONFIG_NATIVEAP_MLME */
}
return _SUCCESS;
asoc_class2_error:
#ifdef CONFIG_NATIVEAP_MLME
issue_deauth(padapter, (void *)get_addr2_ptr(pframe), status);
#endif
return _FAIL;
OnAssocReqFail:
#ifdef CONFIG_NATIVEAP_MLME
pstat->cmn.aid = 0;
if (frame_type == WIFI_ASSOCREQ)
issue_asocrsp(padapter, status, pstat, WIFI_ASSOCRSP);
else
issue_asocrsp(padapter, status, pstat, WIFI_REASSOCRSP);
#endif
#endif /* CONFIG_AP_MODE */
return _FAIL;
}
#if defined(CONFIG_LAYER2_ROAMING) && defined(CONFIG_RTW_80211K)
void rtw_roam_nb_discover(_adapter *padapter, u8 bfroce)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
u8 nb_req_issue = _FALSE;
if (!check_fwstate(pmlmepriv, _FW_LINKED))
return;
if (!rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE))
return;
psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
if (!psta)
return;
if (bfroce || (!pmlmepriv->nb_info.nb_rpt_is_same))
nb_req_issue = _TRUE;
if (nb_req_issue && (psta->rm_en_cap[0] & RTW_RRM_NB_RPT_EN))
rm_add_nb_req(padapter, psta);
}
#endif
unsigned int OnAssocRsp(_adapter *padapter, union recv_frame *precv_frame)
{
uint i;
int res;
unsigned short status;
PNDIS_802_11_VARIABLE_IEs pIE;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network); */
u8 *pframe = precv_frame->u.hdr.rx_data;
uint pkt_len = precv_frame->u.hdr.len;
#ifdef CONFIG_WAPI_SUPPORT
PNDIS_802_11_VARIABLE_IEs pWapiIE = NULL;
#endif
RTW_INFO("%s\n", __FUNCTION__);
/* check A1 matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
return _SUCCESS;
if (!(pmlmeinfo->state & (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)) || pmlmeext->join_abort)
return _SUCCESS;
if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
return _SUCCESS;
_cancel_timer_ex(&pmlmeext->link_timer);
/* status */
status = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 2));
if (status > 0) {
RTW_INFO("assoc reject, status code: %d\n", status);
pmlmeinfo->state = WIFI_FW_NULL_STATE;
res = -4;
goto report_assoc_result;
}
/* get capabilities */
pmlmeinfo->capability = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
/* set slot time */
pmlmeinfo->slotTime = (pmlmeinfo->capability & BIT(10)) ? 9 : 20;
/* AID */
res = pmlmeinfo->aid = (int)(le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 4)) & 0x3fff);
/* check aid value */
if (res < 1 || res > 2007) {
RTW_INFO("assoc reject, aid: %d\n", res);
pmlmeinfo->state = WIFI_FW_NULL_STATE;
res = -4;
goto report_assoc_result;
}
/* following are moved to join event callback function */
/* to handle HT, WMM, rate adaptive, update MAC reg */
/* for not to handle the synchronous IO in the tasklet */
for (i = (6 + WLAN_HDR_A3_LEN); i < pkt_len;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
if (_rtw_memcmp(pIE->data, WMM_PARA_OUI, 6)) /* WMM */
WMM_param_handler(padapter, pIE);
#if defined(CONFIG_P2P) && defined(CONFIG_WFD)
else if (_rtw_memcmp(pIE->data, WFD_OUI, 4)) /* WFD */
rtw_process_wfd_ie(padapter, (u8 *)pIE, pIE->Length, __func__);
#endif
break;
#ifdef CONFIG_WAPI_SUPPORT
case _WAPI_IE_:
pWapiIE = pIE;
break;
#endif
case _HT_CAPABILITY_IE_: /* HT caps */
HT_caps_handler(padapter, pIE);
#ifdef ROKU_PRIVATE
HT_caps_handler_infra_ap(padapter, pIE);
#endif /* ROKU_PRIVATE */
break;
case _HT_EXTRA_INFO_IE_: /* HT info */
HT_info_handler(padapter, pIE);
break;
#ifdef CONFIG_80211AC_VHT
case EID_VHTCapability:
VHT_caps_handler(padapter, pIE);
#ifdef ROKU_PRIVATE
VHT_caps_handler_infra_ap(padapter, pIE);
#endif /* ROKU_PRIVATE */
break;
case EID_VHTOperation:
VHT_operation_handler(padapter, pIE);
break;
#endif
case _ERPINFO_IE_:
ERP_IE_handler(padapter, pIE);
break;
#ifdef CONFIG_TDLS
case _EXT_CAP_IE_:
if (check_ap_tdls_prohibited(pIE->data, pIE->Length) == _TRUE)
padapter->tdlsinfo.ap_prohibited = _TRUE;
if (check_ap_tdls_ch_switching_prohibited(pIE->data, pIE->Length) == _TRUE)
padapter->tdlsinfo.ch_switch_prohibited = _TRUE;
break;
#endif /* CONFIG_TDLS */
#ifdef CONFIG_RTW_80211K
case _EID_RRM_EN_CAP_IE_:
RM_IE_handler(padapter, pIE);
break;
#endif
#ifdef ROKU_PRIVATE
/* Infra mode, used to store AP's info , Parse the supported rates from AssocRsp */
case _SUPPORTEDRATES_IE_:
Supported_rate_infra_ap(padapter, pIE);
break;
case _EXT_SUPPORTEDRATES_IE_:
Extended_Supported_rate_infra_ap(padapter, pIE);
break;
#endif /* ROKU_PRIVATE */
default:
break;
}
i += (pIE->Length + 2);
}
#ifdef CONFIG_WAPI_SUPPORT
rtw_wapi_on_assoc_ok(padapter, pIE);
#endif
pmlmeinfo->state &= (~WIFI_FW_ASSOC_STATE);
pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
/* Update Basic Rate Table for spec, 2010-12-28 , by thomas */
UpdateBrateTbl(padapter, pmlmeinfo->network.SupportedRates);
report_assoc_result:
if (res > 0)
rtw_buf_update(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len, pframe, pkt_len);
else
rtw_buf_free(&pmlmepriv->assoc_rsp, &pmlmepriv->assoc_rsp_len);
report_join_res(padapter, res, status);
#if defined(CONFIG_LAYER2_ROAMING) && defined(CONFIG_RTW_80211K)
rtw_roam_nb_discover(padapter, _TRUE);
#endif
return _SUCCESS;
}
unsigned int OnDeAuth(_adapter *padapter, union recv_frame *precv_frame)
{
unsigned short reason;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 *pframe = precv_frame->u.hdr.rx_data;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
/* check A3 */
if (!(_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
return _SUCCESS;
RTW_INFO(FUNC_ADPT_FMT" - Start to Disconnect\n", FUNC_ADPT_ARG(padapter));
#ifdef CONFIG_P2P
if (pwdinfo->rx_invitereq_info.scan_op_ch_only) {
_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
_set_timer(&pwdinfo->reset_ch_sitesurvey, 10);
}
#endif /* CONFIG_P2P */
reason = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
#ifdef CONFIG_AP_MODE
if (MLME_IS_AP(padapter)) {
_irqL irqL;
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
/* rtw_free_stainfo(padapter, psta); */
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta) {
u8 updated = _FALSE;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
rtw_list_delete(&psta->asoc_list);
pstapriv->asoc_list_cnt--;
updated = ap_free_sta(padapter, psta, _FALSE, reason, _TRUE);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
}
return _SUCCESS;
} else
#endif
if (!MLME_IS_MESH(padapter)) {
int ignore_received_deauth = 0;
/* Commented by Albert 20130604 */
/* Before sending the auth frame to start the STA/GC mode connection with AP/GO, */
/* we will send the deauth first. */
/* However, the Win8.1 with BRCM Wi-Fi will send the deauth with reason code 6 to us after receieving our deauth. */
/* Added the following code to avoid this case. */
if ((pmlmeinfo->state & WIFI_FW_AUTH_STATE) ||
(pmlmeinfo->state & WIFI_FW_ASSOC_STATE)) {
if (reason == WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA)
ignore_received_deauth = 1;
else if (WLAN_REASON_PREV_AUTH_NOT_VALID == reason) {
/* TODO: 802.11r */
ignore_received_deauth = 1;
}
}
RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM, ignore=%d\n"
, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe), ignore_received_deauth);
if (0 == ignore_received_deauth)
receive_disconnect(padapter, get_addr2_ptr(pframe), reason, _FALSE);
}
pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
return _SUCCESS;
}
unsigned int OnDisassoc(_adapter *padapter, union recv_frame *precv_frame)
{
unsigned short reason;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 *pframe = precv_frame->u.hdr.rx_data;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
/* check A3 */
if (!(_rtw_memcmp(GetAddr3Ptr(pframe), get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
return _SUCCESS;
RTW_INFO(FUNC_ADPT_FMT" - Start to Disconnect\n", FUNC_ADPT_ARG(padapter));
#ifdef CONFIG_P2P
if (pwdinfo->rx_invitereq_info.scan_op_ch_only) {
_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
_set_timer(&pwdinfo->reset_ch_sitesurvey, 10);
}
#endif /* CONFIG_P2P */
reason = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN));
#ifdef CONFIG_AP_MODE
if (MLME_IS_AP(padapter)) {
_irqL irqL;
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
/* rtw_free_stainfo(padapter, psta); */
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL); */
RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta) {
u8 updated = _FALSE;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (rtw_is_list_empty(&psta->asoc_list) == _FALSE) {
rtw_list_delete(&psta->asoc_list);
pstapriv->asoc_list_cnt--;
updated = ap_free_sta(padapter, psta, _FALSE, reason, _TRUE);
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
associated_clients_update(padapter, updated, STA_INFO_UPDATE_ALL);
}
return _SUCCESS;
} else
#endif
if (!MLME_IS_MESH(padapter)) {
RTW_PRINT(FUNC_ADPT_FMT" reason=%u, ta=%pM\n"
, FUNC_ADPT_ARG(padapter), reason, get_addr2_ptr(pframe));
receive_disconnect(padapter, get_addr2_ptr(pframe), reason, _FALSE);
}
pmlmepriv->LinkDetectInfo.bBusyTraffic = _FALSE;
return _SUCCESS;
}
unsigned int OnAtim(_adapter *padapter, union recv_frame *precv_frame)
{
RTW_INFO("%s\n", __FUNCTION__);
return _SUCCESS;
}
unsigned int on_action_spct_ch_switch(_adapter *padapter, struct sta_info *psta, u8 *ies, uint ies_len)
{
unsigned int ret = _FAIL;
struct mlme_ext_priv *mlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(mlmeext->mlmext_info);
if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
ret = _SUCCESS;
goto exit;
}
if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
int ch_switch_mode = -1, ch = -1, ch_switch_cnt = -1;
int ch_offset = -1;
u8 bwmode;
struct ieee80211_info_element *ie;
RTW_INFO(FUNC_NDEV_FMT" from "MAC_FMT"\n",
FUNC_NDEV_ARG(padapter->pnetdev), MAC_ARG(psta->cmn.mac_addr));
for_each_ie(ie, ies, ies_len) {
if (ie->id == WLAN_EID_CHANNEL_SWITCH) {
ch_switch_mode = ie->data[0];
ch = ie->data[1];
ch_switch_cnt = ie->data[2];
RTW_INFO("ch_switch_mode:%d, ch:%d, ch_switch_cnt:%d\n",
ch_switch_mode, ch, ch_switch_cnt);
} else if (ie->id == WLAN_EID_SECONDARY_CHANNEL_OFFSET) {
ch_offset = secondary_ch_offset_to_hal_ch_offset(ie->data[0]);
RTW_INFO("ch_offset:%d\n", ch_offset);
}
}
if (ch == -1)
return _SUCCESS;
if (ch_offset == -1)
bwmode = mlmeext->cur_bwmode;
else
bwmode = (ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) ?
CHANNEL_WIDTH_20 : CHANNEL_WIDTH_40;
ch_offset = (ch_offset == -1) ? mlmeext->cur_ch_offset : ch_offset;
/* todo:
* 1. the decision of channel switching
* 2. things after channel switching
*/
ret = rtw_set_chbw_cmd(padapter, ch, bwmode, ch_offset, 0);
}
exit:
return ret;
}
unsigned int on_action_spct(_adapter *padapter, union recv_frame *precv_frame)
{
unsigned int ret = _FAIL;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint frame_len = precv_frame->u.hdr.len;
u8 *frame_body = (u8 *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
u8 category;
u8 action;
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (!psta)
goto exit;
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_SPECTRUM_MGMT)
goto exit;
action = frame_body[1];
RTW_INFO(FUNC_ADPT_FMT" action:%u\n", FUNC_ADPT_ARG(padapter), action);
switch (action) {
case RTW_WLAN_ACTION_SPCT_MSR_REQ:
case RTW_WLAN_ACTION_SPCT_MSR_RPRT:
case RTW_WLAN_ACTION_SPCT_TPC_REQ:
case RTW_WLAN_ACTION_SPCT_TPC_RPRT:
break;
case RTW_WLAN_ACTION_SPCT_CHL_SWITCH:
#ifdef CONFIG_SPCT_CH_SWITCH
ret = on_action_spct_ch_switch(padapter, psta
, frame_body + 2, frame_len - (frame_body - pframe) - 2);
#elif defined(CONFIG_DFS)
if (MLME_IS_STA(padapter) && MLME_IS_ASOC(padapter)) {
process_csa_ie(padapter
, frame_body + 2, frame_len - (frame_body - pframe) - 2);
}
#endif
break;
default:
break;
}
exit:
return ret;
}
unsigned int OnAction_qos(_adapter *padapter, union recv_frame *precv_frame)
{
return _SUCCESS;
}
unsigned int OnAction_dls(_adapter *padapter, union recv_frame *precv_frame)
{
return _SUCCESS;
}
#ifdef CONFIG_RTW_WNM
unsigned int on_action_wnm(_adapter *adapter, union recv_frame *rframe)
{
unsigned int ret = _FAIL;
struct sta_info *sta = NULL;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct sta_priv *stapriv = &(adapter->stapriv);
u8 *frame = rframe->u.hdr.rx_data;
u32 frame_len = rframe->u.hdr.len;
u8 *frame_body = (u8 *)(frame + sizeof(struct rtw_ieee80211_hdr_3addr));
u32 frame_body_len = frame_len - sizeof(struct rtw_ieee80211_hdr_3addr);
u8 category, action;
int cnt = 0;
char msg[16];
sta = rtw_get_stainfo(stapriv, get_addr2_ptr(frame));
if (!sta)
goto exit;
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_WNM)
goto exit;
action = frame_body[1];
switch (action) {
#ifdef CONFIG_RTW_80211R
case RTW_WLAN_ACTION_WNM_BTM_REQ:
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_REQ recv.\n");
rtw_wnm_process_btm_req(adapter, frame_body, frame_body_len);
}
ret = _SUCCESS;
break;
#endif
default:
#ifdef CONFIG_IOCTL_CFG80211
cnt += sprintf((msg + cnt), "ACT_WNM %u", action);
rtw_cfg80211_rx_action(adapter, rframe, msg);
#endif
ret = _SUCCESS;
break;
}
exit:
return ret;
}
#endif /* CONFIG_RTW_WNM */
/**
* rtw_rx_ampdu_size - Get the target RX AMPDU buffer size for the specific @adapter
* @adapter: the adapter to get target RX AMPDU buffer size
*
* Returns: the target RX AMPDU buffer size
*/
u8 rtw_rx_ampdu_size(_adapter *adapter)
{
u8 size;
HT_CAP_AMPDU_FACTOR max_rx_ampdu_factor;
#ifdef CONFIG_BT_COEXIST
if (rtw_btcoex_IsBTCoexCtrlAMPDUSize(adapter) == _TRUE) {
size = rtw_btcoex_GetAMPDUSize(adapter);
goto exit;
}
#endif
/* for scan */
if (!mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_DISABLE)
&& !mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_COMPLETE)
&& adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_size != RX_AMPDU_SIZE_INVALID
) {
size = adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_size;
goto exit;
}
/* default value based on max_rx_ampdu_factor */
if (adapter->driver_rx_ampdu_factor != 0xFF)
max_rx_ampdu_factor = (HT_CAP_AMPDU_FACTOR)adapter->driver_rx_ampdu_factor;
else
rtw_hal_get_def_var(adapter, HW_VAR_MAX_RX_AMPDU_FACTOR, &max_rx_ampdu_factor);
/* In Maximum A-MPDU Length Exponent subfield of A-MPDU Parameters field of HT Capabilities element,
the unit of max_rx_ampdu_factor are octets. 8K, 16K, 32K, 64K is right.
But the buffer size subfield of Block Ack Parameter Set field in ADDBA action frame indicates
the number of buffers available for this particular TID. Each buffer is equal to max. size of
MSDU or AMSDU.
The size variable means how many MSDUs or AMSDUs, it's not Kbytes.
*/
if (MAX_AMPDU_FACTOR_64K == max_rx_ampdu_factor)
size = 64;
else if (MAX_AMPDU_FACTOR_32K == max_rx_ampdu_factor)
size = 32;
else if (MAX_AMPDU_FACTOR_16K == max_rx_ampdu_factor)
size = 16;
else if (MAX_AMPDU_FACTOR_8K == max_rx_ampdu_factor)
size = 8;
else
size = 64;
exit:
if (size > 127)
size = 127;
return size;
}
/**
* rtw_rx_ampdu_is_accept - Get the permission if RX AMPDU should be set up for the specific @adapter
* @adapter: the adapter to get the permission if RX AMPDU should be set up
*
* Returns: accept or not
*/
bool rtw_rx_ampdu_is_accept(_adapter *adapter)
{
bool accept;
if (adapter->fix_rx_ampdu_accept != RX_AMPDU_ACCEPT_INVALID) {
accept = adapter->fix_rx_ampdu_accept;
goto exit;
}
#ifdef CONFIG_BT_COEXIST
if (rtw_btcoex_IsBTCoexRejectAMPDU(adapter) == _TRUE) {
accept = _FALSE;
goto exit;
}
#endif
/* for scan */
if (!mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_DISABLE)
&& !mlmeext_chk_scan_state(&adapter->mlmeextpriv, SCAN_COMPLETE)
&& adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept != RX_AMPDU_ACCEPT_INVALID
) {
accept = adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept;
goto exit;
}
/* default value for other cases */
accept = adapter->mlmeextpriv.mlmext_info.bAcceptAddbaReq;
exit:
return accept;
}
/**
* rtw_rx_ampdu_set_size - Set the target RX AMPDU buffer size for the specific @adapter and specific @reason
* @adapter: the adapter to set target RX AMPDU buffer size
* @size: the target RX AMPDU buffer size to set
* @reason: reason for the target RX AMPDU buffer size setting
*
* Returns: whether the target RX AMPDU buffer size is changed
*/
bool rtw_rx_ampdu_set_size(_adapter *adapter, u8 size, u8 reason)
{
bool is_adj = _FALSE;
struct mlme_ext_priv *mlmeext;
struct mlme_ext_info *mlmeinfo;
mlmeext = &adapter->mlmeextpriv;
mlmeinfo = &mlmeext->mlmext_info;
if (reason == RX_AMPDU_DRV_FIXED) {
if (adapter->fix_rx_ampdu_size != size) {
adapter->fix_rx_ampdu_size = size;
is_adj = _TRUE;
RTW_INFO(FUNC_ADPT_FMT" fix_rx_ampdu_size:%u\n", FUNC_ADPT_ARG(adapter), size);
}
} else if (reason == RX_AMPDU_DRV_SCAN) {
struct ss_res *ss = &adapter->mlmeextpriv.sitesurvey_res;
if (ss->rx_ampdu_size != size) {
ss->rx_ampdu_size = size;
is_adj = _TRUE;
RTW_INFO(FUNC_ADPT_FMT" ss.rx_ampdu_size:%u\n", FUNC_ADPT_ARG(adapter), size);
}
}
return is_adj;
}
/**
* rtw_rx_ampdu_set_accept - Set the permission if RX AMPDU should be set up for the specific @adapter and specific @reason
* @adapter: the adapter to set if RX AMPDU should be set up
* @accept: if RX AMPDU should be set up
* @reason: reason for the permission if RX AMPDU should be set up
*
* Returns: whether the permission if RX AMPDU should be set up is changed
*/
bool rtw_rx_ampdu_set_accept(_adapter *adapter, u8 accept, u8 reason)
{
bool is_adj = _FALSE;
struct mlme_ext_priv *mlmeext;
struct mlme_ext_info *mlmeinfo;
mlmeext = &adapter->mlmeextpriv;
mlmeinfo = &mlmeext->mlmext_info;
if (reason == RX_AMPDU_DRV_FIXED) {
if (adapter->fix_rx_ampdu_accept != accept) {
adapter->fix_rx_ampdu_accept = accept;
is_adj = _TRUE;
RTW_INFO(FUNC_ADPT_FMT" fix_rx_ampdu_accept:%u\n", FUNC_ADPT_ARG(adapter), accept);
}
} else if (reason == RX_AMPDU_DRV_SCAN) {
if (adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept != accept) {
adapter->mlmeextpriv.sitesurvey_res.rx_ampdu_accept = accept;
is_adj = _TRUE;
RTW_INFO(FUNC_ADPT_FMT" ss.rx_ampdu_accept:%u\n", FUNC_ADPT_ARG(adapter), accept);
}
}
return is_adj;
}
/**
* rx_ampdu_apply_sta_tid - Apply RX AMPDU setting to the specific @sta and @tid
* @adapter: the adapter to which @sta belongs
* @sta: the sta to be checked
* @tid: the tid to be checked
* @accept: the target permission if RX AMPDU should be set up
* @size: the target RX AMPDU buffer size
*
* Returns:
* 0: no canceled
* 1: canceled by no permission
* 2: canceled by different buffer size
* 3: canceled by potential mismatched status
*
* Blocking function, may sleep
*/
u8 rx_ampdu_apply_sta_tid(_adapter *adapter, struct sta_info *sta, u8 tid, u8 accept, u8 size)
{
u8 ret = 0;
struct recv_reorder_ctrl *reorder_ctl = &sta->recvreorder_ctrl[tid];
if (reorder_ctl->enable == _FALSE) {
if (reorder_ctl->ampdu_size != RX_AMPDU_SIZE_INVALID) {
send_delba_sta_tid_wait_ack(adapter, 0, sta, tid, 1);
ret = 3;
}
goto exit;
}
if (accept == _FALSE) {
send_delba_sta_tid_wait_ack(adapter, 0, sta, tid, 0);
ret = 1;
} else if (reorder_ctl->ampdu_size != size) {
send_delba_sta_tid_wait_ack(adapter, 0, sta, tid, 0);
ret = 2;
}
exit:
return ret;
}
u8 rx_ampdu_size_sta_limit(_adapter *adapter, struct sta_info *sta)
{
u8 sz_limit = 0xFF;
#ifdef CONFIG_80211N_HT
struct registry_priv *regsty = adapter_to_regsty(adapter);
struct mlme_priv *mlme = &adapter->mlmepriv;
struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
s8 nss = -1;
u8 bw = rtw_min(sta->cmn.bw_mode, adapter->mlmeextpriv.cur_bwmode);
#ifdef CONFIG_80211AC_VHT
if (is_supported_vht(sta->wireless_mode)) {
nss = rtw_min(rtw_vht_mcsmap_to_nss(mlme->vhtpriv.vht_mcs_map)
, rtw_vht_mcsmap_to_nss(sta->vhtpriv.vht_mcs_map));
} else
#endif
if (is_supported_ht(sta->wireless_mode)) {
nss = rtw_min(rtw_ht_mcsset_to_nss(mlmeinfo->HT_caps.u.HT_cap_element.MCS_rate)
, rtw_ht_mcsset_to_nss(sta->htpriv.ht_cap.supp_mcs_set));
}
if (nss >= 1)
sz_limit = regsty->rx_ampdu_sz_limit_by_nss_bw[nss - 1][bw];
#endif /* CONFIG_80211N_HT */
return sz_limit;
}
/**
* rx_ampdu_apply_sta - Apply RX AMPDU setting to the specific @sta
* @adapter: the adapter to which @sta belongs
* @sta: the sta to be checked
* @accept: the target permission if RX AMPDU should be set up
* @size: the target RX AMPDU buffer size
*
* Returns: number of the RX AMPDU assciation canceled for applying current target setting
*
* Blocking function, may sleep
*/
u8 rx_ampdu_apply_sta(_adapter *adapter, struct sta_info *sta, u8 accept, u8 size)
{
u8 change_cnt = 0;
int i;
for (i = 0; i < TID_NUM; i++) {
if (rx_ampdu_apply_sta_tid(adapter, sta, i, accept, size) != 0)
change_cnt++;
}
return change_cnt;
}
/**
* rtw_rx_ampdu_apply - Apply the current target RX AMPDU setting for the specific @adapter
* @adapter: the adapter to be applied
*
* Returns: number of the RX AMPDU assciation canceled for applying current target setting
*/
u16 rtw_rx_ampdu_apply(_adapter *adapter)
{
u16 adj_cnt = 0;
struct sta_info *sta;
u8 accept = rtw_rx_ampdu_is_accept(adapter);
u8 size;
if (adapter->fix_rx_ampdu_size != RX_AMPDU_SIZE_INVALID)
size = adapter->fix_rx_ampdu_size;
else
size = rtw_rx_ampdu_size(adapter);
if (MLME_IS_STA(adapter)) {
sta = rtw_get_stainfo(&adapter->stapriv, get_bssid(&adapter->mlmepriv));
if (sta) {
u8 sta_size = size;
if (adapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID)
sta_size = rtw_min(size, rx_ampdu_size_sta_limit(adapter, sta));
adj_cnt += rx_ampdu_apply_sta(adapter, sta, accept, sta_size);
}
/* TODO: TDLS peer */
} else if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
_irqL irqL;
_list *phead, *plist;
u8 peer_num = 0;
char peers[NUM_STA];
struct sta_priv *pstapriv = &adapter->stapriv;
int i;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
int stainfo_offset;
sta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
stainfo_offset = rtw_stainfo_offset(pstapriv, sta);
if (stainfo_offset_valid(stainfo_offset))
peers[peer_num++] = stainfo_offset;
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
for (i = 0; i < peer_num; i++) {
sta = rtw_get_stainfo_by_offset(pstapriv, peers[i]);
if (sta) {
u8 sta_size = size;
if (adapter->fix_rx_ampdu_size == RX_AMPDU_SIZE_INVALID)
sta_size = rtw_min(size, rx_ampdu_size_sta_limit(adapter, sta));
adj_cnt += rx_ampdu_apply_sta(adapter, sta, accept, sta_size);
}
}
}
/* TODO: ADHOC */
return adj_cnt;
}
unsigned int OnAction_back(_adapter *padapter, union recv_frame *precv_frame)
{
u8 *addr;
struct sta_info *psta = NULL;
struct recv_reorder_ctrl *preorder_ctrl;
unsigned char *frame_body;
unsigned char category, action;
unsigned short tid, status, reason_code = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 *pframe = precv_frame->u.hdr.rx_data;
struct sta_priv *pstapriv = &padapter->stapriv;
struct registry_priv *pregpriv = &padapter->registrypriv;
#ifdef CONFIG_80211N_HT
RTW_INFO("%s\n", __FUNCTION__);
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
return _SUCCESS;
#if 0
/* check A1 matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), get_da(pframe), ETH_ALEN))
return _SUCCESS;
#endif
if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
return _SUCCESS;
addr = get_addr2_ptr(pframe);
psta = rtw_get_stainfo(pstapriv, addr);
if (psta == NULL)
return _SUCCESS;
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
category = frame_body[0];
if (category == RTW_WLAN_CATEGORY_BACK) { /* representing Block Ack */
#ifdef CONFIG_TDLS
if ((psta->tdls_sta_state & TDLS_LINKED_STATE) &&
(psta->htpriv.ht_option == _TRUE) &&
(psta->htpriv.ampdu_enable == _TRUE))
RTW_INFO("Recv [%s] from direc link\n", __FUNCTION__);
else
#endif /* CONFIG_TDLS */
if (!pmlmeinfo->HT_enable)
return _SUCCESS;
action = frame_body[1];
RTW_INFO("%s, action=%d\n", __FUNCTION__, action);
switch (action) {
case RTW_WLAN_ACTION_ADDBA_REQ: /* ADDBA request */
_rtw_memcpy(&(pmlmeinfo->ADDBA_req), &(frame_body[2]), sizeof(struct ADDBA_request));
/* process_addba_req(padapter, (u8*)&(pmlmeinfo->ADDBA_req), GetAddr3Ptr(pframe)); */
process_addba_req(padapter, (u8 *)&(pmlmeinfo->ADDBA_req), addr);
break;
case RTW_WLAN_ACTION_ADDBA_RESP: /* ADDBA response */
/* status = frame_body[3] | (frame_body[4] << 8); */ /* endian issue */
status = RTW_GET_LE16(&frame_body[3]);
tid = ((frame_body[5] >> 2) & 0x7);
if (status == 0) {
/* successful */
RTW_INFO("agg_enable for TID=%d\n", tid);
psta->htpriv.agg_enable_bitmap |= 1 << tid;
psta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
/* amsdu in ampdu */
if (pregpriv->tx_ampdu_amsdu == 0)
psta->htpriv.tx_amsdu_enable = _FALSE;
else if (pregpriv->tx_ampdu_amsdu == 1)
psta->htpriv.tx_amsdu_enable = _TRUE;
else {
if (frame_body[5] & 1)
psta->htpriv.tx_amsdu_enable = _TRUE;
}
} else
psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
RTW_INFO("%s alive check - rx ADDBA response\n", __func__);
psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
psta->expire_to = pstapriv->expire_to;
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
}
/* RTW_INFO("marc: ADDBA RSP: %x\n", pmlmeinfo->agg_enable_bitmap); */
break;
case RTW_WLAN_ACTION_DELBA: /* DELBA */
if ((frame_body[3] & BIT(3)) == 0) {
psta->htpriv.agg_enable_bitmap &= ~(1 << ((frame_body[3] >> 4) & 0xf));
psta->htpriv.candidate_tid_bitmap &= ~(1 << ((frame_body[3] >> 4) & 0xf));
/* reason_code = frame_body[4] | (frame_body[5] << 8); */
reason_code = RTW_GET_LE16(&frame_body[4]);
} else if ((frame_body[3] & BIT(3)) == BIT(3)) {
tid = (frame_body[3] >> 4) & 0x0F;
preorder_ctrl = &psta->recvreorder_ctrl[tid];
preorder_ctrl->enable = _FALSE;
preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
}
RTW_INFO("%s(): DELBA: %x(%x)\n", __FUNCTION__, pmlmeinfo->agg_enable_bitmap, reason_code);
/* todo: how to notify the host while receiving DELETE BA */
break;
default:
break;
}
}
#endif /* CONFIG_80211N_HT */
return _SUCCESS;
}
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
u32 rtw_build_vendor_ie(_adapter *padapter , unsigned char **pframe , u8 mgmt_frame_tyte)
{
int vendor_ie_num = 0;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
u32 len = 0;
for (vendor_ie_num = 0 ; vendor_ie_num < WLAN_MAX_VENDOR_IE_NUM ; vendor_ie_num++) {
if (pmlmepriv->vendor_ielen[vendor_ie_num] > 0 && pmlmepriv->vendor_ie_mask[vendor_ie_num] & mgmt_frame_tyte) {
_rtw_memcpy(*pframe , pmlmepriv->vendor_ie[vendor_ie_num] , pmlmepriv->vendor_ielen[vendor_ie_num]);
*pframe += pmlmepriv->vendor_ielen[vendor_ie_num];
len += pmlmepriv->vendor_ielen[vendor_ie_num];
}
}
return len;
}
#endif
#ifdef CONFIG_P2P
int get_reg_classes_full_count(struct p2p_channels *channel_list)
{
int cnt = 0;
int i;
for (i = 0; i < channel_list->reg_classes; i++)
cnt += channel_list->reg_class[i].channels;
return cnt;
}
void issue_p2p_GO_request(_adapter *padapter, u8 *raddr)
{
struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_GO_NEGO_REQ;
u8 wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
u8 wpsielen = 0, p2pielen = 0;
u16 len_channellist_attr = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
RTW_INFO("[%s] In\n", __FUNCTION__);
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pwdinfo->negotiation_dialog_token = 1; /* Initialize the dialog value */
pframe = rtw_set_fixed_ie(pframe, 1, &pwdinfo->negotiation_dialog_token, &(pattrib->pktlen));
/* WPS Section */
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
/* Device Password ID */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PEER_DISPLAY_PIN)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_USER_SPEC);
else if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_SELF_DISPLAY_PIN)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);
else if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_PBC);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20110306 */
/* According to the P2P Specification, the group negoitation request frame should contain 9 P2P attributes */
/* 1. P2P Capability */
/* 2. Group Owner Intent */
/* 3. Configuration Timeout */
/* 4. Listen Channel */
/* 5. Extended Listen Timing */
/* 6. Intended P2P Interface Address */
/* 7. Channel List */
/* 8. P2P Device Info */
/* 9. Operating Channel */
/* P2P Capability */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
else
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
/* Group Owner Intent */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GO_INTENT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
/* Todo the tie breaker bit. */
p2pie[p2pielen++] = ((pwdinfo->intent << 1) & 0xFE);
/* Configuration Timeout */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P GO */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P Client */
/* Listen Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_LISTEN_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
p2pie[p2pielen++] = 0x51; /* Copy from SD7 */
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->listen_channel; /* listening channel number */
/* Extended Listen Timing ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0004);
p2pielen += 2;
/* Value: */
/* Availability Period */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
p2pielen += 2;
/* Availability Interval */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
p2pielen += 2;
/* Intended P2P Interface Address */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_INTENDED_IF_ADDR;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
/* Length: */
/* Country String(3) */
/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
/* + number of channels in all classes */
len_channellist_attr = 3
+ (1 + 1) * (u16)(ch_list->reg_classes)
+ get_reg_classes_full_count(ch_list);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#endif
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Channel Entry List */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
/* Operating Class */
if (union_ch > 14) {
if (union_ch >= 149)
p2pie[p2pielen++] = 0x7c;
else
p2pie[p2pielen++] = 0x73;
} else
p2pie[p2pielen++] = 0x51;
/* Number of Channels */
/* Just support 1 channel and this channel is AP's channel */
p2pie[p2pielen++] = 1;
/* Channel List */
p2pie[p2pielen++] = union_ch;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
int i, j;
for (j = 0; j < ch_list->reg_classes; j++) {
/* Operating Class */
p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
/* Number of Channels */
p2pie[p2pielen++] = ch_list->reg_class[j].channels;
/* Channel List */
for (i = 0; i < ch_list->reg_class[j].channels; i++)
p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
}
}
/* Device Info */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
p2pielen += 2;
/* Primary Device Type */
/* Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
p2pielen += 4;
/* Sub Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
if (pwdinfo->operating_channel <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* operating channel number */
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_nego_req_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
void issue_p2p_GO_response(_adapter *padapter, u8 *raddr, u8 *frame_body, uint len, u8 result)
{
struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_GO_NEGO_RESP;
u8 wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
u8 p2pielen = 0;
uint wpsielen = 0;
u16 wps_devicepassword_id = 0x0000;
uint wps_devicepassword_id_len = 0;
u16 len_channellist_attr = 0;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
RTW_INFO("[%s] In, result = %d\n", __FUNCTION__, result);
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pwdinfo->negotiation_dialog_token = frame_body[7]; /* The Dialog Token of provisioning discovery request frame. */
pframe = rtw_set_fixed_ie(pframe, 1, &(pwdinfo->negotiation_dialog_token), &(pattrib->pktlen));
/* Commented by Albert 20110328 */
/* Try to get the device password ID from the WPS IE of group negotiation request frame */
/* WiFi Direct test plan 5.1.15 */
rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, wpsie, &wpsielen);
rtw_get_wps_attr_content(wpsie, wpsielen, WPS_ATTR_DEVICE_PWID, (u8 *) &wps_devicepassword_id, &wps_devicepassword_id_len);
wps_devicepassword_id = be16_to_cpu(wps_devicepassword_id);
_rtw_memset(wpsie, 0x00, 255);
wpsielen = 0;
/* WPS Section */
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
/* Device Password ID */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);
else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_USER_SPEC);
else
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_PBC);
wpsielen += 2;
/* Commented by Kurt 20120113 */
/* If some device wants to do p2p handshake without sending prov_disc_req */
/* We have to get peer_req_cm from here. */
if (_rtw_memcmp(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "000", 3)) {
if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3);
else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3);
else
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3);
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20100908 */
/* According to the P2P Specification, the group negoitation response frame should contain 9 P2P attributes */
/* 1. Status */
/* 2. P2P Capability */
/* 3. Group Owner Intent */
/* 4. Configuration Timeout */
/* 5. Operating Channel */
/* 6. Intended P2P Interface Address */
/* 7. Channel List */
/* 8. Device Info */
/* 9. Group ID ( Only GO ) */
/* ToDo: */
/* P2P Status */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_STATUS;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = result;
/* P2P Capability */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
/* Commented by Albert 2011/03/08 */
/* According to the P2P specification */
/* if the sending device will be client, the P2P Capability should be reserved of group negotation response frame */
p2pie[p2pielen++] = 0;
} else {
/* Be group owner or meet the error case */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
}
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
else
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
/* Group Owner Intent */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GO_INTENT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
if (pwdinfo->peer_intent & 0x01) {
/* Peer's tie breaker bit is 1, our tie breaker bit should be 0 */
p2pie[p2pielen++] = (pwdinfo->intent << 1);
} else {
/* Peer's tie breaker bit is 0, our tie breaker bit should be 1 */
p2pie[p2pielen++] = ((pwdinfo->intent << 1) | BIT(0));
}
/* Configuration Timeout */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P GO */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P Client */
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
if (pwdinfo->operating_channel <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* operating channel number */
/* Intended P2P Interface Address */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_INTENDED_IF_ADDR;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
/* Country String(3) */
/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
/* + number of channels in all classes */
len_channellist_attr = 3
+ (1 + 1) * (u16)ch_list->reg_classes
+ get_reg_classes_full_count(ch_list);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#endif
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Channel Entry List */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
u8 union_chan = rtw_mi_get_union_chan(padapter);
/*Operating Class*/
if (union_chan > 14) {
if (union_chan >= 149)
p2pie[p2pielen++] = 0x7c;
else
p2pie[p2pielen++] = 0x73;
} else
p2pie[p2pielen++] = 0x51;
/* Number of Channels
Just support 1 channel and this channel is AP's channel*/
p2pie[p2pielen++] = 1;
/*Channel List*/
p2pie[p2pielen++] = union_chan;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
int i, j;
for (j = 0; j < ch_list->reg_classes; j++) {
/* Operating Class */
p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
/* Number of Channels */
p2pie[p2pielen++] = ch_list->reg_class[j].channels;
/* Channel List */
for (i = 0; i < ch_list->reg_class[j].channels; i++)
p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
}
}
/* Device Info */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
p2pielen += 2;
/* Primary Device Type */
/* Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
p2pielen += 4;
/* Sub Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* Group ID Attribute */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + pwdinfo->nego_ssidlen);
p2pielen += 2;
/* Value: */
/* p2P Device Address */
_rtw_memcpy(p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN);
p2pielen += ETH_ALEN;
/* SSID */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
p2pielen += pwdinfo->nego_ssidlen;
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_nego_resp_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
void issue_p2p_GO_confirm(_adapter *padapter, u8 *raddr, u8 result)
{
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_GO_NEGO_CONF;
u8 p2pie[255] = { 0x00 };
u8 p2pielen = 0;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
RTW_INFO("[%s] In\n", __FUNCTION__);
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(pwdinfo->negotiation_dialog_token), &(pattrib->pktlen));
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20110306 */
/* According to the P2P Specification, the group negoitation request frame should contain 5 P2P attributes */
/* 1. Status */
/* 2. P2P Capability */
/* 3. Operating Channel */
/* 4. Channel List */
/* 5. Group ID ( if this WiFi is GO ) */
/* P2P Status */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_STATUS;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = result;
/* P2P Capability */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
else
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
if (pwdinfo->peer_operating_ch <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->peer_operating_ch >= 36) && (pwdinfo->peer_operating_ch <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
p2pie[p2pielen++] = pwdinfo->peer_operating_ch;
} else {
if (pwdinfo->operating_channel <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* Use the listen channel as the operating channel */
}
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
*(u16 *)(p2pie + p2pielen) = 6;
p2pielen += 2;
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Value: */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
if (pwdinfo->peer_operating_ch <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->peer_operating_ch >= 36) && (pwdinfo->peer_operating_ch <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
p2pie[p2pielen++] = 1;
p2pie[p2pielen++] = pwdinfo->peer_operating_ch;
} else {
if (pwdinfo->operating_channel <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
/* Channel Number */
p2pie[p2pielen++] = 1;
p2pie[p2pielen++] = pwdinfo->operating_channel; /* Use the listen channel as the operating channel */
}
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* Group ID Attribute */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + pwdinfo->nego_ssidlen);
p2pielen += 2;
/* Value: */
/* p2P Device Address */
_rtw_memcpy(p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN);
p2pielen += ETH_ALEN;
/* SSID */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
p2pielen += pwdinfo->nego_ssidlen;
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_nego_confirm_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
void issue_p2p_invitation_request(_adapter *padapter, u8 *raddr)
{
struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_INVIT_REQ;
u8 p2pie[255] = { 0x00 };
u8 p2pielen = 0;
u8 dialogToken = 3;
u16 len_channellist_attr = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, raddr, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20101011 */
/* According to the P2P Specification, the P2P Invitation request frame should contain 7 P2P attributes */
/* 1. Configuration Timeout */
/* 2. Invitation Flags */
/* 3. Operating Channel ( Only GO ) */
/* 4. P2P Group BSSID ( Should be included if I am the GO ) */
/* 5. Channel List */
/* 6. P2P Group ID */
/* 7. P2P Device Info */
/* Configuration Timeout */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P GO */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P Client */
/* Invitation Flags */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_INVITATION_FLAGS;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = P2P_INVITATION_FLAGS_PERSISTENT;
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
if (pwdinfo->invitereq_info.operating_ch <= 14)
p2pie[p2pielen++] = 0x51;
else if ((pwdinfo->invitereq_info.operating_ch >= 36) && (pwdinfo->invitereq_info.operating_ch <= 48))
p2pie[p2pielen++] = 0x73;
else
p2pie[p2pielen++] = 0x7c;
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->invitereq_info.operating_ch; /* operating channel number */
if (_rtw_memcmp(adapter_mac_addr(padapter), pwdinfo->invitereq_info.go_bssid, ETH_ALEN)) {
/* P2P Group BSSID */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_BSSID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
p2pielen += 2;
/* Value: */
/* P2P Device Address for GO */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->invitereq_info.go_bssid, ETH_ALEN);
p2pielen += ETH_ALEN;
}
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
/* Length: */
/* Country String(3) */
/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
/* + number of channels in all classes */
len_channellist_attr = 3
+ (1 + 1) * (u16)ch_list->reg_classes
+ get_reg_classes_full_count(ch_list);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#endif
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Channel Entry List */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
/* Operating Class */
if (union_ch > 14) {
if (union_ch >= 149)
p2pie[p2pielen++] = 0x7c;
else
p2pie[p2pielen++] = 0x73;
} else
p2pie[p2pielen++] = 0x51;
/* Number of Channels */
/* Just support 1 channel and this channel is AP's channel */
p2pie[p2pielen++] = 1;
/* Channel List */
p2pie[p2pielen++] = union_ch;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
int i, j;
for (j = 0; j < ch_list->reg_classes; j++) {
/* Operating Class */
p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
/* Number of Channels */
p2pie[p2pielen++] = ch_list->reg_class[j].channels;
/* Channel List */
for (i = 0; i < ch_list->reg_class[j].channels; i++)
p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
}
}
/* P2P Group ID */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(6 + pwdinfo->invitereq_info.ssidlen);
p2pielen += 2;
/* Value: */
/* P2P Device Address for GO */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->invitereq_info.go_bssid, ETH_ALEN);
p2pielen += ETH_ALEN;
/* SSID */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->invitereq_info.go_ssid, pwdinfo->invitereq_info.ssidlen);
p2pielen += pwdinfo->invitereq_info.ssidlen;
/* Device Info */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_DISPLAY);
p2pielen += 2;
/* Primary Device Type */
/* Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
p2pielen += 4;
/* Sub Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_invitation_req_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
void issue_p2p_invitation_response(_adapter *padapter, u8 *raddr, u8 dialogToken, u8 status_code)
{
struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_INVIT_RESP;
u8 p2pie[255] = { 0x00 };
u8 p2pielen = 0;
u16 len_channellist_attr = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, raddr, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20101005 */
/* According to the P2P Specification, the P2P Invitation response frame should contain 5 P2P attributes */
/* 1. Status */
/* 2. Configuration Timeout */
/* 3. Operating Channel ( Only GO ) */
/* 4. P2P Group BSSID ( Only GO ) */
/* 5. Channel List */
/* P2P Status */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_STATUS;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
/* When status code is P2P_STATUS_FAIL_INFO_UNAVAILABLE. */
/* Sent the event receiving the P2P Invitation Req frame to DMP UI. */
/* DMP had to compare the MAC address to find out the profile. */
/* So, the WiFi driver will send the P2P_STATUS_FAIL_INFO_UNAVAILABLE to NB. */
/* If the UI found the corresponding profile, the WiFi driver sends the P2P Invitation Req */
/* to NB to rebuild the persistent group. */
p2pie[p2pielen++] = status_code;
/* Configuration Timeout */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P GO */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P Client */
if (status_code == P2P_STATUS_SUCCESS) {
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* The P2P Invitation request frame asks this Wi-Fi device to be the P2P GO */
/* In this case, the P2P Invitation response frame should carry the two more P2P attributes. */
/* First one is operating channel attribute. */
/* Second one is P2P Group BSSID attribute. */
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
p2pie[p2pielen++] = 0x51; /* Copy from SD7 */
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* operating channel number */
/* P2P Group BSSID */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_BSSID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
p2pielen += 2;
/* Value: */
/* P2P Device Address for GO */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
}
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
/* Length: */
/* Country String(3) */
/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
/* + number of channels in all classes */
len_channellist_attr = 3
+ (1 + 1) * (u16)ch_list->reg_classes
+ get_reg_classes_full_count(ch_list);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#endif
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Channel Entry List */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
/* Operating Class */
if (union_ch > 14) {
if (union_ch >= 149)
p2pie[p2pielen++] = 0x7c;
else
p2pie[p2pielen++] = 0x73;
} else
p2pie[p2pielen++] = 0x51;
/* Number of Channels */
/* Just support 1 channel and this channel is AP's channel */
p2pie[p2pielen++] = 1;
/* Channel List */
p2pie[p2pielen++] = union_ch;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
int i, j;
for (j = 0; j < ch_list->reg_classes; j++) {
/* Operating Class */
p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
/* Number of Channels */
p2pie[p2pielen++] = ch_list->reg_class[j].channels;
/* Channel List */
for (i = 0; i < ch_list->reg_class[j].channels; i++)
p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
}
}
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_invitation_resp_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
void issue_p2p_provision_request(_adapter *padapter, u8 *pssid, u8 ussidlen, u8 *pdev_raddr)
{
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u8 dialogToken = 1;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_PROVISION_DISC_REQ;
u8 wpsie[100] = { 0x00 };
u8 wpsielen = 0;
u32 p2pielen = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
RTW_INFO("[%s] In\n", __FUNCTION__);
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, pdev_raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pdev_raddr, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
p2pielen = build_prov_disc_request_p2p_ie(pwdinfo, pframe, pssid, ussidlen, pdev_raddr);
pframe += p2pielen;
pattrib->pktlen += p2pielen;
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
/* Config Method */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->tx_prov_disc_info.wps_config_method_request);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_provdisc_req_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
u8 is_matched_in_profilelist(u8 *peermacaddr, struct profile_info *profileinfo)
{
u8 i, match_result = 0;
RTW_INFO("[%s] peermac = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
peermacaddr[0], peermacaddr[1], peermacaddr[2], peermacaddr[3], peermacaddr[4], peermacaddr[5]);
for (i = 0; i < P2P_MAX_PERSISTENT_GROUP_NUM; i++, profileinfo++) {
RTW_INFO("[%s] profileinfo_mac = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
profileinfo->peermac[0], profileinfo->peermac[1], profileinfo->peermac[2], profileinfo->peermac[3], profileinfo->peermac[4], profileinfo->peermac[5]);
if (_rtw_memcmp(peermacaddr, profileinfo->peermac, ETH_ALEN)) {
match_result = 1;
RTW_INFO("[%s] Match!\n", __FUNCTION__);
break;
}
}
return match_result ;
}
void issue_probersp_p2p(_adapter *padapter, unsigned char *da)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned char *mac;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
/* WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network); */
u16 beacon_interval = 100;
u16 capInfo = 0;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 wpsie[255] = { 0x00 };
u32 wpsielen = 0, p2pielen = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
/* RTW_INFO("%s\n", __FUNCTION__); */
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
if (IS_CCK_RATE(pattrib->rate)) {
/* force OFDM 6M rate */
pattrib->rate = MGN_6M;
pattrib->raid = rtw_get_mgntframe_raid(padapter, WIRELESS_11G);
}
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
mac = adapter_mac_addr(padapter);
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
/* Use the device address for BSSID field. */
_rtw_memcpy(pwlanhdr->addr3, mac, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(fctrl, WIFI_PROBERSP);
pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = pattrib->hdrlen;
pframe += pattrib->hdrlen;
/* timestamp will be inserted by hardware */
pframe += 8;
pattrib->pktlen += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *) &beacon_interval, 2);
pframe += 2;
pattrib->pktlen += 2;
/* capability info: 2 bytes */
/* ESS and IBSS bits must be 0 (defined in the 3.1.2.1.1 of WiFi Direct Spec) */
capInfo |= cap_ShortPremble;
capInfo |= cap_ShortSlot;
_rtw_memcpy(pframe, (unsigned char *) &capInfo, 2);
pframe += 2;
pattrib->pktlen += 2;
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, 7, pwdinfo->p2p_wildcard_ssid, &pattrib->pktlen);
/* supported rates... */
/* Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 ) */
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pwdinfo->support_rate, &pattrib->pktlen);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&pwdinfo->listen_channel, &pattrib->pktlen);
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
if (pmlmepriv->wps_probe_resp_ie != NULL && pmlmepriv->p2p_probe_resp_ie != NULL) {
/* WPS IE */
_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, pmlmepriv->wps_probe_resp_ie_len);
pattrib->pktlen += pmlmepriv->wps_probe_resp_ie_len;
pframe += pmlmepriv->wps_probe_resp_ie_len;
/* P2P IE */
_rtw_memcpy(pframe, pmlmepriv->p2p_probe_resp_ie, pmlmepriv->p2p_probe_resp_ie_len);
pattrib->pktlen += pmlmepriv->p2p_probe_resp_ie_len;
pframe += pmlmepriv->p2p_probe_resp_ie_len;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
/* Todo: WPS IE */
/* Noted by Albert 20100907 */
/* According to the WPS specification, all the WPS attribute is presented by Big Endian. */
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
/* WiFi Simple Config State */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SIMPLE_CONF_STATE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_WSC_STATE_NOT_CONFIG; /* Not Configured. */
/* Response Type */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_RESP_TYPE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_RESPONSE_TYPE_8021X;
/* UUID-E */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_UUID_E);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0010);
wpsielen += 2;
/* Value: */
if (pwdinfo->external_uuid == 0) {
_rtw_memset(wpsie + wpsielen, 0x0, 16);
_rtw_memcpy(wpsie + wpsielen, mac, ETH_ALEN);
} else
_rtw_memcpy(wpsie + wpsielen, pwdinfo->uuid, 0x10);
wpsielen += 0x10;
/* Manufacturer */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MANUFACTURER);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0007);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, "Realtek", 7);
wpsielen += 7;
/* Model Name */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NAME);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0006);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, "8192CU", 6);
wpsielen += 6;
/* Model Number */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NUMBER);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = 0x31; /* character 1 */
/* Serial Number */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SERIAL_NUMBER);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(ETH_ALEN);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, "123456" , ETH_ALEN);
wpsielen += ETH_ALEN;
/* Primary Device Type */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
wpsielen += 2;
/* Value: */
/* Category ID */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
wpsielen += 2;
/* OUI */
*(u32 *)(wpsie + wpsielen) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* Sub Category ID */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
wpsielen += 2;
/* Device Name */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->device_name_len);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len);
wpsielen += pwdinfo->device_name_len;
/* Config Method */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
p2pielen = build_probe_resp_p2p_ie(pwdinfo, pframe);
pframe += p2pielen;
pattrib->pktlen += p2pielen;
}
#ifdef CONFIG_WFD
wfdielen = rtw_append_probe_resp_wfd_ie(padapter, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
/* Vendor Specific IE */
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_P2P_PROBERESP_VENDOR_IE_BIT);
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
int _issue_probereq_p2p(_adapter *padapter, u8 *da, int wait_ack)
{
int ret = _FAIL;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned char *mac;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
u16 wpsielen = 0, p2pielen = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
if (IS_CCK_RATE(pattrib->rate)) {
/* force OFDM 6M rate */
pattrib->rate = MGN_6M;
pattrib->raid = rtw_get_mgntframe_raid(padapter, WIRELESS_11G);
}
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
mac = adapter_mac_addr(padapter);
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
if (da) {
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
} else {
if ((pwdinfo->p2p_info.scan_op_ch_only) || (pwdinfo->rx_invitereq_info.scan_op_ch_only)) {
/* This two flags will be set when this is only the P2P client mode. */
_rtw_memcpy(pwlanhdr->addr1, pwdinfo->p2p_peer_interface_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pwdinfo->p2p_peer_interface_addr, ETH_ALEN);
} else {
/* broadcast probe request frame */
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, bc_addr, ETH_ALEN);
}
}
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_PROBEREQ);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ))
pframe = rtw_set_ie(pframe, _SSID_IE_, pwdinfo->tx_prov_disc_info.ssid.SsidLength, pwdinfo->tx_prov_disc_info.ssid.Ssid, &(pattrib->pktlen));
else
pframe = rtw_set_ie(pframe, _SSID_IE_, P2P_WILDCARD_SSID_LEN, pwdinfo->p2p_wildcard_ssid, &(pattrib->pktlen));
/* Use the OFDM rate in the P2P probe request frame. ( 6(B), 9(B), 12(B), 24(B), 36, 48, 54 ) */
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pwdinfo->support_rate, &pattrib->pktlen);
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
if (pmlmepriv->wps_probe_req_ie != NULL && pmlmepriv->p2p_probe_req_ie != NULL) {
/* WPS IE */
_rtw_memcpy(pframe, pmlmepriv->wps_probe_req_ie, pmlmepriv->wps_probe_req_ie_len);
pattrib->pktlen += pmlmepriv->wps_probe_req_ie_len;
pframe += pmlmepriv->wps_probe_req_ie_len;
/* P2P IE */
_rtw_memcpy(pframe, pmlmepriv->p2p_probe_req_ie, pmlmepriv->p2p_probe_req_ie_len);
pattrib->pktlen += pmlmepriv->p2p_probe_req_ie_len;
pframe += pmlmepriv->p2p_probe_req_ie_len;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
/* WPS IE */
/* Noted by Albert 20110221 */
/* According to the WPS specification, all the WPS attribute is presented by Big Endian. */
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
if (pmlmepriv->wps_probe_req_ie == NULL) {
/* UUID-E */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_UUID_E);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0010);
wpsielen += 2;
/* Value: */
if (pwdinfo->external_uuid == 0) {
_rtw_memset(wpsie + wpsielen, 0x0, 16);
_rtw_memcpy(wpsie + wpsielen, mac, ETH_ALEN);
} else
_rtw_memcpy(wpsie + wpsielen, pwdinfo->uuid, 0x10);
wpsielen += 0x10;
/* Config Method */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
wpsielen += 2;
}
/* Device Name */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->device_name_len);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len);
wpsielen += pwdinfo->device_name_len;
/* Primary Device Type */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
wpsielen += 2;
/* Value: */
/* Category ID */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_RTK_WIDI);
wpsielen += 2;
/* OUI */
*(u32 *)(wpsie + wpsielen) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* Sub Category ID */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_RTK_DMP);
wpsielen += 2;
/* Device Password ID */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC); /* Registrar-specified */
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20110221 */
/* According to the P2P Specification, the probe request frame should contain 5 P2P attributes */
/* 1. P2P Capability */
/* 2. P2P Device ID if this probe request wants to find the specific P2P device */
/* 3. Listen Channel */
/* 4. Extended Listen Timing */
/* 5. Operating Channel if this WiFi is working as the group owner now */
/* P2P Capability */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
else
p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
/* Listen Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_LISTEN_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
p2pie[p2pielen++] = 0x51; /* Copy from SD7 */
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->listen_channel; /* listen channel */
/* Extended Listen Timing */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0004);
p2pielen += 2;
/* Value: */
/* Availability Period */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
p2pielen += 2;
/* Availability Interval */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
p2pielen += 2;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* Operating Channel (if this WiFi is working as the group owner now) */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
p2pie[p2pielen++] = 0x51; /* Copy from SD7 */
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* operating channel number */
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
}
#ifdef CONFIG_WFD
wfdielen = rtw_append_probe_req_wfd_ie(padapter, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
/* Vendor Specific IE */
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_P2P_PROBEREQ_VENDOR_IE_BIT);
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
inline void issue_probereq_p2p(_adapter *adapter, u8 *da)
{
_issue_probereq_p2p(adapter, da, _FALSE);
}
/*
* wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
* try_cnt means the maximal TX count to try
*/
int issue_probereq_p2p_ex(_adapter *adapter, u8 *da, int try_cnt, int wait_ms)
{
int ret;
int i = 0;
systime start = rtw_get_current_time();
do {
ret = _issue_probereq_p2p(adapter, da, wait_ms > 0 ? _TRUE : _FALSE);
i++;
if (RTW_CANNOT_RUN(adapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (da)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(adapter), MAC_ARG(da), rtw_get_oper_ch(adapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(adapter), rtw_get_oper_ch(adapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
#endif /* CONFIG_P2P */
s32 rtw_action_public_decache(union recv_frame *rframe, u8 token_offset)
{
_adapter *adapter = rframe->u.hdr.adapter;
struct mlme_ext_priv *mlmeext = &(adapter->mlmeextpriv);
u8 *frame = rframe->u.hdr.rx_data;
u16 seq_ctrl = ((rframe->u.hdr.attrib.seq_num & 0xffff) << 4) | (rframe->u.hdr.attrib.frag_num & 0xf);
u8 token = *(rframe->u.hdr.rx_data + sizeof(struct rtw_ieee80211_hdr_3addr) + token_offset);
if (GetRetry(frame)) {
if ((seq_ctrl == mlmeext->action_public_rxseq)
&& (token == mlmeext->action_public_dialog_token)
) {
RTW_INFO(FUNC_ADPT_FMT" seq_ctrl=0x%x, rxseq=0x%x, token:%d\n",
FUNC_ADPT_ARG(adapter), seq_ctrl, mlmeext->action_public_rxseq, token);
return _FAIL;
}
}
/* TODO: per sta seq & token */
mlmeext->action_public_rxseq = seq_ctrl;
mlmeext->action_public_dialog_token = token;
return _SUCCESS;
}
unsigned int on_action_public_p2p(union recv_frame *precv_frame)
{
_adapter *padapter = precv_frame->u.hdr.adapter;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint len = precv_frame->u.hdr.len;
u8 *frame_body;
#ifdef CONFIG_P2P
u8 *p2p_ie;
u32 p2p_ielen;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 result = P2P_STATUS_SUCCESS;
u8 empty_addr[ETH_ALEN] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
u8 *merged_p2pie = NULL;
u32 merged_p2p_ielen = 0;
#endif /* CONFIG_P2P */
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
#ifdef CONFIG_P2P
_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211)
rtw_cfg80211_rx_p2p_action_public(padapter, precv_frame);
else
#endif /* CONFIG_IOCTL_CFG80211 */
{
/* Do nothing if the driver doesn't enable the P2P function. */
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
return _SUCCESS;
len -= sizeof(struct rtw_ieee80211_hdr_3addr);
switch (frame_body[6]) { /* OUI Subtype */
case P2P_GO_NEGO_REQ: {
RTW_INFO("[%s] Got GO Nego Req Frame\n", __FUNCTION__);
_rtw_memset(&pwdinfo->groupid_info, 0x00, sizeof(struct group_id_info));
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ))
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL)) {
/* Commented by Albert 20110526 */
/* In this case, this means the previous nego fail doesn't be reset yet. */
_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
/* Restore the previous p2p state */
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
RTW_INFO("[%s] Restore the previous p2p state to %d\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
}
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(padapter, _FW_LINKED))
_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
#endif /* CONFIG_CONCURRENT_MODE */
/* Commented by Kurt 20110902 */
/* Add if statement to avoid receiving duplicate prov disc req. such that pre_p2p_state would be covered. */
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING))
rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
/* Commented by Kurt 20120113 */
/* Get peer_dev_addr here if peer doesn't issue prov_disc frame. */
if (_rtw_memcmp(pwdinfo->rx_prov_disc_info.peerDevAddr, empty_addr, ETH_ALEN))
_rtw_memcpy(pwdinfo->rx_prov_disc_info.peerDevAddr, get_addr2_ptr(pframe), ETH_ALEN);
result = process_p2p_group_negotation_req(pwdinfo, frame_body, len);
issue_p2p_GO_response(padapter, get_addr2_ptr(pframe), frame_body, len, result);
/* Commented by Albert 20110718 */
/* No matter negotiating or negotiation failure, the driver should set up the restore P2P state timer. */
#ifdef CONFIG_CONCURRENT_MODE
/* Commented by Albert 20120107 */
_set_timer(&pwdinfo->restore_p2p_state_timer, 3000);
#else /* CONFIG_CONCURRENT_MODE */
_set_timer(&pwdinfo->restore_p2p_state_timer, 5000);
#endif /* CONFIG_CONCURRENT_MODE */
break;
}
case P2P_GO_NEGO_RESP: {
RTW_INFO("[%s] Got GO Nego Resp Frame\n", __FUNCTION__);
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING)) {
/* Commented by Albert 20110425 */
/* The restore timer is enabled when issuing the nego request frame of rtw_p2p_connect function. */
_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
pwdinfo->nego_req_info.benable = _FALSE;
result = process_p2p_group_negotation_resp(pwdinfo, frame_body, len);
issue_p2p_GO_confirm(pwdinfo->padapter, get_addr2_ptr(pframe), result);
if (P2P_STATUS_SUCCESS == result) {
if (rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT) {
pwdinfo->p2p_info.operation_ch[0] = pwdinfo->peer_operating_ch;
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->p2p_info.operation_ch[1] = 1; /* Check whether GO is operating in channel 1; */
pwdinfo->p2p_info.operation_ch[2] = 6; /* Check whether GO is operating in channel 6; */
pwdinfo->p2p_info.operation_ch[3] = 11; /* Check whether GO is operating in channel 11; */
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->p2p_info.scan_op_ch_only = 1;
_set_timer(&pwdinfo->reset_ch_sitesurvey2, P2P_RESET_SCAN_CH);
}
}
/* Reset the dialog token for group negotiation frames. */
pwdinfo->negotiation_dialog_token = 1;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
_set_timer(&pwdinfo->restore_p2p_state_timer, 5000);
} else
RTW_INFO("[%s] Skipped GO Nego Resp Frame (p2p_state != P2P_STATE_GONEGO_ING)\n", __FUNCTION__);
break;
}
case P2P_GO_NEGO_CONF: {
RTW_INFO("[%s] Got GO Nego Confirm Frame\n", __FUNCTION__);
result = process_p2p_group_negotation_confirm(pwdinfo, frame_body, len);
if (P2P_STATUS_SUCCESS == result) {
if (rtw_p2p_role(pwdinfo) == P2P_ROLE_CLIENT) {
pwdinfo->p2p_info.operation_ch[0] = pwdinfo->peer_operating_ch;
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->p2p_info.operation_ch[1] = 1; /* Check whether GO is operating in channel 1; */
pwdinfo->p2p_info.operation_ch[2] = 6; /* Check whether GO is operating in channel 6; */
pwdinfo->p2p_info.operation_ch[3] = 11; /* Check whether GO is operating in channel 11; */
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->p2p_info.scan_op_ch_only = 1;
_set_timer(&pwdinfo->reset_ch_sitesurvey2, P2P_RESET_SCAN_CH);
}
}
break;
}
case P2P_INVIT_REQ: {
/* Added by Albert 2010/10/05 */
/* Received the P2P Invite Request frame. */
RTW_INFO("[%s] Got invite request frame!\n", __FUNCTION__);
p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
if (p2p_ie) {
/* Parse the necessary information from the P2P Invitation Request frame. */
/* For example: The MAC address of sending this P2P Invitation Request frame. */
u32 attr_contentlen = 0;
u8 status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
struct group_id_info group_id;
u8 invitation_flag = 0;
merged_p2p_ielen = rtw_get_p2p_merged_ies_len(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_);
merged_p2pie = rtw_zmalloc(merged_p2p_ielen + 2); /* 2 is for EID and Length */
if (merged_p2pie == NULL) {
RTW_INFO("[%s] Malloc p2p ie fail\n", __FUNCTION__);
goto exit;
}
_rtw_memset(merged_p2pie, 0x00, merged_p2p_ielen);
merged_p2p_ielen = rtw_p2p_merge_ies(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, merged_p2pie);
rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_INVITATION_FLAGS, &invitation_flag, &attr_contentlen);
if (attr_contentlen) {
rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_BSSID, pwdinfo->p2p_peer_interface_addr, &attr_contentlen);
/* Commented by Albert 20120510 */
/* Copy to the pwdinfo->p2p_peer_interface_addr. */
/* So that the WFD UI ( or Sigma ) can get the peer interface address by using the following command. */
/* #> iwpriv wlan0 p2p_get peer_ifa */
/* After having the peer interface address, the sigma can find the correct conf file for wpa_supplicant. */
if (attr_contentlen) {
RTW_INFO("[%s] GO's BSSID = %.2X %.2X %.2X %.2X %.2X %.2X\n", __FUNCTION__,
pwdinfo->p2p_peer_interface_addr[0], pwdinfo->p2p_peer_interface_addr[1],
pwdinfo->p2p_peer_interface_addr[2], pwdinfo->p2p_peer_interface_addr[3],
pwdinfo->p2p_peer_interface_addr[4], pwdinfo->p2p_peer_interface_addr[5]);
}
if (invitation_flag & P2P_INVITATION_FLAGS_PERSISTENT) {
/* Re-invoke the persistent group. */
_rtw_memset(&group_id, 0x00, sizeof(struct group_id_info));
rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_ID, (u8 *) &group_id, &attr_contentlen);
if (attr_contentlen) {
if (_rtw_memcmp(group_id.go_device_addr, adapter_mac_addr(padapter), ETH_ALEN)) {
/* The p2p device sending this p2p invitation request wants this Wi-Fi device to be the persistent GO. */
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_GO);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
status_code = P2P_STATUS_SUCCESS;
} else {
/* The p2p device sending this p2p invitation request wants to be the persistent GO. */
if (is_matched_in_profilelist(pwdinfo->p2p_peer_interface_addr, &pwdinfo->profileinfo[0])) {
u8 operatingch_info[5] = { 0x00 };
if (rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info,
&attr_contentlen)) {
if (rtw_chset_search_ch(adapter_to_chset(padapter), (u32)operatingch_info[4]) >= 0) {
/* The operating channel is acceptable for this device. */
pwdinfo->rx_invitereq_info.operation_ch[0] = operatingch_info[4];
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->rx_invitereq_info.operation_ch[1] = 1; /* Check whether GO is operating in channel 1; */
pwdinfo->rx_invitereq_info.operation_ch[2] = 6; /* Check whether GO is operating in channel 6; */
pwdinfo->rx_invitereq_info.operation_ch[3] = 11; /* Check whether GO is operating in channel 11; */
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->rx_invitereq_info.scan_op_ch_only = 1;
_set_timer(&pwdinfo->reset_ch_sitesurvey, P2P_RESET_SCAN_CH);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_MATCH);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
status_code = P2P_STATUS_SUCCESS;
} else {
/* The operating channel isn't supported by this device. */
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
status_code = P2P_STATUS_FAIL_NO_COMMON_CH;
_set_timer(&pwdinfo->restore_p2p_state_timer, 3000);
}
} else {
/* Commented by Albert 20121130 */
/* Intel will use the different P2P IE to store the operating channel information */
/* Workaround for Intel WiDi 3.5 */
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_MATCH);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
status_code = P2P_STATUS_SUCCESS;
}
} else {
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH);
status_code = P2P_STATUS_FAIL_UNKNOWN_P2PGROUP;
}
}
} else {
RTW_INFO("[%s] P2P Group ID Attribute NOT FOUND!\n", __FUNCTION__);
status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
}
} else {
/* Received the invitation to join a P2P group. */
_rtw_memset(&group_id, 0x00, sizeof(struct group_id_info));
rtw_get_p2p_attr_content(merged_p2pie, merged_p2p_ielen, P2P_ATTR_GROUP_ID, (u8 *) &group_id, &attr_contentlen);
if (attr_contentlen) {
if (_rtw_memcmp(group_id.go_device_addr, adapter_mac_addr(padapter), ETH_ALEN)) {
/* In this case, the GO can't be myself. */
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_DISMATCH);
status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
} else {
/* The p2p device sending this p2p invitation request wants to join an existing P2P group */
/* Commented by Albert 2012/06/28 */
/* In this case, this Wi-Fi device should use the iwpriv command to get the peer device address. */
/* The peer device address should be the destination address for the provisioning discovery request. */
/* Then, this Wi-Fi device should use the iwpriv command to get the peer interface address. */
/* The peer interface address should be the address for WPS mac address */
_rtw_memcpy(pwdinfo->p2p_peer_device_addr, group_id.go_device_addr , ETH_ALEN);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RECV_INVITE_REQ_JOIN);
status_code = P2P_STATUS_SUCCESS;
}
} else {
RTW_INFO("[%s] P2P Group ID Attribute NOT FOUND!\n", __FUNCTION__);
status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
}
}
} else {
RTW_INFO("[%s] P2P Invitation Flags Attribute NOT FOUND!\n", __FUNCTION__);
status_code = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
}
RTW_INFO("[%s] status_code = %d\n", __FUNCTION__, status_code);
pwdinfo->inviteresp_info.token = frame_body[7];
issue_p2p_invitation_response(padapter, get_addr2_ptr(pframe), pwdinfo->inviteresp_info.token, status_code);
_set_timer(&pwdinfo->restore_p2p_state_timer, 3000);
}
break;
}
case P2P_INVIT_RESP: {
u8 attr_content = 0x00;
u32 attr_contentlen = 0;
RTW_INFO("[%s] Got invite response frame!\n", __FUNCTION__);
_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
if (p2p_ie) {
rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
if (attr_contentlen == 1) {
RTW_INFO("[%s] Status = %d\n", __FUNCTION__, attr_content);
pwdinfo->invitereq_info.benable = _FALSE;
if (attr_content == P2P_STATUS_SUCCESS) {
if (_rtw_memcmp(pwdinfo->invitereq_info.go_bssid, adapter_mac_addr(padapter), ETH_ALEN))
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
else
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_OK);
} else {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL);
}
} else {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL);
}
} else {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL);
}
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_INVITE_RESP_FAIL))
_set_timer(&pwdinfo->restore_p2p_state_timer, 5000);
break;
}
case P2P_DEVDISC_REQ:
process_p2p_devdisc_req(pwdinfo, pframe, len);
break;
case P2P_DEVDISC_RESP:
process_p2p_devdisc_resp(pwdinfo, pframe, len);
break;
case P2P_PROVISION_DISC_REQ:
RTW_INFO("[%s] Got Provisioning Discovery Request Frame\n", __FUNCTION__);
process_p2p_provdisc_req(pwdinfo, pframe, len);
_rtw_memcpy(pwdinfo->rx_prov_disc_info.peerDevAddr, get_addr2_ptr(pframe), ETH_ALEN);
/* 20110902 Kurt */
/* Add the following statement to avoid receiving duplicate prov disc req. such that pre_p2p_state would be covered. */
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ))
rtw_p2p_set_pre_state(pwdinfo, rtw_p2p_state(pwdinfo));
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ);
_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
break;
case P2P_PROVISION_DISC_RESP:
/* Commented by Albert 20110707 */
/* Should we check the pwdinfo->tx_prov_disc_info.bsent flag here?? */
RTW_INFO("[%s] Got Provisioning Discovery Response Frame\n", __FUNCTION__);
/* Commented by Albert 20110426 */
/* The restore timer is enabled when issuing the provisioing request frame in rtw_p2p_prov_disc function. */
_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_RSP);
process_p2p_provdisc_resp(pwdinfo, pframe);
_set_timer(&pwdinfo->restore_p2p_state_timer, P2P_PROVISION_TIMEOUT);
break;
}
}
exit:
if (merged_p2pie)
rtw_mfree(merged_p2pie, merged_p2p_ielen + 2);
#endif /* CONFIG_P2P */
return _SUCCESS;
}
unsigned int on_action_public_vendor(union recv_frame *precv_frame)
{
unsigned int ret = _FAIL;
u8 *pframe = precv_frame->u.hdr.rx_data;
u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
if (_rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE) {
if (rtw_action_public_decache(precv_frame, 7) == _FAIL)
goto exit;
if (!hal_chk_wl_func(precv_frame->u.hdr.adapter, WL_FUNC_MIRACAST))
rtw_rframe_del_wfd_ie(precv_frame, 8);
ret = on_action_public_p2p(precv_frame);
}
exit:
return ret;
}
unsigned int on_action_public_default(union recv_frame *precv_frame, u8 action)
{
unsigned int ret = _FAIL;
u8 *pframe = precv_frame->u.hdr.rx_data;
u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
u8 token;
_adapter *adapter = precv_frame->u.hdr.adapter;
int cnt = 0;
char msg[64];
token = frame_body[2];
if (rtw_action_public_decache(precv_frame, 2) == _FAIL)
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
cnt += sprintf((msg + cnt), "%s(token:%u)", action_public_str(action), token);
rtw_cfg80211_rx_action(adapter, precv_frame, msg);
#endif
ret = _SUCCESS;
exit:
return ret;
}
unsigned int on_action_public(_adapter *padapter, union recv_frame *precv_frame)
{
unsigned int ret = _FAIL;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint frame_len = precv_frame->u.hdr.len;
u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
u8 category, action;
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
goto exit;
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_PUBLIC)
goto exit;
action = frame_body[1];
switch (action) {
case ACT_PUBLIC_BSSCOEXIST:
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_AP_MODE
/*20/40 BSS Coexistence Management frame is a Public Action frame*/
if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
rtw_process_public_act_bsscoex(padapter, pframe, frame_len);
#endif /*CONFIG_AP_MODE*/
#endif /*CONFIG_80211N_HT*/
break;
case ACT_PUBLIC_VENDOR:
ret = on_action_public_vendor(precv_frame);
break;
default:
ret = on_action_public_default(precv_frame, action);
break;
}
exit:
return ret;
}
#if defined(CONFIG_RTW_WNM) || defined(CONFIG_RTW_80211K)
static u8 rtw_wnm_nb_elem_parsing(
u8* pdata, u32 data_len, u8 from_btm,
u32 *nb_rpt_num, u8 *nb_rpt_is_same,
struct roam_nb_info *pnb, struct wnm_btm_cant *pcandidates)
{
u8 bfound = _FALSE, ret = _SUCCESS;
u8 *ptr, *pend, *op;
u32 elem_len, subelem_len, op_len;
u32 i, nb_rpt_entries = 0;
struct nb_rpt_hdr *pie;
struct wnm_btm_cant *pcandidate;
if ((!pdata) || (!pnb))
return _FAIL;
if ((from_btm) && (!pcandidates))
return _FAIL;
ptr = pdata;
pend = ptr + data_len;
elem_len = data_len;
subelem_len = (u32)*(pdata+1);
for (i=0; i < RTW_MAX_NB_RPT_NUM; i++) {
if (((ptr + 7) > pend) || (elem_len < subelem_len))
break;
if (*ptr != 0x34) {
RTW_ERR("WNM: invalid data(0x%2x)!\n", *ptr);
ret = _FAIL;
break;
}
pie = (struct nb_rpt_hdr *)ptr;
if (from_btm) {
op = rtw_get_ie((u8 *)(ptr+15),
WNM_BTM_CAND_PREF_SUBEID,
&op_len, (subelem_len - 15));
}
ptr = (u8 *)(ptr + subelem_len + 2);
elem_len -= (subelem_len +2);
subelem_len = *(ptr+1);
if (from_btm) {
pcandidate = (pcandidates + i);
_rtw_memcpy(&pcandidate->nb_rpt, pie, sizeof(struct nb_rpt_hdr));
if (op && (op_len !=0)) {
pcandidate->preference = *(op + 2);
bfound = _TRUE;
} else
pcandidate->preference = 0;
RTW_DBG("WNM: preference check bssid("MAC_FMT
") ,bss_info(0x%04X), reg_class(0x%02X), ch(%d),"
" phy_type(0x%02X), preference(0x%02X)\n",
MAC_ARG(pcandidate->nb_rpt.bssid), pcandidate->nb_rpt.bss_info,
pcandidate->nb_rpt.reg_class, pcandidate->nb_rpt.ch_num,
pcandidate->nb_rpt.phy_type, pcandidate->preference);
} else {
if (_rtw_memcmp(&pnb->nb_rpt[i], pie, sizeof(struct nb_rpt_hdr)) == _FALSE)
*nb_rpt_is_same = _FALSE;
_rtw_memcpy(&pnb->nb_rpt[i], pie, sizeof(struct nb_rpt_hdr));
}
nb_rpt_entries++;
}
if (from_btm)
pnb->preference_en = (bfound)?_TRUE:_FALSE;
*nb_rpt_num = nb_rpt_entries;
return ret;
}
/* selection sorting based on preference value
* : nb_rpt_entries - candidate num
* / : pcandidates - candidate list
* return : TRUE - means pcandidates is updated.
*/
static u8 rtw_wnm_candidates_sorting(
u32 nb_rpt_entries, struct wnm_btm_cant *pcandidates)
{
u8 updated = _FALSE;
u32 i, j, pos;
struct wnm_btm_cant swap;
struct wnm_btm_cant *pcant_1, *pcant_2;
if ((!nb_rpt_entries) || (!pcandidates))
return updated;
for (i=0; i < (nb_rpt_entries - 1); i++) {
pos = i;
for (j=(i + 1); j < nb_rpt_entries; j++) {
pcant_1 = pcandidates+pos;
pcant_2 = pcandidates+j;
if ((pcant_1->preference) < (pcant_2->preference))
pos = j;
}
if (pos != i) {
updated = _TRUE;
_rtw_memcpy(&swap, (pcandidates+i), sizeof(struct wnm_btm_cant));
_rtw_memcpy((pcandidates+i), (pcandidates+pos), sizeof(struct wnm_btm_cant));
_rtw_memcpy((pcandidates+pos), &swap, sizeof(struct wnm_btm_cant));
}
}
return updated;
}
static void rtw_wnm_nb_info_update(
u32 nb_rpt_entries, u8 from_btm,
struct roam_nb_info *pnb, struct wnm_btm_cant *pcandidates,
u8 *nb_rpt_is_same)
{
u8 is_found;
u32 i, j;
struct wnm_btm_cant *pcand;
if (!pnb)
return;
pnb->nb_rpt_ch_list_num = 0;
for (i=0; inb_rpt[i], &pcand->nb_rpt,
sizeof(struct nb_rpt_hdr)) == _FALSE)
*nb_rpt_is_same = _FALSE;
_rtw_memcpy(&pnb->nb_rpt[i], &pcand->nb_rpt, sizeof(struct nb_rpt_hdr));
}
RTW_DBG("WNM: bssid(" MAC_FMT
") , bss_info(0x%04X), reg_class(0x%02X), ch_num(%d), phy_type(0x%02X)\n",
MAC_ARG(pnb->nb_rpt[i].bssid), pnb->nb_rpt[i].bss_info,
pnb->nb_rpt[i].reg_class, pnb->nb_rpt[i].ch_num,
pnb->nb_rpt[i].phy_type);
if (pnb->nb_rpt[i].ch_num == 0)
continue;
for (j=0; jnb_rpt[i].ch_num == pnb->nb_rpt_ch_list[j].hw_value) {
is_found = _TRUE;
break;
}
}
if (!is_found) {
pnb->nb_rpt_ch_list[pnb->nb_rpt_ch_list_num].hw_value = pnb->nb_rpt[i].ch_num;
pnb->nb_rpt_ch_list_num++;
}
}
}
static void rtw_wnm_btm_candidate_select(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
struct wlan_network *pnetwork;
u8 bfound = _FALSE;
u32 i;
for (i = 0; i < pnb->last_nb_rpt_entries; i++) {
pnetwork = rtw_find_network(
&(pmlmepriv->scanned_queue),
pnb->nb_rpt[i].bssid);
if (pnetwork) {
bfound = _TRUE;
break;
}
}
if (bfound) {
_rtw_memcpy(pnb->roam_target_addr, pnb->nb_rpt[i].bssid, ETH_ALEN);
RTW_INFO("WNM : select btm entry(%d) - %s("MAC_FMT", ch%u) rssi:%d\n"
, i
, pnetwork->network.Ssid.Ssid
, MAC_ARG(pnetwork->network.MacAddress)
, pnetwork->network.Configuration.DSConfig
, (int)pnetwork->network.Rssi);
} else
_rtw_memset(pnb->roam_target_addr,0, ETH_ALEN);
}
u32 rtw_wnm_btm_candidates_survey(
_adapter *padapter, u8* pframe, u32 elem_len, u8 from_btm)
{
struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
struct wnm_btm_cant *pcandidate_list = NULL;
u8 nb_rpt_is_same = _TRUE;
u32 ret = _FAIL;
u32 nb_rpt_entries = 0;
if (from_btm) {
u32 mlen = sizeof(struct wnm_btm_cant) * RTW_MAX_NB_RPT_NUM;
pcandidate_list = (struct wnm_btm_cant *)rtw_malloc(mlen);
if (pcandidate_list == NULL)
goto exit;
}
/*clean the status set last time*/
_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
pnb->nb_rpt_valid = _FALSE;
if (!rtw_wnm_nb_elem_parsing(
pframe, elem_len, from_btm,
&nb_rpt_entries, &nb_rpt_is_same,
pnb, pcandidate_list))
goto exit;
if (nb_rpt_entries != 0) {
if ((from_btm) && (rtw_wnm_btm_preference_cap(padapter)))
rtw_wnm_candidates_sorting(nb_rpt_entries, pcandidate_list);
rtw_wnm_nb_info_update(
nb_rpt_entries, from_btm,
pnb, pcandidate_list, &nb_rpt_is_same);
}
RTW_INFO("nb_rpt_is_same = %d, nb_rpt_entries = %d, last_nb_rpt_entries = %d\n",
nb_rpt_is_same, nb_rpt_entries, pnb->last_nb_rpt_entries);
if ((nb_rpt_is_same == _TRUE) && (nb_rpt_entries == pnb->last_nb_rpt_entries))
pnb->nb_rpt_is_same = _TRUE;
else {
pnb->nb_rpt_is_same = _FALSE;
pnb->last_nb_rpt_entries = nb_rpt_entries;
}
if ((from_btm) && (nb_rpt_entries != 0))
rtw_wnm_btm_candidate_select(padapter);
pnb->nb_rpt_valid = _TRUE;
ret = _SUCCESS;
exit:
if (from_btm && pcandidate_list)
rtw_mfree((u8 *)pcandidate_list, sizeof(struct wnm_btm_cant) * RTW_MAX_NB_RPT_NUM);
return ret;
}
#endif
unsigned int OnAction_ft(_adapter *padapter, union recv_frame *precv_frame)
{
#ifdef CONFIG_RTW_80211R
u32 ret = _FAIL;
u32 frame_len = 0;
u8 action_code = 0;
u8 category = 0;
u8 *pframe = NULL;
u8 *pframe_body = NULL;
u8 sta_addr[ETH_ALEN] = {0};
u8 *pie = NULL;
u32 ft_ie_len = 0;
u32 status_code = 0;
struct mlme_ext_priv *pmlmeext = NULL;
struct mlme_ext_info *pmlmeinfo = NULL;
struct mlme_priv *pmlmepriv = NULL;
struct wlan_network *proam_target = NULL;
struct ft_roam_info *pft_roam = NULL;
_irqL irqL;
pmlmeext = &(padapter->mlmeextpriv);
pmlmeinfo = &(pmlmeext->mlmext_info);
pmlmepriv = &(padapter->mlmepriv);
pft_roam = &(pmlmepriv->ft_roam);
pframe = precv_frame->u.hdr.rx_data;
frame_len = precv_frame->u.hdr.len;
pframe_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
category = pframe_body[0];
if (category != RTW_WLAN_CATEGORY_FT)
goto exit;
action_code = pframe_body[1];
switch (action_code) {
case RTW_WLAN_ACTION_FT_RSP:
RTW_INFO("FT: RTW_WLAN_ACTION_FT_RSP recv.\n");
if (!_rtw_memcmp(adapter_mac_addr(padapter), &pframe_body[2], ETH_ALEN)) {
RTW_ERR("FT: Unmatched STA MAC Address "MAC_FMT"\n", MAC_ARG(&pframe_body[2]));
goto exit;
}
status_code = le16_to_cpu(*(u16 *)((SIZE_PTR)pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + 14));
if (status_code != 0) {
RTW_ERR("FT: WLAN ACTION FT RESPONSE fail, status: %d\n", status_code);
goto exit;
}
if (is_zero_mac_addr(&pframe_body[8]) || is_broadcast_mac_addr(&pframe_body[8])) {
RTW_ERR("FT: Invalid Target MAC Address "MAC_FMT"\n", MAC_ARG(padapter->mlmepriv.roam_tgt_addr));
goto exit;
}
pie = rtw_get_ie(pframe_body, _MDIE_, &ft_ie_len, frame_len);
if (pie) {
if (!_rtw_memcmp(&pft_roam->mdid, pie+2, 2)) {
RTW_ERR("FT: Invalid MDID\n");
goto exit;
}
}
rtw_ft_set_status(padapter, RTW_FT_REQUESTED_STA);
_cancel_timer_ex(&pmlmeext->ft_link_timer);
/*Disconnect current AP*/
receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress, WLAN_REASON_ACTIVE_ROAM, _FALSE);
pft_roam->ft_action_len = frame_len;
_rtw_memcpy(pft_roam->ft_action, pframe, rtw_min(frame_len, RTW_FT_MAX_IE_SZ));
ret = _SUCCESS;
break;
case RTW_WLAN_ACTION_FT_REQ:
case RTW_WLAN_ACTION_FT_CONF:
case RTW_WLAN_ACTION_FT_ACK:
default:
RTW_ERR("FT: Unsupported FT Action!\n");
break;
}
exit:
return ret;
#else
return _SUCCESS;
#endif
}
#ifdef CONFIG_RTW_WNM
u8 rtw_wmn_btm_rsp_reason_decision(_adapter *padapter, u8* req_mode)
{
struct recv_priv *precvpriv = &padapter->recvpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 reason = 0;
if (!rtw_wnm_btm_diff_bss(padapter)) {
/* Reject - No suitable BSS transition candidates */
reason = 7;
goto candidate_remove;
}
#ifdef CONFIG_RTW_80211R
if (rtw_ft_chk_flags(padapter, RTW_FT_BTM_ROAM)) {
/* Accept */
reason = 0;
goto under_survey;
}
#endif
if (((*req_mode) & DISASSOC_IMMINENT) == 0) {
/* Reject - Unspecified reject reason */
reason = 1;
goto candidate_remove;
}
if (precvpriv->signal_strength_data.avg_val >= pmlmepriv->roam_rssi_threshold) {
reason = 1;
goto candidate_remove;
}
under_survey:
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
RTW_INFO("%s reject due to _FW_UNDER_SURVEY\n", __func__);
reason = 1;
}
candidate_remove:
if (reason !=0)
rtw_wnm_reset_btm_candidate(&padapter->mlmepriv.nb_info);
return reason;
}
static u32 rtw_wnm_btm_candidates_offset_get(u8* pframe)
{
u8 *pos = pframe;
u32 offset = 0;
if (!pframe)
return 0;
offset += 7;
pos += offset;
/* BSS Termination Duration check */
if (wnm_btm_bss_term_inc(pframe)) {
offset += 12;
pos += offset;
}
/* Session Information URL check*/
if (wnm_btm_ess_disassoc_im(pframe)) {
/*URL length field + URL variable length*/
offset = 1 + *(pframe + offset);
pos += offset;
}
offset = (pos - pframe);
return offset;
}
static void rtw_wnm_btm_req_hdr_parsing(u8* pframe, struct btm_req_hdr *phdr)
{
u8 *pos = pframe;
u32 offset = 0;
if (!pframe || !phdr)
return;
_rtw_memset(phdr, 0, sizeof(struct btm_req_hdr));
phdr->req_mode = wnm_btm_req_mode(pframe);
phdr->disassoc_timer = wnm_btm_disassoc_timer(pframe);
phdr->validity_interval = wnm_btm_valid_interval(pframe);
if (wnm_btm_bss_term_inc(pframe)) {
_rtw_memcpy(&phdr->term_duration,
wnm_btm_term_duration_offset(pframe),
sizeof(struct btm_term_duration));
}
RTW_DBG("WNM: req_mode(%1x), disassoc_timer(%02x), interval(%x)\n",
phdr->req_mode, phdr->disassoc_timer, phdr->validity_interval);
if (wnm_btm_bss_term_inc(pframe))
RTW_INFO("WNM: tsf(%llx), duration(%2x)\n",
phdr->term_duration.tsf, phdr->term_duration.duration);
}
void rtw_wnm_roam_scan_hdl(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
if (rtw_is_scan_deny(padapter))
RTW_INFO("WNM: roam scan would abort by scan_deny!\n");
pmlmepriv->need_to_roam = _TRUE;
rtw_drv_scan_by_self(padapter, RTW_AUTO_SCAN_REASON_ROAM);
}
static void rtw_wnm_roam_scan(_adapter *padapter)
{
struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
if (rtw_is_scan_deny(padapter)) {
_cancel_timer_ex(&pnb->roam_scan_timer);
_set_timer(&pnb->roam_scan_timer, 1000);
} else
rtw_wnm_roam_scan_hdl((void *)padapter);
}
void rtw_wnm_process_btm_req(_adapter *padapter, u8* pframe, u32 frame_len)
{
struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
struct btm_req_hdr req_hdr;
u8 *ptr, reason;
u32 elem_len, offset;
rtw_wnm_btm_req_hdr_parsing(pframe, &req_hdr);
offset = rtw_wnm_btm_candidates_offset_get(pframe);
if ((offset == 0) || ((frame_len - offset) <= 15))
return;
ptr = (pframe + offset);
elem_len = (frame_len - offset);
rtw_wnm_btm_candidates_survey(padapter, ptr, elem_len, _TRUE);
reason = rtw_wmn_btm_rsp_reason_decision(padapter, &pframe[3]);
rtw_wnm_issue_action(padapter,
RTW_WLAN_ACTION_WNM_BTM_RSP, reason);
if (reason == 0)
rtw_wnm_roam_scan(padapter);
}
void rtw_wnm_reset_btm_candidate(struct roam_nb_info *pnb)
{
pnb->preference_en = _FALSE;
_rtw_memset(pnb->roam_target_addr, 0, ETH_ALEN);
}
void rtw_wnm_reset_btm_state(_adapter *padapter)
{
struct roam_nb_info *pnb = &(padapter->mlmepriv.nb_info);
pnb->last_nb_rpt_entries = 0;
pnb->nb_rpt_is_same = _TRUE;
pnb->nb_rpt_valid = _FALSE;
pnb->nb_rpt_ch_list_num = 0;
rtw_wnm_reset_btm_candidate(pnb);
_rtw_memset(&pnb->nb_rpt, 0, sizeof(pnb->nb_rpt));
_rtw_memset(&pnb->nb_rpt_ch_list, 0, sizeof(pnb->nb_rpt_ch_list));
}
void rtw_wnm_issue_action(_adapter *padapter, u8 action, u8 reason)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct xmit_frame *pmgntframe;
struct rtw_ieee80211_hdr *pwlanhdr;
struct pkt_attrib *pattrib;
u8 category, dialog_token, termination_delay, *pframe;
u16 *fctrl;
if ((pmgntframe = alloc_mgtxmitframe(pxmitpriv)) == NULL)
return ;
pattrib = &(pmgntframe->attrib);
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, (WLANHDR_OFFSET + TXDESC_OFFSET));
pframe = (u8 *)(pmgntframe->buf_addr + TXDESC_OFFSET);
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
category = RTW_WLAN_CATEGORY_WNM;
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
switch (action) {
case RTW_WLAN_ACTION_WNM_BTM_QUERY:
pframe = rtw_set_fixed_ie(pframe, 1, &(dialog_token), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(reason), &(pattrib->pktlen));
RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_QUERY sent.\n");
break;
case RTW_WLAN_ACTION_WNM_BTM_RSP:
termination_delay = 0;
pframe = rtw_set_fixed_ie(pframe, 1, &(dialog_token), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(reason), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(termination_delay), &(pattrib->pktlen));
if (!is_zero_mac_addr(pmlmepriv->nb_info.roam_target_addr)) {
pframe = rtw_set_fixed_ie(pframe, 6,
pmlmepriv->nb_info.roam_target_addr, &(pattrib->pktlen));
}
RTW_INFO("WNM: RTW_WLAN_ACTION_WNM_BTM_RSP sent. reason = %d\n", reason);
break;
default:
goto exit;
}
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
exit:
return;
}
#endif
unsigned int OnAction_ht(_adapter *padapter, union recv_frame *precv_frame)
{
u8 *pframe = precv_frame->u.hdr.rx_data;
u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
u8 category, action;
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
goto exit;
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_HT)
goto exit;
action = frame_body[1];
switch (action) {
case RTW_WLAN_ACTION_HT_SM_PS:
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_AP_MODE
if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE)
rtw_process_ht_action_smps(padapter, get_addr2_ptr(pframe), frame_body[2]);
#endif /*CONFIG_AP_MODE*/
#endif /*CONFIG_80211N_HT*/
break;
case RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING:
#ifdef CONFIG_BEAMFORMING
/*RTW_INFO("RTW_WLAN_ACTION_HT_COMPRESS_BEAMFORMING\n");*/
rtw_beamforming_get_report_frame(padapter, precv_frame);
#endif /*CONFIG_BEAMFORMING*/
break;
default:
break;
}
exit:
return _SUCCESS;
}
#ifdef CONFIG_IEEE80211W
unsigned int OnAction_sa_query(_adapter *padapter, union recv_frame *precv_frame)
{
u8 *pframe = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
u16 tid;
/* Baron */
RTW_INFO("OnAction_sa_query\n");
switch (pframe[WLAN_HDR_A3_LEN + 1]) {
case 0: /* SA Query req */
_rtw_memcpy(&tid, &pframe[WLAN_HDR_A3_LEN + 2], sizeof(u16));
RTW_INFO("OnAction_sa_query request,action=%d, tid=%04x, pframe=%02x-%02x\n"
, pframe[WLAN_HDR_A3_LEN + 1], tid, pframe[WLAN_HDR_A3_LEN + 2], pframe[WLAN_HDR_A3_LEN + 3]);
issue_action_SA_Query(padapter, get_addr2_ptr(pframe), 1, tid, IEEE80211W_RIGHT_KEY);
break;
case 1: /* SA Query rsp */
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta != NULL)
_cancel_timer_ex(&psta->dot11w_expire_timer);
_rtw_memcpy(&tid, &pframe[WLAN_HDR_A3_LEN + 2], sizeof(u16));
RTW_INFO("OnAction_sa_query response,action=%d, tid=%04x, cancel timer\n", pframe[WLAN_HDR_A3_LEN + 1], tid);
break;
default:
break;
}
if (0) {
int pp;
printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
for (pp = 0; pp < pattrib->pkt_len; pp++)
printk(" %02x ", pframe[pp]);
printk("\n");
}
return _SUCCESS;
}
#endif /* CONFIG_IEEE80211W */
unsigned int on_action_rm(_adapter *padapter, union recv_frame *precv_frame)
{
#ifdef CONFIG_RTW_80211K
return rm_on_action(padapter, precv_frame);
#else
return _SUCCESS;
#endif /* CONFIG_RTW_80211K */
}
unsigned int OnAction_wmm(_adapter *padapter, union recv_frame *precv_frame)
{
return _SUCCESS;
}
unsigned int OnAction_vht(_adapter *padapter, union recv_frame *precv_frame)
{
#ifdef CONFIG_80211AC_VHT
u8 *pframe = precv_frame->u.hdr.rx_data;
struct rtw_ieee80211_hdr_3addr *whdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
u8 *frame_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
u8 category, action;
struct sta_info *psta = NULL;
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
goto exit;
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_VHT)
goto exit;
action = frame_body[1];
switch (action) {
case RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING:
#ifdef CONFIG_BEAMFORMING
/*RTW_INFO("RTW_WLAN_ACTION_VHT_COMPRESSED_BEAMFORMING\n");*/
rtw_beamforming_get_report_frame(padapter, precv_frame);
#endif /*CONFIG_BEAMFORMING*/
break;
case RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION:
/* CategoryCode(1) + ActionCode(1) + OpModeNotification(1) */
/* RTW_INFO("RTW_WLAN_ACTION_VHT_OPMODE_NOTIFICATION\n"); */
psta = rtw_get_stainfo(&padapter->stapriv, whdr->addr2);
if (psta)
rtw_process_vht_op_mode_notify(padapter, &frame_body[2], psta);
break;
case RTW_WLAN_ACTION_VHT_GROUPID_MANAGEMENT:
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
rtw_beamforming_get_vht_gid_mgnt_frame(padapter, precv_frame);
#endif /* RTW_BEAMFORMING_VERSION_2 */
#endif /* CONFIG_BEAMFORMING */
break;
default:
break;
}
exit:
#endif /* CONFIG_80211AC_VHT */
return _SUCCESS;
}
unsigned int OnAction_p2p(_adapter *padapter, union recv_frame *precv_frame)
{
#ifdef CONFIG_P2P
u8 *frame_body;
u8 category, OUI_Subtype, dialogToken = 0;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint len = precv_frame->u.hdr.len;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(pframe), ETH_ALEN))
return _SUCCESS;
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
category = frame_body[0];
if (category != RTW_WLAN_CATEGORY_P2P)
return _SUCCESS;
if (cpu_to_be32(*((u32 *)(frame_body + 1))) != P2POUI)
return _SUCCESS;
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled
&& pwdinfo->driver_interface == DRIVER_CFG80211
) {
rtw_cfg80211_rx_action_p2p(padapter, precv_frame);
return _SUCCESS;
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
len -= sizeof(struct rtw_ieee80211_hdr_3addr);
OUI_Subtype = frame_body[5];
dialogToken = frame_body[6];
switch (OUI_Subtype) {
case P2P_NOTICE_OF_ABSENCE:
break;
case P2P_PRESENCE_REQUEST:
process_p2p_presence_req(pwdinfo, pframe, len);
break;
case P2P_PRESENCE_RESPONSE:
break;
case P2P_GO_DISC_REQUEST:
break;
default:
break;
}
}
#endif /* CONFIG_P2P */
return _SUCCESS;
}
unsigned int OnAction(_adapter *padapter, union recv_frame *precv_frame)
{
int i;
unsigned char category;
struct action_handler *ptable;
unsigned char *frame_body;
u8 *pframe = precv_frame->u.hdr.rx_data;
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
category = frame_body[0];
for (i = 0; i < sizeof(OnAction_tbl) / sizeof(struct action_handler); i++) {
ptable = &OnAction_tbl[i];
if (category == ptable->num)
ptable->func(padapter, precv_frame);
}
return _SUCCESS;
}
unsigned int DoReserved(_adapter *padapter, union recv_frame *precv_frame)
{
/* RTW_INFO("rcvd mgt frame(%x, %x)\n", (get_frame_sub_type(pframe) >> 4), *(unsigned int *)GetAddr1Ptr(pframe)); */
return _SUCCESS;
}
struct xmit_frame *_alloc_mgtxmitframe(struct xmit_priv *pxmitpriv, bool once)
{
struct xmit_frame *pmgntframe;
struct xmit_buf *pxmitbuf;
if (once)
pmgntframe = rtw_alloc_xmitframe_once(pxmitpriv);
else
pmgntframe = rtw_alloc_xmitframe_ext(pxmitpriv);
if (pmgntframe == NULL) {
RTW_INFO(FUNC_ADPT_FMT" alloc xmitframe fail, once:%d\n", FUNC_ADPT_ARG(pxmitpriv->adapter), once);
goto exit;
}
pxmitbuf = rtw_alloc_xmitbuf_ext(pxmitpriv);
if (pxmitbuf == NULL) {
RTW_INFO(FUNC_ADPT_FMT" alloc xmitbuf fail\n", FUNC_ADPT_ARG(pxmitpriv->adapter));
rtw_free_xmitframe(pxmitpriv, pmgntframe);
pmgntframe = NULL;
goto exit;
}
pmgntframe->frame_tag = MGNT_FRAMETAG;
pmgntframe->pxmitbuf = pxmitbuf;
pmgntframe->buf_addr = pxmitbuf->pbuf;
pxmitbuf->priv_data = pmgntframe;
exit:
return pmgntframe;
}
inline struct xmit_frame *alloc_mgtxmitframe(struct xmit_priv *pxmitpriv)
{
return _alloc_mgtxmitframe(pxmitpriv, _FALSE);
}
inline struct xmit_frame *alloc_mgtxmitframe_once(struct xmit_priv *pxmitpriv)
{
return _alloc_mgtxmitframe(pxmitpriv, _TRUE);
}
/****************************************************************************
Following are some TX fuctions for WiFi MLME
*****************************************************************************/
void update_mgnt_tx_rate(_adapter *padapter, u8 rate)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
pmlmeext->tx_rate = rate;
/* RTW_INFO("%s(): rate = %x\n",__FUNCTION__, rate); */
}
void update_monitor_frame_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 wireless_mode;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
psta = rtw_get_stainfo(pstapriv, pattrib->ra);
pattrib->hdrlen = 24;
pattrib->nr_frags = 1;
pattrib->priority = 7;
pattrib->mac_id = RTW_DEFAULT_MGMT_MACID;
pattrib->qsel = QSLT_MGNT;
pattrib->pktlen = 0;
if (pmlmeext->tx_rate == IEEE80211_CCK_RATE_1MB)
wireless_mode = WIRELESS_11B;
else
wireless_mode = WIRELESS_11G;
pattrib->raid = rtw_get_mgntframe_raid(padapter, wireless_mode);
#ifdef CONFIG_80211AC_VHT
if (pHalData->rf_type == RF_1T1R)
pattrib->raid = RATEID_IDX_VHT_1SS;
else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
pattrib->raid = RATEID_IDX_VHT_2SS;
else if (pHalData->rf_type == RF_3T3R)
pattrib->raid = RATEID_IDX_VHT_3SS;
else
pattrib->raid = RATEID_IDX_BGN_40M_1SS;
#endif
#ifdef CONFIG_80211AC_VHT
pattrib->rate = MGN_VHT1SS_MCS9;
#else
pattrib->rate = MGN_MCS7;
#endif
pattrib->encrypt = _NO_PRIVACY_;
pattrib->bswenc = _FALSE;
pattrib->qos_en = _FALSE;
pattrib->ht_en = 1;
pattrib->bwmode = CHANNEL_WIDTH_20;
pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
pattrib->sgi = _FALSE;
pattrib->seqnum = pmlmeext->mgnt_seq;
pattrib->retry_ctrl = _TRUE;
pattrib->mbssid = 0;
pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
}
void update_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
{
u8 wireless_mode;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
/* _rtw_memset((u8 *)(pattrib), 0, sizeof(struct pkt_attrib)); */
pattrib->hdrlen = 24;
pattrib->nr_frags = 1;
pattrib->priority = 7;
pattrib->mac_id = RTW_DEFAULT_MGMT_MACID;
pattrib->qsel = QSLT_MGNT;
#ifdef CONFIG_MCC_MODE
update_mcc_mgntframe_attrib(padapter, pattrib);
#endif
#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(padapter, WIFI_ASOC_STATE))
#endif /* CONFIG_CONCURRENT_MODE */
if (MLME_IS_GC(padapter)) {
if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
if (psta) {
/* use macid sleep during NoA, mgmt frame use ac queue & ap macid */
pattrib->mac_id = psta->cmn.mac_id;
pattrib->qsel = QSLT_VO;
} else {
if (pwdinfo->p2p_ps_state != P2P_PS_DISABLE)
RTW_ERR("%s , psta was NULL\n", __func__);
}
}
}
#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
pattrib->pktlen = 0;
if (IS_CCK_RATE(pmlmeext->tx_rate))
wireless_mode = WIRELESS_11B;
else
wireless_mode = WIRELESS_11G;
pattrib->raid = rtw_get_mgntframe_raid(padapter, wireless_mode);
pattrib->rate = pmlmeext->tx_rate;
pattrib->encrypt = _NO_PRIVACY_;
pattrib->bswenc = _FALSE;
pattrib->qos_en = _FALSE;
pattrib->ht_en = _FALSE;
pattrib->bwmode = CHANNEL_WIDTH_20;
pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
pattrib->sgi = _FALSE;
pattrib->seqnum = pmlmeext->mgnt_seq;
pattrib->retry_ctrl = _TRUE;
pattrib->mbssid = 0;
pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
}
void update_mgntframe_attrib_addr(_adapter *padapter, struct xmit_frame *pmgntframe)
{
u8 *pframe;
struct pkt_attrib *pattrib = &pmgntframe->attrib;
#if defined(CONFIG_BEAMFORMING) || defined(CONFIG_ANTENNA_DIVERSITY)
struct sta_info *sta = NULL;
#endif
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
_rtw_memcpy(pattrib->ra, GetAddr1Ptr(pframe), ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_addr2_ptr(pframe), ETH_ALEN);
#if defined(CONFIG_BEAMFORMING) || defined(CONFIG_ANTENNA_DIVERSITY)
sta = pattrib->psta;
if (!sta) {
sta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
pattrib->psta = sta;
}
#ifdef CONFIG_BEAMFORMING
if (sta)
update_attrib_txbf_info(padapter, pattrib, sta);
#endif
#endif /* defined(CONFIG_BEAMFORMING) || defined(CONFIG_ANTENNA_DIVERSITY) */
}
void dump_mgntframe(_adapter *padapter, struct xmit_frame *pmgntframe)
{
if (RTW_CANNOT_RUN(padapter)) {
rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
return;
}
rtw_hal_mgnt_xmit(padapter, pmgntframe);
}
s32 dump_mgntframe_and_wait(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)
{
s32 ret = _FAIL;
_irqL irqL;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct xmit_buf *pxmitbuf = pmgntframe->pxmitbuf;
struct submit_ctx sctx;
if (RTW_CANNOT_RUN(padapter)) {
rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
return ret;
}
rtw_sctx_init(&sctx, timeout_ms);
pxmitbuf->sctx = &sctx;
ret = rtw_hal_mgnt_xmit(padapter, pmgntframe);
if (ret == _SUCCESS)
ret = rtw_sctx_wait(&sctx, __func__);
_enter_critical(&pxmitpriv->lock_sctx, &irqL);
pxmitbuf->sctx = NULL;
_exit_critical(&pxmitpriv->lock_sctx, &irqL);
return ret;
}
s32 dump_mgntframe_and_wait_ack_timeout(_adapter *padapter, struct xmit_frame *pmgntframe, int timeout_ms)
{
#ifdef CONFIG_XMIT_ACK
static u8 seq_no = 0;
s32 ret = _FAIL;
struct xmit_priv *pxmitpriv = &(GET_PRIMARY_ADAPTER(padapter))->xmitpriv;
if (RTW_CANNOT_RUN(padapter)) {
rtw_free_xmitbuf(&padapter->xmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(&padapter->xmitpriv, pmgntframe);
return -1;
}
_enter_critical_mutex(&pxmitpriv->ack_tx_mutex, NULL);
pxmitpriv->ack_tx = _TRUE;
pxmitpriv->seq_no = seq_no++;
pmgntframe->ack_report = 1;
rtw_sctx_init(&(pxmitpriv->ack_tx_ops), timeout_ms);
if (rtw_hal_mgnt_xmit(padapter, pmgntframe) == _SUCCESS)
ret = rtw_sctx_wait(&(pxmitpriv->ack_tx_ops), __func__);
pxmitpriv->ack_tx = _FALSE;
_exit_critical_mutex(&pxmitpriv->ack_tx_mutex, NULL);
return ret;
#else /* !CONFIG_XMIT_ACK */
dump_mgntframe(padapter, pmgntframe);
rtw_msleep_os(50);
return _SUCCESS;
#endif /* !CONFIG_XMIT_ACK */
}
s32 dump_mgntframe_and_wait_ack(_adapter *padapter, struct xmit_frame *pmgntframe)
{
/* In this case, use 500 ms as the default wait_ack timeout */
return dump_mgntframe_and_wait_ack_timeout(padapter, pmgntframe, 500);
}
int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
{
u8 *ssid_ie;
sint ssid_len_ori;
int len_diff = 0;
ssid_ie = rtw_get_ie(ies, WLAN_EID_SSID, &ssid_len_ori, ies_len);
/* RTW_INFO("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n", __FUNCTION__, hidden_ssid_mode, ssid_ie, ssid_len_ori); */
if (ssid_ie && ssid_len_ori > 0) {
switch (hidden_ssid_mode) {
case 1: {
u8 *next_ie = ssid_ie + 2 + ssid_len_ori;
u32 remain_len = 0;
remain_len = ies_len - (next_ie - ies);
ssid_ie[1] = 0;
_rtw_memcpy(ssid_ie + 2, next_ie, remain_len);
len_diff -= ssid_len_ori;
break;
}
case 2:
_rtw_memset(&ssid_ie[2], 0, ssid_len_ori);
break;
default:
break;
}
}
return len_diff;
}
void issue_beacon(_adapter *padapter, int timeout_ms)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned int rate_len;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
_irqL irqL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
/* RTW_INFO("%s\n", __FUNCTION__); */
#ifdef CONFIG_BCN_ICF
pmgntframe = rtw_alloc_bcnxmitframe(pxmitpriv);
if (pmgntframe == NULL)
#else
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
#endif
{
RTW_INFO("%s, alloc mgnt frame fail\n", __FUNCTION__);
return;
}
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
_enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
pattrib->qsel = QSLT_BEACON;
#if defined(CONFIG_CONCURRENT_MODE) && (!defined(CONFIG_SWTIMER_BASED_TXBCN))
if (padapter->hw_port == HW_PORT1)
pattrib->mbssid = 1;
#endif
#ifdef CONFIG_FW_HANDLE_TXBCN
if (padapter->vap_id != CONFIG_LIMITED_AP_NUM)
pattrib->mbssid = padapter->vap_id;
#endif
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
/* pmlmeext->mgnt_seq++; */
set_frame_sub_type(pframe, WIFI_BEACON);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
#ifdef CONFIG_P2P
/* for P2P : Primary Device Type & Device Name */
u32 wpsielen = 0, insert_len = 0;
u8 *wpsie = NULL;
wpsie = rtw_get_wps_ie(cur_network->IEs + _FIXED_IE_LENGTH_, cur_network->IELength - _FIXED_IE_LENGTH_, NULL, &wpsielen);
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && wpsie && wpsielen > 0) {
uint wps_offset, remainder_ielen;
u8 *premainder_ie, *pframe_wscie;
wps_offset = (uint)(wpsie - cur_network->IEs);
premainder_ie = wpsie + wpsielen;
remainder_ielen = cur_network->IELength - wps_offset - wpsielen;
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
if (pmlmepriv->wps_beacon_ie && pmlmepriv->wps_beacon_ie_len > 0) {
_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
pframe += wps_offset;
pattrib->pktlen += wps_offset;
_rtw_memcpy(pframe, pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len);
pframe += pmlmepriv->wps_beacon_ie_len;
pattrib->pktlen += pmlmepriv->wps_beacon_ie_len;
/* copy remainder_ie to pframe */
_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
pframe += remainder_ielen;
pattrib->pktlen += remainder_ielen;
} else {
_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
pframe += cur_network->IELength;
pattrib->pktlen += cur_network->IELength;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
pframe_wscie = pframe + wps_offset;
_rtw_memcpy(pframe, cur_network->IEs, wps_offset + wpsielen);
pframe += (wps_offset + wpsielen);
pattrib->pktlen += (wps_offset + wpsielen);
/* now pframe is end of wsc ie, insert Primary Device Type & Device Name */
/* Primary Device Type */
/* Type: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
insert_len += 2;
/* Length: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(0x0008);
insert_len += 2;
/* Value: */
/* Category ID */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
insert_len += 2;
/* OUI */
*(u32 *)(pframe + insert_len) = cpu_to_be32(WPSOUI);
insert_len += 4;
/* Sub Category ID */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
insert_len += 2;
/* Device Name */
/* Type: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
insert_len += 2;
/* Length: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(pwdinfo->device_name_len);
insert_len += 2;
/* Value: */
_rtw_memcpy(pframe + insert_len, pwdinfo->device_name, pwdinfo->device_name_len);
insert_len += pwdinfo->device_name_len;
/* update wsc ie length */
*(pframe_wscie + 1) = (wpsielen - 2) + insert_len;
/* pframe move to end */
pframe += insert_len;
pattrib->pktlen += insert_len;
/* copy remainder_ie to pframe */
_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
pframe += remainder_ielen;
pattrib->pktlen += remainder_ielen;
}
} else
#endif /* CONFIG_P2P */
{
int len_diff;
_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
len_diff = update_hidden_ssid(
pframe + _BEACON_IE_OFFSET_
, cur_network->IELength - _BEACON_IE_OFFSET_
, pmlmeinfo->hidden_ssid_mode
);
pframe += (cur_network->IELength + len_diff);
pattrib->pktlen += (cur_network->IELength + len_diff);
}
{
u8 *wps_ie;
uint wps_ielen;
u8 sr = 0;
wps_ie = rtw_get_wps_ie(pmgntframe->buf_addr + TXDESC_OFFSET + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_,
pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_, NULL, &wps_ielen);
if (wps_ie && wps_ielen > 0)
rtw_get_wps_attr_content(wps_ie, wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
if (sr != 0)
set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
else
_clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
}
#ifdef CONFIG_RTW_80211K
pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_,
sizeof(padapter->rmpriv.rm_en_cap_def),
padapter->rmpriv.rm_en_cap_def, &pattrib->pktlen);
#endif
#ifdef CONFIG_P2P
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
u32 len;
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
len = pmlmepriv->p2p_beacon_ie_len;
if (pmlmepriv->p2p_beacon_ie && len > 0)
_rtw_memcpy(pframe, pmlmepriv->p2p_beacon_ie, len);
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
len = build_beacon_p2p_ie(pwdinfo, pframe);
}
pframe += len;
pattrib->pktlen += len;
#ifdef CONFIG_MCC_MODE
pframe = rtw_hal_mcc_append_go_p2p_ie(padapter, pframe, &pattrib->pktlen);
#endif /* CONFIG_MCC_MODE*/
#ifdef CONFIG_WFD
len = rtw_append_beacon_wfd_ie(padapter, pframe);
pframe += len;
pattrib->pktlen += len;
#endif
}
#endif /* CONFIG_P2P */
#ifdef CONFIG_RTW_REPEATER_SON
rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
#endif
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_BEACON_VENDOR_IE_BIT);
#endif
#ifdef CONFIG_RTL8812A
pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
#endif/*CONFIG_RTL8812A*/
goto _issue_bcn;
}
/* below for ad-hoc mode */
/* timestamp will be inserted by hardware */
pframe += 8;
pattrib->pktlen += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
pframe += 2;
pattrib->pktlen += 2;
/* capability info: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
pframe += 2;
pattrib->pktlen += 2;
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pattrib->pktlen);
/* supported rates... */
rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pattrib->pktlen);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pattrib->pktlen);
/* if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) */
{
u8 erpinfo = 0;
u32 ATIMWindow;
/* IBSS Parameter Set... */
/* ATIMWindow = cur->Configuration.ATIMWindow; */
ATIMWindow = 0;
pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pattrib->pktlen);
/* ERP IE */
pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pattrib->pktlen);
}
/* EXTERNDED SUPPORTED RATE */
if (rate_len > 8)
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pattrib->pktlen);
/* todo:HT for adhoc */
_issue_bcn:
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
pmlmepriv->update_bcn = _FALSE;
_exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
if ((pattrib->pktlen + TXDESC_SIZE) > MAX_BEACON_LEN) {
RTW_ERR("beacon frame too large ,len(%d,%d)\n",
(pattrib->pktlen + TXDESC_SIZE), MAX_BEACON_LEN);
rtw_warn_on(1);
return;
}
pattrib->last_txcmdsz = pattrib->pktlen;
/* RTW_INFO("issue bcn_sz=%d\n", pattrib->last_txcmdsz); */
if (timeout_ms > 0)
dump_mgntframe_and_wait(padapter, pmgntframe, timeout_ms);
else
dump_mgntframe(padapter, pmgntframe);
}
void issue_probersp(_adapter *padapter, unsigned char *da, u8 is_valid_p2p_probereq)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned char *mac, *bssid;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
u8 *pwps_ie;
uint wps_ielen;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
#endif /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
unsigned int rate_len;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
/* RTW_INFO("%s\n", __FUNCTION__); */
if (da == NULL)
return;
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
RTW_INFO("%s, alloc mgnt frame fail\n", __FUNCTION__);
return;
}
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
mac = adapter_mac_addr(padapter);
bssid = cur_network->MacAddress;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, bssid, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(fctrl, WIFI_PROBERSP);
pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = pattrib->hdrlen;
pframe += pattrib->hdrlen;
if (cur_network->IELength > MAX_IE_SZ)
return;
#if defined(CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME)
if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
pwps_ie = rtw_get_wps_ie(cur_network->IEs + _FIXED_IE_LENGTH_, cur_network->IELength - _FIXED_IE_LENGTH_, NULL, &wps_ielen);
/* inerset & update wps_probe_resp_ie */
if ((pmlmepriv->wps_probe_resp_ie != NULL) && pwps_ie && (wps_ielen > 0)) {
uint wps_offset, remainder_ielen;
u8 *premainder_ie;
wps_offset = (uint)(pwps_ie - cur_network->IEs);
premainder_ie = pwps_ie + wps_ielen;
remainder_ielen = cur_network->IELength - wps_offset - wps_ielen;
_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
pframe += wps_offset;
pattrib->pktlen += wps_offset;
wps_ielen = (uint)pmlmepriv->wps_probe_resp_ie[1];/* to get ie data len */
if ((wps_offset + wps_ielen + 2) <= MAX_IE_SZ) {
_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, wps_ielen + 2);
pframe += wps_ielen + 2;
pattrib->pktlen += wps_ielen + 2;
}
if ((wps_offset + wps_ielen + 2 + remainder_ielen) <= MAX_IE_SZ) {
_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
pframe += remainder_ielen;
pattrib->pktlen += remainder_ielen;
}
} else {
_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
pframe += cur_network->IELength;
pattrib->pktlen += cur_network->IELength;
}
/* retrieve SSID IE from cur_network->Ssid */
{
u8 *ssid_ie;
sint ssid_ielen;
sint ssid_ielen_diff;
u8 buf[MAX_IE_SZ];
u8 *ies = pmgntframe->buf_addr + TXDESC_OFFSET + sizeof(struct rtw_ieee80211_hdr_3addr);
ssid_ie = rtw_get_ie(ies + _FIXED_IE_LENGTH_, _SSID_IE_, &ssid_ielen,
(pframe - ies) - _FIXED_IE_LENGTH_);
ssid_ielen_diff = cur_network->Ssid.SsidLength - ssid_ielen;
if (ssid_ie && cur_network->Ssid.SsidLength) {
uint remainder_ielen;
u8 *remainder_ie;
remainder_ie = ssid_ie + 2;
remainder_ielen = (pframe - remainder_ie);
if (remainder_ielen > MAX_IE_SZ) {
RTW_WARN(FUNC_ADPT_FMT" remainder_ielen > MAX_IE_SZ\n", FUNC_ADPT_ARG(padapter));
remainder_ielen = MAX_IE_SZ;
}
_rtw_memcpy(buf, remainder_ie, remainder_ielen);
_rtw_memcpy(remainder_ie + ssid_ielen_diff, buf, remainder_ielen);
*(ssid_ie + 1) = cur_network->Ssid.SsidLength;
_rtw_memcpy(ssid_ie + 2, cur_network->Ssid.Ssid, cur_network->Ssid.SsidLength);
pframe += ssid_ielen_diff;
pattrib->pktlen += ssid_ielen_diff;
}
}
#ifdef CONFIG_RTW_REPEATER_SON
rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
#endif
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_PROBERESP_VENDOR_IE_BIT);
#endif
} else
#endif
{
/* timestamp will be inserted by hardware */
pframe += 8;
pattrib->pktlen += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
pframe += 2;
pattrib->pktlen += 2;
/* capability info: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
pframe += 2;
pattrib->pktlen += 2;
/* below for ad-hoc mode */
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pattrib->pktlen);
/* supported rates... */
rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pattrib->pktlen);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pattrib->pktlen);
if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
u8 erpinfo = 0;
u32 ATIMWindow;
/* IBSS Parameter Set... */
/* ATIMWindow = cur->Configuration.ATIMWindow; */
ATIMWindow = 0;
pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pattrib->pktlen);
/* ERP IE */
pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pattrib->pktlen);
}
/* EXTERNDED SUPPORTED RATE */
if (rate_len > 8)
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pattrib->pktlen);
/* todo:HT for adhoc */
}
#ifdef CONFIG_RTW_80211K
pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_,
sizeof(padapter->rmpriv.rm_en_cap_def),
padapter->rmpriv.rm_en_cap_def, &pattrib->pktlen);
#endif
#ifdef CONFIG_P2P
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)
/* IOT issue, When wifi_spec is not set, send probe_resp with P2P IE even if probe_req has no P2P IE */
&& (is_valid_p2p_probereq || !padapter->registrypriv.wifi_spec)) {
u32 len;
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
/* if pwdinfo->role == P2P_ROLE_DEVICE will call issue_probersp_p2p() */
len = pmlmepriv->p2p_go_probe_resp_ie_len;
if (pmlmepriv->p2p_go_probe_resp_ie && len > 0)
_rtw_memcpy(pframe, pmlmepriv->p2p_go_probe_resp_ie, len);
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
len = build_probe_resp_p2p_ie(pwdinfo, pframe);
}
pframe += len;
pattrib->pktlen += len;
#ifdef CONFIG_MCC_MODE
pframe = rtw_hal_mcc_append_go_p2p_ie(padapter, pframe, &pattrib->pktlen);
#endif /* CONFIG_MCC_MODE*/
#ifdef CONFIG_WFD
len = rtw_append_probe_resp_wfd_ie(padapter, pframe);
pframe += len;
pattrib->pktlen += len;
#endif
}
#endif /* CONFIG_P2P */
#ifdef CONFIG_AUTO_AP_MODE
{
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
RTW_INFO("(%s)\n", __FUNCTION__);
/* check rc station */
psta = rtw_get_stainfo(pstapriv, da);
if (psta && psta->isrc && psta->pid > 0) {
u8 RC_OUI[4] = {0x00, 0xE0, 0x4C, 0x0A};
u8 RC_INFO[14] = {0};
/* EID[1] + EID_LEN[1] + RC_OUI[4] + MAC[6] + PairingID[2] + ChannelNum[2] */
u16 cu_ch = (u16)cur_network->Configuration.DSConfig;
RTW_INFO("%s, reply rc(pid=0x%x) device "MAC_FMT" in ch=%d\n", __FUNCTION__,
psta->pid, MAC_ARG(psta->cmn.mac_addr), cu_ch);
/* append vendor specific ie */
_rtw_memcpy(RC_INFO, RC_OUI, sizeof(RC_OUI));
_rtw_memcpy(&RC_INFO[4], mac, ETH_ALEN);
_rtw_memcpy(&RC_INFO[10], (u8 *)&psta->pid, 2);
_rtw_memcpy(&RC_INFO[12], (u8 *)&cu_ch, 2);
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, sizeof(RC_INFO), RC_INFO, &pattrib->pktlen);
}
}
#endif /* CONFIG_AUTO_AP_MODE */
#ifdef CONFIG_RTL8812A
pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen);
#endif/*CONFIG_RTL8812A*/
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
int _issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps, int wait_ack)
{
int ret = _FAIL;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned char *mac;
unsigned char bssrate[NumRates];
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
int bssrate_len = 0;
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
#endif
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
if ((pwdev_priv->pno_mac_addr[0] != 0xFF)
&& (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE))
mac = pwdev_priv->pno_mac_addr;
else
#endif
mac = adapter_mac_addr(padapter);
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
if (da) {
/* unicast probe request frame */
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
} else {
/* broadcast probe request frame */
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, bc_addr, ETH_ALEN);
}
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
if ((pwdev_priv->pno_mac_addr[0] != 0xFF)
&& (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
#ifdef CONFIG_RTW_DEBUG
RTW_DBG("%s pno_scan_seq_num: %d\n", __func__,
pwdev_priv->pno_scan_seq_num);
#endif
SetSeqNum(pwlanhdr, pwdev_priv->pno_scan_seq_num);
pattrib->seqnum = pwdev_priv->pno_scan_seq_num;
pattrib->qos_en = 1;
pwdev_priv->pno_scan_seq_num++;
} else
#endif
{
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
}
set_frame_sub_type(pframe, WIFI_PROBEREQ);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
if (pssid && !MLME_IS_MESH(padapter))
pframe = rtw_set_ie(pframe, _SSID_IE_, pssid->SsidLength, pssid->Ssid, &(pattrib->pktlen));
else
pframe = rtw_set_ie(pframe, _SSID_IE_, 0, NULL, &(pattrib->pktlen));
get_rate_set(padapter, bssrate, &bssrate_len);
if (bssrate_len > 8) {
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
} else
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
if (ch)
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, &ch, &pattrib->pktlen);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
if (pssid)
pframe = rtw_set_ie_mesh_id(pframe, &pattrib->pktlen, pssid->Ssid, pssid->SsidLength);
else
pframe = rtw_set_ie_mesh_id(pframe, &pattrib->pktlen, NULL, 0);
}
#endif
if (append_wps) {
/* add wps_ie for wps2.0 */
if (pmlmepriv->wps_probe_req_ie_len > 0 && pmlmepriv->wps_probe_req_ie) {
_rtw_memcpy(pframe, pmlmepriv->wps_probe_req_ie, pmlmepriv->wps_probe_req_ie_len);
pframe += pmlmepriv->wps_probe_req_ie_len;
pattrib->pktlen += pmlmepriv->wps_probe_req_ie_len;
/* pmlmepriv->wps_probe_req_ie_len = 0 ; */ /* reset to zero */
}
}
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_PROBEREQ_VENDOR_IE_BIT);
#endif
#ifdef CONFIG_RTL8812A
pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
#endif/*CONFIG_RTL8812A*/
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
inline void issue_probereq(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da)
{
_issue_probereq(padapter, pssid, da, 0, 1, _FALSE);
}
/*
* wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
* try_cnt means the maximal TX count to try
*/
int issue_probereq_ex(_adapter *padapter, const NDIS_802_11_SSID *pssid, const u8 *da, u8 ch, bool append_wps,
int try_cnt, int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
do {
ret = _issue_probereq(padapter, pssid, da, ch, append_wps, wait_ms > 0 ? _TRUE : _FALSE);
i++;
if (RTW_CANNOT_RUN(padapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (da)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
/* if psta == NULL, indiate we are station(client) now... */
void issue_auth(_adapter *padapter, struct sta_info *psta, unsigned short status)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned int val32;
unsigned short val16;
int use_shared_key = 0;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_AUTH);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
if (psta) { /* for AP mode */
#ifdef CONFIG_NATIVEAP_MLME
_rtw_memcpy(pwlanhdr->addr1, psta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
/* setting auth algo number */
val16 = (u16)psta->authalg;
if (status != _STATS_SUCCESSFUL_)
val16 = 0;
if (val16) {
val16 = cpu_to_le16(val16);
use_shared_key = 1;
}
pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
/* setting auth seq number */
val16 = (u16)psta->auth_seq;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
/* setting status code... */
val16 = status;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
/* added challenging text... */
if ((psta->auth_seq == 2) && (psta->state & WIFI_FW_AUTH_STATE) && (use_shared_key == 1))
pframe = rtw_set_ie(pframe, _CHLGETXT_IE_, 128, psta->chg_txt, &(pattrib->pktlen));
#endif
} else {
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam(padapter)) {
/* 2: 802.11R FTAA */
val16 = cpu_to_le16(2);
} else
#endif
{
/* setting auth algo number */
val16 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) ? 1 : 0; /* 0:OPEN System, 1:Shared key */
if (val16) {
val16 = cpu_to_le16(val16);
use_shared_key = 1;
}
}
/* RTW_INFO("%s auth_algo= %s auth_seq=%d\n",__FUNCTION__,(pmlmeinfo->auth_algo==0)?"OPEN":"SHARED",pmlmeinfo->auth_seq); */
/* setting IV for auth seq #3 */
if ((pmlmeinfo->auth_seq == 3) && (pmlmeinfo->state & WIFI_FW_AUTH_STATE) && (use_shared_key == 1)) {
/* RTW_INFO("==> iv(%d),key_index(%d)\n",pmlmeinfo->iv,pmlmeinfo->key_index); */
val32 = ((pmlmeinfo->iv++) | (pmlmeinfo->key_index << 30));
val32 = cpu_to_le32(val32);
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *)&val32, &(pattrib->pktlen));
pattrib->iv_len = 4;
}
pframe = rtw_set_fixed_ie(pframe, _AUTH_ALGM_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
/* setting auth seq number */
val16 = pmlmeinfo->auth_seq;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, _AUTH_SEQ_NUM_, (unsigned char *)&val16, &(pattrib->pktlen));
/* setting status code... */
val16 = status;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, _STATUS_CODE_, (unsigned char *)&val16, &(pattrib->pktlen));
#ifdef CONFIG_RTW_80211R
rtw_ft_build_auth_req_ies(padapter, pattrib, &pframe);
#endif
/* then checking to see if sending challenging text... */
if ((pmlmeinfo->auth_seq == 3) && (pmlmeinfo->state & WIFI_FW_AUTH_STATE) && (use_shared_key == 1)) {
pframe = rtw_set_ie(pframe, _CHLGETXT_IE_, 128, pmlmeinfo->chg_txt, &(pattrib->pktlen));
SetPrivacy(fctrl);
pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->encrypt = _WEP40_;
pattrib->icv_len = 4;
pattrib->pktlen += pattrib->icv_len;
}
}
pattrib->last_txcmdsz = pattrib->pktlen;
rtw_wep_encrypt(padapter, (u8 *)pmgntframe);
RTW_INFO("%s\n", __FUNCTION__);
dump_mgntframe(padapter, pmgntframe);
return;
}
void issue_asocrsp(_adapter *padapter, unsigned short status, struct sta_info *pstat, int pkt_type)
{
#ifdef CONFIG_AP_MODE
struct xmit_frame *pmgntframe;
struct rtw_ieee80211_hdr *pwlanhdr;
struct pkt_attrib *pattrib;
unsigned char *pbuf, *pframe;
unsigned short val, ie_status;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = &(pmlmeinfo->network);
u8 *ie = pnetwork->IEs;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
#endif /* CONFIG_P2P */
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return;
RTW_INFO("%s\n", __FUNCTION__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy((void *)GetAddr1Ptr(pwlanhdr), pstat->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy((void *)get_addr2_ptr(pwlanhdr), adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy((void *)GetAddr3Ptr(pwlanhdr), get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
if ((pkt_type == WIFI_ASSOCRSP) || (pkt_type == WIFI_REASSOCRSP))
set_frame_sub_type(pwlanhdr, pkt_type);
else
return;
pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen += pattrib->hdrlen;
pframe += pattrib->hdrlen;
/* capability */
val = *(unsigned short *)rtw_get_capability_from_ie(ie);
pframe = rtw_set_fixed_ie(pframe, _CAPABILITY_ , (unsigned char *)&val, &(pattrib->pktlen));
ie_status = cpu_to_le16(status);
pframe = rtw_set_fixed_ie(pframe , _STATUS_CODE_ , (unsigned char *)&ie_status, &(pattrib->pktlen));
val = cpu_to_le16(pstat->cmn.aid | BIT(14) | BIT(15));
pframe = rtw_set_fixed_ie(pframe, _ASOC_ID_ , (unsigned char *)&val, &(pattrib->pktlen));
if (pstat->bssratelen <= 8)
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, pstat->bssratelen, pstat->bssrateset, &(pattrib->pktlen));
else {
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pstat->bssrateset, &(pattrib->pktlen));
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (pstat->bssratelen - 8), pstat->bssrateset + 8, &(pattrib->pktlen));
}
#ifdef CONFIG_IEEE80211W
if (status == _STATS_REFUSED_TEMPORARILY_) {
u8 timeout_itvl[5];
u32 timeout_interval = 3000;
/* Association Comeback time */
timeout_itvl[0] = 0x03;
timeout_interval = cpu_to_le32(timeout_interval);
_rtw_memcpy(timeout_itvl + 1, &timeout_interval, 4);
pframe = rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, 5, timeout_itvl, &(pattrib->pktlen));
}
#endif /* CONFIG_IEEE80211W */
#ifdef CONFIG_80211N_HT
if ((pstat->flags & WLAN_STA_HT) && (pmlmepriv->htpriv.ht_option)) {
uint ie_len = 0;
/* FILL HT CAP INFO IE */
/* p = hostapd_eid_ht_capabilities_info(hapd, p); */
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_CAPABILITY_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (pbuf && ie_len > 0) {
_rtw_memcpy(pframe, pbuf, ie_len + 2);
pframe += (ie_len + 2);
pattrib->pktlen += (ie_len + 2);
}
/* FILL HT ADD INFO IE */
/* p = hostapd_eid_ht_operation(hapd, p); */
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _HT_ADD_INFO_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (pbuf && ie_len > 0) {
_rtw_memcpy(pframe, pbuf, ie_len + 2);
pframe += (ie_len + 2);
pattrib->pktlen += (ie_len + 2);
}
}
#endif
/*adding EXT_CAPAB_IE */
if (pmlmepriv->ext_capab_ie_len > 0) {
uint ie_len = 0;
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, _EXT_CAP_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (pbuf && ie_len > 0) {
_rtw_memcpy(pframe, pbuf, ie_len + 2);
pframe += (ie_len + 2);
pattrib->pktlen += (ie_len + 2);
}
}
#ifdef CONFIG_80211AC_VHT
if ((pstat->flags & WLAN_STA_VHT) && (pmlmepriv->vhtpriv.vht_option)
&& (pstat->wpa_pairwise_cipher != WPA_CIPHER_TKIP)
&& (pstat->wpa2_pairwise_cipher != WPA_CIPHER_TKIP)) {
u32 ie_len = 0;
/* FILL VHT CAP IE */
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (pbuf && ie_len > 0) {
_rtw_memcpy(pframe, pbuf, ie_len + 2);
pframe += (ie_len + 2);
pattrib->pktlen += (ie_len + 2);
}
/* FILL VHT OPERATION IE */
pbuf = rtw_get_ie(ie + _BEACON_IE_OFFSET_, EID_VHTOperation, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_));
if (pbuf && ie_len > 0) {
_rtw_memcpy(pframe, pbuf, ie_len + 2);
pframe += (ie_len + 2);
pattrib->pktlen += (ie_len + 2);
}
}
#endif /* CONFIG_80211AC_VHT */
/* FILL WMM IE */
if ((pstat->flags & WLAN_STA_WME) && (pmlmepriv->qospriv.qos_option)) {
uint ie_len = 0;
unsigned char WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
for (pbuf = ie + _BEACON_IE_OFFSET_; ; pbuf += (ie_len + 2)) {
pbuf = rtw_get_ie(pbuf, _VENDOR_SPECIFIC_IE_, &ie_len, (pnetwork->IELength - _BEACON_IE_OFFSET_ - (ie_len + 2)));
if (pbuf && _rtw_memcmp(pbuf + 2, WMM_PARA_IE, 6)) {
_rtw_memcpy(pframe, pbuf, ie_len + 2);
pframe += (ie_len + 2);
pattrib->pktlen += (ie_len + 2);
break;
}
if ((pbuf == NULL) || (ie_len == 0))
break;
}
}
if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 6 , REALTEK_96B_IE, &(pattrib->pktlen));
/* add WPS IE ie for wps 2.0 */
if (pmlmepriv->wps_assoc_resp_ie && pmlmepriv->wps_assoc_resp_ie_len > 0) {
_rtw_memcpy(pframe, pmlmepriv->wps_assoc_resp_ie, pmlmepriv->wps_assoc_resp_ie_len);
pframe += pmlmepriv->wps_assoc_resp_ie_len;
pattrib->pktlen += pmlmepriv->wps_assoc_resp_ie_len;
}
#ifdef CONFIG_P2P
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && (pstat->is_p2p_device == _TRUE)) {
u32 len;
if (padapter->wdinfo.driver_interface == DRIVER_CFG80211) {
len = 0;
if (pmlmepriv->p2p_assoc_resp_ie && pmlmepriv->p2p_assoc_resp_ie_len > 0) {
len = pmlmepriv->p2p_assoc_resp_ie_len;
_rtw_memcpy(pframe, pmlmepriv->p2p_assoc_resp_ie, len);
}
} else
len = build_assoc_resp_p2p_ie(pwdinfo, pframe, pstat->p2p_status_code);
pframe += len;
pattrib->pktlen += len;
}
#ifdef CONFIG_WFD
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
wfdielen = rtw_append_assoc_resp_wfd_ie(padapter, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
}
#endif
#endif /* CONFIG_P2P */
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_ASSOCRESP_VENDOR_IE_BIT);
#endif
#ifdef CONFIG_RTL8812A
pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
#endif/*CONFIG_RTL8812A*/
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
#endif
}
void _issue_assocreq(_adapter *padapter, u8 is_reassoc)
{
int ret = _FAIL;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned short val16;
unsigned int i, j, index = 0;
unsigned char bssrate[NumRates], sta_bssrate[NumRates];
PNDIS_802_11_VARIABLE_IEs pIE;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
int bssrate_len = 0, sta_bssrate_len = 0;
u8 vs_ie_length = 0;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 p2pie[255] = { 0x00 };
u16 p2pielen = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
#endif /* CONFIG_P2P */
#ifdef CONFIG_DFS
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
u16 cap;
/* Dot H */
u8 pow_cap_ele[2] = { 0x00 };
u8 sup_ch[30 * 2] = {0x00 }, sup_ch_idx = 0, idx_5g = 2; /* For supported channel */
#endif /* CONFIG_DFS */
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
if (is_reassoc == _TRUE)
set_frame_sub_type(pframe, WIFI_REASSOCREQ);
else
set_frame_sub_type(pframe, WIFI_ASSOCREQ);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* caps */
#ifdef CONFIG_DFS
_rtw_memcpy(&cap, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
cap |= cap_SpecMgmt;
_rtw_memcpy(pframe, &cap, 2);
#else
_rtw_memcpy(pframe, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
#endif /* CONFIG_DFS */
pframe += 2;
pattrib->pktlen += 2;
/* listen interval */
/* todo: listen interval for power saving */
val16 = cpu_to_le16(3);
_rtw_memcpy(pframe , (unsigned char *)&val16, 2);
pframe += 2;
pattrib->pktlen += 2;
/*Construct Current AP Field for Reassoc-Req only*/
if (is_reassoc == _TRUE) {
_rtw_memcpy(pframe, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
pframe += ETH_ALEN;
pattrib->pktlen += ETH_ALEN;
}
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, pmlmeinfo->network.Ssid.SsidLength, pmlmeinfo->network.Ssid.Ssid, &(pattrib->pktlen));
#ifdef CONFIG_DFS
/* Dot H */
if (pmlmeext->cur_channel > 14) {
pow_cap_ele[0] = 13; /* Minimum transmit power capability */
pow_cap_ele[1] = 21; /* Maximum transmit power capability */
pframe = rtw_set_ie(pframe, EID_PowerCap, 2, pow_cap_ele, &(pattrib->pktlen));
/* supported channels */
while (sup_ch_idx < rfctl->max_chan_nums && rfctl->channel_set[sup_ch_idx].ChannelNum != 0) {
if (rfctl->channel_set[sup_ch_idx].ChannelNum <= 14) {
/* TODO: fix 2.4G supported channel when channel doesn't start from 1 and continuous */
sup_ch[0] = 1; /* First channel number */
sup_ch[1] = rfctl->channel_set[sup_ch_idx].ChannelNum; /* Number of channel */
} else {
sup_ch[idx_5g++] = rfctl->channel_set[sup_ch_idx].ChannelNum;
sup_ch[idx_5g++] = 1;
}
sup_ch_idx++;
}
pframe = rtw_set_ie(pframe, EID_SupportedChannels, idx_5g, sup_ch, &(pattrib->pktlen));
}
#endif /* CONFIG_DFS */
/* supported rate & extended supported rate */
#if 1 /* Check if the AP's supported rates are also supported by STA. */
get_rate_set(padapter, sta_bssrate, &sta_bssrate_len);
/* RTW_INFO("sta_bssrate_len=%d\n", sta_bssrate_len); */
if (pmlmeext->cur_channel == 14) /* for JAPAN, channel 14 can only uses B Mode(CCK) */
sta_bssrate_len = 4;
/* for (i = 0; i < sta_bssrate_len; i++) { */
/* RTW_INFO("sta_bssrate[%d]=%02X\n", i, sta_bssrate[i]); */
/* } */
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
if (pmlmeinfo->network.SupportedRates[i] == 0)
break;
RTW_INFO("network.SupportedRates[%d]=%02X\n", i, pmlmeinfo->network.SupportedRates[i]);
}
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
if (pmlmeinfo->network.SupportedRates[i] == 0)
break;
/* Check if the AP's supported rates are also supported by STA. */
for (j = 0; j < sta_bssrate_len; j++) {
/* Avoid the proprietary data rate (22Mbps) of Handlink WSG-4000 AP */
if ((pmlmeinfo->network.SupportedRates[i] | IEEE80211_BASIC_RATE_MASK)
== (sta_bssrate[j] | IEEE80211_BASIC_RATE_MASK)) {
/* RTW_INFO("match i = %d, j=%d\n", i, j); */
break;
} else {
/* RTW_INFO("not match: %02X != %02X\n", (pmlmeinfo->network.SupportedRates[i]|IEEE80211_BASIC_RATE_MASK), (sta_bssrate[j]|IEEE80211_BASIC_RATE_MASK)); */
}
}
if (j == sta_bssrate_len) {
/* the rate is not supported by STA */
RTW_INFO("%s(): the rate[%d]=%02X is not supported by STA!\n", __FUNCTION__, i, pmlmeinfo->network.SupportedRates[i]);
} else {
/* the rate is supported by STA */
bssrate[index++] = pmlmeinfo->network.SupportedRates[i];
}
}
bssrate_len = index;
RTW_INFO("bssrate_len = %d\n", bssrate_len);
#else /* Check if the AP's supported rates are also supported by STA. */
#if 0
get_rate_set(padapter, bssrate, &bssrate_len);
#else
for (bssrate_len = 0; bssrate_len < NumRates; bssrate_len++) {
if (pmlmeinfo->network.SupportedRates[bssrate_len] == 0)
break;
if (pmlmeinfo->network.SupportedRates[bssrate_len] == 0x2C) /* Avoid the proprietary data rate (22Mbps) of Handlink WSG-4000 AP */
break;
bssrate[bssrate_len] = pmlmeinfo->network.SupportedRates[bssrate_len];
}
#endif
#endif /* Check if the AP's supported rates are also supported by STA. */
if ((bssrate_len == 0) && (pmlmeinfo->network.SupportedRates[0] != 0)) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit; /* don't connect to AP if no joint supported rate */
}
if (bssrate_len > 8) {
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
} else if (bssrate_len > 0)
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
else
RTW_INFO("%s: Connect to AP without 11b and 11g data rate!\n", __FUNCTION__);
#ifdef CONFIG_RTW_80211K
if (pmlmeinfo->network.PhyInfo.rm_en_cap[0] /* RM Enabled Capabilities */
| pmlmeinfo->network.PhyInfo.rm_en_cap[1]
| pmlmeinfo->network.PhyInfo.rm_en_cap[2]
| pmlmeinfo->network.PhyInfo.rm_en_cap[3]
| pmlmeinfo->network.PhyInfo.rm_en_cap[4])
pframe = rtw_set_ie(pframe, _EID_RRM_EN_CAP_IE_, 5,
(u8 *)padapter->rmpriv.rm_en_cap_def, &(pattrib->pktlen));
#endif /* CONFIG_RTW_80211K */
/* vendor specific IE, such as WPA, WMM, WPS */
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
if ((_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4)) ||
(_rtw_memcmp(pIE->data, WMM_OUI, 4)) ||
(_rtw_memcmp(pIE->data, WPS_OUI, 4))) {
vs_ie_length = pIE->Length;
if ((!padapter->registrypriv.wifi_spec) && (_rtw_memcmp(pIE->data, WPS_OUI, 4))) {
/* Commented by Kurt 20110629 */
/* In some older APs, WPS handshake */
/* would be fail if we append vender extensions informations to AP */
vs_ie_length = 14;
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, vs_ie_length, pIE->data, &(pattrib->pktlen));
}
break;
case EID_WPA2:
#ifdef CONFIG_RTW_80211R
if ((is_reassoc) && (rtw_ft_roam(padapter))) {
rtw_ft_update_rsnie(padapter, _TRUE, pattrib, &pframe);
} else
#endif
{
#ifdef CONFIG_IOCTL_CFG80211
if (rtw_sec_chk_auth_alg(padapter, WLAN_AUTH_OPEN) &&
rtw_sec_chk_auth_type(padapter, NL80211_AUTHTYPE_SAE)) {
s32 entry = rtw_cached_pmkid(padapter, pmlmepriv->assoc_bssid);
rtw_rsn_sync_pmkid(padapter, (u8 *)pIE, (pIE->Length + 2), entry);
}
#endif /* CONFIG_IOCTL_CFG80211 */
pframe = rtw_set_ie(pframe, EID_WPA2, pIE->Length, pIE->data, &(pattrib->pktlen));
}
break;
#ifdef CONFIG_80211N_HT
case EID_HTCapability:
if (padapter->mlmepriv.htpriv.ht_option == _TRUE) {
if (!(is_ap_in_tkip(padapter))) {
_rtw_memcpy(&(pmlmeinfo->HT_caps), pIE->data, sizeof(struct HT_caps_element));
pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info = cpu_to_le16(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info);
pframe = rtw_set_ie(pframe, EID_HTCapability, pIE->Length , (u8 *)(&(pmlmeinfo->HT_caps)), &(pattrib->pktlen));
}
}
break;
case EID_EXTCapability:
if (padapter->mlmepriv.htpriv.ht_option == _TRUE)
pframe = rtw_set_ie(pframe, EID_EXTCapability, pIE->Length, pIE->data, &(pattrib->pktlen));
break;
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
case EID_VHTCapability:
if (padapter->mlmepriv.vhtpriv.vht_option == _TRUE)
pframe = rtw_set_ie(pframe, EID_VHTCapability, pIE->Length, pIE->data, &(pattrib->pktlen));
break;
case EID_OpModeNotification:
if (padapter->mlmepriv.vhtpriv.vht_option == _TRUE)
pframe = rtw_set_ie(pframe, EID_OpModeNotification, pIE->Length, pIE->data, &(pattrib->pktlen));
break;
#endif /* CONFIG_80211AC_VHT */
default:
break;
}
i += (pIE->Length + 2);
}
if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 6 , REALTEK_96B_IE, &(pattrib->pktlen));
#ifdef CONFIG_WAPI_SUPPORT
rtw_build_assoc_req_wapi_ie(padapter, pframe, pattrib);
#endif
#ifdef CONFIG_P2P
#ifdef CONFIG_IOCTL_CFG80211
if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->driver_interface == DRIVER_CFG80211) {
if (pmlmepriv->p2p_assoc_req_ie && pmlmepriv->p2p_assoc_req_ie_len > 0) {
_rtw_memcpy(pframe, pmlmepriv->p2p_assoc_req_ie, pmlmepriv->p2p_assoc_req_ie_len);
pframe += pmlmepriv->p2p_assoc_req_ie_len;
pattrib->pktlen += pmlmepriv->p2p_assoc_req_ie_len;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) && !rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
/* Should add the P2P IE in the association request frame. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20101109 */
/* According to the P2P Specification, the association request frame should contain 3 P2P attributes */
/* 1. P2P Capability */
/* 2. Extended Listen Timing */
/* 3. Device Info */
/* Commented by Albert 20110516 */
/* 4. P2P Interface */
/* P2P Capability */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
else
p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
/* Extended Listen Timing */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0004);
p2pielen += 2;
/* Value: */
/* Availability Period */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
p2pielen += 2;
/* Availability Interval */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0xFFFF);
p2pielen += 2;
/* Device Info */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
if ((pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PEER_DISPLAY_PIN) ||
(pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_SELF_DISPLAY_PIN))
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_DISPLAY);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_CONFIG_METHOD_PBC);
p2pielen += 2;
/* Primary Device Type */
/* Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
p2pielen += 4;
/* Sub Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
/* P2P Interface */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_INTERFACE;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x000D);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN); /* P2P Device Address */
p2pielen += ETH_ALEN;
p2pie[p2pielen++] = 1; /* P2P Interface Address Count */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN); /* P2P Interface Address List */
p2pielen += ETH_ALEN;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pattrib->pktlen);
}
}
#ifdef CONFIG_WFD
wfdielen = rtw_append_assoc_req_wfd_ie(padapter, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
#endif /* CONFIG_P2P */
#ifdef CONFIG_RTW_REPEATER_SON
rtw_rson_append_ie(padapter, pframe, &pattrib->pktlen);
#endif
#ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
pattrib->pktlen += rtw_build_vendor_ie(padapter , &pframe , WIFI_ASSOCREQ_VENDOR_IE_BIT);
#endif
#ifdef CONFIG_RTL8812A
pframe = rtw_hal_set_8812a_vendor_ie(padapter, pframe, &pattrib->pktlen );
#endif/*CONFIG_RTL8812A*/
#ifdef CONFIG_RTW_80211R
rtw_ft_build_assoc_req_ies(padapter, is_reassoc, pattrib, &pframe);
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
if (ret == _SUCCESS)
rtw_buf_update(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len, (u8 *)pwlanhdr, pattrib->pktlen);
else
rtw_buf_free(&pmlmepriv->assoc_req, &pmlmepriv->assoc_req_len);
return;
}
void issue_assocreq(_adapter *padapter)
{
_issue_assocreq(padapter, _FALSE);
}
void issue_reassocreq(_adapter *padapter)
{
_issue_assocreq(padapter, _TRUE);
}
/* when wait_ack is ture, this function shoule be called at process context */
static int _issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int wait_ack)
{
int ret = _FAIL;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv;
struct mlme_ext_priv *pmlmeext;
struct mlme_ext_info *pmlmeinfo;
u8 a4_shift;
/* RTW_INFO("%s:%d\n", __FUNCTION__, power_mode); */
if (!padapter)
goto exit;
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
pxmitpriv = &(padapter->xmitpriv);
pmlmeext = &(padapter->mlmeextpriv);
pmlmeinfo = &(pmlmeext->mlmext_info);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
pattrib->retry_ctrl = _FALSE;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
if (MLME_IS_AP(padapter))
SetFrDs(fctrl);
else if (MLME_IS_STA(padapter))
SetToDs(fctrl);
else if (MLME_IS_MESH(padapter)) {
SetToDs(fctrl);
SetFrDs(fctrl);
}
if (power_mode)
SetPwrMgt(fctrl);
if (get_tofr_ds(fctrl) == 3) {
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr4, adapter_mac_addr(padapter), ETH_ALEN);
a4_shift = ETH_ALEN;
pattrib->hdrlen += ETH_ALEN;
} else {
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
a4_shift = 0;
}
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_DATA_NULL);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr) + a4_shift;
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr) + a4_shift;
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
/*
* When wait_ms > 0, this function should be called at process context
* wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
* try_cnt means the maximal TX count to try
* da == NULL for station mode
*/
int issue_nulldata(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
/* da == NULL, assum it's null data for sta to ap */
if (da == NULL)
da = get_my_bssid(&(pmlmeinfo->network));
do {
ret = _issue_nulldata(padapter, da, power_mode, wait_ms > 0 ? _TRUE : _FALSE);
i++;
if (RTW_CANNOT_RUN(padapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (da)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
/* when wait_ack is ture, this function shoule be called at process context */
static int _issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int wait_ack)
{
int ret = _FAIL;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl, *qc;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 a4_shift;
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
/* RTW_INFO("%s\n", __FUNCTION__); */
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
pattrib->hdrlen += 2;
pattrib->qos_en = _TRUE;
pattrib->eosp = 1;
pattrib->ack_policy = 0;
pattrib->mdata = 0;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
if (MLME_IS_AP(padapter))
SetFrDs(fctrl);
else if (MLME_IS_STA(padapter))
SetToDs(fctrl);
else if (MLME_IS_MESH(padapter)) {
SetToDs(fctrl);
SetFrDs(fctrl);
}
if (ps)
SetPwrMgt(fctrl);
if (pattrib->mdata)
SetMData(fctrl);
if (get_tofr_ds(fctrl) == 3) {
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr4, adapter_mac_addr(padapter), ETH_ALEN);
a4_shift = ETH_ALEN;
pattrib->hdrlen += ETH_ALEN;
} else {
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
a4_shift = 0;
}
qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
SetPriority(qc, tid);
SetEOSP(qc, pattrib->eosp);
SetAckpolicy(qc, pattrib->ack_policy);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos) + a4_shift;
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos) + a4_shift;
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
/*
* when wait_ms >0 , this function should be called at process context
* wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
* try_cnt means the maximal TX count to try
* da == NULL for station mode
*/
int issue_qos_nulldata(_adapter *padapter, unsigned char *da, u16 tid, u8 ps, int try_cnt, int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
/* da == NULL, assum it's null data for sta to ap*/
if (da == NULL)
da = get_my_bssid(&(pmlmeinfo->network));
do {
ret = _issue_qos_nulldata(padapter, da, tid, ps, wait_ms > 0 ? _TRUE : _FALSE);
i++;
if (RTW_CANNOT_RUN(padapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (da)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
static int _issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason, u8 wait_ack, u8 key_type)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
int ret = _FAIL;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
/* RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(da)); */
#ifdef CONFIG_P2P
if (!(rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) && (pwdinfo->rx_invitereq_info.scan_op_ch_only)) {
_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
_set_timer(&pwdinfo->reset_ch_sitesurvey, 10);
}
#endif /* CONFIG_P2P */
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
pattrib->retry_ctrl = _FALSE;
pattrib->key_type = key_type;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_DEAUTH);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
reason = cpu_to_le16(reason);
pframe = rtw_set_fixed_ie(pframe, _RSON_CODE_ , (unsigned char *)&reason, &(pattrib->pktlen));
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
int issue_deauth(_adapter *padapter, unsigned char *da, unsigned short reason)
{
RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
return _issue_deauth(padapter, da, reason, _FALSE, IEEE80211W_RIGHT_KEY);
}
#ifdef CONFIG_IEEE80211W
int issue_deauth_11w(_adapter *padapter, unsigned char *da, unsigned short reason, u8 key_type)
{
RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(da));
return _issue_deauth(padapter, da, reason, _FALSE, key_type);
}
#endif /* CONFIG_IEEE80211W */
/*
* wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
* try_cnt means the maximal TX count to try
*/
int issue_deauth_ex(_adapter *padapter, u8 *da, unsigned short reason, int try_cnt,
int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
do {
ret = _issue_deauth(padapter, da, reason, wait_ms > 0 ? _TRUE : _FALSE, IEEE80211W_RIGHT_KEY);
i++;
if (RTW_CANNOT_RUN(padapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (da)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
void issue_action_spct_ch_switch(_adapter *padapter, u8 *ra, u8 new_ch, u8 ch_offset)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return;
RTW_INFO(FUNC_NDEV_FMT" ra="MAC_FMT", ch:%u, offset:%u\n",
FUNC_NDEV_ARG(padapter->pnetdev), MAC_ARG(ra), new_ch, ch_offset);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, ra, ETH_ALEN); /* RA */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN); /* TA */
_rtw_memcpy(pwlanhdr->addr3, ra, ETH_ALEN); /* DA = RA */
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* category, action */
{
u8 category, action;
category = RTW_WLAN_CATEGORY_SPECTRUM_MGMT;
action = RTW_WLAN_ACTION_SPCT_CHL_SWITCH;
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
}
pframe = rtw_set_ie_ch_switch(pframe, &(pattrib->pktlen), 0, new_ch, 0);
pframe = rtw_set_ie_secondary_ch_offset(pframe, &(pattrib->pktlen),
hal_ch_offset_to_secondary_ch_offset(ch_offset));
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
#ifdef CONFIG_IEEE80211W
void issue_action_SA_Query(_adapter *padapter, unsigned char *raddr, unsigned char action, unsigned short tid, u8 key_type)
{
u8 category = RTW_WLAN_CATEGORY_SA_QUERY;
u16 reason_code;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
u8 *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
struct registry_priv *pregpriv = &padapter->registrypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return;
RTW_INFO("%s, %04x\n", __FUNCTION__, tid);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
RTW_INFO("%s: alloc_mgtxmitframe fail\n", __FUNCTION__);
return;
}
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
pattrib->key_type = key_type;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
if (raddr)
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
else
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
pframe = rtw_set_fixed_ie(pframe, 1, &action, &pattrib->pktlen);
switch (action) {
case 0: /* SA Query req */
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)&pmlmeext->sa_query_seq, &pattrib->pktlen);
pmlmeext->sa_query_seq++;
/* send sa query request to AP, AP should reply sa query response in 1 second */
if (pattrib->key_type == IEEE80211W_RIGHT_KEY) {
psta = rtw_get_stainfo(pstapriv, pwlanhdr->addr1);
if (psta != NULL) {
/* RTW_INFO("%s, %d, set dot11w_expire_timer\n", __func__, __LINE__); */
_set_timer(&psta->dot11w_expire_timer, 1000);
}
}
break;
case 1: /* SA Query rsp */
tid = cpu_to_le16(tid);
/* RTW_INFO("rtw_set_fixed_ie, %04x\n", tid); */
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)&tid, &pattrib->pktlen);
break;
default:
break;
}
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
#endif /* CONFIG_IEEE80211W */
/**
* issue_action_ba - internal function to TX Block Ack action frame
* @padapter: the adapter to TX
* @raddr: receiver address
* @action: Block Ack Action
* @tid: tid
* @size: the announced AMPDU buffer size. used by ADDBA_RESP
* @status: status/reason code. used by ADDBA_RESP, DELBA
* @initiator: if we are the initiator of AMPDU association. used by DELBA
* @wait_ack: used xmit ack
*
* Returns:
* _SUCCESS: No xmit ack is used or acked
* _FAIL: not acked when using xmit ack
*/
static int issue_action_ba(_adapter *padapter, unsigned char *raddr, unsigned char action
, u8 tid, u8 size, u16 status, u8 initiator, int wait_ack)
{
int ret = _FAIL;
u8 category = RTW_WLAN_CATEGORY_BACK;
u16 start_seq;
u16 BA_para_set;
u16 BA_timeout_value;
u16 BA_starting_seqctrl;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
u8 *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
struct registry_priv *pregpriv = &padapter->registrypriv;
#ifdef CONFIG_80211N_HT
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
/* _rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN); */
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
if (category == 3) {
switch (action) {
case RTW_WLAN_ACTION_ADDBA_REQ:
do {
pmlmeinfo->dialogToken++;
} while (pmlmeinfo->dialogToken == 0);
pframe = rtw_set_fixed_ie(pframe, 1, &(pmlmeinfo->dialogToken), &(pattrib->pktlen));
#if defined(CONFIG_RTL8188E) && defined(CONFIG_SDIO_HCI)
BA_para_set = (0x0802 | ((tid & 0xf) << 2)); /* immediate ack & 16 buffer size */
#else
BA_para_set = (0x1002 | ((tid & 0xf) << 2)); /* immediate ack & 64 buffer size */
#endif
#ifdef CONFIG_TX_AMSDU
if (padapter->tx_amsdu >= 1) /* TX AMSDU enabled */
BA_para_set |= BIT(0);
else /* TX AMSDU disabled */
BA_para_set &= ~BIT(0);
#endif
BA_para_set = cpu_to_le16(BA_para_set);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
/* BA_timeout_value = 0xffff; */ /* max: 65535 TUs(~ 65 ms) */
BA_timeout_value = 5000;/* ~ 5ms */
BA_timeout_value = cpu_to_le16(BA_timeout_value);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_timeout_value)), &(pattrib->pktlen));
/* if ((psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress)) != NULL) */
psta = rtw_get_stainfo(pstapriv, raddr);
if (psta != NULL) {
start_seq = (psta->sta_xmitpriv.txseq_tid[tid & 0x07] & 0xfff) + 1;
RTW_INFO("BA_starting_seqctrl = %d for TID=%d\n", start_seq, tid & 0x07);
psta->BA_starting_seqctrl[tid & 0x07] = start_seq;
BA_starting_seqctrl = start_seq << 4;
}
BA_starting_seqctrl = cpu_to_le16(BA_starting_seqctrl);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_starting_seqctrl)), &(pattrib->pktlen));
break;
case RTW_WLAN_ACTION_ADDBA_RESP:
pframe = rtw_set_fixed_ie(pframe, 1, &(pmlmeinfo->ADDBA_req.dialog_token), &(pattrib->pktlen));
status = cpu_to_le16(status);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&status), &(pattrib->pktlen));
BA_para_set = le16_to_cpu(pmlmeinfo->ADDBA_req.BA_para_set);
BA_para_set &= ~IEEE80211_ADDBA_PARAM_TID_MASK;
BA_para_set |= (tid << 2) & IEEE80211_ADDBA_PARAM_TID_MASK;
BA_para_set &= ~RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
BA_para_set |= (size << 6) & RTW_IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
if (!padapter->registrypriv.wifi_spec) {
if (pregpriv->rx_ampdu_amsdu == 0) /* disabled */
BA_para_set &= ~BIT(0);
else if (pregpriv->rx_ampdu_amsdu == 1) /* enabled */
BA_para_set |= BIT(0);
}
BA_para_set = cpu_to_le16(BA_para_set);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(pmlmeinfo->ADDBA_req.BA_timeout_value)), &(pattrib->pktlen));
break;
case RTW_WLAN_ACTION_DELBA:
BA_para_set = 0;
BA_para_set |= (tid << 12) & IEEE80211_DELBA_PARAM_TID_MASK;
BA_para_set |= (initiator << 11) & IEEE80211_DELBA_PARAM_INITIATOR_MASK;
BA_para_set = cpu_to_le16(BA_para_set);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(BA_para_set)), &(pattrib->pktlen));
status = cpu_to_le16(status);
pframe = rtw_set_fixed_ie(pframe, 2, (unsigned char *)(&(status)), &(pattrib->pktlen));
break;
default:
break;
}
}
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
#endif /* CONFIG_80211N_HT */
return ret;
}
/**
* issue_addba_req - TX ADDBA_REQ
* @adapter: the adapter to TX
* @ra: receiver address
* @tid: tid
*/
inline void issue_addba_req(_adapter *adapter, unsigned char *ra, u8 tid)
{
issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_REQ
, tid
, 0 /* unused */
, 0 /* unused */
, 0 /* unused */
, _FALSE
);
RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" tid=%u\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), tid);
}
/**
* issue_addba_rsp - TX ADDBA_RESP
* @adapter: the adapter to TX
* @ra: receiver address
* @tid: tid
* @status: status code
* @size: the announced AMPDU buffer size
*/
inline void issue_addba_rsp(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size)
{
issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_RESP
, tid
, size
, status
, 0 /* unused */
, _FALSE
);
RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" status=%u, tid=%u, size=%u\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), status, tid, size);
}
/**
* issue_addba_rsp_wait_ack - TX ADDBA_RESP and wait ack
* @adapter: the adapter to TX
* @ra: receiver address
* @tid: tid
* @status: status code
* @size: the announced AMPDU buffer size
* @try_cnt: the maximal TX count to try
* @wait_ms: == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
*/
inline u8 issue_addba_rsp_wait_ack(_adapter *adapter, unsigned char *ra, u8 tid, u16 status, u8 size, int try_cnt, int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(adapter)))
goto exit;
do {
ret = issue_action_ba(adapter, ra, RTW_WLAN_ACTION_ADDBA_RESP
, tid
, size
, status
, 0 /* unused */
, _TRUE
);
i++;
if (RTW_CANNOT_RUN(adapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
/* goto exit; */
#endif
}
if (try_cnt && wait_ms) {
RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" status:=%u tid=%u size:%u%s, %d/%d in %u ms\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), status, tid, size
, ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
/**
* issue_del_ba - TX DELBA
* @adapter: the adapter to TX
* @ra: receiver address
* @tid: tid
* @reason: reason code
* @initiator: if we are the initiator of AMPDU association. used by DELBA
*/
inline void issue_del_ba(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator)
{
issue_action_ba(adapter, ra, RTW_WLAN_ACTION_DELBA
, tid
, 0 /* unused */
, reason
, initiator
, _FALSE
);
RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" reason=%u, tid=%u, initiator=%u\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), reason, tid, initiator);
}
/**
* issue_del_ba_ex - TX DELBA with xmit ack options
* @adapter: the adapter to TX
* @ra: receiver address
* @tid: tid
* @reason: reason code
* @initiator: if we are the initiator of AMPDU association. used by DELBA
* @try_cnt: the maximal TX count to try
* @wait_ms: == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
*/
int issue_del_ba_ex(_adapter *adapter, unsigned char *ra, u8 tid, u16 reason, u8 initiator
, int try_cnt, int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(adapter)))
goto exit;
do {
ret = issue_action_ba(adapter, ra, RTW_WLAN_ACTION_DELBA
, tid
, 0 /* unused */
, reason
, initiator
, wait_ms > 0 ? _TRUE : _FALSE
);
i++;
if (RTW_CANNOT_RUN(adapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
/* goto exit; */
#endif
}
if (try_cnt && wait_ms) {
RTW_INFO(FUNC_ADPT_FMT" ra="MAC_FMT" reason=%u, tid=%u, initiator=%u%s, %d/%d in %u ms\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(ra), reason, tid, initiator
, ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
void issue_action_BSSCoexistPacket(_adapter *padapter)
{
_irqL irqL;
_list *plist, *phead;
unsigned char category, action;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct wlan_network *pnetwork = NULL;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
_queue *queue = &(pmlmepriv->scanned_queue);
u8 InfoContent[16] = {0};
u8 ICS[8][15];
#ifdef CONFIG_80211N_HT
if ((pmlmepriv->num_FortyMHzIntolerant == 0) && (pmlmepriv->num_sta_no_ht == 0))
return;
if (_TRUE == pmlmeinfo->bwmode_updated)
return;
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return;
RTW_INFO("%s\n", __FUNCTION__);
category = RTW_WLAN_CATEGORY_PUBLIC;
action = ACT_PUBLIC_BSSCOEXIST;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
/* TODO calculate 40Mhz intolerant via ch and ch offset */
/* if (pmlmepriv->num_FortyMHzIntolerant > 0) */
{
u8 iedata = 0;
iedata |= BIT(2);/* 20 MHz BSS Width Request */
pframe = rtw_set_ie(pframe, EID_BSSCoexistence, 1, &iedata, &(pattrib->pktlen));
}
/* */
_rtw_memset(ICS, 0, sizeof(ICS));
if (pmlmepriv->num_sta_no_ht > 0) {
int i;
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
while (1) {
int len;
u8 *p;
WLAN_BSSID_EX *pbss_network;
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
plist = get_next(plist);
pbss_network = (WLAN_BSSID_EX *)&pnetwork->network;
p = rtw_get_ie(pbss_network->IEs + _FIXED_IE_LENGTH_, _HT_CAPABILITY_IE_, &len, pbss_network->IELength - _FIXED_IE_LENGTH_);
if ((p == NULL) || (len == 0)) { /* non-HT */
if ((pbss_network->Configuration.DSConfig <= 0) || (pbss_network->Configuration.DSConfig > 14))
continue;
ICS[0][pbss_network->Configuration.DSConfig] = 1;
if (ICS[0][0] == 0)
ICS[0][0] = 1;
}
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
for (i = 0; i < 8; i++) {
if (ICS[i][0] == 1) {
int j, k = 0;
InfoContent[k] = i;
/* SET_BSS_INTOLERANT_ELE_REG_CLASS(InfoContent,i); */
k++;
for (j = 1; j <= 14; j++) {
if (ICS[i][j] == 1) {
if (k < 16) {
InfoContent[k] = j; /* channel number */
/* SET_BSS_INTOLERANT_ELE_CHANNEL(InfoContent+k, j); */
k++;
}
}
}
pframe = rtw_set_ie(pframe, EID_BSSIntolerantChlReport, k, InfoContent, &(pattrib->pktlen));
}
}
}
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
#endif /* CONFIG_80211N_HT */
}
/* Spatial Multiplexing Powersave (SMPS) action frame */
int _issue_action_SM_PS(_adapter *padapter , unsigned char *raddr , u8 NewMimoPsMode , u8 wait_ack)
{
int ret = _FAIL;
unsigned char category = RTW_WLAN_CATEGORY_HT;
u8 action = RTW_WLAN_ACTION_HT_SM_PS;
u8 sm_power_control = 0;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (NewMimoPsMode == WLAN_HT_CAP_SM_PS_DISABLED) {
sm_power_control = sm_power_control & ~(BIT(0)); /* SM Power Save Enable = 0 SM Power Save Disable */
} else if (NewMimoPsMode == WLAN_HT_CAP_SM_PS_STATIC) {
sm_power_control = sm_power_control | BIT(0); /* SM Power Save Enable = 1 SM Power Save Enable */
sm_power_control = sm_power_control & ~(BIT(1)); /* SM Mode = 0 Static Mode */
} else if (NewMimoPsMode == WLAN_HT_CAP_SM_PS_DYNAMIC) {
sm_power_control = sm_power_control | BIT(0); /* SM Power Save Enable = 1 SM Power Save Enable */
sm_power_control = sm_power_control | BIT(1); /* SM Mode = 1 Dynamic Mode */
} else
return ret;
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
return ret;
RTW_INFO("%s, sm_power_control=%u, NewMimoPsMode=%u\n", __FUNCTION__ , sm_power_control , NewMimoPsMode);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return ret;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN); /* RA */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN); /* TA */
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN); /* DA = RA */
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* category, action */
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(sm_power_control), &(pattrib->pktlen));
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
if (ret != _SUCCESS)
RTW_INFO("%s, ack to\n", __func__);
return ret;
}
/*
* wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
* wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
* try_cnt means the maximal TX count to try
*/
int issue_action_SM_PS_wait_ack(_adapter *padapter, unsigned char *raddr, u8 NewMimoPsMode, int try_cnt, int wait_ms)
{
int ret = _FAIL;
int i = 0;
systime start = rtw_get_current_time();
if (rtw_rfctl_is_tx_blocked_by_ch_waiting(adapter_to_rfctl(padapter)))
goto exit;
do {
ret = _issue_action_SM_PS(padapter, raddr, NewMimoPsMode , wait_ms > 0 ? _TRUE : _FALSE);
i++;
if (RTW_CANNOT_RUN(padapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (raddr)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", %s , %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(raddr),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", %s , %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
int issue_action_SM_PS(_adapter *padapter , unsigned char *raddr , u8 NewMimoPsMode)
{
RTW_INFO("%s to "MAC_FMT"\n", __func__, MAC_ARG(raddr));
return _issue_action_SM_PS(padapter, raddr, NewMimoPsMode , _FALSE);
}
/**
* _send_delba_sta_tid - Cancel the AMPDU association for the specific @sta, @tid
* @adapter: the adapter to which @sta belongs
* @initiator: if we are the initiator of AMPDU association
* @sta: the sta to be checked
* @tid: the tid to be checked
* @force: cancel and send DELBA even when no AMPDU association is setup
* @wait_ack: send delba with xmit ack (valid when initiator == 0)
*
* Returns:
* _FAIL if sta is NULL
* when initiator is 1, always _SUCCESS
* when initiator is 0, _SUCCESS if DELBA is acked
*/
static unsigned int _send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
, u8 force, int wait_ack)
{
int ret = _SUCCESS;
if (sta == NULL) {
ret = _FAIL;
goto exit;
}
if (initiator == 0) {
/* recipient */
if (force || sta->recvreorder_ctrl[tid].enable == _TRUE) {
u8 ampdu_size_bak = sta->recvreorder_ctrl[tid].ampdu_size;
sta->recvreorder_ctrl[tid].enable = _FALSE;
sta->recvreorder_ctrl[tid].ampdu_size = RX_AMPDU_SIZE_INVALID;
if (rtw_del_rx_ampdu_test_trigger_no_tx_fail())
ret = _FAIL;
else if (wait_ack)
ret = issue_del_ba_ex(adapter, sta->cmn.mac_addr, tid, 37, initiator, 3, 1);
else
issue_del_ba(adapter, sta->cmn.mac_addr, tid, 37, initiator);
if (ret == _FAIL && sta->recvreorder_ctrl[tid].enable == _FALSE)
sta->recvreorder_ctrl[tid].ampdu_size = ampdu_size_bak;
}
} else if (initiator == 1) {
/* originator */
#ifdef CONFIG_80211N_HT
if (force || sta->htpriv.agg_enable_bitmap & BIT(tid)) {
sta->htpriv.agg_enable_bitmap &= ~BIT(tid);
sta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
issue_del_ba(adapter, sta->cmn.mac_addr, tid, 37, initiator);
}
#endif
}
exit:
return ret;
}
inline unsigned int send_delba_sta_tid(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
, u8 force)
{
return _send_delba_sta_tid(adapter, initiator, sta, tid, force, 0);
}
inline unsigned int send_delba_sta_tid_wait_ack(_adapter *adapter, u8 initiator, struct sta_info *sta, u8 tid
, u8 force)
{
return _send_delba_sta_tid(adapter, initiator, sta, tid, force, 1);
}
unsigned int send_delba(_adapter *padapter, u8 initiator, u8 *addr)
{
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta = NULL;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u16 tid;
if ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
return _SUCCESS;
psta = rtw_get_stainfo(pstapriv, addr);
if (psta == NULL)
return _SUCCESS;
#if 0
RTW_INFO("%s:%s\n", __func__, (initiator == 0) ? "RX_DIR" : "TX_DIR");
if (initiator == 1) /* originator */
RTW_INFO("tx agg_enable_bitmap(0x%08x)\n", psta->htpriv.agg_enable_bitmap);
#endif
for (tid = 0; tid < TID_NUM; tid++)
send_delba_sta_tid(padapter, initiator, psta, tid, 0);
return _SUCCESS;
}
unsigned int send_beacon(_adapter *padapter)
{
#if defined(CONFIG_PCI_HCI) && !defined(CONFIG_PCI_BCN_POLLING)
#ifdef CONFIG_FW_HANDLE_TXBCN
u8 vap_id = padapter->vap_id;
/* bypass TX BCN because vap_id is invalid*/
if (vap_id == CONFIG_LIMITED_AP_NUM)
return _SUCCESS;
#endif
/* bypass TX BCN queue because op ch is switching/waiting */
if (check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
|| IS_CH_WAITING(adapter_to_rfctl(padapter))
)
return _SUCCESS;
/* RTW_INFO("%s\n", __FUNCTION__); */
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
/* 8192EE Port select for Beacon DL */
rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
#ifdef CONFIG_FW_HANDLE_TXBCN
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
#endif
issue_beacon(padapter, 0);
#ifdef CONFIG_FW_HANDLE_TXBCN
vap_id = 0xFF;
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
#endif
#ifdef RTL8814AE_SW_BCN
if (GET_HAL_DATA(padapter)->bCorrectBCN != 0)
RTW_INFO("%s, line%d, Warnning, pHalData->bCorrectBCN != 0\n", __func__, __LINE__);
GET_HAL_DATA(padapter)->bCorrectBCN = 1;
#endif
return _SUCCESS;
#endif
/* CONFIG_PCI_BCN_POLLING is for pci interface beacon polling mode */
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)|| defined(CONFIG_PCI_BCN_POLLING)
u8 bxmitok = _FALSE;
int issue = 0;
int poll = 0;
systime start = rtw_get_current_time();
#ifdef CONFIG_FW_HANDLE_TXBCN
u8 vap_id = padapter->vap_id;
/* bypass TX BCN because vap_id is invalid*/
if (vap_id == CONFIG_LIMITED_AP_NUM)
return _SUCCESS;
#endif
/* bypass TX BCN queue because op ch is switching/waiting */
if (check_fwstate(&padapter->mlmepriv, WIFI_OP_CH_SWITCHING)
|| IS_CH_WAITING(adapter_to_rfctl(padapter))
)
return _SUCCESS;
#if defined(CONFIG_USB_HCI)
#if defined(CONFIG_RTL8812A)
if (IS_FULL_SPEED_USB(padapter)) {
issue_beacon(padapter, 300);
bxmitok = _TRUE;
} else
#endif
#endif
{
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_VALID, NULL);
rtw_hal_set_hwreg(padapter, HW_VAR_DL_BCN_SEL, NULL);
#ifdef CONFIG_FW_HANDLE_TXBCN
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
#endif
do {
#if defined(CONFIG_PCI_BCN_POLLING)
issue_beacon(padapter, 0);
#else
issue_beacon(padapter, 100);
#endif
issue++;
do {
#if defined(CONFIG_PCI_BCN_POLLING)
rtw_msleep_os(1);
#else
rtw_yield_os();
#endif
rtw_hal_get_hwreg(padapter, HW_VAR_BCN_VALID, (u8 *)(&bxmitok));
poll++;
} while ((poll % 10) != 0 && _FALSE == bxmitok && !RTW_CANNOT_RUN(padapter));
#if defined(CONFIG_PCI_BCN_POLLING)
rtw_hal_unmap_beacon_icf(padapter);
#endif
} while (bxmitok == _FALSE && (issue < 100) && !RTW_CANNOT_RUN(padapter));
#ifdef CONFIG_FW_HANDLE_TXBCN
vap_id = 0xFF;
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_HEAD_SEL, &vap_id);
#endif
}
if (RTW_CANNOT_RUN(padapter))
return _FAIL;
if (_FALSE == bxmitok) {
RTW_INFO("%s fail! %u ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
#ifdef CONFIG_BCN_RECOVERY
GET_HAL_DATA(padapter)->issue_bcn_fail++;
#endif /*CONFIG_BCN_RECOVERY*/
return _FAIL;
} else {
u32 passing_time = rtw_get_passing_time_ms(start);
if (passing_time > 100 || issue > 3)
RTW_INFO("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
else if (0)
RTW_INFO("%s success, issue:%d, poll:%d, %u ms\n", __FUNCTION__, issue, poll, rtw_get_passing_time_ms(start));
#ifdef CONFIG_FW_CORRECT_BCN
rtw_hal_fw_correct_bcn(padapter);
#endif
return _SUCCESS;
}
#endif /*defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)*/
}
/****************************************************************************
Following are some utitity fuctions for WiFi MLME
*****************************************************************************/
BOOLEAN IsLegal5GChannel(
PADAPTER Adapter,
u8 channel)
{
int i = 0;
u8 Channel_5G[45] = {36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58,
60, 62, 64, 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122,
124, 126, 128, 130, 132, 134, 136, 138, 140, 149, 151, 153, 155, 157, 159,
161, 163, 165
};
for (i = 0; i < sizeof(Channel_5G); i++)
if (channel == Channel_5G[i])
return _TRUE;
return _FALSE;
}
/* collect bss info from Beacon and Probe request/response frames. */
u8 collect_bss_info(_adapter *padapter, union recv_frame *precv_frame, WLAN_BSSID_EX *bssid)
{
int i;
sint len;
u8 *p;
u8 rf_path;
u16 val16, subtype;
u8 *pframe = precv_frame->u.hdr.rx_data;
u32 packet_len = precv_frame->u.hdr.len;
u8 ie_offset;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
len = packet_len - sizeof(struct rtw_ieee80211_hdr_3addr);
if (len > MAX_IE_SZ) {
/* RTW_INFO("IE too long for survey event\n"); */
return _FAIL;
}
_rtw_memset(bssid, 0, sizeof(WLAN_BSSID_EX));
subtype = get_frame_sub_type(pframe);
if (subtype == WIFI_BEACON) {
bssid->Reserved[0] = BSS_TYPE_BCN;
ie_offset = _BEACON_IE_OFFSET_;
} else {
/* FIXME : more type */
if (subtype == WIFI_PROBERSP) {
ie_offset = _PROBERSP_IE_OFFSET_;
bssid->Reserved[0] = BSS_TYPE_PROB_RSP;
} else if (subtype == WIFI_PROBEREQ) {
ie_offset = _PROBEREQ_IE_OFFSET_;
bssid->Reserved[0] = BSS_TYPE_PROB_REQ;
} else {
bssid->Reserved[0] = BSS_TYPE_UNDEF;
ie_offset = _FIXED_IE_LENGTH_;
}
}
bssid->Length = sizeof(WLAN_BSSID_EX) - MAX_IE_SZ + len;
/* below is to copy the information element */
bssid->IELength = len;
_rtw_memcpy(bssid->IEs, (pframe + sizeof(struct rtw_ieee80211_hdr_3addr)), bssid->IELength);
/* get the signal strength */
/* bssid->Rssi = precv_frame->u.hdr.attrib.SignalStrength; */ /* 0-100 index. */
bssid->Rssi = precv_frame->u.hdr.attrib.phy_info.recv_signal_power; /* in dBM.raw data */
bssid->PhyInfo.SignalQuality = precv_frame->u.hdr.attrib.phy_info.signal_quality;/* in percentage */
bssid->PhyInfo.SignalStrength = precv_frame->u.hdr.attrib.phy_info.signal_strength;/* in percentage */
/* get rx_snr */
if (precv_frame->u.hdr.attrib.data_rate >= DESC_RATE11M) {
bssid->PhyInfo.is_cck_rate = 0;
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++)
bssid->PhyInfo.rx_snr[rf_path] =
precv_frame->u.hdr.attrib.phy_info.rx_snr[rf_path];
} else
bssid->PhyInfo.is_cck_rate = 1;
#ifdef CONFIG_ANTENNA_DIVERSITY
rtw_hal_get_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &(bssid->PhyInfo.Optimum_antenna), NULL);
#endif
/* checking SSID */
p = rtw_get_ie(bssid->IEs + ie_offset, _SSID_IE_, &len, bssid->IELength - ie_offset);
if (p == NULL) {
RTW_INFO("marc: cannot find SSID for survey event\n");
return _FAIL;
}
if (*(p + 1)) {
if (len > NDIS_802_11_LENGTH_SSID) {
RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
return _FAIL;
}
_rtw_memcpy(bssid->Ssid.Ssid, (p + 2), *(p + 1));
bssid->Ssid.SsidLength = *(p + 1);
} else
bssid->Ssid.SsidLength = 0;
_rtw_memset(bssid->SupportedRates, 0, NDIS_802_11_LENGTH_RATES_EX);
/* checking rate info... */
i = 0;
p = rtw_get_ie(bssid->IEs + ie_offset, _SUPPORTEDRATES_IE_, &len, bssid->IELength - ie_offset);
if (p != NULL) {
if (len > NDIS_802_11_LENGTH_RATES_EX) {
RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
return _FAIL;
}
if (rtw_validate_value(_SUPPORTEDRATES_IE_, p+2, len) == _FALSE) {
rtw_absorb_ssid_ifneed(padapter, bssid, pframe);
RTW_DBG_DUMP("Invalidated Support Rate IE --", p, len+2);
return _FAIL;
}
_rtw_memcpy(bssid->SupportedRates, (p + 2), len);
i = len;
}
p = rtw_get_ie(bssid->IEs + ie_offset, _EXT_SUPPORTEDRATES_IE_, &len, bssid->IELength - ie_offset);
if (p != NULL) {
if (len > (NDIS_802_11_LENGTH_RATES_EX - i)) {
RTW_INFO("%s()-%d: IE too long (%d) for survey event\n", __FUNCTION__, __LINE__, len);
return _FAIL;
}
if (rtw_validate_value(_EXT_SUPPORTEDRATES_IE_, p+2, len) == _FALSE) {
rtw_absorb_ssid_ifneed(padapter, bssid, pframe);
RTW_DBG_DUMP("Invalidated EXT Support Rate IE --", p, len+2);
return _FAIL;
}
_rtw_memcpy(bssid->SupportedRates + i, (p + 2), len);
}
#ifdef CONFIG_P2P
if (subtype == WIFI_PROBEREQ) {
u8 *p2p_ie;
u32 p2p_ielen;
/* Set Listion Channel */
p2p_ie = rtw_get_p2p_ie(bssid->IEs, bssid->IELength, NULL, &p2p_ielen);
if (p2p_ie) {
u32 attr_contentlen = 0;
u8 listen_ch[5] = { 0x00 };
rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, listen_ch, &attr_contentlen);
bssid->Configuration.DSConfig = listen_ch[4];
} else {
/* use current channel */
bssid->Configuration.DSConfig = padapter->mlmeextpriv.cur_channel;
RTW_INFO("%s()-%d: Cannot get p2p_ie. set DSconfig to op_ch(%d)\n", __FUNCTION__, __LINE__, bssid->Configuration.DSConfig);
}
/* FIXME */
bssid->InfrastructureMode = Ndis802_11Infrastructure;
_rtw_memcpy(bssid->MacAddress, get_addr2_ptr(pframe), ETH_ALEN);
bssid->Privacy = 1;
return _SUCCESS;
}
#endif /* CONFIG_P2P */
if (bssid->IELength < 12)
return _FAIL;
/* Checking for DSConfig */
p = rtw_get_ie(bssid->IEs + ie_offset, _DSSET_IE_, &len, bssid->IELength - ie_offset);
bssid->Configuration.DSConfig = 0;
bssid->Configuration.Length = 0;
if (p)
bssid->Configuration.DSConfig = *(p + 2);
else {
/* In 5G, some ap do not have DSSET IE */
/* checking HT info for channel */
p = rtw_get_ie(bssid->IEs + ie_offset, _HT_ADD_INFO_IE_, &len, bssid->IELength - ie_offset);
if (p) {
struct HT_info_element *HT_info = (struct HT_info_element *)(p + 2);
bssid->Configuration.DSConfig = HT_info->primary_channel;
} else {
/* use current channel */
bssid->Configuration.DSConfig = rtw_get_oper_ch(padapter);
}
}
_rtw_memcpy(&bssid->Configuration.BeaconPeriod, rtw_get_beacon_interval_from_ie(bssid->IEs), 2);
bssid->Configuration.BeaconPeriod = le32_to_cpu(bssid->Configuration.BeaconPeriod);
val16 = rtw_get_capability((WLAN_BSSID_EX *)bssid);
if ((val16 & 0x03) == cap_ESS) {
bssid->InfrastructureMode = Ndis802_11Infrastructure;
_rtw_memcpy(bssid->MacAddress, get_addr2_ptr(pframe), ETH_ALEN);
} else if ((val16 & 0x03) == cap_IBSS){
bssid->InfrastructureMode = Ndis802_11IBSS;
_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
} else if ((val16 & 0x03) == 0x00){
u8 *mesh_id_ie, *mesh_conf_ie;
sint mesh_id_ie_len, mesh_conf_ie_len;
mesh_id_ie = rtw_get_ie(bssid->IEs + ie_offset, WLAN_EID_MESH_ID, &mesh_id_ie_len, bssid->IELength - ie_offset);
mesh_conf_ie = rtw_get_ie(bssid->IEs + ie_offset, WLAN_EID_MESH_CONFIG, &mesh_conf_ie_len, bssid->IELength - ie_offset);
if (mesh_id_ie || mesh_conf_ie) {
if (!mesh_id_ie) {
RTW_INFO("cannot find Mesh ID for survey event\n");
return _FAIL;
}
if (mesh_id_ie_len) {
if (mesh_id_ie_len > NDIS_802_11_LENGTH_SSID) {
RTW_INFO("Mesh ID too long (%d) for survey event\n", mesh_id_ie_len);
return _FAIL;
}
_rtw_memcpy(bssid->mesh_id.Ssid, (mesh_id_ie + 2), mesh_id_ie_len);
bssid->mesh_id.SsidLength = mesh_id_ie_len;
} else
bssid->mesh_id.SsidLength = 0;
if (!mesh_conf_ie) {
RTW_INFO("cannot find Mesh config for survey event\n");
return _FAIL;
}
if (mesh_conf_ie_len != 7) {
RTW_INFO("invalid Mesh conf IE len (%d) for survey event\n", mesh_conf_ie_len);
return _FAIL;
}
bssid->InfrastructureMode = Ndis802_11_mesh;
_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
} else {
/* default cases */
bssid->InfrastructureMode = Ndis802_11IBSS;
_rtw_memcpy(bssid->MacAddress, GetAddr3Ptr(pframe), ETH_ALEN);
}
}
if (val16 & BIT(4))
bssid->Privacy = 1;
else
bssid->Privacy = 0;
bssid->Configuration.ATIMWindow = 0;
/* 20/40 BSS Coexistence check */
if ((pregistrypriv->wifi_spec == 1) && (_FALSE == pmlmeinfo->bwmode_updated)) {
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
#ifdef CONFIG_80211N_HT
p = rtw_get_ie(bssid->IEs + ie_offset, _HT_CAPABILITY_IE_, &len, bssid->IELength - ie_offset);
if (p && len > 0) {
struct HT_caps_element *pHT_caps;
pHT_caps = (struct HT_caps_element *)(p + 2);
if (pHT_caps->u.HT_cap_element.HT_caps_info & BIT(14))
pmlmepriv->num_FortyMHzIntolerant++;
} else
pmlmepriv->num_sta_no_ht++;
#endif /* CONFIG_80211N_HT */
}
#if defined(DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) & 1
if (strcmp(bssid->Ssid.Ssid, DBG_RX_SIGNAL_DISPLAY_SSID_MONITORED) == 0) {
RTW_INFO("Receiving %s("MAC_FMT", DSConfig:%u) from ch%u with ss:%3u, sq:%3u, RawRSSI:%3ld\n"
, bssid->Ssid.Ssid, MAC_ARG(bssid->MacAddress), bssid->Configuration.DSConfig
, rtw_get_oper_ch(padapter)
, bssid->PhyInfo.SignalStrength, bssid->PhyInfo.SignalQuality, bssid->Rssi
);
}
#endif
/* mark bss info receving from nearby channel as SignalQuality 101 */
if (bssid->Configuration.DSConfig != rtw_get_oper_ch(padapter))
bssid->PhyInfo.SignalQuality = 101;
#ifdef CONFIG_RTW_80211K
p = rtw_get_ie(bssid->IEs + ie_offset, _EID_RRM_EN_CAP_IE_, &len, bssid->IELength - ie_offset);
if (p)
_rtw_memcpy(bssid->PhyInfo.rm_en_cap, (p + 2), *(p + 1));
/* save freerun counter */
bssid->PhyInfo.free_cnt = precv_frame->u.hdr.attrib.free_cnt;
#endif
return _SUCCESS;
}
void start_create_ibss(_adapter *padapter)
{
unsigned short caps;
u8 val8;
u8 join_type;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
u8 doiqk = _FALSE;
pmlmeext->cur_channel = (u8)pnetwork->Configuration.DSConfig;
pmlmeinfo->bcn_interval = get_beacon_interval(pnetwork);
/* update wireless mode */
update_wireless_mode(padapter);
/* udpate capability */
caps = rtw_get_capability((WLAN_BSSID_EX *)pnetwork);
update_capinfo(padapter, caps);
if (caps & cap_IBSS) { /* adhoc master */
/* set_opmode_cmd(padapter, adhoc); */ /* removed */
val8 = 0xcf;
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
doiqk = _TRUE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
/* switch channel */
set_channel_bwmode(padapter, pmlmeext->cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
doiqk = _FALSE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
beacon_timing_control(padapter);
/* set msr to WIFI_FW_ADHOC_STATE */
pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
Set_MSR(padapter, (pmlmeinfo->state & 0x3));
/* issue beacon */
if (send_beacon(padapter) == _FAIL) {
report_join_res(padapter, -1, WLAN_STATUS_UNSPECIFIED_FAILURE);
pmlmeinfo->state = WIFI_FW_NULL_STATE;
} else {
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
join_type = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
report_join_res(padapter, 1, WLAN_STATUS_SUCCESS);
pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
rtw_indicate_connect(padapter);
}
} else {
RTW_INFO("start_create_ibss, invalid cap:%x\n", caps);
return;
}
/* update bc/mc sta_info */
update_bmc_sta(padapter);
}
void start_clnt_join(_adapter *padapter)
{
unsigned short caps;
u8 val8;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
int beacon_timeout;
u8 ASIX_ID[] = {0x00, 0x0E, 0xC6};
/* update wireless mode */
update_wireless_mode(padapter);
/* udpate capability */
caps = rtw_get_capability((WLAN_BSSID_EX *)pnetwork);
update_capinfo(padapter, caps);
/* check if sta is ASIX peer and fix IOT issue if it is. */
if (_rtw_memcmp(get_my_bssid(&pmlmeinfo->network) , ASIX_ID , 3)) {
u8 iot_flag = _TRUE;
rtw_hal_set_hwreg(padapter, HW_VAR_ASIX_IOT, (u8 *)(&iot_flag));
}
if (caps & cap_ESS) {
Set_MSR(padapter, WIFI_FW_STATION_STATE);
val8 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) ? 0xcc : 0xcf;
#ifdef CONFIG_WAPI_SUPPORT
if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI) {
/* Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey. */
val8 = 0x4c;
}
#endif
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
#ifdef CONFIG_DEAUTH_BEFORE_CONNECT
/* Because of AP's not receiving deauth before */
/* AP may: 1)not response auth or 2)deauth us after link is complete */
/* issue deauth before issuing auth to deal with the situation */
/* Commented by Albert 2012/07/21 */
/* For the Win8 P2P connection, it will be hard to have a successful connection if this Wi-Fi doesn't connect to it. */
{
#ifdef CONFIG_P2P
_queue *queue = &(padapter->mlmepriv.scanned_queue);
_list *head = get_list_head(queue);
_list *pos = get_next(head);
struct wlan_network *scanned = NULL;
u8 ie_offset = 0;
_irqL irqL;
bool has_p2p_ie = _FALSE;
_enter_critical_bh(&(padapter->mlmepriv.scanned_queue.lock), &irqL);
for (pos = get_next(head); !rtw_end_of_queue_search(head, pos); pos = get_next(pos)) {
scanned = LIST_CONTAINOR(pos, struct wlan_network, list);
if (_rtw_memcmp(&(scanned->network.Ssid), &(pnetwork->Ssid), sizeof(NDIS_802_11_SSID)) == _TRUE
&& _rtw_memcmp(scanned->network.MacAddress, pnetwork->MacAddress, sizeof(NDIS_802_11_MAC_ADDRESS)) == _TRUE
) {
ie_offset = (scanned->network.Reserved[0] == BSS_TYPE_PROB_REQ ? 0 : 12);
if (rtw_get_p2p_ie(scanned->network.IEs + ie_offset, scanned->network.IELength - ie_offset, NULL, NULL))
has_p2p_ie = _TRUE;
break;
}
}
_exit_critical_bh(&(padapter->mlmepriv.scanned_queue.lock), &irqL);
if (scanned == NULL || rtw_end_of_queue_search(head, pos) || has_p2p_ie == _FALSE)
#endif /* CONFIG_P2P */
/* To avoid connecting to AP fail during resume process, change retry count from 5 to 1 */
issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
}
#endif /* CONFIG_DEAUTH_BEFORE_CONNECT */
/* here wait for receiving the beacon to start auth */
/* and enable a timer */
beacon_timeout = decide_wait_for_beacon_timeout(pmlmeinfo->bcn_interval);
set_link_timer(pmlmeext, beacon_timeout);
_set_timer(&padapter->mlmepriv.assoc_timer,
(REAUTH_TO * REAUTH_LIMIT) + (REASSOC_TO * REASSOC_LIMIT) + beacon_timeout);
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam(padapter)) {
rtw_ft_start_clnt_join(padapter);
} else
#endif
{
rtw_sta_linking_test_set_start();
pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
}
} else if (caps & cap_IBSS) { /* adhoc client */
Set_MSR(padapter, WIFI_FW_ADHOC_STATE);
val8 = 0xcf;
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
beacon_timing_control(padapter);
pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
report_join_res(padapter, 1, WLAN_STATUS_SUCCESS);
} else {
/* RTW_INFO("marc: invalid cap:%x\n", caps); */
return;
}
}
void start_clnt_auth(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
_cancel_timer_ex(&pmlmeext->link_timer);
pmlmeinfo->state &= (~WIFI_FW_AUTH_NULL);
pmlmeinfo->state |= WIFI_FW_AUTH_STATE;
pmlmeinfo->auth_seq = 1;
pmlmeinfo->reauth_count = 0;
pmlmeinfo->reassoc_count = 0;
pmlmeinfo->link_count = 0;
pmlmeext->retry = 0;
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam(padapter)) {
rtw_ft_set_status(padapter, RTW_FT_AUTHENTICATING_STA);
RTW_PRINT("start ft auth\n");
} else
#endif
RTW_PRINT("start auth\n");
#ifdef CONFIG_IOCTL_CFG80211
if (rtw_sec_chk_auth_type(padapter, NL80211_AUTHTYPE_SAE)) {
if (rtw_cached_pmkid(padapter, get_my_bssid(&pmlmeinfo->network)) != -1) {
RTW_INFO("SAE: PMKSA cache entry found\n");
padapter->securitypriv.auth_alg = WLAN_AUTH_OPEN;
goto no_external_auth;
}
RTW_PRINT("SAE: start external auth\n");
rtw_cfg80211_external_auth_request(padapter, NULL);
return;
}
no_external_auth:
#endif /* CONFIG_IOCTL_CFG80211 */
issue_auth(padapter, NULL, 0);
set_link_timer(pmlmeext, REAUTH_TO);
}
void start_clnt_assoc(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
_cancel_timer_ex(&pmlmeext->link_timer);
pmlmeinfo->state &= (~(WIFI_FW_AUTH_NULL | WIFI_FW_AUTH_STATE));
pmlmeinfo->state |= (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE);
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam(padapter))
issue_reassocreq(padapter);
else
#endif
issue_assocreq(padapter);
set_link_timer(pmlmeext, REASSOC_TO);
}
unsigned int receive_disconnect(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, u8 locally_generated)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (!(_rtw_memcmp(MacAddr, get_my_bssid(&pmlmeinfo->network), ETH_ALEN)))
return _SUCCESS;
RTW_INFO("%s\n", __FUNCTION__);
#ifdef CONFIG_RTW_REPEATER_SON
rtw_rson_do_disconnect(padapter);
#endif
if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
if (report_del_sta_event(padapter, MacAddr, reason, _TRUE, locally_generated) != _FAIL)
pmlmeinfo->state = WIFI_FW_NULL_STATE;
} else if (pmlmeinfo->state & WIFI_FW_LINKING_STATE) {
if (report_join_res(padapter, -2, reason) != _FAIL)
pmlmeinfo->state = WIFI_FW_NULL_STATE;
} else
RTW_INFO(FUNC_ADPT_FMT" - End to Disconnect\n", FUNC_ADPT_ARG(padapter));
#ifdef CONFIG_RTW_80211R
rtw_ft_roam_status_reset(padapter);
#endif
#ifdef CONFIG_RTW_WNM
rtw_wnm_reset_btm_state(padapter);
#endif
}
return _SUCCESS;
}
#ifdef CONFIG_80211D
static void process_80211d(PADAPTER padapter, WLAN_BSSID_EX *bssid)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
struct registry_priv *pregistrypriv;
struct mlme_ext_priv *pmlmeext;
RT_CHANNEL_INFO *chplan_new;
u8 channel;
u8 i;
pregistrypriv = &padapter->registrypriv;
pmlmeext = &padapter->mlmeextpriv;
/* Adjust channel plan by AP Country IE */
if (pregistrypriv->enable80211d
&& (!pmlmeext->update_channel_plan_by_ap_done)) {
u8 *ie, *p;
u32 len;
RT_CHANNEL_PLAN chplan_ap;
RT_CHANNEL_INFO *chplan_sta = NULL;
u8 country[4];
u8 fcn; /* first channel number */
u8 noc; /* number of channel */
u8 j, k;
ie = rtw_get_ie(bssid->IEs + _FIXED_IE_LENGTH_, _COUNTRY_IE_, &len, bssid->IELength - _FIXED_IE_LENGTH_);
if (!ie)
return;
if (len < 6)
return;
ie += 2;
p = ie;
ie += len;
_rtw_memset(country, 0, 4);
_rtw_memcpy(country, p, 3);
p += 3;
RTW_INFO("%s: 802.11d country=%s\n", __FUNCTION__, country);
i = 0;
while ((ie - p) >= 3) {
fcn = *(p++);
noc = *(p++);
p++;
for (j = 0; j < noc; j++) {
if (fcn <= 14)
channel = fcn + j; /* 2.4 GHz */
else
channel = fcn + j * 4; /* 5 GHz */
chplan_ap.Channel[i++] = channel;
}
}
chplan_ap.Len = i;
#ifdef CONFIG_RTW_DEBUG
i = 0;
RTW_INFO("%s: AP[%s] channel plan {", __FUNCTION__, bssid->Ssid.Ssid);
while ((i < chplan_ap.Len) && (chplan_ap.Channel[i] != 0)) {
_RTW_INFO("%02d,", chplan_ap.Channel[i]);
i++;
}
_RTW_INFO("}\n");
#endif
chplan_sta = rtw_malloc(sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
if (!chplan_sta)
goto done_update_chplan_from_ap;
_rtw_memcpy(chplan_sta, rfctl->channel_set, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
#ifdef CONFIG_RTW_DEBUG
i = 0;
RTW_INFO("%s: STA channel plan {", __FUNCTION__);
while ((i < MAX_CHANNEL_NUM) && (chplan_sta[i].ChannelNum != 0)) {
_RTW_INFO("%02d(%c),", chplan_sta[i].ChannelNum, chplan_sta[i].ScanType == SCAN_PASSIVE ? 'p' : 'a');
i++;
}
_RTW_INFO("}\n");
#endif
_rtw_memset(rfctl->channel_set, 0, sizeof(rfctl->channel_set));
chplan_new = rfctl->channel_set;
i = j = k = 0;
if (pregistrypriv->wireless_mode & WIRELESS_11G) {
do {
if ((i == MAX_CHANNEL_NUM)
|| (chplan_sta[i].ChannelNum == 0)
|| (chplan_sta[i].ChannelNum > 14))
break;
if ((j == chplan_ap.Len) || (chplan_ap.Channel[j] > 14))
break;
if (chplan_sta[i].ChannelNum == chplan_ap.Channel[j]) {
chplan_new[k].ChannelNum = chplan_ap.Channel[j];
chplan_new[k].ScanType = SCAN_ACTIVE;
i++;
j++;
k++;
} else if (chplan_sta[i].ChannelNum < chplan_ap.Channel[j]) {
chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
#if 0
chplan_new[k].ScanType = chplan_sta[i].ScanType;
#else
chplan_new[k].ScanType = SCAN_PASSIVE;
#endif
i++;
k++;
} else if (chplan_sta[i].ChannelNum > chplan_ap.Channel[j]) {
chplan_new[k].ChannelNum = chplan_ap.Channel[j];
chplan_new[k].ScanType = SCAN_ACTIVE;
j++;
k++;
}
} while (1);
/* change AP not support channel to Passive scan */
while ((i < MAX_CHANNEL_NUM)
&& (chplan_sta[i].ChannelNum != 0)
&& (chplan_sta[i].ChannelNum <= 14)) {
chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
#if 0
chplan_new[k].ScanType = chplan_sta[i].ScanType;
#else
chplan_new[k].ScanType = SCAN_PASSIVE;
#endif
i++;
k++;
}
/* add channel AP supported */
while ((j < chplan_ap.Len) && (chplan_ap.Channel[j] <= 14)) {
chplan_new[k].ChannelNum = chplan_ap.Channel[j];
chplan_new[k].ScanType = SCAN_ACTIVE;
j++;
k++;
}
} else {
/* keep original STA 2.4G channel plan */
while ((i < MAX_CHANNEL_NUM)
&& (chplan_sta[i].ChannelNum != 0)
&& (chplan_sta[i].ChannelNum <= 14)) {
chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
chplan_new[k].ScanType = chplan_sta[i].ScanType;
i++;
k++;
}
/* skip AP 2.4G channel plan */
while ((j < chplan_ap.Len) && (chplan_ap.Channel[j] <= 14))
j++;
}
if (pregistrypriv->wireless_mode & WIRELESS_11A) {
do {
if ((i >= MAX_CHANNEL_NUM)
|| (chplan_sta[i].ChannelNum == 0))
break;
if ((j == chplan_ap.Len) || (chplan_ap.Channel[j] == 0))
break;
if (chplan_sta[i].ChannelNum == chplan_ap.Channel[j]) {
chplan_new[k].ChannelNum = chplan_ap.Channel[j];
chplan_new[k].ScanType = SCAN_ACTIVE;
i++;
j++;
k++;
} else if (chplan_sta[i].ChannelNum < chplan_ap.Channel[j]) {
chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
#if 0
chplan_new[k].ScanType = chplan_sta[i].ScanType;
#else
chplan_new[k].ScanType = SCAN_PASSIVE;
#endif
i++;
k++;
} else if (chplan_sta[i].ChannelNum > chplan_ap.Channel[j]) {
chplan_new[k].ChannelNum = chplan_ap.Channel[j];
chplan_new[k].ScanType = SCAN_ACTIVE;
j++;
k++;
}
} while (1);
/* change AP not support channel to Passive scan */
while ((i < MAX_CHANNEL_NUM) && (chplan_sta[i].ChannelNum != 0)) {
chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
#if 0
chplan_new[k].ScanType = chplan_sta[i].ScanType;
#else
chplan_new[k].ScanType = SCAN_PASSIVE;
#endif
i++;
k++;
}
/* add channel AP supported */
while ((j < chplan_ap.Len) && (chplan_ap.Channel[j] != 0)) {
chplan_new[k].ChannelNum = chplan_ap.Channel[j];
chplan_new[k].ScanType = SCAN_ACTIVE;
j++;
k++;
}
} else {
/* keep original STA 5G channel plan */
while ((i < MAX_CHANNEL_NUM) && (chplan_sta[i].ChannelNum != 0)) {
chplan_new[k].ChannelNum = chplan_sta[i].ChannelNum;
chplan_new[k].ScanType = chplan_sta[i].ScanType;
i++;
k++;
}
}
pmlmeext->update_channel_plan_by_ap_done = 1;
#ifdef CONFIG_RTW_DEBUG
k = 0;
RTW_INFO("%s: new STA channel plan {", __FUNCTION__);
while ((k < MAX_CHANNEL_NUM) && (chplan_new[k].ChannelNum != 0)) {
_RTW_INFO("%02d(%c),", chplan_new[k].ChannelNum, chplan_new[k].ScanType == SCAN_PASSIVE ? 'p' : 'c');
k++;
}
_RTW_INFO("}\n");
#endif
#if 0
/* recover the right channel index */
channel = chplan_sta[pmlmeext->sitesurvey_res.channel_idx].ChannelNum;
k = 0;
while ((k < MAX_CHANNEL_NUM) && (chplan_new[k].ChannelNum != 0)) {
if (chplan_new[k].ChannelNum == channel) {
RTW_INFO("%s: change mlme_ext sitesurvey channel index from %d to %d\n",
__FUNCTION__, pmlmeext->sitesurvey_res.channel_idx, k);
pmlmeext->sitesurvey_res.channel_idx = k;
break;
}
k++;
}
#endif
done_update_chplan_from_ap:
if (chplan_sta)
rtw_mfree(chplan_sta, sizeof(RT_CHANNEL_INFO) * MAX_CHANNEL_NUM);
}
}
#endif
/****************************************************************************
Following are the functions to report events
*****************************************************************************/
void report_survey_event(_adapter *padapter, union recv_frame *precv_frame)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct survey_event *psurvey_evt;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext;
struct cmd_priv *pcmdpriv;
/* u8 *pframe = precv_frame->u.hdr.rx_data; */
/* uint len = precv_frame->u.hdr.len; */
RT_CHANNEL_INFO *chset = adapter_to_chset(padapter);
int ch_set_idx = -1;
if (!padapter)
return;
pmlmeext = &padapter->mlmeextpriv;
pcmdpriv = &padapter->cmdpriv;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
return;
cmdsz = (sizeof(struct survey_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
return;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct survey_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_Survey);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
psurvey_evt = (struct survey_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
if (collect_bss_info(padapter, precv_frame, (WLAN_BSSID_EX *)&psurvey_evt->bss) == _FAIL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pevtcmd, cmdsz);
return;
}
#ifdef CONFIG_80211D
process_80211d(padapter, &psurvey_evt->bss);
#endif
ch_set_idx = rtw_chset_search_ch(chset, psurvey_evt->bss.Configuration.DSConfig);
if (ch_set_idx >= 0) {
if (psurvey_evt->bss.InfrastructureMode == Ndis802_11Infrastructure) {
if (chset[ch_set_idx].ScanType == SCAN_PASSIVE
&& !rtw_is_dfs_ch(psurvey_evt->bss.Configuration.DSConfig)
) {
RTW_INFO("%s: change ch:%d to active\n", __func__, psurvey_evt->bss.Configuration.DSConfig);
chset[ch_set_idx].ScanType = SCAN_ACTIVE;
}
#ifdef CONFIG_DFS
if (hidden_ssid_ap(&psurvey_evt->bss))
chset[ch_set_idx].hidden_bss_cnt++;
#endif
}
}
rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
pmlmeext->sitesurvey_res.bss_cnt++;
return;
}
void report_surveydone_event(_adapter *padapter)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct surveydone_event *psurveydone_evt;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
return;
cmdsz = (sizeof(struct surveydone_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
return;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct surveydone_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_SurveyDone);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
psurveydone_evt = (struct surveydone_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
psurveydone_evt->bss_cnt = pmlmeext->sitesurvey_res.bss_cnt;
RTW_INFO("survey done event(%x) band:%d for "ADPT_FMT"\n", psurveydone_evt->bss_cnt, padapter->setband, ADPT_ARG(padapter));
rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
return;
}
u32 report_join_res(_adapter *padapter, int aid_res, u16 status)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct joinbss_event *pjoinbss_evt;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u32 ret = _FAIL;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
goto exit;
cmdsz = (sizeof(struct joinbss_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
goto exit;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct joinbss_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_JoinBss);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
pjoinbss_evt = (struct joinbss_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
_rtw_memcpy((unsigned char *)(&(pjoinbss_evt->network.network)), &(pmlmeinfo->network), sizeof(WLAN_BSSID_EX));
pjoinbss_evt->network.join_res = pjoinbss_evt->network.aid = aid_res;
RTW_INFO("report_join_res(%d, %u)\n", aid_res, status);
rtw_joinbss_event_prehandle(padapter, (u8 *)&pjoinbss_evt->network, status);
ret = rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
exit:
return ret;
}
void report_wmm_edca_update(_adapter *padapter)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct wmm_event *pwmm_event;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
return;
cmdsz = (sizeof(struct wmm_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
return;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct wmm_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_WMM);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
pwmm_event = (struct wmm_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
pwmm_event->wmm = 0;
rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
return;
}
u32 report_del_sta_event(_adapter *padapter, unsigned char *MacAddr, unsigned short reason, bool enqueue, u8 locally_generated)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct sta_info *psta;
int mac_id = -1;
struct stadel_event *pdel_sta_evt;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
/* prepare cmd parameter */
cmdsz = (sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
res = _FAIL;
goto exit;
}
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct stadel_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_DelSTA);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
pdel_sta_evt = (struct stadel_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
_rtw_memcpy((unsigned char *)(&(pdel_sta_evt->macaddr)), MacAddr, ETH_ALEN);
_rtw_memcpy((unsigned char *)(pdel_sta_evt->rsvd), (unsigned char *)(&reason), 2);
psta = rtw_get_stainfo(&padapter->stapriv, MacAddr);
if (psta)
mac_id = (int)psta->cmn.mac_id;
else
mac_id = (-1);
pdel_sta_evt->mac_id = mac_id;
pdel_sta_evt->locally_generated = locally_generated;
if (!enqueue) {
/* do directly */
rtw_stadel_event_callback(padapter, (u8 *)pdel_sta_evt);
rtw_mfree(pevtcmd, cmdsz);
} else {
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL) {
rtw_mfree(pevtcmd, cmdsz);
res = _FAIL;
goto exit;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
res = rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
}
exit:
RTW_INFO(FUNC_ADPT_FMT" "MAC_FMT" mac_id=%d, enqueue:%d, res:%u\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(MacAddr), mac_id, enqueue, res);
return res;
}
void report_add_sta_event(_adapter *padapter, unsigned char *MacAddr)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct stassoc_event *padd_sta_evt;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
return;
cmdsz = (sizeof(struct stassoc_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
return;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct stassoc_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_AddSTA);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
padd_sta_evt = (struct stassoc_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
_rtw_memcpy((unsigned char *)(&(padd_sta_evt->macaddr)), MacAddr, ETH_ALEN);
RTW_INFO("report_add_sta_event: add STA\n");
rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
return;
}
bool rtw_port_switch_chk(_adapter *adapter)
{
bool switch_needed = _FALSE;
#ifdef CONFIG_CONCURRENT_MODE
#ifdef CONFIG_RUNTIME_PORT_SWITCH
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct pwrctrl_priv *pwrctl = dvobj_to_pwrctl(dvobj);
_adapter *if_port0 = NULL;
_adapter *if_port1 = NULL;
struct mlme_ext_info *if_port0_mlmeinfo = NULL;
struct mlme_ext_info *if_port1_mlmeinfo = NULL;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
if (get_hw_port(dvobj->padapters[i]) == HW_PORT0) {
if_port0 = dvobj->padapters[i];
if_port0_mlmeinfo = &(if_port0->mlmeextpriv.mlmext_info);
} else if (get_hw_port(dvobj->padapters[i]) == HW_PORT1) {
if_port1 = dvobj->padapters[i];
if_port1_mlmeinfo = &(if_port1->mlmeextpriv.mlmext_info);
}
}
if (if_port0 == NULL) {
rtw_warn_on(1);
goto exit;
}
if (if_port1 == NULL) {
rtw_warn_on(1);
goto exit;
}
#ifdef DBG_RUNTIME_PORT_SWITCH
RTW_INFO(FUNC_ADPT_FMT" wowlan_mode:%u\n"
ADPT_FMT", port0, mlmeinfo->state:0x%08x, p2p_state:%d, %d\n"
ADPT_FMT", port1, mlmeinfo->state:0x%08x, p2p_state:%d, %d\n",
FUNC_ADPT_ARG(adapter), pwrctl->wowlan_mode,
ADPT_ARG(if_port0), if_port0_mlmeinfo->state, rtw_p2p_state(&if_port0->wdinfo), rtw_p2p_chk_state(&if_port0->wdinfo, P2P_STATE_NONE),
ADPT_ARG(if_port1), if_port1_mlmeinfo->state, rtw_p2p_state(&if_port1->wdinfo), rtw_p2p_chk_state(&if_port1->wdinfo, P2P_STATE_NONE));
#endif /* DBG_RUNTIME_PORT_SWITCH */
#ifdef CONFIG_WOWLAN
/* WOWLAN interface(primary, for now) should be port0 */
if (pwrctl->wowlan_mode == _TRUE) {
if (!is_primary_adapter(if_port0)) {
RTW_INFO("%s "ADPT_FMT" enable WOWLAN\n", __func__, ADPT_ARG(if_port1));
switch_needed = _TRUE;
}
goto exit;
}
#endif /* CONFIG_WOWLAN */
/* AP/Mesh should use port0 for ctl frame's ack */
if ((if_port1_mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
RTW_INFO("%s "ADPT_FMT" is AP/GO/Mesh\n", __func__, ADPT_ARG(if_port1));
switch_needed = _TRUE;
goto exit;
}
/* GC should use port0 for p2p ps */
if (((if_port1_mlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
&& (if_port1_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
#ifdef CONFIG_P2P
&& !rtw_p2p_chk_state(&if_port1->wdinfo, P2P_STATE_NONE)
#endif
&& !check_fwstate(&if_port1->mlmepriv, WIFI_UNDER_WPS)
) {
RTW_INFO("%s "ADPT_FMT" is GC\n", __func__, ADPT_ARG(if_port1));
switch_needed = _TRUE;
goto exit;
}
/* port1 linked, but port0 not linked */
if ((if_port1_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
&& !(if_port0_mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
&& ((if_port0_mlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)
) {
RTW_INFO("%s "ADPT_FMT" is SINGLE_LINK\n", __func__, ADPT_ARG(if_port1));
switch_needed = _TRUE;
goto exit;
}
exit:
#ifdef DBG_RUNTIME_PORT_SWITCH
RTW_INFO(FUNC_ADPT_FMT" ret:%d\n", FUNC_ADPT_ARG(adapter), switch_needed);
#endif /* DBG_RUNTIME_PORT_SWITCH */
#endif /* CONFIG_RUNTIME_PORT_SWITCH */
#endif /* CONFIG_CONCURRENT_MODE */
return switch_needed;
}
/****************************************************************************
Following are the event callback functions
*****************************************************************************/
/* for sta/adhoc mode */
void update_sta_info(_adapter *padapter, struct sta_info *psta)
{
_irqL irqL;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* ERP */
VCS_update(padapter, psta);
#ifdef CONFIG_80211N_HT
/* HT */
if (pmlmepriv->htpriv.ht_option) {
psta->htpriv.ht_option = _TRUE;
psta->htpriv.ampdu_enable = pmlmepriv->htpriv.ampdu_enable;
psta->htpriv.rx_ampdu_min_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & IEEE80211_HT_CAP_AMPDU_DENSITY) >> 2;
if (support_short_GI(padapter, &(pmlmeinfo->HT_caps), CHANNEL_WIDTH_20))
psta->htpriv.sgi_20m = _TRUE;
if (support_short_GI(padapter, &(pmlmeinfo->HT_caps), CHANNEL_WIDTH_40))
psta->htpriv.sgi_40m = _TRUE;
psta->qos_option = _TRUE;
psta->htpriv.ldpc_cap = pmlmepriv->htpriv.ldpc_cap;
psta->htpriv.stbc_cap = pmlmepriv->htpriv.stbc_cap;
psta->htpriv.beamform_cap = pmlmepriv->htpriv.beamform_cap;
_rtw_memcpy(&psta->htpriv.ht_cap, &pmlmeinfo->HT_caps, sizeof(struct rtw_ieee80211_ht_cap));
#ifdef CONFIG_BEAMFORMING
psta->htpriv.beamform_cap = pmlmepriv->htpriv.beamform_cap;
psta->cmn.bf_info.ht_beamform_cap = pmlmepriv->htpriv.beamform_cap;
#endif
} else
#endif /* CONFIG_80211N_HT */
{
#ifdef CONFIG_80211N_HT
psta->htpriv.ht_option = _FALSE;
psta->htpriv.ampdu_enable = _FALSE;
psta->htpriv.tx_amsdu_enable = _FALSE;
psta->htpriv.sgi_20m = _FALSE;
psta->htpriv.sgi_40m = _FALSE;
#endif /* CONFIG_80211N_HT */
psta->qos_option = _FALSE;
}
#ifdef CONFIG_80211N_HT
psta->htpriv.ch_offset = pmlmeext->cur_ch_offset;
psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
#endif /* CONFIG_80211N_HT */
psta->cmn.bw_mode = pmlmeext->cur_bwmode;
/* QoS */
if (pmlmepriv->qospriv.qos_option)
psta->qos_option = _TRUE;
#ifdef CONFIG_80211AC_VHT
_rtw_memcpy(&psta->vhtpriv, &pmlmepriv->vhtpriv, sizeof(struct vht_priv));
if (psta->vhtpriv.vht_option) {
psta->cmn.ra_info.is_vht_enable = _TRUE;
#ifdef CONFIG_BEAMFORMING
psta->vhtpriv.beamform_cap = pmlmepriv->vhtpriv.beamform_cap;
psta->cmn.bf_info.vht_beamform_cap = pmlmepriv->vhtpriv.beamform_cap;
#endif /*CONFIG_BEAMFORMING*/
}
#endif /* CONFIG_80211AC_VHT */
psta->cmn.ra_info.is_support_sgi = query_ra_short_GI(psta, rtw_get_tx_bw_mode(padapter, psta));
update_ldpc_stbc_cap(psta);
_enter_critical_bh(&psta->lock, &irqL);
psta->state = _FW_LINKED;
_exit_critical_bh(&psta->lock, &irqL);
}
static void rtw_mlmeext_disconnect(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 self_action = MLME_ACTION_UNKNOWN;
u8 state_backup = (pmlmeinfo->state & 0x03);
u8 ASIX_ID[] = {0x00, 0x0E, 0xC6};
if (MLME_IS_AP(padapter))
self_action = MLME_AP_STOPPED;
else if (MLME_IS_MESH(padapter))
self_action = MLME_MESH_STOPPED;
else if (MLME_IS_STA(padapter))
self_action = MLME_STA_DISCONNECTED;
else if (MLME_IS_ADHOC(padapter) || MLME_IS_ADHOC_MASTER(padapter))
self_action = MLME_ADHOC_STOPPED;
else {
RTW_INFO("state:0x%x\n", MLME_STATE(padapter));
rtw_warn_on(1);
}
/* set_opmode_cmd(padapter, infra_client_with_mlme); */
#ifdef CONFIG_HW_P0_TSF_SYNC
if (self_action == MLME_STA_DISCONNECTED)
correct_TSF(padapter, self_action);
#endif
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
if (self_action == MLME_STA_DISCONNECTED)
rtw_hal_rcr_set_chk_bssid(padapter, self_action);
/* set MSR to no link state->infra. mode */
Set_MSR(padapter, _HW_STATE_STATION_);
/* check if sta is ASIX peer and fix IOT issue if it is. */
if (_rtw_memcmp(get_my_bssid(&pmlmeinfo->network) , ASIX_ID , 3)) {
u8 iot_flag = _FALSE;
rtw_hal_set_hwreg(padapter, HW_VAR_ASIX_IOT, (u8 *)(&iot_flag));
}
pmlmeinfo->state = WIFI_FW_NULL_STATE;
#ifdef CONFIG_MCC_MODE
/* mcc disconnect setting before download LPS rsvd page */
rtw_hal_set_mcc_setting_disconnect(padapter);
#endif /* CONFIG_MCC_MODE */
if (state_backup == WIFI_FW_STATION_STATE) {
if (rtw_port_switch_chk(padapter) == _TRUE) {
rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
#ifdef CONFIG_LPS
{
_adapter *port0_iface = dvobj_get_port0_adapter(adapter_to_dvobj(padapter));
if (port0_iface)
rtw_lps_ctrl_wk_cmd(port0_iface, LPS_CTRL_CONNECT, RTW_CMDF_DIRECTLY);
}
#endif
}
}
/* switch to the 20M Hz mode after disconnect */
pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
#ifdef CONFIG_CTRL_TXSS_BY_TP
pmlmeext->txss_1ss = _FALSE;
#endif
#ifdef CONFIG_FCS_MODE
if (EN_FCS(padapter))
rtw_hal_set_hwreg(padapter, HW_VAR_STOP_FCS_MODE, NULL);
#endif
if (!(MLME_IS_STA(padapter) && MLME_IS_OPCH_SW(padapter))) {
/* DFS and channel status no need to check here for STA under OPCH_SW */
u8 ch, bw, offset;
#ifdef CONFIG_DFS_MASTER
rtw_dfs_rd_en_decision(padapter, self_action, 0);
#endif
if (rtw_mi_get_ch_setting_union_no_self(padapter, &ch, &bw, &offset) != 0) {
set_channel_bwmode(padapter, ch, offset, bw);
rtw_mi_update_union_chan_inf(padapter, ch, offset, bw);
}
}
flush_all_cam_entry(padapter);
_cancel_timer_ex(&pmlmeext->link_timer);
/* pmlmepriv->LinkDetectInfo.TrafficBusyState = _FALSE; */
pmlmepriv->LinkDetectInfo.TrafficTransitionCount = 0;
pmlmepriv->LinkDetectInfo.LowPowerTransitionCount = 0;
#ifdef CONFIG_TDLS
padapter->tdlsinfo.ap_prohibited = _FALSE;
/* For TDLS channel switch, currently we only allow it to work in wifi logo test mode */
if (padapter->registrypriv.wifi_spec == 1)
padapter->tdlsinfo.ch_switch_prohibited = _FALSE;
#endif /* CONFIG_TDLS */
#ifdef CONFIG_WMMPS_STA
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
/* reset currently related uapsd setting when the connection has broken */
pmlmepriv->qospriv.uapsd_max_sp_len = 0;
pmlmepriv->qospriv.uapsd_tid = 0;
pmlmepriv->qospriv.uapsd_tid_delivery_enabled = 0;
pmlmepriv->qospriv.uapsd_tid_trigger_enabled = 0;
pmlmepriv->qospriv.uapsd_ap_supported = 0;
}
#endif /* CONFIG_WMMPS_STA */
#ifdef CONFIG_RTS_FULL_BW
rtw_set_rts_bw(padapter);
#endif/*CONFIG_RTS_FULL_BW*/
}
void mlmeext_joinbss_event_callback(_adapter *padapter, int join_res)
{
struct sta_info *psta;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
struct sta_priv *pstapriv = &padapter->stapriv;
u8 join_type;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
#ifndef CONFIG_IOCTL_CFG80211
struct security_priv *psecuritypriv = &padapter->securitypriv;
#endif
if (pmlmepriv->wpa_phase == _TRUE)
pmlmepriv->wpa_phase = _FALSE;
if (join_res < 0) {
join_type = 1;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, null_addr);
if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE)
rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_DISCONNECTED);
goto exit_mlmeext_joinbss_event_callback;
}
#ifdef CONFIG_ARP_KEEP_ALIVE
pmlmepriv->bGetGateway = 1;
pmlmepriv->GetGatewayTryCnt = 0;
#endif
if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
/* update bc/mc sta_info */
update_bmc_sta(padapter);
}
/* turn on dynamic functions */
/* Switch_DM_Func(padapter, DYNAMIC_ALL_FUNC_ENABLE, _TRUE); */
/* update IOT-releated issue */
update_IOT_info(padapter);
#ifdef CONFIG_RTS_FULL_BW
rtw_set_rts_bw(padapter);
#endif/*CONFIG_RTS_FULL_BW*/
rtw_hal_set_hwreg(padapter, HW_VAR_BASIC_RATE, cur_network->SupportedRates);
/* BCN interval */
rtw_hal_set_hwreg(padapter, HW_VAR_BEACON_INTERVAL, (u8 *)(&pmlmeinfo->bcn_interval));
/* udpate capability */
update_capinfo(padapter, pmlmeinfo->capability);
/* WMM, Update EDCA param */
WMMOnAssocRsp(padapter);
#ifdef CONFIG_80211N_HT
/* HT */
HTOnAssocRsp(padapter);
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
/* VHT */
VHTOnAssocRsp(padapter);
#endif
psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
if (psta) { /* only for infra. mode */
psta->wireless_mode = pmlmeext->cur_wireless_mode;
/* set per sta rate after updating HT cap. */
set_sta_rate(padapter, psta);
rtw_sta_media_status_rpt(padapter, psta, 1);
/* wakeup macid after join bss successfully to ensure
the subsequent data frames can be sent out normally */
rtw_hal_macid_wakeup(padapter, psta->cmn.mac_id);
rtw_xmit_queue_clear(psta);
}
#ifndef CONFIG_IOCTL_CFG80211
if (is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm))
rtw_sec_restore_wep_key(padapter);
#endif /* CONFIG_IOCTL_CFG80211 */
if (rtw_port_switch_chk(padapter) == _TRUE)
rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
join_type = 2;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
if ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE) {
rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTED);
/* correcting TSF */
correct_TSF(padapter, MLME_STA_CONNECTED);
/* set_link_timer(pmlmeext, DISCONNECT_TO); */
}
#ifdef CONFIG_LPS
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
if (get_hw_port(padapter) == HW_PORT0)
#endif
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_CONNECT, RTW_CMDF_DIRECTLY);
#endif
#ifdef CONFIG_BEAMFORMING
if (psta)
beamforming_wk_cmd(padapter, BEAMFORMING_CTRL_ENTER, (u8 *)psta, sizeof(struct sta_info), 0);
#endif/*CONFIG_BEAMFORMING*/
exit_mlmeext_joinbss_event_callback:
rtw_join_done_chk_ch(padapter, join_res);
#ifdef CONFIG_RTW_REPEATER_SON
rtw_rson_join_done(padapter);
#endif
RTW_INFO("=>%s - End to Connection without 4-way\n", __FUNCTION__);
}
/* currently only adhoc mode will go here */
void mlmeext_sta_add_event_callback(_adapter *padapter, struct sta_info *psta)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 join_type;
RTW_INFO("%s\n", __FUNCTION__);
if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) { /* adhoc master or sta_count>1 */
/* nothing to do */
} else { /* adhoc client */
/* update TSF Value */
/* update_TSF(pmlmeext, pframe, len); */
/* correcting TSF */
correct_TSF(padapter, MLME_ADHOC_STARTED);
/* start beacon */
if (send_beacon(padapter) == _FAIL)
rtw_warn_on(1);
pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
}
join_type = 2;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
}
/* update adhoc sta_info */
update_sta_info(padapter, psta);
rtw_hal_update_sta_ra_info(padapter, psta);
/* ToDo: HT for Ad-hoc */
psta->wireless_mode = rtw_check_network_type(psta->bssrateset, psta->bssratelen, pmlmeext->cur_channel);
rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _TRUE);
/* rate radaptive */
Update_RA_Entry(padapter, psta);
}
void mlmeext_sta_del_event_callback(_adapter *padapter)
{
if (is_client_associated_to_ap(padapter) || is_IBSS_empty(padapter))
rtw_mlmeext_disconnect(padapter);
}
/****************************************************************************
Following are the functions for the timer handlers
*****************************************************************************/
void _linked_info_dump(_adapter *padapter)
{
if (padapter->bLinkInfoDump) {
rtw_hal_get_def_var(padapter, HW_DEF_RA_INFO_DUMP, RTW_DBGDUMP);
rtw_hal_set_odm_var(padapter, HAL_ODM_RX_INFO_DUMP, RTW_DBGDUMP, _FALSE);
}
}
/********************************************************************
When station does not receive any packet in MAX_CONTINUAL_NORXPACKET_COUNT*2 seconds,
recipient station will teardown the block ack by issuing DELBA frame.
*********************************************************************/
void rtw_delba_check(_adapter *padapter, struct sta_info *psta, u8 from_timer)
{
int i = 0;
int ret = _SUCCESS;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/*
IOT issue,occur Broadcom ap(Buffalo WZR-D1800H,Netgear R6300).
AP is originator.AP does not transmit unicast packets when STA response its BAR.
This case probably occur ap issue BAR after AP builds BA.
Follow 802.11 spec, STA shall maintain an inactivity timer for every negotiated Block Ack setup.
The inactivity timer is not reset when MPDUs corresponding to other TIDs are received.
*/
if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) {
for (i = 0; i < TID_NUM ; i++) {
if ((psta->recvreorder_ctrl[i].enable) &&
(sta_rx_data_qos_pkts(psta, i) == sta_last_rx_data_qos_pkts(psta, i)) ) {
if (_TRUE == rtw_inc_and_chk_continual_no_rx_packet(psta, i)) {
/* send a DELBA frame to the peer STA with the Reason Code field set to TIMEOUT */
if (!from_timer)
ret = issue_del_ba_ex(padapter, psta->cmn.mac_addr, i, 39, 0, 3, 1);
else
issue_del_ba(padapter, psta->cmn.mac_addr, i, 39, 0);
psta->recvreorder_ctrl[i].enable = _FALSE;
if (ret != _FAIL)
psta->recvreorder_ctrl[i].ampdu_size = RX_AMPDU_SIZE_INVALID;
rtw_reset_continual_no_rx_packet(psta, i);
}
} else {
/* The inactivity timer is reset when MPDUs to the TID is received. */
rtw_reset_continual_no_rx_packet(psta, i);
}
}
}
}
u8 chk_ap_is_alive(_adapter *padapter, struct sta_info *psta)
{
u8 ret = _FALSE;
#ifdef DBG_EXPIRATION_CHK
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
RTW_INFO(FUNC_ADPT_FMT" rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
", retry:%u\n"
, FUNC_ADPT_ARG(padapter)
, STA_RX_PKTS_DIFF_ARG(psta)
, psta->sta_stats.rx_beacon_pkts - psta->sta_stats.last_rx_beacon_pkts
, psta->sta_stats.rx_probersp_pkts - psta->sta_stats.last_rx_probersp_pkts
/*, psta->sta_stats.rx_probersp_bm_pkts - psta->sta_stats.last_rx_probersp_bm_pkts
, psta->sta_stats.rx_probersp_uo_pkts - psta->sta_stats.last_rx_probersp_uo_pkts
, psta->sta_stats.rx_probereq_pkts - psta->sta_stats.last_rx_probereq_pkts
, pmlmeinfo->bcn_interval*/
, pmlmeext->retry
);
RTW_INFO(FUNC_ADPT_FMT" tx_pkts:%llu, link_count:%u\n", FUNC_ADPT_ARG(padapter)
, sta_tx_pkts(psta)
, pmlmeinfo->link_count
);
#endif
if ((sta_rx_data_pkts(psta) == sta_last_rx_data_pkts(psta))
&& sta_rx_beacon_pkts(psta) == sta_last_rx_beacon_pkts(psta)
&& sta_rx_probersp_pkts(psta) == sta_last_rx_probersp_pkts(psta)
)
ret = _FALSE;
else
ret = _TRUE;
sta_update_last_rx_pkts(psta);
return ret;
}
u8 chk_adhoc_peer_is_alive(struct sta_info *psta)
{
u8 ret = _TRUE;
#ifdef DBG_EXPIRATION_CHK
RTW_INFO("sta:"MAC_FMT", rssi:%d, rx:"STA_PKTS_FMT", beacon:%llu, probersp_to_self:%llu"
/*", probersp_bm:%llu, probersp_uo:%llu, probereq:%llu, BI:%u"*/
", expire_to:%u\n"
, MAC_ARG(psta->cmn.mac_addr)
, psta->cmn.rssi_stat.rssi
, STA_RX_PKTS_DIFF_ARG(psta)
, psta->sta_stats.rx_beacon_pkts - psta->sta_stats.last_rx_beacon_pkts
, psta->sta_stats.rx_probersp_pkts - psta->sta_stats.last_rx_probersp_pkts
/*, psta->sta_stats.rx_probersp_bm_pkts - psta->sta_stats.last_rx_probersp_bm_pkts
, psta->sta_stats.rx_probersp_uo_pkts - psta->sta_stats.last_rx_probersp_uo_pkts
, psta->sta_stats.rx_probereq_pkts - psta->sta_stats.last_rx_probereq_pkts
, pmlmeinfo->bcn_interval*/
, psta->expire_to
);
#endif
if (sta_rx_data_pkts(psta) == sta_last_rx_data_pkts(psta)
&& sta_rx_beacon_pkts(psta) == sta_last_rx_beacon_pkts(psta)
&& sta_rx_probersp_pkts(psta) == sta_last_rx_probersp_pkts(psta))
ret = _FALSE;
sta_update_last_rx_pkts(psta);
return ret;
}
#ifdef CONFIG_TDLS
u8 chk_tdls_peer_sta_is_alive(_adapter *padapter, struct sta_info *psta)
{
if ((psta->sta_stats.rx_data_pkts == psta->sta_stats.last_rx_data_pkts)
&& (psta->sta_stats.rx_tdls_disc_rsp_pkts == psta->sta_stats.last_rx_tdls_disc_rsp_pkts))
return _FALSE;
return _TRUE;
}
void linked_status_chk_tdls(_adapter *padapter)
{
struct candidate_pool {
struct sta_info *psta;
u8 addr[ETH_ALEN];
};
struct sta_priv *pstapriv = &padapter->stapriv;
_irqL irqL;
u8 ack_chk;
struct sta_info *psta;
int i, num_teardown = 0, num_checkalive = 0;
_list *plist, *phead;
struct tdls_txmgmt txmgmt;
struct candidate_pool checkalive[MAX_ALLOWED_TDLS_STA_NUM];
struct candidate_pool teardown[MAX_ALLOWED_TDLS_STA_NUM];
u8 tdls_sta_max = _FALSE;
#define ALIVE_MIN 2
#define ALIVE_MAX 5
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
_rtw_memset(checkalive, 0x00, sizeof(checkalive));
_rtw_memset(teardown, 0x00, sizeof(teardown));
if ((padapter->tdlsinfo.link_established == _TRUE)) {
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if (psta->tdls_sta_state & TDLS_LINKED_STATE) {
psta->alive_count++;
if (psta->alive_count >= ALIVE_MIN) {
if (chk_tdls_peer_sta_is_alive(padapter, psta) == _FALSE) {
if (psta->alive_count < ALIVE_MAX) {
_rtw_memcpy(checkalive[num_checkalive].addr, psta->cmn.mac_addr, ETH_ALEN);
checkalive[num_checkalive].psta = psta;
num_checkalive++;
} else {
_rtw_memcpy(teardown[num_teardown].addr, psta->cmn.mac_addr, ETH_ALEN);
teardown[num_teardown].psta = psta;
num_teardown++;
}
} else
psta->alive_count = 0;
}
psta->sta_stats.last_rx_data_pkts = psta->sta_stats.rx_data_pkts;
psta->sta_stats.last_rx_tdls_disc_rsp_pkts = psta->sta_stats.rx_tdls_disc_rsp_pkts;
if ((num_checkalive >= MAX_ALLOWED_TDLS_STA_NUM) || (num_teardown >= MAX_ALLOWED_TDLS_STA_NUM)) {
tdls_sta_max = _TRUE;
break;
}
}
}
if (tdls_sta_max == _TRUE)
break;
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
if (num_checkalive > 0) {
for (i = 0; i < num_checkalive; i++) {
_rtw_memcpy(txmgmt.peer, checkalive[i].addr, ETH_ALEN);
issue_tdls_dis_req(padapter, &txmgmt);
issue_tdls_dis_req(padapter, &txmgmt);
issue_tdls_dis_req(padapter, &txmgmt);
}
}
if (num_teardown > 0) {
for (i = 0; i < num_teardown; i++) {
RTW_INFO("[%s %d] Send teardown to "MAC_FMT"\n", __FUNCTION__, __LINE__, MAC_ARG(teardown[i].addr));
txmgmt.status_code = _RSON_TDLS_TEAR_TOOFAR_;
_rtw_memcpy(txmgmt.peer, teardown[i].addr, ETH_ALEN);
issue_tdls_teardown(padapter, &txmgmt, _FALSE);
}
}
}
}
#endif /* CONFIG_TDLS */
inline int rtw_get_rx_chk_limit(_adapter *adapter)
{
return adapter->stapriv.rx_chk_limit;
}
inline void rtw_set_rx_chk_limit(_adapter *adapter, int limit)
{
adapter->stapriv.rx_chk_limit = limit;
}
/* from_timer == 1 means driver is in LPS */
void linked_status_chk(_adapter *padapter, u8 from_timer)
{
u32 i;
struct sta_info *psta;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_priv *pstapriv = &padapter->stapriv;
#if defined(CONFIG_ARP_KEEP_ALIVE) || defined(CONFIG_LAYER2_ROAMING)
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
#endif
#ifdef CONFIG_LAYER2_ROAMING
struct recv_priv *precvpriv = &padapter->recvpriv;
#endif
if (padapter->registrypriv.mp_mode == _TRUE)
return;
if (is_client_associated_to_ap(padapter)) {
/* linked infrastructure client mode */
int tx_chk = _SUCCESS, rx_chk = _SUCCESS;
int rx_chk_limit;
int link_count_limit;
#if defined(CONFIG_RTW_REPEATER_SON)
rtw_rson_scan_wk_cmd(padapter, RSON_SCAN_PROCESS);
#elif defined(CONFIG_LAYER2_ROAMING)
if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE)) {
RTW_INFO("signal_strength_data.avg_val = %d\n", precvpriv->signal_strength_data.avg_val);
if ((precvpriv->signal_strength_data.avg_val < pmlmepriv->roam_rssi_threshold)
&& (rtw_get_passing_time_ms(pmlmepriv->last_roaming) >= pmlmepriv->roam_scan_int*2000)) {
#ifdef CONFIG_RTW_80211K
rtw_roam_nb_discover(padapter, _FALSE);
#endif
pmlmepriv->need_to_roam = _TRUE;
rtw_drv_scan_by_self(padapter, RTW_AUTO_SCAN_REASON_ROAM);
pmlmepriv->last_roaming = rtw_get_current_time();
} else
pmlmepriv->need_to_roam = _FALSE;
}
#endif
#ifdef CONFIG_MCC_MODE
/*
* due to tx ps null date to ao, so ap doest not tx pkt to driver
* we may check chk_ap_is_alive fail, and may issue_probereq to wrong channel under sitesurvey
* don't keep alive check under MCC
*/
if (rtw_hal_mcc_link_status_chk(padapter, __func__) == _FALSE)
return;
#endif
rx_chk_limit = rtw_get_rx_chk_limit(padapter);
#ifdef CONFIG_ARP_KEEP_ALIVE
if (!from_timer && pmlmepriv->bGetGateway == 1 && pmlmepriv->GetGatewayTryCnt < 3) {
RTW_INFO("do rtw_gw_addr_query() : %d\n", pmlmepriv->GetGatewayTryCnt);
pmlmepriv->GetGatewayTryCnt++;
if (rtw_gw_addr_query(padapter) == 0)
pmlmepriv->bGetGateway = 0;
else {
_rtw_memset(pmlmepriv->gw_ip, 0, 4);
_rtw_memset(pmlmepriv->gw_mac_addr, 0, ETH_ALEN);
}
}
#endif
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE)) {
if (!from_timer)
link_count_limit = 3; /* 8 sec */
else
link_count_limit = 15; /* 32 sec */
} else
#endif /* CONFIG_P2P */
{
if (!from_timer)
link_count_limit = 7; /* 16 sec */
else
link_count_limit = 29; /* 60 sec */
}
#ifdef CONFIG_TDLS
#ifdef CONFIG_TDLS_CH_SW
if (ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on) == _TRUE)
return;
#endif /* CONFIG_TDLS_CH_SW */
#ifdef CONFIG_TDLS_AUTOCHECKALIVE
linked_status_chk_tdls(padapter);
#endif /* CONFIG_TDLS_AUTOCHECKALIVE */
#endif /* CONFIG_TDLS */
psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
if (psta != NULL) {
bool is_p2p_enable = _FALSE;
#ifdef CONFIG_P2P
is_p2p_enable = !rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE);
#endif
#ifdef CONFIG_ISSUE_DELBA_WHEN_NO_TRAFFIC
/*issue delba when ap does not tx data packet that is Broadcom ap */
rtw_delba_check(padapter, psta, from_timer);
#endif
if (chk_ap_is_alive(padapter, psta) == _FALSE)
rx_chk = _FAIL;
if (sta_last_tx_pkts(psta) == sta_tx_pkts(psta))
tx_chk = _FAIL;
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
if (!from_timer && pmlmeext->active_keep_alive_check && (rx_chk == _FAIL || tx_chk == _FAIL)
) {
u8 backup_ch = 0, backup_bw = 0, backup_offset = 0;
u8 union_ch = 0, union_bw = 0, union_offset = 0;
u8 switch_channel_by_drv = _TRUE;
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter)) {
/* driver doesn't switch channel under MCC */
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
switch_channel_by_drv = _FALSE;
}
#endif
if (switch_channel_by_drv) {
if (!rtw_mi_get_ch_setting_union(padapter, &union_ch, &union_bw, &union_offset)
|| pmlmeext->cur_channel != union_ch)
goto bypass_active_keep_alive;
/* switch to correct channel of current network before issue keep-alive frames */
if (rtw_get_oper_ch(padapter) != pmlmeext->cur_channel) {
backup_ch = rtw_get_oper_ch(padapter);
backup_bw = rtw_get_oper_bw(padapter);
backup_offset = rtw_get_oper_choffset(padapter);
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
}
}
if (rx_chk != _SUCCESS)
issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, psta->cmn.mac_addr, 0, 0, 3, 1);
if ((tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit) || rx_chk != _SUCCESS) {
if (rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY))
tx_chk = issue_nulldata(padapter, psta->cmn.mac_addr, 1, 3, 1);
else
tx_chk = issue_nulldata(padapter, psta->cmn.mac_addr, 0, 3, 1);
/* if tx acked and p2p disabled, set rx_chk _SUCCESS to reset retry count */
if (tx_chk == _SUCCESS && !is_p2p_enable)
rx_chk = _SUCCESS;
}
/* back to the original operation channel */
if (backup_ch > 0 && switch_channel_by_drv)
set_channel_bwmode(padapter, backup_ch, backup_offset, backup_bw);
bypass_active_keep_alive:
;
} else
#endif /* CONFIG_ACTIVE_KEEP_ALIVE_CHECK */
{
if (rx_chk != _SUCCESS) {
if (pmlmeext->retry == 0) {
#ifdef DBG_EXPIRATION_CHK
RTW_INFO("issue_probereq to trigger probersp, retry=%d\n", pmlmeext->retry);
#endif
issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, (from_timer ? 0 : 1));
issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, (from_timer ? 0 : 1));
issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress, 0, 0, 0, (from_timer ? 0 : 1));
}
}
if (tx_chk != _SUCCESS && pmlmeinfo->link_count++ == link_count_limit
#ifdef CONFIG_MCC_MODE
/* FW tx nulldata under MCC mode, we just check ap is alive */
&& (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
#endif /* CONFIG_MCC_MODE */
) {
#ifdef DBG_EXPIRATION_CHK
RTW_INFO("%s issue_nulldata(%d)\n", __FUNCTION__, from_timer ? 1 : 0);
#endif
if (from_timer || rtw_mi_check_fwstate(padapter, _FW_UNDER_SURVEY))
tx_chk = issue_nulldata(padapter, NULL, 1, 0, 0);
else
tx_chk = issue_nulldata(padapter, NULL, 0, 1, 1);
}
}
if (rx_chk == _FAIL) {
pmlmeext->retry++;
if (pmlmeext->retry > rx_chk_limit) {
RTW_PRINT(FUNC_ADPT_FMT" disconnect or roaming\n",
FUNC_ADPT_ARG(padapter));
receive_disconnect(padapter, pmlmeinfo->network.MacAddress
, WLAN_REASON_EXPIRATION_CHK, _FALSE);
return;
}
} else
pmlmeext->retry = 0;
if (tx_chk == _FAIL)
pmlmeinfo->link_count %= (link_count_limit + 1);
else {
psta->sta_stats.last_tx_pkts = psta->sta_stats.tx_pkts;
pmlmeinfo->link_count = 0;
}
} /* end of if ((psta = rtw_get_stainfo(pstapriv, passoc_res->network.MacAddress)) != NULL) */
} else if (is_client_associated_to_ibss(padapter)) {
_irqL irqL;
_list *phead, *plist, dlist;
_rtw_init_listhead(&dlist);
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if (is_broadcast_mac_addr(psta->cmn.mac_addr))
continue;
if (chk_adhoc_peer_is_alive(psta) || !psta->expire_to)
psta->expire_to = pstapriv->adhoc_expire_to;
else
psta->expire_to--;
if (psta->expire_to <= 0) {
rtw_list_delete(&psta->list);
rtw_list_insert_tail(&psta->list, &dlist);
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
plist = get_next(&dlist);
while (rtw_end_of_queue_search(&dlist, plist) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, list);
plist = get_next(plist);
rtw_list_delete(&psta->list);
RTW_INFO(FUNC_ADPT_FMT" ibss expire "MAC_FMT"\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr));
report_del_sta_event(padapter, psta->cmn.mac_addr, WLAN_REASON_EXPIRATION_CHK, from_timer ? _TRUE : _FALSE, _FALSE);
}
}
}
void survey_timer_hdl(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
struct cmd_obj *cmd;
struct sitesurvey_parm *psurveyPara;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
if (mlmeext_scan_state(pmlmeext) > SCAN_DISABLE) {
cmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmd == NULL) {
rtw_warn_on(1);
goto exit;
}
psurveyPara = (struct sitesurvey_parm *)rtw_zmalloc(sizeof(struct sitesurvey_parm));
if (psurveyPara == NULL) {
rtw_warn_on(1);
rtw_mfree((unsigned char *)cmd, sizeof(struct cmd_obj));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(cmd, psurveyPara, GEN_CMD_CODE(_SiteSurvey));
rtw_enqueue_cmd(pcmdpriv, cmd);
}
exit:
return;
}
#ifdef CONFIG_RTW_REPEATER_SON
/* 100ms pass, stop rson_scan */
void rson_timer_hdl(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
rtw_rson_scan_wk_cmd(padapter, RSON_SCAN_DISABLE);
}
#endif
void link_timer_hdl(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
/* static unsigned int rx_pkt = 0; */
/* static u64 tx_cnt = 0; */
/* struct xmit_priv *pxmitpriv = &(padapter->xmitpriv); */
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* struct sta_priv *pstapriv = &padapter->stapriv; */
#ifdef CONFIG_RTW_80211R
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta = NULL;
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
#endif
if (rtw_sta_linking_test_force_fail())
RTW_INFO("rtw_sta_linking_test_force_fail\n");
if (pmlmeext->join_abort && pmlmeinfo->state != WIFI_FW_NULL_STATE) {
RTW_INFO(FUNC_ADPT_FMT" join abort\n", FUNC_ADPT_ARG(padapter));
pmlmeinfo->state = WIFI_FW_NULL_STATE;
report_join_res(padapter, -4, WLAN_STATUS_UNSPECIFIED_FAILURE);
goto exit;
}
if (pmlmeinfo->state & WIFI_FW_AUTH_NULL) {
RTW_INFO("link_timer_hdl:no beacon while connecting\n");
pmlmeinfo->state = WIFI_FW_NULL_STATE;
report_join_res(padapter, -3, WLAN_STATUS_UNSPECIFIED_FAILURE);
} else if (pmlmeinfo->state & WIFI_FW_AUTH_STATE) {
#ifdef CONFIG_IOCTL_CFG80211
if (rtw_sec_chk_auth_type(padapter, NL80211_AUTHTYPE_SAE))
return;
#endif /* CONFIG_IOCTL_CFG80211 */
/* re-auth timer */
if (++pmlmeinfo->reauth_count > REAUTH_LIMIT) {
/* if (pmlmeinfo->auth_algo != dot11AuthAlgrthm_Auto) */
/* { */
pmlmeinfo->state = 0;
if (pmlmeinfo->auth_status) {
report_join_res(padapter, -1, pmlmeinfo->auth_status);
pmlmeinfo->auth_status = 0; /* reset */
} else
report_join_res(padapter, -1, WLAN_STATUS_UNSPECIFIED_FAILURE);
return;
/* } */
/* else */
/* { */
/* pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared; */
/* pmlmeinfo->reauth_count = 0; */
/* } */
}
RTW_INFO("link_timer_hdl: auth timeout and try again\n");
pmlmeinfo->auth_seq = 1;
issue_auth(padapter, NULL, 0);
set_link_timer(pmlmeext, REAUTH_TO);
} else if (pmlmeinfo->state & WIFI_FW_ASSOC_STATE) {
/* re-assoc timer */
if (++pmlmeinfo->reassoc_count > REASSOC_LIMIT) {
pmlmeinfo->state = WIFI_FW_NULL_STATE;
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam(padapter)) {
psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
if (psta)
rtw_free_stainfo(padapter, psta);
}
#endif
report_join_res(padapter, -2, WLAN_STATUS_UNSPECIFIED_FAILURE);
return;
}
#ifdef CONFIG_RTW_80211R
if (rtw_ft_roam(padapter)) {
RTW_INFO("link_timer_hdl: reassoc timeout and try again\n");
issue_reassocreq(padapter);
} else
#endif
{
RTW_INFO("link_timer_hdl: assoc timeout and try again\n");
issue_assocreq(padapter);
}
set_link_timer(pmlmeext, REASSOC_TO);
}
exit:
return;
}
void addba_timer_hdl(void *ctx)
{
struct sta_info *psta = (struct sta_info *)ctx;
#ifdef CONFIG_80211N_HT
struct ht_priv *phtpriv;
if (!psta)
return;
phtpriv = &psta->htpriv;
if ((phtpriv->ht_option == _TRUE) && (phtpriv->ampdu_enable == _TRUE)) {
if (phtpriv->candidate_tid_bitmap)
phtpriv->candidate_tid_bitmap = 0x0;
}
#endif /* CONFIG_80211N_HT */
}
#ifdef CONFIG_IEEE80211W
void report_sta_timeout_event(_adapter *padapter, u8 *MacAddr, unsigned short reason)
{
struct cmd_obj *pcmd_obj;
u8 *pevtcmd;
u32 cmdsz;
struct sta_info *psta;
int mac_id;
struct stadel_event *pdel_sta_evt;
struct C2HEvent_Header *pc2h_evt_hdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
return;
cmdsz = (sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
return;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct stadel_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_TimeoutSTA);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
pdel_sta_evt = (struct stadel_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
_rtw_memcpy((unsigned char *)(&(pdel_sta_evt->macaddr)), MacAddr, ETH_ALEN);
_rtw_memcpy((unsigned char *)(pdel_sta_evt->rsvd), (unsigned char *)(&reason), 2);
psta = rtw_get_stainfo(&padapter->stapriv, MacAddr);
if (psta)
mac_id = (int)psta->cmn.mac_id;
else
mac_id = (-1);
pdel_sta_evt->mac_id = mac_id;
RTW_INFO("report_del_sta_event: delete STA, mac_id=%d\n", mac_id);
rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
return;
}
void clnt_sa_query_timeout(_adapter *padapter)
{
struct mlme_ext_priv *mlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
receive_disconnect(padapter, get_my_bssid(&(mlmeinfo->network)), WLAN_REASON_SA_QUERY_TIMEOUT, _FALSE);
}
void sa_query_timer_hdl(void *ctx)
{
struct sta_info *psta = (struct sta_info *)ctx;
_adapter *padapter = psta->padapter;
_irqL irqL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE &&
check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
clnt_sa_query_timeout(padapter);
else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)
report_sta_timeout_event(padapter, psta->cmn.mac_addr, WLAN_REASON_PREV_AUTH_NOT_VALID);
}
#endif /* CONFIG_IEEE80211W */
#ifdef CONFIG_RTW_80211R
void rtw_ft_update_bcn(_adapter *padapter, union recv_frame *precv_frame)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
uint len = precv_frame->u.hdr.len;
WLAN_BSSID_EX *pbss;
if (rtw_ft_chk_status(padapter,RTW_FT_ASSOCIATED_STA)
&& (pmlmepriv->ft_roam.ft_updated_bcn == _FALSE)) {
pbss = (WLAN_BSSID_EX*)rtw_malloc(sizeof(WLAN_BSSID_EX));
if (pbss) {
if (collect_bss_info(padapter, precv_frame, pbss) == _SUCCESS) {
struct beacon_keys recv_beacon;
update_network(&(pmlmepriv->cur_network.network), pbss, padapter, _TRUE);
/* update bcn keys */
if (rtw_get_bcn_keys(padapter, pframe, len, &recv_beacon) == _TRUE) {
RTW_INFO("%s: beacon keys ready\n", __func__);
_rtw_memcpy(&pmlmepriv->cur_beacon_keys,
&recv_beacon, sizeof(recv_beacon));
if (is_hidden_ssid(recv_beacon.ssid, recv_beacon.ssid_len)) {
_rtw_memcpy(pmlmepriv->cur_beacon_keys.ssid, pmlmeinfo->network.Ssid.Ssid, IW_ESSID_MAX_SIZE);
pmlmepriv->cur_beacon_keys.ssid_len = pmlmeinfo->network.Ssid.SsidLength;
}
} else {
RTW_ERR("%s: get beacon keys failed\n", __func__);
_rtw_memset(&pmlmepriv->cur_beacon_keys, 0, sizeof(recv_beacon));
}
#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
pmlmepriv->new_beacon_cnts = 0;
#endif
}
rtw_mfree((u8*)pbss, sizeof(WLAN_BSSID_EX));
}
/* check the vendor of the assoc AP */
pmlmeinfo->assoc_AP_vendor =
check_assoc_AP(pframe+sizeof(struct rtw_ieee80211_hdr_3addr),
(len - sizeof(struct rtw_ieee80211_hdr_3addr)));
/* update TSF Value */
update_TSF(pmlmeext, pframe, len);
pmlmeext->bcn_cnt = 0;
pmlmeext->last_bcn_cnt = 0;
pmlmepriv->ft_roam.ft_updated_bcn = _TRUE;
}
}
void rtw_ft_start_clnt_join(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
if (rtw_ft_otd_roam(padapter)) {
pmlmeinfo->state = WIFI_FW_AUTH_SUCCESS | WIFI_FW_STATION_STATE;
pft_roam->ft_event.ies =
(pft_roam->ft_action + sizeof(struct rtw_ieee80211_hdr_3addr) + 16);
pft_roam->ft_event.ies_len =
(pft_roam->ft_action_len - sizeof(struct rtw_ieee80211_hdr_3addr));
/*Not support RIC*/
pft_roam->ft_event.ric_ies = NULL;
pft_roam->ft_event.ric_ies_len = 0;
rtw_ft_report_evt(padapter);
return;
}
pmlmeinfo->state = WIFI_FW_AUTH_NULL | WIFI_FW_STATION_STATE;
start_clnt_auth(padapter);
}
u8 rtw_ft_update_rsnie(
_adapter *padapter, u8 bwrite,
struct pkt_attrib *pattrib, u8 **pframe)
{
struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
u8 *pie;
u32 len;
pie = rtw_get_ie(pft_roam->updated_ft_ies, EID_WPA2, &len,
pft_roam->updated_ft_ies_len);
if (!bwrite)
return (pie)?_SUCCESS:_FAIL;
if (pie) {
*pframe = rtw_set_ie(((u8 *)*pframe), EID_WPA2, len,
pie+2, &(pattrib->pktlen));
} else
return _FAIL;
return _SUCCESS;
}
static u8 rtw_ft_update_mdie(
_adapter *padapter, struct pkt_attrib *pattrib, u8 **pframe)
{
struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
u8 *pie, mdie[3];
u32 len = 3;
if (rtw_ft_roam(padapter)) {
if ((pie = rtw_get_ie(pft_roam->updated_ft_ies, _MDIE_,
&len, pft_roam->updated_ft_ies_len))) {
pie = (pie + 2); /* ignore md-id & length */
} else
return _FAIL;
} else {
*((u16 *)&mdie[0]) = pft_roam->mdid;
mdie[2] = pft_roam->ft_cap;
pie = &mdie[0];
}
*pframe = rtw_set_ie(((u8 *)*pframe), _MDIE_, len , pie, &(pattrib->pktlen));
return _SUCCESS;
}
static u8 rtw_ft_update_ftie(
_adapter *padapter, struct pkt_attrib *pattrib, u8 **pframe)
{
struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
u8 *pie;
u32 len;
if ((pie = rtw_get_ie(pft_roam->updated_ft_ies, _FTIE_, &len,
pft_roam->updated_ft_ies_len)) != NULL) {
*pframe = rtw_set_ie(*pframe, _FTIE_, len ,
(pie+2), &(pattrib->pktlen));
} else
return _FAIL;
return _SUCCESS;
}
void rtw_ft_build_auth_req_ies(_adapter *padapter,
struct pkt_attrib *pattrib, u8 **pframe)
{
u8 ftie_append = _TRUE;
if (!pattrib || !(*pframe))
return;
if (!rtw_ft_roam(padapter))
return;
ftie_append = rtw_ft_update_rsnie(padapter, _TRUE, pattrib, pframe);
rtw_ft_update_mdie(padapter, pattrib, pframe);
if (ftie_append)
rtw_ft_update_ftie(padapter, pattrib, pframe);
}
void rtw_ft_build_assoc_req_ies(_adapter *padapter,
u8 is_reassoc, struct pkt_attrib *pattrib, u8 **pframe)
{
if (!pattrib || !(*pframe))
return;
if (rtw_ft_chk_flags(padapter, RTW_FT_PEER_EN))
rtw_ft_update_mdie(padapter, pattrib, pframe);
if ((!is_reassoc) || (!rtw_ft_roam(padapter)))
return;
if (rtw_ft_update_rsnie(padapter, _FALSE, pattrib, pframe))
rtw_ft_update_ftie(padapter, pattrib, pframe);
}
u8 rtw_ft_update_auth_rsp_ies(_adapter *padapter, u8 *pframe, u32 len)
{
u8 ret = _SUCCESS;
u8 target_ap_addr[ETH_ALEN] = {0};
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
if (!rtw_ft_roam(padapter))
return _FAIL;
/*rtw_ft_report_reassoc_evt already,
* and waiting for cfg80211_rtw_update_ft_ies */
if (rtw_ft_authed_sta(padapter))
return ret;
if (!pframe || !len)
return _FAIL;
rtw_buf_update(&pmlmepriv->auth_rsp,
&pmlmepriv->auth_rsp_len, pframe, len);
pft_roam->ft_event.ies =
(pmlmepriv->auth_rsp + sizeof(struct rtw_ieee80211_hdr_3addr) + 6);
pft_roam->ft_event.ies_len =
(pmlmepriv->auth_rsp_len - sizeof(struct rtw_ieee80211_hdr_3addr) - 6);
/*Not support RIC*/
pft_roam->ft_event.ric_ies = NULL;
pft_roam->ft_event.ric_ies_len = 0;
_rtw_memcpy(target_ap_addr, pmlmepriv->assoc_bssid, ETH_ALEN);
rtw_ft_report_reassoc_evt(padapter, target_ap_addr);
return ret;
}
static void rtw_ft_start_clnt_action(_adapter *padapter, u8 *pTargetAddr)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
rtw_ft_set_status(padapter, RTW_FT_REQUESTING_STA);
rtw_ft_issue_action_req(padapter, pTargetAddr);
_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
}
void rtw_ft_start_roam(_adapter *padapter, u8 *pTargetAddr)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
if (rtw_ft_otd_roam(padapter)) {
rtw_ft_start_clnt_action(padapter, pTargetAddr);
} else {
/*wait a little time to retrieve packets buffered in the current ap while scan*/
_set_timer(&pmlmeext->ft_roam_timer, 30);
}
}
void rtw_ft_issue_action_req(_adapter *padapter, u8 *pTargetAddr)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct xmit_frame *pmgntframe;
struct rtw_ieee80211_hdr *pwlanhdr;
struct pkt_attrib *pattrib;
u8 *pframe;
u8 category = RTW_WLAN_CATEGORY_FT;
u8 action = RTW_WLAN_ACTION_FT_REQ;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
pwlanhdr->frame_ctl = 0;
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&pmlmeinfo->network), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
_rtw_memcpy(pframe, adapter_mac_addr(padapter), ETH_ALEN);
pframe += ETH_ALEN;
pattrib->pktlen += ETH_ALEN;
_rtw_memcpy(pframe, pTargetAddr, ETH_ALEN);
pframe += ETH_ALEN;
pattrib->pktlen += ETH_ALEN;
rtw_ft_update_mdie(padapter, pattrib, &pframe);
if (rtw_ft_update_rsnie(padapter, _TRUE, pattrib, &pframe))
rtw_ft_update_ftie(padapter, pattrib, &pframe);
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
void rtw_ft_report_evt(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)&(pmlmeinfo->network);
struct cfg80211_ft_event_params ft_evt_parms;
_irqL irqL;
_rtw_memset(&ft_evt_parms, 0, sizeof(ft_evt_parms));
rtw_ft_update_stainfo(padapter, pnetwork);
if (!pnetwork)
goto err_2;
ft_evt_parms.ies_len = pft_roam->ft_event.ies_len;
ft_evt_parms.ies = rtw_zmalloc(ft_evt_parms.ies_len);
if (ft_evt_parms.ies)
_rtw_memcpy((void *)ft_evt_parms.ies, pft_roam->ft_event.ies, ft_evt_parms.ies_len);
else
goto err_2;
ft_evt_parms.target_ap = rtw_zmalloc(ETH_ALEN);
if (ft_evt_parms.target_ap)
_rtw_memcpy((void *)ft_evt_parms.target_ap, pnetwork->MacAddress, ETH_ALEN);
else
goto err_1;
ft_evt_parms.ric_ies = pft_roam->ft_event.ric_ies;
ft_evt_parms.ric_ies_len = pft_roam->ft_event.ric_ies_len;
rtw_ft_lock_set_status(padapter, RTW_FT_AUTHENTICATED_STA, &irqL);
rtw_cfg80211_ft_event(padapter, &ft_evt_parms);
RTW_INFO("FT: rtw_ft_report_evt\n");
rtw_mfree((u8 *)pft_roam->ft_event.target_ap, ETH_ALEN);
err_1:
rtw_mfree((u8 *)ft_evt_parms.ies, ft_evt_parms.ies_len);
err_2:
return;
}
void rtw_ft_report_reassoc_evt(_adapter *padapter, u8 *pMacAddr)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
struct cmd_obj *pcmd_obj = NULL;
struct stassoc_event *passoc_sta_evt = NULL;
struct C2HEvent_Header *pc2h_evt_hdr = NULL;
u8 *pevtcmd = NULL;
u32 cmdsz = 0;
pcmd_obj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd_obj == NULL)
return;
cmdsz = (sizeof(struct stassoc_event) + sizeof(struct C2HEvent_Header));
pevtcmd = (u8 *)rtw_zmalloc(cmdsz);
if (pevtcmd == NULL) {
rtw_mfree((u8 *)pcmd_obj, sizeof(struct cmd_obj));
return;
}
_rtw_init_listhead(&pcmd_obj->list);
pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
pcmd_obj->cmdsz = cmdsz;
pcmd_obj->parmbuf = pevtcmd;
pcmd_obj->rsp = NULL;
pcmd_obj->rspsz = 0;
pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
pc2h_evt_hdr->len = sizeof(struct stassoc_event);
pc2h_evt_hdr->ID = GEN_EVT_CODE(_FT_REASSOC);
pc2h_evt_hdr->seq = ATOMIC_INC_RETURN(&pmlmeext->event_seq);
passoc_sta_evt = (struct stassoc_event *)(pevtcmd + sizeof(struct C2HEvent_Header));
_rtw_memcpy((unsigned char *)(&(passoc_sta_evt->macaddr)), pMacAddr, ETH_ALEN);
rtw_enqueue_cmd(pcmdpriv, pcmd_obj);
}
void rtw_ft_link_timer_hdl(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct ft_roam_info *pft_roam = &(pmlmepriv->ft_roam);
if (rtw_ft_chk_status(padapter, RTW_FT_REQUESTING_STA)) {
if (pft_roam->ft_req_retry_cnt < RTW_FT_ACTION_REQ_LMT) {
pft_roam->ft_req_retry_cnt++;
rtw_ft_issue_action_req(padapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
_set_timer(&pmlmeext->ft_link_timer, REASSOC_TO);
} else {
pft_roam->ft_req_retry_cnt = 0;
if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
rtw_ft_set_status(padapter, RTW_FT_ASSOCIATED_STA);
else
rtw_ft_reset_status(padapter);
}
}
}
void rtw_ft_roam_timer_hdl(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress
, WLAN_REASON_ACTIVE_ROAM, _FALSE);
}
void rtw_ft_roam_status_reset(_adapter *padapter)
{
struct ft_roam_info *pft_roam = &(padapter->mlmepriv.ft_roam);
if ((rtw_to_roam(padapter) > 0) &&
(!rtw_ft_chk_status(padapter, RTW_FT_REQUESTED_STA))) {
rtw_ft_reset_status(padapter);
}
padapter->mlmepriv.ft_roam.ft_updated_bcn = _FALSE;
}
#endif
u8 NULL_hdl(_adapter *padapter, u8 *pbuf)
{
return H2C_SUCCESS;
}
#ifdef CONFIG_AUTO_AP_MODE
void rtw_auto_ap_rx_msg_dump(_adapter *padapter, union recv_frame *precv_frame, u8 *ehdr_pos)
{
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_info *psta = precv_frame->u.hdr.psta;
struct ethhdr *ehdr = (struct ethhdr *)ehdr_pos;
RTW_INFO("eth rx: got eth_type=0x%x\n", ntohs(ehdr->h_proto));
if (psta && psta->isrc && psta->pid > 0) {
u16 rx_pid;
rx_pid = *(u16 *)(ehdr_pos + ETH_HLEN);
RTW_INFO("eth rx(pid=0x%x): sta("MAC_FMT") pid=0x%x\n",
rx_pid, MAC_ARG(psta->cmn.mac_addr), psta->pid);
if (rx_pid == psta->pid) {
int i;
u16 len = *(u16 *)(ehdr_pos + ETH_HLEN + 2);
/* u16 ctrl_type = *(u16 *)(ehdr_pos + ETH_HLEN + 4); */
/* RTW_INFO("eth, RC: len=0x%x, ctrl_type=0x%x\n", len, ctrl_type); */
RTW_INFO("eth, RC: len=0x%x\n", len);
for (i = 0; i < len; i++)
RTW_INFO("0x%x\n", *(ehdr_pos + ETH_HLEN + 4 + i));
/* RTW_INFO("0x%x\n", *(ehdr_pos + ETH_HLEN + 6 + i)); */
RTW_INFO("eth, RC-end\n");
}
}
}
void rtw_start_auto_ap(_adapter *adapter)
{
RTW_INFO("%s\n", __FUNCTION__);
rtw_set_802_11_infrastructure_mode(adapter, Ndis802_11APMode);
rtw_setopmode_cmd(adapter, Ndis802_11APMode, RTW_CMDF_WAIT_ACK);
}
static int rtw_auto_ap_start_beacon(_adapter *adapter)
{
int ret = 0;
u8 *pbuf = NULL;
uint len;
u8 supportRate[16];
int sz = 0, rateLen;
u8 *ie;
u8 wireless_mode, oper_channel;
u8 ssid[3] = {0}; /* hidden ssid */
u32 ssid_len = sizeof(ssid);
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != _TRUE)
return -EINVAL;
len = 128;
pbuf = rtw_zmalloc(len);
if (!pbuf)
return -ENOMEM;
/* generate beacon */
ie = pbuf;
/* timestamp will be inserted by hardware */
sz += 8;
ie += sz;
/* beacon interval : 2bytes */
*(u16 *)ie = cpu_to_le16((u16)100); /* BCN_INTERVAL=100; */
sz += 2;
ie += 2;
/* capability info */
*(u16 *)ie = 0;
*(u16 *)ie |= cpu_to_le16(cap_ESS);
*(u16 *)ie |= cpu_to_le16(cap_ShortPremble);
/* *(u16*)ie |= cpu_to_le16(cap_Privacy); */
sz += 2;
ie += 2;
/* SSID */
ie = rtw_set_ie(ie, _SSID_IE_, ssid_len, ssid, &sz);
/* supported rates */
wireless_mode = (WIRELESS_11BG_24N & padapter->registrypriv.wireless_mode);
rtw_set_supported_rate(supportRate, wireless_mode);
rateLen = rtw_get_rateset_len(supportRate);
if (rateLen > 8)
ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, 8, supportRate, &sz);
else
ie = rtw_set_ie(ie, _SUPPORTEDRATES_IE_, rateLen, supportRate, &sz);
/* DS parameter set */
if (rtw_mi_check_status(adapter, MI_LINKED))
oper_channel = rtw_mi_get_union_chan(adapter);
else
oper_channel = adapter_to_dvobj(adapter)->oper_channel;
ie = rtw_set_ie(ie, _DSSET_IE_, 1, &oper_channel, &sz);
/* ext supported rates */
if (rateLen > 8)
ie = rtw_set_ie(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (supportRate + 8), &sz);
RTW_INFO("%s, start auto ap beacon sz=%d\n", __FUNCTION__, sz);
/* lunch ap mode & start to issue beacon */
if (rtw_check_beacon_data(adapter, pbuf, sz) == _SUCCESS) {
} else
ret = -EINVAL;
rtw_mfree(pbuf, len);
return ret;
}
#endif/* CONFIG_AUTO_AP_MODE */
u8 setopmode_hdl(_adapter *padapter, u8 *pbuf)
{
u8 type;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct setopmode_parm *psetop = (struct setopmode_parm *)pbuf;
if (psetop->mode == Ndis802_11APMode
|| psetop->mode == Ndis802_11_mesh
) {
pmlmeinfo->state = WIFI_FW_AP_STATE;
type = _HW_STATE_AP_;
} else if (psetop->mode == Ndis802_11Infrastructure) {
pmlmeinfo->state &= ~(BIT(0) | BIT(1)); /* clear state */
pmlmeinfo->state |= WIFI_FW_STATION_STATE;/* set to STATION_STATE */
type = _HW_STATE_STATION_;
} else if (psetop->mode == Ndis802_11IBSS)
type = _HW_STATE_ADHOC_;
else if (psetop->mode == Ndis802_11Monitor)
type = _HW_STATE_MONITOR_;
else
type = _HW_STATE_NOLINK_;
#ifdef CONFIG_AP_PORT_SWAP
rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, (u8 *)(&type));
#endif
rtw_hal_set_hwreg(padapter, HW_VAR_SET_OPMODE, (u8 *)(&type));
#ifdef CONFIG_AUTO_AP_MODE
if (psetop->mode == Ndis802_11APMode)
rtw_auto_ap_start_beacon(padapter);
#endif
if (rtw_port_switch_chk(padapter) == _TRUE) {
rtw_hal_set_hwreg(padapter, HW_VAR_PORT_SWITCH, NULL);
if (psetop->mode == Ndis802_11APMode)
adapter_to_pwrctl(padapter)->fw_psmode_iface_id = 0xff; /* ap mode won't dowload rsvd pages */
else if (psetop->mode == Ndis802_11Infrastructure) {
#ifdef CONFIG_LPS
_adapter *port0_iface = dvobj_get_port0_adapter(adapter_to_dvobj(padapter));
if (port0_iface)
rtw_lps_ctrl_wk_cmd(port0_iface, LPS_CTRL_CONNECT, RTW_CMDF_DIRECTLY);
#endif
}
}
#ifdef CONFIG_BT_COEXIST
if (psetop->mode == Ndis802_11APMode
|| psetop->mode == Ndis802_11_mesh
|| psetop->mode == Ndis802_11Monitor
) {
/* Do this after port switch to */
/* prevent from downloading rsvd page to wrong port */
rtw_btcoex_MediaStatusNotify(padapter, 1); /* connect */
}
#endif /* CONFIG_BT_COEXIST */
return H2C_SUCCESS;
}
u8 createbss_hdl(_adapter *padapter, u8 *pbuf)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
WLAN_BSSID_EX *pdev_network = &padapter->registrypriv.dev_network;
struct createbss_parm *parm = (struct createbss_parm *)pbuf;
u8 ret = H2C_SUCCESS;
/* u8 initialgain; */
#ifdef CONFIG_AP_MODE
if ((parm->req_ch == 0 && pmlmeinfo->state == WIFI_FW_AP_STATE)
|| parm->req_ch != 0
) {
start_bss_network(padapter, parm);
goto exit;
}
#endif
/* below is for ad-hoc master */
if (parm->adhoc) {
rtw_warn_on(pdev_network->InfrastructureMode != Ndis802_11IBSS);
rtw_joinbss_reset(padapter);
pmlmeext->cur_bwmode = CHANNEL_WIDTH_20;
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
pmlmeinfo->ERP_enable = 0;
pmlmeinfo->WMM_enable = 0;
pmlmeinfo->HT_enable = 0;
pmlmeinfo->HT_caps_enable = 0;
pmlmeinfo->HT_info_enable = 0;
pmlmeinfo->agg_enable_bitmap = 0;
pmlmeinfo->candidate_tid_bitmap = 0;
/* cancel link timer */
_cancel_timer_ex(&pmlmeext->link_timer);
/* clear CAM */
flush_all_cam_entry(padapter);
pdev_network->Length = get_WLAN_BSSID_EX_sz(pdev_network);
_rtw_memcpy(pnetwork, pdev_network, FIELD_OFFSET(WLAN_BSSID_EX, IELength));
pnetwork->IELength = pdev_network->IELength;
if (pnetwork->IELength > MAX_IE_SZ) {
ret = H2C_PARAMETERS_ERROR;
goto ibss_post_hdl;
}
_rtw_memcpy(pnetwork->IEs, pdev_network->IEs, pnetwork->IELength);
start_create_ibss(padapter);
} else {
rtw_warn_on(1);
ret = H2C_PARAMETERS_ERROR;
}
ibss_post_hdl:
rtw_create_ibss_post_hdl(padapter, ret);
exit:
return ret;
}
u8 join_cmd_hdl(_adapter *padapter, u8 *pbuf)
{
u8 join_type;
PNDIS_802_11_VARIABLE_IEs pIE;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
#ifdef CONFIG_ANTENNA_DIVERSITY
struct joinbss_parm *pparm = (struct joinbss_parm *)pbuf;
#endif /* CONFIG_ANTENNA_DIVERSITY */
u32 i;
/* u8 initialgain; */
/* u32 acparm; */
u8 u_ch, u_bw, u_offset;
u8 doiqk = _FALSE;
/* check already connecting to AP or not */
if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
if (pmlmeinfo->state & WIFI_FW_STATION_STATE)
issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
pmlmeinfo->state = WIFI_FW_NULL_STATE;
/* clear CAM */
flush_all_cam_entry(padapter);
_cancel_timer_ex(&pmlmeext->link_timer);
/* set MSR to nolink->infra. mode */
/* Set_MSR(padapter, _HW_STATE_NOLINK_); */
Set_MSR(padapter, _HW_STATE_STATION_);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_DISCONNECT, 0);
if (pmlmeinfo->state & WIFI_FW_STATION_STATE)
rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_DISCONNECTED);
}
#ifdef CONFIG_ANTENNA_DIVERSITY
rtw_antenna_select_cmd(padapter, pparm->network.PhyInfo.Optimum_antenna, _FALSE);
#endif
#ifdef CONFIG_WAPI_SUPPORT
rtw_wapi_clear_all_cam_entry(padapter);
#endif
rtw_joinbss_reset(padapter);
pmlmeinfo->ERP_enable = 0;
pmlmeinfo->WMM_enable = 0;
pmlmeinfo->HT_enable = 0;
pmlmeinfo->HT_caps_enable = 0;
pmlmeinfo->HT_info_enable = 0;
pmlmeinfo->agg_enable_bitmap = 0;
pmlmeinfo->candidate_tid_bitmap = 0;
pmlmeinfo->bwmode_updated = _FALSE;
/* pmlmeinfo->assoc_AP_vendor = HT_IOT_PEER_MAX; */
pmlmeinfo->VHT_enable = 0;
#ifdef ROKU_PRIVATE
pmlmeinfo->ht_vht_received = 0;
_rtw_memset(pmlmeinfo->SupportedRates_infra_ap, 0, NDIS_802_11_LENGTH_RATES_EX);
#endif /* ROKU_PRIVATE */
_rtw_memcpy(pnetwork, pbuf, FIELD_OFFSET(WLAN_BSSID_EX, IELength));
pnetwork->IELength = ((WLAN_BSSID_EX *)pbuf)->IELength;
if (pnetwork->IELength > MAX_IE_SZ) /* Check pbuf->IELength */
return H2C_PARAMETERS_ERROR;
if (pnetwork->IELength < 2) {
report_join_res(padapter, (-4), WLAN_STATUS_UNSPECIFIED_FAILURE);
return H2C_SUCCESS;
}
_rtw_memcpy(pnetwork->IEs, ((WLAN_BSSID_EX *)pbuf)->IEs, pnetwork->IELength);
pmlmeinfo->bcn_interval = get_beacon_interval(pnetwork);
/* Check AP vendor to move rtw_joinbss_cmd() */
/* pmlmeinfo->assoc_AP_vendor = check_assoc_AP(pnetwork->IEs, pnetwork->IELength); */
/* sizeof(NDIS_802_11_FIXED_IEs) */
for (i = _FIXED_IE_LENGTH_ ; i < pnetwork->IELength - 2 ;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pnetwork->IEs + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_: /* Get WMM IE. */
if (_rtw_memcmp(pIE->data, WMM_OUI, 4))
WMM_param_handler(padapter, pIE);
break;
#ifdef CONFIG_80211N_HT
case _HT_CAPABILITY_IE_: /* Get HT Cap IE. */
pmlmeinfo->HT_caps_enable = 1;
break;
case _HT_EXTRA_INFO_IE_: /* Get HT Info IE. */
pmlmeinfo->HT_info_enable = 1;
break;
#endif /* CONFIG_80211N_HT */
#ifdef CONFIG_80211AC_VHT
case EID_VHTCapability: /* Get VHT Cap IE. */
pmlmeinfo->VHT_enable = 1;
break;
case EID_VHTOperation: /* Get VHT Operation IE. */
break;
#endif /* CONFIG_80211AC_VHT */
default:
break;
}
i += (pIE->Length + 2);
}
rtw_bss_get_chbw(pnetwork
, &pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset, 1, 1);
rtw_adjust_chbw(padapter, pmlmeext->cur_channel, &pmlmeext->cur_bwmode, &pmlmeext->cur_ch_offset);
#if 0
if (padapter->registrypriv.wifi_spec) {
/* for WiFi test, follow WMM test plan spec */
acparm = 0x002F431C; /* VO */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
acparm = 0x005E541C; /* VI */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
acparm = 0x0000A525; /* BE */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
acparm = 0x0000A549; /* BK */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
/* for WiFi test, mixed mode with intel STA under bg mode throughput issue */
if (padapter->mlmepriv.htpriv.ht_option == _FALSE) {
acparm = 0x00004320;
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
}
} else {
acparm = 0x002F3217; /* VO */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acparm));
acparm = 0x005E4317; /* VI */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acparm));
acparm = 0x00105320; /* BE */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acparm));
acparm = 0x0000A444; /* BK */
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acparm));
}
#endif
/* check channel, bandwidth, offset and switch */
if (rtw_chk_start_clnt_join(padapter, &u_ch, &u_bw, &u_offset) == _FAIL) {
report_join_res(padapter, (-4), WLAN_STATUS_UNSPECIFIED_FAILURE);
return H2C_SUCCESS;
}
/* disable dynamic functions, such as high power, DIG */
/*rtw_phydm_func_disable_all(padapter);*/
/* config the initial gain under linking, need to write the BB registers */
/* initialgain = 0x1E; */
/*rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);*/
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
if (MLME_IS_STA(padapter))
rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTING);
else
rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
join_type = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
doiqk = _TRUE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
set_channel_bwmode(padapter, u_ch, u_offset, u_bw);
rtw_mi_update_union_chan_inf(padapter, u_ch, u_offset, u_bw);
doiqk = _FALSE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
/* cancel link timer */
_cancel_timer_ex(&pmlmeext->link_timer);
start_clnt_join(padapter);
return H2C_SUCCESS;
}
u8 disconnect_hdl(_adapter *padapter, unsigned char *pbuf)
{
#ifdef CONFIG_DFS
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
#endif
struct disconnect_parm *param = (struct disconnect_parm *)pbuf;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
u8 val8;
if (is_client_associated_to_ap(padapter)
#ifdef CONFIG_DFS
&& !IS_RADAR_DETECTED(rfctl) && !rfctl->csa_ch
#endif
) {
#ifdef CONFIG_PLATFORM_ROCKCHIPS
/* To avoid connecting to AP fail during resume process, change retry count from 5 to 1 */
issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, 1, 100);
#else
issue_deauth_ex(padapter, pnetwork->MacAddress, WLAN_REASON_DEAUTH_LEAVING, param->deauth_timeout_ms / 100, 100);
#endif /* CONFIG_PLATFORM_ROCKCHIPS */
}
#ifndef CONFIG_SUPPORT_MULTI_BCN
if (((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
/* Stop BCN */
val8 = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_BCN_FUNC, (u8 *)(&val8));
}
#endif
rtw_mlmeext_disconnect(padapter);
rtw_free_uc_swdec_pending_queue(padapter);
rtw_sta_mstatus_report(padapter);
return H2C_SUCCESS;
}
static const char *const _scan_state_str[] = {
"SCAN_DISABLE",
"SCAN_START",
"SCAN_PS_ANNC_WAIT",
"SCAN_ENTER",
"SCAN_PROCESS",
"SCAN_BACKING_OP",
"SCAN_BACK_OP",
"SCAN_LEAVING_OP",
"SCAN_LEAVE_OP",
"SCAN_SW_ANTDIV_BL",
"SCAN_TO_P2P_LISTEN",
"SCAN_P2P_LISTEN",
"SCAN_COMPLETE",
"SCAN_STATE_MAX",
};
const char *scan_state_str(u8 state)
{
state = (state >= SCAN_STATE_MAX) ? SCAN_STATE_MAX : state;
return _scan_state_str[state];
}
static bool scan_abort_hdl(_adapter *adapter)
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct ss_res *ss = &pmlmeext->sitesurvey_res;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
#endif
bool ret = _FALSE;
if (pmlmeext->scan_abort == _TRUE) {
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(&adapter->wdinfo, P2P_STATE_NONE)) {
rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_MAX);
ss->channel_idx = 3;
RTW_INFO("%s idx:%d, cnt:%u\n", __FUNCTION__
, ss->channel_idx
, pwdinfo->find_phase_state_exchange_cnt
);
} else
#endif
{
ss->channel_idx = ss->ch_num;
RTW_INFO("%s idx:%d\n", __FUNCTION__
, ss->channel_idx
);
}
pmlmeext->scan_abort = _FALSE;
ret = _TRUE;
}
return ret;
}
u8 rtw_scan_sparse(_adapter *adapter, struct rtw_ieee80211_channel *ch, u8 ch_num)
{
/* interval larger than this is treated as backgroud scan */
#ifndef RTW_SCAN_SPARSE_BG_INTERVAL_MS
#define RTW_SCAN_SPARSE_BG_INTERVAL_MS 12000
#endif
#ifndef RTW_SCAN_SPARSE_CH_NUM_MIRACAST
#define RTW_SCAN_SPARSE_CH_NUM_MIRACAST 1
#endif
#ifndef RTW_SCAN_SPARSE_CH_NUM_BG
#define RTW_SCAN_SPARSE_CH_NUM_BG 4
#endif
#ifdef CONFIG_LAYER2_ROAMING
#ifndef RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE
#define RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE 1
#endif
#endif
#define SCAN_SPARSE_CH_NUM_INVALID 255
static u8 token = 255;
u32 interval;
bool busy_traffic = _FALSE;
bool miracast_enabled = _FALSE;
bool bg_scan = _FALSE;
u8 max_allow_ch = SCAN_SPARSE_CH_NUM_INVALID;
u8 scan_division_num;
u8 ret_num = ch_num;
struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
if (regsty->wifi_spec)
goto exit;
/* assume ch_num > 6 is normal scan */
if (ch_num <= 6)
goto exit;
if (mlmeext->last_scan_time == 0)
mlmeext->last_scan_time = rtw_get_current_time();
interval = rtw_get_passing_time_ms(mlmeext->last_scan_time);
if (rtw_mi_busy_traffic_check(adapter, _FALSE))
busy_traffic = _TRUE;
if (rtw_mi_check_miracast_enabled(adapter))
miracast_enabled = _TRUE;
if (interval > RTW_SCAN_SPARSE_BG_INTERVAL_MS)
bg_scan = _TRUE;
/* max_allow_ch by conditions*/
#if RTW_SCAN_SPARSE_MIRACAST
if (miracast_enabled == _TRUE && busy_traffic == _TRUE)
max_allow_ch = rtw_min(max_allow_ch, RTW_SCAN_SPARSE_CH_NUM_MIRACAST);
#endif
#if RTW_SCAN_SPARSE_BG
if (bg_scan == _TRUE)
max_allow_ch = rtw_min(max_allow_ch, RTW_SCAN_SPARSE_CH_NUM_BG);
#endif
#if defined(CONFIG_LAYER2_ROAMING) && defined(RTW_SCAN_SPARSE_ROAMING_ACTIVE)
if (rtw_chk_roam_flags(adapter, RTW_ROAM_ACTIVE)) {
if (busy_traffic == _TRUE && adapter->mlmepriv.need_to_roam == _TRUE)
max_allow_ch = rtw_min(max_allow_ch, RTW_SCAN_SPARSE_CH_NUM_ROAMING_ACTIVE);
}
#endif
if (max_allow_ch != SCAN_SPARSE_CH_NUM_INVALID) {
int i;
int k = 0;
scan_division_num = (ch_num / max_allow_ch) + ((ch_num % max_allow_ch) ? 1 : 0);
token = (token + 1) % scan_division_num;
if (0)
RTW_INFO("scan_division_num:%u, token:%u\n", scan_division_num, token);
for (i = 0; i < ch_num; i++) {
if (ch[i].hw_value && (i % scan_division_num) == token
) {
if (i != k)
_rtw_memcpy(&ch[k], &ch[i], sizeof(struct rtw_ieee80211_channel));
k++;
}
}
_rtw_memset(&ch[k], 0, sizeof(struct rtw_ieee80211_channel));
ret_num = k;
mlmeext->last_scan_time = rtw_get_current_time();
}
exit:
return ret_num;
}
#ifdef CONFIG_SCAN_BACKOP
u8 rtw_scan_backop_decision(_adapter *adapter)
{
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct mi_state mstate;
u8 backop_flags = 0;
rtw_mi_status(adapter, &mstate);
if ((MSTATE_STA_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(mlmeext, SS_BACKOP_EN))
|| (MSTATE_STA_NUM(&mstate) && mlmeext_chk_scan_backop_flags_sta(mlmeext, SS_BACKOP_EN_NL)))
backop_flags |= mlmeext_scan_backop_flags_sta(mlmeext);
#ifdef CONFIG_AP_MODE
if ((MSTATE_AP_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(mlmeext, SS_BACKOP_EN))
|| (MSTATE_AP_NUM(&mstate) && mlmeext_chk_scan_backop_flags_ap(mlmeext, SS_BACKOP_EN_NL)))
backop_flags |= mlmeext_scan_backop_flags_ap(mlmeext);
#endif
#ifdef CONFIG_RTW_MESH
if ((MSTATE_MESH_LD_NUM(&mstate) && mlmeext_chk_scan_backop_flags_mesh(mlmeext, SS_BACKOP_EN))
|| (MSTATE_MESH_NUM(&mstate) && mlmeext_chk_scan_backop_flags_mesh(mlmeext, SS_BACKOP_EN_NL)))
backop_flags |= mlmeext_scan_backop_flags_mesh(mlmeext);
#endif
return backop_flags;
}
#endif
#define SCANNING_TIMEOUT_EX 2000
u32 rtw_scan_timeout_decision(_adapter *padapter)
{
u32 back_op_times= 0;
u8 max_chan_num;
u16 scan_ms;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct ss_res *ss = &pmlmeext->sitesurvey_res;
if (is_supported_5g(padapter->registrypriv.wireless_mode)
&& IsSupported24G(padapter->registrypriv.wireless_mode))
max_chan_num = MAX_CHANNEL_NUM;/* dual band */
else
max_chan_num = MAX_CHANNEL_NUM_2G;/*single band*/
#ifdef CONFIG_SCAN_BACKOP
if (rtw_scan_backop_decision(padapter))
back_op_times = (max_chan_num / ss->scan_cnt_max) * ss->backop_ms;
#endif
if (ss->duration)
scan_ms = ss->duration;
else
#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
if (IS_ACS_ENABLE(padapter) && rtw_is_acs_st_valid(padapter))
scan_ms = rtw_acs_get_adv_st(padapter);
else
#endif /*CONFIG_RTW_ACS*/
scan_ms = ss->scan_ch_ms;
ss->scan_timeout_ms = (scan_ms * max_chan_num) + back_op_times + SCANNING_TIMEOUT_EX;
#ifdef DBG_SITESURVEY
RTW_INFO("%s , scan_timeout_ms = %d (ms)\n", __func__, ss->scan_timeout_ms);
#endif /*DBG_SITESURVEY*/
return ss->scan_timeout_ms;
}
static int rtw_scan_ch_decision(_adapter *padapter, struct rtw_ieee80211_channel *out,
u32 out_num, struct rtw_ieee80211_channel *in, u32 in_num)
{
int i, j;
int set_idx;
u8 chan;
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
/* clear first */
_rtw_memset(out, 0, sizeof(struct rtw_ieee80211_channel) * out_num);
/* acquire channels from in */
j = 0;
for (i = 0; i < in_num; i++) {
if (0)
RTW_INFO(FUNC_ADPT_FMT" "CHAN_FMT"\n", FUNC_ADPT_ARG(padapter), CHAN_ARG(&in[i]));
if (!in[i].hw_value || (in[i].flags & RTW_IEEE80211_CHAN_DISABLED))
continue;
if (rtw_mlme_band_check(padapter, in[i].hw_value) == _FALSE)
continue;
set_idx = rtw_chset_search_ch(rfctl->channel_set, in[i].hw_value);
if (set_idx >= 0) {
if (j >= out_num) {
RTW_PRINT(FUNC_ADPT_FMT" out_num:%u not enough\n",
FUNC_ADPT_ARG(padapter), out_num);
break;
}
_rtw_memcpy(&out[j], &in[i], sizeof(struct rtw_ieee80211_channel));
if (rfctl->channel_set[set_idx].ScanType == SCAN_PASSIVE)
out[j].flags |= RTW_IEEE80211_CHAN_PASSIVE_SCAN;
j++;
}
if (j >= out_num)
break;
}
/* if out is empty, use channel_set as default */
if (j == 0) {
for (i = 0; i < rfctl->max_chan_nums; i++) {
chan = rfctl->channel_set[i].ChannelNum;
if (rtw_mlme_band_check(padapter, chan) == _TRUE) {
if (rtw_mlme_ignore_chan(padapter, chan) == _TRUE)
continue;
if (0)
RTW_INFO(FUNC_ADPT_FMT" ch:%u\n", FUNC_ADPT_ARG(padapter), chan);
if (j >= out_num) {
RTW_PRINT(FUNC_ADPT_FMT" out_num:%u not enough\n",
FUNC_ADPT_ARG(padapter), out_num);
break;
}
out[j].hw_value = chan;
if (rfctl->channel_set[i].ScanType == SCAN_PASSIVE)
out[j].flags |= RTW_IEEE80211_CHAN_PASSIVE_SCAN;
j++;
}
}
}
/* scan_sparse */
j = rtw_scan_sparse(padapter, out, j);
return j;
}
static void sitesurvey_res_reset(_adapter *adapter, struct sitesurvey_parm *parm)
{
struct ss_res *ss = &adapter->mlmeextpriv.sitesurvey_res;
RT_CHANNEL_INFO *chset = adapter_to_chset(adapter);
int i;
ss->bss_cnt = 0;
ss->channel_idx = 0;
#ifdef CONFIG_DFS
ss->dfs_ch_ssid_scan = 0;
#endif
ss->igi_scan = 0;
ss->igi_before_scan = 0;
#ifdef CONFIG_SCAN_BACKOP
ss->scan_cnt = 0;
#endif
#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
ss->is_sw_antdiv_bl_scan = 0;
#endif
ss->ssid_num = 0;
for (i = 0; i < RTW_SSID_SCAN_AMOUNT; i++) {
if (parm->ssid[i].SsidLength) {
_rtw_memcpy(ss->ssid[i].Ssid, parm->ssid[i].Ssid, IW_ESSID_MAX_SIZE);
ss->ssid[i].SsidLength = parm->ssid[i].SsidLength;
ss->ssid_num++;
} else
ss->ssid[i].SsidLength = 0;
}
ss->ch_num = rtw_scan_ch_decision(adapter
, ss->ch, RTW_CHANNEL_SCAN_AMOUNT
, parm->ch, parm->ch_num
);
#ifdef CONFIG_DFS
for (i = 0; i < MAX_CHANNEL_NUM; i++)
chset[i].hidden_bss_cnt = 0;
#endif
ss->bw = parm->bw;
ss->igi = parm->igi;
ss->token = parm->token;
ss->duration = parm->duration;
ss->scan_mode = parm->scan_mode;
ss->token = parm->token;
}
static u8 sitesurvey_pick_ch_behavior(_adapter *padapter, u8 *ch, RT_SCAN_TYPE *type)
{
u8 next_state;
u8 scan_ch = 0;
RT_SCAN_TYPE scan_type = SCAN_PASSIVE;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct ss_res *ss = &pmlmeext->sitesurvey_res;
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
int ch_set_idx;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
#endif
#ifdef CONFIG_SCAN_BACKOP
u8 backop_flags = 0;
#endif
/* handle scan abort request */
scan_abort_hdl(padapter);
#ifdef CONFIG_P2P
if (pwdinfo->rx_invitereq_info.scan_op_ch_only || pwdinfo->p2p_info.scan_op_ch_only) {
if (pwdinfo->rx_invitereq_info.scan_op_ch_only)
scan_ch = pwdinfo->rx_invitereq_info.operation_ch[ss->channel_idx];
else
scan_ch = pwdinfo->p2p_info.operation_ch[ss->channel_idx];
scan_type = SCAN_ACTIVE;
} else if (rtw_p2p_findphase_ex_is_social(pwdinfo)) {
/*
* Commented by Albert 2011/06/03
* The driver is in the find phase, it should go through the social channel.
*/
scan_ch = pwdinfo->social_chan[ss->channel_idx];
ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, scan_ch);
if (ch_set_idx >= 0)
scan_type = rfctl->channel_set[ch_set_idx].ScanType;
else
scan_type = SCAN_ACTIVE;
} else
#endif /* CONFIG_P2P */
{
struct rtw_ieee80211_channel *ch;
#ifdef CONFIG_SCAN_BACKOP
backop_flags = rtw_scan_backop_decision(padapter);
#endif
#ifdef CONFIG_DFS
#ifdef CONFIG_SCAN_BACKOP
if (!(backop_flags && ss->scan_cnt >= ss->scan_cnt_max))
#endif
{
#ifdef CONFIG_RTW_WIFI_HAL
if (adapter_to_dvobj(padapter)->nodfs) {
while ( ss->channel_idx < ss->ch_num && rtw_is_dfs_ch(ss->ch[ss->channel_idx].hw_value))
ss->channel_idx++;
} else
#endif
if (ss->channel_idx != 0 && ss->dfs_ch_ssid_scan == 0
&& pmlmeext->sitesurvey_res.ssid_num
&& rtw_is_dfs_ch(ss->ch[ss->channel_idx - 1].hw_value)
) {
ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, ss->ch[ss->channel_idx - 1].hw_value);
if (ch_set_idx != -1 && rfctl->channel_set[ch_set_idx].hidden_bss_cnt
&& (!IS_DFS_SLAVE_WITH_RD(rfctl)
|| rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
|| !CH_IS_NON_OCP(&rfctl->channel_set[ch_set_idx]))
) {
ss->channel_idx--;
ss->dfs_ch_ssid_scan = 1;
}
} else
ss->dfs_ch_ssid_scan = 0;
}
#endif /* CONFIG_DFS */
if (ss->channel_idx < ss->ch_num) {
ch = &ss->ch[ss->channel_idx];
scan_ch = ch->hw_value;
#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
if (IS_ACS_ENABLE(padapter) && rtw_is_acs_passiv_scan(padapter))
scan_type = SCAN_PASSIVE;
else
#endif /*CONFIG_RTW_ACS*/
scan_type = (ch->flags & RTW_IEEE80211_CHAN_PASSIVE_SCAN) ? SCAN_PASSIVE : SCAN_ACTIVE;
}
}
if (scan_ch != 0) {
next_state = SCAN_PROCESS;
#ifdef CONFIG_SCAN_BACKOP
if (backop_flags) {
if (ss->scan_cnt < ss->scan_cnt_max)
ss->scan_cnt++;
else {
mlmeext_assign_scan_backop_flags(pmlmeext, backop_flags);
next_state = SCAN_BACKING_OP;
}
}
#endif
} else if (rtw_p2p_findphase_ex_is_needed(pwdinfo)) {
/* go p2p listen */
next_state = SCAN_TO_P2P_LISTEN;
#ifdef CONFIG_ANTENNA_DIVERSITY
} else if (rtw_hal_antdiv_before_linked(padapter)) {
/* go sw antdiv before link */
next_state = SCAN_SW_ANTDIV_BL;
#endif
} else {
next_state = SCAN_COMPLETE;
#if defined(DBG_SCAN_SW_ANTDIV_BL)
{
/* for SCAN_SW_ANTDIV_BL state testing */
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
int i;
bool is_linked = _FALSE;
for (i = 0; i < dvobj->iface_nums; i++) {
if (rtw_linked_check(dvobj->padapters[i]))
is_linked = _TRUE;
}
if (!is_linked) {
static bool fake_sw_antdiv_bl_state = 0;
if (fake_sw_antdiv_bl_state == 0) {
next_state = SCAN_SW_ANTDIV_BL;
fake_sw_antdiv_bl_state = 1;
} else
fake_sw_antdiv_bl_state = 0;
}
}
#endif /* defined(DBG_SCAN_SW_ANTDIV_BL) */
}
#ifdef CONFIG_SCAN_BACKOP
if (next_state != SCAN_PROCESS)
ss->scan_cnt = 0;
#endif
#ifdef DBG_FIXED_CHAN
if (pmlmeext->fixed_chan != 0xff && next_state == SCAN_PROCESS)
scan_ch = pmlmeext->fixed_chan;
#endif
if (ch)
*ch = scan_ch;
if (type)
*type = scan_type;
return next_state;
}
void site_survey(_adapter *padapter, u8 survey_channel, RT_SCAN_TYPE ScanType)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct ss_res *ss = &pmlmeext->sitesurvey_res;
u8 ssid_scan = 0;
#ifdef CONFIG_P2P
#ifndef CONFIG_IOCTL_CFG80211
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif
#endif
if (survey_channel != 0) {
set_channel_bwmode(padapter, survey_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
#ifdef CONFIG_DFS
if (ScanType == SCAN_PASSIVE && ss->dfs_ch_ssid_scan)
ssid_scan = 1;
else
#endif
if (ScanType == SCAN_ACTIVE) {
#ifdef CONFIG_P2P
#ifdef CONFIG_IOCTL_CFG80211
if (rtw_cfg80211_is_p2p_scan(padapter))
#else
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH))
#endif
{
issue_probereq_p2p(padapter, NULL);
issue_probereq_p2p(padapter, NULL);
issue_probereq_p2p(padapter, NULL);
} else
#endif /* CONFIG_P2P */
{
if (pmlmeext->sitesurvey_res.scan_mode == SCAN_ACTIVE) {
/* IOT issue, When wifi_spec is not set, send one probe req without WPS IE. */
if (padapter->registrypriv.wifi_spec)
issue_probereq(padapter, NULL, NULL);
else
issue_probereq_ex(padapter, NULL, NULL, 0, 0, 0, 0);
issue_probereq(padapter, NULL, NULL);
}
ssid_scan = 1;
}
}
if (ssid_scan) {
int i;
for (i = 0; i < RTW_SSID_SCAN_AMOUNT; i++) {
if (pmlmeext->sitesurvey_res.ssid[i].SsidLength) {
/* IOT issue, When wifi_spec is not set, send one probe req without WPS IE. */
if (padapter->registrypriv.wifi_spec)
issue_probereq(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL);
else
issue_probereq_ex(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL, 0, 0, 0, 0);
issue_probereq(padapter, &(pmlmeext->sitesurvey_res.ssid[i]), NULL);
}
}
}
} else {
/* channel number is 0 or this channel is not valid. */
rtw_warn_on(1);
}
return;
}
void survey_done_set_ch_bw(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
u8 cur_channel = 0;
u8 cur_bwmode;
u8 cur_ch_offset;
#ifdef CONFIG_MCC_MODE
if (!rtw_hal_mcc_change_scan_flag(padapter, &cur_channel, &cur_bwmode, &cur_ch_offset)) {
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to AP channel - ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
goto exit;
}
#endif
if (rtw_mi_get_ch_setting_union(padapter, &cur_channel, &cur_bwmode, &cur_ch_offset) != 0) {
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
} else {
#ifdef CONFIG_P2P
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
#ifdef CONFIG_IOCTL_CFG80211
if (iface->wdinfo.driver_interface == DRIVER_CFG80211 && !adapter_wdev_data(iface)->p2p_enabled)
continue;
#endif
if (rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_LISTEN)) {
cur_channel = iface->wdinfo.listen_channel;
cur_bwmode = CHANNEL_WIDTH_20;
cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to "ADPT_FMT"'s listen ch - ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), ADPT_ARG(iface), cur_channel, cur_bwmode, cur_ch_offset);
break;
}
}
#endif /* CONFIG_P2P */
if (cur_channel == 0) {
cur_channel = pmlmeext->cur_channel;
cur_bwmode = pmlmeext->cur_bwmode;
cur_ch_offset = pmlmeext->cur_ch_offset;
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), cur_channel, cur_bwmode, cur_ch_offset);
}
}
#ifdef CONFIG_MCC_MODE
exit:
#endif
set_channel_bwmode(padapter, cur_channel, cur_ch_offset, cur_bwmode);
}
/**
* rtw_ps_annc - check and doing ps announcement for all the adapters
* @adapter: the requesting adapter
* @ps: power saving or not
*
* Returns: 0: no ps announcement is doing. 1: ps announcement is doing
*/
u8 rtw_ps_annc(_adapter *adapter, bool ps)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface;
int i;
u8 ps_anc = 0;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (MLME_IS_STA(iface)) {
if (is_client_associated_to_ap(iface) == _TRUE) {
/* TODO: TDLS peers */
#ifdef CONFIG_MCC_MODE
/* for two station case */
if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_NEED_MCC)) {
u8 ch = iface->mlmeextpriv.cur_channel;
u8 offset = iface->mlmeextpriv.cur_ch_offset;
u8 bw = iface->mlmeextpriv.cur_bwmode;
set_channel_bwmode(iface, ch, offset, bw);
}
#endif /* CONFIG_MCC_MODE */
issue_nulldata(iface, NULL, ps, 3, 500);
ps_anc = 1;
}
#ifdef CONFIG_RTW_MESH
} else if (MLME_IS_MESH(iface)) {
if (rtw_mesh_ps_annc(iface, ps))
ps_anc = 1;
#endif
}
}
return ps_anc;
}
void rtw_leave_opch(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
#ifdef CONFIG_MCC_MODE
if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
return;
#endif
_enter_critical_mutex(&rfctl->offch_mutex, NULL);
if (rfctl->offch_state == OFFCHS_NONE) {
/* prepare to leave operating channel */
rfctl->offch_state = OFFCHS_LEAVING_OP;
/* clear HW TX queue */
rtw_hal_set_hwreg(adapter, HW_VAR_CHECK_TXBUF, 0);
rtw_hal_macid_sleep_all_used(adapter);
rtw_ps_annc(adapter, 1);
rfctl->offch_state = OFFCHS_LEAVE_OP;
}
_exit_critical_mutex(&rfctl->offch_mutex, NULL);
}
void rtw_back_opch(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
#ifdef CONFIG_MCC_MODE
if (MCC_EN(adapter) && rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
return;
#endif
_enter_critical_mutex(&rfctl->offch_mutex, NULL);
if (rfctl->offch_state != OFFCHS_NONE) {
rfctl->offch_state = OFFCHS_BACKING_OP;
rtw_hal_macid_wakeup_all_used(adapter);
rtw_ps_annc(adapter, 0);
rfctl->offch_state = OFFCHS_NONE;
rtw_mi_os_xmit_schedule(adapter);
}
_exit_critical_mutex(&rfctl->offch_mutex, NULL);
}
void sitesurvey_set_igi(_adapter *adapter)
{
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct ss_res *ss = &mlmeext->sitesurvey_res;
u8 igi;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
#endif
switch (mlmeext_scan_state(mlmeext)) {
case SCAN_ENTER:
#ifdef CONFIG_P2P
#ifdef CONFIG_IOCTL_CFG80211
if (pwdinfo->driver_interface == DRIVER_CFG80211 && rtw_cfg80211_is_p2p_scan(adapter))
igi = 0x30;
else
#endif /* CONFIG_IOCTL_CFG80211 */
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
igi = 0x28;
else
#endif /* CONFIG_P2P */
if (ss->igi)
igi = ss->igi;
else
#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
if (IS_ACS_ENABLE(adapter) && rtw_is_acs_igi_valid(adapter))
igi = rtw_acs_get_adv_igi(adapter);
else
#endif /*CONFIG_RTW_ACS*/
igi = 0x1e;
/* record IGI status */
ss->igi_scan = igi;
rtw_hal_get_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &ss->igi_before_scan, NULL);
/* disable DIG and set IGI for scan */
rtw_hal_set_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &igi, _FALSE);
break;
case SCAN_COMPLETE:
case SCAN_TO_P2P_LISTEN:
/* enable DIG and restore IGI */
igi = 0xff;
rtw_hal_set_odm_var(adapter, HAL_ODM_INITIAL_GAIN, &igi, _FALSE);
break;
#ifdef CONFIG_SCAN_BACKOP
case SCAN_BACKING_OP:
/* write IGI for op channel when DIG is not enabled */
odm_write_dig(adapter_to_phydm(adapter), ss->igi_before_scan);
break;
case SCAN_LEAVE_OP:
/* write IGI for scan when DIG is not enabled */
odm_write_dig(adapter_to_phydm(adapter), ss->igi_scan);
break;
#endif /* CONFIG_SCAN_BACKOP */
default:
rtw_warn_on(1);
break;
}
}
void sitesurvey_set_msr(_adapter *adapter, bool enter)
{
u8 network_type;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (enter) {
#ifdef CONFIG_MI_WITH_MBSSID_CAM
rtw_hal_get_hwreg(adapter, HW_VAR_MEDIA_STATUS, (u8 *)(&pmlmeinfo->hw_media_state));
#endif
/* set MSR to no link state */
network_type = _HW_STATE_NOLINK_;
} else {
#ifdef CONFIG_MI_WITH_MBSSID_CAM
network_type = pmlmeinfo->hw_media_state;
#else
network_type = pmlmeinfo->state & 0x3;
#endif
}
Set_MSR(adapter, network_type);
}
void sitesurvey_set_offch_state(_adapter *adapter, u8 scan_state)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
_enter_critical_mutex(&rfctl->offch_mutex, NULL);
switch (scan_state) {
case SCAN_DISABLE:
case SCAN_BACK_OP:
rfctl->offch_state = OFFCHS_NONE;
break;
case SCAN_START:
case SCAN_LEAVING_OP:
rfctl->offch_state = OFFCHS_LEAVING_OP;
break;
case SCAN_ENTER:
case SCAN_LEAVE_OP:
rfctl->offch_state = OFFCHS_LEAVE_OP;
break;
case SCAN_COMPLETE:
case SCAN_BACKING_OP:
rfctl->offch_state = OFFCHS_BACKING_OP;
break;
default:
break;
}
_exit_critical_mutex(&rfctl->offch_mutex, NULL);
}
u8 sitesurvey_cmd_hdl(_adapter *padapter, u8 *pbuf)
{
struct sitesurvey_parm *pparm = (struct sitesurvey_parm *)pbuf;
#ifdef DBG_CHECK_FW_PS_STATE
struct dvobj_priv *dvobj = padapter->dvobj;
struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
#endif
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct ss_res *ss = &pmlmeext->sitesurvey_res;
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
#endif
u8 val8;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
#endif
#ifdef DBG_CHECK_FW_PS_STATE
if (rtw_fw_ps_state(padapter) == _FAIL) {
RTW_INFO("scan without leave 32k\n");
pdbgpriv->dbg_scan_pwr_state_cnt++;
}
#endif /* DBG_CHECK_FW_PS_STATE */
/* increase channel idx */
if (mlmeext_chk_scan_state(pmlmeext, SCAN_PROCESS))
ss->channel_idx++;
/* update scan state to next state (assigned by previous cmd hdl) */
if (mlmeext_scan_state(pmlmeext) != mlmeext_scan_next_state(pmlmeext))
mlmeext_set_scan_state(pmlmeext, mlmeext_scan_next_state(pmlmeext));
operation_by_state:
switch (mlmeext_scan_state(pmlmeext)) {
case SCAN_DISABLE:
/*
* SW parameter initialization
*/
sitesurvey_res_reset(padapter, pparm);
mlmeext_set_scan_state(pmlmeext, SCAN_START);
goto operation_by_state;
case SCAN_START:
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
if ((pwdev_priv->pno_mac_addr[0] != 0xFF)
&& (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(&padapter->mlmepriv, _FW_LINKED) == _FALSE)) {
u16 seq_num;
rtw_hal_pno_random_gen_mac_addr(padapter);
rtw_hal_set_hw_mac_addr(padapter, pwdev_priv->pno_mac_addr);
get_random_bytes(&seq_num, 2);
pwdev_priv->pno_scan_seq_num = seq_num & 0xFFF;
RTW_INFO("%s pno_scan_seq_num %d\n", __func__,
pwdev_priv->pno_scan_seq_num);
}
#endif
/*
* prepare to leave operating channel
*/
#ifdef CONFIG_MCC_MODE
rtw_hal_set_mcc_setting_scan_start(padapter);
#endif /* CONFIG_MCC_MODE */
/* apply rx ampdu setting */
if (ss->rx_ampdu_accept != RX_AMPDU_ACCEPT_INVALID
|| ss->rx_ampdu_size != RX_AMPDU_SIZE_INVALID)
rtw_rx_ampdu_apply(padapter);
/* clear HW TX queue before scan */
rtw_hal_set_hwreg(padapter, HW_VAR_CHECK_TXBUF, 0);
rtw_hal_macid_sleep_all_used(padapter);
/* power save state announcement */
if (rtw_ps_annc(padapter, 1)) {
mlmeext_set_scan_state(pmlmeext, SCAN_PS_ANNC_WAIT);
mlmeext_set_scan_next_state(pmlmeext, SCAN_ENTER);
set_survey_timer(pmlmeext, 50); /* delay 50ms to protect nulldata(1) */
} else {
mlmeext_set_scan_state(pmlmeext, SCAN_ENTER);
goto operation_by_state;
}
break;
case SCAN_ENTER:
/*
* HW register and DM setting for enter scan
*/
rtw_phydm_ability_backup(padapter);
sitesurvey_set_igi(padapter);
/* config dynamic functions for off channel */
rtw_phydm_func_for_offchannel(padapter);
/* set MSR to no link state */
sitesurvey_set_msr(padapter, _TRUE);
val8 = 1; /* under site survey */
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
mlmeext_set_scan_state(pmlmeext, SCAN_PROCESS);
goto operation_by_state;
case SCAN_PROCESS: {
u8 scan_ch;
RT_SCAN_TYPE scan_type;
u8 next_state;
u32 scan_ms;
#ifdef CONFIG_RTW_ACS
if (IS_ACS_ENABLE(padapter))
rtw_acs_get_rst(padapter);
#endif
next_state = sitesurvey_pick_ch_behavior(padapter, &scan_ch, &scan_type);
if (next_state != SCAN_PROCESS) {
mlmeext_set_scan_state(pmlmeext, next_state);
goto operation_by_state;
}
/* still SCAN_PROCESS state */
#ifdef DBG_SITESURVEY
#ifdef CONFIG_P2P
RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (cnt:%u,idx:%d) at %dms, %c%c%c%c\n"
, FUNC_ADPT_ARG(padapter)
, mlmeext_scan_state_str(pmlmeext)
, scan_ch
, pwdinfo->find_phase_state_exchange_cnt, ss->channel_idx
, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
, scan_type ? 'A' : 'P', ss->scan_mode ? 'A' : 'P'
, ss->ssid[0].SsidLength ? 'S' : ' '
, ss->dfs_ch_ssid_scan ? 'D' : ' '
);
#else
RTW_INFO(FUNC_ADPT_FMT" %s ch:%u (idx:%d) at %dms, %c%c%c%c\n"
, FUNC_ADPT_ARG(padapter)
, mlmeext_scan_state_str(pmlmeext)
, scan_ch
, ss->channel_idx
, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
, scan_type ? 'A' : 'P', ss->scan_mode ? 'A' : 'P'
, ss->ssid[0].SsidLength ? 'S' : ' '
, ss->dfs_ch_ssid_scan ? 'D' : ' '
);
#endif /* CONFIG_P2P */
#endif /*DBG_SITESURVEY*/
#ifdef DBG_FIXED_CHAN
if (pmlmeext->fixed_chan != 0xff)
RTW_INFO(FUNC_ADPT_FMT" fixed_chan:%u\n", pmlmeext->fixed_chan);
#endif
site_survey(padapter, scan_ch, scan_type);
#if defined(CONFIG_ATMEL_RC_PATCH)
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
scan_ms = 20;
else
scan_ms = 40;
#else
#if defined(CONFIG_RTW_ACS) && defined(CONFIG_RTW_ACS_DBG)
if (IS_ACS_ENABLE(padapter) && rtw_is_acs_st_valid(padapter))
scan_ms = rtw_acs_get_adv_st(padapter);
else
#endif /*CONFIG_RTW_ACS*/
scan_ms = ss->scan_ch_ms;
#endif
#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
if (ss->is_sw_antdiv_bl_scan)
scan_ms = scan_ms / 2;
#endif
#ifdef CONFIG_RTW_ACS
if (IS_ACS_ENABLE(padapter)) {
if (pparm->token)
rtw_acs_trigger(padapter, scan_ms, scan_ch, NHM_PID_IEEE_11K_HIGH);
else
rtw_acs_trigger(padapter, scan_ms, scan_ch, NHM_PID_ACS);
}
#endif
#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
if (IS_NM_ENABLE(padapter))
rtw_noise_measure(padapter, scan_ch, _FALSE, 0, scan_ms / 2);
#endif
set_survey_timer(pmlmeext, scan_ms);
break;
}
#ifdef CONFIG_SCAN_BACKOP
case SCAN_BACKING_OP: {
u8 back_ch, back_bw, back_ch_offset;
u8 need_ch_setting_union = _TRUE;
#ifdef CONFIG_MCC_MODE
need_ch_setting_union = rtw_hal_mcc_change_scan_flag(padapter,
&back_ch, &back_bw, &back_ch_offset);
#endif /* CONFIG_MCC_MODE */
if (need_ch_setting_union) {
if (rtw_mi_get_ch_setting_union(padapter, &back_ch, &back_bw, &back_ch_offset) == 0)
rtw_warn_on(1);
}
#ifdef DBG_SITESURVEY
RTW_INFO(FUNC_ADPT_FMT" %s ch:%u, bw:%u, offset:%u at %dms\n"
, FUNC_ADPT_ARG(padapter)
, mlmeext_scan_state_str(pmlmeext)
, back_ch, back_bw, back_ch_offset
, rtw_get_passing_time_ms(padapter->mlmepriv.scan_start_time)
);
#endif /*DBG_SITESURVEY*/
set_channel_bwmode(padapter, back_ch, back_ch_offset, back_bw);
sitesurvey_set_msr(padapter, _FALSE);
val8 = 0; /* survey done */
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC)) {
sitesurvey_set_igi(padapter);
rtw_hal_macid_wakeup_all_used(padapter);
rtw_ps_annc(padapter, 0);
}
mlmeext_set_scan_state(pmlmeext, SCAN_BACK_OP);
ss->backop_time = rtw_get_current_time();
if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_TX_RESUME))
rtw_mi_os_xmit_schedule(padapter);
goto operation_by_state;
}
case SCAN_BACK_OP:
if (rtw_get_passing_time_ms(ss->backop_time) >= ss->backop_ms
|| pmlmeext->scan_abort
) {
mlmeext_set_scan_state(pmlmeext, SCAN_LEAVING_OP);
goto operation_by_state;
}
set_survey_timer(pmlmeext, 50);
break;
case SCAN_LEAVING_OP:
/*
* prepare to leave operating channel
*/
/* clear HW TX queue before scan */
rtw_hal_set_hwreg(padapter, HW_VAR_CHECK_TXBUF, 0);
rtw_hal_macid_sleep_all_used(padapter);
if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC)
&& rtw_ps_annc(padapter, 1)
) {
mlmeext_set_scan_state(pmlmeext, SCAN_PS_ANNC_WAIT);
mlmeext_set_scan_next_state(pmlmeext, SCAN_LEAVE_OP);
set_survey_timer(pmlmeext, 50); /* delay 50ms to protect nulldata(1) */
} else {
mlmeext_set_scan_state(pmlmeext, SCAN_LEAVE_OP);
goto operation_by_state;
}
break;
case SCAN_LEAVE_OP:
/*
* HW register and DM setting for enter scan
*/
if (mlmeext_chk_scan_backop_flags(pmlmeext, SS_BACKOP_PS_ANNC))
sitesurvey_set_igi(padapter);
sitesurvey_set_msr(padapter, _TRUE);
val8 = 1; /* under site survey */
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
mlmeext_set_scan_state(pmlmeext, SCAN_PROCESS);
goto operation_by_state;
#endif /* CONFIG_SCAN_BACKOP */
#if defined(CONFIG_ANTENNA_DIVERSITY) || defined(DBG_SCAN_SW_ANTDIV_BL)
case SCAN_SW_ANTDIV_BL:
/*
* 20100721
* For SW antenna diversity before link, it needs to switch to another antenna and scan again.
* It compares the scan result and select better one to do connection.
*/
ss->bss_cnt = 0;
ss->channel_idx = 0;
ss->is_sw_antdiv_bl_scan = 1;
mlmeext_set_scan_next_state(pmlmeext, SCAN_PROCESS);
set_survey_timer(pmlmeext, ss->scan_ch_ms);
break;
#endif
#ifdef CONFIG_P2P
case SCAN_TO_P2P_LISTEN:
/*
* Set the P2P State to the listen state of find phase
* and set the current channel to the listen channel
*/
set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_LISTEN);
/* turn on phy-dynamic functions */
rtw_phydm_ability_restore(padapter);
sitesurvey_set_igi(padapter);
mlmeext_set_scan_state(pmlmeext, SCAN_P2P_LISTEN);
_set_timer(&pwdinfo->find_phase_timer, (u32)((u32)pwdinfo->listen_dwell * 100));
break;
case SCAN_P2P_LISTEN:
mlmeext_set_scan_state(pmlmeext, SCAN_PROCESS);
ss->channel_idx = 0;
goto operation_by_state;
#endif /* CONFIG_P2P */
case SCAN_COMPLETE:
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
rtw_hal_set_hw_mac_addr(padapter, adapter_mac_addr(padapter));
#endif
#ifdef CONFIG_P2P
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_SCAN)
|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH)
) {
#ifdef CONFIG_CONCURRENT_MODE
if (pwdinfo->driver_interface == DRIVER_WEXT) {
if (rtw_mi_check_status(padapter, MI_LINKED))
_set_timer(&pwdinfo->ap_p2p_switch_timer, 500);
}
#endif
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
}
rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
#endif /* CONFIG_P2P */
/* switch channel */
survey_done_set_ch_bw(padapter);
sitesurvey_set_msr(padapter, _FALSE);
val8 = 0; /* survey done */
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
/* turn on phy-dynamic functions */
rtw_phydm_ability_restore(padapter);
sitesurvey_set_igi(padapter);
#ifdef CONFIG_MCC_MODE
/* start MCC fail, then tx null data */
if (!rtw_hal_set_mcc_setting_scan_complete(padapter))
#endif
{
rtw_hal_macid_wakeup_all_used(padapter);
rtw_ps_annc(padapter, 0);
}
/* apply rx ampdu setting */
rtw_rx_ampdu_apply(padapter);
mlmeext_set_scan_state(pmlmeext, SCAN_DISABLE);
report_surveydone_event(padapter);
#ifdef CONFIG_RTW_ACS
if (IS_ACS_ENABLE(padapter))
rtw_acs_select_best_chan(padapter);
#endif
#if defined(CONFIG_BACKGROUND_NOISE_MONITOR) && defined(DBG_NOISE_MONITOR)
if (IS_NM_ENABLE(padapter))
rtw_noise_info_dump(RTW_DBGDUMP, padapter);
#endif
issue_action_BSSCoexistPacket(padapter);
issue_action_BSSCoexistPacket(padapter);
issue_action_BSSCoexistPacket(padapter);
#ifdef CONFIG_RTW_80211K
if (ss->token)
rm_post_event(padapter, ss->token, RM_EV_survey_done);
#endif /* CONFIG_RTW_80211K */
break;
}
return H2C_SUCCESS;
}
u8 setauth_hdl(_adapter *padapter, unsigned char *pbuf)
{
struct setauth_parm *pparm = (struct setauth_parm *)pbuf;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pparm->mode < 4)
pmlmeinfo->auth_algo = pparm->mode;
return H2C_SUCCESS;
}
/*
SEC CAM Entry format (32 bytes)
DW0 - MAC_ADDR[15:0] | Valid[15] | MFB[14:8] | RSVD[7] | GK[6] | MIC_KEY[5] | SEC_TYPE[4:2] | KID[1:0]
DW0 - MAC_ADDR[15:0] | Valid[15] |RSVD[14:9] | RPT_MODE[8] | SPP_MODE[7] | GK[6] | MIC_KEY[5] | SEC_TYPE[4:2] | KID[1:0] (92E/8812A/8814A)
DW1 - MAC_ADDR[47:16]
DW2 - KEY[31:0]
DW3 - KEY[63:32]
DW4 - KEY[95:64]
DW5 - KEY[127:96]
DW6 - RSVD
DW7 - RSVD
*/
/*Set WEP key or Group Key*/
u8 setkey_hdl(_adapter *padapter, u8 *pbuf)
{
u16 ctrl = 0;
s16 cam_id = 0;
struct setkey_parm *pparm = (struct setkey_parm *)pbuf;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
unsigned char null_addr[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
u8 *addr;
bool used = _FALSE;
/* main tx key for wep. */
if (pparm->set_tx)
pmlmeinfo->key_index = pparm->keyid;
#ifdef CONFIG_CONCURRENT_MODE
if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
cam_id = rtw_iface_bcmc_id_get(padapter);
else
#endif
cam_id = rtw_camid_alloc(padapter, NULL, pparm->keyid, 1, &used);
if (cam_id < 0)
goto enable_mc;
#ifndef CONFIG_CONCURRENT_MODE
if (cam_id >= 0 && cam_id <= 3) {
/* default key camid */
addr = null_addr;
} else
#endif
{
/* not default key camid */
if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)) {
/* group TX, force sec cam entry_id */
addr = adapter_mac_addr(padapter);
} else {
/* group RX, searched by A2 (TA) */
addr = get_bssid(&padapter->mlmepriv);
}
}
#ifdef CONFIG_LPS_PG
if (adapter_to_pwrctl(padapter)->lps_level == LPS_PG)
LPS_Leave(padapter, "SET_KEY");
#endif
/* cam entry searched is pairwise key */
if (used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _FALSE) {
s16 camid_clr;
RTW_PRINT(FUNC_ADPT_FMT" group key with "MAC_FMT" id:%u the same key id as pairwise key\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(addr), pparm->keyid);
/* HW has problem to distinguish this group key with existing pairwise key, stop HW enc and dec for BMC */
rtw_camctl_set_flags(padapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH);
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, NULL);
/* clear group key */
while ((camid_clr = rtw_camid_search(padapter, addr, -1, 1)) >= 0) {
RTW_PRINT("clear group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(addr), camid_clr);
clear_cam_entry(padapter, camid_clr);
rtw_camid_free(padapter, camid_clr);
}
goto enable_mc;
}
ctrl = BIT(15) | BIT(6) | ((pparm->algorithm) << 2) | pparm->keyid;
RTW_PRINT("set group key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n"
, cam_id, MAC_ARG(addr), pparm->keyid, security_type_str(pparm->algorithm));
write_cam(padapter, cam_id, ctrl, addr, pparm->key);
/* if ((cam_id > 3) && (((pmlmeinfo->state&0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE)))*/
#ifdef CONFIG_CONCURRENT_MODE
if (((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE)) {
if (is_wep_enc(pparm->algorithm)) {
padapter->securitypriv.dot11Def_camid[pparm->keyid] = cam_id;
padapter->securitypriv.dot118021x_bmc_cam_id =
padapter->securitypriv.dot11Def_camid[padapter->securitypriv.dot11PrivacyKeyIndex];
RTW_PRINT("wep group key - force camid:%d\n", padapter->securitypriv.dot118021x_bmc_cam_id);
} else {
/*u8 org_cam_id = padapter->securitypriv.dot118021x_bmc_cam_id;*/
/*force GK's cam id*/
padapter->securitypriv.dot118021x_bmc_cam_id = cam_id;
/* for GTK rekey
if ((org_cam_id != INVALID_SEC_MAC_CAM_ID) &&
(org_cam_id != cam_id)) {
RTW_PRINT("clear group key for addr:"MAC_FMT", org_camid:%d new_camid:%d\n", MAC_ARG(addr), org_cam_id, cam_id);
clear_cam_entry(padapter, org_cam_id);
rtw_camid_free(padapter, org_cam_id);
}*/
}
}
#endif
#ifndef CONFIG_CONCURRENT_MODE
if (cam_id >= 0 && cam_id <= 3)
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8 *)_TRUE);
#endif
/* 8814au should set both broadcast and unicast CAM entry for WEP key in STA mode */
if (is_wep_enc(pparm->algorithm) && check_mlmeinfo_state(pmlmeext, WIFI_FW_STATION_STATE) &&
_rtw_camctl_chk_cap(padapter, SEC_CAP_CHK_BMC)) {
struct set_stakey_parm sta_pparm;
_rtw_memset(&sta_pparm, 0, sizeof(struct set_stakey_parm));
sta_pparm.algorithm = pparm->algorithm;
sta_pparm.keyid = pparm->keyid;
_rtw_memcpy(sta_pparm.key, pparm->key, 16);
_rtw_memcpy(sta_pparm.addr, get_bssid(&padapter->mlmepriv), ETH_ALEN);
set_stakey_hdl(padapter, (u8 *)&sta_pparm);
}
enable_mc:
/* allow multicast packets to driver */
rtw_hal_set_hwreg(padapter, HW_VAR_ON_RCR_AM, null_addr);
return H2C_SUCCESS;
}
void rtw_ap_wep_pk_setting(_adapter *adapter, struct sta_info *psta)
{
struct security_priv *psecuritypriv = &(adapter->securitypriv);
struct set_stakey_parm sta_pparm;
sint keyid;
if (!is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm))
return;
for (keyid = 0; keyid < 4; keyid++) {
if ((psecuritypriv->key_mask & BIT(keyid)) && (keyid == psecuritypriv->dot11PrivacyKeyIndex)) {
sta_pparm.algorithm = psecuritypriv->dot11PrivacyAlgrthm;
sta_pparm.keyid = keyid;
sta_pparm.gk = 0;
_rtw_memcpy(sta_pparm.key, &(psecuritypriv->dot11DefKey[keyid].skey[0]), 16);
_rtw_memcpy(sta_pparm.addr, psta->cmn.mac_addr, ETH_ALEN);
RTW_PRINT(FUNC_ADPT_FMT"set WEP - PK with "MAC_FMT" keyid:%u\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr), keyid);
set_stakey_hdl(adapter, (u8 *)&sta_pparm);
}
}
}
u8 set_stakey_hdl(_adapter *padapter, u8 *pbuf)
{
u16 ctrl = 0;
s16 cam_id = 0;
bool used;
u8 ret = H2C_SUCCESS;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct set_stakey_parm *pparm = (struct set_stakey_parm *)pbuf;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
if (pparm->algorithm == _NO_PRIVACY_)
goto write_to_cam;
psta = rtw_get_stainfo(pstapriv, pparm->addr);
if (!psta) {
RTW_PRINT("%s sta:"MAC_FMT" not found\n", __func__, MAC_ARG(pparm->addr));
ret = H2C_REJECTED;
goto exit;
}
pmlmeinfo->enc_algo = pparm->algorithm;
cam_id = rtw_camid_alloc(padapter, psta, pparm->keyid, pparm->gk, &used);
if (cam_id < 0)
goto exit;
#ifdef CONFIG_LPS_PG
if (adapter_to_pwrctl(padapter)->lps_level == LPS_PG)
LPS_Leave(padapter, "SET_KEY");
#endif
/* cam entry searched is group key when setting pariwise key */
if (!pparm->gk && used == _TRUE && rtw_camid_is_gk(padapter, cam_id) == _TRUE) {
s16 camid_clr;
RTW_PRINT(FUNC_ADPT_FMT" pairwise key with "MAC_FMT" id:%u the same key id as group key\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(pparm->addr), pparm->keyid);
/* HW has problem to distinguish this pairwise key with existing group key, stop HW enc and dec for BMC */
rtw_camctl_set_flags(padapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH);
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, NULL);
/* clear group key */
while ((camid_clr = rtw_camid_search(padapter, pparm->addr, -1, 1)) >= 0) {
RTW_PRINT("clear group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(pparm->addr), camid_clr);
clear_cam_entry(padapter, camid_clr);
rtw_camid_free(padapter, camid_clr);
}
}
write_to_cam:
if (pparm->algorithm == _NO_PRIVACY_) {
while ((cam_id = rtw_camid_search(padapter, pparm->addr, -1, -1)) >= 0) {
RTW_PRINT("clear key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(pparm->addr), cam_id);
clear_cam_entry(padapter, cam_id);
rtw_camid_free(padapter, cam_id);
}
} else {
RTW_PRINT("set %s key camid:%d, addr:"MAC_FMT", kid:%d, type:%s\n"
, pparm->gk ? "group" : "pairwise"
, cam_id, MAC_ARG(pparm->addr), pparm->keyid, security_type_str(pparm->algorithm));
ctrl = BIT(15) | ((pparm->algorithm) << 2) | pparm->keyid;
if (pparm->gk)
ctrl |= BIT(6);
write_cam(padapter, cam_id, ctrl, pparm->addr, pparm->key);
}
ret = H2C_SUCCESS_RSP;
exit:
return ret;
}
u8 add_ba_hdl(_adapter *padapter, unsigned char *pbuf)
{
struct addBaReq_parm *pparm = (struct addBaReq_parm *)pbuf;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_info *psta = rtw_get_stainfo(&padapter->stapriv, pparm->addr);
if (!psta)
return H2C_SUCCESS;
#ifdef CONFIG_80211N_HT
if (((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && (pmlmeinfo->HT_enable)) ||
((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
/* pmlmeinfo->ADDBA_retry_count = 0; */
/* pmlmeinfo->candidate_tid_bitmap |= (0x1 << pparm->tid); */
/* psta->htpriv.candidate_tid_bitmap |= BIT(pparm->tid); */
issue_addba_req(padapter, pparm->addr, (u8)pparm->tid);
_set_timer(&psta->addba_retry_timer, ADDBA_TO);
}
#ifdef CONFIG_TDLS
else if ((psta->tdls_sta_state & TDLS_LINKED_STATE) &&
(psta->htpriv.ht_option == _TRUE) &&
(psta->htpriv.ampdu_enable == _TRUE)) {
issue_addba_req(padapter, pparm->addr, (u8)pparm->tid);
_set_timer(&psta->addba_retry_timer, ADDBA_TO);
}
#endif /* CONFIG */
else
psta->htpriv.candidate_tid_bitmap &= ~BIT(pparm->tid);
#endif /* CONFIG_80211N_HT */
return H2C_SUCCESS;
}
u8 add_ba_rsp_hdl(_adapter *padapter, unsigned char *pbuf)
{
struct addBaRsp_parm *pparm = (struct addBaRsp_parm *)pbuf;
struct recv_reorder_ctrl *preorder_ctrl;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
u8 ret = _TRUE;
psta = rtw_get_stainfo(pstapriv, pparm->addr);
if (!psta)
goto exit;
preorder_ctrl = &psta->recvreorder_ctrl[pparm->tid];
ret = issue_addba_rsp_wait_ack(padapter, pparm->addr, pparm->tid, pparm->status, pparm->size, 3, 50);
#ifdef CONFIG_UPDATE_INDICATE_SEQ_WHILE_PROCESS_ADDBA_REQ
/* status = 0 means accept this addba req, so update indicate seq = start_seq under this compile flag */
if (pparm->status == 0) {
preorder_ctrl->indicate_seq = pparm->start_seq;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_UPDATE indicate_seq:%d, start_seq:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pparm->start_seq);
#endif
}
#else
rtw_set_bit(RTW_RECV_ACK_OR_TIMEOUT, &preorder_ctrl->rec_abba_rsp_ack);
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_CLEAR indicate_seq:%d, start_seq:%d preorder_ctrl->rec_abba_rsp_ack =%lu \n"
, FUNC_ADPT_ARG(padapter)
, preorder_ctrl->tid
, preorder_ctrl->indicate_seq
, pparm->start_seq
,preorder_ctrl->rec_abba_rsp_ack
);
#endif
#endif
/*
* status = 0 means accept this addba req
* status = 37 means reject this addba req
*/
if (pparm->status == 0) {
preorder_ctrl->enable = _TRUE;
preorder_ctrl->ampdu_size = pparm->size;
} else if (pparm->status == 37)
preorder_ctrl->enable = _FALSE;
exit:
return H2C_SUCCESS;
}
u8 chk_bmc_sleepq_cmd(_adapter *padapter)
{
struct cmd_obj *ph2c;
struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
init_h2fwcmd_w_parm_no_parm_rsp(ph2c, GEN_CMD_CODE(_ChkBMCSleepq));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
u8 set_tx_beacon_cmd(_adapter *padapter, u8 flags)
{
struct cmd_obj *ph2c;
struct Tx_Beacon_param *ptxBeacon_parm;
struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct submit_ctx sctx;
u8 res = _SUCCESS;
int len_diff = 0;
/*prepare cmd parameter*/
ptxBeacon_parm = (struct Tx_Beacon_param *)rtw_zmalloc(sizeof(struct Tx_Beacon_param));
if (ptxBeacon_parm == NULL) {
res = _FAIL;
goto exit;
}
_rtw_memcpy(&(ptxBeacon_parm->network), &(pmlmeinfo->network), sizeof(WLAN_BSSID_EX));
len_diff = update_hidden_ssid(
ptxBeacon_parm->network.IEs + _BEACON_IE_OFFSET_
, ptxBeacon_parm->network.IELength - _BEACON_IE_OFFSET_
, pmlmeinfo->hidden_ssid_mode
);
ptxBeacon_parm->network.IELength += len_diff;
/* need enqueue, prepare cmd_obj and enqueue */
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
rtw_mfree((u8 *)ptxBeacon_parm, sizeof(*ptxBeacon_parm));
goto exit;
}
init_h2fwcmd_w_parm_no_rsp(ph2c, ptxBeacon_parm, GEN_CMD_CODE(_TX_Beacon));
if (flags & RTW_CMDF_WAIT_ACK) {
ph2c->sctx = &sctx;
rtw_sctx_init(&sctx, 10 * 1000);
}
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
if (res == _SUCCESS && (flags & RTW_CMDF_WAIT_ACK)) {
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
if (sctx.status == RTW_SCTX_SUBMITTED)
ph2c->sctx = NULL;
_exit_critical_mutex(&pcmdpriv->sctx_mutex, NULL);
}
exit:
return res;
}
u8 mlme_evt_hdl(_adapter *padapter, unsigned char *pbuf)
{
u8 evt_code, evt_seq;
u16 evt_sz;
uint *peventbuf;
void (*event_callback)(_adapter *dev, u8 *pbuf);
struct evt_priv *pevt_priv = &(padapter->evtpriv);
if (pbuf == NULL)
goto _abort_event_;
peventbuf = (uint *)pbuf;
evt_sz = (u16)(*peventbuf & 0xffff);
evt_seq = (u8)((*peventbuf >> 24) & 0x7f);
evt_code = (u8)((*peventbuf >> 16) & 0xff);
#ifdef CHECK_EVENT_SEQ
/* checking event sequence... */
if (evt_seq != (ATOMIC_READ(&pevt_priv->event_seq) & 0x7f)) {
pevt_priv->event_seq = (evt_seq + 1) & 0x7f;
goto _abort_event_;
}
#endif
/* checking if event code is valid */
if (evt_code >= MAX_C2HEVT) {
goto _abort_event_;
}
/* checking if event size match the event parm size */
if ((wlanevents[evt_code].parmsize != 0) &&
(wlanevents[evt_code].parmsize != evt_sz)) {
goto _abort_event_;
}
ATOMIC_INC(&pevt_priv->event_seq);
peventbuf += 2;
if (peventbuf) {
event_callback = wlanevents[evt_code].event_callback;
event_callback(padapter, (u8 *)peventbuf);
pevt_priv->evt_done_cnt++;
}
_abort_event_:
return H2C_SUCCESS;
}
u8 h2c_msg_hdl(_adapter *padapter, unsigned char *pbuf)
{
if (!pbuf)
return H2C_PARAMETERS_ERROR;
return H2C_SUCCESS;
}
u8 chk_bmc_sleepq_hdl(_adapter *padapter, unsigned char *pbuf)
{
#ifdef CONFIG_AP_MODE
_irqL irqL;
struct sta_info *psta_bmc;
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct sta_priv *pstapriv = &padapter->stapriv;
/* for BC/MC Frames */
psta_bmc = rtw_get_bcmc_stainfo(padapter);
if (!psta_bmc)
return H2C_SUCCESS;
if ((rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) && (psta_bmc->sleepq_len > 0)) {
#ifndef CONFIG_PCI_HCI
rtw_msleep_os(10);/* 10ms, ATIM(HIQ) Windows */
#endif
/* _enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL); */
_enter_critical_bh(&pxmitpriv->lock, &irqL);
xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
rtw_list_delete(&pxmitframe->list);
psta_bmc->sleepq_len--;
if (psta_bmc->sleepq_len > 0)
pxmitframe->attrib.mdata = 1;
else
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.triggered = 1;
if (xmitframe_hiq_filter(pxmitframe) == _TRUE)
pxmitframe->attrib.qsel = QSLT_HIGH;/* HIQ */
#if 0
_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
if (rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
rtw_os_xmit_complete(padapter, pxmitframe);
_enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
#endif
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
}
/* _exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL); */
_exit_critical_bh(&pxmitpriv->lock, &irqL);
if (rtw_get_intf_type(padapter) != RTW_PCIE) {
/* check hi queue and bmc_sleepq */
rtw_chk_hi_queue_cmd(padapter);
}
}
#endif
return H2C_SUCCESS;
}
u8 tx_beacon_hdl(_adapter *padapter, unsigned char *pbuf)
{
/*RTW_INFO(FUNC_ADPT_FMT, FUNC_ADPT_ARG(padapter));*/
#ifdef CONFIG_SWTIMER_BASED_TXBCN
tx_beacon_handlder(padapter->dvobj);
#else
if (send_beacon(padapter) == _FAIL) {
RTW_INFO("issue_beacon, fail!\n");
return H2C_PARAMETERS_ERROR;
}
/* tx bc/mc frames after update TIM */
chk_bmc_sleepq_hdl(padapter, NULL);
#endif
return H2C_SUCCESS;
}
/*
* according to channel
* add/remove WLAN_BSSID_EX.IEs's ERP ie
* set WLAN_BSSID_EX.SupportedRates
* update WLAN_BSSID_EX.IEs's Supported Rate and Extended Supported Rate ie
*/
void change_band_update_ie(_adapter *padapter, WLAN_BSSID_EX *pnetwork, u8 ch)
{
u8 network_type, rate_len, total_rate_len, remainder_rate_len;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
u8 erpinfo = 0x4;
if (ch >= 36) {
network_type = WIRELESS_11A;
total_rate_len = IEEE80211_NUM_OFDM_RATESLEN;
rtw_remove_bcn_ie(padapter, pnetwork, _ERPINFO_IE_);
#ifdef CONFIG_80211AC_VHT
/* if channel in 5G band, then add vht ie . */
if ((pmlmepriv->htpriv.ht_option == _TRUE)
&& REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
&& is_supported_vht(padapter->registrypriv.wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
) {
if (REGSTY_IS_11AC_AUTO(&padapter->registrypriv)
|| pmlmepriv->ori_vht_en)
rtw_vht_ies_attach(padapter, pnetwork);
}
#endif
} else {
network_type = 0;
total_rate_len = 0;
if (padapter->registrypriv.wireless_mode & WIRELESS_11B) {
network_type |= WIRELESS_11B;
total_rate_len += IEEE80211_CCK_RATE_LEN;
}
if (padapter->registrypriv.wireless_mode & WIRELESS_11G) {
network_type |= WIRELESS_11G;
total_rate_len += IEEE80211_NUM_OFDM_RATESLEN;
}
rtw_add_bcn_ie(padapter, pnetwork, _ERPINFO_IE_, &erpinfo, 1);
#ifdef CONFIG_80211AC_VHT
rtw_vht_ies_detach(padapter, pnetwork);
#endif
}
rtw_set_supported_rate(pnetwork->SupportedRates, network_type);
UpdateBrateTbl(padapter, pnetwork->SupportedRates);
if (total_rate_len > 8) {
rate_len = 8;
remainder_rate_len = total_rate_len - 8;
} else {
rate_len = total_rate_len;
remainder_rate_len = 0;
}
rtw_add_bcn_ie(padapter, pnetwork, _SUPPORTEDRATES_IE_, pnetwork->SupportedRates, rate_len);
if (remainder_rate_len)
rtw_add_bcn_ie(padapter, pnetwork, _EXT_SUPPORTEDRATES_IE_, (pnetwork->SupportedRates + 8), remainder_rate_len);
else
rtw_remove_bcn_ie(padapter, pnetwork, _EXT_SUPPORTEDRATES_IE_);
pnetwork->Length = get_WLAN_BSSID_EX_sz(pnetwork);
}
void rtw_join_done_chk_ch(_adapter *adapter, int join_res)
{
#define DUMP_ADAPTERS_STATUS 0
struct dvobj_priv *dvobj;
_adapter *iface;
struct mlme_priv *mlme;
struct mlme_ext_priv *mlmeext;
u8 u_ch, u_offset, u_bw;
int i;
dvobj = adapter_to_dvobj(adapter);
if (DUMP_ADAPTERS_STATUS) {
RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(adapter));
dump_adapters_status(RTW_DBGDUMP , dvobj);
}
if (join_res >= 0) {
#ifdef CONFIG_MCC_MODE
/* MCC setting success, don't go to ch union process */
if (rtw_hal_set_mcc_setting_join_done_chk_ch(adapter))
return;
#endif /* CONFIG_MCC_MODE */
if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset) <= 0) {
dump_adapters_status(RTW_DBGDUMP , dvobj);
rtw_warn_on(1);
}
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
mlme = &iface->mlmepriv;
mlmeext = &iface->mlmeextpriv;
if (!iface || iface == adapter)
continue;
if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
&& check_fwstate(mlme, WIFI_ASOC_STATE)
) {
u8 ori_ch, ori_bw, ori_offset;
bool is_grouped = rtw_is_chbw_grouped(u_ch, u_bw, u_offset
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
if (is_grouped == _FALSE) {
/* handle AP which need to switch ch setting */
ori_ch = mlmeext->cur_channel;
ori_bw = mlmeext->cur_bwmode;
ori_offset = mlmeext->cur_ch_offset;
/* restore original bw, adjust bw by registry setting on target ch */
mlmeext->cur_bwmode = mlme->ori_bw;
mlmeext->cur_channel = u_ch;
rtw_adjust_chbw(iface, mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(iface))
rtw_mesh_adjust_chbw(mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset);
#endif
rtw_chset_sync_chbw(adapter_to_chset(adapter)
, &mlmeext->cur_channel, &mlmeext->cur_bwmode, &mlmeext->cur_ch_offset
, &u_ch, &u_bw, &u_offset);
RTW_INFO(FUNC_ADPT_FMT" %u,%u,%u => %u,%u,%u\n", FUNC_ADPT_ARG(iface)
, ori_ch, ori_bw, ori_offset
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
rtw_ap_update_bss_chbw(iface, &(mlmeext->mlmext_info.network)
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
_rtw_memcpy(&(mlme->cur_network.network), &(mlmeext->mlmext_info.network), sizeof(WLAN_BSSID_EX));
rtw_start_bss_hdl_after_chbw_decided(iface);
{
#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
u8 ht_option = 0;
#ifdef CONFIG_80211N_HT
ht_option = mlme->htpriv.ht_option;
#endif
rtw_cfg80211_ch_switch_notify(iface
, mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset
, ht_option);
#endif
}
}
clr_fwstate(mlme, WIFI_OP_CH_SWITCHING);
update_beacon(iface, 0xFF, NULL, _TRUE, 0);
}
}
#ifdef CONFIG_DFS_MASTER
rtw_dfs_rd_en_decision(adapter, MLME_STA_CONNECTED, 0);
#endif
} else {
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
mlme = &iface->mlmepriv;
mlmeext = &iface->mlmeextpriv;
if (!iface || iface == adapter)
continue;
if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
&& check_fwstate(mlme, WIFI_ASOC_STATE)
) {
clr_fwstate(mlme, WIFI_OP_CH_SWITCHING);
update_beacon(iface, 0xFF, NULL, _TRUE, 0);
}
}
#ifdef CONFIG_DFS_MASTER
rtw_dfs_rd_en_decision(adapter, MLME_STA_DISCONNECTED, 0);
#endif
}
if (rtw_mi_get_ch_setting_union(adapter, &u_ch, &u_bw, &u_offset)) {
RTW_INFO(FUNC_ADPT_FMT" union:%u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
set_channel_bwmode(adapter, u_ch, u_offset, u_bw);
rtw_mi_update_union_chan_inf(adapter, u_ch, u_offset, u_bw);
}
if (DUMP_ADAPTERS_STATUS) {
RTW_INFO(FUNC_ADPT_FMT" exit\n", FUNC_ADPT_ARG(adapter));
dump_adapters_status(RTW_DBGDUMP , dvobj);
}
}
int rtw_chk_start_clnt_join(_adapter *adapter, u8 *ch, u8 *bw, u8 *offset)
{
#ifdef CONFIG_CONCURRENT_MODE
bool chbw_allow = _TRUE;
#endif
bool connect_allow = _TRUE;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
u8 cur_ch, cur_bw, cur_ch_offset;
u8 u_ch, u_offset, u_bw;
u_ch = cur_ch = pmlmeext->cur_channel;
u_bw = cur_bw = pmlmeext->cur_bwmode;
u_offset = cur_ch_offset = pmlmeext->cur_ch_offset;
if (!ch || !bw || !offset) {
connect_allow = _FALSE;
rtw_warn_on(1);
goto exit;
}
if (cur_ch == 0) {
connect_allow = _FALSE;
RTW_ERR(FUNC_ADPT_FMT" cur_ch:%u\n"
, FUNC_ADPT_ARG(adapter), cur_ch);
rtw_warn_on(1);
goto exit;
}
RTW_INFO(FUNC_ADPT_FMT" req: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
#ifdef CONFIG_CONCURRENT_MODE
{
struct dvobj_priv *dvobj;
_adapter *iface;
struct mlme_priv *mlme;
struct mlme_ext_priv *mlmeext;
struct mi_state mstate;
int i;
dvobj = adapter_to_dvobj(adapter);
rtw_mi_status_no_self(adapter, &mstate);
RTW_INFO(FUNC_ADPT_FMT" others ld_sta_num:%u, ap_num:%u, mesh_num:%u\n"
, FUNC_ADPT_ARG(adapter), MSTATE_STA_LD_NUM(&mstate)
, MSTATE_AP_NUM(&mstate), MSTATE_MESH_NUM(&mstate));
if (!MSTATE_STA_LD_NUM(&mstate) && !MSTATE_AP_NUM(&mstate) && !MSTATE_MESH_NUM(&mstate)) {
/* consider linking STA? */
goto connect_allow_hdl;
}
if (rtw_mi_get_ch_setting_union_no_self(adapter, &u_ch, &u_bw, &u_offset) <= 0) {
dump_adapters_status(RTW_DBGDUMP , dvobj);
rtw_warn_on(1);
}
RTW_INFO(FUNC_ADPT_FMT" others union:%u,%u,%u\n"
, FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
/* chbw_allow? */
chbw_allow = rtw_is_chbw_grouped(pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset
, u_ch, u_bw, u_offset);
RTW_INFO(FUNC_ADPT_FMT" chbw_allow:%d\n"
, FUNC_ADPT_ARG(adapter), chbw_allow);
#ifdef CONFIG_MCC_MODE
/* check setting success, don't go to ch union process */
if (rtw_hal_set_mcc_setting_chk_start_clnt_join(adapter, &u_ch, &u_bw, &u_offset, chbw_allow))
goto exit;
#endif
if (chbw_allow == _TRUE) {
rtw_sync_chbw(&cur_ch, &cur_bw, &cur_ch_offset, &u_ch, &u_bw, &u_offset);
rtw_warn_on(cur_ch != pmlmeext->cur_channel);
rtw_warn_on(cur_bw != pmlmeext->cur_bwmode);
rtw_warn_on(cur_ch_offset != pmlmeext->cur_ch_offset);
goto connect_allow_hdl;
}
#ifdef CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT
/* chbw_allow is _FALSE, connect allow? */
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
mlme = &iface->mlmepriv;
mlmeext = &iface->mlmeextpriv;
if (check_fwstate(mlme, WIFI_STATION_STATE)
&& check_fwstate(mlme, WIFI_ASOC_STATE)
#if defined(CONFIG_P2P)
&& rtw_p2p_chk_state(&(iface->wdinfo), P2P_STATE_NONE)
#endif
) {
connect_allow = _FALSE;
break;
}
}
#endif /* CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT */
if (MSTATE_STA_LD_NUM(&mstate) + MSTATE_AP_LD_NUM(&mstate) + MSTATE_MESH_LD_NUM(&mstate) >= 4)
connect_allow = _FALSE;
RTW_INFO(FUNC_ADPT_FMT" connect_allow:%d\n"
, FUNC_ADPT_ARG(adapter), connect_allow);
if (connect_allow == _FALSE)
goto exit;
connect_allow_hdl:
/* connect_allow == _TRUE */
if (chbw_allow == _FALSE) {
u_ch = cur_ch;
u_bw = cur_bw;
u_offset = cur_ch_offset;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
mlme = &iface->mlmepriv;
mlmeext = &iface->mlmeextpriv;
if (!iface || iface == adapter)
continue;
if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
&& check_fwstate(mlme, WIFI_ASOC_STATE)
) {
#ifdef CONFIG_SPCT_CH_SWITCH
if (1)
rtw_ap_inform_ch_switch(iface, pmlmeext->cur_channel , pmlmeext->cur_ch_offset);
else
#endif
rtw_sta_flush(iface, _FALSE);
rtw_hal_set_hwreg(iface, HW_VAR_CHECK_TXBUF, 0);
set_fwstate(mlme, WIFI_OP_CH_SWITCHING);
} else if (check_fwstate(mlme, WIFI_STATION_STATE)
&& check_fwstate(mlme, WIFI_ASOC_STATE)
) {
rtw_disassoc_cmd(iface, 500, RTW_CMDF_DIRECTLY);
rtw_indicate_disconnect(iface, 0, _FALSE);
rtw_free_assoc_resources(iface, _TRUE);
}
}
}
#ifdef CONFIG_DFS_MASTER
rtw_dfs_rd_en_decision(adapter, MLME_STA_CONNECTING, 0);
#endif
}
#endif /* CONFIG_CONCURRENT_MODE */
exit:
if (connect_allow == _TRUE) {
RTW_INFO(FUNC_ADPT_FMT" union: %u,%u,%u\n", FUNC_ADPT_ARG(adapter), u_ch, u_bw, u_offset);
*ch = u_ch;
*bw = u_bw;
*offset = u_offset;
#if defined(CONFIG_IOCTL_CFG80211) && (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0))
{
u8 ht_option = 0;
#ifdef CONFIG_80211N_HT
ht_option = adapter->mlmepriv.htpriv.ht_option;
#endif /* CONFIG_80211N_HT */
/*
when supplicant send the mlme frame,
the bss freq is updated by channel switch event.
*/
rtw_cfg80211_ch_switch_notify(adapter,
cur_ch, cur_bw, cur_ch_offset, ht_option);
}
#endif
}
return connect_allow == _TRUE ? _SUCCESS : _FAIL;
}
void rtw_set_external_auth_status(_adapter *padapter,
const void *data, int len)
{
#ifdef CONFIG_IOCTL_CFG80211
struct net_device *dev = padapter->pnetdev;
struct wiphy *wiphy = adapter_to_wiphy(padapter);
struct rtw_external_auth_params params;
/* convert data to external_auth_params */
params.action = RTW_GET_BE32((u8 *)data);
_rtw_memcpy(¶ms.bssid, (u8 *)data + 4, ETH_ALEN);
_rtw_memcpy(¶ms.ssid.ssid, (u8 *)data + 10, WLAN_SSID_MAXLEN);
params.ssid.ssid_len = RTW_GET_BE64((u8 *)data + 42);
params.key_mgmt_suite = RTW_GET_BE32((u8 *)data + 58);
params.status = RTW_GET_BE16((u8 *)data + 62);
_rtw_memcpy(¶ms.pmkid, (u8 *)data + 64, PMKID_LEN);
rtw_cfg80211_external_auth_status(wiphy, dev, ¶ms);
#endif /* CONFIG_IOCTL_CFG80211 */
}
u8 rtw_set_chbw_hdl(_adapter *padapter, u8 *pbuf)
{
struct set_ch_parm *set_ch_parm;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
if (!pbuf)
return H2C_PARAMETERS_ERROR;
set_ch_parm = (struct set_ch_parm *)pbuf;
RTW_INFO(FUNC_NDEV_FMT" ch:%u, bw:%u, ch_offset:%u\n",
FUNC_NDEV_ARG(padapter->pnetdev),
set_ch_parm->ch, set_ch_parm->bw, set_ch_parm->ch_offset);
pmlmeext->cur_channel = set_ch_parm->ch;
pmlmeext->cur_ch_offset = set_ch_parm->ch_offset;
pmlmeext->cur_bwmode = set_ch_parm->bw;
set_channel_bwmode(padapter, set_ch_parm->ch, set_ch_parm->ch_offset, set_ch_parm->bw);
return H2C_SUCCESS;
}
u8 set_chplan_hdl(_adapter *padapter, unsigned char *pbuf)
{
struct SetChannelPlan_param *setChannelPlan_param;
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
if (!pbuf)
return H2C_PARAMETERS_ERROR;
setChannelPlan_param = (struct SetChannelPlan_param *)pbuf;
if (!rtw_is_channel_plan_valid(setChannelPlan_param->channel_plan))
return H2C_PARAMETERS_ERROR;
rfctl->country_ent = setChannelPlan_param->country_ent;
rfctl->ChannelPlan = setChannelPlan_param->channel_plan;
rfctl->max_chan_nums = init_channel_set(padapter, rfctl->ChannelPlan, rfctl->channel_set);
init_channel_list(padapter, rfctl->channel_set, &rfctl->channel_list);
#if CONFIG_TXPWR_LIMIT
rtw_txpwr_init_regd(rfctl);
#endif
rtw_hal_set_odm_var(padapter, HAL_ODM_REGULATION, NULL, _TRUE);
#ifdef CONFIG_IOCTL_CFG80211
rtw_regd_apply_flags(adapter_to_wiphy(padapter));
#endif
return H2C_SUCCESS;
}
u8 led_blink_hdl(_adapter *padapter, unsigned char *pbuf)
{
struct LedBlink_param *ledBlink_param;
if (!pbuf)
return H2C_PARAMETERS_ERROR;
ledBlink_param = (struct LedBlink_param *)pbuf;
#ifdef CONFIG_RTW_LED_HANDLED_BY_CMD_THREAD
BlinkHandler((PLED_DATA)ledBlink_param->pLed);
#endif
return H2C_SUCCESS;
}
u8 set_csa_hdl(_adapter *adapter, unsigned char *pbuf)
{
#ifdef CONFIG_DFS
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
if (rfctl->csa_ch)
rtw_dfs_ch_switch_hdl(adapter_to_dvobj(adapter));
#endif
return H2C_SUCCESS;
}
u8 tdls_hdl(_adapter *padapter, unsigned char *pbuf)
{
#ifdef CONFIG_TDLS
_irqL irqL;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
#ifdef CONFIG_TDLS_CH_SW
struct tdls_ch_switch *pchsw_info = &ptdlsinfo->chsw_info;
#endif
struct TDLSoption_param *TDLSoption;
struct sta_info *ptdls_sta = NULL;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
struct sta_info *ap_sta = rtw_get_stainfo(&padapter->stapriv, get_my_bssid(&(pmlmeinfo->network)));
u8 survey_channel, i, min, option;
struct tdls_txmgmt txmgmt;
u32 setchtime, resp_sleep = 0, wait_time;
u8 zaddr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
u8 ret;
u8 doiqk;
u64 tx_ra_bitmap = 0;
if (!pbuf)
return H2C_PARAMETERS_ERROR;
TDLSoption = (struct TDLSoption_param *)pbuf;
option = TDLSoption->option;
if (!_rtw_memcmp(TDLSoption->addr, zaddr, ETH_ALEN)) {
ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), TDLSoption->addr);
if (ptdls_sta == NULL)
return H2C_REJECTED;
} else {
if (!(option == TDLS_RS_RCR))
return H2C_REJECTED;
}
/* _enter_critical_bh(&(ptdlsinfo->hdl_lock), &irqL); */
/* RTW_INFO("[%s] option:%d\n", __FUNCTION__, option); */
switch (option) {
case TDLS_ESTABLISHED: {
/* As long as TDLS handshake success, we should set RCR_CBSSID_DATA bit to 0 */
/* So we can receive all kinds of data frames. */
u8 sta_band = 0;
/* leave ALL PS when TDLS is established */
rtw_pwr_wakeup(padapter);
rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_LINKED);
RTW_INFO("Created Direct Link with "MAC_FMT"\n", MAC_ARG(ptdls_sta->cmn.mac_addr));
/* Set TDLS sta rate. */
/* Update station supportRate */
rtw_hal_update_sta_ra_info(padapter, ptdls_sta);
tx_ra_bitmap = ptdls_sta->cmn.ra_info.ramask;
if (pmlmeext->cur_channel > 14) {
if (tx_ra_bitmap & 0xffff000)
sta_band |= WIRELESS_11_5N ;
if (tx_ra_bitmap & 0xff0)
sta_band |= WIRELESS_11A;
/* 5G band */
#ifdef CONFIG_80211AC_VHT
if (ptdls_sta->vhtpriv.vht_option)
sta_band = WIRELESS_11_5AC;
#endif
} else {
if (tx_ra_bitmap & 0xffff000)
sta_band |= WIRELESS_11_24N;
if (tx_ra_bitmap & 0xff0)
sta_band |= WIRELESS_11G;
if (tx_ra_bitmap & 0x0f)
sta_band |= WIRELESS_11B;
}
ptdls_sta->wireless_mode = sta_band;
rtw_hal_update_sta_wset(padapter, ptdls_sta);
/* Sta mode */
rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, ptdls_sta, _TRUE);
set_sta_rate(padapter, ptdls_sta);
rtw_sta_media_status_rpt(padapter, ptdls_sta, 1);
break;
}
case TDLS_ISSUE_PTI:
ptdls_sta->tdls_sta_state |= TDLS_WAIT_PTR_STATE;
issue_tdls_peer_traffic_indication(padapter, ptdls_sta);
_set_timer(&ptdls_sta->pti_timer, TDLS_PTI_TIME);
break;
#ifdef CONFIG_TDLS_CH_SW
case TDLS_CH_SW_RESP:
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.status_code = 0;
_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
if (ap_sta)
rtw_hal_macid_sleep(padapter, ap_sta->cmn.mac_id);
issue_nulldata(padapter, NULL, 1, 3, 3);
RTW_INFO("[TDLS ] issue tdls channel switch response\n");
ret = issue_tdls_ch_switch_rsp(padapter, &txmgmt, _TRUE);
/* If we receive TDLS_CH_SW_REQ at off channel which it's target is AP's channel */
/* then we just switch to AP's channel*/
if (padapter->mlmeextpriv.cur_channel == pchsw_info->off_ch_num) {
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END_TO_BASE_CHNL);
break;
}
if (ret == _SUCCESS)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_OFF_CHNL);
else
RTW_INFO("[TDLS] issue_tdls_ch_switch_rsp wait ack fail !!!!!!!!!!\n");
break;
case TDLS_CH_SW_PREPARE:
pchsw_info->ch_sw_state |= TDLS_CH_SWITCH_PREPARE_STATE;
/* to collect IQK info of off-chnl */
doiqk = _TRUE;
rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK, &doiqk);
set_channel_bwmode(padapter, pchsw_info->off_ch_num, pchsw_info->ch_offset, (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20);
doiqk = _FALSE;
rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK, &doiqk);
/* switch back to base-chnl */
set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
pchsw_info->ch_sw_state &= ~(TDLS_CH_SWITCH_PREPARE_STATE);
break;
case TDLS_CH_SW_START:
rtw_tdls_set_ch_sw_oper_control(padapter, _TRUE);
break;
case TDLS_CH_SW_TO_OFF_CHNL:
if (ap_sta)
rtw_hal_macid_sleep(padapter, ap_sta->cmn.mac_id);
issue_nulldata(padapter, NULL, 1, 3, 3);
if (padapter->registrypriv.wifi_spec == 0) {
if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
_set_timer(&ptdls_sta->ch_sw_timer, (u32)(ptdls_sta->ch_switch_timeout) / 1000);
}
if (rtw_tdls_do_ch_sw(padapter, ptdls_sta, TDLS_CH_SW_OFF_CHNL, pchsw_info->off_ch_num,
pchsw_info->ch_offset, (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20, ptdls_sta->ch_switch_time) == _SUCCESS) {
pchsw_info->ch_sw_state &= ~(TDLS_PEER_AT_OFF_STATE);
if (pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE) {
if (issue_nulldata_to_TDLS_peer_STA(ptdls_sta->padapter, ptdls_sta->cmn.mac_addr, 0, 1,
(padapter->registrypriv.wifi_spec == 0) ? 3 : 0) == _FAIL)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_BASE_CHNL);
}
} else {
if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
}
break;
case TDLS_CH_SW_END:
case TDLS_CH_SW_END_TO_BASE_CHNL:
rtw_tdls_set_ch_sw_oper_control(padapter, _FALSE);
_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
_cancel_timer_ex(&ptdls_sta->stay_on_base_chnl_timer);
_cancel_timer_ex(&ptdls_sta->ch_sw_monitor_timer);
#if 0
_rtw_memset(pHalData->tdls_ch_sw_iqk_info_base_chnl, 0x00, sizeof(pHalData->tdls_ch_sw_iqk_info_base_chnl));
_rtw_memset(pHalData->tdls_ch_sw_iqk_info_off_chnl, 0x00, sizeof(pHalData->tdls_ch_sw_iqk_info_off_chnl));
#endif
if (option == TDLS_CH_SW_END_TO_BASE_CHNL)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_BASE_CHNL);
break;
case TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED:
case TDLS_CH_SW_TO_BASE_CHNL:
pchsw_info->ch_sw_state &= ~(TDLS_PEER_AT_OFF_STATE | TDLS_WAIT_CH_RSP_STATE);
if (option == TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED) {
if (ptdls_sta != NULL) {
/* Send unsolicited channel switch rsp. to peer */
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.status_code = 0;
_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
issue_tdls_ch_switch_rsp(padapter, &txmgmt, _FALSE);
}
}
if (rtw_tdls_do_ch_sw(padapter, ptdls_sta, TDLS_CH_SW_BASE_CHNL, pmlmeext->cur_channel,
pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode, ptdls_sta->ch_switch_time) == _SUCCESS) {
if (ap_sta)
rtw_hal_macid_wakeup(padapter, ap_sta->cmn.mac_id);
issue_nulldata(padapter, NULL, 0, 3, 3);
/* set ch sw monitor timer for responder */
if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
_set_timer(&ptdls_sta->ch_sw_monitor_timer, TDLS_CH_SW_MONITOR_TIMEOUT);
}
break;
#endif
case TDLS_RS_RCR:
rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_NOLINK);
break;
case TDLS_TEARDOWN_STA:
case TDLS_TEARDOWN_STA_NO_WAIT:
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
issue_tdls_teardown(padapter, &txmgmt, (option == TDLS_TEARDOWN_STA) ? _TRUE : _FALSE);
break;
case TDLS_TEARDOWN_STA_LOCALLY:
case TDLS_TEARDOWN_STA_LOCALLY_POST:
#ifdef CONFIG_TDLS_CH_SW
if (_rtw_memcmp(TDLSoption->addr, pchsw_info->addr, ETH_ALEN) == _TRUE) {
pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE |
TDLS_CH_SWITCH_ON_STATE |
TDLS_PEER_AT_OFF_STATE);
rtw_tdls_set_ch_sw_oper_control(padapter, _FALSE);
_rtw_memset(pchsw_info->addr, 0x00, ETH_ALEN);
}
#endif
if (option == TDLS_TEARDOWN_STA_LOCALLY)
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_teardown_post_hdl(padapter, ptdls_sta, _FALSE);
if (ptdlsinfo->tdls_sctx != NULL)
rtw_sctx_done(&(ptdlsinfo->tdls_sctx));
break;
}
/* _exit_critical_bh(&(ptdlsinfo->hdl_lock), &irqL); */
return H2C_SUCCESS;
#else
return H2C_REJECTED;
#endif /* CONFIG_TDLS */
}
u8 run_in_thread_hdl(_adapter *padapter, u8 *pbuf)
{
struct RunInThread_param *p;
if (NULL == pbuf)
return H2C_PARAMETERS_ERROR;
p = (struct RunInThread_param *)pbuf;
if (p->func)
p->func(p->context);
return H2C_SUCCESS;
}
u8 rtw_getmacreg_hdl(_adapter *padapter, u8 *pbuf)
{
struct readMAC_parm *preadmacparm = NULL;
u8 sz = 0;
u32 addr = 0;
u32 value = 0;
if (!pbuf)
return H2C_PARAMETERS_ERROR;
preadmacparm = (struct readMAC_parm *) pbuf;
sz = preadmacparm->len;
addr = preadmacparm->addr;
value = 0;
switch (sz) {
case 1:
value = rtw_read8(padapter, addr);
break;
case 2:
value = rtw_read16(padapter, addr);
break;
case 4:
value = rtw_read32(padapter, addr);
break;
default:
RTW_INFO("%s: Unknown size\n", __func__);
break;
}
RTW_INFO("%s: addr:0x%02x valeu:0x%02x\n", __func__, addr, value);
return H2C_SUCCESS;
}
int rtw_sae_preprocess(_adapter *adapter, const u8 *buf, u32 len, u8 tx)
{
#ifdef CONFIG_IOCTL_CFG80211
const u8 *frame_body = buf + sizeof(struct rtw_ieee80211_hdr_3addr);
u16 alg;
u16 seq;
u16 status;
int ret = _FAIL;
alg = RTW_GET_LE16(frame_body);
if (alg != WLAN_AUTH_SAE)
goto exit;
seq = RTW_GET_LE16(frame_body + 2);
status = RTW_GET_LE16(frame_body + 4);
RTW_INFO("RTW_%s:AUTH alg:0x%04x, seq:0x%04x, status:0x%04x, mesg:%s\n",
(tx == _TRUE) ? "Tx" : "Rx", alg, seq, status,
(seq == 1) ? "Commit" : "Confirm");
ret = _SUCCESS;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
rtw_mesh_sae_check_frames(adapter, buf, len, tx, alg, seq, status);
goto exit;
}
#endif
if (tx && (seq == 2) && (status == 0)) {
/* quere commit frame until external auth statue update */
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta = NULL;
_irqL irqL;
psta = rtw_get_stainfo(pstapriv, GetAddr1Ptr(buf));
if (psta) {
_enter_critical_bh(&psta->lock, &irqL);
if (psta->pauth_frame) {
rtw_mfree(psta->pauth_frame, psta->auth_len);
psta->pauth_frame = NULL;
psta->auth_len = 0;
}
psta->pauth_frame = rtw_zmalloc(len);
if (psta->pauth_frame) {
_rtw_memcpy(psta->pauth_frame, buf, len);
psta->auth_len = len;
}
_exit_critical_bh(&psta->lock, &irqL);
ret = 2;
}
}
exit:
return ret;
#else
return _SUCCESS;
#endif /* CONFIG_IOCTL_CFG80211 */
}
================================================
FILE: core/rtw_mp.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_MP_C_
#include
#ifdef PLATFORM_FREEBSD
#include /* for RFHIGHPID */
#endif
#include "../hal/phydm/phydm_precomp.h"
#if defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8821A)
#include
#endif
#ifdef CONFIG_MP_VHT_HW_TX_MODE
#define CEILING_POS(X) ((X - (int)(X)) > 0 ? (int)(X + 1) : (int)(X))
#define CEILING_NEG(X) ((X - (int)(X)) < 0 ? (int)(X - 1) : (int)(X))
#define ceil(X) (((X) > 0) ? CEILING_POS(X) : CEILING_NEG(X))
int rtfloor(float x)
{
int i = x - 2;
while
(++i <= x - 1)
;
return i;
}
#endif
#ifdef CONFIG_MP_INCLUDED
u32 read_macreg(_adapter *padapter, u32 addr, u32 sz)
{
u32 val = 0;
switch (sz) {
case 1:
val = rtw_read8(padapter, addr);
break;
case 2:
val = rtw_read16(padapter, addr);
break;
case 4:
val = rtw_read32(padapter, addr);
break;
default:
val = 0xffffffff;
break;
}
return val;
}
void write_macreg(_adapter *padapter, u32 addr, u32 val, u32 sz)
{
switch (sz) {
case 1:
rtw_write8(padapter, addr, (u8)val);
break;
case 2:
rtw_write16(padapter, addr, (u16)val);
break;
case 4:
rtw_write32(padapter, addr, val);
break;
default:
break;
}
}
u32 read_bbreg(_adapter *padapter, u32 addr, u32 bitmask)
{
return rtw_hal_read_bbreg(padapter, addr, bitmask);
}
void write_bbreg(_adapter *padapter, u32 addr, u32 bitmask, u32 val)
{
rtw_hal_write_bbreg(padapter, addr, bitmask, val);
}
u32 _read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask)
{
return rtw_hal_read_rfreg(padapter, rfpath, addr, bitmask);
}
void _write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 bitmask, u32 val)
{
rtw_hal_write_rfreg(padapter, rfpath, addr, bitmask, val);
}
u32 read_rfreg(PADAPTER padapter, u8 rfpath, u32 addr)
{
return _read_rfreg(padapter, rfpath, addr, bRFRegOffsetMask);
}
void write_rfreg(PADAPTER padapter, u8 rfpath, u32 addr, u32 val)
{
_write_rfreg(padapter, rfpath, addr, bRFRegOffsetMask, val);
}
static void _init_mp_priv_(struct mp_priv *pmp_priv)
{
WLAN_BSSID_EX *pnetwork;
_rtw_memset(pmp_priv, 0, sizeof(struct mp_priv));
pmp_priv->mode = MP_OFF;
pmp_priv->channel = 1;
pmp_priv->bandwidth = CHANNEL_WIDTH_20;
pmp_priv->prime_channel_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
pmp_priv->rateidx = RATE_1M;
pmp_priv->txpoweridx = 0x2A;
pmp_priv->antenna_tx = ANTENNA_A;
pmp_priv->antenna_rx = ANTENNA_AB;
pmp_priv->check_mp_pkt = 0;
pmp_priv->tx_pktcount = 0;
pmp_priv->rx_bssidpktcount = 0;
pmp_priv->rx_pktcount = 0;
pmp_priv->rx_crcerrpktcount = 0;
pmp_priv->network_macaddr[0] = 0x00;
pmp_priv->network_macaddr[1] = 0xE0;
pmp_priv->network_macaddr[2] = 0x4C;
pmp_priv->network_macaddr[3] = 0x87;
pmp_priv->network_macaddr[4] = 0x66;
pmp_priv->network_macaddr[5] = 0x55;
pmp_priv->bSetRxBssid = _FALSE;
pmp_priv->bRTWSmbCfg = _FALSE;
pmp_priv->bloopback = _FALSE;
pmp_priv->bloadefusemap = _FALSE;
pmp_priv->brx_filter_beacon = _FALSE;
pmp_priv->mplink_brx = _FALSE;
pnetwork = &pmp_priv->mp_network.network;
_rtw_memcpy(pnetwork->MacAddress, pmp_priv->network_macaddr, ETH_ALEN);
pnetwork->Ssid.SsidLength = 8;
_rtw_memcpy(pnetwork->Ssid.Ssid, "mp_871x", pnetwork->Ssid.SsidLength);
pmp_priv->tx.payload = 2;
#ifdef CONFIG_80211N_HT
pmp_priv->tx.attrib.ht_en = 1;
#endif
pmp_priv->mpt_ctx.mpt_rate_index = 1;
}
static void mp_init_xmit_attrib(struct mp_tx *pmptx, PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct pkt_attrib *pattrib;
/* init xmitframe attribute */
pattrib = &pmptx->attrib;
_rtw_memset(pattrib, 0, sizeof(struct pkt_attrib));
_rtw_memset(pmptx->desc, 0, TXDESC_SIZE);
pattrib->ether_type = 0x8712;
#if 0
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
#endif
_rtw_memset(pattrib->dst, 0xFF, ETH_ALEN);
/* pattrib->dhcp_pkt = 0;
* pattrib->pktlen = 0; */
pattrib->ack_policy = 0;
/* pattrib->pkt_hdrlen = ETH_HLEN; */
pattrib->hdrlen = WLAN_HDR_A3_LEN;
pattrib->subtype = WIFI_DATA;
pattrib->priority = 0;
pattrib->qsel = pattrib->priority;
/* do_queue_select(padapter, pattrib); */
pattrib->nr_frags = 1;
pattrib->encrypt = 0;
pattrib->bswenc = _FALSE;
pattrib->qos_en = _FALSE;
pattrib->pktlen = 1500;
if (pHalData->rf_type == RF_2T2R)
pattrib->raid = RATEID_IDX_BGN_40M_2SS;
else
pattrib->raid = RATEID_IDX_BGN_40M_1SS;
#ifdef CONFIG_80211AC_VHT
if (pHalData->rf_type == RF_1T1R)
pattrib->raid = RATEID_IDX_VHT_1SS;
else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
pattrib->raid = RATEID_IDX_VHT_2SS;
else if (pHalData->rf_type == RF_3T3R)
pattrib->raid = RATEID_IDX_VHT_3SS;
else
pattrib->raid = RATEID_IDX_BGN_40M_1SS;
#endif
}
s32 init_mp_priv(PADAPTER padapter)
{
struct mp_priv *pmppriv = &padapter->mppriv;
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
_init_mp_priv_(pmppriv);
pmppriv->papdater = padapter;
if (IS_HARDWARE_TYPE_8822C(padapter))
pmppriv->mp_dm = 1;/* default enable dpk tracking */
else
pmppriv->mp_dm = 0;
pmppriv->tx.stop = 1;
pmppriv->bSetTxPower = 0; /*for manually set tx power*/
pmppriv->bTxBufCkFail = _FALSE;
pmppriv->pktInterval = 0;
pmppriv->pktLength = 1000;
pmppriv->bprocess_mp_mode = _FALSE;
mp_init_xmit_attrib(&pmppriv->tx, padapter);
switch (padapter->registrypriv.rf_config) {
case RF_1T1R:
pmppriv->antenna_tx = ANTENNA_A;
pmppriv->antenna_rx = ANTENNA_A;
break;
case RF_1T2R:
default:
pmppriv->antenna_tx = ANTENNA_A;
pmppriv->antenna_rx = ANTENNA_AB;
break;
case RF_2T2R:
pmppriv->antenna_tx = ANTENNA_AB;
pmppriv->antenna_rx = ANTENNA_AB;
break;
case RF_2T4R:
pmppriv->antenna_tx = ANTENNA_BC;
pmppriv->antenna_rx = ANTENNA_ABCD;
break;
}
pHalData->AntennaRxPath = pmppriv->antenna_rx;
pHalData->antenna_tx_path = pmppriv->antenna_tx;
return _SUCCESS;
}
void free_mp_priv(struct mp_priv *pmp_priv)
{
if (pmp_priv->pallocated_mp_xmitframe_buf) {
rtw_mfree(pmp_priv->pallocated_mp_xmitframe_buf, 0);
pmp_priv->pallocated_mp_xmitframe_buf = NULL;
}
pmp_priv->pmp_xmtframe_buf = NULL;
}
#if 0
static void PHY_IQCalibrate_default(
PADAPTER pAdapter,
BOOLEAN bReCovery
)
{
RTW_INFO("%s\n", __func__);
}
static void PHY_LCCalibrate_default(
PADAPTER pAdapter
)
{
RTW_INFO("%s\n", __func__);
}
static void PHY_SetRFPathSwitch_default(
PADAPTER pAdapter,
BOOLEAN bMain
)
{
RTW_INFO("%s\n", __func__);
}
#endif
void mpt_InitHWConfig(PADAPTER Adapter)
{
PHAL_DATA_TYPE hal;
hal = GET_HAL_DATA(Adapter);
if (IS_HARDWARE_TYPE_8723B(Adapter)) {
/* TODO: <20130114, Kordan> The following setting is only for DPDT and Fixed board type. */
/* TODO: A better solution is configure it according EFUSE during the run-time. */
phy_set_mac_reg(Adapter, 0x64, BIT20, 0x0); /* 0x66[4]=0 */
phy_set_mac_reg(Adapter, 0x64, BIT24, 0x0); /* 0x66[8]=0 */
phy_set_mac_reg(Adapter, 0x40, BIT4, 0x0); /* 0x40[4]=0 */
phy_set_mac_reg(Adapter, 0x40, BIT3, 0x1); /* 0x40[3]=1 */
phy_set_mac_reg(Adapter, 0x4C, BIT24, 0x1); /* 0x4C[24:23]=10 */
phy_set_mac_reg(Adapter, 0x4C, BIT23, 0x0); /* 0x4C[24:23]=10 */
phy_set_bb_reg(Adapter, 0x944, BIT1 | BIT0, 0x3); /* 0x944[1:0]=11 */
phy_set_bb_reg(Adapter, 0x930, bMaskByte0, 0x77);/* 0x930[7:0]=77 */
phy_set_mac_reg(Adapter, 0x38, BIT11, 0x1);/* 0x38[11]=1 */
/* TODO: <20130206, Kordan> The default setting is wrong, hard-coded here. */
phy_set_mac_reg(Adapter, 0x778, 0x3, 0x3); /* Turn off hardware PTA control (Asked by Scott) */
phy_set_mac_reg(Adapter, 0x64, bMaskDWord, 0x36000000);/* Fix BT S0/S1 */
phy_set_mac_reg(Adapter, 0x948, bMaskDWord, 0x0); /* Fix BT can't Tx */
/* <20130522, Kordan> Turn off equalizer to improve Rx sensitivity. (Asked by EEChou) */
phy_set_bb_reg(Adapter, 0xA00, BIT8, 0x0); /*0xA01[0] = 0*/
} else if (IS_HARDWARE_TYPE_8821(Adapter)) {
/* <20131121, VincentL> Add for 8821AU DPDT setting and fix switching antenna issue (Asked by Rock)
<20131122, VincentL> Enable for all 8821A/8811AU (Asked by Alex)*/
phy_set_mac_reg(Adapter, 0x4C, BIT23, 0x0); /*0x4C[23:22]=01*/
phy_set_mac_reg(Adapter, 0x4C, BIT22, 0x1); /*0x4C[23:22]=01*/
} else if (IS_HARDWARE_TYPE_8188ES(Adapter))
phy_set_mac_reg(Adapter, 0x4C , BIT23, 0); /*select DPDT_P and DPDT_N as output pin*/
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(Adapter))
PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8814A, 0x2000);
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(Adapter)) {
rtw_write32(Adapter, 0x520, rtw_read32(Adapter, 0x520) | 0x8000);
rtw_write32(Adapter, 0x524, rtw_read32(Adapter, 0x524) & (~0x800));
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(Adapter)) {
u32 tmp_reg = 0;
PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8822B, 0x2000);
/* fixed wifi can't 2.4g tx suggest by Szuyitasi 20160504 */
phy_set_bb_reg(Adapter, 0x70, bMaskByte3, 0x0e);
RTW_INFO(" 0x73 = 0x%x\n", phy_query_bb_reg(Adapter, 0x70, bMaskByte3));
phy_set_bb_reg(Adapter, 0x1704, bMaskDWord, 0x0000ff00);
RTW_INFO(" 0x1704 = 0x%x\n", phy_query_bb_reg(Adapter, 0x1704, bMaskDWord));
phy_set_bb_reg(Adapter, 0x1700, bMaskDWord, 0xc00f0038);
RTW_INFO(" 0x1700 = 0x%x\n", phy_query_bb_reg(Adapter, 0x1700, bMaskDWord));
}
#endif /* CONFIG_RTL8822B */
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(Adapter))
PlatformEFIOWrite2Byte(Adapter, REG_RXFLTMAP1_8821C, 0x2000);
#endif /* CONFIG_RTL8821C */
#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
if (IS_A_CUT(hal->version_id) || IS_B_CUT(hal->version_id)) {
RTW_INFO("%s() Active large power detection\n", __func__);
phy_active_large_power_detection_8188f(&(GET_HAL_DATA(Adapter)->odmpriv));
}
}
#endif
#if defined(CONFIG_RTL8822C)
else if( IS_HARDWARE_TYPE_8822C(Adapter)) {
rtw_write16(Adapter, REG_RXFLTMAP1_8822C, 0x2000);
/* 0x7D8[31] : time out enable when cca is not assert
0x60D[7:0] : time out value (Unit : us)*/
rtw_write8(Adapter, 0x7db, 0xc0);
RTW_INFO(" 0x7d8 = 0x%x\n", rtw_read8(Adapter, 0x7d8));
rtw_write8(Adapter, 0x60d, 0x0c);
RTW_INFO(" 0x60d = 0x%x\n", rtw_read8(Adapter, 0x60d));
phy_set_bb_reg(Adapter, 0x1c44, BIT10, 0x1);
RTW_INFO(" 0x1c44 = 0x%x\n", phy_query_bb_reg(Adapter, 0x1c44, bMaskDWord));
}
#endif
}
static void PHY_IQCalibrate(PADAPTER padapter, u8 bReCovery)
{
halrf_iqk_trigger(&(GET_HAL_DATA(padapter)->odmpriv), bReCovery);
}
static void PHY_LCCalibrate(PADAPTER padapter)
{
halrf_lck_trigger(&(GET_HAL_DATA(padapter)->odmpriv));
}
static u8 PHY_QueryRFPathSwitch(PADAPTER padapter)
{
u8 bmain = 0;
/*
if (IS_HARDWARE_TYPE_8723B(padapter)) {
#ifdef CONFIG_RTL8723B
bmain = PHY_QueryRFPathSwitch_8723B(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8188E(padapter)) {
#ifdef CONFIG_RTL8188E
bmain = PHY_QueryRFPathSwitch_8188E(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8814A(padapter)) {
#ifdef CONFIG_RTL8814A
bmain = PHY_QueryRFPathSwitch_8814A(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter)) {
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
bmain = PHY_QueryRFPathSwitch_8812A(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8192E(padapter)) {
#ifdef CONFIG_RTL8192E
bmain = PHY_QueryRFPathSwitch_8192E(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8703B(padapter)) {
#ifdef CONFIG_RTL8703B
bmain = PHY_QueryRFPathSwitch_8703B(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8188F(padapter)) {
#ifdef CONFIG_RTL8188F
bmain = PHY_QueryRFPathSwitch_8188F(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8188GTV(padapter)) {
#ifdef CONFIG_RTL8188GTV
bmain = PHY_QueryRFPathSwitch_8188GTV(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8822B(padapter)) {
#ifdef CONFIG_RTL8822B
bmain = PHY_QueryRFPathSwitch_8822B(padapter);
#endif
} else if (IS_HARDWARE_TYPE_8723D(padapter)) {
#ifdef CONFIG_RTL8723D
bmain = PHY_QueryRFPathSwitch_8723D(padapter);
#endif
} else
*/
if (IS_HARDWARE_TYPE_8821C(padapter)) {
#ifdef CONFIG_RTL8821C
bmain = phy_query_rf_path_switch_8821c(padapter);
#endif
}
return bmain;
}
static void PHY_SetRFPathSwitch(PADAPTER padapter , BOOLEAN bMain) {
PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
struct dm_struct *phydm = &hal->odmpriv;
if (IS_HARDWARE_TYPE_8723B(padapter)) {
#ifdef CONFIG_RTL8723B
phy_set_rf_path_switch_8723b(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8188E(padapter)) {
#ifdef CONFIG_RTL8188E
phy_set_rf_path_switch_8188e(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8814A(padapter)) {
#ifdef CONFIG_RTL8814A
phy_set_rf_path_switch_8814a(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter)) {
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
phy_set_rf_path_switch_8812a(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8192E(padapter)) {
#ifdef CONFIG_RTL8192E
phy_set_rf_path_switch_8192e(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8703B(padapter)) {
#ifdef CONFIG_RTL8703B
phy_set_rf_path_switch_8703b(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8188F(padapter) || IS_HARDWARE_TYPE_8188GTV(padapter)) {
#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
phy_set_rf_path_switch_8188f(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8192F(padapter)) {
#ifdef CONFIG_RTL8192F
phy_set_rf_path_switch_8192f(padapter, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8822B(padapter)) {
#ifdef CONFIG_RTL8822B
phy_set_rf_path_switch_8822b(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8723D(padapter)) {
#ifdef CONFIG_RTL8723D
phy_set_rf_path_switch_8723d(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8821C(padapter)) {
#ifdef CONFIG_RTL8821C
phy_set_rf_path_switch_8821c(phydm, bMain);
#endif
} else if (IS_HARDWARE_TYPE_8822C(padapter)) {
#ifdef CONFIG_RTL8822C
phy_set_rf_path_switch_8822c(phydm, bMain);
#endif
}
}
static void phy_switch_rf_path_set(PADAPTER padapter , u8 *prf_set_State) {
#ifdef CONFIG_RTL8821C
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct dm_struct *p_dm = &pHalData->odmpriv;
if (IS_HARDWARE_TYPE_8821C(padapter)) {
config_phydm_set_ant_path(p_dm, *prf_set_State, p_dm->current_ant_num_8821c);
/* Do IQK when switching to BTG/WLG, requested by RF Binson */
if (*prf_set_State == SWITCH_TO_BTG || *prf_set_State == SWITCH_TO_WLG)
PHY_IQCalibrate(padapter, FALSE);
}
#endif
}
#ifdef CONFIG_ANTENNA_DIVERSITY
u8 rtw_mp_set_antdiv(PADAPTER padapter, BOOLEAN bMain)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 cur_ant, change_ant;
if (!pHalData->AntDivCfg)
return _FALSE;
/*rtw_hal_get_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &cur_ant, NULL);*/
change_ant = (bMain == MAIN_ANT) ? MAIN_ANT : AUX_ANT;
RTW_INFO("%s: config %s\n", __func__, (bMain == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");
rtw_antenna_select_cmd(padapter, change_ant, _FALSE);
return _TRUE;
}
#endif
s32
MPT_InitializeAdapter(
PADAPTER pAdapter,
u8 Channel
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
s32 rtStatus = _SUCCESS;
PMPT_CONTEXT pMptCtx = &pAdapter->mppriv.mpt_ctx;
u32 ledsetting;
pMptCtx->bMptDrvUnload = _FALSE;
pMptCtx->bMassProdTest = _FALSE;
pMptCtx->bMptIndexEven = _TRUE; /* default gain index is -6.0db */
pMptCtx->h2cReqNum = 0x0;
/* init for BT MP */
#if defined(CONFIG_RTL8723B)
pMptCtx->bMPh2c_timeout = _FALSE;
pMptCtx->MptH2cRspEvent = _FALSE;
pMptCtx->MptBtC2hEvent = _FALSE;
_rtw_init_sema(&pMptCtx->MPh2c_Sema, 0);
rtw_init_timer(&pMptCtx->MPh2c_timeout_timer, pAdapter, MPh2c_timeout_handle, pAdapter);
#endif
mpt_InitHWConfig(pAdapter);
#ifdef CONFIG_RTL8723B
rtl8723b_InitAntenna_Selection(pAdapter);
if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
/* <20130522, Kordan> Turn off equalizer to improve Rx sensitivity. (Asked by EEChou)*/
phy_set_bb_reg(pAdapter, 0xA00, BIT8, 0x0);
PHY_SetRFPathSwitch(pAdapter, 1/*pHalData->bDefaultAntenna*/); /*default use Main*/
if (pHalData->PackageType == PACKAGE_DEFAULT)
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6B04E);
else
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, bRFRegOffsetMask, 0x6F10E);
}
/*set ant to wifi side in mp mode*/
rtw_write16(pAdapter, 0x870, 0x300);
rtw_write16(pAdapter, 0x860, 0x110);
#endif
pMptCtx->bMptWorkItemInProgress = _FALSE;
pMptCtx->CurrMptAct = NULL;
pMptCtx->mpt_rf_path = RF_PATH_A;
/* ------------------------------------------------------------------------- */
/* Don't accept any packets */
rtw_write32(pAdapter, REG_RCR, 0);
/* ledsetting = rtw_read32(pAdapter, REG_LEDCFG0); */
/* rtw_write32(pAdapter, REG_LEDCFG0, ledsetting & ~LED0DIS); */
/* rtw_write32(pAdapter, REG_LEDCFG0, 0x08080); */
ledsetting = rtw_read32(pAdapter, REG_LEDCFG0);
PHY_LCCalibrate(pAdapter);
PHY_IQCalibrate(pAdapter, _FALSE);
/* dm_check_txpowertracking(&pHalData->odmpriv); */ /* trigger thermal meter */
PHY_SetRFPathSwitch(pAdapter, 1/*pHalData->bDefaultAntenna*/); /* default use Main */
pMptCtx->backup0xc50 = (u8)phy_query_bb_reg(pAdapter, rOFDM0_XAAGCCore1, bMaskByte0);
pMptCtx->backup0xc58 = (u8)phy_query_bb_reg(pAdapter, rOFDM0_XBAGCCore1, bMaskByte0);
pMptCtx->backup0xc30 = (u8)phy_query_bb_reg(pAdapter, rOFDM0_RxDetector1, bMaskByte0);
pMptCtx->backup0x52_RF_A = (u8)phy_query_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0);
pMptCtx->backup0x52_RF_B = (u8)phy_query_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0);
#ifdef CONFIG_RTL8188E
rtw_write32(pAdapter, REG_MACID_NO_LINK_0, 0x0);
rtw_write32(pAdapter, REG_MACID_NO_LINK_1, 0x0);
#endif
#ifdef CONFIG_RTL8814A
if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
pHalData->BackUp_IG_REG_4_Chnl_Section[0] = (u8)phy_query_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
pHalData->BackUp_IG_REG_4_Chnl_Section[1] = (u8)phy_query_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
pHalData->BackUp_IG_REG_4_Chnl_Section[2] = (u8)phy_query_bb_reg(pAdapter, rC_IGI_Jaguar2, bMaskByte0);
pHalData->BackUp_IG_REG_4_Chnl_Section[3] = (u8)phy_query_bb_reg(pAdapter, rD_IGI_Jaguar2, bMaskByte0);
}
#endif
return rtStatus;
}
/*-----------------------------------------------------------------------------
* Function: MPT_DeInitAdapter()
*
* Overview: Extra DeInitialization for Mass Production Test.
*
* Input: PADAPTER pAdapter
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 05/08/2007 MHC Create Version 0.
* 05/18/2007 MHC Add normal driver MPHalt code.
*
*---------------------------------------------------------------------------*/
void
MPT_DeInitAdapter(
PADAPTER pAdapter
)
{
PMPT_CONTEXT pMptCtx = &pAdapter->mppriv.mpt_ctx;
pMptCtx->bMptDrvUnload = _TRUE;
#if defined(CONFIG_RTL8723B)
_rtw_free_sema(&(pMptCtx->MPh2c_Sema));
_cancel_timer_ex(&pMptCtx->MPh2c_timeout_timer);
#endif
#if defined(CONFIG_RTL8723B)
phy_set_bb_reg(pAdapter, 0xA01, BIT0, 1); /* /suggestion by jerry for MP Rx. */
#endif
#if 0 /* for Windows */
PlatformFreeWorkItem(&(pMptCtx->MptWorkItem));
while (pMptCtx->bMptWorkItemInProgress) {
if (NdisWaitEvent(&(pMptCtx->MptWorkItemEvent), 50))
break;
}
NdisFreeSpinLock(&(pMptCtx->MptWorkItemSpinLock));
#endif
}
static u8 mpt_ProStartTest(PADAPTER padapter)
{
PMPT_CONTEXT pMptCtx = &padapter->mppriv.mpt_ctx;
pMptCtx->bMassProdTest = _TRUE;
pMptCtx->is_start_cont_tx = _FALSE;
pMptCtx->bCckContTx = _FALSE;
pMptCtx->bOfdmContTx = _FALSE;
pMptCtx->bSingleCarrier = _FALSE;
pMptCtx->is_carrier_suppression = _FALSE;
pMptCtx->is_single_tone = _FALSE;
pMptCtx->HWTxmode = PACKETS_TX;
return _SUCCESS;
}
/*
* General use
*/
s32 SetPowerTracking(PADAPTER padapter, u8 enable)
{
hal_mpt_SetPowerTracking(padapter, enable);
return 0;
}
void GetPowerTracking(PADAPTER padapter, u8 *enable)
{
hal_mpt_GetPowerTracking(padapter, enable);
}
void rtw_mp_trigger_iqk(PADAPTER padapter)
{
PHY_IQCalibrate(padapter, _FALSE);
}
void rtw_mp_trigger_lck(PADAPTER padapter)
{
PHY_LCCalibrate(padapter);
}
void rtw_mp_trigger_dpk(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
halrf_dpk_trigger(pDM_Odm);
}
static void init_mp_data(PADAPTER padapter)
{
u8 v8;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
/*disable BCN*/
v8 = rtw_read8(padapter, REG_BCN_CTRL);
v8 &= ~EN_BCN_FUNCTION;
rtw_write8(padapter, REG_BCN_CTRL, v8);
pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
}
void MPT_PwrCtlDM(PADAPTER padapter, u32 bstart)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
u32 rf_ability;
if (bstart == 1) {
RTW_INFO("in MPT_PwrCtlDM start\n");
rf_ability = ((u32)halrf_cmn_info_get(pDM_Odm, HALRF_CMNINFO_ABILITY)) | HAL_RF_TX_PWR_TRACK;
halrf_cmn_info_set(pDM_Odm, HALRF_CMNINFO_ABILITY, rf_ability);
halrf_set_pwr_track(pDM_Odm, true);
pDM_Odm->rf_calibrate_info.txpowertrack_control = _TRUE;
padapter->mppriv.mp_dm = 1;
} else {
RTW_INFO("in MPT_PwrCtlDM stop\n");
rf_ability = ((u32)halrf_cmn_info_get(pDM_Odm, HALRF_CMNINFO_ABILITY)) & ~HAL_RF_TX_PWR_TRACK;
halrf_cmn_info_set(pDM_Odm, HALRF_CMNINFO_ABILITY, rf_ability);
halrf_set_pwr_track(pDM_Odm, false);
pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
if (IS_HARDWARE_TYPE_8822C(padapter))
padapter->mppriv.mp_dm = 1; /* default enable dpk tracking */
else
padapter->mppriv.mp_dm = 0;
{
struct txpwrtrack_cfg c;
u8 chnl = 0 ;
_rtw_memset(&c, 0, sizeof(struct txpwrtrack_cfg));
configure_txpower_track(pDM_Odm, &c);
odm_clear_txpowertracking_state(pDM_Odm);
if (*c.odm_tx_pwr_track_set_pwr) {
if (pDM_Odm->support_ic_type == ODM_RTL8188F)
(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, MIX_MODE, RF_PATH_A, chnl);
else if (pDM_Odm->support_ic_type == ODM_RTL8723D) {
(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_A, chnl);
SetTxPower(padapter);
} else if (pDM_Odm->support_ic_type == ODM_RTL8192F) {
(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, MIX_MODE, RF_PATH_A, chnl);
(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, MIX_MODE, RF_PATH_B, chnl);
} else {
(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_A, chnl);
(*c.odm_tx_pwr_track_set_pwr)(pDM_Odm, BBSWING, RF_PATH_B, chnl);
}
}
}
}
}
u32 mp_join(PADAPTER padapter, u8 mode)
{
WLAN_BSSID_EX bssid;
struct sta_info *psta;
u32 length;
_irqL irqL;
s32 res = _SUCCESS;
struct mp_priv *pmppriv = &padapter->mppriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *tgt_network = &pmlmepriv->cur_network;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *pnetwork = (WLAN_BSSID_EX *)(&(pmlmeinfo->network));
/* 1. initialize a new WLAN_BSSID_EX */
_rtw_memset(&bssid, 0, sizeof(WLAN_BSSID_EX));
RTW_INFO("%s ,pmppriv->network_macaddr=%x %x %x %x %x %x\n", __func__,
pmppriv->network_macaddr[0], pmppriv->network_macaddr[1], pmppriv->network_macaddr[2], pmppriv->network_macaddr[3], pmppriv->network_macaddr[4],
pmppriv->network_macaddr[5]);
_rtw_memcpy(bssid.MacAddress, pmppriv->network_macaddr, ETH_ALEN);
if (mode == WIFI_FW_ADHOC_STATE) {
bssid.Ssid.SsidLength = strlen("mp_pseudo_adhoc");
_rtw_memcpy(bssid.Ssid.Ssid, (u8 *)"mp_pseudo_adhoc", bssid.Ssid.SsidLength);
bssid.InfrastructureMode = Ndis802_11IBSS;
bssid.IELength = 0;
bssid.Configuration.DSConfig = pmppriv->channel;
} else if (mode == WIFI_FW_STATION_STATE) {
bssid.Ssid.SsidLength = strlen("mp_pseudo_STATION");
_rtw_memcpy(bssid.Ssid.Ssid, (u8 *)"mp_pseudo_STATION", bssid.Ssid.SsidLength);
bssid.InfrastructureMode = Ndis802_11Infrastructure;
bssid.IELength = 0;
}
length = get_WLAN_BSSID_EX_sz(&bssid);
if (length % 4)
bssid.Length = ((length >> 2) + 1) << 2; /* round up to multiple of 4 bytes. */
else
bssid.Length = length;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
goto end_of_mp_start_test;
/* init mp_start_test status */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
rtw_disassoc_cmd(padapter, 500, 0);
rtw_indicate_disconnect(padapter, 0, _FALSE);
rtw_free_assoc_resources_cmd(padapter, _TRUE, 0);
}
pmppriv->prev_fw_state = get_fwstate(pmlmepriv);
/*pmlmepriv->fw_state = WIFI_MP_STATE;*/
init_fwstate(pmlmepriv, WIFI_MP_STATE);
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
/* 3 2. create a new psta for mp driver */
/* clear psta in the cur_network, if any */
psta = rtw_get_stainfo(&padapter->stapriv, tgt_network->network.MacAddress);
if (psta)
rtw_free_stainfo(padapter, psta);
psta = rtw_alloc_stainfo(&padapter->stapriv, bssid.MacAddress);
if (psta == NULL) {
/*pmlmepriv->fw_state = pmppriv->prev_fw_state;*/
init_fwstate(pmlmepriv, pmppriv->prev_fw_state);
res = _FAIL;
goto end_of_mp_start_test;
}
if (mode == WIFI_FW_ADHOC_STATE)
set_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
else
set_fwstate(pmlmepriv, WIFI_STATION_STATE);
/* 3 3. join psudo AdHoc */
tgt_network->join_res = 1;
tgt_network->aid = psta->cmn.aid = 1;
_rtw_memcpy(&padapter->registrypriv.dev_network, &bssid, length);
rtw_update_registrypriv_dev_network(padapter);
_rtw_memcpy(&tgt_network->network, &padapter->registrypriv.dev_network, padapter->registrypriv.dev_network.Length);
_rtw_memcpy(pnetwork, &padapter->registrypriv.dev_network, padapter->registrypriv.dev_network.Length);
rtw_indicate_connect(padapter);
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
set_fwstate(pmlmepriv, _FW_LINKED);
end_of_mp_start_test:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
if (1) { /* (res == _SUCCESS) */
/* set MSR to WIFI_FW_ADHOC_STATE */
if (mode == WIFI_FW_ADHOC_STATE) {
/* set msr to WIFI_FW_ADHOC_STATE */
pmlmeinfo->state = WIFI_FW_ADHOC_STATE;
Set_MSR(padapter, (pmlmeinfo->state & 0x3));
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, padapter->registrypriv.dev_network.MacAddress);
rtw_hal_rcr_set_chk_bssid(padapter, MLME_ADHOC_STARTED);
pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
} else {
Set_MSR(padapter, WIFI_FW_STATION_STATE);
RTW_INFO("%s , pmppriv->network_macaddr =%x %x %x %x %x %x\n", __func__,
pmppriv->network_macaddr[0], pmppriv->network_macaddr[1], pmppriv->network_macaddr[2], pmppriv->network_macaddr[3], pmppriv->network_macaddr[4],
pmppriv->network_macaddr[5]);
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmppriv->network_macaddr);
}
}
return res;
}
/* This function initializes the DUT to the MP test mode */
s32 mp_start_test(PADAPTER padapter)
{
struct mp_priv *pmppriv = &padapter->mppriv;
#ifdef CONFIG_PCI_HCI
PHAL_DATA_TYPE hal;
#endif
s32 res = _SUCCESS;
padapter->registrypriv.mp_mode = 1;
init_mp_data(padapter);
#ifdef CONFIG_RTL8814A
rtl8814_InitHalDm(padapter);
#endif /* CONFIG_RTL8814A */
#ifdef CONFIG_RTL8812A
rtl8812_InitHalDm(padapter);
#endif /* CONFIG_RTL8812A */
#ifdef CONFIG_RTL8723B
rtl8723b_InitHalDm(padapter);
#endif /* CONFIG_RTL8723B */
#ifdef CONFIG_RTL8703B
rtl8703b_InitHalDm(padapter);
#endif /* CONFIG_RTL8703B */
#ifdef CONFIG_RTL8192E
rtl8192e_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8188F
rtl8188f_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8188GTV
rtl8188gtv_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8188E
rtl8188e_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8723D
rtl8723d_InitHalDm(padapter);
#endif /* CONFIG_RTL8723D */
#ifdef CONFIG_PCI_HCI
hal = GET_HAL_DATA(padapter);
hal->pci_backdoor_ctrl = 0;
rtw_pci_aspm_config(padapter);
#endif
/* 3 0. update mp_priv */
if (!RF_TYPE_VALID(padapter->registrypriv.rf_config)) {
/* switch (phal->rf_type) { */
switch (GET_RF_TYPE(padapter)) {
case RF_1T1R:
pmppriv->antenna_tx = ANTENNA_A;
pmppriv->antenna_rx = ANTENNA_A;
break;
case RF_1T2R:
default:
pmppriv->antenna_tx = ANTENNA_A;
pmppriv->antenna_rx = ANTENNA_AB;
break;
case RF_2T2R:
pmppriv->antenna_tx = ANTENNA_AB;
pmppriv->antenna_rx = ANTENNA_AB;
break;
case RF_2T4R:
pmppriv->antenna_tx = ANTENNA_AB;
pmppriv->antenna_rx = ANTENNA_ABCD;
break;
}
}
mpt_ProStartTest(padapter);
mp_join(padapter, WIFI_FW_ADHOC_STATE);
return res;
}
/* ------------------------------------------------------------------------------
* This function change the DUT from the MP test mode into normal mode */
void mp_stop_test(PADAPTER padapter)
{
struct mp_priv *pmppriv = &padapter->mppriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *tgt_network = &pmlmepriv->cur_network;
struct sta_info *psta;
#ifdef CONFIG_PCI_HCI
struct registry_priv *registry_par = &padapter->registrypriv;
PHAL_DATA_TYPE hal;
#endif
_irqL irqL;
if (pmppriv->mode == MP_ON) {
pmppriv->bSetTxPower = 0;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _FALSE)
goto end_of_mp_stop_test;
/* 3 1. disconnect psudo AdHoc */
rtw_indicate_disconnect(padapter, 0, _FALSE);
/* 3 2. clear psta used in mp test mode.
* rtw_free_assoc_resources(padapter, _TRUE); */
psta = rtw_get_stainfo(&padapter->stapriv, tgt_network->network.MacAddress);
if (psta)
rtw_free_stainfo(padapter, psta);
/* 3 3. return to normal state (default:station mode) */
/*pmlmepriv->fw_state = pmppriv->prev_fw_state; */ /* WIFI_STATION_STATE;*/
init_fwstate(pmlmepriv, pmppriv->prev_fw_state);
/* flush the cur_network */
_rtw_memset(tgt_network, 0, sizeof(struct wlan_network));
_clr_fwstate_(pmlmepriv, WIFI_MP_STATE);
end_of_mp_stop_test:
_exit_critical_bh(&pmlmepriv->lock, &irqL);
#ifdef CONFIG_PCI_HCI
hal = GET_HAL_DATA(padapter);
hal->pci_backdoor_ctrl = registry_par->pci_aspm_config;
rtw_pci_aspm_config(padapter);
#endif
#ifdef CONFIG_RTL8812A
rtl8812_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8723B
rtl8723b_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8703B
rtl8703b_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8192E
rtl8192e_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8188F
rtl8188f_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8188GTV
rtl8188gtv_InitHalDm(padapter);
#endif
#ifdef CONFIG_RTL8723D
rtl8723d_InitHalDm(padapter);
#endif
}
}
/*---------------------------hal\rtl8192c\MPT_Phy.c---------------------------*/
#if 0
/* #ifdef CONFIG_USB_HCI */
static void mpt_AdjustRFRegByRateByChan92CU(PADAPTER pAdapter, u8 RateIdx, u8 Channel, u8 BandWidthID)
{
u8 eRFPath;
u32 rfReg0x26;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
if (RateIdx < MPT_RATE_6M) /* CCK rate,for 88cu */
rfReg0x26 = 0xf400;
else if ((RateIdx >= MPT_RATE_6M) && (RateIdx <= MPT_RATE_54M)) {/* OFDM rate,for 88cu */
if ((4 == Channel) || (8 == Channel) || (12 == Channel))
rfReg0x26 = 0xf000;
else if ((5 == Channel) || (7 == Channel) || (13 == Channel) || (14 == Channel))
rfReg0x26 = 0xf400;
else
rfReg0x26 = 0x4f200;
} else if ((RateIdx >= MPT_RATE_MCS0) && (RateIdx <= MPT_RATE_MCS15)) {
/* MCS 20M ,for 88cu */ /* MCS40M rate,for 88cu */
if (CHANNEL_WIDTH_20 == BandWidthID) {
if ((4 == Channel) || (8 == Channel))
rfReg0x26 = 0xf000;
else if ((5 == Channel) || (7 == Channel) || (13 == Channel) || (14 == Channel))
rfReg0x26 = 0xf400;
else
rfReg0x26 = 0x4f200;
} else {
if ((4 == Channel) || (8 == Channel))
rfReg0x26 = 0xf000;
else if ((5 == Channel) || (7 == Channel))
rfReg0x26 = 0xf400;
else
rfReg0x26 = 0x4f200;
}
}
for (eRFPath = 0; eRFPath < pHalData->NumTotalRFPath; eRFPath++)
write_rfreg(pAdapter, eRFPath, RF_SYN_G2, rfReg0x26);
}
#endif
/*-----------------------------------------------------------------------------
* Function: mpt_SwitchRfSetting
*
* Overview: Change RF Setting when we siwthc channel/rate/BW for MP.
*
* Input: PADAPTER pAdapter
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 01/08/2009 MHC Suggestion from SD3 Willis for 92S series.
* 01/09/2009 MHC Add CCK modification for 40MHZ. Suggestion from SD3.
*
*---------------------------------------------------------------------------*/
#if 0
static void mpt_SwitchRfSetting(PADAPTER pAdapter)
{
hal_mpt_SwitchRfSetting(pAdapter);
}
/*---------------------------hal\rtl8192c\MPT_Phy.c---------------------------*/
/*---------------------------hal\rtl8192c\MPT_HelperFunc.c---------------------------*/
static void MPT_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
{
hal_mpt_CCKTxPowerAdjust(Adapter, bInCH14);
}
#endif
/*---------------------------hal\rtl8192c\MPT_HelperFunc.c---------------------------*/
/*
* SetChannel
* Description
* Use H2C command to change channel,
* not only modify rf register, but also other setting need to be done.
*/
void SetChannel(PADAPTER pAdapter)
{
hal_mpt_SetChannel(pAdapter);
}
/*
* Notice
* Switch bandwitdth may change center frequency(channel)
*/
void SetBandwidth(PADAPTER pAdapter)
{
hal_mpt_SetBandwidth(pAdapter);
}
void SetAntenna(PADAPTER pAdapter)
{
hal_mpt_SetAntenna(pAdapter);
}
int SetTxPower(PADAPTER pAdapter)
{
hal_mpt_SetTxPower(pAdapter);
return _TRUE;
}
void SetTxAGCOffset(PADAPTER pAdapter, u32 ulTxAGCOffset)
{
u32 TxAGCOffset_B, TxAGCOffset_C, TxAGCOffset_D, tmpAGC;
TxAGCOffset_B = (ulTxAGCOffset & 0x000000ff);
TxAGCOffset_C = ((ulTxAGCOffset & 0x0000ff00) >> 8);
TxAGCOffset_D = ((ulTxAGCOffset & 0x00ff0000) >> 16);
tmpAGC = (TxAGCOffset_D << 8 | TxAGCOffset_C << 4 | TxAGCOffset_B);
write_bbreg(pAdapter, rFPGA0_TxGainStage,
(bXBTxAGC | bXCTxAGC | bXDTxAGC), tmpAGC);
}
void SetDataRate(PADAPTER pAdapter)
{
hal_mpt_SetDataRate(pAdapter);
}
void MP_PHY_SetRFPathSwitch(PADAPTER pAdapter , BOOLEAN bMain)
{
PHY_SetRFPathSwitch(pAdapter, bMain);
}
void mp_phy_switch_rf_path_set(PADAPTER pAdapter , u8 *pstate)
{
phy_switch_rf_path_set(pAdapter, pstate);
}
u8 MP_PHY_QueryRFPathSwitch(PADAPTER pAdapter)
{
return PHY_QueryRFPathSwitch(pAdapter);
}
s32 SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
{
return hal_mpt_SetThermalMeter(pAdapter, target_ther);
}
#if 0
static void TriggerRFThermalMeter(PADAPTER pAdapter)
{
hal_mpt_TriggerRFThermalMeter(pAdapter);
}
static u8 ReadRFThermalMeter(PADAPTER pAdapter)
{
return hal_mpt_ReadRFThermalMeter(pAdapter);
}
#endif
void GetThermalMeter(PADAPTER pAdapter, u8 rfpath ,u8 *value)
{
hal_mpt_GetThermalMeter(pAdapter, rfpath, value);
}
void SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)
{
PhySetTxPowerLevel(pAdapter);
hal_mpt_SetSingleCarrierTx(pAdapter, bStart);
}
void SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
{
PhySetTxPowerLevel(pAdapter);
hal_mpt_SetSingleToneTx(pAdapter, bStart);
}
void SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)
{
PhySetTxPowerLevel(pAdapter);
hal_mpt_SetCarrierSuppressionTx(pAdapter, bStart);
}
void SetContinuousTx(PADAPTER pAdapter, u8 bStart)
{
PhySetTxPowerLevel(pAdapter);
hal_mpt_SetContinuousTx(pAdapter, bStart);
}
void PhySetTxPowerLevel(PADAPTER pAdapter)
{
struct mp_priv *pmp_priv = &pAdapter->mppriv;
if (pmp_priv->bSetTxPower == 0) /* for NO manually set power index */
rtw_hal_set_tx_power_level(pAdapter, pmp_priv->channel);
}
/* ------------------------------------------------------------------------------ */
static void dump_mpframe(PADAPTER padapter, struct xmit_frame *pmpframe)
{
rtw_hal_mgnt_xmit(padapter, pmpframe);
}
static struct xmit_frame *alloc_mp_xmitframe(struct xmit_priv *pxmitpriv)
{
struct xmit_frame *pmpframe;
struct xmit_buf *pxmitbuf;
pmpframe = rtw_alloc_xmitframe(pxmitpriv);
if (pmpframe == NULL)
return NULL;
pxmitbuf = rtw_alloc_xmitbuf(pxmitpriv);
if (pxmitbuf == NULL) {
rtw_free_xmitframe(pxmitpriv, pmpframe);
return NULL;
}
pmpframe->frame_tag = MP_FRAMETAG;
pmpframe->pxmitbuf = pxmitbuf;
pmpframe->buf_addr = pxmitbuf->pbuf;
pxmitbuf->priv_data = pmpframe;
return pmpframe;
}
#ifdef CONFIG_PCI_HCI
static u8 check_nic_enough_desc(_adapter *padapter, struct pkt_attrib *pattrib)
{
u32 prio;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct rtw_tx_ring *ring;
switch (pattrib->qsel) {
case 0:
case 3:
prio = BE_QUEUE_INX;
break;
case 1:
case 2:
prio = BK_QUEUE_INX;
break;
case 4:
case 5:
prio = VI_QUEUE_INX;
break;
case 6:
case 7:
prio = VO_QUEUE_INX;
break;
default:
prio = BE_QUEUE_INX;
break;
}
ring = &pxmitpriv->tx_ring[prio];
/*
* for now we reserve two free descriptor as a safety boundary
* between the tail and the head
*/
if ((ring->entries - ring->qlen) >= 2)
return _TRUE;
else
return _FALSE;
}
#endif
static thread_return mp_xmit_packet_thread(thread_context context)
{
struct xmit_frame *pxmitframe;
struct mp_tx *pmptx;
struct mp_priv *pmp_priv;
struct xmit_priv *pxmitpriv;
PADAPTER padapter;
pmp_priv = (struct mp_priv *)context;
pmptx = &pmp_priv->tx;
padapter = pmp_priv->papdater;
pxmitpriv = &(padapter->xmitpriv);
thread_enter("RTW_MP_THREAD");
RTW_INFO("%s:pkTx Start\n", __func__);
while (1) {
pxmitframe = alloc_mp_xmitframe(pxmitpriv);
#ifdef CONFIG_PCI_HCI
if(check_nic_enough_desc(padapter, &pmptx->attrib) == _FALSE) {
rtw_usleep_os(1000);
continue;
}
#endif
if (pxmitframe == NULL) {
if (pmptx->stop ||
RTW_CANNOT_RUN(padapter))
goto exit;
else {
rtw_usleep_os(10);
continue;
}
}
_rtw_memcpy((u8 *)(pxmitframe->buf_addr + TXDESC_OFFSET), pmptx->buf, pmptx->write_size);
_rtw_memcpy(&(pxmitframe->attrib), &(pmptx->attrib), sizeof(struct pkt_attrib));
rtw_usleep_os(padapter->mppriv.pktInterval);
dump_mpframe(padapter, pxmitframe);
pmptx->sended++;
pmp_priv->tx_pktcount++;
if (pmptx->stop ||
RTW_CANNOT_RUN(padapter))
goto exit;
if ((pmptx->count != 0) &&
(pmptx->count == pmptx->sended))
goto exit;
flush_signals_thread();
}
exit:
/* RTW_INFO("%s:pkTx Exit\n", __func__); */
rtw_mfree(pmptx->pallocated_buf, pmptx->buf_size);
pmptx->pallocated_buf = NULL;
pmptx->stop = 1;
thread_exit(NULL);
return 0;
}
void fill_txdesc_for_mp(PADAPTER padapter, u8 *ptxdesc)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
_rtw_memcpy(ptxdesc, pmp_priv->tx.desc, TXDESC_SIZE);
}
#if defined(CONFIG_RTL8188E)
void fill_tx_desc_8188e(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct tx_desc *desc = (struct tx_desc *)&(pmp_priv->tx.desc);
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u32 pkt_size = pattrib->last_txcmdsz;
s32 bmcast = IS_MCAST(pattrib->ra);
/* offset 0 */
#if !defined(CONFIG_RTL8188E_SDIO) && !defined(CONFIG_PCI_HCI)
desc->txdw0 |= cpu_to_le32(OWN | FSG | LSG);
desc->txdw0 |= cpu_to_le32(pkt_size & 0x0000FFFF); /* packet size */
desc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00FF0000); /* 32 bytes for TX Desc */
if (bmcast)
desc->txdw0 |= cpu_to_le32(BMC); /* broadcast packet */
desc->txdw1 |= cpu_to_le32((0x01 << 26) & 0xff000000);
#endif
desc->txdw1 |= cpu_to_le32((pattrib->mac_id) & 0x3F); /* CAM_ID(MAC_ID) */
desc->txdw1 |= cpu_to_le32((pattrib->qsel << QSEL_SHT) & 0x00001F00); /* Queue Select, TID */
desc->txdw1 |= cpu_to_le32((pattrib->raid << RATE_ID_SHT) & 0x000F0000); /* Rate Adaptive ID */
/* offset 8 */
/* desc->txdw2 |= cpu_to_le32(AGG_BK); */ /* AGG BK */
desc->txdw3 |= cpu_to_le32((pattrib->seqnum << 16) & 0x0fff0000);
desc->txdw4 |= cpu_to_le32(HW_SSN);
desc->txdw4 |= cpu_to_le32(USERATE);
desc->txdw4 |= cpu_to_le32(DISDATAFB);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
desc->txdw4 |= cpu_to_le32(DATA_SHORT); /* CCK Short Preamble */
}
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
desc->txdw4 |= cpu_to_le32(DATA_BW);
/* offset 20 */
desc->txdw5 |= cpu_to_le32(pmp_priv->rateidx & 0x0000001F);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) > MPT_RATE_54M)
desc->txdw5 |= cpu_to_le32(SGI); /* MCS Short Guard Interval */
}
desc->txdw5 |= cpu_to_le32(RTY_LMT_EN); /* retry limit enable */
desc->txdw5 |= cpu_to_le32(0x00180000); /* DATA/RTS Rate Fallback Limit */
}
#endif
#if defined(CONFIG_RTL8814A)
void fill_tx_desc_8814a(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
u8 *pDesc = (u8 *)&(pmp_priv->tx.desc);
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u32 pkt_size = pattrib->last_txcmdsz;
s32 bmcast = IS_MCAST(pattrib->ra);
u8 offset;
/* SET_TX_DESC_FIRST_SEG_8814A(pDesc, 1); */
SET_TX_DESC_LAST_SEG_8814A(pDesc, 1);
/* SET_TX_DESC_OWN_(pDesc, 1); */
SET_TX_DESC_PKT_SIZE_8814A(pDesc, pkt_size);
offset = TXDESC_SIZE + OFFSET_SZ;
SET_TX_DESC_OFFSET_8814A(pDesc, offset);
#if defined(CONFIG_PCI_HCI)
SET_TX_DESC_PKT_OFFSET_8814A(pDesc, 0); /* 8814AE pkt_offset is 0 */
#else
SET_TX_DESC_PKT_OFFSET_8814A(pDesc, 1);
#endif
if (bmcast)
SET_TX_DESC_BMC_8814A(pDesc, 1);
SET_TX_DESC_MACID_8814A(pDesc, pattrib->mac_id);
SET_TX_DESC_RATE_ID_8814A(pDesc, pattrib->raid);
/* SET_TX_DESC_RATE_ID_8812(pDesc, RATEID_IDX_G); */
SET_TX_DESC_QUEUE_SEL_8814A(pDesc, pattrib->qsel);
/* SET_TX_DESC_QUEUE_SEL_8812(pDesc, QSLT_MGNT); */
if (pmp_priv->preamble)
SET_TX_DESC_DATA_SHORT_8814A(pDesc, 1);
if (!pattrib->qos_en) {
SET_TX_DESC_HWSEQ_EN_8814A(pDesc, 1); /* Hw set sequence number */
} else
SET_TX_DESC_SEQ_8814A(pDesc, pattrib->seqnum);
if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160)
SET_TX_DESC_DATA_BW_8814A(pDesc, pmp_priv->bandwidth);
else {
RTW_INFO("%s:Err: unknown bandwidth %d, use 20M\n", __func__, pmp_priv->bandwidth);
SET_TX_DESC_DATA_BW_8814A(pDesc, CHANNEL_WIDTH_20);
}
SET_TX_DESC_DISABLE_FB_8814A(pDesc, 1);
SET_TX_DESC_USE_RATE_8814A(pDesc, 1);
SET_TX_DESC_TX_RATE_8814A(pDesc, pmp_priv->rateidx);
}
#endif
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
void fill_tx_desc_8812a(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
u8 *pDesc = (u8 *)&(pmp_priv->tx.desc);
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u32 pkt_size = pattrib->last_txcmdsz;
s32 bmcast = IS_MCAST(pattrib->ra);
u8 data_rate, pwr_status, offset;
SET_TX_DESC_FIRST_SEG_8812(pDesc, 1);
SET_TX_DESC_LAST_SEG_8812(pDesc, 1);
SET_TX_DESC_OWN_8812(pDesc, 1);
SET_TX_DESC_PKT_SIZE_8812(pDesc, pkt_size);
offset = TXDESC_SIZE + OFFSET_SZ;
SET_TX_DESC_OFFSET_8812(pDesc, offset);
#if defined(CONFIG_PCI_HCI)
SET_TX_DESC_PKT_OFFSET_8812(pDesc, 0);
#else
SET_TX_DESC_PKT_OFFSET_8812(pDesc, 1);
#endif
if (bmcast)
SET_TX_DESC_BMC_8812(pDesc, 1);
SET_TX_DESC_MACID_8812(pDesc, pattrib->mac_id);
SET_TX_DESC_RATE_ID_8812(pDesc, pattrib->raid);
/* SET_TX_DESC_RATE_ID_8812(pDesc, RATEID_IDX_G); */
SET_TX_DESC_QUEUE_SEL_8812(pDesc, pattrib->qsel);
/* SET_TX_DESC_QUEUE_SEL_8812(pDesc, QSLT_MGNT); */
if (!pattrib->qos_en) {
SET_TX_DESC_HWSEQ_EN_8812(pDesc, 1); /* Hw set sequence number */
} else
SET_TX_DESC_SEQ_8812(pDesc, pattrib->seqnum);
if (pmp_priv->bandwidth <= CHANNEL_WIDTH_160)
SET_TX_DESC_DATA_BW_8812(pDesc, pmp_priv->bandwidth);
else {
RTW_INFO("%s:Err: unknown bandwidth %d, use 20M\n", __func__, pmp_priv->bandwidth);
SET_TX_DESC_DATA_BW_8812(pDesc, CHANNEL_WIDTH_20);
}
SET_TX_DESC_DISABLE_FB_8812(pDesc, 1);
SET_TX_DESC_USE_RATE_8812(pDesc, 1);
SET_TX_DESC_TX_RATE_8812(pDesc, pmp_priv->rateidx);
}
#endif
#if defined(CONFIG_RTL8192E)
void fill_tx_desc_8192e(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
u8 *pDesc = (u8 *)&(pmp_priv->tx.desc);
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u32 pkt_size = pattrib->last_txcmdsz;
s32 bmcast = IS_MCAST(pattrib->ra);
u8 data_rate, pwr_status, offset;
SET_TX_DESC_PKT_SIZE_92E(pDesc, pkt_size);
offset = TXDESC_SIZE + OFFSET_SZ;
SET_TX_DESC_OFFSET_92E(pDesc, offset);
#if defined(CONFIG_PCI_HCI) /* 8192EE */
SET_TX_DESC_PKT_OFFSET_92E(pDesc, 0); /* 8192EE pkt_offset is 0 */
#else /* 8192EU 8192ES */
SET_TX_DESC_PKT_OFFSET_92E(pDesc, 1);
#endif
if (bmcast)
SET_TX_DESC_BMC_92E(pDesc, 1);
SET_TX_DESC_MACID_92E(pDesc, pattrib->mac_id);
SET_TX_DESC_RATE_ID_92E(pDesc, pattrib->raid);
SET_TX_DESC_QUEUE_SEL_92E(pDesc, pattrib->qsel);
/* SET_TX_DESC_QUEUE_SEL_8812(pDesc, QSLT_MGNT); */
if (!pattrib->qos_en) {
SET_TX_DESC_EN_HWSEQ_92E(pDesc, 1);/* Hw set sequence number */
SET_TX_DESC_HWSEQ_SEL_92E(pDesc, pattrib->hw_ssn_sel);
} else
SET_TX_DESC_SEQ_92E(pDesc, pattrib->seqnum);
if ((pmp_priv->bandwidth == CHANNEL_WIDTH_20) || (pmp_priv->bandwidth == CHANNEL_WIDTH_40))
SET_TX_DESC_DATA_BW_92E(pDesc, pmp_priv->bandwidth);
else {
RTW_INFO("%s:Err: unknown bandwidth %d, use 20M\n", __func__, pmp_priv->bandwidth);
SET_TX_DESC_DATA_BW_92E(pDesc, CHANNEL_WIDTH_20);
}
/* SET_TX_DESC_DATA_SC_92E(pDesc, SCMapping_92E(padapter,pattrib)); */
SET_TX_DESC_DISABLE_FB_92E(pDesc, 1);
SET_TX_DESC_USE_RATE_92E(pDesc, 1);
SET_TX_DESC_TX_RATE_92E(pDesc, pmp_priv->rateidx);
}
#endif
#if defined(CONFIG_RTL8723B)
void fill_tx_desc_8723b(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_AGG_BREAK_8723B(ptxdesc, 1);
SET_TX_DESC_MACID_8723B(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8723B(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8723B(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8723B(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8723B(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8723B(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8723B(ptxdesc, 1);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8723B(ptxdesc, 1);
}
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8723B(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8723B(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8723B(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8723B(ptxdesc, 0xF);
}
#endif
#if defined(CONFIG_RTL8703B)
void fill_tx_desc_8703b(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_AGG_BREAK_8703B(ptxdesc, 1);
SET_TX_DESC_MACID_8703B(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8703B(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8703B(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8703B(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8703B(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8703B(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8703B(ptxdesc, 1);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8703B(ptxdesc, 1);
}
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8703B(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8703B(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8703B(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8703B(ptxdesc, 0xF);
}
#endif
#if defined(CONFIG_RTL8188F)
void fill_tx_desc_8188f(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_AGG_BREAK_8188F(ptxdesc, 1);
SET_TX_DESC_MACID_8188F(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8188F(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8188F(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8188F(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8188F(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8188F(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8188F(ptxdesc, 1);
if (pmp_priv->preamble)
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8188F(ptxdesc, 1);
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8188F(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8188F(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8188F(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8188F(ptxdesc, 0xF);
}
#endif
#if defined(CONFIG_RTL8188GTV)
void fill_tx_desc_8188gtv(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_AGG_BREAK_8188GTV(ptxdesc, 1);
SET_TX_DESC_MACID_8188GTV(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8188GTV(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8188GTV(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8188GTV(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8188GTV(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8188GTV(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8188GTV(ptxdesc, 1);
if (pmp_priv->preamble)
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8188GTV(ptxdesc, 1);
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8188GTV(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8188GTV(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8188GTV(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8188GTV(ptxdesc, 0xF);
}
#endif
#if defined(CONFIG_RTL8723D)
void fill_tx_desc_8723d(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_BK_8723D(ptxdesc, 1);
SET_TX_DESC_MACID_8723D(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8723D(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8723D(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8723D(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8723D(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8723D(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8723D(ptxdesc, 1);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8723D(ptxdesc, 1);
}
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8723D(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8723D(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8723D(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8723D(ptxdesc, 0xF);
}
#endif
#if defined(CONFIG_RTL8710B)
void fill_tx_desc_8710b(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_BK_8710B(ptxdesc, 1);
SET_TX_DESC_MACID_8710B(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8710B(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8710B(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8710B(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8710B(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8710B(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8710B(ptxdesc, 1);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8710B(ptxdesc, 1);
}
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8710B(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8710B(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8710B(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8710B(ptxdesc, 0xF);
}
#endif
#if defined(CONFIG_RTL8192F)
void fill_tx_desc_8192f(PADAPTER padapter)
{
struct mp_priv *pmp_priv = &padapter->mppriv;
struct pkt_attrib *pattrib = &(pmp_priv->tx.attrib);
u8 *ptxdesc = pmp_priv->tx.desc;
SET_TX_DESC_BK_8192F(ptxdesc, 1);
SET_TX_DESC_MACID_8192F(ptxdesc, pattrib->mac_id);
SET_TX_DESC_QUEUE_SEL_8192F(ptxdesc, pattrib->qsel);
SET_TX_DESC_RATE_ID_8192F(ptxdesc, pattrib->raid);
SET_TX_DESC_SEQ_8192F(ptxdesc, pattrib->seqnum);
SET_TX_DESC_HWSEQ_EN_8192F(ptxdesc, 1);
SET_TX_DESC_USE_RATE_8192F(ptxdesc, 1);
SET_TX_DESC_DISABLE_FB_8192F(ptxdesc, 1);
if (pmp_priv->preamble) {
if (HwRateToMPTRate(pmp_priv->rateidx) <= MPT_RATE_54M)
SET_TX_DESC_DATA_SHORT_8192F(ptxdesc, 1);
}
if (pmp_priv->bandwidth == CHANNEL_WIDTH_40)
SET_TX_DESC_DATA_BW_8192F(ptxdesc, 1);
SET_TX_DESC_TX_RATE_8192F(ptxdesc, pmp_priv->rateidx);
SET_TX_DESC_DATA_RATE_FB_LIMIT_8192F(ptxdesc, 0x1F);
SET_TX_DESC_RTS_RATE_FB_LIMIT_8192F(ptxdesc, 0xF);
}
#endif
static void Rtw_MPSetMacTxEDCA(PADAPTER padapter)
{
rtw_write32(padapter, 0x508 , 0x00a422); /* Disable EDCA BE Txop for MP pkt tx adjust Packet interval */
/* RTW_INFO("%s:write 0x508~~~~~~ 0x%x\n", __func__,rtw_read32(padapter, 0x508)); */
phy_set_mac_reg(padapter, 0x458 , bMaskDWord , 0x0);
/*RTW_INFO("%s()!!!!! 0x460 = 0x%x\n" ,__func__, phy_query_bb_reg(padapter, 0x460, bMaskDWord));*/
phy_set_mac_reg(padapter, 0x460 , bMaskLWord , 0x0); /* fast EDCA queue packet interval & time out value*/
/*phy_set_mac_reg(padapter, ODM_EDCA_VO_PARAM ,bMaskLWord , 0x431C);*/
/*phy_set_mac_reg(padapter, ODM_EDCA_BE_PARAM ,bMaskLWord , 0x431C);*/
/*phy_set_mac_reg(padapter, ODM_EDCA_BK_PARAM ,bMaskLWord , 0x431C);*/
RTW_INFO("%s()!!!!! 0x460 = 0x%x\n" , __func__, phy_query_bb_reg(padapter, 0x460, bMaskDWord));
}
void SetPacketTx(PADAPTER padapter)
{
u8 *ptr, *pkt_start, *pkt_end;
u32 pkt_size, i;
struct rtw_ieee80211_hdr *hdr;
u8 payload;
s32 bmcast;
struct pkt_attrib *pattrib;
struct mp_priv *pmp_priv;
pmp_priv = &padapter->mppriv;
if (pmp_priv->tx.stop)
return;
pmp_priv->tx.sended = 0;
pmp_priv->tx.stop = 0;
pmp_priv->tx_pktcount = 0;
/* 3 1. update_attrib() */
pattrib = &pmp_priv->tx.attrib;
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
bmcast = IS_MCAST(pattrib->ra);
if (bmcast)
pattrib->psta = rtw_get_bcmc_stainfo(padapter);
else
pattrib->psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
pattrib->mac_id = pattrib->psta->cmn.mac_id;
pattrib->mbssid = 0;
pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->pktlen;
/* 3 2. allocate xmit buffer */
pkt_size = pattrib->last_txcmdsz;
if (pmp_priv->tx.pallocated_buf)
rtw_mfree(pmp_priv->tx.pallocated_buf, pmp_priv->tx.buf_size);
pmp_priv->tx.write_size = pkt_size;
pmp_priv->tx.buf_size = pkt_size + XMITBUF_ALIGN_SZ;
pmp_priv->tx.pallocated_buf = rtw_zmalloc(pmp_priv->tx.buf_size);
if (pmp_priv->tx.pallocated_buf == NULL) {
RTW_INFO("%s: malloc(%d) fail!!\n", __func__, pmp_priv->tx.buf_size);
return;
}
pmp_priv->tx.buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pmp_priv->tx.pallocated_buf), XMITBUF_ALIGN_SZ);
ptr = pmp_priv->tx.buf;
_rtw_memset(pmp_priv->tx.desc, 0, TXDESC_SIZE);
pkt_start = ptr;
pkt_end = pkt_start + pkt_size;
/* 3 3. init TX descriptor */
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(padapter))
fill_tx_desc_8188e(padapter);
#endif
#if defined(CONFIG_RTL8814A)
if (IS_HARDWARE_TYPE_8814A(padapter))
fill_tx_desc_8814a(padapter);
#endif /* defined(CONFIG_RTL8814A) */
#if defined(CONFIG_RTL8822B)
if (IS_HARDWARE_TYPE_8822B(padapter))
rtl8822b_prepare_mp_txdesc(padapter, pmp_priv);
#endif /* CONFIG_RTL8822B */
#if defined(CONFIG_RTL8822C)
if (IS_HARDWARE_TYPE_8822C(padapter))
rtl8822c_prepare_mp_txdesc(padapter, pmp_priv);
#endif /* CONFIG_RTL8822C */
#if defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_8821C(padapter))
rtl8821c_prepare_mp_txdesc(padapter, pmp_priv);
#endif /* CONFIG_RTL8821C */
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_8812(padapter) || IS_HARDWARE_TYPE_8821(padapter))
fill_tx_desc_8812a(padapter);
#endif
#if defined(CONFIG_RTL8192E)
if (IS_HARDWARE_TYPE_8192E(padapter))
fill_tx_desc_8192e(padapter);
#endif
#if defined(CONFIG_RTL8723B)
if (IS_HARDWARE_TYPE_8723B(padapter))
fill_tx_desc_8723b(padapter);
#endif
#if defined(CONFIG_RTL8703B)
if (IS_HARDWARE_TYPE_8703B(padapter))
fill_tx_desc_8703b(padapter);
#endif
#if defined(CONFIG_RTL8188F)
if (IS_HARDWARE_TYPE_8188F(padapter))
fill_tx_desc_8188f(padapter);
#endif
#if defined(CONFIG_RTL8188GTV)
if (IS_HARDWARE_TYPE_8188GTV(padapter))
fill_tx_desc_8188gtv(padapter);
#endif
#if defined(CONFIG_RTL8723D)
if (IS_HARDWARE_TYPE_8723D(padapter))
fill_tx_desc_8723d(padapter);
#endif
#if defined(CONFIG_RTL8192F)
if (IS_HARDWARE_TYPE_8192F(padapter))
fill_tx_desc_8192f(padapter);
#endif
#if defined(CONFIG_RTL8710B)
if (IS_HARDWARE_TYPE_8710B(padapter))
fill_tx_desc_8710b(padapter);
#endif
/* 3 4. make wlan header, make_wlanhdr() */
hdr = (struct rtw_ieee80211_hdr *)pkt_start;
set_frame_sub_type(&hdr->frame_ctl, pattrib->subtype);
_rtw_memcpy(hdr->addr1, pattrib->dst, ETH_ALEN); /* DA */
_rtw_memcpy(hdr->addr2, pattrib->src, ETH_ALEN); /* SA */
_rtw_memcpy(hdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN); /* RA, BSSID */
/* 3 5. make payload */
ptr = pkt_start + pattrib->hdrlen;
switch (pmp_priv->tx.payload) {
case 0:
payload = 0x00;
break;
case 1:
payload = 0x5a;
break;
case 2:
payload = 0xa5;
break;
case 3:
payload = 0xff;
break;
default:
payload = 0x00;
break;
}
pmp_priv->TXradomBuffer = rtw_zmalloc(4096);
if (pmp_priv->TXradomBuffer == NULL) {
RTW_INFO("mp create random buffer fail!\n");
goto exit;
}
for (i = 0; i < 4096; i++)
pmp_priv->TXradomBuffer[i] = rtw_random32() % 0xFF;
/* startPlace = (u32)(rtw_random32() % 3450); */
if (pmp_priv->mplink_btx == _TRUE)
_rtw_memcpy(ptr, pmp_priv->mplink_buf, pkt_end - ptr);
else
_rtw_memcpy(ptr, pmp_priv->TXradomBuffer, pkt_end - ptr);
/* _rtw_memset(ptr, payload, pkt_end - ptr); */
rtw_mfree(pmp_priv->TXradomBuffer, 4096);
/* 3 6. start thread */
#ifdef PLATFORM_LINUX
pmp_priv->tx.PktTxThread = kthread_run(mp_xmit_packet_thread, pmp_priv, "RTW_MP_THREAD");
if (IS_ERR(pmp_priv->tx.PktTxThread)) {
RTW_ERR("Create PktTx Thread Fail !!!!!\n");
pmp_priv->tx.PktTxThread = NULL;
}
#endif
#ifdef PLATFORM_FREEBSD
{
struct proc *p;
struct thread *td;
pmp_priv->tx.PktTxThread = kproc_kthread_add(mp_xmit_packet_thread, pmp_priv,
&p, &td, RFHIGHPID, 0, "MPXmitThread", "MPXmitThread");
if (pmp_priv->tx.PktTxThread < 0)
RTW_INFO("Create PktTx Thread Fail !!!!!\n");
}
#endif
Rtw_MPSetMacTxEDCA(padapter);
exit:
return;
}
void SetPacketRx(PADAPTER pAdapter, u8 bStartRx, u8 bAB)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
struct mp_priv *pmppriv = &pAdapter->mppriv;
if (bStartRx) {
#ifdef CONFIG_RTL8723B
phy_set_mac_reg(pAdapter, 0xe70, BIT23 | BIT22, 0x3); /* Power on adc (in RX_WAIT_CCA state) */
write_bbreg(pAdapter, 0xa01, BIT0, bDisable);/* improve Rx performance by jerry */
#endif
pHalData->ReceiveConfig = RCR_AAP | RCR_APM | RCR_AM | RCR_AMF | RCR_HTC_LOC_CTRL;
pHalData->ReceiveConfig |= RCR_ACRC32;
pHalData->ReceiveConfig |= RCR_APP_PHYST_RXFF | RCR_APP_ICV | RCR_APP_MIC;
if (pmppriv->bSetRxBssid == _TRUE) {
RTW_INFO("%s: pmppriv->network_macaddr=" MAC_FMT "\n", __func__,
MAC_ARG(pmppriv->network_macaddr));
pHalData->ReceiveConfig = 0;
pHalData->ReceiveConfig |= RCR_CBSSID_DATA | RCR_CBSSID_BCN |RCR_APM | RCR_AM | RCR_AB |RCR_AMF;
pHalData->ReceiveConfig |= RCR_APP_PHYST_RXFF;
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
write_bbreg(pAdapter, 0x550, BIT3, bEnable);
#endif
rtw_write16(pAdapter, REG_RXFLTMAP0, 0xFFEF); /* REG_RXFLTMAP0 (RX Filter Map Group 0) */
pmppriv->brx_filter_beacon = _TRUE;
} else {
pHalData->ReceiveConfig |= RCR_ADF;
/* Accept all data frames */
rtw_write16(pAdapter, REG_RXFLTMAP2, 0xFFFF);
}
if (bAB)
pHalData->ReceiveConfig |= RCR_AB;
} else {
#ifdef CONFIG_RTL8723B
phy_set_mac_reg(pAdapter, 0xe70, BIT23 | BIT22, 0x00); /* Power off adc (in RX_WAIT_CCA state)*/
write_bbreg(pAdapter, 0xa01, BIT0, bEnable);/* improve Rx performance by jerry */
#endif
pHalData->ReceiveConfig = 0;
rtw_write16(pAdapter, REG_RXFLTMAP0, 0xFFFF); /* REG_RXFLTMAP0 (RX Filter Map Group 0) */
}
rtw_write32(pAdapter, REG_RCR, pHalData->ReceiveConfig);
}
void ResetPhyRxPktCount(PADAPTER pAdapter)
{
u32 i, phyrx_set = 0;
for (i = 0; i <= 0xF; i++) {
phyrx_set = 0;
phyrx_set |= _RXERR_RPT_SEL(i); /* select */
phyrx_set |= RXERR_RPT_RST; /* set counter to zero */
rtw_write32(pAdapter, REG_RXERR_RPT, phyrx_set);
}
}
static u32 GetPhyRxPktCounts(PADAPTER pAdapter, u32 selbit)
{
/* selection */
u32 phyrx_set = 0, count = 0;
phyrx_set = _RXERR_RPT_SEL(selbit & 0xF);
rtw_write32(pAdapter, REG_RXERR_RPT, phyrx_set);
/* Read packet count */
count = rtw_read32(pAdapter, REG_RXERR_RPT) & RXERR_COUNTER_MASK;
return count;
}
u32 GetPhyRxPktReceived(PADAPTER pAdapter)
{
u32 OFDM_cnt = 0, CCK_cnt = 0, HT_cnt = 0;
OFDM_cnt = GetPhyRxPktCounts(pAdapter, RXERR_TYPE_OFDM_MPDU_OK);
CCK_cnt = GetPhyRxPktCounts(pAdapter, RXERR_TYPE_CCK_MPDU_OK);
HT_cnt = GetPhyRxPktCounts(pAdapter, RXERR_TYPE_HT_MPDU_OK);
return OFDM_cnt + CCK_cnt + HT_cnt;
}
u32 GetPhyRxPktCRC32Error(PADAPTER pAdapter)
{
u32 OFDM_cnt = 0, CCK_cnt = 0, HT_cnt = 0;
OFDM_cnt = GetPhyRxPktCounts(pAdapter, RXERR_TYPE_OFDM_MPDU_FAIL);
CCK_cnt = GetPhyRxPktCounts(pAdapter, RXERR_TYPE_CCK_MPDU_FAIL);
HT_cnt = GetPhyRxPktCounts(pAdapter, RXERR_TYPE_HT_MPDU_FAIL);
return OFDM_cnt + CCK_cnt + HT_cnt;
}
struct psd_init_regs {
/* 3 wire */
int reg_88c;
int reg_c00;
int reg_e00;
int reg_1800;
int reg_1a00;
/* cck */
int reg_800;
int reg_808;
};
static int rtw_mp_psd_init(PADAPTER padapter, struct psd_init_regs *regs)
{
HAL_DATA_TYPE *phal_data = GET_HAL_DATA(padapter);
switch (phal_data->rf_type) {
/* 1R */
case RF_1T1R:
if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
/* 11AC 1R PSD Setting 3wire & cck off */
regs->reg_c00 = rtw_read32(padapter, 0xC00);
phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
regs->reg_808 = rtw_read32(padapter, 0x808);
phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
} else {
/* 11N 3-wire off 1 */
regs->reg_88c = rtw_read32(padapter, 0x88C);
phy_set_bb_reg(padapter, 0x88C, 0x300000, 0x3);
/* 11N CCK off */
regs->reg_800 = rtw_read32(padapter, 0x800);
phy_set_bb_reg(padapter, 0x800, 0x1000000, 0x0);
}
break;
/* 2R */
case RF_1T2R:
case RF_2T2R:
if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
/* 11AC 2R PSD Setting 3wire & cck off */
regs->reg_c00 = rtw_read32(padapter, 0xC00);
regs->reg_e00 = rtw_read32(padapter, 0xE00);
phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
phy_set_bb_reg(padapter, 0xE00, 0x3, 0x00);
regs->reg_808 = rtw_read32(padapter, 0x808);
phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
} else {
/* 11N 3-wire off 2 */
regs->reg_88c = rtw_read32(padapter, 0x88C);
phy_set_bb_reg(padapter, 0x88C, 0xF00000, 0xF);
/* 11N CCK off */
regs->reg_800 = rtw_read32(padapter, 0x800);
phy_set_bb_reg(padapter, 0x800, 0x1000000, 0x0);
}
break;
/* 3R */
case RF_2T3R:
case RF_3T3R:
if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
/* 11AC 3R PSD Setting 3wire & cck off */
regs->reg_c00 = rtw_read32(padapter, 0xC00);
regs->reg_e00 = rtw_read32(padapter, 0xE00);
regs->reg_1800 = rtw_read32(padapter, 0x1800);
phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
phy_set_bb_reg(padapter, 0xE00, 0x3, 0x00);
phy_set_bb_reg(padapter, 0x1800, 0x3, 0x00);
regs->reg_808 = rtw_read32(padapter, 0x808);
phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
} else {
RTW_ERR("%s: 11n don't support 3R\n", __func__);
return -1;
}
break;
/* 4R */
case RF_2T4R:
case RF_3T4R:
case RF_4T4R:
if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
/* 11AC 4R PSD Setting 3wire & cck off */
regs->reg_c00 = rtw_read32(padapter, 0xC00);
regs->reg_e00 = rtw_read32(padapter, 0xE00);
regs->reg_1800 = rtw_read32(padapter, 0x1800);
regs->reg_1a00 = rtw_read32(padapter, 0x1A00);
phy_set_bb_reg(padapter, 0xC00, 0x3, 0x00);
phy_set_bb_reg(padapter, 0xE00, 0x3, 0x00);
phy_set_bb_reg(padapter, 0x1800, 0x3, 0x00);
phy_set_bb_reg(padapter, 0x1A00, 0x3, 0x00);
regs->reg_808 = rtw_read32(padapter, 0x808);
phy_set_bb_reg(padapter, 0x808, 0x10000000, 0x0);
} else {
RTW_ERR("%s: 11n don't support 4R\n", __func__);
return -1;
}
break;
default:
RTW_ERR("%s: unknown %d rf type\n", __func__, phal_data->rf_type);
return -1;
}
/* Set PSD points, 0=128, 1=256, 2=512, 3=1024 */
if (hal_chk_proto_cap(padapter, PROTO_CAP_11AC))
phy_set_bb_reg(padapter, 0x910, 0xC000, 3);
else
phy_set_bb_reg(padapter, 0x808, 0xC000, 3);
RTW_INFO("%s: set %d rf type done\n", __func__, phal_data->rf_type);
return 0;
}
static int rtw_mp_psd_close(PADAPTER padapter, struct psd_init_regs *regs)
{
HAL_DATA_TYPE *phal_data = GET_HAL_DATA(padapter);
if (!hal_chk_proto_cap(padapter, PROTO_CAP_11AC)) {
/* 11n 3wire restore */
rtw_write32(padapter, 0x88C, regs->reg_88c);
/* 11n cck restore */
rtw_write32(padapter, 0x800, regs->reg_800);
RTW_INFO("%s: restore %d rf type\n", __func__, phal_data->rf_type);
return 0;
}
/* 11ac 3wire restore */
switch (phal_data->rf_type) {
case RF_1T1R:
rtw_write32(padapter, 0xC00, regs->reg_c00);
break;
case RF_1T2R:
case RF_2T2R:
rtw_write32(padapter, 0xC00, regs->reg_c00);
rtw_write32(padapter, 0xE00, regs->reg_e00);
break;
case RF_2T3R:
case RF_3T3R:
rtw_write32(padapter, 0xC00, regs->reg_c00);
rtw_write32(padapter, 0xE00, regs->reg_e00);
rtw_write32(padapter, 0x1800, regs->reg_1800);
break;
case RF_2T4R:
case RF_3T4R:
case RF_4T4R:
rtw_write32(padapter, 0xC00, regs->reg_c00);
rtw_write32(padapter, 0xE00, regs->reg_e00);
rtw_write32(padapter, 0x1800, regs->reg_1800);
rtw_write32(padapter, 0x1A00, regs->reg_1a00);
break;
default:
RTW_WARN("%s: unknown %d rf type\n", __func__, phal_data->rf_type);
break;
}
/* 11ac cck restore */
rtw_write32(padapter, 0x808, regs->reg_808);
RTW_INFO("%s: restore %d rf type done\n", __func__, phal_data->rf_type);
return 0;
}
/* reg 0x808[9:0]: FFT data x
* reg 0x808[22]: 0 --> 1 to get 1 FFT data y
* reg 0x8B4[15:0]: FFT data y report */
static u32 rtw_GetPSDData(PADAPTER pAdapter, u32 point)
{
u32 psd_val = 0;
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
u16 psd_reg = 0x910;
u16 psd_regL = 0xF44;
#else
u16 psd_reg = 0x808;
u16 psd_regL = 0x8B4;
#endif
psd_val = rtw_read32(pAdapter, psd_reg);
psd_val &= 0xFFBFFC00;
psd_val |= point;
rtw_write32(pAdapter, psd_reg, psd_val);
rtw_mdelay_os(1);
psd_val |= 0x00400000;
rtw_write32(pAdapter, psd_reg, psd_val);
rtw_mdelay_os(1);
psd_val = rtw_read32(pAdapter, psd_regL);
#if defined(CONFIG_RTL8821C)
psd_val = (psd_val & 0x00FFFFFF) / 32;
#else
psd_val &= 0x0000FFFF;
#endif
return psd_val;
}
/*
* pts start_point_min stop_point_max
* 128 64 64 + 128 = 192
* 256 128 128 + 256 = 384
* 512 256 256 + 512 = 768
* 1024 512 512 + 1024 = 1536
*
*/
u32 mp_query_psd(PADAPTER pAdapter, u8 *data)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
struct dm_struct *p_dm = adapter_to_phydm(pAdapter);
u32 i, psd_pts = 0, psd_start = 0, psd_stop = 0;
u32 psd_data = 0;
struct psd_init_regs regs = {};
int psd_analysis = 0;
#ifdef PLATFORM_LINUX
if (!netif_running(pAdapter->pnetdev)) {
return 0;
}
#endif
if (check_fwstate(&pAdapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
return 0;
}
if (strlen(data) == 0) { /* default value */
psd_pts = 128;
psd_start = 64;
psd_stop = 128;
} else if (strncmp(data, "analysis,", 9) == 0) {
if (rtw_mp_psd_init(pAdapter, ®s) != 0)
return 0;
psd_analysis = 1;
sscanf(data + 9, "pts=%d,start=%d,stop=%d", &psd_pts, &psd_start, &psd_stop);
} else
sscanf(data, "pts=%d,start=%d,stop=%d", &psd_pts, &psd_start, &psd_stop);
data[0] = '\0';
if (IS_HARDWARE_TYPE_8822C(pAdapter)) {
u32 *psdbuf = rtw_zmalloc(sizeof(u32)*256);
if (psdbuf == NULL) {
RTW_INFO("%s: psd buf malloc fail!!\n", __func__);
return 0;
}
halrf_cmn_info_set(p_dm, HALRF_CMNINFO_MP_PSD_POINT, psd_pts);
halrf_cmn_info_set(p_dm, HALRF_CMNINFO_MP_PSD_START_POINT, psd_start);
halrf_cmn_info_set(p_dm, HALRF_CMNINFO_MP_PSD_STOP_POINT, psd_stop);
halrf_cmn_info_set(p_dm, HALRF_CMNINFO_MP_PSD_AVERAGE, 0x20000);
halrf_psd_init(p_dm);
#ifdef CONFIG_LONG_DELAY_ISSUE
rtw_msleep_os(100);
#else
rtw_mdelay_os(100);
#endif
halrf_psd_query(p_dm, psdbuf, 256);
i = 0;
while (i < 256) {
sprintf(data, "%s%x ", data, (psdbuf[i]));
i++;
}
if (psdbuf)
rtw_mfree(psdbuf, sizeof(u32)*256);
} else {
i = psd_start;
while (i < psd_stop) {
if (i >= psd_pts)
psd_data = rtw_GetPSDData(pAdapter, i - psd_pts);
else
psd_data = rtw_GetPSDData(pAdapter, i);
sprintf(data, "%s%x ", data, psd_data);
i++;
}
}
#ifdef CONFIG_LONG_DELAY_ISSUE
rtw_msleep_os(100);
#else
rtw_mdelay_os(100);
#endif
if (psd_analysis)
rtw_mp_psd_close(pAdapter, ®s);
return strlen(data) + 1;
}
#if 0
void _rtw_mp_xmit_priv(struct xmit_priv *pxmitpriv)
{
int i, res;
_adapter *padapter = pxmitpriv->adapter;
struct xmit_frame *pxmitframe = (struct xmit_frame *) pxmitpriv->pxmit_frame_buf;
struct xmit_buf *pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmitbuf;
u32 max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
u32 num_xmit_extbuf = NR_XMIT_EXTBUFF;
if (padapter->registrypriv.mp_mode == 0) {
max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
num_xmit_extbuf = NR_XMIT_EXTBUFF;
} else {
max_xmit_extbuf_size = 6000;
num_xmit_extbuf = 8;
}
pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
for (i = 0; i < num_xmit_extbuf; i++) {
rtw_os_xmit_resource_free(padapter, pxmitbuf, (max_xmit_extbuf_size + XMITBUF_ALIGN_SZ), _FALSE);
pxmitbuf++;
}
if (pxmitpriv->pallocated_xmit_extbuf)
rtw_vmfree(pxmitpriv->pallocated_xmit_extbuf, num_xmit_extbuf * sizeof(struct xmit_buf) + 4);
if (padapter->registrypriv.mp_mode == 0) {
max_xmit_extbuf_size = 6000;
num_xmit_extbuf = 8;
} else {
max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
num_xmit_extbuf = NR_XMIT_EXTBUFF;
}
/* Init xmit extension buff */
_rtw_init_queue(&pxmitpriv->free_xmit_extbuf_queue);
pxmitpriv->pallocated_xmit_extbuf = rtw_zvmalloc(num_xmit_extbuf * sizeof(struct xmit_buf) + 4);
if (pxmitpriv->pallocated_xmit_extbuf == NULL) {
res = _FAIL;
goto exit;
}
pxmitpriv->pxmit_extbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_xmit_extbuf), 4);
pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
for (i = 0; i < num_xmit_extbuf; i++) {
_rtw_init_listhead(&pxmitbuf->list);
pxmitbuf->priv_data = NULL;
pxmitbuf->padapter = padapter;
pxmitbuf->buf_tag = XMITBUF_MGNT;
res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, max_xmit_extbuf_size + XMITBUF_ALIGN_SZ, _TRUE);
if (res == _FAIL) {
res = _FAIL;
goto exit;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->phead = pxmitbuf->pbuf;
pxmitbuf->pend = pxmitbuf->pbuf + max_xmit_extbuf_size;
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
#endif
rtw_list_insert_tail(&pxmitbuf->list, &(pxmitpriv->free_xmit_extbuf_queue.queue));
#ifdef DBG_XMIT_BUF_EXT
pxmitbuf->no = i;
#endif
pxmitbuf++;
}
pxmitpriv->free_xmit_extbuf_cnt = num_xmit_extbuf;
exit:
;
}
#endif
u8
mpt_to_mgnt_rate(
u32 MptRateIdx
)
{
/* Mapped to MGN_XXX defined in MgntGen.h */
switch (MptRateIdx) {
/* CCK rate. */
case MPT_RATE_1M:
return MGN_1M;
case MPT_RATE_2M:
return MGN_2M;
case MPT_RATE_55M:
return MGN_5_5M;
case MPT_RATE_11M:
return MGN_11M;
/* OFDM rate. */
case MPT_RATE_6M:
return MGN_6M;
case MPT_RATE_9M:
return MGN_9M;
case MPT_RATE_12M:
return MGN_12M;
case MPT_RATE_18M:
return MGN_18M;
case MPT_RATE_24M:
return MGN_24M;
case MPT_RATE_36M:
return MGN_36M;
case MPT_RATE_48M:
return MGN_48M;
case MPT_RATE_54M:
return MGN_54M;
/* HT rate. */
case MPT_RATE_MCS0:
return MGN_MCS0;
case MPT_RATE_MCS1:
return MGN_MCS1;
case MPT_RATE_MCS2:
return MGN_MCS2;
case MPT_RATE_MCS3:
return MGN_MCS3;
case MPT_RATE_MCS4:
return MGN_MCS4;
case MPT_RATE_MCS5:
return MGN_MCS5;
case MPT_RATE_MCS6:
return MGN_MCS6;
case MPT_RATE_MCS7:
return MGN_MCS7;
case MPT_RATE_MCS8:
return MGN_MCS8;
case MPT_RATE_MCS9:
return MGN_MCS9;
case MPT_RATE_MCS10:
return MGN_MCS10;
case MPT_RATE_MCS11:
return MGN_MCS11;
case MPT_RATE_MCS12:
return MGN_MCS12;
case MPT_RATE_MCS13:
return MGN_MCS13;
case MPT_RATE_MCS14:
return MGN_MCS14;
case MPT_RATE_MCS15:
return MGN_MCS15;
case MPT_RATE_MCS16:
return MGN_MCS16;
case MPT_RATE_MCS17:
return MGN_MCS17;
case MPT_RATE_MCS18:
return MGN_MCS18;
case MPT_RATE_MCS19:
return MGN_MCS19;
case MPT_RATE_MCS20:
return MGN_MCS20;
case MPT_RATE_MCS21:
return MGN_MCS21;
case MPT_RATE_MCS22:
return MGN_MCS22;
case MPT_RATE_MCS23:
return MGN_MCS23;
case MPT_RATE_MCS24:
return MGN_MCS24;
case MPT_RATE_MCS25:
return MGN_MCS25;
case MPT_RATE_MCS26:
return MGN_MCS26;
case MPT_RATE_MCS27:
return MGN_MCS27;
case MPT_RATE_MCS28:
return MGN_MCS28;
case MPT_RATE_MCS29:
return MGN_MCS29;
case MPT_RATE_MCS30:
return MGN_MCS30;
case MPT_RATE_MCS31:
return MGN_MCS31;
/* VHT rate. */
case MPT_RATE_VHT1SS_MCS0:
return MGN_VHT1SS_MCS0;
case MPT_RATE_VHT1SS_MCS1:
return MGN_VHT1SS_MCS1;
case MPT_RATE_VHT1SS_MCS2:
return MGN_VHT1SS_MCS2;
case MPT_RATE_VHT1SS_MCS3:
return MGN_VHT1SS_MCS3;
case MPT_RATE_VHT1SS_MCS4:
return MGN_VHT1SS_MCS4;
case MPT_RATE_VHT1SS_MCS5:
return MGN_VHT1SS_MCS5;
case MPT_RATE_VHT1SS_MCS6:
return MGN_VHT1SS_MCS6;
case MPT_RATE_VHT1SS_MCS7:
return MGN_VHT1SS_MCS7;
case MPT_RATE_VHT1SS_MCS8:
return MGN_VHT1SS_MCS8;
case MPT_RATE_VHT1SS_MCS9:
return MGN_VHT1SS_MCS9;
case MPT_RATE_VHT2SS_MCS0:
return MGN_VHT2SS_MCS0;
case MPT_RATE_VHT2SS_MCS1:
return MGN_VHT2SS_MCS1;
case MPT_RATE_VHT2SS_MCS2:
return MGN_VHT2SS_MCS2;
case MPT_RATE_VHT2SS_MCS3:
return MGN_VHT2SS_MCS3;
case MPT_RATE_VHT2SS_MCS4:
return MGN_VHT2SS_MCS4;
case MPT_RATE_VHT2SS_MCS5:
return MGN_VHT2SS_MCS5;
case MPT_RATE_VHT2SS_MCS6:
return MGN_VHT2SS_MCS6;
case MPT_RATE_VHT2SS_MCS7:
return MGN_VHT2SS_MCS7;
case MPT_RATE_VHT2SS_MCS8:
return MGN_VHT2SS_MCS8;
case MPT_RATE_VHT2SS_MCS9:
return MGN_VHT2SS_MCS9;
case MPT_RATE_VHT3SS_MCS0:
return MGN_VHT3SS_MCS0;
case MPT_RATE_VHT3SS_MCS1:
return MGN_VHT3SS_MCS1;
case MPT_RATE_VHT3SS_MCS2:
return MGN_VHT3SS_MCS2;
case MPT_RATE_VHT3SS_MCS3:
return MGN_VHT3SS_MCS3;
case MPT_RATE_VHT3SS_MCS4:
return MGN_VHT3SS_MCS4;
case MPT_RATE_VHT3SS_MCS5:
return MGN_VHT3SS_MCS5;
case MPT_RATE_VHT3SS_MCS6:
return MGN_VHT3SS_MCS6;
case MPT_RATE_VHT3SS_MCS7:
return MGN_VHT3SS_MCS7;
case MPT_RATE_VHT3SS_MCS8:
return MGN_VHT3SS_MCS8;
case MPT_RATE_VHT3SS_MCS9:
return MGN_VHT3SS_MCS9;
case MPT_RATE_VHT4SS_MCS0:
return MGN_VHT4SS_MCS0;
case MPT_RATE_VHT4SS_MCS1:
return MGN_VHT4SS_MCS1;
case MPT_RATE_VHT4SS_MCS2:
return MGN_VHT4SS_MCS2;
case MPT_RATE_VHT4SS_MCS3:
return MGN_VHT4SS_MCS3;
case MPT_RATE_VHT4SS_MCS4:
return MGN_VHT4SS_MCS4;
case MPT_RATE_VHT4SS_MCS5:
return MGN_VHT4SS_MCS5;
case MPT_RATE_VHT4SS_MCS6:
return MGN_VHT4SS_MCS6;
case MPT_RATE_VHT4SS_MCS7:
return MGN_VHT4SS_MCS7;
case MPT_RATE_VHT4SS_MCS8:
return MGN_VHT4SS_MCS8;
case MPT_RATE_VHT4SS_MCS9:
return MGN_VHT4SS_MCS9;
case MPT_RATE_LAST: /* fully automatiMGN_VHT2SS_MCS1; */
default:
RTW_INFO("<===mpt_to_mgnt_rate(), Invalid Rate: %d!!\n", MptRateIdx);
return 0x0;
}
}
u8 HwRateToMPTRate(u8 rate)
{
u8 ret_rate = MGN_1M;
switch (rate) {
case DESC_RATE1M:
ret_rate = MPT_RATE_1M;
break;
case DESC_RATE2M:
ret_rate = MPT_RATE_2M;
break;
case DESC_RATE5_5M:
ret_rate = MPT_RATE_55M;
break;
case DESC_RATE11M:
ret_rate = MPT_RATE_11M;
break;
case DESC_RATE6M:
ret_rate = MPT_RATE_6M;
break;
case DESC_RATE9M:
ret_rate = MPT_RATE_9M;
break;
case DESC_RATE12M:
ret_rate = MPT_RATE_12M;
break;
case DESC_RATE18M:
ret_rate = MPT_RATE_18M;
break;
case DESC_RATE24M:
ret_rate = MPT_RATE_24M;
break;
case DESC_RATE36M:
ret_rate = MPT_RATE_36M;
break;
case DESC_RATE48M:
ret_rate = MPT_RATE_48M;
break;
case DESC_RATE54M:
ret_rate = MPT_RATE_54M;
break;
case DESC_RATEMCS0:
ret_rate = MPT_RATE_MCS0;
break;
case DESC_RATEMCS1:
ret_rate = MPT_RATE_MCS1;
break;
case DESC_RATEMCS2:
ret_rate = MPT_RATE_MCS2;
break;
case DESC_RATEMCS3:
ret_rate = MPT_RATE_MCS3;
break;
case DESC_RATEMCS4:
ret_rate = MPT_RATE_MCS4;
break;
case DESC_RATEMCS5:
ret_rate = MPT_RATE_MCS5;
break;
case DESC_RATEMCS6:
ret_rate = MPT_RATE_MCS6;
break;
case DESC_RATEMCS7:
ret_rate = MPT_RATE_MCS7;
break;
case DESC_RATEMCS8:
ret_rate = MPT_RATE_MCS8;
break;
case DESC_RATEMCS9:
ret_rate = MPT_RATE_MCS9;
break;
case DESC_RATEMCS10:
ret_rate = MPT_RATE_MCS10;
break;
case DESC_RATEMCS11:
ret_rate = MPT_RATE_MCS11;
break;
case DESC_RATEMCS12:
ret_rate = MPT_RATE_MCS12;
break;
case DESC_RATEMCS13:
ret_rate = MPT_RATE_MCS13;
break;
case DESC_RATEMCS14:
ret_rate = MPT_RATE_MCS14;
break;
case DESC_RATEMCS15:
ret_rate = MPT_RATE_MCS15;
break;
case DESC_RATEMCS16:
ret_rate = MPT_RATE_MCS16;
break;
case DESC_RATEMCS17:
ret_rate = MPT_RATE_MCS17;
break;
case DESC_RATEMCS18:
ret_rate = MPT_RATE_MCS18;
break;
case DESC_RATEMCS19:
ret_rate = MPT_RATE_MCS19;
break;
case DESC_RATEMCS20:
ret_rate = MPT_RATE_MCS20;
break;
case DESC_RATEMCS21:
ret_rate = MPT_RATE_MCS21;
break;
case DESC_RATEMCS22:
ret_rate = MPT_RATE_MCS22;
break;
case DESC_RATEMCS23:
ret_rate = MPT_RATE_MCS23;
break;
case DESC_RATEMCS24:
ret_rate = MPT_RATE_MCS24;
break;
case DESC_RATEMCS25:
ret_rate = MPT_RATE_MCS25;
break;
case DESC_RATEMCS26:
ret_rate = MPT_RATE_MCS26;
break;
case DESC_RATEMCS27:
ret_rate = MPT_RATE_MCS27;
break;
case DESC_RATEMCS28:
ret_rate = MPT_RATE_MCS28;
break;
case DESC_RATEMCS29:
ret_rate = MPT_RATE_MCS29;
break;
case DESC_RATEMCS30:
ret_rate = MPT_RATE_MCS30;
break;
case DESC_RATEMCS31:
ret_rate = MPT_RATE_MCS31;
break;
case DESC_RATEVHTSS1MCS0:
ret_rate = MPT_RATE_VHT1SS_MCS0;
break;
case DESC_RATEVHTSS1MCS1:
ret_rate = MPT_RATE_VHT1SS_MCS1;
break;
case DESC_RATEVHTSS1MCS2:
ret_rate = MPT_RATE_VHT1SS_MCS2;
break;
case DESC_RATEVHTSS1MCS3:
ret_rate = MPT_RATE_VHT1SS_MCS3;
break;
case DESC_RATEVHTSS1MCS4:
ret_rate = MPT_RATE_VHT1SS_MCS4;
break;
case DESC_RATEVHTSS1MCS5:
ret_rate = MPT_RATE_VHT1SS_MCS5;
break;
case DESC_RATEVHTSS1MCS6:
ret_rate = MPT_RATE_VHT1SS_MCS6;
break;
case DESC_RATEVHTSS1MCS7:
ret_rate = MPT_RATE_VHT1SS_MCS7;
break;
case DESC_RATEVHTSS1MCS8:
ret_rate = MPT_RATE_VHT1SS_MCS8;
break;
case DESC_RATEVHTSS1MCS9:
ret_rate = MPT_RATE_VHT1SS_MCS9;
break;
case DESC_RATEVHTSS2MCS0:
ret_rate = MPT_RATE_VHT2SS_MCS0;
break;
case DESC_RATEVHTSS2MCS1:
ret_rate = MPT_RATE_VHT2SS_MCS1;
break;
case DESC_RATEVHTSS2MCS2:
ret_rate = MPT_RATE_VHT2SS_MCS2;
break;
case DESC_RATEVHTSS2MCS3:
ret_rate = MPT_RATE_VHT2SS_MCS3;
break;
case DESC_RATEVHTSS2MCS4:
ret_rate = MPT_RATE_VHT2SS_MCS4;
break;
case DESC_RATEVHTSS2MCS5:
ret_rate = MPT_RATE_VHT2SS_MCS5;
break;
case DESC_RATEVHTSS2MCS6:
ret_rate = MPT_RATE_VHT2SS_MCS6;
break;
case DESC_RATEVHTSS2MCS7:
ret_rate = MPT_RATE_VHT2SS_MCS7;
break;
case DESC_RATEVHTSS2MCS8:
ret_rate = MPT_RATE_VHT2SS_MCS8;
break;
case DESC_RATEVHTSS2MCS9:
ret_rate = MPT_RATE_VHT2SS_MCS9;
break;
case DESC_RATEVHTSS3MCS0:
ret_rate = MPT_RATE_VHT3SS_MCS0;
break;
case DESC_RATEVHTSS3MCS1:
ret_rate = MPT_RATE_VHT3SS_MCS1;
break;
case DESC_RATEVHTSS3MCS2:
ret_rate = MPT_RATE_VHT3SS_MCS2;
break;
case DESC_RATEVHTSS3MCS3:
ret_rate = MPT_RATE_VHT3SS_MCS3;
break;
case DESC_RATEVHTSS3MCS4:
ret_rate = MPT_RATE_VHT3SS_MCS4;
break;
case DESC_RATEVHTSS3MCS5:
ret_rate = MPT_RATE_VHT3SS_MCS5;
break;
case DESC_RATEVHTSS3MCS6:
ret_rate = MPT_RATE_VHT3SS_MCS6;
break;
case DESC_RATEVHTSS3MCS7:
ret_rate = MPT_RATE_VHT3SS_MCS7;
break;
case DESC_RATEVHTSS3MCS8:
ret_rate = MPT_RATE_VHT3SS_MCS8;
break;
case DESC_RATEVHTSS3MCS9:
ret_rate = MPT_RATE_VHT3SS_MCS9;
break;
case DESC_RATEVHTSS4MCS0:
ret_rate = MPT_RATE_VHT4SS_MCS0;
break;
case DESC_RATEVHTSS4MCS1:
ret_rate = MPT_RATE_VHT4SS_MCS1;
break;
case DESC_RATEVHTSS4MCS2:
ret_rate = MPT_RATE_VHT4SS_MCS2;
break;
case DESC_RATEVHTSS4MCS3:
ret_rate = MPT_RATE_VHT4SS_MCS3;
break;
case DESC_RATEVHTSS4MCS4:
ret_rate = MPT_RATE_VHT4SS_MCS4;
break;
case DESC_RATEVHTSS4MCS5:
ret_rate = MPT_RATE_VHT4SS_MCS5;
break;
case DESC_RATEVHTSS4MCS6:
ret_rate = MPT_RATE_VHT4SS_MCS6;
break;
case DESC_RATEVHTSS4MCS7:
ret_rate = MPT_RATE_VHT4SS_MCS7;
break;
case DESC_RATEVHTSS4MCS8:
ret_rate = MPT_RATE_VHT4SS_MCS8;
break;
case DESC_RATEVHTSS4MCS9:
ret_rate = MPT_RATE_VHT4SS_MCS9;
break;
default:
RTW_INFO("hw_rate_to_m_rate(): Non supported Rate [%x]!!!\n", rate);
break;
}
return ret_rate;
}
u8 rtw_mpRateParseFunc(PADAPTER pAdapter, u8 *targetStr)
{
u16 i = 0;
u8 *rateindex_Array[] = { "1M", "2M", "5.5M", "11M", "6M", "9M", "12M", "18M", "24M", "36M", "48M", "54M",
"HTMCS0", "HTMCS1", "HTMCS2", "HTMCS3", "HTMCS4", "HTMCS5", "HTMCS6", "HTMCS7",
"HTMCS8", "HTMCS9", "HTMCS10", "HTMCS11", "HTMCS12", "HTMCS13", "HTMCS14", "HTMCS15",
"HTMCS16", "HTMCS17", "HTMCS18", "HTMCS19", "HTMCS20", "HTMCS21", "HTMCS22", "HTMCS23",
"HTMCS24", "HTMCS25", "HTMCS26", "HTMCS27", "HTMCS28", "HTMCS29", "HTMCS30", "HTMCS31",
"VHT1MCS0", "VHT1MCS1", "VHT1MCS2", "VHT1MCS3", "VHT1MCS4", "VHT1MCS5", "VHT1MCS6", "VHT1MCS7", "VHT1MCS8", "VHT1MCS9",
"VHT2MCS0", "VHT2MCS1", "VHT2MCS2", "VHT2MCS3", "VHT2MCS4", "VHT2MCS5", "VHT2MCS6", "VHT2MCS7", "VHT2MCS8", "VHT2MCS9",
"VHT3MCS0", "VHT3MCS1", "VHT3MCS2", "VHT3MCS3", "VHT3MCS4", "VHT3MCS5", "VHT3MCS6", "VHT3MCS7", "VHT3MCS8", "VHT3MCS9",
"VHT4MCS0", "VHT4MCS1", "VHT4MCS2", "VHT4MCS3", "VHT4MCS4", "VHT4MCS5", "VHT4MCS6", "VHT4MCS7", "VHT4MCS8", "VHT4MCS9"
};
for (i = 0; i <= 83; i++) {
if (strcmp(targetStr, rateindex_Array[i]) == 0) {
RTW_INFO("%s , index = %d\n", __func__ , i);
return i;
}
}
printk("%s ,please input a Data RATE String as:", __func__);
for (i = 0; i <= 83; i++) {
printk("%s ", rateindex_Array[i]);
if (i % 10 == 0)
printk("\n");
}
return _FAIL;
}
u8 rtw_mp_mode_check(PADAPTER pAdapter)
{
PADAPTER primary_adapter = GET_PRIMARY_ADAPTER(pAdapter);
if (primary_adapter->registrypriv.mp_mode == 1 || primary_adapter->mppriv.bprocess_mp_mode == _TRUE)
return _TRUE;
else
return _FALSE;
}
u32 mpt_ProQueryCalTxPower(
PADAPTER pAdapter,
u8 RfPath
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u32 TxPower = 1;
struct txpwr_idx_comp tic;
u8 mgn_rate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
TxPower = rtw_hal_get_tx_power_index(pAdapter, RfPath, mgn_rate, pHalData->current_channel_bw, pHalData->current_channel, &tic);
RTW_INFO("TXPWR: [%c][%s]ch:%u, %s %uT, pwr_idx:%u(0x%02x) = %u + (%d=%d:%d) + (%d) + (%d) + (%d) + (%d)\n"
, rf_path_char(RfPath), ch_width_str(pHalData->current_channel_bw), pHalData->current_channel, MGN_RATE_STR(mgn_rate), tic.ntx_idx + 1
, TxPower, TxPower, tic.pg, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate), tic.by_rate, tic.limit, tic.tpt
, tic.ebias, tic.btc, tic.dpd);
pAdapter->mppriv.txpoweridx = (u8)TxPower;
if (RfPath == RF_PATH_A)
pMptCtx->TxPwrLevel[RF_PATH_A] = (u8)TxPower;
else if (RfPath == RF_PATH_B)
pMptCtx->TxPwrLevel[RF_PATH_B] = (u8)TxPower;
else if (RfPath == RF_PATH_C)
pMptCtx->TxPwrLevel[RF_PATH_C] = (u8)TxPower;
else if (RfPath == RF_PATH_D)
pMptCtx->TxPwrLevel[RF_PATH_D] = (u8)TxPower;
hal_mpt_SetTxPower(pAdapter);
return TxPower;
}
#ifdef CONFIG_MP_VHT_HW_TX_MODE
static inline void dump_buf(u8 *buf, u32 len)
{
u32 i;
RTW_INFO("-----------------Len %d----------------\n", len);
for (i = 0; i < len; i++)
RTW_INFO("%2.2x-", *(buf + i));
RTW_INFO("\n");
}
void ByteToBit(
u8 *out,
bool *in,
u8 in_size)
{
u8 i = 0, j = 0;
for (i = 0; i < in_size; i++) {
for (j = 0; j < 8; j++) {
if (in[8 * i + j])
out[i] |= (1 << j);
}
}
}
void CRC16_generator(
bool *out,
bool *in,
u8 in_size
)
{
u8 i = 0;
bool temp = 0, reg[] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
for (i = 0; i < in_size; i++) {/* take one's complement and bit reverse*/
temp = in[i] ^ reg[15];
reg[15] = reg[14];
reg[14] = reg[13];
reg[13] = reg[12];
reg[12] = reg[11];
reg[11] = reg[10];
reg[10] = reg[9];
reg[9] = reg[8];
reg[8] = reg[7];
reg[7] = reg[6];
reg[6] = reg[5];
reg[5] = reg[4];
reg[4] = reg[3];
reg[3] = reg[2];
reg[2] = reg[1];
reg[1] = reg[0];
reg[12] = reg[12] ^ temp;
reg[5] = reg[5] ^ temp;
reg[0] = temp;
}
for (i = 0; i < 16; i++) /* take one's complement and bit reverse*/
out[i] = 1 - reg[15 - i];
}
/*========================================
SFD SIGNAL SERVICE LENGTH CRC
16 bit 8 bit 8 bit 16 bit 16 bit
========================================*/
void CCK_generator(
PRT_PMAC_TX_INFO pPMacTxInfo,
PRT_PMAC_PKT_INFO pPMacPktInfo
)
{
double ratio = 0;
bool crc16_in[32] = {0}, crc16_out[16] = {0};
bool LengthExtBit;
double LengthExact;
double LengthPSDU;
u8 i;
u32 PacketLength = pPMacTxInfo->PacketLength;
if (pPMacTxInfo->bSPreamble)
pPMacTxInfo->SFD = 0x05CF;
else
pPMacTxInfo->SFD = 0xF3A0;
switch (pPMacPktInfo->MCS) {
case 0:
pPMacTxInfo->SignalField = 0xA;
ratio = 8;
/*CRC16_in(1,0:7)=[0 1 0 1 0 0 0 0]*/
crc16_in[1] = crc16_in[3] = 1;
break;
case 1:
pPMacTxInfo->SignalField = 0x14;
ratio = 4;
/*CRC16_in(1,0:7)=[0 0 1 0 1 0 0 0];*/
crc16_in[2] = crc16_in[4] = 1;
break;
case 2:
pPMacTxInfo->SignalField = 0x37;
ratio = 8.0 / 5.5;
/*CRC16_in(1,0:7)=[1 1 1 0 1 1 0 0];*/
crc16_in[0] = crc16_in[1] = crc16_in[2] = crc16_in[4] = crc16_in[5] = 1;
break;
case 3:
pPMacTxInfo->SignalField = 0x6E;
ratio = 8.0 / 11.0;
/*CRC16_in(1,0:7)=[0 1 1 1 0 1 1 0];*/
crc16_in[1] = crc16_in[2] = crc16_in[3] = crc16_in[5] = crc16_in[6] = 1;
break;
}
LengthExact = PacketLength * ratio;
LengthPSDU = ceil(LengthExact);
if ((pPMacPktInfo->MCS == 3) &&
((LengthPSDU - LengthExact) >= 0.727 || (LengthPSDU - LengthExact) <= -0.727))
LengthExtBit = 1;
else
LengthExtBit = 0;
pPMacTxInfo->LENGTH = (u32)LengthPSDU;
/* CRC16_in(1,16:31) = LengthPSDU[0:15]*/
for (i = 0; i < 16; i++)
crc16_in[i + 16] = (pPMacTxInfo->LENGTH >> i) & 0x1;
if (LengthExtBit == 0) {
pPMacTxInfo->ServiceField = 0x0;
/* CRC16_in(1,8:15) = [0 0 0 0 0 0 0 0];*/
} else {
pPMacTxInfo->ServiceField = 0x80;
/*CRC16_in(1,8:15)=[0 0 0 0 0 0 0 1];*/
crc16_in[15] = 1;
}
CRC16_generator(crc16_out, crc16_in, 32);
_rtw_memset(pPMacTxInfo->CRC16, 0, 2);
ByteToBit(pPMacTxInfo->CRC16, crc16_out, 2);
}
void PMAC_Get_Pkt_Param(
PRT_PMAC_TX_INFO pPMacTxInfo,
PRT_PMAC_PKT_INFO pPMacPktInfo)
{
u8 TX_RATE_HEX = 0, MCS = 0;
u8 TX_RATE = pPMacTxInfo->TX_RATE;
/* TX_RATE & Nss */
if (MPT_IS_2SS_RATE(TX_RATE))
pPMacPktInfo->Nss = 2;
else if (MPT_IS_3SS_RATE(TX_RATE))
pPMacPktInfo->Nss = 3;
else if (MPT_IS_4SS_RATE(TX_RATE))
pPMacPktInfo->Nss = 4;
else
pPMacPktInfo->Nss = 1;
RTW_INFO("PMacTxInfo.Nss =%d\n", pPMacPktInfo->Nss);
/* MCS & TX_RATE_HEX*/
if (MPT_IS_CCK_RATE(TX_RATE)) {
switch (TX_RATE) {
case MPT_RATE_1M:
TX_RATE_HEX = MCS = 0;
break;
case MPT_RATE_2M:
TX_RATE_HEX = MCS = 1;
break;
case MPT_RATE_55M:
TX_RATE_HEX = MCS = 2;
break;
case MPT_RATE_11M:
TX_RATE_HEX = MCS = 3;
break;
}
} else if (MPT_IS_OFDM_RATE(TX_RATE)) {
MCS = TX_RATE - MPT_RATE_6M;
TX_RATE_HEX = MCS + 4;
} else if (MPT_IS_HT_RATE(TX_RATE)) {
MCS = TX_RATE - MPT_RATE_MCS0;
TX_RATE_HEX = MCS + 12;
} else if (MPT_IS_VHT_RATE(TX_RATE)) {
TX_RATE_HEX = TX_RATE - MPT_RATE_VHT1SS_MCS0 + 44;
if (MPT_IS_VHT_2S_RATE(TX_RATE))
MCS = TX_RATE - MPT_RATE_VHT2SS_MCS0;
else if (MPT_IS_VHT_3S_RATE(TX_RATE))
MCS = TX_RATE - MPT_RATE_VHT3SS_MCS0;
else if (MPT_IS_VHT_4S_RATE(TX_RATE))
MCS = TX_RATE - MPT_RATE_VHT4SS_MCS0;
else
MCS = TX_RATE - MPT_RATE_VHT1SS_MCS0;
}
pPMacPktInfo->MCS = MCS;
pPMacTxInfo->TX_RATE_HEX = TX_RATE_HEX;
RTW_INFO(" MCS=%d, TX_RATE_HEX =0x%x\n", MCS, pPMacTxInfo->TX_RATE_HEX);
/* mSTBC & Nsts*/
pPMacPktInfo->Nsts = pPMacPktInfo->Nss;
if (pPMacTxInfo->bSTBC) {
if (pPMacPktInfo->Nss == 1) {
pPMacTxInfo->m_STBC = 2;
pPMacPktInfo->Nsts = pPMacPktInfo->Nss * 2;
} else
pPMacTxInfo->m_STBC = 1;
} else
pPMacTxInfo->m_STBC = 1;
}
u32 LDPC_parameter_generator(
u32 N_pld_int,
u32 N_CBPSS,
u32 N_SS,
u32 R,
u32 m_STBC,
u32 N_TCB_int
)
{
double CR = 0.;
double N_pld = (double)N_pld_int;
double N_TCB = (double)N_TCB_int;
double N_CW = 0., N_shrt = 0., N_spcw = 0., N_fshrt = 0.;
double L_LDPC = 0., K_LDPC = 0., L_LDPC_info = 0.;
double N_punc = 0., N_ppcw = 0., N_fpunc = 0., N_rep = 0., N_rpcw = 0., N_frep = 0.;
double R_eff = 0.;
u32 VHTSIGA2B3 = 0;/* extra symbol from VHT-SIG-A2 Bit 3*/
if (R == 0)
CR = 0.5;
else if (R == 1)
CR = 2. / 3.;
else if (R == 2)
CR = 3. / 4.;
else if (R == 3)
CR = 5. / 6.;
if (N_TCB <= 648.) {
N_CW = 1.;
if (N_TCB >= N_pld + 912.*(1. - CR))
L_LDPC = 1296.;
else
L_LDPC = 648.;
} else if (N_TCB <= 1296.) {
N_CW = 1.;
if (N_TCB >= (double)N_pld + 1464.*(1. - CR))
L_LDPC = 1944.;
else
L_LDPC = 1296.;
} else if (N_TCB <= 1944.) {
N_CW = 1.;
L_LDPC = 1944.;
} else if (N_TCB <= 2592.) {
N_CW = 2.;
if (N_TCB >= N_pld + 2916.*(1. - CR))
L_LDPC = 1944.;
else
L_LDPC = 1296.;
} else {
N_CW = ceil(N_pld / 1944. / CR);
L_LDPC = 1944.;
}
/* Number of information bits per CW*/
K_LDPC = L_LDPC * CR;
/* Number of shortening bits max(0, (N_CW * L_LDPC * R) - N_pld)*/
N_shrt = (N_CW * K_LDPC - N_pld) > 0. ? (N_CW * K_LDPC - N_pld) : 0.;
/* Number of shortening bits per CW N_spcw = rtfloor(N_shrt/N_CW)*/
N_spcw = rtfloor(N_shrt / N_CW);
/* The first N_fshrt CWs shorten 1 bit more*/
N_fshrt = (double)((int)N_shrt % (int)N_CW);
/* Number of data bits for the last N_CW-N_fshrt CWs*/
L_LDPC_info = K_LDPC - N_spcw;
/* Number of puncturing bits*/
N_punc = (N_CW * L_LDPC - N_TCB - N_shrt) > 0. ? (N_CW * L_LDPC - N_TCB - N_shrt) : 0.;
if (((N_punc > .1 * N_CW * L_LDPC * (1. - CR)) && (N_shrt < 1.2 * N_punc * CR / (1. - CR))) ||
(N_punc > 0.3 * N_CW * L_LDPC * (1. - CR))) {
/*cout << "*** N_TCB and N_punc are Recomputed ***" << endl;*/
VHTSIGA2B3 = 1;
N_TCB += (double)N_CBPSS * N_SS * m_STBC;
N_punc = (N_CW * L_LDPC - N_TCB - N_shrt) > 0. ? (N_CW * L_LDPC - N_TCB - N_shrt) : 0.;
} else
VHTSIGA2B3 = 0;
return VHTSIGA2B3;
} /* function end of LDPC_parameter_generator */
/*========================================
Data field of PPDU
Get N_sym and SIGA2BB3
========================================*/
void PMAC_Nsym_generator(
PRT_PMAC_TX_INFO pPMacTxInfo,
PRT_PMAC_PKT_INFO pPMacPktInfo)
{
u32 SIGA2B3 = 0;
u8 TX_RATE = pPMacTxInfo->TX_RATE;
u32 R, R_list[10] = {0, 0, 2, 0, 2, 1, 2, 3, 2, 3};
double CR = 0;
u32 N_SD, N_BPSC_list[10] = {1, 2, 2, 4, 4, 6, 6, 6, 8, 8};
u32 N_BPSC = 0, N_CBPS = 0, N_DBPS = 0, N_ES = 0, N_SYM = 0, N_pld = 0, N_TCB = 0;
int D_R = 0;
RTW_INFO("TX_RATE = %d\n", TX_RATE);
/* N_SD*/
if (pPMacTxInfo->BandWidth == 0)
N_SD = 52;
else if (pPMacTxInfo->BandWidth == 1)
N_SD = 108;
else
N_SD = 234;
if (MPT_IS_HT_RATE(TX_RATE)) {
u8 MCS_temp;
if (pPMacPktInfo->MCS > 23)
MCS_temp = pPMacPktInfo->MCS - 24;
else if (pPMacPktInfo->MCS > 15)
MCS_temp = pPMacPktInfo->MCS - 16;
else if (pPMacPktInfo->MCS > 7)
MCS_temp = pPMacPktInfo->MCS - 8;
else
MCS_temp = pPMacPktInfo->MCS;
R = R_list[MCS_temp];
switch (R) {
case 0:
CR = .5;
break;
case 1:
CR = 2. / 3.;
break;
case 2:
CR = 3. / 4.;
break;
case 3:
CR = 5. / 6.;
break;
}
N_BPSC = N_BPSC_list[MCS_temp];
N_CBPS = N_BPSC * N_SD * pPMacPktInfo->Nss;
N_DBPS = (u32)((double)N_CBPS * CR);
if (pPMacTxInfo->bLDPC == FALSE) {
N_ES = (u32)ceil((double)(N_DBPS * pPMacPktInfo->Nss) / 4. / 300.);
RTW_INFO("N_ES = %d\n", N_ES);
/* N_SYM = m_STBC* (8*length+16+6*N_ES) / (m_STBC*N_DBPS)*/
N_SYM = pPMacTxInfo->m_STBC * (u32)ceil((double)(pPMacTxInfo->PacketLength * 8 + 16 + N_ES * 6) /
(double)(N_DBPS * pPMacTxInfo->m_STBC));
} else {
N_ES = 1;
/* N_pld = length * 8 + 16*/
N_pld = pPMacTxInfo->PacketLength * 8 + 16;
RTW_INFO("N_pld = %d\n", N_pld);
N_SYM = pPMacTxInfo->m_STBC * (u32)ceil((double)(N_pld) /
(double)(N_DBPS * pPMacTxInfo->m_STBC));
RTW_INFO("N_SYM = %d\n", N_SYM);
/* N_avbits = N_CBPS *m_STBC *(N_pld/N_CBPS*R*m_STBC)*/
N_TCB = N_CBPS * N_SYM;
RTW_INFO("N_TCB = %d\n", N_TCB);
SIGA2B3 = LDPC_parameter_generator(N_pld, N_CBPS, pPMacPktInfo->Nss, R, pPMacTxInfo->m_STBC, N_TCB);
RTW_INFO("SIGA2B3 = %d\n", SIGA2B3);
N_SYM = N_SYM + SIGA2B3 * pPMacTxInfo->m_STBC;
RTW_INFO("N_SYM = %d\n", N_SYM);
}
} else if (MPT_IS_VHT_RATE(TX_RATE)) {
R = R_list[pPMacPktInfo->MCS];
switch (R) {
case 0:
CR = .5;
break;
case 1:
CR = 2. / 3.;
break;
case 2:
CR = 3. / 4.;
break;
case 3:
CR = 5. / 6.;
break;
}
N_BPSC = N_BPSC_list[pPMacPktInfo->MCS];
N_CBPS = N_BPSC * N_SD * pPMacPktInfo->Nss;
N_DBPS = (u32)((double)N_CBPS * CR);
if (pPMacTxInfo->bLDPC == FALSE) {
if (pPMacTxInfo->bSGI)
N_ES = (u32)ceil((double)(N_DBPS) / 3.6 / 600.);
else
N_ES = (u32)ceil((double)(N_DBPS) / 4. / 600.);
/* N_SYM = m_STBC* (8*length+16+6*N_ES) / (m_STBC*N_DBPS)*/
N_SYM = pPMacTxInfo->m_STBC * (u32)ceil((double)(pPMacTxInfo->PacketLength * 8 + 16 + N_ES * 6) / (double)(N_DBPS * pPMacTxInfo->m_STBC));
SIGA2B3 = 0;
} else {
N_ES = 1;
/* N_SYM = m_STBC* (8*length+N_service) / (m_STBC*N_DBPS)*/
N_SYM = pPMacTxInfo->m_STBC * (u32)ceil((double)(pPMacTxInfo->PacketLength * 8 + 16) / (double)(N_DBPS * pPMacTxInfo->m_STBC));
/* N_avbits = N_sys_init * N_CBPS*/
N_TCB = N_CBPS * N_SYM;
/* N_pld = N_sys_init * N_DBPS*/
N_pld = N_SYM * N_DBPS;
SIGA2B3 = LDPC_parameter_generator(N_pld, N_CBPS, pPMacPktInfo->Nss, R, pPMacTxInfo->m_STBC, N_TCB);
N_SYM = N_SYM + SIGA2B3 * pPMacTxInfo->m_STBC;
}
switch (R) {
case 0:
D_R = 2;
break;
case 1:
D_R = 3;
break;
case 2:
D_R = 4;
break;
case 3:
D_R = 6;
break;
}
if (((N_CBPS / N_ES) % D_R) != 0) {
RTW_INFO("MCS= %d is not supported when Nss=%d and BW= %d !!\n", pPMacPktInfo->MCS, pPMacPktInfo->Nss, pPMacTxInfo->BandWidth);
return;
}
RTW_INFO("MCS= %d Nss=%d and BW= %d !!\n", pPMacPktInfo->MCS, pPMacPktInfo->Nss, pPMacTxInfo->BandWidth);
}
pPMacPktInfo->N_sym = N_SYM;
pPMacPktInfo->SIGA2B3 = SIGA2B3;
}
/*========================================
L-SIG Rate R Length P Tail
4b 1b 12b 1b 6b
========================================*/
void L_SIG_generator(
u32 N_SYM, /* Max: 750*/
PRT_PMAC_TX_INFO pPMacTxInfo,
PRT_PMAC_PKT_INFO pPMacPktInfo)
{
u8 sig_bi[24] = {0}; /* 24 BIT*/
u32 mode, LENGTH;
int i;
if (MPT_IS_OFDM_RATE(pPMacTxInfo->TX_RATE)) {
mode = pPMacPktInfo->MCS;
LENGTH = pPMacTxInfo->PacketLength;
} else {
u8 N_LTF;
double T_data;
u32 OFDM_symbol;
mode = 0;
/* Table 20-13 Num of HT-DLTFs request*/
if (pPMacPktInfo->Nsts <= 2)
N_LTF = pPMacPktInfo->Nsts;
else
N_LTF = 4;
if (pPMacTxInfo->bSGI)
T_data = 3.6;
else
T_data = 4.0;
/*(L-SIG, HT-SIG, HT-STF, HT-LTF....HT-LTF, Data)*/
if (MPT_IS_VHT_RATE(pPMacTxInfo->TX_RATE))
OFDM_symbol = (u32)ceil((double)(8 + 4 + N_LTF * 4 + N_SYM * T_data + 4) / 4.);
else
OFDM_symbol = (u32)ceil((double)(8 + 4 + N_LTF * 4 + N_SYM * T_data) / 4.);
RTW_INFO("%s , OFDM_symbol =%d\n", __func__, OFDM_symbol);
LENGTH = OFDM_symbol * 3 - 3;
RTW_INFO("%s , LENGTH =%d\n", __func__, LENGTH);
}
/* Rate Field*/
switch (mode) {
case 0:
sig_bi[0] = 1;
sig_bi[1] = 1;
sig_bi[2] = 0;
sig_bi[3] = 1;
break;
case 1:
sig_bi[0] = 1;
sig_bi[1] = 1;
sig_bi[2] = 1;
sig_bi[3] = 1;
break;
case 2:
sig_bi[0] = 0;
sig_bi[1] = 1;
sig_bi[2] = 0;
sig_bi[3] = 1;
break;
case 3:
sig_bi[0] = 0;
sig_bi[1] = 1;
sig_bi[2] = 1;
sig_bi[3] = 1;
break;
case 4:
sig_bi[0] = 1;
sig_bi[1] = 0;
sig_bi[2] = 0;
sig_bi[3] = 1;
break;
case 5:
sig_bi[0] = 1;
sig_bi[1] = 0;
sig_bi[2] = 1;
sig_bi[3] = 1;
break;
case 6:
sig_bi[0] = 0;
sig_bi[1] = 0;
sig_bi[2] = 0;
sig_bi[3] = 1;
break;
case 7:
sig_bi[0] = 0;
sig_bi[1] = 0;
sig_bi[2] = 1;
sig_bi[3] = 1;
break;
}
/*Reserved bit*/
sig_bi[4] = 0;
/* Length Field*/
for (i = 0; i < 12; i++)
sig_bi[i + 5] = (LENGTH >> i) & 1;
/* Parity Bit*/
sig_bi[17] = 0;
for (i = 0; i < 17; i++)
sig_bi[17] = sig_bi[17] + sig_bi[i];
sig_bi[17] %= 2;
/* Tail Field*/
for (i = 18; i < 24; i++)
sig_bi[i] = 0;
/* dump_buf(sig_bi,24);*/
_rtw_memset(pPMacTxInfo->LSIG, 0, 3);
ByteToBit(pPMacTxInfo->LSIG, (bool *)sig_bi, 3);
}
void CRC8_generator(
bool *out,
bool *in,
u8 in_size
)
{
u8 i = 0;
bool temp = 0, reg[] = {1, 1, 1, 1, 1, 1, 1, 1};
for (i = 0; i < in_size; i++) { /* take one's complement and bit reverse*/
temp = in[i] ^ reg[7];
reg[7] = reg[6];
reg[6] = reg[5];
reg[5] = reg[4];
reg[4] = reg[3];
reg[3] = reg[2];
reg[2] = reg[1] ^ temp;
reg[1] = reg[0] ^ temp;
reg[0] = temp;
}
for (i = 0; i < 8; i++)/* take one's complement and bit reverse*/
out[i] = reg[7 - i] ^ 1;
}
/*/================================================================================
HT-SIG1 MCS CW Length 24BIT + 24BIT
7b 1b 16b
HT-SIG2 Smoothing Not sounding Rsvd AGG STBC FEC SGI N_ELTF CRC Tail
1b 1b 1b 1b 2b 1b 1b 2b 8b 6b
================================================================================*/
void HT_SIG_generator(
PRT_PMAC_TX_INFO pPMacTxInfo,
PRT_PMAC_PKT_INFO pPMacPktInfo
)
{
u32 i;
bool sig_bi[48] = {0}, crc8[8] = {0};
/* MCS Field*/
for (i = 0; i < 7; i++)
sig_bi[i] = (pPMacPktInfo->MCS >> i) & 0x1;
/* Packet BW Setting*/
sig_bi[7] = pPMacTxInfo->BandWidth;
/* HT-Length Field*/
for (i = 0; i < 16; i++)
sig_bi[i + 8] = (pPMacTxInfo->PacketLength >> i) & 0x1;
/* Smoothing; 1->allow smoothing*/
sig_bi[24] = 1;
/*Not Sounding*/
sig_bi[25] = 1 - pPMacTxInfo->NDP_sound;
/*Reserved bit*/
sig_bi[26] = 1;
/*/Aggregate*/
sig_bi[27] = 0;
/*STBC Field*/
if (pPMacTxInfo->bSTBC) {
sig_bi[28] = 1;
sig_bi[29] = 0;
} else {
sig_bi[28] = 0;
sig_bi[29] = 0;
}
/*Advance Coding, 0: BCC, 1: LDPC*/
sig_bi[30] = pPMacTxInfo->bLDPC;
/* Short GI*/
sig_bi[31] = pPMacTxInfo->bSGI;
/* N_ELTFs*/
if (pPMacTxInfo->NDP_sound == FALSE) {
sig_bi[32] = 0;
sig_bi[33] = 0;
} else {
int N_ELTF = pPMacTxInfo->Ntx - pPMacPktInfo->Nss;
for (i = 0; i < 2; i++)
sig_bi[32 + i] = (N_ELTF >> i) % 2;
}
/* CRC-8*/
CRC8_generator(crc8, sig_bi, 34);
for (i = 0; i < 8; i++)
sig_bi[34 + i] = crc8[i];
/*Tail*/
for (i = 42; i < 48; i++)
sig_bi[i] = 0;
_rtw_memset(pPMacTxInfo->HT_SIG, 0, 6);
ByteToBit(pPMacTxInfo->HT_SIG, sig_bi, 6);
}
/*======================================================================================
VHT-SIG-A1
BW Reserved STBC G_ID SU_Nsts P_AID TXOP_PS_NOT_ALLOW Reserved
2b 1b 1b 6b 3b 9b 1b 2b 1b
VHT-SIG-A2
SGI SGI_Nsym SU/MU coding LDPC_Extra SU_NCS Beamformed Reserved CRC Tail
1b 1b 1b 1b 4b 1b 1b 8b 6b
======================================================================================*/
void VHT_SIG_A_generator(
PRT_PMAC_TX_INFO pPMacTxInfo,
PRT_PMAC_PKT_INFO pPMacPktInfo)
{
u32 i;
bool sig_bi[48], crc8[8];
_rtw_memset(sig_bi, 0, 48);
_rtw_memset(crc8, 0, 8);
/* BW Setting*/
for (i = 0; i < 2; i++)
sig_bi[i] = (pPMacTxInfo->BandWidth >> i) & 0x1;
/* Reserved Bit*/
sig_bi[2] = 1;
/*STBC Field*/
sig_bi[3] = pPMacTxInfo->bSTBC;
/*Group ID: Single User->A value of 0 or 63 indicates an SU PPDU. */
for (i = 0; i < 6; i++)
sig_bi[4 + i] = 0;
/* N_STS/Partial AID*/
for (i = 0; i < 12; i++) {
if (i < 3)
sig_bi[10 + i] = ((pPMacPktInfo->Nsts - 1) >> i) & 0x1;
else
sig_bi[10 + i] = 0;
}
/*TXOP_PS_NOT_ALLPWED*/
sig_bi[22] = 0;
/*Reserved Bits*/
sig_bi[23] = 1;
/*Short GI*/
sig_bi[24] = pPMacTxInfo->bSGI;
if (pPMacTxInfo->bSGI > 0 && (pPMacPktInfo->N_sym % 10) == 9)
sig_bi[25] = 1;
else
sig_bi[25] = 0;
/* SU/MU[0] Coding*/
sig_bi[26] = pPMacTxInfo->bLDPC; /* 0:BCC, 1:LDPC */
sig_bi[27] = pPMacPktInfo->SIGA2B3; /*/ Record Extra OFDM Symols is added or not when LDPC is used*/
/*SU MCS/MU[1-3] Coding*/
for (i = 0; i < 4; i++)
sig_bi[28 + i] = (pPMacPktInfo->MCS >> i) & 0x1;
/*SU Beamform */
sig_bi[32] = 0; /*packet.TXBF_en;*/
/*Reserved Bit*/
sig_bi[33] = 1;
/*CRC-8*/
CRC8_generator(crc8, sig_bi, 34);
for (i = 0; i < 8; i++)
sig_bi[34 + i] = crc8[i];
/*Tail*/
for (i = 42; i < 48; i++)
sig_bi[i] = 0;
_rtw_memset(pPMacTxInfo->VHT_SIG_A, 0, 6);
ByteToBit(pPMacTxInfo->VHT_SIG_A, sig_bi, 6);
}
/*======================================================================================
VHT-SIG-B
Length Resesrved Trail
17/19/21 BIT 3/2/2 BIT 6b
======================================================================================*/
void VHT_SIG_B_generator(
PRT_PMAC_TX_INFO pPMacTxInfo)
{
bool sig_bi[32], crc8_bi[8];
u32 i, len, res, tail = 6, total_len, crc8_in_len;
u32 sigb_len;
_rtw_memset(sig_bi, 0, 32);
_rtw_memset(crc8_bi, 0, 8);
/*Sounding Packet*/
if (pPMacTxInfo->NDP_sound == 1) {
if (pPMacTxInfo->BandWidth == 0) {
bool sigb_temp[26] = {0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0};
_rtw_memcpy(sig_bi, sigb_temp, 26);
} else if (pPMacTxInfo->BandWidth == 1) {
bool sigb_temp[27] = {1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0};
_rtw_memcpy(sig_bi, sigb_temp, 27);
} else if (pPMacTxInfo->BandWidth == 2) {
bool sigb_temp[29] = {0, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0};
_rtw_memcpy(sig_bi, sigb_temp, 29);
}
} else { /* Not NDP Sounding*/
bool *sigb_temp[29] = {0};
if (pPMacTxInfo->BandWidth == 0) {
len = 17;
res = 3;
} else if (pPMacTxInfo->BandWidth == 1) {
len = 19;
res = 2;
} else if (pPMacTxInfo->BandWidth == 2) {
len = 21;
res = 2;
} else {
len = 21;
res = 2;
}
total_len = len + res + tail;
crc8_in_len = len + res;
/*Length Field*/
sigb_len = (pPMacTxInfo->PacketLength + 3) >> 2;
for (i = 0; i < len; i++)
sig_bi[i] = (sigb_len >> i) & 0x1;
/*Reserved Field*/
for (i = 0; i < res; i++)
sig_bi[len + i] = 1;
/* CRC-8*/
CRC8_generator(crc8_bi, sig_bi, crc8_in_len);
/* Tail */
for (i = 0; i < tail; i++)
sig_bi[len + res + i] = 0;
}
_rtw_memset(pPMacTxInfo->VHT_SIG_B, 0, 4);
ByteToBit(pPMacTxInfo->VHT_SIG_B, sig_bi, 4);
pPMacTxInfo->VHT_SIG_B_CRC = 0;
ByteToBit(&(pPMacTxInfo->VHT_SIG_B_CRC), crc8_bi, 1);
}
/*=======================
VHT Delimiter
=======================*/
void VHT_Delimiter_generator(
PRT_PMAC_TX_INFO pPMacTxInfo
)
{
bool sig_bi[32] = {0}, crc8[8] = {0};
u32 crc8_in_len = 16;
u32 PacketLength = pPMacTxInfo->PacketLength;
int j;
/* Delimiter[0]: EOF*/
sig_bi[0] = 1;
/* Delimiter[1]: Reserved*/
sig_bi[1] = 0;
/* Delimiter[3:2]: MPDU Length High*/
sig_bi[2] = ((PacketLength - 4) >> 12) % 2;
sig_bi[3] = ((PacketLength - 4) >> 13) % 2;
/* Delimiter[15:4]: MPDU Length Low*/
for (j = 4; j < 16; j++)
sig_bi[j] = ((PacketLength - 4) >> (j - 4)) % 2;
CRC8_generator(crc8, sig_bi, crc8_in_len);
for (j = 16; j < 24; j++) /* Delimiter[23:16]: CRC 8*/
sig_bi[j] = crc8[j - 16];
for (j = 24; j < 32; j++) /* Delimiter[31:24]: Signature ('4E' in Hex, 78 in Dec)*/
sig_bi[j] = (78 >> (j - 24)) % 2;
_rtw_memset(pPMacTxInfo->VHT_Delimiter, 0, 4);
ByteToBit(pPMacTxInfo->VHT_Delimiter, sig_bi, 4);
}
#endif
#endif
================================================
FILE: core/rtw_odm.c
================================================
/******************************************************************************
*
* Copyright(c) 2013 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
u32 rtw_phydm_ability_ops(_adapter *adapter, HAL_PHYDM_OPS ops, u32 ability)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
struct dm_struct *podmpriv = &pHalData->odmpriv;
u32 result = 0;
switch (ops) {
case HAL_PHYDM_DIS_ALL_FUNC:
podmpriv->support_ability = DYNAMIC_FUNC_DISABLE;
halrf_cmn_info_set(podmpriv, HALRF_CMNINFO_ABILITY, DYNAMIC_FUNC_DISABLE);
break;
case HAL_PHYDM_FUNC_SET:
podmpriv->support_ability |= ability;
break;
case HAL_PHYDM_FUNC_CLR:
podmpriv->support_ability &= ~(ability);
break;
case HAL_PHYDM_ABILITY_BK:
/* dm flag backup*/
podmpriv->bk_support_ability = podmpriv->support_ability;
pHalData->bk_rf_ability = halrf_cmn_info_get(podmpriv, HALRF_CMNINFO_ABILITY);
break;
case HAL_PHYDM_ABILITY_RESTORE:
/* restore dm flag */
podmpriv->support_ability = podmpriv->bk_support_ability;
halrf_cmn_info_set(podmpriv, HALRF_CMNINFO_ABILITY, pHalData->bk_rf_ability);
break;
case HAL_PHYDM_ABILITY_SET:
podmpriv->support_ability = ability;
break;
case HAL_PHYDM_ABILITY_GET:
result = podmpriv->support_ability;
break;
}
return result;
}
/* set ODM_CMNINFO_IC_TYPE based on chip_type */
void rtw_odm_init_ic_type(_adapter *adapter)
{
struct dm_struct *odm = adapter_to_phydm(adapter);
u32 ic_type = chip_type_to_odm_ic_type(rtw_get_chip_type(adapter));
rtw_warn_on(!ic_type);
odm_cmn_info_init(odm, ODM_CMNINFO_IC_TYPE, ic_type);
}
void rtw_odm_adaptivity_ver_msg(void *sel, _adapter *adapter)
{
RTW_PRINT_SEL(sel, "ADAPTIVITY_VERSION "ADAPTIVITY_VERSION"\n");
}
#define RTW_ADAPTIVITY_EN_DISABLE 0
#define RTW_ADAPTIVITY_EN_ENABLE 1
void rtw_odm_adaptivity_en_msg(void *sel, _adapter *adapter)
{
struct registry_priv *regsty = &adapter->registrypriv;
RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_EN_");
if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_DISABLE)
_RTW_PRINT_SEL(sel, "DISABLE\n");
else if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE)
_RTW_PRINT_SEL(sel, "ENABLE\n");
else
_RTW_PRINT_SEL(sel, "INVALID\n");
}
#define RTW_ADAPTIVITY_MODE_NORMAL 0
#define RTW_ADAPTIVITY_MODE_CARRIER_SENSE 1
void rtw_odm_adaptivity_mode_msg(void *sel, _adapter *adapter)
{
struct registry_priv *regsty = &adapter->registrypriv;
RTW_PRINT_SEL(sel, "RTW_ADAPTIVITY_MODE_");
if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_NORMAL)
_RTW_PRINT_SEL(sel, "NORMAL\n");
else if (regsty->adaptivity_mode == RTW_ADAPTIVITY_MODE_CARRIER_SENSE)
_RTW_PRINT_SEL(sel, "CARRIER_SENSE\n");
else
_RTW_PRINT_SEL(sel, "INVALID\n");
}
void rtw_odm_adaptivity_config_msg(void *sel, _adapter *adapter)
{
rtw_odm_adaptivity_ver_msg(sel, adapter);
rtw_odm_adaptivity_en_msg(sel, adapter);
rtw_odm_adaptivity_mode_msg(sel, adapter);
}
bool rtw_odm_adaptivity_needed(_adapter *adapter)
{
struct registry_priv *regsty = &adapter->registrypriv;
bool ret = _FALSE;
if (regsty->adaptivity_en == RTW_ADAPTIVITY_EN_ENABLE)
ret = _TRUE;
return ret;
}
void rtw_odm_adaptivity_parm_msg(void *sel, _adapter *adapter)
{
struct dm_struct *odm = adapter_to_phydm(adapter);
rtw_odm_adaptivity_config_msg(sel, adapter);
RTW_PRINT_SEL(sel, "%10s %16s\n"
, "th_l2h_ini", "th_edcca_hl_diff");
RTW_PRINT_SEL(sel, "0x%-8x %-16d\n"
, (u8)odm->th_l2h_ini
, odm->th_edcca_hl_diff
);
}
void rtw_odm_adaptivity_parm_set(_adapter *adapter, s8 th_l2h_ini, s8 th_edcca_hl_diff)
{
struct dm_struct *odm = adapter_to_phydm(adapter);
odm->th_l2h_ini = th_l2h_ini;
odm->th_edcca_hl_diff = th_edcca_hl_diff;
}
void rtw_odm_get_perpkt_rssi(void *sel, _adapter *adapter)
{
struct dm_struct *odm = adapter_to_phydm(adapter);
RTW_PRINT_SEL(sel, "rx_rate = %s, rssi_a = %d(%%), rssi_b = %d(%%)\n",
HDATA_RATE(odm->rx_rate), odm->rssi_a, odm->rssi_b);
}
void rtw_odm_acquirespinlock(_adapter *adapter, enum rt_spinlock_type type)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
_irqL irqL;
switch (type) {
case RT_IQK_SPINLOCK:
_enter_critical_bh(&pHalData->IQKSpinLock, &irqL);
default:
break;
}
}
void rtw_odm_releasespinlock(_adapter *adapter, enum rt_spinlock_type type)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
_irqL irqL;
switch (type) {
case RT_IQK_SPINLOCK:
_exit_critical_bh(&pHalData->IQKSpinLock, &irqL);
default:
break;
}
}
inline u8 rtw_odm_get_dfs_domain(struct dvobj_priv *dvobj)
{
#ifdef CONFIG_DFS_MASTER
struct dm_struct *pDM_Odm = dvobj_to_phydm(dvobj);
return pDM_Odm->dfs_region_domain;
#else
return PHYDM_DFS_DOMAIN_UNKNOWN;
#endif
}
inline u8 rtw_odm_dfs_domain_unknown(struct dvobj_priv *dvobj)
{
#ifdef CONFIG_DFS_MASTER
return rtw_odm_get_dfs_domain(dvobj) == PHYDM_DFS_DOMAIN_UNKNOWN;
#else
return 1;
#endif
}
#ifdef CONFIG_DFS_MASTER
inline void rtw_odm_radar_detect_reset(_adapter *adapter)
{
phydm_radar_detect_reset(adapter_to_phydm(adapter));
}
inline void rtw_odm_radar_detect_disable(_adapter *adapter)
{
phydm_radar_detect_disable(adapter_to_phydm(adapter));
}
/* called after ch, bw is set */
inline void rtw_odm_radar_detect_enable(_adapter *adapter)
{
phydm_radar_detect_enable(adapter_to_phydm(adapter));
}
inline BOOLEAN rtw_odm_radar_detect(_adapter *adapter)
{
return phydm_radar_detect(adapter_to_phydm(adapter));
}
inline u8 rtw_odm_radar_detect_polling_int_ms(struct dvobj_priv *dvobj)
{
return phydm_dfs_polling_time(dvobj_to_phydm(dvobj));
}
#endif /* CONFIG_DFS_MASTER */
void rtw_odm_parse_rx_phy_status_chinfo(union recv_frame *rframe, u8 *phys)
{
#ifndef DBG_RX_PHYSTATUS_CHINFO
#define DBG_RX_PHYSTATUS_CHINFO 0
#endif
#if (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1)
_adapter *adapter = rframe->u.hdr.adapter;
struct dm_struct *phydm = adapter_to_phydm(adapter);
struct rx_pkt_attrib *attrib = &rframe->u.hdr.attrib;
u8 *wlanhdr = get_recvframe_data(rframe);
if (phydm->support_ic_type & PHYSTS_2ND_TYPE_IC) {
/*
* 8723D:
* type_0(CCK)
* l_rxsc
* is filled with primary channel SC, not real rxsc.
* 0:LSC, 1:USC
* type_1(OFDM)
* rf_mode
* RF bandwidth when RX
* l_rxsc(legacy), ht_rxsc
* see below RXSC N-series
* type_2(Not used)
*/
/*
* 8821C, 8822B:
* type_0(CCK)
* l_rxsc
* is filled with primary channel SC, not real rxsc.
* 0:LSC, 1:USC
* type_1(OFDM)
* rf_mode
* RF bandwidth when RX
* l_rxsc(legacy), ht_rxsc
* see below RXSC AC-series
* type_2(Not used)
*/
if ((*phys & 0xf) == 0) {
struct phy_sts_rpt_jgr2_type0 *phys_t0 = (struct phy_sts_rpt_jgr2_type0 *)phys;
if (DBG_RX_PHYSTATUS_CHINFO) {
RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u)\n"
, *phys & 0xf
, MAC_ARG(get_ta(wlanhdr))
, is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
, HDATA_RATE(attrib->data_rate)
, phys_t0->band, phys_t0->channel, phys_t0->rxsc
);
}
} else if ((*phys & 0xf) == 1) {
struct phy_sts_rpt_jgr2_type1 *phys_t1 = (struct phy_sts_rpt_jgr2_type1 *)phys;
u8 rxsc = (attrib->data_rate > DESC_RATE11M && attrib->data_rate < DESC_RATEMCS0) ? phys_t1->l_rxsc : phys_t1->ht_rxsc;
u8 pkt_cch = 0;
u8 pkt_bw = CHANNEL_WIDTH_20;
#if ODM_IC_11N_SERIES_SUPPORT
if (phydm->support_ic_type & ODM_IC_11N_SERIES) {
/* RXSC N-series */
#define RXSC_DUP 0
#define RXSC_LSC 1
#define RXSC_USC 2
#define RXSC_40M 3
static const s8 cch_offset_by_rxsc[4] = {0, -2, 2, 0};
if (phys_t1->rf_mode == 0) {
pkt_cch = phys_t1->channel;
pkt_bw = CHANNEL_WIDTH_20;
} else if (phys_t1->rf_mode == 1) {
if (rxsc == RXSC_LSC || rxsc == RXSC_USC) {
pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
pkt_bw = CHANNEL_WIDTH_20;
} else if (rxsc == RXSC_40M) {
pkt_cch = phys_t1->channel;
pkt_bw = CHANNEL_WIDTH_40;
}
} else
rtw_warn_on(1);
goto type1_end;
}
#endif /* ODM_IC_11N_SERIES_SUPPORT */
#if ODM_IC_11AC_SERIES_SUPPORT
if (phydm->support_ic_type & ODM_IC_11AC_SERIES) {
/* RXSC AC-series */
#define RXSC_DUP 0 /* 0: RX from all SC of current rf_mode */
#define RXSC_LL20M_OF_160M 8 /* 1~8: RX from 20MHz SC */
#define RXSC_L20M_OF_160M 6
#define RXSC_L20M_OF_80M 4
#define RXSC_L20M_OF_40M 2
#define RXSC_U20M_OF_40M 1
#define RXSC_U20M_OF_80M 3
#define RXSC_U20M_OF_160M 5
#define RXSC_UU20M_OF_160M 7
#define RXSC_L40M_OF_160M 12 /* 9~12: RX from 40MHz SC */
#define RXSC_L40M_OF_80M 10
#define RXSC_U40M_OF_80M 9
#define RXSC_U40M_OF_160M 11
#define RXSC_L80M_OF_160M 14 /* 13~14: RX from 80MHz SC */
#define RXSC_U80M_OF_160M 13
static const s8 cch_offset_by_rxsc[15] = {0, 2, -2, 6, -6, 10, -10, 14, -14, 4, -4, 12, -12, 8, -8};
if (phys_t1->rf_mode > 3) {
/* invalid rf_mode */
rtw_warn_on(1);
goto type1_end;
}
if (phys_t1->rf_mode == 0) {
/* RF 20MHz */
pkt_cch = phys_t1->channel;
pkt_bw = CHANNEL_WIDTH_20;
goto type1_end;
}
if (rxsc == 0) {
/* RF and RX with same BW */
if (attrib->data_rate >= DESC_RATEMCS0) {
pkt_cch = phys_t1->channel;
pkt_bw = phys_t1->rf_mode;
}
goto type1_end;
}
if ((phys_t1->rf_mode == 1 && rxsc >= 1 && rxsc <= 2) /* RF 40MHz, RX 20MHz */
|| (phys_t1->rf_mode == 2 && rxsc >= 1 && rxsc <= 4) /* RF 80MHz, RX 20MHz */
|| (phys_t1->rf_mode == 3 && rxsc >= 1 && rxsc <= 8) /* RF 160MHz, RX 20MHz */
) {
pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
pkt_bw = CHANNEL_WIDTH_20;
} else if ((phys_t1->rf_mode == 2 && rxsc >= 9 && rxsc <= 10) /* RF 80MHz, RX 40MHz */
|| (phys_t1->rf_mode == 3 && rxsc >= 9 && rxsc <= 12) /* RF 160MHz, RX 40MHz */
) {
if (attrib->data_rate >= DESC_RATEMCS0) {
pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
pkt_bw = CHANNEL_WIDTH_40;
}
} else if ((phys_t1->rf_mode == 3 && rxsc >= 13 && rxsc <= 14) /* RF 160MHz, RX 80MHz */
) {
if (attrib->data_rate >= DESC_RATEMCS0) {
pkt_cch = phys_t1->channel + cch_offset_by_rxsc[rxsc];
pkt_bw = CHANNEL_WIDTH_80;
}
} else
rtw_warn_on(1);
}
#endif /* ODM_IC_11AC_SERIES_SUPPORT */
type1_end:
if (DBG_RX_PHYSTATUS_CHINFO) {
RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, rf_mode:%u, l_rxsc:%u, ht_rxsc:%u) => %u,%u\n"
, *phys & 0xf
, MAC_ARG(get_ta(wlanhdr))
, is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
, HDATA_RATE(attrib->data_rate)
, phys_t1->band, phys_t1->channel, phys_t1->rf_mode, phys_t1->l_rxsc, phys_t1->ht_rxsc
, pkt_cch, pkt_bw
);
}
/* for now, only return cneter channel of 20MHz packet */
if (pkt_cch && pkt_bw == CHANNEL_WIDTH_20)
attrib->ch = pkt_cch;
} else {
struct phy_sts_rpt_jgr2_type2 *phys_t2 = (struct phy_sts_rpt_jgr2_type2 *)phys;
if (DBG_RX_PHYSTATUS_CHINFO) {
RTW_PRINT("phys_t%u ta="MAC_FMT" %s, %s(band:%u, ch:%u, l_rxsc:%u, ht_rxsc:%u)\n"
, *phys & 0xf
, MAC_ARG(get_ta(wlanhdr))
, is_broadcast_mac_addr(get_ra(wlanhdr)) ? "BC" : is_multicast_mac_addr(get_ra(wlanhdr)) ? "MC" : "UC"
, HDATA_RATE(attrib->data_rate)
, phys_t2->band, phys_t2->channel, phys_t2->l_rxsc, phys_t2->ht_rxsc
);
}
}
}
#endif /* (ODM_PHY_STATUS_NEW_TYPE_SUPPORT == 1) */
}
#if defined(CONFIG_RTL8822C) && defined(CONFIG_LPS_PG)
void
debug_DACK(
struct dm_struct *dm
)
{
//P_PHYDM_FUNC dm;
//dm = &(SysMib.ODM.Phydm);
//PIQK_OFFLOAD_PARM pIQK_info;
//pIQK_info= &(SysMib.ODM.IQKParm);
u8 i;
u32 temp1, temp2, temp3;
temp1 = odm_get_bb_reg(dm, 0x1860, bMaskDWord);
temp2 = odm_get_bb_reg(dm, 0x4160, bMaskDWord);
temp3 = odm_get_bb_reg(dm, 0x9b4, bMaskDWord);
odm_set_bb_reg(dm, 0x9b4, bMaskDWord, 0xdb66db00);
//pathA
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x1860, 0xfc000000, 0x3c);
RTW_INFO("path A i\n");
//i
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18b0, 0xf0000000, i);
RTW_INFO("[0][0][%d] = 0x%08x\n", i, (u16)odm_get_bb_reg(dm,0x2810,0x7fc0000));
//pIQK_info->msbk_d[0][0][i] = (u16)odm_get_bb_reg(dm,0x2810,0x7fc0000);
}
RTW_INFO("path A q\n");
//q
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18cc, 0xf0000000, i);
RTW_INFO("[0][1][%d] = 0x%08x\n", i, (u16)odm_get_bb_reg(dm,0x283c,0x7fc0000));
//pIQK_info->msbk_d[0][1][i] = (u16)odm_get_bb_reg(dm,0x283c,0x7fc0000);
}
//pathB
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x4160, 0xfc000000, 0x3c);
RTW_INFO("\npath B i\n");
//i
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41b0, 0xf0000000, i);
RTW_INFO("[1][0][%d] = 0x%08x\n", i, (u16)odm_get_bb_reg(dm,0x4510,0x7fc0000));
//pIQK_info->msbk_d[1][0][i] = (u16)odm_get_bb_reg(dm,0x2810,0x7fc0000);
}
RTW_INFO("path B q\n");
//q
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41cc, 0xf0000000, i);
RTW_INFO("[1][1][%d] = 0x%08x\n", i, (u16)odm_get_bb_reg(dm,0x453c,0x7fc0000));
//pIQK_info->msbk_d[1][1][i] = (u16)odm_get_bb_reg(dm,0x283c,0x7fc0000);
}
//restore to normal
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x1860, bMaskDWord, temp1);
odm_set_bb_reg(dm, 0x4160, bMaskDWord, temp2);
odm_set_bb_reg(dm, 0x9b4, bMaskDWord, temp3);
}
void
debug_IQK(
struct dm_struct *dm,
IN u8 idx,
IN u8 path
)
{
u8 i, ch;
u32 tmp;
u32 bit_mask_20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
RTW_INFO("idx = %d, path = %d\n", idx, path);
odm_set_bb_reg(dm, 0x1b00, MASKDWORD, 0x8 | path << 1);
if (idx == TX_IQK) {//TXCFIR
odm_set_bb_reg(dm, R_0x1b20, BIT(31) | BIT(30), 0x3);
} else {//RXCFIR
odm_set_bb_reg(dm, R_0x1b20, BIT(31) | BIT(30), 0x1);
}
odm_set_bb_reg(dm, R_0x1bd4, BIT(21), 0x1);
odm_set_bb_reg(dm, R_0x1bd4, bit_mask_20_16, 0x10);
for (i = 0; i <= 16; i++) {
odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0xe0000001 | i << 2);
tmp = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
RTW_INFO("iqk_cfir_real[%d][%d][%d] = 0x%x\n", path, idx, i, ((tmp & 0x0fff0000) >> 16));
//iqk_info->iqk_cfir_real[ch][path][idx][i] =
// (tmp & 0x0fff0000) >> 16;
RTW_INFO("iqk_cfir_imag[%d][%d][%d] = 0x%x\n", path, idx, i, (tmp & 0x0fff));
//iqk_info->iqk_cfir_imag[ch][path][idx][i] = tmp & 0x0fff;
}
odm_set_bb_reg(dm, R_0x1b20, BIT(31) | BIT(30), 0x0);
//odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
}
__odm_func__ void
debug_information_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u32 reg_rf18;
if (odm_get_bb_reg(dm, R_0x1e7c, BIT(30)))
dpk_info->is_tssi_mode = true;
else
dpk_info->is_tssi_mode = false;
reg_rf18 = odm_get_rf_reg(dm, RF_PATH_A, RF_0x18, RFREG_MASK);
dpk_info->dpk_band = (u8)((reg_rf18 & BIT(16)) >> 16); /*0/1:G/A*/
dpk_info->dpk_ch = (u8)reg_rf18 & 0xff;
dpk_info->dpk_bw = (u8)((reg_rf18 & 0x3000) >> 12); /*3/2/1:20/40/80*/
RTW_INFO("[DPK] TSSI/ Band/ CH/ BW = %d / %s / %d / %s\n",
dpk_info->is_tssi_mode, dpk_info->dpk_band == 0 ? "2G" : "5G",
dpk_info->dpk_ch,
dpk_info->dpk_bw == 3 ? "20M" : (dpk_info->dpk_bw == 2 ? "40M" : "80M"));
}
extern void _dpk_get_coef_8822c(void *dm_void, u8 path);
__odm_func__ void
debug_reload_data_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 path;
u32 u32tmp;
debug_information_8822c(dm);
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
RTW_INFO("[DPK] Reload path: 0x%x\n", path);
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0x8 | (path << 1));
/*txagc bnd*/
if (dpk_info->dpk_band == 0x0)
u32tmp = odm_get_bb_reg(dm, R_0x1b60, MASKDWORD);
else
u32tmp = odm_get_bb_reg(dm, R_0x1b60, MASKDWORD);
RTW_INFO("[DPK] txagc bnd = 0x%08x\n", u32tmp);
u32tmp = odm_get_bb_reg(dm, R_0x1b64, MASKBYTE3);
RTW_INFO("[DPK] dpk_txagc = 0x%08x\n", u32tmp);
//debug_coef_write_8822c(dm, path, dpk_info->dpk_path_ok & BIT(path) >> path);
_dpk_get_coef_8822c(dm, path);
//debug_one_shot_8822c(dm, path, DPK_ON);
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc);
if (path == RF_PATH_A)
u32tmp = odm_get_bb_reg(dm, R_0x1b04, 0x0fffffff);
else
u32tmp = odm_get_bb_reg(dm, R_0x1b5c, 0x0fffffff);
RTW_INFO("[DPK] dpk_gs = 0x%08x\n", u32tmp);
}
}
void odm_lps_pg_debug_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
debug_DACK(dm);
debug_IQK(dm, TX_IQK, RF_PATH_A);
debug_IQK(dm, RX_IQK, RF_PATH_A);
debug_IQK(dm, TX_IQK, RF_PATH_B);
debug_IQK(dm, RX_IQK, RF_PATH_B);
debug_reload_data_8822c(dm);
}
#endif /* defined(CONFIG_RTL8822C) && defined(CONFIG_LPS_PG) */
================================================
FILE: core/rtw_p2p.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_P2P_C_
#include
#ifdef CONFIG_P2P
int rtw_p2p_is_channel_list_ok(u8 desired_ch, u8 *ch_list, u8 ch_cnt)
{
int found = 0, i = 0;
for (i = 0; i < ch_cnt; i++) {
if (ch_list[i] == desired_ch) {
found = 1;
break;
}
}
return found ;
}
int is_any_client_associated(_adapter *padapter)
{
return padapter->stapriv.asoc_list_cnt ? _TRUE : _FALSE;
}
static u32 go_add_group_info_attr(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
_irqL irqL;
_list *phead, *plist;
u32 len = 0;
u16 attr_len = 0;
u8 tmplen, *pdata_attr, *pstart, *pcur;
struct sta_info *psta = NULL;
_adapter *padapter = pwdinfo->padapter;
struct sta_priv *pstapriv = &padapter->stapriv;
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
pdata_attr = rtw_zmalloc(MAX_P2P_IE_LEN);
if (NULL == pdata_attr) {
RTW_INFO("%s pdata_attr malloc failed\n", __FUNCTION__);
goto _exit;
}
pstart = pdata_attr;
pcur = pdata_attr;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
/* look up sta asoc_queue */
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
if (psta->is_p2p_device) {
tmplen = 0;
pcur++;
/* P2P device address */
_rtw_memcpy(pcur, psta->dev_addr, ETH_ALEN);
pcur += ETH_ALEN;
/* P2P interface address */
_rtw_memcpy(pcur, psta->cmn.mac_addr, ETH_ALEN);
pcur += ETH_ALEN;
*pcur = psta->dev_cap;
pcur++;
/* *(u16*)(pcur) = cpu_to_be16(psta->config_methods); */
RTW_PUT_BE16(pcur, psta->config_methods);
pcur += 2;
_rtw_memcpy(pcur, psta->primary_dev_type, 8);
pcur += 8;
*pcur = psta->num_of_secdev_type;
pcur++;
_rtw_memcpy(pcur, psta->secdev_types_list, psta->num_of_secdev_type * 8);
pcur += psta->num_of_secdev_type * 8;
if (psta->dev_name_len > 0) {
/* *(u16*)(pcur) = cpu_to_be16( WPS_ATTR_DEVICE_NAME ); */
RTW_PUT_BE16(pcur, WPS_ATTR_DEVICE_NAME);
pcur += 2;
/* *(u16*)(pcur) = cpu_to_be16( psta->dev_name_len ); */
RTW_PUT_BE16(pcur, psta->dev_name_len);
pcur += 2;
_rtw_memcpy(pcur, psta->dev_name, psta->dev_name_len);
pcur += psta->dev_name_len;
}
tmplen = (u8)(pcur - pstart);
*pstart = (tmplen - 1);
attr_len += tmplen;
/* pstart += tmplen; */
pstart = pcur;
}
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
if (attr_len > 0)
len = rtw_set_p2p_attr_content(pbuf, P2P_ATTR_GROUP_INFO, attr_len, pdata_attr);
rtw_mfree(pdata_attr, MAX_P2P_IE_LEN);
_exit:
return len;
}
static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
_adapter *padapter = pwdinfo->padapter;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
unsigned char category = RTW_WLAN_CATEGORY_P2P;/* P2P action frame */
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_GO_DISC_REQUEST;
u8 dialogToken = 0;
RTW_INFO("[%s]\n", __FUNCTION__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pwdinfo->interface_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pwdinfo->interface_addr, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* Build P2P action frame header */
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
/* there is no IE in this P2P action frame */
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 status, u8 dialogToken)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
_adapter *padapter = pwdinfo->padapter;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_DEVDISC_RESP;
u8 p2pie[8] = { 0x00 };
u32 p2pielen = 0;
RTW_INFO("[%s]\n", __FUNCTION__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pwdinfo->device_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pwdinfo->device_addr, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* Build P2P public action frame header */
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
/* Build P2P IE */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* P2P_ATTR_STATUS */
p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_STATUS, 1, &status);
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, p2pie, &pattrib->pktlen);
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr, u8 *frame_body, u16 config_method)
{
_adapter *padapter = pwdinfo->padapter;
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u8 dialogToken = frame_body[7]; /* The Dialog Token of provisioning discovery request frame. */
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_PROVISION_DISC_RESP;
u8 wpsie[100] = { 0x00 };
u8 wpsielen = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
wpsielen = 0;
/* WPS OUI */
/* *(u32*) ( wpsie ) = cpu_to_be32( WPSOUI ); */
RTW_PUT_BE32(wpsie, WPSOUI);
wpsielen += 4;
#if 0
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
#endif
/* Config Method */
/* Type: */
/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD ); */
RTW_PUT_BE16(wpsie + wpsielen, WPS_ATTR_CONF_METHOD);
wpsielen += 2;
/* Length: */
/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 ); */
RTW_PUT_BE16(wpsie + wpsielen, 0x0002);
wpsielen += 2;
/* Value: */
/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( config_method ); */
RTW_PUT_BE16(wpsie + wpsielen, config_method);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pattrib->pktlen);
#ifdef CONFIG_WFD
wfdielen = build_provdisc_resp_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
#endif
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
return;
}
static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 status, u8 dialogToken)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
_adapter *padapter = pwdinfo->padapter;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
unsigned char category = RTW_WLAN_CATEGORY_P2P;/* P2P action frame */
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_PRESENCE_RESPONSE;
u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
u8 noa_attr_content[32] = { 0x00 };
u32 p2pielen = 0;
RTW_INFO("[%s]\n", __FUNCTION__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
return;
/* update attribute */
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pwdinfo->interface_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pwdinfo->interface_addr, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* Build P2P action frame header */
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pattrib->pktlen));
/* Add P2P IE header */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Add Status attribute in P2P IE */
p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_STATUS, 1, &status);
/* Add NoA attribute in P2P IE */
noa_attr_content[0] = 0x1;/* index */
noa_attr_content[1] = 0x0;/* CTWindow and OppPS Parameters */
/* todo: Notice of Absence Descriptor(s) */
p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_NOA, 2, noa_attr_content);
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, p2pie, &(pattrib->pktlen));
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
u32 build_beacon_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
u16 capability = 0;
u32 len = 0, p2pielen = 0;
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* According to the P2P Specification, the beacon frame should contain 3 P2P attributes */
/* 1. P2P Capability */
/* 2. P2P Device ID */
/* 3. Notice of Absence ( NOA ) */
/* P2P Capability ATTR */
/* Type: */
/* Length: */
/* Value: */
/* Device Capability Bitmap, 1 byte */
/* Be able to participate in additional P2P Groups and */
/* support the P2P Invitation Procedure */
/* Group Capability Bitmap, 1 byte */
capability = P2P_DEVCAP_INVITATION_PROC | P2P_DEVCAP_CLIENT_DISCOVERABILITY;
capability |= ((P2P_GRPCAP_GO | P2P_GRPCAP_INTRABSS) << 8);
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
capability |= (P2P_GRPCAP_GROUP_FORMATION << 8);
capability = cpu_to_le16(capability);
p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_CAPABILITY, 2, (u8 *)&capability);
/* P2P Device ID ATTR */
p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_DEVICE_ID, ETH_ALEN, pwdinfo->device_addr);
/* Notice of Absence ATTR */
/* Type: */
/* Length: */
/* Value: */
/* go_add_noa_attr(pwdinfo); */
pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
return len;
}
#ifdef CONFIG_WFD
u32 build_beacon_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u16 val16 = 0;
u32 len = 0, wfdielen = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110812 */
/* According to the WFD Specification, the beacon frame should contain 4 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID */
/* 3. Coupled Sink Information */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
if (P2P_ROLE_GO == pwdinfo->role) {
if (is_any_client_associated(pwdinfo->padapter)) {
/* WFD primary sink + WiFi Direct mode + WSD (WFD Service Discovery) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
} else {
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD (WFD Service Discovery) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
}
} else {
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
}
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_probe_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u16 val16 = 0;
u32 len = 0, wfdielen = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110812 */
/* According to the WFD Specification, the probe request frame should contain 4 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID */
/* 3. Coupled Sink Information */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
if (1 == pwdinfo->wfd_tdls_enable) {
/* WFD primary sink + available for WFD session + WiFi TDLS mode + WSC ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type |
WFD_DEVINFO_SESSION_AVAIL |
WFD_DEVINFO_WSD |
WFD_DEVINFO_PC_TDLS;
RTW_PUT_BE16(wfdie + wfdielen, val16);
} else {
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSC ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type |
WFD_DEVINFO_SESSION_AVAIL |
WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
}
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_probe_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 tunneled)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
u16 v16 = 0;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110812 */
/* According to the WFD Specification, the probe response frame should contain 4 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID */
/* 3. Coupled Sink Information */
/* 4. WFD Session Information */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode */
if (_TRUE == pwdinfo->session_available) {
if (P2P_ROLE_GO == pwdinfo->role) {
if (is_any_client_associated(pwdinfo->padapter)) {
if (pwdinfo->wfd_tdls_enable) {
/* TDLS mode + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
} else {
/* WiFi Direct mode + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
}
} else {
if (pwdinfo->wfd_tdls_enable) {
/* available for WFD session + TDLS mode + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
} else {
/* available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
}
}
} else {
if (pwdinfo->wfd_tdls_enable) {
/* available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
} else {
/* available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
}
}
} else {
if (pwdinfo->wfd_tdls_enable) {
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
} else {
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_HDCP_SUPPORT;
RTW_PUT_BE16(wfdie + wfdielen, v16);
}
}
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* WFD Session Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_SESSION_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
wfdielen += 2;
/* Todo: to add the list of WFD device info descriptor in WFD group. */
}
#ifdef CONFIG_CONCURRENT_MODE
#ifdef CONFIG_TDLS
{
int i;
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
if (iface == padapter)
continue;
if ((tunneled == 0) && (iface->wdinfo.wfd_tdls_enable == 1)) {
/* Alternative MAC Address ATTR
Type: */
wfdie[wfdielen++] = WFD_ATTR_ALTER_MAC;
/* Length:
Note: In the WFD specification, the size of length field is 2.*/
RTW_PUT_BE16(wfdie + wfdielen, ETH_ALEN);
wfdielen += 2;
/* Value:
Alternative MAC Address*/
_rtw_memcpy(wfdie + wfdielen, adapter_mac_addr(iface), ETH_ALEN);
wfdielen += ETH_ALEN;
}
}
}
}
#endif /* CONFIG_TDLS*/
#endif /* CONFIG_CONCURRENT_MODE */
pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_assoc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u16 val16 = 0;
u32 len = 0, wfdielen = 0;
_adapter *padapter = NULL;
struct mlme_priv *pmlmepriv = NULL;
struct wifi_display_info *pwfd_info = NULL;
padapter = pwdinfo->padapter;
pmlmepriv = &padapter->mlmepriv;
pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110812 */
/* According to the WFD Specification, the probe request frame should contain 4 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID */
/* 3. Coupled Sink Information */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_assoc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110812 */
/* According to the WFD Specification, the probe request frame should contain 4 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID */
/* 3. Coupled Sink Information */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_nego_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_nego_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_nego_confirm_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + WiFi Direct mode + WSD ( WFD Service Discovery ) + WFD Session Available */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_WSD | WFD_DEVINFO_SESSION_AVAIL;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_invitation_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
if (P2P_ROLE_GO == pwdinfo->role) {
/* WFD Session Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_SESSION_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
wfdielen += 2;
/* Todo: to add the list of WFD device info descriptor in WFD group. */
}
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_invitation_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u16 val16 = 0;
u32 len = 0, wfdielen = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
if (P2P_ROLE_GO == pwdinfo->role) {
/* WFD Session Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_SESSION_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0000);
wfdielen += 2;
/* Todo: to add the list of WFD device info descriptor in WFD group. */
}
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_provdisc_req_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the provision discovery request frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
u32 build_provdisc_resp_wfd_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 len = 0, wfdielen = 0;
u16 val16 = 0;
_adapter *padapter = pwdinfo->padapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->wdinfo.wfd_info;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
goto exit;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/* Commented by Albert 20110825 */
/* According to the WFD Specification, the provision discovery response frame should contain 3 WFD attributes */
/* 1. WFD Device Information */
/* 2. Associated BSSID ( Optional ) */
/* 3. Local IP Adress ( Optional ) */
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* WFD primary sink + available for WFD session + WiFi Direct mode + WSD ( WFD Service Discovery ) */
val16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, val16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
wfdielen += ETH_ALEN;
/* Coupled Sink Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_COUPLED_SINK_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0007);
wfdielen += 2;
/* Value: */
/* Coupled Sink Status bitmap */
/* Not coupled/available for Coupling */
wfdie[wfdielen++] = 0;
/* MAC Addr. */
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
wfdie[wfdielen++] = 0;
rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, &len);
exit:
return len;
}
#endif /* CONFIG_WFD */
u32 build_probe_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
u32 len = 0, p2pielen = 0;
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20100907 */
/* According to the P2P Specification, the probe response frame should contain 5 P2P attributes */
/* 1. P2P Capability */
/* 2. Extended Listen Timing */
/* 3. Notice of Absence ( NOA ) ( Only GO needs this ) */
/* 4. Device Info */
/* 5. Group Info ( Only GO need this ) */
/* P2P Capability ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 ); */
RTW_PUT_LE16(p2pie + p2pielen, 0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
/* Group Capability Bitmap, 1 byte */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
p2pie[p2pielen] = (P2P_GRPCAP_GO | P2P_GRPCAP_INTRABSS);
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_PROVISIONING_ING))
p2pie[p2pielen] |= P2P_GRPCAP_GROUP_FORMATION;
p2pielen++;
} else if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)) {
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
else
p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
}
/* Extended Listen Timing ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_EX_LISTEN_TIMING;
/* Length: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0004 ); */
RTW_PUT_LE16(p2pie + p2pielen, 0x0004);
p2pielen += 2;
/* Value: */
/* Availability Period */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF ); */
RTW_PUT_LE16(p2pie + p2pielen, 0xFFFF);
p2pielen += 2;
/* Availability Interval */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0xFFFF ); */
RTW_PUT_LE16(p2pie + p2pielen, 0xFFFF);
p2pielen += 2;
/* Notice of Absence ATTR */
/* Type: */
/* Length: */
/* Value: */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* go_add_noa_attr(pwdinfo); */
}
/* Device Info ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len ); */
RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->supported_wps_cm ); */
RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->supported_wps_cm);
p2pielen += 2;
{
/* Primary Device Type */
/* Category ID */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
/* *(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI ); */
RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
p2pielen += 4;
/* Sub Category ID */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
}
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len ); */
RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
/* Group Info ATTR */
/* Type: */
/* Length: */
/* Value: */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
p2pielen += go_add_group_info_attr(pwdinfo, p2pie + p2pielen);
pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
return len;
}
u32 build_prov_disc_request_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 *pssid, u8 ussidlen, u8 *pdev_raddr)
{
u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
u32 len = 0, p2pielen = 0;
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20110301 */
/* According to the P2P Specification, the provision discovery request frame should contain 3 P2P attributes */
/* 1. P2P Capability */
/* 2. Device Info */
/* 3. Group ID ( When joining an operating P2P Group ) */
/* P2P Capability ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 0x0002 ); */
RTW_PUT_LE16(p2pie + p2pielen, 0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_PERSISTENT_GROUP | DMP_P2P_GRPCAP_SUPPORT;
else
p2pie[p2pielen++] = DMP_P2P_GRPCAP_SUPPORT;
/* Device Info ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( 21 + pwdinfo->device_name_len ); */
RTW_PUT_LE16(p2pie + p2pielen, 21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_addr, ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
if (pwdinfo->ui_got_wps_info == P2P_GOT_WPSINFO_PBC) {
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_PBC ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_CONFIG_METHOD_PBC);
} else {
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_CONFIG_METHOD_DISPLAY ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_CONFIG_METHOD_DISPLAY);
}
p2pielen += 2;
/* Primary Device Type */
/* Category ID */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_CID_MULIT_MEDIA ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
/* *(u32*) ( p2pie + p2pielen ) = cpu_to_be32( WPSOUI ); */
RTW_PUT_BE32(p2pie + p2pielen, WPSOUI);
p2pielen += 4;
/* Sub Category ID */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_PDT_SCID_MEDIA_SERVER ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( WPS_ATTR_DEVICE_NAME ); */
RTW_PUT_BE16(p2pie + p2pielen, WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_be16( pwdinfo->device_name_len ); */
RTW_PUT_BE16(p2pie + p2pielen, pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name, pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
/* Added by Albert 2011/05/19 */
/* In this case, the pdev_raddr is the device address of the group owner. */
/* P2P Group ID ATTR */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
/* Length: */
/* *(u16*) ( p2pie + p2pielen ) = cpu_to_le16( ETH_ALEN + ussidlen ); */
RTW_PUT_LE16(p2pie + p2pielen, ETH_ALEN + ussidlen);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pdev_raddr, ETH_ALEN);
p2pielen += ETH_ALEN;
_rtw_memcpy(p2pie + p2pielen, pssid, ussidlen);
p2pielen += ussidlen;
}
pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
return len;
}
u32 build_assoc_resp_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf, u8 status_code)
{
u8 p2pie[MAX_P2P_IE_LEN] = { 0x00 };
u32 len = 0, p2pielen = 0;
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* According to the P2P Specification, the Association response frame should contain 2 P2P attributes */
/* 1. Status */
/* 2. Extended Listen Timing (optional) */
/* Status ATTR */
p2pielen += rtw_set_p2p_attr_content(&p2pie[p2pielen], P2P_ATTR_STATUS, 1, &status_code);
/* Extended Listen Timing ATTR */
/* Type: */
/* Length: */
/* Value: */
pbuf = rtw_set_ie(pbuf, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &len);
return len;
}
u32 build_deauth_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pbuf)
{
u32 len = 0;
return len;
}
u32 process_probe_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
u8 *p;
u32 ret = _FALSE;
u8 *p2pie;
u32 p2pielen = 0;
int ssid_len = 0, rate_cnt = 0;
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _SUPPORTEDRATES_IE_, (int *)&rate_cnt,
len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
if (rate_cnt <= 4) {
int i, g_rate = 0;
for (i = 0; i < rate_cnt; i++) {
if (((*(p + 2 + i) & 0xff) != 0x02) &&
((*(p + 2 + i) & 0xff) != 0x04) &&
((*(p + 2 + i) & 0xff) != 0x0B) &&
((*(p + 2 + i) & 0xff) != 0x16))
g_rate = 1;
}
if (g_rate == 0) {
/* There is no OFDM rate included in SupportedRates IE of this probe request frame */
/* The driver should response this probe request. */
return ret;
}
} else {
/* rate_cnt > 4 means the SupportRates IE contains the OFDM rate because the count of CCK rates are 4. */
/* We should proceed the following check for this probe request. */
}
/* Added comments by Albert 20100906 */
/* There are several items we should check here. */
/* 1. This probe request frame must contain the P2P IE. (Done) */
/* 2. This probe request frame must contain the wildcard SSID. (Done) */
/* 3. Wildcard BSSID. (Todo) */
/* 4. Destination Address. ( Done in mgt_dispatcher function ) */
/* 5. Requested Device Type in WSC IE. (Todo) */
/* 6. Device ID attribute in P2P IE. (Todo) */
p = rtw_get_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_, _SSID_IE_, (int *)&ssid_len,
len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_);
ssid_len &= 0xff; /* Just last 1 byte is valid for ssid len of the probe request */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE) || rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
p2pie = rtw_get_p2p_ie(pframe + WLAN_HDR_A3_LEN + _PROBEREQ_IE_OFFSET_ , len - WLAN_HDR_A3_LEN - _PROBEREQ_IE_OFFSET_ , NULL, &p2pielen);
if (p2pie) {
if ((p != NULL) && _rtw_memcmp((void *)(p + 2), (void *) pwdinfo->p2p_wildcard_ssid , 7)) {
/* todo: */
/* Check Requested Device Type attributes in WSC IE. */
/* Check Device ID attribute in P2P IE */
ret = _TRUE;
} else if ((p != NULL) && (ssid_len == 0))
ret = _TRUE;
} else {
/* non -p2p device */
}
}
return ret;
}
u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint len, struct sta_info *psta)
{
u8 status_code = P2P_STATUS_SUCCESS;
u8 *pbuf, *pattr_content = NULL;
u32 attr_contentlen = 0;
u16 cap_attr = 0;
unsigned short frame_type, ie_offset = 0;
u8 *ies;
u32 ies_len;
u8 *p2p_ie;
u32 p2p_ielen = 0;
if (!rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO))
return P2P_STATUS_FAIL_REQUEST_UNABLE;
frame_type = get_frame_sub_type(pframe);
if (frame_type == WIFI_ASSOCREQ)
ie_offset = _ASOCREQ_IE_OFFSET_;
else /* WIFI_REASSOCREQ */
ie_offset = _REASOCREQ_IE_OFFSET_;
ies = pframe + WLAN_HDR_A3_LEN + ie_offset;
ies_len = len - WLAN_HDR_A3_LEN - ie_offset;
p2p_ie = rtw_get_p2p_ie(ies , ies_len , NULL, &p2p_ielen);
if (!p2p_ie) {
RTW_INFO("[%s] P2P IE not Found!!\n", __FUNCTION__);
status_code = P2P_STATUS_FAIL_INVALID_PARAM;
} else
RTW_INFO("[%s] P2P IE Found!!\n", __FUNCTION__);
while (p2p_ie) {
/* Check P2P Capability ATTR */
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *) &attr_contentlen)) {
RTW_INFO("[%s] Got P2P Capability Attr!!\n", __FUNCTION__);
cap_attr = le16_to_cpu(cap_attr);
psta->dev_cap = cap_attr & 0xff;
}
/* Check Extended Listen Timing ATTR */
/* Check P2P Device Info ATTR */
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO, NULL, (uint *)&attr_contentlen)) {
RTW_INFO("[%s] Got P2P DEVICE INFO Attr!!\n", __FUNCTION__);
pattr_content = pbuf = rtw_zmalloc(attr_contentlen);
if (pattr_content) {
u8 num_of_secdev_type;
u16 dev_name_len;
rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_INFO , pattr_content, (uint *)&attr_contentlen);
_rtw_memcpy(psta->dev_addr, pattr_content, ETH_ALEN);/* P2P Device Address */
pattr_content += ETH_ALEN;
_rtw_memcpy(&psta->config_methods, pattr_content, 2);/* Config Methods */
psta->config_methods = be16_to_cpu(psta->config_methods);
pattr_content += 2;
_rtw_memcpy(psta->primary_dev_type, pattr_content, 8);
pattr_content += 8;
num_of_secdev_type = *pattr_content;
pattr_content += 1;
if (num_of_secdev_type == 0)
psta->num_of_secdev_type = 0;
else {
u32 len;
psta->num_of_secdev_type = num_of_secdev_type;
len = (sizeof(psta->secdev_types_list) < (num_of_secdev_type * 8)) ? (sizeof(psta->secdev_types_list)) : (num_of_secdev_type * 8);
_rtw_memcpy(psta->secdev_types_list, pattr_content, len);
pattr_content += (num_of_secdev_type * 8);
}
/* dev_name_len = attr_contentlen - ETH_ALEN - 2 - 8 - 1 - (num_of_secdev_type*8); */
psta->dev_name_len = 0;
if (WPS_ATTR_DEVICE_NAME == be16_to_cpu(*(u16 *)pattr_content)) {
dev_name_len = be16_to_cpu(*(u16 *)(pattr_content + 2));
psta->dev_name_len = (sizeof(psta->dev_name) < dev_name_len) ? sizeof(psta->dev_name) : dev_name_len;
_rtw_memcpy(psta->dev_name, pattr_content + 4, psta->dev_name_len);
}
rtw_mfree(pbuf, attr_contentlen);
}
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
return status_code;
}
u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
u8 *frame_body;
u8 status, dialogToken;
struct sta_info *psta = NULL;
_adapter *padapter = pwdinfo->padapter;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *p2p_ie;
u32 p2p_ielen = 0;
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
dialogToken = frame_body[7];
status = P2P_STATUS_FAIL_UNKNOWN_P2PGROUP;
p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
if (p2p_ie) {
u8 groupid[38] = { 0x00 };
u8 dev_addr[ETH_ALEN] = { 0x00 };
u32 attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen)) {
if (_rtw_memcmp(pwdinfo->device_addr, groupid, ETH_ALEN) &&
_rtw_memcmp(pwdinfo->p2p_group_ssid, groupid + ETH_ALEN, pwdinfo->p2p_group_ssid_len)) {
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_DEVICE_ID, dev_addr, &attr_contentlen)) {
_irqL irqL;
_list *phead, *plist;
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
/* look up sta asoc_queue */
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
if (psta->is_p2p_device && (psta->dev_cap & P2P_DEVCAP_CLIENT_DISCOVERABILITY) &&
_rtw_memcmp(psta->dev_addr, dev_addr, ETH_ALEN)) {
/* _exit_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
/* issue GO Discoverability Request */
issue_group_disc_req(pwdinfo, psta->cmn.mac_addr);
/* _enter_critical_bh(&pstapriv->asoc_list_lock, &irqL); */
status = P2P_STATUS_SUCCESS;
break;
} else
status = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
} else
status = P2P_STATUS_FAIL_INVALID_PARAM;
} else
status = P2P_STATUS_FAIL_INVALID_PARAM;
}
}
/* issue Device Discoverability Response */
issue_p2p_devdisc_resp(pwdinfo, get_addr2_ptr(pframe), status, dialogToken);
return (status == P2P_STATUS_SUCCESS) ? _TRUE : _FALSE;
}
u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
return _TRUE;
}
u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
u8 *frame_body;
u8 *wpsie;
uint wps_ielen = 0, attr_contentlen = 0;
u16 uconfig_method = 0;
frame_body = (pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
wpsie = rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen);
if (wpsie) {
if (rtw_get_wps_attr_content(wpsie, wps_ielen, WPS_ATTR_CONF_METHOD , (u8 *) &uconfig_method, &attr_contentlen)) {
uconfig_method = be16_to_cpu(uconfig_method);
switch (uconfig_method) {
case WPS_CM_DISPLYA: {
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3);
break;
}
case WPS_CM_LABEL: {
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "lab", 3);
break;
}
case WPS_CM_PUSH_BUTTON: {
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3);
break;
}
case WPS_CM_KEYPAD: {
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3);
break;
}
}
issue_p2p_provision_resp(pwdinfo, get_addr2_ptr(pframe), frame_body, uconfig_method);
}
}
RTW_INFO("[%s] config method = %s\n", __FUNCTION__, pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req);
return _TRUE;
}
u8 process_p2p_provdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe)
{
return _TRUE;
}
u8 rtw_p2p_get_peer_ch_list(struct wifidirect_info *pwdinfo, u8 *ch_content, u8 ch_cnt, u8 *peer_ch_list)
{
u8 i = 0, j = 0;
u8 temp = 0;
u8 ch_no = 0;
ch_content += 3;
ch_cnt -= 3;
while (ch_cnt > 0) {
ch_content += 1;
ch_cnt -= 1;
temp = *ch_content;
for (i = 0 ; i < temp ; i++, j++)
peer_ch_list[j] = *(ch_content + 1 + i);
ch_content += (temp + 1);
ch_cnt -= (temp + 1);
ch_no += temp ;
}
return ch_no;
}
u8 rtw_p2p_ch_inclusion(_adapter *adapter, u8 *peer_ch_list, u8 peer_ch_num, u8 *ch_list_inclusioned)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
int i = 0, j = 0, temp = 0;
u8 ch_no = 0;
for (i = 0; i < peer_ch_num; i++) {
for (j = temp; j < rfctl->max_chan_nums; j++) {
if (*(peer_ch_list + i) == rfctl->channel_set[j].ChannelNum) {
ch_list_inclusioned[ch_no++] = *(peer_ch_list + i);
temp = j;
break;
}
}
}
return ch_no;
}
u8 process_p2p_group_negotation_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
_adapter *padapter = pwdinfo->padapter;
u8 result = P2P_STATUS_SUCCESS;
u32 p2p_ielen = 0, wps_ielen = 0;
u8 *ies;
u32 ies_len;
u8 *p2p_ie;
u8 *wpsie;
u16 wps_devicepassword_id = 0x0000;
uint wps_devicepassword_id_len = 0;
#ifdef CONFIG_WFD
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
#endif /* CONFIG_TDLS */
#endif /* CONFIG_WFD */
wpsie = rtw_get_wps_ie(pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen);
if (wpsie) {
/* Commented by Kurt 20120113 */
/* If some device wants to do p2p handshake without sending prov_disc_req */
/* We have to get peer_req_cm from here. */
if (_rtw_memcmp(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "000", 3)) {
rtw_get_wps_attr_content(wpsie, wps_ielen, WPS_ATTR_DEVICE_PWID, (u8 *) &wps_devicepassword_id, &wps_devicepassword_id_len);
wps_devicepassword_id = be16_to_cpu(wps_devicepassword_id);
if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "dis", 3);
else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pad", 3);
else
_rtw_memcpy(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, "pbc", 3);
}
} else {
RTW_INFO("[%s] WPS IE not Found!!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
return result ;
}
ies = pframe + _PUBLIC_ACTION_IE_OFFSET_;
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
if (!p2p_ie) {
RTW_INFO("[%s] P2P IE not Found!!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
}
while (p2p_ie) {
u8 attr_content = 0x00;
u32 attr_contentlen = 0;
u8 ch_content[100] = { 0x00 };
uint ch_cnt = 0;
u8 peer_ch_list[100] = { 0x00 };
u8 peer_ch_num = 0;
u8 ch_list_inclusioned[100] = { 0x00 };
u8 ch_num_inclusioned = 0;
u16 cap_attr;
u8 listen_ch_attr[5] = { 0x00 };
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_ING);
/* Check P2P Capability ATTR */
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *)&attr_contentlen)) {
cap_attr = le16_to_cpu(cap_attr);
#if defined(CONFIG_WFD) && defined(CONFIG_TDLS)
if (!(cap_attr & P2P_GRPCAP_INTRABSS))
ptdlsinfo->ap_prohibited = _TRUE;
#endif /* defined(CONFIG_WFD) && defined(CONFIG_TDLS) */
}
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT , &attr_content, &attr_contentlen)) {
RTW_INFO("[%s] GO Intent = %d, tie = %d\n", __FUNCTION__, attr_content >> 1, attr_content & 0x01);
pwdinfo->peer_intent = attr_content; /* include both intent and tie breaker values. */
if (pwdinfo->intent == (pwdinfo->peer_intent >> 1)) {
/* Try to match the tie breaker value */
if (pwdinfo->intent == P2P_MAX_INTENT) {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
result = P2P_STATUS_FAIL_BOTH_GOINTENT_15;
} else {
if (attr_content & 0x01)
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
else
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
}
} else if (pwdinfo->intent > (pwdinfo->peer_intent >> 1))
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
else
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* Store the group id information. */
_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, pwdinfo->device_addr, ETH_ALEN);
_rtw_memcpy(pwdinfo->groupid_info.ssid, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
}
}
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, (u8 *)listen_ch_attr, (uint *) &attr_contentlen) && attr_contentlen == 5)
pwdinfo->nego_req_info.peer_ch = listen_ch_attr[4];
RTW_INFO(FUNC_ADPT_FMT" listen channel :%u\n", FUNC_ADPT_ARG(padapter), pwdinfo->nego_req_info.peer_ch);
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, pwdinfo->p2p_peer_interface_addr, &attr_contentlen)) {
if (attr_contentlen != ETH_ALEN)
_rtw_memset(pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN);
}
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, ch_content, &ch_cnt)) {
peer_ch_num = rtw_p2p_get_peer_ch_list(pwdinfo, ch_content, ch_cnt, peer_ch_list);
ch_num_inclusioned = rtw_p2p_ch_inclusion(padapter, peer_ch_list, peer_ch_num, ch_list_inclusioned);
if (ch_num_inclusioned == 0) {
RTW_INFO("[%s] No common channel in channel list!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_NO_COMMON_CH;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
break;
}
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
if (!rtw_p2p_is_channel_list_ok(pwdinfo->operating_channel,
ch_list_inclusioned, ch_num_inclusioned)) {
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED)
&& padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
RTW_INFO("[%s] desired channel NOT Found!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_NO_COMMON_CH;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
break;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
u8 operatingch_info[5] = { 0x00 }, peer_operating_ch = 0;
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen))
peer_operating_ch = operatingch_info[4];
if (rtw_p2p_is_channel_list_ok(peer_operating_ch,
ch_list_inclusioned, ch_num_inclusioned)) {
/**
* Change our operating channel as peer's for compatibility.
*/
pwdinfo->operating_channel = peer_operating_ch;
RTW_INFO("[%s] Change op ch to %02x as peer's\n", __FUNCTION__, pwdinfo->operating_channel);
} else {
/* Take first channel of ch_list_inclusioned as operating channel */
pwdinfo->operating_channel = ch_list_inclusioned[0];
RTW_INFO("[%s] Change op ch to %02x\n", __FUNCTION__, pwdinfo->operating_channel);
}
}
}
}
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
if (pwdinfo->ui_got_wps_info == P2P_NO_WPSINFO) {
result = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
rtw_p2p_set_state(pwdinfo, P2P_STATE_TX_INFOR_NOREADY);
return result;
}
#ifdef CONFIG_WFD
rtw_process_wfd_ies(padapter, pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, __func__);
#endif
return result ;
}
u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
_adapter *padapter = pwdinfo->padapter;
u8 result = P2P_STATUS_SUCCESS;
u32 p2p_ielen, wps_ielen;
u8 *ies;
u32 ies_len;
u8 *p2p_ie;
#ifdef CONFIG_WFD
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
#endif /* CONFIG_TDLS */
#endif /* CONFIG_WFD */
ies = pframe + _PUBLIC_ACTION_IE_OFFSET_;
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
/* Be able to know which one is the P2P GO and which one is P2P client. */
if (rtw_get_wps_ie(ies, ies_len, NULL, &wps_ielen)) {
} else {
RTW_INFO("[%s] WPS IE not Found!!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
}
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
if (!p2p_ie) {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
result = P2P_STATUS_FAIL_INCOMPATIBLE_PARAM;
} else {
u8 attr_content = 0x00;
u32 attr_contentlen = 0;
u8 operatingch_info[5] = { 0x00 };
u8 groupid[38];
u16 cap_attr;
u8 peer_ch_list[100] = { 0x00 };
u8 peer_ch_num = 0;
u8 ch_list_inclusioned[100] = { 0x00 };
u8 ch_num_inclusioned = 0;
while (p2p_ie) { /* Found the P2P IE. */
/* Check P2P Capability ATTR */
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CAPABILITY, (u8 *)&cap_attr, (uint *)&attr_contentlen)) {
cap_attr = le16_to_cpu(cap_attr);
#ifdef CONFIG_TDLS
if (!(cap_attr & P2P_GRPCAP_INTRABSS))
ptdlsinfo->ap_prohibited = _TRUE;
#endif /* CONFIG_TDLS */
}
rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
if (attr_contentlen == 1) {
RTW_INFO("[%s] Status = %d\n", __FUNCTION__, attr_content);
if (attr_content == P2P_STATUS_SUCCESS) {
/* Do nothing. */
} else {
if (P2P_STATUS_FAIL_INFO_UNAVAILABLE == attr_content)
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INFOR_NOREADY);
else
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
result = attr_content;
break;
}
}
/* Try to get the peer's interface address */
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, pwdinfo->p2p_peer_interface_addr, &attr_contentlen)) {
if (attr_contentlen != ETH_ALEN)
_rtw_memset(pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN);
}
/* Try to get the peer's intent and tie breaker value. */
attr_content = 0x00;
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT , &attr_content, &attr_contentlen)) {
RTW_INFO("[%s] GO Intent = %d, tie = %d\n", __FUNCTION__, attr_content >> 1, attr_content & 0x01);
pwdinfo->peer_intent = attr_content; /* include both intent and tie breaker values. */
if (pwdinfo->intent == (pwdinfo->peer_intent >> 1)) {
/* Try to match the tie breaker value */
if (pwdinfo->intent == P2P_MAX_INTENT) {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
result = P2P_STATUS_FAIL_BOTH_GOINTENT_15;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
} else {
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
if (attr_content & 0x01)
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
else
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
}
} else if (pwdinfo->intent > (pwdinfo->peer_intent >> 1)) {
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
} else {
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
}
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* Store the group id information. */
_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, pwdinfo->device_addr, ETH_ALEN);
_rtw_memcpy(pwdinfo->groupid_info.ssid, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
}
}
/* Try to get the operation channel information */
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen)) {
RTW_INFO("[%s] Peer's operating channel = %d\n", __FUNCTION__, operatingch_info[4]);
pwdinfo->peer_operating_ch = operatingch_info[4];
}
/* Try to get the channel list information */
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, pwdinfo->channel_list_attr, &pwdinfo->channel_list_attr_len)) {
RTW_INFO("[%s] channel list attribute found, len = %d\n", __FUNCTION__, pwdinfo->channel_list_attr_len);
peer_ch_num = rtw_p2p_get_peer_ch_list(pwdinfo, pwdinfo->channel_list_attr, pwdinfo->channel_list_attr_len, peer_ch_list);
ch_num_inclusioned = rtw_p2p_ch_inclusion(padapter, peer_ch_list, peer_ch_num, ch_list_inclusioned);
if (ch_num_inclusioned == 0) {
RTW_INFO("[%s] No common channel in channel list!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_NO_COMMON_CH;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
break;
}
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
if (!rtw_p2p_is_channel_list_ok(pwdinfo->operating_channel,
ch_list_inclusioned, ch_num_inclusioned)) {
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED)
&& padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
RTW_INFO("[%s] desired channel NOT Found!\n", __FUNCTION__);
result = P2P_STATUS_FAIL_NO_COMMON_CH;
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
break;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
u8 operatingch_info[5] = { 0x00 }, peer_operating_ch = 0;
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen))
peer_operating_ch = operatingch_info[4];
if (rtw_p2p_is_channel_list_ok(peer_operating_ch,
ch_list_inclusioned, ch_num_inclusioned)) {
/**
* Change our operating channel as peer's for compatibility.
*/
pwdinfo->operating_channel = peer_operating_ch;
RTW_INFO("[%s] Change op ch to %02x as peer's\n", __FUNCTION__, pwdinfo->operating_channel);
} else {
/* Take first channel of ch_list_inclusioned as operating channel */
pwdinfo->operating_channel = ch_list_inclusioned[0];
RTW_INFO("[%s] Change op ch to %02x\n", __FUNCTION__, pwdinfo->operating_channel);
}
}
}
}
} else
RTW_INFO("[%s] channel list attribute not found!\n", __FUNCTION__);
/* Try to get the group id information if peer is GO */
attr_contentlen = 0;
_rtw_memset(groupid, 0x00, 38);
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen)) {
_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, &groupid[0], ETH_ALEN);
_rtw_memcpy(pwdinfo->groupid_info.ssid, &groupid[6], attr_contentlen - ETH_ALEN);
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
}
#ifdef CONFIG_WFD
rtw_process_wfd_ies(padapter, pframe + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, __func__);
#endif
return result ;
}
u8 process_p2p_group_negotation_confirm(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
#ifdef CONFIG_CONCURRENT_MODE
_adapter *padapter = pwdinfo->padapter;
#endif
u8 *ies;
u32 ies_len;
u8 *p2p_ie;
u32 p2p_ielen = 0;
u8 result = P2P_STATUS_SUCCESS;
ies = pframe + _PUBLIC_ACTION_IE_OFFSET_;
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) { /* Found the P2P IE. */
u8 attr_content = 0x00, operatingch_info[5] = { 0x00 };
u8 groupid[38] = { 0x00 };
u32 attr_contentlen = 0;
pwdinfo->negotiation_dialog_token = 1;
rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, &attr_content, &attr_contentlen);
if (attr_contentlen == 1) {
RTW_INFO("[%s] Status = %d\n", __FUNCTION__, attr_content);
result = attr_content;
if (attr_content == P2P_STATUS_SUCCESS) {
_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
/* Commented by Albert 20100911 */
/* Todo: Need to handle the case which both Intents are the same. */
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
if ((pwdinfo->intent) > (pwdinfo->peer_intent >> 1))
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
else if ((pwdinfo->intent) < (pwdinfo->peer_intent >> 1))
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
else {
/* Have to compare the Tie Breaker */
if (pwdinfo->peer_intent & 0x01)
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
else
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
}
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED)
&& padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
/* Switch back to the AP channel soon. */
_set_timer(&pwdinfo->ap_p2p_switch_timer, 100);
}
#endif
} else {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
break;
}
}
/* Try to get the group id information */
attr_contentlen = 0;
_rtw_memset(groupid, 0x00, 38);
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, groupid, &attr_contentlen)) {
RTW_INFO("[%s] Ssid = %s, ssidlen = %zu\n", __FUNCTION__, &groupid[ETH_ALEN], strlen(&groupid[ETH_ALEN]));
_rtw_memcpy(pwdinfo->groupid_info.go_device_addr, &groupid[0], ETH_ALEN);
_rtw_memcpy(pwdinfo->groupid_info.ssid, &groupid[6], attr_contentlen - ETH_ALEN);
}
attr_contentlen = 0;
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, operatingch_info, &attr_contentlen)) {
RTW_INFO("[%s] Peer's operating channel = %d\n", __FUNCTION__, operatingch_info[4]);
pwdinfo->peer_operating_ch = operatingch_info[4];
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
return result ;
}
u8 process_p2p_presence_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
{
u8 *frame_body;
u8 dialogToken = 0;
u8 status = P2P_STATUS_SUCCESS;
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
dialogToken = frame_body[6];
/* todo: check NoA attribute */
issue_p2p_presence_resp(pwdinfo, get_addr2_ptr(pframe), status, dialogToken);
return _TRUE;
}
void find_phase_handler(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct sitesurvey_parm parm;
_irqL irqL;
u8 _status = 0;
rtw_init_sitesurvey_parm(padapter, &parm);
_rtw_memcpy(&parm.ssid[0].Ssid, pwdinfo->p2p_wildcard_ssid, P2P_WILDCARD_SSID_LEN);
parm.ssid[0].SsidLength = P2P_WILDCARD_SSID_LEN;
parm.ssid_num = 1;
rtw_p2p_set_state(pwdinfo, P2P_STATE_FIND_PHASE_SEARCH);
_enter_critical_bh(&pmlmepriv->lock, &irqL);
_status = rtw_sitesurvey_cmd(padapter, &parm);
_exit_critical_bh(&pmlmepriv->lock, &irqL);
}
void p2p_concurrent_handler(_adapter *padapter);
void restore_p2p_state_handler(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL))
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED)) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
u8 union_bw = rtw_mi_get_union_bw(padapter);
u8 union_offset = rtw_mi_get_union_offset(padapter);
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ) || rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_RSP)) {
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
rtw_back_opch(padapter);
}
}
#endif
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_DEVICE)) {
#ifdef CONFIG_CONCURRENT_MODE
p2p_concurrent_handler(padapter);
#else
/* In the P2P client mode, the driver should not switch back to its listen channel */
/* because this P2P client should stay at the operating channel of P2P GO. */
set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
#endif
}
}
void pre_tx_invitereq_handler(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
u8 val8 = 1;
set_channel_bwmode(padapter, pwdinfo->invitereq_info.peer_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq_p2p(padapter, NULL);
_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
}
void pre_tx_provdisc_handler(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
u8 val8 = 1;
set_channel_bwmode(padapter, pwdinfo->tx_prov_disc_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq_p2p(padapter, NULL);
_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
}
void pre_tx_negoreq_handler(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
u8 val8 = 1;
set_channel_bwmode(padapter, pwdinfo->nego_req_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq_p2p(padapter , NULL);
/* WIN Phone only accept unicast probe request when nego back */
issue_probereq_p2p(padapter , pwdinfo->nego_req_info.peerDevAddr);
_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
}
#ifdef CONFIG_CONCURRENT_MODE
void p2p_concurrent_handler(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 val8;
#ifdef CONFIG_IOCTL_CFG80211
if (pwdinfo->driver_interface == DRIVER_CFG80211
&& !rtw_cfg80211_get_is_roch(padapter))
return;
#endif
if (rtw_mi_check_status(padapter, MI_LINKED)) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
u8 union_bw = rtw_mi_get_union_bw(padapter);
u8 union_offset = rtw_mi_get_union_offset(padapter);
pwdinfo->operating_channel = union_ch;
if (pwdinfo->driver_interface == DRIVER_CFG80211) {
RTW_INFO("%s, switch ch back to union=%u,%u, %u\n"
, __func__, union_ch, union_bw, union_offset);
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
rtw_back_opch(padapter);
} else if (pwdinfo->driver_interface == DRIVER_WEXT) {
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)) {
/* Now, the driver stays on the AP's channel. */
/* If the pwdinfo->ext_listen_period = 0, that means the P2P listen state is not available on listen channel. */
if (pwdinfo->ext_listen_period > 0) {
RTW_INFO("[%s] P2P_STATE_IDLE, ext_listen_period = %d\n", __FUNCTION__, pwdinfo->ext_listen_period);
if (union_ch != pwdinfo->listen_channel) {
rtw_leave_opch(padapter);
set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
}
rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
if (!rtw_mi_check_mlmeinfo_state(padapter, WIFI_FW_AP_STATE)) {
val8 = 1;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
}
/* Todo: To check the value of pwdinfo->ext_listen_period is equal to 0 or not. */
_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_period);
}
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN) ||
rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_FAIL) ||
(rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) && pwdinfo->nego_req_info.benable == _FALSE) ||
rtw_p2p_chk_state(pwdinfo, P2P_STATE_RX_PROVISION_DIS_REQ)) {
/* Now, the driver is in the listen state of P2P mode. */
RTW_INFO("[%s] P2P_STATE_IDLE, ext_listen_interval = %d\n", __FUNCTION__, pwdinfo->ext_listen_interval);
/* Commented by Albert 2012/11/01 */
/* If the AP's channel is the same as the listen channel, we should still be in the listen state */
/* Other P2P device is still able to find this device out even this device is in the AP's channel. */
/* So, configure this device to be able to receive the probe request frame and set it to listen state. */
if (union_ch != pwdinfo->listen_channel) {
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
if (!rtw_mi_check_status(padapter, MI_AP_MODE)) {
val8 = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
}
rtw_p2p_set_state(pwdinfo, P2P_STATE_IDLE);
rtw_back_opch(padapter);
}
/* Todo: To check the value of pwdinfo->ext_listen_interval is equal to 0 or not. */
_set_timer(&pwdinfo->ap_p2p_switch_timer, pwdinfo->ext_listen_interval);
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_OK)) {
/* The driver had finished the P2P handshake successfully. */
val8 = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
set_channel_bwmode(padapter, union_ch, union_offset, union_bw);
rtw_back_opch(padapter);
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ)) {
val8 = 1;
set_channel_bwmode(padapter, pwdinfo->tx_prov_disc_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq_p2p(padapter, NULL);
_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING) && pwdinfo->nego_req_info.benable == _TRUE) {
val8 = 1;
set_channel_bwmode(padapter, pwdinfo->nego_req_info.peer_channel_num[0], HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq_p2p(padapter, NULL);
_set_timer(&pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT);
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ) && pwdinfo->invitereq_info.benable == _TRUE) {
/*
val8 = 1;
set_channel_bwmode(padapter, , HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq_p2p(padapter, NULL);
_set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT );
*/
}
}
} else {
/* In p2p+softap. When in P2P_STATE_GONEGO_OK, not back to listen channel.*/
if (!rtw_p2p_chk_state(pwdinfo , P2P_STATE_GONEGO_OK) || padapter->registrypriv.full_ch_in_p2p_handshake == 0)
set_channel_bwmode(padapter, pwdinfo->listen_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
else
RTW_INFO("%s, buddy not linked, go nego ok, not back to listen channel\n", __func__);
}
}
#endif
#ifdef CONFIG_IOCTL_CFG80211
u8 roch_stay_in_cur_chan(_adapter *padapter)
{
int i;
_adapter *iface;
struct mlme_priv *pmlmepriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 rst = _FALSE;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface) {
pmlmepriv = &iface->mlmepriv;
if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING | WIFI_UNDER_WPS | WIFI_UNDER_KEY_HANDSHAKE) == _TRUE) {
RTW_INFO(ADPT_FMT"- _FW_UNDER_LINKING |WIFI_UNDER_WPS | WIFI_UNDER_KEY_HANDSHAKE (mlme state:0x%x)\n",
ADPT_ARG(iface), get_fwstate(&iface->mlmepriv));
rst = _TRUE;
break;
}
#ifdef CONFIG_AP_MODE
if (MLME_IS_AP(iface) || MLME_IS_MESH(iface)) {
if (rtw_ap_sta_states_check(iface) == _TRUE) {
rst = _TRUE;
break;
}
}
#endif
}
}
return rst;
}
static int ro_ch_handler(_adapter *adapter, u8 *buf)
{
int ret = H2C_SUCCESS;
struct p2p_roch_parm *roch_parm = (struct p2p_roch_parm *)buf;
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &adapter->cfg80211_wdinfo;
#ifdef CONFIG_CONCURRENT_MODE
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
#ifdef RTW_ROCH_BACK_OP
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
#endif
#endif
u8 ready_on_channel = _FALSE;
u8 remain_ch;
unsigned int duration;
_enter_critical_mutex(&pwdev_priv->roch_mutex, NULL);
if (rtw_cfg80211_get_is_roch(adapter) != _TRUE)
goto exit;
remain_ch = (u8)ieee80211_frequency_to_channel(roch_parm->ch.center_freq);
duration = roch_parm->duration;
RTW_INFO(FUNC_ADPT_FMT" ch:%u duration:%d, cookie:0x%llx\n"
, FUNC_ADPT_ARG(adapter), remain_ch, roch_parm->duration, roch_parm->cookie);
if (roch_parm->wdev && roch_parm->cookie) {
if (pcfg80211_wdinfo->ro_ch_wdev != roch_parm->wdev) {
RTW_WARN(FUNC_ADPT_FMT" ongoing wdev:%p, wdev:%p\n"
, FUNC_ADPT_ARG(adapter), pcfg80211_wdinfo->ro_ch_wdev, roch_parm->wdev);
rtw_warn_on(1);
}
if (pcfg80211_wdinfo->remain_on_ch_cookie != roch_parm->cookie) {
RTW_WARN(FUNC_ADPT_FMT" ongoing cookie:0x%llx, cookie:0x%llx\n"
, FUNC_ADPT_ARG(adapter), pcfg80211_wdinfo->remain_on_ch_cookie, roch_parm->cookie);
rtw_warn_on(1);
}
}
if (roch_stay_in_cur_chan(adapter) == _TRUE) {
remain_ch = rtw_mi_get_union_chan(adapter);
RTW_INFO(FUNC_ADPT_FMT" stay in union ch:%d\n", FUNC_ADPT_ARG(adapter), remain_ch);
}
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(adapter, MI_LINKED) && (0 != rtw_mi_get_union_chan(adapter))) {
if ((remain_ch != rtw_mi_get_union_chan(adapter)) && !check_fwstate(&adapter->mlmepriv, _FW_LINKED)) {
if (remain_ch != pmlmeext->cur_channel
#ifdef RTW_ROCH_BACK_OP
|| ATOMIC_READ(&pwdev_priv->switch_ch_to) == 1
#endif
) {
rtw_leave_opch(adapter);
#ifdef RTW_ROCH_BACK_OP
RTW_INFO("%s, set switch ch timer, duration=%d\n", __func__, duration - pwdinfo->ext_listen_interval);
ATOMIC_SET(&pwdev_priv->switch_ch_to, 0);
_set_timer(&pwdinfo->ap_p2p_switch_timer, duration - pwdinfo->ext_listen_interval);
#endif
}
}
ready_on_channel = _TRUE;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
if (remain_ch != rtw_get_oper_ch(adapter))
ready_on_channel = _TRUE;
}
if (ready_on_channel == _TRUE) {
#ifndef RTW_SINGLE_WIPHY
if (!check_fwstate(&adapter->mlmepriv, _FW_LINKED))
#endif
{
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_get_oper_ch(adapter) != remain_ch)
#endif
{
/* if (!padapter->mlmepriv.LinkDetectInfo.bBusyTraffic) */
set_channel_bwmode(adapter, remain_ch, HAL_PRIME_CHNL_OFFSET_DONT_CARE, CHANNEL_WIDTH_20);
}
}
}
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_ScanNotify(adapter, _TRUE);
#endif
RTW_INFO("%s, set ro ch timer, duration=%d\n", __func__, duration);
_set_timer(&pcfg80211_wdinfo->remain_on_ch_timer, duration);
exit:
_exit_critical_mutex(&pwdev_priv->roch_mutex, NULL);
return ret;
}
static int cancel_ro_ch_handler(_adapter *padapter, u8 *buf)
{
int ret = H2C_SUCCESS;
struct p2p_roch_parm *roch_parm = (struct p2p_roch_parm *)buf;
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
struct wireless_dev *wdev;
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
u8 ch, bw, offset;
_enter_critical_mutex(&pwdev_priv->roch_mutex, NULL);
if (rtw_cfg80211_get_is_roch(padapter) != _TRUE)
goto exit;
if (roch_parm->wdev && roch_parm->cookie) {
if (pcfg80211_wdinfo->ro_ch_wdev != roch_parm->wdev) {
RTW_WARN(FUNC_ADPT_FMT" ongoing wdev:%p, wdev:%p\n"
, FUNC_ADPT_ARG(padapter), pcfg80211_wdinfo->ro_ch_wdev, roch_parm->wdev);
rtw_warn_on(1);
}
if (pcfg80211_wdinfo->remain_on_ch_cookie != roch_parm->cookie) {
RTW_WARN(FUNC_ADPT_FMT" ongoing cookie:0x%llx, cookie:0x%llx\n"
, FUNC_ADPT_ARG(padapter), pcfg80211_wdinfo->remain_on_ch_cookie, roch_parm->cookie);
rtw_warn_on(1);
}
}
#if defined(RTW_ROCH_BACK_OP) && defined(CONFIG_CONCURRENT_MODE)
_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
#endif
if (rtw_mi_get_ch_setting_union(padapter, &ch, &bw, &offset) != 0) {
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to linked/linking union - ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), ch, bw, offset);
} else if (adapter_wdev_data(padapter)->p2p_enabled && pwdinfo->listen_channel) {
ch = pwdinfo->listen_channel;
bw = CHANNEL_WIDTH_20;
offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to listen ch - ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), ch, bw, offset);
} else {
ch = pcfg80211_wdinfo->restore_channel;
bw = CHANNEL_WIDTH_20;
offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
if (0)
RTW_INFO(FUNC_ADPT_FMT" back to restore ch - ch:%u, bw:%u, offset:%u\n",
FUNC_ADPT_ARG(padapter), ch, bw, offset);
}
set_channel_bwmode(padapter, ch, offset, bw);
rtw_back_opch(padapter);
rtw_p2p_set_state(pwdinfo, rtw_p2p_pre_state(pwdinfo));
#ifdef CONFIG_DEBUG_CFG80211
RTW_INFO("%s, role=%d, p2p_state=%d\n", __func__, rtw_p2p_role(pwdinfo), rtw_p2p_state(pwdinfo));
#endif
wdev = pcfg80211_wdinfo->ro_ch_wdev;
rtw_cfg80211_set_is_roch(padapter, _FALSE);
pcfg80211_wdinfo->ro_ch_wdev = NULL;
rtw_cfg80211_set_last_ro_ch_time(padapter);
rtw_cfg80211_remain_on_channel_expired(wdev
, pcfg80211_wdinfo->remain_on_ch_cookie
, &pcfg80211_wdinfo->remain_on_ch_channel
, pcfg80211_wdinfo->remain_on_ch_type, GFP_KERNEL);
RTW_INFO("cfg80211_remain_on_channel_expired cookie:0x%llx\n"
, pcfg80211_wdinfo->remain_on_ch_cookie);
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_ScanNotify(padapter, _FALSE);
#endif
exit:
_exit_critical_mutex(&pwdev_priv->roch_mutex, NULL);
return ret;
}
static void ro_ch_timer_process(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
p2p_cancel_roch_cmd(adapter, 0, NULL, 0);
}
#if 0
static void rtw_change_p2pie_op_ch(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)
{
u8 *ies, *p2p_ie;
u32 ies_len, p2p_ielen;
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter))
return;
#endif /* CONFIG_MCC_MODE */
ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
u32 attr_contentlen = 0;
u8 *pattr = NULL;
/* Check P2P_ATTR_OPERATING_CH */
attr_contentlen = 0;
pattr = NULL;
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint *)&attr_contentlen);
if (pattr != NULL)
*(pattr + 4) = ch;
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
}
#endif
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
static void rtw_change_p2pie_ch_list(_adapter *padapter, const u8 *frame_body, u32 len, u8 ch)
{
u8 *ies, *p2p_ie;
u32 ies_len, p2p_ielen;
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter))
return;
#endif /* CONFIG_MCC_MODE */
ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
u32 attr_contentlen = 0;
u8 *pattr = NULL;
/* Check P2P_ATTR_CH_LIST */
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint *)&attr_contentlen);
if (pattr != NULL) {
int i;
u32 num_of_ch;
u8 *pattr_temp = pattr + 3 ;
attr_contentlen -= 3;
while (attr_contentlen > 0) {
num_of_ch = *(pattr_temp + 1);
for (i = 0; i < num_of_ch; i++)
*(pattr_temp + 2 + i) = ch;
pattr_temp += (2 + num_of_ch);
attr_contentlen -= (2 + num_of_ch);
}
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
}
#endif
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
static bool rtw_chk_p2pie_ch_list_with_buddy(_adapter *padapter, const u8 *frame_body, u32 len)
{
bool fit = _FALSE;
u8 *ies, *p2p_ie;
u32 ies_len, p2p_ielen;
u8 union_ch = rtw_mi_get_union_chan(padapter);
ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
u32 attr_contentlen = 0;
u8 *pattr = NULL;
/* Check P2P_ATTR_CH_LIST */
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint *)&attr_contentlen);
if (pattr != NULL) {
int i;
u32 num_of_ch;
u8 *pattr_temp = pattr + 3 ;
attr_contentlen -= 3;
while (attr_contentlen > 0) {
num_of_ch = *(pattr_temp + 1);
for (i = 0; i < num_of_ch; i++) {
if (*(pattr_temp + 2 + i) == union_ch) {
RTW_INFO(FUNC_ADPT_FMT" ch_list fit buddy_ch:%u\n", FUNC_ADPT_ARG(padapter), union_ch);
fit = _TRUE;
break;
}
}
pattr_temp += (2 + num_of_ch);
attr_contentlen -= (2 + num_of_ch);
}
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
return fit;
}
#if defined(CONFIG_P2P_INVITE_IOT)
static bool rtw_chk_p2pie_op_ch_with_buddy(_adapter *padapter, const u8 *frame_body, u32 len)
{
bool fit = _FALSE;
u8 *ies, *p2p_ie;
u32 ies_len, p2p_ielen;
u8 union_ch = rtw_mi_get_union_chan(padapter);
ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
u32 attr_contentlen = 0;
u8 *pattr = NULL;
/* Check P2P_ATTR_OPERATING_CH */
attr_contentlen = 0;
pattr = NULL;
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint *)&attr_contentlen);
if (pattr != NULL) {
if (*(pattr + 4) == union_ch) {
RTW_INFO(FUNC_ADPT_FMT" op_ch fit buddy_ch:%u\n", FUNC_ADPT_ARG(padapter), union_ch);
fit = _TRUE;
break;
}
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
return fit;
}
#endif
static void rtw_cfg80211_adjust_p2pie_channel(_adapter *padapter, const u8 *frame_body, u32 len)
{
u8 *ies, *p2p_ie;
u32 ies_len, p2p_ielen;
u8 union_ch = rtw_mi_get_union_chan(padapter);
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter))
return;
#endif /* CONFIG_MCC_MODE */
ies = (u8 *)(frame_body + _PUBLIC_ACTION_IE_OFFSET_);
ies_len = len - _PUBLIC_ACTION_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
u32 attr_contentlen = 0;
u8 *pattr = NULL;
/* Check P2P_ATTR_CH_LIST */
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, (uint *)&attr_contentlen);
if (pattr != NULL) {
int i;
u32 num_of_ch;
u8 *pattr_temp = pattr + 3 ;
attr_contentlen -= 3;
while (attr_contentlen > 0) {
num_of_ch = *(pattr_temp + 1);
for (i = 0; i < num_of_ch; i++) {
if (*(pattr_temp + 2 + i) && *(pattr_temp + 2 + i) != union_ch) {
#ifdef RTW_SINGLE_WIPHY
RTW_ERR("replace ch_list:%u with:%u\n", *(pattr_temp + 2 + i), union_ch);
#endif
*(pattr_temp + 2 + i) = union_ch; /*forcing to the same channel*/
}
}
pattr_temp += (2 + num_of_ch);
attr_contentlen -= (2 + num_of_ch);
}
}
/* Check P2P_ATTR_OPERATING_CH */
attr_contentlen = 0;
pattr = NULL;
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, (uint *)&attr_contentlen);
if (pattr != NULL) {
if (*(pattr + 4) && *(pattr + 4) != union_ch) {
#ifdef RTW_SINGLE_WIPHY
RTW_ERR("replace op_ch:%u with:%u\n", *(pattr + 4), union_ch);
#endif
*(pattr + 4) = union_ch; /*forcing to the same channel */
}
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
}
#endif
#ifdef CONFIG_WFD
u32 rtw_xframe_build_wfd_ie(struct xmit_frame *xframe)
{
_adapter *adapter = xframe->padapter;
struct wifidirect_info *wdinfo = &adapter->wdinfo;
u8 *frame = xframe->buf_addr + TXDESC_OFFSET;
u8 *frame_body = frame + sizeof(struct rtw_ieee80211_hdr_3addr);
u8 *frame_tail = frame + xframe->attrib.pktlen;
u8 category, action, OUI_Subtype, dialogToken = 0;
u32 wfdielen = 0;
category = frame_body[0];
if (category == RTW_WLAN_CATEGORY_PUBLIC) {
action = frame_body[1];
if (action == ACT_PUBLIC_VENDOR
&& _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
) {
OUI_Subtype = frame_body[6];
dialogToken = frame_body[7];
switch (OUI_Subtype) {
case P2P_GO_NEGO_REQ:
wfdielen = build_nego_req_wfd_ie(wdinfo, frame_tail);
break;
case P2P_GO_NEGO_RESP:
wfdielen = build_nego_resp_wfd_ie(wdinfo, frame_tail);
break;
case P2P_GO_NEGO_CONF:
wfdielen = build_nego_confirm_wfd_ie(wdinfo, frame_tail);
break;
case P2P_INVIT_REQ:
wfdielen = build_invitation_req_wfd_ie(wdinfo, frame_tail);
break;
case P2P_INVIT_RESP:
wfdielen = build_invitation_resp_wfd_ie(wdinfo, frame_tail);
break;
case P2P_PROVISION_DISC_REQ:
wfdielen = build_provdisc_req_wfd_ie(wdinfo, frame_tail);
break;
case P2P_PROVISION_DISC_RESP:
wfdielen = build_provdisc_resp_wfd_ie(wdinfo, frame_tail);
break;
case P2P_DEVDISC_REQ:
case P2P_DEVDISC_RESP:
default:
break;
}
}
} else if (category == RTW_WLAN_CATEGORY_P2P) {
OUI_Subtype = frame_body[5];
dialogToken = frame_body[6];
#ifdef CONFIG_DEBUG_CFG80211
RTW_INFO("ACTION_CATEGORY_P2P: OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n"
, cpu_to_be32(*((u32 *)(frame_body + 1))), OUI_Subtype, dialogToken);
#endif
switch (OUI_Subtype) {
case P2P_NOTICE_OF_ABSENCE:
break;
case P2P_PRESENCE_REQUEST:
break;
case P2P_PRESENCE_RESPONSE:
break;
case P2P_GO_DISC_REQUEST:
break;
default:
break;
}
} else
RTW_INFO("%s, action frame category=%d\n", __func__, category);
xframe->attrib.pktlen += wfdielen;
return wfdielen;
}
#endif /* CONFIG_WFD */
bool rtw_xframe_del_wfd_ie(struct xmit_frame *xframe)
{
#define DBG_XFRAME_DEL_WFD_IE 0
u8 *frame = xframe->buf_addr + TXDESC_OFFSET;
u8 *frame_body = frame + sizeof(struct rtw_ieee80211_hdr_3addr);
u8 *frame_tail = frame + xframe->attrib.pktlen;
u8 category, action, OUI_Subtype;
u8 *ies = NULL;
uint ies_len_ori = 0;
uint ies_len = 0;
category = frame_body[0];
if (category == RTW_WLAN_CATEGORY_PUBLIC) {
action = frame_body[1];
if (action == ACT_PUBLIC_VENDOR
&& _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
) {
OUI_Subtype = frame_body[6];
switch (OUI_Subtype) {
case P2P_GO_NEGO_REQ:
case P2P_GO_NEGO_RESP:
case P2P_GO_NEGO_CONF:
case P2P_INVIT_REQ:
case P2P_INVIT_RESP:
case P2P_PROVISION_DISC_REQ:
case P2P_PROVISION_DISC_RESP:
ies = frame_body + 8;
ies_len_ori = frame_tail - (frame_body + 8);
break;
}
}
}
if (ies && ies_len_ori) {
ies_len = rtw_del_wfd_ie(ies, ies_len_ori, DBG_XFRAME_DEL_WFD_IE ? __func__ : NULL);
xframe->attrib.pktlen -= (ies_len_ori - ies_len);
}
return ies_len_ori != ies_len;
}
/*
* rtw_xframe_chk_wfd_ie -
*
*/
void rtw_xframe_chk_wfd_ie(struct xmit_frame *xframe)
{
_adapter *adapter = xframe->padapter;
#ifdef CONFIG_IOCTL_CFG80211
struct wifidirect_info *wdinfo = &adapter->wdinfo;
#endif
u8 build = 0;
u8 del = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
del = 1;
#ifdef CONFIG_IOCTL_CFG80211
if (wdinfo->wfd_info->wfd_enable == _TRUE)
#endif
del = build = 1;
if (del)
rtw_xframe_del_wfd_ie(xframe);
#ifdef CONFIG_WFD
if (build)
rtw_xframe_build_wfd_ie(xframe);
#endif
}
u8 *dump_p2p_attr_ch_list(u8 *p2p_ie, uint p2p_ielen, u8 *buf, u32 buf_len)
{
uint attr_contentlen = 0;
u8 *pattr = NULL;
int w_sz = 0;
u8 ch_cnt = 0;
u8 ch_list[40];
pattr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_CH_LIST, NULL, &attr_contentlen);
if (pattr != NULL) {
int i, j;
u32 num_of_ch;
u8 *pattr_temp = pattr + 3 ;
attr_contentlen -= 3;
_rtw_memset(ch_list, 0, 40);
while (attr_contentlen > 0) {
num_of_ch = *(pattr_temp + 1);
for (i = 0; i < num_of_ch; i++) {
for (j = 0; j < ch_cnt; j++) {
if (ch_list[j] == *(pattr_temp + 2 + i))
break;
}
if (j >= ch_cnt)
ch_list[ch_cnt++] = *(pattr_temp + 2 + i);
}
pattr_temp += (2 + num_of_ch);
attr_contentlen -= (2 + num_of_ch);
}
for (j = 0; j < ch_cnt; j++) {
if (j == 0)
w_sz += snprintf(buf + w_sz, buf_len - w_sz, "%u", ch_list[j]);
else if (ch_list[j] - ch_list[j - 1] != 1)
w_sz += snprintf(buf + w_sz, buf_len - w_sz, ", %u", ch_list[j]);
else if (j != ch_cnt - 1 && ch_list[j + 1] - ch_list[j] == 1) {
/* empty */
} else
w_sz += snprintf(buf + w_sz, buf_len - w_sz, "-%u", ch_list[j]);
}
}
return buf;
}
/*
* return _TRUE if requester is GO, _FALSE if responder is GO
*/
bool rtw_p2p_nego_intent_compare(u8 req, u8 resp)
{
if (req >> 1 == resp >> 1)
return req & 0x01 ? _TRUE : _FALSE;
else if (req >> 1 > resp >> 1)
return _TRUE;
else
return _FALSE;
}
int rtw_p2p_check_frames(_adapter *padapter, const u8 *buf, u32 len, u8 tx)
{
int is_p2p_frame = (-1);
unsigned char *frame_body;
u8 category, action, OUI_Subtype, dialogToken = 0;
u8 *p2p_ie = NULL;
uint p2p_ielen = 0;
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(padapter);
int status = -1;
u8 ch_list_buf[128] = {'\0'};
int op_ch = -1;
int listen_ch = -1;
u8 intent = 0;
u8 *iaddr = NULL;
u8 *gbssid = NULL;
frame_body = (unsigned char *)(buf + sizeof(struct rtw_ieee80211_hdr_3addr));
category = frame_body[0];
/* just for check */
if (category == RTW_WLAN_CATEGORY_PUBLIC) {
action = frame_body[1];
if (action == ACT_PUBLIC_VENDOR
&& _rtw_memcmp(frame_body + 2, P2P_OUI, 4) == _TRUE
) {
OUI_Subtype = frame_body[6];
dialogToken = frame_body[7];
is_p2p_frame = OUI_Subtype;
#ifdef CONFIG_DEBUG_CFG80211
RTW_INFO("ACTION_CATEGORY_PUBLIC: ACT_PUBLIC_VENDOR, OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n",
cpu_to_be32(*((u32 *)(frame_body + 2))), OUI_Subtype, dialogToken);
#endif
p2p_ie = rtw_get_p2p_ie(
(u8 *)buf + sizeof(struct rtw_ieee80211_hdr_3addr) + _PUBLIC_ACTION_IE_OFFSET_
, len - sizeof(struct rtw_ieee80211_hdr_3addr) - _PUBLIC_ACTION_IE_OFFSET_
, NULL, &p2p_ielen);
switch (OUI_Subtype) { /* OUI Subtype */
u8 *cont;
uint cont_len;
case P2P_GO_NEGO_REQ: {
struct rtw_wdev_nego_info *nego_info = &pwdev_priv->nego_info;
if (tx) {
#ifdef CONFIG_DRV_ISSUE_PROV_REQ /* IOT FOR S2 */
if (pwdev_priv->provdisc_req_issued == _FALSE)
rtw_cfg80211_issue_p2p_provision_request(padapter, buf, len);
#endif /* CONFIG_DRV_ISSUE_PROV_REQ */
/* pwdev_priv->provdisc_req_issued = _FALSE; */
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
#endif
}
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
if (cont)
op_ch = *(cont + 4);
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_LISTEN_CH, NULL, &cont_len);
if (cont)
listen_ch = *(cont + 4);
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT, NULL, &cont_len);
if (cont)
intent = *cont;
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, NULL, &cont_len);
if (cont && cont_len == 6)
iaddr = cont;
if (nego_info->token != dialogToken)
rtw_wdev_nego_info_init(nego_info);
_rtw_memcpy(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN);
if (iaddr)
_rtw_memcpy(tx ? nego_info->iface_addr : nego_info->peer_iface_addr, iaddr, ETH_ALEN);
nego_info->active = tx ? 1 : 0;
nego_info->token = dialogToken;
nego_info->req_op_ch = op_ch;
nego_info->req_listen_ch = listen_ch;
nego_info->req_intent = intent;
nego_info->state = 0;
dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
RTW_INFO("RTW_%s:P2P_GO_NEGO_REQ, dialogToken=%d, intent:%u%s, listen_ch:%d, op_ch:%d, ch_list:%s"
, (tx == _TRUE) ? "Tx" : "Rx" , dialogToken , (intent >> 1) , intent & 0x1 ? "+" : "-" , listen_ch , op_ch , ch_list_buf);
if (iaddr)
_RTW_INFO(", iaddr:"MAC_FMT, MAC_ARG(iaddr));
_RTW_INFO("\n");
if (!tx) {
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED)
&& rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE
&& padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
}
#endif
}
break;
}
case P2P_GO_NEGO_RESP: {
struct rtw_wdev_nego_info *nego_info = &pwdev_priv->nego_info;
if (tx) {
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
#endif
}
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
if (cont)
op_ch = *(cont + 4);
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GO_INTENT, NULL, &cont_len);
if (cont)
intent = *cont;
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
if (cont)
status = *cont;
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INTENDED_IF_ADDR, NULL, &cont_len);
if (cont && cont_len == 6)
iaddr = cont;
if (nego_info->token == dialogToken && nego_info->state == 0
&& _rtw_memcmp(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN) == _TRUE
) {
if (iaddr)
_rtw_memcpy(tx ? nego_info->iface_addr : nego_info->peer_iface_addr, iaddr, ETH_ALEN);
nego_info->status = (status == -1) ? 0xff : status;
nego_info->rsp_op_ch = op_ch;
nego_info->rsp_intent = intent;
nego_info->state = 1;
if (status != 0)
nego_info->token = 0; /* init */
}
dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
RTW_INFO("RTW_%s:P2P_GO_NEGO_RESP, dialogToken=%d, intent:%u%s, status:%d, op_ch:%d, ch_list:%s"
, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, (intent >> 1), intent & 0x1 ? "+" : "-", status, op_ch, ch_list_buf);
if (iaddr)
_RTW_INFO(", iaddr:"MAC_FMT, MAC_ARG(iaddr));
_RTW_INFO("\n");
if (!tx) {
pwdev_priv->provdisc_req_issued = _FALSE;
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED)
&& rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE
&& padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
}
#endif
}
break;
}
case P2P_GO_NEGO_CONF: {
struct rtw_wdev_nego_info *nego_info = &pwdev_priv->nego_info;
bool is_go = _FALSE;
if (tx) {
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
#endif
}
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
if (cont)
op_ch = *(cont + 4);
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
if (cont)
status = *cont;
if (nego_info->token == dialogToken && nego_info->state == 1
&& _rtw_memcmp(nego_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN) == _TRUE
) {
nego_info->status = (status == -1) ? 0xff : status;
nego_info->conf_op_ch = (op_ch == -1) ? 0 : op_ch;
nego_info->state = 2;
if (status == 0) {
if (rtw_p2p_nego_intent_compare(nego_info->req_intent, nego_info->rsp_intent) ^ !tx)
is_go = _TRUE;
}
nego_info->token = 0; /* init */
}
dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
RTW_INFO("RTW_%s:P2P_GO_NEGO_CONF, dialogToken=%d, status:%d, op_ch:%d, ch_list:%s\n"
, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, status, op_ch, ch_list_buf);
if (!tx) {
}
break;
}
case P2P_INVIT_REQ: {
struct rtw_wdev_invit_info *invit_info = &pwdev_priv->invit_info;
int flags = -1;
if (tx) {
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED)
&& padapter->registrypriv.full_ch_in_p2p_handshake == 0)
rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
#endif
}
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_INVITATION_FLAGS, NULL, &cont_len);
if (cont)
flags = *cont;
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
if (cont)
op_ch = *(cont + 4);
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_BSSID, NULL, &cont_len);
if (cont && cont_len == 6)
gbssid = cont;
if (invit_info->token != dialogToken)
rtw_wdev_invit_info_init(invit_info);
_rtw_memcpy(invit_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN);
if (gbssid)
_rtw_memcpy(invit_info->group_bssid, gbssid, ETH_ALEN);
invit_info->active = tx ? 1 : 0;
invit_info->token = dialogToken;
invit_info->flags = (flags == -1) ? 0x0 : flags;
invit_info->req_op_ch = op_ch;
invit_info->state = 0;
dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
RTW_INFO("RTW_%s:P2P_INVIT_REQ, dialogToken=%d, flags:0x%02x, op_ch:%d, ch_list:%s"
, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, flags, op_ch, ch_list_buf);
if (gbssid)
_RTW_INFO(", gbssid:"MAC_FMT, MAC_ARG(gbssid));
_RTW_INFO("\n");
if (!tx) {
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0) {
#if defined(CONFIG_P2P_INVITE_IOT)
if (op_ch != -1 && rtw_chk_p2pie_op_ch_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
RTW_INFO(FUNC_ADPT_FMT" op_ch:%u has no intersect with buddy\n", FUNC_ADPT_ARG(padapter), op_ch);
rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
} else
#endif
if (rtw_chk_p2pie_ch_list_with_buddy(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr)) == _FALSE) {
RTW_INFO(FUNC_ADPT_FMT" ch_list has no intersect with buddy\n", FUNC_ADPT_ARG(padapter));
rtw_change_p2pie_ch_list(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr), 0);
}
}
#endif
}
break;
}
case P2P_INVIT_RESP: {
struct rtw_wdev_invit_info *invit_info = &pwdev_priv->invit_info;
if (tx) {
#if defined(CONFIG_CONCURRENT_MODE) && defined(CONFIG_CFG80211_ONECHANNEL_UNDER_CONCURRENT)
if (rtw_mi_check_status(padapter, MI_LINKED) && padapter->registrypriv.full_ch_in_p2p_handshake == 0)
rtw_cfg80211_adjust_p2pie_channel(padapter, frame_body, len - sizeof(struct rtw_ieee80211_hdr_3addr));
#endif
}
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
if (cont) {
#ifdef CONFIG_P2P_INVITE_IOT
if (tx && *cont == 7) {
RTW_INFO("TX_P2P_INVITE_RESP, status is no common channel, change to unknown group\n");
*cont = 8; /* unknow group status */
}
#endif /* CONFIG_P2P_INVITE_IOT */
status = *cont;
}
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_OPERATING_CH, NULL, &cont_len);
if (cont)
op_ch = *(cont + 4);
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_BSSID, NULL, &cont_len);
if (cont && cont_len == 6)
gbssid = cont;
if (invit_info->token == dialogToken && invit_info->state == 0
&& _rtw_memcmp(invit_info->peer_mac, tx ? GetAddr1Ptr(buf) : get_addr2_ptr(buf), ETH_ALEN) == _TRUE
) {
invit_info->status = (status == -1) ? 0xff : status;
invit_info->rsp_op_ch = op_ch;
invit_info->state = 1;
invit_info->token = 0; /* init */
}
dump_p2p_attr_ch_list(p2p_ie, p2p_ielen, ch_list_buf, 128);
RTW_INFO("RTW_%s:P2P_INVIT_RESP, dialogToken=%d, status:%d, op_ch:%d, ch_list:%s"
, (tx == _TRUE) ? "Tx" : "Rx", dialogToken, status, op_ch, ch_list_buf);
if (gbssid)
_RTW_INFO(", gbssid:"MAC_FMT, MAC_ARG(gbssid));
_RTW_INFO("\n");
if (!tx) {
}
break;
}
case P2P_DEVDISC_REQ:
RTW_INFO("RTW_%s:P2P_DEVDISC_REQ, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
break;
case P2P_DEVDISC_RESP:
cont = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_STATUS, NULL, &cont_len);
RTW_INFO("RTW_%s:P2P_DEVDISC_RESP, dialogToken=%d, status:%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken, cont ? *cont : -1);
break;
case P2P_PROVISION_DISC_REQ: {
size_t frame_body_len = len - sizeof(struct rtw_ieee80211_hdr_3addr);
u8 *p2p_ie;
uint p2p_ielen = 0;
uint contentlen = 0;
RTW_INFO("RTW_%s:P2P_PROVISION_DISC_REQ, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
/* if(tx) */
{
pwdev_priv->provdisc_req_issued = _FALSE;
p2p_ie = rtw_get_p2p_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, frame_body_len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &p2p_ielen);
if (p2p_ie) {
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_GROUP_ID, NULL, &contentlen)) {
pwdev_priv->provdisc_req_issued = _FALSE;/* case: p2p_client join p2p GO */
} else {
#ifdef CONFIG_DEBUG_CFG80211
RTW_INFO("provdisc_req_issued is _TRUE\n");
#endif /*CONFIG_DEBUG_CFG80211*/
pwdev_priv->provdisc_req_issued = _TRUE;/* case: p2p_devices connection before Nego req. */
}
}
}
}
break;
case P2P_PROVISION_DISC_RESP:
RTW_INFO("RTW_%s:P2P_PROVISION_DISC_RESP, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
break;
default:
RTW_INFO("RTW_%s:OUI_Subtype=%d, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", OUI_Subtype, dialogToken);
break;
}
}
} else if (category == RTW_WLAN_CATEGORY_P2P) {
OUI_Subtype = frame_body[5];
dialogToken = frame_body[6];
#ifdef CONFIG_DEBUG_CFG80211
RTW_INFO("ACTION_CATEGORY_P2P: OUI=0x%x, OUI_Subtype=%d, dialogToken=%d\n",
cpu_to_be32(*((u32 *)(frame_body + 1))), OUI_Subtype, dialogToken);
#endif
is_p2p_frame = OUI_Subtype;
switch (OUI_Subtype) {
case P2P_NOTICE_OF_ABSENCE:
RTW_INFO("RTW_%s:P2P_NOTICE_OF_ABSENCE, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
break;
case P2P_PRESENCE_REQUEST:
RTW_INFO("RTW_%s:P2P_PRESENCE_REQUEST, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
break;
case P2P_PRESENCE_RESPONSE:
RTW_INFO("RTW_%s:P2P_PRESENCE_RESPONSE, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
break;
case P2P_GO_DISC_REQUEST:
RTW_INFO("RTW_%s:P2P_GO_DISC_REQUEST, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", dialogToken);
break;
default:
RTW_INFO("RTW_%s:OUI_Subtype=%d, dialogToken=%d\n", (tx == _TRUE) ? "Tx" : "Rx", OUI_Subtype, dialogToken);
break;
}
}
return is_p2p_frame;
}
void rtw_init_cfg80211_wifidirect_info(_adapter *padapter)
{
struct cfg80211_wifidirect_info *pcfg80211_wdinfo = &padapter->cfg80211_wdinfo;
_rtw_memset(pcfg80211_wdinfo, 0x00, sizeof(struct cfg80211_wifidirect_info));
rtw_init_timer(&pcfg80211_wdinfo->remain_on_ch_timer, padapter, ro_ch_timer_process, padapter);
}
#endif /* CONFIG_IOCTL_CFG80211 */
s32 p2p_protocol_wk_hdl(_adapter *padapter, int intCmdType, u8 *buf)
{
int ret = H2C_SUCCESS;
switch (intCmdType) {
case P2P_FIND_PHASE_WK:
find_phase_handler(padapter);
break;
case P2P_RESTORE_STATE_WK:
restore_p2p_state_handler(padapter);
break;
case P2P_PRE_TX_PROVDISC_PROCESS_WK:
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED))
p2p_concurrent_handler(padapter);
else
pre_tx_provdisc_handler(padapter);
#else
pre_tx_provdisc_handler(padapter);
#endif
break;
case P2P_PRE_TX_INVITEREQ_PROCESS_WK:
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED))
p2p_concurrent_handler(padapter);
else
pre_tx_invitereq_handler(padapter);
#else
pre_tx_invitereq_handler(padapter);
#endif
break;
case P2P_PRE_TX_NEGOREQ_PROCESS_WK:
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED))
p2p_concurrent_handler(padapter);
else
pre_tx_negoreq_handler(padapter);
#else
pre_tx_negoreq_handler(padapter);
#endif
break;
#ifdef CONFIG_CONCURRENT_MODE
case P2P_AP_P2P_CH_SWITCH_PROCESS_WK:
p2p_concurrent_handler(padapter);
break;
#endif
#ifdef CONFIG_IOCTL_CFG80211
case P2P_RO_CH_WK:
ret = ro_ch_handler(padapter, buf);
break;
case P2P_CANCEL_RO_CH_WK:
ret = cancel_ro_ch_handler(padapter, buf);
break;
#endif
default:
rtw_warn_on(1);
break;
}
return ret;
}
int process_p2p_cross_connect_ie(PADAPTER padapter, u8 *IEs, u32 IELength)
{
int ret = _TRUE;
u8 *ies;
u32 ies_len;
u8 *p2p_ie;
u32 p2p_ielen = 0;
u8 p2p_attr[MAX_P2P_IE_LEN] = { 0x00 };/* NoA length should be n*(13) + 2 */
u32 attr_contentlen = 0;
if (IELength <= _BEACON_IE_OFFSET_)
return ret;
ies = IEs + _BEACON_IE_OFFSET_;
ies_len = IELength - _BEACON_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
/* Get P2P Manageability IE. */
if (rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_MANAGEABILITY, p2p_attr, &attr_contentlen)) {
if ((p2p_attr[0] & (BIT(0) | BIT(1))) == 0x01)
ret = _FALSE;
break;
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
return ret;
}
#ifdef CONFIG_P2P_PS
void process_p2p_ps_ie(PADAPTER padapter, u8 *IEs, u32 IELength)
{
u8 *ies;
u32 ies_len;
u8 *p2p_ie;
u32 p2p_ielen = 0;
u8 *noa_attr; /* NoA length should be n*(13) + 2 */
u32 attr_contentlen = 0;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 find_p2p = _FALSE, find_p2p_ps = _FALSE;
u8 noa_offset, noa_num, noa_index;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
#ifdef CONFIG_CONCURRENT_MODE
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
if (padapter->hw_port != HW_PORT0)
return;
#endif
#endif
if (IELength <= _BEACON_IE_OFFSET_)
return;
ies = IEs + _BEACON_IE_OFFSET_;
ies_len = IELength - _BEACON_IE_OFFSET_;
p2p_ie = rtw_get_p2p_ie(ies, ies_len, NULL, &p2p_ielen);
while (p2p_ie) {
find_p2p = _TRUE;
/* Get Notice of Absence IE. */
noa_attr = rtw_get_p2p_attr_content(p2p_ie, p2p_ielen, P2P_ATTR_NOA, NULL, &attr_contentlen);
if (noa_attr) {
find_p2p_ps = _TRUE;
noa_index = noa_attr[0];
if ((pwdinfo->p2p_ps_mode == P2P_PS_NONE) ||
(noa_index != pwdinfo->noa_index)) { /* if index change, driver should reconfigure related setting. */
pwdinfo->noa_index = noa_index;
pwdinfo->opp_ps = noa_attr[1] >> 7;
pwdinfo->ctwindow = noa_attr[1] & 0x7F;
noa_offset = 2;
noa_num = 0;
/* NoA length should be n*(13) + 2 */
if (attr_contentlen > 2 && (attr_contentlen - 2) % 13 == 0) {
while (noa_offset < attr_contentlen && noa_num < P2P_MAX_NOA_NUM) {
/* _rtw_memcpy(&wifidirect_info->noa_count[noa_num], &noa_attr[noa_offset], 1); */
pwdinfo->noa_count[noa_num] = noa_attr[noa_offset];
noa_offset += 1;
_rtw_memcpy(&pwdinfo->noa_duration[noa_num], &noa_attr[noa_offset], 4);
noa_offset += 4;
_rtw_memcpy(&pwdinfo->noa_interval[noa_num], &noa_attr[noa_offset], 4);
noa_offset += 4;
_rtw_memcpy(&pwdinfo->noa_start_time[noa_num], &noa_attr[noa_offset], 4);
noa_offset += 4;
noa_num++;
}
}
pwdinfo->noa_num = noa_num;
if (pwdinfo->opp_ps == 1) {
pwdinfo->p2p_ps_mode = P2P_PS_CTWINDOW;
/* driver should wait LPS for entering CTWindow */
if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 1);
} else if (pwdinfo->noa_num > 0) {
pwdinfo->p2p_ps_mode = P2P_PS_NOA;
p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 1);
} else if (pwdinfo->p2p_ps_mode > P2P_PS_NONE)
p2p_ps_wk_cmd(padapter, P2P_PS_DISABLE, 1);
}
break; /* find target, just break. */
}
/* Get the next P2P IE */
p2p_ie = rtw_get_p2p_ie(p2p_ie + p2p_ielen, ies_len - (p2p_ie - ies + p2p_ielen), NULL, &p2p_ielen);
}
if (find_p2p == _TRUE) {
if ((pwdinfo->p2p_ps_mode > P2P_PS_NONE) && (find_p2p_ps == _FALSE))
p2p_ps_wk_cmd(padapter, P2P_PS_DISABLE, 1);
}
}
void p2p_ps_wk_hdl(_adapter *padapter, u8 p2p_ps_state)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u32 ps_deny = 0;
/* Pre action for p2p state */
switch (p2p_ps_state) {
case P2P_PS_DISABLE:
pwdinfo->p2p_ps_state = p2p_ps_state;
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
pwdinfo->noa_index = 0;
pwdinfo->ctwindow = 0;
pwdinfo->opp_ps = 0;
pwdinfo->noa_num = 0;
pwdinfo->p2p_ps_mode = P2P_PS_NONE;
if (pwrpriv->bFwCurrentInPSMode == _TRUE) {
if (pwrpriv->smart_ps == 0) {
pwrpriv->smart_ps = 2;
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&(pwrpriv->pwr_mode)));
}
}
break;
case P2P_PS_ENABLE:
_enter_pwrlock(&adapter_to_pwrctl(padapter)->lock);
ps_deny = rtw_ps_deny_get(padapter);
_exit_pwrlock(&adapter_to_pwrctl(padapter)->lock);
if ((ps_deny & (PS_DENY_SCAN | PS_DENY_JOIN))
|| rtw_mi_check_fwstate(padapter, (_FW_UNDER_SURVEY | _FW_UNDER_LINKING))) {
pwdinfo->p2p_ps_mode = P2P_PS_NONE;
RTW_DBG(FUNC_ADPT_FMT" Block P2P PS under site survey or LINKING\n", FUNC_ADPT_ARG(padapter));
return;
}
if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter)) {
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
RTW_INFO("P2P PS enble under MCC\n");
rtw_warn_on(1);
}
}
#endif /* CONFIG_MCC_MODE */
pwdinfo->p2p_ps_state = p2p_ps_state;
if (pwdinfo->ctwindow > 0) {
if (pwrpriv->smart_ps != 0) {
pwrpriv->smart_ps = 0;
RTW_INFO("%s(): Enter CTW, change SmartPS\n", __FUNCTION__);
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&(pwrpriv->pwr_mode)));
}
}
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
}
break;
case P2P_PS_SCAN:
case P2P_PS_SCAN_DONE:
case P2P_PS_ALLSTASLEEP:
if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
pwdinfo->p2p_ps_state = p2p_ps_state;
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
}
break;
default:
break;
}
#ifdef CONFIG_MCC_MODE
rtw_hal_mcc_process_noa(padapter);
#endif /* CONFIG_MCC_MODE */
}
u8 p2p_ps_wk_cmd(_adapter *padapter, u8 p2p_ps_state, u8 enqueue)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
#ifdef CONFIG_CONCURRENT_MODE
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
|| (padapter->hw_port != HW_PORT0)
#endif
#endif
)
return res;
if (enqueue) {
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = P2P_PS_WK_CID;
pdrvextra_cmd_parm->type = p2p_ps_state;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
} else
p2p_ps_wk_hdl(padapter, p2p_ps_state);
exit:
return res;
}
#endif /* CONFIG_P2P_PS */
static void reset_ch_sitesurvey_timer_process(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
RTW_INFO("[%s] In\n", __FUNCTION__);
/* Reset the operation channel information */
pwdinfo->rx_invitereq_info.operation_ch[0] = 0;
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->rx_invitereq_info.operation_ch[1] = 0;
pwdinfo->rx_invitereq_info.operation_ch[2] = 0;
pwdinfo->rx_invitereq_info.operation_ch[3] = 0;
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->rx_invitereq_info.scan_op_ch_only = 0;
}
static void reset_ch_sitesurvey_timer_process2(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
RTW_INFO("[%s] In\n", __FUNCTION__);
/* Reset the operation channel information */
pwdinfo->p2p_info.operation_ch[0] = 0;
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->p2p_info.operation_ch[1] = 0;
pwdinfo->p2p_info.operation_ch[2] = 0;
pwdinfo->p2p_info.operation_ch[3] = 0;
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->p2p_info.scan_op_ch_only = 0;
}
static void restore_p2p_state_timer_process(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
p2p_protocol_wk_cmd(adapter, P2P_RESTORE_STATE_WK);
}
static void pre_tx_scan_timer_process(void *FunctionContext)
{
_adapter *adapter = (_adapter *) FunctionContext;
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
_irqL irqL;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
_enter_critical_bh(&pmlmepriv->lock, &irqL);
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_PROVISION_DIS_REQ)) {
if (_TRUE == pwdinfo->tx_prov_disc_info.benable) { /* the provision discovery request frame is trigger to send or not */
p2p_protocol_wk_cmd(adapter, P2P_PRE_TX_PROVDISC_PROCESS_WK);
/* issue_probereq_p2p(adapter, NULL); */
/* _set_timer( &pwdinfo->pre_tx_scan_timer, P2P_TX_PRESCAN_TIMEOUT ); */
}
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_GONEGO_ING)) {
if (_TRUE == pwdinfo->nego_req_info.benable)
p2p_protocol_wk_cmd(adapter, P2P_PRE_TX_NEGOREQ_PROCESS_WK);
} else if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_TX_INVITE_REQ)) {
if (_TRUE == pwdinfo->invitereq_info.benable)
p2p_protocol_wk_cmd(adapter, P2P_PRE_TX_INVITEREQ_PROCESS_WK);
} else
RTW_INFO("[%s] p2p_state is %d, ignore!!\n", __FUNCTION__, rtw_p2p_state(pwdinfo));
_exit_critical_bh(&pmlmepriv->lock, &irqL);
}
static void find_phase_timer_process(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
adapter->wdinfo.find_phase_state_exchange_cnt++;
p2p_protocol_wk_cmd(adapter, P2P_FIND_PHASE_WK);
}
#ifdef CONFIG_CONCURRENT_MODE
void ap_p2p_switch_timer_process(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
#ifdef CONFIG_IOCTL_CFG80211
struct rtw_wdev_priv *pwdev_priv = adapter_wdev_data(adapter);
#endif
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
#ifdef CONFIG_IOCTL_CFG80211
ATOMIC_SET(&pwdev_priv->switch_ch_to, 1);
#endif
p2p_protocol_wk_cmd(adapter, P2P_AP_P2P_CH_SWITCH_PROCESS_WK);
}
#endif
void reset_global_wifidirect_info(_adapter *padapter)
{
struct wifidirect_info *pwdinfo;
pwdinfo = &padapter->wdinfo;
pwdinfo->persistent_supported = 0;
pwdinfo->session_available = _TRUE;
rtw_tdls_wfd_enable(padapter, 0);
pwdinfo->wfd_tdls_weaksec = _TRUE;
}
#ifdef CONFIG_WFD
int rtw_init_wifi_display_info(_adapter *padapter)
{
int res = _SUCCESS;
struct wifi_display_info *pwfd_info = &padapter->wfd_info;
/* Used in P2P and TDLS */
pwfd_info->init_rtsp_ctrlport = 554;
#ifdef CONFIG_IOCTL_CFG80211
pwfd_info->rtsp_ctrlport = 0;
#else
pwfd_info->rtsp_ctrlport = pwfd_info->init_rtsp_ctrlport; /* set non-zero value for legacy wfd */
#endif
pwfd_info->tdls_rtsp_ctrlport = 0;
pwfd_info->peer_rtsp_ctrlport = 0; /* Reset to 0 */
pwfd_info->wfd_enable = _FALSE;
pwfd_info->wfd_device_type = WFD_DEVINFO_PSINK;
pwfd_info->scan_result_type = SCAN_RESULT_P2P_ONLY;
/* Used in P2P */
pwfd_info->peer_session_avail = _TRUE;
pwfd_info->wfd_pc = _FALSE;
/* Used in TDLS */
_rtw_memset(pwfd_info->ip_address, 0x00, 4);
_rtw_memset(pwfd_info->peer_ip_address, 0x00, 4);
return res;
}
inline void rtw_wfd_enable(_adapter *adapter, bool on)
{
struct wifi_display_info *wfdinfo = &adapter->wfd_info;
if (on) {
wfdinfo->rtsp_ctrlport = wfdinfo->init_rtsp_ctrlport;
wfdinfo->wfd_enable = _TRUE;
} else {
wfdinfo->wfd_enable = _FALSE;
wfdinfo->rtsp_ctrlport = 0;
}
}
inline void rtw_wfd_set_ctrl_port(_adapter *adapter, u16 port)
{
struct wifi_display_info *wfdinfo = &adapter->wfd_info;
wfdinfo->init_rtsp_ctrlport = port;
if (wfdinfo->wfd_enable == _TRUE)
wfdinfo->rtsp_ctrlport = port;
if (adapter->wdinfo.wfd_tdls_enable == 1)
wfdinfo->tdls_rtsp_ctrlport = port;
}
inline void rtw_tdls_wfd_enable(_adapter *adapter, bool on)
{
struct wifi_display_info *wfdinfo = &adapter->wfd_info;
if (on) {
wfdinfo->tdls_rtsp_ctrlport = wfdinfo->init_rtsp_ctrlport;
adapter->wdinfo.wfd_tdls_enable = 1;
} else {
adapter->wdinfo.wfd_tdls_enable = 0;
wfdinfo->tdls_rtsp_ctrlport = 0;
}
}
u32 rtw_append_beacon_wfd_ie(_adapter *adapter, u8 *pbuf)
{
struct wifidirect_info *wdinfo = &adapter->wdinfo;
struct mlme_priv *mlme = &adapter->mlmepriv;
u8 build_ie_by_self = 0;
u32 len = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
if (_TRUE == wdinfo->wfd_info->wfd_enable)
#endif
build_ie_by_self = 1;
if (build_ie_by_self)
len = build_beacon_wfd_ie(wdinfo, pbuf);
#ifdef CONFIG_IOCTL_CFG80211
else if (mlme->wfd_beacon_ie && mlme->wfd_beacon_ie_len > 0) {
len = mlme->wfd_beacon_ie_len;
_rtw_memcpy(pbuf, mlme->wfd_beacon_ie, len);
}
#endif
exit:
return len;
}
u32 rtw_append_probe_req_wfd_ie(_adapter *adapter, u8 *pbuf)
{
struct wifidirect_info *wdinfo = &adapter->wdinfo;
struct mlme_priv *mlme = &adapter->mlmepriv;
u8 build_ie_by_self = 0;
u32 len = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
if (_TRUE == wdinfo->wfd_info->wfd_enable)
#endif
build_ie_by_self = 1;
if (build_ie_by_self)
len = build_probe_req_wfd_ie(wdinfo, pbuf);
#ifdef CONFIG_IOCTL_CFG80211
else if (mlme->wfd_probe_req_ie && mlme->wfd_probe_req_ie_len > 0) {
len = mlme->wfd_probe_req_ie_len;
_rtw_memcpy(pbuf, mlme->wfd_probe_req_ie, len);
}
#endif
exit:
return len;
}
u32 rtw_append_probe_resp_wfd_ie(_adapter *adapter, u8 *pbuf)
{
struct wifidirect_info *wdinfo = &adapter->wdinfo;
struct mlme_priv *mlme = &adapter->mlmepriv;
u8 build_ie_by_self = 0;
u32 len = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
if (_TRUE == wdinfo->wfd_info->wfd_enable)
#endif
build_ie_by_self = 1;
if (build_ie_by_self)
len = build_probe_resp_wfd_ie(wdinfo, pbuf, 0);
#ifdef CONFIG_IOCTL_CFG80211
else if (mlme->wfd_probe_resp_ie && mlme->wfd_probe_resp_ie_len > 0) {
len = mlme->wfd_probe_resp_ie_len;
_rtw_memcpy(pbuf, mlme->wfd_probe_resp_ie, len);
}
#endif
exit:
return len;
}
u32 rtw_append_assoc_req_wfd_ie(_adapter *adapter, u8 *pbuf)
{
struct wifidirect_info *wdinfo = &adapter->wdinfo;
struct mlme_priv *mlme = &adapter->mlmepriv;
u8 build_ie_by_self = 0;
u32 len = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
if (_TRUE == wdinfo->wfd_info->wfd_enable)
#endif
build_ie_by_self = 1;
if (build_ie_by_self)
len = build_assoc_req_wfd_ie(wdinfo, pbuf);
#ifdef CONFIG_IOCTL_CFG80211
else if (mlme->wfd_assoc_req_ie && mlme->wfd_assoc_req_ie_len > 0) {
len = mlme->wfd_assoc_req_ie_len;
_rtw_memcpy(pbuf, mlme->wfd_assoc_req_ie, len);
}
#endif
exit:
return len;
}
u32 rtw_append_assoc_resp_wfd_ie(_adapter *adapter, u8 *pbuf)
{
struct wifidirect_info *wdinfo = &adapter->wdinfo;
struct mlme_priv *mlme = &adapter->mlmepriv;
u8 build_ie_by_self = 0;
u32 len = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
goto exit;
#ifdef CONFIG_IOCTL_CFG80211
if (_TRUE == wdinfo->wfd_info->wfd_enable)
#endif
build_ie_by_self = 1;
if (build_ie_by_self)
len = build_assoc_resp_wfd_ie(wdinfo, pbuf);
#ifdef CONFIG_IOCTL_CFG80211
else if (mlme->wfd_assoc_resp_ie && mlme->wfd_assoc_resp_ie_len > 0) {
len = mlme->wfd_assoc_resp_ie_len;
_rtw_memcpy(pbuf, mlme->wfd_assoc_resp_ie, len);
}
#endif
exit:
return len;
}
#endif /* CONFIG_WFD */
void rtw_init_wifidirect_timers(_adapter *padapter)
{
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
rtw_init_timer(&pwdinfo->find_phase_timer, padapter, find_phase_timer_process, padapter);
rtw_init_timer(&pwdinfo->restore_p2p_state_timer, padapter, restore_p2p_state_timer_process, padapter);
rtw_init_timer(&pwdinfo->pre_tx_scan_timer, padapter, pre_tx_scan_timer_process, padapter);
rtw_init_timer(&pwdinfo->reset_ch_sitesurvey, padapter, reset_ch_sitesurvey_timer_process, padapter);
rtw_init_timer(&pwdinfo->reset_ch_sitesurvey2, padapter, reset_ch_sitesurvey_timer_process2, padapter);
#ifdef CONFIG_CONCURRENT_MODE
rtw_init_timer(&pwdinfo->ap_p2p_switch_timer, padapter, ap_p2p_switch_timer_process, padapter);
#endif
}
void rtw_init_wifidirect_addrs(_adapter *padapter, u8 *dev_addr, u8 *iface_addr)
{
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
/*init device&interface address */
if (dev_addr)
_rtw_memcpy(pwdinfo->device_addr, dev_addr, ETH_ALEN);
if (iface_addr)
_rtw_memcpy(pwdinfo->interface_addr, iface_addr, ETH_ALEN);
#endif
}
void init_wifidirect_info(_adapter *padapter, enum P2P_ROLE role)
{
struct wifidirect_info *pwdinfo;
#ifdef CONFIG_WFD
struct wifi_display_info *pwfd_info = &padapter->wfd_info;
#endif
pwdinfo = &padapter->wdinfo;
pwdinfo->padapter = padapter;
/* 1, 6, 11 are the social channel defined in the WiFi Direct specification. */
pwdinfo->social_chan[0] = 1;
pwdinfo->social_chan[1] = 6;
pwdinfo->social_chan[2] = 11;
pwdinfo->social_chan[3] = 0; /* channel 0 for scanning ending in site survey function. */
if (role != P2P_ROLE_DISABLE
&& pwdinfo->driver_interface != DRIVER_CFG80211
) {
#ifdef CONFIG_CONCURRENT_MODE
u8 union_ch = 0;
if (rtw_mi_check_status(padapter, MI_LINKED))
union_ch = rtw_mi_get_union_chan(padapter);
if (union_ch != 0 &&
(union_ch == 1 || union_ch == 6 || union_ch == 11)
) {
/* Use the AP's channel as the listen channel */
/* This will avoid the channel switch between AP's channel and listen channel */
pwdinfo->listen_channel = union_ch;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
/* Use the channel 11 as the listen channel */
pwdinfo->listen_channel = 11;
}
}
if (role == P2P_ROLE_DEVICE) {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DEVICE);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED))
rtw_p2p_set_state(pwdinfo, P2P_STATE_IDLE);
else
#endif
rtw_p2p_set_state(pwdinfo, P2P_STATE_LISTEN);
pwdinfo->intent = 1;
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_LISTEN);
} else if (role == P2P_ROLE_CLIENT) {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_CLIENT);
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
pwdinfo->intent = 1;
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
} else if (role == P2P_ROLE_GO) {
rtw_p2p_set_role(pwdinfo, P2P_ROLE_GO);
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_OK);
pwdinfo->intent = 15;
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_GONEGO_OK);
}
/* Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 ) */
pwdinfo->support_rate[0] = 0x8c; /* 6(B) */
pwdinfo->support_rate[1] = 0x92; /* 9(B) */
pwdinfo->support_rate[2] = 0x18; /* 12 */
pwdinfo->support_rate[3] = 0x24; /* 18 */
pwdinfo->support_rate[4] = 0x30; /* 24 */
pwdinfo->support_rate[5] = 0x48; /* 36 */
pwdinfo->support_rate[6] = 0x60; /* 48 */
pwdinfo->support_rate[7] = 0x6c; /* 54 */
_rtw_memcpy((void *) pwdinfo->p2p_wildcard_ssid, "DIRECT-", 7);
_rtw_memset(pwdinfo->device_name, 0x00, WPS_MAX_DEVICE_NAME_LEN);
pwdinfo->device_name_len = 0;
_rtw_memset(&pwdinfo->invitereq_info, 0x00, sizeof(struct tx_invite_req_info));
pwdinfo->invitereq_info.token = 3; /* Token used for P2P invitation request frame. */
_rtw_memset(&pwdinfo->inviteresp_info, 0x00, sizeof(struct tx_invite_resp_info));
pwdinfo->inviteresp_info.token = 0;
pwdinfo->profileindex = 0;
_rtw_memset(&pwdinfo->profileinfo[0], 0x00, sizeof(struct profile_info) * P2P_MAX_PERSISTENT_GROUP_NUM);
rtw_p2p_findphase_ex_set(pwdinfo, P2P_FINDPHASE_EX_NONE);
pwdinfo->listen_dwell = (u8)((rtw_get_current_time() % 3) + 1);
/* RTW_INFO( "[%s] listen_dwell time is %d00ms\n", __FUNCTION__, pwdinfo->listen_dwell ); */
_rtw_memset(&pwdinfo->tx_prov_disc_info, 0x00, sizeof(struct tx_provdisc_req_info));
pwdinfo->tx_prov_disc_info.wps_config_method_request = WPS_CM_NONE;
_rtw_memset(&pwdinfo->nego_req_info, 0x00, sizeof(struct tx_nego_req_info));
pwdinfo->device_password_id_for_nego = WPS_DPID_PBC;
pwdinfo->negotiation_dialog_token = 1;
_rtw_memset(pwdinfo->nego_ssid, 0x00, WLAN_SSID_MAXLEN);
pwdinfo->nego_ssidlen = 0;
pwdinfo->ui_got_wps_info = P2P_NO_WPSINFO;
#ifdef CONFIG_WFD
pwdinfo->supported_wps_cm = WPS_CONFIG_METHOD_DISPLAY | WPS_CONFIG_METHOD_PBC;
pwdinfo->wfd_info = pwfd_info;
#else
pwdinfo->supported_wps_cm = WPS_CONFIG_METHOD_DISPLAY | WPS_CONFIG_METHOD_PBC | WPS_CONFIG_METHOD_KEYPAD;
#endif /* CONFIG_WFD */
pwdinfo->channel_list_attr_len = 0;
_rtw_memset(pwdinfo->channel_list_attr, 0x00, 100);
_rtw_memset(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, 0x00, 4);
_rtw_memset(pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req, '0', 3);
_rtw_memset(&pwdinfo->groupid_info, 0x00, sizeof(struct group_id_info));
#ifdef CONFIG_CONCURRENT_MODE
#ifdef CONFIG_IOCTL_CFG80211
pwdinfo->ext_listen_interval = 1000; /* The interval to be available with legacy AP during p2p0-find/scan */
pwdinfo->ext_listen_period = 3000; /* The time period to be available for P2P during nego */
#else /* !CONFIG_IOCTL_CFG80211 */
/* pwdinfo->ext_listen_interval = 3000; */
/* pwdinfo->ext_listen_period = 400; */
pwdinfo->ext_listen_interval = 1000;
pwdinfo->ext_listen_period = 1000;
#endif /* !CONFIG_IOCTL_CFG80211 */
#endif
/* Commented by Kurt 20130319
* For WiDi purpose: Use CFG80211 interface but controled WFD/RDS frame by driver itself. */
#ifdef CONFIG_IOCTL_CFG80211
pwdinfo->driver_interface = DRIVER_CFG80211;
#else
pwdinfo->driver_interface = DRIVER_WEXT;
#endif /* CONFIG_IOCTL_CFG80211 */
pwdinfo->wfd_tdls_enable = 0;
_rtw_memset(pwdinfo->p2p_peer_interface_addr, 0x00, ETH_ALEN);
_rtw_memset(pwdinfo->p2p_peer_device_addr, 0x00, ETH_ALEN);
pwdinfo->rx_invitereq_info.operation_ch[0] = 0;
pwdinfo->rx_invitereq_info.operation_ch[1] = 0; /* Used to indicate the scan end in site survey function */
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->rx_invitereq_info.operation_ch[2] = 0;
pwdinfo->rx_invitereq_info.operation_ch[3] = 0;
pwdinfo->rx_invitereq_info.operation_ch[4] = 0;
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->rx_invitereq_info.scan_op_ch_only = 0;
pwdinfo->p2p_info.operation_ch[0] = 0;
pwdinfo->p2p_info.operation_ch[1] = 0; /* Used to indicate the scan end in site survey function */
#ifdef CONFIG_P2P_OP_CHK_SOCIAL_CH
pwdinfo->p2p_info.operation_ch[2] = 0;
pwdinfo->p2p_info.operation_ch[3] = 0;
pwdinfo->p2p_info.operation_ch[4] = 0;
#endif /* CONFIG_P2P_OP_CHK_SOCIAL_CH */
pwdinfo->p2p_info.scan_op_ch_only = 0;
}
void _rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role)
{
if (wdinfo->role != role) {
wdinfo->role = role;
rtw_mi_update_iface_status(&(wdinfo->padapter->mlmepriv), 0);
}
}
#ifdef CONFIG_DBG_P2P
/**
* rtw_p2p_role_txt - Get the p2p role name as a text string
* @role: P2P role
* Returns: The state name as a printable text string
*/
const char *rtw_p2p_role_txt(enum P2P_ROLE role)
{
switch (role) {
case P2P_ROLE_DISABLE:
return "P2P_ROLE_DISABLE";
case P2P_ROLE_DEVICE:
return "P2P_ROLE_DEVICE";
case P2P_ROLE_CLIENT:
return "P2P_ROLE_CLIENT";
case P2P_ROLE_GO:
return "P2P_ROLE_GO";
default:
return "UNKNOWN";
}
}
/**
* rtw_p2p_state_txt - Get the p2p state name as a text string
* @state: P2P state
* Returns: The state name as a printable text string
*/
const char *rtw_p2p_state_txt(enum P2P_STATE state)
{
switch (state) {
case P2P_STATE_NONE:
return "P2P_STATE_NONE";
case P2P_STATE_IDLE:
return "P2P_STATE_IDLE";
case P2P_STATE_LISTEN:
return "P2P_STATE_LISTEN";
case P2P_STATE_SCAN:
return "P2P_STATE_SCAN";
case P2P_STATE_FIND_PHASE_LISTEN:
return "P2P_STATE_FIND_PHASE_LISTEN";
case P2P_STATE_FIND_PHASE_SEARCH:
return "P2P_STATE_FIND_PHASE_SEARCH";
case P2P_STATE_TX_PROVISION_DIS_REQ:
return "P2P_STATE_TX_PROVISION_DIS_REQ";
case P2P_STATE_RX_PROVISION_DIS_RSP:
return "P2P_STATE_RX_PROVISION_DIS_RSP";
case P2P_STATE_RX_PROVISION_DIS_REQ:
return "P2P_STATE_RX_PROVISION_DIS_REQ";
case P2P_STATE_GONEGO_ING:
return "P2P_STATE_GONEGO_ING";
case P2P_STATE_GONEGO_OK:
return "P2P_STATE_GONEGO_OK";
case P2P_STATE_GONEGO_FAIL:
return "P2P_STATE_GONEGO_FAIL";
case P2P_STATE_RECV_INVITE_REQ_MATCH:
return "P2P_STATE_RECV_INVITE_REQ_MATCH";
case P2P_STATE_PROVISIONING_ING:
return "P2P_STATE_PROVISIONING_ING";
case P2P_STATE_PROVISIONING_DONE:
return "P2P_STATE_PROVISIONING_DONE";
case P2P_STATE_TX_INVITE_REQ:
return "P2P_STATE_TX_INVITE_REQ";
case P2P_STATE_RX_INVITE_RESP_OK:
return "P2P_STATE_RX_INVITE_RESP_OK";
case P2P_STATE_RECV_INVITE_REQ_DISMATCH:
return "P2P_STATE_RECV_INVITE_REQ_DISMATCH";
case P2P_STATE_RECV_INVITE_REQ_GO:
return "P2P_STATE_RECV_INVITE_REQ_GO";
case P2P_STATE_RECV_INVITE_REQ_JOIN:
return "P2P_STATE_RECV_INVITE_REQ_JOIN";
case P2P_STATE_RX_INVITE_RESP_FAIL:
return "P2P_STATE_RX_INVITE_RESP_FAIL";
case P2P_STATE_RX_INFOR_NOREADY:
return "P2P_STATE_RX_INFOR_NOREADY";
case P2P_STATE_TX_INFOR_NOREADY:
return "P2P_STATE_TX_INFOR_NOREADY";
default:
return "UNKNOWN";
}
}
void dbg_rtw_p2p_set_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line)
{
if (!_rtw_p2p_chk_state(wdinfo, state)) {
enum P2P_STATE old_state = _rtw_p2p_state(wdinfo);
_rtw_p2p_set_state(wdinfo, state);
RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_state from %s to %s\n", caller, line
, rtw_p2p_state_txt(old_state), rtw_p2p_state_txt(_rtw_p2p_state(wdinfo))
);
} else {
RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_state to same state %s\n", caller, line
, rtw_p2p_state_txt(_rtw_p2p_state(wdinfo))
);
}
}
void dbg_rtw_p2p_set_pre_state(struct wifidirect_info *wdinfo, enum P2P_STATE state, const char *caller, int line)
{
if (_rtw_p2p_pre_state(wdinfo) != state) {
enum P2P_STATE old_state = _rtw_p2p_pre_state(wdinfo);
_rtw_p2p_set_pre_state(wdinfo, state);
RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_pre_state from %s to %s\n", caller, line
, rtw_p2p_state_txt(old_state), rtw_p2p_state_txt(_rtw_p2p_pre_state(wdinfo))
);
} else {
RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_pre_state to same state %s\n", caller, line
, rtw_p2p_state_txt(_rtw_p2p_pre_state(wdinfo))
);
}
}
#if 0
void dbg_rtw_p2p_restore_state(struct wifidirect_info *wdinfo, const char *caller, int line)
{
if (wdinfo->pre_p2p_state != -1) {
RTW_INFO("[CONFIG_DBG_P2P]%s:%d restore from %s to %s\n", caller, line
, p2p_state_str[wdinfo->p2p_state], p2p_state_str[wdinfo->pre_p2p_state]
);
_rtw_p2p_restore_state(wdinfo);
} else {
RTW_INFO("[CONFIG_DBG_P2P]%s:%d restore no pre state, cur state %s\n", caller, line
, p2p_state_str[wdinfo->p2p_state]
);
}
}
#endif
void dbg_rtw_p2p_set_role(struct wifidirect_info *wdinfo, enum P2P_ROLE role, const char *caller, int line)
{
if (wdinfo->role != role) {
enum P2P_ROLE old_role = wdinfo->role;
_rtw_p2p_set_role(wdinfo, role);
RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_role from %s to %s\n", caller, line
, rtw_p2p_role_txt(old_role), rtw_p2p_role_txt(wdinfo->role)
);
} else {
RTW_INFO("[CONFIG_DBG_P2P]%s:%d set_role to same role %s\n", caller, line
, rtw_p2p_role_txt(wdinfo->role)
);
}
}
#endif /* CONFIG_DBG_P2P */
int rtw_p2p_enable(_adapter *padapter, enum P2P_ROLE role)
{
int ret = _SUCCESS;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
if (role == P2P_ROLE_DEVICE || role == P2P_ROLE_CLIENT || role == P2P_ROLE_GO) {
#if defined(CONFIG_CONCURRENT_MODE) && (!defined(RTW_P2P_GROUP_INTERFACE) || !RTW_P2P_GROUP_INTERFACE)
/* Commented by Albert 2011/12/30 */
/* The driver just supports 1 P2P group operation. */
/* So, this function will do nothing if the buddy adapter had enabled the P2P function. */
/*if(!rtw_p2p_chk_state(pbuddy_wdinfo, P2P_STATE_NONE))
return ret;*/
/*The buddy adapter had enabled the P2P function.*/
if (rtw_mi_buddy_stay_in_p2p_mode(padapter))
return ret;
#endif /* CONFIG_CONCURRENT_MODE */
/* leave IPS/Autosuspend */
if (_FAIL == rtw_pwr_wakeup(padapter)) {
ret = _FAIL;
goto exit;
}
/* Added by Albert 2011/03/22 */
/* In the P2P mode, the driver should not support the b mode. */
/* So, the Tx packet shouldn't use the CCK rate */
#ifdef CONFIG_IOCTL_CFG80211
if (rtw_cfg80211_iface_has_p2p_group_cap(padapter))
#endif
update_tx_basic_rate(padapter, WIRELESS_11AGN);
/* Enable P2P function */
init_wifidirect_info(padapter, role);
#ifdef CONFIG_IOCTL_CFG80211
if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
adapter_wdev_data(padapter)->p2p_enabled = _TRUE;
#endif
rtw_hal_set_odm_var(padapter, HAL_ODM_P2P_STATE, NULL, _TRUE);
#ifdef CONFIG_WFD
if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
rtw_hal_set_odm_var(padapter, HAL_ODM_WIFI_DISPLAY_STATE, NULL, _TRUE);
#endif
} else if (role == P2P_ROLE_DISABLE) {
#ifdef CONFIG_IOCTL_CFG80211
if (padapter->wdinfo.driver_interface == DRIVER_CFG80211)
adapter_wdev_data(padapter)->p2p_enabled = _FALSE;
#endif
pwdinfo->listen_channel = 0;
/* Disable P2P function */
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
_cancel_timer_ex(&pwdinfo->find_phase_timer);
_cancel_timer_ex(&pwdinfo->restore_p2p_state_timer);
_cancel_timer_ex(&pwdinfo->pre_tx_scan_timer);
_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey);
_cancel_timer_ex(&pwdinfo->reset_ch_sitesurvey2);
reset_ch_sitesurvey_timer_process(padapter);
reset_ch_sitesurvey_timer_process2(padapter);
#ifdef CONFIG_CONCURRENT_MODE
_cancel_timer_ex(&pwdinfo->ap_p2p_switch_timer);
#endif
rtw_p2p_set_state(pwdinfo, P2P_STATE_NONE);
rtw_p2p_set_pre_state(pwdinfo, P2P_STATE_NONE);
rtw_p2p_set_role(pwdinfo, P2P_ROLE_DISABLE);
_rtw_memset(&pwdinfo->rx_prov_disc_info, 0x00, sizeof(struct rx_provdisc_req_info));
/* Remove profiles in wifidirect_info structure. */
_rtw_memset(&pwdinfo->profileinfo[0], 0x00, sizeof(struct profile_info) * P2P_MAX_PERSISTENT_GROUP_NUM);
pwdinfo->profileindex = 0;
}
rtw_hal_set_odm_var(padapter, HAL_ODM_P2P_STATE, NULL, _FALSE);
#ifdef CONFIG_WFD
if (hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
rtw_hal_set_odm_var(padapter, HAL_ODM_WIFI_DISPLAY_STATE, NULL, _FALSE);
#endif
if (_FAIL == rtw_pwr_wakeup(padapter)) {
ret = _FAIL;
goto exit;
}
/* Restore to initial setting. */
update_tx_basic_rate(padapter, padapter->registrypriv.wireless_mode);
/* For WiDi purpose. */
#ifdef CONFIG_IOCTL_CFG80211
pwdinfo->driver_interface = DRIVER_CFG80211;
#else
pwdinfo->driver_interface = DRIVER_WEXT;
#endif /* CONFIG_IOCTL_CFG80211 */
}
exit:
return ret;
}
#endif /* CONFIG_P2P */
================================================
FILE: core/rtw_pwrctrl.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_PWRCTRL_C_
#include
#include
#include
#ifdef DBG_CHECK_FW_PS_STATE
int rtw_fw_ps_state(PADAPTER padapter)
{
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
int ret = _FAIL, dont_care = 0;
u16 fw_ps_state = 0;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct registry_priv *registry_par = &padapter->registrypriv;
if (registry_par->check_fw_ps != 1)
return _SUCCESS;
_enter_pwrlock(&pwrpriv->check_32k_lock);
if (RTW_CANNOT_RUN(padapter)) {
RTW_INFO("%s: bSurpriseRemoved=%s , hw_init_completed=%d, bDriverStopped=%s\n", __func__
, rtw_is_surprise_removed(padapter) ? "True" : "False"
, rtw_get_hw_init_completed(padapter)
, rtw_is_drv_stopped(padapter) ? "True" : "False");
goto exit_fw_ps_state;
}
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
rtw_hal_get_hwreg(padapter, HW_VAR_FW_PS_STATE, (u8 *)&fw_ps_state);
if ((fw_ps_state & BIT_LPS_STATUS) == 0)
ret = _SUCCESS;
else {
pdbgpriv->dbg_poll_fail_cnt++;
RTW_INFO("%s: fw_ps_state=%04x\n", __FUNCTION__, fw_ps_state);
}
#else
rtw_hal_set_hwreg(padapter, HW_VAR_SET_REQ_FW_PS, (u8 *)&dont_care);
{
/* 4. if 0x88[7]=1, driver set cmd to leave LPS/IPS. */
/* Else, hw will keep in active mode. */
/* debug info: */
/* 0x88[7] = 32kpermission, */
/* 0x88[6:0] = current_ps_state */
/* 0x89[7:0] = last_rpwm */
rtw_hal_get_hwreg(padapter, HW_VAR_FW_PS_STATE, (u8 *)&fw_ps_state);
if ((fw_ps_state & 0x80) == 0)
ret = _SUCCESS;
else {
pdbgpriv->dbg_poll_fail_cnt++;
RTW_INFO("%s: fw_ps_state=%04x\n", __FUNCTION__, fw_ps_state);
}
}
#endif
exit_fw_ps_state:
_exit_pwrlock(&pwrpriv->check_32k_lock);
return ret;
}
#endif /*DBG_CHECK_FW_PS_STATE*/
#ifdef CONFIG_IPS
void _ips_enter(_adapter *padapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
pwrpriv->bips_processing = _TRUE;
/* syn ips_mode with request */
pwrpriv->ips_mode = pwrpriv->ips_mode_req;
pwrpriv->ips_enter_cnts++;
RTW_INFO("==>ips_enter cnts:%d\n", pwrpriv->ips_enter_cnts);
if (rf_off == pwrpriv->change_rfpwrstate) {
pwrpriv->bpower_saving = _TRUE;
RTW_PRINT("nolinked power save enter\n");
if (pwrpriv->ips_mode == IPS_LEVEL_2)
pwrpriv->bkeepfwalive = _TRUE;
#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
pwrpriv->pwr_saving_start_time = rtw_get_current_time();
#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
rtw_ips_pwr_down(padapter);
pwrpriv->rf_pwrstate = rf_off;
}
pwrpriv->bips_processing = _FALSE;
}
void ips_enter(_adapter *padapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_IpsNotify(padapter, pwrpriv->ips_mode_req);
#endif /* CONFIG_BT_COEXIST */
_enter_pwrlock(&pwrpriv->lock);
_ips_enter(padapter);
_exit_pwrlock(&pwrpriv->lock);
}
int _ips_leave(_adapter *padapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
int result = _SUCCESS;
if ((pwrpriv->rf_pwrstate == rf_off) && (!pwrpriv->bips_processing)) {
pwrpriv->bips_processing = _TRUE;
pwrpriv->change_rfpwrstate = rf_on;
pwrpriv->ips_leave_cnts++;
RTW_INFO("==>ips_leave cnts:%d\n", pwrpriv->ips_leave_cnts);
result = rtw_ips_pwr_up(padapter);
if (result == _SUCCESS)
pwrpriv->rf_pwrstate = rf_on;
#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
RTW_PRINT("nolinked power save leave\n");
RTW_INFO("==> ips_leave.....LED(0x%08x)...\n", rtw_read32(padapter, 0x4c));
pwrpriv->bips_processing = _FALSE;
pwrpriv->bkeepfwalive = _FALSE;
pwrpriv->bpower_saving = _FALSE;
}
return result;
}
int ips_leave(_adapter *padapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
#ifdef DBG_CHECK_FW_PS_STATE
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
#endif
int ret;
if (!is_primary_adapter(padapter))
return _SUCCESS;
_enter_pwrlock(&pwrpriv->lock);
ret = _ips_leave(padapter);
#ifdef DBG_CHECK_FW_PS_STATE
if (rtw_fw_ps_state(padapter) == _FAIL) {
RTW_INFO("ips leave doesn't leave 32k\n");
pdbgpriv->dbg_leave_ips_fail_cnt++;
}
#endif /* DBG_CHECK_FW_PS_STATE */
_exit_pwrlock(&pwrpriv->lock);
if (_SUCCESS == ret)
odm_dm_reset(&GET_HAL_DATA(padapter)->odmpriv);
#ifdef CONFIG_BT_COEXIST
if (_SUCCESS == ret)
rtw_btcoex_IpsNotify(padapter, IPS_NONE);
#endif /* CONFIG_BT_COEXIST */
return ret;
}
#endif /* CONFIG_IPS */
#ifdef CONFIG_AUTOSUSPEND
extern void autosuspend_enter(_adapter *padapter);
extern int autoresume_enter(_adapter *padapter);
#endif
#ifdef SUPPORT_HW_RFOFF_DETECTED
int rtw_hw_suspend(_adapter *padapter);
int rtw_hw_resume(_adapter *padapter);
#endif
bool rtw_pwr_unassociated_idle(_adapter *adapter)
{
u8 i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct xmit_priv *pxmit_priv = &adapter->xmitpriv;
struct mlme_priv *pmlmepriv;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo;
#endif
bool ret = _FALSE;
if (adapter_to_pwrctl(adapter)->bpower_saving == _TRUE) {
/* RTW_INFO("%s: already in LPS or IPS mode\n", __func__); */
goto exit;
}
if (rtw_time_after(adapter_to_pwrctl(adapter)->ips_deny_time, rtw_get_current_time())) {
/* RTW_INFO("%s ips_deny_time\n", __func__); */
goto exit;
}
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
pmlmepriv = &(iface->mlmepriv);
#ifdef CONFIG_P2P
pwdinfo = &(iface->wdinfo);
#endif
if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE | WIFI_SITE_MONITOR)
|| check_fwstate(pmlmepriv, WIFI_UNDER_LINKING | WIFI_UNDER_WPS)
|| MLME_IS_AP(iface)
|| MLME_IS_MESH(iface)
|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE)
#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
|| rtw_cfg80211_get_is_roch(iface) == _TRUE
|| (rtw_cfg80211_is_ro_ch_once(adapter)
&& rtw_cfg80211_get_last_ro_ch_passing_ms(adapter) < 3000)
#elif defined(CONFIG_P2P)
|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_IDLE)
|| rtw_p2p_chk_state(pwdinfo, P2P_STATE_LISTEN)
#endif
)
goto exit;
}
}
#if (MP_DRIVER == 1)
if (adapter->registrypriv.mp_mode == 1)
goto exit;
#endif
if (pxmit_priv->free_xmitbuf_cnt != NR_XMITBUFF ||
pxmit_priv->free_xmit_extbuf_cnt != NR_XMIT_EXTBUFF) {
RTW_PRINT("There are some pkts to transmit\n");
RTW_PRINT("free_xmitbuf_cnt: %d, free_xmit_extbuf_cnt: %d\n",
pxmit_priv->free_xmitbuf_cnt, pxmit_priv->free_xmit_extbuf_cnt);
goto exit;
}
ret = _TRUE;
exit:
return ret;
}
/*
* ATTENTION:
* rtw_ps_processor() doesn't handle LPS.
*/
void rtw_ps_processor(_adapter *padapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
#ifdef SUPPORT_HW_RFOFF_DETECTED
rt_rf_power_state rfpwrstate;
#endif /* SUPPORT_HW_RFOFF_DETECTED */
u32 ps_deny = 0;
_enter_pwrlock(&adapter_to_pwrctl(padapter)->lock);
ps_deny = rtw_ps_deny_get(padapter);
_exit_pwrlock(&adapter_to_pwrctl(padapter)->lock);
if (ps_deny != 0) {
RTW_INFO(FUNC_ADPT_FMT ": ps_deny=0x%08X, skip power save!\n",
FUNC_ADPT_ARG(padapter), ps_deny);
goto exit;
}
if (pwrpriv->bInSuspend == _TRUE) { /* system suspend or autosuspend */
pdbgpriv->dbg_ps_insuspend_cnt++;
RTW_INFO("%s, pwrpriv->bInSuspend == _TRUE ignore this process\n", __FUNCTION__);
return;
}
pwrpriv->ps_processing = _TRUE;
#ifdef SUPPORT_HW_RFOFF_DETECTED
if (pwrpriv->bips_processing == _TRUE)
goto exit;
/* RTW_INFO("==> fw report state(0x%x)\n",rtw_read8(padapter,0x1ca)); */
if (pwrpriv->bHWPwrPindetect) {
#ifdef CONFIG_AUTOSUSPEND
if (padapter->registrypriv.usbss_enable) {
if (pwrpriv->rf_pwrstate == rf_on) {
if (padapter->net_closed == _TRUE)
pwrpriv->ps_flag = _TRUE;
rfpwrstate = RfOnOffDetect(padapter);
RTW_INFO("@@@@- #1 %s==> rfstate:%s\n", __FUNCTION__, (rfpwrstate == rf_on) ? "rf_on" : "rf_off");
if (rfpwrstate != pwrpriv->rf_pwrstate) {
if (rfpwrstate == rf_off) {
pwrpriv->change_rfpwrstate = rf_off;
pwrpriv->bkeepfwalive = _TRUE;
pwrpriv->brfoffbyhw = _TRUE;
autosuspend_enter(padapter);
}
}
}
} else
#endif /* CONFIG_AUTOSUSPEND */
{
rfpwrstate = RfOnOffDetect(padapter);
RTW_INFO("@@@@- #2 %s==> rfstate:%s\n", __FUNCTION__, (rfpwrstate == rf_on) ? "rf_on" : "rf_off");
if (rfpwrstate != pwrpriv->rf_pwrstate) {
if (rfpwrstate == rf_off) {
pwrpriv->change_rfpwrstate = rf_off;
pwrpriv->brfoffbyhw = _TRUE;
rtw_hw_suspend(padapter);
} else {
pwrpriv->change_rfpwrstate = rf_on;
rtw_hw_resume(padapter);
}
RTW_INFO("current rf_pwrstate(%s)\n", (pwrpriv->rf_pwrstate == rf_off) ? "rf_off" : "rf_on");
}
}
pwrpriv->pwr_state_check_cnts++;
}
#endif /* SUPPORT_HW_RFOFF_DETECTED */
if (pwrpriv->ips_mode_req == IPS_NONE)
goto exit;
if (rtw_pwr_unassociated_idle(padapter) == _FALSE)
goto exit;
if ((pwrpriv->rf_pwrstate == rf_on) && ((pwrpriv->pwr_state_check_cnts % 4) == 0)) {
RTW_INFO("==>%s .fw_state(%x)\n", __FUNCTION__, get_fwstate(pmlmepriv));
#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
#else
pwrpriv->change_rfpwrstate = rf_off;
#endif
#ifdef CONFIG_AUTOSUSPEND
if (padapter->registrypriv.usbss_enable) {
if (pwrpriv->bHWPwrPindetect)
pwrpriv->bkeepfwalive = _TRUE;
if (padapter->net_closed == _TRUE)
pwrpriv->ps_flag = _TRUE;
#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
if (_TRUE == pwrpriv->bInternalAutoSuspend)
RTW_INFO("<==%s .pwrpriv->bInternalAutoSuspend)(%x)\n", __FUNCTION__, pwrpriv->bInternalAutoSuspend);
else {
pwrpriv->change_rfpwrstate = rf_off;
RTW_INFO("<==%s .pwrpriv->bInternalAutoSuspend)(%x) call autosuspend_enter\n", __FUNCTION__, pwrpriv->bInternalAutoSuspend);
autosuspend_enter(padapter);
}
#else
autosuspend_enter(padapter);
#endif /* if defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND) */
} else if (pwrpriv->bHWPwrPindetect) {
} else
#endif /* CONFIG_AUTOSUSPEND */
{
#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
pwrpriv->change_rfpwrstate = rf_off;
#endif /* defined (CONFIG_BT_COEXIST)&& defined (CONFIG_AUTOSUSPEND) */
#ifdef CONFIG_IPS
ips_enter(padapter);
#endif
}
}
exit:
#ifndef CONFIG_IPS_CHECK_IN_WD
rtw_set_pwr_state_check_timer(pwrpriv);
#endif
pwrpriv->ps_processing = _FALSE;
return;
}
void pwr_state_check_handler(void *ctx)
{
_adapter *padapter = (_adapter *)ctx;
rtw_ps_cmd(padapter);
}
#ifdef CONFIG_LPS
#ifdef CONFIG_CHECK_LEAVE_LPS
#ifdef CONFIG_LPS_CHK_BY_TP
void traffic_check_for_leave_lps_by_tp(PADAPTER padapter, u8 tx, struct sta_info *sta)
{
struct stainfo_stats *pstats = &sta->sta_stats;
u64 cur_acc_tx_bytes = 0, cur_acc_rx_bytes = 0;
u32 tx_tp_kbyte = 0, rx_tp_kbyte = 0;
u32 tx_tp_th = 0, rx_tp_th = 0;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
u8 leave_lps = _FALSE;
if (tx) { /* from tx */
cur_acc_tx_bytes = pstats->tx_bytes - pstats->acc_tx_bytes;
tx_tp_kbyte = cur_acc_tx_bytes >> 10;
tx_tp_th = pwrpriv->lps_tx_tp_th * 1024 / 8 * 2; /*KBytes @2s*/
if (tx_tp_kbyte >= tx_tp_th ||
padapter->mlmepriv.LinkDetectInfo.NumTxOkInPeriod >= pwrpriv->lps_tx_pkts){
if (pwrpriv->bLeisurePs
&& (pwrpriv->pwr_mode != PS_MODE_ACTIVE)
#ifdef CONFIG_BT_COEXIST
&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
#endif
) {
leave_lps = _TRUE;
}
}
} else { /* from rx path */
cur_acc_rx_bytes = pstats->rx_bytes - pstats->acc_rx_bytes;
rx_tp_kbyte = cur_acc_rx_bytes >> 10;
rx_tp_th = pwrpriv->lps_rx_tp_th * 1024 / 8 * 2;
if (rx_tp_kbyte>= rx_tp_th ||
padapter->mlmepriv.LinkDetectInfo.NumRxUnicastOkInPeriod >= pwrpriv->lps_rx_pkts) {
if (pwrpriv->bLeisurePs
&& (pwrpriv->pwr_mode != PS_MODE_ACTIVE)
#ifdef CONFIG_BT_COEXIST
&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
#endif
) {
leave_lps = _TRUE;
}
}
}
if (leave_lps) {
#ifdef DBG_LPS_CHK_BY_TP
RTW_INFO("leave lps via %s, ", tx ? "Tx" : "Rx");
if (tx)
RTW_INFO("Tx = %d [%d] (KB)\n", tx_tp_kbyte, tx_tp_th);
else
RTW_INFO("Rx = %d [%d] (KB)\n", rx_tp_kbyte, rx_tp_th);
#endif
pwrpriv->lps_chk_cnt = pwrpriv->lps_chk_cnt_th;
/* rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 0); */
rtw_lps_ctrl_wk_cmd(padapter, tx ? LPS_CTRL_TX_TRAFFIC_LEAVE : LPS_CTRL_RX_TRAFFIC_LEAVE, 0);
}
}
#endif /*CONFIG_LPS_CHK_BY_TP*/
void traffic_check_for_leave_lps(PADAPTER padapter, u8 tx, u32 tx_packets)
{
static systime start_time = 0;
static u32 xmit_cnt = 0;
u8 bLeaveLPS = _FALSE;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
if (tx) { /* from tx */
xmit_cnt += tx_packets;
if (start_time == 0)
start_time = rtw_get_current_time();
if (rtw_get_passing_time_ms(start_time) > 2000) { /* 2 sec == watch dog timer */
if (xmit_cnt > 8) {
if ((adapter_to_pwrctl(padapter)->bLeisurePs)
&& (adapter_to_pwrctl(padapter)->pwr_mode != PS_MODE_ACTIVE)
#ifdef CONFIG_BT_COEXIST
&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
#endif
) {
/* RTW_INFO("leave lps via Tx = %d\n", xmit_cnt); */
bLeaveLPS = _TRUE;
}
}
start_time = rtw_get_current_time();
xmit_cnt = 0;
}
} else { /* from rx path */
if (pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod > 4/*2*/) {
if ((adapter_to_pwrctl(padapter)->bLeisurePs)
&& (adapter_to_pwrctl(padapter)->pwr_mode != PS_MODE_ACTIVE)
#ifdef CONFIG_BT_COEXIST
&& (rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
#endif
) {
/* RTW_INFO("leave lps via Rx = %d\n", pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod); */
bLeaveLPS = _TRUE;
}
}
}
if (bLeaveLPS) {
/* RTW_INFO("leave lps via %s, Tx = %d, Rx = %d\n", tx?"Tx":"Rx", pmlmepriv->LinkDetectInfo.NumTxOkInPeriod,pmlmepriv->LinkDetectInfo.NumRxUnicastOkInPeriod); */
/* rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 0); */
rtw_lps_ctrl_wk_cmd(padapter, tx ? LPS_CTRL_TX_TRAFFIC_LEAVE : LPS_CTRL_RX_TRAFFIC_LEAVE, tx ? RTW_CMDF_DIRECTLY : 0);
}
}
#endif /* CONFIG_CHECK_LEAVE_LPS */
#ifdef CONFIG_LPS_LCLK
#define LPS_CPWM_TIMEOUT_MS 10 /*ms*/
#define LPS_RPWM_RETRY_CNT 3
u8 rtw_cpwm_polling(_adapter *adapter, u8 rpwm, u8 cpwm_orig)
{
u8 rst = _FAIL;
u8 cpwm_now = 0;
systime start_time;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
#ifdef DBG_CHECK_FW_PS_STATE
struct debug_priv *pdbgpriv = &(adapter_to_dvobj(adapter)->drv_dbg);
#endif
pwrpriv->rpwm_retry = 0;
do {
start_time = rtw_get_current_time();
do {
rtw_msleep_os(1);
rtw_hal_get_hwreg(adapter, HW_VAR_CPWM, &cpwm_now);
if ((cpwm_orig ^ cpwm_now) & 0x80) {
pwrpriv->cpwm = PS_STATE_S4;
pwrpriv->cpwm_tog = cpwm_now & PS_TOGGLE;
rst = _SUCCESS;
break;
}
} while (rtw_get_passing_time_ms(start_time) < LPS_CPWM_TIMEOUT_MS && !RTW_CANNOT_RUN(adapter));
if (rst == _SUCCESS)
break;
else {
/* rpwm retry */
cpwm_orig = cpwm_now;
rpwm &= ~PS_TOGGLE;
rpwm |= pwrpriv->tog;
rtw_hal_set_hwreg(adapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
pwrpriv->tog += 0x80;
}
} while (pwrpriv->rpwm_retry++ < LPS_RPWM_RETRY_CNT && !RTW_CANNOT_RUN(adapter));
if (rst == _SUCCESS) {
#ifdef DBG_CHECK_FW_PS_STATE
RTW_INFO("%s: polling cpwm OK! rpwm_retry=%d, cpwm_orig=%02x, cpwm_now=%02x , 0x100=0x%x\n"
, __func__, pwrpriv->rpwm_retry, cpwm_orig, cpwm_now, rtw_read8(adapter, REG_CR));
if (rtw_fw_ps_state(adapter) == _FAIL) {
RTW_INFO("leave 32k but fw state in 32k\n");
pdbgpriv->dbg_rpwm_toogle_cnt++;
}
#endif /* DBG_CHECK_FW_PS_STATE */
} else {
RTW_ERR("%s: polling cpwm timeout! rpwm_retry=%d, cpwm_orig=%02x, cpwm_now=%02x\n"
, __func__, pwrpriv->rpwm_retry, cpwm_orig, cpwm_now);
#ifdef DBG_CHECK_FW_PS_STATE
if (rtw_fw_ps_state(adapter) == _FAIL) {
RTW_INFO("rpwm timeout and fw ps state in 32k\n");
pdbgpriv->dbg_rpwm_timeout_fail_cnt++;
}
#endif /* DBG_CHECK_FW_PS_STATE */
#ifdef CONFIG_LPS_RPWM_TIMER
_set_timer(&pwrpriv->pwr_rpwm_timer, 1);
#endif /* CONFIG_LPS_RPWM_TIMER */
}
return rst;
}
#endif
/*
* Description:
* This function MUST be called under power lock protect
*
* Parameters
* padapter
* pslv power state level, only could be PS_STATE_S0 ~ PS_STATE_S4
*
*/
u8 rtw_set_rpwm(PADAPTER padapter, u8 pslv)
{
u8 rpwm = 0xFF;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
#ifdef CONFIG_LPS_LCLK
u8 cpwm_orig;
#endif
pslv = PS_STATE(pslv);
#ifdef CONFIG_LPS_RPWM_TIMER
if (pwrpriv->brpwmtimeout == _TRUE)
RTW_INFO("%s: RPWM timeout, force to set RPWM(0x%02X) again!\n", __FUNCTION__, pslv);
else
#endif /* CONFIG_LPS_RPWM_TIMER */
{
if ((pwrpriv->rpwm == pslv)
#ifdef CONFIG_LPS_LCLK
|| ((pwrpriv->rpwm >= PS_STATE_S2) && (pslv >= PS_STATE_S2))
#endif
|| (pwrpriv->lps_level == LPS_NORMAL)
) {
return rpwm;
}
}
if (rtw_is_surprise_removed(padapter) ||
(!rtw_is_hw_init_completed(padapter))) {
pwrpriv->cpwm = PS_STATE_S4;
return rpwm;
}
if (rtw_is_drv_stopped(padapter))
if (pslv < PS_STATE_S2)
return rpwm;
rpwm = pslv | pwrpriv->tog;
#ifdef CONFIG_LPS_LCLK
/* only when from PS_STATE S0/S1 to S2 and higher needs ACK */
if ((pwrpriv->cpwm < PS_STATE_S2) && (pslv >= PS_STATE_S2))
rpwm |= PS_ACK;
#endif
pwrpriv->rpwm = pslv;
#ifdef CONFIG_LPS_LCLK
cpwm_orig = 0;
if (rpwm & PS_ACK)
rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_orig);
#endif
#if defined(CONFIG_LPS_RPWM_TIMER) && !defined(CONFIG_DETECT_CPWM_BY_POLLING)
if (rpwm & PS_ACK) {
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
if (pwrpriv->wowlan_mode != _TRUE &&
pwrpriv->wowlan_ap_mode != _TRUE &&
pwrpriv->wowlan_p2p_mode != _TRUE)
#endif
_set_timer(&pwrpriv->pwr_rpwm_timer, LPS_CPWM_TIMEOUT_MS);
}
#endif /* CONFIG_LPS_RPWM_TIMER & !CONFIG_DETECT_CPWM_BY_POLLING */
rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
pwrpriv->tog += 0x80;
#ifdef CONFIG_LPS_LCLK
/* No LPS 32K, No Ack */
if (rpwm & PS_ACK) {
#ifdef CONFIG_DETECT_CPWM_BY_POLLING
rtw_cpwm_polling(padapter, rpwm, cpwm_orig);
#else
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
if (pwrpriv->wowlan_mode == _TRUE ||
pwrpriv->wowlan_ap_mode == _TRUE ||
pwrpriv->wowlan_p2p_mode == _TRUE)
rtw_cpwm_polling(padapter, rpwm, cpwm_orig);
#endif /*#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)*/
#endif /*#ifdef CONFIG_DETECT_CPWM_BY_POLLING*/
} else
#endif /* CONFIG_LPS_LCLK */
{
pwrpriv->cpwm = pslv;
}
return rpwm;
}
u8 PS_RDY_CHECK(_adapter *padapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
if (_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_mode)
return _TRUE;
else if (_TRUE == pwrpriv->bInSuspend && pwrpriv->wowlan_ap_mode)
return _TRUE;
else if (_TRUE == pwrpriv->bInSuspend)
return _FALSE;
#else
if (_TRUE == pwrpriv->bInSuspend)
return _FALSE;
#endif
if (rtw_time_after(pwrpriv->lps_deny_time, rtw_get_current_time()))
return _FALSE;
if (check_fwstate(pmlmepriv, WIFI_SITE_MONITOR)
|| check_fwstate(pmlmepriv, WIFI_UNDER_LINKING | WIFI_UNDER_WPS)
|| MLME_IS_AP(padapter)
|| MLME_IS_MESH(padapter)
|| check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE | WIFI_ADHOC_STATE)
#if defined(CONFIG_P2P) && defined(CONFIG_IOCTL_CFG80211)
|| rtw_cfg80211_get_is_roch(padapter) == _TRUE
#endif
|| rtw_is_scan_deny(padapter)
#ifdef CONFIG_TDLS
/* TDLS link is established. */
|| (padapter->tdlsinfo.link_established == _TRUE)
#endif /* CONFIG_TDLS */
#ifdef CONFIG_DFS_MASTER
|| adapter_to_rfctl(padapter)->radar_detect_enabled
#endif
)
return _FALSE;
if ((padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) && (padapter->securitypriv.binstallGrpkey == _FALSE)) {
RTW_INFO("Group handshake still in progress !!!\n");
return _FALSE;
}
#ifdef CONFIG_IOCTL_CFG80211
if (!rtw_cfg80211_pwr_mgmt(padapter))
return _FALSE;
#endif
return _TRUE;
}
#if defined(CONFIG_FWLPS_IN_IPS)
void rtw_set_fw_in_ips_mode(PADAPTER padapter, u8 enable)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
int cnt = 0;
systime start_time;
u8 val8 = 0;
u8 cpwm_orig = 0, cpwm_now = 0;
u8 parm[H2C_INACTIVE_PS_LEN] = {0};
if (padapter->netif_up == _FALSE) {
RTW_INFO("%s: ERROR, netif is down\n", __func__);
return;
}
/* u8 cmd_param; */ /* BIT0:enable, BIT1:NoConnect32k */
if (enable) {
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_IpsNotify(padapter, pwrpriv->ips_mode_req);
#endif
/* Enter IPS */
RTW_INFO("%s: issue H2C to FW when entering IPS\n", __func__);
parm[0] = 0x1;/* suggest by Isaac.Hsu*/
#ifdef CONFIG_PNO_SUPPORT
if (pwrpriv->pno_inited) {
parm[1] = pwrpriv->pnlo_info->fast_scan_iterations;
parm[2] = pwrpriv->pnlo_info->slow_scan_period;
}
#endif
rtw_hal_fill_h2c_cmd(padapter, /* H2C_FWLPS_IN_IPS_, */
H2C_INACTIVE_PS_,
H2C_INACTIVE_PS_LEN, parm);
/* poll 0x1cc to make sure H2C command already finished by FW; MAC_0x1cc=0 means H2C done by FW. */
do {
val8 = rtw_read8(padapter, REG_HMETFR);
cnt++;
RTW_INFO("%s polling REG_HMETFR=0x%x, cnt=%d\n",
__func__, val8, cnt);
rtw_mdelay_os(10);
} while (cnt < 100 && (val8 != 0));
#ifdef CONFIG_LPS_LCLK
/* H2C done, enter 32k */
if (val8 == 0) {
/* ser rpwm to enter 32k */
rtw_hal_get_hwreg(padapter, HW_VAR_RPWM_TOG, &val8);
RTW_INFO("%s: read rpwm=%02x\n", __FUNCTION__, val8);
val8 += 0x80;
val8 |= BIT(0);
rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&val8));
RTW_INFO("%s: write rpwm=%02x\n", __FUNCTION__, val8);
adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
cnt = val8 = 0;
if (parm[1] == 0 || parm[2] == 0) {
do {
val8 = rtw_read8(padapter, REG_CR);
cnt++;
RTW_INFO("%s polling 0x100=0x%x, cnt=%d\n",
__func__, val8, cnt);
RTW_INFO("%s 0x08:%02x, 0x03:%02x\n",
__func__,
rtw_read8(padapter, 0x08),
rtw_read8(padapter, 0x03));
rtw_mdelay_os(10);
} while (cnt < 20 && (val8 != 0xEA));
}
}
#endif
} else {
/* Leave IPS */
RTW_INFO("%s: Leaving IPS in FWLPS state\n", __func__);
#ifdef CONFIG_LPS_LCLK
/* for polling cpwm */
cpwm_orig = 0;
rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_orig);
/* ser rpwm */
rtw_hal_get_hwreg(padapter, HW_VAR_RPWM_TOG, &val8);
val8 += 0x80;
val8 |= BIT(6);
rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&val8));
RTW_INFO("%s: write rpwm=%02x\n", __FUNCTION__, val8);
adapter_to_pwrctl(padapter)->tog = (val8 + 0x80) & 0x80;
/* do polling cpwm */
start_time = rtw_get_current_time();
do {
rtw_mdelay_os(1);
rtw_hal_get_hwreg(padapter, HW_VAR_CPWM, &cpwm_now);
if ((cpwm_orig ^ cpwm_now) & 0x80)
break;
if (rtw_get_passing_time_ms(start_time) > 100) {
RTW_INFO("%s: polling cpwm timeout when leaving IPS in FWLPS state\n", __FUNCTION__);
break;
}
} while (1);
#endif
parm[0] = 0x0;
parm[1] = 0x0;
parm[2] = 0x0;
rtw_hal_fill_h2c_cmd(padapter, H2C_INACTIVE_PS_,
H2C_INACTIVE_PS_LEN, parm);
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_IpsNotify(padapter, IPS_NONE);
#endif
}
}
#endif /* CONFIG_PNO_SUPPORT */
void rtw_set_ps_mode(PADAPTER padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode, const char *msg)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
#endif
#ifdef CONFIG_WMMPS_STA
struct registry_priv *pregistrypriv = &padapter->registrypriv;
#endif
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
#ifdef CONFIG_TDLS
struct sta_priv *pstapriv = &padapter->stapriv;
_irqL irqL;
int i, j;
_list *plist, *phead;
struct sta_info *ptdls_sta;
#endif /* CONFIG_TDLS */
#ifdef CONFIG_LPS_PG
u8 lps_pg_hdl_id = 0;
#endif
if (ps_mode > PM_Card_Disable) {
return;
}
if (pwrpriv->pwr_mode == ps_mode) {
if (PS_MODE_ACTIVE == ps_mode)
return;
#ifndef CONFIG_BT_COEXIST
#ifdef CONFIG_WMMPS_STA
if (!rtw_is_wmmps_mode(padapter))
#endif /* CONFIG_WMMPS_STA */
if ((pwrpriv->smart_ps == smart_ps) &&
(pwrpriv->bcn_ant_mode == bcn_ant_mode))
return;
#endif /* !CONFIG_BT_COEXIST */
}
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
if (PS_MODE_ACTIVE != ps_mode) {
rtw_set_ps_rsvd_page(padapter);
rtw_set_default_port_id(padapter);
}
#endif
#ifdef CONFIG_LPS_PG
if ((PS_MODE_ACTIVE != ps_mode) && (pwrpriv->lps_level == LPS_PG)) {
if (pwrpriv->wowlan_mode != _TRUE) {
/*rtw_hal_set_lps_pg_info(padapter);*/
lps_pg_hdl_id = LPS_PG_INFO_CFG;
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
}
}
#endif
#ifdef CONFIG_LPS_LCLK
_enter_pwrlock(&pwrpriv->lock);
#endif
/* if(pwrpriv->pwr_mode == PS_MODE_ACTIVE) */
if (ps_mode == PS_MODE_ACTIVE) {
if (1
#ifdef CONFIG_BT_COEXIST
&& (((rtw_btcoex_IsBtControlLps(padapter) == _FALSE)
#ifdef CONFIG_P2P_PS
&& (pwdinfo->opp_ps == 0)
#endif /* CONFIG_P2P_PS */
)
|| ((rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
&& (rtw_btcoex_IsLpsOn(padapter) == _FALSE))
)
#else /* !CONFIG_BT_COEXIST */
#ifdef CONFIG_P2P_PS
&& (pwdinfo->opp_ps == 0)
#endif /* CONFIG_P2P_PS */
#endif /* !CONFIG_BT_COEXIST */
) {
RTW_INFO(FUNC_ADPT_FMT" Leave 802.11 power save - %s\n",
FUNC_ADPT_ARG(padapter), msg);
if (pwrpriv->lps_leave_cnts < UINT_MAX)
pwrpriv->lps_leave_cnts++;
else
pwrpriv->lps_leave_cnts = 0;
#ifdef CONFIG_TDLS
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
ptdls_sta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 0, 0, 0);
plist = get_next(plist);
}
}
#endif /* CONFIG_TDLS */
pwrpriv->pwr_mode = ps_mode;
rtw_set_rpwm(padapter, PS_STATE_S4);
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN) || defined(CONFIG_P2P_WOWLAN)
if (pwrpriv->wowlan_mode == _TRUE ||
pwrpriv->wowlan_ap_mode == _TRUE ||
pwrpriv->wowlan_p2p_mode == _TRUE) {
systime start_time;
u32 delay_ms;
u8 val8;
delay_ms = 20;
start_time = rtw_get_current_time();
do {
rtw_hal_get_hwreg(padapter, HW_VAR_SYS_CLKR, &val8);
if (!(val8 & BIT(4))) { /* 0x08 bit4 =1 --> in 32k, bit4 = 0 --> leave 32k */
pwrpriv->cpwm = PS_STATE_S4;
break;
}
if (rtw_get_passing_time_ms(start_time) > delay_ms) {
RTW_INFO("%s: Wait for FW 32K leave more than %u ms!!!\n",
__FUNCTION__, delay_ms);
pdbgpriv->dbg_wow_leave_ps_fail_cnt++;
break;
}
rtw_usleep_os(100);
} while (1);
}
#endif
#ifdef CONFIG_LPS_PG
if (pwrpriv->lps_level == LPS_PG) {
lps_pg_hdl_id = LPS_PG_REDLEMEM;
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
}
#endif
#ifdef CONFIG_WOWLAN
if (pwrpriv->wowlan_mode == _TRUE)
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_INACTIVE_IPS, (u8 *)(&ps_mode));
#endif /* CONFIG_WOWLAN */
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_STATE_CHK, (u8 *)(&ps_mode));
#ifdef CONFIG_LPS_PG
if (pwrpriv->lps_level == LPS_PG) {
lps_pg_hdl_id = LPS_PG_PHYDM_EN;
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
}
#endif
#ifdef CONFIG_LPS_POFF
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_POFF_SET_MODE,
(u8 *)(&ps_mode));
#endif /*CONFIG_LPS_POFF*/
pwrpriv->bFwCurrentInPSMode = _FALSE;
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_LpsNotify(padapter, ps_mode);
#endif /* CONFIG_BT_COEXIST */
}
} else {
if ((PS_RDY_CHECK(padapter) && check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE))
#ifdef CONFIG_BT_COEXIST
|| ((rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
&& (rtw_btcoex_IsLpsOn(padapter) == _TRUE))
#endif
#ifdef CONFIG_P2P_WOWLAN
|| (_TRUE == pwrpriv->wowlan_p2p_mode)
#endif /* CONFIG_P2P_WOWLAN */
#ifdef CONFIG_WOWLAN
|| WOWLAN_IS_STA_MIX_MODE(padapter)
#endif /* CONFIG_WOWLAN */
) {
u8 pslv;
RTW_INFO(FUNC_ADPT_FMT" Enter 802.11 power save - %s\n",
FUNC_ADPT_ARG(padapter), msg);
if (pwrpriv->lps_enter_cnts < UINT_MAX)
pwrpriv->lps_enter_cnts++;
else
pwrpriv->lps_enter_cnts = 0;
#ifdef CONFIG_TDLS
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
ptdls_sta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 1, 0, 0);
plist = get_next(plist);
}
}
#endif /* CONFIG_TDLS */
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_LpsNotify(padapter, ps_mode);
#endif /* CONFIG_BT_COEXIST */
#ifdef CONFIG_LPS_POFF
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_POFF_SET_MODE,
(u8 *)(&ps_mode));
#endif /*CONFIG_LPS_POFF*/
pwrpriv->bFwCurrentInPSMode = _TRUE;
pwrpriv->pwr_mode = ps_mode;
pwrpriv->smart_ps = smart_ps;
pwrpriv->bcn_ant_mode = bcn_ant_mode;
#ifdef CONFIG_LPS_PG
if (pwrpriv->lps_level == LPS_PG) {
lps_pg_hdl_id = LPS_PG_PHYDM_DIS;
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
}
#endif
#ifdef CONFIG_WMMPS_STA
pwrpriv->wmm_smart_ps = pregistrypriv->wmm_smart_ps;
#endif /* CONFIG_WMMPS_STA */
if (check_fwstate(pmlmepriv, _FW_LINKED))
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
#ifdef CONFIG_WOWLAN
if (pwrpriv->wowlan_mode == _TRUE)
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_INACTIVE_IPS, (u8 *)(&ps_mode));
#endif /* CONFIG_WOWLAN */
#ifdef CONFIG_P2P_PS
/* Set CTWindow after LPS */
if (pwdinfo->opp_ps == 1)
p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 0);
#endif /* CONFIG_P2P_PS */
pslv = PS_STATE_S2;
#ifdef CONFIG_LPS_LCLK
if (pwrpriv->alives == 0)
pslv = PS_STATE_S0;
#endif /* CONFIG_LPS_LCLK */
#ifdef CONFIG_BT_COEXIST
if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
u8 val8;
val8 = rtw_btcoex_LpsVal(padapter);
if (val8 & BIT(4))
pslv = PS_STATE_S2;
}
#endif /* CONFIG_BT_COEXIST */
rtw_set_rpwm(padapter, pslv);
}
}
#ifdef CONFIG_LPS_LCLK
_exit_pwrlock(&pwrpriv->lock);
#endif
}
/*
* Description:
* Enter the leisure power save mode.
* */
void LPS_Enter(PADAPTER padapter, const char *msg)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
int i;
char buf[32] = {0};
#ifdef DBG_LA_MODE
struct registry_priv *registry_par = &(padapter->registrypriv);
#endif
/* RTW_INFO("+LeisurePSEnter\n"); */
if (GET_HAL_DATA(padapter)->bFWReady == _FALSE)
return;
#ifdef CONFIG_BT_COEXIST
if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
return;
#endif
#ifdef DBG_LA_MODE
if(registry_par->la_mode_en == 1) {
RTW_INFO("%s LA debug mode lps_leave \n", __func__);
return;
}
#endif
/* Skip lps enter request if number of assocated adapters is not 1 */
if (rtw_mi_get_assoc_if_num(padapter) != 1)
return;
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
/* Skip lps enter request for adapter not port0 */
if (get_hw_port(padapter) != HW_PORT0)
return;
#endif
for (i = 0; i < dvobj->iface_nums; i++) {
if (PS_RDY_CHECK(dvobj->padapters[i]) == _FALSE)
return;
}
#ifdef CONFIG_CLIENT_PORT_CFG
if ((rtw_hal_get_port(padapter) == CLT_PORT_INVALID) ||
get_clt_num(padapter) > MAX_CLIENT_PORT_NUM){
RTW_ERR(ADPT_FMT" cannot get client port or clt num(%d) over than 4\n", ADPT_ARG(padapter), get_clt_num(padapter));
return;
}
#endif
#ifdef CONFIG_P2P_PS
if (padapter->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
return;/* supporting p2p client ps NOA via H2C_8723B_P2P_PS_OFFLOAD */
}
#endif /* CONFIG_P2P_PS */
if (pwrpriv->bLeisurePs) {
/* Idle for a while if we connect to AP a while ago. */
if (pwrpriv->LpsIdleCount >= 2) { /* 4 Sec */
if (pwrpriv->pwr_mode == PS_MODE_ACTIVE) {
#ifdef CONFIG_WMMPS_STA
if (rtw_is_wmmps_mode(padapter))
msg = "WMMPS_IDLE";
#endif /* CONFIG_WMMPS_STA */
sprintf(buf, "WIFI-%s", msg);
pwrpriv->bpower_saving = _TRUE;
#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
pwrpriv->pwr_saving_start_time = rtw_get_current_time();
#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
rtw_set_ps_mode(padapter, pwrpriv->power_mgnt, padapter->registrypriv.smart_ps, 0, buf);
}
} else
pwrpriv->LpsIdleCount++;
}
/* RTW_INFO("-LeisurePSEnter\n"); */
}
/*
* Description:
* Leave the leisure power save mode.
* */
void LPS_Leave(PADAPTER padapter, const char *msg)
{
#define LPS_LEAVE_TIMEOUT_MS 100
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
char buf[32] = {0};
#ifdef DBG_CHECK_FW_PS_STATE
struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
#endif
/* RTW_INFO("+LeisurePSLeave\n"); */
#ifdef CONFIG_BT_COEXIST
if (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)
return;
#endif
if (pwrpriv->bLeisurePs) {
if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
#ifdef CONFIG_WMMPS_STA
if (rtw_is_wmmps_mode(padapter))
msg = "WMMPS_BUSY";
#endif /* CONFIG_WMMPS_STA */
sprintf(buf, "WIFI-%s", msg);
rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, buf);
#ifdef CONFIG_RTW_CFGVEDNOR_LLSTATS
pwrpriv->pwr_saving_time += rtw_get_passing_time_ms(pwrpriv->pwr_saving_start_time);
#endif /* CONFIG_RTW_CFGVEDNOR_LLSTATS */
}
}
pwrpriv->bpower_saving = _FALSE;
#ifdef DBG_CHECK_FW_PS_STATE
if (rtw_fw_ps_state(padapter) == _FAIL) {
RTW_INFO("leave lps, fw in 32k\n");
pdbgpriv->dbg_leave_lps_fail_cnt++;
}
#endif /* DBG_CHECK_FW_PS_STATE
* RTW_INFO("-LeisurePSLeave\n"); */
}
#ifdef CONFIG_WOWLAN
void rtw_wow_lps_level_decide(_adapter *adapter, u8 wow_en)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
if (wow_en) {
pwrpriv->lps_level_bk = pwrpriv->lps_level;
pwrpriv->lps_level = pwrpriv->wowlan_lps_level;
#ifdef CONFIG_LPS_1T1R
pwrpriv->lps_1t1r_bk = pwrpriv->lps_1t1r;
pwrpriv->lps_1t1r = pwrpriv->wowlan_lps_1t1r;
#endif
} else {
pwrpriv->lps_level = pwrpriv->lps_level_bk;
#ifdef CONFIG_LPS_1T1R
pwrpriv->lps_1t1r = pwrpriv->lps_1t1r_bk;
#endif
}
}
#endif /* CONFIG_WOWLAN */
#endif /* CONFIG_LPS */
void LeaveAllPowerSaveModeDirect(PADAPTER Adapter)
{
PADAPTER pri_padapter = GET_PRIMARY_ADAPTER(Adapter);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(Adapter);
#ifdef CONFIG_LPS_LCLK
#ifndef CONFIG_DETECT_CPWM_BY_POLLING
u8 cpwm_orig;
#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
u8 rpwm;
#endif
RTW_INFO("%s.....\n", __FUNCTION__);
if (rtw_is_surprise_removed(Adapter)) {
RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
return;
}
if (rtw_mi_check_status(Adapter, MI_LINKED)) { /*connect*/
if (pwrpriv->pwr_mode == PS_MODE_ACTIVE) {
RTW_INFO("%s: Driver Already Leave LPS\n", __FUNCTION__);
return;
}
#ifdef CONFIG_LPS_LCLK
_enter_pwrlock(&pwrpriv->lock);
#ifndef CONFIG_DETECT_CPWM_BY_POLLING
cpwm_orig = 0;
rtw_hal_get_hwreg(Adapter, HW_VAR_CPWM, &cpwm_orig);
#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
rpwm = rtw_set_rpwm(Adapter, PS_STATE_S4);
#ifndef CONFIG_DETECT_CPWM_BY_POLLING
if (rpwm != 0xFF && rpwm & PS_ACK)
rtw_cpwm_polling(Adapter, rpwm, cpwm_orig);
#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
_exit_pwrlock(&pwrpriv->lock);
#endif/*CONFIG_LPS_LCLK*/
#ifdef CONFIG_P2P_PS
p2p_ps_wk_cmd(pri_padapter, P2P_PS_DISABLE, 0);
#endif /* CONFIG_P2P_PS */
#ifdef CONFIG_LPS
rtw_lps_ctrl_wk_cmd(pri_padapter, LPS_CTRL_LEAVE, RTW_CMDF_DIRECTLY);
#endif
} else {
if (pwrpriv->rf_pwrstate == rf_off) {
#ifdef CONFIG_AUTOSUSPEND
if (Adapter->registrypriv.usbss_enable) {
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
usb_disable_autosuspend(adapter_to_dvobj(Adapter)->pusbdev);
#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
adapter_to_dvobj(Adapter)->pusbdev->autosuspend_disabled = Adapter->bDisableAutosuspend;/* autosuspend disabled by the user */
#endif
} else
#endif
{
#if defined(CONFIG_FWLPS_IN_IPS) || defined(CONFIG_SWLPS_IN_IPS) || defined(CONFIG_RTL8188E)
#ifdef CONFIG_IPS
if (_FALSE == ips_leave(pri_padapter))
RTW_INFO("======> ips_leave fail.............\n");
#endif
#endif /* CONFIG_SWLPS_IN_IPS || (CONFIG_PLATFORM_SPRD && CONFIG_RTL8188E) */
}
}
}
}
/*
* Description: Leave all power save mode: LPS, FwLPS, IPS if needed.
* Move code to function by tynli. 2010.03.26.
* */
void LeaveAllPowerSaveMode(PADAPTER Adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(Adapter);
u8 enqueue = 0;
int i;
#ifndef CONFIG_NEW_NETDEV_HDL
if (_FALSE == Adapter->bup) {
RTW_INFO(FUNC_ADPT_FMT ": bup=%d Skip!\n",
FUNC_ADPT_ARG(Adapter), Adapter->bup);
return;
}
#endif
/* RTW_INFO(FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(Adapter));*/
if (rtw_is_surprise_removed(Adapter)) {
RTW_INFO(FUNC_ADPT_FMT ": bSurpriseRemoved=_TRUE Skip!\n", FUNC_ADPT_ARG(Adapter));
return;
}
if (rtw_mi_get_assoc_if_num(Adapter)) {
/* connect */
#ifdef CONFIG_LPS_LCLK
enqueue = 1;
#endif
#ifdef CONFIG_P2P_PS
for (i = 0; i < dvobj->iface_nums; i++) {
_adapter *iface = dvobj->padapters[i];
struct wifidirect_info *pwdinfo = &(iface->wdinfo);
if (pwdinfo->p2p_ps_mode > P2P_PS_NONE)
p2p_ps_wk_cmd(iface, P2P_PS_DISABLE, enqueue);
}
#endif /* CONFIG_P2P_PS */
#ifdef CONFIG_LPS
rtw_lps_ctrl_wk_cmd(Adapter, LPS_CTRL_LEAVE, enqueue ? 0 : RTW_CMDF_DIRECTLY);
#endif
#ifdef CONFIG_LPS_LCLK
LPS_Leave_check(Adapter);
#endif
} else {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate == rf_off) {
#ifdef CONFIG_AUTOSUSPEND
if (Adapter->registrypriv.usbss_enable) {
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35))
usb_disable_autosuspend(adapter_to_dvobj(Adapter)->pusbdev);
#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22) && LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 34))
adapter_to_dvobj(Adapter)->pusbdev->autosuspend_disabled = Adapter->bDisableAutosuspend;/* autosuspend disabled by the user */
#endif
} else
#endif
{
#if defined(CONFIG_FWLPS_IN_IPS) || defined(CONFIG_SWLPS_IN_IPS) || (defined(CONFIG_PLATFORM_SPRD) && defined(CONFIG_RTL8188E))
#ifdef CONFIG_IPS
if (_FALSE == ips_leave(Adapter))
RTW_INFO("======> ips_leave fail.............\n");
#endif
#endif /* CONFIG_SWLPS_IN_IPS || (CONFIG_PLATFORM_SPRD && CONFIG_RTL8188E) */
}
}
}
}
#ifdef CONFIG_LPS_LCLK
void LPS_Leave_check(
PADAPTER padapter)
{
struct pwrctrl_priv *pwrpriv;
systime start_time;
u8 bReady;
pwrpriv = adapter_to_pwrctl(padapter);
bReady = _FALSE;
start_time = rtw_get_current_time();
rtw_yield_os();
while (1) {
_enter_pwrlock(&pwrpriv->lock);
if (rtw_is_surprise_removed(padapter)
|| (!rtw_is_hw_init_completed(padapter))
#ifdef CONFIG_USB_HCI
|| rtw_is_drv_stopped(padapter)
#endif
|| (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
)
bReady = _TRUE;
_exit_pwrlock(&pwrpriv->lock);
if (_TRUE == bReady)
break;
if (rtw_get_passing_time_ms(start_time) > 100) {
RTW_ERR("Wait for cpwm event than 100 ms!!!\n");
break;
}
rtw_msleep_os(1);
}
}
/*
* Caller:ISR handler...
*
* This will be called when CPWM interrupt is up.
*
* using to update cpwn of drv; and drv willl make a decision to up or down pwr level
*/
void cpwm_int_hdl(
PADAPTER padapter,
struct reportpwrstate_parm *preportpwrstate)
{
struct pwrctrl_priv *pwrpriv;
if (!padapter)
goto exit;
if (RTW_CANNOT_RUN(padapter))
goto exit;
pwrpriv = adapter_to_pwrctl(padapter);
#if 0
if (pwrpriv->cpwm_tog == (preportpwrstate->state & PS_TOGGLE)) {
goto exit;
}
#endif
_enter_pwrlock(&pwrpriv->lock);
#ifdef CONFIG_LPS_RPWM_TIMER
if (pwrpriv->rpwm < PS_STATE_S2) {
RTW_INFO("%s: Redundant CPWM Int. RPWM=0x%02X CPWM=0x%02x\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
_exit_pwrlock(&pwrpriv->lock);
goto exit;
}
#endif /* CONFIG_LPS_RPWM_TIMER */
pwrpriv->cpwm = PS_STATE(preportpwrstate->state);
pwrpriv->cpwm_tog = preportpwrstate->state & PS_TOGGLE;
if (pwrpriv->cpwm >= PS_STATE_S2) {
if (pwrpriv->alives & CMD_ALIVE)
_rtw_up_sema(&padapter->cmdpriv.cmd_queue_sema);
if (pwrpriv->alives & XMIT_ALIVE)
_rtw_up_sema(&padapter->xmitpriv.xmit_sema);
}
_exit_pwrlock(&pwrpriv->lock);
exit:
return;
}
static void cpwm_event_callback(struct work_struct *work)
{
struct pwrctrl_priv *pwrpriv = container_of(work, struct pwrctrl_priv, cpwm_event);
struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
struct reportpwrstate_parm report;
/* RTW_INFO("%s\n",__FUNCTION__); */
report.state = PS_STATE_S2;
cpwm_int_hdl(adapter, &report);
}
static void dma_event_callback(struct work_struct *work)
{
struct pwrctrl_priv *pwrpriv = container_of(work, struct pwrctrl_priv, dma_event);
struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
rtw_unregister_tx_alive(adapter);
}
#ifdef CONFIG_LPS_RPWM_TIMER
#define DBG_CPWM_CHK_FAIL
#if defined(DBG_CPWM_CHK_FAIL) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C))
#define CPU_EXCEPTION_CODE 0xFAFAFAFA
static void rtw_cpwm_chk_fail_debug(_adapter *padapter)
{
u32 cpu_state;
cpu_state = rtw_read32(padapter, 0x10FC);
RTW_INFO("[PS-DBG] Reg_10FC =0x%08x\n", cpu_state);
RTW_INFO("[PS-DBG] Reg_10F8 =0x%08x\n", rtw_read32(padapter, 0x10F8));
RTW_INFO("[PS-DBG] Reg_11F8 =0x%08x\n", rtw_read32(padapter, 0x11F8));
RTW_INFO("[PS-DBG] Reg_4A4 =0x%08x\n", rtw_read32(padapter, 0x4A4));
RTW_INFO("[PS-DBG] Reg_4A8 =0x%08x\n", rtw_read32(padapter, 0x4A8));
if (cpu_state == CPU_EXCEPTION_CODE) {
RTW_INFO("[PS-DBG] Reg_48C =0x%08x\n", rtw_read32(padapter, 0x48C));
RTW_INFO("[PS-DBG] Reg_490 =0x%08x\n", rtw_read32(padapter, 0x490));
RTW_INFO("[PS-DBG] Reg_494 =0x%08x\n", rtw_read32(padapter, 0x494));
RTW_INFO("[PS-DBG] Reg_498 =0x%08x\n", rtw_read32(padapter, 0x498));
RTW_INFO("[PS-DBG] Reg_49C =0x%08x\n", rtw_read32(padapter, 0x49C));
RTW_INFO("[PS-DBG] Reg_4A0 =0x%08x\n", rtw_read32(padapter, 0x4A0));
RTW_INFO("[PS-DBG] Reg_1BC =0x%08x\n", rtw_read32(padapter, 0x1BC));
RTW_INFO("[PS-DBG] Reg_008 =0x%08x\n", rtw_read32(padapter, 0x08));
RTW_INFO("[PS-DBG] Reg_2F0 =0x%08x\n", rtw_read32(padapter, 0x2F0));
RTW_INFO("[PS-DBG] Reg_2F4 =0x%08x\n", rtw_read32(padapter, 0x2F4));
RTW_INFO("[PS-DBG] Reg_2F8 =0x%08x\n", rtw_read32(padapter, 0x2F8));
RTW_INFO("[PS-DBG] Reg_2FC =0x%08x\n", rtw_read32(padapter, 0x2FC));
rtw_dump_fifo(RTW_DBGDUMP, padapter, 5, 0, 3072);
}
}
#endif
static void rpwmtimeout_workitem_callback(struct work_struct *work)
{
PADAPTER padapter;
struct dvobj_priv *dvobj;
struct pwrctrl_priv *pwrpriv;
pwrpriv = container_of(work, struct pwrctrl_priv, rpwmtimeoutwi);
dvobj = pwrctl_to_dvobj(pwrpriv);
padapter = dvobj_get_primary_adapter(dvobj);
if (!padapter)
return;
if (RTW_CANNOT_RUN(padapter))
return;
_enter_pwrlock(&pwrpriv->lock);
if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2)) {
RTW_INFO("%s: rpwm=0x%02X cpwm=0x%02X CPWM done!\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
goto exit;
}
if (pwrpriv->rpwm_retry++ < LPS_RPWM_RETRY_CNT) {
u8 rpwm = (pwrpriv->rpwm | pwrpriv->tog | PS_ACK);
rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&rpwm));
pwrpriv->tog += 0x80;
_set_timer(&pwrpriv->pwr_rpwm_timer, LPS_CPWM_TIMEOUT_MS);
goto exit;
}
pwrpriv->rpwm_retry = 0;
_exit_pwrlock(&pwrpriv->lock);
#if defined(DBG_CPWM_CHK_FAIL) && (defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C))
RTW_INFO("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
rtw_cpwm_chk_fail_debug(padapter);
#endif
if (rtw_read8(padapter, 0x100) != 0xEA) {
#if 1
struct reportpwrstate_parm report;
report.state = PS_STATE_S2;
RTW_INFO("\n%s: FW already leave 32K!\n\n", __func__);
cpwm_int_hdl(padapter, &report);
#else
RTW_INFO("\n%s: FW already leave 32K!\n\n", __func__);
cpwm_event_callback(&pwrpriv->cpwm_event);
#endif
return;
}
_enter_pwrlock(&pwrpriv->lock);
if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2)) {
RTW_INFO("%s: cpwm=%d, nothing to do!\n", __func__, pwrpriv->cpwm);
goto exit;
}
pwrpriv->brpwmtimeout = _TRUE;
rtw_set_rpwm(padapter, pwrpriv->rpwm);
pwrpriv->brpwmtimeout = _FALSE;
exit:
_exit_pwrlock(&pwrpriv->lock);
}
/*
* This function is a timer handler, can't do any IO in it.
*/
static void pwr_rpwm_timeout_handler(void *FunctionContext)
{
PADAPTER padapter;
struct pwrctrl_priv *pwrpriv;
padapter = (PADAPTER)FunctionContext;
pwrpriv = adapter_to_pwrctl(padapter);
if (!padapter)
return;
if (RTW_CANNOT_RUN(padapter))
return;
RTW_INFO("+%s: rpwm=0x%02X cpwm=0x%02X\n", __func__, pwrpriv->rpwm, pwrpriv->cpwm);
if ((pwrpriv->rpwm == pwrpriv->cpwm) || (pwrpriv->cpwm >= PS_STATE_S2)) {
RTW_INFO("+%s: cpwm=%d, nothing to do!\n", __func__, pwrpriv->cpwm);
return;
}
_set_workitem(&pwrpriv->rpwmtimeoutwi);
}
#endif /* CONFIG_LPS_RPWM_TIMER */
__inline static void register_task_alive(struct pwrctrl_priv *pwrctrl, u32 tag)
{
pwrctrl->alives |= tag;
}
__inline static void unregister_task_alive(struct pwrctrl_priv *pwrctrl, u32 tag)
{
pwrctrl->alives &= ~tag;
}
/*
* Description:
* Check if the fw_pwrstate is okay for I/O.
* If not (cpwm is less than S2), then the sub-routine
* will raise the cpwm to be greater than or equal to S2.
*
* Calling Context: Passive
*
* Constraint:
* 1. this function will request pwrctrl->lock
*
* Return Value:
* _SUCCESS hardware is ready for I/O
* _FAIL can't I/O right now
*/
s32 rtw_register_task_alive(PADAPTER padapter, u32 task)
{
s32 res;
struct pwrctrl_priv *pwrctrl;
u8 pslv;
res = _SUCCESS;
pwrctrl = adapter_to_pwrctl(padapter);
pslv = PS_STATE_S2;
_enter_pwrlock(&pwrctrl->lock);
register_task_alive(pwrctrl, task);
if (pwrctrl->bFwCurrentInPSMode == _TRUE) {
if (pwrctrl->cpwm < pslv) {
if (pwrctrl->cpwm < PS_STATE_S2)
res = _FAIL;
if (pwrctrl->rpwm < pslv)
rtw_set_rpwm(padapter, pslv);
}
}
_exit_pwrlock(&pwrctrl->lock);
#ifdef CONFIG_DETECT_CPWM_BY_POLLING
if (_FAIL == res) {
if (pwrctrl->cpwm >= PS_STATE_S2)
res = _SUCCESS;
}
#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
return res;
}
/*
* Description:
* If task is done, call this func. to power down firmware again.
*
* Constraint:
* 1. this function will request pwrctrl->lock
*
* Return Value:
* none
*/
void rtw_unregister_task_alive(PADAPTER padapter, u32 task)
{
struct pwrctrl_priv *pwrctrl;
u8 pslv;
pwrctrl = adapter_to_pwrctl(padapter);
pslv = PS_STATE_S0;
#ifdef CONFIG_BT_COEXIST
if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
u8 val8;
val8 = rtw_btcoex_LpsVal(padapter);
if (val8 & BIT(4))
pslv = PS_STATE_S2;
}
#endif /* CONFIG_BT_COEXIST */
_enter_pwrlock(&pwrctrl->lock);
unregister_task_alive(pwrctrl, task);
if ((pwrctrl->pwr_mode != PS_MODE_ACTIVE)
&& (pwrctrl->bFwCurrentInPSMode == _TRUE)) {
if (pwrctrl->cpwm > pslv) {
if ((pslv >= PS_STATE_S2) || (pwrctrl->alives == 0))
rtw_set_rpwm(padapter, pslv);
}
}
_exit_pwrlock(&pwrctrl->lock);
}
/*
* Caller: rtw_xmit_thread
*
* Check if the fw_pwrstate is okay for xmit.
* If not (cpwm is less than S3), then the sub-routine
* will raise the cpwm to be greater than or equal to S3.
*
* Calling Context: Passive
*
* Return Value:
* _SUCCESS rtw_xmit_thread can write fifo/txcmd afterwards.
* _FAIL rtw_xmit_thread can not do anything.
*/
s32 rtw_register_tx_alive(PADAPTER padapter)
{
s32 res;
struct pwrctrl_priv *pwrctrl;
u8 pslv;
res = _SUCCESS;
pwrctrl = adapter_to_pwrctl(padapter);
pslv = PS_STATE_S2;
_enter_pwrlock(&pwrctrl->lock);
register_task_alive(pwrctrl, XMIT_ALIVE);
if (pwrctrl->bFwCurrentInPSMode == _TRUE) {
if (pwrctrl->cpwm < pslv) {
if (pwrctrl->cpwm < PS_STATE_S2)
res = _FAIL;
if (pwrctrl->rpwm < pslv)
rtw_set_rpwm(padapter, pslv);
}
}
_exit_pwrlock(&pwrctrl->lock);
#ifdef CONFIG_DETECT_CPWM_BY_POLLING
if (_FAIL == res) {
if (pwrctrl->cpwm >= PS_STATE_S2)
res = _SUCCESS;
}
#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
return res;
}
/*
* Caller: rtw_cmd_thread
*
* Check if the fw_pwrstate is okay for issuing cmd.
* If not (cpwm should be is less than S2), then the sub-routine
* will raise the cpwm to be greater than or equal to S2.
*
* Calling Context: Passive
*
* Return Value:
* _SUCCESS rtw_cmd_thread can issue cmds to firmware afterwards.
* _FAIL rtw_cmd_thread can not do anything.
*/
s32 rtw_register_cmd_alive(PADAPTER padapter)
{
s32 res;
struct pwrctrl_priv *pwrctrl;
u8 pslv;
res = _SUCCESS;
pwrctrl = adapter_to_pwrctl(padapter);
pslv = PS_STATE_S2;
_enter_pwrlock(&pwrctrl->lock);
register_task_alive(pwrctrl, CMD_ALIVE);
if (pwrctrl->bFwCurrentInPSMode == _TRUE) {
if (pwrctrl->cpwm < pslv) {
if (pwrctrl->cpwm < PS_STATE_S2)
res = _FAIL;
if (pwrctrl->rpwm < pslv)
rtw_set_rpwm(padapter, pslv);
}
}
_exit_pwrlock(&pwrctrl->lock);
#ifdef CONFIG_DETECT_CPWM_BY_POLLING
if (_FAIL == res) {
if (pwrctrl->cpwm >= PS_STATE_S2)
res = _SUCCESS;
}
#endif /* CONFIG_DETECT_CPWM_BY_POLLING */
return res;
}
/*
* Caller: rx_isr
*
* Calling Context: Dispatch/ISR
*
* Return Value:
* _SUCCESS
* _FAIL
*/
s32 rtw_register_rx_alive(PADAPTER padapter)
{
struct pwrctrl_priv *pwrctrl;
pwrctrl = adapter_to_pwrctl(padapter);
_enter_pwrlock(&pwrctrl->lock);
register_task_alive(pwrctrl, RECV_ALIVE);
_exit_pwrlock(&pwrctrl->lock);
return _SUCCESS;
}
/*
* Caller: evt_isr or evt_thread
*
* Calling Context: Dispatch/ISR or Passive
*
* Return Value:
* _SUCCESS
* _FAIL
*/
s32 rtw_register_evt_alive(PADAPTER padapter)
{
struct pwrctrl_priv *pwrctrl;
pwrctrl = adapter_to_pwrctl(padapter);
_enter_pwrlock(&pwrctrl->lock);
register_task_alive(pwrctrl, EVT_ALIVE);
_exit_pwrlock(&pwrctrl->lock);
return _SUCCESS;
}
/*
* Caller: ISR
*
* If ISR's txdone,
* No more pkts for TX,
* Then driver shall call this fun. to power down firmware again.
*/
void rtw_unregister_tx_alive(PADAPTER padapter)
{
struct pwrctrl_priv *pwrctrl;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 pslv, i;
pwrctrl = adapter_to_pwrctl(padapter);
pslv = PS_STATE_S0;
#ifdef CONFIG_BT_COEXIST
if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
u8 val8;
val8 = rtw_btcoex_LpsVal(padapter);
if (val8 & BIT(4))
pslv = PS_STATE_S2;
}
#endif /* CONFIG_BT_COEXIST */
#ifdef CONFIG_P2P_PS
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
if (iface->wdinfo.p2p_ps_mode > P2P_PS_NONE) {
pslv = PS_STATE_S2;
break;
}
}
}
#endif
_enter_pwrlock(&pwrctrl->lock);
unregister_task_alive(pwrctrl, XMIT_ALIVE);
if ((pwrctrl->pwr_mode != PS_MODE_ACTIVE)
&& (pwrctrl->bFwCurrentInPSMode == _TRUE)) {
if (pwrctrl->cpwm > pslv) {
if ((pslv >= PS_STATE_S2) || (pwrctrl->alives == 0))
rtw_set_rpwm(padapter, pslv);
}
}
_exit_pwrlock(&pwrctrl->lock);
}
/*
* Caller: ISR
*
* If all commands have been done,
* and no more command to do,
* then driver shall call this fun. to power down firmware again.
*/
void rtw_unregister_cmd_alive(PADAPTER padapter)
{
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pwrctrl_priv *pwrctrl;
u8 pslv, i;
pwrctrl = adapter_to_pwrctl(padapter);
pslv = PS_STATE_S0;
#ifdef CONFIG_BT_COEXIST
if ((rtw_btcoex_IsBtDisabled(padapter) == _FALSE)
&& (rtw_btcoex_IsBtControlLps(padapter) == _TRUE)) {
u8 val8;
val8 = rtw_btcoex_LpsVal(padapter);
if (val8 & BIT(4))
pslv = PS_STATE_S2;
}
#endif /* CONFIG_BT_COEXIST */
#ifdef CONFIG_P2P_PS
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
if (iface->wdinfo.p2p_ps_mode > P2P_PS_NONE) {
pslv = PS_STATE_S2;
break;
}
}
}
#endif
_enter_pwrlock(&pwrctrl->lock);
unregister_task_alive(pwrctrl, CMD_ALIVE);
if ((pwrctrl->pwr_mode != PS_MODE_ACTIVE)
&& (pwrctrl->bFwCurrentInPSMode == _TRUE)) {
if (pwrctrl->cpwm > pslv) {
if ((pslv >= PS_STATE_S2) || (pwrctrl->alives == 0))
rtw_set_rpwm(padapter, pslv);
}
}
_exit_pwrlock(&pwrctrl->lock);
}
/*
* Caller: ISR
*/
void rtw_unregister_rx_alive(PADAPTER padapter)
{
struct pwrctrl_priv *pwrctrl;
pwrctrl = adapter_to_pwrctl(padapter);
_enter_pwrlock(&pwrctrl->lock);
unregister_task_alive(pwrctrl, RECV_ALIVE);
_exit_pwrlock(&pwrctrl->lock);
}
void rtw_unregister_evt_alive(PADAPTER padapter)
{
struct pwrctrl_priv *pwrctrl;
pwrctrl = adapter_to_pwrctl(padapter);
unregister_task_alive(pwrctrl, EVT_ALIVE);
_exit_pwrlock(&pwrctrl->lock);
}
#endif /* CONFIG_LPS_LCLK */
#ifdef CONFIG_RESUME_IN_WORKQUEUE
static void resume_workitem_callback(struct work_struct *work);
#endif /* CONFIG_RESUME_IN_WORKQUEUE */
void rtw_init_pwrctrl_priv(PADAPTER padapter)
{
#ifdef CONFIG_LPS_1T1R
#define LPS_1T1R_FMT ", LPS_1T1R=%d"
#define LPS_1T1R_ARG , pwrctrlpriv->lps_1t1r
#else
#define LPS_1T1R_FMT ""
#define LPS_1T1R_ARG
#endif
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
#ifdef CONFIG_WOWLAN
struct registry_priv *registry_par = &padapter->registrypriv;
#endif
#ifdef CONFIG_GPIO_WAKEUP
u8 val8 = 0;
#endif
#if defined(CONFIG_CONCURRENT_MODE)
if (!is_primary_adapter(padapter))
return;
#endif
_init_pwrlock(&pwrctrlpriv->lock);
_init_pwrlock(&pwrctrlpriv->check_32k_lock);
pwrctrlpriv->rf_pwrstate = rf_on;
pwrctrlpriv->ips_enter_cnts = 0;
pwrctrlpriv->ips_leave_cnts = 0;
pwrctrlpriv->lps_enter_cnts = 0;
pwrctrlpriv->lps_leave_cnts = 0;
pwrctrlpriv->bips_processing = _FALSE;
#ifdef CONFIG_LPS_CHK_BY_TP
pwrctrlpriv->lps_chk_by_tp = padapter->registrypriv.lps_chk_by_tp;
pwrctrlpriv->lps_tx_tp_th = LPS_TX_TP_TH;
pwrctrlpriv->lps_rx_tp_th = LPS_RX_TP_TH;
pwrctrlpriv->lps_bi_tp_th = LPS_BI_TP_TH;
pwrctrlpriv->lps_chk_cnt = pwrctrlpriv->lps_chk_cnt_th = LPS_TP_CHK_CNT;
pwrctrlpriv->lps_tx_pkts = LPS_CHK_PKTS_TX;
pwrctrlpriv->lps_rx_pkts = LPS_CHK_PKTS_RX;
#endif
pwrctrlpriv->ips_mode = padapter->registrypriv.ips_mode;
pwrctrlpriv->ips_mode_req = padapter->registrypriv.ips_mode;
pwrctrlpriv->ips_deny_time = rtw_get_current_time();
pwrctrlpriv->lps_level = padapter->registrypriv.lps_level;
#ifdef CONFIG_LPS_1T1R
pwrctrlpriv->lps_1t1r = padapter->registrypriv.lps_1t1r;
#endif
pwrctrlpriv->pwr_state_check_interval = RTW_PWR_STATE_CHK_INTERVAL;
pwrctrlpriv->pwr_state_check_cnts = 0;
#ifdef CONFIG_AUTOSUSPEND
pwrctrlpriv->bInternalAutoSuspend = _FALSE;
#endif
pwrctrlpriv->bInSuspend = _FALSE;
pwrctrlpriv->bkeepfwalive = _FALSE;
#ifdef CONFIG_AUTOSUSPEND
#ifdef SUPPORT_HW_RFOFF_DETECTED
pwrctrlpriv->pwr_state_check_interval = (pwrctrlpriv->bHWPwrPindetect) ? 1000 : 2000;
#endif
#endif
pwrctrlpriv->LpsIdleCount = 0;
/* pwrctrlpriv->FWCtrlPSMode =padapter->registrypriv.power_mgnt; */ /* PS_MODE_MIN; */
if (padapter->registrypriv.mp_mode == 1)
pwrctrlpriv->power_mgnt = PS_MODE_ACTIVE ;
else
pwrctrlpriv->power_mgnt = padapter->registrypriv.power_mgnt; /* PS_MODE_MIN; */
pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ? _TRUE : _FALSE;
pwrctrlpriv->bFwCurrentInPSMode = _FALSE;
pwrctrlpriv->lps_deny_time = rtw_get_current_time();
pwrctrlpriv->rpwm = 0;
pwrctrlpriv->cpwm = PS_STATE_S4;
pwrctrlpriv->pwr_mode = PS_MODE_ACTIVE;
pwrctrlpriv->smart_ps = padapter->registrypriv.smart_ps;
pwrctrlpriv->bcn_ant_mode = 0;
pwrctrlpriv->dtim = 0;
pwrctrlpriv->tog = 0x80;
pwrctrlpriv->rpwm_retry = 0;
RTW_INFO("%s: IPS_mode=%d, LPS_mode=%d, LPS_level=%d"LPS_1T1R_FMT"\n",
__func__, pwrctrlpriv->ips_mode, pwrctrlpriv->power_mgnt, pwrctrlpriv->lps_level
LPS_1T1R_ARG
);
#ifdef CONFIG_LPS_LCLK
rtw_hal_set_hwreg(padapter, HW_VAR_SET_RPWM, (u8 *)(&pwrctrlpriv->rpwm));
_init_workitem(&pwrctrlpriv->cpwm_event, cpwm_event_callback, NULL);
_init_workitem(&pwrctrlpriv->dma_event, dma_event_callback, NULL);
#ifdef CONFIG_LPS_RPWM_TIMER
pwrctrlpriv->brpwmtimeout = _FALSE;
_init_workitem(&pwrctrlpriv->rpwmtimeoutwi, rpwmtimeout_workitem_callback, NULL);
rtw_init_timer(&pwrctrlpriv->pwr_rpwm_timer, padapter, pwr_rpwm_timeout_handler, padapter);
#endif /* CONFIG_LPS_RPWM_TIMER */
#endif /* CONFIG_LPS_LCLK */
#ifdef CONFIG_LPS_PG
pwrctrlpriv->lpspg_info.name = "LPSPG_INFO";
#ifdef CONFIG_RTL8822C
pwrctrlpriv->lpspg_dpk_info.name = "LPSPG_DPK_INFO";
pwrctrlpriv->lpspg_iqk_info.name = "LPSPG_IQK_INFO";
#endif
#endif
rtw_init_timer(&pwrctrlpriv->pwr_state_check_timer, padapter, pwr_state_check_handler, padapter);
pwrctrlpriv->wowlan_mode = _FALSE;
pwrctrlpriv->wowlan_ap_mode = _FALSE;
pwrctrlpriv->wowlan_p2p_mode = _FALSE;
pwrctrlpriv->wowlan_in_resume = _FALSE;
pwrctrlpriv->wowlan_last_wake_reason = 0;
#ifdef CONFIG_RESUME_IN_WORKQUEUE
_init_workitem(&pwrctrlpriv->resume_work, resume_workitem_callback, NULL);
pwrctrlpriv->rtw_workqueue = create_singlethread_workqueue("rtw_workqueue");
#endif /* CONFIG_RESUME_IN_WORKQUEUE */
#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
pwrctrlpriv->early_suspend.suspend = NULL;
rtw_register_early_suspend(pwrctrlpriv);
#endif /* CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER */
#ifdef CONFIG_GPIO_WAKEUP
/*default low active*/
pwrctrlpriv->is_high_active = HIGH_ACTIVE_DEV2HST;
pwrctrlpriv->hst2dev_high_active = HIGH_ACTIVE_HST2DEV;
#ifdef CONFIG_RTW_ONE_PIN_GPIO
rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
#else
#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
if (pwrctrlpriv->is_high_active == 0)
rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
else
rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
#else
val8 = (pwrctrlpriv->is_high_active == 0) ? 1 : 0;
rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
RTW_INFO("%s: set GPIO_%d %d as default.\n",
__func__, WAKEUP_GPIO_IDX, val8);
#endif /*CONFIG_WAKEUP_GPIO_INPUT_MODE*/
#endif /* CONFIG_RTW_ONE_PIN_GPIO */
#endif /* CONFIG_GPIO_WAKEUP */
#ifdef CONFIG_WOWLAN
#ifdef CONFIG_LPS_1T1R
#define WOW_LPS_1T1R_FMT ", WOW_LPS_1T1R=%d"
#define WOW_LPS_1T1R_ARG , pwrctrlpriv->wowlan_lps_1t1r
#else
#define WOW_LPS_1T1R_FMT ""
#define WOW_LPS_1T1R_ARG
#endif
pwrctrlpriv->wowlan_power_mgmt = padapter->registrypriv.wow_power_mgnt;
pwrctrlpriv->wowlan_lps_level = padapter->registrypriv.wow_lps_level;
#ifdef CONFIG_LPS_1T1R
pwrctrlpriv->wowlan_lps_1t1r = padapter->registrypriv.wow_lps_1t1r;
#endif
RTW_INFO("%s: WOW_LPS_mode=%d, WOW_LPS_level=%d"WOW_LPS_1T1R_FMT"\n",
__func__, pwrctrlpriv->wowlan_power_mgmt, pwrctrlpriv->wowlan_lps_level
WOW_LPS_1T1R_ARG
);
if (registry_par->wakeup_event & BIT(1))
pwrctrlpriv->default_patterns_en = _TRUE;
else
pwrctrlpriv->default_patterns_en = _FALSE;
rtw_wow_pattern_sw_reset(padapter);
#ifdef CONFIG_PNO_SUPPORT
pwrctrlpriv->pno_inited = _FALSE;
pwrctrlpriv->pnlo_info = NULL;
pwrctrlpriv->pscan_info = NULL;
pwrctrlpriv->pno_ssid_list = NULL;
#endif /* CONFIG_PNO_SUPPORT */
#ifdef CONFIG_WOW_PATTERN_HW_CAM
_rtw_mutex_init(&pwrctrlpriv->wowlan_pattern_cam_mutex);
#endif
pwrctrlpriv->wowlan_aoac_rpt_loc = 0;
#endif /* CONFIG_WOWLAN */
#ifdef CONFIG_LPS_POFF
rtw_hal_set_hwreg(padapter, HW_VAR_LPS_POFF_INIT, 0);
#endif
}
void rtw_free_pwrctrl_priv(PADAPTER adapter)
{
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(adapter);
#if defined(CONFIG_CONCURRENT_MODE)
if (!is_primary_adapter(adapter))
return;
#endif
/* _rtw_memset((unsigned char *)pwrctrlpriv, 0, sizeof(struct pwrctrl_priv)); */
#ifdef CONFIG_RESUME_IN_WORKQUEUE
if (pwrctrlpriv->rtw_workqueue) {
flush_workqueue(pwrctrlpriv->rtw_workqueue);
destroy_workqueue(pwrctrlpriv->rtw_workqueue);
}
#endif
#ifdef CONFIG_LPS_POFF
rtw_hal_set_hwreg(adapter, HW_VAR_LPS_POFF_DEINIT, 0);
#endif
#ifdef CONFIG_LPS_LCLK
_cancel_workitem_sync(&pwrctrlpriv->cpwm_event);
_cancel_workitem_sync(&pwrctrlpriv->dma_event);
#ifdef CONFIG_LPS_RPWM_TIMER
_cancel_workitem_sync(&pwrctrlpriv->rpwmtimeoutwi);
#endif
#endif /* CONFIG_LPS_LCLK */
#ifdef CONFIG_LPS_PG
rsvd_page_cache_free(&pwrctrlpriv->lpspg_info);
#ifdef CONFIG_RTL8822C
rsvd_page_cache_free(&pwrctrlpriv->lpspg_dpk_info);
rsvd_page_cache_free(&pwrctrlpriv->lpspg_iqk_info);
#endif
#endif
#ifdef CONFIG_WOWLAN
#ifdef CONFIG_PNO_SUPPORT
if (pwrctrlpriv->pnlo_info != NULL)
printk("****** pnlo_info memory leak********\n");
if (pwrctrlpriv->pscan_info != NULL)
printk("****** pscan_info memory leak********\n");
if (pwrctrlpriv->pno_ssid_list != NULL)
printk("****** pno_ssid_list memory leak********\n");
#endif
#ifdef CONFIG_WOW_PATTERN_HW_CAM
_rtw_mutex_free(&pwrctrlpriv->wowlan_pattern_cam_mutex);
#endif
#endif /* CONFIG_WOWLAN */
#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
rtw_unregister_early_suspend(pwrctrlpriv);
#endif /* CONFIG_HAS_EARLYSUSPEND || CONFIG_ANDROID_POWER */
_free_pwrlock(&pwrctrlpriv->lock);
_free_pwrlock(&pwrctrlpriv->check_32k_lock);
}
#ifdef CONFIG_RESUME_IN_WORKQUEUE
extern int rtw_resume_process(_adapter *padapter);
static void resume_workitem_callback(struct work_struct *work)
{
struct pwrctrl_priv *pwrpriv = container_of(work, struct pwrctrl_priv, resume_work);
struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
RTW_INFO("%s\n", __FUNCTION__);
rtw_resume_process(adapter);
rtw_resume_unlock_suspend();
}
void rtw_resume_in_workqueue(struct pwrctrl_priv *pwrpriv)
{
/* accquire system's suspend lock preventing from falliing asleep while resume in workqueue */
/* rtw_lock_suspend(); */
rtw_resume_lock_suspend();
#if 1
queue_work(pwrpriv->rtw_workqueue, &pwrpriv->resume_work);
#else
_set_workitem(&pwrpriv->resume_work);
#endif
}
#endif /* CONFIG_RESUME_IN_WORKQUEUE */
#if defined(CONFIG_HAS_EARLYSUSPEND) || defined(CONFIG_ANDROID_POWER)
inline bool rtw_is_earlysuspend_registered(struct pwrctrl_priv *pwrpriv)
{
return (pwrpriv->early_suspend.suspend) ? _TRUE : _FALSE;
}
inline bool rtw_is_do_late_resume(struct pwrctrl_priv *pwrpriv)
{
return (pwrpriv->do_late_resume) ? _TRUE : _FALSE;
}
inline void rtw_set_do_late_resume(struct pwrctrl_priv *pwrpriv, bool enable)
{
pwrpriv->do_late_resume = enable;
}
#endif
#ifdef CONFIG_HAS_EARLYSUSPEND
extern int rtw_resume_process(_adapter *padapter);
static void rtw_early_suspend(struct early_suspend *h)
{
struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
RTW_INFO("%s\n", __FUNCTION__);
rtw_set_do_late_resume(pwrpriv, _FALSE);
}
static void rtw_late_resume(struct early_suspend *h)
{
struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
RTW_INFO("%s\n", __FUNCTION__);
if (pwrpriv->do_late_resume) {
rtw_set_do_late_resume(pwrpriv, _FALSE);
rtw_resume_process(adapter);
}
}
void rtw_register_early_suspend(struct pwrctrl_priv *pwrpriv)
{
RTW_INFO("%s\n", __FUNCTION__);
/* jeff: set the early suspend level before blank screen, so we wll do late resume after scree is lit */
pwrpriv->early_suspend.level = EARLY_SUSPEND_LEVEL_BLANK_SCREEN - 20;
pwrpriv->early_suspend.suspend = rtw_early_suspend;
pwrpriv->early_suspend.resume = rtw_late_resume;
register_early_suspend(&pwrpriv->early_suspend);
}
void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv)
{
RTW_INFO("%s\n", __FUNCTION__);
rtw_set_do_late_resume(pwrpriv, _FALSE);
if (pwrpriv->early_suspend.suspend)
unregister_early_suspend(&pwrpriv->early_suspend);
pwrpriv->early_suspend.suspend = NULL;
pwrpriv->early_suspend.resume = NULL;
}
#endif /* CONFIG_HAS_EARLYSUSPEND */
#ifdef CONFIG_ANDROID_POWER
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
extern int rtw_resume_process(PADAPTER padapter);
#endif
static void rtw_early_suspend(android_early_suspend_t *h)
{
struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
RTW_INFO("%s\n", __FUNCTION__);
rtw_set_do_late_resume(pwrpriv, _FALSE);
}
static void rtw_late_resume(android_early_suspend_t *h)
{
struct pwrctrl_priv *pwrpriv = container_of(h, struct pwrctrl_priv, early_suspend);
struct dvobj_priv *dvobj = pwrctl_to_dvobj(pwrpriv);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
RTW_INFO("%s\n", __FUNCTION__);
if (pwrpriv->do_late_resume) {
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
rtw_set_do_late_resume(pwrpriv, _FALSE);
rtw_resume_process(adapter);
#endif
}
}
void rtw_register_early_suspend(struct pwrctrl_priv *pwrpriv)
{
RTW_INFO("%s\n", __FUNCTION__);
/* jeff: set the early suspend level before blank screen, so we wll do late resume after scree is lit */
pwrpriv->early_suspend.level = ANDROID_EARLY_SUSPEND_LEVEL_BLANK_SCREEN - 20;
pwrpriv->early_suspend.suspend = rtw_early_suspend;
pwrpriv->early_suspend.resume = rtw_late_resume;
android_register_early_suspend(&pwrpriv->early_suspend);
}
void rtw_unregister_early_suspend(struct pwrctrl_priv *pwrpriv)
{
RTW_INFO("%s\n", __FUNCTION__);
rtw_set_do_late_resume(pwrpriv, _FALSE);
if (pwrpriv->early_suspend.suspend)
android_unregister_early_suspend(&pwrpriv->early_suspend);
pwrpriv->early_suspend.suspend = NULL;
pwrpriv->early_suspend.resume = NULL;
}
#endif /* CONFIG_ANDROID_POWER */
u8 rtw_interface_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)
{
u8 bResult = _TRUE;
rtw_hal_intf_ps_func(padapter, efunc_id, val);
return bResult;
}
inline void rtw_set_ips_deny(_adapter *padapter, u32 ms)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ms);
}
/*
* rtw_pwr_wakeup - Wake the NIC up from: 1)IPS. 2)USB autosuspend
* @adapter: pointer to _adapter structure
* @ips_deffer_ms: the ms wiil prevent from falling into IPS after wakeup
* Return _SUCCESS or _FAIL
*/
int _rtw_pwr_wakeup(_adapter *padapter, u32 ips_deffer_ms, const char *caller)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
struct mlme_priv *pmlmepriv;
int ret = _SUCCESS;
systime start = rtw_get_current_time();
/*RTW_INFO(FUNC_ADPT_FMT "===>\n", FUNC_ADPT_ARG(padapter));*/
/* for LPS */
LeaveAllPowerSaveMode(padapter);
/* IPS still bound with primary adapter */
padapter = GET_PRIMARY_ADAPTER(padapter);
pmlmepriv = &padapter->mlmepriv;
if (rtw_time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms);
if (pwrpriv->ps_processing) {
RTW_INFO("%s wait ps_processing...\n", __func__);
while (pwrpriv->ps_processing && rtw_get_passing_time_ms(start) <= 3000)
rtw_msleep_os(10);
if (pwrpriv->ps_processing)
RTW_INFO("%s wait ps_processing timeout\n", __func__);
else
RTW_INFO("%s wait ps_processing done\n", __func__);
}
#ifdef DBG_CONFIG_ERROR_DETECT
if (rtw_hal_sreset_inprogress(padapter)) {
RTW_INFO("%s wait sreset_inprogress...\n", __func__);
while (rtw_hal_sreset_inprogress(padapter) && rtw_get_passing_time_ms(start) <= 4000)
rtw_msleep_os(10);
if (rtw_hal_sreset_inprogress(padapter))
RTW_INFO("%s wait sreset_inprogress timeout\n", __func__);
else
RTW_INFO("%s wait sreset_inprogress done\n", __func__);
}
#endif
if (pwrpriv->bInSuspend
#ifdef CONFIG_AUTOSUSPEND
&& pwrpriv->bInternalAutoSuspend == _FALSE
#endif
) {
RTW_INFO("%s wait bInSuspend...\n", __func__);
while (pwrpriv->bInSuspend
&& ((rtw_get_passing_time_ms(start) <= 3000 && !rtw_is_do_late_resume(pwrpriv))
|| (rtw_get_passing_time_ms(start) <= 500 && rtw_is_do_late_resume(pwrpriv)))
)
rtw_msleep_os(10);
if (pwrpriv->bInSuspend)
RTW_INFO("%s wait bInSuspend timeout\n", __func__);
else
RTW_INFO("%s wait bInSuspend done\n", __func__);
}
/* System suspend is not allowed to wakeup */
if ((_TRUE == pwrpriv->bInSuspend)
#ifdef CONFIG_AUTOSUSPEND
&& (pwrpriv->bInternalAutoSuspend == _FALSE)
#endif
) {
ret = _FAIL;
goto exit;
}
#ifdef CONFIG_AUTOSUSPEND
/* usb autosuspend block??? */
if ((pwrpriv->bInternalAutoSuspend == _TRUE) && (padapter->net_closed == _TRUE)) {
ret = _FAIL;
goto exit;
}
#endif
/* I think this should be check in IPS, LPS, autosuspend functions... */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
if (_TRUE == pwrpriv->bInternalAutoSuspend) {
if (0 == pwrpriv->autopm_cnt) {
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 33))
if (usb_autopm_get_interface(adapter_to_dvobj(padapter)->pusbintf) < 0)
RTW_INFO("can't get autopm:\n");
#elif (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 20))
usb_autopm_disable(adapter_to_dvobj(padapter)->pusbintf);
#else
usb_autoresume_device(adapter_to_dvobj(padapter)->pusbdev, 1);
#endif
pwrpriv->autopm_cnt++;
}
#endif /* #if defined (CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND) */
ret = _SUCCESS;
goto exit;
#if defined(CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND)
}
#endif /* #if defined (CONFIG_BT_COEXIST) && defined (CONFIG_AUTOSUSPEND) */
}
if (rf_off == pwrpriv->rf_pwrstate) {
#ifdef CONFIG_USB_HCI
#ifdef CONFIG_AUTOSUSPEND
if (pwrpriv->brfoffbyhw == _TRUE) {
RTW_INFO("hw still in rf_off state ...........\n");
ret = _FAIL;
goto exit;
} else if (padapter->registrypriv.usbss_enable) {
RTW_INFO("%s call autoresume_enter....\n", __FUNCTION__);
if (_FAIL == autoresume_enter(padapter)) {
RTW_INFO("======> autoresume fail.............\n");
ret = _FAIL;
goto exit;
}
} else
#endif
#endif
{
#ifdef CONFIG_IPS
RTW_INFO("%s call ips_leave....\n", __FUNCTION__);
if (_FAIL == ips_leave(padapter)) {
RTW_INFO("======> ips_leave fail.............\n");
ret = _FAIL;
goto exit;
}
#endif
}
}
/* TODO: the following checking need to be merged... */
if (rtw_is_drv_stopped(padapter)
|| !padapter->bup
|| !rtw_is_hw_init_completed(padapter)
) {
RTW_INFO("%s: bDriverStopped=%s, bup=%d, hw_init_completed=%u\n"
, caller
, rtw_is_drv_stopped(padapter) ? "True" : "False"
, padapter->bup
, rtw_get_hw_init_completed(padapter));
ret = _FALSE;
goto exit;
}
exit:
if (rtw_time_after(rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms), pwrpriv->ips_deny_time))
pwrpriv->ips_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ips_deffer_ms);
/*RTW_INFO(FUNC_ADPT_FMT "<===\n", FUNC_ADPT_ARG(padapter));*/
return ret;
}
int rtw_pm_set_lps(_adapter *padapter, u8 mode)
{
int ret = 0;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
if (mode < PS_MODE_NUM) {
if (pwrctrlpriv->power_mgnt != mode) {
if (PS_MODE_ACTIVE == mode)
LeaveAllPowerSaveMode(padapter);
else
pwrctrlpriv->LpsIdleCount = 2;
pwrctrlpriv->power_mgnt = mode;
pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ? _TRUE : _FALSE;
}
} else
ret = -EINVAL;
return ret;
}
int rtw_pm_set_lps_level(_adapter *padapter, u8 level)
{
int ret = 0;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
if (level < LPS_LEVEL_MAX) {
if (pwrctrlpriv->lps_level != level) {
#ifdef CONFIG_LPS
if (rtw_lps_ctrl_leave_set_level_cmd(padapter, level, RTW_CMDF_WAIT_ACK) != _SUCCESS)
#endif
pwrctrlpriv->lps_level = level;
}
} else
ret = -EINVAL;
return ret;
}
#ifdef CONFIG_LPS_1T1R
int rtw_pm_set_lps_1t1r(_adapter *padapter, u8 en)
{
int ret = 0;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
en = en ? 1 : 0;
if (pwrctrlpriv->lps_1t1r != en) {
if (rtw_lps_ctrl_leave_set_1t1r_cmd(padapter, en, RTW_CMDF_WAIT_ACK) != _SUCCESS)
pwrctrlpriv->lps_1t1r = en;
}
return ret;
}
#endif
inline void rtw_set_lps_deny(_adapter *adapter, u32 ms)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
pwrpriv->lps_deny_time = rtw_get_current_time() + rtw_ms_to_systime(ms);
}
#ifdef CONFIG_WOWLAN
int rtw_pm_set_wow_lps(_adapter *padapter, u8 mode)
{
int ret = 0;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
if (mode < PS_MODE_NUM) {
if (pwrctrlpriv->wowlan_power_mgmt != mode)
pwrctrlpriv->wowlan_power_mgmt = mode;
} else
ret = -EINVAL;
return ret;
}
int rtw_pm_set_wow_lps_level(_adapter *padapter, u8 level)
{
int ret = 0;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
if (level < LPS_LEVEL_MAX)
pwrctrlpriv->wowlan_lps_level = level;
else
ret = -EINVAL;
return ret;
}
#ifdef CONFIG_LPS_1T1R
int rtw_pm_set_wow_lps_1t1r(_adapter *padapter, u8 en)
{
int ret = 0;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
en = en ? 1 : 0;
pwrctrlpriv->wowlan_lps_1t1r = en;
return ret;
}
#endif /* CONFIG_LPS_1T1R */
#endif /* CONFIG_WOWLAN */
int rtw_pm_set_ips(_adapter *padapter, u8 mode)
{
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
if (mode == IPS_NORMAL || mode == IPS_LEVEL_2) {
rtw_ips_mode_req(pwrctrlpriv, mode);
RTW_INFO("%s %s\n", __FUNCTION__, mode == IPS_NORMAL ? "IPS_NORMAL" : "IPS_LEVEL_2");
return 0;
} else if (mode == IPS_NONE) {
rtw_ips_mode_req(pwrctrlpriv, mode);
RTW_INFO("%s %s\n", __FUNCTION__, "IPS_NONE");
if (!rtw_is_surprise_removed(padapter) && (_FAIL == rtw_pwr_wakeup(padapter)))
return -EFAULT;
} else
return -EINVAL;
return 0;
}
/*
* ATTENTION:
* This function will request pwrctrl LOCK!
*/
void rtw_ps_deny(PADAPTER padapter, PS_DENY_REASON reason)
{
struct pwrctrl_priv *pwrpriv;
/* RTW_INFO("+" FUNC_ADPT_FMT ": Request PS deny for %d (0x%08X)\n",
* FUNC_ADPT_ARG(padapter), reason, BIT(reason)); */
pwrpriv = adapter_to_pwrctl(padapter);
_enter_pwrlock(&pwrpriv->lock);
if (pwrpriv->ps_deny & BIT(reason)) {
RTW_INFO(FUNC_ADPT_FMT ": [WARNING] Reason %d had been set before!!\n",
FUNC_ADPT_ARG(padapter), reason);
}
pwrpriv->ps_deny |= BIT(reason);
_exit_pwrlock(&pwrpriv->lock);
/* RTW_INFO("-" FUNC_ADPT_FMT ": Now PS deny for 0x%08X\n",
* FUNC_ADPT_ARG(padapter), pwrpriv->ps_deny); */
}
/*
* ATTENTION:
* This function will request pwrctrl LOCK!
*/
void rtw_ps_deny_cancel(PADAPTER padapter, PS_DENY_REASON reason)
{
struct pwrctrl_priv *pwrpriv;
/* RTW_INFO("+" FUNC_ADPT_FMT ": Cancel PS deny for %d(0x%08X)\n",
* FUNC_ADPT_ARG(padapter), reason, BIT(reason)); */
pwrpriv = adapter_to_pwrctl(padapter);
_enter_pwrlock(&pwrpriv->lock);
if ((pwrpriv->ps_deny & BIT(reason)) == 0) {
RTW_INFO(FUNC_ADPT_FMT ": [ERROR] Reason %d had been canceled before!!\n",
FUNC_ADPT_ARG(padapter), reason);
}
pwrpriv->ps_deny &= ~BIT(reason);
_exit_pwrlock(&pwrpriv->lock);
/* RTW_INFO("-" FUNC_ADPT_FMT ": Now PS deny for 0x%08X\n",
* FUNC_ADPT_ARG(padapter), pwrpriv->ps_deny); */
}
/*
* ATTENTION:
* Before calling this function pwrctrl lock should be occupied already,
* otherwise it may return incorrect value.
*/
u32 rtw_ps_deny_get(PADAPTER padapter)
{
u32 deny;
deny = adapter_to_pwrctl(padapter)->ps_deny;
return deny;
}
static void _rtw_ssmps(_adapter *adapter, struct sta_info *sta)
{
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (MLME_IS_STA(adapter)) {
issue_action_SM_PS_wait_ack(adapter , get_my_bssid(&(pmlmeinfo->network)),
sta->cmn.sm_ps, 3 , 1);
}
else if (MLME_IS_AP(adapter)) {
}
rtw_phydm_ra_registed(adapter, sta);
}
void rtw_ssmps_enter(_adapter *adapter, struct sta_info *sta)
{
if (sta->cmn.sm_ps == SM_PS_STATIC)
return;
RTW_INFO(ADPT_FMT" STA [" MAC_FMT "]\n", ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
sta->cmn.sm_ps = SM_PS_STATIC;
_rtw_ssmps(adapter, sta);
}
void rtw_ssmps_leave(_adapter *adapter, struct sta_info *sta)
{
if (sta->cmn.sm_ps == SM_PS_DISABLE)
return;
RTW_INFO(ADPT_FMT" STA [" MAC_FMT "] \n", ADPT_ARG(adapter), MAC_ARG(sta->cmn.mac_addr));
sta->cmn.sm_ps = SM_PS_DISABLE;
_rtw_ssmps(adapter, sta);
}
================================================
FILE: core/rtw_recv.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_RECV_C_
#include
#include
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
static void rtw_signal_stat_timer_hdl(void *ctx);
enum {
SIGNAL_STAT_CALC_PROFILE_0 = 0,
SIGNAL_STAT_CALC_PROFILE_1,
SIGNAL_STAT_CALC_PROFILE_MAX
};
u8 signal_stat_calc_profile[SIGNAL_STAT_CALC_PROFILE_MAX][2] = {
{4, 1}, /* Profile 0 => pre_stat : curr_stat = 4 : 1 */
{3, 7} /* Profile 1 => pre_stat : curr_stat = 3 : 7 */
};
#ifndef RTW_SIGNAL_STATE_CALC_PROFILE
#define RTW_SIGNAL_STATE_CALC_PROFILE SIGNAL_STAT_CALC_PROFILE_1
#endif
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
u8 rtw_bridge_tunnel_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0xf8 };
u8 rtw_rfc1042_header[] = { 0xaa, 0xaa, 0x03, 0x00, 0x00, 0x00 };
static u8 SNAP_ETH_TYPE_IPX[2] = {0x81, 0x37};
static u8 SNAP_ETH_TYPE_APPLETALK_AARP[2] = {0x80, 0xf3};
#ifdef CONFIG_TDLS
static u8 SNAP_ETH_TYPE_TDLS[2] = {0x89, 0x0d};
#endif
#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
int recv_frame_monitor(_adapter *padapter, union recv_frame *rframe);
#endif
void _rtw_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv)
{
_rtw_memset((u8 *)psta_recvpriv, 0, sizeof(struct sta_recv_priv));
_rtw_spinlock_init(&psta_recvpriv->lock);
/* for(i=0; iblk_strms[i]); */
_rtw_init_queue(&psta_recvpriv->defrag_q);
}
sint _rtw_init_recv_priv(struct recv_priv *precvpriv, _adapter *padapter)
{
sint i;
union recv_frame *precvframe;
sint res = _SUCCESS;
/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
/* _rtw_memset((unsigned char *)precvpriv, 0, sizeof (struct recv_priv)); */
_rtw_spinlock_init(&precvpriv->lock);
#ifdef CONFIG_RECV_THREAD_MODE
_rtw_init_sema(&precvpriv->recv_sema, 0);
#endif
_rtw_init_queue(&precvpriv->free_recv_queue);
_rtw_init_queue(&precvpriv->recv_pending_queue);
_rtw_init_queue(&precvpriv->uc_swdec_pending_queue);
precvpriv->adapter = padapter;
precvpriv->free_recvframe_cnt = NR_RECVFRAME;
precvpriv->sink_udpport = 0;
precvpriv->pre_rtp_rxseq = 0;
precvpriv->cur_rtp_rxseq = 0;
#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
precvpriv->store_law_data_flag = 1;
#else
precvpriv->store_law_data_flag = 0;
#endif
rtw_os_recv_resource_init(precvpriv, padapter);
precvpriv->pallocated_frame_buf = rtw_zvmalloc(NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ);
if (precvpriv->pallocated_frame_buf == NULL) {
res = _FAIL;
goto exit;
}
/* _rtw_memset(precvpriv->pallocated_frame_buf, 0, NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ); */
precvpriv->precv_frame_buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(precvpriv->pallocated_frame_buf), RXFRAME_ALIGN_SZ);
/* precvpriv->precv_frame_buf = precvpriv->pallocated_frame_buf + RXFRAME_ALIGN_SZ - */
/* ((SIZE_PTR) (precvpriv->pallocated_frame_buf) &(RXFRAME_ALIGN_SZ-1)); */
precvframe = (union recv_frame *) precvpriv->precv_frame_buf;
for (i = 0; i < NR_RECVFRAME ; i++) {
_rtw_init_listhead(&(precvframe->u.list));
rtw_list_insert_tail(&(precvframe->u.list), &(precvpriv->free_recv_queue.queue));
res = rtw_os_recv_resource_alloc(padapter, precvframe);
precvframe->u.hdr.len = 0;
precvframe->u.hdr.adapter = padapter;
precvframe++;
}
#ifdef CONFIG_USB_HCI
ATOMIC_SET(&(precvpriv->rx_pending_cnt), 1);
_rtw_init_sema(&precvpriv->allrxreturnevt, 0);
#endif
res = rtw_hal_init_recv_priv(padapter);
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
rtw_init_timer(&precvpriv->signal_stat_timer, padapter, rtw_signal_stat_timer_hdl, padapter);
precvpriv->signal_stat_sampling_interval = 2000; /* ms */
/* precvpriv->signal_stat_converging_constant = 5000; */ /* ms */
rtw_set_signal_stat_timer(precvpriv);
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
exit:
return res;
}
void rtw_mfree_recv_priv_lock(struct recv_priv *precvpriv);
void rtw_mfree_recv_priv_lock(struct recv_priv *precvpriv)
{
_rtw_spinlock_free(&precvpriv->lock);
#ifdef CONFIG_RECV_THREAD_MODE
_rtw_free_sema(&precvpriv->recv_sema);
#endif
_rtw_spinlock_free(&precvpriv->free_recv_queue.lock);
_rtw_spinlock_free(&precvpriv->recv_pending_queue.lock);
_rtw_spinlock_free(&precvpriv->free_recv_buf_queue.lock);
#ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX
_rtw_spinlock_free(&precvpriv->recv_buf_pending_queue.lock);
#endif /* CONFIG_USE_USB_BUFFER_ALLOC_RX */
}
void _rtw_free_recv_priv(struct recv_priv *precvpriv)
{
_adapter *padapter = precvpriv->adapter;
rtw_free_uc_swdec_pending_queue(padapter);
rtw_mfree_recv_priv_lock(precvpriv);
rtw_os_recv_resource_free(precvpriv);
if (precvpriv->pallocated_frame_buf)
rtw_vmfree(precvpriv->pallocated_frame_buf, NR_RECVFRAME * sizeof(union recv_frame) + RXFRAME_ALIGN_SZ);
rtw_hal_free_recv_priv(padapter);
}
bool rtw_rframe_del_wfd_ie(union recv_frame *rframe, u8 ies_offset)
{
#define DBG_RFRAME_DEL_WFD_IE 0
u8 *ies = rframe->u.hdr.rx_data + sizeof(struct rtw_ieee80211_hdr_3addr) + ies_offset;
uint ies_len_ori = rframe->u.hdr.len - (ies - rframe->u.hdr.rx_data);
uint ies_len;
ies_len = rtw_del_wfd_ie(ies, ies_len_ori, DBG_RFRAME_DEL_WFD_IE ? __func__ : NULL);
rframe->u.hdr.len -= ies_len_ori - ies_len;
return ies_len_ori != ies_len;
}
union recv_frame *_rtw_alloc_recvframe(_queue *pfree_recv_queue)
{
union recv_frame *precvframe;
_list *plist, *phead;
_adapter *padapter;
struct recv_priv *precvpriv;
if (_rtw_queue_empty(pfree_recv_queue) == _TRUE)
precvframe = NULL;
else {
phead = get_list_head(pfree_recv_queue);
plist = get_next(phead);
precvframe = LIST_CONTAINOR(plist, union recv_frame, u);
rtw_list_delete(&precvframe->u.hdr.list);
padapter = precvframe->u.hdr.adapter;
if (padapter != NULL) {
precvpriv = &padapter->recvpriv;
if (pfree_recv_queue == &precvpriv->free_recv_queue)
precvpriv->free_recvframe_cnt--;
}
}
return precvframe;
}
union recv_frame *rtw_alloc_recvframe(_queue *pfree_recv_queue)
{
_irqL irqL;
union recv_frame *precvframe;
_enter_critical_bh(&pfree_recv_queue->lock, &irqL);
precvframe = _rtw_alloc_recvframe(pfree_recv_queue);
_exit_critical_bh(&pfree_recv_queue->lock, &irqL);
return precvframe;
}
void rtw_init_recvframe(union recv_frame *precvframe, struct recv_priv *precvpriv)
{
/* Perry: This can be removed */
_rtw_init_listhead(&precvframe->u.hdr.list);
precvframe->u.hdr.len = 0;
}
int rtw_free_recvframe(union recv_frame *precvframe, _queue *pfree_recv_queue)
{
_irqL irqL;
_adapter *padapter = precvframe->u.hdr.adapter;
struct recv_priv *precvpriv = &padapter->recvpriv;
#ifdef CONFIG_CONCURRENT_MODE
padapter = GET_PRIMARY_ADAPTER(padapter);
precvpriv = &padapter->recvpriv;
pfree_recv_queue = &precvpriv->free_recv_queue;
precvframe->u.hdr.adapter = padapter;
#endif
rtw_os_free_recvframe(precvframe);
_enter_critical_bh(&pfree_recv_queue->lock, &irqL);
rtw_list_delete(&(precvframe->u.hdr.list));
precvframe->u.hdr.len = 0;
rtw_list_insert_tail(&(precvframe->u.hdr.list), get_list_head(pfree_recv_queue));
if (padapter != NULL) {
if (pfree_recv_queue == &precvpriv->free_recv_queue)
precvpriv->free_recvframe_cnt++;
}
_exit_critical_bh(&pfree_recv_queue->lock, &irqL);
return _SUCCESS;
}
sint _rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)
{
_adapter *padapter = precvframe->u.hdr.adapter;
struct recv_priv *precvpriv = &padapter->recvpriv;
/* _rtw_init_listhead(&(precvframe->u.hdr.list)); */
rtw_list_delete(&(precvframe->u.hdr.list));
rtw_list_insert_tail(&(precvframe->u.hdr.list), get_list_head(queue));
if (padapter != NULL) {
if (queue == &precvpriv->free_recv_queue)
precvpriv->free_recvframe_cnt++;
}
return _SUCCESS;
}
sint rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)
{
sint ret;
_irqL irqL;
/* _spinlock(&pfree_recv_queue->lock); */
_enter_critical_bh(&queue->lock, &irqL);
ret = _rtw_enqueue_recvframe(precvframe, queue);
/* _rtw_spinunlock(&pfree_recv_queue->lock); */
_exit_critical_bh(&queue->lock, &irqL);
return ret;
}
/*
sint rtw_enqueue_recvframe(union recv_frame *precvframe, _queue *queue)
{
return rtw_free_recvframe(precvframe, queue);
}
*/
/*
caller : defrag ; recvframe_chk_defrag in recv_thread (passive)
pframequeue: defrag_queue : will be accessed in recv_thread (passive)
using spinlock to protect
*/
void rtw_free_recvframe_queue(_queue *pframequeue, _queue *pfree_recv_queue)
{
union recv_frame *precvframe;
_list *plist, *phead;
_rtw_spinlock(&pframequeue->lock);
phead = get_list_head(pframequeue);
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
precvframe = LIST_CONTAINOR(plist, union recv_frame, u);
plist = get_next(plist);
/* rtw_list_delete(&precvframe->u.hdr.list); */ /* will do this in rtw_free_recvframe() */
rtw_free_recvframe(precvframe, pfree_recv_queue);
}
_rtw_spinunlock(&pframequeue->lock);
}
u32 rtw_free_uc_swdec_pending_queue(_adapter *adapter)
{
u32 cnt = 0;
union recv_frame *pending_frame;
while ((pending_frame = rtw_alloc_recvframe(&adapter->recvpriv.uc_swdec_pending_queue))) {
rtw_free_recvframe(pending_frame, &adapter->recvpriv.free_recv_queue);
cnt++;
}
if (cnt)
RTW_INFO(FUNC_ADPT_FMT" dequeue %d\n", FUNC_ADPT_ARG(adapter), cnt);
return cnt;
}
sint rtw_enqueue_recvbuf_to_head(struct recv_buf *precvbuf, _queue *queue)
{
_irqL irqL;
_enter_critical_bh(&queue->lock, &irqL);
rtw_list_delete(&precvbuf->list);
rtw_list_insert_head(&precvbuf->list, get_list_head(queue));
_exit_critical_bh(&queue->lock, &irqL);
return _SUCCESS;
}
sint rtw_enqueue_recvbuf(struct recv_buf *precvbuf, _queue *queue)
{
_irqL irqL;
#ifdef CONFIG_SDIO_HCI
_enter_critical_bh(&queue->lock, &irqL);
#else
_enter_critical_ex(&queue->lock, &irqL);
#endif/*#ifdef CONFIG_SDIO_HCI*/
rtw_list_delete(&precvbuf->list);
rtw_list_insert_tail(&precvbuf->list, get_list_head(queue));
#ifdef CONFIG_SDIO_HCI
_exit_critical_bh(&queue->lock, &irqL);
#else
_exit_critical_ex(&queue->lock, &irqL);
#endif/*#ifdef CONFIG_SDIO_HCI*/
return _SUCCESS;
}
struct recv_buf *rtw_dequeue_recvbuf(_queue *queue)
{
_irqL irqL;
struct recv_buf *precvbuf;
_list *plist, *phead;
#ifdef CONFIG_SDIO_HCI
_enter_critical_bh(&queue->lock, &irqL);
#else
_enter_critical_ex(&queue->lock, &irqL);
#endif/*#ifdef CONFIG_SDIO_HCI*/
if (_rtw_queue_empty(queue) == _TRUE)
precvbuf = NULL;
else {
phead = get_list_head(queue);
plist = get_next(phead);
precvbuf = LIST_CONTAINOR(plist, struct recv_buf, list);
rtw_list_delete(&precvbuf->list);
}
#ifdef CONFIG_SDIO_HCI
_exit_critical_bh(&queue->lock, &irqL);
#else
_exit_critical_ex(&queue->lock, &irqL);
#endif/*#ifdef CONFIG_SDIO_HCI*/
return precvbuf;
}
sint recvframe_chkmic(_adapter *adapter, union recv_frame *precvframe);
sint recvframe_chkmic(_adapter *adapter, union recv_frame *precvframe)
{
sint i, res = _SUCCESS;
u32 datalen;
u8 miccode[8];
u8 bmic_err = _FALSE, brpt_micerror = _TRUE;
u8 *pframe, *payload, *pframemic;
u8 *mickey;
/* u8 *iv,rxdata_key_idx=0; */
struct sta_info *stainfo;
struct rx_pkt_attrib *prxattrib = &precvframe->u.hdr.attrib;
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
stainfo = rtw_get_stainfo(&adapter->stapriv , &prxattrib->ta[0]);
if (prxattrib->encrypt == _TKIP_) {
/* calculate mic code */
if (stainfo != NULL) {
if (IS_MCAST(prxattrib->ra)) {
/* mickey=&psecuritypriv->dot118021XGrprxmickey.skey[0]; */
/* iv = precvframe->u.hdr.rx_data+prxattrib->hdrlen; */
/* rxdata_key_idx =( ((iv[3])>>6)&0x3) ; */
mickey = &psecuritypriv->dot118021XGrprxmickey[prxattrib->key_index].skey[0];
/* RTW_INFO("\n recvframe_chkmic: bcmc key psecuritypriv->dot118021XGrpKeyid(%d),pmlmeinfo->key_index(%d) ,recv key_id(%d)\n", */
/* psecuritypriv->dot118021XGrpKeyid,pmlmeinfo->key_index,rxdata_key_idx); */
if (psecuritypriv->binstallGrpkey == _FALSE) {
res = _FAIL;
RTW_INFO("\n recvframe_chkmic:didn't install group key!!!!!!!!!!\n");
goto exit;
}
} else {
mickey = &stainfo->dot11tkiprxmickey.skey[0];
}
datalen = precvframe->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len - prxattrib->icv_len - 8; /* icv_len included the mic code */
pframe = precvframe->u.hdr.rx_data;
payload = pframe + prxattrib->hdrlen + prxattrib->iv_len;
/* rtw_seccalctkipmic(&stainfo->dot11tkiprxmickey.skey[0],pframe,payload, datalen ,&miccode[0],(unsigned char)prxattrib->priority); */ /* care the length of the data */
rtw_seccalctkipmic(mickey, pframe, payload, datalen , &miccode[0], (unsigned char)prxattrib->priority); /* care the length of the data */
pframemic = payload + datalen;
bmic_err = _FALSE;
for (i = 0; i < 8; i++) {
if (miccode[i] != *(pframemic + i)) {
bmic_err = _TRUE;
}
}
if (bmic_err == _TRUE) {
/* double check key_index for some timing issue , */
/* cannot compare with psecuritypriv->dot118021XGrpKeyid also cause timing issue */
if ((IS_MCAST(prxattrib->ra) == _TRUE) && (prxattrib->key_index != pmlmeinfo->key_index))
brpt_micerror = _FALSE;
if ((prxattrib->bdecrypted == _TRUE) && (brpt_micerror == _TRUE)) {
rtw_handle_tkip_mic_err(adapter, stainfo, (u8)IS_MCAST(prxattrib->ra));
RTW_INFO(" mic error :prxattrib->bdecrypted=%d\n", prxattrib->bdecrypted);
} else {
RTW_INFO(" mic error :prxattrib->bdecrypted=%d\n", prxattrib->bdecrypted);
}
res = _FAIL;
} else {
/* mic checked ok */
if ((psecuritypriv->bcheck_grpkey == _FALSE) && (IS_MCAST(prxattrib->ra) == _TRUE)) {
psecuritypriv->bcheck_grpkey = _TRUE;
}
}
}
recvframe_pull_tail(precvframe, 8);
}
exit:
return res;
}
/*#define DBG_RX_SW_DECRYPTOR*/
/* decrypt and set the ivlen,icvlen of the recv_frame */
union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame);
union recv_frame *decryptor(_adapter *padapter, union recv_frame *precv_frame)
{
struct rx_pkt_attrib *prxattrib = &precv_frame->u.hdr.attrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
union recv_frame *return_packet = precv_frame;
u32 res = _SUCCESS;
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt);
if (prxattrib->encrypt > 0) {
u8 *iv = precv_frame->u.hdr.rx_data + prxattrib->hdrlen;
prxattrib->key_index = (((iv[3]) >> 6) & 0x3) ;
if (prxattrib->key_index > WEP_KEYS) {
RTW_INFO("prxattrib->key_index(%d) > WEP_KEYS\n", prxattrib->key_index);
switch (prxattrib->encrypt) {
case _WEP40_:
case _WEP104_:
prxattrib->key_index = psecuritypriv->dot11PrivacyKeyIndex;
break;
case _TKIP_:
case _AES_:
default:
prxattrib->key_index = psecuritypriv->dot118021XGrpKeyid;
break;
}
}
}
if (prxattrib->encrypt && !prxattrib->bdecrypted) {
if (GetFrameType(get_recvframe_data(precv_frame)) == WIFI_DATA
#ifdef CONFIG_CONCURRENT_MODE
&& !IS_MCAST(prxattrib->ra) /* bc/mc packets may use sw decryption for concurrent mode */
#endif
)
psecuritypriv->hw_decrypted = _FALSE;
#ifdef DBG_RX_SW_DECRYPTOR
RTW_INFO(ADPT_FMT" - sec_type:%s DO SW decryption\n",
ADPT_ARG(padapter), security_type_str(prxattrib->encrypt));
#endif
#ifdef DBG_RX_DECRYPTOR
RTW_INFO("[%s] %d:prxstat->bdecrypted:%d, prxattrib->encrypt:%d, Setting psecuritypriv->hw_decrypted = %d\n",
__FUNCTION__,
__LINE__,
prxattrib->bdecrypted,
prxattrib->encrypt,
psecuritypriv->hw_decrypted);
#endif
switch (prxattrib->encrypt) {
case _WEP40_:
case _WEP104_:
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_wep);
rtw_wep_decrypt(padapter, (u8 *)precv_frame);
break;
case _TKIP_:
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_tkip);
res = rtw_tkip_decrypt(padapter, (u8 *)precv_frame);
break;
case _AES_:
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_aes);
res = rtw_aes_decrypt(padapter, (u8 *)precv_frame);
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_wapi);
rtw_sms4_decrypt(padapter, (u8 *)precv_frame);
break;
#endif
default:
break;
}
} else if (prxattrib->bdecrypted == 1
&& prxattrib->encrypt > 0
&& (psecuritypriv->busetkipkey == 1 || prxattrib->encrypt != _TKIP_)
) {
#if 0
if ((prxstat->icv == 1) && (prxattrib->encrypt != _AES_)) {
psecuritypriv->hw_decrypted = _FALSE;
rtw_free_recvframe(precv_frame, &padapter->recvpriv.free_recv_queue);
return_packet = NULL;
} else
#endif
{
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_hw);
psecuritypriv->hw_decrypted = _TRUE;
#ifdef DBG_RX_DECRYPTOR
RTW_INFO("[%s] %d:prxstat->bdecrypted:%d, prxattrib->encrypt:%d, Setting psecuritypriv->hw_decrypted = %d\n",
__FUNCTION__,
__LINE__,
prxattrib->bdecrypted,
prxattrib->encrypt,
psecuritypriv->hw_decrypted);
#endif
}
} else {
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_unknown);
#ifdef DBG_RX_DECRYPTOR
RTW_INFO("[%s] %d:prxstat->bdecrypted:%d, prxattrib->encrypt:%d, Setting psecuritypriv->hw_decrypted = %d\n",
__FUNCTION__,
__LINE__,
prxattrib->bdecrypted,
prxattrib->encrypt,
psecuritypriv->hw_decrypted);
#endif
}
#ifdef CONFIG_RTW_MESH
if (res != _FAIL
&& !prxattrib->amsdu
&& prxattrib->mesh_ctrl_present)
res = rtw_mesh_rx_validate_mctrl_non_amsdu(padapter, precv_frame);
#endif
if (res == _FAIL) {
rtw_free_recvframe(return_packet, &padapter->recvpriv.free_recv_queue);
return_packet = NULL;
} else
prxattrib->bdecrypted = _TRUE;
/* recvframe_chkmic(adapter, precv_frame); */ /* move to recvframme_defrag function */
return return_packet;
}
/* ###set the security information in the recv_frame */
union recv_frame *portctrl(_adapter *adapter, union recv_frame *precv_frame);
union recv_frame *portctrl(_adapter *adapter, union recv_frame *precv_frame)
{
u8 *psta_addr = NULL;
u8 *ptr;
uint auth_alg;
struct recv_frame_hdr *pfhdr;
struct sta_info *psta;
struct sta_priv *pstapriv ;
union recv_frame *prtnframe;
u16 ether_type = 0;
u16 eapol_type = 0x888e;/* for Funia BD's WPA issue */
struct rx_pkt_attrib *pattrib;
pstapriv = &adapter->stapriv;
auth_alg = adapter->securitypriv.dot11AuthAlgrthm;
ptr = get_recvframe_data(precv_frame);
pfhdr = &precv_frame->u.hdr;
pattrib = &pfhdr->attrib;
psta_addr = pattrib->ta;
prtnframe = NULL;
psta = rtw_get_stainfo(pstapriv, psta_addr);
if (auth_alg == dot11AuthAlgrthm_8021X) {
if ((psta != NULL) && (psta->ieee8021x_blocked)) {
/* blocked */
/* only accept EAPOL frame */
prtnframe = precv_frame;
/* get ether_type */
ptr = ptr + pfhdr->attrib.hdrlen + pfhdr->attrib.iv_len + LLC_HEADER_SIZE;
_rtw_memcpy(ðer_type, ptr, 2);
ether_type = ntohs((unsigned short)ether_type);
if (ether_type == eapol_type)
prtnframe = precv_frame;
else {
/* free this frame */
rtw_free_recvframe(precv_frame, &adapter->recvpriv.free_recv_queue);
prtnframe = NULL;
}
} else {
/* allowed */
/* check decryption status, and decrypt the frame if needed */
prtnframe = precv_frame;
/* check is the EAPOL frame or not (Rekey) */
/* if(ether_type == eapol_type){ */
/* check Rekey */
/* prtnframe=precv_frame; */
/* } */
}
} else
prtnframe = precv_frame;
return prtnframe;
}
/* VALID_PN_CHK
* Return true when PN is legal, otherwise false.
* Legal PN:
* 1. If old PN is 0, any PN is legal
* 2. PN > old PN
*/
#define PN_LESS_CHK(a, b) (((a-b) & 0x800000000000) != 0)
#define VALID_PN_CHK(new, old) (((old) == 0) || PN_LESS_CHK(old, new))
#define CCMPH_2_KEYID(ch) (((ch) & 0x00000000c0000000) >> 30)
sint recv_ucast_pn_decache(union recv_frame *precv_frame);
sint recv_ucast_pn_decache(union recv_frame *precv_frame)
{
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_info *sta = precv_frame->u.hdr.psta;
struct stainfo_rxcache *prxcache = &sta->sta_recvpriv.rxcache;
u8 *pdata = precv_frame->u.hdr.rx_data;
sint tid = precv_frame->u.hdr.attrib.priority;
u64 tmp_iv_hdr = 0;
u64 curr_pn = 0, pkt_pn = 0;
if (tid > 15)
return _FAIL;
if (pattrib->encrypt == _AES_) {
tmp_iv_hdr = le64_to_cpu(*(u64*)(pdata + pattrib->hdrlen));
pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
tmp_iv_hdr = le64_to_cpu(*(u64*)prxcache->iv[tid]);
curr_pn = CCMPH_2_PN(tmp_iv_hdr);
if (!VALID_PN_CHK(pkt_pn, curr_pn)) {
/* return _FAIL; */
} else {
prxcache->last_tid = tid;
_rtw_memcpy(prxcache->iv[tid],
(pdata + pattrib->hdrlen),
sizeof(prxcache->iv[tid]));
}
}
return _SUCCESS;
}
sint recv_bcast_pn_decache(union recv_frame *precv_frame);
sint recv_bcast_pn_decache(union recv_frame *precv_frame)
{
_adapter *padapter = precv_frame->u.hdr.adapter;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
u8 *pdata = precv_frame->u.hdr.rx_data;
u64 tmp_iv_hdr = 0;
u64 curr_pn = 0, pkt_pn = 0;
u8 key_id;
if ((pattrib->encrypt == _AES_) &&
(check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {
tmp_iv_hdr = le64_to_cpu(*(u64*)(pdata + pattrib->hdrlen));
key_id = CCMPH_2_KEYID(tmp_iv_hdr);
pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
curr_pn = le64_to_cpu(*(u64*)psecuritypriv->iv_seq[key_id]);
curr_pn &= 0x0000ffffffffffff;
if (!VALID_PN_CHK(pkt_pn, curr_pn))
return _FAIL;
*(u64*)psecuritypriv->iv_seq[key_id] = cpu_to_le64(pkt_pn);
}
return _SUCCESS;
}
sint recv_decache(union recv_frame *precv_frame)
{
struct sta_info *psta = precv_frame->u.hdr.psta;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
_adapter *adapter = psta->padapter;
sint tid = pattrib->priority;
u16 seq_ctrl = ((precv_frame->u.hdr.attrib.seq_num & 0xffff) << 4) |
(precv_frame->u.hdr.attrib.frag_num & 0xf);
u16 *prxseq;
if (tid > 15)
return _FAIL;
if (pattrib->qos) {
if (IS_MCAST(pattrib->ra))
prxseq = &psta->sta_recvpriv.bmc_tid_rxseq[tid];
else
prxseq = &psta->sta_recvpriv.rxcache.tid_rxseq[tid];
} else {
if (IS_MCAST(pattrib->ra)) {
prxseq = &psta->sta_recvpriv.nonqos_bmc_rxseq;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" nonqos bmc seq_num:%d\n"
, FUNC_ADPT_ARG(adapter), pattrib->seq_num);
#endif
} else {
prxseq = &psta->sta_recvpriv.nonqos_rxseq;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" nonqos seq_num:%d\n"
, FUNC_ADPT_ARG(adapter), pattrib->seq_num);
#endif
}
}
if (seq_ctrl == *prxseq) {
/* for non-AMPDU case */
psta->sta_stats.duplicate_cnt++;
if (psta->sta_stats.duplicate_cnt % 100 == 0)
RTW_INFO("%s: tid=%u seq=%d frag=%d\n", __func__
, tid, precv_frame->u.hdr.attrib.seq_num
, precv_frame->u.hdr.attrib.frag_num);
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_decache _FAIL for sta="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
#endif
return _FAIL;
}
*prxseq = seq_ctrl;
return _SUCCESS;
}
void process_pwrbit_data(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *psta)
{
#ifdef CONFIG_AP_MODE
unsigned char pwrbit;
u8 *ptr = precv_frame->u.hdr.rx_data;
pwrbit = GetPwrMgt(ptr);
if (pwrbit) {
if (!(psta->state & WIFI_SLEEP_STATE)) {
/* psta->state |= WIFI_SLEEP_STATE; */
/* rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, BIT(psta->cmn.aid)); */
stop_sta_xmit(padapter, psta);
/* RTW_INFO_DUMP("to sleep, sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len); */
}
} else {
if (psta->state & WIFI_SLEEP_STATE) {
/* psta->state ^= WIFI_SLEEP_STATE; */
/* rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, BIT(psta->cmn.aid)); */
wakeup_sta_to_xmit(padapter, psta);
/* RTW_INFO_DUMP("to wakeup, sta_dz_bitmap=", pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len); */
}
}
#endif
}
void process_wmmps_data(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *psta)
{
#ifdef CONFIG_AP_MODE
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
#ifdef CONFIG_TDLS
if (!(psta->tdls_sta_state & TDLS_LINKED_STATE)) {
#endif /* CONFIG_TDLS */
if (!psta->qos_option)
return;
if (!(psta->qos_info & 0xf))
return;
#ifdef CONFIG_TDLS
}
#endif /* CONFIG_TDLS */
if (psta->state & WIFI_SLEEP_STATE) {
u8 wmmps_ac = 0;
switch (pattrib->priority) {
case 1:
case 2:
wmmps_ac = psta->uapsd_bk & BIT(1);
break;
case 4:
case 5:
wmmps_ac = psta->uapsd_vi & BIT(1);
break;
case 6:
case 7:
wmmps_ac = psta->uapsd_vo & BIT(1);
break;
case 0:
case 3:
default:
wmmps_ac = psta->uapsd_be & BIT(1);
break;
}
if (wmmps_ac) {
if (psta->sleepq_ac_len > 0) {
/* process received triggered frame */
xmit_delivery_enabled_frames(padapter, psta);
} else {
/* issue one qos null frame with More data bit = 0 and the EOSP bit set (=1) */
issue_qos_nulldata(padapter, psta->cmn.mac_addr, (u16)pattrib->priority, 0, 0, 0);
}
}
}
#endif
}
#ifdef CONFIG_TDLS
sint OnTDLS(_adapter *adapter, union recv_frame *precv_frame)
{
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
sint ret = _SUCCESS;
u8 *paction = get_recvframe_data(precv_frame);
u8 category_field = 1;
#ifdef CONFIG_WFD
u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a };
#endif /* CONFIG_WFD */
struct tdls_info *ptdlsinfo = &(adapter->tdlsinfo);
u8 *ptr = precv_frame->u.hdr.rx_data;
struct sta_priv *pstapriv = &(adapter->stapriv);
struct sta_info *ptdls_sta = NULL;
/* point to action field */
paction += pattrib->hdrlen
+ pattrib->iv_len
+ SNAP_SIZE
+ ETH_TYPE_LEN
+ PAYLOAD_TYPE_LEN
+ category_field;
RTW_INFO("[TDLS] Recv %s from "MAC_FMT" with SeqNum = %d\n", rtw_tdls_action_txt(*paction), MAC_ARG(pattrib->src), GetSequence(get_recvframe_data(precv_frame)));
if (hal_chk_wl_func(adapter, WL_FUNC_TDLS) == _FALSE) {
RTW_INFO("Ignore tdls frame since hal doesn't support tdls\n");
ret = _FAIL;
return ret;
}
if (rtw_is_tdls_enabled(adapter) == _FALSE) {
RTW_INFO("recv tdls frame, "
"but tdls haven't enabled\n");
ret = _FAIL;
return ret;
}
ptdls_sta = rtw_get_stainfo(pstapriv, get_sa(ptr));
if (ptdls_sta == NULL) {
switch (*paction) {
case TDLS_SETUP_REQUEST:
case TDLS_DISCOVERY_REQUEST:
break;
default:
RTW_INFO("[TDLS] %s - Direct Link Peer = "MAC_FMT" not found for action = %d\n", __func__, MAC_ARG(get_sa(ptr)), *paction);
ret = _FAIL;
goto exit;
}
}
switch (*paction) {
case TDLS_SETUP_REQUEST:
ret = On_TDLS_Setup_Req(adapter, precv_frame, ptdls_sta);
break;
case TDLS_SETUP_RESPONSE:
ret = On_TDLS_Setup_Rsp(adapter, precv_frame, ptdls_sta);
break;
case TDLS_SETUP_CONFIRM:
ret = On_TDLS_Setup_Cfm(adapter, precv_frame, ptdls_sta);
break;
case TDLS_TEARDOWN:
ret = On_TDLS_Teardown(adapter, precv_frame, ptdls_sta);
break;
case TDLS_DISCOVERY_REQUEST:
ret = On_TDLS_Dis_Req(adapter, precv_frame);
break;
case TDLS_PEER_TRAFFIC_INDICATION:
ret = On_TDLS_Peer_Traffic_Indication(adapter, precv_frame, ptdls_sta);
break;
case TDLS_PEER_TRAFFIC_RESPONSE:
ret = On_TDLS_Peer_Traffic_Rsp(adapter, precv_frame, ptdls_sta);
break;
#ifdef CONFIG_TDLS_CH_SW
case TDLS_CHANNEL_SWITCH_REQUEST:
ret = On_TDLS_Ch_Switch_Req(adapter, precv_frame, ptdls_sta);
break;
case TDLS_CHANNEL_SWITCH_RESPONSE:
ret = On_TDLS_Ch_Switch_Rsp(adapter, precv_frame, ptdls_sta);
break;
#endif
#ifdef CONFIG_WFD
/* First byte of WFA OUI */
case 0x50:
if (_rtw_memcmp(WFA_OUI, paction, 3)) {
/* Probe request frame */
if (*(paction + 3) == 0x04) {
/* WFDTDLS: for sigma test, do not setup direct link automatically */
ptdlsinfo->dev_discovered = _TRUE;
RTW_INFO("recv tunneled probe request frame\n");
issue_tunneled_probe_rsp(adapter, precv_frame);
}
/* Probe response frame */
if (*(paction + 3) == 0x05) {
/* WFDTDLS: for sigma test, do not setup direct link automatically */
ptdlsinfo->dev_discovered = _TRUE;
RTW_INFO("recv tunneled probe response frame\n");
}
}
break;
#endif /* CONFIG_WFD */
default:
RTW_INFO("receive TDLS frame %d but not support\n", *paction);
ret = _FAIL;
break;
}
exit:
return ret;
}
#endif /* CONFIG_TDLS */
void count_rx_stats(_adapter *padapter, union recv_frame *prframe, struct sta_info *sta)
{
int sz;
struct sta_info *psta = NULL;
struct stainfo_stats *pstats = NULL;
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
struct recv_priv *precvpriv = &padapter->recvpriv;
sz = get_recvframe_len(prframe);
precvpriv->rx_bytes += sz;
padapter->mlmepriv.LinkDetectInfo.NumRxOkInPeriod++;
if ((!MacAddr_isBcst(pattrib->dst)) && (!IS_MCAST(pattrib->dst)))
padapter->mlmepriv.LinkDetectInfo.NumRxUnicastOkInPeriod++;
if (sta)
psta = sta;
else
psta = prframe->u.hdr.psta;
if (psta) {
u8 is_ra_bmc = IS_MCAST(pattrib->ra);
pstats = &psta->sta_stats;
pstats->last_rx_time = rtw_get_current_time();
pstats->rx_data_pkts++;
pstats->rx_bytes += sz;
if (is_broadcast_mac_addr(pattrib->ra)) {
pstats->rx_data_bc_pkts++;
pstats->rx_bc_bytes += sz;
} else if (is_ra_bmc) {
pstats->rx_data_mc_pkts++;
pstats->rx_mc_bytes += sz;
}
if (!is_ra_bmc) {
pstats->rxratecnt[pattrib->data_rate]++;
/*record rx packets for every tid*/
pstats->rx_data_qos_pkts[pattrib->priority]++;
}
#ifdef CONFIG_DYNAMIC_SOML
rtw_dyn_soml_byte_update(padapter, pattrib->data_rate, sz);
#endif
#if defined(CONFIG_CHECK_LEAVE_LPS) && defined(CONFIG_LPS_CHK_BY_TP)
if (adapter_to_pwrctl(padapter)->lps_chk_by_tp)
traffic_check_for_leave_lps_by_tp(padapter, _FALSE, psta);
#endif /* CONFIG_LPS */
}
#ifdef CONFIG_CHECK_LEAVE_LPS
#ifdef CONFIG_LPS_CHK_BY_TP
if (!adapter_to_pwrctl(padapter)->lps_chk_by_tp)
#endif
traffic_check_for_leave_lps(padapter, _FALSE, 0);
#endif /* CONFIG_CHECK_LEAVE_LPS */
}
sint sta2sta_data_frame(
_adapter *adapter,
union recv_frame *precv_frame,
struct sta_info **psta
)
{
u8 *ptr = precv_frame->u.hdr.rx_data;
sint ret = _SUCCESS;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_priv *pstapriv = &adapter->stapriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
u8 *mybssid = get_bssid(pmlmepriv);
u8 *myhwaddr = adapter_mac_addr(adapter);
u8 *sta_addr = pattrib->ta;
sint bmcast = IS_MCAST(pattrib->dst);
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &adapter->tdlsinfo;
#ifdef CONFIG_TDLS_CH_SW
struct tdls_ch_switch *pchsw_info = &ptdlsinfo->chsw_info;
#endif
struct sta_info *ptdls_sta = NULL;
u8 *psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
/* frame body located after [+2]: ether-type, [+1]: payload type */
u8 *pframe_body = psnap_type + 2 + 1;
#endif
/* RTW_INFO("[%s] %d, seqnum:%d\n", __FUNCTION__, __LINE__, pattrib->seq_num); */
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
/* filter packets that SA is myself or multicast or broadcast */
if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)) {
ret = _FAIL;
goto exit;
}
if ((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN)) && (!bmcast)) {
ret = _FAIL;
goto exit;
}
if (_rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
_rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
(!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
ret = _FAIL;
goto exit;
}
} else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
#ifdef CONFIG_TDLS
/* direct link data transfer */
if (ptdlsinfo->link_established == _TRUE) {
*psta = ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->ta);
if (ptdls_sta == NULL) {
ret = _FAIL;
goto exit;
} else if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
/* filter packets that SA is myself or multicast or broadcast */
if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)) {
ret = _FAIL;
goto exit;
}
/* da should be for me */
if ((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN)) && (!bmcast)) {
ret = _FAIL;
goto exit;
}
/* check BSSID */
if (_rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
_rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
(!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
ret = _FAIL;
goto exit;
}
#ifdef CONFIG_TDLS_CH_SW
if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) {
if (adapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(adapter)) {
pchsw_info->ch_sw_state |= TDLS_PEER_AT_OFF_STATE;
if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
_cancel_timer_ex(&ptdls_sta->ch_sw_timer);
/* On_TDLS_Peer_Traffic_Rsp(adapter, precv_frame); */
}
}
#endif
/* process UAPSD tdls sta */
process_pwrbit_data(adapter, precv_frame, ptdls_sta);
/* if NULL-frame, check pwrbit */
if ((get_frame_sub_type(ptr) & WIFI_DATA_NULL) == WIFI_DATA_NULL) {
/* NULL-frame with pwrbit=1, buffer_STA should buffer frames for sleep_STA */
if (GetPwrMgt(ptr)) {
/* it would be triggered when we are off channel and receiving NULL DATA */
/* we can confirm that peer STA is at off channel */
RTW_INFO("TDLS: recv peer null frame with pwr bit 1\n");
/* ptdls_sta->tdls_sta_state|=TDLS_PEER_SLEEP_STATE; */
}
/* TODO: Updated BSSID's seq. */
/* RTW_INFO("drop Null Data\n"); */
ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
ret = _FAIL;
goto exit;
}
/* receive some of all TDLS management frames, process it at ON_TDLS */
if (_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_TDLS, 2)) {
ret = OnTDLS(adapter, precv_frame);
goto exit;
}
if ((get_frame_sub_type(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE)
process_wmmps_data(adapter, precv_frame, ptdls_sta);
ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
}
} else
#endif /* CONFIG_TDLS */
{
/* For Station mode, sa and bssid should always be BSSID, and DA is my mac-address */
if (!_rtw_memcmp(pattrib->bssid, pattrib->src, ETH_ALEN)) {
ret = _FAIL;
goto exit;
}
}
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
if (bmcast) {
/* For AP mode, if DA == MCAST, then BSSID should be also MCAST */
if (!IS_MCAST(pattrib->bssid)) {
ret = _FAIL;
goto exit;
}
} else { /* not mc-frame */
/* For AP mode, if DA is non-MCAST, then it must be BSSID, and bssid == BSSID */
if (!_rtw_memcmp(pattrib->bssid, pattrib->dst, ETH_ALEN)) {
ret = _FAIL;
goto exit;
}
}
} else if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) {
_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
sta_addr = mybssid;
} else
ret = _FAIL;
#ifdef CONFIG_TDLS
if (ptdls_sta == NULL)
#endif
*psta = rtw_get_stainfo(pstapriv, sta_addr);
if (*psta == NULL) {
#ifdef CONFIG_MP_INCLUDED
if (adapter->registrypriv.mp_mode == 1) {
if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)
adapter->mppriv.rx_pktloss++;
}
#endif
ret = _FAIL;
goto exit;
}
exit:
return ret;
}
sint ap2sta_data_frame(
_adapter *adapter,
union recv_frame *precv_frame,
struct sta_info **psta)
{
u8 *ptr = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
sint ret = _SUCCESS;
struct sta_priv *pstapriv = &adapter->stapriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
u8 *mybssid = get_bssid(pmlmepriv);
u8 *myhwaddr = adapter_mac_addr(adapter);
sint bmcast = IS_MCAST(pattrib->dst);
if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
&& (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE
|| check_fwstate(pmlmepriv, _FW_UNDER_LINKING) == _TRUE)
) {
/* filter packets that SA is myself or multicast or broadcast */
if (_rtw_memcmp(myhwaddr, pattrib->src, ETH_ALEN)) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" SA="MAC_FMT", myhwaddr="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->src), MAC_ARG(myhwaddr));
#endif
ret = _FAIL;
goto exit;
}
/* da should be for me */
if ((!_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN)) && (!bmcast)) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DA="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->dst));
#endif
ret = _FAIL;
goto exit;
}
/* check BSSID */
if (_rtw_memcmp(pattrib->bssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
_rtw_memcmp(mybssid, "\x0\x0\x0\x0\x0\x0", ETH_ALEN) ||
(!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN))) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" BSSID="MAC_FMT", mybssid="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(pattrib->bssid), MAC_ARG(mybssid));
#endif
#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
if (!bmcast
&& !IS_RADAR_DETECTED(adapter_to_rfctl(adapter))
) {
RTW_INFO(ADPT_FMT" -issue_deauth to the nonassociated ap=" MAC_FMT " for the reason(7)\n", ADPT_ARG(adapter), MAC_ARG(pattrib->bssid));
issue_deauth(adapter, pattrib->bssid, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
}
#endif
ret = _FAIL;
goto exit;
}
*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
if (*psta == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" can't get psta under STATION_MODE ; drop pkt\n"
, FUNC_ADPT_ARG(adapter));
#endif
ret = _FAIL;
goto exit;
}
/*if ((get_frame_sub_type(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE) {
}
*/
if (get_frame_sub_type(ptr) & BIT(6)) {
/* No data, will not indicate to upper layer, temporily count it here */
count_rx_stats(adapter, precv_frame, *psta);
ret = RTW_RX_HANDLED;
goto exit;
}
} else if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) &&
(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); /* get sta_info */
if (*psta == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" can't get psta under WIFI_MP_STATE ; drop pkt\n"
, FUNC_ADPT_ARG(adapter));
#endif
ret = _FAIL;
goto exit;
}
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
/* Special case */
ret = RTW_RX_HANDLED;
goto exit;
} else {
if (_rtw_memcmp(myhwaddr, pattrib->dst, ETH_ALEN) && (!bmcast)) {
*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
if (*psta == NULL) {
/* for AP multicast issue , modify by yiwei */
static systime send_issue_deauth_time = 0;
/* RTW_INFO("After send deauth , %u ms has elapsed.\n", rtw_get_passing_time_ms(send_issue_deauth_time)); */
if (rtw_get_passing_time_ms(send_issue_deauth_time) > 10000 || send_issue_deauth_time == 0) {
send_issue_deauth_time = rtw_get_current_time();
RTW_INFO("issue_deauth to the ap=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->bssid));
issue_deauth(adapter, pattrib->bssid, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
}
}
}
ret = _FAIL;
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" fw_state:0x%x\n"
, FUNC_ADPT_ARG(adapter), get_fwstate(pmlmepriv));
#endif
}
exit:
return ret;
}
sint sta2ap_data_frame(
_adapter *adapter,
union recv_frame *precv_frame,
struct sta_info **psta)
{
u8 *ptr = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_priv *pstapriv = &adapter->stapriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
unsigned char *mybssid = get_bssid(pmlmepriv);
sint ret = _SUCCESS;
if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
/* For AP mode, RA=BSSID, TX=STA(SRC_ADDR), A3=DST_ADDR */
if (!_rtw_memcmp(pattrib->bssid, mybssid, ETH_ALEN)) {
ret = _FAIL;
goto exit;
}
*psta = rtw_get_stainfo(pstapriv, pattrib->ta);
if (*psta == NULL) {
if (!IS_RADAR_DETECTED(adapter_to_rfctl(adapter))) {
#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
#endif
}
ret = RTW_RX_HANDLED;
goto exit;
}
process_pwrbit_data(adapter, precv_frame, *psta);
if ((get_frame_sub_type(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE)
process_wmmps_data(adapter, precv_frame, *psta);
if (get_frame_sub_type(ptr) & BIT(6)) {
/* No data, will not indicate to upper layer, temporily count it here */
count_rx_stats(adapter, precv_frame, *psta);
ret = RTW_RX_HANDLED;
goto exit;
}
} else if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE) &&
(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
/* RTW_INFO("%s ,in WIFI_MP_STATE\n",__func__); */
_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
*psta = rtw_get_stainfo(pstapriv, pattrib->bssid); /* get sta_info */
if (*psta == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" can't get psta under WIFI_MP_STATE ; drop pkt\n"
, FUNC_ADPT_ARG(adapter));
#endif
ret = _FAIL;
goto exit;
}
} else {
u8 *myhwaddr = adapter_mac_addr(adapter);
if (!_rtw_memcmp(pattrib->ra, myhwaddr, ETH_ALEN)) {
ret = RTW_RX_HANDLED;
goto exit;
}
#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
RTW_INFO("issue_deauth to sta=" MAC_FMT " for the reason(7)\n", MAC_ARG(pattrib->src));
issue_deauth(adapter, pattrib->src, WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
#endif
ret = RTW_RX_HANDLED;
goto exit;
}
exit:
return ret;
}
sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame);
sint validate_recv_ctrl_frame(_adapter *padapter, union recv_frame *precv_frame)
{
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
struct sta_info *psta = NULL;
/* uint len = precv_frame->u.hdr.len; */
/* RTW_INFO("+validate_recv_ctrl_frame\n"); */
if (GetFrameType(pframe) != WIFI_CTRL_TYPE)
return _FAIL;
/* receive the frames that ra(a1) is my address */
if (!_rtw_memcmp(GetAddr1Ptr(pframe), adapter_mac_addr(padapter), ETH_ALEN))
return _FAIL;
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta == NULL)
return _FAIL;
/* for rx pkt statistics */
psta->sta_stats.last_rx_time = rtw_get_current_time();
psta->sta_stats.rx_ctrl_pkts++;
/* only handle ps-poll */
if (get_frame_sub_type(pframe) == WIFI_PSPOLL) {
#ifdef CONFIG_AP_MODE
u16 aid;
u8 wmmps_ac = 0;
aid = GetAid(pframe);
if (psta->cmn.aid != aid)
return _FAIL;
switch (pattrib->priority) {
case 1:
case 2:
wmmps_ac = psta->uapsd_bk & BIT(0);
break;
case 4:
case 5:
wmmps_ac = psta->uapsd_vi & BIT(0);
break;
case 6:
case 7:
wmmps_ac = psta->uapsd_vo & BIT(0);
break;
case 0:
case 3:
default:
wmmps_ac = psta->uapsd_be & BIT(0);
break;
}
if (wmmps_ac)
return _FAIL;
if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
RTW_INFO("%s alive check-rx ps-poll\n", __func__);
psta->expire_to = pstapriv->expire_to;
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
}
if ((psta->state & WIFI_SLEEP_STATE) && (rtw_tim_map_is_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid))) {
_irqL irqL;
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
_enter_critical_bh(&pxmitpriv->lock, &irqL);
xmitframe_phead = get_list_head(&psta->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
if ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
rtw_list_delete(&pxmitframe->list);
psta->sleepq_len--;
if (psta->sleepq_len > 0)
pxmitframe->attrib.mdata = 1;
else
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.triggered = 1;
/* RTW_INFO("handling ps-poll, q_len=%d\n", psta->sleepq_len); */
/* RTW_INFO_DUMP("handling, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
#if 0
_exit_critical_bh(&psta->sleep_q.lock, &irqL);
if (rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
rtw_os_xmit_complete(padapter, pxmitframe);
_enter_critical_bh(&psta->sleep_q.lock, &irqL);
#endif
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
if (psta->sleepq_len == 0) {
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
/* RTW_INFO("after handling ps-poll\n"); */
/* RTW_INFO_DUMP("after handling, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
/* upate BCN for TIM IE */
/* update_BCNTIM(padapter); */
update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0);
}
/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
_exit_critical_bh(&pxmitpriv->lock, &irqL);
} else {
/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
_exit_critical_bh(&pxmitpriv->lock, &irqL);
/* RTW_INFO("no buffered packets to xmit\n"); */
if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
if (psta->sleepq_len == 0) {
RTW_INFO("no buffered packets to xmit\n");
/* issue nulldata with More data bit = 0 to indicate we have no buffered packets */
issue_nulldata(padapter, psta->cmn.mac_addr, 0, 0, 0);
} else {
RTW_INFO("error!psta->sleepq_len=%d\n", psta->sleepq_len);
psta->sleepq_len = 0;
}
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
/* upate BCN for TIM IE */
/* update_BCNTIM(padapter); */
update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0);
}
}
}
#endif /* CONFIG_AP_MODE */
} else if (get_frame_sub_type(pframe) == WIFI_NDPA) {
#ifdef CONFIG_BEAMFORMING
rtw_beamforming_get_ndpa_frame(padapter, precv_frame);
#endif/*CONFIG_BEAMFORMING*/
} else if (get_frame_sub_type(pframe) == WIFI_BAR) {
rtw_process_bar_frame(padapter, precv_frame);
}
return _FAIL;
}
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
static sint validate_mgmt_protect(_adapter *adapter, union recv_frame *precv_frame)
{
#define DBG_VALIDATE_MGMT_PROTECT 0
#define DBG_VALIDATE_MGMT_DEC 0
struct security_priv *sec = &adapter->securitypriv;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_info *psta = precv_frame->u.hdr.psta;
u8 *ptr;
u8 type;
u8 subtype;
u8 is_bmc;
u8 category = 0xFF;
#ifdef CONFIG_IEEE80211W
const u8 *igtk;
u16 igtk_id;
u64* ipn;
#endif
u8 *mgmt_DATA;
u32 data_len = 0;
sint ret;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
if (!adapter->mesh_info.mesh_auth_id)
return pattrib->privacy ? _FAIL : _SUCCESS;
} else
#endif
if (SEC_IS_BIP_KEY_INSTALLED(sec) == _FALSE)
return _SUCCESS;
ptr = precv_frame->u.hdr.rx_data;
type = GetFrameType(ptr);
subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
is_bmc = IS_MCAST(GetAddr1Ptr(ptr));
#if DBG_VALIDATE_MGMT_PROTECT
if (subtype == WIFI_DEAUTH) {
RTW_INFO(FUNC_ADPT_FMT" bmc:%u, deauth, privacy:%u, encrypt:%u, bdecrypted:%u\n"
, FUNC_ADPT_ARG(adapter)
, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
} else if (subtype == WIFI_DISASSOC) {
RTW_INFO(FUNC_ADPT_FMT" bmc:%u, disassoc, privacy:%u, encrypt:%u, bdecrypted:%u\n"
, FUNC_ADPT_ARG(adapter)
, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
} if (subtype == WIFI_ACTION) {
if (pattrib->privacy) {
RTW_INFO(FUNC_ADPT_FMT" bmc:%u, action(?), privacy:%u, encrypt:%u, bdecrypted:%u\n"
, FUNC_ADPT_ARG(adapter)
, is_bmc, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
} else {
RTW_INFO(FUNC_ADPT_FMT" bmc:%u, action(%u), privacy:%u, encrypt:%u, bdecrypted:%u\n"
, FUNC_ADPT_ARG(adapter), is_bmc
, *(ptr + sizeof(struct rtw_ieee80211_hdr_3addr))
, pattrib->privacy, pattrib->encrypt, pattrib->bdecrypted);
}
}
#endif
if (!pattrib->privacy) {
if (!psta || !(psta->flags & WLAN_STA_MFP)) {
/* peer is not MFP capable, no need to check */
goto exit;
}
if (subtype == WIFI_ACTION)
category = *(ptr + sizeof(struct rtw_ieee80211_hdr_3addr));
if (is_bmc) {
/* broadcast cases */
if (subtype == WIFI_ACTION) {
if (CATEGORY_IS_GROUP_PRIVACY(category)) {
/* drop broadcast group privacy action frame without encryption */
#if DBG_VALIDATE_MGMT_PROTECT
RTW_INFO(FUNC_ADPT_FMT" broadcast gp action(%u) w/o encrypt\n"
, FUNC_ADPT_ARG(adapter), category);
#endif
goto fail;
}
if (CATEGORY_IS_ROBUST(category)) {
/* broadcast robust action frame need BIP check */
goto bip_verify;
}
}
if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
/* broadcast deauth or disassoc frame need BIP check */
goto bip_verify;
}
goto exit;
} else {
/* unicast cases */
#ifdef CONFIG_IEEE80211W
if (subtype == WIFI_DEAUTH || subtype == WIFI_DISASSOC) {
if (!MLME_IS_MESH(adapter)) {
unsigned short reason = le16_to_cpu(*(unsigned short *)(ptr + WLAN_HDR_A3_LEN));
#if DBG_VALIDATE_MGMT_PROTECT
RTW_INFO(FUNC_ADPT_FMT" unicast %s, reason=%d w/o encrypt\n"
, FUNC_ADPT_ARG(adapter), subtype == WIFI_DEAUTH ? "deauth" : "disassoc", reason);
#endif
if (reason == 6 || reason == 7) {
/* issue sa query request */
issue_action_SA_Query(adapter, psta->cmn.mac_addr, 0, 0, IEEE80211W_RIGHT_KEY);
}
}
goto fail;
}
#endif
if (subtype == WIFI_ACTION && CATEGORY_IS_ROBUST(category)) {
if (psta->bpairwise_key_installed == _TRUE) {
#if DBG_VALIDATE_MGMT_PROTECT
RTW_INFO(FUNC_ADPT_FMT" unicast robust action(%d) w/o encrypt\n"
, FUNC_ADPT_ARG(adapter), category);
#endif
goto fail;
}
}
goto exit;
}
bip_verify:
#ifdef CONFIG_IEEE80211W
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
if (psta->igtk_bmp) {
igtk = psta->igtk.skey;
igtk_id = psta->igtk_id;
ipn = &psta->igtk_pn.val;
} else {
/* mesh MFP without IGTK */
goto exit;
}
} else
#endif
{
igtk = sec->dot11wBIPKey[sec->dot11wBIPKeyid].skey;
igtk_id = sec->dot11wBIPKeyid;
ipn = &sec->dot11wBIPrxpn.val;
}
/* verify BIP MME IE */
ret = rtw_BIP_verify(adapter
, get_recvframe_data(precv_frame)
, get_recvframe_len(precv_frame)
, igtk, igtk_id, ipn);
if (ret == _FAIL) {
/* RTW_INFO("802.11w BIP verify fail\n"); */
goto fail;
} else if (ret == RTW_RX_HANDLED) {
#if DBG_VALIDATE_MGMT_PROTECT
RTW_INFO(FUNC_ADPT_FMT" none protected packet\n", FUNC_ADPT_ARG(adapter));
#endif
goto fail;
}
#endif /* CONFIG_IEEE80211W */
goto exit;
}
/* cases to decrypt mgmt frame */
pattrib->bdecrypted = 0;
pattrib->encrypt = _AES_;
pattrib->hdrlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* set iv and icv length */
SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
/* actual management data frame body */
data_len = pattrib->pkt_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
mgmt_DATA = rtw_zmalloc(data_len);
if (mgmt_DATA == NULL) {
RTW_INFO(FUNC_ADPT_FMT" mgmt allocate fail !!!!!!!!!\n", FUNC_ADPT_ARG(adapter));
goto fail;
}
#if DBG_VALIDATE_MGMT_DEC
/* dump the packet content before decrypt */
{
int pp;
printk("pattrib->pktlen = %d =>", pattrib->pkt_len);
for (pp = 0; pp < pattrib->pkt_len; pp++)
printk(" %02x ", ptr[pp]);
printk("\n");
}
#endif
precv_frame = decryptor(adapter, precv_frame);
/* save actual management data frame body */
_rtw_memcpy(mgmt_DATA, ptr + pattrib->hdrlen + pattrib->iv_len, data_len);
/* overwrite the iv field */
_rtw_memcpy(ptr + pattrib->hdrlen, mgmt_DATA, data_len);
/* remove the iv and icv length */
pattrib->pkt_len = pattrib->pkt_len - pattrib->iv_len - pattrib->icv_len;
rtw_mfree(mgmt_DATA, data_len);
#if DBG_VALIDATE_MGMT_DEC
/* print packet content after decryption */
{
int pp;
printk("after decryption pattrib->pktlen = %d @@=>", pattrib->pkt_len);
for (pp = 0; pp < pattrib->pkt_len; pp++)
printk(" %02x ", ptr[pp]);
printk("\n");
}
#endif
if (!precv_frame) {
#if DBG_VALIDATE_MGMT_PROTECT
RTW_INFO(FUNC_ADPT_FMT" mgmt descrypt fail !!!!!!!!!\n", FUNC_ADPT_ARG(adapter));
#endif
goto fail;
}
exit:
return _SUCCESS;
fail:
return _FAIL;
}
#endif /* defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH) */
union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame);
sint validate_recv_mgnt_frame(PADAPTER padapter, union recv_frame *precv_frame)
{
struct sta_info *psta = precv_frame->u.hdr.psta
= rtw_get_stainfo(&padapter->stapriv, get_addr2_ptr(precv_frame->u.hdr.rx_data));
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
if (validate_mgmt_protect(padapter, precv_frame) == _FAIL) {
DBG_COUNTER(padapter->rx_logs.core_rx_pre_mgmt_err_80211w);
goto exit;
}
#endif
precv_frame = recvframe_chk_defrag(padapter, precv_frame);
if (precv_frame == NULL)
return _SUCCESS;
/* for rx pkt statistics */
if (psta) {
psta->sta_stats.last_rx_time = rtw_get_current_time();
psta->sta_stats.rx_mgnt_pkts++;
if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_BEACON)
psta->sta_stats.rx_beacon_pkts++;
else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBEREQ)
psta->sta_stats.rx_probereq_pkts++;
else if (get_frame_sub_type(precv_frame->u.hdr.rx_data) == WIFI_PROBERSP) {
if (_rtw_memcmp(adapter_mac_addr(padapter), GetAddr1Ptr(precv_frame->u.hdr.rx_data), ETH_ALEN) == _TRUE)
psta->sta_stats.rx_probersp_pkts++;
else if (is_broadcast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data))
|| is_multicast_mac_addr(GetAddr1Ptr(precv_frame->u.hdr.rx_data)))
psta->sta_stats.rx_probersp_bm_pkts++;
else
psta->sta_stats.rx_probersp_uo_pkts++;
}
}
mgt_dispatcher(padapter, precv_frame);
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
exit:
#endif
return _SUCCESS;
}
sint validate_recv_data_frame(_adapter *adapter, union recv_frame *precv_frame)
{
u8 bretry, a4_shift;
struct sta_info *psta = NULL;
u8 *ptr = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct security_priv *psecuritypriv = &adapter->securitypriv;
sint ret = _SUCCESS;
bretry = GetRetry(ptr);
a4_shift = (pattrib->to_fr_ds == 3) ? ETH_ALEN : 0;
/* some address fields are different when using AMSDU */
if (pattrib->qos)
pattrib->amsdu = GetAMsdu(ptr + WLAN_HDR_A3_LEN + a4_shift);
else
pattrib->amsdu = 0;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(adapter)) {
ret = rtw_mesh_rx_data_validate_hdr(adapter, precv_frame, &psta);
goto pre_validate_status_chk;
}
#endif
switch (pattrib->to_fr_ds) {
case 0:
_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->bssid, GetAddr3Ptr(ptr), ETH_ALEN);
ret = sta2sta_data_frame(adapter, precv_frame, &psta);
break;
case 1:
_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->dst, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->src, GetAddr3Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->bssid, get_addr2_ptr(ptr), ETH_ALEN);
ret = ap2sta_data_frame(adapter, precv_frame, &psta);
break;
case 2:
_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->dst, GetAddr3Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->src, get_addr2_ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->bssid, GetAddr1Ptr(ptr), ETH_ALEN);
ret = sta2ap_data_frame(adapter, precv_frame, &psta);
break;
case 3:
default:
/* WDS is not supported */
ret = _FAIL;
break;
}
#ifdef CONFIG_RTW_MESH
pre_validate_status_chk:
#endif
if (ret == _FAIL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" case:%d, res:%d, ra="MAC_FMT", ta="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), pattrib->to_fr_ds, ret, MAC_ARG(GetAddr1Ptr(ptr)), MAC_ARG(get_addr2_ptr(ptr)));
#endif
goto exit;
} else if (ret == RTW_RX_HANDLED)
goto exit;
if (psta == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" psta == NULL, ra="MAC_FMT", ta="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(GetAddr1Ptr(ptr)), MAC_ARG(get_addr2_ptr(ptr)));
#endif
ret = _FAIL;
goto exit;
}
precv_frame->u.hdr.psta = psta;
precv_frame->u.hdr.preorder_ctrl = NULL;
pattrib->ack_policy = 0;
/* parsing QC field */
if (pattrib->qos == 1) {
pattrib->priority = GetPriority((ptr + WLAN_HDR_A3_LEN + a4_shift)); /* point to Qos field*/
pattrib->ack_policy = GetAckpolicy((ptr + WLAN_HDR_A3_LEN + a4_shift));
pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN + a4_shift;
if (pattrib->priority != 0 && pattrib->priority != 3)
adapter->recvpriv.is_any_non_be_pkts = _TRUE;
else
adapter->recvpriv.is_any_non_be_pkts = _FALSE;
} else {
pattrib->priority = 0;
pattrib->hdrlen = WLAN_HDR_A3_LEN + a4_shift;
}
if (pattrib->order) /* HT-CTRL 11n */
pattrib->hdrlen += 4;
/* decache, drop duplicate recv packets */
ret = recv_decache(precv_frame);
if (ret == _FAIL)
goto exit;
if (!IS_MCAST(pattrib->ra)) {
if (pattrib->qos)
precv_frame->u.hdr.preorder_ctrl = &psta->recvreorder_ctrl[pattrib->priority];
if (recv_ucast_pn_decache(precv_frame) == _FAIL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_ucast_pn_decache return _FAIL for sta="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
#endif
ret = _FAIL;
goto exit;
}
} else {
if (recv_bcast_pn_decache(precv_frame) == _FAIL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recv_bcast_pn_decache return _FAIL for sta="MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(psta->cmn.mac_addr));
#endif
ret = _FAIL;
goto exit;
}
}
if (pattrib->privacy) {
#ifdef CONFIG_TDLS
if ((psta->tdls_sta_state & TDLS_LINKED_STATE) && (psta->dot118021XPrivacy == _AES_))
pattrib->encrypt = psta->dot118021XPrivacy;
else
#endif /* CONFIG_TDLS */
GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, IS_MCAST(pattrib->ra));
SET_ICE_IV_LEN(pattrib->iv_len, pattrib->icv_len, pattrib->encrypt);
} else {
pattrib->encrypt = 0;
pattrib->iv_len = pattrib->icv_len = 0;
}
#ifdef CONFIG_RTW_MESH
if (!pattrib->amsdu
&& pattrib->mesh_ctrl_present
&& (!pattrib->encrypt || pattrib->bdecrypted))
ret = rtw_mesh_rx_validate_mctrl_non_amsdu(adapter, precv_frame);
#endif
exit:
return ret;
}
static inline void dump_rx_packet(u8 *ptr)
{
int i;
RTW_INFO("#############################\n");
for (i = 0; i < 64; i = i + 8)
RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(ptr + i),
*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
RTW_INFO("#############################\n");
}
sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame);
sint validate_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
{
/* shall check frame subtype, to / from ds, da, bssid */
/* then call check if rx seq/frag. duplicated. */
u8 type;
u8 subtype;
sint retval = _SUCCESS;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct recv_priv *precvpriv = &adapter->recvpriv;
u8 *ptr = precv_frame->u.hdr.rx_data;
u8 ver = (unsigned char)(*ptr) & 0x3 ;
#ifdef CONFIG_FIND_BEST_CHANNEL
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
#endif
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &adapter->tdlsinfo;
#endif /* CONFIG_TDLS */
#ifdef CONFIG_WAPI_SUPPORT
PRT_WAPI_T pWapiInfo = &adapter->wapiInfo;
struct recv_frame_hdr *phdr = &precv_frame->u.hdr;
u8 wai_pkt = 0;
u16 sc;
u8 external_len = 0;
#endif
#ifdef CONFIG_FIND_BEST_CHANNEL
if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS) {
int ch_set_idx = rtw_chset_search_ch(rfctl->channel_set, rtw_get_oper_ch(adapter));
if (ch_set_idx >= 0)
rfctl->channel_set[ch_set_idx].rx_count++;
}
#endif
#ifdef CONFIG_TDLS
if (ptdlsinfo->ch_sensing == 1 && ptdlsinfo->cur_channel != 0)
ptdlsinfo->collect_pkt_num[ptdlsinfo->cur_channel - 1]++;
#endif /* CONFIG_TDLS */
#ifdef RTK_DMP_PLATFORM
if (0) {
RTW_INFO("++\n");
{
int i;
for (i = 0; i < 64; i = i + 8)
RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:", *(ptr + i),
*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
}
RTW_INFO("--\n");
}
#endif /* RTK_DMP_PLATFORM */
/* add version chk */
if (ver != 0) {
retval = _FAIL;
DBG_COUNTER(adapter->rx_logs.core_rx_pre_ver_err);
goto exit;
}
type = GetFrameType(ptr);
subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
pattrib->to_fr_ds = get_tofr_ds(ptr);
pattrib->frag_num = GetFragNum(ptr);
pattrib->seq_num = GetSequence(ptr);
pattrib->pw_save = GetPwrMgt(ptr);
pattrib->mfrag = GetMFrag(ptr);
pattrib->mdata = GetMData(ptr);
pattrib->privacy = GetPrivacy(ptr);
pattrib->order = GetOrder(ptr);
#ifdef CONFIG_WAPI_SUPPORT
sc = (pattrib->seq_num << 4) | pattrib->frag_num;
#endif
#if 1 /* Dump rx packets */
{
u8 bDumpRxPkt = 0;
rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
if (bDumpRxPkt == 1) /* dump all rx packets */
dump_rx_packet(ptr);
else if ((bDumpRxPkt == 2) && (type == WIFI_MGT_TYPE))
dump_rx_packet(ptr);
else if ((bDumpRxPkt == 3) && (type == WIFI_DATA_TYPE))
dump_rx_packet(ptr);
}
#endif
switch (type) {
case WIFI_MGT_TYPE: /* mgnt */
DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt);
retval = validate_recv_mgnt_frame(adapter, precv_frame);
if (retval == _FAIL) {
DBG_COUNTER(adapter->rx_logs.core_rx_pre_mgmt_err);
}
retval = _FAIL; /* only data frame return _SUCCESS */
break;
case WIFI_CTRL_TYPE: /* ctrl */
DBG_COUNTER(adapter->rx_logs.core_rx_pre_ctrl);
retval = validate_recv_ctrl_frame(adapter, precv_frame);
if (retval == _FAIL) {
DBG_COUNTER(adapter->rx_logs.core_rx_pre_ctrl_err);
}
retval = _FAIL; /* only data frame return _SUCCESS */
break;
case WIFI_DATA_TYPE: /* data */
DBG_COUNTER(adapter->rx_logs.core_rx_pre_data);
#ifdef CONFIG_WAPI_SUPPORT
if (pattrib->qos)
external_len = 2;
else
external_len = 0;
wai_pkt = rtw_wapi_is_wai_packet(adapter, ptr);
phdr->bIsWaiPacket = wai_pkt;
if (wai_pkt != 0) {
if (sc != adapter->wapiInfo.wapiSeqnumAndFragNum)
adapter->wapiInfo.wapiSeqnumAndFragNum = sc;
else {
retval = _FAIL;
DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_wapi_seq_err);
break;
}
} else {
if (rtw_wapi_drop_for_key_absent(adapter, get_addr2_ptr(ptr))) {
retval = _FAIL;
WAPI_TRACE(WAPI_RX, "drop for key absent for rx\n");
DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_wapi_key_err);
break;
}
}
#endif
pattrib->qos = (subtype & BIT(7)) ? 1 : 0;
retval = validate_recv_data_frame(adapter, precv_frame);
if (retval == _FAIL) {
precvpriv->dbg_rx_drop_count++;
DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_err);
} else if (retval == _SUCCESS) {
#ifdef DBG_RX_DUMP_EAP
if (!pattrib->encrypt || pattrib->bdecrypted) {
u8 bDumpRxPkt;
u16 eth_type;
/* dump eapol */
rtw_hal_get_def_var(adapter, HAL_DEF_DBG_DUMP_RXPKT, &(bDumpRxPkt));
/* get ether_type */
_rtw_memcpy(ð_type, ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + LLC_HEADER_SIZE, 2);
eth_type = ntohs((unsigned short) eth_type);
if ((bDumpRxPkt == 4) && (eth_type == 0x888e))
dump_rx_packet(ptr);
}
#endif
} else
DBG_COUNTER(adapter->rx_logs.core_rx_pre_data_handled);
break;
default:
DBG_COUNTER(adapter->rx_logs.core_rx_pre_unknown);
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" fail! type=0x%x\n"
, FUNC_ADPT_ARG(adapter), type);
#endif
retval = _FAIL;
break;
}
exit:
return retval;
}
/* remove the wlanhdr and add the eth_hdr */
sint wlanhdr_to_ethhdr(union recv_frame *precvframe)
{
sint rmv_len;
u16 eth_type, len;
u8 bsnaphdr;
u8 *psnap_type;
struct ieee80211_snap_hdr *psnap;
sint ret = _SUCCESS;
_adapter *adapter = precvframe->u.hdr.adapter;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
u8 *ptr = get_recvframe_data(precvframe) ; /* point to frame_ctrl field */
struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
if (pattrib->encrypt)
recvframe_pull_tail(precvframe, pattrib->icv_len);
psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib));
psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + SNAP_SIZE;
/* convert hdr + possible LLC headers into Ethernet header */
/* eth_type = (psnap_type[0] << 8) | psnap_type[1]; */
if ((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_IPX, 2) == _FALSE) &&
(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_AARP, 2) == _FALSE)) ||
/* eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) || */
_rtw_memcmp(psnap, rtw_bridge_tunnel_header, SNAP_SIZE)) {
/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
bsnaphdr = _TRUE;
} else {
/* Leave Ethernet header part of hdr and full payload */
bsnaphdr = _FALSE;
}
rmv_len = pattrib->hdrlen + pattrib->iv_len + RATTRIB_GET_MCTRL_LEN(pattrib) + (bsnaphdr ? SNAP_SIZE : 0);
len = precvframe->u.hdr.len - rmv_len;
_rtw_memcpy(ð_type, ptr + rmv_len, 2);
eth_type = ntohs((unsigned short)eth_type); /* pattrib->ether_type */
pattrib->eth_type = eth_type;
if ((check_fwstate(pmlmepriv, WIFI_MP_STATE) == _TRUE)) {
ptr += rmv_len ;
*ptr = 0x87;
*(ptr + 1) = 0x12;
eth_type = 0x8712;
/* append rx status for mp test packets */
ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + 2) - 24);
if (!ptr) {
ret = _FAIL;
goto exiting;
}
_rtw_memcpy(ptr, get_rxmem(precvframe), 24);
ptr += 24;
} else {
ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + (bsnaphdr ? 2 : 0)));
if (!ptr) {
ret = _FAIL;
goto exiting;
}
}
if (ptr) {
_rtw_memcpy(ptr, pattrib->dst, ETH_ALEN);
_rtw_memcpy(ptr + ETH_ALEN, pattrib->src, ETH_ALEN);
if (!bsnaphdr) {
len = htons(len);
_rtw_memcpy(ptr + 12, &len, 2);
}
rtw_rframe_set_os_pkt(precvframe);
}
exiting:
return ret;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
#ifndef CONFIG_SDIO_RX_COPY
#ifdef PLATFORM_LINUX
static void recvframe_expand_pkt(
PADAPTER padapter,
union recv_frame *prframe)
{
struct recv_frame_hdr *pfhdr;
_pkt *ppkt;
u8 shift_sz;
u32 alloc_sz;
u8 *ptr;
pfhdr = &prframe->u.hdr;
/* 6 is for IP header 8 bytes alignment in QoS packet case. */
if (pfhdr->attrib.qos)
shift_sz = 6;
else
shift_sz = 0;
/* for first fragment packet, need to allocate */
/* (1536 + RXDESC_SIZE + drvinfo_sz) to reassemble packet */
/* 8 is for skb->data 8 bytes alignment.
* alloc_sz = _RND(1536 + RXDESC_SIZE + pfhdr->attrib.drvinfosize + shift_sz + 8, 128); */
alloc_sz = 1664; /* round (1536 + 24 + 32 + shift_sz + 8) to 128 bytes alignment */
/* 3 1. alloc new skb */
/* prepare extra space for 4 bytes alignment */
ppkt = rtw_skb_alloc(alloc_sz);
if (!ppkt)
return; /* no way to expand */
/* 3 2. Prepare new skb to replace & release old skb */
/* force ppkt->data at 8-byte alignment address */
skb_reserve(ppkt, 8 - ((SIZE_PTR)ppkt->data & 7));
/* force ip_hdr at 8-byte alignment address according to shift_sz */
skb_reserve(ppkt, shift_sz);
/* copy data to new pkt */
ptr = skb_put(ppkt, pfhdr->len);
if (ptr)
_rtw_memcpy(ptr, pfhdr->rx_data, pfhdr->len);
rtw_skb_free(pfhdr->pkt);
/* attach new pkt to recvframe */
pfhdr->pkt = ppkt;
pfhdr->rx_head = ppkt->head;
pfhdr->rx_data = ppkt->data;
pfhdr->rx_tail = skb_tail_pointer(ppkt);
pfhdr->rx_end = skb_end_pointer(ppkt);
}
#else /*!= PLATFORM_LINUX*/
#warning "recvframe_expand_pkt not implement, defrag may crash system"
#endif
#endif /*#ifndef CONFIG_SDIO_RX_COPY*/
#endif
/* perform defrag */
union recv_frame *recvframe_defrag(_adapter *adapter, _queue *defrag_q);
union recv_frame *recvframe_defrag(_adapter *adapter, _queue *defrag_q)
{
_list *plist, *phead;
u8 *data, wlanhdr_offset;
u8 curfragnum;
struct recv_frame_hdr *pfhdr, *pnfhdr;
union recv_frame *prframe, *pnextrframe;
_queue *pfree_recv_queue;
curfragnum = 0;
pfree_recv_queue = &adapter->recvpriv.free_recv_queue;
phead = get_list_head(defrag_q);
plist = get_next(phead);
prframe = LIST_CONTAINOR(plist, union recv_frame, u);
pfhdr = &prframe->u.hdr;
rtw_list_delete(&(prframe->u.list));
if (curfragnum != pfhdr->attrib.frag_num) {
/* the first fragment number must be 0 */
/* free the whole queue */
rtw_free_recvframe(prframe, pfree_recv_queue);
rtw_free_recvframe_queue(defrag_q, pfree_recv_queue);
return NULL;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
#ifndef CONFIG_SDIO_RX_COPY
recvframe_expand_pkt(adapter, prframe);
#endif
#endif
curfragnum++;
plist = get_list_head(defrag_q);
plist = get_next(plist);
data = get_recvframe_data(prframe);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
pnextrframe = LIST_CONTAINOR(plist, union recv_frame , u);
pnfhdr = &pnextrframe->u.hdr;
/* check the fragment sequence (2nd ~n fragment frame) */
if (curfragnum != pnfhdr->attrib.frag_num) {
/* the fragment number must be increasing (after decache) */
/* release the defrag_q & prframe */
rtw_free_recvframe(prframe, pfree_recv_queue);
rtw_free_recvframe_queue(defrag_q, pfree_recv_queue);
return NULL;
}
curfragnum++;
/* copy the 2nd~n fragment frame's payload to the first fragment */
/* get the 2nd~last fragment frame's payload */
wlanhdr_offset = pnfhdr->attrib.hdrlen + pnfhdr->attrib.iv_len;
recvframe_pull(pnextrframe, wlanhdr_offset);
/* append to first fragment frame's tail (if privacy frame, pull the ICV) */
recvframe_pull_tail(prframe, pfhdr->attrib.icv_len);
/* memcpy */
_rtw_memcpy(pfhdr->rx_tail, pnfhdr->rx_data, pnfhdr->len);
recvframe_put(prframe, pnfhdr->len);
pfhdr->attrib.icv_len = pnfhdr->attrib.icv_len;
plist = get_next(plist);
};
/* free the defrag_q queue and return the prframe */
rtw_free_recvframe_queue(defrag_q, pfree_recv_queue);
return prframe;
}
/* check if need to defrag, if needed queue the frame to defrag_q */
union recv_frame *recvframe_chk_defrag(PADAPTER padapter, union recv_frame *precv_frame)
{
u8 ismfrag;
u8 fragnum;
u8 *psta_addr;
struct recv_frame_hdr *pfhdr;
struct sta_info *psta;
struct sta_priv *pstapriv;
_list *phead;
union recv_frame *prtnframe = NULL;
_queue *pfree_recv_queue, *pdefrag_q = NULL;
pstapriv = &padapter->stapriv;
pfhdr = &precv_frame->u.hdr;
pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
/* need to define struct of wlan header frame ctrl */
ismfrag = pfhdr->attrib.mfrag;
fragnum = pfhdr->attrib.frag_num;
psta_addr = pfhdr->attrib.ta;
psta = rtw_get_stainfo(pstapriv, psta_addr);
if (psta == NULL) {
u8 type = GetFrameType(pfhdr->rx_data);
if (type != WIFI_DATA_TYPE) {
psta = rtw_get_bcmc_stainfo(padapter);
if (psta)
pdefrag_q = &psta->sta_recvpriv.defrag_q;
} else
pdefrag_q = NULL;
} else
pdefrag_q = &psta->sta_recvpriv.defrag_q;
if ((ismfrag == 0) && (fragnum == 0)) {
prtnframe = precv_frame;/* isn't a fragment frame */
}
if (ismfrag == 1) {
/* 0~(n-1) fragment frame */
/* enqueue to defraf_g */
if (pdefrag_q != NULL) {
if (fragnum == 0) {
/* the first fragment */
if (_rtw_queue_empty(pdefrag_q) == _FALSE) {
/* free current defrag_q */
rtw_free_recvframe_queue(pdefrag_q, pfree_recv_queue);
}
}
/* Then enqueue the 0~(n-1) fragment into the defrag_q */
/* _rtw_spinlock(&pdefrag_q->lock); */
phead = get_list_head(pdefrag_q);
rtw_list_insert_tail(&pfhdr->list, phead);
/* _rtw_spinunlock(&pdefrag_q->lock); */
prtnframe = NULL;
} else {
/* can't find this ta's defrag_queue, so free this recv_frame */
rtw_free_recvframe(precv_frame, pfree_recv_queue);
prtnframe = NULL;
}
}
if ((ismfrag == 0) && (fragnum != 0)) {
/* the last fragment frame */
/* enqueue the last fragment */
if (pdefrag_q != NULL) {
/* _rtw_spinlock(&pdefrag_q->lock); */
phead = get_list_head(pdefrag_q);
rtw_list_insert_tail(&pfhdr->list, phead);
/* _rtw_spinunlock(&pdefrag_q->lock); */
/* call recvframe_defrag to defrag */
precv_frame = recvframe_defrag(padapter, pdefrag_q);
prtnframe = precv_frame;
} else {
/* can't find this ta's defrag_queue, so free this recv_frame */
rtw_free_recvframe(precv_frame, pfree_recv_queue);
prtnframe = NULL;
}
}
if ((prtnframe != NULL) && (prtnframe->u.hdr.attrib.privacy)) {
/* after defrag we must check tkip mic code */
if (recvframe_chkmic(padapter, prtnframe) == _FAIL) {
rtw_free_recvframe(prtnframe, pfree_recv_queue);
prtnframe = NULL;
}
}
return prtnframe;
}
static int rtw_recv_indicatepkt_check(union recv_frame *rframe, u8 *ehdr_pos, u32 pkt_len)
{
_adapter *adapter = rframe->u.hdr.adapter;
struct recv_priv *recvpriv = &adapter->recvpriv;
struct ethhdr *ehdr = (struct ethhdr *)ehdr_pos;
#ifdef DBG_IP_R_MONITOR
int i;
struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
#endif/*DBG_IP_R_MONITOR*/
int ret = _FAIL;
#ifdef CONFIG_WAPI_SUPPORT
if (rtw_wapi_check_for_drop(adapter, rframe, ehdr_pos)) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" rtw_wapi_check_for_drop\n"
, FUNC_ADPT_ARG(adapter));
#endif
goto exit;
}
#endif
if (rframe->u.hdr.psta)
rtw_st_ctl_rx(rframe->u.hdr.psta, ehdr_pos);
if (ntohs(ehdr->h_proto) == 0x888e)
parsing_eapol_packet(adapter, ehdr_pos + ETH_HLEN, rframe->u.hdr.psta, 0);
#ifdef DBG_ARP_DUMP
else if (ntohs(ehdr->h_proto) == ETH_P_ARP)
dump_arp_pkt(RTW_DBGDUMP, ehdr->h_dest, ehdr->h_source, ehdr_pos + ETH_HLEN, 0);
#endif
if (recvpriv->sink_udpport > 0)
rtw_sink_rtp_seq_dbg(adapter, ehdr_pos);
#ifdef DBG_UDP_PKT_LOSE_11AC
#define PAYLOAD_LEN_LOC_OF_IP_HDR 0x10 /*ethernet payload length location of ip header (DA + SA+eth_type+(version&hdr_len)) */
if (ntohs(ehdr->h_proto) == ETH_P_ARP) {
/* ARP Payload length will be 42bytes or 42+18(tailer)=60bytes*/
if (pkt_len != 42 && pkt_len != 60)
RTW_INFO("Error !!%s,ARP Payload length %u not correct\n" , __func__ , pkt_len);
} else if (ntohs(ehdr->h_proto) == ETH_P_IP) {
if (be16_to_cpu(*((u16 *)(ehdr_pos + PAYLOAD_LEN_LOC_OF_IP_HDR))) != (pkt_len) - ETH_HLEN) {
RTW_INFO("Error !!%s,Payload length not correct\n" , __func__);
RTW_INFO("%s, IP header describe Total length=%u\n" , __func__ , be16_to_cpu(*((u16 *)(ehdr_pos + PAYLOAD_LEN_LOC_OF_IP_HDR))));
RTW_INFO("%s, Pkt real length=%u\n" , __func__ , (pkt_len) - ETH_HLEN);
}
}
#endif
#ifdef DBG_IP_R_MONITOR
#define LEN_ARP_OP_HDR 7 /*ARP OERATION */
if (ntohs(ehdr->h_proto) == ETH_P_ARP) {
if(check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE){
if(ehdr_pos[ETHERNET_HEADER_SIZE+LEN_ARP_OP_HDR] == 2) {
RTW_INFO("%s,[DBG_ARP] Rx ARP RSP Packet;SeqNum = %d !\n",
__FUNCTION__, pattrib->seq_num);
dump_arp_pkt(RTW_DBGDUMP, ehdr->h_dest, ehdr->h_source, ehdr_pos + ETH_HLEN, 0);
}
}
}
#endif/*DBG_IP_R_MONITOR*/
#ifdef CONFIG_AUTO_AP_MODE
if (ntohs(ehdr->h_proto) == 0x8899)
rtw_auto_ap_rx_msg_dump(adapter, rframe, ehdr_pos);
#endif
ret = _SUCCESS;
#ifdef CONFIG_WAPI_SUPPORT
exit:
#endif
return ret;
}
static void recv_free_fwd_resource(_adapter *adapter, struct xmit_frame *fwd_frame, _list *b2u_list)
{
struct xmit_priv *xmitpriv = &adapter->xmitpriv;
if (fwd_frame)
rtw_free_xmitframe(xmitpriv, fwd_frame);
#ifdef CONFIG_RTW_MESH
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (!rtw_is_list_empty(b2u_list)) {
struct xmit_frame *b2uframe;
_list *list;
list = get_next(b2u_list);
while (rtw_end_of_queue_search(b2u_list, list) == _FALSE) {
b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&b2uframe->list);
rtw_free_xmitframe(xmitpriv, b2uframe);
}
}
#endif
#endif /* CONFIG_RTW_MESH */
}
#ifdef CONFIG_RTW_MESH
static void recv_fwd_pkt_hdl(_adapter *adapter, _pkt *pkt
, u8 act, struct xmit_frame *fwd_frame, _list *b2u_list)
{
struct xmit_priv *xmitpriv = &adapter->xmitpriv;
_pkt *fwd_pkt = pkt;
if (act & RTW_RX_MSDU_ACT_INDICATE) {
fwd_pkt = rtw_os_pkt_copy(pkt);
if (!fwd_pkt) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s rtw_os_pkt_copy fail\n", __func__);
#endif
recv_free_fwd_resource(adapter, fwd_frame, b2u_list);
goto exit;
}
}
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (!rtw_is_list_empty(b2u_list)) {
_list *list = get_next(b2u_list);
struct xmit_frame *b2uframe;
while (rtw_end_of_queue_search(b2u_list, list) == _FALSE) {
b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&b2uframe->list);
if (!fwd_frame && rtw_is_list_empty(b2u_list)) /* the last fwd_pkt */
b2uframe->pkt = fwd_pkt;
else
b2uframe->pkt = rtw_os_pkt_copy(fwd_pkt);
if (!b2uframe->pkt) {
rtw_free_xmitframe(xmitpriv, b2uframe);
continue;
}
rtw_xmit_posthandle(adapter, b2uframe, b2uframe->pkt);
}
}
#endif
if (fwd_frame) {
fwd_frame->pkt = fwd_pkt;
if (rtw_xmit_posthandle(adapter, fwd_frame, fwd_pkt) < 0) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s rtw_xmit_posthandle fail\n", __func__);
#endif
xmitpriv->tx_drop++;
}
}
exit:
return;
}
#endif /* CONFIG_RTW_MESH */
int amsdu_to_msdu(_adapter *padapter, union recv_frame *prframe)
{
struct rx_pkt_attrib *rattrib = &prframe->u.hdr.attrib;
int a_len, padding_len;
u16 nSubframe_Length;
u8 nr_subframes, i;
u8 *pdata;
_pkt *sub_pkt, *subframes[MAX_SUBFRAME_COUNT];
struct recv_priv *precvpriv = &padapter->recvpriv;
_queue *pfree_recv_queue = &(precvpriv->free_recv_queue);
const u8 *da, *sa;
int act;
struct xmit_frame *fwd_frame;
_list b2u_list;
u8 mctrl_len = 0;
int ret = _SUCCESS;
nr_subframes = 0;
recvframe_pull(prframe, rattrib->hdrlen);
if (rattrib->iv_len > 0)
recvframe_pull(prframe, rattrib->iv_len);
a_len = prframe->u.hdr.len;
pdata = prframe->u.hdr.rx_data;
while (a_len > ETH_HLEN) {
/* Offset 12 denote 2 mac address */
nSubframe_Length = RTW_GET_BE16(pdata + 12);
if (a_len < (ETHERNET_HEADER_SIZE + nSubframe_Length)) {
RTW_INFO("nRemain_Length is %d and nSubframe_Length is : %d\n", a_len, nSubframe_Length);
break;
}
act = RTW_RX_MSDU_ACT_INDICATE;
fwd_frame = NULL;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
u8 *mda = pdata, *msa = pdata + ETH_ALEN;
struct rtw_ieee80211s_hdr *mctrl = (struct rtw_ieee80211s_hdr *)(pdata + ETH_HLEN);
int v_ret;
v_ret = rtw_mesh_rx_data_validate_mctrl(padapter, prframe
, mctrl, mda, msa, &mctrl_len, &da, &sa);
if (v_ret != _SUCCESS)
goto move_to_next;
act = rtw_mesh_rx_msdu_act_check(prframe
, mda, msa, da, sa, mctrl, &fwd_frame, &b2u_list);
} else
#endif
{
da = pdata;
sa = pdata + ETH_ALEN;
}
if (!act)
goto move_to_next;
rtw_led_rx_control(padapter, da);
sub_pkt = rtw_os_alloc_msdu_pkt(prframe, da, sa
, pdata + ETH_HLEN + mctrl_len, nSubframe_Length - mctrl_len);
if (sub_pkt == NULL) {
if (act & RTW_RX_MSDU_ACT_INDICATE) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME %s rtw_os_alloc_msdu_pkt fail\n", __func__);
#endif
}
if (act & RTW_RX_MSDU_ACT_FORWARD) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s rtw_os_alloc_msdu_pkt fail\n", __func__);
#endif
recv_free_fwd_resource(padapter, fwd_frame, &b2u_list);
}
break;
}
#ifdef CONFIG_RTW_MESH
if (act & RTW_RX_MSDU_ACT_FORWARD) {
recv_fwd_pkt_hdl(padapter, sub_pkt, act, fwd_frame, &b2u_list);
if (!(act & RTW_RX_MSDU_ACT_INDICATE))
goto move_to_next;
}
#endif
if (rtw_recv_indicatepkt_check(prframe, rtw_os_pkt_data(sub_pkt), rtw_os_pkt_len(sub_pkt)) == _SUCCESS)
subframes[nr_subframes++] = sub_pkt;
else
rtw_os_pkt_free(sub_pkt);
move_to_next:
/* move the data point to data content */
pdata += ETH_HLEN;
a_len -= ETH_HLEN;
if (nr_subframes >= MAX_SUBFRAME_COUNT) {
RTW_WARN("ParseSubframe(): Too many Subframes! Packets dropped!\n");
break;
}
pdata += nSubframe_Length;
a_len -= nSubframe_Length;
if (a_len != 0) {
padding_len = 4 - ((nSubframe_Length + ETH_HLEN) & (4 - 1));
if (padding_len == 4)
padding_len = 0;
if (a_len < padding_len) {
RTW_INFO("ParseSubframe(): a_len < padding_len !\n");
break;
}
pdata += padding_len;
a_len -= padding_len;
}
}
for (i = 0; i < nr_subframes; i++) {
sub_pkt = subframes[i];
/* Indicat the packets to upper layer */
if (sub_pkt)
rtw_os_recv_indicate_pkt(padapter, sub_pkt, prframe);
}
prframe->u.hdr.len = 0;
rtw_free_recvframe(prframe, pfree_recv_queue);/* free this recv_frame */
return ret;
}
static int recv_process_mpdu(_adapter *padapter, union recv_frame *prframe)
{
_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
int ret;
if (pattrib->amsdu) {
ret = amsdu_to_msdu(padapter, prframe);
if (ret != _SUCCESS) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" amsdu_to_msdu fail\n"
, FUNC_ADPT_ARG(padapter));
#endif
rtw_free_recvframe(prframe, pfree_recv_queue);
goto exit;
}
} else {
int act = RTW_RX_MSDU_ACT_INDICATE;
struct xmit_frame *fwd_frame = NULL;
_list b2u_list;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter) && pattrib->mesh_ctrl_present) {
act = rtw_mesh_rx_msdu_act_check(prframe
, pattrib->mda, pattrib->msa
, pattrib->dst, pattrib->src
, (struct rtw_ieee80211s_hdr *)(get_recvframe_data(prframe) + pattrib->hdrlen + pattrib->iv_len)
, &fwd_frame, &b2u_list);
}
#endif
if (!act) {
rtw_free_recvframe(prframe, pfree_recv_queue);
ret = _FAIL;
goto exit;
}
rtw_led_rx_control(padapter, pattrib->dst);
ret = wlanhdr_to_ethhdr(prframe);
if (ret != _SUCCESS) {
if (act & RTW_RX_MSDU_ACT_INDICATE) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" wlanhdr_to_ethhdr: drop pkt\n"
, FUNC_ADPT_ARG(padapter));
#endif
}
if (act & RTW_RX_MSDU_ACT_FORWARD) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s wlanhdr_to_ethhdr fail\n", __func__);
#endif
recv_free_fwd_resource(padapter, fwd_frame, &b2u_list);
}
rtw_free_recvframe(prframe, pfree_recv_queue);
goto exit;
}
#ifdef CONFIG_RTW_MESH
if (act & RTW_RX_MSDU_ACT_FORWARD) {
recv_fwd_pkt_hdl(padapter, prframe->u.hdr.pkt, act, fwd_frame, &b2u_list);
if (!(act & RTW_RX_MSDU_ACT_INDICATE)) {
prframe->u.hdr.pkt = NULL;
rtw_free_recvframe(prframe, pfree_recv_queue);
goto exit;
}
}
#endif
if (!RTW_CANNOT_RUN(padapter)) {
ret = rtw_recv_indicatepkt_check(prframe
, get_recvframe_data(prframe), get_recvframe_len(prframe));
if (ret != _SUCCESS) {
rtw_free_recvframe(prframe, pfree_recv_queue);
goto exit;
}
/* indicate this recv_frame */
ret = rtw_recv_indicatepkt(padapter, prframe);
if (ret != _SUCCESS) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" rtw_recv_indicatepkt fail!\n"
, FUNC_ADPT_ARG(padapter));
#endif
goto exit;
}
} else {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" DS:%u SR:%u\n"
, FUNC_ADPT_ARG(padapter)
, rtw_is_drv_stopped(padapter)
, rtw_is_surprise_removed(padapter));
#endif
ret = _SUCCESS; /* don't count as packet drop */
rtw_free_recvframe(prframe, pfree_recv_queue);
}
}
exit:
return ret;
}
#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
static int check_indicate_seq(struct recv_reorder_ctrl *preorder_ctrl, u16 seq_num)
{
PADAPTER padapter = preorder_ctrl->padapter;
struct recv_priv *precvpriv = &padapter->recvpriv;
u8 wsize = preorder_ctrl->wsize_b;
u16 wend;
/* Rx Reorder initialize condition. */
if (preorder_ctrl->indicate_seq == 0xFFFF) {
preorder_ctrl->indicate_seq = seq_num;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_INIT indicate_seq:%d, seq_num:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
#endif
}
wend = (preorder_ctrl->indicate_seq + wsize - 1) & 0xFFF; /* % 4096; */
/* Drop out the packet which SeqNum is smaller than WinStart */
if (SN_LESS(seq_num, preorder_ctrl->indicate_seq)) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO(FUNC_ADPT_FMT" tid:%u indicate_seq:%d > seq_num:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
#endif
return _FALSE;
}
/*
* Sliding window manipulation. Conditions includes:
* 1. Incoming SeqNum is equal to WinStart =>Window shift 1
* 2. Incoming SeqNum is larger than the WinEnd => Window shift N
*/
if (SN_EQUAL(seq_num, preorder_ctrl->indicate_seq)) {
preorder_ctrl->indicate_seq = (preorder_ctrl->indicate_seq + 1) & 0xFFF;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_EQUAL indicate_seq:%d, seq_num:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
#endif
} else if (SN_LESS(wend, seq_num)) {
/* boundary situation, when seq_num cross 0xFFF */
if (seq_num >= (wsize - 1))
preorder_ctrl->indicate_seq = seq_num + 1 - wsize;
else
preorder_ctrl->indicate_seq = 0xFFF - (wsize - (seq_num + 1)) + 1;
precvpriv->dbg_rx_ampdu_window_shift_cnt++;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_LESS(wend, seq_num) indicate_seq:%d, seq_num:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, seq_num);
#endif
}
return _TRUE;
}
static int enqueue_reorder_recvframe(struct recv_reorder_ctrl *preorder_ctrl, union recv_frame *prframe)
{
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
_queue *ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
_list *phead, *plist;
union recv_frame *pnextrframe;
struct rx_pkt_attrib *pnextattrib;
/* DbgPrint("+enqueue_reorder_recvframe()\n"); */
/* _enter_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* _rtw_spinlock_ex(&ppending_recvframe_queue->lock); */
phead = get_list_head(ppending_recvframe_queue);
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
pnextrframe = LIST_CONTAINOR(plist, union recv_frame, u);
pnextattrib = &pnextrframe->u.hdr.attrib;
if (SN_LESS(pnextattrib->seq_num, pattrib->seq_num))
plist = get_next(plist);
else if (SN_EQUAL(pnextattrib->seq_num, pattrib->seq_num)) {
/* Duplicate entry is found!! Do not insert current entry. */
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
return _FALSE;
} else
break;
/* DbgPrint("enqueue_reorder_recvframe():while\n"); */
}
/* _enter_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* _rtw_spinlock_ex(&ppending_recvframe_queue->lock); */
rtw_list_delete(&(prframe->u.hdr.list));
rtw_list_insert_tail(&(prframe->u.hdr.list), plist);
/* _rtw_spinunlock_ex(&ppending_recvframe_queue->lock); */
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
return _TRUE;
}
static void recv_indicatepkts_pkt_loss_cnt(_adapter *padapter, u64 prev_seq, u64 current_seq)
{
struct recv_priv *precvpriv = &padapter->recvpriv;
if (current_seq < prev_seq) {
precvpriv->dbg_rx_ampdu_loss_count += (4096 + current_seq - prev_seq);
precvpriv->rx_drop += (4096 + current_seq - prev_seq);
} else {
precvpriv->dbg_rx_ampdu_loss_count += (current_seq - prev_seq);
precvpriv->rx_drop += (current_seq - prev_seq);
}
}
static int recv_indicatepkts_in_order(_adapter *padapter, struct recv_reorder_ctrl *preorder_ctrl, int bforced)
{
/* _irqL irql; */
_list *phead, *plist;
union recv_frame *prframe;
struct rx_pkt_attrib *pattrib;
/* u8 index = 0; */
int bPktInBuf = _FALSE;
struct recv_priv *precvpriv = &padapter->recvpriv;
_queue *ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate_in_oder);
/* DbgPrint("+recv_indicatepkts_in_order\n"); */
/* _enter_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* _rtw_spinlock_ex(&ppending_recvframe_queue->lock); */
phead = get_list_head(ppending_recvframe_queue);
plist = get_next(phead);
#if 0
/* Check if there is any other indication thread running. */
if (pTS->RxIndicateState == RXTS_INDICATE_PROCESSING)
return;
#endif
/* Handling some condition for forced indicate case. */
if (bforced == _TRUE) {
precvpriv->dbg_rx_ampdu_forced_indicate_count++;
if (rtw_is_list_empty(phead)) {
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* _rtw_spinunlock_ex(&ppending_recvframe_queue->lock); */
return _TRUE;
}
prframe = LIST_CONTAINOR(plist, union recv_frame, u);
pattrib = &prframe->u.hdr.attrib;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u FORCE indicate_seq:%d, seq_num:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pattrib->seq_num);
#endif
recv_indicatepkts_pkt_loss_cnt(padapter, preorder_ctrl->indicate_seq, pattrib->seq_num);
preorder_ctrl->indicate_seq = pattrib->seq_num;
}
/* Prepare indication list and indication. */
/* Check if there is any packet need indicate. */
while (!rtw_is_list_empty(phead)) {
prframe = LIST_CONTAINOR(plist, union recv_frame, u);
pattrib = &prframe->u.hdr.attrib;
if (!SN_LESS(preorder_ctrl->indicate_seq, pattrib->seq_num)) {
#if 0
/* This protect buffer from overflow. */
if (index >= REORDER_WIN_SIZE) {
RT_ASSERT(FALSE, ("IndicateRxReorderList(): Buffer overflow!!\n"));
bPktInBuf = TRUE;
break;
}
#endif
plist = get_next(plist);
rtw_list_delete(&(prframe->u.hdr.list));
if (SN_EQUAL(preorder_ctrl->indicate_seq, pattrib->seq_num)) {
preorder_ctrl->indicate_seq = (preorder_ctrl->indicate_seq + 1) & 0xFFF;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_EQUAL indicate_seq:%d, seq_num:%d\n"
, FUNC_ADPT_ARG(padapter), preorder_ctrl->tid, preorder_ctrl->indicate_seq, pattrib->seq_num);
#endif
}
#if 0
index++;
if (index == 1) {
/* Cancel previous pending timer. */
/* PlatformCancelTimer(Adapter, &pTS->RxPktPendingTimer); */
if (bforced != _TRUE) {
/* RTW_INFO("_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);\n"); */
_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
}
}
#endif
/* Set this as a lock to make sure that only one thread is indicating packet. */
/* pTS->RxIndicateState = RXTS_INDICATE_PROCESSING; */
/* Indicate packets */
/* RT_ASSERT((index<=REORDER_WIN_SIZE), ("RxReorderIndicatePacket(): Rx Reorder buffer full!!\n")); */
/* indicate this recv_frame */
/* DbgPrint("recv_indicatepkts_in_order, indicate_seq=%d, seq_num=%d\n", precvpriv->indicate_seq, pattrib->seq_num); */
if (recv_process_mpdu(padapter, prframe) != _SUCCESS)
precvpriv->dbg_rx_drop_count++;
/* Update local variables. */
bPktInBuf = _FALSE;
} else {
bPktInBuf = _TRUE;
break;
}
/* DbgPrint("recv_indicatepkts_in_order():while\n"); */
}
/* _rtw_spinunlock_ex(&ppending_recvframe_queue->lock); */
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
#if 0
/* Release the indication lock and set to new indication step. */
if (bPktInBuf) {
/* Set new pending timer. */
/* pTS->RxIndicateState = RXTS_INDICATE_REORDER; */
/* PlatformSetTimer(Adapter, &pTS->RxPktPendingTimer, pHTInfo->RxReorderPendingTime); */
_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
} else {
/* pTS->RxIndicateState = RXTS_INDICATE_IDLE; */
}
#endif
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* return _TRUE; */
return bPktInBuf;
}
static int recv_indicatepkt_reorder(_adapter *padapter, union recv_frame *prframe)
{
_irqL irql;
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
struct recv_reorder_ctrl *preorder_ctrl = prframe->u.hdr.preorder_ctrl;
_queue *ppending_recvframe_queue = preorder_ctrl ? &preorder_ctrl->pending_recvframe_queue : NULL;
struct recv_priv *precvpriv = &padapter->recvpriv;
if (!pattrib->qos || !preorder_ctrl || preorder_ctrl->enable == _FALSE)
goto _success_exit;
DBG_COUNTER(padapter->rx_logs.core_rx_post_indicate_reoder);
_enter_critical_bh(&ppending_recvframe_queue->lock, &irql);
if(rtw_test_and_clear_bit(RTW_RECV_ACK_OR_TIMEOUT, &preorder_ctrl->rec_abba_rsp_ack))
preorder_ctrl->indicate_seq = 0xFFFF;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ %s:preorder_ctrl->rec_abba_rsp_ack = %u,indicate_seq = %d\n"
, __func__
, preorder_ctrl->rec_abba_rsp_ack
, preorder_ctrl->indicate_seq);
#endif
/* s2. check if winstart_b(indicate_seq) needs to been updated */
if (!check_indicate_seq(preorder_ctrl, pattrib->seq_num)) {
precvpriv->dbg_rx_ampdu_drop_count++;
/* pHTInfo->RxReorderDropCounter++; */
/* ReturnRFDList(Adapter, pRfd); */
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* return _FAIL; */
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" check_indicate_seq fail\n"
, FUNC_ADPT_ARG(padapter));
#endif
#if 0
rtw_recv_indicatepkt(padapter, prframe);
_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
goto _success_exit;
#else
goto _err_exit;
#endif
}
/* s3. Insert all packet into Reorder Queue to maintain its ordering. */
if (!enqueue_reorder_recvframe(preorder_ctrl, prframe)) {
/* DbgPrint("recv_indicatepkt_reorder, enqueue_reorder_recvframe fail!\n"); */
/* _exit_critical_ex(&ppending_recvframe_queue->lock, &irql); */
/* return _FAIL; */
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" enqueue_reorder_recvframe fail\n"
, FUNC_ADPT_ARG(padapter));
#endif
goto _err_exit;
}
/* s4. */
/* Indication process. */
/* After Packet dropping and Sliding Window shifting as above, we can now just indicate the packets */
/* with the SeqNum smaller than latest WinStart and buffer other packets. */
/* */
/* For Rx Reorder condition: */
/* 1. All packets with SeqNum smaller than WinStart => Indicate */
/* 2. All packets with SeqNum larger than or equal to WinStart => Buffer it. */
/* */
/* recv_indicatepkts_in_order(padapter, preorder_ctrl, _TRUE); */
if (recv_indicatepkts_in_order(padapter, preorder_ctrl, _FALSE) == _TRUE) {
if (!preorder_ctrl->bReorderWaiting) {
preorder_ctrl->bReorderWaiting = _TRUE;
_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
}
_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
} else {
preorder_ctrl->bReorderWaiting = _FALSE;
_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
}
return RTW_RX_HANDLED;
_success_exit:
return _SUCCESS;
_err_exit:
_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
return _FAIL;
}
void rtw_reordering_ctrl_timeout_handler(void *pcontext)
{
_irqL irql;
struct recv_reorder_ctrl *preorder_ctrl = (struct recv_reorder_ctrl *)pcontext;
_adapter *padapter = preorder_ctrl->padapter;
_queue *ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
if (RTW_CANNOT_RUN(padapter))
return;
/* RTW_INFO("+rtw_reordering_ctrl_timeout_handler()=>\n"); */
_enter_critical_bh(&ppending_recvframe_queue->lock, &irql);
if (preorder_ctrl)
preorder_ctrl->bReorderWaiting = _FALSE;
if (recv_indicatepkts_in_order(padapter, preorder_ctrl, _TRUE) == _TRUE)
_set_timer(&preorder_ctrl->reordering_ctrl_timer, REORDER_WAIT_TIME);
_exit_critical_bh(&ppending_recvframe_queue->lock, &irql);
}
#endif /* defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL) */
static void recv_set_iseq_before_mpdu_process(union recv_frame *rframe, u16 seq_num, const char *caller)
{
#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
struct recv_reorder_ctrl *reorder_ctrl = rframe->u.hdr.preorder_ctrl;
if (reorder_ctrl) {
reorder_ctrl->indicate_seq = seq_num;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ %s("ADPT_FMT")-B tid:%u indicate_seq:%d, seq_num:%d\n"
, caller, ADPT_ARG(reorder_ctrl->padapter)
, reorder_ctrl->tid, reorder_ctrl->indicate_seq, seq_num);
#endif
}
#endif
}
static void recv_set_iseq_after_mpdu_process(union recv_frame *rframe, u16 seq_num, const char *caller)
{
#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
struct recv_reorder_ctrl *reorder_ctrl = rframe->u.hdr.preorder_ctrl;
if (reorder_ctrl) {
reorder_ctrl->indicate_seq = (reorder_ctrl->indicate_seq + 1) % 4096;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ %s("ADPT_FMT")-A tid:%u indicate_seq:%d, seq_num:%d\n"
, caller, ADPT_ARG(reorder_ctrl->padapter)
, reorder_ctrl->tid, reorder_ctrl->indicate_seq, seq_num);
#endif
}
#endif
}
#ifdef CONFIG_MP_INCLUDED
int validate_mp_recv_frame(_adapter *adapter, union recv_frame *precv_frame)
{
int ret = _SUCCESS;
u8 *ptr = precv_frame->u.hdr.rx_data;
u8 type, subtype;
struct mp_priv *pmppriv = &adapter->mppriv;
struct mp_tx *pmptx;
unsigned char *sa , *da, *bs;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
u32 i = 0;
u8 rtk_prefix[]={0x52, 0x65, 0x61, 0x6C, 0x4C, 0x6F, 0x76, 0x65, 0x54, 0x65, 0x6B};
u8 *prx_data;
pmptx = &pmppriv->tx;
if (pmppriv->mplink_brx == _FALSE) {
u8 bDumpRxPkt = 0;
type = GetFrameType(ptr);
subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
RTW_INFO("hdr len = %d iv_len=%d \n", pattrib->hdrlen , pattrib->iv_len);
prx_data = ptr + pattrib->hdrlen + pattrib->iv_len;
for (i = 0; i < precv_frame->u.hdr.len; i++) {
if (precv_frame->u.hdr.len < (11 + i))
break;
if (_rtw_memcmp(prx_data + i, (void *)&rtk_prefix, 11) == _FALSE) {
bDumpRxPkt = 0;
RTW_DBG("prx_data = %02X != rtk_prefix[%d] = %02X \n", *(prx_data + i), i , rtk_prefix[i]);
} else {
bDumpRxPkt = 1;
RTW_DBG("prx_data = %02X = rtk_prefix[%d] = %02X \n", *(prx_data + i), i , rtk_prefix[i]);
break;
}
}
if (bDumpRxPkt == 1) { /* dump all rx packets */
int i;
RTW_INFO("############ type:0x%02x subtype:0x%02x #################\n", type, subtype);
for (i = 0; i < precv_frame->u.hdr.len; i = i + 8)
RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:\n", *(ptr + i),
*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
RTW_INFO("#############################\n");
_rtw_memset(pmppriv->mplink_buf, '\0' , sizeof(pmppriv->mplink_buf));
_rtw_memcpy(pmppriv->mplink_buf, ptr, precv_frame->u.hdr.len);
pmppriv->mplink_rx_len = precv_frame->u.hdr.len;
pmppriv->mplink_brx =_TRUE;
}
}
if (pmppriv->bloopback) {
if (_rtw_memcmp(ptr + 24, pmptx->buf + 24, precv_frame->u.hdr.len - 24) == _FALSE) {
RTW_INFO("Compare payload content Fail !!!\n");
ret = _FAIL;
}
}
if (pmppriv->bSetRxBssid == _TRUE) {
sa = get_addr2_ptr(ptr);
da = GetAddr1Ptr(ptr);
bs = GetAddr3Ptr(ptr);
type = GetFrameType(ptr);
subtype = get_frame_sub_type(ptr); /* bit(7)~bit(2) */
if (_rtw_memcmp(bs, adapter->mppriv.network_macaddr, ETH_ALEN) == _FALSE)
ret = _FAIL;
RTW_DBG("############ type:0x%02x subtype:0x%02x #################\n", type, subtype);
RTW_DBG("A2 sa %02X:%02X:%02X:%02X:%02X:%02X \n", *(sa) , *(sa + 1), *(sa+ 2), *(sa + 3), *(sa + 4), *(sa + 5));
RTW_DBG("A1 da %02X:%02X:%02X:%02X:%02X:%02X \n", *(da) , *(da + 1), *(da+ 2), *(da + 3), *(da + 4), *(da + 5));
RTW_DBG("A3 bs %02X:%02X:%02X:%02X:%02X:%02X \n --------------------------\n", *(bs) , *(bs + 1), *(bs+ 2), *(bs + 3), *(bs + 4), *(bs + 5));
}
if (!adapter->mppriv.bmac_filter)
return ret;
if (_rtw_memcmp(get_addr2_ptr(ptr), adapter->mppriv.mac_filter, ETH_ALEN) == _FALSE)
ret = _FAIL;
return ret;
}
static sint MPwlanhdr_to_ethhdr(union recv_frame *precvframe)
{
sint rmv_len;
u16 eth_type, len;
u8 bsnaphdr;
u8 *psnap_type;
u8 mcastheadermac[] = {0x01, 0x00, 0x5e};
struct ieee80211_snap_hdr *psnap;
sint ret = _SUCCESS;
_adapter *adapter = precvframe->u.hdr.adapter;
u8 *ptr = get_recvframe_data(precvframe) ; /* point to frame_ctrl field */
struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
if (pattrib->encrypt)
recvframe_pull_tail(precvframe, pattrib->icv_len);
psnap = (struct ieee80211_snap_hdr *)(ptr + pattrib->hdrlen + pattrib->iv_len);
psnap_type = ptr + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
/* convert hdr + possible LLC headers into Ethernet header */
/* eth_type = (psnap_type[0] << 8) | psnap_type[1]; */
if ((_rtw_memcmp(psnap, rtw_rfc1042_header, SNAP_SIZE) &&
(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_IPX, 2) == _FALSE) &&
(_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_APPLETALK_AARP, 2) == _FALSE)) ||
/* eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) || */
_rtw_memcmp(psnap, rtw_bridge_tunnel_header, SNAP_SIZE)) {
/* remove RFC1042 or Bridge-Tunnel encapsulation and replace EtherType */
bsnaphdr = _TRUE;
} else {
/* Leave Ethernet header part of hdr and full payload */
bsnaphdr = _FALSE;
}
rmv_len = pattrib->hdrlen + pattrib->iv_len + (bsnaphdr ? SNAP_SIZE : 0);
len = precvframe->u.hdr.len - rmv_len;
_rtw_memcpy(ð_type, ptr + rmv_len, 2);
eth_type = ntohs((unsigned short)eth_type); /* pattrib->ether_type */
pattrib->eth_type = eth_type;
{
ptr = recvframe_pull(precvframe, (rmv_len - sizeof(struct ethhdr) + (bsnaphdr ? 2 : 0)));
}
_rtw_memcpy(ptr, pattrib->dst, ETH_ALEN);
_rtw_memcpy(ptr + ETH_ALEN, pattrib->src, ETH_ALEN);
if (!bsnaphdr) {
len = htons(len);
_rtw_memcpy(ptr + 12, &len, 2);
}
len = htons(pattrib->seq_num);
/* RTW_INFO("wlan seq = %d ,seq_num =%x\n",len,pattrib->seq_num); */
_rtw_memcpy(ptr + 12, &len, 2);
if (adapter->mppriv.bRTWSmbCfg == _TRUE) {
/* if(_rtw_memcmp(mcastheadermac, pattrib->dst, 3) == _TRUE) */ /* SimpleConfig Dest. */
/* _rtw_memcpy(ptr+ETH_ALEN, pattrib->bssid, ETH_ALEN); */
if (_rtw_memcmp(mcastheadermac, pattrib->bssid, 3) == _TRUE) /* SimpleConfig Dest. */
_rtw_memcpy(ptr, pattrib->bssid, ETH_ALEN);
}
return ret;
}
int mp_recv_frame(_adapter *padapter, union recv_frame *rframe)
{
int ret = _SUCCESS;
struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
#ifdef CONFIG_MP_INCLUDED
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mp_priv *pmppriv = &padapter->mppriv;
#endif /* CONFIG_MP_INCLUDED */
u8 type;
u8 *ptr = rframe->u.hdr.rx_data;
u8 *psa, *pda, *pbssid;
struct sta_info *psta = NULL;
DBG_COUNTER(padapter->rx_logs.core_rx_pre);
if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) { /* &&(padapter->mppriv.check_mp_pkt == 0)) */
if (pattrib->crc_err == 1)
padapter->mppriv.rx_crcerrpktcount++;
else {
if (_SUCCESS == validate_mp_recv_frame(padapter, rframe))
padapter->mppriv.rx_pktcount++;
else
padapter->mppriv.rx_pktcount_filter_out++;
}
if (pmppriv->rx_bindicatePkt == _FALSE) {
ret = _FAIL;
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
goto exit;
} else {
type = GetFrameType(ptr);
pattrib->to_fr_ds = get_tofr_ds(ptr);
pattrib->frag_num = GetFragNum(ptr);
pattrib->seq_num = GetSequence(ptr);
pattrib->pw_save = GetPwrMgt(ptr);
pattrib->mfrag = GetMFrag(ptr);
pattrib->mdata = GetMData(ptr);
pattrib->privacy = GetPrivacy(ptr);
pattrib->order = GetOrder(ptr);
if (type == WIFI_DATA_TYPE) {
pda = get_da(ptr);
psa = get_sa(ptr);
pbssid = get_hdr_bssid(ptr);
_rtw_memcpy(pattrib->dst, pda, ETH_ALEN);
_rtw_memcpy(pattrib->src, psa, ETH_ALEN);
_rtw_memcpy(pattrib->bssid, pbssid, ETH_ALEN);
switch (pattrib->to_fr_ds) {
case 0:
_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
ret = sta2sta_data_frame(padapter, rframe, &psta);
break;
case 1:
_rtw_memcpy(pattrib->ra, pda, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pbssid, ETH_ALEN);
ret = ap2sta_data_frame(padapter, rframe, &psta);
break;
case 2:
_rtw_memcpy(pattrib->ra, pbssid, ETH_ALEN);
_rtw_memcpy(pattrib->ta, psa, ETH_ALEN);
ret = sta2ap_data_frame(padapter, rframe, &psta);
break;
case 3:
_rtw_memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_addr2_ptr(ptr), ETH_ALEN);
ret = _FAIL;
break;
default:
ret = _FAIL;
break;
}
ret = MPwlanhdr_to_ethhdr(rframe);
if (ret != _SUCCESS) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" wlanhdr_to_ethhdr: drop pkt\n"
, FUNC_ADPT_ARG(padapter));
#endif
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
ret = _FAIL;
goto exit;
}
if (!RTW_CANNOT_RUN(padapter)) {
/* indicate this recv_frame */
ret = rtw_recv_indicatepkt(padapter, rframe);
if (ret != _SUCCESS) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" rtw_recv_indicatepkt fail!\n"
, FUNC_ADPT_ARG(padapter));
#endif
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
ret = _FAIL;
goto exit;
}
} else {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" bDriverStopped(%s) OR bSurpriseRemoved(%s)\n"
, FUNC_ADPT_ARG(padapter)
, rtw_is_drv_stopped(padapter) ? "True" : "False"
, rtw_is_surprise_removed(padapter) ? "True" : "False");
#endif
ret = _FAIL;
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
goto exit;
}
}
}
}
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
ret = _FAIL;
exit:
return ret;
}
#endif
static sint fill_radiotap_hdr(_adapter *padapter, union recv_frame *precvframe, u8 *buf)
{
#define CHAN2FREQ(a) ((a < 14) ? (2407+5*a) : (5000+5*a))
#if 0
#define RTW_RX_RADIOTAP_PRESENT (\
(1 << IEEE80211_RADIOTAP_TSFT) | \
(1 << IEEE80211_RADIOTAP_FLAGS) | \
(1 << IEEE80211_RADIOTAP_RATE) | \
(1 << IEEE80211_RADIOTAP_CHANNEL) | \
(0 << IEEE80211_RADIOTAP_FHSS) | \
(1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL) | \
(1 << IEEE80211_RADIOTAP_DBM_ANTNOISE) | \
(0 << IEEE80211_RADIOTAP_LOCK_QUALITY) | \
(0 << IEEE80211_RADIOTAP_TX_ATTENUATION) | \
(0 << IEEE80211_RADIOTAP_DB_TX_ATTENUATION) | \
(0 << IEEE80211_RADIOTAP_DBM_TX_POWER) | \
(1 << IEEE80211_RADIOTAP_ANTENNA) | \
(1 << IEEE80211_RADIOTAP_DB_ANTSIGNAL) | \
(0 << IEEE80211_RADIOTAP_DB_ANTNOISE) | \
(0 << IEEE80211_RADIOTAP_RX_FLAGS) | \
(0 << IEEE80211_RADIOTAP_TX_FLAGS) | \
(0 << IEEE80211_RADIOTAP_RTS_RETRIES) | \
(0 << IEEE80211_RADIOTAP_DATA_RETRIES) | \
(0 << IEEE80211_RADIOTAP_MCS) | \
(0 << IEEE80211_RADIOTAP_RADIOTAP_NAMESPACE)| \
(0 << IEEE80211_RADIOTAP_VENDOR_NAMESPACE) | \
(0 << IEEE80211_RADIOTAP_EXT) | \
0)
/* (0 << IEEE80211_RADIOTAP_AMPDU_STATUS) | \ */
/* (0 << IEEE80211_RADIOTAP_VHT) | \ */
#endif
#ifndef IEEE80211_RADIOTAP_RX_FLAGS
#define IEEE80211_RADIOTAP_RX_FLAGS 14
#endif
#ifndef IEEE80211_RADIOTAP_MCS
#define IEEE80211_RADIOTAP_MCS 19
#endif
#ifndef IEEE80211_RADIOTAP_VHT
#define IEEE80211_RADIOTAP_VHT 21
#endif
#ifndef IEEE80211_RADIOTAP_F_BADFCS
#define IEEE80211_RADIOTAP_F_BADFCS 0x40 /* bad FCS */
#endif
sint ret = _SUCCESS;
struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u16 tmp_16bit = 0;
u8 data_rate[] = {
2, 4, 11, 22, /* CCK */
12, 18, 24, 36, 48, 72, 93, 108, /* OFDM */
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, /* HT MCS index */
16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, /* VHT Nss 1 */
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, /* VHT Nss 2 */
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, /* VHT Nss 3 */
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, /* VHT Nss 4 */
};
_pkt *pskb = NULL;
struct ieee80211_radiotap_header *rtap_hdr = NULL;
u8 *ptr = NULL;
u8 hdr_buf[64] = {0};
u16 rt_len = 8;
/* create header */
rtap_hdr = (struct ieee80211_radiotap_header *)&hdr_buf[0];
rtap_hdr->it_version = PKTHDR_RADIOTAP_VERSION;
/* tsft */
if (pattrib->tsfl) {
u64 tmp_64bit;
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_TSFT);
tmp_64bit = cpu_to_le64(pattrib->tsfl);
memcpy(&hdr_buf[rt_len], &tmp_64bit, 8);
rt_len += 8;
}
/* flags */
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_FLAGS);
if (0)
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_CFP;
if (0)
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_SHORTPRE;
if ((pattrib->encrypt == 1) || (pattrib->encrypt == 5))
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_WEP;
if (pattrib->mfrag)
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_FRAG;
/* always append FCS */
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_FCS;
if (0)
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_DATAPAD;
if (pattrib->crc_err)
hdr_buf[rt_len] |= IEEE80211_RADIOTAP_F_BADFCS;
if (pattrib->sgi) {
/* Currently unspecified but used */
hdr_buf[rt_len] |= 0x80;
}
rt_len += 1;
/* rate */
if (pattrib->data_rate <= DESC_RATE54M) {
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_RATE);
if (pattrib->data_rate <= DESC_RATE11M) {
/* CCK */
hdr_buf[rt_len] = data_rate[pattrib->data_rate];
} else {
/* OFDM */
hdr_buf[rt_len] = data_rate[pattrib->data_rate];
}
}
rt_len += 1; /* force padding 1 byte for aligned */
/* channel */
tmp_16bit = 0;
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_CHANNEL);
tmp_16bit = CHAN2FREQ(rtw_get_oper_ch(padapter));
/*tmp_16bit = CHAN2FREQ(pHalData->current_channel);*/
memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
rt_len += 2;
/* channel flags */
tmp_16bit = 0;
if (pHalData->current_band_type == 0)
tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_2GHZ);
else
tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_5GHZ);
if (pattrib->data_rate <= DESC_RATE54M) {
if (pattrib->data_rate <= DESC_RATE11M) {
/* CCK */
tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_CCK);
} else {
/* OFDM */
tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_OFDM);
}
} else
tmp_16bit |= cpu_to_le16(IEEE80211_CHAN_DYN);
memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
rt_len += 2;
/* dBm Antenna Signal */
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_DBM_ANTSIGNAL);
hdr_buf[rt_len] = pattrib->phy_info.recv_signal_power;
rt_len += 1;
#if 0
/* dBm Antenna Noise */
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_DBM_ANTNOISE);
hdr_buf[rt_len] = 0;
rt_len += 1;
/* Signal Quality */
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_LOCK_QUALITY);
hdr_buf[rt_len] = pattrib->phy_info.signal_quality;
rt_len += 1;
#endif
/* Antenna */
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_ANTENNA);
hdr_buf[rt_len] = 0; /* pHalData->rf_type; */
rt_len += 1;
/* RX flags */
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_RX_FLAGS);
#if 0
tmp_16bit = cpu_to_le16(0);
memcpy(ptr, &tmp_16bit, 1);
#endif
rt_len += 2;
/* MCS information */
if (pattrib->data_rate >= DESC_RATEMCS0 && pattrib->data_rate <= DESC_RATEMCS31) {
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_MCS);
/* known, flag */
hdr_buf[rt_len] |= BIT1; /* MCS index known */
/* bandwidth */
hdr_buf[rt_len] |= BIT0;
hdr_buf[rt_len + 1] |= (pattrib->bw & 0x03);
/* guard interval */
hdr_buf[rt_len] |= BIT2;
hdr_buf[rt_len + 1] |= (pattrib->sgi & 0x01) << 2;
/* STBC */
hdr_buf[rt_len] |= BIT5;
hdr_buf[rt_len + 1] |= (pattrib->stbc & 0x03) << 5;
rt_len += 2;
/* MCS rate index */
hdr_buf[rt_len] = data_rate[pattrib->data_rate];
rt_len += 1;
}
/* VHT */
if (pattrib->data_rate >= DESC_RATEVHTSS1MCS0 && pattrib->data_rate <= DESC_RATEVHTSS4MCS9) {
rtap_hdr->it_present |= (1 << IEEE80211_RADIOTAP_VHT);
/* known 16 bit, flag 8 bit */
tmp_16bit = 0;
/* Bandwidth */
tmp_16bit |= BIT6;
/* Group ID */
tmp_16bit |= BIT7;
/* Partial AID */
tmp_16bit |= BIT8;
/* STBC */
tmp_16bit |= BIT0;
hdr_buf[rt_len + 2] |= (pattrib->stbc & 0x01);
/* Guard interval */
tmp_16bit |= BIT2;
hdr_buf[rt_len + 2] |= (pattrib->sgi & 0x01) << 2;
/* LDPC extra OFDM symbol */
tmp_16bit |= BIT4;
hdr_buf[rt_len + 2] |= (pattrib->ldpc & 0x01) << 4;
memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
rt_len += 3;
/* bandwidth */
if (pattrib->bw == 0)
hdr_buf[rt_len] |= 0;
else if (pattrib->bw == 1)
hdr_buf[rt_len] |= 1;
else if (pattrib->bw == 2)
hdr_buf[rt_len] |= 4;
else if (pattrib->bw == 3)
hdr_buf[rt_len] |= 11;
rt_len += 1;
/* mcs_nss */
if (pattrib->data_rate >= DESC_RATEVHTSS1MCS0 && pattrib->data_rate <= DESC_RATEVHTSS1MCS9) {
hdr_buf[rt_len] |= 1;
hdr_buf[rt_len] |= data_rate[pattrib->data_rate] << 4;
} else if (pattrib->data_rate >= DESC_RATEVHTSS2MCS0 && pattrib->data_rate <= DESC_RATEVHTSS2MCS9) {
hdr_buf[rt_len + 1] |= 2;
hdr_buf[rt_len + 1] |= data_rate[pattrib->data_rate] << 4;
} else if (pattrib->data_rate >= DESC_RATEVHTSS3MCS0 && pattrib->data_rate <= DESC_RATEVHTSS3MCS9) {
hdr_buf[rt_len + 2] |= 3;
hdr_buf[rt_len + 2] |= data_rate[pattrib->data_rate] << 4;
} else if (pattrib->data_rate >= DESC_RATEVHTSS4MCS0 && pattrib->data_rate <= DESC_RATEVHTSS4MCS9) {
hdr_buf[rt_len + 3] |= 4;
hdr_buf[rt_len + 3] |= data_rate[pattrib->data_rate] << 4;
}
rt_len += 4;
/* coding */
hdr_buf[rt_len] = 0;
rt_len += 1;
/* group_id */
hdr_buf[rt_len] = 0;
rt_len += 1;
/* partial_aid */
tmp_16bit = 0;
memcpy(&hdr_buf[rt_len], &tmp_16bit, 2);
rt_len += 2;
}
/* push to skb */
pskb = (_pkt *)buf;
if (skb_headroom(pskb) < rt_len) {
RTW_INFO("%s:%d %s headroom is too small.\n", __FILE__, __LINE__, __func__);
ret = _FAIL;
return ret;
}
ptr = skb_push(pskb, rt_len);
if (ptr) {
rtap_hdr->it_len = cpu_to_le16(rt_len);
rtap_hdr->it_present = cpu_to_le32(rtap_hdr->it_present);
memcpy(ptr, rtap_hdr, rt_len);
} else
ret = _FAIL;
return ret;
}
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
int recv_frame_monitor(_adapter *padapter, union recv_frame *rframe)
{
int ret = _SUCCESS;
_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
_pkt *pskb = NULL;
/* read skb information from recv frame */
pskb = rframe->u.hdr.pkt;
pskb->len = rframe->u.hdr.len;
pskb->data = rframe->u.hdr.rx_data;
skb_set_tail_pointer(pskb, rframe->u.hdr.len);
#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
/* fill radiotap header */
if (fill_radiotap_hdr(padapter, rframe, (u8 *)pskb) == _FAIL) {
ret = _FAIL;
rtw_free_recvframe(rframe, pfree_recv_queue); /* free this recv_frame */
goto exit;
}
#endif
/* write skb information to recv frame */
skb_reset_mac_header(pskb);
rframe->u.hdr.len = pskb->len;
rframe->u.hdr.rx_data = pskb->data;
rframe->u.hdr.rx_head = pskb->head;
rframe->u.hdr.rx_tail = skb_tail_pointer(pskb);
rframe->u.hdr.rx_end = skb_end_pointer(pskb);
if (!RTW_CANNOT_RUN(padapter)) {
/* indicate this recv_frame */
ret = rtw_recv_monitor(padapter, rframe);
if (ret != _SUCCESS) {
ret = _FAIL;
rtw_free_recvframe(rframe, pfree_recv_queue); /* free this recv_frame */
goto exit;
}
} else {
ret = _FAIL;
rtw_free_recvframe(rframe, pfree_recv_queue); /* free this recv_frame */
goto exit;
}
exit:
return ret;
}
#endif
int recv_func_prehandle(_adapter *padapter, union recv_frame *rframe)
{
int ret = _SUCCESS;
#ifdef DBG_RX_COUNTER_DUMP
struct rx_pkt_attrib *pattrib = &rframe->u.hdr.attrib;
#endif
_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
#ifdef DBG_RX_COUNTER_DUMP
if (padapter->dump_rx_cnt_mode & DUMP_DRV_RX_COUNTER) {
if (pattrib->crc_err == 1)
padapter->drv_rx_cnt_crcerror++;
else
padapter->drv_rx_cnt_ok++;
}
#endif
#ifdef CONFIG_MP_INCLUDED
if (padapter->registrypriv.mp_mode == 1 || padapter->mppriv.bRTWSmbCfg == _TRUE) {
mp_recv_frame(padapter, rframe);
ret = _FAIL;
goto exit;
} else
#endif
{
/* check the frame crtl field and decache */
ret = validate_recv_frame(padapter, rframe);
if (ret != _SUCCESS) {
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
goto exit;
}
}
exit:
return ret;
}
/*#define DBG_RX_BMC_FRAME*/
int recv_func_posthandle(_adapter *padapter, union recv_frame *prframe)
{
int ret = _SUCCESS;
union recv_frame *orig_prframe = prframe;
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
struct recv_priv *precvpriv = &padapter->recvpriv;
_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
#ifdef CONFIG_TDLS
u8 *psnap_type, *pcategory;
#endif /* CONFIG_TDLS */
DBG_COUNTER(padapter->rx_logs.core_rx_post);
prframe = decryptor(padapter, prframe);
if (prframe == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" decryptor: drop pkt\n"
, FUNC_ADPT_ARG(padapter));
#endif
ret = _FAIL;
DBG_COUNTER(padapter->rx_logs.core_rx_post_decrypt_err);
goto _recv_data_drop;
}
#ifdef DBG_RX_BMC_FRAME
if (IS_MCAST(pattrib->ra))
RTW_INFO("%s =>"ADPT_FMT" Rx BC/MC from "MAC_FMT"\n", __func__, ADPT_ARG(padapter), MAC_ARG(pattrib->ta));
#endif
#if 0
if (is_primary_adapter(padapter)) {
RTW_INFO("+++\n");
{
int i;
u8 *ptr = get_recvframe_data(prframe);
for (i = 0; i < 140; i = i + 8)
RTW_INFO("%02X:%02X:%02X:%02X:%02X:%02X:%02X:%02X:", *(ptr + i),
*(ptr + i + 1), *(ptr + i + 2) , *(ptr + i + 3) , *(ptr + i + 4), *(ptr + i + 5), *(ptr + i + 6), *(ptr + i + 7));
}
RTW_INFO("---\n");
}
#endif
#ifdef CONFIG_TDLS
/* check TDLS frame */
psnap_type = get_recvframe_data(orig_prframe) + pattrib->hdrlen + pattrib->iv_len + SNAP_SIZE;
pcategory = psnap_type + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
if ((_rtw_memcmp(psnap_type, SNAP_ETH_TYPE_TDLS, ETH_TYPE_LEN)) &&
((*pcategory == RTW_WLAN_CATEGORY_TDLS) || (*pcategory == RTW_WLAN_CATEGORY_P2P))) {
ret = OnTDLS(padapter, prframe);
if (ret == _FAIL)
goto _exit_recv_func;
}
#endif /* CONFIG_TDLS */
prframe = recvframe_chk_defrag(padapter, prframe);
if (prframe == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" recvframe_chk_defrag: drop pkt\n"
, FUNC_ADPT_ARG(padapter));
#endif
DBG_COUNTER(padapter->rx_logs.core_rx_post_defrag_err);
goto _recv_data_drop;
}
prframe = portctrl(padapter, prframe);
if (prframe == NULL) {
#ifdef DBG_RX_DROP_FRAME
RTW_INFO("DBG_RX_DROP_FRAME "FUNC_ADPT_FMT" portctrl: drop pkt\n"
, FUNC_ADPT_ARG(padapter));
#endif
ret = _FAIL;
DBG_COUNTER(padapter->rx_logs.core_rx_post_portctrl_err);
goto _recv_data_drop;
}
count_rx_stats(padapter, prframe, NULL);
#ifdef CONFIG_WAPI_SUPPORT
rtw_wapi_update_info(padapter, prframe);
#endif
#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
/* including perform A-MPDU Rx Ordering Buffer Control */
ret = recv_indicatepkt_reorder(padapter, prframe);
if (ret == _FAIL) {
rtw_free_recvframe(orig_prframe, pfree_recv_queue);
goto _recv_data_drop;
} else if (ret == RTW_RX_HANDLED) /* queued OR indicated in order */
goto _exit_recv_func;
#endif
recv_set_iseq_before_mpdu_process(prframe, pattrib->seq_num, __func__);
ret = recv_process_mpdu(padapter, prframe);
recv_set_iseq_after_mpdu_process(prframe, pattrib->seq_num, __func__);
if (ret == _FAIL)
goto _recv_data_drop;
_exit_recv_func:
return ret;
_recv_data_drop:
precvpriv->dbg_rx_drop_count++;
return ret;
}
int recv_func(_adapter *padapter, union recv_frame *rframe)
{
int ret;
struct rx_pkt_attrib *prxattrib = &rframe->u.hdr.attrib;
struct recv_priv *recvpriv = &padapter->recvpriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
u8 type;
u8 *ptr = rframe->u.hdr.rx_data;
#endif
if (check_fwstate(mlmepriv, WIFI_MONITOR_STATE)) {
/* monitor mode */
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
recv_frame_monitor(padapter, rframe);
#endif
ret = _SUCCESS;
goto exit;
} else
{}
#ifdef CONFIG_CUSTOMER_ALIBABA_GENERAL
type = GetFrameType(ptr);
if ((type == WIFI_DATA_TYPE)&& check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
struct wlan_network *cur_network = &(mlmepriv->cur_network);
if ( _rtw_memcmp(get_addr2_ptr(ptr), cur_network->network.MacAddress, ETH_ALEN)==0) {
recv_frame_monitor(padapter, rframe);
ret = _SUCCESS;
goto exit;
}
}
#endif
/* check if need to handle uc_swdec_pending_queue*/
if (check_fwstate(mlmepriv, WIFI_STATION_STATE) && psecuritypriv->busetkipkey) {
union recv_frame *pending_frame;
int cnt = 0;
while ((pending_frame = rtw_alloc_recvframe(&padapter->recvpriv.uc_swdec_pending_queue))) {
cnt++;
DBG_COUNTER(padapter->rx_logs.core_rx_dequeue);
recv_func_posthandle(padapter, pending_frame);
}
if (cnt)
RTW_INFO(FUNC_ADPT_FMT" dequeue %d from uc_swdec_pending_queue\n",
FUNC_ADPT_ARG(padapter), cnt);
}
DBG_COUNTER(padapter->rx_logs.core_rx);
ret = recv_func_prehandle(padapter, rframe);
if (ret == _SUCCESS) {
/* check if need to enqueue into uc_swdec_pending_queue*/
if (check_fwstate(mlmepriv, WIFI_STATION_STATE) &&
!IS_MCAST(prxattrib->ra) && prxattrib->encrypt > 0 &&
(prxattrib->bdecrypted == 0 || psecuritypriv->sw_decrypt == _TRUE) &&
psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPAPSK &&
!psecuritypriv->busetkipkey) {
DBG_COUNTER(padapter->rx_logs.core_rx_enqueue);
rtw_enqueue_recvframe(rframe, &padapter->recvpriv.uc_swdec_pending_queue);
/* RTW_INFO("%s: no key, enqueue uc_swdec_pending_queue\n", __func__); */
if (recvpriv->free_recvframe_cnt < NR_RECVFRAME / 4) {
/* to prevent from recvframe starvation, get recvframe from uc_swdec_pending_queue to free_recvframe_cnt */
rframe = rtw_alloc_recvframe(&padapter->recvpriv.uc_swdec_pending_queue);
if (rframe)
goto do_posthandle;
}
goto exit;
}
do_posthandle:
ret = recv_func_posthandle(padapter, rframe);
}
exit:
return ret;
}
s32 rtw_recv_entry(union recv_frame *precvframe)
{
_adapter *padapter;
struct recv_priv *precvpriv;
s32 ret = _SUCCESS;
padapter = precvframe->u.hdr.adapter;
precvpriv = &padapter->recvpriv;
ret = recv_func(padapter, precvframe);
if (ret == _FAIL) {
goto _recv_entry_drop;
}
precvpriv->rx_pkts++;
return ret;
_recv_entry_drop:
#ifdef CONFIG_MP_INCLUDED
if (padapter->registrypriv.mp_mode == 1)
padapter->mppriv.rx_pktloss = precvpriv->rx_drop;
#endif
return ret;
}
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
static void rtw_signal_stat_timer_hdl(void *ctx)
{
_adapter *adapter = (_adapter *)ctx;
struct recv_priv *recvpriv = &adapter->recvpriv;
u32 tmp_s, tmp_q;
u8 avg_signal_strength = 0;
u8 avg_signal_qual = 0;
u32 num_signal_strength = 0;
u32 num_signal_qual = 0;
u8 ratio_pre_stat = 0, ratio_curr_stat = 0, ratio_total = 0, ratio_profile = SIGNAL_STAT_CALC_PROFILE_0;
if (adapter->recvpriv.is_signal_dbg) {
/* update the user specific value, signal_strength_dbg, to signal_strength, rssi */
adapter->recvpriv.signal_strength = adapter->recvpriv.signal_strength_dbg;
adapter->recvpriv.rssi = (s8)translate_percentage_to_dbm((u8)adapter->recvpriv.signal_strength_dbg);
} else {
if (recvpriv->signal_strength_data.update_req == 0) { /* update_req is clear, means we got rx */
avg_signal_strength = recvpriv->signal_strength_data.avg_val;
num_signal_strength = recvpriv->signal_strength_data.total_num;
/* after avg_vals are accquired, we can re-stat the signal values */
recvpriv->signal_strength_data.update_req = 1;
}
if (recvpriv->signal_qual_data.update_req == 0) { /* update_req is clear, means we got rx */
avg_signal_qual = recvpriv->signal_qual_data.avg_val;
num_signal_qual = recvpriv->signal_qual_data.total_num;
/* after avg_vals are accquired, we can re-stat the signal values */
recvpriv->signal_qual_data.update_req = 1;
}
if (num_signal_strength == 0) {
if (rtw_get_on_cur_ch_time(adapter) == 0
|| rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) < 2 * adapter->mlmeextpriv.mlmext_info.bcn_interval
)
goto set_timer;
}
if (check_fwstate(&adapter->mlmepriv, _FW_UNDER_SURVEY) == _TRUE
|| check_fwstate(&adapter->mlmepriv, _FW_LINKED) == _FALSE
)
goto set_timer;
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(adapter, _FW_UNDER_SURVEY) == _TRUE)
goto set_timer;
#endif
if (RTW_SIGNAL_STATE_CALC_PROFILE < SIGNAL_STAT_CALC_PROFILE_MAX)
ratio_profile = RTW_SIGNAL_STATE_CALC_PROFILE;
ratio_pre_stat = signal_stat_calc_profile[ratio_profile][0];
ratio_curr_stat = signal_stat_calc_profile[ratio_profile][1];
ratio_total = ratio_pre_stat + ratio_curr_stat;
/* update value of signal_strength, rssi, signal_qual */
tmp_s = (ratio_curr_stat * avg_signal_strength + ratio_pre_stat * recvpriv->signal_strength);
if (tmp_s % ratio_total)
tmp_s = tmp_s / ratio_total + 1;
else
tmp_s = tmp_s / ratio_total;
if (tmp_s > 100)
tmp_s = 100;
tmp_q = (ratio_curr_stat * avg_signal_qual + ratio_pre_stat * recvpriv->signal_qual);
if (tmp_q % ratio_total)
tmp_q = tmp_q / ratio_total + 1;
else
tmp_q = tmp_q / ratio_total;
if (tmp_q > 100)
tmp_q = 100;
recvpriv->signal_strength = tmp_s;
recvpriv->rssi = (s8)translate_percentage_to_dbm(tmp_s);
recvpriv->signal_qual = tmp_q;
#if defined(DBG_RX_SIGNAL_DISPLAY_PROCESSING) && 1
RTW_INFO(FUNC_ADPT_FMT" signal_strength:%3u, rssi:%3d, signal_qual:%3u"
", num_signal_strength:%u, num_signal_qual:%u"
", on_cur_ch_ms:%d"
"\n"
, FUNC_ADPT_ARG(adapter)
, recvpriv->signal_strength
, recvpriv->rssi
, recvpriv->signal_qual
, num_signal_strength, num_signal_qual
, rtw_get_on_cur_ch_time(adapter) ? rtw_get_passing_time_ms(rtw_get_on_cur_ch_time(adapter)) : 0
);
#endif
}
set_timer:
rtw_set_signal_stat_timer(recvpriv);
}
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
static void rx_process_rssi(_adapter *padapter, union recv_frame *prframe)
{
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
struct signal_stat *signal_stat = &padapter->recvpriv.signal_strength_data;
#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
u32 last_rssi, tmp_val;
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
/* RTW_INFO("process_rssi=> pattrib->rssil(%d) signal_strength(%d)\n ",pattrib->recv_signal_power,pattrib->signal_strength); */
/* if(pRfd->Status.bPacketToSelf || pRfd->Status.bPacketBeacon) */
{
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
if (signal_stat->update_req) {
signal_stat->total_num = 0;
signal_stat->total_val = 0;
signal_stat->update_req = 0;
}
signal_stat->total_num++;
signal_stat->total_val += pattrib->phy_info.signal_strength;
signal_stat->avg_val = signal_stat->total_val / signal_stat->total_num;
#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
/* Adapter->RxStats.RssiCalculateCnt++; */ /* For antenna Test */
if (padapter->recvpriv.signal_strength_data.total_num++ >= PHY_RSSI_SLID_WIN_MAX) {
padapter->recvpriv.signal_strength_data.total_num = PHY_RSSI_SLID_WIN_MAX;
last_rssi = padapter->recvpriv.signal_strength_data.elements[padapter->recvpriv.signal_strength_data.index];
padapter->recvpriv.signal_strength_data.total_val -= last_rssi;
}
padapter->recvpriv.signal_strength_data.total_val += pattrib->phy_info.signal_strength;
padapter->recvpriv.signal_strength_data.elements[padapter->recvpriv.signal_strength_data.index++] = pattrib->phy_info.signal_strength;
if (padapter->recvpriv.signal_strength_data.index >= PHY_RSSI_SLID_WIN_MAX)
padapter->recvpriv.signal_strength_data.index = 0;
tmp_val = padapter->recvpriv.signal_strength_data.total_val / padapter->recvpriv.signal_strength_data.total_num;
if (padapter->recvpriv.is_signal_dbg) {
padapter->recvpriv.signal_strength = padapter->recvpriv.signal_strength_dbg;
padapter->recvpriv.rssi = (s8)translate_percentage_to_dbm(padapter->recvpriv.signal_strength_dbg);
} else {
padapter->recvpriv.signal_strength = tmp_val;
padapter->recvpriv.rssi = (s8)translate_percentage_to_dbm(tmp_val);
}
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
}
}
static void rx_process_link_qual(_adapter *padapter, union recv_frame *prframe)
{
struct rx_pkt_attrib *pattrib;
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
struct signal_stat *signal_stat;
#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
u32 last_evm = 0, tmpVal;
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
if (prframe == NULL || padapter == NULL)
return;
pattrib = &prframe->u.hdr.attrib;
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
signal_stat = &padapter->recvpriv.signal_qual_data;
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
/* RTW_INFO("process_link_qual=> pattrib->signal_qual(%d)\n ",pattrib->signal_qual); */
#ifdef CONFIG_NEW_SIGNAL_STAT_PROCESS
if (signal_stat->update_req) {
signal_stat->total_num = 0;
signal_stat->total_val = 0;
signal_stat->update_req = 0;
}
signal_stat->total_num++;
signal_stat->total_val += pattrib->phy_info.signal_quality;
signal_stat->avg_val = signal_stat->total_val / signal_stat->total_num;
#else /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
if (pattrib->phy_info.signal_quality != 0) {
/* */
/* 1. Record the general EVM to the sliding window. */
/* */
if (padapter->recvpriv.signal_qual_data.total_num++ >= PHY_LINKQUALITY_SLID_WIN_MAX) {
padapter->recvpriv.signal_qual_data.total_num = PHY_LINKQUALITY_SLID_WIN_MAX;
last_evm = padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index];
padapter->recvpriv.signal_qual_data.total_val -= last_evm;
}
padapter->recvpriv.signal_qual_data.total_val += pattrib->phy_info.signal_quality;
padapter->recvpriv.signal_qual_data.elements[padapter->recvpriv.signal_qual_data.index++] = pattrib->phy_info.signal_quality;
if (padapter->recvpriv.signal_qual_data.index >= PHY_LINKQUALITY_SLID_WIN_MAX)
padapter->recvpriv.signal_qual_data.index = 0;
/* <1> Showed on UI for user, in percentage. */
tmpVal = padapter->recvpriv.signal_qual_data.total_val / padapter->recvpriv.signal_qual_data.total_num;
padapter->recvpriv.signal_qual = (u8)tmpVal;
}
#endif /* CONFIG_NEW_SIGNAL_STAT_PROCESS */
}
void rx_process_phy_info(_adapter *padapter, union recv_frame *rframe)
{
/* Check RSSI */
rx_process_rssi(padapter, rframe);
/* Check PWDB */
/* process_PWDB(padapter, rframe); */
/* UpdateRxSignalStatistics8192C(Adapter, pRfd); */
/* Check EVM */
rx_process_link_qual(padapter, rframe);
rtw_store_phy_info(padapter, rframe);
}
void rx_query_phy_status(
union recv_frame *precvframe,
u8 *pphy_status)
{
PADAPTER padapter = precvframe->u.hdr.adapter;
struct rx_pkt_attrib *pattrib = &precvframe->u.hdr.attrib;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct phydm_phyinfo_struct *p_phy_info = &pattrib->phy_info;
u8 *wlanhdr;
struct phydm_perpkt_info_struct pkt_info;
u8 *ta, *ra;
u8 is_ra_bmc;
struct sta_priv *pstapriv;
struct sta_info *psta = NULL;
struct recv_priv *precvpriv = &padapter->recvpriv;
/* _irqL irqL; */
pkt_info.is_packet_match_bssid = _FALSE;
pkt_info.is_packet_to_self = _FALSE;
pkt_info.is_packet_beacon = _FALSE;
pkt_info.ppdu_cnt = pattrib->ppdu_cnt;
pkt_info.station_id = 0xFF;
wlanhdr = get_recvframe_data(precvframe);
ta = get_ta(wlanhdr);
ra = get_ra(wlanhdr);
is_ra_bmc = IS_MCAST(ra);
if (_rtw_memcmp(adapter_mac_addr(padapter), ta, ETH_ALEN) == _TRUE) {
static systime start_time = 0;
#if 0 /*For debug */
if (IsFrameTypeCtrl(wlanhdr)) {
RTW_INFO("-->Control frame: Y\n");
RTW_INFO("-->pkt_len: %d\n", pattrib->pkt_len);
RTW_INFO("-->Sub Type = 0x%X\n", get_frame_sub_type(wlanhdr));
}
/* Dump first 40 bytes of header */
int i = 0;
for (i = 0; i < 40; i++)
RTW_INFO("%d: %X\n", i, *((u8 *)wlanhdr + i));
RTW_INFO("\n");
#endif
if ((start_time == 0) || (rtw_get_passing_time_ms(start_time) > 5000)) {
RTW_PRINT("Warning!!! %s: Confilc mac addr!!\n", __func__);
start_time = rtw_get_current_time();
}
precvpriv->dbg_rx_conflic_mac_addr_cnt++;
} else {
pstapriv = &padapter->stapriv;
psta = rtw_get_stainfo(pstapriv, ta);
if (psta)
pkt_info.station_id = psta->cmn.mac_id;
}
pkt_info.is_packet_match_bssid = (!IsFrameTypeCtrl(wlanhdr))
&& (!pattrib->icv_err) && (!pattrib->crc_err)
&& ((!MLME_IS_MESH(padapter) && _rtw_memcmp(get_hdr_bssid(wlanhdr), get_bssid(&padapter->mlmepriv), ETH_ALEN))
|| (MLME_IS_MESH(padapter) && psta));
pkt_info.is_to_self = (!pattrib->icv_err) && (!pattrib->crc_err)
&& _rtw_memcmp(ra, adapter_mac_addr(padapter), ETH_ALEN);
pkt_info.is_packet_to_self = pkt_info.is_packet_match_bssid
&& _rtw_memcmp(ra, adapter_mac_addr(padapter), ETH_ALEN);
pkt_info.is_packet_beacon = pkt_info.is_packet_match_bssid
&& (get_frame_sub_type(wlanhdr) == WIFI_BEACON);
if (psta && IsFrameTypeData(wlanhdr)) {
if (is_ra_bmc)
psta->curr_rx_rate_bmc = pattrib->data_rate;
else
psta->curr_rx_rate = pattrib->data_rate;
}
pkt_info.data_rate = pattrib->data_rate;
odm_phy_status_query(&pHalData->odmpriv, p_phy_info, pphy_status, &pkt_info);
/* If bw is initial value, get from phy status */
if (pattrib->bw == CHANNEL_WIDTH_MAX)
pattrib->bw = p_phy_info->band_width;
{
precvframe->u.hdr.psta = NULL;
if (padapter->registrypriv.mp_mode != 1) {
if ((!MLME_IS_MESH(padapter) && pkt_info.is_packet_match_bssid)
|| (MLME_IS_MESH(padapter) && psta)) {
if (psta) {
precvframe->u.hdr.psta = psta;
rx_process_phy_info(padapter, precvframe);
}
} else if (pkt_info.is_packet_to_self || pkt_info.is_packet_beacon) {
if (psta)
precvframe->u.hdr.psta = psta;
rx_process_phy_info(padapter, precvframe);
}
} else {
#ifdef CONFIG_MP_INCLUDED
if (padapter->mppriv.brx_filter_beacon == _TRUE) {
if (pkt_info.is_packet_beacon) {
RTW_INFO("in MP Rx is_packet_beacon\n");
if (psta)
precvframe->u.hdr.psta = psta;
rx_process_phy_info(padapter, precvframe);
}
} else
#endif
{
if (psta)
precvframe->u.hdr.psta = psta;
rx_process_phy_info(padapter, precvframe);
}
}
}
rtw_odm_parse_rx_phy_status_chinfo(precvframe, pphy_status);
}
/*
* Increase and check if the continual_no_rx_packet of this @param pmlmepriv is larger than MAX_CONTINUAL_NORXPACKET_COUNT
* @return _TRUE:
* @return _FALSE:
*/
int rtw_inc_and_chk_continual_no_rx_packet(struct sta_info *sta, int tid_index)
{
int ret = _FALSE;
int value = ATOMIC_INC_RETURN(&sta->continual_no_rx_packet[tid_index]);
if (value >= MAX_CONTINUAL_NORXPACKET_COUNT)
ret = _TRUE;
return ret;
}
/*
* Set the continual_no_rx_packet of this @param pmlmepriv to 0
*/
void rtw_reset_continual_no_rx_packet(struct sta_info *sta, int tid_index)
{
ATOMIC_SET(&sta->continual_no_rx_packet[tid_index], 0);
}
u8 adapter_allow_bmc_data_rx(_adapter *adapter)
{
if (check_fwstate(&adapter->mlmepriv, WIFI_MONITOR_STATE | WIFI_MP_STATE) == _TRUE)
return 1;
if (MLME_IS_AP(adapter))
return 0;
if (rtw_linked_check(adapter) == _FALSE)
return 0;
return 1;
}
s32 pre_recv_entry(union recv_frame *precvframe, u8 *pphy_status)
{
s32 ret = _SUCCESS;
u8 *pbuf = precvframe->u.hdr.rx_data;
u8 *pda = get_ra(pbuf);
u8 ra_is_bmc = IS_MCAST(pda);
_adapter *primary_padapter = precvframe->u.hdr.adapter;
#ifdef CONFIG_CONCURRENT_MODE
_adapter *iface = NULL;
#ifdef CONFIG_MP_INCLUDED
if (rtw_mp_mode_check(primary_padapter))
goto bypass_concurrent_hdl;
#endif
if (ra_is_bmc == _FALSE) { /*unicast packets*/
iface = rtw_get_iface_by_macddr(primary_padapter , pda);
if (NULL == iface) {
#ifdef CONFIG_RTW_CFGVENDOR_RANDOM_MAC_OUI
if (_rtw_memcmp(pda, adapter_pno_mac_addr(primary_padapter),
ETH_ALEN) != _TRUE)
#endif
RTW_INFO("%s [WARN] Cannot find appropriate adapter - mac_addr : "MAC_FMT"\n", __func__, MAC_ARG(pda));
/*rtw_warn_on(1);*/
} else
precvframe->u.hdr.adapter = iface;
} else /* Handle BC/MC Packets */
rtw_mi_buddy_clone_bcmc_packet(primary_padapter, precvframe, pphy_status);
bypass_concurrent_hdl:
#endif /* CONFIG_CONCURRENT_MODE */
if (primary_padapter->registrypriv.mp_mode != 1) {
/* skip unnecessary bmc data frame for primary adapter */
if (ra_is_bmc == _TRUE && GetFrameType(pbuf) == WIFI_DATA_TYPE
&& !adapter_allow_bmc_data_rx(precvframe->u.hdr.adapter)
) {
rtw_free_recvframe(precvframe, &precvframe->u.hdr.adapter->recvpriv.free_recv_queue);
goto exit;
}
}
if (pphy_status)
rx_query_phy_status(precvframe, pphy_status);
ret = rtw_recv_entry(precvframe);
exit:
return ret;
}
#ifdef CONFIG_RECV_THREAD_MODE
thread_return rtw_recv_thread(thread_context context)
{
_adapter *adapter = (_adapter *)context;
struct recv_priv *recvpriv = &adapter->recvpriv;
s32 err = _SUCCESS;
#ifdef RTW_RECV_THREAD_HIGH_PRIORITY
#ifdef PLATFORM_LINUX
struct sched_param param = { .sched_priority = 1 };
sched_setscheduler(current, SCHED_FIFO, ¶m);
#endif /* PLATFORM_LINUX */
#endif /*RTW_RECV_THREAD_HIGH_PRIORITY*/
thread_enter("RTW_RECV_THREAD");
RTW_INFO(FUNC_ADPT_FMT" enter\n", FUNC_ADPT_ARG(adapter));
do {
err = _rtw_down_sema(&recvpriv->recv_sema);
if (_FAIL == err) {
RTW_ERR(FUNC_ADPT_FMT" down recv_sema fail!\n", FUNC_ADPT_ARG(adapter));
goto exit;
}
if (RTW_CANNOT_RUN(adapter)) {
RTW_DBG(FUNC_ADPT_FMT "- bDriverStopped(%s) bSurpriseRemoved(%s)\n",
FUNC_ADPT_ARG(adapter),
rtw_is_drv_stopped(adapter) ? "True" : "False",
rtw_is_surprise_removed(adapter) ? "True" : "False");
goto exit;
}
err = rtw_hal_recv_hdl(adapter);
if (err == RTW_RFRAME_UNAVAIL
|| err == RTW_RFRAME_PKT_UNAVAIL
) {
rtw_msleep_os(1);
_rtw_up_sema(&recvpriv->recv_sema);
}
flush_signals_thread();
} while (err != _FAIL);
exit:
RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(adapter));
rtw_thread_wait_stop();
return 0;
}
#endif /* CONFIG_RECV_THREAD_MODE */
#if DBG_RX_BH_TRACKING
void rx_bh_tk_set_stage(struct recv_priv *recv, u32 s)
{
recv->rx_bh_stage = s;
}
void rx_bh_tk_set_buf(struct recv_priv *recv, void *buf, void *data, u32 dlen)
{
if (recv->rx_bh_cbuf)
recv->rx_bh_lbuf = recv->rx_bh_cbuf;
recv->rx_bh_cbuf = buf;
if (buf) {
recv->rx_bh_cbuf_data = data;
recv->rx_bh_cbuf_dlen = dlen;
recv->rx_bh_buf_dq_cnt++;
} else {
recv->rx_bh_cbuf_data = NULL;
recv->rx_bh_cbuf_dlen = 0;
}
}
void rx_bh_tk_set_buf_pos(struct recv_priv *recv, void *pos)
{
if (recv->rx_bh_cbuf) {
recv->rx_bh_cbuf_pos = pos - recv->rx_bh_cbuf_data;
} else {
rtw_warn_on(1);
recv->rx_bh_cbuf_pos = 0;
}
}
void rx_bh_tk_set_frame(struct recv_priv *recv, void *frame)
{
recv->rx_bh_cframe = frame;
}
void dump_rx_bh_tk(void *sel, struct recv_priv *recv)
{
RTW_PRINT_SEL(sel, "[RXBHTK]s:%u, buf_dqc:%u, lbuf:%p, cbuf:%p, dlen:%u, pos:%u, cframe:%p\n"
, recv->rx_bh_stage
, recv->rx_bh_buf_dq_cnt
, recv->rx_bh_lbuf
, recv->rx_bh_cbuf
, recv->rx_bh_cbuf_dlen
, recv->rx_bh_cbuf_pos
, recv->rx_bh_cframe
);
}
#endif /* DBG_RX_BH_TRACKING */
================================================
FILE: core/rtw_rf.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_RF_C_
#include
#include
u8 center_ch_2g[CENTER_CH_2G_NUM] = {
/* G00 */1, 2,
/* G01 */3, 4, 5,
/* G02 */6, 7, 8,
/* G03 */9, 10, 11,
/* G04 */12, 13,
/* G05 */14
};
u8 center_ch_2g_40m[CENTER_CH_2G_40M_NUM] = {
3,
4,
5,
6,
7,
8,
9,
10,
11,
};
u8 op_chs_of_cch_2g_40m[CENTER_CH_2G_40M_NUM][2] = {
{1, 5}, /* 3 */
{2, 6}, /* 4 */
{3, 7}, /* 5 */
{4, 8}, /* 6 */
{5, 9}, /* 7 */
{6, 10}, /* 8 */
{7, 11}, /* 9 */
{8, 12}, /* 10 */
{9, 13}, /* 11 */
};
u8 center_ch_5g_all[CENTER_CH_5G_ALL_NUM] = {
/* G00 */36, 38, 40,
42,
/* G01 */44, 46, 48,
/* 50, */
/* G02 */52, 54, 56,
58,
/* G03 */60, 62, 64,
/* G04 */100, 102, 104,
106,
/* G05 */108, 110, 112,
/* 114, */
/* G06 */116, 118, 120,
122,
/* G07 */124, 126, 128,
/* G08 */132, 134, 136,
138,
/* G09 */140, 142, 144,
/* G10 */149, 151, 153,
155,
/* G11 */157, 159, 161,
/* 163, */
/* G12 */165, 167, 169,
171,
/* G13 */173, 175, 177
};
u8 center_ch_5g_20m[CENTER_CH_5G_20M_NUM] = {
/* G00 */36, 40,
/* G01 */44, 48,
/* G02 */52, 56,
/* G03 */60, 64,
/* G04 */100, 104,
/* G05 */108, 112,
/* G06 */116, 120,
/* G07 */124, 128,
/* G08 */132, 136,
/* G09 */140, 144,
/* G10 */149, 153,
/* G11 */157, 161,
/* G12 */165, 169,
/* G13 */173, 177
};
u8 center_ch_5g_40m[CENTER_CH_5G_40M_NUM] = {
/* G00 */38,
/* G01 */46,
/* G02 */54,
/* G03 */62,
/* G04 */102,
/* G05 */110,
/* G06 */118,
/* G07 */126,
/* G08 */134,
/* G09 */142,
/* G10 */151,
/* G11 */159,
/* G12 */167,
/* G13 */175
};
u8 center_ch_5g_20m_40m[CENTER_CH_5G_20M_NUM + CENTER_CH_5G_40M_NUM] = {
/* G00 */36, 38, 40,
/* G01 */44, 46, 48,
/* G02 */52, 54, 56,
/* G03 */60, 62, 64,
/* G04 */100, 102, 104,
/* G05 */108, 110, 112,
/* G06 */116, 118, 120,
/* G07 */124, 126, 128,
/* G08 */132, 134, 136,
/* G09 */140, 142, 144,
/* G10 */149, 151, 153,
/* G11 */157, 159, 161,
/* G12 */165, 167, 169,
/* G13 */173, 175, 177
};
u8 op_chs_of_cch_5g_40m[CENTER_CH_5G_40M_NUM][2] = {
{36, 40}, /* 38 */
{44, 48}, /* 46 */
{52, 56}, /* 54 */
{60, 64}, /* 62 */
{100, 104}, /* 102 */
{108, 112}, /* 110 */
{116, 120}, /* 118 */
{124, 128}, /* 126 */
{132, 136}, /* 134 */
{140, 144}, /* 142 */
{149, 153}, /* 151 */
{157, 161}, /* 159 */
{165, 169}, /* 167 */
{173, 177}, /* 175 */
};
u8 center_ch_5g_80m[CENTER_CH_5G_80M_NUM] = {
/* G00 ~ G01*/42,
/* G02 ~ G03*/58,
/* G04 ~ G05*/106,
/* G06 ~ G07*/122,
/* G08 ~ G09*/138,
/* G10 ~ G11*/155,
/* G12 ~ G13*/171
};
u8 op_chs_of_cch_5g_80m[CENTER_CH_5G_80M_NUM][4] = {
{36, 40, 44, 48}, /* 42 */
{52, 56, 60, 64}, /* 58 */
{100, 104, 108, 112}, /* 106 */
{116, 120, 124, 128}, /* 122 */
{132, 136, 140, 144}, /* 138 */
{149, 153, 157, 161}, /* 155 */
{165, 169, 173, 177}, /* 171 */
};
u8 center_ch_5g_160m[CENTER_CH_5G_160M_NUM] = {
/* G00 ~ G03*/50,
/* G04 ~ G07*/114,
/* G10 ~ G13*/163
};
u8 op_chs_of_cch_5g_160m[CENTER_CH_5G_160M_NUM][8] = {
{36, 40, 44, 48, 52, 56, 60, 64}, /* 50 */
{100, 104, 108, 112, 116, 120, 124, 128}, /* 114 */
{149, 153, 157, 161, 165, 169, 173, 177}, /* 163 */
};
struct center_chs_ent_t {
u8 ch_num;
u8 *chs;
};
struct center_chs_ent_t center_chs_2g_by_bw[] = {
{CENTER_CH_2G_NUM, center_ch_2g},
{CENTER_CH_2G_40M_NUM, center_ch_2g_40m},
};
struct center_chs_ent_t center_chs_5g_by_bw[] = {
{CENTER_CH_5G_20M_NUM, center_ch_5g_20m},
{CENTER_CH_5G_40M_NUM, center_ch_5g_40m},
{CENTER_CH_5G_80M_NUM, center_ch_5g_80m},
{CENTER_CH_5G_160M_NUM, center_ch_5g_160m},
};
/*
* Get center channel of smaller bandwidth by @param cch, @param bw, @param offset
* @cch: the given center channel
* @bw: the given bandwidth
* @offset: the given primary SC offset of the given bandwidth
*
* return center channel of smaller bandiwdth if valid, or 0
*/
u8 rtw_get_scch_by_cch_offset(u8 cch, u8 bw, u8 offset)
{
u8 t_cch = 0;
if (bw == CHANNEL_WIDTH_20) {
t_cch = cch;
goto exit;
}
if (offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
rtw_warn_on(1);
goto exit;
}
/* 2.4G, 40MHz */
if (cch >= 3 && cch <= 11 && bw == CHANNEL_WIDTH_40) {
t_cch = (offset == HAL_PRIME_CHNL_OFFSET_UPPER) ? cch + 2 : cch - 2;
goto exit;
}
/* 5G, 160MHz */
if (cch >= 50 && cch <= 163 && bw == CHANNEL_WIDTH_160) {
t_cch = (offset == HAL_PRIME_CHNL_OFFSET_UPPER) ? cch + 8 : cch - 8;
goto exit;
/* 5G, 80MHz */
} else if (cch >= 42 && cch <= 171 && bw == CHANNEL_WIDTH_80) {
t_cch = (offset == HAL_PRIME_CHNL_OFFSET_UPPER) ? cch + 4 : cch - 4;
goto exit;
/* 5G, 40MHz */
} else if (cch >= 38 && cch <= 175 && bw == CHANNEL_WIDTH_40) {
t_cch = (offset == HAL_PRIME_CHNL_OFFSET_UPPER) ? cch + 2 : cch - 2;
goto exit;
} else {
rtw_warn_on(1);
goto exit;
}
exit:
return t_cch;
}
struct op_chs_ent_t {
u8 ch_num;
u8 *chs;
};
struct op_chs_ent_t op_chs_of_cch_2g_by_bw[] = {
{1, center_ch_2g},
{2, (u8 *)op_chs_of_cch_2g_40m},
};
struct op_chs_ent_t op_chs_of_cch_5g_by_bw[] = {
{1, center_ch_5g_20m},
{2, (u8 *)op_chs_of_cch_5g_40m},
{4, (u8 *)op_chs_of_cch_5g_80m},
{8, (u8 *)op_chs_of_cch_5g_160m},
};
inline u8 center_chs_2g_num(u8 bw)
{
if (bw > CHANNEL_WIDTH_40)
return 0;
return center_chs_2g_by_bw[bw].ch_num;
}
inline u8 center_chs_2g(u8 bw, u8 id)
{
if (bw > CHANNEL_WIDTH_40)
return 0;
if (id >= center_chs_2g_num(bw))
return 0;
return center_chs_2g_by_bw[bw].chs[id];
}
inline u8 center_chs_5g_num(u8 bw)
{
if (bw > CHANNEL_WIDTH_80)
return 0;
return center_chs_5g_by_bw[bw].ch_num;
}
inline u8 center_chs_5g(u8 bw, u8 id)
{
if (bw > CHANNEL_WIDTH_80)
return 0;
if (id >= center_chs_5g_num(bw))
return 0;
return center_chs_5g_by_bw[bw].chs[id];
}
/*
* Get available op channels by @param cch, @param bw
* @cch: the given center channel
* @bw: the given bandwidth
* @op_chs: the pointer to return pointer of op channel array
* @op_ch_num: the pointer to return pointer of op channel number
*
* return valid (1) or not (0)
*/
u8 rtw_get_op_chs_by_cch_bw(u8 cch, u8 bw, u8 **op_chs, u8 *op_ch_num)
{
int i;
struct center_chs_ent_t *c_chs_ent = NULL;
struct op_chs_ent_t *op_chs_ent = NULL;
u8 valid = 1;
if (cch <= 14
&& bw >= CHANNEL_WIDTH_20 && bw <= CHANNEL_WIDTH_40
) {
c_chs_ent = ¢er_chs_2g_by_bw[bw];
op_chs_ent = &op_chs_of_cch_2g_by_bw[bw];
} else if (cch >= 36 && cch <= 177
&& bw >= CHANNEL_WIDTH_20 && bw <= CHANNEL_WIDTH_160
) {
c_chs_ent = ¢er_chs_5g_by_bw[bw];
op_chs_ent = &op_chs_of_cch_5g_by_bw[bw];
} else {
valid = 0;
goto exit;
}
for (i = 0; i < c_chs_ent->ch_num; i++)
if (cch == *(c_chs_ent->chs + i))
break;
if (i == c_chs_ent->ch_num) {
valid = 0;
goto exit;
}
*op_chs = op_chs_ent->chs + op_chs_ent->ch_num * i;
*op_ch_num = op_chs_ent->ch_num;
exit:
return valid;
}
u8 rtw_get_ch_group(u8 ch, u8 *group, u8 *cck_group)
{
BAND_TYPE band = BAND_MAX;
s8 gp = -1, cck_gp = -1;
if (ch <= 14) {
band = BAND_ON_2_4G;
if (1 <= ch && ch <= 2)
gp = 0;
else if (3 <= ch && ch <= 5)
gp = 1;
else if (6 <= ch && ch <= 8)
gp = 2;
else if (9 <= ch && ch <= 11)
gp = 3;
else if (12 <= ch && ch <= 14)
gp = 4;
else
band = BAND_MAX;
if (ch == 14)
cck_gp = 5;
else
cck_gp = gp;
} else {
band = BAND_ON_5G;
if (36 <= ch && ch <= 42)
gp = 0;
else if (44 <= ch && ch <= 48)
gp = 1;
else if (50 <= ch && ch <= 58)
gp = 2;
else if (60 <= ch && ch <= 64)
gp = 3;
else if (100 <= ch && ch <= 106)
gp = 4;
else if (108 <= ch && ch <= 114)
gp = 5;
else if (116 <= ch && ch <= 122)
gp = 6;
else if (124 <= ch && ch <= 130)
gp = 7;
else if (132 <= ch && ch <= 138)
gp = 8;
else if (140 <= ch && ch <= 144)
gp = 9;
else if (149 <= ch && ch <= 155)
gp = 10;
else if (157 <= ch && ch <= 161)
gp = 11;
else if (165 <= ch && ch <= 171)
gp = 12;
else if (173 <= ch && ch <= 177)
gp = 13;
else
band = BAND_MAX;
}
if (band == BAND_MAX
|| (band == BAND_ON_2_4G && cck_gp == -1)
|| gp == -1
) {
RTW_WARN("%s invalid channel:%u", __func__, ch);
rtw_warn_on(1);
goto exit;
}
if (group)
*group = gp;
if (cck_group && band == BAND_ON_2_4G)
*cck_group = cck_gp;
exit:
return band;
}
int rtw_ch2freq(int chan)
{
/* see 802.11 17.3.8.3.2 and Annex J
* there are overlapping channel numbers in 5GHz and 2GHz bands */
/*
* RTK: don't consider the overlapping channel numbers: 5G channel <= 14,
* because we don't support it. simply judge from channel number
*/
if (chan >= 1 && chan <= 14) {
if (chan == 14)
return 2484;
else if (chan < 14)
return 2407 + chan * 5;
} else if (chan >= 36 && chan <= 177)
return 5000 + chan * 5;
return 0; /* not supported */
}
int rtw_freq2ch(int freq)
{
/* see 802.11 17.3.8.3.2 and Annex J */
if (freq == 2484)
return 14;
else if (freq < 2484)
return (freq - 2407) / 5;
else if (freq >= 4910 && freq <= 4980)
return (freq - 4000) / 5;
else if (freq <= 45000) /* DMG band lower limit */
return (freq - 5000) / 5;
else if (freq >= 58320 && freq <= 64800)
return (freq - 56160) / 2160;
else
return 0;
}
bool rtw_chbw_to_freq_range(u8 ch, u8 bw, u8 offset, u32 *hi, u32 *lo)
{
u8 c_ch;
u32 freq;
u32 hi_ret = 0, lo_ret = 0;
bool valid = _FALSE;
if (hi)
*hi = 0;
if (lo)
*lo = 0;
c_ch = rtw_get_center_ch(ch, bw, offset);
freq = rtw_ch2freq(c_ch);
if (!freq) {
rtw_warn_on(1);
goto exit;
}
if (bw == CHANNEL_WIDTH_80) {
hi_ret = freq + 40;
lo_ret = freq - 40;
} else if (bw == CHANNEL_WIDTH_40) {
hi_ret = freq + 20;
lo_ret = freq - 20;
} else if (bw == CHANNEL_WIDTH_20) {
hi_ret = freq + 10;
lo_ret = freq - 10;
} else
rtw_warn_on(1);
if (hi)
*hi = hi_ret;
if (lo)
*lo = lo_ret;
valid = _TRUE;
exit:
return valid;
}
const char *const _ch_width_str[CHANNEL_WIDTH_MAX] = {
"20MHz",
"40MHz",
"80MHz",
"160MHz",
"80_80MHz",
"5MHz",
"10MHz",
};
const u8 _ch_width_to_bw_cap[CHANNEL_WIDTH_MAX] = {
BW_CAP_20M,
BW_CAP_40M,
BW_CAP_80M,
BW_CAP_160M,
BW_CAP_80_80M,
BW_CAP_5M,
BW_CAP_10M,
};
const char *const _band_str[] = {
"2.4G",
"5G",
"BOTH",
"BAND_MAX",
};
const u8 _band_to_band_cap[] = {
BAND_CAP_2G,
BAND_CAP_5G,
0,
0,
};
const u8 _rf_type_to_rf_tx_cnt[] = {
1, /*RF_1T1R*/
1, /*RF_1T2R*/
2, /*RF_2T2R*/
2, /*RF_2T3R*/
2, /*RF_2T4R*/
3, /*RF_3T3R*/
3, /*RF_3T4R*/
4, /*RF_4T4R*/
1, /*RF_TYPE_MAX*/
};
const u8 _rf_type_to_rf_rx_cnt[] = {
1, /*RF_1T1R*/
2, /*RF_1T2R*/
2, /*RF_2T2R*/
3, /*RF_2T3R*/
4, /*RF_2T4R*/
3, /*RF_3T3R*/
4, /*RF_3T4R*/
4, /*RF_4T4R*/
1, /*RF_TYPE_MAX*/
};
const char *const _regd_str[] = {
"NONE",
"FCC",
"MKK",
"ETSI",
"IC",
"KCC",
"ACMA",
"CHILE",
"MEXICO",
"WW",
};
#if CONFIG_TXPWR_LIMIT
void _dump_regd_exc_list(void *sel, struct rf_ctl_t *rfctl)
{
struct regd_exc_ent *ent;
_list *cur, *head;
RTW_PRINT_SEL(sel, "regd_exc_num:%u\n", rfctl->regd_exc_num);
if (!rfctl->regd_exc_num)
goto exit;
RTW_PRINT_SEL(sel, "%-7s %-6s %-9s\n", "country", "domain", "regd_name");
head = &rfctl->reg_exc_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
u8 has_country;
ent = LIST_CONTAINOR(cur, struct regd_exc_ent, list);
cur = get_next(cur);
has_country = (ent->country[0] == '\0' && ent->country[1] == '\0') ? 0 : 1;
RTW_PRINT_SEL(sel, " %c%c 0x%02x %s\n"
, has_country ? ent->country[0] : '0'
, has_country ? ent->country[1] : '0'
, ent->domain
, ent->regd_name
);
}
exit:
return;
}
inline void dump_regd_exc_list(void *sel, struct rf_ctl_t *rfctl)
{
_irqL irqL;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
_dump_regd_exc_list(sel, rfctl);
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
}
void rtw_regd_exc_add_with_nlen(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name, u32 nlen)
{
struct regd_exc_ent *ent;
_irqL irqL;
if (!regd_name || !nlen) {
rtw_warn_on(1);
goto exit;
}
ent = (struct regd_exc_ent *)rtw_zmalloc(sizeof(struct regd_exc_ent) + nlen + 1);
if (!ent)
goto exit;
_rtw_init_listhead(&ent->list);
if (country)
_rtw_memcpy(ent->country, country, 2);
ent->domain = domain;
_rtw_memcpy(ent->regd_name, regd_name, nlen);
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
rtw_list_insert_tail(&ent->list, &rfctl->reg_exc_list);
rfctl->regd_exc_num++;
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
exit:
return;
}
inline void rtw_regd_exc_add(struct rf_ctl_t *rfctl, const char *country, u8 domain, const char *regd_name)
{
rtw_regd_exc_add_with_nlen(rfctl, country, domain, regd_name, strlen(regd_name));
}
struct regd_exc_ent *_rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain)
{
struct regd_exc_ent *ent;
_list *cur, *head;
u8 match = 0;
head = &rfctl->reg_exc_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
u8 has_country;
ent = LIST_CONTAINOR(cur, struct regd_exc_ent, list);
cur = get_next(cur);
has_country = (ent->country[0] == '\0' && ent->country[1] == '\0') ? 0 : 1;
/* entry has country condition to match */
if (has_country) {
if (!country)
continue;
if (ent->country[0] != country[0]
|| ent->country[1] != country[1])
continue;
}
/* entry has domain condition to match */
if (ent->domain != 0xFF) {
if (domain == 0xFF)
continue;
if (ent->domain != domain)
continue;
}
match = 1;
break;
}
if (match)
return ent;
else
return NULL;
}
inline struct regd_exc_ent *rtw_regd_exc_search(struct rf_ctl_t *rfctl, const char *country, u8 domain)
{
struct regd_exc_ent *ent;
_irqL irqL;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
ent = _rtw_regd_exc_search(rfctl, country, domain);
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
return ent;
}
void rtw_regd_exc_list_free(struct rf_ctl_t *rfctl)
{
struct regd_exc_ent *ent;
_irqL irqL;
_list *cur, *head;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
head = &rfctl->reg_exc_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct regd_exc_ent, list);
cur = get_next(cur);
rtw_list_delete(&ent->list);
rtw_mfree((u8 *)ent, sizeof(struct regd_exc_ent) + strlen(ent->regd_name) + 1);
}
rfctl->regd_exc_num = 0;
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
}
void dump_txpwr_lmt(void *sel, _adapter *adapter)
{
#define TMP_STR_LEN 16
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
_irqL irqL;
char fmt[16];
char tmp_str[TMP_STR_LEN];
s8 *lmt_idx = NULL;
int bw, band, ch_num, tlrs, ntx_idx, rs, i, path;
u8 ch, n, rfpath_num;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
_dump_regd_exc_list(sel, rfctl);
RTW_PRINT_SEL(sel, "\n");
if (!rfctl->txpwr_regd_num)
goto release_lock;
lmt_idx = rtw_malloc(sizeof(s8) * RF_PATH_MAX * rfctl->txpwr_regd_num);
if (!lmt_idx) {
RTW_ERR("%s alloc fail\n", __func__);
goto release_lock;
}
RTW_PRINT_SEL(sel, "txpwr_lmt_2g_cck_ofdm_state:0x%02x\n", rfctl->txpwr_lmt_2g_cck_ofdm_state);
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (IS_HARDWARE_TYPE_JAGUAR_ALL(adapter)) {
RTW_PRINT_SEL(sel, "txpwr_lmt_5g_cck_ofdm_state:0x%02x\n", rfctl->txpwr_lmt_5g_cck_ofdm_state);
RTW_PRINT_SEL(sel, "txpwr_lmt_5g_20_40_ref:0x%02x\n", rfctl->txpwr_lmt_5g_20_40_ref);
}
#endif
RTW_PRINT_SEL(sel, "\n");
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
rfpath_num = (band == BAND_ON_2_4G ? hal_spec->rfpath_num_2g : hal_spec->rfpath_num_5g);
for (bw = 0; bw < MAX_5G_BANDWIDTH_NUM; bw++) {
if (bw >= CHANNEL_WIDTH_160)
break;
if (band == BAND_ON_2_4G && bw >= CHANNEL_WIDTH_80)
break;
if (band == BAND_ON_2_4G)
ch_num = CENTER_CH_2G_NUM;
else
ch_num = center_chs_5g_num(bw);
if (ch_num == 0) {
rtw_warn_on(1);
break;
}
for (tlrs = TXPWR_LMT_RS_CCK; tlrs < TXPWR_LMT_RS_NUM; tlrs++) {
if (band == BAND_ON_2_4G && tlrs == TXPWR_LMT_RS_VHT)
continue;
if (band == BAND_ON_5G && tlrs == TXPWR_LMT_RS_CCK)
continue;
if (bw > CHANNEL_WIDTH_20 && (tlrs == TXPWR_LMT_RS_CCK || tlrs == TXPWR_LMT_RS_OFDM))
continue;
if (bw > CHANNEL_WIDTH_40 && tlrs == TXPWR_LMT_RS_HT)
continue;
if (tlrs == TXPWR_LMT_RS_VHT && !IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
continue;
for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
struct txpwr_lmt_ent *ent;
_list *cur, *head;
if (ntx_idx >= hal_spec->tx_nss_num)
continue;
/* bypass CCK multi-TX is not defined */
if (tlrs == TXPWR_LMT_RS_CCK && ntx_idx > RF_1TX) {
if (band == BAND_ON_2_4G
&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_CCK_1T << ntx_idx)))
continue;
}
/* bypass OFDM multi-TX is not defined */
if (tlrs == TXPWR_LMT_RS_OFDM && ntx_idx > RF_1TX) {
if (band == BAND_ON_2_4G
&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
continue;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (band == BAND_ON_5G
&& !(rfctl->txpwr_lmt_5g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
continue;
#endif
}
/* bypass 5G 20M, 40M pure reference */
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (band == BAND_ON_5G && (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40)) {
if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_HT_FROM_VHT) {
if (tlrs == TXPWR_LMT_RS_HT)
continue;
} else if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_VHT_FROM_HT) {
if (tlrs == TXPWR_LMT_RS_VHT && bw <= CHANNEL_WIDTH_40)
continue;
}
}
#endif
/* choose n-SS mapping rate section to get lmt diff value */
if (tlrs == TXPWR_LMT_RS_CCK)
rs = CCK;
else if (tlrs == TXPWR_LMT_RS_OFDM)
rs = OFDM;
else if (tlrs == TXPWR_LMT_RS_HT)
rs = HT_1SS + ntx_idx;
else if (tlrs == TXPWR_LMT_RS_VHT)
rs = VHT_1SS + ntx_idx;
else {
RTW_ERR("%s invalid tlrs %u\n", __func__, tlrs);
continue;
}
RTW_PRINT_SEL(sel, "[%s][%s][%s][%uT]\n"
, band_str(band)
, ch_width_str(bw)
, txpwr_lmt_rs_str(tlrs)
, ntx_idx + 1
);
/* header for limit in db */
RTW_PRINT_SEL(sel, "%3s ", "ch");
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
sprintf(fmt, "%%%zus%%s ", strlen(ent->regd_name) >= 6 ? 1 : 6 - strlen(ent->regd_name));
snprintf(tmp_str, TMP_STR_LEN, fmt
, strcmp(ent->regd_name, rfctl->regd_name) == 0 ? "*" : ""
, ent->regd_name);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
}
sprintf(fmt, "%%%zus%%s ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? 1 : 6 - strlen(regd_str(TXPWR_LMT_WW)));
snprintf(tmp_str, TMP_STR_LEN, fmt
, strcmp(rfctl->regd_name, regd_str(TXPWR_LMT_WW)) == 0 ? "*" : ""
, regd_str(TXPWR_LMT_WW));
_RTW_PRINT_SEL(sel, "%s", tmp_str);
/* header for limit offset */
for (path = 0; path < RF_PATH_MAX; path++) {
if (path >= rfpath_num)
break;
_RTW_PRINT_SEL(sel, "|");
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
_RTW_PRINT_SEL(sel, "%3c "
, strcmp(ent->regd_name, rfctl->regd_name) == 0 ? rf_path_char(path) : ' ');
}
_RTW_PRINT_SEL(sel, "%3c "
, strcmp(rfctl->regd_name, regd_str(TXPWR_LMT_WW)) == 0 ? rf_path_char(path) : ' ');
}
_RTW_PRINT_SEL(sel, "\n");
for (n = 0; n < ch_num; n++) {
s8 lmt;
s8 lmt_offset;
u8 base;
if (band == BAND_ON_2_4G)
ch = n + 1;
else
ch = center_chs_5g(bw, n);
if (ch == 0) {
rtw_warn_on(1);
break;
}
/* dump limit in db */
RTW_PRINT_SEL(sel, "%3u ", ch);
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
lmt = phy_get_txpwr_lmt_abs(adapter, ent->regd_name, band, bw, tlrs, ntx_idx, ch, 0);
if (lmt == hal_spec->txgi_max) {
sprintf(fmt, "%%%zus ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) + 1 : 6);
snprintf(tmp_str, TMP_STR_LEN, fmt, "NA");
_RTW_PRINT_SEL(sel, "%s", tmp_str);
} else if (lmt > -hal_spec->txgi_pdbm && lmt < 0) { /* -0.xx */
sprintf(fmt, "%%%zus-0.%%d ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) - 4 : 1);
snprintf(tmp_str, TMP_STR_LEN, fmt, "", (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
} else if (lmt % hal_spec->txgi_pdbm) { /* d.xx */
sprintf(fmt, "%%%zud.%%d ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) - 2 : 3);
snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm, (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
} else { /* d */
sprintf(fmt, "%%%zud ", strlen(ent->regd_name) >= 6 ? strlen(ent->regd_name) + 1 : 6);
snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
}
}
lmt = phy_get_txpwr_lmt_abs(adapter, regd_str(TXPWR_LMT_WW), band, bw, tlrs, ntx_idx, ch, 0);
if (lmt == hal_spec->txgi_max) {
sprintf(fmt, "%%%zus ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 6);
snprintf(tmp_str, TMP_STR_LEN, fmt, "NA");
_RTW_PRINT_SEL(sel, "%s", tmp_str);
} else if (lmt > -hal_spec->txgi_pdbm && lmt < 0) { /* -0.xx */
sprintf(fmt, "%%%zus-0.%%d ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) - 4 : 1);
snprintf(tmp_str, TMP_STR_LEN, fmt, "", (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
} else if (lmt % hal_spec->txgi_pdbm) { /* d.xx */
sprintf(fmt, "%%%zud.%%d ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) - 2 : 3);
snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm, (rtw_abs(lmt) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
} else { /* d */
sprintf(fmt, "%%%zud ", strlen(regd_str(TXPWR_LMT_WW)) >= 6 ? strlen(regd_str(TXPWR_LMT_WW)) + 1 : 6);
snprintf(tmp_str, TMP_STR_LEN, fmt, lmt / hal_spec->txgi_pdbm);
_RTW_PRINT_SEL(sel, "%s", tmp_str);
}
/* dump limit offset of each path */
for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
if (path >= rfpath_num)
break;
base = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
_RTW_PRINT_SEL(sel, "|");
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
i = 0;
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
lmt_offset = phy_get_txpwr_lmt(adapter, ent->regd_name, band, bw, path, rs, ntx_idx, ch, 0);
if (lmt_offset == hal_spec->txgi_max) {
*(lmt_idx + i * RF_PATH_MAX + path) = hal_spec->txgi_max;
_RTW_PRINT_SEL(sel, "%3s ", "NA");
} else {
*(lmt_idx + i * RF_PATH_MAX + path) = lmt_offset + base;
_RTW_PRINT_SEL(sel, "%3d ", lmt_offset);
}
i++;
}
lmt_offset = phy_get_txpwr_lmt(adapter, regd_str(TXPWR_LMT_WW), band, bw, path, rs, ntx_idx, ch, 0);
if (lmt_offset == hal_spec->txgi_max)
_RTW_PRINT_SEL(sel, "%3s ", "NA");
else
_RTW_PRINT_SEL(sel, "%3d ", lmt_offset);
}
/* compare limit_idx of each path, print 'x' when mismatch */
if (rfpath_num > 1) {
for (i = 0; i < rfctl->txpwr_regd_num; i++) {
for (path = 0; path < RF_PATH_MAX; path++) {
if (path >= rfpath_num)
break;
if (*(lmt_idx + i * RF_PATH_MAX + path) != *(lmt_idx + i * RF_PATH_MAX + ((path + 1) % rfpath_num)))
break;
}
if (path >= rfpath_num)
_RTW_PRINT_SEL(sel, " ");
else
_RTW_PRINT_SEL(sel, "x");
}
}
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
}
} /* loop for rate sections */
} /* loop for bandwidths */
} /* loop for bands */
if (lmt_idx)
rtw_mfree(lmt_idx, sizeof(s8) * RF_PATH_MAX * rfctl->txpwr_regd_num);
release_lock:
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
}
/* search matcing first, if not found, alloc one */
void rtw_txpwr_lmt_add_with_nlen(struct rf_ctl_t *rfctl, const char *regd_name, u32 nlen
, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(dvobj_get_primary_adapter(rfctl_to_dvobj(rfctl)));
struct txpwr_lmt_ent *ent;
_irqL irqL;
_list *cur, *head;
s8 pre_lmt;
if (!regd_name || !nlen) {
rtw_warn_on(1);
goto exit;
}
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
/* search for existed entry */
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
if (strlen(ent->regd_name) == nlen
&& _rtw_memcmp(ent->regd_name, regd_name, nlen) == _TRUE)
goto chk_lmt_val;
}
/* alloc new one */
ent = (struct txpwr_lmt_ent *)rtw_zvmalloc(sizeof(struct txpwr_lmt_ent) + nlen + 1);
if (!ent)
goto release_lock;
_rtw_init_listhead(&ent->list);
_rtw_memcpy(ent->regd_name, regd_name, nlen);
{
u8 j, k, l, m;
for (j = 0; j < MAX_2_4G_BANDWIDTH_NUM; ++j)
for (k = 0; k < TXPWR_LMT_RS_NUM_2G; ++k)
for (m = 0; m < CENTER_CH_2G_NUM; ++m)
for (l = 0; l < MAX_TX_COUNT; ++l)
ent->lmt_2g[j][k][m][l] = hal_spec->txgi_max;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
for (j = 0; j < MAX_5G_BANDWIDTH_NUM; ++j)
for (k = 0; k < TXPWR_LMT_RS_NUM_5G; ++k)
for (m = 0; m < CENTER_CH_5G_ALL_NUM; ++m)
for (l = 0; l < MAX_TX_COUNT; ++l)
ent->lmt_5g[j][k][m][l] = hal_spec->txgi_max;
#endif
}
rtw_list_insert_tail(&ent->list, &rfctl->txpwr_lmt_list);
rfctl->txpwr_regd_num++;
chk_lmt_val:
if (band == BAND_ON_2_4G)
pre_lmt = ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx];
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else if (band == BAND_ON_5G)
pre_lmt = ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx];
#endif
else
goto release_lock;
if (pre_lmt != hal_spec->txgi_max)
RTW_PRINT("duplicate txpwr_lmt for [%s][%s][%s][%s][%uT][%d]\n"
, regd_name, band_str(band), ch_width_str(bw), txpwr_lmt_rs_str(tlrs), ntx_idx + 1
, band == BAND_ON_2_4G ? ch_idx + 1 : center_ch_5g_all[ch_idx]);
lmt = rtw_min(pre_lmt, lmt);
if (band == BAND_ON_2_4G)
ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx] = lmt;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else if (band == BAND_ON_5G)
ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx] = lmt;
#endif
if (0)
RTW_PRINT("%s, %4s, %6s, %7s, %uT, ch%3d = %d\n"
, regd_name, band_str(band), ch_width_str(bw), txpwr_lmt_rs_str(tlrs), ntx_idx + 1
, band == BAND_ON_2_4G ? ch_idx + 1 : center_ch_5g_all[ch_idx]
, lmt);
release_lock:
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
exit:
return;
}
inline void rtw_txpwr_lmt_add(struct rf_ctl_t *rfctl, const char *regd_name
, u8 band, u8 bw, u8 tlrs, u8 ntx_idx, u8 ch_idx, s8 lmt)
{
rtw_txpwr_lmt_add_with_nlen(rfctl, regd_name, strlen(regd_name)
, band, bw, tlrs, ntx_idx, ch_idx, lmt);
}
struct txpwr_lmt_ent *_rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name)
{
struct txpwr_lmt_ent *ent;
_list *cur, *head;
u8 found = 0;
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
if (strcmp(ent->regd_name, regd_name) == 0) {
found = 1;
break;
}
}
if (found)
return ent;
return NULL;
}
inline struct txpwr_lmt_ent *rtw_txpwr_lmt_get_by_name(struct rf_ctl_t *rfctl, const char *regd_name)
{
struct txpwr_lmt_ent *ent;
_irqL irqL;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_name);
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
return ent;
}
void rtw_txpwr_lmt_list_free(struct rf_ctl_t *rfctl)
{
struct txpwr_lmt_ent *ent;
_irqL irqL;
_list *cur, *head;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
if (ent->regd_name == rfctl->regd_name)
rfctl->regd_name = regd_str(TXPWR_LMT_NONE);
rtw_list_delete(&ent->list);
rtw_vmfree((u8 *)ent, sizeof(struct txpwr_lmt_ent) + strlen(ent->regd_name) + 1);
}
rfctl->txpwr_regd_num = 0;
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
}
#endif /* CONFIG_TXPWR_LIMIT */
int rtw_ch_to_bb_gain_sel(int ch)
{
int sel = -1;
if (ch >= 1 && ch <= 14)
sel = BB_GAIN_2G;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else if (ch >= 36 && ch < 48)
sel = BB_GAIN_5GLB1;
else if (ch >= 52 && ch <= 64)
sel = BB_GAIN_5GLB2;
else if (ch >= 100 && ch <= 120)
sel = BB_GAIN_5GMB1;
else if (ch >= 124 && ch <= 144)
sel = BB_GAIN_5GMB2;
else if (ch >= 149 && ch <= 177)
sel = BB_GAIN_5GHB;
#endif
return sel;
}
s8 rtw_rf_get_kfree_tx_gain_offset(_adapter *padapter, u8 path, u8 ch)
{
s8 kfree_offset = 0;
#ifdef CONFIG_RF_POWER_TRIM
struct kfree_data_t *kfree_data = GET_KFREE_DATA(padapter);
s8 bb_gain_sel = rtw_ch_to_bb_gain_sel(ch);
if (bb_gain_sel < BB_GAIN_2G || bb_gain_sel >= BB_GAIN_NUM) {
rtw_warn_on(1);
goto exit;
}
if (kfree_data->flag & KFREE_FLAG_ON) {
kfree_offset = kfree_data->bb_gain[bb_gain_sel][path];
if (IS_HARDWARE_TYPE_8723D(padapter))
RTW_INFO("%s path:%s, ch:%u, bb_gain_sel:%d, kfree_offset:%d\n"
, __func__, (path == 0)?"S1":"S0",
ch, bb_gain_sel, kfree_offset);
else
RTW_INFO("%s path:%u, ch:%u, bb_gain_sel:%d, kfree_offset:%d\n"
, __func__, path, ch, bb_gain_sel, kfree_offset);
}
exit:
#endif /* CONFIG_RF_POWER_TRIM */
return kfree_offset;
}
void rtw_rf_set_tx_gain_offset(_adapter *adapter, u8 path, s8 offset)
{
#if !defined(CONFIG_RTL8814A) && !defined(CONFIG_RTL8822B) && !defined(CONFIG_RTL8821C) && !defined(CONFIG_RTL8822C)
u8 write_value;
#endif
u8 target_path = 0;
u32 val32 = 0;
if (IS_HARDWARE_TYPE_8723D(adapter)) {
target_path = RF_PATH_A; /*in 8723D case path means S0/S1*/
if (path == PPG_8723D_S1)
RTW_INFO("kfree gain_offset 0x55:0x%x ",
rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff));
else if (path == PPG_8723D_S0)
RTW_INFO("kfree gain_offset 0x65:0x%x ",
rtw_hal_read_rfreg(adapter, target_path, 0x65, 0xffffffff));
} else {
target_path = path;
RTW_INFO("kfree gain_offset 0x55:0x%x ", rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff));
}
switch (rtw_get_chip_type(adapter)) {
#ifdef CONFIG_RTL8723D
case RTL8723D:
write_value = RF_TX_GAIN_OFFSET_8723D(offset);
if (path == PPG_8723D_S1)
rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
else if (path == PPG_8723D_S0)
rtw_hal_write_rfreg(adapter, target_path, 0x65, 0x0f8000, write_value);
break;
#endif /* CONFIG_RTL8723D */
#ifdef CONFIG_RTL8703B
case RTL8703B:
write_value = RF_TX_GAIN_OFFSET_8703B(offset);
rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
break;
#endif /* CONFIG_RTL8703B */
#ifdef CONFIG_RTL8188F
case RTL8188F:
write_value = RF_TX_GAIN_OFFSET_8188F(offset);
rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
break;
#endif /* CONFIG_RTL8188F */
#ifdef CONFIG_RTL8188GTV
case RTL8188GTV:
write_value = RF_TX_GAIN_OFFSET_8188GTV(offset);
rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0fc000, write_value);
break;
#endif /* CONFIG_RTL8188GTV */
#ifdef CONFIG_RTL8192E
case RTL8192E:
write_value = RF_TX_GAIN_OFFSET_8192E(offset);
rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
break;
#endif /* CONFIG_RTL8188F */
#ifdef CONFIG_RTL8821A
case RTL8821:
write_value = RF_TX_GAIN_OFFSET_8821A(offset);
rtw_hal_write_rfreg(adapter, target_path, 0x55, 0x0f8000, write_value);
break;
#endif /* CONFIG_RTL8821A */
#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8822C)
case RTL8814A:
case RTL8822B:
case RTL8822C:
case RTL8821C:
case RTL8192F:
RTW_INFO("\nkfree by PhyDM on the sw CH. path %d\n", path);
break;
#endif /* CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
default:
rtw_warn_on(1);
break;
}
if (IS_HARDWARE_TYPE_8723D(adapter)) {
if (path == PPG_8723D_S1)
val32 = rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff);
else if (path == PPG_8723D_S0)
val32 = rtw_hal_read_rfreg(adapter, target_path, 0x65, 0xffffffff);
} else {
val32 = rtw_hal_read_rfreg(adapter, target_path, 0x55, 0xffffffff);
}
RTW_INFO(" after :0x%x\n", val32);
}
void rtw_rf_apply_tx_gain_offset(_adapter *adapter, u8 ch)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
s8 kfree_offset = 0;
s8 tx_pwr_track_offset = 0; /* TODO: 8814A should consider tx pwr track when setting tx gain offset */
s8 total_offset;
int i, total = 0;
if (IS_HARDWARE_TYPE_8723D(adapter))
total = 2; /* S1 and S0 */
else
total = hal_data->NumTotalRFPath;
for (i = 0; i < total; i++) {
kfree_offset = rtw_rf_get_kfree_tx_gain_offset(adapter, i, ch);
total_offset = kfree_offset + tx_pwr_track_offset;
rtw_rf_set_tx_gain_offset(adapter, i, total_offset);
}
}
inline u8 rtw_is_dfs_range(u32 hi, u32 lo)
{
return rtw_is_range_overlap(hi, lo, 5720 + 10, 5260 - 10);
}
u8 rtw_is_dfs_ch(u8 ch)
{
u32 hi, lo;
if (!rtw_chbw_to_freq_range(ch, CHANNEL_WIDTH_20, HAL_PRIME_CHNL_OFFSET_DONT_CARE, &hi, &lo))
return 0;
return rtw_is_dfs_range(hi, lo);
}
u8 rtw_is_dfs_chbw(u8 ch, u8 bw, u8 offset)
{
u32 hi, lo;
if (!rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo))
return 0;
return rtw_is_dfs_range(hi, lo);
}
bool rtw_is_long_cac_range(u32 hi, u32 lo, u8 dfs_region)
{
return (dfs_region == PHYDM_DFS_DOMAIN_ETSI && rtw_is_range_overlap(hi, lo, 5650, 5600)) ? _TRUE : _FALSE;
}
bool rtw_is_long_cac_ch(u8 ch, u8 bw, u8 offset, u8 dfs_region)
{
u32 hi, lo;
if (rtw_chbw_to_freq_range(ch, bw, offset, &hi, &lo) == _FALSE)
return _FALSE;
return rtw_is_long_cac_range(hi, lo, dfs_region) ? _TRUE : _FALSE;
}
================================================
FILE: core/rtw_rm.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#include "rtw_rm_fsm.h"
#define pstr(s) s+strlen(s)
u8 rm_post_event_hdl(_adapter *padapter, u8 *pbuf)
{
#ifdef CONFIG_RTW_80211K
struct rm_event *pev = (struct rm_event *)pbuf;
_rm_post_event(padapter, pev->rmid, pev->evid);
rm_handler(padapter, pev);
#endif
return H2C_SUCCESS;
}
#ifdef CONFIG_RTW_80211K
/* 802.11-2012 Table E-1 Operationg classes in United States */
static RT_OPERATING_CLASS RTW_OP_CLASS_US[] = {
/* 0, OP_CLASS_NULL */ { 0, 0, {}},
/* 1, OP_CLASS_1 */ {115, 4, {36, 40, 44, 48}},
/* 2, OP_CLASS_2 */ {118, 4, {52, 56, 60, 64}},
/* 3, OP_CLASS_3 */ {124, 4, {149, 153, 157, 161}},
/* 4, OP_CLASS_4 */ {121, 11, {100, 104, 108, 112, 116, 120, 124,
128, 132, 136, 140}},
/* 5, OP_CLASS_5 */ {125, 5, {149, 153, 157, 161, 165}},
/* 6, OP_CLASS_12 */ { 81, 11, {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}}
};
struct cmd_meas_type_ {
u8 id;
char *name;
};
char *rm_type_req_name(u8 meas_type) {
switch (meas_type) {
case basic_req:
return "basic_req";
case cca_req:
return "cca_req";
case rpi_histo_req:
return "rpi_histo_req";
case ch_load_req:
return "ch_load_req";
case noise_histo_req:
return "noise_histo_req";
case bcn_req:
return "bcn_req";
case frame_req:
return "frame_req";
case sta_statis_req:
return "sta_statis_req";
}
return "unknown_req";
};
char *rm_type_rep_name(u8 meas_type) {
switch (meas_type) {
case basic_rep:
return "basic_rep";
case cca_rep:
return "cca_rep";
case rpi_histo_rep:
return "rpi_histo_rep";
case ch_load_rep:
return "ch_load_rep";
case noise_histo_rep:
return "noise_histo_rep";
case bcn_rep:
return "bcn_rep";
case frame_rep:
return "frame_rep";
case sta_statis_rep:
return "sta_statis_rep";
}
return "unknown_rep";
};
char *rm_en_cap_name(enum rm_cap_en en)
{
switch (en) {
case RM_LINK_MEAS_CAP_EN:
return "RM_LINK_MEAS_CAP_EN";
case RM_NB_REP_CAP_EN:
return "RM_NB_REP_CAP_EN";
case RM_PARAL_MEAS_CAP_EN:
return "RM_PARAL_MEAS_CAP_EN";
case RM_REPEAT_MEAS_CAP_EN:
return "RM_REPEAT_MEAS_CAP_EN";
case RM_BCN_PASSIVE_MEAS_CAP_EN:
return "RM_BCN_PASSIVE_MEAS_CAP_EN";
case RM_BCN_ACTIVE_MEAS_CAP_EN:
return "RM_BCN_ACTIVE_MEAS_CAP_EN";
case RM_BCN_TABLE_MEAS_CAP_EN:
return "RM_BCN_TABLE_MEAS_CAP_EN";
case RM_BCN_MEAS_REP_COND_CAP_EN:
return "RM_BCN_MEAS_REP_COND_CAP_EN";
case RM_FRAME_MEAS_CAP_EN:
return "RM_FRAME_MEAS_CAP_EN";
case RM_CH_LOAD_CAP_EN:
return "RM_CH_LOAD_CAP_EN";
case RM_NOISE_HISTO_CAP_EN:
return "RM_NOISE_HISTO_CAP_EN";
case RM_STATIS_MEAS_CAP_EN:
return "RM_STATIS_MEAS_CAP_EN";
case RM_LCI_MEAS_CAP_EN:
return "RM_LCI_MEAS_CAP_EN";
case RM_LCI_AMIMUTH_CAP_EN:
return "RM_LCI_AMIMUTH_CAP_EN";
case RM_TRANS_STREAM_CAT_MEAS_CAP_EN:
return "RM_TRANS_STREAM_CAT_MEAS_CAP_EN";
case RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN:
return "RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN";
case RM_AP_CH_REP_CAP_EN:
return "RM_AP_CH_REP_CAP_EN";
case RM_RM_MIB_CAP_EN:
return "RM_RM_MIB_CAP_EN";
case RM_OP_CH_MAX_MEAS_DUR0:
return "RM_OP_CH_MAX_MEAS_DUR0";
case RM_OP_CH_MAX_MEAS_DUR1:
return "RM_OP_CH_MAX_MEAS_DUR1";
case RM_OP_CH_MAX_MEAS_DUR2:
return "RM_OP_CH_MAX_MEAS_DUR2";
case RM_NONOP_CH_MAX_MEAS_DUR0:
return "RM_NONOP_CH_MAX_MEAS_DUR0";
case RM_NONOP_CH_MAX_MEAS_DUR1:
return "RM_NONOP_CH_MAX_MEAS_DUR1";
case RM_NONOP_CH_MAX_MEAS_DUR2:
return "RM_NONOP_CH_MAX_MEAS_DUR2";
case RM_MEAS_PILOT_CAP0:
return "RM_MEAS_PILOT_CAP0"; /* 24-26 */
case RM_MEAS_PILOT_CAP1:
return "RM_MEAS_PILOT_CAP1";
case RM_MEAS_PILOT_CAP2:
return "RM_MEAS_PILOT_CAP2";
case RM_MEAS_PILOT_TRANS_INFO_CAP_EN:
return "RM_MEAS_PILOT_TRANS_INFO_CAP_EN";
case RM_NB_REP_TSF_OFFSET_CAP_EN:
return "RM_NB_REP_TSF_OFFSET_CAP_EN";
case RM_RCPI_MEAS_CAP_EN:
return "RM_RCPI_MEAS_CAP_EN"; /* 29 */
case RM_RSNI_MEAS_CAP_EN:
return "RM_RSNI_MEAS_CAP_EN";
case RM_BSS_AVG_ACCESS_DELAY_CAP_EN:
return "RM_BSS_AVG_ACCESS_DELAY_CAP_EN";
case RM_AVALB_ADMIS_CAPACITY_CAP_EN:
return "RM_AVALB_ADMIS_CAPACITY_CAP_EN";
case RM_ANT_CAP_EN:
return "RM_ANT_CAP_EN";
case RM_RSVD:
case RM_MAX:
default:
break;
}
return "unknown";
}
int rm_en_cap_chk_and_set(struct rm_obj *prm, enum rm_cap_en en)
{
int idx;
u8 cap;
if (en >= RM_MAX)
return _FALSE;
idx = en / 8;
cap = prm->psta->padapter->rmpriv.rm_en_cap_def[idx];
if (!(cap & BIT(en - (idx*8)))) {
RTW_INFO("RM: %s incapable\n",rm_en_cap_name(en));
rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
return _FALSE;
}
return _SUCCESS;
}
static u8 rm_get_oper_class_via_ch(u8 ch)
{
int i,j,sz;
sz = sizeof(RTW_OP_CLASS_US)/sizeof(struct _RT_OPERATING_CLASS);
for (i = 0; i < sz; i++) {
for (j = 0; j < RTW_OP_CLASS_US[i].Len; j++) {
if ( ch == RTW_OP_CLASS_US[i].Channel[j]) {
RTW_INFO("RM: ch %u in oper_calss %u\n",
ch, RTW_OP_CLASS_US[i].global_op_class);
return RTW_OP_CLASS_US[i].global_op_class;
break;
}
}
}
return 0;
}
static u8 rm_get_ch_set(
struct rtw_ieee80211_channel *pch_set, u8 op_class, u8 ch_num)
{
int i,j,sz;
u8 ch_amount = 0;
sz = sizeof(RTW_OP_CLASS_US)/sizeof(struct _RT_OPERATING_CLASS);
if (ch_num != 0) {
pch_set[0].hw_value = ch_num;
ch_amount = 1;
RTW_INFO("RM: meas_ch->hw_value = %u\n", pch_set->hw_value);
goto done;
}
for (i = 0; i < sz; i++) {
if (RTW_OP_CLASS_US[i].global_op_class == op_class) {
for (j = 0; j < RTW_OP_CLASS_US[i].Len; j++) {
pch_set[j].hw_value =
RTW_OP_CLASS_US[i].Channel[j];
RTW_INFO("RM: meas_ch[%d].hw_value = %u\n",
j, pch_set[j].hw_value);
}
ch_amount = RTW_OP_CLASS_US[i].Len;
break;
}
}
done:
return ch_amount;
}
static int is_wildcard_bssid(u8 *bssid)
{
int i;
u8 val8 = 0xff;
for (i=0;i<6;i++)
val8 &= bssid[i];
if (val8 == 0xff)
return _SUCCESS;
return _FALSE;
}
/* for caller outside rm */
u8 rm_add_nb_req(_adapter *padapter, struct sta_info *psta)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
struct rm_obj *prm;
prm = rm_alloc_rmobj(padapter);
if (prm == NULL) {
RTW_ERR("RM: unable to alloc rm obj for requeset\n");
return _FALSE;
}
prm->psta = psta;
prm->q.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
prm->q.diag_token = pmlmeinfo->dialogToken++;
prm->q.m_token = 1;
prm->rmid = psta->cmn.aid << 16
| prm->q.diag_token << 8
| RM_MASTER;
prm->q.action_code = RM_ACT_NB_REP_REQ;
#if 0
if (pmac) { /* find sta_info according to bssid */
pmac += 4; /* skip mac= */
if (hwaddr_parse(pmac, bssid) == NULL) {
sprintf(pstr(s), "Err: \nincorrect mac format\n");
return _FAIL;
}
psta = rm_get_sta(padapter, 0xff, bssid);
}
#endif
/* enquee rmobj */
rm_enqueue_rmobj(padapter, prm, _FALSE);
RTW_INFO("RM: rmid=%x add req to " MAC_FMT "\n",
prm->rmid, MAC_ARG(psta->cmn.mac_addr));
return _SUCCESS;
}
static u8 *build_wlan_hdr(_adapter *padapter, struct xmit_frame *pmgntframe,
struct sta_info *psta, u16 frame_type)
{
u8 *pframe;
u16 *fctrl;
struct pkt_attrib *pattr;
struct rtw_ieee80211_hdr *pwlanhdr;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
/* update attribute */
pattr = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattr);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, psta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3,
get_my_bssid(&(pmlmeinfo->network)),ETH_ALEN);
RTW_INFO("RM: dst = " MAC_FMT "\n", MAC_ARG(pwlanhdr->addr1));
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
SetFragNum(pframe, 0);
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattr->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
return pframe;
}
void rm_set_rep_mode(struct rm_obj *prm, u8 mode)
{
RTW_INFO("RM: rmid=%x set %s\n",
prm->rmid,
mode|MEAS_REP_MOD_INCAP?"INCAP":
mode|MEAS_REP_MOD_REFUSE?"REFUSE":
mode|MEAS_REP_MOD_LATE?"LATE":"");
prm->p.m_mode |= mode;
}
int issue_null_reply(struct rm_obj *prm)
{
int len=0, my_len;
u8 *pframe, m_mode;
_adapter *padapter = prm->psta->padapter;
struct pkt_attrib *pattr;
struct xmit_frame *pmgntframe;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
m_mode = prm->p.m_mode;
if (m_mode || prm->p.rpt == 0) {
RTW_INFO("RM: rmid=%x reply (%s repeat=%d)\n",
prm->rmid,
m_mode&MEAS_REP_MOD_INCAP?"INCAP":
m_mode&MEAS_REP_MOD_REFUSE?"REFUSE":
m_mode&MEAS_REP_MOD_LATE?"LATE":"no content",
prm->p.rpt);
}
switch (prm->p.action_code) {
case RM_ACT_RADIO_MEAS_REQ:
len = 8;
break;
case RM_ACT_NB_REP_REQ:
len = 3;
break;
case RM_ACT_LINK_MEAS_REQ:
len = 3;
break;
default:
break;
}
if (len==0)
return _FALSE;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
return _FALSE;
}
pattr = &pmgntframe->attrib;
pframe = build_wlan_hdr(padapter, pmgntframe, prm->psta, WIFI_ACTION);
pframe = rtw_set_fixed_ie(pframe, 3, &prm->p.category, &pattr->pktlen);
my_len = 0;
if (len>5) {
prm->p.len = len - 3 - 2;
pframe = rtw_set_fixed_ie(pframe, len - 3,
&prm->p.e_id, &my_len);
}
pattr->pktlen += my_len;
pattr->last_txcmdsz = pattr->pktlen;
dump_mgntframe(padapter, pmgntframe);
return _SUCCESS;
}
int ready_for_scan(struct rm_obj *prm)
{
_adapter *padapter = prm->psta->padapter;
u8 ssc_chk;
if (!rtw_is_adapter_up(padapter))
return _FALSE;
ssc_chk = rtw_sitesurvey_condition_check(padapter, _FALSE);
if (ssc_chk == SS_ALLOW)
return _SUCCESS;
return _FALSE;
}
int rm_sitesurvey(struct rm_obj *prm)
{
int meas_ch_num=0;
u8 ch_num=0, op_class=0, val8;
struct rtw_ieee80211_channel *pch_set;
struct sitesurvey_parm parm;
RTW_INFO("RM: rmid=%x %s\n",prm->rmid, __func__);
pch_set = &prm->q.ch_set[0];
_rtw_memset(pch_set, 0,
sizeof(struct rtw_ieee80211_channel) * MAX_OP_CHANNEL_SET_NUM);
if (prm->q.ch_num == 0) {
/* ch_num=0 : scan all ch in operating class */
op_class = prm->q.op_class;
} else if (prm->q.ch_num == 255) {
/* 802.11 p.499 */
/* ch_num=255 : scan all ch in current operating class */
op_class = rm_get_oper_class_via_ch(
(u8)prm->psta->padapter->mlmeextpriv.cur_channel);
} else
ch_num = prm->q.ch_num;
/* get means channel */
meas_ch_num = rm_get_ch_set(pch_set, op_class, ch_num);
prm->q.ch_set_ch_amount = meas_ch_num;
_rtw_memset(&parm, 0, sizeof(struct sitesurvey_parm));
_rtw_memcpy(parm.ch, pch_set,
sizeof(struct rtw_ieee80211_channel) * MAX_OP_CHANNEL_SET_NUM);
_rtw_memcpy(&parm.ssid[0], &prm->q.opt.bcn.ssid, IW_ESSID_MAX_SIZE);
parm.ssid_num = 1;
parm.scan_mode = prm->q.m_mode;
parm.ch_num = meas_ch_num;
parm.igi = 0;
parm.token = prm->rmid;
parm.duration = prm->q.meas_dur;
/* parm.bw = BW_20M; */
rtw_sitesurvey_cmd(prm->psta->padapter, &parm);
return _SUCCESS;
}
static u8 translate_percentage_to_rcpi(u32 SignalStrengthIndex)
{
s32 SignalPower; /* in dBm. */
u8 rcpi;
/* Translate to dBm (x=y-100) */
SignalPower = SignalStrengthIndex - 100;
/* RCPI = Int{(Power in dBm + 110)*2} for 0dBm > Power > -110dBm
* 0 : power <= -110.0 dBm
* 1 : power = -109.5 dBm
* 2 : power = -109.0 dBm
*/
rcpi = (SignalPower + 110)*2;
return rcpi;
}
static int rm_parse_ch_load_s_elem(struct rm_obj *prm, u8 *pbody, int req_len)
{
u8 *popt_id;
int i, p=0; /* position */
int len = req_len;
prm->q.opt_s_elem_len = len;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: opt_s_elem_len=%d\n", len);
#endif
while (len) {
switch (pbody[p]) {
case ch_load_rep_info:
/* check RM_EN */
rm_en_cap_chk_and_set(prm, RM_CH_LOAD_CAP_EN);
_rtw_memcpy(&(prm->q.opt.clm.rep_cond),
&pbody[p+2], sizeof(prm->q.opt.clm.rep_cond));
RTW_INFO("RM: ch_load_rep_info=%u:%u\n",
prm->q.opt.clm.rep_cond.cond,
prm->q.opt.clm.rep_cond.threshold);
break;
default:
break;
}
len = len - (int)pbody[p+1] - 2;
p = p + (int)pbody[p+1] + 2;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: opt_s_elem_len=%d\n",len);
#endif
}
return _SUCCESS;
}
static int rm_parse_noise_histo_s_elem(struct rm_obj *prm,
u8 *pbody, int req_len)
{
u8 *popt_id;
int i, p=0; /* position */
int len = req_len;
prm->q.opt_s_elem_len = len;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: opt_s_elem_len=%d\n", len);
#endif
while (len) {
switch (pbody[p]) {
case noise_histo_rep_info:
/* check RM_EN */
rm_en_cap_chk_and_set(prm, RM_NOISE_HISTO_CAP_EN);
_rtw_memcpy(&(prm->q.opt.nhm.rep_cond),
&pbody[p+2], sizeof(prm->q.opt.nhm.rep_cond));
RTW_INFO("RM: noise_histo_rep_info=%u:%u\n",
prm->q.opt.nhm.rep_cond.cond,
prm->q.opt.nhm.rep_cond.threshold);
break;
default:
break;
}
len = len - (int)pbody[p+1] - 2;
p = p + (int)pbody[p+1] + 2;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: opt_s_elem_len=%d\n",len);
#endif
}
return _SUCCESS;
}
static int rm_parse_bcn_req_s_elem(struct rm_obj *prm, u8 *pbody, int req_len)
{
u8 *popt_id;
int i, p=0; /* position */
int len = req_len;
/* opt length,2:pbody[0]+ pbody[1] */
/* first opt id : pbody[18] */
prm->q.opt_s_elem_len = len;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: opt_s_elem_len=%d\n", len);
#endif
popt_id = prm->q.opt.bcn.opt_id;
while (len && prm->q.opt.bcn.opt_id_num < BCN_REQ_OPT_MAX_NUM) {
switch (pbody[p]) {
case bcn_req_ssid:
RTW_INFO("bcn_req_ssid\n");
#if (DBG_BCN_REQ_WILDCARD)
RTW_INFO("DBG set ssid to WILDCARD\n");
#else
#if (DBG_BCN_REQ_SSID)
RTW_INFO("DBG set ssid to %s\n",DBG_BCN_REQ_SSID_NAME);
i = strlen(DBG_BCN_REQ_SSID_NAME);
prm->q.opt.bcn.ssid.SsidLength = i;
_rtw_memcpy(&(prm->q.opt.bcn.ssid.Ssid),
DBG_BCN_REQ_SSID_NAME, i);
#else /* original */
prm->q.opt.bcn.ssid.SsidLength = pbody[p+1];
_rtw_memcpy(&(prm->q.opt.bcn.ssid.Ssid),
&pbody[p+2], pbody[p+1]);
#endif
#endif
RTW_INFO("RM: bcn_req_ssid=%s\n",
prm->q.opt.bcn.ssid.Ssid);
popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
break;
case bcn_req_rep_info:
/* check RM_EN */
rm_en_cap_chk_and_set(prm, RM_BCN_MEAS_REP_COND_CAP_EN);
_rtw_memcpy(&(prm->q.opt.bcn.rep_cond),
&pbody[p+2], sizeof(prm->q.opt.bcn.rep_cond));
RTW_INFO("bcn_req_rep_info=%u:%u\n",
prm->q.opt.bcn.rep_cond.cond,
prm->q.opt.bcn.rep_cond.threshold);
/*popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];*/
break;
case bcn_req_rep_detail:
#if DBG_BCN_REQ_DETAIL
prm->q.opt.bcn.rep_detail = 2; /* all IE in beacon */
#else
prm->q.opt.bcn.rep_detail = pbody[p+2];
#endif
popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: report_detail=%d\n",
prm->q.opt.bcn.rep_detail);
#endif
break;
case bcn_req_req:
RTW_INFO("RM: bcn_req_req\n");
prm->q.opt.bcn.req_start = rtw_malloc(pbody[p+1]);
if (prm->q.opt.bcn.req_start == NULL) {
RTW_ERR("RM: req_start malloc fail!!\n");
break;
}
for (i = 0; i < pbody[p+1]; i++)
*((prm->q.opt.bcn.req_start)+i) =
pbody[p+2+i];
prm->q.opt.bcn.req_len = pbody[p+1];
popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
break;
case bcn_req_ac_ch_rep:
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: bcn_req_ac_ch_rep\n");
#endif
popt_id[prm->q.opt.bcn.opt_id_num++] = pbody[p];
break;
default:
break;
}
len = len - (int)pbody[p+1] - 2;
p = p + (int)pbody[p+1] + 2;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: opt_s_elem_len=%d\n",len);
#endif
}
return _SUCCESS;
}
static int rm_parse_meas_req(struct rm_obj *prm, u8 *pbody)
{
int p; /* position */
int req_len;
req_len = (int)pbody[1];
p = 5;
prm->q.op_class = pbody[p++];
prm->q.ch_num = pbody[p++];
prm->q.rand_intvl = le16_to_cpu(*(u16*)(&pbody[p]));
p+=2;
prm->q.meas_dur = le16_to_cpu(*(u16*)(&pbody[p]));
p+=2;
if (prm->q.m_type == bcn_req) {
/*
* 0: passive
* 1: active
* 2: bcn_table
*/
prm->q.m_mode = pbody[p++];
/* BSSID */
_rtw_memcpy(&(prm->q.bssid), &pbody[p], 6);
p+=6;
/*
* default, used when Reporting detail subelement
* is not included in Beacon Request
*/
prm->q.opt.bcn.rep_detail = 2;
}
if (req_len-(p-2) <= 0) /* without sub-element */
return _SUCCESS;
switch (prm->q.m_type) {
case bcn_req:
rm_parse_bcn_req_s_elem(prm, &pbody[p], req_len-(p-2));
break;
case ch_load_req:
rm_parse_ch_load_s_elem(prm, &pbody[p], req_len-(p-2));
break;
case noise_histo_req:
rm_parse_noise_histo_s_elem(prm, &pbody[p], req_len-(p-2));
break;
default:
break;
}
return _SUCCESS;
}
/* receive measurement request */
int rm_recv_radio_mens_req(_adapter *padapter,
union recv_frame *precv_frame, struct sta_info *psta)
{
struct rm_obj *prm;
struct rm_priv *prmpriv = &padapter->rmpriv;
u8 *pdiag_body = (u8 *)(precv_frame->u.hdr.rx_data +
sizeof(struct rtw_ieee80211_hdr_3addr));
u8 *pmeas_body = &pdiag_body[5];
u8 rmid, update = 0;
#if 0
/* search existing rm_obj */
rmid = psta->cmn.aid << 16
| pdiag_body[2] << 8
| RM_SLAVE;
prm = rm_get_rmobj(padapter, rmid);
if (prm) {
RTW_INFO("RM: Found an exist meas rmid=%u\n", rmid);
update = 1;
} else
#endif
prm = rm_alloc_rmobj(padapter);
if (prm == NULL) {
RTW_ERR("RM: unable to alloc rm obj for requeset\n");
return _FALSE;
}
prm->psta = psta;
prm->q.diag_token = pdiag_body[2];
prm->q.rpt = le16_to_cpu(*(u16*)(&pdiag_body[3]));
/* Figure 8-104 Measurement Requested format */
prm->q.e_id = pmeas_body[0];
prm->q.m_token = pmeas_body[2];
prm->q.m_mode = pmeas_body[3];
prm->q.m_type = pmeas_body[4];
prm->rmid = psta->cmn.aid << 16
| prm->q.diag_token << 8
| RM_SLAVE;
RTW_INFO("RM: rmid=%x, bssid " MAC_FMT "\n", prm->rmid,
MAC_ARG(prm->psta->cmn.mac_addr));
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: element_id = %d\n", prm->q.e_id);
RTW_INFO("RM: length = %d\n", (int)pmeas_body[1]);
RTW_INFO("RM: meas_token = %d\n", prm->q.m_token);
RTW_INFO("RM: meas_mode = %d\n", prm->q.m_mode);
RTW_INFO("RM: meas_type = %d\n", prm->q.m_type);
#endif
if (prm->q.e_id != _MEAS_REQ_IE_) /* 38 */
return _FALSE;
switch (prm->q.m_type) {
case bcn_req:
RTW_INFO("RM: recv beacon_request\n");
switch (prm->q.m_mode) {
case bcn_req_passive:
rm_en_cap_chk_and_set(prm, RM_BCN_PASSIVE_MEAS_CAP_EN);
break;
case bcn_req_active:
rm_en_cap_chk_and_set(prm, RM_BCN_ACTIVE_MEAS_CAP_EN);
break;
case bcn_req_bcn_table:
rm_en_cap_chk_and_set(prm, RM_BCN_TABLE_MEAS_CAP_EN);
break;
default:
rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
break;
}
break;
case ch_load_req:
RTW_INFO("RM: recv ch_load_request\n");
rm_en_cap_chk_and_set(prm, RM_CH_LOAD_CAP_EN);
break;
case noise_histo_req:
RTW_INFO("RM: recv noise_histogram_request\n");
rm_en_cap_chk_and_set(prm, RM_NOISE_HISTO_CAP_EN);
break;
default:
RTW_INFO("RM: recv unknown request type 0x%02x\n",
prm->q.m_type);
rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
goto done;
}
rm_parse_meas_req(prm, pmeas_body);
done:
if (!update)
rm_enqueue_rmobj(padapter, prm, _FALSE);
return _SUCCESS;
}
/* receive measurement report */
int rm_recv_radio_mens_rep(_adapter *padapter,
union recv_frame *precv_frame, struct sta_info *psta)
{
int ret = _FALSE;
struct rm_obj *prm;
u32 rmid;
u8 *pdiag_body = (u8 *)(precv_frame->u.hdr.rx_data +
sizeof(struct rtw_ieee80211_hdr_3addr));
u8 *pmeas_body = &pdiag_body[3];
rmid = psta->cmn.aid << 16
| pdiag_body[2] << 8
| RM_MASTER;
prm = rm_get_rmobj(padapter, rmid);
if (prm == NULL)
return _FALSE;
prm->p.action_code = pdiag_body[1];
prm->p.diag_token = pdiag_body[2];
/* Figure 8-140 Measuremnt Report format */
prm->p.e_id = pmeas_body[0];
prm->p.m_token = pmeas_body[2];
prm->p.m_mode = pmeas_body[3];
prm->p.m_type = pmeas_body[4];
RTW_INFO("RM: rmid=%x, bssid " MAC_FMT "\n", prm->rmid,
MAC_ARG(prm->psta->cmn.mac_addr));
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: element_id = %d\n", prm->p.e_id);
RTW_INFO("RM: length = %d\n", (int)pmeas_body[1]);
RTW_INFO("RM: meas_token = %d\n", prm->p.m_token);
RTW_INFO("RM: meas_mode = %d\n", prm->p.m_mode);
RTW_INFO("RM: meas_type = %d\n", prm->p.m_type);
#endif
if (prm->p.e_id != _MEAS_RSP_IE_) /* 39 */
return _FALSE;
RTW_INFO("RM: recv %s\n", rm_type_rep_name(prm->p.m_type));
rm_post_event(padapter, prm->rmid, RM_EV_recv_rep);
return ret;
}
int rm_radio_mens_nb_rep(_adapter *padapter,
union recv_frame *precv_frame, struct sta_info *psta)
{
u8 *pdiag_body = (u8 *)(precv_frame->u.hdr.rx_data +
sizeof(struct rtw_ieee80211_hdr_3addr));
u8 *pmeas_body = &pdiag_body[3];
u32 len = precv_frame->u.hdr.len;
u32 rmid;
struct rm_obj *prm;
rmid = psta->cmn.aid << 16
| pdiag_body[2] << 8
| RM_MASTER;
prm = rm_get_rmobj(padapter, rmid);
if (prm == NULL)
return _FALSE;
prm->p.action_code = pdiag_body[1];
prm->p.diag_token = pdiag_body[2];
prm->p.e_id = pmeas_body[0];
RTW_INFO("RM: rmid=%x, bssid " MAC_FMT "\n", prm->rmid,
MAC_ARG(prm->psta->cmn.mac_addr));
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: element_id = %d\n", prm->p.e_id);
RTW_INFO("RM: length = %d\n", (int)pmeas_body[1]);
#endif
rm_post_event(padapter, prm->rmid, RM_EV_recv_rep);
#ifdef CONFIG_LAYER2_ROAMING
if (rtw_wnm_btm_candidates_survey(padapter
,(pdiag_body + 3)
,(len - sizeof(struct rtw_ieee80211_hdr_3addr))
,_FALSE) == _FAIL)
return _FALSE;
#endif
rtw_cfg80211_rx_rrm_action(padapter, precv_frame);
return _TRUE;
}
unsigned int rm_on_action(_adapter *padapter, union recv_frame *precv_frame)
{
u32 ret = _FAIL;
u8 *pframe = NULL;
u8 *pframe_body = NULL;
u8 action_code = 0;
u8 diag_token = 0;
struct rtw_ieee80211_hdr_3addr *whdr;
struct sta_info *psta;
pframe = precv_frame->u.hdr.rx_data;
/* check RA matches or not */
if (!_rtw_memcmp(adapter_mac_addr(padapter),
GetAddr1Ptr(pframe), ETH_ALEN))
goto exit;
whdr = (struct rtw_ieee80211_hdr_3addr *)pframe;
RTW_INFO("RM: %s bssid = " MAC_FMT "\n",
__func__, MAC_ARG(whdr->addr2));
psta = rtw_get_stainfo(&padapter->stapriv, whdr->addr2);
if (!psta) {
RTW_ERR("RM: psta not found\n");
goto exit;
}
pframe_body = (unsigned char *)(pframe +
sizeof(struct rtw_ieee80211_hdr_3addr));
/* Figure 8-438 radio measurement request frame Action field format */
/* Category = pframe_body[0] = 5 (Radio Measurement) */
action_code = pframe_body[1];
diag_token = pframe_body[2];
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: %s radio_action=%x, diag_token=%x\n", __func__,
action_code, diag_token);
#endif
switch (action_code) {
case RM_ACT_RADIO_MEAS_REQ:
RTW_INFO("RM: RM_ACT_RADIO_MEAS_REQ\n");
ret = rm_recv_radio_mens_req(padapter, precv_frame, psta);
break;
case RM_ACT_RADIO_MEAS_REP:
RTW_INFO("RM: RM_ACT_RADIO_MEAS_REP\n");
ret = rm_recv_radio_mens_rep(padapter, precv_frame, psta);
break;
case RM_ACT_LINK_MEAS_REQ:
RTW_INFO("RM: RM_ACT_LINK_MEAS_REQ\n");
break;
case RM_ACT_LINK_MEAS_REP:
RTW_INFO("RM: RM_ACT_LINK_MEAS_REP\n");
break;
case RM_ACT_NB_REP_REQ:
RTW_INFO("RM: RM_ACT_NB_REP_REQ\n");
break;
case RM_ACT_NB_REP_RESP:
RTW_INFO("RM: RM_ACT_NB_REP_RESP\n");
ret = rm_radio_mens_nb_rep(padapter, precv_frame, psta);
break;
default:
/* TODO reply incabable */
RTW_ERR("RM: unknown specturm management action %2x\n",
action_code);
break;
}
exit:
return ret;
}
static u8 *rm_gen_bcn_detail_elem(_adapter *padapter, u8 *pframe,
struct rm_obj *prm, struct wlan_network *pnetwork,
unsigned int *fr_len)
{
WLAN_BSSID_EX *pbss = &pnetwork->network;
unsigned int my_len;
int j, k, len;
u8 *plen;
u8 *ptr;
u8 val8, eid;
my_len = 0;
/* Reporting Detail values
* 0: No fixed length fields or elements
* 1: All fixed length fields and any requested elements
* in the Request info element if present
* 2: All fixed length fields and elements
* 3-255: Reserved
*/
/* report_detail = 0 */
if (prm->q.opt.bcn.rep_detail == 0
|| prm->q.opt.bcn.rep_detail > 2) {
return pframe;
}
/* ID */
val8 = 1; /* 1:reported frame body */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
plen = pframe;
val8 = 0;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* report_detail = 2 */
if (prm->q.opt.bcn.rep_detail == 2) {
pframe = rtw_set_fixed_ie(pframe, pbss->IELength - 4,
pbss->IEs, &my_len); /* -4 remove FCS */
goto done;
}
/* report_detail = 1 */
/* all fixed lenght fields */
pframe = rtw_set_fixed_ie(pframe,
_FIXED_IE_LENGTH_, pbss->IEs, &my_len);
for (j = 0; j < prm->q.opt.bcn.opt_id_num; j++) {
switch (prm->q.opt.bcn.opt_id[j]) {
case bcn_req_ssid:
/* SSID */
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: bcn_req_ssid\n");
#endif
pframe = rtw_set_ie(pframe, _SSID_IE_,
pbss->Ssid.SsidLength,
pbss->Ssid.Ssid, &my_len);
break;
case bcn_req_req:
if (prm->q.opt.bcn.req_start == NULL)
break;
#if (RM_MORE_DBG_MSG)
RTW_INFO("RM: bcn_req_req");
#endif
for (k=0; kq.opt.bcn.req_len; k++) {
eid = prm->q.opt.bcn.req_start[k];
val8 = pbss->IELength - _FIXED_IE_LENGTH_;
ptr = rtw_get_ie(pbss->IEs + _FIXED_IE_LENGTH_,
eid, &len, val8);
if (!ptr)
continue;
#if (RM_MORE_DBG_MSG)
switch (eid) {
case EID_QBSSLoad:
RTW_INFO("RM: EID_QBSSLoad\n");
break;
case EID_HTCapability:
RTW_INFO("RM: EID_HTCapability\n");
break;
case _MDIE_:
RTW_INFO("RM: EID_MobilityDomain\n");
break;
default:
RTW_INFO("RM: EID %d todo\n",eid);
break;
}
#endif
pframe = rtw_set_ie(pframe, eid,
len,ptr+2, &my_len);
} /* for() */
break;
case bcn_req_ac_ch_rep:
default:
RTW_INFO("RM: OPT %d TODO\n",prm->q.opt.bcn.opt_id[j]);
break;
}
}
done:
/*
* update my length
* content length does NOT include ID and LEN
*/
val8 = my_len - 2;
rtw_set_fixed_ie(plen, 1, &val8, &j);
/* update length to caller */
*fr_len += my_len;
return pframe;
}
static u8 rm_get_rcpi(struct rm_obj *prm, struct wlan_network *pnetwork)
{
return translate_percentage_to_rcpi(
pnetwork->network.PhyInfo.SignalStrength);
}
static u8 rm_get_rsni(struct rm_obj *prm, struct wlan_network *pnetwork)
{
int i;
u8 val8, snr;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(prm->psta->padapter);
if (pnetwork->network.PhyInfo.is_cck_rate) {
/* current HW doesn't have CCK RSNI */
/* 255 indicates RSNI is unavailable */
val8 = 255;
} else {
snr = 0;
for (i = 0; i < pHalData->NumTotalRFPath; i++) {
snr += pnetwork->network.PhyInfo.rx_snr[i];
}
snr = snr / pHalData->NumTotalRFPath;
val8 = (u8)(snr + 10)*2;
}
return val8;
}
u8 rm_bcn_req_cond_mach(struct rm_obj *prm, struct wlan_network *pnetwork)
{
u8 val8;
switch(prm->q.opt.bcn.rep_cond.cond) {
case bcn_rep_cond_immediately:
return _SUCCESS;
case bcn_req_cond_rcpi_greater:
val8 = rm_get_rcpi(prm, pnetwork);
if (val8 > prm->q.opt.bcn.rep_cond.threshold)
return _SUCCESS;
break;
case bcn_req_cond_rcpi_less:
val8 = rm_get_rcpi(prm, pnetwork);
if (val8 < prm->q.opt.bcn.rep_cond.threshold)
return _SUCCESS;
break;
case bcn_req_cond_rsni_greater:
val8 = rm_get_rsni(prm, pnetwork);
if (val8 != 255 && val8 > prm->q.opt.bcn.rep_cond.threshold)
return _SUCCESS;
break;
case bcn_req_cond_rsni_less:
val8 = rm_get_rsni(prm, pnetwork);
if (val8 != 255 && val8 < prm->q.opt.bcn.rep_cond.threshold)
return _SUCCESS;
break;
default:
RTW_ERR("RM: bcn_req cond %u not support\n",
prm->q.opt.bcn.rep_cond.cond);
break;
}
return _FALSE;
}
static u8 *rm_bcn_rep_fill_scan_resule (struct rm_obj *prm,
u8 *pframe, struct wlan_network *pnetwork, unsigned int *fr_len)
{
int snr, i;
u8 val8, *plen;
u16 val16;
u32 val32;
u64 val64;
PWLAN_BSSID_EX pbss;
unsigned int my_len;
_adapter *padapter = prm->psta->padapter;
my_len = 0;
/* meas ID */
val8 = EID_MeasureReport;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* remember position form elelment length */
plen = pframe;
/* meas_rpt_len */
/* default 3 = mode + token + type but no beacon content */
val8 = 3;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* meas_token */
val8 = prm->q.m_token;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* meas_rpt_mode F8-141 */
val8 = prm->p.m_mode;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* meas_type T8-81 */
val8 = bcn_rep;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
if (pnetwork == NULL)
goto done;
pframe = rtw_set_fixed_ie(pframe, 1, &prm->q.op_class, &my_len);
/* channel */
pbss = &pnetwork->network;
val8 = pbss->Configuration.DSConfig;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* Actual Measurement StartTime */
val64 = cpu_to_le64(prm->meas_start_time);
pframe = rtw_set_fixed_ie(pframe, 8, (u8 *)&val64, &my_len);
/* Measurement Duration */
val16 = prm->meas_end_time - prm->meas_start_time;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
/* TODO
* ReportedFrameInformation:
* 0 :beacon or probe rsp
* 1 :pilot frame
*/
val8 = 0; /* report frame info */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* RCPI */
val8 = rm_get_rcpi(prm, pnetwork);
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* RSNI */
val8 = rm_get_rsni(prm, pnetwork);
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* BSSID */
pframe = rtw_set_fixed_ie(pframe, 6, (u8 *)&pbss->MacAddress, &my_len);
/*
* AntennaID
* 0: unknown
* 255: multiple antenna (Diversity)
*/
val8 = 0;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* ParentTSF */
val32 = prm->meas_start_time + pnetwork->network.PhyInfo.free_cnt;
pframe = rtw_set_fixed_ie(pframe, 4, (u8 *)&val32, &my_len);
/*
* Generate Beacon detail
*/
pframe = rm_gen_bcn_detail_elem(padapter, pframe,
prm, pnetwork, &my_len);
done:
/*
* update my length
* content length does NOT include ID and LEN
*/
val8 = my_len - 2;
rtw_set_fixed_ie(plen, 1, &val8, &i);
/* update length to caller */
*fr_len += my_len;
return pframe;
}
static u8 *rm_gen_bcn_rep_ie (struct rm_obj *prm,
u8 *pframe, struct wlan_network *pnetwork, unsigned int *fr_len)
{
int snr, i;
u8 val8, *plen;
u16 val16;
u32 val32;
u64 val64;
unsigned int my_len;
_adapter *padapter = prm->psta->padapter;
my_len = 0;
plen = pframe + 1;
pframe = rtw_set_fixed_ie(pframe, 7, &prm->p.e_id, &my_len);
/* Actual Measurement StartTime */
val64 = cpu_to_le64(prm->meas_start_time);
pframe = rtw_set_fixed_ie(pframe, 8, (u8 *)&val64, &my_len);
/* Measurement Duration */
val16 = prm->meas_end_time - prm->meas_start_time;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, 2, (u8*)&val16, &my_len);
/* TODO
* ReportedFrameInformation:
* 0 :beacon or probe rsp
* 1 :pilot frame
*/
val8 = 0; /* report frame info */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* RCPI */
val8 = rm_get_rcpi(prm, pnetwork);
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* RSNI */
val8 = rm_get_rsni(prm, pnetwork);
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* BSSID */
pframe = rtw_set_fixed_ie(pframe, 6,
(u8 *)&pnetwork->network.MacAddress, &my_len);
/*
* AntennaID
* 0: unknown
* 255: multiple antenna (Diversity)
*/
val8 = 0;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* ParentTSF */
val32 = prm->meas_start_time + pnetwork->network.PhyInfo.free_cnt;
pframe = rtw_set_fixed_ie(pframe, 4, (u8 *)&val32, &my_len);
/* Generate Beacon detail */
pframe = rm_gen_bcn_detail_elem(padapter, pframe,
prm, pnetwork, &my_len);
done:
/*
* update my length
* content length does NOT include ID and LEN
*/
val8 = my_len - 2;
rtw_set_fixed_ie(plen, 1, &val8, &i);
/* update length to caller */
*fr_len += my_len;
return pframe;
}
static int retrieve_scan_result(struct rm_obj *prm)
{
_irqL irqL;
_list *plist, *phead;
_queue *queue;
_adapter *padapter = prm->psta->padapter;
struct rtw_ieee80211_channel *pch_set;
struct wlan_network *pnetwork = NULL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
int i, meas_ch_num=0;
PWLAN_BSSID_EX pbss;
unsigned int matched_network;
int len, my_len;
u8 buf_idx, *pbuf = NULL, *tmp_buf = NULL;
tmp_buf = rtw_malloc(MAX_XMIT_EXTBUF_SZ);
if (tmp_buf == NULL)
return 0;
my_len = 0;
buf_idx = 0;
matched_network = 0;
queue = &(pmlmepriv->scanned_queue);
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
/* get requested measurement channel set */
pch_set = prm->q.ch_set;
meas_ch_num = prm->q.ch_set_ch_amount;
/* search scan queue to find requested SSID */
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
pbss = &pnetwork->network;
/*
* report network if requested channel set contains
* the channel matchs selected network
*/
if (rtw_chset_search_ch(adapter_to_chset(padapter),
pbss->Configuration.DSConfig) == 0)
goto next;
if (rtw_mlme_band_check(padapter, pbss->Configuration.DSConfig)
== _FALSE)
goto next;
if (rtw_validate_ssid(&(pbss->Ssid)) == _FALSE)
goto next;
/* go through measurement requested channels */
for (i = 0; i < meas_ch_num; i++) {
/* match channel */
if (pch_set[i].hw_value != pbss->Configuration.DSConfig)
continue;
/* match bssid */
if (is_wildcard_bssid(prm->q.bssid) == FALSE)
if (_rtw_memcmp(prm->q.bssid,
pbss->MacAddress, 6) == _FALSE) {
continue;
}
/*
* default wildcard SSID. wildcard SSID:
* A SSID value (null) used to represent all SSIDs
*/
/* match ssid */
if ((prm->q.opt.bcn.ssid.SsidLength > 0) &&
_rtw_memcmp(prm->q.opt.bcn.ssid.Ssid,
pbss->Ssid.Ssid,
prm->q.opt.bcn.ssid.SsidLength) == _FALSE)
continue;
/* match condition */
if (rm_bcn_req_cond_mach(prm, pnetwork) == _FALSE) {
RTW_INFO("RM: condition mismatch ch %u ssid %s bssid "MAC_FMT"\n",
pch_set[i].hw_value, pbss->Ssid.Ssid,
MAC_ARG(pbss->MacAddress));
RTW_INFO("RM: condition %u:%u\n",
prm->q.opt.bcn.rep_cond.cond,
prm->q.opt.bcn.rep_cond.threshold);
continue;
}
/* Found a matched SSID */
matched_network++;
RTW_INFO("RM: ch %u Found %s bssid "MAC_FMT"\n",
pch_set[i].hw_value, pbss->Ssid.Ssid,
MAC_ARG(pbss->MacAddress));
len = 0;
_rtw_memset(tmp_buf, 0, MAX_XMIT_EXTBUF_SZ);
rm_gen_bcn_rep_ie(prm, tmp_buf, pnetwork, &len);
new_packet:
if (my_len == 0) {
pbuf = rtw_malloc(MAX_XMIT_EXTBUF_SZ);
if (pbuf == NULL)
goto fail;
prm->buf[buf_idx].pbuf = pbuf;
}
if ((MAX_XMIT_EXTBUF_SZ - (my_len+len+24+4)) > 0) {
pbuf = rtw_set_fixed_ie(pbuf,
len, tmp_buf, &my_len);
prm->buf[buf_idx].len = my_len;
} else {
if (my_len == 0) /* not enough space */
goto fail;
my_len = 0;
buf_idx++;
goto new_packet;
}
} /* for() */
next:
plist = get_next(plist);
} /* while() */
fail:
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
if (tmp_buf)
rtw_mfree(tmp_buf, MAX_XMIT_EXTBUF_SZ);
RTW_INFO("RM: Found %d matched %s\n", matched_network,
prm->q.opt.bcn.ssid.Ssid);
if (prm->buf[buf_idx].pbuf)
return buf_idx+1;
return 0;
}
int issue_beacon_rep(struct rm_obj *prm)
{
int i, my_len;
u8 *pframe;
_adapter *padapter = prm->psta->padapter;
struct pkt_attrib *pattr;
struct xmit_frame *pmgntframe;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
int pkt_num;
pkt_num = retrieve_scan_result(prm);
if (pkt_num == 0) {
issue_null_reply(prm);
return _SUCCESS;
}
for (i=0;iattrib;
pframe = build_wlan_hdr(padapter,
pmgntframe, prm->psta, WIFI_ACTION);
pframe = rtw_set_fixed_ie(pframe,
3, &prm->p.category, &pattr->pktlen);
my_len = 0;
pframe = rtw_set_fixed_ie(pframe,
prm->buf[i].len, prm->buf[i].pbuf, &my_len);
pattr->pktlen += my_len;
pattr->last_txcmdsz = pattr->pktlen;
dump_mgntframe(padapter, pmgntframe);
}
fail:
for (i=0;ibuf[i].pbuf) {
rtw_mfree(prm->buf[i].pbuf, MAX_XMIT_EXTBUF_SZ);
prm->buf[i].pbuf = NULL;
prm->buf[i].len = 0;
}
}
return _SUCCESS;
}
/* neighbor request */
int issue_nb_req(struct rm_obj *prm)
{
_adapter *padapter = prm->psta->padapter;
struct sta_info *psta = prm->psta;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct xmit_frame *pmgntframe = NULL;
struct pkt_attrib *pattr = NULL;
u8 val8;
u8 *pframe = NULL;
RTW_INFO("RM: %s\n", __func__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
return _FALSE;
}
pattr = &pmgntframe->attrib;
pframe = build_wlan_hdr(padapter, pmgntframe, psta, WIFI_ACTION);
pframe = rtw_set_fixed_ie(pframe,
3, &prm->q.category, &pattr->pktlen);
if (prm->q.pssid) {
u8 sub_ie[64] = {0};
u8 *pie = &sub_ie[2];
RTW_INFO("RM: Send NB Req to "MAC_FMT" for(SSID) %s searching\n",
MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
pmlmepriv->cur_network.network.Ssid.Ssid);
val8 = strlen(prm->q.pssid);
sub_ie[0] = 0; /*SSID*/
sub_ie[1] = val8;
_rtw_memcpy(pie, prm->q.pssid, val8);
pframe = rtw_set_fixed_ie(pframe, val8 + 2,
sub_ie, &pattr->pktlen);
} else {
if (!pmlmepriv->cur_network.network.Ssid.SsidLength)
RTW_INFO("RM: Send NB Req to "MAC_FMT"\n",
MAC_ARG(pmlmepriv->cur_network.network.MacAddress));
else {
u8 sub_ie[64] = {0};
u8 *pie = &sub_ie[2];
RTW_INFO("RM: Send NB Req to "MAC_FMT" for(SSID) %s searching\n",
MAC_ARG(pmlmepriv->cur_network.network.MacAddress),
pmlmepriv->cur_network.network.Ssid.Ssid);
sub_ie[0] = 0; /*SSID*/
sub_ie[1] = pmlmepriv->cur_network.network.Ssid.SsidLength;
_rtw_memcpy(pie, pmlmepriv->cur_network.network.Ssid.Ssid,
pmlmepriv->cur_network.network.Ssid.SsidLength);
pframe = rtw_set_fixed_ie(pframe,
pmlmepriv->cur_network.network.Ssid.SsidLength + 2,
sub_ie, &pattr->pktlen);
}
}
pattr->last_txcmdsz = pattr->pktlen;
dump_mgntframe(padapter, pmgntframe);
return _SUCCESS;
}
static u8 *rm_gen_bcn_req_s_elem(_adapter *padapter,
u8 *pframe, unsigned int *fr_len)
{
u8 val8;
unsigned int my_len = 0;
u8 bssid[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
val8 = bcn_req_active; /* measurement mode T8-64 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
pframe = rtw_set_fixed_ie(pframe, 6, bssid, &my_len);
/* update length to caller */
*fr_len += my_len;
/* optional subelements */
return pframe;
}
static u8 *rm_gen_ch_load_req_s_elem(_adapter *padapter,
u8 *pframe, unsigned int *fr_len)
{
u8 val8;
unsigned int my_len = 0;
val8 = 1; /* 1: channel load T8-60 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
val8 = 2; /* channel load length = 2 (extensible) */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
val8 = 0; /* channel load condition : 0 (issue when meas done) T8-61 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
val8 = 0; /* channel load reference value : 0 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* update length to caller */
*fr_len += my_len;
return pframe;
}
static u8 *rm_gen_noise_histo_req_s_elem(_adapter *padapter,
u8 *pframe, unsigned int *fr_len)
{
u8 val8;
unsigned int my_len = 0;
val8 = 1; /* 1: noise histogram T8-62 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
val8 = 2; /* noise histogram length = 2 (extensible) */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
val8 = 0; /* noise histogram condition : 0 (issue when meas done) T8-63 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
val8 = 0; /* noise histogram reference value : 0 */
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* update length to caller */
*fr_len += my_len;
return pframe;
}
int issue_radio_meas_req(struct rm_obj *prm)
{
u8 val8;
u8 *pframe;
u8 *plen;
u16 val16;
int my_len, i;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattr;
_adapter *padapter = prm->psta->padapter;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
RTW_INFO("RM: %s - %s\n", __func__, rm_type_req_name(prm->q.m_type));
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
RTW_ERR("RM: %s alloc xmit_frame fail\n",__func__);
return _FALSE;
}
pattr = &pmgntframe->attrib;
pframe = build_wlan_hdr(padapter, pmgntframe, prm->psta, WIFI_ACTION);
pframe = rtw_set_fixed_ie(pframe, 3, &prm->q.category, &pattr->pktlen);
/* repeat */
val16 = cpu_to_le16(prm->q.rpt);
pframe = rtw_set_fixed_ie(pframe, 2,
(unsigned char *)&(val16), &pattr->pktlen);
my_len = 0;
plen = pframe + 1;
pframe = rtw_set_fixed_ie(pframe, 7, &prm->q.e_id, &my_len);
/* random interval */
val16 = 100; /* 100 TU */
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
/* measurement duration */
val16 = 100;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
/* optional subelement */
switch (prm->q.m_type) {
case bcn_req:
pframe = rm_gen_bcn_req_s_elem(padapter, pframe, &my_len);
break;
case ch_load_req:
pframe = rm_gen_ch_load_req_s_elem(padapter, pframe, &my_len);
break;
case noise_histo_req:
pframe = rm_gen_noise_histo_req_s_elem(padapter,
pframe, &my_len);
break;
case basic_req:
default:
break;
}
/* length */
val8 = (u8)my_len - 2;
rtw_set_fixed_ie(plen, 1, &val8, &i);
pattr->pktlen += my_len;
pattr->last_txcmdsz = pattr->pktlen;
dump_mgntframe(padapter, pmgntframe);
return _SUCCESS;
}
/* noise histogram */
static u8 rm_get_anpi(struct rm_obj *prm, struct wlan_network *pnetwork)
{
return translate_percentage_to_rcpi(
pnetwork->network.PhyInfo.SignalStrength);
}
int rm_radio_meas_report_cond(struct rm_obj *prm)
{
u8 val8;
int i;
switch (prm->q.m_type) {
case ch_load_req:
val8 = prm->p.ch_load;
switch (prm->q.opt.clm.rep_cond.cond) {
case ch_load_cond_immediately:
return _SUCCESS;
case ch_load_cond_anpi_equal_greater:
if (val8 >= prm->q.opt.clm.rep_cond.threshold)
return _SUCCESS;
case ch_load_cond_anpi_equal_less:
if (val8 <= prm->q.opt.clm.rep_cond.threshold)
return _SUCCESS;
default:
break;
}
break;
case noise_histo_req:
val8 = prm->p.anpi;
switch (prm->q.opt.nhm.rep_cond.cond) {
case noise_histo_cond_immediately:
return _SUCCESS;
case noise_histo_cond_anpi_equal_greater:
if (val8 >= prm->q.opt.nhm.rep_cond.threshold)
return _SUCCESS;
break;
case noise_histo_cond_anpi_equal_less:
if (val8 <= prm->q.opt.nhm.rep_cond.threshold)
return _SUCCESS;
break;
default:
break;
}
break;
default:
break;
}
return _FAIL;
}
int retrieve_radio_meas_result(struct rm_obj *prm)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(prm->psta->padapter);
int i, ch = -1;
u8 val8;
ch = rtw_chset_search_ch(adapter_to_chset(prm->psta->padapter),
prm->q.ch_num);
if ((ch == -1) || (ch >= MAX_CHANNEL_NUM)) {
RTW_ERR("RM: get ch(CH:%d) fail\n", prm->q.ch_num);
ch = 0;
}
switch (prm->q.m_type) {
case ch_load_req:
#ifdef CONFIG_RTW_ACS
val8 = hal_data->acs.clm_ratio[ch];
#else
val8 = 0;
#endif
prm->p.ch_load = val8;
break;
case noise_histo_req:
#ifdef CONFIG_RTW_ACS
/* ANPI */
prm->p.anpi = hal_data->acs.nhm_ratio[ch];
/* IPI 0~10 */
for (i=0;i<11;i++)
prm->p.ipi[i] = hal_data->acs.nhm[ch][i];
#else
val8 = 0;
prm->p.anpi = val8;
for (i=0;i<11;i++)
prm->p.ipi[i] = val8;
#endif
break;
default:
break;
}
return _SUCCESS;
}
int issue_radio_meas_rep(struct rm_obj *prm)
{
u8 val8;
u8 *pframe;
u8 *plen;
u16 val16;
u64 val64;
unsigned int my_len;
_adapter *padapter = prm->psta->padapter;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattr;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct sta_info *psta = prm->psta;
int i;
RTW_INFO("RM: %s\n", __func__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
RTW_ERR("RM: ERR %s alloc xmit_frame fail\n",__func__);
return _FALSE;
}
pattr = &pmgntframe->attrib;
pframe = build_wlan_hdr(padapter, pmgntframe, psta, WIFI_ACTION);
pframe = rtw_set_fixed_ie(pframe, 3,
&prm->p.category, &pattr->pktlen);
my_len = 0;
plen = pframe + 1;
pframe = rtw_set_fixed_ie(pframe, 7, &prm->p.e_id, &my_len);
/* Actual Meas start time - 8 bytes */
val64 = cpu_to_le64(prm->meas_start_time);
pframe = rtw_set_fixed_ie(pframe, 8, (u8 *)&val64, &my_len);
/* measurement duration */
val16 = prm->meas_end_time - prm->meas_start_time;
val16 = cpu_to_le16(val16);
pframe = rtw_set_fixed_ie(pframe, 2, (u8 *)&val16, &my_len);
/* optional subelement */
switch (prm->q.m_type) {
case ch_load_req:
val8 = prm->p.ch_load;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
break;
case noise_histo_req:
/*
* AntennaID
* 0: unknown
* 255: multiple antenna (Diversity)
*/
val8 = 0;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* ANPI */
val8 = prm->p.anpi;
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
/* IPI 0~10 */
for (i=0;i<11;i++) {
val8 = prm->p.ipi[i];
pframe = rtw_set_fixed_ie(pframe, 1, &val8, &my_len);
}
break;
default:
break;
}
done:
/* length */
val8 = (u8)my_len-2;
rtw_set_fixed_ie(plen, 1, &val8, &i); /* use variable i to ignore it */
pattr->pktlen += my_len;
pattr->last_txcmdsz = pattr->pktlen;
dump_mgntframe(padapter, pmgntframe);
return _SUCCESS;
}
void rtw_ap_parse_sta_rm_en_cap(_adapter *padapter,
struct sta_info *psta, struct rtw_ieee802_11_elems *elem)
{
if (elem->rm_en_cap) {
RTW_INFO("assoc.rm_en_cap="RM_CAP_FMT"\n",
RM_CAP_ARG(elem->rm_en_cap));
_rtw_memcpy(psta->rm_en_cap,
(elem->rm_en_cap), elem->rm_en_cap_len);
}
}
void RM_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
int i;
_rtw_memcpy(&padapter->rmpriv.rm_en_cap_assoc, pIE->data, pIE->Length);
RTW_INFO("assoc.rm_en_cap="RM_CAP_FMT"\n", RM_CAP_ARG(pIE->data));
}
/* Debug command */
#if (RM_SUPPORT_IWPRIV_DBG)
static int hex2num(char c)
{
if (c >= '0' && c <= '9')
return c - '0';
if (c >= 'a' && c <= 'f')
return c - 'a' + 10;
if (c >= 'A' && c <= 'F')
return c - 'A' + 10;
return -1;
}
int hex2byte(const char *hex)
{
int a, b;
a = hex2num(*hex++);
if (a < 0)
return -1;
b = hex2num(*hex++);
if (b < 0)
return -1;
return (a << 4) | b;
}
static char * hwaddr_parse(char *txt, u8 *addr)
{
size_t i;
for (i = 0; i < ETH_ALEN; i++) {
int a;
a = hex2byte(txt);
if (a < 0)
return NULL;
txt += 2;
addr[i] = a;
if (i < ETH_ALEN - 1 && *txt++ != ':')
return NULL;
}
return txt;
}
void rm_dbg_list_sta(_adapter *padapter, char *s)
{
int i;
_irqL irqL;
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
_list *plist, *phead;
sprintf(pstr(s), "\n");
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist,
struct sta_info, hash_list);
plist = get_next(plist);
sprintf(pstr(s), "=========================================\n");
sprintf(pstr(s), "mac=" MAC_FMT "\n",
MAC_ARG(psta->cmn.mac_addr));
sprintf(pstr(s), "state=0x%x, aid=%d, macid=%d\n",
psta->state, psta->cmn.aid, psta->cmn.mac_id);
sprintf(pstr(s), "rm_cap="RM_CAP_FMT"\n",
RM_CAP_ARG(psta->rm_en_cap));
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
sprintf(pstr(s), "=========================================\n");
}
void rm_dbg_help(_adapter *padapter, char *s)
{
int i;
sprintf(pstr(s), "\n");
sprintf(pstr(s), "rrm list_sta\n");
sprintf(pstr(s), "rrm list_meas\n");
sprintf(pstr(s), "rrm add_meas ,m=,rpt=\n");
sprintf(pstr(s), "rrm run_meas \n");
sprintf(pstr(s), "rrm del_meas\n");
sprintf(pstr(s), "rrm run_meas rmid=xxxx,ev=xx\n");
sprintf(pstr(s), "rrm activate\n");
for (i=0;istapriv;
_list *plist, *phead;
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist,
struct sta_info, hash_list);
plist = get_next(plist);
if (psta->cmn.aid == aid)
goto done;
if (pbssid && _rtw_memcmp(psta->cmn.mac_addr,
pbssid, 6))
goto done;
}
}
psta = NULL;
done:
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
return psta;
}
static int rm_dbg_modify_meas(_adapter *padapter, char *s)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
struct mlme_ext_info *pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
struct rm_obj *prm;
struct sta_info *psta;
char *pmac, *ptr, *paid, *prpt, *pnbp, *pclm, *pnhm, *pbcn;
unsigned val;
u8 bssid[ETH_ALEN];
/* example :
* rrm add_meas ,m=,
* rrm run_meas
*/
paid = strstr(s, "aid=");
pmac = strstr(s, "mac=");
pbcn = strstr(s, "m=bcn");
pclm = strstr(s, "m=clm");
pnhm = strstr(s, "m=nhm");
pnbp = strstr(s, "m=nb");
prpt = strstr(s, "rpt=");
/* set all ',' to NULL (end of line) */
ptr = s;
while (ptr) {
ptr = strchr(ptr, ',');
if (ptr) {
*(ptr) = 0x0;
ptr++;
}
}
prm = (struct rm_obj *)prmpriv->prm_sel;
prm->q.m_token = 1;
psta = prm->psta;
if (paid) { /* find sta_info according to aid */
paid += 4; /* skip aid= */
sscanf(paid, "%u", &val); /* aid=x */
psta = rm_get_sta(padapter, val, NULL);
} else if (pmac) { /* find sta_info according to bssid */
pmac += 4; /* skip mac= */
if (hwaddr_parse(pmac, bssid) == NULL) {
sprintf(pstr(s), "Err: \nincorrect mac format\n");
return _FAIL;
}
psta = rm_get_sta(padapter, 0xff, bssid);
}
if (psta) {
prm->psta = psta;
#if 0
prm->q.diag_token = psta->rm_diag_token++;
#else
/* TODO dialog should base on sta_info */
prm->q.diag_token = pmlmeinfo->dialogToken++;
#endif
prm->rmid = psta->cmn.aid << 16
| prm->q.diag_token << 8
| RM_MASTER;
} else
return _FAIL;
prm->q.action_code = RM_ACT_RADIO_MEAS_REQ;
if (pbcn) {
prm->q.m_type = bcn_req;
} else if (pnhm) {
prm->q.m_type = noise_histo_req;
} else if (pclm) {
prm->q.m_type = ch_load_req;
} else if (pnbp) {
prm->q.action_code = RM_ACT_NB_REP_REQ;
} else
return _FAIL;
if (prpt) {
prpt += 4; /* skip rpt= */
sscanf(prpt, "%u", &val);
prm->q.rpt = (u8)val;
}
return _SUCCESS;
}
static void rm_dbg_activate_meas(_adapter *padapter, char *s)
{
struct rm_priv *prmpriv = &(padapter->rmpriv);
struct rm_obj *prm;
if (prmpriv->prm_sel == NULL) {
sprintf(pstr(s), "\nErr: No inActivate measurement\n");
return;
}
prm = (struct rm_obj *)prmpriv->prm_sel;
/* verify attributes */
if (prm->psta == NULL) {
sprintf(pstr(s), "\nErr: inActivate meas has no psta\n");
return;
}
/* measure current channel */
prm->q.ch_num = padapter->mlmeextpriv.cur_channel;
prm->q.op_class = rm_get_oper_class_via_ch(prm->q.ch_num);
/* enquee rmobj */
rm_enqueue_rmobj(padapter, prm, _FALSE);
sprintf(pstr(s), "\nActivate rmid=%x, state=%s, meas_type=%s\n",
prm->rmid, rm_state_name(prm->state),
rm_type_req_name(prm->q.m_type));
sprintf(pstr(s), "aid=%d, mac=" MAC_FMT "\n",
prm->psta->cmn.aid, MAC_ARG(prm->psta->cmn.mac_addr));
/* clearn inActivate prm info */
prmpriv->prm_sel = NULL;
}
static void rm_dbg_add_meas(_adapter *padapter, char *s)
{
struct rm_priv *prmpriv = &(padapter->rmpriv);
struct rm_obj *prm;
char *pact;
/* example :
* rrm add_meas ,m=
* rrm run_meas
*/
prm = (struct rm_obj *)prmpriv->prm_sel;
if (prm == NULL)
prm = rm_alloc_rmobj(padapter);
if (prm == NULL) {
sprintf(pstr(s), "\nErr: alloc meas fail\n");
return;
}
prmpriv->prm_sel = prm;
pact = strstr(s, "act");
if (rm_dbg_modify_meas(padapter, s) == _FAIL) {
sprintf(pstr(s), "\nErr: add meas fail\n");
rm_free_rmobj(prm);
prmpriv->prm_sel = NULL;
return;
}
prm->q.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
prm->q.e_id = _MEAS_REQ_IE_; /* 38 */
if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ)
sprintf(pstr(s), "\nAdd rmid=%x, meas_type=%s ok\n",
prm->rmid, rm_type_req_name(prm->q.m_type));
else if (prm->q.action_code == RM_ACT_NB_REP_REQ)
sprintf(pstr(s), "\nAdd rmid=%x, meas_type=bcn_req ok\n",
prm->rmid);
if (prm->psta)
sprintf(pstr(s), "mac="MAC_FMT"\n",
MAC_ARG(prm->psta->cmn.mac_addr));
if (pact)
rm_dbg_activate_meas(padapter, pstr(s));
}
static void rm_dbg_del_meas(_adapter *padapter, char *s)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_obj *prm = (struct rm_obj *)prmpriv->prm_sel;
if (prm) {
sprintf(pstr(s), "\ndelete rmid=%x\n",prm->rmid);
/* free inActivate meas - enqueue yet */
prmpriv->prm_sel = NULL;
rtw_mfree(prmpriv->prm_sel, sizeof(struct rm_obj));
} else
sprintf(pstr(s), "Err: no inActivate measurement\n");
}
static void rm_dbg_run_meas(_adapter *padapter, char *s)
{
struct rm_obj *prm;
char *pevid, *prmid;
u32 rmid, evid;
prmid = strstr(s, "rmid="); /* hex */
pevid = strstr(s, "evid="); /* dec */
if (prmid && pevid) {
prmid += 5; /* rmid= */
sscanf(prmid, "%x", &rmid);
pevid += 5; /* evid= */
sscanf(pevid, "%u", &evid);
} else {
sprintf(pstr(s), "\nErr: incorrect attribute\n");
return;
}
prm = rm_get_rmobj(padapter, rmid);
if (!prm) {
sprintf(pstr(s), "\nErr: measurement not found\n");
return;
}
if (evid >= RM_EV_max) {
sprintf(pstr(s), "\nErr: wrong event id\n");
return;
}
rm_post_event(padapter, prm->rmid, evid);
sprintf(pstr(s), "\npost %s to rmid=%x\n",rm_event_name(evid), rmid);
}
static void rm_dbg_show_meas(struct rm_obj *prm, char *s)
{
struct sta_info *psta;
psta = prm->psta;
if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
sprintf(pstr(s), "\nrmid=%x, meas_type=%s\n",
prm->rmid, rm_type_req_name(prm->q.m_type));
} else if (prm->q.action_code == RM_ACT_NB_REP_REQ) {
sprintf(pstr(s), "\nrmid=%x, action=neighbor_req\n",
prm->rmid);
} else
sprintf(pstr(s), "\nrmid=%x, action=unknown\n",
prm->rmid);
if (psta)
sprintf(pstr(s), "aid=%d, mac="MAC_FMT"\n",
psta->cmn.aid, MAC_ARG(psta->cmn.mac_addr));
sprintf(pstr(s), "clock=%d, state=%s, rpt=%u/%u\n",
(int)ATOMIC_READ(&prm->pclock->counter),
rm_state_name(prm->state), prm->p.rpt, prm->q.rpt);
}
static void rm_dbg_list_meas(_adapter *padapter, char *s)
{
int meas_amount;
_irqL irqL;
struct rm_obj *prm;
struct sta_info *psta;
struct rm_priv *prmpriv = &padapter->rmpriv;
_queue *queue = &prmpriv->rm_queue;
_list *plist, *phead;
sprintf(pstr(s), "\n");
_enter_critical(&queue->lock, &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
meas_amount = 0;
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
prm = LIST_CONTAINOR(plist, struct rm_obj, list);
meas_amount++;
plist = get_next(plist);
psta = prm->psta;
sprintf(pstr(s), "=========================================\n");
rm_dbg_show_meas(prm, s);
}
_exit_critical(&queue->lock, &irqL);
sprintf(pstr(s), "=========================================\n");
if (meas_amount==0) {
sprintf(pstr(s), "No Activate measurement\n");
sprintf(pstr(s), "=========================================\n");
}
if (prmpriv->prm_sel == NULL)
sprintf(pstr(s), "\nNo inActivate measurement\n");
else {
sprintf(pstr(s), "\ninActivate measurement\n");
rm_dbg_show_meas((struct rm_obj *)prmpriv->prm_sel, s);
}
}
#endif /* RM_SUPPORT_IWPRIV_DBG */
void rm_dbg_cmd(_adapter *padapter, char *s)
{
unsigned val;
char *paid;
struct sta_info *psta=NULL;
#if (RM_SUPPORT_IWPRIV_DBG)
if (_rtw_memcmp(s, "help", 4)) {
rm_dbg_help(padapter, s);
} else if (_rtw_memcmp(s, "list_sta", 8)) {
rm_dbg_list_sta(padapter, s);
} else if (_rtw_memcmp(s, "list_meas", 9)) {
rm_dbg_list_meas(padapter, s);
} else if (_rtw_memcmp(s, "add_meas", 8)) {
rm_dbg_add_meas(padapter, s);
} else if (_rtw_memcmp(s, "del_meas", 8)) {
rm_dbg_del_meas(padapter, s);
} else if (_rtw_memcmp(s, "activate", 8)) {
rm_dbg_activate_meas(padapter, s);
} else if (_rtw_memcmp(s, "run_meas", 8)) {
rm_dbg_run_meas(padapter, s);
} else if (_rtw_memcmp(s, "nb", 2)) {
paid = strstr(s, "aid=");
if (paid) { /* find sta_info according to aid */
paid += 4; /* skip aid= */
sscanf(paid, "%u", &val); /* aid=x */
psta = rm_get_sta(padapter, val, NULL);
if (psta)
rm_add_nb_req(padapter, psta);
}
}
#else
sprintf(pstr(s), "\n");
sprintf(pstr(s), "rrm debug command was disabled\n");
#endif
}
#endif /* CONFIG_RTW_80211K */
================================================
FILE: core/rtw_rm_fsm.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#include "rtw_rm_fsm.h"
#ifdef CONFIG_RTW_80211K
struct fsm_state {
u8 *name;
int(*fsm_func)(struct rm_obj *prm, enum RM_EV_ID evid);
};
static void rm_state_initial(struct rm_obj *prm);
static void rm_state_goto(struct rm_obj *prm, enum RM_STATE rm_state);
static void rm_state_run(struct rm_obj *prm, enum RM_EV_ID evid);
static struct rm_event *rm_dequeue_ev(_queue *queue);
static struct rm_obj *rm_dequeue_rm(_queue *queue);
void rm_timer_callback(void *data)
{
int i;
_adapter *padapter = (_adapter *)data;
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_clock *pclock;
/* deal with clock */
for (i=0;iclock[i];
if (pclock->prm == NULL
||(ATOMIC_READ(&(pclock->counter)) == 0))
continue;
ATOMIC_DEC(&(pclock->counter));
if (ATOMIC_READ(&(pclock->counter)) == 0)
rm_post_event(pclock->prm->psta->padapter,
pclock->prm->rmid, prmpriv->clock[i].evid);
}
_set_timer(&prmpriv->rm_timer, CLOCK_UNIT);
}
int rtw_init_rm(_adapter *padapter)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
RTW_INFO("RM: %s\n",__func__);
_rtw_init_queue(&(prmpriv->rm_queue));
_rtw_init_queue(&(prmpriv->ev_queue));
/* bit 0-7 */
prmpriv->rm_en_cap_def[0] = 0
/*| BIT(RM_LINK_MEAS_CAP_EN)*/
| BIT(RM_NB_REP_CAP_EN)
/*| BIT(RM_PARAL_MEAS_CAP_EN)*/
| BIT(RM_REPEAT_MEAS_CAP_EN)
| BIT(RM_BCN_PASSIVE_MEAS_CAP_EN)
| BIT(RM_BCN_ACTIVE_MEAS_CAP_EN)
| BIT(RM_BCN_TABLE_MEAS_CAP_EN)
/*| BIT(RM_BCN_MEAS_REP_COND_CAP_EN)*/;
/* bit 8-15 */
prmpriv->rm_en_cap_def[1] = 0
/*| BIT(RM_FRAME_MEAS_CAP_EN - 8)*/
#ifdef CONFIG_RTW_ACS
| BIT(RM_CH_LOAD_CAP_EN - 8)
| BIT(RM_NOISE_HISTO_CAP_EN - 8)
#endif
/*| BIT(RM_STATIS_MEAS_CAP_EN - 8)*/
/*| BIT(RM_LCI_MEAS_CAP_EN - 8)*/
/*| BIT(RM_LCI_AMIMUTH_CAP_EN - 8)*/
/*| BIT(RM_TRANS_STREAM_CAT_MEAS_CAP_EN - 8)*/
/*| BIT(RM_TRIG_TRANS_STREAM_CAT_MEAS_CAP_EN - 8)*/;
/* bit 16-23 */
prmpriv->rm_en_cap_def[2] = 0
/*| BIT(RM_AP_CH_REP_CAP_EN - 16)*/
/*| BIT(RM_RM_MIB_CAP_EN - 16)*/
/*| BIT(RM_OP_CH_MAX_MEAS_DUR0 - 16)*/
/*| BIT(RM_OP_CH_MAX_MEAS_DUR1 - 16)*/
/*| BIT(RM_OP_CH_MAX_MEAS_DUR2 - 16)*/
/*| BIT(RM_NONOP_CH_MAX_MEAS_DUR0 - 16)*/
/*| BIT(RM_NONOP_CH_MAX_MEAS_DUR1 - 16)*/
/*| BIT(RM_NONOP_CH_MAX_MEAS_DUR2 - 16)*/;
/* bit 24-31 */
prmpriv->rm_en_cap_def[3] = 0
/*| BIT(RM_MEAS_PILOT_CAP0 - 24)*/
/*| BIT(RM_MEAS_PILOT_CAP1 - 24)*/
/*| BIT(RM_MEAS_PILOT_CAP2 - 24)*/
/*| BIT(RM_MEAS_PILOT_TRANS_INFO_CAP_EN - 24)*/
/*| BIT(RM_NB_REP_TSF_OFFSET_CAP_EN - 24)*/
| BIT(RM_RCPI_MEAS_CAP_EN - 24)
| BIT(RM_RSNI_MEAS_CAP_EN - 24)
/*| BIT(RM_BSS_AVG_ACCESS_DELAY_CAP_EN - 24)*/;
/* bit 32-39 */
prmpriv->rm_en_cap_def[4] = 0
/*| BIT(RM_BSS_AVG_ACCESS_DELAY_CAP_EN - 32)*/
/*| BIT(RM_AVALB_ADMIS_CAPACITY_CAP_EN - 32)*/
/*| BIT(RM_ANT_CAP_EN - 32)*/;
prmpriv->enable = _TRUE;
/* clock timer */
rtw_init_timer(&prmpriv->rm_timer,
padapter, rm_timer_callback, padapter);
_set_timer(&prmpriv->rm_timer, CLOCK_UNIT);
return _SUCCESS;
}
int rtw_deinit_rm(_adapter *padapter)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_obj *prm;
struct rm_event *pev;
RTW_INFO("RM: %s\n",__func__);
prmpriv->enable = _FALSE;
_cancel_timer_ex(&prmpriv->rm_timer);
/* free all events and measurements */
while((pev = rm_dequeue_ev(&prmpriv->ev_queue)) != NULL)
rtw_mfree((void *)pev, sizeof(struct rm_event));
while((prm = rm_dequeue_rm(&prmpriv->rm_queue)) != NULL)
rm_state_run(prm, RM_EV_cancel);
_rtw_deinit_queue(&(prmpriv->rm_queue));
_rtw_deinit_queue(&(prmpriv->ev_queue));
return _SUCCESS;
}
int rtw_free_rm_priv(_adapter *padapter)
{
return rtw_deinit_rm(padapter);
}
static int rm_enqueue_ev(_queue *queue, struct rm_event *obj, bool to_head)
{
_irqL irqL;
if (obj == NULL)
return _FAIL;
_enter_critical(&queue->lock, &irqL);
if (to_head)
rtw_list_insert_head(&obj->list, &queue->queue);
else
rtw_list_insert_tail(&obj->list, &queue->queue);
_exit_critical(&queue->lock, &irqL);
return _SUCCESS;
}
static void rm_set_clock(struct rm_obj *prm, u32 ms, enum RM_EV_ID evid)
{
ATOMIC_SET(&(prm->pclock->counter), (ms/CLOCK_UNIT));
prm->pclock->evid = evid;
}
static struct rm_clock *rm_alloc_clock(_adapter *padapter, struct rm_obj *prm)
{
int i;
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_clock *pclock = NULL;
for (i=0;iclock[i];
if (pclock->prm == NULL) {
pclock->prm = prm;
ATOMIC_SET(&(pclock->counter), 0);
pclock->evid = RM_EV_max;
break;
}
}
return pclock;
}
static void rm_cancel_clock(struct rm_obj *prm)
{
ATOMIC_SET(&(prm->pclock->counter), 0);
prm->pclock->evid = RM_EV_max;
}
static void rm_free_clock(struct rm_clock *pclock)
{
pclock->prm = NULL;
ATOMIC_SET(&(pclock->counter), 0);
pclock->evid = RM_EV_max;
}
static int is_list_linked(const struct list_head *head)
{
return head->prev != NULL;
}
void rm_free_rmobj(struct rm_obj *prm)
{
if (is_list_linked(&prm->list))
rtw_list_delete(&prm->list);
if (prm->q.pssid)
rtw_mfree(prm->q.pssid, strlen(prm->q.pssid)+1);
if (prm->q.opt.bcn.req_start)
rtw_mfree(prm->q.opt.bcn.req_start,
prm->q.opt.bcn.req_len);
if (prm->pclock)
rm_free_clock(prm->pclock);
rtw_mfree((void *)prm, sizeof(struct rm_obj));
}
struct rm_obj *rm_alloc_rmobj(_adapter *padapter)
{
struct rm_obj *prm;
prm = (struct rm_obj *)rtw_malloc(sizeof(struct rm_obj));
if (prm == NULL)
return NULL;
_rtw_memset(prm, 0, sizeof(struct rm_obj));
/* alloc timer */
if ((prm->pclock = rm_alloc_clock(padapter, prm)) == NULL) {
rm_free_rmobj(prm);
return NULL;
}
return prm;
}
int rm_enqueue_rmobj(_adapter *padapter, struct rm_obj *prm, bool to_head)
{
_irqL irqL;
struct rm_priv *prmpriv = &padapter->rmpriv;
_queue *queue = &prmpriv->rm_queue;
if (prm == NULL)
return _FAIL;
_enter_critical(&queue->lock, &irqL);
if (to_head)
rtw_list_insert_head(&prm->list, &queue->queue);
else
rtw_list_insert_tail(&prm->list, &queue->queue);
_exit_critical(&queue->lock, &irqL);
rm_state_initial(prm);
return _SUCCESS;
}
static struct rm_obj *rm_dequeue_rm(_queue *queue)
{
_irqL irqL;
struct rm_obj *prm;
_enter_critical(&queue->lock, &irqL);
if (rtw_is_list_empty(&(queue->queue)))
prm = NULL;
else {
prm = LIST_CONTAINOR(get_next(&(queue->queue)),
struct rm_obj, list);
/* rtw_list_delete(&prm->list); */
}
_exit_critical(&queue->lock, &irqL);
return prm;
}
static struct rm_event *rm_dequeue_ev(_queue *queue)
{
_irqL irqL;
struct rm_event *ev;
_enter_critical(&queue->lock, &irqL);
if (rtw_is_list_empty(&(queue->queue)))
ev = NULL;
else {
ev = LIST_CONTAINOR(get_next(&(queue->queue)),
struct rm_event, list);
rtw_list_delete(&ev->list);
}
_exit_critical(&queue->lock, &irqL);
return ev;
}
static struct rm_obj *_rm_get_rmobj(_queue *queue, u32 rmid)
{
_irqL irqL;
_list *phead, *plist;
struct rm_obj *prm = NULL;
if (rmid == 0)
return NULL;
_enter_critical(&queue->lock, &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
prm = LIST_CONTAINOR(plist, struct rm_obj, list);
if (rmid == (prm->rmid)) {
_exit_critical(&queue->lock, &irqL);
return prm;
}
plist = get_next(plist);
}
_exit_critical(&queue->lock, &irqL);
return NULL;
}
struct sta_info *rm_get_psta(_adapter *padapter, u32 rmid)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_obj *prm;
prm = _rm_get_rmobj(&prmpriv->rm_queue, rmid);
if (prm)
return prm->psta;
return NULL;
}
struct rm_obj *rm_get_rmobj(_adapter *padapter, u32 rmid)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
return _rm_get_rmobj(&prmpriv->rm_queue, rmid);
}
u8 rtw_rm_post_envent_cmd(_adapter *padapter, u32 rmid, u8 evid)
{
struct cmd_obj *pcmd;
struct rm_event *pev;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 res = _SUCCESS;
pcmd = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (pcmd == NULL) {
res = _FAIL;
goto exit;
}
pev = (struct rm_event*)rtw_zmalloc(sizeof(struct rm_event));
if (pev == NULL) {
rtw_mfree((u8 *) pcmd, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pev->rmid = rmid;
pev->evid = evid;
init_h2fwcmd_w_parm_no_rsp(pcmd, pev, GEN_CMD_CODE(_RM_POST_EVENT));
res = rtw_enqueue_cmd(pcmdpriv, pcmd);
exit:
return res;
}
int rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid)
{
if (padapter->rmpriv.enable == _FALSE)
return _FALSE;
RTW_INFO("RM: post asyn %s to rmid=%x\n", rm_event_name(evid), rmid);
rtw_rm_post_envent_cmd(padapter, rmid, evid);
return _SUCCESS;
}
int _rm_post_event(_adapter *padapter, u32 rmid, enum RM_EV_ID evid)
{
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_event *pev;
if (evid >= RM_EV_max || rmid == 0)
return _FALSE;
pev = (struct rm_event *)rtw_malloc(sizeof(struct rm_event));
if (pev == NULL)
return _FALSE;
pev->rmid = rmid;
pev->evid = evid;
RTW_INFO("RM: post sync %s to rmid=%x\n", rm_event_name(evid), rmid);
rm_enqueue_ev(&prmpriv->ev_queue, pev, FALSE);
return _SUCCESS;
}
static void rm_bcast_aid_handler(_adapter *padapter, struct rm_event *pev)
{
_irqL irqL;
_list *phead, *plist;
_queue *queue = &padapter->rmpriv.rm_queue;
struct rm_obj *prm;
_enter_critical(&queue->lock, &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
prm = LIST_CONTAINOR(plist, struct rm_obj, list);
plist = get_next(plist);
if (RM_GET_AID(pev->rmid) == RM_GET_AID(prm->rmid)) {
_exit_critical(&queue->lock, &irqL);
rm_state_run(prm, pev->evid);
_enter_critical(&queue->lock, &irqL);
}
}
_exit_critical(&queue->lock, &irqL);
return;
}
/* main handler of RM (Resource Management) */
void rm_handler(_adapter *padapter, struct rm_event *pe)
{
int i;
struct rm_priv *prmpriv = &padapter->rmpriv;
struct rm_obj *prm;
struct rm_event *pev;
/* dequeue event */
while((pev = rm_dequeue_ev(&prmpriv->ev_queue)) != NULL)
{
if (RM_IS_ID_FOR_ALL(pev->rmid)) {
/* apply to all aid mateched measurement */
rm_bcast_aid_handler(padapter, pev);
rtw_mfree((void *)pev, sizeof(struct rm_event));
continue;
}
/* retrieve rmobj */
prm = _rm_get_rmobj(&prmpriv->rm_queue, pev->rmid);
if (prm == NULL) {
RTW_ERR("RM: rmid=%x event=%s doesn't find rm obj\n",
pev->rmid, rm_event_name(pev->evid));
rtw_mfree((void *)pev, sizeof(struct rm_event));
return;
}
/* run state machine */
rm_state_run(prm, pev->evid);
rtw_mfree((void *)pev, sizeof(struct rm_event));
}
}
static int rm_issue_meas_req(struct rm_obj *prm)
{
switch (prm->q.action_code) {
case RM_ACT_RADIO_MEAS_REQ:
switch (prm->q.m_type) {
case bcn_req:
case ch_load_req:
case noise_histo_req:
issue_radio_meas_req(prm);
break;
default:
break;
} /* meas_type */
break;
case RM_ACT_NB_REP_REQ:
/* issue neighbor request */
issue_nb_req(prm);
break;
case RM_ACT_LINK_MEAS_REQ:
default:
return _FALSE;
} /* action_code */
return _SUCCESS;
}
/*
* RM state machine
*/
static int rm_state_idle(struct rm_obj *prm, enum RM_EV_ID evid)
{
_adapter *padapter = prm->psta->padapter;
u8 val8;
u32 val32;
prm->p.category = RTW_WLAN_CATEGORY_RADIO_MEAS;
switch (evid) {
case RM_EV_state_in:
switch (prm->q.action_code) {
case RM_ACT_RADIO_MEAS_REQ:
/* copy attrib from meas_req to meas_rep */
prm->p.action_code = RM_ACT_RADIO_MEAS_REP;
prm->p.diag_token = prm->q.diag_token;
prm->p.e_id = _MEAS_RSP_IE_;
prm->p.m_token = prm->q.m_token;
prm->p.m_type = prm->q.m_type;
prm->p.rpt = prm->q.rpt;
prm->p.ch_num = prm->q.ch_num;
prm->p.op_class = prm->q.op_class;
if (prm->q.m_type == ch_load_req
|| prm->q.m_type == noise_histo_req) {
/*
* phydm measure current ch periodically
* scan current ch is not necessary
*/
val8 = padapter->mlmeextpriv.cur_channel;
if (prm->q.ch_num == val8)
prm->poll_mode = 1;
}
RTW_INFO("RM: rmid=%x %s switch in repeat=%u\n",
prm->rmid, rm_type_req_name(prm->q.m_type),
prm->q.rpt);
break;
case RM_ACT_NB_REP_REQ:
prm->p.action_code = RM_ACT_NB_REP_RESP;
RTW_INFO("RM: rmid=%x Neighbor request switch in\n",
prm->rmid);
break;
case RM_ACT_LINK_MEAS_REQ:
prm->p.action_code = RM_ACT_LINK_MEAS_REP;
rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
RTW_INFO("RM: rmid=%x Link meas switch in\n",
prm->rmid);
break;
default:
prm->p.action_code = prm->q.action_code;
rm_set_rep_mode(prm, MEAS_REP_MOD_INCAP);
RTW_INFO("RM: rmid=%x recv unknown action %d\n",
prm->rmid,prm->p.action_code);
break;
} /* switch() */
if (prm->rmid & RM_MASTER) {
if (rm_issue_meas_req(prm) == _SUCCESS)
rm_state_goto(prm, RM_ST_WAIT_MEAS);
else
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
} else {
rm_state_goto(prm, RM_ST_DO_MEAS);
return _SUCCESS;
}
if (prm->p.m_mode) {
issue_null_reply(prm);
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
if (prm->q.rand_intvl) {
/* get low tsf to generate random interval */
val32 = rtw_read32(padapter, REG_TSFTR);
val32 = val32 % prm->q.rand_intvl;
RTW_INFO("RM: rmid=%x rand_intval=%d, rand=%d\n",
prm->rmid, (int)prm->q.rand_intvl,val32);
rm_set_clock(prm, prm->q.rand_intvl,
RM_EV_delay_timer_expire);
return _SUCCESS;
}
break;
case RM_EV_delay_timer_expire:
rm_state_goto(prm, RM_ST_DO_MEAS);
break;
case RM_EV_cancel:
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_state_out:
rm_cancel_clock(prm);
break;
default:
break;
}
return _SUCCESS;
}
/* we do the measuring */
static int rm_state_do_meas(struct rm_obj *prm, enum RM_EV_ID evid)
{
_adapter *padapter = prm->psta->padapter;
u8 val8;
u64 val64;
switch (evid) {
case RM_EV_state_in:
if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
switch (prm->q.m_type) {
case bcn_req:
if (prm->q.m_mode == bcn_req_bcn_table) {
RTW_INFO("RM: rmid=%x Beacon table\n",
prm->rmid);
_rm_post_event(padapter, prm->rmid,
RM_EV_survey_done);
return _SUCCESS;
}
break;
case ch_load_req:
case noise_histo_req:
if (prm->poll_mode)
_rm_post_event(padapter, prm->rmid,
RM_EV_survey_done);
return _SUCCESS;
default:
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
if (!ready_for_scan(prm)) {
prm->wait_busy = RM_BUSY_TRAFFIC_TIMES;
RTW_INFO("RM: wait busy traffic - %d\n",
prm->wait_busy);
rm_set_clock(prm, RM_WAIT_BUSY_TIMEOUT,
RM_EV_busy_timer_expire);
return _SUCCESS;
}
}
_rm_post_event(padapter, prm->rmid, RM_EV_start_meas);
break;
case RM_EV_start_meas:
if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
/* resotre measurement start time */
prm->meas_start_time = rtw_hal_get_tsftr_by_port(padapter
, rtw_hal_get_port(padapter));
switch (prm->q.m_type) {
case bcn_req:
val8 = 1; /* Enable free run counter */
rtw_hal_set_hwreg(padapter,
HW_VAR_FREECNT, &val8);
rm_sitesurvey(prm);
break;
case ch_load_req:
case noise_histo_req:
rm_sitesurvey(prm);
break;
default:
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
break;
}
}
/* handle measurement timeout */
rm_set_clock(prm, RM_MEAS_TIMEOUT, RM_EV_meas_timer_expire);
break;
case RM_EV_survey_done:
if (prm->q.action_code == RM_ACT_RADIO_MEAS_REQ) {
switch (prm->q.m_type) {
case bcn_req:
rm_cancel_clock(prm);
rm_state_goto(prm, RM_ST_SEND_REPORT);
return _SUCCESS;
case ch_load_req:
case noise_histo_req:
retrieve_radio_meas_result(prm);
if (rm_radio_meas_report_cond(prm) == _SUCCESS)
rm_state_goto(prm, RM_ST_SEND_REPORT);
else
rm_set_clock(prm, RM_COND_INTVL,
RM_EV_retry_timer_expire);
break;
default:
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
}
break;
case RM_EV_meas_timer_expire:
RTW_INFO("RM: rmid=%x measurement timeount\n",prm->rmid);
rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
issue_null_reply(prm);
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_busy_timer_expire:
if (!ready_for_scan(prm) && prm->wait_busy--) {
RTW_INFO("RM: wait busy - %d\n",prm->wait_busy);
rm_set_clock(prm, RM_WAIT_BUSY_TIMEOUT,
RM_EV_busy_timer_expire);
break;
}
else if (prm->wait_busy <= 0) {
RTW_INFO("RM: wait busy timeout\n");
rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
issue_null_reply(prm);
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
_rm_post_event(padapter, prm->rmid, RM_EV_start_meas);
break;
case RM_EV_request_timer_expire:
rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
issue_null_reply(prm);
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_retry_timer_expire:
/* expired due to meas condition mismatch, meas again */
_rm_post_event(padapter, prm->rmid, RM_EV_start_meas);
break;
case RM_EV_cancel:
rm_set_rep_mode(prm, MEAS_REP_MOD_REFUSE);
issue_null_reply(prm);
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_state_out:
rm_cancel_clock(prm);
/* resotre measurement end time */
prm->meas_end_time = rtw_hal_get_tsftr_by_port(padapter
, rtw_hal_get_port(padapter));
val8 = 0; /* Disable free run counter */
rtw_hal_set_hwreg(padapter, HW_VAR_FREECNT, &val8);
break;
default:
break;
}
return _SUCCESS;
}
static int rm_state_wait_meas(struct rm_obj *prm, enum RM_EV_ID evid)
{
u8 val8;
u64 val64;
switch (evid) {
case RM_EV_state_in:
/* we create meas_req, waiting for peer report */
rm_set_clock(prm, RM_REQ_TIMEOUT,
RM_EV_request_timer_expire);
break;
case RM_EV_recv_rep:
rm_state_goto(prm, RM_ST_RECV_REPORT);
break;
case RM_EV_request_timer_expire:
case RM_EV_cancel:
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_state_out:
rm_cancel_clock(prm);
break;
default:
break;
}
return _SUCCESS;
}
static int rm_state_send_report(struct rm_obj *prm, enum RM_EV_ID evid)
{
u8 val8;
switch (evid) {
case RM_EV_state_in:
/* we have to issue report */
switch (prm->q.m_type) {
case bcn_req:
issue_beacon_rep(prm);
break;
case ch_load_req:
case noise_histo_req:
issue_radio_meas_rep(prm);
break;
default:
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
/* check repeat */
if (prm->p.rpt) {
RTW_INFO("RM: rmid=%x repeat=%u/%u\n",
prm->rmid, prm->p.rpt,
prm->q.rpt);
prm->p.rpt--;
/*
* we recv meas_req,
* delay for a wihile and than meas again
*/
if (prm->poll_mode)
rm_set_clock(prm, RM_REPT_POLL_INTVL,
RM_EV_repeat_delay_expire);
else
rm_set_clock(prm, RM_REPT_SCAN_INTVL,
RM_EV_repeat_delay_expire);
return _SUCCESS;
}
/* we are done */
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_repeat_delay_expire:
rm_state_goto(prm, RM_ST_DO_MEAS);
break;
case RM_EV_cancel:
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_state_out:
rm_cancel_clock(prm);
break;
default:
break;
}
return _SUCCESS;
}
static int rm_state_recv_report(struct rm_obj *prm, enum RM_EV_ID evid)
{
u8 val8;
switch (evid) {
case RM_EV_state_in:
/* we issue meas_req, got peer's meas report */
switch (prm->p.action_code) {
case RM_ACT_RADIO_MEAS_REP:
/* check refuse, incapable and repeat */
val8 = prm->p.m_mode;
if (val8) {
RTW_INFO("RM: rmid=%x peer reject (%s repeat=%d)\n",
prm->rmid,
val8|MEAS_REP_MOD_INCAP?"INCAP":
val8|MEAS_REP_MOD_REFUSE?"REFUSE":
val8|MEAS_REP_MOD_LATE?"LATE":"",
prm->p.rpt);
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
break;
case RM_ACT_NB_REP_RESP:
/* report to upper layer if needing */
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
default:
rm_state_goto(prm, RM_ST_END);
return _SUCCESS;
}
/* check repeat */
if (prm->p.rpt) {
RTW_INFO("RM: rmid=%x repeat=%u/%u\n",
prm->rmid, prm->p.rpt,
prm->q.rpt);
prm->p.rpt--;
/* waitting more report */
rm_state_goto(prm, RM_ST_WAIT_MEAS);
break;
}
/* we are done */
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_cancel:
rm_state_goto(prm, RM_ST_END);
break;
case RM_EV_state_out:
rm_cancel_clock(prm);
break;
default:
break;
}
return _SUCCESS;
}
static int rm_state_end(struct rm_obj *prm, enum RM_EV_ID evid)
{
switch (evid) {
case RM_EV_state_in:
_rm_post_event(prm->psta->padapter, prm->rmid, RM_EV_state_out);
break;
case RM_EV_cancel:
case RM_EV_state_out:
default:
rm_free_rmobj(prm);
break;
}
return _SUCCESS;
}
struct fsm_state rm_fsm[] = {
{"RM_ST_IDLE", rm_state_idle},
{"RM_ST_DO_MEAS", rm_state_do_meas},
{"RM_ST_WAIT_MEAS", rm_state_wait_meas},
{"RM_ST_SEND_REPORT", rm_state_send_report},
{"RM_ST_RECV_REPORT", rm_state_recv_report},
{"RM_ST_END", rm_state_end}
};
char *rm_state_name(enum RM_STATE state)
{
return rm_fsm[state].name;
}
char *rm_event_name(enum RM_EV_ID evid)
{
switch(evid) {
case RM_EV_state_in:
return "RM_EV_state_in";
case RM_EV_busy_timer_expire:
return "RM_EV_busy_timer_expire";
case RM_EV_delay_timer_expire:
return "RM_EV_delay_timer_expire";
case RM_EV_meas_timer_expire:
return "RM_EV_meas_timer_expire";
case RM_EV_repeat_delay_expire:
return "RM_EV_repeat_delay_expire";
case RM_EV_retry_timer_expire:
return "RM_EV_retry_timer_expire";
case RM_EV_request_timer_expire:
return "RM_EV_request_timer_expire";
case RM_EV_wait_report:
return "RM_EV_wait_report";
case RM_EV_start_meas:
return "RM_EV_start_meas";
case RM_EV_survey_done:
return "RM_EV_survey_done";
case RM_EV_recv_rep:
return "RM_EV_recv_report";
case RM_EV_cancel:
return "RM_EV_cancel";
case RM_EV_state_out:
return "RM_EV_state_out";
case RM_EV_max:
return "RM_EV_max";
default:
return "RM_EV_unknown";
}
return "UNKNOWN";
}
static void rm_state_initial(struct rm_obj *prm)
{
prm->state = RM_ST_IDLE;
RTW_INFO("\n");
RTW_INFO("RM: rmid=%x %-18s -> %s\n",prm->rmid,
"new measurement", rm_fsm[prm->state].name);
rm_post_event(prm->psta->padapter, prm->rmid, RM_EV_state_in);
}
static void rm_state_run(struct rm_obj *prm, enum RM_EV_ID evid)
{
RTW_INFO("RM: rmid=%x %-18s %s\n",prm->rmid,
rm_fsm[prm->state].name,rm_event_name(evid));
rm_fsm[prm->state].fsm_func(prm, evid);
}
static void rm_state_goto(struct rm_obj *prm, enum RM_STATE rm_state)
{
if (prm->state == rm_state)
return;
rm_state_run(prm, RM_EV_state_out);
RTW_INFO("\n");
RTW_INFO("RM: rmid=%x %-18s -> %s\n",prm->rmid,
rm_fsm[prm->state].name, rm_fsm[rm_state].name);
prm->state = rm_state;
rm_state_run(prm, RM_EV_state_in);
}
#endif /* CONFIG_RTW_80211K */
================================================
FILE: core/rtw_rson.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
*
*
******************************************************************************/
#define _RTW_RSON_C_
#include
#ifdef CONFIG_RTW_REPEATER_SON
/******** Custommize Part ***********************/
unsigned char RTW_RSON_OUI[] = {0xFA, 0xFA, 0xFA};
#define RSON_SCORE_DIFF_TH 8
/*
Calculate the corresponding score.
*/
inline u8 rtw_cal_rson_score(struct rtw_rson_struct *cand_rson_data, NDIS_802_11_RSSI Rssi)
{
if ((cand_rson_data->hopcnt == RTW_RSON_HC_NOTREADY)
|| (cand_rson_data->connectible == RTW_RSON_DENYCONNECT))
return RTW_RSON_SCORE_NOTCNNT;
return RTW_RSON_SCORE_MAX - (cand_rson_data->hopcnt * 10) + (Rssi/10);
}
/*************************************************/
static u8 rtw_rson_block_bssid_idx = 0;
u8 rtw_rson_block_bssid[10][6] = {
/*{0x02, 0xE0, 0x4C, 0x07, 0xC3, 0xF6}*/
};
/* fake root, regard a real AP as a SO root */
static u8 rtw_rson_root_bssid_idx = 0;
u8 rtw_rson_root_bssid[10][6] = {
/*{0x1c, 0x5f, 0x2b, 0x5a, 0x60, 0x24}*/
};
int is_match_bssid(u8 *mac, u8 bssid_array[][6], int num)
{
int i;
for (i = 0; i < num; i++)
if (_rtw_memcmp(mac, bssid_array[i], 6) == _TRUE)
return _TRUE;
return _FALSE;
}
void init_rtw_rson_data(struct dvobj_priv *dvobj)
{
/*Aries todo. if pdvobj->rson_data.ver == 1 */
dvobj->rson_data.ver = RTW_RSON_VER;
dvobj->rson_data.id = CONFIG_RTW_REPEATER_SON_ID;
#ifdef CONFIG_RTW_REPEATER_SON_ROOT
dvobj->rson_data.hopcnt = RTW_RSON_HC_ROOT;
dvobj->rson_data.connectible = RTW_RSON_ALLOWCONNECT;
#else
dvobj->rson_data.hopcnt = RTW_RSON_HC_NOTREADY;
dvobj->rson_data.connectible = RTW_RSON_DENYCONNECT;
#endif
dvobj->rson_data.loading = 0;
_rtw_memset(dvobj->rson_data.res, 0xAA, sizeof(dvobj->rson_data.res));
}
void rtw_rson_get_property_str(_adapter *padapter, char *rson_data_str)
{
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
sprintf(rson_data_str, "version : \t%d\nid : \t\t%08x\nhop count : \t%d\nconnectible : \t%s\nloading : \t%d\nreserve : \t%16ph\n",
pdvobj->rson_data.ver,
pdvobj->rson_data.id,
pdvobj->rson_data.hopcnt,
pdvobj->rson_data.connectible ? "connectable":"unconnectable",
pdvobj->rson_data.loading,
pdvobj->rson_data.res);
}
int str2hexbuf(char *str, u8 *hexbuf, int len)
{
u8 *p;
int i, slen, idx = 0;
p = (unsigned char *)str;
if ((*p != '0') || (*(p+1) != 'x'))
return _FALSE;
slen = strlen(str);
if (slen > (len*2) + 2)
return _FALSE;
p += 2;
for (i = 0 ; i < len; i++, idx = idx+2) {
hexbuf[i] = key_2char2num(p[idx], p[idx + 1]);
if (slen <= idx+2)
break;
}
return _TRUE;
}
int rtw_rson_set_property(_adapter *padapter, char *field, char *value)
{
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
int num = 0;
if (_rtw_memcmp(field, (u8 *)"ver", 3) == _TRUE)
pdvobj->rson_data.ver = rtw_atoi(value);
else if (_rtw_memcmp(field, (u8 *)"id", 2) == _TRUE)
num = sscanf(value, "%08x", &(pdvobj->rson_data.id));
else if (_rtw_memcmp(field, (u8 *)"hc", 2) == _TRUE)
num = sscanf(value, "%hhu", &(pdvobj->rson_data.hopcnt));
else if (_rtw_memcmp(field, (u8 *)"cnt", 3) == _TRUE)
num = sscanf(value, "%hhu", &(pdvobj->rson_data.connectible));
else if (_rtw_memcmp(field, (u8 *)"loading", 2) == _TRUE)
num = sscanf(value, "%hhu", &(pdvobj->rson_data.loading));
else if (_rtw_memcmp(field, (u8 *)"res", 2) == _TRUE) {
str2hexbuf(value, pdvobj->rson_data.res, 16);
return 1;
} else
return _FALSE;
return num;
}
/*
return : TRUE -- competitor is taking advantage than condidate
FALSE -- we should continue keeping candidate
*/
int rtw_rson_choose(struct wlan_network **candidate, struct wlan_network *competitor)
{
s16 comp_score = 0, cand_score = 0;
struct rtw_rson_struct rson_cand, rson_comp;
if (is_match_bssid(competitor->network.MacAddress, rtw_rson_block_bssid, rtw_rson_block_bssid_idx) == _TRUE)
return _FALSE;
if ((competitor == NULL)
|| (rtw_get_rson_struct(&(competitor->network), &rson_comp) != _TRUE)
|| (rson_comp.id != CONFIG_RTW_REPEATER_SON_ID))
return _FALSE;
comp_score = rtw_cal_rson_score(&rson_comp, competitor->network.Rssi);
if (comp_score == RTW_RSON_SCORE_NOTCNNT)
return _FALSE;
if (*candidate == NULL)
return _TRUE;
if (rtw_get_rson_struct(&((*candidate)->network), &rson_cand) != _TRUE)
return _FALSE;
cand_score = rtw_cal_rson_score(&rson_cand, (*candidate)->network.Rssi);
RTW_INFO("%s: competitor_score=%d, candidate_score=%d\n", __func__, comp_score, cand_score);
if (comp_score - cand_score > RSON_SCORE_DIFF_TH)
return _TRUE;
return _FALSE;
}
inline u8 rtw_rson_varify_ie(u8 *p)
{
u8 *ptr = NULL;
u8 ver;
u32 id;
u8 hopcnt;
u8 allcnnt;
ptr = p + 2 + sizeof(RTW_RSON_OUI);
ver = *ptr;
/* for (ver == 1) */
if (ver != 1)
return _FALSE;
return _TRUE;
}
/*
Parsing RTK self-organization vendor IE
*/
int rtw_get_rson_struct(WLAN_BSSID_EX *bssid, struct rtw_rson_struct *rson_data)
{
sint limit = 0;
u32 len;
u8 *p;
if ((rson_data == NULL) || (bssid == NULL))
return -EINVAL;
/* Default */
rson_data->id = 0;
rson_data->ver = 0;
rson_data->hopcnt = 0;
rson_data->connectible = 0;
rson_data->loading = 0;
/* fake root */
if (is_match_bssid(bssid->MacAddress, rtw_rson_root_bssid, rtw_rson_root_bssid_idx) == _TRUE) {
rson_data->id = CONFIG_RTW_REPEATER_SON_ID;
rson_data->ver = RTW_RSON_VER;
rson_data->hopcnt = RTW_RSON_HC_ROOT;
rson_data->connectible = RTW_RSON_ALLOWCONNECT;
rson_data->loading = 0;
return _TRUE;
}
limit = bssid->IELength - _BEACON_IE_OFFSET_;
for (p = bssid->IEs + _BEACON_IE_OFFSET_; ; p += (len + 2)) {
p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &len, limit);
limit -= len;
if ((p == NULL) || (len == 0))
break;
if (p && (_rtw_memcmp(p + 2, RTW_RSON_OUI, sizeof(RTW_RSON_OUI)) == _TRUE)
&& rtw_rson_varify_ie(p)) {
p = p + 2 + sizeof(RTW_RSON_OUI);
rson_data->ver = *p;
/* for (ver == 1) */
p = p + 1;
rson_data->id = le32_to_cpup((__le32 *)p);
p = p + 4;
rson_data->hopcnt = *p;
p = p + 1;
rson_data->connectible = *p;
p = p + 1;
rson_data->loading = *p;
return _TRUE;
}
}
return -EBADMSG;
}
u32 rtw_rson_append_ie(_adapter *padapter, unsigned char *pframe, u32 *len)
{
u8 *ptr, *ori, ie_len = 0;
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
/* static int iii = 0;*/
if ((!pdvobj) || (!pframe))
return 0;
ptr = ori = pframe;
*ptr++ = _VENDOR_SPECIFIC_IE_;
*ptr++ = ie_len = sizeof(RTW_RSON_OUI)+sizeof(pdvobj->rson_data);
_rtw_memcpy(ptr, RTW_RSON_OUI, sizeof(RTW_RSON_OUI));
ptr = ptr + sizeof(RTW_RSON_OUI);
*ptr++ = pdvobj->rson_data.ver;
*(s32 *)ptr = cpu_to_le32(pdvobj->rson_data.id);
ptr = ptr + sizeof(pdvobj->rson_data.id);
*ptr++ = pdvobj->rson_data.hopcnt;
*ptr++ = pdvobj->rson_data.connectible;
*ptr++ = pdvobj->rson_data.loading;
_rtw_memcpy(ptr, pdvobj->rson_data.res, sizeof(pdvobj->rson_data.res));
pframe = ptr;
/*
iii = iii % 20;
if (iii++ == 0)
RTW_INFO("%s : RTW RSON IE : %20ph\n", __func__, ori);
*/
*len += (ie_len+2);
return ie_len;
}
void rtw_rson_do_disconnect(_adapter *padapter)
{
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
#ifndef CONFIG_RTW_REPEATER_SON_ROOT
pdvobj->rson_data.ver = RTW_RSON_VER;
pdvobj->rson_data.id = CONFIG_RTW_REPEATER_SON_ID;
pdvobj->rson_data.hopcnt = RTW_RSON_HC_NOTREADY;
pdvobj->rson_data.connectible = RTW_RSON_DENYCONNECT;
pdvobj->rson_data.loading = 0;
rtw_mi_tx_beacon_hdl(padapter);
#endif
}
void rtw_rson_join_done(_adapter *padapter)
{
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
WLAN_BSSID_EX *cur_network = NULL;
struct rtw_rson_struct rson_data;
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
if (!padapter->mlmepriv.cur_network_scanned)
return;
cur_network = &(padapter->mlmepriv.cur_network_scanned->network);
if (rtw_get_rson_struct(cur_network, &rson_data) != _TRUE) {
RTW_ERR("%s: try to join a improper network(%s)\n", __func__, cur_network->Ssid.Ssid);
return;
}
#ifndef CONFIG_RTW_REPEATER_SON_ROOT
/* update rson_data */
pdvobj->rson_data.ver = RTW_RSON_VER;
pdvobj->rson_data.id = rson_data.id;
pdvobj->rson_data.hopcnt = rson_data.hopcnt + 1;
pdvobj->rson_data.connectible = RTW_RSON_ALLOWCONNECT;
pdvobj->rson_data.loading = 0;
rtw_mi_tx_beacon_hdl(padapter);
#endif
}
int rtw_rson_isupdate_roamcan(struct mlme_priv *mlme
, struct wlan_network **candidate, struct wlan_network *competitor)
{
struct rtw_rson_struct rson_cand, rson_comp, rson_curr;
s16 comp_score, cand_score, curr_score;
if ((competitor == NULL)
|| (rtw_get_rson_struct(&(competitor->network), &rson_comp) != _TRUE)
|| (rson_comp.id != CONFIG_RTW_REPEATER_SON_ID))
return _FALSE;
if (is_match_bssid(competitor->network.MacAddress, rtw_rson_block_bssid, rtw_rson_block_bssid_idx) == _TRUE)
return _FALSE;
if ((!mlme->cur_network_scanned)
|| (mlme->cur_network_scanned == competitor)
|| (rtw_get_rson_struct(&(mlme->cur_network_scanned->network), &rson_curr)) != _TRUE)
return _FALSE;
if (rtw_get_passing_time_ms((u32)competitor->last_scanned) >= mlme->roam_scanr_exp_ms)
return _FALSE;
comp_score = rtw_cal_rson_score(&rson_comp, competitor->network.Rssi);
curr_score = rtw_cal_rson_score(&rson_curr, mlme->cur_network_scanned->network.Rssi);
if (comp_score - curr_score < RSON_SCORE_DIFF_TH)
return _FALSE;
if (*candidate == NULL)
return _TRUE;
if (rtw_get_rson_struct(&((*candidate)->network), &rson_cand) != _TRUE) {
RTW_ERR("%s : Unable to get rson_struct from candidate(%s -- " MAC_FMT")\n",
__func__, (*candidate)->network.Ssid.Ssid, MAC_ARG((*candidate)->network.MacAddress));
return _FALSE;
}
cand_score = rtw_cal_rson_score(&rson_cand, (*candidate)->network.Rssi);
RTW_DBG("comp_score=%d , cand_score=%d , curr_score=%d\n", comp_score, cand_score, curr_score);
if (cand_score < comp_score)
return _TRUE;
#if 0 /* Handle 11R protocol */
#ifdef CONFIG_RTW_80211R
if (rtw_chk_ft_flags(adapter, RTW_FT_SUPPORTED)) {
ptmp = rtw_get_ie(&competitor->network.IEs[12], _MDIE_, &mdie_len, competitor->network.IELength-12);
if (ptmp) {
if (!_rtw_memcmp(&pftpriv->mdid, ptmp+2, 2))
goto exit;
/*The candidate don't support over-the-DS*/
if (rtw_chk_ft_flags(adapter, RTW_FT_STA_OVER_DS_SUPPORTED)) {
if ((rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED) && !(*(ptmp+4) & 0x01)) ||
(!rtw_chk_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED) && (*(ptmp+4) & 0x01))) {
RTW_INFO("FT: ignore the candidate(" MAC_FMT ") for over-the-DS\n", MAC_ARG(competitor->network.MacAddress));
rtw_clr_ft_flags(adapter, RTW_FT_OVER_DS_SUPPORTED);
goto exit;
}
}
} else
goto exit;
}
#endif
#endif
return _FALSE;
}
void rtw_rson_show_survey_info(struct seq_file *m, _list *plist, _list *phead)
{
struct wlan_network *pnetwork = NULL;
struct rtw_rson_struct rson_data;
s16 rson_score;
u16 index = 0;
RTW_PRINT_SEL(m, "%5s %-17s %3s %5s %14s %10s %-3s %5s %32s\n", "index", "bssid", "ch", "id", "hop_cnt", "loading", "RSSI", "score", "ssid");
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
if (!pnetwork)
break;
_rtw_memset(&rson_data, 0, sizeof(rson_data));
rson_score = 0;
if (rtw_get_rson_struct(&(pnetwork->network), &rson_data) == _TRUE)
rson_score = rtw_cal_rson_score(&rson_data, pnetwork->network.Rssi);
RTW_PRINT_SEL(m, "%5d "MAC_FMT" %3d 0x%08x %6d %10d %6d %6d %32s\n",
++index,
MAC_ARG(pnetwork->network.MacAddress),
pnetwork->network.Configuration.DSConfig,
rson_data.id,
rson_data.hopcnt,
rson_data.loading,
(int)pnetwork->network.Rssi,
rson_score,
pnetwork->network.Ssid.Ssid);
plist = get_next(plist);
}
}
/*
Description : As a AP role, We need to check the qualify of associating STA.
We also need to check if we are ready to be associated.
return : TRUE -- AP REJECT this STA
FALSE -- AP ACCEPT this STA
*/
u8 rtw_rson_ap_check_sta(_adapter *padapter, u8 *pframe, uint pkt_len, unsigned short ie_offset)
{
struct wlan_network *pnetwork = NULL;
struct rtw_rson_struct rson_target;
struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
int len = 0;
u8 ret = _FALSE;
u8 *p;
#ifndef CONFIG_RTW_REPEATER_SON_ROOT
_rtw_memset(&rson_target, 0, sizeof(rson_target));
for (p = pframe + WLAN_HDR_A3_LEN + ie_offset; ; p += (len + 2)) {
p = rtw_get_ie(p, _VENDOR_SPECIFIC_IE_, &len, pkt_len - WLAN_HDR_A3_LEN - ie_offset);
if ((p == NULL) || (len == 0))
break;
if (p && (_rtw_memcmp(p + 2, RTW_RSON_OUI, sizeof(RTW_RSON_OUI)) == _TRUE)
&& rtw_rson_varify_ie(p)) {
p = p + 2 + sizeof(RTW_RSON_OUI);
rson_target.ver = *p;
/* for (ver == 1) */
p = p + 1;
rson_target.id = le32_to_cpup((__le32 *)p);
p = p + 4;
rson_target.hopcnt = *p;
p = p + 1;
rson_target.connectible = *p;
p = p + 1;
rson_target.loading = *p;
break;
}
}
if (rson_target.id == 0) /* Normal STA, not a RSON STA */
ret = _FALSE;
else if (rson_target.id != pdvobj->rson_data.id) {
ret = _TRUE;
RTW_INFO("%s : Reject AssoReq because RSON ID not match, STA=%08x, our=%08x\n",
__func__, rson_target.id, pdvobj->rson_data.id);
} else if ((pdvobj->rson_data.hopcnt == RTW_RSON_HC_NOTREADY)
|| (pdvobj->rson_data.connectible == RTW_RSON_DENYCONNECT)) {
ret = _TRUE;
RTW_INFO("%s : Reject AssoReq becuase our hopcnt=%d or connectbile=%d\n",
__func__, pdvobj->rson_data.hopcnt, pdvobj->rson_data.connectible);
}
#endif
return ret;
}
u8 rtw_rson_scan_wk_cmd(_adapter *padapter, int op)
{
struct cmd_obj *ph2c;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
u8 *extra_cmd_buf;
u8 res = _SUCCESS;
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)ph2c, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = RSON_SCAN_WK_CID;
pdrvextra_cmd_parm->type = op;
pdrvextra_cmd_parm->size = 0;
pdrvextra_cmd_parm->pbuf = NULL;
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, ph2c);
exit:
return res;
}
void rtw_rson_scan_cmd_hdl(_adapter *padapter, int op)
{
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 val8;
if (mlmeext_chk_scan_state(pmlmeext, SCAN_DISABLE) != _TRUE)
return;
if (op == RSON_SCAN_PROCESS) {
padapter->rtw_rson_scanstage = RSON_SCAN_PROCESS;
val8 = 0x1e;
rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &val8, _FALSE);
val8 = 1;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
issue_probereq(padapter, NULL, NULL);
/* stop rson_scan after 100ms */
_set_timer(&(pmlmeext->rson_scan_timer), 100);
} else if (op == RSON_SCAN_DISABLE) {
padapter->rtw_rson_scanstage = RSON_SCAN_DISABLE;
val8 = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_SITESURVEY, (u8 *)(&val8));
val8 = 0xff;
rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &val8, _FALSE);
/* report_surveydone_event(padapter);*/
if (pmlmepriv->to_join == _TRUE) {
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) != _TRUE) {
int s_ret;
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
pmlmepriv->to_join = _FALSE;
s_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
if (s_ret == _SUCCESS)
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
else if (s_ret == 2) {
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
rtw_indicate_connect(padapter);
} else {
RTW_INFO("try_to_join, but select scanning queue fail, to_roam:%d\n", rtw_to_roam(padapter));
if (rtw_to_roam(padapter) != 0) {
if (rtw_dec_to_roam(padapter) == 0) {
rtw_set_to_roam(padapter, 0);
rtw_free_assoc_resources(padapter, _TRUE);
rtw_indicate_disconnect(padapter, 0, _FALSE);
} else
pmlmepriv->to_join = _TRUE;
} else
rtw_indicate_disconnect(padapter, 0, _FALSE);
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
}
}
} else {
if (rtw_chk_roam_flags(padapter, RTW_ROAM_ACTIVE)) {
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)
&& check_fwstate(pmlmepriv, _FW_LINKED)) {
if (rtw_select_roaming_candidate(pmlmepriv) == _SUCCESS) {
#ifdef CONFIG_RTW_80211R
if (rtw_chk_ft_flags(padapter, RTW_FT_OVER_DS_SUPPORTED)) {
start_clnt_ft_action(adapter, (u8 *)pmlmepriv->roam_network->network.MacAddress);
} else {
/*wait a little time to retrieve packets buffered in the current ap while scan*/
_set_timer(&pmlmeext->ft_roam_timer, 30);
}
#else
receive_disconnect(padapter, pmlmepriv->cur_network.network.MacAddress
, WLAN_REASON_ACTIVE_ROAM, _FALSE);
#endif
}
}
}
issue_action_BSSCoexistPacket(padapter);
issue_action_BSSCoexistPacket(padapter);
issue_action_BSSCoexistPacket(padapter);
}
} else {
RTW_ERR("%s : improper parameter -- op = %d\n", __func__, op);
}
}
#endif /* CONFIG_RTW_REPEATER_SON */
================================================
FILE: core/rtw_sdio.c
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_SDIO_C_
#include /* struct dvobj_priv and etc. */
#include /* RTW_SDIO_ADDR_CMD52_GEN */
/*
* Description:
* Use SDIO cmd52 or cmd53 to read/write data
*
* Parameters:
* d pointer of device object(struct dvobj_priv)
* addr SDIO address, 17 bits
* buf buffer for I/O
* len length
* write 0:read, 1:write
* cmd52 0:cmd52, 1:cmd53
*
* Return:
* _SUCCESS I/O ok.
* _FAIL I/O fail.
*/
static u8 sdio_io(struct dvobj_priv *d, u32 addr, void *buf, size_t len, u8 write, u8 cmd52)
{
#ifdef DBG_SDIO
#if (DBG_SDIO >= 3)
struct sdio_data *sdio;
#endif /* DBG_SDIO >= 3 */
#endif /* DBG_SDIO */
u32 addr_drv; /* address with driver defined bit */
int err;
u8 retry = 0;
u8 stop_retry = _FALSE; /* flag for stopping retry or not */
#ifdef DBG_SDIO
#if (DBG_SDIO >= 3)
sdio = &d->intf_data;
#endif /* DBG_SDIO >= 3 */
#endif /* DBG_SDIO */
if (rtw_is_surprise_removed(dvobj_get_primary_adapter(d))) {
RTW_ERR("%s: bSurpriseRemoved, skip %s 0x%05x, %zu bytes\n",
__FUNCTION__, write?"write":"read", addr, len);
return _FAIL;
}
addr_drv = addr;
if (cmd52)
addr_drv = RTW_SDIO_ADDR_CMD52_GEN(addr_drv);
do {
if (write)
err = d->intf_ops->write(d, addr_drv, buf, len, 0);
else
err = d->intf_ops->read(d, addr_drv, buf, len, 0);
if (!err) {
if (retry) {
RTW_INFO("%s: Retry %s OK! addr=0x%05x %zu bytes, retry=%u,%u\n",
__FUNCTION__, write?"write":"read",
addr, len, retry, ATOMIC_READ(&d->continual_io_error));
RTW_INFO_DUMP("Data: ", buf, len);
}
rtw_reset_continual_io_error(d);
break;
}
RTW_ERR("%s: %s FAIL! error(%d) addr=0x%05x %zu bytes, retry=%u,%u\n",
__FUNCTION__, write?"write":"read", err, addr, len,
retry, ATOMIC_READ(&d->continual_io_error));
#ifdef DBG_SDIO
#if (DBG_SDIO >= 3)
if (sdio->dbg_enable) {
if (sdio->err_test && sdio->err_test_triggered)
sdio->err_test = 0;
if (sdio->err_stop) {
RTW_ERR("%s: I/O error! Set surprise remove flag ON!\n",
__FUNCTION__);
rtw_set_surprise_removed(dvobj_get_primary_adapter(d));
return _FAIL;
}
}
#endif /* DBG_SDIO >= 3 */
#endif /* DBG_SDIO */
retry++;
stop_retry = rtw_inc_and_chk_continual_io_error(d);
if ((err == -1) || (stop_retry == _TRUE) || (retry > SD_IO_TRY_CNT)) {
/* critical error, unrecoverable */
RTW_ERR("%s: Fatal error! Set surprise remove flag ON! (retry=%u,%u)\n",
__FUNCTION__, retry, ATOMIC_READ(&d->continual_io_error));
rtw_set_surprise_removed(dvobj_get_primary_adapter(d));
return _FAIL;
}
/* WLAN IOREG or SDIO Local */
if ((addr & 0x10000) || !(addr & 0xE000)) {
RTW_WARN("%s: Retry %s addr=0x%05x %zu bytes, retry=%u,%u\n",
__FUNCTION__, write?"write":"read", addr, len,
retry, ATOMIC_READ(&d->continual_io_error));
continue;
}
return _FAIL;
} while (1);
return _SUCCESS;
}
u8 rtw_sdio_read_cmd52(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
{
return sdio_io(d, addr, buf, len, 0, 1);
}
u8 rtw_sdio_read_cmd53(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
{
return sdio_io(d, addr, buf, len, 0, 0);
}
u8 rtw_sdio_write_cmd52(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
{
return sdio_io(d, addr, buf, len, 1, 1);
}
u8 rtw_sdio_write_cmd53(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
{
return sdio_io(d, addr, buf, len, 1, 0);
}
u8 rtw_sdio_f0_read(struct dvobj_priv *d, u32 addr, void *buf, size_t len)
{
int err;
u8 ret;
ret = _SUCCESS;
addr = RTW_SDIO_ADDR_F0_GEN(addr);
err = d->intf_ops->read(d, addr, buf, len, 0);
if (err)
ret = _FAIL;
return ret;
}
================================================
FILE: core/rtw_security.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_SECURITY_C_
#include
static const char *_security_type_str[] = {
"N/A",
"WEP40",
"TKIP",
"TKIP_WM",
"AES",
"WEP104",
"SMS4",
"WEP_WPA",
"BIP",
};
const char *security_type_str(u8 value)
{
#ifdef CONFIG_IEEE80211W
if (value <= _BIP_)
#else
if (value <= _WEP_WPA_MIXED_)
#endif
return _security_type_str[value];
return NULL;
}
#ifdef DBG_SW_SEC_CNT
#define WEP_SW_ENC_CNT_INC(sec, ra) do {\
if (is_broadcast_mac_addr(ra)) \
sec->wep_sw_enc_cnt_bc++; \
else if (is_multicast_mac_addr(ra)) \
sec->wep_sw_enc_cnt_mc++; \
else \
sec->wep_sw_enc_cnt_uc++; \
} while (0)
#define WEP_SW_DEC_CNT_INC(sec, ra) do {\
if (is_broadcast_mac_addr(ra)) \
sec->wep_sw_dec_cnt_bc++; \
else if (is_multicast_mac_addr(ra)) \
sec->wep_sw_dec_cnt_mc++; \
else \
sec->wep_sw_dec_cnt_uc++; \
} while (0)
#define TKIP_SW_ENC_CNT_INC(sec, ra) do {\
if (is_broadcast_mac_addr(ra)) \
sec->tkip_sw_enc_cnt_bc++; \
else if (is_multicast_mac_addr(ra)) \
sec->tkip_sw_enc_cnt_mc++; \
else \
sec->tkip_sw_enc_cnt_uc++; \
} while (0)
#define TKIP_SW_DEC_CNT_INC(sec, ra) do {\
if (is_broadcast_mac_addr(ra)) \
sec->tkip_sw_dec_cnt_bc++; \
else if (is_multicast_mac_addr(ra)) \
sec->tkip_sw_dec_cnt_mc++; \
else \
sec->tkip_sw_dec_cnt_uc++; \
} while (0)
#define AES_SW_ENC_CNT_INC(sec, ra) do {\
if (is_broadcast_mac_addr(ra)) \
sec->aes_sw_enc_cnt_bc++; \
else if (is_multicast_mac_addr(ra)) \
sec->aes_sw_enc_cnt_mc++; \
else \
sec->aes_sw_enc_cnt_uc++; \
} while (0)
#define AES_SW_DEC_CNT_INC(sec, ra) do {\
if (is_broadcast_mac_addr(ra)) \
sec->aes_sw_dec_cnt_bc++; \
else if (is_multicast_mac_addr(ra)) \
sec->aes_sw_dec_cnt_mc++; \
else \
sec->aes_sw_dec_cnt_uc++; \
} while (0)
#else
#define WEP_SW_ENC_CNT_INC(sec, ra)
#define WEP_SW_DEC_CNT_INC(sec, ra)
#define TKIP_SW_ENC_CNT_INC(sec, ra)
#define TKIP_SW_DEC_CNT_INC(sec, ra)
#define AES_SW_ENC_CNT_INC(sec, ra)
#define AES_SW_DEC_CNT_INC(sec, ra)
#endif /* DBG_SW_SEC_CNT */
/* *****WEP related***** */
#define CRC32_POLY 0x04c11db7
struct arc4context {
u32 x;
u32 y;
u8 state[256];
};
static void arcfour_init(struct arc4context *parc4ctx, u8 *key, u32 key_len)
{
u32 t, u;
u32 keyindex;
u32 stateindex;
u8 *state;
u32 counter;
state = parc4ctx->state;
parc4ctx->x = 0;
parc4ctx->y = 0;
for (counter = 0; counter < 256; counter++)
state[counter] = (u8)counter;
keyindex = 0;
stateindex = 0;
for (counter = 0; counter < 256; counter++) {
t = state[counter];
stateindex = (stateindex + key[keyindex] + t) & 0xff;
u = state[stateindex];
state[stateindex] = (u8)t;
state[counter] = (u8)u;
if (++keyindex >= key_len)
keyindex = 0;
}
}
static u32 arcfour_byte(struct arc4context *parc4ctx)
{
u32 x;
u32 y;
u32 sx, sy;
u8 *state;
state = parc4ctx->state;
x = (parc4ctx->x + 1) & 0xff;
sx = state[x];
y = (sx + parc4ctx->y) & 0xff;
sy = state[y];
parc4ctx->x = x;
parc4ctx->y = y;
state[y] = (u8)sx;
state[x] = (u8)sy;
return state[(sx + sy) & 0xff];
}
static void arcfour_encrypt(struct arc4context *parc4ctx,
u8 *dest,
u8 *src,
u32 len)
{
u32 i;
for (i = 0; i < len; i++)
dest[i] = src[i] ^ (unsigned char)arcfour_byte(parc4ctx);
}
static sint bcrc32initialized = 0;
static u32 crc32_table[256];
static u8 crc32_reverseBit(u8 data)
{
return (u8)((data << 7) & 0x80) | ((data << 5) & 0x40) | ((data << 3) & 0x20) | ((data << 1) & 0x10) | ((data >> 1) & 0x08) | ((data >> 3) & 0x04) | ((data >> 5) & 0x02) | ((
data >> 7) & 0x01) ;
}
static void crc32_init(void)
{
if (bcrc32initialized == 1)
goto exit;
else {
sint i, j;
u32 c;
u8 *p = (u8 *)&c, *p1;
u8 k;
c = 0x12340000;
for (i = 0; i < 256; ++i) {
k = crc32_reverseBit((u8)i);
for (c = ((u32)k) << 24, j = 8; j > 0; --j)
c = c & 0x80000000 ? (c << 1) ^ CRC32_POLY : (c << 1);
p1 = (u8 *)&crc32_table[i];
p1[0] = crc32_reverseBit(p[3]);
p1[1] = crc32_reverseBit(p[2]);
p1[2] = crc32_reverseBit(p[1]);
p1[3] = crc32_reverseBit(p[0]);
}
bcrc32initialized = 1;
}
exit:
return;
}
static u32 getcrc32(u8 *buf, sint len)
{
u8 *p;
u32 crc;
if (bcrc32initialized == 0)
crc32_init();
crc = 0xffffffff; /* preload shift register, per CRC-32 spec */
for (p = buf; len > 0; ++p, --len)
crc = crc32_table[(crc ^ *p) & 0xff] ^ (crc >> 8);
return ~crc; /* transmit complement, per CRC-32 spec */
}
/*
Need to consider the fragment situation
*/
void rtw_wep_encrypt(_adapter *padapter, u8 *pxmitframe)
{
/* exclude ICV */
unsigned char crc[4];
struct arc4context mycontext;
sint curfragnum, length;
u32 keylength;
u8 *pframe, *payload, *iv; /* ,*wepkey */
u8 wepkey[16];
u8 hw_hdr_offset = 0;
struct pkt_attrib *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
return;
#ifdef CONFIG_USB_TX_AGGREGATION
hw_hdr_offset = TXDESC_SIZE +
(((struct xmit_frame *)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
#else
#ifdef CONFIG_TX_EARLY_MODE
hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
#else
hw_hdr_offset = TXDESC_OFFSET;
#endif
#endif
pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + hw_hdr_offset;
/* start to encrypt each fragment */
if ((pattrib->encrypt == _WEP40_) || (pattrib->encrypt == _WEP104_)) {
keylength = psecuritypriv->dot11DefKeylen[psecuritypriv->dot11PrivacyKeyIndex];
for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
iv = pframe + pattrib->hdrlen;
_rtw_memcpy(&wepkey[0], iv, 3);
_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0], keylength);
payload = pframe + pattrib->iv_len + pattrib->hdrlen;
if ((curfragnum + 1) == pattrib->nr_frags) {
/* the last fragment */
length = pattrib->last_txcmdsz - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length));
arcfour_init(&mycontext, wepkey, 3 + keylength);
arcfour_encrypt(&mycontext, payload, payload, length);
arcfour_encrypt(&mycontext, payload + length, crc, 4);
} else {
length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len ;
*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length));
arcfour_init(&mycontext, wepkey, 3 + keylength);
arcfour_encrypt(&mycontext, payload, payload, length);
arcfour_encrypt(&mycontext, payload + length, crc, 4);
pframe += pxmitpriv->frag_len;
pframe = (u8 *)RND4((SIZE_PTR)(pframe));
}
}
WEP_SW_ENC_CNT_INC(psecuritypriv, pattrib->ra);
}
}
void rtw_wep_decrypt(_adapter *padapter, u8 *precvframe)
{
/* exclude ICV */
u8 crc[4];
struct arc4context mycontext;
sint length;
u32 keylength;
u8 *pframe, *payload, *iv, wepkey[16];
u8 keyindex;
struct rx_pkt_attrib *prxattrib = &(((union recv_frame *)precvframe)->u.hdr.attrib);
struct security_priv *psecuritypriv = &padapter->securitypriv;
pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
/* start to decrypt recvframe */
if ((prxattrib->encrypt == _WEP40_) || (prxattrib->encrypt == _WEP104_)) {
iv = pframe + prxattrib->hdrlen;
/* keyindex=(iv[3]&0x3); */
keyindex = prxattrib->key_index;
keylength = psecuritypriv->dot11DefKeylen[keyindex];
_rtw_memcpy(&wepkey[0], iv, 3);
/* _rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0],keylength); */
_rtw_memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[keyindex].skey[0], keylength);
length = ((union recv_frame *)precvframe)->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len;
payload = pframe + prxattrib->iv_len + prxattrib->hdrlen;
/* decrypt payload include icv */
arcfour_init(&mycontext, wepkey, 3 + keylength);
arcfour_encrypt(&mycontext, payload, payload, length);
/* calculate icv and compare the icv */
*((u32 *)crc) = le32_to_cpu(getcrc32(payload, length - 4));
WEP_SW_DEC_CNT_INC(psecuritypriv, prxattrib->ra);
}
return;
}
/* 3 =====TKIP related===== */
static u32 secmicgetuint32(u8 *p)
/* Convert from Byte[] to Us4Byte32 in a portable way */
{
s32 i;
u32 res = 0;
for (i = 0; i < 4; i++)
res |= ((u32)(*p++)) << (8 * i);
return res;
}
static void secmicputuint32(u8 *p, u32 val)
/* Convert from Us4Byte32 to Byte[] in a portable way */
{
long i;
for (i = 0; i < 4; i++) {
*p++ = (u8)(val & 0xff);
val >>= 8;
}
}
static void secmicclear(struct mic_data *pmicdata)
{
/* Reset the state to the empty message. */
pmicdata->L = pmicdata->K0;
pmicdata->R = pmicdata->K1;
pmicdata->nBytesInM = 0;
pmicdata->M = 0;
}
void rtw_secmicsetkey(struct mic_data *pmicdata, u8 *key)
{
/* Set the key */
pmicdata->K0 = secmicgetuint32(key);
pmicdata->K1 = secmicgetuint32(key + 4);
/* and reset the message */
secmicclear(pmicdata);
}
void rtw_secmicappendbyte(struct mic_data *pmicdata, u8 b)
{
/* Append the byte to our word-sized buffer */
pmicdata->M |= ((unsigned long)b) << (8 * pmicdata->nBytesInM);
pmicdata->nBytesInM++;
/* Process the word if it is full. */
if (pmicdata->nBytesInM >= 4) {
pmicdata->L ^= pmicdata->M;
pmicdata->R ^= ROL32(pmicdata->L, 17);
pmicdata->L += pmicdata->R;
pmicdata->R ^= ((pmicdata->L & 0xff00ff00) >> 8) | ((pmicdata->L & 0x00ff00ff) << 8);
pmicdata->L += pmicdata->R;
pmicdata->R ^= ROL32(pmicdata->L, 3);
pmicdata->L += pmicdata->R;
pmicdata->R ^= ROR32(pmicdata->L, 2);
pmicdata->L += pmicdata->R;
/* Clear the buffer */
pmicdata->M = 0;
pmicdata->nBytesInM = 0;
}
}
void rtw_secmicappend(struct mic_data *pmicdata, u8 *src, u32 nbytes)
{
/* This is simple */
while (nbytes > 0) {
rtw_secmicappendbyte(pmicdata, *src++);
nbytes--;
}
}
void rtw_secgetmic(struct mic_data *pmicdata, u8 *dst)
{
/* Append the minimum padding */
rtw_secmicappendbyte(pmicdata, 0x5a);
rtw_secmicappendbyte(pmicdata, 0);
rtw_secmicappendbyte(pmicdata, 0);
rtw_secmicappendbyte(pmicdata, 0);
rtw_secmicappendbyte(pmicdata, 0);
/* and then zeroes until the length is a multiple of 4 */
while (pmicdata->nBytesInM != 0)
rtw_secmicappendbyte(pmicdata, 0);
/* The appendByte function has already computed the result. */
secmicputuint32(dst, pmicdata->L);
secmicputuint32(dst + 4, pmicdata->R);
/* Reset to the empty message. */
secmicclear(pmicdata);
}
void rtw_seccalctkipmic(u8 *key, u8 *header, u8 *data, u32 data_len, u8 *mic_code, u8 pri)
{
struct mic_data micdata;
u8 priority[4] = {0x0, 0x0, 0x0, 0x0};
rtw_secmicsetkey(&micdata, key);
priority[0] = pri;
/* Michael MIC pseudo header: DA, SA, 3 x 0, Priority */
if (header[1] & 1) { /* ToDS==1 */
rtw_secmicappend(&micdata, &header[16], 6); /* DA */
if (header[1] & 2) /* From Ds==1 */
rtw_secmicappend(&micdata, &header[24], 6);
else
rtw_secmicappend(&micdata, &header[10], 6);
} else { /* ToDS==0 */
rtw_secmicappend(&micdata, &header[4], 6); /* DA */
if (header[1] & 2) /* From Ds==1 */
rtw_secmicappend(&micdata, &header[16], 6);
else
rtw_secmicappend(&micdata, &header[10], 6);
}
rtw_secmicappend(&micdata, &priority[0], 4);
rtw_secmicappend(&micdata, data, data_len);
rtw_secgetmic(&micdata, mic_code);
}
/* macros for extraction/creation of unsigned char/unsigned short values */
#define RotR1(v16) ((((v16) >> 1) & 0x7FFF) ^ (((v16) & 1) << 15))
#define Lo8(v16) ((u8)((v16) & 0x00FF))
#define Hi8(v16) ((u8)(((v16) >> 8) & 0x00FF))
#define Lo16(v32) ((u16)((v32) & 0xFFFF))
#define Hi16(v32) ((u16)(((v32) >> 16) & 0xFFFF))
#define Mk16(hi, lo) ((lo) ^ (((u16)(hi)) << 8))
/* select the Nth 16-bit word of the temporal key unsigned char array TK[] */
#define TK16(N) Mk16(tk[2*(N)+1], tk[2*(N)])
/* S-box lookup: 16 bits --> 16 bits */
#define _S_(v16) (Sbox1[0][Lo8(v16)] ^ Sbox1[1][Hi8(v16)])
/* fixed algorithm "parameters" */
#define PHASE1_LOOP_CNT 8 /* this needs to be "big enough" */
#define TA_SIZE 6 /* 48-bit transmitter address */
#define TK_SIZE 16 /* 128-bit temporal key */
#define P1K_SIZE 10 /* 80-bit Phase1 key */
#define RC4_KEY_SIZE 16 /* 128-bit RC4KEY (104 bits unknown) */
/* 2-unsigned char by 2-unsigned char subset of the full AES S-box table */
static const unsigned short Sbox1[2][256] = /* Sbox for hash (can be in ROM) */
{ {
0xC6A5, 0xF884, 0xEE99, 0xF68D, 0xFF0D, 0xD6BD, 0xDEB1, 0x9154,
0x6050, 0x0203, 0xCEA9, 0x567D, 0xE719, 0xB562, 0x4DE6, 0xEC9A,
0x8F45, 0x1F9D, 0x8940, 0xFA87, 0xEF15, 0xB2EB, 0x8EC9, 0xFB0B,
0x41EC, 0xB367, 0x5FFD, 0x45EA, 0x23BF, 0x53F7, 0xE496, 0x9B5B,
0x75C2, 0xE11C, 0x3DAE, 0x4C6A, 0x6C5A, 0x7E41, 0xF502, 0x834F,
0x685C, 0x51F4, 0xD134, 0xF908, 0xE293, 0xAB73, 0x6253, 0x2A3F,
0x080C, 0x9552, 0x4665, 0x9D5E, 0x3028, 0x37A1, 0x0A0F, 0x2FB5,
0x0E09, 0x2436, 0x1B9B, 0xDF3D, 0xCD26, 0x4E69, 0x7FCD, 0xEA9F,
0x121B, 0x1D9E, 0x5874, 0x342E, 0x362D, 0xDCB2, 0xB4EE, 0x5BFB,
0xA4F6, 0x764D, 0xB761, 0x7DCE, 0x527B, 0xDD3E, 0x5E71, 0x1397,
0xA6F5, 0xB968, 0x0000, 0xC12C, 0x4060, 0xE31F, 0x79C8, 0xB6ED,
0xD4BE, 0x8D46, 0x67D9, 0x724B, 0x94DE, 0x98D4, 0xB0E8, 0x854A,
0xBB6B, 0xC52A, 0x4FE5, 0xED16, 0x86C5, 0x9AD7, 0x6655, 0x1194,
0x8ACF, 0xE910, 0x0406, 0xFE81, 0xA0F0, 0x7844, 0x25BA, 0x4BE3,
0xA2F3, 0x5DFE, 0x80C0, 0x058A, 0x3FAD, 0x21BC, 0x7048, 0xF104,
0x63DF, 0x77C1, 0xAF75, 0x4263, 0x2030, 0xE51A, 0xFD0E, 0xBF6D,
0x814C, 0x1814, 0x2635, 0xC32F, 0xBEE1, 0x35A2, 0x88CC, 0x2E39,
0x9357, 0x55F2, 0xFC82, 0x7A47, 0xC8AC, 0xBAE7, 0x322B, 0xE695,
0xC0A0, 0x1998, 0x9ED1, 0xA37F, 0x4466, 0x547E, 0x3BAB, 0x0B83,
0x8CCA, 0xC729, 0x6BD3, 0x283C, 0xA779, 0xBCE2, 0x161D, 0xAD76,
0xDB3B, 0x6456, 0x744E, 0x141E, 0x92DB, 0x0C0A, 0x486C, 0xB8E4,
0x9F5D, 0xBD6E, 0x43EF, 0xC4A6, 0x39A8, 0x31A4, 0xD337, 0xF28B,
0xD532, 0x8B43, 0x6E59, 0xDAB7, 0x018C, 0xB164, 0x9CD2, 0x49E0,
0xD8B4, 0xACFA, 0xF307, 0xCF25, 0xCAAF, 0xF48E, 0x47E9, 0x1018,
0x6FD5, 0xF088, 0x4A6F, 0x5C72, 0x3824, 0x57F1, 0x73C7, 0x9751,
0xCB23, 0xA17C, 0xE89C, 0x3E21, 0x96DD, 0x61DC, 0x0D86, 0x0F85,
0xE090, 0x7C42, 0x71C4, 0xCCAA, 0x90D8, 0x0605, 0xF701, 0x1C12,
0xC2A3, 0x6A5F, 0xAEF9, 0x69D0, 0x1791, 0x9958, 0x3A27, 0x27B9,
0xD938, 0xEB13, 0x2BB3, 0x2233, 0xD2BB, 0xA970, 0x0789, 0x33A7,
0x2DB6, 0x3C22, 0x1592, 0xC920, 0x8749, 0xAAFF, 0x5078, 0xA57A,
0x038F, 0x59F8, 0x0980, 0x1A17, 0x65DA, 0xD731, 0x84C6, 0xD0B8,
0x82C3, 0x29B0, 0x5A77, 0x1E11, 0x7BCB, 0xA8FC, 0x6DD6, 0x2C3A,
},
{ /* second half of table is unsigned char-reversed version of first! */
0xA5C6, 0x84F8, 0x99EE, 0x8DF6, 0x0DFF, 0xBDD6, 0xB1DE, 0x5491,
0x5060, 0x0302, 0xA9CE, 0x7D56, 0x19E7, 0x62B5, 0xE64D, 0x9AEC,
0x458F, 0x9D1F, 0x4089, 0x87FA, 0x15EF, 0xEBB2, 0xC98E, 0x0BFB,
0xEC41, 0x67B3, 0xFD5F, 0xEA45, 0xBF23, 0xF753, 0x96E4, 0x5B9B,
0xC275, 0x1CE1, 0xAE3D, 0x6A4C, 0x5A6C, 0x417E, 0x02F5, 0x4F83,
0x5C68, 0xF451, 0x34D1, 0x08F9, 0x93E2, 0x73AB, 0x5362, 0x3F2A,
0x0C08, 0x5295, 0x6546, 0x5E9D, 0x2830, 0xA137, 0x0F0A, 0xB52F,
0x090E, 0x3624, 0x9B1B, 0x3DDF, 0x26CD, 0x694E, 0xCD7F, 0x9FEA,
0x1B12, 0x9E1D, 0x7458, 0x2E34, 0x2D36, 0xB2DC, 0xEEB4, 0xFB5B,
0xF6A4, 0x4D76, 0x61B7, 0xCE7D, 0x7B52, 0x3EDD, 0x715E, 0x9713,
0xF5A6, 0x68B9, 0x0000, 0x2CC1, 0x6040, 0x1FE3, 0xC879, 0xEDB6,
0xBED4, 0x468D, 0xD967, 0x4B72, 0xDE94, 0xD498, 0xE8B0, 0x4A85,
0x6BBB, 0x2AC5, 0xE54F, 0x16ED, 0xC586, 0xD79A, 0x5566, 0x9411,
0xCF8A, 0x10E9, 0x0604, 0x81FE, 0xF0A0, 0x4478, 0xBA25, 0xE34B,
0xF3A2, 0xFE5D, 0xC080, 0x8A05, 0xAD3F, 0xBC21, 0x4870, 0x04F1,
0xDF63, 0xC177, 0x75AF, 0x6342, 0x3020, 0x1AE5, 0x0EFD, 0x6DBF,
0x4C81, 0x1418, 0x3526, 0x2FC3, 0xE1BE, 0xA235, 0xCC88, 0x392E,
0x5793, 0xF255, 0x82FC, 0x477A, 0xACC8, 0xE7BA, 0x2B32, 0x95E6,
0xA0C0, 0x9819, 0xD19E, 0x7FA3, 0x6644, 0x7E54, 0xAB3B, 0x830B,
0xCA8C, 0x29C7, 0xD36B, 0x3C28, 0x79A7, 0xE2BC, 0x1D16, 0x76AD,
0x3BDB, 0x5664, 0x4E74, 0x1E14, 0xDB92, 0x0A0C, 0x6C48, 0xE4B8,
0x5D9F, 0x6EBD, 0xEF43, 0xA6C4, 0xA839, 0xA431, 0x37D3, 0x8BF2,
0x32D5, 0x438B, 0x596E, 0xB7DA, 0x8C01, 0x64B1, 0xD29C, 0xE049,
0xB4D8, 0xFAAC, 0x07F3, 0x25CF, 0xAFCA, 0x8EF4, 0xE947, 0x1810,
0xD56F, 0x88F0, 0x6F4A, 0x725C, 0x2438, 0xF157, 0xC773, 0x5197,
0x23CB, 0x7CA1, 0x9CE8, 0x213E, 0xDD96, 0xDC61, 0x860D, 0x850F,
0x90E0, 0x427C, 0xC471, 0xAACC, 0xD890, 0x0506, 0x01F7, 0x121C,
0xA3C2, 0x5F6A, 0xF9AE, 0xD069, 0x9117, 0x5899, 0x273A, 0xB927,
0x38D9, 0x13EB, 0xB32B, 0x3322, 0xBBD2, 0x70A9, 0x8907, 0xA733,
0xB62D, 0x223C, 0x9215, 0x20C9, 0x4987, 0xFFAA, 0x7850, 0x7AA5,
0x8F03, 0xF859, 0x8009, 0x171A, 0xDA65, 0x31D7, 0xC684, 0xB8D0,
0xC382, 0xB029, 0x775A, 0x111E, 0xCB7B, 0xFCA8, 0xD66D, 0x3A2C,
}
};
/*
**********************************************************************
* Routine: Phase 1 -- generate P1K, given TA, TK, IV32
*
* Inputs:
* tk[] = temporal key [128 bits]
* ta[] = transmitter's MAC address [ 48 bits]
* iv32 = upper 32 bits of IV [ 32 bits]
* Output:
* p1k[] = Phase 1 key [ 80 bits]
*
* Note:
* This function only needs to be called every 2**16 packets,
* although in theory it could be called every packet.
*
**********************************************************************
*/
static void phase1(u16 *p1k, const u8 *tk, const u8 *ta, u32 iv32)
{
sint i;
/* Initialize the 80 bits of P1K[] from IV32 and TA[0..5] */
p1k[0] = Lo16(iv32);
p1k[1] = Hi16(iv32);
p1k[2] = Mk16(ta[1], ta[0]); /* use TA[] as little-endian */
p1k[3] = Mk16(ta[3], ta[2]);
p1k[4] = Mk16(ta[5], ta[4]);
/* Now compute an unbalanced Feistel cipher with 80-bit block */
/* size on the 80-bit block P1K[], using the 128-bit key TK[] */
for (i = 0; i < PHASE1_LOOP_CNT ; i++) {
/* Each add operation here is mod 2**16 */
p1k[0] += _S_(p1k[4] ^ TK16((i & 1) + 0));
p1k[1] += _S_(p1k[0] ^ TK16((i & 1) + 2));
p1k[2] += _S_(p1k[1] ^ TK16((i & 1) + 4));
p1k[3] += _S_(p1k[2] ^ TK16((i & 1) + 6));
p1k[4] += _S_(p1k[3] ^ TK16((i & 1) + 0));
p1k[4] += (unsigned short)i; /* avoid "slide attacks" */
}
}
/*
**********************************************************************
* Routine: Phase 2 -- generate RC4KEY, given TK, P1K, IV16
*
* Inputs:
* tk[] = Temporal key [128 bits]
* p1k[] = Phase 1 output key [ 80 bits]
* iv16 = low 16 bits of IV counter [ 16 bits]
* Output:
* rc4key[] = the key used to encrypt the packet [128 bits]
*
* Note:
* The value {TA,IV32,IV16} for Phase1/Phase2 must be unique
* across all packets using the same key TK value. Then, for a
* given value of TK[], this TKIP48 construction guarantees that
* the final RC4KEY value is unique across all packets.
*
* Suggested implementation optimization: if PPK[] is "overlaid"
* appropriately on RC4KEY[], there is no need for the final
* for loop below that copies the PPK[] result into RC4KEY[].
*
**********************************************************************
*/
static void phase2(u8 *rc4key, const u8 *tk, const u16 *p1k, u16 iv16)
{
sint i;
u16 PPK[6]; /* temporary key for mixing */
/* Note: all adds in the PPK[] equations below are mod 2**16 */
for (i = 0; i < 5; i++)
PPK[i] = p1k[i]; /* first, copy P1K to PPK */
PPK[5] = p1k[4] + iv16; /* next, add in IV16 */
/* Bijective non-linear mixing of the 96 bits of PPK[0..5] */
PPK[0] += _S_(PPK[5] ^ TK16(0)); /* Mix key in each "round" */
PPK[1] += _S_(PPK[0] ^ TK16(1));
PPK[2] += _S_(PPK[1] ^ TK16(2));
PPK[3] += _S_(PPK[2] ^ TK16(3));
PPK[4] += _S_(PPK[3] ^ TK16(4));
PPK[5] += _S_(PPK[4] ^ TK16(5)); /* Total # S-box lookups == 6 */
/* Final sweep: bijective, "linear". Rotates kill LSB correlations */
PPK[0] += RotR1(PPK[5] ^ TK16(6));
PPK[1] += RotR1(PPK[0] ^ TK16(7)); /* Use all of TK[] in Phase2 */
PPK[2] += RotR1(PPK[1]);
PPK[3] += RotR1(PPK[2]);
PPK[4] += RotR1(PPK[3]);
PPK[5] += RotR1(PPK[4]);
/* Note: At this point, for a given key TK[0..15], the 96-bit output */
/* value PPK[0..5] is guaranteed to be unique, as a function */
/* of the 96-bit "input" value {TA,IV32,IV16}. That is, P1K */
/* is now a keyed permutation of {TA,IV32,IV16}. */
/* Set RC4KEY[0..3], which includes "cleartext" portion of RC4 key */
rc4key[0] = Hi8(iv16); /* RC4KEY[0..2] is the WEP IV */
rc4key[1] = (Hi8(iv16) | 0x20) & 0x7F; /* Help avoid weak (FMS) keys */
rc4key[2] = Lo8(iv16);
rc4key[3] = Lo8((PPK[5] ^ TK16(0)) >> 1);
/* Copy 96 bits of PPK[0..5] to RC4KEY[4..15] (little-endian) */
for (i = 0; i < 6; i++) {
rc4key[4 + 2 * i] = Lo8(PPK[i]);
rc4key[5 + 2 * i] = Hi8(PPK[i]);
}
}
/* The hlen isn't include the IV */
u32 rtw_tkip_encrypt(_adapter *padapter, u8 *pxmitframe)
{
/* exclude ICV */
u16 pnl;
u32 pnh;
u8 rc4key[16];
u8 ttkey[16];
u8 crc[4];
u8 hw_hdr_offset = 0;
struct arc4context mycontext;
sint curfragnum, length;
u32 prwskeylen;
u8 *pframe, *payload, *iv, *prwskey;
union pn48 dot11txpn;
/* struct sta_info *stainfo; */
struct pkt_attrib *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
u32 res = _SUCCESS;
if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
return _FAIL;
#ifdef CONFIG_USB_TX_AGGREGATION
hw_hdr_offset = TXDESC_SIZE +
(((struct xmit_frame *)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
#else
#ifdef CONFIG_TX_EARLY_MODE
hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
#else
hw_hdr_offset = TXDESC_OFFSET;
#endif
#endif
pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + hw_hdr_offset;
/* 4 start to encrypt each fragment */
if (pattrib->encrypt == _TKIP_) {
/*
if(pattrib->psta)
{
stainfo = pattrib->psta;
}
else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
}
*/
/* if (stainfo!=NULL) */
{
/*
if(!(stainfo->state &_FW_LINKED))
{
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
return _FAIL;
}
*/
if (IS_MCAST(pattrib->ra))
prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
else {
/* prwskey=&stainfo->dot118021x_UncstKey.skey[0]; */
prwskey = pattrib->dot118021x_UncstKey.skey;
}
prwskeylen = 16;
for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
iv = pframe + pattrib->hdrlen;
payload = pframe + pattrib->iv_len + pattrib->hdrlen;
GET_TKIP_PN(iv, dot11txpn);
pnl = (u16)(dot11txpn.val);
pnh = (u32)(dot11txpn.val >> 16);
phase1((u16 *)&ttkey[0], prwskey, &pattrib->ta[0], pnh);
phase2(&rc4key[0], prwskey, (u16 *)&ttkey[0], pnl);
if ((curfragnum + 1) == pattrib->nr_frags) { /* 4 the last fragment */
length = pattrib->last_txcmdsz - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length)); /* modified by Amy*/
arcfour_init(&mycontext, rc4key, 16);
arcfour_encrypt(&mycontext, payload, payload, length);
arcfour_encrypt(&mycontext, payload + length, crc, 4);
} else {
length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len ;
*((u32 *)crc) = cpu_to_le32(getcrc32(payload, length)); /* modified by Amy*/
arcfour_init(&mycontext, rc4key, 16);
arcfour_encrypt(&mycontext, payload, payload, length);
arcfour_encrypt(&mycontext, payload + length, crc, 4);
pframe += pxmitpriv->frag_len;
pframe = (u8 *)RND4((SIZE_PTR)(pframe));
}
}
TKIP_SW_ENC_CNT_INC(psecuritypriv, pattrib->ra);
}
/*
else{
RTW_INFO("%s, psta==NUL\n", __func__);
res=_FAIL;
}
*/
}
return res;
}
/* The hlen isn't include the IV */
u32 rtw_tkip_decrypt(_adapter *padapter, u8 *precvframe)
{
/* exclude ICV */
u16 pnl;
u32 pnh;
u8 rc4key[16];
u8 ttkey[16];
u8 crc[4];
struct arc4context mycontext;
sint length;
u32 prwskeylen;
u8 *pframe, *payload, *iv, *prwskey;
union pn48 dot11txpn;
struct sta_info *stainfo;
struct rx_pkt_attrib *prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
/* struct recv_priv *precvpriv=&padapter->recvpriv; */
u32 res = _SUCCESS;
pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
/* 4 start to decrypt recvframe */
if (prxattrib->encrypt == _TKIP_) {
stainfo = rtw_get_stainfo(&padapter->stapriv , &prxattrib->ta[0]);
if (stainfo != NULL) {
if (IS_MCAST(prxattrib->ra)) {
static systime start = 0;
static u32 no_gkey_bc_cnt = 0;
static u32 no_gkey_mc_cnt = 0;
if (psecuritypriv->binstallGrpkey == _FALSE) {
res = _FAIL;
if (start == 0)
start = rtw_get_current_time();
if (is_broadcast_mac_addr(prxattrib->ra))
no_gkey_bc_cnt++;
else
no_gkey_mc_cnt++;
if (rtw_get_passing_time_ms(start) > 1000) {
if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
RTW_PRINT(FUNC_ADPT_FMT" no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
}
start = rtw_get_current_time();
no_gkey_bc_cnt = 0;
no_gkey_mc_cnt = 0;
}
goto exit;
}
if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
RTW_PRINT(FUNC_ADPT_FMT" gkey installed. no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
}
start = 0;
no_gkey_bc_cnt = 0;
no_gkey_mc_cnt = 0;
/* RTW_INFO("rx bc/mc packets, to perform sw rtw_tkip_decrypt\n"); */
/* prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey; */
prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
prwskeylen = 16;
} else {
prwskey = &stainfo->dot118021x_UncstKey.skey[0];
prwskeylen = 16;
}
iv = pframe + prxattrib->hdrlen;
payload = pframe + prxattrib->iv_len + prxattrib->hdrlen;
length = ((union recv_frame *)precvframe)->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len;
GET_TKIP_PN(iv, dot11txpn);
pnl = (u16)(dot11txpn.val);
pnh = (u32)(dot11txpn.val >> 16);
phase1((u16 *)&ttkey[0], prwskey, &prxattrib->ta[0], pnh);
phase2(&rc4key[0], prwskey, (unsigned short *)&ttkey[0], pnl);
/* 4 decrypt payload include icv */
arcfour_init(&mycontext, rc4key, 16);
arcfour_encrypt(&mycontext, payload, payload, length);
*((u32 *)crc) = le32_to_cpu(getcrc32(payload, length - 4));
if (crc[3] != payload[length - 1] || crc[2] != payload[length - 2] || crc[1] != payload[length - 3] || crc[0] != payload[length - 4]) {
res = _FAIL;
}
TKIP_SW_DEC_CNT_INC(psecuritypriv, prxattrib->ra);
} else {
res = _FAIL;
}
}
exit:
return res;
}
/* 3 =====AES related===== */
#define MAX_MSG_SIZE 2048
/*****************************/
/******** SBOX Table *********/
/*****************************/
static u8 sbox_table[256] = {
0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5,
0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76,
0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0,
0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0,
0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc,
0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15,
0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a,
0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75,
0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0,
0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84,
0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b,
0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf,
0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85,
0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8,
0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5,
0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2,
0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17,
0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73,
0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88,
0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb,
0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c,
0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79,
0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9,
0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08,
0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6,
0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a,
0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e,
0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e,
0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94,
0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf,
0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68,
0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16
};
/*****************************/
/**** Function Prototypes ****/
/*****************************/
static void bitwise_xor(u8 *ina, u8 *inb, u8 *out);
static void construct_mic_iv(
u8 *mic_header1,
sint qc_exists,
sint a4_exists,
u8 *mpdu,
uint payload_length,
u8 *pn_vector,
uint frtype);/* add for CONFIG_IEEE80211W, none 11w also can use */
static void construct_mic_header1(
u8 *mic_header1,
sint header_length,
u8 *mpdu,
uint frtype);/* add for CONFIG_IEEE80211W, none 11w also can use */
static void construct_mic_header2(
u8 *mic_header2,
u8 *mpdu,
sint a4_exists,
sint qc_exists);
static void construct_ctr_preload(
u8 *ctr_preload,
sint a4_exists,
sint qc_exists,
u8 *mpdu,
u8 *pn_vector,
sint c,
uint frtype);/* add for CONFIG_IEEE80211W, none 11w also can use */
static void xor_128(u8 *a, u8 *b, u8 *out);
static void xor_32(u8 *a, u8 *b, u8 *out);
static u8 sbox(u8 a);
static void next_key(u8 *key, sint round);
static void byte_sub(u8 *in, u8 *out);
static void shift_row(u8 *in, u8 *out);
static void mix_column(u8 *in, u8 *out);
static void aes128k128d(u8 *key, u8 *data, u8 *ciphertext);
/****************************************/
/* aes128k128d() */
/* Performs a 128 bit AES encrypt with */
/* 128 bit data. */
/****************************************/
static void xor_128(u8 *a, u8 *b, u8 *out)
{
sint i;
for (i = 0; i < 16; i++)
out[i] = a[i] ^ b[i];
}
static void xor_32(u8 *a, u8 *b, u8 *out)
{
sint i;
for (i = 0; i < 4; i++)
out[i] = a[i] ^ b[i];
}
static u8 sbox(u8 a)
{
return sbox_table[(sint)a];
}
static void next_key(u8 *key, sint round)
{
u8 rcon;
u8 sbox_key[4];
u8 rcon_table[12] = {
0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80,
0x1b, 0x36, 0x36, 0x36
};
sbox_key[0] = sbox(key[13]);
sbox_key[1] = sbox(key[14]);
sbox_key[2] = sbox(key[15]);
sbox_key[3] = sbox(key[12]);
rcon = rcon_table[round];
xor_32(&key[0], sbox_key, &key[0]);
key[0] = key[0] ^ rcon;
xor_32(&key[4], &key[0], &key[4]);
xor_32(&key[8], &key[4], &key[8]);
xor_32(&key[12], &key[8], &key[12]);
}
static void byte_sub(u8 *in, u8 *out)
{
sint i;
for (i = 0; i < 16; i++)
out[i] = sbox(in[i]);
}
static void shift_row(u8 *in, u8 *out)
{
out[0] = in[0];
out[1] = in[5];
out[2] = in[10];
out[3] = in[15];
out[4] = in[4];
out[5] = in[9];
out[6] = in[14];
out[7] = in[3];
out[8] = in[8];
out[9] = in[13];
out[10] = in[2];
out[11] = in[7];
out[12] = in[12];
out[13] = in[1];
out[14] = in[6];
out[15] = in[11];
}
static void mix_column(u8 *in, u8 *out)
{
sint i;
u8 add1b[4];
u8 add1bf7[4];
u8 rotl[4];
u8 swap_halfs[4];
u8 andf7[4];
u8 rotr[4];
u8 temp[4];
u8 tempb[4];
for (i = 0 ; i < 4; i++) {
if ((in[i] & 0x80) == 0x80)
add1b[i] = 0x1b;
else
add1b[i] = 0x00;
}
swap_halfs[0] = in[2]; /* Swap halfs */
swap_halfs[1] = in[3];
swap_halfs[2] = in[0];
swap_halfs[3] = in[1];
rotl[0] = in[3]; /* Rotate left 8 bits */
rotl[1] = in[0];
rotl[2] = in[1];
rotl[3] = in[2];
andf7[0] = in[0] & 0x7f;
andf7[1] = in[1] & 0x7f;
andf7[2] = in[2] & 0x7f;
andf7[3] = in[3] & 0x7f;
for (i = 3; i > 0; i--) { /* logical shift left 1 bit */
andf7[i] = andf7[i] << 1;
if ((andf7[i - 1] & 0x80) == 0x80)
andf7[i] = (andf7[i] | 0x01);
}
andf7[0] = andf7[0] << 1;
andf7[0] = andf7[0] & 0xfe;
xor_32(add1b, andf7, add1bf7);
xor_32(in, add1bf7, rotr);
temp[0] = rotr[0]; /* Rotate right 8 bits */
rotr[0] = rotr[1];
rotr[1] = rotr[2];
rotr[2] = rotr[3];
rotr[3] = temp[0];
xor_32(add1bf7, rotr, temp);
xor_32(swap_halfs, rotl, tempb);
xor_32(temp, tempb, out);
}
static void aes128k128d(u8 *key, u8 *data, u8 *ciphertext)
{
sint round;
sint i;
u8 intermediatea[16];
u8 intermediateb[16];
u8 round_key[16];
for (i = 0; i < 16; i++)
round_key[i] = key[i];
for (round = 0; round < 11; round++) {
if (round == 0) {
xor_128(round_key, data, ciphertext);
next_key(round_key, round);
} else if (round == 10) {
byte_sub(ciphertext, intermediatea);
shift_row(intermediatea, intermediateb);
xor_128(intermediateb, round_key, ciphertext);
} else { /* 1 - 9 */
byte_sub(ciphertext, intermediatea);
shift_row(intermediatea, intermediateb);
mix_column(&intermediateb[0], &intermediatea[0]);
mix_column(&intermediateb[4], &intermediatea[4]);
mix_column(&intermediateb[8], &intermediatea[8]);
mix_column(&intermediateb[12], &intermediatea[12]);
xor_128(intermediatea, round_key, ciphertext);
next_key(round_key, round);
}
}
}
/************************************************/
/* construct_mic_iv() */
/* Builds the MIC IV from header fields and PN */
/* Baron think the function is construct CCM */
/* nonce */
/************************************************/
static void construct_mic_iv(
u8 *mic_iv,
sint qc_exists,
sint a4_exists,
u8 *mpdu,
uint payload_length,
u8 *pn_vector,
uint frtype/* add for CONFIG_IEEE80211W, none 11w also can use */
)
{
sint i;
mic_iv[0] = 0x59;
if (qc_exists && a4_exists)
mic_iv[1] = mpdu[30] & 0x0f; /* QoS_TC */
if (qc_exists && !a4_exists)
mic_iv[1] = mpdu[24] & 0x0f; /* mute bits 7-4 */
if (!qc_exists)
mic_iv[1] = 0x00;
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
/* 802.11w management frame should set management bit(4) */
if (frtype == WIFI_MGT_TYPE)
mic_iv[1] |= BIT(4);
#endif
for (i = 2; i < 8; i++)
mic_iv[i] = mpdu[i + 8]; /* mic_iv[2:7] = A2[0:5] = mpdu[10:15] */
#ifdef CONSISTENT_PN_ORDER
for (i = 8; i < 14; i++)
mic_iv[i] = pn_vector[i - 8]; /* mic_iv[8:13] = PN[0:5] */
#else
for (i = 8; i < 14; i++)
mic_iv[i] = pn_vector[13 - i]; /* mic_iv[8:13] = PN[5:0] */
#endif
mic_iv[14] = (unsigned char)(payload_length / 256);
mic_iv[15] = (unsigned char)(payload_length % 256);
}
/************************************************/
/* construct_mic_header1() */
/* Builds the first MIC header block from */
/* header fields. */
/* Build AAD SC,A1,A2 */
/************************************************/
static void construct_mic_header1(
u8 *mic_header1,
sint header_length,
u8 *mpdu,
uint frtype/* add for CONFIG_IEEE80211W, none 11w also can use */
)
{
mic_header1[0] = (u8)((header_length - 2) / 256);
mic_header1[1] = (u8)((header_length - 2) % 256);
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
/* 802.11w management frame don't AND subtype bits 4,5,6 of frame control field */
if (frtype == WIFI_MGT_TYPE)
mic_header1[2] = mpdu[0];
else
#endif
mic_header1[2] = mpdu[0] & 0xcf; /* Mute CF poll & CF ack bits */
mic_header1[3] = mpdu[1] & 0xc7; /* Mute retry, more data and pwr mgt bits */
mic_header1[4] = mpdu[4]; /* A1 */
mic_header1[5] = mpdu[5];
mic_header1[6] = mpdu[6];
mic_header1[7] = mpdu[7];
mic_header1[8] = mpdu[8];
mic_header1[9] = mpdu[9];
mic_header1[10] = mpdu[10]; /* A2 */
mic_header1[11] = mpdu[11];
mic_header1[12] = mpdu[12];
mic_header1[13] = mpdu[13];
mic_header1[14] = mpdu[14];
mic_header1[15] = mpdu[15];
}
/************************************************/
/* construct_mic_header2() */
/* Builds the last MIC header block from */
/* header fields. */
/************************************************/
static void construct_mic_header2(
u8 *mic_header2,
u8 *mpdu,
sint a4_exists,
sint qc_exists
)
{
sint i;
for (i = 0; i < 16; i++)
mic_header2[i] = 0x00;
mic_header2[0] = mpdu[16]; /* A3 */
mic_header2[1] = mpdu[17];
mic_header2[2] = mpdu[18];
mic_header2[3] = mpdu[19];
mic_header2[4] = mpdu[20];
mic_header2[5] = mpdu[21];
/* mic_header2[6] = mpdu[22] & 0xf0; SC */
mic_header2[6] = 0x00;
mic_header2[7] = 0x00; /* mpdu[23]; */
if (!qc_exists && a4_exists) {
for (i = 0; i < 6; i++)
mic_header2[8 + i] = mpdu[24 + i]; /* A4 */
}
if (qc_exists && !a4_exists) {
mic_header2[8] = mpdu[24] & 0x0f; /* mute bits 15 - 4 */
mic_header2[9] = mpdu[25] & 0x00;
}
if (qc_exists && a4_exists) {
for (i = 0; i < 6; i++)
mic_header2[8 + i] = mpdu[24 + i]; /* A4 */
mic_header2[14] = mpdu[30] & 0x0f;
mic_header2[15] = mpdu[31] & 0x00;
}
}
/************************************************/
/* construct_mic_header2() */
/* Builds the last MIC header block from */
/* header fields. */
/* Baron think the function is construct CCM */
/* nonce */
/************************************************/
static void construct_ctr_preload(
u8 *ctr_preload,
sint a4_exists,
sint qc_exists,
u8 *mpdu,
u8 *pn_vector,
sint c,
uint frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
)
{
sint i = 0;
for (i = 0; i < 16; i++)
ctr_preload[i] = 0x00;
i = 0;
ctr_preload[0] = 0x01; /* flag */
if (qc_exists && a4_exists)
ctr_preload[1] = mpdu[30] & 0x0f; /* QoC_Control */
if (qc_exists && !a4_exists)
ctr_preload[1] = mpdu[24] & 0x0f;
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
/* 802.11w management frame should set management bit(4) */
if (frtype == WIFI_MGT_TYPE)
ctr_preload[1] |= BIT(4);
#endif
for (i = 2; i < 8; i++)
ctr_preload[i] = mpdu[i + 8]; /* ctr_preload[2:7] = A2[0:5] = mpdu[10:15] */
#ifdef CONSISTENT_PN_ORDER
for (i = 8; i < 14; i++)
ctr_preload[i] = pn_vector[i - 8]; /* ctr_preload[8:13] = PN[0:5] */
#else
for (i = 8; i < 14; i++)
ctr_preload[i] = pn_vector[13 - i]; /* ctr_preload[8:13] = PN[5:0] */
#endif
ctr_preload[14] = (unsigned char)(c / 256); /* Ctr */
ctr_preload[15] = (unsigned char)(c % 256);
}
/************************************/
/* bitwise_xor() */
/* A 128 bit, bitwise exclusive or */
/************************************/
static void bitwise_xor(u8 *ina, u8 *inb, u8 *out)
{
sint i;
for (i = 0; i < 16; i++)
out[i] = ina[i] ^ inb[i];
}
static sint aes_cipher(u8 *key, uint hdrlen,
u8 *pframe, uint plen)
{
/* static unsigned char message[MAX_MSG_SIZE]; */
uint qc_exists, a4_exists, i, j, payload_remainder,
num_blocks, payload_index;
u8 pn_vector[6];
u8 mic_iv[16];
u8 mic_header1[16];
u8 mic_header2[16];
u8 ctr_preload[16];
/* Intermediate Buffers */
u8 chain_buffer[16];
u8 aes_out[16];
u8 padded_buffer[16];
u8 mic[8];
/* uint offset = 0; */
uint frtype = GetFrameType(pframe);
uint frsubtype = get_frame_sub_type(pframe);
frsubtype = frsubtype >> 4;
_rtw_memset((void *)mic_iv, 0, 16);
_rtw_memset((void *)mic_header1, 0, 16);
_rtw_memset((void *)mic_header2, 0, 16);
_rtw_memset((void *)ctr_preload, 0, 16);
_rtw_memset((void *)chain_buffer, 0, 16);
_rtw_memset((void *)aes_out, 0, 16);
_rtw_memset((void *)padded_buffer, 0, 16);
if ((hdrlen == WLAN_HDR_A3_LEN) || (hdrlen == WLAN_HDR_A3_QOS_LEN))
a4_exists = 0;
else
a4_exists = 1;
if (
((frtype | frsubtype) == WIFI_DATA_CFACK) ||
((frtype | frsubtype) == WIFI_DATA_CFPOLL) ||
((frtype | frsubtype) == WIFI_DATA_CFACKPOLL)) {
qc_exists = 1;
if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
hdrlen += 2;
}
/* add for CONFIG_IEEE80211W, none 11w also can use */
else if ((frtype == WIFI_DATA) &&
((frsubtype == 0x08) ||
(frsubtype == 0x09) ||
(frsubtype == 0x0a) ||
(frsubtype == 0x0b))) {
if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
hdrlen += 2;
qc_exists = 1;
} else
qc_exists = 0;
pn_vector[0] = pframe[hdrlen];
pn_vector[1] = pframe[hdrlen + 1];
pn_vector[2] = pframe[hdrlen + 4];
pn_vector[3] = pframe[hdrlen + 5];
pn_vector[4] = pframe[hdrlen + 6];
pn_vector[5] = pframe[hdrlen + 7];
construct_mic_iv(
mic_iv,
qc_exists,
a4_exists,
pframe, /* message, */
plen,
pn_vector,
frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
);
construct_mic_header1(
mic_header1,
hdrlen,
pframe, /* message */
frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
);
construct_mic_header2(
mic_header2,
pframe, /* message, */
a4_exists,
qc_exists
);
payload_remainder = plen % 16;
num_blocks = plen / 16;
/* Find start of payload */
payload_index = (hdrlen + 8);
/* Calculate MIC */
aes128k128d(key, mic_iv, aes_out);
bitwise_xor(aes_out, mic_header1, chain_buffer);
aes128k128d(key, chain_buffer, aes_out);
bitwise_xor(aes_out, mic_header2, chain_buffer);
aes128k128d(key, chain_buffer, aes_out);
for (i = 0; i < num_blocks; i++) {
bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);/* bitwise_xor(aes_out, &message[payload_index], chain_buffer); */
payload_index += 16;
aes128k128d(key, chain_buffer, aes_out);
}
/* Add on the final payload block if it needs padding */
if (payload_remainder > 0) {
for (j = 0; j < 16; j++)
padded_buffer[j] = 0x00;
for (j = 0; j < payload_remainder; j++) {
padded_buffer[j] = pframe[payload_index++];/* padded_buffer[j] = message[payload_index++]; */
}
bitwise_xor(aes_out, padded_buffer, chain_buffer);
aes128k128d(key, chain_buffer, aes_out);
}
for (j = 0 ; j < 8; j++)
mic[j] = aes_out[j];
/* Insert MIC into payload */
for (j = 0; j < 8; j++)
pframe[payload_index + j] = mic[j]; /* message[payload_index+j] = mic[j]; */
payload_index = hdrlen + 8;
for (i = 0; i < num_blocks; i++) {
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
pframe, /* message, */
pn_vector,
i + 1,
frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);/* bitwise_xor(aes_out, &message[payload_index], chain_buffer); */
for (j = 0; j < 16; j++)
pframe[payload_index++] = chain_buffer[j];/* for (j=0; j<16;j++) message[payload_index++] = chain_buffer[j]; */
}
if (payload_remainder > 0) { /* If there is a short final block, then pad it,*/
/* encrypt it and copy the unpadded part back */
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
pframe, /* message, */
pn_vector,
num_blocks + 1,
frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
for (j = 0; j < 16; j++)
padded_buffer[j] = 0x00;
for (j = 0; j < payload_remainder; j++) {
padded_buffer[j] = pframe[payload_index + j]; /* padded_buffer[j] = message[payload_index+j]; */
}
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, padded_buffer, chain_buffer);
for (j = 0; j < payload_remainder; j++)
pframe[payload_index++] = chain_buffer[j];/* for (j=0; jattrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
/* uint offset = 0; */
u32 res = _SUCCESS;
if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
return _FAIL;
#ifdef CONFIG_USB_TX_AGGREGATION
hw_hdr_offset = TXDESC_SIZE +
(((struct xmit_frame *)pxmitframe)->pkt_offset * PACKET_OFFSET_SZ);
#else
#ifdef CONFIG_TX_EARLY_MODE
hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
#else
hw_hdr_offset = TXDESC_OFFSET;
#endif
#endif
pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + hw_hdr_offset;
/* 4 start to encrypt each fragment */
if ((pattrib->encrypt == _AES_)) {
/*
if(pattrib->psta)
{
stainfo = pattrib->psta;
}
else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
}
*/
/* if (stainfo!=NULL) */
{
/*
if(!(stainfo->state &_FW_LINKED))
{
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
return _FAIL;
}
*/
if (IS_MCAST(pattrib->ra))
prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
else {
/* prwskey=&stainfo->dot118021x_UncstKey.skey[0]; */
prwskey = pattrib->dot118021x_UncstKey.skey;
}
#ifdef CONFIG_TDLS
{
/* Swencryption */
struct sta_info *ptdls_sta;
ptdls_sta = rtw_get_stainfo(&padapter->stapriv , &pattrib->dst[0]);
if ((ptdls_sta != NULL) && (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)) {
RTW_INFO("[%s] for tdls link\n", __FUNCTION__);
prwskey = &ptdls_sta->tpk.tk[0];
}
}
#endif /* CONFIG_TDLS */
prwskeylen = 16;
for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
if ((curfragnum + 1) == pattrib->nr_frags) { /* 4 the last fragment */
length = pattrib->last_txcmdsz - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len;
aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
} else {
length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - pattrib->icv_len ;
aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
pframe += pxmitpriv->frag_len;
pframe = (u8 *)RND4((SIZE_PTR)(pframe));
}
}
AES_SW_ENC_CNT_INC(psecuritypriv, pattrib->ra);
}
/*
else{
RTW_INFO("%s, psta==NUL\n", __func__);
res=_FAIL;
}
*/
}
return res;
}
static sint aes_decipher(u8 *key, uint hdrlen,
u8 *pframe, uint plen)
{
static u8 message[MAX_MSG_SIZE];
uint qc_exists, a4_exists, i, j, payload_remainder,
num_blocks, payload_index;
sint res = _SUCCESS;
u8 pn_vector[6];
u8 mic_iv[16];
u8 mic_header1[16];
u8 mic_header2[16];
u8 ctr_preload[16];
/* Intermediate Buffers */
u8 chain_buffer[16];
u8 aes_out[16];
u8 padded_buffer[16];
u8 mic[8];
/* uint offset = 0; */
uint frtype = GetFrameType(pframe);
uint frsubtype = get_frame_sub_type(pframe);
frsubtype = frsubtype >> 4;
_rtw_memset((void *)mic_iv, 0, 16);
_rtw_memset((void *)mic_header1, 0, 16);
_rtw_memset((void *)mic_header2, 0, 16);
_rtw_memset((void *)ctr_preload, 0, 16);
_rtw_memset((void *)chain_buffer, 0, 16);
_rtw_memset((void *)aes_out, 0, 16);
_rtw_memset((void *)padded_buffer, 0, 16);
/* start to decrypt the payload */
num_blocks = (plen - 8) / 16; /* (plen including LLC, payload_length and mic ) */
payload_remainder = (plen - 8) % 16;
pn_vector[0] = pframe[hdrlen];
pn_vector[1] = pframe[hdrlen + 1];
pn_vector[2] = pframe[hdrlen + 4];
pn_vector[3] = pframe[hdrlen + 5];
pn_vector[4] = pframe[hdrlen + 6];
pn_vector[5] = pframe[hdrlen + 7];
if ((hdrlen == WLAN_HDR_A3_LEN) || (hdrlen == WLAN_HDR_A3_QOS_LEN))
a4_exists = 0;
else
a4_exists = 1;
if (
((frtype | frsubtype) == WIFI_DATA_CFACK) ||
((frtype | frsubtype) == WIFI_DATA_CFPOLL) ||
((frtype | frsubtype) == WIFI_DATA_CFACKPOLL)) {
qc_exists = 1;
if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
hdrlen += 2;
} /* only for data packet . add for CONFIG_IEEE80211W, none 11w also can use */
else if ((frtype == WIFI_DATA) &&
((frsubtype == 0x08) ||
(frsubtype == 0x09) ||
(frsubtype == 0x0a) ||
(frsubtype == 0x0b))) {
if (hdrlen != WLAN_HDR_A3_QOS_LEN && hdrlen != WLAN_HDR_A4_QOS_LEN)
hdrlen += 2;
qc_exists = 1;
} else
qc_exists = 0;
/* now, decrypt pframe with hdrlen offset and plen long */
payload_index = hdrlen + 8; /* 8 is for extiv */
for (i = 0; i < num_blocks; i++) {
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
pframe,
pn_vector,
i + 1,
frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
);
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);
for (j = 0; j < 16; j++)
pframe[payload_index++] = chain_buffer[j];
}
if (payload_remainder > 0) { /* If there is a short final block, then pad it,*/
/* encrypt it and copy the unpadded part back */
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
pframe,
pn_vector,
num_blocks + 1,
frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
);
for (j = 0; j < 16; j++)
padded_buffer[j] = 0x00;
for (j = 0; j < payload_remainder; j++)
padded_buffer[j] = pframe[payload_index + j];
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, padded_buffer, chain_buffer);
for (j = 0; j < payload_remainder; j++)
pframe[payload_index++] = chain_buffer[j];
}
/* start to calculate the mic */
if ((hdrlen + plen + 8) <= MAX_MSG_SIZE)
_rtw_memcpy((void *)message, pframe, (hdrlen + plen + 8)); /* 8 is for ext iv len */
pn_vector[0] = pframe[hdrlen];
pn_vector[1] = pframe[hdrlen + 1];
pn_vector[2] = pframe[hdrlen + 4];
pn_vector[3] = pframe[hdrlen + 5];
pn_vector[4] = pframe[hdrlen + 6];
pn_vector[5] = pframe[hdrlen + 7];
construct_mic_iv(
mic_iv,
qc_exists,
a4_exists,
message,
plen - 8,
pn_vector,
frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
);
construct_mic_header1(
mic_header1,
hdrlen,
message,
frtype /* add for CONFIG_IEEE80211W, none 11w also can use */
);
construct_mic_header2(
mic_header2,
message,
a4_exists,
qc_exists
);
payload_remainder = (plen - 8) % 16;
num_blocks = (plen - 8) / 16;
/* Find start of payload */
payload_index = (hdrlen + 8);
/* Calculate MIC */
aes128k128d(key, mic_iv, aes_out);
bitwise_xor(aes_out, mic_header1, chain_buffer);
aes128k128d(key, chain_buffer, aes_out);
bitwise_xor(aes_out, mic_header2, chain_buffer);
aes128k128d(key, chain_buffer, aes_out);
for (i = 0; i < num_blocks; i++) {
bitwise_xor(aes_out, &message[payload_index], chain_buffer);
payload_index += 16;
aes128k128d(key, chain_buffer, aes_out);
}
/* Add on the final payload block if it needs padding */
if (payload_remainder > 0) {
for (j = 0; j < 16; j++)
padded_buffer[j] = 0x00;
for (j = 0; j < payload_remainder; j++)
padded_buffer[j] = message[payload_index++];
bitwise_xor(aes_out, padded_buffer, chain_buffer);
aes128k128d(key, chain_buffer, aes_out);
}
for (j = 0 ; j < 8; j++)
mic[j] = aes_out[j];
/* Insert MIC into payload */
for (j = 0; j < 8; j++)
message[payload_index + j] = mic[j];
payload_index = hdrlen + 8;
for (i = 0; i < num_blocks; i++) {
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
message,
pn_vector,
i + 1,
frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, &message[payload_index], chain_buffer);
for (j = 0; j < 16; j++)
message[payload_index++] = chain_buffer[j];
}
if (payload_remainder > 0) { /* If there is a short final block, then pad it,*/
/* encrypt it and copy the unpadded part back */
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
message,
pn_vector,
num_blocks + 1,
frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
for (j = 0; j < 16; j++)
padded_buffer[j] = 0x00;
for (j = 0; j < payload_remainder; j++)
padded_buffer[j] = message[payload_index + j];
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, padded_buffer, chain_buffer);
for (j = 0; j < payload_remainder; j++)
message[payload_index++] = chain_buffer[j];
}
/* Encrypt the MIC */
construct_ctr_preload(
ctr_preload,
a4_exists,
qc_exists,
message,
pn_vector,
0,
frtype); /* add for CONFIG_IEEE80211W, none 11w also can use */
for (j = 0; j < 16; j++)
padded_buffer[j] = 0x00;
for (j = 0; j < 8; j++)
padded_buffer[j] = message[j + hdrlen + 8 + plen - 8];
aes128k128d(key, ctr_preload, aes_out);
bitwise_xor(aes_out, padded_buffer, chain_buffer);
for (j = 0; j < 8; j++)
message[payload_index++] = chain_buffer[j];
/* compare the mic */
for (i = 0; i < 8; i++) {
if (pframe[hdrlen + 8 + plen - 8 + i] != message[hdrlen + 8 + plen - 8 + i]) {
RTW_INFO("aes_decipher:mic check error mic[%d]: pframe(%x) != message(%x)\n",
i, pframe[hdrlen + 8 + plen - 8 + i], message[hdrlen + 8 + plen - 8 + i]);
res = _FAIL;
}
}
return res;
}
u32 rtw_aes_decrypt(_adapter *padapter, u8 *precvframe)
{
/* exclude ICV */
/*static*/
/* unsigned char message[MAX_MSG_SIZE]; */
/* Intermediate Buffers */
sint length;
u8 *pframe, *prwskey; /* , *payload,*iv */
struct sta_info *stainfo;
struct rx_pkt_attrib *prxattrib = &((union recv_frame *)precvframe)->u.hdr.attrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
/* struct recv_priv *precvpriv=&padapter->recvpriv; */
u32 res = _SUCCESS;
pframe = (unsigned char *)((union recv_frame *)precvframe)->u.hdr.rx_data;
/* 4 start to encrypt each fragment */
if ((prxattrib->encrypt == _AES_)) {
stainfo = rtw_get_stainfo(&padapter->stapriv , &prxattrib->ta[0]);
if (stainfo != NULL) {
if (IS_MCAST(prxattrib->ra)) {
static systime start = 0;
static u32 no_gkey_bc_cnt = 0;
static u32 no_gkey_mc_cnt = 0;
/* RTW_INFO("rx bc/mc packets, to perform sw rtw_aes_decrypt\n"); */
/* prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey; */
if ((!MLME_IS_MESH(padapter) && psecuritypriv->binstallGrpkey == _FALSE)
#ifdef CONFIG_RTW_MESH
|| !(stainfo->gtk_bmp | BIT(prxattrib->key_index))
#endif
) {
res = _FAIL;
if (start == 0)
start = rtw_get_current_time();
if (is_broadcast_mac_addr(prxattrib->ra))
no_gkey_bc_cnt++;
else
no_gkey_mc_cnt++;
if (rtw_get_passing_time_ms(start) > 1000) {
if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
RTW_PRINT(FUNC_ADPT_FMT" no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
}
start = rtw_get_current_time();
no_gkey_bc_cnt = 0;
no_gkey_mc_cnt = 0;
}
goto exit;
}
if (no_gkey_bc_cnt || no_gkey_mc_cnt) {
RTW_PRINT(FUNC_ADPT_FMT" gkey installed. no_gkey_bc_cnt:%u, no_gkey_mc_cnt:%u\n",
FUNC_ADPT_ARG(padapter), no_gkey_bc_cnt, no_gkey_mc_cnt);
}
start = 0;
no_gkey_bc_cnt = 0;
no_gkey_mc_cnt = 0;
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
/* TODO: multiple GK? */
prwskey = &stainfo->gtk.skey[0];
} else
#endif
{
prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
if (psecuritypriv->dot118021XGrpKeyid != prxattrib->key_index) {
RTW_DBG("not match packet_index=%d, install_index=%d\n"
, prxattrib->key_index, psecuritypriv->dot118021XGrpKeyid);
res = _FAIL;
goto exit;
}
}
} else
prwskey = &stainfo->dot118021x_UncstKey.skey[0];
length = ((union recv_frame *)precvframe)->u.hdr.len - prxattrib->hdrlen - prxattrib->iv_len;
#if 0
/* add for CONFIG_IEEE80211W, debug */
if (0)
printk("@@@@@@@@@@@@@@@@@@ length=%d, prxattrib->hdrlen=%d, prxattrib->pkt_len=%d\n"
, length, prxattrib->hdrlen, prxattrib->pkt_len);
if (0) {
int no;
/* test print PSK */
printk("PSK key below:\n");
for (no = 0; no < 16; no++)
printk(" %02x ", prwskey[no]);
printk("\n");
}
if (0) {
int no;
/* test print PSK */
printk("frame:\n");
for (no = 0; no < prxattrib->pkt_len; no++)
printk(" %02x ", pframe[no]);
printk("\n");
}
#endif
res = aes_decipher(prwskey, prxattrib->hdrlen, pframe, length);
AES_SW_DEC_CNT_INC(psecuritypriv, prxattrib->ra);
} else {
res = _FAIL;
}
}
exit:
return res;
}
#ifdef CONFIG_IEEE80211W
u32 rtw_BIP_verify(_adapter *padapter, u8 *whdr_pos, sint flen
, const u8 *key, u16 keyid, u64* ipn)
{
u8 *BIP_AAD, *mme;
u32 res = _FAIL;
uint len, ori_len;
u16 pkt_keyid = 0;
u64 pkt_ipn = 0;
struct rtw_ieee80211_hdr *pwlanhdr;
u8 mic[16];
mme = whdr_pos + flen - 18;
if (*mme != _MME_IE_)
return RTW_RX_HANDLED;
/* copy key index */
_rtw_memcpy(&pkt_keyid, mme + 2, 2);
pkt_keyid = le16_to_cpu(pkt_keyid);
if (pkt_keyid != keyid) {
RTW_INFO("BIP key index error!\n");
return _FAIL;
}
/* save packet number */
_rtw_memcpy(&pkt_ipn, mme + 4, 6);
pkt_ipn = le64_to_cpu(pkt_ipn);
/* BIP packet number should bigger than previous BIP packet */
if (pkt_ipn <= *ipn) { /* wrap around? */
RTW_INFO("replay BIP packet\n");
return _FAIL;
}
ori_len = flen - WLAN_HDR_A3_LEN + BIP_AAD_SIZE;
BIP_AAD = rtw_zmalloc(ori_len);
if (BIP_AAD == NULL) {
RTW_INFO("BIP AAD allocate fail\n");
return _FAIL;
}
/* mapping to wlan header */
pwlanhdr = (struct rtw_ieee80211_hdr *)whdr_pos;
/* save the frame body + MME */
_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, whdr_pos + WLAN_HDR_A3_LEN, flen - WLAN_HDR_A3_LEN);
/* point mme to the copy */
mme = BIP_AAD + ori_len - 18;
/* clear the MIC field of MME to zero */
_rtw_memset(mme + 10, 0, 8);
/* conscruct AAD, copy frame control field */
_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
ClearRetry(BIP_AAD);
ClearPwrMgt(BIP_AAD);
ClearMData(BIP_AAD);
/* conscruct AAD, copy address 1 to address 3 */
_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
if (omac1_aes_128(key, BIP_AAD, ori_len, mic))
goto BIP_exit;
#if 0
/* management packet content */
{
int pp;
RTW_INFO("pkt: ");
for (pp = 0; pp < flen; pp++)
printk(" %02x ", whdr_pos[pp]);
RTW_INFO("\n");
/* BIP AAD + management frame body + MME(MIC is zero) */
RTW_INFO("AAD+PKT: ");
for (pp = 0; pp < ori_len; pp++)
RTW_INFO(" %02x ", BIP_AAD[pp]);
RTW_INFO("\n");
/* show the MIC result */
RTW_INFO("mic: ");
for (pp = 0; pp < 16; pp++)
RTW_INFO(" %02x ", mic[pp]);
RTW_INFO("\n");
}
#endif
/* MIC field should be last 8 bytes of packet (packet without FCS) */
if (_rtw_memcmp(mic, whdr_pos + flen - 8, 8)) {
*ipn = pkt_ipn;
res = _SUCCESS;
} else
RTW_INFO("BIP MIC error!\n");
BIP_exit:
rtw_mfree(BIP_AAD, ori_len);
return res;
}
#endif /* CONFIG_IEEE80211W */
#ifndef PLATFORM_FREEBSD
#if defined(CONFIG_TDLS)
/* compress 512-bits */
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static int sha256_compress(struct sha256_state *md, unsigned char *buf)
{
u32 S[8], W[64], t0, t1;
u32 t;
int i;
/* copy state into S */
for (i = 0; i < 8; i++)
S[i] = md->state[i];
/* copy the state into 512-bits into W[0..15] */
for (i = 0; i < 16; i++)
W[i] = WPA_GET_BE32(buf + (4 * i));
/* fill W[16..63] */
for (i = 16; i < 64; i++) {
W[i] = Gamma1(W[i - 2]) + W[i - 7] + Gamma0(W[i - 15]) +
W[i - 16];
}
/* Compress */
#define RND(a, b, c, d, e, f, g, h, i) do {\
t0 = h + Sigma1(e) + Ch(e, f, g) + K[i] + W[i]; \
t1 = Sigma0(a) + Maj(a, b, c); \
d += t0; \
h = t0 + t1; \
} while (0)
for (i = 0; i < 64; ++i) {
RND(S[0], S[1], S[2], S[3], S[4], S[5], S[6], S[7], i);
t = S[7];
S[7] = S[6];
S[6] = S[5];
S[5] = S[4];
S[4] = S[3];
S[3] = S[2];
S[2] = S[1];
S[1] = S[0];
S[0] = t;
}
/* feedback */
for (i = 0; i < 8; i++)
md->state[i] = md->state[i] + S[i];
return 0;
}
#endif
/* Initialize the hash state */
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static void sha256_init(struct sha256_state *md)
{
md->curlen = 0;
md->length = 0;
md->state[0] = 0x6A09E667UL;
md->state[1] = 0xBB67AE85UL;
md->state[2] = 0x3C6EF372UL;
md->state[3] = 0xA54FF53AUL;
md->state[4] = 0x510E527FUL;
md->state[5] = 0x9B05688CUL;
md->state[6] = 0x1F83D9ABUL;
md->state[7] = 0x5BE0CD19UL;
}
#endif
/**
Process a block of memory though the hash
@param md The hash state
@param in The data to hash
@param inlen The length of the data (octets)
@return CRYPT_OK if successful
*/
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static int sha256_process(struct sha256_state *md, unsigned char *in,
unsigned long inlen)
{
unsigned long n;
#define block_size 64
if (md->curlen >= sizeof(md->buf))
return -1;
while (inlen > 0) {
if (md->curlen == 0 && inlen >= block_size) {
if (sha256_compress(md, (unsigned char *) in) < 0)
return -1;
md->length += block_size * 8;
in += block_size;
inlen -= block_size;
} else {
n = MIN(inlen, (block_size - md->curlen));
_rtw_memcpy(md->buf + md->curlen, in, n);
md->curlen += n;
in += n;
inlen -= n;
if (md->curlen == block_size) {
if (sha256_compress(md, md->buf) < 0)
return -1;
md->length += 8 * block_size;
md->curlen = 0;
}
}
}
return 0;
}
#endif
/**
Terminate the hash to get the digest
@param md The hash state
@param out [out] The destination of the hash (32 bytes)
@return CRYPT_OK if successful
*/
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static int sha256_done(struct sha256_state *md, unsigned char *out)
{
int i;
if (md->curlen >= sizeof(md->buf))
return -1;
/* increase the length of the message */
md->length += md->curlen * 8;
/* append the '1' bit */
md->buf[md->curlen++] = (unsigned char) 0x80;
/* if the length is currently above 56 bytes we append zeros
* then compress. Then we can fall back to padding zeros and length
* encoding like normal.
*/
if (md->curlen > 56) {
while (md->curlen < 64)
md->buf[md->curlen++] = (unsigned char) 0;
sha256_compress(md, md->buf);
md->curlen = 0;
}
/* pad upto 56 bytes of zeroes */
while (md->curlen < 56)
md->buf[md->curlen++] = (unsigned char) 0;
/* store length */
WPA_PUT_BE64(md->buf + 56, md->length);
sha256_compress(md, md->buf);
/* copy output */
for (i = 0; i < 8; i++)
WPA_PUT_BE32(out + (4 * i), md->state[i]);
return 0;
}
#endif
/**
* sha256_vector - SHA256 hash for data vector
* @num_elem: Number of elements in the data vector
* @addr: Pointers to the data areas
* @len: Lengths of the data blocks
* @mac: Buffer for the hash
* Returns: 0 on success, -1 of failure
*/
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static int sha256_vector(size_t num_elem, u8 *addr[], size_t *len,
u8 *mac)
{
struct sha256_state ctx;
size_t i;
sha256_init(&ctx);
for (i = 0; i < num_elem; i++)
if (sha256_process(&ctx, addr[i], len[i]))
return -1;
if (sha256_done(&ctx, mac))
return -1;
return 0;
}
#endif
static u8 os_strlen(const char *s)
{
const char *p = s;
while (*p)
p++;
return p - s;
}
#endif
#if defined(CONFIG_TDLS) || defined(CONFIG_RTW_MESH_AEK)
static int os_memcmp(const void *s1, const void *s2, u8 n)
{
const unsigned char *p1 = s1, *p2 = s2;
if (n == 0)
return 0;
while (*p1 == *p2) {
p1++;
p2++;
n--;
if (n == 0)
return 0;
}
return *p1 - *p2;
}
#endif
/**
* hmac_sha256_vector - HMAC-SHA256 over data vector (RFC 2104)
* @key: Key for HMAC operations
* @key_len: Length of the key in bytes
* @num_elem: Number of elements in the data vector
* @addr: Pointers to the data areas
* @len: Lengths of the data blocks
* @mac: Buffer for the hash (32 bytes)
*/
#if defined(CONFIG_TDLS)
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static void hmac_sha256_vector(u8 *key, size_t key_len, size_t num_elem,
u8 *addr[], size_t *len, u8 *mac)
{
unsigned char k_pad[64]; /* padding - key XORd with ipad/opad */
unsigned char tk[32];
u8 *_addr[6];
size_t _len[6], i;
if (num_elem > 5) {
/*
* Fixed limit on the number of fragments to avoid having to
* allocate memory (which could fail).
*/
return;
}
/* if key is longer than 64 bytes reset it to key = SHA256(key) */
if (key_len > 64) {
sha256_vector(1, &key, &key_len, tk);
key = tk;
key_len = 32;
}
/* the HMAC_SHA256 transform looks like:
*
* SHA256(K XOR opad, SHA256(K XOR ipad, text))
*
* where K is an n byte key
* ipad is the byte 0x36 repeated 64 times
* opad is the byte 0x5c repeated 64 times
* and text is the data being protected */
/* start out by storing key in ipad */
_rtw_memset(k_pad, 0, sizeof(k_pad));
_rtw_memcpy(k_pad, key, key_len);
/* XOR key with ipad values */
for (i = 0; i < 64; i++)
k_pad[i] ^= 0x36;
/* perform inner SHA256 */
_addr[0] = k_pad;
_len[0] = 64;
for (i = 0; i < num_elem; i++) {
_addr[i + 1] = addr[i];
_len[i + 1] = len[i];
}
sha256_vector(1 + num_elem, _addr, _len, mac);
_rtw_memset(k_pad, 0, sizeof(k_pad));
_rtw_memcpy(k_pad, key, key_len);
/* XOR key with opad values */
for (i = 0; i < 64; i++)
k_pad[i] ^= 0x5c;
/* perform outer SHA256 */
_addr[0] = k_pad;
_len[0] = 64;
_addr[1] = mac;
_len[1] = 32;
sha256_vector(2, _addr, _len, mac);
}
#endif
#endif /* CONFIG_TDLS */
#endif /* PLATFORM_FREEBSD */
/**
* sha256_prf - SHA256-based Pseudo-Random Function (IEEE 802.11r, 8.5.1.5.2)
* @key: Key for PRF
* @key_len: Length of the key in bytes
* @label: A unique label for each purpose of the PRF
* @data: Extra data to bind into the key
* @data_len: Length of the data
* @buf: Buffer for the generated pseudo-random key
* @buf_len: Number of bytes of key to generate
*
* This function is used to derive new, cryptographically separate keys from a
* given key.
*/
#ifndef PLATFORM_FREEBSD /* Baron */
#if defined(CONFIG_TDLS)
#if (LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0))
static void sha256_prf(u8 *key, size_t key_len, char *label,
u8 *data, size_t data_len, u8 *buf, size_t buf_len)
{
u16 counter = 1;
size_t pos, plen;
u8 hash[SHA256_MAC_LEN];
u8 *addr[4];
size_t len[4];
u8 counter_le[2], length_le[2];
addr[0] = counter_le;
len[0] = 2;
addr[1] = (u8 *) label;
len[1] = os_strlen(label);
addr[2] = data;
len[2] = data_len;
addr[3] = length_le;
len[3] = sizeof(length_le);
WPA_PUT_LE16(length_le, buf_len * 8);
pos = 0;
while (pos < buf_len) {
plen = buf_len - pos;
WPA_PUT_LE16(counter_le, counter);
if (plen >= SHA256_MAC_LEN) {
hmac_sha256_vector(key, key_len, 4, addr, len,
&buf[pos]);
pos += SHA256_MAC_LEN;
} else {
hmac_sha256_vector(key, key_len, 4, addr, len, hash);
_rtw_memcpy(&buf[pos], hash, plen);
break;
}
counter++;
}
}
#endif
#endif
#endif /* PLATFORM_FREEBSD Baron */
/* AES tables*/
const u32 Te0[256] = {
0xc66363a5U, 0xf87c7c84U, 0xee777799U, 0xf67b7b8dU,
0xfff2f20dU, 0xd66b6bbdU, 0xde6f6fb1U, 0x91c5c554U,
0x60303050U, 0x02010103U, 0xce6767a9U, 0x562b2b7dU,
0xe7fefe19U, 0xb5d7d762U, 0x4dababe6U, 0xec76769aU,
0x8fcaca45U, 0x1f82829dU, 0x89c9c940U, 0xfa7d7d87U,
0xeffafa15U, 0xb25959ebU, 0x8e4747c9U, 0xfbf0f00bU,
0x41adadecU, 0xb3d4d467U, 0x5fa2a2fdU, 0x45afafeaU,
0x239c9cbfU, 0x53a4a4f7U, 0xe4727296U, 0x9bc0c05bU,
0x75b7b7c2U, 0xe1fdfd1cU, 0x3d9393aeU, 0x4c26266aU,
0x6c36365aU, 0x7e3f3f41U, 0xf5f7f702U, 0x83cccc4fU,
0x6834345cU, 0x51a5a5f4U, 0xd1e5e534U, 0xf9f1f108U,
0xe2717193U, 0xabd8d873U, 0x62313153U, 0x2a15153fU,
0x0804040cU, 0x95c7c752U, 0x46232365U, 0x9dc3c35eU,
0x30181828U, 0x379696a1U, 0x0a05050fU, 0x2f9a9ab5U,
0x0e070709U, 0x24121236U, 0x1b80809bU, 0xdfe2e23dU,
0xcdebeb26U, 0x4e272769U, 0x7fb2b2cdU, 0xea75759fU,
0x1209091bU, 0x1d83839eU, 0x582c2c74U, 0x341a1a2eU,
0x361b1b2dU, 0xdc6e6eb2U, 0xb45a5aeeU, 0x5ba0a0fbU,
0xa45252f6U, 0x763b3b4dU, 0xb7d6d661U, 0x7db3b3ceU,
0x5229297bU, 0xdde3e33eU, 0x5e2f2f71U, 0x13848497U,
0xa65353f5U, 0xb9d1d168U, 0x00000000U, 0xc1eded2cU,
0x40202060U, 0xe3fcfc1fU, 0x79b1b1c8U, 0xb65b5bedU,
0xd46a6abeU, 0x8dcbcb46U, 0x67bebed9U, 0x7239394bU,
0x944a4adeU, 0x984c4cd4U, 0xb05858e8U, 0x85cfcf4aU,
0xbbd0d06bU, 0xc5efef2aU, 0x4faaaae5U, 0xedfbfb16U,
0x864343c5U, 0x9a4d4dd7U, 0x66333355U, 0x11858594U,
0x8a4545cfU, 0xe9f9f910U, 0x04020206U, 0xfe7f7f81U,
0xa05050f0U, 0x783c3c44U, 0x259f9fbaU, 0x4ba8a8e3U,
0xa25151f3U, 0x5da3a3feU, 0x804040c0U, 0x058f8f8aU,
0x3f9292adU, 0x219d9dbcU, 0x70383848U, 0xf1f5f504U,
0x63bcbcdfU, 0x77b6b6c1U, 0xafdada75U, 0x42212163U,
0x20101030U, 0xe5ffff1aU, 0xfdf3f30eU, 0xbfd2d26dU,
0x81cdcd4cU, 0x180c0c14U, 0x26131335U, 0xc3ecec2fU,
0xbe5f5fe1U, 0x359797a2U, 0x884444ccU, 0x2e171739U,
0x93c4c457U, 0x55a7a7f2U, 0xfc7e7e82U, 0x7a3d3d47U,
0xc86464acU, 0xba5d5de7U, 0x3219192bU, 0xe6737395U,
0xc06060a0U, 0x19818198U, 0x9e4f4fd1U, 0xa3dcdc7fU,
0x44222266U, 0x542a2a7eU, 0x3b9090abU, 0x0b888883U,
0x8c4646caU, 0xc7eeee29U, 0x6bb8b8d3U, 0x2814143cU,
0xa7dede79U, 0xbc5e5ee2U, 0x160b0b1dU, 0xaddbdb76U,
0xdbe0e03bU, 0x64323256U, 0x743a3a4eU, 0x140a0a1eU,
0x924949dbU, 0x0c06060aU, 0x4824246cU, 0xb85c5ce4U,
0x9fc2c25dU, 0xbdd3d36eU, 0x43acacefU, 0xc46262a6U,
0x399191a8U, 0x319595a4U, 0xd3e4e437U, 0xf279798bU,
0xd5e7e732U, 0x8bc8c843U, 0x6e373759U, 0xda6d6db7U,
0x018d8d8cU, 0xb1d5d564U, 0x9c4e4ed2U, 0x49a9a9e0U,
0xd86c6cb4U, 0xac5656faU, 0xf3f4f407U, 0xcfeaea25U,
0xca6565afU, 0xf47a7a8eU, 0x47aeaee9U, 0x10080818U,
0x6fbabad5U, 0xf0787888U, 0x4a25256fU, 0x5c2e2e72U,
0x381c1c24U, 0x57a6a6f1U, 0x73b4b4c7U, 0x97c6c651U,
0xcbe8e823U, 0xa1dddd7cU, 0xe874749cU, 0x3e1f1f21U,
0x964b4bddU, 0x61bdbddcU, 0x0d8b8b86U, 0x0f8a8a85U,
0xe0707090U, 0x7c3e3e42U, 0x71b5b5c4U, 0xcc6666aaU,
0x904848d8U, 0x06030305U, 0xf7f6f601U, 0x1c0e0e12U,
0xc26161a3U, 0x6a35355fU, 0xae5757f9U, 0x69b9b9d0U,
0x17868691U, 0x99c1c158U, 0x3a1d1d27U, 0x279e9eb9U,
0xd9e1e138U, 0xebf8f813U, 0x2b9898b3U, 0x22111133U,
0xd26969bbU, 0xa9d9d970U, 0x078e8e89U, 0x339494a7U,
0x2d9b9bb6U, 0x3c1e1e22U, 0x15878792U, 0xc9e9e920U,
0x87cece49U, 0xaa5555ffU, 0x50282878U, 0xa5dfdf7aU,
0x038c8c8fU, 0x59a1a1f8U, 0x09898980U, 0x1a0d0d17U,
0x65bfbfdaU, 0xd7e6e631U, 0x844242c6U, 0xd06868b8U,
0x824141c3U, 0x299999b0U, 0x5a2d2d77U, 0x1e0f0f11U,
0x7bb0b0cbU, 0xa85454fcU, 0x6dbbbbd6U, 0x2c16163aU,
};
const u32 Td0[256] = {
0x51f4a750U, 0x7e416553U, 0x1a17a4c3U, 0x3a275e96U,
0x3bab6bcbU, 0x1f9d45f1U, 0xacfa58abU, 0x4be30393U,
0x2030fa55U, 0xad766df6U, 0x88cc7691U, 0xf5024c25U,
0x4fe5d7fcU, 0xc52acbd7U, 0x26354480U, 0xb562a38fU,
0xdeb15a49U, 0x25ba1b67U, 0x45ea0e98U, 0x5dfec0e1U,
0xc32f7502U, 0x814cf012U, 0x8d4697a3U, 0x6bd3f9c6U,
0x038f5fe7U, 0x15929c95U, 0xbf6d7aebU, 0x955259daU,
0xd4be832dU, 0x587421d3U, 0x49e06929U, 0x8ec9c844U,
0x75c2896aU, 0xf48e7978U, 0x99583e6bU, 0x27b971ddU,
0xbee14fb6U, 0xf088ad17U, 0xc920ac66U, 0x7dce3ab4U,
0x63df4a18U, 0xe51a3182U, 0x97513360U, 0x62537f45U,
0xb16477e0U, 0xbb6bae84U, 0xfe81a01cU, 0xf9082b94U,
0x70486858U, 0x8f45fd19U, 0x94de6c87U, 0x527bf8b7U,
0xab73d323U, 0x724b02e2U, 0xe31f8f57U, 0x6655ab2aU,
0xb2eb2807U, 0x2fb5c203U, 0x86c57b9aU, 0xd33708a5U,
0x302887f2U, 0x23bfa5b2U, 0x02036abaU, 0xed16825cU,
0x8acf1c2bU, 0xa779b492U, 0xf307f2f0U, 0x4e69e2a1U,
0x65daf4cdU, 0x0605bed5U, 0xd134621fU, 0xc4a6fe8aU,
0x342e539dU, 0xa2f355a0U, 0x058ae132U, 0xa4f6eb75U,
0x0b83ec39U, 0x4060efaaU, 0x5e719f06U, 0xbd6e1051U,
0x3e218af9U, 0x96dd063dU, 0xdd3e05aeU, 0x4de6bd46U,
0x91548db5U, 0x71c45d05U, 0x0406d46fU, 0x605015ffU,
0x1998fb24U, 0xd6bde997U, 0x894043ccU, 0x67d99e77U,
0xb0e842bdU, 0x07898b88U, 0xe7195b38U, 0x79c8eedbU,
0xa17c0a47U, 0x7c420fe9U, 0xf8841ec9U, 0x00000000U,
0x09808683U, 0x322bed48U, 0x1e1170acU, 0x6c5a724eU,
0xfd0efffbU, 0x0f853856U, 0x3daed51eU, 0x362d3927U,
0x0a0fd964U, 0x685ca621U, 0x9b5b54d1U, 0x24362e3aU,
0x0c0a67b1U, 0x9357e70fU, 0xb4ee96d2U, 0x1b9b919eU,
0x80c0c54fU, 0x61dc20a2U, 0x5a774b69U, 0x1c121a16U,
0xe293ba0aU, 0xc0a02ae5U, 0x3c22e043U, 0x121b171dU,
0x0e090d0bU, 0xf28bc7adU, 0x2db6a8b9U, 0x141ea9c8U,
0x57f11985U, 0xaf75074cU, 0xee99ddbbU, 0xa37f60fdU,
0xf701269fU, 0x5c72f5bcU, 0x44663bc5U, 0x5bfb7e34U,
0x8b432976U, 0xcb23c6dcU, 0xb6edfc68U, 0xb8e4f163U,
0xd731dccaU, 0x42638510U, 0x13972240U, 0x84c61120U,
0x854a247dU, 0xd2bb3df8U, 0xaef93211U, 0xc729a16dU,
0x1d9e2f4bU, 0xdcb230f3U, 0x0d8652ecU, 0x77c1e3d0U,
0x2bb3166cU, 0xa970b999U, 0x119448faU, 0x47e96422U,
0xa8fc8cc4U, 0xa0f03f1aU, 0x567d2cd8U, 0x223390efU,
0x87494ec7U, 0xd938d1c1U, 0x8ccaa2feU, 0x98d40b36U,
0xa6f581cfU, 0xa57ade28U, 0xdab78e26U, 0x3fadbfa4U,
0x2c3a9de4U, 0x5078920dU, 0x6a5fcc9bU, 0x547e4662U,
0xf68d13c2U, 0x90d8b8e8U, 0x2e39f75eU, 0x82c3aff5U,
0x9f5d80beU, 0x69d0937cU, 0x6fd52da9U, 0xcf2512b3U,
0xc8ac993bU, 0x10187da7U, 0xe89c636eU, 0xdb3bbb7bU,
0xcd267809U, 0x6e5918f4U, 0xec9ab701U, 0x834f9aa8U,
0xe6956e65U, 0xaaffe67eU, 0x21bccf08U, 0xef15e8e6U,
0xbae79bd9U, 0x4a6f36ceU, 0xea9f09d4U, 0x29b07cd6U,
0x31a4b2afU, 0x2a3f2331U, 0xc6a59430U, 0x35a266c0U,
0x744ebc37U, 0xfc82caa6U, 0xe090d0b0U, 0x33a7d815U,
0xf104984aU, 0x41ecdaf7U, 0x7fcd500eU, 0x1791f62fU,
0x764dd68dU, 0x43efb04dU, 0xccaa4d54U, 0xe49604dfU,
0x9ed1b5e3U, 0x4c6a881bU, 0xc12c1fb8U, 0x4665517fU,
0x9d5eea04U, 0x018c355dU, 0xfa877473U, 0xfb0b412eU,
0xb3671d5aU, 0x92dbd252U, 0xe9105633U, 0x6dd64713U,
0x9ad7618cU, 0x37a10c7aU, 0x59f8148eU, 0xeb133c89U,
0xcea927eeU, 0xb761c935U, 0xe11ce5edU, 0x7a47b13cU,
0x9cd2df59U, 0x55f2733fU, 0x1814ce79U, 0x73c737bfU,
0x53f7cdeaU, 0x5ffdaa5bU, 0xdf3d6f14U, 0x7844db86U,
0xcaaff381U, 0xb968c43eU, 0x3824342cU, 0xc2a3405fU,
0x161dc372U, 0xbce2250cU, 0x283c498bU, 0xff0d9541U,
0x39a80171U, 0x080cb3deU, 0xd8b4e49cU, 0x6456c190U,
0x7bcb8461U, 0xd532b670U, 0x486c5c74U, 0xd0b85742U,
};
const u8 Td4s[256] = {
0x52U, 0x09U, 0x6aU, 0xd5U, 0x30U, 0x36U, 0xa5U, 0x38U,
0xbfU, 0x40U, 0xa3U, 0x9eU, 0x81U, 0xf3U, 0xd7U, 0xfbU,
0x7cU, 0xe3U, 0x39U, 0x82U, 0x9bU, 0x2fU, 0xffU, 0x87U,
0x34U, 0x8eU, 0x43U, 0x44U, 0xc4U, 0xdeU, 0xe9U, 0xcbU,
0x54U, 0x7bU, 0x94U, 0x32U, 0xa6U, 0xc2U, 0x23U, 0x3dU,
0xeeU, 0x4cU, 0x95U, 0x0bU, 0x42U, 0xfaU, 0xc3U, 0x4eU,
0x08U, 0x2eU, 0xa1U, 0x66U, 0x28U, 0xd9U, 0x24U, 0xb2U,
0x76U, 0x5bU, 0xa2U, 0x49U, 0x6dU, 0x8bU, 0xd1U, 0x25U,
0x72U, 0xf8U, 0xf6U, 0x64U, 0x86U, 0x68U, 0x98U, 0x16U,
0xd4U, 0xa4U, 0x5cU, 0xccU, 0x5dU, 0x65U, 0xb6U, 0x92U,
0x6cU, 0x70U, 0x48U, 0x50U, 0xfdU, 0xedU, 0xb9U, 0xdaU,
0x5eU, 0x15U, 0x46U, 0x57U, 0xa7U, 0x8dU, 0x9dU, 0x84U,
0x90U, 0xd8U, 0xabU, 0x00U, 0x8cU, 0xbcU, 0xd3U, 0x0aU,
0xf7U, 0xe4U, 0x58U, 0x05U, 0xb8U, 0xb3U, 0x45U, 0x06U,
0xd0U, 0x2cU, 0x1eU, 0x8fU, 0xcaU, 0x3fU, 0x0fU, 0x02U,
0xc1U, 0xafU, 0xbdU, 0x03U, 0x01U, 0x13U, 0x8aU, 0x6bU,
0x3aU, 0x91U, 0x11U, 0x41U, 0x4fU, 0x67U, 0xdcU, 0xeaU,
0x97U, 0xf2U, 0xcfU, 0xceU, 0xf0U, 0xb4U, 0xe6U, 0x73U,
0x96U, 0xacU, 0x74U, 0x22U, 0xe7U, 0xadU, 0x35U, 0x85U,
0xe2U, 0xf9U, 0x37U, 0xe8U, 0x1cU, 0x75U, 0xdfU, 0x6eU,
0x47U, 0xf1U, 0x1aU, 0x71U, 0x1dU, 0x29U, 0xc5U, 0x89U,
0x6fU, 0xb7U, 0x62U, 0x0eU, 0xaaU, 0x18U, 0xbeU, 0x1bU,
0xfcU, 0x56U, 0x3eU, 0x4bU, 0xc6U, 0xd2U, 0x79U, 0x20U,
0x9aU, 0xdbU, 0xc0U, 0xfeU, 0x78U, 0xcdU, 0x5aU, 0xf4U,
0x1fU, 0xddU, 0xa8U, 0x33U, 0x88U, 0x07U, 0xc7U, 0x31U,
0xb1U, 0x12U, 0x10U, 0x59U, 0x27U, 0x80U, 0xecU, 0x5fU,
0x60U, 0x51U, 0x7fU, 0xa9U, 0x19U, 0xb5U, 0x4aU, 0x0dU,
0x2dU, 0xe5U, 0x7aU, 0x9fU, 0x93U, 0xc9U, 0x9cU, 0xefU,
0xa0U, 0xe0U, 0x3bU, 0x4dU, 0xaeU, 0x2aU, 0xf5U, 0xb0U,
0xc8U, 0xebU, 0xbbU, 0x3cU, 0x83U, 0x53U, 0x99U, 0x61U,
0x17U, 0x2bU, 0x04U, 0x7eU, 0xbaU, 0x77U, 0xd6U, 0x26U,
0xe1U, 0x69U, 0x14U, 0x63U, 0x55U, 0x21U, 0x0cU, 0x7dU,
};
const u8 rcons[] = {
0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1B, 0x36
/* for 128-bit blocks, Rijndael never uses more than 10 rcon values */
};
/**
* Expand the cipher key into the encryption key schedule.
*
* @return the number of rounds for the given cipher key size.
*/
#ifndef PLATFORM_FREEBSD /* Baron */
static void rijndaelKeySetupEnc(u32 rk[/*44*/], const u8 cipherKey[])
{
int i;
u32 temp;
rk[0] = GETU32(cipherKey);
rk[1] = GETU32(cipherKey + 4);
rk[2] = GETU32(cipherKey + 8);
rk[3] = GETU32(cipherKey + 12);
for (i = 0; i < 10; i++) {
temp = rk[3];
rk[4] = rk[0] ^
TE421(temp) ^ TE432(temp) ^ TE443(temp) ^ TE414(temp) ^
RCON(i);
rk[5] = rk[1] ^ rk[4];
rk[6] = rk[2] ^ rk[5];
rk[7] = rk[3] ^ rk[6];
rk += 4;
}
}
static void rijndaelEncrypt(u32 rk[/*44*/], u8 pt[16], u8 ct[16])
{
u32 s0, s1, s2, s3, t0, t1, t2, t3;
int Nr = 10;
#ifndef FULL_UNROLL
int r;
#endif /* ?FULL_UNROLL */
/*
* map byte array block to cipher state
* and add initial round key:
*/
s0 = GETU32(pt) ^ rk[0];
s1 = GETU32(pt + 4) ^ rk[1];
s2 = GETU32(pt + 8) ^ rk[2];
s3 = GETU32(pt + 12) ^ rk[3];
#define ROUND(i, d, s) do {\
d##0 = TE0(s##0) ^ TE1(s##1) ^ TE2(s##2) ^ TE3(s##3) ^ rk[4 * i]; \
d##1 = TE0(s##1) ^ TE1(s##2) ^ TE2(s##3) ^ TE3(s##0) ^ rk[4 * i + 1]; \
d##2 = TE0(s##2) ^ TE1(s##3) ^ TE2(s##0) ^ TE3(s##1) ^ rk[4 * i + 2]; \
d##3 = TE0(s##3) ^ TE1(s##0) ^ TE2(s##1) ^ TE3(s##2) ^ rk[4 * i + 3]; \
} while (0)
#ifdef FULL_UNROLL
ROUND(1, t, s);
ROUND(2, s, t);
ROUND(3, t, s);
ROUND(4, s, t);
ROUND(5, t, s);
ROUND(6, s, t);
ROUND(7, t, s);
ROUND(8, s, t);
ROUND(9, t, s);
rk += Nr << 2;
#else /* !FULL_UNROLL */
/* Nr - 1 full rounds: */
r = Nr >> 1;
for (;;) {
ROUND(1, t, s);
rk += 8;
if (--r == 0)
break;
ROUND(0, s, t);
}
#endif /* ?FULL_UNROLL */
#undef ROUND
/*
* apply last round and
* map cipher state to byte array block:
*/
s0 = TE41(t0) ^ TE42(t1) ^ TE43(t2) ^ TE44(t3) ^ rk[0];
PUTU32(ct , s0);
s1 = TE41(t1) ^ TE42(t2) ^ TE43(t3) ^ TE44(t0) ^ rk[1];
PUTU32(ct + 4, s1);
s2 = TE41(t2) ^ TE42(t3) ^ TE43(t0) ^ TE44(t1) ^ rk[2];
PUTU32(ct + 8, s2);
s3 = TE41(t3) ^ TE42(t0) ^ TE43(t1) ^ TE44(t2) ^ rk[3];
PUTU32(ct + 12, s3);
}
static void *aes_encrypt_init(const u8 *key, size_t len)
{
u32 *rk;
if (len != 16)
return NULL;
rk = (u32 *)rtw_malloc(AES_PRIV_SIZE);
if (rk == NULL)
return NULL;
rijndaelKeySetupEnc(rk, key);
return rk;
}
static void aes_128_encrypt(void *ctx, u8 *plain, u8 *crypt)
{
rijndaelEncrypt(ctx, plain, crypt);
}
static void gf_mulx(u8 *pad)
{
int i, carry;
carry = pad[0] & 0x80;
for (i = 0; i < AES_BLOCK_SIZE - 1; i++)
pad[i] = (pad[i] << 1) | (pad[i + 1] >> 7);
pad[AES_BLOCK_SIZE - 1] <<= 1;
if (carry)
pad[AES_BLOCK_SIZE - 1] ^= 0x87;
}
static void aes_encrypt_deinit(void *ctx)
{
_rtw_memset(ctx, 0, AES_PRIV_SIZE);
rtw_mfree(ctx, AES_PRIV_SIZE);
}
/**
* omac1_aes_128_vector - One-Key CBC MAC (OMAC1) hash with AES-128
* @key: 128-bit key for the hash operation
* @num_elem: Number of elements in the data vector
* @addr: Pointers to the data areas
* @len: Lengths of the data blocks
* @mac: Buffer for MAC (128 bits, i.e., 16 bytes)
* Returns: 0 on success, -1 on failure
*
* This is a mode for using block cipher (AES in this case) for authentication.
* OMAC1 was standardized with the name CMAC by NIST in a Special Publication
* (SP) 800-38B.
*/
static int omac1_aes_128_vector(const u8 *key, size_t num_elem,
const u8 *addr[], const size_t *len, u8 *mac)
{
void *ctx;
u8 cbc[AES_BLOCK_SIZE], pad[AES_BLOCK_SIZE];
const u8 *pos, *end;
size_t i, e, left, total_len;
ctx = aes_encrypt_init(key, 16);
if (ctx == NULL)
return -1;
_rtw_memset(cbc, 0, AES_BLOCK_SIZE);
total_len = 0;
for (e = 0; e < num_elem; e++)
total_len += len[e];
left = total_len;
e = 0;
pos = addr[0];
end = pos + len[0];
while (left >= AES_BLOCK_SIZE) {
for (i = 0; i < AES_BLOCK_SIZE; i++) {
cbc[i] ^= *pos++;
if (pos >= end) {
e++;
pos = addr[e];
end = pos + len[e];
}
}
if (left > AES_BLOCK_SIZE)
aes_128_encrypt(ctx, cbc, cbc);
left -= AES_BLOCK_SIZE;
}
_rtw_memset(pad, 0, AES_BLOCK_SIZE);
aes_128_encrypt(ctx, pad, pad);
gf_mulx(pad);
if (left || total_len == 0) {
for (i = 0; i < left; i++) {
cbc[i] ^= *pos++;
if (pos >= end) {
e++;
pos = addr[e];
end = pos + len[e];
}
}
cbc[left] ^= 0x80;
gf_mulx(pad);
}
for (i = 0; i < AES_BLOCK_SIZE; i++)
pad[i] ^= cbc[i];
aes_128_encrypt(ctx, pad, mac);
aes_encrypt_deinit(ctx);
return 0;
}
/**
* omac1_aes_128 - One-Key CBC MAC (OMAC1) hash with AES-128 (aka AES-CMAC)
* @key: 128-bit key for the hash operation
* @data: Data buffer for which a MAC is determined
* @data_len: Length of data buffer in bytes
* @mac: Buffer for MAC (128 bits, i.e., 16 bytes)
* Returns: 0 on success, -1 on failure
*
* This is a mode for using block cipher (AES in this case) for authentication.
* OMAC1 was standardized with the name CMAC by NIST in a Special Publication
* (SP) 800-38B.
*/ /* modify for CONFIG_IEEE80211W */
int omac1_aes_128(const u8 *key, const u8 *data, size_t data_len, u8 *mac)
{
return omac1_aes_128_vector(key, 1, &data, &data_len, mac);
}
#endif /* PLATFORM_FREEBSD Baron */
#ifdef CONFIG_RTW_MESH_AEK
/* for AES-SIV */
#define os_memset _rtw_memset
#define os_memcpy _rtw_memcpy
#define os_malloc rtw_malloc
#define bin_clear_free(bin, len) \
do { \
if (bin) { \
os_memset(bin, 0, len); \
rtw_mfree(bin, len); \
} \
} while (0)
static const u8 zero[AES_BLOCK_SIZE];
static void dbl(u8 *pad)
{
int i, carry;
carry = pad[0] & 0x80;
for (i = 0; i < AES_BLOCK_SIZE - 1; i++)
pad[i] = (pad[i] << 1) | (pad[i + 1] >> 7);
pad[AES_BLOCK_SIZE - 1] <<= 1;
if (carry)
pad[AES_BLOCK_SIZE - 1] ^= 0x87;
}
static void xor(u8 *a, const u8 *b)
{
int i;
for (i = 0; i < AES_BLOCK_SIZE; i++)
*a++ ^= *b++;
}
static void xorend(u8 *a, int alen, const u8 *b, int blen)
{
int i;
if (alen < blen)
return;
for (i = 0; i < blen; i++)
a[alen - blen + i] ^= b[i];
}
static void pad_block(u8 *pad, const u8 *addr, size_t len)
{
os_memset(pad, 0, AES_BLOCK_SIZE);
os_memcpy(pad, addr, len);
if (len < AES_BLOCK_SIZE)
pad[len] = 0x80;
}
static int aes_s2v(const u8 *key, size_t num_elem, const u8 *addr[],
size_t *len, u8 *mac)
{
u8 tmp[AES_BLOCK_SIZE], tmp2[AES_BLOCK_SIZE];
u8 *buf = NULL;
int ret;
size_t i;
if (!num_elem) {
os_memcpy(tmp, zero, sizeof(zero));
tmp[AES_BLOCK_SIZE - 1] = 1;
return omac1_aes_128(key, tmp, sizeof(tmp), mac);
}
ret = omac1_aes_128(key, zero, sizeof(zero), tmp);
if (ret)
return ret;
for (i = 0; i < num_elem - 1; i++) {
ret = omac1_aes_128(key, addr[i], len[i], tmp2);
if (ret)
return ret;
dbl(tmp);
xor(tmp, tmp2);
}
if (len[i] >= AES_BLOCK_SIZE) {
buf = os_malloc(len[i]);
if (!buf)
return -ENOMEM;
os_memcpy(buf, addr[i], len[i]);
xorend(buf, len[i], tmp, AES_BLOCK_SIZE);
ret = omac1_aes_128(key, buf, len[i], mac);
bin_clear_free(buf, len[i]);
return ret;
}
dbl(tmp);
pad_block(tmp2, addr[i], len[i]);
xor(tmp, tmp2);
return omac1_aes_128(key, tmp, sizeof(tmp), mac);
}
/**
* aes_128_ctr_encrypt - AES-128 CTR mode encryption
* @key: Key for encryption (16 bytes)
* @nonce: Nonce for counter mode (16 bytes)
* @data: Data to encrypt in-place
* @data_len: Length of data in bytes
* Returns: 0 on success, -1 on failure
*/
int aes_128_ctr_encrypt(const u8 *key, const u8 *nonce,
u8 *data, size_t data_len)
{
void *ctx;
size_t j, len, left = data_len;
int i;
u8 *pos = data;
u8 counter[AES_BLOCK_SIZE], buf[AES_BLOCK_SIZE];
ctx = aes_encrypt_init(key, 16);
if (ctx == NULL)
return -1;
os_memcpy(counter, nonce, AES_BLOCK_SIZE);
while (left > 0) {
#if 0
aes_encrypt(ctx, counter, buf);
#else
aes_128_encrypt(ctx, counter, buf);
#endif
len = (left < AES_BLOCK_SIZE) ? left : AES_BLOCK_SIZE;
for (j = 0; j < len; j++)
pos[j] ^= buf[j];
pos += len;
left -= len;
for (i = AES_BLOCK_SIZE - 1; i >= 0; i--) {
counter[i]++;
if (counter[i])
break;
}
}
aes_encrypt_deinit(ctx);
return 0;
}
int aes_siv_encrypt(const u8 *key, const u8 *pw,
size_t pwlen, size_t num_elem,
const u8 *addr[], const size_t *len, u8 *out)
{
const u8 *_addr[6];
size_t _len[6];
const u8 *k1 = key, *k2 = key + 16;
u8 v[AES_BLOCK_SIZE];
size_t i;
u8 *iv, *crypt_pw;
if (num_elem > ARRAY_SIZE(_addr) - 1)
return -1;
for (i = 0; i < num_elem; i++) {
_addr[i] = addr[i];
_len[i] = len[i];
}
_addr[num_elem] = pw;
_len[num_elem] = pwlen;
if (aes_s2v(k1, num_elem + 1, _addr, _len, v))
return -1;
iv = out;
crypt_pw = out + AES_BLOCK_SIZE;
os_memcpy(iv, v, AES_BLOCK_SIZE);
os_memcpy(crypt_pw, pw, pwlen);
/* zero out 63rd and 31st bits of ctr (from right) */
v[8] &= 0x7f;
v[12] &= 0x7f;
return aes_128_ctr_encrypt(k2, v, crypt_pw, pwlen);
}
int aes_siv_decrypt(const u8 *key, const u8 *iv_crypt, size_t iv_c_len,
size_t num_elem, const u8 *addr[], const size_t *len,
u8 *out)
{
const u8 *_addr[6];
size_t _len[6];
const u8 *k1 = key, *k2 = key + 16;
size_t crypt_len;
size_t i;
int ret;
u8 iv[AES_BLOCK_SIZE];
u8 check[AES_BLOCK_SIZE];
if (iv_c_len < AES_BLOCK_SIZE || num_elem > ARRAY_SIZE(_addr) - 1)
return -1;
crypt_len = iv_c_len - AES_BLOCK_SIZE;
for (i = 0; i < num_elem; i++) {
_addr[i] = addr[i];
_len[i] = len[i];
}
_addr[num_elem] = out;
_len[num_elem] = crypt_len;
os_memcpy(iv, iv_crypt, AES_BLOCK_SIZE);
os_memcpy(out, iv_crypt + AES_BLOCK_SIZE, crypt_len);
iv[8] &= 0x7f;
iv[12] &= 0x7f;
ret = aes_128_ctr_encrypt(k2, iv, out, crypt_len);
if (ret)
return ret;
ret = aes_s2v(k1, num_elem + 1, _addr, _len, check);
if (ret)
return ret;
if (os_memcmp(check, iv_crypt, AES_BLOCK_SIZE) == 0)
return 0;
return -1;
}
#endif /* CONFIG_RTW_MESH_AEK */
#ifdef CONFIG_TDLS
void wpa_tdls_generate_tpk(_adapter *padapter, void *sta)
{
struct sta_info *psta = (struct sta_info *)sta;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 *SNonce = psta->SNonce;
u8 *ANonce = psta->ANonce;
u8 key_input[SHA256_MAC_LEN];
u8 *nonce[2];
size_t len[2];
u8 data[3 * ETH_ALEN];
/* IEEE Std 802.11z-2010 8.5.9.1:
* TPK-Key-Input = SHA-256(min(SNonce, ANonce) || max(SNonce, ANonce))
*/
len[0] = 32;
len[1] = 32;
if (os_memcmp(SNonce, ANonce, 32) < 0) {
nonce[0] = SNonce;
nonce[1] = ANonce;
} else {
nonce[0] = ANonce;
nonce[1] = SNonce;
}
sha256_vector(2, nonce, len, key_input);
/*
* TPK-Key-Data = KDF-N_KEY(TPK-Key-Input, "TDLS PMK",
* min(MAC_I, MAC_R) || max(MAC_I, MAC_R) || BSSID || N_KEY)
* TODO: is N_KEY really included in KDF Context and if so, in which
* presentation format (little endian 16-bit?) is it used? It gets
* added by the KDF anyway..
*/
if (os_memcmp(adapter_mac_addr(padapter), psta->cmn.mac_addr, ETH_ALEN) < 0) {
_rtw_memcpy(data, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(data + ETH_ALEN, psta->cmn.mac_addr, ETH_ALEN);
} else {
_rtw_memcpy(data, psta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(data + ETH_ALEN, adapter_mac_addr(padapter), ETH_ALEN);
}
_rtw_memcpy(data + 2 * ETH_ALEN, get_bssid(pmlmepriv), ETH_ALEN);
sha256_prf(key_input, SHA256_MAC_LEN, "TDLS PMK", data, sizeof(data), (u8 *) &psta->tpk, sizeof(psta->tpk));
}
/**
* wpa_tdls_ftie_mic - Calculate TDLS FTIE MIC
* @kck: TPK-KCK
* @lnkid: Pointer to the beginning of Link Identifier IE
* @rsnie: Pointer to the beginning of RSN IE used for handshake
* @timeoutie: Pointer to the beginning of Timeout IE used for handshake
* @ftie: Pointer to the beginning of FT IE
* @mic: Pointer for writing MIC
*
* Calculate MIC for TDLS frame.
*/
int wpa_tdls_ftie_mic(u8 *kck, u8 trans_seq,
u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie,
u8 *mic)
{
u8 *buf, *pos;
struct wpa_tdls_ftie *_ftie;
struct wpa_tdls_lnkid *_lnkid;
int ret;
int len = 2 * ETH_ALEN + 1 + 2 + lnkid[1] + 2 + rsnie[1] +
2 + timeoutie[1] + 2 + ftie[1];
buf = rtw_zmalloc(len);
if (!buf) {
RTW_INFO("TDLS: No memory for MIC calculation\n");
return -1;
}
pos = buf;
_lnkid = (struct wpa_tdls_lnkid *) lnkid;
/* 1) TDLS initiator STA MAC address */
_rtw_memcpy(pos, _lnkid->init_sta, ETH_ALEN);
pos += ETH_ALEN;
/* 2) TDLS responder STA MAC address */
_rtw_memcpy(pos, _lnkid->resp_sta, ETH_ALEN);
pos += ETH_ALEN;
/* 3) Transaction Sequence number */
*pos++ = trans_seq;
/* 4) Link Identifier IE */
_rtw_memcpy(pos, lnkid, 2 + lnkid[1]);
pos += 2 + lnkid[1];
/* 5) RSN IE */
_rtw_memcpy(pos, rsnie, 2 + rsnie[1]);
pos += 2 + rsnie[1];
/* 6) Timeout Interval IE */
_rtw_memcpy(pos, timeoutie, 2 + timeoutie[1]);
pos += 2 + timeoutie[1];
/* 7) FTIE, with the MIC field of the FTIE set to 0 */
_rtw_memcpy(pos, ftie, 2 + ftie[1]);
_ftie = (struct wpa_tdls_ftie *) pos;
_rtw_memset(_ftie->mic, 0, TDLS_MIC_LEN);
pos += 2 + ftie[1];
ret = omac1_aes_128(kck, buf, pos - buf, mic);
rtw_mfree(buf, len);
return ret;
}
/**
* wpa_tdls_teardown_ftie_mic - Calculate TDLS TEARDOWN FTIE MIC
* @kck: TPK-KCK
* @lnkid: Pointer to the beginning of Link Identifier IE
* @reason: Reason code of TDLS Teardown
* @dialog_token: Dialog token that was used in the MIC calculation for TPK Handshake Message 3
* @trans_seq: Transaction Sequence number (1 octet) which shall be set to the value 4
* @ftie: Pointer to the beginning of FT IE
* @mic: Pointer for writing MIC
*
* Calculate MIC for TDLS TEARDOWN frame according to Section 10.22.5 in IEEE 802.11 - 2012.
*/
int wpa_tdls_teardown_ftie_mic(u8 *kck, u8 *lnkid, u16 reason,
u8 dialog_token, u8 trans_seq, u8 *ftie, u8 *mic)
{
u8 *buf, *pos;
struct wpa_tdls_ftie *_ftie;
int ret;
int len = 2 + lnkid[1] + 2 + 1 + 1 + 2 + ftie[1];
buf = rtw_zmalloc(len);
if (!buf) {
RTW_INFO("TDLS: No memory for MIC calculation\n");
return -1;
}
pos = buf;
/* 1) Link Identifier IE */
_rtw_memcpy(pos, lnkid, 2 + lnkid[1]);
pos += 2 + lnkid[1];
/* 2) Reason Code */
_rtw_memcpy(pos, (u8 *)&reason, 2);
pos += 2;
/* 3) Dialog Token */
*pos++ = dialog_token;
/* 4) Transaction Sequence number */
*pos++ = trans_seq;
/* 5) FTIE, with the MIC field of the FTIE set to 0 */
_rtw_memcpy(pos, ftie, 2 + ftie[1]);
_ftie = (struct wpa_tdls_ftie *) pos;
_rtw_memset(_ftie->mic, 0, TDLS_MIC_LEN);
pos += 2 + ftie[1];
ret = omac1_aes_128(kck, buf, pos - buf, mic);
rtw_mfree(buf, len);
return ret;
}
int tdls_verify_mic(u8 *kck, u8 trans_seq,
u8 *lnkid, u8 *rsnie, u8 *timeoutie, u8 *ftie)
{
u8 *buf, *pos;
int len;
u8 mic[16];
int ret;
u8 *rx_ftie, *tmp_ftie;
if (lnkid == NULL || rsnie == NULL ||
timeoutie == NULL || ftie == NULL)
return _FAIL;
len = 2 * ETH_ALEN + 1 + 2 + 18 + 2 + *(rsnie + 1) + 2 + *(timeoutie + 1) + 2 + *(ftie + 1);
buf = rtw_zmalloc(len);
if (buf == NULL)
return _FAIL;
pos = buf;
/* 1) TDLS initiator STA MAC address */
_rtw_memcpy(pos, lnkid + ETH_ALEN + 2, ETH_ALEN);
pos += ETH_ALEN;
/* 2) TDLS responder STA MAC address */
_rtw_memcpy(pos, lnkid + 2 * ETH_ALEN + 2, ETH_ALEN);
pos += ETH_ALEN;
/* 3) Transaction Sequence number */
*pos++ = trans_seq;
/* 4) Link Identifier IE */
_rtw_memcpy(pos, lnkid, 2 + 18);
pos += 2 + 18;
/* 5) RSN IE */
_rtw_memcpy(pos, rsnie, 2 + *(rsnie + 1));
pos += 2 + *(rsnie + 1);
/* 6) Timeout Interval IE */
_rtw_memcpy(pos, timeoutie, 2 + *(timeoutie + 1));
pos += 2 + *(timeoutie + 1);
/* 7) FTIE, with the MIC field of the FTIE set to 0 */
_rtw_memcpy(pos, ftie, 2 + *(ftie + 1));
pos += 2;
tmp_ftie = (u8 *)(pos + 2);
_rtw_memset(tmp_ftie, 0, 16);
pos += *(ftie + 1);
ret = omac1_aes_128(kck, buf, pos - buf, mic);
rtw_mfree(buf, len);
if (ret)
return _FAIL;
rx_ftie = ftie + 4;
if (os_memcmp(mic, rx_ftie, 16) == 0) {
/* Valid MIC */
return _SUCCESS;
}
/* Invalid MIC */
RTW_INFO("[%s] Invalid MIC\n", __FUNCTION__);
return _FAIL;
}
#endif /* CONFIG_TDLS */
/* Restore HW wep key setting according to key_mask */
void rtw_sec_restore_wep_key(_adapter *adapter)
{
struct security_priv *securitypriv = &(adapter->securitypriv);
sint keyid;
if ((_WEP40_ == securitypriv->dot11PrivacyAlgrthm) || (_WEP104_ == securitypriv->dot11PrivacyAlgrthm)) {
for (keyid = 0; keyid < 4; keyid++) {
if (securitypriv->key_mask & BIT(keyid)) {
if (keyid == securitypriv->dot11PrivacyKeyIndex)
rtw_set_key(adapter, securitypriv, keyid, 1, _FALSE);
else
rtw_set_key(adapter, securitypriv, keyid, 0, _FALSE);
}
}
}
}
u8 rtw_handle_tkip_countermeasure(_adapter *adapter, const char *caller)
{
struct security_priv *securitypriv = &(adapter->securitypriv);
u8 status = _SUCCESS;
if (securitypriv->btkip_countermeasure == _TRUE) {
u32 passing_ms = rtw_get_passing_time_ms(securitypriv->btkip_countermeasure_time);
if (passing_ms > 60 * 1000) {
RTW_PRINT("%s("ADPT_FMT") countermeasure time:%ds > 60s\n",
caller, ADPT_ARG(adapter), passing_ms / 1000);
securitypriv->btkip_countermeasure = _FALSE;
securitypriv->btkip_countermeasure_time = 0;
} else {
RTW_PRINT("%s("ADPT_FMT") countermeasure time:%ds < 60s\n",
caller, ADPT_ARG(adapter), passing_ms / 1000);
status = _FAIL;
}
}
return status;
}
#ifdef CONFIG_WOWLAN
u16 rtw_cal_crc16(u8 data, u16 crc)
{
u8 shift_in, data_bit;
u8 crc_bit4, crc_bit11, crc_bit15;
u16 crc_result;
int index;
for (index = 0; index < 8; index++) {
crc_bit15 = ((crc & BIT15) ? 1 : 0);
data_bit = (data & (BIT0 << index) ? 1 : 0);
shift_in = crc_bit15 ^ data_bit;
/*printf("crc_bit15=%d, DataBit=%d, shift_in=%d\n",
* crc_bit15, data_bit, shift_in);*/
crc_result = crc << 1;
if (shift_in == 0)
crc_result &= (~BIT0);
else
crc_result |= BIT0;
/*printf("CRC =%x\n",CRC_Result);*/
crc_bit11 = ((crc & BIT11) ? 1 : 0) ^ shift_in;
if (crc_bit11 == 0)
crc_result &= (~BIT12);
else
crc_result |= BIT12;
/*printf("bit12 CRC =%x\n",CRC_Result);*/
crc_bit4 = ((crc & BIT4) ? 1 : 0) ^ shift_in;
if (crc_bit4 == 0)
crc_result &= (~BIT5);
else
crc_result |= BIT5;
/* printf("bit5 CRC =%x\n",CRC_Result); */
/* repeat using the last result*/
crc = crc_result;
}
return crc;
}
/*
* function name :rtw_calc_crc
*
* input: char* pattern , pattern size
*
*/
u16 rtw_calc_crc(u8 *pdata, int length)
{
u16 crc = 0xffff;
int i;
for (i = 0; i < length; i++)
crc = rtw_cal_crc16(pdata[i], crc);
/* get 1' complement */
crc = ~crc;
return crc;
}
#endif /*CONFIG_WOWLAN*/
================================================
FILE: core/rtw_sreset.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#include
void sreset_init_value(_adapter *padapter)
{
#if defined(DBG_CONFIG_ERROR_DETECT)
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
_rtw_mutex_init(&psrtpriv->silentreset_mutex);
psrtpriv->silent_reset_inprogress = _FALSE;
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
psrtpriv->last_tx_time = 0;
psrtpriv->last_tx_complete_time = 0;
#endif
}
void sreset_reset_value(_adapter *padapter)
{
#if defined(DBG_CONFIG_ERROR_DETECT)
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
psrtpriv->last_tx_time = 0;
psrtpriv->last_tx_complete_time = 0;
#endif
}
u8 sreset_get_wifi_status(_adapter *padapter)
{
#if defined(DBG_CONFIG_ERROR_DETECT)
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
u8 status = WIFI_STATUS_SUCCESS;
u32 val32 = 0;
if (psrtpriv->silent_reset_inprogress == _TRUE)
return status;
val32 = rtw_read32(padapter, REG_TXDMA_STATUS);
if (val32 == 0xeaeaeaea)
psrtpriv->Wifi_Error_Status = WIFI_IF_NOT_EXIST;
else if (val32 != 0) {
RTW_INFO("txdmastatu(%x)\n", val32);
psrtpriv->Wifi_Error_Status = WIFI_MAC_TXDMA_ERROR;
}
if (WIFI_STATUS_SUCCESS != psrtpriv->Wifi_Error_Status) {
RTW_INFO("==>%s error_status(0x%x)\n", __FUNCTION__, psrtpriv->Wifi_Error_Status);
status = (psrtpriv->Wifi_Error_Status & (~(USB_READ_PORT_FAIL | USB_WRITE_PORT_FAIL)));
}
RTW_INFO("==> %s wifi_status(0x%x)\n", __FUNCTION__, status);
/* status restore */
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
return status;
#else
return WIFI_STATUS_SUCCESS;
#endif
}
void sreset_set_wifi_error_status(_adapter *padapter, u32 status)
{
#if defined(DBG_CONFIG_ERROR_DETECT)
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
pHalData->srestpriv.Wifi_Error_Status = status;
#endif
}
void sreset_set_trigger_point(_adapter *padapter, s32 tgp)
{
#if defined(DBG_CONFIG_ERROR_DETECT)
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
pHalData->srestpriv.dbg_trigger_point = tgp;
#endif
}
bool sreset_inprogress(_adapter *padapter)
{
#if defined(DBG_CONFIG_ERROR_RESET)
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
return pHalData->srestpriv.silent_reset_inprogress;
#else
return _FALSE;
#endif
}
void sreset_restore_security_station(_adapter *padapter)
{
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
struct mlme_ext_info *pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
{
u8 val8;
if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) {
val8 = 0xcc;
#ifdef CONFIG_WAPI_SUPPORT
} else if (padapter->wapiInfo.bWapiEnable && pmlmeinfo->auth_algo == dot11AuthAlgrthm_WAPI) {
/* Disable TxUseDefaultKey, RxUseDefaultKey, RxBroadcastUseDefaultKey. */
val8 = 0x4c;
#endif
} else
val8 = 0xcf;
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_CFG, (u8 *)(&val8));
}
if ((padapter->securitypriv.dot11PrivacyAlgrthm == _TKIP_) ||
(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
psta = rtw_get_stainfo(pstapriv, get_bssid(mlmepriv));
if (psta == NULL) {
/* DEBUG_ERR( ("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
} else {
/* pairwise key */
rtw_setstakey_cmd(padapter, psta, UNICAST_KEY, _FALSE);
/* group key */
rtw_set_key(padapter, &padapter->securitypriv, padapter->securitypriv.dot118021XGrpKeyid, 0, _FALSE);
}
}
}
void sreset_restore_network_station(_adapter *padapter)
{
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 doiqk = _FALSE;
rtw_setopmode_cmd(padapter, Ndis802_11Infrastructure, RTW_CMDF_DIRECTLY);
{
u8 threshold;
#ifdef CONFIG_USB_HCI
/* TH=1 => means that invalidate usb rx aggregation */
/* TH=0 => means that validate usb rx aggregation, use init value. */
#ifdef CONFIG_80211N_HT
if (mlmepriv->htpriv.ht_option) {
if (padapter->registrypriv.wifi_spec == 1)
threshold = 1;
else
threshold = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
} else {
threshold = 1;
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
}
#endif /* CONFIG_80211N_HT */
#endif
}
doiqk = _TRUE;
rtw_hal_set_hwreg(padapter, HW_VAR_DO_IQK , &doiqk);
set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
doiqk = _FALSE;
rtw_hal_set_hwreg(padapter , HW_VAR_DO_IQK , &doiqk);
/* disable dynamic functions, such as high power, DIG */
/*rtw_phydm_func_disable_all(padapter);*/
rtw_hal_set_hwreg(padapter, HW_VAR_BSSID, pmlmeinfo->network.MacAddress);
{
u8 join_type = 0;
rtw_hal_rcr_set_chk_bssid(padapter, MLME_STA_CONNECTING);
rtw_hal_set_hwreg(padapter, HW_VAR_MLME_JOIN, (u8 *)(&join_type));
}
Set_MSR(padapter, (pmlmeinfo->state & 0x3));
mlmeext_joinbss_event_callback(padapter, 1);
/* restore Sequence No. */
rtw_hal_set_hwreg(padapter, HW_VAR_RESTORE_HW_SEQ, 0);
sreset_restore_security_station(padapter);
}
void sreset_restore_network_status(_adapter *padapter)
{
struct mlme_priv *mlmepriv = &padapter->mlmepriv;
if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_STATION_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
sreset_restore_network_station(padapter);
} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(padapter), MLME_IS_AP(padapter) ? "AP" : "MESH");
rtw_ap_restore_network(padapter);
} else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE))
RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - WIFI_ADHOC_STATE\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
else
RTW_INFO(FUNC_ADPT_FMT" fwstate:0x%08x - ???\n", FUNC_ADPT_ARG(padapter), get_fwstate(mlmepriv));
}
void sreset_stop_adapter(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
if (padapter == NULL)
return;
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
rtw_netif_stop_queue(padapter->pnetdev);
rtw_cancel_all_timer(padapter);
/* TODO: OS and HCI independent */
#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
tasklet_kill(&pxmitpriv->xmit_tasklet);
#endif
if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
rtw_scan_abort(padapter);
if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
rtw_set_to_roam(padapter, 0);
rtw_join_timeout_handler(padapter);
}
}
void sreset_start_adapter(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
if (padapter == NULL)
return;
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
if (check_fwstate(pmlmepriv, _FW_LINKED))
sreset_restore_network_status(padapter);
/* TODO: OS and HCI independent */
#if defined(PLATFORM_LINUX) && defined(CONFIG_USB_HCI)
tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
#endif
if (is_primary_adapter(padapter))
_set_timer(&adapter_to_dvobj(padapter)->dynamic_chk_timer, 2000);
rtw_netif_wake_queue(padapter->pnetdev);
}
void sreset_reset(_adapter *padapter)
{
#ifdef DBG_CONFIG_ERROR_RESET
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct sreset_priv *psrtpriv = &pHalData->srestpriv;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
_irqL irqL;
systime start = rtw_get_current_time();
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
RTW_INFO("%s\n", __FUNCTION__);
psrtpriv->Wifi_Error_Status = WIFI_STATUS_SUCCESS;
#ifdef CONFIG_LPS
rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "SRESET");
#endif/* #ifdef CONFIG_LPS */
_enter_pwrlock(&pwrpriv->lock);
psrtpriv->silent_reset_inprogress = _TRUE;
pwrpriv->change_rfpwrstate = rf_off;
rtw_mi_sreset_adapter_hdl(padapter, _FALSE);/*sreset_stop_adapter*/
#ifdef CONFIG_IPS
_ips_enter(padapter);
_ips_leave(padapter);
#endif
rtw_mi_sreset_adapter_hdl(padapter, _TRUE);/*sreset_start_adapter*/
psrtpriv->silent_reset_inprogress = _FALSE;
_exit_pwrlock(&pwrpriv->lock);
RTW_INFO("%s done in %d ms\n", __FUNCTION__, rtw_get_passing_time_ms(start));
pdbgpriv->dbg_sreset_cnt++;
psrtpriv->self_dect_fw = _FALSE;
psrtpriv->rx_cnt = 0;
#endif
}
================================================
FILE: core/rtw_sta_mgt.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_STA_MGT_C_
#include
bool test_st_match_rule(_adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
{
if (ntohs(*((u16 *)local_port)) == 5001 || ntohs(*((u16 *)remote_port)) == 5001)
return _TRUE;
return _FALSE;
}
struct st_register test_st_reg = {
.s_proto = 0x06,
.rule = test_st_match_rule,
};
inline void rtw_st_ctl_init(struct st_ctl_t *st_ctl)
{
_rtw_memset(st_ctl->reg, 0 , sizeof(struct st_register) * SESSION_TRACKER_REG_ID_NUM);
_rtw_init_queue(&st_ctl->tracker_q);
}
inline void rtw_st_ctl_clear_tracker_q(struct st_ctl_t *st_ctl)
{
_irqL irqL;
_list *plist, *phead;
struct session_tracker *st;
_enter_critical_bh(&st_ctl->tracker_q.lock, &irqL);
phead = &st_ctl->tracker_q.queue;
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
st = LIST_CONTAINOR(plist, struct session_tracker, list);
plist = get_next(plist);
rtw_list_delete(&st->list);
rtw_mfree((u8 *)st, sizeof(struct session_tracker));
}
_exit_critical_bh(&st_ctl->tracker_q.lock, &irqL);
}
inline void rtw_st_ctl_deinit(struct st_ctl_t *st_ctl)
{
rtw_st_ctl_clear_tracker_q(st_ctl);
_rtw_deinit_queue(&st_ctl->tracker_q);
}
inline void rtw_st_ctl_register(struct st_ctl_t *st_ctl, u8 st_reg_id, struct st_register *reg)
{
if (st_reg_id >= SESSION_TRACKER_REG_ID_NUM) {
rtw_warn_on(1);
return;
}
st_ctl->reg[st_reg_id].s_proto = reg->s_proto;
st_ctl->reg[st_reg_id].rule = reg->rule;
}
inline void rtw_st_ctl_unregister(struct st_ctl_t *st_ctl, u8 st_reg_id)
{
int i;
if (st_reg_id >= SESSION_TRACKER_REG_ID_NUM) {
rtw_warn_on(1);
return;
}
st_ctl->reg[st_reg_id].s_proto = 0;
st_ctl->reg[st_reg_id].rule = NULL;
/* clear tracker queue if no session trecker registered */
for (i = 0; i < SESSION_TRACKER_REG_ID_NUM; i++)
if (st_ctl->reg[i].s_proto != 0)
break;
if (i >= SESSION_TRACKER_REG_ID_NUM)
rtw_st_ctl_clear_tracker_q(st_ctl);
}
inline bool rtw_st_ctl_chk_reg_s_proto(struct st_ctl_t *st_ctl, u8 s_proto)
{
bool ret = _FALSE;
int i;
for (i = 0; i < SESSION_TRACKER_REG_ID_NUM; i++) {
if (st_ctl->reg[i].s_proto == s_proto) {
ret = _TRUE;
break;
}
}
return ret;
}
inline bool rtw_st_ctl_chk_reg_rule(struct st_ctl_t *st_ctl, _adapter *adapter, u8 *local_naddr, u8 *local_port, u8 *remote_naddr, u8 *remote_port)
{
bool ret = _FALSE;
int i;
st_match_rule rule;
for (i = 0; i < SESSION_TRACKER_REG_ID_NUM; i++) {
rule = st_ctl->reg[i].rule;
if (rule && rule(adapter, local_naddr, local_port, remote_naddr, remote_port) == _TRUE) {
ret = _TRUE;
break;
}
}
return ret;
}
void rtw_st_ctl_rx(struct sta_info *sta, u8 *ehdr_pos)
{
_adapter *adapter = sta->padapter;
struct ethhdr *etherhdr = (struct ethhdr *)ehdr_pos;
if (ntohs(etherhdr->h_proto) == ETH_P_IP) {
u8 *ip = ehdr_pos + ETH_HLEN;
if (GET_IPV4_PROTOCOL(ip) == 0x06 /* TCP */
&& rtw_st_ctl_chk_reg_s_proto(&sta->st_ctl, 0x06) == _TRUE
) {
u8 *tcp = ip + GET_IPV4_IHL(ip) * 4;
if (rtw_st_ctl_chk_reg_rule(&sta->st_ctl, adapter, IPV4_DST(ip), TCP_DST(tcp), IPV4_SRC(ip), TCP_SRC(tcp)) == _TRUE) {
if (GET_TCP_SYN(tcp) && GET_TCP_ACK(tcp)) {
session_tracker_add_cmd(adapter, sta
, IPV4_DST(ip), TCP_DST(tcp)
, IPV4_SRC(ip), TCP_SRC(tcp));
if (DBG_SESSION_TRACKER)
RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" SYN-ACK\n"
, FUNC_ADPT_ARG(adapter)
, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp))
, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp)));
}
if (GET_TCP_FIN(tcp)) {
session_tracker_del_cmd(adapter, sta
, IPV4_DST(ip), TCP_DST(tcp)
, IPV4_SRC(ip), TCP_SRC(tcp));
if (DBG_SESSION_TRACKER)
RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" FIN\n"
, FUNC_ADPT_ARG(adapter)
, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp))
, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp)));
}
}
}
}
}
#define SESSION_TRACKER_FMT IP_FMT":"PORT_FMT" "IP_FMT":"PORT_FMT" %u %d"
#define SESSION_TRACKER_ARG(st) IP_ARG(&(st)->local_naddr), PORT_ARG(&(st)->local_port), IP_ARG(&(st)->remote_naddr), PORT_ARG(&(st)->remote_port), (st)->status, rtw_get_passing_time_ms((st)->set_time)
void dump_st_ctl(void *sel, struct st_ctl_t *st_ctl)
{
int i;
_irqL irqL;
_list *plist, *phead;
struct session_tracker *st;
if (!DBG_SESSION_TRACKER)
return;
for (i = 0; i < SESSION_TRACKER_REG_ID_NUM; i++)
RTW_PRINT_SEL(sel, "reg%d: %u %p\n", i, st_ctl->reg[i].s_proto, st_ctl->reg[i].rule);
_enter_critical_bh(&st_ctl->tracker_q.lock, &irqL);
phead = &st_ctl->tracker_q.queue;
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
st = LIST_CONTAINOR(plist, struct session_tracker, list);
plist = get_next(plist);
RTW_PRINT_SEL(sel, SESSION_TRACKER_FMT"\n", SESSION_TRACKER_ARG(st));
}
_exit_critical_bh(&st_ctl->tracker_q.lock, &irqL);
}
void _rtw_init_stainfo(struct sta_info *psta);
void _rtw_init_stainfo(struct sta_info *psta)
{
_rtw_memset((u8 *)psta, 0, sizeof(struct sta_info));
_rtw_spinlock_init(&psta->lock);
_rtw_init_listhead(&psta->list);
_rtw_init_listhead(&psta->hash_list);
/* _rtw_init_listhead(&psta->asoc_list); */
/* _rtw_init_listhead(&psta->sleep_list); */
/* _rtw_init_listhead(&psta->wakeup_list); */
_rtw_init_queue(&psta->sleep_q);
_rtw_init_sta_xmit_priv(&psta->sta_xmitpriv);
_rtw_init_sta_recv_priv(&psta->sta_recvpriv);
#ifdef CONFIG_AP_MODE
_rtw_init_listhead(&psta->asoc_list);
_rtw_init_listhead(&psta->auth_list);
psta->bpairwise_key_installed = _FALSE;
#ifdef CONFIG_RTW_80211R
psta->ft_pairwise_key_installed = _FALSE;
#endif
#endif /* CONFIG_AP_MODE */
rtw_st_ctl_init(&psta->st_ctl);
}
u32 _rtw_init_sta_priv(struct sta_priv *pstapriv)
{
_adapter *adapter = container_of(pstapriv, _adapter, stapriv);
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
struct sta_info *psta;
s32 i;
u32 ret = _FAIL;
pstapriv->padapter = adapter;
pstapriv->pallocated_stainfo_buf = rtw_zvmalloc(
sizeof(struct sta_info) * NUM_STA + MEM_ALIGNMENT_OFFSET);
if (!pstapriv->pallocated_stainfo_buf)
goto exit;
pstapriv->pstainfo_buf = pstapriv->pallocated_stainfo_buf;
if ((SIZE_PTR)pstapriv->pstainfo_buf & MEM_ALIGNMENT_PADDING)
pstapriv->pstainfo_buf += MEM_ALIGNMENT_OFFSET -
((SIZE_PTR)pstapriv->pstainfo_buf & MEM_ALIGNMENT_PADDING);
_rtw_init_queue(&pstapriv->free_sta_queue);
_rtw_spinlock_init(&pstapriv->sta_hash_lock);
/* _rtw_init_queue(&pstapriv->asoc_q); */
pstapriv->asoc_sta_count = 0;
_rtw_init_queue(&pstapriv->sleep_q);
_rtw_init_queue(&pstapriv->wakeup_q);
psta = (struct sta_info *)(pstapriv->pstainfo_buf);
for (i = 0; i < NUM_STA; i++) {
_rtw_init_stainfo(psta);
_rtw_init_listhead(&(pstapriv->sta_hash[i]));
rtw_list_insert_tail(&psta->list, get_list_head(&pstapriv->free_sta_queue));
psta++;
}
pstapriv->adhoc_expire_to = 4; /* 4 * 2 = 8 sec */
#ifdef CONFIG_AP_MODE
pstapriv->max_aid = macid_ctl->num;
pstapriv->rr_aid = 0;
pstapriv->started_aid = 1;
pstapriv->sta_aid = rtw_zmalloc(pstapriv->max_aid * sizeof(struct sta_info *));
if (!pstapriv->sta_aid)
goto exit;
pstapriv->aid_bmp_len = AID_BMP_LEN(pstapriv->max_aid);
pstapriv->sta_dz_bitmap = rtw_zmalloc(pstapriv->aid_bmp_len);
if (!pstapriv->sta_dz_bitmap)
goto exit;
pstapriv->tim_bitmap = rtw_zmalloc(pstapriv->aid_bmp_len);
if (!pstapriv->tim_bitmap)
goto exit;
_rtw_init_listhead(&pstapriv->asoc_list);
_rtw_init_listhead(&pstapriv->auth_list);
_rtw_spinlock_init(&pstapriv->asoc_list_lock);
_rtw_spinlock_init(&pstapriv->auth_list_lock);
pstapriv->asoc_list_cnt = 0;
pstapriv->auth_list_cnt = 0;
pstapriv->auth_to = 3; /* 3*2 = 6 sec */
pstapriv->assoc_to = 3;
/* pstapriv->expire_to = 900; */ /* 900*2 = 1800 sec = 30 min, expire after no any traffic. */
/* pstapriv->expire_to = 30; */ /* 30*2 = 60 sec = 1 min, expire after no any traffic. */
#ifdef CONFIG_ACTIVE_KEEP_ALIVE_CHECK
pstapriv->expire_to = 3; /* 3*2 = 6 sec */
#else
pstapriv->expire_to = 60;/* 60*2 = 120 sec = 2 min, expire after no any traffic. */
#endif
#ifdef CONFIG_ATMEL_RC_PATCH
_rtw_memset(pstapriv->atmel_rc_pattern, 0, ETH_ALEN);
#endif
pstapriv->max_num_sta = NUM_STA;
#endif
#if CONFIG_RTW_MACADDR_ACL
for (i = 0; i < RTW_ACL_PERIOD_NUM; i++)
rtw_macaddr_acl_init(adapter, i);
#endif
#if CONFIG_RTW_PRE_LINK_STA
rtw_pre_link_sta_ctl_init(pstapriv);
#endif
#if defined(DBG_ROAMING_TEST) || defined(CONFIG_RTW_REPEATER_SON)
rtw_set_rx_chk_limit(adapter,1);
#elif defined(CONFIG_ACTIVE_KEEP_ALIVE_CHECK) && !defined(CONFIG_LPS_LCLK_WD_TIMER)
rtw_set_rx_chk_limit(adapter,4);
#else
rtw_set_rx_chk_limit(adapter,8);
#endif
ret = _SUCCESS;
exit:
if (ret != _SUCCESS) {
if (pstapriv->pallocated_stainfo_buf)
rtw_vmfree(pstapriv->pallocated_stainfo_buf,
sizeof(struct sta_info) * NUM_STA + MEM_ALIGNMENT_OFFSET);
#ifdef CONFIG_AP_MODE
if (pstapriv->sta_aid)
rtw_mfree(pstapriv->sta_aid, pstapriv->max_aid * sizeof(struct sta_info *));
if (pstapriv->sta_dz_bitmap)
rtw_mfree(pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
#endif
}
return ret;
}
inline int rtw_stainfo_offset(struct sta_priv *stapriv, struct sta_info *sta)
{
int offset = (((u8 *)sta) - stapriv->pstainfo_buf) / sizeof(struct sta_info);
if (!stainfo_offset_valid(offset))
RTW_INFO("%s invalid offset(%d), out of range!!!", __func__, offset);
return offset;
}
inline struct sta_info *rtw_get_stainfo_by_offset(struct sta_priv *stapriv, int offset)
{
if (!stainfo_offset_valid(offset))
RTW_INFO("%s invalid offset(%d), out of range!!!", __func__, offset);
return (struct sta_info *)(stapriv->pstainfo_buf + offset * sizeof(struct sta_info));
}
void _rtw_free_sta_xmit_priv_lock(struct sta_xmit_priv *psta_xmitpriv);
void _rtw_free_sta_xmit_priv_lock(struct sta_xmit_priv *psta_xmitpriv)
{
_rtw_spinlock_free(&psta_xmitpriv->lock);
_rtw_spinlock_free(&(psta_xmitpriv->be_q.sta_pending.lock));
_rtw_spinlock_free(&(psta_xmitpriv->bk_q.sta_pending.lock));
_rtw_spinlock_free(&(psta_xmitpriv->vi_q.sta_pending.lock));
_rtw_spinlock_free(&(psta_xmitpriv->vo_q.sta_pending.lock));
}
static void _rtw_free_sta_recv_priv_lock(struct sta_recv_priv *psta_recvpriv)
{
_rtw_spinlock_free(&psta_recvpriv->lock);
_rtw_spinlock_free(&(psta_recvpriv->defrag_q.lock));
}
void rtw_mfree_stainfo(struct sta_info *psta);
void rtw_mfree_stainfo(struct sta_info *psta)
{
if (&psta->lock != NULL)
_rtw_spinlock_free(&psta->lock);
_rtw_free_sta_xmit_priv_lock(&psta->sta_xmitpriv);
_rtw_free_sta_recv_priv_lock(&psta->sta_recvpriv);
}
/* this function is used to free the memory of lock || sema for all stainfos */
void rtw_mfree_all_stainfo(struct sta_priv *pstapriv);
void rtw_mfree_all_stainfo(struct sta_priv *pstapriv)
{
_irqL irqL;
_list *plist, *phead;
struct sta_info *psta = NULL;
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
phead = get_list_head(&pstapriv->free_sta_queue);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info , list);
plist = get_next(plist);
rtw_mfree_stainfo(psta);
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
}
void rtw_mfree_sta_priv_lock(struct sta_priv *pstapriv);
void rtw_mfree_sta_priv_lock(struct sta_priv *pstapriv)
{
rtw_mfree_all_stainfo(pstapriv); /* be done before free sta_hash_lock */
_rtw_spinlock_free(&pstapriv->free_sta_queue.lock);
_rtw_spinlock_free(&pstapriv->sta_hash_lock);
_rtw_spinlock_free(&pstapriv->wakeup_q.lock);
_rtw_spinlock_free(&pstapriv->sleep_q.lock);
#ifdef CONFIG_AP_MODE
_rtw_spinlock_free(&pstapriv->asoc_list_lock);
_rtw_spinlock_free(&pstapriv->auth_list_lock);
#endif
}
u32 _rtw_free_sta_priv(struct sta_priv *pstapriv)
{
_irqL irqL;
_list *phead, *plist;
struct sta_info *psta = NULL;
struct recv_reorder_ctrl *preorder_ctrl;
int index;
if (pstapriv) {
/* delete all reordering_ctrl_timer */
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < NUM_STA; index++) {
phead = &(pstapriv->sta_hash[index]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
int i;
psta = LIST_CONTAINOR(plist, struct sta_info , hash_list);
plist = get_next(plist);
for (i = 0; i < 16 ; i++) {
preorder_ctrl = &psta->recvreorder_ctrl[i];
_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
/*===============================*/
rtw_mfree_sta_priv_lock(pstapriv);
#if CONFIG_RTW_MACADDR_ACL
for (index = 0; index < RTW_ACL_PERIOD_NUM; index++)
rtw_macaddr_acl_deinit(pstapriv->padapter, index);
#endif
#if CONFIG_RTW_PRE_LINK_STA
rtw_pre_link_sta_ctl_deinit(pstapriv);
#endif
if (pstapriv->pallocated_stainfo_buf)
rtw_vmfree(pstapriv->pallocated_stainfo_buf,
sizeof(struct sta_info) * NUM_STA + MEM_ALIGNMENT_OFFSET);
#ifdef CONFIG_AP_MODE
if (pstapriv->sta_aid)
rtw_mfree(pstapriv->sta_aid, pstapriv->max_aid * sizeof(struct sta_info *));
if (pstapriv->sta_dz_bitmap)
rtw_mfree(pstapriv->sta_dz_bitmap, pstapriv->aid_bmp_len);
if (pstapriv->tim_bitmap)
rtw_mfree(pstapriv->tim_bitmap, pstapriv->aid_bmp_len);
#endif
}
return _SUCCESS;
}
static void rtw_init_recv_timer(struct recv_reorder_ctrl *preorder_ctrl)
{
_adapter *padapter = preorder_ctrl->padapter;
#if defined(CONFIG_80211N_HT) && defined(CONFIG_RECV_REORDERING_CTRL)
rtw_init_timer(&(preorder_ctrl->reordering_ctrl_timer), padapter, rtw_reordering_ctrl_timeout_handler, preorder_ctrl);
#endif
}
/* struct sta_info *rtw_alloc_stainfo(_queue *pfree_sta_queue, unsigned char *hwaddr) */
struct sta_info *rtw_alloc_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr)
{
_irqL irqL2;
s32 index;
_list *phash_list;
struct sta_info *psta;
_queue *pfree_sta_queue;
struct recv_reorder_ctrl *preorder_ctrl;
int i = 0;
u16 wRxSeqInitialValue = 0xffff;
pfree_sta_queue = &pstapriv->free_sta_queue;
/* _enter_critical_bh(&(pfree_sta_queue->lock), &irqL); */
_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
if (_rtw_queue_empty(pfree_sta_queue) == _TRUE) {
/* _exit_critical_bh(&(pfree_sta_queue->lock), &irqL); */
_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
psta = NULL;
} else {
psta = LIST_CONTAINOR(get_next(&pfree_sta_queue->queue), struct sta_info, list);
rtw_list_delete(&(psta->list));
/* _exit_critical_bh(&(pfree_sta_queue->lock), &irqL); */
_rtw_init_stainfo(psta);
psta->padapter = pstapriv->padapter;
_rtw_memcpy(psta->cmn.mac_addr, hwaddr, ETH_ALEN);
index = wifi_mac_hash(hwaddr);
if (index >= NUM_STA) {
psta = NULL;
goto exit;
}
phash_list = &(pstapriv->sta_hash[index]);
/* _enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
rtw_list_insert_tail(&psta->hash_list, phash_list);
pstapriv->asoc_sta_count++;
/* _exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2); */
/* Commented by Albert 2009/08/13
* For the SMC router, the sequence number of first packet of WPS handshake will be 0.
* In this case, this packet will be dropped by recv_decache function if we use the 0x00 as the default value for tid_rxseq variable.
* So, we initialize the tid_rxseq variable as the 0xffff. */
for (i = 0; i < 16; i++) {
_rtw_memcpy(&psta->sta_recvpriv.rxcache.tid_rxseq[i], &wRxSeqInitialValue, 2);
_rtw_memcpy(&psta->sta_recvpriv.bmc_tid_rxseq[i], &wRxSeqInitialValue, 2);
_rtw_memset(&psta->sta_recvpriv.rxcache.iv[i], 0, sizeof(psta->sta_recvpriv.rxcache.iv[i]));
}
rtw_init_timer(&psta->addba_retry_timer, psta->padapter, addba_timer_hdl, psta);
#ifdef CONFIG_IEEE80211W
rtw_init_timer(&psta->dot11w_expire_timer, psta->padapter, sa_query_timer_hdl, psta);
#endif /* CONFIG_IEEE80211W */
#ifdef CONFIG_TDLS
rtw_init_tdls_timer(pstapriv->padapter, psta);
#endif /* CONFIG_TDLS */
/* for A-MPDU Rx reordering buffer control */
for (i = 0; i < 16 ; i++) {
preorder_ctrl = &psta->recvreorder_ctrl[i];
preorder_ctrl->padapter = pstapriv->padapter;
preorder_ctrl->tid = i;
preorder_ctrl->enable = _FALSE;
preorder_ctrl->indicate_seq = 0xffff;
#ifdef DBG_RX_SEQ
RTW_INFO("DBG_RX_SEQ "FUNC_ADPT_FMT" tid:%u SN_CLEAR indicate_seq:%d\n"
, FUNC_ADPT_ARG(pstapriv->padapter), i, preorder_ctrl->indicate_seq);
#endif
preorder_ctrl->wend_b = 0xffff;
/* preorder_ctrl->wsize_b = (NR_RECVBUFF-2); */
preorder_ctrl->wsize_b = 64;/* 64; */
preorder_ctrl->ampdu_size = RX_AMPDU_SIZE_INVALID;
_rtw_init_queue(&preorder_ctrl->pending_recvframe_queue);
rtw_init_recv_timer(preorder_ctrl);
rtw_clear_bit(RTW_RECV_ACK_OR_TIMEOUT, &preorder_ctrl->rec_abba_rsp_ack);
}
/* init for DM */
psta->cmn.rssi_stat.rssi = (-1);
psta->cmn.rssi_stat.rssi_cck = (-1);
psta->cmn.rssi_stat.rssi_ofdm = (-1);
#ifdef CONFIG_ATMEL_RC_PATCH
psta->flag_atmel_rc = 0;
#endif
/* init for the sequence number of received management frame */
psta->RxMgmtFrameSeqNum = 0xffff;
_rtw_memset(&psta->sta_stats, 0, sizeof(struct stainfo_stats));
rtw_alloc_macid(pstapriv->padapter, psta);
psta->tx_q_enable = 0;
_rtw_init_queue(&psta->tx_queue);
_init_workitem(&psta->tx_q_work, rtw_xmit_dequeue_callback, NULL);
}
exit:
_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL2);
if (psta)
rtw_mi_update_iface_status(&(pstapriv->padapter->mlmepriv), 0);
return psta;
}
/* using pstapriv->sta_hash_lock to protect */
u32 rtw_free_stainfo(_adapter *padapter , struct sta_info *psta)
{
int i;
_irqL irqL0;
_queue *pfree_sta_queue;
struct recv_reorder_ctrl *preorder_ctrl;
struct sta_xmit_priv *pstaxmitpriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct sta_priv *pstapriv = &padapter->stapriv;
struct hw_xmit *phwxmit;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
int pending_qcnt[4];
u8 is_pre_link_sta = _FALSE;
if (psta == NULL)
goto exit;
#ifdef CONFIG_RTW_80211K
rm_post_event(padapter, RM_ID_FOR_ALL(psta->cmn.aid), RM_EV_cancel);
#endif
is_pre_link_sta = rtw_is_pre_link_sta(pstapriv, psta->cmn.mac_addr);
if (is_pre_link_sta == _FALSE) {
_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
rtw_list_delete(&psta->hash_list);
pstapriv->asoc_sta_count--;
_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
rtw_mi_update_iface_status(&(padapter->mlmepriv), 0);
} else {
_enter_critical_bh(&psta->lock, &irqL0);
psta->state = WIFI_FW_PRE_LINK;
_exit_critical_bh(&psta->lock, &irqL0);
}
_enter_critical_bh(&psta->lock, &irqL0);
psta->state &= ~_FW_LINKED;
_exit_critical_bh(&psta->lock, &irqL0);
pfree_sta_queue = &pstapriv->free_sta_queue;
pstaxmitpriv = &psta->sta_xmitpriv;
/* rtw_list_delete(&psta->sleep_list); */
/* rtw_list_delete(&psta->wakeup_list); */
rtw_free_xmitframe_queue(pxmitpriv, &psta->tx_queue);
_rtw_deinit_queue(&psta->tx_queue);
_enter_critical_bh(&pxmitpriv->lock, &irqL0);
rtw_free_xmitframe_queue(pxmitpriv, &psta->sleep_q);
psta->sleepq_len = 0;
/* vo */
/* _enter_critical_bh(&(pxmitpriv->vo_pending.lock), &irqL0); */
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->vo_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
phwxmit = pxmitpriv->hwxmits;
phwxmit->accnt -= pstaxmitpriv->vo_q.qcnt;
pending_qcnt[0] = pstaxmitpriv->vo_q.qcnt;
pstaxmitpriv->vo_q.qcnt = 0;
/* _exit_critical_bh(&(pxmitpriv->vo_pending.lock), &irqL0); */
/* vi */
/* _enter_critical_bh(&(pxmitpriv->vi_pending.lock), &irqL0); */
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->vi_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
phwxmit = pxmitpriv->hwxmits + 1;
phwxmit->accnt -= pstaxmitpriv->vi_q.qcnt;
pending_qcnt[1] = pstaxmitpriv->vi_q.qcnt;
pstaxmitpriv->vi_q.qcnt = 0;
/* _exit_critical_bh(&(pxmitpriv->vi_pending.lock), &irqL0); */
/* be */
/* _enter_critical_bh(&(pxmitpriv->be_pending.lock), &irqL0); */
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->be_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
phwxmit = pxmitpriv->hwxmits + 2;
phwxmit->accnt -= pstaxmitpriv->be_q.qcnt;
pending_qcnt[2] = pstaxmitpriv->be_q.qcnt;
pstaxmitpriv->be_q.qcnt = 0;
/* _exit_critical_bh(&(pxmitpriv->be_pending.lock), &irqL0); */
/* bk */
/* _enter_critical_bh(&(pxmitpriv->bk_pending.lock), &irqL0); */
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->bk_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
phwxmit = pxmitpriv->hwxmits + 3;
phwxmit->accnt -= pstaxmitpriv->bk_q.qcnt;
pending_qcnt[3] = pstaxmitpriv->bk_q.qcnt;
pstaxmitpriv->bk_q.qcnt = 0;
/* _exit_critical_bh(&(pxmitpriv->bk_pending.lock), &irqL0); */
rtw_os_wake_queue_at_free_stainfo(padapter, pending_qcnt);
_exit_critical_bh(&pxmitpriv->lock, &irqL0);
/* re-init sta_info; 20061114 */ /* will be init in alloc_stainfo */
/* _rtw_init_sta_xmit_priv(&psta->sta_xmitpriv); */
/* _rtw_init_sta_recv_priv(&psta->sta_recvpriv); */
#ifdef CONFIG_IEEE80211W
_cancel_timer_ex(&psta->dot11w_expire_timer);
#endif /* CONFIG_IEEE80211W */
_cancel_timer_ex(&psta->addba_retry_timer);
#ifdef CONFIG_TDLS
psta->tdls_sta_state = TDLS_STATE_NONE;
#endif /* CONFIG_TDLS */
/* for A-MPDU Rx reordering buffer control, cancel reordering_ctrl_timer */
for (i = 0; i < 16 ; i++) {
_irqL irqL;
_list *phead, *plist;
union recv_frame *prframe;
_queue *ppending_recvframe_queue;
_queue *pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
preorder_ctrl = &psta->recvreorder_ctrl[i];
rtw_clear_bit(RTW_RECV_ACK_OR_TIMEOUT, &preorder_ctrl->rec_abba_rsp_ack);
_cancel_timer_ex(&preorder_ctrl->reordering_ctrl_timer);
ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
_enter_critical_bh(&ppending_recvframe_queue->lock, &irqL);
phead = get_list_head(ppending_recvframe_queue);
plist = get_next(phead);
while (!rtw_is_list_empty(phead)) {
prframe = LIST_CONTAINOR(plist, union recv_frame, u);
plist = get_next(plist);
rtw_list_delete(&(prframe->u.hdr.list));
rtw_free_recvframe(prframe, pfree_recv_queue);
}
_exit_critical_bh(&ppending_recvframe_queue->lock, &irqL);
}
if (!((psta->state & WIFI_AP_STATE) || MacAddr_isBcst(psta->cmn.mac_addr)) && is_pre_link_sta == _FALSE)
rtw_hal_set_odm_var(padapter, HAL_ODM_STA_INFO, psta, _FALSE);
/* release mac id for non-bc/mc station, */
if (is_pre_link_sta == _FALSE)
rtw_release_macid(pstapriv->padapter, psta);
#ifdef CONFIG_AP_MODE
/*
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL0);
rtw_list_delete(&psta->asoc_list);
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL0);
*/
_enter_critical_bh(&pstapriv->auth_list_lock, &irqL0);
if (!rtw_is_list_empty(&psta->auth_list)) {
rtw_list_delete(&psta->auth_list);
pstapriv->auth_list_cnt--;
}
_exit_critical_bh(&pstapriv->auth_list_lock, &irqL0);
psta->expire_to = 0;
#ifdef CONFIG_ATMEL_RC_PATCH
psta->flag_atmel_rc = 0;
#endif
psta->sleepq_ac_len = 0;
psta->qos_info = 0;
psta->max_sp_len = 0;
psta->uapsd_bk = 0;
psta->uapsd_be = 0;
psta->uapsd_vi = 0;
psta->uapsd_vo = 0;
psta->has_legacy_ac = 0;
#ifdef CONFIG_NATIVEAP_MLME
if (pmlmeinfo->state == _HW_STATE_AP_) {
rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
/* rtw_indicate_sta_disassoc_event(padapter, psta); */
if ((psta->cmn.aid > 0) && (pstapriv->sta_aid[psta->cmn.aid - 1] == psta)) {
pstapriv->sta_aid[psta->cmn.aid - 1] = NULL;
psta->cmn.aid = 0;
}
}
#endif /* CONFIG_NATIVEAP_MLME */
#ifdef CONFIG_TX_MCAST2UNI
psta->under_exist_checking = 0;
#endif /* CONFIG_TX_MCAST2UNI */
#endif /* CONFIG_AP_MODE */
rtw_st_ctl_deinit(&psta->st_ctl);
if (is_pre_link_sta == _FALSE) {
_rtw_spinlock_free(&psta->lock);
/* _enter_critical_bh(&(pfree_sta_queue->lock), &irqL0); */
_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
rtw_list_insert_tail(&psta->list, get_list_head(pfree_sta_queue));
_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL0);
/* _exit_critical_bh(&(pfree_sta_queue->lock), &irqL0); */
}
exit:
return _SUCCESS;
}
/* free all stainfo which in sta_hash[all] */
void rtw_free_all_stainfo(_adapter *padapter)
{
_irqL irqL;
_list *plist, *phead;
s32 index;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *pbcmc_stainfo = rtw_get_bcmc_stainfo(padapter);
u8 free_sta_num = 0;
char free_sta_list[NUM_STA];
int stainfo_offset;
if (pstapriv->asoc_sta_count == 1)
goto exit;
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < NUM_STA; index++) {
phead = &(pstapriv->sta_hash[index]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info , hash_list);
plist = get_next(plist);
if (pbcmc_stainfo != psta) {
if (rtw_is_pre_link_sta(pstapriv, psta->cmn.mac_addr) == _FALSE)
rtw_list_delete(&psta->hash_list);
stainfo_offset = rtw_stainfo_offset(pstapriv, psta);
if (stainfo_offset_valid(stainfo_offset))
free_sta_list[free_sta_num++] = stainfo_offset;
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < free_sta_num; index++) {
psta = rtw_get_stainfo_by_offset(pstapriv, free_sta_list[index]);
rtw_free_stainfo(padapter , psta);
}
exit:
return;
}
/* any station allocated can be searched by hash list */
struct sta_info *rtw_get_stainfo(struct sta_priv *pstapriv, const u8 *hwaddr)
{
_irqL irqL;
_list *plist, *phead;
struct sta_info *psta = NULL;
u32 index;
const u8 *addr;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
if (hwaddr == NULL)
return NULL;
if (IS_MCAST(hwaddr))
addr = bc_addr;
else
addr = hwaddr;
index = wifi_mac_hash(addr);
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
phead = &(pstapriv->sta_hash[index]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
if ((_rtw_memcmp(psta->cmn.mac_addr, addr, ETH_ALEN)) == _TRUE) {
/* if found the matched address */
break;
}
psta = NULL;
plist = get_next(plist);
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
return psta;
}
u32 rtw_init_bcmc_stainfo(_adapter *padapter)
{
struct sta_info *psta;
struct tx_servq *ptxservq;
u32 res = _SUCCESS;
NDIS_802_11_MAC_ADDRESS bcast_addr = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct sta_priv *pstapriv = &padapter->stapriv;
/* _queue *pstapending = &padapter->xmitpriv.bm_pending; */
psta = rtw_alloc_stainfo(pstapriv, bcast_addr);
if (psta == NULL) {
res = _FAIL;
goto exit;
}
#ifdef CONFIG_BEAMFORMING
psta->cmn.bf_info.g_id = 63;
psta->cmn.bf_info.p_aid = 0;
#endif
ptxservq = &(psta->sta_xmitpriv.be_q);
/*
_enter_critical(&pstapending->lock, &irqL0);
if (rtw_is_list_empty(&ptxservq->tx_pending))
rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(pstapending));
_exit_critical(&pstapending->lock, &irqL0);
*/
exit:
return _SUCCESS;
}
struct sta_info *rtw_get_bcmc_stainfo(_adapter *padapter)
{
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
psta = rtw_get_stainfo(pstapriv, bc_addr);
return psta;
}
#ifdef CONFIG_AP_MODE
u16 rtw_aid_alloc(_adapter *adapter, struct sta_info *sta)
{
struct sta_priv *stapriv = &adapter->stapriv;
u16 aid, i, used_cnt = 0;
for (i = 0; i < stapriv->max_aid; i++) {
aid = ((i + stapriv->started_aid - 1) % stapriv->max_aid) + 1;
if (stapriv->sta_aid[aid - 1] == NULL)
break;
if (++used_cnt >= stapriv->max_num_sta)
break;
}
/* check for aid limit and assoc limit */
if (i >= stapriv->max_aid || used_cnt >= stapriv->max_num_sta)
aid = 0;
sta->cmn.aid = aid;
if (aid) {
stapriv->sta_aid[aid - 1] = sta;
if (stapriv->rr_aid)
stapriv->started_aid = (aid % stapriv->max_aid) + 1;
}
return aid;
}
void dump_aid_status(void *sel, _adapter *adapter)
{
struct sta_priv *stapriv = &adapter->stapriv;
u8 *aid_bmp;
u16 i, used_cnt = 0;
aid_bmp = rtw_zmalloc(stapriv->aid_bmp_len);
if (!aid_bmp)
return;
for (i = 1; i <= stapriv->max_aid; i++) {
if (stapriv->sta_aid[i - 1]) {
aid_bmp[i / 8] |= BIT(i % 8);
++used_cnt;
}
}
RTW_PRINT_SEL(sel, "used_cnt:%u/%u\n", used_cnt, stapriv->max_aid);
RTW_MAP_DUMP_SEL(sel, "aid_map:", aid_bmp, stapriv->aid_bmp_len);
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "%-2s %-11s\n", "rr", "started_aid");
RTW_PRINT_SEL(sel, "%2d %11d\n", stapriv->rr_aid, stapriv->started_aid);
rtw_mfree(aid_bmp, stapriv->aid_bmp_len);
}
#endif /* CONFIG_AP_MODE */
#if CONFIG_RTW_MACADDR_ACL
const char *const _acl_period_str[RTW_ACL_PERIOD_NUM] = {
"DEV",
"BSS",
};
const char *const _acl_mode_str[RTW_ACL_MODE_MAX] = {
"DISABLED",
"ACCEPT_UNLESS_LISTED",
"DENY_UNLESS_LISTED",
};
u8 _rtw_access_ctrl(_adapter *adapter, u8 period, const u8 *mac_addr)
{
u8 res = _TRUE;
_irqL irqL;
_list *list, *head;
struct rtw_wlan_acl_node *acl_node;
u8 match = _FALSE;
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
_queue *acl_node_q;
if (period >= RTW_ACL_PERIOD_NUM) {
rtw_warn_on(1);
goto exit;
}
acl = &stapriv->acl_list[period];
acl_node_q = &acl->acl_node_q;
if (acl->mode != RTW_ACL_MODE_ACCEPT_UNLESS_LISTED
&& acl->mode != RTW_ACL_MODE_DENY_UNLESS_LISTED)
goto exit;
_enter_critical_bh(&(acl_node_q->lock), &irqL);
head = get_list_head(acl_node_q);
list = get_next(head);
while (rtw_end_of_queue_search(head, list) == _FALSE) {
acl_node = LIST_CONTAINOR(list, struct rtw_wlan_acl_node, list);
list = get_next(list);
if (_rtw_memcmp(acl_node->addr, mac_addr, ETH_ALEN)) {
if (acl_node->valid == _TRUE) {
match = _TRUE;
break;
}
}
}
_exit_critical_bh(&(acl_node_q->lock), &irqL);
if (acl->mode == RTW_ACL_MODE_ACCEPT_UNLESS_LISTED)
res = (match == _TRUE) ? _FALSE : _TRUE;
else /* RTW_ACL_MODE_DENY_UNLESS_LISTED */
res = (match == _TRUE) ? _TRUE : _FALSE;
exit:
return res;
}
u8 rtw_access_ctrl(_adapter *adapter, const u8 *mac_addr)
{
int i;
for (i = 0; i < RTW_ACL_PERIOD_NUM; i++)
if (_rtw_access_ctrl(adapter, i, mac_addr) == _FALSE)
return _FALSE;
return _TRUE;
}
void dump_macaddr_acl(void *sel, _adapter *adapter)
{
struct sta_priv *stapriv = &adapter->stapriv;
struct wlan_acl_pool *acl;
int i, j;
for (j = 0; j < RTW_ACL_PERIOD_NUM; j++) {
RTW_PRINT_SEL(sel, "period:%s(%d)\n", acl_period_str(j), j);
acl = &stapriv->acl_list[j];
RTW_PRINT_SEL(sel, "mode:%s(%d)\n", acl_mode_str(acl->mode), acl->mode);
RTW_PRINT_SEL(sel, "num:%d/%d\n", acl->num, NUM_ACL);
for (i = 0; i < NUM_ACL; i++) {
if (acl->aclnode[i].valid == _FALSE)
continue;
RTW_PRINT_SEL(sel, MAC_FMT"\n", MAC_ARG(acl->aclnode[i].addr));
}
RTW_PRINT_SEL(sel, "\n");
}
}
#endif /* CONFIG_RTW_MACADDR_ACL */
bool rtw_is_pre_link_sta(struct sta_priv *stapriv, u8 *addr)
{
#if CONFIG_RTW_PRE_LINK_STA
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
struct sta_info *sta = NULL;
u8 exist = _FALSE;
int i;
_irqL irqL;
_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
if (pre_link_sta_ctl->node[i].valid == _TRUE
&& _rtw_memcmp(pre_link_sta_ctl->node[i].addr, addr, ETH_ALEN) == _TRUE
) {
exist = _TRUE;
break;
}
}
_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
return exist;
#else
return _FALSE;
#endif
}
#if CONFIG_RTW_PRE_LINK_STA
struct sta_info *rtw_pre_link_sta_add(struct sta_priv *stapriv, u8 *hwaddr)
{
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
struct pre_link_sta_node_t *node = NULL;
struct sta_info *sta = NULL;
u8 exist = _FALSE;
int i;
_irqL irqL;
if (rtw_check_invalid_mac_address(hwaddr, _FALSE) == _TRUE)
goto exit;
_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
if (pre_link_sta_ctl->node[i].valid == _TRUE
&& _rtw_memcmp(pre_link_sta_ctl->node[i].addr, hwaddr, ETH_ALEN) == _TRUE
) {
node = &pre_link_sta_ctl->node[i];
exist = _TRUE;
break;
}
if (node == NULL && pre_link_sta_ctl->node[i].valid == _FALSE)
node = &pre_link_sta_ctl->node[i];
}
if (exist == _FALSE && node) {
_rtw_memcpy(node->addr, hwaddr, ETH_ALEN);
node->valid = _TRUE;
pre_link_sta_ctl->num++;
}
_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
if (node == NULL)
goto exit;
sta = rtw_get_stainfo(stapriv, hwaddr);
if (sta)
goto odm_hook;
sta = rtw_alloc_stainfo(stapriv, hwaddr);
if (!sta)
goto exit;
sta->state = WIFI_FW_PRE_LINK;
odm_hook:
rtw_hal_set_odm_var(stapriv->padapter, HAL_ODM_STA_INFO, sta, _TRUE);
exit:
return sta;
}
void rtw_pre_link_sta_del(struct sta_priv *stapriv, u8 *hwaddr)
{
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
struct pre_link_sta_node_t *node = NULL;
struct sta_info *sta = NULL;
u8 exist = _FALSE;
int i;
_irqL irqL;
if (rtw_check_invalid_mac_address(hwaddr, _FALSE) == _TRUE)
goto exit;
_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
if (pre_link_sta_ctl->node[i].valid == _TRUE
&& _rtw_memcmp(pre_link_sta_ctl->node[i].addr, hwaddr, ETH_ALEN) == _TRUE
) {
node = &pre_link_sta_ctl->node[i];
exist = _TRUE;
break;
}
}
if (exist == _TRUE && node) {
node->valid = _FALSE;
pre_link_sta_ctl->num--;
}
_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
if (exist == _FALSE)
goto exit;
sta = rtw_get_stainfo(stapriv, hwaddr);
if (!sta)
goto exit;
if (sta->state == WIFI_FW_PRE_LINK)
rtw_free_stainfo(stapriv->padapter, sta);
exit:
return;
}
void rtw_pre_link_sta_ctl_reset(struct sta_priv *stapriv)
{
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
struct pre_link_sta_node_t *node = NULL;
struct sta_info *sta = NULL;
int i, j = 0;
_irqL irqL;
u8 addrs[RTW_PRE_LINK_STA_NUM][ETH_ALEN];
_rtw_memset(addrs, 0, RTW_PRE_LINK_STA_NUM * ETH_ALEN);
_enter_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
if (pre_link_sta_ctl->node[i].valid == _FALSE)
continue;
_rtw_memcpy(&(addrs[j][0]), pre_link_sta_ctl->node[i].addr, ETH_ALEN);
pre_link_sta_ctl->node[i].valid = _FALSE;
pre_link_sta_ctl->num--;
j++;
}
_exit_critical_bh(&(pre_link_sta_ctl->lock), &irqL);
for (i = 0; i < j; i++) {
sta = rtw_get_stainfo(stapriv, &(addrs[i][0]));
if (!sta)
continue;
if (sta->state == WIFI_FW_PRE_LINK)
rtw_free_stainfo(stapriv->padapter, sta);
}
}
void rtw_pre_link_sta_ctl_init(struct sta_priv *stapriv)
{
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
int i;
_rtw_spinlock_init(&pre_link_sta_ctl->lock);
pre_link_sta_ctl->num = 0;
for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++)
pre_link_sta_ctl->node[i].valid = _FALSE;
}
void rtw_pre_link_sta_ctl_deinit(struct sta_priv *stapriv)
{
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
int i;
rtw_pre_link_sta_ctl_reset(stapriv);
_rtw_spinlock_free(&pre_link_sta_ctl->lock);
}
void dump_pre_link_sta_ctl(void *sel, struct sta_priv *stapriv)
{
struct pre_link_sta_ctl_t *pre_link_sta_ctl = &stapriv->pre_link_sta_ctl;
int i;
RTW_PRINT_SEL(sel, "num:%d/%d\n", pre_link_sta_ctl->num, RTW_PRE_LINK_STA_NUM);
for (i = 0; i < RTW_PRE_LINK_STA_NUM; i++) {
if (pre_link_sta_ctl->node[i].valid == _FALSE)
continue;
RTW_PRINT_SEL(sel, MAC_FMT"\n", MAC_ARG(pre_link_sta_ctl->node[i].addr));
}
}
#endif /* CONFIG_RTW_PRE_LINK_STA */
================================================
FILE: core/rtw_tdls.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_TDLS_C_
#include
#include
#ifdef CONFIG_TDLS
#define ONE_SEC 1000 /* 1000 ms */
extern unsigned char MCS_rate_2R[16];
extern unsigned char MCS_rate_1R[16];
inline void rtw_tdls_set_link_established(_adapter *adapter, bool en)
{
adapter->tdlsinfo.link_established = en;
rtw_mi_update_iface_status(&(adapter->mlmepriv), 0);
}
void rtw_reset_tdls_info(_adapter *padapter)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
ptdlsinfo->ap_prohibited = _FALSE;
/* For TDLS channel switch, currently we only allow it to work in wifi logo test mode */
if (padapter->registrypriv.wifi_spec == 1)
ptdlsinfo->ch_switch_prohibited = _FALSE;
else
ptdlsinfo->ch_switch_prohibited = _TRUE;
rtw_tdls_set_link_established(padapter, _FALSE);
ptdlsinfo->sta_cnt = 0;
ptdlsinfo->sta_maximum = _FALSE;
#ifdef CONFIG_TDLS_CH_SW
ptdlsinfo->chsw_info.ch_sw_state = TDLS_STATE_NONE;
ATOMIC_SET(&ptdlsinfo->chsw_info.chsw_on, _FALSE);
ptdlsinfo->chsw_info.off_ch_num = 0;
ptdlsinfo->chsw_info.ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
ptdlsinfo->chsw_info.cur_time = 0;
ptdlsinfo->chsw_info.delay_switch_back = _FALSE;
ptdlsinfo->chsw_info.dump_stack = _FALSE;
#endif
ptdlsinfo->ch_sensing = 0;
ptdlsinfo->watchdog_count = 0;
ptdlsinfo->dev_discovered = _FALSE;
#ifdef CONFIG_WFD
ptdlsinfo->wfd_info = &padapter->wfd_info;
#endif
ptdlsinfo->tdls_sctx = NULL;
}
int rtw_init_tdls_info(_adapter *padapter)
{
int res = _SUCCESS;
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
rtw_reset_tdls_info(padapter);
#ifdef CONFIG_TDLS_DRIVER_SETUP
ptdlsinfo->driver_setup = _TRUE;
#else
ptdlsinfo->driver_setup = _FALSE;
#endif /* CONFIG_TDLS_DRIVER_SETUP */
_rtw_spinlock_init(&ptdlsinfo->cmd_lock);
_rtw_spinlock_init(&ptdlsinfo->hdl_lock);
return res;
}
void rtw_free_tdls_info(struct tdls_info *ptdlsinfo)
{
_rtw_spinlock_free(&ptdlsinfo->cmd_lock);
_rtw_spinlock_free(&ptdlsinfo->hdl_lock);
_rtw_memset(ptdlsinfo, 0, sizeof(struct tdls_info));
}
void rtw_free_all_tdls_sta(_adapter *padapter, u8 enqueue_cmd)
{
struct sta_priv *pstapriv = &padapter->stapriv;
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
_irqL irqL;
_list *plist, *phead;
s32 index;
struct sta_info *psta = NULL;
struct sta_info *ptdls_sta[NUM_STA];
u8 empty_hwaddr[ETH_ALEN] = { 0x00 };
_rtw_memset(ptdls_sta, 0x00, sizeof(ptdls_sta));
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < NUM_STA; index++) {
phead = &(pstapriv->sta_hash[index]);
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if (psta->tdls_sta_state != TDLS_STATE_NONE)
ptdls_sta[index] = psta;
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (index = 0; index < NUM_STA; index++) {
if (ptdls_sta[index]) {
struct TDLSoption_param tdls_param;
psta = ptdls_sta[index];
RTW_INFO("Do tear down to "MAC_FMT" by enqueue_cmd = %d\n", MAC_ARG(psta->cmn.mac_addr), enqueue_cmd);
_rtw_memcpy(&(tdls_param.addr), psta->cmn.mac_addr, ETH_ALEN);
tdls_param.option = TDLS_TEARDOWN_STA_NO_WAIT;
tdls_hdl(padapter, (unsigned char *)&(tdls_param));
rtw_tdls_teardown_pre_hdl(padapter, psta);
if (enqueue_cmd == _TRUE)
rtw_tdls_cmd(padapter, psta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
else
{
tdls_param.option = TDLS_TEARDOWN_STA_LOCALLY_POST;
tdls_hdl(padapter, (unsigned char *)&(tdls_param));
}
}
}
}
int check_ap_tdls_prohibited(u8 *pframe, u8 pkt_len)
{
u8 tdls_prohibited_bit = 0x40; /* bit(38); TDLS_prohibited */
if (pkt_len < 5)
return _FALSE;
pframe += 4;
if ((*pframe) & tdls_prohibited_bit)
return _TRUE;
return _FALSE;
}
int check_ap_tdls_ch_switching_prohibited(u8 *pframe, u8 pkt_len)
{
u8 tdls_ch_swithcing_prohibited_bit = 0x80; /* bit(39); TDLS_channel_switching prohibited */
if (pkt_len < 5)
return _FALSE;
pframe += 4;
if ((*pframe) & tdls_ch_swithcing_prohibited_bit)
return _TRUE;
return _FALSE;
}
u8 rtw_is_tdls_enabled(_adapter *padapter)
{
return padapter->registrypriv.en_tdls;
}
void rtw_set_tdls_enable(_adapter *padapter, u8 enable)
{
padapter->registrypriv.en_tdls = enable;
RTW_INFO("%s: en_tdls = %d\n", __func__, rtw_is_tdls_enabled(padapter));
}
void rtw_enable_tdls_func(_adapter *padapter)
{
if (rtw_is_tdls_enabled(padapter) == _TRUE)
return;
#if 0
#ifdef CONFIG_MCC_MODE
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC) == _TRUE) {
RTW_INFO("[TDLS] MCC is running, can't enable TDLS !\n");
return;
}
#endif
#endif
rtw_set_tdls_enable(padapter, _TRUE);
}
void rtw_disable_tdls_func(_adapter *padapter, u8 enqueue_cmd)
{
if (rtw_is_tdls_enabled(padapter) == _FALSE)
return;
rtw_free_all_tdls_sta(padapter, enqueue_cmd);
rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
rtw_reset_tdls_info(padapter);
rtw_set_tdls_enable(padapter, _FALSE);
}
u8 rtw_is_tdls_sta_existed(_adapter *padapter)
{
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
int i = 0;
_irqL irqL;
_list *plist, *phead;
u8 ret = _FALSE;
if (rtw_is_tdls_enabled(padapter) == _FALSE)
return _FALSE;
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if (psta->tdls_sta_state != TDLS_STATE_NONE) {
ret = _TRUE;
goto Exit;
}
}
}
Exit:
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
return ret;
}
u8 rtw_tdls_is_setup_allowed(_adapter *padapter)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
if (is_client_associated_to_ap(padapter) == _FALSE)
return _FALSE;
if (ptdlsinfo->ap_prohibited == _TRUE)
return _FALSE;
return _TRUE;
}
#ifdef CONFIG_TDLS_CH_SW
u8 rtw_tdls_is_chsw_allowed(_adapter *padapter)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
if (ptdlsinfo->ch_switch_prohibited == _TRUE)
return _FALSE;
if (padapter->registrypriv.wifi_spec == 0)
return _FALSE;
return _TRUE;
}
#endif
int _issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int wait_ms)
{
int ret = _FAIL;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl, *qc;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
pattrib->hdrlen += 2;
pattrib->qos_en = _TRUE;
pattrib->eosp = 1;
pattrib->ack_policy = 0;
pattrib->mdata = 0;
pattrib->retry_ctrl = _FALSE;
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
if (power_mode)
SetPwrMgt(fctrl);
qc = (unsigned short *)(pframe + pattrib->hdrlen - 2);
SetPriority(qc, 7); /* Set priority to VO */
SetEOSP(qc, pattrib->eosp);
SetAckpolicy(qc, pattrib->ack_policy);
_rtw_memcpy(pwlanhdr->addr1, da, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr_qos);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
pattrib->last_txcmdsz = pattrib->pktlen;
if (wait_ms)
ret = dump_mgntframe_and_wait_ack_timeout(padapter, pmgntframe, wait_ms);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
/*
*wait_ms == 0 means that there is no need to wait ack through C2H_CCX_TX_RPT
*wait_ms > 0 means you want to wait ack through C2H_CCX_TX_RPT, and the value of wait_ms means the interval between each TX
*try_cnt means the maximal TX count to try
*/
int issue_nulldata_to_TDLS_peer_STA(_adapter *padapter, unsigned char *da, unsigned int power_mode, int try_cnt, int wait_ms)
{
int ret;
int i = 0;
systime start = rtw_get_current_time();
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
#if 0
psta = rtw_get_stainfo(&padapter->stapriv, da);
if (psta) {
if (power_mode)
rtw_hal_macid_sleep(padapter, psta->cmn.mac_id);
else
rtw_hal_macid_wakeup(padapter, psta->cmn.mac_id);
} else {
RTW_INFO(FUNC_ADPT_FMT ": Can't find sta info for " MAC_FMT ", skip macid %s!!\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(da), power_mode ? "sleep" : "wakeup");
rtw_warn_on(1);
}
#endif
do {
ret = _issue_nulldata_to_TDLS_peer_STA(padapter, da, power_mode, wait_ms);
i++;
if (RTW_CANNOT_RUN(padapter))
break;
if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
rtw_msleep_os(wait_ms);
} while ((i < try_cnt) && (ret == _FAIL || wait_ms == 0));
if (ret != _FAIL) {
ret = _SUCCESS;
#ifndef DBG_XMIT_ACK
goto exit;
#endif
}
if (try_cnt && wait_ms) {
if (da)
RTW_INFO(FUNC_ADPT_FMT" to "MAC_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), MAC_ARG(da), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
else
RTW_INFO(FUNC_ADPT_FMT", ch:%u%s, %d/%d in %u ms\n",
FUNC_ADPT_ARG(padapter), rtw_get_oper_ch(padapter),
ret == _SUCCESS ? ", acked" : "", i, try_cnt, rtw_get_passing_time_ms(start));
}
exit:
return ret;
}
/* TDLS encryption(if needed) will always be CCMP */
void rtw_tdls_set_key(_adapter *padapter, struct sta_info *ptdls_sta)
{
ptdls_sta->dot118021XPrivacy = _AES_;
rtw_setstakey_cmd(padapter, ptdls_sta, TDLS_KEY, _TRUE);
}
#ifdef CONFIG_80211N_HT
void rtw_tdls_process_ht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
u8 max_AMPDU_len, min_MPDU_spacing;
u8 cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0;
/* Save HT capabilities in the sta object */
_rtw_memset(&ptdls_sta->htpriv.ht_cap, 0, sizeof(struct rtw_ieee80211_ht_cap));
if (data && Length >= sizeof(struct rtw_ieee80211_ht_cap)) {
ptdls_sta->flags |= WLAN_STA_HT;
ptdls_sta->flags |= WLAN_STA_WME;
_rtw_memcpy(&ptdls_sta->htpriv.ht_cap, data, sizeof(struct rtw_ieee80211_ht_cap));
} else {
ptdls_sta->flags &= ~WLAN_STA_HT;
return;
}
if (ptdls_sta->flags & WLAN_STA_HT) {
if (padapter->registrypriv.ht_enable == _TRUE && is_supported_ht(padapter->registrypriv.wireless_mode) ) {
ptdls_sta->htpriv.ht_option = _TRUE;
ptdls_sta->qos_option = _TRUE;
} else {
ptdls_sta->htpriv.ht_option = _FALSE;
ptdls_sta->qos_option = _FALSE;
}
}
/* HT related cap */
if (ptdls_sta->htpriv.ht_option) {
/* Check if sta supports rx ampdu */
if (padapter->registrypriv.ampdu_enable == 1)
ptdls_sta->htpriv.ampdu_enable = _TRUE;
/* AMPDU Parameters field */
/* Get MIN of MAX AMPDU Length Exp */
if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3) > (data[2] & 0x3))
max_AMPDU_len = (data[2] & 0x3);
else
max_AMPDU_len = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3);
/* Get MAX of MIN MPDU Start Spacing */
if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) > (data[2] & 0x1c))
min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c);
else
min_MPDU_spacing = (data[2] & 0x1c);
ptdls_sta->htpriv.rx_ampdu_min_spacing = max_AMPDU_len | min_MPDU_spacing;
/* Check if sta support s Short GI 20M */
if ((phtpriv->sgi_20m == _TRUE) && (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SGI_20)))
ptdls_sta->htpriv.sgi_20m = _TRUE;
/* Check if sta support s Short GI 40M */
if ((phtpriv->sgi_40m == _TRUE) && (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SGI_40)))
ptdls_sta->htpriv.sgi_40m = _TRUE;
/* Bwmode would still followed AP's setting */
if (ptdls_sta->htpriv.ht_cap.cap_info & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH)) {
if (padapter->mlmeextpriv.cur_bwmode >= CHANNEL_WIDTH_40)
ptdls_sta->cmn.bw_mode = CHANNEL_WIDTH_40;
ptdls_sta->htpriv.ch_offset = padapter->mlmeextpriv.cur_ch_offset;
}
/* Config LDPC Coding Capability */
if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX) && GET_HT_CAP_ELE_LDPC_CAP(data)) {
SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
RTW_INFO("Enable HT Tx LDPC!\n");
}
ptdls_sta->htpriv.ldpc_cap = cur_ldpc_cap;
/* Config STBC setting */
if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(data)) {
SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
RTW_INFO("Enable HT Tx STBC!\n");
}
ptdls_sta->htpriv.stbc_cap = cur_stbc_cap;
#ifdef CONFIG_BEAMFORMING
/* Config Tx beamforming setting */
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(data))
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(data))
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
ptdls_sta->htpriv.beamform_cap = cur_beamform_cap;
if (cur_beamform_cap)
RTW_INFO("Client HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
#endif /* CONFIG_BEAMFORMING */
}
}
u8 *rtw_tdls_set_ht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
rtw_ht_use_default_setting(padapter);
if (padapter->registrypriv.wifi_spec == 1) {
padapter->mlmepriv.htpriv.sgi_20m = _FALSE;
padapter->mlmepriv.htpriv.sgi_40m = _FALSE;
}
rtw_restructure_ht_ie(padapter, NULL, pframe, 0, &(pattrib->pktlen), padapter->mlmeextpriv.cur_channel);
return pframe + pattrib->pktlen;
}
#endif
#ifdef CONFIG_80211AC_VHT
void rtw_tdls_process_vht_cap(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
u8 cur_ldpc_cap = 0, cur_stbc_cap = 0, rf_type = RF_1T1R, tx_nss = 0;
u16 cur_beamform_cap = 0;
u8 *pcap_mcs;
_rtw_memset(&ptdls_sta->vhtpriv, 0, sizeof(struct vht_priv));
if (data && Length == 12) {
ptdls_sta->flags |= WLAN_STA_VHT;
_rtw_memcpy(ptdls_sta->vhtpriv.vht_cap, data, 12);
#if 0
if (elems.vht_op_mode_notify && elems.vht_op_mode_notify_len == 1)
_rtw_memcpy(&pstat->vhtpriv.vht_op_mode_notify, elems.vht_op_mode_notify, 1);
else /* for Frame without Operating Mode notify ie; default: 80M */
pstat->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
#else
ptdls_sta->vhtpriv.vht_op_mode_notify = CHANNEL_WIDTH_80;
#endif
} else {
ptdls_sta->flags &= ~WLAN_STA_VHT;
return;
}
if (ptdls_sta->flags & WLAN_STA_VHT) {
if (REGSTY_IS_11AC_ENABLE(&padapter->registrypriv)
&& is_supported_vht(padapter->registrypriv.wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))) {
ptdls_sta->vhtpriv.vht_option = _TRUE;
ptdls_sta->cmn.ra_info.is_vht_enable = _TRUE;
}
else
ptdls_sta->vhtpriv.vht_option = _FALSE;
}
/* B4 Rx LDPC */
if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX) &&
GET_VHT_CAPABILITY_ELE_RX_LDPC(data)) {
SET_FLAG(cur_ldpc_cap, (LDPC_VHT_ENABLE_TX | LDPC_VHT_CAP_TX));
RTW_INFO("Current VHT LDPC Setting = %02X\n", cur_ldpc_cap);
}
ptdls_sta->vhtpriv.ldpc_cap = cur_ldpc_cap;
/* B5 Short GI for 80 MHz */
ptdls_sta->vhtpriv.sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(data) & pvhtpriv->sgi_80m) ? _TRUE : _FALSE;
/* B8 B9 B10 Rx STBC */
if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX) &&
GET_VHT_CAPABILITY_ELE_RX_STBC(data)) {
SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));
RTW_INFO("Current VHT STBC Setting = %02X\n", cur_stbc_cap);
}
ptdls_sta->vhtpriv.stbc_cap = cur_stbc_cap;
#ifdef CONFIG_BEAMFORMING
/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) &&
GET_VHT_CAPABILITY_ELE_SU_BFEE(data))
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
GET_VHT_CAPABILITY_ELE_SU_BFER(data))
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
ptdls_sta->vhtpriv.beamform_cap = cur_beamform_cap;
ptdls_sta->cmn.bf_info.vht_beamform_cap = cur_beamform_cap;
if (cur_beamform_cap)
RTW_INFO("Current VHT Beamforming Setting = %02X\n", cur_beamform_cap);
#endif /*CONFIG_BEAMFORMING*/
/* B23 B24 B25 Maximum A-MPDU Length Exponent */
ptdls_sta->vhtpriv.ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(data);
pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(data);
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
rtw_vht_nss_to_mcsmap(tx_nss, ptdls_sta->vhtpriv.vht_mcs_map, pcap_mcs);
ptdls_sta->vhtpriv.vht_highest_rate = rtw_get_vht_highest_rate(ptdls_sta->vhtpriv.vht_mcs_map);
}
void rtw_tdls_process_vht_operation(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct registry_priv *regsty = adapter_to_regsty(padapter);
u8 operation_bw = 0;
if (GET_VHT_OPERATION_ELE_CHL_WIDTH(data) >= 1) {
operation_bw = CHANNEL_WIDTH_80;
if (hal_is_bw_support(padapter, operation_bw) && REGSTY_IS_BW_5G_SUPPORT(regsty, operation_bw)
&& (operation_bw <= pmlmeext->cur_bwmode))
ptdls_sta->cmn.bw_mode = operation_bw;
else
ptdls_sta->cmn.bw_mode = pmlmeext->cur_bwmode;
} else
ptdls_sta->cmn.bw_mode = pmlmeext->cur_bwmode;
}
void rtw_tdls_process_vht_op_mode_notify(_adapter *padapter, struct sta_info *ptdls_sta, u8 *data, u8 Length)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct registry_priv *regsty = adapter_to_regsty(padapter);
u8 target_bw;
u8 target_rxss, current_rxss;
if (pvhtpriv->vht_option == _FALSE)
return;
target_bw = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(data);
target_rxss = (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(data) + 1);
if (hal_is_bw_support(padapter, target_bw) && REGSTY_IS_BW_5G_SUPPORT(regsty, target_bw)
&& (target_bw <= pmlmeext->cur_bwmode))
ptdls_sta->cmn.bw_mode = target_bw;
else
ptdls_sta->cmn.bw_mode = pmlmeext->cur_bwmode;
current_rxss = rtw_vht_mcsmap_to_nss(ptdls_sta->vhtpriv.vht_mcs_map);
if (target_rxss != current_rxss) {
u8 vht_mcs_map[2] = {};
rtw_vht_nss_to_mcsmap(target_rxss, vht_mcs_map, ptdls_sta->vhtpriv.vht_mcs_map);
_rtw_memcpy(ptdls_sta->vhtpriv.vht_mcs_map, vht_mcs_map, 2);
}
}
u8 *rtw_tdls_set_aid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
return rtw_set_ie(pframe, EID_AID, 2, (u8 *)&(padapter->mlmepriv.cur_network.aid), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_vht_cap(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
u32 ie_len = 0;
rtw_vht_use_default_setting(padapter);
ie_len = rtw_build_vht_cap_ie(padapter, pframe);
pattrib->pktlen += ie_len;
return pframe + ie_len;
}
u8 *rtw_tdls_set_vht_operation(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 channel)
{
u32 ie_len = 0;
ie_len = rtw_build_vht_operation_ie(padapter, pframe, channel);
pattrib->pktlen += ie_len;
return pframe + ie_len;
}
u8 *rtw_tdls_set_vht_op_mode_notify(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 bw)
{
u32 ie_len = 0;
ie_len = rtw_build_vht_op_mode_notify_ie(padapter, pframe, bw);
pattrib->pktlen += ie_len;
return pframe + ie_len;
}
#endif
u8 *rtw_tdls_set_sup_ch(_adapter *adapter, u8 *pframe, struct pkt_attrib *pattrib)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
u8 sup_ch[30 * 2] = {0x00}, ch_set_idx = 0, sup_ch_idx = 2;
while (ch_set_idx < rfctl->max_chan_nums && rfctl->channel_set[ch_set_idx].ChannelNum != 0) {
if (rfctl->channel_set[ch_set_idx].ChannelNum <= 14) {
/* TODO: fix 2.4G supported channel when channel doesn't start from 1 and continuous */
sup_ch[0] = 1; /* First channel number */
sup_ch[1] = rfctl->channel_set[ch_set_idx].ChannelNum; /* Number of channel */
} else {
sup_ch[sup_ch_idx++] = rfctl->channel_set[ch_set_idx].ChannelNum;
sup_ch[sup_ch_idx++] = 1;
}
ch_set_idx++;
}
return rtw_set_ie(pframe, _SUPPORTED_CH_IE_, sup_ch_idx, sup_ch, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_rsnie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, int init, struct sta_info *ptdls_sta)
{
u8 *p = NULL;
int len = 0;
if (ptxmgmt->len > 0)
p = rtw_get_ie(ptxmgmt->buf, _RSN_IE_2_, &len, ptxmgmt->len);
if (p != NULL)
return rtw_set_ie(pframe, _RSN_IE_2_, len, p + 2, &(pattrib->pktlen));
else if (init == _TRUE)
return rtw_set_ie(pframe, _RSN_IE_2_, sizeof(TDLS_RSNIE), TDLS_RSNIE, &(pattrib->pktlen));
else
return rtw_set_ie(pframe, _RSN_IE_2_, sizeof(ptdls_sta->TDLS_RSNIE), ptdls_sta->TDLS_RSNIE, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_ext_cap(u8 *pframe, struct pkt_attrib *pattrib)
{
return rtw_set_ie(pframe, _EXT_CAP_IE_ , sizeof(TDLS_EXT_CAPIE), TDLS_EXT_CAPIE, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_qos_cap(u8 *pframe, struct pkt_attrib *pattrib)
{
return rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, sizeof(TDLS_WMMIE), TDLS_WMMIE, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_ftie(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, u8 *ANonce, u8 *SNonce)
{
struct wpa_tdls_ftie FTIE = {0};
u8 *p = NULL;
int len = 0;
if (ptxmgmt->len > 0)
p = rtw_get_ie(ptxmgmt->buf, _FTIE_, &len, ptxmgmt->len);
if (p != NULL)
return rtw_set_ie(pframe, _FTIE_, len, p + 2, &(pattrib->pktlen));
else {
if (ANonce != NULL)
_rtw_memcpy(FTIE.Anonce, ANonce, WPA_NONCE_LEN);
if (SNonce != NULL)
_rtw_memcpy(FTIE.Snonce, SNonce, WPA_NONCE_LEN);
return rtw_set_ie(pframe, _FTIE_, TDLS_FTIE_DATA_LEN,
(u8 *)FTIE.data, &(pattrib->pktlen));
}
}
u8 *rtw_tdls_set_timeout_interval(struct tdls_txmgmt *ptxmgmt, u8 *pframe, struct pkt_attrib *pattrib, int init, struct sta_info *ptdls_sta)
{
u8 timeout_itvl[5]; /* set timeout interval to maximum value */
u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
u8 *p = NULL;
int len = 0;
if (ptxmgmt->len > 0)
p = rtw_get_ie(ptxmgmt->buf, _TIMEOUT_ITVL_IE_, &len, ptxmgmt->len);
if (p != NULL)
return rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, len, p + 2, &(pattrib->pktlen));
else {
/* Timeout interval */
timeout_itvl[0] = 0x02;
if (init == _TRUE)
_rtw_memcpy(timeout_itvl + 1, &timeout_interval, 4);
else
_rtw_memcpy(timeout_itvl + 1, (u8 *)(&ptdls_sta->TDLS_PeerKey_Lifetime), 4);
return rtw_set_ie(pframe, _TIMEOUT_ITVL_IE_, 5, timeout_itvl, &(pattrib->pktlen));
}
}
u8 *rtw_tdls_set_bss_coexist(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
u8 iedata = 0;
if (padapter->mlmepriv.num_FortyMHzIntolerant > 0)
iedata |= BIT(2); /* 20 MHz BSS Width Request */
/* Information Bit should be set by TDLS test plan 5.9 */
iedata |= BIT(0);
return rtw_set_ie(pframe, EID_BSSCoexistence, 1, &iedata, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_payload_type(u8 *pframe, struct pkt_attrib *pattrib)
{
u8 payload_type = 0x02;
return rtw_set_fixed_ie(pframe, 1, &(payload_type), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_category(u8 *pframe, struct pkt_attrib *pattrib, u8 category)
{
return rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_action(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
{
return rtw_set_fixed_ie(pframe, 1, &(ptxmgmt->action_code), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_status_code(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
{
return rtw_set_fixed_ie(pframe, 2, (u8 *)&(ptxmgmt->status_code), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_dialog(u8 *pframe, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
{
u8 dialogtoken = 1;
if (ptxmgmt->dialog_token)
return rtw_set_fixed_ie(pframe, 1, &(ptxmgmt->dialog_token), &(pattrib->pktlen));
else
return rtw_set_fixed_ie(pframe, 1, &(dialogtoken), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_reg_class(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)
{
u8 reg_class = 22;
return rtw_set_fixed_ie(pframe, 1, &(reg_class), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_second_channel_offset(u8 *pframe, struct pkt_attrib *pattrib, u8 ch_offset)
{
return rtw_set_ie(pframe, EID_SecondaryChnlOffset , 1, &ch_offset, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_capability(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
u8 cap_from_ie[2] = {0};
_rtw_memcpy(cap_from_ie, rtw_get_capability_from_ie(pmlmeinfo->network.IEs), 2);
return rtw_set_fixed_ie(pframe, 2, cap_from_ie, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_supported_rate(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
u8 bssrate[NDIS_802_11_LENGTH_RATES_EX];
int bssrate_len = 0;
u8 more_supportedrates = 0;
rtw_set_supported_rate(bssrate, (padapter->registrypriv.wireless_mode == WIRELESS_MODE_MAX) ? padapter->mlmeextpriv.cur_wireless_mode : padapter->registrypriv.wireless_mode);
bssrate_len = rtw_get_rateset_len(bssrate);
if (bssrate_len > 8) {
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &(pattrib->pktlen));
more_supportedrates = 1;
} else
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &(pattrib->pktlen));
/* extended supported rates */
if (more_supportedrates == 1)
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &(pattrib->pktlen));
return pframe;
}
u8 *rtw_tdls_set_sup_reg_class(u8 *pframe, struct pkt_attrib *pattrib)
{
return rtw_set_ie(pframe, _SRC_IE_ , sizeof(TDLS_SRC), TDLS_SRC, &(pattrib->pktlen));
}
u8 *rtw_tdls_set_linkid(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib, u8 init)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 link_id_addr[18] = {0};
_rtw_memcpy(link_id_addr, get_my_bssid(&(pmlmeinfo->network)), 6);
if (init == _TRUE) {
_rtw_memcpy((link_id_addr + 6), pattrib->src, 6);
_rtw_memcpy((link_id_addr + 12), pattrib->dst, 6);
} else {
_rtw_memcpy((link_id_addr + 6), pattrib->dst, 6);
_rtw_memcpy((link_id_addr + 12), pattrib->src, 6);
}
return rtw_set_ie(pframe, _LINK_ID_IE_, 18, link_id_addr, &(pattrib->pktlen));
}
#ifdef CONFIG_TDLS_CH_SW
u8 *rtw_tdls_set_target_ch(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
u8 target_ch = 1;
if (padapter->tdlsinfo.chsw_info.off_ch_num)
return rtw_set_fixed_ie(pframe, 1, &(padapter->tdlsinfo.chsw_info.off_ch_num), &(pattrib->pktlen));
else
return rtw_set_fixed_ie(pframe, 1, &(target_ch), &(pattrib->pktlen));
}
u8 *rtw_tdls_set_ch_sw(u8 *pframe, struct pkt_attrib *pattrib, struct sta_info *ptdls_sta)
{
u8 ch_switch_timing[4] = {0};
u16 switch_time = (ptdls_sta->ch_switch_time >= TDLS_CH_SWITCH_TIME * 1000) ?
ptdls_sta->ch_switch_time : TDLS_CH_SWITCH_TIME;
u16 switch_timeout = (ptdls_sta->ch_switch_timeout >= TDLS_CH_SWITCH_TIMEOUT * 1000) ?
ptdls_sta->ch_switch_timeout : TDLS_CH_SWITCH_TIMEOUT;
_rtw_memcpy(ch_switch_timing, &switch_time, 2);
_rtw_memcpy(ch_switch_timing + 2, &switch_timeout, 2);
return rtw_set_ie(pframe, _CH_SWITCH_TIMING_, 4, ch_switch_timing, &(pattrib->pktlen));
}
void rtw_tdls_set_ch_sw_oper_control(_adapter *padapter, u8 enable)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if (enable == _TRUE) {
#ifdef CONFIG_TDLS_CH_SW_V2
pHalData->ch_switch_offload = _TRUE;
#endif
#ifdef CONFIG_TDLS_CH_SW_BY_DRV
pHalData->ch_switch_offload = _FALSE;
#endif
}
else
pHalData->ch_switch_offload = _FALSE;
if (ATOMIC_READ(&padapter->tdlsinfo.chsw_info.chsw_on) != enable)
ATOMIC_SET(&padapter->tdlsinfo.chsw_info.chsw_on, enable);
rtw_hal_set_hwreg(padapter, HW_VAR_TDLS_BCN_EARLY_C2H_RPT, &enable);
RTW_INFO("[TDLS] %s Bcn Early C2H Report\n", (enable == _TRUE) ? "Start" : "Stop");
}
void rtw_tdls_ch_sw_back_to_base_chnl(_adapter *padapter)
{
struct mlme_priv *pmlmepriv;
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
pmlmepriv = &padapter->mlmepriv;
if ((ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) &&
(padapter->mlmeextpriv.cur_channel != rtw_get_oper_ch(padapter)))
rtw_tdls_cmd(padapter, pchsw_info->addr, TDLS_CH_SW_TO_BASE_CHNL_UNSOLICITED);
}
static void rtw_tdls_chsw_oper_init(_adapter *padapter, u32 timeout_ms)
{
struct submit_ctx *chsw_sctx = &padapter->tdlsinfo.chsw_info.chsw_sctx;
rtw_sctx_init(chsw_sctx, timeout_ms);
}
static int rtw_tdls_chsw_oper_wait(_adapter *padapter)
{
struct submit_ctx *chsw_sctx = &padapter->tdlsinfo.chsw_info.chsw_sctx;
return rtw_sctx_wait(chsw_sctx, __func__);
}
void rtw_tdls_chsw_oper_done(_adapter *padapter)
{
struct submit_ctx *chsw_sctx = &padapter->tdlsinfo.chsw_info.chsw_sctx;
rtw_sctx_done(&chsw_sctx);
}
s32 rtw_tdls_do_ch_sw(_adapter *padapter, struct sta_info *ptdls_sta, u8 chnl_type, u8 channel, u8 channel_offset, u16 bwmode, u16 ch_switch_time)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
u32 ch_sw_time_start, ch_sw_time_spent, wait_time;
u8 take_care_iqk;
s32 ret = _FAIL;
ch_sw_time_start = rtw_systime_to_ms(rtw_get_current_time());
/* set mac_id sleep before channel switch */
rtw_hal_macid_sleep(padapter, ptdls_sta->cmn.mac_id);
#if defined(CONFIG_TDLS_CH_SW_BY_DRV) || defined(CONFIG_TDLS_CH_SW_V2)
set_channel_bwmode(padapter, channel, channel_offset, bwmode);
ret = _SUCCESS;
#else
rtw_tdls_chsw_oper_init(padapter, TDLS_CH_SWITCH_OPER_OFFLOAD_TIMEOUT);
/* channel switch IOs offload to FW */
if (rtw_hal_ch_sw_oper_offload(padapter, channel, channel_offset, bwmode) == _SUCCESS) {
if (rtw_tdls_chsw_oper_wait(padapter) == _SUCCESS) {
/* set channel and bw related variables in driver */
_enter_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
rtw_set_oper_ch(padapter, channel);
rtw_set_oper_choffset(padapter, channel_offset);
rtw_set_oper_bw(padapter, bwmode);
center_ch = rtw_get_center_ch(channel, bwmode, channel_offset);
pHalData->current_channel = center_ch;
pHalData->CurrentCenterFrequencyIndex1 = center_ch;
pHalData->current_channel_bw = bwmode;
pHalData->nCur40MhzPrimeSC = channel_offset;
if (bwmode == CHANNEL_WIDTH_80) {
if (center_ch > channel)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
else if (center_ch < channel)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
else
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
pHalData->nCur80MhzPrimeSC = chnl_offset80;
pHalData->CurrentCenterFrequencyIndex1 = center_ch;
_exit_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
if (take_care_iqk == _TRUE)
rtw_hal_ch_sw_iqk_info_restore(padapter, CH_SW_USE_CASE_TDLS);
ret = _SUCCESS;
} else
RTW_INFO("[TDLS] chsw oper wait fail !!\n");
}
#endif
if (ret == _SUCCESS) {
ch_sw_time_spent = rtw_systime_to_ms(rtw_get_current_time()) - ch_sw_time_start;
if (chnl_type == TDLS_CH_SW_OFF_CHNL) {
if ((u32)ch_switch_time / 1000 > ch_sw_time_spent)
wait_time = (u32)ch_switch_time / 1000 - ch_sw_time_spent;
else
wait_time = 0;
if (wait_time > 0)
rtw_msleep_os(wait_time);
}
}
/* set mac_id wakeup after channel switch */
rtw_hal_macid_wakeup(padapter, ptdls_sta->cmn.mac_id);
return ret;
}
#endif
u8 *rtw_tdls_set_wmm_params(_adapter *padapter, u8 *pframe, struct pkt_attrib *pattrib)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 wmm_param_ele[24] = {0};
if (&pmlmeinfo->WMM_param) {
_rtw_memcpy(wmm_param_ele, WMM_PARA_OUI, 6);
if (_rtw_memcmp(&pmlmeinfo->WMM_param, &wmm_param_ele[6], 18) == _TRUE)
/* Use default WMM Param */
_rtw_memcpy(wmm_param_ele + 6, (u8 *)&TDLS_WMM_PARAM_IE, sizeof(TDLS_WMM_PARAM_IE));
else
_rtw_memcpy(wmm_param_ele + 6, (u8 *)&pmlmeinfo->WMM_param, sizeof(pmlmeinfo->WMM_param));
return rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, 24, wmm_param_ele, &(pattrib->pktlen));
} else
return pframe;
}
#ifdef CONFIG_WFD
void rtw_tdls_process_wfd_ie(struct tdls_info *ptdlsinfo, u8 *ptr, u8 length)
{
u8 *wfd_ie;
u32 wfd_ielen = 0;
if (!hal_chk_wl_func(tdls_info_to_adapter(ptdlsinfo), WL_FUNC_MIRACAST))
return;
/* Try to get the TCP port information when receiving the negotiation response. */
wfd_ie = rtw_get_wfd_ie(ptr, length, NULL, &wfd_ielen);
while (wfd_ie) {
u8 *attr_content;
u32 attr_contentlen = 0;
int i;
RTW_INFO("[%s] WFD IE Found!!\n", __FUNCTION__);
attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &attr_contentlen);
if (attr_content && attr_contentlen) {
ptdlsinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
RTW_INFO("[%s] Peer PORT NUM = %d\n", __FUNCTION__, ptdlsinfo->wfd_info->peer_rtsp_ctrlport);
}
attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_LOCAL_IP_ADDR, NULL, &attr_contentlen);
if (attr_content && attr_contentlen) {
_rtw_memcpy(ptdlsinfo->wfd_info->peer_ip_address, (attr_content + 1), 4);
RTW_INFO("[%s] Peer IP = %02u.%02u.%02u.%02u\n", __FUNCTION__,
ptdlsinfo->wfd_info->peer_ip_address[0], ptdlsinfo->wfd_info->peer_ip_address[1],
ptdlsinfo->wfd_info->peer_ip_address[2], ptdlsinfo->wfd_info->peer_ip_address[3]);
}
wfd_ie = rtw_get_wfd_ie(wfd_ie + wfd_ielen, (ptr + length) - (wfd_ie + wfd_ielen), NULL, &wfd_ielen);
}
}
int issue_tunneled_probe_req(_adapter *padapter)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
u8 baddr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct tdls_txmgmt txmgmt;
int ret = _FAIL;
RTW_INFO("[%s]\n", __FUNCTION__);
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.action_code = TUNNELED_PROBE_REQ;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, baddr, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
int issue_tunneled_probe_rsp(_adapter *padapter, union recv_frame *precv_frame)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct tdls_txmgmt txmgmt;
int ret = _FAIL;
RTW_INFO("[%s]\n", __FUNCTION__);
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.action_code = TUNNELED_PROBE_RSP;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, precv_frame->u.hdr.attrib.src, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
#endif /* CONFIG_WFD */
int issue_tdls_setup_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *ptdls_sta = NULL;
_irqL irqL;
int ret = _FAIL;
/* Retry timer should be set at least 301 sec, using TPK_count counting 301 times. */
u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
if (rtw_tdls_is_setup_allowed(padapter) == _FALSE)
goto exit;
if (IS_MCAST(ptxmgmt->peer))
goto exit;
ptdls_sta = rtw_get_stainfo(pstapriv, ptxmgmt->peer);
if (ptdlsinfo->sta_maximum == _TRUE) {
if (ptdls_sta == NULL)
goto exit;
else if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
goto exit;
}
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
if (ptdls_sta == NULL) {
ptdls_sta = rtw_alloc_stainfo(pstapriv, ptxmgmt->peer);
if (ptdls_sta == NULL) {
RTW_INFO("[%s] rtw_alloc_stainfo fail\n", __FUNCTION__);
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
ptdlsinfo->sta_cnt++;
}
ptxmgmt->action_code = TDLS_SETUP_REQUEST;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
ptdlsinfo->sta_maximum = _TRUE;
ptdls_sta->tdls_sta_state |= TDLS_RESPONDER_STATE;
if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
_set_timer(&ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
}
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
int _issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta, u8 wait_ack)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct sta_priv *pstapriv = &padapter->stapriv;
_irqL irqL;
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
ptxmgmt->action_code = TDLS_TEARDOWN;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
rtw_mi_set_scan_deny(padapter, 550);
rtw_mi_scan_abort(padapter, _TRUE);
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
if (ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_)
_rtw_memcpy(pattrib->ra, ptxmgmt->peer, ETH_ALEN);
else
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
if (pattrib->encrypt)
_cancel_timer_ex(&ptdls_sta->TPK_timer);
if (wait_ack)
ret = dump_mgntframe_and_wait_ack(padapter, pmgntframe);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
int issue_tdls_teardown(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 wait_ack)
{
struct sta_info *ptdls_sta = NULL;
int ret = _FAIL;
ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), ptxmgmt->peer);
if (ptdls_sta == NULL) {
RTW_INFO("No tdls_sta for tearing down\n");
goto exit;
}
ret = _issue_tdls_teardown(padapter, ptxmgmt, ptdls_sta, wait_ack);
if ((ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_) && (ret == _FAIL)) {
/* Change status code and send teardown again via AP */
ptxmgmt->status_code = _RSON_TDLS_TEAR_TOOFAR_;
ret = _issue_tdls_teardown(padapter, ptxmgmt, ptdls_sta, wait_ack);
}
if (rtw_tdls_is_driver_setup(padapter)) {
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptxmgmt->peer, TDLS_TEARDOWN_STA_LOCALLY_POST);
}
exit:
return ret;
}
int issue_tdls_dis_req(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
ptxmgmt->action_code = TDLS_DISCOVERY_REQUEST;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
RTW_INFO("issue tdls dis req\n");
ret = _SUCCESS;
exit:
return ret;
}
int issue_tdls_setup_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
ptxmgmt->action_code = TDLS_SETUP_RESPONSE;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(&(padapter->mlmepriv)), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
int issue_tdls_setup_cfm(_adapter *padapter, struct tdls_txmgmt *ptxmgmt)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
ptxmgmt->action_code = TDLS_SETUP_CONFIRM;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(&padapter->mlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
/* TDLS Discovery Response frame is a management action frame */
int issue_tdls_dis_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, u8 privacy)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
unsigned char *pframe;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
/* unicast probe request frame */
_rtw_memcpy(pwlanhdr->addr1, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->dst, pwlanhdr->addr1, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->src, pwlanhdr->addr2, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_bssid(&padapter->mlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ra, pwlanhdr->addr3, ETH_ALEN);
SetSeqNum(pwlanhdr, pmlmeext->mgnt_seq);
pmlmeext->mgnt_seq++;
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
rtw_build_tdls_dis_rsp_ies(padapter, pmgntframe, pframe, ptxmgmt, privacy);
pattrib->nr_frags = 1;
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
int issue_tdls_peer_traffic_rsp(_adapter *padapter, struct sta_info *ptdls_sta, struct tdls_txmgmt *ptxmgmt)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
ptxmgmt->action_code = TDLS_PEER_TRAFFIC_RESPONSE;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptdls_sta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, ptdls_sta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
int issue_tdls_peer_traffic_indication(_adapter *padapter, struct sta_info *ptdls_sta)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct tdls_txmgmt txmgmt;
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.action_code = TDLS_PEER_TRAFFIC_INDICATION;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptdls_sta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
/* PTI frame's priority should be AC_VO */
pattrib->priority = 7;
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
#ifdef CONFIG_TDLS_CH_SW
int issue_tdls_ch_switch_req(_adapter *padapter, struct sta_info *ptdls_sta)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct tdls_txmgmt txmgmt;
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
goto exit;
}
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.action_code = TDLS_CHANNEL_SWITCH_REQUEST;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptdls_sta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, ptdls_sta->cmn.mac_addr, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, &txmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
exit:
return ret;
}
int issue_tdls_ch_switch_rsp(_adapter *padapter, struct tdls_txmgmt *ptxmgmt, int wait_ack)
{
struct xmit_frame *pmgntframe;
struct pkt_attrib *pattrib;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
int ret = _FAIL;
RTW_INFO("[TDLS] %s\n", __FUNCTION__);
if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
goto exit;
}
ptxmgmt->action_code = TDLS_CHANNEL_SWITCH_RESPONSE;
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL)
goto exit;
pattrib = &pmgntframe->attrib;
pmgntframe->frame_tag = DATA_FRAMETAG;
pattrib->ether_type = 0x890d;
_rtw_memcpy(pattrib->dst, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->src, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pattrib->ra, ptxmgmt->peer, ETH_ALEN);
_rtw_memcpy(pattrib->ta, pattrib->src, ETH_ALEN);
update_tdls_attrib(padapter, pattrib);
pattrib->qsel = pattrib->priority;
/*
_enter_critical_bh(&pxmitpriv->lock, &irqL);
if(xmitframe_enqueue_for_tdls_sleeping_sta(padapter, pmgntframe)==_TRUE){
_exit_critical_bh(&pxmitpriv->lock, &irqL);
return _FALSE;
}
*/
if (rtw_xmit_tdls_coalesce(padapter, pmgntframe, ptxmgmt) != _SUCCESS) {
rtw_free_xmitbuf(pxmitpriv, pmgntframe->pxmitbuf);
rtw_free_xmitframe(pxmitpriv, pmgntframe);
goto exit;
}
if (wait_ack)
ret = dump_mgntframe_and_wait_ack_timeout(padapter, pmgntframe, 10);
else {
dump_mgntframe(padapter, pmgntframe);
ret = _SUCCESS;
}
exit:
return ret;
}
#endif
int On_TDLS_Dis_Rsp(_adapter *padapter, union recv_frame *precv_frame)
{
struct sta_info *ptdls_sta = NULL, *psta = rtw_get_stainfo(&(padapter->stapriv), get_bssid(&(padapter->mlmepriv)));
struct recv_priv *precvpriv = &(padapter->recvpriv);
u8 *ptr = precv_frame->u.hdr.rx_data, *psa;
struct rx_pkt_attrib *pattrib = &(precv_frame->u.hdr.attrib);
struct tdls_info *ptdlsinfo = &(padapter->tdlsinfo);
u8 empty_addr[ETH_ALEN] = { 0x00 };
int rssi = 0;
struct tdls_txmgmt txmgmt;
int ret = _SUCCESS;
if (psta)
rssi = psta->cmn.rssi_stat.rssi;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
/* WFDTDLS: for sigma test, not to setup direct link automatically */
ptdlsinfo->dev_discovered = _TRUE;
psa = get_sa(ptr);
ptdls_sta = rtw_get_stainfo(&(padapter->stapriv), psa);
if (ptdls_sta != NULL)
ptdls_sta->sta_stats.rx_tdls_disc_rsp_pkts++;
#ifdef CONFIG_TDLS_AUTOSETUP
if (ptdls_sta != NULL) {
/* Record the tdls sta with lowest signal strength */
if (ptdlsinfo->sta_maximum == _TRUE && ptdls_sta->alive_count >= 1) {
if (_rtw_memcmp(ptdlsinfo->ss_record.macaddr, empty_addr, ETH_ALEN)) {
_rtw_memcpy(ptdlsinfo->ss_record.macaddr, psa, ETH_ALEN);
ptdlsinfo->ss_record.RxPWDBAll = pattrib->phy_info.rx_pwdb_all;
} else {
if (ptdlsinfo->ss_record.RxPWDBAll < pattrib->phy_info.rx_pwdb_all) {
_rtw_memcpy(ptdlsinfo->ss_record.macaddr, psa, ETH_ALEN);
ptdlsinfo->ss_record.RxPWDBAll = pattrib->phy_info.rx_pwdb_all;
}
}
}
} else {
if (ptdlsinfo->sta_maximum == _TRUE) {
if (_rtw_memcmp(ptdlsinfo->ss_record.macaddr, empty_addr, ETH_ALEN)) {
/* All traffics are busy, do not set up another direct link. */
ret = _FAIL;
goto exit;
} else {
if (pattrib->phy_info.rx_pwdb_all > ptdlsinfo->ss_record.RxPWDBAll) {
_rtw_memcpy(txmgmt.peer, ptdlsinfo->ss_record.macaddr, ETH_ALEN);
/* issue_tdls_teardown(padapter, ptdlsinfo->ss_record.macaddr, _FALSE); */
} else {
ret = _FAIL;
goto exit;
}
}
}
if (pattrib->phy_info.rx_pwdb_all + TDLS_SIGNAL_THRESH >= rssi) {
RTW_INFO("pattrib->RxPWDBAll=%d, pdmpriv->undecorated_smoothed_pwdb=%d\n", pattrib->phy_info.rx_pwdb_all, rssi);
_rtw_memcpy(txmgmt.peer, psa, ETH_ALEN);
issue_tdls_setup_req(padapter, &txmgmt, _FALSE);
}
}
#endif /* CONFIG_TDLS_AUTOSETUP */
exit:
return ret;
}
sint On_TDLS_Setup_Req(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
u8 *psa, *pmyid;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *ptr = precv_frame->u.hdr.rx_data;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct security_priv *psecuritypriv = &padapter->securitypriv;
_irqL irqL;
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
u8 *prsnie, *ppairwise_cipher;
u8 i, k;
u8 ccmp_included = 0, rsnie_included = 0;
u16 j, pairwise_count;
u8 SNonce[32];
u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
sint parsing_length; /* Frame body length, without icv_len */
PNDIS_802_11_VARIABLE_IEs pIE;
u8 FIXED_IE = 5;
unsigned char supportRate[16];
int supportRateNum = 0;
struct tdls_txmgmt txmgmt;
if (rtw_tdls_is_setup_allowed(padapter) == _FALSE)
goto exit;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
psa = get_sa(ptr);
if (ptdlsinfo->sta_maximum == _TRUE) {
if (ptdls_sta == NULL)
goto exit;
else if (!(ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE))
goto exit;
}
pmyid = adapter_mac_addr(padapter);
ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
- prx_pkt_attrib->hdrlen
- prx_pkt_attrib->iv_len
- prx_pkt_attrib->icv_len
- LLC_HEADER_SIZE
- ETH_TYPE_LEN
- PAYLOAD_TYPE_LEN;
if (ptdls_sta == NULL) {
ptdls_sta = rtw_alloc_stainfo(pstapriv, psa);
if (ptdls_sta == NULL)
goto exit;
ptdlsinfo->sta_cnt++;
}
else {
if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
/* If the direct link is already set up */
/* Process as re-setup after tear down */
RTW_INFO("re-setup a direct link\n");
}
/* Already receiving TDLS setup request */
else if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE) {
RTW_INFO("receive duplicated TDLS setup request frame in handshaking\n");
goto exit;
}
/* When receiving and sending setup_req to the same link at the same time */
/* STA with higher MAC_addr would be initiator */
else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE) {
RTW_INFO("receive setup_req after sending setup_req\n");
for (i = 0; i < 6; i++) {
if (*(pmyid + i) == *(psa + i)) {
} else if (*(pmyid + i) > *(psa + i)) {
ptdls_sta->tdls_sta_state = TDLS_INITIATOR_STATE;
break;
} else if (*(pmyid + i) < *(psa + i))
goto exit;
}
}
}
if (ptdls_sta) {
txmgmt.dialog_token = *(ptr + 2); /* Copy dialog token */
txmgmt.status_code = _STATS_SUCCESSFUL_;
/* Parsing information element */
for (j = FIXED_IE; j < parsing_length;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
switch (pIE->ElementID) {
case _SUPPORTEDRATES_IE_:
_rtw_memcpy(supportRate, pIE->data, pIE->Length);
supportRateNum = pIE->Length;
break;
case _COUNTRY_IE_:
break;
case _EXT_SUPPORTEDRATES_IE_:
if (supportRateNum < sizeof(supportRate)) {
_rtw_memcpy(supportRate + supportRateNum, pIE->data, pIE->Length);
supportRateNum += pIE->Length;
}
break;
case _SUPPORTED_CH_IE_:
break;
case _RSN_IE_2_:
rsnie_included = 1;
if (prx_pkt_attrib->encrypt) {
prsnie = (u8 *)pIE;
/* Check CCMP pairwise_cipher presence. */
ppairwise_cipher = prsnie + 10;
_rtw_memcpy(ptdls_sta->TDLS_RSNIE, pIE->data, pIE->Length);
pairwise_count = *(u16 *)(ppairwise_cipher - 2);
for (k = 0; k < pairwise_count; k++) {
if (_rtw_memcmp(ppairwise_cipher + 4 * k, RSN_CIPHER_SUITE_CCMP, 4) == _TRUE)
ccmp_included = 1;
}
if (ccmp_included == 0)
txmgmt.status_code = _STATS_INVALID_RSNIE_;
}
break;
case _EXT_CAP_IE_:
break;
case _VENDOR_SPECIFIC_IE_:
break;
case _FTIE_:
if (prx_pkt_attrib->encrypt)
_rtw_memcpy(SNonce, (ptr + j + 52), 32);
break;
case _TIMEOUT_ITVL_IE_:
if (prx_pkt_attrib->encrypt)
timeout_interval = cpu_to_le32(*(u32 *)(ptr + j + 3));
break;
case _RIC_Descriptor_IE_:
break;
#ifdef CONFIG_80211N_HT
case _HT_CAPABILITY_IE_:
rtw_tdls_process_ht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
#endif
#ifdef CONFIG_80211AC_VHT
case EID_AID:
break;
case EID_VHTCapability:
rtw_tdls_process_vht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
#endif
case EID_BSSCoexistence:
break;
case _LINK_ID_IE_:
if (_rtw_memcmp(get_bssid(pmlmepriv), pIE->data, 6) == _FALSE)
txmgmt.status_code = _STATS_NOT_IN_SAME_BSS_;
break;
default:
break;
}
j += (pIE->Length + 2);
}
/* Check status code */
/* If responder STA has/hasn't security on AP, but request hasn't/has RSNIE, it should reject */
if (txmgmt.status_code == _STATS_SUCCESSFUL_) {
if (rsnie_included && prx_pkt_attrib->encrypt == 0)
txmgmt.status_code = _STATS_SEC_DISABLED_;
else if (rsnie_included == 0 && prx_pkt_attrib->encrypt)
txmgmt.status_code = _STATS_INVALID_PARAMETERS_;
#ifdef CONFIG_WFD
/* WFD test plan version 0.18.2 test item 5.1.5 */
/* SoUT does not use TDLS if AP uses weak security */
if (padapter->wdinfo.wfd_tdls_enable && (rsnie_included && prx_pkt_attrib->encrypt != _AES_))
txmgmt.status_code = _STATS_SEC_DISABLED_;
#endif /* CONFIG_WFD */
}
ptdls_sta->tdls_sta_state |= TDLS_INITIATOR_STATE;
if (prx_pkt_attrib->encrypt) {
_rtw_memcpy(ptdls_sta->SNonce, SNonce, 32);
if (timeout_interval <= 300)
ptdls_sta->TDLS_PeerKey_Lifetime = TDLS_TPK_RESEND_COUNT;
else
ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
}
/* Update station supportRate */
ptdls_sta->bssratelen = supportRateNum;
_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
/* -2: AP + BC/MC sta, -4: default key */
if (ptdlsinfo->sta_cnt == MAX_ALLOWED_TDLS_STA_NUM)
ptdlsinfo->sta_maximum = _TRUE;
#ifdef CONFIG_WFD
rtw_tdls_process_wfd_ie(ptdlsinfo, ptr + FIXED_IE, parsing_length);
#endif
} else
goto exit;
_rtw_memcpy(txmgmt.peer, prx_pkt_attrib->src, ETH_ALEN);
if (rtw_tdls_is_driver_setup(padapter)) {
issue_tdls_setup_rsp(padapter, &txmgmt);
if (txmgmt.status_code == _STATS_SUCCESSFUL_)
_set_timer(&ptdls_sta->handshake_timer, TDLS_HANDSHAKE_TIME);
else {
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
}
}
exit:
return _SUCCESS;
}
int On_TDLS_Setup_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *ptr = precv_frame->u.hdr.rx_data;
_irqL irqL;
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
u8 *psa;
u16 status_code = 0;
sint parsing_length; /* Frame body length, without icv_len */
PNDIS_802_11_VARIABLE_IEs pIE;
u8 FIXED_IE = 7;
u8 ANonce[32];
u8 *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL, *ppairwise_cipher = NULL;
u16 pairwise_count, j, k;
u8 verify_ccmp = 0;
unsigned char supportRate[16];
int supportRateNum = 0;
struct tdls_txmgmt txmgmt;
int ret = _SUCCESS;
u32 timeout_interval = TDLS_TPK_RESEND_COUNT;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
psa = get_sa(ptr);
ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
- prx_pkt_attrib->hdrlen
- prx_pkt_attrib->iv_len
- prx_pkt_attrib->icv_len
- LLC_HEADER_SIZE
- ETH_TYPE_LEN
- PAYLOAD_TYPE_LEN;
_rtw_memcpy(&status_code, ptr + 2, 2);
if (status_code != 0) {
RTW_INFO("[TDLS] %s status_code = %d, free_tdls_sta\n", __FUNCTION__, status_code);
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
ret = _FAIL;
goto exit;
}
status_code = 0;
/* parsing information element */
for (j = FIXED_IE; j < parsing_length;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
switch (pIE->ElementID) {
case _SUPPORTEDRATES_IE_:
_rtw_memcpy(supportRate, pIE->data, pIE->Length);
supportRateNum = pIE->Length;
break;
case _COUNTRY_IE_:
break;
case _EXT_SUPPORTEDRATES_IE_:
if (supportRateNum < sizeof(supportRate)) {
_rtw_memcpy(supportRate + supportRateNum, pIE->data, pIE->Length);
supportRateNum += pIE->Length;
}
break;
case _SUPPORTED_CH_IE_:
break;
case _RSN_IE_2_:
prsnie = (u8 *)pIE;
/* Check CCMP pairwise_cipher presence. */
ppairwise_cipher = prsnie + 10;
_rtw_memcpy(&pairwise_count, (u16 *)(ppairwise_cipher - 2), 2);
for (k = 0; k < pairwise_count; k++) {
if (_rtw_memcmp(ppairwise_cipher + 4 * k, RSN_CIPHER_SUITE_CCMP, 4) == _TRUE)
verify_ccmp = 1;
}
case _EXT_CAP_IE_:
break;
case _VENDOR_SPECIFIC_IE_:
if (_rtw_memcmp((u8 *)pIE + 2, WMM_INFO_OUI, 6) == _TRUE) {
/* WMM Info ID and OUI */
if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
ptdls_sta->qos_option = _TRUE;
}
break;
case _FTIE_:
pftie = (u8 *)pIE;
_rtw_memcpy(ANonce, (ptr + j + 20), 32);
break;
case _TIMEOUT_ITVL_IE_:
ptimeout_ie = (u8 *)pIE;
timeout_interval = cpu_to_le32(*(u32 *)(ptimeout_ie + 3));
break;
case _RIC_Descriptor_IE_:
break;
#ifdef CONFIG_80211N_HT
case _HT_CAPABILITY_IE_:
rtw_tdls_process_ht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
#endif
#ifdef CONFIG_80211AC_VHT
case EID_AID:
/* todo in the future if necessary */
break;
case EID_VHTCapability:
rtw_tdls_process_vht_cap(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
case EID_OpModeNotification:
rtw_tdls_process_vht_op_mode_notify(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
#endif
case EID_BSSCoexistence:
break;
case _LINK_ID_IE_:
plinkid_ie = (u8 *)pIE;
break;
default:
break;
}
j += (pIE->Length + 2);
}
ptdls_sta->bssratelen = supportRateNum;
_rtw_memcpy(ptdls_sta->bssrateset, supportRate, supportRateNum);
_rtw_memcpy(ptdls_sta->ANonce, ANonce, 32);
#ifdef CONFIG_WFD
rtw_tdls_process_wfd_ie(ptdlsinfo, ptr + FIXED_IE, parsing_length);
#endif
if (prx_pkt_attrib->encrypt) {
if (verify_ccmp == 1) {
txmgmt.status_code = _STATS_SUCCESSFUL_;
if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
wpa_tdls_generate_tpk(padapter, ptdls_sta);
if (tdls_verify_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL) {
RTW_INFO("[TDLS] %s tdls_verify_mic fail, free_tdls_sta\n", __FUNCTION__);
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
ret = _FAIL;
goto exit;
}
ptdls_sta->TDLS_PeerKey_Lifetime = timeout_interval;
}
} else
txmgmt.status_code = _STATS_INVALID_RSNIE_;
} else
txmgmt.status_code = _STATS_SUCCESSFUL_;
if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
_rtw_memcpy(txmgmt.peer, prx_pkt_attrib->src, ETH_ALEN);
issue_tdls_setup_cfm(padapter, &txmgmt);
if (txmgmt.status_code == _STATS_SUCCESSFUL_) {
rtw_tdls_set_link_established(padapter, _TRUE);
if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE) {
ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
ptdls_sta->state |= _FW_LINKED;
_cancel_timer_ex(&ptdls_sta->handshake_timer);
}
if (prx_pkt_attrib->encrypt)
rtw_tdls_set_key(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_ESTABLISHED);
}
}
exit:
if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
return ret;
else
return _SUCCESS;
}
int On_TDLS_Setup_Cfm(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *ptr = precv_frame->u.hdr.rx_data;
_irqL irqL;
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
u8 *psa;
u16 status_code = 0;
sint parsing_length;
PNDIS_802_11_VARIABLE_IEs pIE;
u8 FIXED_IE = 5;
u8 *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL, *ppairwise_cipher = NULL;
u16 j, pairwise_count;
int ret = _SUCCESS;
psa = get_sa(ptr);
ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
- prx_pkt_attrib->hdrlen
- prx_pkt_attrib->iv_len
- prx_pkt_attrib->icv_len
- LLC_HEADER_SIZE
- ETH_TYPE_LEN
- PAYLOAD_TYPE_LEN;
_rtw_memcpy(&status_code, ptr + 2, 2);
if (status_code != 0) {
RTW_INFO("[%s] status_code = %d\n, free_tdls_sta", __FUNCTION__, status_code);
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
ret = _FAIL;
goto exit;
}
/* Parsing information element */
for (j = FIXED_IE; j < parsing_length;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
switch (pIE->ElementID) {
case _RSN_IE_2_:
prsnie = (u8 *)pIE;
break;
case _VENDOR_SPECIFIC_IE_:
if (_rtw_memcmp((u8 *)pIE + 2, WMM_PARA_OUI, 6) == _TRUE) {
/* WMM Parameter ID and OUI */
ptdls_sta->qos_option = _TRUE;
}
break;
case _FTIE_:
pftie = (u8 *)pIE;
break;
case _TIMEOUT_ITVL_IE_:
ptimeout_ie = (u8 *)pIE;
break;
#ifdef CONFIG_80211N_HT
case _HT_EXTRA_INFO_IE_:
break;
#endif
#ifdef CONFIG_80211AC_VHT
case EID_VHTOperation:
rtw_tdls_process_vht_operation(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
case EID_OpModeNotification:
rtw_tdls_process_vht_op_mode_notify(padapter, ptdls_sta, pIE->data, pIE->Length);
break;
#endif
case _LINK_ID_IE_:
plinkid_ie = (u8 *)pIE;
break;
default:
break;
}
j += (pIE->Length + 2);
}
if (prx_pkt_attrib->encrypt) {
/* Verify mic in FTIE MIC field */
if (rtw_tdls_is_driver_setup(padapter) &&
(tdls_verify_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie) == _FAIL)) {
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
ret = _FAIL;
goto exit;
}
}
if (rtw_tdls_is_driver_setup(padapter)) {
rtw_tdls_set_link_established(padapter, _TRUE);
if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE) {
ptdls_sta->tdls_sta_state |= TDLS_LINKED_STATE;
ptdls_sta->state |= _FW_LINKED;
_cancel_timer_ex(&ptdls_sta->handshake_timer);
}
if (prx_pkt_attrib->encrypt) {
rtw_tdls_set_key(padapter, ptdls_sta);
/* Start TPK timer */
ptdls_sta->TPK_count = 0;
_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
}
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_ESTABLISHED);
}
exit:
return ret;
}
int On_TDLS_Dis_Req(_adapter *padapter, union recv_frame *precv_frame)
{
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta_ap;
u8 *ptr = precv_frame->u.hdr.rx_data;
sint parsing_length; /* Frame body length, without icv_len */
PNDIS_802_11_VARIABLE_IEs pIE;
u8 FIXED_IE = 3, *dst;
u16 j;
struct tdls_txmgmt txmgmt;
int ret = _SUCCESS;
if (rtw_tdls_is_driver_setup(padapter) == _FALSE)
goto exit;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
txmgmt.dialog_token = *(ptr + 2);
_rtw_memcpy(&txmgmt.peer, precv_frame->u.hdr.attrib.src, ETH_ALEN);
txmgmt.action_code = TDLS_DISCOVERY_RESPONSE;
parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
- prx_pkt_attrib->hdrlen
- prx_pkt_attrib->iv_len
- prx_pkt_attrib->icv_len
- LLC_HEADER_SIZE
- ETH_TYPE_LEN
- PAYLOAD_TYPE_LEN;
/* Parsing information element */
for (j = FIXED_IE; j < parsing_length;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
switch (pIE->ElementID) {
case _LINK_ID_IE_:
psta_ap = rtw_get_stainfo(pstapriv, pIE->data);
if (psta_ap == NULL)
goto exit;
dst = pIE->data + 12;
if (MacAddr_isBcst(dst) == _FALSE && (_rtw_memcmp(adapter_mac_addr(padapter), dst, ETH_ALEN) == _FALSE))
goto exit;
break;
default:
break;
}
j += (pIE->Length + 2);
}
issue_tdls_dis_rsp(padapter, &txmgmt, prx_pkt_attrib->privacy);
exit:
return ret;
}
int On_TDLS_Teardown(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
u8 *ptr = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_priv *pstapriv = &padapter->stapriv;
_irqL irqL;
u8 reason;
reason = *(ptr + prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN + 2);
RTW_INFO("[TDLS] %s Reason code(%d)\n", __FUNCTION__, reason);
if (rtw_tdls_is_driver_setup(padapter)) {
rtw_tdls_teardown_pre_hdl(padapter, ptdls_sta);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY_POST);
}
return _SUCCESS;
}
#if 0
u8 TDLS_check_ch_state(uint state)
{
if (state & TDLS_CH_SWITCH_ON_STATE &&
state & TDLS_PEER_AT_OFF_STATE) {
if (state & TDLS_PEER_SLEEP_STATE)
return 2; /* U-APSD + ch. switch */
else
return 1; /* ch. switch */
} else
return 0;
}
#endif
int On_TDLS_Peer_Traffic_Indication(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
u8 *ptr = precv_frame->u.hdr.rx_data;
struct tdls_txmgmt txmgmt;
ptr += pattrib->hdrlen + pattrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
txmgmt.dialog_token = *(ptr + 2);
issue_tdls_peer_traffic_rsp(padapter, ptdls_sta, &txmgmt);
/* issue_nulldata_to_TDLS_peer_STA(padapter, ptdls_sta->cmn.mac_addr, 0, 0, 0); */
return _SUCCESS;
}
/* We process buffered data for 1. U-APSD, 2. ch. switch, 3. U-APSD + ch. switch here */
int On_TDLS_Peer_Traffic_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct rx_pkt_attrib *pattrib = &precv_frame->u.hdr.attrib;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 wmmps_ac = 0;
/* u8 state=TDLS_check_ch_state(ptdls_sta->tdls_sta_state); */
int i;
ptdls_sta->sta_stats.rx_data_pkts++;
ptdls_sta->tdls_sta_state &= ~(TDLS_WAIT_PTR_STATE);
/* Check 4-AC queue bit */
if (ptdls_sta->uapsd_vo || ptdls_sta->uapsd_vi || ptdls_sta->uapsd_be || ptdls_sta->uapsd_bk)
wmmps_ac = 1;
/* If it's a direct link and have buffered frame */
if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
if (wmmps_ac) {
_irqL irqL;
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
_enter_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
xmitframe_phead = get_list_head(&ptdls_sta->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
/* transmit buffered frames */
while (rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
rtw_list_delete(&pxmitframe->list);
ptdls_sta->sleepq_len--;
ptdls_sta->sleepq_ac_len--;
if (ptdls_sta->sleepq_len > 0) {
pxmitframe->attrib.mdata = 1;
pxmitframe->attrib.eosp = 0;
} else {
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.eosp = 1;
}
pxmitframe->attrib.triggered = 1;
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
}
if (ptdls_sta->sleepq_len == 0)
RTW_INFO("no buffered packets for tdls to xmit\n");
else {
RTW_INFO("error!psta->sleepq_len=%d\n", ptdls_sta->sleepq_len);
ptdls_sta->sleepq_len = 0;
}
_exit_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
}
}
return _SUCCESS;
}
#ifdef CONFIG_TDLS_CH_SW
sint On_TDLS_Ch_Switch_Req(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *ptr = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
sint parsing_length;
PNDIS_802_11_VARIABLE_IEs pIE;
u8 FIXED_IE = 4;
u16 j;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
u8 zaddr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
u16 switch_time = TDLS_CH_SWITCH_TIME * 1000, switch_timeout = TDLS_CH_SWITCH_TIMEOUT * 1000;
u8 take_care_iqk;
if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
return _FAIL;
}
ptdls_sta->ch_switch_time = switch_time;
ptdls_sta->ch_switch_timeout = switch_timeout;
ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
- prx_pkt_attrib->hdrlen
- prx_pkt_attrib->iv_len
- prx_pkt_attrib->icv_len
- LLC_HEADER_SIZE
- ETH_TYPE_LEN
- PAYLOAD_TYPE_LEN;
pchsw_info->off_ch_num = *(ptr + 2);
if ((*(ptr + 2) == 2) && (hal_is_band_support(padapter, BAND_ON_5G)))
pchsw_info->off_ch_num = 44;
if (pchsw_info->off_ch_num != pmlmeext->cur_channel)
pchsw_info->delay_switch_back = _FALSE;
/* Parsing information element */
for (j = FIXED_IE; j < parsing_length;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
switch (pIE->ElementID) {
case EID_SecondaryChnlOffset:
switch (*(pIE->data)) {
case EXTCHNL_OFFSET_UPPER:
pchsw_info->ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case EXTCHNL_OFFSET_LOWER:
pchsw_info->ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
default:
pchsw_info->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
break;
}
break;
case _LINK_ID_IE_:
break;
case _CH_SWITCH_TIMING_:
ptdls_sta->ch_switch_time = (RTW_GET_LE16(pIE->data) >= TDLS_CH_SWITCH_TIME * 1000) ?
RTW_GET_LE16(pIE->data) : TDLS_CH_SWITCH_TIME * 1000;
ptdls_sta->ch_switch_timeout = (RTW_GET_LE16(pIE->data + 2) >= TDLS_CH_SWITCH_TIMEOUT * 1000) ?
RTW_GET_LE16(pIE->data + 2) : TDLS_CH_SWITCH_TIMEOUT * 1000;
RTW_INFO("[TDLS] %s ch_switch_time:%d, ch_switch_timeout:%d\n"
, __FUNCTION__, RTW_GET_LE16(pIE->data), RTW_GET_LE16(pIE->data + 2));
default:
break;
}
j += (pIE->Length + 2);
}
rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
if (take_care_iqk == _TRUE) {
u8 central_chnl;
u8 bw_mode;
bw_mode = (pchsw_info->ch_offset) ? CHANNEL_WIDTH_40 : CHANNEL_WIDTH_20;
central_chnl = rtw_get_center_ch(pchsw_info->off_ch_num, bw_mode, pchsw_info->ch_offset);
if (rtw_hal_ch_sw_iqk_info_search(padapter, central_chnl, bw_mode) < 0) {
if (!(pchsw_info->ch_sw_state & TDLS_CH_SWITCH_PREPARE_STATE))
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_PREPARE);
return _FAIL;
}
}
/* cancel ch sw monitor timer for responder */
if (!(pchsw_info->ch_sw_state & TDLS_CH_SW_INITIATOR_STATE))
_cancel_timer_ex(&ptdls_sta->ch_sw_monitor_timer);
if (_rtw_memcmp(pchsw_info->addr, zaddr, ETH_ALEN) == _TRUE)
_rtw_memcpy(pchsw_info->addr, ptdls_sta->cmn.mac_addr, ETH_ALEN);
if (ATOMIC_READ(&pchsw_info->chsw_on) == _FALSE)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_START);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_RESP);
return _SUCCESS;
}
sint On_TDLS_Ch_Switch_Rsp(_adapter *padapter, union recv_frame *precv_frame, struct sta_info *ptdls_sta)
{
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *ptr = precv_frame->u.hdr.rx_data;
struct rx_pkt_attrib *prx_pkt_attrib = &precv_frame->u.hdr.attrib;
sint parsing_length;
PNDIS_802_11_VARIABLE_IEs pIE;
u8 FIXED_IE = 4;
u16 status_code, j, switch_time, switch_timeout;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
int ret = _SUCCESS;
if (rtw_tdls_is_chsw_allowed(padapter) == _FALSE) {
RTW_INFO("[TDLS] Ignore %s since channel switch is not allowed\n", __func__);
return _SUCCESS;
}
/* If we receive Unsolicited TDLS Channel Switch Response when channel switch is running, */
/* we will go back to base channel and terminate this channel switch procedure */
if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE) {
if (pmlmeext->cur_channel != rtw_get_oper_ch(padapter)) {
RTW_INFO("[TDLS] Rx unsolicited channel switch response\n");
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_BASE_CHNL);
goto exit;
}
}
ptr += prx_pkt_attrib->hdrlen + prx_pkt_attrib->iv_len + LLC_HEADER_SIZE + ETH_TYPE_LEN + PAYLOAD_TYPE_LEN;
parsing_length = ((union recv_frame *)precv_frame)->u.hdr.len
- prx_pkt_attrib->hdrlen
- prx_pkt_attrib->iv_len
- prx_pkt_attrib->icv_len
- LLC_HEADER_SIZE
- ETH_TYPE_LEN
- PAYLOAD_TYPE_LEN;
_rtw_memcpy(&status_code, ptr + 2, 2);
if (status_code != 0) {
RTW_INFO("[TDLS] %s status_code:%d\n", __func__, status_code);
pchsw_info->ch_sw_state &= ~(TDLS_CH_SW_INITIATOR_STATE);
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END);
ret = _FAIL;
goto exit;
}
/* Parsing information element */
for (j = FIXED_IE; j < parsing_length;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ptr + j);
switch (pIE->ElementID) {
case _LINK_ID_IE_:
break;
case _CH_SWITCH_TIMING_:
_rtw_memcpy(&switch_time, pIE->data, 2);
if (switch_time > ptdls_sta->ch_switch_time)
_rtw_memcpy(&ptdls_sta->ch_switch_time, &switch_time, 2);
_rtw_memcpy(&switch_timeout, pIE->data + 2, 2);
if (switch_timeout > ptdls_sta->ch_switch_timeout)
_rtw_memcpy(&ptdls_sta->ch_switch_timeout, &switch_timeout, 2);
break;
default:
break;
}
j += (pIE->Length + 2);
}
if ((pmlmeext->cur_channel == rtw_get_oper_ch(padapter)) &&
(pchsw_info->ch_sw_state & TDLS_WAIT_CH_RSP_STATE)) {
if (ATOMIC_READ(&pchsw_info->chsw_on) == _TRUE)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_TO_OFF_CHNL);
}
exit:
return ret;
}
#endif /* CONFIG_TDLS_CH_SW */
#ifdef CONFIG_WFD
void wfd_ie_tdls(_adapter *padapter, u8 *pframe, u32 *pktlen)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wifi_display_info *pwfd_info = padapter->tdlsinfo.wfd_info;
u8 wfdie[MAX_WFD_IE_LEN] = { 0x00 };
u32 wfdielen = 0;
u16 v16 = 0;
if (!hal_chk_wl_func(padapter, WL_FUNC_MIRACAST))
return;
/* WFD OUI */
wfdielen = 0;
wfdie[wfdielen++] = 0x50;
wfdie[wfdielen++] = 0x6F;
wfdie[wfdielen++] = 0x9A;
wfdie[wfdielen++] = 0x0A; /* WFA WFD v1.0 */
/*
* Commented by Albert 20110825
* According to the WFD Specification, the negotiation request frame should contain 3 WFD attributes
* 1. WFD Device Information
* 2. Associated BSSID ( Optional )
* 3. Local IP Adress ( Optional )
*/
/* WFD Device Information ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_DEVICE_INFO;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value1: */
/* WFD device information */
/* available for WFD session + Preferred TDLS + WSD ( WFD Service Discovery ) */
v16 = pwfd_info->wfd_device_type | WFD_DEVINFO_SESSION_AVAIL
| WFD_DEVINFO_PC_TDLS | WFD_DEVINFO_WSD;
RTW_PUT_BE16(wfdie + wfdielen, v16);
wfdielen += 2;
/* Value2: */
/* Session Management Control Port */
/* Default TCP port for RTSP messages is 554 */
RTW_PUT_BE16(wfdie + wfdielen, pwfd_info->tdls_rtsp_ctrlport);
wfdielen += 2;
/* Value3: */
/* WFD Device Maximum Throughput */
/* 300Mbps is the maximum throughput */
RTW_PUT_BE16(wfdie + wfdielen, 300);
wfdielen += 2;
/* Associated BSSID ATTR */
/* Type: */
wfdie[wfdielen++] = WFD_ATTR_ASSOC_BSSID;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0006);
wfdielen += 2;
/* Value: */
/* Associated BSSID */
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)
_rtw_memcpy(wfdie + wfdielen, &pmlmepriv->assoc_bssid[0], ETH_ALEN);
else
_rtw_memset(wfdie + wfdielen, 0x00, ETH_ALEN);
/* Local IP Address ATTR */
wfdie[wfdielen++] = WFD_ATTR_LOCAL_IP_ADDR;
/* Length: */
/* Note: In the WFD specification, the size of length field is 2. */
RTW_PUT_BE16(wfdie + wfdielen, 0x0005);
wfdielen += 2;
/* Version: */
/* 0x01: Version1;IPv4 */
wfdie[wfdielen++] = 0x01;
/* IPv4 Address */
_rtw_memcpy(wfdie + wfdielen, pwfd_info->ip_address, 4);
wfdielen += 4;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wfdielen, (unsigned char *) wfdie, pktlen);
}
#endif /* CONFIG_WFD */
void rtw_build_tdls_setup_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct pkt_attrib *pattrib = &pxmitframe->attrib;
int i = 0 ;
u32 time;
u8 *pframe_head;
/* SNonce */
if (pattrib->encrypt) {
for (i = 0; i < 8; i++) {
time = rtw_get_current_time();
_rtw_memcpy(&ptdls_sta->SNonce[4 * i], (u8 *)&time, 4);
}
}
pframe_head = pframe; /* For rtw_tdls_set_ht_cap() */
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
pframe = rtw_tdls_set_sup_ch(padapter, pframe, pattrib);
pframe = rtw_tdls_set_sup_reg_class(pframe, pattrib);
if (pattrib->encrypt)
pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
if (pattrib->encrypt) {
pframe = rtw_tdls_set_ftie(ptxmgmt
, pframe
, pattrib
, NULL
, ptdls_sta->SNonce);
pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
}
#ifdef CONFIG_80211N_HT
/* Sup_reg_classes(optional) */
if (pregistrypriv->ht_enable == _TRUE)
pframe = rtw_tdls_set_ht_cap(padapter, pframe_head, pattrib);
#endif
pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
#ifdef CONFIG_80211AC_VHT
if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
&& is_supported_vht(pregistrypriv->wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
) {
pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
pframe = rtw_tdls_set_vht_cap(padapter, pframe, pattrib);
}
#endif
#ifdef CONFIG_WFD
if (padapter->wdinfo.wfd_tdls_enable == 1)
wfd_ie_tdls(padapter, pframe, &(pattrib->pktlen));
#endif
}
void rtw_build_tdls_setup_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 k; /* for random ANonce */
u8 *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL;
u32 time;
u8 *pframe_head;
if (pattrib->encrypt) {
for (k = 0; k < 8; k++) {
time = rtw_get_current_time();
_rtw_memcpy(&ptdls_sta->ANonce[4 * k], (u8 *)&time, 4);
}
}
pframe_head = pframe;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
if (ptxmgmt->status_code != 0) {
RTW_INFO("[%s] status_code:%04x\n", __FUNCTION__, ptxmgmt->status_code);
return;
}
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
pframe = rtw_tdls_set_sup_ch(padapter, pframe, pattrib);
pframe = rtw_tdls_set_sup_reg_class(pframe, pattrib);
if (pattrib->encrypt) {
prsnie = pframe;
pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _FALSE, ptdls_sta);
}
pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
if (pattrib->encrypt) {
if (rtw_tdls_is_driver_setup(padapter) == _TRUE)
wpa_tdls_generate_tpk(padapter, ptdls_sta);
pftie = pframe;
pftie_mic = pframe + 4;
pframe = rtw_tdls_set_ftie(ptxmgmt
, pframe
, pattrib
, ptdls_sta->ANonce
, ptdls_sta->SNonce);
ptimeout_ie = pframe;
pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _FALSE, ptdls_sta);
}
#ifdef CONFIG_80211N_HT
/* Sup_reg_classes(optional) */
if (pregistrypriv->ht_enable == _TRUE)
pframe = rtw_tdls_set_ht_cap(padapter, pframe_head, pattrib);
#endif
pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
plinkid_ie = pframe;
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
/* Fill FTIE mic */
if (pattrib->encrypt && rtw_tdls_is_driver_setup(padapter) == _TRUE)
wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 2, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
if ((pregistrypriv->wmm_enable == _TRUE) || (padapter->mlmepriv.htpriv.ht_option == _TRUE))
pframe = rtw_tdls_set_qos_cap(pframe, pattrib);
#ifdef CONFIG_80211AC_VHT
if ((padapter->mlmepriv.htpriv.ht_option == _TRUE) && (pmlmeext->cur_channel > 14)
&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
&& is_supported_vht(pregistrypriv->wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
) {
pframe = rtw_tdls_set_aid(padapter, pframe, pattrib);
pframe = rtw_tdls_set_vht_cap(padapter, pframe, pattrib);
pframe = rtw_tdls_set_vht_op_mode_notify(padapter, pframe, pattrib, pmlmeext->cur_bwmode);
}
#endif
#ifdef CONFIG_WFD
if (padapter->wdinfo.wfd_tdls_enable)
wfd_ie_tdls(padapter, pframe, &(pattrib->pktlen));
#endif
}
void rtw_build_tdls_setup_cfm_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct pkt_attrib *pattrib = &pxmitframe->attrib;
unsigned int ie_len;
unsigned char *p;
u8 wmm_param_ele[24] = {0};
u8 *pftie = NULL, *ptimeout_ie = NULL, *plinkid_ie = NULL, *prsnie = NULL, *pftie_mic = NULL;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
if (ptxmgmt->status_code != 0)
return;
if (pattrib->encrypt) {
prsnie = pframe;
pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
}
if (pattrib->encrypt) {
pftie = pframe;
pftie_mic = pframe + 4;
pframe = rtw_tdls_set_ftie(ptxmgmt
, pframe
, pattrib
, ptdls_sta->ANonce
, ptdls_sta->SNonce);
ptimeout_ie = pframe;
pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, ptdls_sta);
if (rtw_tdls_is_driver_setup(padapter) == _TRUE) {
/* Start TPK timer */
ptdls_sta->TPK_count = 0;
_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
}
}
/* HT operation; todo */
plinkid_ie = pframe;
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
wpa_tdls_ftie_mic(ptdls_sta->tpk.kck, 3, plinkid_ie, prsnie, ptimeout_ie, pftie, pftie_mic);
if (ptdls_sta->qos_option == _TRUE)
pframe = rtw_tdls_set_wmm_params(padapter, pframe, pattrib);
#ifdef CONFIG_80211AC_VHT
if ((padapter->mlmepriv.htpriv.ht_option == _TRUE)
&& (ptdls_sta->vhtpriv.vht_option == _TRUE) && (pmlmeext->cur_channel > 14)
&& REGSTY_IS_11AC_ENABLE(pregistrypriv)
&& is_supported_vht(pregistrypriv->wireless_mode)
&& (!rfctl->country_ent || COUNTRY_CHPLAN_EN_11AC(rfctl->country_ent))
) {
pframe = rtw_tdls_set_vht_operation(padapter, pframe, pattrib, pmlmeext->cur_channel);
pframe = rtw_tdls_set_vht_op_mode_notify(padapter, pframe, pattrib, pmlmeext->cur_bwmode);
}
#endif
}
void rtw_build_tdls_teardown_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 *pftie = NULL, *pftie_mic = NULL, *plinkid_ie = NULL;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
if (pattrib->encrypt) {
pftie = pframe;
pftie_mic = pframe + 4;
pframe = rtw_tdls_set_ftie(ptxmgmt
, pframe
, pattrib
, ptdls_sta->ANonce
, ptdls_sta->SNonce);
}
plinkid_ie = pframe;
if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
if (pattrib->encrypt && (rtw_tdls_is_driver_setup(padapter) == _TRUE))
wpa_tdls_teardown_ftie_mic(ptdls_sta->tpk.kck, plinkid_ie, ptxmgmt->status_code, 1, 4, pftie, pftie_mic);
}
void rtw_build_tdls_dis_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
}
void rtw_build_tdls_dis_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, u8 privacy)
{
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 *pframe_head, pktlen_index;
pktlen_index = pattrib->pktlen;
pframe_head = pframe;
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_PUBLIC);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_capability(padapter, pframe, pattrib);
pframe = rtw_tdls_set_supported_rate(padapter, pframe, pattrib);
pframe = rtw_tdls_set_sup_ch(padapter, pframe, pattrib);
if (privacy)
pframe = rtw_tdls_set_rsnie(ptxmgmt, pframe, pattrib, _TRUE, NULL);
pframe = rtw_tdls_set_ext_cap(pframe, pattrib);
if (privacy) {
pframe = rtw_tdls_set_ftie(ptxmgmt, pframe, pattrib, NULL, NULL);
pframe = rtw_tdls_set_timeout_interval(ptxmgmt, pframe, pattrib, _TRUE, NULL);
}
#ifdef CONFIG_80211N_HT
if (pregistrypriv->ht_enable == _TRUE)
pframe = rtw_tdls_set_ht_cap(padapter, pframe_head - pktlen_index, pattrib);
#endif
pframe = rtw_tdls_set_bss_coexist(padapter, pframe, pattrib);
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
}
void rtw_build_tdls_peer_traffic_indication_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 AC_queue = 0;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
/* PTI control */
/* PU buffer status */
if (ptdls_sta->uapsd_bk & BIT(1))
AC_queue = BIT(0);
if (ptdls_sta->uapsd_be & BIT(1))
AC_queue = BIT(1);
if (ptdls_sta->uapsd_vi & BIT(1))
AC_queue = BIT(2);
if (ptdls_sta->uapsd_vo & BIT(1))
AC_queue = BIT(3);
pframe = rtw_set_ie(pframe, _PTI_BUFFER_STATUS_, 1, &AC_queue, &(pattrib->pktlen));
}
void rtw_build_tdls_peer_traffic_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_dialog(pframe, pattrib, ptxmgmt);
if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
}
#ifdef CONFIG_TDLS_CH_SW
void rtw_build_tdls_ch_switch_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct sta_priv *pstapriv = &padapter->stapriv;
u16 switch_time = TDLS_CH_SWITCH_TIME * 1000, switch_timeout = TDLS_CH_SWITCH_TIMEOUT * 1000;
ptdls_sta->ch_switch_time = switch_time;
ptdls_sta->ch_switch_timeout = switch_timeout;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_target_ch(padapter, pframe, pattrib);
pframe = rtw_tdls_set_reg_class(pframe, pattrib, ptdls_sta);
if (ptdlsinfo->chsw_info.ch_offset != HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
switch (ptdlsinfo->chsw_info.ch_offset) {
case HAL_PRIME_CHNL_OFFSET_LOWER:
pframe = rtw_tdls_set_second_channel_offset(pframe, pattrib, SCA);
break;
case HAL_PRIME_CHNL_OFFSET_UPPER:
pframe = rtw_tdls_set_second_channel_offset(pframe, pattrib, SCB);
break;
}
}
if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
}
void rtw_build_tdls_ch_switch_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt, struct sta_info *ptdls_sta)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct sta_priv *pstapriv = &padapter->stapriv;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_tdls_set_category(pframe, pattrib, RTW_WLAN_CATEGORY_TDLS);
pframe = rtw_tdls_set_action(pframe, pattrib, ptxmgmt);
pframe = rtw_tdls_set_status_code(pframe, pattrib, ptxmgmt);
if (ptdls_sta->tdls_sta_state & TDLS_INITIATOR_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _FALSE);
else if (ptdls_sta->tdls_sta_state & TDLS_RESPONDER_STATE)
pframe = rtw_tdls_set_linkid(padapter, pframe, pattrib, _TRUE);
pframe = rtw_tdls_set_ch_sw(pframe, pattrib, ptdls_sta);
}
#endif
#ifdef CONFIG_WFD
void rtw_build_tunneled_probe_req_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe)
{
u8 i;
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct wifidirect_info *pwdinfo;
u8 category = RTW_WLAN_CATEGORY_P2P;
u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a};
u8 probe_req = 4;
u8 wfdielen = 0;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 3, WFA_OUI, &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(probe_req), &(pattrib->pktlen));
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
pwdinfo = &iface->wdinfo;
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
wfdielen = build_probe_req_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
}
}
}
}
void rtw_build_tunneled_probe_rsp_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe)
{
u8 i;
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct wifidirect_info *pwdinfo;
u8 category = RTW_WLAN_CATEGORY_P2P;
u8 WFA_OUI[3] = { 0x50, 0x6f, 0x9a};
u8 probe_rsp = 5;
u8 wfdielen = 0;
pframe = rtw_tdls_set_payload_type(pframe, pattrib);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 3, WFA_OUI, &(pattrib->pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(probe_rsp), &(pattrib->pktlen));
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
pwdinfo = &iface->wdinfo;
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)) {
wfdielen = build_probe_resp_wfd_ie(pwdinfo, pframe, 1);
pframe += wfdielen;
pattrib->pktlen += wfdielen;
}
}
}
}
#endif /* CONFIG_WFD */
void _tdls_tpk_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
struct tdls_txmgmt txmgmt;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
ptdls_sta->TPK_count++;
/* TPK_timer expired in a second */
/* Retry timer should set at least 301 sec. */
if (ptdls_sta->TPK_count >= (ptdls_sta->TDLS_PeerKey_Lifetime - 3)) {
RTW_INFO("[TDLS] %s, Re-Setup TDLS link with "MAC_FMT" since TPK lifetime expires!\n",
__FUNCTION__, MAC_ARG(ptdls_sta->cmn.mac_addr));
ptdls_sta->TPK_count = 0;
_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
issue_tdls_setup_req(ptdls_sta->padapter, &txmgmt, _FALSE);
}
_set_timer(&ptdls_sta->TPK_timer, ONE_SEC);
}
#ifdef CONFIG_TDLS_CH_SW
void _tdls_ch_switch_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
_adapter *padapter = ptdls_sta->padapter;
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END_TO_BASE_CHNL);
RTW_INFO("[TDLS] %s, can't get traffic from op_ch:%d\n", __func__, rtw_get_oper_ch(padapter));
}
void _tdls_delay_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
_adapter *padapter = ptdls_sta->padapter;
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
RTW_INFO("[TDLS] %s, op_ch:%d, tdls_state:0x%08x\n", __func__, rtw_get_oper_ch(padapter), ptdls_sta->tdls_sta_state);
pchsw_info->delay_switch_back = _TRUE;
}
void _tdls_stay_on_base_chnl_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
_adapter *padapter = ptdls_sta->padapter;
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
if (ptdls_sta != NULL) {
issue_tdls_ch_switch_req(padapter, ptdls_sta);
pchsw_info->ch_sw_state |= TDLS_WAIT_CH_RSP_STATE;
}
}
void _tdls_ch_switch_monitor_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
_adapter *padapter = ptdls_sta->padapter;
struct tdls_ch_switch *pchsw_info = &padapter->tdlsinfo.chsw_info;
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_CH_SW_END);
RTW_INFO("[TDLS] %s, does not receive ch sw req\n", __func__);
}
#endif
void _tdls_handshake_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
_adapter *padapter = NULL;
struct tdls_txmgmt txmgmt;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
txmgmt.status_code = _RSON_TDLS_TEAR_UN_RSN_;
if (ptdls_sta != NULL) {
padapter = ptdls_sta->padapter;
RTW_INFO("[TDLS] Handshake time out\n");
if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA);
else
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA_LOCALLY);
}
}
void _tdls_pti_timer_hdl(void *FunctionContext)
{
struct sta_info *ptdls_sta = (struct sta_info *)FunctionContext;
_adapter *padapter = NULL;
struct tdls_txmgmt txmgmt;
_rtw_memset(&txmgmt, 0x00, sizeof(struct tdls_txmgmt));
_rtw_memcpy(txmgmt.peer, ptdls_sta->cmn.mac_addr, ETH_ALEN);
txmgmt.status_code = _RSON_TDLS_TEAR_TOOFAR_;
if (ptdls_sta != NULL) {
padapter = ptdls_sta->padapter;
if (ptdls_sta->tdls_sta_state & TDLS_WAIT_PTR_STATE) {
RTW_INFO("[TDLS] Doesn't receive PTR from peer dev:"MAC_FMT"; "
"Send TDLS Tear Down\n", MAC_ARG(ptdls_sta->cmn.mac_addr));
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_TEARDOWN_STA);
}
}
}
void rtw_init_tdls_timer(_adapter *padapter, struct sta_info *psta)
{
psta->padapter = padapter;
rtw_init_timer(&psta->TPK_timer, padapter, _tdls_tpk_timer_hdl, psta);
#ifdef CONFIG_TDLS_CH_SW
rtw_init_timer(&psta->ch_sw_timer, padapter, _tdls_ch_switch_timer_hdl, psta);
rtw_init_timer(&psta->delay_timer, padapter, _tdls_delay_timer_hdl, psta);
rtw_init_timer(&psta->stay_on_base_chnl_timer, padapter, _tdls_stay_on_base_chnl_timer_hdl, psta);
rtw_init_timer(&psta->ch_sw_monitor_timer, padapter, _tdls_ch_switch_monitor_timer_hdl, psta);
#endif
rtw_init_timer(&psta->handshake_timer, padapter, _tdls_handshake_timer_hdl, psta);
rtw_init_timer(&psta->pti_timer, padapter, _tdls_pti_timer_hdl, psta);
}
void rtw_cancel_tdls_timer(struct sta_info *psta)
{
_cancel_timer_ex(&psta->TPK_timer);
#ifdef CONFIG_TDLS_CH_SW
_cancel_timer_ex(&psta->ch_sw_timer);
_cancel_timer_ex(&psta->delay_timer);
_cancel_timer_ex(&psta->stay_on_base_chnl_timer);
_cancel_timer_ex(&psta->ch_sw_monitor_timer);
#endif
_cancel_timer_ex(&psta->handshake_timer);
_cancel_timer_ex(&psta->pti_timer);
}
void rtw_tdls_teardown_pre_hdl(_adapter *padapter, struct sta_info *psta)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
struct sta_priv *pstapriv = &padapter->stapriv;
_irqL irqL;
rtw_cancel_tdls_timer(psta);
_enter_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
if (ptdlsinfo->sta_cnt != 0)
ptdlsinfo->sta_cnt--;
_exit_critical_bh(&(pstapriv->sta_hash_lock), &irqL);
if (ptdlsinfo->sta_cnt < MAX_ALLOWED_TDLS_STA_NUM) {
ptdlsinfo->sta_maximum = _FALSE;
_rtw_memset(&ptdlsinfo->ss_record, 0x00, sizeof(struct tdls_ss_record));
}
if (ptdlsinfo->sta_cnt == 0)
rtw_tdls_set_link_established(padapter, _FALSE);
else
RTW_INFO("Remain tdls sta:%02x\n", ptdlsinfo->sta_cnt);
}
void rtw_tdls_teardown_post_hdl(_adapter *padapter, struct sta_info *psta, u8 enqueue_cmd)
{
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
/* Clear cam */
rtw_clearstakey_cmd(padapter, psta, enqueue_cmd);
/* Update sta media status */
if (enqueue_cmd)
rtw_sta_media_status_rpt_cmd(padapter, psta, 0);
else
rtw_sta_media_status_rpt(padapter, psta, 0);
/* Set RCR if necessary */
if (ptdlsinfo->sta_cnt == 0) {
if (enqueue_cmd)
rtw_tdls_cmd(padapter, NULL, TDLS_RS_RCR);
else
rtw_hal_rcr_set_chk_bssid(padapter, MLME_TDLS_NOLINK);
}
/* Free tdls sta info */
rtw_free_stainfo(padapter, psta);
}
int rtw_tdls_is_driver_setup(_adapter *padapter)
{
return padapter->tdlsinfo.driver_setup;
}
const char *rtw_tdls_action_txt(enum TDLS_ACTION_FIELD action)
{
switch (action) {
case TDLS_SETUP_REQUEST:
return "TDLS_SETUP_REQUEST";
case TDLS_SETUP_RESPONSE:
return "TDLS_SETUP_RESPONSE";
case TDLS_SETUP_CONFIRM:
return "TDLS_SETUP_CONFIRM";
case TDLS_TEARDOWN:
return "TDLS_TEARDOWN";
case TDLS_PEER_TRAFFIC_INDICATION:
return "TDLS_PEER_TRAFFIC_INDICATION";
case TDLS_CHANNEL_SWITCH_REQUEST:
return "TDLS_CHANNEL_SWITCH_REQUEST";
case TDLS_CHANNEL_SWITCH_RESPONSE:
return "TDLS_CHANNEL_SWITCH_RESPONSE";
case TDLS_PEER_PSM_REQUEST:
return "TDLS_PEER_PSM_REQUEST";
case TDLS_PEER_PSM_RESPONSE:
return "TDLS_PEER_PSM_RESPONSE";
case TDLS_PEER_TRAFFIC_RESPONSE:
return "TDLS_PEER_TRAFFIC_RESPONSE";
case TDLS_DISCOVERY_REQUEST:
return "TDLS_DISCOVERY_REQUEST";
case TDLS_DISCOVERY_RESPONSE:
return "TDLS_DISCOVERY_RESPONSE";
default:
return "UNKNOWN";
}
}
#endif /* CONFIG_TDLS */
================================================
FILE: core/rtw_vht.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_VHT_C
#include
#include
#ifdef CONFIG_80211AC_VHT
const u16 _vht_max_mpdu_len[] = {
3895,
7991,
11454,
0,
};
const u8 _vht_sup_ch_width_set_to_bw_cap[] = {
BW_CAP_80M,
BW_CAP_80M | BW_CAP_160M,
BW_CAP_80M | BW_CAP_160M | BW_CAP_80_80M,
0,
};
const char *const _vht_sup_ch_width_set_str[] = {
"80MHz",
"160MHz",
"160MHz & 80+80MHz",
"BW-RSVD",
};
void dump_vht_cap_ie_content(void *sel, const u8 *buf, u32 buf_len)
{
if (buf_len != VHT_CAP_IE_LEN) {
RTW_PRINT_SEL(sel, "Invalid VHT capability IE len:%d != %d\n", buf_len, VHT_CAP_IE_LEN);
return;
}
RTW_PRINT_SEL(sel, "cap_info:%02x %02x %02x %02x: MAX_MPDU_LEN:%u %s%s%s%s%s RX-STBC:%u MAX_AMPDU_LEN:%u\n"
, *(buf), *(buf + 1), *(buf + 2), *(buf + 3)
, vht_max_mpdu_len(GET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(buf))
, vht_sup_ch_width_set_str(GET_VHT_CAPABILITY_ELE_CHL_WIDTH(buf))
, GET_VHT_CAPABILITY_ELE_RX_LDPC(buf) ? " RX-LDPC" : ""
, GET_VHT_CAPABILITY_ELE_SHORT_GI80M(buf) ? " SGI-80" : ""
, GET_VHT_CAPABILITY_ELE_SHORT_GI160M(buf) ? " SGI-160" : ""
, GET_VHT_CAPABILITY_ELE_TX_STBC(buf) ? " TX-STBC" : ""
, GET_VHT_CAPABILITY_ELE_RX_STBC(buf)
, VHT_MAX_AMPDU_LEN(GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(buf))
);
}
void dump_vht_cap_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *vht_cap_ie;
sint vht_cap_ielen;
vht_cap_ie = rtw_get_ie(ie, WLAN_EID_VHT_CAPABILITY, &vht_cap_ielen, ie_len);
if (!ie || vht_cap_ie != ie)
return;
dump_vht_cap_ie_content(sel, vht_cap_ie + 2, vht_cap_ielen);
}
const char *const _vht_op_ch_width_str[] = {
"20 or 40MHz",
"80MHz",
"160MHz",
"80+80MHz",
"BW-RSVD",
};
void dump_vht_op_ie_content(void *sel, const u8 *buf, u32 buf_len)
{
if (buf_len != VHT_OP_IE_LEN) {
RTW_PRINT_SEL(sel, "Invalid VHT operation IE len:%d != %d\n", buf_len, VHT_OP_IE_LEN);
return;
}
RTW_PRINT_SEL(sel, "%s, ch0:%u, ch1:%u\n"
, vht_op_ch_width_str(GET_VHT_OPERATION_ELE_CHL_WIDTH(buf))
, GET_VHT_OPERATION_ELE_CENTER_FREQ1(buf)
, GET_VHT_OPERATION_ELE_CENTER_FREQ2(buf)
);
}
void dump_vht_op_ie(void *sel, const u8 *ie, u32 ie_len)
{
const u8 *vht_op_ie;
sint vht_op_ielen;
vht_op_ie = rtw_get_ie(ie, WLAN_EID_VHT_OPERATION, &vht_op_ielen, ie_len);
if (!ie || vht_op_ie != ie)
return;
dump_vht_op_ie_content(sel, vht_op_ie + 2, vht_op_ielen);
}
/* 20/40/80, ShortGI, MCS Rate */
const u16 VHT_MCS_DATA_RATE[3][2][30] = {
{ {
13, 26, 39, 52, 78, 104, 117, 130, 156, 156,
26, 52, 78, 104, 156, 208, 234, 260, 312, 312,
39, 78, 117, 156, 234, 312, 351, 390, 468, 520
}, /* Long GI, 20MHz */
{
14, 29, 43, 58, 87, 116, 130, 144, 173, 173,
29, 58, 87, 116, 173, 231, 260, 289, 347, 347,
43, 87, 130, 173, 260, 347, 390, 433, 520, 578
}
}, /* Short GI, 20MHz */
{ {
27, 54, 81, 108, 162, 216, 243, 270, 324, 360,
54, 108, 162, 216, 324, 432, 486, 540, 648, 720,
81, 162, 243, 324, 486, 648, 729, 810, 972, 1080
}, /* Long GI, 40MHz */
{
30, 60, 90, 120, 180, 240, 270, 300, 360, 400,
60, 120, 180, 240, 360, 480, 540, 600, 720, 800,
90, 180, 270, 360, 540, 720, 810, 900, 1080, 1200
}
}, /* Short GI, 40MHz */
{ {
59, 117, 176, 234, 351, 468, 527, 585, 702, 780,
117, 234, 351, 468, 702, 936, 1053, 1170, 1404, 1560,
176, 351, 527, 702, 1053, 1404, 1580, 1755, 2106, 2340
}, /* Long GI, 80MHz */
{
65, 130, 195, 260, 390, 520, 585, 650, 780, 867,
130, 260, 390, 520, 780, 1040, 1170, 1300, 1560, 1734,
195, 390, 585, 780, 1170, 1560, 1755, 1950, 2340, 2600
}
} /* Short GI, 80MHz */
};
u8 rtw_get_vht_highest_rate(u8 *pvht_mcs_map)
{
u8 i, j;
u8 bit_map;
u8 vht_mcs_rate = 0;
for (i = 0; i < 2; i++) {
if (pvht_mcs_map[i] != 0xff) {
for (j = 0; j < 8; j += 2) {
bit_map = (pvht_mcs_map[i] >> j) & 3;
if (bit_map != 3)
vht_mcs_rate = MGN_VHT1SS_MCS7 + 10 * j / 2 + i * 40 + bit_map; /* VHT rate indications begin from 0x90 */
}
}
}
/* RTW_INFO("HighestVHTMCSRate is %x\n", vht_mcs_rate); */
return vht_mcs_rate;
}
u8 rtw_vht_mcsmap_to_nss(u8 *pvht_mcs_map)
{
u8 i, j;
u8 bit_map;
u8 nss = 0;
for (i = 0; i < 2; i++) {
if (pvht_mcs_map[i] != 0xff) {
for (j = 0; j < 8; j += 2) {
bit_map = (pvht_mcs_map[i] >> j) & 3;
if (bit_map != 3)
nss++;
}
}
}
/* RTW_INFO("%s : %dSS\n", __FUNCTION__, nss); */
return nss;
}
void rtw_vht_nss_to_mcsmap(u8 nss, u8 *target_mcs_map, u8 *cur_mcs_map)
{
u8 i, j;
u8 cur_rate, target_rate;
for (i = 0; i < 2; i++) {
target_mcs_map[i] = 0;
for (j = 0; j < 8; j += 2) {
cur_rate = (cur_mcs_map[i] >> j) & 3;
if (cur_rate == 3) /* 0x3 indicates not supported that num of SS */
target_rate = 3;
else if (nss <= ((j / 2) + i * 4))
target_rate = 3;
else
target_rate = cur_rate;
target_mcs_map[i] |= (target_rate << j);
}
}
/* RTW_INFO("%s : %dSS\n", __FUNCTION__, nss); */
}
u16 rtw_vht_mcs_to_data_rate(u8 bw, u8 short_GI, u8 vht_mcs_rate)
{
if (vht_mcs_rate > MGN_VHT3SS_MCS9)
vht_mcs_rate = MGN_VHT3SS_MCS9;
/* RTW_INFO("bw=%d, short_GI=%d, ((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)=%d\n", bw, short_GI, ((vht_mcs_rate - MGN_VHT1SS_MCS0)&0x3f)); */
return VHT_MCS_DATA_RATE[bw][short_GI][((vht_mcs_rate - MGN_VHT1SS_MCS0) & 0x3f)];
}
void rtw_vht_use_default_setting(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
BOOLEAN bHwLDPCSupport = _FALSE, bHwSTBCSupport = _FALSE;
#ifdef CONFIG_BEAMFORMING
BOOLEAN bHwSupportBeamformer = _FALSE, bHwSupportBeamformee = _FALSE;
u8 mu_bfer, mu_bfee;
#endif /* CONFIG_BEAMFORMING */
u8 rf_type = 0;
u8 tx_nss, rx_nss;
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
pvhtpriv->sgi_80m = TEST_FLAG(pregistrypriv->short_gi, BIT2) ? _TRUE : _FALSE;
/* LDPC support */
rtw_hal_get_def_var(padapter, HAL_DEF_RX_LDPC, (u8 *)&bHwLDPCSupport);
CLEAR_FLAGS(pvhtpriv->ldpc_cap);
if (bHwLDPCSupport) {
if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT0))
SET_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX);
}
rtw_hal_get_def_var(padapter, HAL_DEF_TX_LDPC, (u8 *)&bHwLDPCSupport);
if (bHwLDPCSupport) {
if (TEST_FLAG(pregistrypriv->ldpc_cap, BIT1))
SET_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX);
}
if (pvhtpriv->ldpc_cap)
RTW_INFO("[VHT] Support LDPC = 0x%02X\n", pvhtpriv->ldpc_cap);
/* STBC */
rtw_hal_get_def_var(padapter, HAL_DEF_TX_STBC, (u8 *)&bHwSTBCSupport);
CLEAR_FLAGS(pvhtpriv->stbc_cap);
if (bHwSTBCSupport) {
if (TEST_FLAG(pregistrypriv->stbc_cap, BIT1))
SET_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX);
}
rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)&bHwSTBCSupport);
if (bHwSTBCSupport) {
if (TEST_FLAG(pregistrypriv->stbc_cap, BIT0))
SET_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX);
}
if (pvhtpriv->stbc_cap)
RTW_INFO("[VHT] Support STBC = 0x%02X\n", pvhtpriv->stbc_cap);
/* Beamforming setting */
CLEAR_FLAGS(pvhtpriv->beamform_cap);
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
/* only enable beamforming in STA client mode */
if (MLME_IS_STA(padapter) && !MLME_IS_GC(padapter)
&& !MLME_IS_ADHOC(padapter)
&& !MLME_IS_MESH(padapter))
#endif
{
rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMER,
(u8 *)&bHwSupportBeamformer);
rtw_hal_get_def_var(padapter, HAL_DEF_EXPLICIT_BEAMFORMEE,
(u8 *)&bHwSupportBeamformee);
mu_bfer = _FALSE;
mu_bfee = _FALSE;
rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMER, &mu_bfer);
rtw_hal_get_def_var(padapter, HAL_DEF_VHT_MU_BEAMFORMEE, &mu_bfee);
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT0) && bHwSupportBeamformer) {
#ifdef CONFIG_CONCURRENT_MODE
if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
RTW_INFO("[VHT] CONCURRENT AP Support Beamformer\n");
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
&& (_TRUE == mu_bfer)) {
SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
RTW_INFO("[VHT] Support MU-MIMO AP\n");
}
} else
RTW_INFO("[VHT] CONCURRENT not AP ;not allow Support Beamformer\n");
#else
SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
RTW_INFO("[VHT] Support Beamformer\n");
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(2))
&& (_TRUE == mu_bfer)
&& ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)) {
SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
RTW_INFO("[VHT] Support MU-MIMO AP\n");
}
#endif
}
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT1) && bHwSupportBeamformee) {
SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
RTW_INFO("[VHT] Support Beamformee\n");
if (TEST_FLAG(pregistrypriv->beamform_cap, BIT(3))
&& (_TRUE == mu_bfee)
&& ((pmlmeinfo->state & 0x03) != WIFI_FW_AP_STATE)) {
SET_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
RTW_INFO("[VHT] Support MU-MIMO STA\n");
}
}
}
#endif /* CONFIG_BEAMFORMING */
pvhtpriv->ampdu_len = pregistrypriv->ampdu_factor;
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
rx_nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
/* for now, vhtpriv.vht_mcs_map comes from RX NSS */
rtw_vht_nss_to_mcsmap(rx_nss, pvhtpriv->vht_mcs_map, pregistrypriv->vht_rx_mcs_map);
pvhtpriv->vht_highest_rate = rtw_get_vht_highest_rate(pvhtpriv->vht_mcs_map);
}
u64 rtw_vht_mcs_map_to_bitmap(u8 *mcs_map, u8 nss)
{
u8 i, j, tmp;
u64 bitmap = 0;
u8 bits_nss = nss * 2;
for (i = j = 0; i < bits_nss; i += 2, j += 10) {
/* every two bits means single sptial stream */
tmp = (mcs_map[i / 8] >> i) & 3;
switch (tmp) {
case 2:
bitmap = bitmap | (0x03ff << j);
break;
case 1:
bitmap = bitmap | (0x01ff << j);
break;
case 0:
bitmap = bitmap | (0x00ff << j);
break;
default:
break;
}
}
RTW_INFO("vht_mcs_map=%02x %02x, nss=%u => bitmap=%016llx\n"
, mcs_map[0], mcs_map[1], nss, bitmap);
return bitmap;
}
#ifdef CONFIG_BEAMFORMING
void update_sta_vht_info_apmode_bf_cap(_adapter *padapter, struct sta_info *psta)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct vht_priv *pvhtpriv_ap = &pmlmepriv->vhtpriv;
struct vht_priv *pvhtpriv_sta = &psta->vhtpriv;
u16 cur_beamform_cap = 0;
/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
if (TEST_FLAG(pvhtpriv_ap->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) &&
GET_VHT_CAPABILITY_ELE_SU_BFEE(pvhtpriv_sta->vht_cap)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
/*Shift to BEAMFORMING_VHT_BEAMFORMER_STS_CAP*/
SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pvhtpriv_sta->vht_cap) << 8);
}
/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
if (TEST_FLAG(pvhtpriv_ap->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
GET_VHT_CAPABILITY_ELE_SU_BFER(pvhtpriv_sta->vht_cap)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
/*Shit to BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM*/
SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pvhtpriv_sta->vht_cap) << 12);
}
if (cur_beamform_cap)
RTW_INFO("Current STA(%d) VHT Beamforming Setting = %02X\n", psta->cmn.aid, cur_beamform_cap);
pvhtpriv_sta->beamform_cap = cur_beamform_cap;
psta->cmn.bf_info.vht_beamform_cap = cur_beamform_cap;
}
#endif
void update_sta_vht_info_apmode(_adapter *padapter, void *sta)
{
struct sta_info *psta = (struct sta_info *)sta;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct vht_priv *pvhtpriv_ap = &pmlmepriv->vhtpriv;
struct vht_priv *pvhtpriv_sta = &psta->vhtpriv;
u8 cur_ldpc_cap = 0, cur_stbc_cap = 0;
s8 bw_mode = -1;
u8 *pcap_mcs;
if (pvhtpriv_sta->vht_option == _FALSE)
return;
if (pvhtpriv_sta->op_present) {
switch (GET_VHT_OPERATION_ELE_CHL_WIDTH(pvhtpriv_sta->vht_op)) {
case 1: /* 80MHz */
case 2: /* 160MHz */
case 3: /* 80+80 */
bw_mode = CHANNEL_WIDTH_80; /* only support up to 80MHz for now */
break;
}
}
if (pvhtpriv_sta->notify_present)
bw_mode = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&pvhtpriv_sta->vht_op_mode_notify);
else if (MLME_IS_AP(padapter)) {
/* for VHT client without Operating Mode Notify IE; minimal 80MHz */
if (bw_mode < CHANNEL_WIDTH_80)
bw_mode = CHANNEL_WIDTH_80;
}
if (bw_mode != -1)
psta->cmn.bw_mode = bw_mode; /* update bw_mode only if get value from VHT IEs */
psta->cmn.ra_info.is_vht_enable = _TRUE;
/* B4 Rx LDPC */
if (TEST_FLAG(pvhtpriv_ap->ldpc_cap, LDPC_VHT_ENABLE_TX) &&
GET_VHT_CAPABILITY_ELE_RX_LDPC(pvhtpriv_sta->vht_cap)) {
SET_FLAG(cur_ldpc_cap, (LDPC_VHT_ENABLE_TX | LDPC_VHT_CAP_TX));
RTW_INFO("Current STA(%d) VHT LDPC = %02X\n", psta->cmn.aid, cur_ldpc_cap);
}
pvhtpriv_sta->ldpc_cap = cur_ldpc_cap;
if (psta->cmn.bw_mode > pmlmeext->cur_bwmode)
psta->cmn.bw_mode = pmlmeext->cur_bwmode;
if (psta->cmn.bw_mode == CHANNEL_WIDTH_80) {
/* B5 Short GI for 80 MHz */
pvhtpriv_sta->sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(pvhtpriv_sta->vht_cap) & pvhtpriv_ap->sgi_80m) ? _TRUE : _FALSE;
/* RTW_INFO("Current STA ShortGI80MHz = %d\n", pvhtpriv_sta->sgi_80m); */
} else if (psta->cmn.bw_mode >= CHANNEL_WIDTH_160) {
/* B5 Short GI for 80 MHz */
pvhtpriv_sta->sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI160M(pvhtpriv_sta->vht_cap) & pvhtpriv_ap->sgi_80m) ? _TRUE : _FALSE;
/* RTW_INFO("Current STA ShortGI160MHz = %d\n", pvhtpriv_sta->sgi_80m); */
}
/* B8 B9 B10 Rx STBC */
if (TEST_FLAG(pvhtpriv_ap->stbc_cap, STBC_VHT_ENABLE_TX) &&
GET_VHT_CAPABILITY_ELE_RX_STBC(pvhtpriv_sta->vht_cap)) {
SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));
RTW_INFO("Current STA(%d) VHT STBC = %02X\n", psta->cmn.aid, cur_stbc_cap);
}
pvhtpriv_sta->stbc_cap = cur_stbc_cap;
#ifdef CONFIG_BEAMFORMING
update_sta_vht_info_apmode_bf_cap(padapter, psta);
#endif
/* B23 B24 B25 Maximum A-MPDU Length Exponent */
pvhtpriv_sta->ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pvhtpriv_sta->vht_cap);
pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pvhtpriv_sta->vht_cap);
_rtw_memcpy(pvhtpriv_sta->vht_mcs_map, pcap_mcs, 2);
pvhtpriv_sta->vht_highest_rate = rtw_get_vht_highest_rate(pvhtpriv_sta->vht_mcs_map);
}
void update_hw_vht_param(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 ht_AMPDU_len;
ht_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
if (pvhtpriv->ampdu_len > ht_AMPDU_len)
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&pvhtpriv->ampdu_len));
}
#ifdef ROKU_PRIVATE
u8 VHT_get_ss_from_map(u8 *vht_mcs_map)
{
u8 i, j;
u8 ss = 0;
for (i = 0; i < 2; i++) {
if (vht_mcs_map[i] != 0xff) {
for (j = 0; j < 8; j += 2) {
if (((vht_mcs_map[i] >> j) & 0x03) == 0x03)
break;
ss++;
}
}
}
return ss;
}
void VHT_caps_handler_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv_infra_ap *pvhtpriv = &pmlmepriv->vhtpriv_infra_ap;
u8 cur_stbc_cap_infra_ap = 0;
u16 cur_beamform_cap_infra_ap = 0;
u8 *pcap_mcs;
u8 *pcap_mcs_tx;
u8 Rx_ss = 0, Tx_ss = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pIE == NULL)
return;
pmlmeinfo->ht_vht_received |= BIT(1);
pvhtpriv->ldpc_cap_infra_ap = GET_VHT_CAPABILITY_ELE_RX_LDPC(pIE->data);
if (GET_VHT_CAPABILITY_ELE_RX_STBC(pIE->data))
SET_FLAG(cur_stbc_cap_infra_ap, STBC_VHT_ENABLE_RX);
if (GET_VHT_CAPABILITY_ELE_TX_STBC(pIE->data))
SET_FLAG(cur_stbc_cap_infra_ap, STBC_VHT_ENABLE_TX);
pvhtpriv->stbc_cap_infra_ap = cur_stbc_cap_infra_ap;
/*store ap info for channel bandwidth*/
pvhtpriv->channel_width_infra_ap = GET_VHT_CAPABILITY_ELE_CHL_WIDTH(pIE->data);
/*check B11: SU Beamformer Capable and B12: SU Beamformee B19: MU Beamformer B20:MU Beamformee*/
if (GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data))
SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
if (GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data))
SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
if (GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data))
SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
if (GET_VHT_CAPABILITY_ELE_MU_BFEE(pIE->data))
SET_FLAG(cur_beamform_cap_infra_ap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
pvhtpriv->beamform_cap_infra_ap = cur_beamform_cap_infra_ap;
/*store information about vht_mcs_set*/
pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pIE->data);
pcap_mcs_tx = GET_VHT_CAPABILITY_ELE_TX_MCS(pIE->data);
_rtw_memcpy(pvhtpriv->vht_mcs_map_infra_ap, pcap_mcs, 2);
_rtw_memcpy(pvhtpriv->vht_mcs_map_tx_infra_ap, pcap_mcs_tx, 2);
Rx_ss = VHT_get_ss_from_map(pvhtpriv->vht_mcs_map_infra_ap);
Tx_ss = VHT_get_ss_from_map(pvhtpriv->vht_mcs_map_tx_infra_ap);
if (Rx_ss >= Tx_ss) {
pvhtpriv->number_of_streams_infra_ap = Rx_ss;
} else{
pvhtpriv->number_of_streams_infra_ap = Tx_ss;
}
}
#endif /* ROKU_PRIVATE */
void VHT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 cur_ldpc_cap = 0, cur_stbc_cap = 0, rf_type = RF_1T1R, tx_nss = 0;
u16 cur_beamform_cap = 0;
u8 *pcap_mcs;
if (pIE == NULL)
return;
if (pvhtpriv->vht_option == _FALSE)
return;
pmlmeinfo->VHT_enable = 1;
/* B4 Rx LDPC */
if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_TX) &&
GET_VHT_CAPABILITY_ELE_RX_LDPC(pIE->data)) {
SET_FLAG(cur_ldpc_cap, (LDPC_VHT_ENABLE_TX | LDPC_VHT_CAP_TX));
RTW_INFO("Current VHT LDPC Setting = %02X\n", cur_ldpc_cap);
}
pvhtpriv->ldpc_cap = cur_ldpc_cap;
/* B5 Short GI for 80 MHz */
pvhtpriv->sgi_80m = (GET_VHT_CAPABILITY_ELE_SHORT_GI80M(pIE->data) & pvhtpriv->sgi_80m) ? _TRUE : _FALSE;
/* RTW_INFO("Current ShortGI80MHz = %d\n", pvhtpriv->sgi_80m); */
/* B8 B9 B10 Rx STBC */
if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX) &&
GET_VHT_CAPABILITY_ELE_RX_STBC(pIE->data)) {
SET_FLAG(cur_stbc_cap, (STBC_VHT_ENABLE_TX | STBC_VHT_CAP_TX));
RTW_INFO("Current VHT STBC Setting = %02X\n", cur_stbc_cap);
}
pvhtpriv->stbc_cap = cur_stbc_cap;
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
/*
* B11 SU Beamformer Capable,
* the target supports Beamformer and we are Beamformee
*/
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)
&& GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
/* Shift to BEAMFORMING_VHT_BEAMFORMEE_STS_CAP */
SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pIE->data) << 8);
/*
* B19 MU Beamformer Capable,
* the target supports Beamformer and we are Beamformee
*/
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)
&& GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data))
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE);
}
/*
* B12 SU Beamformee Capable,
* the target supports Beamformee and we are Beamformer
*/
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)
&& GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
/* Shit to BEAMFORMING_VHT_BEAMFORMER_SOUND_DIM */
SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pIE->data) << 12);
/*
* B20 MU Beamformee Capable,
* the target supports Beamformee and we are Beamformer
*/
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)
&& GET_VHT_CAPABILITY_ELE_MU_BFEE(pIE->data))
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE);
}
pvhtpriv->beamform_cap = cur_beamform_cap;
RTW_INFO("Current VHT Beamforming Setting=0x%04X\n", cur_beamform_cap);
#else /* !RTW_BEAMFORMING_VERSION_2 */
/* B11 SU Beamformer Capable, the target supports Beamformer and we are Beamformee */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE) &&
GET_VHT_CAPABILITY_ELE_SU_BFEE(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE);
/*Shift to BEAMFORMING_VHT_BEAMFORMER_STS_CAP*/
SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFEE_STS_CAP(pIE->data) << 8);
}
/* B12 SU Beamformee Capable, the target supports Beamformee and we are Beamformer */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE) &&
GET_VHT_CAPABILITY_ELE_SU_BFER(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE);
/*Shit to BEAMFORMING_VHT_BEAMFORMEE_SOUND_DIM*/
SET_FLAG(cur_beamform_cap, GET_VHT_CAPABILITY_ELE_SU_BFER_SOUND_DIM_NUM(pIE->data) << 12);
}
pvhtpriv->beamform_cap = cur_beamform_cap;
if (cur_beamform_cap)
RTW_INFO("Current VHT Beamforming Setting = %02X\n", cur_beamform_cap);
#endif /* !RTW_BEAMFORMING_VERSION_2 */
#endif /* CONFIG_BEAMFORMING */
/* B23 B24 B25 Maximum A-MPDU Length Exponent */
pvhtpriv->ampdu_len = GET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pIE->data);
pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pIE->data);
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
rtw_vht_nss_to_mcsmap(tx_nss, pvhtpriv->vht_mcs_map, pcap_mcs);
pvhtpriv->vht_highest_rate = rtw_get_vht_highest_rate(pvhtpriv->vht_mcs_map);
}
void VHT_operation_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
if (pIE == NULL)
return;
if (pvhtpriv->vht_option == _FALSE)
return;
}
void rtw_process_vht_op_mode_notify(_adapter *padapter, u8 *pframe, void *sta)
{
struct sta_info *psta = (struct sta_info *)sta;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct registry_priv *regsty = adapter_to_regsty(padapter);
u8 target_bw;
u8 target_rxss, current_rxss;
u8 update_ra = _FALSE;
u8 tx_nss = 0, rf_type = RF_1T1R;
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
if (pvhtpriv->vht_option == _FALSE)
return;
target_bw = GET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(pframe);
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
target_rxss = rtw_min(tx_nss, (GET_VHT_OPERATING_MODE_FIELD_RX_NSS(pframe) + 1));
if (target_bw != psta->cmn.bw_mode) {
if (hal_is_bw_support(padapter, target_bw)
&& REGSTY_IS_BW_5G_SUPPORT(regsty, target_bw)
) {
update_ra = _TRUE;
psta->cmn.bw_mode = target_bw;
}
}
current_rxss = rtw_vht_mcsmap_to_nss(psta->vhtpriv.vht_mcs_map);
if (target_rxss != current_rxss) {
u8 vht_mcs_map[2] = {};
update_ra = _TRUE;
rtw_vht_nss_to_mcsmap(target_rxss, vht_mcs_map, psta->vhtpriv.vht_mcs_map);
_rtw_memcpy(psta->vhtpriv.vht_mcs_map, vht_mcs_map, 2);
rtw_hal_update_sta_ra_info(padapter, psta);
}
if (update_ra)
rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
}
u32 rtw_build_vht_operation_ie(_adapter *padapter, u8 *pbuf, u8 channel)
{
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
/* struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv; */
u8 ChnlWidth, center_freq, bw_mode;
u32 len = 0;
u8 operation[5];
_rtw_memset(operation, 0, 5);
bw_mode = REGSTY_BW_5G(pregistrypriv); /* TODO: control op bw with other info */
if (hal_chk_bw_cap(padapter, BW_CAP_80M | BW_CAP_160M)
&& REGSTY_BW_5G(pregistrypriv) >= CHANNEL_WIDTH_80
) {
center_freq = rtw_get_center_ch(channel, bw_mode, HAL_PRIME_CHNL_OFFSET_LOWER);
ChnlWidth = 1;
} else {
center_freq = 0;
ChnlWidth = 0;
}
SET_VHT_OPERATION_ELE_CHL_WIDTH(operation, ChnlWidth);
/* center frequency */
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(operation, center_freq);/* Todo: need to set correct center channel */
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(operation, 0);
_rtw_memcpy(operation + 3, pvhtpriv->vht_mcs_map, 2);
rtw_set_ie(pbuf, EID_VHTOperation, 5, operation, &len);
return len;
}
u32 rtw_build_vht_op_mode_notify_ie(_adapter *padapter, u8 *pbuf, u8 bw)
{
/* struct registry_priv *pregistrypriv = &padapter->registrypriv; */
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
u32 len = 0;
u8 opmode = 0;
u8 chnl_width, rx_nss;
chnl_width = bw;
rx_nss = rtw_vht_mcsmap_to_nss(pvhtpriv->vht_mcs_map);
SET_VHT_OPERATING_MODE_FIELD_CHNL_WIDTH(&opmode, chnl_width);
SET_VHT_OPERATING_MODE_FIELD_RX_NSS(&opmode, (rx_nss - 1));
SET_VHT_OPERATING_MODE_FIELD_RX_NSS_TYPE(&opmode, 0); /* Todo */
pvhtpriv->vht_op_mode_notify = opmode;
pbuf = rtw_set_ie(pbuf, EID_OpModeNotification, 1, &opmode, &len);
return len;
}
u32 rtw_build_vht_cap_ie(_adapter *padapter, u8 *pbuf)
{
u8 bw, rf_num, rx_stbc_nss = 0;
u16 HighestRate;
u8 *pcap, *pcap_mcs;
u32 len = 0;
u32 rx_packet_offset, max_recvbuf_sz;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
pcap = pvhtpriv->vht_cap;
_rtw_memset(pcap, 0, 32);
/* B0 B1 Maximum MPDU Length */
rtw_hal_get_def_var(padapter, HAL_DEF_RX_PACKET_OFFSET, &rx_packet_offset);
rtw_hal_get_def_var(padapter, HAL_DEF_MAX_RECVBUF_SZ, &max_recvbuf_sz);
RTW_DBG("%s, line%d, Available RX buf size = %d bytes\n", __FUNCTION__, __LINE__, max_recvbuf_sz - rx_packet_offset);
if ((max_recvbuf_sz - rx_packet_offset) >= 11454) {
SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 2);
RTW_INFO("%s, line%d, Set MAX MPDU len = 11454 bytes\n", __FUNCTION__, __LINE__);
} else if ((max_recvbuf_sz - rx_packet_offset) >= 7991) {
SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 1);
RTW_INFO("%s, line%d, Set MAX MPDU len = 7991 bytes\n", __FUNCTION__, __LINE__);
} else if ((max_recvbuf_sz - rx_packet_offset) >= 3895) {
SET_VHT_CAPABILITY_ELE_MAX_MPDU_LENGTH(pcap, 0);
RTW_INFO("%s, line%d, Set MAX MPDU len = 3895 bytes\n", __FUNCTION__, __LINE__);
} else
RTW_ERR("%s, line%d, Error!! Available RX buf size < 3895 bytes\n", __FUNCTION__, __LINE__);
/* B2 B3 Supported Channel Width Set */
if (hal_chk_bw_cap(padapter, BW_CAP_160M) && REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_160)) {
if (hal_chk_bw_cap(padapter, BW_CAP_80_80M) && REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_80_80))
SET_VHT_CAPABILITY_ELE_CHL_WIDTH(pcap, 2);
else
SET_VHT_CAPABILITY_ELE_CHL_WIDTH(pcap, 1);
} else
SET_VHT_CAPABILITY_ELE_CHL_WIDTH(pcap, 0);
/* B4 Rx LDPC */
if (TEST_FLAG(pvhtpriv->ldpc_cap, LDPC_VHT_ENABLE_RX)) {
SET_VHT_CAPABILITY_ELE_RX_LDPC(pcap, 1);
RTW_INFO("[VHT] Declare supporting RX LDPC\n");
}
/* B5 ShortGI for 80MHz */
SET_VHT_CAPABILITY_ELE_SHORT_GI80M(pcap, pvhtpriv->sgi_80m ? 1 : 0); /* We can receive Short GI of 80M */
if (pvhtpriv->sgi_80m)
RTW_INFO("[VHT] Declare supporting SGI 80MHz\n");
/* B6 ShortGI for 160MHz */
/* SET_VHT_CAPABILITY_ELE_SHORT_GI160M(pcap, pvhtpriv->sgi_80m? 1 : 0); */
/* B7 Tx STBC */
if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_TX)) {
SET_VHT_CAPABILITY_ELE_TX_STBC(pcap, 1);
RTW_INFO("[VHT] Declare supporting TX STBC\n");
}
/* B8 B9 B10 Rx STBC */
if (TEST_FLAG(pvhtpriv->stbc_cap, STBC_VHT_ENABLE_RX)) {
rtw_hal_get_def_var(padapter, HAL_DEF_RX_STBC, (u8 *)(&rx_stbc_nss));
SET_VHT_CAPABILITY_ELE_RX_STBC(pcap, rx_stbc_nss);
RTW_INFO("[VHT] Declare supporting RX STBC = %d\n", rx_stbc_nss);
}
#ifdef CONFIG_BEAMFORMING
/* B11 SU Beamformer Capable */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMER_ENABLE)) {
SET_VHT_CAPABILITY_ELE_SU_BFER(pcap, 1);
RTW_INFO("[VHT] Declare supporting SU Bfer\n");
/* B16 17 18 Number of Sounding Dimensions */
rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMER_CAP, (u8 *)&rf_num);
SET_VHT_CAPABILITY_ELE_SOUNDING_DIMENSIONS(pcap, rf_num);
/* B19 MU Beamformer Capable */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_AP_ENABLE)) {
SET_VHT_CAPABILITY_ELE_MU_BFER(pcap, 1);
RTW_INFO("[VHT] Declare supporting MU Bfer\n");
}
}
/* B12 SU Beamformee Capable */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_BEAMFORMEE_ENABLE)) {
SET_VHT_CAPABILITY_ELE_SU_BFEE(pcap, 1);
RTW_INFO("[VHT] Declare supporting SU Bfee\n");
rtw_hal_get_def_var(padapter, HAL_DEF_BEAMFORMEE_CAP, (u8 *)&rf_num);
/* IOT action suggested by Yu Chen 2017/3/3 */
#ifdef CONFIG_80211AC_VHT
if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM) &&
!pvhtpriv->ap_is_mu_bfer)
rf_num = (rf_num >= 2 ? 2 : rf_num);
#endif
/* B13 14 15 Compressed Steering Number of Beamformer Antennas Supported */
SET_VHT_CAPABILITY_ELE_BFER_ANT_SUPP(pcap, rf_num);
/* B20 SU Beamformee Capable */
if (TEST_FLAG(pvhtpriv->beamform_cap, BEAMFORMING_VHT_MU_MIMO_STA_ENABLE)) {
SET_VHT_CAPABILITY_ELE_MU_BFEE(pcap, 1);
RTW_INFO("[VHT] Declare supporting MU Bfee\n");
}
}
#endif/*CONFIG_BEAMFORMING*/
/* B21 VHT TXOP PS */
SET_VHT_CAPABILITY_ELE_TXOP_PS(pcap, 0);
/* B22 +HTC-VHT Capable */
SET_VHT_CAPABILITY_ELE_HTC_VHT(pcap, 1);
/* B23 24 25 Maximum A-MPDU Length Exponent */
if (pregistrypriv->ampdu_factor != 0xFE)
SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pcap, pregistrypriv->ampdu_factor);
else
SET_VHT_CAPABILITY_ELE_MAX_RXAMPDU_FACTOR(pcap, 7);
/* B26 27 VHT Link Adaptation Capable */
SET_VHT_CAPABILITY_ELE_LINK_ADAPTION(pcap, 0);
pcap_mcs = GET_VHT_CAPABILITY_ELE_RX_MCS(pcap);
_rtw_memcpy(pcap_mcs, pvhtpriv->vht_mcs_map, 2);
pcap_mcs = GET_VHT_CAPABILITY_ELE_TX_MCS(pcap);
_rtw_memcpy(pcap_mcs, pvhtpriv->vht_mcs_map, 2);
/* find the largest bw supported by both registry and hal */
bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
HighestRate = VHT_MCS_DATA_RATE[bw][pvhtpriv->sgi_80m][((pvhtpriv->vht_highest_rate - MGN_VHT1SS_MCS0) & 0x3f)];
HighestRate = (HighestRate + 1) >> 1;
SET_VHT_CAPABILITY_ELE_MCS_RX_HIGHEST_RATE(pcap, HighestRate); /* indicate we support highest rx rate is 600Mbps. */
SET_VHT_CAPABILITY_ELE_MCS_TX_HIGHEST_RATE(pcap, HighestRate); /* indicate we support highest tx rate is 600Mbps. */
pbuf = rtw_set_ie(pbuf, EID_VHTCapability, 12, pcap, &len);
return len;
}
u32 rtw_restructure_vht_ie(_adapter *padapter, u8 *in_ie, u8 *out_ie, uint in_len, uint *pout_len)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
RT_CHANNEL_INFO *chset = rfctl->channel_set;
u32 ielen;
u8 max_bw;
u8 oper_ch, oper_bw = CHANNEL_WIDTH_20, oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
u8 *out_vht_op_ie, *ht_op_ie, *vht_cap_ie, *vht_op_ie;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
rtw_vht_use_default_setting(padapter);
ht_op_ie = rtw_get_ie(in_ie + 12, WLAN_EID_HT_OPERATION, &ielen, in_len - 12);
if (!ht_op_ie || ielen != HT_OP_IE_LEN)
goto exit;
vht_cap_ie = rtw_get_ie(in_ie + 12, EID_VHTCapability, &ielen, in_len - 12);
if (!vht_cap_ie || ielen != VHT_CAP_IE_LEN)
goto exit;
vht_op_ie = rtw_get_ie(in_ie + 12, EID_VHTOperation, &ielen, in_len - 12);
if (!vht_op_ie || ielen != VHT_OP_IE_LEN)
goto exit;
/* VHT Capabilities element */
*pout_len += rtw_build_vht_cap_ie(padapter, out_ie + *pout_len);
/* VHT Operation element */
out_vht_op_ie = out_ie + *pout_len;
rtw_set_ie(out_vht_op_ie, EID_VHTOperation, VHT_OP_IE_LEN, vht_op_ie + 2 , pout_len);
/* get primary channel from HT_OP_IE */
oper_ch = GET_HT_OP_ELE_PRI_CHL(ht_op_ie + 2);
/* find the largest bw supported by both registry and hal */
max_bw = hal_largest_bw(padapter, REGSTY_BW_5G(pregistrypriv));
if (max_bw >= CHANNEL_WIDTH_40) {
/* get bw offset form HT_OP_IE */
if (GET_HT_OP_ELE_STA_CHL_WIDTH(ht_op_ie + 2)) {
switch (GET_HT_OP_ELE_2ND_CHL_OFFSET(ht_op_ie + 2)) {
case SCA:
oper_bw = CHANNEL_WIDTH_40;
oper_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case SCB:
oper_bw = CHANNEL_WIDTH_40;
oper_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
}
}
if (oper_bw == CHANNEL_WIDTH_40) {
switch (GET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2)) {
case 1: /* 80MHz */
case 2: /* 160MHz */
case 3: /* 80+80 */
oper_bw = CHANNEL_WIDTH_80; /* only support up to 80MHz for now */
break;
}
oper_bw = rtw_min(oper_bw, max_bw);
/* try downgrage bw to fit in channel plan setting */
while (!rtw_chset_is_chbw_valid(chset, oper_ch, oper_bw, oper_offset)
|| (IS_DFS_SLAVE_WITH_RD(rfctl)
&& !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl))
&& rtw_chset_is_chbw_non_ocp(chset, oper_ch, oper_bw, oper_offset))
) {
oper_bw--;
if (oper_bw == CHANNEL_WIDTH_20) {
oper_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
break;
}
}
}
}
rtw_warn_on(!rtw_chset_is_chbw_valid(chset, oper_ch, oper_bw, oper_offset));
if (IS_DFS_SLAVE_WITH_RD(rfctl) && !rtw_odm_dfs_domain_unknown(rfctl_to_dvobj(rfctl)))
rtw_warn_on(rtw_chset_is_chbw_non_ocp(chset, oper_ch, oper_bw, oper_offset));
/* update VHT_OP_IE */
if (oper_bw < CHANNEL_WIDTH_80) {
SET_VHT_OPERATION_ELE_CHL_WIDTH(out_vht_op_ie + 2, 0);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(out_vht_op_ie + 2, 0);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(out_vht_op_ie + 2, 0);
} else if (oper_bw == CHANNEL_WIDTH_80) {
u8 cch = rtw_get_center_ch(oper_ch, oper_bw, oper_offset);
SET_VHT_OPERATION_ELE_CHL_WIDTH(out_vht_op_ie + 2, 1);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(out_vht_op_ie + 2, cch);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(out_vht_op_ie + 2, 0);
} else {
RTW_ERR(FUNC_ADPT_FMT" unsupported BW:%u\n", FUNC_ADPT_ARG(padapter), oper_bw);
rtw_warn_on(1);
}
/* Operating Mode Notification element */
*pout_len += rtw_build_vht_op_mode_notify_ie(padapter, out_ie + *pout_len, oper_bw);
pvhtpriv->vht_option = _TRUE;
exit:
return pvhtpriv->vht_option;
}
void VHTOnAssocRsp(_adapter *padapter)
{
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct vht_priv *pvhtpriv = &pmlmepriv->vhtpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 ht_AMPDU_len;
RTW_INFO("%s\n", __FUNCTION__);
if (!pmlmeinfo->HT_enable)
return;
if (!pmlmeinfo->VHT_enable)
return;
ht_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
if (pvhtpriv->ampdu_len > ht_AMPDU_len)
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&pvhtpriv->ampdu_len));
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MAX_TIME, (u8 *)(&pvhtpriv->vht_highest_rate));
}
void rtw_vht_ies_attach(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
u8 cap_len, operation_len;
uint len = 0;
sint ie_len = 0;
u8 *p = NULL;
p = rtw_get_ie(pnetwork->IEs + _BEACON_IE_OFFSET_, EID_VHTCapability, &ie_len,
(pnetwork->IELength - _BEACON_IE_OFFSET_));
if (p && ie_len > 0)
return;
rtw_vht_use_default_setting(padapter);
/* VHT Operation mode notifiy bit in Extended IE (127) */
SET_EXT_CAPABILITY_ELE_OP_MODE_NOTIF(pmlmepriv->ext_capab_ie_data, 1);
pmlmepriv->ext_capab_ie_len = 10;
rtw_set_ie(pnetwork->IEs + pnetwork->IELength, EID_EXTCapability, 8, pmlmepriv->ext_capab_ie_data, &len);
pnetwork->IELength += pmlmepriv->ext_capab_ie_len;
/* VHT Capabilities element */
cap_len = rtw_build_vht_cap_ie(padapter, pnetwork->IEs + pnetwork->IELength);
pnetwork->IELength += cap_len;
/* VHT Operation element */
operation_len = rtw_build_vht_operation_ie(padapter, pnetwork->IEs + pnetwork->IELength,
pnetwork->Configuration.DSConfig);
pnetwork->IELength += operation_len;
rtw_check_for_vht20(padapter, pnetwork->IEs + _BEACON_IE_OFFSET_, pnetwork->IELength - _BEACON_IE_OFFSET_);
pmlmepriv->vhtpriv.vht_option = _TRUE;
}
void rtw_vht_ies_detach(_adapter *padapter, WLAN_BSSID_EX *pnetwork)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
rtw_remove_bcn_ie(padapter, pnetwork, EID_EXTCapability);
rtw_remove_bcn_ie(padapter, pnetwork, EID_VHTCapability);
rtw_remove_bcn_ie(padapter, pnetwork, EID_VHTOperation);
pmlmepriv->vhtpriv.vht_option = _FALSE;
}
void rtw_check_for_vht20(_adapter *adapter, u8 *ies, int ies_len)
{
u8 ht_ch, ht_bw, ht_offset;
u8 vht_ch, vht_bw, vht_offset;
rtw_ies_get_chbw(ies, ies_len, &ht_ch, &ht_bw, &ht_offset, 1, 0);
rtw_ies_get_chbw(ies, ies_len, &vht_ch, &vht_bw, &vht_offset, 1, 1);
if (ht_bw == CHANNEL_WIDTH_20 && vht_bw >= CHANNEL_WIDTH_80) {
u8 *vht_op_ie;
int vht_op_ielen;
RTW_INFO(FUNC_ADPT_FMT" vht80 is not allowed without ht40\n", FUNC_ADPT_ARG(adapter));
vht_op_ie = rtw_get_ie(ies, EID_VHTOperation, &vht_op_ielen, ies_len);
if (vht_op_ie && vht_op_ielen) {
RTW_INFO(FUNC_ADPT_FMT" switch to vht20\n", FUNC_ADPT_ARG(adapter));
SET_VHT_OPERATION_ELE_CHL_WIDTH(vht_op_ie + 2, 0);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ1(vht_op_ie + 2, 0);
SET_VHT_OPERATION_ELE_CHL_CENTER_FREQ2(vht_op_ie + 2, 0);
}
}
}
#endif /* CONFIG_80211AC_VHT */
================================================
FILE: core/rtw_wapi.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifdef CONFIG_WAPI_SUPPORT
#include
#include
#include
#include
u32 wapi_debug_component =
/* WAPI_INIT |
* WAPI_API |
* WAPI_TX |
* WAPI_RX | */
WAPI_ERR ; /* always open err flags on */
void WapiFreeAllStaInfo(_adapter *padapter)
{
PRT_WAPI_T pWapiInfo;
PRT_WAPI_STA_INFO pWapiStaInfo;
PRT_WAPI_BKID pWapiBkid;
WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
pWapiInfo = &padapter->wapiInfo;
/* Pust to Idle List */
rtw_wapi_return_all_sta_info(padapter);
/* Sta Info List */
while (!list_empty(&(pWapiInfo->wapiSTAIdleList))) {
pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAIdleList.next, RT_WAPI_STA_INFO, list);
list_del_init(&pWapiStaInfo->list);
}
/* BKID List */
while (!list_empty(&(pWapiInfo->wapiBKIDIdleList))) {
pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDIdleList.next, RT_WAPI_BKID, list);
list_del_init(&pWapiBkid->list);
}
WAPI_TRACE(WAPI_INIT, "<=========== %s\n", __FUNCTION__);
return;
}
void WapiSetIE(_adapter *padapter)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
/* PRT_WAPI_BKID pWapiBkid; */
u16 protocolVer = 1;
u16 akmCnt = 1;
u16 suiteCnt = 1;
u16 capability = 0;
u8 OUI[3];
OUI[0] = 0x00;
OUI[1] = 0x14;
OUI[2] = 0x72;
pWapiInfo->wapiIELength = 0;
/* protocol version */
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &protocolVer, 2);
pWapiInfo->wapiIELength += 2;
/* akm */
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &akmCnt, 2);
pWapiInfo->wapiIELength += 2;
if (pWapiInfo->bWapiPSK) {
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
pWapiInfo->wapiIELength += 3;
pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x2;
pWapiInfo->wapiIELength += 1;
} else {
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
pWapiInfo->wapiIELength += 3;
pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
pWapiInfo->wapiIELength += 1;
}
/* usk */
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &suiteCnt, 2);
pWapiInfo->wapiIELength += 2;
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
pWapiInfo->wapiIELength += 3;
pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
pWapiInfo->wapiIELength += 1;
/* msk */
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, OUI, 3);
pWapiInfo->wapiIELength += 3;
pWapiInfo->wapiIE[pWapiInfo->wapiIELength] = 0x1;
pWapiInfo->wapiIELength += 1;
/* Capbility */
memcpy(pWapiInfo->wapiIE + pWapiInfo->wapiIELength, &capability, 2);
pWapiInfo->wapiIELength += 2;
}
/* PN1 > PN2, return 1,
* else return 0.
*/
u32 WapiComparePN(u8 *PN1, u8 *PN2)
{
char i;
if ((NULL == PN1) || (NULL == PN2))
return 1;
/* overflow case */
if ((PN2[15] - PN1[15]) & 0x80)
return 1;
for (i = 16; i > 0; i--) {
if (PN1[i - 1] == PN2[i - 1])
continue;
else if (PN1[i - 1] > PN2[i - 1])
return 1;
else
return 0;
}
return 0;
}
u8
WapiGetEntryForCamWrite(_adapter *padapter, u8 *pMacAddr, u8 KID, BOOLEAN IsMsk)
{
PRT_WAPI_T pWapiInfo = NULL;
/* PRT_WAPI_CAM_ENTRY pEntry=NULL; */
u8 i = 0;
u8 ret = 0xff;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
pWapiInfo = &padapter->wapiInfo;
/* exist? */
for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
if (pWapiInfo->wapiCamEntry[i].IsUsed
&& (_rtw_memcmp(pMacAddr, pWapiInfo->wapiCamEntry[i].PeerMacAddr, ETH_ALEN) == _TRUE)
&& pWapiInfo->wapiCamEntry[i].keyidx == KID
&& pWapiInfo->wapiCamEntry[i].type == IsMsk) {
ret = pWapiInfo->wapiCamEntry[i].entry_idx; /* cover it */
break;
}
}
if (i == WAPI_CAM_ENTRY_NUM) { /* not found */
for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
if (pWapiInfo->wapiCamEntry[i].IsUsed == 0) {
pWapiInfo->wapiCamEntry[i].IsUsed = 1;
pWapiInfo->wapiCamEntry[i].type = IsMsk;
pWapiInfo->wapiCamEntry[i].keyidx = KID;
_rtw_memcpy(pWapiInfo->wapiCamEntry[i].PeerMacAddr, pMacAddr, ETH_ALEN);
ret = pWapiInfo->wapiCamEntry[i].entry_idx;
break;
}
}
}
WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
return ret;
/*
if(RTIsListEmpty(&pWapiInfo->wapiCamIdleList)) {
return 0;
}
pEntry = (PRT_WAPI_CAM_ENTRY)RTRemoveHeadList(&pWapiInfo->wapiCamIdleList);
RTInsertTailList(&pWapiInfo->wapiCamUsedList, &pEntry->list);
return pEntry->entry_idx;*/
}
u8 WapiGetEntryForCamClear(_adapter *padapter, u8 *pPeerMac, u8 keyid, u8 IsMsk)
{
PRT_WAPI_T pWapiInfo = NULL;
u8 i = 0;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
pWapiInfo = &padapter->wapiInfo;
for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
if (pWapiInfo->wapiCamEntry[i].IsUsed
&& (_rtw_memcmp(pPeerMac, pWapiInfo->wapiCamEntry[i].PeerMacAddr, ETH_ALEN) == _TRUE)
&& pWapiInfo->wapiCamEntry[i].keyidx == keyid
&& pWapiInfo->wapiCamEntry[i].type == IsMsk) {
pWapiInfo->wapiCamEntry[i].IsUsed = 0;
pWapiInfo->wapiCamEntry[i].keyidx = 2;
_rtw_memset(pWapiInfo->wapiCamEntry[i].PeerMacAddr, 0, ETH_ALEN);
WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
return pWapiInfo->wapiCamEntry[i].entry_idx;
}
}
WAPI_TRACE(WAPI_API, "<====WapiGetReturnCamEntry(), No this cam entry.\n");
return 0xff;
/*
if(RTIsListEmpty(&pWapiInfo->wapiCamUsedList)) {
return FALSE;
}
pList = &pWapiInfo->wapiCamUsedList;
while(pList->Flink != &pWapiInfo->wapiCamUsedList)
{
pEntry = (PRT_WAPI_CAM_ENTRY)pList->Flink;
if(PlatformCompareMemory(pPeerMac,pEntry->PeerMacAddr, ETHER_ADDRLEN)== 0
&& keyid == pEntry->keyidx)
{
RTRemoveEntryList(pList);
RTInsertHeadList(&pWapiInfo->wapiCamIdleList, pList);
return pEntry->entry_idx;
}
pList = pList->Flink;
}
return 0;
*/
}
void
WapiResetAllCamEntry(_adapter *padapter)
{
PRT_WAPI_T pWapiInfo;
int i;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
pWapiInfo = &padapter->wapiInfo;
for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
_rtw_memset(pWapiInfo->wapiCamEntry[i].PeerMacAddr, 0, ETH_ALEN);
pWapiInfo->wapiCamEntry[i].IsUsed = 0;
pWapiInfo->wapiCamEntry[i].keyidx = 2; /* invalid */
pWapiInfo->wapiCamEntry[i].entry_idx = 4 + i * 2;
}
WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
return;
}
u8 WapiWriteOneCamEntry(
_adapter *padapter,
u8 *pMacAddr,
u8 KeyId,
u8 EntryId,
u8 EncAlg,
u8 bGroupKey,
u8 *pKey
)
{
u8 retVal = 0;
u16 usConfig = 0;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
if (EntryId >= 32) {
WAPI_TRACE(WAPI_ERR, "<=== CamAddOneEntry(): ulKeyId exceed!\n");
return retVal;
}
usConfig = usConfig | (0x01 << 15) | ((u16)(EncAlg) << 2) | (KeyId);
if (EncAlg == _SMS4_) {
if (bGroupKey == 1)
usConfig |= (0x01 << 6);
if ((EntryId % 2) == 1) /* ==0 sec key; == 1mic key */
usConfig |= (0x01 << 5);
}
write_cam(padapter, EntryId, usConfig, pMacAddr, pKey);
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
return 1;
}
void rtw_wapi_init(_adapter *padapter)
{
PRT_WAPI_T pWapiInfo;
int i;
WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
RT_ASSERT_RET(padapter);
if (!padapter->WapiSupport) {
WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
return;
}
pWapiInfo = &padapter->wapiInfo;
pWapiInfo->bWapiEnable = false;
/* Init BKID List */
INIT_LIST_HEAD(&pWapiInfo->wapiBKIDIdleList);
INIT_LIST_HEAD(&pWapiInfo->wapiBKIDStoreList);
for (i = 0; i < WAPI_MAX_BKID_NUM; i++)
list_add_tail(&pWapiInfo->wapiBKID[i].list, &pWapiInfo->wapiBKIDIdleList);
/* Init STA List */
INIT_LIST_HEAD(&pWapiInfo->wapiSTAIdleList);
INIT_LIST_HEAD(&pWapiInfo->wapiSTAUsedList);
for (i = 0; i < WAPI_MAX_STAINFO_NUM; i++)
list_add_tail(&pWapiInfo->wapiSta[i].list, &pWapiInfo->wapiSTAIdleList);
for (i = 0; i < WAPI_CAM_ENTRY_NUM; i++) {
pWapiInfo->wapiCamEntry[i].IsUsed = 0;
pWapiInfo->wapiCamEntry[i].keyidx = 2; /* invalid */
pWapiInfo->wapiCamEntry[i].entry_idx = 4 + i * 2;
}
WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
}
void rtw_wapi_free(_adapter *padapter)
{
WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
RT_ASSERT_RET(padapter);
if (!padapter->WapiSupport) {
WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
return;
}
WapiFreeAllStaInfo(padapter);
WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
}
void rtw_wapi_disable_tx(_adapter *padapter)
{
WAPI_TRACE(WAPI_INIT, "===========> %s\n", __FUNCTION__);
RT_ASSERT_RET(padapter);
if (!padapter->WapiSupport) {
WAPI_TRACE(WAPI_INIT, "<========== %s, WAPI not supported!\n", __FUNCTION__);
return;
}
padapter->wapiInfo.wapiTxMsk.bTxEnable = false;
padapter->wapiInfo.wapiTxMsk.bSet = false;
WAPI_TRACE(WAPI_INIT, "<========== %s\n", __FUNCTION__);
}
u8 rtw_wapi_is_wai_packet(_adapter *padapter, u8 *pkt_data)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
PRT_WAPI_STA_INFO pWapiSta = NULL;
u8 WaiPkt = 0, *pTaddr, bFind = false;
u8 Offset_TypeWAI = 0 ; /* (mac header len + llc length) */
WAPI_TRACE(WAPI_TX | WAPI_RX, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return 0;
}
Offset_TypeWAI = 24 + 6 ;
/* YJ,add,091103. Data frame may also have skb->data[30]=0x88 and skb->data[31]=0xb4. */
if ((pkt_data[1] & 0x40) != 0) {
/* RTW_INFO("data is privacy\n"); */
return 0;
}
pTaddr = get_addr2_ptr(pkt_data);
if (list_empty(&pWapiInfo->wapiSTAUsedList))
bFind = false;
else {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (_rtw_memcmp(pTaddr, pWapiSta->PeerMacAddr, 6) == _TRUE) {
bFind = true;
break;
}
}
}
WAPI_TRACE(WAPI_TX | WAPI_RX, "%s: bFind=%d pTaddr="MAC_FMT"\n", __FUNCTION__, bFind, MAC_ARG(pTaddr));
if (pkt_data[0] == WIFI_QOS_DATA_TYPE)
Offset_TypeWAI += 2;
/* 88b4? */
if ((pkt_data[Offset_TypeWAI] == 0x88) && (pkt_data[Offset_TypeWAI + 1] == 0xb4)) {
WaiPkt = pkt_data[Offset_TypeWAI + 5];
psecuritypriv->hw_decrypted = _TRUE;
} else
WAPI_TRACE(WAPI_TX | WAPI_RX, "%s(): non wai packet\n", __FUNCTION__);
WAPI_TRACE(WAPI_TX | WAPI_RX, "%s(): Recvd WAI frame. IsWAIPkt(%d)\n", __FUNCTION__, WaiPkt);
return WaiPkt;
}
void rtw_wapi_update_info(_adapter *padapter, union recv_frame *precv_frame)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
struct recv_frame_hdr *precv_hdr;
u8 *ptr;
u8 *pTA;
u8 *pRecvPN;
WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
precv_hdr = &precv_frame->u.hdr;
ptr = precv_hdr->rx_data;
if (precv_hdr->attrib.qos == 1)
precv_hdr->UserPriority = GetTid(ptr);
else
precv_hdr->UserPriority = 0;
pTA = get_addr2_ptr(ptr);
_rtw_memcpy((u8 *)precv_hdr->WapiSrcAddr, pTA, 6);
pRecvPN = ptr + precv_hdr->attrib.hdrlen + 2;
_rtw_memcpy((u8 *)precv_hdr->WapiTempPN, pRecvPN, 16);
WAPI_TRACE(WAPI_RX, "<========== %s\n", __FUNCTION__);
}
/****************************************************************************
TRUE-----------------Drop
FALSE---------------- handle
add to support WAPI to N-mode
*****************************************************************************/
u8 rtw_wapi_check_for_drop(
_adapter *padapter,
union recv_frame *precv_frame,
u8 *ehdr_ops
)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
u8 *pLastRecvPN = NULL;
u8 bFind = false;
PRT_WAPI_STA_INFO pWapiSta = NULL;
u8 bDrop = false;
struct recv_frame_hdr *precv_hdr = &precv_frame->u.hdr;
u8 WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
u8 WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
u8 *ptr = ehdr_ops;
int i;
WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return false;
}
if (precv_hdr->bIsWaiPacket != 0) {
if (precv_hdr->bIsWaiPacket == 0x8) {
RTW_INFO("rtw_wapi_check_for_drop: dump packet\n");
for (i = 0; i < 50; i++) {
RTW_INFO("%02X ", ptr[i]);
if ((i + 1) % 8 == 0)
RTW_INFO("\n");
}
RTW_INFO("\n rtw_wapi_check_for_drop: dump packet\n");
for (i = 0; i < 16; i++) {
if (ptr[i + 27] != 0)
break;
}
if (i == 16) {
WAPI_TRACE(WAPI_RX, "rtw_wapi_check_for_drop: drop with zero BKID\n");
return true;
} else
return false;
} else
return false;
}
if (list_empty(&pWapiInfo->wapiSTAUsedList))
bFind = false;
else {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (_rtw_memcmp(precv_hdr->WapiSrcAddr, pWapiSta->PeerMacAddr, ETH_ALEN) == _TRUE) {
bFind = true;
break;
}
}
}
WAPI_TRACE(WAPI_RX, "%s: bFind=%d prxb->WapiSrcAddr="MAC_FMT"\n", __FUNCTION__, bFind, MAC_ARG(precv_hdr->WapiSrcAddr));
if (bFind) {
if (IS_MCAST(precv_hdr->attrib.ra)) {
WAPI_TRACE(WAPI_RX, "rtw_wapi_check_for_drop: multicast case\n");
pLastRecvPN = pWapiSta->lastRxMulticastPN;
} else {
WAPI_TRACE(WAPI_RX, "rtw_wapi_check_for_drop: unicast case\n");
switch (precv_hdr->UserPriority) {
case 0:
case 3:
pLastRecvPN = pWapiSta->lastRxUnicastPNBEQueue;
break;
case 1:
case 2:
pLastRecvPN = pWapiSta->lastRxUnicastPNBKQueue;
break;
case 4:
case 5:
pLastRecvPN = pWapiSta->lastRxUnicastPNVIQueue;
break;
case 6:
case 7:
pLastRecvPN = pWapiSta->lastRxUnicastPNVOQueue;
break;
default:
WAPI_TRACE(WAPI_ERR, "%s: Unknown TID\n", __FUNCTION__);
break;
}
}
if (!WapiComparePN(precv_hdr->WapiTempPN, pLastRecvPN)) {
WAPI_TRACE(WAPI_RX, "%s: Equal PN!!\n", __FUNCTION__);
if (IS_MCAST(precv_hdr->attrib.ra))
_rtw_memcpy(pLastRecvPN, WapiAEMultiCastPNInitialValueSrc, 16);
else
_rtw_memcpy(pLastRecvPN, WapiAEPNInitialValueSrc, 16);
bDrop = true;
} else
_rtw_memcpy(pLastRecvPN, precv_hdr->WapiTempPN, 16);
}
WAPI_TRACE(WAPI_RX, "<========== %s\n", __FUNCTION__);
return bDrop;
}
void rtw_build_probe_resp_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
u8 WapiIELength = 0;
WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
return;
}
WapiSetIE(padapter);
WapiIELength = pWapiInfo->wapiIELength;
pframe[0] = _WAPI_IE_;
pframe[1] = WapiIELength;
_rtw_memcpy(pframe + 2, pWapiInfo->wapiIE, WapiIELength);
pframe += WapiIELength + 2;
pattrib->pktlen += WapiIELength + 2;
WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
}
void rtw_build_beacon_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
u8 WapiIELength = 0;
WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
return;
}
WapiSetIE(padapter);
WapiIELength = pWapiInfo->wapiIELength;
pframe[0] = _WAPI_IE_;
pframe[1] = WapiIELength;
_rtw_memcpy(pframe + 2, pWapiInfo->wapiIE, WapiIELength);
pframe += WapiIELength + 2;
pattrib->pktlen += WapiIELength + 2;
WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
}
void rtw_build_assoc_req_wapi_ie(_adapter *padapter, unsigned char *pframe, struct pkt_attrib *pattrib)
{
PRT_WAPI_BKID pWapiBKID;
u16 bkidNum;
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
u8 WapiIELength = 0;
WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported!\n", __FUNCTION__);
return;
}
WapiSetIE(padapter);
WapiIELength = pWapiInfo->wapiIELength;
bkidNum = 0;
if (!list_empty(&(pWapiInfo->wapiBKIDStoreList))) {
list_for_each_entry(pWapiBKID, &pWapiInfo->wapiBKIDStoreList, list) {
bkidNum++;
_rtw_memcpy(pWapiInfo->wapiIE + WapiIELength + 2, pWapiBKID->bkid, 16);
WapiIELength += 16;
}
}
_rtw_memcpy(pWapiInfo->wapiIE + WapiIELength, &bkidNum, 2);
WapiIELength += 2;
pframe[0] = _WAPI_IE_;
pframe[1] = WapiIELength;
_rtw_memcpy(pframe + 2, pWapiInfo->wapiIE, WapiIELength);
pframe += WapiIELength + 2;
pattrib->pktlen += WapiIELength + 2;
WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
}
void rtw_wapi_on_assoc_ok(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
PRT_WAPI_T pWapiInfo = &(padapter->wapiInfo);
PRT_WAPI_STA_INFO pWapiSta;
u8 WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
/* u8 WapiASUEPNInitialValueSrc[16] = {0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C,0x36,0x5C} ; */
u8 WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
WAPI_TRACE(WAPI_MLME, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
pWapiSta = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAIdleList.next, RT_WAPI_STA_INFO, list);
list_del_init(&pWapiSta->list);
list_add_tail(&pWapiSta->list, &pWapiInfo->wapiSTAUsedList);
_rtw_memcpy(pWapiSta->PeerMacAddr, padapter->mlmeextpriv.mlmext_info.network.MacAddress, 6);
_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
/* For chenk PN error with Qos Data after s3: add by ylb 20111114 */
_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
WAPI_TRACE(WAPI_MLME, "<========== %s\n", __FUNCTION__);
}
void rtw_wapi_return_one_sta_info(_adapter *padapter, u8 *MacAddr)
{
PRT_WAPI_T pWapiInfo;
PRT_WAPI_STA_INFO pWapiStaInfo = NULL;
PRT_WAPI_BKID pWapiBkid = NULL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
pWapiInfo = &padapter->wapiInfo;
WAPI_TRACE(WAPI_API, "==========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
while (!list_empty(&(pWapiInfo->wapiBKIDStoreList))) {
pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDStoreList.next, RT_WAPI_BKID, list);
list_del_init(&pWapiBkid->list);
_rtw_memset(pWapiBkid->bkid, 0, 16);
list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDIdleList);
}
}
WAPI_TRACE(WAPI_API, " %s: after clear bkid\n", __FUNCTION__);
/* Remove STA info */
if (list_empty(&(pWapiInfo->wapiSTAUsedList))) {
WAPI_TRACE(WAPI_API, " %s: wapiSTAUsedList is null\n", __FUNCTION__);
return;
} else {
WAPI_TRACE(WAPI_API, " %s: wapiSTAUsedList is not null\n", __FUNCTION__);
#if 0
pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry((pWapiInfo->wapiSTAUsedList.next), RT_WAPI_STA_INFO, list);
list_for_each_entry(pWapiStaInfo, &(pWapiInfo->wapiSTAUsedList), list) {
RTW_INFO("MAC Addr %02x-%02x-%02x-%02x-%02x-%02x\n", MacAddr[0], MacAddr[1], MacAddr[2], MacAddr[3], MacAddr[4], MacAddr[5]);
RTW_INFO("peer Addr %02x-%02x-%02x-%02x-%02x-%02x\n", pWapiStaInfo->PeerMacAddr[0], pWapiStaInfo->PeerMacAddr[1], pWapiStaInfo->PeerMacAddr[2], pWapiStaInfo->PeerMacAddr[3],
pWapiStaInfo->PeerMacAddr[4], pWapiStaInfo->PeerMacAddr[5]);
if (pWapiStaInfo == NULL) {
WAPI_TRACE(WAPI_API, " %s: pWapiStaInfo == NULL Case\n", __FUNCTION__);
return;
}
if (pWapiStaInfo->PeerMacAddr == NULL) {
WAPI_TRACE(WAPI_API, " %s: pWapiStaInfo->PeerMacAddr == NULL Case\n", __FUNCTION__);
return;
}
if (MacAddr == NULL) {
WAPI_TRACE(WAPI_API, " %s: MacAddr == NULL Case\n", __FUNCTION__);
return;
}
if (_rtw_memcmp(pWapiStaInfo->PeerMacAddr, MacAddr, ETH_ALEN) == _TRUE) {
pWapiStaInfo->bAuthenticateInProgress = false;
pWapiStaInfo->bSetkeyOk = false;
_rtw_memset(pWapiStaInfo->PeerMacAddr, 0, ETH_ALEN);
list_del_init(&pWapiStaInfo->list);
list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
break;
}
}
#endif
while (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAUsedList.next, RT_WAPI_STA_INFO, list);
RTW_INFO("peer Addr %02x-%02x-%02x-%02x-%02x-%02x\n", pWapiStaInfo->PeerMacAddr[0], pWapiStaInfo->PeerMacAddr[1], pWapiStaInfo->PeerMacAddr[2], pWapiStaInfo->PeerMacAddr[3],
pWapiStaInfo->PeerMacAddr[4], pWapiStaInfo->PeerMacAddr[5]);
list_del_init(&pWapiStaInfo->list);
memset(pWapiStaInfo->PeerMacAddr, 0, ETH_ALEN);
pWapiStaInfo->bSetkeyOk = 0;
list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
}
}
WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
return;
}
void rtw_wapi_return_all_sta_info(_adapter *padapter)
{
PRT_WAPI_T pWapiInfo;
PRT_WAPI_STA_INFO pWapiStaInfo;
PRT_WAPI_BKID pWapiBkid;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
pWapiInfo = &padapter->wapiInfo;
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
/* Sta Info List */
while (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
pWapiStaInfo = (PRT_WAPI_STA_INFO)list_entry(pWapiInfo->wapiSTAUsedList.next, RT_WAPI_STA_INFO, list);
list_del_init(&pWapiStaInfo->list);
memset(pWapiStaInfo->PeerMacAddr, 0, ETH_ALEN);
pWapiStaInfo->bSetkeyOk = 0;
list_add_tail(&pWapiStaInfo->list, &pWapiInfo->wapiSTAIdleList);
}
/* BKID List */
while (!list_empty(&(pWapiInfo->wapiBKIDStoreList))) {
pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDStoreList.next, RT_WAPI_BKID, list);
list_del_init(&pWapiBkid->list);
memset(pWapiBkid->bkid, 0, 16);
list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDIdleList);
}
WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
}
void CAM_empty_entry(
PADAPTER Adapter,
u8 ucIndex
)
{
rtw_hal_set_hwreg(Adapter, HW_VAR_CAM_EMPTY_ENTRY, (u8 *)(&ucIndex));
}
void rtw_wapi_clear_cam_entry(_adapter *padapter, u8 *pMacAddr)
{
u8 UcIndex = 0;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 0, 0);
if (UcIndex != 0xff) {
/* CAM_mark_invalid(Adapter, UcIndex); */
CAM_empty_entry(padapter, UcIndex);
}
UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 1, 0);
if (UcIndex != 0xff) {
/* CAM_mark_invalid(Adapter, UcIndex); */
CAM_empty_entry(padapter, UcIndex);
}
UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 0, 1);
if (UcIndex != 0xff) {
/* CAM_mark_invalid(Adapter, UcIndex); */
CAM_empty_entry(padapter, UcIndex);
}
UcIndex = WapiGetEntryForCamClear(padapter, pMacAddr, 1, 1);
if (UcIndex != 0xff) {
/* CAM_mark_invalid(padapter, UcIndex); */
CAM_empty_entry(padapter, UcIndex);
}
WAPI_TRACE(WAPI_API, "<========== %s\n", __FUNCTION__);
}
void rtw_wapi_clear_all_cam_entry(_adapter *padapter)
{
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
WAPI_TRACE(WAPI_MLME, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
invalidate_cam_all(padapter); /* is this ok? */
WapiResetAllCamEntry(padapter);
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
}
void rtw_wapi_set_key(_adapter *padapter, RT_WAPI_KEY *pWapiKey, RT_WAPI_STA_INFO *pWapiSta, u8 bGroupKey, u8 bUseDefaultKey)
{
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
u8 *pMacAddr = pWapiSta->PeerMacAddr;
u32 EntryId = 0;
BOOLEAN IsPairWise = false ;
u8 EncAlgo;
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
WAPI_TRACE(WAPI_API, "<========== %s, WAPI not supported or not enabled!\n", __FUNCTION__);
return;
}
EncAlgo = _SMS4_;
/* For Tx bc/mc pkt,use defualt key entry */
if (bUseDefaultKey) {
/* when WAPI update key, keyid will be 0 or 1 by turns. */
if (pWapiKey->keyId == 0)
EntryId = 0;
else
EntryId = 2;
} else {
/* tx/rx unicast pkt, or rx broadcast, find the key entry by peer's MacAddr */
EntryId = WapiGetEntryForCamWrite(padapter, pMacAddr, pWapiKey->keyId, bGroupKey);
}
if (EntryId == 0xff) {
WAPI_TRACE(WAPI_API, "===>No entry for WAPI setkey! !!\n");
return;
}
/* EntryId is also used to diff Sec key and Mic key */
/* Sec Key */
WapiWriteOneCamEntry(padapter,
pMacAddr,
pWapiKey->keyId, /* keyid */
EntryId, /* entry */
EncAlgo, /* type */
bGroupKey, /* pairwise or group key */
pWapiKey->dataKey);
/* MIC key */
WapiWriteOneCamEntry(padapter,
pMacAddr,
pWapiKey->keyId, /* keyid */
EntryId + 1, /* entry */
EncAlgo, /* type */
bGroupKey, /* pairwise or group key */
pWapiKey->micKey);
WAPI_TRACE(WAPI_API, "Set Wapi Key :KeyId:%d,EntryId:%d,PairwiseKey:%d.\n", pWapiKey->keyId, EntryId, !bGroupKey);
WAPI_TRACE(WAPI_API, "===========> %s\n", __FUNCTION__);
}
#if 0
/* YJ,test,091013 */
void wapi_test_set_key(struct _adapter *padapter, u8 *buf)
{
/*Data: keyType(1) + bTxEnable(1) + bAuthenticator(1) + bUpdate(1) + PeerAddr(6) + DataKey(16) + MicKey(16) + KeyId(1)*/
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
PRT_WAPI_BKID pWapiBkid;
PRT_WAPI_STA_INFO pWapiSta;
u8 data[43];
bool bTxEnable;
bool bUpdate;
bool bAuthenticator;
u8 PeerAddr[6];
u8 WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
u8 WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
u8 WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
WAPI_TRACE(WAPI_INIT, "===========>%s\n", __FUNCTION__);
if (!padapter->WapiSupport)
return;
copy_from_user(data, buf, 43);
bTxEnable = data[1];
bAuthenticator = data[2];
bUpdate = data[3];
memcpy(PeerAddr, data + 4, 6);
if (data[0] == 0x3) {
if (!list_empty(&(pWapiInfo->wapiBKIDIdleList))) {
pWapiBkid = (PRT_WAPI_BKID)list_entry(pWapiInfo->wapiBKIDIdleList.next, RT_WAPI_BKID, list);
list_del_init(&pWapiBkid->list);
memcpy(pWapiBkid->bkid, data + 10, 16);
WAPI_DATA(WAPI_INIT, "SetKey - BKID", pWapiBkid->bkid, 16);
list_add_tail(&pWapiBkid->list, &pWapiInfo->wapiBKIDStoreList);
}
} else {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (!memcmp(pWapiSta->PeerMacAddr, PeerAddr, 6)) {
pWapiSta->bAuthenticatorInUpdata = false;
switch (data[0]) {
case 1: /* usk */
if (bAuthenticator) { /* authenticator */
memcpy(pWapiSta->lastTxUnicastPN, WapiAEPNInitialValueSrc, 16);
if (!bUpdate) { /* first */
WAPI_TRACE(WAPI_INIT, "AE fisrt set usk\n");
pWapiSta->wapiUsk.bSet = true;
memcpy(pWapiSta->wapiUsk.dataKey, data + 10, 16);
memcpy(pWapiSta->wapiUsk.micKey, data + 26, 16);
pWapiSta->wapiUsk.keyId = *(data + 42);
pWapiSta->wapiUsk.bTxEnable = true;
WAPI_DATA(WAPI_INIT, "SetKey - AE USK Data Key", pWapiSta->wapiUsk.dataKey, 16);
WAPI_DATA(WAPI_INIT, "SetKey - AE USK Mic Key", pWapiSta->wapiUsk.micKey, 16);
} else { /* update */
WAPI_TRACE(WAPI_INIT, "AE update usk\n");
pWapiSta->wapiUskUpdate.bSet = true;
pWapiSta->bAuthenticatorInUpdata = true;
memcpy(pWapiSta->wapiUskUpdate.dataKey, data + 10, 16);
memcpy(pWapiSta->wapiUskUpdate.micKey, data + 26, 16);
memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPN, WapiASUEPNInitialValueSrc, 16);
pWapiSta->wapiUskUpdate.keyId = *(data + 42);
pWapiSta->wapiUskUpdate.bTxEnable = true;
}
} else {
if (!bUpdate) {
WAPI_TRACE(WAPI_INIT, "ASUE fisrt set usk\n");
if (bTxEnable) {
pWapiSta->wapiUsk.bTxEnable = true;
memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
} else {
pWapiSta->wapiUsk.bSet = true;
memcpy(pWapiSta->wapiUsk.dataKey, data + 10, 16);
memcpy(pWapiSta->wapiUsk.micKey, data + 26, 16);
pWapiSta->wapiUsk.keyId = *(data + 42);
pWapiSta->wapiUsk.bTxEnable = false;
}
} else {
WAPI_TRACE(WAPI_INIT, "ASUE update usk\n");
if (bTxEnable) {
pWapiSta->wapiUskUpdate.bTxEnable = true;
if (pWapiSta->wapiUskUpdate.bSet) {
memcpy(pWapiSta->wapiUsk.dataKey, pWapiSta->wapiUskUpdate.dataKey, 16);
memcpy(pWapiSta->wapiUsk.micKey, pWapiSta->wapiUskUpdate.micKey, 16);
pWapiSta->wapiUsk.keyId = pWapiSta->wapiUskUpdate.keyId;
memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiASUEPNInitialValueSrc, 16);
memcpy(pWapiSta->lastRxUnicastPN, WapiASUEPNInitialValueSrc, 16);
pWapiSta->wapiUskUpdate.bTxEnable = false;
pWapiSta->wapiUskUpdate.bSet = false;
}
memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
} else {
pWapiSta->wapiUskUpdate.bSet = true;
memcpy(pWapiSta->wapiUskUpdate.dataKey, data + 10, 16);
memcpy(pWapiSta->wapiUskUpdate.micKey, data + 26, 16);
pWapiSta->wapiUskUpdate.keyId = *(data + 42);
pWapiSta->wapiUskUpdate.bTxEnable = false;
}
}
}
break;
case 2: /* msk */
if (bAuthenticator) { /* authenticator */
pWapiInfo->wapiTxMsk.bSet = true;
memcpy(pWapiInfo->wapiTxMsk.dataKey, data + 10, 16);
memcpy(pWapiInfo->wapiTxMsk.micKey, data + 26, 16);
pWapiInfo->wapiTxMsk.keyId = *(data + 42);
pWapiInfo->wapiTxMsk.bTxEnable = true;
memcpy(pWapiInfo->lastTxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
if (!bUpdate) { /* first */
WAPI_TRACE(WAPI_INIT, "AE fisrt set msk\n");
if (!pWapiSta->bSetkeyOk)
pWapiSta->bSetkeyOk = true;
pWapiInfo->bFirstAuthentiateInProgress = false;
} else /* update */
WAPI_TRACE(WAPI_INIT, "AE update msk\n");
WAPI_DATA(WAPI_INIT, "SetKey - AE MSK Data Key", pWapiInfo->wapiTxMsk.dataKey, 16);
WAPI_DATA(WAPI_INIT, "SetKey - AE MSK Mic Key", pWapiInfo->wapiTxMsk.micKey, 16);
} else {
if (!bUpdate) {
WAPI_TRACE(WAPI_INIT, "ASUE fisrt set msk\n");
pWapiSta->wapiMsk.bSet = true;
memcpy(pWapiSta->wapiMsk.dataKey, data + 10, 16);
memcpy(pWapiSta->wapiMsk.micKey, data + 26, 16);
pWapiSta->wapiMsk.keyId = *(data + 42);
pWapiSta->wapiMsk.bTxEnable = false;
if (!pWapiSta->bSetkeyOk)
pWapiSta->bSetkeyOk = true;
pWapiInfo->bFirstAuthentiateInProgress = false;
WAPI_DATA(WAPI_INIT, "SetKey - ASUE MSK Data Key", pWapiSta->wapiMsk.dataKey, 16);
WAPI_DATA(WAPI_INIT, "SetKey - ASUE MSK Mic Key", pWapiSta->wapiMsk.micKey, 16);
} else {
WAPI_TRACE(WAPI_INIT, "ASUE update msk\n");
pWapiSta->wapiMskUpdate.bSet = true;
memcpy(pWapiSta->wapiMskUpdate.dataKey, data + 10, 16);
memcpy(pWapiSta->wapiMskUpdate.micKey, data + 26, 16);
pWapiSta->wapiMskUpdate.keyId = *(data + 42);
pWapiSta->wapiMskUpdate.bTxEnable = false;
}
}
break;
default:
WAPI_TRACE(WAPI_ERR, "Unknown Flag\n");
break;
}
}
}
}
WAPI_TRACE(WAPI_INIT, "<===========%s\n", __FUNCTION__);
}
void wapi_test_init(struct _adapter *padapter)
{
u8 keybuf[100];
u8 mac_addr[ETH_ALEN] = {0x00, 0xe0, 0x4c, 0x72, 0x04, 0x70};
u8 UskDataKey[16] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f};
u8 UskMicKey[16] = {0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f};
u8 UskId = 0;
u8 MskDataKey[16] = {0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f};
u8 MskMicKey[16] = {0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f};
u8 MskId = 0;
WAPI_TRACE(WAPI_INIT, "===========>%s\n", __FUNCTION__);
/* Enable Wapi */
WAPI_TRACE(WAPI_INIT, "%s: Enable wapi!!!!\n", __FUNCTION__);
padapter->wapiInfo.bWapiEnable = true;
padapter->pairwise_key_type = KEY_TYPE_SMS4;
ieee->group_key_type = KEY_TYPE_SMS4;
padapter->wapiInfo.extra_prefix_len = WAPI_EXT_LEN;
padapter->wapiInfo.extra_postfix_len = SMS4_MIC_LEN;
/* set usk */
WAPI_TRACE(WAPI_INIT, "%s: Set USK!!!!\n", __FUNCTION__);
memset(keybuf, 0, 100);
keybuf[0] = 1; /* set usk */
keybuf[1] = 1; /* enable tx */
keybuf[2] = 1; /* AE */
keybuf[3] = 0; /* not update */
memcpy(keybuf + 4, mac_addr, ETH_ALEN);
memcpy(keybuf + 10, UskDataKey, 16);
memcpy(keybuf + 26, UskMicKey, 16);
keybuf[42] = UskId;
wapi_test_set_key(padapter, keybuf);
memset(keybuf, 0, 100);
keybuf[0] = 1; /* set usk */
keybuf[1] = 1; /* enable tx */
keybuf[2] = 0; /* AE */
keybuf[3] = 0; /* not update */
memcpy(keybuf + 4, mac_addr, ETH_ALEN);
memcpy(keybuf + 10, UskDataKey, 16);
memcpy(keybuf + 26, UskMicKey, 16);
keybuf[42] = UskId;
wapi_test_set_key(padapter, keybuf);
/* set msk */
WAPI_TRACE(WAPI_INIT, "%s: Set MSK!!!!\n", __FUNCTION__);
memset(keybuf, 0, 100);
keybuf[0] = 2; /* set msk */
keybuf[1] = 1; /* Enable TX */
keybuf[2] = 1; /* AE */
keybuf[3] = 0; /* not update */
memcpy(keybuf + 4, mac_addr, ETH_ALEN);
memcpy(keybuf + 10, MskDataKey, 16);
memcpy(keybuf + 26, MskMicKey, 16);
keybuf[42] = MskId;
wapi_test_set_key(padapter, keybuf);
memset(keybuf, 0, 100);
keybuf[0] = 2; /* set msk */
keybuf[1] = 1; /* Enable TX */
keybuf[2] = 0; /* AE */
keybuf[3] = 0; /* not update */
memcpy(keybuf + 4, mac_addr, ETH_ALEN);
memcpy(keybuf + 10, MskDataKey, 16);
memcpy(keybuf + 26, MskMicKey, 16);
keybuf[42] = MskId;
wapi_test_set_key(padapter, keybuf);
WAPI_TRACE(WAPI_INIT, "<===========%s\n", __FUNCTION__);
}
#endif
void rtw_wapi_get_iv(_adapter *padapter, u8 *pRA, u8 *IV)
{
PWLAN_HEADER_WAPI_EXTENSION pWapiExt = NULL;
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
bool bPNOverflow = false;
bool bFindMatchPeer = false;
PRT_WAPI_STA_INFO pWapiSta = NULL;
pWapiExt = (PWLAN_HEADER_WAPI_EXTENSION)IV;
WAPI_DATA(WAPI_RX, "wapi_get_iv: pra", pRA, 6);
if (IS_MCAST(pRA)) {
if (!pWapiInfo->wapiTxMsk.bTxEnable) {
WAPI_TRACE(WAPI_ERR, "%s: bTxEnable = 0!!\n", __FUNCTION__);
return;
}
if (pWapiInfo->wapiTxMsk.keyId <= 1) {
pWapiExt->KeyIdx = pWapiInfo->wapiTxMsk.keyId;
pWapiExt->Reserved = 0;
bPNOverflow = WapiIncreasePN(pWapiInfo->lastTxMulticastPN, 1);
memcpy(pWapiExt->PN, pWapiInfo->lastTxMulticastPN, 16);
}
} else {
if (list_empty(&pWapiInfo->wapiSTAUsedList)) {
WAPI_TRACE(WAPI_RX, "rtw_wapi_get_iv: list is empty\n");
_rtw_memset(IV, 10, 18);
return;
} else {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
WAPI_DATA(WAPI_RX, "rtw_wapi_get_iv: peermacaddr ", pWapiSta->PeerMacAddr, 6);
if (_rtw_memcmp((u8 *)pWapiSta->PeerMacAddr, pRA, 6) == _TRUE) {
bFindMatchPeer = true;
break;
}
}
WAPI_TRACE(WAPI_RX, "bFindMatchPeer: %d\n", bFindMatchPeer);
WAPI_DATA(WAPI_RX, "Addr", pRA, 6);
if (bFindMatchPeer) {
if ((!pWapiSta->wapiUskUpdate.bTxEnable) && (!pWapiSta->wapiUsk.bTxEnable))
return;
if (pWapiSta->wapiUsk.keyId <= 1) {
if (pWapiSta->wapiUskUpdate.bTxEnable)
pWapiExt->KeyIdx = pWapiSta->wapiUskUpdate.keyId;
else
pWapiExt->KeyIdx = pWapiSta->wapiUsk.keyId;
pWapiExt->Reserved = 0;
bPNOverflow = WapiIncreasePN(pWapiSta->lastTxUnicastPN, 2);
_rtw_memcpy(pWapiExt->PN, pWapiSta->lastTxUnicastPN, 16);
}
}
}
}
}
bool rtw_wapi_drop_for_key_absent(_adapter *padapter, u8 *pRA)
{
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
bool bFindMatchPeer = false;
bool bDrop = false;
PRT_WAPI_STA_INFO pWapiSta = NULL;
struct security_priv *psecuritypriv = &padapter->securitypriv;
WAPI_DATA(WAPI_RX, "rtw_wapi_drop_for_key_absent: ra ", pRA, 6);
if (psecuritypriv->dot11PrivacyAlgrthm == _SMS4_) {
if ((!padapter->WapiSupport) || (!pWapiInfo->bWapiEnable))
return true;
if (IS_MCAST(pRA)) {
if (!pWapiInfo->wapiTxMsk.bTxEnable) {
bDrop = true;
WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: multicast key is absent\n");
return bDrop;
}
} else {
if (!list_empty(&pWapiInfo->wapiSTAUsedList)) {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
WAPI_DATA(WAPI_RX, "rtw_wapi_drop_for_key_absent: pWapiSta->PeerMacAddr ", pWapiSta->PeerMacAddr, 6);
if (_rtw_memcmp(pRA, pWapiSta->PeerMacAddr, 6) == _TRUE) {
bFindMatchPeer = true;
break;
}
}
if (bFindMatchPeer) {
if (!pWapiSta->wapiUsk.bTxEnable) {
bDrop = true;
WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: unicast key is absent\n");
return bDrop;
}
} else {
bDrop = true;
WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: no peer find\n");
return bDrop;
}
} else {
bDrop = true;
WAPI_TRACE(WAPI_RX, "rtw_wapi_drop_for_key_absent: no sta exist\n");
return bDrop;
}
}
} else
return bDrop;
return bDrop;
}
void rtw_wapi_set_set_encryption(_adapter *padapter, struct ieee_param *param)
{
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
PRT_WAPI_STA_INFO pWapiSta;
u8 WapiASUEPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
u8 WapiAEPNInitialValueSrc[16] = {0x37, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
u8 WapiAEMultiCastPNInitialValueSrc[16] = {0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C, 0x36, 0x5C} ;
if (param->u.crypt.set_tx == 1) {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (_rtw_memcmp(pWapiSta->PeerMacAddr, param->sta_addr, 6)) {
_rtw_memcpy(pWapiSta->lastTxUnicastPN, WapiASUEPNInitialValueSrc, 16);
pWapiSta->wapiUsk.bSet = true;
_rtw_memcpy(pWapiSta->wapiUsk.dataKey, param->u.crypt.key, 16);
_rtw_memcpy(pWapiSta->wapiUsk.micKey, param->u.crypt.key + 16, 16);
pWapiSta->wapiUsk.keyId = param->u.crypt.idx ;
pWapiSta->wapiUsk.bTxEnable = true;
_rtw_memcpy(pWapiSta->lastRxUnicastPNBEQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPNBKQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPNVIQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPNVOQueue, WapiAEPNInitialValueSrc, 16);
_rtw_memcpy(pWapiSta->lastRxUnicastPN, WapiAEPNInitialValueSrc, 16);
pWapiSta->wapiUskUpdate.bTxEnable = false;
pWapiSta->wapiUskUpdate.bSet = false;
if (psecuritypriv->sw_encrypt == false || psecuritypriv->sw_decrypt == false) {
/* set unicast key for ASUE */
rtw_wapi_set_key(padapter, &pWapiSta->wapiUsk, pWapiSta, false, false);
}
}
}
} else {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (_rtw_memcmp(pWapiSta->PeerMacAddr, get_bssid(pmlmepriv), 6)) {
pWapiSta->wapiMsk.bSet = true;
_rtw_memcpy(pWapiSta->wapiMsk.dataKey, param->u.crypt.key, 16);
_rtw_memcpy(pWapiSta->wapiMsk.micKey, param->u.crypt.key + 16, 16);
pWapiSta->wapiMsk.keyId = param->u.crypt.idx ;
pWapiSta->wapiMsk.bTxEnable = false;
if (!pWapiSta->bSetkeyOk)
pWapiSta->bSetkeyOk = true;
pWapiSta->bAuthenticateInProgress = false;
_rtw_memcpy(pWapiSta->lastRxMulticastPN, WapiAEMultiCastPNInitialValueSrc, 16);
if (psecuritypriv->sw_decrypt == false) {
/* set rx broadcast key for ASUE */
rtw_wapi_set_key(padapter, &pWapiSta->wapiMsk, pWapiSta, true, false);
}
}
}
}
}
#endif
================================================
FILE: core/rtw_wapi_sms4.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifdef CONFIG_WAPI_SUPPORT
#include
#include
#include
#include
#ifdef CONFIG_WAPI_SW_SMS4
#define WAPI_LITTLE_ENDIAN
/* #define BIG_ENDIAN */
#define ENCRYPT 0
#define DECRYPT 1
/**********************************************************
**********************************************************/
const u8 Sbox[256] = {
0xd6, 0x90, 0xe9, 0xfe, 0xcc, 0xe1, 0x3d, 0xb7, 0x16, 0xb6, 0x14, 0xc2, 0x28, 0xfb, 0x2c, 0x05,
0x2b, 0x67, 0x9a, 0x76, 0x2a, 0xbe, 0x04, 0xc3, 0xaa, 0x44, 0x13, 0x26, 0x49, 0x86, 0x06, 0x99,
0x9c, 0x42, 0x50, 0xf4, 0x91, 0xef, 0x98, 0x7a, 0x33, 0x54, 0x0b, 0x43, 0xed, 0xcf, 0xac, 0x62,
0xe4, 0xb3, 0x1c, 0xa9, 0xc9, 0x08, 0xe8, 0x95, 0x80, 0xdf, 0x94, 0xfa, 0x75, 0x8f, 0x3f, 0xa6,
0x47, 0x07, 0xa7, 0xfc, 0xf3, 0x73, 0x17, 0xba, 0x83, 0x59, 0x3c, 0x19, 0xe6, 0x85, 0x4f, 0xa8,
0x68, 0x6b, 0x81, 0xb2, 0x71, 0x64, 0xda, 0x8b, 0xf8, 0xeb, 0x0f, 0x4b, 0x70, 0x56, 0x9d, 0x35,
0x1e, 0x24, 0x0e, 0x5e, 0x63, 0x58, 0xd1, 0xa2, 0x25, 0x22, 0x7c, 0x3b, 0x01, 0x21, 0x78, 0x87,
0xd4, 0x00, 0x46, 0x57, 0x9f, 0xd3, 0x27, 0x52, 0x4c, 0x36, 0x02, 0xe7, 0xa0, 0xc4, 0xc8, 0x9e,
0xea, 0xbf, 0x8a, 0xd2, 0x40, 0xc7, 0x38, 0xb5, 0xa3, 0xf7, 0xf2, 0xce, 0xf9, 0x61, 0x15, 0xa1,
0xe0, 0xae, 0x5d, 0xa4, 0x9b, 0x34, 0x1a, 0x55, 0xad, 0x93, 0x32, 0x30, 0xf5, 0x8c, 0xb1, 0xe3,
0x1d, 0xf6, 0xe2, 0x2e, 0x82, 0x66, 0xca, 0x60, 0xc0, 0x29, 0x23, 0xab, 0x0d, 0x53, 0x4e, 0x6f,
0xd5, 0xdb, 0x37, 0x45, 0xde, 0xfd, 0x8e, 0x2f, 0x03, 0xff, 0x6a, 0x72, 0x6d, 0x6c, 0x5b, 0x51,
0x8d, 0x1b, 0xaf, 0x92, 0xbb, 0xdd, 0xbc, 0x7f, 0x11, 0xd9, 0x5c, 0x41, 0x1f, 0x10, 0x5a, 0xd8,
0x0a, 0xc1, 0x31, 0x88, 0xa5, 0xcd, 0x7b, 0xbd, 0x2d, 0x74, 0xd0, 0x12, 0xb8, 0xe5, 0xb4, 0xb0,
0x89, 0x69, 0x97, 0x4a, 0x0c, 0x96, 0x77, 0x7e, 0x65, 0xb9, 0xf1, 0x09, 0xc5, 0x6e, 0xc6, 0x84,
0x18, 0xf0, 0x7d, 0xec, 0x3a, 0xdc, 0x4d, 0x20, 0x79, 0xee, 0x5f, 0x3e, 0xd7, 0xcb, 0x39, 0x48
};
const u32 CK[32] = {
0x00070e15, 0x1c232a31, 0x383f464d, 0x545b6269,
0x70777e85, 0x8c939aa1, 0xa8afb6bd, 0xc4cbd2d9,
0xe0e7eef5, 0xfc030a11, 0x181f262d, 0x343b4249,
0x50575e65, 0x6c737a81, 0x888f969d, 0xa4abb2b9,
0xc0c7ced5, 0xdce3eaf1, 0xf8ff060d, 0x141b2229,
0x30373e45, 0x4c535a61, 0x686f767d, 0x848b9299,
0xa0a7aeb5, 0xbcc3cad1, 0xd8dfe6ed, 0xf4fb0209,
0x10171e25, 0x2c333a41, 0x484f565d, 0x646b7279
};
#define Rotl(_x, _y) (((_x) << (_y)) | ((_x) >> (32 - (_y))))
#define ByteSub(_A) (Sbox[(_A) >> 24 & 0xFF] << 24 | \
Sbox[(_A) >> 16 & 0xFF] << 16 | \
Sbox[(_A) >> 8 & 0xFF] << 8 | \
Sbox[(_A) & 0xFF])
#define L1(_B) ((_B) ^ Rotl(_B, 2) ^ Rotl(_B, 10) ^ Rotl(_B, 18) ^ Rotl(_B, 24))
#define L2(_B) ((_B) ^ Rotl(_B, 13) ^ Rotl(_B, 23))
static void
xor_block(void *dst, void *src1, void *src2)
/* 128-bit xor: *dst = *src1 xor *src2. Pointers must be 32-bit aligned */
{
((u32 *)dst)[0] = ((u32 *)src1)[0] ^ ((u32 *)src2)[0];
((u32 *)dst)[1] = ((u32 *)src1)[1] ^ ((u32 *)src2)[1];
((u32 *)dst)[2] = ((u32 *)src1)[2] ^ ((u32 *)src2)[2];
((u32 *)dst)[3] = ((u32 *)src1)[3] ^ ((u32 *)src2)[3];
}
void SMS4Crypt(u8 *Input, u8 *Output, u32 *rk)
{
u32 r, mid, x0, x1, x2, x3, *p;
p = (u32 *)Input;
x0 = p[0];
x1 = p[1];
x2 = p[2];
x3 = p[3];
#ifdef WAPI_LITTLE_ENDIAN
x0 = Rotl(x0, 16);
x0 = ((x0 & 0x00FF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
x1 = Rotl(x1, 16);
x1 = ((x1 & 0x00FF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
x2 = Rotl(x2, 16);
x2 = ((x2 & 0x00FF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
x3 = Rotl(x3, 16);
x3 = ((x3 & 0x00FF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
#endif
for (r = 0; r < 32; r += 4) {
mid = x1 ^ x2 ^ x3 ^ rk[r + 0];
mid = ByteSub(mid);
x0 ^= L1(mid);
mid = x2 ^ x3 ^ x0 ^ rk[r + 1];
mid = ByteSub(mid);
x1 ^= L1(mid);
mid = x3 ^ x0 ^ x1 ^ rk[r + 2];
mid = ByteSub(mid);
x2 ^= L1(mid);
mid = x0 ^ x1 ^ x2 ^ rk[r + 3];
mid = ByteSub(mid);
x3 ^= L1(mid);
}
#ifdef WAPI_LITTLE_ENDIAN
x0 = Rotl(x0, 16);
x0 = ((x0 & 0x00FF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
x1 = Rotl(x1, 16);
x1 = ((x1 & 0x00FF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
x2 = Rotl(x2, 16);
x2 = ((x2 & 0x00FF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
x3 = Rotl(x3, 16);
x3 = ((x3 & 0x00FF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
#endif
p = (u32 *)Output;
p[0] = x3;
p[1] = x2;
p[2] = x1;
p[3] = x0;
}
void SMS4KeyExt(u8 *Key, u32 *rk, u32 CryptFlag)
{
u32 r, mid, x0, x1, x2, x3, *p;
p = (u32 *)Key;
x0 = p[0];
x1 = p[1];
x2 = p[2];
x3 = p[3];
#ifdef WAPI_LITTLE_ENDIAN
x0 = Rotl(x0, 16);
x0 = ((x0 & 0xFF00FF) << 8) | ((x0 & 0xFF00FF00) >> 8);
x1 = Rotl(x1, 16);
x1 = ((x1 & 0xFF00FF) << 8) | ((x1 & 0xFF00FF00) >> 8);
x2 = Rotl(x2, 16);
x2 = ((x2 & 0xFF00FF) << 8) | ((x2 & 0xFF00FF00) >> 8);
x3 = Rotl(x3, 16);
x3 = ((x3 & 0xFF00FF) << 8) | ((x3 & 0xFF00FF00) >> 8);
#endif
x0 ^= 0xa3b1bac6;
x1 ^= 0x56aa3350;
x2 ^= 0x677d9197;
x3 ^= 0xb27022dc;
for (r = 0; r < 32; r += 4) {
mid = x1 ^ x2 ^ x3 ^ CK[r + 0];
mid = ByteSub(mid);
rk[r + 0] = x0 ^= L2(mid);
mid = x2 ^ x3 ^ x0 ^ CK[r + 1];
mid = ByteSub(mid);
rk[r + 1] = x1 ^= L2(mid);
mid = x3 ^ x0 ^ x1 ^ CK[r + 2];
mid = ByteSub(mid);
rk[r + 2] = x2 ^= L2(mid);
mid = x0 ^ x1 ^ x2 ^ CK[r + 3];
mid = ByteSub(mid);
rk[r + 3] = x3 ^= L2(mid);
}
if (CryptFlag == DECRYPT) {
for (r = 0; r < 16; r++)
mid = rk[r], rk[r] = rk[31 - r], rk[31 - r] = mid;
}
}
void WapiSMS4Cryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
u8 *Output, u16 *OutputLength, u32 CryptFlag)
{
u32 blockNum, i, j, rk[32];
u16 remainder;
u8 blockIn[16], blockOut[16], tempIV[16], k;
*OutputLength = 0;
remainder = InputLength & 0x0F;
blockNum = InputLength >> 4;
if (remainder != 0)
blockNum++;
else
remainder = 16;
for (k = 0; k < 16; k++)
tempIV[k] = IV[15 - k];
memcpy(blockIn, tempIV, 16);
SMS4KeyExt((u8 *)Key, rk, CryptFlag);
for (i = 0; i < blockNum - 1; i++) {
SMS4Crypt((u8 *)blockIn, blockOut, rk);
xor_block(&Output[i * 16], &Input[i * 16], blockOut);
memcpy(blockIn, blockOut, 16);
}
*OutputLength = i * 16;
SMS4Crypt((u8 *)blockIn, blockOut, rk);
for (j = 0; j < remainder; j++)
Output[i * 16 + j] = Input[i * 16 + j] ^ blockOut[j];
*OutputLength += remainder;
}
void WapiSMS4Encryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
u8 *Output, u16 *OutputLength)
{
WapiSMS4Cryption(Key, IV, Input, InputLength, Output, OutputLength, ENCRYPT);
}
void WapiSMS4Decryption(u8 *Key, u8 *IV, u8 *Input, u16 InputLength,
u8 *Output, u16 *OutputLength)
{
/* OFB mode: is also ENCRYPT flag */
WapiSMS4Cryption(Key, IV, Input, InputLength, Output, OutputLength, ENCRYPT);
}
void WapiSMS4CalculateMic(u8 *Key, u8 *IV, u8 *Input1, u8 Input1Length,
u8 *Input2, u16 Input2Length, u8 *Output, u8 *OutputLength)
{
u32 blockNum, i, remainder, rk[32];
u8 BlockIn[16], BlockOut[16], TempBlock[16], tempIV[16], k;
*OutputLength = 0;
remainder = Input1Length & 0x0F;
blockNum = Input1Length >> 4;
for (k = 0; k < 16; k++)
tempIV[k] = IV[15 - k];
memcpy(BlockIn, tempIV, 16);
SMS4KeyExt((u8 *)Key, rk, ENCRYPT);
SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
for (i = 0; i < blockNum; i++) {
xor_block(BlockIn, (Input1 + i * 16), BlockOut);
SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
}
if (remainder != 0) {
memset(TempBlock, 0, 16);
memcpy(TempBlock, (Input1 + blockNum * 16), remainder);
xor_block(BlockIn, TempBlock, BlockOut);
SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
}
remainder = Input2Length & 0x0F;
blockNum = Input2Length >> 4;
for (i = 0; i < blockNum; i++) {
xor_block(BlockIn, (Input2 + i * 16), BlockOut);
SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
}
if (remainder != 0) {
memset(TempBlock, 0, 16);
memcpy(TempBlock, (Input2 + blockNum * 16), remainder);
xor_block(BlockIn, TempBlock, BlockOut);
SMS4Crypt((u8 *)BlockIn, BlockOut, rk);
}
memcpy(Output, BlockOut, 16);
*OutputLength = 16;
}
void SecCalculateMicSMS4(
u8 KeyIdx,
u8 *MicKey,
u8 *pHeader,
u8 *pData,
u16 DataLen,
u8 *MicBuffer
)
{
#if 0
struct ieee80211_hdr_3addr_qos *header;
u8 TempBuf[34], TempLen = 32, MicLen, QosOffset, *IV;
u16 *pTemp, fc;
WAPI_TRACE(WAPI_TX | WAPI_RX, "=========>%s\n", __FUNCTION__);
header = (struct ieee80211_hdr_3addr_qos *)pHeader;
memset(TempBuf, 0, 34);
memcpy(TempBuf, pHeader, 2); /* FrameCtrl */
pTemp = (u16 *)TempBuf;
*pTemp &= 0xc78f; /* bit4,5,6,11,12,13 */
memcpy((TempBuf + 2), (pHeader + 4), 12); /* Addr1, Addr2 */
memcpy((TempBuf + 14), (pHeader + 22), 2); /* SeqCtrl */
pTemp = (u16 *)(TempBuf + 14);
*pTemp &= 0x000f;
memcpy((TempBuf + 16), (pHeader + 16), 6); /* Addr3 */
fc = le16_to_cpu(header->frame_ctl);
if (GetFrDs((u16 *)&fc) && GetToDs((u16 *)&fc)) {
memcpy((TempBuf + 22), (pHeader + 24), 6);
QosOffset = 30;
} else {
memset((TempBuf + 22), 0, 6);
QosOffset = 24;
}
if ((fc & 0x0088) == 0x0088) {
memcpy((TempBuf + 28), (pHeader + QosOffset), 2);
TempLen += 2;
/* IV = pHeader + QosOffset + 2 + SNAP_SIZE + sizeof(u16) + 2; */
IV = pHeader + QosOffset + 2 + 2;
} else {
IV = pHeader + QosOffset + 2;
/* IV = pHeader + QosOffset + SNAP_SIZE + sizeof(u16) + 2; */
}
TempBuf[TempLen - 1] = (u8)(DataLen & 0xff);
TempBuf[TempLen - 2] = (u8)((DataLen & 0xff00) >> 8);
TempBuf[TempLen - 4] = KeyIdx;
WAPI_DATA(WAPI_TX, "CalculateMic - KEY", MicKey, 16);
WAPI_DATA(WAPI_TX, "CalculateMic - IV", IV, 16);
WAPI_DATA(WAPI_TX, "CalculateMic - TempBuf", TempBuf, TempLen);
WAPI_DATA(WAPI_TX, "CalculateMic - pData", pData, DataLen);
WapiSMS4CalculateMic(MicKey, IV, TempBuf, TempLen,
pData, DataLen, MicBuffer, &MicLen);
if (MicLen != 16)
WAPI_TRACE(WAPI_ERR, "%s: MIC Length Error!!\n", __FUNCTION__);
WAPI_TRACE(WAPI_TX | WAPI_RX, "<=========%s\n", __FUNCTION__);
#endif
}
/* AddCount: 1 or 2.
* If overflow, return 1,
* else return 0.
*/
u8 WapiIncreasePN(u8 *PN, u8 AddCount)
{
u8 i;
if (NULL == PN)
return 1;
/* YJ,test,091102 */
/*
if(AddCount == 2){
RTW_INFO("############################%s(): PN[0]=0x%x\n", __FUNCTION__, PN[0]);
if(PN[0] == 0x48){
PN[0] += AddCount;
return 1;
}else{
PN[0] += AddCount;
return 0;
}
}
*/
/* YJ,test,091102,end */
for (i = 0; i < 16; i++) {
if (PN[i] + AddCount <= 0xff) {
PN[i] += AddCount;
return 0;
} else {
PN[i] += AddCount;
AddCount = 1;
}
}
return 1;
}
void WapiGetLastRxUnicastPNForQoSData(
u8 UserPriority,
PRT_WAPI_STA_INFO pWapiStaInfo,
u8 *PNOut
)
{
WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
switch (UserPriority) {
case 0:
case 3:
memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNBEQueue, 16);
break;
case 1:
case 2:
memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNBKQueue, 16);
break;
case 4:
case 5:
memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNVIQueue, 16);
break;
case 6:
case 7:
memcpy(PNOut, pWapiStaInfo->lastRxUnicastPNVOQueue, 16);
break;
default:
WAPI_TRACE(WAPI_ERR, "%s: Unknown TID\n", __FUNCTION__);
break;
}
WAPI_TRACE(WAPI_RX, "<=========== %s\n", __FUNCTION__);
}
void WapiSetLastRxUnicastPNForQoSData(
u8 UserPriority,
u8 *PNIn,
PRT_WAPI_STA_INFO pWapiStaInfo
)
{
WAPI_TRACE(WAPI_RX, "===========> %s\n", __FUNCTION__);
switch (UserPriority) {
case 0:
case 3:
memcpy(pWapiStaInfo->lastRxUnicastPNBEQueue, PNIn, 16);
break;
case 1:
case 2:
memcpy(pWapiStaInfo->lastRxUnicastPNBKQueue, PNIn, 16);
break;
case 4:
case 5:
memcpy(pWapiStaInfo->lastRxUnicastPNVIQueue, PNIn, 16);
break;
case 6:
case 7:
memcpy(pWapiStaInfo->lastRxUnicastPNVOQueue, PNIn, 16);
break;
default:
WAPI_TRACE(WAPI_ERR, "%s: Unknown TID\n", __FUNCTION__);
break;
}
WAPI_TRACE(WAPI_RX, "<=========== %s\n", __FUNCTION__);
}
/****************************************************************************
FALSE not RX-Reorder
TRUE do RX Reorder
add to support WAPI to N-mode
*****************************************************************************/
u8 WapiCheckPnInSwDecrypt(
_adapter *padapter,
struct sk_buff *pskb
)
{
u8 ret = false;
#if 0
struct ieee80211_hdr_3addr_qos *header;
u16 fc;
u8 *pDaddr, *pTaddr, *pRaddr;
header = (struct ieee80211_hdr_3addr_qos *)pskb->data;
pTaddr = header->addr2;
pRaddr = header->addr1;
fc = le16_to_cpu(header->frame_ctl);
if (GetToDs(&fc))
pDaddr = header->addr3;
else
pDaddr = header->addr1;
if ((_rtw_memcmp(pRaddr, padapter->pnetdev->dev_addr, ETH_ALEN) == 0)
&& !(pDaddr)
&& (GetFrameType(&fc) == WIFI_QOS_DATA_TYPE))
/* && ieee->pHTInfo->bCurrentHTSupport && */
/* ieee->pHTInfo->bCurRxReorderEnable) */
ret = false;
else
ret = true;
#endif
WAPI_TRACE(WAPI_RX, "%s: return %d\n", __FUNCTION__, ret);
return ret;
}
int SecSMS4HeaderFillIV(_adapter *padapter, u8 *pxmitframe)
{
struct pkt_attrib *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
u8 *frame = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_OFFSET;
u8 *pSecHeader = NULL, *pos = NULL, *pRA = NULL;
u8 bPNOverflow = false, bFindMatchPeer = false, hdr_len = 0;
PWLAN_HEADER_WAPI_EXTENSION pWapiExt = NULL;
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
PRT_WAPI_STA_INFO pWapiSta = NULL;
int ret = 0;
WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
return ret;
#if 0
hdr_len = sMacHdrLng;
if (GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE)
hdr_len += 2;
/* hdr_len += SNAP_SIZE + sizeof(u16); */
pos = skb_push(pskb, padapter->wapiInfo.extra_prefix_len);
memmove(pos, pos + padapter->wapiInfo.extra_prefix_len, hdr_len);
pSecHeader = pskb->data + hdr_len;
pWapiExt = (PWLAN_HEADER_WAPI_EXTENSION)pSecHeader;
pRA = pskb->data + 4;
WAPI_DATA(WAPI_TX, "FillIV - Before Fill IV", pskb->data, pskb->len);
/* Address 1 is always receiver's address */
if (IS_MCAST(pRA)) {
if (!pWapiInfo->wapiTxMsk.bTxEnable) {
WAPI_TRACE(WAPI_ERR, "%s: bTxEnable = 0!!\n", __FUNCTION__);
return -2;
}
if (pWapiInfo->wapiTxMsk.keyId <= 1) {
pWapiExt->KeyIdx = pWapiInfo->wapiTxMsk.keyId;
pWapiExt->Reserved = 0;
bPNOverflow = WapiIncreasePN(pWapiInfo->lastTxMulticastPN, 1);
memcpy(pWapiExt->PN, pWapiInfo->lastTxMulticastPN, 16);
if (bPNOverflow) {
/* Update MSK Notification. */
WAPI_TRACE(WAPI_ERR, "===============>%s():multicast PN overflow\n", __FUNCTION__);
rtw_wapi_app_event_handler(padapter, NULL, 0, pRA, false, false, true, 0, false);
}
} else {
WAPI_TRACE(WAPI_ERR, "%s: Invalid Wapi Multicast KeyIdx!!\n", __FUNCTION__);
ret = -3;
}
} else {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (!memcmp(pWapiSta->PeerMacAddr, pRA, 6)) {
bFindMatchPeer = true;
break;
}
}
if (bFindMatchPeer) {
if ((!pWapiSta->wapiUskUpdate.bTxEnable) && (!pWapiSta->wapiUsk.bTxEnable)) {
WAPI_TRACE(WAPI_ERR, "%s: bTxEnable = 0!!\n", __FUNCTION__);
return -4;
}
if (pWapiSta->wapiUsk.keyId <= 1) {
if (pWapiSta->wapiUskUpdate.bTxEnable)
pWapiExt->KeyIdx = pWapiSta->wapiUskUpdate.keyId;
else
pWapiExt->KeyIdx = pWapiSta->wapiUsk.keyId;
pWapiExt->Reserved = 0;
bPNOverflow = WapiIncreasePN(pWapiSta->lastTxUnicastPN, 2);
memcpy(pWapiExt->PN, pWapiSta->lastTxUnicastPN, 16);
if (bPNOverflow) {
/* Update USK Notification. */
WAPI_TRACE(WAPI_ERR, "===============>%s():unicast PN overflow\n", __FUNCTION__);
rtw_wapi_app_event_handler(padapter, NULL, 0, pWapiSta->PeerMacAddr, false, true, false, 0, false);
}
} else {
WAPI_TRACE(WAPI_ERR, "%s: Invalid Wapi Unicast KeyIdx!!\n", __FUNCTION__);
ret = -5;
}
} else {
WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta "MAC_FMT"!!\n", __FUNCTION__, MAC_ARG(pRA));
ret = -6;
}
}
WAPI_DATA(WAPI_TX, "FillIV - After Fill IV", pskb->data, pskb->len);
WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
return ret;
#endif
}
/* WAPI SW Enc: must have done Coalesce! */
void SecSWSMS4Encryption(
_adapter *padapter,
u8 *pxmitframe
)
{
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
PRT_WAPI_STA_INFO pWapiSta = NULL;
u8 *pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_SIZE;
struct pkt_attrib *pattrib = &((struct xmit_frame *)pxmitframe)->attrib;
u8 *SecPtr = NULL, *pRA, *pMicKey = NULL, *pDataKey = NULL, *pIV = NULL;
u8 IVOffset, DataOffset, bFindMatchPeer = false, KeyIdx = 0, MicBuffer[16];
u16 OutputLength;
WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
WAPI_TRACE(WAPI_TX, "hdrlen: %d\n", pattrib->hdrlen);
return;
DataOffset = pattrib->hdrlen + pattrib->iv_len;
pRA = pframe + 4;
if (IS_MCAST(pRA)) {
KeyIdx = pWapiInfo->wapiTxMsk.keyId;
pIV = pWapiInfo->lastTxMulticastPN;
pMicKey = pWapiInfo->wapiTxMsk.micKey;
pDataKey = pWapiInfo->wapiTxMsk.dataKey;
} else {
if (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (0 == memcmp(pWapiSta->PeerMacAddr, pRA, 6)) {
bFindMatchPeer = true;
break;
}
}
if (bFindMatchPeer) {
if (pWapiSta->wapiUskUpdate.bTxEnable) {
KeyIdx = pWapiSta->wapiUskUpdate.keyId;
WAPI_TRACE(WAPI_TX, "%s(): Use update USK!! KeyIdx=%d\n", __FUNCTION__, KeyIdx);
pIV = pWapiSta->lastTxUnicastPN;
pMicKey = pWapiSta->wapiUskUpdate.micKey;
pDataKey = pWapiSta->wapiUskUpdate.dataKey;
} else {
KeyIdx = pWapiSta->wapiUsk.keyId;
WAPI_TRACE(WAPI_TX, "%s(): Use USK!! KeyIdx=%d\n", __FUNCTION__, KeyIdx);
pIV = pWapiSta->lastTxUnicastPN;
pMicKey = pWapiSta->wapiUsk.micKey;
pDataKey = pWapiSta->wapiUsk.dataKey;
}
} else {
WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta!!\n", __FUNCTION__);
return;
}
} else {
WAPI_TRACE(WAPI_ERR, "%s: wapiSTAUsedList is empty!!\n", __FUNCTION__);
return;
}
}
SecPtr = pframe;
SecCalculateMicSMS4(KeyIdx, pMicKey, SecPtr, (SecPtr + DataOffset), pattrib->pktlen, MicBuffer);
WAPI_DATA(WAPI_TX, "Encryption - MIC", MicBuffer, padapter->wapiInfo.extra_postfix_len);
memcpy(pframe + pattrib->hdrlen + pattrib->iv_len + pattrib->pktlen - pattrib->icv_len,
(u8 *)MicBuffer,
padapter->wapiInfo.extra_postfix_len
);
WapiSMS4Encryption(pDataKey, pIV, (SecPtr + DataOffset), pattrib->pktlen + pattrib->icv_len, (SecPtr + DataOffset), &OutputLength);
WAPI_DATA(WAPI_TX, "Encryption - After SMS4 encryption", pframe, pattrib->hdrlen + pattrib->iv_len + pattrib->pktlen);
WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
}
u8 SecSWSMS4Decryption(
_adapter *padapter,
u8 *precv_frame,
struct recv_priv *precv_priv
)
{
PRT_WAPI_T pWapiInfo = &padapter->wapiInfo;
struct recv_frame_hdr *precv_hdr;
PRT_WAPI_STA_INFO pWapiSta = NULL;
u8 IVOffset, DataOffset, bFindMatchPeer = false, bUseUpdatedKey = false;
u8 KeyIdx, MicBuffer[16], lastRxPNforQoS[16];
u8 *pRA, *pTA, *pMicKey, *pDataKey, *pLastRxPN, *pRecvPN, *pSecData, *pRecvMic, *pos;
u8 TID = 0;
u16 OutputLength, DataLen;
u8 bQosData;
struct sk_buff *pskb;
WAPI_TRACE(WAPI_RX, "=========>%s\n", __FUNCTION__);
return 0;
precv_hdr = &((union recv_frame *)precv_frame)->u.hdr;
pskb = (struct sk_buff *)(precv_hdr->rx_data);
precv_hdr->bWapiCheckPNInDecrypt = WapiCheckPnInSwDecrypt(padapter, pskb);
WAPI_TRACE(WAPI_RX, "=========>%s: check PN %d\n", __FUNCTION__, precv_hdr->bWapiCheckPNInDecrypt);
WAPI_DATA(WAPI_RX, "Decryption - Before decryption", pskb->data, pskb->len);
IVOffset = sMacHdrLng;
bQosData = GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE;
if (bQosData)
IVOffset += 2;
/* if(GetHTC()) */
/* IVOffset += 4; */
/* IVOffset += SNAP_SIZE + sizeof(u16); */
DataOffset = IVOffset + padapter->wapiInfo.extra_prefix_len;
pRA = pskb->data + 4;
pTA = pskb->data + 10;
KeyIdx = *(pskb->data + IVOffset);
pRecvPN = pskb->data + IVOffset + 2;
pSecData = pskb->data + DataOffset;
DataLen = pskb->len - DataOffset;
pRecvMic = pskb->data + pskb->len - padapter->wapiInfo.extra_postfix_len;
TID = GetTid(pskb->data);
if (!list_empty(&(pWapiInfo->wapiSTAUsedList))) {
list_for_each_entry(pWapiSta, &pWapiInfo->wapiSTAUsedList, list) {
if (0 == memcmp(pWapiSta->PeerMacAddr, pTA, 6)) {
bFindMatchPeer = true;
break;
}
}
}
if (!bFindMatchPeer) {
WAPI_TRACE(WAPI_ERR, "%s: Can not find Peer Sta "MAC_FMT" for Key Info!!!\n", __FUNCTION__, MAC_ARG(pTA));
return false;
}
if (IS_MCAST(pRA)) {
WAPI_TRACE(WAPI_RX, "%s: Multicast decryption !!!\n", __FUNCTION__);
if (pWapiSta->wapiMsk.keyId == KeyIdx && pWapiSta->wapiMsk.bSet) {
pLastRxPN = pWapiSta->lastRxMulticastPN;
if (!WapiComparePN(pRecvPN, pLastRxPN)) {
WAPI_TRACE(WAPI_ERR, "%s: MSK PN is not larger than last, Dropped!!!\n", __FUNCTION__);
WAPI_DATA(WAPI_ERR, "pRecvPN:", pRecvPN, 16);
WAPI_DATA(WAPI_ERR, "pLastRxPN:", pLastRxPN, 16);
return false;
}
memcpy(pLastRxPN, pRecvPN, 16);
pMicKey = pWapiSta->wapiMsk.micKey;
pDataKey = pWapiSta->wapiMsk.dataKey;
} else if (pWapiSta->wapiMskUpdate.keyId == KeyIdx && pWapiSta->wapiMskUpdate.bSet) {
WAPI_TRACE(WAPI_RX, "%s: Use Updated MSK for Decryption !!!\n", __FUNCTION__);
bUseUpdatedKey = true;
memcpy(pWapiSta->lastRxMulticastPN, pRecvPN, 16);
pMicKey = pWapiSta->wapiMskUpdate.micKey;
pDataKey = pWapiSta->wapiMskUpdate.dataKey;
} else {
WAPI_TRACE(WAPI_ERR, "%s: Can not find MSK with matched KeyIdx(%d), Dropped !!!\n", __FUNCTION__, KeyIdx);
return false;
}
} else {
WAPI_TRACE(WAPI_RX, "%s: Unicast decryption !!!\n", __FUNCTION__);
if (pWapiSta->wapiUsk.keyId == KeyIdx && pWapiSta->wapiUsk.bSet) {
WAPI_TRACE(WAPI_RX, "%s: Use USK for Decryption!!!\n", __FUNCTION__);
if (precv_hdr->bWapiCheckPNInDecrypt) {
if (GetFrameType(pskb->data) == WIFI_QOS_DATA_TYPE) {
WapiGetLastRxUnicastPNForQoSData(TID, pWapiSta, lastRxPNforQoS);
pLastRxPN = lastRxPNforQoS;
} else
pLastRxPN = pWapiSta->lastRxUnicastPN;
if (!WapiComparePN(pRecvPN, pLastRxPN))
return false;
if (bQosData)
WapiSetLastRxUnicastPNForQoSData(TID, pRecvPN, pWapiSta);
else
memcpy(pWapiSta->lastRxUnicastPN, pRecvPN, 16);
} else
memcpy(precv_hdr->WapiTempPN, pRecvPN, 16);
if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE)) {
if ((pRecvPN[0] & 0x1) == 0) {
WAPI_TRACE(WAPI_ERR, "%s: Rx USK PN is not odd when Infra STA mode, Dropped !!!\n", __FUNCTION__);
return false;
}
}
pMicKey = pWapiSta->wapiUsk.micKey;
pDataKey = pWapiSta->wapiUsk.dataKey;
} else if (pWapiSta->wapiUskUpdate.keyId == KeyIdx && pWapiSta->wapiUskUpdate.bSet) {
WAPI_TRACE(WAPI_RX, "%s: Use Updated USK for Decryption!!!\n", __FUNCTION__);
if (pWapiSta->bAuthenticatorInUpdata)
bUseUpdatedKey = true;
else
bUseUpdatedKey = false;
if (bQosData)
WapiSetLastRxUnicastPNForQoSData(TID, pRecvPN, pWapiSta);
else
memcpy(pWapiSta->lastRxUnicastPN, pRecvPN, 16);
pMicKey = pWapiSta->wapiUskUpdate.micKey;
pDataKey = pWapiSta->wapiUskUpdate.dataKey;
} else {
WAPI_TRACE(WAPI_ERR, "%s: No valid USK!!!KeyIdx=%d pWapiSta->wapiUsk.keyId=%d pWapiSta->wapiUskUpdate.keyId=%d\n", __FUNCTION__, KeyIdx, pWapiSta->wapiUsk.keyId,
pWapiSta->wapiUskUpdate.keyId);
/* dump_buf(pskb->data,pskb->len); */
return false;
}
}
WAPI_DATA(WAPI_RX, "Decryption - DataKey", pDataKey, 16);
WAPI_DATA(WAPI_RX, "Decryption - IV", pRecvPN, 16);
WapiSMS4Decryption(pDataKey, pRecvPN, pSecData, DataLen, pSecData, &OutputLength);
if (OutputLength != DataLen)
WAPI_TRACE(WAPI_ERR, "%s: Output Length Error!!!!\n", __FUNCTION__);
WAPI_DATA(WAPI_RX, "Decryption - After decryption", pskb->data, pskb->len);
DataLen -= padapter->wapiInfo.extra_postfix_len;
SecCalculateMicSMS4(KeyIdx, pMicKey, pskb->data, pSecData, DataLen, MicBuffer);
WAPI_DATA(WAPI_RX, "Decryption - MIC received", pRecvMic, SMS4_MIC_LEN);
WAPI_DATA(WAPI_RX, "Decryption - MIC calculated", MicBuffer, SMS4_MIC_LEN);
if (0 == memcmp(MicBuffer, pRecvMic, padapter->wapiInfo.extra_postfix_len)) {
WAPI_TRACE(WAPI_RX, "%s: Check MIC OK!!\n", __FUNCTION__);
if (bUseUpdatedKey) {
/* delete the old key */
if (IS_MCAST(pRA)) {
WAPI_TRACE(WAPI_API, "%s(): AE use new update MSK!!\n", __FUNCTION__);
pWapiSta->wapiMsk.keyId = pWapiSta->wapiMskUpdate.keyId;
memcpy(pWapiSta->wapiMsk.dataKey, pWapiSta->wapiMskUpdate.dataKey, 16);
memcpy(pWapiSta->wapiMsk.micKey, pWapiSta->wapiMskUpdate.micKey, 16);
pWapiSta->wapiMskUpdate.bTxEnable = pWapiSta->wapiMskUpdate.bSet = false;
} else {
WAPI_TRACE(WAPI_API, "%s(): AE use new update USK!!\n", __FUNCTION__);
pWapiSta->wapiUsk.keyId = pWapiSta->wapiUskUpdate.keyId;
memcpy(pWapiSta->wapiUsk.dataKey, pWapiSta->wapiUskUpdate.dataKey, 16);
memcpy(pWapiSta->wapiUsk.micKey, pWapiSta->wapiUskUpdate.micKey, 16);
pWapiSta->wapiUskUpdate.bTxEnable = pWapiSta->wapiUskUpdate.bSet = false;
}
}
} else {
WAPI_TRACE(WAPI_ERR, "%s: Check MIC Error, Dropped !!!!\n", __FUNCTION__);
return false;
}
pos = pskb->data;
memmove(pos + padapter->wapiInfo.extra_prefix_len, pos, IVOffset);
skb_pull(pskb, padapter->wapiInfo.extra_prefix_len);
WAPI_TRACE(WAPI_RX, "<=========%s\n", __FUNCTION__);
return true;
}
u32 rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)
{
u8 *pframe;
u32 res = _SUCCESS;
WAPI_TRACE(WAPI_TX, "=========>%s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
WAPI_TRACE(WAPI_TX, "<========== %s, WAPI not supported or enabled!\n", __FUNCTION__);
return _FAIL;
}
if (((struct xmit_frame *)pxmitframe)->buf_addr == NULL)
return _FAIL;
pframe = ((struct xmit_frame *)pxmitframe)->buf_addr + TXDESC_OFFSET;
SecSWSMS4Encryption(padapter, pxmitframe);
WAPI_TRACE(WAPI_TX, "<=========%s\n", __FUNCTION__);
return res;
}
u32 rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)
{
u8 *pframe;
u32 res = _SUCCESS;
WAPI_TRACE(WAPI_RX, "=========>%s\n", __FUNCTION__);
if ((!padapter->WapiSupport) || (!padapter->wapiInfo.bWapiEnable)) {
WAPI_TRACE(WAPI_RX, "<========== %s, WAPI not supported or enabled!\n", __FUNCTION__);
return _FAIL;
}
/* drop packet when hw decrypt fail
* return tempraily */
return _FAIL;
/* pframe=(unsigned char *)((union recv_frame*)precvframe)->u.hdr.rx_data; */
if (false == SecSWSMS4Decryption(padapter, precvframe, &padapter->recvpriv)) {
WAPI_TRACE(WAPI_ERR, "%s():SMS4 decrypt frame error\n", __FUNCTION__);
return _FAIL;
}
WAPI_TRACE(WAPI_RX, "<=========%s\n", __FUNCTION__);
return res;
}
#else
u32 rtw_sms4_encrypt(_adapter *padapter, u8 *pxmitframe)
{
WAPI_TRACE(WAPI_TX, "=========>Dummy %s\n", __FUNCTION__);
WAPI_TRACE(WAPI_TX, "<=========Dummy %s\n", __FUNCTION__);
return _SUCCESS;
}
u32 rtw_sms4_decrypt(_adapter *padapter, u8 *precvframe)
{
WAPI_TRACE(WAPI_RX, "=========>Dummy %s\n", __FUNCTION__);
WAPI_TRACE(WAPI_RX, "<=========Dummy %s\n", __FUNCTION__);
return _SUCCESS;
}
#endif
#endif
================================================
FILE: core/rtw_wlan_util.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_WLAN_UTIL_C_
#include
#include
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
#include
#define ETH_TYPE_OFFSET 12
#define PROTOCOL_OFFSET 23
#define IP_OFFSET 30
#define IPv6_OFFSET 38
#define IPv6_PROTOCOL_OFFSET 20
#endif
unsigned char ARTHEROS_OUI1[] = {0x00, 0x03, 0x7f};
unsigned char ARTHEROS_OUI2[] = {0x00, 0x13, 0x74};
unsigned char BROADCOM_OUI1[] = {0x00, 0x10, 0x18};
unsigned char BROADCOM_OUI2[] = {0x00, 0x0a, 0xf7};
unsigned char BROADCOM_OUI3[] = {0x00, 0x05, 0xb5};
unsigned char CISCO_OUI[] = {0x00, 0x40, 0x96};
unsigned char MARVELL_OUI[] = {0x00, 0x50, 0x43};
unsigned char RALINK_OUI[] = {0x00, 0x0c, 0x43};
unsigned char REALTEK_OUI[] = {0x00, 0xe0, 0x4c};
unsigned char AIRGOCAP_OUI[] = {0x00, 0x0a, 0xf5};
unsigned char REALTEK_96B_IE[] = {0x00, 0xe0, 0x4c, 0x02, 0x01, 0x20};
extern unsigned char RTW_WPA_OUI[];
extern unsigned char WPA_TKIP_CIPHER[4];
extern unsigned char RSN_TKIP_CIPHER[4];
#define R2T_PHY_DELAY (0)
/* #define WAIT_FOR_BCN_TO_MIN (3000) */
#define WAIT_FOR_BCN_TO_MIN (6000)
#define WAIT_FOR_BCN_TO_MAX (20000)
static u8 rtw_basic_rate_cck[4] = {
IEEE80211_CCK_RATE_1MB | IEEE80211_BASIC_RATE_MASK, IEEE80211_CCK_RATE_2MB | IEEE80211_BASIC_RATE_MASK,
IEEE80211_CCK_RATE_5MB | IEEE80211_BASIC_RATE_MASK, IEEE80211_CCK_RATE_11MB | IEEE80211_BASIC_RATE_MASK
};
static u8 rtw_basic_rate_ofdm[3] = {
IEEE80211_OFDM_RATE_6MB | IEEE80211_BASIC_RATE_MASK, IEEE80211_OFDM_RATE_12MB | IEEE80211_BASIC_RATE_MASK,
IEEE80211_OFDM_RATE_24MB | IEEE80211_BASIC_RATE_MASK
};
static u8 rtw_basic_rate_mix[7] = {
IEEE80211_CCK_RATE_1MB | IEEE80211_BASIC_RATE_MASK, IEEE80211_CCK_RATE_2MB | IEEE80211_BASIC_RATE_MASK,
IEEE80211_CCK_RATE_5MB | IEEE80211_BASIC_RATE_MASK, IEEE80211_CCK_RATE_11MB | IEEE80211_BASIC_RATE_MASK,
IEEE80211_OFDM_RATE_6MB | IEEE80211_BASIC_RATE_MASK, IEEE80211_OFDM_RATE_12MB | IEEE80211_BASIC_RATE_MASK,
IEEE80211_OFDM_RATE_24MB | IEEE80211_BASIC_RATE_MASK
};
extern u8 WIFI_CCKRATES[];
bool rtw_is_cck_rate(u8 rate)
{
int i;
for (i = 0; i < 4; i++)
if ((WIFI_CCKRATES[i] & 0x7F) == (rate & 0x7F))
return 1;
return 0;
}
extern u8 WIFI_OFDMRATES[];
bool rtw_is_ofdm_rate(u8 rate)
{
int i;
for (i = 0; i < 8; i++)
if ((WIFI_OFDMRATES[i] & 0x7F) == (rate & 0x7F))
return 1;
return 0;
}
/* test if rate is defined in rtw_basic_rate_cck */
bool rtw_is_basic_rate_cck(u8 rate)
{
int i;
for (i = 0; i < 4; i++)
if ((rtw_basic_rate_cck[i] & 0x7F) == (rate & 0x7F))
return 1;
return 0;
}
/* test if rate is defined in rtw_basic_rate_ofdm */
bool rtw_is_basic_rate_ofdm(u8 rate)
{
int i;
for (i = 0; i < 3; i++)
if ((rtw_basic_rate_ofdm[i] & 0x7F) == (rate & 0x7F))
return 1;
return 0;
}
/* test if rate is defined in rtw_basic_rate_mix */
bool rtw_is_basic_rate_mix(u8 rate)
{
int i;
for (i = 0; i < 7; i++)
if ((rtw_basic_rate_mix[i] & 0x7F) == (rate & 0x7F))
return 1;
return 0;
}
#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
int new_bcn_max = 3;
#endif
int cckrates_included(unsigned char *rate, int ratelen)
{
int i;
for (i = 0; i < ratelen; i++) {
if ((((rate[i]) & 0x7f) == 2) || (((rate[i]) & 0x7f) == 4) ||
(((rate[i]) & 0x7f) == 11) || (((rate[i]) & 0x7f) == 22))
return _TRUE;
}
return _FALSE;
}
int cckratesonly_included(unsigned char *rate, int ratelen)
{
int i;
for (i = 0; i < ratelen; i++) {
if ((((rate[i]) & 0x7f) != 2) && (((rate[i]) & 0x7f) != 4) &&
(((rate[i]) & 0x7f) != 11) && (((rate[i]) & 0x7f) != 22))
return _FALSE;
}
return _TRUE;
}
s8 rtw_get_sta_rx_nss(_adapter *adapter, struct sta_info *psta)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 rf_type = RF_1T1R, custom_rf_type;
s8 nss = 1;
if (!psta)
return nss;
custom_rf_type = adapter->registrypriv.rf_config;
rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
if (RF_TYPE_VALID(custom_rf_type))
rf_type = custom_rf_type;
nss = rtw_min(rf_type_to_rf_rx_cnt(rf_type), hal_spec->rx_nss_num);
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_80211AC_VHT
if (psta->vhtpriv.vht_option)
nss = rtw_min(nss, rtw_vht_mcsmap_to_nss(psta->vhtpriv.vht_mcs_map));
else
#endif /* CONFIG_80211AC_VHT */
if (psta->htpriv.ht_option)
nss = rtw_min(nss, rtw_ht_mcsset_to_nss(psta->htpriv.ht_cap.supp_mcs_set));
#endif /*CONFIG_80211N_HT*/
RTW_INFO("%s: %d SS\n", __func__, nss);
return nss;
}
s8 rtw_get_sta_tx_nss(_adapter *adapter, struct sta_info *psta)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 rf_type = RF_1T1R, custom_rf_type;
s8 nss = 1;
if (!psta)
return nss;
custom_rf_type = adapter->registrypriv.rf_config;
rtw_hal_get_hwreg(adapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
if (RF_TYPE_VALID(custom_rf_type))
rf_type = custom_rf_type;
nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_80211AC_VHT
if (psta->vhtpriv.vht_option)
nss = rtw_min(nss, rtw_vht_mcsmap_to_nss(psta->vhtpriv.vht_mcs_map));
else
#endif /* CONFIG_80211AC_VHT */
if (psta->htpriv.ht_option)
nss = rtw_min(nss, rtw_ht_mcsset_to_nss(psta->htpriv.ht_cap.supp_mcs_set));
#endif /*CONFIG_80211N_HT*/
RTW_INFO("%s: %d SS\n", __func__, nss);
return nss;
}
u8 judge_network_type(_adapter *padapter, unsigned char *rate, int ratelen)
{
u8 network_type = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pmlmeext->cur_channel > 14) {
if (pmlmeinfo->VHT_enable)
network_type = WIRELESS_11AC;
else if (pmlmeinfo->HT_enable)
network_type = WIRELESS_11_5N;
network_type |= WIRELESS_11A;
} else {
if (pmlmeinfo->HT_enable)
network_type = WIRELESS_11_24N;
if ((cckratesonly_included(rate, ratelen)) == _TRUE)
network_type |= WIRELESS_11B;
else if ((cckrates_included(rate, ratelen)) == _TRUE)
network_type |= WIRELESS_11BG;
else
network_type |= WIRELESS_11G;
}
return network_type;
}
unsigned char ratetbl_val_2wifirate(unsigned char rate);
unsigned char ratetbl_val_2wifirate(unsigned char rate)
{
unsigned char val = 0;
switch (rate & 0x7f) {
case 0:
val = IEEE80211_CCK_RATE_1MB;
break;
case 1:
val = IEEE80211_CCK_RATE_2MB;
break;
case 2:
val = IEEE80211_CCK_RATE_5MB;
break;
case 3:
val = IEEE80211_CCK_RATE_11MB;
break;
case 4:
val = IEEE80211_OFDM_RATE_6MB;
break;
case 5:
val = IEEE80211_OFDM_RATE_9MB;
break;
case 6:
val = IEEE80211_OFDM_RATE_12MB;
break;
case 7:
val = IEEE80211_OFDM_RATE_18MB;
break;
case 8:
val = IEEE80211_OFDM_RATE_24MB;
break;
case 9:
val = IEEE80211_OFDM_RATE_36MB;
break;
case 10:
val = IEEE80211_OFDM_RATE_48MB;
break;
case 11:
val = IEEE80211_OFDM_RATE_54MB;
break;
}
return val;
}
int is_basicrate(_adapter *padapter, unsigned char rate);
int is_basicrate(_adapter *padapter, unsigned char rate)
{
int i;
unsigned char val;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
for (i = 0; i < NumRates; i++) {
val = pmlmeext->basicrate[i];
if ((val != 0xff) && (val != 0xfe)) {
if (rate == ratetbl_val_2wifirate(val))
return _TRUE;
}
}
return _FALSE;
}
unsigned int ratetbl2rateset(_adapter *padapter, unsigned char *rateset);
unsigned int ratetbl2rateset(_adapter *padapter, unsigned char *rateset)
{
int i;
unsigned char rate;
unsigned int len = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
for (i = 0; i < NumRates; i++) {
rate = pmlmeext->datarate[i];
if (rtw_get_oper_ch(padapter) > 14 && rate < _6M_RATE_) /*5G no support CCK rate*/
continue;
switch (rate) {
case 0xff:
return len;
case 0xfe:
continue;
default:
rate = ratetbl_val_2wifirate(rate);
if (is_basicrate(padapter, rate) == _TRUE)
rate |= IEEE80211_BASIC_RATE_MASK;
rateset[len] = rate;
len++;
break;
}
}
return len;
}
void get_rate_set(_adapter *padapter, unsigned char *pbssrate, int *bssrate_len)
{
unsigned char supportedrates[NumRates];
_rtw_memset(supportedrates, 0, NumRates);
*bssrate_len = ratetbl2rateset(padapter, supportedrates);
_rtw_memcpy(pbssrate, supportedrates, *bssrate_len);
}
void set_mcs_rate_by_mask(u8 *mcs_set, u32 mask)
{
u8 mcs_rate_1r = (u8)(mask & 0xff);
u8 mcs_rate_2r = (u8)((mask >> 8) & 0xff);
u8 mcs_rate_3r = (u8)((mask >> 16) & 0xff);
u8 mcs_rate_4r = (u8)((mask >> 24) & 0xff);
mcs_set[0] &= mcs_rate_1r;
mcs_set[1] &= mcs_rate_2r;
mcs_set[2] &= mcs_rate_3r;
mcs_set[3] &= mcs_rate_4r;
}
void UpdateBrateTbl(
PADAPTER Adapter,
u8 *mBratesOS
)
{
u8 i;
u8 rate;
/* 1M, 2M, 5.5M, 11M, 6M, 12M, 24M are mandatory. */
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
rate = mBratesOS[i] & 0x7f;
switch (rate) {
case IEEE80211_CCK_RATE_1MB:
case IEEE80211_CCK_RATE_2MB:
case IEEE80211_CCK_RATE_5MB:
case IEEE80211_CCK_RATE_11MB:
case IEEE80211_OFDM_RATE_6MB:
case IEEE80211_OFDM_RATE_12MB:
case IEEE80211_OFDM_RATE_24MB:
mBratesOS[i] |= IEEE80211_BASIC_RATE_MASK;
break;
}
}
}
void UpdateBrateTblForSoftAP(u8 *bssrateset, u32 bssratelen)
{
u8 i;
u8 rate;
for (i = 0; i < bssratelen; i++) {
rate = bssrateset[i] & 0x7f;
switch (rate) {
case IEEE80211_CCK_RATE_1MB:
case IEEE80211_CCK_RATE_2MB:
case IEEE80211_CCK_RATE_5MB:
case IEEE80211_CCK_RATE_11MB:
bssrateset[i] |= IEEE80211_BASIC_RATE_MASK;
break;
}
}
}
void Set_MSR(_adapter *padapter, u8 type)
{
rtw_hal_set_hwreg(padapter, HW_VAR_MEDIA_STATUS, (u8 *)(&type));
}
inline u8 rtw_get_oper_ch(_adapter *adapter)
{
return adapter_to_dvobj(adapter)->oper_channel;
}
inline void rtw_set_oper_ch(_adapter *adapter, u8 ch)
{
#ifdef DBG_CH_SWITCH
const int len = 128;
char msg[128] = {0};
int cnt = 0;
int i = 0;
#endif /* DBG_CH_SWITCH */
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
if (dvobj->oper_channel != ch) {
dvobj->on_oper_ch_time = rtw_get_current_time();
#ifdef DBG_CH_SWITCH
cnt += snprintf(msg + cnt, len - cnt, "switch to ch %3u", ch);
for (i = 0; i < dvobj->iface_nums; i++) {
_adapter *iface = dvobj->padapters[i];
cnt += snprintf(msg + cnt, len - cnt, " ["ADPT_FMT":", ADPT_ARG(iface));
if (iface->mlmeextpriv.cur_channel == ch)
cnt += snprintf(msg + cnt, len - cnt, "C");
else
cnt += snprintf(msg + cnt, len - cnt, "_");
if (iface->wdinfo.listen_channel == ch && !rtw_p2p_chk_state(&iface->wdinfo, P2P_STATE_NONE))
cnt += snprintf(msg + cnt, len - cnt, "L");
else
cnt += snprintf(msg + cnt, len - cnt, "_");
cnt += snprintf(msg + cnt, len - cnt, "]");
}
RTW_INFO(FUNC_ADPT_FMT" %s\n", FUNC_ADPT_ARG(adapter), msg);
#endif /* DBG_CH_SWITCH */
}
dvobj->oper_channel = ch;
}
inline u8 rtw_get_oper_bw(_adapter *adapter)
{
return adapter_to_dvobj(adapter)->oper_bwmode;
}
inline void rtw_set_oper_bw(_adapter *adapter, u8 bw)
{
adapter_to_dvobj(adapter)->oper_bwmode = bw;
}
inline u8 rtw_get_oper_choffset(_adapter *adapter)
{
return adapter_to_dvobj(adapter)->oper_ch_offset;
}
inline void rtw_set_oper_choffset(_adapter *adapter, u8 offset)
{
adapter_to_dvobj(adapter)->oper_ch_offset = offset;
}
u8 rtw_get_offset_by_chbw(u8 ch, u8 bw, u8 *r_offset)
{
u8 valid = 1;
u8 offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
if (bw == CHANNEL_WIDTH_20)
goto exit;
if (bw >= CHANNEL_WIDTH_80 && ch <= 14) {
valid = 0;
goto exit;
}
if (ch >= 1 && ch <= 4)
offset = HAL_PRIME_CHNL_OFFSET_LOWER;
else if (ch >= 5 && ch <= 9) {
if (*r_offset == HAL_PRIME_CHNL_OFFSET_LOWER || *r_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
offset = *r_offset; /* both lower and upper is valid, obey input value */
else
offset = HAL_PRIME_CHNL_OFFSET_UPPER; /* default use upper */
} else if (ch >= 10 && ch <= 13)
offset = HAL_PRIME_CHNL_OFFSET_UPPER;
else if (ch == 14) {
valid = 0; /* ch14 doesn't support 40MHz bandwidth */
goto exit;
} else if (ch >= 36 && ch <= 177) {
switch (ch) {
case 36:
case 44:
case 52:
case 60:
case 100:
case 108:
case 116:
case 124:
case 132:
case 140:
case 149:
case 157:
case 165:
case 173:
offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case 40:
case 48:
case 56:
case 64:
case 104:
case 112:
case 120:
case 128:
case 136:
case 144:
case 153:
case 161:
case 169:
case 177:
offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
default:
valid = 0;
break;
}
} else
valid = 0;
exit:
if (valid && r_offset)
*r_offset = offset;
return valid;
}
u8 rtw_get_center_ch(u8 channel, u8 chnl_bw, u8 chnl_offset)
{
u8 center_ch = channel;
if (chnl_bw == CHANNEL_WIDTH_80) {
if (channel == 36 || channel == 40 || channel == 44 || channel == 48)
center_ch = 42;
else if (channel == 52 || channel == 56 || channel == 60 || channel == 64)
center_ch = 58;
else if (channel == 100 || channel == 104 || channel == 108 || channel == 112)
center_ch = 106;
else if (channel == 116 || channel == 120 || channel == 124 || channel == 128)
center_ch = 122;
else if (channel == 132 || channel == 136 || channel == 140 || channel == 144)
center_ch = 138;
else if (channel == 149 || channel == 153 || channel == 157 || channel == 161)
center_ch = 155;
else if (channel == 165 || channel == 169 || channel == 173 || channel == 177)
center_ch = 171;
else if (channel <= 14)
center_ch = 7;
} else if (chnl_bw == CHANNEL_WIDTH_40) {
if (chnl_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
center_ch = channel + 2;
else
center_ch = channel - 2;
} else if (chnl_bw == CHANNEL_WIDTH_20)
center_ch = channel;
else
rtw_warn_on(1);
return center_ch;
}
inline systime rtw_get_on_oper_ch_time(_adapter *adapter)
{
return adapter_to_dvobj(adapter)->on_oper_ch_time;
}
inline systime rtw_get_on_cur_ch_time(_adapter *adapter)
{
if (adapter->mlmeextpriv.cur_channel == adapter_to_dvobj(adapter)->oper_channel)
return adapter_to_dvobj(adapter)->on_oper_ch_time;
else
return 0;
}
void set_channel_bwmode(_adapter *padapter, unsigned char channel, unsigned char channel_offset, unsigned short bwmode)
{
u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
#if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
u8 iqk_info_backup = _FALSE;
#endif
if (padapter->bNotifyChannelChange)
RTW_INFO("[%s] ch = %d, offset = %d, bwmode = %d\n", __FUNCTION__, channel, channel_offset, bwmode);
center_ch = rtw_get_center_ch(channel, bwmode, channel_offset);
if (bwmode == CHANNEL_WIDTH_80) {
if (center_ch > channel)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
else if (center_ch < channel)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
else
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
_enter_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter)) {
/* driver doesn't set channel setting reg under MCC */
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
RTW_INFO("Warning: Do not set channel setting reg MCC mode\n");
}
#endif
#ifdef CONFIG_DFS_MASTER
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
bool ori_overlap_radar_detect_ch = rtw_rfctl_overlap_radar_detect_ch(rfctl);
bool new_overlap_radar_detect_ch = _rtw_rfctl_overlap_radar_detect_ch(rfctl, channel, bwmode, channel_offset);
if (new_overlap_radar_detect_ch && IS_CH_WAITING(rfctl)) {
u8 pause = 0xFF;
rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &pause);
}
#endif /* CONFIG_DFS_MASTER */
/* set Channel */
/* saved channel/bw info */
rtw_set_oper_ch(padapter, channel);
rtw_set_oper_bw(padapter, bwmode);
rtw_set_oper_choffset(padapter, channel_offset);
#if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
/* To check if we need to backup iqk info after switch chnl & bw */
{
u8 take_care_iqk, do_iqk;
rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
rtw_hal_get_hwreg(padapter, HW_VAR_DO_IQK, &do_iqk);
if ((take_care_iqk == _TRUE) && (do_iqk == _TRUE))
iqk_info_backup = _TRUE;
}
#endif
rtw_hal_set_chnl_bw(padapter, center_ch, bwmode, channel_offset, chnl_offset80); /* set center channel */
#if (defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)) || defined(CONFIG_MCC_MODE)
if (iqk_info_backup == _TRUE)
rtw_hal_ch_sw_iqk_info_backup(padapter);
#endif
#ifdef CONFIG_DFS_MASTER
if (new_overlap_radar_detect_ch)
rtw_odm_radar_detect_enable(padapter);
else if (ori_overlap_radar_detect_ch) {
u8 pause = 0x00;
rtw_odm_radar_detect_disable(padapter);
rtw_hal_set_hwreg(padapter, HW_VAR_TXPAUSE, &pause);
}
}
#endif /* CONFIG_DFS_MASTER */
_exit_critical_mutex(&(adapter_to_dvobj(padapter)->setch_mutex), NULL);
}
__inline u8 *get_my_bssid(WLAN_BSSID_EX *pnetwork)
{
return pnetwork->MacAddress;
}
u16 get_beacon_interval(WLAN_BSSID_EX *bss)
{
unsigned short val;
_rtw_memcpy((unsigned char *)&val, rtw_get_beacon_interval_from_ie(bss->IEs), 2);
return le16_to_cpu(val);
}
int is_client_associated_to_ap(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext;
struct mlme_ext_info *pmlmeinfo;
if (!padapter)
return _FAIL;
pmlmeext = &padapter->mlmeextpriv;
pmlmeinfo = &(pmlmeext->mlmext_info);
if ((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && ((pmlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE))
return _TRUE;
else
return _FAIL;
}
int is_client_associated_to_ibss(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if ((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) && ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
return _TRUE;
else
return _FAIL;
}
int is_IBSS_empty(_adapter *padapter)
{
int i;
struct macid_ctl_t *macid_ctl = &padapter->dvobj->macid_ctl;
for (i = 0; i < macid_ctl->num; i++) {
if (!rtw_macid_is_used(macid_ctl, i))
continue;
if (!rtw_macid_is_iface_specific(macid_ctl, i, padapter))
continue;
if (!GET_H2CCMD_MSRRPT_PARM_OPMODE(&macid_ctl->h2c_msr[i]))
continue;
if (GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[i]) == H2C_MSR_ROLE_ADHOC)
return _FAIL;
}
return _TRUE;
}
unsigned int decide_wait_for_beacon_timeout(unsigned int bcn_interval)
{
if ((bcn_interval << 2) < WAIT_FOR_BCN_TO_MIN)
return WAIT_FOR_BCN_TO_MIN;
else if ((bcn_interval << 2) > WAIT_FOR_BCN_TO_MAX)
return WAIT_FOR_BCN_TO_MAX;
else
return bcn_interval << 2;
}
void invalidate_cam_all(_adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
u8 val8 = 0;
rtw_hal_set_hwreg(padapter, HW_VAR_CAM_INVALID_ALL, &val8);
_enter_critical_bh(&cam_ctl->lock, &irqL);
rtw_sec_cam_map_clr_all(&cam_ctl->used);
_rtw_memset(dvobj->cam_cache, 0, sizeof(struct sec_cam_ent) * SEC_CAM_ENT_NUM_SW_LIMIT);
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
void _clear_cam_entry(_adapter *padapter, u8 entry)
{
unsigned char null_sta[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
unsigned char null_key[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
rtw_sec_write_cam_ent(padapter, entry, 0, null_sta, null_key);
}
inline void write_cam(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
{
#ifdef CONFIG_WRITE_CACHE_ONLY
write_cam_cache(adapter, id , ctrl, mac, key);
#else
rtw_sec_write_cam_ent(adapter, id, ctrl, mac, key);
write_cam_cache(adapter, id , ctrl, mac, key);
#endif
}
inline void clear_cam_entry(_adapter *adapter, u8 id)
{
_clear_cam_entry(adapter, id);
clear_cam_cache(adapter, id);
}
inline void write_cam_from_cache(_adapter *adapter, u8 id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
struct sec_cam_ent cache;
_enter_critical_bh(&cam_ctl->lock, &irqL);
_rtw_memcpy(&cache, &dvobj->cam_cache[id], sizeof(struct sec_cam_ent));
_exit_critical_bh(&cam_ctl->lock, &irqL);
rtw_sec_write_cam_ent(adapter, id, cache.ctrl, cache.mac, cache.key);
}
void write_cam_cache(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
_enter_critical_bh(&cam_ctl->lock, &irqL);
dvobj->cam_cache[id].ctrl = ctrl;
_rtw_memcpy(dvobj->cam_cache[id].mac, mac, ETH_ALEN);
_rtw_memcpy(dvobj->cam_cache[id].key, key, 16);
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
void clear_cam_cache(_adapter *adapter, u8 id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
_enter_critical_bh(&cam_ctl->lock, &irqL);
_rtw_memset(&(dvobj->cam_cache[id]), 0, sizeof(struct sec_cam_ent));
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
inline bool _rtw_camctl_chk_cap(_adapter *adapter, u8 cap)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
if (cam_ctl->sec_cap & cap)
return _TRUE;
return _FALSE;
}
inline void _rtw_camctl_set_flags(_adapter *adapter, u32 flags)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
cam_ctl->flags |= flags;
}
inline void rtw_camctl_set_flags(_adapter *adapter, u32 flags)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
_enter_critical_bh(&cam_ctl->lock, &irqL);
_rtw_camctl_set_flags(adapter, flags);
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
inline void _rtw_camctl_clr_flags(_adapter *adapter, u32 flags)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
cam_ctl->flags &= ~flags;
}
inline void rtw_camctl_clr_flags(_adapter *adapter, u32 flags)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
_enter_critical_bh(&cam_ctl->lock, &irqL);
_rtw_camctl_clr_flags(adapter, flags);
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
inline bool _rtw_camctl_chk_flags(_adapter *adapter, u32 flags)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
if (cam_ctl->flags & flags)
return _TRUE;
return _FALSE;
}
void dump_sec_cam_map(void *sel, struct sec_cam_bmp *map, u8 max_num)
{
RTW_PRINT_SEL(sel, "0x%08x\n", map->m0);
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
if (max_num && max_num > 32)
RTW_PRINT_SEL(sel, "0x%08x\n", map->m1);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
if (max_num && max_num > 64)
RTW_PRINT_SEL(sel, "0x%08x\n", map->m2);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
if (max_num && max_num > 96)
RTW_PRINT_SEL(sel, "0x%08x\n", map->m3);
#endif
}
inline bool rtw_sec_camid_is_set(struct sec_cam_bmp *map, u8 id)
{
if (id < 32)
return map->m0 & BIT(id);
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
else if (id < 64)
return map->m1 & BIT(id - 32);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
else if (id < 96)
return map->m2 & BIT(id - 64);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
else if (id < 128)
return map->m3 & BIT(id - 96);
#endif
else
rtw_warn_on(1);
return 0;
}
inline void rtw_sec_cam_map_set(struct sec_cam_bmp *map, u8 id)
{
if (id < 32)
map->m0 |= BIT(id);
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
else if (id < 64)
map->m1 |= BIT(id - 32);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
else if (id < 96)
map->m2 |= BIT(id - 64);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
else if (id < 128)
map->m3 |= BIT(id - 96);
#endif
else
rtw_warn_on(1);
}
inline void rtw_sec_cam_map_clr(struct sec_cam_bmp *map, u8 id)
{
if (id < 32)
map->m0 &= ~BIT(id);
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
else if (id < 64)
map->m1 &= ~BIT(id - 32);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
else if (id < 96)
map->m2 &= ~BIT(id - 64);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
else if (id < 128)
map->m3 &= ~BIT(id - 96);
#endif
else
rtw_warn_on(1);
}
inline void rtw_sec_cam_map_clr_all(struct sec_cam_bmp *map)
{
map->m0 = 0;
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
map->m1 = 0;
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
map->m2 = 0;
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
map->m3 = 0;
#endif
}
inline bool rtw_sec_camid_is_drv_forbid(struct cam_ctl_t *cam_ctl, u8 id)
{
struct sec_cam_bmp forbid_map;
forbid_map.m0 = 0x00000ff0;
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
forbid_map.m1 = 0x00000000;
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
forbid_map.m2 = 0x00000000;
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
forbid_map.m3 = 0x00000000;
#endif
if (id < 32)
return forbid_map.m0 & BIT(id);
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 32)
else if (id < 64)
return forbid_map.m1 & BIT(id - 32);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 64)
else if (id < 96)
return forbid_map.m2 & BIT(id - 64);
#endif
#if (SEC_CAM_ENT_NUM_SW_LIMIT > 96)
else if (id < 128)
return forbid_map.m3 & BIT(id - 96);
#endif
else
rtw_warn_on(1);
return 1;
}
bool _rtw_sec_camid_is_used(struct cam_ctl_t *cam_ctl, u8 id)
{
bool ret = _FALSE;
if (id >= cam_ctl->num) {
rtw_warn_on(1);
goto exit;
}
#if 0 /* for testing */
if (rtw_sec_camid_is_drv_forbid(cam_ctl, id)) {
ret = _TRUE;
goto exit;
}
#endif
ret = rtw_sec_camid_is_set(&cam_ctl->used, id);
exit:
return ret;
}
inline bool rtw_sec_camid_is_used(struct cam_ctl_t *cam_ctl, u8 id)
{
_irqL irqL;
bool ret;
_enter_critical_bh(&cam_ctl->lock, &irqL);
ret = _rtw_sec_camid_is_used(cam_ctl, id);
_exit_critical_bh(&cam_ctl->lock, &irqL);
return ret;
}
u8 rtw_get_sec_camid(_adapter *adapter, u8 max_bk_key_num, u8 *sec_key_id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
int i;
_irqL irqL;
u8 sec_cam_num = 0;
_enter_critical_bh(&cam_ctl->lock, &irqL);
for (i = 0; i < cam_ctl->num; i++) {
if (_rtw_sec_camid_is_used(cam_ctl, i)) {
sec_key_id[sec_cam_num++] = i;
if (sec_cam_num == max_bk_key_num)
break;
}
}
_exit_critical_bh(&cam_ctl->lock, &irqL);
return sec_cam_num;
}
inline bool _rtw_camid_is_gk(_adapter *adapter, u8 cam_id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
bool ret = _FALSE;
if (cam_id >= cam_ctl->num) {
rtw_warn_on(1);
goto exit;
}
if (_rtw_sec_camid_is_used(cam_ctl, cam_id) == _FALSE)
goto exit;
ret = (dvobj->cam_cache[cam_id].ctrl & BIT6) ? _TRUE : _FALSE;
exit:
return ret;
}
inline bool rtw_camid_is_gk(_adapter *adapter, u8 cam_id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
bool ret;
_enter_critical_bh(&cam_ctl->lock, &irqL);
ret = _rtw_camid_is_gk(adapter, cam_id);
_exit_critical_bh(&cam_ctl->lock, &irqL);
return ret;
}
bool cam_cache_chk(_adapter *adapter, u8 id, u8 *addr, s16 kid, s8 gk)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
bool ret = _FALSE;
if (addr && _rtw_memcmp(dvobj->cam_cache[id].mac, addr, ETH_ALEN) == _FALSE)
goto exit;
if (kid >= 0 && kid != (dvobj->cam_cache[id].ctrl & 0x03))
goto exit;
if (gk != -1 && (gk ? _TRUE : _FALSE) != _rtw_camid_is_gk(adapter, id))
goto exit;
ret = _TRUE;
exit:
return ret;
}
s16 _rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
int i;
s16 cam_id = -1;
for (i = 0; i < cam_ctl->num; i++) {
if (cam_cache_chk(adapter, i, addr, kid, gk)) {
cam_id = i;
break;
}
}
if (0) {
if (addr)
RTW_INFO(FUNC_ADPT_FMT" addr:"MAC_FMT" kid:%d, gk:%d, return cam_id:%d\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), kid, gk, cam_id);
else
RTW_INFO(FUNC_ADPT_FMT" addr:%p kid:%d, gk:%d, return cam_id:%d\n"
, FUNC_ADPT_ARG(adapter), addr, kid, gk, cam_id);
}
return cam_id;
}
s16 rtw_camid_search(_adapter *adapter, u8 *addr, s16 kid, s8 gk)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
s16 cam_id = -1;
_enter_critical_bh(&cam_ctl->lock, &irqL);
cam_id = _rtw_camid_search(adapter, addr, kid, gk);
_exit_critical_bh(&cam_ctl->lock, &irqL);
return cam_id;
}
s16 rtw_get_camid(_adapter *adapter, u8 *addr, s16 kid, u8 gk)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
int i;
#if 0 /* for testing */
static u8 start_id = 0;
#else
u8 start_id = 0;
#endif
s16 cam_id = -1;
if (addr == NULL) {
RTW_PRINT(FUNC_ADPT_FMT" mac_address is NULL\n"
, FUNC_ADPT_ARG(adapter));
rtw_warn_on(1);
goto _exit;
}
/* find cam entry which has the same addr, kid (, gk bit) */
if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC) == _TRUE)
i = _rtw_camid_search(adapter, addr, kid, gk);
else
i = _rtw_camid_search(adapter, addr, kid, -1);
if (i >= 0) {
cam_id = i;
goto _exit;
}
for (i = 0; i < cam_ctl->num; i++) {
/* bypass default key which is allocated statically */
#ifndef CONFIG_CONCURRENT_MODE
if (((i + start_id) % cam_ctl->num) < 4)
continue;
#endif
if (_rtw_sec_camid_is_used(cam_ctl, ((i + start_id) % cam_ctl->num)) == _FALSE)
break;
}
if (i == cam_ctl->num) {
RTW_PRINT(FUNC_ADPT_FMT" %s key with "MAC_FMT" id:%u no room\n"
, FUNC_ADPT_ARG(adapter), gk ? "group" : "pairwise", MAC_ARG(addr), kid);
rtw_warn_on(1);
goto _exit;
}
cam_id = ((i + start_id) % cam_ctl->num);
start_id = ((i + start_id + 1) % cam_ctl->num);
_exit:
return cam_id;
}
s16 rtw_camid_alloc(_adapter *adapter, struct sta_info *sta, u8 kid, u8 gk, bool *used)
{
struct mlme_ext_info *mlmeinfo = &adapter->mlmeextpriv.mlmext_info;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
s16 cam_id = -1;
*used = _FALSE;
_enter_critical_bh(&cam_ctl->lock, &irqL);
if ((((mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) || ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE))
&& !sta) {
/*
* 1. non-STA mode WEP key
* 2. group TX key
*/
#ifndef CONFIG_CONCURRENT_MODE
/* static alloction to default key by key ID when concurrent is not defined */
if (kid > 3) {
RTW_PRINT(FUNC_ADPT_FMT" group key with invalid key id:%u\n"
, FUNC_ADPT_ARG(adapter), kid);
rtw_warn_on(1);
goto bitmap_handle;
}
cam_id = kid;
#else
u8 *addr = adapter_mac_addr(adapter);
cam_id = rtw_get_camid(adapter, addr, kid, gk);
if (1)
RTW_PRINT(FUNC_ADPT_FMT" group key with "MAC_FMT" assigned cam_id:%u\n"
, FUNC_ADPT_ARG(adapter), MAC_ARG(addr), cam_id);
#endif
} else {
/*
* 1. STA mode WEP key
* 2. STA mode group RX key
* 3. sta key (pairwise, group RX)
*/
u8 *addr = sta ? sta->cmn.mac_addr : NULL;
if (!sta) {
if (!(mlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
/* bypass STA mode group key setting before connected(ex:WEP) because bssid is not ready */
goto bitmap_handle;
}
addr = get_bssid(&adapter->mlmepriv);/*A2*/
}
cam_id = rtw_get_camid(adapter, addr, kid, gk);
}
bitmap_handle:
if (cam_id >= 0) {
*used = _rtw_sec_camid_is_used(cam_ctl, cam_id);
rtw_sec_cam_map_set(&cam_ctl->used, cam_id);
}
_exit_critical_bh(&cam_ctl->lock, &irqL);
return cam_id;
}
void rtw_camid_set(_adapter *adapter, u8 cam_id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
_enter_critical_bh(&cam_ctl->lock, &irqL);
if (cam_id < cam_ctl->num)
rtw_sec_cam_map_set(&cam_ctl->used, cam_id);
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
void rtw_camid_free(_adapter *adapter, u8 cam_id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
_enter_critical_bh(&cam_ctl->lock, &irqL);
if (cam_id < cam_ctl->num)
rtw_sec_cam_map_clr(&cam_ctl->used, cam_id);
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
/*Must pause TX/RX before use this API*/
inline void rtw_sec_cam_swap(_adapter *adapter, u8 cam_id_a, u8 cam_id_b)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
struct sec_cam_ent cache_a, cache_b;
_irqL irqL;
bool cam_a_used, cam_b_used;
if (1)
RTW_INFO(ADPT_FMT" - sec_cam %d,%d swap\n", ADPT_ARG(adapter), cam_id_a, cam_id_b);
if (cam_id_a == cam_id_b)
return;
#ifdef CONFIG_CONCURRENT_MODE
rtw_mi_update_ap_bmc_camid(adapter, cam_id_a, cam_id_b);
#endif
/*setp-1. backup org cam_info*/
_enter_critical_bh(&cam_ctl->lock, &irqL);
cam_a_used = _rtw_sec_camid_is_used(cam_ctl, cam_id_a);
cam_b_used = _rtw_sec_camid_is_used(cam_ctl, cam_id_b);
if (cam_a_used)
_rtw_memcpy(&cache_a, &dvobj->cam_cache[cam_id_a], sizeof(struct sec_cam_ent));
if (cam_b_used)
_rtw_memcpy(&cache_b, &dvobj->cam_cache[cam_id_b], sizeof(struct sec_cam_ent));
_exit_critical_bh(&cam_ctl->lock, &irqL);
/*setp-2. clean cam_info*/
if (cam_a_used) {
rtw_camid_free(adapter, cam_id_a);
clear_cam_entry(adapter, cam_id_a);
}
if (cam_b_used) {
rtw_camid_free(adapter, cam_id_b);
clear_cam_entry(adapter, cam_id_b);
}
/*setp-3. set cam_info*/
if (cam_a_used) {
write_cam(adapter, cam_id_b, cache_a.ctrl, cache_a.mac, cache_a.key);
rtw_camid_set(adapter, cam_id_b);
}
if (cam_b_used) {
write_cam(adapter, cam_id_a, cache_b.ctrl, cache_b.mac, cache_b.key);
rtw_camid_set(adapter, cam_id_a);
}
}
s16 rtw_get_empty_cam_entry(_adapter *adapter, u8 start_camid)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
int i;
s16 cam_id = -1;
_enter_critical_bh(&cam_ctl->lock, &irqL);
for (i = start_camid; i < cam_ctl->num; i++) {
if (_FALSE == _rtw_sec_camid_is_used(cam_ctl, i)) {
cam_id = i;
break;
}
}
_exit_critical_bh(&cam_ctl->lock, &irqL);
return cam_id;
}
void rtw_clean_dk_section(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
s16 ept_cam_id;
int i;
for (i = 0; i < 4; i++) {
if (rtw_sec_camid_is_used(cam_ctl, i)) {
ept_cam_id = rtw_get_empty_cam_entry(adapter, 4);
if (ept_cam_id > 0)
rtw_sec_cam_swap(adapter, i, ept_cam_id);
}
}
}
void rtw_clean_hw_dk_cam(_adapter *adapter)
{
int i;
for (i = 0; i < 4; i++)
rtw_sec_clr_cam_ent(adapter, i);
/*_clear_cam_entry(adapter, i);*/
}
void flush_all_cam_entry(_adapter *padapter)
{
#ifdef CONFIG_CONCURRENT_MODE
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct security_priv *psecpriv = &padapter->securitypriv;
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
psta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
if (psta) {
if (psta->state & WIFI_AP_STATE) {
/*clear cam when ap free per sta_info*/
} else
rtw_clearstakey_cmd(padapter, psta, _FALSE);
}
} else if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
#if 1
int cam_id = -1;
u8 *addr = adapter_mac_addr(padapter);
while ((cam_id = rtw_camid_search(padapter, addr, -1, -1)) >= 0) {
RTW_PRINT("clear wep or group key for addr:"MAC_FMT", camid:%d\n", MAC_ARG(addr), cam_id);
clear_cam_entry(padapter, cam_id);
rtw_camid_free(padapter, cam_id);
}
#else
/* clear default key */
int i, cam_id;
u8 null_addr[ETH_ALEN] = {0, 0, 0, 0, 0, 0};
for (i = 0; i < 4; i++) {
cam_id = rtw_camid_search(padapter, null_addr, i, -1);
if (cam_id >= 0) {
clear_cam_entry(padapter, cam_id);
rtw_camid_free(padapter, cam_id);
}
}
/* clear default key related key search setting */
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8 *)_FALSE);
#endif
}
#else /*NON CONFIG_CONCURRENT_MODE*/
invalidate_cam_all(padapter);
/* clear default key related key search setting */
rtw_hal_set_hwreg(padapter, HW_VAR_SEC_DK_CFG, (u8 *)_FALSE);
#endif
}
#if defined(CONFIG_P2P) && defined(CONFIG_WFD)
void rtw_process_wfd_ie(_adapter *adapter, u8 *wfd_ie, u8 wfd_ielen, const char *tag)
{
struct wifidirect_info *wdinfo = &adapter->wdinfo;
u8 *attr_content;
u32 attr_contentlen = 0;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
return;
RTW_INFO("[%s] Found WFD IE\n", tag);
attr_content = rtw_get_wfd_attr_content(wfd_ie, wfd_ielen, WFD_ATTR_DEVICE_INFO, NULL, &attr_contentlen);
if (attr_content && attr_contentlen) {
wdinfo->wfd_info->peer_rtsp_ctrlport = RTW_GET_BE16(attr_content + 2);
RTW_INFO("[%s] Peer PORT NUM = %d\n", tag, wdinfo->wfd_info->peer_rtsp_ctrlport);
}
}
void rtw_process_wfd_ies(_adapter *adapter, u8 *ies, u8 ies_len, const char *tag)
{
u8 *wfd_ie;
u32 wfd_ielen;
if (!hal_chk_wl_func(adapter, WL_FUNC_MIRACAST))
return;
wfd_ie = rtw_get_wfd_ie(ies, ies_len, NULL, &wfd_ielen);
while (wfd_ie) {
rtw_process_wfd_ie(adapter, wfd_ie, wfd_ielen, tag);
wfd_ie = rtw_get_wfd_ie(wfd_ie + wfd_ielen, (ies + ies_len) - (wfd_ie + wfd_ielen), NULL, &wfd_ielen);
}
}
#endif /* defined(CONFIG_P2P) && defined(CONFIG_WFD) */
int WMM_param_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
/* struct registry_priv *pregpriv = &padapter->registrypriv; */
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pmlmepriv->qospriv.qos_option == 0) {
pmlmeinfo->WMM_enable = 0;
return _FALSE;
}
if (_rtw_memcmp(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element)))
return _FALSE;
else
_rtw_memcpy(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element));
pmlmeinfo->WMM_enable = 1;
return _TRUE;
#if 0
if (pregpriv->wifi_spec == 1) {
if (pmlmeinfo->WMM_enable == 1) {
/* todo: compare the parameter set count & decide wheher to update or not */
return _FAIL;
} else {
pmlmeinfo->WMM_enable = 1;
_rtw_rtw_memcpy(&(pmlmeinfo->WMM_param), (pIE->data + 6), sizeof(struct WMM_para_element));
return _TRUE;
}
} else {
pmlmeinfo->WMM_enable = 0;
return _FAIL;
}
#endif
}
void WMMOnAssocRsp(_adapter *padapter)
{
u8 ACI, ACM, AIFS, ECWMin, ECWMax, aSifsTime;
u8 acm_mask;
u16 TXOP;
u32 acParm, i;
u32 edca[4], inx[4];
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct registry_priv *pregpriv = &padapter->registrypriv;
#ifdef CONFIG_WMMPS_STA
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
#endif /* CONFIG_WMMPS_STA */
acm_mask = 0;
if (is_supported_5g(pmlmeext->cur_wireless_mode) ||
(pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
aSifsTime = 16;
else
aSifsTime = 10;
if (pmlmeinfo->WMM_enable == 0) {
padapter->mlmepriv.acm_mask = 0;
AIFS = aSifsTime + (2 * pmlmeinfo->slotTime);
if (pmlmeext->cur_wireless_mode & (WIRELESS_11G | WIRELESS_11A)) {
ECWMin = 4;
ECWMax = 10;
} else if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
ECWMin = 5;
ECWMax = 10;
} else {
ECWMin = 4;
ECWMax = 10;
}
TXOP = 0;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
ECWMin = 2;
ECWMax = 3;
TXOP = 0x2f;
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
} else {
edca[0] = edca[1] = edca[2] = edca[3] = 0;
for (i = 0; i < 4; i++) {
ACI = (pmlmeinfo->WMM_param.ac_param[i].ACI_AIFSN >> 5) & 0x03;
ACM = (pmlmeinfo->WMM_param.ac_param[i].ACI_AIFSN >> 4) & 0x01;
/* AIFS = AIFSN * slot time + SIFS - r2t phy delay */
AIFS = (pmlmeinfo->WMM_param.ac_param[i].ACI_AIFSN & 0x0f) * pmlmeinfo->slotTime + aSifsTime;
ECWMin = (pmlmeinfo->WMM_param.ac_param[i].CW & 0x0f);
ECWMax = (pmlmeinfo->WMM_param.ac_param[i].CW & 0xf0) >> 4;
TXOP = le16_to_cpu(pmlmeinfo->WMM_param.ac_param[i].TXOP_limit);
acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
switch (ACI) {
case 0x0:
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
acm_mask |= (ACM ? BIT(1) : 0);
edca[XMIT_BE_QUEUE] = acParm;
break;
case 0x1:
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_BK, (u8 *)(&acParm));
/* acm_mask |= (ACM? BIT(0):0); */
edca[XMIT_BK_QUEUE] = acParm;
break;
case 0x2:
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VI, (u8 *)(&acParm));
acm_mask |= (ACM ? BIT(2) : 0);
edca[XMIT_VI_QUEUE] = acParm;
break;
case 0x3:
rtw_hal_set_hwreg(padapter, HW_VAR_AC_PARAM_VO, (u8 *)(&acParm));
acm_mask |= (ACM ? BIT(3) : 0);
edca[XMIT_VO_QUEUE] = acParm;
break;
}
RTW_INFO("WMM(%x): %x, %x\n", ACI, ACM, acParm);
}
if (padapter->registrypriv.acm_method == 1)
rtw_hal_set_hwreg(padapter, HW_VAR_ACM_CTRL, (u8 *)(&acm_mask));
else
padapter->mlmepriv.acm_mask = acm_mask;
inx[0] = 0;
inx[1] = 1;
inx[2] = 2;
inx[3] = 3;
if (pregpriv->wifi_spec == 1) {
u32 j, tmp, change_inx = _FALSE;
/* entry indx: 0->vo, 1->vi, 2->be, 3->bk. */
for (i = 0; i < 4; i++) {
for (j = i + 1; j < 4; j++) {
/* compare CW and AIFS */
if ((edca[j] & 0xFFFF) < (edca[i] & 0xFFFF))
change_inx = _TRUE;
else if ((edca[j] & 0xFFFF) == (edca[i] & 0xFFFF)) {
/* compare TXOP */
if ((edca[j] >> 16) > (edca[i] >> 16))
change_inx = _TRUE;
}
if (change_inx) {
tmp = edca[i];
edca[i] = edca[j];
edca[j] = tmp;
tmp = inx[i];
inx[i] = inx[j];
inx[j] = tmp;
change_inx = _FALSE;
}
}
}
}
for (i = 0; i < 4; i++) {
pxmitpriv->wmm_para_seq[i] = inx[i];
RTW_INFO("wmm_para_seq(%d): %d\n", i, pxmitpriv->wmm_para_seq[i]);
}
#ifdef CONFIG_WMMPS_STA
/* if AP supports UAPSD function, driver must set each uapsd TID to coresponding mac register 0x693 */
if (pmlmeinfo->WMM_param.QoS_info & AP_SUPPORTED_UAPSD) {
pqospriv->uapsd_ap_supported = 1;
rtw_hal_set_hwreg(padapter, HW_VAR_UAPSD_TID, NULL);
}
#endif /* CONFIG_WMMPS_STA */
}
}
static void bwmode_update_check(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
#ifdef CONFIG_80211N_HT
unsigned char new_bwmode;
unsigned char new_ch_offset;
struct HT_info_element *pHT_info;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct registry_priv *pregistrypriv = &padapter->registrypriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
u8 cbw40_enable = 0;
if (!pIE)
return;
if (phtpriv->ht_option == _FALSE)
return;
if (pmlmeext->cur_bwmode >= CHANNEL_WIDTH_80)
return;
if (pIE->Length > sizeof(struct HT_info_element))
return;
pHT_info = (struct HT_info_element *)pIE->data;
if (hal_chk_bw_cap(padapter, BW_CAP_40M)) {
if (pmlmeext->cur_channel > 14) {
if (REGSTY_IS_BW_5G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
cbw40_enable = 1;
} else {
if (REGSTY_IS_BW_2G_SUPPORT(pregistrypriv, CHANNEL_WIDTH_40))
cbw40_enable = 1;
}
}
if ((pHT_info->infos[0] & BIT(2)) && cbw40_enable) {
new_bwmode = CHANNEL_WIDTH_40;
switch (pHT_info->infos[0] & 0x3) {
case 1:
new_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case 3:
new_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
default:
new_bwmode = CHANNEL_WIDTH_20;
new_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
break;
}
} else {
new_bwmode = CHANNEL_WIDTH_20;
new_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
if ((new_bwmode != pmlmeext->cur_bwmode || new_ch_offset != pmlmeext->cur_ch_offset)
&& new_bwmode < pmlmeext->cur_bwmode
) {
pmlmeinfo->bwmode_updated = _TRUE;
pmlmeext->cur_bwmode = new_bwmode;
pmlmeext->cur_ch_offset = new_ch_offset;
/* update HT info also */
HT_info_handler(padapter, pIE);
} else
pmlmeinfo->bwmode_updated = _FALSE;
if (_TRUE == pmlmeinfo->bwmode_updated) {
struct sta_info *psta;
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
struct sta_priv *pstapriv = &padapter->stapriv;
/* set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
/* update ap's stainfo */
psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
if (psta) {
struct ht_priv *phtpriv_sta = &psta->htpriv;
if (phtpriv_sta->ht_option) {
/* bwmode */
psta->cmn.bw_mode = pmlmeext->cur_bwmode;
phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;
} else {
psta->cmn.bw_mode = CHANNEL_WIDTH_20;
phtpriv_sta->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
rtw_dm_ra_mask_wk_cmd(padapter, (u8 *)psta);
}
/* pmlmeinfo->bwmode_updated = _FALSE; */ /* bwmode_updated done, reset it! */
}
#endif /* CONFIG_80211N_HT */
}
#ifdef ROKU_PRIVATE
void Supported_rate_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
unsigned int i;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pIE == NULL)
return;
for (i = 0 ; i < pIE->Length; i++)
pmlmeinfo->SupportedRates_infra_ap[i] = (pIE->data[i]);
}
void Extended_Supported_rate_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
unsigned int i, j;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pIE == NULL)
return;
if (pIE->Length > 0) {
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
if (pmlmeinfo->SupportedRates_infra_ap[i] == 0)
break;
}
for (j = 0; j < pIE->Length; j++)
pmlmeinfo->SupportedRates_infra_ap[i+j] = (pIE->data[j]);
}
}
void HT_get_ss_from_mcs_set(u8 *mcs_set, u8 *Rx_ss)
{
u8 i, j;
u8 r_ss = 0, t_ss = 0;
for (i = 0; i < 4; i++) {
if ((mcs_set[3-i] & 0xff) != 0x00) {
r_ss = 4-i;
break;
}
}
*Rx_ss = r_ss;
}
void HT_caps_handler_infra_ap(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
unsigned int i;
u8 cur_stbc_cap_infra_ap = 0;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv_infra_ap *phtpriv = &pmlmepriv->htpriv_infra_ap;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pIE == NULL)
return;
pmlmeinfo->ht_vht_received |= BIT(0);
/*copy MCS_SET*/
for (i = 3; i < 19; i++)
phtpriv->MCS_set_infra_ap[i-3] = (pIE->data[i]);
/*get number of stream from mcs set*/
HT_get_ss_from_mcs_set(phtpriv->MCS_set_infra_ap, &phtpriv->Rx_ss_infra_ap);
phtpriv->rx_highest_data_rate_infra_ap = le16_to_cpu(GET_HT_CAP_ELE_RX_HIGHEST_DATA_RATE(pIE->data));
phtpriv->ldpc_cap_infra_ap = GET_HT_CAP_ELE_LDPC_CAP(pIE->data);
if (GET_HT_CAP_ELE_RX_STBC(pIE->data))
SET_FLAG(cur_stbc_cap_infra_ap, STBC_HT_ENABLE_RX);
if (GET_HT_CAP_ELE_TX_STBC(pIE->data))
SET_FLAG(cur_stbc_cap_infra_ap, STBC_HT_ENABLE_TX);
phtpriv->stbc_cap_infra_ap = cur_stbc_cap_infra_ap;
/*store ap info SGI 20m 40m*/
phtpriv->sgi_20m_infra_ap = GET_HT_CAP_ELE_SHORT_GI20M(pIE->data);
phtpriv->sgi_40m_infra_ap = GET_HT_CAP_ELE_SHORT_GI40M(pIE->data);
/*store ap info for supported channel bandwidth*/
phtpriv->channel_width_infra_ap = GET_HT_CAP_ELE_CHL_WIDTH(pIE->data);
}
#endif /* ROKU_PRIVATE */
void HT_caps_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
#ifdef CONFIG_80211N_HT
unsigned int i;
u8 rf_type = RF_1T1R;
u8 max_AMPDU_len, min_MPDU_spacing;
u8 cur_ldpc_cap = 0, cur_stbc_cap = 0, cur_beamform_cap = 0, tx_nss = 0;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
#ifdef CONFIG_DISABLE_MCS13TO15
struct registry_priv *pregistrypriv = &padapter->registrypriv;
#endif
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
if (pIE == NULL)
return;
if (phtpriv->ht_option == _FALSE)
return;
pmlmeinfo->HT_caps_enable = 1;
for (i = 0; i < (pIE->Length); i++) {
if (i != 2) {
/* Commented by Albert 2010/07/12 */
/* Got the endian issue here. */
pmlmeinfo->HT_caps.u.HT_cap[i] &= (pIE->data[i]);
} else {
/* AMPDU Parameters field */
/* Get MIN of MAX AMPDU Length Exp */
if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3) > (pIE->data[i] & 0x3))
max_AMPDU_len = (pIE->data[i] & 0x3);
else
max_AMPDU_len = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x3);
/* Get MAX of MIN MPDU Start Spacing */
if ((pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) > (pIE->data[i] & 0x1c))
min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c);
else
min_MPDU_spacing = (pIE->data[i] & 0x1c);
pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para = max_AMPDU_len | min_MPDU_spacing;
}
}
/* Commented by Albert 2010/07/12 */
/* Have to handle the endian issue after copying. */
/* HT_ext_caps didn't be used yet. */
pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info = le16_to_cpu(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info);
pmlmeinfo->HT_caps.u.HT_cap_element.HT_ext_caps = le16_to_cpu(pmlmeinfo->HT_caps.u.HT_cap_element.HT_ext_caps);
/* update the MCS set */
for (i = 0; i < 16; i++)
pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate[i] &= pmlmeext->default_supported_mcs_set[i];
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
switch (tx_nss) {
case 1:
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_1R);
break;
case 2:
#ifdef CONFIG_DISABLE_MCS13TO15
if (pmlmeext->cur_bwmode == CHANNEL_WIDTH_40 && pregistrypriv->wifi_spec != 1)
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R_13TO15_OFF);
else
#endif
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_2R);
break;
case 3:
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_3R);
break;
case 4:
set_mcs_rate_by_mask(pmlmeinfo->HT_caps.u.HT_cap_element.MCS_rate, MCS_RATE_4R);
break;
default:
RTW_WARN("rf_type:%d or tx_nss:%u is not expected\n", rf_type, hal_spec->tx_nss_num);
}
if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
/* Config STBC setting */
if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(pIE->data)) {
SET_FLAG(cur_stbc_cap, STBC_HT_ENABLE_TX);
RTW_INFO("Enable HT Tx STBC !\n");
}
phtpriv->stbc_cap = cur_stbc_cap;
#ifdef CONFIG_BEAMFORMING
/* Config Tx beamforming setting */
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
/* Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pIE->data) << 6);
}
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
/* Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pIE->data) << 4);
}
phtpriv->beamform_cap = cur_beamform_cap;
if (cur_beamform_cap)
RTW_INFO("AP HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
#endif /*CONFIG_BEAMFORMING*/
} else {
/*WIFI_STATION_STATEorI_ADHOC_STATE or WIFI_ADHOC_MASTER_STATE*/
/* Config LDPC Coding Capability */
if (TEST_FLAG(phtpriv->ldpc_cap, LDPC_HT_ENABLE_TX) && GET_HT_CAP_ELE_LDPC_CAP(pIE->data)) {
SET_FLAG(cur_ldpc_cap, (LDPC_HT_ENABLE_TX | LDPC_HT_CAP_TX));
RTW_INFO("Enable HT Tx LDPC!\n");
}
phtpriv->ldpc_cap = cur_ldpc_cap;
/* Config STBC setting */
if (TEST_FLAG(phtpriv->stbc_cap, STBC_HT_ENABLE_TX) && GET_HT_CAP_ELE_RX_STBC(pIE->data)) {
SET_FLAG(cur_stbc_cap, (STBC_HT_ENABLE_TX | STBC_HT_CAP_TX));
RTW_INFO("Enable HT Tx STBC!\n");
}
phtpriv->stbc_cap = cur_stbc_cap;
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
/* Config beamforming setting */
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
/* Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pIE->data) << 6);
}
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
/* Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pIE->data) << 4);
}
#else /* !RTW_BEAMFORMING_VERSION_2 */
/* Config Tx beamforming setting */
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_STEERING_CAP(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE);
/* Shift to BEAMFORMING_HT_BEAMFORMEE_CHNL_EST_CAP*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_CHNL_ESTIMATION_NUM_ANTENNAS(pIE->data) << 6);
}
if (TEST_FLAG(phtpriv->beamform_cap, BEAMFORMING_HT_BEAMFORMER_ENABLE) &&
GET_HT_CAP_TXBF_EXPLICIT_COMP_FEEDBACK_CAP(pIE->data)) {
SET_FLAG(cur_beamform_cap, BEAMFORMING_HT_BEAMFORMEE_ENABLE);
/* Shift to BEAMFORMING_HT_BEAMFORMER_STEER_NUM*/
SET_FLAG(cur_beamform_cap, GET_HT_CAP_TXBF_COMP_STEERING_NUM_ANTENNAS(pIE->data) << 4);
}
#endif /* !RTW_BEAMFORMING_VERSION_2 */
phtpriv->beamform_cap = cur_beamform_cap;
if (cur_beamform_cap)
RTW_INFO("Client HT Beamforming Cap = 0x%02X\n", cur_beamform_cap);
#endif /*CONFIG_BEAMFORMING*/
}
#endif /* CONFIG_80211N_HT */
}
void HT_info_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
#ifdef CONFIG_80211N_HT
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
if (pIE == NULL)
return;
if (phtpriv->ht_option == _FALSE)
return;
if (pIE->Length > sizeof(struct HT_info_element))
return;
pmlmeinfo->HT_info_enable = 1;
_rtw_memcpy(&(pmlmeinfo->HT_info), pIE->data, pIE->Length);
#endif /* CONFIG_80211N_HT */
return;
}
void HTOnAssocRsp(_adapter *padapter)
{
unsigned char max_AMPDU_len;
unsigned char min_MPDU_spacing;
/* struct registry_priv *pregpriv = &padapter->registrypriv; */
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
RTW_INFO("%s\n", __FUNCTION__);
if ((pmlmeinfo->HT_info_enable) && (pmlmeinfo->HT_caps_enable))
pmlmeinfo->HT_enable = 1;
else {
pmlmeinfo->HT_enable = 0;
/* set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
return;
}
/* handle A-MPDU parameter field */
/*
AMPDU_para [1:0]:Max AMPDU Len => 0:8k , 1:16k, 2:32k, 3:64k
AMPDU_para [4:2]:Min MPDU Start Spacing
*/
max_AMPDU_len = pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x03;
min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
#ifdef CONFIG_80211N_HT
rtw_hal_set_hwreg(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
#endif /* CONFIG_80211N_HT */
#if 0 /* move to rtw_update_ht_cap() */
if ((pregpriv->bw_mode > 0) &&
(pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & BIT(1)) &&
(pmlmeinfo->HT_info.infos[0] & BIT(2))) {
/* switch to the 40M Hz mode accoring to the AP */
pmlmeext->cur_bwmode = CHANNEL_WIDTH_40;
switch ((pmlmeinfo->HT_info.infos[0] & 0x3)) {
case EXTCHNL_OFFSET_UPPER:
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
break;
case EXTCHNL_OFFSET_LOWER:
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
break;
default:
pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
break;
}
}
#endif
/* set_channel_bwmode(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
#if 0 /* move to rtw_update_ht_cap() */
/* */
/* Config SM Power Save setting */
/* */
pmlmeinfo->SM_PS = (pmlmeinfo->HT_caps.u.HT_cap_element.HT_caps_info & 0x0C) >> 2;
if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC) {
#if 0
u8 i;
/* update the MCS rates */
for (i = 0; i < 16; i++)
pmlmeinfo->HT_caps.HT_cap_element.MCS_rate[i] &= MCS_rate_1R[i];
#endif
RTW_INFO("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __FUNCTION__);
}
/* */
/* Config current HT Protection mode. */
/* */
pmlmeinfo->HT_protection = pmlmeinfo->HT_info.infos[1] & 0x3;
#endif
}
void ERP_IE_handler(_adapter *padapter, PNDIS_802_11_VARIABLE_IEs pIE)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (pIE->Length > 1)
return;
pmlmeinfo->ERP_enable = 1;
_rtw_memcpy(&(pmlmeinfo->ERP_IE), pIE->data, pIE->Length);
}
void VCS_update(_adapter *padapter, struct sta_info *psta)
{
struct registry_priv *pregpriv = &padapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
switch (pregpriv->vrtl_carrier_sense) { /* 0:off 1:on 2:auto */
case 0: /* off */
psta->rtsen = 0;
psta->cts2self = 0;
break;
case 1: /* on */
if (pregpriv->vcs_type == 1) { /* 1:RTS/CTS 2:CTS to self */
psta->rtsen = 1;
psta->cts2self = 0;
} else {
psta->rtsen = 0;
psta->cts2self = 1;
}
break;
case 2: /* auto */
default:
if (((pmlmeinfo->ERP_enable) && (pmlmeinfo->ERP_IE & BIT(1)))
/*||(pmlmepriv->ht_op_mode & HT_INFO_OPERATION_MODE_NON_GF_DEVS_PRESENT)*/
) {
if (pregpriv->vcs_type == 1) {
psta->rtsen = 1;
psta->cts2self = 0;
} else {
psta->rtsen = 0;
psta->cts2self = 1;
}
} else {
psta->rtsen = 0;
psta->cts2self = 0;
}
break;
}
}
void update_ldpc_stbc_cap(struct sta_info *psta)
{
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_80211AC_VHT
if (psta->vhtpriv.vht_option) {
if (TEST_FLAG(psta->vhtpriv.ldpc_cap, LDPC_VHT_ENABLE_TX))
psta->cmn.ldpc_en = VHT_LDPC_EN;
else
psta->cmn.ldpc_en = 0;
if (TEST_FLAG(psta->vhtpriv.stbc_cap, STBC_VHT_ENABLE_TX))
psta->cmn.stbc_en = VHT_STBC_EN;
else
psta->cmn.stbc_en = 0;
} else
#endif /* CONFIG_80211AC_VHT */
if (psta->htpriv.ht_option) {
if (TEST_FLAG(psta->htpriv.ldpc_cap, LDPC_HT_ENABLE_TX))
psta->cmn.ldpc_en = HT_LDPC_EN;
else
psta->cmn.ldpc_en = 0;
if (TEST_FLAG(psta->htpriv.stbc_cap, STBC_HT_ENABLE_TX))
psta->cmn.stbc_en = HT_STBC_EN;
else
psta->cmn.stbc_en = 0;
} else {
psta->cmn.ldpc_en = 0;
psta->cmn.stbc_en = 0;
}
#endif /* CONFIG_80211N_HT */
}
int check_ielen(u8 *start, uint len)
{
int left = len;
u8 *pos = start;
u8 id, elen;
while (left >= 2) {
id = *pos++;
elen = *pos++;
left -= 2;
if (elen > left) {
RTW_INFO("IEEE 802.11 element parse failed (id=%d elen=%d left=%lu)\n",
id, elen, (unsigned long) left);
return _FALSE;
}
if ((id == WLAN_EID_VENDOR_SPECIFIC) && (elen < 3))
return _FALSE;
left -= elen;
pos += elen;
}
if (left)
return _FALSE;
return _TRUE;
}
int validate_beacon_len(u8 *pframe, u32 len)
{
u8 ie_offset = _BEACON_IE_OFFSET_ + sizeof(struct rtw_ieee80211_hdr_3addr);
if (len < ie_offset) {
RTW_INFO("%s: incorrect beacon length(%d)\n", __func__, len);
return _FALSE;
}
if (check_ielen(pframe + ie_offset, len - ie_offset) == _FALSE)
return _FALSE;
return _TRUE;
}
u8 support_rate_ranges[] = {
IEEE80211_CCK_RATE_1MB,
IEEE80211_CCK_RATE_2MB,
IEEE80211_CCK_RATE_5MB,
IEEE80211_CCK_RATE_11MB,
IEEE80211_OFDM_RATE_6MB,
IEEE80211_OFDM_RATE_9MB,
IEEE80211_OFDM_RATE_12MB,
IEEE80211_OFDM_RATE_18MB,
IEEE80211_OFDM_RATE_24MB,
IEEE80211_OFDM_RATE_36MB,
IEEE80211_OFDM_RATE_48MB,
IEEE80211_OFDM_RATE_54MB,
IEEE80211_PBCC_RATE_22MB,
IEEE80211_PBCC_RATE_33MB,
};
inline bool match_ranges(u16 EID, u32 value)
{
int i;
int nr_range;
switch (EID) {
case _EXT_SUPPORTEDRATES_IE_:
case _SUPPORTEDRATES_IE_:
nr_range = sizeof(support_rate_ranges)/sizeof(u8);
for (i = 0; i < nr_range; i++) {
/* clear bit7 before searching. */
value &= ~BIT(7);
if (value == support_rate_ranges[i])
return _TRUE;
}
break;
default:
break;
};
return _FALSE;
}
/*
* rtw_validate_value: validate the IE contain.
*
* Input :
* EID : Element ID
* p : IE buffer (without EID & length)
* len : IE length
* return:
* _TRUE : All Values are validated.
* _FALSE : At least one value is NOT validated.
*/
bool rtw_validate_value(u16 EID, u8 *p, u16 len)
{
u8 rate;
u32 i, nr_val;
switch (EID) {
case _EXT_SUPPORTEDRATES_IE_:
case _SUPPORTEDRATES_IE_:
nr_val = len;
for (i=0; iSsid.Ssid, snetwork->Ssid.SsidLength);
}
/*
Get SSID if this ilegal frame(probe resp) comes from a hidden SSID AP.
Update the SSID to the corresponding pnetwork in scan queue.
*/
void rtw_absorb_ssid_ifneed(_adapter *padapter, WLAN_BSSID_EX *bssid, u8 *pframe)
{
struct wlan_network *scanned = NULL;
WLAN_BSSID_EX *snetwork;
u8 ie_offset, *p=NULL, *next_ie=NULL, *mac = get_addr2_ptr(pframe);
sint len, ssid_len_ori;
u32 remain_len = 0;
u8 backupIE[MAX_IE_SZ];
u16 subtype = get_frame_sub_type(pframe);
_irqL irqL;
if ((!bssid) || (!pframe))
return;
if (subtype == WIFI_BEACON) {
bssid->Reserved[0] = BSS_TYPE_BCN;
ie_offset = _BEACON_IE_OFFSET_;
} else {
/* FIXME : more type */
if (subtype == WIFI_PROBERSP) {
ie_offset = _PROBERSP_IE_OFFSET_;
bssid->Reserved[0] = BSS_TYPE_PROB_RSP;
} else if (subtype == WIFI_PROBEREQ) {
ie_offset = _PROBEREQ_IE_OFFSET_;
bssid->Reserved[0] = BSS_TYPE_PROB_REQ;
} else {
bssid->Reserved[0] = BSS_TYPE_UNDEF;
ie_offset = _FIXED_IE_LENGTH_;
}
}
_enter_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
scanned = _rtw_find_network(&padapter->mlmepriv.scanned_queue, mac);
if (!scanned) {
_exit_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
return;
}
snetwork = &(scanned->network);
/* scan queue records as Hidden SSID && Input frame is NOT Hidden SSID */
if (hidden_ssid_ap(snetwork) && !hidden_ssid_ap(bssid)) {
p = rtw_get_ie(snetwork->IEs+ie_offset, _SSID_IE_, &ssid_len_ori, snetwork->IELength-ie_offset);
if (!p) {
_exit_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
return;
}
next_ie = p + 2 + ssid_len_ori;
remain_len = snetwork->IELength - (next_ie - snetwork->IEs);
scanned->network.Ssid.SsidLength = bssid->Ssid.SsidLength;
_rtw_memcpy(scanned->network.Ssid.Ssid, bssid->Ssid.Ssid, bssid->Ssid.SsidLength);
//update pnetwork->ssid, pnetwork->ssidlen
_rtw_memcpy(backupIE, next_ie, remain_len);
*(p+1) = bssid->Ssid.SsidLength;
_rtw_memcpy(p+2, bssid->Ssid.Ssid, bssid->Ssid.SsidLength);
_rtw_memcpy(p+2+bssid->Ssid.SsidLength, backupIE, remain_len);
snetwork->IELength += bssid->Ssid.SsidLength;
}
_exit_critical_bh(&padapter->mlmepriv.scanned_queue.lock, &irqL);
}
#ifdef DBG_RX_BCN
void rtw_debug_rx_bcn(_adapter *adapter, u8 *pframe, u32 packet_len)
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *mlmeinfo = &(pmlmeext->mlmext_info);
u16 sn = ((struct rtw_ieee80211_hdr_3addr *)pframe)->seq_ctl >> 4;
u64 tsf, tsf_offset;
u8 dtim_cnt, dtim_period, tim_bmap, tim_pvbit;
update_TSF(pmlmeext, pframe, packet_len);
tsf = pmlmeext->TSFValue;
tsf_offset = rtw_modular64(pmlmeext->TSFValue, (mlmeinfo->bcn_interval * 1024));
/*get TIM IE*/
/*DTIM Count*/
dtim_cnt = pmlmeext->tim[0];
/*DTIM Period*/
dtim_period = pmlmeext->tim[1];
/*Bitmap*/
tim_bmap = pmlmeext->tim[2];
/*Partial VBitmap AID 0 ~ 7*/
tim_pvbit = pmlmeext->tim[3];
RTW_INFO("[BCN] SN-%d, TSF-%lld(us), offset-%lld, bcn_interval-%d DTIM-%d[%d] bitmap-0x%02x-0x%02x\n",
sn, tsf, tsf_offset, mlmeinfo->bcn_interval, dtim_period, dtim_cnt, tim_bmap, tim_pvbit);
}
#endif
/*
* rtw_get_bcn_keys: get beacon keys from recv frame
*
* TODO:
* WLAN_EID_COUNTRY
* WLAN_EID_ERP_INFO
* WLAN_EID_CHANNEL_SWITCH
* WLAN_EID_PWR_CONSTRAINT
*/
int rtw_get_bcn_keys(ADAPTER *Adapter, u8 *pframe, u32 packet_len,
struct beacon_keys *recv_beacon)
{
int left;
u16 capability;
unsigned char *pos;
struct rtw_ieee802_11_elems elems;
_rtw_memset(recv_beacon, 0, sizeof(*recv_beacon));
/* checking capabilities */
capability = le16_to_cpu(*(unsigned short *)(pframe + WLAN_HDR_A3_LEN + 10));
/* checking IEs */
left = packet_len - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_;
pos = pframe + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_;
if (rtw_ieee802_11_parse_elems(pos, left, &elems, 1) == ParseFailed)
return _FALSE;
if (elems.ht_capabilities) {
if (elems.ht_capabilities_len != 26)
return _FALSE;
}
if (elems.ht_operation) {
if (elems.ht_operation_len != 22)
return _FALSE;
}
if (elems.vht_capabilities) {
if (elems.vht_capabilities_len != 12)
return _FALSE;
}
if (elems.vht_operation) {
if (elems.vht_operation_len != 5)
return _FALSE;
}
if (rtw_ies_get_supported_rate(pos, left, recv_beacon->rate_set, &recv_beacon->rate_num) == _FAIL)
return _FALSE;
if (cckratesonly_included(recv_beacon->rate_set, recv_beacon->rate_num) == _TRUE)
recv_beacon->proto_cap |= PROTO_CAP_11B;
else if (cckrates_included(recv_beacon->rate_set, recv_beacon->rate_num) == _TRUE)
recv_beacon->proto_cap |= PROTO_CAP_11B | PROTO_CAP_11G;
else
recv_beacon->proto_cap |= PROTO_CAP_11G;
if (elems.ht_capabilities && elems.ht_operation)
recv_beacon->proto_cap |= PROTO_CAP_11N;
if (elems.vht_capabilities && elems.vht_operation)
recv_beacon->proto_cap |= PROTO_CAP_11AC;
/* check bw and channel offset */
rtw_ies_get_chbw(pos, left, &recv_beacon->ch, &recv_beacon->bw, &recv_beacon->offset, 1, 1);
if (!recv_beacon->ch) {
/* we don't find channel IE, so don't check it */
/* RTW_INFO("Oops: %s we don't find channel IE, so don't check it\n", __func__); */
recv_beacon->ch = Adapter->mlmeextpriv.cur_channel;
}
/* checking SSID */
if (elems.ssid) {
if (elems.ssid_len > sizeof(recv_beacon->ssid))
return _FALSE;
_rtw_memcpy(recv_beacon->ssid, elems.ssid, elems.ssid_len);
recv_beacon->ssid_len = elems.ssid_len;
}
/* checking RSN first */
if (elems.rsn_ie && elems.rsn_ie_len) {
recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WPA2;
rtw_parse_wpa2_ie(elems.rsn_ie - 2, elems.rsn_ie_len + 2,
&recv_beacon->group_cipher, &recv_beacon->pairwise_cipher,
&recv_beacon->akm, NULL);
}
/* checking WPA secon */
else if (elems.wpa_ie && elems.wpa_ie_len) {
recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WPA;
rtw_parse_wpa_ie(elems.wpa_ie - 2, elems.wpa_ie_len + 2,
&recv_beacon->group_cipher, &recv_beacon->pairwise_cipher,
&recv_beacon->akm);
} else if (capability & BIT(4))
recv_beacon->encryp_protocol = ENCRYP_PROTOCOL_WEP;
if (elems.tim && elems.tim_len) {
struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
#ifdef DBG_RX_BCN
_rtw_memcpy(pmlmeext->tim, elems.tim, 4);
#endif
pmlmeext->dtim = elems.tim[1];
}
return _TRUE;
}
void rtw_dump_bcn_keys(void *sel, struct beacon_keys *recv_beacon)
{
u8 ssid[IW_ESSID_MAX_SIZE + 1];
_rtw_memcpy(ssid, recv_beacon->ssid, recv_beacon->ssid_len);
ssid[recv_beacon->ssid_len] = '\0';
RTW_PRINT_SEL(sel, "ssid = %s (len = %u)\n", ssid, recv_beacon->ssid_len);
RTW_PRINT_SEL(sel, "ch = %u,%u,%u\n"
, recv_beacon->ch, recv_beacon->bw, recv_beacon->offset);
RTW_PRINT_SEL(sel, "proto_cap = 0x%02x\n", recv_beacon->proto_cap);
RTW_MAP_DUMP_SEL(sel, "rate_set = "
, recv_beacon->rate_set, recv_beacon->rate_num);
RTW_PRINT_SEL(sel, "sec = %d, group = 0x%x, pair = 0x%x, akm = 0x%08x\n"
, recv_beacon->encryp_protocol, recv_beacon->group_cipher
, recv_beacon->pairwise_cipher, recv_beacon->akm);
}
int rtw_check_bcn_info(ADAPTER *Adapter, u8 *pframe, u32 packet_len)
{
#define BCNKEY_VERIFY_PROTO_CAP 0
#define BCNKEY_VERIFY_WHOLE_RATE_SET 0
u8 *pbssid = GetAddr3Ptr(pframe);
struct mlme_priv *pmlmepriv = &Adapter->mlmepriv;
struct wlan_network *cur_network = &(Adapter->mlmepriv.cur_network);
struct beacon_keys *cur_beacon = &pmlmepriv->cur_beacon_keys;
struct beacon_keys recv_beacon;
int ret = 0;
if (is_client_associated_to_ap(Adapter) == _FALSE)
goto exit_success;
if (rtw_get_bcn_keys(Adapter, pframe, packet_len, &recv_beacon) == _FALSE)
goto exit_success; /* parsing failed => broken IE */
#ifdef DBG_RX_BCN
rtw_debug_bcn(Adapter, pframe, packet_len);
#endif
/* hidden ssid, replace with current beacon ssid directly */
if (is_hidden_ssid(recv_beacon.ssid, recv_beacon.ssid_len)) {
_rtw_memcpy(recv_beacon.ssid, pmlmepriv->cur_beacon_keys.ssid,
pmlmepriv->cur_beacon_keys.ssid_len);
recv_beacon.ssid_len = pmlmepriv->cur_beacon_keys.ssid_len;
}
#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
if (_rtw_memcmp(&recv_beacon, cur_beacon, sizeof(recv_beacon)) == _TRUE)
pmlmepriv->new_beacon_cnts = 0;
else if ((pmlmepriv->new_beacon_cnts == 0) ||
_rtw_memcmp(&recv_beacon, &pmlmepriv->new_beacon_keys, sizeof(recv_beacon)) == _FALSE) {
RTW_DBG("%s: start new beacon (seq=%d)\n", __func__, GetSequence(pframe));
if (pmlmepriv->new_beacon_cnts == 0) {
RTW_ERR("%s: cur beacon key\n", __func__);
RTW_DBG_EXPR(rtw_dump_bcn_keys(RTW_DBGDUMP, cur_beacon));
}
RTW_DBG("%s: new beacon key\n", __func__);
RTW_DBG_EXPR(rtw_dump_bcn_keys(RTW_DBGDUMP, &recv_beacon));
_rtw_memcpy(&pmlmepriv->new_beacon_keys, &recv_beacon, sizeof(recv_beacon));
pmlmepriv->new_beacon_cnts = 1;
} else {
RTW_DBG("%s: new beacon again (seq=%d)\n", __func__, GetSequence(pframe));
pmlmepriv->new_beacon_cnts++;
}
/* if counter >= max, it means beacon is changed really */
if (pmlmepriv->new_beacon_cnts >= new_bcn_max)
#else
if (_rtw_memcmp(&recv_beacon, cur_beacon, sizeof(recv_beacon)) == _FALSE)
#endif
{
struct beacon_keys tmp_beacon;
RTW_INFO(FUNC_ADPT_FMT" new beacon occur!!\n", FUNC_ADPT_ARG(Adapter));
RTW_INFO(FUNC_ADPT_FMT" cur beacon key:\n", FUNC_ADPT_ARG(Adapter));
rtw_dump_bcn_keys(RTW_DBGDUMP, cur_beacon);
RTW_INFO(FUNC_ADPT_FMT" new beacon key:\n", FUNC_ADPT_ARG(Adapter));
rtw_dump_bcn_keys(RTW_DBGDUMP, &recv_beacon);
if (!rtw_is_chbw_grouped(cur_beacon->ch, cur_beacon->bw, cur_beacon->offset
, recv_beacon.ch, recv_beacon.bw, recv_beacon.offset))
goto exit;
_rtw_memcpy(&tmp_beacon, cur_beacon, sizeof(tmp_beacon));
/* check fields excluding below */
tmp_beacon.ch = recv_beacon.ch;
tmp_beacon.bw = recv_beacon.bw;
tmp_beacon.offset = recv_beacon.offset;
if (!BCNKEY_VERIFY_PROTO_CAP)
tmp_beacon.proto_cap = recv_beacon.proto_cap;
if (!BCNKEY_VERIFY_WHOLE_RATE_SET) {
tmp_beacon.rate_num = recv_beacon.rate_num;
_rtw_memcpy(tmp_beacon.rate_set, recv_beacon.rate_set, 12);
}
if (_rtw_memcmp(&tmp_beacon, &recv_beacon, sizeof(recv_beacon)) == _FALSE)
goto exit;
_rtw_memcpy(cur_beacon, &recv_beacon, sizeof(recv_beacon));
#ifdef CONFIG_BCN_CNT_CONFIRM_HDL
pmlmepriv->new_beacon_cnts = 0;
#endif
}
exit_success:
ret = 1;
exit:
return ret;
}
void update_beacon_info(_adapter *padapter, u8 *pframe, uint pkt_len, struct sta_info *psta)
{
unsigned int i;
unsigned int len;
PNDIS_802_11_VARIABLE_IEs pIE;
#ifdef CONFIG_TDLS
struct tdls_info *ptdlsinfo = &padapter->tdlsinfo;
u8 tdls_prohibited[] = { 0x00, 0x00, 0x00, 0x00, 0x10 }; /* bit(38): TDLS_prohibited */
#endif /* CONFIG_TDLS */
len = pkt_len - (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN);
for (i = 0; i < len;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + (_BEACON_IE_OFFSET_ + WLAN_HDR_A3_LEN) + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
/* to update WMM paramter set while receiving beacon */
if (_rtw_memcmp(pIE->data, WMM_PARA_OUI, 6) && pIE->Length == WLAN_WMM_LEN) /* WMM */
(WMM_param_handler(padapter, pIE)) ? report_wmm_edca_update(padapter) : 0;
break;
case _HT_EXTRA_INFO_IE_: /* HT info */
/* HT_info_handler(padapter, pIE); */
bwmode_update_check(padapter, pIE);
break;
#ifdef CONFIG_80211AC_VHT
case EID_OpModeNotification:
rtw_process_vht_op_mode_notify(padapter, pIE->data, psta);
break;
#endif /* CONFIG_80211AC_VHT */
case _ERPINFO_IE_:
ERP_IE_handler(padapter, pIE);
VCS_update(padapter, psta);
break;
#ifdef CONFIG_TDLS
case _EXT_CAP_IE_:
if (check_ap_tdls_prohibited(pIE->data, pIE->Length) == _TRUE)
ptdlsinfo->ap_prohibited = _TRUE;
if (check_ap_tdls_ch_switching_prohibited(pIE->data, pIE->Length) == _TRUE)
ptdlsinfo->ch_switch_prohibited = _TRUE;
break;
#endif /* CONFIG_TDLS */
default:
break;
}
i += (pIE->Length + 2);
}
}
#ifdef CONFIG_DFS
void process_csa_ie(_adapter *padapter, u8 *ies, uint ies_len)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
unsigned int i;
PNDIS_802_11_VARIABLE_IEs pIE;
u8 ch = 0;
/* TODO: compare with scheduling CSA */
if (rfctl->csa_ch)
return;
for (i = 0; i + 1 < ies_len;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(ies + i);
switch (pIE->ElementID) {
case _CH_SWTICH_ANNOUNCE_:
ch = *(pIE->data + 1);
break;
default:
break;
}
i += (pIE->Length + 2);
}
if (ch != 0) {
rfctl->csa_ch = ch;
if (rtw_set_csa_cmd(padapter) != _SUCCESS)
rfctl->csa_ch = 0;
}
}
#endif /* CONFIG_DFS */
void parsing_eapol_packet(_adapter *padapter, u8 *key_payload, struct sta_info *psta, u8 trx_type)
{
struct security_priv *psecuritypriv = &(padapter->securitypriv);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct sta_priv *pstapriv = &(padapter->stapriv);
struct ieee802_1x_hdr *hdr;
struct wpa_eapol_key *key;
u16 key_info, key_data_length;
char *trx_msg = trx_type ? "send" : "recv";
hdr = (struct ieee802_1x_hdr *) key_payload;
/* WPS - eapol start packet */
if (hdr->type == 1 && hdr->length == 0) {
RTW_INFO("%s eapol start packet\n", trx_msg);
return;
}
if (hdr->type == 0) { /* WPS - eapol packet */
RTW_INFO("%s eapol packet\n", trx_msg);
return;
}
key = (struct wpa_eapol_key *) (hdr + 1);
key_info = be16_to_cpu(*((u16 *)(key->key_info)));
key_data_length = be16_to_cpu(*((u16 *)(key->key_data_length)));
if (!(key_info & WPA_KEY_INFO_KEY_TYPE)) { /* WPA group key handshake */
if (key_info & WPA_KEY_INFO_ACK) {
RTW_PRINT("%s eapol packet - WPA Group Key 1/2\n", trx_msg);
} else {
RTW_PRINT("%s eapol packet - WPA Group Key 2/2\n", trx_msg);
/* WPA key-handshake has completed */
if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPAPSK)
psta->state &= (~WIFI_UNDER_KEY_HANDSHAKE);
}
} else if (key_info & WPA_KEY_INFO_MIC) {
if (key_data_length == 0)
RTW_PRINT("%s eapol packet 4/4\n", trx_msg);
else if (key_info & WPA_KEY_INFO_ACK)
RTW_PRINT("%s eapol packet 3/4\n", trx_msg);
else
RTW_PRINT("%s eapol packet 2/4\n", trx_msg);
} else {
RTW_PRINT("%s eapol packet 1/4\n", trx_msg);
}
}
unsigned int is_ap_in_tkip(_adapter *padapter)
{
u32 i;
PNDIS_802_11_VARIABLE_IEs pIE;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY) {
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
if ((_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4)) && (_rtw_memcmp((pIE->data + 12), WPA_TKIP_CIPHER, 4)))
return _TRUE;
break;
case _RSN_IE_2_:
if (_rtw_memcmp((pIE->data + 8), RSN_TKIP_CIPHER, 4))
return _TRUE;
default:
break;
}
i += (pIE->Length + 2);
}
return _FALSE;
} else
return _FALSE;
}
unsigned int should_forbid_n_rate(_adapter *padapter)
{
u32 i;
PNDIS_802_11_VARIABLE_IEs pIE;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
WLAN_BSSID_EX *cur_network = &pmlmepriv->cur_network.network;
if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY) {
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < cur_network->IELength;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(cur_network->IEs + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
if (_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4) &&
((_rtw_memcmp((pIE->data + 12), WPA_CIPHER_SUITE_CCMP, 4)) ||
(_rtw_memcmp((pIE->data + 16), WPA_CIPHER_SUITE_CCMP, 4))))
return _FALSE;
break;
case _RSN_IE_2_:
if ((_rtw_memcmp((pIE->data + 8), RSN_CIPHER_SUITE_CCMP, 4)) ||
(_rtw_memcmp((pIE->data + 12), RSN_CIPHER_SUITE_CCMP, 4)))
return _FALSE;
default:
break;
}
i += (pIE->Length + 2);
}
return _TRUE;
} else
return _FALSE;
}
unsigned int is_ap_in_wep(_adapter *padapter)
{
u32 i;
PNDIS_802_11_VARIABLE_IEs pIE;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
if (rtw_get_capability((WLAN_BSSID_EX *)cur_network) & WLAN_CAPABILITY_PRIVACY) {
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < pmlmeinfo->network.IELength;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pmlmeinfo->network.IEs + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
if (_rtw_memcmp(pIE->data, RTW_WPA_OUI, 4))
return _FALSE;
break;
case _RSN_IE_2_:
return _FALSE;
default:
break;
}
i += (pIE->Length + 2);
}
return _TRUE;
} else
return _FALSE;
}
int wifirate2_ratetbl_inx(unsigned char rate);
int wifirate2_ratetbl_inx(unsigned char rate)
{
int inx = 0;
rate = rate & 0x7f;
switch (rate) {
case 54*2:
inx = 11;
break;
case 48*2:
inx = 10;
break;
case 36*2:
inx = 9;
break;
case 24*2:
inx = 8;
break;
case 18*2:
inx = 7;
break;
case 12*2:
inx = 6;
break;
case 9*2:
inx = 5;
break;
case 6*2:
inx = 4;
break;
case 11*2:
inx = 3;
break;
case 11:
inx = 2;
break;
case 2*2:
inx = 1;
break;
case 1*2:
inx = 0;
break;
}
return inx;
}
unsigned int update_basic_rate(unsigned char *ptn, unsigned int ptn_sz)
{
unsigned int i, num_of_rate;
unsigned int mask = 0;
num_of_rate = (ptn_sz > NumRates) ? NumRates : ptn_sz;
for (i = 0; i < num_of_rate; i++) {
if ((*(ptn + i)) & 0x80)
mask |= 0x1 << wifirate2_ratetbl_inx(*(ptn + i));
}
return mask;
}
unsigned int update_supported_rate(unsigned char *ptn, unsigned int ptn_sz)
{
unsigned int i, num_of_rate;
unsigned int mask = 0;
num_of_rate = (ptn_sz > NumRates) ? NumRates : ptn_sz;
for (i = 0; i < num_of_rate; i++)
mask |= 0x1 << wifirate2_ratetbl_inx(*(ptn + i));
return mask;
}
int support_short_GI(_adapter *padapter, struct HT_caps_element *pHT_caps, u8 bwmode)
{
unsigned char bit_offset;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if (!(pmlmeinfo->HT_enable))
return _FAIL;
bit_offset = (bwmode & CHANNEL_WIDTH_40) ? 6 : 5;
if (pHT_caps->u.HT_cap_element.HT_caps_info & (0x1 << bit_offset))
return _SUCCESS;
else
return _FAIL;
}
unsigned char get_highest_rate_idx(u64 mask)
{
int i;
unsigned char rate_idx = 0;
for (i = 63; i >= 0; i--) {
if ((mask >> i) & 0x01) {
rate_idx = i;
break;
}
}
return rate_idx;
}
unsigned char get_lowest_rate_idx_ex(u64 mask, int start_bit)
{
int i;
unsigned char rate_idx = 0;
for (i = start_bit; i < 64; i++) {
if ((mask >> i) & 0x01) {
rate_idx = i;
break;
}
}
return rate_idx;
}
void Update_RA_Entry(_adapter *padapter, struct sta_info *psta)
{
rtw_hal_update_ra_mask(psta);
}
void set_sta_rate(_adapter *padapter, struct sta_info *psta)
{
/* rate adaptive */
rtw_hal_update_ra_mask(psta);
}
/* Update RRSR and Rate for USERATE */
void update_tx_basic_rate(_adapter *padapter, u8 wirelessmode)
{
NDIS_802_11_RATES_EX supported_rates;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
/* Added by Albert 2011/03/22 */
/* In the P2P mode, the driver should not support the b mode. */
/* So, the Tx packet shouldn't use the CCK rate */
if (!rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
return;
#endif /* CONFIG_P2P */
_rtw_memset(supported_rates, 0, NDIS_802_11_LENGTH_RATES_EX);
/* clear B mod if current channel is in 5G band, avoid tx cck rate in 5G band. */
if (pmlmeext->cur_channel > 14)
wirelessmode &= ~(WIRELESS_11B);
if ((wirelessmode & WIRELESS_11B) && (wirelessmode == WIRELESS_11B))
_rtw_memcpy(supported_rates, rtw_basic_rate_cck, 4);
else if (wirelessmode & WIRELESS_11B)
_rtw_memcpy(supported_rates, rtw_basic_rate_mix, 7);
else
_rtw_memcpy(supported_rates, rtw_basic_rate_ofdm, 3);
if (wirelessmode & WIRELESS_11B)
update_mgnt_tx_rate(padapter, IEEE80211_CCK_RATE_1MB);
else
update_mgnt_tx_rate(padapter, IEEE80211_OFDM_RATE_6MB);
rtw_hal_set_hwreg(padapter, HW_VAR_BASIC_RATE, supported_rates);
}
unsigned char check_assoc_AP(u8 *pframe, uint len)
{
unsigned int i;
PNDIS_802_11_VARIABLE_IEs pIE;
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < len;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
switch (pIE->ElementID) {
case _VENDOR_SPECIFIC_IE_:
if ((_rtw_memcmp(pIE->data, ARTHEROS_OUI1, 3)) || (_rtw_memcmp(pIE->data, ARTHEROS_OUI2, 3))) {
RTW_INFO("link to Artheros AP\n");
return HT_IOT_PEER_ATHEROS;
} else if ((_rtw_memcmp(pIE->data, BROADCOM_OUI1, 3))
|| (_rtw_memcmp(pIE->data, BROADCOM_OUI2, 3))
|| (_rtw_memcmp(pIE->data, BROADCOM_OUI3, 3))) {
RTW_INFO("link to Broadcom AP\n");
return HT_IOT_PEER_BROADCOM;
} else if (_rtw_memcmp(pIE->data, MARVELL_OUI, 3)) {
RTW_INFO("link to Marvell AP\n");
return HT_IOT_PEER_MARVELL;
} else if (_rtw_memcmp(pIE->data, RALINK_OUI, 3)) {
RTW_INFO("link to Ralink AP\n");
return HT_IOT_PEER_RALINK;
} else if (_rtw_memcmp(pIE->data, CISCO_OUI, 3)) {
RTW_INFO("link to Cisco AP\n");
return HT_IOT_PEER_CISCO;
} else if (_rtw_memcmp(pIE->data, REALTEK_OUI, 3)) {
u32 Vender = HT_IOT_PEER_REALTEK;
if (pIE->Length >= 5) {
if (pIE->data[4] == 1) {
/* if(pIE->data[5] & RT_HT_CAP_USE_LONG_PREAMBLE) */
/* bssDesc->BssHT.RT2RT_HT_Mode |= RT_HT_CAP_USE_LONG_PREAMBLE; */
if (pIE->data[5] & RT_HT_CAP_USE_92SE) {
/* bssDesc->BssHT.RT2RT_HT_Mode |= RT_HT_CAP_USE_92SE; */
Vender = HT_IOT_PEER_REALTEK_92SE;
}
}
if (pIE->data[5] & RT_HT_CAP_USE_SOFTAP)
Vender = HT_IOT_PEER_REALTEK_SOFTAP;
if (pIE->data[4] == 2) {
if (pIE->data[6] & RT_HT_CAP_USE_JAGUAR_BCUT) {
Vender = HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP;
RTW_INFO("link to Realtek JAGUAR_BCUTAP\n");
}
if (pIE->data[6] & RT_HT_CAP_USE_JAGUAR_CCUT) {
Vender = HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP;
RTW_INFO("link to Realtek JAGUAR_CCUTAP\n");
}
}
}
RTW_INFO("link to Realtek AP\n");
return Vender;
} else if (_rtw_memcmp(pIE->data, AIRGOCAP_OUI, 3)) {
RTW_INFO("link to Airgo Cap\n");
return HT_IOT_PEER_AIRGO;
} else
break;
default:
break;
}
i += (pIE->Length + 2);
}
RTW_INFO("link to new AP\n");
return HT_IOT_PEER_UNKNOWN;
}
void get_assoc_AP_Vendor(char *vendor, u8 assoc_AP_vendor)
{
switch (assoc_AP_vendor) {
case HT_IOT_PEER_UNKNOWN:
sprintf(vendor, "%s", "unknown");
break;
case HT_IOT_PEER_REALTEK:
case HT_IOT_PEER_REALTEK_92SE:
case HT_IOT_PEER_REALTEK_SOFTAP:
case HT_IOT_PEER_REALTEK_JAGUAR_BCUTAP:
case HT_IOT_PEER_REALTEK_JAGUAR_CCUTAP:
sprintf(vendor, "%s", "Realtek");
break;
case HT_IOT_PEER_BROADCOM:
sprintf(vendor, "%s", "Broadcom");
break;
case HT_IOT_PEER_MARVELL:
sprintf(vendor, "%s", "Marvell");
break;
case HT_IOT_PEER_RALINK:
sprintf(vendor, "%s", "Ralink");
break;
case HT_IOT_PEER_CISCO:
sprintf(vendor, "%s", "Cisco");
break;
case HT_IOT_PEER_AIRGO:
sprintf(vendor, "%s", "Airgo");
break;
case HT_IOT_PEER_ATHEROS:
sprintf(vendor, "%s", "Atheros");
break;
default:
sprintf(vendor, "%s", "unkown");
break;
}
}
#ifdef CONFIG_RTS_FULL_BW
void rtw_parse_sta_vendor_ie_8812(_adapter *adapter, struct sta_info *sta, u8 *tlv_ies, u16 tlv_ies_len)
{
struct mlme_priv *mlme = &adapter->mlmepriv;
unsigned char REALTEK_OUI[] = {0x00,0xe0, 0x4c};
u8 *p;
int i;
p = rtw_get_ie_ex(tlv_ies, tlv_ies_len, WLAN_EID_VENDOR_SPECIFIC, REALTEK_OUI, 3, NULL, NULL);
if (!p)
goto exit;
else {
if(*(p+1) > 6 ) {
if(*(p+6) != 2)
goto exit;
if(*(p+8) == RT_HT_CAP_USE_JAGUAR_BCUT)
sta->vendor_8812 = TRUE;
else if (*(p+8) == RT_HT_CAP_USE_JAGUAR_CCUT)
sta->vendor_8812 = TRUE;
}
}
exit:
return;
}
#endif/*CONFIG_RTS_FULL_BW*/
#ifdef CONFIG_80211AC_VHT
unsigned char get_vht_mu_bfer_cap(u8 *pframe, uint len)
{
unsigned int i;
unsigned int mu_bfer=0;
PNDIS_802_11_VARIABLE_IEs pIE;
for (i = sizeof(NDIS_802_11_FIXED_IEs); i < len;) {
pIE = (PNDIS_802_11_VARIABLE_IEs)(pframe + i);
switch (pIE->ElementID) {
case EID_VHTCapability:
mu_bfer = GET_VHT_CAPABILITY_ELE_MU_BFER(pIE->data);
break;
default:
break;
}
i += (pIE->Length + 2);
}
return mu_bfer;
}
#endif
void update_capinfo(PADAPTER Adapter, u16 updateCap)
{
struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
BOOLEAN ShortPreamble;
/* Check preamble mode, 2005.01.06, by rcnjko. */
/* Mark to update preamble value forever, 2008.03.18 by lanhsin */
/* if( pMgntInfo->RegPreambleMode == PREAMBLE_AUTO ) */
{
if (updateCap & cShortPreamble) {
/* Short Preamble */
if (pmlmeinfo->preamble_mode != PREAMBLE_SHORT) { /* PREAMBLE_LONG or PREAMBLE_AUTO */
ShortPreamble = _TRUE;
pmlmeinfo->preamble_mode = PREAMBLE_SHORT;
rtw_hal_set_hwreg(Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble);
}
} else {
/* Long Preamble */
if (pmlmeinfo->preamble_mode != PREAMBLE_LONG) { /* PREAMBLE_SHORT or PREAMBLE_AUTO */
ShortPreamble = _FALSE;
pmlmeinfo->preamble_mode = PREAMBLE_LONG;
rtw_hal_set_hwreg(Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble);
}
}
}
if (updateCap & cIBSS) {
/* Filen: See 802.11-2007 p.91 */
pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
} else {
/* Filen: See 802.11-2007 p.90 */
if (pmlmeext->cur_wireless_mode & (WIRELESS_11_24N | WIRELESS_11A | WIRELESS_11_5N | WIRELESS_11AC))
pmlmeinfo->slotTime = SHORT_SLOT_TIME;
else if (pmlmeext->cur_wireless_mode & (WIRELESS_11G)) {
if ((updateCap & cShortSlotTime) /* && (!(pMgntInfo->pHTInfo->RT2RT_HT_Mode & RT_HT_CAP_USE_LONG_PREAMBLE)) */) {
/* Short Slot Time */
pmlmeinfo->slotTime = SHORT_SLOT_TIME;
} else {
/* Long Slot Time */
pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
}
} else {
/* B Mode */
pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
}
}
rtw_hal_set_hwreg(Adapter, HW_VAR_SLOT_TIME, &pmlmeinfo->slotTime);
}
/*
* set adapter.mlmeextpriv.mlmext_info.HT_enable
* set adapter.mlmeextpriv.cur_wireless_mode
* set SIFS register
* set mgmt tx rate
*/
void update_wireless_mode(_adapter *padapter)
{
int ratelen, network_type = 0;
u32 SIFS_Timer;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
unsigned char *rate = cur_network->SupportedRates;
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
ratelen = rtw_get_rateset_len(cur_network->SupportedRates);
if ((pmlmeinfo->HT_info_enable) && (pmlmeinfo->HT_caps_enable))
pmlmeinfo->HT_enable = 1;
if (pmlmeext->cur_channel > 14) {
if (pmlmeinfo->VHT_enable)
network_type = WIRELESS_11AC;
else if (pmlmeinfo->HT_enable)
network_type = WIRELESS_11_5N;
network_type |= WIRELESS_11A;
} else {
if (pmlmeinfo->VHT_enable)
network_type = WIRELESS_11AC;
else if (pmlmeinfo->HT_enable)
network_type = WIRELESS_11_24N;
if ((cckratesonly_included(rate, ratelen)) == _TRUE)
network_type |= WIRELESS_11B;
else if ((cckrates_included(rate, ratelen)) == _TRUE)
network_type |= WIRELESS_11BG;
else
network_type |= WIRELESS_11G;
}
pmlmeext->cur_wireless_mode = network_type & padapter->registrypriv.wireless_mode;
/* RTW_INFO("network_type=%02x, padapter->registrypriv.wireless_mode=%02x\n", network_type, padapter->registrypriv.wireless_mode); */
#ifndef RTW_HALMAC
/* HALMAC IC do not set HW_VAR_RESP_SIFS here */
#if 0
if ((pmlmeext->cur_wireless_mode == WIRELESS_11G) ||
(pmlmeext->cur_wireless_mode == WIRELESS_11BG)) /* WIRELESS_MODE_G) */
SIFS_Timer = 0x0a0a;/* CCK */
else
SIFS_Timer = 0x0e0e;/* pHalData->SifsTime; //OFDM */
#endif
SIFS_Timer = 0x0a0a0808; /* 0x0808->for CCK, 0x0a0a->for OFDM
* change this value if having IOT issues. */
rtw_hal_set_hwreg(padapter, HW_VAR_RESP_SIFS, (u8 *)&SIFS_Timer);
#endif
rtw_hal_set_hwreg(padapter, HW_VAR_WIRELESS_MODE, (u8 *)&(pmlmeext->cur_wireless_mode));
if ((pmlmeext->cur_wireless_mode & WIRELESS_11B)
#ifdef CONFIG_P2P
&& (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE)
#ifdef CONFIG_IOCTL_CFG80211
|| !rtw_cfg80211_iface_has_p2p_group_cap(padapter)
#endif
)
#endif
)
update_mgnt_tx_rate(padapter, IEEE80211_CCK_RATE_1MB);
else
update_mgnt_tx_rate(padapter, IEEE80211_OFDM_RATE_6MB);
}
void fire_write_MAC_cmd(_adapter *padapter, unsigned int addr, unsigned int value);
void fire_write_MAC_cmd(_adapter *padapter, unsigned int addr, unsigned int value)
{
#if 0
struct cmd_obj *ph2c;
struct reg_rw_parm *pwriteMacPara;
struct cmd_priv *pcmdpriv = &(padapter->cmdpriv);
ph2c = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (ph2c == NULL)
return;
pwriteMacPara = (struct reg_rw_parm *)rtw_malloc(sizeof(struct reg_rw_parm));
if (pwriteMacPara == NULL) {
rtw_mfree((unsigned char *)ph2c, sizeof(struct cmd_obj));
return;
}
pwriteMacPara->rw = 1;
pwriteMacPara->addr = addr;
pwriteMacPara->value = value;
init_h2fwcmd_w_parm_no_rsp(ph2c, pwriteMacPara, GEN_CMD_CODE(_Write_MACREG));
rtw_enqueue_cmd(pcmdpriv, ph2c);
#endif
}
void update_sta_basic_rate(struct sta_info *psta, u8 wireless_mode)
{
if (IsSupportedTxCCK(wireless_mode)) {
/* Only B, B/G, and B/G/N AP could use CCK rate */
_rtw_memcpy(psta->bssrateset, rtw_basic_rate_cck, 4);
psta->bssratelen = 4;
} else {
_rtw_memcpy(psta->bssrateset, rtw_basic_rate_ofdm, 3);
psta->bssratelen = 3;
}
}
int rtw_ies_get_supported_rate(u8 *ies, uint ies_len, u8 *rate_set, u8 *rate_num)
{
u8 *ie, *p;
unsigned int ie_len;
int i, j;
struct support_rate_handler support_rate_tbl[] = {
{IEEE80211_CCK_RATE_1MB, _FALSE, _FALSE},
{IEEE80211_CCK_RATE_2MB, _FALSE, _FALSE},
{IEEE80211_CCK_RATE_5MB, _FALSE, _FALSE},
{IEEE80211_CCK_RATE_11MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_6MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_9MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_12MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_18MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_24MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_36MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_48MB, _FALSE, _FALSE},
{IEEE80211_OFDM_RATE_54MB, _FALSE, _FALSE},
};
if (!rate_set || !rate_num)
return _FALSE;
*rate_num = 0;
ie = rtw_get_ie(ies, _SUPPORTEDRATES_IE_, &ie_len, ies_len);
if (ie == NULL)
goto ext_rate;
/* get valid supported rates */
for (i = 0; i < 12; i++) {
p = ie + 2;
for (j = 0; j < ie_len; j++) {
if ((*p & ~BIT(7)) == support_rate_tbl[i].rate){
support_rate_tbl[i].existence = _TRUE;
if ((*p) & BIT(7))
support_rate_tbl[i].basic = _TRUE;
}
p++;
}
}
ext_rate:
ie = rtw_get_ie(ies, _EXT_SUPPORTEDRATES_IE_, &ie_len, ies_len);
if (ie) {
/* get valid extended supported rates */
for (i = 0; i < 12; i++) {
p = ie + 2;
for (j = 0; j < ie_len; j++) {
if ((*p & ~BIT(7)) == support_rate_tbl[i].rate){
support_rate_tbl[i].existence = _TRUE;
if ((*p) & BIT(7))
support_rate_tbl[i].basic = _TRUE;
}
p++;
}
}
}
for (i = 0; i < 12; i++){
if (support_rate_tbl[i].existence){
if (support_rate_tbl[i].basic)
rate_set[*rate_num] = support_rate_tbl[i].rate | IEEE80211_BASIC_RATE_MASK;
else
rate_set[*rate_num] = support_rate_tbl[i].rate;
*rate_num += 1;
}
}
if (*rate_num == 0)
return _FAIL;
if (0) {
int i;
for (i = 0; i < *rate_num; i++)
RTW_INFO("rate:0x%02x\n", *(rate_set + i));
}
return _SUCCESS;
}
void process_addba_req(_adapter *padapter, u8 *paddba_req, u8 *addr)
{
struct sta_info *psta;
u16 tid, start_seq, param;
struct sta_priv *pstapriv = &padapter->stapriv;
struct ADDBA_request *preq = (struct ADDBA_request *)paddba_req;
u8 size, accept = _FALSE;
psta = rtw_get_stainfo(pstapriv, addr);
if (!psta)
goto exit;
start_seq = le16_to_cpu(preq->BA_starting_seqctrl) >> 4;
param = le16_to_cpu(preq->BA_para_set);
tid = (param >> 2) & 0x0f;
accept = rtw_rx_ampdu_is_accept(padapter);
if (padapter->fix_rx_ampdu_size != RX_AMPDU_SIZE_INVALID)
size = padapter->fix_rx_ampdu_size;
else {
size = rtw_rx_ampdu_size(padapter);
size = rtw_min(size, rx_ampdu_size_sta_limit(padapter, psta));
}
if (accept == _TRUE)
rtw_addbarsp_cmd(padapter, addr, tid, 0, size, start_seq);
else
rtw_addbarsp_cmd(padapter, addr, tid, 37, size, start_seq); /* reject ADDBA Req */
exit:
return;
}
void rtw_process_bar_frame(_adapter *padapter, union recv_frame *precv_frame)
{
struct sta_priv *pstapriv = &padapter->stapriv;
u8 *pframe = precv_frame->u.hdr.rx_data;
struct sta_info *psta = NULL;
struct recv_reorder_ctrl *preorder_ctrl = NULL;
u8 tid = 0;
u16 start_seq=0;
psta = rtw_get_stainfo(pstapriv, get_addr2_ptr(pframe));
if (psta == NULL)
goto exit;
tid = ((cpu_to_le16((*(u16 *)(pframe + 16))) & 0xf000) >> 12);
preorder_ctrl = &psta->recvreorder_ctrl[tid];
start_seq = ((cpu_to_le16(*(u16 *)(pframe + 18))) >> 4);
preorder_ctrl->indicate_seq = start_seq;
/* for Debug use */
if (0)
RTW_INFO(FUNC_ADPT_FMT" tid=%d, start_seq=%d\n", FUNC_ADPT_ARG(padapter), tid, start_seq);
exit:
return;
}
void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
{
u8 *pIE;
u32 *pbuf;
pIE = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
pbuf = (u32 *)pIE;
pmlmeext->TSFValue = le32_to_cpu(*(pbuf + 1));
pmlmeext->TSFValue = pmlmeext->TSFValue << 32;
pmlmeext->TSFValue |= le32_to_cpu(*pbuf);
}
void correct_TSF(_adapter *padapter, u8 mlme_state)
{
u8 m_state = mlme_state;
rtw_hal_set_hwreg(padapter, HW_VAR_CORRECT_TSF, (u8 *)&m_state);
}
#ifdef CONFIG_BCN_RECV_TIME
/* calculate beacon receiving time
1.RxBCNTime(CCK_1M) = [192us(preamble)] + [length of beacon(byte)*8us] + [10us]
2.RxBCNTime(OFDM_6M) = [8us(S) + 8us(L) + 4us(L-SIG)] + [(length of beacon(byte)/3 + 1] *4us] + [10us]
*/
inline u16 _rx_bcn_time_calculate(uint bcn_len, u8 data_rate)
{
u16 rx_bcn_time = 0;/*us*/
if (data_rate == DESC_RATE1M)
rx_bcn_time = 192 + bcn_len * 8 + 10;
else if(data_rate == DESC_RATE6M)
rx_bcn_time = 8 + 8 + 4 + (bcn_len /3 + 1) * 4 + 10;
/*
else
RTW_ERR("%s invalid data rate(0x%02x)\n", __func__, data_rate);
*/
return rx_bcn_time;
}
void rtw_rx_bcn_time_update(_adapter *adapter, uint bcn_len, u8 data_rate)
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
pmlmeext->bcn_rx_time = _rx_bcn_time_calculate(bcn_len, data_rate);
}
#endif
void beacon_timing_control(_adapter *padapter)
{
rtw_hal_bcn_related_reg_setting(padapter);
}
void dump_macid_map(void *sel, struct macid_bmp *map, u8 max_num)
{
RTW_PRINT_SEL(sel, "0x%08x\n", map->m0);
#if (MACID_NUM_SW_LIMIT > 32)
if (max_num && max_num > 32)
RTW_PRINT_SEL(sel, "0x%08x\n", map->m1);
#endif
#if (MACID_NUM_SW_LIMIT > 64)
if (max_num && max_num > 64)
RTW_PRINT_SEL(sel, "0x%08x\n", map->m2);
#endif
#if (MACID_NUM_SW_LIMIT > 96)
if (max_num && max_num > 96)
RTW_PRINT_SEL(sel, "0x%08x\n", map->m3);
#endif
}
inline bool rtw_macid_is_set(struct macid_bmp *map, u8 id)
{
if (id < 32)
return map->m0 & BIT(id);
#if (MACID_NUM_SW_LIMIT > 32)
else if (id < 64)
return map->m1 & BIT(id - 32);
#endif
#if (MACID_NUM_SW_LIMIT > 64)
else if (id < 96)
return map->m2 & BIT(id - 64);
#endif
#if (MACID_NUM_SW_LIMIT > 96)
else if (id < 128)
return map->m3 & BIT(id - 96);
#endif
else
rtw_warn_on(1);
return 0;
}
inline void rtw_macid_map_set(struct macid_bmp *map, u8 id)
{
if (id < 32)
map->m0 |= BIT(id);
#if (MACID_NUM_SW_LIMIT > 32)
else if (id < 64)
map->m1 |= BIT(id - 32);
#endif
#if (MACID_NUM_SW_LIMIT > 64)
else if (id < 96)
map->m2 |= BIT(id - 64);
#endif
#if (MACID_NUM_SW_LIMIT > 96)
else if (id < 128)
map->m3 |= BIT(id - 96);
#endif
else
rtw_warn_on(1);
}
inline void rtw_macid_map_clr(struct macid_bmp *map, u8 id)
{
if (id < 32)
map->m0 &= ~BIT(id);
#if (MACID_NUM_SW_LIMIT > 32)
else if (id < 64)
map->m1 &= ~BIT(id - 32);
#endif
#if (MACID_NUM_SW_LIMIT > 64)
else if (id < 96)
map->m2 &= ~BIT(id - 64);
#endif
#if (MACID_NUM_SW_LIMIT > 96)
else if (id < 128)
map->m3 &= ~BIT(id - 96);
#endif
else
rtw_warn_on(1);
}
inline bool rtw_macid_is_used(struct macid_ctl_t *macid_ctl, u8 id)
{
return rtw_macid_is_set(&macid_ctl->used, id);
}
inline bool rtw_macid_is_bmc(struct macid_ctl_t *macid_ctl, u8 id)
{
return rtw_macid_is_set(&macid_ctl->bmc, id);
}
inline u8 rtw_macid_get_iface_bmp(struct macid_ctl_t *macid_ctl, u8 id)
{
int i;
u8 iface_bmp = 0;
for (i = 0; i < CONFIG_IFACE_NUMBER; i++) {
if (rtw_macid_is_set(&macid_ctl->if_g[i], id))
iface_bmp |= BIT(i);
}
return iface_bmp;
}
inline bool rtw_macid_is_iface_shared(struct macid_ctl_t *macid_ctl, u8 id)
{
int i;
u8 iface_bmp = 0;
for (i = 0; i < CONFIG_IFACE_NUMBER; i++) {
if (rtw_macid_is_set(&macid_ctl->if_g[i], id)) {
if (iface_bmp)
return 1;
iface_bmp |= BIT(i);
}
}
return 0;
}
inline bool rtw_macid_is_iface_specific(struct macid_ctl_t *macid_ctl, u8 id, _adapter *adapter)
{
int i;
u8 iface_bmp = 0;
for (i = 0; i < CONFIG_IFACE_NUMBER; i++) {
if (rtw_macid_is_set(&macid_ctl->if_g[i], id)) {
if (iface_bmp || i != adapter->iface_id)
return 0;
iface_bmp |= BIT(i);
}
}
return iface_bmp ? 1 : 0;
}
inline s8 rtw_macid_get_ch_g(struct macid_ctl_t *macid_ctl, u8 id)
{
int i;
for (i = 0; i < 2; i++) {
if (rtw_macid_is_set(&macid_ctl->ch_g[i], id))
return i;
}
return -1;
}
/*Record bc's mac-id and sec-cam-id*/
inline void rtw_iface_bcmc_id_set(_adapter *padapter, u8 mac_id)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
macid_ctl->iface_bmc[padapter->iface_id] = mac_id;
}
inline u8 rtw_iface_bcmc_id_get(_adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
return macid_ctl->iface_bmc[padapter->iface_id];
}
void rtw_alloc_macid(_adapter *padapter, struct sta_info *psta)
{
int i;
_irqL irqL;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct macid_bmp *used_map = &macid_ctl->used;
/* static u8 last_id = 0; for testing */
u8 last_id = 0;
u8 is_bc_sta = _FALSE;
if (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN)) {
psta->cmn.mac_id = macid_ctl->num;
return;
}
if (_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN)) {
is_bc_sta = _TRUE;
rtw_iface_bcmc_id_set(padapter, INVALID_SEC_MAC_CAM_ID); /*init default value*/
}
if (is_bc_sta
#ifdef CONFIG_CONCURRENT_MODE
&& (MLME_IS_STA(padapter) || MLME_IS_NULL(padapter))
#endif
) {
/* STA mode have no BMC data TX, shared with this macid */
/* When non-concurrent, only one BMC data TX is used, shared with this macid */
/* TODO: When concurrent, non-security BMC data TX may use this, but will not control by specific macid sleep */
i = RTW_DEFAULT_MGMT_MACID;
goto assigned;
}
_enter_critical_bh(&macid_ctl->lock, &irqL);
for (i = last_id; i < macid_ctl->num; i++) {
#ifdef CONFIG_MCC_MODE
/* macid 0/1 reserve for mcc for mgnt queue macid */
if (MCC_EN(padapter)) {
if (i == MCC_ROLE_STA_GC_MGMT_QUEUE_MACID)
continue;
if (i == MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID)
continue;
}
#endif /* CONFIG_MCC_MODE */
if (is_bc_sta) {
struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
if ((!rtw_macid_is_used(macid_ctl, i)) && (!rtw_sec_camid_is_used(cam_ctl, i)))
break;
} else {
if (!rtw_macid_is_used(macid_ctl, i))
break;
}
}
if (i < macid_ctl->num) {
rtw_macid_map_set(used_map, i);
if (is_bc_sta) {
struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
rtw_macid_map_set(&macid_ctl->bmc, i);
rtw_iface_bcmc_id_set(padapter, i);
rtw_sec_cam_map_set(&cam_ctl->used, i);
}
rtw_macid_map_set(&macid_ctl->if_g[padapter->iface_id], i);
macid_ctl->sta[i] = psta;
/* TODO ch_g? */
last_id++;
last_id %= macid_ctl->num;
}
_exit_critical_bh(&macid_ctl->lock, &irqL);
if (i >= macid_ctl->num) {
psta->cmn.mac_id = macid_ctl->num;
RTW_ERR(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" no available macid\n"
, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1, MAC_ARG(psta->cmn.mac_addr));
rtw_warn_on(1);
goto exit;
} else
goto assigned;
assigned:
psta->cmn.mac_id = i;
RTW_INFO(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u\n"
, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
exit:
return;
}
void rtw_release_macid(_adapter *padapter, struct sta_info *psta)
{
_irqL irqL;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
u8 ifbmp;
int i;
if (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN))
goto exit;
if (psta->cmn.mac_id >= macid_ctl->num) {
RTW_WARN(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u not valid\n"
, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
rtw_warn_on(1);
goto exit;
}
if (psta->cmn.mac_id == RTW_DEFAULT_MGMT_MACID)
goto msg;
_enter_critical_bh(&macid_ctl->lock, &irqL);
if (!rtw_macid_is_used(macid_ctl, psta->cmn.mac_id)) {
RTW_WARN(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u not used\n"
, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
_exit_critical_bh(&macid_ctl->lock, &irqL);
rtw_warn_on(1);
goto exit;
}
ifbmp = rtw_macid_get_iface_bmp(macid_ctl, psta->cmn.mac_id);
if (!(ifbmp & BIT(padapter->iface_id))) {
RTW_WARN(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u not used by self\n"
, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id);
_exit_critical_bh(&macid_ctl->lock, &irqL);
rtw_warn_on(1);
goto exit;
}
if (_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN)) {
struct cam_ctl_t *cam_ctl = dvobj_to_sec_camctl(dvobj);
u8 id = rtw_iface_bcmc_id_get(padapter);
if ((id != INVALID_SEC_MAC_CAM_ID) && (id < cam_ctl->num))
rtw_sec_cam_map_clr(&cam_ctl->used, id);
rtw_iface_bcmc_id_set(padapter, INVALID_SEC_MAC_CAM_ID);
}
rtw_macid_map_clr(&macid_ctl->if_g[padapter->iface_id], psta->cmn.mac_id);
ifbmp &= ~BIT(padapter->iface_id);
if (!ifbmp) { /* only used by self */
rtw_macid_map_clr(&macid_ctl->used, psta->cmn.mac_id);
rtw_macid_map_clr(&macid_ctl->bmc, psta->cmn.mac_id);
for (i = 0; i < 2; i++)
rtw_macid_map_clr(&macid_ctl->ch_g[i], psta->cmn.mac_id);
macid_ctl->sta[psta->cmn.mac_id] = NULL;
}
_exit_critical_bh(&macid_ctl->lock, &irqL);
msg:
RTW_INFO(FUNC_ADPT_FMT" if%u, mac_addr:"MAC_FMT" macid:%u\n"
, FUNC_ADPT_ARG(padapter), padapter->iface_id + 1
, MAC_ARG(psta->cmn.mac_addr), psta->cmn.mac_id
);
exit:
psta->cmn.mac_id = macid_ctl->num;
}
/* For 8188E RA */
u8 rtw_search_max_mac_id(_adapter *padapter)
{
u8 max_mac_id = 0;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
int i;
_irqL irqL;
/* TODO: Only search for connected macid? */
_enter_critical_bh(&macid_ctl->lock, &irqL);
for (i = (macid_ctl->num - 1); i > 0 ; i--) {
if (rtw_macid_is_used(macid_ctl, i))
break;
}
_exit_critical_bh(&macid_ctl->lock, &irqL);
max_mac_id = i;
return max_mac_id;
}
inline u8 rtw_macid_ctl_set_h2c_msr(struct macid_ctl_t *macid_ctl, u8 id, u8 h2c_msr)
{
u8 op_num_change_bmp = 0;
if (id >= macid_ctl->num) {
rtw_warn_on(1);
goto exit;
}
if (GET_H2CCMD_MSRRPT_PARM_OPMODE(&macid_ctl->h2c_msr[id])
&& !GET_H2CCMD_MSRRPT_PARM_OPMODE(&h2c_msr)
) {
u8 role = GET_H2CCMD_MSRRPT_PARM_ROLE(&macid_ctl->h2c_msr[id]);
if (role < H2C_MSR_ROLE_MAX) {
macid_ctl->op_num[role]--;
op_num_change_bmp |= BIT(role);
}
} else if (!GET_H2CCMD_MSRRPT_PARM_OPMODE(&macid_ctl->h2c_msr[id])
&& GET_H2CCMD_MSRRPT_PARM_OPMODE(&h2c_msr)
) {
u8 role = GET_H2CCMD_MSRRPT_PARM_ROLE(&h2c_msr);
if (role < H2C_MSR_ROLE_MAX) {
macid_ctl->op_num[role]++;
op_num_change_bmp |= BIT(role);
}
}
macid_ctl->h2c_msr[id] = h2c_msr;
if (0)
RTW_INFO("macid:%u, h2c_msr:"H2C_MSR_FMT"\n", id, H2C_MSR_ARG(&macid_ctl->h2c_msr[id]));
exit:
return op_num_change_bmp;
}
inline void rtw_macid_ctl_set_bw(struct macid_ctl_t *macid_ctl, u8 id, u8 bw)
{
if (id >= macid_ctl->num) {
rtw_warn_on(1);
return;
}
macid_ctl->bw[id] = bw;
if (0)
RTW_INFO("macid:%u, bw:%s\n", id, ch_width_str(macid_ctl->bw[id]));
}
inline void rtw_macid_ctl_set_vht_en(struct macid_ctl_t *macid_ctl, u8 id, u8 en)
{
if (id >= macid_ctl->num) {
rtw_warn_on(1);
return;
}
macid_ctl->vht_en[id] = en;
if (0)
RTW_INFO("macid:%u, vht_en:%u\n", id, macid_ctl->vht_en[id]);
}
inline void rtw_macid_ctl_set_rate_bmp0(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp)
{
if (id >= macid_ctl->num) {
rtw_warn_on(1);
return;
}
macid_ctl->rate_bmp0[id] = bmp;
if (0)
RTW_INFO("macid:%u, rate_bmp0:0x%08X\n", id, macid_ctl->rate_bmp0[id]);
}
inline void rtw_macid_ctl_set_rate_bmp1(struct macid_ctl_t *macid_ctl, u8 id, u32 bmp)
{
if (id >= macid_ctl->num) {
rtw_warn_on(1);
return;
}
macid_ctl->rate_bmp1[id] = bmp;
if (0)
RTW_INFO("macid:%u, rate_bmp1:0x%08X\n", id, macid_ctl->rate_bmp1[id]);
}
inline void rtw_macid_ctl_init_sleep_reg(struct macid_ctl_t *macid_ctl, u16 m0, u16 m1, u16 m2, u16 m3)
{
macid_ctl->reg_sleep_m0 = m0;
#if (MACID_NUM_SW_LIMIT > 32)
macid_ctl->reg_sleep_m1 = m1;
#endif
#if (MACID_NUM_SW_LIMIT > 64)
macid_ctl->reg_sleep_m2 = m2;
#endif
#if (MACID_NUM_SW_LIMIT > 96)
macid_ctl->reg_sleep_m3 = m3;
#endif
}
inline void rtw_macid_ctl_init(struct macid_ctl_t *macid_ctl)
{
int i;
u8 id = RTW_DEFAULT_MGMT_MACID;
rtw_macid_map_set(&macid_ctl->used, id);
rtw_macid_map_set(&macid_ctl->bmc, id);
for (i = 0; i < CONFIG_IFACE_NUMBER; i++)
rtw_macid_map_set(&macid_ctl->if_g[i], id);
macid_ctl->sta[id] = NULL;
_rtw_spinlock_init(&macid_ctl->lock);
}
inline void rtw_macid_ctl_deinit(struct macid_ctl_t *macid_ctl)
{
_rtw_spinlock_free(&macid_ctl->lock);
}
inline bool rtw_bmp_is_set(const u8 *bmp, u8 bmp_len, u8 id)
{
if (id / 8 >= bmp_len)
return 0;
return bmp[id / 8] & BIT(id % 8);
}
inline void rtw_bmp_set(u8 *bmp, u8 bmp_len, u8 id)
{
if (id / 8 < bmp_len)
bmp[id / 8] |= BIT(id % 8);
}
inline void rtw_bmp_clear(u8 *bmp, u8 bmp_len, u8 id)
{
if (id / 8 < bmp_len)
bmp[id / 8] &= ~BIT(id % 8);
}
inline bool rtw_bmp_not_empty(const u8 *bmp, u8 bmp_len)
{
int i;
for (i = 0; i < bmp_len; i++) {
if (bmp[i])
return 1;
}
return 0;
}
inline bool rtw_bmp_not_empty_exclude_bit0(const u8 *bmp, u8 bmp_len)
{
int i;
for (i = 0; i < bmp_len; i++) {
if (i == 0) {
if (bmp[i] & 0xFE)
return 1;
} else {
if (bmp[i])
return 1;
}
}
return 0;
}
#ifdef CONFIG_AP_MODE
/* Check the id be set or not in map , if yes , return a none zero value*/
bool rtw_tim_map_is_set(_adapter *padapter, const u8 *map, u8 id)
{
return rtw_bmp_is_set(map, padapter->stapriv.aid_bmp_len, id);
}
/* Set the id into map array*/
void rtw_tim_map_set(_adapter *padapter, u8 *map, u8 id)
{
rtw_bmp_set(map, padapter->stapriv.aid_bmp_len, id);
}
/* Clear the id from map array*/
void rtw_tim_map_clear(_adapter *padapter, u8 *map, u8 id)
{
rtw_bmp_clear(map, padapter->stapriv.aid_bmp_len, id);
}
/* Check have anyone bit be set , if yes return true*/
bool rtw_tim_map_anyone_be_set(_adapter *padapter, const u8 *map)
{
return rtw_bmp_not_empty(map, padapter->stapriv.aid_bmp_len);
}
/* Check have anyone bit be set exclude bit0 , if yes return true*/
bool rtw_tim_map_anyone_be_set_exclude_aid0(_adapter *padapter, const u8 *map)
{
return rtw_bmp_not_empty_exclude_bit0(map, padapter->stapriv.aid_bmp_len);
}
#endif /* CONFIG_AP_MODE */
#if 0
unsigned int setup_beacon_frame(_adapter *padapter, unsigned char *beacon_frame)
{
unsigned short ATIMWindow;
unsigned char *pframe;
struct tx_desc *ptxdesc;
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned int rate_len, len = 0;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
_rtw_memset(beacon_frame, 0, 256);
pframe = beacon_frame + TXDESC_SIZE;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
set_frame_sub_type(pframe, WIFI_BEACON);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
len = sizeof(struct rtw_ieee80211_hdr_3addr);
/* timestamp will be inserted by hardware */
pframe += 8;
len += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
pframe += 2;
len += 2;
/* capability info: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
pframe += 2;
len += 2;
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &len);
/* supported rates... */
rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &len);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &len);
/* IBSS Parameter Set... */
/* ATIMWindow = cur->Configuration.ATIMWindow; */
ATIMWindow = 0;
pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &len);
/* todo: ERP IE */
/* EXTERNDED SUPPORTED RATE */
if (rate_len > 8)
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &len);
if ((len + TXDESC_SIZE) > 256) {
/* RTW_INFO("marc: beacon frame too large\n"); */
return 0;
}
/* fill the tx descriptor */
ptxdesc = (struct tx_desc *)beacon_frame;
/* offset 0 */
ptxdesc->txdw0 |= cpu_to_le32(len & 0x0000ffff);
ptxdesc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) << OFFSET_SHT) & 0x00ff0000); /* default = 32 bytes for TX Desc */
/* offset 4 */
ptxdesc->txdw1 |= cpu_to_le32((0x10 << QSEL_SHT) & 0x00001f00);
/* offset 8 */
ptxdesc->txdw2 |= cpu_to_le32(BMC);
ptxdesc->txdw2 |= cpu_to_le32(BK);
/* offset 16 */
ptxdesc->txdw4 = 0x80000000;
/* offset 20 */
ptxdesc->txdw5 = 0x00000000; /* 1M */
return len + TXDESC_SIZE;
}
#endif
_adapter *dvobj_get_port0_adapter(struct dvobj_priv *dvobj)
{
_adapter *port0_iface = NULL;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
if (get_hw_port(dvobj->padapters[i]) == HW_PORT0)
break;
}
if (i < 0 || i >= dvobj->iface_nums)
rtw_warn_on(1);
else
port0_iface = dvobj->padapters[i];
return port0_iface;
}
_adapter *dvobj_get_unregisterd_adapter(struct dvobj_priv *dvobj)
{
_adapter *adapter = NULL;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
if (dvobj->padapters[i]->registered == 0)
break;
}
if (i < dvobj->iface_nums)
adapter = dvobj->padapters[i];
return adapter;
}
_adapter *dvobj_get_adapter_by_addr(struct dvobj_priv *dvobj, u8 *addr)
{
_adapter *adapter = NULL;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
if (_rtw_memcmp(dvobj->padapters[i]->mac_addr, addr, ETH_ALEN) == _TRUE)
break;
}
if (i < dvobj->iface_nums)
adapter = dvobj->padapters[i];
return adapter;
}
#ifdef CONFIG_WOWLAN
bool rtw_wowlan_parser_pattern_cmd(u8 *input, char *pattern,
int *pattern_len, char *bit_mask)
{
char *cp = NULL, *end = NULL;
size_t len = 0;
int pos = 0, mask_pos = 0, res = 0;
u8 member[2] = {0};
cp = strchr(input, '=');
if (cp) {
*cp = 0;
cp++;
input = cp;
}
while (1) {
cp = strchr(input, ':');
if (cp) {
len = strlen(input) - strlen(cp);
*cp = 0;
cp++;
} else
len = 2;
if (bit_mask && (strcmp(input, "-") == 0 ||
strcmp(input, "xx") == 0 ||
strcmp(input, "--") == 0)) {
/* skip this byte and leave mask bit unset */
} else {
u8 hex;
strncpy(member, input, len);
if (!rtw_check_pattern_valid(member, sizeof(member))) {
RTW_INFO("%s:[ERROR] pattern is invalid!!\n",
__func__);
goto error;
}
res = sscanf(member, "%02hhx", &hex);
pattern[pos] = hex;
mask_pos = pos / 8;
if (bit_mask)
bit_mask[mask_pos] |= 1 << (pos % 8);
}
pos++;
if (!cp)
break;
input = cp;
}
(*pattern_len) = pos;
return _TRUE;
error:
return _FALSE;
}
bool rtw_check_pattern_valid(u8 *input, u8 len)
{
int i = 0;
bool res = _FALSE;
if (len != 2)
goto exit;
for (i = 0 ; i < len ; i++)
if (IsHexDigit(input[i]) == _FALSE)
goto exit;
res = _SUCCESS;
exit:
return res;
}
void rtw_wow_pattern_sw_reset(_adapter *adapter)
{
int i;
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(adapter);
if (pwrctrlpriv->default_patterns_en == _TRUE)
pwrctrlpriv->wowlan_pattern_idx = DEFAULT_PATTERN_NUM;
else
pwrctrlpriv->wowlan_pattern_idx = 0;
for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++) {
_rtw_memset(pwrctrlpriv->patterns[i].content, '\0', sizeof(pwrctrlpriv->patterns[i].content));
_rtw_memset(pwrctrlpriv->patterns[i].mask, '\0', sizeof(pwrctrlpriv->patterns[i].mask));
pwrctrlpriv->patterns[i].len = 0;
}
}
u8 rtw_set_default_pattern(_adapter *adapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
u8 index = 0;
u8 multicast_addr[3] = {0x01, 0x00, 0x5e};
u8 multicast_ip[4] = {0xe0, 0x28, 0x28, 0x2a};
u8 unicast_mask[5] = {0x3f, 0x70, 0x80, 0xc0, 0x03};
u8 icmpv6_mask[7] = {0x00, 0x70, 0x10, 0x00, 0xc0, 0xc0, 0x3f};
u8 multicast_mask[5] = {0x07, 0x70, 0x80, 0xc0, 0x03};
u8 ip_protocol[3] = {0x08, 0x00, 0x45};
u8 ipv6_protocol[3] = {0x86, 0xdd, 0x60};
u8 *target = NULL;
if (pwrpriv->default_patterns_en == _FALSE)
return 0;
for (index = 0 ; index < DEFAULT_PATTERN_NUM ; index++) {
_rtw_memset(pwrpriv->patterns[index].content, 0,
sizeof(pwrpriv->patterns[index].content));
_rtw_memset(pwrpriv->patterns[index].mask, 0,
sizeof(pwrpriv->patterns[index].mask));
pwrpriv->patterns[index].len = 0;
}
/*TCP/ICMP unicast*/
for (index = 0 ; index < DEFAULT_PATTERN_NUM ; index++) {
switch (index) {
case 0:
target = pwrpriv->patterns[index].content;
_rtw_memcpy(target, adapter_mac_addr(adapter),
ETH_ALEN);
target += ETH_TYPE_OFFSET;
_rtw_memcpy(target, &ip_protocol,
sizeof(ip_protocol));
/* TCP */
target += (PROTOCOL_OFFSET - ETH_TYPE_OFFSET);
_rtw_memset(target, 0x06, 1);
target += (IP_OFFSET - PROTOCOL_OFFSET);
_rtw_memcpy(target, pmlmeinfo->ip_addr,
RTW_IP_ADDR_LEN);
_rtw_memcpy(pwrpriv->patterns[index].mask,
&unicast_mask, sizeof(unicast_mask));
pwrpriv->patterns[index].len =
IP_OFFSET + RTW_IP_ADDR_LEN;
break;
case 1:
target = pwrpriv->patterns[index].content;
_rtw_memcpy(target, adapter_mac_addr(adapter),
ETH_ALEN);
target += ETH_TYPE_OFFSET;
_rtw_memcpy(target, &ip_protocol, sizeof(ip_protocol));
/* ICMP */
target += (PROTOCOL_OFFSET - ETH_TYPE_OFFSET);
_rtw_memset(target, 0x01, 1);
target += (IP_OFFSET - PROTOCOL_OFFSET);
_rtw_memcpy(target, pmlmeinfo->ip_addr,
RTW_IP_ADDR_LEN);
_rtw_memcpy(pwrpriv->patterns[index].mask,
&unicast_mask, sizeof(unicast_mask));
pwrpriv->patterns[index].len =
IP_OFFSET + RTW_IP_ADDR_LEN;
break;
#ifdef CONFIG_IPV6
case 2:
if (pwrpriv->wowlan_ns_offload_en == _TRUE) {
target = pwrpriv->patterns[index].content;
target += ETH_TYPE_OFFSET;
_rtw_memcpy(target, &ipv6_protocol,
sizeof(ipv6_protocol));
/* ICMPv6 */
target += (IPv6_PROTOCOL_OFFSET -
ETH_TYPE_OFFSET);
_rtw_memset(target, 0x3a, 1);
target += (IPv6_OFFSET - IPv6_PROTOCOL_OFFSET);
_rtw_memcpy(target, pmlmeinfo->ip6_addr,
RTW_IPv6_ADDR_LEN);
_rtw_memcpy(pwrpriv->patterns[index].mask,
&icmpv6_mask, sizeof(icmpv6_mask));
pwrpriv->patterns[index].len =
IPv6_OFFSET + RTW_IPv6_ADDR_LEN;
}
break;
#endif /*CONFIG_IPV6*/
case 3:
target = pwrpriv->patterns[index].content;
_rtw_memcpy(target, &multicast_addr,
sizeof(multicast_addr));
target += ETH_TYPE_OFFSET;
_rtw_memcpy(target, &ip_protocol, sizeof(ip_protocol));
/* UDP */
target += (PROTOCOL_OFFSET - ETH_TYPE_OFFSET);
_rtw_memset(target, 0x11, 1);
target += (IP_OFFSET - PROTOCOL_OFFSET);
_rtw_memcpy(target, &multicast_ip,
sizeof(multicast_ip));
_rtw_memcpy(pwrpriv->patterns[index].mask,
&multicast_mask, sizeof(multicast_mask));
pwrpriv->patterns[index].len =
IP_OFFSET + sizeof(multicast_ip);
break;
default:
break;
}
}
return index;
}
void rtw_dump_priv_pattern(_adapter *adapter, u8 idx)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
char str_1[128];
char *p_str;
u8 val8 = 0;
int i = 0, j = 0, len = 0, max_len = 0;
RTW_INFO("=========[%d]========\n", idx);
RTW_INFO(">>>priv_pattern_content:\n");
p_str = str_1;
max_len = sizeof(str_1);
for (i = 0 ; i < MAX_WKFM_PATTERN_SIZE / 8 ; i++) {
_rtw_memset(p_str, 0, max_len);
len = 0;
for (j = 0 ; j < 8 ; j++) {
val8 = pwrctl->patterns[idx].content[i * 8 + j];
len += snprintf(p_str + len, max_len - len,
"%02x ", val8);
}
RTW_INFO("%s\n", p_str);
}
RTW_INFO(">>>priv_pattern_mask:\n");
for (i = 0 ; i < MAX_WKFM_SIZE / 8 ; i++) {
_rtw_memset(p_str, 0, max_len);
len = 0;
for (j = 0 ; j < 8 ; j++) {
val8 = pwrctl->patterns[idx].mask[i * 8 + j];
len += snprintf(p_str + len, max_len - len,
"%02x ", val8);
}
RTW_INFO("%s\n", p_str);
}
RTW_INFO(">>>priv_pattern_len:\n");
RTW_INFO("%s: len: %d\n", __func__, pwrctl->patterns[idx].len);
}
void rtw_wow_pattern_sw_dump(_adapter *adapter)
{
int i;
RTW_INFO("********[RTK priv-patterns]*********\n");
for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++)
rtw_dump_priv_pattern(adapter, i);
}
void rtw_get_sec_iv(PADAPTER padapter, u8 *pcur_dot11txpn, u8 *StaAddr)
{
struct sta_info *psta;
struct security_priv *psecpriv = &padapter->securitypriv;
_rtw_memset(pcur_dot11txpn, 0, 8);
if (NULL == StaAddr)
return;
psta = rtw_get_stainfo(&padapter->stapriv, StaAddr);
RTW_INFO("%s(): StaAddr: %02x %02x %02x %02x %02x %02x\n",
__func__, StaAddr[0], StaAddr[1], StaAddr[2],
StaAddr[3], StaAddr[4], StaAddr[5]);
if (psta) {
if (psecpriv->dot11PrivacyAlgrthm == _AES_)
AES_IV(pcur_dot11txpn, psta->dot11txpn, 0);
else if (psecpriv->dot11PrivacyAlgrthm == _TKIP_)
TKIP_IV(pcur_dot11txpn, psta->dot11txpn, 0);
RTW_INFO("%s(): CurrentIV: %02x %02x %02x %02x %02x %02x %02x %02x\n"
, __func__, pcur_dot11txpn[0], pcur_dot11txpn[1],
pcur_dot11txpn[2], pcur_dot11txpn[3], pcur_dot11txpn[4],
pcur_dot11txpn[5], pcur_dot11txpn[6], pcur_dot11txpn[7]);
}
}
#endif /* CONFIG_WOWLAN */
#ifdef CONFIG_PNO_SUPPORT
#define CSCAN_TLV_TYPE_SSID_IE 'S'
#define CIPHER_IE "key_mgmt="
#define CIPHER_NONE "NONE"
#define CIPHER_WPA_PSK "WPA-PSK"
#define CIPHER_WPA_EAP "WPA-EAP IEEE8021X"
/*
* SSIDs list parsing from cscan tlv list
*/
int rtw_parse_ssid_list_tlv(char **list_str, pno_ssid_t *ssid,
int max, int *bytes_left)
{
char *str;
int idx = 0;
if ((list_str == NULL) || (*list_str == NULL) || (*bytes_left < 0)) {
RTW_INFO("%s error paramters\n", __func__);
return -1;
}
str = *list_str;
while (*bytes_left > 0) {
if (str[0] != CSCAN_TLV_TYPE_SSID_IE) {
*list_str = str;
RTW_INFO("nssid=%d left_parse=%d %d\n", idx, *bytes_left, str[0]);
return idx;
}
/* Get proper CSCAN_TLV_TYPE_SSID_IE */
*bytes_left -= 1;
str += 1;
if (str[0] == 0) {
/* Broadcast SSID */
ssid[idx].SSID_len = 0;
memset((char *)ssid[idx].SSID, 0x0, WLAN_SSID_MAXLEN);
*bytes_left -= 1;
str += 1;
RTW_INFO("BROADCAST SCAN left=%d\n", *bytes_left);
} else if (str[0] <= WLAN_SSID_MAXLEN) {
/* Get proper SSID size */
ssid[idx].SSID_len = str[0];
*bytes_left -= 1;
str += 1;
/* Get SSID */
if (ssid[idx].SSID_len > *bytes_left) {
RTW_INFO("%s out of memory range len=%d but left=%d\n",
__func__, ssid[idx].SSID_len, *bytes_left);
return -1;
}
memcpy((char *)ssid[idx].SSID, str, ssid[idx].SSID_len);
*bytes_left -= ssid[idx].SSID_len;
str += ssid[idx].SSID_len;
RTW_INFO("%s :size=%d left=%d\n",
(char *)ssid[idx].SSID, ssid[idx].SSID_len, *bytes_left);
} else {
RTW_INFO("### SSID size more that %d\n", str[0]);
return -1;
}
if (idx++ > max) {
RTW_INFO("%s number of SSIDs more that %d\n", __func__, idx);
return -1;
}
}
*list_str = str;
return idx;
}
int rtw_parse_cipher_list(struct pno_nlo_info *nlo_info, char *list_str)
{
char *pch, *pnext, *pend;
u8 key_len = 0, index = 0;
pch = list_str;
if (nlo_info == NULL || list_str == NULL) {
RTW_INFO("%s error paramters\n", __func__);
return -1;
}
while (strlen(pch) != 0) {
pnext = strstr(pch, "key_mgmt=");
if (pnext != NULL) {
pch = pnext + strlen(CIPHER_IE);
pend = strstr(pch, "}");
if (strncmp(pch, CIPHER_NONE,
strlen(CIPHER_NONE)) == 0)
nlo_info->ssid_cipher_info[index] = 0x00;
else if (strncmp(pch, CIPHER_WPA_PSK,
strlen(CIPHER_WPA_PSK)) == 0)
nlo_info->ssid_cipher_info[index] = 0x66;
else if (strncmp(pch, CIPHER_WPA_EAP,
strlen(CIPHER_WPA_EAP)) == 0)
nlo_info->ssid_cipher_info[index] = 0x01;
index++;
pch = pend + 1;
} else
break;
}
return 0;
}
int rtw_dev_nlo_info_set(struct pno_nlo_info *nlo_info, pno_ssid_t *ssid,
int num, int pno_time, int pno_repeat, int pno_freq_expo_max)
{
int i = 0;
struct file *fp;
mm_segment_t fs;
loff_t pos = 0;
u8 *source = NULL;
long len = 0;
RTW_INFO("+%s+\n", __func__);
nlo_info->fast_scan_period = pno_time;
nlo_info->ssid_num = num & BIT_LEN_MASK_32(8);
nlo_info->hidden_ssid_num = num & BIT_LEN_MASK_32(8);
nlo_info->slow_scan_period = (pno_time * 2);
nlo_info->fast_scan_iterations = 5;
if (nlo_info->hidden_ssid_num > 8)
nlo_info->hidden_ssid_num = 8;
/* TODO: channel list and probe index is all empty. */
for (i = 0 ; i < num ; i++) {
nlo_info->ssid_length[i]
= ssid[i].SSID_len;
}
/* cipher array */
fp = filp_open("/data/misc/wifi/wpa_supplicant.conf", O_RDONLY, 0644);
if (IS_ERR(fp)) {
RTW_INFO("Error, wpa_supplicant.conf doesn't exist.\n");
RTW_INFO("Error, cipher array using default value.\n");
return 0;
}
len = i_size_read(fp->f_path.dentry->d_inode);
if (len < 0 || len > 2048) {
RTW_INFO("Error, file size is bigger than 2048.\n");
RTW_INFO("Error, cipher array using default value.\n");
return 0;
}
fs = get_fs();
set_fs(KERNEL_DS);
source = rtw_zmalloc(2048);
if (source != NULL) {
len = vfs_read(fp, source, len, &pos);
rtw_parse_cipher_list(nlo_info, source);
rtw_mfree(source, 2048);
}
set_fs(fs);
filp_close(fp, NULL);
RTW_INFO("-%s-\n", __func__);
return 0;
}
int rtw_dev_ssid_list_set(struct pno_ssid_list *pno_ssid_list,
pno_ssid_t *ssid, u8 num)
{
int i = 0;
if (num > MAX_PNO_LIST_COUNT)
num = MAX_PNO_LIST_COUNT;
for (i = 0 ; i < num ; i++) {
_rtw_memcpy(&pno_ssid_list->node[i].SSID,
ssid[i].SSID, ssid[i].SSID_len);
pno_ssid_list->node[i].SSID_len = ssid[i].SSID_len;
}
return 0;
}
int rtw_dev_scan_info_set(_adapter *padapter, pno_ssid_t *ssid,
unsigned char ch, unsigned char ch_offset, unsigned short bw_mode)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
struct pno_scan_info *scan_info = pwrctl->pscan_info;
int i;
scan_info->channel_num = MAX_SCAN_LIST_COUNT;
scan_info->orig_ch = ch;
scan_info->orig_bw = bw_mode;
scan_info->orig_40_offset = ch_offset;
for (i = 0 ; i < scan_info->channel_num ; i++) {
if (i < 11)
scan_info->ssid_channel_info[i].active = 1;
else
scan_info->ssid_channel_info[i].active = 0;
scan_info->ssid_channel_info[i].timeout = 100;
scan_info->ssid_channel_info[i].tx_power =
phy_get_tx_power_index(padapter, 0, 0x02, bw_mode, i + 1);
scan_info->ssid_channel_info[i].channel = i + 1;
}
RTW_INFO("%s, channel_num: %d, orig_ch: %d, orig_bw: %d orig_40_offset: %d\n",
__func__, scan_info->channel_num, scan_info->orig_ch,
scan_info->orig_bw, scan_info->orig_40_offset);
return 0;
}
int rtw_dev_pno_set(struct net_device *net, pno_ssid_t *ssid, int num,
int pno_time, int pno_repeat, int pno_freq_expo_max)
{
_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
int ret = -1;
if (num == 0) {
RTW_INFO("%s, nssid is zero, no need to setup pno ssid list\n", __func__);
return 0;
}
if (pwrctl == NULL) {
RTW_INFO("%s, ERROR: pwrctl is NULL\n", __func__);
return -1;
} else {
pwrctl->pnlo_info =
(pno_nlo_info_t *)rtw_zmalloc(sizeof(pno_nlo_info_t));
pwrctl->pno_ssid_list =
(pno_ssid_list_t *)rtw_zmalloc(sizeof(pno_ssid_list_t));
pwrctl->pscan_info =
(pno_scan_info_t *)rtw_zmalloc(sizeof(pno_scan_info_t));
}
if (pwrctl->pnlo_info == NULL ||
pwrctl->pscan_info == NULL ||
pwrctl->pno_ssid_list == NULL) {
RTW_INFO("%s, ERROR: alloc nlo_info, ssid_list, scan_info fail\n", __func__);
goto failing;
}
pwrctl->wowlan_in_resume = _FALSE;
pwrctl->pno_inited = _TRUE;
/* NLO Info */
ret = rtw_dev_nlo_info_set(pwrctl->pnlo_info, ssid, num,
pno_time, pno_repeat, pno_freq_expo_max);
/* SSID Info */
ret = rtw_dev_ssid_list_set(pwrctl->pno_ssid_list, ssid, num);
/* SCAN Info */
ret = rtw_dev_scan_info_set(padapter, ssid, pmlmeext->cur_channel,
pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
RTW_INFO("+%s num: %d, pno_time: %d, pno_repeat:%d, pno_freq_expo_max:%d+\n",
__func__, num, pno_time, pno_repeat, pno_freq_expo_max);
return 0;
failing:
if (pwrctl->pnlo_info) {
rtw_mfree((u8 *)pwrctl->pnlo_info, sizeof(pno_nlo_info_t));
pwrctl->pnlo_info = NULL;
}
if (pwrctl->pno_ssid_list) {
rtw_mfree((u8 *)pwrctl->pno_ssid_list, sizeof(pno_ssid_list_t));
pwrctl->pno_ssid_list = NULL;
}
if (pwrctl->pscan_info) {
rtw_mfree((u8 *)pwrctl->pscan_info, sizeof(pno_scan_info_t));
pwrctl->pscan_info = NULL;
}
return -1;
}
#ifdef CONFIG_PNO_SET_DEBUG
void rtw_dev_pno_debug(struct net_device *net)
{
_adapter *padapter = (_adapter *)rtw_netdev_priv(net);
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
int i = 0, j = 0;
RTW_INFO("*******NLO_INFO********\n");
RTW_INFO("ssid_num: %d\n", pwrctl->pnlo_info->ssid_num);
RTW_INFO("fast_scan_iterations: %d\n",
pwrctl->pnlo_info->fast_scan_iterations);
RTW_INFO("fast_scan_period: %d\n", pwrctl->pnlo_info->fast_scan_period);
RTW_INFO("slow_scan_period: %d\n", pwrctl->pnlo_info->slow_scan_period);
for (i = 0 ; i < MAX_PNO_LIST_COUNT ; i++) {
RTW_INFO("%d SSID (%s) length (%d) cipher(%x) channel(%d)\n",
i, pwrctl->pno_ssid_list->node[i].SSID, pwrctl->pnlo_info->ssid_length[i],
pwrctl->pnlo_info->ssid_cipher_info[i], pwrctl->pnlo_info->ssid_channel_info[i]);
}
RTW_INFO("******SCAN_INFO******\n");
RTW_INFO("ch_num: %d\n", pwrctl->pscan_info->channel_num);
RTW_INFO("orig_ch: %d\n", pwrctl->pscan_info->orig_ch);
RTW_INFO("orig bw: %d\n", pwrctl->pscan_info->orig_bw);
RTW_INFO("orig 40 offset: %d\n", pwrctl->pscan_info->orig_40_offset);
for (i = 0 ; i < MAX_SCAN_LIST_COUNT ; i++) {
RTW_INFO("[%02d] avtive:%d, timeout:%d, tx_power:%d, ch:%02d\n",
i, pwrctl->pscan_info->ssid_channel_info[i].active,
pwrctl->pscan_info->ssid_channel_info[i].timeout,
pwrctl->pscan_info->ssid_channel_info[i].tx_power,
pwrctl->pscan_info->ssid_channel_info[i].channel);
}
RTW_INFO("*****************\n");
}
#endif /* CONFIG_PNO_SET_DEBUG */
#endif /* CONFIG_PNO_SUPPORT */
inline void rtw_collect_bcn_info(_adapter *adapter)
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
if (!is_client_associated_to_ap(adapter))
return;
pmlmeext->cur_bcn_cnt = pmlmeext->bcn_cnt - pmlmeext->last_bcn_cnt;
pmlmeext->last_bcn_cnt = pmlmeext->bcn_cnt;
/*TODO get offset of bcn's timestamp*/
/*pmlmeext->bcn_timestamp;*/
}
================================================
FILE: core/rtw_xmit.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _RTW_XMIT_C_
#include
#include
static u8 P802_1H_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0xf8 };
static u8 RFC1042_OUI[P80211_OUI_LEN] = { 0x00, 0x00, 0x00 };
static void _init_txservq(struct tx_servq *ptxservq)
{
_rtw_init_listhead(&ptxservq->tx_pending);
_rtw_init_queue(&ptxservq->sta_pending);
ptxservq->qcnt = 0;
}
void _rtw_init_sta_xmit_priv(struct sta_xmit_priv *psta_xmitpriv)
{
_rtw_memset((unsigned char *)psta_xmitpriv, 0, sizeof(struct sta_xmit_priv));
_rtw_spinlock_init(&psta_xmitpriv->lock);
/* for(i = 0 ; i < MAX_NUMBLKS; i++) */
/* _init_txservq(&(psta_xmitpriv->blk_q[i])); */
_init_txservq(&psta_xmitpriv->be_q);
_init_txservq(&psta_xmitpriv->bk_q);
_init_txservq(&psta_xmitpriv->vi_q);
_init_txservq(&psta_xmitpriv->vo_q);
_rtw_init_listhead(&psta_xmitpriv->legacy_dz);
_rtw_init_listhead(&psta_xmitpriv->apsd);
}
void rtw_init_xmit_block(_adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_rtw_spinlock_init(&dvobj->xmit_block_lock);
dvobj->xmit_block = XMIT_BLOCK_NONE;
}
void rtw_free_xmit_block(_adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_rtw_spinlock_free(&dvobj->xmit_block_lock);
}
s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, _adapter *padapter)
{
int i;
struct xmit_buf *pxmitbuf;
struct xmit_frame *pxframe;
sint res = _SUCCESS;
/* We don't need to memset padapter->XXX to zero, because adapter is allocated by rtw_zvmalloc(). */
/* _rtw_memset((unsigned char *)pxmitpriv, 0, sizeof(struct xmit_priv)); */
_rtw_spinlock_init(&pxmitpriv->lock);
_rtw_spinlock_init(&pxmitpriv->lock_sctx);
_rtw_init_sema(&pxmitpriv->xmit_sema, 0);
/*
Please insert all the queue initializaiton using _rtw_init_queue below
*/
pxmitpriv->adapter = padapter;
/* for(i = 0 ; i < MAX_NUMBLKS; i++) */
/* _rtw_init_queue(&pxmitpriv->blk_strms[i]); */
_rtw_init_queue(&pxmitpriv->be_pending);
_rtw_init_queue(&pxmitpriv->bk_pending);
_rtw_init_queue(&pxmitpriv->vi_pending);
_rtw_init_queue(&pxmitpriv->vo_pending);
_rtw_init_queue(&pxmitpriv->bm_pending);
/* _rtw_init_queue(&pxmitpriv->legacy_dz_queue); */
/* _rtw_init_queue(&pxmitpriv->apsd_queue); */
_rtw_init_queue(&pxmitpriv->free_xmit_queue);
/*
Please allocate memory with the sz = (struct xmit_frame) * NR_XMITFRAME,
and initialize free_xmit_frame below.
Please also apply free_txobj to link_up all the xmit_frames...
*/
pxmitpriv->pallocated_frame_buf = rtw_zvmalloc(NR_XMITFRAME * sizeof(struct xmit_frame) + 4);
if (pxmitpriv->pallocated_frame_buf == NULL) {
pxmitpriv->pxmit_frame_buf = NULL;
res = _FAIL;
goto exit;
}
pxmitpriv->pxmit_frame_buf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_frame_buf), 4);
/* pxmitpriv->pxmit_frame_buf = pxmitpriv->pallocated_frame_buf + 4 - */
/* ((SIZE_PTR) (pxmitpriv->pallocated_frame_buf) &3); */
pxframe = (struct xmit_frame *) pxmitpriv->pxmit_frame_buf;
for (i = 0; i < NR_XMITFRAME; i++) {
_rtw_init_listhead(&(pxframe->list));
pxframe->padapter = padapter;
pxframe->frame_tag = NULL_FRAMETAG;
pxframe->pkt = NULL;
pxframe->buf_addr = NULL;
pxframe->pxmitbuf = NULL;
rtw_list_insert_tail(&(pxframe->list), &(pxmitpriv->free_xmit_queue.queue));
pxframe++;
}
pxmitpriv->free_xmitframe_cnt = NR_XMITFRAME;
pxmitpriv->frag_len = MAX_FRAG_THRESHOLD;
/* init xmit_buf */
_rtw_init_queue(&pxmitpriv->free_xmitbuf_queue);
_rtw_init_queue(&pxmitpriv->pending_xmitbuf_queue);
pxmitpriv->pallocated_xmitbuf = rtw_zvmalloc(NR_XMITBUFF * sizeof(struct xmit_buf) + 4);
if (pxmitpriv->pallocated_xmitbuf == NULL) {
res = _FAIL;
goto exit;
}
pxmitpriv->pxmitbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_xmitbuf), 4);
/* pxmitpriv->pxmitbuf = pxmitpriv->pallocated_xmitbuf + 4 - */
/* ((SIZE_PTR) (pxmitpriv->pallocated_xmitbuf) &3); */
pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmitbuf;
for (i = 0; i < NR_XMITBUFF; i++) {
_rtw_init_listhead(&pxmitbuf->list);
pxmitbuf->priv_data = NULL;
pxmitbuf->padapter = padapter;
pxmitbuf->buf_tag = XMITBUF_DATA;
/* Tx buf allocation may fail sometimes, so sleep and retry. */
res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
if (res == _FAIL) {
rtw_msleep_os(10);
res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
if (res == _FAIL)
goto exit;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->phead = pxmitbuf->pbuf;
pxmitbuf->pend = pxmitbuf->pbuf + MAX_XMITBUF_SZ;
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
#endif
pxmitbuf->flags = XMIT_VO_QUEUE;
rtw_list_insert_tail(&pxmitbuf->list, &(pxmitpriv->free_xmitbuf_queue.queue));
#ifdef DBG_XMIT_BUF
pxmitbuf->no = i;
#endif
pxmitbuf++;
}
pxmitpriv->free_xmitbuf_cnt = NR_XMITBUFF;
/* init xframe_ext queue, the same count as extbuf */
_rtw_init_queue(&pxmitpriv->free_xframe_ext_queue);
pxmitpriv->xframe_ext_alloc_addr = rtw_zvmalloc(NR_XMIT_EXTBUFF * sizeof(struct xmit_frame) + 4);
if (pxmitpriv->xframe_ext_alloc_addr == NULL) {
pxmitpriv->xframe_ext = NULL;
res = _FAIL;
goto exit;
}
pxmitpriv->xframe_ext = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->xframe_ext_alloc_addr), 4);
pxframe = (struct xmit_frame *)pxmitpriv->xframe_ext;
for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
_rtw_init_listhead(&(pxframe->list));
pxframe->padapter = padapter;
pxframe->frame_tag = NULL_FRAMETAG;
pxframe->pkt = NULL;
pxframe->buf_addr = NULL;
pxframe->pxmitbuf = NULL;
pxframe->ext_tag = 1;
rtw_list_insert_tail(&(pxframe->list), &(pxmitpriv->free_xframe_ext_queue.queue));
pxframe++;
}
pxmitpriv->free_xframe_ext_cnt = NR_XMIT_EXTBUFF;
/* Init xmit extension buff */
_rtw_init_queue(&pxmitpriv->free_xmit_extbuf_queue);
pxmitpriv->pallocated_xmit_extbuf = rtw_zvmalloc(NR_XMIT_EXTBUFF * sizeof(struct xmit_buf) + 4);
if (pxmitpriv->pallocated_xmit_extbuf == NULL) {
res = _FAIL;
goto exit;
}
pxmitpriv->pxmit_extbuf = (u8 *)N_BYTE_ALIGMENT((SIZE_PTR)(pxmitpriv->pallocated_xmit_extbuf), 4);
pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
_rtw_init_listhead(&pxmitbuf->list);
pxmitbuf->priv_data = NULL;
pxmitbuf->padapter = padapter;
pxmitbuf->buf_tag = XMITBUF_MGNT;
res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, MAX_XMIT_EXTBUF_SZ + XMITBUF_ALIGN_SZ, _TRUE);
if (res == _FAIL) {
res = _FAIL;
goto exit;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->phead = pxmitbuf->pbuf;
pxmitbuf->pend = pxmitbuf->pbuf + MAX_XMIT_EXTBUF_SZ;
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
#endif
rtw_list_insert_tail(&pxmitbuf->list, &(pxmitpriv->free_xmit_extbuf_queue.queue));
#ifdef DBG_XMIT_BUF_EXT
pxmitbuf->no = i;
#endif
pxmitbuf++;
}
pxmitpriv->free_xmit_extbuf_cnt = NR_XMIT_EXTBUFF;
for (i = 0; i < CMDBUF_MAX; i++) {
pxmitbuf = &pxmitpriv->pcmd_xmitbuf[i];
if (pxmitbuf) {
_rtw_init_listhead(&pxmitbuf->list);
pxmitbuf->priv_data = NULL;
pxmitbuf->padapter = padapter;
pxmitbuf->buf_tag = XMITBUF_CMD;
res = rtw_os_xmit_resource_alloc(padapter, pxmitbuf, MAX_CMDBUF_SZ + XMITBUF_ALIGN_SZ, _TRUE);
if (res == _FAIL) {
res = _FAIL;
goto exit;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->phead = pxmitbuf->pbuf;
pxmitbuf->pend = pxmitbuf->pbuf + MAX_CMDBUF_SZ;
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
#endif
pxmitbuf->alloc_sz = MAX_CMDBUF_SZ + XMITBUF_ALIGN_SZ;
}
}
rtw_alloc_hwxmits(padapter);
rtw_init_hwxmits(pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
for (i = 0; i < 4; i++)
pxmitpriv->wmm_para_seq[i] = i;
#ifdef CONFIG_USB_HCI
pxmitpriv->txirp_cnt = 1;
_rtw_init_sema(&(pxmitpriv->tx_retevt), 0);
/* per AC pending irp */
pxmitpriv->beq_cnt = 0;
pxmitpriv->bkq_cnt = 0;
pxmitpriv->viq_cnt = 0;
pxmitpriv->voq_cnt = 0;
#endif
#ifdef CONFIG_XMIT_ACK
pxmitpriv->ack_tx = _FALSE;
_rtw_mutex_init(&pxmitpriv->ack_tx_mutex);
rtw_sctx_init(&pxmitpriv->ack_tx_ops, 0);
#endif
#ifdef CONFIG_TX_AMSDU
rtw_init_timer(&(pxmitpriv->amsdu_vo_timer), padapter,
rtw_amsdu_vo_timeout_handler, padapter);
pxmitpriv->amsdu_vo_timeout = RTW_AMSDU_TIMER_UNSET;
rtw_init_timer(&(pxmitpriv->amsdu_vi_timer), padapter,
rtw_amsdu_vi_timeout_handler, padapter);
pxmitpriv->amsdu_vi_timeout = RTW_AMSDU_TIMER_UNSET;
rtw_init_timer(&(pxmitpriv->amsdu_be_timer), padapter,
rtw_amsdu_be_timeout_handler, padapter);
pxmitpriv->amsdu_be_timeout = RTW_AMSDU_TIMER_UNSET;
rtw_init_timer(&(pxmitpriv->amsdu_bk_timer), padapter,
rtw_amsdu_bk_timeout_handler, padapter);
pxmitpriv->amsdu_bk_timeout = RTW_AMSDU_TIMER_UNSET;
pxmitpriv->amsdu_debug_set_timer = 0;
pxmitpriv->amsdu_debug_timeout = 0;
pxmitpriv->amsdu_debug_coalesce_one = 0;
pxmitpriv->amsdu_debug_coalesce_two = 0;
#endif
#ifdef DBG_TXBD_DESC_DUMP
pxmitpriv->dump_txbd_desc = 0;
#endif
rtw_init_xmit_block(padapter);
rtw_hal_init_xmit_priv(padapter);
exit:
return res;
}
void rtw_mfree_xmit_priv_lock(struct xmit_priv *pxmitpriv);
void rtw_mfree_xmit_priv_lock(struct xmit_priv *pxmitpriv)
{
_rtw_spinlock_free(&pxmitpriv->lock);
_rtw_free_sema(&pxmitpriv->xmit_sema);
_rtw_spinlock_free(&pxmitpriv->be_pending.lock);
_rtw_spinlock_free(&pxmitpriv->bk_pending.lock);
_rtw_spinlock_free(&pxmitpriv->vi_pending.lock);
_rtw_spinlock_free(&pxmitpriv->vo_pending.lock);
_rtw_spinlock_free(&pxmitpriv->bm_pending.lock);
/* _rtw_spinlock_free(&pxmitpriv->legacy_dz_queue.lock); */
/* _rtw_spinlock_free(&pxmitpriv->apsd_queue.lock); */
_rtw_spinlock_free(&pxmitpriv->free_xmit_queue.lock);
_rtw_spinlock_free(&pxmitpriv->free_xmitbuf_queue.lock);
_rtw_spinlock_free(&pxmitpriv->pending_xmitbuf_queue.lock);
}
void _rtw_free_xmit_priv(struct xmit_priv *pxmitpriv)
{
int i;
_adapter *padapter = pxmitpriv->adapter;
struct xmit_frame *pxmitframe = (struct xmit_frame *) pxmitpriv->pxmit_frame_buf;
struct xmit_buf *pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmitbuf;
rtw_hal_free_xmit_priv(padapter);
rtw_mfree_xmit_priv_lock(pxmitpriv);
if (pxmitpriv->pxmit_frame_buf == NULL)
goto out;
for (i = 0; i < NR_XMITFRAME; i++) {
rtw_os_xmit_complete(padapter, pxmitframe);
pxmitframe++;
}
for (i = 0; i < NR_XMITBUFF; i++) {
rtw_os_xmit_resource_free(padapter, pxmitbuf, (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
pxmitbuf++;
}
if (pxmitpriv->pallocated_frame_buf)
rtw_vmfree(pxmitpriv->pallocated_frame_buf, NR_XMITFRAME * sizeof(struct xmit_frame) + 4);
if (pxmitpriv->pallocated_xmitbuf)
rtw_vmfree(pxmitpriv->pallocated_xmitbuf, NR_XMITBUFF * sizeof(struct xmit_buf) + 4);
/* free xframe_ext queue, the same count as extbuf */
if ((pxmitframe = (struct xmit_frame *)pxmitpriv->xframe_ext)) {
for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
rtw_os_xmit_complete(padapter, pxmitframe);
pxmitframe++;
}
}
if (pxmitpriv->xframe_ext_alloc_addr)
rtw_vmfree(pxmitpriv->xframe_ext_alloc_addr, NR_XMIT_EXTBUFF * sizeof(struct xmit_frame) + 4);
_rtw_spinlock_free(&pxmitpriv->free_xframe_ext_queue.lock);
/* free xmit extension buff */
_rtw_spinlock_free(&pxmitpriv->free_xmit_extbuf_queue.lock);
pxmitbuf = (struct xmit_buf *)pxmitpriv->pxmit_extbuf;
for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
rtw_os_xmit_resource_free(padapter, pxmitbuf, (MAX_XMIT_EXTBUF_SZ + XMITBUF_ALIGN_SZ), _TRUE);
pxmitbuf++;
}
if (pxmitpriv->pallocated_xmit_extbuf)
rtw_vmfree(pxmitpriv->pallocated_xmit_extbuf, NR_XMIT_EXTBUFF * sizeof(struct xmit_buf) + 4);
for (i = 0; i < CMDBUF_MAX; i++) {
pxmitbuf = &pxmitpriv->pcmd_xmitbuf[i];
if (pxmitbuf != NULL)
rtw_os_xmit_resource_free(padapter, pxmitbuf, MAX_CMDBUF_SZ + XMITBUF_ALIGN_SZ , _TRUE);
}
rtw_free_hwxmits(padapter);
#ifdef CONFIG_XMIT_ACK
_rtw_mutex_free(&pxmitpriv->ack_tx_mutex);
#endif
rtw_free_xmit_block(padapter);
out:
return;
}
u8 rtw_get_tx_bw_mode(_adapter *adapter, struct sta_info *sta)
{
u8 bw;
bw = sta->cmn.bw_mode;
if (MLME_STATE(adapter) & WIFI_ASOC_STATE) {
if (adapter->mlmeextpriv.cur_channel <= 14)
bw = rtw_min(bw, ADAPTER_TX_BW_2G(adapter));
else
bw = rtw_min(bw, ADAPTER_TX_BW_5G(adapter));
}
return bw;
}
void rtw_get_adapter_tx_rate_bmp_by_bw(_adapter *adapter, u8 bw, u16 *r_bmp_cck_ofdm, u32 *r_bmp_ht, u32 *r_bmp_vht)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
u8 fix_bw = 0xFF;
u16 bmp_cck_ofdm = 0;
u32 bmp_ht = 0;
u32 bmp_vht = 0;
int i;
if (adapter->fix_rate != 0xFF && adapter->fix_bw != 0xFF)
fix_bw = adapter->fix_bw;
/* TODO: adapter->fix_rate */
for (i = 0; i < macid_ctl->num; i++) {
if (!rtw_macid_is_used(macid_ctl, i))
continue;
if (!rtw_macid_is_iface_specific(macid_ctl, i, adapter))
continue;
if (bw == CHANNEL_WIDTH_20) /* CCK, OFDM always 20MHz */
bmp_cck_ofdm |= macid_ctl->rate_bmp0[i] & 0x00000FFF;
/* bypass mismatch bandwidth for HT, VHT */
if ((fix_bw != 0xFF && fix_bw != bw) || (fix_bw == 0xFF && macid_ctl->bw[i] != bw))
continue;
if (macid_ctl->vht_en[i])
bmp_vht |= (macid_ctl->rate_bmp0[i] >> 12) | (macid_ctl->rate_bmp1[i] << 20);
else
bmp_ht |= (macid_ctl->rate_bmp0[i] >> 12) | (macid_ctl->rate_bmp1[i] << 20);
}
/* TODO: mlmeext->tx_rate*/
if (r_bmp_cck_ofdm)
*r_bmp_cck_ofdm = bmp_cck_ofdm;
if (r_bmp_ht)
*r_bmp_ht = bmp_ht;
if (r_bmp_vht)
*r_bmp_vht = bmp_vht;
}
void rtw_get_shared_macid_tx_rate_bmp_by_bw(struct dvobj_priv *dvobj, u8 bw, u16 *r_bmp_cck_ofdm, u32 *r_bmp_ht, u32 *r_bmp_vht)
{
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
u16 bmp_cck_ofdm = 0;
u32 bmp_ht = 0;
u32 bmp_vht = 0;
int i;
for (i = 0; i < macid_ctl->num; i++) {
if (!rtw_macid_is_used(macid_ctl, i))
continue;
if (!rtw_macid_is_iface_shared(macid_ctl, i))
continue;
if (bw == CHANNEL_WIDTH_20) /* CCK, OFDM always 20MHz */
bmp_cck_ofdm |= macid_ctl->rate_bmp0[i] & 0x00000FFF;
/* bypass mismatch bandwidth for HT, VHT */
if (macid_ctl->bw[i] != bw)
continue;
if (macid_ctl->vht_en[i])
bmp_vht |= (macid_ctl->rate_bmp0[i] >> 12) | (macid_ctl->rate_bmp1[i] << 20);
else
bmp_ht |= (macid_ctl->rate_bmp0[i] >> 12) | (macid_ctl->rate_bmp1[i] << 20);
}
if (r_bmp_cck_ofdm)
*r_bmp_cck_ofdm = bmp_cck_ofdm;
if (r_bmp_ht)
*r_bmp_ht = bmp_ht;
if (r_bmp_vht)
*r_bmp_vht = bmp_vht;
}
void rtw_update_tx_rate_bmp(struct dvobj_priv *dvobj)
{
struct rf_ctl_t *rf_ctl = dvobj_to_rfctl(dvobj);
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 bw;
u16 bmp_cck_ofdm, tmp_cck_ofdm;
u32 bmp_ht, tmp_ht, ori_bmp_ht[2];
u8 ori_highest_ht_rate_bw_bmp;
u32 bmp_vht, tmp_vht, ori_bmp_vht[4];
u8 ori_highest_vht_rate_bw_bmp;
int i;
/* backup the original ht & vht highest bw bmp */
ori_highest_ht_rate_bw_bmp = rf_ctl->highest_ht_rate_bw_bmp;
ori_highest_vht_rate_bw_bmp = rf_ctl->highest_vht_rate_bw_bmp;
for (bw = CHANNEL_WIDTH_20; bw <= CHANNEL_WIDTH_160; bw++) {
/* backup the original ht & vht bmp */
if (bw <= CHANNEL_WIDTH_40)
ori_bmp_ht[bw] = rf_ctl->rate_bmp_ht_by_bw[bw];
if (bw <= CHANNEL_WIDTH_160)
ori_bmp_vht[bw] = rf_ctl->rate_bmp_vht_by_bw[bw];
bmp_cck_ofdm = bmp_ht = bmp_vht = 0;
if (hal_is_bw_support(dvobj_get_primary_adapter(dvobj), bw)) {
for (i = 0; i < dvobj->iface_nums; i++) {
if (!dvobj->padapters[i])
continue;
rtw_get_adapter_tx_rate_bmp_by_bw(dvobj->padapters[i], bw, &tmp_cck_ofdm, &tmp_ht, &tmp_vht);
bmp_cck_ofdm |= tmp_cck_ofdm;
bmp_ht |= tmp_ht;
bmp_vht |= tmp_vht;
}
rtw_get_shared_macid_tx_rate_bmp_by_bw(dvobj, bw, &tmp_cck_ofdm, &tmp_ht, &tmp_vht);
bmp_cck_ofdm |= tmp_cck_ofdm;
bmp_ht |= tmp_ht;
bmp_vht |= tmp_vht;
}
if (bw == CHANNEL_WIDTH_20)
rf_ctl->rate_bmp_cck_ofdm = bmp_cck_ofdm;
if (bw <= CHANNEL_WIDTH_40)
rf_ctl->rate_bmp_ht_by_bw[bw] = bmp_ht;
if (bw <= CHANNEL_WIDTH_160)
rf_ctl->rate_bmp_vht_by_bw[bw] = bmp_vht;
}
#ifndef DBG_HIGHEST_RATE_BMP_BW_CHANGE
#define DBG_HIGHEST_RATE_BMP_BW_CHANGE 0
#endif
{
u8 highest_rate_bw;
u8 highest_rate_bw_bmp;
u8 update_ht_rs = _FALSE;
u8 update_vht_rs = _FALSE;
highest_rate_bw_bmp = BW_CAP_20M;
highest_rate_bw = CHANNEL_WIDTH_20;
for (bw = CHANNEL_WIDTH_20; bw <= CHANNEL_WIDTH_40; bw++) {
if (rf_ctl->rate_bmp_ht_by_bw[highest_rate_bw] < rf_ctl->rate_bmp_ht_by_bw[bw]) {
highest_rate_bw_bmp = ch_width_to_bw_cap(bw);
highest_rate_bw = bw;
} else if (rf_ctl->rate_bmp_ht_by_bw[highest_rate_bw] == rf_ctl->rate_bmp_ht_by_bw[bw])
highest_rate_bw_bmp |= ch_width_to_bw_cap(bw);
}
rf_ctl->highest_ht_rate_bw_bmp = highest_rate_bw_bmp;
if (ori_highest_ht_rate_bw_bmp != rf_ctl->highest_ht_rate_bw_bmp
|| largest_bit(ori_bmp_ht[highest_rate_bw]) != largest_bit(rf_ctl->rate_bmp_ht_by_bw[highest_rate_bw])
) {
if (DBG_HIGHEST_RATE_BMP_BW_CHANGE) {
RTW_INFO("highest_ht_rate_bw_bmp:0x%02x=>0x%02x\n", ori_highest_ht_rate_bw_bmp, rf_ctl->highest_ht_rate_bw_bmp);
RTW_INFO("rate_bmp_ht_by_bw[%u]:0x%08x=>0x%08x\n", highest_rate_bw, ori_bmp_ht[highest_rate_bw], rf_ctl->rate_bmp_ht_by_bw[highest_rate_bw]);
}
update_ht_rs = _TRUE;
}
highest_rate_bw_bmp = BW_CAP_20M;
highest_rate_bw = CHANNEL_WIDTH_20;
for (bw = CHANNEL_WIDTH_20; bw <= CHANNEL_WIDTH_160; bw++) {
if (rf_ctl->rate_bmp_vht_by_bw[highest_rate_bw] < rf_ctl->rate_bmp_vht_by_bw[bw]) {
highest_rate_bw_bmp = ch_width_to_bw_cap(bw);
highest_rate_bw = bw;
} else if (rf_ctl->rate_bmp_vht_by_bw[highest_rate_bw] == rf_ctl->rate_bmp_vht_by_bw[bw])
highest_rate_bw_bmp |= ch_width_to_bw_cap(bw);
}
rf_ctl->highest_vht_rate_bw_bmp = highest_rate_bw_bmp;
if (ori_highest_vht_rate_bw_bmp != rf_ctl->highest_vht_rate_bw_bmp
|| largest_bit(ori_bmp_vht[highest_rate_bw]) != largest_bit(rf_ctl->rate_bmp_vht_by_bw[highest_rate_bw])
) {
if (DBG_HIGHEST_RATE_BMP_BW_CHANGE) {
RTW_INFO("highest_vht_rate_bw_bmp:0x%02x=>0x%02x\n", ori_highest_vht_rate_bw_bmp, rf_ctl->highest_vht_rate_bw_bmp);
RTW_INFO("rate_bmp_vht_by_bw[%u]:0x%08x=>0x%08x\n", highest_rate_bw, ori_bmp_vht[highest_rate_bw], rf_ctl->rate_bmp_vht_by_bw[highest_rate_bw]);
}
update_vht_rs = _TRUE;
}
/* TODO: per rfpath and rate section handling? */
if (update_ht_rs == _TRUE || update_vht_rs == _TRUE)
rtw_hal_set_tx_power_level(dvobj_get_primary_adapter(dvobj), hal_data->current_channel);
}
}
inline u16 rtw_get_tx_rate_bmp_cck_ofdm(struct dvobj_priv *dvobj)
{
struct rf_ctl_t *rf_ctl = dvobj_to_rfctl(dvobj);
return rf_ctl->rate_bmp_cck_ofdm;
}
inline u32 rtw_get_tx_rate_bmp_ht_by_bw(struct dvobj_priv *dvobj, u8 bw)
{
struct rf_ctl_t *rf_ctl = dvobj_to_rfctl(dvobj);
return rf_ctl->rate_bmp_ht_by_bw[bw];
}
inline u32 rtw_get_tx_rate_bmp_vht_by_bw(struct dvobj_priv *dvobj, u8 bw)
{
struct rf_ctl_t *rf_ctl = dvobj_to_rfctl(dvobj);
return rf_ctl->rate_bmp_vht_by_bw[bw];
}
u8 rtw_get_tx_bw_bmp_of_ht_rate(struct dvobj_priv *dvobj, u8 rate, u8 max_bw)
{
struct rf_ctl_t *rf_ctl = dvobj_to_rfctl(dvobj);
u8 bw;
u8 bw_bmp = 0;
u32 rate_bmp;
if (!IS_HT_RATE(rate)) {
rtw_warn_on(1);
goto exit;
}
rate_bmp = 1 << (rate - MGN_MCS0);
if (max_bw > CHANNEL_WIDTH_40)
max_bw = CHANNEL_WIDTH_40;
for (bw = CHANNEL_WIDTH_20; bw <= max_bw; bw++) {
/* RA may use lower rate for retry */
if (rf_ctl->rate_bmp_ht_by_bw[bw] >= rate_bmp)
bw_bmp |= ch_width_to_bw_cap(bw);
}
exit:
return bw_bmp;
}
u8 rtw_get_tx_bw_bmp_of_vht_rate(struct dvobj_priv *dvobj, u8 rate, u8 max_bw)
{
struct rf_ctl_t *rf_ctl = dvobj_to_rfctl(dvobj);
u8 bw;
u8 bw_bmp = 0;
u32 rate_bmp;
if (!IS_VHT_RATE(rate)) {
rtw_warn_on(1);
goto exit;
}
rate_bmp = 1 << (rate - MGN_VHT1SS_MCS0);
if (max_bw > CHANNEL_WIDTH_160)
max_bw = CHANNEL_WIDTH_160;
for (bw = CHANNEL_WIDTH_20; bw <= max_bw; bw++) {
/* RA may use lower rate for retry */
if (rf_ctl->rate_bmp_vht_by_bw[bw] >= rate_bmp)
bw_bmp |= ch_width_to_bw_cap(bw);
}
exit:
return bw_bmp;
}
u8 query_ra_short_GI(struct sta_info *psta, u8 bw)
{
u8 sgi = _FALSE, sgi_20m = _FALSE, sgi_40m = _FALSE, sgi_80m = _FALSE;
#ifdef CONFIG_80211N_HT
#ifdef CONFIG_80211AC_VHT
if (psta->vhtpriv.vht_option)
sgi_80m = psta->vhtpriv.sgi_80m;
#endif
sgi_20m = psta->htpriv.sgi_20m;
sgi_40m = psta->htpriv.sgi_40m;
#endif
switch (bw) {
case CHANNEL_WIDTH_80:
sgi = sgi_80m;
break;
case CHANNEL_WIDTH_40:
sgi = sgi_40m;
break;
case CHANNEL_WIDTH_20:
default:
sgi = sgi_20m;
break;
}
return sgi;
}
static void update_attrib_vcs_info(_adapter *padapter, struct xmit_frame *pxmitframe)
{
u32 sz;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
/* struct sta_info *psta = pattrib->psta; */
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/*
if(pattrib->psta)
{
psta = pattrib->psta;
}
else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
psta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0] );
}
if(psta==NULL)
{
RTW_INFO("%s, psta==NUL\n", __func__);
return;
}
if(!(psta->state &_FW_LINKED))
{
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return;
}
*/
if (pattrib->nr_frags != 1)
sz = padapter->xmitpriv.frag_len;
else /* no frag */
sz = pattrib->last_txcmdsz;
/* (1) RTS_Threshold is compared to the MPDU, not MSDU. */
/* (2) If there are more than one frag in this MSDU, only the first frag uses protection frame. */
/* Other fragments are protected by previous fragment. */
/* So we only need to check the length of first fragment. */
if (pmlmeext->cur_wireless_mode < WIRELESS_11_24N || padapter->registrypriv.wifi_spec) {
if (sz > padapter->registrypriv.rts_thresh)
pattrib->vcs_mode = RTS_CTS;
else {
if (pattrib->rtsen)
pattrib->vcs_mode = RTS_CTS;
else if (pattrib->cts2self)
pattrib->vcs_mode = CTS_TO_SELF;
else
pattrib->vcs_mode = NONE_VCS;
}
} else {
while (_TRUE) {
#if 0 /* Todo */
/* check IOT action */
if (pHTInfo->IOTAction & HT_IOT_ACT_FORCED_CTS2SELF) {
pattrib->vcs_mode = CTS_TO_SELF;
pattrib->rts_rate = MGN_24M;
break;
} else if (pHTInfo->IOTAction & (HT_IOT_ACT_FORCED_RTS | HT_IOT_ACT_PURE_N_MODE)) {
pattrib->vcs_mode = RTS_CTS;
pattrib->rts_rate = MGN_24M;
break;
}
#endif
/* IOT action */
if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_ATHEROS) && (pattrib->ampdu_en == _TRUE) &&
(padapter->securitypriv.dot11PrivacyAlgrthm == _AES_)) {
pattrib->vcs_mode = CTS_TO_SELF;
break;
}
/* check ERP protection */
if (pattrib->rtsen || pattrib->cts2self) {
if (pattrib->rtsen)
pattrib->vcs_mode = RTS_CTS;
else if (pattrib->cts2self)
pattrib->vcs_mode = CTS_TO_SELF;
break;
}
/* check HT op mode */
if (pattrib->ht_en) {
u8 HTOpMode = pmlmeinfo->HT_protection;
if ((pmlmeext->cur_bwmode && (HTOpMode == 2 || HTOpMode == 3)) ||
(!pmlmeext->cur_bwmode && HTOpMode == 3)) {
pattrib->vcs_mode = RTS_CTS;
break;
}
}
/* check rts */
if (sz > padapter->registrypriv.rts_thresh) {
pattrib->vcs_mode = RTS_CTS;
break;
}
/* to do list: check MIMO power save condition. */
/* check AMPDU aggregation for TXOP */
if ((pattrib->ampdu_en == _TRUE) && (!IS_HARDWARE_TYPE_8812(padapter))) {
pattrib->vcs_mode = RTS_CTS;
break;
}
pattrib->vcs_mode = NONE_VCS;
break;
}
}
/* for debug : force driver control vrtl_carrier_sense. */
if (padapter->driver_vcs_en == 1) {
/* u8 driver_vcs_en; */ /* Enable=1, Disable=0 driver control vrtl_carrier_sense. */
/* u8 driver_vcs_type; */ /* force 0:disable VCS, 1:RTS-CTS, 2:CTS-to-self when vcs_en=1. */
pattrib->vcs_mode = padapter->driver_vcs_type;
}
}
#ifdef CONFIG_WMMPS_STA
/*
* update_attrib_trigger_frame_info
* For Station mode, if a specific TID of driver setting and an AP support uapsd function, the data
* frame with corresponding TID will be a trigger frame when driver is in wmm power saving mode.
*
* Arguments:
* @padapter: _adapter pointer.
* @pattrib: pkt_attrib pointer.
*
* Auther: Arvin Liu
* Date: 2017/06/05
*/
static void update_attrib_trigger_frame_info(_adapter *padapter, struct pkt_attrib *pattrib) {
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
u8 trigger_frame_en = 0;
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE) {
if ((pwrpriv->pwr_mode == PS_MODE_MIN) || (pwrpriv->pwr_mode == PS_MODE_MAX)) {
if((pqospriv->uapsd_ap_supported) && ((pqospriv->uapsd_tid & BIT(pattrib->priority)) == _TRUE)) {
trigger_frame_en = 1;
RTW_INFO("[WMMPS]"FUNC_ADPT_FMT": This is a Trigger Frame\n", FUNC_ADPT_ARG(padapter));
}
}
}
pattrib->trigger_frame = trigger_frame_en;
}
#endif /* CONFIG_WMMPS_STA */
static void update_attrib_phy_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)
{
struct mlme_ext_priv *mlmeext = &padapter->mlmeextpriv;
u8 bw;
pattrib->rtsen = psta->rtsen;
pattrib->cts2self = psta->cts2self;
pattrib->mdata = 0;
pattrib->eosp = 0;
pattrib->triggered = 0;
pattrib->ampdu_spacing = 0;
/* ht_en, init rate, ,bw, ch_offset, sgi */
pattrib->raid = psta->cmn.ra_info.rate_id;
bw = rtw_get_tx_bw_mode(padapter, psta);
pattrib->bwmode = rtw_min(bw, mlmeext->cur_bwmode);
pattrib->sgi = query_ra_short_GI(psta, pattrib->bwmode);
pattrib->ldpc = psta->cmn.ldpc_en;
pattrib->stbc = psta->cmn.stbc_en;
#ifdef CONFIG_80211N_HT
if(padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode)) {
pattrib->ht_en = psta->htpriv.ht_option;
pattrib->ch_offset = psta->htpriv.ch_offset;
pattrib->ampdu_en = _FALSE;
if (padapter->driver_ampdu_spacing != 0xFF) /* driver control AMPDU Density for peer sta's rx */
pattrib->ampdu_spacing = padapter->driver_ampdu_spacing;
else
pattrib->ampdu_spacing = psta->htpriv.rx_ampdu_min_spacing;
/* check if enable ampdu */
if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
if (psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority)) {
pattrib->ampdu_en = _TRUE;
if (psta->htpriv.tx_amsdu_enable == _TRUE)
pattrib->amsdu_ampdu_en = _TRUE;
else
pattrib->amsdu_ampdu_en = _FALSE;
}
}
}
#endif /* CONFIG_80211N_HT */
/* if(pattrib->ht_en && psta->htpriv.ampdu_enable) */
/* { */
/* if(psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority)) */
/* pattrib->ampdu_en = _TRUE; */
/* } */
#ifdef CONFIG_TDLS
if (pattrib->direct_link == _TRUE) {
psta = pattrib->ptdls_sta;
pattrib->raid = psta->cmn.ra_info.rate_id;
#ifdef CONFIG_80211N_HT
if(padapter->registrypriv.ht_enable &&
is_supported_ht(padapter->registrypriv.wireless_mode)) {
pattrib->bwmode = rtw_get_tx_bw_mode(padapter, psta);
pattrib->ht_en = psta->htpriv.ht_option;
pattrib->ch_offset = psta->htpriv.ch_offset;
pattrib->sgi = query_ra_short_GI(psta, pattrib->bwmode);
}
#endif /* CONFIG_80211N_HT */
}
#endif /* CONFIG_TDLS */
pattrib->retry_ctrl = _FALSE;
}
static s32 update_attrib_sec_info(_adapter *padapter, struct pkt_attrib *pattrib, struct sta_info *psta)
{
sint res = _SUCCESS;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
sint bmcast = IS_MCAST(pattrib->ra);
_rtw_memset(pattrib->dot118021x_UncstKey.skey, 0, 16);
_rtw_memset(pattrib->dot11tkiptxmickey.skey, 0, 16);
pattrib->mac_id = psta->cmn.mac_id;
if (psta->ieee8021x_blocked == _TRUE) {
pattrib->encrypt = 0;
if ((pattrib->ether_type != 0x888e) && (check_fwstate(pmlmepriv, WIFI_MP_STATE) == _FALSE)) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s psta->ieee8021x_blocked == _TRUE, pattrib->ether_type(%04x) != 0x888e\n", __FUNCTION__, pattrib->ether_type);
#endif
res = _FAIL;
goto exit;
}
} else {
GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, bmcast);
#ifdef CONFIG_WAPI_SUPPORT
if (pattrib->ether_type == 0x88B4)
pattrib->encrypt = _NO_PRIVACY_;
#endif
switch (psecuritypriv->dot11AuthAlgrthm) {
case dot11AuthAlgrthm_Open:
case dot11AuthAlgrthm_Shared:
case dot11AuthAlgrthm_Auto:
pattrib->key_idx = (u8)psecuritypriv->dot11PrivacyKeyIndex;
break;
case dot11AuthAlgrthm_8021X:
if (bmcast)
pattrib->key_idx = (u8)psecuritypriv->dot118021XGrpKeyid;
else
pattrib->key_idx = 0;
break;
default:
pattrib->key_idx = 0;
break;
}
/* For WPS 1.0 WEP, driver should not encrypt EAPOL Packet for WPS handshake. */
if (((pattrib->encrypt == _WEP40_) || (pattrib->encrypt == _WEP104_)) && (pattrib->ether_type == 0x888e))
pattrib->encrypt = _NO_PRIVACY_;
}
#ifdef CONFIG_TDLS
if (pattrib->direct_link == _TRUE) {
if (pattrib->encrypt > 0)
pattrib->encrypt = _AES_;
}
#endif
switch (pattrib->encrypt) {
case _WEP40_:
case _WEP104_:
pattrib->iv_len = 4;
pattrib->icv_len = 4;
WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
break;
case _TKIP_:
pattrib->iv_len = 8;
pattrib->icv_len = 4;
if (psecuritypriv->busetkipkey == _FAIL) {
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s psecuritypriv->busetkipkey(%d)==_FAIL drop packet\n", __FUNCTION__, psecuritypriv->busetkipkey);
#endif
res = _FAIL;
goto exit;
}
if (bmcast)
TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
else
TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
_rtw_memcpy(pattrib->dot11tkiptxmickey.skey, psta->dot11tkiptxmickey.skey, 16);
break;
case _AES_:
pattrib->iv_len = 8;
pattrib->icv_len = 8;
if (bmcast)
AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
else
AES_IV(pattrib->iv, psta->dot11txpn, 0);
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
pattrib->iv_len = 18;
pattrib->icv_len = 16;
rtw_wapi_get_iv(padapter, pattrib->ra, pattrib->iv);
break;
#endif
default:
pattrib->iv_len = 0;
pattrib->icv_len = 0;
break;
}
if (pattrib->encrypt > 0)
_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
if (pattrib->encrypt &&
((padapter->securitypriv.sw_encrypt == _TRUE) || (psecuritypriv->hw_decrypted == _FALSE))) {
pattrib->bswenc = _TRUE;
} else {
pattrib->bswenc = _FALSE;
}
#if defined(CONFIG_CONCURRENT_MODE)
pattrib->bmc_camid = padapter->securitypriv.dot118021x_bmc_cam_id;
#endif
if (pattrib->encrypt && bmcast && _rtw_camctl_chk_flags(padapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH))
pattrib->bswenc = _TRUE;
#ifdef CONFIG_WAPI_SUPPORT
if (pattrib->encrypt == _SMS4_)
pattrib->bswenc = _FALSE;
#endif
exit:
return res;
}
u8 qos_acm(u8 acm_mask, u8 priority)
{
u8 change_priority = priority;
switch (priority) {
case 0:
case 3:
if (acm_mask & BIT(1))
change_priority = 1;
break;
case 1:
case 2:
break;
case 4:
case 5:
if (acm_mask & BIT(2))
change_priority = 0;
break;
case 6:
case 7:
if (acm_mask & BIT(3))
change_priority = 5;
break;
default:
RTW_INFO("qos_acm(): invalid pattrib->priority: %d!!!\n", priority);
break;
}
return change_priority;
}
#ifdef CONFIG_USER_PRIORITY_COMPLY_RFC4594_DSCP
/* refer to IEEE802.11-2016 Table R-3; Comply with Table R-2 (IETF RFC4594) */
static u8 dscp_to_up_ac(u8 tos)
{
u8 up = 0;
u8 dscp;
dscp = (tos >> 2);
if ( dscp == 0 )
up = 0;
else if ( dscp >= 1 && dscp <= 9)
up = 1;
else if ( dscp >= 10 && dscp <= 16)
up = 2;
else if ( dscp >= 17 && dscp <= 23)
up = 3;
else if ( dscp >= 24 && dscp <= 31)
up = 4;
else if ( dscp >= 33 && dscp <= 40)
up = 5;
else if ((dscp >= 41 && dscp <= 47) || (dscp == 32))
up = 6;
else if ( dscp >= 48 && dscp <= 63)
up = 7;
return up;
}
#endif
static void set_qos(struct pkt_file *ppktfile, struct pkt_attrib *pattrib)
{
struct ethhdr etherhdr;
struct iphdr ip_hdr;
s32 UserPriority = 0;
_rtw_open_pktfile(ppktfile->pkt, ppktfile);
_rtw_pktfile_read(ppktfile, (unsigned char *)ðerhdr, ETH_HLEN);
/* get UserPriority from IP hdr */
if (pattrib->ether_type == 0x0800) {
_rtw_pktfile_read(ppktfile, (u8 *)&ip_hdr, sizeof(ip_hdr));
/* UserPriority = (ntohs(ip_hdr.tos) >> 5) & 0x3; */
#ifdef CONFIG_USER_PRIORITY_COMPLY_RFC4594_DSCP
UserPriority = dscp_to_up_ac(ip_hdr.tos);
#else
UserPriority = ip_hdr.tos >> 5;
#endif
}
/*
else if (pattrib->ether_type == 0x888e) {
UserPriority = 7;
}
*/
#ifdef CONFIG_ICMP_VOQ
if(pattrib->icmp_pkt==1)/*use VO queue to send icmp packet*/
UserPriority = 7;
#endif
#ifdef CONFIG_IP_R_MONITOR
if (pattrib->ether_type == ETH_P_ARP)
UserPriority = 7;
#endif/*CONFIG_IP_R_MONITOR*/
pattrib->priority = UserPriority;
pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
pattrib->subtype = WIFI_QOS_DATA_TYPE;
}
#ifdef CONFIG_TDLS
u8 rtw_check_tdls_established(_adapter *padapter, struct pkt_attrib *pattrib)
{
pattrib->ptdls_sta = NULL;
pattrib->direct_link = _FALSE;
if (padapter->tdlsinfo.link_established == _TRUE) {
pattrib->ptdls_sta = rtw_get_stainfo(&padapter->stapriv, pattrib->dst);
#if 1
if ((pattrib->ptdls_sta != NULL) &&
(pattrib->ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) &&
(pattrib->ether_type != 0x0806)) {
pattrib->direct_link = _TRUE;
/* RTW_INFO("send ptk to "MAC_FMT" using direct link\n", MAC_ARG(pattrib->dst)); */
}
#else
if (pattrib->ptdls_sta != NULL &&
pattrib->ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
pattrib->direct_link = _TRUE;
#if 0
RTW_INFO("send ptk to "MAC_FMT" using direct link\n", MAC_ARG(pattrib->dst));
#endif
}
/* ARP frame may be helped by AP*/
if (pattrib->ether_type != 0x0806)
pattrib->direct_link = _FALSE;
#endif
}
return pattrib->direct_link;
}
s32 update_tdls_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
{
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
s32 res = _SUCCESS;
psta = rtw_get_stainfo(pstapriv, pattrib->ra);
if (psta == NULL) {
res = _FAIL;
goto exit;
}
pattrib->mac_id = psta->cmn.mac_id;
pattrib->psta = psta;
pattrib->ack_policy = 0;
/* get ether_hdr_len */
pattrib->pkt_hdrlen = ETH_HLEN;
pattrib->qos_en = psta->qos_option;
/* [TDLS] TODO: setup req/rsp should be AC_BK */
if (pqospriv->qos_option && psta->qos_option) {
pattrib->priority = 4; /* tdls management frame should be AC_VI */
pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
pattrib->subtype = WIFI_QOS_DATA_TYPE;
} else {
pattrib->priority = 0;
pattrib->hdrlen = WLAN_HDR_A3_LEN;
pattrib->subtype = WIFI_DATA_TYPE;
}
/* TODO:_lock */
if (update_attrib_sec_info(padapter, pattrib, psta) == _FAIL) {
res = _FAIL;
goto exit;
}
update_attrib_phy_info(padapter, pattrib, psta);
exit:
return res;
}
#endif /* CONFIG_TDLS */
/*get non-qos hw_ssn control register,mapping to REG_HW_SEQ 0,1,2,3*/
inline u8 rtw_get_hwseq_no(_adapter *padapter)
{
u8 hwseq_num = 0;
#ifdef CONFIG_CONCURRENT_MODE
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
hwseq_num = padapter->iface_id;
if (hwseq_num > 3)
hwseq_num = 3;
#else
if (!is_primary_adapter(padapter))
hwseq_num = 1;
#endif
#endif /* CONFIG_CONCURRENT_MODE */
return hwseq_num;
}
#ifdef CONFIG_LPS
#define LPS_PT_NORMAL 0
#define LPS_PT_SP 1/* only DHCP packets is as SPECIAL_PACKET*/
#define LPS_PT_ICMP 2
/*If EAPOL , ARP , OR DHCP packet, driver must be in active mode.*/
static u8 _rtw_lps_chk_packet_type(struct pkt_attrib *pattrib)
{
u8 pkt_type = LPS_PT_NORMAL; /*normal data frame*/
#ifdef CONFIG_WAPI_SUPPORT
if ((pattrib->ether_type == 0x88B4) || (pattrib->ether_type == 0x0806) || (pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
pkt_type = LPS_PT_SP;
#else /* !CONFIG_WAPI_SUPPORT */
#ifndef CONFIG_LPS_NOT_LEAVE_FOR_ICMP
if (pattrib->icmp_pkt == 1)
pkt_type = LPS_PT_ICMP;
else
#endif
if (pattrib->dhcp_pkt == 1)
pkt_type = LPS_PT_SP;
#endif
return pkt_type;
}
#endif
static s32 update_attrib(_adapter *padapter, _pkt *pkt, struct pkt_attrib *pattrib)
{
uint i;
struct pkt_file pktfile;
struct sta_info *psta = NULL;
struct ethhdr etherhdr;
sint bmcast;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
sint res = _SUCCESS;
#ifdef CONFIG_LPS
u8 pkt_type = 0;
#endif
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib);
_rtw_open_pktfile(pkt, &pktfile);
i = _rtw_pktfile_read(&pktfile, (u8 *)ðerhdr, ETH_HLEN);
pattrib->ether_type = ntohs(etherhdr.h_proto);
if (MLME_IS_MESH(padapter)) /* address resolve is done for mesh */
goto get_sta_info;
_rtw_memcpy(pattrib->dst, ðerhdr.h_dest, ETH_ALEN);
_rtw_memcpy(pattrib->src, ðerhdr.h_source, ETH_ALEN);
if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pattrib->ta, adapter_mac_addr(padapter), ETH_ALEN);
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_adhoc);
} else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
#ifdef CONFIG_TDLS
if (rtw_check_tdls_established(padapter, pattrib) == _TRUE)
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN); /* For TDLS direct link Tx, set ra to be same to dst */
else
#endif
_rtw_memcpy(pattrib->ra, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pattrib->ta, adapter_mac_addr(padapter), ETH_ALEN);
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_sta);
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
_rtw_memcpy(pattrib->ra, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pattrib->ta, get_bssid(pmlmepriv), ETH_ALEN);
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_ap);
} else
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_unknown);
get_sta_info:
bmcast = IS_MCAST(pattrib->ra);
if (bmcast) {
psta = rtw_get_bcmc_stainfo(padapter);
if (psta == NULL) { /* if we cannot get psta => drop the pkt */
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_sta);
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
#endif
res = _FAIL;
goto exit;
}
} else {
psta = rtw_get_stainfo(pstapriv, pattrib->ra);
if (psta == NULL) { /* if we cannot get psta => drop the pkt */
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_ucast_sta);
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s get sta_info fail, ra:" MAC_FMT"\n", __func__, MAC_ARG(pattrib->ra));
#endif
res = _FAIL;
goto exit;
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE && !(psta->state & _FW_LINKED)) {
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_ucast_ap_link);
res = _FAIL;
goto exit;
}
}
if (!(psta->state & _FW_LINKED)) {
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_link);
RTW_INFO("%s-"ADPT_FMT" psta("MAC_FMT")->state(0x%x) != _FW_LINKED\n",
__func__, ADPT_ARG(padapter), MAC_ARG(psta->cmn.mac_addr), psta->state);
res = _FAIL;
goto exit;
}
pattrib->pktlen = pktfile.pkt_len;
/* TODO: 802.1Q VLAN header */
/* TODO: IPV6 */
if (ETH_P_IP == pattrib->ether_type) {
u8 ip[20];
_rtw_pktfile_read(&pktfile, ip, 20);
if (GET_IPV4_IHL(ip) * 4 > 20)
_rtw_pktfile_read(&pktfile, NULL, GET_IPV4_IHL(ip) - 20);
pattrib->icmp_pkt = 0;
pattrib->dhcp_pkt = 0;
if (GET_IPV4_PROTOCOL(ip) == 0x01) { /* ICMP */
pattrib->icmp_pkt = 1;
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_icmp);
} else if (GET_IPV4_PROTOCOL(ip) == 0x11) { /* UDP */
u8 udp[8];
_rtw_pktfile_read(&pktfile, udp, 8);
if ((GET_UDP_SRC(udp) == 68 && GET_UDP_DST(udp) == 67)
|| (GET_UDP_SRC(udp) == 67 && GET_UDP_DST(udp) == 68)
) {
/* 67 : UDP BOOTP server, 68 : UDP BOOTP client */
if (pattrib->pktlen > 282) { /* MINIMUM_DHCP_PACKET_SIZE */
pattrib->dhcp_pkt = 1;
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_dhcp);
if (0)
RTW_INFO("send DHCP packet\n");
}
}
} else if (GET_IPV4_PROTOCOL(ip) == 0x06 /* TCP */
&& rtw_st_ctl_chk_reg_s_proto(&psta->st_ctl, 0x06) == _TRUE
) {
u8 tcp[20];
_rtw_pktfile_read(&pktfile, tcp, 20);
if (rtw_st_ctl_chk_reg_rule(&psta->st_ctl, padapter, IPV4_SRC(ip), TCP_SRC(tcp), IPV4_DST(ip), TCP_DST(tcp)) == _TRUE) {
if (GET_TCP_SYN(tcp) && GET_TCP_ACK(tcp)) {
session_tracker_add_cmd(padapter, psta
, IPV4_SRC(ip), TCP_SRC(tcp)
, IPV4_SRC(ip), TCP_DST(tcp));
if (DBG_SESSION_TRACKER)
RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" SYN-ACK\n"
, FUNC_ADPT_ARG(padapter)
, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp))
, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp)));
}
if (GET_TCP_FIN(tcp)) {
session_tracker_del_cmd(padapter, psta
, IPV4_SRC(ip), TCP_SRC(tcp)
, IPV4_SRC(ip), TCP_DST(tcp));
if (DBG_SESSION_TRACKER)
RTW_INFO(FUNC_ADPT_FMT" local:"IP_FMT":"PORT_FMT", remote:"IP_FMT":"PORT_FMT" FIN\n"
, FUNC_ADPT_ARG(padapter)
, IP_ARG(IPV4_SRC(ip)), PORT_ARG(TCP_SRC(tcp))
, IP_ARG(IPV4_DST(ip)), PORT_ARG(TCP_DST(tcp)));
}
}
}
} else if (0x888e == pattrib->ether_type)
parsing_eapol_packet(padapter, pktfile.cur_addr, psta, 1);
#if defined (DBG_ARP_DUMP) || defined (DBG_IP_R_MONITOR)
else if (pattrib->ether_type == ETH_P_ARP) {
u8 arp[28] = {0};
_rtw_pktfile_read(&pktfile, arp, 28);
dump_arp_pkt(RTW_DBGDUMP, etherhdr.h_dest, etherhdr.h_source, arp, 1);
}
#endif
if ((pattrib->ether_type == 0x888e) || (pattrib->dhcp_pkt == 1))
rtw_mi_set_scan_deny(padapter, 3000);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) &&
pattrib->ether_type == ETH_P_ARP &&
!IS_MCAST(pattrib->dst)) {
rtw_mi_set_scan_deny(padapter, 1000);
rtw_mi_scan_abort(padapter, _FALSE); /*rtw_scan_abort_no_wait*/
}
#ifdef CONFIG_LPS
pkt_type = _rtw_lps_chk_packet_type(pattrib);
if (pkt_type == LPS_PT_SP) {/*packet is as SPECIAL_PACKET*/
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_active);
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_SPECIAL_PACKET, 0);
} else if (pkt_type == LPS_PT_ICMP)
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_LEAVE, 0);
#endif /* CONFIG_LPS */
#ifdef CONFIG_BEAMFORMING
update_attrib_txbf_info(padapter, pattrib, psta);
#endif
/* TODO:_lock */
if (update_attrib_sec_info(padapter, pattrib, psta) == _FAIL) {
DBG_COUNTER(padapter->tx_logs.core_tx_upd_attrib_err_sec);
res = _FAIL;
goto exit;
}
/* get ether_hdr_len */
pattrib->pkt_hdrlen = ETH_HLEN;/* (pattrib->ether_type == 0x8100) ? (14 + 4 ): 14; */ /* vlan tag */
pattrib->hdrlen = WLAN_HDR_A3_LEN;
pattrib->subtype = WIFI_DATA_TYPE;
pattrib->qos_en = psta->qos_option;
pattrib->priority = 0;
if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_MESH_STATE
| WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)
) {
if (pattrib->qos_en) {
set_qos(&pktfile, pattrib);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter))
rtw_mesh_tx_set_whdr_mctrl_len(pattrib->mesh_frame_mode, pattrib);
#endif
}
} else {
#ifdef CONFIG_TDLS
if (pattrib->direct_link == _TRUE) {
if (pattrib->qos_en)
set_qos(&pktfile, pattrib);
} else
#endif
{
if (pqospriv->qos_option) {
set_qos(&pktfile, pattrib);
if (pmlmepriv->acm_mask != 0)
pattrib->priority = qos_acm(pmlmepriv->acm_mask, pattrib->priority);
}
}
}
update_attrib_phy_info(padapter, pattrib, psta);
/* RTW_INFO("%s ==> mac_id(%d)\n",__FUNCTION__,pattrib->mac_id ); */
pattrib->psta = psta;
/* TODO:_unlock */
#ifdef CONFIG_AUTO_AP_MODE
if (psta->isrc && psta->pid > 0)
pattrib->pctrl = _TRUE;
else
#endif
pattrib->pctrl = 0;
pattrib->ack_policy = 0;
if (bmcast)
pattrib->rate = psta->init_rate;
#ifdef CONFIG_WMMPS_STA
update_attrib_trigger_frame_info(padapter, pattrib);
#endif /* CONFIG_WMMPS_STA */
/* pattrib->priority = 5; */ /* force to used VI queue, for testing */
pattrib->hw_ssn_sel = pxmitpriv->hw_ssn_seq_no;
rtw_set_tx_chksum_offload(pkt, pattrib);
exit:
return res;
}
static s32 xmitframe_addmic(_adapter *padapter, struct xmit_frame *pxmitframe)
{
sint curfragnum, length;
u8 *pframe, *payload, mic[8];
struct mic_data micdata;
/* struct sta_info *stainfo; */
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
u8 priority[4] = {0x0, 0x0, 0x0, 0x0};
u8 hw_hdr_offset = 0;
sint bmcst = IS_MCAST(pattrib->ra);
/*
if(pattrib->psta)
{
stainfo = pattrib->psta;
}
else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
stainfo=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0]);
}
if(stainfo==NULL)
{
RTW_INFO("%s, psta==NUL\n", __func__);
return _FAIL;
}
if(!(stainfo->state &_FW_LINKED))
{
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
return _FAIL;
}
*/
#ifdef CONFIG_USB_TX_AGGREGATION
hw_hdr_offset = TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);;
#else
#ifdef CONFIG_TX_EARLY_MODE
hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
#else
hw_hdr_offset = TXDESC_OFFSET;
#endif
#endif
if (pattrib->encrypt == _TKIP_) { /* if(psecuritypriv->dot11PrivacyAlgrthm==_TKIP_PRIVACY_) */
/* encode mic code */
/* if(stainfo!= NULL) */
{
u8 null_key[16] = {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
pframe = pxmitframe->buf_addr + hw_hdr_offset;
if (bmcst) {
if (_rtw_memcmp(psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey, null_key, 16) == _TRUE) {
/* DbgPrint("\nxmitframe_addmic:stainfo->dot11tkiptxmickey==0\n"); */
/* rtw_msleep_os(10); */
return _FAIL;
}
/* start to calculate the mic code */
rtw_secmicsetkey(&micdata, psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey);
} else {
if (_rtw_memcmp(&pattrib->dot11tkiptxmickey.skey[0], null_key, 16) == _TRUE) {
/* DbgPrint("\nxmitframe_addmic:stainfo->dot11tkiptxmickey==0\n"); */
/* rtw_msleep_os(10); */
return _FAIL;
}
/* start to calculate the mic code */
rtw_secmicsetkey(&micdata, &pattrib->dot11tkiptxmickey.skey[0]);
}
if (pframe[1] & 1) { /* ToDS==1 */
rtw_secmicappend(&micdata, &pframe[16], 6); /* DA */
if (pframe[1] & 2) /* From Ds==1 */
rtw_secmicappend(&micdata, &pframe[24], 6);
else
rtw_secmicappend(&micdata, &pframe[10], 6);
} else { /* ToDS==0 */
rtw_secmicappend(&micdata, &pframe[4], 6); /* DA */
if (pframe[1] & 2) /* From Ds==1 */
rtw_secmicappend(&micdata, &pframe[16], 6);
else
rtw_secmicappend(&micdata, &pframe[10], 6);
}
if (pattrib->qos_en)
priority[0] = (u8)pxmitframe->attrib.priority;
rtw_secmicappend(&micdata, &priority[0], 4);
payload = pframe;
for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
payload = (u8 *)RND4((SIZE_PTR)(payload));
payload = payload + pattrib->hdrlen + pattrib->iv_len;
if ((curfragnum + 1) == pattrib->nr_frags) {
length = pattrib->last_txcmdsz - pattrib->hdrlen - pattrib->iv_len - ((pattrib->bswenc) ? pattrib->icv_len : 0);
rtw_secmicappend(&micdata, payload, length);
payload = payload + length;
} else {
length = pxmitpriv->frag_len - pattrib->hdrlen - pattrib->iv_len - ((pattrib->bswenc) ? pattrib->icv_len : 0);
rtw_secmicappend(&micdata, payload, length);
payload = payload + length + pattrib->icv_len;
}
}
rtw_secgetmic(&micdata, &(mic[0]));
/* add mic code and add the mic code length in last_txcmdsz */
_rtw_memcpy(payload, &(mic[0]), 8);
pattrib->last_txcmdsz += 8;
payload = payload - pattrib->last_txcmdsz + 8;
}
}
return _SUCCESS;
}
/*#define DBG_TX_SW_ENCRYPTOR*/
static s32 xmitframe_swencrypt(_adapter *padapter, struct xmit_frame *pxmitframe)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
/* struct security_priv *psecuritypriv=&padapter->securitypriv; */
/* if((psecuritypriv->sw_encrypt)||(pattrib->bswenc)) */
if (pattrib->bswenc) {
#ifdef DBG_TX_SW_ENCRYPTOR
RTW_INFO(ADPT_FMT" - sec_type:%s DO SW encryption\n",
ADPT_ARG(padapter), security_type_str(pattrib->encrypt));
#endif
switch (pattrib->encrypt) {
case _WEP40_:
case _WEP104_:
rtw_wep_encrypt(padapter, (u8 *)pxmitframe);
break;
case _TKIP_:
rtw_tkip_encrypt(padapter, (u8 *)pxmitframe);
break;
case _AES_:
rtw_aes_encrypt(padapter, (u8 *)pxmitframe);
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
rtw_sms4_encrypt(padapter, (u8 *)pxmitframe);
#endif
default:
break;
}
}
return _SUCCESS;
}
s32 rtw_make_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib)
{
u16 *qc;
struct rtw_ieee80211_hdr *pwlanhdr = (struct rtw_ieee80211_hdr *)hdr;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
u8 qos_option = _FALSE;
sint res = _SUCCESS;
u16 *fctrl = &pwlanhdr->frame_ctl;
/* struct sta_info *psta; */
/* sint bmcst = IS_MCAST(pattrib->ra); */
/*
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if(pattrib->psta != psta)
{
RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
return;
}
if(psta==NULL)
{
RTW_INFO("%s, psta==NUL\n", __func__);
return _FAIL;
}
if(!(psta->state &_FW_LINKED))
{
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return _FAIL;
}
*/
_rtw_memset(hdr, 0, WLANHDR_OFFSET);
set_frame_sub_type(fctrl, pattrib->subtype);
if (pattrib->subtype & WIFI_DATA_TYPE) {
if ((check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)) {
#ifdef CONFIG_TDLS
if (pattrib->direct_link == _TRUE) {
/* TDLS data transfer, ToDS=0, FrDs=0 */
_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
if (pattrib->qos_en)
qos_option = _TRUE;
} else
#endif /* CONFIG_TDLS */
{
/* to_ds = 1, fr_ds = 0; */
/* 1.Data transfer to AP */
/* 2.Arp pkt will relayed by AP */
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->ta, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
if (pqospriv->qos_option)
qos_option = _TRUE;
}
} else if ((check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE)) {
/* to_ds = 0, fr_ds = 1; */
SetFrDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pattrib->src, ETH_ALEN);
if (pattrib->qos_en)
qos_option = _TRUE;
} else if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) == _TRUE) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) == _TRUE)) {
_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->ta, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
if (pattrib->qos_en)
qos_option = _TRUE;
#ifdef CONFIG_RTW_MESH
} else if (check_fwstate(pmlmepriv, WIFI_MESH_STATE) == _TRUE) {
rtw_mesh_tx_build_whdr(padapter, pattrib, fctrl, pwlanhdr);
if (pattrib->qos_en)
qos_option = _TRUE;
else {
RTW_WARN("[%s] !qos_en in Mesh\n", __FUNCTION__);
res = _FAIL;
goto exit;
}
#endif
} else {
res = _FAIL;
goto exit;
}
if (pattrib->mdata)
SetMData(fctrl);
if (pattrib->encrypt)
SetPrivacy(fctrl);
if (qos_option) {
qc = (unsigned short *)(hdr + pattrib->hdrlen - 2);
if (pattrib->priority)
SetPriority(qc, pattrib->priority);
SetEOSP(qc, pattrib->eosp);
SetAckpolicy(qc, pattrib->ack_policy);
if(pattrib->amsdu)
SetAMsdu(qc, pattrib->amsdu);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
/* active: don't care, light sleep: 0, deep sleep: 1*/
set_mps_lv(qc, 0); //TBD
/* TBD: temporary set (rspi, eosp) = (0, 1) which means End MPSP */
set_rspi(qc, 0);
SetEOSP(qc, 1);
set_mctrl_present(qc, 1);
}
#endif
}
/* TODO: fill HT Control Field */
/* Update Seq Num will be handled by f/w */
{
struct sta_info *psta;
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if (pattrib->psta != psta) {
RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
return _FAIL;
}
if (psta == NULL) {
RTW_INFO("%s, psta==NUL\n", __func__);
return _FAIL;
}
if (!(psta->state & _FW_LINKED)) {
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return _FAIL;
}
if (psta) {
psta->sta_xmitpriv.txseq_tid[pattrib->priority]++;
psta->sta_xmitpriv.txseq_tid[pattrib->priority] &= 0xFFF;
pattrib->seqnum = psta->sta_xmitpriv.txseq_tid[pattrib->priority];
SetSeqNum(hdr, pattrib->seqnum);
#ifdef CONFIG_80211N_HT
#if 0 /* move into update_attrib_phy_info(). */
/* check if enable ampdu */
if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
if (psta->htpriv.agg_enable_bitmap & BIT(pattrib->priority))
pattrib->ampdu_en = _TRUE;
}
#endif
/* re-check if enable ampdu by BA_starting_seqctrl */
if (pattrib->ampdu_en == _TRUE) {
u16 tx_seq;
tx_seq = psta->BA_starting_seqctrl[pattrib->priority & 0x0f];
/* check BA_starting_seqctrl */
if (SN_LESS(pattrib->seqnum, tx_seq)) {
/* RTW_INFO("tx ampdu seqnum(%d) < tx_seq(%d)\n", pattrib->seqnum, tx_seq); */
pattrib->ampdu_en = _FALSE;/* AGG BK */
} else if (SN_EQUAL(pattrib->seqnum, tx_seq)) {
psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (tx_seq + 1) & 0xfff;
pattrib->ampdu_en = _TRUE;/* AGG EN */
} else {
/* RTW_INFO("tx ampdu over run\n"); */
psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (pattrib->seqnum + 1) & 0xfff;
pattrib->ampdu_en = _TRUE;/* AGG EN */
}
}
#endif /* CONFIG_80211N_HT */
}
}
} else {
}
exit:
return res;
}
s32 rtw_txframes_pending(_adapter *padapter)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
return ((_rtw_queue_empty(&pxmitpriv->be_pending) == _FALSE) ||
(_rtw_queue_empty(&pxmitpriv->bk_pending) == _FALSE) ||
(_rtw_queue_empty(&pxmitpriv->vi_pending) == _FALSE) ||
(_rtw_queue_empty(&pxmitpriv->vo_pending) == _FALSE));
}
s32 rtw_txframes_sta_ac_pending(_adapter *padapter, struct pkt_attrib *pattrib)
{
struct sta_info *psta;
struct tx_servq *ptxservq;
int priority = pattrib->priority;
/*
if(pattrib->psta)
{
psta = pattrib->psta;
}
else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
psta=rtw_get_stainfo(&padapter->stapriv ,&pattrib->ra[0]);
}
*/
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if (pattrib->psta != psta) {
RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
return 0;
}
if (psta == NULL) {
RTW_INFO("%s, psta==NUL\n", __func__);
return 0;
}
if (!(psta->state & _FW_LINKED)) {
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return 0;
}
switch (priority) {
case 1:
case 2:
ptxservq = &(psta->sta_xmitpriv.bk_q);
break;
case 4:
case 5:
ptxservq = &(psta->sta_xmitpriv.vi_q);
break;
case 6:
case 7:
ptxservq = &(psta->sta_xmitpriv.vo_q);
break;
case 0:
case 3:
default:
ptxservq = &(psta->sta_xmitpriv.be_q);
break;
}
return ptxservq->qcnt;
}
#ifdef CONFIG_TDLS
int rtw_build_tdls_ies(_adapter *padapter, struct xmit_frame *pxmitframe, u8 *pframe, struct tdls_txmgmt *ptxmgmt)
{
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct sta_info *ptdls_sta = NULL;
int res = _SUCCESS;
ptdls_sta = rtw_get_stainfo((&padapter->stapriv), pattrib->dst);
if (ptdls_sta == NULL) {
switch (ptxmgmt->action_code) {
case TDLS_DISCOVERY_REQUEST:
case TUNNELED_PROBE_REQ:
case TUNNELED_PROBE_RSP:
break;
default:
RTW_INFO("[TDLS] %s - Direct Link Peer = "MAC_FMT" not found for action = %d\n", __func__, MAC_ARG(pattrib->dst), ptxmgmt->action_code);
res = _FAIL;
goto exit;
}
}
switch (ptxmgmt->action_code) {
case TDLS_SETUP_REQUEST:
rtw_build_tdls_setup_req_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
case TDLS_SETUP_RESPONSE:
rtw_build_tdls_setup_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
case TDLS_SETUP_CONFIRM:
rtw_build_tdls_setup_cfm_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
case TDLS_TEARDOWN:
rtw_build_tdls_teardown_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
case TDLS_DISCOVERY_REQUEST:
rtw_build_tdls_dis_req_ies(padapter, pxmitframe, pframe, ptxmgmt);
break;
case TDLS_PEER_TRAFFIC_INDICATION:
rtw_build_tdls_peer_traffic_indication_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
#ifdef CONFIG_TDLS_CH_SW
case TDLS_CHANNEL_SWITCH_REQUEST:
rtw_build_tdls_ch_switch_req_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
case TDLS_CHANNEL_SWITCH_RESPONSE:
rtw_build_tdls_ch_switch_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
#endif
case TDLS_PEER_TRAFFIC_RESPONSE:
rtw_build_tdls_peer_traffic_rsp_ies(padapter, pxmitframe, pframe, ptxmgmt, ptdls_sta);
break;
#ifdef CONFIG_WFD
case TUNNELED_PROBE_REQ:
rtw_build_tunneled_probe_req_ies(padapter, pxmitframe, pframe);
break;
case TUNNELED_PROBE_RSP:
rtw_build_tunneled_probe_rsp_ies(padapter, pxmitframe, pframe);
break;
#endif /* CONFIG_WFD */
default:
res = _FAIL;
break;
}
exit:
return res;
}
s32 rtw_make_tdls_wlanhdr(_adapter *padapter , u8 *hdr, struct pkt_attrib *pattrib, struct tdls_txmgmt *ptxmgmt)
{
u16 *qc;
struct rtw_ieee80211_hdr *pwlanhdr = (struct rtw_ieee80211_hdr *)hdr;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta = NULL, *ptdls_sta = NULL;
u8 tdls_seq = 0, baddr[ETH_ALEN] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
sint res = _SUCCESS;
u16 *fctrl = &pwlanhdr->frame_ctl;
_rtw_memset(hdr, 0, WLANHDR_OFFSET);
set_frame_sub_type(fctrl, pattrib->subtype);
switch (ptxmgmt->action_code) {
case TDLS_SETUP_REQUEST:
case TDLS_SETUP_RESPONSE:
case TDLS_SETUP_CONFIRM:
case TDLS_PEER_TRAFFIC_INDICATION:
case TDLS_PEER_PSM_REQUEST:
case TUNNELED_PROBE_REQ:
case TUNNELED_PROBE_RSP:
case TDLS_DISCOVERY_REQUEST:
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
break;
case TDLS_CHANNEL_SWITCH_REQUEST:
case TDLS_CHANNEL_SWITCH_RESPONSE:
case TDLS_PEER_PSM_RESPONSE:
case TDLS_PEER_TRAFFIC_RESPONSE:
_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
tdls_seq = 1;
break;
case TDLS_TEARDOWN:
if (ptxmgmt->status_code == _RSON_TDLS_TEAR_UN_RSN_) {
_rtw_memcpy(pwlanhdr->addr1, pattrib->dst, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_bssid(pmlmepriv), ETH_ALEN);
tdls_seq = 1;
} else {
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, get_bssid(pmlmepriv), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, pattrib->src, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, pattrib->dst, ETH_ALEN);
}
break;
}
if (pattrib->encrypt)
SetPrivacy(fctrl);
if (ptxmgmt->action_code == TDLS_PEER_TRAFFIC_RESPONSE)
SetPwrMgt(fctrl);
if (pqospriv->qos_option) {
qc = (unsigned short *)(hdr + pattrib->hdrlen - 2);
if (pattrib->priority)
SetPriority(qc, pattrib->priority);
SetAckpolicy(qc, pattrib->ack_policy);
}
psta = pattrib->psta;
/* 1. update seq_num per link by sta_info */
/* 2. rewrite encrypt to _AES_, also rewrite iv_len, icv_len */
if (tdls_seq == 1) {
ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->dst);
if (ptdls_sta) {
ptdls_sta->sta_xmitpriv.txseq_tid[pattrib->priority]++;
ptdls_sta->sta_xmitpriv.txseq_tid[pattrib->priority] &= 0xFFF;
pattrib->seqnum = ptdls_sta->sta_xmitpriv.txseq_tid[pattrib->priority];
SetSeqNum(hdr, pattrib->seqnum);
if (pattrib->encrypt) {
pattrib->encrypt = _AES_;
pattrib->iv_len = 8;
pattrib->icv_len = 8;
pattrib->bswenc = _FALSE;
}
pattrib->mac_id = ptdls_sta->cmn.mac_id;
} else {
res = _FAIL;
goto exit;
}
} else if (psta) {
psta->sta_xmitpriv.txseq_tid[pattrib->priority]++;
psta->sta_xmitpriv.txseq_tid[pattrib->priority] &= 0xFFF;
pattrib->seqnum = psta->sta_xmitpriv.txseq_tid[pattrib->priority];
SetSeqNum(hdr, pattrib->seqnum);
}
exit:
return res;
}
s32 rtw_xmit_tdls_coalesce(_adapter *padapter, struct xmit_frame *pxmitframe, struct tdls_txmgmt *ptxmgmt)
{
s32 llc_sz;
u8 *pframe, *mem_start;
struct sta_info *psta;
struct sta_priv *pstapriv = &padapter->stapriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 *pbuf_start;
s32 bmcst = IS_MCAST(pattrib->ra);
s32 res = _SUCCESS;
if (pattrib->psta)
psta = pattrib->psta;
else {
if (bmcst)
psta = rtw_get_bcmc_stainfo(padapter);
else
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
}
if (psta == NULL) {
res = _FAIL;
goto exit;
}
if (pxmitframe->buf_addr == NULL) {
res = _FAIL;
goto exit;
}
pbuf_start = pxmitframe->buf_addr;
mem_start = pbuf_start + TXDESC_OFFSET;
if (rtw_make_tdls_wlanhdr(padapter, mem_start, pattrib, ptxmgmt) == _FAIL) {
res = _FAIL;
goto exit;
}
pframe = mem_start;
pframe += pattrib->hdrlen;
/* adding icv, if necessary... */
if (pattrib->iv_len) {
if (psta != NULL) {
switch (pattrib->encrypt) {
case _WEP40_:
case _WEP104_:
WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
break;
case _TKIP_:
if (bmcst)
TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
else
TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
break;
case _AES_:
if (bmcst)
AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
else
AES_IV(pattrib->iv, psta->dot11txpn, 0);
break;
}
}
_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
pframe += pattrib->iv_len;
}
llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
pframe += llc_sz;
/* pattrib->pktlen will be counted in rtw_build_tdls_ies */
pattrib->pktlen = 0;
rtw_build_tdls_ies(padapter, pxmitframe, pframe, ptxmgmt);
if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
pframe += pattrib->pktlen;
_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
pframe += pattrib->icv_len;
}
pattrib->nr_frags = 1;
pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len + llc_sz +
((pattrib->bswenc) ? pattrib->icv_len : 0) + pattrib->pktlen;
if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
res = _FAIL;
goto exit;
}
xmitframe_swencrypt(padapter, pxmitframe);
update_attrib_vcs_info(padapter, pxmitframe);
exit:
return res;
}
#endif /* CONFIG_TDLS */
/*
* Calculate wlan 802.11 packet MAX size from pkt_attrib
* This function doesn't consider fragment case
*/
u32 rtw_calculate_wlan_pkt_size_by_attribue(struct pkt_attrib *pattrib)
{
u32 len = 0;
len = pattrib->hdrlen /* WLAN Header */
+ pattrib->iv_len /* IV */
+ XATTRIB_GET_MCTRL_LEN(pattrib)
+ SNAP_SIZE + sizeof(u16) /* LLC */
+ pattrib->pktlen
+ (pattrib->encrypt == _TKIP_ ? 8 : 0) /* MIC */
+ (pattrib->bswenc ? pattrib->icv_len : 0) /* ICV */
;
return len;
}
#ifdef CONFIG_TX_AMSDU
s32 check_amsdu(struct xmit_frame *pxmitframe)
{
struct pkt_attrib *pattrib;
s32 ret = _TRUE;
if (!pxmitframe)
ret = _FALSE;
pattrib = &pxmitframe->attrib;
if (IS_MCAST(pattrib->ra))
ret = _FALSE;
if ((pattrib->ether_type == 0x888e) ||
(pattrib->ether_type == 0x0806) ||
(pattrib->ether_type == 0x88b4) ||
(pattrib->dhcp_pkt == 1))
ret = _FALSE;
if ((pattrib->encrypt == _WEP40_) ||
(pattrib->encrypt == _WEP104_) ||
(pattrib->encrypt == _TKIP_))
ret = _FALSE;
if (!pattrib->qos_en)
ret = _FALSE;
if (IS_AMSDU_AMPDU_NOT_VALID(pattrib))
ret = _FALSE;
return ret;
}
s32 check_amsdu_tx_support(_adapter *padapter)
{
struct dvobj_priv *pdvobjpriv;
int tx_amsdu;
int tx_amsdu_rate;
int current_tx_rate;
s32 ret = _FALSE;
pdvobjpriv = adapter_to_dvobj(padapter);
tx_amsdu = padapter->tx_amsdu;
tx_amsdu_rate = padapter->tx_amsdu_rate;
current_tx_rate = pdvobjpriv->traffic_stat.cur_tx_tp;
if (tx_amsdu == 1)
ret = _TRUE;
else if (tx_amsdu == 2 && (tx_amsdu_rate == 0 || current_tx_rate > tx_amsdu_rate))
ret = _TRUE;
else
ret = _FALSE;
return ret;
}
s32 rtw_xmitframe_coalesce_amsdu(_adapter *padapter, struct xmit_frame *pxmitframe, struct xmit_frame *pxmitframe_queue)
{
struct pkt_file pktfile;
struct pkt_attrib *pattrib;
_pkt *pkt;
struct pkt_file pktfile_queue;
struct pkt_attrib *pattrib_queue;
_pkt *pkt_queue;
s32 llc_sz, mem_sz;
s32 padding = 0;
u8 *pframe, *mem_start;
u8 hw_hdr_offset;
u16* len;
u8 *pbuf_start;
s32 res = _SUCCESS;
if (pxmitframe->buf_addr == NULL) {
RTW_INFO("==> %s buf_addr==NULL\n", __FUNCTION__);
return _FAIL;
}
pbuf_start = pxmitframe->buf_addr;
#ifdef CONFIG_USB_TX_AGGREGATION
hw_hdr_offset = TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
#else
#ifdef CONFIG_TX_EARLY_MODE /* for SDIO && Tx Agg */
hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
#else
hw_hdr_offset = TXDESC_OFFSET;
#endif
#endif
mem_start = pbuf_start + hw_hdr_offset; //for DMA
pattrib = &pxmitframe->attrib;
pattrib->amsdu = 1;
if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
RTW_INFO("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n");
res = _FAIL;
goto exit;
}
llc_sz = 0;
pframe = mem_start;
//SetMFrag(mem_start);
ClearMFrag(mem_start);
pframe += pattrib->hdrlen;
/* adding icv, if necessary... */
if (pattrib->iv_len) {
_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len); // queue or new?
RTW_DBG("rtw_xmitframe_coalesce: keyid=%d pattrib->iv[3]=%.2x pframe=%.2x %.2x %.2x %.2x\n",
padapter->securitypriv.dot11PrivacyKeyIndex, pattrib->iv[3], *pframe, *(pframe + 1), *(pframe + 2), *(pframe + 3));
pframe += pattrib->iv_len;
}
pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len;
if(pxmitframe_queue)
{
pattrib_queue = &pxmitframe_queue->attrib;
pkt_queue = pxmitframe_queue->pkt;
_rtw_open_pktfile(pkt_queue, &pktfile_queue);
_rtw_pktfile_read(&pktfile_queue, NULL, pattrib_queue->pkt_hdrlen);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
/* mDA(6), mSA(6), len(2), mctrl */
_rtw_memcpy(pframe, pattrib_queue->mda, ETH_ALEN);
pframe += ETH_ALEN;
_rtw_memcpy(pframe, pattrib_queue->msa, ETH_ALEN);
pframe += ETH_ALEN;
len = (u16*)pframe;
pframe += 2;
rtw_mesh_tx_build_mctrl(padapter, pattrib_queue, pframe);
pframe += XATTRIB_GET_MCTRL_LEN(pattrib_queue);
} else
#endif
{
/* 802.3 MAC Header DA(6) SA(6) Len(2)*/
_rtw_memcpy(pframe, pattrib_queue->dst, ETH_ALEN);
pframe += ETH_ALEN;
_rtw_memcpy(pframe, pattrib_queue->src, ETH_ALEN);
pframe += ETH_ALEN;
len = (u16*)pframe;
pframe += 2;
}
llc_sz = rtw_put_snap(pframe, pattrib_queue->ether_type);
pframe += llc_sz;
mem_sz = _rtw_pktfile_read(&pktfile_queue, pframe, pattrib_queue->pktlen);
pframe += mem_sz;
*len = htons(XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz);
//calc padding
padding = 4 - ((ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz) & (4-1));
if(padding == 4)
padding = 0;
//_rtw_memset(pframe,0xaa, padding);
pframe += padding;
pattrib->last_txcmdsz += ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib_queue) + llc_sz + mem_sz + padding ;
}
//2nd mpdu
pkt = pxmitframe->pkt;
_rtw_open_pktfile(pkt, &pktfile);
_rtw_pktfile_read(&pktfile, NULL, pattrib->pkt_hdrlen);
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
/* mDA(6), mSA(6), len(2), mctrl */
_rtw_memcpy(pframe, pattrib->mda, ETH_ALEN);
pframe += ETH_ALEN;
_rtw_memcpy(pframe, pattrib->msa, ETH_ALEN);
pframe += ETH_ALEN;
len = (u16*)pframe;
pframe += 2;
rtw_mesh_tx_build_mctrl(padapter, pattrib, pframe);
pframe += XATTRIB_GET_MCTRL_LEN(pattrib);
} else
#endif
{
/* 802.3 MAC Header DA(6) SA(6) Len(2) */
_rtw_memcpy(pframe, pattrib->dst, ETH_ALEN);
pframe += ETH_ALEN;
_rtw_memcpy(pframe, pattrib->src, ETH_ALEN);
pframe += ETH_ALEN;
len = (u16*)pframe;
pframe += 2;
}
llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
pframe += llc_sz;
mem_sz = _rtw_pktfile_read(&pktfile, pframe, pattrib->pktlen);
pframe += mem_sz;
*len = htons(XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz + mem_sz);
//the last ampdu has no padding
padding = 0;
pattrib->nr_frags = 1;
pattrib->last_txcmdsz += ETH_HLEN + XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz + mem_sz + padding +
((pattrib->bswenc) ? pattrib->icv_len : 0) ;
if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
pframe += pattrib->icv_len;
}
if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
RTW_INFO("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n");
res = _FAIL;
goto exit;
}
xmitframe_swencrypt(padapter, pxmitframe);
update_attrib_vcs_info(padapter, pxmitframe);
exit:
return res;
}
#endif /* CONFIG_TX_AMSDU */
/*
This sub-routine will perform all the following:
1. remove 802.3 header.
2. create wlan_header, based on the info in pxmitframe
3. append sta's iv/ext-iv
4. append LLC
5. move frag chunk from pframe to pxmitframe->mem
6. apply sw-encrypt, if necessary.
*/
s32 rtw_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)
{
struct pkt_file pktfile;
s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
SIZE_PTR addr;
u8 *pframe, *mem_start;
u8 hw_hdr_offset;
/* struct sta_info *psta; */
/* struct sta_priv *pstapriv = &padapter->stapriv; */
/* struct mlme_priv *pmlmepriv = &padapter->mlmepriv; */
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 *pbuf_start;
s32 bmcst = IS_MCAST(pattrib->ra);
s32 res = _SUCCESS;
/*
if (pattrib->psta)
{
psta = pattrib->psta;
} else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
}
if(psta==NULL)
{
RTW_INFO("%s, psta==NUL\n", __func__);
return _FAIL;
}
if(!(psta->state &_FW_LINKED))
{
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return _FAIL;
}
*/
if (pxmitframe->buf_addr == NULL) {
RTW_INFO("==> %s buf_addr==NULL\n", __FUNCTION__);
return _FAIL;
}
pbuf_start = pxmitframe->buf_addr;
#ifdef CONFIG_USB_TX_AGGREGATION
hw_hdr_offset = TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
#else
#ifdef CONFIG_TX_EARLY_MODE /* for SDIO && Tx Agg */
hw_hdr_offset = TXDESC_OFFSET + EARLY_MODE_INFO_SIZE;
#else
hw_hdr_offset = TXDESC_OFFSET;
#endif
#endif
mem_start = pbuf_start + hw_hdr_offset;
if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
RTW_INFO("rtw_xmitframe_coalesce: rtw_make_wlanhdr fail; drop pkt\n");
res = _FAIL;
goto exit;
}
_rtw_open_pktfile(pkt, &pktfile);
_rtw_pktfile_read(&pktfile, NULL, pattrib->pkt_hdrlen);
frg_inx = 0;
frg_len = pxmitpriv->frag_len - 4;/* 2346-4 = 2342 */
while (1) {
llc_sz = 0;
mpdu_len = frg_len;
pframe = mem_start;
SetMFrag(mem_start);
pframe += pattrib->hdrlen;
mpdu_len -= pattrib->hdrlen;
/* adding icv, if necessary... */
if (pattrib->iv_len) {
#if 0
/* if (check_fwstate(pmlmepriv, WIFI_MP_STATE)) */
/* psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv)); */
/* else */
/* psta = rtw_get_stainfo(pstapriv, pattrib->ra); */
if (psta != NULL) {
switch (pattrib->encrypt) {
case _WEP40_:
case _WEP104_:
WEP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
break;
case _TKIP_:
if (bmcst)
TKIP_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
else
TKIP_IV(pattrib->iv, psta->dot11txpn, 0);
break;
case _AES_:
if (bmcst)
AES_IV(pattrib->iv, psta->dot11txpn, pattrib->key_idx);
else
AES_IV(pattrib->iv, psta->dot11txpn, 0);
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
rtw_wapi_get_iv(padapter, pattrib->ra, pattrib->iv);
break;
#endif
}
}
#endif
_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
pframe += pattrib->iv_len;
mpdu_len -= pattrib->iv_len;
}
if (frg_inx == 0) {
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
rtw_mesh_tx_build_mctrl(padapter, pattrib, pframe);
pframe += XATTRIB_GET_MCTRL_LEN(pattrib);
mpdu_len -= XATTRIB_GET_MCTRL_LEN(pattrib);
}
#endif
llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
pframe += llc_sz;
mpdu_len -= llc_sz;
}
if ((pattrib->icv_len > 0) && (pattrib->bswenc))
mpdu_len -= pattrib->icv_len;
if (bmcst) {
/* don't do fragment to broadcat/multicast packets */
mem_sz = _rtw_pktfile_read(&pktfile, pframe, pattrib->pktlen);
} else
mem_sz = _rtw_pktfile_read(&pktfile, pframe, mpdu_len);
pframe += mem_sz;
if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
pframe += pattrib->icv_len;
}
frg_inx++;
if (bmcst || (rtw_endofpktfile(&pktfile) == _TRUE)) {
pattrib->nr_frags = frg_inx;
pattrib->last_txcmdsz = pattrib->hdrlen + pattrib->iv_len +
((pattrib->nr_frags == 1) ? (XATTRIB_GET_MCTRL_LEN(pattrib) + llc_sz) : 0) +
((pattrib->bswenc) ? pattrib->icv_len : 0) + mem_sz;
ClearMFrag(mem_start);
break;
}
addr = (SIZE_PTR)(pframe);
mem_start = (unsigned char *)RND4(addr) + hw_hdr_offset;
_rtw_memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);
}
if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
RTW_INFO("xmitframe_addmic(padapter, pxmitframe)==_FAIL\n");
res = _FAIL;
goto exit;
}
xmitframe_swencrypt(padapter, pxmitframe);
if (bmcst == _FALSE)
update_attrib_vcs_info(padapter, pxmitframe);
else
pattrib->vcs_mode = NONE_VCS;
exit:
return res;
}
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
/*
* CCMP encryption for unicast robust mgmt frame and broadcast group privicy action
* BIP for broadcast robust mgmt frame
*/
s32 rtw_mgmt_xmitframe_coalesce(_adapter *padapter, _pkt *pkt, struct xmit_frame *pxmitframe)
{
#define DBG_MGMT_XMIT_COALESEC_DUMP 0
#define DBG_MGMT_XMIT_BIP_DUMP 0
#define DBG_MGMT_XMIT_ENC_DUMP 0
struct pkt_file pktfile;
s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
SIZE_PTR addr;
u8 *pframe, *mem_start = NULL, *tmp_buf = NULL;
u8 hw_hdr_offset, subtype ;
u8 category = 0xFF;
struct sta_info *psta = NULL;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
u8 *pbuf_start;
s32 bmcst = IS_MCAST(pattrib->ra);
s32 res = _FAIL;
u8 *BIP_AAD = NULL;
u8 *MGMT_body = NULL;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct rtw_ieee80211_hdr *pwlanhdr;
u8 MME[_MME_IE_LENGTH_];
_irqL irqL;
u32 ori_len;
union pn48 *pn = NULL;
u8 kid;
if (pxmitframe->buf_addr == NULL) {
RTW_WARN(FUNC_ADPT_FMT" pxmitframe->buf_addr\n"
, FUNC_ADPT_ARG(padapter));
return _FAIL;
}
mem_start = pframe = (u8 *)(pxmitframe->buf_addr) + TXDESC_OFFSET;
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
subtype = get_frame_sub_type(pframe); /* bit(7)~bit(2) */
/* check if robust mgmt frame */
if (subtype != WIFI_DEAUTH && subtype != WIFI_DISASSOC && subtype != WIFI_ACTION)
return _SUCCESS;
if (subtype == WIFI_ACTION) {
category = *(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
if (CATEGORY_IS_NON_ROBUST(category))
return _SUCCESS;
}
if (!bmcst) {
if (pattrib->psta)
psta = pattrib->psta;
else
pattrib->psta = psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if (psta == NULL) {
RTW_INFO(FUNC_ADPT_FMT" unicast sta == NULL\n", FUNC_ADPT_ARG(padapter));
return _FAIL;
}
if (!(psta->flags & WLAN_STA_MFP)) {
/* peer is not MFP capable, no need to encrypt */
return _SUCCESS;
}
if (psta->bpairwise_key_installed != _TRUE) {
RTW_INFO(FUNC_ADPT_FMT" PTK is not installed\n"
, FUNC_ADPT_ARG(padapter));
return _FAIL;
}
}
ori_len = BIP_AAD_SIZE + pattrib->pktlen;
tmp_buf = BIP_AAD = rtw_zmalloc(ori_len);
if (BIP_AAD == NULL)
return _FAIL;
_enter_critical_bh(&padapter->security_key_mutex, &irqL);
if (bmcst) {
if (subtype == WIFI_ACTION && CATEGORY_IS_GROUP_PRIVACY(category)) {
/* broadcast group privacy action frame */
#if DBG_MGMT_XMIT_COALESEC_DUMP
RTW_INFO(FUNC_ADPT_FMT" broadcast gp action(%u)\n"
, FUNC_ADPT_ARG(padapter), category);
#endif
if (pattrib->psta)
psta = pattrib->psta;
else
pattrib->psta = psta = rtw_get_bcmc_stainfo(padapter);
if (psta == NULL) {
RTW_INFO(FUNC_ADPT_FMT" broadcast sta == NULL\n"
, FUNC_ADPT_ARG(padapter));
goto xmitframe_coalesce_fail;
}
if (padapter->securitypriv.binstallGrpkey != _TRUE) {
RTW_INFO(FUNC_ADPT_FMT" GTK is not installed\n"
, FUNC_ADPT_ARG(padapter));
goto xmitframe_coalesce_fail;
}
pn = &psta->dot11txpn;
kid = padapter->securitypriv.dot118021XGrpKeyid;
} else {
#ifdef CONFIG_IEEE80211W
/* broadcast robust mgmt frame, using BIP */
int frame_body_len;
u8 mic[16];
/* IGTK key is not install ex: mesh MFP without IGTK */
if (SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) != _TRUE)
goto xmitframe_coalesce_success;
#if DBG_MGMT_XMIT_COALESEC_DUMP
if (subtype == WIFI_DEAUTH)
RTW_INFO(FUNC_ADPT_FMT" braodcast deauth\n", FUNC_ADPT_ARG(padapter));
else if (subtype == WIFI_DISASSOC)
RTW_INFO(FUNC_ADPT_FMT" braodcast disassoc\n", FUNC_ADPT_ARG(padapter));
else if (subtype == WIFI_ACTION) {
RTW_INFO(FUNC_ADPT_FMT" braodcast action(%u)\n"
, FUNC_ADPT_ARG(padapter), category);
}
#endif
_rtw_memset(MME, 0, _MME_IE_LENGTH_);
MGMT_body = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
pframe += pattrib->pktlen;
/* octent 0 and 1 is key index ,BIP keyid is 4 or 5, LSB only need octent 0 */
MME[0] = padapter->securitypriv.dot11wBIPKeyid;
/* increase PN and apply to packet */
padapter->securitypriv.dot11wBIPtxpn.val++;
RTW_PUT_LE64(&MME[2], padapter->securitypriv.dot11wBIPtxpn.val);
/* add MME IE with MIC all zero, MME string doesn't include element id and length */
pframe = rtw_set_ie(pframe, _MME_IE_ , 16 , MME, &(pattrib->pktlen));
pattrib->last_txcmdsz = pattrib->pktlen;
/* total frame length - header length */
frame_body_len = pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr);
/* conscruct AAD, copy frame control field */
_rtw_memcpy(BIP_AAD, &pwlanhdr->frame_ctl, 2);
ClearRetry(BIP_AAD);
ClearPwrMgt(BIP_AAD);
ClearMData(BIP_AAD);
/* conscruct AAD, copy address 1 to address 3 */
_rtw_memcpy(BIP_AAD + 2, pwlanhdr->addr1, 18);
/* copy management fram body */
_rtw_memcpy(BIP_AAD + BIP_AAD_SIZE, MGMT_body, frame_body_len);
#if DBG_MGMT_XMIT_BIP_DUMP
/* dump total packet include MME with zero MIC */
{
int i;
printk("Total packet: ");
for (i = 0; i < BIP_AAD_SIZE + frame_body_len; i++)
printk(" %02x ", BIP_AAD[i]);
printk("\n");
}
#endif
/* calculate mic */
if (omac1_aes_128(padapter->securitypriv.dot11wBIPKey[padapter->securitypriv.dot11wBIPKeyid].skey
, BIP_AAD, BIP_AAD_SIZE + frame_body_len, mic))
goto xmitframe_coalesce_fail;
#if DBG_MGMT_XMIT_BIP_DUMP
/* dump calculated mic result */
{
int i;
printk("Calculated mic result: ");
for (i = 0; i < 16; i++)
printk(" %02x ", mic[i]);
printk("\n");
}
#endif
/* copy right BIP mic value, total is 128bits, we use the 0~63 bits */
_rtw_memcpy(pframe - 8, mic, 8);
#if DBG_MGMT_XMIT_BIP_DUMP
/*dump all packet after mic ok */
{
int pp;
printk("pattrib->pktlen = %d\n", pattrib->pktlen);
for(pp=0;pp< pattrib->pktlen; pp++)
printk(" %02x ", mem_start[pp]);
printk("\n");
}
#endif
#endif /* CONFIG_IEEE80211W */
goto xmitframe_coalesce_success;
}
}
else {
/* unicast robust mgmt frame */
#if DBG_MGMT_XMIT_COALESEC_DUMP
if (subtype == WIFI_DEAUTH) {
RTW_INFO(FUNC_ADPT_FMT" unicast deauth to "MAC_FMT"\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(pattrib->ra));
} else if (subtype == WIFI_DISASSOC) {
RTW_INFO(FUNC_ADPT_FMT" unicast disassoc to "MAC_FMT"\n"
, FUNC_ADPT_ARG(padapter), MAC_ARG(pattrib->ra));
} else if (subtype == WIFI_ACTION) {
RTW_INFO(FUNC_ADPT_FMT" unicast action(%u) to "MAC_FMT"\n"
, FUNC_ADPT_ARG(padapter), category, MAC_ARG(pattrib->ra));
}
#endif
_rtw_memcpy(pattrib->dot118021x_UncstKey.skey, psta->dot118021x_UncstKey.skey, 16);
/* To use wrong key */
if (pattrib->key_type == IEEE80211W_WRONG_KEY) {
RTW_INFO("use wrong key\n");
pattrib->dot118021x_UncstKey.skey[0] = 0xff;
}
pn = &psta->dot11txpn;
kid = 0;
}
#if DBG_MGMT_XMIT_ENC_DUMP
/* before encrypt dump the management packet content */
{
int i;
printk("Management pkt: ");
for(i=0; ipktlen; i++)
printk(" %02x ", pframe[i]);
printk("=======\n");
}
#endif
/* bakeup original management packet */
_rtw_memcpy(tmp_buf, pframe, pattrib->pktlen);
/* move to data portion */
pframe += pattrib->hdrlen;
/* 802.11w encrypted management packet must be _AES_ */
if (pattrib->key_type != IEEE80211W_NO_KEY) {
pattrib->encrypt = _AES_;
pattrib->bswenc = _TRUE;
}
pattrib->iv_len = 8;
/* it's MIC of AES */
pattrib->icv_len = 8;
switch (pattrib->encrypt) {
case _AES_:
/* set AES IV header */
AES_IV(pattrib->iv, (*pn), kid);
break;
default:
goto xmitframe_coalesce_fail;
}
/* insert iv header into management frame */
_rtw_memcpy(pframe, pattrib->iv, pattrib->iv_len);
pframe += pattrib->iv_len;
/* copy mgmt data portion after CCMP header */
_rtw_memcpy(pframe, tmp_buf + pattrib->hdrlen, pattrib->pktlen - pattrib->hdrlen);
/* move pframe to end of mgmt pkt */
pframe += pattrib->pktlen - pattrib->hdrlen;
/* add 8 bytes CCMP IV header to length */
pattrib->pktlen += pattrib->iv_len;
#if DBG_MGMT_XMIT_ENC_DUMP
/* dump management packet include AES IV header */
{
int i;
printk("Management pkt + IV: ");
/* for(i=0; ipktlen; i++) */
printk("@@@@@@@@@@@@@\n");
}
#endif
if ((pattrib->icv_len > 0) && (pattrib->bswenc)) {
_rtw_memcpy(pframe, pattrib->icv, pattrib->icv_len);
pframe += pattrib->icv_len;
}
/* add 8 bytes MIC */
pattrib->pktlen += pattrib->icv_len;
/* set final tx command size */
pattrib->last_txcmdsz = pattrib->pktlen;
/* set protected bit must be beofre SW encrypt */
SetPrivacy(mem_start);
#if DBG_MGMT_XMIT_ENC_DUMP
/* dump management packet include AES header */
{
int i;
printk("prepare to enc Management pkt + IV: ");
for (i = 0; i < pattrib->pktlen; i++)
printk(" %02x ", mem_start[i]);
printk("@@@@@@@@@@@@@\n");
}
#endif
/* software encrypt */
xmitframe_swencrypt(padapter, pxmitframe);
xmitframe_coalesce_success:
_exit_critical_bh(&padapter->security_key_mutex, &irqL);
rtw_mfree(BIP_AAD, ori_len);
return _SUCCESS;
xmitframe_coalesce_fail:
_exit_critical_bh(&padapter->security_key_mutex, &irqL);
rtw_mfree(BIP_AAD, ori_len);
return _FAIL;
}
#endif /* defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH) */
/* Logical Link Control(LLC) SubNetwork Attachment Point(SNAP) header
* IEEE LLC/SNAP header contains 8 octets
* First 3 octets comprise the LLC portion
* SNAP portion, 5 octets, is divided into two fields:
* Organizationally Unique Identifier(OUI), 3 octets,
* type, defined by that organization, 2 octets.
*/
s32 rtw_put_snap(u8 *data, u16 h_proto)
{
struct ieee80211_snap_hdr *snap;
u8 *oui;
snap = (struct ieee80211_snap_hdr *)data;
snap->dsap = 0xaa;
snap->ssap = 0xaa;
snap->ctrl = 0x03;
if (h_proto == 0x8137 || h_proto == 0x80f3)
oui = P802_1H_OUI;
else
oui = RFC1042_OUI;
snap->oui[0] = oui[0];
snap->oui[1] = oui[1];
snap->oui[2] = oui[2];
*(u16 *)(data + SNAP_SIZE) = htons(h_proto);
return SNAP_SIZE + sizeof(u16);
}
void rtw_update_protection(_adapter *padapter, u8 *ie, uint ie_len)
{
uint protection;
u8 *perp;
sint erp_len;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct registry_priv *pregistrypriv = &padapter->registrypriv;
switch (pxmitpriv->vcs_setting) {
case DISABLE_VCS:
pxmitpriv->vcs = NONE_VCS;
break;
case ENABLE_VCS:
break;
case AUTO_VCS:
default:
perp = rtw_get_ie(ie, _ERPINFO_IE_, &erp_len, ie_len);
if (perp == NULL)
pxmitpriv->vcs = NONE_VCS;
else {
protection = (*(perp + 2)) & BIT(1);
if (protection) {
if (pregistrypriv->vcs_type == RTS_CTS)
pxmitpriv->vcs = RTS_CTS;
else
pxmitpriv->vcs = CTS_TO_SELF;
} else
pxmitpriv->vcs = NONE_VCS;
}
break;
}
}
void rtw_count_tx_stats(PADAPTER padapter, struct xmit_frame *pxmitframe, int sz)
{
struct sta_info *psta = NULL;
struct stainfo_stats *pstats = NULL;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 pkt_num = 1;
if ((pxmitframe->frame_tag & 0x0f) == DATA_FRAMETAG) {
#if defined(CONFIG_USB_TX_AGGREGATION) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pkt_num = pxmitframe->agg_num;
#endif
pmlmepriv->LinkDetectInfo.NumTxOkInPeriod += pkt_num;
pxmitpriv->tx_pkts += pkt_num;
pxmitpriv->tx_bytes += sz;
psta = pxmitframe->attrib.psta;
if (psta) {
pstats = &psta->sta_stats;
pstats->tx_pkts += pkt_num;
pstats->tx_bytes += sz;
#if defined(CONFIG_CHECK_LEAVE_LPS) && defined(CONFIG_LPS_CHK_BY_TP)
if (adapter_to_pwrctl(padapter)->lps_chk_by_tp)
traffic_check_for_leave_lps_by_tp(padapter, _TRUE, psta);
#endif /* CONFIG_LPS */
}
#ifdef CONFIG_CHECK_LEAVE_LPS
/* traffic_check_for_leave_lps(padapter, _TRUE); */
#endif /* CONFIG_CHECK_LEAVE_LPS */
}
}
static struct xmit_buf *__rtw_alloc_cmd_xmitbuf(struct xmit_priv *pxmitpriv,
enum cmdbuf_type buf_type)
{
struct xmit_buf *pxmitbuf = NULL;
pxmitbuf = &pxmitpriv->pcmd_xmitbuf[buf_type];
if (pxmitbuf != NULL) {
pxmitbuf->priv_data = NULL;
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
pxmitbuf->agg_num = 0;
pxmitbuf->pg_num = 0;
#endif
#ifdef CONFIG_PCI_HCI
pxmitbuf->len = 0;
#ifdef CONFIG_TRX_BD_ARCH
/*pxmitbuf->buf_desc = NULL;*/
#else
pxmitbuf->desc = NULL;
#endif
#endif
if (pxmitbuf->sctx) {
RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
}
} else
RTW_INFO("%s fail, no xmitbuf available !!!\n", __func__);
return pxmitbuf;
}
struct xmit_frame *__rtw_alloc_cmdxmitframe(struct xmit_priv *pxmitpriv,
enum cmdbuf_type buf_type)
{
struct xmit_frame *pcmdframe;
struct xmit_buf *pxmitbuf;
pcmdframe = rtw_alloc_xmitframe(pxmitpriv);
if (pcmdframe == NULL) {
RTW_INFO("%s, alloc xmitframe fail\n", __FUNCTION__);
return NULL;
}
pxmitbuf = __rtw_alloc_cmd_xmitbuf(pxmitpriv, buf_type);
if (pxmitbuf == NULL) {
RTW_INFO("%s, alloc xmitbuf fail\n", __FUNCTION__);
rtw_free_xmitframe(pxmitpriv, pcmdframe);
return NULL;
}
pcmdframe->frame_tag = MGNT_FRAMETAG;
pcmdframe->pxmitbuf = pxmitbuf;
pcmdframe->buf_addr = pxmitbuf->pbuf;
/* initial memory to zero */
_rtw_memset(pcmdframe->buf_addr, 0, MAX_CMDBUF_SZ);
pxmitbuf->priv_data = pcmdframe;
return pcmdframe;
}
struct xmit_buf *rtw_alloc_xmitbuf_ext(struct xmit_priv *pxmitpriv)
{
_irqL irqL;
struct xmit_buf *pxmitbuf = NULL;
_list *plist, *phead;
_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
_enter_critical(&pfree_queue->lock, &irqL);
if (_rtw_queue_empty(pfree_queue) == _TRUE)
pxmitbuf = NULL;
else {
phead = get_list_head(pfree_queue);
plist = get_next(phead);
pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
rtw_list_delete(&(pxmitbuf->list));
}
if (pxmitbuf != NULL) {
pxmitpriv->free_xmit_extbuf_cnt--;
#ifdef DBG_XMIT_BUF_EXT
RTW_INFO("DBG_XMIT_BUF_EXT ALLOC no=%d, free_xmit_extbuf_cnt=%d\n", pxmitbuf->no, pxmitpriv->free_xmit_extbuf_cnt);
#endif
pxmitbuf->priv_data = NULL;
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
pxmitbuf->agg_num = 1;
#endif
#ifdef CONFIG_PCI_HCI
pxmitbuf->len = 0;
#ifdef CONFIG_TRX_BD_ARCH
/*pxmitbuf->buf_desc = NULL;*/
#else
pxmitbuf->desc = NULL;
#endif
#endif
if (pxmitbuf->sctx) {
RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
}
}
_exit_critical(&pfree_queue->lock, &irqL);
return pxmitbuf;
}
s32 rtw_free_xmitbuf_ext(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
{
_irqL irqL;
_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
if (pxmitbuf == NULL)
return _FAIL;
_enter_critical(&pfree_queue->lock, &irqL);
rtw_list_delete(&pxmitbuf->list);
rtw_list_insert_tail(&(pxmitbuf->list), get_list_head(pfree_queue));
pxmitpriv->free_xmit_extbuf_cnt++;
#ifdef DBG_XMIT_BUF_EXT
RTW_INFO("DBG_XMIT_BUF_EXT FREE no=%d, free_xmit_extbuf_cnt=%d\n", pxmitbuf->no , pxmitpriv->free_xmit_extbuf_cnt);
#endif
_exit_critical(&pfree_queue->lock, &irqL);
return _SUCCESS;
}
struct xmit_buf *rtw_alloc_xmitbuf(struct xmit_priv *pxmitpriv)
{
_irqL irqL;
struct xmit_buf *pxmitbuf = NULL;
_list *plist, *phead;
_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
/* RTW_INFO("+rtw_alloc_xmitbuf\n"); */
_enter_critical(&pfree_xmitbuf_queue->lock, &irqL);
if (_rtw_queue_empty(pfree_xmitbuf_queue) == _TRUE)
pxmitbuf = NULL;
else {
phead = get_list_head(pfree_xmitbuf_queue);
plist = get_next(phead);
pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
rtw_list_delete(&(pxmitbuf->list));
}
if (pxmitbuf != NULL) {
pxmitpriv->free_xmitbuf_cnt--;
#ifdef DBG_XMIT_BUF
RTW_INFO("DBG_XMIT_BUF ALLOC no=%d, free_xmitbuf_cnt=%d\n", pxmitbuf->no, pxmitpriv->free_xmitbuf_cnt);
#endif
/* RTW_INFO("alloc, free_xmitbuf_cnt=%d\n", pxmitpriv->free_xmitbuf_cnt); */
pxmitbuf->priv_data = NULL;
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxmitbuf->len = 0;
pxmitbuf->pdata = pxmitbuf->ptail = pxmitbuf->phead;
pxmitbuf->agg_num = 0;
pxmitbuf->pg_num = 0;
#endif
#ifdef CONFIG_PCI_HCI
pxmitbuf->len = 0;
#ifdef CONFIG_TRX_BD_ARCH
/*pxmitbuf->buf_desc = NULL;*/
#else
pxmitbuf->desc = NULL;
#endif
#endif
if (pxmitbuf->sctx) {
RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
}
}
#ifdef DBG_XMIT_BUF
else
RTW_INFO("DBG_XMIT_BUF rtw_alloc_xmitbuf return NULL\n");
#endif
_exit_critical(&pfree_xmitbuf_queue->lock, &irqL);
return pxmitbuf;
}
s32 rtw_free_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
{
_irqL irqL;
_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
/* RTW_INFO("+rtw_free_xmitbuf\n"); */
if (pxmitbuf == NULL)
return _FAIL;
if (pxmitbuf->sctx) {
RTW_INFO("%s pxmitbuf->sctx is not NULL\n", __func__);
rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_FREE);
}
if (pxmitbuf->buf_tag == XMITBUF_CMD) {
} else if (pxmitbuf->buf_tag == XMITBUF_MGNT)
rtw_free_xmitbuf_ext(pxmitpriv, pxmitbuf);
else {
_enter_critical(&pfree_xmitbuf_queue->lock, &irqL);
rtw_list_delete(&pxmitbuf->list);
rtw_list_insert_tail(&(pxmitbuf->list), get_list_head(pfree_xmitbuf_queue));
pxmitpriv->free_xmitbuf_cnt++;
/* RTW_INFO("FREE, free_xmitbuf_cnt=%d\n", pxmitpriv->free_xmitbuf_cnt); */
#ifdef DBG_XMIT_BUF
RTW_INFO("DBG_XMIT_BUF FREE no=%d, free_xmitbuf_cnt=%d\n", pxmitbuf->no , pxmitpriv->free_xmitbuf_cnt);
#endif
_exit_critical(&pfree_xmitbuf_queue->lock, &irqL);
}
return _SUCCESS;
}
void rtw_init_xmitframe(struct xmit_frame *pxframe)
{
if (pxframe != NULL) { /* default value setting */
pxframe->buf_addr = NULL;
pxframe->pxmitbuf = NULL;
_rtw_memset(&pxframe->attrib, 0, sizeof(struct pkt_attrib));
/* pxframe->attrib.psta = NULL; */
pxframe->frame_tag = DATA_FRAMETAG;
#ifdef CONFIG_USB_HCI
pxframe->pkt = NULL;
#ifdef USB_PACKET_OFFSET_SZ
pxframe->pkt_offset = (PACKET_OFFSET_SZ / 8);
#else
pxframe->pkt_offset = 1;/* default use pkt_offset to fill tx desc */
#endif
#ifdef CONFIG_USB_TX_AGGREGATION
pxframe->agg_num = 1;
#endif
#endif /* #ifdef CONFIG_USB_HCI */
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pxframe->pg_num = 1;
pxframe->agg_num = 1;
#endif
#ifdef CONFIG_XMIT_ACK
pxframe->ack_report = 0;
#endif
}
}
/*
Calling context:
1. OS_TXENTRY
2. RXENTRY (rx_thread or RX_ISR/RX_CallBack)
If we turn on USE_RXTHREAD, then, no need for critical section.
Otherwise, we must use _enter/_exit critical to protect free_xmit_queue...
Must be very very cautious...
*/
struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)/* (_queue *pfree_xmit_queue) */
{
/*
Please remember to use all the osdep_service api,
and lock/unlock or _enter/_exit critical to protect
pfree_xmit_queue
*/
_irqL irqL;
struct xmit_frame *pxframe = NULL;
_list *plist, *phead;
_queue *pfree_xmit_queue = &pxmitpriv->free_xmit_queue;
_enter_critical_bh(&pfree_xmit_queue->lock, &irqL);
if (_rtw_queue_empty(pfree_xmit_queue) == _TRUE) {
pxframe = NULL;
} else {
phead = get_list_head(pfree_xmit_queue);
plist = get_next(phead);
pxframe = LIST_CONTAINOR(plist, struct xmit_frame, list);
rtw_list_delete(&(pxframe->list));
pxmitpriv->free_xmitframe_cnt--;
}
_exit_critical_bh(&pfree_xmit_queue->lock, &irqL);
rtw_init_xmitframe(pxframe);
return pxframe;
}
struct xmit_frame *rtw_alloc_xmitframe_ext(struct xmit_priv *pxmitpriv)
{
_irqL irqL;
struct xmit_frame *pxframe = NULL;
_list *plist, *phead;
_queue *queue = &pxmitpriv->free_xframe_ext_queue;
_enter_critical_bh(&queue->lock, &irqL);
if (_rtw_queue_empty(queue) == _TRUE) {
pxframe = NULL;
} else {
phead = get_list_head(queue);
plist = get_next(phead);
pxframe = LIST_CONTAINOR(plist, struct xmit_frame, list);
rtw_list_delete(&(pxframe->list));
pxmitpriv->free_xframe_ext_cnt--;
}
_exit_critical_bh(&queue->lock, &irqL);
rtw_init_xmitframe(pxframe);
return pxframe;
}
struct xmit_frame *rtw_alloc_xmitframe_once(struct xmit_priv *pxmitpriv)
{
struct xmit_frame *pxframe = NULL;
u8 *alloc_addr;
alloc_addr = rtw_zmalloc(sizeof(struct xmit_frame) + 4);
if (alloc_addr == NULL)
goto exit;
pxframe = (struct xmit_frame *)N_BYTE_ALIGMENT((SIZE_PTR)(alloc_addr), 4);
pxframe->alloc_addr = alloc_addr;
pxframe->padapter = pxmitpriv->adapter;
pxframe->frame_tag = NULL_FRAMETAG;
pxframe->pkt = NULL;
pxframe->buf_addr = NULL;
pxframe->pxmitbuf = NULL;
rtw_init_xmitframe(pxframe);
RTW_INFO("################## %s ##################\n", __func__);
exit:
return pxframe;
}
s32 rtw_free_xmitframe(struct xmit_priv *pxmitpriv, struct xmit_frame *pxmitframe)
{
_irqL irqL;
_queue *queue = NULL;
_adapter *padapter = pxmitpriv->adapter;
_pkt *pndis_pkt = NULL;
if (pxmitframe == NULL) {
goto exit;
}
if (pxmitframe->pkt) {
pndis_pkt = pxmitframe->pkt;
pxmitframe->pkt = NULL;
}
if (pxmitframe->alloc_addr) {
RTW_INFO("################## %s with alloc_addr ##################\n", __func__);
rtw_mfree(pxmitframe->alloc_addr, sizeof(struct xmit_frame) + 4);
goto check_pkt_complete;
}
if (pxmitframe->ext_tag == 0)
queue = &pxmitpriv->free_xmit_queue;
else if (pxmitframe->ext_tag == 1)
queue = &pxmitpriv->free_xframe_ext_queue;
else
rtw_warn_on(1);
_enter_critical_bh(&queue->lock, &irqL);
rtw_list_delete(&pxmitframe->list);
rtw_list_insert_tail(&pxmitframe->list, get_list_head(queue));
if (pxmitframe->ext_tag == 0) {
pxmitpriv->free_xmitframe_cnt++;
} else if (pxmitframe->ext_tag == 1) {
pxmitpriv->free_xframe_ext_cnt++;
} else {
}
_exit_critical_bh(&queue->lock, &irqL);
check_pkt_complete:
if (pndis_pkt)
rtw_os_pkt_complete(padapter, pndis_pkt);
exit:
return _SUCCESS;
}
void rtw_free_xmitframe_queue(struct xmit_priv *pxmitpriv, _queue *pframequeue)
{
_irqL irqL;
_list *plist, *phead;
struct xmit_frame *pxmitframe;
_enter_critical_bh(&(pframequeue->lock), &irqL);
phead = get_list_head(pframequeue);
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
pxmitframe = LIST_CONTAINOR(plist, struct xmit_frame, list);
plist = get_next(plist);
rtw_free_xmitframe(pxmitpriv, pxmitframe);
}
_exit_critical_bh(&(pframequeue->lock), &irqL);
}
s32 rtw_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)
{
DBG_COUNTER(padapter->tx_logs.core_tx_enqueue);
if (rtw_xmit_classifier(padapter, pxmitframe) == _FAIL) {
/* pxmitframe->pkt = NULL; */
return _FAIL;
}
return _SUCCESS;
}
static struct xmit_frame *dequeue_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit, struct tx_servq *ptxservq, _queue *pframe_queue)
{
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
xmitframe_phead = get_list_head(pframe_queue);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
/* xmitframe_plist = get_next(xmitframe_plist); */
/*#ifdef RTK_DMP_PLATFORM
#ifdef CONFIG_USB_TX_AGGREGATION
if((ptxservq->qcnt>0) && (ptxservq->qcnt<=2))
{
pxmitframe = NULL;
tasklet_schedule(&pxmitpriv->xmit_tasklet);
break;
}
#endif
#endif*/
rtw_list_delete(&pxmitframe->list);
ptxservq->qcnt--;
/* rtw_list_insert_tail(&pxmitframe->list, &phwxmit->pending); */
/* ptxservq->qcnt--; */
break;
/* pxmitframe = NULL; */
}
return pxmitframe;
}
static struct xmit_frame *get_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit, struct tx_servq *ptxservq, _queue *pframe_queue)
{
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
xmitframe_phead = get_list_head(pframe_queue);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
break;
}
return pxmitframe;
}
struct xmit_frame *rtw_get_xframe(struct xmit_priv *pxmitpriv, int *num_frame)
{
_irqL irqL0;
_list *sta_plist, *sta_phead;
struct hw_xmit *phwxmit_i = pxmitpriv->hwxmits;
sint entry = pxmitpriv->hwxmit_entry;
struct hw_xmit *phwxmit;
struct tx_servq *ptxservq = NULL;
_queue *pframe_queue = NULL;
struct xmit_frame *pxmitframe = NULL;
_adapter *padapter = pxmitpriv->adapter;
struct registry_priv *pregpriv = &padapter->registrypriv;
int i, inx[4];
inx[0] = 0;
inx[1] = 1;
inx[2] = 2;
inx[3] = 3;
*num_frame = 0;
/*No amsdu when wifi_spec on*/
if (pregpriv->wifi_spec == 1) {
return NULL;
}
_enter_critical_bh(&pxmitpriv->lock, &irqL0);
for (i = 0; i < entry; i++) {
phwxmit = phwxmit_i + inx[i];
sta_phead = get_list_head(phwxmit->sta_queue);
sta_plist = get_next(sta_phead);
while ((rtw_end_of_queue_search(sta_phead, sta_plist)) == _FALSE) {
ptxservq = LIST_CONTAINOR(sta_plist, struct tx_servq, tx_pending);
pframe_queue = &ptxservq->sta_pending;
if(ptxservq->qcnt)
{
*num_frame = ptxservq->qcnt;
pxmitframe = get_one_xmitframe(pxmitpriv, phwxmit, ptxservq, pframe_queue);
goto exit;
}
sta_plist = get_next(sta_plist);
}
}
exit:
_exit_critical_bh(&pxmitpriv->lock, &irqL0);
return pxmitframe;
}
struct xmit_frame *rtw_dequeue_xframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i, sint entry)
{
_irqL irqL0;
_list *sta_plist, *sta_phead;
struct hw_xmit *phwxmit;
struct tx_servq *ptxservq = NULL;
_queue *pframe_queue = NULL;
struct xmit_frame *pxmitframe = NULL;
_adapter *padapter = pxmitpriv->adapter;
struct registry_priv *pregpriv = &padapter->registrypriv;
int i, inx[4];
inx[0] = 0;
inx[1] = 1;
inx[2] = 2;
inx[3] = 3;
if (pregpriv->wifi_spec == 1) {
int j;
#if 0
if (flags < XMIT_QUEUE_ENTRY) {
/* priority exchange according to the completed xmitbuf flags. */
inx[flags] = 0;
inx[0] = flags;
}
#endif
#if defined(CONFIG_USB_HCI) || defined(CONFIG_SDIO_HCI) || defined(CONFIG_PCI_HCI)
for (j = 0; j < 4; j++)
inx[j] = pxmitpriv->wmm_para_seq[j];
#endif
}
_enter_critical_bh(&pxmitpriv->lock, &irqL0);
for (i = 0; i < entry; i++) {
phwxmit = phwxmit_i + inx[i];
/* _enter_critical_ex(&phwxmit->sta_queue->lock, &irqL0); */
sta_phead = get_list_head(phwxmit->sta_queue);
sta_plist = get_next(sta_phead);
while ((rtw_end_of_queue_search(sta_phead, sta_plist)) == _FALSE) {
ptxservq = LIST_CONTAINOR(sta_plist, struct tx_servq, tx_pending);
pframe_queue = &ptxservq->sta_pending;
pxmitframe = dequeue_one_xmitframe(pxmitpriv, phwxmit, ptxservq, pframe_queue);
if (pxmitframe) {
phwxmit->accnt--;
/* Remove sta node when there is no pending packets. */
if (_rtw_queue_empty(pframe_queue)) /* must be done after get_next and before break */
rtw_list_delete(&ptxservq->tx_pending);
/* _exit_critical_ex(&phwxmit->sta_queue->lock, &irqL0); */
goto exit;
}
sta_plist = get_next(sta_plist);
}
/* _exit_critical_ex(&phwxmit->sta_queue->lock, &irqL0); */
}
exit:
_exit_critical_bh(&pxmitpriv->lock, &irqL0);
return pxmitframe;
}
#if 1
struct tx_servq *rtw_get_sta_pending(_adapter *padapter, struct sta_info *psta, sint up, u8 *ac)
{
struct tx_servq *ptxservq = NULL;
switch (up) {
case 1:
case 2:
ptxservq = &(psta->sta_xmitpriv.bk_q);
*(ac) = 3;
break;
case 4:
case 5:
ptxservq = &(psta->sta_xmitpriv.vi_q);
*(ac) = 1;
break;
case 6:
case 7:
ptxservq = &(psta->sta_xmitpriv.vo_q);
*(ac) = 0;
break;
case 0:
case 3:
default:
ptxservq = &(psta->sta_xmitpriv.be_q);
*(ac) = 2;
break;
}
return ptxservq;
}
#else
__inline static struct tx_servq *rtw_get_sta_pending
(_adapter *padapter, _queue **ppstapending, struct sta_info *psta, sint up)
{
struct tx_servq *ptxservq;
struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
#ifdef CONFIG_RTL8711
if (IS_MCAST(psta->cmn.mac_addr)) {
ptxservq = &(psta->sta_xmitpriv.be_q); /* we will use be_q to queue bc/mc frames in BCMC_stainfo */
*ppstapending = &padapter->xmitpriv.bm_pending;
} else
#endif
{
switch (up) {
case 1:
case 2:
ptxservq = &(psta->sta_xmitpriv.bk_q);
*ppstapending = &padapter->xmitpriv.bk_pending;
(phwxmits + 3)->accnt++;
break;
case 4:
case 5:
ptxservq = &(psta->sta_xmitpriv.vi_q);
*ppstapending = &padapter->xmitpriv.vi_pending;
(phwxmits + 1)->accnt++;
break;
case 6:
case 7:
ptxservq = &(psta->sta_xmitpriv.vo_q);
*ppstapending = &padapter->xmitpriv.vo_pending;
(phwxmits + 0)->accnt++;
break;
case 0:
case 3:
default:
ptxservq = &(psta->sta_xmitpriv.be_q);
*ppstapending = &padapter->xmitpriv.be_pending;
(phwxmits + 2)->accnt++;
break;
}
}
return ptxservq;
}
#endif
/*
* Will enqueue pxmitframe to the proper queue,
* and indicate it to xx_pending list.....
*/
s32 rtw_xmit_classifier(_adapter *padapter, struct xmit_frame *pxmitframe)
{
/* _irqL irqL0; */
u8 ac_index;
struct sta_info *psta;
struct tx_servq *ptxservq;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
sint res = _SUCCESS;
DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class);
/*
if (pattrib->psta) {
psta = pattrib->psta;
} else {
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
psta = rtw_get_stainfo(pstapriv, pattrib->ra);
}
*/
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if (pattrib->psta != psta) {
DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class_err_sta);
RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
return _FAIL;
}
if (psta == NULL) {
DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class_err_nosta);
res = _FAIL;
RTW_INFO("rtw_xmit_classifier: psta == NULL\n");
goto exit;
}
if (!(psta->state & _FW_LINKED)) {
DBG_COUNTER(padapter->tx_logs.core_tx_enqueue_class_err_fwlink);
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return _FAIL;
}
ptxservq = rtw_get_sta_pending(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
/* _enter_critical(&pstapending->lock, &irqL0); */
if (rtw_is_list_empty(&ptxservq->tx_pending))
rtw_list_insert_tail(&ptxservq->tx_pending, get_list_head(phwxmits[ac_index].sta_queue));
/* _enter_critical(&ptxservq->sta_pending.lock, &irqL1); */
rtw_list_insert_tail(&pxmitframe->list, get_list_head(&ptxservq->sta_pending));
ptxservq->qcnt++;
phwxmits[ac_index].accnt++;
/* _exit_critical(&ptxservq->sta_pending.lock, &irqL1); */
/* _exit_critical(&pstapending->lock, &irqL0); */
exit:
return res;
}
void rtw_alloc_hwxmits(_adapter *padapter)
{
struct hw_xmit *hwxmits;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
pxmitpriv->hwxmit_entry = HWXMIT_ENTRY;
pxmitpriv->hwxmits = NULL;
pxmitpriv->hwxmits = (struct hw_xmit *)rtw_zmalloc(sizeof(struct hw_xmit) * pxmitpriv->hwxmit_entry);
if (pxmitpriv->hwxmits == NULL) {
RTW_INFO("alloc hwxmits fail!...\n");
return;
}
hwxmits = pxmitpriv->hwxmits;
if (pxmitpriv->hwxmit_entry == 5) {
/* pxmitpriv->bmc_txqueue.head = 0; */
/* hwxmits[0] .phwtxqueue = &pxmitpriv->bmc_txqueue; */
hwxmits[0] .sta_queue = &pxmitpriv->bm_pending;
/* pxmitpriv->vo_txqueue.head = 0; */
/* hwxmits[1] .phwtxqueue = &pxmitpriv->vo_txqueue; */
hwxmits[1] .sta_queue = &pxmitpriv->vo_pending;
/* pxmitpriv->vi_txqueue.head = 0; */
/* hwxmits[2] .phwtxqueue = &pxmitpriv->vi_txqueue; */
hwxmits[2] .sta_queue = &pxmitpriv->vi_pending;
/* pxmitpriv->bk_txqueue.head = 0; */
/* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
/* pxmitpriv->be_txqueue.head = 0; */
/* hwxmits[4] .phwtxqueue = &pxmitpriv->be_txqueue; */
hwxmits[4] .sta_queue = &pxmitpriv->be_pending;
} else if (pxmitpriv->hwxmit_entry == 4) {
/* pxmitpriv->vo_txqueue.head = 0; */
/* hwxmits[0] .phwtxqueue = &pxmitpriv->vo_txqueue; */
hwxmits[0] .sta_queue = &pxmitpriv->vo_pending;
/* pxmitpriv->vi_txqueue.head = 0; */
/* hwxmits[1] .phwtxqueue = &pxmitpriv->vi_txqueue; */
hwxmits[1] .sta_queue = &pxmitpriv->vi_pending;
/* pxmitpriv->be_txqueue.head = 0; */
/* hwxmits[2] .phwtxqueue = &pxmitpriv->be_txqueue; */
hwxmits[2] .sta_queue = &pxmitpriv->be_pending;
/* pxmitpriv->bk_txqueue.head = 0; */
/* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
} else {
}
}
void rtw_free_hwxmits(_adapter *padapter)
{
struct hw_xmit *hwxmits;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
hwxmits = pxmitpriv->hwxmits;
if (hwxmits)
rtw_mfree((u8 *)hwxmits, (sizeof(struct hw_xmit) * pxmitpriv->hwxmit_entry));
}
void rtw_init_hwxmits(struct hw_xmit *phwxmit, sint entry)
{
sint i;
for (i = 0; i < entry; i++, phwxmit++) {
/* _rtw_spinlock_init(&phwxmit->xmit_lock); */
/* _rtw_init_listhead(&phwxmit->pending); */
/* phwxmit->txcmdcnt = 0; */
phwxmit->accnt = 0;
}
}
#ifdef CONFIG_BR_EXT
int rtw_br_client_tx(_adapter *padapter, struct sk_buff **pskb)
{
struct sk_buff *skb = *pskb;
_irqL irqL;
/* if(check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE) == _TRUE) */
{
void dhcp_flag_bcast(_adapter *priv, struct sk_buff *skb);
int res, is_vlan_tag = 0, i, do_nat25 = 1;
unsigned short vlan_hdr = 0;
void *br_port = NULL;
/* mac_clone_handle_frame(priv, skb); */
#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
br_port = padapter->pnetdev->br_port;
#else /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
rcu_read_lock();
br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
rcu_read_unlock();
#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35)) */
_enter_critical_bh(&padapter->br_ext_lock, &irqL);
if (!(skb->data[0] & 1) &&
br_port &&
memcmp(skb->data + MACADDRLEN, padapter->br_mac, MACADDRLEN) &&
*((unsigned short *)(skb->data + MACADDRLEN * 2)) != __constant_htons(ETH_P_8021Q) &&
*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_IP) &&
!memcmp(padapter->scdb_mac, skb->data + MACADDRLEN, MACADDRLEN) && padapter->scdb_entry) {
memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
padapter->scdb_entry->ageing_timer = jiffies;
_exit_critical_bh(&padapter->br_ext_lock, &irqL);
} else
/* if (!priv->pmib->ethBrExtInfo.nat25_disable) */
{
/* if (priv->dev->br_port &&
* !memcmp(skb->data+MACADDRLEN, priv->br_mac, MACADDRLEN)) { */
#if 1
if (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_8021Q)) {
is_vlan_tag = 1;
vlan_hdr = *((unsigned short *)(skb->data + MACADDRLEN * 2 + 2));
for (i = 0; i < 6; i++)
*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2 - i * 2)) = *((unsigned short *)(skb->data + MACADDRLEN * 2 - 2 - i * 2));
skb_pull(skb, 4);
}
/* if SA == br_mac && skb== IP => copy SIP to br_ip ?? why */
if (!memcmp(skb->data + MACADDRLEN, padapter->br_mac, MACADDRLEN) &&
(*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_IP)))
memcpy(padapter->br_ip, skb->data + WLAN_ETHHDR_LEN + 12, 4);
if (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_IP)) {
if (memcmp(padapter->scdb_mac, skb->data + MACADDRLEN, MACADDRLEN)) {
void *scdb_findEntry(_adapter *priv, unsigned char *macAddr, unsigned char *ipAddr);
padapter->scdb_entry = (struct nat25_network_db_entry *)scdb_findEntry(padapter,
skb->data + MACADDRLEN, skb->data + WLAN_ETHHDR_LEN + 12);
if (padapter->scdb_entry != NULL) {
memcpy(padapter->scdb_mac, skb->data + MACADDRLEN, MACADDRLEN);
memcpy(padapter->scdb_ip, skb->data + WLAN_ETHHDR_LEN + 12, 4);
padapter->scdb_entry->ageing_timer = jiffies;
do_nat25 = 0;
}
} else {
if (padapter->scdb_entry) {
padapter->scdb_entry->ageing_timer = jiffies;
do_nat25 = 0;
} else {
memset(padapter->scdb_mac, 0, MACADDRLEN);
memset(padapter->scdb_ip, 0, 4);
}
}
}
_exit_critical_bh(&padapter->br_ext_lock, &irqL);
#endif /* 1 */
if (do_nat25) {
int nat25_db_handle(_adapter *priv, struct sk_buff *skb, int method);
if (nat25_db_handle(padapter, skb, NAT25_CHECK) == 0) {
struct sk_buff *newskb;
if (is_vlan_tag) {
skb_push(skb, 4);
for (i = 0; i < 6; i++)
*((unsigned short *)(skb->data + i * 2)) = *((unsigned short *)(skb->data + 4 + i * 2));
*((unsigned short *)(skb->data + MACADDRLEN * 2)) = __constant_htons(ETH_P_8021Q);
*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2)) = vlan_hdr;
}
newskb = rtw_skb_copy(skb);
if (newskb == NULL) {
/* priv->ext_stats.tx_drops++; */
DEBUG_ERR("TX DROP: rtw_skb_copy fail!\n");
/* goto stop_proc; */
return -1;
}
rtw_skb_free(skb);
*pskb = skb = newskb;
if (is_vlan_tag) {
vlan_hdr = *((unsigned short *)(skb->data + MACADDRLEN * 2 + 2));
for (i = 0; i < 6; i++)
*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2 - i * 2)) = *((unsigned short *)(skb->data + MACADDRLEN * 2 - 2 - i * 2));
skb_pull(skb, 4);
}
}
if (skb_is_nonlinear(skb))
DEBUG_ERR("%s(): skb_is_nonlinear!!\n", __FUNCTION__);
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18))
res = skb_linearize(skb, GFP_ATOMIC);
#else /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18)) */
res = skb_linearize(skb);
#endif /* (LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 18)) */
if (res < 0) {
DEBUG_ERR("TX DROP: skb_linearize fail!\n");
/* goto free_and_stop; */
return -1;
}
res = nat25_db_handle(padapter, skb, NAT25_INSERT);
if (res < 0) {
if (res == -2) {
/* priv->ext_stats.tx_drops++; */
DEBUG_ERR("TX DROP: nat25_db_handle fail!\n");
/* goto free_and_stop; */
return -1;
}
/* we just print warning message and let it go */
/* DEBUG_WARN("%s()-%d: nat25_db_handle INSERT Warning!\n", __FUNCTION__, __LINE__); */
/* return -1; */ /* return -1 will cause system crash on 2011/08/30! */
return 0;
}
}
memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
dhcp_flag_bcast(padapter, skb);
if (is_vlan_tag) {
skb_push(skb, 4);
for (i = 0; i < 6; i++)
*((unsigned short *)(skb->data + i * 2)) = *((unsigned short *)(skb->data + 4 + i * 2));
*((unsigned short *)(skb->data + MACADDRLEN * 2)) = __constant_htons(ETH_P_8021Q);
*((unsigned short *)(skb->data + MACADDRLEN * 2 + 2)) = vlan_hdr;
}
}
#if 0
else {
if (*((unsigned short *)(skb->data + MACADDRLEN * 2)) == __constant_htons(ETH_P_8021Q))
is_vlan_tag = 1;
if (is_vlan_tag) {
if (ICMPV6_MCAST_MAC(skb->data) && ICMPV6_PROTO1A_VALN(skb->data))
memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
} else {
if (ICMPV6_MCAST_MAC(skb->data) && ICMPV6_PROTO1A(skb->data))
memcpy(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN);
}
}
#endif /* 0 */
/* check if SA is equal to our MAC */
if (memcmp(skb->data + MACADDRLEN, GET_MY_HWADDR(padapter), MACADDRLEN)) {
/* priv->ext_stats.tx_drops++; */
DEBUG_ERR("TX DROP: untransformed frame SA:%02X%02X%02X%02X%02X%02X!\n",
skb->data[6], skb->data[7], skb->data[8], skb->data[9], skb->data[10], skb->data[11]);
/* goto free_and_stop; */
return -1;
}
}
return 0;
}
#endif /* CONFIG_BR_EXT */
u32 rtw_get_ff_hwaddr(struct xmit_frame *pxmitframe)
{
u32 addr;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
switch (pattrib->qsel) {
case 0:
case 3:
addr = BE_QUEUE_INX;
break;
case 1:
case 2:
addr = BK_QUEUE_INX;
break;
case 4:
case 5:
addr = VI_QUEUE_INX;
break;
case 6:
case 7:
addr = VO_QUEUE_INX;
break;
case 0x10:
addr = BCN_QUEUE_INX;
break;
case 0x11: /* BC/MC in PS (HIQ) */
addr = HIGH_QUEUE_INX;
break;
case 0x13:
addr = TXCMD_QUEUE_INX;
break;
case 0x12:
default:
addr = MGT_QUEUE_INX;
break;
}
return addr;
}
static void do_queue_select(_adapter *padapter, struct pkt_attrib *pattrib)
{
u8 qsel;
qsel = pattrib->priority;
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter)) {
/* Under MCC */
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
if (padapter->mcc_adapterpriv.role == MCC_ROLE_GO
|| padapter->mcc_adapterpriv.role == MCC_ROLE_AP) {
pattrib->qsel = QSLT_VO; /* AP interface VO queue */
pattrib->priority = QSLT_VO;
} else {
pattrib->qsel = QSLT_BE; /* STA interface BE queue */
pattrib->priority = QSLT_BE;
}
} else
/* Not Under MCC */
pattrib->qsel = qsel;
} else
/* Not enable MCC */
pattrib->qsel = qsel;
#else /* !CONFIG_MCC_MODE */
pattrib->qsel = qsel;
#endif /* CONFIG_MCC_MODE */
}
/*
* The main transmit(tx) entry
*
* Return
* 1 enqueue
* 0 success, hardware will handle this xmit frame(packet)
* <0 fail
*/
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24))
s32 rtw_monitor_xmit_entry(struct sk_buff *skb, struct net_device *ndev)
{
u16 frame_ctl;
struct ieee80211_radiotap_header rtap_hdr;
_adapter *padapter = (_adapter *)rtw_netdev_priv(ndev);
struct pkt_file pktfile;
struct rtw_ieee80211_hdr *pwlanhdr;
struct pkt_attrib *pattrib;
struct xmit_frame *pmgntframe;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
unsigned char *pframe;
u8 dummybuf[32];
int len = skb->len, rtap_len;
rtw_mstat_update(MSTAT_TYPE_SKB, MSTAT_ALLOC_SUCCESS, skb->truesize);
#ifndef CONFIG_CUSTOMER_ALIBABA_GENERAL
if (unlikely(skb->len < sizeof(struct ieee80211_radiotap_header)))
goto fail;
_rtw_open_pktfile((_pkt *)skb, &pktfile);
_rtw_pktfile_read(&pktfile, (u8 *)(&rtap_hdr), sizeof(struct ieee80211_radiotap_header));
rtap_len = ieee80211_get_radiotap_len((u8 *)(&rtap_hdr));
if (unlikely(rtap_hdr.it_version))
goto fail;
if (unlikely(skb->len < rtap_len))
goto fail;
if (rtap_len != 12) {
RTW_INFO("radiotap len (should be 14): %d\n", rtap_len);
goto fail;
}
_rtw_pktfile_read(&pktfile, dummybuf, rtap_len-sizeof(struct ieee80211_radiotap_header));
len = len - rtap_len;
#endif
pmgntframe = alloc_mgtxmitframe(pxmitpriv);
if (pmgntframe == NULL) {
rtw_udelay_os(500);
goto fail;
}
_rtw_memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
// _rtw_memcpy(pframe, (void *)checking, len);
_rtw_pktfile_read(&pktfile, pframe, len);
/* Check DATA/MGNT frames */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
frame_ctl = le16_to_cpu(pwlanhdr->frame_ctl);
if ((frame_ctl & RTW_IEEE80211_FCTL_FTYPE) == RTW_IEEE80211_FTYPE_DATA) {
pattrib = &pmgntframe->attrib;
update_monitor_frame_attrib(padapter, pattrib);
if (is_broadcast_mac_addr(pwlanhdr->addr3) || is_broadcast_mac_addr(pwlanhdr->addr1))
pattrib->rate = MGN_24M;
} else {
pattrib = &pmgntframe->attrib;
update_mgntframe_attrib(padapter, pattrib);
}
pattrib->retry_ctrl = _FALSE;
pattrib->pktlen = len;
pmlmeext->mgnt_seq = GetSequence(pwlanhdr);
pattrib->seqnum = pmlmeext->mgnt_seq;
pmlmeext->mgnt_seq++;
pattrib->last_txcmdsz = pattrib->pktlen;
dump_mgntframe(padapter, pmgntframe);
fail:
rtw_skb_free(skb);
return 0;
}
#endif
/*
*
* Return _TRUE when frame has been put to queue, otherwise return _FALSE.
*/
static u8 xmit_enqueue(struct _ADAPTER *a, struct xmit_frame *frame)
{
struct sta_info *sta = NULL;
struct pkt_attrib *attrib = NULL;
_irqL irqL;
_list *head;
u8 ret = _TRUE;
attrib = &frame->attrib;
sta = attrib->psta;
if (!sta)
return _FALSE;
_enter_critical_bh(&sta->tx_queue.lock, &irqL);
head = get_list_head(&sta->tx_queue);
if ((rtw_is_list_empty(head) == _TRUE) && (!sta->tx_q_enable)) {
ret = _FALSE;
goto exit;
}
rtw_list_insert_tail(&frame->list, head);
RTW_INFO(FUNC_ADPT_FMT ": en-queue tx pkt for macid=%d\n",
FUNC_ADPT_ARG(a), sta->cmn.mac_id);
exit:
_exit_critical_bh(&sta->tx_queue.lock, &irqL);
return ret;
}
static void xmit_dequeue(struct sta_info *sta)
{
struct _ADAPTER *a;
_irqL irqL;
_list *head, *list;
struct xmit_frame *frame;
a = sta->padapter;
_enter_critical_bh(&sta->tx_queue.lock, &irqL);
head = get_list_head(&sta->tx_queue);
do {
if (rtw_is_list_empty(head) == _TRUE)
break;
list = get_next(head);
rtw_list_delete(list);
frame = LIST_CONTAINOR(list, struct xmit_frame, list);
RTW_INFO(FUNC_ADPT_FMT ": de-queue tx frame of macid=%d\n",
FUNC_ADPT_ARG(a), sta->cmn.mac_id);
rtw_hal_xmit(a, frame);
} while (1);
_exit_critical_bh(&sta->tx_queue.lock, &irqL);
}
void rtw_xmit_dequeue_callback(_workitem *work)
{
struct sta_info *sta;
sta = container_of(work, struct sta_info, tx_q_work);
xmit_dequeue(sta);
}
void rtw_xmit_queue_set(struct sta_info *sta)
{
_irqL irqL;
_enter_critical_bh(&sta->tx_queue.lock, &irqL);
if (sta->tx_q_enable) {
RTW_WARN(FUNC_ADPT_FMT ": duplicated set!\n",
FUNC_ADPT_ARG(sta->padapter));
goto exit;
}
sta->tx_q_enable = 1;
RTW_INFO(FUNC_ADPT_FMT ": enable queue TX for macid=%d\n",
FUNC_ADPT_ARG(sta->padapter), sta->cmn.mac_id);
exit:
_exit_critical_bh(&sta->tx_queue.lock, &irqL);
}
void rtw_xmit_queue_clear(struct sta_info *sta)
{
_irqL irqL;
_enter_critical_bh(&sta->tx_queue.lock, &irqL);
if (!sta->tx_q_enable) {
RTW_WARN(FUNC_ADPT_FMT ": tx queue for macid=%d "
"not be enabled!\n",
FUNC_ADPT_ARG(sta->padapter), sta->cmn.mac_id);
goto exit;
}
sta->tx_q_enable = 0;
RTW_INFO(FUNC_ADPT_FMT ": disable queue TX for macid=%d\n",
FUNC_ADPT_ARG(sta->padapter), sta->cmn.mac_id);
_set_workitem(&sta->tx_q_work);
exit:
_exit_critical_bh(&sta->tx_queue.lock, &irqL);
}
/*
* The main transmit(tx) entry post handle
*
* Return
* 1 enqueue
* 0 success, hardware will handle this xmit frame(packet)
* <0 fail
*/
s32 rtw_xmit_posthandle(_adapter *padapter, struct xmit_frame *pxmitframe, _pkt *pkt)
{
#ifdef CONFIG_AP_MODE
_irqL irqL0;
#endif
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
s32 res;
res = update_attrib(padapter, pkt, &pxmitframe->attrib);
#ifdef CONFIG_MCC_MODE
/* record data kernel TX to driver to check MCC concurrent TX */
rtw_hal_mcc_calc_tx_bytes_from_kernel(padapter, pxmitframe->attrib.pktlen);
#endif /* CONFIG_MCC_MODE */
#ifdef CONFIG_WAPI_SUPPORT
if (pxmitframe->attrib.ether_type != 0x88B4) {
if (rtw_wapi_drop_for_key_absent(padapter, pxmitframe->attrib.ra)) {
WAPI_TRACE(WAPI_RX, "drop for key absend when tx\n");
res = _FAIL;
}
}
#endif
if (res == _FAIL) {
/*RTW_INFO("%s-"ADPT_FMT" update attrib fail\n", __func__, ADPT_ARG(padapter));*/
#ifdef DBG_TX_DROP_FRAME
RTW_INFO("DBG_TX_DROP_FRAME %s update attrib fail\n", __FUNCTION__);
#endif
rtw_free_xmitframe(pxmitpriv, pxmitframe);
return -1;
}
pxmitframe->pkt = pkt;
rtw_led_tx_control(padapter, pxmitframe->attrib.dst);
do_queue_select(padapter, &pxmitframe->attrib);
#ifdef CONFIG_AP_MODE
_enter_critical_bh(&pxmitpriv->lock, &irqL0);
if (xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe) == _TRUE) {
_exit_critical_bh(&pxmitpriv->lock, &irqL0);
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue);
return 1;
}
_exit_critical_bh(&pxmitpriv->lock, &irqL0);
#endif
if (xmit_enqueue(padapter, pxmitframe) == _TRUE)
return 1;
/* pre_xmitframe */
if (rtw_hal_xmit(padapter, pxmitframe) == _FALSE)
return 1;
return 0;
}
/*
* The main transmit(tx) entry
*
* Return
* 1 enqueue
* 0 success, hardware will handle this xmit frame(packet)
* <0 fail
*/
s32 rtw_xmit(_adapter *padapter, _pkt **ppkt)
{
static systime start = 0;
static u32 drop_cnt = 0;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct xmit_frame *pxmitframe = NULL;
s32 res;
DBG_COUNTER(padapter->tx_logs.core_tx);
if (IS_CH_WAITING(adapter_to_rfctl(padapter)))
return -1;
if (rtw_linked_check(padapter) == _FALSE)
return -1;
if (start == 0)
start = rtw_get_current_time();
pxmitframe = rtw_alloc_xmitframe(pxmitpriv);
if (rtw_get_passing_time_ms(start) > 2000) {
if (drop_cnt)
RTW_INFO("DBG_TX_DROP_FRAME %s no more pxmitframe, drop_cnt:%u\n", __FUNCTION__, drop_cnt);
start = rtw_get_current_time();
drop_cnt = 0;
}
if (pxmitframe == NULL) {
drop_cnt++;
/*RTW_INFO("%s-"ADPT_FMT" no more xmitframe\n", __func__, ADPT_ARG(padapter));*/
DBG_COUNTER(padapter->tx_logs.core_tx_err_pxmitframe);
return -1;
}
#ifdef CONFIG_BR_EXT
if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE | WIFI_ADHOC_STATE) == _TRUE) {
void *br_port = NULL;
#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 35))
br_port = padapter->pnetdev->br_port;
#else
rcu_read_lock();
br_port = rcu_dereference(padapter->pnetdev->rx_handler_data);
rcu_read_unlock();
#endif
if (br_port) {
res = rtw_br_client_tx(padapter, ppkt);
if (res == -1) {
rtw_free_xmitframe(pxmitpriv, pxmitframe);
DBG_COUNTER(padapter->tx_logs.core_tx_err_brtx);
return -1;
}
}
}
#endif /* CONFIG_BR_EXT */
#ifdef CONFIG_RTW_MESH
if (MLME_IS_MESH(padapter)) {
_list b2u_list;
res = rtw_mesh_addr_resolve(padapter, pxmitframe, *ppkt, &b2u_list);
if (res == RTW_RA_RESOLVING)
return 1;
if (res == _FAIL)
return -1;
#if CONFIG_RTW_MESH_DATA_BMC_TO_UC
if (!rtw_is_list_empty(&b2u_list)) {
_list *list = get_next(&b2u_list);
struct xmit_frame *b2uframe;
while ((rtw_end_of_queue_search(&b2u_list, list)) == _FALSE) {
b2uframe = LIST_CONTAINOR(list, struct xmit_frame, list);
list = get_next(list);
rtw_list_delete(&b2uframe->list);
b2uframe->pkt = rtw_os_pkt_copy(*ppkt);
if (!b2uframe->pkt) {
if (res == RTW_BMC_NO_NEED)
res = _SUCCESS;
rtw_free_xmitframe(pxmitpriv, b2uframe);
continue;
}
rtw_xmit_posthandle(padapter, b2uframe, b2uframe->pkt);
}
}
#endif /* CONFIG_RTW_MESH_DATA_BMC_TO_UC */
if (res == RTW_BMC_NO_NEED) {
rtw_free_xmitframe(&padapter->xmitpriv, pxmitframe);
return 0;
}
}
#endif /* CONFIG_RTW_MESH */
pxmitframe->pkt = NULL; /* let rtw_xmit_posthandle not to free pkt inside */
res = rtw_xmit_posthandle(padapter, pxmitframe, *ppkt);
return res;
}
#ifdef CONFIG_TDLS
sint xmitframe_enqueue_for_tdls_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe)
{
sint ret = _FALSE;
_irqL irqL;
struct sta_info *ptdls_sta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
int i;
ptdls_sta = rtw_get_stainfo(pstapriv, pattrib->dst);
if (ptdls_sta == NULL)
return ret;
else if (ptdls_sta->tdls_sta_state & TDLS_LINKED_STATE) {
if (pattrib->triggered == 1) {
ret = _TRUE;
return ret;
}
_enter_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
if (ptdls_sta->state & WIFI_SLEEP_STATE) {
rtw_list_delete(&pxmitframe->list);
/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
rtw_list_insert_tail(&pxmitframe->list, get_list_head(&ptdls_sta->sleep_q));
ptdls_sta->sleepq_len++;
ptdls_sta->sleepq_ac_len++;
/* indicate 4-AC queue bit in TDLS peer traffic indication */
switch (pattrib->priority) {
case 1:
case 2:
ptdls_sta->uapsd_bk |= BIT(1);
break;
case 4:
case 5:
ptdls_sta->uapsd_vi |= BIT(1);
break;
case 6:
case 7:
ptdls_sta->uapsd_vo |= BIT(1);
break;
case 0:
case 3:
default:
ptdls_sta->uapsd_be |= BIT(1);
break;
}
/* Transmit TDLS PTI via AP */
if (ptdls_sta->sleepq_len == 1)
rtw_tdls_cmd(padapter, ptdls_sta->cmn.mac_addr, TDLS_ISSUE_PTI);
ret = _TRUE;
}
_exit_critical_bh(&ptdls_sta->sleep_q.lock, &irqL);
}
return ret;
}
#endif /* CONFIG_TDLS */
#define RTW_HIQ_FILTER_ALLOW_ALL 0
#define RTW_HIQ_FILTER_ALLOW_SPECIAL 1
#define RTW_HIQ_FILTER_DENY_ALL 2
inline bool xmitframe_hiq_filter(struct xmit_frame *xmitframe)
{
bool allow = _FALSE;
_adapter *adapter = xmitframe->padapter;
struct registry_priv *registry = &adapter->registrypriv;
if (adapter->registrypriv.wifi_spec == 1)
allow = _TRUE;
else if (registry->hiq_filter == RTW_HIQ_FILTER_ALLOW_SPECIAL) {
struct pkt_attrib *attrib = &xmitframe->attrib;
if (attrib->ether_type == 0x0806
|| attrib->ether_type == 0x888e
#ifdef CONFIG_WAPI_SUPPORT
|| attrib->ether_type == 0x88B4
#endif
|| attrib->dhcp_pkt
) {
if (0)
RTW_INFO(FUNC_ADPT_FMT" ether_type:0x%04x%s\n", FUNC_ADPT_ARG(xmitframe->padapter)
, attrib->ether_type, attrib->dhcp_pkt ? " DHCP" : "");
allow = _TRUE;
}
} else if (registry->hiq_filter == RTW_HIQ_FILTER_ALLOW_ALL)
allow = _TRUE;
else if (registry->hiq_filter == RTW_HIQ_FILTER_DENY_ALL)
allow = _FALSE;
else
rtw_warn_on(1);
return allow;
}
#if defined(CONFIG_AP_MODE) || defined(CONFIG_TDLS)
sint xmitframe_enqueue_for_sleeping_sta(_adapter *padapter, struct xmit_frame *pxmitframe)
{
_irqL irqL;
sint ret = _FALSE;
struct sta_info *psta = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct pkt_attrib *pattrib = &pxmitframe->attrib;
sint bmcst = IS_MCAST(pattrib->ra);
bool update_tim = _FALSE;
#ifdef CONFIG_TDLS
if (padapter->tdlsinfo.link_established == _TRUE)
ret = xmitframe_enqueue_for_tdls_sleeping_sta(padapter, pxmitframe);
#endif /* CONFIG_TDLS */
if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter)) {
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_fwstate);
return ret;
}
/*
if(pattrib->psta)
{
psta = pattrib->psta;
}
else
{
RTW_INFO("%s, call rtw_get_stainfo()\n", __func__);
psta=rtw_get_stainfo(pstapriv, pattrib->ra);
}
*/
psta = rtw_get_stainfo(&padapter->stapriv, pattrib->ra);
if (pattrib->psta != psta) {
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_sta);
RTW_INFO("%s, pattrib->psta(%p) != psta(%p)\n", __func__, pattrib->psta, psta);
return _FALSE;
}
if (psta == NULL) {
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_nosta);
RTW_INFO("%s, psta==NUL\n", __func__);
return _FALSE;
}
if (!(psta->state & _FW_LINKED)) {
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_link);
RTW_INFO("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
return _FALSE;
}
if (pattrib->triggered == 1) {
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_warn_trigger);
/* RTW_INFO("directly xmit pspoll_triggered packet\n"); */
/* pattrib->triggered=0; */
if (bmcst && xmitframe_hiq_filter(pxmitframe) == _TRUE)
pattrib->qsel = QSLT_HIGH;/* HIQ */
return ret;
}
if (bmcst) {
_enter_critical_bh(&psta->sleep_q.lock, &irqL);
if (rtw_tim_map_anyone_be_set(padapter, pstapriv->sta_dz_bitmap)) { /* if anyone sta is in ps mode */
/* pattrib->qsel = QSLT_HIGH; */ /* HIQ */
rtw_list_delete(&pxmitframe->list);
/*_enter_critical_bh(&psta->sleep_q.lock, &irqL);*/
rtw_list_insert_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
psta->sleepq_len++;
if (!(rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)))
update_tim = _TRUE;
rtw_tim_map_set(padapter, pstapriv->tim_bitmap, 0);
rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, 0);
/* RTW_INFO("enqueue, sq_len=%d\n", psta->sleepq_len); */
/* RTW_INFO_DUMP("enqueue, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
if (update_tim == _TRUE) {
if (is_broadcast_mac_addr(pattrib->ra))
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "buffer BC");
else
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "buffer MC");
} else
chk_bmc_sleepq_cmd(padapter);
/*_exit_critical_bh(&psta->sleep_q.lock, &irqL);*/
ret = _TRUE;
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_mcast);
}
_exit_critical_bh(&psta->sleep_q.lock, &irqL);
return ret;
}
_enter_critical_bh(&psta->sleep_q.lock, &irqL);
if (psta->state & WIFI_SLEEP_STATE) {
u8 wmmps_ac = 0;
if (rtw_tim_map_is_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid)) {
rtw_list_delete(&pxmitframe->list);
/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
rtw_list_insert_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
psta->sleepq_len++;
switch (pattrib->priority) {
case 1:
case 2:
wmmps_ac = psta->uapsd_bk & BIT(0);
break;
case 4:
case 5:
wmmps_ac = psta->uapsd_vi & BIT(0);
break;
case 6:
case 7:
wmmps_ac = psta->uapsd_vo & BIT(0);
break;
case 0:
case 3:
default:
wmmps_ac = psta->uapsd_be & BIT(0);
break;
}
if (wmmps_ac)
psta->sleepq_ac_len++;
if (((psta->has_legacy_ac) && (!wmmps_ac)) || ((!psta->has_legacy_ac) && (wmmps_ac))) {
if (!(rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)))
update_tim = _TRUE;
rtw_tim_map_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
/* RTW_INFO("enqueue, sq_len=%d\n", psta->sleepq_len); */
/* RTW_INFO_DUMP("enqueue, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
if (update_tim == _TRUE) {
/* RTW_INFO("sleepq_len==1, update BCNTIM\n"); */
/* upate BCN for TIM IE */
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "buffer UC");
}
}
/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
/* if(psta->sleepq_len > (NR_XMITFRAME>>3)) */
/* { */
/* wakeup_sta_to_xmit(padapter, psta); */
/* } */
ret = _TRUE;
DBG_COUNTER(padapter->tx_logs.core_tx_ap_enqueue_ucast);
}
}
_exit_critical_bh(&psta->sleep_q.lock, &irqL);
return ret;
}
static void dequeue_xmitframes_to_sleeping_queue(_adapter *padapter, struct sta_info *psta, _queue *pframequeue)
{
sint ret;
_list *plist, *phead;
u8 ac_index;
struct tx_servq *ptxservq;
struct pkt_attrib *pattrib;
struct xmit_frame *pxmitframe;
struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
phead = get_list_head(pframequeue);
plist = get_next(phead);
while (rtw_end_of_queue_search(phead, plist) == _FALSE) {
pxmitframe = LIST_CONTAINOR(plist, struct xmit_frame, list);
plist = get_next(plist);
pattrib = &pxmitframe->attrib;
pattrib->triggered = 0;
ret = xmitframe_enqueue_for_sleeping_sta(padapter, pxmitframe);
if (_TRUE == ret) {
ptxservq = rtw_get_sta_pending(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
ptxservq->qcnt--;
phwxmits[ac_index].accnt--;
} else {
/* RTW_INFO("xmitframe_enqueue_for_sleeping_sta return _FALSE\n"); */
}
}
}
void stop_sta_xmit(_adapter *padapter, struct sta_info *psta)
{
_irqL irqL0;
struct sta_info *psta_bmc;
struct sta_xmit_priv *pstaxmitpriv;
struct sta_priv *pstapriv = &padapter->stapriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
pstaxmitpriv = &psta->sta_xmitpriv;
/* for BC/MC Frames */
psta_bmc = rtw_get_bcmc_stainfo(padapter);
_enter_critical_bh(&pxmitpriv->lock, &irqL0);
psta->state |= WIFI_SLEEP_STATE;
#ifdef CONFIG_TDLS
if (!(psta->tdls_sta_state & TDLS_LINKED_STATE))
#endif /* CONFIG_TDLS */
rtw_tim_map_set(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vo_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vi_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->be_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->bk_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
#ifdef CONFIG_TDLS
if (!(psta->tdls_sta_state & TDLS_LINKED_STATE) && (psta_bmc != NULL)) {
#endif /* CONFIG_TDLS */
/* for BC/MC Frames */
pstaxmitpriv = &psta_bmc->sta_xmitpriv;
dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->vo_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->vo_q.tx_pending));
dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->vi_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->vi_q.tx_pending));
dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->be_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->be_q.tx_pending));
dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc, &pstaxmitpriv->bk_q.sta_pending);
rtw_list_delete(&(pstaxmitpriv->bk_q.tx_pending));
#ifdef CONFIG_TDLS
}
#endif /* CONFIG_TDLS */
_exit_critical_bh(&pxmitpriv->lock, &irqL0);
}
void wakeup_sta_to_xmit(_adapter *padapter, struct sta_info *psta)
{
_irqL irqL;
u8 update_mask = 0, wmmps_ac = 0;
struct sta_info *psta_bmc;
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
psta_bmc = rtw_get_bcmc_stainfo(padapter);
/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
_enter_critical_bh(&pxmitpriv->lock, &irqL);
xmitframe_phead = get_list_head(&psta->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
rtw_list_delete(&pxmitframe->list);
switch (pxmitframe->attrib.priority) {
case 1:
case 2:
wmmps_ac = psta->uapsd_bk & BIT(1);
break;
case 4:
case 5:
wmmps_ac = psta->uapsd_vi & BIT(1);
break;
case 6:
case 7:
wmmps_ac = psta->uapsd_vo & BIT(1);
break;
case 0:
case 3:
default:
wmmps_ac = psta->uapsd_be & BIT(1);
break;
}
psta->sleepq_len--;
if (psta->sleepq_len > 0)
pxmitframe->attrib.mdata = 1;
else
pxmitframe->attrib.mdata = 0;
if (wmmps_ac) {
psta->sleepq_ac_len--;
if (psta->sleepq_ac_len > 0) {
pxmitframe->attrib.mdata = 1;
pxmitframe->attrib.eosp = 0;
} else {
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.eosp = 1;
}
}
pxmitframe->attrib.triggered = 1;
/*
_exit_critical_bh(&psta->sleep_q.lock, &irqL);
if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
{
rtw_os_xmit_complete(padapter, pxmitframe);
}
_enter_critical_bh(&psta->sleep_q.lock, &irqL);
*/
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
}
if (psta->sleepq_len == 0) {
#ifdef CONFIG_TDLS
if (psta->tdls_sta_state & TDLS_LINKED_STATE) {
if (psta->state & WIFI_SLEEP_STATE)
psta->state ^= WIFI_SLEEP_STATE;
_exit_critical_bh(&pxmitpriv->lock, &irqL);
return;
}
#endif /* CONFIG_TDLS */
if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, psta->cmn.aid)) {
/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
/* upate BCN for TIM IE */
/* update_BCNTIM(padapter); */
update_mask = BIT(0);
}
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
if (psta->state & WIFI_SLEEP_STATE)
psta->state ^= WIFI_SLEEP_STATE;
if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
RTW_INFO("%s alive check\n", __func__);
psta->expire_to = pstapriv->expire_to;
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
}
rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, psta->cmn.aid);
}
/* for BC/MC Frames */
if (!psta_bmc)
goto _exit;
if (!(rtw_tim_map_anyone_be_set_exclude_aid0(padapter, pstapriv->sta_dz_bitmap))) { /* no any sta in ps mode */
xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
rtw_list_delete(&pxmitframe->list);
psta_bmc->sleepq_len--;
if (psta_bmc->sleepq_len > 0)
pxmitframe->attrib.mdata = 1;
else
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.triggered = 1;
/*
_exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
if(rtw_hal_xmit(padapter, pxmitframe) == _TRUE)
{
rtw_os_xmit_complete(padapter, pxmitframe);
}
_enter_critical_bh(&psta_bmc->sleep_q.lock, &irqL);
*/
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
}
if (psta_bmc->sleepq_len == 0) {
if (rtw_tim_map_is_set(padapter, pstapriv->tim_bitmap, 0)) {
/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
/* upate BCN for TIM IE */
/* update_BCNTIM(padapter); */
update_mask |= BIT(1);
}
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, 0);
rtw_tim_map_clear(padapter, pstapriv->sta_dz_bitmap, 0);
}
}
_exit:
/* _exit_critical_bh(&psta_bmc->sleep_q.lock, &irqL); */
_exit_critical_bh(&pxmitpriv->lock, &irqL);
if (update_mask) {
/* update_BCNTIM(padapter); */
if ((update_mask & (BIT(0) | BIT(1))) == (BIT(0) | BIT(1)))
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "clear UC&BMC");
else if ((update_mask & BIT(1)) == BIT(1))
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "clear BMC");
else
_update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0, "clear UC");
}
}
void xmit_delivery_enabled_frames(_adapter *padapter, struct sta_info *psta)
{
_irqL irqL;
u8 wmmps_ac = 0;
_list *xmitframe_plist, *xmitframe_phead;
struct xmit_frame *pxmitframe = NULL;
struct sta_priv *pstapriv = &padapter->stapriv;
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
/* _enter_critical_bh(&psta->sleep_q.lock, &irqL); */
_enter_critical_bh(&pxmitpriv->lock, &irqL);
xmitframe_phead = get_list_head(&psta->sleep_q);
xmitframe_plist = get_next(xmitframe_phead);
while ((rtw_end_of_queue_search(xmitframe_phead, xmitframe_plist)) == _FALSE) {
pxmitframe = LIST_CONTAINOR(xmitframe_plist, struct xmit_frame, list);
xmitframe_plist = get_next(xmitframe_plist);
switch (pxmitframe->attrib.priority) {
case 1:
case 2:
wmmps_ac = psta->uapsd_bk & BIT(1);
break;
case 4:
case 5:
wmmps_ac = psta->uapsd_vi & BIT(1);
break;
case 6:
case 7:
wmmps_ac = psta->uapsd_vo & BIT(1);
break;
case 0:
case 3:
default:
wmmps_ac = psta->uapsd_be & BIT(1);
break;
}
if (!wmmps_ac)
continue;
rtw_list_delete(&pxmitframe->list);
psta->sleepq_len--;
psta->sleepq_ac_len--;
if (psta->sleepq_ac_len > 0) {
pxmitframe->attrib.mdata = 1;
pxmitframe->attrib.eosp = 0;
} else {
pxmitframe->attrib.mdata = 0;
pxmitframe->attrib.eosp = 1;
}
pxmitframe->attrib.triggered = 1;
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
if ((psta->sleepq_ac_len == 0) && (!psta->has_legacy_ac) && (wmmps_ac)) {
#ifdef CONFIG_TDLS
if (psta->tdls_sta_state & TDLS_LINKED_STATE) {
/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
goto exit;
}
#endif /* CONFIG_TDLS */
rtw_tim_map_clear(padapter, pstapriv->tim_bitmap, psta->cmn.aid);
/* RTW_INFO("wakeup to xmit, qlen==0\n"); */
/* RTW_INFO_DUMP("update_BCNTIM, tim=", pstapriv->tim_bitmap, pstapriv->aid_bmp_len); */
/* upate BCN for TIM IE */
/* update_BCNTIM(padapter); */
update_beacon(padapter, _TIM_IE_, NULL, _TRUE, 0);
/* update_mask = BIT(0); */
}
}
#ifdef CONFIG_TDLS
exit:
#endif
/* _exit_critical_bh(&psta->sleep_q.lock, &irqL); */
_exit_critical_bh(&pxmitpriv->lock, &irqL);
return;
}
#endif /* defined(CONFIG_AP_MODE) || defined(CONFIG_TDLS) */
#ifdef CONFIG_XMIT_THREAD_MODE
void enqueue_pending_xmitbuf(
struct xmit_priv *pxmitpriv,
struct xmit_buf *pxmitbuf)
{
_irqL irql;
_queue *pqueue;
_adapter *pri_adapter = pxmitpriv->adapter;
pqueue = &pxmitpriv->pending_xmitbuf_queue;
_enter_critical_bh(&pqueue->lock, &irql);
rtw_list_delete(&pxmitbuf->list);
rtw_list_insert_tail(&pxmitbuf->list, get_list_head(pqueue));
_exit_critical_bh(&pqueue->lock, &irql);
#if defined(CONFIG_SDIO_HCI) && defined(CONFIG_CONCURRENT_MODE)
pri_adapter = GET_PRIMARY_ADAPTER(pri_adapter);
#endif /*SDIO_HCI + CONCURRENT*/
_rtw_up_sema(&(pri_adapter->xmitpriv.xmit_sema));
}
void enqueue_pending_xmitbuf_to_head(
struct xmit_priv *pxmitpriv,
struct xmit_buf *pxmitbuf)
{
_irqL irql;
_queue *pqueue = &pxmitpriv->pending_xmitbuf_queue;
_enter_critical_bh(&pqueue->lock, &irql);
rtw_list_delete(&pxmitbuf->list);
rtw_list_insert_head(&pxmitbuf->list, get_list_head(pqueue));
_exit_critical_bh(&pqueue->lock, &irql);
}
struct xmit_buf *dequeue_pending_xmitbuf(
struct xmit_priv *pxmitpriv)
{
_irqL irql;
struct xmit_buf *pxmitbuf;
_queue *pqueue;
pxmitbuf = NULL;
pqueue = &pxmitpriv->pending_xmitbuf_queue;
_enter_critical_bh(&pqueue->lock, &irql);
if (_rtw_queue_empty(pqueue) == _FALSE) {
_list *plist, *phead;
phead = get_list_head(pqueue);
plist = get_next(phead);
pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
rtw_list_delete(&pxmitbuf->list);
}
_exit_critical_bh(&pqueue->lock, &irql);
return pxmitbuf;
}
static struct xmit_buf *dequeue_pending_xmitbuf_ext(
struct xmit_priv *pxmitpriv)
{
_irqL irql;
struct xmit_buf *pxmitbuf;
_queue *pqueue;
pxmitbuf = NULL;
pqueue = &pxmitpriv->pending_xmitbuf_queue;
_enter_critical_bh(&pqueue->lock, &irql);
if (_rtw_queue_empty(pqueue) == _FALSE) {
_list *plist, *phead;
u8 type = 0;
phead = get_list_head(pqueue);
plist = phead;
do {
plist = get_next(plist);
if (plist == phead)
break;
pxmitbuf = LIST_CONTAINOR(plist, struct xmit_buf, list);
if (pxmitbuf->buf_tag == XMITBUF_MGNT) {
rtw_list_delete(&pxmitbuf->list);
break;
}
pxmitbuf = NULL;
} while (1);
}
_exit_critical_bh(&pqueue->lock, &irql);
return pxmitbuf;
}
struct xmit_buf *select_and_dequeue_pending_xmitbuf(_adapter *padapter)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
struct xmit_buf *pxmitbuf = NULL;
if (_TRUE == rtw_is_xmit_blocked(padapter))
return pxmitbuf;
pxmitbuf = dequeue_pending_xmitbuf_ext(pxmitpriv);
if (pxmitbuf == NULL && rtw_xmit_ac_blocked(padapter) != _TRUE)
pxmitbuf = dequeue_pending_xmitbuf(pxmitpriv);
return pxmitbuf;
}
sint check_pending_xmitbuf(
struct xmit_priv *pxmitpriv)
{
_irqL irql;
_queue *pqueue;
sint ret = _FALSE;
pqueue = &pxmitpriv->pending_xmitbuf_queue;
_enter_critical_bh(&pqueue->lock, &irql);
if (_rtw_queue_empty(pqueue) == _FALSE)
ret = _TRUE;
_exit_critical_bh(&pqueue->lock, &irql);
return ret;
}
thread_return rtw_xmit_thread(thread_context context)
{
s32 err;
PADAPTER padapter;
#ifdef RTW_XMIT_THREAD_HIGH_PRIORITY
#ifdef PLATFORM_LINUX
struct sched_param param = { .sched_priority = 1 };
sched_setscheduler(current, SCHED_FIFO, ¶m);
#endif /* PLATFORM_LINUX */
#endif /* RTW_XMIT_THREAD_HIGH_PRIORITY */
err = _SUCCESS;
padapter = (PADAPTER)context;
thread_enter("RTW_XMIT_THREAD");
do {
err = rtw_hal_xmit_thread_handler(padapter);
flush_signals_thread();
} while (_SUCCESS == err);
RTW_INFO(FUNC_ADPT_FMT " Exit\n", FUNC_ADPT_ARG(padapter));
rtw_thread_wait_stop();
return 0;
}
#endif
#ifdef DBG_XMIT_BLOCK
void dump_xmit_block(void *sel, _adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
RTW_PRINT_SEL(sel, "[XMIT-BLOCK] xmit_block :0x%02x\n", dvobj->xmit_block);
if (dvobj->xmit_block & XMIT_BLOCK_REDLMEM)
RTW_PRINT_SEL(sel, "Reason:%s\n", "XMIT_BLOCK_REDLMEM");
if (dvobj->xmit_block & XMIT_BLOCK_SUSPEND)
RTW_PRINT_SEL(sel, "Reason:%s\n", "XMIT_BLOCK_SUSPEND");
if (dvobj->xmit_block == XMIT_BLOCK_NONE)
RTW_PRINT_SEL(sel, "Reason:%s\n", "XMIT_BLOCK_NONE");
}
void dump_xmit_block_info(void *sel, const char *fun_name, _adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
RTW_INFO("\n"ADPT_FMT" call %s\n", ADPT_ARG(padapter), fun_name);
dump_xmit_block(sel, padapter);
}
#define DBG_XMIT_BLOCK_DUMP(adapter) dump_xmit_block_info(RTW_DBGDUMP, __func__, adapter)
#endif
void rtw_set_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason)
{
_irqL irqL;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_enter_critical_bh(&dvobj->xmit_block_lock, &irqL);
dvobj->xmit_block |= reason;
_exit_critical_bh(&dvobj->xmit_block_lock, &irqL);
#ifdef DBG_XMIT_BLOCK
DBG_XMIT_BLOCK_DUMP(padapter);
#endif
}
void rtw_clr_xmit_block(_adapter *padapter, enum XMIT_BLOCK_REASON reason)
{
_irqL irqL;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_enter_critical_bh(&dvobj->xmit_block_lock, &irqL);
dvobj->xmit_block &= ~reason;
_exit_critical_bh(&dvobj->xmit_block_lock, &irqL);
#ifdef DBG_XMIT_BLOCK
DBG_XMIT_BLOCK_DUMP(padapter);
#endif
}
bool rtw_is_xmit_blocked(_adapter *padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
#ifdef DBG_XMIT_BLOCK
DBG_XMIT_BLOCK_DUMP(padapter);
#endif
return ((dvobj->xmit_block) ? _TRUE : _FALSE);
}
bool rtw_xmit_ac_blocked(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
_adapter *iface;
struct mlme_ext_priv *mlmeext;
bool blocked = _FALSE;
int i;
#ifdef DBG_CONFIG_ERROR_DETECT
#ifdef DBG_CONFIG_ERROR_RESET
#ifdef CONFIG_USB_HCI
if (rtw_hal_sreset_inprogress(adapter) == _TRUE) {
blocked = _TRUE;
goto exit;
}
#endif/* #ifdef CONFIG_USB_HCI */
#endif/* #ifdef DBG_CONFIG_ERROR_RESET */
#endif/* #ifdef DBG_CONFIG_ERROR_DETECT */
if (rfctl->offch_state != OFFCHS_NONE
#ifdef CONFIG_DFS
|| IS_RADAR_DETECTED(rfctl) || rfctl->csa_ch
#endif
) {
blocked = _TRUE;
goto exit;
}
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
mlmeext = &iface->mlmeextpriv;
/* check scan state */
if (mlmeext_scan_state(mlmeext) != SCAN_DISABLE
&& mlmeext_scan_state(mlmeext) != SCAN_BACK_OP
) {
blocked = _TRUE;
goto exit;
}
if (mlmeext_scan_state(mlmeext) == SCAN_BACK_OP
&& !mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_TX_RESUME)
) {
blocked = _TRUE;
goto exit;
}
}
#ifdef CONFIG_MCC_MODE
if (MCC_EN(adapter)) {
if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
if (MCC_STOP(adapter)) {
blocked = _TRUE;
goto exit;
}
}
}
#endif /* CONFIG_MCC_MODE */
exit:
return blocked;
}
#ifdef CONFIG_TX_AMSDU
void rtw_amsdu_vo_timeout_handler(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
adapter->xmitpriv.amsdu_vo_timeout = RTW_AMSDU_TIMER_TIMEOUT;
tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
}
void rtw_amsdu_vi_timeout_handler(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
adapter->xmitpriv.amsdu_vi_timeout = RTW_AMSDU_TIMER_TIMEOUT;
tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
}
void rtw_amsdu_be_timeout_handler(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
adapter->xmitpriv.amsdu_be_timeout = RTW_AMSDU_TIMER_TIMEOUT;
if (printk_ratelimit())
RTW_DBG("%s Timeout!\n",__FUNCTION__);
tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
}
void rtw_amsdu_bk_timeout_handler(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
adapter->xmitpriv.amsdu_bk_timeout = RTW_AMSDU_TIMER_TIMEOUT;
tasklet_hi_schedule(&adapter->xmitpriv.xmit_tasklet);
}
u8 rtw_amsdu_get_timer_status(_adapter *padapter, u8 priority)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
u8 status = RTW_AMSDU_TIMER_UNSET;
switch(priority)
{
case 1:
case 2:
status = pxmitpriv->amsdu_bk_timeout;
break;
case 4:
case 5:
status = pxmitpriv->amsdu_vi_timeout;
break;
case 6:
case 7:
status = pxmitpriv->amsdu_vo_timeout;
break;
case 0:
case 3:
default:
status = pxmitpriv->amsdu_be_timeout;
break;
}
return status;
}
void rtw_amsdu_set_timer_status(_adapter *padapter, u8 priority, u8 status)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
switch(priority)
{
case 1:
case 2:
pxmitpriv->amsdu_bk_timeout = status;
break;
case 4:
case 5:
pxmitpriv->amsdu_vi_timeout = status;
break;
case 6:
case 7:
pxmitpriv->amsdu_vo_timeout = status;
break;
case 0:
case 3:
default:
pxmitpriv->amsdu_be_timeout = status;
break;
}
}
void rtw_amsdu_set_timer(_adapter *padapter, u8 priority)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
_timer* amsdu_timer = NULL;
switch(priority)
{
case 1:
case 2:
amsdu_timer = &pxmitpriv->amsdu_bk_timer;
break;
case 4:
case 5:
amsdu_timer = &pxmitpriv->amsdu_vi_timer;
break;
case 6:
case 7:
amsdu_timer = &pxmitpriv->amsdu_vo_timer;
break;
case 0:
case 3:
default:
amsdu_timer = &pxmitpriv->amsdu_be_timer;
break;
}
_set_timer(amsdu_timer, 1);
}
void rtw_amsdu_cancel_timer(_adapter *padapter, u8 priority)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
_timer* amsdu_timer = NULL;
switch(priority)
{
case 1:
case 2:
amsdu_timer = &pxmitpriv->amsdu_bk_timer;
break;
case 4:
case 5:
amsdu_timer = &pxmitpriv->amsdu_vi_timer;
break;
case 6:
case 7:
amsdu_timer = &pxmitpriv->amsdu_vo_timer;
break;
case 0:
case 3:
default:
amsdu_timer = &pxmitpriv->amsdu_be_timer;
break;
}
_cancel_timer_ex(amsdu_timer);
}
#endif /* CONFIG_TX_AMSDU */
#ifdef DBG_TXBD_DESC_DUMP
static struct rtw_tx_desc_backup tx_backup[HW_QUEUE_ENTRY][TX_BAK_FRMAE_CNT];
static u8 backup_idx[HW_QUEUE_ENTRY];
void rtw_tx_desc_backup(_adapter *padapter, struct xmit_frame *pxmitframe, u8 desc_size, u8 hwq)
{
u32 tmp32;
u8 *pxmit_buf;
if (rtw_get_hw_init_completed(padapter) == _FALSE)
return;
pxmit_buf = pxmitframe->pxmitbuf->pbuf;
_rtw_memcpy(tx_backup[hwq][backup_idx[hwq]].tx_bak_desc, pxmit_buf, desc_size);
_rtw_memcpy(tx_backup[hwq][backup_idx[hwq]].tx_bak_data_hdr, pxmit_buf+desc_size, TX_BAK_DATA_LEN);
tmp32 = rtw_read32(padapter, get_txbd_rw_reg(hwq));
tx_backup[hwq][backup_idx[hwq]].tx_bak_rp = (tmp32>>16)&0xfff;
tx_backup[hwq][backup_idx[hwq]].tx_bak_wp = tmp32&0xfff;
tx_backup[hwq][backup_idx[hwq]].tx_desc_size = desc_size;
backup_idx[hwq] = (backup_idx[hwq] + 1) % TX_BAK_FRMAE_CNT;
}
void rtw_tx_desc_backup_reset(void)
{
int i, j;
for (i = 0; i < HW_QUEUE_ENTRY; i++) {
for (j = 0; j < TX_BAK_FRMAE_CNT; j++)
_rtw_memset(&tx_backup[i][j], 0, sizeof(struct rtw_tx_desc_backup));
backup_idx[i] = 0;
}
}
u8 rtw_get_tx_desc_backup(_adapter *padapter, u8 hwq, struct rtw_tx_desc_backup **pbak)
{
*pbak = &tx_backup[hwq][0];
return backup_idx[hwq];
}
#endif
#ifdef CONFIG_PCI_TX_POLLING
void rtw_tx_poll_init(_adapter *padapter)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
_timer* timer = &pxmitpriv->tx_poll_timer;
if (!is_primary_adapter(padapter))
return;
if (timer->function != NULL) {
RTW_INFO("tx polling timer has been init.\n");
return;
}
rtw_init_timer(timer, padapter, rtw_tx_poll_timeout_handler, padapter);
rtw_tx_poll_timer_set(padapter, 1);
RTW_INFO("Tx poll timer init!\n");
}
void rtw_tx_poll_timeout_handler(void *FunctionContext)
{
_adapter *adapter = (_adapter *)FunctionContext;
rtw_tx_poll_timer_set(adapter, 1);
if (adapter->hal_func.tx_poll_handler)
adapter->hal_func.tx_poll_handler(adapter);
else
RTW_WARN("hal ops: tx_poll_handler is NULL\n");
}
void rtw_tx_poll_timer_set(_adapter *padapter, u32 delay)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
_timer* timer = NULL;
timer = &pxmitpriv->tx_poll_timer;
_set_timer(timer, delay);
}
void rtw_tx_poll_timer_cancel(_adapter *padapter)
{
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
_timer* timer = NULL;
if (!is_primary_adapter(padapter))
return;
timer = &pxmitpriv->tx_poll_timer;
_cancel_timer_ex(timer);
timer->function = NULL;
RTW_INFO("Tx poll timer cancel !\n");
}
#endif /* CONFIG_PCI_TX_POLLING */
void rtw_sctx_init(struct submit_ctx *sctx, int timeout_ms)
{
sctx->timeout_ms = timeout_ms;
sctx->submit_time = rtw_get_current_time();
#ifdef PLATFORM_LINUX /* TODO: add condition wating interface for other os */
init_completion(&sctx->done);
#endif
sctx->status = RTW_SCTX_SUBMITTED;
}
int rtw_sctx_wait(struct submit_ctx *sctx, const char *msg)
{
int ret = _FAIL;
unsigned long expire;
int status = 0;
#ifdef PLATFORM_LINUX
expire = sctx->timeout_ms ? msecs_to_jiffies(sctx->timeout_ms) : MAX_SCHEDULE_TIMEOUT;
if (!wait_for_completion_timeout(&sctx->done, expire)) {
/* timeout, do something?? */
status = RTW_SCTX_DONE_TIMEOUT;
RTW_INFO("%s timeout: %s\n", __func__, msg);
} else
status = sctx->status;
#endif
if (status == RTW_SCTX_DONE_SUCCESS)
ret = _SUCCESS;
return ret;
}
bool rtw_sctx_chk_waring_status(int status)
{
switch (status) {
case RTW_SCTX_DONE_UNKNOWN:
case RTW_SCTX_DONE_BUF_ALLOC:
case RTW_SCTX_DONE_BUF_FREE:
case RTW_SCTX_DONE_DRV_STOP:
case RTW_SCTX_DONE_DEV_REMOVE:
return _TRUE;
default:
return _FALSE;
}
}
void rtw_sctx_done_err(struct submit_ctx **sctx, int status)
{
if (*sctx) {
if (rtw_sctx_chk_waring_status(status))
RTW_INFO("%s status:%d\n", __func__, status);
(*sctx)->status = status;
#ifdef PLATFORM_LINUX
complete(&((*sctx)->done));
#endif
*sctx = NULL;
}
}
void rtw_sctx_done(struct submit_ctx **sctx)
{
rtw_sctx_done_err(sctx, RTW_SCTX_DONE_SUCCESS);
}
#ifdef CONFIG_XMIT_ACK
int rtw_ack_tx_wait(struct xmit_priv *pxmitpriv, u32 timeout_ms)
{
struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
pack_tx_ops->submit_time = rtw_get_current_time();
pack_tx_ops->timeout_ms = timeout_ms;
pack_tx_ops->status = RTW_SCTX_SUBMITTED;
return rtw_sctx_wait(pack_tx_ops, __func__);
}
void rtw_ack_tx_done(struct xmit_priv *pxmitpriv, int status)
{
struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
if (pxmitpriv->ack_tx)
rtw_sctx_done_err(&pack_tx_ops, status);
else
RTW_INFO("%s ack_tx not set\n", __func__);
}
#endif /* CONFIG_XMIT_ACK */
================================================
FILE: dkms.conf
================================================
PACKAGE_NAME="rtl88x2ce"
PACKAGE_VERSION="5.7.3_35403_20240103"
PROCS_NUM=$(nproc)
[ $PROCS_NUM -gt 16 ] && PROCS_NUM=16
MAKE="'make' -j${PROCS_NUM} KVER=${kernelver} KSRC=/lib/modules/${kernelver}/build USER_EXTRA_CFLAGS+=-DCONFIG_CONCURRENT_MODE"
CLEAN="make clean"
BUILT_MODULE_NAME[0]="rtl88x2ce"
DEST_MODULE_LOCATION[0]="/kernel/drivers/net/wireless/realtek/rtl88x2ce"
AUTOINSTALL="yes"
================================================
FILE: hal/HalPwrSeqCmd.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/*++
Copyright (c) Realtek Semiconductor Corp. All rights reserved.
Module Name:
HalPwrSeqCmd.c
Abstract:
Implement HW Power sequence configuration CMD handling routine for Realtek devices.
Major Change History:
When Who What
---------- --------------- -------------------------------
2011-10-26 Lucas Modify to be compatible with SD4-CE driver.
2011-07-07 Roger Create.
--*/
#include
/*
* Description:
* This routine deal with the Power Configuration CMDs parsing for RTL8723/RTL8188E Series IC.
*
* Assumption:
* We should follow specific format which was released from HW SD.
*
* 2011.07.07, added by Roger.
* */
u8 HalPwrSeqCmdParsing(
PADAPTER padapter,
u8 CutVersion,
u8 FabVersion,
u8 InterfaceType,
WLAN_PWR_CFG PwrSeqCmd[])
{
WLAN_PWR_CFG PwrCfgCmd = {0};
u8 bPollingBit = _FALSE;
u8 bHWICSupport = _FALSE;
u32 AryIdx = 0;
u8 value = 0;
u32 offset = 0;
u8 flag = 0;
u32 pollingCount = 0; /* polling autoload done. */
u32 maxPollingCnt = 5000;
do {
PwrCfgCmd = PwrSeqCmd[AryIdx];
/* 2 Only Handle the command whose FAB, CUT, and Interface are matched */
if ((GET_PWR_CFG_FAB_MASK(PwrCfgCmd) & FabVersion) &&
(GET_PWR_CFG_CUT_MASK(PwrCfgCmd) & CutVersion) &&
(GET_PWR_CFG_INTF_MASK(PwrCfgCmd) & InterfaceType)) {
switch (GET_PWR_CFG_CMD(PwrCfgCmd)) {
case PWR_CMD_READ:
break;
case PWR_CMD_WRITE:
offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
#ifdef CONFIG_SDIO_HCI
/* */
/* We should deal with interface specific address mapping for some interfaces, e.g., SDIO interface */
/* 2011.07.07. */
/* */
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO) {
/* Read Back SDIO Local value */
value = SdioLocalCmd52Read1Byte(padapter, offset);
value &= ~(GET_PWR_CFG_MASK(PwrCfgCmd));
value |= (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd));
/* Write Back SDIO Local value */
SdioLocalCmd52Write1Byte(padapter, offset, value);
} else
#endif
{
#ifdef CONFIG_GSPI_HCI
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
offset = SPI_LOCAL_OFFSET | offset;
#endif
/* Read the value from system register */
value = rtw_read8(padapter, offset);
value = value & (~(GET_PWR_CFG_MASK(PwrCfgCmd)));
value = value | (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd));
/* Write the value back to sytem register */
rtw_write8(padapter, offset, value);
}
break;
case PWR_CMD_POLLING:
bPollingBit = _FALSE;
offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
rtw_hal_get_hwreg(padapter, HW_VAR_PWR_CMD, &bHWICSupport);
if (bHWICSupport && offset == 0x06) {
flag = 0;
maxPollingCnt = 100000;
} else
maxPollingCnt = 5000;
#ifdef CONFIG_GSPI_HCI
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
offset = SPI_LOCAL_OFFSET | offset;
#endif
do {
#ifdef CONFIG_SDIO_HCI
if (GET_PWR_CFG_BASE(PwrCfgCmd) == PWR_BASEADDR_SDIO)
value = SdioLocalCmd52Read1Byte(padapter, offset);
else
#endif
value = rtw_read8(padapter, offset);
value = value & GET_PWR_CFG_MASK(PwrCfgCmd);
if (value == (GET_PWR_CFG_VALUE(PwrCfgCmd) & GET_PWR_CFG_MASK(PwrCfgCmd)))
bPollingBit = _TRUE;
else
rtw_udelay_os(10);
if (pollingCount++ > maxPollingCnt) {
RTW_ERR("HalPwrSeqCmdParsing: Fail to polling Offset[%#x]=%02x\n", offset, value);
/* For PCIE + USB package poll power bit timeout issue only modify 8821AE and 8723BE */
if (bHWICSupport && offset == 0x06 && flag == 0) {
RTW_ERR("[WARNING] PCIE polling(0x%X) timeout(%d), Toggle 0x04[3] and try again.\n", offset, maxPollingCnt);
if (IS_HARDWARE_TYPE_8723DE(padapter))
PlatformEFIOWrite1Byte(padapter, 0x40, (PlatformEFIORead1Byte(padapter, 0x40)) & (~BIT3));
PlatformEFIOWrite1Byte(padapter, 0x04, PlatformEFIORead1Byte(padapter, 0x04) | BIT3);
PlatformEFIOWrite1Byte(padapter, 0x04, PlatformEFIORead1Byte(padapter, 0x04) & ~BIT3);
if (IS_HARDWARE_TYPE_8723DE(padapter))
PlatformEFIOWrite1Byte(padapter, 0x40, PlatformEFIORead1Byte(padapter, 0x40)|BIT3);
/* Retry Polling Process one more time */
pollingCount = 0;
flag = 1;
} else {
return _FALSE;
}
}
} while (!bPollingBit);
break;
case PWR_CMD_DELAY:
if (GET_PWR_CFG_VALUE(PwrCfgCmd) == PWRSEQ_DELAY_US)
rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd));
else
rtw_udelay_os(GET_PWR_CFG_OFFSET(PwrCfgCmd) * 1000);
break;
case PWR_CMD_END:
/* When this command is parsed, end the process */
return _TRUE;
break;
default:
break;
}
}
AryIdx++;/* Add Array Index */
} while (1);
return _TRUE;
}
================================================
FILE: hal/btc/btc_basic_types.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __BTC_BASIC_TYPES_H__
#define __BTC_BASIC_TYPES_H__
#define IN
#define OUT
#define VOID void
typedef void *PVOID;
#define u1Byte u8
#define pu1Byte u8*
#define u2Byte u16
#define pu2Byte u16*
#define u4Byte u32
#define pu4Byte u32*
#define u8Byte u64
#define pu8Byte u64*
#define s1Byte s8
#define ps1Byte s8*
#define s2Byte s16
#define ps2Byte s16*
#define s4Byte s32
#define ps4Byte s32*
#define s8Byte s64
#define ps8Byte s64*
#define UCHAR u8
#define USHORT u16
#define UINT u32
#define ULONG u32
#define PULONG u32*
#endif /* __BTC_BASIC_TYPES_H__ */
================================================
FILE: hal/btc/halbtc8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include "mp_precomp.h"
#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
static u8 *trace_buf = &gl_btc_trace_buf[0];
static const u32 bt_desired_ver_8822c = 0xd;
/* rssi express in percentage % (dbm = % - 100) */
static const u8 wl_rssi_step_8822c[] = {60, 50, 44, 30};
static const u8 bt_rssi_step_8822c[] = {8, 15, 20, 25};
/* Shared-Antenna Coex Table */
static const struct btc_coex_table_para table_sant_8822c[] = {
{0xffffffff, 0xffffffff}, /*case-0*/
{0x55555555, 0x55555555},
{0x66555555, 0x66555555},
{0xaaaaaaaa, 0xaaaaaaaa},
{0x5a5a5a5a, 0x5a5a5a5a},
{0xfafafafa, 0xfafafafa}, /*case-5*/
{0x6a5a6a5a, 0xaaaaaaaa},
{0x6a5a56aa, 0x6a5a56aa},
{0x6a5a5a5a, 0x6a5a5a5a},
{0x66555555, 0x5a5a5a5a},
{0x66555555, 0x6a5a5a5a}, /*case-10*/
{0x66555555, 0xfafafafa},
{0x66555555, 0x6a5a5aaa},
{0x66555555, 0x5aaa5aaa},
{0x66555555, 0xaaaa5aaa},
{0x66555555, 0xaaaaaaaa}, /*case-15*/
{0xffff55ff, 0xfafafafa},
{0xffff55ff, 0x6afa5afa},
{0xaaffffaa, 0xfafafafa},
{0xaa5555aa, 0x5a5a5a5a},
{0xaa5555aa, 0x6a5a5a5a}, /*case-20*/
{0xaa5555aa, 0xaaaaaaaa},
{0xffffffff, 0x5a5a5a5a},
{0xffffffff, 0x6a5a5a5a},
{0xffffffff, 0x55555555},
{0xffffffff, 0x6a5a5aaa}, /*case-25*/
{0x55555555, 0x5a5a5a5a},
{0x55555555, 0xaaaaaaaa},
{0x55555555, 0x6a5a6a5a},
{0x66556655, 0x66556655} };
/* Non-Shared-Antenna Coex Table */
static const struct btc_coex_table_para table_nsant_8822c[] = {
{0xffffffff, 0xffffffff}, /*case-100*/
{0x55555555, 0x55555555},
{0x66555555, 0x66555555},
{0xaaaaaaaa, 0xaaaaaaaa},
{0x5a5a5a5a, 0x5a5a5a5a},
{0xfafafafa, 0xfafafafa}, /*case-105*/
{0x5afa5afa, 0x5afa5afa},
{0x55555555, 0xfafafafa},
{0x66555555, 0xfafafafa},
{0x66555555, 0x5a5a5a5a},
{0x66555555, 0x6a5a5a5a}, /*case-110*/
{0x66555555, 0xaaaaaaaa},
{0xffff55ff, 0xfafafafa},
{0xffff55ff, 0x5afa5afa},
{0xffff55ff, 0xaaaaaaaa},
{0xaaffffaa, 0xfafafafa}, /*case-115*/
{0xaaffffaa, 0x5afa5afa},
{0xaaffffaa, 0xaaaaaaaa},
{0xffffffff, 0xfafafafa},
{0xffffffff, 0x5afa5afa},
{0xffffffff, 0xaaaaaaaa},/*case-120*/
{0x55ff55ff, 0x5afa5afa},
{0x55ff55ff, 0xaaaaaaaa},
{0x55ff55ff, 0x55ff55ff} };
/* Shared-Antenna TDMA*/
static const struct btc_tdma_para tdma_sant_8822c[] = {
{ {0x00, 0x00, 0x00, 0x00, 0x00} }, /*case-0*/
{ {0x61, 0x45, 0x03, 0x11, 0x11} }, /*case-1*/
{ {0x61, 0x3a, 0x03, 0x11, 0x11} },
{ {0x61, 0x30, 0x03, 0x11, 0x11} },
{ {0x61, 0x20, 0x03, 0x11, 0x11} },
{ {0x61, 0x10, 0x03, 0x11, 0x11} }, /*case-5*/
{ {0x61, 0x45, 0x03, 0x11, 0x10} },
{ {0x61, 0x3a, 0x03, 0x11, 0x10} },
{ {0x61, 0x30, 0x03, 0x11, 0x10} },
{ {0x61, 0x20, 0x03, 0x11, 0x10} },
{ {0x61, 0x10, 0x03, 0x11, 0x10} }, /*case-10*/
{ {0x61, 0x08, 0x03, 0x11, 0x14} },
{ {0x61, 0x08, 0x03, 0x10, 0x14} },
{ {0x51, 0x08, 0x03, 0x10, 0x54} },
{ {0x51, 0x08, 0x03, 0x10, 0x55} },
{ {0x51, 0x08, 0x07, 0x10, 0x54} }, /*case-15*/
{ {0x51, 0x45, 0x03, 0x10, 0x50} },
{ {0x51, 0x3a, 0x03, 0x10, 0x50} },
{ {0x51, 0x30, 0x03, 0x10, 0x50} },
{ {0x51, 0x20, 0x03, 0x10, 0x50} },
{ {0x51, 0x10, 0x03, 0x10, 0x50} }, /*case-20*/
{ {0x51, 0x4a, 0x03, 0x10, 0x50} },
{ {0x51, 0x0c, 0x03, 0x10, 0x54} },
{ {0x55, 0x08, 0x03, 0x10, 0x54} },
{ {0x65, 0x10, 0x03, 0x11, 0x11} },
{ {0x51, 0x10, 0x03, 0x10, 0x51} } };
/* Non-Shared-Antenna TDMA*/
static const struct btc_tdma_para tdma_nsant_8822c[] = {
{ {0x00, 0x00, 0x00, 0x00, 0x00} }, /*case-100*/
{ {0x61, 0x45, 0x03, 0x11, 0x11} }, /*case-101*/
{ {0x61, 0x3a, 0x03, 0x11, 0x11} },
{ {0x61, 0x30, 0x03, 0x11, 0x11} },
{ {0x61, 0x20, 0x03, 0x11, 0x11} },
{ {0x61, 0x10, 0x03, 0x11, 0x11} }, /*case-105*/
{ {0x61, 0x45, 0x03, 0x11, 0x10} },
{ {0x61, 0x3a, 0x03, 0x11, 0x10} },
{ {0x61, 0x30, 0x03, 0x11, 0x10} },
{ {0x61, 0x20, 0x03, 0x11, 0x10} },
{ {0x61, 0x10, 0x03, 0x11, 0x10} }, /*case-110*/
{ {0x61, 0x08, 0x03, 0x11, 0x14} },
{ {0x61, 0x08, 0x03, 0x10, 0x14} },
{ {0x51, 0x08, 0x03, 0x10, 0x54} },
{ {0x51, 0x08, 0x03, 0x10, 0x55} },
{ {0x51, 0x08, 0x07, 0x10, 0x54} }, /*case-115*/
{ {0x51, 0x45, 0x03, 0x10, 0x50} },
{ {0x51, 0x3a, 0x03, 0x10, 0x50} },
{ {0x51, 0x30, 0x03, 0x10, 0x50} },
{ {0x51, 0x20, 0x03, 0x10, 0x50} },
{ {0x51, 0x10, 0x03, 0x10, 0x50} } };
/* wl_tx_dec_power, bt_tx_dec_power, wl_rx_gain, bt_rx_lna_constrain */
static const struct btc_rf_para rf_para_tx_8822c[] = {
{0, 0, FALSE, 7}, /* for normal */
{0, 16, FALSE, 7}, /* for WL-CPT */
{8, 17, TRUE, 4},
{7, 18, TRUE, 4},
{6, 19, TRUE, 4},
{5, 20, TRUE, 4} };
static const struct btc_rf_para rf_para_rx_8822c[] = {
{0, 0, FALSE, 7}, /* for normal */
{0, 16, FALSE, 7}, /* for WL-CPT */
{3, 24, TRUE, 5},
{2, 26, TRUE, 5},
{1, 27, TRUE, 5},
{0, 28, TRUE, 5} };
const struct btc_5g_afh_map afh_5g_8822c[] = { {0, 0, 0} };
const struct btc_chip_para btc_chip_para_8822c = {
"8822c", /*.chip_name */
20190531, /*.para_ver_date */
0xe, /*.para_ver */
0xd, /* bt_desired_ver */
TRUE, /* scbd_support */
TRUE, /* mailbox_support*/
TRUE, /* lte_indirect_access */
TRUE, /* new_scbd10_def */
BTC_INDIRECT_1700, /* indirect_type */
BTC_PSTDMA_FORCE_LPSOFF, /* pstdma_type */
BTC_BTRSSI_DBM, /* bt_rssi_type */
15, /*.ant_isolation */
2, /*.rssi_tolerance */
2, /* rx_path_num */
ARRAY_SIZE(wl_rssi_step_8822c), /*.wl_rssi_step_num */
wl_rssi_step_8822c, /*.wl_rssi_step */
ARRAY_SIZE(bt_rssi_step_8822c), /*.bt_rssi_step_num */
bt_rssi_step_8822c, /*.bt_rssi_step */
ARRAY_SIZE(table_sant_8822c), /*.table_sant_num */
table_sant_8822c, /*.table_sant = */
ARRAY_SIZE(table_nsant_8822c), /*.table_nsant_num */
table_nsant_8822c, /*.table_nsant = */
ARRAY_SIZE(tdma_sant_8822c), /*.tdma_sant_num */
tdma_sant_8822c, /*.tdma_sant = */
ARRAY_SIZE(tdma_nsant_8822c), /*.tdma_nsant_num */
tdma_nsant_8822c, /*.tdma_nsant */
ARRAY_SIZE(rf_para_tx_8822c), /* wl_rf_para_tx_num */
rf_para_tx_8822c, /* wl_rf_para_tx */
rf_para_rx_8822c, /* wl_rf_para_rx */
0x24, /*.bt_afh_span_bw20 */
0x36, /*.bt_afh_span_bw40 */
ARRAY_SIZE(afh_5g_8822c), /*.afh_5g_num */
afh_5g_8822c, /*.afh_5g */
halbtc8822c_chip_setup /* chip_setup function */
};
void halbtc8822c_cfg_init(struct btc_coexist *btc)
{
u8 u8tmp = 0;
/* enable TBTT nterrupt */
btc->btc_write_1byte_bitmask(btc, 0x550, 0x8, 0x1);
/* BT report packet sample rate */
/* 0x790[5:0]=0x5 */
btc->btc_write_1byte(btc, 0x790, 0x5);
/* Enable BT counter statistics */
btc->btc_write_1byte(btc, 0x778, 0x1);
/* Enable PTA (3-wire function form BT side) */
btc->btc_write_1byte_bitmask(btc, 0x40, 0x20, 0x1);
btc->btc_write_1byte_bitmask(btc, 0x41, 0x02, 0x1);
/* Enable PTA (tx/rx signal form WiFi side) */
btc->btc_write_1byte_bitmask(btc, 0x4c6, BIT(4), 0x1);
btc->btc_write_1byte_bitmask(btc, 0x4c6, BIT(5), 0x0);
/*GNT_BT=1 while select both */
btc->btc_write_1byte_bitmask(btc, 0x763, BIT(4), 0x1);
/* BT_CCA = ~GNT_WL_BB, (not or GNT_BT_BB, LTE_Rx */
btc->btc_write_1byte_bitmask(btc, 0x4fc, 0x3, 0x0);
/* To avoid RF parameter error */
btc->btc_set_rf_reg(btc, BTC_RF_B, 0x1, 0xfffff, 0x40000);
}
void halbtc8822c_cfg_ant_switch(struct btc_coexist *btc)
{}
void halbtc8822c_cfg_gnt_fix(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u32 val = 0x40000;
/* Because WL-S1 5G RF TRX mask affect by GNT_BT
* Set debug mode on: GNT_BT=0, GNT_WL=1, BT at BTG
*/
if (coex_sta->kt_ver == 0 &&
coex_sta->wl_coex_mode == BTC_WLINK_5G)
val = 0x40021;
else if (coex_sta->coex_freerun) /* WL S1 force to GNT_WL=1, GNT_BT=0 */
val = 0x40021;
else
val = 0x40000;
if (btc->board_info.btdm_ant_num == 1) /* BT at S1 for 2-Ant */
val = val | BIT(13);
btc->btc_set_rf_reg(btc, BTC_RF_B, 0x1, 0xfffff, val);
/* Because WL-S0 2G RF TRX can't masked by GNT_BT
* enable "WLS0 BB chage RF mode if GNT_BT = 1" for shared-antenna type
* disable:0x1860[3] = 1, enable:0x1860[3] = 0
*
* enable "AFE DAC off if GNT_WL = 0"
* disable 0x1c30[22] = 0,
* enable: 0x1c30[22] = 1, 0x1c38[12] = 0, 0x1c38[28] = 1
*/
btc->btc_write_1byte_bitmask(btc, 0x1c32, BIT(6), 1);
btc->btc_write_1byte_bitmask(btc, 0x1c39, BIT(4), 0);
btc->btc_write_1byte_bitmask(btc, 0x1c3b, BIT(4), 1);
/* disable WLS1 BB chage RF mode if GNT_BT
* since RF TRx mask can do it
*/
btc->btc_write_1byte_bitmask(btc, 0x4160, BIT(3), 1);
/* for kt_ver >= 3: 0x1860[3] = 0
* always set "WLS0 BB chage RF mode if GNT_WL = 0"
* But the BB DAC will be turned off by GNT_BT = 1
* 0x1ca7[3] = 1, "don't off BB DAC if GNT_BT = 1"
*/
if (coex_sta->wl_coex_mode == BTC_WLINK_5G ||
link_info_ext->is_all_under_5g) {
if (coex_sta->kt_ver >= 3) {
btc->btc_write_1byte_bitmask(btc, 0x1860, BIT(3), 0);
btc->btc_write_1byte_bitmask(btc, 0x1ca7, BIT(3), 1);
} else {
btc->btc_write_1byte_bitmask(btc, 0x1860, BIT(3), 1);
}
} else if (btc->board_info.btdm_ant_num == 2 ||
coex_sta->wl_coex_mode == BTC_WLINK_25GMPORT) {
/* non-shared-antenna or MCC-2band */
if (coex_sta->kt_ver >= 3) {
btc->btc_write_1byte_bitmask(btc, 0x1860, BIT(3), 0);
btc->btc_write_1byte_bitmask(btc, 0x1ca7, BIT(3), 1);
} else {
btc->btc_write_1byte_bitmask(btc, 0x1860, BIT(3), 1);
}
} else { /* shared-antenna */
btc->btc_write_1byte_bitmask(btc, 0x1860, BIT(3), 0);
if (coex_sta->kt_ver >= 3)
btc->btc_write_1byte_bitmask(btc, 0x1ca7, BIT(3), 0);
}
}
void halbtc8822c_cfg_gnt_debug(struct btc_coexist *btc)
{
btc->btc_write_1byte_bitmask(btc, 0x66, BIT(4), 0);
btc->btc_write_1byte_bitmask(btc, 0x67, BIT(0), 0);
btc->btc_write_1byte_bitmask(btc, 0x42, BIT(3), 0);
btc->btc_write_1byte_bitmask(btc, 0x65, BIT(7), 0);
btc->btc_write_1byte_bitmask(btc, 0x73, BIT(3), 0);
}
void halbtc8822c_cfg_rfe_type(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
struct btc_board_info *board_info = &btc->board_info;
rfe_type->rfe_module_type = board_info->rfe_type;
rfe_type->ant_switch_polarity = 0;
rfe_type->ant_switch_exist = FALSE;
rfe_type->ant_switch_with_bt = FALSE;
rfe_type->ant_switch_type = BTC_SWITCH_NONE;
rfe_type->ant_switch_diversity = FALSE;
rfe_type->band_switch_exist = FALSE;
rfe_type->band_switch_type = 0;
rfe_type->band_switch_polarity = 0;
if (btc->board_info.btdm_ant_num == 1)
rfe_type->wlg_at_btg = TRUE;
else
rfe_type->wlg_at_btg = FALSE;
coex_sta->rf4ce_en = FALSE;
/* Disable LTE Coex Function in WiFi side */
btc->btc_write_linderct(btc, 0x38, BIT(7), 0);
/* BTC_CTT_WL_VS_LTE */
btc->btc_write_linderct(btc, 0xa0, 0xffff, 0xffff);
/* BTC_CTT_BT_VS_LTE */
btc->btc_write_linderct(btc, 0xa4, 0xffff, 0xffff);
}
void halbtc8822c_cfg_coexinfo_hw(struct btc_coexist *btc)
{
u8 *cli_buf = btc->cli_buf, u8tmp[4];
u16 u16tmp[4];
u32 u32tmp[4];
boolean lte_coex_on = FALSE;
u32tmp[0] = btc->btc_read_linderct(btc, 0x38);
u32tmp[1] = btc->btc_read_linderct(btc, 0x54);
u8tmp[0] = btc->btc_read_1byte(btc, 0x73);
lte_coex_on = ((u32tmp[0] & BIT(7)) >> 7) ? TRUE : FALSE;
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s",
"LTE Coex/Path Owner", ((lte_coex_on) ? "On" : "Off"),
((u8tmp[0] & BIT(2)) ? "WL" : "BT"));
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = RF:%s_BB:%s/ RF:%s_BB:%s/ %s",
"GNT_WL_Ctrl/GNT_BT_Ctrl/Dbg",
((u32tmp[0] & BIT(12)) ? "SW" : "HW"),
((u32tmp[0] & BIT(8)) ? "SW" : "HW"),
((u32tmp[0] & BIT(14)) ? "SW" : "HW"),
((u32tmp[0] & BIT(10)) ? "SW" : "HW"),
((u8tmp[0] & BIT(3)) ? "On" : "Off"));
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
"GNT_WL/GNT_BT", (int)((u32tmp[1] & BIT(2)) >> 2),
(int)((u32tmp[1] & BIT(3)) >> 3));
CL_PRINTF(cli_buf);
u32tmp[0] = btc->btc_read_4byte(btc, 0x1c38);
u8tmp[0] = btc->btc_read_1byte(btc, 0x1860);
u8tmp[1] = btc->btc_read_1byte(btc, 0x4160);
u8tmp[2] = btc->btc_read_1byte(btc, 0x1c32);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ %d/ %d/ %d",
"1860[3]/4160[3]/1c30[22]/1c38[28]",
(int)((u8tmp[0] & BIT(3)) >> 3),
(int)((u8tmp[1] & BIT(3)) >> 3),
(int)((u8tmp[2] & BIT(6)) >> 6),
(int)((u32tmp[0] & BIT(28)) >> 28));
CL_PRINTF(cli_buf);
u32tmp[0] = btc->btc_read_4byte(btc, 0x430);
u32tmp[1] = btc->btc_read_4byte(btc, 0x434);
u16tmp[0] = btc->btc_read_2byte(btc, 0x42a);
u8tmp[0] = btc->btc_read_1byte(btc, 0x426);
u8tmp[1] = btc->btc_read_1byte(btc, 0x45e);
u8tmp[2] = btc->btc_read_1byte(btc, 0x455);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%x",
"430/434/42a/426/45e[3]/455",
u32tmp[0], u32tmp[1], u16tmp[0], u8tmp[0],
(int)((u8tmp[1] & BIT(3)) >> 3), u8tmp[2]);
CL_PRINTF(cli_buf);
u32tmp[0] = btc->btc_read_4byte(btc, 0x4c);
u8tmp[2] = btc->btc_read_1byte(btc, 0x64);
u8tmp[0] = btc->btc_read_1byte(btc, 0x4c6);
u8tmp[1] = btc->btc_read_1byte(btc, 0x40);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%x",
"4c[24:23]/64[0]/4c6[4]/40[5]/RF_0x1",
(int)(u32tmp[0] & (BIT(24) | BIT(23))) >> 23, u8tmp[2] & 0x1,
(int)((u8tmp[0] & BIT(4)) >> 4),
(int)((u8tmp[1] & BIT(5)) >> 5),
(int)(btc->btc_get_rf_reg(btc, BTC_RF_B, 0x1, 0xfffff)));
CL_PRINTF(cli_buf);
u32tmp[0] = btc->btc_read_4byte(btc, 0x550);
u8tmp[0] = btc->btc_read_1byte(btc, 0x522);
u8tmp[1] = btc->btc_read_1byte(btc, 0x953);
u8tmp[2] = btc->btc_read_1byte(btc, 0xc50);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%x/ %s/ 0x%x",
"550/522/4-RxAGC/c50", u32tmp[0], u8tmp[0],
(u8tmp[1] & 0x2) ? "On" : "Off", u8tmp[2]);
CL_PRINTF(cli_buf);
u8tmp[0] = btc->btc_read_1byte(btc, 0xf8e);
u8tmp[1] = btc->btc_read_1byte(btc, 0xf8f);
u8tmp[2] = btc->btc_read_1byte(btc, 0xd14);
u8tmp[3] = btc->btc_read_1byte(btc, 0xd54);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
"EVM_A/ EVM_B/ SNR_A/ SNR_B",
(u8tmp[0] > 127 ? u8tmp[0] - 256 : u8tmp[0]),
(u8tmp[1] > 127 ? u8tmp[1] - 256 : u8tmp[1]),
(u8tmp[2] > 127 ? u8tmp[2] - 256 : u8tmp[2]),
(u8tmp[3] > 127 ? u8tmp[3] - 256 : u8tmp[3]));
CL_PRINTF(cli_buf);
}
void halbtc8822c_cfg_wl_tx_power(struct btc_coexist *btc)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
btc->btc_reduce_wl_tx_power(btc, coex_dm->cur_wl_pwr_lvl);
}
void halbtc8822c_cfg_wl_rx_gain(struct btc_coexist *btc)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 i;
/* WL Rx Low gain on */
static const u32 wl_rx_gain_on_HT20[] = {0x00000000};
static const u32 wl_rx_gain_on_HT40[] = {0x00000000};
/* WL Rx Low gain off */
static const u32 wl_rx_gain_off_HT20[] = {0x00000000};
static const u32 wl_rx_gain_off_HT40[] = {0x00000000};
u32 *wl_rx_gain_on, *wl_rx_gain_off;
if (coex_dm->cur_wl_rx_low_gain_en) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Hi-Li Table On!\n");
BTC_TRACE(trace_buf);
#if 0
if (link_info_ext->wifi_bw == BTC_WIFI_BW_HT40)
wl_rx_gain_on = wl_rx_gain_on_HT40;
else
wl_rx_gain_on = wl_rx_gain_on_HT20;
for (i = 0; i < ARRAY_SIZE(wl_rx_gain_on); i++)
btc->btc_write_4byte(btc, 0x1d90, wl_rx_gain_on[i]);
#endif
/* set Rx filter corner RCK offset */
btc->btc_set_rf_reg(btc, BTC_RF_A, 0xde, 0xfffff, 0x22);
btc->btc_set_rf_reg(btc, BTC_RF_A, 0x1d, 0xfffff, 0x36);
btc->btc_set_rf_reg(btc, BTC_RF_B, 0xde, 0xfffff, 0x22);
btc->btc_set_rf_reg(btc, BTC_RF_B, 0x1d, 0xfffff, 0x36);
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Hi-Li Table Off!\n");
BTC_TRACE(trace_buf);
#if 0
if (link_info_ext->wifi_bw == BTC_WIFI_BW_HT40)
wl_rx_gain_off = wl_rx_gain_off_HT40;
else
wl_rx_gain_off = wl_rx_gain_off_HT20;
for (i = 0; i < ARRAY_SIZE(wl_rx_gain_off); i++)
btc->btc_write_4byte(btc, 0x1d90, wl_rx_gain_off[i]);
#endif
/* set Rx filter corner RCK offset */
btc->btc_set_rf_reg(btc, BTC_RF_A, 0xde, 0xfffff, 0x20);
btc->btc_set_rf_reg(btc, BTC_RF_A, 0x1d, 0xfffff, 0x0);
btc->btc_set_rf_reg(btc, BTC_RF_B, 0xde, 0xfffff, 0x20);
btc->btc_set_rf_reg(btc, BTC_RF_B, 0x1d, 0xfffff, 0x0);
}
}
void halbtc8822c_cfg_wlan_act_ips(struct btc_coexist *btc)
{}
void halbtc8822c_chip_setup(struct btc_coexist *btc, u8 type)
{
switch (type) {
case BTC_CSETUP_INIT_HW:
halbtc8822c_cfg_init(btc);
break;
case BTC_CSETUP_ANT_SWITCH:
halbtc8822c_cfg_ant_switch(btc);
break;
case BTC_CSETUP_GNT_FIX:
halbtc8822c_cfg_gnt_fix(btc);
break;
case BTC_CSETUP_GNT_DEBUG:
halbtc8822c_cfg_gnt_debug(btc);
break;
case BTC_CSETUP_RFE_TYPE:
halbtc8822c_cfg_rfe_type(btc);
break;
case BTC_CSETUP_COEXINFO_HW:
halbtc8822c_cfg_coexinfo_hw(btc);
break;
case BTC_CSETUP_WL_TX_POWER:
halbtc8822c_cfg_wl_tx_power(btc);
break;
case BTC_CSETUP_WL_RX_GAIN:
halbtc8822c_cfg_wl_rx_gain(btc);
break;
case BTC_CSETUP_WLAN_ACT_IPS:
halbtc8822c_cfg_wlan_act_ips(btc);
break;
}
}
#endif
================================================
FILE: hal/btc/halbtc8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
extern const struct btc_chip_para btc_chip_para_8822c;
void halbtc8822c_chip_setup(struct btc_coexist *btc, u8 type);
void halbtc8822c_cfg_init(struct btc_coexist *btc);
void halbtc8822c_cfg_ant_switch(struct btc_coexist *btc);
void halbtc8822c_cfg_gnt_debug(struct btc_coexist *btc);
void halbtc8822c_cfg_fre_type(struct btc_coexist *btc);
void halbtc8822c_cfg_coexinfo_hw(struct btc_coexist *btc);
void halbtc8822c_cfg_wl_tx_power(struct btc_coexist *btc);
void halbtc8822c_cfg_wl_rx_gain(struct btc_coexist *btc);
void halbtc8822c_cfg_wlan_act_ips(struct btc_coexist *btc);
================================================
FILE: hal/btc/halbtc8822cwifionly.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include "mp_precomp.h"
VOID
ex_hal8822c_wifi_only_hw_config(
IN struct wifi_only_cfg *pwifionlycfg
)
{
halwifionly_phy_set_bb_reg(pwifionlycfg, 0x70, 0xff000000, 0x0e);
/*gnt_wl=1 , gnt_bt=0*/
halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1704, 0xffffffff, 0x7700);
halwifionly_phy_set_bb_reg(pwifionlycfg, 0x1700, 0xffffffff, 0xc00f0038);
halwifionly_phy_set_bb_reg(pwifionlycfg, 0x6c0, 0xffffffff, 0xaaaaaaaa);
halwifionly_phy_set_bb_reg(pwifionlycfg, 0x6c4, 0xffffffff, 0xaaaaaaaa);
}
VOID
ex_hal8822c_wifi_only_scannotify(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
)
{
}
VOID
ex_hal8822c_wifi_only_switchbandnotify(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
)
{
}
VOID
ex_hal8822c_wifi_only_connectnotify(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
)
{
}
VOID
hal8822c_wifi_only_switch_antenna(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
)
{
}
================================================
FILE: hal/btc/halbtc8822cwifionly.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __INC_HAL8822CWIFIONLYHWCFG_H
#define __INC_HAL8822CWIFIONLYHWCFG_H
VOID
ex_hal8822c_wifi_only_hw_config(
IN struct wifi_only_cfg *pwifionlycfg
);
VOID
ex_hal8822c_wifi_only_scannotify(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
);
VOID
ex_hal8822c_wifi_only_switchbandnotify(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
);
VOID
ex_hal8822c_wifi_only_connectnotify(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
);
VOID
hal8822c_wifi_only_switch_antenna(
IN struct wifi_only_cfg *pwifionlycfg,
IN u1Byte is_5g
);
#endif
================================================
FILE: hal/btc/halbtccommon.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include "mp_precomp.h"
#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
static u8 *trace_buf = &gl_btc_trace_buf[0];
static const u32 coex_ver_date = 20190531;
static const u32 coex_ver = 0xe;
/* static const u32 bt_desired_ver = 0x9; */
static u8
rtw_btc_rssi_state(struct btc_coexist *btc, u8 *pre_state,
u8 rssi, u8 rssi_thresh)
{
const struct btc_chip_para *chip_para = btc->chip_para;
u8 next_state, tol = chip_para->rssi_tolerance;
if (*pre_state == BTC_RSSI_STATE_LOW ||
*pre_state == BTC_RSSI_STATE_STAY_LOW) {
if (rssi >= (rssi_thresh + tol))
next_state = BTC_RSSI_STATE_HIGH;
else
next_state = BTC_RSSI_STATE_STAY_LOW;
} else {
if (rssi < rssi_thresh)
next_state = BTC_RSSI_STATE_LOW;
else
next_state = BTC_RSSI_STATE_STAY_HIGH;
}
*pre_state = next_state;
return next_state;
}
static void
rtw_btc_limited_tx(struct btc_coexist *btc, boolean force_exec,
boolean tx_limit_en, boolean ampdu_limit_en)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
const struct btc_chip_para *chip_para = btc->chip_para;
boolean wl_b_mode = FALSE;
if (!chip_para->scbd_support)
return;
/* Force Max Tx retry limit = 8*/
if (!coex_sta->wl_tx_limit_en) {
coex_sta->wl_arfb1_backup = btc->btc_read_4byte(btc, 0x430);
coex_sta->wl_arfb2_backup = btc->btc_read_4byte(btc, 0x434);
coex_sta->wl_txlimit_backup = btc->btc_read_2byte(btc, 0x42a);
}
if (!coex_sta->wl_ampdu_limit_en)
coex_sta->wl_ampdulen_backup = btc->btc_read_1byte(btc, 0x455);
if (!force_exec && tx_limit_en == coex_sta->wl_tx_limit_en &&
ampdu_limit_en == coex_sta->wl_ampdu_limit_en)
return;
coex_sta->wl_tx_limit_en = tx_limit_en;
coex_sta->wl_ampdu_limit_en = ampdu_limit_en;
if (tx_limit_en) {
/* Set BT polluted packet on for Tx rate adaptive
* Set queue life time to avoid can't reach tx retry limit
* if tx is always break by GNT_BT.
*/
btc->btc_write_1byte_bitmask(btc, 0x45e, 0x8, 0x1);
/* queue life time can't on if 2-port */
if (link_info_ext->num_of_active_port <= 1)
btc->btc_write_1byte_bitmask(btc, 0x426, 0xf, 0xf);
/* Max Tx retry limit = 8*/
btc->btc_write_2byte(btc, 0x42a, 0x0808);
btc->btc_get(btc, BTC_GET_BL_WIFI_UNDER_B_MODE, &wl_b_mode);
/* Auto rate fallback step within 8 retry*/
if (wl_b_mode) {
btc->btc_write_4byte(btc, 0x430, 0x1000000);
btc->btc_write_4byte(btc, 0x434, 0x1010101);
} else {
btc->btc_write_4byte(btc, 0x430, 0x1000000);
btc->btc_write_4byte(btc, 0x434, 0x4030201);
}
} else {
/* Set BT polluted packet on for Tx rate adaptive not
*including Tx retry break by PTA, 0x45c[19] =1
*/
btc->btc_write_1byte_bitmask(btc, 0x45e, 0x8, 0x0);
/* Set queue life time to avoid can't reach tx retry limit
* if tx is always break by GNT_BT.
*/
btc->btc_write_1byte_bitmask(btc, 0x426, 0xf, 0x0);
/* Recovery Max Tx retry limit*/
btc->btc_write_2byte(btc, 0x42a, coex_sta->wl_txlimit_backup);
btc->btc_write_4byte(btc, 0x430, coex_sta->wl_arfb1_backup);
btc->btc_write_4byte(btc, 0x434, coex_sta->wl_arfb2_backup);
}
if (ampdu_limit_en)
btc->btc_write_1byte(btc, 0x455, 0x20);
else
btc->btc_write_1byte(btc, 0x455, coex_sta->wl_ampdulen_backup);
}
static void
rtw_btc_limited_rx(struct btc_coexist *btc, boolean force_exec,
boolean rej_ap_agg_pkt, boolean bt_ctrl_agg_buf_size,
u8 agg_buf_size)
{
#if 0
struct btc_coex_sta *coex_sta = &btc->coex_sta;
boolean reject_rx_agg = rej_ap_agg_pkt;
boolean bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size;
u8 rx_agg_size = agg_buf_size;
if (!force_exec &&
bt_ctrl_agg_buf_size == coex_sta->wl_rxagg_limit_en &&
agg_buf_size == coex_sta->wl_rxagg_size)
return;
coex_sta->wl_rxagg_limit_en = bt_ctrl_agg_buf_size;
coex_sta->wl_rxagg_size = agg_buf_size;
/*btc->btc_set(btc, BTC_SET_BL_TO_REJ_AP_AGG_PKT, &reject_rx_agg);*/
/* decide BT control aggregation buf size or not */
btc->btc_set(btc, BTC_SET_BL_BT_CTRL_AGG_SIZE, &bt_ctrl_rx_agg_size);
/* aggregation buf size, only work when BT control Rx aggregation size*/
btc->btc_set(btc, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size);
/* real update aggregation setting */
btc->btc_set(btc, BTC_SET_ACT_AGGREGATE_CTRL, NULL);
#endif
}
static void
rtw_btc_low_penalty_ra(struct btc_coexist *btc, boolean force_exec,
boolean low_penalty_ra, u8 thres)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
if (!force_exec) {
if (low_penalty_ra == coex_dm->cur_low_penalty_ra &&
thres == coex_sta->wl_ra_thres)
return;
}
if (low_penalty_ra)
btc->btc_phydm_modify_RA_PCR_threshold(btc, 0, thres);
else
btc->btc_phydm_modify_RA_PCR_threshold(btc, 0, 0);
coex_dm->cur_low_penalty_ra = low_penalty_ra;
coex_sta->wl_ra_thres = thres;
}
static void
rtw_btc_limited_wl(struct btc_coexist *btc)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
if (link_info_ext->is_all_under_5g ||
link_info_ext->num_of_active_port == 0 ||
coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE) {
rtw_btc_low_penalty_ra(btc, NM_EXCU, FALSE, 0);
rtw_btc_limited_tx(btc, NM_EXCU, FALSE, FALSE);
rtw_btc_limited_rx(btc, NM_EXCU, FALSE, TRUE, 64);
} else if (link_info_ext->num_of_active_port > 1) {
rtw_btc_low_penalty_ra(btc, NM_EXCU, TRUE, 30);
rtw_btc_limited_tx(btc, NM_EXCU, TRUE, TRUE);
rtw_btc_limited_rx(btc, NM_EXCU, FALSE, TRUE, 16);
} else {
if (link_info_ext->is_p2p_connected)
rtw_btc_low_penalty_ra(btc, NM_EXCU, TRUE, 30);
else
rtw_btc_low_penalty_ra(btc, NM_EXCU, TRUE, 15);
if (coex_sta->bt_hid_exist || coex_sta->bt_hid_pair_num > 0 ||
coex_sta->bt_hfp_exist) {
rtw_btc_limited_tx(btc, NM_EXCU, TRUE, TRUE);
rtw_btc_limited_rx(btc, NM_EXCU, FALSE, TRUE, 16);
} else {
rtw_btc_limited_tx(btc, NM_EXCU, TRUE, FALSE);
rtw_btc_limited_rx(btc, NM_EXCU, FALSE, TRUE, 64);
}
}
}
static void
rtw_btc_mailbox_operation(struct btc_coexist *btc, u8 h2c_id, u8 h2c_len,
u8 *h2c_para)
{
const struct btc_chip_para *chip_para = btc->chip_para;
u8 buf[6] = {0};
if (chip_para->mailbox_support) {
btc->btc_fill_h2c(btc, h2c_id, h2c_len, h2c_para);
return;
}
switch (h2c_id) {
case 0x61:
buf[0] = 3;
buf[1] = 0x1; /* polling enable, 1=enable, 0=disable */
buf[2] = 0x2; /* polling time in seconds */
buf[3] = 0x1; /* auto report enable, 1=enable, 0=disable */
btc->btc_set(btc, BTC_SET_ACT_CTRL_BT_INFO, (void *)&buf[0]);
break;
case 0x62:
buf[0] = 4;
buf[1] = 0x3; /* OP_Code */
buf[2] = 0x2; /* OP_Code_Length */
buf[3] = (h2c_para[0] != 0) ? 0x1 : 0x0; /* OP_Code_Content */
buf[4] = h2c_para[0];/* pwr_level */
btc->btc_set(btc, BTC_SET_ACT_CTRL_BT_COEX, (void *)&buf[0]);
break;
case 0x63:
buf[0] = 3;
buf[1] = 0x1; /* OP_Code */
buf[2] = 0x1; /* OP_Code_Length */
buf[3] = (h2c_para[0] == 0x1) ? 0x1 : 0x0; /* OP_Code_Content */
btc->btc_set(btc, BTC_SET_ACT_CTRL_BT_COEX, (void *)&buf[0]);
break;
case 0x66:
buf[0] = 5;
buf[1] = 0x5; /* OP_Code */
buf[2] = 0x3; /* OP_Code_Length */
buf[3] = h2c_para[0]; /* OP_Code_Content */
buf[4] = h2c_para[1];
buf[5] = h2c_para[2];
btc->btc_set(btc, BTC_SET_ACT_CTRL_BT_COEX, (void *)&buf[0]);
break;
}
}
static boolean
rtw_btc_freerun_check(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 bt_rssi;
if (btc->board_info.btdm_ant_num == 1)
return FALSE;
if (btc->board_info.ant_distance >= 40)
return TRUE;
if (btc->board_info.ant_distance <= 5)
return FALSE;
if (coex_sta->bt_hid_pair_num >= 2)
return TRUE;
if (!coex_sta->wl_gl_busy)
return FALSE;
/* ant_distance = 5 ~ 40 */
if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[1]) &&
BTC_RSSI_HIGH(coex_dm->bt_rssi_state[0]))
return TRUE;
if (link_info_ext->traffic_dir == BTC_WIFI_TRAFFIC_TX)
bt_rssi = coex_dm->bt_rssi_state[0];
else
bt_rssi = coex_dm->bt_rssi_state[1];
if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[3]) &&
BTC_RSSI_HIGH(bt_rssi) &&
coex_sta->cnt_wl[BTC_CNT_WL_SCANAP] <= 5)
return TRUE;
return FALSE;
}
static void
rtw_btc_wl_ccklock_action(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 h2c_parameter[2] = {0};
if (btc->manual_control || btc->stop_coex_dm)
return;
if (coex_sta->tdma_timer_base == 3) {
if (!coex_sta->is_no_wl_5ms_extend) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], set h2c 0x69 opcode 12 to turn off 5ms WL slot extend!!\n");
BTC_TRACE(trace_buf);
h2c_parameter[0] = 0xc;
h2c_parameter[1] = 0x1;
btc->btc_fill_h2c(btc, 0x69, 2, h2c_parameter);
coex_sta->is_no_wl_5ms_extend = TRUE;
coex_sta->cnt_wl[BTC_CNT_WL_5MS_NOEXTEND] = 0;
}
return;
}
if (!coex_sta->is_no_wl_5ms_extend && coex_sta->wl_force_lps_ctrl &&
!coex_sta->wl_cck_lock_ever) {
if (coex_sta->wl_fw_dbg_info[7] <= 5)
coex_sta->cnt_wl[BTC_CNT_WL_5MS_NOEXTEND]++;
else
coex_sta->cnt_wl[BTC_CNT_WL_5MS_NOEXTEND] = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], 5ms WL slot extend cnt = %d!!\n",
coex_sta->cnt_wl[BTC_CNT_WL_5MS_NOEXTEND]);
BTC_TRACE(trace_buf);
if (coex_sta->cnt_wl[BTC_CNT_WL_5MS_NOEXTEND] == 7) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], set h2c 0x69 opcode 12 to turn off 5ms WL slot extend!!\n");
BTC_TRACE(trace_buf);
h2c_parameter[0] = 0xc;
h2c_parameter[1] = 0x1;
btc->btc_fill_h2c(btc, 0x69, 2, h2c_parameter);
coex_sta->is_no_wl_5ms_extend = TRUE;
coex_sta->cnt_wl[BTC_CNT_WL_5MS_NOEXTEND] = 0;
}
} else if (coex_sta->is_no_wl_5ms_extend && coex_sta->wl_cck_lock) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], set h2c 0x69 opcode 12 to turn on 5ms WL slot extend!!\n");
BTC_TRACE(trace_buf);
h2c_parameter[0] = 0xc;
h2c_parameter[1] = 0x0;
btc->btc_fill_h2c(btc, 0x69, 2, h2c_parameter);
coex_sta->is_no_wl_5ms_extend = FALSE;
}
}
static void
rtw_btc_wl_ccklock_detect(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
boolean is_cck_lock_rate = FALSE;
if (coex_dm->bt_status == BTC_BTSTATUS_INQ_PAGE ||
coex_sta->bt_setup_link) {
coex_sta->wl_cck_lock = FALSE;
coex_sta->wl_cck_lock_pre = FALSE;
return;
}
if (coex_sta->wl_rx_rate <= BTC_CCK_2 ||
coex_sta->wl_rts_rx_rate <= BTC_CCK_2)
is_cck_lock_rate = TRUE;
if (link_info_ext->is_connected && coex_sta->wl_gl_busy &&
BTC_RSSI_HIGH(coex_dm->wl_rssi_state[3]) &&
(coex_dm->bt_status == BTC_BTSTATUS_ACL_BUSY ||
coex_dm->bt_status == BTC_BTSTATUS_ACL_SCO_BUSY ||
coex_dm->bt_status == BTC_BTSTATUS_SCO_BUSY)) {
if (is_cck_lock_rate) {
coex_sta->wl_cck_lock = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], cck locking...\n");
BTC_TRACE(trace_buf);
} else {
coex_sta->wl_cck_lock = FALSE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], cck unlock...\n");
BTC_TRACE(trace_buf);
}
} else {
coex_sta->wl_cck_lock = FALSE;
}
/* CCK lock identification */
if (coex_sta->wl_cck_lock && !coex_sta->wl_cck_lock_pre)
btc->btc_set_timer(btc, BTC_TIMER_WL_CCKLOCK, 3);
coex_sta->wl_cck_lock_pre = coex_sta->wl_cck_lock;
}
static void
rtw_btc_wl_noisy_detect(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u32 cnt_cck, ok_11b, err_11b;
ok_11b = btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_OK_CCK);
err_11b = btc->btc_phydm_query_PHY_counter(btc,
PHYDM_INFO_CRC32_ERROR_CCK);
/* WiFi environment noisy identification */
cnt_cck = ok_11b + err_11b;
if (!coex_sta->wl_gl_busy && !coex_sta->wl_cck_lock) {
if (cnt_cck > 250) {
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY2] < 5)
coex_sta->cnt_wl[BTC_CNT_WL_NOISY2]++;
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY2] == 5) {
coex_sta->cnt_wl[BTC_CNT_WL_NOISY0] = 0;
coex_sta->cnt_wl[BTC_CNT_WL_NOISY1] = 0;
}
} else if (cnt_cck < 100) {
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY0] < 5)
coex_sta->cnt_wl[BTC_CNT_WL_NOISY0]++;
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY0] == 5) {
coex_sta->cnt_wl[BTC_CNT_WL_NOISY1] = 0;
coex_sta->cnt_wl[BTC_CNT_WL_NOISY2] = 0;
}
} else {
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY1] < 5)
coex_sta->cnt_wl[BTC_CNT_WL_NOISY1]++;
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY1] == 5) {
coex_sta->cnt_wl[BTC_CNT_WL_NOISY0] = 0;
coex_sta->cnt_wl[BTC_CNT_WL_NOISY2] = 0;
}
}
if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY2] == 5)
coex_sta->wl_noisy_level = 2;
else if (coex_sta->cnt_wl[BTC_CNT_WL_NOISY1] == 5)
coex_sta->wl_noisy_level = 1;
else
coex_sta->wl_noisy_level = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], wl_noisy_level = %d\n",
coex_sta->wl_noisy_level);
BTC_TRACE(trace_buf);
}
}
static void
rtw_btc_set_extend_btautoslot(struct btc_coexist *btc, u8 thres)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 h2c_para[2] = {0x9, 0x32};
h2c_para[1] = thres; /* thres must be 50 ~ 80*/
coex_sta->bt_ext_autoslot_thres = h2c_para[1];
btc->btc_fill_h2c(btc, 0x69, 2, h2c_para);
}
static void
rtw_btc_set_tdma_timer_base(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u16 tbtt_interval = 100;
u8 h2c_para[2] = {0xb, 0x1};
btc->btc_get(btc, BTC_GET_U2_BEACON_PERIOD, &tbtt_interval);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], tbtt_interval = %d\n", tbtt_interval);
BTC_TRACE(trace_buf);
/* Add for JIRA coex-256 */
if (type == 3) { /* 4-slot */
if (coex_sta->tdma_timer_base == 3)
return;
h2c_para[1] = 0xc1; /* 4-slot */
coex_sta->tdma_timer_base = 3;
} else if (tbtt_interval < 80 && tbtt_interval > 0) {
if (coex_sta->tdma_timer_base == 2)
return;
h2c_para[1] = (100 / tbtt_interval);
if (100 % tbtt_interval != 0)
h2c_para[1] = h2c_para[1] + 1;
h2c_para[1] = h2c_para[1] & 0x3f;
coex_sta->tdma_timer_base = 2;
} else if (tbtt_interval >= 180) {
if (coex_sta->tdma_timer_base == 1)
return;
h2c_para[1] = (tbtt_interval / 100);
if (tbtt_interval % 100 <= 80)
h2c_para[1] = h2c_para[1] - 1;
h2c_para[1] = h2c_para[1] & 0x3f;
h2c_para[1] = h2c_para[1] | 0x80;
coex_sta->tdma_timer_base = 1;
} else {
if (coex_sta->tdma_timer_base == 0)
return;
h2c_para[1] = 0x1;
coex_sta->tdma_timer_base = 0;
}
btc->btc_fill_h2c(btc, 0x69, 2, h2c_para);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): h2c_0x69 = 0x%x\n", __func__, h2c_para[1]);
BTC_TRACE(trace_buf);
/* no 5ms_wl_slot_extend for 4-slot mode */
if (coex_sta->tdma_timer_base == 3)
rtw_btc_wl_ccklock_action(btc);
}
static void
rtw_btc_set_wl_pri_mask(struct btc_coexist *btc, u8 bitmap, u8 data)
{
u32 addr;
addr = 0x6cc + (bitmap / 8);
bitmap = bitmap % 8;
btc->btc_write_1byte_bitmask(btc, addr, BIT(bitmap), data);
}
static void
rtw_btc_set_bt_golden_rx_range(struct btc_coexist *btc, boolean force_exec,
u8 profile_id, u8 shift_level)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u16 para;
if (profile_id > 3)
return;
if (!force_exec &&
shift_level == coex_sta->bt_golden_rx_shift[profile_id])
return;
coex_sta->bt_golden_rx_shift[profile_id] = shift_level;
para = (profile_id << 8) | ((0x100 - shift_level) & 0xff);
btc->btc_set(btc, BTC_SET_BL_BT_GOLDEN_RX_RANGE, ¶);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): para = 0x%04x\n", __func__, para);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_query_bt_info(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 h2c_parameter[1] = {0x1};
if (coex_sta->bt_disabled)
return;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_mailbox_operation(btc, 0x61, 1, h2c_parameter);
}
static void
rtw_btc_gnt_debug(struct btc_coexist *btc, boolean isenable)
{
if (!isenable)
btc->btc_write_1byte_bitmask(btc, 0x73, 0x8, 0x0);
else
btc->chip_para->chip_setup(btc, BTC_CSETUP_GNT_DEBUG);
}
static void
rtw_btc_gnt_workaround(struct btc_coexist *btc, boolean force_exec, u8 mode)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (!force_exec) {
if (coex_sta->gnt_workaround_state == coex_sta->wl_coex_mode)
return;
}
coex_sta->gnt_workaround_state = coex_sta->wl_coex_mode;
btc->chip_para->chip_setup(btc, BTC_CSETUP_GNT_FIX);
}
static void
rtw_btc_monitor_bt_ctr(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u32 u32tmp;
u32tmp = btc->btc_read_4byte(btc, 0x770);
coex_sta->hi_pri_tx = u32tmp & MASKLWORD;
coex_sta->hi_pri_rx = (u32tmp & MASKHWORD) >> 16;
u32tmp = btc->btc_read_4byte(btc, 0x774);
coex_sta->lo_pri_tx = u32tmp & MASKLWORD;
coex_sta->lo_pri_rx = (u32tmp & MASKHWORD) >> 16;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Hi-Pri Rx/Tx: %d/%d, Lo-Pri Rx/Tx: %d/%d\n",
coex_sta->hi_pri_rx, coex_sta->hi_pri_tx,
coex_sta->lo_pri_rx, coex_sta->lo_pri_tx);
BTC_TRACE(trace_buf);
if (coex_sta->hi_pri_rx == 0 && coex_sta->hi_pri_tx == 0 &&
coex_sta->lo_pri_rx == 0 && coex_sta->lo_pri_tx == 0) {
coex_sta->cnt_bt[BTC_CNT_BT_DISABLE]++;
if (coex_sta->cnt_bt[BTC_CNT_BT_DISABLE] > 2)
coex_sta->cnt_bt[BTC_CNT_BT_DISABLE] = 2;
} else {
coex_sta->cnt_bt[BTC_CNT_BT_DISABLE] = 0;
}
/* reset counter */
btc->btc_write_1byte(btc, 0x76e, 0xc);
}
static void
rtw_btc_monitor_bt_enable(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
boolean bt_disabled = FALSE;
u16 u16tmp;
if (chip_para->scbd_support) {
btc->btc_read_scbd(btc, &u16tmp);
bt_disabled = (u16tmp & BTC_SCBD_BT_ONOFF) ? FALSE : TRUE;
} else {
if (coex_sta->cnt_bt[BTC_CNT_BT_DISABLE] >= 2)
bt_disabled = TRUE;
}
btc->btc_set(btc, BTC_SET_BL_BT_DISABLE, &bt_disabled);
if (coex_sta->bt_disabled != bt_disabled) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT is from %s to %s!!\n",
(coex_sta->bt_disabled ? "disabled" : "enabled"),
(bt_disabled ? "disabled" : "enabled"));
BTC_TRACE(trace_buf);
coex_sta->bt_disabled = bt_disabled;
coex_sta->bt_supported_feature = 0;
coex_sta->bt_supported_version = 0;
coex_sta->bt_ble_scan_type = 0;
coex_sta->bt_ble_scan_para[0] = 0;
coex_sta->bt_ble_scan_para[1] = 0;
coex_sta->bt_ble_scan_para[2] = 0;
coex_sta->bt_reg_vendor_ac = 0xffff;
coex_sta->bt_reg_vendor_ae = 0xffff;
coex_sta->bt_a2dp_vendor_id = 0;
coex_sta->bt_a2dp_device_name = 0;
coex_sta->bt_iqk_state = 0;
coex_dm->cur_bt_lna_lvl = 0;
btc->bt_info.bt_get_fw_ver = 0;
/*for win10 BT disable->enable trigger wifi scan issue */
if (!coex_sta->bt_disabled) {
coex_sta->bt_reenable = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_BT_REENABLE, 15);
} else {
coex_sta->bt_reenable = FALSE;
}
}
}
static void
rtw_btc_update_bt_sut_info(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u32 val = 0;
if (coex_sta->bt_profile_num == 0) {
/* clear golden rx range if no PAN exist */
if (coex_sta->bt_golden_rx_shift[3] != 0)
rtw_btc_set_bt_golden_rx_range(btc, FC_EXCU, 3, 0);
return;
}
if (coex_sta->bt_a2dp_exist) {
if (coex_sta->bt_a2dp_vendor_id == 0 &&
coex_sta->bt_a2dp_device_name == 0) {
btc->btc_get(btc, BTC_GET_U4_BT_DEVICE_INFO, &val);
coex_sta->bt_a2dp_vendor_id = (u8)(val & 0xff);
coex_sta->bt_a2dp_device_name = (val & 0xffffff00) >> 8;
}
rtw_btc_set_bt_golden_rx_range(btc, FC_EXCU, 2, 0);
} else {
coex_sta->bt_sut_pwr_lvl[2] = 0xff;
}
if (coex_sta->bt_hfp_exist)
rtw_btc_set_bt_golden_rx_range(btc, FC_EXCU, 0, 0);
else
coex_sta->bt_sut_pwr_lvl[0] = 0xff;
if (coex_sta->bt_hid_exist)
rtw_btc_set_bt_golden_rx_range(btc, FC_EXCU, 1, 0);
else
coex_sta->bt_sut_pwr_lvl[1] = 0xff;
if (coex_sta->bt_pan_exist) {
rtw_btc_set_bt_golden_rx_range(btc, FC_EXCU, 3,
coex_sta->bt_golden_rx_shift[3]);
} else {
coex_sta->bt_golden_rx_shift[3] = 0;
coex_sta->bt_sut_pwr_lvl[3] = 0xff;
}
}
static void
rtw_btc_update_wl_link_info(struct btc_coexist *btc, u8 reason)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *linfo_ext = &btc->wifi_link_info_ext;
struct btc_wifi_link_info linfo;
const struct btc_chip_para *chip_para = btc->chip_para;
u8 wifi_central_chnl = 0, num_of_wifi_link = 0, i;
u32 wifi_link_status = 0, wifi_bw;
s32 wl_rssi;
boolean isunder5G = FALSE, ismcc25g = FALSE, is_p2p_connected = FALSE,
plus_bt = FALSE;
btc->btc_get(btc, BTC_GET_BL_WIFI_SCAN, &linfo_ext->is_scan);
btc->btc_get(btc, BTC_GET_BL_WIFI_LINK, &linfo_ext->is_link);
btc->btc_get(btc, BTC_GET_BL_WIFI_ROAM, &linfo_ext->is_roam);
btc->btc_get(btc, BTC_GET_BL_WIFI_LW_PWR_STATE, &linfo_ext->is_32k);
btc->btc_get(btc, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &linfo_ext->is_4way);
btc->btc_get(btc, BTC_GET_BL_WIFI_CONNECTED, &linfo_ext->is_connected);
btc->btc_get(btc, BTC_GET_U4_WIFI_TRAFFIC_DIR, &linfo_ext->traffic_dir);
btc->btc_get(btc, BTC_GET_U4_WIFI_BW, &linfo_ext->wifi_bw);
btc->btc_get(btc, BTC_GET_U4_WIFI_LINK_STATUS, &wifi_link_status);
linfo_ext->port_connect_status = wifi_link_status & 0xffff;
btc->btc_get(btc, BTC_GET_BL_WIFI_LINK_INFO, &linfo);
btc->wifi_link_info = linfo;
btc->btc_get(btc, BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifi_central_chnl);
coex_sta->wl_center_ch = wifi_central_chnl;
btc->btc_get(btc, BTC_GET_S4_WIFI_RSSI, &wl_rssi);
for (i = 0; i < 4; i++)
rtw_btc_rssi_state(btc, &coex_dm->wl_rssi_state[i],
(u8)(wl_rssi & 0xff),
chip_para->wl_rssi_step[i]);
/* Check scan/connect/special-pkt action first */
switch (reason) {
case BTC_RSN_5GSCANSTART:
case BTC_RSN_5GSWITCHBAND:
case BTC_RSN_5GCONSTART:
isunder5G = TRUE;
break;
case BTC_RSN_2GSCANSTART:
case BTC_RSN_2GSWITCHBAND:
case BTC_RSN_2GCONSTART:
isunder5G = FALSE;
break;
case BTC_RSN_2GCONFINISH:
case BTC_RSN_5GCONFINISH:
case BTC_RSN_2GMEDIA:
case BTC_RSN_5GMEDIA:
case BTC_RSN_BTINFO:
case BTC_RSN_PERIODICAL:
case BTC_RSN_TIMERUP:
case BTC_RSN_WLSTATUS:
case BTC_RSN_2GSPECIALPKT:
case BTC_RSN_5GSPECIALPKT:
default:
switch (linfo.link_mode) {
case BTC_LINK_5G_MCC_GO_STA:
case BTC_LINK_5G_MCC_GC_STA:
case BTC_LINK_5G_SCC_GO_STA:
case BTC_LINK_5G_SCC_GC_STA:
isunder5G = TRUE;
break;
case BTC_LINK_2G_MCC_GO_STA:
case BTC_LINK_2G_MCC_GC_STA:
case BTC_LINK_2G_SCC_GO_STA:
case BTC_LINK_2G_SCC_GC_STA:
isunder5G = FALSE;
break;
case BTC_LINK_25G_MCC_GO_STA:
case BTC_LINK_25G_MCC_GC_STA:
isunder5G = FALSE;
ismcc25g = TRUE;
break;
case BTC_LINK_ONLY_STA:
if (linfo.sta_center_channel > 14)
isunder5G = TRUE;
else
isunder5G = FALSE;
break;
case BTC_LINK_ONLY_GO:
case BTC_LINK_ONLY_GC:
case BTC_LINK_ONLY_AP:
default:
if (linfo.p2p_center_channel > 14)
isunder5G = TRUE;
else
isunder5G = FALSE;
break;
}
break;
}
linfo_ext->is_all_under_5g = isunder5G;
linfo_ext->is_mcc_25g = ismcc25g;
if (wifi_link_status & WIFI_STA_CONNECTED)
num_of_wifi_link++;
if (wifi_link_status & WIFI_AP_CONNECTED)
num_of_wifi_link++;
if (wifi_link_status & WIFI_P2P_GO_CONNECTED) {
if (!(wifi_link_status & WIFI_AP_CONNECTED))
num_of_wifi_link++;
is_p2p_connected = TRUE;
}
if (wifi_link_status & WIFI_P2P_GC_CONNECTED) {
num_of_wifi_link++;
is_p2p_connected = TRUE;
}
linfo_ext->num_of_active_port = num_of_wifi_link;
linfo_ext->is_p2p_connected = is_p2p_connected;
if (linfo.link_mode == BTC_LINK_ONLY_GO && linfo.bhotspot)
linfo_ext->is_ap_mode = TRUE;
else
linfo_ext->is_ap_mode = FALSE;
if (linfo_ext->is_p2p_connected && coex_sta->bt_link_exist)
plus_bt = TRUE;
btc->btc_set(btc, BTC_SET_BL_MIRACAST_PLUS_BT, &plus_bt);
if (linfo_ext->is_scan || linfo_ext->is_link ||
linfo_ext->is_roam || linfo_ext->is_4way ||
reason == BTC_RSN_2GSCANSTART ||
reason == BTC_RSN_2GSWITCHBAND ||
reason == BTC_RSN_2GCONSTART ||
reason == BTC_RSN_2GSPECIALPKT)
coex_sta->wl_linkscan_proc = TRUE;
else
coex_sta->wl_linkscan_proc = FALSE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], scan = %d, link = %d, roam = %d 4way = %d!!!\n",
linfo_ext->is_scan, linfo_ext->is_link,
linfo_ext->is_roam,
linfo_ext->is_4way);
BTC_TRACE(trace_buf);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], wifi_link_info: link_mode=%d, STA_Ch=%d, P2P_Ch=%d, AnyClient_Join_Go=%d !\n",
linfo.link_mode,
linfo.sta_center_channel,
linfo.p2p_center_channel,
linfo.bany_client_join_go);
BTC_TRACE(trace_buf);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], wifi_link_info: center_ch=%d, is_all_under_5g=%d, is_mcc_25g=%d!\n",
coex_sta->wl_center_ch,
linfo_ext->is_all_under_5g,
linfo_ext->is_mcc_25g);
BTC_TRACE(trace_buf);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], wifi_link_info: port_connect_status=0x%x, active_port_cnt=%d, P2P_Connect=%d!\n",
linfo_ext->port_connect_status,
linfo_ext->num_of_active_port,
linfo_ext->is_p2p_connected);
BTC_TRACE(trace_buf);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Update reason = %s\n",
run_reason_string[reason]);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_update_bt_link_info(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
boolean bt_busy = FALSE, increase_scan_dev_num = FALSE,
scan_type_change = FALSE;
u8 i, scan_type;
/* update wl/bt rssi by btinfo */
for (i = 0; i < 4; i++)
rtw_btc_rssi_state(btc, &coex_dm->bt_rssi_state[i],
coex_sta->bt_rssi,
chip_para->bt_rssi_step[i]);
if (coex_sta->bt_ble_scan_en) {
scan_type = btc->btc_get_ble_scan_type_from_bt(btc);
if (scan_type != coex_sta->bt_ble_scan_type)
scan_type_change = TRUE;
coex_sta->bt_ble_scan_type = scan_type;
}
if (scan_type_change) {
u32 *p = NULL;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BTinfo HiByte1[5] check, query BLE Scan type!!\n");
BTC_TRACE(trace_buf);
if ((coex_sta->bt_ble_scan_type & 0x1) == 0x1) {
coex_sta->bt_init_scan = TRUE;
p = &coex_sta->bt_ble_scan_para[0];
*p = btc->btc_get_ble_scan_para_from_bt(btc, 0x1);
} else {
coex_sta->bt_init_scan = FALSE;
}
if ((coex_sta->bt_ble_scan_type & 0x2) == 0x2) {
p = &coex_sta->bt_ble_scan_para[1];
*p = btc->btc_get_ble_scan_para_from_bt(btc, 0x2);
}
if ((coex_sta->bt_ble_scan_type & 0x4) == 0x4) {
p = &coex_sta->bt_ble_scan_para[2];
*p = btc->btc_get_ble_scan_para_from_bt(btc, 0x4);
}
}
coex_sta->bt_profile_num = 0;
/* set link exist status */
if (!(coex_sta->bt_info_lb2 & BTC_INFO_CONNECTION)) {
coex_sta->bt_link_exist = FALSE;
coex_sta->bt_pan_exist = FALSE;
coex_sta->bt_a2dp_exist = FALSE;
coex_sta->bt_hid_exist = FALSE;
coex_sta->bt_hfp_exist = FALSE;
coex_sta->bt_msft_mr_exist = FALSE;
} else { /* connection exists */
coex_sta->bt_link_exist = TRUE;
if (coex_sta->bt_info_lb2 & BTC_INFO_FTP) {
coex_sta->bt_pan_exist = TRUE;
coex_sta->bt_profile_num++;
} else {
coex_sta->bt_pan_exist = FALSE;
}
if (coex_sta->bt_info_lb2 & BTC_INFO_A2DP) {
coex_sta->bt_a2dp_exist = TRUE;
coex_sta->bt_profile_num++;
} else {
coex_sta->bt_a2dp_exist = FALSE;
}
if (coex_sta->bt_info_lb2 & BTC_INFO_HID) {
coex_sta->bt_hid_exist = TRUE;
coex_sta->bt_profile_num++;
} else {
coex_sta->bt_hid_exist = FALSE;
}
if (coex_sta->bt_info_lb2 & BTC_INFO_SCO_ESCO) {
coex_sta->bt_hfp_exist = TRUE;
coex_sta->bt_profile_num++;
} else {
coex_sta->bt_hfp_exist = FALSE;
}
if (coex_sta->bt_hid_slot == 0 &&
coex_sta->bt_hid_pair_num > 0 &&
coex_sta->lo_pri_tx > 1000 &&
coex_sta->lo_pri_rx > 1000 &&
!coex_sta->bt_inq_page)
coex_sta->bt_msft_mr_exist = TRUE;
else
coex_sta->bt_msft_mr_exist = FALSE;
}
if (coex_sta->bt_info_lb2 & BTC_INFO_INQ_PAGE) {
coex_dm->bt_status = BTC_BTSTATUS_INQ_PAGE;
} else if (!(coex_sta->bt_info_lb2 & BTC_INFO_CONNECTION)) {
coex_dm->bt_status = BTC_BTSTATUS_NCON_IDLE;
} else if (coex_sta->bt_info_lb2 == BTC_INFO_CONNECTION) {
if (coex_sta->bt_msft_mr_exist)
coex_dm->bt_status = BTC_BTSTATUS_ACL_BUSY;
else
coex_dm->bt_status = BTC_BTSTATUS_CON_IDLE;
} else if ((coex_sta->bt_info_lb2 & BTC_INFO_SCO_ESCO) ||
(coex_sta->bt_info_lb2 & BTC_INFO_SCO_BUSY)) {
if (coex_sta->bt_info_lb2 & BTC_INFO_ACL_BUSY)
coex_dm->bt_status = BTC_BTSTATUS_ACL_SCO_BUSY;
else
coex_dm->bt_status = BTC_BTSTATUS_SCO_BUSY;
} else if (coex_sta->bt_info_lb2 & BTC_INFO_ACL_BUSY) {
coex_dm->bt_status = BTC_BTSTATUS_ACL_BUSY;
} else {
coex_dm->bt_status = BTC_BTSTATUS_MAX;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s(), %s!!!\n",
__func__, bt_status_string[coex_dm->bt_status]);
BTC_TRACE(trace_buf);
if (coex_dm->bt_status == BTC_BTSTATUS_ACL_BUSY ||
coex_dm->bt_status == BTC_BTSTATUS_SCO_BUSY ||
coex_dm->bt_status == BTC_BTSTATUS_ACL_SCO_BUSY) {
bt_busy = TRUE;
increase_scan_dev_num = TRUE;
} else {
bt_busy = FALSE;
increase_scan_dev_num = FALSE;
}
btc->btc_set(btc, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy);
btc->btc_set(btc, BTC_SET_BL_INC_SCAN_DEV_NUM, &increase_scan_dev_num);
if (coex_sta->bt_profile_num != coex_sta->bt_profile_num_pre) {
rtw_btc_update_bt_sut_info(btc);
coex_sta->bt_profile_num_pre = coex_sta->bt_profile_num;
}
coex_sta->cnt_bt[BTC_CNT_BT_INFOUPDATE]++;
}
static void
rtw_btc_update_wl_ch_info(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
struct btc_wifi_link_info *link_info = &btc->wifi_link_info;
u8 h2c_para[3] = {0}, i, wl_center_ch = 0;
if (btc->manual_control)
return;
if (btc->stop_coex_dm || btc->wl_rf_state_off) {
wl_center_ch = 0;
} else if (type != BTC_MEDIA_DISCONNECT ||
(type == BTC_MEDIA_DISCONNECT &&
link_info_ext->num_of_active_port > 0)) {
if (link_info_ext->num_of_active_port == 1) {
if (link_info_ext->is_p2p_connected)
wl_center_ch = link_info->p2p_center_channel;
else
wl_center_ch = link_info->sta_center_channel;
} else { /* port > 2 */
if (link_info->p2p_center_channel > 14 &&
link_info->sta_center_channel > 14)
wl_center_ch = link_info->p2p_center_channel;
else if (link_info->p2p_center_channel <= 14)
wl_center_ch = link_info->p2p_center_channel;
else if (link_info->sta_center_channel <= 14)
wl_center_ch = link_info->sta_center_channel;
}
}
if (wl_center_ch == 0 ||
(btc->board_info.btdm_ant_num == 1 && wl_center_ch <= 14)) {
h2c_para[0] = 0;
h2c_para[1] = 0;
h2c_para[2] = 0;
} else if (wl_center_ch <= 14) {
h2c_para[0] = 0x1;
h2c_para[1] = wl_center_ch;
if (link_info_ext->wifi_bw == BTC_WIFI_BW_HT40)
h2c_para[2] = chip_para->bt_afh_span_bw40;
else
h2c_para[2] = chip_para->bt_afh_span_bw20;
} else if (chip_para->afh_5g_num > 1) { /* for 5G */
for (i = 0; i < chip_para->afh_5g_num; i++) {
if (wl_center_ch == chip_para->afh_5g[i].wl_5g_ch) {
h2c_para[0] = 0x3;
h2c_para[1] = chip_para->afh_5g[i].bt_skip_ch;
h2c_para[2] = chip_para->afh_5g[i].bt_skip_span;
break;
}
}
}
coex_dm->wl_chnl_info[0] = h2c_para[0];
coex_dm->wl_chnl_info[1] = h2c_para[1];
coex_dm->wl_chnl_info[2] = h2c_para[2];
rtw_btc_mailbox_operation(btc, 0x66, 3, h2c_para);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s: para[0:2] = 0x%x 0x%x 0x%x\n",
__func__, h2c_para[0], h2c_para[1], h2c_para[2]);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_set_wl_tx_power(struct btc_coexist *btc,
boolean force_exec, u8 wl_pwr_dec_lvl)
{
const struct btc_chip_para *chip_para = btc->chip_para;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
u8 i, pwr;
u32 reg_addr;
if (!force_exec && wl_pwr_dec_lvl == coex_dm->cur_wl_pwr_lvl)
return;
coex_dm->cur_wl_pwr_lvl = wl_pwr_dec_lvl;
chip_para->chip_setup(btc, BTC_CSETUP_WL_TX_POWER);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s(): level = %d\n",
__func__, wl_pwr_dec_lvl);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_set_bt_tx_power(struct btc_coexist *btc,
boolean force_exec, u8 bt_pwr_dec_lvl)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
u8 h2c_para[1] = {0};
if (!force_exec && bt_pwr_dec_lvl == coex_dm->cur_bt_pwr_lvl)
return;
h2c_para[0] = (0x100 - bt_pwr_dec_lvl) & 0xff;
rtw_btc_mailbox_operation(btc, 0x62, 1, h2c_para);
coex_dm->cur_bt_pwr_lvl = bt_pwr_dec_lvl;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(), bt_tx_power = 0x%x, level = %d\n",
__func__, h2c_para[0], bt_pwr_dec_lvl);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_set_wl_rx_gain(struct btc_coexist *btc, boolean force_exec,
boolean low_gain_en)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
if (!force_exec && low_gain_en == coex_dm->cur_wl_rx_low_gain_en)
return;
coex_dm->cur_wl_rx_low_gain_en = low_gain_en;
if (low_gain_en)
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Hi-L Rx!\n");
else
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], Nm-L Rx!\n");
BTC_TRACE(trace_buf);
chip_para->chip_setup(btc, BTC_CSETUP_WL_RX_GAIN);
}
static void
rtw_btc_set_bt_rx_gain(struct btc_coexist *btc, boolean force_exec, u8 lna_lvl)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
if (!force_exec && lna_lvl == coex_dm->cur_bt_lna_lvl)
return;
if (lna_lvl < 7) {
btc->btc_set(btc, BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL, &lna_lvl);
/* use scoreboard[4] to notify BT Rx gain table change */
btc->btc_write_scbd(btc, BTC_SCBD_RXGAIN, TRUE);
} else {
btc->btc_write_scbd(btc, BTC_SCBD_RXGAIN, FALSE);
}
coex_dm->cur_bt_lna_lvl = lna_lvl;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): bt_rx_LNA_level = %d\n",
__func__, lna_lvl);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_set_rf_para(struct btc_coexist *btc, boolean force_exec,
struct btc_rf_para para)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 tmp = 0;
if (coex_sta->coex_freerun) {
if (coex_sta->cnt_wl[BTC_CNT_WL_SCANAP] <= 5)
tmp = 3;
}
rtw_btc_set_wl_tx_power(btc, force_exec, para.wl_pwr_dec_lvl);
rtw_btc_set_bt_tx_power(btc, force_exec, para.bt_pwr_dec_lvl + tmp);
rtw_btc_set_wl_rx_gain(btc, force_exec, para.wl_low_gain_en);
rtw_btc_set_bt_rx_gain(btc, force_exec, para.bt_lna_lvl);
}
static void
rtw_btc_coex_ctrl_owner(struct btc_coexist *btc, boolean wifi_control)
{
u8 val;
val = (wifi_control) ? 1 : 0;
btc->btc_write_1byte_bitmask(btc, 0x73, BIT(2), val); /* 0x70[26] */
if (!wifi_control)
btc->chip_para->chip_setup(btc, BTC_CSETUP_WLAN_ACT_IPS);
}
static void
rtw_btc_set_gnt_bt(struct btc_coexist *btc, u8 state)
{
switch (state) {
case BTC_GNT_SW_LOW:
btc->btc_write_linderct(btc, 0x38, 0xc000, 0x1);
btc->btc_write_linderct(btc, 0x38, 0x0c00, 0x1);
break;
case BTC_GNT_SW_HIGH:
btc->btc_write_linderct(btc, 0x38, 0xc000, 0x3);
btc->btc_write_linderct(btc, 0x38, 0x0c00, 0x3);
break;
case BTC_GNT_HW_PTA:
default:
btc->btc_write_linderct(btc, 0x38, 0xc000, 0x0);
btc->btc_write_linderct(btc, 0x38, 0x0c00, 0x0);
break;
}
}
static void
rtw_btc_set_gnt_wl(struct btc_coexist *btc, u8 state)
{
switch (state) {
case BTC_GNT_SW_LOW:
btc->btc_write_linderct(btc, 0x38, 0x3000, 0x1);
btc->btc_write_linderct(btc, 0x38, 0x0300, 0x1);
break;
case BTC_GNT_SW_HIGH:
btc->btc_write_linderct(btc, 0x38, 0x3000, 0x3);
btc->btc_write_linderct(btc, 0x38, 0x0300, 0x3);
break;
case BTC_GNT_HW_PTA:
default:
btc->btc_write_linderct(btc, 0x38, 0x3000, 0x0);
btc->btc_write_linderct(btc, 0x38, 0x0300, 0x0);
break;
}
}
static void
rtw_btc_mimo_ps(struct btc_coexist *btc, boolean force_exec,
u8 state)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (!force_exec && state == coex_sta->wl_mimo_ps)
return;
coex_sta->wl_mimo_ps = state;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): state = %d\n", __func__, state);
BTC_TRACE(trace_buf);
btc->btc_set(btc, BTC_SET_MIMO_PS_MODE, &state);
}
static void
rtw_btc_wltoggle_tableA(IN struct btc_coexist *btc,
IN boolean force_exec, IN u32 table_case)
{
const struct btc_chip_para *chip_para = btc->chip_para;
u8 h2c_para[6] = {0};
u32 table_wl = 0x5a5a5a5a;
h2c_para[0] = 0xd; /* op_code, 0x7= wlan slot toggle-A*/
h2c_para[1] = 0x1; /* no definition */
if (btc->board_info.btdm_ant_num == 1) {
if (table_case < chip_para->table_sant_num)
table_wl = chip_para->table_sant[table_case].wl;
} else {
if (table_case < chip_para->table_nsant_num)
table_wl = chip_para->table_nsant[table_case].wl;
}
/* tell WL FW WL slot toggle table-A*/
h2c_para[2] = (u8)(table_wl & 0xff);
h2c_para[3] = (u8)((table_wl & 0xff00) >> 8);
h2c_para[4] = (u8)((table_wl & 0xff0000) >> 16);
h2c_para[5] = (u8)((table_wl & 0xff000000) >> 24);
btc->btc_fill_h2c(btc, 0x69, 6, h2c_para);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): H2C = [%02x %02x %02x %02x %02x %02x]\n",
__func__, h2c_para[0], h2c_para[1], h2c_para[2],
h2c_para[3], h2c_para[4], h2c_para[5]);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_wltoggle_tableB(IN struct btc_coexist *btc, IN boolean force_exec,
IN u8 interval, IN u32 table)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 cur_h2c_para[6] = {0};
u8 i, match_cnt = 0;
cur_h2c_para[0] = 0x7; /* op_code, 0x7= wlan slot toggle-B*/
cur_h2c_para[1] = interval;
cur_h2c_para[2] = (u8)(table & 0xff);
cur_h2c_para[3] = (u8)((table & 0xff00) >> 8);
cur_h2c_para[4] = (u8)((table & 0xff0000) >> 16);
cur_h2c_para[5] = (u8)((table & 0xff000000) >> 24);
if (ARRAY_SIZE(coex_sta->wl_toggle_para) != 6)
return;
for (i = 0; i <= 5; i++)
coex_sta->wl_toggle_para[i] = cur_h2c_para[i];
btc->btc_fill_h2c(btc, 0x69, 6, cur_h2c_para);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): H2C = [%02x %02x %02x %02x %02x %02x]\n",
__func__, cur_h2c_para[0], cur_h2c_para[1], cur_h2c_para[2],
cur_h2c_para[3], cur_h2c_para[4], cur_h2c_para[5]);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_set_table(struct btc_coexist *btc, boolean force_exec, u32 val0x6c0,
u32 val0x6c4)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
/* If last tdma is wl slot toggle, force write table*/
if (!force_exec && coex_sta->coex_run_reason != BTC_RSN_LPS) {
if (val0x6c0 == coex_dm->cur_val0x6c0 &&
val0x6c4 == coex_dm->cur_val0x6c4)
return;
}
btc->btc_write_4byte(btc, 0x6c0, val0x6c0);
btc->btc_write_4byte(btc, 0x6c4, val0x6c4);
btc->btc_write_4byte(btc, 0x6c8, 0xf0ffffff);
coex_dm->cur_val0x6c0 = btc->btc_read_4byte(btc, 0x6c0);
coex_dm->cur_val0x6c4 = btc->btc_read_4byte(btc, 0x6c4);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 0x6c0 = %x, 0x6c4 = %x\n",
__func__, val0x6c0, val0x6c4);
BTC_TRACE(trace_buf);
}
static void
rtw_btc_table(struct btc_coexist *btc, boolean force_exec, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
const struct btc_chip_para *chip_para = btc->chip_para;
u8 h2c_para[6] = {0};
u32 table_wl = 0x0;
coex_sta->coex_table_type = type;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], ***** Coex_Table - %d *****\n", type);
BTC_TRACE(trace_buf);
h2c_para[0] = 0xd;
h2c_para[1] = 0x1;
if (btc->board_info.btdm_ant_num == 1) {
if (type < chip_para->table_sant_num)
rtw_btc_set_table(btc, force_exec,
chip_para->table_sant[type].bt,
chip_para->table_sant[type].wl);
} else {
type = type - 100;
if (type < chip_para->table_nsant_num)
rtw_btc_set_table(btc, force_exec,
chip_para->table_nsant[type].bt,
chip_para->table_nsant[type].wl);
}
if (coex_sta->wl_slot_toggle_change)
rtw_btc_wltoggle_tableA(btc, FC_EXCU, type);
}
static void
rtw_btc_ignore_wlan_act(struct btc_coexist *btc, boolean force_exec,
boolean enable)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
u8 h2c_para[1] = {0};
if (btc->manual_control || btc->stop_coex_dm)
return;
if (!force_exec && enable == coex_dm->cur_ignore_wlan_act)
return;
if (enable)
h2c_para[0] = 0x1; /* function enable */
rtw_btc_mailbox_operation(btc, 0x63, 1, h2c_para);
coex_dm->cur_ignore_wlan_act = enable;
}
static void
rtw_btc_lps_rpwm(struct btc_coexist *btc, boolean force_exec, u8 lps_val,
u8 rpwm_val)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
if (!force_exec) {
if (lps_val == coex_dm->cur_lps &&
rpwm_val == coex_dm->cur_rpwm)
return;
}
btc->btc_set(btc, BTC_SET_U1_LPS_VAL, &lps_val);
btc->btc_set(btc, BTC_SET_U1_RPWM_VAL, &rpwm_val);
coex_dm->cur_lps = lps_val;
coex_dm->cur_rpwm = rpwm_val;
}
static boolean
rtw_btc_power_save_state(struct btc_coexist *btc, u8 ps_type, u8 lps_val,
u8 rpwm_val)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
boolean low_pwr_dis = FALSE, result = TRUE;
u8 lps_mode = 0x0;
u8 h2c_para[5] = {0, 0, 0, 0, 0};
btc->btc_get(btc, BTC_GET_U1_LPS_MODE, &lps_mode);
switch (ps_type) {
case BTC_PS_WIFI_NATIVE:
/* recover to original 32k low power setting */
coex_sta->wl_force_lps_ctrl = FALSE;
btc->btc_set(btc, BTC_SET_ACT_PRE_NORMAL_LPS, NULL);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BTC_PS_WIFI_NATIVE\n", __func__);
break;
case BTC_PS_LPS_ON:
coex_sta->wl_force_lps_ctrl = TRUE;
/*set tdma off if LPS off */
if (!lps_mode)
btc->btc_fill_h2c(btc, 0x60, 5, h2c_para);
rtw_btc_lps_rpwm(btc, NM_EXCU, lps_val, rpwm_val);
/* when coex force to enter LPS, do not enter 32k low power. */
low_pwr_dis = TRUE;
btc->btc_set(btc, BTC_SET_ACT_DISABLE_LOW_POWER, &low_pwr_dis);
/* power save must executed before psTdma. */
btc->btc_set(btc, BTC_SET_ACT_ENTER_LPS, NULL);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BTC_PS_LPS_ON\n", __func__);
break;
case BTC_PS_LPS_OFF:
coex_sta->wl_force_lps_ctrl = TRUE;
/*set tdma off if LPS on */
if (lps_mode)
btc->btc_fill_h2c(btc, 0x60, 5, h2c_para);
result = btc->btc_set(btc, BTC_SET_ACT_LEAVE_LPS, NULL);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BTC_PS_LPS_OFF\n", __func__);
break;
default:
break;
}
BTC_TRACE(trace_buf);
return result;
}
static void
rtw_btc_set_tdma(struct btc_coexist *btc, u8 byte1, u8 byte2, u8 byte3,
u8 byte4, u8 byte5)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *linfo_ext = &btc->wifi_link_info_ext;
u8 ps_type = BTC_PS_WIFI_NATIVE,
real_byte1 = byte1, real_byte5 = byte5;
boolean result = FALSE;
if (byte5 & BIT(2))
coex_sta->tdma_bt_autoslot = TRUE;
else
coex_sta->tdma_bt_autoslot = FALSE;
if (linfo_ext->is_ap_mode && (byte1 & BIT(4) && !(byte1 & BIT(5)))) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): AP mode\n", __func__);
BTC_TRACE(trace_buf);
real_byte1 &= ~BIT(4);
real_byte1 |= BIT(5);
real_byte5 |= BIT(5);
real_byte5 &= ~BIT(6);
ps_type = BTC_PS_WIFI_NATIVE;
rtw_btc_power_save_state(btc, ps_type, 0x0, 0x0);
} else if (byte1 & BIT(4) && !(byte1 & BIT(5))) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Force LPS (byte1 = 0x%x)\n",
__func__, byte1);
BTC_TRACE(trace_buf);
if (btc->chip_para->pstdma_type == BTC_PSTDMA_FORCE_LPSOFF)
ps_type = BTC_PS_LPS_OFF;
else
ps_type = BTC_PS_LPS_ON;
if (!rtw_btc_power_save_state(btc, ps_type, 0x50, 0x4))
result = TRUE;
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): native power save (byte1 = 0x%x)\n",
__func__, byte1);
BTC_TRACE(trace_buf);
ps_type = BTC_PS_WIFI_NATIVE;
rtw_btc_power_save_state(btc, ps_type, 0x0, 0x0);
}
coex_sta->wl_ps_state_fail = result;
if (coex_sta->wl_ps_state_fail) {
coex_sta->cnt_wl[BTC_CNT_WL_PSFAIL]++;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Force Leave LPS Fail (cnt = %d)\n",
__func__, coex_sta->cnt_wl[BTC_CNT_WL_PSFAIL]);
BTC_TRACE(trace_buf);
return;
}
coex_dm->ps_tdma_para[0] = real_byte1;
coex_dm->ps_tdma_para[1] = byte2;
coex_dm->ps_tdma_para[2] = byte3;
coex_dm->ps_tdma_para[3] = byte4;
coex_dm->ps_tdma_para[4] = real_byte5;
btc->btc_fill_h2c(btc, 0x60, 5, coex_dm->ps_tdma_para);
/* Always forec excute rtw_btc_set_table To avoid
* coex table error if wl slot toggle mode on ->off
* ex: 5508031054 next state -> rtw_btc_table + 5108031054
* rtw_btc_table may be changed by 5508031054
*/
if (real_byte1 & BIT(2)) {
coex_sta->wl_slot_toggle = TRUE;
coex_sta->wl_slot_toggle_change = FALSE;
} else {
coex_sta->wl_slot_toggle_change = coex_sta->wl_slot_toggle;
coex_sta->wl_slot_toggle = FALSE;
}
if (ps_type == BTC_PS_WIFI_NATIVE)
btc->btc_set(btc, BTC_SET_ACT_POST_NORMAL_LPS, NULL);
}
static
void rtw_btc_tdma(struct btc_coexist *btc, boolean force_exec, u32 tcase)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
u8 type;
boolean turn_on;
btc->btc_set_atomic(btc, &coex_dm->setting_tdma, TRUE);
/* tcase: bit0~7 --> tdma case index
* bit8 --> for 4-slot (50ms) mode
*/
if (tcase & BIT(8))/* 4-slot (50ms) mode */
rtw_btc_set_tdma_timer_base(btc, 3);
else
rtw_btc_set_tdma_timer_base(btc, 0);
type = (u8)(tcase & 0xff);
turn_on = (type == 0 || type == 100) ? FALSE : TRUE;
if (!force_exec && turn_on == coex_dm->cur_ps_tdma_on &&
type == coex_dm->cur_ps_tdma) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Skip TDMA because no change TDMA(%s, %d)\n",
(coex_dm->cur_ps_tdma_on ? "on" : "off"),
coex_dm->cur_ps_tdma);
BTC_TRACE(trace_buf);
btc->btc_set_atomic(btc, &coex_dm->setting_tdma, FALSE);
return;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], ***** TDMA - %d *****\n", type);
BTC_TRACE(trace_buf);
if (turn_on) { /* enable TBTT nterrupt */
btc->btc_write_1byte_bitmask(btc, 0x550, BIT(3), 0x1);
btc->btc_write_scbd(btc, BTC_SCBD_TDMA, TRUE);
} else {
btc->btc_write_scbd(btc, BTC_SCBD_TDMA, FALSE);
}
if (btc->board_info.btdm_ant_num == 1) {
if (type < chip_para->tdma_sant_num)
rtw_btc_set_tdma(btc,
chip_para->tdma_sant[type].para[0],
chip_para->tdma_sant[type].para[1],
chip_para->tdma_sant[type].para[2],
chip_para->tdma_sant[type].para[3],
chip_para->tdma_sant[type].para[4]);
} else {
type = type - 100;
if (type < chip_para->tdma_nsant_num)
rtw_btc_set_tdma(btc,
chip_para->tdma_nsant[type].para[0],
chip_para->tdma_nsant[type].para[1],
chip_para->tdma_nsant[type].para[2],
chip_para->tdma_nsant[type].para[3],
chip_para->tdma_nsant[type].para[4]);
}
if (!coex_sta->wl_ps_state_fail) { /* update pre state */
coex_dm->cur_ps_tdma_on = turn_on;
coex_dm->cur_ps_tdma = type;
}
btc->btc_set_atomic(btc, &coex_dm->setting_tdma, FALSE);
}
static
void rtw_btc_set_ant_switch(struct btc_coexist *btc, boolean force_exec,
u8 ctrl_type, u8 pos_type)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
if (!force_exec) {
if (((ctrl_type << 8) + pos_type) == coex_dm->cur_switch_status)
return;
}
coex_dm->cur_switch_status = (ctrl_type << 8) + pos_type;
btc->chip_para->chip_setup(btc, BTC_CSETUP_ANT_SWITCH);
}
static
void rtw_btc_set_ant_path(struct btc_coexist *btc, boolean force_exec,
u8 phase)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
u8 u8tmp = 0, ctrl_type = BTC_SWITCH_CTRL_MAX,
pos_type = BTC_SWITCH_TO_MAX, cnt = 0;
u32 u32tmp1 = 0;
u16 u16tmp = 0;
if (!force_exec && coex_dm->cur_ant_pos_type == phase)
return;
coex_dm->cur_ant_pos_type = phase;
/* To avoid switch coex_ctrl_owner during BT IQK */
if (rfe_type->wlg_at_btg && btc->chip_para->scbd_support &&
coex_sta->bt_iqk_state != 0xff) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], (Before Ant Setup) Delay by IQK\n");
BTC_TRACE(trace_buf);
btc->btc_read_scbd(btc, &u16tmp); /* BT RFK */
u8tmp = btc->btc_read_1byte(btc, 0x49c); /* WL RFK */
while (++cnt < 12 && ((u16tmp & BIT(5)) || (u8tmp & BIT(0))))
delay_ms(50);
/* wait timeout */
if (cnt >= 12)
coex_sta->bt_iqk_state = 0xff;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], coex_sta->bt_disabled = 0x%x\n",
coex_sta->bt_disabled);
BTC_TRACE(trace_buf);
switch (phase) {
case BTC_ANT_POWERON:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_COEX_POWERON\n", __func__);
BTC_TRACE(trace_buf);
/* set Path control owner to BT at power-on step */
if (coex_sta->bt_disabled)
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
else
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_BT);
/*Caution: Don't indirect access while power on phase */
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_BT;
break;
case BTC_ANT_INIT:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_COEX_INIT\n", __func__);
BTC_TRACE(trace_buf);
if (coex_sta->bt_disabled) {
/* set GNT_BT to SW low */
rtw_btc_set_gnt_bt(btc, BTC_GNT_SW_LOW);
/* set GNT_WL to SW high */
rtw_btc_set_gnt_wl(btc, BTC_GNT_SW_HIGH);
} else {
/* set GNT_BT to SW high */
rtw_btc_set_gnt_bt(btc, BTC_GNT_SW_HIGH);
/* set GNT_WL to SW low */
rtw_btc_set_gnt_wl(btc, BTC_GNT_SW_LOW);
}
/* set Path control owner to WL at initial step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_BT;
break;
case BTC_ANT_WONLY:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_WLANONLY_INIT\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to SW Low */
rtw_btc_set_gnt_bt(btc, BTC_GNT_SW_LOW);
/* Set GNT_WL to SW high */
rtw_btc_set_gnt_wl(btc, BTC_GNT_SW_HIGH);
/* set Path control owner to WL at initial step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_WLG;
break;
case BTC_ANT_WOFF:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_WLAN_OFF\n", __func__);
BTC_TRACE(trace_buf);
/* set Path control owner to BT */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_BT);
ctrl_type = BTC_SWITCH_CTRL_BY_BT;
pos_type = BTC_SWITCH_TO_NOCARE;
break;
case BTC_ANT_2G:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_2G_RUNTIME\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to PTA */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to PTA */
rtw_btc_set_gnt_wl(btc, BTC_GNT_HW_PTA);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_PTA;
pos_type = BTC_SWITCH_TO_NOCARE;
break;
case BTC_ANT_5G:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_5G_RUNTIME\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to SW Hi */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to SW Hi */
rtw_btc_set_gnt_wl(btc, BTC_GNT_SW_HIGH);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_WLA;
break;
case BTC_ANT_2G_FREERUN:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_2G_FREERUN\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to SW Hi */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to SW Hi */
rtw_btc_set_gnt_wl(btc, BTC_GNT_SW_HIGH);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_WLG_BT;
break;
case BTC_ANT_2G_WLBT:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_2G_WLBT\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to HW PTA */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to HW PTA */
rtw_btc_set_gnt_wl(btc, BTC_GNT_HW_PTA);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_WLG_BT;
break;
case BTC_ANT_2G_WL:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_2G_WL\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to PTA */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to PTA */
rtw_btc_set_gnt_wl(btc, BTC_GNT_HW_PTA);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_WLG;
break;
case BTC_ANT_2G_BT:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_2G_WL\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to PTA */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to PTA */
rtw_btc_set_gnt_wl(btc, BTC_GNT_HW_PTA);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_BT;
break;
case BTC_ANT_BTMP:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_BTMP\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to SW Hi */
rtw_btc_set_gnt_bt(btc, BTC_GNT_SW_HIGH);
/* Set GNT_WL to SW Lo */
rtw_btc_set_gnt_wl(btc, BTC_GNT_SW_LOW);
/* set Path control owner to WL */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
btc->stop_coex_dm = TRUE;
ctrl_type = BTC_SWITCH_CTRL_BY_BBSW;
pos_type = BTC_SWITCH_TO_BT;
break;
case BTC_ANT_MCC:
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s() - PHASE_MCC\n", __func__);
BTC_TRACE(trace_buf);
/* set GNT_BT to PTA */
rtw_btc_set_gnt_bt(btc, BTC_GNT_HW_PTA);
/* Set GNT_WL to PTA */
rtw_btc_set_gnt_wl(btc, BTC_GNT_HW_PTA);
/* set Path control owner to WL at runtime step */
rtw_btc_coex_ctrl_owner(btc, BTC_OWNER_WL);
ctrl_type = BTC_SWITCH_CTRL_BY_FW;
pos_type = BTC_SWITCH_TO_NOCARE;
break;
}
if (ctrl_type < BTC_SWITCH_CTRL_MAX && pos_type < BTC_SWITCH_TO_MAX &&
rfe_type->ant_switch_exist)
rtw_btc_set_ant_switch(btc, force_exec, ctrl_type, pos_type);
}
static u8 rtw_btc_algorithm(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 algorithm = BTC_COEX_NOPROFILE;
u8 profile_map = 0;
if (coex_sta->bt_hfp_exist)
profile_map = profile_map | BTC_BTPROFILE_HFP;
if (coex_sta->bt_hid_exist)
profile_map = profile_map | BTC_BTPROFILE_HID;
if (coex_sta->bt_a2dp_exist)
profile_map = profile_map | BTC_BTPROFILE_A2DP;
if (coex_sta->bt_pan_exist)
profile_map = profile_map | BTC_BTPROFILE_PAN;
switch (profile_map) {
case BTC_BTPROFILE_NONE:
algorithm = BTC_COEX_NOPROFILE;
break;
case BTC_BTPROFILE_HFP:
algorithm = BTC_COEX_HFP;
break;
case BTC_BTPROFILE_HID:
algorithm = BTC_COEX_HID;
break;
case (BTC_BTPROFILE_HID | BTC_BTPROFILE_HFP):
algorithm = BTC_COEX_HID;
break;
case BTC_BTPROFILE_A2DP:
/* OPP may disappear during CPT_for_WiFi test */
if (coex_sta->bt_multi_link && coex_sta->bt_hid_pair_num > 0)
algorithm = BTC_COEX_A2DP_HID;
else if (coex_sta->bt_multi_link)
algorithm = BTC_COEX_A2DP_PAN;
else
algorithm = BTC_COEX_A2DP;
break;
case (BTC_BTPROFILE_A2DP | BTC_BTPROFILE_HFP):
algorithm = BTC_COEX_A2DP_HID;
break;
case (BTC_BTPROFILE_A2DP | BTC_BTPROFILE_HID):
algorithm = BTC_COEX_A2DP_HID;
break;
case (BTC_BTPROFILE_A2DP | BTC_BTPROFILE_HID | BTC_BTPROFILE_HFP):
algorithm = BTC_COEX_A2DP_HID;
break;
case BTC_BTPROFILE_PAN:
algorithm = BTC_COEX_PAN;
break;
case (BTC_BTPROFILE_PAN | BTC_BTPROFILE_HFP):
algorithm = BTC_COEX_PAN_HID;
break;
case (BTC_BTPROFILE_PAN | BTC_BTPROFILE_HID):
algorithm = BTC_COEX_PAN_HID;
break;
case (BTC_BTPROFILE_PAN | BTC_BTPROFILE_HID | BTC_BTPROFILE_HFP):
algorithm = BTC_COEX_PAN_HID;
break;
case (BTC_BTPROFILE_PAN | BTC_BTPROFILE_A2DP):
algorithm = BTC_COEX_A2DP_PAN;
break;
case (BTC_BTPROFILE_PAN | BTC_BTPROFILE_A2DP | BTC_BTPROFILE_HFP):
algorithm = BTC_COEX_A2DP_PAN_HID;
break;
case (BTC_BTPROFILE_PAN | BTC_BTPROFILE_A2DP | BTC_BTPROFILE_HID):
algorithm = BTC_COEX_A2DP_PAN_HID;
break;
case BTC_BTPROFILE_MAX:
algorithm = BTC_COEX_A2DP_PAN_HID;
break;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT Profile = %s => Algorithm = %s\n",
bt_profile_string[profile_map],
coex_algo_string[algorithm]);
BTC_TRACE(trace_buf);
return algorithm;
}
static void rtw_btc_action_coex_all_off(struct btc_coexist *btc)
{
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
/* To avoid rtw_btc_set_ant_path here */
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 2;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_freerun(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *cpara = btc->chip_para;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 level = 0, i;
boolean bt_afh_loss = TRUE;
if (btc->board_info.btdm_ant_num != 2)
return;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
coex_sta->coex_freerun = TRUE;
for (i = 0; i <= 8; i++) {
if (coex_sta->bt_afh_map[i] != 0xff) {
bt_afh_loss = FALSE;
break;
}
}
if (bt_afh_loss)
rtw_btc_update_wl_ch_info(btc, BTC_MEDIA_CONNECT);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G_FREERUN);
btc->btc_write_scbd(btc, BTC_SCBD_FIX2M, FALSE);
/* decrease more BT Tx power for clear case */
if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[0]))
level = 2;
else if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[1]))
level = 3;
else if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[2]))
level = 4;
else
level = 5;
if (level > cpara->wl_rf_para_tx_num - 1)
level = cpara->wl_rf_para_tx_num - 1;
if (link_info_ext->traffic_dir == BTC_WIFI_TRAFFIC_TX)
rtw_btc_set_rf_para(btc, NM_EXCU, cpara->wl_rf_para_tx[level]);
else
rtw_btc_set_rf_para(btc, NM_EXCU, cpara->wl_rf_para_rx[level]);
rtw_btc_table(btc, NM_EXCU, 100);
rtw_btc_tdma(btc, NM_EXCU, 100);
}
static void rtw_btc_action_rf4ce(struct btc_coexist *btc)
{
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 9;
tdma_case = 16;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_whql_test(struct btc_coexist *btc)
{
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 2;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_relink(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 1;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_idle(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
struct btc_wifi_link_info *link_info = &btc->wifi_link_info;
u8 table_case = 0xff, tdma_case = 0xff;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (rfe_type->ant_switch_with_bt &&
coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE) {
if (btc->board_info.btdm_ant_num == 1 &&
BTC_RSSI_HIGH(coex_dm->wl_rssi_state[1])) {
table_case = 0;
tdma_case = 0;
} else if (btc->board_info.btdm_ant_num == 2) {
table_case = 100;
tdma_case = 100;
}
}
if (table_case != 0xff && tdma_case != 0xff) {
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G_FREERUN);
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
return;
}
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
#ifndef PLATFORM_WINDOWS
if (coex_sta->wl_noisy_level > 0) {
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 1;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 123;
tdma_case = 0;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
return;
}
#endif
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (!coex_sta->wl_gl_busy) {
table_case = 10;
tdma_case = 3;
} else if (coex_sta->bt_mesh) {
table_case = 26;
tdma_case = 7;
} else if (coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE) {
table_case = 6;
tdma_case = 7;
} else {
table_case = 12;
tdma_case = 7;
}
} else { /* Non-Shared-Ant */
if (!coex_sta->wl_gl_busy) {
table_case = 112;
tdma_case = 104;
} else if ((coex_sta->bt_ble_scan_type & 0x2) &&
coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE) {
table_case = 114;
tdma_case = 103;
} else {
table_case = 112;
tdma_case = 103;
}
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_inquiry(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
boolean wl_hi_pri = FALSE;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (coex_sta->wl_linkscan_proc || coex_sta->wl_hi_pri_task1 ||
coex_sta->wl_hi_pri_task2 || coex_sta->wl_gl_busy)
wl_hi_pri = TRUE;
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (wl_hi_pri) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt inq/page + wifi hi-pri task\n");
table_case = 15;
if (coex_sta->bt_a2dp_exist && !coex_sta->bt_pan_exist)
tdma_case = 11;
else if (coex_sta->wl_hi_pri_task1)
tdma_case = 6;
else if (!coex_sta->bt_page)
tdma_case = 8;
else
tdma_case = 9;
} else if (link_info_ext->is_connected) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt inq/page + wifi connected\n");
table_case = 10;
tdma_case = 10;
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt inq/page + wifi not-connected\n");
table_case = 1;
tdma_case = 0;
}
} else { /* Non_Shared-Ant */
if (wl_hi_pri) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt inq/page + wifi hi-pri task\n");
table_case = 113;
if (coex_sta->bt_a2dp_exist && !coex_sta->bt_pan_exist)
tdma_case = 111;
else if (coex_sta->wl_hi_pri_task1)
tdma_case = 106;
else if (!coex_sta->bt_page)
tdma_case = 108;
else
tdma_case = 109;
} else if (link_info_ext->is_connected) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt inq/page + wifi connected\n");
table_case = 101;
tdma_case = 100;
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt inq/page + wifi not-connected\n");
table_case = 101;
tdma_case = 100;
}
}
BTC_TRACE(trace_buf);
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_mr(struct btc_coexist *btc)
{
struct btc_rfe_type *rfe_type = &btc->rfe_type;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (rfe_type->ant_switch_with_bt)
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G_FREERUN);
else
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
table_case = 0;
tdma_case = 0;
} else { /* Non-Shared-Ant */
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_hfp(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->bt_multi_link) {
table_case = 10;
tdma_case = 17;
} else {
table_case = 10;
tdma_case = 5;
}
} else { /* Non-Shared-Ant */
if (coex_sta->bt_multi_link) {
table_case = 112;
tdma_case = 117;
} else {
table_case = 105;
tdma_case = 100;
}
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_hid(struct btc_coexist *btc)
{
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
boolean is_toggle_table = FALSE;
u32 slot_type = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->bt_ble_exist) { /* RCU */
if (coex_sta->cnt_wl[BTC_CNT_WL_SCANAP] > 5) {
table_case = 26;
tdma_case = 2;
} else {
table_case = 27;
tdma_case = 9;
}
} else { /* Legacy HID */
if (coex_sta->bt_a2dp_active) {
table_case = 9;
tdma_case = 18;
} else if (coex_sta->bt_418_hid_exist &&
coex_sta->wl_gl_busy) {
is_toggle_table = TRUE;
slot_type = BIT(8);
table_case = 9;
tdma_case = 24;
} else {
table_case = 9;
tdma_case = 9;
}
}
} else { /* Non-Shared-Ant */
if (coex_sta->bt_ble_exist) { /* BLE */
if (coex_sta->cnt_wl[BTC_CNT_WL_SCANAP] > 5) {
table_case = 121;
tdma_case = 102;
} else {
table_case = 122;
tdma_case = 109;
}
} else if (coex_sta->bt_a2dp_active) {
table_case = 113;
tdma_case = 118;
} else {
table_case = 113;
tdma_case = 104;
}
}
rtw_btc_table(btc, NM_EXCU, table_case);
if (is_toggle_table) {
rtw_btc_wltoggle_tableA(btc, FC_EXCU, table_case);
rtw_btc_wltoggle_tableB(btc, NM_EXCU, 1, 0x5a5a5aaa);
}
rtw_btc_tdma(btc, NM_EXCU, tdma_case | slot_type);
}
static void rtw_btc_action_bt_a2dp(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->wl_gl_busy && coex_sta->wl_noisy_level == 0)
table_case = 12;
else
table_case = 9;
if (coex_sta->wl_connecting || !coex_sta->wl_gl_busy)
tdma_case = 14;
else
tdma_case = 13;
} else { /* Non-Shared-Ant */
table_case = 112;
if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[1]))
tdma_case = 112;
else
tdma_case = 113;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_a2dpsink(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *linfo_ext = &btc->wifi_link_info_ext;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (linfo_ext->is_ap_mode) {
table_case = 2;
tdma_case = 0;
} else if (coex_sta->wl_gl_busy) {
table_case = 28;
tdma_case = 20;
} else {
table_case = 28;
tdma_case = 26;
}
} else { /* Non-Shared-Ant */
if (linfo_ext->is_ap_mode) {
table_case = 100;
tdma_case = 100;
} else {
table_case = 119;
tdma_case = 120;
}
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_pan(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->wl_gl_busy && coex_sta->wl_noisy_level == 0)
table_case = 14;
else
table_case = 10;
if (coex_sta->wl_gl_busy)
tdma_case = 17;
else
tdma_case = 19;
} else { /* Non-Shared-Ant */
table_case = 112;
if (coex_sta->wl_gl_busy)
tdma_case = 117;
else
tdma_case = 119;
}
if (coex_sta->bt_slave && coex_sta->wl_gl_busy)
rtw_btc_set_bt_golden_rx_range(btc, NM_EXCU, 3, 20);
else
rtw_btc_set_bt_golden_rx_range(btc, NM_EXCU, 3, 0);
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_a2dp_hid(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 table_case, tdma_case;
boolean is_toggle_table = FALSE;
u32 slot_type = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->bt_ble_exist)
table_case = 26; /* for RCU */
else
table_case = 9;
if (coex_sta->wl_connecting || !coex_sta->wl_gl_busy) {
tdma_case = 14;
} else if (coex_sta->bt_418_hid_exist && coex_sta->wl_gl_busy) {
is_toggle_table = TRUE;
slot_type = BIT(8);
tdma_case = 23;
} else {
tdma_case = 13;
}
} else { /* Non-Shared-Ant */
if (coex_sta->bt_ble_exist)
table_case = 121;
else
table_case = 113;
if (BTC_RSSI_HIGH(coex_dm->wl_rssi_state[1]))
tdma_case = 112;
else
tdma_case = 113;
}
rtw_btc_table(btc, NM_EXCU, table_case);
if (is_toggle_table) {
rtw_btc_wltoggle_tableA(btc, FC_EXCU, table_case);
rtw_btc_wltoggle_tableB(btc, NM_EXCU, 1, 0x5a5a5aaa);
}
rtw_btc_tdma(btc, NM_EXCU, tdma_case | slot_type);
}
static void rtw_btc_action_bt_a2dp_pan(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
u8 table_case, tdma_case;
boolean wl_cpt_test = FALSE, bt_cpt_test = FALSE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
if (btc->board_info.customer_id == RT_CID_LENOVO_CHINA &&
coex_sta->cnt_wl[BTC_CNT_WL_SCANAP] <= 10 &&
coex_sta->wl_iot_peer == BTC_IOT_PEER_ATHEROS) {
if (BTC_RSSI_LOW(coex_dm->wl_rssi_state[2]))
wl_cpt_test = TRUE;
else
bt_cpt_test = TRUE;
}
if (wl_cpt_test)
rtw_btc_set_rf_para(btc, NM_EXCU, chip_para->wl_rf_para_rx[1]);
else
rtw_btc_set_rf_para(btc, NM_EXCU, chip_para->wl_rf_para_rx[0]);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (wl_cpt_test) {
if (coex_sta->wl_gl_busy) {
table_case = 20;
tdma_case = 17;
} else {
table_case = 10;
tdma_case = 15;
}
} else if (bt_cpt_test) {
table_case = 10;
tdma_case = 15;
} else {
if (coex_sta->wl_gl_busy &&
coex_sta->wl_noisy_level == 0)
table_case = 14;
else
table_case = 10;
if (coex_sta->wl_gl_busy)
tdma_case = 15;
else
tdma_case = 20;
}
} else { /* Non-Shared-Ant */
table_case = 112;
if (coex_sta->wl_gl_busy)
tdma_case = 115;
else
tdma_case = 120;
}
if (coex_sta->bt_slave)
rtw_btc_set_extend_btautoslot(btc, 0x3c);
else
rtw_btc_set_extend_btautoslot(btc, 0x32);
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_pan_hid(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 9;
if (coex_sta->wl_gl_busy)
tdma_case = 18;
else
tdma_case = 19;
} else { /* Non-Shared-Ant */
table_case = 113;
if (coex_sta->wl_gl_busy)
tdma_case = 117;
else
tdma_case = 119;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_bt_a2dp_pan_hid(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 10;
if (coex_sta->wl_gl_busy)
tdma_case = 15;
else
tdma_case = 20;
} else { /* Non-Shared-Ant */
table_case = 113;
if (coex_sta->wl_gl_busy)
tdma_case = 115;
else
tdma_case = 120;
}
if (coex_sta->bt_slave)
rtw_btc_set_extend_btautoslot(btc, 0x3c);
else
rtw_btc_set_extend_btautoslot(btc, 0x32);
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_under5g(struct btc_coexist *btc)
{
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_5G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
btc->btc_write_scbd(btc, BTC_SCBD_FIX2M, FALSE);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 0;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_only(struct btc_coexist *btc)
{
u8 table_case, tdma_case;
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 2;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_native_lps(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 table_case, tdma_case;
if (link_info_ext->is_all_under_5g)
return;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 28; /*0x6c0 for A2DP, 0x6c4 for non-A2DP*/
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_linkscan(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->bt_a2dp_exist) {
table_case = 9;
tdma_case = 11;
} else {
table_case = 9;
tdma_case = 7;
}
} else { /* Non-Shared-Ant */
if (coex_sta->bt_a2dp_exist) {
table_case = 112;
tdma_case = 111;
} else {
table_case = 112;
tdma_case = 107;
}
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_not_connected(struct btc_coexist *btc)
{
u8 table_case, tdma_case;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
table_case = 2;
tdma_case = 0;
} else { /* Non-Shared-Ant */
table_case = 100;
tdma_case = 100;
}
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_connected(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 algorithm;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
algorithm = rtw_btc_algorithm(btc);
switch (algorithm) {
case BTC_COEX_HFP:
rtw_btc_action_bt_hfp(btc);
break;
case BTC_COEX_HID:
if (rtw_btc_freerun_check(btc))
rtw_btc_action_freerun(btc);
else
rtw_btc_action_bt_hid(btc);
break;
case BTC_COEX_A2DP:
if (rtw_btc_freerun_check(btc))
rtw_btc_action_freerun(btc);
else if (coex_sta->bt_a2dp_sink)
rtw_btc_action_bt_a2dpsink(btc);
else
rtw_btc_action_bt_a2dp(btc);
break;
case BTC_COEX_PAN:
rtw_btc_action_bt_pan(btc);
break;
case BTC_COEX_A2DP_HID:
if (rtw_btc_freerun_check(btc))
rtw_btc_action_freerun(btc);
else
rtw_btc_action_bt_a2dp_hid(btc);
break;
case BTC_COEX_A2DP_PAN:
rtw_btc_action_bt_a2dp_pan(btc);
break;
case BTC_COEX_PAN_HID:
rtw_btc_action_bt_pan_hid(btc);
break;
case BTC_COEX_A2DP_PAN_HID:
rtw_btc_action_bt_a2dp_pan_hid(btc);
break;
default:
case BTC_COEX_NOPROFILE:
rtw_btc_action_bt_idle(btc);
break;
}
}
static void rtw_btc_action_wl_mcc25g(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case, tdma_case;
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_MCC);
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
btc->btc_write_scbd(btc, BTC_SCBD_FIX2M, FALSE);
if (btc->board_info.btdm_ant_num == 1) { /* Shared-Ant */
if (coex_sta->bt_setup_link) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Relink\n", __func__);
table_case = 24;
tdma_case = 0;
} else if (coex_sta->bt_inq_page) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Inq-Pag\n", __func__);
table_case = 23;
tdma_case = 0;
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT on\n", __func__);
if (coex_sta->bt_418_hid_exist)
table_case = 25;
else
table_case = 23;
tdma_case = 0;
}
} else { /* Non-Shared-Ant */
if (coex_sta->bt_setup_link) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Relink\n", __func__);
table_case = 100;
tdma_case = 100;
} else if (coex_sta->bt_inq_page) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Inq-Pag\n", __func__);
table_case = 118;
tdma_case = 100;
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT on!!\n", __func__);
table_case = 118;
tdma_case = 100;
}
}
BTC_TRACE(trace_buf);
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
static void rtw_btc_action_wl_scc2g(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 table_case = 0xff, tdma_case = 0xff;
boolean is_toggle_table = FALSE;
u32 slot_type = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
if (coex_sta->bt_profile_num == 1) {
if (coex_sta->bt_hid_exist || coex_sta->bt_hfp_exist) {
if (coex_sta->bt_a2dp_active) {
table_case = 9;
tdma_case = 21;
} else if (coex_sta->bt_418_hid_exist) {
table_case = 10;
tdma_case = 24;
is_toggle_table = TRUE;
slot_type = BIT(8);
} else {
table_case = 2;
tdma_case = 0;
}
} else if (coex_sta->bt_a2dp_exist) {
table_case = 10;
tdma_case = 22;
slot_type = BIT(8);
} else { /* PAN or OPP */
table_case = 10;
tdma_case = 21;
}
} else {
if ((coex_sta->bt_hid_exist || coex_sta->bt_hfp_exist) &&
coex_sta->bt_a2dp_exist) {
table_case = 9;
tdma_case = 22;
slot_type = BIT(8);
if (coex_sta->bt_418_hid_exist)
is_toggle_table = TRUE;
} else if (coex_sta->bt_pan_exist && coex_sta->bt_a2dp_exist) {
table_case = 10;
tdma_case = 22;
slot_type = BIT(8);
} else { /* hid + pan */
table_case = 9;
tdma_case = 21;
}
}
rtw_btc_table(btc, NM_EXCU, table_case);
if (is_toggle_table) {
rtw_btc_wltoggle_tableA(btc, FC_EXCU, table_case);
rtw_btc_wltoggle_tableB(btc, NM_EXCU, 1, 0x5a5a5aaa);
}
rtw_btc_tdma(btc, NM_EXCU, tdma_case | slot_type);
}
static void rtw_btc_action_wl_p2p2g(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
struct btc_wifi_link_info *link_info = &btc->wifi_link_info;
u8 table_case = 0xff, tdma_case = 0xff, ant_phase;
if (rfe_type->ant_switch_with_bt)
ant_phase = BTC_ANT_2G_FREERUN;
else
ant_phase = BTC_ANT_2G;
rtw_btc_set_rf_para(btc, NM_EXCU, btc->chip_para->wl_rf_para_rx[0]);
btc->btc_write_scbd(btc, BTC_SCBD_FIX2M, FALSE);
if (btc->board_info.btdm_ant_num == 2) { /* Non-Shared-Ant */
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Non_Shared_Ant!!\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_action_freerun(btc);
return;
}
/* Shared-Ant */
if (coex_sta->bt_disabled) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Disable!!\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
table_case = 0;
tdma_case = 0;
} else if (coex_sta->bt_setup_link) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Relink!!\n", __func__);
rtw_btc_set_ant_path(btc, NM_EXCU, ant_phase);
table_case = 1;
tdma_case = 0;
} else if (coex_sta->bt_inq_page) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT Inq-Page!!\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, ant_phase);
table_case = 15;
tdma_case = 2;
} else if (coex_sta->bt_profile_num == 0) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT idle!!\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, NM_EXCU, ant_phase);
table_case = 2;
tdma_case = 0;
} else if (coex_sta->wl_linkscan_proc) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL scan!!\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_action_wl_linkscan(btc);
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT busy!!\n", __func__);
BTC_TRACE(trace_buf);
switch (link_info->link_mode) {
case BTC_LINK_2G_SCC_GC_STA:
case BTC_LINK_2G_SCC_GO_STA:
rtw_btc_set_ant_path(btc, NM_EXCU, BTC_ANT_2G);
rtw_btc_action_wl_scc2g(btc);
break;
#if 0
case BTC_LINK_ONLY_GO:
rtw_btc_set_ant_path(btc, NM_EXCU, ant_phase);
table_case = 7;
tdma_case = 0;
break;
case BTC_LINK_ONLY_GC:
rtw_btc_set_ant_path(btc, NM_EXCU, ant_phase);
if (coex_sta->bt_418_hid_exist)
table_case = 6;
else
table_case = 8;
tdma_case = 0;
break;
#endif
default:
rtw_btc_set_ant_path(btc, NM_EXCU, ant_phase);
table_case = 2;
tdma_case = 0;
break;
}
}
if (table_case != 0xff && tdma_case != 0xff) {
rtw_btc_table(btc, NM_EXCU, table_case);
rtw_btc_tdma(btc, NM_EXCU, tdma_case);
}
}
static void rtw_btc_run_coex(struct btc_coexist *btc, u8 reason)
{
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
struct btc_wifi_link_info *link_info = &btc->wifi_link_info;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): reason = %d\n", __func__, reason);
BTC_TRACE(trace_buf);
coex_sta->coex_run_reason = reason;
/* update wifi_link_info_ext variable */
rtw_btc_update_wl_link_info(btc, reason);
rtw_btc_monitor_bt_enable(btc);
if (coex_sta->wl_linkscan_proc ||
coex_sta->wl_hi_pri_task1 ||
coex_sta->wl_hi_pri_task2 || coex_sta->wl_gl_busy)
btc->btc_write_scbd(btc, BTC_SCBD_SCAN, TRUE);
else
btc->btc_write_scbd(btc, BTC_SCBD_SCAN, FALSE);
if (btc->manual_control) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], return for Manual CTRL!!\n");
BTC_TRACE(trace_buf);
return;
}
if (btc->stop_coex_dm) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], return for Stop Coex DM!!\n");
BTC_TRACE(trace_buf);
return;
}
if (coex_sta->wl_under_ips) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], return for wifi is under IPS!!\n");
BTC_TRACE(trace_buf);
return;
}
if (coex_sta->wl_under_lps && link_info_ext->is_32k) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], return for wifi is under LPS-32K!!\n");
BTC_TRACE(trace_buf);
return;
}
if (coex_sta->coex_freeze && !coex_sta->bt_setup_link) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], return for coex_freeze!!\n");
BTC_TRACE(trace_buf);
return;
}
coex_sta->cnt_wl[BTC_CNT_WL_COEXRUN]++;
coex_sta->coex_freerun = FALSE;
/* Pure-5G Coex Process */
if (link_info_ext->is_all_under_5g) {
coex_sta->wl_coex_mode = BTC_WLINK_5G;
rtw_btc_action_wl_under5g(btc);
goto exit;
}
if (coex_sta->bt_msft_mr_exist && link_info_ext->is_connected) {
coex_sta->wl_coex_mode = BTC_WLINK_BTMR;
rtw_btc_action_bt_mr(btc);
goto exit;
}
if (link_info_ext->is_mcc_25g) {
coex_sta->wl_coex_mode = BTC_WLINK_25GMPORT;
rtw_btc_action_wl_mcc25g(btc);
goto exit;
}
/* if multi-port, P2P-GO, P2P-GC */
if (link_info_ext->num_of_active_port > 1 ||
(link_info->link_mode == BTC_LINK_ONLY_GO &&
!link_info_ext->is_ap_mode) ||
link_info->link_mode == BTC_LINK_ONLY_GC) {
if (link_info->link_mode == BTC_LINK_ONLY_GO)
coex_sta->wl_coex_mode = BTC_WLINK_2GGO;
else if (link_info->link_mode == BTC_LINK_ONLY_GC)
coex_sta->wl_coex_mode = BTC_WLINK_2GGC;
else
coex_sta->wl_coex_mode = BTC_WLINK_2GMPORT;
rtw_btc_action_wl_p2p2g(btc);
goto exit;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], WiFi is single-port 2G!!\n");
BTC_TRACE(trace_buf);
coex_sta->wl_coex_mode = BTC_WLINK_2G1PORT;
btc->btc_write_scbd(btc, BTC_SCBD_FIX2M, FALSE);
if (coex_sta->bt_disabled) {
if (link_info_ext->is_connected && coex_sta->rf4ce_en)
rtw_btc_action_rf4ce(btc);
else if (!link_info_ext->is_connected)
rtw_btc_action_wl_not_connected(btc);
else
rtw_btc_action_wl_only(btc);
goto exit;
}
if (coex_sta->wl_under_lps && !coex_sta->wl_force_lps_ctrl) {
rtw_btc_action_wl_native_lps(btc);
goto exit;
}
if (coex_sta->bt_whck_test) {
rtw_btc_action_bt_whql_test(btc);
goto exit;
}
if (coex_sta->bt_setup_link) {
rtw_btc_action_bt_relink(btc);
goto exit;
}
if (coex_sta->bt_inq_page) {
rtw_btc_action_bt_inquiry(btc);
goto exit;
}
if ((coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE ||
coex_dm->bt_status == BTC_BTSTATUS_CON_IDLE) &&
link_info_ext->is_connected) {
rtw_btc_action_bt_idle(btc);
goto exit;
}
if (coex_sta->wl_linkscan_proc && !coex_sta->coex_freerun) {
rtw_btc_action_wl_linkscan(btc);
goto exit;
}
if (link_info_ext->is_connected) {
rtw_btc_action_wl_connected(btc);
goto exit;
} else {
rtw_btc_action_wl_not_connected(btc);
goto exit;
}
exit:
/* No MIMO Power Save, 3:disable */
if (coex_sta->wl_coex_mode == BTC_WLINK_BTMR)
rtw_btc_mimo_ps(btc, NM_EXCU, 3);
else
rtw_btc_mimo_ps(btc, NM_EXCU, 0);
rtw_btc_gnt_workaround(btc, NM_EXCU, coex_sta->wl_coex_mode);
rtw_btc_limited_wl(btc);
}
static void rtw_btc_init_coex_var(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
u8 i;
/* Reset Coex variable */
btc->btc_set(btc, BTC_SET_RESET_COEX_VAR, NULL);
/* Init Coex variables that are not zero */
for (i = 0; i < ARRAY_SIZE(coex_dm->bt_rssi_state); i++)
coex_dm->bt_rssi_state[i] = BTC_RSSI_STATE_LOW;
for (i = 0; i < ARRAY_SIZE(coex_dm->wl_rssi_state); i++)
coex_dm->wl_rssi_state[i] = BTC_RSSI_STATE_LOW;
for (i = 0; i < ARRAY_SIZE(coex_sta->bt_sut_pwr_lvl); i++)
coex_sta->bt_sut_pwr_lvl[i] = 0xff;
coex_sta->bt_reg_vendor_ac = 0xffff;
coex_sta->bt_reg_vendor_ae = 0xffff;
coex_sta->gnt_workaround_state = BTC_WLINK_MAX;
btc->bt_info.bt_get_fw_ver = 0;
}
static void rtw_btc_init_coex_dm(struct btc_coexist *btc)
{
}
static void
rtw_btc_init_hw_config(struct btc_coexist *btc, boolean wifi_only)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u32 u32tmp1 = 0, u32tmp2 = 0;
u8 table_case = 1, tdma_case = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
/* init coex_dm, coex_sta variable to sync with chip status */
rtw_btc_init_coex_var(btc);
/* 0xf0[15:12] --> chip kt info */
coex_sta->kt_ver = (btc->btc_read_1byte(btc, 0xf1) & 0xf0) >> 4;
rtw_btc_monitor_bt_enable(btc);
/* Setup RF front end type */
btc->chip_para->chip_setup(btc, BTC_CSETUP_RFE_TYPE);
/* Init coex relared register */
btc->chip_para->chip_setup(btc, BTC_CSETUP_INIT_HW);
/* set Tx response = Hi-Pri (ex: Transmitting ACK,BA,CTS) */
rtw_btc_set_wl_pri_mask(btc, BTC_WLPRI_TX_RSP, 1);
/* set Tx beacon = Hi-Pri */
rtw_btc_set_wl_pri_mask(btc, BTC_WLPRI_TX_BEACON, 1);
/* set Tx beacon queue = Hi-Pri */
rtw_btc_set_wl_pri_mask(btc, BTC_WLPRI_TX_BEACONQ, 1);
#if 0
/* coex-276 P2P-Go beacon request can't release issue
* Only PCIe can set 0x454[6] = 1 to solve this issue,
* WL SDIO/USB interface need driver support.
*/
if (btc->chip_interface == BTC_INTF_PCI)
btc->btc_write_1byte_bitmask(btc, 0x454, BIT(6), 0x1);
#endif
/* Antenna config */
if (btc->wl_rf_state_off) {
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_WOFF);
btc->btc_write_scbd(btc, BTC_SCBD_ALL, FALSE);
btc->stop_coex_dm = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): RF Off\n", __func__);
BTC_TRACE(trace_buf);
} else if (wifi_only) {
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_WONLY);
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE | BTC_SCBD_ON, TRUE);
btc->stop_coex_dm = TRUE;
} else {
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_INIT);
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE | BTC_SCBD_ON, TRUE);
btc->stop_coex_dm = FALSE;
}
/* PTA parameter */
rtw_btc_table(btc, FC_EXCU, table_case);
rtw_btc_tdma(btc, FC_EXCU, tdma_case);
rtw_btc_query_bt_info(btc);
}
void rtw_btc_ex_power_on_setting(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_board_info *board_info = &btc->board_info;
u8 u8tmp = 0x0, table_case = 1;
u16 u16tmp = 0x0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
btc->stop_coex_dm = TRUE;
btc->wl_rf_state_off = FALSE;
/* enable BB, REG_SYS_FUNC_EN to write reg correctly. */
u16tmp = btc->btc_read_2byte(btc, 0x2);
btc->btc_write_2byte(btc, 0x2, u16tmp | BIT(0) | BIT(1));
rtw_btc_monitor_bt_enable(btc);
/* Setup RF front end type */
btc->chip_para->chip_setup(btc, BTC_CSETUP_RFE_TYPE);
/* Set Antenna Path to BT side */
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_POWERON);
rtw_btc_table(btc, FC_EXCU, table_case);
/* SD1 Chunchu red x issue */
btc->btc_write_1byte(btc, 0xff1a, 0x0);
rtw_btc_gnt_debug(btc, TRUE);
board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
}
void rtw_btc_ex_pre_load_firmware(struct btc_coexist *btc) {}
void rtw_btc_ex_init_hw_config(struct btc_coexist *btc, boolean wifi_only)
{
rtw_btc_init_hw_config(btc, wifi_only);
}
void rtw_btc_ex_init_coex_dm(struct btc_coexist *btc)
{
rtw_btc_init_coex_dm(btc);
}
void rtw_btc_ex_display_simple_coex_info(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
struct btc_board_info *board_info = &btc->board_info;
u8 *cli_buf = btc->cli_buf;
u32 bt_patch_ver = 0, bt_coex_ver = 0, val = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n _____[BT Coexist info]____");
CL_PRINTF(cli_buf);
if (btc->manual_control) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n __[Under Manual Control]_");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n _________________________");
CL_PRINTF(cli_buf);
}
if (btc->stop_coex_dm) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ____[Coex is STOPPED]____");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n _________________________");
CL_PRINTF(cli_buf);
}
if (!coex_sta->bt_disabled &&
(coex_sta->bt_supported_version == 0 ||
coex_sta->bt_supported_version == 0xffff) &&
coex_sta->cnt_wl[BTC_CNT_WL_COEXINFO2] % 3 == 0) {
btc->btc_get(btc, BTC_GET_U4_SUPPORTED_FEATURE,
&coex_sta->bt_supported_feature);
btc->btc_get(btc, BTC_GET_U4_SUPPORTED_VERSION,
&coex_sta->bt_supported_version);
val = btc->btc_get_bt_reg(btc, 3, 0xac);
coex_sta->bt_reg_vendor_ac = (u16)(val & 0xffff);
val = btc->btc_get_bt_reg(btc, 3, 0xae);
coex_sta->bt_reg_vendor_ae = (u16)(val & 0xffff);
btc->btc_get(btc, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
btc->bt_info.bt_get_fw_ver = bt_patch_ver;
}
/* BT coex. info. */
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ %d/ %s / %d",
"Ant PG Num/ Mech/ Pos/ RFE", board_info->pg_ant_num,
board_info->btdm_ant_num,
(board_info->btdm_ant_pos ==
BTC_ANTENNA_AT_MAIN_PORT ? "Main" : "Aux"),
rfe_type->rfe_module_type);
CL_PRINTF(cli_buf);
bt_coex_ver = ((coex_sta->bt_supported_version & 0xff00) >> 8);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d_%02x/ %d_%02x/ 0x%02x/ 0x%02x (%s)",
"Ver Coex/ Para/ BT_Dez/ BT_Rpt",
coex_ver_date, coex_ver, chip_para->para_ver_date,
chip_para->para_ver, chip_para->bt_desired_ver, bt_coex_ver,
(bt_coex_ver == 0xff ? "Unknown" :
(coex_sta->bt_disabled ? "BT-disable" :
(bt_coex_ver >= chip_para->bt_desired_ver ?
"Match" : "Mis-Match"))));
CL_PRINTF(cli_buf);
/* BT Status */
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "BT status",
((coex_sta->bt_disabled) ? ("disabled") :
((coex_sta->bt_inq_page) ? ("inquiry/page") :
((coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE) ?
"non-connected idle" :
((coex_dm->bt_status == BTC_BTSTATUS_CON_IDLE) ?
"connected-idle" : "busy")))));
CL_PRINTF(cli_buf);
/* HW Settings */
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
"0x770(Hi-pri rx/tx)", coex_sta->hi_pri_rx,
coex_sta->hi_pri_tx);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
"0x774(Lo-pri rx/tx)", coex_sta->lo_pri_rx,
coex_sta->lo_pri_tx, (coex_sta->bt_slave ?
"(Slave!!)" : ""));
CL_PRINTF(cli_buf);
coex_sta->cnt_wl[BTC_CNT_WL_COEXINFO2]++;
}
void rtw_btc_ex_display_coex_info(struct btc_coexist *btc)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
const struct btc_chip_para *chip_para = btc->chip_para;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
struct btc_board_info *board_info = &btc->board_info;
u8 *cli_buf = btc->cli_buf, u8tmp[4], i, ps_tdma_case = 0;
u16 u16tmp[4];
u32 u32tmp[4], phy_ver = 0, fw_ver = 0,
bt_coex_ver = 0, val = 0,
fa_ofdm, fa_cck, cca_ofdm, cca_cck,
ok_11b, ok_11g, ok_11n, ok_11vht,
err_11b, err_11g, err_11n, err_11vht;
boolean is_bt_reply = FALSE;
u8 * const p = &coex_sta->bt_afh_map[0];
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ============[BT Coexist info %s]============",
chip_para->chip_name);
CL_PRINTF(cli_buf);
if (btc->manual_control) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ============[Under Manual Control]============");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ==========================================");
CL_PRINTF(cli_buf);
} else if (btc->stop_coex_dm) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ============[Coex is STOPPED]============");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ==========================================");
CL_PRINTF(cli_buf);
} else if (coex_sta->coex_freeze) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ============[coex_freeze]============");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n ==========================================");
CL_PRINTF(cli_buf);
}
if (!coex_sta->bt_disabled &&
coex_sta->cnt_wl[BTC_CNT_WL_COEXINFO1] % 3 == 0) {
if (coex_sta->bt_supported_version == 0 ||
coex_sta->bt_supported_version == 0xffff) {
btc->btc_get(btc, BTC_GET_U4_SUPPORTED_VERSION,
&coex_sta->bt_supported_version);
if (coex_sta->bt_supported_version > 0 &&
coex_sta->bt_supported_version < 0xffff)
is_bt_reply = TRUE;
} else {
is_bt_reply = TRUE;
}
if (coex_dm->bt_status != BTC_BTSTATUS_NCON_IDLE) {
btc->btc_get_bt_afh_map_from_bt(btc, 0, p);
val = btc->btc_get_bt_reg(btc, 1, 0xa);
coex_sta->bt_reg_modem_a = (u16)((val & 0x1c0) >> 6);
val = btc->btc_get_bt_reg(btc, 0, 0x2);
coex_sta->bt_reg_rf_2 = (u16)val;
}
}
if (is_bt_reply) {
if (coex_sta->bt_supported_feature == 0) {
btc->btc_get(btc, BTC_GET_U4_SUPPORTED_FEATURE,
&coex_sta->bt_supported_feature);
if (coex_sta->bt_supported_feature & BIT(11))
coex_sta->bt_slave_latency = TRUE;
else
coex_sta->bt_slave_latency = FALSE;
}
if (coex_sta->bt_reg_vendor_ac == 0xffff) {
val = btc->btc_get_bt_reg(btc, 3, 0xac);
coex_sta->bt_reg_vendor_ac = (u16)(val & 0xffff);
}
if (coex_sta->bt_reg_vendor_ae == 0xffff) {
val = btc->btc_get_bt_reg(btc, 3, 0xae);
coex_sta->bt_reg_vendor_ae = (u16)(val & 0xffff);
}
if (btc->bt_info.bt_get_fw_ver == 0)
btc->btc_get(btc, BTC_GET_U4_BT_PATCH_VER,
&btc->bt_info.bt_get_fw_ver);
}
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %s/ %s / %d/ %d",
"Ant PG Num/ Mech/ Pos/ RFE/ Dist", board_info->pg_ant_num,
(board_info->btdm_ant_num == 1 ? "Shared" : "Non-Shared"),
(board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT ?
"Main" : "Aux"), rfe_type->rfe_module_type,
board_info->ant_distance);
CL_PRINTF(cli_buf);
btc->btc_get(btc, BTC_GET_U4_WIFI_FW_VER, &fw_ver);
btc->btc_get(btc, BTC_GET_U4_WIFI_PHY_VER, &phy_ver);
bt_coex_ver = ((coex_sta->bt_supported_version & 0xff00) >> 8);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d_%02x/ %d_%02x/ 0x%02x/ 0x%02x (%s)",
"Ver Coex/ Para/ BT_Dez/ BT_Rpt",
coex_ver_date, coex_ver, chip_para->para_ver_date,
chip_para->para_ver, chip_para->bt_desired_ver, bt_coex_ver,
(bt_coex_ver == 0xff ? "Unknown" :
(coex_sta->bt_disabled ? "BT-disable" :
(bt_coex_ver >= chip_para->bt_desired_ver ?
"Match" : "Mis-Match"))));
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%08x/ v%d/ %c",
"W_FW/ B_FW/ Phy/ Kt", fw_ver, btc->bt_info.bt_get_fw_ver,
phy_ver, coex_sta->kt_ver + 65);
CL_PRINTF(cli_buf);
/* wifi status */
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
"============[Wifi Status]============");
CL_PRINTF(cli_buf);
btc->btc_disp_dbg_msg(btc, BTC_DBG_DISP_WIFI_STATUS);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
"============[BT Status]============");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %ddBm/ %d/ %d",
"BT status/ rssi/ retryCnt/ popCnt",
((coex_sta->bt_disabled) ? ("disabled") :
((coex_sta->bt_inq_page) ? ("inquiry-page") :
((coex_dm->bt_status == BTC_BTSTATUS_NCON_IDLE) ?
"non-connecte-idle" : ((coex_dm->bt_status ==
BTC_BTSTATUS_CON_IDLE) ? "connected-idle" : "busy")))),
coex_sta->bt_rssi - 100, coex_sta->cnt_bt[BTC_CNT_BT_RETRY],
coex_sta->cnt_bt[BTC_CNT_BT_POPEVENT]);
CL_PRINTF(cli_buf);
if (coex_sta->bt_profile_num != 0) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %s%s%s%s%s%s (multilink = %d)",
"Profiles", ((coex_sta->bt_a2dp_exist) ?
((coex_sta->bt_a2dp_sink) ? "A2DP sink," :
"A2DP,") : ""),
((coex_sta->bt_hfp_exist) ? "HFP," : ""),
((coex_sta->bt_hid_exist) ?
((coex_sta->bt_ble_exist) ? "HID(RCU)" :
((coex_sta->bt_hid_slot >= 2) ? "HID(4/18)," :
"HID(2/18),")) : ""), ((coex_sta->bt_pan_exist) ?
((coex_sta->bt_opp_exist) ? "OPP," : "PAN,") :
""), ((coex_sta->bt_ble_voice) ? "Voice," : ""),
((coex_sta->bt_msft_mr_exist) ? "MR" : ""),
coex_sta->bt_multi_link);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ %d/ %d/ %d",
"SUT Power[3:0]",
coex_sta->bt_sut_pwr_lvl[3],
coex_sta->bt_sut_pwr_lvl[2],
coex_sta->bt_sut_pwr_lvl[1],
coex_sta->bt_sut_pwr_lvl[0]);
CL_PRINTF(cli_buf);
} else {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s",
"Profiles",
(coex_sta->bt_msft_mr_exist) ? "MR" : "None");
CL_PRINTF(cli_buf);
}
/* for 8822b, Scoreboard[10]: 0: CQDDR off, 1: CQDDR on
* for 8822c, Scoreboard[10]: 0: CQDDR on, 1:CQDDR fix 2M
*/
if (coex_sta->bt_a2dp_exist) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %s/ %d/ 0x%x/ 0x%x",
"CQDDR/Bitpool/V_ID/D_name",
(chip_para->new_scbd10_def ?
((coex_sta->bt_fix_2M) ? "fix_2M" : "CQDDR_On") :
((coex_sta->bt_fix_2M) ? "CQDDR_On" : "CQDDR_Off")),
coex_sta->bt_a2dp_bitpool,
coex_sta->bt_a2dp_vendor_id,
coex_sta->bt_a2dp_device_name);
CL_PRINTF(cli_buf);
}
if (coex_sta->bt_hid_exist) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d",
"HID PairNum", coex_sta->bt_hid_pair_num);
CL_PRINTF(cli_buf);
}
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %s/ 0x%x",
"Role/RoleSwCnt/IgnWla/Feature",
((coex_sta->bt_slave) ? "Slave" : "Master"),
coex_sta->cnt_bt[BTC_CNT_BT_ROLESWITCH],
((coex_dm->cur_ignore_wlan_act) ? "Yes" : "No"),
coex_sta->bt_supported_feature);
CL_PRINTF(cli_buf);
if (coex_sta->bt_ble_scan_en) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
"BLEScan Type/TV/Init/Ble",
coex_sta->bt_ble_scan_type,
(coex_sta->bt_ble_scan_type & 0x1 ?
coex_sta->bt_ble_scan_para[0] : 0x0),
(coex_sta->bt_ble_scan_type & 0x2 ?
coex_sta->bt_ble_scan_para[1] : 0x0),
(coex_sta->bt_ble_scan_type & 0x4 ?
coex_sta->bt_ble_scan_para[2] : 0x0));
CL_PRINTF(cli_buf);
}
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ %d/ %d/ %d/ %d/ %d/ %d %s",
"Init/ReLink/IgnWl/Pag/Inq/iqkO/iqkX",
coex_sta->cnt_bt[BTC_CNT_BT_REINIT],
coex_sta->cnt_bt[BTC_CNT_BT_SETUPLINK],
coex_sta->cnt_bt[BTC_CNT_BT_IGNWLANACT],
coex_sta->cnt_bt[BTC_CNT_BT_PAGE],
coex_sta->cnt_bt[BTC_CNT_BT_INQ],
coex_sta->cnt_bt[BTC_CNT_BT_IQK],
coex_sta->cnt_bt[BTC_CNT_BT_IQKFAIL],
(coex_sta->bt_setup_link ? "(Relink!!)" : ""));
CL_PRINTF(cli_buf);
btc->btc_read_scbd(btc, &u16tmp[0]);
if (coex_sta->bt_reg_vendor_ae == 0xffff ||
coex_sta->bt_reg_vendor_ac == 0xffff)
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = x/ x/ 0x%04x",
"0xae[4]/0xac[1:0]/ScBd(B->W)", u16tmp[0]);
else
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%04x/ %s",
"ae/ac/m_a[8:6]/rf_2/ScBd(B->W)/path",
coex_sta->bt_reg_vendor_ae,
coex_sta->bt_reg_vendor_ac,
coex_sta->bt_reg_modem_a,
coex_sta->bt_reg_rf_2, u16tmp[0],
((coex_sta->bt_reg_vendor_ae & BIT(4)) ? "S1" : "S0"
));
CL_PRINTF(cli_buf);
if (coex_dm->bt_status != BTC_BTSTATUS_NCON_IDLE) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %02x%02x%02x%02x %02x%02x%02x%02x %02x%02x",
"AFH MAP", coex_sta->bt_afh_map[0],
coex_sta->bt_afh_map[1], coex_sta->bt_afh_map[2],
coex_sta->bt_afh_map[3], coex_sta->bt_afh_map[4],
coex_sta->bt_afh_map[5], coex_sta->bt_afh_map[6],
coex_sta->bt_afh_map[7], coex_sta->bt_afh_map[8],
coex_sta->bt_afh_map[9]);
CL_PRINTF(cli_buf);
}
for (i = 0; i < BTC_BTINFO_SRC_BT_IQK; i++) {
if (coex_sta->cnt_bt_info_c2h[i]) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %02x %02x %02x %02x %02x %02x %02x (%d)",
glbt_info_src[i],
coex_sta->bt_info_c2h[i][0],
coex_sta->bt_info_c2h[i][1],
coex_sta->bt_info_c2h[i][2],
coex_sta->bt_info_c2h[i][3],
coex_sta->bt_info_c2h[i][4],
coex_sta->bt_info_c2h[i][5],
coex_sta->bt_info_c2h[i][6],
coex_sta->cnt_bt_info_c2h[i]);
CL_PRINTF(cli_buf);
}
}
if (btc->manual_control) {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
"============[mechanisms] (under Manual)============");
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %02x %02x %02x %02x %02x",
"TDMA_Now",
coex_dm->fw_tdma_para[0], coex_dm->fw_tdma_para[1],
coex_dm->fw_tdma_para[2], coex_dm->fw_tdma_para[3],
coex_dm->fw_tdma_para[4]);
CL_PRINTF(cli_buf);
} else {
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
"============[Mechanisms]============");
CL_PRINTF(cli_buf);
ps_tdma_case = coex_dm->cur_ps_tdma;
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %02x %02x %02x %02x %02x (case-%d, TDMA-%s, Ext-%d)",
"TDMA",
coex_dm->ps_tdma_para[0], coex_dm->ps_tdma_para[1],
coex_dm->ps_tdma_para[2], coex_dm->ps_tdma_para[3],
coex_dm->ps_tdma_para[4], ps_tdma_case,
(coex_dm->cur_ps_tdma_on ? "On" : "Off"),
coex_sta->bt_ext_autoslot_thres);
CL_PRINTF(cli_buf);
}
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %d",
"Coex_Mode/Free_Run/Timer_base",
coex_mode_string[coex_sta->wl_coex_mode],
((coex_sta->coex_freerun) ? "Yes" : "No"),
coex_sta->tdma_timer_base);
CL_PRINTF(cli_buf);
u32tmp[0] = btc->btc_read_4byte(btc, 0x6c0);
u32tmp[1] = btc->btc_read_4byte(btc, 0x6c4);
u32tmp[2] = btc->btc_read_4byte(btc, 0x6c8);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ 0x%x/ 0x%x/ 0x%x",
"Table/0x6c0/0x6c4/0x6c8", coex_sta->coex_table_type,
u32tmp[0], u32tmp[1], u32tmp[2]);
CL_PRINTF(cli_buf);
u8tmp[0] = btc->btc_read_1byte(btc, 0x778);
u32tmp[0] = btc->btc_read_4byte(btc, 0x6cc);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = 0x%x/ 0x%x/ 0x%04x/ %d/ %s",
"0x778/0x6cc/ScBd(W->B)/RunCnt/Rsn", u8tmp[0], u32tmp[0],
coex_sta->score_board_WB,
coex_sta->cnt_wl[BTC_CNT_WL_COEXRUN],
run_reason_string[coex_sta->coex_run_reason]);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %02x %02x %02x (RF-Ch = %d)", "AFH Map to BT",
coex_dm->wl_chnl_info[0], coex_dm->wl_chnl_info[1],
coex_dm->wl_chnl_info[2], coex_sta->wl_center_ch);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d/ %d",
"AntDiv/BtCtrlLPS/LPRA/PsFail/g_busy",
((board_info->ant_div_cfg) ? "On" : "Off"),
((coex_sta->wl_force_lps_ctrl) ? "On" : "Off"),
((coex_dm->cur_low_penalty_ra) ? "On" : "Off"),
coex_sta->cnt_wl[BTC_CNT_WL_PSFAIL], coex_sta->wl_gl_busy);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
"Null All/Retry/Ack/BT_Empty/BT_Late",
coex_sta->wl_fw_dbg_info[1], coex_sta->wl_fw_dbg_info[2],
coex_sta->wl_fw_dbg_info[3], coex_sta->wl_fw_dbg_info[4],
coex_sta->wl_fw_dbg_info[5]);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s/ %d",
"Cnt TDMA_Togg/Lk5ms/Lk5ms_off/fw",
coex_sta->wl_fw_dbg_info[6],
coex_sta->wl_fw_dbg_info[7],
((coex_sta->is_no_wl_5ms_extend) ? "Yes" : "No"),
coex_sta->cnt_wl[BTC_CNT_WL_FW_NOTIFY]);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %s/ %d",
"WL_TxPw/BT_TxPw/WL_Rx/BT_LNA_Lvl",
coex_dm->cur_wl_pwr_lvl, coex_dm->cur_bt_pwr_lvl,
((coex_dm->cur_wl_rx_low_gain_en) ? "On" : "Off"),
coex_dm->cur_bt_lna_lvl);
CL_PRINTF(cli_buf);
/* Hw setting */
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s",
"============[Hw setting]============");
CL_PRINTF(cli_buf);
btc->chip_para->chip_setup(btc, BTC_CSETUP_COEXINFO_HW);
fa_ofdm = btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_FA_OFDM);
fa_cck = btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_FA_CCK);
cca_ofdm = btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CCA_OFDM);
cca_cck = btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CCA_CCK);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ %d/ %d/ %d",
"CCK-CCA/CCK-FA/OFDM-CCA/OFDM-FA", cca_cck, fa_cck, cca_ofdm,
fa_ofdm);
CL_PRINTF(cli_buf);
ok_11b =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_OK_CCK);
ok_11g =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_OK_LEGACY);
ok_11n =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_OK_HT);
ok_11vht =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_OK_VHT);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
"CRC_OK CCK/11g/11n/11ac", ok_11b, ok_11g, ok_11n, ok_11vht);
CL_PRINTF(cli_buf);
err_11b =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_ERROR_CCK);
err_11g =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_ERROR_LEGACY);
err_11n =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_ERROR_HT);
err_11vht =
btc->btc_phydm_query_PHY_counter(btc, PHYDM_INFO_CRC32_ERROR_VHT);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d",
"CRC_Err CCK/11g/11n/11ac",
err_11b, err_11g, err_11n, err_11vht);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE,
"\r\n %-35s = %d/ %d/ %s-%d/ %d (Tx macid: %d)",
"Rate RxD/RxRTS/TxD/TxRetry_ratio",
coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate,
(coex_sta->wl_tx_rate & 0x80 ? "SGI" : "LGI"),
coex_sta->wl_tx_rate & 0x7f,
coex_sta->wl_tx_retry_ratio,
coex_sta->wl_tx_macid);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s/ %d",
"HiPr/ Locking/ Locked/ Noisy",
(coex_sta->wl_hi_pri_task1 ? "Yes" : "No"),
(coex_sta->wl_cck_lock ? "Yes" : "No"),
(coex_sta->wl_cck_lock_ever ? "Yes" : "No"),
coex_sta->wl_noisy_level);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d",
"0x770(Hi-pri rx/tx)", coex_sta->hi_pri_rx,
coex_sta->hi_pri_tx);
CL_PRINTF(cli_buf);
CL_SPRINTF(cli_buf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d %s",
"0x774(Lo-pri rx/tx)", coex_sta->lo_pri_rx,
coex_sta->lo_pri_tx, (coex_sta->bt_slave ?
"(Slave!!)" : ""));
CL_PRINTF(cli_buf);
btc->btc_disp_dbg_msg(btc, BTC_DBG_DISP_COEX_STATISTICS);
coex_sta->cnt_wl[BTC_CNT_WL_COEXINFO1]++;
if (coex_sta->cnt_wl[BTC_CNT_WL_COEXINFO1] % 5 == 0)
coex_sta->cnt_bt[BTC_CNT_BT_POPEVENT] = 0;
}
void rtw_btc_ex_ips_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (btc->manual_control || btc->stop_coex_dm)
return;
if (type == BTC_IPS_ENTER) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], IPS ENTER notify\n");
BTC_TRACE(trace_buf);
coex_sta->wl_under_ips = TRUE;
/* Write WL "Active" in Score-board for LPS off */
btc->btc_write_scbd(btc, BTC_SCBD_ALL, FALSE);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_WOFF);
rtw_btc_action_coex_all_off(btc);
} else if (type == BTC_IPS_LEAVE) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], IPS LEAVE notify\n");
BTC_TRACE(trace_buf);
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE | BTC_SCBD_ON, TRUE);
/*leave IPS : run ini hw config (exclude wifi only)*/
rtw_btc_init_hw_config(btc, FALSE);
/*sw all off*/
rtw_btc_init_coex_dm(btc);
rtw_btc_query_bt_info(btc);
coex_sta->wl_under_ips = FALSE;
}
}
void rtw_btc_ex_lps_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (btc->manual_control || btc->stop_coex_dm)
return;
if (type == BTC_LPS_ENABLE) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], LPS ENABLE notify\n");
BTC_TRACE(trace_buf);
coex_sta->wl_under_lps = TRUE;
if (coex_sta->wl_force_lps_ctrl) { /* LPS No-32K */
/* Write WL "Active" in Score-board for PS-TDMA */
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE, TRUE);
} else {
/* Write WL "Non-Active" in Score-board for Native-PS */
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE, FALSE);
rtw_btc_run_coex(btc, BTC_RSN_LPS);
}
} else if (type == BTC_LPS_DISABLE) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], LPS DISABLE notify\n");
BTC_TRACE(trace_buf);
coex_sta->wl_under_lps = FALSE;
/* Write WL "Active" in Score-board for LPS off */
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE, TRUE);
if (!coex_sta->wl_force_lps_ctrl)
rtw_btc_query_bt_info(btc);
rtw_btc_run_coex(btc, BTC_RSN_LPS);
}
}
void rtw_btc_ex_scan_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (btc->manual_control || btc->stop_coex_dm)
return;
coex_sta->coex_freeze = FALSE;
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE | BTC_SCBD_ON, TRUE);
if (type == BTC_SCAN_START_5G) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], SCAN START notify (5G)\n");
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_5G);
rtw_btc_run_coex(btc, BTC_RSN_5GSCANSTART);
} else if (type == BTC_SCAN_START_2G || type == BTC_SCAN_START) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], SCAN START notify (2G)\n");
BTC_TRACE(trace_buf);
coex_sta->wl_hi_pri_task2 = TRUE;
/* Force antenna setup for no scan result issue */
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_2G);
rtw_btc_run_coex(btc, BTC_RSN_2GSCANSTART);
} else {
btc->btc_get(btc, BTC_GET_U1_AP_NUM,
&coex_sta->cnt_wl[BTC_CNT_WL_SCANAP]);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], SCAN FINISH notify (Scan-AP = %d)\n",
coex_sta->cnt_wl[BTC_CNT_WL_SCANAP]);
BTC_TRACE(trace_buf);
coex_sta->wl_hi_pri_task2 = FALSE;
rtw_btc_run_coex(btc, BTC_RSN_SCANFINISH);
}
}
void rtw_btc_ex_scan_notify_without_bt(struct btc_coexist *btc, u8 type)
{
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
struct btc_rfe_type *rfe_type = &btc->rfe_type;
u8 ctrl_type = BTC_SWITCH_CTRL_BY_BBSW, pos_type = BTC_SWITCH_TO_WLG;
if (!rfe_type->ant_switch_exist)
return;
if (type == BTC_SCAN_START) {
if (link_info_ext->is_all_under_5g)
pos_type = BTC_SWITCH_TO_WLA;
else /* under 2.4G */
pos_type = BTC_SWITCH_TO_WLG;
} else if (type == BTC_SCAN_START_2G) {
pos_type = BTC_SWITCH_TO_WLG;
}
rtw_btc_set_ant_switch(btc, FC_EXCU, ctrl_type, pos_type);
}
void rtw_btc_ex_switchband_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (btc->manual_control || btc->stop_coex_dm)
return;
if (type == BTC_SWITCH_TO_5G) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): TO_5G\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_run_coex(btc, BTC_RSN_5GSWITCHBAND);
} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): TO_24G_NOFORSCAN\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_run_coex(btc, BTC_RSN_2GSWITCHBAND);
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): TO_2G\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_ex_scan_notify(btc, BTC_SCAN_START_2G);
}
}
void rtw_btc_ex_switchband_notify_without_bt(struct btc_coexist *btc, u8 type)
{
struct btc_rfe_type *rfe_type = &btc->rfe_type;
u8 ctrl_type = BTC_SWITCH_CTRL_BY_BBSW, pos_type = BTC_SWITCH_TO_WLG;
if (!rfe_type->ant_switch_exist)
return;
if (type == BTC_SWITCH_TO_5G) {
pos_type = BTC_SWITCH_TO_WLA;
} else if (type == BTC_SWITCH_TO_24G_NOFORSCAN) {
pos_type = BTC_SWITCH_TO_WLG;
} else {
rtw_btc_ex_scan_notify_without_bt(btc, BTC_SCAN_START_2G);
return;
}
rtw_btc_set_ant_switch(btc, FC_EXCU, ctrl_type, pos_type);
}
void rtw_btc_ex_connect_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (btc->manual_control || btc->stop_coex_dm)
return;
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE | BTC_SCBD_ON, TRUE);
if (type == BTC_ASSOCIATE_5G_START) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 5G start\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_5G);
rtw_btc_run_coex(btc, BTC_RSN_5GCONSTART);
} else if (type == BTC_ASSOCIATE_5G_FINISH) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 5G finish\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_5G);
rtw_btc_run_coex(btc, BTC_RSN_5GCONFINISH);
} else if (type == BTC_ASSOCIATE_START) {
coex_sta->wl_hi_pri_task1 = TRUE;
coex_sta->cnt_wl[BTC_CNT_WL_ARP] = 0;
coex_sta->wl_connecting = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_WL_CONNPKT, 2);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 2G start\n", __func__);
BTC_TRACE(trace_buf);
/* Force antenna setup for no scan result issue */
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_2G);
rtw_btc_run_coex(btc, BTC_RSN_2GCONSTART);
/* To keep TDMA case during connect process,
* to avoid changed by Btinfo and run_coex
*/
coex_sta->coex_freeze = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_WL_COEXFREEZE, 5);
} else {
coex_sta->wl_hi_pri_task1 = FALSE;
coex_sta->coex_freeze = FALSE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 2G finish\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_run_coex(btc, BTC_RSN_2GCONFINISH);
}
}
void rtw_btc_ex_media_status_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
boolean wl_b_mode = FALSE;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
if (btc->manual_control || btc->stop_coex_dm)
return;
if (type == BTC_MEDIA_CONNECT_5G) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 5G\n", __func__);
BTC_TRACE(trace_buf);
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE, TRUE);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_5G);
rtw_btc_run_coex(btc, BTC_RSN_5GMEDIA);
} else if (type == BTC_MEDIA_CONNECT) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 2G\n", __func__);
BTC_TRACE(trace_buf);
btc->btc_write_scbd(btc, BTC_SCBD_ACTIVE, TRUE);
/* Force antenna setup for no scan result issue */
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_2G);
btc->btc_get(btc, BTC_GET_BL_WIFI_UNDER_B_MODE, &wl_b_mode);
/* Set CCK Tx/Rx high Pri except 11b mode */
if (wl_b_mode)/* CCK Rx */
rtw_btc_set_wl_pri_mask(btc, BTC_WLPRI_RX_CCK, 0);
else /* CCK Rx */
rtw_btc_set_wl_pri_mask(btc, BTC_WLPRI_RX_CCK, 1);
rtw_btc_run_coex(btc, BTC_RSN_2GMEDIA);
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): disconnect!!\n", __func__);
BTC_TRACE(trace_buf);
coex_sta->cnt_wl[BTC_CNT_WL_ARP] = 0;
/* CCK Rx, Tx response, Tx beacon = low pri */
if (link_info_ext->num_of_active_port == 0)
rtw_btc_set_wl_pri_mask(btc, BTC_WLPRI_RX_CCK, 0);
coex_sta->wl_cck_lock_ever = FALSE;
coex_sta->wl_cck_lock = FALSE;
rtw_btc_run_coex(btc, BTC_RSN_MEDIADISCON);
}
btc->btc_get(btc, BTC_GET_U1_IOT_PEER, &coex_sta->wl_iot_peer);
rtw_btc_update_wl_ch_info(btc, type);
}
void rtw_btc_ex_specific_packet_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
boolean under_4way = FALSE;
if (btc->manual_control || btc->stop_coex_dm)
return;
if (type & BTC_5G_BAND) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): 5G\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_run_coex(btc, BTC_RSN_5GSPECIALPKT);
return;
}
btc->btc_get(btc, BTC_GET_BL_WIFI_4_WAY_PROGRESS, &under_4way);
if (under_4way) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): under_4way!!\n", __func__);
BTC_TRACE(trace_buf);
coex_sta->wl_hi_pri_task1 = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_WL_SPECPKT, 2);
} else if (type == BTC_PACKET_ARP) {
coex_sta->cnt_wl[BTC_CNT_WL_ARP]++;
if (coex_sta->wl_hi_pri_task1) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): ARP cnt = %d\n",
__func__, coex_sta->cnt_wl[BTC_CNT_WL_ARP]);
BTC_TRACE(trace_buf);
}
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): DHCP or EAPOL Type = %d\n",
__func__, type);
BTC_TRACE(trace_buf);
coex_sta->wl_hi_pri_task1 = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_WL_SPECPKT, 2);
}
if (coex_sta->wl_hi_pri_task1)
rtw_btc_run_coex(btc, BTC_RSN_2GSPECIALPKT);
}
void rtw_btc_ex_bt_info_notify(struct btc_coexist *btc, u8 *tmp_buf, u8 length)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_coex_dm *coex_dm = &btc->coex_dm;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 i, rsp_source = 0, type;
rsp_source = tmp_buf[0] & 0xf;
if (rsp_source >= BTC_BTINFO_SRC_MAX)
return;
coex_sta->cnt_bt_info_c2h[rsp_source]++;
/* bt_iqk_state-> 1: start, 0: ok, 2:fail */
if (rsp_source == BTC_BTINFO_SRC_BT_IQK) {
coex_sta->bt_iqk_state = tmp_buf[1];
if (coex_sta->bt_iqk_state == 0x0)
coex_sta->cnt_bt[BTC_CNT_BT_IQK]++;
else if (coex_sta->bt_iqk_state == 0x2)
coex_sta->cnt_bt[BTC_CNT_BT_IQKFAIL]++;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT IQK by bt_info, data0 = 0x%02x\n",
tmp_buf[1]);
BTC_TRACE(trace_buf);
return;
}
if (rsp_source == BTC_BTINFO_SRC_BT_SCBD) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT Scoreboard change notify by WL FW c2h, 0xaa = 0x%02x, 0xab = 0x%02x\n",
tmp_buf[1], tmp_buf[2]);
BTC_TRACE(trace_buf);
rtw_btc_monitor_bt_enable(btc);
if (coex_sta->bt_disabled != coex_sta->bt_disabled_pre) {
coex_sta->bt_disabled_pre = coex_sta->bt_disabled;
rtw_btc_run_coex(btc, BTC_RSN_BTINFO);
}
return;
}
if (rsp_source == BTC_BTINFO_SRC_H2C60) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], H2C 0x60 content replied by WL FW: H2C_0x60 = [%02x %02x %02x %02x %02x]\n",
tmp_buf[1], tmp_buf[2], tmp_buf[3], tmp_buf[4],
tmp_buf[5]);
BTC_TRACE(trace_buf);
for (i = 1; i <= 5; i++)
coex_dm->fw_tdma_para[i - 1] = tmp_buf[i];
return;
}
if (rsp_source == BTC_BTINFO_SRC_WL_FW) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], bt_info reply by WL FW\n");
BTC_TRACE(trace_buf);
rtw_btc_update_bt_link_info(btc);
rtw_btc_run_coex(btc, BTC_RSN_BTINFO);
return;
}
if (rsp_source == BTC_BTINFO_SRC_BT_RSP ||
rsp_source == BTC_BTINFO_SRC_BT_ACT) {
if (coex_sta->bt_disabled) {
coex_sta->bt_disabled = FALSE;
coex_sta->bt_reenable = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_BT_REENABLE, 15);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT enable detected by bt_info\n");
BTC_TRACE(trace_buf);
}
}
if (length != 7) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Bt_info length = %d invalid!!\n",
length);
BTC_TRACE(trace_buf);
return;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Bt_info[%d], len=%d, data=[%02x %02x %02x %02x %02x %02x]\n",
tmp_buf[0], length, tmp_buf[1], tmp_buf[2], tmp_buf[3],
tmp_buf[4], tmp_buf[5], tmp_buf[6]);
BTC_TRACE(trace_buf);
for (i = 0; i < 7; i++)
coex_sta->bt_info_c2h[rsp_source][i] = tmp_buf[i];
if (coex_sta->bt_info_c2h[rsp_source][1] == coex_sta->bt_info_lb2 &&
coex_sta->bt_info_c2h[rsp_source][2] == coex_sta->bt_info_lb3 &&
coex_sta->bt_info_c2h[rsp_source][3] == coex_sta->bt_info_hb0 &&
coex_sta->bt_info_c2h[rsp_source][4] == coex_sta->bt_info_hb1 &&
coex_sta->bt_info_c2h[rsp_source][5] == coex_sta->bt_info_hb2 &&
coex_sta->bt_info_c2h[rsp_source][6] == coex_sta->bt_info_hb3) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Return because Btinfo duplicate!!\n");
BTC_TRACE(trace_buf);
return;
}
coex_sta->bt_info_lb2 = coex_sta->bt_info_c2h[rsp_source][1];
coex_sta->bt_info_lb3 = coex_sta->bt_info_c2h[rsp_source][2];
coex_sta->bt_info_hb0 = coex_sta->bt_info_c2h[rsp_source][3];
coex_sta->bt_info_hb1 = coex_sta->bt_info_c2h[rsp_source][4];
coex_sta->bt_info_hb2 = coex_sta->bt_info_c2h[rsp_source][5];
coex_sta->bt_info_hb3 = coex_sta->bt_info_c2h[rsp_source][6];
/* ========== BT info Low-Byte2 ========== */
/* if 0xff, it means BT is under WHCK test */
coex_sta->bt_whck_test = (coex_sta->bt_info_lb2 == 0xff);
coex_sta->bt_inq_page = ((coex_sta->bt_info_lb2 & BIT(2)) == BIT(2));
coex_sta->bt_acl_busy = ((coex_sta->bt_info_lb2 & BIT(3)) == BIT(3));
/* ========== BT info Low-Byte3 ========== */
coex_sta->cnt_bt[BTC_CNT_BT_RETRY] = coex_sta->bt_info_lb3 & 0xf;
if (coex_sta->cnt_bt[BTC_CNT_BT_RETRY] >= 1)
coex_sta->cnt_bt[BTC_CNT_BT_POPEVENT]++;
coex_sta->bt_fix_2M = ((coex_sta->bt_info_lb3 & BIT(4)) == BIT(4));
coex_sta->bt_inq = ((coex_sta->bt_info_lb3 & BIT(5)) == BIT(5));
coex_sta->bt_mesh = ((coex_sta->bt_info_lb3 & BIT(6)) == BIT(6));
if (coex_sta->bt_inq)
coex_sta->cnt_bt[BTC_CNT_BT_INQ]++;
coex_sta->bt_page = ((coex_sta->bt_info_lb3 & BIT(7)) == BIT(7));
if (coex_sta->bt_page)
coex_sta->cnt_bt[BTC_CNT_BT_PAGE]++;
/* ========== BT info High-Byte0 ========== */
/* unit: %, value-100 to translate to unit: dBm */
if (btc->chip_para->bt_rssi_type == BTC_BTRSSI_RATIO) {
coex_sta->bt_rssi = coex_sta->bt_info_hb0 * 2 + 10;
} else { /* coex_sta->bt_info_hb0 is just dbm */
if (coex_sta->bt_info_hb0 <= 127)
coex_sta->bt_rssi = 100;
else if (256 - coex_sta->bt_info_hb0 <= 100)
coex_sta->bt_rssi = 100 - (256 - coex_sta->bt_info_hb0);
else
coex_sta->bt_rssi = 0;
}
/* ========== BT info High-Byte1 ========== */
coex_sta->bt_ble_exist = ((coex_sta->bt_info_hb1 & BIT(0)) == BIT(0));
if (coex_sta->bt_info_hb1 & BIT(1))
coex_sta->cnt_bt[BTC_CNT_BT_REINIT]++;
if ((coex_sta->bt_info_hb1 & BIT(2)) ||
(coex_sta->bt_page && coex_sta->wl_pnp_wakeup)) {
coex_sta->cnt_bt[BTC_CNT_BT_SETUPLINK]++;
coex_sta->bt_setup_link = TRUE;
if (coex_sta->bt_reenable)
btc->btc_set_timer(btc, BTC_TIMER_BT_RELINK, 6);
else
btc->btc_set_timer(btc, BTC_TIMER_BT_RELINK, 2);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], Re-Link start in BT info!!\n");
BTC_TRACE(trace_buf);
}
if (coex_sta->bt_info_hb1 & BIT(3))
coex_sta->cnt_bt[BTC_CNT_BT_IGNWLANACT]++;
coex_sta->bt_ble_voice = ((coex_sta->bt_info_hb1 & BIT(4)) == BIT(4));
coex_sta->bt_ble_scan_en = ((coex_sta->bt_info_hb1 & BIT(5)) == BIT(5));
if (coex_sta->bt_info_hb1 & BIT(6))
coex_sta->cnt_bt[BTC_CNT_BT_ROLESWITCH]++;
coex_sta->bt_multi_link = ((coex_sta->bt_info_hb1 & BIT(7)) == BIT(7));
/* Here we need to resend some wifi info to BT */
/* because bt is reset and loss of the info. */
/* Re-Init */
if ((coex_sta->bt_info_hb1 & BIT(1))) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT Re-init, send wifi BW & Chnl to BT!!\n");
BTC_TRACE(trace_buf);
if (link_info_ext->is_connected)
type = BTC_MEDIA_CONNECT;
else
type = BTC_MEDIA_DISCONNECT;
rtw_btc_update_wl_ch_info(btc, type);
}
/* If Ignore_WLanAct && not SetUp_Link */
if ((coex_sta->bt_info_hb1 & BIT(3)) &&
(!(coex_sta->bt_info_hb1 & BIT(2)))) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n");
BTC_TRACE(trace_buf);
rtw_btc_ignore_wlan_act(btc, FC_EXCU, FALSE);
}
/* ========== BT info High-Byte2 ========== */
coex_sta->bt_opp_exist = ((coex_sta->bt_info_hb2 & BIT(0)) == BIT(0));
if (coex_sta->bt_info_hb2 & BIT(1))
coex_sta->cnt_bt[BTC_CNT_BT_AFHUPDATE]++;
coex_sta->bt_a2dp_active = ((coex_sta->bt_info_hb2 & BIT(2)) == BIT(2));
coex_sta->bt_slave = ((coex_sta->bt_info_hb2 & BIT(3)) == BIT(3));
coex_sta->bt_hid_slot = (coex_sta->bt_info_hb2 & 0x30) >> 4;
coex_sta->bt_hid_pair_num = (coex_sta->bt_info_hb2 & 0xc0) >> 6;
if (coex_sta->bt_hid_pair_num > 0 && coex_sta->bt_hid_slot >= 2)
coex_sta->bt_418_hid_exist = TRUE;
else if (coex_sta->bt_hid_pair_num == 0)
coex_sta->bt_418_hid_exist = FALSE;
/* ========== BT info High-Byte3 ========== */
if ((coex_sta->bt_info_lb2 & 0x49) == 0x49)
coex_sta->bt_a2dp_bitpool = (coex_sta->bt_info_hb3 & 0x7f);
else
coex_sta->bt_a2dp_bitpool = 0;
coex_sta->bt_a2dp_sink = ((coex_sta->bt_info_hb3 & BIT(7)) == BIT(7));
rtw_btc_update_bt_link_info(btc);
rtw_btc_run_coex(btc, BTC_RSN_BTINFO);
}
void rtw_btc_ex_wl_fwdbginfo_notify(struct btc_coexist *btc, u8 *tmp_buf,
u8 length)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
u8 i = 0, val = 0;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], WiFi Fw Dbg info = %d %d %d %d %d %d %d %d (len = %d)\n",
tmp_buf[0], tmp_buf[1], tmp_buf[2], tmp_buf[3], tmp_buf[4],
tmp_buf[5], tmp_buf[6], tmp_buf[7], length);
BTC_TRACE(trace_buf);
if (tmp_buf[0] != 0x8)
return;
for (i = 1; i <= 7; i++) {
val = coex_sta->wl_fw_dbg_info_pre[i];
if (tmp_buf[i] >= val)
coex_sta->wl_fw_dbg_info[i] = tmp_buf[i] - val;
else
coex_sta->wl_fw_dbg_info[i] = 255 - val + tmp_buf[i];
coex_sta->wl_fw_dbg_info_pre[i] = tmp_buf[i];
}
/* wl_fwdbginfo_notify is auto send by WL FW if TDMA slot toggle = 20
* coex_sta->wl_fw_dbg_info[6] = TDMA slot toggle
* For debug, TDMA slot toggle should be calculated by 2-second
*/
coex_sta->cnt_wl[BTC_CNT_WL_FW_NOTIFY]++;
rtw_btc_wl_ccklock_action(btc);
}
void rtw_btc_ex_rx_rate_change_notify(struct btc_coexist *btc,
BOOLEAN is_data_frame, u8 btc_rate_id)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (is_data_frame)
coex_sta->wl_rx_rate = btc_rate_id;
else
coex_sta->wl_rts_rx_rate = btc_rate_id;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): rate id = %d, RTS_Rate = %d\n", __func__,
coex_sta->wl_rx_rate, coex_sta->wl_rts_rx_rate);
BTC_TRACE(trace_buf);
rtw_btc_wl_ccklock_detect(btc);
}
void rtw_btc_ex_tx_rate_change_notify(struct btc_coexist *btc, u8 tx_rate,
u8 tx_retry_ratio, u8 macid)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Tx_Rate = %d, Tx_Retry_Ratio = %d, macid =%d\n",
__func__, tx_rate, tx_retry_ratio, macid);
BTC_TRACE(trace_buf);
coex_sta->wl_tx_rate = tx_rate;
coex_sta->wl_tx_retry_ratio = tx_retry_ratio;
coex_sta->wl_tx_macid = macid;
}
void rtw_btc_ex_rf_status_notify(struct btc_coexist *btc, u8 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
if (type == BTC_RF_ON) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): RF is turned ON!!\n", __func__);
BTC_TRACE(trace_buf);
btc->stop_coex_dm = FALSE;
btc->wl_rf_state_off = FALSE;
} else if (type == BTC_RF_OFF) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): RF is turned Off!!\n", __func__);
BTC_TRACE(trace_buf);
btc->btc_write_scbd(btc, BTC_SCBD_ALL, FALSE);
rtw_btc_tdma(btc, FC_EXCU, 0);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_WOFF);
rtw_btc_ignore_wlan_act(btc, FC_EXCU, TRUE);
btc->stop_coex_dm = TRUE;
btc->wl_rf_state_off = TRUE;
/* must place in the last step */
rtw_btc_update_wl_ch_info(btc, BTC_MEDIA_DISCONNECT);
}
}
void rtw_btc_ex_halt_notify(struct btc_coexist *btc)
{
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_ex_media_status_notify(btc, BTC_MEDIA_DISCONNECT);
rtw_btc_ignore_wlan_act(btc, FC_EXCU, TRUE);
rtw_btc_set_ant_path(btc, FC_EXCU, BTC_ANT_WOFF);
btc->btc_write_scbd(btc, BTC_SCBD_ALL, FALSE);
btc->stop_coex_dm = TRUE;
/* must place in the last step */
rtw_btc_update_wl_ch_info(btc, BTC_MEDIA_DISCONNECT);
}
void rtw_btc_ex_pnp_notify(struct btc_coexist *btc, u8 pnp_state)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
struct btc_wifi_link_info_ext *link_info_ext = &btc->wifi_link_info_ext;
u8 phase;
if (pnp_state == BTC_WIFI_PNP_SLEEP ||
pnp_state == BTC_WIFI_PNP_SLEEP_KEEP_ANT) {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Sleep\n", __func__);
BTC_TRACE(trace_buf);
btc->btc_write_scbd(btc, BTC_SCBD_ALL, FALSE);
if (pnp_state == BTC_WIFI_PNP_SLEEP_KEEP_ANT) {
if (link_info_ext->is_all_under_5g)
phase = BTC_ANT_5G;
else
phase = BTC_ANT_2G;
} else {
phase = BTC_ANT_WOFF;
}
rtw_btc_set_ant_path(btc, FC_EXCU, phase);
btc->stop_coex_dm = TRUE;
} else {
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Wake up\n", __func__);
BTC_TRACE(trace_buf);
coex_sta->wl_pnp_wakeup = TRUE;
btc->btc_set_timer(btc, BTC_TIMER_WL_PNPWAKEUP, 3);
/*WoWLAN*/
if (coex_sta->wl_pnp_state_pre == BTC_WIFI_PNP_SLEEP_KEEP_ANT ||
pnp_state == BTC_WIFI_PNP_WOWLAN) {
btc->stop_coex_dm = FALSE;
rtw_btc_run_coex(btc, BTC_RSN_PNP);
}
}
coex_sta->wl_pnp_state_pre = pnp_state;
}
void rtw_btc_ex_coex_dm_reset(struct btc_coexist *btc)
{
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE, "[BTCoex], %s()\n", __func__);
BTC_TRACE(trace_buf);
rtw_btc_init_hw_config(btc, FALSE);
rtw_btc_init_coex_dm(btc);
}
void rtw_btc_ex_periodical(struct btc_coexist *btc)
{
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], ============== Periodical ==============\n");
BTC_TRACE(trace_buf);
rtw_btc_monitor_bt_ctr(btc);
rtw_btc_wl_noisy_detect(btc);
}
void rtw_btc_ex_timerup_notify(struct btc_coexist *btc, u32 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
boolean is_change = FALSE;
if (type & BIT(BTC_TIMER_WL_STAYBUSY)) {
if (!coex_sta->wl_busy_pre) {
coex_sta->wl_gl_busy = FALSE;
is_change = TRUE;
btc->btc_write_scbd(btc, BTC_SCBD_WLBUSY, FALSE);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL busy -> idle!!\n", __func__);
BTC_TRACE(trace_buf);
}
}
/*avoid no connect finish notify */
if (type & BIT(BTC_TIMER_WL_COEXFREEZE)) {
coex_sta->coex_freeze = FALSE;
coex_sta->wl_hi_pri_task1 = FALSE;
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Coex is de-freeze!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_TIMER_WL_SPECPKT)) {
if (!coex_sta->coex_freeze) {
coex_sta->wl_hi_pri_task1 = FALSE;
is_change = TRUE;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL SPECPKT finish!\n", __func__);
BTC_TRACE(trace_buf);
}
/*for A2DP glitch during connecting AP*/
if (type & BIT(BTC_TIMER_WL_CONNPKT)) {
coex_sta->wl_connecting = FALSE;
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL connecting stop!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_TIMER_WL_PNPWAKEUP)) {
coex_sta->wl_pnp_wakeup = FALSE;
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL pnp wakeup stop!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_TIMER_WL_CCKLOCK)) {
if (coex_sta->wl_cck_lock_pre) {
coex_sta->wl_cck_lock_ever = TRUE;
is_change = TRUE;
}
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL CCK Lock Detect!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_TIMER_BT_RELINK)) {
coex_sta->bt_setup_link = FALSE;
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): Re-Link stop!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_TIMER_BT_REENABLE)) {
coex_sta->bt_reenable = FALSE;
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): BT renable finish!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (is_change)
rtw_btc_run_coex(btc, BTC_RSN_TIMERUP);
}
void rtw_btc_ex_wl_status_change_notify(struct btc_coexist *btc, u32 type)
{
struct btc_coex_sta *coex_sta = &btc->coex_sta;
boolean is_change = FALSE;
if (type & BIT(BTC_WLSTATUS_CHANGE_TOIDLE)) { /* if busy->idle */
coex_sta->wl_busy_pre = FALSE;
btc->btc_set_timer(btc, BTC_TIMER_WL_STAYBUSY, 6);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL busy -> idle!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_WLSTATUS_CHANGE_TOBUSY)) { /* if idle->busy */
coex_sta->wl_gl_busy = TRUE;
coex_sta->wl_busy_pre = TRUE;
is_change = TRUE;
btc->btc_write_scbd(btc, BTC_SCBD_WLBUSY, TRUE);
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL idle -> busy!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_WLSTATUS_CHANGE_RSSI)) { /* if RSSI change */
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL RSSI change!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_WLSTATUS_CHANGE_LINKINFO)) { /* if linkinfo change */
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL LinkInfo change!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_WLSTATUS_CHANGE_DIR)) { /*if WL UL-DL change*/
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s(): WL UL-DL change!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (type & BIT(BTC_WLSTATUS_CHANGE_NOISY)) { /*if noisy level change*/
is_change = TRUE;
BTC_SPRINTF(trace_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s():Noisy Level change!!\n", __func__);
BTC_TRACE(trace_buf);
}
if (is_change)
rtw_btc_run_coex(btc, BTC_RSN_WLSTATUS);
}
#endif
/* #if (BT_SUPPORT == 1 && COEX_SUPPORT == 1) */
================================================
FILE: hal/btc/halbtccommon.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#if (BT_SUPPORT == 1 && COEX_SUPPORT == 1)
/* *******************************************
* The following is interface which will notify coex module.
* ********************************************/
void rtw_btc_ex_power_on_setting(struct btc_coexist *btc);
void rtw_btc_ex_pre_load_firmware(struct btc_coexist *btc);
void rtw_btc_ex_init_hw_config(struct btc_coexist *btc, boolean wifi_only);
void rtw_btc_ex_init_coex_dm(struct btc_coexist *btc);
void rtw_btc_ex_ips_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_lps_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_scan_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_scan_notify_without_bt(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_switchband_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_switchband_notify_without_bt(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_connect_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_media_status_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_specific_packet_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_bt_info_notify(struct btc_coexist *btc, u8 *tmp_buf, u8 length);
void rtw_btc_ex_wl_fwdbginfo_notify(struct btc_coexist *btc, u8 *tmp_buf,
u8 length);
void rtw_btc_ex_rx_rate_change_notify(struct btc_coexist *btc,
BOOLEAN is_data_frame,
u8 btc_rate_id);
void rtw_btc_ex_tx_rate_change_notify(struct btc_coexist *btc, u8 tx_rate,
u8 tx_retry_ratio, u8 macid);
void rtw_btc_ex_rf_status_notify(struct btc_coexist *btc, u8 type);
void rtw_btc_ex_halt_notify(struct btc_coexist *btc);
void rtw_btc_ex_pnp_notify(struct btc_coexist *btc, u8 pnp_state);
void rtw_btc_ex_coex_dm_reset(struct btc_coexist *btc);
void rtw_btc_ex_periodical(struct btc_coexist *btc);
void rtw_btc_ex_timerup_notify(struct btc_coexist *btc, u32 type);
void rtw_btc_ex_wl_status_change_notify(struct btc_coexist *btc, u32 type);
void rtw_btc_ex_display_simple_coex_info(struct btc_coexist *btc);
void rtw_btc_ex_display_coex_info(struct btc_coexist *btc);
void rtw_btc_ex_dbg_control(struct btc_coexist *btc, u8 op_code, u8 op_len,
u8 *pdata);
#else
#define rtw_btc_ex_power_on_setting(btc)
#define rtw_btc_ex_pre_load_firmware(btc)
#define rtw_btc_ex_init_hw_config(btc, wifi_only)
#define rtw_btc_ex_init_coex_dm(btc)
#define rtw_btc_ex_ips_notify(btc, type)
#define rtw_btc_ex_lps_notify(btc, type)
#define rtw_btc_ex_scan_notify(btc, type)
#define rtw_btc_ex_scan_notify_without_bt(btc, type)
#define rtw_btc_ex_switchband_notify(btc, type)
#define rtw_btc_ex_switchband_notify_without_bt(btc, type)
#define rtw_btc_ex_connect_notify(btc, type)
#define rtw_btc_ex_media_status_notify(btc, type)
#define rtw_btc_ex_specific_packet_notify(btc, type)
#define rtw_btc_ex_bt_info_notify(btc, tmp_buf, length)
#define rtw_btc_ex_wl_fwdbginfo_notify(btc, tmp_buf, length)
#define rtw_btc_ex_rx_rate_change_notify(btc, is_data_frame, btc_rate_id)
#define rtw_btc_ex_tx_rate_change_notify(btcoexist, tx_rate, tx_retry_ratio, \
macid)
#define rtw_btc_ex_rf_status_notify(btc, type)
#define rtw_btc_ex_halt_notify(btc)
#define rtw_btc_ex_pnp_notify(btc, pnp_state)
#define rtw_btc_ex_coex_dm_reset(btc)
#define rtw_btc_ex_periodical(btc)
#define rtw_btc_ex_timerup_notify(btc, type)
#define rtw_btc_ex_wl_status_change_notify(btc, type)
#define rtw_btc_ex_display_coex_info(btc)
#define rtw_btc_ex_dbg_control(btc, op_code, op_len, pdata)
#endif
================================================
FILE: hal/btc/halbtcoutsrc.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HALBTC_OUT_SRC_H__
#define __HALBTC_OUT_SRC_H__
enum {
BTC_CCK_1,
BTC_CCK_2,
BTC_CCK_5_5,
BTC_CCK_11,
BTC_OFDM_6,
BTC_OFDM_9,
BTC_OFDM_12,
BTC_OFDM_18,
BTC_OFDM_24,
BTC_OFDM_36,
BTC_OFDM_48,
BTC_OFDM_54,
BTC_MCS_0,
BTC_MCS_1,
BTC_MCS_2,
BTC_MCS_3,
BTC_MCS_4,
BTC_MCS_5,
BTC_MCS_6,
BTC_MCS_7,
BTC_MCS_8,
BTC_MCS_9,
BTC_MCS_10,
BTC_MCS_11,
BTC_MCS_12,
BTC_MCS_13,
BTC_MCS_14,
BTC_MCS_15,
BTC_MCS_16,
BTC_MCS_17,
BTC_MCS_18,
BTC_MCS_19,
BTC_MCS_20,
BTC_MCS_21,
BTC_MCS_22,
BTC_MCS_23,
BTC_MCS_24,
BTC_MCS_25,
BTC_MCS_26,
BTC_MCS_27,
BTC_MCS_28,
BTC_MCS_29,
BTC_MCS_30,
BTC_MCS_31,
BTC_VHT_1SS_MCS_0,
BTC_VHT_1SS_MCS_1,
BTC_VHT_1SS_MCS_2,
BTC_VHT_1SS_MCS_3,
BTC_VHT_1SS_MCS_4,
BTC_VHT_1SS_MCS_5,
BTC_VHT_1SS_MCS_6,
BTC_VHT_1SS_MCS_7,
BTC_VHT_1SS_MCS_8,
BTC_VHT_1SS_MCS_9,
BTC_VHT_2SS_MCS_0,
BTC_VHT_2SS_MCS_1,
BTC_VHT_2SS_MCS_2,
BTC_VHT_2SS_MCS_3,
BTC_VHT_2SS_MCS_4,
BTC_VHT_2SS_MCS_5,
BTC_VHT_2SS_MCS_6,
BTC_VHT_2SS_MCS_7,
BTC_VHT_2SS_MCS_8,
BTC_VHT_2SS_MCS_9,
BTC_VHT_3SS_MCS_0,
BTC_VHT_3SS_MCS_1,
BTC_VHT_3SS_MCS_2,
BTC_VHT_3SS_MCS_3,
BTC_VHT_3SS_MCS_4,
BTC_VHT_3SS_MCS_5,
BTC_VHT_3SS_MCS_6,
BTC_VHT_3SS_MCS_7,
BTC_VHT_3SS_MCS_8,
BTC_VHT_3SS_MCS_9,
BTC_VHT_4SS_MCS_0,
BTC_VHT_4SS_MCS_1,
BTC_VHT_4SS_MCS_2,
BTC_VHT_4SS_MCS_3,
BTC_VHT_4SS_MCS_4,
BTC_VHT_4SS_MCS_5,
BTC_VHT_4SS_MCS_6,
BTC_VHT_4SS_MCS_7,
BTC_VHT_4SS_MCS_8,
BTC_VHT_4SS_MCS_9,
BTC_MCS_32,
BTC_UNKNOWN,
BTC_PKT_MGNT,
BTC_PKT_CTRL,
BTC_PKT_UNKNOWN,
BTC_PKT_NOT_FOR_ME,
BTC_RATE_MAX
};
enum {
BTC_MULTIPORT_SCC,
BTC_MULTIPORT_MCC_DUAL_CHANNEL,
BTC_MULTIPORT_MCC_DUAL_BAND,
BTC_MULTIPORT_MAX
};
#define BTC_COEX_8822B_COMMON_CODE 0
#define BTC_COEX_OFFLOAD 0
#define BTC_TMP_BUF_SHORT 20
extern u1Byte gl_btc_trace_buf[];
#define BTC_SPRINTF rsprintf
#define BTC_TRACE(_MSG_)\
do {\
if (GLBtcDbgType[COMP_COEX] & BIT(DBG_LOUD)) {\
RTW_INFO("%s", _MSG_);\
} \
} while (0)
#define BT_PrintData(adapter, _MSG_, len, data) RTW_DBG_DUMP((_MSG_), data, len)
#define NORMAL_EXEC FALSE
#define FORCE_EXEC TRUE
#define NM_EXCU FALSE
#define FC_EXCU TRUE
#define BTC_RF_OFF 0x0
#define BTC_RF_ON 0x1
#define BTC_RF_A 0x0
#define BTC_RF_B 0x1
#define BTC_RF_C 0x2
#define BTC_RF_D 0x3
#define BTC_SMSP SINGLEMAC_SINGLEPHY
#define BTC_DMDP DUALMAC_DUALPHY
#define BTC_DMSP DUALMAC_SINGLEPHY
#define BTC_MP_UNKNOWN 0xff
#define BT_COEX_ANT_TYPE_PG 0
#define BT_COEX_ANT_TYPE_ANTDIV 1
#define BT_COEX_ANT_TYPE_DETECTED 2
#define BTC_MIMO_PS_STATIC 0 /* 1ss */
#define BTC_MIMO_PS_DYNAMIC 1 /* 2ss */
#define BTC_RATE_DISABLE 0
#define BTC_RATE_ENABLE 1
/* single Antenna definition */
#define BTC_ANT_PATH_WIFI 0
#define BTC_ANT_PATH_BT 1
#define BTC_ANT_PATH_PTA 2
#define BTC_ANT_PATH_WIFI5G 3
#define BTC_ANT_PATH_AUTO 4
/* dual Antenna definition */
#define BTC_ANT_WIFI_AT_MAIN 0
#define BTC_ANT_WIFI_AT_AUX 1
#define BTC_ANT_WIFI_AT_DIVERSITY 2
/* coupler Antenna definition */
#define BTC_ANT_WIFI_AT_CPL_MAIN 0
#define BTC_ANT_WIFI_AT_CPL_AUX 1
typedef enum _BTC_POWERSAVE_TYPE {
BTC_PS_WIFI_NATIVE = 0, /* wifi original power save behavior */
BTC_PS_LPS_ON = 1,
BTC_PS_LPS_OFF = 2,
BTC_PS_MAX
} BTC_POWERSAVE_TYPE, *PBTC_POWERSAVE_TYPE;
typedef enum _BTC_BT_REG_TYPE {
BTC_BT_REG_RF = 0,
BTC_BT_REG_MODEM = 1,
BTC_BT_REG_BLUEWIZE = 2,
BTC_BT_REG_VENDOR = 3,
BTC_BT_REG_LE = 4,
BTC_BT_REG_MAX
} BTC_BT_REG_TYPE, *PBTC_BT_REG_TYPE;
typedef enum _BTC_CHIP_INTERFACE {
BTC_INTF_UNKNOWN = 0,
BTC_INTF_PCI = 1,
BTC_INTF_USB = 2,
BTC_INTF_SDIO = 3,
BTC_INTF_MAX
} BTC_CHIP_INTERFACE, *PBTC_CHIP_INTERFACE;
typedef enum _BTC_CHIP_TYPE {
BTC_CHIP_UNDEF = 0,
BTC_CHIP_CSR_BC4 = 1,
BTC_CHIP_CSR_BC8 = 2,
BTC_CHIP_RTL8723A = 3,
BTC_CHIP_RTL8821 = 4,
BTC_CHIP_RTL8723B = 5,
BTC_CHIP_RTL8822B = 6,
BTC_CHIP_RTL8822C = 7,
BTC_CHIP_RTL8821C = 8,
BTC_CHIP_RTL8821A = 9,
BTC_CHIP_RTL8723D = 10,
BTC_CHIP_RTL8703B = 11,
BTC_CHIP_RTL8725A = 12,
BTC_CHIP_MAX
} BTC_CHIP_TYPE, *PBTC_CHIP_TYPE;
/* following is for wifi link status */
#define WIFI_STA_CONNECTED BIT0
#define WIFI_AP_CONNECTED BIT1
#define WIFI_HS_CONNECTED BIT2
#define WIFI_P2P_GO_CONNECTED BIT3
#define WIFI_P2P_GC_CONNECTED BIT4
/* following is for command line utility */
#define CL_SPRINTF rsprintf
#define CL_PRINTF DCMD_Printf
#define CL_STRNCAT(dst, dst_size, src, src_size) rstrncat(dst, src, src_size)
static const char *const glbt_info_src[] = {
"BT Info[wifi fw]",
"BT Info[bt rsp]",
"BT Info[bt auto report]",
};
#define BTC_INFO_FTP BIT(7)
#define BTC_INFO_A2DP BIT(6)
#define BTC_INFO_HID BIT(5)
#define BTC_INFO_SCO_BUSY BIT(4)
#define BTC_INFO_ACL_BUSY BIT(3)
#define BTC_INFO_INQ_PAGE BIT(2)
#define BTC_INFO_SCO_ESCO BIT(1)
#define BTC_INFO_CONNECTION BIT(0)
#define BTC_BTINFO_LENGTH_MAX 10
enum btc_gnt_setup_state {
BTC_GNT_SET_SW_LOW = 0x0,
BTC_GNT_SET_SW_HIGH = 0x1,
BTC_GNT_SET_HW_PTA = 0x2,
BTC_GNT_SET_MAX
};
enum btc_gnt_setup_state_2 {
BTC_GNT_SW_LOW = 0x0,
BTC_GNT_SW_HIGH = 0x1,
BTC_GNT_HW_PTA = 0x2,
BTC_GNT_MAX
};
enum btc_path_ctrl_owner {
BTC_OWNER_BT = 0x0,
BTC_OWNER_WL = 0x1,
BTC_OWNER_MAX
};
enum btc_gnt_ctrl_type {
BTC_GNT_CTRL_BY_PTA = 0x0,
BTC_GNT_CTRL_BY_SW = 0x1,
BTC_GNT_CTRL_MAX
};
enum btc_gnt_ctrl_block {
BTC_GNT_BLOCK_RFC_BB = 0x0,
BTC_GNT_BLOCK_RFC = 0x1,
BTC_GNT_BLOCK_BB = 0x2,
BTC_GNT_BLOCK_MAX
};
enum btc_lte_coex_table_type {
BTC_CTT_WL_VS_LTE = 0x0,
BTC_CTT_BT_VS_LTE = 0x1,
BTC_CTT_MAX
};
enum btc_lte_break_table_type {
BTC_LBTT_WL_BREAK_LTE = 0x0,
BTC_LBTT_BT_BREAK_LTE = 0x1,
BTC_LBTT_LTE_BREAK_WL = 0x2,
BTC_LBTT_LTE_BREAK_BT = 0x3,
BTC_LBTT_MAX
};
enum btc_btinfo_src {
BTC_BTINFO_SRC_WL_FW = 0x0,
BTC_BTINFO_SRC_BT_RSP = 0x1,
BTC_BTINFO_SRC_BT_ACT = 0x2,
BTC_BTINFO_SRC_BT_IQK = 0x3,
BTC_BTINFO_SRC_BT_SCBD = 0x4,
BTC_BTINFO_SRC_H2C60 = 0x5,
BTC_BTINFO_SRC_MAX
};
enum btc_bt_profile {
BTC_BTPROFILE_NONE = 0,
BTC_BTPROFILE_HFP = BIT(0),
BTC_BTPROFILE_HID = BIT(1),
BTC_BTPROFILE_A2DP = BIT(2),
BTC_BTPROFILE_PAN = BIT(3),
BTC_BTPROFILE_MAX = 0xf
};
static const char *const bt_profile_string[] = {
"None",
"HFP",
"HID",
"HID + HFP",
"A2DP",
"A2DP + HFP",
"A2DP + HID",
"PAN + HID + HFP",
"PAN",
"PAN + HFP",
"PAN + HID",
"PAN + HID + HFP",
"PAN + A2DP",
"PAN + A2DP + HFP",
"PAN + A2DP + HID",
"PAN + A2DP + HID + HFP"
};
enum btc_bt_status {
BTC_BTSTATUS_NCON_IDLE = 0x0,
BTC_BTSTATUS_CON_IDLE = 0x1,
BTC_BTSTATUS_INQ_PAGE = 0x2,
BTC_BTSTATUS_ACL_BUSY = 0x3,
BTC_BTSTATUS_SCO_BUSY = 0x4,
BTC_BTSTATUS_ACL_SCO_BUSY = 0x5,
BTC_BTSTATUS_MAX
};
static const char *const bt_status_string[] = {
"BT Non-Connected-idle",
"BT Connected-idle",
"BT Inq-page",
"BT ACL-busy",
"BT SCO-busy",
"BT ACL-SCO-busy",
"BT Non-Defined-state"
};
enum btc_coex_algo {
BTC_COEX_NOPROFILE = 0x0,
BTC_COEX_HFP = 0x1,
BTC_COEX_HID = 0x2,
BTC_COEX_A2DP = 0x3,
BTC_COEX_PAN = 0x4,
BTC_COEX_A2DP_HID = 0x5,
BTC_COEX_A2DP_PAN = 0x6,
BTC_COEX_PAN_HID = 0x7,
BTC_COEX_A2DP_PAN_HID = 0x8,
BTC_COEX_MAX
};
static const char *const coex_algo_string[] = {
"No Profile",
"HFP",
"HID",
"A2DP",
"PAN",
"A2DP + HID",
"A2DP + PAN",
"PAN + HID",
"A2DP + PAN + HID"
};
enum btc_ext_ant_switch_type {
BTC_SWITCH_NONE = 0x0,
BTC_SWITCH_SPDT = 0x1,
BTC_SWITCH_SP3T = 0x2,
BTC_SWITCH_ANTMAX
};
enum btc_ext_ant_switch_ctrl_type {
BTC_SWITCH_CTRL_BY_BBSW = 0x0,
BTC_SWITCH_CTRL_BY_PTA = 0x1,
BTC_SWITCH_CTRL_BY_ANTDIV = 0x2,
BTC_SWITCH_CTRL_BY_MAC = 0x3,
BTC_SWITCH_CTRL_BY_BT = 0x4,
BTC_SWITCH_CTRL_BY_FW = 0x5,
BTC_SWITCH_CTRL_MAX
};
enum btc_ext_ant_switch_pos_type {
BTC_SWITCH_TO_BT = 0x0,
BTC_SWITCH_TO_WLG = 0x1,
BTC_SWITCH_TO_WLA = 0x2,
BTC_SWITCH_TO_NOCARE = 0x3,
BTC_SWITCH_TO_WLG_BT = 0x4,
BTC_SWITCH_TO_MAX
};
enum btx_set_ant_phase {
BTC_ANT_INIT = 0x0,
BTC_ANT_WONLY = 0x1,
BTC_ANT_WOFF = 0x2,
BTC_ANT_2G = 0x3,
BTC_ANT_5G = 0x4,
BTC_ANT_BTMP = 0x5,
BTC_ANT_POWERON = 0x6,
BTC_ANT_2G_WL = 0x7,
BTC_ANT_2G_BT = 0x8,
BTC_ANT_MCC = 0x9,
BTC_ANT_2G_WLBT = 0xa,
BTC_ANT_2G_FREERUN = 0xb,
BTC_ANT_MAX
};
/*ADD SCOREBOARD TO FIX BT LPS 32K ISSUE WHILE WL BUSY*/
enum btc_wl2bt_scoreboard {
BTC_SCBD_ACTIVE = BIT(0),
BTC_SCBD_ON = BIT(1),
BTC_SCBD_SCAN = BIT(2),
BTC_SCBD_UNDERTEST = BIT(3),
BTC_SCBD_RXGAIN = BIT(4),
BTC_SCBD_WLBUSY = BIT(7),
BTC_SCBD_EXTFEM = BIT(8),
BTC_SCBD_TDMA = BIT(9),
BTC_SCBD_FIX2M = BIT(10),
BTC_SCBD_ALL = 0xffff
};
enum btc_bt2wl_scoreboard {
BTC_SCBD_BT_ONOFF = BIT(1),
BTC_SCBD_BT_LPS = BIT(7)
};
enum btc_runreason {
BTC_RSN_2GSCANSTART = 0x0,
BTC_RSN_5GSCANSTART = 0x1,
BTC_RSN_SCANFINISH = 0x2,
BTC_RSN_2GSWITCHBAND = 0x3,
BTC_RSN_5GSWITCHBAND = 0x4,
BTC_RSN_2GCONSTART = 0x5,
BTC_RSN_5GCONSTART = 0x6,
BTC_RSN_2GCONFINISH = 0x7,
BTC_RSN_5GCONFINISH = 0x8,
BTC_RSN_2GMEDIA = 0x9,
BTC_RSN_5GMEDIA = 0xa,
BTC_RSN_MEDIADISCON = 0xb,
BTC_RSN_2GSPECIALPKT = 0xc,
BTC_RSN_5GSPECIALPKT = 0xd,
BTC_RSN_BTINFO = 0xe,
BTC_RSN_PERIODICAL = 0xf,
BTC_RSN_PNP = 0x10,
BTC_RSN_LPS = 0x11,
BTC_RSN_TIMERUP = 0x12,
BTC_RSN_WLSTATUS = 0x13,
BTC_RSN_MAX
};
static const char *const run_reason_string[] = {
"2G_SCAN_START",
"5G_SCAN_START",
"SCAN_FINISH",
"2G_SWITCH_BAND",
"5G_SWITCH_BAND",
"2G_CONNECT_START",
"5G_CONNECT_START",
"2G_CONNECT_FINISH",
"5G_CONNECT_FINISH",
"2G_MEDIA_STATUS",
"5G_MEDIA_STATUS",
"MEDIA_DISCONNECT",
"2G_SPECIALPKT",
"5G_SPECIALPKT",
"BTINFO",
"PERIODICAL",
"PNPNotify",
"LPSNotify",
"TimerUp",
"WL_STATUS_CHANGE",
};
enum btc_wl_link_mode {
BTC_WLINK_2G1PORT = 0x0,
BTC_WLINK_2GMPORT = 0x1,
BTC_WLINK_25GMPORT = 0x2,
BTC_WLINK_5G = 0x3,
BTC_WLINK_2GGO = 0x4,
BTC_WLINK_2GGC = 0x5,
BTC_WLINK_BTMR = 0x6,
BTC_WLINK_MAX
};
static const char *const coex_mode_string[] = {
"2G-SP",
"2G-MP",
"25G-MP",
"5G",
"2G-P2P-GO",
"2G-P2P-GC",
"BT-MR"
};
enum btc_bt_state_cnt {
BTC_CNT_BT_RETRY = 0x0,
BTC_CNT_BT_REINIT = 0x1,
BTC_CNT_BT_POPEVENT = 0x2,
BTC_CNT_BT_SETUPLINK = 0x3,
BTC_CNT_BT_IGNWLANACT = 0x4,
BTC_CNT_BT_INQ = 0x5,
BTC_CNT_BT_PAGE = 0x6,
BTC_CNT_BT_ROLESWITCH = 0x7,
BTC_CNT_BT_AFHUPDATE = 0x8,
BTC_CNT_BT_DISABLE = 0x9,
BTC_CNT_BT_INFOUPDATE = 0xa,
BTC_CNT_BT_IQK = 0xb,
BTC_CNT_BT_IQKFAIL = 0xc,
BTC_CNT_BT_MAX
};
enum btc_wl_state_cnt {
BTC_CNT_WL_SCANAP = 0x0,
BTC_CNT_WL_ARP = 0x1,
BTC_CNT_WL_GNTERR = 0x2,
BTC_CNT_WL_PSFAIL = 0x3,
BTC_CNT_WL_COEXRUN = 0x4,
BTC_CNT_WL_COEXINFO1 = 0x5,
BTC_CNT_WL_COEXINFO2 = 0x6,
BTC_CNT_WL_AUTOSLOT_HANG = 0x7,
BTC_CNT_WL_NOISY0 = 0x8,
BTC_CNT_WL_NOISY1 = 0x9,
BTC_CNT_WL_NOISY2 = 0xa,
BTC_CNT_WL_ACTIVEPORT = 0xb,
BTC_CNT_WL_5MS_NOEXTEND = 0xc,
BTC_CNT_WL_FW_NOTIFY = 0xd,
BTC_CNT_WL_MAX
};
enum btc_wl_crc_cnt {
BTC_WLCRC_11BOK = 0x0,
BTC_WLCRC_11GOK = 0x1,
BTC_WLCRC_11NOK = 0x2,
BTC_WLCRC_11VHTOK = 0x3,
BTC_WLCRC_11BERR = 0x4,
BTC_WLCRC_11GERR = 0x5,
BTC_WLCRC_11NERR = 0x6,
BTC_WLCRC_11VHTERR = 0x7,
BTC_WLCRC_MAX
};
enum btc_timer_cnt {
BTC_TIMER_WL_STAYBUSY = 0x0,
BTC_TIMER_WL_COEXFREEZE = 0x1,
BTC_TIMER_WL_SPECPKT = 0x2,
BTC_TIMER_WL_CONNPKT = 0x3,
BTC_TIMER_WL_PNPWAKEUP = 0x4,
BTC_TIMER_WL_CCKLOCK = 0x5,
BTC_TIMER_WL_FWDBG = 0x6,
BTC_TIMER_BT_RELINK = 0x7,
BTC_TIMER_BT_REENABLE = 0x8,
BTC_TIMER_MAX
};
enum btc_wl_status_change {
BTC_WLSTATUS_CHANGE_TOIDLE = 0x0,
BTC_WLSTATUS_CHANGE_TOBUSY = 0x1,
BTC_WLSTATUS_CHANGE_RSSI = 0x2,
BTC_WLSTATUS_CHANGE_LINKINFO = 0x3,
BTC_WLSTATUS_CHANGE_DIR = 0x4,
BTC_WLSTATUS_CHANGE_NOISY = 0x5,
BTC_WLSTATUS_CHANGE_MAX
};
enum btc_commom_chip_setup {
BTC_CSETUP_INIT_HW = 0x0,
BTC_CSETUP_ANT_SWITCH = 0x1,
BTC_CSETUP_GNT_FIX = 0x2,
BTC_CSETUP_GNT_DEBUG = 0x3,
BTC_CSETUP_RFE_TYPE = 0x4,
BTC_CSETUP_COEXINFO_HW = 0x5,
BTC_CSETUP_WL_TX_POWER = 0x6,
BTC_CSETUP_WL_RX_GAIN = 0x7,
BTC_CSETUP_WLAN_ACT_IPS = 0x8,
BTC_CSETUP_MAX
};
enum btc_indirect_reg_type {
BTC_INDIRECT_1700 = 0x0,
BTC_INDIRECT_7C0 = 0x1,
BTC_INDIRECT_MAX
};
enum btc_pstdma_type {
BTC_PSTDMA_FORCE_LPSOFF = 0x0,
BTC_PSTDMA_FORCE_LPSON = 0x1,
BTC_PSTDMA_MAX
};
enum btc_btrssi_type {
BTC_BTRSSI_RATIO = 0x0,
BTC_BTRSSI_DBM = 0x1,
BTC_BTRSSI_MAX
};
enum btc_wl_priority_mask {
BTC_WLPRI_RX_RSP = 2,
BTC_WLPRI_TX_RSP = 3,
BTC_WLPRI_TX_BEACON = 4,
BTC_WLPRI_TX_OFDM = 11,
BTC_WLPRI_TX_CCK = 12,
BTC_WLPRI_TX_BEACONQ = 27,
BTC_WLPRI_RX_CCK = 28,
BTC_WLPRI_RX_OFDM = 29,
BTC_WLPRI_MAX
};
struct btc_board_info {
/* The following is some board information */
u8 bt_chip_type;
u8 pg_ant_num; /* pg ant number */
u8 btdm_ant_num; /* ant number for btdm */
u8 btdm_ant_num_by_ant_det; /* ant number for btdm after antenna detection */
u8 btdm_ant_pos; /* Bryant Add to indicate Antenna Position for (pg_ant_num = 2) && (btdm_ant_num =1) (DPDT+1Ant case) */
u8 single_ant_path; /* current used for 8723b only, 1=>s0, 0=>s1 */
boolean tfbga_package; /* for Antenna detect threshold */
boolean btdm_ant_det_finish;
boolean btdm_ant_det_already_init_phydm;
u8 ant_type;
u8 rfe_type;
u8 ant_div_cfg;
boolean btdm_ant_det_complete_fail;
u8 ant_det_result;
boolean ant_det_result_five_complete;
u32 antdetval;
u8 customerID;
u8 customer_id;
u8 ant_distance; /* WL-BT antenna space for non-shared antenna */
};
struct btc_coex_dm {
boolean cur_ignore_wlan_act;
boolean cur_ps_tdma_on;
boolean cur_low_penalty_ra;
boolean cur_wl_rx_low_gain_en;
u8 bt_rssi_state[4];
u8 wl_rssi_state[4];
u8 cur_ps_tdma;
u8 ps_tdma_para[5];
u8 fw_tdma_para[5];
u8 cur_lps;
u8 cur_rpwm;
u8 cur_bt_pwr_lvl;
u8 cur_bt_lna_lvl;
u8 cur_wl_pwr_lvl;
u8 cur_algorithm;
u8 bt_status;
u8 wl_chnl_info[3];
u8 cur_toggle_para[6];
u8 cur_val0x6cc;
u32 cur_val0x6c0;
u32 cur_val0x6c4;
u32 cur_val0x6c8;
u32 cur_ant_pos_type;
u32 cur_switch_status;
u32 setting_tdma;
};
struct btc_coex_sta {
boolean coex_freeze;
boolean coex_freerun;
boolean tdma_bt_autoslot;
boolean rf4ce_en;
boolean is_no_wl_5ms_extend;
boolean bt_disabled;
boolean bt_disabled_pre;
boolean bt_link_exist;
boolean bt_whck_test;
boolean bt_inq_page;
boolean bt_inq;
boolean bt_page;
boolean bt_ble_voice;
boolean bt_ble_exist;
boolean bt_hfp_exist;
boolean bt_a2dp_exist;
boolean bt_hid_exist;
boolean bt_pan_exist; // PAN or OPP
boolean bt_opp_exist; //OPP only
boolean bt_msft_mr_exist;
boolean bt_acl_busy;
boolean bt_fix_2M;
boolean bt_setup_link;
boolean bt_multi_link;
boolean bt_a2dp_sink;
boolean bt_reenable;
boolean bt_ble_scan_en;
boolean bt_slave;
boolean bt_a2dp_active;
boolean bt_slave_latency;
boolean bt_init_scan;
boolean bt_418_hid_exist;
boolean bt_mesh;
boolean wl_under_lps;
boolean wl_under_ips;
boolean wl_under_4way;
boolean wl_hi_pri_task1;
boolean wl_hi_pri_task2;
boolean wl_cck_lock;
boolean wl_cck_lock_pre;
boolean wl_cck_lock_ever;
boolean wl_force_lps_ctrl;
boolean wl_busy_pre;
boolean wl_gl_busy;
boolean wl_gl_busy_pre;
boolean wl_linkscan_proc;
boolean wl_mimo_ps;
boolean wl_ps_state_fail;
boolean wl_cck_dead_lock_ap;
boolean wl_tx_limit_en;
boolean wl_ampdu_limit_en;
boolean wl_rxagg_limit_en;
boolean wl_connecting;
boolean wl_pnp_wakeup;
boolean wl_slot_toggle;
boolean wl_slot_toggle_change; /* if toggle to no-toggle */
u8 coex_table_type;
u8 coex_run_reason;
u8 tdma_byte4_modify_pre;
u8 kt_ver;
u8 gnt_workaround_state;
u8 tdma_timer_base;
u8 bt_rssi;
u8 bt_profile_num;
u8 bt_profile_num_pre;
u8 bt_info_c2h[BTC_BTINFO_SRC_MAX][BTC_BTINFO_LENGTH_MAX];
u8 bt_info_lb2;
u8 bt_info_lb3;
u8 bt_info_hb0;
u8 bt_info_hb1;
u8 bt_info_hb2;
u8 bt_info_hb3;
u8 bt_ble_scan_type;
u8 bt_afh_map[10];
u8 bt_a2dp_vendor_id;
u8 bt_hid_pair_num;
u8 bt_hid_slot;
u8 bt_a2dp_bitpool;
u8 bt_iqk_state;
u8 bt_sut_pwr_lvl[4];
u8 bt_golden_rx_shift[4];
u8 bt_ext_autoslot_thres;
u8 wl_pnp_state_pre;
u8 wl_noisy_level;
u8 wl_fw_dbg_info[10];
u8 wl_fw_dbg_info_pre[10];
u8 wl_rx_rate;
u8 wl_tx_rate;
u8 wl_rts_rx_rate;
u8 wl_center_ch;
u8 wl_tx_macid;
u8 wl_tx_retry_ratio;
u8 wl_coex_mode;
u8 wl_iot_peer;
u8 wl_ra_thres;
u8 wl_ampdulen_backup;
u8 wl_rxagg_size;
u8 wl_toggle_para[6];
u16 score_board_BW;
u16 score_board_WB;
u16 bt_reg_vendor_ac;
u16 bt_reg_vendor_ae;
u16 bt_reg_modem_a;
u16 bt_reg_rf_2;
u16 wl_txlimit_backup;
u32 hi_pri_tx;
u32 hi_pri_rx;
u32 lo_pri_tx;
u32 lo_pri_rx;
u32 bt_supported_feature;
u32 bt_supported_version;
u32 bt_ble_scan_para[3];
u32 bt_a2dp_device_name;
u32 wl_arfb1_backup;
u32 wl_arfb2_backup;
u32 wl_traffic_dir;
u32 wl_bw;
u32 cnt_bt_info_c2h[BTC_BTINFO_SRC_MAX];
u32 cnt_bt[BTC_CNT_BT_MAX];
u32 cnt_wl[BTC_CNT_WL_MAX];
u32 cnt_timer[BTC_TIMER_MAX];
};
struct btc_rfe_type {
boolean ant_switch_exist;
boolean ant_switch_diversity; /* If diversity on */
boolean ant_switch_with_bt; /* If WL_2G/BT use ext-switch at shared-ant */
u8 rfe_module_type;
u8 ant_switch_type;
u8 ant_switch_polarity;
boolean band_switch_exist;
u8 band_switch_type; /* 0:DPDT, 1:SPDT */
u8 band_switch_polarity;
/* If TRUE: WLG at BTG, If FALSE: WLG at WLAG */
boolean wlg_at_btg;
};
struct btc_wifi_link_info_ext {
boolean is_all_under_5g;
boolean is_mcc_25g;
boolean is_p2p_connected;
boolean is_ap_mode;
boolean is_scan;
boolean is_link;
boolean is_roam;
boolean is_4way;
boolean is_32k;
boolean is_connected;
u8 num_of_active_port;
u32 port_connect_status;
u32 traffic_dir;
u32 wifi_bw;
};
struct btc_coex_table_para {
u32 bt; //0x6c0
u32 wl; //0x6c4
};
struct btc_tdma_para {
u8 para[5];
};
struct btc_reg_byte_modify {
u32 addr;
u8 bitmask;
u8 val;
};
struct btc_5g_afh_map {
u32 wl_5g_ch;
u8 bt_skip_ch;
u8 bt_skip_span;
};
struct btc_rf_para {
u8 wl_pwr_dec_lvl;
u8 bt_pwr_dec_lvl;
boolean wl_low_gain_en;
u8 bt_lna_lvl;
};
typedef enum _BTC_DBG_OPCODE {
BTC_DBG_SET_COEX_NORMAL = 0x0,
BTC_DBG_SET_COEX_WIFI_ONLY = 0x1,
BTC_DBG_SET_COEX_BT_ONLY = 0x2,
BTC_DBG_SET_COEX_DEC_BT_PWR = 0x3,
BTC_DBG_SET_COEX_BT_AFH_MAP = 0x4,
BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT = 0x5,
BTC_DBG_SET_COEX_MANUAL_CTRL = 0x6,
BTC_DBG_MAX
} BTC_DBG_OPCODE, *PBTC_DBG_OPCODE;
typedef enum _BTC_RSSI_STATE {
BTC_RSSI_STATE_HIGH = 0x0,
BTC_RSSI_STATE_MEDIUM = 0x1,
BTC_RSSI_STATE_LOW = 0x2,
BTC_RSSI_STATE_STAY_HIGH = 0x3,
BTC_RSSI_STATE_STAY_MEDIUM = 0x4,
BTC_RSSI_STATE_STAY_LOW = 0x5,
BTC_RSSI_MAX
} BTC_RSSI_STATE, *PBTC_RSSI_STATE;
#define BTC_RSSI_HIGH(_rssi_) ((_rssi_ == BTC_RSSI_STATE_HIGH || _rssi_ == BTC_RSSI_STATE_STAY_HIGH) ? TRUE:FALSE)
#define BTC_RSSI_MEDIUM(_rssi_) ((_rssi_ == BTC_RSSI_STATE_MEDIUM || _rssi_ == BTC_RSSI_STATE_STAY_MEDIUM) ? TRUE:FALSE)
#define BTC_RSSI_LOW(_rssi_) ((_rssi_ == BTC_RSSI_STATE_LOW || _rssi_ == BTC_RSSI_STATE_STAY_LOW) ? TRUE:FALSE)
typedef enum _BTC_WIFI_ROLE {
BTC_ROLE_STATION = 0x0,
BTC_ROLE_AP = 0x1,
BTC_ROLE_IBSS = 0x2,
BTC_ROLE_HS_MODE = 0x3,
BTC_ROLE_MAX
} BTC_WIFI_ROLE, *PBTC_WIFI_ROLE;
typedef enum _BTC_WIRELESS_FREQ {
BTC_FREQ_2_4G = 0x0,
BTC_FREQ_5G = 0x1,
BTC_FREQ_25G = 0x2,
BTC_FREQ_MAX
} BTC_WIRELESS_FREQ, *PBTC_WIRELESS_FREQ;
typedef enum _BTC_WIFI_BW_MODE {
BTC_WIFI_BW_LEGACY = 0x0,
BTC_WIFI_BW_HT20 = 0x1,
BTC_WIFI_BW_HT40 = 0x2,
BTC_WIFI_BW_HT80 = 0x3,
BTC_WIFI_BW_HT160 = 0x4,
BTC_WIFI_BW_MAX
} BTC_WIFI_BW_MODE, *PBTC_WIFI_BW_MODE;
typedef enum _BTC_WIFI_TRAFFIC_DIR {
BTC_WIFI_TRAFFIC_TX = 0x0,
BTC_WIFI_TRAFFIC_RX = 0x1,
BTC_WIFI_TRAFFIC_MAX
} BTC_WIFI_TRAFFIC_DIR, *PBTC_WIFI_TRAFFIC_DIR;
typedef enum _BTC_WIFI_PNP {
BTC_WIFI_PNP_WAKE_UP = 0x0,
BTC_WIFI_PNP_SLEEP = 0x1,
BTC_WIFI_PNP_SLEEP_KEEP_ANT = 0x2,
BTC_WIFI_PNP_WOWLAN = 0x3,
BTC_WIFI_PNP_MAX
} BTC_WIFI_PNP, *PBTC_WIFI_PNP;
typedef enum _BTC_IOT_PEER {
BTC_IOT_PEER_UNKNOWN = 0,
BTC_IOT_PEER_REALTEK = 1,
BTC_IOT_PEER_REALTEK_92SE = 2,
BTC_IOT_PEER_BROADCOM = 3,
BTC_IOT_PEER_RALINK = 4,
BTC_IOT_PEER_ATHEROS = 5,
BTC_IOT_PEER_CISCO = 6,
BTC_IOT_PEER_MERU = 7,
BTC_IOT_PEER_MARVELL = 8,
BTC_IOT_PEER_REALTEK_SOFTAP = 9, /* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 */
BTC_IOT_PEER_SELF_SOFTAP = 10, /* Self is SoftAP */
BTC_IOT_PEER_AIRGO = 11,
BTC_IOT_PEER_INTEL = 12,
BTC_IOT_PEER_RTK_APCLIENT = 13,
BTC_IOT_PEER_REALTEK_81XX = 14,
BTC_IOT_PEER_REALTEK_WOW = 15,
BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 16,
BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,
BTC_IOT_PEER_MAX,
} BTC_IOT_PEER, *PBTC_IOT_PEER;
/* for 8723b-d cut large current issue */
typedef enum _BTC_WIFI_COEX_STATE {
BTC_WIFI_STAT_INIT,
BTC_WIFI_STAT_IQK,
BTC_WIFI_STAT_NORMAL_OFF,
BTC_WIFI_STAT_MP_OFF,
BTC_WIFI_STAT_NORMAL,
BTC_WIFI_STAT_ANT_DIV,
BTC_WIFI_STAT_MAX
} BTC_WIFI_COEX_STATE, *PBTC_WIFI_COEX_STATE;
typedef enum _BTC_ANT_TYPE {
BTC_ANT_TYPE_0,
BTC_ANT_TYPE_1,
BTC_ANT_TYPE_2,
BTC_ANT_TYPE_3,
BTC_ANT_TYPE_4,
BTC_ANT_TYPE_MAX
} BTC_ANT_TYPE, *PBTC_ANT_TYPE;
typedef enum _BTC_VENDOR {
BTC_VENDOR_LENOVO,
BTC_VENDOR_ASUS,
BTC_VENDOR_OTHER
} BTC_VENDOR, *PBTC_VENDOR;
/* defined for BFP_BTC_GET */
typedef enum _BTC_GET_TYPE {
/* type BOOLEAN */
BTC_GET_BL_HS_OPERATION,
BTC_GET_BL_HS_CONNECTING,
BTC_GET_BL_WIFI_FW_READY,
BTC_GET_BL_WIFI_CONNECTED,
BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED,
BTC_GET_BL_WIFI_LINK_INFO,
BTC_GET_BL_WIFI_BUSY,
BTC_GET_BL_WIFI_SCAN,
BTC_GET_BL_WIFI_LINK,
BTC_GET_BL_WIFI_ROAM,
BTC_GET_BL_WIFI_4_WAY_PROGRESS,
BTC_GET_BL_WIFI_UNDER_5G,
BTC_GET_BL_WIFI_AP_MODE_ENABLE,
BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
BTC_GET_BL_WIFI_UNDER_B_MODE,
BTC_GET_BL_EXT_SWITCH,
BTC_GET_BL_WIFI_IS_IN_MP_MODE,
BTC_GET_BL_IS_ASUS_8723B,
BTC_GET_BL_RF4CE_CONNECTED,
BTC_GET_BL_WIFI_LW_PWR_STATE,
/* type s4Byte */
BTC_GET_S4_WIFI_RSSI,
BTC_GET_S4_HS_RSSI,
/* type u4Byte */
BTC_GET_U4_WIFI_BW,
BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
BTC_GET_U4_WIFI_TRAFFIC_DIR,
BTC_GET_U4_WIFI_FW_VER,
BTC_GET_U4_WIFI_PHY_VER,
BTC_GET_U4_WIFI_LINK_STATUS,
BTC_GET_U4_BT_PATCH_VER,
BTC_GET_U4_VENDOR,
BTC_GET_U4_SUPPORTED_VERSION,
BTC_GET_U4_SUPPORTED_FEATURE,
BTC_GET_U4_BT_DEVICE_INFO,
BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL,
BTC_GET_U4_WIFI_IQK_TOTAL,
BTC_GET_U4_WIFI_IQK_OK,
BTC_GET_U4_WIFI_IQK_FAIL,
/* type u1Byte */
BTC_GET_U1_WIFI_DOT11_CHNL,
BTC_GET_U1_WIFI_CENTRAL_CHNL,
BTC_GET_U1_WIFI_HS_CHNL,
BTC_GET_U1_WIFI_P2P_CHNL,
BTC_GET_U1_MAC_PHY_MODE,
BTC_GET_U1_AP_NUM,
BTC_GET_U1_ANT_TYPE,
BTC_GET_U1_IOT_PEER,
/* type u2Byte */
BTC_GET_U2_BEACON_PERIOD,
/*===== for 1Ant ======*/
BTC_GET_U1_LPS_MODE,
BTC_GET_MAX
} BTC_GET_TYPE, *PBTC_GET_TYPE;
/* defined for BFP_BTC_SET */
typedef enum _BTC_SET_TYPE {
/* type BOOLEAN */
BTC_SET_BL_BT_DISABLE,
BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE,
BTC_SET_BL_BT_TRAFFIC_BUSY,
BTC_SET_BL_BT_LIMITED_DIG,
BTC_SET_BL_FORCE_TO_ROAM,
BTC_SET_BL_TO_REJ_AP_AGG_PKT,
BTC_SET_BL_BT_CTRL_AGG_SIZE,
BTC_SET_BL_INC_SCAN_DEV_NUM,
BTC_SET_BL_BT_TX_RX_MASK,
BTC_SET_BL_MIRACAST_PLUS_BT,
BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL,
BTC_SET_BL_BT_GOLDEN_RX_RANGE,
/* type u1Byte */
BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
BTC_SET_U1_AGG_BUF_SIZE,
/* type trigger some action */
BTC_SET_ACT_GET_BT_RSSI,
BTC_SET_ACT_AGGREGATE_CTRL,
BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
// for mimo ps mode setting
BTC_SET_MIMO_PS_MODE,
/*===== for 1Ant ======*/
/* type BOOLEAN */
/* type u1Byte */
BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
BTC_SET_U1_LPS_VAL,
BTC_SET_U1_RPWM_VAL,
/* type trigger some action */
BTC_SET_ACT_LEAVE_LPS,
BTC_SET_ACT_ENTER_LPS,
BTC_SET_ACT_NORMAL_LPS,
BTC_SET_ACT_PRE_NORMAL_LPS,
BTC_SET_ACT_POST_NORMAL_LPS,
BTC_SET_ACT_DISABLE_LOW_POWER,
BTC_SET_ACT_UPDATE_RAMASK,
BTC_SET_ACT_SEND_MIMO_PS,
/* BT Coex related */
BTC_SET_ACT_CTRL_BT_INFO,
BTC_SET_ACT_CTRL_BT_COEX,
BTC_SET_ACT_CTRL_8723B_ANT,
BTC_SET_RESET_COEX_VAR,
/*=================*/
BTC_SET_MAX
} BTC_SET_TYPE, *PBTC_SET_TYPE;
typedef enum _BTC_DBG_DISP_TYPE {
BTC_DBG_DISP_COEX_STATISTICS = 0x0,
BTC_DBG_DISP_BT_LINK_INFO = 0x1,
BTC_DBG_DISP_WIFI_STATUS = 0x2,
BTC_DBG_DISP_MAX
} BTC_DBG_DISP_TYPE, *PBTC_DBG_DISP_TYPE;
typedef enum _BTC_NOTIFY_TYPE_IPS {
BTC_IPS_LEAVE = 0x0,
BTC_IPS_ENTER = 0x1,
BTC_IPS_MAX
} BTC_NOTIFY_TYPE_IPS, *PBTC_NOTIFY_TYPE_IPS;
typedef enum _BTC_NOTIFY_TYPE_LPS {
BTC_LPS_DISABLE = 0x0,
BTC_LPS_ENABLE = 0x1,
BTC_LPS_MAX
} BTC_NOTIFY_TYPE_LPS, *PBTC_NOTIFY_TYPE_LPS;
typedef enum _BTC_NOTIFY_TYPE_SCAN {
BTC_SCAN_FINISH = 0x0,
BTC_SCAN_START = 0x1,
BTC_SCAN_START_2G = 0x2,
BTC_SCAN_START_5G = 0x3,
BTC_SCAN_MAX
} BTC_NOTIFY_TYPE_SCAN, *PBTC_NOTIFY_TYPE_SCAN;
typedef enum _BTC_NOTIFY_TYPE_SWITCHBAND {
BTC_NOT_SWITCH = 0x0,
BTC_SWITCH_TO_24G = 0x1,
BTC_SWITCH_TO_5G = 0x2,
BTC_SWITCH_TO_24G_NOFORSCAN = 0x3,
BTC_SWITCH_MAX
} BTC_NOTIFY_TYPE_SWITCHBAND, *PBTC_NOTIFY_TYPE_SWITCHBAND;
typedef enum _BTC_NOTIFY_TYPE_ASSOCIATE {
BTC_ASSOCIATE_FINISH = 0x0,
BTC_ASSOCIATE_START = 0x1,
BTC_ASSOCIATE_5G_FINISH = 0x2,
BTC_ASSOCIATE_5G_START = 0x3,
BTC_ASSOCIATE_MAX
} BTC_NOTIFY_TYPE_ASSOCIATE, *PBTC_NOTIFY_TYPE_ASSOCIATE;
typedef enum _BTC_NOTIFY_TYPE_MEDIA_STATUS {
BTC_MEDIA_DISCONNECT = 0x0,
BTC_MEDIA_CONNECT = 0x1,
BTC_MEDIA_CONNECT_5G = 0x02,
BTC_MEDIA_MAX
} BTC_NOTIFY_TYPE_MEDIA_STATUS, *PBTC_NOTIFY_TYPE_MEDIA_STATUS;
typedef enum _BTC_NOTIFY_TYPE_SPECIFIC_PACKET {
BTC_PACKET_UNKNOWN = 0x0,
BTC_PACKET_DHCP = 0x1,
BTC_PACKET_ARP = 0x2,
BTC_PACKET_EAPOL = 0x3,
BTC_PACKET_MAX
} BTC_NOTIFY_TYPE_SPECIFIC_PACKET, *PBTC_NOTIFY_TYPE_SPECIFIC_PACKET;
typedef enum _BTC_NOTIFY_TYPE_STACK_OPERATION {
BTC_STACK_OP_NONE = 0x0,
BTC_STACK_OP_INQ_PAGE_PAIR_START = 0x1,
BTC_STACK_OP_INQ_PAGE_PAIR_FINISH = 0x2,
BTC_STACK_OP_MAX
} BTC_NOTIFY_TYPE_STACK_OPERATION, *PBTC_NOTIFY_TYPE_STACK_OPERATION;
/* Bryant Add */
typedef enum _BTC_ANTENNA_POS {
BTC_ANTENNA_AT_MAIN_PORT = 0x1,
BTC_ANTENNA_AT_AUX_PORT = 0x2,
} BTC_ANTENNA_POS, *PBTC_ANTENNA_POS;
/* Bryant Add */
typedef enum _BTC_BT_OFFON {
BTC_BT_OFF = 0x0,
BTC_BT_ON = 0x1,
} BTC_BTOFFON, *PBTC_BT_OFFON;
#define BTC_5G_BAND 0x80
/*==================================================
For following block is for coex offload
==================================================*/
typedef struct _COL_H2C {
u1Byte opcode;
u1Byte opcode_ver:4;
u1Byte req_num:4;
u1Byte buf[1];
} COL_H2C, *PCOL_H2C;
#define COL_C2H_ACK_HDR_LEN 3
typedef struct _COL_C2H_ACK {
u1Byte status;
u1Byte opcode_ver:4;
u1Byte req_num:4;
u1Byte ret_len;
u1Byte buf[1];
} COL_C2H_ACK, *PCOL_C2H_ACK;
#define COL_C2H_IND_HDR_LEN 3
typedef struct _COL_C2H_IND {
u1Byte type;
u1Byte version;
u1Byte length;
u1Byte data[1];
} COL_C2H_IND, *PCOL_C2H_IND;
/*============================================
NOTE: for debug message, the following define should match
the strings in coexH2cResultString.
============================================*/
typedef enum _COL_H2C_STATUS {
/* c2h status */
COL_STATUS_C2H_OK = 0x00, /* Wifi received H2C request and check content ok. */
COL_STATUS_C2H_UNKNOWN = 0x01, /* Not handled routine */
COL_STATUS_C2H_UNKNOWN_OPCODE = 0x02, /* Invalid OP code, It means that wifi firmware received an undefiend OP code. */
COL_STATUS_C2H_OPCODE_VER_MISMATCH = 0x03, /* Wifi firmware and wifi driver mismatch, need to update wifi driver or wifi or. */
COL_STATUS_C2H_PARAMETER_ERROR = 0x04, /* Error paraneter.(ex: parameters = NULL but it should have values) */
COL_STATUS_C2H_PARAMETER_OUT_OF_RANGE = 0x05, /* Wifi firmware needs to check the parameters from H2C request and return the status.(ex: ch = 500, it's wrong) */
/* other COL status start from here */
COL_STATUS_C2H_REQ_NUM_MISMATCH , /* c2h req_num mismatch, means this c2h is not we expected. */
COL_STATUS_H2C_HALMAC_FAIL , /* HALMAC return fail. */
COL_STATUS_H2C_TIMTOUT , /* not received the c2h response from fw */
COL_STATUS_INVALID_C2H_LEN , /* invalid coex offload c2h ack length, must >= 3 */
COL_STATUS_COEX_DATA_OVERFLOW , /* coex returned length over the c2h ack length. */
COL_STATUS_MAX
} COL_H2C_STATUS, *PCOL_H2C_STATUS;
#define COL_MAX_H2C_REQ_NUM 16
#define COL_H2C_BUF_LEN 20
typedef enum _COL_OPCODE {
COL_OP_WIFI_STATUS_NOTIFY = 0x0,
COL_OP_WIFI_PROGRESS_NOTIFY = 0x1,
COL_OP_WIFI_INFO_NOTIFY = 0x2,
COL_OP_WIFI_POWER_STATE_NOTIFY = 0x3,
COL_OP_SET_CONTROL = 0x4,
COL_OP_GET_CONTROL = 0x5,
COL_OP_WIFI_OPCODE_MAX
} COL_OPCODE, *PCOL_OPCODE;
typedef enum _COL_IND_TYPE {
COL_IND_BT_INFO = 0x0,
COL_IND_PSTDMA = 0x1,
COL_IND_LIMITED_TX_RX = 0x2,
COL_IND_COEX_TABLE = 0x3,
COL_IND_REQ = 0x4,
COL_IND_MAX
} COL_IND_TYPE, *PCOL_IND_TYPE;
typedef struct _COL_SINGLE_H2C_RECORD {
u1Byte h2c_buf[COL_H2C_BUF_LEN]; /* the latest sent h2c buffer */
u4Byte h2c_len;
u1Byte c2h_ack_buf[COL_H2C_BUF_LEN]; /* the latest received c2h buffer */
u4Byte c2h_ack_len;
u4Byte count; /* the total number of the sent h2c command */
u4Byte status[COL_STATUS_MAX]; /* the c2h status for the sent h2c command */
} COL_SINGLE_H2C_RECORD, *PCOL_SINGLE_H2C_RECORD;
typedef struct _COL_SINGLE_C2H_IND_RECORD {
u1Byte ind_buf[COL_H2C_BUF_LEN]; /* the latest received c2h indication buffer */
u4Byte ind_len;
u4Byte count; /* the total number of the rcvd c2h indication */
u4Byte status[COL_STATUS_MAX]; /* the c2h indication verified status */
} COL_SINGLE_C2H_IND_RECORD, *PCOL_SINGLE_C2H_IND_RECORD;
typedef struct _BTC_OFFLOAD {
/* H2C command related */
u1Byte h2c_req_num;
u4Byte cnt_h2c_sent;
COL_SINGLE_H2C_RECORD h2c_record[COL_OP_WIFI_OPCODE_MAX];
/* C2H Ack related */
u4Byte cnt_c2h_ack;
u4Byte status[COL_STATUS_MAX];
struct completion c2h_event[COL_MAX_H2C_REQ_NUM]; /* for req_num = 1~COL_MAX_H2C_REQ_NUM */
u1Byte c2h_ack_buf[COL_MAX_H2C_REQ_NUM][COL_H2C_BUF_LEN];
u1Byte c2h_ack_len[COL_MAX_H2C_REQ_NUM];
/* C2H Indication related */
u4Byte cnt_c2h_ind;
COL_SINGLE_C2H_IND_RECORD c2h_ind_record[COL_IND_MAX];
u4Byte c2h_ind_status[COL_STATUS_MAX];
u1Byte c2h_ind_buf[COL_H2C_BUF_LEN];
u1Byte c2h_ind_len;
} BTC_OFFLOAD, *PBTC_OFFLOAD;
extern BTC_OFFLOAD gl_coex_offload;
/*==================================================*/
/* BTC_LINK_MODE same as WIFI_LINK_MODE */
typedef enum _BTC_LINK_MODE{
BTC_LINK_NONE=0,
BTC_LINK_ONLY_GO,
BTC_LINK_ONLY_GC,
BTC_LINK_ONLY_STA,
BTC_LINK_ONLY_AP,
BTC_LINK_2G_MCC_GO_STA,
BTC_LINK_5G_MCC_GO_STA,
BTC_LINK_25G_MCC_GO_STA,
BTC_LINK_2G_MCC_GC_STA,
BTC_LINK_5G_MCC_GC_STA,
BTC_LINK_25G_MCC_GC_STA,
BTC_LINK_2G_SCC_GO_STA,
BTC_LINK_5G_SCC_GO_STA,
BTC_LINK_2G_SCC_GC_STA,
BTC_LINK_5G_SCC_GC_STA,
BTC_LINK_MAX=30
}BTC_LINK_MODE, *PBTC_LINK_MODE;
struct btc_wifi_link_info {
BTC_LINK_MODE link_mode; /* LinkMode */
u1Byte sta_center_channel; /* StaCenterChannel */
u1Byte p2p_center_channel; /* P2PCenterChannel */
BOOLEAN bany_client_join_go;
BOOLEAN benable_noa;
BOOLEAN bhotspot;
};
typedef enum _BTC_MULTI_PORT_TDMA_MODE {
BTC_MULTI_PORT_TDMA_MODE_NONE=0,
BTC_MULTI_PORT_TDMA_MODE_2G_SCC_GO,
BTC_MULTI_PORT_TDMA_MODE_2G_P2P_GO,
BTC_MULTI_PORT_TDMA_MODE_2G_HOTSPOT_GO
} BTC_MULTI_PORT_TDMA_MODE, *PBTC_MULTI_PORT_TDMA_MODE;
typedef struct btc_multi_port_tdma_info {
BTC_MULTI_PORT_TDMA_MODE btc_multi_port_tdma_mode;
u1Byte start_time_from_bcn;
u1Byte bt_time;
} BTC_MULTI_PORT_TDMA_INFO, *PBTC_MULTI_PORT_TDMA_INFO;
typedef u1Byte
(*BFP_BTC_R1)(
IN PVOID pBtcContext,
IN u4Byte RegAddr
);
typedef u2Byte
(*BFP_BTC_R2)(
IN PVOID pBtcContext,
IN u4Byte RegAddr
);
typedef u4Byte
(*BFP_BTC_R4)(
IN PVOID pBtcContext,
IN u4Byte RegAddr
);
typedef VOID
(*BFP_BTC_W1)(
IN PVOID pBtcContext,
IN u4Byte RegAddr,
IN u1Byte Data
);
typedef VOID
(*BFP_BTC_W1_BIT_MASK)(
IN PVOID pBtcContext,
IN u4Byte regAddr,
IN u1Byte bitMask,
IN u1Byte data1b
);
typedef VOID
(*BFP_BTC_W2)(
IN PVOID pBtcContext,
IN u4Byte RegAddr,
IN u2Byte Data
);
typedef VOID
(*BFP_BTC_W4)(
IN PVOID pBtcContext,
IN u4Byte RegAddr,
IN u4Byte Data
);
typedef VOID
(*BFP_BTC_LOCAL_REG_W1)(
IN PVOID pBtcContext,
IN u4Byte RegAddr,
IN u1Byte Data
);
typedef u4Byte
(*BFP_BTC_R_LINDIRECT)(
IN PVOID pBtcContext,
IN u2Byte reg_addr
);
typedef VOID
(*BFP_BTC_R_SCBD)(
IN PVOID pBtcContext,
IN pu2Byte score_board_val
);
typedef VOID
(*BFP_BTC_W_SCBD)(
IN PVOID pBtcContext,
IN u2Byte bitpos,
IN BOOLEAN state
);
typedef VOID
(*BFP_BTC_W_LINDIRECT)(
IN PVOID pBtcContext,
IN u2Byte reg_addr,
IN u4Byte bit_mask,
IN u4Byte reg_value
);
typedef VOID
(*BFP_BTC_SET_BB_REG)(
IN PVOID pBtcContext,
IN u4Byte RegAddr,
IN u4Byte BitMask,
IN u4Byte Data
);
typedef u4Byte
(*BFP_BTC_GET_BB_REG)(
IN PVOID pBtcContext,
IN u4Byte RegAddr,
IN u4Byte BitMask
);
typedef VOID
(*BFP_BTC_SET_RF_REG)(
IN PVOID pBtcContext,
IN enum rf_path eRFPath,
IN u4Byte RegAddr,
IN u4Byte BitMask,
IN u4Byte Data
);
typedef u4Byte
(*BFP_BTC_GET_RF_REG)(
IN PVOID pBtcContext,
IN enum rf_path eRFPath,
IN u4Byte RegAddr,
IN u4Byte BitMask
);
typedef VOID
(*BFP_BTC_FILL_H2C)(
IN PVOID pBtcContext,
IN u1Byte elementId,
IN u4Byte cmdLen,
IN pu1Byte pCmdBuffer
);
typedef BOOLEAN
(*BFP_BTC_GET)(
IN PVOID pBtCoexist,
IN u1Byte getType,
OUT PVOID pOutBuf
);
typedef BOOLEAN
(*BFP_BTC_SET)(
IN PVOID pBtCoexist,
IN u1Byte setType,
OUT PVOID pInBuf
);
typedef u2Byte
(*BFP_BTC_SET_BT_REG)(
IN PVOID pBtcContext,
IN u1Byte regType,
IN u4Byte offset,
IN u4Byte value
);
typedef BOOLEAN
(*BFP_BTC_SET_BT_ANT_DETECTION)(
IN PVOID pBtcContext,
IN u1Byte txTime,
IN u1Byte btChnl
);
typedef BOOLEAN
(*BFP_BTC_SET_BT_TRX_MASK)(
IN PVOID pBtcContext,
IN u1Byte bt_trx_mask
);
typedef u4Byte
(*BFP_BTC_GET_BT_REG)(
IN PVOID pBtcContext,
IN u1Byte regType,
IN u4Byte offset
);
typedef VOID
(*BFP_BTC_DISP_DBG_MSG)(
IN PVOID pBtCoexist,
IN u1Byte dispType
);
typedef COL_H2C_STATUS
(*BFP_BTC_COEX_H2C_PROCESS)(
IN PVOID pBtCoexist,
IN u1Byte opcode,
IN u1Byte opcode_ver,
IN pu1Byte ph2c_par,
IN u1Byte h2c_par_len
);
typedef u4Byte
(*BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE)(
IN PVOID pBtcContext
);
typedef u4Byte
(*BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION)(
IN PVOID pBtcContext
);
typedef u4Byte
(*BFP_BTC_GET_PHYDM_VERSION)(
IN PVOID pBtcContext
);
typedef u1Byte
(*BFP_BTC_SET_TIMER) (
IN PVOID pBtcContext,
IN u4Byte type,
IN u4Byte val
);
typedef u4Byte
(*BFP_BTC_SET_ATOMIC) (
IN PVOID pBtcContext,
IN pu4Byte target,
IN u4Byte val
);
typedef VOID
(*BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD)(
IN PVOID pDM_Odm,
IN u1Byte RA_offset_direction,
IN u1Byte RA_threshold_offset
);
typedef u4Byte
(*BTC_PHYDM_CMNINFOQUERY)(
IN PVOID pDM_Odm,
IN u1Byte info_type
);
typedef VOID
(*BTC_REDUCE_WL_TX_POWER)(
IN PVOID pDM_Odm,
IN s1Byte tx_power
);
typedef VOID
(*BTC_PHYDM_MODIFY_ANTDIV_HWSW)(
IN PVOID pDM_Odm,
IN u1Byte type
);
typedef u1Byte
(*BFP_BTC_GET_ANT_DET_VAL_FROM_BT)(
IN PVOID pBtcContext
);
typedef u1Byte
(*BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT)(
IN PVOID pBtcContext
);
typedef u4Byte
(*BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT)(
IN PVOID pBtcContext,
IN u1Byte scanType
);
typedef BOOLEAN
(*BFP_BTC_GET_BT_AFH_MAP_FROM_BT)(
IN PVOID pBtcContext,
IN u1Byte mapType,
OUT pu1Byte afhMap
);
struct btc_bt_info {
boolean bt_disabled;
boolean bt_enable_disable_change;
u8 rssi_adjust_for_agc_table_on;
u8 rssi_adjust_for_1ant_coex_type;
boolean pre_bt_ctrl_agg_buf_size;
boolean bt_ctrl_agg_buf_size;
boolean pre_reject_agg_pkt;
boolean reject_agg_pkt;
boolean increase_scan_dev_num;
boolean bt_tx_rx_mask;
u8 pre_agg_buf_size;
u8 agg_buf_size;
boolean bt_busy;
boolean limited_dig;
u16 bt_hci_ver;
u32 bt_real_fw_ver;
u32 get_bt_fw_ver_cnt;
u32 bt_get_fw_ver;
boolean miracast_plus_bt;
boolean bt_disable_low_pwr;
boolean bt_ctrl_lps;
boolean bt_lps_on;
boolean force_to_roam; /* for 1Ant solution */
u8 lps_val;
u8 rpwm_val;
u32 ra_mask;
};
struct btc_stack_info {
boolean profile_notified;
u16 hci_version; /* stack hci version */
u8 num_of_link;
boolean bt_link_exist;
boolean sco_exist;
boolean acl_exist;
boolean a2dp_exist;
boolean hid_exist;
u8 num_of_hid;
boolean pan_exist;
boolean unknown_acl_exist;
s8 min_bt_rssi;
};
struct btc_bt_link_info {
boolean bt_link_exist;
boolean bt_hi_pri_link_exist;
boolean sco_exist;
boolean sco_only;
boolean a2dp_exist;
boolean a2dp_only;
boolean hid_exist;
boolean hid_only;
boolean pan_exist;
boolean pan_only;
boolean slave_role;
boolean acl_busy;
};
#ifdef CONFIG_RF4CE_COEXIST
struct btc_rf4ce_info {
u8 link_state;
};
#endif
struct btc_statistics {
u32 cnt_bind;
u32 cnt_power_on;
u32 cnt_pre_load_firmware;
u32 cnt_init_hw_config;
u32 cnt_init_coex_dm;
u32 cnt_ips_notify;
u32 cnt_lps_notify;
u32 cnt_scan_notify;
u32 cnt_connect_notify;
u32 cnt_media_status_notify;
u32 cnt_specific_packet_notify;
u32 cnt_bt_info_notify;
u32 cnt_rf_status_notify;
u32 cnt_periodical;
u32 cnt_coex_dm_switch;
u32 cnt_stack_operation_notify;
u32 cnt_dbg_ctrl;
u32 cnt_rate_id_notify;
u32 cnt_halt_notify;
u32 cnt_pnp_notify;
};
struct btc_coexist {
BOOLEAN bBinded; /*make sure only one adapter can bind the data context*/
PVOID Adapter; /*default adapter*/
struct btc_board_info board_info;
struct btc_bt_info bt_info; /*some bt info referenced by non-bt module*/
struct btc_stack_info stack_info;
struct btc_bt_link_info bt_link_info;
struct btc_wifi_link_info wifi_link_info;
struct btc_wifi_link_info_ext wifi_link_info_ext;
struct btc_coex_dm coex_dm;
struct btc_coex_sta coex_sta;
struct btc_rfe_type rfe_type;
const struct btc_chip_para *chip_para;
#ifdef CONFIG_RF4CE_COEXIST
struct btc_rf4ce_info rf4ce_info;
#endif
BTC_CHIP_INTERFACE chip_interface;
PVOID odm_priv;
BOOLEAN initilized;
BOOLEAN stop_coex_dm;
BOOLEAN manual_control;
BOOLEAN bdontenterLPS;
pu1Byte cli_buf;
struct btc_statistics statistics;
u1Byte pwrModeVal[10];
BOOLEAN dbg_mode;
BOOLEAN auto_report;
u8 chip_type;
BOOLEAN wl_rf_state_off;
/* function pointers */
/* io related */
BFP_BTC_R1 btc_read_1byte;
BFP_BTC_W1 btc_write_1byte;
BFP_BTC_W1_BIT_MASK btc_write_1byte_bitmask;
BFP_BTC_R2 btc_read_2byte;
BFP_BTC_W2 btc_write_2byte;
BFP_BTC_R4 btc_read_4byte;
BFP_BTC_W4 btc_write_4byte;
BFP_BTC_LOCAL_REG_W1 btc_write_local_reg_1byte;
BFP_BTC_R_LINDIRECT btc_read_linderct;
BFP_BTC_W_LINDIRECT btc_write_linderct;
BFP_BTC_R_SCBD btc_read_scbd;
BFP_BTC_W_SCBD btc_write_scbd;
/* read/write bb related */
BFP_BTC_SET_BB_REG btc_set_bb_reg;
BFP_BTC_GET_BB_REG btc_get_bb_reg;
/* read/write rf related */
BFP_BTC_SET_RF_REG btc_set_rf_reg;
BFP_BTC_GET_RF_REG btc_get_rf_reg;
/* fill h2c related */
BFP_BTC_FILL_H2C btc_fill_h2c;
/* other */
BFP_BTC_DISP_DBG_MSG btc_disp_dbg_msg;
/* normal get/set related */
BFP_BTC_GET btc_get;
BFP_BTC_SET btc_set;
BFP_BTC_GET_BT_REG btc_get_bt_reg;
BFP_BTC_SET_BT_REG btc_set_bt_reg;
BFP_BTC_SET_BT_ANT_DETECTION btc_set_bt_ant_detection;
BFP_BTC_COEX_H2C_PROCESS btc_coex_h2c_process;
BFP_BTC_SET_BT_TRX_MASK btc_set_bt_trx_mask;
BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE btc_get_bt_coex_supported_feature;
BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION btc_get_bt_coex_supported_version;
BFP_BTC_GET_PHYDM_VERSION btc_get_bt_phydm_version;
BFP_BTC_SET_TIMER btc_set_timer;
BFP_BTC_SET_ATOMIC btc_set_atomic;
BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD btc_phydm_modify_RA_PCR_threshold;
BTC_PHYDM_CMNINFOQUERY btc_phydm_query_PHY_counter;
BTC_REDUCE_WL_TX_POWER btc_reduce_wl_tx_power;
BTC_PHYDM_MODIFY_ANTDIV_HWSW btc_phydm_modify_antdiv_hwsw;
BFP_BTC_GET_ANT_DET_VAL_FROM_BT btc_get_ant_det_val_from_bt;
BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT btc_get_ble_scan_type_from_bt;
BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT btc_get_ble_scan_para_from_bt;
BFP_BTC_GET_BT_AFH_MAP_FROM_BT btc_get_bt_afh_map_from_bt;
union {
#ifdef CONFIG_RTL8822B
struct coex_dm_8822b_1ant coex_dm_8822b_1ant;
struct coex_dm_8822b_2ant coex_dm_8822b_2ant;
#endif /* 8822B */
#ifdef CONFIG_RTL8821C
struct coex_dm_8821c_1ant coex_dm_8821c_1ant;
struct coex_dm_8821c_2ant coex_dm_8821c_2ant;
#endif /* 8821C */
#ifdef CONFIG_RTL8723D
struct coex_dm_8723d_1ant coex_dm_8723d_1ant;
struct coex_dm_8723d_2ant coex_dm_8723d_2ant;
#endif /* 8723D */
};
union {
#ifdef CONFIG_RTL8822B
struct coex_sta_8822b_1ant coex_sta_8822b_1ant;
struct coex_sta_8822b_2ant coex_sta_8822b_2ant;
#endif /* 8822B */
#ifdef CONFIG_RTL8821C
struct coex_sta_8821c_1ant coex_sta_8821c_1ant;
struct coex_sta_8821c_2ant coex_sta_8821c_2ant;
#endif /* 8821C */
#ifdef CONFIG_RTL8723D
struct coex_sta_8723d_1ant coex_sta_8723d_1ant;
struct coex_sta_8723d_2ant coex_sta_8723d_2ant;
#endif /* 8723D */
};
union {
#ifdef CONFIG_RTL8822B
struct rfe_type_8822b_1ant rfe_type_8822b_1ant;
struct rfe_type_8822b_2ant rfe_type_8822b_2ant;
#endif /* 8822B */
#ifdef CONFIG_RTL8821C
struct rfe_type_8821c_1ant rfe_type_8821c_1ant;
struct rfe_type_8821c_2ant rfe_type_8821c_2ant;
#endif /* 8821C */
};
union {
#ifdef CONFIG_RTL8822B
struct wifi_link_info_8822b_1ant wifi_link_info_8822b_1ant;
struct wifi_link_info_8822b_2ant wifi_link_info_8822b_2ant;
#endif /* 8822B */
#ifdef CONFIG_RTL8821C
struct wifi_link_info_8821c_1ant wifi_link_info_8821c_1ant;
struct wifi_link_info_8821c_2ant wifi_link_info_8821c_2ant;
#endif /* 8821C */
};
};
typedef struct btc_coexist *PBTC_COEXIST;
extern struct btc_coexist GLBtCoexist;
typedef void
(*BFP_BTC_CHIP_SETUP)(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte setType
);
struct btc_chip_para {
const char *chip_name;
u32 para_ver_date;
u32 para_ver;
u32 bt_desired_ver;
boolean scbd_support;
boolean mailbox_support;
boolean lte_indirect_access;
boolean new_scbd10_def; /* TRUE: 1:fix 2M(8822c) */
u8 indirect_type; /* 0:17xx, 1:7cx */
u8 pstdma_type; /* 0: LPSoff, 1:LPSon */
u8 bt_rssi_type;
u8 ant_isolation;
u8 rssi_tolerance;
u8 rx_path_num;
u8 wl_rssi_step_num;
const u8 *wl_rssi_step;
u8 bt_rssi_step_num;
const u8 *bt_rssi_step;
u8 table_sant_num;
const struct btc_coex_table_para *table_sant;
u8 table_nsant_num;
const struct btc_coex_table_para *table_nsant;
u8 tdma_sant_num;
const struct btc_tdma_para *tdma_sant;
u8 tdma_nsant_num;
const struct btc_tdma_para *tdma_nsant;
u8 wl_rf_para_tx_num;
const struct btc_rf_para *wl_rf_para_tx;
const struct btc_rf_para *wl_rf_para_rx;
u8 bt_afh_span_bw20;
u8 bt_afh_span_bw40;
u8 afh_5g_num;
const struct btc_5g_afh_map *afh_5g;
BFP_BTC_CHIP_SETUP chip_setup;
};
BOOLEAN
EXhalbtcoutsrc_InitlizeVariables(
IN PVOID Adapter
);
VOID
EXhalbtcoutsrc_PowerOnSetting(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_PreLoadFirmware(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_InitHwConfig(
IN PBTC_COEXIST pBtCoexist,
IN BOOLEAN bWifiOnly
);
VOID
EXhalbtcoutsrc_InitCoexDm(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_IpsNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte type
);
VOID
EXhalbtcoutsrc_LpsNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte type
);
VOID
EXhalbtcoutsrc_ScanNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte type
);
VOID
EXhalbtcoutsrc_SetAntennaPathNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte type
);
VOID
EXhalbtcoutsrc_ConnectNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte action
);
VOID
EXhalbtcoutsrc_MediaStatusNotify(
IN PBTC_COEXIST pBtCoexist,
IN RT_MEDIA_STATUS mediaStatus
);
VOID
EXhalbtcoutsrc_SpecificPacketNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte pktType
);
VOID
EXhalbtcoutsrc_BtInfoNotify(
IN PBTC_COEXIST pBtCoexist,
IN pu1Byte tmpBuf,
IN u1Byte length
);
VOID
EXhalbtcoutsrc_RfStatusNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte type
);
u4Byte
EXhalbtcoutsrc_CoexTimerCheck(
IN PBTC_COEXIST pBtCoexist
);
u4Byte
EXhalbtcoutsrc_WLStatusCheck(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_WlFwDbgInfoNotify(
IN PBTC_COEXIST pBtCoexist,
IN pu1Byte tmpBuf,
IN u1Byte length
);
VOID
EXhalbtcoutsrc_rx_rate_change_notify(
IN PBTC_COEXIST pBtCoexist,
IN BOOLEAN is_data_frame,
IN u1Byte btc_rate_id
);
VOID
EXhalbtcoutsrc_StackOperationNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte type
);
VOID
EXhalbtcoutsrc_HaltNotify(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_PnpNotify(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte pnpState
);
VOID
EXhalbtcoutsrc_TimerNotify(
IN PBTC_COEXIST pBtCoexist,
IN u4Byte timer_type
);
VOID
EXhalbtcoutsrc_WLStatusChangeNotify(
IN PBTC_COEXIST pBtCoexist,
IN u4Byte change_type
);
VOID
EXhalbtcoutsrc_CoexDmSwitch(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_Periodical(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_DbgControl(
IN PBTC_COEXIST pBtCoexist,
IN u1Byte opCode,
IN u1Byte opLen,
IN pu1Byte pData
);
VOID
EXhalbtcoutsrc_AntennaDetection(
IN PBTC_COEXIST pBtCoexist,
IN u4Byte centFreq,
IN u4Byte offset,
IN u4Byte span,
IN u4Byte seconds
);
VOID
EXhalbtcoutsrc_StackUpdateProfileInfo(
VOID
);
VOID
EXhalbtcoutsrc_SetHciVersion(
IN u2Byte hciVersion
);
VOID
EXhalbtcoutsrc_SetBtPatchVersion(
IN u2Byte btHciVersion,
IN u2Byte btPatchVersion
);
VOID
EXhalbtcoutsrc_UpdateMinBtRssi(
IN s1Byte btRssi
);
#if 0
VOID
EXhalbtcoutsrc_SetBtExist(
IN BOOLEAN bBtExist
);
#endif
VOID
EXhalbtcoutsrc_SetChipType(
IN u1Byte chipType
);
VOID
EXhalbtcoutsrc_SetAntNum(
IN u1Byte type,
IN u1Byte antNum
);
VOID
EXhalbtcoutsrc_SetSingleAntPath(
IN u1Byte singleAntPath
);
VOID
EXhalbtcoutsrc_DisplayBtCoexInfo(
IN PBTC_COEXIST pBtCoexist
);
VOID
EXhalbtcoutsrc_DisplayAntDetection(
IN PBTC_COEXIST pBtCoexist
);
#define MASKBYTE0 0xff
#define MASKBYTE1 0xff00
#define MASKBYTE2 0xff0000
#define MASKBYTE3 0xff000000
#define MASKHWORD 0xffff0000
#define MASKLWORD 0x0000ffff
#define MASKDWORD 0xffffffff
#define MASK12BITS 0xfff
#define MASKH4BITS 0xf0000000
#define MASKOFDM_D 0xffc00000
#define MASKCCK 0x3f3f3f3f
#endif
================================================
FILE: hal/btc/mp_precomp.h
================================================
/******************************************************************************
*
* Copyright(c) 2013 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __MP_PRECOMP_H__
#define __MP_PRECOMP_H__
#include
#include
#include "btc_basic_types.h"
#define BT_TMP_BUF_SIZE 100
#ifdef PLATFORM_LINUX
#define rsprintf snprintf
#define rstrncat(dst, src, src_size) strncat(dst, src, src_size)
#elif defined(PLATFORM_WINDOWS)
#define rsprintf sprintf_s
#endif
#define DCMD_Printf DBG_BT_INFO
#define delay_ms(ms) rtw_mdelay_os(ms)
#ifdef bEnable
#undef bEnable
#endif
#define WPP_SOFTWARE_TRACE 0
typedef enum _BTC_MSG_COMP_TYPE {
COMP_COEX = 0,
COMP_MAX
} BTC_MSG_COMP_TYPE;
extern u4Byte GLBtcDbgType[];
#define DBG_OFF 0
#define DBG_SEC 1
#define DBG_SERIOUS 2
#define DBG_WARNING 3
#define DBG_LOUD 4
#define DBG_TRACE 5
#ifdef CONFIG_BT_COEXIST
#define BT_SUPPORT 1
#define COEX_SUPPORT 1
#define HS_SUPPORT 1
#else
#define BT_SUPPORT 0
#define COEX_SUPPORT 0
#define HS_SUPPORT 0
#endif
/* for wifi only mode */
#include "hal_btcoex_wifionly.h"
#ifdef CONFIG_BT_COEXIST
#define BTC_BTINFO_LENGTH_MAX 10
struct wifi_only_cfg;
struct btc_coexist;
#ifdef CONFIG_RTL8192E
#include "halbtc8192e1ant.h"
#include "halbtc8192e2ant.h"
#endif
#ifdef CONFIG_RTL8723B
#include "halbtc8723bwifionly.h"
#include "halbtc8723b1ant.h"
#include "halbtc8723b2ant.h"
#endif
#ifdef CONFIG_RTL8812A
#include "halbtc8812a1ant.h"
#include "halbtc8812a2ant.h"
#endif
#ifdef CONFIG_RTL8821A
#include "halbtc8821a1ant.h"
#include "halbtc8821a2ant.h"
#endif
#ifdef CONFIG_RTL8703B
#include "halbtc8703b1ant.h"
#endif
#ifdef CONFIG_RTL8723D
#include "halbtc8723d1ant.h"
#include "halbtc8723d2ant.h"
#endif
#ifdef CONFIG_RTL8822B
#include "halbtc8822bwifionly.h"
#include "halbtc8822b1ant.h"
#include "halbtc8822b2ant.h"
#endif
#ifdef CONFIG_RTL8821C
#include "halbtc8821cwifionly.h"
#include "halbtc8821c1ant.h"
#include "halbtc8821c2ant.h"
#endif
#ifdef CONFIG_RTL8822C
#include "halbtccommon.h"
#include "halbtc8822cwifionly.h"
#include "halbtc8822c.h"
#endif
#ifdef CONFIG_RTL8814A
#include "halbtc8814a2ant.h"
#endif
#include "halbtcoutsrc.h"
#else /* CONFIG_BT_COEXIST */
#ifdef CONFIG_RTL8723B
#include "halbtc8723bwifionly.h"
#endif
#ifdef CONFIG_RTL8822B
#include "halbtc8822bwifionly.h"
#endif
#ifdef CONFIG_RTL8821C
#include "halbtc8821cwifionly.h"
#endif
#ifdef CONFIG_RTL8822C
#include "halbtc8822cwifionly.h"
#endif
#endif /* CONFIG_BT_COEXIST */
#endif /* __MP_PRECOMP_H__ */
================================================
FILE: hal/efuse/efuse_mask.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifdef CONFIG_USB_HCI
#if defined(CONFIG_RTL8188E)
#include "rtl8188e/HalEfuseMask8188E_USB.h"
#endif
#if defined(CONFIG_RTL8812A)
#include "rtl8812a/HalEfuseMask8812A_USB.h"
#endif
#if defined(CONFIG_RTL8821A)
#include "rtl8812a/HalEfuseMask8821A_USB.h"
#endif
#if defined(CONFIG_RTL8192E)
#include "rtl8192e/HalEfuseMask8192E_USB.h"
#endif
#if defined(CONFIG_RTL8723B)
#include "rtl8723b/HalEfuseMask8723B_USB.h"
#endif
#if defined(CONFIG_RTL8814A)
#include "rtl8814a/HalEfuseMask8814A_USB.h"
#endif
#if defined(CONFIG_RTL8703B)
#include "rtl8703b/HalEfuseMask8703B_USB.h"
#endif
#if defined(CONFIG_RTL8723D)
#include "rtl8723d/HalEfuseMask8723D_USB.h"
#endif
#if defined(CONFIG_RTL8188F)
#include "rtl8188f/HalEfuseMask8188F_USB.h"
#endif
#if defined(CONFIG_RTL8188GTV)
#include "rtl8188gtv/HalEfuseMask8188GTV_USB.h"
#endif
#if defined(CONFIG_RTL8822B)
#include "rtl8822b/HalEfuseMask8822B_USB.h"
#endif
#if defined(CONFIG_RTL8821C)
#include "rtl8821c/HalEfuseMask8821C_USB.h"
#endif
#if defined(CONFIG_RTL8710B)
#include "rtl8710b/HalEfuseMask8710B_USB.h"
#endif
#if defined(CONFIG_RTL8192F)
#include "rtl8192f/HalEfuseMask8192F_USB.h"
#endif
#if defined(CONFIG_RTL8822C)
#include "rtl8822c/HalEfuseMask8822C_USB.h"
#endif
#endif /*CONFIG_USB_HCI*/
#ifdef CONFIG_PCI_HCI
#if defined(CONFIG_RTL8188E)
#include "rtl8188e/HalEfuseMask8188E_PCIE.h"
#endif
#if defined(CONFIG_RTL8812A)
#include "rtl8812a/HalEfuseMask8812A_PCIE.h"
#endif
#if defined(CONFIG_RTL8821A)
#include "rtl8812a/HalEfuseMask8821A_PCIE.h"
#endif
#if defined(CONFIG_RTL8192E)
#include "rtl8192e/HalEfuseMask8192E_PCIE.h"
#endif
#if defined(CONFIG_RTL8723B)
#include "rtl8723b/HalEfuseMask8723B_PCIE.h"
#endif
#if defined(CONFIG_RTL8814A)
#include "rtl8814a/HalEfuseMask8814A_PCIE.h"
#endif
#if defined(CONFIG_RTL8703B)
#include "rtl8703b/HalEfuseMask8703B_PCIE.h"
#endif
#if defined(CONFIG_RTL8822B)
#include "rtl8822b/HalEfuseMask8822B_PCIE.h"
#endif
#if defined(CONFIG_RTL8723D)
#include "rtl8723d/HalEfuseMask8723D_PCIE.h"
#endif
#if defined(CONFIG_RTL8821C)
#include "rtl8821c/HalEfuseMask8821C_PCIE.h"
#endif
#if defined(CONFIG_RTL8192F)
#include "rtl8192f/HalEfuseMask8192F_PCIE.h"
#endif
#if defined(CONFIG_RTL8822C)
#include "rtl8822c/HalEfuseMask8822C_PCIE.h"
#endif
#endif /*CONFIG_PCI_HCI*/
#ifdef CONFIG_SDIO_HCI
#if defined(CONFIG_RTL8723B)
#include "rtl8723b/HalEfuseMask8723B_SDIO.h"
#endif
#if defined(CONFIG_RTL8188E)
#include "rtl8188e/HalEfuseMask8188E_SDIO.h"
#endif
#if defined(CONFIG_RTL8703B)
#include "rtl8703b/HalEfuseMask8703B_SDIO.h"
#endif
#if defined(CONFIG_RTL8188F)
#include "rtl8188f/HalEfuseMask8188F_SDIO.h"
#endif
#if defined(CONFIG_RTL8188GTV)
#include "rtl8188gtv/HalEfuseMask8188GTV_SDIO.h"
#endif
#if defined(CONFIG_RTL8723D)
#include "rtl8723d/HalEfuseMask8723D_SDIO.h"
#endif
#if defined(CONFIG_RTL8192E)
#include "rtl8192e/HalEfuseMask8192E_SDIO.h"
#endif
#if defined(CONFIG_RTL8821A)
#include "rtl8812a/HalEfuseMask8821A_SDIO.h"
#endif
#if defined(CONFIG_RTL8821C)
#include "rtl8821c/HalEfuseMask8821C_SDIO.h"
#endif
#if defined(CONFIG_RTL8822B)
#include "rtl8822b/HalEfuseMask8822B_SDIO.h"
#endif
#if defined(CONFIG_RTL8192F)
#include "rtl8192f/HalEfuseMask8192F_SDIO.h"
#endif
#if defined(CONFIG_RTL8822C)
#include "rtl8822c/HalEfuseMask8822C_SDIO.h"
#endif
#endif /*CONFIG_SDIO_HCI*/
================================================
FILE: hal/efuse/rtl8822c/HalEfuseMask8822C_PCIE.c
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include "HalEfuseMask8822C_PCIE.h"
/******************************************************************************
* MPCIE.TXT
******************************************************************************/
u8 Array_MP_8822C_MPCIE_BT[] = {
0x00,
0x41,
0x00,
0x70,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x02,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x08,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0xCF,
0xFF,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
};
u8 Array_MP_8822C_MPCIE[] = {
0xFF,
0xF7,
0xEF,
0xDE,
0xFC,
0xFB,
0x10,
0x00,
0x00,
0x00,
0x00,
0x03,
0xF7,
0xD7,
0x00,
0x00,
0x71,
0xF1,
0xFF,
0xFF,
0x7E,
0xFC,
0xFF,
0xF1,
0x00,
0xD0,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
};
/* BT eFuse Maks */
u16 EFUSE_GetBTArrayLen_MP_8822C_MPCIE(void)
{
return sizeof(Array_MP_8822C_MPCIE_BT) / sizeof(u8);
}
void EFUSE_GetBTMaskArray_MP_8822C_MPCIE(u8 *Array)
{
u16 len = EFUSE_GetBTArrayLen_MP_8822C_MPCIE(), i = 0;
for (i = 0; i < len; ++i)
Array[i] = Array_MP_8822C_MPCIE_BT[i];
}
BOOLEAN EFUSE_IsBTAddressMasked_MP_8822C_MPCIE(u16 Offset)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (c < 4) /*Upper double word*/
result = (Array_MP_8822C_MPCIE_BT[r] & (0x10 << c));
else
result = (Array_MP_8822C_MPCIE_BT[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
/* WiFi eFuse Maks */
u16 EFUSE_GetArrayLen_MP_8822C_MPCIE(void)
{
return sizeof(Array_MP_8822C_MPCIE) / sizeof(u8);
}
void EFUSE_GetMaskArray_MP_8822C_MPCIE(u8 *Array)
{
u16 len = EFUSE_GetArrayLen_MP_8822C_MPCIE(), i = 0;
for (i = 0; i < len; ++i)
Array[i] = Array_MP_8822C_MPCIE[i];
}
BOOLEAN EFUSE_IsAddressMasked_MP_8822C_MPCIE(u16 Offset)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (c < 4) /*Upper double word*/
result = (Array_MP_8822C_MPCIE[r] & (0x10 << c));
else
result = (Array_MP_8822C_MPCIE[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
================================================
FILE: hal/efuse/rtl8822c/HalEfuseMask8822C_PCIE.h
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/******************************************************************************
* MPCIE.TXT
******************************************************************************/
u16 EFUSE_GetArrayLen_MP_8822C_MPCIE(void);
void EFUSE_GetMaskArray_MP_8822C_MPCIE(u8 *Array);
BOOLEAN EFUSE_IsAddressMasked_MP_8822C_MPCIE(u16 Offset);
u16 EFUSE_GetBTArrayLen_MP_8822C_MPCIE(void);
void EFUSE_GetBTMaskArray_MP_8822C_MPCIE(u8 *Array);
BOOLEAN EFUSE_IsBTAddressMasked_MP_8822C_MPCIE(u16 Offset);
================================================
FILE: hal/efuse/rtl8822c/HalEfuseMask8822C_SDIO.c
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include "HalEfuseMask8822C_SDIO.h"
/******************************************************************************
* MSDIO.TXT
******************************************************************************/
u8 Array_MP_8822C_MSDIO_BT[] = {
0x00,
0x41,
0x00,
0x70,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x02,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x08,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0xCF,
0xFF,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
};
u8 Array_MP_8822C_MSDIO[] = {
0xFF,
0xF7,
0xEF,
0xDE,
0xFC,
0xFB,
0x10,
0x00,
0x00,
0x00,
0x00,
0x03,
0xF7,
0xD7,
0x00,
0x00,
0x71,
0xF1,
0x76,
0x00,
0x00,
0x00,
0x0E,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
};
/* BT eFuse Mask */
u16 EFUSE_GetBTArrayLen_MP_8822C_MSDIO(void)
{
return sizeof(Array_MP_8822C_MSDIO_BT) / sizeof(u8);
}
void EFUSE_GetBTMaskArray_MP_8822C_MSDIO(u8 *Array)
{
u16 len = EFUSE_GetBTArrayLen_MP_8822C_MSDIO(), i = 0;
for (i = 0; i < len; ++i)
Array[i] = Array_MP_8822C_MSDIO_BT[i];
}
BOOLEAN EFUSE_IsBTAddressMasked_MP_8822C_MSDIO(u16 Offset)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (c < 4) /*Upper double word*/
result = (Array_MP_8822C_MSDIO_BT[r] & (0x10 << c));
else
result = (Array_MP_8822C_MSDIO_BT[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
/* WiFi eFuse Mask */
u16 EFUSE_GetArrayLen_MP_8822C_MSDIO(void)
{
return sizeof(Array_MP_8822C_MSDIO) / sizeof(u8);
}
void EFUSE_GetMaskArray_MP_8822C_MSDIO(u8 *Array)
{
u16 len = EFUSE_GetArrayLen_MP_8822C_MSDIO(), i = 0;
for (i = 0; i < len; ++i)
Array[i] = Array_MP_8822C_MSDIO[i];
}
BOOLEAN EFUSE_IsAddressMasked_MP_8822C_MSDIO(u16 Offset)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (c < 4) /*Upper double word*/
result = (Array_MP_8822C_MSDIO[r] & (0x10 << c));
else
result = (Array_MP_8822C_MSDIO[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
================================================
FILE: hal/efuse/rtl8822c/HalEfuseMask8822C_SDIO.h
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/******************************************************************************
* MSDIO.TXT
******************************************************************************/
u16 EFUSE_GetArrayLen_MP_8822C_MSDIO(void);
void EFUSE_GetMaskArray_MP_8822C_MSDIO(u8 *Array);
BOOLEAN EFUSE_IsAddressMasked_MP_8822C_MSDIO(u16 Offset);
u16 EFUSE_GetBTArrayLen_MP_8822C_MSDIO(void);
void EFUSE_GetBTMaskArray_MP_8822C_MSDIO(u8 *Array);
BOOLEAN EFUSE_IsBTAddressMasked_MP_8822C_MSDIO(u16 Offset);
================================================
FILE: hal/efuse/rtl8822c/HalEfuseMask8822C_USB.c
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include "HalEfuseMask8822C_USB.h"
/******************************************************************************
* MUSB.TXT
******************************************************************************/
u8 Array_MP_8822C_MUSB_BT[] = {
0x00,
0x41,
0x00,
0x70,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x02,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x08,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0xCF,
0xFF,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
};
u8 Array_MP_8822C_MUSB[] = {
0xFF,
0xF7,
0xEF,
0xDE,
0xFC,
0xFB,
0x10,
0x00,
0x00,
0x00,
0x00,
0x03,
0xF7,
0xD7,
0x00,
0x00,
0x71,
0xF1,
0x00,
0x00,
0x00,
0xFF,
0xFF,
0xFF,
0xFF,
0xD0,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
0x00,
};
/* BT eFuse Mask */
u16 EFUSE_GetBTArrayLen_MP_8822C_MUSB(void)
{
return sizeof(Array_MP_8822C_MUSB_BT) / sizeof(u8);
}
void EFUSE_GetBTMaskArray_MP_8822C_MUSB(u8 *Array)
{
u16 len = EFUSE_GetBTArrayLen_MP_8822C_MUSB(), i = 0;
for (i = 0; i < len; ++i)
Array[i] = Array_MP_8822C_MUSB_BT[i];
}
BOOLEAN EFUSE_IsBTAddressMasked_MP_8822C_MUSB(u16 Offset)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (c < 4) /*Upper double word*/
result = (Array_MP_8822C_MUSB_BT[r] & (0x10 << c));
else
result = (Array_MP_8822C_MUSB_BT[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
/* WiFi eFuse Mask */
u16 EFUSE_GetArrayLen_MP_8822C_MUSB(void)
{
return sizeof(Array_MP_8822C_MUSB) / sizeof(u8);
}
void EFUSE_GetMaskArray_MP_8822C_MUSB(u8 *Array)
{
u16 len = EFUSE_GetArrayLen_MP_8822C_MUSB(), i = 0;
for (i = 0; i < len; ++i)
Array[i] = Array_MP_8822C_MUSB[i];
}
BOOLEAN EFUSE_IsAddressMasked_MP_8822C_MUSB(u16 Offset)
{
int r = Offset / 16;
int c = (Offset % 16) / 2;
int result = 0;
if (c < 4) /*Upper double word*/
result = (Array_MP_8822C_MUSB[r] & (0x10 << c));
else
result = (Array_MP_8822C_MUSB[r] & (0x01 << (c - 4)));
return (result > 0) ? 0 : 1;
}
================================================
FILE: hal/efuse/rtl8822c/HalEfuseMask8822C_USB.h
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/******************************************************************************
* MUSB.TXT
******************************************************************************/
u16 EFUSE_GetArrayLen_MP_8822C_MUSB(void);
void EFUSE_GetMaskArray_MP_8822C_MUSB(u8 *Array);
BOOLEAN EFUSE_IsAddressMasked_MP_8822C_MUSB(u16 Offset);
u16 EFUSE_GetBTArrayLen_MP_8822C_MUSB(void);
void EFUSE_GetBTMaskArray_MP_8822C_MUSB(u8 *Array);
BOOLEAN EFUSE_IsBTAddressMasked_MP_8822C_MUSB(u16 Offset);
================================================
FILE: hal/hal_btcoex.c
================================================
/******************************************************************************
*
* Copyright(c) 2013 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define __HAL_BTCOEX_C__
#ifdef CONFIG_BT_COEXIST
#include
#include
#include "btc/mp_precomp.h"
/* ************************************
* Global variables
* ************************************ */
const char *const BtProfileString[] = {
"NONE",
"A2DP",
"PAN",
"HID",
"SCO",
};
const char *const BtSpecString[] = {
"1.0b",
"1.1",
"1.2",
"2.0+EDR",
"2.1+EDR",
"3.0+HS",
"4.0",
};
const char *const BtLinkRoleString[] = {
"Master",
"Slave",
};
const char *const h2cStaString[] = {
"successful",
"h2c busy",
"rf off",
"fw not read",
};
const char *const ioStaString[] = {
"success",
"can not IO",
"rf off",
"fw not read",
"wait io timeout",
"invalid len",
"idle Q empty",
"insert waitQ fail",
"unknown fail",
"wrong level",
"h2c stopped",
};
const char *const GLBtcWifiBwString[] = {
"11bg",
"HT20",
"HT40",
"VHT80",
"VHT160"
};
const char *const GLBtcWifiFreqString[] = {
"2.4G",
"5G",
"2.4G+5G"
};
const char *const GLBtcIotPeerString[] = {
"UNKNOWN",
"REALTEK",
"REALTEK_92SE",
"BROADCOM",
"RALINK",
"ATHEROS",
"CISCO",
"MERU",
"MARVELL",
"REALTEK_SOFTAP", /* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 */
"SELF_SOFTAP", /* Self is SoftAP */
"AIRGO",
"INTEL",
"RTK_APCLIENT",
"REALTEK_81XX",
"REALTEK_WOW",
"REALTEK_JAGUAR_BCUTAP",
"REALTEK_JAGUAR_CCUTAP"
};
const char *const coexOpcodeString[] = {
"Wifi status notify",
"Wifi progress",
"Wifi info",
"Power state",
"Set Control",
"Get Control"
};
const char *const coexIndTypeString[] = {
"bt info",
"pstdma",
"limited tx/rx",
"coex table",
"request"
};
const char *const coexH2cResultString[] = {
"ok",
"unknown",
"un opcode",
"opVer MM",
"par Err",
"par OoR",
"reqNum MM",
"halMac Fail",
"h2c TimeOut",
"Invalid c2h Len",
"data overflow"
};
#define HALBTCOUTSRC_AGG_CHK_WINDOW_IN_MS 8000
struct btc_coexist GLBtCoexist;
BTC_OFFLOAD gl_coex_offload;
u8 GLBtcWiFiInScanState;
u8 GLBtcWiFiInIQKState;
u8 GLBtcWiFiInIPS;
u8 GLBtcWiFiInLPS;
u8 GLBtcBtCoexAliveRegistered;
/*
* BT control H2C/C2H
*/
/* EXT_EID */
typedef enum _bt_ext_eid {
C2H_WIFI_FW_ACTIVE_RSP = 0,
C2H_TRIG_BY_BT_FW
} BT_EXT_EID;
/* C2H_STATUS */
typedef enum _bt_c2h_status {
BT_STATUS_OK = 0,
BT_STATUS_VERSION_MISMATCH,
BT_STATUS_UNKNOWN_OPCODE,
BT_STATUS_ERROR_PARAMETER
} BT_C2H_STATUS;
/* C2H BT OP CODES */
typedef enum _bt_op_code {
BT_OP_GET_BT_VERSION = 0x00,
BT_OP_WRITE_REG_ADDR = 0x0c,
BT_OP_WRITE_REG_VALUE = 0x0d,
BT_OP_READ_REG = 0x11,
BT_LO_OP_GET_AFH_MAP_L = 0x1e,
BT_LO_OP_GET_AFH_MAP_M = 0x1f,
BT_LO_OP_GET_AFH_MAP_H = 0x20,
BT_OP_GET_BT_COEX_SUPPORTED_FEATURE = 0x2a,
BT_OP_GET_BT_COEX_SUPPORTED_VERSION = 0x2b,
BT_OP_GET_BT_ANT_DET_VAL = 0x2c,
BT_OP_GET_BT_BLE_SCAN_TYPE = 0x2d,
BT_OP_GET_BT_BLE_SCAN_PARA = 0x2e,
BT_OP_GET_BT_DEVICE_INFO = 0x30,
BT_OP_GET_BT_FORBIDDEN_SLOT_VAL = 0x31,
BT_OP_SET_BT_LANCONSTRAIN_LEVEL = 0x32,
BT_OP_SET_BT_TEST_MODE_VAL = 0x33,
BT_OP_MAX
} BT_OP_CODE;
#define BTC_MPOPER_TIMEOUT 50 /* unit: ms */
#define C2H_MAX_SIZE 16
u8 GLBtcBtMpOperSeq;
_mutex GLBtcBtMpOperLock;
_timer GLBtcBtMpOperTimer;
_sema GLBtcBtMpRptSema;
u8 GLBtcBtMpRptSeq;
u8 GLBtcBtMpRptStatus;
u8 GLBtcBtMpRptRsp[C2H_MAX_SIZE];
u8 GLBtcBtMpRptRspSize;
u8 GLBtcBtMpRptWait;
u8 GLBtcBtMpRptWiFiOK;
u8 GLBtcBtMpRptBTOK;
/*
* Debug
*/
u32 GLBtcDbgType[COMP_MAX];
u8 GLBtcDbgBuf[BT_TMP_BUF_SIZE];
u8 gl_btc_trace_buf[BT_TMP_BUF_SIZE];
typedef struct _btcoexdbginfo {
u8 *info;
u32 size; /* buffer total size */
u32 len; /* now used length */
} BTCDBGINFO, *PBTCDBGINFO;
BTCDBGINFO GLBtcDbgInfo;
#define BT_Operation(Adapter) _FALSE
static void DBG_BT_INFO_INIT(PBTCDBGINFO pinfo, u8 *pbuf, u32 size)
{
if (NULL == pinfo)
return;
_rtw_memset(pinfo, 0, sizeof(BTCDBGINFO));
if (pbuf && size) {
pinfo->info = pbuf;
pinfo->size = size;
}
}
void DBG_BT_INFO(u8 *dbgmsg)
{
PBTCDBGINFO pinfo;
u32 msglen, buflen;
u8 *pbuf;
pinfo = &GLBtcDbgInfo;
if (NULL == pinfo->info)
return;
msglen = strlen(dbgmsg);
if (pinfo->len + msglen > pinfo->size)
return;
pbuf = pinfo->info + pinfo->len;
_rtw_memcpy(pbuf, dbgmsg, msglen);
pinfo->len += msglen;
}
/* ************************************
* Debug related function
* ************************************ */
static u8 halbtcoutsrc_IsBtCoexistAvailable(PBTC_COEXIST pBtCoexist)
{
if (!pBtCoexist->bBinded ||
NULL == pBtCoexist->Adapter)
return _FALSE;
return _TRUE;
}
static void halbtcoutsrc_DbgInit(void)
{
u8 i;
for (i = 0; i < COMP_MAX; i++)
GLBtcDbgType[i] = 0;
}
static void halbtcoutsrc_EnterPwrLock(PBTC_COEXIST pBtCoexist)
{
struct dvobj_priv *dvobj = adapter_to_dvobj((PADAPTER)pBtCoexist->Adapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
_enter_pwrlock(&pwrpriv->lock);
}
static void halbtcoutsrc_ExitPwrLock(PBTC_COEXIST pBtCoexist)
{
struct dvobj_priv *dvobj = adapter_to_dvobj((PADAPTER)pBtCoexist->Adapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
_exit_pwrlock(&pwrpriv->lock);
}
static u8 halbtcoutsrc_IsHwMailboxExist(PBTC_COEXIST pBtCoexist)
{
if (pBtCoexist->board_info.bt_chip_type == BTC_CHIP_CSR_BC4
|| pBtCoexist->board_info.bt_chip_type == BTC_CHIP_CSR_BC8
)
return _FALSE;
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter))
return _FALSE;
else
return _TRUE;
}
static u8 halbtcoutsrc_LeaveLps(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
padapter = pBtCoexist->Adapter;
pBtCoexist->bt_info.bt_ctrl_lps = _TRUE;
pBtCoexist->bt_info.bt_lps_on = _FALSE;
return rtw_btcoex_LPS_Leave(padapter);
}
void halbtcoutsrc_EnterLps(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
padapter = pBtCoexist->Adapter;
if (pBtCoexist->bdontenterLPS == _FALSE) {
pBtCoexist->bt_info.bt_ctrl_lps = _TRUE;
pBtCoexist->bt_info.bt_lps_on = _TRUE;
rtw_btcoex_LPS_Enter(padapter);
}
}
void halbtcoutsrc_NormalLps(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
padapter = pBtCoexist->Adapter;
if (pBtCoexist->bt_info.bt_ctrl_lps) {
pBtCoexist->bt_info.bt_lps_on = _FALSE;
rtw_btcoex_LPS_Leave(padapter);
pBtCoexist->bt_info.bt_ctrl_lps = _FALSE;
/* recover the LPS state to the original */
#if 0
padapter->hal_func.UpdateLPSStatusHandler(
padapter,
pPSC->RegLeisurePsMode,
pPSC->RegPowerSaveMode);
#endif
}
}
void halbtcoutsrc_Pre_NormalLps(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
padapter = pBtCoexist->Adapter;
if (pBtCoexist->bt_info.bt_ctrl_lps) {
pBtCoexist->bt_info.bt_lps_on = _FALSE;
rtw_btcoex_LPS_Leave(padapter);
}
}
void halbtcoutsrc_Post_NormalLps(PBTC_COEXIST pBtCoexist)
{
if (pBtCoexist->bt_info.bt_ctrl_lps)
pBtCoexist->bt_info.bt_ctrl_lps = _FALSE;
}
/*
* Constraint:
* 1. this function will request pwrctrl->lock
*/
void halbtcoutsrc_LeaveLowPower(PBTC_COEXIST pBtCoexist)
{
#ifdef CONFIG_LPS_LCLK
PADAPTER padapter;
PHAL_DATA_TYPE pHalData;
struct pwrctrl_priv *pwrctrl;
s32 ready;
systime stime;
s32 utime;
u32 timeout; /* unit: ms */
padapter = pBtCoexist->Adapter;
pHalData = GET_HAL_DATA(padapter);
pwrctrl = adapter_to_pwrctl(padapter);
ready = _FAIL;
#ifdef LPS_RPWM_WAIT_MS
timeout = LPS_RPWM_WAIT_MS;
#else /* !LPS_RPWM_WAIT_MS */
timeout = 30;
#endif /* !LPS_RPWM_WAIT_MS */
if (GLBtcBtCoexAliveRegistered == _TRUE)
return;
stime = rtw_get_current_time();
do {
ready = rtw_register_task_alive(padapter, BTCOEX_ALIVE);
if (_SUCCESS == ready)
break;
utime = rtw_get_passing_time_ms(stime);
if (utime > timeout)
break;
rtw_msleep_os(1);
} while (1);
GLBtcBtCoexAliveRegistered = _TRUE;
#endif /* CONFIG_LPS_LCLK */
}
/*
* Constraint:
* 1. this function will request pwrctrl->lock
*/
void halbtcoutsrc_NormalLowPower(PBTC_COEXIST pBtCoexist)
{
#ifdef CONFIG_LPS_LCLK
PADAPTER padapter;
if (GLBtcBtCoexAliveRegistered == _FALSE)
return;
padapter = pBtCoexist->Adapter;
rtw_unregister_task_alive(padapter, BTCOEX_ALIVE);
GLBtcBtCoexAliveRegistered = _FALSE;
#endif /* CONFIG_LPS_LCLK */
}
void halbtcoutsrc_DisableLowPower(PBTC_COEXIST pBtCoexist, u8 bLowPwrDisable)
{
pBtCoexist->bt_info.bt_disable_low_pwr = bLowPwrDisable;
if (bLowPwrDisable)
halbtcoutsrc_LeaveLowPower(pBtCoexist); /* leave 32k low power. */
else
halbtcoutsrc_NormalLowPower(pBtCoexist); /* original 32k low power behavior. */
}
void halbtcoutsrc_AggregationCheck(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
BOOLEAN bNeedToAct = _FALSE;
static u32 preTime = 0;
u32 curTime = 0;
padapter = pBtCoexist->Adapter;
/* ===================================== */
/* To void continuous deleteBA=>addBA=>deleteBA=>addBA */
/* This function is not allowed to continuous called. */
/* It can only be called after 8 seconds. */
/* ===================================== */
curTime = rtw_systime_to_ms(rtw_get_current_time());
if ((curTime - preTime) < HALBTCOUTSRC_AGG_CHK_WINDOW_IN_MS) /* over 8 seconds you can execute this function again. */
return;
else
preTime = curTime;
if (pBtCoexist->bt_info.reject_agg_pkt) {
bNeedToAct = _TRUE;
pBtCoexist->bt_info.pre_reject_agg_pkt = pBtCoexist->bt_info.reject_agg_pkt;
} else {
if (pBtCoexist->bt_info.pre_reject_agg_pkt) {
bNeedToAct = _TRUE;
pBtCoexist->bt_info.pre_reject_agg_pkt = pBtCoexist->bt_info.reject_agg_pkt;
}
if (pBtCoexist->bt_info.pre_bt_ctrl_agg_buf_size !=
pBtCoexist->bt_info.bt_ctrl_agg_buf_size) {
bNeedToAct = _TRUE;
pBtCoexist->bt_info.pre_bt_ctrl_agg_buf_size = pBtCoexist->bt_info.bt_ctrl_agg_buf_size;
}
if (pBtCoexist->bt_info.bt_ctrl_agg_buf_size) {
if (pBtCoexist->bt_info.pre_agg_buf_size !=
pBtCoexist->bt_info.agg_buf_size)
bNeedToAct = _TRUE;
pBtCoexist->bt_info.pre_agg_buf_size = pBtCoexist->bt_info.agg_buf_size;
}
}
if (bNeedToAct)
rtw_btcoex_rx_ampdu_apply(padapter);
}
u8 halbtcoutsrc_is_autoload_fail(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
PHAL_DATA_TYPE pHalData;
padapter = pBtCoexist->Adapter;
pHalData = GET_HAL_DATA(padapter);
return pHalData->bautoload_fail_flag;
}
u8 halbtcoutsrc_is_fw_ready(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
padapter = pBtCoexist->Adapter;
return GET_HAL_DATA(padapter)->bFWReady;
}
u8 halbtcoutsrc_IsDualBandConnected(PADAPTER padapter)
{
u8 ret = BTC_MULTIPORT_SCC;
#ifdef CONFIG_MCC_MODE
if (MCC_EN(padapter) && (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))) {
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
u8 band0 = mccobjpriv->iface[0]->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
u8 band1 = mccobjpriv->iface[1]->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
if (band0 != band1)
ret = BTC_MULTIPORT_MCC_DUAL_BAND;
else
ret = BTC_MULTIPORT_MCC_DUAL_CHANNEL;
}
#endif
return ret;
}
u8 halbtcoutsrc_IsWifiBusy(PADAPTER padapter)
{
if (rtw_mi_check_status(padapter, MI_AP_ASSOC))
return _TRUE;
if (rtw_mi_busy_traffic_check(padapter, _FALSE))
return _TRUE;
return _FALSE;
}
static u32 _halbtcoutsrc_GetWifiLinkStatus(PADAPTER padapter)
{
struct mlme_priv *pmlmepriv;
u8 bp2p;
u32 portConnectedStatus;
pmlmepriv = &padapter->mlmepriv;
bp2p = _FALSE;
portConnectedStatus = 0;
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_state(&padapter->wdinfo, P2P_STATE_NONE))
bp2p = _TRUE;
#endif /* CONFIG_P2P */
if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE) == _TRUE) {
if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
if (_TRUE == bp2p)
portConnectedStatus |= WIFI_P2P_GO_CONNECTED;
else
portConnectedStatus |= WIFI_AP_CONNECTED;
} else {
if (_TRUE == bp2p)
portConnectedStatus |= WIFI_P2P_GC_CONNECTED;
else
portConnectedStatus |= WIFI_STA_CONNECTED;
}
}
return portConnectedStatus;
}
u32 halbtcoutsrc_GetWifiLinkStatus(PBTC_COEXIST pBtCoexist)
{
/* ================================= */
/* return value: */
/* [31:16]=> connected port number */
/* [15:0]=> port connected bit define */
/* ================================ */
PADAPTER padapter;
u32 retVal;
u32 portConnectedStatus, numOfConnectedPort;
struct dvobj_priv *dvobj;
_adapter *iface;
int i;
padapter = pBtCoexist->Adapter;
retVal = 0;
portConnectedStatus = 0;
numOfConnectedPort = 0;
dvobj = adapter_to_dvobj(padapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if ((iface) && rtw_is_adapter_up(iface)) {
retVal = _halbtcoutsrc_GetWifiLinkStatus(iface);
if (retVal) {
portConnectedStatus |= retVal;
numOfConnectedPort++;
}
}
}
retVal = (numOfConnectedPort << 16) | portConnectedStatus;
return retVal;
}
struct btc_wifi_link_info halbtcoutsrc_getwifilinkinfo(PBTC_COEXIST pBtCoexist)
{
u8 n_assoc_iface = 0, i =0, mcc_en = _FALSE;
PADAPTER adapter = NULL;
PADAPTER iface = NULL;
PADAPTER sta_iface = NULL, p2p_iface = NULL, ap_iface = NULL;
BTC_LINK_MODE btc_link_moe = BTC_LINK_MAX;
struct dvobj_priv *dvobj = NULL;
struct mlme_ext_priv *mlmeext = NULL;
struct btc_wifi_link_info wifi_link_info;
adapter = (PADAPTER)pBtCoexist->Adapter;
dvobj = adapter_to_dvobj(adapter);
n_assoc_iface = rtw_mi_get_assoc_if_num(adapter);
/* init value */
wifi_link_info.link_mode = BTC_LINK_NONE;
wifi_link_info.sta_center_channel = 0;
wifi_link_info.p2p_center_channel = 0;
wifi_link_info.bany_client_join_go = _FALSE;
wifi_link_info.benable_noa = _FALSE;
wifi_link_info.bhotspot = _FALSE;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
mlmeext = &iface->mlmeextpriv;
if (MLME_IS_GO(iface)) {
wifi_link_info.link_mode = BTC_LINK_ONLY_GO;
wifi_link_info.p2p_center_channel =
rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
p2p_iface = iface;
if (rtw_linked_check(iface))
wifi_link_info.bany_client_join_go = _TRUE;
} else if (MLME_IS_GC(iface)) {
wifi_link_info.link_mode = BTC_LINK_ONLY_GC;
wifi_link_info.p2p_center_channel =
rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
p2p_iface = iface;
} else if (MLME_IS_AP(iface)) {
wifi_link_info.link_mode = BTC_LINK_ONLY_AP;
ap_iface = iface;
wifi_link_info.p2p_center_channel =
rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
} else if (MLME_IS_STA(iface) && rtw_linked_check(iface)) {
wifi_link_info.link_mode = BTC_LINK_ONLY_STA;
wifi_link_info.sta_center_channel =
rtw_get_center_ch(mlmeext->cur_channel, mlmeext->cur_bwmode, mlmeext->cur_ch_offset);
sta_iface = iface;
}
}
#ifdef CONFIG_MCC_MODE
if (MCC_EN(adapter)) {
if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
mcc_en = _TRUE;
}
#endif/* CONFIG_MCC_MODE */
if (n_assoc_iface == 0) {
wifi_link_info.link_mode = BTC_LINK_NONE;
} else if (n_assoc_iface == 1) {
/* by pass */
} else if (n_assoc_iface == 2) {
if (sta_iface && p2p_iface) {
u8 band_sta = sta_iface->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
u8 band_p2p = p2p_iface->mlmeextpriv.cur_channel > 14 ? BAND_ON_5G : BAND_ON_2_4G;
if (band_sta == band_p2p) {
switch (band_sta) {
case BAND_ON_2_4G:
if (MLME_IS_GO(p2p_iface))
wifi_link_info.link_mode =
mcc_en == _TRUE ? BTC_LINK_2G_MCC_GO_STA : BTC_LINK_2G_SCC_GO_STA;
else if (MLME_IS_GC(p2p_iface))
wifi_link_info.link_mode =
mcc_en == _TRUE ? BTC_LINK_2G_MCC_GC_STA : BTC_LINK_2G_SCC_GC_STA;
break;
case BAND_ON_5G:
if (MLME_IS_GO(p2p_iface))
wifi_link_info.link_mode =
mcc_en == _TRUE ? BTC_LINK_5G_MCC_GO_STA : BTC_LINK_5G_SCC_GO_STA;
else if (MLME_IS_GC(p2p_iface))
wifi_link_info.link_mode =
mcc_en == _TRUE ? BTC_LINK_5G_MCC_GC_STA : BTC_LINK_5G_SCC_GC_STA;
break;
default:
break;
}
} else {
if (MLME_IS_GO(p2p_iface))
wifi_link_info.link_mode = BTC_LINK_25G_MCC_GO_STA;
else if (MLME_IS_GC(p2p_iface))
wifi_link_info.link_mode = BTC_LINK_25G_MCC_GC_STA;
}
}
} else {
if (pBtCoexist->board_info.btdm_ant_num == 1)
RTW_ERR("%s do not support n_assoc_iface > 2 (ant_num == 1)", __func__);
}
return wifi_link_info;
}
static void _btmpoper_timer_hdl(void *p)
{
if (GLBtcBtMpRptWait == _TRUE) {
GLBtcBtMpRptWait = _FALSE;
_rtw_up_sema(&GLBtcBtMpRptSema);
}
}
/*
* !IMPORTANT!
* Before call this function, caller should acquire "GLBtcBtMpOperLock"!
* Othrewise there will be racing problem and something may go wrong.
*/
static u8 _btmpoper_cmd(PBTC_COEXIST pBtCoexist, u8 opcode, u8 opcodever, u8 *cmd, u8 size)
{
PADAPTER padapter;
u8 buf[H2C_BTMP_OPER_LEN] = {0};
u8 buflen;
u8 seq;
s32 ret;
if (!cmd && size)
size = 0;
if ((size + 2) > H2C_BTMP_OPER_LEN)
return BT_STATUS_H2C_LENGTH_EXCEEDED;
buflen = size + 2;
seq = GLBtcBtMpOperSeq & 0xF;
GLBtcBtMpOperSeq++;
buf[0] = (opcodever & 0xF) | (seq << 4);
buf[1] = opcode;
if (cmd && size)
_rtw_memcpy(buf + 2, cmd, size);
GLBtcBtMpRptWait = _TRUE;
GLBtcBtMpRptWiFiOK = _FALSE;
GLBtcBtMpRptBTOK = _FALSE;
GLBtcBtMpRptStatus = 0;
padapter = pBtCoexist->Adapter;
_set_timer(&GLBtcBtMpOperTimer, BTC_MPOPER_TIMEOUT);
if (rtw_hal_fill_h2c_cmd(padapter, H2C_BT_MP_OPER, buflen, buf) == _FAIL) {
_cancel_timer_ex(&GLBtcBtMpOperTimer);
ret = BT_STATUS_H2C_FAIL;
goto exit;
}
_rtw_down_sema(&GLBtcBtMpRptSema);
/* GLBtcBtMpRptWait should be _FALSE here*/
if (GLBtcBtMpRptWiFiOK == _FALSE) {
RTW_ERR("%s: Didn't get H2C Rsp Event!\n", __FUNCTION__);
ret = BT_STATUS_H2C_TIMTOUT;
goto exit;
}
if (GLBtcBtMpRptBTOK == _FALSE) {
RTW_DBG("%s: Didn't get BT response!\n", __FUNCTION__);
ret = BT_STATUS_H2C_BT_NO_RSP;
goto exit;
}
if (seq != GLBtcBtMpRptSeq) {
RTW_ERR("%s: Sequence number not match!(%d!=%d)!\n",
__FUNCTION__, seq, GLBtcBtMpRptSeq);
ret = BT_STATUS_C2H_REQNUM_MISMATCH;
goto exit;
}
switch (GLBtcBtMpRptStatus) {
/* Examine the status reported from C2H */
case BT_STATUS_OK:
ret = BT_STATUS_BT_OP_SUCCESS;
RTW_DBG("%s: C2H status = BT_STATUS_BT_OP_SUCCESS\n", __FUNCTION__);
break;
case BT_STATUS_VERSION_MISMATCH:
ret = BT_STATUS_OPCODE_L_VERSION_MISMATCH;
RTW_DBG("%s: C2H status = BT_STATUS_OPCODE_L_VERSION_MISMATCH\n", __FUNCTION__);
break;
case BT_STATUS_UNKNOWN_OPCODE:
ret = BT_STATUS_UNKNOWN_OPCODE_L;
RTW_DBG("%s: C2H status = MP_BT_STATUS_UNKNOWN_OPCODE_L\n", __FUNCTION__);
break;
case BT_STATUS_ERROR_PARAMETER:
ret = BT_STATUS_PARAMETER_FORMAT_ERROR_L;
RTW_DBG("%s: C2H status = MP_BT_STATUS_PARAMETER_FORMAT_ERROR_L\n", __FUNCTION__);
break;
default:
ret = BT_STATUS_UNKNOWN_STATUS_L;
RTW_DBG("%s: C2H status = MP_BT_STATUS_UNKNOWN_STATUS_L\n", __FUNCTION__);
break;
}
exit:
return ret;
}
u32 halbtcoutsrc_GetBtPatchVer(PBTC_COEXIST pBtCoexist)
{
if (pBtCoexist->bt_info.get_bt_fw_ver_cnt <= 5) {
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
_irqL irqL;
u8 ret;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
ret = _btmpoper_cmd(pBtCoexist, BT_OP_GET_BT_VERSION, 0, NULL, 0);
if (BT_STATUS_BT_OP_SUCCESS == ret) {
pBtCoexist->bt_info.bt_real_fw_ver = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
pBtCoexist->bt_info.get_bt_fw_ver_cnt++;
}
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else {
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
u8 dataLen = 2;
u8 buf[4] = {0};
buf[0] = 0x0; /* OP_Code */
buf[1] = 0x0; /* OP_Code_Length */
BT_SendEventExtBtCoexControl(pBtCoexist->Adapter, _FALSE, dataLen, &buf[0]);
#endif /* !CONFIG_BT_COEXIST_SOCKET_TRX */
}
}
return pBtCoexist->bt_info.bt_real_fw_ver;
}
s32 halbtcoutsrc_GetWifiRssi(PADAPTER padapter)
{
return rtw_dm_get_min_rssi(padapter);
}
u32 halbtcoutsrc_GetBtCoexSupportedFeature(void *pBtcContext)
{
PBTC_COEXIST pBtCoexist;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
u32 data = 0;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_GET_BT_COEX_SUPPORTED_FEATURE;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
data = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return data;
}
u32 halbtcoutsrc_GetBtCoexSupportedVersion(void *pBtcContext)
{
PBTC_COEXIST pBtCoexist;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
u32 data = 0xFFFF;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_GET_BT_COEX_SUPPORTED_VERSION;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
data = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return data;
}
u32 halbtcoutsrc_GetBtDeviceInfo(void *pBtcContext)
{
PBTC_COEXIST pBtCoexist;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
u32 btDeviceInfo = 0;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_GET_BT_DEVICE_INFO;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
btDeviceInfo = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return btDeviceInfo;
}
u32 halbtcoutsrc_GetBtForbiddenSlotVal(void *pBtcContext)
{
PBTC_COEXIST pBtCoexist;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
u32 btForbiddenSlotVal = 0;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_GET_BT_FORBIDDEN_SLOT_VAL;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
btForbiddenSlotVal = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return btForbiddenSlotVal;
}
static u8 halbtcoutsrc_GetWifiScanAPNum(PADAPTER padapter)
{
struct mlme_priv *pmlmepriv;
struct mlme_ext_priv *pmlmeext;
static u8 scan_AP_num = 0;
pmlmepriv = &padapter->mlmepriv;
pmlmeext = &padapter->mlmeextpriv;
if (GLBtcWiFiInScanState == _FALSE) {
if (pmlmepriv->num_of_scanned > 0xFF)
scan_AP_num = 0xFF;
else
scan_AP_num = (u8)pmlmepriv->num_of_scanned;
}
return scan_AP_num;
}
u32 halbtcoutsrc_GetPhydmVersion(void *pBtcContext)
{
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
PADAPTER Adapter = pBtCoexist->Adapter;
#ifdef CONFIG_RTL8192E
return RELEASE_VERSION_8192E;
#endif
#ifdef CONFIG_RTL8821A
return RELEASE_VERSION_8821A;
#endif
#ifdef CONFIG_RTL8723B
return RELEASE_VERSION_8723B;
#endif
#ifdef CONFIG_RTL8812A
return RELEASE_VERSION_8812A;
#endif
#ifdef CONFIG_RTL8703B
return RELEASE_VERSION_8703B;
#endif
#ifdef CONFIG_RTL8822B
return RELEASE_VERSION_8822B;
#endif
#ifdef CONFIG_RTL8723D
return RELEASE_VERSION_8723D;
#endif
#ifdef CONFIG_RTL8821C
return RELEASE_VERSION_8821C;
#endif
#ifdef CONFIG_RTL8192F
return RELEASE_VERSION_8192F;
#endif
#ifdef CONFIG_RTL8822C
return RELEASE_VERSION_8822C;
#endif
#ifdef CONFIG_RTL8814A
return RELEASE_VERSION_8814A;
#endif
#ifdef CONFIG_RTL8814B
return RELEASE_VERSION_8814B;
#endif
}
u8 halbtcoutsrc_Get(void *pBtcContext, u8 getType, void *pOutBuf)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
PHAL_DATA_TYPE pHalData;
struct mlme_ext_priv *mlmeext;
struct btc_wifi_link_info *wifi_link_info;
u8 bSoftApExist, bVwifiExist;
u8 *pu8;
s32 *pS4Tmp;
u32 *pU4Tmp;
u8 *pU1Tmp;
u16 *pU2Tmp;
u8 ret;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return _FALSE;
padapter = pBtCoexist->Adapter;
pHalData = GET_HAL_DATA(padapter);
mlmeext = &padapter->mlmeextpriv;
bSoftApExist = _FALSE;
bVwifiExist = _FALSE;
pu8 = (u8 *)pOutBuf;
pS4Tmp = (s32 *)pOutBuf;
pU4Tmp = (u32 *)pOutBuf;
pU1Tmp = (u8 *)pOutBuf;
pU2Tmp = (u16*)pOutBuf;
wifi_link_info = (struct btc_wifi_link_info *)pOutBuf;
ret = _TRUE;
switch (getType) {
case BTC_GET_BL_HS_OPERATION:
*pu8 = _FALSE;
ret = _FALSE;
break;
case BTC_GET_BL_HS_CONNECTING:
*pu8 = _FALSE;
ret = _FALSE;
break;
case BTC_GET_BL_WIFI_FW_READY:
*pu8 = halbtcoutsrc_is_fw_ready(pBtCoexist);
break;
case BTC_GET_BL_WIFI_CONNECTED:
*pu8 = (rtw_mi_check_status(padapter, MI_LINKED)) ? _TRUE : _FALSE;
break;
case BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED:
*pu8 = halbtcoutsrc_IsDualBandConnected(padapter);
break;
case BTC_GET_BL_WIFI_BUSY:
*pu8 = halbtcoutsrc_IsWifiBusy(padapter);
break;
case BTC_GET_BL_WIFI_SCAN:
#if 0
*pu8 = (rtw_mi_check_fwstate(padapter, WIFI_SITE_MONITOR)) ? _TRUE : _FALSE;
#else
/* Use the value of the new variable GLBtcWiFiInScanState to judge whether WiFi is in scan state or not, since the originally used flag
WIFI_SITE_MONITOR in fwstate may not be cleared in time */
*pu8 = GLBtcWiFiInScanState;
#endif
break;
case BTC_GET_BL_WIFI_LINK:
*pu8 = (rtw_mi_check_status(padapter, MI_STA_LINKING)) ? _TRUE : _FALSE;
break;
case BTC_GET_BL_WIFI_ROAM:
*pu8 = (rtw_mi_check_status(padapter, MI_STA_LINKING)) ? _TRUE : _FALSE;
break;
case BTC_GET_BL_WIFI_4_WAY_PROGRESS:
*pu8 = _FALSE;
break;
case BTC_GET_BL_WIFI_UNDER_5G:
*pu8 = (pHalData->current_band_type == BAND_ON_5G) ? _TRUE : _FALSE;
break;
case BTC_GET_BL_WIFI_AP_MODE_ENABLE:
*pu8 = (rtw_mi_check_status(padapter, MI_AP_MODE)) ? _TRUE : _FALSE;
break;
case BTC_GET_BL_WIFI_ENABLE_ENCRYPTION:
*pu8 = padapter->securitypriv.dot11PrivacyAlgrthm == 0 ? _FALSE : _TRUE;
break;
case BTC_GET_BL_WIFI_UNDER_B_MODE:
if (mlmeext->cur_wireless_mode == WIRELESS_11B)
*pu8 = _TRUE;
else
*pu8 = _FALSE;
break;
case BTC_GET_BL_WIFI_IS_IN_MP_MODE:
if (padapter->registrypriv.mp_mode == 0)
*pu8 = _FALSE;
else
*pu8 = _TRUE;
break;
case BTC_GET_BL_EXT_SWITCH:
*pu8 = _FALSE;
break;
case BTC_GET_BL_IS_ASUS_8723B:
/* Always return FALSE in linux driver since this case is added only for windows driver */
*pu8 = _FALSE;
break;
case BTC_GET_BL_RF4CE_CONNECTED:
#ifdef CONFIG_RF4CE_COEXIST
if (hal_btcoex_get_rf4ce_link_state() == 0)
*pu8 = FALSE;
else
*pu8 = TRUE;
#else
*pu8 = FALSE;
#endif
break;
case BTC_GET_BL_WIFI_LW_PWR_STATE:
/* return false due to coex do not run during 32K */
*pu8 = FALSE;
break;
case BTC_GET_S4_WIFI_RSSI:
*pS4Tmp = halbtcoutsrc_GetWifiRssi(padapter);
break;
case BTC_GET_S4_HS_RSSI:
*pS4Tmp = 0;
ret = _FALSE;
break;
case BTC_GET_U4_WIFI_BW:
if (IsLegacyOnly(mlmeext->cur_wireless_mode))
*pU4Tmp = BTC_WIFI_BW_LEGACY;
else {
switch (pHalData->current_channel_bw) {
case CHANNEL_WIDTH_20:
*pU4Tmp = BTC_WIFI_BW_HT20;
break;
case CHANNEL_WIDTH_40:
*pU4Tmp = BTC_WIFI_BW_HT40;
break;
case CHANNEL_WIDTH_80:
*pU4Tmp = BTC_WIFI_BW_HT80;
break;
case CHANNEL_WIDTH_160:
*pU4Tmp = BTC_WIFI_BW_HT160;
break;
default:
RTW_INFO("[BTCOEX] unknown bandwidth(%d)\n", pHalData->current_channel_bw);
*pU4Tmp = BTC_WIFI_BW_HT40;
break;
}
}
break;
case BTC_GET_U4_WIFI_TRAFFIC_DIRECTION:
case BTC_GET_U4_WIFI_TRAFFIC_DIR:
{
PRT_LINK_DETECT_T plinkinfo;
plinkinfo = &padapter->mlmepriv.LinkDetectInfo;
if (plinkinfo->NumTxOkInPeriod > plinkinfo->NumRxOkInPeriod)
*pU4Tmp = BTC_WIFI_TRAFFIC_TX;
else
*pU4Tmp = BTC_WIFI_TRAFFIC_RX;
}
break;
case BTC_GET_U4_WIFI_FW_VER:
*pU4Tmp = pHalData->firmware_version << 16;
*pU4Tmp |= pHalData->firmware_sub_version;
break;
case BTC_GET_U4_WIFI_PHY_VER:
*pU4Tmp = halbtcoutsrc_GetPhydmVersion(pBtCoexist);
break;
case BTC_GET_U4_WIFI_LINK_STATUS:
*pU4Tmp = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
break;
case BTC_GET_BL_WIFI_LINK_INFO:
*wifi_link_info = halbtcoutsrc_getwifilinkinfo(pBtCoexist);
break;
case BTC_GET_U4_BT_PATCH_VER:
*pU4Tmp = halbtcoutsrc_GetBtPatchVer(pBtCoexist);
break;
case BTC_GET_U4_VENDOR:
*pU4Tmp = BTC_VENDOR_OTHER;
break;
case BTC_GET_U4_SUPPORTED_VERSION:
*pU4Tmp = halbtcoutsrc_GetBtCoexSupportedVersion(pBtCoexist);
break;
case BTC_GET_U4_SUPPORTED_FEATURE:
*pU4Tmp = halbtcoutsrc_GetBtCoexSupportedFeature(pBtCoexist);
break;
case BTC_GET_U4_BT_DEVICE_INFO:
*pU4Tmp = halbtcoutsrc_GetBtDeviceInfo(pBtCoexist);
break;
case BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL:
*pU4Tmp = halbtcoutsrc_GetBtForbiddenSlotVal(pBtCoexist);
break;
case BTC_GET_U4_WIFI_IQK_TOTAL:
*pU4Tmp = pHalData->odmpriv.n_iqk_cnt;
break;
case BTC_GET_U4_WIFI_IQK_OK:
*pU4Tmp = pHalData->odmpriv.n_iqk_ok_cnt;
break;
case BTC_GET_U4_WIFI_IQK_FAIL:
*pU4Tmp = pHalData->odmpriv.n_iqk_fail_cnt;
break;
case BTC_GET_U1_WIFI_DOT11_CHNL:
*pU1Tmp = padapter->mlmeextpriv.cur_channel;
break;
case BTC_GET_U1_WIFI_CENTRAL_CHNL:
*pU1Tmp = pHalData->current_channel;
break;
case BTC_GET_U1_WIFI_HS_CHNL:
*pU1Tmp = 0;
ret = _FALSE;
break;
case BTC_GET_U1_WIFI_P2P_CHNL:
#ifdef CONFIG_P2P
{
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
*pU1Tmp = pwdinfo->operating_channel;
}
#else
*pU1Tmp = 0;
#endif
break;
case BTC_GET_U1_MAC_PHY_MODE:
/* *pU1Tmp = BTC_SMSP;
* *pU1Tmp = BTC_DMSP;
* *pU1Tmp = BTC_DMDP;
* *pU1Tmp = BTC_MP_UNKNOWN; */
break;
case BTC_GET_U1_AP_NUM:
*pU1Tmp = halbtcoutsrc_GetWifiScanAPNum(padapter);
break;
case BTC_GET_U1_ANT_TYPE:
switch (pHalData->bt_coexist.btAntisolation) {
case 0:
*pU1Tmp = (u8)BTC_ANT_TYPE_0;
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_0;
break;
case 1:
*pU1Tmp = (u8)BTC_ANT_TYPE_1;
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_1;
break;
case 2:
*pU1Tmp = (u8)BTC_ANT_TYPE_2;
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_2;
break;
case 3:
*pU1Tmp = (u8)BTC_ANT_TYPE_3;
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_3;
break;
case 4:
*pU1Tmp = (u8)BTC_ANT_TYPE_4;
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_4;
break;
}
break;
case BTC_GET_U1_IOT_PEER:
*pU1Tmp = mlmeext->mlmext_info.assoc_AP_vendor;
break;
/* =======1Ant=========== */
case BTC_GET_U1_LPS_MODE:
*pU1Tmp = padapter->dvobj->pwrctl_priv.pwr_mode;
break;
case BTC_GET_U2_BEACON_PERIOD:
*pU2Tmp = mlmeext->mlmext_info.bcn_interval;
break;
default:
ret = _FALSE;
break;
}
return ret;
}
u16 halbtcoutsrc_LnaConstrainLvl(void *pBtcContext, u8 *lna_constrain_level)
{
PBTC_COEXIST pBtCoexist;
u16 ret = BT_STATUS_BT_OP_SUCCESS;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
_irqL irqL;
u8 op_code;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
ret = _btmpoper_cmd(pBtCoexist, BT_OP_SET_BT_LANCONSTRAIN_LEVEL, 0, lna_constrain_level, 1);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else {
ret = BT_STATUS_NOT_IMPLEMENT;
RTW_INFO("%s halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == FALSE\n", __func__);
}
return ret;
}
u8 halbtcoutsrc_SetBtGoldenRxRange(void *pBtcContext, u8 profile, u8 range_shift)
{
/* wait for implementation if necessary */
return 0;
}
u8 halbtcoutsrc_Set(void *pBtcContext, u8 setType, void *pInBuf)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
PHAL_DATA_TYPE pHalData;
u8 *pu8;
u8 *pU1Tmp;
u16 *pU2Tmp;
u32 *pU4Tmp;
u8 ret;
u8 result = _TRUE;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return _FALSE;
padapter = pBtCoexist->Adapter;
pHalData = GET_HAL_DATA(padapter);
pu8 = (u8 *)pInBuf;
pU1Tmp = (u8 *)pInBuf;
pU2Tmp = (u16*)pInBuf;
pU4Tmp = (u32 *)pInBuf;
ret = _TRUE;
switch (setType) {
/* set some u8 type variables. */
case BTC_SET_BL_BT_DISABLE:
pBtCoexist->bt_info.bt_disabled = *pu8;
break;
case BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE:
pBtCoexist->bt_info.bt_enable_disable_change = *pu8;
break;
case BTC_SET_BL_BT_TRAFFIC_BUSY:
pBtCoexist->bt_info.bt_busy = *pu8;
break;
case BTC_SET_BL_BT_LIMITED_DIG:
pBtCoexist->bt_info.limited_dig = *pu8;
break;
case BTC_SET_BL_FORCE_TO_ROAM:
pBtCoexist->bt_info.force_to_roam = *pu8;
break;
case BTC_SET_BL_TO_REJ_AP_AGG_PKT:
pBtCoexist->bt_info.reject_agg_pkt = *pu8;
break;
case BTC_SET_BL_BT_CTRL_AGG_SIZE:
pBtCoexist->bt_info.bt_ctrl_agg_buf_size = *pu8;
break;
case BTC_SET_BL_INC_SCAN_DEV_NUM:
pBtCoexist->bt_info.increase_scan_dev_num = *pu8;
break;
case BTC_SET_BL_BT_TX_RX_MASK:
pBtCoexist->bt_info.bt_tx_rx_mask = *pu8;
break;
case BTC_SET_BL_MIRACAST_PLUS_BT:
pBtCoexist->bt_info.miracast_plus_bt = *pu8;
break;
/* set some u8 type variables. */
case BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON:
pBtCoexist->bt_info.rssi_adjust_for_agc_table_on = *pU1Tmp;
break;
case BTC_SET_U1_AGG_BUF_SIZE:
pBtCoexist->bt_info.agg_buf_size = *pU1Tmp;
break;
/* the following are some action which will be triggered */
case BTC_SET_ACT_GET_BT_RSSI:
#if 0
BT_SendGetBtRssiEvent(padapter);
#else
ret = _FALSE;
#endif
break;
case BTC_SET_ACT_AGGREGATE_CTRL:
halbtcoutsrc_AggregationCheck(pBtCoexist);
break;
/* =======1Ant=========== */
/* set some u8 type variables. */
case BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE:
pBtCoexist->bt_info.rssi_adjust_for_1ant_coex_type = *pU1Tmp;
break;
case BTC_SET_U1_LPS_VAL:
pBtCoexist->bt_info.lps_val = *pU1Tmp;
break;
case BTC_SET_U1_RPWM_VAL:
pBtCoexist->bt_info.rpwm_val = *pU1Tmp;
break;
/* the following are some action which will be triggered */
case BTC_SET_ACT_LEAVE_LPS:
result = halbtcoutsrc_LeaveLps(pBtCoexist);
break;
case BTC_SET_ACT_ENTER_LPS:
halbtcoutsrc_EnterLps(pBtCoexist);
break;
case BTC_SET_ACT_NORMAL_LPS:
halbtcoutsrc_NormalLps(pBtCoexist);
break;
case BTC_SET_ACT_PRE_NORMAL_LPS:
halbtcoutsrc_Pre_NormalLps(pBtCoexist);
break;
case BTC_SET_ACT_POST_NORMAL_LPS:
halbtcoutsrc_Post_NormalLps(pBtCoexist);
break;
case BTC_SET_ACT_DISABLE_LOW_POWER:
halbtcoutsrc_DisableLowPower(pBtCoexist, *pu8);
break;
case BTC_SET_ACT_UPDATE_RAMASK:
/*
pBtCoexist->bt_info.ra_mask = *pU4Tmp;
if (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE) == _TRUE) {
struct sta_info *psta;
PWLAN_BSSID_EX cur_network;
cur_network = &padapter->mlmeextpriv.mlmext_info.network;
psta = rtw_get_stainfo(&padapter->stapriv, cur_network->MacAddress);
rtw_hal_update_ra_mask(psta);
}
*/
break;
case BTC_SET_ACT_SEND_MIMO_PS: {
u8 newMimoPsMode = 3;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* *pU1Tmp = 0 use SM_PS static type */
/* *pU1Tmp = 1 disable SM_PS */
if (*pU1Tmp == 0)
newMimoPsMode = WLAN_HT_CAP_SM_PS_STATIC;
else if (*pU1Tmp == 1)
newMimoPsMode = WLAN_HT_CAP_SM_PS_DISABLED;
if (check_fwstate(&padapter->mlmepriv , WIFI_ASOC_STATE) == _TRUE) {
/* issue_action_SM_PS(padapter, get_my_bssid(&(pmlmeinfo->network)), newMimoPsMode); */
issue_action_SM_PS_wait_ack(padapter , get_my_bssid(&(pmlmeinfo->network)) , newMimoPsMode, 3 , 1);
}
}
break;
case BTC_SET_ACT_CTRL_BT_INFO:
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
{
u8 dataLen = *pU1Tmp;
u8 tmpBuf[BTC_TMP_BUF_SHORT];
if (dataLen)
_rtw_memcpy(tmpBuf, pU1Tmp + 1, dataLen);
BT_SendEventExtBtInfoControl(padapter, dataLen, &tmpBuf[0]);
}
#else /* !CONFIG_BT_COEXIST_SOCKET_TRX */
ret = _FALSE;
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
break;
case BTC_SET_ACT_CTRL_BT_COEX:
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
{
u8 dataLen = *pU1Tmp;
u8 tmpBuf[BTC_TMP_BUF_SHORT];
if (dataLen)
_rtw_memcpy(tmpBuf, pU1Tmp + 1, dataLen);
BT_SendEventExtBtCoexControl(padapter, _FALSE, dataLen, &tmpBuf[0]);
}
#else /* !CONFIG_BT_COEXIST_SOCKET_TRX */
ret = _FALSE;
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
break;
case BTC_SET_ACT_CTRL_8723B_ANT:
#if 0
{
u8 dataLen = *pU1Tmp;
u8 tmpBuf[BTC_TMP_BUF_SHORT];
if (dataLen)
PlatformMoveMemory(&tmpBuf[0], pU1Tmp + 1, dataLen);
BT_Set8723bAnt(Adapter, dataLen, &tmpBuf[0]);
}
#else
ret = _FALSE;
#endif
break;
case BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL:
halbtcoutsrc_LnaConstrainLvl(pBtCoexist, pu8);
break;
case BTC_SET_BL_BT_GOLDEN_RX_RANGE:
halbtcoutsrc_SetBtGoldenRxRange(pBtCoexist, (*pU2Tmp & 0xff00) >> 8, (*pU2Tmp & 0xff));
break;
case BTC_SET_RESET_COEX_VAR:
_rtw_memset(&pBtCoexist->coex_dm, 0x00, sizeof(pBtCoexist->coex_dm));
_rtw_memset(&pBtCoexist->coex_sta, 0x00, sizeof(pBtCoexist->coex_sta));
switch(pBtCoexist->chip_type) {
#ifdef CONFIG_RTL8822B
case BTC_CHIP_RTL8822B:
_rtw_memset(&pBtCoexist->coex_dm_8822b_1ant, 0x00, sizeof(pBtCoexist->coex_dm_8822b_1ant));
_rtw_memset(&pBtCoexist->coex_dm_8822b_2ant, 0x00, sizeof(pBtCoexist->coex_dm_8822b_2ant));
break;
#endif
#ifdef CONFIG_RTL8821C
case BTC_CHIP_RTL8821C:
_rtw_memset(&pBtCoexist->coex_dm_8821c_1ant, 0x00, sizeof(pBtCoexist->coex_dm_8821c_1ant));
_rtw_memset(&pBtCoexist->coex_dm_8821c_2ant, 0x00, sizeof(pBtCoexist->coex_dm_8821c_2ant));
break;
#endif
#ifdef CONFIG_RTL8723D
case BTC_CHIP_RTL8723D:
_rtw_memset(&pBtCoexist->coex_dm_8723d_1ant, 0x00, sizeof(pBtCoexist->coex_dm_8723d_1ant));
_rtw_memset(&pBtCoexist->coex_dm_8723d_2ant, 0x00, sizeof(pBtCoexist->coex_dm_8723d_2ant));
break;
#endif
}
break;
/* ===================== */
default:
ret = _FALSE;
break;
}
return result;
}
u8 halbtcoutsrc_UnderIps(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter;
struct pwrctrl_priv *pwrpriv;
u8 bMacPwrCtrlOn;
padapter = pBtCoexist->Adapter;
pwrpriv = &padapter->dvobj->pwrctl_priv;
bMacPwrCtrlOn = _FALSE;
if ((_TRUE == pwrpriv->bips_processing)
&& (IPS_NONE != pwrpriv->ips_mode_req)
)
return _TRUE;
if (rf_off == pwrpriv->rf_pwrstate)
return _TRUE;
rtw_hal_get_hwreg(padapter, HW_VAR_APFM_ON_MAC, &bMacPwrCtrlOn);
if (_FALSE == bMacPwrCtrlOn)
return _TRUE;
return _FALSE;
}
u8 halbtcoutsrc_UnderLps(PBTC_COEXIST pBtCoexist)
{
return GLBtcWiFiInLPS;
}
u8 halbtcoutsrc_Under32K(PBTC_COEXIST pBtCoexist)
{
/* todo: the method to check whether wifi is under 32K or not */
return _FALSE;
}
void halbtcoutsrc_DisplayCoexStatistics(PBTC_COEXIST pBtCoexist)
{
#if 0
PADAPTER padapter = (PADAPTER)pBtCoexist->Adapter;
PBT_MGNT pBtMgnt = &padapter->MgntInfo.BtInfo.BtMgnt;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
u8 *cliBuf = pBtCoexist->cliBuf;
u8 i, j;
u8 tmpbuf[BTC_TMP_BUF_SHORT];
if (gl_coex_offload.cnt_h2c_sent) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Coex h2c notify]============");
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = H2c(%d)/Ack(%d)", "Coex h2c/c2h overall statistics",
gl_coex_offload.cnt_h2c_sent, gl_coex_offload.cnt_c2h_ack);
for (j = 0; j < COL_STATUS_MAX; j++) {
if (gl_coex_offload.status[j]) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.status[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
}
}
CL_PRINTF(cliBuf);
}
for (i = 0; i < COL_OP_WIFI_OPCODE_MAX; i++) {
if (gl_coex_offload.h2c_record[i].count) {
/*==========================================*/
/* H2C result statistics*/
/*==========================================*/
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = total:%d", coexOpcodeString[i], gl_coex_offload.h2c_record[i].count);
for (j = 0; j < COL_STATUS_MAX; j++) {
if (gl_coex_offload.h2c_record[i].status[j]) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.h2c_record[i].status[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
}
}
CL_PRINTF(cliBuf);
/*==========================================*/
/* H2C/C2H content*/
/*==========================================*/
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = ", "H2C / C2H content");
for (j = 0; j < gl_coex_offload.h2c_record[i].h2c_len; j++) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, "%02x ", gl_coex_offload.h2c_record[i].h2c_buf[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, 3);
}
if (gl_coex_offload.h2c_record[i].c2h_ack_len) {
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, "/ ", 2);
for (j = 0; j < gl_coex_offload.h2c_record[i].c2h_ack_len; j++) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, "%02x ", gl_coex_offload.h2c_record[i].c2h_ack_buf[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, 3);
}
}
CL_PRINTF(cliBuf);
/*==========================================*/
}
}
if (gl_coex_offload.cnt_c2h_ind) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Coex c2h indication]============");
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = Ind(%d)", "C2H indication statistics",
gl_coex_offload.cnt_c2h_ind);
for (j = 0; j < COL_STATUS_MAX; j++) {
if (gl_coex_offload.c2h_ind_status[j]) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.c2h_ind_status[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
}
}
CL_PRINTF(cliBuf);
}
for (i = 0; i < COL_IND_MAX; i++) {
if (gl_coex_offload.c2h_ind_record[i].count) {
/*==========================================*/
/* H2C result statistics*/
/*==========================================*/
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = total:%d", coexIndTypeString[i], gl_coex_offload.c2h_ind_record[i].count);
for (j = 0; j < COL_STATUS_MAX; j++) {
if (gl_coex_offload.c2h_ind_record[i].status[j]) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, ", %s:%d", coexH2cResultString[j], gl_coex_offload.c2h_ind_record[i].status[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, BTC_TMP_BUF_SHORT);
}
}
CL_PRINTF(cliBuf);
/*==========================================*/
/* content*/
/*==========================================*/
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = ", "C2H indication content");
for (j = 0; j < gl_coex_offload.c2h_ind_record[i].ind_len; j++) {
CL_SPRINTF(tmpbuf, BTC_TMP_BUF_SHORT, "%02x ", gl_coex_offload.c2h_ind_record[i].ind_buf[j]);
CL_STRNCAT(cliBuf, BT_TMP_BUF_SIZE, tmpbuf, 3);
}
CL_PRINTF(cliBuf);
/*==========================================*/
}
}
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Statistics]============");
CL_PRINTF(cliBuf);
#if (H2C_USE_IO_THREAD != 1)
for (i = 0; i < H2C_STATUS_MAX; i++) {
if (pHalData->h2cStatistics[i]) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s] = %d", "H2C statistics", \
h2cStaString[i], pHalData->h2cStatistics[i]);
CL_PRINTF(cliBuf);
}
}
#else
for (i = 0; i < IO_STATUS_MAX; i++) {
if (Adapter->ioComStr.ioH2cStatistics[i]) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = [%s] = %d", "H2C statistics", \
ioStaString[i], Adapter->ioComStr.ioH2cStatistics[i]);
CL_PRINTF(cliBuf);
}
}
#endif
#if 0
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "lastHMEBoxNum", \
pHalData->LastHMEBoxNum);
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x / 0x%x", "LastOkH2c/FirstFailH2c(fwNotRead)", \
pHalData->lastSuccessH2cEid, pHalData->firstFailedH2cEid);
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "c2hIsr/c2hIntr/clr1AF/noRdy/noBuf", \
pHalData->InterruptLog.nIMR_C2HCMD, DBG_Var.c2hInterruptCnt, DBG_Var.c2hClrReadC2hCnt,
DBG_Var.c2hNotReadyCnt, DBG_Var.c2hBufAlloFailCnt);
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d", "c2hPacket", \
DBG_Var.c2hPacketCnt);
CL_PRINTF(cliBuf);
#endif
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d", "Periodical/ DbgCtrl", \
pBtCoexist->statistics.cntPeriodical, pBtCoexist->statistics.cntDbgCtrl);
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d", "PowerOn/InitHw/InitCoexDm/RfStatus", \
pBtCoexist->statistics.cntPowerOn, pBtCoexist->statistics.cntInitHwConfig, pBtCoexist->statistics.cntInitCoexDm,
pBtCoexist->statistics.cntRfStatusNotify);
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "Ips/Lps/Scan/Connect/Mstatus", \
pBtCoexist->statistics.cntIpsNotify, pBtCoexist->statistics.cntLpsNotify,
pBtCoexist->statistics.cntScanNotify, pBtCoexist->statistics.cntConnectNotify,
pBtCoexist->statistics.cntMediaStatusNotify);
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d", "Special pkt/Bt info/ bind",
pBtCoexist->statistics.cntSpecialPacketNotify, pBtCoexist->statistics.cntBtInfoNotify,
pBtCoexist->statistics.cntBind);
CL_PRINTF(cliBuf);
#endif
PADAPTER padapter = pBtCoexist->Adapter;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
u8 *cliBuf = pBtCoexist->cli_buf;
if (pHalData->EEPROMBluetoothCoexist == 1) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Coex Status]============");
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IsBtDisabled", rtw_btcoex_IsBtDisabled(padapter));
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "IsBtControlLps", rtw_btcoex_IsBtControlLps(padapter));
CL_PRINTF(cliBuf);
}
}
void halbtcoutsrc_DisplayBtLinkInfo(PBTC_COEXIST pBtCoexist)
{
#if 0
PADAPTER padapter = (PADAPTER)pBtCoexist->Adapter;
PBT_MGNT pBtMgnt = &padapter->MgntInfo.BtInfo.BtMgnt;
u8 *cliBuf = pBtCoexist->cliBuf;
u8 i;
if (pBtCoexist->stack_info.profile_notified) {
for (i = 0; i < pBtMgnt->ExtConfig.NumberOfACL; i++) {
if (pBtMgnt->ExtConfig.HCIExtensionVer >= 1) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s", "Bt link type/spec/role", \
BtProfileString[pBtMgnt->ExtConfig.aclLink[i].BTProfile],
BtSpecString[pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec],
BtLinkRoleString[pBtMgnt->ExtConfig.aclLink[i].linkRole]);
CL_PRINTF(cliBuf);
} else {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s", "Bt link type/spec", \
BtProfileString[pBtMgnt->ExtConfig.aclLink[i].BTProfile],
BtSpecString[pBtMgnt->ExtConfig.aclLink[i].BTCoreSpec]);
CL_PRINTF(cliBuf);
}
}
}
#endif
}
void halbtcoutsrc_DisplayWifiStatus(PBTC_COEXIST pBtCoexist)
{
PADAPTER padapter = pBtCoexist->Adapter;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
u8 *cliBuf = pBtCoexist->cli_buf;
s32 wifiRssi = 0, btHsRssi = 0;
BOOLEAN bScan = _FALSE, bLink = _FALSE, bRoam = _FALSE, bWifiBusy = _FALSE, bWifiUnderBMode = _FALSE;
u32 wifiBw = BTC_WIFI_BW_HT20, wifiTrafficDir = BTC_WIFI_TRAFFIC_TX, wifiFreq = BTC_FREQ_2_4G;
u32 wifiLinkStatus = 0x0;
BOOLEAN bBtHsOn = _FALSE, bLowPower = _FALSE;
u8 wifiChnl = 0, wifiP2PChnl = 0, nScanAPNum = 0, FwPSState;
u32 iqk_cnt_total = 0, iqk_cnt_ok = 0, iqk_cnt_fail = 0;
u16 wifiBcnInterval = 0;
PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
struct btc_wifi_link_info wifi_link_info;
wifi_link_info = halbtcoutsrc_getwifilinkinfo(pBtCoexist);
switch (wifi_link_info.link_mode) {
case BTC_LINK_NONE:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"None", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = hal->current_channel > 14 ? BTC_FREQ_5G : BTC_FREQ_2_4G;
break;
case BTC_LINK_ONLY_GO:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"ONLY_GO", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = hal->current_channel > 14 ? BTC_FREQ_5G : BTC_FREQ_2_4G;
break;
case BTC_LINK_ONLY_GC:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"ONLY_GC", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = hal->current_channel > 14 ? BTC_FREQ_5G : BTC_FREQ_2_4G;
break;
case BTC_LINK_ONLY_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"ONLY_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = hal->current_channel > 14 ? BTC_FREQ_5G : BTC_FREQ_2_4G;
break;
case BTC_LINK_ONLY_AP:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"ONLY_AP", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = hal->current_channel > 14 ? BTC_FREQ_5G : BTC_FREQ_2_4G;
break;
case BTC_LINK_2G_MCC_GO_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"24G_MCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_2_4G;
break;
case BTC_LINK_5G_MCC_GO_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"5G_MCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_5G;
break;
case BTC_LINK_25G_MCC_GO_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"2BANDS_MCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_25G;
break;
case BTC_LINK_2G_MCC_GC_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"24G_MCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_2_4G;
break;
case BTC_LINK_5G_MCC_GC_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"5G_MCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_5G;
break;
case BTC_LINK_25G_MCC_GC_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"2BANDS_MCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_25G;
break;
case BTC_LINK_2G_SCC_GO_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"24G_SCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_2_4G;
break;
case BTC_LINK_5G_SCC_GO_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"5G_SCC_GO_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_5G;
break;
case BTC_LINK_2G_SCC_GC_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"24G_SCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_2_4G;
break;
case BTC_LINK_5G_SCC_GC_STA:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"5G_SCC_GC_STA", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = BTC_FREQ_5G;
break;
default:
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %d/ %d/ %d", "WifiLinkMode/HotSpa/Noa/ClientJoin",
"UNKNOWN", wifi_link_info.bhotspot, wifi_link_info.benable_noa, wifi_link_info.bany_client_join_go);
wifiFreq = hal->current_channel > 14 ? BTC_FREQ_5G : BTC_FREQ_2_4G;
break;
}
CL_PRINTF(cliBuf);
wifiLinkStatus = halbtcoutsrc_GetWifiLinkStatus(pBtCoexist);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d/ %d/ %d", "STA/vWifi/HS/p2pGo/p2pGc",
((wifiLinkStatus & WIFI_STA_CONNECTED) ? 1 : 0), ((wifiLinkStatus & WIFI_AP_CONNECTED) ? 1 : 0),
((wifiLinkStatus & WIFI_HS_CONNECTED) ? 1 : 0), ((wifiLinkStatus & WIFI_P2P_GO_CONNECTED) ? 1 : 0),
((wifiLinkStatus & WIFI_P2P_GC_CONNECTED) ? 1 : 0));
CL_PRINTF(cliBuf);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_SCAN, &bScan);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_LINK, &bLink);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_ROAM, &bRoam);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d ", "Link/ Roam/ Scan",
bLink, bRoam, bScan);
CL_PRINTF(cliBuf);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_IQK_TOTAL, &iqk_cnt_total);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_IQK_OK, &iqk_cnt_ok);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_IQK_FAIL, &iqk_cnt_fail);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/ %d/ %d %s %s",
"IQK All/ OK/ Fail/AutoLoad/FWDL", iqk_cnt_total, iqk_cnt_ok, iqk_cnt_fail,
((halbtcoutsrc_is_autoload_fail(pBtCoexist) == _TRUE) ? "fail":"ok"), ((halbtcoutsrc_is_fw_ready(pBtCoexist) == _TRUE) ? "ok":"fail"));
CL_PRINTF(cliBuf);
if (wifiLinkStatus & WIFI_STA_CONNECTED) {
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "IOT Peer", GLBtcIotPeerString[padapter->mlmeextpriv.mlmext_info.assoc_AP_vendor]);
CL_PRINTF(cliBuf);
}
pBtCoexist->btc_get(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wifiRssi);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U2_BEACON_PERIOD, &wifiBcnInterval);
wifiChnl = wifi_link_info.sta_center_channel;
wifiP2PChnl = wifi_link_info.p2p_center_channel;
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d dBm/ %d/ %d/ %d", "RSSI/ STA_Chnl/ P2P_Chnl/ BI",
wifiRssi-100, wifiChnl, wifiP2PChnl, wifiBcnInterval);
CL_PRINTF(cliBuf);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_BW, &wifiBw);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &bWifiBusy);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, &wifiTrafficDir);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_UNDER_B_MODE, &bWifiUnderBMode);
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U1_AP_NUM, &nScanAPNum);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %s/ %s/ %d ", "Band/ BW/ Traffic/ APCnt",
GLBtcWifiFreqString[wifiFreq], ((bWifiUnderBMode) ? "11b" : GLBtcWifiBwString[wifiBw]),
((!bWifiBusy) ? "idle" : ((BTC_WIFI_TRAFFIC_TX == wifiTrafficDir) ? "uplink" : "downlink")),
nScanAPNum);
CL_PRINTF(cliBuf);
/* power status */
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s%s%s", "Power Status", \
((halbtcoutsrc_UnderIps(pBtCoexist) == _TRUE) ? "IPS ON" : "IPS OFF"),
((halbtcoutsrc_UnderLps(pBtCoexist) == _TRUE) ? ", LPS ON" : ", LPS OFF"),
((halbtcoutsrc_Under32K(pBtCoexist) == _TRUE) ? ", 32k" : ""));
CL_PRINTF(cliBuf);
CL_SPRINTF(cliBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %02x %02x %02x %02x %02x %02x (0x%x/0x%x)", "Power mode cmd(lps/rpwm)",
pBtCoexist->pwrModeVal[0], pBtCoexist->pwrModeVal[1],
pBtCoexist->pwrModeVal[2], pBtCoexist->pwrModeVal[3],
pBtCoexist->pwrModeVal[4], pBtCoexist->pwrModeVal[5],
pBtCoexist->bt_info.lps_val,
pBtCoexist->bt_info.rpwm_val);
CL_PRINTF(cliBuf);
}
void halbtcoutsrc_DisplayDbgMsg(void *pBtcContext, u8 dispType)
{
PBTC_COEXIST pBtCoexist;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
switch (dispType) {
case BTC_DBG_DISP_COEX_STATISTICS:
halbtcoutsrc_DisplayCoexStatistics(pBtCoexist);
break;
case BTC_DBG_DISP_BT_LINK_INFO:
halbtcoutsrc_DisplayBtLinkInfo(pBtCoexist);
break;
case BTC_DBG_DISP_WIFI_STATUS:
halbtcoutsrc_DisplayWifiStatus(pBtCoexist);
break;
default:
break;
}
}
/* ************************************
* IO related function
* ************************************ */
u8 halbtcoutsrc_Read1Byte(void *pBtcContext, u32 RegAddr)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
return rtw_read8(padapter, RegAddr);
}
u16 halbtcoutsrc_Read2Byte(void *pBtcContext, u32 RegAddr)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
return rtw_read16(padapter, RegAddr);
}
u32 halbtcoutsrc_Read4Byte(void *pBtcContext, u32 RegAddr)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
return rtw_read32(padapter, RegAddr);
}
void halbtcoutsrc_Write1Byte(void *pBtcContext, u32 RegAddr, u8 Data)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
rtw_write8(padapter, RegAddr, Data);
}
void halbtcoutsrc_BitMaskWrite1Byte(void *pBtcContext, u32 regAddr, u8 bitMask, u8 data1b)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
u8 originalValue, bitShift;
u8 i;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
originalValue = 0;
bitShift = 0;
if (bitMask != 0xff) {
originalValue = rtw_read8(padapter, regAddr);
for (i = 0; i <= 7; i++) {
if ((bitMask >> i) & 0x1)
break;
}
bitShift = i;
data1b = (originalValue & ~bitMask) | ((data1b << bitShift) & bitMask);
}
rtw_write8(padapter, regAddr, data1b);
}
void halbtcoutsrc_Write2Byte(void *pBtcContext, u32 RegAddr, u16 Data)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
rtw_write16(padapter, RegAddr, Data);
}
void halbtcoutsrc_Write4Byte(void *pBtcContext, u32 RegAddr, u32 Data)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
rtw_write32(padapter, RegAddr, Data);
}
void halbtcoutsrc_WriteLocalReg1Byte(void *pBtcContext, u32 RegAddr, u8 Data)
{
PBTC_COEXIST pBtCoexist = (PBTC_COEXIST)pBtcContext;
PADAPTER Adapter = pBtCoexist->Adapter;
if (BTC_INTF_SDIO == pBtCoexist->chip_interface)
rtw_write8(Adapter, SDIO_LOCAL_BASE | RegAddr, Data);
else
rtw_write8(Adapter, RegAddr, Data);
}
u32 halbtcoutsrc_WaitLIndirectReg_Ready(void *pBtcContext)
{
PBTC_COEXIST btc = (PBTC_COEXIST)pBtcContext;
u32 delay_count = 0, reg = 0;
if (!btc->chip_para->lte_indirect_access)
return 0;
switch (btc->chip_para->indirect_type) {
case BTC_INDIRECT_1700:
reg = 0x1703;
break;
case BTC_INDIRECT_7C0:
reg = 0x7C3;
break;
default:
return 0;
}
/* wait for ready bit before access */
while (1) {
if ((halbtcoutsrc_Read1Byte(btc, reg) & BIT(5)) == 0) {
rtw_mdelay_os(10);
if (++delay_count >= 10)
break;
} else {
break;
}
}
return delay_count;
}
u32 halbtcoutsrc_ReadLIndirectReg(void *pBtcContext, u16 reg_addr)
{
PBTC_COEXIST btc = (PBTC_COEXIST)pBtcContext;
u32 val = 0;
if (!btc->chip_para->lte_indirect_access)
return 0;
/* wait for ready bit before access */
halbtcoutsrc_WaitLIndirectReg_Ready(btc);
switch (btc->chip_para->indirect_type) {
case BTC_INDIRECT_1700:
halbtcoutsrc_Write4Byte(btc, 0x1700, 0x800F0000 | reg_addr);
val = halbtcoutsrc_Read4Byte(btc, 0x1708); /* get read data */
break;
case BTC_INDIRECT_7C0:
halbtcoutsrc_Write4Byte(btc, 0x7c0, 0x800F0000 | reg_addr);
val = halbtcoutsrc_Read4Byte(btc, 0x7c8); /* get read data */
break;
}
return val;
}
void halbtcoutsrc_WriteLIndirectReg(void *pBtcContext, u16 reg_addr, u32 bit_mask, u32 reg_value)
{
PBTC_COEXIST btc = (PBTC_COEXIST)pBtcContext;
u32 val, i = 0, bitpos = 0, reg0, reg1;
if (!btc->chip_para->lte_indirect_access)
return;
if (bit_mask == 0x0)
return;
switch (btc->chip_para->indirect_type) {
case BTC_INDIRECT_1700:
reg0 = 0x1700;
reg1 = 0x1704;
break;
case BTC_INDIRECT_7C0:
reg0 = 0x7C0;
reg1 = 0x7C4;
break;
default:
return;
}
if (bit_mask == 0xffffffff) {
/* wait for ready bit before access 0x1700 */
halbtcoutsrc_WaitLIndirectReg_Ready(btc);
/* put write data */
halbtcoutsrc_Write4Byte(btc, reg1, reg_value);
halbtcoutsrc_Write4Byte(btc, reg0, 0xc00F0000 | reg_addr);
} else {
for (i = 0; i <= 31; i++) {
if (((bit_mask >> i) & 0x1) == 0x1) {
bitpos = i;
break;
}
}
/* read back register value before write */
val = halbtcoutsrc_ReadLIndirectReg(btc, reg_addr);
val = (val & (~bit_mask)) | (reg_value << bitpos);
/* wait for ready bit before access 0x1700 */
halbtcoutsrc_WaitLIndirectReg_Ready(btc);
halbtcoutsrc_Write4Byte(btc, reg1, val); /* put write data */
halbtcoutsrc_Write4Byte(btc, reg0, 0xc00F0000 | reg_addr);
}
}
void halbtcoutsrc_Read_scbd(void *pBtcContext, u16* score_board_val)
{
PBTC_COEXIST btc = (PBTC_COEXIST)pBtcContext;
struct btc_coex_sta *coex_sta = &btc->coex_sta;
const struct btc_chip_para *chip_para = btc->chip_para;
if (!chip_para->scbd_support)
return;
*score_board_val = (btc->btc_read_2byte(btc, 0xaa)) & 0x7fff;
coex_sta->score_board_BW = *score_board_val;
}
void halbtcoutsrc_Write_scbd(void *pBtcContext, u16 bitpos, u8 state)
{
PBTC_COEXIST btc = (PBTC_COEXIST)pBtcContext;
struct btc_coex_sta *coex_sta = &btc->coex_sta;
const struct btc_chip_para *chip_para = btc->chip_para;
u16 val = 0x2;
u8* btc_dbg_buf = &gl_btc_trace_buf[0];
if (!chip_para->scbd_support)
return;
val = val | coex_sta->score_board_WB;
/* for 8822b, Scoreboard[10]: 0: CQDDR off, 1: CQDDR on
* for 8822c, Scoreboard[10]: 0: CQDDR on, 1:CQDDR fix 2M
*/
if (!btc->chip_para->new_scbd10_def && (bitpos & BTC_SCBD_FIX2M)) {
if (state)
val = val & (~BTC_SCBD_FIX2M);
else
val = val | BTC_SCBD_FIX2M;
} else {
if (state)
val = val | bitpos;
else
val = val & (~bitpos);
}
if (val != coex_sta->score_board_WB) {
coex_sta->score_board_WB = val;
val = val | 0x8000;
btc->btc_write_2byte(btc, 0xaa, val);
BTC_SPRINTF(btc_dbg_buf, BT_TMP_BUF_SIZE,
"[BTCoex], write scoreboard 0x%x\n", val);
} else {
BTC_SPRINTF(btc_dbg_buf, BT_TMP_BUF_SIZE,
"[BTCoex], %s: return for nochange\n", __func__);
}
BTC_TRACE(btc_dbg_buf);
}
void halbtcoutsrc_SetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask, u32 Data)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
phy_set_bb_reg(padapter, RegAddr, BitMask, Data);
}
u32 halbtcoutsrc_GetBbReg(void *pBtcContext, u32 RegAddr, u32 BitMask)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
return phy_query_bb_reg(padapter, RegAddr, BitMask);
}
void halbtcoutsrc_SetRfReg(void *pBtcContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
phy_set_rf_reg(padapter, eRFPath, RegAddr, BitMask, Data);
}
u32 halbtcoutsrc_GetRfReg(void *pBtcContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
return phy_query_rf_reg(padapter, eRFPath, RegAddr, BitMask);
}
u16 halbtcoutsrc_SetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr, u32 Data)
{
PBTC_COEXIST pBtCoexist;
u16 ret = BT_STATUS_BT_OP_SUCCESS;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
Data = cpu_to_le32(Data);
op_code = BT_OP_WRITE_REG_VALUE;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, (u8 *)&Data, 3);
if (status != BT_STATUS_BT_OP_SUCCESS)
ret = SET_BT_MP_OPER_RET(op_code, status);
else {
buf[0] = RegType;
*(u16 *)(buf + 1) = cpu_to_le16((u16)RegAddr);
op_code = BT_OP_WRITE_REG_ADDR;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 3);
if (status != BT_STATUS_BT_OP_SUCCESS)
ret = SET_BT_MP_OPER_RET(op_code, status);
}
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return ret;
}
u8 halbtcoutsrc_SetBtAntDetection(void *pBtcContext, u8 txTime, u8 btChnl)
{
/* Always return _FALSE since we don't implement this yet */
#if 0
PBTC_COEXIST pBtCoexist = (PBTC_COEXIST)pBtcContext;
PADAPTER Adapter = pBtCoexist->Adapter;
u8 btCanTx = 0;
BOOLEAN bStatus = FALSE;
bStatus = NDBG_SetBtAntDetection(Adapter, txTime, btChnl, &btCanTx);
if (bStatus && btCanTx)
return _TRUE;
else
return _FALSE;
#else
return _FALSE;
#endif
}
BOOLEAN
halbtcoutsrc_SetBtTRXMASK(
void *pBtcContext,
u8 bt_trx_mask
)
{
/* Always return _FALSE since we don't implement this yet */
#if 0
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
PADAPTER Adapter = pBtCoexist->Adapter;
BOOLEAN bStatus = FALSE;
u8 btCanTx = 0;
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter) || IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)
|| IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter))
bStatus = NDBG_SetBtTRXMASK(Adapter, 1, bt_trx_mask, &btCanTx);
else
bStatus = NDBG_SetBtTRXMASK(Adapter, 2, bt_trx_mask, &btCanTx);
}
if (bStatus)
return TRUE;
else
return FALSE;
#else
return _FALSE;
#endif
}
u16 halbtcoutsrc_GetBtReg_with_status(void *pBtcContext, u8 RegType, u32 RegAddr, u32 *data)
{
PBTC_COEXIST pBtCoexist;
u16 ret = BT_STATUS_BT_OP_SUCCESS;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
buf[0] = RegType;
*(u16 *)(buf + 1) = cpu_to_le16((u16)RegAddr);
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_READ_REG;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 3);
if (status == BT_STATUS_BT_OP_SUCCESS)
*data = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return ret;
}
u32 halbtcoutsrc_GetBtReg(void *pBtcContext, u8 RegType, u32 RegAddr)
{
u32 regVal;
return (BT_STATUS_BT_OP_SUCCESS == halbtcoutsrc_GetBtReg_with_status(pBtcContext, RegType, RegAddr, ®Val)) ? regVal : 0xffffffff;
}
u16 halbtcoutsrc_setbttestmode(void *pBtcContext, u8 Type)
{
PBTC_COEXIST pBtCoexist;
u16 ret = BT_STATUS_BT_OP_SUCCESS;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
Type = cpu_to_le32(Type);
op_code = BT_OP_SET_BT_TEST_MODE_VAL;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, (u8 *)&Type, 3);
if (status != BT_STATUS_BT_OP_SUCCESS)
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return ret;
}
void halbtcoutsrc_FillH2cCmd(void *pBtcContext, u8 elementId, u32 cmdLen, u8 *pCmdBuffer)
{
PBTC_COEXIST pBtCoexist;
PADAPTER padapter;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
padapter = pBtCoexist->Adapter;
rtw_hal_fill_h2c_cmd(padapter, elementId, cmdLen, pCmdBuffer);
}
static void halbtcoutsrc_coex_offload_init(void)
{
u8 i;
gl_coex_offload.h2c_req_num = 0;
gl_coex_offload.cnt_h2c_sent = 0;
gl_coex_offload.cnt_c2h_ack = 0;
gl_coex_offload.cnt_c2h_ind = 0;
for (i = 0; i < COL_MAX_H2C_REQ_NUM; i++)
init_completion(&gl_coex_offload.c2h_event[i]);
}
static COL_H2C_STATUS halbtcoutsrc_send_h2c(PADAPTER Adapter, PCOL_H2C pcol_h2c, u16 h2c_cmd_len)
{
COL_H2C_STATUS h2c_status = COL_STATUS_C2H_OK;
u8 i;
#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 13, 0))
reinit_completion(&gl_coex_offload.c2h_event[pcol_h2c->req_num]); /* set event to un signaled state */
#else
INIT_COMPLETION(gl_coex_offload.c2h_event[pcol_h2c->req_num]);
#endif
if (TRUE) {
#if 0 /*(USE_HAL_MAC_API == 1) */
if (RT_STATUS_SUCCESS == HAL_MAC_Send_BT_COEX(&GET_HAL_MAC_INFO(Adapter), (u8 *)(pcol_h2c), (u32)h2c_cmd_len, 1)) {
if (!wait_for_completion_timeout(&gl_coex_offload.c2h_event[pcol_h2c->req_num], 20)) {
h2c_status = COL_STATUS_H2C_TIMTOUT;
}
} else {
h2c_status = COL_STATUS_H2C_HALMAC_FAIL;
}
#endif
}
return h2c_status;
}
static COL_H2C_STATUS halbtcoutsrc_check_c2h_ack(PADAPTER Adapter, PCOL_SINGLE_H2C_RECORD pH2cRecord)
{
COL_H2C_STATUS c2h_status = COL_STATUS_C2H_OK;
PCOL_H2C p_h2c_cmd = (PCOL_H2C)&pH2cRecord->h2c_buf[0];
u8 req_num = p_h2c_cmd->req_num;
PCOL_C2H_ACK p_c2h_ack = (PCOL_C2H_ACK)&gl_coex_offload.c2h_ack_buf[req_num];
if ((COL_C2H_ACK_HDR_LEN + p_c2h_ack->ret_len) > gl_coex_offload.c2h_ack_len[req_num]) {
c2h_status = COL_STATUS_COEX_DATA_OVERFLOW;
return c2h_status;
}
/* else */
{
_rtw_memmove(&pH2cRecord->c2h_ack_buf[0], &gl_coex_offload.c2h_ack_buf[req_num], gl_coex_offload.c2h_ack_len[req_num]);
pH2cRecord->c2h_ack_len = gl_coex_offload.c2h_ack_len[req_num];
}
if (p_c2h_ack->req_num != p_h2c_cmd->req_num) {
c2h_status = COL_STATUS_C2H_REQ_NUM_MISMATCH;
} else if (p_c2h_ack->opcode_ver != p_h2c_cmd->opcode_ver) {
c2h_status = COL_STATUS_C2H_OPCODE_VER_MISMATCH;
} else {
c2h_status = p_c2h_ack->status;
}
return c2h_status;
}
COL_H2C_STATUS halbtcoutsrc_CoexH2cProcess(void *pBtCoexist,
u8 opcode, u8 opcode_ver, u8 *ph2c_par, u8 h2c_par_len)
{
PADAPTER Adapter = ((struct btc_coexist *)pBtCoexist)->Adapter;
u8 H2C_Parameter[BTC_TMP_BUF_SHORT] = {0};
PCOL_H2C pcol_h2c = (PCOL_H2C)&H2C_Parameter[0];
u16 paraLen = 0;
COL_H2C_STATUS h2c_status = COL_STATUS_C2H_OK, c2h_status = COL_STATUS_C2H_OK;
COL_H2C_STATUS ret_status = COL_STATUS_C2H_OK;
u16 i, col_h2c_len = 0;
pcol_h2c->opcode = opcode;
pcol_h2c->opcode_ver = opcode_ver;
pcol_h2c->req_num = gl_coex_offload.h2c_req_num;
gl_coex_offload.h2c_req_num++;
gl_coex_offload.h2c_req_num %= 16;
_rtw_memmove(&pcol_h2c->buf[0], ph2c_par, h2c_par_len);
col_h2c_len = h2c_par_len + 2; /* 2=sizeof(OPCode, OPCode_version and Request number) */
BT_PrintData(Adapter, "[COL], H2C cmd: ", col_h2c_len, H2C_Parameter);
gl_coex_offload.cnt_h2c_sent++;
gl_coex_offload.h2c_record[opcode].count++;
gl_coex_offload.h2c_record[opcode].h2c_len = col_h2c_len;
_rtw_memmove((void *)&gl_coex_offload.h2c_record[opcode].h2c_buf[0], (void *)pcol_h2c, col_h2c_len);
h2c_status = halbtcoutsrc_send_h2c(Adapter, pcol_h2c, col_h2c_len);
gl_coex_offload.h2c_record[opcode].c2h_ack_len = 0;
if (COL_STATUS_C2H_OK == h2c_status) {
/* if reach here, it means H2C get the correct c2h response, */
c2h_status = halbtcoutsrc_check_c2h_ack(Adapter, &gl_coex_offload.h2c_record[opcode]);
ret_status = c2h_status;
} else {
/* check h2c status error, return error status code to upper layer. */
ret_status = h2c_status;
}
gl_coex_offload.h2c_record[opcode].status[ret_status]++;
gl_coex_offload.status[ret_status]++;
return ret_status;
}
u8 halbtcoutsrc_GetAntDetValFromBt(void *pBtcContext)
{
/* Always return 0 since we don't implement this yet */
#if 0
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
PADAPTER Adapter = pBtCoexist->Adapter;
u8 AntDetVal = 0x0;
u8 opcodeVer = 1;
BOOLEAN status = false;
status = NDBG_GetAntDetValFromBt(Adapter, opcodeVer, &AntDetVal);
RT_TRACE(COMP_DBG, DBG_LOUD, ("$$$ halbtcoutsrc_GetAntDetValFromBt(): status = %d, feature = %x\n", status, AntDetVal));
return AntDetVal;
#else
return 0;
#endif
}
u8 halbtcoutsrc_GetBleScanTypeFromBt(void *pBtcContext)
{
PBTC_COEXIST pBtCoexist;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
u8 data = 0;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_GET_BT_BLE_SCAN_TYPE;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
data = *(u8 *)GLBtcBtMpRptRsp;
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return data;
}
u32 halbtcoutsrc_GetBleScanParaFromBt(void *pBtcContext, u8 scanType)
{
PBTC_COEXIST pBtCoexist;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
u32 data = 0;
pBtCoexist = (PBTC_COEXIST)pBtcContext;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _TRUE) {
u8 buf[3] = {0};
_irqL irqL;
u8 op_code;
u8 status;
buf[0] = scanType;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_OP_GET_BT_BLE_SCAN_PARA;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 1);
if (status == BT_STATUS_BT_OP_SUCCESS)
data = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
else
ret = SET_BT_MP_OPER_RET(op_code, status);
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
} else
ret = BT_STATUS_NOT_IMPLEMENT;
return data;
}
u8 halbtcoutsrc_GetBtAFHMapFromBt(void *pBtcContext, u8 mapType, u8 *afhMap)
{
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
u8 buf[2] = {0};
_irqL irqL;
u8 op_code;
u32 *AfhMapL = (u32 *)&(afhMap[0]);
u32 *AfhMapM = (u32 *)&(afhMap[4]);
u16 *AfhMapH = (u16 *)&(afhMap[8]);
u8 status;
u32 ret = BT_STATUS_BT_OP_SUCCESS;
if (halbtcoutsrc_IsHwMailboxExist(pBtCoexist) == _FALSE)
return _FALSE;
buf[0] = 0;
buf[1] = mapType;
_enter_critical_mutex(&GLBtcBtMpOperLock, &irqL);
op_code = BT_LO_OP_GET_AFH_MAP_L;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
*AfhMapL = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
else {
ret = SET_BT_MP_OPER_RET(op_code, status);
goto exit;
}
op_code = BT_LO_OP_GET_AFH_MAP_M;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
*AfhMapM = le32_to_cpu(*(u32 *)GLBtcBtMpRptRsp);
else {
ret = SET_BT_MP_OPER_RET(op_code, status);
goto exit;
}
op_code = BT_LO_OP_GET_AFH_MAP_H;
status = _btmpoper_cmd(pBtCoexist, op_code, 0, buf, 0);
if (status == BT_STATUS_BT_OP_SUCCESS)
*AfhMapH = le16_to_cpu(*(u16 *)GLBtcBtMpRptRsp);
else {
ret = SET_BT_MP_OPER_RET(op_code, status);
goto exit;
}
exit:
_exit_critical_mutex(&GLBtcBtMpOperLock, &irqL);
return (ret == BT_STATUS_BT_OP_SUCCESS) ? _TRUE : _FALSE;
}
u8 halbtcoutsrc_SetTimer(void *pBtcContext, u32 type, u32 val)
{
struct btc_coexist *pBtCoexist=(struct btc_coexist *)pBtcContext;
if (type >= BTC_TIMER_MAX)
return _FALSE;
pBtCoexist->coex_sta.cnt_timer[type] = val;
RTW_DBG("[BTC], Set Timer: type = %d, val = %d\n", type, val);
return _TRUE;
}
u32 halbtcoutsrc_SetAtomic (void *btc_ctx, u32 *target, u32 val)
{
*target = val;
return _SUCCESS;
}
void halbtcoutsrc_phydm_modify_AntDiv_HwSw(void *pBtcContext, u8 is_hw)
{
/* empty function since we don't need it */
}
void halbtcoutsrc_phydm_modify_RA_PCR_threshold(void *pBtcContext, u8 RA_offset_direction, u8 RA_threshold_offset)
{
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
/* switch to #if 0 in case the phydm version does not provide the function */
#if 1
phydm_modify_RA_PCR_threshold(pBtCoexist->odm_priv, RA_offset_direction, RA_threshold_offset);
#endif
}
u32 halbtcoutsrc_phydm_query_PHY_counter(void *pBtcContext, u8 info_type)
{
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
/* switch to #if 0 in case the phydm version does not provide the function */
#if 1
return phydm_cmn_info_query((struct dm_struct *)pBtCoexist->odm_priv, (enum phydm_info_query)info_type);
#else
return 0;
#endif
}
void halbtcoutsrc_reduce_wl_tx_power(void *pBtcContext, s8 tx_power)
{
struct btc_coexist *pBtCoexist = (struct btc_coexist *)pBtcContext;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA((PADAPTER)pBtCoexist->Adapter);
/* The reduction of wl tx pwr should be processed inside the set tx pwr lvl function */
if (IS_HARDWARE_TYPE_8822C(pBtCoexist->Adapter))
rtw_hal_set_tx_power_level(pBtCoexist->Adapter, pHalData->current_channel);
}
#if 0
static void BT_CoexOffloadRecordErrC2hAck(PADAPTER Adapter)
{
PADAPTER pDefaultAdapter = GetDefaultAdapter(Adapter);
if (pDefaultAdapter != Adapter)
return;
if (!hal_btcoex_IsBtExist(Adapter))
return;
gl_coex_offload.cnt_c2h_ack++;
gl_coex_offload.status[COL_STATUS_INVALID_C2H_LEN]++;
}
static void BT_CoexOffloadC2hAckCheck(PADAPTER Adapter, u8 *tmpBuf, u8 length)
{
PADAPTER pDefaultAdapter = GetDefaultAdapter(Adapter);
PCOL_C2H_ACK p_c2h_ack = NULL;
u8 req_num = 0xff;
if (pDefaultAdapter != Adapter)
return;
if (!hal_btcoex_IsBtExist(Adapter))
return;
gl_coex_offload.cnt_c2h_ack++;
if (length < COL_C2H_ACK_HDR_LEN) { /* c2h ack length must >= 3 (status, opcode_ver, req_num and ret_len) */
gl_coex_offload.status[COL_STATUS_INVALID_C2H_LEN]++;
} else {
BT_PrintData(Adapter, "[COL], c2h ack:", length, tmpBuf);
p_c2h_ack = (PCOL_C2H_ACK)tmpBuf;
req_num = p_c2h_ack->req_num;
_rtw_memmove(&gl_coex_offload.c2h_ack_buf[req_num][0], tmpBuf, length);
gl_coex_offload.c2h_ack_len[req_num] = length;
complete(&gl_coex_offload.c2h_event[req_num]);
}
}
static void BT_CoexOffloadC2hIndCheck(PADAPTER Adapter, u8 *tmpBuf, u8 length)
{
PADAPTER pDefaultAdapter = GetDefaultAdapter(Adapter);
PCOL_C2H_IND p_c2h_ind = NULL;
u8 ind_type = 0, ind_version = 0, ind_length = 0;
if (pDefaultAdapter != Adapter)
return;
if (!hal_btcoex_IsBtExist(Adapter))
return;
gl_coex_offload.cnt_c2h_ind++;
if (length < COL_C2H_IND_HDR_LEN) { /* c2h indication length must >= 3 (type, version and length) */
gl_coex_offload.c2h_ind_status[COL_STATUS_INVALID_C2H_LEN]++;
} else {
BT_PrintData(Adapter, "[COL], c2h indication:", length, tmpBuf);
p_c2h_ind = (PCOL_C2H_IND)tmpBuf;
ind_type = p_c2h_ind->type;
ind_version = p_c2h_ind->version;
ind_length = p_c2h_ind->length;
_rtw_memmove(&gl_coex_offload.c2h_ind_buf[0], tmpBuf, length);
gl_coex_offload.c2h_ind_len = length;
/* log */
gl_coex_offload.c2h_ind_record[ind_type].count++;
gl_coex_offload.c2h_ind_record[ind_type].status[COL_STATUS_C2H_OK]++;
_rtw_memmove(&gl_coex_offload.c2h_ind_record[ind_type].ind_buf[0], tmpBuf, length);
gl_coex_offload.c2h_ind_record[ind_type].ind_len = length;
gl_coex_offload.c2h_ind_status[COL_STATUS_C2H_OK]++;
/*TODO: need to check c2h indication length*/
/* TODO: Notification */
}
}
void BT_CoexOffloadC2hCheck(PADAPTER Adapter, u8 *Buffer, u8 Length)
{
#if 0 /*(USE_HAL_MAC_API == 1)*/
u8 c2hSubCmdId = 0, c2hAckLen = 0, h2cCmdId = 0, h2cSubCmdId = 0, c2hIndLen = 0;
BT_PrintData(Adapter, "[COL], c2h packet:", Length - 2, Buffer + 2);
c2hSubCmdId = (u8)C2H_HDR_GET_C2H_SUB_CMD_ID(Buffer);
if (c2hSubCmdId == C2H_SUB_CMD_ID_H2C_ACK_HDR ||
c2hSubCmdId == C2H_SUB_CMD_ID_BT_COEX_INFO) {
if (c2hSubCmdId == C2H_SUB_CMD_ID_H2C_ACK_HDR) {
/* coex c2h ack */
h2cCmdId = (u8)H2C_ACK_HDR_GET_H2C_CMD_ID(Buffer);
h2cSubCmdId = (u8)H2C_ACK_HDR_GET_H2C_SUB_CMD_ID(Buffer);
if (h2cCmdId == 0xff && h2cSubCmdId == 0x60) {
c2hAckLen = (u8)C2H_HDR_GET_LEN(Buffer);
if (c2hAckLen >= 8)
BT_CoexOffloadC2hAckCheck(Adapter, &Buffer[12], (u8)(c2hAckLen - 8));
else
BT_CoexOffloadRecordErrC2hAck(Adapter);
}
} else if (c2hSubCmdId == C2H_SUB_CMD_ID_BT_COEX_INFO) {
/* coex c2h indication */
c2hIndLen = (u8)C2H_HDR_GET_LEN(Buffer);
BT_CoexOffloadC2hIndCheck(Adapter, &Buffer[4], (u8)c2hIndLen);
}
}
#endif
}
#endif
/* ************************************
* Extern functions called by other module
* ************************************ */
u8 EXhalbtcoutsrc_BindBtCoexWithAdapter(void *padapter)
{
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA((PADAPTER)padapter);
if (pBtCoexist->bBinded)
return _FALSE;
else
pBtCoexist->bBinded = _TRUE;
pBtCoexist->statistics.cnt_bind++;
pBtCoexist->Adapter = padapter;
pBtCoexist->odm_priv = (void *)&(pHalData->odmpriv);
pBtCoexist->stack_info.profile_notified = _FALSE;
pBtCoexist->bt_info.bt_ctrl_agg_buf_size = _FALSE;
pBtCoexist->bt_info.agg_buf_size = 5;
pBtCoexist->bt_info.increase_scan_dev_num = _FALSE;
pBtCoexist->bt_info.miracast_plus_bt = _FALSE;
/* for btc common architecture, inform chip type to coex. mechanism */
if(IS_HARDWARE_TYPE_8822C(padapter)) {
#ifdef CONFIG_RTL8822C
pBtCoexist->chip_type = BTC_CHIP_RTL8822C;
pBtCoexist->chip_para = &btc_chip_para_8822c;
#endif
}
#ifdef CONFIG_RTL8192F
else if (IS_HARDWARE_TYPE_8192F(padapter)) {
pBtCoexist->chip_type = BTC_CHIP_RTL8725A;
pBtCoexist->chip_para = &btc_chip_para_8725a;
}
#endif
else {
pBtCoexist->chip_type = BTC_CHIP_UNDEF;
pBtCoexist->chip_para = NULL;
}
return _TRUE;
}
void EXhalbtcoutsrc_AntInfoSetting(void *padapter)
{
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
u8 antNum = 1, singleAntPath = 0;
antNum = rtw_btcoex_get_pg_ant_num((PADAPTER)padapter);
EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_PG, antNum);
if (antNum == 1) {
singleAntPath = rtw_btcoex_get_pg_single_ant_path((PADAPTER)padapter);
EXhalbtcoutsrc_SetSingleAntPath(singleAntPath);
}
pBtCoexist->board_info.customerID = RT_CID_DEFAULT;
pBtCoexist->board_info.customer_id = RT_CID_DEFAULT;
/* set default antenna position to main port */
pBtCoexist->board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
pBtCoexist->board_info.btdm_ant_det_finish = _FALSE;
pBtCoexist->board_info.btdm_ant_num_by_ant_det = 1;
pBtCoexist->board_info.tfbga_package = rtw_btcoex_is_tfbga_package_type((PADAPTER)padapter);
pBtCoexist->board_info.rfe_type = rtw_btcoex_get_pg_rfe_type((PADAPTER)padapter);
pBtCoexist->board_info.ant_div_cfg = rtw_btcoex_get_ant_div_cfg((PADAPTER)padapter);
pBtCoexist->board_info.ant_distance = 10;
}
u8 EXhalbtcoutsrc_InitlizeVariables(void *padapter)
{
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
/* pBtCoexist->statistics.cntBind++; */
halbtcoutsrc_DbgInit();
halbtcoutsrc_coex_offload_init();
#ifdef CONFIG_PCI_HCI
pBtCoexist->chip_interface = BTC_INTF_PCI;
#elif defined(CONFIG_USB_HCI)
pBtCoexist->chip_interface = BTC_INTF_USB;
#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pBtCoexist->chip_interface = BTC_INTF_SDIO;
#else
pBtCoexist->chip_interface = BTC_INTF_UNKNOWN;
#endif
EXhalbtcoutsrc_BindBtCoexWithAdapter(padapter);
pBtCoexist->btc_read_1byte = halbtcoutsrc_Read1Byte;
pBtCoexist->btc_write_1byte = halbtcoutsrc_Write1Byte;
pBtCoexist->btc_write_1byte_bitmask = halbtcoutsrc_BitMaskWrite1Byte;
pBtCoexist->btc_read_2byte = halbtcoutsrc_Read2Byte;
pBtCoexist->btc_write_2byte = halbtcoutsrc_Write2Byte;
pBtCoexist->btc_read_4byte = halbtcoutsrc_Read4Byte;
pBtCoexist->btc_write_4byte = halbtcoutsrc_Write4Byte;
pBtCoexist->btc_write_local_reg_1byte = halbtcoutsrc_WriteLocalReg1Byte;
pBtCoexist->btc_read_linderct = halbtcoutsrc_ReadLIndirectReg;
pBtCoexist->btc_write_linderct = halbtcoutsrc_WriteLIndirectReg;
pBtCoexist->btc_read_scbd = halbtcoutsrc_Read_scbd;
pBtCoexist->btc_write_scbd = halbtcoutsrc_Write_scbd;
pBtCoexist->btc_set_bb_reg = halbtcoutsrc_SetBbReg;
pBtCoexist->btc_get_bb_reg = halbtcoutsrc_GetBbReg;
pBtCoexist->btc_set_rf_reg = halbtcoutsrc_SetRfReg;
pBtCoexist->btc_get_rf_reg = halbtcoutsrc_GetRfReg;
pBtCoexist->btc_fill_h2c = halbtcoutsrc_FillH2cCmd;
pBtCoexist->btc_disp_dbg_msg = halbtcoutsrc_DisplayDbgMsg;
pBtCoexist->btc_get = halbtcoutsrc_Get;
pBtCoexist->btc_set = halbtcoutsrc_Set;
pBtCoexist->btc_get_bt_reg = halbtcoutsrc_GetBtReg;
pBtCoexist->btc_set_bt_reg = halbtcoutsrc_SetBtReg;
pBtCoexist->btc_set_bt_ant_detection = halbtcoutsrc_SetBtAntDetection;
pBtCoexist->btc_set_bt_trx_mask = halbtcoutsrc_SetBtTRXMASK;
pBtCoexist->btc_coex_h2c_process = halbtcoutsrc_CoexH2cProcess;
pBtCoexist->btc_get_bt_coex_supported_feature = halbtcoutsrc_GetBtCoexSupportedFeature;
pBtCoexist->btc_get_bt_coex_supported_version= halbtcoutsrc_GetBtCoexSupportedVersion;
pBtCoexist->btc_get_ant_det_val_from_bt = halbtcoutsrc_GetAntDetValFromBt;
pBtCoexist->btc_get_ble_scan_type_from_bt = halbtcoutsrc_GetBleScanTypeFromBt;
pBtCoexist->btc_get_ble_scan_para_from_bt = halbtcoutsrc_GetBleScanParaFromBt;
pBtCoexist->btc_get_bt_afh_map_from_bt = halbtcoutsrc_GetBtAFHMapFromBt;
pBtCoexist->btc_get_bt_phydm_version = halbtcoutsrc_GetPhydmVersion;
pBtCoexist->btc_set_timer = halbtcoutsrc_SetTimer;
pBtCoexist->btc_set_atomic= halbtcoutsrc_SetAtomic;
pBtCoexist->btc_phydm_modify_RA_PCR_threshold = halbtcoutsrc_phydm_modify_RA_PCR_threshold;
pBtCoexist->btc_phydm_query_PHY_counter = halbtcoutsrc_phydm_query_PHY_counter;
pBtCoexist->btc_reduce_wl_tx_power = halbtcoutsrc_reduce_wl_tx_power;
pBtCoexist->btc_phydm_modify_antdiv_hwsw = halbtcoutsrc_phydm_modify_AntDiv_HwSw;
pBtCoexist->cli_buf = &GLBtcDbgBuf[0];
GLBtcWiFiInScanState = _FALSE;
GLBtcWiFiInIQKState = _FALSE;
GLBtcWiFiInIPS = _FALSE;
GLBtcWiFiInLPS = _FALSE;
GLBtcBtCoexAliveRegistered = _FALSE;
/* BT Control H2C/C2H*/
GLBtcBtMpOperSeq = 0;
_rtw_mutex_init(&GLBtcBtMpOperLock);
rtw_init_timer(&GLBtcBtMpOperTimer, padapter, _btmpoper_timer_hdl, pBtCoexist);
_rtw_init_sema(&GLBtcBtMpRptSema, 0);
GLBtcBtMpRptSeq = 0;
GLBtcBtMpRptStatus = 0;
_rtw_memset(GLBtcBtMpRptRsp, 0, C2H_MAX_SIZE);
GLBtcBtMpRptRspSize = 0;
GLBtcBtMpRptWait = _FALSE;
GLBtcBtMpRptWiFiOK = _FALSE;
GLBtcBtMpRptBTOK = _FALSE;
return _TRUE;
}
void EXhalbtcoutsrc_PowerOnSetting(PBTC_COEXIST pBtCoexist)
{
HAL_DATA_TYPE *pHalData = NULL;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pHalData = GET_HAL_DATA((PADAPTER)pBtCoexist->Adapter);
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_power_on_setting(pBtCoexist);
#else
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8723B
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_power_on_setting(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_power_on_setting(pBtCoexist);
#endif
}
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_power_on_setting(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_power_on_setting(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_power_on_setting(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821A
else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_power_on_setting(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_power_on_setting(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8822B
else if ((IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_power_on_setting(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_power_on_setting(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821C
else if ((IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) && (pHalData->EEPROMBluetoothCoexist == _TRUE)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_power_on_setting(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_power_on_setting(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8814A
if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_power_on_setting(pBtCoexist);
/* else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8814a1ant_power_on_setting(pBtCoexist); */
}
#endif
#endif
}
void EXhalbtcoutsrc_PreLoadFirmware(PBTC_COEXIST pBtCoexist)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_pre_load_firmware++;
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8723B
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_pre_load_firmware(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_pre_load_firmware(pBtCoexist);
#endif
}
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_pre_load_firmware(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_pre_load_firmware(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_pre_load_firmware(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_pre_load_firmware(pBtCoexist);
}
#endif
}
void EXhalbtcoutsrc_init_hw_config(PBTC_COEXIST pBtCoexist, u8 bWifiOnly)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_init_hw_config++;
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_init_hw_config(pBtCoexist, bWifiOnly);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_init_hw_config(pBtCoexist, bWifiOnly);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_init_hw_config(pBtCoexist, bWifiOnly);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_init_hw_config(pBtCoexist, bWifiOnly);
}
#endif
#endif
}
void EXhalbtcoutsrc_init_coex_dm(PBTC_COEXIST pBtCoexist)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_init_coex_dm++;
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_init_coex_dm(pBtCoexist);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_init_coex_dm(pBtCoexist);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_init_coex_dm(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_init_coex_dm(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_init_coex_dm(pBtCoexist);
}
#endif
#endif
pBtCoexist->initilized = _TRUE;
}
void EXhalbtcoutsrc_ips_notify(PBTC_COEXIST pBtCoexist, u8 type)
{
u8 ipsType;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_ips_notify++;
if (pBtCoexist->manual_control)
return;
if (IPS_NONE == type) {
ipsType = BTC_IPS_LEAVE;
GLBtcWiFiInIPS = _FALSE;
} else {
ipsType = BTC_IPS_ENTER;
GLBtcWiFiInIPS = _TRUE;
}
/* All notify is called in cmd thread, don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_ips_notify(pBtCoexist, ipsType);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_ips_notify(pBtCoexist, ipsType);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_ips_notify(pBtCoexist, ipsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_ips_notify(pBtCoexist, ipsType);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_lps_notify(PBTC_COEXIST pBtCoexist, u8 type)
{
u8 lpsType;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_lps_notify++;
if (pBtCoexist->manual_control)
return;
if (PS_MODE_ACTIVE == type) {
lpsType = BTC_LPS_DISABLE;
GLBtcWiFiInLPS = _FALSE;
} else {
lpsType = BTC_LPS_ENABLE;
GLBtcWiFiInLPS = _TRUE;
}
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_lps_notify(pBtCoexist, lpsType);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_lps_notify(pBtCoexist, lpsType);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_lps_notify(pBtCoexist, lpsType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_lps_notify(pBtCoexist, lpsType);
}
#endif
#endif
}
void EXhalbtcoutsrc_scan_notify(PBTC_COEXIST pBtCoexist, u8 type)
{
u8 scanType;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_scan_notify++;
if (pBtCoexist->manual_control)
return;
if (type) {
scanType = BTC_SCAN_START;
GLBtcWiFiInScanState = _TRUE;
} else {
scanType = BTC_SCAN_FINISH;
GLBtcWiFiInScanState = _FALSE;
}
/* All notify is called in cmd thread, don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_scan_notify(pBtCoexist, scanType);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_scan_notify(pBtCoexist, scanType);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_scan_notify(pBtCoexist, scanType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_scan_notify(pBtCoexist, scanType);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_scan_notify(pBtCoexist, scanType);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_SetAntennaPathNotify(PBTC_COEXIST pBtCoexist, u8 type)
{
#if 0
u8 switchType;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
if (pBtCoexist->manual_control)
return;
halbtcoutsrc_LeaveLowPower(pBtCoexist);
switchType = type;
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_set_antenna_notify(pBtCoexist, type);
}
if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_set_antenna_notify(pBtCoexist, type);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_set_antenna_notify(pBtCoexist, type);
}
halbtcoutsrc_NormalLowPower(pBtCoexist);
#endif
}
void EXhalbtcoutsrc_connect_notify(PBTC_COEXIST pBtCoexist, u8 assoType)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_connect_notify++;
if (pBtCoexist->manual_control)
return;
/* All notify is called in cmd thread, don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_connect_notify(pBtCoexist, assoType);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_connect_notify(pBtCoexist, assoType);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_connect_notify(pBtCoexist, assoType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_connect_notify(pBtCoexist, assoType);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_connect_notify(pBtCoexist, assoType);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_media_status_notify(PBTC_COEXIST pBtCoexist, RT_MEDIA_STATUS mediaStatus)
{
u8 mStatus = BTC_MEDIA_MAX;
PADAPTER adapter = NULL;
HAL_DATA_TYPE *hal = NULL;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
if (pBtCoexist->manual_control)
return;
pBtCoexist->statistics.cnt_media_status_notify++;
adapter = (PADAPTER)pBtCoexist->Adapter;
hal = GET_HAL_DATA(adapter);
if (RT_MEDIA_CONNECT == mediaStatus) {
if (hal->current_band_type == BAND_ON_2_4G)
mStatus = BTC_MEDIA_CONNECT;
else if (hal->current_band_type == BAND_ON_5G)
mStatus = BTC_MEDIA_CONNECT_5G;
else {
mStatus = BTC_MEDIA_CONNECT;
RTW_ERR("%s unknow band type\n", __func__);
}
} else
mStatus = BTC_MEDIA_DISCONNECT;
/* All notify is called in cmd thread, don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_media_status_notify(pBtCoexist, mStatus);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
/* compatible for 8821A */
if (mStatus == BTC_MEDIA_CONNECT_5G)
mStatus = BTC_MEDIA_CONNECT;
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_media_status_notify(pBtCoexist, mStatus);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
/* compatible for 8812A */
if (mStatus == BTC_MEDIA_CONNECT_5G)
mStatus = BTC_MEDIA_CONNECT;
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_media_status_notify(pBtCoexist, mStatus);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_media_status_notify(pBtCoexist, mStatus);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_specific_packet_notify(PBTC_COEXIST pBtCoexist, u8 pktType)
{
u8 packetType;
PADAPTER adapter = NULL;
HAL_DATA_TYPE *hal = NULL;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
if (pBtCoexist->manual_control)
return;
pBtCoexist->statistics.cnt_specific_packet_notify++;
adapter = (PADAPTER)pBtCoexist->Adapter;
hal = GET_HAL_DATA(adapter);
if (PACKET_DHCP == pktType)
packetType = BTC_PACKET_DHCP;
else if (PACKET_EAPOL == pktType)
packetType = BTC_PACKET_EAPOL;
else if (PACKET_ARP == pktType)
packetType = BTC_PACKET_ARP;
else {
packetType = BTC_PACKET_UNKNOWN;
return;
}
if (hal->current_band_type == BAND_ON_5G)
packetType |= BTC_5G_BAND;
/* All notify is called in cmd thread, don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_specific_packet_notify(pBtCoexist, packetType);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
/* compatible for 8821A */
if (hal->current_band_type == BAND_ON_5G)
packetType &= ~BTC_5G_BAND;
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_specific_packet_notify(pBtCoexist, packetType);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
/* compatible for 8812A */
if (hal->current_band_type == BAND_ON_5G)
packetType &= ~BTC_5G_BAND;
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_specific_packet_notify(pBtCoexist, packetType);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_specific_packet_notify(pBtCoexist, packetType);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_bt_info_notify(PBTC_COEXIST pBtCoexist, u8 *tmpBuf, u8 length)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_bt_info_notify++;
/* All notify is called in cmd thread, don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_bt_info_notify(pBtCoexist, tmpBuf, length);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_bt_info_notify(pBtCoexist, tmpBuf, length);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_WlFwDbgInfoNotify(PBTC_COEXIST pBtCoexist, u8* tmpBuf, u8 length)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
#else
if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8703B
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
#endif
}
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_wl_fwdbginfo_notify(pBtCoexist, tmpBuf, length);
}
#endif
#endif
}
void EXhalbtcoutsrc_rx_rate_change_notify(PBTC_COEXIST pBtCoexist, u8 is_data_frame, u8 btc_rate_id)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_rate_id_notify++;
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
#else
if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8703B
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
#endif
}
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_rx_rate_change_notify(pBtCoexist, is_data_frame, btc_rate_id);
}
#endif
#endif
}
void
EXhalbtcoutsrc_RfStatusNotify(
PBTC_COEXIST pBtCoexist,
u8 type
)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_rf_status_notify++;
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_rf_status_notify(pBtCoexist, type);
#else
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8723B
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_rf_status_notify(pBtCoexist, type);
#endif
}
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_rf_status_notify(pBtCoexist, type);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_rf_status_notify(pBtCoexist, type);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_rf_status_notify(pBtCoexist, type);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_rf_status_notify(pBtCoexist, type);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_rf_status_notify(pBtCoexist, type);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_rf_status_notify(pBtCoexist, type);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_rf_status_notify(pBtCoexist, type);
}
#endif
#endif
}
void EXhalbtcoutsrc_StackOperationNotify(PBTC_COEXIST pBtCoexist, u8 type)
{
#if 0
u8 stackOpType;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cntStackOperationNotify++;
if (pBtCoexist->manual_control)
return;
if ((HCI_BT_OP_INQUIRY_START == type) ||
(HCI_BT_OP_PAGING_START == type) ||
(HCI_BT_OP_PAIRING_START == type))
stackOpType = BTC_STACK_OP_INQ_PAGE_PAIR_START;
else if ((HCI_BT_OP_INQUIRY_FINISH == type) ||
(HCI_BT_OP_PAGING_SUCCESS == type) ||
(HCI_BT_OP_PAGING_UNSUCCESS == type) ||
(HCI_BT_OP_PAIRING_FINISH == type))
stackOpType = BTC_STACK_OP_INQ_PAGE_PAIR_FINISH;
else
stackOpType = BTC_STACK_OP_NONE;
#endif
}
void EXhalbtcoutsrc_halt_notify(PBTC_COEXIST pBtCoexist)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_halt_notify++;
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_halt_notify(pBtCoexist);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_halt_notify(pBtCoexist);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_halt_notify(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_halt_notify(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_halt_notify(pBtCoexist);
}
#endif
#endif
}
void EXhalbtcoutsrc_SwitchBtTRxMask(PBTC_COEXIST pBtCoexist)
{
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2) {
halbtcoutsrc_SetBtReg(pBtCoexist, 0, 0x3c, 0x01); /* BT goto standby while GNT_BT 1-->0 */
} else if (pBtCoexist->board_info.btdm_ant_num == 1) {
halbtcoutsrc_SetBtReg(pBtCoexist, 0, 0x3c, 0x15); /* BT goto standby while GNT_BT 1-->0 */
}
}
}
void EXhalbtcoutsrc_pnp_notify(PBTC_COEXIST pBtCoexist, u8 pnpState)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_pnp_notify++;
/* */
/* currently only 1ant we have to do the notification, */
/* once pnp is notified to sleep state, we have to leave LPS that we can sleep normally. */
/* */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_pnp_notify(pBtCoexist, pnpState);
#else
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8723B
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_pnp_notify(pBtCoexist, pnpState);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_pnp_notify(pBtCoexist, pnpState);
#endif
}
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_pnp_notify(pBtCoexist, pnpState);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8821A
else if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_pnp_notify(pBtCoexist, pnpState);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_pnp_notify(pBtCoexist, pnpState);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_pnp_notify(pBtCoexist, pnpState);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_pnp_notify(pBtCoexist, pnpState);
}
#endif
#endif
}
void EXhalbtcoutsrc_CoexDmSwitch(PBTC_COEXIST pBtCoexist)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_coex_dm_switch++;
halbtcoutsrc_LeaveLowPower(pBtCoexist);
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8723B
if (pBtCoexist->board_info.btdm_ant_num == 1) {
pBtCoexist->stop_coex_dm = TRUE;
ex_halbtc8723b1ant_coex_dm_reset(pBtCoexist);
EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_DETECTED, 2);
ex_halbtc8723b2ant_init_hw_config(pBtCoexist, FALSE);
ex_halbtc8723b2ant_init_coex_dm(pBtCoexist);
pBtCoexist->stop_coex_dm = FALSE;
}
#endif
}
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1) {
pBtCoexist->stop_coex_dm = TRUE;
ex_halbtc8723d1ant_coex_dm_reset(pBtCoexist);
EXhalbtcoutsrc_SetAntNum(BT_COEX_ANT_TYPE_DETECTED, 2);
ex_halbtc8723d2ant_init_hw_config(pBtCoexist, FALSE);
ex_halbtc8723d2ant_init_coex_dm(pBtCoexist);
pBtCoexist->stop_coex_dm = FALSE;
}
}
#endif
halbtcoutsrc_NormalLowPower(pBtCoexist);
}
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
void EXhalbtcoutsrc_TimerNotify(PBTC_COEXIST pBtCoexist, u32 timer_type)
{
rtw_btc_ex_timerup_notify(pBtCoexist, timer_type);
}
void EXhalbtcoutsrc_WLStatusChangeNotify(PBTC_COEXIST pBtCoexist, u32 change_type)
{
rtw_btc_ex_wl_status_change_notify(pBtCoexist, change_type);
}
u32 EXhalbtcoutsrc_CoexTimerCheck(PBTC_COEXIST pBtCoexist)
{
u32 i, timer_map = 0;
for (i = 0; i < BTC_TIMER_MAX; i++) {
if (pBtCoexist->coex_sta.cnt_timer[i] > 0) {
if (pBtCoexist->coex_sta.cnt_timer[i] == 1) {
timer_map |= BIT(i);
RTW_DBG("[BTC], %s(): timer_map = 0x%x\n", __func__, timer_map);
}
pBtCoexist->coex_sta.cnt_timer[i]--;
}
}
return timer_map;
}
u32 EXhalbtcoutsrc_WLStatusCheck(PBTC_COEXIST pBtCoexist)
{
struct btc_wifi_link_info link_info;
const struct btc_chip_para *chip_para = pBtCoexist->chip_para;
u32 change_map = 0;
static bool wl_busy_pre;
bool wl_busy = _FALSE;
s32 wl_rssi;
u32 traffic_dir;
u8 i, tmp;
static u8 rssi_step_pre = 5, wl_noisy_level_pre = 4;
/* WL busy to idle or idle to busy */
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_BUSY, &wl_busy);
if (wl_busy != wl_busy_pre) {
if (wl_busy)
change_map |= BIT(BTC_WLSTATUS_CHANGE_TOBUSY);
else
change_map |= BIT(BTC_WLSTATUS_CHANGE_TOIDLE);
wl_busy_pre = wl_busy;
}
/* WL RSSI */
pBtCoexist->btc_get(pBtCoexist, BTC_GET_S4_WIFI_RSSI, &wl_rssi);
tmp = (u8)(wl_rssi & 0xff);
for (i = 0; i < 4; i++) {
if (tmp >= chip_para->wl_rssi_step[i])
break;
}
if (rssi_step_pre != i) {
rssi_step_pre = i;
change_map |= BIT(BTC_WLSTATUS_CHANGE_RSSI);
}
/* WL Link info */
pBtCoexist->btc_get(pBtCoexist, BTC_GET_BL_WIFI_LINK_INFO, &link_info);
if (link_info.link_mode != pBtCoexist->wifi_link_info.link_mode ||
link_info.sta_center_channel !=
pBtCoexist->wifi_link_info.sta_center_channel ||
link_info.p2p_center_channel !=
pBtCoexist->wifi_link_info.p2p_center_channel ||
link_info.bany_client_join_go !=
pBtCoexist->wifi_link_info.bany_client_join_go) {
change_map |= BIT(BTC_WLSTATUS_CHANGE_LINKINFO);
pBtCoexist->wifi_link_info = link_info;
}
/* WL Traffic Direction */
pBtCoexist->btc_get(pBtCoexist, BTC_GET_U4_WIFI_TRAFFIC_DIR, &traffic_dir);
if (wl_busy && traffic_dir != pBtCoexist->wifi_link_info_ext.traffic_dir) {
change_map |= BIT(BTC_WLSTATUS_CHANGE_DIR);
pBtCoexist->wifi_link_info_ext.traffic_dir = traffic_dir;
}
/* Noisy Detect */
if (pBtCoexist->coex_sta.wl_noisy_level != wl_noisy_level_pre) {
change_map |= BIT(BTC_WLSTATUS_CHANGE_NOISY);
wl_noisy_level_pre = pBtCoexist->coex_sta.wl_noisy_level;
}
RTW_DBG("[BTC], %s(): change_map = 0x%x\n", __func__, change_map);
return change_map;
}
void EXhalbtcoutsrc_status_monitor(PBTC_COEXIST pBtCoexist)
{
u32 timer_up_type = 0, wl_status_change_type = 0;
timer_up_type = EXhalbtcoutsrc_CoexTimerCheck(pBtCoexist);
if (timer_up_type != 0)
EXhalbtcoutsrc_TimerNotify(pBtCoexist, timer_up_type);
wl_status_change_type = EXhalbtcoutsrc_WLStatusCheck(pBtCoexist);
if (wl_status_change_type != 0)
EXhalbtcoutsrc_WLStatusChangeNotify(pBtCoexist, wl_status_change_type);
rtw_btc_ex_periodical(pBtCoexist);
}
#endif
void EXhalbtcoutsrc_periodical(PBTC_COEXIST pBtCoexist)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_periodical++;
/* Periodical should be called in cmd thread, */
/* don't need to leave low power again
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
EXhalbtcoutsrc_status_monitor(pBtCoexist);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1) {
if (!halbtcoutsrc_UnderIps(pBtCoexist))
ex_halbtc8821a1ant_periodical(pBtCoexist);
}
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_periodical(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_periodical(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_periodical(pBtCoexist);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
void EXhalbtcoutsrc_dbg_control(PBTC_COEXIST pBtCoexist, u8 opCode, u8 opLen, u8 *pData)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->statistics.cnt_dbg_ctrl++;
/* This function doesn't be called yet, */
/* default no need to leave low power to avoid deadlock
* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
/* rtw_btc_ex_dbg_control(pBtCoexist, opCode, opLen, pData); */
#else
if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8192E
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
#endif
}
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_dbg_control(pBtCoexist, opCode, opLen, pData);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter))
if(pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_dbg_control(pBtCoexist, opCode, opLen, pData);
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
#if 0
void
EXhalbtcoutsrc_AntennaDetection(
PBTC_COEXIST pBtCoexist,
u32 centFreq,
u32 offset,
u32 span,
u32 seconds
)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
/* Need to refine the following power save operations to enable this function in the future */
#if 0
IPSDisable(pBtCoexist->Adapter, FALSE, 0);
LeisurePSLeave(pBtCoexist->Adapter, LPS_DISABLE_BT_COEX);
#endif
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_AntennaDetection(pBtCoexist, centFreq, offset, span, seconds);
}
/* IPSReturn(pBtCoexist->Adapter, 0xff); */
}
#endif
void EXhalbtcoutsrc_StackUpdateProfileInfo(void)
{
#ifdef CONFIG_BT_COEXIST_SOCKET_TRX
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
PADAPTER padapter = NULL;
PBT_MGNT pBtMgnt = NULL;
u8 i;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
padapter = (PADAPTER)pBtCoexist->Adapter;
pBtMgnt = &padapter->coex_info.BtMgnt;
pBtCoexist->stack_info.profile_notified = _TRUE;
pBtCoexist->stack_info.num_of_link =
pBtMgnt->ExtConfig.NumberOfACL + pBtMgnt->ExtConfig.NumberOfSCO;
/* reset first */
pBtCoexist->stack_info.bt_link_exist = _FALSE;
pBtCoexist->stack_info.sco_exist = _FALSE;
pBtCoexist->stack_info.acl_exist = _FALSE;
pBtCoexist->stack_info.a2dp_exist = _FALSE;
pBtCoexist->stack_info.hid_exist = _FALSE;
pBtCoexist->stack_info.num_of_hid = 0;
pBtCoexist->stack_info.pan_exist = _FALSE;
if (!pBtMgnt->ExtConfig.NumberOfACL)
pBtCoexist->stack_info.min_bt_rssi = 0;
if (pBtCoexist->stack_info.num_of_link) {
pBtCoexist->stack_info.bt_link_exist = _TRUE;
if (pBtMgnt->ExtConfig.NumberOfSCO)
pBtCoexist->stack_info.sco_exist = _TRUE;
if (pBtMgnt->ExtConfig.NumberOfACL)
pBtCoexist->stack_info.acl_exist = _TRUE;
}
for (i = 0; i < pBtMgnt->ExtConfig.NumberOfACL; i++) {
if (BT_PROFILE_A2DP == pBtMgnt->ExtConfig.aclLink[i].BTProfile)
pBtCoexist->stack_info.a2dp_exist = _TRUE;
else if (BT_PROFILE_PAN == pBtMgnt->ExtConfig.aclLink[i].BTProfile)
pBtCoexist->stack_info.pan_exist = _TRUE;
else if (BT_PROFILE_HID == pBtMgnt->ExtConfig.aclLink[i].BTProfile) {
pBtCoexist->stack_info.hid_exist = _TRUE;
pBtCoexist->stack_info.num_of_hid++;
} else
pBtCoexist->stack_info.unknown_acl_exist = _TRUE;
}
#endif /* CONFIG_BT_COEXIST_SOCKET_TRX */
}
void EXhalbtcoutsrc_UpdateMinBtRssi(s8 btRssi)
{
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->stack_info.min_bt_rssi = btRssi;
}
void EXhalbtcoutsrc_SetHciVersion(u16 hciVersion)
{
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->stack_info.hci_version = hciVersion;
}
void EXhalbtcoutsrc_SetBtPatchVersion(u16 btHciVersion, u16 btPatchVersion)
{
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
pBtCoexist->bt_info.bt_real_fw_ver = btPatchVersion;
pBtCoexist->bt_info.bt_hci_ver = btHciVersion;
}
#if 0
void EXhalbtcoutsrc_SetBtExist(u8 bBtExist)
{
GLBtCoexist.boardInfo.bBtExist = bBtExist;
}
#endif
void EXhalbtcoutsrc_SetChipType(u8 chipType)
{
switch (chipType) {
default:
case BT_2WIRE:
case BT_ISSC_3WIRE:
case BT_ACCEL:
case BT_RTL8756:
GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_UNDEF;
break;
case BT_CSR_BC4:
GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_CSR_BC4;
break;
case BT_CSR_BC8:
GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_CSR_BC8;
break;
case BT_RTL8723A:
GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_RTL8723A;
break;
case BT_RTL8821:
GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_RTL8821;
break;
case BT_RTL8723B:
GLBtCoexist.board_info.bt_chip_type = BTC_CHIP_RTL8723B;
break;
}
}
void EXhalbtcoutsrc_SetAntNum(u8 type, u8 antNum)
{
if (BT_COEX_ANT_TYPE_PG == type) {
GLBtCoexist.board_info.pg_ant_num = antNum;
GLBtCoexist.board_info.btdm_ant_num = antNum;
#if 0
/* The antenna position: Main (default) or Aux for pgAntNum=2 && btdmAntNum =1 */
/* The antenna position should be determined by auto-detect mechanism */
/* The following is assumed to main, and those must be modified if y auto-detect mechanism is ready */
if ((GLBtCoexist.board_info.pg_ant_num == 2) && (GLBtCoexist.board_info.btdm_ant_num == 1))
GLBtCoexist.board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
else
GLBtCoexist.board_info.btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT;
#endif
} else if (BT_COEX_ANT_TYPE_ANTDIV == type) {
GLBtCoexist.board_info.btdm_ant_num = antNum;
/* GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT; */
} else if (BT_COEX_ANT_TYPE_DETECTED == type) {
GLBtCoexist.board_info.btdm_ant_num = antNum;
/* GLBtCoexist.boardInfo.btdmAntPos = BTC_ANTENNA_AT_MAIN_PORT; */
}
}
/*
* Currently used by 8723b only, S0 or S1
* */
void EXhalbtcoutsrc_SetSingleAntPath(u8 singleAntPath)
{
GLBtCoexist.board_info.single_ant_path = singleAntPath;
}
void EXhalbtcoutsrc_DisplayBtCoexInfo(PBTC_COEXIST pBtCoexist)
{
HAL_DATA_TYPE *pHalData = NULL;
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
halbtcoutsrc_LeaveLowPower(pBtCoexist);
/* To prevent the racing with IPS enter */
halbtcoutsrc_EnterPwrLock(pBtCoexist);
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
pHalData = GET_HAL_DATA((PADAPTER)pBtCoexist->Adapter);
if (pHalData->EEPROMBluetoothCoexist == _TRUE)
rtw_btc_ex_display_coex_info(pBtCoexist);
#else
if (IS_HARDWARE_TYPE_8821(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8821A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821a2ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821a1ant_display_coex_info(pBtCoexist);
#endif
}
#ifdef CONFIG_RTL8723B
else if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723b2ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8703B
else if (IS_HARDWARE_TYPE_8703B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8703b1ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8723D
else if (IS_HARDWARE_TYPE_8723D(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8723d2ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723d1ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8192E
else if (IS_HARDWARE_TYPE_8192E(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8192e2ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8192e1ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8812A
else if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8812a1ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_display_coex_info(pBtCoexist);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_display_coex_info(pBtCoexist);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_display_coex_info(pBtCoexist);
}
#endif
#endif
halbtcoutsrc_ExitPwrLock(pBtCoexist);
halbtcoutsrc_NormalLowPower(pBtCoexist);
}
void EXhalbtcoutsrc_DisplayAntDetection(PBTC_COEXIST pBtCoexist)
{
if (!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
halbtcoutsrc_LeaveLowPower(pBtCoexist);
if (IS_HARDWARE_TYPE_8723B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8723B
if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8723b1ant_display_ant_detection(pBtCoexist);
#endif
}
halbtcoutsrc_NormalLowPower(pBtCoexist);
}
void ex_halbtcoutsrc_pta_off_on_notify(PBTC_COEXIST pBtCoexist, u8 bBTON)
{
if (IS_HARDWARE_TYPE_8812(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8812A
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8812a2ant_pta_off_on_notify(pBtCoexist, (bBTON == _TRUE) ? BTC_BT_ON : BTC_BT_OFF);
#endif
}
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_pta_off_on_notify(pBtCoexist, (bBTON == _TRUE) ? BTC_BT_ON : BTC_BT_OFF);
}
#endif
}
void EXhalbtcoutsrc_set_rfe_type(u8 type)
{
GLBtCoexist.board_info.rfe_type= type;
}
#ifdef CONFIG_RF4CE_COEXIST
void EXhalbtcoutsrc_set_rf4ce_link_state(u8 state)
{
GLBtCoexist.rf4ce_info.link_state = state;
}
u8 EXhalbtcoutsrc_get_rf4ce_link_state(void)
{
return GLBtCoexist.rf4ce_info.link_state;
}
#endif
void EXhalbtcoutsrc_switchband_notify(struct btc_coexist *pBtCoexist, u8 type)
{
if(!halbtcoutsrc_IsBtCoexistAvailable(pBtCoexist))
return;
if(pBtCoexist->manual_control)
return;
/* Driver should guarantee that the HW status isn't in low power mode */
/* halbtcoutsrc_LeaveLowPower(pBtCoexist); */
#if (CONFIG_BTCOEX_SUPPORT_BTC_CMN == 1)
rtw_btc_ex_switchband_notify(pBtCoexist, type);
#else
if(IS_HARDWARE_TYPE_8822B(pBtCoexist->Adapter)) {
#ifdef CONFIG_RTL8822B
if(pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8822b1ant_switchband_notify(pBtCoexist, type);
else if(pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8822b2ant_switchband_notify(pBtCoexist, type);
#endif
}
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8821c2ant_switchband_notify(pBtCoexist, type);
else if (pBtCoexist->board_info.btdm_ant_num == 1)
ex_halbtc8821c1ant_switchband_notify(pBtCoexist, type);
}
#endif
#ifdef CONFIG_RTL8814A
else if (IS_HARDWARE_TYPE_8814A(pBtCoexist->Adapter)) {
if (pBtCoexist->board_info.btdm_ant_num == 2)
ex_halbtc8814a2ant_switchband_notify(pBtCoexist, type);
}
#endif
#endif
/* halbtcoutsrc_NormalLowPower(pBtCoexist); */
}
u8 EXhalbtcoutsrc_rate_id_to_btc_rate_id(u8 rate_id)
{
u8 btc_rate_id = BTC_UNKNOWN;
switch (rate_id) {
/* CCK rates */
case DESC_RATE1M:
btc_rate_id = BTC_CCK_1;
break;
case DESC_RATE2M:
btc_rate_id = BTC_CCK_2;
break;
case DESC_RATE5_5M:
btc_rate_id = BTC_CCK_5_5;
break;
case DESC_RATE11M:
btc_rate_id = BTC_CCK_11;
break;
/* OFDM rates */
case DESC_RATE6M:
btc_rate_id = BTC_OFDM_6;
break;
case DESC_RATE9M:
btc_rate_id = BTC_OFDM_9;
break;
case DESC_RATE12M:
btc_rate_id = BTC_OFDM_12;
break;
case DESC_RATE18M:
btc_rate_id = BTC_OFDM_18;
break;
case DESC_RATE24M:
btc_rate_id = BTC_OFDM_24;
break;
case DESC_RATE36M:
btc_rate_id = BTC_OFDM_36;
break;
case DESC_RATE48M:
btc_rate_id = BTC_OFDM_48;
break;
case DESC_RATE54M:
btc_rate_id = BTC_OFDM_54;
break;
/* MCS rates */
case DESC_RATEMCS0:
btc_rate_id = BTC_MCS_0;
break;
case DESC_RATEMCS1:
btc_rate_id = BTC_MCS_1;
break;
case DESC_RATEMCS2:
btc_rate_id = BTC_MCS_2;
break;
case DESC_RATEMCS3:
btc_rate_id = BTC_MCS_3;
break;
case DESC_RATEMCS4:
btc_rate_id = BTC_MCS_4;
break;
case DESC_RATEMCS5:
btc_rate_id = BTC_MCS_5;
break;
case DESC_RATEMCS6:
btc_rate_id = BTC_MCS_6;
break;
case DESC_RATEMCS7:
btc_rate_id = BTC_MCS_7;
break;
case DESC_RATEMCS8:
btc_rate_id = BTC_MCS_8;
break;
case DESC_RATEMCS9:
btc_rate_id = BTC_MCS_9;
break;
case DESC_RATEMCS10:
btc_rate_id = BTC_MCS_10;
break;
case DESC_RATEMCS11:
btc_rate_id = BTC_MCS_11;
break;
case DESC_RATEMCS12:
btc_rate_id = BTC_MCS_12;
break;
case DESC_RATEMCS13:
btc_rate_id = BTC_MCS_13;
break;
case DESC_RATEMCS14:
btc_rate_id = BTC_MCS_14;
break;
case DESC_RATEMCS15:
btc_rate_id = BTC_MCS_15;
break;
case DESC_RATEMCS16:
btc_rate_id = BTC_MCS_16;
break;
case DESC_RATEMCS17:
btc_rate_id = BTC_MCS_17;
break;
case DESC_RATEMCS18:
btc_rate_id = BTC_MCS_18;
break;
case DESC_RATEMCS19:
btc_rate_id = BTC_MCS_19;
break;
case DESC_RATEMCS20:
btc_rate_id = BTC_MCS_20;
break;
case DESC_RATEMCS21:
btc_rate_id = BTC_MCS_21;
break;
case DESC_RATEMCS22:
btc_rate_id = BTC_MCS_22;
break;
case DESC_RATEMCS23:
btc_rate_id = BTC_MCS_23;
break;
case DESC_RATEMCS24:
btc_rate_id = BTC_MCS_24;
break;
case DESC_RATEMCS25:
btc_rate_id = BTC_MCS_25;
break;
case DESC_RATEMCS26:
btc_rate_id = BTC_MCS_26;
break;
case DESC_RATEMCS27:
btc_rate_id = BTC_MCS_27;
break;
case DESC_RATEMCS28:
btc_rate_id = BTC_MCS_28;
break;
case DESC_RATEMCS29:
btc_rate_id = BTC_MCS_29;
break;
case DESC_RATEMCS30:
btc_rate_id = BTC_MCS_30;
break;
case DESC_RATEMCS31:
btc_rate_id = BTC_MCS_31;
break;
case DESC_RATEVHTSS1MCS0:
btc_rate_id = BTC_VHT_1SS_MCS_0;
break;
case DESC_RATEVHTSS1MCS1:
btc_rate_id = BTC_VHT_1SS_MCS_1;
break;
case DESC_RATEVHTSS1MCS2:
btc_rate_id = BTC_VHT_1SS_MCS_2;
break;
case DESC_RATEVHTSS1MCS3:
btc_rate_id = BTC_VHT_1SS_MCS_3;
break;
case DESC_RATEVHTSS1MCS4:
btc_rate_id = BTC_VHT_1SS_MCS_4;
break;
case DESC_RATEVHTSS1MCS5:
btc_rate_id = BTC_VHT_1SS_MCS_5;
break;
case DESC_RATEVHTSS1MCS6:
btc_rate_id = BTC_VHT_1SS_MCS_6;
break;
case DESC_RATEVHTSS1MCS7:
btc_rate_id = BTC_VHT_1SS_MCS_7;
break;
case DESC_RATEVHTSS1MCS8:
btc_rate_id = BTC_VHT_1SS_MCS_8;
break;
case DESC_RATEVHTSS1MCS9:
btc_rate_id = BTC_VHT_1SS_MCS_9;
break;
case DESC_RATEVHTSS2MCS0:
btc_rate_id = BTC_VHT_2SS_MCS_0;
break;
case DESC_RATEVHTSS2MCS1:
btc_rate_id = BTC_VHT_2SS_MCS_1;
break;
case DESC_RATEVHTSS2MCS2:
btc_rate_id = BTC_VHT_2SS_MCS_2;
break;
case DESC_RATEVHTSS2MCS3:
btc_rate_id = BTC_VHT_2SS_MCS_3;
break;
case DESC_RATEVHTSS2MCS4:
btc_rate_id = BTC_VHT_2SS_MCS_4;
break;
case DESC_RATEVHTSS2MCS5:
btc_rate_id = BTC_VHT_2SS_MCS_5;
break;
case DESC_RATEVHTSS2MCS6:
btc_rate_id = BTC_VHT_2SS_MCS_6;
break;
case DESC_RATEVHTSS2MCS7:
btc_rate_id = BTC_VHT_2SS_MCS_7;
break;
case DESC_RATEVHTSS2MCS8:
btc_rate_id = BTC_VHT_2SS_MCS_8;
break;
case DESC_RATEVHTSS2MCS9:
btc_rate_id = BTC_VHT_2SS_MCS_9;
break;
case DESC_RATEVHTSS3MCS0:
btc_rate_id = BTC_VHT_3SS_MCS_0;
break;
case DESC_RATEVHTSS3MCS1:
btc_rate_id = BTC_VHT_3SS_MCS_1;
break;
case DESC_RATEVHTSS3MCS2:
btc_rate_id = BTC_VHT_3SS_MCS_2;
break;
case DESC_RATEVHTSS3MCS3:
btc_rate_id = BTC_VHT_3SS_MCS_3;
break;
case DESC_RATEVHTSS3MCS4:
btc_rate_id = BTC_VHT_3SS_MCS_4;
break;
case DESC_RATEVHTSS3MCS5:
btc_rate_id = BTC_VHT_3SS_MCS_5;
break;
case DESC_RATEVHTSS3MCS6:
btc_rate_id = BTC_VHT_3SS_MCS_6;
break;
case DESC_RATEVHTSS3MCS7:
btc_rate_id = BTC_VHT_3SS_MCS_7;
break;
case DESC_RATEVHTSS3MCS8:
btc_rate_id = BTC_VHT_3SS_MCS_8;
break;
case DESC_RATEVHTSS3MCS9:
btc_rate_id = BTC_VHT_3SS_MCS_9;
break;
case DESC_RATEVHTSS4MCS0:
btc_rate_id = BTC_VHT_4SS_MCS_0;
break;
case DESC_RATEVHTSS4MCS1:
btc_rate_id = BTC_VHT_4SS_MCS_1;
break;
case DESC_RATEVHTSS4MCS2:
btc_rate_id = BTC_VHT_4SS_MCS_2;
break;
case DESC_RATEVHTSS4MCS3:
btc_rate_id = BTC_VHT_4SS_MCS_3;
break;
case DESC_RATEVHTSS4MCS4:
btc_rate_id = BTC_VHT_4SS_MCS_4;
break;
case DESC_RATEVHTSS4MCS5:
btc_rate_id = BTC_VHT_4SS_MCS_5;
break;
case DESC_RATEVHTSS4MCS6:
btc_rate_id = BTC_VHT_4SS_MCS_6;
break;
case DESC_RATEVHTSS4MCS7:
btc_rate_id = BTC_VHT_4SS_MCS_7;
break;
case DESC_RATEVHTSS4MCS8:
btc_rate_id = BTC_VHT_4SS_MCS_8;
break;
case DESC_RATEVHTSS4MCS9:
btc_rate_id = BTC_VHT_4SS_MCS_9;
break;
}
return btc_rate_id;
}
/*
* Description:
* Run BT-Coexist mechansim or not
*
*/
void hal_btcoex_SetBTCoexist(PADAPTER padapter, u8 bBtExist)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
pHalData->bt_coexist.bBtExist = bBtExist;
}
/*
* Dewcription:
* Check is co-exist mechanism enabled or not
*
* Return:
* _TRUE Enable BT co-exist mechanism
* _FALSE Disable BT co-exist mechanism
*/
u8 hal_btcoex_IsBtExist(PADAPTER padapter)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
return pHalData->bt_coexist.bBtExist;
}
u8 hal_btcoex_IsBtDisabled(PADAPTER padapter)
{
if (!hal_btcoex_IsBtExist(padapter))
return _TRUE;
if (GLBtCoexist.bt_info.bt_disabled)
return _TRUE;
else
return _FALSE;
}
void hal_btcoex_SetChipType(PADAPTER padapter, u8 chipType)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
pHalData->bt_coexist.btChipType = chipType;
}
void hal_btcoex_SetPgAntNum(PADAPTER padapter, u8 antNum)
{
PHAL_DATA_TYPE pHalData;
pHalData = GET_HAL_DATA(padapter);
pHalData->bt_coexist.btTotalAntNum = antNum;
}
u8 hal_btcoex_Initialize(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 ret;
_rtw_memset(&GLBtCoexist, 0, sizeof(GLBtCoexist));
ret = EXhalbtcoutsrc_InitlizeVariables((void *)padapter);
return ret;
}
void hal_btcoex_PowerOnSetting(PADAPTER padapter)
{
EXhalbtcoutsrc_PowerOnSetting(&GLBtCoexist);
}
void hal_btcoex_AntInfoSetting(PADAPTER padapter)
{
hal_btcoex_SetBTCoexist(padapter, rtw_btcoex_get_bt_coexist(padapter));
hal_btcoex_SetChipType(padapter, rtw_btcoex_get_chip_type(padapter));
hal_btcoex_SetPgAntNum(padapter, rtw_btcoex_get_pg_ant_num(padapter));
EXhalbtcoutsrc_AntInfoSetting(padapter);
}
void hal_btcoex_PowerOffSetting(PADAPTER padapter)
{
/* Clear the WiFi on/off bit in scoreboard reg. if necessary */
if (IS_HARDWARE_TYPE_8703B(padapter) || IS_HARDWARE_TYPE_8723D(padapter)
|| IS_HARDWARE_TYPE_8821C(padapter) || IS_HARDWARE_TYPE_8822B(padapter)
|| IS_HARDWARE_TYPE_8822C(padapter))
rtw_write16(padapter, 0xaa, 0x8000);
}
void hal_btcoex_PreLoadFirmware(PADAPTER padapter)
{
EXhalbtcoutsrc_PreLoadFirmware(&GLBtCoexist);
}
void hal_btcoex_InitHwConfig(PADAPTER padapter, u8 bWifiOnly)
{
if (!hal_btcoex_IsBtExist(padapter))
return;
EXhalbtcoutsrc_init_hw_config(&GLBtCoexist, bWifiOnly);
EXhalbtcoutsrc_init_coex_dm(&GLBtCoexist);
}
void hal_btcoex_IpsNotify(PADAPTER padapter, u8 type)
{
EXhalbtcoutsrc_ips_notify(&GLBtCoexist, type);
}
void hal_btcoex_LpsNotify(PADAPTER padapter, u8 type)
{
EXhalbtcoutsrc_lps_notify(&GLBtCoexist, type);
}
void hal_btcoex_ScanNotify(PADAPTER padapter, u8 type)
{
EXhalbtcoutsrc_scan_notify(&GLBtCoexist, type);
}
void hal_btcoex_ConnectNotify(PADAPTER padapter, u8 action)
{
u8 assoType = 0;
u8 is_5g_band = _FALSE;
is_5g_band = (padapter->mlmeextpriv.cur_channel > 14) ? _TRUE : _FALSE;
if (action == _TRUE) {
if (is_5g_band == _TRUE)
assoType = BTC_ASSOCIATE_5G_START;
else
assoType = BTC_ASSOCIATE_START;
}
else {
if (is_5g_band == _TRUE)
assoType = BTC_ASSOCIATE_5G_FINISH;
else
assoType = BTC_ASSOCIATE_FINISH;
}
EXhalbtcoutsrc_connect_notify(&GLBtCoexist, assoType);
}
void hal_btcoex_MediaStatusNotify(PADAPTER padapter, u8 mediaStatus)
{
EXhalbtcoutsrc_media_status_notify(&GLBtCoexist, mediaStatus);
}
void hal_btcoex_SpecialPacketNotify(PADAPTER padapter, u8 pktType)
{
EXhalbtcoutsrc_specific_packet_notify(&GLBtCoexist, pktType);
}
void hal_btcoex_IQKNotify(PADAPTER padapter, u8 state)
{
GLBtcWiFiInIQKState = state;
}
void hal_btcoex_BtInfoNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
{
if (GLBtcWiFiInIQKState == _TRUE)
return;
EXhalbtcoutsrc_bt_info_notify(&GLBtCoexist, tmpBuf, length);
}
void hal_btcoex_BtMpRptNotify(PADAPTER padapter, u8 length, u8 *tmpBuf)
{
u8 extid, status, len, seq;
if (GLBtcBtMpRptWait == _FALSE)
return;
if ((length < 3) || (!tmpBuf))
return;
extid = tmpBuf[0];
/* not response from BT FW then exit*/
switch (extid) {
case C2H_WIFI_FW_ACTIVE_RSP:
GLBtcBtMpRptWiFiOK = _TRUE;
break;
case C2H_TRIG_BY_BT_FW:
GLBtcBtMpRptBTOK = _TRUE;
status = tmpBuf[1] & 0xF;
len = length - 3;
seq = tmpBuf[2] >> 4;
GLBtcBtMpRptSeq = seq;
GLBtcBtMpRptStatus = status;
_rtw_memcpy(GLBtcBtMpRptRsp, tmpBuf + 3, len);
GLBtcBtMpRptRspSize = len;
break;
default:
return;
}
if ((GLBtcBtMpRptWiFiOK == _TRUE) && (GLBtcBtMpRptBTOK == _TRUE)) {
GLBtcBtMpRptWait = _FALSE;
_cancel_timer_ex(&GLBtcBtMpOperTimer);
_rtw_up_sema(&GLBtcBtMpRptSema);
}
}
void hal_btcoex_SuspendNotify(PADAPTER padapter, u8 state)
{
switch (state) {
case BTCOEX_SUSPEND_STATE_SUSPEND:
EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP);
break;
case BTCOEX_SUSPEND_STATE_SUSPEND_KEEP_ANT:
/* should switch to "#if 1" once all ICs' coex. revision are upgraded to support the KEEP_ANT case */
#if 0
EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP_KEEP_ANT);
#else
EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP);
EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_SLEEP_KEEP_ANT);
#endif
break;
case BTCOEX_SUSPEND_STATE_RESUME:
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
/* re-download FW after resume, inform WL FW port number */
rtw_hal_set_wifi_btc_port_id_cmd(GLBtCoexist.Adapter);
#endif
EXhalbtcoutsrc_pnp_notify(&GLBtCoexist, BTC_WIFI_PNP_WAKE_UP);
break;
}
}
void hal_btcoex_HaltNotify(PADAPTER padapter, u8 do_halt)
{
if (do_halt == 1)
EXhalbtcoutsrc_halt_notify(&GLBtCoexist);
GLBtCoexist.bBinded = _FALSE;
GLBtCoexist.Adapter = NULL;
}
void hal_btcoex_SwitchBtTRxMask(PADAPTER padapter)
{
EXhalbtcoutsrc_SwitchBtTRxMask(&GLBtCoexist);
}
void hal_btcoex_Hanlder(PADAPTER padapter)
{
u32 bt_patch_ver;
EXhalbtcoutsrc_periodical(&GLBtCoexist);
if (GLBtCoexist.bt_info.bt_get_fw_ver == 0) {
GLBtCoexist.btc_get(&GLBtCoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver);
GLBtCoexist.bt_info.bt_get_fw_ver = bt_patch_ver;
}
}
s32 hal_btcoex_IsBTCoexRejectAMPDU(PADAPTER padapter)
{
return (s32)GLBtCoexist.bt_info.reject_agg_pkt;
}
s32 hal_btcoex_IsBTCoexCtrlAMPDUSize(PADAPTER padapter)
{
return (s32)GLBtCoexist.bt_info.bt_ctrl_agg_buf_size;
}
u32 hal_btcoex_GetAMPDUSize(PADAPTER padapter)
{
return (u32)GLBtCoexist.bt_info.agg_buf_size;
}
void hal_btcoex_SetManualControl(PADAPTER padapter, u8 bmanual)
{
GLBtCoexist.manual_control = bmanual;
}
u8 hal_btcoex_1Ant(PADAPTER padapter)
{
if (hal_btcoex_IsBtExist(padapter) == _FALSE)
return _FALSE;
if (GLBtCoexist.board_info.btdm_ant_num == 1)
return _TRUE;
return _FALSE;
}
u8 hal_btcoex_IsBtControlLps(PADAPTER padapter)
{
if (GLBtCoexist.bdontenterLPS == _TRUE)
return _TRUE;
if (hal_btcoex_IsBtExist(padapter) == _FALSE)
return _FALSE;
if (GLBtCoexist.bt_info.bt_disabled)
return _FALSE;
if (GLBtCoexist.bt_info.bt_ctrl_lps)
return _TRUE;
return _FALSE;
}
u8 hal_btcoex_IsLpsOn(PADAPTER padapter)
{
if (GLBtCoexist.bdontenterLPS == _TRUE)
return _FALSE;
if (hal_btcoex_IsBtExist(padapter) == _FALSE)
return _FALSE;
if (GLBtCoexist.bt_info.bt_disabled)
return _FALSE;
if (GLBtCoexist.bt_info.bt_lps_on)
return _TRUE;
return _FALSE;
}
u8 hal_btcoex_RpwmVal(PADAPTER padapter)
{
return GLBtCoexist.bt_info.rpwm_val;
}
u8 hal_btcoex_LpsVal(PADAPTER padapter)
{
return GLBtCoexist.bt_info.lps_val;
}
u32 hal_btcoex_GetRaMask(PADAPTER padapter)
{
if (!hal_btcoex_IsBtExist(padapter))
return 0;
if (GLBtCoexist.bt_info.bt_disabled)
return 0;
/* Modify by YiWei , suggest by Cosa and Jenyu
* Remove the limit antenna number , because 2 antenna case (ex: 8192eu)also want to get BT coex report rate mask.
*/
/*if (GLBtCoexist.board_info.btdm_ant_num != 1)
return 0;*/
return GLBtCoexist.bt_info.ra_mask;
}
u8 hal_btcoex_query_reduced_wl_pwr_lvl(PADAPTER padapter)
{
return GLBtCoexist.coex_dm.cur_wl_pwr_lvl;
}
void hal_btcoex_set_reduced_wl_pwr_lvl(PADAPTER padapter, u8 val)
{
GLBtCoexist.coex_dm.cur_wl_pwr_lvl = val;
}
void hal_btcoex_do_reduce_wl_pwr_lvl(PADAPTER padapter)
{
halbtcoutsrc_reduce_wl_tx_power(&GLBtCoexist, 0);
}
void hal_btcoex_RecordPwrMode(PADAPTER padapter, u8 *pCmdBuf, u8 cmdLen)
{
_rtw_memcpy(GLBtCoexist.pwrModeVal, pCmdBuf, cmdLen);
}
void hal_btcoex_DisplayBtCoexInfo(PADAPTER padapter, u8 *pbuf, u32 bufsize)
{
PBTCDBGINFO pinfo;
pinfo = &GLBtcDbgInfo;
DBG_BT_INFO_INIT(pinfo, pbuf, bufsize);
EXhalbtcoutsrc_DisplayBtCoexInfo(&GLBtCoexist);
DBG_BT_INFO_INIT(pinfo, NULL, 0);
}
void hal_btcoex_SetDBG(PADAPTER padapter, u32 *pDbgModule)
{
u32 i;
if (NULL == pDbgModule)
return;
for (i = 0; i < COMP_MAX; i++)
GLBtcDbgType[i] = pDbgModule[i];
}
u32 hal_btcoex_GetDBG(PADAPTER padapter, u8 *pStrBuf, u32 bufSize)
{
s32 count;
u8 *pstr;
u32 leftSize;
if ((NULL == pStrBuf) || (0 == bufSize))
return 0;
count = 0;
pstr = pStrBuf;
leftSize = bufSize;
/* RTW_INFO(FUNC_ADPT_FMT ": bufsize=%d\n", FUNC_ADPT_ARG(padapter), bufSize); */
count = rtw_sprintf(pstr, leftSize, "#define DBG\t%d\n", DBG);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "BTCOEX Debug Setting:\n");
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize,
"COMP_COEX: 0x%08X\n\n",
GLBtcDbgType[COMP_COEX]);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
#if 0
count = rtw_sprintf(pstr, leftSize, "INTERFACE Debug Setting Definition:\n");
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[0]=%d for INTF_INIT\n",
GLBtcDbgType[BTC_MSG_INTERFACE] & INTF_INIT ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[2]=%d for INTF_NOTIFY\n\n",
GLBtcDbgType[BTC_MSG_INTERFACE] & INTF_NOTIFY ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "ALGORITHM Debug Setting Definition:\n");
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[0]=%d for BT_RSSI_STATE\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_BT_RSSI_STATE ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[1]=%d for WIFI_RSSI_STATE\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_WIFI_RSSI_STATE ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[2]=%d for BT_MONITOR\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_BT_MONITOR ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[3]=%d for TRACE\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[4]=%d for TRACE_FW\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_FW ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[5]=%d for TRACE_FW_DETAIL\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_FW_DETAIL ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[6]=%d for TRACE_FW_EXEC\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_FW_EXEC ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[7]=%d for TRACE_SW\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_SW ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[8]=%d for TRACE_SW_DETAIL\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_SW_DETAIL ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
count = rtw_sprintf(pstr, leftSize, "\tbit[9]=%d for TRACE_SW_EXEC\n",
GLBtcDbgType[BTC_MSG_ALGORITHM] & ALGO_TRACE_SW_EXEC ? 1 : 0);
if ((count < 0) || (count >= leftSize))
goto exit;
pstr += count;
leftSize -= count;
#endif
exit:
count = pstr - pStrBuf;
/* RTW_INFO(FUNC_ADPT_FMT ": usedsize=%d\n", FUNC_ADPT_ARG(padapter), count); */
return count;
}
u8 hal_btcoex_IncreaseScanDeviceNum(PADAPTER padapter)
{
if (!hal_btcoex_IsBtExist(padapter))
return _FALSE;
if (GLBtCoexist.bt_info.increase_scan_dev_num)
return _TRUE;
return _FALSE;
}
u8 hal_btcoex_IsBtLinkExist(PADAPTER padapter)
{
if (GLBtCoexist.bt_link_info.bt_link_exist)
return _TRUE;
return _FALSE;
}
void hal_btcoex_SetBtPatchVersion(PADAPTER padapter, u16 btHciVer, u16 btPatchVer)
{
EXhalbtcoutsrc_SetBtPatchVersion(btHciVer, btPatchVer);
}
void hal_btcoex_SetHciVersion(PADAPTER padapter, u16 hciVersion)
{
EXhalbtcoutsrc_SetHciVersion(hciVersion);
}
void hal_btcoex_StackUpdateProfileInfo(void)
{
EXhalbtcoutsrc_StackUpdateProfileInfo();
}
void hal_btcoex_pta_off_on_notify(PADAPTER padapter, u8 bBTON)
{
ex_halbtcoutsrc_pta_off_on_notify(&GLBtCoexist, bBTON);
}
/*
* Description:
* Setting BT coex antenna isolation type .
* coex mechanisn/ spital stream/ best throughput
* anttype = 0 , PSTDMA / 2SS / 0.5T , bad isolation , WiFi/BT ANT Distance<15cm , (<20dB) for 2,3 antenna
* anttype = 1 , PSTDMA / 1SS / 0.5T , normal isolaiton , 50cm>WiFi/BT ANT Distance>15cm , (>20dB) for 2 antenna
* anttype = 2 , TDMA / 2SS / T , normal isolaiton , 50cm>WiFi/BT ANT Distance>15cm , (>20dB) for 3 antenna
* anttype = 3 , no TDMA / 1SS / 0.5T , good isolation , WiFi/BT ANT Distance >50cm , (>40dB) for 2 antenna
* anttype = 4 , no TDMA / 2SS / T , good isolation , WiFi/BT ANT Distance >50cm , (>40dB) for 3 antenna
* wifi only throughput ~ T
* wifi/BT share one antenna with SPDT
*/
void hal_btcoex_SetAntIsolationType(PADAPTER padapter, u8 anttype)
{
PHAL_DATA_TYPE pHalData;
PBTC_COEXIST pBtCoexist = &GLBtCoexist;
/*RTW_INFO("####%s , anttype = %d , %d\n" , __func__ , anttype , __LINE__); */
pHalData = GET_HAL_DATA(padapter);
pHalData->bt_coexist.btAntisolation = anttype;
switch (pHalData->bt_coexist.btAntisolation) {
case 0:
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_0;
break;
case 1:
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_1;
break;
case 2:
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_2;
break;
case 3:
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_3;
break;
case 4:
pBtCoexist->board_info.ant_type = (u8)BTC_ANT_TYPE_4;
break;
}
}
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
int
hal_btcoex_ParseAntIsolationConfigFile(
PADAPTER Adapter,
char *buffer
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
u32 i = 0 , j = 0;
char *szLine , *ptmp;
int rtStatus = _SUCCESS;
char param_value_string[10];
u8 param_value;
u8 anttype = 4;
u8 ant_num = 3 , ant_distance = 50 , rfe_type = 1;
typedef struct ant_isolation {
char *param_name; /* antenna isolation config parameter name */
u8 *value; /* antenna isolation config parameter value */
} ANT_ISOLATION;
ANT_ISOLATION ant_isolation_param[] = {
{"ANT_NUMBER" , &ant_num},
{"ANT_DISTANCE" , &ant_distance},
{"RFE_TYPE" , &rfe_type},
{NULL , 0}
};
/* RTW_INFO("===>Hal_ParseAntIsolationConfigFile()\n" ); */
ptmp = buffer;
for (szLine = GetLineFromBuffer(ptmp) ; szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
/* skip comment */
if (IsCommentString(szLine))
continue;
/* RTW_INFO("%s : szLine = %s , strlen(szLine) = %d\n" , __func__ , szLine , strlen(szLine));*/
for (j = 0 ; ant_isolation_param[j].param_name != NULL ; j++) {
if (strstr(szLine , ant_isolation_param[j].param_name) != NULL) {
i = 0;
while (i < strlen(szLine)) {
if (szLine[i] != '"')
++i;
else {
/* skip only has one " */
if (strpbrk(szLine , "\"") == strrchr(szLine , '"')) {
RTW_INFO("Fail to parse parameters , format error!\n");
break;
}
_rtw_memset((void *)param_value_string , 0 , 10);
if (!ParseQualifiedString(szLine , &i , param_value_string , '"' , '"')) {
RTW_INFO("Fail to parse parameters\n");
return _FAIL;
} else if (!GetU1ByteIntegerFromStringInDecimal(param_value_string , ant_isolation_param[j].value))
RTW_INFO("Fail to GetU1ByteIntegerFromStringInDecimal\n");
break;
}
}
}
}
}
/* YiWei 20140716 , for BT coex antenna isolation control */
/* rfe_type = 0 was SPDT , rfe_type = 1 was coupler */
if (ant_num == 3 && ant_distance >= 50)
anttype = 3;
else if (ant_num == 2 && ant_distance >= 50 && rfe_type == 1)
anttype = 2;
else if (ant_num == 3 && ant_distance >= 15 && ant_distance < 50)
anttype = 2;
else if (ant_num == 2 && ant_distance >= 15 && ant_distance < 50 && rfe_type == 1)
anttype = 2;
else if ((ant_num == 2 && ant_distance < 15 && rfe_type == 1) || (ant_num == 3 && ant_distance < 15))
anttype = 1;
else if (ant_num == 2 && rfe_type == 0)
anttype = 0;
else
anttype = 0;
hal_btcoex_SetAntIsolationType(Adapter, anttype);
RTW_INFO("%s : ant_num = %d\n" , __func__ , ant_num);
RTW_INFO("%s : ant_distance = %d\n" , __func__ , ant_distance);
RTW_INFO("%s : rfe_type = %d\n" , __func__ , rfe_type);
/* RTW_INFO("<===Hal_ParseAntIsolationConfigFile()\n"); */
return rtStatus;
}
int
hal_btcoex_AntIsolationConfig_ParaFile(
PADAPTER Adapter,
char *pFileName
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
int rlen = 0 , rtStatus = _FAIL;
_rtw_memset(pHalData->para_file_buf , 0 , MAX_PARA_FILE_BUF_LEN);
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_is_file_readable(rtw_phy_para_file_path) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0)
rtStatus = _SUCCESS;
}
if (rtStatus == _SUCCESS) {
/*RTW_INFO("%s(): read %s ok\n", __func__ , pFileName);*/
rtStatus = hal_btcoex_ParseAntIsolationConfigFile(Adapter , pHalData->para_file_buf);
} else
RTW_INFO("%s(): No File %s, Load from *** Array!\n" , __func__ , pFileName);
return rtStatus;
}
#endif /* CONFIG_LOAD_PHY_PARA_FROM_FILE */
u16 hal_btcoex_btreg_read(PADAPTER padapter, u8 type, u16 addr, u32 *data)
{
u16 ret = 0;
halbtcoutsrc_LeaveLowPower(&GLBtCoexist);
ret = halbtcoutsrc_GetBtReg_with_status(&GLBtCoexist, type, addr, data);
halbtcoutsrc_NormalLowPower(&GLBtCoexist);
return ret;
}
u16 hal_btcoex_btreg_write(PADAPTER padapter, u8 type, u16 addr, u16 val)
{
u16 ret = 0;
halbtcoutsrc_LeaveLowPower(&GLBtCoexist);
ret = halbtcoutsrc_SetBtReg(&GLBtCoexist, type, addr, val);
halbtcoutsrc_NormalLowPower(&GLBtCoexist);
return ret;
}
void hal_btcoex_set_rfe_type(u8 type)
{
EXhalbtcoutsrc_set_rfe_type(type);
}
#ifdef CONFIG_RF4CE_COEXIST
void hal_btcoex_set_rf4ce_link_state(u8 state)
{
EXhalbtcoutsrc_set_rf4ce_link_state(state);
}
u8 hal_btcoex_get_rf4ce_link_state(void)
{
return EXhalbtcoutsrc_get_rf4ce_link_state();
}
#endif /* CONFIG_RF4CE_COEXIST */
void hal_btcoex_switchband_notify(u8 under_scan, u8 band_type)
{
switch (band_type) {
case BAND_ON_2_4G:
if (under_scan)
EXhalbtcoutsrc_switchband_notify(&GLBtCoexist, BTC_SWITCH_TO_24G);
else
EXhalbtcoutsrc_switchband_notify(&GLBtCoexist, BTC_SWITCH_TO_24G_NOFORSCAN);
break;
case BAND_ON_5G:
EXhalbtcoutsrc_switchband_notify(&GLBtCoexist, BTC_SWITCH_TO_5G);
break;
default:
RTW_INFO("[BTCOEX] unkown switch band type\n");
break;
}
}
void hal_btcoex_WlFwDbgInfoNotify(PADAPTER padapter, u8* tmpBuf, u8 length)
{
EXhalbtcoutsrc_WlFwDbgInfoNotify(&GLBtCoexist, tmpBuf, length);
}
void hal_btcoex_rx_rate_change_notify(PADAPTER padapter, u8 is_data_frame, u8 rate_id)
{
EXhalbtcoutsrc_rx_rate_change_notify(&GLBtCoexist, is_data_frame, EXhalbtcoutsrc_rate_id_to_btc_rate_id(rate_id));
}
u16 hal_btcoex_btset_testode(PADAPTER padapter, u8 type)
{
u16 ret = 0;
halbtcoutsrc_LeaveLowPower(&GLBtCoexist);
ret = halbtcoutsrc_setbttestmode(&GLBtCoexist, type);
halbtcoutsrc_NormalLowPower(&GLBtCoexist);
return ret;
}
#endif /* CONFIG_BT_COEXIST */
================================================
FILE: hal/hal_btcoex_wifionly.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#if (CONFIG_BTCOEX_SUPPORT_WIFI_ONLY_CFG == 1)
#include "btc/mp_precomp.h"
struct wifi_only_cfg GLBtCoexistWifiOnly;
void halwifionly_write1byte(void *pwifionlyContext, u32 RegAddr, u8 Data)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
rtw_write8(Adapter, RegAddr, Data);
}
void halwifionly_write2byte(void *pwifionlyContext, u32 RegAddr, u16 Data)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
rtw_write16(Adapter, RegAddr, Data);
}
void halwifionly_write4byte(void *pwifionlyContext, u32 RegAddr, u32 Data)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
rtw_write32(Adapter, RegAddr, Data);
}
u8 halwifionly_read1byte(void *pwifionlyContext, u32 RegAddr)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
return rtw_read8(Adapter, RegAddr);
}
u16 halwifionly_read2byte(void * pwifionlyContext, u32 RegAddr)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
return rtw_read16(Adapter, RegAddr);
}
u32 halwifionly_read4byte(void *pwifionlyContext, u32 RegAddr)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
return rtw_read32(Adapter, RegAddr);
}
void halwifionly_bitmaskwrite1byte(void *pwifionlyContext, u32 regAddr, u8 bitMask, u8 data)
{
u8 originalValue, bitShift = 0;
u8 i;
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
if (bitMask != 0xff) {
originalValue = rtw_read8(Adapter, regAddr);
for (i = 0; i <= 7; i++) {
if ((bitMask >> i) & 0x1)
break;
}
bitShift = i;
data = ((originalValue) & (~bitMask)) | (((data << bitShift)) & bitMask);
}
rtw_write8(Adapter, regAddr, data);
}
void halwifionly_phy_set_rf_reg(void *pwifionlyContext, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
phy_set_rf_reg(Adapter, eRFPath, RegAddr, BitMask, Data);
}
void halwifionly_phy_set_bb_reg(void *pwifionlyContext, u32 RegAddr, u32 BitMask, u32 Data)
{
struct wifi_only_cfg *pwifionlycfg = (struct wifi_only_cfg *)pwifionlyContext;
PADAPTER Adapter = pwifionlycfg->Adapter;
phy_set_bb_reg(Adapter, RegAddr, BitMask, Data);
}
void hal_btcoex_wifionly_switchband_notify(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 is_5g = _FALSE;
if (pHalData->current_band_type == BAND_ON_5G)
is_5g = _TRUE;
if (IS_HARDWARE_TYPE_8822B(padapter)) {
#ifdef CONFIG_RTL8822B
ex_hal8822b_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
#endif
}
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(padapter))
ex_hal8821c_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
#endif
#ifdef CONFIG_RTL8822C
else if (IS_HARDWARE_TYPE_8822C(padapter))
ex_hal8822c_wifi_only_switchbandnotify(&GLBtCoexistWifiOnly, is_5g);
#endif
}
void hal_btcoex_wifionly_scan_notify(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 is_5g = _FALSE;
if (pHalData->current_band_type == BAND_ON_5G)
is_5g = _TRUE;
if (IS_HARDWARE_TYPE_8822B(padapter)) {
#ifdef CONFIG_RTL8822B
ex_hal8822b_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
#endif
}
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(padapter))
ex_hal8821c_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
#endif
#ifdef CONFIG_RTL8822C
else if (IS_HARDWARE_TYPE_8822C(padapter))
ex_hal8822c_wifi_only_scannotify(&GLBtCoexistWifiOnly, is_5g);
#endif
}
void hal_btcoex_wifionly_connect_notify(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 is_5g = _FALSE;
if (pHalData->current_band_type == BAND_ON_5G)
is_5g = _TRUE;
if (IS_HARDWARE_TYPE_8822B(padapter)) {
#ifdef CONFIG_RTL8822B
ex_hal8822b_wifi_only_connectnotify(&GLBtCoexistWifiOnly, is_5g);
#endif
}
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(padapter))
ex_hal8821c_wifi_only_connectnotify(&GLBtCoexistWifiOnly, is_5g);
#endif
#ifdef CONFIG_RTL8822C
else if (IS_HARDWARE_TYPE_8822C(padapter))
ex_hal8822c_wifi_only_connectnotify(&GLBtCoexistWifiOnly, is_5g);
#endif
}
void hal_btcoex_wifionly_hw_config(PADAPTER padapter)
{
struct wifi_only_cfg *pwifionlycfg = &GLBtCoexistWifiOnly;
if (IS_HARDWARE_TYPE_8723B(padapter)) {
#ifdef CONFIG_RTL8723B
ex_hal8723b_wifi_only_hw_config(pwifionlycfg);
#endif
}
#ifdef CONFIG_RTL8822B
else if (IS_HARDWARE_TYPE_8822B(padapter))
ex_hal8822b_wifi_only_hw_config(pwifionlycfg);
#endif
#ifdef CONFIG_RTL8821C
else if (IS_HARDWARE_TYPE_8821C(padapter))
ex_hal8821c_wifi_only_hw_config(pwifionlycfg);
#endif
#ifdef CONFIG_RTL8822C
else if (IS_HARDWARE_TYPE_8822C(padapter))
ex_hal8822c_wifi_only_hw_config(pwifionlycfg);
#endif
}
void hal_btcoex_wifionly_initlizevariables(PADAPTER padapter)
{
struct wifi_only_cfg *pwifionlycfg = &GLBtCoexistWifiOnly;
struct wifi_only_haldata *pwifionly_haldata = &pwifionlycfg->haldata_info;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
_rtw_memset(&GLBtCoexistWifiOnly, 0, sizeof(GLBtCoexistWifiOnly));
pwifionlycfg->Adapter = padapter;
#ifdef CONFIG_PCI_HCI
pwifionlycfg->chip_interface = WIFIONLY_INTF_PCI;
#elif defined(CONFIG_USB_HCI)
pwifionlycfg->chip_interface = WIFIONLY_INTF_USB;
#elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
pwifionlycfg->chip_interface = WIFIONLY_INTF_SDIO;
#else
pwifionlycfg->chip_interface = WIFIONLY_INTF_UNKNOWN;
#endif
pwifionly_haldata->customer_id = CUSTOMER_NORMAL;
}
void hal_btcoex_wifionly_AntInfoSetting(PADAPTER padapter)
{
struct wifi_only_cfg *pwifionlycfg = &GLBtCoexistWifiOnly;
struct wifi_only_haldata *pwifionly_haldata = &pwifionlycfg->haldata_info;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
pwifionly_haldata->efuse_pg_antnum = pHalData->EEPROMBluetoothAntNum;
pwifionly_haldata->efuse_pg_antpath = pHalData->ant_path;
pwifionly_haldata->rfe_type = pHalData->rfe_type;
pwifionly_haldata->ant_div_cfg = pHalData->AntDivCfg;
}
#endif
================================================
FILE: hal/hal_com.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_COM_C_
#include
#include "hal_com_h2c.h"
#include "hal_data.h"
#ifdef RTW_HALMAC
#include "../../hal/hal_halmac.h"
#endif
void rtw_dump_fw_info(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal_data = NULL;
if (!adapter)
return;
hal_data = GET_HAL_DATA(adapter);
if (hal_data->bFWReady)
RTW_PRINT_SEL(sel, "FW VER -%d.%d\n", hal_data->firmware_version, hal_data->firmware_sub_version);
else
RTW_PRINT_SEL(sel, "FW not ready\n");
}
bool rsvd_page_cache_update_all(struct rsvd_page_cache_t *cache, u8 loc
, u8 txdesc_len, u32 page_size, u8 *info, u32 info_len)
{
u8 page_num;
bool modified = 0;
bool loc_mod = 0, size_mod = 0, page_num_mod = 0;
page_num = info_len ? (u8)PageNum(txdesc_len + info_len, page_size) : 0;
if (!info_len)
loc = 0;
if (cache->loc != loc) {
RTW_INFO("%s %s loc change (%u -> %u)\n"
, __func__, cache->name, cache->loc, loc);
loc_mod = 1;
}
if (cache->size != info_len) {
RTW_INFO("%s %s size change (%u -> %u)\n"
, __func__, cache->name, cache->size, info_len);
size_mod = 1;
}
if (cache->page_num != page_num) {
RTW_INFO("%s %s page_num change (%u -> %u)\n"
, __func__, cache->name, cache->page_num, page_num);
page_num_mod = 1;
}
if (info && info_len) {
if (cache->data) {
if (cache->size == info_len) {
if (_rtw_memcmp(cache->data, info, info_len) != _TRUE) {
RTW_INFO("%s %s data change\n", __func__, cache->name);
modified = 1;
}
} else
rsvd_page_cache_free_data(cache);
}
if (!cache->data) {
cache->data = rtw_malloc(info_len);
if (!cache->data) {
RTW_ERR("%s %s alloc data with size(%u) fail\n"
, __func__, cache->name, info_len);
rtw_warn_on(1);
} else {
RTW_INFO("%s %s alloc data with size(%u)\n"
, __func__, cache->name, info_len);
}
modified = 1;
}
if (cache->data && modified)
_rtw_memcpy(cache->data, info, info_len);
} else {
if (cache->data && size_mod)
rsvd_page_cache_free_data(cache);
}
cache->loc = loc;
cache->page_num = page_num;
cache->size = info_len;
return modified | loc_mod | size_mod | page_num_mod;
}
bool rsvd_page_cache_update_data(struct rsvd_page_cache_t *cache, u8 *info, u32 info_len)
{
bool modified = 0;
if (!info || !info_len) {
RTW_WARN("%s %s invalid input(info:%p, info_len:%u)\n"
, __func__, cache->name, info, info_len);
goto exit;
}
if (!cache->loc || !cache->page_num || !cache->size) {
RTW_ERR("%s %s layout not ready(loc:%u, page_num:%u, size:%u)\n"
, __func__, cache->name, cache->loc, cache->page_num, cache->size);
rtw_warn_on(1);
goto exit;
}
if (cache->size != info_len) {
RTW_ERR("%s %s size(%u) differ with info_len(%u)\n"
, __func__, cache->name, cache->size, info_len);
rtw_warn_on(1);
goto exit;
}
if (!cache->data) {
cache->data = rtw_zmalloc(cache->size);
if (!cache->data) {
RTW_ERR("%s %s alloc data with size(%u) fail\n"
, __func__, cache->name, cache->size);
rtw_warn_on(1);
goto exit;
} else {
RTW_INFO("%s %s alloc data with size(%u)\n"
, __func__, cache->name, info_len);
}
modified = 1;
}
if (_rtw_memcmp(cache->data, info, cache->size) == _FALSE) {
RTW_INFO("%s %s data change\n", __func__, cache->name);
_rtw_memcpy(cache->data, info, cache->size);
modified = 1;
}
exit:
return modified;
}
void rsvd_page_cache_free_data(struct rsvd_page_cache_t *cache)
{
if (cache->data) {
rtw_mfree(cache->data, cache->size);
cache->data = NULL;
}
}
void rsvd_page_cache_free(struct rsvd_page_cache_t *cache)
{
cache->loc = 0;
cache->page_num = 0;
rsvd_page_cache_free_data(cache);
cache->size = 0;
}
/* #define CONFIG_GTK_OL_DBG */
/*#define DBG_SEC_CAM_MOVE*/
#ifdef DBG_SEC_CAM_MOVE
void rtw_hal_move_sta_gk_to_dk(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
int cam_id, index = 0;
u8 *addr = NULL;
if (!MLME_IS_STA(adapter))
return;
addr = get_bssid(pmlmepriv);
if (addr == NULL) {
RTW_INFO("%s: get bssid MAC addr fail!!\n", __func__);
return;
}
rtw_clean_dk_section(adapter);
do {
cam_id = rtw_camid_search(adapter, addr, index, 1);
if (cam_id == -1)
RTW_INFO("%s: cam_id: %d, key_id:%d\n", __func__, cam_id, index);
else
rtw_sec_cam_swap(adapter, cam_id, index);
index++;
} while (index < 4);
}
void rtw_hal_read_sta_dk_key(_adapter *adapter, u8 key_id)
{
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
u8 get_key[16];
_rtw_memset(get_key, 0, sizeof(get_key));
if (key_id > 4) {
RTW_INFO("%s [ERROR] gtk_keyindex:%d invalid\n", __func__, key_id);
rtw_warn_on(1);
return;
}
rtw_sec_read_cam_ent(adapter, key_id, NULL, NULL, get_key);
/*update key into related sw variable*/
_enter_critical_bh(&cam_ctl->lock, &irqL);
if (_rtw_camid_is_gk(adapter, key_id)) {
RTW_INFO("[HW KEY] -Key-id:%d "KEY_FMT"\n", key_id, KEY_ARG(get_key));
RTW_INFO("[cam_cache KEY] - Key-id:%d "KEY_FMT"\n", key_id, KEY_ARG(&dvobj->cam_cache[key_id].key));
}
_exit_critical_bh(&cam_ctl->lock, &irqL);
}
#endif
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
char rtw_phy_para_file_path[PATH_LENGTH_MAX];
#endif
void dump_chip_info(HAL_VERSION ChipVersion)
{
int cnt = 0;
u8 buf[128] = {0};
if (IS_8188E(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188E_");
else if (IS_8188F(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188F_");
else if (IS_8188GTV(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8188GTV_");
else if (IS_8812_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8812_");
else if (IS_8192E(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8192E_");
else if (IS_8821_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8821_");
else if (IS_8723B_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8723B_");
else if (IS_8703B_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8703B_");
else if (IS_8723D_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8723D_");
else if (IS_8814A_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8814A_");
else if (IS_8822B_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8822B_");
else if (IS_8821C_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8821C_");
else if (IS_8710B_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8710B_");
else if (IS_8192F_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8192F_");
else if (IS_8822C_SERIES(ChipVersion))
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_8822C_");
else
cnt += sprintf((buf + cnt), "Chip Version Info: CHIP_UNKNOWN_");
cnt += sprintf((buf + cnt), "%s_", IS_NORMAL_CHIP(ChipVersion) ? "Normal_Chip" : "Test_Chip");
if (IS_CHIP_VENDOR_TSMC(ChipVersion))
cnt += sprintf((buf + cnt), "%s_", "TSMC");
else if (IS_CHIP_VENDOR_UMC(ChipVersion))
cnt += sprintf((buf + cnt), "%s_", "UMC");
else if (IS_CHIP_VENDOR_SMIC(ChipVersion))
cnt += sprintf((buf + cnt), "%s_", "SMIC");
if (IS_A_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "A_CUT_");
else if (IS_B_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "B_CUT_");
else if (IS_C_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "C_CUT_");
else if (IS_D_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "D_CUT_");
else if (IS_E_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "E_CUT_");
else if (IS_F_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "F_CUT_");
else if (IS_I_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "I_CUT_");
else if (IS_J_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "J_CUT_");
else if (IS_K_CUT(ChipVersion))
cnt += sprintf((buf + cnt), "K_CUT_");
else
cnt += sprintf((buf + cnt), "UNKNOWN_CUT(%d)_", ChipVersion.CUTVersion);
if (IS_1T1R(ChipVersion))
cnt += sprintf((buf + cnt), "1T1R_");
else if (IS_1T2R(ChipVersion))
cnt += sprintf((buf + cnt), "1T2R_");
else if (IS_2T2R(ChipVersion))
cnt += sprintf((buf + cnt), "2T2R_");
else if (IS_3T3R(ChipVersion))
cnt += sprintf((buf + cnt), "3T3R_");
else if (IS_3T4R(ChipVersion))
cnt += sprintf((buf + cnt), "3T4R_");
else if (IS_4T4R(ChipVersion))
cnt += sprintf((buf + cnt), "4T4R_");
else
cnt += sprintf((buf + cnt), "UNKNOWN_RFTYPE(%d)_", ChipVersion.RFType);
cnt += sprintf((buf + cnt), "RomVer(%d)\n", ChipVersion.ROMVer);
RTW_INFO("%s", buf);
}
u8 rtw_hal_get_port(_adapter *adapter)
{
u8 hw_port = get_hw_port(adapter);
#ifdef CONFIG_CLIENT_PORT_CFG
u8 clt_port = get_clt_port(adapter);
if (clt_port)
hw_port = clt_port;
#ifdef DBG_HW_PORT
if (MLME_IS_STA(adapter) && (adapter->client_id != MAX_CLIENT_PORT_NUM)) {
if(hw_port == CLT_PORT_INVALID) {
RTW_ERR(ADPT_FMT" @@@@@ Client port == 0 @@@@@\n", ADPT_ARG(adapter));
rtw_warn_on(1);
}
}
else if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
if (hw_port != HW_PORT0) {
RTW_ERR(ADPT_FMT" @@@@@ AP / MESH port != 0 @@@@@\n", ADPT_ARG(adapter));
rtw_warn_on(1);
}
}
if (0)
RTW_INFO(ADPT_FMT" - HP:%d,CP:%d\n", ADPT_ARG(adapter), get_hw_port(adapter), get_clt_port(adapter));
#endif /*DBG_HW_PORT*/
#endif/*CONFIG_CLIENT_PORT_CFG*/
return hw_port;
}
void rtw_hal_config_rftype(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if (IS_1T1R(pHalData->version_id)) {
pHalData->rf_type = RF_1T1R;
pHalData->NumTotalRFPath = 1;
} else if (IS_2T2R(pHalData->version_id)) {
pHalData->rf_type = RF_2T2R;
pHalData->NumTotalRFPath = 2;
} else if (IS_1T2R(pHalData->version_id)) {
pHalData->rf_type = RF_1T2R;
pHalData->NumTotalRFPath = 2;
} else if (IS_3T3R(pHalData->version_id)) {
pHalData->rf_type = RF_3T3R;
pHalData->NumTotalRFPath = 3;
} else if (IS_4T4R(pHalData->version_id)) {
pHalData->rf_type = RF_4T4R;
pHalData->NumTotalRFPath = 4;
} else {
pHalData->rf_type = RF_1T1R;
pHalData->NumTotalRFPath = 1;
}
RTW_INFO("%s RF_Type is %d TotalTxPath is %d\n", __FUNCTION__, pHalData->rf_type, pHalData->NumTotalRFPath);
}
#define EEPROM_CHANNEL_PLAN_BY_HW_MASK 0x80
/*
* Description:
* Use hardware(efuse), driver parameter(registry) and default channel plan
* to decide which one should be used.
*
* Parameters:
* padapter pointer of adapter
* hw_alpha2 country code from HW (efuse/eeprom/mapfile)
* hw_chplan channel plan from HW (efuse/eeprom/mapfile)
* BIT[7] software configure mode; 0:Enable, 1:disable
* BIT[6:0] Channel Plan
* sw_alpha2 country code from HW (registry/module param)
* sw_chplan channel plan from SW (registry/module param)
* def_chplan channel plan used when HW/SW both invalid
* AutoLoadFail efuse autoload fail or not
*
*/
void hal_com_config_channel_plan(
PADAPTER padapter,
char *hw_alpha2,
u8 hw_chplan,
char *sw_alpha2,
u8 sw_chplan,
u8 def_chplan,
BOOLEAN AutoLoadFail
)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(padapter);
PHAL_DATA_TYPE pHalData;
u8 force_hw_chplan = _FALSE;
int chplan = -1;
const struct country_chplan *country_ent = NULL, *ent;
pHalData = GET_HAL_DATA(padapter);
/* treat 0xFF as invalid value, bypass hw_chplan & force_hw_chplan parsing */
if (hw_chplan == 0xFF)
goto chk_hw_country_code;
if (AutoLoadFail == _TRUE)
goto chk_sw_config;
#ifndef CONFIG_FORCE_SW_CHANNEL_PLAN
if (hw_chplan & EEPROM_CHANNEL_PLAN_BY_HW_MASK)
force_hw_chplan = _TRUE;
#endif
hw_chplan &= (~EEPROM_CHANNEL_PLAN_BY_HW_MASK);
chk_hw_country_code:
if (hw_alpha2 && !IS_ALPHA2_NO_SPECIFIED(hw_alpha2)) {
ent = rtw_get_chplan_from_country(hw_alpha2);
if (ent) {
/* get chplan from hw country code, by pass hw chplan setting */
country_ent = ent;
chplan = ent->chplan;
goto chk_sw_config;
} else
RTW_PRINT("%s unsupported hw_alpha2:\"%c%c\"\n", __func__, hw_alpha2[0], hw_alpha2[1]);
}
if (rtw_is_channel_plan_valid(hw_chplan))
chplan = hw_chplan;
else if (force_hw_chplan == _TRUE) {
RTW_PRINT("%s unsupported hw_chplan:0x%02X\n", __func__, hw_chplan);
/* hw infomaton invalid, refer to sw information */
force_hw_chplan = _FALSE;
}
chk_sw_config:
if (force_hw_chplan == _TRUE)
goto done;
if (sw_alpha2 && !IS_ALPHA2_NO_SPECIFIED(sw_alpha2)) {
ent = rtw_get_chplan_from_country(sw_alpha2);
if (ent) {
/* get chplan from sw country code, by pass sw chplan setting */
country_ent = ent;
chplan = ent->chplan;
goto done;
} else
RTW_PRINT("%s unsupported sw_alpha2:\"%c%c\"\n", __func__, sw_alpha2[0], sw_alpha2[1]);
}
if (rtw_is_channel_plan_valid(sw_chplan)) {
/* cancel hw_alpha2 because chplan is specified by sw_chplan*/
country_ent = NULL;
chplan = sw_chplan;
} else if (sw_chplan != RTW_CHPLAN_UNSPECIFIED)
RTW_PRINT("%s unsupported sw_chplan:0x%02X\n", __func__, sw_chplan);
done:
if (chplan == -1) {
RTW_PRINT("%s use def_chplan:0x%02X\n", __func__, def_chplan);
chplan = def_chplan;
} else if (country_ent) {
RTW_PRINT("%s country code:\"%c%c\" with chplan:0x%02X\n", __func__
, country_ent->alpha2[0], country_ent->alpha2[1], country_ent->chplan);
} else
RTW_PRINT("%s chplan:0x%02X\n", __func__, chplan);
rfctl->country_ent = country_ent;
rfctl->ChannelPlan = chplan;
pHalData->bDisableSWChannelPlan = force_hw_chplan;
}
BOOLEAN
HAL_IsLegalChannel(
PADAPTER Adapter,
u32 Channel
)
{
BOOLEAN bLegalChannel = _TRUE;
if (Channel > 14) {
if (is_supported_5g(Adapter->registrypriv.wireless_mode) == _FALSE) {
bLegalChannel = _FALSE;
RTW_INFO("Channel > 14 but wireless_mode do not support 5G\n");
}
} else if ((Channel <= 14) && (Channel >= 1)) {
if (IsSupported24G(Adapter->registrypriv.wireless_mode) == _FALSE) {
bLegalChannel = _FALSE;
RTW_INFO("(Channel <= 14) && (Channel >=1) but wireless_mode do not support 2.4G\n");
}
} else {
bLegalChannel = _FALSE;
RTW_INFO("Channel is Invalid !!!\n");
}
return bLegalChannel;
}
u8 MRateToHwRate(u8 rate)
{
u8 ret = DESC_RATE1M;
switch (rate) {
case MGN_1M:
ret = DESC_RATE1M;
break;
case MGN_2M:
ret = DESC_RATE2M;
break;
case MGN_5_5M:
ret = DESC_RATE5_5M;
break;
case MGN_11M:
ret = DESC_RATE11M;
break;
case MGN_6M:
ret = DESC_RATE6M;
break;
case MGN_9M:
ret = DESC_RATE9M;
break;
case MGN_12M:
ret = DESC_RATE12M;
break;
case MGN_18M:
ret = DESC_RATE18M;
break;
case MGN_24M:
ret = DESC_RATE24M;
break;
case MGN_36M:
ret = DESC_RATE36M;
break;
case MGN_48M:
ret = DESC_RATE48M;
break;
case MGN_54M:
ret = DESC_RATE54M;
break;
case MGN_MCS0:
ret = DESC_RATEMCS0;
break;
case MGN_MCS1:
ret = DESC_RATEMCS1;
break;
case MGN_MCS2:
ret = DESC_RATEMCS2;
break;
case MGN_MCS3:
ret = DESC_RATEMCS3;
break;
case MGN_MCS4:
ret = DESC_RATEMCS4;
break;
case MGN_MCS5:
ret = DESC_RATEMCS5;
break;
case MGN_MCS6:
ret = DESC_RATEMCS6;
break;
case MGN_MCS7:
ret = DESC_RATEMCS7;
break;
case MGN_MCS8:
ret = DESC_RATEMCS8;
break;
case MGN_MCS9:
ret = DESC_RATEMCS9;
break;
case MGN_MCS10:
ret = DESC_RATEMCS10;
break;
case MGN_MCS11:
ret = DESC_RATEMCS11;
break;
case MGN_MCS12:
ret = DESC_RATEMCS12;
break;
case MGN_MCS13:
ret = DESC_RATEMCS13;
break;
case MGN_MCS14:
ret = DESC_RATEMCS14;
break;
case MGN_MCS15:
ret = DESC_RATEMCS15;
break;
case MGN_MCS16:
ret = DESC_RATEMCS16;
break;
case MGN_MCS17:
ret = DESC_RATEMCS17;
break;
case MGN_MCS18:
ret = DESC_RATEMCS18;
break;
case MGN_MCS19:
ret = DESC_RATEMCS19;
break;
case MGN_MCS20:
ret = DESC_RATEMCS20;
break;
case MGN_MCS21:
ret = DESC_RATEMCS21;
break;
case MGN_MCS22:
ret = DESC_RATEMCS22;
break;
case MGN_MCS23:
ret = DESC_RATEMCS23;
break;
case MGN_MCS24:
ret = DESC_RATEMCS24;
break;
case MGN_MCS25:
ret = DESC_RATEMCS25;
break;
case MGN_MCS26:
ret = DESC_RATEMCS26;
break;
case MGN_MCS27:
ret = DESC_RATEMCS27;
break;
case MGN_MCS28:
ret = DESC_RATEMCS28;
break;
case MGN_MCS29:
ret = DESC_RATEMCS29;
break;
case MGN_MCS30:
ret = DESC_RATEMCS30;
break;
case MGN_MCS31:
ret = DESC_RATEMCS31;
break;
case MGN_VHT1SS_MCS0:
ret = DESC_RATEVHTSS1MCS0;
break;
case MGN_VHT1SS_MCS1:
ret = DESC_RATEVHTSS1MCS1;
break;
case MGN_VHT1SS_MCS2:
ret = DESC_RATEVHTSS1MCS2;
break;
case MGN_VHT1SS_MCS3:
ret = DESC_RATEVHTSS1MCS3;
break;
case MGN_VHT1SS_MCS4:
ret = DESC_RATEVHTSS1MCS4;
break;
case MGN_VHT1SS_MCS5:
ret = DESC_RATEVHTSS1MCS5;
break;
case MGN_VHT1SS_MCS6:
ret = DESC_RATEVHTSS1MCS6;
break;
case MGN_VHT1SS_MCS7:
ret = DESC_RATEVHTSS1MCS7;
break;
case MGN_VHT1SS_MCS8:
ret = DESC_RATEVHTSS1MCS8;
break;
case MGN_VHT1SS_MCS9:
ret = DESC_RATEVHTSS1MCS9;
break;
case MGN_VHT2SS_MCS0:
ret = DESC_RATEVHTSS2MCS0;
break;
case MGN_VHT2SS_MCS1:
ret = DESC_RATEVHTSS2MCS1;
break;
case MGN_VHT2SS_MCS2:
ret = DESC_RATEVHTSS2MCS2;
break;
case MGN_VHT2SS_MCS3:
ret = DESC_RATEVHTSS2MCS3;
break;
case MGN_VHT2SS_MCS4:
ret = DESC_RATEVHTSS2MCS4;
break;
case MGN_VHT2SS_MCS5:
ret = DESC_RATEVHTSS2MCS5;
break;
case MGN_VHT2SS_MCS6:
ret = DESC_RATEVHTSS2MCS6;
break;
case MGN_VHT2SS_MCS7:
ret = DESC_RATEVHTSS2MCS7;
break;
case MGN_VHT2SS_MCS8:
ret = DESC_RATEVHTSS2MCS8;
break;
case MGN_VHT2SS_MCS9:
ret = DESC_RATEVHTSS2MCS9;
break;
case MGN_VHT3SS_MCS0:
ret = DESC_RATEVHTSS3MCS0;
break;
case MGN_VHT3SS_MCS1:
ret = DESC_RATEVHTSS3MCS1;
break;
case MGN_VHT3SS_MCS2:
ret = DESC_RATEVHTSS3MCS2;
break;
case MGN_VHT3SS_MCS3:
ret = DESC_RATEVHTSS3MCS3;
break;
case MGN_VHT3SS_MCS4:
ret = DESC_RATEVHTSS3MCS4;
break;
case MGN_VHT3SS_MCS5:
ret = DESC_RATEVHTSS3MCS5;
break;
case MGN_VHT3SS_MCS6:
ret = DESC_RATEVHTSS3MCS6;
break;
case MGN_VHT3SS_MCS7:
ret = DESC_RATEVHTSS3MCS7;
break;
case MGN_VHT3SS_MCS8:
ret = DESC_RATEVHTSS3MCS8;
break;
case MGN_VHT3SS_MCS9:
ret = DESC_RATEVHTSS3MCS9;
break;
case MGN_VHT4SS_MCS0:
ret = DESC_RATEVHTSS4MCS0;
break;
case MGN_VHT4SS_MCS1:
ret = DESC_RATEVHTSS4MCS1;
break;
case MGN_VHT4SS_MCS2:
ret = DESC_RATEVHTSS4MCS2;
break;
case MGN_VHT4SS_MCS3:
ret = DESC_RATEVHTSS4MCS3;
break;
case MGN_VHT4SS_MCS4:
ret = DESC_RATEVHTSS4MCS4;
break;
case MGN_VHT4SS_MCS5:
ret = DESC_RATEVHTSS4MCS5;
break;
case MGN_VHT4SS_MCS6:
ret = DESC_RATEVHTSS4MCS6;
break;
case MGN_VHT4SS_MCS7:
ret = DESC_RATEVHTSS4MCS7;
break;
case MGN_VHT4SS_MCS8:
ret = DESC_RATEVHTSS4MCS8;
break;
case MGN_VHT4SS_MCS9:
ret = DESC_RATEVHTSS4MCS9;
break;
default:
break;
}
return ret;
}
u8 hw_rate_to_m_rate(u8 rate)
{
u8 ret_rate = MGN_1M;
switch (rate) {
case DESC_RATE1M:
ret_rate = MGN_1M;
break;
case DESC_RATE2M:
ret_rate = MGN_2M;
break;
case DESC_RATE5_5M:
ret_rate = MGN_5_5M;
break;
case DESC_RATE11M:
ret_rate = MGN_11M;
break;
case DESC_RATE6M:
ret_rate = MGN_6M;
break;
case DESC_RATE9M:
ret_rate = MGN_9M;
break;
case DESC_RATE12M:
ret_rate = MGN_12M;
break;
case DESC_RATE18M:
ret_rate = MGN_18M;
break;
case DESC_RATE24M:
ret_rate = MGN_24M;
break;
case DESC_RATE36M:
ret_rate = MGN_36M;
break;
case DESC_RATE48M:
ret_rate = MGN_48M;
break;
case DESC_RATE54M:
ret_rate = MGN_54M;
break;
case DESC_RATEMCS0:
ret_rate = MGN_MCS0;
break;
case DESC_RATEMCS1:
ret_rate = MGN_MCS1;
break;
case DESC_RATEMCS2:
ret_rate = MGN_MCS2;
break;
case DESC_RATEMCS3:
ret_rate = MGN_MCS3;
break;
case DESC_RATEMCS4:
ret_rate = MGN_MCS4;
break;
case DESC_RATEMCS5:
ret_rate = MGN_MCS5;
break;
case DESC_RATEMCS6:
ret_rate = MGN_MCS6;
break;
case DESC_RATEMCS7:
ret_rate = MGN_MCS7;
break;
case DESC_RATEMCS8:
ret_rate = MGN_MCS8;
break;
case DESC_RATEMCS9:
ret_rate = MGN_MCS9;
break;
case DESC_RATEMCS10:
ret_rate = MGN_MCS10;
break;
case DESC_RATEMCS11:
ret_rate = MGN_MCS11;
break;
case DESC_RATEMCS12:
ret_rate = MGN_MCS12;
break;
case DESC_RATEMCS13:
ret_rate = MGN_MCS13;
break;
case DESC_RATEMCS14:
ret_rate = MGN_MCS14;
break;
case DESC_RATEMCS15:
ret_rate = MGN_MCS15;
break;
case DESC_RATEMCS16:
ret_rate = MGN_MCS16;
break;
case DESC_RATEMCS17:
ret_rate = MGN_MCS17;
break;
case DESC_RATEMCS18:
ret_rate = MGN_MCS18;
break;
case DESC_RATEMCS19:
ret_rate = MGN_MCS19;
break;
case DESC_RATEMCS20:
ret_rate = MGN_MCS20;
break;
case DESC_RATEMCS21:
ret_rate = MGN_MCS21;
break;
case DESC_RATEMCS22:
ret_rate = MGN_MCS22;
break;
case DESC_RATEMCS23:
ret_rate = MGN_MCS23;
break;
case DESC_RATEMCS24:
ret_rate = MGN_MCS24;
break;
case DESC_RATEMCS25:
ret_rate = MGN_MCS25;
break;
case DESC_RATEMCS26:
ret_rate = MGN_MCS26;
break;
case DESC_RATEMCS27:
ret_rate = MGN_MCS27;
break;
case DESC_RATEMCS28:
ret_rate = MGN_MCS28;
break;
case DESC_RATEMCS29:
ret_rate = MGN_MCS29;
break;
case DESC_RATEMCS30:
ret_rate = MGN_MCS30;
break;
case DESC_RATEMCS31:
ret_rate = MGN_MCS31;
break;
case DESC_RATEVHTSS1MCS0:
ret_rate = MGN_VHT1SS_MCS0;
break;
case DESC_RATEVHTSS1MCS1:
ret_rate = MGN_VHT1SS_MCS1;
break;
case DESC_RATEVHTSS1MCS2:
ret_rate = MGN_VHT1SS_MCS2;
break;
case DESC_RATEVHTSS1MCS3:
ret_rate = MGN_VHT1SS_MCS3;
break;
case DESC_RATEVHTSS1MCS4:
ret_rate = MGN_VHT1SS_MCS4;
break;
case DESC_RATEVHTSS1MCS5:
ret_rate = MGN_VHT1SS_MCS5;
break;
case DESC_RATEVHTSS1MCS6:
ret_rate = MGN_VHT1SS_MCS6;
break;
case DESC_RATEVHTSS1MCS7:
ret_rate = MGN_VHT1SS_MCS7;
break;
case DESC_RATEVHTSS1MCS8:
ret_rate = MGN_VHT1SS_MCS8;
break;
case DESC_RATEVHTSS1MCS9:
ret_rate = MGN_VHT1SS_MCS9;
break;
case DESC_RATEVHTSS2MCS0:
ret_rate = MGN_VHT2SS_MCS0;
break;
case DESC_RATEVHTSS2MCS1:
ret_rate = MGN_VHT2SS_MCS1;
break;
case DESC_RATEVHTSS2MCS2:
ret_rate = MGN_VHT2SS_MCS2;
break;
case DESC_RATEVHTSS2MCS3:
ret_rate = MGN_VHT2SS_MCS3;
break;
case DESC_RATEVHTSS2MCS4:
ret_rate = MGN_VHT2SS_MCS4;
break;
case DESC_RATEVHTSS2MCS5:
ret_rate = MGN_VHT2SS_MCS5;
break;
case DESC_RATEVHTSS2MCS6:
ret_rate = MGN_VHT2SS_MCS6;
break;
case DESC_RATEVHTSS2MCS7:
ret_rate = MGN_VHT2SS_MCS7;
break;
case DESC_RATEVHTSS2MCS8:
ret_rate = MGN_VHT2SS_MCS8;
break;
case DESC_RATEVHTSS2MCS9:
ret_rate = MGN_VHT2SS_MCS9;
break;
case DESC_RATEVHTSS3MCS0:
ret_rate = MGN_VHT3SS_MCS0;
break;
case DESC_RATEVHTSS3MCS1:
ret_rate = MGN_VHT3SS_MCS1;
break;
case DESC_RATEVHTSS3MCS2:
ret_rate = MGN_VHT3SS_MCS2;
break;
case DESC_RATEVHTSS3MCS3:
ret_rate = MGN_VHT3SS_MCS3;
break;
case DESC_RATEVHTSS3MCS4:
ret_rate = MGN_VHT3SS_MCS4;
break;
case DESC_RATEVHTSS3MCS5:
ret_rate = MGN_VHT3SS_MCS5;
break;
case DESC_RATEVHTSS3MCS6:
ret_rate = MGN_VHT3SS_MCS6;
break;
case DESC_RATEVHTSS3MCS7:
ret_rate = MGN_VHT3SS_MCS7;
break;
case DESC_RATEVHTSS3MCS8:
ret_rate = MGN_VHT3SS_MCS8;
break;
case DESC_RATEVHTSS3MCS9:
ret_rate = MGN_VHT3SS_MCS9;
break;
case DESC_RATEVHTSS4MCS0:
ret_rate = MGN_VHT4SS_MCS0;
break;
case DESC_RATEVHTSS4MCS1:
ret_rate = MGN_VHT4SS_MCS1;
break;
case DESC_RATEVHTSS4MCS2:
ret_rate = MGN_VHT4SS_MCS2;
break;
case DESC_RATEVHTSS4MCS3:
ret_rate = MGN_VHT4SS_MCS3;
break;
case DESC_RATEVHTSS4MCS4:
ret_rate = MGN_VHT4SS_MCS4;
break;
case DESC_RATEVHTSS4MCS5:
ret_rate = MGN_VHT4SS_MCS5;
break;
case DESC_RATEVHTSS4MCS6:
ret_rate = MGN_VHT4SS_MCS6;
break;
case DESC_RATEVHTSS4MCS7:
ret_rate = MGN_VHT4SS_MCS7;
break;
case DESC_RATEVHTSS4MCS8:
ret_rate = MGN_VHT4SS_MCS8;
break;
case DESC_RATEVHTSS4MCS9:
ret_rate = MGN_VHT4SS_MCS9;
break;
default:
RTW_INFO("hw_rate_to_m_rate(): Non supported Rate [%x]!!!\n", rate);
break;
}
return ret_rate;
}
void HalSetBrateCfg(
PADAPTER Adapter,
u8 *mBratesOS,
u16 *pBrateCfg)
{
u8 i, is_brate, brate;
for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
is_brate = mBratesOS[i] & IEEE80211_BASIC_RATE_MASK;
brate = mBratesOS[i] & 0x7f;
if (is_brate) {
switch (brate) {
case IEEE80211_CCK_RATE_1MB:
*pBrateCfg |= RATE_1M;
break;
case IEEE80211_CCK_RATE_2MB:
*pBrateCfg |= RATE_2M;
break;
case IEEE80211_CCK_RATE_5MB:
*pBrateCfg |= RATE_5_5M;
break;
case IEEE80211_CCK_RATE_11MB:
*pBrateCfg |= RATE_11M;
break;
case IEEE80211_OFDM_RATE_6MB:
*pBrateCfg |= RATE_6M;
break;
case IEEE80211_OFDM_RATE_9MB:
*pBrateCfg |= RATE_9M;
break;
case IEEE80211_OFDM_RATE_12MB:
*pBrateCfg |= RATE_12M;
break;
case IEEE80211_OFDM_RATE_18MB:
*pBrateCfg |= RATE_18M;
break;
case IEEE80211_OFDM_RATE_24MB:
*pBrateCfg |= RATE_24M;
break;
case IEEE80211_OFDM_RATE_36MB:
*pBrateCfg |= RATE_36M;
break;
case IEEE80211_OFDM_RATE_48MB:
*pBrateCfg |= RATE_48M;
break;
case IEEE80211_OFDM_RATE_54MB:
*pBrateCfg |= RATE_54M;
break;
}
}
}
}
static void
_OneOutPipeMapping(
PADAPTER pAdapter
)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[0];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[0];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
}
static void
_TwoOutPipeMapping(
PADAPTER pAdapter,
BOOLEAN bWIFICfg
)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
if (bWIFICfg) { /* WMM */
/* BK, BE, VI, VO, BCN, CMD,MGT,HIGH,HCCA */
/* { 0, 1, 0, 1, 0, 0, 0, 0, 0 }; */
/* 0:ep_0 num, 1:ep_1 num */
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[1];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[1];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[0];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
} else { /* typical setting */
/* BK, BE, VI, VO, BCN, CMD,MGT,HIGH,HCCA */
/* { 1, 1, 0, 0, 0, 0, 0, 0, 0 }; */
/* 0:ep_0 num, 1:ep_1 num */
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[1];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
}
}
static void _ThreeOutPipeMapping(
PADAPTER pAdapter,
BOOLEAN bWIFICfg
)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
if (bWIFICfg) { /* for WMM */
/* BK, BE, VI, VO, BCN, CMD,MGT,HIGH,HCCA */
/* { 1, 2, 1, 0, 0, 0, 0, 0, 0 }; */
/* 0:H, 1:N, 2:L */
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
} else { /* typical setting */
/* BK, BE, VI, VO, BCN, CMD,MGT,HIGH,HCCA */
/* { 2, 2, 1, 0, 0, 0, 0, 0, 0 }; */
/* 0:H, 1:N, 2:L */
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[2];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
}
}
#if 0
static void _FourOutPipeMapping(
PADAPTER pAdapter,
BOOLEAN bWIFICfg
)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
if (bWIFICfg) { /* for WMM */
/* BK, BE, VI, VO, BCN, CMD,MGT,HIGH,HCCA */
/* { 1, 2, 1, 0, 0, 0, 0, 0, 0 }; */
/* 0:H, 1:N, 2:L ,3:E */
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[3];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
} else { /* typical setting */
/* BK, BE, VI, VO, BCN, CMD,MGT,HIGH,HCCA */
/* { 2, 2, 1, 0, 0, 0, 0, 0, 0 }; */
/* 0:H, 1:N, 2:L */
pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];/* VO */
pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1];/* VI */
pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2];/* BE */
pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[2];/* BK */
pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];/* BCN */
pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];/* MGT */
pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[3];/* HIGH */
pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];/* TXCMD */
}
}
#endif
BOOLEAN
Hal_MappingOutPipe(
PADAPTER pAdapter,
u8 NumOutPipe
)
{
struct registry_priv *pregistrypriv = &pAdapter->registrypriv;
BOOLEAN bWIFICfg = (pregistrypriv->wifi_spec) ? _TRUE : _FALSE;
BOOLEAN result = _TRUE;
switch (NumOutPipe) {
case 2:
_TwoOutPipeMapping(pAdapter, bWIFICfg);
break;
case 3:
case 4:
case 5:
case 6:
_ThreeOutPipeMapping(pAdapter, bWIFICfg);
break;
case 1:
_OneOutPipeMapping(pAdapter);
break;
default:
result = _FALSE;
break;
}
return result;
}
void rtw_hal_reqtxrpt(_adapter *padapter, u8 macid)
{
if (padapter->hal_func.reqtxrpt)
padapter->hal_func.reqtxrpt(padapter, macid);
}
void rtw_hal_dump_macaddr(void *sel, _adapter *adapter)
{
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 mac_addr[ETH_ALEN];
#ifdef CONFIG_MI_WITH_MBSSID_CAM
rtw_mbid_cam_dump(sel, __func__, adapter);
#else
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface) {
rtw_hal_get_hwreg(iface, HW_VAR_MAC_ADDR, mac_addr);
RTW_PRINT_SEL(sel, ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n",
ADPT_ARG(iface), iface->hw_port, MAC_ARG(mac_addr));
}
}
#endif
}
#ifdef RTW_HALMAC
void rtw_hal_hw_port_enable(_adapter *adapter)
{
#if 1
u8 port_enable = _TRUE;
rtw_hal_set_hwreg(adapter, HW_VAR_PORT_CFG, &port_enable);
#else
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rtw_halmac_bcn_ctrl bcn_ctrl;
_rtw_memset(&bcn_ctrl, 0, sizeof(struct rtw_halmac_bcn_ctrl));
bcn_ctrl.enable_bcn = 1;
bcn_ctrl.rx_bssid_fit = 1;
bcn_ctrl.rxbcn_rpt = 1;
/*rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
struct rtw_halmac_bcn_ctrl *bcn_ctrl)*/
if (rtw_halmac_set_bcn_ctrl(dvobj, get_hw_port(adapter), &bcn_ctrl) == -1) {
RTW_ERR(ADPT_FMT" - hw port(%d) enable fail!!\n", ADPT_ARG(adapter), get_hw_port(adapter));
rtw_warn_on(1);
}
#endif
}
void rtw_hal_hw_port_disable(_adapter *adapter)
{
u8 port_enable = _FALSE;
rtw_hal_set_hwreg(adapter, HW_VAR_PORT_CFG, &port_enable);
}
void rtw_restore_hw_port_cfg(_adapter *adapter)
{
#ifdef CONFIG_MI_WITH_MBSSID_CAM
#else
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface)
rtw_hal_hw_port_enable(iface);
}
#endif
}
#endif
void rtw_mi_set_mac_addr(_adapter *adapter)
{
#ifdef CONFIG_MI_WITH_MBSSID_CAM
rtw_mi_set_mbid_cam(adapter);
#else
int i;
_adapter *iface;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface)
rtw_hal_set_hwreg(iface, HW_VAR_MAC_ADDR, adapter_mac_addr(iface));
}
#endif
if (1)
rtw_hal_dump_macaddr(RTW_DBGDUMP, adapter);
}
void rtw_init_hal_com_default_value(PADAPTER Adapter)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
struct registry_priv *regsty = adapter_to_regsty(Adapter);
pHalData->AntDetection = 1;
pHalData->antenna_test = _FALSE;
pHalData->RegIQKFWOffload = regsty->iqk_fw_offload;
pHalData->ch_switch_offload = regsty->ch_switch_offload;
pHalData->multi_ch_switch_mode = 0;
#ifdef RTW_REDUCE_SCAN_SWITCH_CH_TIME
if (pHalData->ch_switch_offload == 0)
pHalData->ch_switch_offload = 1;
#endif
}
#ifdef CONFIG_FW_C2H_REG
void c2h_evt_clear(_adapter *adapter)
{
rtw_write8(adapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE);
}
s32 c2h_evt_read_88xx(_adapter *adapter, u8 *buf)
{
s32 ret = _FAIL;
int i;
u8 trigger;
if (buf == NULL)
goto exit;
trigger = rtw_read8(adapter, REG_C2HEVT_CLEAR);
if (trigger == C2H_EVT_HOST_CLOSE) {
goto exit; /* Not ready */
} else if (trigger != C2H_EVT_FW_CLOSE) {
goto clear_evt; /* Not a valid value */
}
_rtw_memset(buf, 0, C2H_REG_LEN);
/* Read ID, LEN, SEQ */
SET_C2H_ID_88XX(buf, rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL));
SET_C2H_SEQ_88XX(buf, rtw_read8(adapter, REG_C2HEVT_CMD_SEQ_88XX));
SET_C2H_PLEN_88XX(buf, rtw_read8(adapter, REG_C2HEVT_CMD_LEN_88XX));
if (0) {
RTW_INFO("%s id=0x%02x, seq=%u, plen=%u, trigger=0x%02x\n", __func__
, C2H_ID_88XX(buf), C2H_SEQ_88XX(buf), C2H_PLEN_88XX(buf), trigger);
}
/* Read the content */
for (i = 0; i < C2H_PLEN_88XX(buf); i++)
*(C2H_PAYLOAD_88XX(buf) + i) = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 2 + i);
RTW_DBG_DUMP("payload: ", C2H_PAYLOAD_88XX(buf), C2H_PLEN_88XX(buf));
ret = _SUCCESS;
clear_evt:
/*
* Clear event to notify FW we have read the command.
* If this field isn't clear, the FW won't update the next command message.
*/
c2h_evt_clear(adapter);
exit:
return ret;
}
#endif /* CONFIG_FW_C2H_REG */
#ifdef CONFIG_FW_C2H_PKT
#ifndef DBG_C2H_PKT_PRE_HDL
#define DBG_C2H_PKT_PRE_HDL 0
#endif
#ifndef DBG_C2H_PKT_HDL
#define DBG_C2H_PKT_HDL 0
#endif
void rtw_hal_c2h_pkt_pre_hdl(_adapter *adapter, u8 *buf, u16 len)
{
#ifdef RTW_HALMAC
/* TODO: extract hal_mac IC's code here*/
#else
u8 parse_fail = 0;
u8 hdl_here = 0;
s32 ret = _FAIL;
u8 id, seq, plen;
u8 *payload;
if (rtw_hal_c2h_pkt_hdr_parse(adapter, buf, len, &id, &seq, &plen, &payload) != _SUCCESS) {
parse_fail = 1;
goto exit;
}
hdl_here = rtw_hal_c2h_id_handle_directly(adapter, id, seq, plen, payload) == _TRUE ? 1 : 0;
if (hdl_here)
ret = rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
else
ret = rtw_c2h_packet_wk_cmd(adapter, buf, len);
exit:
if (parse_fail)
RTW_ERR("%s parse fail, buf=%p, len=:%u\n", __func__, buf, len);
else if (ret != _SUCCESS || DBG_C2H_PKT_PRE_HDL > 0) {
RTW_PRINT("%s: id=0x%02x, seq=%u, plen=%u, %s %s\n", __func__, id, seq, plen
, hdl_here ? "handle" : "enqueue"
, ret == _SUCCESS ? "ok" : "fail"
);
if (DBG_C2H_PKT_PRE_HDL >= 2)
RTW_PRINT_DUMP("dump: ", buf, len);
}
#endif
}
void rtw_hal_c2h_pkt_hdl(_adapter *adapter, u8 *buf, u16 len)
{
#ifdef RTW_HALMAC
adapter->hal_func.hal_mac_c2h_handler(adapter, buf, len);
#else
u8 parse_fail = 0;
u8 bypass = 0;
s32 ret = _FAIL;
u8 id, seq, plen;
u8 *payload;
if (rtw_hal_c2h_pkt_hdr_parse(adapter, buf, len, &id, &seq, &plen, &payload) != _SUCCESS) {
parse_fail = 1;
goto exit;
}
#ifdef CONFIG_WOWLAN
if (adapter_to_pwrctl(adapter)->wowlan_mode == _TRUE) {
bypass = 1;
ret = _SUCCESS;
goto exit;
}
#endif
ret = rtw_hal_c2h_handler(adapter, id, seq, plen, payload);
exit:
if (parse_fail)
RTW_ERR("%s parse fail, buf=%p, len=:%u\n", __func__, buf, len);
else if (ret != _SUCCESS || bypass || DBG_C2H_PKT_HDL > 0) {
RTW_PRINT("%s: id=0x%02x, seq=%u, plen=%u, %s %s\n", __func__, id, seq, plen
, !bypass ? "handle" : "bypass"
, ret == _SUCCESS ? "ok" : "fail"
);
if (DBG_C2H_PKT_HDL >= 2)
RTW_PRINT_DUMP("dump: ", buf, len);
}
#endif
}
#endif /* CONFIG_FW_C2H_PKT */
void c2h_iqk_offload(_adapter *adapter, u8 *data, u8 len)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct submit_ctx *iqk_sctx = &hal_data->iqk_sctx;
RTW_INFO("IQK offload finish in %dms\n", rtw_get_passing_time_ms(iqk_sctx->submit_time));
if (0)
RTW_INFO_DUMP("C2H_IQK_FINISH: ", data, len);
rtw_sctx_done(&iqk_sctx);
}
int c2h_iqk_offload_wait(_adapter *adapter, u32 timeout_ms)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct submit_ctx *iqk_sctx = &hal_data->iqk_sctx;
iqk_sctx->submit_time = rtw_get_current_time();
iqk_sctx->timeout_ms = timeout_ms;
iqk_sctx->status = RTW_SCTX_SUBMITTED;
return rtw_sctx_wait(iqk_sctx, __func__);
}
#define GET_C2H_MAC_HIDDEN_RPT_UUID_X(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 0, 0, 8)
#define GET_C2H_MAC_HIDDEN_RPT_UUID_Y(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
#define GET_C2H_MAC_HIDDEN_RPT_UUID_Z(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 5)
#define GET_C2H_MAC_HIDDEN_RPT_UUID_CRC(_data) LE_BITS_TO_2BYTE(((u8 *)(_data)) + 2, 5, 11)
#define GET_C2H_MAC_HIDDEN_RPT_HCI_TYPE(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 4, 0, 4)
#define GET_C2H_MAC_HIDDEN_RPT_PACKAGE_TYPE(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 4, 4, 3)
#define GET_C2H_MAC_HIDDEN_RPT_TR_SWITCH(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 4, 7, 1)
#define GET_C2H_MAC_HIDDEN_RPT_WL_FUNC(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 0, 4)
#define GET_C2H_MAC_HIDDEN_RPT_HW_STYPE(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 4, 4)
#define GET_C2H_MAC_HIDDEN_RPT_BW(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 3)
#define GET_C2H_MAC_HIDDEN_RPT_ANT_NUM(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 5, 3)
#define GET_C2H_MAC_HIDDEN_RPT_80211_PROTOCOL(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 2, 2)
#define GET_C2H_MAC_HIDDEN_RPT_NIC_ROUTER(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 6, 2)
#ifndef DBG_C2H_MAC_HIDDEN_RPT_HANDLE
#define DBG_C2H_MAC_HIDDEN_RPT_HANDLE 0
#endif
#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
int ret = _FAIL;
u32 uuid;
u8 uuid_x;
u8 uuid_y;
u8 uuid_z;
u16 uuid_crc;
u8 hci_type;
u8 package_type;
u8 tr_switch;
u8 wl_func;
u8 hw_stype;
u8 bw;
u8 ss_num = 4;
u8 ant_num;
u8 protocol;
u8 nic;
int i;
if (len < MAC_HIDDEN_RPT_LEN) {
RTW_WARN("%s len(%u) < %d\n", __func__, len, MAC_HIDDEN_RPT_LEN);
goto exit;
}
uuid_x = GET_C2H_MAC_HIDDEN_RPT_UUID_X(data);
uuid_y = GET_C2H_MAC_HIDDEN_RPT_UUID_Y(data);
uuid_z = GET_C2H_MAC_HIDDEN_RPT_UUID_Z(data);
uuid_crc = GET_C2H_MAC_HIDDEN_RPT_UUID_CRC(data);
hci_type = GET_C2H_MAC_HIDDEN_RPT_HCI_TYPE(data);
package_type = GET_C2H_MAC_HIDDEN_RPT_PACKAGE_TYPE(data);
tr_switch = GET_C2H_MAC_HIDDEN_RPT_TR_SWITCH(data);
wl_func = GET_C2H_MAC_HIDDEN_RPT_WL_FUNC(data);
hw_stype = GET_C2H_MAC_HIDDEN_RPT_HW_STYPE(data);
bw = GET_C2H_MAC_HIDDEN_RPT_BW(data);
ant_num = GET_C2H_MAC_HIDDEN_RPT_ANT_NUM(data);
protocol = GET_C2H_MAC_HIDDEN_RPT_80211_PROTOCOL(data);
nic = GET_C2H_MAC_HIDDEN_RPT_NIC_ROUTER(data);
if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE) {
for (i = 0; i < len; i++)
RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
RTW_PRINT("uuid x:0x%02x y:0x%02x z:0x%x crc:0x%x\n", uuid_x, uuid_y, uuid_z, uuid_crc);
RTW_PRINT("hci_type:0x%x\n", hci_type);
RTW_PRINT("package_type:0x%x\n", package_type);
RTW_PRINT("tr_switch:0x%x\n", tr_switch);
RTW_PRINT("wl_func:0x%x\n", wl_func);
RTW_PRINT("hw_stype:0x%x\n", hw_stype);
RTW_PRINT("bw:0x%x\n", bw);
RTW_PRINT("ant_num:0x%x\n", ant_num);
RTW_PRINT("protocol:0x%x\n", protocol);
RTW_PRINT("nic:0x%x\n", nic);
}
#if defined(CONFIG_RTL8822C)
if (IS_8822C_SERIES(hal_data->version_id)) {
#define GET_C2H_MAC_HIDDEN_RPT_SS_NUM(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 3, 2)
ss_num = GET_C2H_MAC_HIDDEN_RPT_SS_NUM(data);
if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE)
RTW_PRINT("ss_num:0x%x\n", ss_num);
}
#endif
#if defined(CONFIG_RTL8822C)
if (IS_8822C_SERIES(hal_data->version_id)) {
if (hw_stype == 0xE)
hal_data->rf_type = RF_1T2R; /* txpath:A, rxpath:AB */
}
#endif
hal_data->PackageType = package_type;
hal_spec->hci_type = hci_type;
hal_spec->wl_func &= mac_hidden_wl_func_to_hal_wl_func(wl_func);
hal_spec->bw_cap &= mac_hidden_max_bw_to_hal_bw_cap(bw);
hal_spec->proto_cap &= mac_hidden_proto_to_hal_proto_cap(protocol);
/*
* RF TX path num >= max_tx_cnt >= tx_nss_num
* ex: RF TX path num(4) >= max_tx_cnt(2) >= tx_nss_num(1)
* Select at most 2 out of 4 TX RF path to do 1SS 2TX
*/
hal_spec->max_tx_cnt = rtw_min(hal_spec->max_tx_cnt, rf_type_to_rf_tx_cnt(hal_data->rf_type));
hal_spec->max_tx_cnt = rtw_min(hal_spec->max_tx_cnt, ant_num);
hal_spec->tx_nss_num = rtw_min(hal_spec->tx_nss_num, hal_spec->max_tx_cnt);
hal_spec->tx_nss_num = rtw_min(hal_spec->tx_nss_num, ss_num);
hal_spec->rx_nss_num = rtw_min(hal_spec->rx_nss_num, rf_type_to_rf_rx_cnt(hal_data->rf_type));
hal_spec->rx_nss_num = rtw_min(hal_spec->rx_nss_num, ant_num);
hal_spec->rx_nss_num = rtw_min(hal_spec->rx_nss_num, ss_num);
ret = _SUCCESS;
exit:
return ret;
}
int c2h_mac_hidden_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
int ret = _FAIL;
int i;
if (len < MAC_HIDDEN_RPT_2_LEN) {
RTW_WARN("%s len(%u) < %d\n", __func__, len, MAC_HIDDEN_RPT_2_LEN);
goto exit;
}
if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE) {
for (i = 0; i < len; i++)
RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
}
#if defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV)
if (IS_8188F(hal_data->version_id) || IS_8188GTV(hal_data->version_id)) {
#define GET_C2H_MAC_HIDDEN_RPT_IRV(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 0, 0, 4)
u8 irv = GET_C2H_MAC_HIDDEN_RPT_IRV(data);
if (DBG_C2H_MAC_HIDDEN_RPT_HANDLE)
RTW_PRINT("irv:0x%x\n", irv);
if(irv != 0xf)
hal_data->version_id.CUTVersion = irv;
}
#endif
ret = _SUCCESS;
exit:
return ret;
}
int hal_read_mac_hidden_rpt(_adapter *adapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
int ret = _FAIL;
int ret_fwdl;
u8 mac_hidden_rpt[MAC_HIDDEN_RPT_LEN + MAC_HIDDEN_RPT_2_LEN] = {0};
systime start = rtw_get_current_time();
u32 cnt = 0;
u32 timeout_ms = 800;
u32 min_cnt = 10;
u8 id = C2H_DEFEATURE_RSVD;
int i;
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
u8 hci_type = rtw_get_intf_type(adapter);
if ((hci_type == RTW_USB || hci_type == RTW_PCIE)
&& !rtw_is_hw_init_completed(adapter))
rtw_hal_power_on(adapter);
#endif
/* inform FW mac hidden rpt from reg is needed */
rtw_write8(adapter, REG_C2HEVT_MSG_NORMAL, C2H_DEFEATURE_RSVD);
/* download FW */
pHalData->not_xmitframe_fw_dl = 1;
ret_fwdl = rtw_hal_fw_dl(adapter, _FALSE);
pHalData->not_xmitframe_fw_dl = 0;
if (ret_fwdl != _SUCCESS)
goto mac_hidden_rpt_hdl;
/* polling for data ready */
start = rtw_get_current_time();
do {
cnt++;
id = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL);
if (id == C2H_MAC_HIDDEN_RPT || RTW_CANNOT_IO(adapter))
break;
rtw_msleep_os(10);
} while (rtw_get_passing_time_ms(start) < timeout_ms || cnt < min_cnt);
if (id == C2H_MAC_HIDDEN_RPT) {
/* read data */
for (i = 0; i < MAC_HIDDEN_RPT_LEN + MAC_HIDDEN_RPT_2_LEN; i++)
mac_hidden_rpt[i] = rtw_read8(adapter, REG_C2HEVT_MSG_NORMAL + 2 + i);
}
/* inform FW mac hidden rpt has read */
rtw_write8(adapter, REG_C2HEVT_MSG_NORMAL, C2H_DBG);
mac_hidden_rpt_hdl:
c2h_mac_hidden_rpt_hdl(adapter, mac_hidden_rpt, MAC_HIDDEN_RPT_LEN);
c2h_mac_hidden_rpt_2_hdl(adapter, mac_hidden_rpt + MAC_HIDDEN_RPT_LEN, MAC_HIDDEN_RPT_2_LEN);
if (ret_fwdl == _SUCCESS && id == C2H_MAC_HIDDEN_RPT)
ret = _SUCCESS;
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
if ((hci_type == RTW_USB || hci_type == RTW_PCIE)
&& !rtw_is_hw_init_completed(adapter))
rtw_hal_power_off(adapter);
#endif
RTW_INFO("%s %s! (%u, %dms), fwdl:%d, id:0x%02x\n", __func__
, (ret == _SUCCESS) ? "OK" : "Fail", cnt, rtw_get_passing_time_ms(start), ret_fwdl, id);
return ret;
}
#endif /* CONFIG_RTW_MAC_HIDDEN_RPT */
int c2h_defeature_dbg_hdl(_adapter *adapter, u8 *data, u8 len)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
int ret = _FAIL;
int i;
if (len < DEFEATURE_DBG_LEN) {
RTW_WARN("%s len(%u) < %d\n", __func__, len, DEFEATURE_DBG_LEN);
goto exit;
}
for (i = 0; i < len; i++)
RTW_PRINT("%s: 0x%02X\n", __func__, *(data + i));
ret = _SUCCESS;
exit:
return ret;
}
#ifndef DBG_CUSTOMER_STR_RPT_HANDLE
#define DBG_CUSTOMER_STR_RPT_HANDLE 0
#endif
#ifdef CONFIG_RTW_CUSTOMER_STR
s32 rtw_hal_h2c_customer_str_req(_adapter *adapter)
{
u8 h2c_data[H2C_CUSTOMER_STR_REQ_LEN] = {0};
SET_H2CCMD_CUSTOMER_STR_REQ_EN(h2c_data, 1);
return rtw_hal_fill_h2c_cmd(adapter, H2C_CUSTOMER_STR_REQ, H2C_CUSTOMER_STR_REQ_LEN, h2c_data);
}
#define C2H_CUSTOMER_STR_RPT_BYTE0(_data) ((u8 *)(_data))
#define C2H_CUSTOMER_STR_RPT_2_BYTE8(_data) ((u8 *)(_data))
int c2h_customer_str_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
int ret = _FAIL;
int i;
if (len < CUSTOMER_STR_RPT_LEN) {
RTW_WARN("%s len(%u) < %d\n", __func__, len, CUSTOMER_STR_RPT_LEN);
goto exit;
}
if (DBG_CUSTOMER_STR_RPT_HANDLE)
RTW_PRINT_DUMP("customer_str_rpt: ", data, CUSTOMER_STR_RPT_LEN);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
if (dvobj->customer_str_sctx != NULL) {
if (dvobj->customer_str_sctx->status != RTW_SCTX_SUBMITTED)
RTW_WARN("%s invalid sctx.status:%d\n", __func__, dvobj->customer_str_sctx->status);
_rtw_memcpy(dvobj->customer_str, C2H_CUSTOMER_STR_RPT_BYTE0(data), CUSTOMER_STR_RPT_LEN);
dvobj->customer_str_sctx->status = RTX_SCTX_CSTR_WAIT_RPT2;
} else
RTW_WARN("%s sctx not set\n", __func__);
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
ret = _SUCCESS;
exit:
return ret;
}
int c2h_customer_str_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
int ret = _FAIL;
int i;
if (len < CUSTOMER_STR_RPT_2_LEN) {
RTW_WARN("%s len(%u) < %d\n", __func__, len, CUSTOMER_STR_RPT_2_LEN);
goto exit;
}
if (DBG_CUSTOMER_STR_RPT_HANDLE)
RTW_PRINT_DUMP("customer_str_rpt_2: ", data, CUSTOMER_STR_RPT_2_LEN);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
if (dvobj->customer_str_sctx != NULL) {
if (dvobj->customer_str_sctx->status != RTX_SCTX_CSTR_WAIT_RPT2)
RTW_WARN("%s rpt not ready\n", __func__);
_rtw_memcpy(dvobj->customer_str + CUSTOMER_STR_RPT_LEN, C2H_CUSTOMER_STR_RPT_2_BYTE8(data), CUSTOMER_STR_RPT_2_LEN);
rtw_sctx_done(&dvobj->customer_str_sctx);
} else
RTW_WARN("%s sctx not set\n", __func__);
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
ret = _SUCCESS;
exit:
return ret;
}
/* read customer str */
s32 rtw_hal_customer_str_read(_adapter *adapter, u8 *cs)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct submit_ctx sctx;
s32 ret = _SUCCESS;
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
if (dvobj->customer_str_sctx != NULL)
ret = _FAIL;
else {
rtw_sctx_init(&sctx, 2 * 1000);
dvobj->customer_str_sctx = &sctx;
}
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
if (ret == _FAIL) {
RTW_WARN("%s another handle ongoing\n", __func__);
goto exit;
}
ret = rtw_customer_str_req_cmd(adapter);
if (ret != _SUCCESS) {
RTW_WARN("%s read cmd fail\n", __func__);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
dvobj->customer_str_sctx = NULL;
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
goto exit;
}
/* wait till rpt done or timeout */
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
dvobj->customer_str_sctx = NULL;
if (sctx.status == RTW_SCTX_DONE_SUCCESS)
_rtw_memcpy(cs, dvobj->customer_str, RTW_CUSTOMER_STR_LEN);
else
ret = _FAIL;
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
exit:
return ret;
}
s32 rtw_hal_h2c_customer_str_write(_adapter *adapter, const u8 *cs)
{
u8 h2c_data_w1[H2C_CUSTOMER_STR_W1_LEN] = {0};
u8 h2c_data_w2[H2C_CUSTOMER_STR_W2_LEN] = {0};
u8 h2c_data_w3[H2C_CUSTOMER_STR_W3_LEN] = {0};
s32 ret;
SET_H2CCMD_CUSTOMER_STR_W1_EN(h2c_data_w1, 1);
_rtw_memcpy(H2CCMD_CUSTOMER_STR_W1_BYTE0(h2c_data_w1), cs, 6);
SET_H2CCMD_CUSTOMER_STR_W2_EN(h2c_data_w2, 1);
_rtw_memcpy(H2CCMD_CUSTOMER_STR_W2_BYTE6(h2c_data_w2), cs + 6, 6);
SET_H2CCMD_CUSTOMER_STR_W3_EN(h2c_data_w3, 1);
_rtw_memcpy(H2CCMD_CUSTOMER_STR_W3_BYTE12(h2c_data_w3), cs + 6 + 6, 4);
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_CUSTOMER_STR_W1, H2C_CUSTOMER_STR_W1_LEN, h2c_data_w1);
if (ret != _SUCCESS) {
RTW_WARN("%s w1 fail\n", __func__);
goto exit;
}
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_CUSTOMER_STR_W2, H2C_CUSTOMER_STR_W2_LEN, h2c_data_w2);
if (ret != _SUCCESS) {
RTW_WARN("%s w2 fail\n", __func__);
goto exit;
}
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_CUSTOMER_STR_W3, H2C_CUSTOMER_STR_W3_LEN, h2c_data_w3);
if (ret != _SUCCESS) {
RTW_WARN("%s w3 fail\n", __func__);
goto exit;
}
exit:
return ret;
}
/* write customer str and check if value reported is the same as requested */
s32 rtw_hal_customer_str_write(_adapter *adapter, const u8 *cs)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct submit_ctx sctx;
s32 ret = _SUCCESS;
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
if (dvobj->customer_str_sctx != NULL)
ret = _FAIL;
else {
rtw_sctx_init(&sctx, 2 * 1000);
dvobj->customer_str_sctx = &sctx;
}
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
if (ret == _FAIL) {
RTW_WARN("%s another handle ongoing\n", __func__);
goto exit;
}
ret = rtw_customer_str_write_cmd(adapter, cs);
if (ret != _SUCCESS) {
RTW_WARN("%s write cmd fail\n", __func__);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
dvobj->customer_str_sctx = NULL;
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
goto exit;
}
ret = rtw_customer_str_req_cmd(adapter);
if (ret != _SUCCESS) {
RTW_WARN("%s read cmd fail\n", __func__);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
dvobj->customer_str_sctx = NULL;
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
goto exit;
}
/* wait till rpt done or timeout */
rtw_sctx_wait(&sctx, __func__);
_enter_critical_mutex(&dvobj->customer_str_mutex, NULL);
dvobj->customer_str_sctx = NULL;
if (sctx.status == RTW_SCTX_DONE_SUCCESS) {
if (_rtw_memcmp(cs, dvobj->customer_str, RTW_CUSTOMER_STR_LEN) != _TRUE) {
RTW_WARN("%s read back check fail\n", __func__);
RTW_INFO_DUMP("write req: ", cs, RTW_CUSTOMER_STR_LEN);
RTW_INFO_DUMP("read back: ", dvobj->customer_str, RTW_CUSTOMER_STR_LEN);
ret = _FAIL;
}
} else
ret = _FAIL;
_exit_critical_mutex(&dvobj->customer_str_mutex, NULL);
exit:
return ret;
}
#endif /* CONFIG_RTW_CUSTOMER_STR */
#ifdef RTW_PER_CMD_SUPPORT_FW
#define H2C_REQ_PER_RPT_LEN 5
#define SET_H2CCMD_REQ_PER_RPT_GROUP_MACID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
#define SET_H2CCMD_REQ_PER_RPT_RPT_TYPE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
#define SET_H2CCMD_REQ_PER_RPT_MACID_BMAP(__pH2CCmd, __Value) SET_BITS_TO_LE_4BYTE(__pH2CCmd + 1, 0, 32, __Value)
u8 rtw_hal_set_req_per_rpt_cmd(_adapter *adapter, u8 group_macid,
u8 rpt_type, u32 macid_bitmap)
{
u8 ret = _FAIL;
u8 cmd_buf[H2C_REQ_PER_RPT_LEN] = {0};
SET_H2CCMD_REQ_PER_RPT_GROUP_MACID(cmd_buf, group_macid);
SET_H2CCMD_REQ_PER_RPT_RPT_TYPE(cmd_buf, rpt_type);
SET_H2CCMD_REQ_PER_RPT_MACID_BMAP(cmd_buf, macid_bitmap);
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_REQ_PER_RPT,
H2C_REQ_PER_RPT_LEN,
cmd_buf);
return ret;
}
#define GET_C2H_PER_RATE_RPT_TYPE0_MACID0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)), 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE0_PER0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE0_RATE0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE0_BW0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 3, 0, 2)
#define GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT0(_data) LE_BITS_TO_2BYTE(((u8 *)(_data)) + 4, 0, 16)
#define GET_C2H_PER_RATE_RPT_TYPE0_MACID1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE0_PER1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE0_RATE1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 8, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE0_BW1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 9, 0, 2)
#define GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT1(_data) LE_BITS_TO_2BYTE(((u8 *)(_data)) + 10, 0, 16)
#define GET_C2H_PER_RATE_RPT_TYPE1_MACID0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)), 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_PER0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 1, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_RATE0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 2, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_BW0(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 3, 0, 2)
#define GET_C2H_PER_RATE_RPT_TYPE1_MACID1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 4, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_PER1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 5, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_RATE1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 6, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_BW1(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 7, 0, 2)
#define GET_C2H_PER_RATE_RPT_TYPE1_MACID2(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 8, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_PER2(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 9, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_RATE2(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 10, 0, 8)
#define GET_C2H_PER_RATE_RPT_TYPE1_BW2(_data) LE_BITS_TO_1BYTE(((u8 *)(_data)) + 11, 0, 2)
static void per_rate_rpt_update(_adapter *adapter, u8 mac_id,
u8 per, u8 rate,
u8 bw, u8 total_pkt)
{
#ifdef CONFIG_RTW_MESH
rtw_ieee80211s_update_metric(adapter, mac_id,
per, rate,
bw, total_pkt);
#endif
}
int c2h_per_rate_rpt_hdl(_adapter *adapter, u8 *data, u8 len)
{
/* Now only consider type0, since it covers all params in type1
* type0: mac_id, per, rate, bw, total_pkt
* type1: mac_id, per, rate, bw
*/
u8 mac_id[2] = {0}, per[2] = {0}, rate[2] = {0}, bw[2] = {0};
u16 total_pkt[2] = {0};
int ret = _FAIL, i, macid_cnt = 0;
/* type0:
* 1 macid includes 6 bytes info + 1 byte 0xff
* 2 macid includes 2*6 bytes info
*/
if (!(len == 7 || len == 12)) {
RTW_WARN("%s len(%u) != 7 or 12\n", __FUNCTION__, len);
goto exit;
}
macid_cnt++;
mac_id[0] = GET_C2H_PER_RATE_RPT_TYPE0_MACID0(data);
per[0] = GET_C2H_PER_RATE_RPT_TYPE0_PER0(data);
rate[0] = GET_C2H_PER_RATE_RPT_TYPE0_RATE0(data);
bw[0] = GET_C2H_PER_RATE_RPT_TYPE0_BW0(data);
total_pkt[0] = GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT0(data);
mac_id[1] = GET_C2H_PER_RATE_RPT_TYPE0_MACID1(data);
/* 0xff means no report anymore */
if (mac_id[1] == 0xff)
goto update_per;
if (len != 12) {
RTW_WARN("%s incorrect format\n", __FUNCTION__);
goto exit;
}
macid_cnt++;
per[1] = GET_C2H_PER_RATE_RPT_TYPE0_PER1(data);
rate[1] = GET_C2H_PER_RATE_RPT_TYPE0_RATE1(data);
bw[1] = GET_C2H_PER_RATE_RPT_TYPE0_BW1(data);
total_pkt[1] = GET_C2H_PER_RATE_RPT_TYPE0_TOTAL_PKT1(data);
update_per:
for (i = 0; i < macid_cnt; i++) {
RTW_DBG("[%s] type0 rpt[%d]: macid = %u, per = %u, "
"rate = %u, bw = %u, total_pkt = %u\n",
__FUNCTION__, i, mac_id[i], per[i],
rate[i], bw[i], total_pkt[i]);
per_rate_rpt_update(adapter, mac_id[i],
per[i], rate[i],
bw[i], total_pkt[i]);
}
ret = _SUCCESS;
exit:
return ret;
}
#endif /* RTW_PER_CMD_SUPPORT_FW */
void rtw_hal_update_sta_wset(_adapter *adapter, struct sta_info *psta)
{
u8 w_set = 0;
if (psta->wireless_mode & WIRELESS_11B)
w_set |= WIRELESS_CCK;
if ((psta->wireless_mode & WIRELESS_11G) || (psta->wireless_mode & WIRELESS_11A))
w_set |= WIRELESS_OFDM;
if (psta->wireless_mode & WIRELESS_11_24N)
w_set |= WIRELESS_HT;
if ((psta->wireless_mode & WIRELESS_11AC) || (psta->wireless_mode & WIRELESS_11_5N))
w_set |= WIRELESS_VHT;
psta->cmn.support_wireless_set = w_set;
}
void rtw_hal_update_sta_mimo_type(_adapter *adapter, struct sta_info *psta)
{
s8 tx_nss, rx_nss;
tx_nss = rtw_get_sta_tx_nss(adapter, psta);
rx_nss = rtw_get_sta_rx_nss(adapter, psta);
if ((tx_nss == 1) && (rx_nss == 1))
psta->cmn.mimo_type = RF_1T1R;
else if ((tx_nss == 1) && (rx_nss == 2))
psta->cmn.mimo_type = RF_1T2R;
else if ((tx_nss == 2) && (rx_nss == 2))
psta->cmn.mimo_type = RF_2T2R;
else if ((tx_nss == 2) && (rx_nss == 3))
psta->cmn.mimo_type = RF_2T3R;
else if ((tx_nss == 2) && (rx_nss == 4))
psta->cmn.mimo_type = RF_2T4R;
else if ((tx_nss == 3) && (rx_nss == 3))
psta->cmn.mimo_type = RF_3T3R;
else if ((tx_nss == 3) && (rx_nss == 4))
psta->cmn.mimo_type = RF_3T4R;
else if ((tx_nss == 4) && (rx_nss == 4))
psta->cmn.mimo_type = RF_4T4R;
else
rtw_warn_on(1);
#ifdef CONFIG_CTRL_TXSS_BY_TP
rtw_ctrl_txss_update_mimo_type(adapter, psta);
#endif
RTW_INFO("STA - MAC_ID:%d, Tx - %d SS, Rx - %d SS\n",
psta->cmn.mac_id, tx_nss, rx_nss);
}
void rtw_hal_update_sta_smps_cap(_adapter *adapter, struct sta_info *psta)
{
/*Spatial Multiplexing Power Save*/
#if 0
if (check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE) {
#ifdef CONFIG_80211N_HT
if (psta->htpriv.ht_option) {
if (psta->htpriv.smps_cap == 0)
psta->cmn.sm_ps = SM_PS_STATIC;
else if (psta->htpriv.smps_cap == 1)
psta->cmn.sm_ps = SM_PS_DYNAMIC;
else
psta->cmn.sm_ps = SM_PS_DISABLE;
}
#endif /* CONFIG_80211N_HT */
} else
#endif
psta->cmn.sm_ps = SM_PS_DISABLE;
RTW_INFO("STA - MAC_ID:%d, SM_PS %d\n",
psta->cmn.mac_id, psta->cmn.sm_ps);
}
u8 rtw_get_mgntframe_raid(_adapter *adapter, unsigned char network_type)
{
u8 raid;
if (IS_NEW_GENERATION_IC(adapter)) {
raid = (network_type & WIRELESS_11B) ? RATEID_IDX_B
: RATEID_IDX_G;
} else {
raid = (network_type & WIRELESS_11B) ? RATR_INX_WIRELESS_B
: RATR_INX_WIRELESS_G;
}
return raid;
}
void rtw_hal_update_sta_rate_mask(PADAPTER padapter, struct sta_info *psta)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
u8 i, rf_type, tx_nss;
u64 tx_ra_bitmap = 0, tmp64=0;
if (psta == NULL)
return;
/* b/g mode ra_bitmap */
for (i = 0; i < sizeof(psta->bssrateset); i++) {
if (psta->bssrateset[i])
tx_ra_bitmap |= rtw_get_bit_value_from_ieee_value(psta->bssrateset[i] & 0x7f);
}
#ifdef CONFIG_80211N_HT
if (padapter->registrypriv.ht_enable && is_supported_ht(padapter->registrypriv.wireless_mode)) {
rtw_hal_get_hwreg(padapter, HW_VAR_RF_TYPE, (u8 *)(&rf_type));
tx_nss = rtw_min(rf_type_to_rf_tx_cnt(rf_type), hal_spec->tx_nss_num);
#ifdef CONFIG_80211AC_VHT
if (psta->vhtpriv.vht_option) {
/* AC mode ra_bitmap */
tx_ra_bitmap |= (rtw_vht_mcs_map_to_bitmap(psta->vhtpriv.vht_mcs_map, tx_nss) << 12);
} else
#endif /* CONFIG_80211AC_VHT */
if (psta->htpriv.ht_option) {
/* n mode ra_bitmap */
/* Handling SMPS mode for AP MODE only*/
if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == _TRUE) {
/*0:static SMPS, 1:dynamic SMPS, 3:SMPS disabled, 2:reserved*/
if (psta->htpriv.smps_cap == 0 || psta->htpriv.smps_cap == 1) {
/*operate with only one active receive chain // 11n-MCS rate <= MSC7*/
tx_nss = rtw_min(tx_nss, 1);
}
}
tmp64 = rtw_ht_mcs_set_to_bitmap(psta->htpriv.ht_cap.supp_mcs_set, tx_nss);
tx_ra_bitmap |= (tmp64 << 12);
}
}
#endif /* CONFIG_80211N_HT */
psta->cmn.ra_info.ramask = tx_ra_bitmap;
psta->init_rate = get_highest_rate_idx(tx_ra_bitmap) & 0x3f;
}
void rtw_hal_update_sta_ra_info(PADAPTER padapter, struct sta_info *psta)
{
rtw_hal_update_sta_mimo_type(padapter, psta);
rtw_hal_update_sta_smps_cap(padapter, psta);
rtw_hal_update_sta_rate_mask(padapter, psta);
}
static u32 hw_bcn_ctrl_addr(_adapter *adapter, u8 hw_port)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
if (hw_port >= hal_spec->port_num) {
RTW_ERR(FUNC_ADPT_FMT" HW Port(%d) invalid\n", FUNC_ADPT_ARG(adapter), hw_port);
rtw_warn_on(1);
return 0;
}
switch (hw_port) {
case HW_PORT0:
return REG_BCN_CTRL;
case HW_PORT1:
return REG_BCN_CTRL_1;
}
return 0;
}
static void rtw_hal_get_msr(_adapter *adapter, u8 *net_type)
{
#ifdef RTW_HALMAC
rtw_halmac_get_network_type(adapter_to_dvobj(adapter),
adapter->hw_port, net_type);
#else /* !RTW_HALMAC */
switch (adapter->hw_port) {
case HW_PORT0:
/*REG_CR - BIT[17:16]-Network Type for port 1*/
*net_type = rtw_read8(adapter, MSR) & 0x03;
break;
case HW_PORT1:
/*REG_CR - BIT[19:18]-Network Type for port 1*/
*net_type = (rtw_read8(adapter, MSR) & 0x0C) >> 2;
break;
#if defined(CONFIG_RTL8814A)
case HW_PORT2:
/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
*net_type = rtw_read8(adapter, MSR1) & 0x03;
break;
case HW_PORT3:
/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
*net_type = (rtw_read8(adapter, MSR1) & 0x0C) >> 2;
break;
case HW_PORT4:
/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
*net_type = (rtw_read8(adapter, MSR1) & 0x30) >> 4;
break;
#endif /*#if defined(CONFIG_RTL8814A)*/
default:
RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
ADPT_ARG(adapter), adapter->hw_port);
rtw_warn_on(1);
break;
}
#endif /* !RTW_HALMAC */
}
#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM) /*For 2 hw ports - 88E/92E/8812/8821/8723B*/
static u8 rtw_hal_net_type_decision(_adapter *adapter, u8 net_type)
{
if ((adapter->hw_port == HW_PORT0) && (rtw_get_mbid_cam_entry_num(adapter))) {
if (net_type != _HW_STATE_NOLINK_)
return _HW_STATE_AP_;
}
return net_type;
}
#endif
static void rtw_hal_set_msr(_adapter *adapter, u8 net_type)
{
#ifdef RTW_HALMAC
#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
net_type = rtw_hal_net_type_decision(adapter, net_type);
#endif
rtw_halmac_set_network_type(adapter_to_dvobj(adapter),
adapter->hw_port, net_type);
#else /* !RTW_HALMAC */
u8 val8 = 0;
switch (adapter->hw_port) {
case HW_PORT0:
#if defined(CONFIG_MI_WITH_MBSSID_CAM) && defined(CONFIG_MBSSID_CAM)
net_type = rtw_hal_net_type_decision(adapter, net_type);
#endif
/*REG_CR - BIT[17:16]-Network Type for port 0*/
val8 = rtw_read8(adapter, MSR) & 0x0C;
val8 |= net_type;
rtw_write8(adapter, MSR, val8);
break;
case HW_PORT1:
/*REG_CR - BIT[19:18]-Network Type for port 1*/
val8 = rtw_read8(adapter, MSR) & 0x03;
val8 |= net_type << 2;
rtw_write8(adapter, MSR, val8);
break;
#if defined(CONFIG_RTL8814A)
case HW_PORT2:
/*REG_CR_EXT- BIT[1:0]-Network Type for port 2*/
val8 = rtw_read8(adapter, MSR1) & 0xFC;
val8 |= net_type;
rtw_write8(adapter, MSR1, val8);
break;
case HW_PORT3:
/*REG_CR_EXT- BIT[3:2]-Network Type for port 3*/
val8 = rtw_read8(adapter, MSR1) & 0xF3;
val8 |= net_type << 2;
rtw_write8(adapter, MSR1, val8);
break;
case HW_PORT4:
/*REG_CR_EXT- BIT[5:4]-Network Type for port 4*/
val8 = rtw_read8(adapter, MSR1) & 0xCF;
val8 |= net_type << 4;
rtw_write8(adapter, MSR1, val8);
break;
#endif /* CONFIG_RTL8814A */
default:
RTW_INFO("[WARN] "ADPT_FMT"- invalid hw port -%d\n",
ADPT_ARG(adapter), adapter->hw_port);
rtw_warn_on(1);
break;
}
#endif /* !RTW_HALMAC */
}
#ifndef SEC_CAM_ACCESS_TIMEOUT_MS
#define SEC_CAM_ACCESS_TIMEOUT_MS 200
#endif
#ifndef DBG_SEC_CAM_ACCESS
#define DBG_SEC_CAM_ACCESS 0
#endif
u32 rtw_sec_read_cam(_adapter *adapter, u8 addr)
{
_mutex *mutex = &adapter_to_dvobj(adapter)->cam_ctl.sec_cam_access_mutex;
u32 rdata;
u32 cnt = 0;
systime start = 0, end = 0;
u8 timeout = 0;
u8 sr = 0;
_enter_critical_mutex(mutex, NULL);
rtw_write32(adapter, REG_CAMCMD, CAM_POLLINIG | addr);
start = rtw_get_current_time();
while (1) {
if (rtw_is_surprise_removed(adapter)) {
sr = 1;
break;
}
cnt++;
if (0 == (rtw_read32(adapter, REG_CAMCMD) & CAM_POLLINIG))
break;
if (rtw_get_passing_time_ms(start) > SEC_CAM_ACCESS_TIMEOUT_MS) {
timeout = 1;
break;
}
}
end = rtw_get_current_time();
rdata = rtw_read32(adapter, REG_CAMREAD);
_exit_critical_mutex(mutex, NULL);
if (DBG_SEC_CAM_ACCESS || timeout) {
RTW_INFO(FUNC_ADPT_FMT" addr:0x%02x, rdata:0x%08x, to:%u, polling:%u, %d ms\n"
, FUNC_ADPT_ARG(adapter), addr, rdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
}
return rdata;
}
void rtw_sec_write_cam(_adapter *adapter, u8 addr, u32 wdata)
{
_mutex *mutex = &adapter_to_dvobj(adapter)->cam_ctl.sec_cam_access_mutex;
u32 cnt = 0;
systime start = 0, end = 0;
u8 timeout = 0;
u8 sr = 0;
_enter_critical_mutex(mutex, NULL);
rtw_write32(adapter, REG_CAMWRITE, wdata);
rtw_write32(adapter, REG_CAMCMD, CAM_POLLINIG | CAM_WRITE | addr);
start = rtw_get_current_time();
while (1) {
if (rtw_is_surprise_removed(adapter)) {
sr = 1;
break;
}
cnt++;
if (0 == (rtw_read32(adapter, REG_CAMCMD) & CAM_POLLINIG))
break;
if (rtw_get_passing_time_ms(start) > SEC_CAM_ACCESS_TIMEOUT_MS) {
timeout = 1;
break;
}
}
end = rtw_get_current_time();
_exit_critical_mutex(mutex, NULL);
if (DBG_SEC_CAM_ACCESS || timeout) {
RTW_INFO(FUNC_ADPT_FMT" addr:0x%02x, wdata:0x%08x, to:%u, polling:%u, %d ms\n"
, FUNC_ADPT_ARG(adapter), addr, wdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
}
}
void rtw_sec_read_cam_ent(_adapter *adapter, u8 id, u8 *ctrl, u8 *mac, u8 *key)
{
unsigned int val, addr;
u8 i;
u32 rdata;
u8 begin = 0;
u8 end = 5; /* TODO: consider other key length accordingly */
if (!ctrl && !mac && !key) {
rtw_warn_on(1);
goto exit;
}
/* TODO: check id range */
if (!ctrl && !mac)
begin = 2; /* read from key */
if (!key && !mac)
end = 0; /* read to ctrl */
else if (!key)
end = 2; /* read to mac */
for (i = begin; i <= end; i++) {
rdata = rtw_sec_read_cam(adapter, (id << 3) | i);
switch (i) {
case 0:
if (ctrl)
_rtw_memcpy(ctrl, (u8 *)(&rdata), 2);
if (mac)
_rtw_memcpy(mac, ((u8 *)(&rdata)) + 2, 2);
break;
case 1:
if (mac)
_rtw_memcpy(mac + 2, (u8 *)(&rdata), 4);
break;
default:
if (key)
_rtw_memcpy(key + (i - 2) * 4, (u8 *)(&rdata), 4);
break;
}
}
exit:
return;
}
void rtw_sec_write_cam_ent(_adapter *adapter, u8 id, u16 ctrl, u8 *mac, u8 *key)
{
unsigned int i;
int j;
u8 addr, addr1 = 0;
u32 wdata, wdata1 = 0;
/* TODO: consider other key length accordingly */
#if 0
switch ((ctrl & 0x1c) >> 2) {
case _WEP40_:
case _TKIP_:
case _AES_:
case _WEP104_:
}
#else
j = 7;
#endif
for (; j >= 0; j--) {
switch (j) {
case 0:
wdata = (ctrl | (mac[0] << 16) | (mac[1] << 24));
break;
case 1:
wdata = (mac[2] | (mac[3] << 8) | (mac[4] << 16) | (mac[5] << 24));
break;
case 6:
case 7:
wdata = 0;
break;
default:
i = (j - 2) << 2;
wdata = (key[i] | (key[i + 1] << 8) | (key[i + 2] << 16) | (key[i + 3] << 24));
break;
}
addr = (id << 3) + j;
#if defined(CONFIG_RTL8192F)
if(j == 1) {
wdata1 = wdata;
addr1 = addr;
continue;
}
#endif
rtw_sec_write_cam(adapter, addr, wdata);
}
#if defined(CONFIG_RTL8192F)
rtw_sec_write_cam(adapter, addr1, wdata1);
#endif
}
void rtw_sec_clr_cam_ent(_adapter *adapter, u8 id)
{
u8 addr;
addr = (id << 3);
rtw_sec_write_cam(adapter, addr, 0);
}
bool rtw_sec_read_cam_is_gk(_adapter *adapter, u8 id)
{
bool res;
u16 ctrl;
rtw_sec_read_cam_ent(adapter, id, (u8 *)&ctrl, NULL, NULL);
res = (ctrl & BIT6) ? _TRUE : _FALSE;
return res;
}
#ifdef CONFIG_MBSSID_CAM
void rtw_mbid_cam_init(struct dvobj_priv *dvobj)
{
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_rtw_spinlock_init(&mbid_cam_ctl->lock);
mbid_cam_ctl->bitmap = 0;
ATOMIC_SET(&mbid_cam_ctl->mbid_entry_num, 0);
_rtw_memset(&dvobj->mbid_cam_cache, 0, sizeof(dvobj->mbid_cam_cache));
}
void rtw_mbid_cam_deinit(struct dvobj_priv *dvobj)
{
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_rtw_spinlock_free(&mbid_cam_ctl->lock);
}
void rtw_mbid_cam_reset(_adapter *adapter)
{
_irqL irqL;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
mbid_cam_ctl->bitmap = 0;
_rtw_memset(&dvobj->mbid_cam_cache, 0, sizeof(dvobj->mbid_cam_cache));
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
ATOMIC_SET(&mbid_cam_ctl->mbid_entry_num, 0);
}
static u8 _rtw_mbid_cam_search_by_macaddr(_adapter *adapter, u8 *mac_addr)
{
u8 i;
u8 cam_id = INVALID_CAM_ID;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
if (mac_addr && _rtw_memcmp(dvobj->mbid_cam_cache[i].mac_addr, mac_addr, ETH_ALEN) == _TRUE) {
cam_id = i;
break;
}
}
RTW_INFO("%s mac:"MAC_FMT" - cam_id:%d\n", __func__, MAC_ARG(mac_addr), cam_id);
return cam_id;
}
u8 rtw_mbid_cam_search_by_macaddr(_adapter *adapter, u8 *mac_addr)
{
_irqL irqL;
u8 cam_id = INVALID_CAM_ID;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
cam_id = _rtw_mbid_cam_search_by_macaddr(adapter, mac_addr);
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
return cam_id;
}
static u8 _rtw_mbid_cam_search_by_ifaceid(_adapter *adapter, u8 iface_id)
{
u8 i;
u8 cam_id = INVALID_CAM_ID;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
if (iface_id == dvobj->mbid_cam_cache[i].iface_id) {
cam_id = i;
break;
}
}
if (cam_id != INVALID_CAM_ID)
RTW_INFO("%s iface_id:%d mac:"MAC_FMT" - cam_id:%d\n",
__func__, iface_id, MAC_ARG(dvobj->mbid_cam_cache[cam_id].mac_addr), cam_id);
return cam_id;
}
u8 rtw_mbid_cam_search_by_ifaceid(_adapter *adapter, u8 iface_id)
{
_irqL irqL;
u8 cam_id = INVALID_CAM_ID;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
cam_id = _rtw_mbid_cam_search_by_ifaceid(adapter, iface_id);
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
return cam_id;
}
u8 rtw_get_max_mbid_cam_id(_adapter *adapter)
{
_irqL irqL;
s8 i;
u8 cam_id = INVALID_CAM_ID;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
for (i = (TOTAL_MBID_CAM_NUM - 1); i >= 0; i--) {
if (mbid_cam_ctl->bitmap & BIT(i)) {
cam_id = i;
break;
}
}
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
/*RTW_INFO("%s max cam_id:%d\n", __func__, cam_id);*/
return cam_id;
}
inline u8 rtw_get_mbid_cam_entry_num(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
return ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
}
static inline void mbid_cam_cache_init(_adapter *adapter, struct mbid_cam_cache *pmbid_cam, u8 *mac_addr)
{
if (adapter && pmbid_cam && mac_addr) {
_rtw_memcpy(pmbid_cam->mac_addr, mac_addr, ETH_ALEN);
pmbid_cam->iface_id = adapter->iface_id;
}
}
static inline void mbid_cam_cache_clr(struct mbid_cam_cache *pmbid_cam)
{
if (pmbid_cam) {
_rtw_memset(pmbid_cam->mac_addr, 0, ETH_ALEN);
pmbid_cam->iface_id = CONFIG_IFACE_NUMBER;
}
}
u8 rtw_mbid_camid_alloc(_adapter *adapter, u8 *mac_addr)
{
_irqL irqL;
u8 cam_id = INVALID_CAM_ID, i;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
u8 entry_num = ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
if (INVALID_CAM_ID != rtw_mbid_cam_search_by_macaddr(adapter, mac_addr))
goto exit;
if (entry_num >= TOTAL_MBID_CAM_NUM) {
RTW_INFO(FUNC_ADPT_FMT" failed !! MBSSID number :%d over TOTAL_CAM_ENTRY(8)\n", FUNC_ADPT_ARG(adapter), entry_num);
rtw_warn_on(1);
}
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
if (!(mbid_cam_ctl->bitmap & BIT(i))) {
mbid_cam_ctl->bitmap |= BIT(i);
cam_id = i;
break;
}
}
if ((cam_id != INVALID_CAM_ID) && (mac_addr))
mbid_cam_cache_init(adapter, &dvobj->mbid_cam_cache[cam_id], mac_addr);
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
if (cam_id != INVALID_CAM_ID) {
ATOMIC_INC(&mbid_cam_ctl->mbid_entry_num);
RTW_INFO("%s mac:"MAC_FMT" - cam_id:%d\n", __func__, MAC_ARG(mac_addr), cam_id);
#ifdef DBG_MBID_CAM_DUMP
rtw_mbid_cam_cache_dump(RTW_DBGDUMP, __func__, adapter);
#endif
} else
RTW_INFO("%s [WARN] "MAC_FMT" - invalid cam_id:%d\n", __func__, MAC_ARG(mac_addr), cam_id);
exit:
return cam_id;
}
u8 rtw_mbid_cam_info_change(_adapter *adapter, u8 *mac_addr)
{
_irqL irqL;
u8 entry_id = INVALID_CAM_ID;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
entry_id = _rtw_mbid_cam_search_by_ifaceid(adapter, adapter->iface_id);
if (entry_id != INVALID_CAM_ID)
mbid_cam_cache_init(adapter, &dvobj->mbid_cam_cache[entry_id], mac_addr);
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
return entry_id;
}
u8 rtw_mbid_cam_assign(_adapter *adapter, u8 *mac_addr, u8 camid)
{
_irqL irqL;
u8 ret = _FALSE;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
if ((camid >= TOTAL_MBID_CAM_NUM) || (camid == INVALID_CAM_ID)) {
RTW_INFO(FUNC_ADPT_FMT" failed !! invlaid mbid_canid :%d\n", FUNC_ADPT_ARG(adapter), camid);
rtw_warn_on(1);
}
if (INVALID_CAM_ID != rtw_mbid_cam_search_by_macaddr(adapter, mac_addr))
goto exit;
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
if (!(mbid_cam_ctl->bitmap & BIT(camid))) {
if (mac_addr) {
mbid_cam_ctl->bitmap |= BIT(camid);
mbid_cam_cache_init(adapter, &dvobj->mbid_cam_cache[camid], mac_addr);
ret = _TRUE;
}
}
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
if (ret == _TRUE) {
ATOMIC_INC(&mbid_cam_ctl->mbid_entry_num);
RTW_INFO("%s mac:"MAC_FMT" - cam_id:%d\n", __func__, MAC_ARG(mac_addr), camid);
#ifdef DBG_MBID_CAM_DUMP
rtw_mbid_cam_cache_dump(RTW_DBGDUMP, __func__, adapter);
#endif
} else
RTW_INFO("%s [WARN] mac:"MAC_FMT" - cam_id:%d assigned failed\n", __func__, MAC_ARG(mac_addr), camid);
exit:
return ret;
}
void rtw_mbid_camid_clean(_adapter *adapter, u8 mbss_canid)
{
_irqL irqL;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
if ((mbss_canid >= TOTAL_MBID_CAM_NUM) || (mbss_canid == INVALID_CAM_ID)) {
RTW_INFO(FUNC_ADPT_FMT" failed !! invlaid mbid_canid :%d\n", FUNC_ADPT_ARG(adapter), mbss_canid);
rtw_warn_on(1);
}
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
mbid_cam_cache_clr(&dvobj->mbid_cam_cache[mbss_canid]);
mbid_cam_ctl->bitmap &= (~BIT(mbss_canid));
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
ATOMIC_DEC(&mbid_cam_ctl->mbid_entry_num);
RTW_INFO("%s - cam_id:%d\n", __func__, mbss_canid);
}
int rtw_mbid_cam_cache_dump(void *sel, const char *fun_name, _adapter *adapter)
{
_irqL irqL;
u8 i;
_adapter *iface;
u8 iface_id;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
u8 entry_num = ATOMIC_READ(&mbid_cam_ctl->mbid_entry_num);
u8 max_cam_id = rtw_get_max_mbid_cam_id(adapter);
RTW_PRINT_SEL(sel, "== MBSSID CAM DUMP (%s)==\n", fun_name);
_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);
RTW_PRINT_SEL(sel, "Entry numbers:%d, max_camid:%d, bitmap:0x%08x\n", entry_num, max_cam_id, mbid_cam_ctl->bitmap);
for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
RTW_PRINT_SEL(sel, "CAM_ID = %d\t", i);
if (mbid_cam_ctl->bitmap & BIT(i)) {
iface_id = dvobj->mbid_cam_cache[i].iface_id;
_RTW_PRINT_SEL(sel, "IF_ID:%d\t", iface_id);
_RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\t", MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
iface = dvobj->padapters[iface_id];
if (iface) {
if (MLME_IS_STA(iface))
_RTW_PRINT_SEL(sel, "ROLE:%s\n", "STA");
else if (MLME_IS_AP(iface))
_RTW_PRINT_SEL(sel, "ROLE:%s\n", "AP");
else if (MLME_IS_MESH(iface))
_RTW_PRINT_SEL(sel, "ROLE:%s\n", "MESH");
else
_RTW_PRINT_SEL(sel, "ROLE:%s\n", "NONE");
}
} else
_RTW_PRINT_SEL(sel, "N/A\n");
}
_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);
return 0;
}
static void read_mbssid_cam(_adapter *padapter, u8 cam_addr, u8 *mac)
{
u8 poll = 1;
u8 cam_ready = _FALSE;
u32 cam_data1 = 0;
u16 cam_data2 = 0;
if (RTW_CANNOT_RUN(padapter))
return;
rtw_write32(padapter, REG_MBIDCAMCFG_2, BIT_MBIDCAM_POLL | ((cam_addr & MBIDCAM_ADDR_MASK) << MBIDCAM_ADDR_SHIFT));
do {
if (0 == (rtw_read32(padapter, REG_MBIDCAMCFG_2) & BIT_MBIDCAM_POLL)) {
cam_ready = _TRUE;
break;
}
poll++;
} while ((poll % 10) != 0 && !RTW_CANNOT_RUN(padapter));
if (cam_ready) {
cam_data1 = rtw_read32(padapter, REG_MBIDCAMCFG_1);
mac[0] = cam_data1 & 0xFF;
mac[1] = (cam_data1 >> 8) & 0xFF;
mac[2] = (cam_data1 >> 16) & 0xFF;
mac[3] = (cam_data1 >> 24) & 0xFF;
cam_data2 = rtw_read16(padapter, REG_MBIDCAMCFG_2);
mac[4] = cam_data2 & 0xFF;
mac[5] = (cam_data2 >> 8) & 0xFF;
}
}
int rtw_mbid_cam_dump(void *sel, const char *fun_name, _adapter *adapter)
{
/*_irqL irqL;*/
u8 i;
u8 mac_addr[ETH_ALEN];
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
RTW_PRINT_SEL(sel, "\n== MBSSID HW-CAM DUMP (%s)==\n", fun_name);
/*_enter_critical_bh(&mbid_cam_ctl->lock, &irqL);*/
for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
RTW_PRINT_SEL(sel, "CAM_ID = %d\t", i);
_rtw_memset(mac_addr, 0, ETH_ALEN);
read_mbssid_cam(adapter, i, mac_addr);
_RTW_PRINT_SEL(sel, "MAC Addr:"MAC_FMT"\n", MAC_ARG(mac_addr));
}
/*_exit_critical_bh(&mbid_cam_ctl->lock, &irqL);*/
return 0;
}
static void write_mbssid_cam(_adapter *padapter, u8 cam_addr, u8 *mac)
{
u32 cam_val[2] = {0};
cam_val[0] = (mac[3] << 24) | (mac[2] << 16) | (mac[1] << 8) | mac[0];
cam_val[1] = ((cam_addr & MBIDCAM_ADDR_MASK) << MBIDCAM_ADDR_SHIFT) | (mac[5] << 8) | mac[4];
rtw_hal_set_hwreg(padapter, HW_VAR_MBSSID_CAM_WRITE, (u8 *)cam_val);
}
/*
static void clear_mbssid_cam(_adapter *padapter, u8 cam_addr)
{
rtw_hal_set_hwreg(padapter, HW_VAR_MBSSID_CAM_CLEAR, &cam_addr);
}
*/
void rtw_ap_set_mbid_num(_adapter *adapter, u8 ap_num)
{
rtw_write8(adapter, REG_MBID_NUM,
((rtw_read8(adapter, REG_MBID_NUM) & 0xF8) | ((ap_num -1) & 0x07)));
}
void rtw_mbid_cam_enable(_adapter *adapter)
{
/*enable MBSSID*/
rtw_hal_rcr_add(adapter, RCR_ENMBID);
}
void rtw_mi_set_mbid_cam(_adapter *adapter)
{
u8 i;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mbid_cam_ctl_t *mbid_cam_ctl = &dvobj->mbid_cam_ctl;
#ifdef DBG_MBID_CAM_DUMP
rtw_mbid_cam_cache_dump(RTW_DBGDUMP, __func__, adapter);
#endif
for (i = 0; i < TOTAL_MBID_CAM_NUM; i++) {
if (mbid_cam_ctl->bitmap & BIT(i)) {
write_mbssid_cam(adapter, i, dvobj->mbid_cam_cache[i].mac_addr);
RTW_INFO("%s - cam_id:%d => mac:"MAC_FMT"\n", __func__, i, MAC_ARG(dvobj->mbid_cam_cache[i].mac_addr));
}
}
rtw_mbid_cam_enable(adapter);
}
#endif /*CONFIG_MBSSID_CAM*/
#ifdef CONFIG_FW_HANDLE_TXBCN
#define H2C_BCN_OFFLOAD_LEN 1
#define SET_H2CCMD_BCN_OFFLOAD_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 1, __Value)
#define SET_H2CCMD_BCN_ROOT_TBTT_RPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 1, __Value)
#define SET_H2CCMD_BCN_VAP1_TBTT_RPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 1, __Value)
#define SET_H2CCMD_BCN_VAP2_TBTT_RPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 1, __Value)
#define SET_H2CCMD_BCN_VAP3_TBTT_RPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 1, __Value)
#define SET_H2CCMD_BCN_VAP4_TBTT_RPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 5, 1, __Value)
void rtw_hal_set_fw_ap_bcn_offload_cmd(_adapter *adapter, bool fw_bcn_en, u8 tbtt_rpt_map)
{
u8 fw_bcn_offload[1] = {0};
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
if (fw_bcn_en)
SET_H2CCMD_BCN_OFFLOAD_EN(fw_bcn_offload, 1);
if (tbtt_rpt_map & BIT(0))
SET_H2CCMD_BCN_ROOT_TBTT_RPT(fw_bcn_offload, 1);
if (tbtt_rpt_map & BIT(1))
SET_H2CCMD_BCN_VAP1_TBTT_RPT(fw_bcn_offload, 1);
if (tbtt_rpt_map & BIT(2))
SET_H2CCMD_BCN_VAP2_TBTT_RPT(fw_bcn_offload, 1);
if (tbtt_rpt_map & BIT(3))
SET_H2CCMD_BCN_VAP3_TBTT_RPT(fw_bcn_offload, 1);
dvobj->vap_tbtt_rpt_map = tbtt_rpt_map;
dvobj->fw_bcn_offload = fw_bcn_en;
RTW_INFO("[FW BCN] Offload : %s\n", (dvobj->fw_bcn_offload) ? "EN" : "DIS");
RTW_INFO("[FW BCN] TBTT RPT map : 0x%02x\n", dvobj->vap_tbtt_rpt_map);
rtw_hal_fill_h2c_cmd(adapter, H2C_FW_BCN_OFFLOAD,
H2C_BCN_OFFLOAD_LEN, fw_bcn_offload);
}
void rtw_hal_set_bcn_rsvdpage_loc_cmd(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 ret, vap_id;
u32 page_size = 0;
u8 bcn_rsvdpage[H2C_BCN_RSVDPAGE_LEN] = {0};
rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&page_size);
#if 1
for (vap_id = 0; vap_id < CONFIG_LIMITED_AP_NUM; vap_id++) {
if (dvobj->vap_map & BIT(vap_id))
bcn_rsvdpage[vap_id] = vap_id * (MAX_BEACON_LEN / page_size);
}
#else
#define SET_H2CCMD_BCN_RSVDPAGE_LOC_ROOT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 1, 8, __Value)
#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 2, 8, __Value)
#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP3(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 3, 8, __Value)
#define SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP4(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 8, __Value)
if (dvobj->vap_map & BIT(0))
SET_H2CCMD_BCN_RSVDPAGE_LOC_ROOT(bcn_rsvdpage, 0);
if (dvobj->vap_map & BIT(1))
SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP1(bcn_rsvdpage,
1 * (MAX_BEACON_LEN / page_size));
if (dvobj->vap_map & BIT(2))
SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP2(bcn_rsvdpage,
2 * (MAX_BEACON_LEN / page_size));
if (dvobj->vap_map & BIT(3))
SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP3(bcn_rsvdpage,
3 * (MAX_BEACON_LEN / page_size));
if (dvobj->vap_map & BIT(4))
SET_H2CCMD_BCN_RSVDPAGE_LOC_VAP4(bcn_rsvdpage,
4 * (MAX_BEACON_LEN / page_size));
#endif
if (1) {
RTW_INFO("[BCN_LOC] vap_map : 0x%02x\n", dvobj->vap_map);
RTW_INFO("[BCN_LOC] page_size :%d, @bcn_page_num :%d\n"
, page_size, (MAX_BEACON_LEN / page_size));
RTW_INFO("[BCN_LOC] root ap : 0x%02x\n", *bcn_rsvdpage);
RTW_INFO("[BCN_LOC] vap_1 : 0x%02x\n", *(bcn_rsvdpage + 1));
RTW_INFO("[BCN_LOC] vap_2 : 0x%02x\n", *(bcn_rsvdpage + 2));
RTW_INFO("[BCN_LOC] vap_3 : 0x%02x\n", *(bcn_rsvdpage + 3));
RTW_INFO("[BCN_LOC] vap_4 : 0x%02x\n", *(bcn_rsvdpage + 4));
}
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_BCN_RSVDPAGE,
H2C_BCN_RSVDPAGE_LEN, bcn_rsvdpage);
}
void rtw_ap_multi_bcn_cfg(_adapter *adapter)
{
u8 dft_bcn_space = DEFAULT_BCN_INTERVAL;
u8 sub_bcn_space = (DEFAULT_BCN_INTERVAL / CONFIG_LIMITED_AP_NUM);
/*enable to rx data frame*/
rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
/*Disable Port0's beacon function*/
rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL) & ~BIT_EN_BCN_FUNCTION);
/*Reset Port0's TSF*/
rtw_write8(adapter, REG_DUAL_TSF_RST, BIT_TSFTR_RST);
rtw_ap_set_mbid_num(adapter, CONFIG_LIMITED_AP_NUM);
/*BCN space & BCN sub-space 0x554[15:0] = 0x64,0x5BC[23:16] = 0x21*/
rtw_halmac_set_bcn_interval(adapter_to_dvobj(adapter), HW_PORT0, dft_bcn_space);
rtw_write8(adapter, REG_MBSSID_BCN_SPACE3 + 2, sub_bcn_space);
#if 0 /*setting in hw_var_set_opmode_mbid - ResumeTxBeacon*/
/*BCN hold time 0x540[19:8] = 0x80*/
rtw_write8(adapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME & 0xFF);
rtw_write8(adapter, REG_TBTT_PROHIBIT + 2,
(rtw_read8(adapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME >> 8));
#endif
/*ATIM window -0x55A = 0x32, reg 0x570 = 0x32, reg 0x5A0 = 0x32 */
rtw_write8(adapter, REG_ATIMWND, 0x32);
rtw_write8(adapter, REG_ATIMWND1_V1, 0x32);
rtw_write8(adapter, REG_ATIMWND2, 0x32);
rtw_write8(adapter, REG_ATIMWND3, 0x32);
/*
rtw_write8(adapter, REG_ATIMWND4, 0x32);
rtw_write8(adapter, REG_ATIMWND5, 0x32);
rtw_write8(adapter, REG_ATIMWND6, 0x32);
rtw_write8(adapter, REG_ATIMWND7, 0x32);*/
/*no limit setting - 0x5A7 = 0xFF - Packet in Hi Queue Tx immediately*/
rtw_write8(adapter, REG_HIQ_NO_LMT_EN, 0xFF);
/*Mask all beacon*/
rtw_write8(adapter, REG_MBSSID_CTRL, 0);
/*BCN invalid bit setting 0x454[6] = 1*/
/*rtw_write8(adapter, REG_CCK_CHECK, rtw_read8(adapter, REG_CCK_CHECK) | BIT_EN_BCN_PKT_REL);*/
/*Enable Port0's beacon function*/
rtw_write8(adapter, REG_BCN_CTRL,
rtw_read8(adapter, REG_BCN_CTRL) | BIT_DIS_RX_BSSID_FIT | BIT_P0_EN_TXBCN_RPT | BIT_DIS_TSF_UDT | BIT_EN_BCN_FUNCTION);
/* Enable HW seq for BCN
* 0x4FC[0]: EN_HWSEQ / 0x4FC[1]: EN_HWSEQEXT */
#ifdef CONFIG_RTL8822B
if (IS_HARDWARE_TYPE_8822B(adapter))
rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822B, 0x01);
#endif
#ifdef CONFIG_RTL8822C
if (IS_HARDWARE_TYPE_8822C(adapter))
rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822C, 0x01);
#endif
}
static void _rtw_mbid_bcn_cfg(_adapter *adapter, bool mbcnq_en, u8 mbcnq_id)
{
if (mbcnq_id >= CONFIG_LIMITED_AP_NUM) {
RTW_ERR(FUNC_ADPT_FMT"- mbid bcnq_id(%d) invalid\n", FUNC_ADPT_ARG(adapter), mbcnq_id);
rtw_warn_on(1);
}
if (mbcnq_en) {
rtw_write8(adapter, REG_MBSSID_CTRL,
rtw_read8(adapter, REG_MBSSID_CTRL) | BIT(mbcnq_id));
RTW_INFO(FUNC_ADPT_FMT"- mbid bcnq_id(%d) enabled\n", FUNC_ADPT_ARG(adapter), mbcnq_id);
} else {
rtw_write8(adapter, REG_MBSSID_CTRL,
rtw_read8(adapter, REG_MBSSID_CTRL) & (~BIT(mbcnq_id)));
RTW_INFO(FUNC_ADPT_FMT"- mbid bcnq_id(%d) disabled\n", FUNC_ADPT_ARG(adapter), mbcnq_id);
}
}
/*#define CONFIG_FW_TBTT_RPT*/
void rtw_ap_mbid_bcn_en(_adapter *adapter, u8 ap_id)
{
RTW_INFO(FUNC_ADPT_FMT"- ap_id(%d)\n", FUNC_ADPT_ARG(adapter), ap_id);
#ifdef CONFIG_FW_TBTT_RPT
if (rtw_ap_get_nums(adapter) >= 1) {
u8 tbtt_rpt_map = adapter_to_dvobj(adapter)->vap_tbtt_rpt_map;
rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _TRUE,
tbtt_rpt_map | BIT(ap_id));/*H2C-0xBA*/
}
#else
if (rtw_ap_get_nums(adapter) == 1)
rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _TRUE, 0);/*H2C-0xBA*/
#endif
rtw_hal_set_bcn_rsvdpage_loc_cmd(adapter);/*H2C-0x09*/
_rtw_mbid_bcn_cfg(adapter, _TRUE, ap_id);
}
void rtw_ap_mbid_bcn_dis(_adapter *adapter, u8 ap_id)
{
RTW_INFO(FUNC_ADPT_FMT"- ap_id(%d)\n", FUNC_ADPT_ARG(adapter), ap_id);
_rtw_mbid_bcn_cfg(adapter, _FALSE, ap_id);
if (rtw_ap_get_nums(adapter) == 0)
rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _FALSE, 0);
#ifdef CONFIG_FW_TBTT_RPT
else if (rtw_ap_get_nums(adapter) >= 1) {
u8 tbtt_rpt_map = adapter_to_dvobj(adapter)->vap_tbtt_rpt_map;
rtw_hal_set_fw_ap_bcn_offload_cmd(adapter, _TRUE,
tbtt_rpt_map & ~BIT(ap_id));/*H2C-0xBA*/
}
#endif
}
#endif
#ifdef CONFIG_SWTIMER_BASED_TXBCN
void rtw_ap_multi_bcn_cfg(_adapter *adapter)
{
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
rtw_write8(adapter, REG_BCN_CTRL, DIS_TSF_UDT);
#else
rtw_write8(adapter, REG_BCN_CTRL, DIS_TSF_UDT | DIS_BCNQ_SUB);
#endif
/*enable to rx data frame*/
rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
/*Beacon Control related register for first time*/
rtw_write8(adapter, REG_BCNDMATIM, 0x02); /* 2ms */
/*rtw_write8(Adapter, REG_BCN_MAX_ERR, 0xFF);*/
rtw_write8(adapter, REG_ATIMWND, 0x0c); /* 12ms */
#ifndef CONFIG_HW_P0_TSF_SYNC
rtw_write16(adapter, REG_TSFTR_SYN_OFFSET, 0x7fff);/* +32767 (~32ms) */
#endif
/*reset TSF*/
rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(0));
/*enable BCN0 Function for if1*/
/*don't enable update TSF0 for if1 (due to TSF update when beacon,probe rsp are received)*/
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
rtw_write8(adapter, REG_BCN_CTRL, BIT_DIS_RX_BSSID_FIT | BIT_P0_EN_TXBCN_RPT | BIT_DIS_TSF_UDT |BIT_EN_BCN_FUNCTION);
#else
rtw_write8(adapter, REG_BCN_CTRL, (DIS_TSF_UDT | EN_BCN_FUNCTION | EN_TXBCN_RPT | DIS_BCNQ_SUB));
#endif
#ifdef CONFIG_BCN_XMIT_PROTECT
rtw_write8(adapter, REG_CCK_CHECK, rtw_read8(adapter, REG_CCK_CHECK) | BIT_EN_BCN_PKT_REL);
#endif
if (IS_HARDWARE_TYPE_8821(adapter) || IS_HARDWARE_TYPE_8192E(adapter))/* select BCN on port 0 for DualBeacon*/
rtw_write8(adapter, REG_CCK_CHECK, rtw_read8(adapter, REG_CCK_CHECK) & (~BIT_BCN_PORT_SEL));
/* Enable HW seq for BCN
* 0x4FC[0]: EN_HWSEQ / 0x4FC[1]: EN_HWSEQEXT */
#ifdef CONFIG_RTL8822B
if (IS_HARDWARE_TYPE_8822B(adapter))
rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822B, 0x01);
#endif
#ifdef CONFIG_RTL8822C
if (IS_HARDWARE_TYPE_8822C(adapter))
rtw_write8(adapter, REG_DUMMY_PAGE4_V1_8822C, 0x01);
#endif
}
#endif
#ifdef CONFIG_MI_WITH_MBSSID_CAM
void rtw_hal_set_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
{
#if 0 /*TODO - modify for more flexible*/
u8 idx = 0;
if ((check_fwstate(&adapter->mlmepriv, WIFI_STATION_STATE) == _TRUE) &&
(DEV_STA_NUM(adapter_to_dvobj(adapter)) == 1)) {
for (idx = 0; idx < 6; idx++)
rtw_write8(GET_PRIMARY_ADAPTER(adapter), (REG_MACID + idx), val[idx]);
} else {
/*MBID entry_id = 0~7 ,0 for root AP, 1~7 for VAP*/
u8 entry_id;
if ((check_fwstate(&adapter->mlmepriv, WIFI_AP_STATE) == _TRUE) &&
(DEV_AP_NUM(adapter_to_dvobj(adapter)) == 1)) {
entry_id = 0;
if (rtw_mbid_cam_assign(adapter, val, entry_id)) {
RTW_INFO(FUNC_ADPT_FMT" Root AP assigned success\n", FUNC_ADPT_ARG(adapter));
write_mbssid_cam(adapter, entry_id, val);
}
} else {
entry_id = rtw_mbid_camid_alloc(adapter, val);
if (entry_id != INVALID_CAM_ID)
write_mbssid_cam(adapter, entry_id, val);
}
}
#else
{
/*
MBID entry_id = 0~7 ,for IFACE_ID0 ~ IFACE_IDx
*/
u8 entry_id = rtw_mbid_camid_alloc(adapter, mac_addr);
if (entry_id != INVALID_CAM_ID) {
write_mbssid_cam(adapter, entry_id, mac_addr);
RTW_INFO("%s "ADPT_FMT"- mbid(%d) mac_addr ="MAC_FMT"\n", __func__,
ADPT_ARG(adapter), entry_id, MAC_ARG(mac_addr));
}
}
#endif
}
void rtw_hal_change_macaddr_mbid(_adapter *adapter, u8 *mac_addr)
{
u8 idx = 0;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 entry_id;
if (!mac_addr) {
rtw_warn_on(1);
return;
}
entry_id = rtw_mbid_cam_info_change(adapter, mac_addr);
if (entry_id != INVALID_CAM_ID)
write_mbssid_cam(adapter, entry_id, mac_addr);
}
#ifdef CONFIG_SWTIMER_BASED_TXBCN
u16 rtw_hal_bcn_interval_adjust(_adapter *adapter, u16 bcn_interval)
{
if (adapter_to_dvobj(adapter)->inter_bcn_space != bcn_interval)
return adapter_to_dvobj(adapter)->inter_bcn_space;
else
return bcn_interval;
}
#endif/*CONFIG_SWTIMER_BASED_TXBCN*/
#else
static void rtw_hal_set_macaddr_port(_adapter *adapter, u8 *val)
{
u8 idx = 0;
u32 reg_macid = 0;
enum _hw_port hwport;
if (val == NULL)
return;
hwport = get_hw_port(adapter);
RTW_INFO("%s "ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n", __func__,
ADPT_ARG(adapter), hwport, MAC_ARG(val));
#ifdef RTW_HALMAC
rtw_halmac_set_mac_address(adapter_to_dvobj(adapter), hwport, val);
#else /* !RTW_HALMAC */
switch (hwport) {
case HW_PORT0:
default:
reg_macid = REG_MACID;
break;
case HW_PORT1:
reg_macid = REG_MACID1;
break;
#if defined(CONFIG_RTL8814A)
case HW_PORT2:
reg_macid = REG_MACID2;
break;
case HW_PORT3:
reg_macid = REG_MACID3;
break;
case HW_PORT4:
reg_macid = REG_MACID4;
break;
#endif/*defined(CONFIG_RTL8814A)*/
}
for (idx = 0; idx < ETH_ALEN; idx++)
rtw_write8(GET_PRIMARY_ADAPTER(adapter), (reg_macid + idx), val[idx]);
#endif /* !RTW_HALMAC */
}
#endif/*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
static void rtw_hal_get_macaddr_port(_adapter *adapter, u8 *mac_addr)
{
u8 idx = 0;
u32 reg_macid = 0;
if (mac_addr == NULL)
return;
_rtw_memset(mac_addr, 0, ETH_ALEN);
#ifdef RTW_HALMAC
rtw_halmac_get_mac_address(adapter_to_dvobj(adapter), adapter->hw_port, mac_addr);
#else /* !RTW_HALMAC */
switch (adapter->hw_port) {
case HW_PORT0:
default:
reg_macid = REG_MACID;
break;
case HW_PORT1:
reg_macid = REG_MACID1;
break;
#if defined(CONFIG_RTL8814A)
case HW_PORT2:
reg_macid = REG_MACID2;
break;
case HW_PORT3:
reg_macid = REG_MACID3;
break;
case HW_PORT4:
reg_macid = REG_MACID4;
break;
#endif /*defined(CONFIG_RTL8814A)*/
}
for (idx = 0; idx < ETH_ALEN; idx++)
mac_addr[idx] = rtw_read8(GET_PRIMARY_ADAPTER(adapter), (reg_macid + idx));
#endif /* !RTW_HALMAC */
RTW_INFO("%s "ADPT_FMT"- hw port(%d) mac_addr ="MAC_FMT"\n", __func__,
ADPT_ARG(adapter), adapter->hw_port, MAC_ARG(mac_addr));
}
static void rtw_hal_set_bssid(_adapter *adapter, u8 *val)
{
u8 hw_port = rtw_hal_get_port(adapter);
#ifdef RTW_HALMAC
rtw_halmac_set_bssid(adapter_to_dvobj(adapter), hw_port, val);
#else /* !RTW_HALMAC */
u8 idx = 0;
u32 reg_bssid = 0;
switch (hw_port) {
case HW_PORT0:
default:
reg_bssid = REG_BSSID;
break;
case HW_PORT1:
reg_bssid = REG_BSSID1;
break;
#if defined(CONFIG_RTL8814A)
case HW_PORT2:
reg_bssid = REG_BSSID2;
break;
case HW_PORT3:
reg_bssid = REG_BSSID3;
break;
case HW_PORT4:
reg_bssid = REG_BSSID4;
break;
#endif/*defined(CONFIG_RTL8814A)*/
}
for (idx = 0 ; idx < ETH_ALEN; idx++)
rtw_write8(adapter, (reg_bssid + idx), val[idx]);
#endif /* !RTW_HALMAC */
RTW_INFO("%s "ADPT_FMT"- hw port -%d BSSID: "MAC_FMT"\n",
__func__, ADPT_ARG(adapter), hw_port, MAC_ARG(val));
}
static void rtw_hal_set_tsf_update(_adapter *adapter, u8 en)
{
u32 addr = 0;
u8 val8;
rtw_hal_get_hwreg(adapter, HW_VAR_BCN_CTRL_ADDR, (u8 *)&addr);
if (addr) {
val8 = rtw_read8(adapter, addr);
if (en && (val8 & DIS_TSF_UDT)) {
rtw_write8(adapter, addr, val8 & ~DIS_TSF_UDT);
#ifdef DBG_TSF_UPDATE
RTW_INFO("port%u("ADPT_FMT") enable TSF update\n", adapter->hw_port, ADPT_ARG(adapter));
#endif
}
if (!en && !(val8 & DIS_TSF_UDT)) {
rtw_write8(adapter, addr, val8 | DIS_TSF_UDT);
#ifdef DBG_TSF_UPDATE
RTW_INFO("port%u("ADPT_FMT") disable TSF update\n", adapter->hw_port, ADPT_ARG(adapter));
#endif
}
} else {
RTW_WARN("unknown port%d("ADPT_FMT") %s TSF update\n"
, adapter->hw_port, ADPT_ARG(adapter), en ? "enable" : "disable");
rtw_warn_on(1);
}
}
static void rtw_hal_set_hw_update_tsf(PADAPTER padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
#if defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8822C) || defined(CONFIG_MI_WITH_MBSSID_CAM)
RTW_INFO("[Warn] %s "ADPT_FMT" enter func\n", __func__, ADPT_ARG(padapter));
rtw_warn_on(1);
return;
#endif
if (!pmlmeext->en_hw_update_tsf)
return;
/* check RCR */
if (!rtw_hal_rcr_check(padapter, RCR_CBSSID_BCN))
return;
if (pmlmeext->tsf_update_required) {
pmlmeext->tsf_update_pause_stime = 0;
rtw_hal_set_tsf_update(padapter, 1);
}
pmlmeext->en_hw_update_tsf = 0;
}
void rtw_iface_enable_tsf_update(_adapter *adapter)
{
adapter->mlmeextpriv.tsf_update_pause_stime = 0;
adapter->mlmeextpriv.tsf_update_required = 1;
#ifdef CONFIG_MI_WITH_MBSSID_CAM
#else
rtw_hal_set_tsf_update(adapter, 1);
#endif
}
void rtw_iface_disable_tsf_update(_adapter *adapter)
{
adapter->mlmeextpriv.tsf_update_required = 0;
adapter->mlmeextpriv.tsf_update_pause_stime = 0;
adapter->mlmeextpriv.en_hw_update_tsf = 0;
#ifdef CONFIG_MI_WITH_MBSSID_CAM
#else
rtw_hal_set_tsf_update(adapter, 0);
#endif
}
static void rtw_hal_tsf_update_pause(_adapter *adapter)
{
#ifdef CONFIG_MI_WITH_MBSSID_CAM
#else
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface;
int i;
u8 val8;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
rtw_hal_set_tsf_update(iface, 0);
if (iface->mlmeextpriv.tsf_update_required) {
iface->mlmeextpriv.tsf_update_pause_stime = rtw_get_current_time();
if (!iface->mlmeextpriv.tsf_update_pause_stime)
iface->mlmeextpriv.tsf_update_pause_stime++;
}
iface->mlmeextpriv.en_hw_update_tsf = 0;
}
#endif
}
static void rtw_hal_tsf_update_restore(_adapter *adapter)
{
#ifdef CONFIG_MI_WITH_MBSSID_CAM
#else
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (iface->mlmeextpriv.tsf_update_required) {
/* enable HW TSF update when recive beacon*/
iface->mlmeextpriv.en_hw_update_tsf = 1;
#ifdef DBG_TSF_UPDATE
RTW_INFO("port%d("ADPT_FMT") enabling TSF update...\n"
, iface->hw_port, ADPT_ARG(iface));
#endif
}
}
#endif
}
void rtw_hal_periodic_tsf_update_chk(_adapter *adapter)
{
#ifdef CONFIG_MI_WITH_MBSSID_CAM
#else
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface;
struct mlme_ext_priv *mlmeext;
int i;
u32 restore_ms = 0;
if (dvobj->periodic_tsf_update_etime) {
if (rtw_time_after(rtw_get_current_time(), dvobj->periodic_tsf_update_etime)) {
/* end for restore status */
dvobj->periodic_tsf_update_etime = 0;
rtw_hal_rcr_set_chk_bssid(adapter, MLME_ACTION_NONE);
}
return;
}
if (dvobj->rf_ctl.offch_state != OFFCHS_NONE)
return;
/*
* all required ifaces can switch to restore status together
* loop all pause iface to get largest restore time required
*/
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
mlmeext = &iface->mlmeextpriv;
if (mlmeext->tsf_update_required
&& mlmeext->tsf_update_pause_stime
&& rtw_get_passing_time_ms(mlmeext->tsf_update_pause_stime)
> mlmeext->mlmext_info.bcn_interval * mlmeext->tsf_update_pause_factor
) {
if (restore_ms < mlmeext->mlmext_info.bcn_interval * mlmeext->tsf_update_restore_factor)
restore_ms = mlmeext->mlmext_info.bcn_interval * mlmeext->tsf_update_restore_factor;
}
}
if (!restore_ms)
return;
dvobj->periodic_tsf_update_etime = rtw_get_current_time() + rtw_ms_to_systime(restore_ms);
if (!dvobj->periodic_tsf_update_etime)
dvobj->periodic_tsf_update_etime++;
rtw_hal_rcr_set_chk_bssid(adapter, MLME_ACTION_NONE);
/* set timer to end restore status */
_set_timer(&dvobj->periodic_tsf_update_end_timer, restore_ms);
#endif
}
void rtw_hal_periodic_tsf_update_end_timer_hdl(void *ctx)
{
struct dvobj_priv *dvobj = (struct dvobj_priv *)ctx;
if (dev_is_surprise_removed(dvobj) || dev_is_drv_stopped(dvobj))
return;
rtw_periodic_tsf_update_end_cmd(dvobj_get_primary_adapter(dvobj));
}
static inline u8 hw_var_rcr_config(_adapter *adapter, u32 rcr)
{
int err;
err = rtw_write32(adapter, REG_RCR, rcr);
if (err == _SUCCESS)
GET_HAL_DATA(adapter)->ReceiveConfig = rcr;
return err;
}
static inline u8 hw_var_rcr_get(_adapter *adapter, u32 *rcr)
{
u32 v32;
v32 = rtw_read32(adapter, REG_RCR);
if (rcr)
*rcr = v32;
GET_HAL_DATA(adapter)->ReceiveConfig = v32;
return _SUCCESS;
}
/* only check SW RCR variable */
inline u8 rtw_hal_rcr_check(_adapter *adapter, u32 check_bit)
{
PHAL_DATA_TYPE hal;
u32 rcr;
hal = GET_HAL_DATA(adapter);
rcr = hal->ReceiveConfig;
if ((rcr & check_bit) == check_bit)
return 1;
return 0;
}
inline u8 rtw_hal_rcr_add(_adapter *adapter, u32 add)
{
PHAL_DATA_TYPE hal;
u32 rcr;
u8 ret = _SUCCESS;
hal = GET_HAL_DATA(adapter);
rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
rcr |= add;
if (rcr != hal->ReceiveConfig)
ret = rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
return ret;
}
inline u8 rtw_hal_rcr_clear(_adapter *adapter, u32 clear)
{
PHAL_DATA_TYPE hal;
u32 rcr;
u8 ret = _SUCCESS;
hal = GET_HAL_DATA(adapter);
rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
rcr &= ~clear;
if (rcr != hal->ReceiveConfig)
ret = rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
return ret;
}
void rtw_hal_rcr_set_chk_bssid(_adapter *adapter, u8 self_action)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u32 rcr, rcr_new;
struct mi_state mstate, mstate_s;
rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
rcr_new = rcr;
#if defined(CONFIG_MI_WITH_MBSSID_CAM) && !defined(CONFIG_CLIENT_PORT_CFG)
rcr_new &= ~(RCR_CBSSID_BCN | RCR_CBSSID_DATA);
#else
rtw_mi_status_no_self(adapter, &mstate);
rtw_mi_status_no_others(adapter, &mstate_s);
/* only adjust parameters interested */
switch (self_action) {
case MLME_SCAN_ENTER:
mstate_s.scan_num = 1;
mstate_s.scan_enter_num = 1;
break;
case MLME_SCAN_DONE:
mstate_s.scan_enter_num = 0;
break;
case MLME_STA_CONNECTING:
mstate_s.lg_sta_num = 1;
mstate_s.ld_sta_num = 0;
break;
case MLME_STA_CONNECTED:
mstate_s.lg_sta_num = 0;
mstate_s.ld_sta_num = 1;
break;
case MLME_STA_DISCONNECTED:
mstate_s.lg_sta_num = 0;
mstate_s.ld_sta_num = 0;
break;
#ifdef CONFIG_TDLS
case MLME_TDLS_LINKED:
mstate_s.ld_tdls_num = 1;
break;
case MLME_TDLS_NOLINK:
mstate_s.ld_tdls_num = 0;
break;
#endif
#ifdef CONFIG_AP_MODE
case MLME_AP_STARTED:
mstate_s.ap_num = 1;
break;
case MLME_AP_STOPPED:
mstate_s.ap_num = 0;
mstate_s.ld_ap_num = 0;
break;
#endif
#ifdef CONFIG_RTW_MESH
case MLME_MESH_STARTED:
mstate_s.mesh_num = 1;
break;
case MLME_MESH_STOPPED:
mstate_s.mesh_num = 0;
mstate_s.ld_mesh_num = 0;
break;
#endif
case MLME_ACTION_NONE:
case MLME_ADHOC_STARTED:
/* caller without effect of decision */
break;
default:
rtw_warn_on(1);
};
rtw_mi_status_merge(&mstate, &mstate_s);
if (MSTATE_AP_NUM(&mstate) || MSTATE_MESH_NUM(&mstate) || MSTATE_TDLS_LD_NUM(&mstate)
#ifdef CONFIG_FIND_BEST_CHANNEL
|| MSTATE_SCAN_ENTER_NUM(&mstate)
#endif
|| hal_data->in_cta_test
)
rcr_new &= ~RCR_CBSSID_DATA;
else
rcr_new |= RCR_CBSSID_DATA;
if (MSTATE_SCAN_ENTER_NUM(&mstate) || hal_data->in_cta_test)
rcr_new &= ~RCR_CBSSID_BCN;
else if (MSTATE_STA_LG_NUM(&mstate)
|| adapter_to_dvobj(adapter)->periodic_tsf_update_etime
)
rcr_new |= RCR_CBSSID_BCN;
else if ((MSTATE_AP_NUM(&mstate) && adapter->registrypriv.wifi_spec) /* for 11n Logo 4.2.31/4.2.32 */
|| MSTATE_MESH_NUM(&mstate)
)
rcr_new &= ~RCR_CBSSID_BCN;
else
rcr_new |= RCR_CBSSID_BCN;
#ifdef CONFIG_CLIENT_PORT_CFG
if (get_clt_num(adapter) > MAX_CLIENT_PORT_NUM)
rcr_new &= ~RCR_CBSSID_BCN;
#endif
#endif /* CONFIG_MI_WITH_MBSSID_CAM */
if (rcr == rcr_new)
return;
if (!hal_spec->rx_tsf_filter
&& (rcr & RCR_CBSSID_BCN) && !(rcr_new & RCR_CBSSID_BCN))
rtw_hal_tsf_update_pause(adapter);
rtw_hal_set_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr_new);
if (!hal_spec->rx_tsf_filter
&& !(rcr & RCR_CBSSID_BCN) && (rcr_new & RCR_CBSSID_BCN)
&& self_action != MLME_STA_CONNECTING)
rtw_hal_tsf_update_restore(adapter);
}
static void hw_var_set_rcr_am(_adapter *adapter, u8 enable)
{
u32 rcr = RCR_AM;
if (enable)
rtw_hal_rcr_add(adapter, rcr);
else
rtw_hal_rcr_clear(adapter, rcr);
}
static void hw_var_set_bcn_interval(_adapter *adapter, u16 interval)
{
#ifdef CONFIG_SWTIMER_BASED_TXBCN
interval = rtw_hal_bcn_interval_adjust(adapter, interval);
#endif
#ifdef RTW_HALMAC
rtw_halmac_set_bcn_interval(adapter_to_dvobj(adapter), adapter->hw_port, interval);
#else
rtw_write16(adapter, REG_MBSSID_BCN_SPACE, interval);
#endif
#ifdef CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
RTW_INFO("%s==> bcn_interval:%d, eraly_int:%d\n", __func__, interval, interval >> 1);
rtw_write8(adapter, REG_DRVERLYINT, interval >> 1);
}
}
#endif
}
#if CONFIG_TX_AC_LIFETIME
const char *const _tx_aclt_conf_str[] = {
"DEFAULT",
"AP_M2U",
"MESH",
"INVALID",
};
void dump_tx_aclt_force_val(void *sel, struct dvobj_priv *dvobj)
{
#define TX_ACLT_FORCE_MSG_LEN 64
struct hal_spec_t *hal_spec = GET_HAL_SPEC(dvobj_get_primary_adapter(dvobj));
struct tx_aclt_conf_t *conf = &dvobj->tx_aclt_force_val;
char buf[TX_ACLT_FORCE_MSG_LEN];
int cnt = 0;
RTW_PRINT_SEL(sel, "unit:%uus, maximum:%uus\n"
, hal_spec->tx_aclt_unit_factor * 32
, 0xFFFF * hal_spec->tx_aclt_unit_factor * 32);
RTW_PRINT_SEL(sel, "%-5s %-12s %-12s\n", "en", "vo_vi(us)", "be_bk(us)");
RTW_PRINT_SEL(sel, " 0x%02x %12u %12u\n"
, conf->en
, conf->vo_vi * hal_spec->tx_aclt_unit_factor * 32
, conf->be_bk * hal_spec->tx_aclt_unit_factor * 32
);
cnt += snprintf(buf + cnt, TX_ACLT_FORCE_MSG_LEN - cnt - 1, "%5s", conf->en == 0xFF ? "AUTO" : "FORCE");
if (cnt >= TX_ACLT_FORCE_MSG_LEN - 1)
goto exit;
if (conf->vo_vi)
cnt += snprintf(buf + cnt, TX_ACLT_FORCE_MSG_LEN - cnt - 1, " FORCE:0x%04x", conf->vo_vi);
else
cnt += snprintf(buf + cnt, TX_ACLT_FORCE_MSG_LEN - cnt - 1, " AUTO");
if (cnt >= TX_ACLT_FORCE_MSG_LEN - 1)
goto exit;
if (conf->be_bk)
cnt += snprintf(buf + cnt, TX_ACLT_FORCE_MSG_LEN - cnt - 1, " FORCE:0x%04x", conf->be_bk);
else
cnt += snprintf(buf + cnt, TX_ACLT_FORCE_MSG_LEN - cnt - 1, " AUTO");
if (cnt >= TX_ACLT_FORCE_MSG_LEN - 1)
goto exit;
RTW_PRINT_SEL(sel, "%s\n", buf);
exit:
return;
}
void rtw_hal_set_tx_aclt_force_val(_adapter *adapter, struct tx_aclt_conf_t *input, u8 arg_num)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct tx_aclt_conf_t *conf = &dvobj->tx_aclt_force_val;
if (arg_num >= 1) {
if (input->en == 0xFF)
conf->en = input->en;
else
conf->en = input->en & 0xF;
}
if (arg_num >= 2) {
conf->vo_vi = input->vo_vi / (hal_spec->tx_aclt_unit_factor * 32);
if (conf->vo_vi > 0xFFFF)
conf->vo_vi = 0xFFFF;
}
if (arg_num >= 3) {
conf->be_bk = input->be_bk / (hal_spec->tx_aclt_unit_factor * 32);
if (conf->be_bk > 0xFFFF)
conf->be_bk = 0xFFFF;
}
}
void dump_tx_aclt_confs(void *sel, struct dvobj_priv *dvobj)
{
#define TX_ACLT_CONF_MSG_LEN 32
struct hal_spec_t *hal_spec = GET_HAL_SPEC(dvobj_get_primary_adapter(dvobj));
struct tx_aclt_conf_t *conf;
char buf[TX_ACLT_CONF_MSG_LEN];
int cnt;
int i;
RTW_PRINT_SEL(sel, "unit:%uus, maximum:%uus\n"
, hal_spec->tx_aclt_unit_factor * 32
, 0xFFFF * hal_spec->tx_aclt_unit_factor * 32);
RTW_PRINT_SEL(sel, "%-7s %-1s %-3s %-9s %-9s %-10s %-10s\n"
, "name", "#", "en", "vo_vi(us)", "be_bk(us)", "vo_vi(reg)", "be_bk(reg)");
for (i = 0; i < TX_ACLT_CONF_NUM; i++) {
conf = &dvobj->tx_aclt_confs[i];
cnt = 0;
if (conf->vo_vi)
cnt += snprintf(buf + cnt, TX_ACLT_CONF_MSG_LEN - cnt - 1, " 0x%04x", conf->vo_vi);
else
cnt += snprintf(buf + cnt, TX_ACLT_CONF_MSG_LEN - cnt - 1, " N/A");
if (cnt >= TX_ACLT_CONF_MSG_LEN - 1)
continue;
if (conf->be_bk)
cnt += snprintf(buf + cnt, TX_ACLT_CONF_MSG_LEN - cnt - 1, " 0x%04x", conf->be_bk);
else
cnt += snprintf(buf + cnt, TX_ACLT_CONF_MSG_LEN - cnt - 1, " N/A");
if (cnt >= TX_ACLT_CONF_MSG_LEN - 1)
continue;
RTW_PRINT_SEL(sel, "%7s %1u 0x%x %9u %9u%s\n"
, tx_aclt_conf_str(i), i
, conf->en
, conf->vo_vi * hal_spec->tx_aclt_unit_factor * 32
, conf->be_bk * hal_spec->tx_aclt_unit_factor * 32
, buf
);
}
}
void rtw_hal_set_tx_aclt_conf(_adapter *adapter, u8 conf_idx, struct tx_aclt_conf_t *input, u8 arg_num)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct tx_aclt_conf_t *conf;
if (conf_idx >= TX_ACLT_CONF_NUM)
return;
conf = &dvobj->tx_aclt_confs[conf_idx];
if (arg_num >= 1) {
if (input->en != 0xFF)
conf->en = input->en & 0xF;
}
if (arg_num >= 2) {
conf->vo_vi = input->vo_vi / (hal_spec->tx_aclt_unit_factor * 32);
if (conf->vo_vi > 0xFFFF)
conf->vo_vi = 0xFFFF;
}
if (arg_num >= 3) {
conf->be_bk = input->be_bk / (hal_spec->tx_aclt_unit_factor * 32);
if (conf->be_bk > 0xFFFF)
conf->be_bk = 0xFFFF;
}
}
void rtw_hal_update_tx_aclt(_adapter *adapter)
{
#ifdef CONFIG_TX_MCAST2UNI
extern int rtw_mc2u_disable;
#endif
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
u8 lt_en = 0, lt_en_ori;
u16 lt_vo_vi = 0xFFFF, lt_be_bk = 0xFFFF;
u32 lt, lt_ori;
struct tx_aclt_conf_t *conf;
int i;
lt_en_ori = rtw_read8(adapter, REG_LIFETIME_EN);
lt_ori = rtw_read32(adapter, REG_PKT_LIFE_TIME);
for (i = 0; i < TX_ACLT_CONF_NUM; i++) {
if (!(dvobj->tx_aclt_flags & BIT(i)))
continue;
conf = &dvobj->tx_aclt_confs[i];
if (i == TX_ACLT_CONF_DEFAULT) {
/* first and default status, assign directly */
lt_en = conf->en;
if (conf->vo_vi)
lt_vo_vi = conf->vo_vi;
if (conf->be_bk)
lt_be_bk = conf->be_bk;
}
#if defined(CONFIG_TX_MCAST2UNI) || defined(CONFIG_RTW_MESH)
else if (0
#ifdef CONFIG_TX_MCAST2UNI
|| (i == TX_ACLT_CONF_AP_M2U
&& !rtw_mc2u_disable
&& macid_ctl->op_num[H2C_MSR_ROLE_STA] /* having AP mode with STA connected */)
#endif
#ifdef CONFIG_RTW_MESH
|| (i == TX_ACLT_CONF_MESH
&& macid_ctl->op_num[H2C_MSR_ROLE_MESH] > 1 /* implies only 1 MESH mode supported */)
#endif
) {
/* long term status, OR en and MIN lifetime */
lt_en |= conf->en;
if (conf->vo_vi && lt_vo_vi > conf->vo_vi)
lt_vo_vi = conf->vo_vi;
if (conf->be_bk && lt_be_bk > conf->be_bk)
lt_be_bk = conf->be_bk;
}
#endif
}
if (dvobj->tx_aclt_force_val.en != 0xFF)
lt_en = dvobj->tx_aclt_force_val.en;
if (dvobj->tx_aclt_force_val.vo_vi)
lt_vo_vi = dvobj->tx_aclt_force_val.vo_vi;
if (dvobj->tx_aclt_force_val.be_bk)
lt_be_bk = dvobj->tx_aclt_force_val.be_bk;
lt_en = (lt_en_ori & 0xF0) | (lt_en & 0x0F);
lt = (lt_be_bk << 16) | lt_vo_vi;
if (0)
RTW_INFO("lt_en:0x%x(0x%x), lt:0x%08x(0x%08x)\n", lt_en, lt_en_ori, lt, lt_ori);
if (lt_en != lt_en_ori)
rtw_write8(adapter, REG_LIFETIME_EN, lt_en);
if (lt != lt_ori)
rtw_write32(adapter, REG_PKT_LIFE_TIME, lt);
}
#endif /* CONFIG_TX_AC_LIFETIME */
void hw_var_port_switch(_adapter *adapter)
{
#ifdef CONFIG_CONCURRENT_MODE
#ifdef CONFIG_RUNTIME_PORT_SWITCH
/*
0x102: MSR
0x550: REG_BCN_CTRL
0x551: REG_BCN_CTRL_1
0x55A: REG_ATIMWND
0x560: REG_TSFTR
0x568: REG_TSFTR1
0x570: REG_ATIMWND_1
0x610: REG_MACID
0x618: REG_BSSID
0x700: REG_MACID1
0x708: REG_BSSID1
*/
int i;
u8 msr;
u8 bcn_ctrl;
u8 bcn_ctrl_1;
u8 atimwnd[2];
u8 atimwnd_1[2];
u8 tsftr[8];
u8 tsftr_1[8];
u8 macid[6];
u8 bssid[6];
u8 macid_1[6];
u8 bssid_1[6];
#if defined(CONFIG_RTL8192F)
u16 wlan_act_mask_ctrl = 0;
u16 en_port_mask = EN_PORT_0_FUNCTION | EN_PORT_1_FUNCTION;
#endif
u8 hw_port;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface = NULL;
msr = rtw_read8(adapter, MSR);
bcn_ctrl = rtw_read8(adapter, REG_BCN_CTRL);
bcn_ctrl_1 = rtw_read8(adapter, REG_BCN_CTRL_1);
#if defined(CONFIG_RTL8192F)
wlan_act_mask_ctrl = rtw_read16(adapter, REG_WLAN_ACT_MASK_CTRL_1);
#endif
for (i = 0; i < 2; i++)
atimwnd[i] = rtw_read8(adapter, REG_ATIMWND + i);
for (i = 0; i < 2; i++)
atimwnd_1[i] = rtw_read8(adapter, REG_ATIMWND_1 + i);
for (i = 0; i < 8; i++)
tsftr[i] = rtw_read8(adapter, REG_TSFTR + i);
for (i = 0; i < 8; i++)
tsftr_1[i] = rtw_read8(adapter, REG_TSFTR1 + i);
for (i = 0; i < 6; i++)
macid[i] = rtw_read8(adapter, REG_MACID + i);
for (i = 0; i < 6; i++)
bssid[i] = rtw_read8(adapter, REG_BSSID + i);
for (i = 0; i < 6; i++)
macid_1[i] = rtw_read8(adapter, REG_MACID1 + i);
for (i = 0; i < 6; i++)
bssid_1[i] = rtw_read8(adapter, REG_BSSID1 + i);
#ifdef DBG_RUNTIME_PORT_SWITCH
RTW_INFO(FUNC_ADPT_FMT" before switch\n"
"msr:0x%02x\n"
"bcn_ctrl:0x%02x\n"
"bcn_ctrl_1:0x%02x\n"
#if defined(CONFIG_RTL8192F)
"wlan_act_mask_ctrl:0x%02x\n"
#endif
"atimwnd:0x%04x\n"
"atimwnd_1:0x%04x\n"
"tsftr:%llu\n"
"tsftr1:%llu\n"
"macid:"MAC_FMT"\n"
"bssid:"MAC_FMT"\n"
"macid_1:"MAC_FMT"\n"
"bssid_1:"MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter)
, msr
, bcn_ctrl
, bcn_ctrl_1
#if defined(CONFIG_RTL8192F)
, wlan_act_mask_ctrl
#endif
, *((u16 *)atimwnd)
, *((u16 *)atimwnd_1)
, *((u64 *)tsftr)
, *((u64 *)tsftr_1)
, MAC_ARG(macid)
, MAC_ARG(bssid)
, MAC_ARG(macid_1)
, MAC_ARG(bssid_1)
);
#endif /* DBG_RUNTIME_PORT_SWITCH */
/* disable bcn function, disable update TSF */
rtw_write8(adapter, REG_BCN_CTRL, (bcn_ctrl & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
rtw_write8(adapter, REG_BCN_CTRL_1, (bcn_ctrl_1 & (~EN_BCN_FUNCTION)) | DIS_TSF_UDT);
#if defined(CONFIG_RTL8192F)
rtw_write16(adapter, REG_WLAN_ACT_MASK_CTRL_1, wlan_act_mask_ctrl & ~en_port_mask);
#endif
/* switch msr */
msr = (msr & 0xf0) | ((msr & 0x03) << 2) | ((msr & 0x0c) >> 2);
rtw_write8(adapter, MSR, msr);
/* write port0 */
rtw_write8(adapter, REG_BCN_CTRL, bcn_ctrl_1 & ~EN_BCN_FUNCTION);
for (i = 0; i < 2; i++)
rtw_write8(adapter, REG_ATIMWND + i, atimwnd_1[i]);
for (i = 0; i < 8; i++)
rtw_write8(adapter, REG_TSFTR + i, tsftr_1[i]);
for (i = 0; i < 6; i++)
rtw_write8(adapter, REG_MACID + i, macid_1[i]);
for (i = 0; i < 6; i++)
rtw_write8(adapter, REG_BSSID + i, bssid_1[i]);
/* write port1 */
rtw_write8(adapter, REG_BCN_CTRL_1, bcn_ctrl & ~EN_BCN_FUNCTION);
for (i = 0; i < 2; i++)
rtw_write8(adapter, REG_ATIMWND_1 + i, atimwnd[i]);
for (i = 0; i < 8; i++)
rtw_write8(adapter, REG_TSFTR1 + i, tsftr[i]);
for (i = 0; i < 6; i++)
rtw_write8(adapter, REG_MACID1 + i, macid[i]);
for (i = 0; i < 6; i++)
rtw_write8(adapter, REG_BSSID1 + i, bssid[i]);
/* write bcn ctl */
#ifdef CONFIG_BT_COEXIST
/* always enable port0 beacon function for PSTDMA */
if (IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
|| IS_HARDWARE_TYPE_8723D(adapter))
bcn_ctrl_1 |= EN_BCN_FUNCTION;
/* always disable port1 beacon function for PSTDMA */
if (IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8703B(adapter))
bcn_ctrl &= ~EN_BCN_FUNCTION;
#endif
rtw_write8(adapter, REG_BCN_CTRL, bcn_ctrl_1);
rtw_write8(adapter, REG_BCN_CTRL_1, bcn_ctrl);
#if defined(CONFIG_RTL8192F)
/* if the setting of port0 and port1 are the same, it does not need to switch port setting*/
if(((wlan_act_mask_ctrl & en_port_mask) != 0) && ((wlan_act_mask_ctrl & en_port_mask)
!= (EN_PORT_0_FUNCTION | EN_PORT_1_FUNCTION)))
wlan_act_mask_ctrl ^= en_port_mask;
rtw_write16(adapter, REG_WLAN_ACT_MASK_CTRL_1, wlan_act_mask_ctrl);
#endif
if (adapter->iface_id == IFACE_ID0)
iface = dvobj->padapters[IFACE_ID1];
else if (adapter->iface_id == IFACE_ID1)
iface = dvobj->padapters[IFACE_ID0];
if (adapter->hw_port == HW_PORT0) {
adapter->hw_port = HW_PORT1;
iface->hw_port = HW_PORT0;
RTW_PRINT("port switch - port0("ADPT_FMT"), port1("ADPT_FMT")\n",
ADPT_ARG(iface), ADPT_ARG(adapter));
} else {
adapter->hw_port = HW_PORT0;
iface->hw_port = HW_PORT1;
RTW_PRINT("port switch - port0("ADPT_FMT"), port1("ADPT_FMT")\n",
ADPT_ARG(adapter), ADPT_ARG(iface));
}
#ifdef DBG_RUNTIME_PORT_SWITCH
msr = rtw_read8(adapter, MSR);
bcn_ctrl = rtw_read8(adapter, REG_BCN_CTRL);
bcn_ctrl_1 = rtw_read8(adapter, REG_BCN_CTRL_1);
#if defined(CONFIG_RTL8192F)
wlan_act_mask_ctrl = rtw_read16(adapter, REG_WLAN_ACT_MASK_CTRL_1);
#endif
for (i = 0; i < 2; i++)
atimwnd[i] = rtw_read8(adapter, REG_ATIMWND + i);
for (i = 0; i < 2; i++)
atimwnd_1[i] = rtw_read8(adapter, REG_ATIMWND_1 + i);
for (i = 0; i < 8; i++)
tsftr[i] = rtw_read8(adapter, REG_TSFTR + i);
for (i = 0; i < 8; i++)
tsftr_1[i] = rtw_read8(adapter, REG_TSFTR1 + i);
for (i = 0; i < 6; i++)
macid[i] = rtw_read8(adapter, REG_MACID + i);
for (i = 0; i < 6; i++)
bssid[i] = rtw_read8(adapter, REG_BSSID + i);
for (i = 0; i < 6; i++)
macid_1[i] = rtw_read8(adapter, REG_MACID1 + i);
for (i = 0; i < 6; i++)
bssid_1[i] = rtw_read8(adapter, REG_BSSID1 + i);
RTW_INFO(FUNC_ADPT_FMT" after switch\n"
"msr:0x%02x\n"
"bcn_ctrl:0x%02x\n"
"bcn_ctrl_1:0x%02x\n"
#if defined(CONFIG_RTL8192F)
"wlan_act_mask_ctrl:0x%02x\n"
#endif
"atimwnd:%u\n"
"atimwnd_1:%u\n"
"tsftr:%llu\n"
"tsftr1:%llu\n"
"macid:"MAC_FMT"\n"
"bssid:"MAC_FMT"\n"
"macid_1:"MAC_FMT"\n"
"bssid_1:"MAC_FMT"\n"
, FUNC_ADPT_ARG(adapter)
, msr
, bcn_ctrl
, bcn_ctrl_1
#if defined(CONFIG_RTL8192F)
, wlan_act_mask_ctrl
#endif
, *((u16 *)atimwnd)
, *((u16 *)atimwnd_1)
, *((u64 *)tsftr)
, *((u64 *)tsftr_1)
, MAC_ARG(macid)
, MAC_ARG(bssid)
, MAC_ARG(macid_1)
, MAC_ARG(bssid_1)
);
#endif /* DBG_RUNTIME_PORT_SWITCH */
#endif /* CONFIG_RUNTIME_PORT_SWITCH */
#endif /* CONFIG_CONCURRENT_MODE */
}
const char *const _h2c_msr_role_str[] = {
"RSVD",
"STA",
"AP",
"GC",
"GO",
"TDLS",
"ADHOC",
"MESH",
"INVALID",
};
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
s32 rtw_hal_set_default_port_id_cmd(_adapter *adapter, u8 mac_id)
{
s32 ret = _SUCCESS;
u8 parm[H2C_DEFAULT_PORT_ID_LEN] = {0};
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 port_id = rtw_hal_get_port(adapter);
if ((dvobj->dft.port_id == port_id) && (dvobj->dft.mac_id == mac_id))
return ret;
SET_H2CCMD_DFTPID_PORT_ID(parm, port_id);
SET_H2CCMD_DFTPID_MAC_ID(parm, mac_id);
RTW_DBG_DUMP("DFT port id parm:", parm, H2C_DEFAULT_PORT_ID_LEN);
RTW_INFO("%s ("ADPT_FMT") port_id :%d, mad_id:%d\n",
__func__, ADPT_ARG(adapter), port_id, mac_id);
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_DEFAULT_PORT_ID, H2C_DEFAULT_PORT_ID_LEN, parm);
dvobj->dft.port_id = port_id;
dvobj->dft.mac_id = mac_id;
return ret;
}
s32 rtw_set_default_port_id(_adapter *adapter)
{
s32 ret = _SUCCESS;
struct sta_info *psta;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
if (is_client_associated_to_ap(adapter)) {
psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
if (psta)
ret = rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
} else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == _TRUE) {
} else {
}
return ret;
}
s32 rtw_set_ps_rsvd_page(_adapter *adapter)
{
s32 ret = _SUCCESS;
u16 media_status_rpt = RT_MEDIA_CONNECT;
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
if (adapter->iface_id == pwrctl->fw_psmode_iface_id)
return ret;
rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
(u8 *)&media_status_rpt);
return ret;
}
#if 0
_adapter * _rtw_search_dp_iface(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface;
_adapter *target_iface = NULL;
int i;
u8 sta_num = 0, tdls_num = 0, ap_num = 0, mesh_num = 0, adhoc_num = 0;
u8 p2p_go_num = 0, p2p_gc_num = 0;
_adapter *sta_ifs[8];
_adapter *ap_ifs[8];
_adapter *mesh_ifs[8];
_adapter *gc_ifs[8];
_adapter *go_ifs[8];
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
sta_ifs[sta_num++] = iface;
#ifdef CONFIG_TDLS
if (iface->tdlsinfo.link_established == _TRUE)
tdls_num++;
#endif
#ifdef CONFIG_P2P
if (MLME_IS_GC(iface))
gc_ifs[p2p_gc_num++] = iface;
#endif
}
#ifdef CONFIG_AP_MODE
} else if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
ap_ifs[ap_num++] = iface;
#ifdef CONFIG_P2P
if (MLME_IS_GO(iface))
go_ifs[p2p_go_num++] = iface;
#endif
}
#endif
} else if (check_fwstate(&iface->mlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE) == _TRUE
&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
) {
adhoc_num++;
#ifdef CONFIG_RTW_MESH
} else if (check_fwstate(&iface->mlmepriv, WIFI_MESH_STATE) == _TRUE
&& check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE
) {
mesh_ifs[mesh_num++] = iface;
#endif
}
}
if (p2p_gc_num) {
target_iface = gc_ifs[0];
}
else if (sta_num) {
if(sta_num == 1) {
target_iface = sta_ifs[0];
} else if (sta_num >= 2) {
/*TODO get target_iface by timestamp*/
target_iface = sta_ifs[0];
}
} else if (ap_num) {
target_iface = ap_ifs[0];
}
RTW_INFO("[IFS_ASSOC_STATUS] - STA :%d", sta_num);
RTW_INFO("[IFS_ASSOC_STATUS] - TDLS :%d", tdls_num);
RTW_INFO("[IFS_ASSOC_STATUS] - AP:%d", ap_num);
RTW_INFO("[IFS_ASSOC_STATUS] - MESH :%d", mesh_num);
RTW_INFO("[IFS_ASSOC_STATUS] - ADHOC :%d", adhoc_num);
RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GC :%d", p2p_gc_num);
RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GO :%d", p2p_go_num);
if (target_iface)
RTW_INFO("%s => target_iface ("ADPT_FMT")\n",
__func__, ADPT_ARG(target_iface));
else
RTW_INFO("%s => target_iface NULL\n", __func__);
return target_iface;
}
void rtw_search_default_port(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *adp_iface = NULL;
#ifdef CONFIG_WOWLAN
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
if (pwrpriv->wowlan_mode == _TRUE) {
adp_iface = adapter;
goto exit;
}
#endif
adp_iface = _rtw_search_dp_iface(adapter);
exit :
if ((adp_iface != NULL) && (MLME_IS_STA(adp_iface)))
rtw_set_default_port_id(adp_iface);
else
rtw_hal_set_default_port_id_cmd(adapter, 0);
if (1) {
_adapter *tmp_adp;
tmp_adp = (adp_iface) ? adp_iface : adapter;
RTW_INFO("%s ("ADPT_FMT")=> hw_port :%d, default_port(%d)\n",
__func__, ADPT_ARG(adapter), get_hw_port(tmp_adp), get_dft_portid(tmp_adp));
}
}
#endif
#endif /*CONFIG_FW_MULTI_PORT_SUPPORT*/
#ifdef CONFIG_P2P_PS
#ifdef RTW_HALMAC
void rtw_set_p2p_ps_offload_cmd(_adapter *adapter, u8 p2p_ps_state)
{
PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
struct wifidirect_info *pwdinfo = &adapter->wdinfo;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta;
HAL_P2P_PS_PARA p2p_ps_para;
int status = -1;
u8 i;
u8 hw_port = rtw_hal_get_port(adapter);
_rtw_memset(&p2p_ps_para, 0, sizeof(HAL_P2P_PS_PARA));
_rtw_memcpy((&p2p_ps_para) , &hal->p2p_ps_offload , sizeof(hal->p2p_ps_offload));
(&p2p_ps_para)->p2p_port_id = hw_port;
(&p2p_ps_para)->p2p_group = 0;
psta = rtw_get_stainfo(pstapriv, cur_network->MacAddress);
if (psta) {
(&p2p_ps_para)->p2p_macid = psta->cmn.mac_id;
} else {
if (p2p_ps_state != P2P_PS_DISABLE) {
RTW_ERR("%s , psta was NULL\n", __func__);
return;
}
}
switch (p2p_ps_state) {
case P2P_PS_DISABLE:
RTW_INFO("P2P_PS_DISABLE\n");
_rtw_memset(&p2p_ps_para , 0, sizeof(HAL_P2P_PS_PARA));
break;
case P2P_PS_ENABLE:
RTW_INFO("P2P_PS_ENABLE\n");
/* update CTWindow value. */
if (pwdinfo->ctwindow > 0) {
(&p2p_ps_para)->ctwindow_en = 1;
(&p2p_ps_para)->ctwindow_length = pwdinfo->ctwindow;
/*RTW_INFO("%s , ctwindow_length = %d\n" , __func__ , (&p2p_ps_para)->ctwindow_length);*/
}
if ((pwdinfo->opp_ps == 1) || (pwdinfo->noa_num > 0)) {
(&p2p_ps_para)->offload_en = 1;
if (pwdinfo->role == P2P_ROLE_GO) {
(&p2p_ps_para)->role = 1;
(&p2p_ps_para)->all_sta_sleep = 0;
} else
(&p2p_ps_para)->role = 0;
(&p2p_ps_para)->discovery = 0;
}
/* hw only support 2 set of NoA */
for (i = 0; i < pwdinfo->noa_num; i++) {
/* To control the register setting for which NOA */
(&p2p_ps_para)->noa_sel = i;
(&p2p_ps_para)->noa_en = 1;
(&p2p_ps_para)->disable_close_rf = 0;
#ifdef CONFIG_P2P_PS_NOA_USE_MACID_SLEEP
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(adapter, WIFI_ASOC_STATE))
#endif /* CONFIG_CONCURRENT_MODE */
(&p2p_ps_para)->disable_close_rf = 1;
#endif /* CONFIG_P2P_PS_NOA_USE_MACID_SLEEP */
/* config P2P NoA Descriptor Register */
/* config NOA duration */
(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[i];
/* config NOA interval */
(&p2p_ps_para)->noa_interval_para = pwdinfo->noa_interval[i];
/* config NOA start time */
(&p2p_ps_para)->noa_start_time_para = pwdinfo->noa_start_time[i];
/* config NOA count */
(&p2p_ps_para)->noa_count_para = pwdinfo->noa_count[i];
/*RTW_INFO("%s , noa_duration_para = %d , noa_interval_para = %d , noa_start_time_para = %d , noa_count_para = %d\n" , __func__ ,
(&p2p_ps_para)->noa_duration_para , (&p2p_ps_para)->noa_interval_para ,
(&p2p_ps_para)->noa_start_time_para , (&p2p_ps_para)->noa_count_para);*/
status = rtw_halmac_p2pps(adapter_to_dvobj(adapter) , (&p2p_ps_para));
if (status == -1)
RTW_ERR("%s , rtw_halmac_p2pps fail\n", __func__);
}
break;
case P2P_PS_SCAN:
/*This feature FW not ready 20161116 YiWei*/
return;
RTW_INFO("P2P_PS_SCAN\n");
(&p2p_ps_para)->discovery = 1;
/*
(&p2p_ps_para)->ctwindow_length = pwdinfo->ctwindow;
(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[0];
(&p2p_ps_para)->noa_interval_para = pwdinfo->noa_interval[0];
(&p2p_ps_para)->noa_start_time_para = pwdinfo->noa_start_time[0];
(&p2p_ps_para)->noa_count_para = pwdinfo->noa_count[0];
*/
break;
case P2P_PS_SCAN_DONE:
/*This feature FW not ready 20161116 YiWei*/
return;
RTW_INFO("P2P_PS_SCAN_DONE\n");
(&p2p_ps_para)->discovery = 0;
/*
pwdinfo->p2p_ps_state = P2P_PS_ENABLE;
(&p2p_ps_para)->ctwindow_length = pwdinfo->ctwindow;
(&p2p_ps_para)->noa_duration_para = pwdinfo->noa_duration[0];
(&p2p_ps_para)->noa_interval_para = pwdinfo->noa_interval[0];
(&p2p_ps_para)->noa_start_time_para = pwdinfo->noa_start_time[0];
(&p2p_ps_para)->noa_count_para = pwdinfo->noa_count[0];
*/
break;
default:
break;
}
if (p2p_ps_state != P2P_PS_ENABLE || (&p2p_ps_para)->noa_en == 0) {
status = rtw_halmac_p2pps(adapter_to_dvobj(adapter) , (&p2p_ps_para));
if (status == -1)
RTW_ERR("%s , rtw_halmac_p2pps fail\n", __func__);
}
_rtw_memcpy(&hal->p2p_ps_offload , (&p2p_ps_para) , sizeof(hal->p2p_ps_offload));
}
#endif /* RTW_HALMAC */
#endif /* CONFIG_P2P */
/*
* rtw_hal_set_FwMediaStatusRpt_cmd -
*
* @adapter:
* @opmode: 0:disconnect, 1:connect
* @miracast: 0:it's not in miracast scenario. 1:it's in miracast scenario
* @miracast_sink: 0:source. 1:sink
* @role: The role of this macid. 0:rsvd. 1:STA. 2:AP. 3:GC. 4:GO. 5:TDLS
* @macid:
* @macid_ind: 0:update Media Status to macid. 1:update Media Status from macid to macid_end
* @macid_end:
*/
s32 rtw_hal_set_FwMediaStatusRpt_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, bool macid_ind, u8 macid_end)
{
struct macid_ctl_t *macid_ctl = &adapter->dvobj->macid_ctl;
u8 parm[H2C_MEDIA_STATUS_RPT_LEN] = {0};
int i;
s32 ret;
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
u8 hw_port = rtw_hal_get_port(adapter);
#endif
u8 op_num_change_bmp = 0;
SET_H2CCMD_MSRRPT_PARM_OPMODE(parm, opmode);
SET_H2CCMD_MSRRPT_PARM_MACID_IND(parm, macid_ind);
SET_H2CCMD_MSRRPT_PARM_MIRACAST(parm, miracast);
SET_H2CCMD_MSRRPT_PARM_MIRACAST_SINK(parm, miracast_sink);
SET_H2CCMD_MSRRPT_PARM_ROLE(parm, role);
SET_H2CCMD_MSRRPT_PARM_MACID(parm, macid);
SET_H2CCMD_MSRRPT_PARM_MACID_END(parm, macid_end);
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
SET_H2CCMD_MSRRPT_PARM_PORT_NUM(parm, hw_port);
#endif
RTW_DBG_DUMP("MediaStatusRpt parm:", parm, H2C_MEDIA_STATUS_RPT_LEN);
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_MEDIA_STATUS_RPT, H2C_MEDIA_STATUS_RPT_LEN, parm);
if (ret != _SUCCESS)
goto exit;
#if defined(CONFIG_RTL8188E)
if (rtw_get_chip_type(adapter) == RTL8188E) {
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
/* 8188E FW doesn't set macid no link, driver does it by self */
if (opmode)
rtw_hal_set_hwreg(adapter, HW_VAR_MACID_LINK, &macid);
else
rtw_hal_set_hwreg(adapter, HW_VAR_MACID_NOLINK, &macid);
/* for 8188E RA */
#if (RATE_ADAPTIVE_SUPPORT == 1)
if (hal_data->fw_ractrl == _FALSE) {
u8 max_macid;
max_macid = rtw_search_max_mac_id(adapter);
rtw_hal_set_hwreg(adapter, HW_VAR_TX_RPT_MAX_MACID, &max_macid);
}
#endif
}
#endif
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
/* TODO: this should move to IOT issue area */
if (rtw_get_chip_type(adapter) == RTL8812
|| rtw_get_chip_type(adapter) == RTL8821
) {
if (MLME_IS_STA(adapter))
Hal_PatchwithJaguar_8812(adapter, opmode);
}
#endif
SET_H2CCMD_MSRRPT_PARM_MACID_IND(parm, 0);
if (macid_ind == 0)
macid_end = macid;
for (i = macid; macid <= macid_end; macid++) {
op_num_change_bmp |= rtw_macid_ctl_set_h2c_msr(macid_ctl, macid, parm[0]);
if (!opmode) {
rtw_macid_ctl_set_bw(macid_ctl, macid, CHANNEL_WIDTH_20);
rtw_macid_ctl_set_vht_en(macid_ctl, macid, 0);
rtw_macid_ctl_set_rate_bmp0(macid_ctl, macid, 0);
rtw_macid_ctl_set_rate_bmp1(macid_ctl, macid, 0);
}
}
#if CONFIG_TX_AC_LIFETIME
if (op_num_change_bmp)
rtw_hal_update_tx_aclt(adapter);
#endif
if (!opmode)
rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
exit:
return ret;
}
inline s32 rtw_hal_set_FwMediaStatusRpt_single_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid)
{
return rtw_hal_set_FwMediaStatusRpt_cmd(adapter, opmode, miracast, miracast_sink, role, macid, 0, 0);
}
inline s32 rtw_hal_set_FwMediaStatusRpt_range_cmd(_adapter *adapter, bool opmode, bool miracast, bool miracast_sink, u8 role, u8 macid, u8 macid_end)
{
return rtw_hal_set_FwMediaStatusRpt_cmd(adapter, opmode, miracast, miracast_sink, role, macid, 1, macid_end);
}
void rtw_hal_set_FwRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
{
struct hal_ops *pHalFunc = &padapter->hal_func;
u8 u1H2CRsvdPageParm[H2C_RSVDPAGE_LOC_LEN] = {0};
u8 ret = 0;
RTW_INFO("RsvdPageLoc: ProbeRsp=%d PsPoll=%d Null=%d QoSNull=%d BTNull=%d\n",
rsvdpageloc->LocProbeRsp, rsvdpageloc->LocPsPoll,
rsvdpageloc->LocNullData, rsvdpageloc->LocQosNull,
rsvdpageloc->LocBTQosNull);
SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(u1H2CRsvdPageParm, rsvdpageloc->LocProbeRsp);
SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(u1H2CRsvdPageParm, rsvdpageloc->LocPsPoll);
SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocNullData);
SET_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocQosNull);
SET_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(u1H2CRsvdPageParm, rsvdpageloc->LocBTQosNull);
ret = rtw_hal_fill_h2c_cmd(padapter,
H2C_RSVD_PAGE,
H2C_RSVDPAGE_LOC_LEN,
u1H2CRsvdPageParm);
}
#ifdef CONFIG_GPIO_WAKEUP
void rtw_hal_switch_gpio_wl_ctrl(_adapter *padapter, u8 index, u8 enable)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
if (IS_8723D_SERIES(pHalData->version_id) || IS_8192F_SERIES(pHalData->version_id)
|| IS_8822B_SERIES(pHalData->version_id) || IS_8821C_SERIES(pHalData->version_id)
|| IS_8822C_SERIES(pHalData->version_id))
rtw_hal_set_hwreg(padapter, HW_SET_GPIO_WL_CTRL, (u8 *)(&enable));
/*
* Switch GPIO_13, GPIO_14 to wlan control, or pull GPIO_13,14 MUST fail.
* It happended at 8723B/8192E/8821A. New IC will check multi function GPIO,
* and implement HAL function.
* TODO: GPIO_8 multi function?
*/
if ((index == 13 || index == 14)
#if defined(CONFIG_RTL8821A) && defined(CONFIG_SDIO_HCI)
/* 8821A's LED2 circuit(used by HW_LED strategy) needs enable WL GPIO control of GPIO[14:13], can't disable */
&& (!IS_HW_LED_STRATEGY(rtw_led_get_strategy(padapter)) || enable)
#endif
)
rtw_hal_set_hwreg(padapter, HW_SET_GPIO_WL_CTRL, (u8 *)(&enable));
}
void rtw_hal_set_output_gpio(_adapter *padapter, u8 index, u8 outputval)
{
#if defined(CONFIG_RTL8192F)
rtw_hal_set_hwreg(padapter, HW_VAR_WOW_OUTPUT_GPIO, (u8 *)(&index));
#else
if (index <= 7) {
/* config GPIO mode */
rtw_write8(padapter, REG_GPIO_PIN_CTRL + 3,
rtw_read8(padapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(index));
/* config GPIO Sel */
/* 0: input */
/* 1: output */
rtw_write8(padapter, REG_GPIO_PIN_CTRL + 2,
rtw_read8(padapter, REG_GPIO_PIN_CTRL + 2) | BIT(index));
/* set output value */
if (outputval) {
rtw_write8(padapter, REG_GPIO_PIN_CTRL + 1,
rtw_read8(padapter, REG_GPIO_PIN_CTRL + 1) | BIT(index));
} else {
rtw_write8(padapter, REG_GPIO_PIN_CTRL + 1,
rtw_read8(padapter, REG_GPIO_PIN_CTRL + 1) & ~BIT(index));
}
} else if (index <= 15) {
/* 88C Series: */
/* index: 11~8 transform to 3~0 */
/* 8723 Series: */
/* index: 12~8 transform to 4~0 */
index -= 8;
/* config GPIO mode */
rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 3,
rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 3) & ~BIT(index));
/* config GPIO Sel */
/* 0: input */
/* 1: output */
rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 2,
rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 2) | BIT(index));
/* set output value */
if (outputval) {
rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 1,
rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 1) | BIT(index));
} else {
rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 1,
rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 1) & ~BIT(index));
}
} else {
RTW_INFO("%s: invalid GPIO%d=%d\n",
__FUNCTION__, index, outputval);
}
#endif
}
void rtw_hal_set_input_gpio(_adapter *padapter, u8 index)
{
#if defined(CONFIG_RTL8192F)
rtw_hal_set_hwreg(padapter, HW_VAR_WOW_INPUT_GPIO, (u8 *)(&index));
#else
if (index <= 7) {
/* config GPIO mode */
rtw_write8(padapter, REG_GPIO_PIN_CTRL + 3,
rtw_read8(padapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(index));
/* config GPIO Sel */
/* 0: input */
/* 1: output */
rtw_write8(padapter, REG_GPIO_PIN_CTRL + 2,
rtw_read8(padapter, REG_GPIO_PIN_CTRL + 2) & ~BIT(index));
} else if (index <= 15) {
/* 88C Series: */
/* index: 11~8 transform to 3~0 */
/* 8723 Series: */
/* index: 12~8 transform to 4~0 */
index -= 8;
/* config GPIO mode */
rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 3,
rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 3) & ~BIT(index));
/* config GPIO Sel */
/* 0: input */
/* 1: output */
rtw_write8(padapter, REG_GPIO_PIN_CTRL_2 + 2,
rtw_read8(padapter, REG_GPIO_PIN_CTRL_2 + 2) & ~BIT(index));
} else
RTW_INFO("%s: invalid GPIO%d\n", __func__, index);
#endif
}
#endif
void rtw_hal_set_FwAoacRsvdPage_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
{
struct hal_ops *pHalFunc = &padapter->hal_func;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
u8 res = 0, count = 0, ret = 0;
#ifdef CONFIG_WOWLAN
u8 u1H2CAoacRsvdPageParm[H2C_AOAC_RSVDPAGE_LOC_LEN] = {0};
RTW_INFO("%s: RWC: %d ArpRsp: %d NbrAdv: %d LocNDPInfo: %d\n",
__func__, rsvdpageloc->LocRemoteCtrlInfo,
rsvdpageloc->LocArpRsp, rsvdpageloc->LocNbrAdv,
rsvdpageloc->LocNDPInfo);
RTW_INFO("%s:GtkRsp: %d GtkInfo: %d ProbeReq: %d NetworkList: %d\n",
__func__, rsvdpageloc->LocGTKRsp, rsvdpageloc->LocGTKInfo,
rsvdpageloc->LocProbeReq, rsvdpageloc->LocNetList);
if (check_fwstate(pmlmepriv, _FW_LINKED)) {
SET_H2CCMD_AOAC_RSVDPAGE_LOC_REMOTE_WAKE_CTRL_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocRemoteCtrlInfo);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_ARP_RSP(u1H2CAoacRsvdPageParm, rsvdpageloc->LocArpRsp);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_NEIGHBOR_ADV(u1H2CAoacRsvdPageParm,
rsvdpageloc->LocNbrAdv);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_NDP_INFO(u1H2CAoacRsvdPageParm,
rsvdpageloc->LocNDPInfo);
#ifdef CONFIG_GTK_OL
SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_RSP(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKRsp);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_INFO(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKInfo);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_GTK_EXT_MEM(u1H2CAoacRsvdPageParm, rsvdpageloc->LocGTKEXTMEM);
#endif /* CONFIG_GTK_OL */
ret = rtw_hal_fill_h2c_cmd(padapter,
H2C_AOAC_RSVD_PAGE,
H2C_AOAC_RSVDPAGE_LOC_LEN,
u1H2CAoacRsvdPageParm);
RTW_INFO("AOAC Report=%d\n", rsvdpageloc->LocAOACReport);
_rtw_memset(&u1H2CAoacRsvdPageParm, 0, sizeof(u1H2CAoacRsvdPageParm));
SET_H2CCMD_AOAC_RSVDPAGE_LOC_AOAC_REPORT(u1H2CAoacRsvdPageParm,
rsvdpageloc->LocAOACReport);
ret = rtw_hal_fill_h2c_cmd(padapter,
H2C_AOAC_RSVDPAGE3,
H2C_AOAC_RSVDPAGE_LOC_LEN,
u1H2CAoacRsvdPageParm);
pwrpriv->wowlan_aoac_rpt_loc = rsvdpageloc->LocAOACReport;
}
#ifdef CONFIG_PNO_SUPPORT
else {
if (!pwrpriv->wowlan_in_resume) {
RTW_INFO("NLO_INFO=%d\n", rsvdpageloc->LocPNOInfo);
_rtw_memset(&u1H2CAoacRsvdPageParm, 0,
sizeof(u1H2CAoacRsvdPageParm));
SET_H2CCMD_AOAC_RSVDPAGE_LOC_NLO_INFO(u1H2CAoacRsvdPageParm,
rsvdpageloc->LocPNOInfo);
ret = rtw_hal_fill_h2c_cmd(padapter,
H2C_AOAC_RSVDPAGE3,
H2C_AOAC_RSVDPAGE_LOC_LEN,
u1H2CAoacRsvdPageParm);
}
}
#endif /* CONFIG_PNO_SUPPORT */
#endif /* CONFIG_WOWLAN */
}
#ifdef DBG_FW_DEBUG_MSG_PKT
void rtw_hal_set_fw_dbg_msg_pkt_rsvd_page_cmd(PADAPTER padapter, PRSVDPAGE_LOC rsvdpageloc)
{
struct hal_ops *pHalFunc = &padapter->hal_func;
u8 u1H2C_fw_dbg_msg_pkt_parm[H2C_FW_DBG_MSG_PKT_LEN] = {0};
u8 ret = 0;
RTW_INFO("RsvdPageLoc: loc_fw_dbg_msg_pkt =%d\n", rsvdpageloc->loc_fw_dbg_msg_pkt);
SET_H2CCMD_FW_DBG_MSG_PKT_EN(u1H2C_fw_dbg_msg_pkt_parm, 1);
SET_H2CCMD_RSVDPAGE_LOC_FW_DBG_MSG_PKT(u1H2C_fw_dbg_msg_pkt_parm, rsvdpageloc->loc_fw_dbg_msg_pkt);
ret = rtw_hal_fill_h2c_cmd(padapter,
H2C_FW_DBG_MSG_PKT,
H2C_FW_DBG_MSG_PKT_LEN,
u1H2C_fw_dbg_msg_pkt_parm);
}
#endif /*DBG_FW_DEBUG_MSG_PKT*/
/*#define DBG_GET_RSVD_PAGE*/
int rtw_hal_get_rsvd_page(_adapter *adapter, u32 page_offset,
u32 page_num, u8 *buffer, u32 buffer_size)
{
u32 addr = 0, size = 0, count = 0;
u32 page_size = 0, data_low = 0, data_high = 0;
u16 txbndy = 0, offset = 0;
u8 i = 0;
bool rst = _FALSE;
#ifdef DBG_LA_MODE
struct registry_priv *registry_par = &adapter->registrypriv;
if(registry_par->la_mode_en == 1) {
RTW_INFO("%s LA debug mode can't dump rsvd pg \n", __func__);
return rst;
}
#endif
rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
addr = page_offset * page_size;
size = page_num * page_size;
if (buffer_size < size) {
RTW_ERR("%s buffer_size(%d) < get page total size(%d)\n",
__func__, buffer_size, size);
return rst;
}
#ifdef RTW_HALMAC
if (rtw_halmac_dump_fifo(adapter_to_dvobj(adapter), 2, addr, size, buffer) < 0)
rst = _FALSE;
else
rst = _TRUE;
#else
txbndy = rtw_read8(adapter, REG_TDECTRL + 1);
offset = (txbndy + page_offset) * page_size / 8;
count = (buffer_size / 8) + 1;
rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, 0x69);
for (i = 0 ; i < count ; i++) {
rtw_write32(adapter, REG_PKTBUF_DBG_CTRL, offset + i);
data_low = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_L);
data_high = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_H);
_rtw_memcpy(buffer + (i * 8),
&data_low, sizeof(data_low));
_rtw_memcpy(buffer + ((i * 8) + 4),
&data_high, sizeof(data_high));
}
rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, 0x0);
rst = _TRUE;
#endif /*RTW_HALMAC*/
#ifdef DBG_GET_RSVD_PAGE
RTW_INFO("%s [page_offset:%d , page_num:%d][start_addr:0x%04x , size:%d]\n",
__func__, page_offset, page_num, addr, size);
RTW_INFO_DUMP("\n", buffer, size);
RTW_INFO(" ==================================================\n");
#endif
return rst;
}
void rtw_dump_rsvd_page(void *sel, _adapter *adapter, u8 page_offset, u8 page_num)
{
u32 page_size = 0;
u8 *buffer = NULL;
u32 buf_size = 0;
if (page_num == 0)
return;
RTW_PRINT_SEL(sel, "======= RSVD PAGE DUMP =======\n");
RTW_PRINT_SEL(sel, "page_offset:%d, page_num:%d\n", page_offset, page_num);
rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
if (page_size) {
buf_size = page_size * page_num;
buffer = rtw_zvmalloc(buf_size);
if (buffer) {
rtw_hal_get_rsvd_page(adapter, page_offset, page_num, buffer, buf_size);
RTW_DUMP_SEL(sel, buffer, buf_size);
rtw_vmfree(buffer, buf_size);
} else
RTW_PRINT_SEL(sel, "ERROR - rsvd_buf mem allocate failed\n");
} else
RTW_PRINT_SEL(sel, "ERROR - Tx page size is zero ??\n");
RTW_PRINT_SEL(sel, "==========================\n");
}
#ifdef CONFIG_SUPPORT_FIFO_DUMP
void rtw_dump_fifo(void *sel, _adapter *adapter, u8 fifo_sel, u32 fifo_addr, u32 fifo_size)
{
u8 *buffer = NULL;
u32 buff_size = 0;
static const char * const fifo_sel_str[] = {
"TX", "RX", "RSVD_PAGE", "REPORT", "LLT", "RXBUF_FW"
};
if (fifo_sel > 5) {
RTW_ERR("fifo_sel:%d invalid\n", fifo_sel);
return;
}
RTW_PRINT_SEL(sel, "========= FIFO DUMP =========\n");
RTW_PRINT_SEL(sel, "%s FIFO DUMP [start_addr:0x%04x , size:%d]\n", fifo_sel_str[fifo_sel], fifo_addr, fifo_size);
if (fifo_size) {
buff_size = RND4(fifo_size);
buffer = rtw_zvmalloc(buff_size);
if (buffer == NULL)
buff_size = 0;
}
rtw_halmac_dump_fifo(adapter_to_dvobj(adapter), fifo_sel, fifo_addr, buff_size, buffer);
if (buffer) {
RTW_DUMP_SEL(sel, buffer, fifo_size);
rtw_vmfree(buffer, buff_size);
}
RTW_PRINT_SEL(sel, "==========================\n");
}
#endif
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
static void rtw_hal_force_enable_rxdma(_adapter *adapter)
{
RTW_INFO("%s: Set 0x690=0x00\n", __func__);
rtw_write8(adapter, REG_WOW_CTRL,
(rtw_read8(adapter, REG_WOW_CTRL) & 0xf0));
RTW_PRINT("%s: Release RXDMA\n", __func__);
rtw_write32(adapter, REG_RXPKT_NUM,
(rtw_read32(adapter, REG_RXPKT_NUM) & (~RW_RELEASE_EN)));
}
#if defined(CONFIG_RTL8188E)
static void rtw_hal_disable_tx_report(_adapter *adapter)
{
rtw_write8(adapter, REG_TX_RPT_CTRL,
((rtw_read8(adapter, REG_TX_RPT_CTRL) & ~BIT(1))) & ~BIT(5));
RTW_INFO("disable TXRPT:0x%02x\n", rtw_read8(adapter, REG_TX_RPT_CTRL));
}
static void rtw_hal_enable_tx_report(_adapter *adapter)
{
rtw_write8(adapter, REG_TX_RPT_CTRL,
((rtw_read8(adapter, REG_TX_RPT_CTRL) | BIT(1))) | BIT(5));
RTW_INFO("enable TX_RPT:0x%02x\n", rtw_read8(adapter, REG_TX_RPT_CTRL));
}
#endif
static void rtw_hal_release_rx_dma(_adapter *adapter)
{
u32 val32 = 0;
val32 = rtw_read32(adapter, REG_RXPKT_NUM);
rtw_write32(adapter, REG_RXPKT_NUM, (val32 & (~RW_RELEASE_EN)));
RTW_INFO("%s, [0x%04x]: 0x%08x\n",
__func__, REG_RXPKT_NUM, (u32)(val32 & (~RW_RELEASE_EN)));
}
static u8 rtw_hal_pause_rx_dma(_adapter *adapter)
{
PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
u8 ret = 0;
s8 trycnt = 100;
u32 tmp = 0;
int res = 0;
/* RX DMA stop */
RTW_PRINT("Pause DMA\n");
rtw_write32(adapter, REG_RXPKT_NUM,
(rtw_read32(adapter, REG_RXPKT_NUM) | RW_RELEASE_EN));
do {
if ((rtw_read32(adapter, REG_RXPKT_NUM) & RXDMA_IDLE)) {
#ifdef CONFIG_USB_HCI
/* stop interface before leave */
if (_TRUE == hal->usb_intf_start) {
rtw_intf_stop(adapter);
RTW_ENABLE_FUNC(adapter, DF_RX_BIT);
RTW_ENABLE_FUNC(adapter, DF_TX_BIT);
}
#endif /* CONFIG_USB_HCI */
RTW_PRINT("RX_DMA_IDLE is true\n");
ret = _SUCCESS;
break;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
else {
res = RecvOnePkt(adapter);
RTW_PRINT("RecvOnePkt Result: %d\n", res);
}
#endif /* CONFIG_SDIO_HCI || CONFIG_GSPI_HCI */
#ifdef CONFIG_USB_HCI
else {
/* to avoid interface start repeatedly */
if (_FALSE == hal->usb_intf_start)
rtw_intf_start(adapter);
}
#endif /* CONFIG_USB_HCI */
} while (trycnt--);
if (trycnt < 0) {
tmp = rtw_read16(adapter, REG_RXPKT_NUM + 2);
RTW_PRINT("Stop RX DMA failed......\n");
#ifdef CONFIG_RTL8822C
RTW_PRINT("%s, RXPKT_NUM: 0x%04x\n",
__func__, rtw_read16(adapter, 0x02B0));
#else
RTW_PRINT("%s, RXPKT_NUM: 0x%02x\n",
__func__, ((tmp & 0xFF00) >> 8));
#endif
if (tmp & BIT(3))
RTW_PRINT("%s, RX DMA has req\n",
__func__);
else
RTW_PRINT("%s, RX DMA no req\n",
__func__);
ret = _FAIL;
}
return ret;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
#ifndef RTW_HALMAC
static u8 rtw_hal_enable_cpwm2(_adapter *adapter)
{
u8 ret = 0;
int res = 0;
u32 tmp = 0;
#ifdef CONFIG_GPIO_WAKEUP
return _SUCCESS;
#else
RTW_PRINT("%s\n", __func__);
res = sdio_local_read(adapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
if (!res)
RTW_INFO("read SDIO_REG_HIMR: 0x%08x\n", tmp);
else
RTW_INFO("sdio_local_read fail\n");
tmp = SDIO_HIMR_CPWM2_MSK;
res = sdio_local_write(adapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
if (!res) {
res = sdio_local_read(adapter, SDIO_REG_HIMR, 4, (u8 *)&tmp);
RTW_INFO("read again SDIO_REG_HIMR: 0x%08x\n", tmp);
ret = _SUCCESS;
} else {
RTW_INFO("sdio_local_write fail\n");
ret = _FAIL;
}
return ret;
#endif /* CONFIG_CPIO_WAKEUP */
}
#endif
#endif /* CONFIG_SDIO_HCI, CONFIG_GSPI_HCI */
#endif /* CONFIG_WOWLAN || CONFIG_AP_WOWLAN */
#ifdef CONFIG_WOWLAN
/*
* rtw_hal_check_wow_ctrl
* chk_type: _TRUE means to check enable, if 0x690 & bit1 (for 8051), WOW enable successful.
* If 0x1C7 == 0 (for 3081), WOW enable successful.
* _FALSE means to check disable, if 0x690 & bit1 (for 8051), WOW disable fail.
* If 0x120 & bit16 || 0x284 & bit18 (for 3081), WOW disable fail.
*/
static u8 rtw_hal_check_wow_ctrl(_adapter *adapter, u8 chk_type)
{
u32 fe1_imr = 0xFF, rxpkt_num = 0xFF;
u8 mstatus = 0;
u8 reason = 0xFF;
u8 trycnt = 25;
u8 res = _FALSE;
if (IS_HARDWARE_TYPE_JAGUAR2(adapter) || IS_HARDWARE_TYPE_JAGUAR3(adapter)) {
if (chk_type) {
reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
RTW_INFO("%s reason:0x%02x\n", __func__, reason);
while (reason && trycnt > 1) {
reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
RTW_PRINT("Loop index: %d :0x%02x\n",
trycnt, reason);
trycnt--;
rtw_msleep_os(20);
}
if (!reason)
res = _TRUE;
else
res = _FALSE;
} else {
/* Wait FW to cleare 0x120 bit16, 0x284 bit18 to 0 */
fe1_imr = rtw_read32(adapter, REG_FE1IMR); /* RxDone IMR for 3081 */
rxpkt_num = rtw_read32(adapter, REG_RXPKT_NUM); /* Release RXDMA */
RTW_PRINT("%s REG_FE1IMR (reg120): 0x%x, REG_RXPKT_NUM(reg284): 0x%x\n", __func__, fe1_imr, rxpkt_num);
while (((fe1_imr & BIT_FS_RXDONE_INT_EN) || (rxpkt_num & BIT_RW_RELEASE_EN)) && trycnt > 1) {
rtw_msleep_os(20);
fe1_imr = rtw_read32(adapter, REG_FE1IMR);
rxpkt_num = rtw_read32(adapter, REG_RXPKT_NUM);
RTW_PRINT("Loop index: %d :0x%x, 0x%x\n",
trycnt, fe1_imr, rxpkt_num);
trycnt--;
}
if ((fe1_imr & BIT_FS_RXDONE_INT_EN) || (rxpkt_num & BIT_RW_RELEASE_EN))
res = _FALSE;
else
res = _TRUE;
}
} else {
mstatus = rtw_read8(adapter, REG_WOW_CTRL);
RTW_INFO("%s mstatus:0x%02x\n", __func__, mstatus);
if (chk_type) {
while (!(mstatus & BIT1) && trycnt > 1) {
mstatus = rtw_read8(adapter, REG_WOW_CTRL);
RTW_PRINT("Loop index: %d :0x%02x\n",
trycnt, mstatus);
trycnt--;
rtw_msleep_os(20);
}
if (mstatus & BIT1)
res = _TRUE;
else
res = _FALSE;
} else {
while (mstatus & BIT1 && trycnt > 1) {
mstatus = rtw_read8(adapter, REG_WOW_CTRL);
RTW_PRINT("Loop index: %d :0x%02x\n",
trycnt, mstatus);
trycnt--;
rtw_msleep_os(20);
}
if (mstatus & BIT1)
res = _FALSE;
else
res = _TRUE;
}
}
RTW_PRINT("%s check_type: %d res: %d trycnt: %d\n",
__func__, chk_type, res, (25 - trycnt));
return res;
}
#ifdef CONFIG_PNO_SUPPORT
static u8 rtw_hal_check_pno_enabled(_adapter *adapter)
{
struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
u8 res = 0, count = 0;
u8 ret = _FALSE;
if (ppwrpriv->wowlan_pno_enable && ppwrpriv->wowlan_in_resume == _FALSE) {
res = rtw_read8(adapter, REG_PNO_STATUS);
while (!(res & BIT(7)) && count < 25) {
RTW_INFO("[%d] cmd: 0x81 REG_PNO_STATUS: 0x%02x\n",
count, res);
res = rtw_read8(adapter, REG_PNO_STATUS);
count++;
rtw_msleep_os(2);
}
if (res & BIT(7))
ret = _TRUE;
else
ret = _FALSE;
RTW_INFO("cmd: 0x81 REG_PNO_STATUS: ret(%d)\n", ret);
}
return ret;
}
#endif
static void rtw_hal_backup_rate(_adapter *adapter)
{
RTW_INFO("%s\n", __func__);
/* backup data rate to register 0x8b for wowlan FW */
rtw_write8(adapter, 0x8d, 1);
rtw_write8(adapter, 0x8c, 0);
rtw_write8(adapter, 0x8f, 0x40);
rtw_write8(adapter, 0x8b, rtw_read8(adapter, 0x2f0));
}
#ifdef CONFIG_GTK_OL
static void rtw_hal_fw_sync_cam_id(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
int cam_id, index = 0;
u8 *addr = NULL;
if (!MLME_IS_STA(adapter))
return;
addr = get_bssid(pmlmepriv);
if (addr == NULL) {
RTW_INFO("%s: get bssid MAC addr fail!!\n", __func__);
return;
}
rtw_clean_dk_section(adapter);
do {
cam_id = rtw_camid_search(adapter, addr, index, 1);
if (cam_id == -1)
RTW_INFO("%s: cam_id: %d, key_id:%d\n", __func__, cam_id, index);
else
rtw_sec_cam_swap(adapter, cam_id, index);
index++;
} while (index < 4);
rtw_write8(adapter, REG_SECCFG, 0xcc);
}
static void rtw_hal_update_gtk_offload_info(_adapter *adapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct cam_ctl_t *cam_ctl = &dvobj->cam_ctl;
_irqL irqL;
u8 get_key[16];
u8 gtk_id = 0, offset = 0, i = 0, sz = 0, aoac_rpt_ver = 0, has_rekey = _FALSE;
u64 replay_count = 0, tmp_iv_hdr = 0, pkt_pn = 0;
if (!MLME_IS_STA(adapter))
return;
_rtw_memset(get_key, 0, sizeof(get_key));
_rtw_memcpy(&replay_count,
paoac_rpt->replay_counter_eapol_key, 8);
/*read gtk key index*/
gtk_id = paoac_rpt->key_index;
aoac_rpt_ver = paoac_rpt->version_info;
if (aoac_rpt_ver == 0) {
/* initial verison */
if (gtk_id == 5)
has_rekey = _FALSE;
else
has_rekey = _TRUE;
} else if (aoac_rpt_ver >= 1) {
/* Add krack patch */
if (gtk_id == 5)
RTW_WARN("%s FW check iv fail\n", __func__);
if (aoac_rpt_ver == 1)
RTW_WARN("%s aoac report version should be update to v2\n", __func__);
/* Fix key id mismatch */
if (aoac_rpt_ver == 2)
has_rekey = paoac_rpt->rekey_ok == 1 ? _TRUE : _FALSE;
}
if (has_rekey == _FALSE) {
RTW_INFO("%s no rekey event happened.\n", __func__);
} else if (has_rekey == _TRUE) {
RTW_INFO("%s update security key.\n", __func__);
/*read key from sec-cam,for DK ,keyindex is equal to cam-id*/
rtw_sec_read_cam_ent(adapter, gtk_id,
NULL, NULL, get_key);
rtw_clean_hw_dk_cam(adapter);
if (_rtw_camid_is_gk(adapter, gtk_id)) {
_enter_critical_bh(&cam_ctl->lock, &irqL);
_rtw_memcpy(&dvobj->cam_cache[gtk_id].key,
get_key, 16);
_exit_critical_bh(&cam_ctl->lock, &irqL);
} else {
struct setkey_parm parm_gtk;
parm_gtk.algorithm = paoac_rpt->security_type;
parm_gtk.keyid = gtk_id;
_rtw_memcpy(parm_gtk.key, get_key, 16);
setkey_hdl(adapter, (u8 *)&parm_gtk);
}
/*update key into related sw variable and sec-cam cache*/
psecuritypriv->dot118021XGrpKeyid = gtk_id;
_rtw_memcpy(&psecuritypriv->dot118021XGrpKey[gtk_id],
get_key, 16);
/* update SW TKIP TX/RX MIC value */
if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_) {
offset = RTW_KEK_LEN + RTW_TKIP_MIC_LEN;
_rtw_memcpy(
&psecuritypriv->dot118021XGrptxmickey[gtk_id],
&(paoac_rpt->group_key[offset]),
RTW_TKIP_MIC_LEN);
offset = RTW_KEK_LEN;
_rtw_memcpy(
&psecuritypriv->dot118021XGrprxmickey[gtk_id],
&(paoac_rpt->group_key[offset]),
RTW_TKIP_MIC_LEN);
}
RTW_PRINT("GTK (%d) "KEY_FMT"\n", gtk_id,
KEY_ARG(psecuritypriv->dot118021XGrpKey[gtk_id].skey));
}
/* Update broadcast RX IV */
if (psecuritypriv->dot118021XGrpPrivacy == _AES_) {
sz = sizeof(psecuritypriv->iv_seq[0]);
for (i = 0 ; i < 4 ; i++) {
_rtw_memcpy(&tmp_iv_hdr, paoac_rpt->rxgtk_iv[i], sz);
tmp_iv_hdr = le64_to_cpu(tmp_iv_hdr);
pkt_pn = CCMPH_2_PN(tmp_iv_hdr);
_rtw_memcpy(psecuritypriv->iv_seq[i], &pkt_pn, sz);
}
}
rtw_clean_dk_section(adapter);
rtw_write8(adapter, REG_SECCFG, 0x0c);
#ifdef CONFIG_GTK_OL_DBG
/* if (gtk_keyindex != 5) */
dump_sec_cam(RTW_DBGDUMP, adapter);
dump_sec_cam_cache(RTW_DBGDUMP, adapter);
#endif
}
#endif /*CONFIG_GTK_OL*/
static void rtw_dump_aoac_rpt(_adapter *adapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
int i = 0;
RTW_INFO_DUMP("[AOAC-RPT] IV -", paoac_rpt->iv, 8);
RTW_INFO_DUMP("[AOAC-RPT] Replay counter of EAPOL key - ",
paoac_rpt->replay_counter_eapol_key, 8);
RTW_INFO_DUMP("[AOAC-RPT] Group key - ", paoac_rpt->group_key, 32);
RTW_INFO("[AOAC-RPT] Key Index - %d\n", paoac_rpt->key_index);
RTW_INFO("[AOAC-RPT] Security Type - %d\n", paoac_rpt->security_type);
RTW_INFO("[AOAC-RPT] wow_pattern_idx - %d\n",
paoac_rpt->wow_pattern_idx);
RTW_INFO("[AOAC-RPT] version_info - %d\n", paoac_rpt->version_info);
RTW_INFO("[AOAC-RPT] rekey_ok - %d\n", paoac_rpt->rekey_ok);
RTW_INFO_DUMP("[AOAC-RPT] RX PTK IV-", paoac_rpt->rxptk_iv, 8);
RTW_INFO_DUMP("[AOAC-RPT] RX GTK[0] IV-", paoac_rpt->rxgtk_iv[0], 8);
RTW_INFO_DUMP("[AOAC-RPT] RX GTK[1] IV-", paoac_rpt->rxgtk_iv[1], 8);
RTW_INFO_DUMP("[AOAC-RPT] RX GTK[2] IV-", paoac_rpt->rxgtk_iv[2], 8);
RTW_INFO_DUMP("[AOAC-RPT] RX GTK[3] IV-", paoac_rpt->rxgtk_iv[3], 8);
}
static void rtw_hal_get_aoac_rpt(_adapter *adapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
u32 page_offset = 0, page_number = 0;
u32 page_size = 0, buf_size = 0;
u8 *buffer = NULL;
u8 i = 0, tmp = 0;
int ret = -1;
/* read aoac report from rsvd page */
page_offset = pwrctl->wowlan_aoac_rpt_loc;
page_number = 1;
rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, &page_size);
buf_size = page_size * page_number;
buffer = rtw_zvmalloc(buf_size);
if (buffer == NULL) {
RTW_ERR("%s buffer allocate failed size(%d)\n",
__func__, buf_size);
return;
}
RTW_INFO("Get AOAC Report from rsvd page_offset:%d\n", page_offset);
ret = rtw_hal_get_rsvd_page(adapter, page_offset,
page_number, buffer, buf_size);
if (ret == _FALSE) {
RTW_ERR("%s get aoac report failed\n", __func__);
rtw_warn_on(1);
goto _exit;
}
_rtw_memset(paoac_rpt, 0, sizeof(struct aoac_report));
_rtw_memcpy(paoac_rpt, buffer, sizeof(struct aoac_report));
for (i = 0 ; i < 4 ; i++) {
tmp = paoac_rpt->replay_counter_eapol_key[i];
paoac_rpt->replay_counter_eapol_key[i] =
paoac_rpt->replay_counter_eapol_key[7 - i];
paoac_rpt->replay_counter_eapol_key[7 - i] = tmp;
}
rtw_dump_aoac_rpt(adapter);
_exit:
if (buffer)
rtw_vmfree(buffer, buf_size);
}
static void rtw_hal_update_tx_iv(_adapter *adapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct aoac_report *paoac_rpt = &pwrctl->wowlan_aoac_rpt;
struct sta_info *psta;
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct security_priv *psecpriv = &adapter->securitypriv;
u16 val16 = 0;
u32 val32 = 0;
u64 txiv = 0;
u8 *pval = NULL;
psta = rtw_get_stainfo(&adapter->stapriv,
get_my_bssid(&pmlmeinfo->network));
/* Update TX iv data. */
pval = (u8 *)&paoac_rpt->iv;
if (psecpriv->dot11PrivacyAlgrthm == _TKIP_) {
val16 = ((u16)(paoac_rpt->iv[2]) << 0) +
((u16)(paoac_rpt->iv[0]) << 8);
val32 = ((u32)(paoac_rpt->iv[4]) << 0) +
((u32)(paoac_rpt->iv[5]) << 8) +
((u32)(paoac_rpt->iv[6]) << 16) +
((u32)(paoac_rpt->iv[7]) << 24);
} else if (psecpriv->dot11PrivacyAlgrthm == _AES_) {
val16 = ((u16)(paoac_rpt->iv[0]) << 0) +
((u16)(paoac_rpt->iv[1]) << 8);
val32 = ((u32)(paoac_rpt->iv[4]) << 0) +
((u32)(paoac_rpt->iv[5]) << 8) +
((u32)(paoac_rpt->iv[6]) << 16) +
((u32)(paoac_rpt->iv[7]) << 24);
}
if (psta) {
txiv = val16 + ((u64)val32 << 16);
if (txiv != 0)
psta->dot11txpn.val = txiv;
}
}
static void rtw_hal_update_sw_security_info(_adapter *adapter)
{
struct security_priv *psecpriv = &adapter->securitypriv;
u8 sz = sizeof (psecpriv->iv_seq);
rtw_hal_update_tx_iv(adapter);
#ifdef CONFIG_GTK_OL
if (psecpriv->binstallKCK_KEK == _TRUE &&
psecpriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
rtw_hal_update_gtk_offload_info(adapter);
#else
_rtw_memset(psecpriv->iv_seq, 0, sz);
#endif
}
static u8 rtw_hal_set_keep_alive_cmd(_adapter *adapter, u8 enable, u8 pkt_type)
{
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 u1H2CKeepAliveParm[H2C_KEEP_ALIVE_CTRL_LEN] = {0};
u8 adopt = 1, check_period = 5;
u8 ret = _FAIL;
u8 hw_port = rtw_hal_get_port(adapter);
SET_H2CCMD_KEEPALIVE_PARM_ENABLE(u1H2CKeepAliveParm, enable);
SET_H2CCMD_KEEPALIVE_PARM_ADOPT(u1H2CKeepAliveParm, adopt);
SET_H2CCMD_KEEPALIVE_PARM_PKT_TYPE(u1H2CKeepAliveParm, pkt_type);
SET_H2CCMD_KEEPALIVE_PARM_CHECK_PERIOD(u1H2CKeepAliveParm, check_period);
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
SET_H2CCMD_KEEPALIVE_PARM_PORT_NUM(u1H2CKeepAliveParm, hw_port);
RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, hw_port);
#else
RTW_INFO("%s(): enable = %d\n", __func__, enable);
#endif
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_KEEP_ALIVE,
H2C_KEEP_ALIVE_CTRL_LEN,
u1H2CKeepAliveParm);
return ret;
}
static u8 rtw_hal_set_disconnect_decision_cmd(_adapter *adapter, u8 enable)
{
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 u1H2CDisconDecisionParm[H2C_DISCON_DECISION_LEN] = {0};
u8 adopt = 1, check_period = 30, trypkt_num = 5;
u8 ret = _FAIL;
u8 hw_port = rtw_hal_get_port(adapter);
SET_H2CCMD_DISCONDECISION_PARM_ENABLE(u1H2CDisconDecisionParm, enable);
SET_H2CCMD_DISCONDECISION_PARM_ADOPT(u1H2CDisconDecisionParm, adopt);
/* SET_H2CCMD_DISCONDECISION_PARM_DISCONNECT_EN(u1H2CDisconDecisionParm, adopt); */
SET_H2CCMD_DISCONDECISION_PARM_CHECK_PERIOD(u1H2CDisconDecisionParm, check_period);
SET_H2CCMD_DISCONDECISION_PARM_TRY_PKT_NUM(u1H2CDisconDecisionParm, trypkt_num);
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
SET_H2CCMD_DISCONDECISION_PORT_NUM(u1H2CDisconDecisionParm, hw_port);
RTW_INFO("%s(): enable = %d, port = %d\n", __func__, enable, hw_port);
#else
RTW_INFO("%s(): enable = %d\n", __func__, enable);
#endif
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_DISCON_DECISION,
H2C_DISCON_DECISION_LEN,
u1H2CDisconDecisionParm);
return ret;
}
static u8 rtw_hal_set_wowlan_ctrl_cmd(_adapter *adapter, u8 enable, u8 change_unit)
{
struct registry_priv *registry_par = &adapter->registrypriv;
struct security_priv *psecpriv = &adapter->securitypriv;
struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
struct hal_ops *pHalFunc = &adapter->hal_func;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
u8 u1H2CWoWlanCtrlParm[H2C_WOWLAN_LEN] = {0};
u8 discont_wake = 0, gpionum = 0, gpio_dur = 0, no_wake = 0;
u8 hw_unicast = 0, gpio_pulse_cnt = 0, gpio_pulse_en = 0;
u8 sdio_wakeup_enable = 1;
u8 gpio_high_active = 0;
u8 magic_pkt = 0;
u8 gpio_unit = 0; /*0: 64ns, 1: 8ms*/
u8 ret = _FAIL;
#ifdef CONFIG_DIS_UPHY
u8 dis_uphy = 0, dis_uphy_unit = 0, dis_uphy_time = 0;
#endif /* CONFIG_DIS_UPHY */
#ifdef CONFIG_GPIO_WAKEUP
gpio_high_active = ppwrpriv->is_high_active;
gpionum = WAKEUP_GPIO_IDX;
sdio_wakeup_enable = 0;
#endif /* CONFIG_GPIO_WAKEUP */
if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF &&
!check_fwstate(pmlmepriv, _FW_LINKED))
no_wake = 1;
if (!ppwrpriv->wowlan_pno_enable &&
registry_par->wakeup_event & BIT(0) && !no_wake)
magic_pkt = enable;
if ((registry_par->wakeup_event & BIT(1)) &&
(psecpriv->dot11PrivacyAlgrthm == _WEP40_ ||
psecpriv->dot11PrivacyAlgrthm == _WEP104_) && !no_wake)
hw_unicast = 1;
if (registry_par->wakeup_event & BIT(2) && !no_wake)
discont_wake = enable;
RTW_INFO("%s(): enable=%d change_unit=%d\n", __func__,
enable, change_unit);
/* time = (gpio_dur/2) * gpio_unit, default:256 ms */
if (enable && change_unit) {
gpio_dur = 0x40;
gpio_unit = 1;
gpio_pulse_en = 1;
}
#ifdef CONFIG_PLATFORM_ARM_RK3188
if (enable) {
gpio_pulse_en = 1;
gpio_pulse_cnt = 0x04;
}
#endif
SET_H2CCMD_WOWLAN_FUNC_ENABLE(u1H2CWoWlanCtrlParm, enable);
if(!no_wake)
SET_H2CCMD_WOWLAN_PATTERN_MATCH_ENABLE(u1H2CWoWlanCtrlParm, enable);
SET_H2CCMD_WOWLAN_MAGIC_PKT_ENABLE(u1H2CWoWlanCtrlParm, magic_pkt);
SET_H2CCMD_WOWLAN_UNICAST_PKT_ENABLE(u1H2CWoWlanCtrlParm, hw_unicast);
SET_H2CCMD_WOWLAN_ALL_PKT_DROP(u1H2CWoWlanCtrlParm, 0);
SET_H2CCMD_WOWLAN_GPIO_ACTIVE(u1H2CWoWlanCtrlParm, gpio_high_active);
#ifdef CONFIG_GTK_OL
if (psecpriv->binstallKCK_KEK == _TRUE &&
psecpriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK)
SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, 0);
else
SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, 1);
#else
SET_H2CCMD_WOWLAN_REKEY_WAKE_UP(u1H2CWoWlanCtrlParm, enable);
#endif
SET_H2CCMD_WOWLAN_DISCONNECT_WAKE_UP(u1H2CWoWlanCtrlParm, discont_wake);
SET_H2CCMD_WOWLAN_GPIONUM(u1H2CWoWlanCtrlParm, gpionum);
SET_H2CCMD_WOWLAN_DATAPIN_WAKE_UP(u1H2CWoWlanCtrlParm, sdio_wakeup_enable);
SET_H2CCMD_WOWLAN_GPIO_DURATION(u1H2CWoWlanCtrlParm, gpio_dur);
SET_H2CCMD_WOWLAN_CHANGE_UNIT(u1H2CWoWlanCtrlParm, gpio_unit);
SET_H2CCMD_WOWLAN_GPIO_PULSE_EN(u1H2CWoWlanCtrlParm, gpio_pulse_en);
SET_H2CCMD_WOWLAN_GPIO_PULSE_COUNT(u1H2CWoWlanCtrlParm, gpio_pulse_cnt);
#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
if (enable)
SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(u1H2CWoWlanCtrlParm, 1);
#endif
#ifdef CONFIG_DIS_UPHY
if (enable) {
dis_uphy = 1;
/* time unit: 0 -> ms, 1 -> 256 ms*/
dis_uphy_unit = 1;
dis_uphy_time = 0x4;
}
SET_H2CCMD_WOWLAN_DISABLE_UPHY(u1H2CWoWlanCtrlParm, dis_uphy);
SET_H2CCMD_WOWLAN_UNIT_FOR_UPHY_DISABLE(u1H2CWoWlanCtrlParm, dis_uphy_unit);
SET_H2CCMD_WOWLAN_TIME_FOR_UPHY_DISABLE(u1H2CWoWlanCtrlParm, dis_uphy_time);
if (ppwrpriv->hst2dev_high_active == 1)
SET_H2CCMD_WOWLAN_RISE_HST2DEV(u1H2CWoWlanCtrlParm, 1);
#ifdef CONFIG_RTW_ONE_PIN_GPIO
SET_H2CCMD_WOWLAN_GPIO_INPUT_EN(u1H2CWoWlanCtrlParm, 1);
SET_H2CCMD_WOWLAN_DEV2HST_EN(u1H2CWoWlanCtrlParm, 1);
SET_H2CCMD_WOWLAN_HST2DEV_EN(u1H2CWoWlanCtrlParm, 0);
#else
SET_H2CCMD_WOWLAN_HST2DEV_EN(u1H2CWoWlanCtrlParm, 1);
#endif /* CONFIG_RTW_ONE_PIN_GPIO */
#endif /* CONFIG_DIS_UPHY */
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_WOWLAN,
H2C_WOWLAN_LEN,
u1H2CWoWlanCtrlParm);
return ret;
}
static u8 rtw_hal_set_remote_wake_ctrl_cmd(_adapter *adapter, u8 enable)
{
struct hal_ops *pHalFunc = &adapter->hal_func;
struct security_priv *psecuritypriv = &(adapter->securitypriv);
struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
struct registry_priv *pregistrypriv = &adapter->registrypriv;
u8 u1H2CRemoteWakeCtrlParm[H2C_REMOTE_WAKE_CTRL_LEN] = {0};
u8 ret = _FAIL, count = 0, no_wake = 0;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
RTW_INFO("%s(): enable=%d\n", __func__, enable);
if(pregistrypriv->suspend_type == FW_IPS_DISABLE_BBRF &&
!check_fwstate(pmlmepriv, _FW_LINKED))
no_wake = 1;
if(no_wake) {
SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
u1H2CRemoteWakeCtrlParm, enable);
} else {
if (!ppwrpriv->wowlan_pno_enable) {
SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
u1H2CRemoteWakeCtrlParm, enable);
SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, 1);
#ifdef CONFIG_GTK_OL
if (psecuritypriv->binstallKCK_KEK == _TRUE &&
psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, 1);
} else {
RTW_INFO("no kck kek\n");
SET_H2CCMD_REMOTE_WAKE_CTRL_GTK_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, 0);
}
#endif /* CONFIG_GTK_OL */
#ifdef CONFIG_IPV6
if (ppwrpriv->wowlan_ns_offload_en == _TRUE) {
RTW_INFO("enable NS offload\n");
SET_H2CCMD_REMOTE_WAKE_CTRL_NDP_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, enable);
}
/*
* filter NetBios name service pkt to avoid being waked-up
* by this kind of unicast pkt this exceptional modification
* is used for match competitor's behavior
*/
SET_H2CCMD_REMOTE_WAKE_CTRL_NBNS_FILTER_EN(
u1H2CRemoteWakeCtrlParm, enable);
#endif /*CONFIG_IPV6*/
#ifdef CONFIG_RTL8192F
if (IS_HARDWARE_TYPE_8192F(adapter)){
SET_H2CCMD_REMOTE_WAKE_CTRL_FW_UNICAST_EN(
u1H2CRemoteWakeCtrlParm, enable);
}
#endif /* CONFIG_RTL8192F */
if ((psecuritypriv->dot11PrivacyAlgrthm == _AES_) ||
(psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) ||
(psecuritypriv->dot11PrivacyAlgrthm == _NO_PRIVACY_)) {
SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
u1H2CRemoteWakeCtrlParm, 0);
} else {
SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
u1H2CRemoteWakeCtrlParm, 1);
}
if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_ &&
psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, enable);
if (IS_HARDWARE_TYPE_8188E(adapter) ||
IS_HARDWARE_TYPE_8812(adapter)) {
SET_H2CCMD_REMOTE_WAKE_CTRL_TKIP_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, 0);
SET_H2CCMD_REMOTE_WAKE_CTRL_ARP_ACTION(
u1H2CRemoteWakeCtrlParm, 1);
}
}
SET_H2CCMD_REMOTE_WAKE_CTRL_FW_PARSING_UNTIL_WAKEUP(
u1H2CRemoteWakeCtrlParm, 1);
}
#ifdef CONFIG_PNO_SUPPORT
else {
SET_H2CCMD_REMOTE_WAKECTRL_ENABLE(
u1H2CRemoteWakeCtrlParm, enable);
SET_H2CCMD_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(
u1H2CRemoteWakeCtrlParm, enable);
}
#endif
#ifdef CONFIG_P2P_WOWLAN
if (_TRUE == ppwrpriv->wowlan_p2p_mode) {
RTW_INFO("P2P OFFLOAD ENABLE\n");
SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 1);
} else {
RTW_INFO("P2P OFFLOAD DISABLE\n");
SET_H2CCMD_REMOTE_WAKE_CTRL_P2P_OFFLAD_EN(u1H2CRemoteWakeCtrlParm, 0);
}
#endif /* CONFIG_P2P_WOWLAN */
}
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_REMOTE_WAKE_CTRL,
H2C_REMOTE_WAKE_CTRL_LEN,
u1H2CRemoteWakeCtrlParm);
return ret;
}
static u8 rtw_hal_set_global_info_cmd(_adapter *adapter, u8 group_alg, u8 pairwise_alg)
{
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 ret = _FAIL;
u8 u1H2CAOACGlobalInfoParm[H2C_AOAC_GLOBAL_INFO_LEN] = {0};
RTW_INFO("%s(): group_alg=%d pairwise_alg=%d\n",
__func__, group_alg, pairwise_alg);
SET_H2CCMD_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(u1H2CAOACGlobalInfoParm,
pairwise_alg);
SET_H2CCMD_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(u1H2CAOACGlobalInfoParm,
group_alg);
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_AOAC_GLOBAL_INFO,
H2C_AOAC_GLOBAL_INFO_LEN,
u1H2CAOACGlobalInfoParm);
return ret;
}
#ifdef CONFIG_PNO_SUPPORT
static u8 rtw_hal_set_scan_offload_info_cmd(_adapter *adapter,
PRSVDPAGE_LOC rsvdpageloc, u8 enable)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 u1H2CScanOffloadInfoParm[H2C_SCAN_OFFLOAD_CTRL_LEN] = {0};
u8 res = 0, count = 0, ret = _FAIL;
RTW_INFO("%s: loc_probe_packet:%d, loc_scan_info: %d loc_ssid_info:%d\n",
__func__, rsvdpageloc->LocProbePacket,
rsvdpageloc->LocScanInfo, rsvdpageloc->LocSSIDInfo);
SET_H2CCMD_AOAC_NLO_FUN_EN(u1H2CScanOffloadInfoParm, enable);
SET_H2CCMD_AOAC_NLO_IPS_EN(u1H2CScanOffloadInfoParm, enable);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_SCAN_INFO(u1H2CScanOffloadInfoParm,
rsvdpageloc->LocScanInfo);
SET_H2CCMD_AOAC_RSVDPAGE_LOC_PROBE_PACKET(u1H2CScanOffloadInfoParm,
rsvdpageloc->LocProbePacket);
/*
SET_H2CCMD_AOAC_RSVDPAGE_LOC_SSID_INFO(u1H2CScanOffloadInfoParm,
rsvdpageloc->LocSSIDInfo);
*/
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_D0_SCAN_OFFLOAD_INFO,
H2C_SCAN_OFFLOAD_CTRL_LEN,
u1H2CScanOffloadInfoParm);
return ret;
}
#endif /* CONFIG_PNO_SUPPORT */
void rtw_hal_set_fw_wow_related_cmd(_adapter *padapter, u8 enable)
{
struct security_priv *psecpriv = &padapter->securitypriv;
struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(padapter);
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct registry_priv *pregistry = &padapter->registrypriv;
struct sta_info *psta = NULL;
u16 media_status_rpt;
u8 pkt_type = 0, no_wake = 0;
u8 ret = _SUCCESS;
if(pregistry->suspend_type == FW_IPS_DISABLE_BBRF &&
!check_fwstate(pmlmepriv, _FW_LINKED))
no_wake = 1;
RTW_PRINT("+%s()+: enable=%d\n", __func__, enable);
rtw_hal_set_wowlan_ctrl_cmd(padapter, enable, _FALSE);
if (enable) {
if(!no_wake)
rtw_hal_set_global_info_cmd(padapter,
psecpriv->dot118021XGrpPrivacy,
psecpriv->dot11PrivacyAlgrthm);
if (!(ppwrpriv->wowlan_pno_enable)) {
if (pregistry->wakeup_event & BIT(2) && !no_wake)
rtw_hal_set_disconnect_decision_cmd(padapter,
enable);
#ifdef CONFIG_ARP_KEEP_ALIVE
if ((psecpriv->dot11PrivacyAlgrthm == _WEP40_) ||
(psecpriv->dot11PrivacyAlgrthm == _WEP104_))
pkt_type = 0;
else
pkt_type = 1;
#else
pkt_type = 0;
#endif /* CONFIG_ARP_KEEP_ALIVE */
if(!no_wake)
rtw_hal_set_keep_alive_cmd(padapter, enable, pkt_type);
}
rtw_hal_set_remote_wake_ctrl_cmd(padapter, enable);
#ifdef CONFIG_PNO_SUPPORT
rtw_hal_check_pno_enabled(padapter);
#endif /* CONFIG_PNO_SUPPORT */
} else {
#if 0
{
u32 PageSize = 0;
rtw_hal_get_def_var(padapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&PageSize);
dump_TX_FIFO(padapter, 4, PageSize);
}
#endif
rtw_hal_set_remote_wake_ctrl_cmd(padapter, enable);
}
RTW_PRINT("-%s()-\n", __func__);
}
#endif /* CONFIG_WOWLAN */
#ifdef CONFIG_AP_WOWLAN
static u8 rtw_hal_set_ap_wowlan_ctrl_cmd(_adapter *adapter, u8 enable)
{
struct security_priv *psecpriv = &adapter->securitypriv;
struct pwrctrl_priv *ppwrpriv = adapter_to_pwrctl(adapter);
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 u1H2CAPWoWlanCtrlParm[H2C_AP_WOW_GPIO_CTRL_LEN] = {0};
u8 gpionum = 0, gpio_dur = 0;
u8 gpio_pulse = enable;
u8 sdio_wakeup_enable = 1;
u8 gpio_high_active = 0;
u8 ret = _FAIL;
#ifdef CONFIG_GPIO_WAKEUP
gpio_high_active = ppwrpriv->is_high_active;
gpionum = WAKEUP_GPIO_IDX;
sdio_wakeup_enable = 0;
#endif /*CONFIG_GPIO_WAKEUP*/
RTW_INFO("%s(): enable=%d\n", __func__, enable);
SET_H2CCMD_AP_WOW_GPIO_CTRL_INDEX(u1H2CAPWoWlanCtrlParm,
gpionum);
SET_H2CCMD_AP_WOW_GPIO_CTRL_PLUS(u1H2CAPWoWlanCtrlParm,
gpio_pulse);
SET_H2CCMD_AP_WOW_GPIO_CTRL_HIGH_ACTIVE(u1H2CAPWoWlanCtrlParm,
gpio_high_active);
SET_H2CCMD_AP_WOW_GPIO_CTRL_EN(u1H2CAPWoWlanCtrlParm,
enable);
SET_H2CCMD_AP_WOW_GPIO_CTRL_DURATION(u1H2CAPWoWlanCtrlParm,
gpio_dur);
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_AP_WOW_GPIO_CTRL,
H2C_AP_WOW_GPIO_CTRL_LEN,
u1H2CAPWoWlanCtrlParm);
return ret;
}
static u8 rtw_hal_set_ap_offload_ctrl_cmd(_adapter *adapter, u8 enable)
{
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 u1H2CAPOffloadCtrlParm[H2C_WOWLAN_LEN] = {0};
u8 ret = _FAIL;
RTW_INFO("%s(): bFuncEn=%d\n", __func__, enable);
SET_H2CCMD_AP_WOWLAN_EN(u1H2CAPOffloadCtrlParm, enable);
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_AP_OFFLOAD,
H2C_AP_OFFLOAD_LEN,
u1H2CAPOffloadCtrlParm);
return ret;
}
static u8 rtw_hal_set_ap_ps_cmd(_adapter *adapter, u8 enable)
{
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 ap_ps_parm[H2C_AP_PS_LEN] = {0};
u8 ret = _FAIL;
RTW_INFO("%s(): enable=%d\n" , __func__ , enable);
SET_H2CCMD_AP_WOW_PS_EN(ap_ps_parm, enable);
#ifndef CONFIG_USB_HCI
SET_H2CCMD_AP_WOW_PS_32K_EN(ap_ps_parm, enable);
#endif /*CONFIG_USB_HCI*/
SET_H2CCMD_AP_WOW_PS_RF(ap_ps_parm, enable);
if (enable)
SET_H2CCMD_AP_WOW_PS_DURATION(ap_ps_parm, 0x32);
else
SET_H2CCMD_AP_WOW_PS_DURATION(ap_ps_parm, 0x0);
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_SAP_PS_,
H2C_AP_PS_LEN, ap_ps_parm);
return ret;
}
static void rtw_hal_set_ap_rsvdpage_loc_cmd(PADAPTER padapter,
PRSVDPAGE_LOC rsvdpageloc)
{
struct hal_ops *pHalFunc = &padapter->hal_func;
u8 rsvdparm[H2C_AOAC_RSVDPAGE_LOC_LEN] = {0};
u8 ret = _FAIL, header = 0;
if (pHalFunc->fill_h2c_cmd == NULL) {
RTW_INFO("%s: Please hook fill_h2c_cmd first!\n", __func__);
return;
}
header = rtw_read8(padapter, REG_BCNQ_BDNY);
RTW_INFO("%s: beacon: %d, probeRsp: %d, header:0x%02x\n", __func__,
rsvdpageloc->LocApOffloadBCN,
rsvdpageloc->LocProbeRsp,
header);
SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_BCN(rsvdparm,
rsvdpageloc->LocApOffloadBCN + header);
ret = rtw_hal_fill_h2c_cmd(padapter, H2C_BCN_RSVDPAGE,
H2C_BCN_RSVDPAGE_LEN, rsvdparm);
if (ret == _FAIL)
RTW_INFO("%s: H2C_BCN_RSVDPAGE cmd fail\n", __func__);
rtw_msleep_os(10);
_rtw_memset(&rsvdparm, 0, sizeof(rsvdparm));
SET_H2CCMD_AP_WOWLAN_RSVDPAGE_LOC_ProbeRsp(rsvdparm,
rsvdpageloc->LocProbeRsp + header);
ret = rtw_hal_fill_h2c_cmd(padapter, H2C_PROBERSP_RSVDPAGE,
H2C_PROBERSP_RSVDPAGE_LEN, rsvdparm);
if (ret == _FAIL)
RTW_INFO("%s: H2C_PROBERSP_RSVDPAGE cmd fail\n", __func__);
rtw_msleep_os(10);
}
static void rtw_hal_set_fw_ap_wow_related_cmd(_adapter *padapter, u8 enable)
{
rtw_hal_set_ap_offload_ctrl_cmd(padapter, enable);
rtw_hal_set_ap_wowlan_ctrl_cmd(padapter, enable);
rtw_hal_set_ap_ps_cmd(padapter, enable);
}
static void rtw_hal_ap_wow_enable(_adapter *padapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
struct security_priv *psecuritypriv = &padapter->securitypriv;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct hal_ops *pHalFunc = &padapter->hal_func;
struct sta_info *psta = NULL;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
#ifdef DBG_CHECK_FW_PS_STATE
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
#endif /*DBG_CHECK_FW_PS_STATE*/
int res;
u16 media_status_rpt;
RTW_INFO("%s, WOWLAN_AP_ENABLE\n", __func__);
#ifdef DBG_CHECK_FW_PS_STATE
if (rtw_fw_ps_state(padapter) == _FAIL) {
pdbgpriv->dbg_enwow_dload_fw_fail_cnt++;
RTW_PRINT("wowlan enable no leave 32k\n");
}
#endif /*DBG_CHECK_FW_PS_STATE*/
/* 1. Download WOWLAN FW*/
rtw_hal_fw_dl(padapter, _TRUE);
media_status_rpt = RT_MEDIA_CONNECT;
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT,
(u8 *)&media_status_rpt);
issue_beacon(padapter, 0);
rtw_msleep_os(2);
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(padapter))
rtw_hal_disable_tx_report(padapter);
#endif
/* RX DMA stop */
res = rtw_hal_pause_rx_dma(padapter);
if (res == _FAIL)
RTW_PRINT("[WARNING] pause RX DMA fail\n");
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
/* Enable CPWM2 only. */
res = rtw_hal_enable_cpwm2(padapter);
if (res == _FAIL)
RTW_PRINT("[WARNING] enable cpwm2 fail\n");
#endif
#ifdef CONFIG_GPIO_WAKEUP
rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _TRUE);
#endif
/* 5. Set Enable WOWLAN H2C command. */
RTW_PRINT("Set Enable AP WOWLan cmd\n");
rtw_hal_set_fw_ap_wow_related_cmd(padapter, 1);
rtw_write8(padapter, REG_MCUTST_WOWLAN, 0);
#ifdef CONFIG_USB_HCI
rtw_mi_intf_stop(padapter);
#endif
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
/* Invoid SE0 reset signal during suspending*/
rtw_write8(padapter, REG_RSV_CTRL, 0x20);
if (IS_8188F(pHalData->version_id) == FALSE
&& IS_8188GTV(pHalData->version_id) == FALSE)
rtw_write8(padapter, REG_RSV_CTRL, 0x60);
#endif
}
static void rtw_hal_ap_wow_disable(_adapter *padapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
struct hal_ops *pHalFunc = &padapter->hal_func;
#ifdef DBG_CHECK_FW_PS_STATE
struct dvobj_priv *psdpriv = padapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
#endif /*DBG_CHECK_FW_PS_STATE*/
u16 media_status_rpt;
u8 val8;
RTW_INFO("%s, WOWLAN_AP_DISABLE\n", __func__);
/* 1. Read wakeup reason*/
pwrctl->wowlan_wake_reason = rtw_read8(padapter, REG_MCUTST_WOWLAN);
RTW_PRINT("wakeup_reason: 0x%02x\n",
pwrctl->wowlan_wake_reason);
rtw_hal_set_fw_ap_wow_related_cmd(padapter, 0);
rtw_msleep_os(2);
#ifdef DBG_CHECK_FW_PS_STATE
if (rtw_fw_ps_state(padapter) == _FAIL) {
pdbgpriv->dbg_diswow_dload_fw_fail_cnt++;
RTW_PRINT("wowlan enable no leave 32k\n");
}
#endif /*DBG_CHECK_FW_PS_STATE*/
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(padapter))
rtw_hal_enable_tx_report(padapter);
#endif
rtw_hal_force_enable_rxdma(padapter);
rtw_hal_fw_dl(padapter, _FALSE);
#ifdef CONFIG_GPIO_WAKEUP
#ifdef CONFIG_RTW_ONE_PIN_GPIO
rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
#else
#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
if (pwrctl->is_high_active == 0)
rtw_hal_set_input_gpio(padapter, WAKEUP_GPIO_IDX);
else
rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, 0);
#else
val8 = (pwrctl->is_high_active == 0) ? 1 : 0;
RTW_PRINT("Set Wake GPIO to default(%d).\n", val8);
rtw_hal_set_output_gpio(padapter, WAKEUP_GPIO_IDX, val8);
rtw_hal_switch_gpio_wl_ctrl(padapter, WAKEUP_GPIO_IDX, _FALSE);
#endif/*CONFIG_WAKEUP_GPIO_INPUT_MODE*/
#endif /* CONFIG_RTW_ONE_PIN_GPIO */
#endif
media_status_rpt = RT_MEDIA_CONNECT;
rtw_hal_set_hwreg(padapter, HW_VAR_H2C_FW_JOINBSSRPT,
(u8 *)&media_status_rpt);
issue_beacon(padapter, 0);
}
#endif /*CONFIG_AP_WOWLAN*/
#ifdef CONFIG_P2P_WOWLAN
static int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
{
u8 *ssid_ie;
sint ssid_len_ori;
int len_diff = 0;
ssid_ie = rtw_get_ie(ies, WLAN_EID_SSID, &ssid_len_ori, ies_len);
/* RTW_INFO("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n", __FUNCTION__, hidden_ssid_mode, ssid_ie, ssid_len_ori); */
if (ssid_ie && ssid_len_ori > 0) {
switch (hidden_ssid_mode) {
case 1: {
u8 *next_ie = ssid_ie + 2 + ssid_len_ori;
u32 remain_len = 0;
remain_len = ies_len - (next_ie - ies);
ssid_ie[1] = 0;
_rtw_memcpy(ssid_ie + 2, next_ie, remain_len);
len_diff -= ssid_len_ori;
break;
}
case 2:
_rtw_memset(&ssid_ie[2], 0, ssid_len_ori);
break;
default:
break;
}
}
return len_diff;
}
static void rtw_hal_construct_P2PBeacon(_adapter *padapter, u8 *pframe, u32 *pLength)
{
/* struct xmit_frame *pmgntframe; */
/* struct pkt_attrib *pattrib; */
/* unsigned char *pframe; */
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned int rate_len;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
u32 pktlen;
/* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
/* _irqL irqL;
* struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
* #endif */ /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
#ifdef CONFIG_P2P
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
#endif /* CONFIG_P2P */
/* for debug */
u8 *dbgbuf = pframe;
u8 dbgbufLen = 0, index = 0;
RTW_INFO("%s\n", __FUNCTION__);
/* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
/* _enter_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
* #endif */ /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
/* pmlmeext->mgnt_seq++; */
set_frame_sub_type(pframe, WIFI_BEACON);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
#ifdef CONFIG_P2P
/* for P2P : Primary Device Type & Device Name */
u32 wpsielen = 0, insert_len = 0;
u8 *wpsie = NULL;
wpsie = rtw_get_wps_ie(cur_network->IEs + _FIXED_IE_LENGTH_, cur_network->IELength - _FIXED_IE_LENGTH_, NULL, &wpsielen);
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO) && wpsie && wpsielen > 0) {
uint wps_offset, remainder_ielen;
u8 *premainder_ie, *pframe_wscie;
wps_offset = (uint)(wpsie - cur_network->IEs);
premainder_ie = wpsie + wpsielen;
remainder_ielen = cur_network->IELength - wps_offset - wpsielen;
#ifdef CONFIG_IOCTL_CFG80211
if (pwdinfo->driver_interface == DRIVER_CFG80211) {
if (pmlmepriv->wps_beacon_ie && pmlmepriv->wps_beacon_ie_len > 0) {
_rtw_memcpy(pframe, cur_network->IEs, wps_offset);
pframe += wps_offset;
pktlen += wps_offset;
_rtw_memcpy(pframe, pmlmepriv->wps_beacon_ie, pmlmepriv->wps_beacon_ie_len);
pframe += pmlmepriv->wps_beacon_ie_len;
pktlen += pmlmepriv->wps_beacon_ie_len;
/* copy remainder_ie to pframe */
_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
pframe += remainder_ielen;
pktlen += remainder_ielen;
} else {
_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
pframe += cur_network->IELength;
pktlen += cur_network->IELength;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
pframe_wscie = pframe + wps_offset;
_rtw_memcpy(pframe, cur_network->IEs, wps_offset + wpsielen);
pframe += (wps_offset + wpsielen);
pktlen += (wps_offset + wpsielen);
/* now pframe is end of wsc ie, insert Primary Device Type & Device Name */
/* Primary Device Type */
/* Type: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
insert_len += 2;
/* Length: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(0x0008);
insert_len += 2;
/* Value: */
/* Category ID */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
insert_len += 2;
/* OUI */
*(u32 *)(pframe + insert_len) = cpu_to_be32(WPSOUI);
insert_len += 4;
/* Sub Category ID */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
insert_len += 2;
/* Device Name */
/* Type: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
insert_len += 2;
/* Length: */
*(u16 *)(pframe + insert_len) = cpu_to_be16(pwdinfo->device_name_len);
insert_len += 2;
/* Value: */
_rtw_memcpy(pframe + insert_len, pwdinfo->device_name, pwdinfo->device_name_len);
insert_len += pwdinfo->device_name_len;
/* update wsc ie length */
*(pframe_wscie + 1) = (wpsielen - 2) + insert_len;
/* pframe move to end */
pframe += insert_len;
pktlen += insert_len;
/* copy remainder_ie to pframe */
_rtw_memcpy(pframe, premainder_ie, remainder_ielen);
pframe += remainder_ielen;
pktlen += remainder_ielen;
}
} else
#endif /* CONFIG_P2P */
{
int len_diff;
_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
len_diff = update_hidden_ssid(
pframe + _BEACON_IE_OFFSET_
, cur_network->IELength - _BEACON_IE_OFFSET_
, pmlmeinfo->hidden_ssid_mode
);
pframe += (cur_network->IELength + len_diff);
pktlen += (cur_network->IELength + len_diff);
}
#if 0
{
u8 *wps_ie;
uint wps_ielen;
u8 sr = 0;
wps_ie = rtw_get_wps_ie(pmgntframe->buf_addr + TXDESC_OFFSET + sizeof(struct rtw_ieee80211_hdr_3addr) + _BEACON_IE_OFFSET_,
pattrib->pktlen - sizeof(struct rtw_ieee80211_hdr_3addr) - _BEACON_IE_OFFSET_, NULL, &wps_ielen);
if (wps_ie && wps_ielen > 0)
rtw_get_wps_attr_content(wps_ie, wps_ielen, WPS_ATTR_SELECTED_REGISTRAR, (u8 *)(&sr), NULL);
if (sr != 0)
set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
else
_clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
}
#endif
#ifdef CONFIG_P2P
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
u32 len;
#ifdef CONFIG_IOCTL_CFG80211
if (pwdinfo->driver_interface == DRIVER_CFG80211) {
len = pmlmepriv->p2p_beacon_ie_len;
if (pmlmepriv->p2p_beacon_ie && len > 0)
_rtw_memcpy(pframe, pmlmepriv->p2p_beacon_ie, len);
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
len = build_beacon_p2p_ie(pwdinfo, pframe);
}
pframe += len;
pktlen += len;
#ifdef CONFIG_WFD
len = rtw_append_beacon_wfd_ie(padapter, pframe);
pframe += len;
pktlen += len;
#endif
}
#endif /* CONFIG_P2P */
goto _issue_bcn;
}
/* below for ad-hoc mode */
/* timestamp will be inserted by hardware */
pframe += 8;
pktlen += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
pframe += 2;
pktlen += 2;
/* capability info: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
pframe += 2;
pktlen += 2;
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pktlen);
/* supported rates... */
rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pktlen);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pktlen);
/* if( (pmlmeinfo->state&0x03) == WIFI_FW_ADHOC_STATE) */
{
u8 erpinfo = 0;
u32 ATIMWindow;
/* IBSS Parameter Set... */
/* ATIMWindow = cur->Configuration.ATIMWindow; */
ATIMWindow = 0;
pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pktlen);
/* ERP IE */
pframe = rtw_set_ie(pframe, _ERPINFO_IE_, 1, &erpinfo, &pktlen);
}
/* EXTERNDED SUPPORTED RATE */
if (rate_len > 8)
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
/* todo:HT for adhoc */
_issue_bcn:
/* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
/* pmlmepriv->update_bcn = _FALSE;
*
* _exit_critical_bh(&pmlmepriv->bcn_update_lock, &irqL);
* #endif */ /* #if defined (CONFIG_AP_MODE) && defined (CONFIG_NATIVEAP_MLME) */
*pLength = pktlen;
#if 0
/* printf dbg msg */
dbgbufLen = pktlen;
RTW_INFO("======> DBG MSG FOR CONSTRAUCT P2P BEACON\n");
for (index = 0; index < dbgbufLen; index++)
printk("%x ", *(dbgbuf + index));
printk("\n");
RTW_INFO("<====== DBG MSG FOR CONSTRAUCT P2P BEACON\n");
#endif
}
static void rtw_hal_construct_P2PProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
{
/* struct xmit_frame *pmgntframe; */
/* struct pkt_attrib *pattrib; */
/* unsigned char *pframe; */
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
unsigned char *mac;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
/* WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network); */
u16 beacon_interval = 100;
u16 capInfo = 0;
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
u8 wpsie[255] = { 0x00 };
u32 wpsielen = 0, p2pielen = 0;
u32 pktlen;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
/* for debug */
u8 *dbgbuf = pframe;
u8 dbgbufLen = 0, index = 0;
RTW_INFO("%s\n", __FUNCTION__);
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
mac = adapter_mac_addr(padapter);
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
/* DA filled by FW */
_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
/* Use the device address for BSSID field. */
_rtw_memcpy(pwlanhdr->addr3, mac, ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(fctrl, WIFI_PROBERSP);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe += pktlen;
/* timestamp will be inserted by hardware */
pframe += 8;
pktlen += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *) &beacon_interval, 2);
pframe += 2;
pktlen += 2;
/* capability info: 2 bytes */
/* ESS and IBSS bits must be 0 (defined in the 3.1.2.1.1 of WiFi Direct Spec) */
capInfo |= cap_ShortPremble;
capInfo |= cap_ShortSlot;
_rtw_memcpy(pframe, (unsigned char *) &capInfo, 2);
pframe += 2;
pktlen += 2;
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, 7, pwdinfo->p2p_wildcard_ssid, &pktlen);
/* supported rates... */
/* Use the OFDM rate in the P2P probe response frame. ( 6(B), 9(B), 12, 18, 24, 36, 48, 54 ) */
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, 8, pwdinfo->support_rate, &pktlen);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&pwdinfo->listen_channel, &pktlen);
#ifdef CONFIG_IOCTL_CFG80211
if (pwdinfo->driver_interface == DRIVER_CFG80211) {
if (pmlmepriv->wps_probe_resp_ie != NULL && pmlmepriv->p2p_probe_resp_ie != NULL) {
/* WPS IE */
_rtw_memcpy(pframe, pmlmepriv->wps_probe_resp_ie, pmlmepriv->wps_probe_resp_ie_len);
pktlen += pmlmepriv->wps_probe_resp_ie_len;
pframe += pmlmepriv->wps_probe_resp_ie_len;
/* P2P IE */
_rtw_memcpy(pframe, pmlmepriv->p2p_probe_resp_ie, pmlmepriv->p2p_probe_resp_ie_len);
pktlen += pmlmepriv->p2p_probe_resp_ie_len;
pframe += pmlmepriv->p2p_probe_resp_ie_len;
}
} else
#endif /* CONFIG_IOCTL_CFG80211 */
{
/* Todo: WPS IE */
/* Noted by Albert 20100907 */
/* According to the WPS specification, all the WPS attribute is presented by Big Endian. */
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
/* WiFi Simple Config State */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SIMPLE_CONF_STATE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_WSC_STATE_NOT_CONFIG; /* Not Configured. */
/* Response Type */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_RESP_TYPE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_RESPONSE_TYPE_8021X;
/* UUID-E */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_UUID_E);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0010);
wpsielen += 2;
/* Value: */
if (pwdinfo->external_uuid == 0) {
_rtw_memset(wpsie + wpsielen, 0x0, 16);
_rtw_memcpy(wpsie + wpsielen, mac, ETH_ALEN);
} else
_rtw_memcpy(wpsie + wpsielen, pwdinfo->uuid, 0x10);
wpsielen += 0x10;
/* Manufacturer */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MANUFACTURER);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0007);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, "Realtek", 7);
wpsielen += 7;
/* Model Name */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NAME);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0006);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, "8192CU", 6);
wpsielen += 6;
/* Model Number */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_MODEL_NUMBER);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = 0x31; /* character 1 */
/* Serial Number */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_SERIAL_NUMBER);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(ETH_ALEN);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, "123456" , ETH_ALEN);
wpsielen += ETH_ALEN;
/* Primary Device Type */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_PRIMARY_DEV_TYPE);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0008);
wpsielen += 2;
/* Value: */
/* Category ID */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
wpsielen += 2;
/* OUI */
*(u32 *)(wpsie + wpsielen) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* Sub Category ID */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
wpsielen += 2;
/* Device Name */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->device_name_len);
wpsielen += 2;
/* Value: */
_rtw_memcpy(wpsie + wpsielen, pwdinfo->device_name, pwdinfo->device_name_len);
wpsielen += pwdinfo->device_name_len;
/* Config Method */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_CONF_METHOD);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen);
p2pielen = build_probe_resp_p2p_ie(pwdinfo, pframe);
pframe += p2pielen;
pktlen += p2pielen;
}
#ifdef CONFIG_WFD
wfdielen = rtw_append_probe_resp_wfd_ie(padapter, pframe);
pframe += wfdielen;
pktlen += wfdielen;
#endif
*pLength = pktlen;
#if 0
/* printf dbg msg */
dbgbufLen = pktlen;
RTW_INFO("======> DBG MSG FOR CONSTRAUCT P2P Probe Rsp\n");
for (index = 0; index < dbgbufLen; index++)
printk("%x ", *(dbgbuf + index));
printk("\n");
RTW_INFO("<====== DBG MSG FOR CONSTRAUCT P2P Probe Rsp\n");
#endif
}
static void rtw_hal_construct_P2PNegoRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
{
struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_GO_NEGO_RESP;
u8 wpsie[255] = { 0x00 }, p2pie[255] = { 0x00 };
u8 p2pielen = 0, i;
uint wpsielen = 0;
u16 wps_devicepassword_id = 0x0000;
uint wps_devicepassword_id_len = 0;
u8 channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh;
u16 len_channellist_attr = 0;
u32 pktlen;
u8 dialogToken = 0;
/* struct xmit_frame *pmgntframe; */
/* struct pkt_attrib *pattrib; */
/* unsigned char *pframe; */
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
/* WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network); */
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
/* for debug */
u8 *dbgbuf = pframe;
u8 dbgbufLen = 0, index = 0;
RTW_INFO("%s\n", __FUNCTION__);
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
/* RA, filled by FW */
_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(pframe, WIFI_ACTION);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe += pktlen;
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));
/* dialog token, filled by FW */
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));
_rtw_memset(wpsie, 0x00, 255);
wpsielen = 0;
/* WPS Section */
wpsielen = 0;
/* WPS OUI */
*(u32 *)(wpsie) = cpu_to_be32(WPSOUI);
wpsielen += 4;
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
/* Device Password ID */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_DEVICE_PWID);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0002);
wpsielen += 2;
/* Value: */
if (wps_devicepassword_id == WPS_DPID_USER_SPEC)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_REGISTRAR_SPEC);
else if (wps_devicepassword_id == WPS_DPID_REGISTRAR_SPEC)
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_USER_SPEC);
else
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_DPID_PBC);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen);
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20100908 */
/* According to the P2P Specification, the group negoitation response frame should contain 9 P2P attributes */
/* 1. Status */
/* 2. P2P Capability */
/* 3. Group Owner Intent */
/* 4. Configuration Timeout */
/* 5. Operating Channel */
/* 6. Intended P2P Interface Address */
/* 7. Channel List */
/* 8. Device Info */
/* 9. Group ID ( Only GO ) */
/* ToDo: */
/* P2P Status */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_STATUS;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value, filled by FW */
p2pie[p2pielen++] = 1;
/* P2P Capability */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CAPABILITY;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
/* Device Capability Bitmap, 1 byte */
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_CLIENT)) {
/* Commented by Albert 2011/03/08 */
/* According to the P2P specification */
/* if the sending device will be client, the P2P Capability should be reserved of group negotation response frame */
p2pie[p2pielen++] = 0;
} else {
/* Be group owner or meet the error case */
p2pie[p2pielen++] = DMP_P2P_DEVCAP_SUPPORT;
}
/* Group Capability Bitmap, 1 byte */
if (pwdinfo->persistent_supported)
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN | P2P_GRPCAP_PERSISTENT_GROUP;
else
p2pie[p2pielen++] = P2P_GRPCAP_CROSS_CONN;
/* Group Owner Intent */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GO_INTENT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: */
if (pwdinfo->peer_intent & 0x01) {
/* Peer's tie breaker bit is 1, our tie breaker bit should be 0 */
p2pie[p2pielen++] = (pwdinfo->intent << 1);
} else {
/* Peer's tie breaker bit is 0, our tie breaker bit should be 1 */
p2pie[p2pielen++] = ((pwdinfo->intent << 1) | BIT(0));
}
/* Configuration Timeout */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P GO */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P Client */
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
if (pwdinfo->operating_channel <= 14) {
/* Operating Class */
p2pie[p2pielen++] = 0x51;
} else if ((pwdinfo->operating_channel >= 36) && (pwdinfo->operating_channel <= 48)) {
/* Operating Class */
p2pie[p2pielen++] = 0x73;
} else {
/* Operating Class */
p2pie[p2pielen++] = 0x7c;
}
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* operating channel number */
/* Intended P2P Interface Address */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_INTENDED_IF_ADDR;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
/* Country String(3) */
/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
/* + number of channels in all classes */
len_channellist_attr = 3
+ (1 + 1) * (u16)ch_list->reg_classes
+ get_reg_classes_full_count(ch_list);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_buddy_check_fwstate(padapter, _FW_LINKED))
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#endif
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Channel Entry List */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED)) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
/* Operating Class */
if (union_ch > 14) {
if (union_ch >= 149)
p2pie[p2pielen++] = 0x7c;
else
p2pie[p2pielen++] = 0x73;
} else
p2pie[p2pielen++] = 0x51;
/* Number of Channels */
/* Just support 1 channel and this channel is AP's channel */
p2pie[p2pielen++] = 1;
/* Channel List */
p2pie[p2pielen++] = union_ch;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
int i, j;
for (j = 0; j < ch_list->reg_classes; j++) {
/* Operating Class */
p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
/* Number of Channels */
p2pie[p2pielen++] = ch_list->reg_class[j].channels;
/* Channel List */
for (i = 0; i < ch_list->reg_class[j].channels; i++)
p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
}
}
/* Device Info */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_DEVICE_INFO;
/* Length: */
/* 21->P2P Device Address (6bytes) + Config Methods (2bytes) + Primary Device Type (8bytes) */
/* + NumofSecondDevType (1byte) + WPS Device Name ID field (2bytes) + WPS Device Name Len field (2bytes) */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(21 + pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
/* P2P Device Address */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
/* Config Method */
/* This field should be big endian. Noted by P2P specification. */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->supported_wps_cm);
p2pielen += 2;
/* Primary Device Type */
/* Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_CID_MULIT_MEDIA);
p2pielen += 2;
/* OUI */
*(u32 *)(p2pie + p2pielen) = cpu_to_be32(WPSOUI);
p2pielen += 4;
/* Sub Category ID */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_PDT_SCID_MEDIA_SERVER);
p2pielen += 2;
/* Number of Secondary Device Types */
p2pie[p2pielen++] = 0x00; /* No Secondary Device Type List */
/* Device Name */
/* Type: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(WPS_ATTR_DEVICE_NAME);
p2pielen += 2;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_be16(pwdinfo->device_name_len);
p2pielen += 2;
/* Value: */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->device_name , pwdinfo->device_name_len);
p2pielen += pwdinfo->device_name_len;
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* Group ID Attribute */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_ID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN + pwdinfo->nego_ssidlen);
p2pielen += 2;
/* Value: */
/* p2P Device Address */
_rtw_memcpy(p2pie + p2pielen , pwdinfo->device_addr, ETH_ALEN);
p2pielen += ETH_ALEN;
/* SSID */
_rtw_memcpy(p2pie + p2pielen, pwdinfo->nego_ssid, pwdinfo->nego_ssidlen);
p2pielen += pwdinfo->nego_ssidlen;
}
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pktlen);
#ifdef CONFIG_WFD
wfdielen = build_nego_resp_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pktlen += wfdielen;
#endif
*pLength = pktlen;
#if 0
/* printf dbg msg */
dbgbufLen = pktlen;
RTW_INFO("======> DBG MSG FOR CONSTRAUCT Nego Rsp\n");
for (index = 0; index < dbgbufLen; index++)
printk("%x ", *(dbgbuf + index));
printk("\n");
RTW_INFO("<====== DBG MSG FOR CONSTRAUCT Nego Rsp\n");
#endif
}
static void rtw_hal_construct_P2PInviteRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
{
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_INVIT_RESP;
u8 p2pie[255] = { 0x00 };
u8 p2pielen = 0, i;
u8 channel_cnt_24g = 0, channel_cnt_5gl = 0, channel_cnt_5gh = 0;
u16 len_channellist_attr = 0;
u32 pktlen;
u8 dialogToken = 0;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
/* struct xmit_frame *pmgntframe; */
/* struct pkt_attrib *pattrib; */
/* unsigned char *pframe; */
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
/* for debug */
u8 *dbgbuf = pframe;
u8 dbgbufLen = 0, index = 0;
RTW_INFO("%s\n", __FUNCTION__);
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
/* RA fill by FW */
_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
/* BSSID fill by FW */
_rtw_memset(pwlanhdr->addr3, 0, ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));
/* dialog token, filled by FW */
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));
/* P2P IE Section. */
/* P2P OUI */
p2pielen = 0;
p2pie[p2pielen++] = 0x50;
p2pie[p2pielen++] = 0x6F;
p2pie[p2pielen++] = 0x9A;
p2pie[p2pielen++] = 0x09; /* WFA P2P v1.0 */
/* Commented by Albert 20101005 */
/* According to the P2P Specification, the P2P Invitation response frame should contain 5 P2P attributes */
/* 1. Status */
/* 2. Configuration Timeout */
/* 3. Operating Channel ( Only GO ) */
/* 4. P2P Group BSSID ( Only GO ) */
/* 5. Channel List */
/* P2P Status */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_STATUS;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0001);
p2pielen += 2;
/* Value: filled by FW, defult value is FAIL INFO UNAVAILABLE */
p2pie[p2pielen++] = P2P_STATUS_FAIL_INFO_UNAVAILABLE;
/* Configuration Timeout */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CONF_TIMEOUT;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0002);
p2pielen += 2;
/* Value: */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P GO */
p2pie[p2pielen++] = 200; /* 2 seconds needed to be the P2P Client */
/* due to defult value is FAIL INFO UNAVAILABLE, so the following IE is not needed */
#if 0
if (status_code == P2P_STATUS_SUCCESS) {
struct p2p_channels *ch_list = &(adapter_to_rfctl(padapter)->channel_list);
if (rtw_p2p_chk_role(pwdinfo, P2P_ROLE_GO)) {
/* The P2P Invitation request frame asks this Wi-Fi device to be the P2P GO */
/* In this case, the P2P Invitation response frame should carry the two more P2P attributes. */
/* First one is operating channel attribute. */
/* Second one is P2P Group BSSID attribute. */
/* Operating Channel */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_OPERATING_CH;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(0x0005);
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Operating Class */
p2pie[p2pielen++] = 0x51; /* Copy from SD7 */
/* Channel Number */
p2pie[p2pielen++] = pwdinfo->operating_channel; /* operating channel number */
/* P2P Group BSSID */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_GROUP_BSSID;
/* Length: */
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(ETH_ALEN);
p2pielen += 2;
/* Value: */
/* P2P Device Address for GO */
_rtw_memcpy(p2pie + p2pielen, adapter_mac_addr(padapter), ETH_ALEN);
p2pielen += ETH_ALEN;
}
/* Channel List */
/* Type: */
p2pie[p2pielen++] = P2P_ATTR_CH_LIST;
/* Length: */
/* Country String(3) */
/* + ( Operating Class (1) + Number of Channels(1) ) * Operation Classes (?) */
/* + number of channels in all classes */
len_channellist_attr = 3
+ (1 + 1) * (u16)ch_list->reg_classes
+ get_reg_classes_full_count(ch_list);
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED))
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(5 + 1);
else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#else
*(u16 *)(p2pie + p2pielen) = cpu_to_le16(len_channellist_attr);
#endif
p2pielen += 2;
/* Value: */
/* Country String */
p2pie[p2pielen++] = 'X';
p2pie[p2pielen++] = 'X';
/* The third byte should be set to 0x04. */
/* Described in the "Operating Channel Attribute" section. */
p2pie[p2pielen++] = 0x04;
/* Channel Entry List */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(padapter, MI_LINKED)) {
u8 union_ch = rtw_mi_get_union_chan(padapter);
/* Operating Class */
if (union_ch > 14) {
if (union_ch >= 149)
p2pie[p2pielen++] = 0x7c;
else
p2pie[p2pielen++] = 0x73;
} else
p2pie[p2pielen++] = 0x51;
/* Number of Channels */
/* Just support 1 channel and this channel is AP's channel */
p2pie[p2pielen++] = 1;
/* Channel List */
p2pie[p2pielen++] = union_ch;
} else
#endif /* CONFIG_CONCURRENT_MODE */
{
int i, j;
for (j = 0; j < ch_list->reg_classes; j++) {
/* Operating Class */
p2pie[p2pielen++] = ch_list->reg_class[j].reg_class;
/* Number of Channels */
p2pie[p2pielen++] = ch_list->reg_class[j].channels;
/* Channel List */
for (i = 0; i < ch_list->reg_class[j].channels; i++)
p2pie[p2pielen++] = ch_list->reg_class[j].channel[i];
}
}
}
#endif
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, p2pielen, (unsigned char *) p2pie, &pktlen);
#ifdef CONFIG_WFD
wfdielen = build_invitation_resp_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pktlen += wfdielen;
#endif
*pLength = pktlen;
#if 0
/* printf dbg msg */
dbgbufLen = pktlen;
RTW_INFO("======> DBG MSG FOR CONSTRAUCT Invite Rsp\n");
for (index = 0; index < dbgbufLen; index++)
printk("%x ", *(dbgbuf + index));
printk("\n");
RTW_INFO("<====== DBG MSG FOR CONSTRAUCT Invite Rsp\n");
#endif
}
static void rtw_hal_construct_P2PProvisionDisRsp(_adapter *padapter, u8 *pframe, u32 *pLength)
{
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
u8 action = P2P_PUB_ACTION_ACTION;
u8 dialogToken = 0;
u32 p2poui = cpu_to_be32(P2POUI);
u8 oui_subtype = P2P_PROVISION_DISC_RESP;
u8 wpsie[100] = { 0x00 };
u8 wpsielen = 0;
u32 pktlen;
#ifdef CONFIG_WFD
u32 wfdielen = 0;
#endif
/* struct xmit_frame *pmgntframe; */
/* struct pkt_attrib *pattrib; */
/* unsigned char *pframe; */
struct rtw_ieee80211_hdr *pwlanhdr;
unsigned short *fctrl;
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
/* for debug */
u8 *dbgbuf = pframe;
u8 dbgbufLen = 0, index = 0;
RTW_INFO("%s\n", __FUNCTION__);
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
/* RA filled by FW */
_rtw_memset(pwlanhdr->addr1, 0, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(pframe, WIFI_ACTION);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe = rtw_set_fixed_ie(pframe, 1, &(category), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(action), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 4, (unsigned char *) &(p2poui), &(pktlen));
pframe = rtw_set_fixed_ie(pframe, 1, &(oui_subtype), &(pktlen));
/* dialog token, filled by FW */
pframe = rtw_set_fixed_ie(pframe, 1, &(dialogToken), &(pktlen));
wpsielen = 0;
/* WPS OUI */
/* *(u32*) ( wpsie ) = cpu_to_be32( WPSOUI ); */
RTW_PUT_BE32(wpsie, WPSOUI);
wpsielen += 4;
#if 0
/* WPS version */
/* Type: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(WPS_ATTR_VER1);
wpsielen += 2;
/* Length: */
*(u16 *)(wpsie + wpsielen) = cpu_to_be16(0x0001);
wpsielen += 2;
/* Value: */
wpsie[wpsielen++] = WPS_VERSION_1; /* Version 1.0 */
#endif
/* Config Method */
/* Type: */
/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( WPS_ATTR_CONF_METHOD ); */
RTW_PUT_BE16(wpsie + wpsielen, WPS_ATTR_CONF_METHOD);
wpsielen += 2;
/* Length: */
/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( 0x0002 ); */
RTW_PUT_BE16(wpsie + wpsielen, 0x0002);
wpsielen += 2;
/* Value: filled by FW, default value is PBC */
/* *(u16*) ( wpsie + wpsielen ) = cpu_to_be16( config_method ); */
RTW_PUT_BE16(wpsie + wpsielen, WPS_CM_PUSH_BUTTON);
wpsielen += 2;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_, wpsielen, (unsigned char *) wpsie, &pktlen);
#ifdef CONFIG_WFD
wfdielen = build_provdisc_resp_wfd_ie(pwdinfo, pframe);
pframe += wfdielen;
pktlen += wfdielen;
#endif
*pLength = pktlen;
/* printf dbg msg */
#if 0
dbgbufLen = pktlen;
RTW_INFO("======> DBG MSG FOR CONSTRAUCT ProvisionDis Rsp\n");
for (index = 0; index < dbgbufLen; index++)
printk("%x ", *(dbgbuf + index));
printk("\n");
RTW_INFO("<====== DBG MSG FOR CONSTRAUCT ProvisionDis Rsp\n");
#endif
}
u8 rtw_hal_set_FwP2PRsvdPage_cmd(_adapter *adapter, PRSVDPAGE_LOC rsvdpageloc)
{
u8 u1H2CP2PRsvdPageParm[H2C_P2PRSVDPAGE_LOC_LEN] = {0};
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 ret = _FAIL;
RTW_INFO("P2PRsvdPageLoc: P2PBeacon=%d P2PProbeRsp=%d NegoRsp=%d InviteRsp=%d PDRsp=%d\n",
rsvdpageloc->LocP2PBeacon, rsvdpageloc->LocP2PProbeRsp,
rsvdpageloc->LocNegoRsp, rsvdpageloc->LocInviteRsp,
rsvdpageloc->LocPDRsp);
SET_H2CCMD_RSVDPAGE_LOC_P2P_BCN(u1H2CP2PRsvdPageParm, rsvdpageloc->LocProbeRsp);
SET_H2CCMD_RSVDPAGE_LOC_P2P_PROBE_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocPsPoll);
SET_H2CCMD_RSVDPAGE_LOC_P2P_NEGO_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocNullData);
SET_H2CCMD_RSVDPAGE_LOC_P2P_INVITE_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocQosNull);
SET_H2CCMD_RSVDPAGE_LOC_P2P_PD_RSP(u1H2CP2PRsvdPageParm, rsvdpageloc->LocBTQosNull);
/* FillH2CCmd8723B(padapter, H2C_8723B_P2P_OFFLOAD_RSVD_PAGE, H2C_P2PRSVDPAGE_LOC_LEN, u1H2CP2PRsvdPageParm); */
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_P2P_OFFLOAD_RSVD_PAGE,
H2C_P2PRSVDPAGE_LOC_LEN,
u1H2CP2PRsvdPageParm);
return ret;
}
u8 rtw_hal_set_p2p_wowlan_offload_cmd(_adapter *adapter)
{
u8 offload_cmd[H2C_P2P_OFFLOAD_LEN] = {0};
struct wifidirect_info *pwdinfo = &(adapter->wdinfo);
struct P2P_WoWlan_Offload_t *p2p_wowlan_offload = (struct P2P_WoWlan_Offload_t *)offload_cmd;
struct hal_ops *pHalFunc = &adapter->hal_func;
u8 ret = _FAIL;
_rtw_memset(p2p_wowlan_offload, 0 , sizeof(struct P2P_WoWlan_Offload_t));
RTW_INFO("%s\n", __func__);
switch (pwdinfo->role) {
case P2P_ROLE_DEVICE:
RTW_INFO("P2P_ROLE_DEVICE\n");
p2p_wowlan_offload->role = 0;
break;
case P2P_ROLE_CLIENT:
RTW_INFO("P2P_ROLE_CLIENT\n");
p2p_wowlan_offload->role = 1;
break;
case P2P_ROLE_GO:
RTW_INFO("P2P_ROLE_GO\n");
p2p_wowlan_offload->role = 2;
break;
default:
RTW_INFO("P2P_ROLE_DISABLE\n");
break;
}
p2p_wowlan_offload->Wps_Config[0] = pwdinfo->supported_wps_cm >> 8;
p2p_wowlan_offload->Wps_Config[1] = pwdinfo->supported_wps_cm;
offload_cmd = (u8 *)p2p_wowlan_offload;
RTW_INFO("p2p_wowlan_offload: %x:%x:%x\n", offload_cmd[0], offload_cmd[1], offload_cmd[2]);
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_P2P_OFFLOAD,
H2C_P2P_OFFLOAD_LEN,
offload_cmd);
return ret;
/* FillH2CCmd8723B(adapter, H2C_8723B_P2P_OFFLOAD, sizeof(struct P2P_WoWlan_Offload_t), (u8 *)p2p_wowlan_offload); */
}
#endif /* CONFIG_P2P_WOWLAN */
void rtw_hal_construct_beacon(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 rate_len, pktlen;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
/* RTW_INFO("%s\n", __FUNCTION__); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(cur_network), ETH_ALEN);
SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
/* pmlmeext->mgnt_seq++; */
set_frame_sub_type(pframe, WIFI_BEACON);
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
/* timestamp will be inserted by hardware */
pframe += 8;
pktlen += 8;
/* beacon interval: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_beacon_interval_from_ie(cur_network->IEs)), 2);
pframe += 2;
pktlen += 2;
#if 0
/* capability info: 2 bytes */
_rtw_memcpy(pframe, (unsigned char *)(rtw_get_capability_from_ie(cur_network->IEs)), 2);
pframe += 2;
pktlen += 2;
if ((pmlmeinfo->state & 0x03) == WIFI_FW_AP_STATE) {
/* RTW_INFO("ie len=%d\n", cur_network->IELength); */
pktlen += cur_network->IELength - sizeof(NDIS_802_11_FIXED_IEs);
_rtw_memcpy(pframe, cur_network->IEs + sizeof(NDIS_802_11_FIXED_IEs), pktlen);
goto _ConstructBeacon;
}
/* below for ad-hoc mode */
/* SSID */
pframe = rtw_set_ie(pframe, _SSID_IE_, cur_network->Ssid.SsidLength, cur_network->Ssid.Ssid, &pktlen);
/* supported rates... */
rate_len = rtw_get_rateset_len(cur_network->SupportedRates);
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_, ((rate_len > 8) ? 8 : rate_len), cur_network->SupportedRates, &pktlen);
/* DS parameter set */
pframe = rtw_set_ie(pframe, _DSSET_IE_, 1, (unsigned char *)&(cur_network->Configuration.DSConfig), &pktlen);
if ((pmlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE) {
u32 ATIMWindow;
/* IBSS Parameter Set... */
/* ATIMWindow = cur->Configuration.ATIMWindow; */
ATIMWindow = 0;
pframe = rtw_set_ie(pframe, _IBSS_PARA_IE_, 2, (unsigned char *)(&ATIMWindow), &pktlen);
}
/* todo: ERP IE */
/* EXTERNDED SUPPORTED RATE */
if (rate_len > 8)
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_, (rate_len - 8), (cur_network->SupportedRates + 8), &pktlen);
/* todo:HT for adhoc */
_ConstructBeacon:
#endif
if ((pktlen + TXDESC_SIZE) > MAX_BEACON_LEN) {
RTW_ERR("beacon frame too large ,len(%d,%d)\n",
(pktlen + TXDESC_SIZE), MAX_BEACON_LEN);
rtw_warn_on(1);
return;
}
*pLength = pktlen;
/* RTW_INFO("%s bcn_sz=%d\n", __FUNCTION__, pktlen); */
}
static void rtw_hal_construct_PSPoll(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 pktlen;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* RTW_INFO("%s\n", __FUNCTION__); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
/* Frame control. */
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
SetPwrMgt(fctrl);
set_frame_sub_type(pframe, WIFI_PSPOLL);
/* AID. */
set_duration(pframe, (pmlmeinfo->aid | 0xc000));
/* BSSID. */
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
/* TA. */
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
*pLength = 16;
}
#ifdef DBG_FW_DEBUG_MSG_PKT
void rtw_hal_construct_fw_dbg_msg_pkt(
PADAPTER padapter,
u8 *pframe,
u32 *plength)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 pktlen;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &pwlanhdr->frame_ctl;
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(pframe, WIFI_DATA);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
*plength = pktlen;
}
#endif /*DBG_FW_DEBUG_MSG_PKT*/
void rtw_hal_construct_NullFunctionData(
PADAPTER padapter,
u8 *pframe,
u32 *pLength,
u8 bQoS,
u8 AC,
u8 bEosp,
u8 bForcePowerSave)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 pktlen;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
u8 *sta_addr = NULL;
u8 bssid[ETH_ALEN] = {0};
/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &pwlanhdr->frame_ctl;
*(fctrl) = 0;
if (bForcePowerSave)
SetPwrMgt(fctrl);
sta_addr = get_my_bssid(&pmlmeinfo->network);
if (NULL == sta_addr) {
_rtw_memcpy(bssid, adapter_mac_addr(padapter), ETH_ALEN);
sta_addr = bssid;
}
switch (cur_network->network.InfrastructureMode) {
case Ndis802_11Infrastructure:
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, sta_addr, ETH_ALEN);
break;
case Ndis802_11APMode:
SetFrDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, sta_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, adapter_mac_addr(padapter), ETH_ALEN);
break;
case Ndis802_11IBSS:
default:
_rtw_memcpy(pwlanhdr->addr1, sta_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
break;
}
SetSeqNum(pwlanhdr, 0);
set_duration(pwlanhdr, 0);
if (bQoS == _TRUE) {
struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
set_frame_sub_type(pframe, WIFI_QOS_DATA_NULL);
pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
SetPriority(&pwlanqoshdr->qc, AC);
SetEOSP(&pwlanqoshdr->qc, bEosp);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
} else {
set_frame_sub_type(pframe, WIFI_DATA_NULL);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
}
*pLength = pktlen;
}
void rtw_hal_construct_ProbeRsp(_adapter *padapter, u8 *pframe, u32 *pLength,
BOOLEAN bHideSSID)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u8 *mac, *bssid, *sta_addr;
u32 pktlen;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
WLAN_BSSID_EX *cur_network = &(pmlmeinfo->network);
/*RTW_INFO("%s\n", __FUNCTION__);*/
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
mac = adapter_mac_addr(padapter);
bssid = cur_network->MacAddress;
sta_addr = get_my_bssid(&pmlmeinfo->network);
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, sta_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, bssid, ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(fctrl, WIFI_PROBERSP);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe += pktlen;
if (cur_network->IELength > MAX_IE_SZ)
return;
_rtw_memcpy(pframe, cur_network->IEs, cur_network->IELength);
pframe += cur_network->IELength;
pktlen += cur_network->IELength;
*pLength = pktlen;
}
#ifdef CONFIG_WOWLAN
static void rtw_hal_append_tkip_mic(PADAPTER padapter,
u8 *pframe, u32 offset)
{
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct rtw_ieee80211_hdr *pwlanhdr;
struct mic_data micdata;
struct sta_info *psta = NULL;
int res = 0;
u8 *payload = (u8 *)(pframe + offset);
u8 mic[8];
u8 priority[4] = {0x0};
u8 null_key[16] = {0x0};
RTW_INFO("%s(): Add MIC, offset: %d\n", __func__, offset);
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
psta = rtw_get_stainfo(&padapter->stapriv,
get_my_bssid(&(pmlmeinfo->network)));
if (psta != NULL) {
res = _rtw_memcmp(&psta->dot11tkiptxmickey.skey[0],
null_key, 16);
if (res == _TRUE)
RTW_INFO("%s(): STA dot11tkiptxmickey==0\n", __func__);
rtw_secmicsetkey(&micdata, &psta->dot11tkiptxmickey.skey[0]);
}
rtw_secmicappend(&micdata, pwlanhdr->addr3, 6); /* DA */
rtw_secmicappend(&micdata, pwlanhdr->addr2, 6); /* SA */
priority[0] = 0;
rtw_secmicappend(&micdata, &priority[0], 4);
rtw_secmicappend(&micdata, payload, 36); /* payload length = 8 + 28 */
rtw_secgetmic(&micdata, &(mic[0]));
payload += 36;
_rtw_memcpy(payload, &(mic[0]), 8);
}
/*
* Description:
* Construct the ARP response packet to support ARP offload.
* */
static void rtw_hal_construct_ARPRsp(
PADAPTER padapter,
u8 *pframe,
u32 *pLength,
u8 *pIPAddress
)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 pktlen;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct security_priv *psecuritypriv = &padapter->securitypriv;
static u8 ARPLLCHeader[8] = {0xAA, 0xAA, 0x03, 0x00, 0x00, 0x00, 0x08, 0x06};
u8 *pARPRspPkt = pframe;
/* for TKIP Cal MIC */
u8 *payload = pframe;
u8 EncryptionHeadOverhead = 0, arp_offset = 0;
/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &pwlanhdr->frame_ctl;
*(fctrl) = 0;
/* ------------------------------------------------------------------------- */
/* MAC Header. */
/* ------------------------------------------------------------------------- */
SetFrameType(fctrl, WIFI_DATA);
/* set_frame_sub_type(fctrl, 0); */
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_duration(pwlanhdr, 0);
/* SET_80211_HDR_FRAME_CONTROL(pARPRspPkt, 0); */
/* SET_80211_HDR_TYPE_AND_SUBTYPE(pARPRspPkt, Type_Data); */
/* SET_80211_HDR_TO_DS(pARPRspPkt, 1); */
/* SET_80211_HDR_ADDRESS1(pARPRspPkt, pMgntInfo->Bssid); */
/* SET_80211_HDR_ADDRESS2(pARPRspPkt, Adapter->CurrentAddress); */
/* SET_80211_HDR_ADDRESS3(pARPRspPkt, pMgntInfo->Bssid); */
/* SET_80211_HDR_DURATION(pARPRspPkt, 0); */
/* SET_80211_HDR_FRAGMENT_SEQUENCE(pARPRspPkt, 0); */
#ifdef CONFIG_WAPI_SUPPORT
*pLength = sMacHdrLng;
#else
*pLength = 24;
#endif
switch (psecuritypriv->dot11PrivacyAlgrthm) {
case _WEP40_:
case _WEP104_:
EncryptionHeadOverhead = 4;
break;
case _TKIP_:
EncryptionHeadOverhead = 8;
break;
case _AES_:
EncryptionHeadOverhead = 8;
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
EncryptionHeadOverhead = 18;
break;
#endif
default:
EncryptionHeadOverhead = 0;
}
if (EncryptionHeadOverhead > 0) {
_rtw_memset(&(pframe[*pLength]), 0, EncryptionHeadOverhead);
*pLength += EncryptionHeadOverhead;
/* SET_80211_HDR_WEP(pARPRspPkt, 1); */ /* Suggested by CCW. */
SetPrivacy(fctrl);
}
/* ------------------------------------------------------------------------- */
/* Frame Body. */
/* ------------------------------------------------------------------------- */
arp_offset = *pLength;
pARPRspPkt = (u8 *)(pframe + arp_offset);
payload = pARPRspPkt; /* Get Payload pointer */
/* LLC header */
_rtw_memcpy(pARPRspPkt, ARPLLCHeader, 8);
*pLength += 8;
/* ARP element */
pARPRspPkt += 8;
SET_ARP_HTYPE(pARPRspPkt, 1);
SET_ARP_PTYPE(pARPRspPkt, ETH_P_IP); /* IP protocol */
SET_ARP_HLEN(pARPRspPkt, ETH_ALEN);
SET_ARP_PLEN(pARPRspPkt, RTW_IP_ADDR_LEN);
SET_ARP_OPER(pARPRspPkt, 2); /* ARP response */
SET_ARP_SENDER_MAC_ADDR(pARPRspPkt, adapter_mac_addr(padapter));
SET_ARP_SENDER_IP_ADDR(pARPRspPkt, pIPAddress);
#ifdef CONFIG_ARP_KEEP_ALIVE
if (!is_zero_mac_addr(pmlmepriv->gw_mac_addr)) {
SET_ARP_TARGET_MAC_ADDR(pARPRspPkt, pmlmepriv->gw_mac_addr);
SET_ARP_TARGET_IP_ADDR(pARPRspPkt, pmlmepriv->gw_ip);
} else
#endif
{
SET_ARP_TARGET_MAC_ADDR(pARPRspPkt,
get_my_bssid(&(pmlmeinfo->network)));
SET_ARP_TARGET_IP_ADDR(pARPRspPkt,
pIPAddress);
RTW_INFO("%s Target Mac Addr:" MAC_FMT "\n", __FUNCTION__,
MAC_ARG(get_my_bssid(&(pmlmeinfo->network))));
RTW_INFO("%s Target IP Addr" IP_FMT "\n", __FUNCTION__,
IP_ARG(pIPAddress));
}
*pLength += 28;
if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) {
if (IS_HARDWARE_TYPE_8188E(padapter) ||
IS_HARDWARE_TYPE_8812(padapter)) {
rtw_hal_append_tkip_mic(padapter, pframe, arp_offset);
}
*pLength += 8;
}
}
#ifdef CONFIG_IPV6
/*
* Description: Neighbor Discovery Offload.
*/
static void rtw_hal_construct_na_message(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct rtw_ieee80211_hdr *pwlanhdr = NULL;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
struct security_priv *psecuritypriv = &padapter->securitypriv;
u32 pktlen = 0;
u16 *fctrl = NULL;
u8 ns_hdr[8] = {0xAA, 0xAA, 0x03, 0x00, 0x00, 0x00, 0x86, 0xDD};
u8 ipv6_info[4] = {0x60, 0x00, 0x00, 0x00};
u8 ipv6_contx[4] = {0x00, 0x20, 0x3a, 0xff};
u8 icmpv6_hdr[8] = {0x88, 0x00, 0x00, 0x00, 0x60, 0x00, 0x00, 0x00};
u8 val8 = 0;
u8 *p_na_msg = pframe;
/* for TKIP Cal MIC */
u8 *payload = pframe;
u8 EncryptionHeadOverhead = 0, na_msg_offset = 0;
/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &pwlanhdr->frame_ctl;
*(fctrl) = 0;
/* ------------------------------------------------------------------------- */
/* MAC Header. */
/* ------------------------------------------------------------------------- */
SetFrameType(fctrl, WIFI_DATA);
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1,
get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2,
adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3,
get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_duration(pwlanhdr, 0);
#ifdef CONFIG_WAPI_SUPPORT
*pLength = sMacHdrLng;
#else
*pLength = 24;
#endif
switch (psecuritypriv->dot11PrivacyAlgrthm) {
case _WEP40_:
case _WEP104_:
EncryptionHeadOverhead = 4;
break;
case _TKIP_:
EncryptionHeadOverhead = 8;
break;
case _AES_:
EncryptionHeadOverhead = 8;
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
EncryptionHeadOverhead = 18;
break;
#endif
default:
EncryptionHeadOverhead = 0;
}
if (EncryptionHeadOverhead > 0) {
_rtw_memset(&(pframe[*pLength]), 0, EncryptionHeadOverhead);
*pLength += EncryptionHeadOverhead;
/* SET_80211_HDR_WEP(pARPRspPkt, 1); */ /* Suggested by CCW. */
SetPrivacy(fctrl);
}
/* ------------------------------------------------------------------------- */
/* Frame Body. */
/* ------------------------------------------------------------------------- */
na_msg_offset = *pLength;
p_na_msg = (u8 *)(pframe + na_msg_offset);
payload = p_na_msg; /* Get Payload pointer */
/* LLC header */
val8 = sizeof(ns_hdr);
_rtw_memcpy(p_na_msg, ns_hdr, val8);
*pLength += val8;
p_na_msg += val8;
/* IPv6 Header */
/* 1 . Information (4 bytes): 0x60 0x00 0x00 0x00 */
val8 = sizeof(ipv6_info);
_rtw_memcpy(p_na_msg, ipv6_info, val8);
*pLength += val8;
p_na_msg += val8;
/* 2 . playload : 0x00 0x20 , NextProt : 0x3a (ICMPv6) HopLim : 0xff */
val8 = sizeof(ipv6_contx);
_rtw_memcpy(p_na_msg, ipv6_contx, val8);
*pLength += val8;
p_na_msg += val8;
/* 3 . SA : 16 bytes , DA : 16 bytes ( Fw will filled ) */
_rtw_memset(&(p_na_msg[*pLength]), 0, 32);
*pLength += 32;
p_na_msg += 32;
/* ICMPv6 */
/* 1. Type : 0x88 (NA)
* 2. Code : 0x00
* 3. ChechSum : 0x00 0x00 (RSvd)
* 4. NAFlag: 0x60 0x00 0x00 0x00 ( Solicited , Override)
*/
val8 = sizeof(icmpv6_hdr);
_rtw_memcpy(p_na_msg, icmpv6_hdr, val8);
*pLength += val8;
p_na_msg += val8;
/* TA: 16 bytes*/
_rtw_memset(&(p_na_msg[*pLength]), 0, 16);
*pLength += 16;
p_na_msg += 16;
/* ICMPv6 Target Link Layer Address */
p_na_msg[0] = 0x02; /* type */
p_na_msg[1] = 0x01; /* len 1 unit of 8 octes */
*pLength += 2;
p_na_msg += 2;
_rtw_memset(&(p_na_msg[*pLength]), 0, 6);
*pLength += 6;
p_na_msg += 6;
if (psecuritypriv->dot11PrivacyAlgrthm == _TKIP_) {
if (IS_HARDWARE_TYPE_8188E(padapter) ||
IS_HARDWARE_TYPE_8812(padapter)) {
rtw_hal_append_tkip_mic(padapter, pframe,
na_msg_offset);
}
*pLength += 8;
}
}
/*
* Description: Neighbor Discovery Protocol Information.
*/
static void rtw_hal_construct_ndp_info(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct mlme_ext_priv *pmlmeext = NULL;
struct mlme_ext_info *pmlmeinfo = NULL;
struct rtw_ndp_info ndp_info;
u8 *pndp_info = pframe;
u8 len = sizeof(struct rtw_ndp_info);
RTW_INFO("%s: len: %d\n", __func__, len);
pmlmeext = &padapter->mlmeextpriv;
pmlmeinfo = &pmlmeext->mlmext_info;
_rtw_memset(pframe, 0, len);
_rtw_memset(&ndp_info, 0, len);
ndp_info.enable = 1;
ndp_info.check_remote_ip = 0;
ndp_info.num_of_target_ip = 1;
_rtw_memcpy(&ndp_info.target_link_addr, adapter_mac_addr(padapter),
ETH_ALEN);
_rtw_memcpy(&ndp_info.target_ipv6_addr, pmlmeinfo->ip6_addr,
RTW_IPv6_ADDR_LEN);
_rtw_memcpy(pndp_info, &ndp_info, len);
}
#endif /* CONFIG_IPV6 */
#ifdef CONFIG_PNO_SUPPORT
static void rtw_hal_construct_ProbeReq(_adapter *padapter, u8 *pframe,
u32 *pLength, pno_ssid_t *ssid)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 pktlen;
unsigned char *mac;
unsigned char bssrate[NumRates];
struct xmit_priv *pxmitpriv = &(padapter->xmitpriv);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
int bssrate_len = 0;
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
mac = adapter_mac_addr(padapter);
fctrl = &(pwlanhdr->frame_ctl);
*(fctrl) = 0;
_rtw_memcpy(pwlanhdr->addr1, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3, bc_addr, ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_frame_sub_type(pframe, WIFI_PROBEREQ);
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
pframe += pktlen;
if (ssid == NULL)
pframe = rtw_set_ie(pframe, _SSID_IE_, 0, NULL, &pktlen);
else {
/* RTW_INFO("%s len:%d\n", ssid->SSID, ssid->SSID_len); */
pframe = rtw_set_ie(pframe, _SSID_IE_, ssid->SSID_len, ssid->SSID, &pktlen);
}
get_rate_set(padapter, bssrate, &bssrate_len);
if (bssrate_len > 8) {
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , 8, bssrate, &pktlen);
pframe = rtw_set_ie(pframe, _EXT_SUPPORTEDRATES_IE_ , (bssrate_len - 8), (bssrate + 8), &pktlen);
} else
pframe = rtw_set_ie(pframe, _SUPPORTEDRATES_IE_ , bssrate_len , bssrate, &pktlen);
*pLength = pktlen;
}
static void rtw_hal_construct_PNO_info(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
int i;
u8 *pPnoInfoPkt = pframe;
pPnoInfoPkt = (u8 *)(pframe + *pLength);
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_num, 1);
pPnoInfoPkt += 1;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->hidden_ssid_num, 1);
pPnoInfoPkt += 3;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->fast_scan_period, 1);
pPnoInfoPkt += 4;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->fast_scan_iterations, 4);
pPnoInfoPkt += 4;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->slow_scan_period, 4);
pPnoInfoPkt += 4;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_length, MAX_PNO_LIST_COUNT);
pPnoInfoPkt += MAX_PNO_LIST_COUNT;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_cipher_info, MAX_PNO_LIST_COUNT);
pPnoInfoPkt += MAX_PNO_LIST_COUNT;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->ssid_channel_info, MAX_PNO_LIST_COUNT);
pPnoInfoPkt += MAX_PNO_LIST_COUNT;
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pnlo_info->loc_probe_req, MAX_HIDDEN_AP);
pPnoInfoPkt += MAX_HIDDEN_AP;
/*
SSID is located at 128th Byte in NLO info Page
*/
*pLength += 128;
pPnoInfoPkt = pframe + 128;
for (i = 0; i < pwrctl->pnlo_info->ssid_num ; i++) {
_rtw_memcpy(pPnoInfoPkt, &pwrctl->pno_ssid_list->node[i].SSID,
pwrctl->pnlo_info->ssid_length[i]);
*pLength += WLAN_SSID_MAXLEN;
pPnoInfoPkt += WLAN_SSID_MAXLEN;
}
}
static void rtw_hal_construct_ssid_list(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
u8 *pSSIDListPkt = pframe;
int i;
pSSIDListPkt = (u8 *)(pframe + *pLength);
for (i = 0; i < pwrctl->pnlo_info->ssid_num ; i++) {
_rtw_memcpy(pSSIDListPkt, &pwrctl->pno_ssid_list->node[i].SSID,
pwrctl->pnlo_info->ssid_length[i]);
*pLength += WLAN_SSID_MAXLEN;
pSSIDListPkt += WLAN_SSID_MAXLEN;
}
}
static void rtw_hal_construct_scan_info(_adapter *padapter,
u8 *pframe, u32 *pLength)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(padapter);
u8 *pScanInfoPkt = pframe;
int i;
pScanInfoPkt = (u8 *)(pframe + *pLength);
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->channel_num, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_ch, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_bw, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_40_offset, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->orig_80_offset, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->periodScan, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->period_scan_time, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->enableRFE, 1);
*pLength += 1;
pScanInfoPkt += 1;
_rtw_memcpy(pScanInfoPkt, &pwrctl->pscan_info->rfe_type, 8);
*pLength += 8;
pScanInfoPkt += 8;
for (i = 0 ; i < MAX_SCAN_LIST_COUNT ; i++) {
_rtw_memcpy(pScanInfoPkt,
&pwrctl->pscan_info->ssid_channel_info[i], 4);
*pLength += 4;
pScanInfoPkt += 4;
}
}
#endif /* CONFIG_PNO_SUPPORT */
#ifdef CONFIG_GTK_OL
static void rtw_hal_construct_GTKRsp(
PADAPTER padapter,
u8 *pframe,
u32 *pLength
)
{
struct rtw_ieee80211_hdr *pwlanhdr;
u16 *fctrl;
u32 pktlen;
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
struct wlan_network *cur_network = &pmlmepriv->cur_network;
struct mlme_ext_priv *pmlmeext = &(padapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct security_priv *psecuritypriv = &padapter->securitypriv;
static u8 LLCHeader[8] = {0xAA, 0xAA, 0x03, 0x00, 0x00, 0x00, 0x88, 0x8E};
static u8 GTKbody_a[11] = {0x01, 0x03, 0x00, 0x5F, 0x02, 0x03, 0x12, 0x00, 0x10, 0x42, 0x0B};
u8 *pGTKRspPkt = pframe;
u8 EncryptionHeadOverhead = 0;
/* RTW_INFO("%s:%d\n", __FUNCTION__, bForcePowerSave); */
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
fctrl = &pwlanhdr->frame_ctl;
*(fctrl) = 0;
/* ------------------------------------------------------------------------- */
/* MAC Header. */
/* ------------------------------------------------------------------------- */
SetFrameType(fctrl, WIFI_DATA);
/* set_frame_sub_type(fctrl, 0); */
SetToDs(fctrl);
_rtw_memcpy(pwlanhdr->addr1,
get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr2,
adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy(pwlanhdr->addr3,
get_my_bssid(&(pmlmeinfo->network)), ETH_ALEN);
SetSeqNum(pwlanhdr, 0);
set_duration(pwlanhdr, 0);
#ifdef CONFIG_WAPI_SUPPORT
*pLength = sMacHdrLng;
#else
*pLength = 24;
#endif /* CONFIG_WAPI_SUPPORT */
/* ------------------------------------------------------------------------- */
/* Security Header: leave space for it if necessary. */
/* ------------------------------------------------------------------------- */
switch (psecuritypriv->dot11PrivacyAlgrthm) {
case _WEP40_:
case _WEP104_:
EncryptionHeadOverhead = 4;
break;
case _TKIP_:
EncryptionHeadOverhead = 8;
break;
case _AES_:
EncryptionHeadOverhead = 8;
break;
#ifdef CONFIG_WAPI_SUPPORT
case _SMS4_:
EncryptionHeadOverhead = 18;
break;
#endif /* CONFIG_WAPI_SUPPORT */
default:
EncryptionHeadOverhead = 0;
}
if (EncryptionHeadOverhead > 0) {
_rtw_memset(&(pframe[*pLength]), 0, EncryptionHeadOverhead);
*pLength += EncryptionHeadOverhead;
/* SET_80211_HDR_WEP(pGTKRspPkt, 1); */ /* Suggested by CCW. */
/* GTK's privacy bit is done by FW */
/* SetPrivacy(fctrl); */
}
/* ------------------------------------------------------------------------- */
/* Frame Body. */
/* ------------------------------------------------------------------------- */
pGTKRspPkt = (u8 *)(pframe + *pLength);
/* LLC header */
_rtw_memcpy(pGTKRspPkt, LLCHeader, 8);
*pLength += 8;
/* GTK element */
pGTKRspPkt += 8;
/* GTK frame body after LLC, part 1 */
/* TKIP key_length = 32, AES key_length = 16 */
if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_)
GTKbody_a[8] = 0x20;
/* GTK frame body after LLC, part 1 */
_rtw_memcpy(pGTKRspPkt, GTKbody_a, 11);
*pLength += 11;
pGTKRspPkt += 11;
/* GTK frame body after LLC, part 2 */
_rtw_memset(&(pframe[*pLength]), 0, 88);
*pLength += 88;
pGTKRspPkt += 88;
if (psecuritypriv->dot118021XGrpPrivacy == _TKIP_)
*pLength += 8;
}
#endif /* CONFIG_GTK_OL */
#define PN_2_CCMPH(ch,key_id) ((ch) & 0x000000000000ffff) \
| (((ch) & 0x0000ffffffff0000) << 16) \
| (((key_id) << 30)) \
| BIT(29)
static void rtw_hal_construct_remote_control_info(_adapter *adapter,
u8 *pframe, u32 *pLength)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct sta_priv *pstapriv = &adapter->stapriv;
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
struct sta_info *psta;
struct stainfo_rxcache *prxcache;
u8 cur_dot11rxiv[8], id = 0, tid_id = 0, i = 0;
size_t sz = 0, total = 0;
u64 ccmp_hdr = 0, tmp_key = 0;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL) {
rtw_warn_on(1);
return;
}
prxcache = &psta->sta_recvpriv.rxcache;
sz = sizeof(cur_dot11rxiv);
/* 3 SEC IV * 1 page */
rtw_get_sec_iv(adapter, cur_dot11rxiv,
get_my_bssid(&pmlmeinfo->network));
_rtw_memcpy(pframe, cur_dot11rxiv, sz);
*pLength += sz;
pframe += sz;
_rtw_memset(&cur_dot11rxiv, 0, sz);
if (psecuritypriv->ndisauthtype == Ndis802_11AuthModeWPA2PSK) {
id = psecuritypriv->dot118021XGrpKeyid;
tid_id = prxcache->last_tid;
REMOTE_INFO_CTRL_SET_VALD_EN(cur_dot11rxiv, 0xdd);
REMOTE_INFO_CTRL_SET_PTK_EN(cur_dot11rxiv, 1);
REMOTE_INFO_CTRL_SET_GTK_EN(cur_dot11rxiv, 1);
REMOTE_INFO_CTRL_SET_GTK_IDX(cur_dot11rxiv, id);
_rtw_memcpy(pframe, cur_dot11rxiv, sz);
*pLength += sz;
pframe += sz;
_rtw_memcpy(pframe, prxcache->iv[tid_id], sz);
*pLength += sz;
pframe += sz;
total = sizeof(psecuritypriv->iv_seq);
total /= sizeof(psecuritypriv->iv_seq[0]);
for (i = 0 ; i < total ; i ++) {
ccmp_hdr =
le64_to_cpu(*(u64*)psecuritypriv->iv_seq[i]);
_rtw_memset(&cur_dot11rxiv, 0, sz);
if (ccmp_hdr != 0) {
tmp_key = i;
ccmp_hdr = PN_2_CCMPH(ccmp_hdr, tmp_key);
*(u64*)cur_dot11rxiv = cpu_to_le64(ccmp_hdr);
_rtw_memcpy(pframe, cur_dot11rxiv, sz);
}
*pLength += sz;
pframe += sz;
}
}
}
void rtw_hal_set_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
RSVDPAGE_LOC *rsvd_page_loc)
{
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct mlme_ext_priv *pmlmeext;
struct mlme_ext_info *pmlmeinfo;
u32 ARPLength = 0, GTKLength = 0, PNOLength = 0, ScanInfoLength = 0;
u32 SSIDLegnth = 0, ProbeReqLength = 0, ns_len = 0, rc_len = 0;
u8 CurtPktPageNum = 0;
#ifdef CONFIG_GTK_OL
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta;
struct security_priv *psecpriv = &adapter->securitypriv;
u8 kek[RTW_KEK_LEN];
u8 kck[RTW_KCK_LEN];
#endif /* CONFIG_GTK_OL */
#ifdef CONFIG_PNO_SUPPORT
int pno_index;
u8 ssid_num;
#endif /* CONFIG_PNO_SUPPORT */
pmlmeext = &adapter->mlmeextpriv;
pmlmeinfo = &pmlmeext->mlmext_info;
if (pwrctl->wowlan_pno_enable == _FALSE) {
/* ARP RSP * 1 page */
rsvd_page_loc->LocArpRsp = *page_num;
RTW_INFO("LocArpRsp: %d\n", rsvd_page_loc->LocArpRsp);
rtw_hal_construct_ARPRsp(adapter, &pframe[index],
&ARPLength, pmlmeinfo->ip_addr);
rtw_hal_fill_fake_txdesc(adapter,
&pframe[index - tx_desc],
ARPLength, _FALSE, _FALSE, _TRUE);
CurtPktPageNum = (u8)PageNum(tx_desc + ARPLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-ARPRsp", CurtPktPageNum, *page_num, 0);
#ifdef CONFIG_IPV6
/* 2 NS offload and NDP Info*/
if (pwrctl->wowlan_ns_offload_en == _TRUE) {
rsvd_page_loc->LocNbrAdv = *page_num;
RTW_INFO("LocNbrAdv: %d\n", rsvd_page_loc->LocNbrAdv);
rtw_hal_construct_na_message(adapter,
&pframe[index], &ns_len);
rtw_hal_fill_fake_txdesc(adapter,
&pframe[index - tx_desc],
ns_len, _FALSE,
_FALSE, _TRUE);
CurtPktPageNum = (u8)PageNum(tx_desc + ns_len,
page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-NbrAdv", CurtPktPageNum, *page_num, 0);
rsvd_page_loc->LocNDPInfo = *page_num;
RTW_INFO("LocNDPInfo: %d\n",
rsvd_page_loc->LocNDPInfo);
rtw_hal_construct_ndp_info(adapter,
&pframe[index - tx_desc],
&ns_len);
CurtPktPageNum =
(u8)PageNum(tx_desc + ns_len, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-NDPInfo", CurtPktPageNum, *page_num, 0);
}
#endif /*CONFIG_IPV6*/
/* 3 Remote Control Info. * 1 page */
rsvd_page_loc->LocRemoteCtrlInfo = *page_num;
RTW_INFO("LocRemoteCtrlInfo: %d\n", rsvd_page_loc->LocRemoteCtrlInfo);
rtw_hal_construct_remote_control_info(adapter,
&pframe[index - tx_desc],
&rc_len);
CurtPktPageNum = (u8)PageNum(rc_len, page_size);
*page_num += CurtPktPageNum;
*total_pkt_len = index + rc_len;
RSVD_PAGE_CFG("WOW-RCI", CurtPktPageNum, *page_num, *total_pkt_len);
#ifdef CONFIG_GTK_OL
index += (CurtPktPageNum * page_size);
/* if the ap staion info. exists, get the kek, kck from staion info. */
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL) {
_rtw_memset(kek, 0, RTW_KEK_LEN);
_rtw_memset(kck, 0, RTW_KCK_LEN);
RTW_INFO("%s, KEK, KCK download rsvd page all zero\n",
__func__);
} else {
_rtw_memcpy(kek, psta->kek, RTW_KEK_LEN);
_rtw_memcpy(kck, psta->kck, RTW_KCK_LEN);
}
/* 3 KEK, KCK */
rsvd_page_loc->LocGTKInfo = *page_num;
RTW_INFO("LocGTKInfo: %d\n", rsvd_page_loc->LocGTKInfo);
if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_8812(adapter)) {
struct security_priv *psecpriv = NULL;
psecpriv = &adapter->securitypriv;
_rtw_memcpy(pframe + index - tx_desc,
&psecpriv->dot11PrivacyAlgrthm, 1);
_rtw_memcpy(pframe + index - tx_desc + 1,
&psecpriv->dot118021XGrpPrivacy, 1);
_rtw_memcpy(pframe + index - tx_desc + 2,
kck, RTW_KCK_LEN);
_rtw_memcpy(pframe + index - tx_desc + 2 + RTW_KCK_LEN,
kek, RTW_KEK_LEN);
CurtPktPageNum = (u8)PageNum(tx_desc + 2 + RTW_KCK_LEN + RTW_KEK_LEN, page_size);
} else {
_rtw_memcpy(pframe + index - tx_desc, kck, RTW_KCK_LEN);
_rtw_memcpy(pframe + index - tx_desc + RTW_KCK_LEN,
kek, RTW_KEK_LEN);
GTKLength = tx_desc + RTW_KCK_LEN + RTW_KEK_LEN;
if (psta != NULL &&
psecuritypriv->dot118021XGrpPrivacy == _TKIP_) {
_rtw_memcpy(pframe + index - tx_desc + 56,
&psta->dot11tkiptxmickey, RTW_TKIP_MIC_LEN);
GTKLength += RTW_TKIP_MIC_LEN;
}
CurtPktPageNum = (u8)PageNum(GTKLength, page_size);
}
#if 0
{
int i;
printk("\ntoFW KCK: ");
for (i = 0; i < 16; i++)
printk(" %02x ", kck[i]);
printk("\ntoFW KEK: ");
for (i = 0; i < 16; i++)
printk(" %02x ", kek[i]);
printk("\n");
}
RTW_INFO("%s(): HW_VAR_SET_TX_CMD: KEK KCK %p %d\n",
__FUNCTION__, &pframe[index - tx_desc],
(tx_desc + RTW_KCK_LEN + RTW_KEK_LEN));
#endif
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-GTKInfo", CurtPktPageNum, *page_num, 0);
/* 3 GTK Response */
rsvd_page_loc->LocGTKRsp = *page_num;
RTW_INFO("LocGTKRsp: %d\n", rsvd_page_loc->LocGTKRsp);
rtw_hal_construct_GTKRsp(adapter, &pframe[index], >KLength);
rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
GTKLength, _FALSE, _FALSE, _TRUE);
#if 0
{
int gj;
printk("123GTK pkt=>\n");
for (gj = 0; gj < GTKLength + tx_desc; gj++) {
printk(" %02x ", pframe[index - tx_desc + gj]);
if ((gj + 1) % 16 == 0)
printk("\n");
}
printk(" <=end\n");
}
RTW_INFO("%s(): HW_VAR_SET_TX_CMD: GTK RSP %p %d\n",
__FUNCTION__, &pframe[index - tx_desc],
(tx_desc + GTKLength));
#endif
CurtPktPageNum = (u8)PageNum(tx_desc + GTKLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-GTKRsp", CurtPktPageNum, *page_num, 0);
/* below page is empty for GTK extension memory */
/* 3(11) GTK EXT MEM */
rsvd_page_loc->LocGTKEXTMEM = *page_num;
RTW_INFO("LocGTKEXTMEM: %d\n", rsvd_page_loc->LocGTKEXTMEM);
CurtPktPageNum = 2;
if (page_size >= 256)
CurtPktPageNum = 1;
*page_num += CurtPktPageNum;
/* extension memory for FW */
*total_pkt_len = index + (page_size * CurtPktPageNum);
RSVD_PAGE_CFG("WOW-GTKEXTMEM", CurtPktPageNum, *page_num, *total_pkt_len);
#endif /* CONFIG_GTK_OL */
index += (CurtPktPageNum * page_size);
/*Reserve 1 page for AOAC report*/
rsvd_page_loc->LocAOACReport = *page_num;
RTW_INFO("LocAOACReport: %d\n", rsvd_page_loc->LocAOACReport);
*page_num += 1;
*total_pkt_len = index + (page_size * 1);
RSVD_PAGE_CFG("WOW-AOAC", 1, *page_num, *total_pkt_len);
} else {
#ifdef CONFIG_PNO_SUPPORT
if (pwrctl->wowlan_in_resume == _FALSE &&
pwrctl->pno_inited == _TRUE) {
/* Broadcast Probe Request */
rsvd_page_loc->LocProbePacket = *page_num;
RTW_INFO("loc_probe_req: %d\n",
rsvd_page_loc->LocProbePacket);
rtw_hal_construct_ProbeReq(
adapter,
&pframe[index],
&ProbeReqLength,
NULL);
rtw_hal_fill_fake_txdesc(adapter,
&pframe[index - tx_desc],
ProbeReqLength, _FALSE, _FALSE, _FALSE);
CurtPktPageNum =
(u8)PageNum(tx_desc + ProbeReqLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-ProbeReq", CurtPktPageNum, *page_num, 0);
/* Hidden SSID Probe Request */
ssid_num = pwrctl->pnlo_info->hidden_ssid_num;
for (pno_index = 0 ; pno_index < ssid_num ; pno_index++) {
pwrctl->pnlo_info->loc_probe_req[pno_index] =
*page_num;
rtw_hal_construct_ProbeReq(
adapter,
&pframe[index],
&ProbeReqLength,
&pwrctl->pno_ssid_list->node[pno_index]);
rtw_hal_fill_fake_txdesc(adapter,
&pframe[index - tx_desc],
ProbeReqLength, _FALSE, _FALSE, _FALSE);
CurtPktPageNum =
(u8)PageNum(tx_desc + ProbeReqLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-ProbeReq", CurtPktPageNum, *page_num, 0);
}
/* PNO INFO Page */
rsvd_page_loc->LocPNOInfo = *page_num;
RTW_INFO("LocPNOInfo: %d\n", rsvd_page_loc->LocPNOInfo);
rtw_hal_construct_PNO_info(adapter,
&pframe[index - tx_desc],
&PNOLength);
CurtPktPageNum = (u8)PageNum(PNOLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-PNOInfo", CurtPktPageNum, *page_num, 0);
/* Scan Info Page */
rsvd_page_loc->LocScanInfo = *page_num;
RTW_INFO("LocScanInfo: %d\n", rsvd_page_loc->LocScanInfo);
rtw_hal_construct_scan_info(adapter,
&pframe[index - tx_desc],
&ScanInfoLength);
CurtPktPageNum = (u8)PageNum(ScanInfoLength, page_size);
*page_num += CurtPktPageNum;
*total_pkt_len = index + ScanInfoLength;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-ScanInfo", CurtPktPageNum, *page_num, *total_pkt_len);
}
#endif /* CONFIG_PNO_SUPPORT */
}
}
static void rtw_hal_gate_bb(_adapter *adapter, bool stop)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
u8 i = 0, val8 = 0, empty = _FAIL;
u16 val16 = 0;
if (stop) {
/* checking TX queue status */
for (i = 0 ; i < 5 ; i++) {
rtw_hal_get_hwreg(adapter, HW_VAR_CHK_MGQ_CPU_EMPTY, &empty);
if (empty) {
break;
} else {
RTW_WARN("%s: MGQ_CPU is busy(%d)!\n",
__func__, i);
rtw_mdelay_os(10);
}
}
if (val8 == 5)
RTW_ERR("%s: Polling MGQ_CPU empty fail!\n", __func__);
/* Pause TX*/
pwrpriv->wowlan_txpause_status = rtw_read8(adapter, REG_TXPAUSE);
rtw_write8(adapter, REG_TXPAUSE, 0xff);
val8 = rtw_read8(adapter, REG_SYS_FUNC_EN);
val8 &= ~BIT(0);
rtw_write8(adapter, REG_SYS_FUNC_EN, val8);
RTW_INFO("%s: BB gated: 0x%02x, store TXPAUSE: %02x\n",
__func__,
rtw_read8(adapter, REG_SYS_FUNC_EN),
pwrpriv->wowlan_txpause_status);
} else {
val8 = rtw_read8(adapter, REG_SYS_FUNC_EN);
val8 |= BIT(0);
rtw_write8(adapter, REG_SYS_FUNC_EN, val8);
RTW_INFO("%s: BB release: 0x%02x, recover TXPAUSE:%02x\n",
__func__, rtw_read8(adapter, REG_SYS_FUNC_EN),
pwrpriv->wowlan_txpause_status);
/* release TX*/
rtw_write8(adapter, REG_TXPAUSE, pwrpriv->wowlan_txpause_status);
}
}
static u8 rtw_hal_wow_pattern_generate(_adapter *adapter, u8 idx, struct rtl_wow_pattern *pwow_pattern)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
u8 *pattern;
u8 len = 0;
u8 *mask;
u8 mask_hw[MAX_WKFM_SIZE] = {0};
u8 content[MAX_WKFM_PATTERN_SIZE] = {0};
u8 broadcast_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 multicast_addr1[2] = {0x33, 0x33};
u8 multicast_addr2[3] = {0x01, 0x00, 0x5e};
u8 mask_len = 0;
u8 mac_addr[ETH_ALEN] = {0};
u16 count = 0;
int i, j;
if (pwrctl->wowlan_pattern_idx > MAX_WKFM_CAM_NUM) {
RTW_INFO("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
__func__, MAX_WKFM_CAM_NUM);
return _FAIL;
}
pattern = pwrctl->patterns[idx].content;
len = pwrctl->patterns[idx].len;
mask = pwrctl->patterns[idx].mask;
_rtw_memcpy(mac_addr, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memset(pwow_pattern, 0, sizeof(struct rtl_wow_pattern));
mask_len = DIV_ROUND_UP(len, 8);
/* 1. setup A1 table */
if (memcmp(pattern, broadcast_addr, ETH_ALEN) == 0)
pwow_pattern->type = PATTERN_BROADCAST;
else if (memcmp(pattern, multicast_addr1, 2) == 0)
pwow_pattern->type = PATTERN_MULTICAST;
else if (memcmp(pattern, multicast_addr2, 3) == 0)
pwow_pattern->type = PATTERN_MULTICAST;
else if (memcmp(pattern, mac_addr, ETH_ALEN) == 0)
pwow_pattern->type = PATTERN_UNICAST;
else
pwow_pattern->type = PATTERN_INVALID;
/* translate mask from os to mask for hw */
/******************************************************************************
* pattern from OS uses 'ethenet frame', like this:
| 6 | 6 | 2 | 20 | Variable | 4 |
|--------+--------+------+-----------+------------+-----|
| 802.3 Mac Header | IP Header | TCP Packet | FCS |
| DA | SA | Type |
* BUT, packet catched by our HW is in '802.11 frame', begin from LLC,
| 24 or 30 | 6 | 2 | 20 | Variable | 4 |
|-------------------+--------+------+-----------+------------+-----|
| 802.11 MAC Header | LLC | IP Header | TCP Packet | FCS |
| Others | Tpye |
* Therefore, we need translate mask_from_OS to mask_to_hw.
* We should left-shift mask by 6 bits, then set the new bit[0~5] = 0,
* because new mask[0~5] means 'SA', but our HW packet begins from LLC,
* bit[0~5] corresponds to first 6 Bytes in LLC, they just don't match.
******************************************************************************/
/* Shift 6 bits */
for (i = 0; i < mask_len - 1; i++) {
mask_hw[i] = mask[i] >> 6;
mask_hw[i] |= (mask[i + 1] & 0x3F) << 2;
}
mask_hw[i] = (mask[i] >> 6) & 0x3F;
/* Set bit 0-5 to zero */
mask_hw[0] &= 0xC0;
for (i = 0; i < (MAX_WKFM_SIZE / 4); i++) {
pwow_pattern->mask[i] = mask_hw[i * 4];
pwow_pattern->mask[i] |= (mask_hw[i * 4 + 1] << 8);
pwow_pattern->mask[i] |= (mask_hw[i * 4 + 2] << 16);
pwow_pattern->mask[i] |= (mask_hw[i * 4 + 3] << 24);
}
/* To get the wake up pattern from the mask.
* We do not count first 12 bits which means
* DA[6] and SA[6] in the pattern to match HW design. */
count = 0;
for (i = 12; i < len; i++) {
if ((mask[i / 8] >> (i % 8)) & 0x01) {
content[count] = pattern[i];
count++;
}
}
pwow_pattern->crc = rtw_calc_crc(content, count);
if (pwow_pattern->crc != 0) {
if (pwow_pattern->type == PATTERN_INVALID)
pwow_pattern->type = PATTERN_VALID;
}
return _SUCCESS;
}
#ifndef CONFIG_WOW_PATTERN_HW_CAM
static void rtw_hal_reset_mac_rx(_adapter *adapter)
{
u8 val8 = 0;
/* Set REG_CR bit1, bit3, bit7 to 0*/
val8 = rtw_read8(adapter, REG_CR);
val8 &= 0x75;
rtw_write8(adapter, REG_CR, val8);
val8 = rtw_read8(adapter, REG_CR);
/* Set REG_CR bit1, bit3, bit7 to 1*/
val8 |= 0x8a;
rtw_write8(adapter, REG_CR, val8);
RTW_INFO("0x%04x: %02x\n", REG_CR, rtw_read8(adapter, REG_CR));
}
static void rtw_hal_set_wow_rxff_boundary(_adapter *adapter, bool wow_mode)
{
u8 val8 = 0;
u16 rxff_bndy = 0;
u32 rx_dma_buff_sz = 0;
val8 = rtw_read8(adapter, REG_FIFOPAGE + 3);
if (val8 != 0)
RTW_INFO("%s:[%04x]some PKTs in TXPKTBUF\n",
__func__, (REG_FIFOPAGE + 3));
rtw_hal_reset_mac_rx(adapter);
if (wow_mode) {
rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
(u8 *)&rx_dma_buff_sz);
rxff_bndy = rx_dma_buff_sz - 1;
rtw_write16(adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
RTW_INFO("%s: wow mode, 0x%04x: 0x%04x\n", __func__,
REG_TRXFF_BNDY + 2,
rtw_read16(adapter, (REG_TRXFF_BNDY + 2)));
} else {
rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ,
(u8 *)&rx_dma_buff_sz);
rxff_bndy = rx_dma_buff_sz - 1;
rtw_write16(adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
RTW_INFO("%s: normal mode, 0x%04x: 0x%04x\n", __func__,
REG_TRXFF_BNDY + 2,
rtw_read16(adapter, (REG_TRXFF_BNDY + 2)));
}
}
bool rtw_read_from_frame_mask(_adapter *adapter, u8 idx)
{
u32 data_l = 0, data_h = 0, rx_dma_buff_sz = 0, page_sz = 0;
u16 offset, rx_buf_ptr = 0;
u16 cam_start_offset = 0;
u16 ctrl_l = 0, ctrl_h = 0;
u8 count = 0, tmp = 0;
int i = 0;
bool res = _TRUE;
if (idx > MAX_WKFM_CAM_NUM) {
RTW_INFO("[Error]: %s, pattern index is out of range\n",
__func__);
return _FALSE;
}
rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
(u8 *)&rx_dma_buff_sz);
if (rx_dma_buff_sz == 0) {
RTW_INFO("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
return _FALSE;
}
rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
if (page_sz == 0) {
RTW_INFO("[Error]: %s, page_sz is 0!!\n", __func__);
return _FALSE;
}
offset = (u16)PageNum(rx_dma_buff_sz, page_sz);
cam_start_offset = offset * page_sz;
ctrl_l = 0x0;
ctrl_h = 0x0;
/* Enable RX packet buffer access */
rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, RXPKT_BUF_SELECT);
/* Read the WKFM CAM */
for (i = 0; i < (WKFMCAM_ADDR_NUM / 2); i++) {
/*
* Set Rx packet buffer offset.
* RxBufer pointer increases 1, we can access 8 bytes in Rx packet buffer.
* CAM start offset (unit: 1 byte) = Index*WKFMCAM_SIZE
* RxBufer pointer addr = (CAM start offset + per entry offset of a WKFMCAM)/8
* * Index: The index of the wake up frame mask
* * WKFMCAM_SIZE: the total size of one WKFM CAM
* * per entry offset of a WKFM CAM: Addr i * 4 bytes
*/
rx_buf_ptr =
(cam_start_offset + idx * WKFMCAM_SIZE + i * 8) >> 3;
rtw_write16(adapter, REG_PKTBUF_DBG_CTRL, rx_buf_ptr);
rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
data_l = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_L);
data_h = rtw_read32(adapter, REG_PKTBUF_DBG_DATA_H);
RTW_INFO("[%d]: %08x %08x\n", i, data_h, data_l);
count = 0;
do {
tmp = rtw_read8(adapter, REG_RXPKTBUF_CTRL);
rtw_udelay_os(2);
count++;
} while (!tmp && count < 100);
if (count >= 100) {
RTW_INFO("%s count:%d\n", __func__, count);
res = _FALSE;
}
}
/* Disable RX packet buffer access */
rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL,
DISABLE_TRXPKT_BUF_ACCESS);
return res;
}
bool rtw_write_to_frame_mask(_adapter *adapter, u8 idx,
struct rtl_wow_pattern *context)
{
u32 data = 0, rx_dma_buff_sz = 0, page_sz = 0;
u16 offset, rx_buf_ptr = 0;
u16 cam_start_offset = 0;
u16 ctrl_l = 0, ctrl_h = 0;
u8 count = 0, tmp = 0;
int res = 0, i = 0;
if (idx > MAX_WKFM_CAM_NUM) {
RTW_INFO("[Error]: %s, pattern index is out of range\n",
__func__);
return _FALSE;
}
rtw_hal_get_def_var(adapter, HAL_DEF_RX_DMA_SZ_WOW,
(u8 *)&rx_dma_buff_sz);
if (rx_dma_buff_sz == 0) {
RTW_INFO("[Error]: %s, rx_dma_buff_sz is 0!!\n", __func__);
return _FALSE;
}
rtw_hal_get_def_var(adapter, HAL_DEF_RX_PAGE_SIZE, (u8 *)&page_sz);
if (page_sz == 0) {
RTW_INFO("[Error]: %s, page_sz is 0!!\n", __func__);
return _FALSE;
}
offset = (u16)PageNum(rx_dma_buff_sz, page_sz);
cam_start_offset = offset * page_sz;
if (IS_HARDWARE_TYPE_8188E(adapter)) {
ctrl_l = 0x0001;
ctrl_h = 0x0001;
} else {
ctrl_l = 0x0f01;
ctrl_h = 0xf001;
}
/* Enable RX packet buffer access */
rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL, RXPKT_BUF_SELECT);
/* Write the WKFM CAM */
for (i = 0; i < WKFMCAM_ADDR_NUM; i++) {
/*
* Set Rx packet buffer offset.
* RxBufer pointer increases 1, we can access 8 bytes in Rx packet buffer.
* CAM start offset (unit: 1 byte) = Index*WKFMCAM_SIZE
* RxBufer pointer addr = (CAM start offset + per entry offset of a WKFMCAM)/8
* * Index: The index of the wake up frame mask
* * WKFMCAM_SIZE: the total size of one WKFM CAM
* * per entry offset of a WKFM CAM: Addr i * 4 bytes
*/
rx_buf_ptr =
(cam_start_offset + idx * WKFMCAM_SIZE + i * 4) >> 3;
rtw_write16(adapter, REG_PKTBUF_DBG_CTRL, rx_buf_ptr);
if (i == 0) {
if (context->type == PATTERN_VALID)
data = BIT(31);
else if (context->type == PATTERN_BROADCAST)
data = BIT(31) | BIT(26);
else if (context->type == PATTERN_MULTICAST)
data = BIT(31) | BIT(25);
else if (context->type == PATTERN_UNICAST)
data = BIT(31) | BIT(24);
if (context->crc != 0)
data |= context->crc;
rtw_write32(adapter, REG_PKTBUF_DBG_DATA_L, data);
rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
} else if (i == 1) {
data = 0;
rtw_write32(adapter, REG_PKTBUF_DBG_DATA_H, data);
rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_h);
} else if (i == 2 || i == 4) {
data = context->mask[i - 2];
rtw_write32(adapter, REG_PKTBUF_DBG_DATA_L, data);
/* write to RX packet buffer*/
rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_l);
} else if (i == 3 || i == 5) {
data = context->mask[i - 2];
rtw_write32(adapter, REG_PKTBUF_DBG_DATA_H, data);
/* write to RX packet buffer*/
rtw_write16(adapter, REG_RXPKTBUF_CTRL, ctrl_h);
}
count = 0;
do {
tmp = rtw_read8(adapter, REG_RXPKTBUF_CTRL);
rtw_udelay_os(2);
count++;
} while (tmp && count < 100);
if (count >= 100)
res = _FALSE;
else
res = _TRUE;
}
/* Disable RX packet buffer access */
rtw_write8(adapter, REG_PKT_BUFF_ACCESS_CTRL,
DISABLE_TRXPKT_BUF_ACCESS);
return res;
}
void rtw_clean_pattern(_adapter *adapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct rtl_wow_pattern zero_pattern;
int i = 0;
_rtw_memset(&zero_pattern, 0, sizeof(struct rtl_wow_pattern));
zero_pattern.type = PATTERN_INVALID;
for (i = 0; i < MAX_WKFM_CAM_NUM; i++)
rtw_write_to_frame_mask(adapter, i, &zero_pattern);
rtw_write8(adapter, REG_WKFMCAM_NUM, 0);
}
#if 0
static int rtw_hal_set_pattern(_adapter *adapter, u8 *pattern,
u8 len, u8 *mask, u8 idx)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct mlme_ext_priv *pmlmeext = NULL;
struct mlme_ext_info *pmlmeinfo = NULL;
struct rtl_wow_pattern wow_pattern;
u8 mask_hw[MAX_WKFM_SIZE] = {0};
u8 content[MAX_WKFM_PATTERN_SIZE] = {0};
u8 broadcast_addr[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 multicast_addr1[2] = {0x33, 0x33};
u8 multicast_addr2[3] = {0x01, 0x00, 0x5e};
u8 res = _FALSE, index = 0, mask_len = 0;
u8 mac_addr[ETH_ALEN] = {0};
u16 count = 0;
int i, j;
if (pwrctl->wowlan_pattern_idx > MAX_WKFM_CAM_NUM) {
RTW_INFO("%s pattern_idx is more than MAX_FMC_NUM: %d\n",
__func__, MAX_WKFM_CAM_NUM);
return _FALSE;
}
pmlmeext = &adapter->mlmeextpriv;
pmlmeinfo = &pmlmeext->mlmext_info;
_rtw_memcpy(mac_addr, adapter_mac_addr(adapter), ETH_ALEN);
_rtw_memset(&wow_pattern, 0, sizeof(struct rtl_wow_pattern));
mask_len = DIV_ROUND_UP(len, 8);
/* 1. setup A1 table */
if (memcmp(pattern, broadcast_addr, ETH_ALEN) == 0)
wow_pattern.type = PATTERN_BROADCAST;
else if (memcmp(pattern, multicast_addr1, 2) == 0)
wow_pattern.type = PATTERN_MULTICAST;
else if (memcmp(pattern, multicast_addr2, 3) == 0)
wow_pattern.type = PATTERN_MULTICAST;
else if (memcmp(pattern, mac_addr, ETH_ALEN) == 0)
wow_pattern.type = PATTERN_UNICAST;
else
wow_pattern.type = PATTERN_INVALID;
/* translate mask from os to mask for hw */
/******************************************************************************
* pattern from OS uses 'ethenet frame', like this:
| 6 | 6 | 2 | 20 | Variable | 4 |
|--------+--------+------+-----------+------------+-----|
| 802.3 Mac Header | IP Header | TCP Packet | FCS |
| DA | SA | Type |
* BUT, packet catched by our HW is in '802.11 frame', begin from LLC,
| 24 or 30 | 6 | 2 | 20 | Variable | 4 |
|-------------------+--------+------+-----------+------------+-----|
| 802.11 MAC Header | LLC | IP Header | TCP Packet | FCS |
| Others | Tpye |
* Therefore, we need translate mask_from_OS to mask_to_hw.
* We should left-shift mask by 6 bits, then set the new bit[0~5] = 0,
* because new mask[0~5] means 'SA', but our HW packet begins from LLC,
* bit[0~5] corresponds to first 6 Bytes in LLC, they just don't match.
******************************************************************************/
/* Shift 6 bits */
for (i = 0; i < mask_len - 1; i++) {
mask_hw[i] = mask[i] >> 6;
mask_hw[i] |= (mask[i + 1] & 0x3F) << 2;
}
mask_hw[i] = (mask[i] >> 6) & 0x3F;
/* Set bit 0-5 to zero */
mask_hw[0] &= 0xC0;
for (i = 0; i < (MAX_WKFM_SIZE / 4); i++) {
wow_pattern.mask[i] = mask_hw[i * 4];
wow_pattern.mask[i] |= (mask_hw[i * 4 + 1] << 8);
wow_pattern.mask[i] |= (mask_hw[i * 4 + 2] << 16);
wow_pattern.mask[i] |= (mask_hw[i * 4 + 3] << 24);
}
/* To get the wake up pattern from the mask.
* We do not count first 12 bits which means
* DA[6] and SA[6] in the pattern to match HW design. */
count = 0;
for (i = 12; i < len; i++) {
if ((mask[i / 8] >> (i % 8)) & 0x01) {
content[count] = pattern[i];
count++;
}
}
wow_pattern.crc = rtw_calc_crc(content, count);
if (wow_pattern.crc != 0) {
if (wow_pattern.type == PATTERN_INVALID)
wow_pattern.type = PATTERN_VALID;
}
index = idx;
if (!pwrctl->bInSuspend)
index += 2;
/* write pattern */
res = rtw_write_to_frame_mask(adapter, index, &wow_pattern);
if (res == _FALSE)
RTW_INFO("%s: ERROR!! idx: %d write_to_frame_mask_cam fail\n",
__func__, idx);
return res;
}
#endif
void rtw_fill_pattern(_adapter *adapter)
{
int i = 0, total = 0, index;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct rtl_wow_pattern wow_pattern;
total = pwrpriv->wowlan_pattern_idx;
if (total > MAX_WKFM_CAM_NUM)
total = MAX_WKFM_CAM_NUM;
for (i = 0 ; i < total ; i++) {
if (_SUCCESS == rtw_hal_wow_pattern_generate(adapter, i, &wow_pattern)) {
index = i;
if (!pwrpriv->bInSuspend)
index += 2;
if (rtw_write_to_frame_mask(adapter, index, &wow_pattern) == _FALSE)
RTW_INFO("%s: ERROR!! idx: %d write_to_frame_mask_cam fail\n", __func__, i);
}
}
rtw_write8(adapter, REG_WKFMCAM_NUM, total);
}
#else /*CONFIG_WOW_PATTERN_HW_CAM*/
#define WOW_CAM_ACCESS_TIMEOUT_MS 200
#define WOW_VALID_BIT BIT31
#define WOW_BC_BIT BIT26
#define WOW_MC_BIT BIT25
#define WOW_UC_BIT BIT24
static u32 _rtw_wow_pattern_read_cam(_adapter *adapter, u8 addr)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
_mutex *mutex = &pwrpriv->wowlan_pattern_cam_mutex;
u32 rdata = 0;
u32 cnt = 0;
systime start = 0;
u8 timeout = 0;
u8 rst = _FALSE;
_enter_critical_mutex(mutex, NULL);
rtw_write32(adapter, REG_WKFMCAM_CMD, BIT_WKFCAM_POLLING_V1 | BIT_WKFCAM_ADDR_V2(addr));
start = rtw_get_current_time();
while (1) {
if (rtw_is_surprise_removed(adapter))
break;
cnt++;
if (0 == (rtw_read32(adapter, REG_WKFMCAM_CMD) & BIT_WKFCAM_POLLING_V1)) {
rst = _SUCCESS;
break;
}
if (rtw_get_passing_time_ms(start) > WOW_CAM_ACCESS_TIMEOUT_MS) {
timeout = 1;
break;
}
}
rdata = rtw_read32(adapter, REG_WKFMCAM_RWD);
_exit_critical_mutex(mutex, NULL);
/*RTW_INFO("%s ==> addr:0x%02x , rdata:0x%08x\n", __func__, addr, rdata);*/
if (timeout)
RTW_ERR(FUNC_ADPT_FMT" failed due to polling timeout\n", FUNC_ADPT_ARG(adapter));
return rdata;
}
void rtw_wow_pattern_read_cam_ent(_adapter *adapter, u8 id, struct rtl_wow_pattern *context)
{
int i;
u32 rdata;
_rtw_memset(context, 0, sizeof(struct rtl_wow_pattern));
for (i = 4; i >= 0; i--) {
rdata = _rtw_wow_pattern_read_cam(adapter, (id << 3) | i);
switch (i) {
case 4:
if (rdata & WOW_BC_BIT)
context->type = PATTERN_BROADCAST;
else if (rdata & WOW_MC_BIT)
context->type = PATTERN_MULTICAST;
else if (rdata & WOW_UC_BIT)
context->type = PATTERN_UNICAST;
else
context->type = PATTERN_INVALID;
context->crc = rdata & 0xFFFF;
break;
default:
_rtw_memcpy(&context->mask[i], (u8 *)(&rdata), 4);
break;
}
}
}
static void _rtw_wow_pattern_write_cam(_adapter *adapter, u8 addr, u32 wdata)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
_mutex *mutex = &pwrpriv->wowlan_pattern_cam_mutex;
u32 cnt = 0;
systime start = 0, end = 0;
u8 timeout = 0;
/*RTW_INFO("%s ==> addr:0x%02x , wdata:0x%08x\n", __func__, addr, wdata);*/
_enter_critical_mutex(mutex, NULL);
rtw_write32(adapter, REG_WKFMCAM_RWD, wdata);
rtw_write32(adapter, REG_WKFMCAM_CMD, BIT_WKFCAM_POLLING_V1 | BIT_WKFCAM_WE | BIT_WKFCAM_ADDR_V2(addr));
start = rtw_get_current_time();
while (1) {
if (rtw_is_surprise_removed(adapter))
break;
cnt++;
if (0 == (rtw_read32(adapter, REG_WKFMCAM_CMD) & BIT_WKFCAM_POLLING_V1))
break;
if (rtw_get_passing_time_ms(start) > WOW_CAM_ACCESS_TIMEOUT_MS) {
timeout = 1;
break;
}
}
end = rtw_get_current_time();
_exit_critical_mutex(mutex, NULL);
if (timeout) {
RTW_ERR(FUNC_ADPT_FMT" addr:0x%02x, wdata:0x%08x, to:%u, polling:%u, %d ms\n"
, FUNC_ADPT_ARG(adapter), addr, wdata, timeout, cnt, rtw_get_time_interval_ms(start, end));
}
}
void rtw_wow_pattern_write_cam_ent(_adapter *adapter, u8 id, struct rtl_wow_pattern *context)
{
int j;
u8 addr;
u32 wdata = 0;
for (j = 4; j >= 0; j--) {
switch (j) {
case 4:
wdata = context->crc;
if (PATTERN_BROADCAST == context->type)
wdata |= WOW_BC_BIT;
if (PATTERN_MULTICAST == context->type)
wdata |= WOW_MC_BIT;
if (PATTERN_UNICAST == context->type)
wdata |= WOW_UC_BIT;
if (PATTERN_INVALID != context->type)
wdata |= WOW_VALID_BIT;
break;
default:
wdata = context->mask[j];
break;
}
addr = (id << 3) + j;
_rtw_wow_pattern_write_cam(adapter, addr, wdata);
}
}
static u8 _rtw_wow_pattern_clean_cam(_adapter *adapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
_mutex *mutex = &pwrpriv->wowlan_pattern_cam_mutex;
u32 cnt = 0;
systime start = 0;
u8 timeout = 0;
u8 rst = _FAIL;
_enter_critical_mutex(mutex, NULL);
rtw_write32(adapter, REG_WKFMCAM_CMD, BIT_WKFCAM_POLLING_V1 | BIT_WKFCAM_CLR_V1);
start = rtw_get_current_time();
while (1) {
if (rtw_is_surprise_removed(adapter))
break;
cnt++;
if (0 == (rtw_read32(adapter, REG_WKFMCAM_CMD) & BIT_WKFCAM_POLLING_V1)) {
rst = _SUCCESS;
break;
}
if (rtw_get_passing_time_ms(start) > WOW_CAM_ACCESS_TIMEOUT_MS) {
timeout = 1;
break;
}
}
_exit_critical_mutex(mutex, NULL);
if (timeout)
RTW_ERR(FUNC_ADPT_FMT" falied ,polling timeout\n", FUNC_ADPT_ARG(adapter));
return rst;
}
void rtw_clean_pattern(_adapter *adapter)
{
if (_FAIL == _rtw_wow_pattern_clean_cam(adapter))
RTW_ERR("rtw_clean_pattern failed\n");
}
void rtw_dump_wow_pattern(void *sel, struct rtl_wow_pattern *pwow_pattern, u8 idx)
{
int j;
RTW_PRINT_SEL(sel, "=======WOW CAM-ID[%d]=======\n", idx);
RTW_PRINT_SEL(sel, "[WOW CAM] type:%d\n", pwow_pattern->type);
RTW_PRINT_SEL(sel, "[WOW CAM] crc:0x%04x\n", pwow_pattern->crc);
for (j = 0; j < 4; j++)
RTW_PRINT_SEL(sel, "[WOW CAM] Mask:0x%08x\n", pwow_pattern->mask[j]);
}
void rtw_fill_pattern(_adapter *adapter)
{
int i = 0, total = 0;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct rtl_wow_pattern wow_pattern;
total = pwrpriv->wowlan_pattern_idx;
if (total > MAX_WKFM_CAM_NUM)
total = MAX_WKFM_CAM_NUM;
for (i = 0 ; i < total ; i++) {
if (_SUCCESS == rtw_hal_wow_pattern_generate(adapter, i, &wow_pattern)) {
rtw_dump_wow_pattern(RTW_DBGDUMP, &wow_pattern, i);
rtw_wow_pattern_write_cam_ent(adapter, i, &wow_pattern);
}
}
}
#endif
void rtw_wow_pattern_cam_dump(_adapter *adapter)
{
#ifndef CONFIG_WOW_PATTERN_HW_CAM
int i;
for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++) {
RTW_INFO("=======[%d]=======\n", i);
rtw_read_from_frame_mask(adapter, i);
}
#else
struct rtl_wow_pattern context;
int i;
for (i = 0 ; i < MAX_WKFM_CAM_NUM; i++) {
rtw_wow_pattern_read_cam_ent(adapter, i, &context);
rtw_dump_wow_pattern(RTW_DBGDUMP, &context, i);
}
#endif
}
static void rtw_hal_dl_pattern(_adapter *adapter, u8 mode)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
switch (mode) {
case 0:
rtw_clean_pattern(adapter);
RTW_INFO("%s: total patterns: %d\n", __func__, pwrpriv->wowlan_pattern_idx);
break;
case 1:
rtw_set_default_pattern(adapter);
rtw_fill_pattern(adapter);
RTW_INFO("%s: pattern total: %d downloaded\n", __func__, pwrpriv->wowlan_pattern_idx);
break;
case 2:
rtw_clean_pattern(adapter);
rtw_wow_pattern_sw_reset(adapter);
RTW_INFO("%s: clean patterns\n", __func__);
break;
default:
RTW_INFO("%s: unknown mode\n", __func__);
break;
}
}
static void rtw_hal_wow_enable(_adapter *adapter)
{
struct registry_priv *registry_par = &adapter->registrypriv;
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct hal_ops *pHalFunc = &adapter->hal_func;
struct sta_info *psta = NULL;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
int res;
u16 media_status_rpt;
u8 no_wake = 0;
#ifdef CONFIG_LPS_PG
u8 lps_pg_hdl_id = 0;
#endif
if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF &&
!check_fwstate(pmlmepriv, _FW_LINKED))
no_wake = 1;
RTW_PRINT(FUNC_ADPT_FMT " WOWLAN_ENABLE\n", FUNC_ADPT_ARG(adapter));
rtw_hal_gate_bb(adapter, _TRUE);
#ifdef CONFIG_GTK_OL
if (psecuritypriv->binstallKCK_KEK == _TRUE)
rtw_hal_fw_sync_cam_id(adapter);
#endif
if (IS_HARDWARE_TYPE_8723B(adapter))
rtw_hal_backup_rate(adapter);
rtw_hal_fw_dl(adapter, _TRUE);
if(no_wake)
media_status_rpt = RT_MEDIA_DISCONNECT;
else
media_status_rpt = RT_MEDIA_CONNECT;
rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
(u8 *)&media_status_rpt);
/* RX DMA stop */
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(adapter))
rtw_hal_disable_tx_report(adapter);
#endif
res = rtw_hal_pause_rx_dma(adapter);
if (res == _FAIL)
RTW_PRINT("[WARNING] pause RX DMA fail\n");
#ifndef CONFIG_WOW_PATTERN_HW_CAM
/* Reconfig RX_FF Boundary */
rtw_hal_set_wow_rxff_boundary(adapter, _TRUE);
#endif
/* redownload wow pattern */
if(!no_wake)
rtw_hal_dl_pattern(adapter, 1);
if (!pwrctl->wowlan_pno_enable) {
psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
if (psta != NULL) {
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
adapter_to_dvobj(adapter)->dft.port_id = 0xFF;
adapter_to_dvobj(adapter)->dft.mac_id = 0xFF;
rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
#endif
if(!no_wake)
rtw_sta_media_status_rpt(adapter, psta, 1);
}
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
/* Enable CPWM2 only. */
res = rtw_hal_enable_cpwm2(adapter);
if (res == _FAIL)
RTW_PRINT("[WARNING] enable cpwm2 fail\n");
#endif
#ifdef CONFIG_GPIO_WAKEUP
rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _TRUE);
#endif
/* Set WOWLAN H2C command. */
RTW_PRINT("Set WOWLan cmd\n");
rtw_hal_set_fw_wow_related_cmd(adapter, 1);
res = rtw_hal_check_wow_ctrl(adapter, _TRUE);
if (res == _FALSE)
RTW_INFO("[Error]%s: set wowlan CMD fail!!\n", __func__);
pwrctl->wowlan_wake_reason =
rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
RTW_PRINT("wowlan_wake_reason: 0x%02x\n",
pwrctl->wowlan_wake_reason);
#ifdef CONFIG_GTK_OL_DBG
dump_sec_cam(RTW_DBGDUMP, adapter);
dump_sec_cam_cache(RTW_DBGDUMP, adapter);
#endif
#ifdef CONFIG_LPS_PG
if (pwrctl->lps_level == LPS_PG) {
lps_pg_hdl_id = LPS_PG_INFO_CFG;
rtw_hal_set_hwreg(adapter, HW_VAR_LPS_PG_HANDLE, (u8 *)(&lps_pg_hdl_id));
}
#endif
#ifdef CONFIG_USB_HCI
/* free adapter's resource */
rtw_mi_intf_stop(adapter);
#endif
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
/* Invoid SE0 reset signal during suspending*/
rtw_write8(adapter, REG_RSV_CTRL, 0x20);
if (IS_8188F(pHalData->version_id) == FALSE
&& IS_8188GTV(pHalData->version_id) == FALSE)
rtw_write8(adapter, REG_RSV_CTRL, 0x60);
#endif
rtw_hal_gate_bb(adapter, _FALSE);
}
#define DBG_WAKEUP_REASON
#ifdef DBG_WAKEUP_REASON
void _dbg_wake_up_reason_string(_adapter *adapter, const char *srt_res)
{
RTW_INFO(ADPT_FMT "- wake up reason - %s\n", ADPT_ARG(adapter), srt_res);
}
void _dbg_rtw_wake_up_reason(_adapter *adapter, u8 reason)
{
if (RX_PAIRWISEKEY == reason)
_dbg_wake_up_reason_string(adapter, "Rx pairwise key");
else if (RX_GTK == reason)
_dbg_wake_up_reason_string(adapter, "Rx GTK");
else if (RX_FOURWAY_HANDSHAKE == reason)
_dbg_wake_up_reason_string(adapter, "Rx four way handshake");
else if (RX_DISASSOC == reason)
_dbg_wake_up_reason_string(adapter, "Rx disassoc");
else if (RX_DEAUTH == reason)
_dbg_wake_up_reason_string(adapter, "Rx deauth");
else if (RX_ARP_REQUEST == reason)
_dbg_wake_up_reason_string(adapter, "Rx ARP request");
else if (FW_DECISION_DISCONNECT == reason)
_dbg_wake_up_reason_string(adapter, "FW detect disconnect");
else if (RX_MAGIC_PKT == reason)
_dbg_wake_up_reason_string(adapter, "Rx magic packet");
else if (RX_UNICAST_PKT == reason)
_dbg_wake_up_reason_string(adapter, "Rx unicast packet");
else if (RX_PATTERN_PKT == reason)
_dbg_wake_up_reason_string(adapter, "Rx pattern packet");
else if (RTD3_SSID_MATCH == reason)
_dbg_wake_up_reason_string(adapter, "RTD3 SSID match");
else if (RX_REALWOW_V2_WAKEUP_PKT == reason)
_dbg_wake_up_reason_string(adapter, "Rx real WOW V2 wakeup packet");
else if (RX_REALWOW_V2_ACK_LOST == reason)
_dbg_wake_up_reason_string(adapter, "Rx real WOW V2 ack lost");
else if (ENABLE_FAIL_DMA_IDLE == reason)
_dbg_wake_up_reason_string(adapter, "enable fail DMA idle");
else if (ENABLE_FAIL_DMA_PAUSE == reason)
_dbg_wake_up_reason_string(adapter, "enable fail DMA pause");
else if (AP_OFFLOAD_WAKEUP == reason)
_dbg_wake_up_reason_string(adapter, "AP offload wakeup");
else if (CLK_32K_UNLOCK == reason)
_dbg_wake_up_reason_string(adapter, "clk 32k unlock");
else if (RTIME_FAIL_DMA_IDLE == reason)
_dbg_wake_up_reason_string(adapter, "RTIME fail DMA idle");
else if (CLK_32K_LOCK == reason)
_dbg_wake_up_reason_string(adapter, "clk 32k lock");
else
_dbg_wake_up_reason_string(adapter, "unknown reasoen");
}
#endif
static void rtw_hal_wow_disable(_adapter *adapter)
{
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct security_priv *psecuritypriv = &adapter->securitypriv;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct hal_ops *pHalFunc = &adapter->hal_func;
struct sta_info *psta = NULL;
struct registry_priv *registry_par = &adapter->registrypriv;
int res;
u16 media_status_rpt;
u8 val8;
RTW_PRINT("%s, WOWLAN_DISABLE\n", __func__);
if(registry_par->suspend_type == FW_IPS_DISABLE_BBRF && !check_fwstate(pmlmepriv, _FW_LINKED)) {
RTW_INFO("FW_IPS_DISABLE_BBRF resume\n");
return;
}
if (!pwrctl->wowlan_pno_enable) {
psta = rtw_get_stainfo(&adapter->stapriv, get_bssid(pmlmepriv));
if (psta != NULL)
rtw_sta_media_status_rpt(adapter, psta, 0);
else
RTW_INFO("%s: psta is null\n", __func__);
}
if (0) {
RTW_INFO("0x630:0x%02x\n", rtw_read8(adapter, 0x630));
RTW_INFO("0x631:0x%02x\n", rtw_read8(adapter, 0x631));
RTW_INFO("0x634:0x%02x\n", rtw_read8(adapter, 0x634));
RTW_INFO("0x1c7:0x%02x\n", rtw_read8(adapter, 0x1c7));
}
pwrctl->wowlan_wake_reason = rtw_read8(adapter, REG_WOWLAN_WAKE_REASON);
RTW_PRINT("wakeup_reason: 0x%02x\n",
pwrctl->wowlan_wake_reason);
#ifdef DBG_WAKEUP_REASON
_dbg_rtw_wake_up_reason(adapter, pwrctl->wowlan_wake_reason);
#endif
rtw_hal_set_fw_wow_related_cmd(adapter, 0);
res = rtw_hal_check_wow_ctrl(adapter, _FALSE);
if (res == _FALSE) {
RTW_INFO("[Error]%s: disable WOW cmd fail\n!!", __func__);
rtw_hal_force_enable_rxdma(adapter);
}
rtw_hal_gate_bb(adapter, _TRUE);
res = rtw_hal_pause_rx_dma(adapter);
if (res == _FAIL)
RTW_PRINT("[WARNING] pause RX DMA fail\n");
/* clean HW pattern match */
rtw_hal_dl_pattern(adapter, 0);
#ifndef CONFIG_WOW_PATTERN_HW_CAM
/* config RXFF boundary to original */
rtw_hal_set_wow_rxff_boundary(adapter, _FALSE);
#endif
rtw_hal_release_rx_dma(adapter);
#if defined(CONFIG_RTL8188E)
if (IS_HARDWARE_TYPE_8188E(adapter))
rtw_hal_enable_tx_report(adapter);
#endif
if ((pwrctl->wowlan_wake_reason != RX_DISASSOC) &&
(pwrctl->wowlan_wake_reason != RX_DEAUTH) &&
(pwrctl->wowlan_wake_reason != FW_DECISION_DISCONNECT)) {
rtw_hal_get_aoac_rpt(adapter);
rtw_hal_update_sw_security_info(adapter);
}
rtw_hal_fw_dl(adapter, _FALSE);
#ifdef CONFIG_GPIO_WAKEUP
#ifdef CONFIG_RTW_ONE_PIN_GPIO
rtw_hal_set_input_gpio(adapter, WAKEUP_GPIO_IDX);
#else
#ifdef CONFIG_WAKEUP_GPIO_INPUT_MODE
if (pwrctl->is_high_active == 0)
rtw_hal_set_input_gpio(adapter, WAKEUP_GPIO_IDX);
else
rtw_hal_set_output_gpio(adapter, WAKEUP_GPIO_IDX, 0);
#else
val8 = (pwrctl->is_high_active == 0) ? 1 : 0;
RTW_PRINT("Set Wake GPIO to default(%d).\n", val8);
rtw_hal_set_output_gpio(adapter, WAKEUP_GPIO_IDX, val8);
rtw_hal_switch_gpio_wl_ctrl(adapter, WAKEUP_GPIO_IDX, _FALSE);
#endif
#endif /* CONFIG_RTW_ONE_PIN_GPIO */
#endif
if ((pwrctl->wowlan_wake_reason != FW_DECISION_DISCONNECT) &&
(pwrctl->wowlan_wake_reason != RX_PAIRWISEKEY) &&
(pwrctl->wowlan_wake_reason != RX_DISASSOC) &&
(pwrctl->wowlan_wake_reason != RX_DEAUTH)) {
media_status_rpt = RT_MEDIA_CONNECT;
rtw_hal_set_hwreg(adapter, HW_VAR_H2C_FW_JOINBSSRPT,
(u8 *)&media_status_rpt);
if (psta != NULL) {
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
adapter_to_dvobj(adapter)->dft.port_id = 0xFF;
adapter_to_dvobj(adapter)->dft.mac_id = 0xFF;
rtw_hal_set_default_port_id_cmd(adapter, psta->cmn.mac_id);
#endif
rtw_sta_media_status_rpt(adapter, psta, 1);
}
}
rtw_hal_gate_bb(adapter, _FALSE);
}
#endif /*CONFIG_WOWLAN*/
#ifdef CONFIG_P2P_WOWLAN
void rtw_hal_set_p2p_wow_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 index,
u8 tx_desc, u32 page_size, u8 *page_num, u32 *total_pkt_len,
RSVDPAGE_LOC *rsvd_page_loc)
{
u32 P2PNegoRspLength = 0, P2PInviteRspLength = 0;
u32 P2PPDRspLength = 0, P2PProbeRspLength = 0, P2PBCNLength = 0;
u8 CurtPktPageNum = 0;
/* P2P Beacon */
rsvd_page_loc->LocP2PBeacon = *page_num;
rtw_hal_construct_P2PBeacon(adapter, &pframe[index], &P2PBCNLength);
rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
P2PBCNLength, _FALSE, _FALSE, _FALSE);
#if 0
RTW_INFO("%s(): HW_VAR_SET_TX_CMD: PROBE RSP %p %d\n",
__FUNCTION__, &pframe[index - tx_desc], (P2PBCNLength + tx_desc));
#endif
CurtPktPageNum = (u8)PageNum(tx_desc + P2PBCNLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-P2P-Beacon", CurtPktPageNum, *page_num, 0);
/* P2P Probe rsp */
rsvd_page_loc->LocP2PProbeRsp = *page_num;
rtw_hal_construct_P2PProbeRsp(adapter, &pframe[index],
&P2PProbeRspLength);
rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
P2PProbeRspLength, _FALSE, _FALSE, _FALSE);
/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: PROBE RSP %p %d\n", */
/* __FUNCTION__, &pframe[index-tx_desc], (P2PProbeRspLength+tx_desc)); */
CurtPktPageNum = (u8)PageNum(tx_desc + P2PProbeRspLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-P2P-ProbeRsp", CurtPktPageNum, *page_num, 0);
/* P2P nego rsp */
rsvd_page_loc->LocNegoRsp = *page_num;
rtw_hal_construct_P2PNegoRsp(adapter, &pframe[index],
&P2PNegoRspLength);
rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
P2PNegoRspLength, _FALSE, _FALSE, _FALSE);
/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n", */
/* __FUNCTION__, &pframe[index-tx_desc], (NegoRspLength+tx_desc)); */
CurtPktPageNum = (u8)PageNum(tx_desc + P2PNegoRspLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-P2P-NegoRsp", CurtPktPageNum, *page_num, 0);
/* P2P invite rsp */
rsvd_page_loc->LocInviteRsp = *page_num;
rtw_hal_construct_P2PInviteRsp(adapter, &pframe[index],
&P2PInviteRspLength);
rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
P2PInviteRspLength, _FALSE, _FALSE, _FALSE);
/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n", */
/* __FUNCTION__, &pframe[index-tx_desc], (InviteRspLength+tx_desc)); */
CurtPktPageNum = (u8)PageNum(tx_desc + P2PInviteRspLength, page_size);
*page_num += CurtPktPageNum;
index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("WOW-P2P-InviteRsp", CurtPktPageNum, *page_num, 0);
/* P2P provision discovery rsp */
rsvd_page_loc->LocPDRsp = *page_num;
rtw_hal_construct_P2PProvisionDisRsp(adapter,
&pframe[index], &P2PPDRspLength);
rtw_hal_fill_fake_txdesc(adapter, &pframe[index - tx_desc],
P2PPDRspLength, _FALSE, _FALSE, _FALSE);
/* RTW_INFO("%s(): HW_VAR_SET_TX_CMD: QOS NULL DATA %p %d\n", */
/* __FUNCTION__, &pframe[index-tx_desc], (PDRspLength+tx_desc)); */
CurtPktPageNum = (u8)PageNum(tx_desc + P2PPDRspLength, page_size);
*page_num += CurtPktPageNum;
*total_pkt_len = index + P2PPDRspLength;
RSVD_PAGE_CFG("WOW-P2P-PDR", CurtPktPageNum, *page_num, *total_pkt_len);
index += (CurtPktPageNum * page_size);
}
#endif /* CONFIG_P2P_WOWLAN */
#ifdef CONFIG_LPS_PG
#ifndef DBG_LPSPG_INFO_DUMP
#define DBG_LPSPG_INFO_DUMP 1
#endif
#include "hal_halmac.h"
#ifdef CONFIG_RTL8822C
static int rtw_lps_pg_set_dpk_info_rsvd_page(_adapter *adapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct dm_struct *dm = adapter_to_phydm(adapter);
struct rsvd_page_cache_t *cache = &pwrpriv->lpspg_dpk_info;
u8 *info = NULL;
u32 info_len;
int ret = _FAIL;
/* get length */
halrf_dpk_info_rsvd_page(dm, NULL, &info_len);
if (!info_len) {
RTW_ERR("get %s length fail\n", cache->name);
goto exit;
}
/* allocate buf */
info = rtw_zmalloc(info_len);
if (!info) {
RTW_ERR("alloc %s buffer fail(len=%d)\n", cache->name, info_len);
goto exit;
}
/* get content */
halrf_dpk_info_rsvd_page(dm, info, NULL);
if (rsvd_page_cache_update_data(cache, info, info_len)) {
#if (DBG_LPSPG_INFO_DUMP >= 1)
RTW_INFO_DUMP(cache->name, info, info_len);
#endif
ret = rtw_halmac_download_rsvd_page(dvobj, cache->loc, info, info_len);
ret = !ret ? _SUCCESS : _FAIL;
if (ret != _SUCCESS) {
RTW_ERR("download %s rsvd page to offset:%u fail\n", cache->name, cache->loc);
goto free_mem;
}
#if (DBG_LPSPG_INFO_DUMP >= 2)
RTW_INFO("get %s from rsvd page offset:%d\n", cache->name, cache->loc);
rtw_dump_rsvd_page(RTW_DBGDUMP, adapter, cache->loc, cache->page_num);
#endif
}
free_mem:
rtw_mfree(info, info_len);
exit:
return ret;
}
static int rtw_lps_pg_set_iqk_info_rsvd_page(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct dm_struct *dm = adapter_to_phydm(adapter);
struct rsvd_page_cache_t *cache = &pwrpriv->lpspg_iqk_info;
u8 *info = NULL;
u32 info_len = 0;
int ret = _FAIL;
if (hal_data->RegIQKFWOffload) {
rsvd_page_cache_free_data(cache);
ret = _SUCCESS;
goto exit;
}
/* get length */
halrf_iqk_info_rsvd_page(dm, NULL, &info_len);
if (!info_len) {
RTW_ERR("get %s length fail\n", cache->name);
goto exit;
}
/* allocate buf */
info = rtw_zmalloc(info_len);
if (!info) {
RTW_ERR("alloc %s buffer fail(len=%d)\n", cache->name, info_len);
goto exit;
}
/* get content */
halrf_iqk_info_rsvd_page(dm, info, NULL);
if (rsvd_page_cache_update_data(cache, info, info_len)) {
#if (DBG_LPSPG_INFO_DUMP >= 1)
RTW_INFO_DUMP(cache->name, info, info_len);
#endif
ret = rtw_halmac_download_rsvd_page(dvobj, cache->loc, info, info_len);
ret = !ret ? _SUCCESS : _FAIL;
if (ret != _SUCCESS) {
RTW_ERR("download %s rsvd page to offset:%u fail\n", cache->name, cache->loc);
goto free_mem;
}
#if (DBG_LPSPG_INFO_DUMP >= 2)
RTW_INFO("get %s from rsvd page offset:%d\n", cache->name, cache->loc);
rtw_dump_rsvd_page(RTW_DBGDUMP, adapter, cache->loc, cache->page_num);
#endif
}
free_mem:
rtw_mfree(info, info_len);
exit:
return ret;
}
#endif /* CONFIG_RTL8822C */
static void rtw_hal_build_lps_pg_info_rsvd_page(struct dvobj_priv *dvobj, _adapter *ld_sta_iface, u8 *buf, u32 *buf_size)
{
#define LPS_PG_INFO_RSVD_LEN 16
if (buf) {
_adapter *adapter = dvobj_get_primary_adapter(dvobj);
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct sta_info *psta;
#ifdef CONFIG_MBSSID_CAM
u8 cam_id = INVALID_CAM_ID;
#endif
u8 *psec_cam_id = buf + 8;
u8 sec_cam_num = 0;
u8 drv_rsvdpage_num = 0;
if (ld_sta_iface) {
psta = rtw_get_stainfo(&ld_sta_iface->stapriv, get_bssid(&ld_sta_iface->mlmepriv));
if (!psta) {
RTW_ERR("%s [ERROR] sta is NULL\n", __func__);
rtw_warn_on(1);
goto size_chk;
}
/*Byte 0 - used macid*/
LPSPG_RSVD_PAGE_SET_MACID(buf, psta->cmn.mac_id);
RTW_INFO("[LPSPG-INFO] mac_id:%d\n", psta->cmn.mac_id);
}
#ifdef CONFIG_MBSSID_CAM
/*Byte 1 - used BSSID CAM entry*/
cam_id = rtw_mbid_cam_search_by_ifaceid(adapter, adapter->iface_id);
if (cam_id != INVALID_CAM_ID)
LPSPG_RSVD_PAGE_SET_MBSSCAMID(buf, cam_id);
RTW_INFO("[LPSPG-INFO] mbss_cam_id:%d\n", cam_id);
#endif
#ifdef CONFIG_WOWLAN /*&& pattern match cam used*/
/*Btye 2 - Max used Pattern Match CAM entry*/
if (pwrpriv->wowlan_mode == _TRUE
&& ld_sta_iface && check_fwstate(&ld_sta_iface->mlmepriv, _FW_LINKED) == _TRUE) {
LPSPG_RSVD_PAGE_SET_PMC_NUM(buf, pwrpriv->wowlan_pattern_idx);
RTW_INFO("[LPSPG-INFO] Max Pattern Match CAM entry :%d\n", pwrpriv->wowlan_pattern_idx);
}
#endif
#ifdef CONFIG_BEAMFORMING /*&& MU BF*/
/*Btye 3 - Max MU rate table Group ID*/
LPSPG_RSVD_PAGE_SET_MU_RAID_GID(buf, 0);
RTW_INFO("[LPSPG-INFO] Max MU rate table Group ID :%d\n", 0);
#endif
/*Btye 8 ~15 - used Security CAM entry */
sec_cam_num = rtw_get_sec_camid(adapter, 8, psec_cam_id);
/*Btye 4 - used Security CAM entry number*/
if (sec_cam_num < 8)
LPSPG_RSVD_PAGE_SET_SEC_CAM_NUM(buf, sec_cam_num);
RTW_INFO("[LPSPG-INFO] Security CAM entry number :%d\n", sec_cam_num);
/*Btye 5 - Txbuf used page number for fw offload*/
if (pwrpriv->wowlan_mode == _TRUE || pwrpriv->wowlan_ap_mode == _TRUE)
drv_rsvdpage_num = rtw_hal_get_txbuff_rsvd_page_num(adapter, _TRUE);
else
drv_rsvdpage_num = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
LPSPG_RSVD_PAGE_SET_DRV_RSVDPAGE_NUM(buf, drv_rsvdpage_num);
RTW_INFO("[LPSPG-INFO] DRV's rsvd page numbers :%d\n", drv_rsvdpage_num);
}
size_chk:
if (buf_size)
*buf_size = LPS_PG_INFO_RSVD_LEN;
}
static int rtw_hal_set_lps_pg_info_rsvd_page(_adapter *adapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rsvd_page_cache_t *cache = &pwrpriv->lpspg_info;
u8 *info = NULL;
u32 info_len = 0;
int ret = _FAIL;
/* get length */
rtw_hal_build_lps_pg_info_rsvd_page(dvobj, adapter, NULL, &info_len);
if (!info_len) {
RTW_ERR("get %s length fail\n", cache->name);
goto exit;
}
/* allocate buf */
info = rtw_zmalloc(info_len);
if (!info) {
RTW_ERR("alloc %s buffer fail(len=%d)\n", cache->name, info_len);
goto exit;
}
/* get content */
rtw_hal_build_lps_pg_info_rsvd_page(dvobj, adapter, info, NULL);
if (rsvd_page_cache_update_data(cache, info, info_len)) {
#if (DBG_LPSPG_INFO_DUMP >= 1)
RTW_INFO_DUMP(cache->name, info, info_len);
#endif
ret = rtw_halmac_download_rsvd_page(dvobj, cache->loc, info, info_len);
ret = !ret ? _SUCCESS : _FAIL;
if (ret != _SUCCESS) {
RTW_ERR("download %s rsvd page to offset:%u fail\n", cache->name, cache->loc);
goto free_mem;
}
#if (DBG_LPSPG_INFO_DUMP >= 2)
RTW_INFO("get %s from rsvd page offset:%d\n", cache->name, cache->loc);
rtw_dump_rsvd_page(RTW_DBGDUMP, adapter, cache->loc, cache->page_num);
#endif
}
free_mem:
rtw_mfree(info, info_len);
exit:
return ret;
}
static void rtw_lps_pg_set_rsvd_page(_adapter *adapter, u8 *frame, u16 *index
, u8 txdesc_size, u32 page_size, u8 *total_page_num
, bool is_wow_mode, _adapter *ld_sta_iface, bool only_get_page_num)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
struct rsvd_page_cache_t *cache;
bool rsvd = 1;
u8 *pos;
u32 len;
if (is_wow_mode) {
/* lps_level will not change when enter wow_mode */
if (pwrctl->lps_level != LPS_PG)
rsvd = 0;
} else {
if (!only_get_page_num && !ld_sta_iface)
rsvd = 0;
}
pos = only_get_page_num ? NULL : frame + *index;
#ifdef CONFIG_RTL8822C
if (IS_8822C_SERIES(hal_data->version_id)) {
/* LPSPG_DPK_INFO */
cache = &pwrctl->lpspg_dpk_info;
if (rsvd) {
if (pwrctl->lps_level != LPS_PG)
pos = NULL;
len = 0;
halrf_dpk_info_rsvd_page(adapter_to_phydm(adapter), pos, &len);
#if (DBG_LPSPG_INFO_DUMP >= 1)
if (pos)
RTW_INFO_DUMP(cache->name, pos, len);
#endif
rsvd_page_cache_update_all(cache, *total_page_num, txdesc_size, page_size, pos, len);
*total_page_num += cache->page_num;
*index += page_size * cache->page_num;
pos = only_get_page_num ? NULL : frame + *index;
RSVD_PAGE_CFG(cache->name, cache->page_num, *total_page_num, *index);
} else
rsvd_page_cache_free(cache);
/* LPSPG_IQK_INFO */
cache = &pwrctl->lpspg_iqk_info;
if (rsvd
/* RegIQKFWOffload will not change when enter wow_mode */
&& !(is_wow_mode && hal_data->RegIQKFWOffload)
) {
if (pwrctl->lps_level != LPS_PG || hal_data->RegIQKFWOffload)
pos = NULL;
len = 0;
halrf_iqk_info_rsvd_page(adapter_to_phydm(adapter), pos, &len);
#if (DBG_LPSPG_INFO_DUMP >= 1)
if (pos)
RTW_INFO_DUMP(cache->name, pos, len);
#endif
rsvd_page_cache_update_all(cache, *total_page_num, txdesc_size, page_size, pos, len);
*total_page_num += cache->page_num;
*index += page_size * cache->page_num;
pos = only_get_page_num ? NULL : frame + *index;
RSVD_PAGE_CFG(cache->name, cache->page_num, *total_page_num, *index);
} else
rsvd_page_cache_free(cache);
}
#endif
/* LPSPG_INFO */
cache = &pwrctl->lpspg_info;
if (rsvd) {
if (pwrctl->lps_level != LPS_PG)
pos = NULL;
rtw_hal_build_lps_pg_info_rsvd_page(adapter_to_dvobj(adapter), ld_sta_iface, pos, &len);
#if (DBG_LPSPG_INFO_DUMP >= 1)
if (pos)
RTW_INFO_DUMP(cache->name, pos, len);
#endif
rsvd_page_cache_update_all(cache, *total_page_num, txdesc_size, page_size, pos, len);
*total_page_num += cache->page_num;
*index += page_size * cache->page_num;
pos = only_get_page_num ? NULL : frame + *index;
RSVD_PAGE_CFG(cache->name, cache->page_num, *total_page_num, *index);
} else
rsvd_page_cache_free(cache);
}
static u8 rtw_hal_set_lps_pg_info_cmd(_adapter *adapter)
{
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
u8 lpspg_info[H2C_LPS_PG_INFO_LEN] = {0};
u8 ret = _FAIL;
if (_NO_PRIVACY_ != adapter->securitypriv.dot11PrivacyAlgrthm)
SET_H2CCMD_LPSPG_SEC_CAM_EN(lpspg_info, 1); /*SecurityCAM_En*/
#ifdef CONFIG_MBSSID_CAM
SET_H2CCMD_LPSPG_MBID_CAM_EN(lpspg_info, 1); /*BSSIDCAM_En*/
#endif
#if defined(CONFIG_WOWLAN) && defined(CONFIG_WOW_PATTERN_HW_CAM)
if (pwrpriv->wowlan_mode == _TRUE &&
check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
SET_H2CCMD_LPSPG_PMC_CAM_EN(lpspg_info, 1); /*PatternMatchCAM_En*/
}
#endif
#ifdef CONFIG_MACID_SEARCH
SET_H2CCMD_LPSPG_MACID_SEARCH_EN(lpspg_info, 1); /*MACIDSearch_En*/
#endif
#ifdef CONFIG_TX_SC
SET_H2CCMD_LPSPG_TXSC_EN(lpspg_info, 1); /*TXSC_En*/
#endif
#ifdef CONFIG_BEAMFORMING /*&& MU BF*/
SET_H2CCMD_LPSPG_MU_RATE_TB_EN(lpspg_info, 1); /*MURateTable_En*/
#endif
SET_H2CCMD_LPSPG_LOC(lpspg_info, pwrpriv->lpspg_info.loc);
#ifdef CONFIG_RTL8822C
SET_H2CCMD_LPSPG_DPK_INFO_LOC(lpspg_info, pwrpriv->lpspg_dpk_info.loc);
if (!GET_HAL_DATA(adapter)->RegIQKFWOffload)
SET_H2CCMD_LPSPG_IQK_INFO_LOC(lpspg_info, pwrpriv->lpspg_iqk_info.loc);
#endif
#if (DBG_LPSPG_INFO_DUMP >= 1)
RTW_INFO_DUMP("H2C_LPS_PG_INFO: ", lpspg_info, H2C_LPS_PG_INFO_LEN);
#endif
ret = rtw_hal_fill_h2c_cmd(adapter,
H2C_LPS_PG_INFO,
H2C_LPS_PG_INFO_LEN,
lpspg_info);
return ret;
}
u8 rtw_hal_set_lps_pg_info(_adapter *adapter)
{
u8 ret = _FAIL;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
if (pwrpriv->lpspg_info.loc == 0) {
RTW_ERR("%s lpspg_info.loc = 0\n", __func__);
rtw_warn_on(1);
return ret;
}
#ifdef CONFIG_RTL8822C
rtw_lps_pg_set_dpk_info_rsvd_page(adapter);
rtw_lps_pg_set_iqk_info_rsvd_page(adapter);
#endif
rtw_hal_set_lps_pg_info_rsvd_page(adapter);
ret = rtw_hal_set_lps_pg_info_cmd(adapter);
return ret;
}
void rtw_hal_lps_pg_rssi_lv_decide(_adapter *adapter, struct sta_info *sta)
{
#if 0
if (sta->cmn.ra_info.rssi_level >= 4)
sta->lps_pg_rssi_lv = 3; /*RSSI High - 1SS_VHT_MCS7*/
else if (sta->cmn.ra_info.rssi_level >= 2)
sta->lps_pg_rssi_lv = 2; /*RSSI Middle - 1SS_VHT_MCS3*/
else
sta->lps_pg_rssi_lv = 1; /*RSSI Lower - Lowest_rate*/
#else
sta->lps_pg_rssi_lv = 0;
#endif
RTW_INFO("%s mac-id:%d, rssi:%d, rssi_level:%d, lps_pg_rssi_lv:%d\n",
__func__, sta->cmn.mac_id, sta->cmn.rssi_stat.rssi, sta->cmn.ra_info.rssi_level, sta->lps_pg_rssi_lv);
}
void rtw_hal_lps_pg_handler(_adapter *adapter, enum lps_pg_hdl_id hdl_id)
{
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *sta;
sta = rtw_get_stainfo(pstapriv, pmlmeinfo->network.MacAddress);
switch (hdl_id) {
case LPS_PG_INFO_CFG:
rtw_hal_set_lps_pg_info(adapter);
break;
case LPS_PG_REDLEMEM:
if (IS_8822C_SERIES(GET_HAL_DATA(adapter)->version_id))
break;
/*set xmit_block*/
rtw_set_xmit_block(adapter, XMIT_BLOCK_REDLMEM);
if (_FAIL == rtw_hal_fw_mem_dl(adapter, FW_EMEM))
rtw_warn_on(1);
/*clearn xmit_block*/
rtw_clr_xmit_block(adapter, XMIT_BLOCK_REDLMEM);
break;
case LPS_PG_PHYDM_DIS:/*Disable RA and PT by H2C*/
if (IS_8822C_SERIES(GET_HAL_DATA(adapter)->version_id))
break;
if (sta)
rtw_phydm_lps_pg_hdl(adapter, sta, _TRUE);
break;
case LPS_PG_PHYDM_EN:/*Enable RA and PT by H2C*/
if (IS_8822C_SERIES(GET_HAL_DATA(adapter)->version_id))
break;
if (sta) {
rtw_hal_lps_pg_rssi_lv_decide(adapter, sta);
rtw_phydm_lps_pg_hdl(adapter, sta, _FALSE);
sta->lps_pg_rssi_lv = 0;
}
break;
default:
break;
}
}
#endif /*CONFIG_LPS_PG*/
static u8 _rtw_mi_assoc_if_num(_adapter *adapter)
{
u8 mi_iface_num = 0;
if (0) {
RTW_INFO("[IFS_ASSOC_STATUS] - STA :%d", DEV_STA_LD_NUM(adapter_to_dvobj(adapter)));
RTW_INFO("[IFS_ASSOC_STATUS] - AP:%d", DEV_AP_NUM(adapter_to_dvobj(adapter)));
RTW_INFO("[IFS_ASSOC_STATUS] - AP starting :%d", DEV_AP_STARTING_NUM(adapter_to_dvobj(adapter)));
RTW_INFO("[IFS_ASSOC_STATUS] - MESH :%d", DEV_MESH_NUM(adapter_to_dvobj(adapter)));
RTW_INFO("[IFS_ASSOC_STATUS] - ADHOC :%d", DEV_ADHOC_NUM(adapter_to_dvobj(adapter)));
/*RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GC :%d", DEV_P2P_GC_NUM(adapter_to_dvobj(adapter)));*/
/*RTW_INFO("[IFS_ASSOC_STATUS] - P2P-GO :%d", DEV_P2P_GO_NUM(adapter_to_dvobj(adapter)));*/
}
mi_iface_num = (DEV_STA_LD_NUM(adapter_to_dvobj(adapter)) +
DEV_AP_NUM(adapter_to_dvobj(adapter)) +
DEV_AP_STARTING_NUM(adapter_to_dvobj(adapter)));
return mi_iface_num;
}
#ifdef CONFIG_CONCURRENT_MODE
static _adapter *_rtw_search_sta_iface(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface = NULL;
_adapter *sta_iface = NULL;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (check_fwstate(&iface->mlmepriv, WIFI_STATION_STATE) == _TRUE) {
if (check_fwstate(&iface->mlmepriv, _FW_LINKED) == _TRUE) {
sta_iface = iface;
break;
}
}
}
return sta_iface;
}
#if defined(CONFIG_AP_MODE) && defined(CONFIG_BT_COEXIST)
static _adapter *_rtw_search_ap_iface(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface = NULL;
_adapter *ap_iface = NULL;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (check_fwstate(&iface->mlmepriv, WIFI_AP_STATE) == _TRUE ) {
ap_iface = iface;
break;
}
}
return ap_iface;
}
#endif/*CONFIG_AP_MODE*/
#endif/*CONFIG_CONCURRENT_MODE*/
#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
void rtw_hal_set_pathb_phase(_adapter *adapter, u8 phase_idx)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
struct PHY_DM_STRUCT *pDM_Odm = &pHalData->odmpriv;
return phydm_pathb_q_matrix_rotate(pDM_Odm, phase_idx);
}
#endif
/*
* Description: Fill the reserved packets that FW will use to RSVD page.
* Now we just send 4 types packet to rsvd page.
* (1)Beacon, (2)Ps-poll, (3)Null data, (4)ProbeRsp.
* Input:
* finished - FALSE:At the first time we will send all the packets as a large packet to Hw,
* so we need to set the packet length to total lengh.
* TRUE: At the second time, we should send the first packet (default:beacon)
* to Hw again and set the lengh in descriptor to the real beacon lengh.
* page_num - The amount of reserved page which driver need.
* If this is not NULL, this function doesn't real download reserved
* page, but just count the number of reserved page.
*
* 2009.10.15 by tynli.
* 2017.06.20 modified by Lucas.
*
* Page Size = 128: 8188e, 8723a/b, 8192c/d,
* Page Size = 256: 8192e, 8821a
* Page Size = 512: 8812a
*/
/*#define DBG_DUMP_SET_RSVD_PAGE*/
static void _rtw_hal_set_fw_rsvd_page(_adapter *adapter, bool finished, u8 *page_num)
{
PHAL_DATA_TYPE pHalData;
struct xmit_frame *pcmdframe = NULL;
struct pkt_attrib *pattrib;
struct xmit_priv *pxmitpriv;
struct pwrctrl_priv *pwrctl;
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct hal_ops *pHalFunc = &adapter->hal_func;
u32 BeaconLength = 0, ProbeRspLength = 0, PSPollLength = 0;
u32 NullDataLength = 0, QosNullLength = 0, BTQosNullLength = 0;
u32 ProbeReqLength = 0, NullFunctionDataLength = 0;
u8 TxDescLen = TXDESC_SIZE, TxDescOffset = TXDESC_OFFSET;
u8 TotalPageNum = 0 , CurtPktPageNum = 0 , RsvdPageNum = 0;
u8 *ReservedPagePacket;
u16 BufIndex = 0;
u32 TotalPacketLen = 0, MaxRsvdPageBufSize = 0, PageSize = 0;
RSVDPAGE_LOC RsvdPageLoc;
struct registry_priv *registry_par = &adapter->registrypriv;
#ifdef DBG_FW_DEBUG_MSG_PKT
u32 fw_dbg_msg_pkt_len = 0;
#endif /*DBG_FW_DEBUG_MSG_PKT*/
#ifdef DBG_CONFIG_ERROR_DETECT
struct sreset_priv *psrtpriv;
#endif /* DBG_CONFIG_ERROR_DETECT */
#ifdef CONFIG_MCC_MODE
u8 dl_mcc_page = _FAIL;
#endif /* CONFIG_MCC_MODE */
u8 nr_assoc_if;
_adapter *sta_iface = NULL;
_adapter *ap_iface = NULL;
bool is_wow_mode = _FALSE;
pHalData = GET_HAL_DATA(adapter);
#ifdef DBG_CONFIG_ERROR_DETECT
psrtpriv = &pHalData->srestpriv;
#endif
pxmitpriv = &adapter->xmitpriv;
pwrctl = adapter_to_pwrctl(adapter);
rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&PageSize);
if (PageSize == 0) {
RTW_ERR("[Error]: %s, PageSize is zero!!\n", __func__);
return;
}
nr_assoc_if = _rtw_mi_assoc_if_num(adapter);
if ((pwrctl->wowlan_mode == _TRUE && pwrctl->wowlan_in_resume == _FALSE) ||
pwrctl->wowlan_ap_mode == _TRUE ||
pwrctl->wowlan_p2p_mode == _TRUE)
is_wow_mode = _TRUE;
/*page_num for init time to get rsvd page number*/
/* Prepare ReservedPagePacket */
if (page_num) {
ReservedPagePacket = rtw_zmalloc(MAX_CMDBUF_SZ);
if (!ReservedPagePacket) {
RTW_WARN("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
*page_num = 0xFF;
return;
}
RTW_INFO(FUNC_ADPT_FMT" Get [ %s ] RsvdPageNUm ==>\n",
FUNC_ADPT_ARG(adapter), (is_wow_mode) ? "WOW" : "NOR");
} else {
if (is_wow_mode)
RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _TRUE);
else
RsvdPageNum = rtw_hal_get_txbuff_rsvd_page_num(adapter, _FALSE);
RTW_INFO(FUNC_ADPT_FMT" PageSize: %d, [ %s ]-RsvdPageNUm: %d\n",
FUNC_ADPT_ARG(adapter), PageSize, (is_wow_mode) ? "WOW" : "NOR", RsvdPageNum);
MaxRsvdPageBufSize = RsvdPageNum * PageSize;
if (MaxRsvdPageBufSize > MAX_CMDBUF_SZ) {
RTW_ERR("%s MaxRsvdPageBufSize(%d) is larger than MAX_CMDBUF_SZ(%d)",
__func__, MaxRsvdPageBufSize, MAX_CMDBUF_SZ);
rtw_warn_on(1);
return;
}
pcmdframe = rtw_alloc_cmdxmitframe(pxmitpriv);
if (pcmdframe == NULL) {
RTW_ERR("%s: alloc ReservedPagePacket fail!\n", __FUNCTION__);
return;
}
ReservedPagePacket = pcmdframe->buf_addr;
}
_rtw_memset(&RsvdPageLoc, 0, sizeof(RSVDPAGE_LOC));
BufIndex = TxDescOffset;
/*======== beacon content =======*/
rtw_hal_construct_beacon(adapter,
&ReservedPagePacket[BufIndex], &BeaconLength);
/*
* When we count the first page size, we need to reserve description size for the RSVD
* packet, it will be filled in front of the packet in TXPKTBUF.
*/
BeaconLength = MAX_BEACON_LEN - TxDescLen;
CurtPktPageNum = (u8)PageNum((TxDescLen + BeaconLength), PageSize);
#ifdef CONFIG_FW_HANDLE_TXBCN
CurtPktPageNum = CurtPktPageNum * CONFIG_LIMITED_AP_NUM;
#endif
TotalPageNum += CurtPktPageNum;
BufIndex += (CurtPktPageNum * PageSize);
RSVD_PAGE_CFG("Beacon", CurtPktPageNum, TotalPageNum, TotalPacketLen);
/*======== probe response content ========*/
if (pwrctl->wowlan_ap_mode == _TRUE) {/*WOW mode*/
#ifdef CONFIG_CONCURRENT_MODE
if (nr_assoc_if >= 2)
RTW_ERR("Not support > 2 net-interface in WOW\n");
#endif
/* (4) probe response*/
RsvdPageLoc.LocProbeRsp = TotalPageNum;
rtw_hal_construct_ProbeRsp(
adapter, &ReservedPagePacket[BufIndex],
&ProbeRspLength,
_FALSE);
rtw_hal_fill_fake_txdesc(adapter,
&ReservedPagePacket[BufIndex - TxDescLen],
ProbeRspLength, _FALSE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum(TxDescLen + ProbeRspLength, PageSize);
TotalPageNum += CurtPktPageNum;
TotalPacketLen = BufIndex + ProbeRspLength;
BufIndex += (CurtPktPageNum * PageSize);
RSVD_PAGE_CFG("ProbeRsp", CurtPktPageNum, TotalPageNum, TotalPacketLen);
goto download_page;
}
/*======== ps-poll content * 1 page ========*/
sta_iface = adapter;
#ifdef CONFIG_CONCURRENT_MODE
if (!MLME_IS_STA(sta_iface) && DEV_STA_LD_NUM(adapter_to_dvobj(sta_iface))) {
sta_iface = _rtw_search_sta_iface(adapter);
RTW_INFO("get ("ADPT_FMT") to create PS-Poll/Null/QosNull\n", ADPT_ARG(sta_iface));
}
#endif
if (MLME_IS_STA(sta_iface) || (nr_assoc_if == 0)) {
RsvdPageLoc.LocPsPoll = TotalPageNum;
RTW_INFO("LocPsPoll: %d\n", RsvdPageLoc.LocPsPoll);
rtw_hal_construct_PSPoll(sta_iface,
&ReservedPagePacket[BufIndex], &PSPollLength);
rtw_hal_fill_fake_txdesc(sta_iface,
&ReservedPagePacket[BufIndex - TxDescLen],
PSPollLength, _TRUE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum((TxDescLen + PSPollLength), PageSize);
TotalPageNum += CurtPktPageNum;
BufIndex += (CurtPktPageNum * PageSize);
RSVD_PAGE_CFG("PSPoll", CurtPktPageNum, TotalPageNum, TotalPacketLen);
}
#ifdef CONFIG_MCC_MODE
/*======== MCC * n page ======== */
if (MCC_EN(adapter)) {/*Normal mode*/
dl_mcc_page = rtw_hal_dl_mcc_fw_rsvd_page(adapter, ReservedPagePacket,
&BufIndex, TxDescLen, PageSize, &TotalPageNum, &RsvdPageLoc, page_num);
} else {
dl_mcc_page = _FAIL;
}
if (dl_mcc_page == _FAIL)
#endif /* CONFIG_MCC_MODE */
{ /*======== null data * 1 page ======== */
if (MLME_IS_STA(sta_iface) || (nr_assoc_if == 0)) {
RsvdPageLoc.LocNullData = TotalPageNum;
RTW_INFO("LocNullData: %d\n", RsvdPageLoc.LocNullData);
rtw_hal_construct_NullFunctionData(
sta_iface,
&ReservedPagePacket[BufIndex],
&NullDataLength,
_FALSE, 0, 0, _FALSE);
rtw_hal_fill_fake_txdesc(sta_iface,
&ReservedPagePacket[BufIndex - TxDescLen],
NullDataLength, _FALSE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum(TxDescLen + NullDataLength, PageSize);
TotalPageNum += CurtPktPageNum;
BufIndex += (CurtPktPageNum * PageSize);
RSVD_PAGE_CFG("NullData", CurtPktPageNum, TotalPageNum, TotalPacketLen);
}
}
/*======== Qos null data * 1 page ======== */
if (pwrctl->wowlan_mode == _FALSE ||
pwrctl->wowlan_in_resume == _TRUE) {/*Normal mode*/
if (MLME_IS_STA(sta_iface) || (nr_assoc_if == 0)) {
RsvdPageLoc.LocQosNull = TotalPageNum;
RTW_INFO("LocQosNull: %d\n", RsvdPageLoc.LocQosNull);
rtw_hal_construct_NullFunctionData(sta_iface,
&ReservedPagePacket[BufIndex],
&QosNullLength,
_TRUE, 0, 0, _FALSE);
rtw_hal_fill_fake_txdesc(sta_iface,
&ReservedPagePacket[BufIndex - TxDescLen],
QosNullLength, _FALSE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum(TxDescLen + QosNullLength,
PageSize);
TotalPageNum += CurtPktPageNum;
BufIndex += (CurtPktPageNum * PageSize);
RSVD_PAGE_CFG("QosNull", CurtPktPageNum, TotalPageNum, TotalPacketLen);
}
}
#ifdef CONFIG_BT_COEXIST
/*======== BT Qos null data * 1 page ======== */
if (pwrctl->wowlan_mode == _FALSE ||
pwrctl->wowlan_in_resume == _TRUE) {/*Normal mode*/
ap_iface = adapter;
#ifdef CONFIG_CONCURRENT_MODE
if (!MLME_IS_AP(ap_iface) && DEV_AP_NUM(adapter_to_dvobj(ap_iface))) { /*DEV_AP_STARTING_NUM*/
ap_iface = _rtw_search_ap_iface(adapter);
RTW_INFO("get ("ADPT_FMT") to create BTQoSNull\n", ADPT_ARG(ap_iface));
}
#endif
if (MLME_IS_AP(ap_iface) || (nr_assoc_if == 0)) {
RsvdPageLoc.LocBTQosNull = TotalPageNum;
RTW_INFO("LocBTQosNull: %d\n", RsvdPageLoc.LocBTQosNull);
rtw_hal_construct_NullFunctionData(ap_iface,
&ReservedPagePacket[BufIndex],
&BTQosNullLength,
_TRUE, 0, 0, _FALSE);
rtw_hal_fill_fake_txdesc(ap_iface,
&ReservedPagePacket[BufIndex - TxDescLen],
BTQosNullLength, _FALSE, _TRUE, _FALSE);
CurtPktPageNum = (u8)PageNum(TxDescLen + BTQosNullLength,
PageSize);
TotalPageNum += CurtPktPageNum;
BufIndex += (CurtPktPageNum * PageSize);
RSVD_PAGE_CFG("BTQosNull", CurtPktPageNum, TotalPageNum, TotalPacketLen);
}
}
#endif /* CONFIG_BT_COEXIT */
TotalPacketLen = BufIndex;
#ifdef DBG_FW_DEBUG_MSG_PKT
/*======== FW DEBUG MSG * n page ======== */
RsvdPageLoc.loc_fw_dbg_msg_pkt = TotalPageNum;
RTW_INFO("loc_fw_dbg_msg_pkt: %d\n", RsvdPageLoc.loc_fw_dbg_msg_pkt);
rtw_hal_construct_fw_dbg_msg_pkt(
adapter,
&ReservedPagePacket[BufIndex],
&fw_dbg_msg_pkt_len);
rtw_hal_fill_fake_txdesc(adapter,
&ReservedPagePacket[BufIndex - TxDescLen],
fw_dbg_msg_pkt_len, _FALSE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum(TxDescLen + fw_dbg_msg_pkt_len, PageSize);
TotalPageNum += CurtPktPageNum;
TotalPacketLen = BufIndex + fw_dbg_msg_pkt_len;
BufIndex += (CurtPktPageNum * PageSize);
#endif /*DBG_FW_DEBUG_MSG_PKT*/
#ifdef CONFIG_LPS_PG
rtw_lps_pg_set_rsvd_page(adapter, ReservedPagePacket, &BufIndex
, TxDescLen, PageSize, &TotalPageNum, is_wow_mode
, (sta_iface && MLME_IS_STA(sta_iface) && MLME_IS_ASOC(sta_iface)) ? sta_iface : NULL
, page_num ? 1 : 0
);
TotalPacketLen = BufIndex;
#endif
#ifdef CONFIG_WOWLAN
/*======== WOW * n page ======== */
if (pwrctl->wowlan_mode == _TRUE &&
pwrctl->wowlan_in_resume == _FALSE &&
!(registry_par->suspend_type == FW_IPS_DISABLE_BBRF && !check_fwstate(pmlmepriv, _FW_LINKED))) {/*WOW mode*/
rtw_hal_set_wow_fw_rsvd_page(adapter, ReservedPagePacket,
BufIndex, TxDescLen, PageSize,
&TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
}
#endif /* CONFIG_WOWLAN */
#ifdef CONFIG_P2P_WOWLAN
/*======== P2P WOW * n page ======== */
if (_TRUE == pwrctl->wowlan_p2p_mode) {/*WOW mode*/
rtw_hal_set_p2p_wow_fw_rsvd_page(adapter, ReservedPagePacket,
BufIndex, TxDescLen, PageSize,
&TotalPageNum, &TotalPacketLen, &RsvdPageLoc);
}
#endif /* CONFIG_P2P_WOWLAN */
/*Note: BufIndex already add a TxDescOffset offset in first Beacon page
* The "TotalPacketLen" is calculate by BufIndex.
* We need to decrease TxDescOffset before doing length check. by yiwei
*/
TotalPacketLen = TotalPacketLen - TxDescOffset;
download_page:
if (page_num) {
*page_num = TotalPageNum;
rtw_mfree(ReservedPagePacket, MAX_CMDBUF_SZ);
ReservedPagePacket = NULL;
RTW_INFO(FUNC_ADPT_FMT" Get [ %s ] RsvdPageNUm <==\n",
FUNC_ADPT_ARG(adapter), (is_wow_mode) ? "WOW" : "NOR");
return;
}
/* RTW_INFO("%s BufIndex(%d), TxDescLen(%d), PageSize(%d)\n",__func__, BufIndex, TxDescLen, PageSize);*/
RTW_INFO("%s PageNum(%d), pktlen(%d)\n",
__func__, TotalPageNum, TotalPacketLen);
if (TotalPacketLen > MaxRsvdPageBufSize) {
RTW_ERR("%s : rsvd page size is not enough!!TotalPacketLen %d, MaxRsvdPageBufSize %d\n",
__FUNCTION__, TotalPacketLen, MaxRsvdPageBufSize);
rtw_warn_on(1);
goto error;
} else {
/* update attribute */
pattrib = &pcmdframe->attrib;
update_mgntframe_attrib(adapter, pattrib);
pattrib->qsel = QSLT_BEACON;
pattrib->pktlen = TotalPacketLen;
pattrib->last_txcmdsz = TotalPacketLen;
#ifdef CONFIG_PCI_HCI
dump_mgntframe(adapter, pcmdframe);
#else
dump_mgntframe_and_wait(adapter, pcmdframe, 100);
#endif
}
RTW_INFO("%s: Set RSVD page location to Fw ,TotalPacketLen(%d), TotalPageNum(%d)\n",
__func__, TotalPacketLen, TotalPageNum);
#ifdef DBG_DUMP_SET_RSVD_PAGE
RTW_INFO(" ==================================================\n");
RTW_INFO_DUMP("\n", ReservedPagePacket, TotalPacketLen);
RTW_INFO(" ==================================================\n");
#endif
if (check_fwstate(pmlmepriv, _FW_LINKED)
|| MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)){
rtw_hal_set_FwRsvdPage_cmd(adapter, &RsvdPageLoc);
#ifdef DBG_FW_DEBUG_MSG_PKT
rtw_hal_set_fw_dbg_msg_pkt_rsvd_page_cmd(adapter, &RsvdPageLoc);
#endif /*DBG_FW_DEBUG_MSG_PKT*/
#ifdef CONFIG_WOWLAN
if (pwrctl->wowlan_mode == _TRUE &&
pwrctl->wowlan_in_resume == _FALSE)
rtw_hal_set_FwAoacRsvdPage_cmd(adapter, &RsvdPageLoc);
#endif /* CONFIG_WOWLAN */
#ifdef CONFIG_AP_WOWLAN
if (pwrctl->wowlan_ap_mode == _TRUE)
rtw_hal_set_ap_rsvdpage_loc_cmd(adapter, &RsvdPageLoc);
#endif /* CONFIG_AP_WOWLAN */
} else if (pwrctl->wowlan_pno_enable) {
#ifdef CONFIG_PNO_SUPPORT
rtw_hal_set_FwAoacRsvdPage_cmd(adapter, &RsvdPageLoc);
if (pwrctl->wowlan_in_resume)
rtw_hal_set_scan_offload_info_cmd(adapter,
&RsvdPageLoc, 0);
else
rtw_hal_set_scan_offload_info_cmd(adapter,
&RsvdPageLoc, 1);
#endif /* CONFIG_PNO_SUPPORT */
}
#ifdef CONFIG_P2P_WOWLAN
if (_TRUE == pwrctl->wowlan_p2p_mode)
rtw_hal_set_FwP2PRsvdPage_cmd(adapter, &RsvdPageLoc);
#endif /* CONFIG_P2P_WOWLAN */
return;
error:
rtw_free_xmitframe(pxmitpriv, pcmdframe);
}
void rtw_hal_set_fw_rsvd_page(struct _ADAPTER *adapter, bool finished)
{
if (finished)
rtw_mi_tx_beacon_hdl(adapter);
else
_rtw_hal_set_fw_rsvd_page(adapter, finished, NULL);
}
/**
* rtw_hal_get_rsvd_page_num() - Get needed reserved page number
* @adapter: struct _ADAPTER*
*
* Caculate needed reserved page number.
* In different state would get different number, for example normal mode and
* WOW mode would need different reserved page size.
*
* Return the number of reserved page which driver need.
*/
u8 rtw_hal_get_rsvd_page_num(struct _ADAPTER *adapter)
{
u8 num = 0;
_rtw_hal_set_fw_rsvd_page(adapter, _FALSE, &num);
return num;
}
static void hw_var_set_bcn_func(_adapter *adapter, u8 enable)
{
u32 bcn_ctrl_reg;
#ifdef CONFIG_CONCURRENT_MODE
if (adapter->hw_port == HW_PORT1)
bcn_ctrl_reg = REG_BCN_CTRL_1;
else
#endif
bcn_ctrl_reg = REG_BCN_CTRL;
if (enable)
rtw_write8(adapter, bcn_ctrl_reg, (EN_BCN_FUNCTION | EN_TXBCN_RPT));
else {
u8 val8;
val8 = rtw_read8(adapter, bcn_ctrl_reg);
val8 &= ~(EN_BCN_FUNCTION | EN_TXBCN_RPT);
#ifdef CONFIG_BT_COEXIST
if (GET_HAL_DATA(adapter)->EEPROMBluetoothCoexist == 1) {
/* Always enable port0 beacon function for PSTDMA */
if (REG_BCN_CTRL == bcn_ctrl_reg)
val8 |= EN_BCN_FUNCTION;
}
#endif
rtw_write8(adapter, bcn_ctrl_reg, val8);
}
#ifdef CONFIG_RTL8192F
if (IS_HARDWARE_TYPE_8192F(adapter)) {
u16 val16, val16_ori;
val16_ori = val16 = rtw_read16(adapter, REG_WLAN_ACT_MASK_CTRL_1);
#ifdef CONFIG_CONCURRENT_MODE
if (adapter->hw_port == HW_PORT1) {
if (enable)
val16 |= EN_PORT_1_FUNCTION;
else
val16 &= ~EN_PORT_1_FUNCTION;
} else
#endif
{
if (enable)
val16 |= EN_PORT_0_FUNCTION;
else
val16 &= ~EN_PORT_0_FUNCTION;
#ifdef CONFIG_BT_COEXIST
if (GET_HAL_DATA(adapter)->EEPROMBluetoothCoexist == 1)
val16 |= EN_PORT_0_FUNCTION;
#endif
}
if (val16 != val16_ori)
rtw_write16(adapter, REG_WLAN_ACT_MASK_CTRL_1, val16);
}
#endif
}
static void hw_var_set_mlme_disconnect(_adapter *adapter)
{
u8 val8;
/* reject all data frames */
#ifdef CONFIG_CONCURRENT_MODE
if (rtw_mi_check_status(adapter, MI_LINKED) == _FALSE)
#endif
rtw_write16(adapter, REG_RXFLTMAP2, 0x0000);
#ifdef CONFIG_CONCURRENT_MODE
if (adapter->hw_port == HW_PORT1) {
/* reset TSF1 */
rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(1));
/* disable update TSF1 */
rtw_iface_disable_tsf_update(adapter);
if (!IS_HARDWARE_TYPE_8723D(adapter)
&& !IS_HARDWARE_TYPE_8192F(adapter)
&& !IS_HARDWARE_TYPE_8710B(adapter)
) {
/* disable Port1's beacon function */
val8 = rtw_read8(adapter, REG_BCN_CTRL_1);
val8 &= ~EN_BCN_FUNCTION;
rtw_write8(adapter, REG_BCN_CTRL_1, val8);
}
} else
#endif
{
/* reset TSF */
rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(0));
/* disable update TSF */
rtw_iface_disable_tsf_update(adapter);
}
}
static void hw_var_set_mlme_sitesurvey(_adapter *adapter, u8 enable)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u16 value_rxfltmap2;
int i;
_adapter *iface;
#ifdef DBG_IFACE_STATUS
DBG_IFACE_STATUS_DUMP(adapter);
#endif
#ifdef CONFIG_FIND_BEST_CHANNEL
/* Receive all data frames */
value_rxfltmap2 = 0xFFFF;
#else
/* not to receive data frame */
value_rxfltmap2 = 0;
#endif
if (enable) { /* under sitesurvey */
/*
* 1. configure REG_RXFLTMAP2
* 2. disable TSF update & buddy TSF update to avoid updating wrong TSF due to clear RCR_CBSSID_BCN
* 3. config RCR to receive different BSSID BCN or probe rsp
*/
rtw_write16(adapter, REG_RXFLTMAP2, value_rxfltmap2);
rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_ENTER);
/* Save orignal RRSR setting, only 8812 set RRSR after set ch/bw/band */
#if defined (CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
hal_data->RegRRSR = rtw_read32(adapter, REG_RRSR);
hal_data->RegRRSR &= 0x000FFFFF;
#endif
#if defined(CONFIG_BEAMFORMING) && (defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A))
if (IS_8812_SERIES(hal_data->version_id) || IS_8821_SERIES(hal_data->version_id)) {
/* set 718[1:0]=2'b00 to avoid BF scan hang */
hal_data->backup_snd_ptcl_ctrl = rtw_read8(adapter, REG_SND_PTCL_CTRL_8812A);
rtw_write8(adapter, REG_SND_PTCL_CTRL_8812A, (hal_data->backup_snd_ptcl_ctrl & 0xfc));
}
#endif
if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
StopTxBeacon(adapter);
} else { /* sitesurvey done */
/*
* 1. enable rx data frame
* 2. config RCR not to receive different BSSID BCN or probe rsp
* 3. doesn't enable TSF update & buddy TSF right now to avoid HW conflict
* so, we enable TSF update when rx first BCN after sitesurvey done
*/
if (rtw_mi_check_fwstate(adapter, _FW_LINKED | WIFI_AP_STATE | WIFI_MESH_STATE)) {
/* enable to rx data frame */
rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
}
rtw_hal_rcr_set_chk_bssid(adapter, MLME_SCAN_DONE);
/* Restore orignal RRSR setting,only 8812 set RRSR after set ch/bw/band */
#if defined (CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
#ifdef RTW_DYNAMIC_RRSR
rtw_phydm_set_rrsr(adapter, hal_data->RegRRSR, TRUE);
#else/*RTW_DYNAMIC_RRSR*/
u32 temp_RRSR;
temp_RRSR = rtw_read32(adapter, REG_RRSR);
temp_RRSR &= 0xFFF00000;
hal_data->RegRRSR |= temp_RRSR;
rtw_write32(adapter, REG_RRSR, hal_data->RegRRSR);
#endif/*RTW_DYNAMIC_RRSR*/
#endif
#if defined(CONFIG_BEAMFORMING) && (defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A))
if (IS_8812_SERIES(hal_data->version_id) || IS_8821_SERIES(hal_data->version_id)) {
/* Restore orignal 0x718 setting*/
rtw_write8(adapter, REG_SND_PTCL_CTRL_8812A, hal_data->backup_snd_ptcl_ctrl);
}
#endif
if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
ResumeTxBeacon(adapter);
rtw_mi_tx_beacon_hdl(adapter);
}
}
}
static void hw_var_set_mlme_join(_adapter *adapter, u8 type)
{
u8 val8;
u16 val16;
u32 val32;
u8 RetryLimit = RL_VAL_STA;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
#ifdef CONFIG_CONCURRENT_MODE
if (type == 0) {
/* prepare to join */
if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
StopTxBeacon(adapter);
/* enable to rx data frame.Accept all data frame */
rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
RetryLimit = (hal_data->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
else /* Ad-hoc Mode */
RetryLimit = RL_VAL_AP;
rtw_iface_enable_tsf_update(adapter);
} else if (type == 1) {
/* joinbss_event call back when join res < 0 */
if (rtw_mi_check_status(adapter, MI_LINKED) == _FALSE)
rtw_write16(adapter, REG_RXFLTMAP2, 0x00);
rtw_iface_disable_tsf_update(adapter);
if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
ResumeTxBeacon(adapter);
/* reset TSF 1/2 after ResumeTxBeacon */
rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(1) | BIT(0));
}
} else if (type == 2) {
/* sta add event call back */
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
/* fixed beacon issue for 8191su........... */
rtw_write8(adapter, 0x542 , 0x02);
RetryLimit = RL_VAL_AP;
}
if (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter)) {
ResumeTxBeacon(adapter);
/* reset TSF 1/2 after ResumeTxBeacon */
rtw_write8(adapter, REG_DUAL_TSF_RST, BIT(1) | BIT(0));
}
}
val16 = BIT_SRL(RetryLimit) | BIT_LRL(RetryLimit);
rtw_write16(adapter, REG_RETRY_LIMIT, val16);
#else /* !CONFIG_CONCURRENT_MODE */
if (type == 0) { /* prepare to join */
/* enable to rx data frame.Accept all data frame */
rtw_write16(adapter, REG_RXFLTMAP2, 0xFFFF);
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == _TRUE)
RetryLimit = (hal_data->CustomerID == RT_CID_CCX) ? RL_VAL_AP : RL_VAL_STA;
else /* Ad-hoc Mode */
RetryLimit = RL_VAL_AP;
rtw_iface_enable_tsf_update(adapter);
} else if (type == 1) { /* joinbss_event call back when join res < 0 */
rtw_write16(adapter, REG_RXFLTMAP2, 0x00);
rtw_iface_disable_tsf_update(adapter);
} else if (type == 2) { /* sta add event call back */
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE))
RetryLimit = RL_VAL_AP;
}
val16 = BIT_SRL(RetryLimit) | BIT_LRL(RetryLimit);
rtw_write16(adapter, REG_RETRY_LIMIT, val16);
#endif /* !CONFIG_CONCURRENT_MODE */
}
#ifdef CONFIG_TSF_RESET_OFFLOAD
static int rtw_hal_h2c_reset_tsf(_adapter *adapter, u8 reset_port)
{
u8 buf[2];
int ret;
if (reset_port == HW_PORT0) {
buf[0] = 0x1;
buf[1] = 0;
} else {
buf[0] = 0x0;
buf[1] = 0x1;
}
ret = rtw_hal_fill_h2c_cmd(adapter, H2C_RESET_TSF, 2, buf);
return ret;
}
int rtw_hal_reset_tsf(_adapter *adapter, u8 reset_port)
{
u8 reset_cnt_before = 0, reset_cnt_after = 0, loop_cnt = 0;
u32 reg_reset_tsf_cnt = (reset_port == HW_PORT0) ?
REG_FW_RESET_TSF_CNT_0 : REG_FW_RESET_TSF_CNT_1;
int ret;
/* site survey will cause reset tsf fail */
rtw_mi_buddy_scan_abort(adapter, _FALSE);
reset_cnt_after = reset_cnt_before = rtw_read8(adapter, reg_reset_tsf_cnt);
ret = rtw_hal_h2c_reset_tsf(adapter, reset_port);
if (ret != _SUCCESS)
return ret;
while ((reset_cnt_after == reset_cnt_before) && (loop_cnt < 10)) {
rtw_msleep_os(100);
loop_cnt++;
reset_cnt_after = rtw_read8(adapter, reg_reset_tsf_cnt);
}
return (loop_cnt >= 10) ? _FAIL : _SUCCESS;
}
#endif /* CONFIG_TSF_RESET_OFFLOAD */
#ifdef CONFIG_HW_P0_TSF_SYNC
#ifdef CONFIG_CONCURRENT_MODE
static void hw_port0_tsf_sync_sel(_adapter *adapter, u8 benable, u8 hw_port, u16 tr_offset)
{
u8 val8;
u8 client_id = 0;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
#ifdef CONFIG_MCC_MODE
if (MCC_EN(adapter) && (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))) {
RTW_INFO("[MCC] do not set HW TSF sync\n");
return;
}
#endif
/* check if port0 is already synced */
if (benable && dvobj->p0_tsf.sync_port != MAX_HW_PORT && dvobj->p0_tsf.sync_port == hw_port) {
RTW_WARN(FUNC_ADPT_FMT ": port0 already enable TSF sync(%d)\n",
FUNC_ADPT_ARG(adapter), dvobj->p0_tsf.sync_port);
return;
}
/* check if port0 already disable sync */
if (!benable && dvobj->p0_tsf.sync_port == MAX_HW_PORT) {
RTW_WARN(FUNC_ADPT_FMT ": port0 already disable TSF sync\n", FUNC_ADPT_ARG(adapter));
return;
}
/* check if port0 sync to port0 */
if (benable && hw_port == HW_PORT0) {
RTW_ERR(FUNC_ADPT_FMT ": hw_port is port0 under enable\n", FUNC_ADPT_ARG(adapter));
rtw_warn_on(1);
return;
}
/*0x5B4 [6:4] :SYNC_CLI_SEL - The selector for the CLINT port of sync tsft source for port 0*/
/* Bit[5:4] : 0 for clint0, 1 for clint1, 2 for clint2, 3 for clint3.
Bit6 : 1= enable sync to port 0. 0=disable sync to port 0.*/
val8 = rtw_read8(adapter, REG_TIMER0_SRC_SEL);
if (benable) {
/*Disable Port0's beacon function*/
rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL) & ~BIT_EN_BCN_FUNCTION);
/*Reg 0x518[15:0]: TSFTR_SYN_OFFSET*/
if (tr_offset)
rtw_write16(adapter, REG_TSFTR_SYN_OFFSET, tr_offset);
/*reg 0x577[6]=1*/ /*auto sync by tbtt*/
rtw_write8(adapter, REG_MISC_CTRL, rtw_read8(adapter, REG_MISC_CTRL) | BIT_AUTO_SYNC_BY_TBTT);
if (HW_PORT1 == hw_port)
client_id = 0;
else if (HW_PORT2 == hw_port)
client_id = 1;
else if (HW_PORT3 == hw_port)
client_id = 2;
else if (HW_PORT4 == hw_port)
client_id = 3;
val8 &= 0x8F;
val8 |= (BIT(6) | (client_id << 4));
dvobj->p0_tsf.sync_port = hw_port;
dvobj->p0_tsf.offset = tr_offset;
rtw_write8(adapter, REG_TIMER0_SRC_SEL, val8);
/*Enable Port0's beacon function*/
rtw_write8(adapter, REG_BCN_CTRL, rtw_read8(adapter, REG_BCN_CTRL) | BIT_EN_BCN_FUNCTION);
RTW_INFO("%s Port_%d TSF sync to P0, timer offset :%d\n", __func__, hw_port, tr_offset);
} else {
val8 &= ~BIT(6);
dvobj->p0_tsf.sync_port = MAX_HW_PORT;
dvobj->p0_tsf.offset = 0;
rtw_write8(adapter, REG_TIMER0_SRC_SEL, val8);
RTW_INFO("%s P0 TSF sync disable\n", __func__);
}
}
static _adapter * _search_ld_sta(_adapter *adapter, u8 include_self)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 i;
_adapter *iface = NULL;
if (rtw_mi_get_assoced_sta_num(adapter) == 0) {
RTW_ERR("STA_LD_NUM == 0\n");
rtw_warn_on(1);
}
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (include_self == _FALSE && adapter == iface)
continue;
if (is_client_associated_to_ap(iface))
break;
}
if (iface)
RTW_INFO("search STA iface -"ADPT_FMT"\n", ADPT_ARG(iface));
return iface;
}
#endif /*CONFIG_CONCURRENT_MODE*/
/*Correct port0's TSF*/
/*#define DBG_P0_TSF_SYNC*/
void hw_var_set_correct_tsf(PADAPTER adapter, u8 mlme_state)
{
#ifdef CONFIG_CONCURRENT_MODE
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 p0_tsfsync = _FALSE;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
_adapter *sta_if = NULL;
u8 hw_port;
RTW_INFO(FUNC_ADPT_FMT "\n", FUNC_ADPT_ARG(adapter));
#ifdef DBG_P0_TSF_SYNC
RTW_INFO("[TSF_SYNC] AP_NUM = %d\n", rtw_mi_get_ap_num(adapter));
RTW_INFO("[TSF_SYNC] MESH_NUM = %d\n", rtw_mi_get_mesh_num(adapter));
RTW_INFO("[TSF_SYNC] LD_STA_NUM = %d\n", rtw_mi_get_assoced_sta_num(adapter));
if (dvobj->p0_tsf.sync_port == MAX_HW_PORT)
RTW_INFO("[TSF_SYNC] org p0 sync port = N/A\n");
else
RTW_INFO("[TSF_SYNC] org p0 sync port = %d\n", dvobj->p0_tsf.sync_port);
RTW_INFO("[TSF_SYNC] timer offset = %d\n", dvobj->p0_tsf.offset);
#endif
switch (mlme_state) {
case MLME_STA_CONNECTED :
{
hw_port = rtw_hal_get_port(adapter);
if (!MLME_IS_STA(adapter)) {
RTW_ERR("STA CON state,but iface("ADPT_FMT") is not STA\n", ADPT_ARG(adapter));
rtw_warn_on(1);
}
if ((dvobj->p0_tsf.sync_port != MAX_HW_PORT) && (hw_port == HW_PORT0)) {
RTW_ERR(ADPT_FMT" is STA with P0 connected => DIS P0_TSF_SYNC\n", ADPT_ARG(adapter));
rtw_warn_on(1);
hw_port0_tsf_sync_sel(adapter, _FALSE, 0, 0);
}
if ((dvobj->p0_tsf.sync_port == MAX_HW_PORT) &&
(rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))) {
hw_port0_tsf_sync_sel(adapter, _TRUE, hw_port, 50);/*timer offset 50ms*/
#ifdef DBG_P0_TSF_SYNC
RTW_INFO("[TSF_SYNC] STA_LINKED => EN P0_TSF_SYNC\n");
#endif
}
}
break;
case MLME_STA_DISCONNECTED :
{
hw_port = rtw_hal_get_port(adapter);
if (!MLME_IS_STA(adapter)) {
RTW_ERR("STA DIS_CON state,but iface("ADPT_FMT") is not STA\n", ADPT_ARG(adapter));
rtw_warn_on(1);
}
if (dvobj->p0_tsf.sync_port == hw_port) {
if (rtw_mi_get_assoced_sta_num(adapter) >= 2) {
/* search next appropriate sta*/
sta_if = _search_ld_sta(adapter, _FALSE);
if (sta_if) {
hw_port = rtw_hal_get_port(sta_if);
hw_port0_tsf_sync_sel(adapter, _TRUE, hw_port, 50);/*timer offset 50ms*/
#ifdef DBG_P0_TSF_SYNC
RTW_INFO("[TSF_SYNC] STA_DIS_CON => CHANGE P0_TSF_SYNC\n");
#endif
}
} else if (rtw_mi_get_assoced_sta_num(adapter) == 1) {
hw_port0_tsf_sync_sel(adapter, _FALSE, 0, 0);
#ifdef DBG_P0_TSF_SYNC
RTW_INFO("[TSF_SYNC] STA_DIS_CON => DIS P0_TSF_SYNC\n");
#endif
}
}
}
break;
case MLME_AP_STARTED :
case MLME_MESH_STARTED :
{
if (!(MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))) {
RTW_ERR("AP START state,but iface("ADPT_FMT") is not AP\n", ADPT_ARG(adapter));
rtw_warn_on(1);
}
if ((dvobj->p0_tsf.sync_port == MAX_HW_PORT) &&
rtw_mi_get_assoced_sta_num(adapter)) {
/* get port of sta */
sta_if = _search_ld_sta(adapter, _FALSE);
if (sta_if) {
hw_port = rtw_hal_get_port(sta_if);
hw_port0_tsf_sync_sel(adapter, _TRUE, hw_port, 50);/*timer offset 50ms*/
#ifdef DBG_P0_TSF_SYNC
RTW_INFO("[TSF_SYNC] AP_START => EN P0_TSF_SYNC\n");
#endif
}
}
}
break;
case MLME_AP_STOPPED :
case MLME_MESH_STOPPED :
{
if (!(MLME_IS_AP(adapter) || MLME_IS_MESH(adapter))) {
RTW_ERR("AP START state,but iface("ADPT_FMT") is not AP\n", ADPT_ARG(adapter));
rtw_warn_on(1);
}
/*stop ap mode*/
if ((rtw_mi_get_ap_num(adapter) + rtw_mi_get_mesh_num(adapter) == 1) &&
(dvobj->p0_tsf.sync_port != MAX_HW_PORT)) {
hw_port0_tsf_sync_sel(adapter, _FALSE, 0, 0);
#ifdef DBG_P0_TSF_SYNC
RTW_INFO("[TSF_SYNC] AP_STOP => DIS P0_TSF_SYNC\n");
#endif
}
}
break;
default :
RTW_ERR(FUNC_ADPT_FMT" unknow state(0x%02x)\n", FUNC_ADPT_ARG(adapter), mlme_state);
break;
}
/*#ifdef DBG_P0_TSF_SYNC*/
#if 1
if (dvobj->p0_tsf.sync_port == MAX_HW_PORT)
RTW_INFO("[TSF_SYNC] p0 sync port = N/A\n");
else
RTW_INFO("[TSF_SYNC] p0 sync port = %d\n", dvobj->p0_tsf.sync_port);
RTW_INFO("[TSF_SYNC] timer offset = %d\n", dvobj->p0_tsf.offset);
#endif
#endif /*CONFIG_CONCURRENT_MODE*/
}
#else /*! CONFIG_HW_P0_TSF_SYNC*/
#ifdef CONFIG_MI_WITH_MBSSID_CAM
static void hw_var_set_correct_tsf(_adapter *adapter, u8 mlme_state)
{
/*do nothing*/
}
#else /* !CONFIG_MI_WITH_MBSSID_CAM*/
static void rtw_hal_correct_tsf(_adapter *padapter, u8 hw_port, u64 tsf)
{
if (hw_port == HW_PORT0) {
/*disable related TSF function*/
rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) & (~EN_BCN_FUNCTION));
#if defined(CONFIG_RTL8192F)
rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
REG_WLAN_ACT_MASK_CTRL_1) & ~EN_PORT_0_FUNCTION);
#endif
rtw_write32(padapter, REG_TSFTR, tsf);
rtw_write32(padapter, REG_TSFTR + 4, tsf >> 32);
/*enable related TSF function*/
rtw_write8(padapter, REG_BCN_CTRL, rtw_read8(padapter, REG_BCN_CTRL) | EN_BCN_FUNCTION);
#if defined(CONFIG_RTL8192F)
rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
REG_WLAN_ACT_MASK_CTRL_1) | EN_PORT_0_FUNCTION);
#endif
} else if (hw_port == HW_PORT1) {
/*disable related TSF function*/
rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) & (~EN_BCN_FUNCTION));
#if defined(CONFIG_RTL8192F)
rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
REG_WLAN_ACT_MASK_CTRL_1) & ~EN_PORT_1_FUNCTION);
#endif
rtw_write32(padapter, REG_TSFTR1, tsf);
rtw_write32(padapter, REG_TSFTR1 + 4, tsf >> 32);
/*enable related TSF function*/
rtw_write8(padapter, REG_BCN_CTRL_1, rtw_read8(padapter, REG_BCN_CTRL_1) | EN_BCN_FUNCTION);
#if defined(CONFIG_RTL8192F)
rtw_write16(padapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(padapter,
REG_WLAN_ACT_MASK_CTRL_1) | EN_PORT_1_FUNCTION);
#endif
} else
RTW_INFO("%s-[WARN] "ADPT_FMT" invalid hw_port:%d\n", __func__, ADPT_ARG(padapter), hw_port);
}
static void hw_var_set_correct_tsf(_adapter *adapter, u8 mlme_state)
{
u64 tsf;
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *mlmeinfo = &(mlmeext->mlmext_info);
tsf = mlmeext->TSFValue - rtw_modular64(mlmeext->TSFValue, (mlmeinfo->bcn_interval * 1024)) - 1024; /*us*/
if ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE
|| (mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)
StopTxBeacon(adapter);
rtw_hal_correct_tsf(adapter, adapter->hw_port, tsf);
#ifdef CONFIG_CONCURRENT_MODE
/* Update buddy port's TSF if it is SoftAP/Mesh for beacon TX issue! */
if ((mlmeinfo->state & 0x03) == WIFI_FW_STATION_STATE
&& (rtw_mi_get_ap_num(adapter) || rtw_mi_get_mesh_num(adapter))
) {
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
int i;
_adapter *iface;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
if (iface == adapter)
continue;
if ((MLME_IS_AP(iface) || MLME_IS_MESH(iface))
&& check_fwstate(&iface->mlmepriv, WIFI_ASOC_STATE) == _TRUE
) {
rtw_hal_correct_tsf(iface, iface->hw_port, tsf);
#ifdef CONFIG_TSF_RESET_OFFLOAD
if (rtw_hal_reset_tsf(iface, iface->hw_port) == _FAIL)
RTW_INFO("%s-[ERROR] "ADPT_FMT" Reset port%d TSF fail\n"
, __func__, ADPT_ARG(iface), iface->hw_port);
#endif /* CONFIG_TSF_RESET_OFFLOAD*/
}
}
}
#endif /* CONFIG_CONCURRENT_MODE */
if ((mlmeinfo->state & 0x03) == WIFI_FW_ADHOC_STATE
|| (mlmeinfo->state & 0x03) == WIFI_FW_AP_STATE)
ResumeTxBeacon(adapter);
}
#endif /*#ifdef CONFIG_MI_WITH_MBSSID_CAM*/
#endif /*#ifdef CONFIG_HW_P0_TSF_SYNC*/
u64 rtw_hal_get_tsftr_by_port(_adapter *adapter, u8 port)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u64 tsftr = 0;
if (port >= hal_spec->port_num) {
RTW_ERR("%s invalid port(%d) \n", __func__, port);
goto exit;
}
switch (rtw_get_chip_type(adapter)) {
#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
case RTL8814A:
case RTL8822B:
case RTL8821C:
case RTL8822C:
{
u8 val8;
/* 0x554[30:28] - BIT_BCN_TIMER_SEL_FWRD */
val8 = rtw_read8(adapter, REG_MBSSID_BCN_SPACE + 3);
val8 &= 0x8F;
val8 |= port << 4;
rtw_write8(adapter, REG_MBSSID_BCN_SPACE + 3, val8);
tsftr = rtw_read32(adapter, REG_TSFTR + 4);
tsftr = tsftr << 32;
tsftr |= rtw_read32(adapter, REG_TSFTR);
break;
}
#endif
#if defined(CONFIG_RTL8188E) || defined(CONFIG_RTL8188F) || defined(CONFIG_RTL8188GTV) \
|| defined(CONFIG_RTL8192E) || defined(CONFIG_RTL8192F) \
|| defined(CONFIG_RTL8723B) || defined(CONFIG_RTL8703B) || defined(CONFIG_RTL8723D) \
|| defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) \
|| defined(CONFIG_RTL8710B)
case RTL8188E:
case RTL8188F:
case RTL8188GTV:
case RTL8192E:
case RTL8192F:
case RTL8723B:
case RTL8703B:
case RTL8723D:
case RTL8812:
case RTL8821:
case RTL8710B:
{
u32 addr;
if (port == HW_PORT0)
addr = REG_TSFTR;
else if (port == HW_PORT1)
addr = REG_TSFTR1;
else {
RTW_ERR("%s unknown port(%d) \n", __func__, port);
goto exit;
}
tsftr = rtw_read32(adapter, addr + 4);
tsftr = tsftr << 32;
tsftr |= rtw_read32(adapter, addr);
break;
}
#endif
default:
RTW_ERR("%s unknow chip type\n", __func__);
}
exit:
return tsftr;
}
#ifdef CONFIG_TDLS
#ifdef CONFIG_TDLS_CH_SW
s32 rtw_hal_ch_sw_oper_offload(_adapter *padapter, u8 channel, u8 channel_offset, u16 bwmode)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
u8 ch_sw_h2c_buf[4] = {0x00, 0x00, 0x00, 0x00};
SET_H2CCMD_CH_SW_OPER_OFFLOAD_CH_NUM(ch_sw_h2c_buf, channel);
SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_MODE(ch_sw_h2c_buf, bwmode);
switch (bwmode) {
case CHANNEL_WIDTH_40:
SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_40M_SC(ch_sw_h2c_buf, channel_offset);
break;
case CHANNEL_WIDTH_80:
SET_H2CCMD_CH_SW_OPER_OFFLOAD_BW_80M_SC(ch_sw_h2c_buf, channel_offset);
break;
case CHANNEL_WIDTH_20:
default:
break;
}
SET_H2CCMD_CH_SW_OPER_OFFLOAD_RFE_TYPE(ch_sw_h2c_buf, pHalData->rfe_type);
return rtw_hal_fill_h2c_cmd(padapter, H2C_CHNL_SWITCH_OPER_OFFLOAD, sizeof(ch_sw_h2c_buf), ch_sw_h2c_buf);
}
#endif
#endif
#ifdef CONFIG_WMMPS_STA
void rtw_hal_update_uapsd_tid(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
/* write complement of pqospriv->uapsd_tid to mac register 0x693 because
it's designed for "0" represents "enable" and "1" represents "disable" */
rtw_write8(adapter, REG_WMMPS_UAPSD_TID, (u8)(~pqospriv->uapsd_tid));
}
#endif /* CONFIG_WMMPS_STA */
#if defined(CONFIG_BT_COEXIST) && defined(CONFIG_FW_MULTI_PORT_SUPPORT)
/* For multi-port support, driver needs to inform the port ID to FW for btc operations */
s32 rtw_hal_set_wifi_btc_port_id_cmd(_adapter *adapter)
{
u8 h2c_buf[H2C_BTC_WL_PORT_ID_LEN] = {0};
u8 hw_port = rtw_hal_get_port(adapter);
SET_H2CCMD_BTC_WL_PORT_ID(h2c_buf, hw_port);
RTW_INFO("%s ("ADPT_FMT") - hw_port :%d\n", __func__, ADPT_ARG(adapter), hw_port);
return rtw_hal_fill_h2c_cmd(adapter, H2C_BTC_WL_PORT_ID, H2C_BTC_WL_PORT_ID_LEN, h2c_buf);
}
#endif
#define LPS_ACTIVE_TIMEOUT 10 /*number of times*/
void rtw_lps_state_chk(_adapter *adapter, u8 ps_mode)
{
if (ps_mode == PS_MODE_ACTIVE) {
u8 ps_ready = _FALSE;
s8 leave_wait_count = LPS_ACTIVE_TIMEOUT;
do {
if ((rtw_read8(adapter, REG_TCR) & BIT_PWRBIT_OW_EN) == 0) {
ps_ready = _TRUE;
break;
}
rtw_msleep_os(1);
} while (leave_wait_count--);
if (ps_ready == _FALSE) {
RTW_ERR(FUNC_ADPT_FMT" PS_MODE_ACTIVE check failed\n", FUNC_ADPT_ARG(adapter));
rtw_warn_on(1);
}
}
}
void rtw_var_set_basic_rate(PADAPTER padapter, u8 *val) {
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct mlme_ext_info *mlmext_info = &padapter->mlmeextpriv.mlmext_info;
u16 input_b = 0, masked = 0, ioted = 0, BrateCfg = 0;
u16 rrsr_2g_force_mask = RRSR_CCK_RATES;
u16 rrsr_2g_allow_mask = (RRSR_24M | RRSR_12M | RRSR_6M | RRSR_CCK_RATES);
#ifdef CONFIG_IEEE80211_BAND_5GHZ
u16 rrsr_5g_force_mask = (RRSR_6M);
u16 rrsr_5g_allow_mask = (RRSR_OFDM_RATES);
#endif
#ifdef RTW_DYNAMIC_RRSR
u32 temp_RRSR;
#endif
HalSetBrateCfg(padapter, val, &BrateCfg);
input_b = BrateCfg;
/* apply force and allow mask */
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (pHalData->current_band_type != BAND_ON_2_4G) {
BrateCfg |= rrsr_5g_force_mask;
BrateCfg &= rrsr_5g_allow_mask;
} else
#endif
{ /* 2.4G */
BrateCfg |= rrsr_2g_force_mask;
BrateCfg &= rrsr_2g_allow_mask;
}
masked = BrateCfg;
#ifdef CONFIG_CMCC_TEST
BrateCfg |= (RRSR_11M | RRSR_5_5M | RRSR_1M); /* use 11M to send ACK */
BrateCfg |= (RRSR_24M | RRSR_18M | RRSR_12M); /*CMCC_OFDM_ACK 12/18/24M */
#endif
/* IOT consideration */
if (mlmext_info->assoc_AP_vendor == HT_IOT_PEER_CISCO) {
/* if peer is cisco and didn't use ofdm rate, we enable 6M ack */
if ((BrateCfg & (RRSR_24M | RRSR_12M | RRSR_6M)) == 0)
BrateCfg |= RRSR_6M;
}
ioted = BrateCfg;
#ifdef CONFIG_NARROWBAND_SUPPORTING
if ((padapter->registrypriv.rtw_nb_config == RTW_NB_CONFIG_WIDTH_10)
|| (padapter->registrypriv.rtw_nb_config == RTW_NB_CONFIG_WIDTH_5)) {
BrateCfg &= ~RRSR_CCK_RATES;
BrateCfg |= RRSR_6M;
}
#endif
pHalData->BasicRateSet = BrateCfg;
RTW_INFO("HW_VAR_BASIC_RATE: %#x->%#x->%#x\n", input_b, masked, ioted);
/* Set RRSR rate table. */
#ifdef RTW_DYNAMIC_RRSR
temp_RRSR = rtw_read32(padapter, REG_RRSR);
temp_RRSR &=0xFFFF0000;
temp_RRSR |=BrateCfg;
rtw_phydm_set_rrsr(padapter, temp_RRSR, TRUE);
#else
rtw_write16(padapter, REG_RRSR, BrateCfg);
#endif
rtw_write8(padapter, REG_RRSR + 2, rtw_read8(padapter, REG_RRSR + 2) & 0xf0);
#if defined(CONFIG_RTL8188E)
rtw_hal_set_hwreg(padapter, HW_VAR_INIT_RTS_RATE, (u8 *)&BrateCfg);
#endif
}
u8 SetHwReg(_adapter *adapter, u8 variable, u8 *val)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 ret = _SUCCESS;
switch (variable) {
case HW_VAR_MEDIA_STATUS: {
u8 net_type = *((u8 *)val);
rtw_hal_set_msr(adapter, net_type);
}
break;
case HW_VAR_DO_IQK:
if (*val)
hal_data->bNeedIQK = _TRUE;
else
hal_data->bNeedIQK = _FALSE;
break;
case HW_VAR_MAC_ADDR:
#ifdef CONFIG_MI_WITH_MBSSID_CAM
rtw_hal_set_macaddr_mbid(adapter, val);
#else
rtw_hal_set_macaddr_port(adapter, val);
#endif
break;
case HW_VAR_BSSID:
rtw_hal_set_bssid(adapter, val);
break;
case HW_VAR_RCR:
ret = hw_var_rcr_config(adapter, *((u32 *)val));
break;
case HW_VAR_ON_RCR_AM:
hw_var_set_rcr_am(adapter, 1);
break;
case HW_VAR_OFF_RCR_AM:
hw_var_set_rcr_am(adapter, 0);
break;
case HW_VAR_BEACON_INTERVAL:
hw_var_set_bcn_interval(adapter, *(u16 *)val);
break;
#ifdef CONFIG_MBSSID_CAM
case HW_VAR_MBSSID_CAM_WRITE: {
u32 cmd = 0;
u32 *cam_val = (u32 *)val;
rtw_write32(adapter, REG_MBIDCAMCFG_1, cam_val[0]);
cmd = BIT_MBIDCAM_POLL | BIT_MBIDCAM_WT_EN | BIT_MBIDCAM_VALID | cam_val[1];
rtw_write32(adapter, REG_MBIDCAMCFG_2, cmd);
}
break;
case HW_VAR_MBSSID_CAM_CLEAR: {
u32 cmd;
u8 entry_id = *(u8 *)val;
rtw_write32(adapter, REG_MBIDCAMCFG_1, 0);
cmd = BIT_MBIDCAM_POLL | BIT_MBIDCAM_WT_EN | ((entry_id & MBIDCAM_ADDR_MASK) << MBIDCAM_ADDR_SHIFT);
rtw_write32(adapter, REG_MBIDCAMCFG_2, cmd);
}
break;
case HW_VAR_RCR_MBSSID_EN:
if (*((u8 *)val))
rtw_hal_rcr_add(adapter, RCR_ENMBID);
else
rtw_hal_rcr_clear(adapter, RCR_ENMBID);
break;
#endif
case HW_VAR_PORT_SWITCH:
hw_var_port_switch(adapter);
break;
case HW_VAR_INIT_RTS_RATE: {
u16 brate_cfg = *((u16 *)val);
u8 rate_index = 0;
HAL_VERSION *hal_ver = &hal_data->version_id;
if (IS_8188E(*hal_ver)) {
while (brate_cfg > 0x1) {
brate_cfg = (brate_cfg >> 1);
rate_index++;
}
rtw_write8(adapter, REG_INIRTS_RATE_SEL, rate_index);
} else
rtw_warn_on(1);
}
break;
case HW_VAR_SEC_CFG: {
u16 reg_scr_ori;
u16 reg_scr;
reg_scr = reg_scr_ori = rtw_read16(adapter, REG_SECCFG);
reg_scr |= (SCR_CHK_KEYID | SCR_RxDecEnable | SCR_TxEncEnable);
if (_rtw_camctl_chk_cap(adapter, SEC_CAP_CHK_BMC))
reg_scr |= SCR_CHK_BMC;
if (_rtw_camctl_chk_flags(adapter, SEC_STATUS_STA_PK_GK_CONFLICT_DIS_BMC_SEARCH))
reg_scr |= SCR_NoSKMC;
if (reg_scr != reg_scr_ori)
rtw_write16(adapter, REG_SECCFG, reg_scr);
}
break;
case HW_VAR_SEC_DK_CFG: {
struct security_priv *sec = &adapter->securitypriv;
u8 reg_scr = rtw_read8(adapter, REG_SECCFG);
if (val) { /* Enable default key related setting */
reg_scr |= SCR_TXBCUSEDK;
if (sec->dot11AuthAlgrthm != dot11AuthAlgrthm_8021X)
reg_scr |= (SCR_RxUseDK | SCR_TxUseDK);
} else /* Disable default key related setting */
reg_scr &= ~(SCR_RXBCUSEDK | SCR_TXBCUSEDK | SCR_RxUseDK | SCR_TxUseDK);
rtw_write8(adapter, REG_SECCFG, reg_scr);
}
break;
case HW_VAR_ASIX_IOT:
/* enable ASIX IOT function */
if (*((u8 *)val) == _TRUE) {
/* 0xa2e[0]=0 (disable rake receiver) */
rtw_write8(adapter, rCCK0_FalseAlarmReport + 2,
rtw_read8(adapter, rCCK0_FalseAlarmReport + 2) & ~(BIT0));
/* 0xa1c=0xa0 (reset channel estimation if signal quality is bad) */
rtw_write8(adapter, rCCK0_DSPParameter2, 0xa0);
} else {
/* restore reg:0xa2e, reg:0xa1c */
rtw_write8(adapter, rCCK0_FalseAlarmReport + 2,
rtw_read8(adapter, rCCK0_FalseAlarmReport + 2) | (BIT0));
rtw_write8(adapter, rCCK0_DSPParameter2, 0x00);
}
break;
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
case HW_VAR_WOWLAN: {
struct wowlan_ioctl_param *poidparam;
poidparam = (struct wowlan_ioctl_param *)val;
switch (poidparam->subcode) {
#ifdef CONFIG_WOWLAN
case WOWLAN_PATTERN_CLEAN:
rtw_hal_dl_pattern(adapter, 2);
break;
case WOWLAN_ENABLE:
rtw_hal_wow_enable(adapter);
break;
case WOWLAN_DISABLE:
rtw_hal_wow_disable(adapter);
break;
#endif /*CONFIG_WOWLAN*/
#ifdef CONFIG_AP_WOWLAN
case WOWLAN_AP_ENABLE:
rtw_hal_ap_wow_enable(adapter);
break;
case WOWLAN_AP_DISABLE:
rtw_hal_ap_wow_disable(adapter);
break;
#endif /*CONFIG_AP_WOWLAN*/
default:
break;
}
}
break;
#endif /*defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)*/
case HW_VAR_BCN_FUNC:
hw_var_set_bcn_func(adapter, *val);
break;
case HW_VAR_MLME_DISCONNECT:
hw_var_set_mlme_disconnect(adapter);
break;
case HW_VAR_MLME_SITESURVEY:
hw_var_set_mlme_sitesurvey(adapter, *val);
#ifdef CONFIG_BT_COEXIST
if (hal_data->EEPROMBluetoothCoexist == 1)
rtw_btcoex_ScanNotify(adapter, *val ? _TRUE : _FALSE);
#endif
break;
case HW_VAR_MLME_JOIN:
hw_var_set_mlme_join(adapter, *val);
#ifdef CONFIG_BT_COEXIST
if (hal_data->EEPROMBluetoothCoexist == 1) {
switch (*val) {
case 0:
/* Notify coex. mechanism before join */
rtw_btcoex_ConnectNotify(adapter, _TRUE);
break;
case 1:
case 2:
/* Notify coex. mechanism after join, whether successful or failed */
rtw_btcoex_ConnectNotify(adapter, _FALSE);
break;
}
}
#endif /* CONFIG_BT_COEXIST */
break;
case HW_VAR_EN_HW_UPDATE_TSF:
rtw_hal_set_hw_update_tsf(adapter);
break;
case HW_VAR_CORRECT_TSF:
hw_var_set_correct_tsf(adapter, *val);
break;
#if defined(CONFIG_HW_P0_TSF_SYNC) && defined(CONFIG_CONCURRENT_MODE)
case HW_VAR_TSF_AUTO_SYNC:
if (*val == _TRUE)
hw_port0_tsf_sync_sel(adapter, _TRUE, adapter->hw_port, 50);
else
hw_port0_tsf_sync_sel(adapter, _FALSE, adapter->hw_port, 50);
break;
#endif
case HW_VAR_APFM_ON_MAC:
hal_data->bMacPwrCtrlOn = *val;
RTW_INFO("%s: bMacPwrCtrlOn=%d\n", __func__, hal_data->bMacPwrCtrlOn);
break;
#ifdef CONFIG_WMMPS_STA
case HW_VAR_UAPSD_TID:
rtw_hal_update_uapsd_tid(adapter);
break;
#endif /* CONFIG_WMMPS_STA */
#ifdef CONFIG_LPS_PG
case HW_VAR_LPS_PG_HANDLE:
rtw_hal_lps_pg_handler(adapter, *val);
break;
#endif
#ifdef CONFIG_LPS_LCLK_WD_TIMER
case HW_VAR_DM_IN_LPS_LCLK:
rtw_phydm_wd_lps_lclk_hdl(adapter);
break;
#endif
case HW_VAR_ENABLE_RX_BAR:
if (*val == _TRUE) {
/* enable RX BAR */
u16 val16 = rtw_read16(adapter, REG_RXFLTMAP1);
val16 |= BIT(8);
rtw_write16(adapter, REG_RXFLTMAP1, val16);
} else {
/* disable RX BAR */
u16 val16 = rtw_read16(adapter, REG_RXFLTMAP1);
val16 &= (~BIT(8));
rtw_write16(adapter, REG_RXFLTMAP1, val16);
}
RTW_INFO("[HW_VAR_ENABLE_RX_BAR] 0x%02X=0x%02X\n",
REG_RXFLTMAP1, rtw_read16(adapter, REG_RXFLTMAP1));
break;
case HW_VAR_HCI_SUS_STATE:
hal_data->hci_sus_state = *(u8 *)val;
RTW_INFO("%s: hci_sus_state=%u\n", __func__, hal_data->hci_sus_state);
break;
#if defined(CONFIG_AP_MODE) && defined(CONFIG_FW_HANDLE_TXBCN) && defined(CONFIG_SUPPORT_MULTI_BCN)
case HW_VAR_BCN_HEAD_SEL:
{
u8 vap_id = *(u8 *)val;
if ((vap_id >= CONFIG_LIMITED_AP_NUM) && (vap_id != 0xFF)) {
RTW_ERR(ADPT_FMT " vap_id(%d:%d) is invalid\n", ADPT_ARG(adapter),vap_id, adapter->vap_id);
rtw_warn_on(1);
}
if (MLME_IS_AP(adapter) || MLME_IS_MESH(adapter)) {
u16 drv_pg_bndy = 0, bcn_addr = 0;
u32 page_size = 0;
/*rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_BOUNDARY, &drv_pg_bndy);*/
rtw_halmac_get_rsvd_drv_pg_bndy(adapter_to_dvobj(adapter), &drv_pg_bndy);
rtw_hal_get_def_var(adapter, HAL_DEF_TX_PAGE_SIZE, (u8 *)&page_size);
if (vap_id != 0xFF)
bcn_addr = drv_pg_bndy + (vap_id * (MAX_BEACON_LEN / page_size));
else
bcn_addr = drv_pg_bndy;
RTW_INFO(ADPT_FMT" vap_id(%d) change BCN HEAD to 0x%04x\n",
ADPT_ARG(adapter), vap_id, bcn_addr);
rtw_write16(adapter, REG_FIFOPAGE_CTRL_2,
(bcn_addr & BIT_MASK_BCN_HEAD_1_V1) | BIT_BCN_VALID_V1);
}
}
break;
#endif
case HW_VAR_LPS_STATE_CHK :
rtw_lps_state_chk(adapter, *(u8 *)val);
break;
#ifdef CONFIG_RTS_FULL_BW
case HW_VAR_SET_RTS_BW:
{
#ifdef RTW_HALMAC
rtw_halmac_set_rts_full_bw(adapter_to_dvobj(adapter), (*val));
#else
u8 temp;
if(*val)
temp = (( rtw_read8(adapter, REG_INIRTS_RATE_SEL)) | BIT5 );
else
temp = (( rtw_read8(adapter, REG_INIRTS_RATE_SEL)) & (~BIT5));
rtw_write8(adapter, REG_INIRTS_RATE_SEL, temp);
/*RTW_INFO("HW_VAR_SET_RTS_BW val=%u REG480=0x%x\n", *val, rtw_read8(adapter, REG_INIRTS_RATE_SEL));*/
#endif
}
break;
#endif/*CONFIG_RTS_FULL_BW*/
#if defined(CONFIG_PCI_HCI)
case HW_VAR_ENSWBCN:
if (*val == _TRUE) {
rtw_write8(adapter, REG_CR + 1,
rtw_read8(adapter, REG_CR + 1) | BIT(0));
} else
rtw_write8(adapter, REG_CR + 1,
rtw_read8(adapter, REG_CR + 1) & ~BIT(0));
break;
#endif
default:
if (0)
RTW_PRINT(FUNC_ADPT_FMT" variable(%d) not defined!\n",
FUNC_ADPT_ARG(adapter), variable);
ret = _FAIL;
break;
}
return ret;
}
void GetHwReg(_adapter *adapter, u8 variable, u8 *val)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u64 val64;
switch (variable) {
case HW_VAR_MAC_ADDR:
rtw_hal_get_macaddr_port(adapter, val);
break;
case HW_VAR_BASIC_RATE:
*((u16 *)val) = hal_data->BasicRateSet;
break;
case HW_VAR_RF_TYPE:
*((u8 *)val) = hal_data->rf_type;
#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
*((u8 *)val) = RF_1T1R;
#endif
break;
case HW_VAR_MEDIA_STATUS:
rtw_hal_get_msr(adapter, val);
break;
case HW_VAR_DO_IQK:
*val = hal_data->bNeedIQK;
break;
case HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO:
if (hal_is_band_support(adapter, BAND_ON_5G))
*val = _TRUE;
else
*val = _FALSE;
break;
case HW_VAR_APFM_ON_MAC:
*val = hal_data->bMacPwrCtrlOn;
break;
case HW_VAR_RCR:
hw_var_rcr_get(adapter, (u32 *)val);
break;
case HW_VAR_FWLPS_RF_ON:
/* When we halt NIC, we should check if FW LPS is leave. */
if (rtw_is_surprise_removed(adapter)
|| (adapter_to_pwrctl(adapter)->rf_pwrstate == rf_off)
) {
/*
* If it is in HW/SW Radio OFF or IPS state,
* we do not check Fw LPS Leave,
* because Fw is unload.
*/
*val = _TRUE;
} else {
u32 rcr = 0;
rtw_hal_get_hwreg(adapter, HW_VAR_RCR, (u8 *)&rcr);
if (rcr & (RCR_UC_MD_EN | RCR_BC_MD_EN | RCR_TIM_PARSER_EN))
*val = _FALSE;
else
*val = _TRUE;
}
break;
case HW_VAR_HCI_SUS_STATE:
*((u8 *)val) = hal_data->hci_sus_state;
break;
case HW_VAR_BCN_CTRL_ADDR:
*((u32 *)val) = hw_bcn_ctrl_addr(adapter, adapter->hw_port);
break;
#ifdef CONFIG_WAPI_SUPPORT
case HW_VAR_CAM_EMPTY_ENTRY: {
u8 ucIndex = *((u8 *)val);
u8 i;
u32 ulCommand = 0;
u32 ulContent = 0;
u32 ulEncAlgo = CAM_AES;
for (i = 0; i < CAM_CONTENT_COUNT; i++) {
/* filled id in CAM config 2 byte */
if (i == 0)
ulContent |= (ucIndex & 0x03) | ((u16)(ulEncAlgo) << 2);
else
ulContent = 0;
/* polling bit, and No Write enable, and address */
ulCommand = CAM_CONTENT_COUNT * ucIndex + i;
ulCommand = ulCommand | CAM_POLLINIG | CAM_WRITE;
/* write content 0 is equall to mark invalid */
rtw_write32(adapter, REG_CAMWRITE, ulContent); /* delay_ms(40); */
rtw_write32(adapter, REG_CAMCMD, ulCommand); /* delay_ms(40); */
}
}
#endif
default:
if (0)
RTW_PRINT(FUNC_ADPT_FMT" variable(%d) not defined!\n",
FUNC_ADPT_ARG(adapter), variable);
break;
}
}
static u32 _get_page_size(struct _ADAPTER *a)
{
#ifdef RTW_HALMAC
struct dvobj_priv *d;
u32 size = 0;
int err = 0;
d = adapter_to_dvobj(a);
err = rtw_halmac_get_page_size(d, &size);
if (!err)
return size;
RTW_WARN(FUNC_ADPT_FMT ": Fail to get Page size!!(err=%d)\n",
FUNC_ADPT_ARG(a), err);
#endif /* RTW_HALMAC */
return PAGE_SIZE_128;
}
u8
SetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 bResult = _SUCCESS;
switch (variable) {
case HAL_DEF_DBG_DUMP_RXPKT:
hal_data->bDumpRxPkt = *((u8 *)value);
break;
case HAL_DEF_DBG_DUMP_TXPKT:
hal_data->bDumpTxPkt = *((u8 *)value);
break;
case HAL_DEF_ANT_DETECT:
hal_data->AntDetection = *((u8 *)value);
break;
default:
RTW_PRINT("%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
bResult = _FAIL;
break;
}
return bResult;
}
#ifdef CONFIG_BEAMFORMING
u8 rtw_hal_query_txbfer_rf_num(_adapter *adapter)
{
struct registry_priv *pregistrypriv = &adapter->registrypriv;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
if ((pregistrypriv->beamformer_rf_num) && (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter) || IS_HARDWARE_TYPE_8822BU(adapter) || IS_HARDWARE_TYPE_8821C(adapter)))
return pregistrypriv->beamformer_rf_num;
else if (IS_HARDWARE_TYPE_8814AE(adapter)
#if 0
#if defined(CONFIG_USB_HCI)
|| (IS_HARDWARE_TYPE_8814AU(adapter) && (pUsbModeMech->CurUsbMode == 2 || pUsbModeMech->HubUsbMode == 2)) /* for USB3.0 */
#endif
#endif
) {
/*BF cap provided by Yu Chen, Sean, 2015, 01 */
if (hal_data->rf_type == RF_3T3R)
return 2;
else if (hal_data->rf_type == RF_4T4R)
return 3;
else
return 1;
} else
return 1;
}
u8 rtw_hal_query_txbfee_rf_num(_adapter *adapter)
{
struct registry_priv *pregistrypriv = &adapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
if ((pregistrypriv->beamformee_rf_num) && (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter) || IS_HARDWARE_TYPE_8822BU(adapter) || IS_HARDWARE_TYPE_8821C(adapter)))
return pregistrypriv->beamformee_rf_num;
else if (IS_HARDWARE_TYPE_8814AE(adapter) || IS_HARDWARE_TYPE_8814AU(adapter)) {
if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_BROADCOM)
return 2;
else
return 2;/*TODO: May be 3 in the future, by ChenYu. */
} else
return 1;
}
#ifdef RTW_BEAMFORMING_VERSION_2
void rtw_hal_beamforming_config_csirate(PADAPTER adapter)
{
struct dm_struct *p_dm_odm;
struct beamforming_info *bf_info;
u8 fix_rate_enable = 0;
u8 new_csi_rate_idx;
u8 rrsr_54_en;
u32 temp_rrsr;
/* Acting as BFee */
if (IS_BEAMFORMEE(adapter)) {
#if 0
/* Do not enable now because it will affect MU performance and CTS/BA rate. 2016.07.19. by tynli. [PCIE-1660] */
if (IS_HARDWARE_TYPE_8821C(Adapter))
FixRateEnable = 1; /* Support after 8821C */
#endif
p_dm_odm = adapter_to_phydm(adapter);
bf_info = GET_BEAMFORM_INFO(adapter);
rtw_halmac_bf_cfg_csi_rate(adapter_to_dvobj(adapter),
p_dm_odm->rssi_min,
bf_info->cur_csi_rpt_rate,
fix_rate_enable, &new_csi_rate_idx, &rrsr_54_en);
temp_rrsr = rtw_read32(adapter,REG_RRSR);
if(rrsr_54_en == 1)
temp_rrsr |= BIT(HALMAC_OFDM54);
else if(rrsr_54_en == 0)
temp_rrsr &= ~(BIT(HALMAC_OFDM54));
#ifdef RTW_DYNAMIC_RRSR
rtw_phydm_set_rrsr(adapter, temp_rrsr, FALSE);
#else
rtw_write32(adapter, REG_RRSR, temp_rrsr);
#endif
if (new_csi_rate_idx != bf_info->cur_csi_rpt_rate)
bf_info->cur_csi_rpt_rate = new_csi_rate_idx;
}
}
#endif
#endif
u8
GetHalDefVar(_adapter *adapter, HAL_DEF_VARIABLE variable, void *value)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 bResult = _SUCCESS;
switch (variable) {
case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB: {
struct mlme_priv *pmlmepriv;
struct sta_priv *pstapriv;
struct sta_info *psta;
pmlmepriv = &adapter->mlmepriv;
pstapriv = &adapter->stapriv;
psta = rtw_get_stainfo(pstapriv, pmlmepriv->cur_network.network.MacAddress);
if (psta)
*((int *)value) = psta->cmn.rssi_stat.rssi;
}
break;
case HAL_DEF_DBG_DUMP_RXPKT:
*((u8 *)value) = hal_data->bDumpRxPkt;
break;
case HAL_DEF_DBG_DUMP_TXPKT:
*((u8 *)value) = hal_data->bDumpTxPkt;
break;
case HAL_DEF_ANT_DETECT:
*((u8 *)value) = hal_data->AntDetection;
break;
case HAL_DEF_TX_PAGE_SIZE:
*((u32 *)value) = _get_page_size(adapter);
break;
case HAL_DEF_EXPLICIT_BEAMFORMER:
case HAL_DEF_EXPLICIT_BEAMFORMEE:
case HAL_DEF_VHT_MU_BEAMFORMER:
case HAL_DEF_VHT_MU_BEAMFORMEE:
*(u8 *)value = _FALSE;
break;
#ifdef CONFIG_BEAMFORMING
case HAL_DEF_BEAMFORMER_CAP:
*(u8 *)value = rtw_hal_query_txbfer_rf_num(adapter);
break;
case HAL_DEF_BEAMFORMEE_CAP:
*(u8 *)value = rtw_hal_query_txbfee_rf_num(adapter);
break;
#endif
default:
RTW_PRINT("%s: [WARNING] HAL_DEF_VARIABLE(%d) not defined!\n", __FUNCTION__, variable);
bResult = _FAIL;
break;
}
return bResult;
}
BOOLEAN
eqNByte(
u8 *str1,
u8 *str2,
u32 num
)
{
if (num == 0)
return _FALSE;
while (num > 0) {
num--;
if (str1[num] != str2[num])
return _FALSE;
}
return _TRUE;
}
/*
* Description:
* Translate a character to hex digit.
* */
u32
MapCharToHexDigit(
char chTmp
)
{
if (chTmp >= '0' && chTmp <= '9')
return chTmp - '0';
else if (chTmp >= 'a' && chTmp <= 'f')
return 10 + (chTmp - 'a');
else if (chTmp >= 'A' && chTmp <= 'F')
return 10 + (chTmp - 'A');
else
return 0;
}
/*
* Description:
* Parse hex number from the string pucStr.
* */
BOOLEAN
GetHexValueFromString(
char *szStr,
u32 *pu4bVal,
u32 *pu4bMove
)
{
char *szScan = szStr;
/* Check input parameter. */
if (szStr == NULL || pu4bVal == NULL || pu4bMove == NULL) {
RTW_INFO("GetHexValueFromString(): Invalid inpur argumetns! szStr: %p, pu4bVal: %p, pu4bMove: %p\n", szStr, pu4bVal, pu4bMove);
return _FALSE;
}
/* Initialize output. */
*pu4bMove = 0;
*pu4bVal = 0;
/* Skip leading space. */
while (*szScan != '\0' &&
(*szScan == ' ' || *szScan == '\t')) {
szScan++;
(*pu4bMove)++;
}
/* Skip leading '0x' or '0X'. */
if (*szScan == '0' && (*(szScan + 1) == 'x' || *(szScan + 1) == 'X')) {
szScan += 2;
(*pu4bMove) += 2;
}
/* Check if szScan is now pointer to a character for hex digit, */
/* if not, it means this is not a valid hex number. */
if (!IsHexDigit(*szScan))
return _FALSE;
/* Parse each digit. */
do {
(*pu4bVal) <<= 4;
*pu4bVal += MapCharToHexDigit(*szScan);
szScan++;
(*pu4bMove)++;
} while (IsHexDigit(*szScan));
return _TRUE;
}
BOOLEAN
GetFractionValueFromString(
char *szStr,
u8 *pInteger,
u8 *pFraction,
u32 *pu4bMove
)
{
char *szScan = szStr;
/* Initialize output. */
*pu4bMove = 0;
*pInteger = 0;
*pFraction = 0;
/* Skip leading space. */
while (*szScan != '\0' && (*szScan == ' ' || *szScan == '\t')) {
++szScan;
++(*pu4bMove);
}
if (*szScan < '0' || *szScan > '9')
return _FALSE;
/* Parse each digit. */
do {
(*pInteger) *= 10;
*pInteger += (*szScan - '0');
++szScan;
++(*pu4bMove);
if (*szScan == '.') {
++szScan;
++(*pu4bMove);
if (*szScan < '0' || *szScan > '9')
return _FALSE;
*pFraction += (*szScan - '0') * 10;
++szScan;
++(*pu4bMove);
if (*szScan >= '0' && *szScan <= '9') {
*pFraction += *szScan - '0';
++szScan;
++(*pu4bMove);
}
return _TRUE;
}
} while (*szScan >= '0' && *szScan <= '9');
return _TRUE;
}
/*
* Description:
* Return TRUE if szStr is comment out with leading " */ /* ".
* */
BOOLEAN
IsCommentString(
char *szStr
)
{
if (*szStr == '/' && *(szStr + 1) == '/')
return _TRUE;
else
return _FALSE;
}
BOOLEAN
GetU1ByteIntegerFromStringInDecimal(
char *Str,
u8 *pInt
)
{
u16 i = 0;
*pInt = 0;
while (Str[i] != '\0') {
if (Str[i] >= '0' && Str[i] <= '9') {
*pInt *= 10;
*pInt += (Str[i] - '0');
} else
return _FALSE;
++i;
}
return _TRUE;
}
/* <20121004, Kordan> For example,
* ParseQualifiedString(inString, 0, outString, '[', ']') gets "Kordan" from a string "Hello [Kordan]".
* If RightQualifier does not exist, it will hang on in the while loop */
BOOLEAN
ParseQualifiedString(
char *In,
u32 *Start,
char *Out,
char LeftQualifier,
char RightQualifier
)
{
u32 i = 0, j = 0;
char c = In[(*Start)++];
if (c != LeftQualifier)
return _FALSE;
i = (*Start);
c = In[(*Start)++];
while (c != RightQualifier && c != '\0')
c = In[(*Start)++];
if (c == '\0')
return _FALSE;
j = (*Start) - 2;
strncpy((char *)Out, (const char *)(In + i), j - i + 1);
return _TRUE;
}
BOOLEAN
isAllSpaceOrTab(
u8 *data,
u8 size
)
{
u8 cnt = 0, NumOfSpaceAndTab = 0;
while (size > cnt) {
if (data[cnt] == ' ' || data[cnt] == '\t' || data[cnt] == '\0')
++NumOfSpaceAndTab;
++cnt;
}
return size == NumOfSpaceAndTab;
}
void rtw_hal_check_rxfifo_full(_adapter *adapter)
{
struct dvobj_priv *psdpriv = adapter->dvobj;
struct debug_priv *pdbgpriv = &psdpriv->drv_dbg;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
struct registry_priv *regsty = &adapter->registrypriv;
int save_cnt = _FALSE;
if (regsty->check_hw_status == 1) {
/* switch counter to RX fifo */
if (IS_8188E(pHalData->version_id) ||
IS_8188F(pHalData->version_id) ||
IS_8188GTV(pHalData->version_id) ||
IS_8812_SERIES(pHalData->version_id) ||
IS_8821_SERIES(pHalData->version_id) ||
IS_8723B_SERIES(pHalData->version_id) ||
IS_8192E(pHalData->version_id) ||
IS_8703B_SERIES(pHalData->version_id) ||
IS_8723D_SERIES(pHalData->version_id) ||
IS_8192F_SERIES(pHalData->version_id)) {
rtw_write8(adapter, REG_RXERR_RPT + 3, rtw_read8(adapter, REG_RXERR_RPT + 3) | 0xa0);
save_cnt = _TRUE;
} else {
/* todo: other chips */
}
if (save_cnt) {
pdbgpriv->dbg_rx_fifo_last_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow;
pdbgpriv->dbg_rx_fifo_curr_overflow = rtw_read16(adapter, REG_RXERR_RPT);
pdbgpriv->dbg_rx_fifo_diff_overflow = pdbgpriv->dbg_rx_fifo_curr_overflow - pdbgpriv->dbg_rx_fifo_last_overflow;
} else {
/* special value to indicate no implementation */
pdbgpriv->dbg_rx_fifo_last_overflow = 1;
pdbgpriv->dbg_rx_fifo_curr_overflow = 1;
pdbgpriv->dbg_rx_fifo_diff_overflow = 1;
}
}
}
void linked_info_dump(_adapter *padapter, u8 benable)
{
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(padapter);
if (padapter->bLinkInfoDump == benable)
return;
RTW_INFO("%s %s\n", __FUNCTION__, (benable) ? "enable" : "disable");
if (benable) {
#ifdef CONFIG_LPS
pwrctrlpriv->org_power_mgnt = pwrctrlpriv->power_mgnt;/* keep org value */
rtw_pm_set_lps(padapter, PS_MODE_ACTIVE);
#endif
#ifdef CONFIG_IPS
pwrctrlpriv->ips_org_mode = pwrctrlpriv->ips_mode;/* keep org value */
rtw_pm_set_ips(padapter, IPS_NONE);
#endif
} else {
#ifdef CONFIG_IPS
rtw_pm_set_ips(padapter, pwrctrlpriv->ips_org_mode);
#endif /* CONFIG_IPS */
#ifdef CONFIG_LPS
rtw_pm_set_lps(padapter, pwrctrlpriv->org_power_mgnt);
#endif /* CONFIG_LPS */
}
padapter->bLinkInfoDump = benable ;
}
#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
void rtw_get_raw_rssi_info(void *sel, _adapter *padapter)
{
u8 isCCKrate, rf_path;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
RTW_PRINT_SEL(sel, "RxRate = %s, PWDBALL = %d(%%), rx_pwr_all = %d(dBm)\n",
HDATA_RATE(psample_pkt_rssi->data_rate), psample_pkt_rssi->pwdball, psample_pkt_rssi->pwr_all);
isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
if (isCCKrate)
psample_pkt_rssi->mimo_signal_strength[0] = psample_pkt_rssi->pwdball;
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
RTW_PRINT_SEL(sel, "RF_PATH_%d=>signal_strength:%d(%%),signal_quality:%d(%%)\n"
, rf_path, psample_pkt_rssi->mimo_signal_strength[rf_path], psample_pkt_rssi->mimo_signal_quality[rf_path]);
if (!isCCKrate) {
RTW_PRINT_SEL(sel, "\trx_ofdm_pwr:%d(dBm),rx_ofdm_snr:%d(dB)\n",
psample_pkt_rssi->ofdm_pwr[rf_path], psample_pkt_rssi->ofdm_snr[rf_path]);
}
}
}
void rtw_dump_raw_rssi_info(_adapter *padapter, void *sel)
{
u8 isCCKrate, rf_path;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
_RTW_PRINT_SEL(sel, "============ RAW Rx Info dump ===================\n");
_RTW_PRINT_SEL(sel, "RxRate = %s, PWDBALL = %d(%%), rx_pwr_all = %d(dBm)\n", HDATA_RATE(psample_pkt_rssi->data_rate), psample_pkt_rssi->pwdball, psample_pkt_rssi->pwr_all);
isCCKrate = (psample_pkt_rssi->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
if (isCCKrate)
psample_pkt_rssi->mimo_signal_strength[0] = psample_pkt_rssi->pwdball;
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
_RTW_PRINT_SEL(sel , "RF_PATH_%d=>signal_strength:%d(%%),signal_quality:%d(%%)"
, rf_path, psample_pkt_rssi->mimo_signal_strength[rf_path], psample_pkt_rssi->mimo_signal_quality[rf_path]);
if (!isCCKrate)
_RTW_PRINT_SEL(sel , ",rx_ofdm_pwr:%d(dBm),rx_ofdm_snr:%d(dB)\n", psample_pkt_rssi->ofdm_pwr[rf_path], psample_pkt_rssi->ofdm_snr[rf_path]);
else
_RTW_PRINT_SEL(sel , "\n");
}
}
#endif
#ifdef DBG_RX_DFRAME_RAW_DATA
void rtw_dump_rx_dframe_info(_adapter *padapter, void *sel)
{
#define DBG_RX_DFRAME_RAW_DATA_UC 0
#define DBG_RX_DFRAME_RAW_DATA_BMC 1
#define DBG_RX_DFRAME_RAW_DATA_TYPES 2
_irqL irqL;
u8 isCCKrate, rf_path;
struct recv_priv *precvpriv = &(padapter->recvpriv);
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta;
struct sta_recv_dframe_info *psta_dframe_info;
int i, j;
_list *plist, *phead;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
u8 null_addr[ETH_ALEN] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
if (precvpriv->store_law_data_flag) {
_enter_critical_bh(&pstapriv->sta_hash_lock, &irqL);
for (i = 0; i < NUM_STA; i++) {
phead = &(pstapriv->sta_hash[i]);
plist = get_next(phead);
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, hash_list);
plist = get_next(plist);
if (psta) {
if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, null_addr, ETH_ALEN) != _TRUE)
&& (_rtw_memcmp(psta->cmn.mac_addr, adapter_mac_addr(padapter), ETH_ALEN) != _TRUE)) {
RTW_PRINT_SEL(sel, "==============================\n");
RTW_PRINT_SEL(sel, "macaddr =" MAC_FMT "\n", MAC_ARG(psta->cmn.mac_addr));
for (j = 0; j < DBG_RX_DFRAME_RAW_DATA_TYPES; j++) {
if (j == DBG_RX_DFRAME_RAW_DATA_UC) {
psta_dframe_info = &psta->sta_dframe_info;
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "Unicast:\n");
} else if (j == DBG_RX_DFRAME_RAW_DATA_BMC) {
psta_dframe_info = &psta->sta_dframe_info_bmc;
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "Broadcast/Multicast:\n");
}
isCCKrate = (psta_dframe_info->sta_data_rate <= DESC_RATE11M) ? TRUE : FALSE;
RTW_PRINT_SEL(sel, "BW=%s, sgi =%d\n", ch_width_str(psta_dframe_info->sta_bw_mode), psta_dframe_info->sta_sgi);
RTW_PRINT_SEL(sel, "Rx_Data_Rate = %s\n", HDATA_RATE(psta_dframe_info->sta_data_rate));
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
if (!isCCKrate) {
RTW_PRINT_SEL(sel , "RF_PATH_%d RSSI:%d(dBm)", rf_path, psta_dframe_info->sta_RxPwr[rf_path]);
_RTW_PRINT_SEL(sel , ",rx_ofdm_snr:%d(dB)\n", psta_dframe_info->sta_ofdm_snr[rf_path]);
} else
RTW_PRINT_SEL(sel , "RF_PATH_%d RSSI:%d(dBm)\n", rf_path, (psta_dframe_info->sta_mimo_signal_strength[rf_path]) - 100);
}
}
}
}
}
}
_exit_critical_bh(&pstapriv->sta_hash_lock, &irqL);
}
}
#endif
void rtw_store_phy_info(_adapter *padapter, union recv_frame *prframe)
{
u8 isCCKrate, rf_path , dframe_type;
u8 *ptr;
u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
#ifdef DBG_RX_DFRAME_RAW_DATA
struct sta_recv_dframe_info *psta_dframe_info;
#endif
struct recv_priv *precvpriv = &(padapter->recvpriv);
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
struct rx_pkt_attrib *pattrib = &prframe->u.hdr.attrib;
struct sta_info *psta = prframe->u.hdr.psta;
struct phydm_phyinfo_struct *p_phy_info = &pattrib->phy_info;
struct rx_raw_rssi *psample_pkt_rssi = &padapter->recvpriv.raw_rssi_info;
psample_pkt_rssi->data_rate = pattrib->data_rate;
ptr = prframe->u.hdr.rx_data;
dframe_type = GetFrameType(ptr);
/*RTW_INFO("=>%s\n", __FUNCTION__);*/
if (precvpriv->store_law_data_flag) {
isCCKrate = (pattrib->data_rate <= DESC_RATE11M) ? TRUE : FALSE;
psample_pkt_rssi->pwdball = p_phy_info->rx_pwdb_all;
psample_pkt_rssi->pwr_all = p_phy_info->recv_signal_power;
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
psample_pkt_rssi->mimo_signal_strength[rf_path] = p_phy_info->rx_mimo_signal_strength[rf_path];
psample_pkt_rssi->mimo_signal_quality[rf_path] = p_phy_info->rx_mimo_signal_quality[rf_path];
if (!isCCKrate) {
psample_pkt_rssi->ofdm_pwr[rf_path] = p_phy_info->rx_pwr[rf_path];
psample_pkt_rssi->ofdm_snr[rf_path] = p_phy_info->rx_snr[rf_path];
}
}
#ifdef DBG_RX_DFRAME_RAW_DATA
if ((dframe_type == WIFI_DATA_TYPE) || (dframe_type == WIFI_QOS_DATA_TYPE) || (padapter->registrypriv.mp_mode == 1)) {
/*RTW_INFO("=>%s WIFI_DATA_TYPE or WIFI_QOS_DATA_TYPE\n", __FUNCTION__);*/
if (psta) {
if (IS_MCAST(get_ra(get_recvframe_data(prframe))))
psta_dframe_info = &psta->sta_dframe_info_bmc;
else
psta_dframe_info = &psta->sta_dframe_info;
/*RTW_INFO("=>%s psta->cmn.mac_addr="MAC_FMT" !\n",
__FUNCTION__, MAC_ARG(psta->cmn.mac_addr));*/
if ((_rtw_memcmp(psta->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE) || (padapter->registrypriv.mp_mode == 1)) {
psta_dframe_info->sta_data_rate = pattrib->data_rate;
psta_dframe_info->sta_sgi = pattrib->sgi;
psta_dframe_info->sta_bw_mode = pattrib->bw;
for (rf_path = 0; rf_path < pHalData->NumTotalRFPath; rf_path++) {
psta_dframe_info->sta_mimo_signal_strength[rf_path] = (p_phy_info->rx_mimo_signal_strength[rf_path]);/*Percentage to dbm*/
if (!isCCKrate) {
psta_dframe_info->sta_ofdm_snr[rf_path] = p_phy_info->rx_snr[rf_path];
psta_dframe_info->sta_RxPwr[rf_path] = p_phy_info->rx_pwr[rf_path];
}
}
}
}
}
#endif
}
}
int hal_efuse_macaddr_offset(_adapter *adapter)
{
u8 interface_type = 0;
int addr_offset = -1;
interface_type = rtw_get_intf_type(adapter);
switch (rtw_get_chip_type(adapter)) {
#ifdef CONFIG_RTL8723B
case RTL8723B:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8723BU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8723BS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8723BE;
break;
#endif
#ifdef CONFIG_RTL8703B
case RTL8703B:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8703BU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8703BS;
break;
#endif
#ifdef CONFIG_RTL8723D
case RTL8723D:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8723DU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8723DS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8723DE;
break;
#endif
#ifdef CONFIG_RTL8188E
case RTL8188E:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_88EU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_88ES;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_88EE;
break;
#endif
#ifdef CONFIG_RTL8188F
case RTL8188F:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8188FU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8188FS;
break;
#endif
#ifdef CONFIG_RTL8188GTV
case RTL8188GTV:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8188GTVU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8188GTVS;
break;
#endif
#ifdef CONFIG_RTL8812A
case RTL8812:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8812AU;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8812AE;
break;
#endif
#ifdef CONFIG_RTL8821A
case RTL8821:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8821AU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8821AS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8821AE;
break;
#endif
#ifdef CONFIG_RTL8192E
case RTL8192E:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8192EU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8192ES;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8192EE;
break;
#endif
#ifdef CONFIG_RTL8814A
case RTL8814A:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8814AU;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8814AE;
break;
#endif
#ifdef CONFIG_RTL8822B
case RTL8822B:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8822BU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8822BS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8822BE;
break;
#endif /* CONFIG_RTL8822B */
#ifdef CONFIG_RTL8821C
case RTL8821C:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8821CU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8821CS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8821CE;
break;
#endif /* CONFIG_RTL8821C */
#ifdef CONFIG_RTL8710B
case RTL8710B:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8710B;
break;
#endif
#ifdef CONFIG_RTL8192F
case RTL8192F:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8192FU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8192FS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8192FE;
break;
#endif /* CONFIG_RTL8192F */
#ifdef CONFIG_RTL8822C
case RTL8822C:
if (interface_type == RTW_USB)
addr_offset = EEPROM_MAC_ADDR_8822CU;
else if (interface_type == RTW_SDIO)
addr_offset = EEPROM_MAC_ADDR_8822CS;
else if (interface_type == RTW_PCIE)
addr_offset = EEPROM_MAC_ADDR_8822CE;
break;
#endif /* CONFIG_RTL8822C */
}
if (addr_offset == -1) {
RTW_ERR("%s: unknown combination - chip_type:%u, interface:%u\n"
, __func__, rtw_get_chip_type(adapter), rtw_get_intf_type(adapter));
}
return addr_offset;
}
int Hal_GetPhyEfuseMACAddr(PADAPTER padapter, u8 *mac_addr)
{
int ret = _FAIL;
int addr_offset;
addr_offset = hal_efuse_macaddr_offset(padapter);
if (addr_offset == -1)
goto exit;
ret = rtw_efuse_map_read(padapter, addr_offset, ETH_ALEN, mac_addr);
exit:
return ret;
}
void rtw_dump_cur_efuse(PADAPTER padapter)
{
int i =0;
int mapsize =0;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&mapsize, _FALSE);
if (mapsize <= 0 || mapsize > EEPROM_MAX_SIZE) {
RTW_ERR("wrong map size %d\n", mapsize);
return;
}
#ifdef CONFIG_RTW_DEBUG
if (hal_data->efuse_file_status == EFUSE_FILE_LOADED)
RTW_MAP_DUMP_SEL(RTW_DBGDUMP, "EFUSE FILE", hal_data->efuse_eeprom_data, mapsize);
else
RTW_MAP_DUMP_SEL(RTW_DBGDUMP, "HW EFUSE", hal_data->efuse_eeprom_data, mapsize);
#endif
}
#ifdef CONFIG_EFUSE_CONFIG_FILE
u32 Hal_readPGDataFromConfigFile(PADAPTER padapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
u32 ret = _FALSE;
u32 maplen = 0;
EFUSE_GetEfuseDefinition(padapter, EFUSE_WIFI, TYPE_EFUSE_MAP_LEN , (void *)&maplen, _FALSE);
if (maplen < 256 || maplen > EEPROM_MAX_SIZE) {
RTW_ERR("eFuse length error :%d\n", maplen);
return _FALSE;
}
ret = rtw_read_efuse_from_file(EFUSE_MAP_PATH, hal_data->efuse_eeprom_data, maplen);
hal_data->efuse_file_status = ((ret == _FAIL) ? EFUSE_FILE_FAILED : EFUSE_FILE_LOADED);
if (hal_data->efuse_file_status == EFUSE_FILE_LOADED)
rtw_dump_cur_efuse(padapter);
return ret;
}
u32 Hal_ReadMACAddrFromFile(PADAPTER padapter, u8 *mac_addr)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
u32 ret = _FAIL;
if (rtw_read_macaddr_from_file(WIFIMAC_PATH, mac_addr) == _SUCCESS
&& rtw_check_invalid_mac_address(mac_addr, _TRUE) == _FALSE
) {
hal_data->macaddr_file_status = MACADDR_FILE_LOADED;
ret = _SUCCESS;
} else
hal_data->macaddr_file_status = MACADDR_FILE_FAILED;
return ret;
}
#endif /* CONFIG_EFUSE_CONFIG_FILE */
int hal_config_macaddr(_adapter *adapter, bool autoload_fail)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 addr[ETH_ALEN];
int addr_offset = hal_efuse_macaddr_offset(adapter);
u8 *hw_addr = NULL;
int ret = _SUCCESS;
#if defined(CONFIG_RTL8822B) && defined(CONFIG_USB_HCI)
u8 ft_mac_addr[ETH_ALEN] = {0x00, 0xff, 0xff, 0xff, 0xff, 0xff}; /* FT USB2 for 8822B */
#endif
if (autoload_fail)
goto bypass_hw_pg;
if (addr_offset != -1)
hw_addr = &hal_data->efuse_eeprom_data[addr_offset];
#ifdef CONFIG_EFUSE_CONFIG_FILE
/* if the hw_addr is written by efuse file, set to NULL */
if (hal_data->efuse_file_status == EFUSE_FILE_LOADED)
hw_addr = NULL;
#endif
if (!hw_addr) {
/* try getting hw pg data */
if (Hal_GetPhyEfuseMACAddr(adapter, addr) == _SUCCESS)
hw_addr = addr;
}
#if defined(CONFIG_RTL8822B) && defined(CONFIG_USB_HCI)
if (_rtw_memcmp(hw_addr, ft_mac_addr, ETH_ALEN))
hw_addr[0] = 0xff;
#endif
/* check hw pg data */
if (hw_addr && rtw_check_invalid_mac_address(hw_addr, _TRUE) == _FALSE) {
_rtw_memcpy(hal_data->EEPROMMACAddr, hw_addr, ETH_ALEN);
goto exit;
}
bypass_hw_pg:
#ifdef CONFIG_EFUSE_CONFIG_FILE
/* check wifi mac file */
if (Hal_ReadMACAddrFromFile(adapter, addr) == _SUCCESS) {
_rtw_memcpy(hal_data->EEPROMMACAddr, addr, ETH_ALEN);
goto exit;
}
#endif
_rtw_memset(hal_data->EEPROMMACAddr, 0, ETH_ALEN);
ret = _FAIL;
exit:
return ret;
}
#ifdef CONFIG_RF_POWER_TRIM
u32 Array_kfreemap[] = {
0x08, 0xe,
0x06, 0xc,
0x04, 0xa,
0x02, 0x8,
0x00, 0x6,
0x03, 0x4,
0x05, 0x2,
0x07, 0x0,
0x09, 0x0,
0x0c, 0x0,
};
void rtw_bb_rf_gain_offset(_adapter *padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct registry_priv *registry_par = &padapter->registrypriv;
struct kfree_data_t *kfree_data = &pHalData->kfree_data;
u8 value = pHalData->EEPROMRFGainOffset;
u8 tmp = 0x3e;
u32 res, i = 0;
u32 ArrayLen = sizeof(Array_kfreemap) / sizeof(u32);
u32 *Array = Array_kfreemap;
u32 v1 = 0, v2 = 0, GainValue = 0, target = 0;
if (registry_par->RegPwrTrimEnable == 2) {
RTW_INFO("Registry kfree default force disable.\n");
return;
}
#if defined(CONFIG_RTL8723B)
if (value & BIT4 && (registry_par->RegPwrTrimEnable == 1)) {
RTW_INFO("Offset RF Gain.\n");
RTW_INFO("Offset RF Gain. pHalData->EEPROMRFGainVal=0x%x\n", pHalData->EEPROMRFGainVal);
if (pHalData->EEPROMRFGainVal != 0xff) {
if (pHalData->ant_path == RF_PATH_A)
GainValue = (pHalData->EEPROMRFGainVal & 0x0f);
else
GainValue = (pHalData->EEPROMRFGainVal & 0xf0) >> 4;
RTW_INFO("Ant PATH_%d GainValue Offset = 0x%x\n", (pHalData->ant_path == RF_PATH_A) ? (RF_PATH_A) : (RF_PATH_B), GainValue);
for (i = 0; i < ArrayLen; i += 2) {
/* RTW_INFO("ArrayLen in =%d ,Array 1 =0x%x ,Array2 =0x%x\n",i,Array[i],Array[i]+1); */
v1 = Array[i];
v2 = Array[i + 1];
if (v1 == GainValue) {
RTW_INFO("Offset RF Gain. got v1 =0x%x ,v2 =0x%x\n", v1, v2);
target = v2;
break;
}
}
RTW_INFO("pHalData->EEPROMRFGainVal=0x%x ,Gain offset Target Value=0x%x\n", pHalData->EEPROMRFGainVal, target);
res = rtw_hal_read_rfreg(padapter, RF_PATH_A, 0x7f, 0xffffffff);
RTW_INFO("Offset RF Gain. before reg 0x7f=0x%08x\n", res);
phy_set_rf_reg(padapter, RF_PATH_A, REG_RF_BB_GAIN_OFFSET, BIT18 | BIT17 | BIT16 | BIT15, target);
res = rtw_hal_read_rfreg(padapter, RF_PATH_A, 0x7f, 0xffffffff);
RTW_INFO("Offset RF Gain. After reg 0x7f=0x%08x\n", res);
} else
RTW_INFO("Offset RF Gain. pHalData->EEPROMRFGainVal=0x%x != 0xff, didn't run Kfree\n", pHalData->EEPROMRFGainVal);
} else
RTW_INFO("Using the default RF gain.\n");
#elif defined(CONFIG_RTL8188E)
if (value & BIT4 && (registry_par->RegPwrTrimEnable == 1)) {
RTW_INFO("8188ES Offset RF Gain.\n");
RTW_INFO("8188ES Offset RF Gain. EEPROMRFGainVal=0x%x\n",
pHalData->EEPROMRFGainVal);
if (pHalData->EEPROMRFGainVal != 0xff) {
res = rtw_hal_read_rfreg(padapter, RF_PATH_A,
REG_RF_BB_GAIN_OFFSET, 0xffffffff);
RTW_INFO("Offset RF Gain. reg 0x55=0x%x\n", res);
res &= 0xfff87fff;
res |= (pHalData->EEPROMRFGainVal & 0x0f) << 15;
RTW_INFO("Offset RF Gain. res=0x%x\n", res);
rtw_hal_write_rfreg(padapter, RF_PATH_A,
REG_RF_BB_GAIN_OFFSET,
RF_GAIN_OFFSET_MASK, res);
} else {
RTW_INFO("Offset RF Gain. EEPROMRFGainVal=0x%x == 0xff, didn't run Kfree\n",
pHalData->EEPROMRFGainVal);
}
} else
RTW_INFO("Using the default RF gain.\n");
#else
/* TODO: call this when channel switch */
if (kfree_data->flag & KFREE_FLAG_ON)
rtw_rf_apply_tx_gain_offset(padapter, 6); /* input ch6 to select BB_GAIN_2G */
#endif
}
#endif /*CONFIG_RF_POWER_TRIM */
bool kfree_data_is_bb_gain_empty(struct kfree_data_t *data)
{
#ifdef CONFIG_RF_POWER_TRIM
int i, j;
for (i = 0; i < BB_GAIN_NUM; i++)
for (j = 0; j < RF_PATH_MAX; j++)
if (data->bb_gain[i][j] != 0)
return 0;
#endif
return 1;
}
#ifdef CONFIG_USB_RX_AGGREGATION
void rtw_set_usb_agg_by_mode_normal(_adapter *padapter, u8 cur_wireless_mode)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if (cur_wireless_mode < WIRELESS_11_24N
&& cur_wireless_mode > 0) { /* ABG mode */
#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
u32 remainder = 0;
u8 quotient = 0;
remainder = MAX_RECVBUF_SZ % (4 * 1024);
quotient = (u8)(MAX_RECVBUF_SZ >> 12);
if (quotient > 5) {
pHalData->rxagg_usb_size = 0x6;
pHalData->rxagg_usb_timeout = 0x10;
} else {
if (remainder >= 2048) {
pHalData->rxagg_usb_size = quotient;
pHalData->rxagg_usb_timeout = 0x10;
} else {
pHalData->rxagg_usb_size = (quotient - 1);
pHalData->rxagg_usb_timeout = 0x10;
}
}
#else /* !CONFIG_PREALLOC_RX_SKB_BUFFER */
if (0x6 != pHalData->rxagg_usb_size || 0x10 != pHalData->rxagg_usb_timeout) {
pHalData->rxagg_usb_size = 0x6;
pHalData->rxagg_usb_timeout = 0x10;
rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
}
#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
} else if (cur_wireless_mode >= WIRELESS_11_24N
&& cur_wireless_mode <= WIRELESS_MODE_MAX) { /* N AC mode */
#ifdef CONFIG_PREALLOC_RX_SKB_BUFFER
u32 remainder = 0;
u8 quotient = 0;
remainder = MAX_RECVBUF_SZ % (4 * 1024);
quotient = (u8)(MAX_RECVBUF_SZ >> 12);
if (quotient > 5) {
pHalData->rxagg_usb_size = 0x5;
pHalData->rxagg_usb_timeout = 0x20;
} else {
if (remainder >= 2048) {
pHalData->rxagg_usb_size = quotient;
pHalData->rxagg_usb_timeout = 0x10;
} else {
pHalData->rxagg_usb_size = (quotient - 1);
pHalData->rxagg_usb_timeout = 0x10;
}
}
#else /* !CONFIG_PREALLOC_RX_SKB_BUFFER */
if ((0x5 != pHalData->rxagg_usb_size) || (0x20 != pHalData->rxagg_usb_timeout)) {
pHalData->rxagg_usb_size = 0x5;
pHalData->rxagg_usb_timeout = 0x20;
rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
}
#endif /* CONFIG_PREALLOC_RX_SKB_BUFFER */
} else {
/* RTW_INFO("%s: Unknow wireless mode(0x%x)\n",__func__,padapter->mlmeextpriv.cur_wireless_mode); */
}
}
void rtw_set_usb_agg_by_mode_customer(_adapter *padapter, u8 cur_wireless_mode, u8 UsbDmaSize, u8 Legacy_UsbDmaSize)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if (cur_wireless_mode < WIRELESS_11_24N
&& cur_wireless_mode > 0) { /* ABG mode */
if (Legacy_UsbDmaSize != pHalData->rxagg_usb_size
|| 0x10 != pHalData->rxagg_usb_timeout) {
pHalData->rxagg_usb_size = Legacy_UsbDmaSize;
pHalData->rxagg_usb_timeout = 0x10;
rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
}
} else if (cur_wireless_mode >= WIRELESS_11_24N
&& cur_wireless_mode <= WIRELESS_MODE_MAX) { /* N AC mode */
if (UsbDmaSize != pHalData->rxagg_usb_size
|| 0x20 != pHalData->rxagg_usb_timeout) {
pHalData->rxagg_usb_size = UsbDmaSize;
pHalData->rxagg_usb_timeout = 0x20;
rtw_write16(padapter, REG_RXDMA_AGG_PG_TH,
pHalData->rxagg_usb_size | (pHalData->rxagg_usb_timeout << 8));
}
} else {
/* RTW_INFO("%s: Unknown wireless mode(0x%x)\n",__func__,padapter->mlmeextpriv.cur_wireless_mode); */
}
}
void rtw_set_usb_agg_by_mode(_adapter *padapter, u8 cur_wireless_mode)
{
#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
rtw_set_usb_agg_by_mode_customer(padapter, cur_wireless_mode, 0x3, 0x3);
return;
#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
rtw_set_usb_agg_by_mode_normal(padapter, cur_wireless_mode);
}
#endif /* CONFIG_USB_RX_AGGREGATION */
/* To avoid RX affect TX throughput */
void dm_DynamicUsbTxAgg(_adapter *padapter, u8 from_timer)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct registry_priv *registry_par = &padapter->registrypriv;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 cur_wireless_mode = WIRELESS_INVALID;
#ifdef CONFIG_USB_RX_AGGREGATION
if (!registry_par->dynamic_agg_enable)
return;
#ifdef RTW_HALMAC
if (IS_HARDWARE_TYPE_8822BU(padapter) || IS_HARDWARE_TYPE_8821CU(padapter) || IS_HARDWARE_TYPE_8822CU(padapter))
rtw_hal_set_hwreg(padapter, HW_VAR_RXDMA_AGG_PG_TH, NULL);
#else /* !RTW_HALMAC */
if (IS_HARDWARE_TYPE_8821U(padapter)) { /* || IS_HARDWARE_TYPE_8192EU(padapter)) */
/* This AGG_PH_TH only for UsbRxAggMode == USB_RX_AGG_USB */
if ((pHalData->rxagg_mode == RX_AGG_USB) && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
if (pdvobjpriv->traffic_stat.cur_tx_tp > 2 && pdvobjpriv->traffic_stat.cur_rx_tp < 30)
rtw_write16(padapter , REG_RXDMA_AGG_PG_TH , 0x1010);
else if (pdvobjpriv->traffic_stat.last_tx_bytes > 220000 && pdvobjpriv->traffic_stat.cur_rx_tp < 30)
rtw_write16(padapter , REG_RXDMA_AGG_PG_TH , 0x1006);
else
rtw_write16(padapter, REG_RXDMA_AGG_PG_TH, 0x2005); /* dmc agg th 20K */
/* RTW_INFO("TX_TP=%u, RX_TP=%u\n", pdvobjpriv->traffic_stat.cur_tx_tp, pdvobjpriv->traffic_stat.cur_rx_tp); */
}
} else if (IS_HARDWARE_TYPE_8812(padapter)) {
#ifdef CONFIG_CONCURRENT_MODE
u8 i;
_adapter *iface;
u8 bassocaed = _FALSE;
struct mlme_ext_priv *mlmeext;
for (i = 0; i < pdvobjpriv->iface_nums; i++) {
iface = pdvobjpriv->padapters[i];
mlmeext = &iface->mlmeextpriv;
if (rtw_linked_check(iface) == _TRUE) {
if (mlmeext->cur_wireless_mode >= cur_wireless_mode)
cur_wireless_mode = mlmeext->cur_wireless_mode;
bassocaed = _TRUE;
}
}
if (bassocaed)
#endif
rtw_set_usb_agg_by_mode(padapter, cur_wireless_mode);
#ifdef CONFIG_PLATFORM_NOVATEK_NT72668
} else {
rtw_set_usb_agg_by_mode(padapter, cur_wireless_mode);
#endif /* CONFIG_PLATFORM_NOVATEK_NT72668 */
}
#endif /* RTW_HALMAC */
#endif /* CONFIG_USB_RX_AGGREGATION */
}
/* bus-agg check for SoftAP mode */
inline u8 rtw_hal_busagg_qsel_check(_adapter *padapter, u8 pre_qsel, u8 next_qsel)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
u8 chk_rst = _SUCCESS;
if (!MLME_IS_AP(padapter) && !MLME_IS_MESH(padapter))
return chk_rst;
/* if((pre_qsel == 0xFF)||(next_qsel== 0xFF)) */
/* return chk_rst; */
if (((pre_qsel == QSLT_HIGH) || ((next_qsel == QSLT_HIGH)))
&& (pre_qsel != next_qsel)) {
/* RTW_INFO("### bus-agg break cause of qsel misatch, pre_qsel=0x%02x,next_qsel=0x%02x ###\n", */
/* pre_qsel,next_qsel); */
chk_rst = _FAIL;
}
return chk_rst;
}
/*
* Description:
* dump_TX_FIFO: This is only used to dump TX_FIFO for debug WoW mode offload
* contant.
*
* Input:
* adapter: adapter pointer.
* page_num: The max. page number that user want to dump.
* page_size: page size of each page. eg. 128 bytes, 256 bytes, 512byte.
*/
void dump_TX_FIFO(_adapter *padapter, u8 page_num, u16 page_size)
{
int i;
u8 val = 0;
u8 base = 0;
u32 addr = 0;
u32 count = (page_size / 8);
if (page_num <= 0) {
RTW_INFO("!!%s: incorrect input page_num paramter!\n", __func__);
return;
}
if (page_size < 128 || page_size > 512) {
RTW_INFO("!!%s: incorrect input page_size paramter!\n", __func__);
return;
}
RTW_INFO("+%s+\n", __func__);
val = rtw_read8(padapter, 0x106);
rtw_write8(padapter, 0x106, 0x69);
RTW_INFO("0x106: 0x%02x\n", val);
base = rtw_read8(padapter, 0x209);
RTW_INFO("0x209: 0x%02x\n", base);
addr = ((base)*page_size) / 8;
for (i = 0 ; i < page_num * count ; i += 2) {
rtw_write32(padapter, 0x140, addr + i);
printk(" %08x %08x ", rtw_read32(padapter, 0x144), rtw_read32(padapter, 0x148));
rtw_write32(padapter, 0x140, addr + i + 1);
printk(" %08x %08x\n", rtw_read32(padapter, 0x144), rtw_read32(padapter, 0x148));
}
}
#ifdef CONFIG_GPIO_API
u8 rtw_hal_get_gpio(_adapter *adapter, u8 gpio_num)
{
u8 value = 0;
u8 direction = 0;
u32 gpio_pin_input_val = REG_GPIO_PIN_CTRL;
u32 gpio_pin_output_val = REG_GPIO_PIN_CTRL + 1;
u32 gpio_pin_output_en = REG_GPIO_PIN_CTRL + 2;
u8 gpio_num_to_set = gpio_num;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
if (rtw_hal_gpio_func_check(adapter, gpio_num) == _FAIL)
return value;
rtw_ps_deny(adapter, PS_DENY_IOCTL);
RTW_INFO("rf_pwrstate=0x%02x\n", pwrpriv->rf_pwrstate);
LeaveAllPowerSaveModeDirect(adapter);
if (gpio_num > 7) {
gpio_pin_input_val = REG_GPIO_PIN_CTRL_2;
gpio_pin_output_val = REG_GPIO_PIN_CTRL_2 + 1;
gpio_pin_output_en = REG_GPIO_PIN_CTRL_2 + 2;
gpio_num_to_set = gpio_num - 8;
}
/* Read GPIO Direction */
direction = (rtw_read8(adapter, gpio_pin_output_en) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
/* According the direction to read register value */
if (direction)
value = (rtw_read8(adapter, gpio_pin_output_val) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
else
value = (rtw_read8(adapter, gpio_pin_input_val) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
RTW_INFO("%s direction=%d value=%d\n", __FUNCTION__, direction, value);
return value;
}
int rtw_hal_set_gpio_output_value(_adapter *adapter, u8 gpio_num, bool isHigh)
{
u8 direction = 0;
u8 res = -1;
u32 gpio_pin_output_val = REG_GPIO_PIN_CTRL + 1;
u32 gpio_pin_output_en = REG_GPIO_PIN_CTRL + 2;
u8 gpio_num_to_set = gpio_num;
if (rtw_hal_gpio_func_check(adapter, gpio_num) == _FAIL)
return -1;
rtw_ps_deny(adapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(adapter);
if (gpio_num > 7) {
gpio_pin_output_val = REG_GPIO_PIN_CTRL_2 + 1;
gpio_pin_output_en = REG_GPIO_PIN_CTRL_2 + 2;
gpio_num_to_set = gpio_num - 8;
}
/* Read GPIO direction */
direction = (rtw_read8(adapter, gpio_pin_output_en) & BIT(gpio_num_to_set)) >> gpio_num_to_set;
/* If GPIO is output direction, setting value. */
if (direction) {
if (isHigh)
rtw_write8(adapter, gpio_pin_output_val, rtw_read8(adapter, gpio_pin_output_val) | BIT(gpio_num_to_set));
else
rtw_write8(adapter, gpio_pin_output_val, rtw_read8(adapter, gpio_pin_output_val) & ~BIT(gpio_num_to_set));
RTW_INFO("%s Set gpio %x[%d]=%d\n", __FUNCTION__, REG_GPIO_PIN_CTRL + 1, gpio_num, isHigh);
res = 0;
} else {
RTW_INFO("%s The gpio is input,not be set!\n", __FUNCTION__);
res = -1;
}
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
return res;
}
int rtw_hal_config_gpio(_adapter *adapter, u8 gpio_num, bool isOutput)
{
u32 gpio_ctrl_reg_to_set = REG_GPIO_PIN_CTRL + 2;
u8 gpio_num_to_set = gpio_num;
if (rtw_hal_gpio_func_check(adapter, gpio_num) == _FAIL)
return -1;
RTW_INFO("%s gpio_num =%d direction=%d\n", __FUNCTION__, gpio_num, isOutput);
rtw_ps_deny(adapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(adapter);
rtw_hal_gpio_multi_func_reset(adapter, gpio_num);
if (gpio_num > 7) {
gpio_ctrl_reg_to_set = REG_GPIO_PIN_CTRL_2 + 2;
gpio_num_to_set = gpio_num - 8;
}
if (isOutput)
rtw_write8(adapter, gpio_ctrl_reg_to_set, rtw_read8(adapter, gpio_ctrl_reg_to_set) | BIT(gpio_num_to_set));
else
rtw_write8(adapter, gpio_ctrl_reg_to_set, rtw_read8(adapter, gpio_ctrl_reg_to_set) & ~BIT(gpio_num_to_set));
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
return 0;
}
int rtw_hal_register_gpio_interrupt(_adapter *adapter, int gpio_num, void(*callback)(u8 level))
{
u8 value;
u8 direction;
PHAL_DATA_TYPE phal = GET_HAL_DATA(adapter);
if (IS_HARDWARE_TYPE_8188E(adapter)) {
if (gpio_num > 7 || gpio_num < 4) {
RTW_PRINT("%s The gpio number does not included 4~7.\n", __FUNCTION__);
return -1;
}
}
rtw_ps_deny(adapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(adapter);
/* Read GPIO direction */
direction = (rtw_read8(adapter, REG_GPIO_PIN_CTRL + 2) & BIT(gpio_num)) >> gpio_num;
if (direction) {
RTW_PRINT("%s Can't register output gpio as interrupt.\n", __FUNCTION__);
return -1;
}
/* Config GPIO Mode */
rtw_write8(adapter, REG_GPIO_PIN_CTRL + 3, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 3) | BIT(gpio_num));
/* Register GPIO interrupt handler*/
adapter->gpiointpriv.callback[gpio_num] = callback;
/* Set GPIO interrupt mode, 0:positive edge, 1:negative edge */
value = rtw_read8(adapter, REG_GPIO_PIN_CTRL) & BIT(gpio_num);
adapter->gpiointpriv.interrupt_mode = rtw_read8(adapter, REG_HSIMR + 2) ^ value;
rtw_write8(adapter, REG_GPIO_INTM, adapter->gpiointpriv.interrupt_mode);
/* Enable GPIO interrupt */
adapter->gpiointpriv.interrupt_enable_mask = rtw_read8(adapter, REG_HSIMR + 2) | BIT(gpio_num);
rtw_write8(adapter, REG_HSIMR + 2, adapter->gpiointpriv.interrupt_enable_mask);
rtw_hal_update_hisr_hsisr_ind(adapter, 1);
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
return 0;
}
int rtw_hal_disable_gpio_interrupt(_adapter *adapter, int gpio_num)
{
u8 value;
u8 direction;
PHAL_DATA_TYPE phal = GET_HAL_DATA(adapter);
if (IS_HARDWARE_TYPE_8188E(adapter)) {
if (gpio_num > 7 || gpio_num < 4) {
RTW_INFO("%s The gpio number does not included 4~7.\n", __FUNCTION__);
return -1;
}
}
rtw_ps_deny(adapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(adapter);
/* Config GPIO Mode */
rtw_write8(adapter, REG_GPIO_PIN_CTRL + 3, rtw_read8(adapter, REG_GPIO_PIN_CTRL + 3) & ~BIT(gpio_num));
/* Unregister GPIO interrupt handler*/
adapter->gpiointpriv.callback[gpio_num] = NULL;
/* Reset GPIO interrupt mode, 0:positive edge, 1:negative edge */
adapter->gpiointpriv.interrupt_mode = rtw_read8(adapter, REG_GPIO_INTM) & ~BIT(gpio_num);
rtw_write8(adapter, REG_GPIO_INTM, 0x00);
/* Disable GPIO interrupt */
adapter->gpiointpriv.interrupt_enable_mask = rtw_read8(adapter, REG_HSIMR + 2) & ~BIT(gpio_num);
rtw_write8(adapter, REG_HSIMR + 2, adapter->gpiointpriv.interrupt_enable_mask);
if (!adapter->gpiointpriv.interrupt_enable_mask)
rtw_hal_update_hisr_hsisr_ind(adapter, 0);
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
return 0;
}
#endif
s8 rtw_hal_ch_sw_iqk_info_search(_adapter *padapter, u8 central_chnl, u8 bw_mode)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 i;
for (i = 0; i < MAX_IQK_INFO_BACKUP_CHNL_NUM; i++) {
if ((pHalData->iqk_reg_backup[i].central_chnl != 0)) {
if ((pHalData->iqk_reg_backup[i].central_chnl == central_chnl)
&& (pHalData->iqk_reg_backup[i].bw_mode == bw_mode))
return i;
}
}
return -1;
}
void rtw_hal_ch_sw_iqk_info_backup(_adapter *padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
s8 res;
u8 i;
/* If it's an existed record, overwrite it */
res = rtw_hal_ch_sw_iqk_info_search(padapter, pHalData->current_channel, pHalData->current_channel_bw);
if ((res >= 0) && (res < MAX_IQK_INFO_BACKUP_CHNL_NUM)) {
rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_BACKUP, (u8 *)&(pHalData->iqk_reg_backup[res]));
return;
}
/* Search for the empty record to use */
for (i = 0; i < MAX_IQK_INFO_BACKUP_CHNL_NUM; i++) {
if (pHalData->iqk_reg_backup[i].central_chnl == 0) {
rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_BACKUP, (u8 *)&(pHalData->iqk_reg_backup[i]));
return;
}
}
/* Else, overwrite the oldest record */
for (i = 1; i < MAX_IQK_INFO_BACKUP_CHNL_NUM; i++)
_rtw_memcpy(&(pHalData->iqk_reg_backup[i - 1]), &(pHalData->iqk_reg_backup[i]), sizeof(struct hal_iqk_reg_backup));
rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_BACKUP, (u8 *)&(pHalData->iqk_reg_backup[MAX_IQK_INFO_BACKUP_CHNL_NUM - 1]));
}
void rtw_hal_ch_sw_iqk_info_restore(_adapter *padapter, u8 ch_sw_use_case)
{
rtw_hal_set_hwreg(padapter, HW_VAR_CH_SW_IQK_INFO_RESTORE, &ch_sw_use_case);
}
void rtw_dump_mac_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)
{
u32 mac_cck_ok = 0, mac_ofdm_ok = 0, mac_ht_ok = 0, mac_vht_ok = 0;
u32 mac_cck_err = 0, mac_ofdm_err = 0, mac_ht_err = 0, mac_vht_err = 0;
u32 mac_cck_fa = 0, mac_ofdm_fa = 0, mac_ht_fa = 0;
u32 DropPacket = 0;
if (!rx_counter) {
rtw_warn_on(1);
return;
}
if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter))
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x0);/*clear bit-26*/
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x3);
mac_cck_ok = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x0);
mac_ofdm_ok = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x6);
mac_ht_ok = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
mac_vht_ok = 0;
if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x0);
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x1);
mac_vht_ok = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]*/
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x0);/*clear bit-26*/
}
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x4);
mac_cck_err = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x1);
mac_ofdm_err = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x7);
mac_ht_err = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
mac_vht_err = 0;
if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x1);
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x1);
mac_vht_err = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0]*/
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT26, 0x0);/*clear bit-26*/
}
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x5);
mac_cck_fa = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x2);
mac_ofdm_fa = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT28 | BIT29 | BIT30 | BIT31, 0x9);
mac_ht_fa = phy_query_mac_reg(padapter, REG_RXERR_RPT, bMaskLWord);/* [15:0] */
/* Mac_DropPacket */
rtw_write32(padapter, REG_RXERR_RPT, (rtw_read32(padapter, REG_RXERR_RPT) & 0x0FFFFFFF) | Mac_DropPacket);
DropPacket = rtw_read32(padapter, REG_RXERR_RPT) & 0x0000FFFF;
rx_counter->rx_pkt_ok = mac_cck_ok + mac_ofdm_ok + mac_ht_ok + mac_vht_ok;
rx_counter->rx_pkt_crc_error = mac_cck_err + mac_ofdm_err + mac_ht_err + mac_vht_err;
rx_counter->rx_cck_fa = mac_cck_fa;
rx_counter->rx_ofdm_fa = mac_ofdm_fa;
rx_counter->rx_ht_fa = mac_ht_fa;
rx_counter->rx_pkt_drop = DropPacket;
}
void rtw_reset_mac_rx_counters(_adapter *padapter)
{
/* If no packet rx, MaxRx clock be gating ,BIT_DISGCLK bit19 set 1 for fix*/
if (IS_HARDWARE_TYPE_8703B(padapter) ||
IS_HARDWARE_TYPE_8723D(padapter) ||
IS_HARDWARE_TYPE_8188F(padapter) ||
IS_HARDWARE_TYPE_8188GTV(padapter) ||
IS_HARDWARE_TYPE_8192F(padapter) ||
IS_HARDWARE_TYPE_8822C(padapter))
phy_set_mac_reg(padapter, REG_RCR, BIT19, 0x1);
/* reset mac counter */
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT27, 0x1);
phy_set_mac_reg(padapter, REG_RXERR_RPT, BIT27, 0x0);
}
void rtw_dump_phy_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)
{
u32 cckok = 0, cckcrc = 0, ofdmok = 0, ofdmcrc = 0, htok = 0, htcrc = 0, OFDM_FA = 0, CCK_FA = 0, vht_ok = 0, vht_err = 0;
if (!rx_counter) {
rtw_warn_on(1);
return;
}
if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
cckok = phy_query_bb_reg(padapter, 0xF04, 0x3FFF); /* [13:0] */
ofdmok = phy_query_bb_reg(padapter, 0xF14, 0x3FFF); /* [13:0] */
htok = phy_query_bb_reg(padapter, 0xF10, 0x3FFF); /* [13:0] */
vht_ok = phy_query_bb_reg(padapter, 0xF0C, 0x3FFF); /* [13:0] */
cckcrc = phy_query_bb_reg(padapter, 0xF04, 0x3FFF0000); /* [29:16] */
ofdmcrc = phy_query_bb_reg(padapter, 0xF14, 0x3FFF0000); /* [29:16] */
htcrc = phy_query_bb_reg(padapter, 0xF10, 0x3FFF0000); /* [29:16] */
vht_err = phy_query_bb_reg(padapter, 0xF0C, 0x3FFF0000); /* [29:16] */
CCK_FA = phy_query_bb_reg(padapter, 0xA5C, bMaskLWord);
OFDM_FA = phy_query_bb_reg(padapter, 0xF48, bMaskLWord);
} else if(IS_HARDWARE_TYPE_JAGUAR3(padapter)){
cckok = phy_query_bb_reg(padapter, 0x2c04, 0xffff);
ofdmok = phy_query_bb_reg(padapter, 0x2c14, 0xffff);
htok = phy_query_bb_reg(padapter, 0x2c10, 0xffff);
vht_ok = phy_query_bb_reg(padapter, 0x2c0c, 0xffff);
cckcrc = phy_query_bb_reg(padapter, 0x2c04, 0xffff0000);
ofdmcrc = phy_query_bb_reg(padapter, 0x2c14, 0xffff0000);
htcrc = phy_query_bb_reg(padapter, 0x2c10, 0xffff0000);
vht_err = phy_query_bb_reg(padapter, 0x2c0c, 0xffff0000);
CCK_FA = phy_query_bb_reg(padapter, 0x1a5c, bMaskLWord);
OFDM_FA = phy_query_bb_reg(padapter, 0x2d00, bMaskLWord) - phy_query_bb_reg(padapter, 0x2de0, bMaskLWord);
} else {
cckok = phy_query_bb_reg(padapter, 0xF88, bMaskDWord);
ofdmok = phy_query_bb_reg(padapter, 0xF94, bMaskLWord);
htok = phy_query_bb_reg(padapter, 0xF90, bMaskLWord);
vht_ok = 0;
cckcrc = phy_query_bb_reg(padapter, 0xF84, bMaskDWord);
ofdmcrc = phy_query_bb_reg(padapter, 0xF94, bMaskHWord);
htcrc = phy_query_bb_reg(padapter, 0xF90, bMaskHWord);
vht_err = 0;
OFDM_FA = phy_query_bb_reg(padapter, 0xCF0, bMaskLWord) + phy_query_bb_reg(padapter, 0xCF2, bMaskLWord) +
phy_query_bb_reg(padapter, 0xDA2, bMaskLWord) + phy_query_bb_reg(padapter, 0xDA4, bMaskLWord) +
phy_query_bb_reg(padapter, 0xDA6, bMaskLWord) + phy_query_bb_reg(padapter, 0xDA8, bMaskLWord);
CCK_FA = (rtw_read8(padapter, 0xA5B) << 8) | (rtw_read8(padapter, 0xA5C));
}
rx_counter->rx_pkt_ok = cckok + ofdmok + htok + vht_ok;
rx_counter->rx_pkt_crc_error = cckcrc + ofdmcrc + htcrc + vht_err;
rx_counter->rx_ofdm_fa = OFDM_FA;
rx_counter->rx_cck_fa = CCK_FA;
}
void rtw_reset_phy_trx_ok_counters(_adapter *padapter)
{
if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
phy_set_bb_reg(padapter, 0xB58, BIT0, 0x1);
phy_set_bb_reg(padapter, 0xB58, BIT0, 0x0);
} else if(IS_HARDWARE_TYPE_JAGUAR3(padapter)) {
phy_set_bb_reg(padapter, 0x1EB4, BIT25, 0x1);
phy_set_bb_reg(padapter, 0x1EB4, BIT25, 0x0);
} else {
phy_set_bb_reg(padapter, 0xF14, BIT16, 0x1);
phy_set_bb_reg(padapter, 0xF14, BIT16, 0x0);
}
}
void rtw_reset_phy_rx_counters(_adapter *padapter)
{
/* reset phy counter */
if (IS_HARDWARE_TYPE_JAGUAR3(padapter)) {
/* reset CCK FA counter */
phy_set_bb_reg(padapter, 0x1a2c, BIT(15) | BIT(14), 0);
phy_set_bb_reg(padapter, 0x1a2c, BIT(15) | BIT(14), 2);
/* reset CCK CCA counter */
phy_set_bb_reg(padapter, 0x1a2c, BIT(13) | BIT(12), 0);
phy_set_bb_reg(padapter, 0x1a2c, BIT(13) | BIT(12), 2);
rtw_reset_phy_trx_ok_counters(padapter);
} else if (IS_HARDWARE_TYPE_JAGUAR(padapter) || IS_HARDWARE_TYPE_JAGUAR2(padapter)) {
rtw_reset_phy_trx_ok_counters(padapter);
phy_set_bb_reg(padapter, 0x9A4, BIT17, 0x1);/* reset OFDA FA counter */
phy_set_bb_reg(padapter, 0x9A4, BIT17, 0x0);
phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x0);/* reset CCK FA counter */
phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x1);
} else {
phy_set_bb_reg(padapter, 0xF14, BIT16, 0x1);
rtw_msleep_os(10);
phy_set_bb_reg(padapter, 0xF14, BIT16, 0x0);
phy_set_bb_reg(padapter, 0xD00, BIT27, 0x1);/* reset OFDA FA counter */
phy_set_bb_reg(padapter, 0xC0C, BIT31, 0x1);/* reset OFDA FA counter */
phy_set_bb_reg(padapter, 0xD00, BIT27, 0x0);
phy_set_bb_reg(padapter, 0xC0C, BIT31, 0x0);
phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x0);/* reset CCK FA counter */
phy_set_bb_reg(padapter, 0xA2C, BIT15, 0x1);
}
}
#ifdef DBG_RX_COUNTER_DUMP
void rtw_dump_drv_rx_counters(_adapter *padapter, struct dbg_rx_counter *rx_counter)
{
struct recv_priv *precvpriv = &padapter->recvpriv;
if (!rx_counter) {
rtw_warn_on(1);
return;
}
rx_counter->rx_pkt_ok = padapter->drv_rx_cnt_ok;
rx_counter->rx_pkt_crc_error = padapter->drv_rx_cnt_crcerror;
rx_counter->rx_pkt_drop = precvpriv->rx_drop - padapter->drv_rx_cnt_drop;
}
void rtw_reset_drv_rx_counters(_adapter *padapter)
{
struct recv_priv *precvpriv = &padapter->recvpriv;
padapter->drv_rx_cnt_ok = 0;
padapter->drv_rx_cnt_crcerror = 0;
padapter->drv_rx_cnt_drop = precvpriv->rx_drop;
}
void rtw_dump_phy_rxcnts_preprocess(_adapter *padapter, u8 rx_cnt_mode)
{
u8 initialgain;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
if ((!(padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER)) && (rx_cnt_mode & DUMP_PHY_RX_COUNTER)) {
rtw_hal_get_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, NULL);
RTW_INFO("%s CurIGValue:0x%02x\n", __FUNCTION__, initialgain);
rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);
/*disable dynamic functions, such as high power, DIG*/
rtw_phydm_ability_backup(padapter);
rtw_phydm_func_clr(padapter, (ODM_BB_DIG | ODM_BB_FA_CNT));
} else if ((padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER) && (!(rx_cnt_mode & DUMP_PHY_RX_COUNTER))) {
/* turn on phy-dynamic functions */
rtw_phydm_ability_restore(padapter);
initialgain = 0xff; /* restore RX GAIN */
rtw_hal_set_odm_var(padapter, HAL_ODM_INITIAL_GAIN, &initialgain, _FALSE);
}
}
void rtw_dump_rx_counters(_adapter *padapter)
{
struct dbg_rx_counter rx_counter;
if (padapter->dump_rx_cnt_mode & DUMP_DRV_RX_COUNTER) {
_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
rtw_dump_drv_rx_counters(padapter, &rx_counter);
RTW_INFO("Drv Received packet OK:%d CRC error:%d Drop Packets: %d\n",
rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error, rx_counter.rx_pkt_drop);
rtw_reset_drv_rx_counters(padapter);
}
if (padapter->dump_rx_cnt_mode & DUMP_MAC_RX_COUNTER) {
_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
rtw_dump_mac_rx_counters(padapter, &rx_counter);
RTW_INFO("Mac Received packet OK:%d CRC error:%d FA Counter: %d Drop Packets: %d\n",
rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error,
rx_counter.rx_cck_fa + rx_counter.rx_ofdm_fa + rx_counter.rx_ht_fa,
rx_counter.rx_pkt_drop);
rtw_reset_mac_rx_counters(padapter);
}
if (padapter->dump_rx_cnt_mode & DUMP_PHY_RX_COUNTER) {
_rtw_memset(&rx_counter, 0, sizeof(struct dbg_rx_counter));
rtw_dump_phy_rx_counters(padapter, &rx_counter);
/* RTW_INFO("%s: OFDM_FA =%d\n", __FUNCTION__, rx_counter.rx_ofdm_fa); */
/* RTW_INFO("%s: CCK_FA =%d\n", __FUNCTION__, rx_counter.rx_cck_fa); */
RTW_INFO("Phy Received packet OK:%d CRC error:%d FA Counter: %d\n", rx_counter.rx_pkt_ok, rx_counter.rx_pkt_crc_error,
rx_counter.rx_ofdm_fa + rx_counter.rx_cck_fa);
rtw_reset_phy_rx_counters(padapter);
}
}
#endif
u8 rtw_get_current_tx_sgi(_adapter *padapter, struct sta_info *psta)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
u8 curr_tx_sgi = 0;
struct ra_sta_info *ra_info;
if (!psta)
return curr_tx_sgi;
if (padapter->fix_rate == 0xff) {
#if defined(CONFIG_RTL8188E)
#if (RATE_ADAPTIVE_SUPPORT == 1)
curr_tx_sgi = hal_data->odmpriv.ra_info[psta->cmn.mac_id].rate_sgi;
#endif /* (RATE_ADAPTIVE_SUPPORT == 1)*/
#else
ra_info = &psta->cmn.ra_info;
curr_tx_sgi = ((ra_info->curr_tx_rate) & 0x80) >> 7;
#endif
} else {
curr_tx_sgi = ((padapter->fix_rate) & 0x80) >> 7;
}
return curr_tx_sgi;
}
u8 rtw_get_current_tx_rate(_adapter *padapter, struct sta_info *psta)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
u8 rate_id = 0;
struct ra_sta_info *ra_info;
if (!psta)
return rate_id;
if (padapter->fix_rate == 0xff) {
#if defined(CONFIG_RTL8188E)
#if (RATE_ADAPTIVE_SUPPORT == 1)
rate_id = hal_data->odmpriv.ra_info[psta->cmn.mac_id].decision_rate;
#endif /* (RATE_ADAPTIVE_SUPPORT == 1)*/
#else
ra_info = &psta->cmn.ra_info;
rate_id = ra_info->curr_tx_rate & 0x7f;
#endif
} else {
rate_id = padapter->fix_rate & 0x7f;
}
return rate_id;
}
void update_IOT_info(_adapter *padapter)
{
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
switch (pmlmeinfo->assoc_AP_vendor) {
case HT_IOT_PEER_MARVELL:
pmlmeinfo->turboMode_cts2self = 1;
pmlmeinfo->turboMode_rtsen = 0;
break;
case HT_IOT_PEER_RALINK:
pmlmeinfo->turboMode_cts2self = 0;
pmlmeinfo->turboMode_rtsen = 1;
break;
case HT_IOT_PEER_REALTEK:
/* rtw_write16(padapter, 0x4cc, 0xffff); */
/* rtw_write16(padapter, 0x546, 0x01c0); */
break;
default:
pmlmeinfo->turboMode_cts2self = 0;
pmlmeinfo->turboMode_rtsen = 1;
break;
}
}
#ifdef CONFIG_RTS_FULL_BW
/*
8188E: not support full RTS BW feature(mac REG no define 480[5])
*/
void rtw_set_rts_bw(_adapter *padapter) {
int i;
u8 enable = 1;
bool connect_to_8812 = _FALSE;
u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
struct sta_info *station = NULL;
for (i = 0; i < macid_ctl->num; i++) {
if (rtw_macid_is_used(macid_ctl, i)) {
station = NULL;
station = macid_ctl->sta[i];
if(station) {
_adapter *sta_adapter =station->padapter;
struct mlme_ext_priv *pmlmeext = &(sta_adapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
if ( pmlmeinfo->state != WIFI_FW_NULL_STATE) {
if(_rtw_memcmp(macid_ctl->sta[i]->cmn.mac_addr, bc_addr, ETH_ALEN) != _TRUE) {
if ( macid_ctl->sta[i]->vendor_8812) {
connect_to_8812 = _TRUE;
enable = 0;
}
}
}
}
}
if(connect_to_8812)
break;
}
RTW_INFO("%s connect_to_8812=%d,enable=%u\n", __FUNCTION__,connect_to_8812,enable);
rtw_hal_set_hwreg(padapter, HW_VAR_SET_RTS_BW, &enable);
}
#endif/*CONFIG_RTS_FULL_BW*/
int hal_spec_init(_adapter *adapter)
{
u8 interface_type = 0;
int ret = _SUCCESS;
interface_type = rtw_get_intf_type(adapter);
switch (rtw_get_chip_type(adapter)) {
#ifdef CONFIG_RTL8723B
case RTL8723B:
init_hal_spec_8723b(adapter);
break;
#endif
#ifdef CONFIG_RTL8703B
case RTL8703B:
init_hal_spec_8703b(adapter);
break;
#endif
#ifdef CONFIG_RTL8723D
case RTL8723D:
init_hal_spec_8723d(adapter);
break;
#endif
#ifdef CONFIG_RTL8188E
case RTL8188E:
init_hal_spec_8188e(adapter);
break;
#endif
#ifdef CONFIG_RTL8188F
case RTL8188F:
init_hal_spec_8188f(adapter);
break;
#endif
#ifdef CONFIG_RTL8188GTV
case RTL8188GTV:
init_hal_spec_8188gtv(adapter);
break;
#endif
#ifdef CONFIG_RTL8812A
case RTL8812:
init_hal_spec_8812a(adapter);
break;
#endif
#ifdef CONFIG_RTL8821A
case RTL8821:
init_hal_spec_8821a(adapter);
break;
#endif
#ifdef CONFIG_RTL8192E
case RTL8192E:
init_hal_spec_8192e(adapter);
break;
#endif
#ifdef CONFIG_RTL8814A
case RTL8814A:
init_hal_spec_8814a(adapter);
break;
#endif
#ifdef CONFIG_RTL8822B
case RTL8822B:
rtl8822b_init_hal_spec(adapter);
break;
#endif
#ifdef CONFIG_RTL8821C
case RTL8821C:
init_hal_spec_rtl8821c(adapter);
break;
#endif
#ifdef CONFIG_RTL8710B
case RTL8710B:
init_hal_spec_8710b(adapter);
break;
#endif
#ifdef CONFIG_RTL8192F
case RTL8192F:
init_hal_spec_8192f(adapter);
break;
#endif
#ifdef CONFIG_RTL8822C
case RTL8822C:
rtl8822c_init_hal_spec(adapter);
break;
#endif
default:
RTW_ERR("%s: unknown chip_type:%u\n"
, __func__, rtw_get_chip_type(adapter));
ret = _FAIL;
break;
}
return ret;
}
static const char *const _band_cap_str[] = {
/* BIT0 */"2G",
/* BIT1 */"5G",
};
static const char *const _bw_cap_str[] = {
/* BIT0 */"5M",
/* BIT1 */"10M",
/* BIT2 */"20M",
/* BIT3 */"40M",
/* BIT4 */"80M",
/* BIT5 */"160M",
/* BIT6 */"80_80M",
};
static const char *const _proto_cap_str[] = {
/* BIT0 */"b",
/* BIT1 */"g",
/* BIT2 */"n",
/* BIT3 */"ac",
};
static const char *const _wl_func_str[] = {
/* BIT0 */"P2P",
/* BIT1 */"MIRACAST",
/* BIT2 */"TDLS",
/* BIT3 */"FTM",
};
void dump_hal_spec(void *sel, _adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
int i;
RTW_PRINT_SEL(sel, "macid_num:%u\n", hal_spec->macid_num);
RTW_PRINT_SEL(sel, "sec_cap:0x%02x\n", hal_spec->sec_cap);
RTW_PRINT_SEL(sel, "sec_cam_ent_num:%u\n", hal_spec->sec_cam_ent_num);
RTW_PRINT_SEL(sel, "rfpath_num_2g:%u\n", hal_spec->rfpath_num_2g);
RTW_PRINT_SEL(sel, "rfpath_num_5g:%u\n", hal_spec->rfpath_num_5g);
RTW_PRINT_SEL(sel, "txgi_max:%u\n", hal_spec->txgi_max);
RTW_PRINT_SEL(sel, "txgi_pdbm:%u\n", hal_spec->txgi_pdbm);
RTW_PRINT_SEL(sel, "max_tx_cnt:%u\n", hal_spec->max_tx_cnt);
RTW_PRINT_SEL(sel, "tx_nss_num:%u\n", hal_spec->tx_nss_num);
RTW_PRINT_SEL(sel, "rx_nss_num:%u\n", hal_spec->rx_nss_num);
RTW_PRINT_SEL(sel, "band_cap:");
for (i = 0; i < BAND_CAP_BIT_NUM; i++) {
if (((hal_spec->band_cap) >> i) & BIT0 && _band_cap_str[i])
_RTW_PRINT_SEL(sel, "%s ", _band_cap_str[i]);
}
_RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "bw_cap:");
for (i = 0; i < BW_CAP_BIT_NUM; i++) {
if (((hal_spec->bw_cap) >> i) & BIT0 && _bw_cap_str[i])
_RTW_PRINT_SEL(sel, "%s ", _bw_cap_str[i]);
}
_RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "proto_cap:");
for (i = 0; i < PROTO_CAP_BIT_NUM; i++) {
if (((hal_spec->proto_cap) >> i) & BIT0 && _proto_cap_str[i])
_RTW_PRINT_SEL(sel, "%s ", _proto_cap_str[i]);
}
_RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "wl_func:");
for (i = 0; i < WL_FUNC_BIT_NUM; i++) {
if (((hal_spec->wl_func) >> i) & BIT0 && _wl_func_str[i])
_RTW_PRINT_SEL(sel, "%s ", _wl_func_str[i]);
}
_RTW_PRINT_SEL(sel, "\n");
#if CONFIG_TX_AC_LIFETIME
RTW_PRINT_SEL(sel, "tx_aclt_unit_factor:%u (unit:%uus)\n"
, hal_spec->tx_aclt_unit_factor, hal_spec->tx_aclt_unit_factor * 32);
#endif
RTW_PRINT_SEL(sel, "rx_tsf_filter:%u\n", hal_spec->rx_tsf_filter);
RTW_PRINT_SEL(sel, "pg_txpwr_saddr:0x%X\n", hal_spec->pg_txpwr_saddr);
RTW_PRINT_SEL(sel, "pg_txgi_diff_factor:%u\n", hal_spec->pg_txgi_diff_factor);
}
inline bool hal_chk_band_cap(_adapter *adapter, u8 cap)
{
return GET_HAL_SPEC(adapter)->band_cap & cap;
}
inline bool hal_chk_bw_cap(_adapter *adapter, u8 cap)
{
return GET_HAL_SPEC(adapter)->bw_cap & cap;
}
inline bool hal_chk_proto_cap(_adapter *adapter, u8 cap)
{
return GET_HAL_SPEC(adapter)->proto_cap & cap;
}
inline bool hal_chk_wl_func(_adapter *adapter, u8 func)
{
return GET_HAL_SPEC(adapter)->wl_func & func;
}
inline bool hal_is_band_support(_adapter *adapter, u8 band)
{
return GET_HAL_SPEC(adapter)->band_cap & band_to_band_cap(band);
}
inline bool hal_is_bw_support(_adapter *adapter, u8 bw)
{
return GET_HAL_SPEC(adapter)->bw_cap & ch_width_to_bw_cap(bw);
}
inline bool hal_is_wireless_mode_support(_adapter *adapter, u8 mode)
{
u8 proto_cap = GET_HAL_SPEC(adapter)->proto_cap;
if (mode == WIRELESS_11B)
if ((proto_cap & PROTO_CAP_11B) && hal_chk_band_cap(adapter, BAND_CAP_2G))
return 1;
if (mode == WIRELESS_11G)
if ((proto_cap & PROTO_CAP_11G) && hal_chk_band_cap(adapter, BAND_CAP_2G))
return 1;
if (mode == WIRELESS_11A)
if ((proto_cap & PROTO_CAP_11G) && hal_chk_band_cap(adapter, BAND_CAP_5G))
return 1;
if (mode == WIRELESS_11_24N)
if ((proto_cap & PROTO_CAP_11N) && hal_chk_band_cap(adapter, BAND_CAP_2G))
return 1;
if (mode == WIRELESS_11_5N)
if ((proto_cap & PROTO_CAP_11N) && hal_chk_band_cap(adapter, BAND_CAP_5G))
return 1;
if (mode == WIRELESS_11AC)
if ((proto_cap & PROTO_CAP_11AC) && hal_chk_band_cap(adapter, BAND_CAP_5G))
return 1;
return 0;
}
inline bool hal_is_mimo_support(_adapter *adapter)
{
if ((GET_HAL_SPEC(adapter)->tx_nss_num == 1) &&
(GET_HAL_SPEC(adapter)->rx_nss_num == 1))
return 0;
return 1;
}
/*
* hal_largest_bw - starting from in_bw, get largest bw supported by HAL
* @adapter:
* @in_bw: starting bw, value of enum channel_width
*
* Returns: value of enum channel_width
*/
u8 hal_largest_bw(_adapter *adapter, u8 in_bw)
{
for (; in_bw > CHANNEL_WIDTH_20; in_bw--) {
if (hal_is_bw_support(adapter, in_bw))
break;
}
if (!hal_is_bw_support(adapter, in_bw))
rtw_warn_on(1);
return in_bw;
}
void ResumeTxBeacon(_adapter *padapter)
{
rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2) | BIT(6));
#ifdef RTW_HALMAC
/* Add this for driver using HALMAC because driver doesn't have setup time init by self */
/* TBTT setup time */
rtw_write8(padapter, REG_TBTT_PROHIBIT, TBTT_PROHIBIT_SETUP_TIME);
#endif
/* TBTT hold time: 0x540[19:8] */
rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME & 0xFF);
rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME >> 8));
}
void StopTxBeacon(_adapter *padapter)
{
rtw_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
rtw_read8(padapter, REG_FWHW_TXQ_CTRL + 2) & (~BIT6));
/* TBTT hold time: 0x540[19:8] */
rtw_write8(padapter, REG_TBTT_PROHIBIT + 1, TBTT_PROHIBIT_HOLD_TIME_STOP_BCN & 0xFF);
rtw_write8(padapter, REG_TBTT_PROHIBIT + 2,
(rtw_read8(padapter, REG_TBTT_PROHIBIT + 2) & 0xF0) | (TBTT_PROHIBIT_HOLD_TIME_STOP_BCN >> 8));
}
#ifdef CONFIG_MI_WITH_MBSSID_CAM /*HW port0 - MBSS*/
#ifdef CONFIG_CLIENT_PORT_CFG
const u8 _clt_port_id[MAX_CLIENT_PORT_NUM] = {
CLT_PORT0,
CLT_PORT1,
CLT_PORT2,
CLT_PORT3
};
void rtw_clt_port_init(struct clt_port_t *cltp)
{
cltp->bmp = 0;
cltp->num = 0;
_rtw_spinlock_init(&cltp->lock);
}
void rtw_clt_port_deinit(struct clt_port_t *cltp)
{
_rtw_spinlock_free(&cltp->lock);
}
static void _hw_client_port_alloc(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct clt_port_t *cltp = &dvobj->clt_port;
_irqL irql;
int i;
#if 0
if (cltp->num > MAX_CLIENT_PORT_NUM) {
RTW_ERR(ADPT_FMT" cann't alloc client (%d)\n", ADPT_ARG(adapter), cltp->num);
rtw_warn_on(1);
return;
}
#endif
if (adapter->client_id != MAX_CLIENT_PORT_NUM) {
RTW_INFO(ADPT_FMT" client_id %d has allocated port:%d\n",
ADPT_ARG(adapter), adapter->client_id, adapter->client_port);
return;
}
_enter_critical_bh(&cltp->lock, &irql);
for (i = 0; i < MAX_CLIENT_PORT_NUM; i++) {
if (!(cltp->bmp & BIT(i)))
break;
}
if (i < MAX_CLIENT_PORT_NUM) {
adapter->client_id = i;
cltp->bmp |= BIT(i);
adapter->client_port = _clt_port_id[i];
}
cltp->num++;
_exit_critical_bh(&cltp->lock, &irql);
RTW_INFO("%s("ADPT_FMT")id:%d, port:%d clt_num:%d\n",
__func__, ADPT_ARG(adapter), adapter->client_id, adapter->client_port, cltp->num);
}
static void _hw_client_port_free(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct clt_port_t *cltp = &dvobj->clt_port;
_irqL irql;
#if 0
if (adapter->client_id >= MAX_CLIENT_PORT_NUM) {
RTW_ERR(ADPT_FMT" client_id %d is invalid\n", ADPT_ARG(adapter), adapter->client_id);
/*rtw_warn_on(1);*/
}
#endif
RTW_INFO("%s ("ADPT_FMT") id:%d, port:%d clt_num:%d\n",
__func__, ADPT_ARG(adapter), adapter->client_id, adapter->client_port, cltp->num);
_enter_critical_bh(&cltp->lock, &irql);
if (adapter->client_id != MAX_CLIENT_PORT_NUM) {
cltp->bmp &= ~ BIT(adapter->client_id);
adapter->client_id = MAX_CLIENT_PORT_NUM;
adapter->client_port = CLT_PORT_INVALID;
}
cltp->num--;
if (cltp->num < 0)
cltp->num = 0;
_exit_critical_bh(&cltp->lock, &irql);
}
void rtw_hw_client_port_allocate(_adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
if (hal_spec->port_num != 5)
return;
_hw_client_port_alloc(adapter);
}
void rtw_hw_client_port_release(_adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
if (hal_spec->port_num != 5)
return;
_hw_client_port_free(adapter);
}
#endif /*CONFIG_CLIENT_PORT_CFG*/
void hw_var_set_opmode_mbid(_adapter *Adapter, u8 mode)
{
RTW_INFO("%s()-"ADPT_FMT" mode = %d\n", __func__, ADPT_ARG(Adapter), mode);
rtw_hal_rcr_set_chk_bssid(Adapter, MLME_ACTION_NONE);
/* set net_type */
Set_MSR(Adapter, mode);
if ((mode == _HW_STATE_STATION_) || (mode == _HW_STATE_NOLINK_)) {
if (!rtw_mi_get_ap_num(Adapter) && !rtw_mi_get_mesh_num(Adapter))
StopTxBeacon(Adapter);
} else if (mode == _HW_STATE_ADHOC_)
ResumeTxBeacon(Adapter);
else if (mode == _HW_STATE_AP_)
/* enable rx ps-poll */
rtw_write16(Adapter, REG_RXFLTMAP1, rtw_read16(Adapter, REG_RXFLTMAP1) | BIT_CTRLFLT10EN);
/* enable rx data frame */
rtw_write16(Adapter, REG_RXFLTMAP2, 0xFFFF);
#ifdef CONFIG_CLIENT_PORT_CFG
if (mode == _HW_STATE_STATION_)
rtw_hw_client_port_allocate(Adapter);
else
rtw_hw_client_port_release(Adapter);
#endif
#if defined(CONFIG_RTL8192F)
rtw_write16(Adapter, REG_WLAN_ACT_MASK_CTRL_1, rtw_read16(Adapter,
REG_WLAN_ACT_MASK_CTRL_1) | EN_PORT_0_FUNCTION);
#endif
}
#endif
#ifdef CONFIG_ANTENNA_DIVERSITY
u8 rtw_hal_antdiv_before_linked(_adapter *padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
u8 cur_ant, change_ant;
if (!pHalData->AntDivCfg)
return _FALSE;
if (pHalData->sw_antdiv_bl_state == 0) {
pHalData->sw_antdiv_bl_state = 1;
rtw_hal_get_odm_var(padapter, HAL_ODM_ANTDIV_SELECT, &cur_ant, NULL);
change_ant = (cur_ant == MAIN_ANT) ? AUX_ANT : MAIN_ANT;
return rtw_antenna_select_cmd(padapter, change_ant, _FALSE);
}
pHalData->sw_antdiv_bl_state = 0;
return _FALSE;
}
void rtw_hal_antdiv_rssi_compared(_adapter *padapter, WLAN_BSSID_EX *dst, WLAN_BSSID_EX *src)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if (pHalData->AntDivCfg) {
/*RTW_INFO("update_network=> org-RSSI(%d), new-RSSI(%d)\n", dst->Rssi, src->Rssi);*/
/*select optimum_antenna for before linked =>For antenna diversity*/
if (dst->Rssi >= src->Rssi) {/*keep org parameter*/
src->Rssi = dst->Rssi;
src->PhyInfo.Optimum_antenna = dst->PhyInfo.Optimum_antenna;
}
}
}
#endif
#ifdef CONFIG_PHY_CAPABILITY_QUERY
void rtw_dump_phy_cap_by_phydmapi(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(adapter);
struct phy_spec_t *phy_spec = &pHalData->phy_spec;
RTW_PRINT_SEL(sel, "[PHY SPEC] TRx Capability : 0x%08x\n", phy_spec->trx_cap);
RTW_PRINT_SEL(sel, "[PHY SPEC] Tx Stream Num Index : %d\n", (phy_spec->trx_cap >> 24) & 0xFF); /*Tx Stream Num Index [31:24]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] Rx Stream Num Index : %d\n", (phy_spec->trx_cap >> 16) & 0xFF); /*Rx Stream Num Index [23:16]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] Tx Path Num Index : %d\n", (phy_spec->trx_cap >> 8) & 0xFF);/*Tx Path Num Index [15:8]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] Rx Path Num Index : %d\n\n", (phy_spec->trx_cap & 0xFF));/*Rx Path Num Index [7:0]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] STBC Capability : 0x%08x\n", phy_spec->stbc_cap);
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT STBC Tx : %s\n", ((phy_spec->stbc_cap >> 24) & 0xFF) ? "Supported" : "N/A"); /*VHT STBC Tx [31:24]*/
/*VHT STBC Rx [23:16]
0 = not support
1 = support for 1 spatial stream
2 = support for 1 or 2 spatial streams
3 = support for 1 or 2 or 3 spatial streams
4 = support for 1 or 2 or 3 or 4 spatial streams*/
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT STBC Rx :%d\n", ((phy_spec->stbc_cap >> 16) & 0xFF));
RTW_PRINT_SEL(sel, "[PHY SPEC] HT STBC Tx : %s\n", ((phy_spec->stbc_cap >> 8) & 0xFF) ? "Supported" : "N/A"); /*HT STBC Tx [15:8]*/
/*HT STBC Rx [7:0]
0 = not support
1 = support for 1 spatial stream
2 = support for 1 or 2 spatial streams
3 = support for 1 or 2 or 3 spatial streams*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT STBC Rx : %d\n\n", (phy_spec->stbc_cap & 0xFF));
RTW_PRINT_SEL(sel, "[PHY SPEC] LDPC Capability : 0x%08x\n", phy_spec->ldpc_cap);
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT LDPC Tx : %s\n", ((phy_spec->ldpc_cap >> 24) & 0xFF) ? "Supported" : "N/A"); /*VHT LDPC Tx [31:24]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT LDPC Rx : %s\n", ((phy_spec->ldpc_cap >> 16) & 0xFF) ? "Supported" : "N/A"); /*VHT LDPC Rx [23:16]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT LDPC Tx : %s\n", ((phy_spec->ldpc_cap >> 8) & 0xFF) ? "Supported" : "N/A"); /*HT LDPC Tx [15:8]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT LDPC Rx : %s\n\n", (phy_spec->ldpc_cap & 0xFF) ? "Supported" : "N/A"); /*HT LDPC Rx [7:0]*/
#ifdef CONFIG_BEAMFORMING
RTW_PRINT_SEL(sel, "[PHY SPEC] TxBF Capability : 0x%08x\n", phy_spec->txbf_cap);
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT MU Bfer : %s\n", ((phy_spec->txbf_cap >> 28) & 0xF) ? "Supported" : "N/A"); /*VHT MU Bfer [31:28]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT MU Bfee : %s\n", ((phy_spec->txbf_cap >> 24) & 0xF) ? "Supported" : "N/A"); /*VHT MU Bfee [27:24]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT SU Bfer : %s\n", ((phy_spec->txbf_cap >> 20) & 0xF) ? "Supported" : "N/A"); /*VHT SU Bfer [23:20]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT SU Bfee : %s\n", ((phy_spec->txbf_cap >> 16) & 0xF) ? "Supported" : "N/A"); /*VHT SU Bfee [19:16]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT Bfer : %s\n", ((phy_spec->txbf_cap >> 4) & 0xF) ? "Supported" : "N/A"); /*HT Bfer [7:4]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT Bfee : %s\n\n", (phy_spec->txbf_cap & 0xF) ? "Supported" : "N/A"); /*HT Bfee [3:0]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] TxBF parameter : 0x%08x\n", phy_spec->txbf_param);
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT Sounding Dim : %d\n", (phy_spec->txbf_param >> 24) & 0xFF); /*VHT Sounding Dim [31:24]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] VHT Steering Ant : %d\n", (phy_spec->txbf_param >> 16) & 0xFF); /*VHT Steering Ant [23:16]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT Sounding Dim : %d\n", (phy_spec->txbf_param >> 8) & 0xFF); /*HT Sounding Dim [15:8]*/
RTW_PRINT_SEL(sel, "[PHY SPEC] HT Steering Ant : %d\n", phy_spec->txbf_param & 0xFF); /*HT Steering Ant [7:0]*/
#endif
}
#else
void rtw_dump_phy_cap_by_hal(void *sel, _adapter *adapter)
{
u8 phy_cap = _FALSE;
/* STBC */
rtw_hal_get_def_var(adapter, HAL_DEF_TX_STBC, (u8 *)&phy_cap);
RTW_PRINT_SEL(sel, "[HAL] STBC Tx : %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_RX_STBC, (u8 *)&phy_cap);
RTW_PRINT_SEL(sel, "[HAL] STBC Rx : %s\n\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
/* LDPC support */
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_TX_LDPC, (u8 *)&phy_cap);
RTW_PRINT_SEL(sel, "[HAL] LDPC Tx : %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_RX_LDPC, (u8 *)&phy_cap);
RTW_PRINT_SEL(sel, "[HAL] LDPC Rx : %s\n\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
#ifdef CONFIG_BEAMFORMING
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_EXPLICIT_BEAMFORMER, (u8 *)&phy_cap);
RTW_PRINT_SEL(sel, "[HAL] Beamformer: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_EXPLICIT_BEAMFORMEE, (u8 *)&phy_cap);
RTW_PRINT_SEL(sel, "[HAL] Beamformee: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_VHT_MU_BEAMFORMER, &phy_cap);
RTW_PRINT_SEL(sel, "[HAL] VHT MU Beamformer: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
phy_cap = _FALSE;
rtw_hal_get_def_var(adapter, HAL_DEF_VHT_MU_BEAMFORMEE, &phy_cap);
RTW_PRINT_SEL(sel, "[HAL] VHT MU Beamformee: %s\n", (_TRUE == phy_cap) ? "Supported" : "N/A");
#endif
}
#endif
void rtw_dump_phy_cap(void *sel, _adapter *adapter)
{
RTW_PRINT_SEL(sel, "\n ======== PHY Capability ========\n");
#ifdef CONFIG_PHY_CAPABILITY_QUERY
rtw_dump_phy_cap_by_phydmapi(sel, adapter);
#else
rtw_dump_phy_cap_by_hal(sel, adapter);
#endif
}
inline s16 translate_dbm_to_percentage(s16 signal)
{
if ((signal <= -100) || (signal >= 20))
return 0;
else if (signal >= 0)
return 100;
else
return 100 + signal;
}
#ifdef CONFIG_SWTIMER_BASED_TXBCN
#ifdef CONFIG_BCN_RECOVERY
#define REG_CPU_MGQ_INFO 0x041C
#define BIT_BCN_POLL BIT(28)
u8 rtw_ap_bcn_recovery(_adapter *padapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
if (hal_data->issue_bcn_fail >= 2) {
RTW_ERR("%s ISSUE BCN Fail\n", __func__);
rtw_write8(padapter, REG_CPU_MGQ_INFO + 3, 0x10);
hal_data->issue_bcn_fail = 0;
}
return _SUCCESS;
}
#endif /*CONFIG_BCN_RECOVERY*/
#ifdef CONFIG_BCN_XMIT_PROTECT
u8 rtw_ap_bcn_queue_empty_check(_adapter *padapter, u32 txbcn_timer_ms)
{
u32 start_time = rtw_get_current_time();
u8 bcn_queue_empty = _FALSE;
do {
if (rtw_read16(padapter, REG_TXPKT_EMPTY) & BIT(11)) {
bcn_queue_empty = _TRUE;
break;
}
} while (rtw_get_passing_time_ms(start_time) <= (txbcn_timer_ms + 10));
if (bcn_queue_empty == _FALSE)
RTW_ERR("%s BCN queue not empty\n", __func__);
return bcn_queue_empty;
}
#endif /*CONFIG_BCN_XMIT_PROTECT*/
#endif /*CONFIG_SWTIMER_BASED_TXBCN*/
static void _rf_type_to_ant_path(enum rf_type rf, enum bb_path *tx,
enum bb_path *rx)
{
if (tx) {
switch (rf) {
case RF_1T1R:
case RF_1T2R:
*tx = BB_PATH_A;
break;
case RF_2T2R:
case RF_2T3R:
case RF_2T4R:
*tx = BB_PATH_AB;
break;
case RF_3T3R:
case RF_3T4R:
*tx = BB_PATH_ABC;
break;
case RF_4T4R:
default:
*tx = BB_PATH_ABCD;
break;
}
}
if (rx) {
switch (rf) {
case RF_1T1R:
*rx = BB_PATH_A;
break;
case RF_1T2R:
case RF_2T2R:
*rx = BB_PATH_AB;
break;
case RF_2T3R:
case RF_3T3R:
*rx = BB_PATH_ABC;
break;
case RF_2T4R:
case RF_3T4R:
case RF_4T4R:
default:
*rx = BB_PATH_ABCD;
break;
}
}
}
/**
* rtw_hal_get_rf_path() - Get RF path related information
* @d: struct dvobj_priv*
* @type: RF type, nTnR
* @tx: Tx path
* @rx: Rx path
*
* Get RF type, TX path and RX path information.
*/
void rtw_hal_get_rf_path(struct dvobj_priv *d, enum rf_type *type,
enum bb_path *tx, enum bb_path *rx)
{
struct _ADAPTER *a;
u8 val8 = RF_1T1R;
enum rf_type rf;
a = dvobj_get_primary_adapter(d);
#ifndef CONFIG_CUSTOMER01_SMART_ANTENNA
rtw_hal_get_hwreg(a, HW_VAR_RF_TYPE, &val8);
#else
val8 = RF_2T2R;
#endif
rf = (enum rf_type)val8;
if (type)
*type = rf;
if (tx || rx)
_rf_type_to_ant_path(rf, tx, rx);
}
#ifdef RTW_CHANNEL_SWITCH_OFFLOAD
void rtw_hal_switch_chnl_and_set_bw_offload(_adapter *adapter, u8 central_ch, u8 pri_ch_idx, u8 bw)
{
u8 h2c[H2C_SINGLE_CHANNELSWITCH_V2_LEN] = {0};
PHAL_DATA_TYPE hal;
struct submit_ctx *chsw_sctx;
hal = GET_HAL_DATA(adapter);
chsw_sctx = &hal->chsw_sctx;
SET_H2CCMD_SINGLE_CH_SWITCH_V2_CENTRAL_CH_NUM(h2c, central_ch);
SET_H2CCMD_SINGLE_CH_SWITCH_V2_PRIMARY_CH_IDX(h2c, pri_ch_idx);
SET_H2CCMD_SINGLE_CH_SWITCH_V2_BW(h2c, bw);
rtw_sctx_init(chsw_sctx, 10);
rtw_hal_fill_h2c_cmd(adapter, H2C_SINGLE_CHANNELSWITCH_V2, H2C_SINGLE_CHANNELSWITCH_V2_LEN, h2c);
rtw_sctx_wait(chsw_sctx, __func__);
}
#endif /* RTW_CHANNEL_SWITCH_OFFLOAD */
#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8812A) ||\
defined(CONFIG_RTL8192F) || defined(CONFIG_RTL8192E) ||\
defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821A) ||\
defined (CONFIG_RTL8822C)
u8 phy_get_current_tx_num(
PADAPTER pAdapter,
u8 Rate
)
{
u8 tx_num = RF_1TX;
if (IS_1T_RATE(Rate)) {
#if defined(CONFIG_RTW_TX_2PATH_EN)
tx_num = RF_2TX;
#else
tx_num = RF_1TX;
#endif
} else if (IS_2T_RATE(Rate))
tx_num = RF_2TX;
else if (IS_3T_RATE(Rate))
tx_num = RF_3TX;
else
rtw_warn_on(1);
return tx_num;
}
#endif
#ifdef CONFIG_RTL8812A
u8 * rtw_hal_set_8812a_vendor_ie(_adapter *padapter , u8 *pframe ,uint *frlen ) {
int vender_len = 7;
unsigned char vendor_info[vender_len];
unsigned char REALTEK_OUI[] = {0x00, 0xe0, 0x4c};
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if( !IS_HARDWARE_TYPE_8812(padapter) )
return pframe;
_rtw_memset(vendor_info,0,vender_len);
_rtw_memcpy(vendor_info, REALTEK_OUI, 3);
vendor_info[4] =2;
if(pHalData->version_id.CUTVersion > B_CUT_VERSION )
vendor_info[6] = RT_HT_CAP_USE_JAGUAR_CCUT;
else
vendor_info[6] = RT_HT_CAP_USE_JAGUAR_BCUT;
pframe = rtw_set_ie(pframe, _VENDOR_SPECIFIC_IE_,vender_len,vendor_info , frlen);
return pframe;
}
#endif /*CONFIG_RTL8812A*/
================================================
FILE: hal/hal_com_c2h.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __COMMON_C2H_H__
#define __COMMON_C2H_H__
#define C2H_TYPE_REG 0
#define C2H_TYPE_PKT 1
/*
* C2H event format:
* Fields TRIGGER PAYLOAD SEQ PLEN ID
* BITS [127:120] [119:16] [15:8] [7:4] [3:0]
*/
#define C2H_ID(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)), 0, 4)
#define C2H_PLEN(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)), 4, 4)
#define C2H_SEQ(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 1, 0, 8)
#define C2H_PAYLOAD(_c2h) (((u8*)(_c2h)) + 2)
#define SET_C2H_ID(_c2h, _val) SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)), 0, 4, _val)
#define SET_C2H_PLEN(_c2h, _val) SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)), 4, 4, _val)
#define SET_C2H_SEQ(_c2h, _val) SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)) + 1 , 0, 8, _val)
/*
* C2H event format:
* Fields TRIGGER PLEN PAYLOAD SEQ ID
* BITS [127:120] [119:112] [111:16] [15:8] [7:0]
*/
#define C2H_ID_88XX(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)), 0, 8)
#define C2H_SEQ_88XX(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 1, 0, 8)
#define C2H_PAYLOAD_88XX(_c2h) (((u8*)(_c2h)) + 2)
#define C2H_PLEN_88XX(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 14, 0, 8)
#define C2H_TRIGGER_88XX(_c2h) LE_BITS_TO_1BYTE(((u8*)(_c2h)) + 15, 0, 8)
#define SET_C2H_ID_88XX(_c2h, _val) SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)), 0, 8, _val)
#define SET_C2H_SEQ_88XX(_c2h, _val) SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)) + 1, 0, 8, _val)
#define SET_C2H_PLEN_88XX(_c2h, _val) SET_BITS_TO_LE_1BYTE(((u8*)(_c2h)) + 14, 0, 8, _val)
typedef enum _C2H_EVT {
C2H_DBG = 0x00,
C2H_LB = 0x01,
C2H_TXBF = 0x02,
C2H_CCX_TX_RPT = 0x03,
C2H_AP_REQ_TXRPT = 0x04,
C2H_FW_SCAN_COMPLETE = 0x7,
C2H_BT_INFO = 0x09,
C2H_BT_MP_INFO = 0x0B,
C2H_RA_RPT = 0x0C,
C2H_SPC_STAT = 0x0D,
C2H_RA_PARA_RPT = 0x0E,
C2H_FW_CHNL_SWITCH_COMPLETE = 0x10,
C2H_IQK_FINISH = 0x11,
C2H_MAILBOX_STATUS = 0x15,
C2H_P2P_RPORT = 0x16,
C2H_MCC = 0x17,
C2H_MAC_HIDDEN_RPT = 0x19,
C2H_MAC_HIDDEN_RPT_2 = 0x1A,
C2H_BCN_EARLY_RPT = 0x1E,
C2H_DEFEATURE_DBG = 0x22,
C2H_CUSTOMER_STR_RPT = 0x24,
C2H_CUSTOMER_STR_RPT_2 = 0x25,
C2H_WLAN_INFO = 0x27,
#ifdef RTW_PER_CMD_SUPPORT_FW
C2H_PER_RATE_RPT = 0x2c,
#endif
C2H_LPS_STATUS_RPT = 0x32,
C2H_DEFEATURE_RSVD = 0xFD,
C2H_EXTEND = 0xff,
} C2H_EVT;
typedef enum _EXTEND_C2H_EVT {
EXTEND_C2H_DBG_PRINT = 0
} EXTEND_C2H_EVT;
#define C2H_REG_LEN 16
/* C2H_IQK_FINISH, 0x11 */
#define IQK_OFFLOAD_LEN 1
void c2h_iqk_offload(_adapter *adapter, u8 *data, u8 len);
int c2h_iqk_offload_wait(_adapter *adapter, u32 timeout_ms);
#define rtl8812_iqk_wait c2h_iqk_offload_wait /* TODO: remove this after phydm call c2h_iqk_offload_wait instead */
#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
/* C2H_MAC_HIDDEN_RPT, 0x19 */
#define MAC_HIDDEN_RPT_LEN 8
int c2h_mac_hidden_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
/* C2H_MAC_HIDDEN_RPT_2, 0x1A */
#define MAC_HIDDEN_RPT_2_LEN 5
int c2h_mac_hidden_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len);
int hal_read_mac_hidden_rpt(_adapter *adapter);
#else
#define hal_read_mac_hidden_rpt(adapter) _SUCCESS
#endif /* CONFIG_RTW_MAC_HIDDEN_RPT */
/* C2H_DEFEATURE_DBG, 0x22 */
#define DEFEATURE_DBG_LEN 1
int c2h_defeature_dbg_hdl(_adapter *adapter, u8 *data, u8 len);
#ifdef CONFIG_RTW_CUSTOMER_STR
/* C2H_CUSTOMER_STR_RPT, 0x24 */
#define CUSTOMER_STR_RPT_LEN 8
int c2h_customer_str_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
/* C2H_CUSTOMER_STR_RPT_2, 0x25 */
#define CUSTOMER_STR_RPT_2_LEN 8
int c2h_customer_str_rpt_2_hdl(_adapter *adapter, u8 *data, u8 len);
#endif /* CONFIG_RTW_CUSTOMER_STR */
#ifdef RTW_PER_CMD_SUPPORT_FW
/* C2H_PER_RATE_RPT, 0x2c */
int c2h_per_rate_rpt_hdl(_adapter *adapter, u8 *data, u8 len);
#endif
#endif /* __COMMON_C2H_H__ */
================================================
FILE: hal/hal_com_phycfg.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_COM_PHYCFG_C_
#include
#include
#define PG_TXPWR_1PATH_BYTE_NUM_2G 18
#define PG_TXPWR_BASE_BYTE_NUM_2G 11
#define PG_TXPWR_1PATH_BYTE_NUM_5G 24
#define PG_TXPWR_BASE_BYTE_NUM_5G 14
#define PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) (((_pg_v) & 0xf0) >> 4)
#define PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) ((_pg_v) & 0x0f)
#define PG_TXPWR_MSB_DIFF_TO_S8BIT(_pg_v) ((PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) & BIT3) ? (PG_TXPWR_MSB_DIFF_S4BIT(_pg_v) | 0xF0) : PG_TXPWR_MSB_DIFF_S4BIT(_pg_v))
#define PG_TXPWR_LSB_DIFF_TO_S8BIT(_pg_v) ((PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) & BIT3) ? (PG_TXPWR_LSB_DIFF_S4BIT(_pg_v) | 0xF0) : PG_TXPWR_LSB_DIFF_S4BIT(_pg_v))
#define IS_PG_TXPWR_BASE_INVALID(hal_spec, _base) ((_base) > hal_spec->txgi_max)
#define IS_PG_TXPWR_DIFF_INVALID(_diff) ((_diff) > 7 || (_diff) < -8)
#define PG_TXPWR_INVALID_BASE 255
#define PG_TXPWR_INVALID_DIFF 8
#if !IS_PG_TXPWR_DIFF_INVALID(PG_TXPWR_INVALID_DIFF)
#error "PG_TXPWR_DIFF definition has problem"
#endif
#define PG_TXPWR_SRC_PG_DATA 0
#define PG_TXPWR_SRC_IC_DEF 1
#define PG_TXPWR_SRC_DEF 2
#define PG_TXPWR_SRC_NUM 3
const char *const _pg_txpwr_src_str[] = {
"PG_DATA",
"IC_DEF",
"DEF",
"UNKNOWN"
};
#define pg_txpwr_src_str(src) (((src) >= PG_TXPWR_SRC_NUM) ? _pg_txpwr_src_str[PG_TXPWR_SRC_NUM] : _pg_txpwr_src_str[(src)])
#ifndef DBG_PG_TXPWR_READ
#define DBG_PG_TXPWR_READ 0
#endif
#if DBG_PG_TXPWR_READ
static void dump_pg_txpwr_info_2g(void *sel, TxPowerInfo24G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)
{
int path, group, tx_idx;
RTW_PRINT_SEL(sel, "2.4G\n");
RTW_PRINT_SEL(sel, "CCK-1T base:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (group = 0; group < MAX_CHNL_GROUP_24G; group++)
_RTW_PRINT_SEL(sel, "G%02d ", group);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (group = 0; group < MAX_CHNL_GROUP_24G; group++)
_RTW_PRINT_SEL(sel, "%3u ", txpwr_info->IndexCCK_Base[path][group]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "CCK diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dT ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->CCK_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW40-1S base:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (group = 0; group < MAX_CHNL_GROUP_24G - 1; group++)
_RTW_PRINT_SEL(sel, "G%02d ", group);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (group = 0; group < MAX_CHNL_GROUP_24G - 1; group++)
_RTW_PRINT_SEL(sel, "%3u ", txpwr_info->IndexBW40_Base[path][group]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "OFDM diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dT ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->OFDM_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW20 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dS ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->BW20_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW40 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dS ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->BW40_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
}
static void dump_pg_txpwr_info_5g(void *sel, TxPowerInfo5G *txpwr_info, u8 rfpath_num, u8 max_tx_cnt)
{
int path, group, tx_idx;
RTW_PRINT_SEL(sel, "5G\n");
RTW_PRINT_SEL(sel, "BW40-1S base:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (group = 0; group < MAX_CHNL_GROUP_5G; group++)
_RTW_PRINT_SEL(sel, "G%02d ", group);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (group = 0; group < MAX_CHNL_GROUP_5G; group++)
_RTW_PRINT_SEL(sel, "%3u ", txpwr_info->IndexBW40_Base[path][group]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "OFDM diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dT ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->OFDM_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW20 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dS ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->BW20_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW40 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dS ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->BW40_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW80 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dS ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->BW80_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW160 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++)
_RTW_PRINT_SEL(sel, "%dS ", path + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", txpwr_info->BW160_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
}
#endif /* DBG_PG_TXPWR_READ */
const struct map_t pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 168,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE, 0xEE, 0xEE,
0xEE, 0xEE, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x04, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x2A, 0x2A, 0x2A, 0x2A,
0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x04, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE,
0xEE, 0xEE, 0xEE, 0xEE, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24,
0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x2A, 0x2A, 0x2A, 0x2A, 0x04, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE,
0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x04, 0xEE,
0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE)
);
#ifdef CONFIG_RTL8188E
static const struct map_t rtl8188e_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 12,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24)
);
#endif
#ifdef CONFIG_RTL8188F
static const struct map_t rtl8188f_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 12,
0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x27, 0x27, 0x27, 0x27, 0x27, 0x24)
);
#endif
#ifdef CONFIG_RTL8188GTV
static const struct map_t rtl8188gtv_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 12,
0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x27, 0x27, 0x27, 0x27, 0x27, 0x24)
);
#endif
#ifdef CONFIG_RTL8723B
static const struct map_t rtl8723b_pg_txpwr_def_info =
MAP_ENT(0xB8, 2, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 12,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0xE0)
, MAPSEG_ARRAY_ENT(0x3A, 12,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0xE0)
);
#endif
#ifdef CONFIG_RTL8703B
static const struct map_t rtl8703b_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 12,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02)
);
#endif
#ifdef CONFIG_RTL8723D
static const struct map_t rtl8723d_pg_txpwr_def_info =
MAP_ENT(0xB8, 2, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 12,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02)
, MAPSEG_ARRAY_ENT(0x3A, 12,
0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x21, 0x21, 0x21, 0x21, 0x21, 0x02)
);
#endif
#ifdef CONFIG_RTL8192E
static const struct map_t rtl8192e_pg_txpwr_def_info =
MAP_ENT(0xB8, 2, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 14,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE)
, MAPSEG_ARRAY_ENT(0x3A, 14,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE)
);
#endif
#ifdef CONFIG_RTL8821A
static const struct map_t rtl8821a_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 39,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xFF, 0xFF, 0xFF, 0xFF,
0xFF, 0xFF, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x04, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x00)
);
#endif
#ifdef CONFIG_RTL8821C
static const struct map_t rtl8821c_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 54,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xFF, 0xFF, 0xFF, 0xFF,
0xFF, 0xFF, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28, 0x28,
0x02, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xEC, 0xFF, 0xFF, 0xFF, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02)
);
#endif
#ifdef CONFIG_RTL8710B
static const struct map_t rtl8710b_pg_txpwr_def_info =
MAP_ENT(0xC8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x20, 12,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x20)
);
#endif
#ifdef CONFIG_RTL8812A
static const struct map_t rtl8812a_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 82,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xFF, 0xFF,
0xFF, 0xFF, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x02, 0xEE, 0xFF, 0xFF, 0xEE, 0xFF, 0x00, 0xEE, 0xFF, 0xFF, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xFF, 0xFF, 0xFF, 0xFF, 0x2A, 0x2A, 0x2A, 0x2A,
0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x02, 0xEE, 0xFF, 0xFF, 0xEE, 0xFF,
0x00, 0xEE)
);
#endif
#ifdef CONFIG_RTL8822B
static const struct map_t rtl8822b_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 82,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xFF, 0xFF,
0xFF, 0xFF, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x02, 0xEE, 0xFF, 0xFF, 0xEE, 0xFF, 0xEC, 0xEC, 0xFF, 0xFF, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xFF, 0xFF, 0xFF, 0xFF, 0x2A, 0x2A, 0x2A, 0x2A,
0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x02, 0xEE, 0xFF, 0xFF, 0xEE, 0xFF,
0xEC, 0xEC)
);
#endif
#ifdef CONFIG_RTL8822C
static const struct map_t rtl8822c_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 82,
0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x02, 0x00, 0x00, 0xFF, 0xFF,
0xFF, 0xFF, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33,
0x02, 0x00, 0xFF, 0xFF, 0x00, 0xFF, 0x00, 0x00, 0xFF, 0xFF, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33,
0x33, 0x33, 0x33, 0x33, 0x33, 0x02, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0x33, 0x33, 0x33, 0x33,
0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x33, 0x02, 0x00, 0xFF, 0xFF, 0x00, 0xFF,
0x00, 0x00)
);
#endif
#ifdef CONFIG_RTL8814A
static const struct map_t rtl8814a_pg_txpwr_def_info =
MAP_ENT(0xB8, 1, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 168,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xEE, 0xEE,
0xEE, 0xEE, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x02, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x00, 0xEE, 0xEE, 0xEE, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x2A, 0x2A, 0x2A, 0x2A,
0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x02, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE,
0x00, 0xEE, 0xEE, 0xEE, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02,
0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A,
0x2A, 0x2A, 0x2A, 0x2A, 0x02, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0x00, 0xEE, 0xEE, 0xEE, 0x2D, 0x2D,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x02, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE, 0xEE,
0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x02, 0xEE,
0xEE, 0xEE, 0xEE, 0xEE, 0x00, 0xEE, 0xEE, 0xEE)
);
#endif
#ifdef CONFIG_RTL8192F/*use 8192F default,no document*/
static const struct map_t rtl8192f_pg_txpwr_def_info =
MAP_ENT(0xB8, 2, 0xFF
, MAPSEG_ARRAY_ENT(0x10, 14,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE)
, MAPSEG_ARRAY_ENT(0x3A, 14,
0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x2D, 0x24, 0xEE, 0xEE)
);
#endif
const struct map_t *hal_pg_txpwr_def_info(_adapter *adapter)
{
u8 interface_type = 0;
const struct map_t *map = NULL;
interface_type = rtw_get_intf_type(adapter);
switch (rtw_get_chip_type(adapter)) {
#ifdef CONFIG_RTL8723B
case RTL8723B:
map = &rtl8723b_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8703B
case RTL8703B:
map = &rtl8703b_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8723D
case RTL8723D:
map = &rtl8723d_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8188E
case RTL8188E:
map = &rtl8188e_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8188F
case RTL8188F:
map = &rtl8188f_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8188GTV
case RTL8188GTV:
map = &rtl8188gtv_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8812A
case RTL8812:
map = &rtl8812a_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8821A
case RTL8821:
map = &rtl8821a_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8192E
case RTL8192E:
map = &rtl8192e_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8814A
case RTL8814A:
map = &rtl8814a_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8822B
case RTL8822B:
map = &rtl8822b_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8821C
case RTL8821C:
map = &rtl8821c_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8710B
case RTL8710B:
map = &rtl8710b_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8192F
case RTL8192F:
map = &rtl8192f_pg_txpwr_def_info;
break;
#endif
#ifdef CONFIG_RTL8822C
case RTL8822C:
map = &rtl8822c_pg_txpwr_def_info;
break;
#endif
}
if (map == NULL) {
RTW_ERR("%s: unknown chip_type:%u\n"
, __func__, rtw_get_chip_type(adapter));
rtw_warn_on(1);
}
return map;
}
static u8 hal_chk_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *pwr_info)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 path, group, tx_idx;
if (pwr_info == NULL || !hal_chk_band_cap(adapter, BAND_CAP_2G))
return _SUCCESS;
for (path = 0; path < MAX_RF_PATH; path++) {
if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path))
continue;
for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
if (IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexCCK_Base[path][group])
|| IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group]))
return _FAIL;
}
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (!HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx))
continue;
if (IS_PG_TXPWR_DIFF_INVALID(pwr_info->CCK_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW20_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW40_Diff[path][tx_idx]))
return _FAIL;
}
}
return _SUCCESS;
}
static u8 hal_chk_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *pwr_info)
{
#ifdef CONFIG_IEEE80211_BAND_5GHZ
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 path, group, tx_idx;
if (pwr_info == NULL || !hal_chk_band_cap(adapter, BAND_CAP_5G))
return _SUCCESS;
for (path = 0; path < MAX_RF_PATH; path++) {
if (!HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
continue;
for (group = 0; group < MAX_CHNL_GROUP_5G; group++)
if (IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group]))
return _FAIL;
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (!HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx))
continue;
if (IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW20_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW40_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW80_Diff[path][tx_idx])
|| IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW160_Diff[path][tx_idx]))
return _FAIL;
}
}
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
return _SUCCESS;
}
static inline void hal_init_pg_txpwr_info_2g(_adapter *adapter, TxPowerInfo24G *pwr_info)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 path, group, tx_idx;
if (pwr_info == NULL)
return;
_rtw_memset(pwr_info, 0, sizeof(TxPowerInfo24G));
/* init with invalid value */
for (path = 0; path < MAX_RF_PATH; path++) {
for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
pwr_info->IndexCCK_Base[path][group] = PG_TXPWR_INVALID_BASE;
pwr_info->IndexBW40_Base[path][group] = PG_TXPWR_INVALID_BASE;
}
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
pwr_info->CCK_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->OFDM_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->BW20_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->BW40_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
}
}
/* init for dummy base and diff */
for (path = 0; path < MAX_RF_PATH; path++) {
if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path))
break;
/* 2.4G BW40 base has 1 less group than CCK base*/
pwr_info->IndexBW40_Base[path][MAX_CHNL_GROUP_24G - 1] = 0;
/* dummy diff */
pwr_info->CCK_Diff[path][0] = 0; /* 2.4G CCK-1TX */
pwr_info->BW40_Diff[path][0] = 0; /* 2.4G BW40-1S */
}
}
static inline void hal_init_pg_txpwr_info_5g(_adapter *adapter, TxPowerInfo5G *pwr_info)
{
#ifdef CONFIG_IEEE80211_BAND_5GHZ
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 path, group, tx_idx;
if (pwr_info == NULL)
return;
_rtw_memset(pwr_info, 0, sizeof(TxPowerInfo5G));
/* init with invalid value */
for (path = 0; path < MAX_RF_PATH; path++) {
for (group = 0; group < MAX_CHNL_GROUP_5G; group++)
pwr_info->IndexBW40_Base[path][group] = PG_TXPWR_INVALID_BASE;
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
pwr_info->OFDM_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->BW20_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->BW40_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->BW80_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
pwr_info->BW160_Diff[path][tx_idx] = PG_TXPWR_INVALID_DIFF;
}
}
for (path = 0; path < MAX_RF_PATH; path++) {
if (!HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
break;
/* dummy diff */
pwr_info->BW40_Diff[path][0] = 0; /* 5G BW40-1S */
}
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
}
#if DBG_PG_TXPWR_READ
#define LOAD_PG_TXPWR_WARN_COND(_txpwr_src) 1
#else
#define LOAD_PG_TXPWR_WARN_COND(_txpwr_src) (_txpwr_src > PG_TXPWR_SRC_PG_DATA)
#endif
u16 hal_load_pg_txpwr_info_path_2g(
_adapter *adapter,
TxPowerInfo24G *pwr_info,
u32 path,
u8 txpwr_src,
const struct map_t *txpwr_map,
u16 pg_offset)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u16 offset = pg_offset;
u8 group, tx_idx;
u8 val;
u8 tmp_base;
s8 tmp_diff;
if (pwr_info == NULL || !hal_chk_band_cap(adapter, BAND_CAP_2G)) {
offset += PG_TXPWR_1PATH_BYTE_NUM_2G;
goto exit;
}
if (DBG_PG_TXPWR_READ)
RTW_INFO("%s [%c] offset:0x%03x\n", __func__, rf_path_char(path), offset);
for (group = 0; group < MAX_CHNL_GROUP_24G; group++) {
if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
tmp_base = map_read8(txpwr_map, offset);
if (!IS_PG_TXPWR_BASE_INVALID(hal_spec, tmp_base)
&& IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexCCK_Base[path][group])
) {
pwr_info->IndexCCK_Base[path][group] = tmp_base;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G G%02d CCK-1T base:%u from %s\n", rf_path_char(path), group, tmp_base, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
}
for (group = 0; group < MAX_CHNL_GROUP_24G - 1; group++) {
if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
tmp_base = map_read8(txpwr_map, offset);
if (!IS_PG_TXPWR_BASE_INVALID(hal_spec, tmp_base)
&& IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group])
) {
pwr_info->IndexBW40_Base[path][group] = tmp_base;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G G%02d BW40-1S base:%u from %s\n", rf_path_char(path), group, tmp_base, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
}
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (tx_idx == 0) {
if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW20_Diff[path][tx_idx])
) {
pwr_info->BW20_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G BW20-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][tx_idx])
) {
pwr_info->OFDM_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G OFDM-%dT diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
} else {
if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW40_Diff[path][tx_idx])
) {
pwr_info->BW40_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G BW40-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW20_Diff[path][tx_idx])
) {
pwr_info->BW20_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G BW20-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][tx_idx])
) {
pwr_info->OFDM_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G OFDM-%dT diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->CCK_Diff[path][tx_idx])
) {
pwr_info->CCK_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 2G CCK-%dT diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
}
}
if (offset != pg_offset + PG_TXPWR_1PATH_BYTE_NUM_2G) {
RTW_ERR("%s parse %d bytes != %d\n", __func__, offset - pg_offset, PG_TXPWR_1PATH_BYTE_NUM_2G);
rtw_warn_on(1);
}
exit:
return offset;
}
u16 hal_load_pg_txpwr_info_path_5g(
_adapter *adapter,
TxPowerInfo5G *pwr_info,
u32 path,
u8 txpwr_src,
const struct map_t *txpwr_map,
u16 pg_offset)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u16 offset = pg_offset;
u8 group, tx_idx;
u8 val;
u8 tmp_base;
s8 tmp_diff;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (pwr_info == NULL || !hal_chk_band_cap(adapter, BAND_CAP_5G))
#endif
{
offset += PG_TXPWR_1PATH_BYTE_NUM_5G;
goto exit;
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (DBG_PG_TXPWR_READ)
RTW_INFO("%s[%c] eaddr:0x%03x\n", __func__, rf_path_char(path), offset);
for (group = 0; group < MAX_CHNL_GROUP_5G; group++) {
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path)) {
tmp_base = map_read8(txpwr_map, offset);
if (!IS_PG_TXPWR_BASE_INVALID(hal_spec, tmp_base)
&& IS_PG_TXPWR_BASE_INVALID(hal_spec, pwr_info->IndexBW40_Base[path][group])
) {
pwr_info->IndexBW40_Base[path][group] = tmp_base;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G G%02d BW40-1S base:%u from %s\n", rf_path_char(path), group, tmp_base, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
}
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (tx_idx == 0) {
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW20_Diff[path][tx_idx])
) {
pwr_info->BW20_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G BW20-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][tx_idx])
) {
pwr_info->OFDM_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G OFDM-%dT diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
} else {
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW40_Diff[path][tx_idx])
) {
pwr_info->BW40_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G BW40-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW20_Diff[path][tx_idx])
) {
pwr_info->BW20_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G BW20-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
}
}
/* OFDM diff 2T ~ 3T */
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 1)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][1])
) {
pwr_info->OFDM_Diff[path][1] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G OFDM-%dT diff:%d from %s\n", rf_path_char(path), 2, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
if (HAL_SPEC_CHK_TX_CNT(hal_spec, 2)) {
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][2])
) {
pwr_info->OFDM_Diff[path][2] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G OFDM-%dT diff:%d from %s\n", rf_path_char(path), 3, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
}
offset++;
/* OFDM diff 4T */
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, 3)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->OFDM_Diff[path][3])
) {
pwr_info->OFDM_Diff[path][3] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G OFDM-%dT diff:%d from %s\n", rf_path_char(path), 4, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path) && HAL_SPEC_CHK_TX_CNT(hal_spec, tx_idx)) {
val = map_read8(txpwr_map, offset);
tmp_diff = PG_TXPWR_MSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW80_Diff[path][tx_idx])
) {
pwr_info->BW80_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G BW80-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
tmp_diff = PG_TXPWR_LSB_DIFF_TO_S8BIT(val);
if (!IS_PG_TXPWR_DIFF_INVALID(tmp_diff)
&& IS_PG_TXPWR_DIFF_INVALID(pwr_info->BW160_Diff[path][tx_idx])
) {
pwr_info->BW160_Diff[path][tx_idx] = tmp_diff;
if (LOAD_PG_TXPWR_WARN_COND(txpwr_src))
RTW_INFO("[%c] 5G BW160-%dS diff:%d from %s\n", rf_path_char(path), tx_idx + 1, tmp_diff, pg_txpwr_src_str(txpwr_src));
}
}
offset++;
}
if (offset != pg_offset + PG_TXPWR_1PATH_BYTE_NUM_5G) {
RTW_ERR("%s parse %d bytes != %d\n", __func__, offset - pg_offset, PG_TXPWR_1PATH_BYTE_NUM_5G);
rtw_warn_on(1);
}
#endif /* #ifdef CONFIG_IEEE80211_BAND_5GHZ */
exit:
return offset;
}
void hal_load_pg_txpwr_info(
_adapter *adapter,
TxPowerInfo24G *pwr_info_2g,
TxPowerInfo5G *pwr_info_5g,
u8 *pg_data,
BOOLEAN AutoLoadFail
)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 path;
u16 pg_offset;
u8 txpwr_src = PG_TXPWR_SRC_PG_DATA;
struct map_t pg_data_map = MAP_ENT(184, 1, 0xFF, MAPSEG_PTR_ENT(0x00, 184, pg_data));
const struct map_t *txpwr_map = NULL;
/* init with invalid value and some dummy base and diff */
hal_init_pg_txpwr_info_2g(adapter, pwr_info_2g);
hal_init_pg_txpwr_info_5g(adapter, pwr_info_5g);
select_src:
pg_offset = hal_spec->pg_txpwr_saddr;
switch (txpwr_src) {
case PG_TXPWR_SRC_PG_DATA:
txpwr_map = &pg_data_map;
break;
case PG_TXPWR_SRC_IC_DEF:
txpwr_map = hal_pg_txpwr_def_info(adapter);
break;
case PG_TXPWR_SRC_DEF:
default:
txpwr_map = &pg_txpwr_def_info;
break;
};
if (txpwr_map == NULL)
goto end_parse;
for (path = 0; path < MAX_RF_PATH ; path++) {
if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
break;
pg_offset = hal_load_pg_txpwr_info_path_2g(adapter, pwr_info_2g, path, txpwr_src, txpwr_map, pg_offset);
pg_offset = hal_load_pg_txpwr_info_path_5g(adapter, pwr_info_5g, path, txpwr_src, txpwr_map, pg_offset);
}
if (hal_chk_pg_txpwr_info_2g(adapter, pwr_info_2g) == _SUCCESS
&& hal_chk_pg_txpwr_info_5g(adapter, pwr_info_5g) == _SUCCESS)
goto exit;
end_parse:
txpwr_src++;
if (txpwr_src < PG_TXPWR_SRC_NUM)
goto select_src;
if (hal_chk_pg_txpwr_info_2g(adapter, pwr_info_2g) != _SUCCESS
|| hal_chk_pg_txpwr_info_5g(adapter, pwr_info_5g) != _SUCCESS)
rtw_warn_on(1);
exit:
#if DBG_PG_TXPWR_READ
if (pwr_info_2g)
dump_pg_txpwr_info_2g(RTW_DBGDUMP, pwr_info_2g, 4, 4);
if (pwr_info_5g)
dump_pg_txpwr_info_5g(RTW_DBGDUMP, pwr_info_5g, 4, 4);
#endif
return;
}
#ifdef CONFIG_EFUSE_CONFIG_FILE
#define EFUSE_POWER_INDEX_INVALID 0xFF
static u8 _check_phy_efuse_tx_power_info_valid(u8 *pg_data, int base_len, u16 pg_offset)
{
int ff_cnt = 0;
int i;
for (i = 0; i < base_len; i++) {
if (*(pg_data + pg_offset + i) == 0xFF)
ff_cnt++;
}
if (ff_cnt == 0)
return _TRUE;
else if (ff_cnt == base_len)
return _FALSE;
else
return EFUSE_POWER_INDEX_INVALID;
}
int check_phy_efuse_tx_power_info_valid(_adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 *pg_data = hal_data->efuse_eeprom_data;
u16 pg_offset = hal_spec->pg_txpwr_saddr;
u8 path;
u8 valid_2g_path_bmp = 0;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
u8 valid_5g_path_bmp = 0;
#endif
int result = _FALSE;
for (path = 0; path < MAX_RF_PATH; path++) {
u8 ret = _FALSE;
if (!HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path) && !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path))
break;
if (HAL_SPEC_CHK_RF_PATH_2G(hal_spec, path)) {
ret = _check_phy_efuse_tx_power_info_valid(pg_data, PG_TXPWR_BASE_BYTE_NUM_2G, pg_offset);
if (ret == _TRUE)
valid_2g_path_bmp |= BIT(path);
else if (ret == EFUSE_POWER_INDEX_INVALID)
return _FALSE;
}
pg_offset += PG_TXPWR_1PATH_BYTE_NUM_2G;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (HAL_SPEC_CHK_RF_PATH_5G(hal_spec, path)) {
ret = _check_phy_efuse_tx_power_info_valid(pg_data, PG_TXPWR_BASE_BYTE_NUM_5G, pg_offset);
if (ret == _TRUE)
valid_5g_path_bmp |= BIT(path);
else if (ret == EFUSE_POWER_INDEX_INVALID)
return _FALSE;
}
#endif
pg_offset += PG_TXPWR_1PATH_BYTE_NUM_5G;
}
if ((hal_chk_band_cap(adapter, BAND_CAP_2G) && valid_2g_path_bmp)
#ifdef CONFIG_IEEE80211_BAND_5GHZ
|| (hal_chk_band_cap(adapter, BAND_CAP_5G) && valid_5g_path_bmp)
#endif
)
return _TRUE;
return _FALSE;
}
#endif /* CONFIG_EFUSE_CONFIG_FILE */
void hal_load_txpwr_info(
_adapter *adapter,
TxPowerInfo24G *pwr_info_2g,
TxPowerInfo5G *pwr_info_5g,
u8 *pg_data
)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 max_tx_cnt = hal_spec->max_tx_cnt;
u8 rfpath, ch_idx, group, tx_idx;
/* load from pg data (or default value) */
hal_load_pg_txpwr_info(adapter, pwr_info_2g, pwr_info_5g, pg_data, _FALSE);
/* transform to hal_data */
for (rfpath = 0; rfpath < MAX_RF_PATH; rfpath++) {
if (!pwr_info_2g || !HAL_SPEC_CHK_RF_PATH_2G(hal_spec, rfpath))
goto bypass_2g;
/* 2.4G base */
for (ch_idx = 0; ch_idx < CENTER_CH_2G_NUM; ch_idx++) {
u8 cck_group;
if (rtw_get_ch_group(ch_idx + 1, &group, &cck_group) != BAND_ON_2_4G)
continue;
hal_data->Index24G_CCK_Base[rfpath][ch_idx] = pwr_info_2g->IndexCCK_Base[rfpath][cck_group];
hal_data->Index24G_BW40_Base[rfpath][ch_idx] = pwr_info_2g->IndexBW40_Base[rfpath][group];
}
/* 2.4G diff */
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (tx_idx >= max_tx_cnt)
break;
hal_data->CCK_24G_Diff[rfpath][tx_idx] = pwr_info_2g->CCK_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
hal_data->OFDM_24G_Diff[rfpath][tx_idx] = pwr_info_2g->OFDM_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
hal_data->BW20_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW20_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
hal_data->BW40_24G_Diff[rfpath][tx_idx] = pwr_info_2g->BW40_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
}
bypass_2g:
;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (!pwr_info_5g || !HAL_SPEC_CHK_RF_PATH_5G(hal_spec, rfpath))
goto bypass_5g;
/* 5G base */
for (ch_idx = 0; ch_idx < CENTER_CH_5G_ALL_NUM; ch_idx++) {
if (rtw_get_ch_group(center_ch_5g_all[ch_idx], &group, NULL) != BAND_ON_5G)
continue;
hal_data->Index5G_BW40_Base[rfpath][ch_idx] = pwr_info_5g->IndexBW40_Base[rfpath][group];
}
for (ch_idx = 0 ; ch_idx < CENTER_CH_5G_80M_NUM; ch_idx++) {
u8 upper, lower;
if (rtw_get_ch_group(center_ch_5g_80m[ch_idx], &group, NULL) != BAND_ON_5G)
continue;
upper = pwr_info_5g->IndexBW40_Base[rfpath][group];
lower = pwr_info_5g->IndexBW40_Base[rfpath][group + 1];
hal_data->Index5G_BW80_Base[rfpath][ch_idx] = (upper + lower) / 2;
}
/* 5G diff */
for (tx_idx = 0; tx_idx < MAX_TX_COUNT; tx_idx++) {
if (tx_idx >= max_tx_cnt)
break;
hal_data->OFDM_5G_Diff[rfpath][tx_idx] = pwr_info_5g->OFDM_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
hal_data->BW20_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW20_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
hal_data->BW40_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW40_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
hal_data->BW80_5G_Diff[rfpath][tx_idx] = pwr_info_5g->BW80_Diff[rfpath][tx_idx] * hal_spec->pg_txgi_diff_factor;
}
bypass_5g:
;
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
}
}
void dump_hal_txpwr_info_2g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
int path, ch_idx, tx_idx;
RTW_PRINT_SEL(sel, "2.4G\n");
RTW_PRINT_SEL(sel, "CCK-1T base:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (ch_idx = 0; ch_idx < CENTER_CH_2G_NUM; ch_idx++)
_RTW_PRINT_SEL(sel, "%3d ", center_ch_2g[ch_idx]);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (ch_idx = 0; ch_idx < CENTER_CH_2G_NUM; ch_idx++)
_RTW_PRINT_SEL(sel, "%3u ", hal_data->Index24G_CCK_Base[path][ch_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "CCK diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dT ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->CCK_24G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW40-1S base:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (ch_idx = 0; ch_idx < CENTER_CH_2G_NUM; ch_idx++)
_RTW_PRINT_SEL(sel, "%3d ", center_ch_2g[ch_idx]);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (ch_idx = 0; ch_idx < CENTER_CH_2G_NUM; ch_idx++)
_RTW_PRINT_SEL(sel, "%3u ", hal_data->Index24G_BW40_Base[path][ch_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "OFDM diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dT ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->OFDM_24G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW20 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dS ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->BW20_24G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW40 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dS ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->BW40_24G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
}
void dump_hal_txpwr_info_5g(void *sel, _adapter *adapter, u8 rfpath_num, u8 max_tx_cnt)
{
#ifdef CONFIG_IEEE80211_BAND_5GHZ
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
int path, ch_idx, tx_idx;
u8 dump_section = 0;
u8 ch_idx_s = 0;
RTW_PRINT_SEL(sel, "5G\n");
RTW_PRINT_SEL(sel, "BW40-1S base:\n");
do {
#define DUMP_5G_BW40_BASE_SECTION_NUM 3
u8 end[DUMP_5G_BW40_BASE_SECTION_NUM] = {64, 144, 177};
RTW_PRINT_SEL(sel, "%4s ", "");
for (ch_idx = ch_idx_s; ch_idx < CENTER_CH_5G_ALL_NUM; ch_idx++) {
_RTW_PRINT_SEL(sel, "%3d ", center_ch_5g_all[ch_idx]);
if (end[dump_section] == center_ch_5g_all[ch_idx])
break;
}
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (ch_idx = ch_idx_s; ch_idx < CENTER_CH_5G_ALL_NUM; ch_idx++) {
_RTW_PRINT_SEL(sel, "%3u ", hal_data->Index5G_BW40_Base[path][ch_idx]);
if (end[dump_section] == center_ch_5g_all[ch_idx])
break;
}
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
ch_idx_s = ch_idx + 1;
dump_section++;
if (dump_section >= DUMP_5G_BW40_BASE_SECTION_NUM)
break;
} while (1);
RTW_PRINT_SEL(sel, "BW80-1S base:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (ch_idx = 0; ch_idx < CENTER_CH_5G_80M_NUM; ch_idx++)
_RTW_PRINT_SEL(sel, "%3d ", center_ch_5g_80m[ch_idx]);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (ch_idx = 0; ch_idx < CENTER_CH_5G_80M_NUM; ch_idx++)
_RTW_PRINT_SEL(sel, "%3u ", hal_data->Index5G_BW80_Base[path][ch_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "OFDM diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dT ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->OFDM_5G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW20 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dS ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->BW20_5G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW40 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dS ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->BW40_5G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "BW80 diff:\n");
RTW_PRINT_SEL(sel, "%4s ", "");
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%dS ", tx_idx + 1);
_RTW_PRINT_SEL(sel, "\n");
for (path = 0; path < MAX_RF_PATH && path < rfpath_num; path++) {
RTW_PRINT_SEL(sel, "[%c]: ", rf_path_char(path));
for (tx_idx = RF_1TX; tx_idx < MAX_TX_COUNT && tx_idx < max_tx_cnt; tx_idx++)
_RTW_PRINT_SEL(sel, "%2d ", hal_data->BW80_5G_Diff[path][tx_idx]);
_RTW_PRINT_SEL(sel, "\n");
}
RTW_PRINT_SEL(sel, "\n");
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
}
/*
* rtw_regsty_get_target_tx_power -
*
* Return dBm or -1 for undefined
*/
s8 rtw_regsty_get_target_tx_power(
PADAPTER Adapter,
u8 Band,
u8 RfPath,
RATE_SECTION RateSection
)
{
struct registry_priv *regsty = adapter_to_regsty(Adapter);
s8 value = 0;
if (RfPath > RF_PATH_D) {
RTW_PRINT("%s invalid RfPath:%d\n", __func__, RfPath);
return -1;
}
if (Band != BAND_ON_2_4G
#ifdef CONFIG_IEEE80211_BAND_5GHZ
&& Band != BAND_ON_5G
#endif
) {
RTW_PRINT("%s invalid Band:%d\n", __func__, Band);
return -1;
}
if (RateSection >= RATE_SECTION_NUM
#ifdef CONFIG_IEEE80211_BAND_5GHZ
|| (Band == BAND_ON_5G && RateSection == CCK)
#endif
) {
RTW_PRINT("%s invalid RateSection:%d in Band:%d, RfPath:%d\n", __func__
, RateSection, Band, RfPath);
return -1;
}
if (Band == BAND_ON_2_4G)
value = regsty->target_tx_pwr_2g[RfPath][RateSection];
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else /* BAND_ON_5G */
value = regsty->target_tx_pwr_5g[RfPath][RateSection - 1];
#endif
return value;
}
bool rtw_regsty_chk_target_tx_power_valid(_adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
int path, tx_num, band, rs;
s8 target;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
for (path = 0; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
break;
for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
tx_num = rate_section_to_tx_num(rs);
if (tx_num >= hal_spec->tx_nss_num)
continue;
if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
continue;
if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
continue;
target = rtw_regsty_get_target_tx_power(adapter, band, path, rs);
if (target == -1) {
RTW_PRINT("%s return _FALSE for band:%d, path:%d, rs:%d, t:%d\n", __func__, band, path, rs, target);
return _FALSE;
}
}
}
}
return _TRUE;
}
/*
* PHY_GetTxPowerByRateBase -
*
* Return value in unit of TX Gain Index
*/
u8
PHY_GetTxPowerByRateBase(
PADAPTER Adapter,
u8 Band,
u8 RfPath,
RATE_SECTION RateSection
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
u8 value = 0;
if (RfPath > RF_PATH_D) {
RTW_PRINT("%s invalid RfPath:%d\n", __func__, RfPath);
return 0;
}
if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
RTW_PRINT("%s invalid Band:%d\n", __func__, Band);
return 0;
}
if (RateSection >= RATE_SECTION_NUM
|| (Band == BAND_ON_5G && RateSection == CCK)
) {
RTW_PRINT("%s invalid RateSection:%d in Band:%d, RfPath:%d\n", __func__
, RateSection, Band, RfPath);
return 0;
}
if (Band == BAND_ON_2_4G)
value = pHalData->TxPwrByRateBase2_4G[RfPath][RateSection];
else /* BAND_ON_5G */
value = pHalData->TxPwrByRateBase5G[RfPath][RateSection - 1];
return value;
}
void
phy_SetTxPowerByRateBase(
PADAPTER Adapter,
u8 Band,
u8 RfPath,
RATE_SECTION RateSection,
u8 Value
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
if (RfPath > RF_PATH_D) {
RTW_PRINT("%s invalid RfPath:%d\n", __func__, RfPath);
return;
}
if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
RTW_PRINT("%s invalid Band:%d\n", __func__, Band);
return;
}
if (RateSection >= RATE_SECTION_NUM
|| (Band == BAND_ON_5G && RateSection == CCK)
) {
RTW_PRINT("%s invalid RateSection:%d in %sG, RfPath:%d\n", __func__
, RateSection, (Band == BAND_ON_2_4G) ? "2.4" : "5", RfPath);
return;
}
if (Band == BAND_ON_2_4G)
pHalData->TxPwrByRateBase2_4G[RfPath][RateSection] = Value;
else /* BAND_ON_5G */
pHalData->TxPwrByRateBase5G[RfPath][RateSection - 1] = Value;
}
static inline BOOLEAN phy_is_txpwr_by_rate_undefined_of_band_path(_adapter *adapter, u8 band, u8 path)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 rate_idx = 0;
for (rate_idx = 0; rate_idx < TX_PWR_BY_RATE_NUM_RATE; rate_idx++) {
if (hal_data->TxPwrByRateOffset[band][path][rate_idx] != 0)
goto exit;
}
exit:
return rate_idx >= TX_PWR_BY_RATE_NUM_RATE ? _TRUE : _FALSE;
}
static inline void phy_txpwr_by_rate_duplicate_band_path(_adapter *adapter, u8 band, u8 s_path, u8 t_path)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 rate_idx = 0;
for (rate_idx = 0; rate_idx < TX_PWR_BY_RATE_NUM_RATE; rate_idx++)
hal_data->TxPwrByRateOffset[band][t_path][rate_idx] = hal_data->TxPwrByRateOffset[band][s_path][rate_idx];
}
static void phy_txpwr_by_rate_chk_for_path_dup(_adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 band, path;
s8 src_path;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++)
for (path = RF_PATH_A; path < RF_PATH_MAX; path++)
hal_data->txpwr_by_rate_undefined_band_path[band][path] = 0;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
continue;
if (phy_is_txpwr_by_rate_undefined_of_band_path(adapter, band, path))
hal_data->txpwr_by_rate_undefined_band_path[band][path] = 1;
}
}
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
src_path = -1;
for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
continue;
/* find src */
if (src_path == -1 && hal_data->txpwr_by_rate_undefined_band_path[band][path] == 0)
src_path = path;
}
if (src_path == -1) {
RTW_ERR("%s all power by rate undefined\n", __func__);
continue;
}
for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
continue;
/* duplicate src to undefined one */
if (hal_data->txpwr_by_rate_undefined_band_path[band][path] == 1) {
RTW_INFO("%s duplicate %s [%c] to [%c]\n", __func__
, band_str(band), rf_path_char(src_path), rf_path_char(path));
phy_txpwr_by_rate_duplicate_band_path(adapter, band, src_path, path);
}
}
}
}
void
phy_StoreTxPowerByRateBase(
PADAPTER pAdapter
)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(pAdapter);
struct registry_priv *regsty = adapter_to_regsty(pAdapter);
u8 rate_sec_base[RATE_SECTION_NUM] = {
MGN_11M,
MGN_54M,
MGN_MCS7,
MGN_MCS15,
MGN_MCS23,
MGN_MCS31,
MGN_VHT1SS_MCS7,
MGN_VHT2SS_MCS7,
MGN_VHT3SS_MCS7,
MGN_VHT4SS_MCS7,
};
u8 band, path, rs, tx_num, base, index;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(pAdapter, band))
continue;
for (path = RF_PATH_A; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
break;
for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
tx_num = rate_section_to_tx_num(rs);
if (tx_num >= hal_spec->tx_nss_num)
continue;
if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
continue;
if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
continue;
if (regsty->target_tx_pwr_valid == _TRUE)
base = hal_spec->txgi_pdbm * rtw_regsty_get_target_tx_power(pAdapter, band, path, rs);
else
base = _PHY_GetTxPowerByRate(pAdapter, band, path, rate_sec_base[rs]);
phy_SetTxPowerByRateBase(pAdapter, band, path, rs, base);
}
}
}
}
static u8 get_val_from_dhex(u32 dhex, u8 i)
{
return (((dhex >> (i * 8 + 4)) & 0xF)) * 10 + ((dhex >> (i * 8)) & 0xF);
}
static u8 get_val_from_hex(u32 hex, u8 i)
{
return (hex >> (i * 8)) & 0xFF;
}
void
PHY_GetRateValuesOfTxPowerByRate(
PADAPTER pAdapter,
u32 RegAddr,
u32 BitMask,
u32 Value,
u8 *Rate,
s8 *PwrByRateVal,
u8 *RateNum
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(pAdapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
u8 index = 0, i = 0;
u8 (*get_val)(u32, u8);
if (pDM_Odm->phy_reg_pg_version == 1)
get_val = get_val_from_dhex;
else
get_val = get_val_from_hex;
switch (RegAddr) {
case rTxAGC_A_Rate18_06:
case rTxAGC_B_Rate18_06:
Rate[0] = MGN_6M;
Rate[1] = MGN_9M;
Rate[2] = MGN_12M;
Rate[3] = MGN_18M;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case rTxAGC_A_Rate54_24:
case rTxAGC_B_Rate54_24:
Rate[0] = MGN_24M;
Rate[1] = MGN_36M;
Rate[2] = MGN_48M;
Rate[3] = MGN_54M;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case rTxAGC_A_CCK1_Mcs32:
Rate[0] = MGN_1M;
PwrByRateVal[0] = (s8)get_val(Value, 1);
*RateNum = 1;
break;
case rTxAGC_B_CCK11_A_CCK2_11:
if (BitMask == 0xffffff00) {
Rate[0] = MGN_2M;
Rate[1] = MGN_5_5M;
Rate[2] = MGN_11M;
for (i = 1; i < 4; ++i)
PwrByRateVal[i - 1] = (s8)get_val(Value, i);
*RateNum = 3;
} else if (BitMask == 0x000000ff) {
Rate[0] = MGN_11M;
PwrByRateVal[0] = (s8)get_val(Value, 0);
*RateNum = 1;
}
break;
case rTxAGC_A_Mcs03_Mcs00:
case rTxAGC_B_Mcs03_Mcs00:
Rate[0] = MGN_MCS0;
Rate[1] = MGN_MCS1;
Rate[2] = MGN_MCS2;
Rate[3] = MGN_MCS3;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case rTxAGC_A_Mcs07_Mcs04:
case rTxAGC_B_Mcs07_Mcs04:
Rate[0] = MGN_MCS4;
Rate[1] = MGN_MCS5;
Rate[2] = MGN_MCS6;
Rate[3] = MGN_MCS7;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case rTxAGC_A_Mcs11_Mcs08:
case rTxAGC_B_Mcs11_Mcs08:
Rate[0] = MGN_MCS8;
Rate[1] = MGN_MCS9;
Rate[2] = MGN_MCS10;
Rate[3] = MGN_MCS11;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case rTxAGC_A_Mcs15_Mcs12:
case rTxAGC_B_Mcs15_Mcs12:
Rate[0] = MGN_MCS12;
Rate[1] = MGN_MCS13;
Rate[2] = MGN_MCS14;
Rate[3] = MGN_MCS15;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case rTxAGC_B_CCK1_55_Mcs32:
Rate[0] = MGN_1M;
Rate[1] = MGN_2M;
Rate[2] = MGN_5_5M;
for (i = 1; i < 4; ++i)
PwrByRateVal[i - 1] = (s8)get_val(Value, i);
*RateNum = 3;
break;
case 0xC20:
case 0xE20:
case 0x1820:
case 0x1a20:
Rate[0] = MGN_1M;
Rate[1] = MGN_2M;
Rate[2] = MGN_5_5M;
Rate[3] = MGN_11M;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC24:
case 0xE24:
case 0x1824:
case 0x1a24:
Rate[0] = MGN_6M;
Rate[1] = MGN_9M;
Rate[2] = MGN_12M;
Rate[3] = MGN_18M;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC28:
case 0xE28:
case 0x1828:
case 0x1a28:
Rate[0] = MGN_24M;
Rate[1] = MGN_36M;
Rate[2] = MGN_48M;
Rate[3] = MGN_54M;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC2C:
case 0xE2C:
case 0x182C:
case 0x1a2C:
Rate[0] = MGN_MCS0;
Rate[1] = MGN_MCS1;
Rate[2] = MGN_MCS2;
Rate[3] = MGN_MCS3;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC30:
case 0xE30:
case 0x1830:
case 0x1a30:
Rate[0] = MGN_MCS4;
Rate[1] = MGN_MCS5;
Rate[2] = MGN_MCS6;
Rate[3] = MGN_MCS7;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC34:
case 0xE34:
case 0x1834:
case 0x1a34:
Rate[0] = MGN_MCS8;
Rate[1] = MGN_MCS9;
Rate[2] = MGN_MCS10;
Rate[3] = MGN_MCS11;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC38:
case 0xE38:
case 0x1838:
case 0x1a38:
Rate[0] = MGN_MCS12;
Rate[1] = MGN_MCS13;
Rate[2] = MGN_MCS14;
Rate[3] = MGN_MCS15;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC3C:
case 0xE3C:
case 0x183C:
case 0x1a3C:
Rate[0] = MGN_VHT1SS_MCS0;
Rate[1] = MGN_VHT1SS_MCS1;
Rate[2] = MGN_VHT1SS_MCS2;
Rate[3] = MGN_VHT1SS_MCS3;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC40:
case 0xE40:
case 0x1840:
case 0x1a40:
Rate[0] = MGN_VHT1SS_MCS4;
Rate[1] = MGN_VHT1SS_MCS5;
Rate[2] = MGN_VHT1SS_MCS6;
Rate[3] = MGN_VHT1SS_MCS7;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC44:
case 0xE44:
case 0x1844:
case 0x1a44:
Rate[0] = MGN_VHT1SS_MCS8;
Rate[1] = MGN_VHT1SS_MCS9;
Rate[2] = MGN_VHT2SS_MCS0;
Rate[3] = MGN_VHT2SS_MCS1;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC48:
case 0xE48:
case 0x1848:
case 0x1a48:
Rate[0] = MGN_VHT2SS_MCS2;
Rate[1] = MGN_VHT2SS_MCS3;
Rate[2] = MGN_VHT2SS_MCS4;
Rate[3] = MGN_VHT2SS_MCS5;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xC4C:
case 0xE4C:
case 0x184C:
case 0x1a4C:
Rate[0] = MGN_VHT2SS_MCS6;
Rate[1] = MGN_VHT2SS_MCS7;
Rate[2] = MGN_VHT2SS_MCS8;
Rate[3] = MGN_VHT2SS_MCS9;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xCD8:
case 0xED8:
case 0x18D8:
case 0x1aD8:
Rate[0] = MGN_MCS16;
Rate[1] = MGN_MCS17;
Rate[2] = MGN_MCS18;
Rate[3] = MGN_MCS19;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xCDC:
case 0xEDC:
case 0x18DC:
case 0x1aDC:
Rate[0] = MGN_MCS20;
Rate[1] = MGN_MCS21;
Rate[2] = MGN_MCS22;
Rate[3] = MGN_MCS23;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xCE0:
case 0xEE0:
case 0x18E0:
case 0x1aE0:
Rate[0] = MGN_VHT3SS_MCS0;
Rate[1] = MGN_VHT3SS_MCS1;
Rate[2] = MGN_VHT3SS_MCS2;
Rate[3] = MGN_VHT3SS_MCS3;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xCE4:
case 0xEE4:
case 0x18E4:
case 0x1aE4:
Rate[0] = MGN_VHT3SS_MCS4;
Rate[1] = MGN_VHT3SS_MCS5;
Rate[2] = MGN_VHT3SS_MCS6;
Rate[3] = MGN_VHT3SS_MCS7;
for (i = 0; i < 4; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 4;
break;
case 0xCE8:
case 0xEE8:
case 0x18E8:
case 0x1aE8:
Rate[0] = MGN_VHT3SS_MCS8;
Rate[1] = MGN_VHT3SS_MCS9;
for (i = 0; i < 2; ++i)
PwrByRateVal[i] = (s8)get_val(Value, i);
*RateNum = 2;
break;
default:
RTW_PRINT("Invalid RegAddr 0x%x in %s()\n", RegAddr, __func__);
break;
};
}
void
PHY_StoreTxPowerByRateNew(
PADAPTER pAdapter,
u32 Band,
u32 RfPath,
u32 RegAddr,
u32 BitMask,
u32 Data
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 i = 0, rates[4] = {0}, rateNum = 0;
s8 PwrByRateVal[4] = {0};
PHY_GetRateValuesOfTxPowerByRate(pAdapter, RegAddr, BitMask, Data, rates, PwrByRateVal, &rateNum);
if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
RTW_PRINT("Invalid Band %d\n", Band);
return;
}
if (RfPath > RF_PATH_D) {
RTW_PRINT("Invalid RfPath %d\n", RfPath);
return;
}
for (i = 0; i < rateNum; ++i) {
u8 rate_idx = PHY_GetRateIndexOfTxPowerByRate(rates[i]);
pHalData->TxPwrByRateOffset[Band][RfPath][rate_idx] = PwrByRateVal[i];
}
}
void
PHY_InitTxPowerByRate(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 band = 0, rfPath = 0, rate = 0, i = 0, j = 0;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; ++band)
for (rfPath = 0; rfPath < TX_PWR_BY_RATE_NUM_RF; ++rfPath)
for (rate = 0; rate < TX_PWR_BY_RATE_NUM_RATE; ++rate)
pHalData->TxPwrByRateOffset[band][rfPath][rate] = 0;
}
void
phy_store_tx_power_by_rate(
PADAPTER pAdapter,
u32 Band,
u32 RfPath,
u32 TxNum,
u32 RegAddr,
u32 BitMask,
u32 Data
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
if (pDM_Odm->phy_reg_pg_version > 0)
PHY_StoreTxPowerByRateNew(pAdapter, Band, RfPath, RegAddr, BitMask, Data);
else
RTW_INFO("Invalid PHY_REG_PG.txt version %d\n", pDM_Odm->phy_reg_pg_version);
}
void
phy_ConvertTxPowerByRateInDbmToRelativeValues(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 base = 0, i = 0, value = 0,
band = 0, path = 0, index = 0,
startIndex = 0, endIndex = 0;
u8 cckRates[4] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M},
ofdmRates[8] = {MGN_6M, MGN_9M, MGN_12M, MGN_18M, MGN_24M, MGN_36M, MGN_48M, MGN_54M},
mcs0_7Rates[8] = {MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4, MGN_MCS5, MGN_MCS6, MGN_MCS7},
mcs8_15Rates[8] = {MGN_MCS8, MGN_MCS9, MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14, MGN_MCS15},
mcs16_23Rates[8] = {MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19, MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23},
vht1ssRates[10] = {MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4,
MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9},
vht2ssRates[10] = {MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4,
MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9},
vht3ssRates[10] = {MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4,
MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9};
/* RTW_INFO("===>PHY_ConvertTxPowerByRateInDbmToRelativeValues()\n" ); */
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; ++band) {
for (path = RF_PATH_A; path <= RF_PATH_D; ++path) {
/* CCK */
if (band == BAND_ON_2_4G) {
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, CCK);
for (i = 0; i < sizeof(cckRates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, cckRates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, cckRates[i], value - base);
}
}
/* OFDM */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, OFDM);
for (i = 0; i < sizeof(ofdmRates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, ofdmRates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, ofdmRates[i], value - base);
}
/* HT MCS0~7 */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, HT_1SS);
for (i = 0; i < sizeof(mcs0_7Rates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, mcs0_7Rates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, mcs0_7Rates[i], value - base);
}
/* HT MCS8~15 */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, HT_2SS);
for (i = 0; i < sizeof(mcs8_15Rates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, mcs8_15Rates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, mcs8_15Rates[i], value - base);
}
/* HT MCS16~23 */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, HT_3SS);
for (i = 0; i < sizeof(mcs16_23Rates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, mcs16_23Rates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, mcs16_23Rates[i], value - base);
}
/* VHT 1SS */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, VHT_1SS);
for (i = 0; i < sizeof(vht1ssRates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, vht1ssRates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, vht1ssRates[i], value - base);
}
/* VHT 2SS */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, VHT_2SS);
for (i = 0; i < sizeof(vht2ssRates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, vht2ssRates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, vht2ssRates[i], value - base);
}
/* VHT 3SS */
base = PHY_GetTxPowerByRateBase(pAdapter, band, path, VHT_3SS);
for (i = 0; i < sizeof(vht3ssRates); ++i) {
value = PHY_GetTxPowerByRate(pAdapter, band, path, vht3ssRates[i]);
PHY_SetTxPowerByRate(pAdapter, band, path, vht3ssRates[i], value - base);
}
}
}
/* RTW_INFO("<===PHY_ConvertTxPowerByRateInDbmToRelativeValues()\n" ); */
}
/*
* This function must be called if the value in the PHY_REG_PG.txt(or header)
* is exact dBm values
*/
void
PHY_TxPowerByRateConfiguration(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
phy_txpwr_by_rate_chk_for_path_dup(pAdapter);
phy_StoreTxPowerByRateBase(pAdapter);
phy_ConvertTxPowerByRateInDbmToRelativeValues(pAdapter);
}
void
phy_set_tx_power_index_by_rate_section(
PADAPTER pAdapter,
enum rf_path RFPath,
u8 Channel,
u8 RateSection
)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
if (RateSection >= RATE_SECTION_NUM) {
RTW_INFO("Invalid RateSection %d in %s", RateSection, __func__);
rtw_warn_on(1);
goto exit;
}
if (RateSection == CCK && pHalData->current_band_type != BAND_ON_2_4G)
goto exit;
PHY_SetTxPowerIndexByRateArray(pAdapter, RFPath, pHalData->current_channel_bw, Channel,
rates_by_sections[RateSection].rates, rates_by_sections[RateSection].rate_num);
exit:
return;
}
BOOLEAN
phy_GetChnlIndex(
u8 Channel,
u8 *ChannelIdx
)
{
u8 i = 0;
BOOLEAN bIn24G = _TRUE;
if (Channel <= 14) {
bIn24G = _TRUE;
*ChannelIdx = Channel - 1;
} else {
bIn24G = _FALSE;
for (i = 0; i < CENTER_CH_5G_ALL_NUM; ++i) {
if (center_ch_5g_all[i] == Channel) {
*ChannelIdx = i;
return bIn24G;
}
}
}
return bIn24G;
}
u8 phy_get_pg_txpwr_idx(
PADAPTER pAdapter,
enum rf_path RFPath,
u8 Rate,
u8 ntx_idx,
enum channel_width BandWidth,
u8 Channel,
PBOOLEAN bIn24G
)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
u8 i = 0; /* default set to 1S */
u8 txPower = 0;
u8 chnlIdx = (Channel - 1);
if (HAL_IsLegalChannel(pAdapter, Channel) == _FALSE) {
chnlIdx = 0;
RTW_INFO("Illegal channel!!\n");
}
*bIn24G = phy_GetChnlIndex(Channel, &chnlIdx);
if (0)
RTW_INFO("[%s] Channel Index: %d\n", (*bIn24G ? "2.4G" : "5G"), chnlIdx);
if (*bIn24G) {
if (IS_CCK_RATE(Rate)) {
/* CCK-nTX */
txPower = pHalData->Index24G_CCK_Base[RFPath][chnlIdx];
txPower += pHalData->CCK_24G_Diff[RFPath][RF_1TX];
if (ntx_idx >= RF_2TX)
txPower += pHalData->CCK_24G_Diff[RFPath][RF_2TX];
if (ntx_idx >= RF_3TX)
txPower += pHalData->CCK_24G_Diff[RFPath][RF_3TX];
if (ntx_idx >= RF_4TX)
txPower += pHalData->CCK_24G_Diff[RFPath][RF_4TX];
goto exit;
}
txPower = pHalData->Index24G_BW40_Base[RFPath][chnlIdx];
/* OFDM-nTX */
if ((MGN_6M <= Rate && Rate <= MGN_54M) && !IS_CCK_RATE(Rate)) {
txPower += pHalData->OFDM_24G_Diff[RFPath][RF_1TX];
if (ntx_idx >= RF_2TX)
txPower += pHalData->OFDM_24G_Diff[RFPath][RF_2TX];
if (ntx_idx >= RF_3TX)
txPower += pHalData->OFDM_24G_Diff[RFPath][RF_3TX];
if (ntx_idx >= RF_4TX)
txPower += pHalData->OFDM_24G_Diff[RFPath][RF_4TX];
goto exit;
}
/* BW20-nS */
if (BandWidth == CHANNEL_WIDTH_20) {
if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_24G_Diff[RFPath][RF_1TX];
if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_24G_Diff[RFPath][RF_2TX];
if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_24G_Diff[RFPath][RF_3TX];
if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_24G_Diff[RFPath][RF_4TX];
goto exit;
}
/* BW40-nS */
if (BandWidth == CHANNEL_WIDTH_40) {
if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_1TX];
if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_2TX];
if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_3TX];
if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_4TX];
goto exit;
}
/* Willis suggest adopt BW 40M power index while in BW 80 mode */
if (BandWidth == CHANNEL_WIDTH_80) {
if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_1TX];
if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_2TX];
if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_3TX];
if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_24G_Diff[RFPath][RF_4TX];
goto exit;
}
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else {
if (Rate >= MGN_6M)
txPower = pHalData->Index5G_BW40_Base[RFPath][chnlIdx];
else {
RTW_INFO("===>%s: INVALID Rate(0x%02x).\n", __func__, Rate);
goto exit;
}
/* OFDM-nTX */
if ((MGN_6M <= Rate && Rate <= MGN_54M) && !IS_CCK_RATE(Rate)) {
txPower += pHalData->OFDM_5G_Diff[RFPath][RF_1TX];
if (ntx_idx >= RF_2TX)
txPower += pHalData->OFDM_5G_Diff[RFPath][RF_2TX];
if (ntx_idx >= RF_3TX)
txPower += pHalData->OFDM_5G_Diff[RFPath][RF_3TX];
if (ntx_idx >= RF_4TX)
txPower += pHalData->OFDM_5G_Diff[RFPath][RF_4TX];
goto exit;
}
/* BW20-nS */
if (BandWidth == CHANNEL_WIDTH_20) {
if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_5G_Diff[RFPath][RF_1TX];
if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_5G_Diff[RFPath][RF_2TX];
if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_5G_Diff[RFPath][RF_3TX];
if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW20_5G_Diff[RFPath][RF_4TX];
goto exit;
}
/* BW40-nS */
if (BandWidth == CHANNEL_WIDTH_40) {
if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_5G_Diff[RFPath][RF_1TX];
if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_5G_Diff[RFPath][RF_2TX];
if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_5G_Diff[RFPath][RF_3TX];
if ((MGN_MCS24 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW40_5G_Diff[RFPath][RF_4TX];
goto exit;
}
/* BW80-nS */
if (BandWidth == CHANNEL_WIDTH_80) {
/* get 80MHz cch index */
for (i = 0; i < CENTER_CH_5G_80M_NUM; ++i) {
if (center_ch_5g_80m[i] == Channel) {
chnlIdx = i;
break;
}
}
if (i >= CENTER_CH_5G_80M_NUM) {
#ifdef CONFIG_MP_INCLUDED
if (rtw_mp_mode_check(pAdapter) == _FALSE)
#endif
rtw_warn_on(1);
txPower = 0;
goto exit;
}
txPower = pHalData->Index5G_BW80_Base[RFPath][chnlIdx];
if ((MGN_MCS0 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT1SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += + pHalData->BW80_5G_Diff[RFPath][RF_1TX];
if ((MGN_MCS8 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT2SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW80_5G_Diff[RFPath][RF_2TX];
if ((MGN_MCS16 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT3SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW80_5G_Diff[RFPath][RF_3TX];
if ((MGN_MCS23 <= Rate && Rate <= MGN_MCS31) || (MGN_VHT4SS_MCS0 <= Rate && Rate <= MGN_VHT4SS_MCS9))
txPower += pHalData->BW80_5G_Diff[RFPath][RF_4TX];
goto exit;
}
/* TODO: BW160-nS */
rtw_warn_on(1);
}
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
exit:
return txPower;
}
s8
PHY_GetTxPowerTrackingOffset(
PADAPTER pAdapter,
enum rf_path RFPath,
u8 Rate
)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(pAdapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
s8 offset = 0;
if (pDM_Odm->rf_calibrate_info.txpowertrack_control == _FALSE)
return offset;
if ((Rate == MGN_1M) || (Rate == MGN_2M) || (Rate == MGN_5_5M) || (Rate == MGN_11M)) {
offset = pDM_Odm->rf_calibrate_info.remnant_cck_swing_idx;
/*RTW_INFO("+Remnant_CCKSwingIdx = 0x%x\n", RFPath, Rate, pRFCalibrateInfo->Remnant_CCKSwingIdx);*/
} else {
offset = pDM_Odm->rf_calibrate_info.remnant_ofdm_swing_idx[RFPath];
/*RTW_INFO("+Remanant_OFDMSwingIdx[RFPath %u][Rate 0x%x] = 0x%x\n", RFPath, Rate, pRFCalibrateInfo->Remnant_OFDMSwingIdx[RFPath]); */
}
return offset;
}
/*The same as MRateToHwRate in hal_com.c*/
u8
PHY_GetRateIndexOfTxPowerByRate(
u8 Rate
)
{
u8 index = 0;
switch (Rate) {
case MGN_1M:
index = 0;
break;
case MGN_2M:
index = 1;
break;
case MGN_5_5M:
index = 2;
break;
case MGN_11M:
index = 3;
break;
case MGN_6M:
index = 4;
break;
case MGN_9M:
index = 5;
break;
case MGN_12M:
index = 6;
break;
case MGN_18M:
index = 7;
break;
case MGN_24M:
index = 8;
break;
case MGN_36M:
index = 9;
break;
case MGN_48M:
index = 10;
break;
case MGN_54M:
index = 11;
break;
case MGN_MCS0:
index = 12;
break;
case MGN_MCS1:
index = 13;
break;
case MGN_MCS2:
index = 14;
break;
case MGN_MCS3:
index = 15;
break;
case MGN_MCS4:
index = 16;
break;
case MGN_MCS5:
index = 17;
break;
case MGN_MCS6:
index = 18;
break;
case MGN_MCS7:
index = 19;
break;
case MGN_MCS8:
index = 20;
break;
case MGN_MCS9:
index = 21;
break;
case MGN_MCS10:
index = 22;
break;
case MGN_MCS11:
index = 23;
break;
case MGN_MCS12:
index = 24;
break;
case MGN_MCS13:
index = 25;
break;
case MGN_MCS14:
index = 26;
break;
case MGN_MCS15:
index = 27;
break;
case MGN_MCS16:
index = 28;
break;
case MGN_MCS17:
index = 29;
break;
case MGN_MCS18:
index = 30;
break;
case MGN_MCS19:
index = 31;
break;
case MGN_MCS20:
index = 32;
break;
case MGN_MCS21:
index = 33;
break;
case MGN_MCS22:
index = 34;
break;
case MGN_MCS23:
index = 35;
break;
case MGN_MCS24:
index = 36;
break;
case MGN_MCS25:
index = 37;
break;
case MGN_MCS26:
index = 38;
break;
case MGN_MCS27:
index = 39;
break;
case MGN_MCS28:
index = 40;
break;
case MGN_MCS29:
index = 41;
break;
case MGN_MCS30:
index = 42;
break;
case MGN_MCS31:
index = 43;
break;
case MGN_VHT1SS_MCS0:
index = 44;
break;
case MGN_VHT1SS_MCS1:
index = 45;
break;
case MGN_VHT1SS_MCS2:
index = 46;
break;
case MGN_VHT1SS_MCS3:
index = 47;
break;
case MGN_VHT1SS_MCS4:
index = 48;
break;
case MGN_VHT1SS_MCS5:
index = 49;
break;
case MGN_VHT1SS_MCS6:
index = 50;
break;
case MGN_VHT1SS_MCS7:
index = 51;
break;
case MGN_VHT1SS_MCS8:
index = 52;
break;
case MGN_VHT1SS_MCS9:
index = 53;
break;
case MGN_VHT2SS_MCS0:
index = 54;
break;
case MGN_VHT2SS_MCS1:
index = 55;
break;
case MGN_VHT2SS_MCS2:
index = 56;
break;
case MGN_VHT2SS_MCS3:
index = 57;
break;
case MGN_VHT2SS_MCS4:
index = 58;
break;
case MGN_VHT2SS_MCS5:
index = 59;
break;
case MGN_VHT2SS_MCS6:
index = 60;
break;
case MGN_VHT2SS_MCS7:
index = 61;
break;
case MGN_VHT2SS_MCS8:
index = 62;
break;
case MGN_VHT2SS_MCS9:
index = 63;
break;
case MGN_VHT3SS_MCS0:
index = 64;
break;
case MGN_VHT3SS_MCS1:
index = 65;
break;
case MGN_VHT3SS_MCS2:
index = 66;
break;
case MGN_VHT3SS_MCS3:
index = 67;
break;
case MGN_VHT3SS_MCS4:
index = 68;
break;
case MGN_VHT3SS_MCS5:
index = 69;
break;
case MGN_VHT3SS_MCS6:
index = 70;
break;
case MGN_VHT3SS_MCS7:
index = 71;
break;
case MGN_VHT3SS_MCS8:
index = 72;
break;
case MGN_VHT3SS_MCS9:
index = 73;
break;
case MGN_VHT4SS_MCS0:
index = 74;
break;
case MGN_VHT4SS_MCS1:
index = 75;
break;
case MGN_VHT4SS_MCS2:
index = 76;
break;
case MGN_VHT4SS_MCS3:
index = 77;
break;
case MGN_VHT4SS_MCS4:
index = 78;
break;
case MGN_VHT4SS_MCS5:
index = 79;
break;
case MGN_VHT4SS_MCS6:
index = 80;
break;
case MGN_VHT4SS_MCS7:
index = 81;
break;
case MGN_VHT4SS_MCS8:
index = 82;
break;
case MGN_VHT4SS_MCS9:
index = 83;
break;
default:
RTW_INFO("Invalid rate 0x%x in %s\n", Rate, __FUNCTION__);
break;
};
return index;
}
s8
_PHY_GetTxPowerByRate(
PADAPTER pAdapter,
u8 Band,
enum rf_path RFPath,
u8 Rate
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
s8 value = 0;
u8 rateIndex = PHY_GetRateIndexOfTxPowerByRate(Rate);
if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
RTW_INFO("Invalid band %d in %s\n", Band, __func__);
goto exit;
}
if (RFPath > RF_PATH_D) {
RTW_INFO("Invalid RfPath %d in %s\n", RFPath, __func__);
goto exit;
}
if (rateIndex >= TX_PWR_BY_RATE_NUM_RATE) {
RTW_INFO("Invalid RateIndex %d in %s\n", rateIndex, __func__);
goto exit;
}
value = pHalData->TxPwrByRateOffset[Band][RFPath][rateIndex];
exit:
return value;
}
s8
PHY_GetTxPowerByRate(
PADAPTER pAdapter,
u8 Band,
enum rf_path RFPath,
u8 Rate
)
{
if (!phy_is_tx_power_by_rate_needed(pAdapter))
return 0;
return _PHY_GetTxPowerByRate(pAdapter, Band, RFPath, Rate);
}
void
PHY_SetTxPowerByRate(
PADAPTER pAdapter,
u8 Band,
enum rf_path RFPath,
u8 Rate,
s8 Value
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 rateIndex = PHY_GetRateIndexOfTxPowerByRate(Rate);
if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
RTW_INFO("Invalid band %d in %s\n", Band, __FUNCTION__);
return;
}
if (RFPath > RF_PATH_D) {
RTW_INFO("Invalid RfPath %d in %s\n", RFPath, __FUNCTION__);
return;
}
if (rateIndex >= TX_PWR_BY_RATE_NUM_RATE) {
RTW_INFO("Invalid RateIndex %d in %s\n", rateIndex, __FUNCTION__);
return;
}
pHalData->TxPwrByRateOffset[Band][RFPath][rateIndex] = Value;
}
u8 phy_check_under_survey_ch(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
_adapter *iface;
struct mlme_ext_priv *mlmeext;
u8 ret = _FALSE;
int i;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
mlmeext = &iface->mlmeextpriv;
/* check scan state */
if (mlmeext_scan_state(mlmeext) != SCAN_DISABLE
&& mlmeext_scan_state(mlmeext) != SCAN_COMPLETE
&& mlmeext_scan_state(mlmeext) != SCAN_BACKING_OP) {
ret = _TRUE;
} else if (mlmeext_scan_state(mlmeext) == SCAN_BACKING_OP
&& !mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_TX_RESUME)) {
ret = _TRUE;
}
}
return ret;
}
void
phy_set_tx_power_level_by_path(
PADAPTER Adapter,
u8 channel,
u8 path
)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
BOOLEAN bIsIn24G = (pHalData->current_band_type == BAND_ON_2_4G);
u8 under_survey_ch = phy_check_under_survey_ch(Adapter);
/* if ( pMgntInfo->RegNByteAccess == 0 ) */
{
if (bIsIn24G)
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, CCK);
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, OFDM);
if (!under_survey_ch) {
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS0_MCS7);
if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_1SSMCS0_1SSMCS9);
if (pHalData->NumTotalRFPath >= 2) {
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS8_MCS15);
if (IS_HARDWARE_TYPE_JAGUAR(Adapter) || IS_HARDWARE_TYPE_8814A(Adapter))
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_2SSMCS0_2SSMCS9);
if (IS_HARDWARE_TYPE_8814A(Adapter)) {
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, HT_MCS16_MCS23);
phy_set_tx_power_index_by_rate_section(Adapter, path, channel, VHT_3SSMCS0_3SSMCS9);
}
}
}
}
}
#ifndef DBG_TX_POWER_IDX
#define DBG_TX_POWER_IDX 0
#endif
void
PHY_SetTxPowerIndexByRateArray(
PADAPTER pAdapter,
enum rf_path RFPath,
enum channel_width BandWidth,
u8 Channel,
u8 *Rates,
u8 RateArraySize
)
{
u32 powerIndex = 0;
int i = 0;
for (i = 0; i < RateArraySize; ++i) {
#if DBG_TX_POWER_IDX
struct txpwr_idx_comp tic;
powerIndex = rtw_hal_get_tx_power_index(pAdapter, RFPath, Rates[i], BandWidth, Channel, &tic);
RTW_INFO("TXPWR: [%c][%s]ch:%u, %s %uT, pwr_idx:%u(0x%02x) = %u + (%d=%d:%d) + (%d) + (%d) + (%d) + (%d)\n"
, rf_path_char(RFPath), ch_width_str(BandWidth), Channel, MGN_RATE_STR(Rates[i]), tic.ntx_idx + 1
, powerIndex, powerIndex, tic.pg, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate), tic.by_rate, tic.limit, tic.tpt
, tic.ebias, tic.btc, tic.dpd);
#else
powerIndex = phy_get_tx_power_index(pAdapter, RFPath, Rates[i], BandWidth, Channel);
#endif
PHY_SetTxPowerIndex(pAdapter, powerIndex, RFPath, Rates[i]);
}
}
#if CONFIG_TXPWR_LIMIT
const char *const _txpwr_lmt_rs_str[] = {
"CCK",
"OFDM",
"HT",
"VHT",
"UNKNOWN",
};
static s8
phy_GetChannelIndexOfTxPowerLimit(
u8 Band,
u8 Channel
)
{
s8 channelIndex = -1;
u8 i = 0;
if (Band == BAND_ON_2_4G)
channelIndex = Channel - 1;
else if (Band == BAND_ON_5G) {
for (i = 0; i < CENTER_CH_5G_ALL_NUM; ++i) {
if (center_ch_5g_all[i] == Channel)
channelIndex = i;
}
} else
RTW_PRINT("Invalid Band %d in %s\n", Band, __func__);
if (channelIndex == -1)
RTW_PRINT("Invalid Channel %d of Band %d in %s\n", Channel, Band, __func__);
return channelIndex;
}
static s8 phy_txpwr_ww_lmt_value(_adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
if (hal_spec->txgi_max == 63)
return -63;
else if (hal_spec->txgi_max == 127)
return -128;
rtw_warn_on(1);
return -128;
}
/*
* return txpwr limit absolute value
* hsl_spec->txgi_max is returned when NO limit
*/
s8 phy_get_txpwr_lmt_abs(
PADAPTER Adapter,
const char *regd_name,
BAND_TYPE Band,
enum channel_width bw,
u8 tlrs,
u8 ntx_idx,
u8 cch,
u8 lock
)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(Adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(Adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(Adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
struct txpwr_lmt_ent *ent = NULL;
_irqL irqL;
_list *cur, *head;
s8 ch_idx;
u8 is_ww_regd = 0;
s8 ww_lmt_val = phy_txpwr_ww_lmt_value(Adapter);
s8 lmt = hal_spec->txgi_max;
if ((Adapter->registrypriv.RegEnableTxPowerLimit == 2 && hal_data->EEPROMRegulatory != 1) ||
Adapter->registrypriv.RegEnableTxPowerLimit == 0)
goto exit;
if (Band != BAND_ON_2_4G && Band != BAND_ON_5G) {
RTW_ERR("%s invalid band:%u\n", __func__, Band);
rtw_warn_on(1);
goto exit;
}
if (Band == BAND_ON_5G && tlrs == TXPWR_LMT_RS_CCK) {
RTW_ERR("5G has no CCK\n");
goto exit;
}
if (lock)
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
if (!regd_name) /* no regd_name specified, use currnet */
regd_name = rfctl->regd_name;
if (rfctl->txpwr_regd_num == 0
|| strcmp(regd_name, regd_str(TXPWR_LMT_NONE)) == 0)
goto release_lock;
if (strcmp(regd_name, regd_str(TXPWR_LMT_WW)) == 0)
is_ww_regd = 1;
if (!is_ww_regd) {
ent = _rtw_txpwr_lmt_get_by_name(rfctl, regd_name);
if (!ent)
goto release_lock;
}
ch_idx = phy_GetChannelIndexOfTxPowerLimit(Band, cch);
if (ch_idx == -1)
goto release_lock;
if (Band == BAND_ON_2_4G) {
if (!is_ww_regd) {
lmt = ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx];
if (lmt != ww_lmt_val)
goto release_lock;
}
/* search for min value for WW regd or WW limit */
lmt = hal_spec->txgi_max;
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
if (ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx] != ww_lmt_val)
lmt = rtw_min(lmt, ent->lmt_2g[bw][tlrs][ch_idx][ntx_idx]);
}
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else if (Band == BAND_ON_5G) {
if (!is_ww_regd) {
lmt = ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx];
if (lmt != ww_lmt_val)
goto release_lock;
}
/* search for min value for WW regd or WW limit */
lmt = hal_spec->txgi_max;
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
if (ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx] != ww_lmt_val)
lmt = rtw_min(lmt, ent->lmt_5g[bw][tlrs - 1][ch_idx][ntx_idx]);
}
}
#endif
release_lock:
if (lock)
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
exit:
return lmt;
}
/*
* return txpwr limit diff value
* hal_spec->txgi_max is returned when NO limit
*/
inline s8 phy_get_txpwr_lmt(_adapter *adapter
, const char *regd_name
, BAND_TYPE band, enum channel_width bw
, u8 rfpath, u8 rs, u8 ntx_idx, u8 cch, u8 lock
)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 tlrs;
s8 lmt = hal_spec->txgi_max;
if (IS_CCK_RATE_SECTION(rs))
tlrs = TXPWR_LMT_RS_CCK;
else if (IS_OFDM_RATE_SECTION(rs))
tlrs = TXPWR_LMT_RS_OFDM;
else if (IS_HT_RATE_SECTION(rs))
tlrs = TXPWR_LMT_RS_HT;
else if (IS_VHT_RATE_SECTION(rs))
tlrs = TXPWR_LMT_RS_VHT;
else {
RTW_ERR("%s invalid rs %u\n", __func__, rs);
rtw_warn_on(1);
goto exit;
}
lmt = phy_get_txpwr_lmt_abs(adapter, regd_name, band, bw, tlrs, ntx_idx, cch, lock);
if (lmt != hal_spec->txgi_max) {
/* return diff value */
lmt = lmt - PHY_GetTxPowerByRateBase(adapter, band, rfpath, rs);
}
exit:
return lmt;
}
/*
* May search for secondary channels for min limit
* return txpwr limit diff value
*/
s8
PHY_GetTxPowerLimit(_adapter *adapter
, const char *regd_name
, BAND_TYPE band, enum channel_width bw
, u8 rfpath, u8 rate, u8 ntx_idx, u8 cch)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
BOOLEAN no_sc = _FALSE;
s8 tlrs = -1, rs = -1;
s8 lmt = hal_spec->txgi_max;
u8 tmp_cch = 0;
u8 tmp_bw;
u8 bw_bmp = 0;
s8 min_lmt = hal_spec->txgi_max;
u8 final_bw = bw, final_cch = cch;
_irqL irqL;
#ifdef CONFIG_MP_INCLUDED
/* MP mode channel don't use secondary channel */
if (rtw_mp_mode_check(adapter) == _TRUE)
no_sc = _TRUE;
#endif
if (IS_CCK_RATE(rate)) {
tlrs = TXPWR_LMT_RS_CCK;
rs = CCK;
} else if (IS_OFDM_RATE(rate)) {
tlrs = TXPWR_LMT_RS_OFDM;
rs = OFDM;
} else if (IS_HT_RATE(rate)) {
tlrs = TXPWR_LMT_RS_HT;
rs = HT_1SS + (IS_HT1SS_RATE(rate) ? 0 : IS_HT2SS_RATE(rate) ? 1 : IS_HT3SS_RATE(rate) ? 2 : IS_HT4SS_RATE(rate) ? 3 : 0);
} else if (IS_VHT_RATE(rate)) {
tlrs = TXPWR_LMT_RS_VHT;
rs = VHT_1SS + (IS_VHT1SS_RATE(rate) ? 0 : IS_VHT2SS_RATE(rate) ? 1 : IS_VHT3SS_RATE(rate) ? 2 : IS_VHT4SS_RATE(rate) ? 3 : 0);
} else {
RTW_ERR("%s invalid rate 0x%x\n", __func__, rate);
rtw_warn_on(1);
goto exit;
}
if (no_sc == _TRUE) {
/* use the input center channel and bandwidth directly */
tmp_cch = cch;
bw_bmp = ch_width_to_bw_cap(bw);
} else {
/*
* find the possible tx bandwidth bmp for this rate, and then will get center channel for each bandwidth
* if no possible tx bandwidth bmp, select valid bandwidth up to current RF bandwidth into bmp
*/
if (tlrs == TXPWR_LMT_RS_CCK || tlrs == TXPWR_LMT_RS_OFDM)
bw_bmp = BW_CAP_20M; /* CCK, OFDM only BW 20M */
else if (tlrs == TXPWR_LMT_RS_HT) {
bw_bmp = rtw_get_tx_bw_bmp_of_ht_rate(dvobj, rate, bw);
if (bw_bmp == 0)
bw_bmp = ch_width_to_bw_cap(bw > CHANNEL_WIDTH_40 ? CHANNEL_WIDTH_40 : bw);
} else if (tlrs == TXPWR_LMT_RS_VHT) {
bw_bmp = rtw_get_tx_bw_bmp_of_vht_rate(dvobj, rate, bw);
if (bw_bmp == 0)
bw_bmp = ch_width_to_bw_cap(bw > CHANNEL_WIDTH_160 ? CHANNEL_WIDTH_160 : bw);
} else
rtw_warn_on(1);
}
if (bw_bmp == 0)
goto exit;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
/* loop for each possible tx bandwidth to find minimum limit */
for (tmp_bw = CHANNEL_WIDTH_20; tmp_bw <= bw; tmp_bw++) {
if (!(ch_width_to_bw_cap(tmp_bw) & bw_bmp))
continue;
if (no_sc == _FALSE) {
if (tmp_bw == CHANNEL_WIDTH_20)
tmp_cch = hal_data->cch_20;
else if (tmp_bw == CHANNEL_WIDTH_40)
tmp_cch = hal_data->cch_40;
else if (tmp_bw == CHANNEL_WIDTH_80)
tmp_cch = hal_data->cch_80;
else {
tmp_cch = 0;
rtw_warn_on(1);
}
}
lmt = phy_get_txpwr_lmt_abs(adapter, regd_name, band, tmp_bw, tlrs, ntx_idx, tmp_cch, 0);
if (min_lmt >= lmt) {
min_lmt = lmt;
final_cch = tmp_cch;
final_bw = tmp_bw;
}
}
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
if (min_lmt != hal_spec->txgi_max) {
/* return diff value */
min_lmt = min_lmt - PHY_GetTxPowerByRateBase(adapter, band, rfpath, rs);
}
exit:
if (0) {
if (final_bw != bw && (IS_HT_RATE(rate) || IS_VHT_RATE(rate)))
RTW_INFO("%s min_lmt: %s ch%u -> %s ch%u\n"
, MGN_RATE_STR(rate)
, ch_width_str(bw), cch
, ch_width_str(final_bw), final_cch);
}
return min_lmt;
}
static void phy_txpwr_lmt_cck_ofdm_mt_chk(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
struct txpwr_lmt_ent *ent;
_list *cur, *head;
u8 channel, tlrs, ntx_idx;
rfctl->txpwr_lmt_2g_cck_ofdm_state = 0;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
rfctl->txpwr_lmt_5g_cck_ofdm_state = 0;
#endif
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
/* check 2G CCK, OFDM state*/
for (tlrs = TXPWR_LMT_RS_CCK; tlrs <= TXPWR_LMT_RS_OFDM; tlrs++) {
for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
for (channel = 0; channel < CENTER_CH_2G_NUM; ++channel) {
if (ent->lmt_2g[CHANNEL_WIDTH_20][tlrs][channel][ntx_idx] != hal_spec->txgi_max) {
if (tlrs == TXPWR_LMT_RS_CCK)
rfctl->txpwr_lmt_2g_cck_ofdm_state |= TXPWR_LMT_HAS_CCK_1T << ntx_idx;
else
rfctl->txpwr_lmt_2g_cck_ofdm_state |= TXPWR_LMT_HAS_OFDM_1T << ntx_idx;
break;
}
}
}
}
/* if 2G OFDM multi-TX is not defined, reference HT20 */
for (channel = 0; channel < CENTER_CH_2G_NUM; ++channel) {
for (ntx_idx = RF_2TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
if (rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx))
continue;
ent->lmt_2g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM][channel][ntx_idx] =
ent->lmt_2g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_HT][channel][ntx_idx];
}
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
/* check 5G OFDM state*/
for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
if (ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM - 1][channel][ntx_idx] != hal_spec->txgi_max) {
rfctl->txpwr_lmt_5g_cck_ofdm_state |= TXPWR_LMT_HAS_OFDM_1T << ntx_idx;
break;
}
}
}
for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
for (ntx_idx = RF_2TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
if (rfctl->txpwr_lmt_5g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx))
continue;
/* if 5G OFDM multi-TX is not defined, reference HT20 */
ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_OFDM - 1][channel][ntx_idx] =
ent->lmt_5g[CHANNEL_WIDTH_20][TXPWR_LMT_RS_HT - 1][channel][ntx_idx];
}
}
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
}
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
static void phy_txpwr_lmt_cross_ref_ht_vht(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
struct txpwr_lmt_ent *ent;
_list *cur, *head;
u8 bw, channel, tlrs, ref_tlrs, ntx_idx;
int ht_ref_vht_5g_20_40 = 0;
int vht_ref_ht_5g_20_40 = 0;
int ht_has_ref_5g_20_40 = 0;
int vht_has_ref_5g_20_40 = 0;
rfctl->txpwr_lmt_5g_20_40_ref = 0;
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
for (bw = 0; bw < MAX_5G_BANDWIDTH_NUM; ++bw) {
for (channel = 0; channel < CENTER_CH_5G_ALL_NUM; ++channel) {
for (tlrs = TXPWR_LMT_RS_HT; tlrs < TXPWR_LMT_RS_NUM; ++tlrs) {
/* 5G 20M 40M VHT and HT can cross reference */
if (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40) {
if (tlrs == TXPWR_LMT_RS_HT)
ref_tlrs = TXPWR_LMT_RS_VHT;
else if (tlrs == TXPWR_LMT_RS_VHT)
ref_tlrs = TXPWR_LMT_RS_HT;
else
continue;
for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
if (ent->lmt_5g[bw][ref_tlrs - 1][channel][ntx_idx] == hal_spec->txgi_max)
continue;
if (tlrs == TXPWR_LMT_RS_HT)
ht_has_ref_5g_20_40++;
else if (tlrs == TXPWR_LMT_RS_VHT)
vht_has_ref_5g_20_40++;
else
continue;
if (ent->lmt_5g[bw][tlrs - 1][channel][ntx_idx] != hal_spec->txgi_max)
continue;
if (tlrs == TXPWR_LMT_RS_HT && ref_tlrs == TXPWR_LMT_RS_VHT)
ht_ref_vht_5g_20_40++;
else if (tlrs == TXPWR_LMT_RS_VHT && ref_tlrs == TXPWR_LMT_RS_HT)
vht_ref_ht_5g_20_40++;
if (0)
RTW_INFO("reg:%s, bw:%u, ch:%u, %s-%uT ref %s-%uT\n"
, ent->regd_name, bw, channel
, txpwr_lmt_rs_str(tlrs), ntx_idx + 1
, txpwr_lmt_rs_str(ref_tlrs), ntx_idx + 1);
ent->lmt_5g[bw][tlrs - 1][channel][ntx_idx] =
ent->lmt_5g[bw][ref_tlrs - 1][channel][ntx_idx];
}
}
}
}
}
}
if (0) {
RTW_INFO("ht_ref_vht_5g_20_40:%d, ht_has_ref_5g_20_40:%d\n", ht_ref_vht_5g_20_40, ht_has_ref_5g_20_40);
RTW_INFO("vht_ref_ht_5g_20_40:%d, vht_has_ref_5g_20_40:%d\n", vht_ref_ht_5g_20_40, vht_has_ref_5g_20_40);
}
/* 5G 20M&40M HT all come from VHT*/
if (ht_ref_vht_5g_20_40 && ht_has_ref_5g_20_40 == ht_ref_vht_5g_20_40)
rfctl->txpwr_lmt_5g_20_40_ref |= TXPWR_LMT_REF_HT_FROM_VHT;
/* 5G 20M&40M VHT all come from HT*/
if (vht_ref_ht_5g_20_40 && vht_has_ref_5g_20_40 == vht_ref_ht_5g_20_40)
rfctl->txpwr_lmt_5g_20_40_ref |= TXPWR_LMT_REF_VHT_FROM_HT;
}
#endif /* CONFIG_IEEE80211_BAND_5GHZ */
#ifndef DBG_TXPWR_LMT_BAND_CHK
#define DBG_TXPWR_LMT_BAND_CHK 0
#endif
#if DBG_TXPWR_LMT_BAND_CHK
/* check if larger bandwidth limit is less than smaller bandwidth for HT & VHT rate */
void phy_txpwr_limit_bandwidth_chk(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 band, bw, path, tlrs, ntx_idx, cch, offset, scch;
u8 ch_num, n, i;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
for (bw = CHANNEL_WIDTH_40; bw <= CHANNEL_WIDTH_80; bw++) {
if (bw >= CHANNEL_WIDTH_160)
continue;
if (band == BAND_ON_2_4G && bw >= CHANNEL_WIDTH_80)
continue;
if (band == BAND_ON_2_4G)
ch_num = center_chs_2g_num(bw);
else
ch_num = center_chs_5g_num(bw);
if (ch_num == 0) {
rtw_warn_on(1);
break;
}
for (tlrs = TXPWR_LMT_RS_HT; tlrs < TXPWR_LMT_RS_NUM; tlrs++) {
if (band == BAND_ON_2_4G && tlrs == TXPWR_LMT_RS_VHT)
continue;
if (band == BAND_ON_5G && tlrs == TXPWR_LMT_RS_CCK)
continue;
if (bw > CHANNEL_WIDTH_20 && (tlrs == TXPWR_LMT_RS_CCK || tlrs == TXPWR_LMT_RS_OFDM))
continue;
if (bw > CHANNEL_WIDTH_40 && tlrs == TXPWR_LMT_RS_HT)
continue;
if (tlrs == TXPWR_LMT_RS_VHT && !IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
continue;
for (ntx_idx = RF_1TX; ntx_idx < MAX_TX_COUNT; ntx_idx++) {
struct txpwr_lmt_ent *ent;
_list *cur, *head;
if (ntx_idx >= hal_spec->tx_nss_num)
continue;
/* bypass CCK multi-TX is not defined */
if (tlrs == TXPWR_LMT_RS_CCK && ntx_idx > RF_1TX) {
if (band == BAND_ON_2_4G
&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_CCK_1T << ntx_idx)))
continue;
}
/* bypass OFDM multi-TX is not defined */
if (tlrs == TXPWR_LMT_RS_OFDM && ntx_idx > RF_1TX) {
if (band == BAND_ON_2_4G
&& !(rfctl->txpwr_lmt_2g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
continue;
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (band == BAND_ON_5G
&& !(rfctl->txpwr_lmt_5g_cck_ofdm_state & (TXPWR_LMT_HAS_OFDM_1T << ntx_idx)))
continue;
#endif
}
/* bypass 5G 20M, 40M pure reference */
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (band == BAND_ON_5G && (bw == CHANNEL_WIDTH_20 || bw == CHANNEL_WIDTH_40)) {
if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_HT_FROM_VHT) {
if (tlrs == TXPWR_LMT_RS_HT)
continue;
} else if (rfctl->txpwr_lmt_5g_20_40_ref == TXPWR_LMT_REF_VHT_FROM_HT) {
if (tlrs == TXPWR_LMT_RS_VHT && bw <= CHANNEL_WIDTH_40)
continue;
}
}
#endif
for (n = 0; n < ch_num; n++) {
u8 cch_by_bw[3];
u8 offset_by_bw; /* bitmap, 0 for lower, 1 for upper */
u8 bw_pos;
s8 lmt[3];
if (band == BAND_ON_2_4G)
cch = center_chs_2g(bw, n);
else
cch = center_chs_5g(bw, n);
if (cch == 0) {
rtw_warn_on(1);
break;
}
_rtw_memset(cch_by_bw, 0, 3);
cch_by_bw[bw] = cch;
offset_by_bw = 0x01;
do {
for (bw_pos = bw; bw_pos >= CHANNEL_WIDTH_40; bw_pos--)
cch_by_bw[bw_pos - 1] = rtw_get_scch_by_cch_offset(cch_by_bw[bw_pos], bw_pos, offset_by_bw & BIT(bw_pos) ? HAL_PRIME_CHNL_OFFSET_UPPER : HAL_PRIME_CHNL_OFFSET_LOWER);
head = &rfctl->txpwr_lmt_list;
cur = get_next(head);
while ((rtw_end_of_queue_search(head, cur)) == _FALSE) {
ent = LIST_CONTAINOR(cur, struct txpwr_lmt_ent, list);
cur = get_next(cur);
for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
lmt[bw_pos] = phy_get_txpwr_lmt_abs(adapter, ent->regd_name, band, bw_pos, tlrs, ntx_idx, cch_by_bw[bw_pos], 0);
for (bw_pos = bw; bw_pos > CHANNEL_WIDTH_20; bw_pos--)
if (lmt[bw_pos] > lmt[bw_pos - 1])
break;
if (bw_pos == CHANNEL_WIDTH_20)
continue;
RTW_PRINT_SEL(RTW_DBGDUMP, "[%s][%s][%s][%uT][%-4s] cch:"
, band_str(band)
, ch_width_str(bw)
, txpwr_lmt_rs_str(tlrs)
, ntx_idx + 1
, ent->regd_name
);
for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
_RTW_PRINT_SEL(RTW_DBGDUMP, "%03u ", cch_by_bw[bw_pos]);
_RTW_PRINT_SEL(RTW_DBGDUMP, "limit:");
for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--) {
if (lmt[bw_pos] == hal_spec->txgi_max)
_RTW_PRINT_SEL(RTW_DBGDUMP, "N/A ");
else if (lmt[bw_pos] > -hal_spec->txgi_pdbm && lmt[bw_pos] < 0) /* -1 < value < 0 */
_RTW_PRINT_SEL(RTW_DBGDUMP, "-0.%d", (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
else if (lmt[bw_pos] % hal_spec->txgi_pdbm)
_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d.%d ", lmt[bw_pos] / hal_spec->txgi_pdbm, (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
else
_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d ", lmt[bw_pos] / hal_spec->txgi_pdbm);
}
_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
}
for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
lmt[bw_pos] = phy_get_txpwr_lmt_abs(adapter, regd_str(TXPWR_LMT_WW), band, bw_pos, tlrs, ntx_idx, cch_by_bw[bw_pos], 0);
for (bw_pos = bw; bw_pos > CHANNEL_WIDTH_20; bw_pos--)
if (lmt[bw_pos] > lmt[bw_pos - 1])
break;
if (bw_pos != CHANNEL_WIDTH_20) {
RTW_PRINT_SEL(RTW_DBGDUMP, "[%s][%s][%s][%uT][%-4s] cch:"
, band_str(band)
, ch_width_str(bw)
, txpwr_lmt_rs_str(tlrs)
, ntx_idx + 1
, regd_str(TXPWR_LMT_WW)
);
for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--)
_RTW_PRINT_SEL(RTW_DBGDUMP, "%03u ", cch_by_bw[bw_pos]);
_RTW_PRINT_SEL(RTW_DBGDUMP, "limit:");
for (bw_pos = bw; bw_pos < CHANNEL_WIDTH_160; bw_pos--) {
if (lmt[bw_pos] == hal_spec->txgi_max)
_RTW_PRINT_SEL(RTW_DBGDUMP, "N/A ");
else if (lmt[bw_pos] > -hal_spec->txgi_pdbm && lmt[bw_pos] < 0) /* -1 < value < 0 */
_RTW_PRINT_SEL(RTW_DBGDUMP, "-0.%d", (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
else if (lmt[bw_pos] % hal_spec->txgi_pdbm)
_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d.%d ", lmt[bw_pos] / hal_spec->txgi_pdbm, (rtw_abs(lmt[bw_pos]) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
else
_RTW_PRINT_SEL(RTW_DBGDUMP, "%2d ", lmt[bw_pos] / hal_spec->txgi_pdbm);
}
_RTW_PRINT_SEL(RTW_DBGDUMP, "\n");
}
offset_by_bw += 2;
if (offset_by_bw & BIT(bw + 1))
break;
} while (1); /* loop for all ch combinations */
} /* loop for center channels */
} /* loop fo each ntx_idx */
} /* loop for tlrs */
} /* loop for bandwidth */
} /* loop for band */
}
#endif /* DBG_TXPWR_LMT_BAND_CHK */
static void phy_txpwr_lmt_post_hdl(_adapter *adapter)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
_irqL irqL;
_enter_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
#ifdef CONFIG_IEEE80211_BAND_5GHZ
if (IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
phy_txpwr_lmt_cross_ref_ht_vht(adapter);
#endif
phy_txpwr_lmt_cck_ofdm_mt_chk(adapter);
#if DBG_TXPWR_LMT_BAND_CHK
phy_txpwr_limit_bandwidth_chk(adapter);
#endif
_exit_critical_mutex(&rfctl->txpwr_lmt_mutex, &irqL);
}
BOOLEAN
GetS1ByteIntegerFromStringInDecimal(
char *str,
s8 *val
)
{
u8 negative = 0;
u16 i = 0;
*val = 0;
while (str[i] != '\0') {
if (i == 0 && (str[i] == '+' || str[i] == '-')) {
if (str[i] == '-')
negative = 1;
} else if (str[i] >= '0' && str[i] <= '9') {
*val *= 10;
*val += (str[i] - '0');
} else
return _FALSE;
++i;
}
if (negative)
*val = -*val;
return _TRUE;
}
#endif /* CONFIG_TXPWR_LIMIT */
/*
* phy_set_tx_power_limit - Parsing TX power limit from phydm array, called by odm_ConfigBB_TXPWR_LMT_XXX in phydm
*/
void
phy_set_tx_power_limit(
struct dm_struct *pDM_Odm,
u8 *Regulation,
u8 *Band,
u8 *Bandwidth,
u8 *RateSection,
u8 *ntx,
u8 *Channel,
u8 *PowerLimit
)
{
#if CONFIG_TXPWR_LIMIT
PADAPTER Adapter = pDM_Odm->adapter;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
u8 band = 0, bandwidth = 0, tlrs = 0, channel;
u8 ntx_idx;
s8 powerLimit = 0, prevPowerLimit, channelIndex;
s8 ww_lmt_val = phy_txpwr_ww_lmt_value(Adapter);
if (0)
RTW_INFO("Index of power limit table [regulation %s][band %s][bw %s][rate section %s][ntx %s][chnl %s][val %s]\n"
, Regulation, Band, Bandwidth, RateSection, ntx, Channel, PowerLimit);
if (GetU1ByteIntegerFromStringInDecimal((char *)Channel, &channel) == _FALSE
|| GetS1ByteIntegerFromStringInDecimal((char *)PowerLimit, &powerLimit) == _FALSE
) {
RTW_PRINT("Illegal index of power limit table [ch %s][val %s]\n", Channel, PowerLimit);
return;
}
if (powerLimit != ww_lmt_val) {
if (powerLimit < -hal_spec->txgi_max || powerLimit > hal_spec->txgi_max)
RTW_PRINT("Illegal power limit value [ch %s][val %s]\n", Channel, PowerLimit);
if (powerLimit > hal_spec->txgi_max)
powerLimit = hal_spec->txgi_max;
else if (powerLimit < -hal_spec->txgi_max)
powerLimit = ww_lmt_val + 1;
}
if (eqNByte(RateSection, (u8 *)("CCK"), 3))
tlrs = TXPWR_LMT_RS_CCK;
else if (eqNByte(RateSection, (u8 *)("OFDM"), 4))
tlrs = TXPWR_LMT_RS_OFDM;
else if (eqNByte(RateSection, (u8 *)("HT"), 2))
tlrs = TXPWR_LMT_RS_HT;
else if (eqNByte(RateSection, (u8 *)("VHT"), 3))
tlrs = TXPWR_LMT_RS_VHT;
else {
RTW_PRINT("Wrong rate section:%s\n", RateSection);
return;
}
if (eqNByte(ntx, (u8 *)("1T"), 2))
ntx_idx = RF_1TX;
else if (eqNByte(ntx, (u8 *)("2T"), 2))
ntx_idx = RF_2TX;
else if (eqNByte(ntx, (u8 *)("3T"), 2))
ntx_idx = RF_3TX;
else if (eqNByte(ntx, (u8 *)("4T"), 2))
ntx_idx = RF_4TX;
else {
RTW_PRINT("Wrong tx num:%s\n", ntx);
return;
}
if (eqNByte(Bandwidth, (u8 *)("20M"), 3))
bandwidth = CHANNEL_WIDTH_20;
else if (eqNByte(Bandwidth, (u8 *)("40M"), 3))
bandwidth = CHANNEL_WIDTH_40;
else if (eqNByte(Bandwidth, (u8 *)("80M"), 3))
bandwidth = CHANNEL_WIDTH_80;
else if (eqNByte(Bandwidth, (u8 *)("160M"), 4))
bandwidth = CHANNEL_WIDTH_160;
else {
RTW_PRINT("unknown bandwidth: %s\n", Bandwidth);
return;
}
if (eqNByte(Band, (u8 *)("2.4G"), 4)) {
band = BAND_ON_2_4G;
channelIndex = phy_GetChannelIndexOfTxPowerLimit(BAND_ON_2_4G, channel);
if (channelIndex == -1) {
RTW_PRINT("unsupported channel: %d at 2.4G\n", channel);
return;
}
if (bandwidth >= MAX_2_4G_BANDWIDTH_NUM) {
RTW_PRINT("unsupported bandwidth: %s at 2.4G\n", Bandwidth);
return;
}
rtw_txpwr_lmt_add(adapter_to_rfctl(Adapter), Regulation, band, bandwidth, tlrs, ntx_idx, channelIndex, powerLimit);
}
#ifdef CONFIG_IEEE80211_BAND_5GHZ
else if (eqNByte(Band, (u8 *)("5G"), 2)) {
band = BAND_ON_5G;
channelIndex = phy_GetChannelIndexOfTxPowerLimit(BAND_ON_5G, channel);
if (channelIndex == -1) {
RTW_PRINT("unsupported channel: %d at 5G\n", channel);
return;
}
rtw_txpwr_lmt_add(adapter_to_rfctl(Adapter), Regulation, band, bandwidth, tlrs, ntx_idx, channelIndex, powerLimit);
}
#endif
else {
RTW_PRINT("unknown/unsupported band:%s\n", Band);
return;
}
#endif
}
u8
phy_get_tx_power_index(
PADAPTER pAdapter,
enum rf_path RFPath,
u8 Rate,
enum channel_width BandWidth,
u8 Channel
)
{
return rtw_hal_get_tx_power_index(pAdapter, RFPath, Rate, BandWidth, Channel, NULL);
}
void
PHY_SetTxPowerIndex(
PADAPTER pAdapter,
u32 PowerIndex,
enum rf_path RFPath,
u8 Rate
)
{
rtw_hal_set_tx_power_index(pAdapter, PowerIndex, RFPath, Rate);
}
void dump_tx_power_idx_title(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 bw = hal_data->current_channel_bw;
RTW_PRINT_SEL(sel, "%s", ch_width_str(bw));
if (bw >= CHANNEL_WIDTH_80)
_RTW_PRINT_SEL(sel, ", cch80:%u", hal_data->cch_80);
if (bw >= CHANNEL_WIDTH_40)
_RTW_PRINT_SEL(sel, ", cch40:%u", hal_data->cch_40);
_RTW_PRINT_SEL(sel, ", cch20:%u\n", hal_data->cch_20);
RTW_PRINT_SEL(sel, "%-4s %-9s %2s %-3s%6s %-3s %-3s %-4s %-4s %-3s %-5s %-3s %-3s\n"
, "path", "rate", "", "pwr", "", "pg", "", "(byr", "lmt)", "tpt", "ebias", "btc", "dpd");
}
void dump_tx_power_idx_by_path_rs(void *sel, _adapter *adapter, u8 rfpath, u8 rs)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
u8 power_idx;
struct txpwr_idx_comp tic;
u8 tx_num, i;
u8 band = hal_data->current_band_type;
u8 cch = hal_data->current_channel;
u8 bw = hal_data->current_channel_bw;
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, rfpath))
return;
if (rs >= RATE_SECTION_NUM)
return;
tx_num = rate_section_to_tx_num(rs);
if (tx_num >= hal_spec->tx_nss_num || tx_num >= hal_spec->max_tx_cnt)
return;
if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
return;
if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
return;
for (i = 0; i < rates_by_sections[rs].rate_num; i++) {
power_idx = rtw_hal_get_tx_power_index(adapter, rfpath, rates_by_sections[rs].rates[i], bw, cch, &tic);
RTW_PRINT_SEL(sel, "%4c %9s %uT %3u(0x%02x) %3u %3d (%3d %3d) %3d %5d %3d %3d\n"
, rf_path_char(rfpath), MGN_RATE_STR(rates_by_sections[rs].rates[i]), tic.ntx_idx + 1
, power_idx, power_idx, tic.pg, (tic.by_rate > tic.limit ? tic.limit : tic.by_rate)
, tic.by_rate, tic.limit, tic.tpt, tic.ebias, tic.btc, tic.dpd);
}
}
void dump_tx_power_idx(void *sel, _adapter *adapter)
{
u8 rfpath, rs;
dump_tx_power_idx_title(sel, adapter);
for (rfpath = RF_PATH_A; rfpath < RF_PATH_MAX; rfpath++)
for (rs = CCK; rs < RATE_SECTION_NUM; rs++)
dump_tx_power_idx_by_path_rs(sel, adapter, rfpath, rs);
}
bool phy_is_tx_power_limit_needed(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
#if CONFIG_TXPWR_LIMIT
if (regsty->RegEnableTxPowerLimit == 1
|| (regsty->RegEnableTxPowerLimit == 2 && hal_data->EEPROMRegulatory == 1))
return _TRUE;
#endif
return _FALSE;
}
bool phy_is_tx_power_by_rate_needed(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
if (regsty->RegEnableTxPowerByRate == 1
|| (regsty->RegEnableTxPowerByRate == 2 && hal_data->EEPROMRegulatory != 2))
return _TRUE;
return _FALSE;
}
int phy_load_tx_power_by_rate(_adapter *adapter, u8 chk_file)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
int ret = _FAIL;
hal_data->txpwr_by_rate_loaded = 0;
PHY_InitTxPowerByRate(adapter);
/* tx power limit is based on tx power by rate */
hal_data->txpwr_limit_loaded = 0;
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
if (chk_file
&& phy_ConfigBBWithPgParaFile(adapter, PHY_FILE_PHY_REG_PG) == _SUCCESS
) {
hal_data->txpwr_by_rate_from_file = 1;
goto post_hdl;
}
#endif
#ifdef CONFIG_EMBEDDED_FWIMG
if (HAL_STATUS_SUCCESS == odm_config_bb_with_header_file(&hal_data->odmpriv, CONFIG_BB_PHY_REG_PG)) {
RTW_INFO("default power by rate loaded\n");
hal_data->txpwr_by_rate_from_file = 0;
goto post_hdl;
}
#endif
RTW_ERR("%s():Read Tx power by rate fail\n", __func__);
goto exit;
post_hdl:
if (hal_data->odmpriv.phy_reg_pg_value_type != PHY_REG_PG_EXACT_VALUE) {
rtw_warn_on(1);
goto exit;
}
PHY_TxPowerByRateConfiguration(adapter);
hal_data->txpwr_by_rate_loaded = 1;
ret = _SUCCESS;
exit:
return ret;
}
#if CONFIG_TXPWR_LIMIT
int phy_load_tx_power_limit(_adapter *adapter, u8 chk_file)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct registry_priv *regsty = dvobj_to_regsty(adapter_to_dvobj(adapter));
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
int ret = _FAIL;
hal_data->txpwr_limit_loaded = 0;
rtw_regd_exc_list_free(rfctl);
rtw_txpwr_lmt_list_free(rfctl);
if (!hal_data->txpwr_by_rate_loaded && regsty->target_tx_pwr_valid != _TRUE) {
RTW_ERR("%s():Read Tx power limit before target tx power is specify\n", __func__);
goto exit;
}
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
if (chk_file
&& PHY_ConfigRFWithPowerLimitTableParaFile(adapter, PHY_FILE_TXPWR_LMT) == _SUCCESS
) {
hal_data->txpwr_limit_from_file = 1;
goto post_hdl;
}
#endif
#ifdef CONFIG_EMBEDDED_FWIMG
if (odm_config_rf_with_header_file(&hal_data->odmpriv, CONFIG_RF_TXPWR_LMT, RF_PATH_A) == HAL_STATUS_SUCCESS) {
RTW_INFO("default power limit loaded\n");
hal_data->txpwr_limit_from_file = 0;
goto post_hdl;
}
#endif
RTW_ERR("%s():Read Tx power limit fail\n", __func__);
goto exit;
post_hdl:
phy_txpwr_lmt_post_hdl(adapter);
rtw_txpwr_init_regd(rfctl);
hal_data->txpwr_limit_loaded = 1;
ret = _SUCCESS;
exit:
return ret;
}
#endif /* CONFIG_TXPWR_LIMIT */
void phy_load_tx_power_ext_info(_adapter *adapter, u8 chk_file)
{
struct registry_priv *regsty = adapter_to_regsty(adapter);
/* check registy target tx power */
regsty->target_tx_pwr_valid = rtw_regsty_chk_target_tx_power_valid(adapter);
/* power by rate and limit */
if (phy_is_tx_power_by_rate_needed(adapter)
|| (phy_is_tx_power_limit_needed(adapter) && regsty->target_tx_pwr_valid != _TRUE)
)
phy_load_tx_power_by_rate(adapter, chk_file);
#if CONFIG_TXPWR_LIMIT
if (phy_is_tx_power_limit_needed(adapter))
phy_load_tx_power_limit(adapter, chk_file);
#endif
}
inline void phy_reload_tx_power_ext_info(_adapter *adapter)
{
phy_load_tx_power_ext_info(adapter, 1);
}
inline void phy_reload_default_tx_power_ext_info(_adapter *adapter)
{
phy_load_tx_power_ext_info(adapter, 0);
}
void dump_tx_power_ext_info(void *sel, _adapter *adapter)
{
struct registry_priv *regsty = adapter_to_regsty(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
if (regsty->target_tx_pwr_valid == _TRUE)
RTW_PRINT_SEL(sel, "target_tx_power: from registry\n");
else if (phy_is_tx_power_by_rate_needed(adapter))
RTW_PRINT_SEL(sel, "target_tx_power: from power by rate\n");
else
RTW_PRINT_SEL(sel, "target_tx_power: unavailable\n");
RTW_PRINT_SEL(sel, "tx_power_by_rate: %s, %s, %s\n"
, phy_is_tx_power_by_rate_needed(adapter) ? "enabled" : "disabled"
, hal_data->txpwr_by_rate_loaded ? "loaded" : "unloaded"
, hal_data->txpwr_by_rate_from_file ? "file" : "default"
);
RTW_PRINT_SEL(sel, "tx_power_limit: %s, %s, %s\n"
, phy_is_tx_power_limit_needed(adapter) ? "enabled" : "disabled"
, hal_data->txpwr_limit_loaded ? "loaded" : "unloaded"
, hal_data->txpwr_limit_from_file ? "file" : "default"
);
}
void dump_target_tx_power(void *sel, _adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct registry_priv *regsty = adapter_to_regsty(adapter);
int path, tx_num, band, rs;
u8 target;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
for (path = 0; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
break;
RTW_PRINT_SEL(sel, "[%s][%c]%s\n", band_str(band), rf_path_char(path)
, (regsty->target_tx_pwr_valid == _FALSE && hal_data->txpwr_by_rate_undefined_band_path[band][path]) ? "(dup)" : "");
for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
tx_num = rate_section_to_tx_num(rs);
if (tx_num >= hal_spec->tx_nss_num)
continue;
if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
continue;
if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
continue;
target = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
if (target % hal_spec->txgi_pdbm) {
_RTW_PRINT_SEL(sel, "%7s: %2d.%d\n", rate_section_str(rs)
, target / hal_spec->txgi_pdbm, (target % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
} else {
_RTW_PRINT_SEL(sel, "%7s: %5d\n", rate_section_str(rs)
, target / hal_spec->txgi_pdbm);
}
}
}
}
return;
}
void dump_tx_power_by_rate(void *sel, _adapter *adapter)
{
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
int path, tx_num, band, n, rs;
u8 rate_num, max_rate_num, base;
s8 by_rate_offset;
for (band = BAND_ON_2_4G; band <= BAND_ON_5G; band++) {
if (!hal_is_band_support(adapter, band))
continue;
for (path = 0; path < RF_PATH_MAX; path++) {
if (!HAL_SPEC_CHK_RF_PATH(hal_spec, band, path))
break;
RTW_PRINT_SEL(sel, "[%s][%c]%s\n", band_str(band), rf_path_char(path)
, hal_data->txpwr_by_rate_undefined_band_path[band][path] ? "(dup)" : "");
for (rs = 0; rs < RATE_SECTION_NUM; rs++) {
tx_num = rate_section_to_tx_num(rs);
if (tx_num >= hal_spec->tx_nss_num)
continue;
if (band == BAND_ON_5G && IS_CCK_RATE_SECTION(rs))
continue;
if (IS_VHT_RATE_SECTION(rs) && !IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
continue;
if (IS_HARDWARE_TYPE_JAGUAR_ALL(adapter))
max_rate_num = 10;
else
max_rate_num = 8;
rate_num = rate_section_rate_num(rs);
base = PHY_GetTxPowerByRateBase(adapter, band, path, rs);
RTW_PRINT_SEL(sel, "%7s: ", rate_section_str(rs));
/* dump power by rate in db */
for (n = rate_num - 1; n >= 0; n--) {
by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, rates_by_sections[rs].rates[n]);
if ((base + by_rate_offset) % hal_spec->txgi_pdbm) {
_RTW_PRINT_SEL(sel, "%2d.%d ", (base + by_rate_offset) / hal_spec->txgi_pdbm
, ((base + by_rate_offset) % hal_spec->txgi_pdbm) * 100 / hal_spec->txgi_pdbm);
} else
_RTW_PRINT_SEL(sel, "%5d ", (base + by_rate_offset) / hal_spec->txgi_pdbm);
}
for (n = 0; n < max_rate_num - rate_num; n++)
_RTW_PRINT_SEL(sel, "%5s ", "");
_RTW_PRINT_SEL(sel, "|");
/* dump power by rate in offset */
for (n = rate_num - 1; n >= 0; n--) {
by_rate_offset = PHY_GetTxPowerByRate(adapter, band, path, rates_by_sections[rs].rates[n]);
_RTW_PRINT_SEL(sel, "%3d ", by_rate_offset);
}
RTW_PRINT_SEL(sel, "\n");
}
}
}
}
/*
* phy file path is stored in global char array rtw_phy_para_file_path
* need to care about racing
*/
int rtw_get_phy_file_path(_adapter *adapter, const char *file_name)
{
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
struct hal_spec_t *hal_spec = GET_HAL_SPEC(adapter);
int len = 0;
if (file_name) {
len += snprintf(rtw_phy_para_file_path, PATH_LENGTH_MAX, "%s", rtw_phy_file_path);
#if defined(CONFIG_MULTIDRV) || defined(REALTEK_CONFIG_PATH_WITH_IC_NAME_FOLDER)
len += snprintf(rtw_phy_para_file_path + len, PATH_LENGTH_MAX - len, "%s/", hal_spec->ic_name);
#endif
len += snprintf(rtw_phy_para_file_path + len, PATH_LENGTH_MAX - len, "%s", file_name);
return _TRUE;
}
#endif
return _FALSE;
}
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
int
phy_ConfigMACWithParaFile(
PADAPTER Adapter,
char *pFileName
)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(Adapter);
int rlen = 0, rtStatus = _FAIL;
char *szLine, *ptmp;
u32 u4bRegOffset, u4bRegValue, u4bMove;
if (!(Adapter->registrypriv.load_phy_file & LOAD_MAC_PARA_FILE))
return rtStatus;
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if ((pHalData->mac_reg_len == 0) && (pHalData->mac_reg == NULL)) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pHalData->mac_reg = rtw_zvmalloc(rlen);
if (pHalData->mac_reg) {
_rtw_memcpy(pHalData->mac_reg, pHalData->para_file_buf, rlen);
pHalData->mac_reg_len = rlen;
} else
RTW_INFO("%s mac_reg alloc fail !\n", __FUNCTION__);
}
}
} else {
if ((pHalData->mac_reg_len != 0) && (pHalData->mac_reg != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pHalData->mac_reg, pHalData->mac_reg_len);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
ptmp = pHalData->para_file_buf;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (!IsCommentString(szLine)) {
/* Get 1st hex value as register offset */
if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
if (u4bRegOffset == 0xffff) {
/* Ending. */
break;
}
/* Get 2nd hex value as register value. */
szLine += u4bMove;
if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove))
rtw_write8(Adapter, u4bRegOffset, (u8)u4bRegValue);
}
}
}
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
return rtStatus;
}
int
phy_ConfigBBWithParaFile(
PADAPTER Adapter,
char *pFileName,
u32 ConfigType
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
int rlen = 0, rtStatus = _FAIL;
char *szLine, *ptmp;
u32 u4bRegOffset, u4bRegValue, u4bMove;
char *pBuf = NULL;
u32 *pBufLen = NULL;
if (!(Adapter->registrypriv.load_phy_file & LOAD_BB_PARA_FILE))
return rtStatus;
switch (ConfigType) {
case CONFIG_BB_PHY_REG:
pBuf = pHalData->bb_phy_reg;
pBufLen = &pHalData->bb_phy_reg_len;
break;
case CONFIG_BB_AGC_TAB:
pBuf = pHalData->bb_agc_tab;
pBufLen = &pHalData->bb_agc_tab_len;
break;
default:
RTW_INFO("Unknown ConfigType!! %d\r\n", ConfigType);
break;
}
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if ((pBufLen != NULL) && (*pBufLen == 0) && (pBuf == NULL)) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pBuf = rtw_zvmalloc(rlen);
if (pBuf) {
_rtw_memcpy(pBuf, pHalData->para_file_buf, rlen);
*pBufLen = rlen;
switch (ConfigType) {
case CONFIG_BB_PHY_REG:
pHalData->bb_phy_reg = pBuf;
break;
case CONFIG_BB_AGC_TAB:
pHalData->bb_agc_tab = pBuf;
break;
}
} else
RTW_INFO("%s(): ConfigType %d alloc fail !\n", __FUNCTION__, ConfigType);
}
}
} else {
if ((pBufLen != NULL) && (*pBufLen != 0) && (pBuf != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pBuf, *pBufLen);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
ptmp = pHalData->para_file_buf;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (!IsCommentString(szLine)) {
/* Get 1st hex value as register offset. */
if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
if (u4bRegOffset == 0xffff) {
/* Ending. */
break;
} else if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe) {
#ifdef CONFIG_LONG_DELAY_ISSUE
rtw_msleep_os(50);
#else
rtw_mdelay_os(50);
#endif
} else if (u4bRegOffset == 0xfd)
rtw_mdelay_os(5);
else if (u4bRegOffset == 0xfc)
rtw_mdelay_os(1);
else if (u4bRegOffset == 0xfb)
rtw_udelay_os(50);
else if (u4bRegOffset == 0xfa)
rtw_udelay_os(5);
else if (u4bRegOffset == 0xf9)
rtw_udelay_os(1);
/* Get 2nd hex value as register value. */
szLine += u4bMove;
if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
/* RTW_INFO("[BB-ADDR]%03lX=%08lX\n", u4bRegOffset, u4bRegValue); */
phy_set_bb_reg(Adapter, u4bRegOffset, bMaskDWord, u4bRegValue);
if (u4bRegOffset == 0xa24)
pHalData->odmpriv.rf_calibrate_info.rega24 = u4bRegValue;
/* Add 1us delay between BB/RF register setting. */
rtw_udelay_os(1);
}
}
}
}
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
return rtStatus;
}
void
phy_DecryptBBPgParaFile(
PADAPTER Adapter,
char *buffer
)
{
u32 i = 0, j = 0;
u8 map[95] = {0};
u8 currentChar;
char *BufOfLines, *ptmp;
/* RTW_INFO("=====>phy_DecryptBBPgParaFile()\n"); */
/* 32 the ascii code of the first visable char, 126 the last one */
for (i = 0; i < 95; ++i)
map[i] = (u8)(94 - i);
ptmp = buffer;
i = 0;
for (BufOfLines = GetLineFromBuffer(ptmp); BufOfLines != NULL; BufOfLines = GetLineFromBuffer(ptmp)) {
/* RTW_INFO("Encrypted Line: %s\n", BufOfLines); */
for (j = 0; j < strlen(BufOfLines); ++j) {
currentChar = BufOfLines[j];
if (currentChar == '\0')
break;
currentChar -= (u8)((((i + j) * 3) % 128));
BufOfLines[j] = map[currentChar - 32] + 32;
}
/* RTW_INFO("Decrypted Line: %s\n", BufOfLines ); */
if (strlen(BufOfLines) != 0)
i++;
BufOfLines[strlen(BufOfLines)] = '\n';
}
}
#ifndef DBG_TXPWR_BY_RATE_FILE_PARSE
#define DBG_TXPWR_BY_RATE_FILE_PARSE 0
#endif
int
phy_ParseBBPgParaFile(
PADAPTER Adapter,
char *buffer
)
{
int rtStatus = _FAIL;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
char *szLine, *ptmp;
u32 u4bRegOffset, u4bRegMask, u4bRegValue;
u32 u4bMove;
BOOLEAN firstLine = _TRUE;
u8 tx_num = 0;
u8 band = 0, rf_path = 0;
if (Adapter->registrypriv.RegDecryptCustomFile == 1)
phy_DecryptBBPgParaFile(Adapter, buffer);
ptmp = buffer;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (isAllSpaceOrTab(szLine, sizeof(*szLine)))
continue;
if (!IsCommentString(szLine)) {
/* Get header info (relative value or exact value) */
if (firstLine) {
if (eqNByte(szLine, (u8 *)("#[v1]"), 5)
|| eqNByte(szLine, (u8 *)("#[v2]"), 5))
pHalData->odmpriv.phy_reg_pg_version = szLine[3] - '0';
else {
RTW_ERR("The format in PHY_REG_PG are invalid %s\n", szLine);
goto exit;
}
if (eqNByte(szLine + 5, (u8 *)("[Exact]#"), 8)) {
pHalData->odmpriv.phy_reg_pg_value_type = PHY_REG_PG_EXACT_VALUE;
firstLine = _FALSE;
continue;
} else {
RTW_ERR("The values in PHY_REG_PG are invalid %s\n", szLine);
goto exit;
}
}
if (pHalData->odmpriv.phy_reg_pg_version > 0) {
u32 index = 0, cnt = 0;
if (eqNByte(szLine, "0xffff", 6))
break;
if (!eqNByte("#[END]#", szLine, 7)) {
/* load the table label info */
if (szLine[0] == '#') {
index = 0;
if (eqNByte(szLine, "#[2.4G]" , 7)) {
band = BAND_ON_2_4G;
index += 8;
} else if (eqNByte(szLine, "#[5G]", 5)) {
band = BAND_ON_5G;
index += 6;
} else {
RTW_ERR("Invalid band %s in PHY_REG_PG.txt\n", szLine);
goto exit;
}
rf_path = szLine[index] - 'A';
if (DBG_TXPWR_BY_RATE_FILE_PARSE)
RTW_INFO(" Table label Band %d, RfPath %d\n", band, rf_path );
} else { /* load rows of tables */
if (szLine[1] == '1')
tx_num = RF_1TX;
else if (szLine[1] == '2')
tx_num = RF_2TX;
else if (szLine[1] == '3')
tx_num = RF_3TX;
else if (szLine[1] == '4')
tx_num = RF_4TX;
else {
RTW_ERR("Invalid row in PHY_REG_PG.txt '%c'(%d)\n", szLine[1], szLine[1]);
goto exit;
}
while (szLine[index] != ']')
++index;
++index;/* skip ] */
/* Get 2nd hex value as register offset. */
szLine += index;
if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove))
szLine += u4bMove;
else
goto exit;
/* Get 2nd hex value as register mask. */
if (GetHexValueFromString(szLine, &u4bRegMask, &u4bMove))
szLine += u4bMove;
else
goto exit;
if (pHalData->odmpriv.phy_reg_pg_value_type == PHY_REG_PG_EXACT_VALUE) {
u32 combineValue = 0;
u8 integer = 0, fraction = 0;
if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
szLine += u4bMove;
else
goto exit;
integer *= hal_spec->txgi_pdbm;
integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
if (pHalData->odmpriv.phy_reg_pg_version == 1)
combineValue |= (((integer / 10) << 4) + (integer % 10));
else
combineValue |= integer;
if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
szLine += u4bMove;
else
goto exit;
integer *= hal_spec->txgi_pdbm;
integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
combineValue <<= 8;
if (pHalData->odmpriv.phy_reg_pg_version == 1)
combineValue |= (((integer / 10) << 4) + (integer % 10));
else
combineValue |= integer;
if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
szLine += u4bMove;
else
goto exit;
integer *= hal_spec->txgi_pdbm;
integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
combineValue <<= 8;
if (pHalData->odmpriv.phy_reg_pg_version == 1)
combineValue |= (((integer / 10) << 4) + (integer % 10));
else
combineValue |= integer;
if (GetFractionValueFromString(szLine, &integer, &fraction, &u4bMove))
szLine += u4bMove;
else
goto exit;
integer *= hal_spec->txgi_pdbm;
integer += ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
combineValue <<= 8;
if (pHalData->odmpriv.phy_reg_pg_version == 1)
combineValue |= (((integer / 10) << 4) + (integer % 10));
else
combineValue |= integer;
phy_store_tx_power_by_rate(Adapter, band, rf_path, tx_num, u4bRegOffset, u4bRegMask, combineValue);
if (DBG_TXPWR_BY_RATE_FILE_PARSE)
RTW_INFO("addr:0x%3x mask:0x%08x %dTx = 0x%08x\n", u4bRegOffset, u4bRegMask, tx_num + 1, combineValue);
}
}
}
}
}
}
rtStatus = _SUCCESS;
exit:
RTW_INFO("%s return %d\n", __func__, rtStatus);
return rtStatus;
}
int
phy_ConfigBBWithPgParaFile(
PADAPTER Adapter,
const char *pFileName)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
int rlen = 0, rtStatus = _FAIL;
if (!(Adapter->registrypriv.load_phy_file & LOAD_BB_PG_PARA_FILE))
return rtStatus;
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if (pHalData->bb_phy_reg_pg == NULL) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pHalData->bb_phy_reg_pg = rtw_zvmalloc(rlen);
if (pHalData->bb_phy_reg_pg) {
_rtw_memcpy(pHalData->bb_phy_reg_pg, pHalData->para_file_buf, rlen);
pHalData->bb_phy_reg_pg_len = rlen;
} else
RTW_INFO("%s bb_phy_reg_pg alloc fail !\n", __FUNCTION__);
}
}
} else {
if ((pHalData->bb_phy_reg_pg_len != 0) && (pHalData->bb_phy_reg_pg != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pHalData->bb_phy_reg_pg, pHalData->bb_phy_reg_pg_len);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
/* RTW_INFO("phy_ConfigBBWithPgParaFile(): read %s ok\n", pFileName); */
rtStatus = phy_ParseBBPgParaFile(Adapter, pHalData->para_file_buf);
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
return rtStatus;
}
#if (MP_DRIVER == 1)
int
phy_ConfigBBWithMpParaFile(
PADAPTER Adapter,
char *pFileName
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
int rlen = 0, rtStatus = _FAIL;
char *szLine, *ptmp;
u32 u4bRegOffset, u4bRegValue, u4bMove;
if (!(Adapter->registrypriv.load_phy_file & LOAD_BB_MP_PARA_FILE))
return rtStatus;
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if ((pHalData->bb_phy_reg_mp_len == 0) && (pHalData->bb_phy_reg_mp == NULL)) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pHalData->bb_phy_reg_mp = rtw_zvmalloc(rlen);
if (pHalData->bb_phy_reg_mp) {
_rtw_memcpy(pHalData->bb_phy_reg_mp, pHalData->para_file_buf, rlen);
pHalData->bb_phy_reg_mp_len = rlen;
} else
RTW_INFO("%s bb_phy_reg_mp alloc fail !\n", __FUNCTION__);
}
}
} else {
if ((pHalData->bb_phy_reg_mp_len != 0) && (pHalData->bb_phy_reg_mp != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pHalData->bb_phy_reg_mp, pHalData->bb_phy_reg_mp_len);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
/* RTW_INFO("phy_ConfigBBWithMpParaFile(): read %s ok\n", pFileName); */
ptmp = pHalData->para_file_buf;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (!IsCommentString(szLine)) {
/* Get 1st hex value as register offset. */
if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
if (u4bRegOffset == 0xffff) {
/* Ending. */
break;
} else if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe) {
#ifdef CONFIG_LONG_DELAY_ISSUE
rtw_msleep_os(50);
#else
rtw_mdelay_os(50);
#endif
} else if (u4bRegOffset == 0xfd)
rtw_mdelay_os(5);
else if (u4bRegOffset == 0xfc)
rtw_mdelay_os(1);
else if (u4bRegOffset == 0xfb)
rtw_udelay_os(50);
else if (u4bRegOffset == 0xfa)
rtw_udelay_os(5);
else if (u4bRegOffset == 0xf9)
rtw_udelay_os(1);
/* Get 2nd hex value as register value. */
szLine += u4bMove;
if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
/* RTW_INFO("[ADDR]%03lX=%08lX\n", u4bRegOffset, u4bRegValue); */
phy_set_bb_reg(Adapter, u4bRegOffset, bMaskDWord, u4bRegValue);
/* Add 1us delay between BB/RF register setting. */
rtw_udelay_os(1);
}
}
}
}
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
return rtStatus;
}
#endif
int
PHY_ConfigRFWithParaFile(
PADAPTER Adapter,
char *pFileName,
enum rf_path eRFPath
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
int rlen = 0, rtStatus = _FAIL;
char *szLine, *ptmp;
u32 u4bRegOffset, u4bRegValue, u4bMove;
u16 i;
char *pBuf = NULL;
u32 *pBufLen = NULL;
if (!(Adapter->registrypriv.load_phy_file & LOAD_RF_PARA_FILE))
return rtStatus;
switch (eRFPath) {
case RF_PATH_A:
pBuf = pHalData->rf_radio_a;
pBufLen = &pHalData->rf_radio_a_len;
break;
case RF_PATH_B:
pBuf = pHalData->rf_radio_b;
pBufLen = &pHalData->rf_radio_b_len;
break;
default:
RTW_INFO("Unknown RF path!! %d\r\n", eRFPath);
break;
}
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if ((pBufLen != NULL) && (*pBufLen == 0) && (pBuf == NULL)) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pBuf = rtw_zvmalloc(rlen);
if (pBuf) {
_rtw_memcpy(pBuf, pHalData->para_file_buf, rlen);
*pBufLen = rlen;
switch (eRFPath) {
case RF_PATH_A:
pHalData->rf_radio_a = pBuf;
break;
case RF_PATH_B:
pHalData->rf_radio_b = pBuf;
break;
default:
RTW_INFO("Unknown RF path!! %d\r\n", eRFPath);
break;
}
} else
RTW_INFO("%s(): eRFPath=%d alloc fail !\n", __FUNCTION__, eRFPath);
}
}
} else {
if ((pBufLen != NULL) && (*pBufLen != 0) && (pBuf != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pBuf, *pBufLen);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
/* RTW_INFO("%s(): read %s successfully\n", __FUNCTION__, pFileName); */
ptmp = pHalData->para_file_buf;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (!IsCommentString(szLine)) {
/* Get 1st hex value as register offset. */
if (GetHexValueFromString(szLine, &u4bRegOffset, &u4bMove)) {
if (u4bRegOffset == 0xfe || u4bRegOffset == 0xffe) {
/* Deay specific ms. Only RF configuration require delay. */
#ifdef CONFIG_LONG_DELAY_ISSUE
rtw_msleep_os(50);
#else
rtw_mdelay_os(50);
#endif
} else if (u4bRegOffset == 0xfd) {
/* delay_ms(5); */
for (i = 0; i < 100; i++)
rtw_udelay_os(MAX_STALL_TIME);
} else if (u4bRegOffset == 0xfc) {
/* delay_ms(1); */
for (i = 0; i < 20; i++)
rtw_udelay_os(MAX_STALL_TIME);
} else if (u4bRegOffset == 0xfb)
rtw_udelay_os(50);
else if (u4bRegOffset == 0xfa)
rtw_udelay_os(5);
else if (u4bRegOffset == 0xf9)
rtw_udelay_os(1);
else if (u4bRegOffset == 0xffff)
break;
/* Get 2nd hex value as register value. */
szLine += u4bMove;
if (GetHexValueFromString(szLine, &u4bRegValue, &u4bMove)) {
phy_set_rf_reg(Adapter, eRFPath, u4bRegOffset, bRFRegOffsetMask, u4bRegValue);
/* Temp add, for frequency lock, if no delay, that may cause */
/* frequency shift, ex: 2412MHz => 2417MHz */
/* If frequency shift, the following action may works. */
/* Fractional-N table in radio_a.txt */
/* 0x2a 0x00001 */ /* channel 1 */
/* 0x2b 0x00808 frequency divider. */
/* 0x2b 0x53333 */
/* 0x2c 0x0000c */
rtw_udelay_os(1);
}
}
}
}
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
return rtStatus;
}
void
initDeltaSwingIndexTables(
PADAPTER Adapter,
char *Band,
char *Path,
char *Sign,
char *Channel,
char *Rate,
char *Data
)
{
#define STR_EQUAL_5G(_band, _path, _sign, _rate, _chnl) \
((strcmp(Band, _band) == 0) && (strcmp(Path, _path) == 0) && (strcmp(Sign, _sign) == 0) &&\
(strcmp(Rate, _rate) == 0) && (strcmp(Channel, _chnl) == 0)\
)
#define STR_EQUAL_2G(_band, _path, _sign, _rate) \
((strcmp(Band, _band) == 0) && (strcmp(Path, _path) == 0) && (strcmp(Sign, _sign) == 0) &&\
(strcmp(Rate, _rate) == 0)\
)
#define STORE_SWING_TABLE(_array, _iteratedIdx) \
do { \
for (token = strsep(&Data, delim); token != NULL; token = strsep(&Data, delim)) {\
sscanf(token, "%d", &idx);\
_array[_iteratedIdx++] = (u8)idx;\
} } while (0)\
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
struct dm_rf_calibration_struct *pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
u32 j = 0;
char *token;
char delim[] = ",";
u32 idx = 0;
/* RTW_INFO("===>initDeltaSwingIndexTables(): Band: %s;\nPath: %s;\nSign: %s;\nChannel: %s;\nRate: %s;\n, Data: %s;\n", */
/* Band, Path, Sign, Channel, Rate, Data); */
if (STR_EQUAL_2G("2G", "A", "+", "CCK"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_p, j);
else if (STR_EQUAL_2G("2G", "A", "-", "CCK"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_n, j);
else if (STR_EQUAL_2G("2G", "B", "+", "CCK"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_p, j);
else if (STR_EQUAL_2G("2G", "B", "-", "CCK"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_n, j);
else if (STR_EQUAL_2G("2G", "A", "+", "ALL"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2ga_p, j);
else if (STR_EQUAL_2G("2G", "A", "-", "ALL"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2ga_n, j);
else if (STR_EQUAL_2G("2G", "B", "+", "ALL"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2gb_p, j);
else if (STR_EQUAL_2G("2G", "B", "-", "ALL"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_2gb_n, j);
else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "0"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[0], j);
else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "0"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[0], j);
else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "0"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[0], j);
else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "0"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[0], j);
else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "1"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[1], j);
else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "1"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[1], j);
else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "1"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[1], j);
else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "1"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[1], j);
else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "2"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[2], j);
else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "2"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[2], j);
else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "2"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[2], j);
else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "2"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[2], j);
else if (STR_EQUAL_5G("5G", "A", "+", "ALL", "3"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_p[3], j);
else if (STR_EQUAL_5G("5G", "A", "-", "ALL", "3"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5ga_n[3], j);
else if (STR_EQUAL_5G("5G", "B", "+", "ALL", "3"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_p[3], j);
else if (STR_EQUAL_5G("5G", "B", "-", "ALL", "3"))
STORE_SWING_TABLE(pRFCalibrateInfo->delta_swing_table_idx_5gb_n[3], j);
else
RTW_INFO("===>initDeltaSwingIndexTables(): The input is invalid!!\n");
}
int
PHY_ConfigRFWithTxPwrTrackParaFile(
PADAPTER Adapter,
char *pFileName
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
struct dm_rf_calibration_struct *pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
int rlen = 0, rtStatus = _FAIL;
char *szLine, *ptmp;
u32 i = 0, j = 0;
char c = 0;
if (!(Adapter->registrypriv.load_phy_file & LOAD_RF_TXPWR_TRACK_PARA_FILE))
return rtStatus;
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if ((pHalData->rf_tx_pwr_track_len == 0) && (pHalData->rf_tx_pwr_track == NULL)) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pHalData->rf_tx_pwr_track = rtw_zvmalloc(rlen);
if (pHalData->rf_tx_pwr_track) {
_rtw_memcpy(pHalData->rf_tx_pwr_track, pHalData->para_file_buf, rlen);
pHalData->rf_tx_pwr_track_len = rlen;
} else
RTW_INFO("%s rf_tx_pwr_track alloc fail !\n", __FUNCTION__);
}
}
} else {
if ((pHalData->rf_tx_pwr_track_len != 0) && (pHalData->rf_tx_pwr_track != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pHalData->rf_tx_pwr_track, pHalData->rf_tx_pwr_track_len);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
/* RTW_INFO("%s(): read %s successfully\n", __FUNCTION__, pFileName); */
ptmp = pHalData->para_file_buf;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (!IsCommentString(szLine)) {
char band[5] = "", path[5] = "", sign[5] = "";
char chnl[5] = "", rate[10] = "";
char data[300] = ""; /* 100 is too small */
if (strlen(szLine) < 10 || szLine[0] != '[')
continue;
strncpy(band, szLine + 1, 2);
strncpy(path, szLine + 5, 1);
strncpy(sign, szLine + 8, 1);
i = 10; /* szLine+10 */
if (!ParseQualifiedString(szLine, &i, rate, '[', ']')) {
/* RTW_INFO("Fail to parse rate!\n"); */
}
if (!ParseQualifiedString(szLine, &i, chnl, '[', ']')) {
/* RTW_INFO("Fail to parse channel group!\n"); */
}
while (szLine[i] != '{' && i < strlen(szLine))
i++;
if (!ParseQualifiedString(szLine, &i, data, '{', '}')) {
/* RTW_INFO("Fail to parse data!\n"); */
}
initDeltaSwingIndexTables(Adapter, band, path, sign, chnl, rate, data);
}
}
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
#if 0
for (i = 0; i < DELTA_SWINGIDX_SIZE; ++i) {
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2ga_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2ga_p[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2ga_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2ga_n[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2gb_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2gb_p[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2gb_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2gb_n[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_p[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_a_n[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_p[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_p[i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_n[%d] = %d\n", i, pRFCalibrateInfo->delta_swing_table_idx_2g_cck_b_n[i]);
for (j = 0; j < 3; ++j) {
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5ga_p[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5ga_p[j][i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5ga_n[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5ga_n[j][i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5gb_p[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5gb_p[j][i]);
RTW_INFO("pRFCalibrateInfo->delta_swing_table_idx_5gb_n[%d][%d] = %d\n", j, i, pRFCalibrateInfo->delta_swing_table_idx_5gb_n[j][i]);
}
}
#endif
return rtStatus;
}
#if CONFIG_TXPWR_LIMIT
#ifndef DBG_TXPWR_LMT_FILE_PARSE
#define DBG_TXPWR_LMT_FILE_PARSE 0
#endif
#define PARSE_RET_NO_HDL 0
#define PARSE_RET_SUCCESS 1
#define PARSE_RET_FAIL 2
/*
* @@Ver=2.0
* or
* @@DomainCode=0x28, Regulation=C6
* or
* @@CountryCode=GB, Regulation=C7
*/
static u8 parse_reg_exc_config(_adapter *adapter, char *szLine)
{
#define VER_PREFIX "Ver="
#define DOMAIN_PREFIX "DomainCode=0x"
#define COUNTRY_PREFIX "CountryCode="
#define REG_PREFIX "Regulation="
const u8 ver_prefix_len = strlen(VER_PREFIX);
const u8 domain_prefix_len = strlen(DOMAIN_PREFIX);
const u8 country_prefix_len = strlen(COUNTRY_PREFIX);
const u8 reg_prefix_len = strlen(REG_PREFIX);
u32 i, i_val_s, i_val_e;
u32 j;
u8 domain = 0xFF;
char *country = NULL;
u8 parse_reg = 0;
if (szLine[0] != '@' || szLine[1] != '@')
return PARSE_RET_NO_HDL;
i = 2;
if (strncmp(szLine + i, VER_PREFIX, ver_prefix_len) == 0)
; /* nothing to do */
else if (strncmp(szLine + i, DOMAIN_PREFIX, domain_prefix_len) == 0) {
/* get string after domain prefix to ',' */
i += domain_prefix_len;
i_val_s = i;
while (szLine[i] != ',') {
if (szLine[i] == '\0')
return PARSE_RET_FAIL;
i++;
}
i_val_e = i;
/* check if all hex */
for (j = i_val_s; j < i_val_e; j++)
if (IsHexDigit(szLine[j]) == _FALSE)
return PARSE_RET_FAIL;
/* get value from hex string */
if (sscanf(szLine + i_val_s, "%hhx", &domain) != 1)
return PARSE_RET_FAIL;
parse_reg = 1;
} else if (strncmp(szLine + i, COUNTRY_PREFIX, country_prefix_len) == 0) {
/* get string after country prefix to ',' */
i += country_prefix_len;
i_val_s = i;
while (szLine[i] != ',') {
if (szLine[i] == '\0')
return PARSE_RET_FAIL;
i++;
}
i_val_e = i;
if (i_val_e - i_val_s != 2)
return PARSE_RET_FAIL;
/* check if all alpha */
for (j = i_val_s; j < i_val_e; j++)
if (is_alpha(szLine[j]) == _FALSE)
return PARSE_RET_FAIL;
country = szLine + i_val_s;
parse_reg = 1;
} else
return PARSE_RET_FAIL;
if (parse_reg) {
/* move to 'R' */
while (szLine[i] != 'R') {
if (szLine[i] == '\0')
return PARSE_RET_FAIL;
i++;
}
/* check if matching regulation prefix */
if (strncmp(szLine + i, REG_PREFIX, reg_prefix_len) != 0)
return PARSE_RET_FAIL;
/* get string after regulation prefix ending with space */
i += reg_prefix_len;
i_val_s = i;
while (szLine[i] != ' ' && szLine[i] != '\t' && szLine[i] != '\0')
i++;
if (i == i_val_s)
return PARSE_RET_FAIL;
rtw_regd_exc_add_with_nlen(adapter_to_rfctl(adapter), country, domain, szLine + i_val_s, i - i_val_s);
}
return PARSE_RET_SUCCESS;
}
static int
phy_ParsePowerLimitTableFile(
PADAPTER Adapter,
char *buffer
)
{
#define LD_STAGE_EXC_MAPPING 0
#define LD_STAGE_TAB_DEFINE 1
#define LD_STAGE_TAB_START 2
#define LD_STAGE_COLUMN_DEFINE 3
#define LD_STAGE_CH_ROW 4
int rtStatus = _FAIL;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct hal_spec_t *hal_spec = GET_HAL_SPEC(Adapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
u8 loadingStage = LD_STAGE_EXC_MAPPING;
u32 i = 0, forCnt = 0;
char *szLine, *ptmp;
char band[10], bandwidth[10], rateSection[10], ntx[10], colNumBuf[10];
char **regulation = NULL;
u8 colNum = 0;
if (Adapter->registrypriv.RegDecryptCustomFile == 1)
phy_DecryptBBPgParaFile(Adapter, buffer);
ptmp = buffer;
for (szLine = GetLineFromBuffer(ptmp); szLine != NULL; szLine = GetLineFromBuffer(ptmp)) {
if (isAllSpaceOrTab(szLine, sizeof(*szLine)))
continue;
if (IsCommentString(szLine))
continue;
if (loadingStage == LD_STAGE_EXC_MAPPING) {
if (szLine[0] == '#' || szLine[1] == '#') {
loadingStage = LD_STAGE_TAB_DEFINE;
if (DBG_TXPWR_LMT_FILE_PARSE)
dump_regd_exc_list(RTW_DBGDUMP, adapter_to_rfctl(Adapter));
} else {
if (parse_reg_exc_config(Adapter, szLine) == PARSE_RET_FAIL) {
RTW_ERR("Fail to parse regulation exception ruls!\n");
goto exit;
}
continue;
}
}
if (loadingStage == LD_STAGE_TAB_DEFINE) {
/* read "## 2.4G, 20M, 1T, CCK" */
if (szLine[0] != '#' || szLine[1] != '#')
continue;
/* skip the space */
i = 2;
while (szLine[i] == ' ' || szLine[i] == '\t')
++i;
szLine[--i] = ' '; /* return the space in front of the regulation info */
/* Parse the label of the table */
_rtw_memset((void *) band, 0, 10);
_rtw_memset((void *) bandwidth, 0, 10);
_rtw_memset((void *) ntx, 0, 10);
_rtw_memset((void *) rateSection, 0, 10);
if (!ParseQualifiedString(szLine, &i, band, ' ', ',')) {
RTW_ERR("Fail to parse band!\n");
goto exit;
}
if (!ParseQualifiedString(szLine, &i, bandwidth, ' ', ',')) {
RTW_ERR("Fail to parse bandwidth!\n");
goto exit;
}
if (!ParseQualifiedString(szLine, &i, ntx, ' ', ',')) {
RTW_ERR("Fail to parse ntx!\n");
goto exit;
}
if (!ParseQualifiedString(szLine, &i, rateSection, ' ', ',')) {
RTW_ERR("Fail to parse rate!\n");
goto exit;
}
loadingStage = LD_STAGE_TAB_START;
} else if (loadingStage == LD_STAGE_TAB_START) {
/* read "## START" */
if (szLine[0] != '#' || szLine[1] != '#')
continue;
/* skip the space */
i = 2;
while (szLine[i] == ' ' || szLine[i] == '\t')
++i;
if (!eqNByte((u8 *)(szLine + i), (u8 *)("START"), 5)) {
RTW_ERR("Missing \"## START\" label\n");
goto exit;
}
loadingStage = LD_STAGE_COLUMN_DEFINE;
} else if (loadingStage == LD_STAGE_COLUMN_DEFINE) {
/* read "## #5# FCC ETSI MKK IC KCC" */
if (szLine[0] != '#' || szLine[1] != '#')
continue;
/* skip the space */
i = 2;
while (szLine[i] == ' ' || szLine[i] == '\t')
++i;
_rtw_memset((void *) colNumBuf, 0, 10);
if (!ParseQualifiedString(szLine, &i, colNumBuf, '#', '#')) {
RTW_ERR("Fail to parse column number!\n");
goto exit;
}
if (!GetU1ByteIntegerFromStringInDecimal(colNumBuf, &colNum)) {
RTW_ERR("Column number \"%s\" is not unsigned decimal\n", colNumBuf);
goto exit;
}
if (colNum == 0) {
RTW_ERR("Column number is 0\n");
goto exit;
}
if (DBG_TXPWR_LMT_FILE_PARSE)
RTW_PRINT("[%s][%s][%s][%s] column num:%d\n", band, bandwidth, rateSection, ntx, colNum);
regulation = (char **)rtw_zmalloc(sizeof(char *) * colNum);
if (!regulation) {
RTW_ERR("Regulation alloc fail\n");
goto exit;
}
for (forCnt = 0; forCnt < colNum; ++forCnt) {
u32 i_ns;
/* skip the space */
while (szLine[i] == ' ' || szLine[i] == '\t')
i++;
i_ns = i;
while (szLine[i] != ' ' && szLine[i] != '\t' && szLine[i] != '\0')
i++;
regulation[forCnt] = (char *)rtw_malloc(i - i_ns + 1);
if (!regulation[forCnt]) {
RTW_ERR("Regulation alloc fail\n");
goto exit;
}
_rtw_memcpy(regulation[forCnt], szLine + i_ns, i - i_ns);
regulation[forCnt][i - i_ns] = '\0';
}
if (DBG_TXPWR_LMT_FILE_PARSE) {
RTW_PRINT("column name:");
for (forCnt = 0; forCnt < colNum; ++forCnt)
_RTW_PRINT(" %s", regulation[forCnt]);
_RTW_PRINT("\n");
}
loadingStage = LD_STAGE_CH_ROW;
} else if (loadingStage == LD_STAGE_CH_ROW) {
char channel[10] = {0}, powerLimit[10] = {0};
u8 cnt = 0;
/* the table ends */
if (szLine[0] == '#' && szLine[1] == '#') {
i = 2;
while (szLine[i] == ' ' || szLine[i] == '\t')
++i;
if (eqNByte((u8 *)(szLine + i), (u8 *)("END"), 3)) {
loadingStage = LD_STAGE_TAB_DEFINE;
if (regulation) {
for (forCnt = 0; forCnt < colNum; ++forCnt) {
if (regulation[forCnt]) {
rtw_mfree(regulation[forCnt], strlen(regulation[forCnt]) + 1);
regulation[forCnt] = NULL;
}
}
rtw_mfree((u8 *)regulation, sizeof(char *) * colNum);
regulation = NULL;
}
colNum = 0;
continue;
} else {
RTW_ERR("Missing \"## END\" label\n");
goto exit;
}
}
if ((szLine[0] != 'c' && szLine[0] != 'C') ||
(szLine[1] != 'h' && szLine[1] != 'H')
) {
RTW_WARN("Wrong channel prefix: '%c','%c'(%d,%d)\n", szLine[0], szLine[1], szLine[0], szLine[1]);
continue;
}
i = 2;/* move to the location behind 'h' */
/* load the channel number */
cnt = 0;
while (szLine[i] >= '0' && szLine[i] <= '9') {
channel[cnt] = szLine[i];
++cnt;
++i;
}
/* RTW_INFO("chnl %s!\n", channel); */
for (forCnt = 0; forCnt < colNum; ++forCnt) {
/* skip the space between channel number and the power limit value */
while (szLine[i] == ' ' || szLine[i] == '\t')
++i;
/* load the power limit value */
_rtw_memset((void *) powerLimit, 0, 10);
if (szLine[i] == 'W' && szLine[i + 1] == 'W') {
/*
* case "WW" assign special ww value
* means to get minimal limit in other regulations at same channel
*/
s8 ww_value = phy_txpwr_ww_lmt_value(Adapter);
sprintf(powerLimit, "%d", ww_value);
i += 2;
} else if (szLine[i] == 'N' && szLine[i + 1] == 'A') {
/*
* case "NA" assign max txgi value
* means no limitation
*/
sprintf(powerLimit, "%d", hal_spec->txgi_max);
i += 2;
} else if ((szLine[i] >= '0' && szLine[i] <= '9') || szLine[i] == '.'
|| szLine[i] == '+' || szLine[i] == '-'
){
/* case of dBm value */
u8 integer = 0, fraction = 0, negative = 0;
u32 u4bMove;
s8 lmt = 0;
if (szLine[i] == '+' || szLine[i] == '-') {
if (szLine[i] == '-')
negative = 1;
i++;
}
if (GetFractionValueFromString(&szLine[i], &integer, &fraction, &u4bMove))
i += u4bMove;
else {
RTW_ERR("Limit \"%s\" is not valid decimal\n", &szLine[i]);
goto exit;
}
/* transform to string of value in unit of txgi */
lmt = integer * hal_spec->txgi_pdbm + ((u16)fraction * (u16)hal_spec->txgi_pdbm) / 100;
if (negative)
lmt = -lmt;
sprintf(powerLimit, "%d", lmt);
} else {
RTW_ERR("Wrong limit expression \"%c%c\"(%d, %d)\n"
, szLine[i], szLine[i + 1], szLine[i], szLine[i + 1]);
goto exit;
}
/* store the power limit value */
phy_set_tx_power_limit(pDM_Odm, (u8 *)regulation[forCnt], (u8 *)band,
(u8 *)bandwidth, (u8 *)rateSection, (u8 *)ntx, (u8 *)channel, (u8 *)powerLimit);
}
}
}
rtStatus = _SUCCESS;
exit:
if (regulation) {
for (forCnt = 0; forCnt < colNum; ++forCnt) {
if (regulation[forCnt]) {
rtw_mfree(regulation[forCnt], strlen(regulation[forCnt]) + 1);
regulation[forCnt] = NULL;
}
}
rtw_mfree((u8 *)regulation, sizeof(char *) * colNum);
regulation = NULL;
}
RTW_INFO("%s return %d\n", __func__, rtStatus);
return rtStatus;
}
int
PHY_ConfigRFWithPowerLimitTableParaFile(
PADAPTER Adapter,
const char *pFileName
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
int rlen = 0, rtStatus = _FAIL;
if (!(Adapter->registrypriv.load_phy_file & LOAD_RF_TXPWR_LMT_PARA_FILE))
return rtStatus;
_rtw_memset(pHalData->para_file_buf, 0, MAX_PARA_FILE_BUF_LEN);
if (pHalData->rf_tx_pwr_lmt == NULL) {
rtw_get_phy_file_path(Adapter, pFileName);
if (rtw_readable_file_sz_chk(rtw_phy_para_file_path,
MAX_PARA_FILE_BUF_LEN) == _TRUE) {
rlen = rtw_retrieve_from_file(rtw_phy_para_file_path, pHalData->para_file_buf, MAX_PARA_FILE_BUF_LEN);
if (rlen > 0) {
rtStatus = _SUCCESS;
pHalData->rf_tx_pwr_lmt = rtw_zvmalloc(rlen);
if (pHalData->rf_tx_pwr_lmt) {
_rtw_memcpy(pHalData->rf_tx_pwr_lmt, pHalData->para_file_buf, rlen);
pHalData->rf_tx_pwr_lmt_len = rlen;
} else
RTW_INFO("%s rf_tx_pwr_lmt alloc fail !\n", __FUNCTION__);
}
}
} else {
if ((pHalData->rf_tx_pwr_lmt_len != 0) && (pHalData->rf_tx_pwr_lmt != NULL)) {
_rtw_memcpy(pHalData->para_file_buf, pHalData->rf_tx_pwr_lmt, pHalData->rf_tx_pwr_lmt_len);
rtStatus = _SUCCESS;
} else
RTW_INFO("%s(): Critical Error !!!\n", __FUNCTION__);
}
if (rtStatus == _SUCCESS) {
/* RTW_INFO("%s(): read %s ok\n", __FUNCTION__, pFileName); */
rtStatus = phy_ParsePowerLimitTableFile(Adapter, pHalData->para_file_buf);
} else
RTW_INFO("%s(): No File %s, Load from HWImg Array!\n", __FUNCTION__, pFileName);
return rtStatus;
}
#endif /* CONFIG_TXPWR_LIMIT */
void phy_free_filebuf_mask(_adapter *padapter, u8 mask)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
if (pHalData->mac_reg && (mask & LOAD_MAC_PARA_FILE)) {
rtw_vmfree(pHalData->mac_reg, pHalData->mac_reg_len);
pHalData->mac_reg = NULL;
}
if (mask & LOAD_BB_PARA_FILE) {
if (pHalData->bb_phy_reg) {
rtw_vmfree(pHalData->bb_phy_reg, pHalData->bb_phy_reg_len);
pHalData->bb_phy_reg = NULL;
}
if (pHalData->bb_agc_tab) {
rtw_vmfree(pHalData->bb_agc_tab, pHalData->bb_agc_tab_len);
pHalData->bb_agc_tab = NULL;
}
}
if (pHalData->bb_phy_reg_pg && (mask & LOAD_BB_PG_PARA_FILE)) {
rtw_vmfree(pHalData->bb_phy_reg_pg, pHalData->bb_phy_reg_pg_len);
pHalData->bb_phy_reg_pg = NULL;
}
if (pHalData->bb_phy_reg_mp && (mask & LOAD_BB_MP_PARA_FILE)) {
rtw_vmfree(pHalData->bb_phy_reg_mp, pHalData->bb_phy_reg_mp_len);
pHalData->bb_phy_reg_mp = NULL;
}
if (mask & LOAD_RF_PARA_FILE) {
if (pHalData->rf_radio_a) {
rtw_vmfree(pHalData->rf_radio_a, pHalData->rf_radio_a_len);
pHalData->rf_radio_a = NULL;
}
if (pHalData->rf_radio_b) {
rtw_vmfree(pHalData->rf_radio_b, pHalData->rf_radio_b_len);
pHalData->rf_radio_b = NULL;
}
}
if (pHalData->rf_tx_pwr_track && (mask & LOAD_RF_TXPWR_TRACK_PARA_FILE)) {
rtw_vmfree(pHalData->rf_tx_pwr_track, pHalData->rf_tx_pwr_track_len);
pHalData->rf_tx_pwr_track = NULL;
}
if (pHalData->rf_tx_pwr_lmt && (mask & LOAD_RF_TXPWR_LMT_PARA_FILE)) {
rtw_vmfree(pHalData->rf_tx_pwr_lmt, pHalData->rf_tx_pwr_lmt_len);
pHalData->rf_tx_pwr_lmt = NULL;
}
}
inline void phy_free_filebuf(_adapter *padapter)
{
phy_free_filebuf_mask(padapter, 0xFF);
}
#endif
================================================
FILE: hal/hal_dm.c
================================================
/******************************************************************************
*
* Copyright(c) 2014 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
/* A mapping from HalData to ODM. */
enum odm_board_type boardType(u8 InterfaceSel)
{
enum odm_board_type board = ODM_BOARD_DEFAULT;
#ifdef CONFIG_PCI_HCI
INTERFACE_SELECT_PCIE pcie = (INTERFACE_SELECT_PCIE)InterfaceSel;
switch (pcie) {
case INTF_SEL0_SOLO_MINICARD:
board |= ODM_BOARD_MINICARD;
break;
case INTF_SEL1_BT_COMBO_MINICARD:
board |= ODM_BOARD_BT;
board |= ODM_BOARD_MINICARD;
break;
default:
board = ODM_BOARD_DEFAULT;
break;
}
#elif defined(CONFIG_USB_HCI)
INTERFACE_SELECT_USB usb = (INTERFACE_SELECT_USB)InterfaceSel;
switch (usb) {
case INTF_SEL1_USB_High_Power:
board |= ODM_BOARD_EXT_LNA;
board |= ODM_BOARD_EXT_PA;
break;
case INTF_SEL2_MINICARD:
board |= ODM_BOARD_MINICARD;
break;
case INTF_SEL4_USB_Combo:
board |= ODM_BOARD_BT;
break;
case INTF_SEL5_USB_Combo_MF:
board |= ODM_BOARD_BT;
break;
case INTF_SEL0_USB:
case INTF_SEL3_USB_Solo:
default:
board = ODM_BOARD_DEFAULT;
break;
}
#endif
/* RTW_INFO("===> boardType(): (pHalData->InterfaceSel, pDM_Odm->BoardType) = (%d, %d)\n", InterfaceSel, board); */
return board;
}
void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter)
{
PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
if (hal->RegIQKFWOffload) {
rtw_sctx_init(&hal->iqk_sctx, 0);
phydm_fwoffload_ability_init(p_dm_odm, PHYDM_RF_IQK_OFFLOAD);
} else
phydm_fwoffload_ability_clear(p_dm_odm, PHYDM_RF_IQK_OFFLOAD);
RTW_INFO("IQK FW offload:%s\n", hal->RegIQKFWOffload ? "enable" : "disable");
if (rtw_mi_check_status(adapter, MI_LINKED)) {
#ifdef CONFIG_LPS
LPS_Leave(adapter, "SWITCH_IQK_OFFLOAD");
#endif
halrf_iqk_trigger(p_dm_odm, _FALSE);
}
}
#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
void rtw_phydm_iqk_trigger(_adapter *adapter)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
u8 clear = _TRUE;
u8 segment = _FALSE;
u8 rfk_forbidden = _FALSE;
halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
#if (RTL8822C_SUPPORT == 1)
/* halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_IQK_SEGMENT, segment); to do */
halrf_rf_k_connect_trigger(p_dm_odm, _TRUE, SEGMENT_FREE);
#else
/*segment = _rtw_phydm_iqk_segment_chk(adapter);*/
halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_IQK_SEGMENT, segment);
halrf_segment_iqk_trigger(p_dm_odm, clear, segment);
#endif
}
#endif
void rtw_phydm_iqk_trigger_dbg(_adapter *adapter, bool recovery, bool clear, bool segment)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
halrf_segment_iqk_trigger(p_dm_odm, clear, segment);
#else
halrf_iqk_trigger(p_dm_odm, recovery);
#endif
}
void rtw_phydm_lck_trigger(_adapter *adapter)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
halrf_lck_trigger(p_dm_odm);
}
#ifdef CONFIG_DBG_RF_CAL
void rtw_hal_iqk_test(_adapter *adapter, bool recovery, bool clear, bool segment)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
rtw_ps_deny(adapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(adapter);
rtw_phydm_ability_backup(adapter);
rtw_phydm_func_disable_all(adapter);
halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_ABILITY, HAL_RF_IQK);
rtw_phydm_iqk_trigger_dbg(adapter, recovery, clear, segment);
rtw_phydm_ability_restore(adapter);
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
}
void rtw_hal_lck_test(_adapter *adapter)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
rtw_ps_deny(adapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(adapter);
rtw_phydm_ability_backup(adapter);
rtw_phydm_func_disable_all(adapter);
halrf_cmn_info_set(p_dm_odm, HALRF_CMNINFO_ABILITY, HAL_RF_LCK);
rtw_phydm_lck_trigger(adapter);
rtw_phydm_ability_restore(adapter);
rtw_ps_deny_cancel(adapter, PS_DENY_IOCTL);
}
#endif
#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
void rtw_hal_update_param_init_fw_offload_cap(_adapter *adapter)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(adapter);
if (adapter->registrypriv.fw_param_init)
phydm_fwoffload_ability_init(p_dm_odm, PHYDM_PHY_PARAM_OFFLOAD);
else
phydm_fwoffload_ability_clear(p_dm_odm, PHYDM_PHY_PARAM_OFFLOAD);
RTW_INFO("Init-Parameter FW offload:%s\n", adapter->registrypriv.fw_param_init ? "enable" : "disable");
}
#endif
void record_ra_info(void *p_dm_void, u8 macid, struct cmn_sta_info *p_sta, u64 ra_mask)
{
struct dm_struct *p_dm = (struct dm_struct *)p_dm_void;
_adapter *adapter = p_dm->adapter;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
if (p_sta) {
rtw_macid_ctl_set_bw(macid_ctl, macid, p_sta->ra_info.ra_bw_mode);
rtw_macid_ctl_set_vht_en(macid_ctl, macid, p_sta->ra_info.is_vht_enable);
rtw_macid_ctl_set_rate_bmp0(macid_ctl, macid, ra_mask);
rtw_macid_ctl_set_rate_bmp1(macid_ctl, macid, ra_mask >> 32);
rtw_update_tx_rate_bmp(adapter_to_dvobj(adapter));
}
}
#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
void rtw_phydm_fill_desc_dpt(void *dm, u8 *desc, u8 dpt_lv)
{
struct dm_struct *p_dm = (struct dm_struct *)dm;
_adapter *adapter = p_dm->adapter;
switch (rtw_get_chip_type(adapter)) {
/*
#ifdef CONFIG_RTL8188F
case RTL8188F:
break;
#endif
#ifdef CONFIG_RTL8723B
case RTL8723B :
break;
#endif
#ifdef CONFIG_RTL8703B
case RTL8703B :
break;
#endif
#ifdef CONFIG_RTL8812A
case RTL8812 :
break;
#endif
#ifdef CONFIG_RTL8821A
case RTL8821:
break;
#endif
#ifdef CONFIG_RTL8814A
case RTL8814A :
break;
#endif
#ifdef CONFIG_RTL8192F
case RTL8192F :
break;
#endif
*/
/*
#ifdef CONFIG_RTL8192E
case RTL8192E :
SET_TX_DESC_TX_POWER_0_PSET_92E(desc, dpt_lv);
break;
#endif
*/
#ifdef CONFIG_RTL8821C
case RTL8821C :
SET_TX_DESC_TXPWR_OFSET_8821C(desc, dpt_lv);
break;
#endif
default :
RTW_ERR("%s IC not support dynamic tx power\n", __func__);
break;
}
}
void rtw_phydm_set_dyntxpwr(_adapter *adapter, u8 *desc, u8 mac_id)
{
struct dm_struct *dm = adapter_to_phydm(adapter);
odm_set_dyntxpwr(dm, desc, mac_id);
}
#endif
#ifdef CONFIG_RTW_TX_2PATH_EN
void rtw_phydm_tx_2path_en(_adapter *adapter)
{
struct dm_struct *dm = adapter_to_phydm(adapter);
phydm_tx_2path(dm);
}
#endif
#ifdef CONFIG_TDMADIG
void rtw_phydm_tdmadig(_adapter *adapter, u8 state)
{
struct registry_priv *pregistrypriv = &adapter->registrypriv;
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
struct dm_struct *dm = adapter_to_phydm(adapter);
u8 tdma_dig_en;
switch (state) {
case TDMADIG_INIT:
phydm_tdma_dig_para_upd(dm, ENABLE_TDMA, pregistrypriv->tdmadig_en);
phydm_tdma_dig_para_upd(dm, MODE_DECISION, pregistrypriv->tdmadig_mode);
break;
case TDMADIG_NON_INIT:
if(pregistrypriv->tdmadig_dynamic) {
if(pmlmepriv->LinkDetectInfo.bBusyTraffic == _TRUE)
tdma_dig_en = 0;
else
tdma_dig_en = pregistrypriv->tdmadig_en;
phydm_tdma_dig_para_upd(dm, ENABLE_TDMA, tdma_dig_en);
}
break;
default:
break;
}
}
#endif/*CONFIG_TDMADIG*/
void rtw_phydm_ops_func_init(struct dm_struct *p_phydm)
{
struct ra_table *p_ra_t = &p_phydm->dm_ra_table;
p_ra_t->record_ra_info = record_ra_info;
#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
p_phydm->fill_desc_dyntxpwr = rtw_phydm_fill_desc_dpt;
#endif
}
void rtw_phydm_priv_init(_adapter *adapter)
{
PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
struct dm_struct *phydm = &(hal->odmpriv);
phydm->adapter = adapter;
odm_cmn_info_init(phydm, ODM_CMNINFO_PLATFORM, ODM_CE);
}
void Init_ODM_ComInfo(_adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
struct pwrctrl_priv *pwrctl = adapter_to_pwrctl(adapter);
int i;
/*phydm_op_mode could be change for different scenarios: ex: SoftAP - PHYDM_BALANCE_MODE*/
pHalData->phydm_op_mode = PHYDM_PERFORMANCE_MODE;/*Service one device*/
rtw_odm_init_ic_type(adapter);
if (rtw_get_intf_type(adapter) == RTW_GSPI)
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_INTERFACE, ODM_ITRF_SDIO);
else
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_INTERFACE, rtw_get_intf_type(adapter));
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_MP_TEST_CHIP, IS_NORMAL_CHIP(pHalData->version_id));
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_PATCH_ID, pHalData->CustomerID);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BWIFI_TEST, adapter->registrypriv.wifi_spec);
#ifdef CONFIG_ADVANCE_OTA
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_ADVANCE_OTA, adapter->registrypriv.adv_ota);
#endif
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_TYPE, pHalData->rf_type);
{
/* 1 ======= BoardType: ODM_CMNINFO_BOARD_TYPE ======= */
u8 odm_board_type = ODM_BOARD_DEFAULT;
if (pHalData->ExternalLNA_2G != 0) {
odm_board_type |= ODM_BOARD_EXT_LNA;
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_LNA, 1);
}
if (pHalData->external_lna_5g != 0) {
odm_board_type |= ODM_BOARD_EXT_LNA_5G;
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_5G_EXT_LNA, 1);
}
if (pHalData->ExternalPA_2G != 0) {
odm_board_type |= ODM_BOARD_EXT_PA;
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_PA, 1);
}
if (pHalData->external_pa_5g != 0) {
odm_board_type |= ODM_BOARD_EXT_PA_5G;
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_5G_EXT_PA, 1);
}
if (pHalData->EEPROMBluetoothCoexist)
odm_board_type |= ODM_BOARD_BT;
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BOARD_TYPE, odm_board_type);
/* 1 ============== End of BoardType ============== */
}
rtw_hal_set_odm_var(adapter, HAL_ODM_REGULATION, NULL, _TRUE);
#ifdef CONFIG_DFS_MASTER
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_DFS_REGION_DOMAIN, adapter->registrypriv.dfs_region_domain);
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_DFS_MASTER_ENABLE, &(adapter_to_rfctl(adapter)->radar_detect_enabled));
#endif
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GPA, pHalData->TypeGPA);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_APA, pHalData->TypeAPA);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_GLNA, pHalData->TypeGLNA);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_ALNA, pHalData->TypeALNA);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFE_TYPE, pHalData->rfe_type);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_X_CAP_SETTING, pHalData->crystal_cap);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EXT_TRSW, 0);
/*Add by YuChen for kfree init*/
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_REGRFKFREEENABLE, adapter->registrypriv.RegPwrTrimEnable);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RFKFREEENABLE, pHalData->RfKFreeEnable);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_RF_ANTENNA_TYPE, pHalData->TRxAntDivType);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_BE_FIX_TX_ANT, pHalData->b_fix_tx_ant);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_WITH_EXT_ANTENNA_SWITCH, pHalData->with_extenal_ant_switch);
/* (8822B) efuse 0x3D7 & 0x3D8 for TX PA bias */
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EFUSE0X3D7, pHalData->efuse0x3d7);
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_EFUSE0X3D8, pHalData->efuse0x3d8);
/* waiting for PhyDMV034 support*/
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_MANUAL_SUPPORTABILITY, &(adapter->registrypriv.phydm_ability));
/*Add by YuChen for adaptivity init*/
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVITY, &(adapter->registrypriv.adaptivity_en));
phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_CARRIER_SENSE_ENABLE, (adapter->registrypriv.adaptivity_mode != 0) ? TRUE : FALSE);
phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_L2H_INI, adapter->registrypriv.adaptivity_th_l2h_ini);
phydm_adaptivity_info_init(pDM_Odm, PHYDM_ADAPINFO_TH_EDCCA_HL_DIFF, adapter->registrypriv.adaptivity_th_edcca_hl_diff);
/*halrf info init*/
halrf_cmn_info_init(pDM_Odm, HALRF_CMNINFO_EEPROM_THERMAL_VALUE, pHalData->eeprom_thermal_meter);
halrf_cmn_info_init(pDM_Odm, HALRF_CMNINFO_PWT_TYPE, 0);
if (rtw_odm_adaptivity_needed(adapter) == _TRUE)
rtw_odm_adaptivity_config_msg(RTW_DBGDUMP, adapter);
#ifdef CONFIG_IQK_PA_OFF
odm_cmn_info_init(pDM_Odm, ODM_CMNINFO_IQKPAOFF, 1);
#endif
rtw_hal_update_iqk_fw_offload_cap(adapter);
#ifdef CONFIG_FW_OFFLOAD_PARAM_INIT
rtw_hal_update_param_init_fw_offload_cap(adapter);
#endif
/* Pointer reference */
/*Antenna diversity relative parameters*/
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ANT_DIV, &(pHalData->AntDivCfg));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_MP_MODE, &(adapter->registrypriv.mp_mode));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BB_OPERATION_MODE, &(pHalData->phydm_op_mode));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_TX_UNI, &(dvobj->traffic_stat.tx_bytes));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RX_UNI, &(dvobj->traffic_stat.rx_bytes));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BAND, &(pHalData->current_band_type));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_FORCED_RATE, &(pHalData->ForcedDataRate));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SEC_CHNL_OFFSET, &(pHalData->nCur40MhzPrimeSC));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SEC_MODE, &(adapter->securitypriv.dot11PrivacyAlgrthm));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BW, &(pHalData->current_channel_bw));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_CHNL, &(pHalData->current_channel));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_NET_CLOSED, &(adapter->net_closed));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_SCAN, &(pHalData->bScanInProcess));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_POWER_SAVING, &(pwrctl->bpower_saving));
/*Add by Yuchen for phydm beamforming*/
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_TX_TP, &(dvobj->traffic_stat.cur_tx_tp));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RX_TP, &(dvobj->traffic_stat.cur_rx_tp));
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ANT_TEST, &(pHalData->antenna_test));
#ifdef CONFIG_RTL8723B
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_IS1ANTENNA, &pHalData->EEPROMBluetoothAntNum);
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_RFDEFAULTPATH, &pHalData->ant_path);
#endif /*CONFIG_RTL8723B*/
#ifdef CONFIG_USB_HCI
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_HUBUSBMODE, &(dvobj->usb_speed));
#endif
#ifdef CONFIG_DYNAMIC_SOML
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_ADAPTIVE_SOML, &(adapter->registrypriv.dyn_soml_en));
#endif
odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_FCS_MODE, &(pHalData->multi_ch_switch_mode));
/*halrf info hook*/
/* waiting for PhyDMV034 support*/
halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_MANUAL_RF_SUPPORTABILITY, &(adapter->registrypriv.halrf_ability));
#ifdef CONFIG_MP_INCLUDED
halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_CON_TX, &(adapter->mppriv.mpt_ctx.is_start_cont_tx));
halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_SINGLE_TONE, &(adapter->mppriv.mpt_ctx.is_single_tone));
halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_CARRIER_SUPPRESSION, &(adapter->mppriv.mpt_ctx.is_carrier_suppression));
halrf_cmn_info_hook(pDM_Odm, HALRF_CMNINFO_MP_RATE_INDEX, &(adapter->mppriv.mpt_ctx.mpt_rate_index));
#endif/*CONFIG_MP_INCLUDED*/
for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++)
phydm_cmn_sta_info_hook(pDM_Odm, i, NULL);
rtw_phydm_ops_func_init(pDM_Odm);
phydm_dm_early_init(pDM_Odm);
/* TODO */
/* odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BT_OPERATION, _FALSE); */
/* odm_cmn_info_hook(pDM_Odm, ODM_CMNINFO_BT_DISABLE_EDCA, _FALSE); */
}
static u32 edca_setting_UL[HT_IOT_PEER_MAX] =
/*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM,*/
/*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP(DownLink/Tx) */
{ 0x5e4322, 0xa44f, 0x5e4322, 0x5ea32b, 0x5ea422, 0x5ea322, 0x3ea430, 0x5ea42b, 0x5ea44f, 0x5e4322, 0x5e4322};
static u32 edca_setting_DL[HT_IOT_PEER_MAX] =
/*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM,*/
/*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP(UpLink/Rx)*/
{ 0xa44f, 0x5ea44f, 0x5e4322, 0x5ea42b, 0xa44f, 0xa630, 0x5ea630, 0x5ea42b, 0xa44f, 0xa42b, 0xa42b};
static u32 edca_setting_dl_g_mode[HT_IOT_PEER_MAX] =
/*UNKNOWN, REALTEK_90, REALTEK_92SE, BROADCOM,*/
/*RALINK, ATHEROS, CISCO, MERU, MARVELL, 92U_AP, SELF_AP */
{ 0x4322, 0xa44f, 0x5e4322, 0xa42b, 0x5e4322, 0x4322, 0xa42b, 0x5ea42b, 0xa44f, 0x5e4322, 0x5ea42b};
struct turbo_edca_setting{
u32 edca_ul; /* uplink, tx */
u32 edca_dl; /* downlink, rx */
};
#define TURBO_EDCA_ENT(UL, DL) {UL, DL}
#if 0
#define TURBO_EDCA_MODE_NUM 18
static struct turbo_edca_setting rtw_turbo_edca[TURBO_EDCA_MODE_NUM] = {
TURBO_EDCA_ENT(0xa42b, 0xa42b), /* mode 0 */
TURBO_EDCA_ENT(0x431c, 0x431c), /* mode 1 */
TURBO_EDCA_ENT(0x4319, 0x4319), /* mode 2 */
TURBO_EDCA_ENT(0x5ea42b, 0x5ea42b), /* mode 3 */
TURBO_EDCA_ENT(0x5e431c, 0x5e431c), /* mode 4 */
TURBO_EDCA_ENT(0x5e4319, 0x5e4319), /* mode 5 */
TURBO_EDCA_ENT(0x6ea42b, 0x6ea42b), /* mode 6 */
TURBO_EDCA_ENT(0x6e431c, 0x6e431c), /* mode 7 */
TURBO_EDCA_ENT(0x6e4319, 0x6e4319), /* mode 8 */
TURBO_EDCA_ENT(0x5ea42b, 0xa42b), /* mode 9 */
TURBO_EDCA_ENT(0x5e431c, 0x431c), /* mode 10 */
TURBO_EDCA_ENT(0x5e4319, 0x4319), /* mode 11 */
TURBO_EDCA_ENT(0x6ea42b, 0xa42b), /* mode 12 */
TURBO_EDCA_ENT(0x6e431c, 0x431c), /* mode 13 */
TURBO_EDCA_ENT(0x6e4319, 0x4319), /* mode 14 */
TURBO_EDCA_ENT(0x431c, 0x5e431c), /* mode 15 */
TURBO_EDCA_ENT(0xa42b, 0x5ea42b), /* mode 16 */
TURBO_EDCA_ENT(0x138642b, 0x431c), /* mode 17 */
};
#else
#define TURBO_EDCA_MODE_NUM 8
static struct turbo_edca_setting rtw_turbo_edca[TURBO_EDCA_MODE_NUM] = {
/* { UL, DL } */
TURBO_EDCA_ENT(0x5e431c, 0x431c), /* mode 0 */
TURBO_EDCA_ENT(0x431c, 0x431c), /* mode 1 */
TURBO_EDCA_ENT(0x5e431c, 0x5e431c), /* mode 2 */
TURBO_EDCA_ENT(0x5ea42b, 0x5ea42b), /* mode 3 */
TURBO_EDCA_ENT(0x5ea42b, 0x431c), /* mode 4 */
TURBO_EDCA_ENT(0x6ea42b, 0x6ea42b), /* mode 5 */
TURBO_EDCA_ENT(0xa42b, 0xa42b), /* mode 6 */
TURBO_EDCA_ENT(0x5e431c, 0xa42b), /* mode 7 */
};
#endif
void rtw_hal_turbo_edca(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct recv_priv *precvpriv = &(adapter->recvpriv);
struct registry_priv *pregpriv = &adapter->registrypriv;
struct mlme_ext_priv *pmlmeext = &(adapter->mlmeextpriv);
struct mlme_ext_info *pmlmeinfo = &(pmlmeext->mlmext_info);
/* Parameter suggested by Scott */
#if 0
u32 EDCA_BE_UL = edca_setting_UL[p_mgnt_info->iot_peer];
u32 EDCA_BE_DL = edca_setting_DL[p_mgnt_info->iot_peer];
#endif
u32 EDCA_BE_UL = 0x5ea42b;
u32 EDCA_BE_DL = 0x00a42b;
u8 ic_type = rtw_get_chip_type(adapter);
u8 iot_peer = 0;
u8 wireless_mode = 0xFF; /* invalid value */
u8 traffic_index;
u32 edca_param;
u64 cur_tx_bytes = 0;
u64 cur_rx_bytes = 0;
u8 bbtchange = _TRUE;
u8 is_bias_on_rx = _FALSE;
u8 is_linked = _FALSE;
u8 interface_type;
if (hal_data->dis_turboedca == 1)
return;
if (rtw_mi_check_status(adapter, MI_ASSOC))
is_linked = _TRUE;
if (is_linked != _TRUE) {
precvpriv->is_any_non_be_pkts = _FALSE;
return;
}
if ((pregpriv->wifi_spec == 1)) { /* || (pmlmeinfo->HT_enable == 0)) */
precvpriv->is_any_non_be_pkts = _FALSE;
return;
}
interface_type = rtw_get_intf_type(adapter);
wireless_mode = pmlmeext->cur_wireless_mode;
iot_peer = pmlmeinfo->assoc_AP_vendor;
if (iot_peer >= HT_IOT_PEER_MAX) {
precvpriv->is_any_non_be_pkts = _FALSE;
return;
}
if (ic_type == RTL8188E) {
if ((iot_peer == HT_IOT_PEER_RALINK) || (iot_peer == HT_IOT_PEER_ATHEROS))
is_bias_on_rx = _TRUE;
}
/* Check if the status needs to be changed. */
if ((bbtchange) || (!precvpriv->is_any_non_be_pkts)) {
cur_tx_bytes = dvobj->traffic_stat.cur_tx_bytes;
cur_rx_bytes = dvobj->traffic_stat.cur_rx_bytes;
/* traffic, TX or RX */
if (is_bias_on_rx) {
if (cur_tx_bytes > (cur_rx_bytes << 2)) {
/* Uplink TP is present. */
traffic_index = UP_LINK;
} else {
/* Balance TP is present. */
traffic_index = DOWN_LINK;
}
} else {
if (cur_rx_bytes > (cur_tx_bytes << 2)) {
/* Downlink TP is present. */
traffic_index = DOWN_LINK;
} else {
/* Balance TP is present. */
traffic_index = UP_LINK;
}
}
#if 0
if ((p_dm_odm->dm_edca_table.prv_traffic_idx != traffic_index)
|| (!p_dm_odm->dm_edca_table.is_current_turbo_edca))
#endif
{
if (interface_type == RTW_PCIE) {
EDCA_BE_UL = 0x6ea42b;
EDCA_BE_DL = 0x6ea42b;
}
/* 92D txop can't be set to 0x3e for cisco1250 */
if ((iot_peer == HT_IOT_PEER_CISCO) && (wireless_mode == ODM_WM_N24G)) {
EDCA_BE_DL = edca_setting_DL[iot_peer];
EDCA_BE_UL = edca_setting_UL[iot_peer];
}
/* merge from 92s_92c_merge temp*/
else if ((iot_peer == HT_IOT_PEER_CISCO) && ((wireless_mode == ODM_WM_G) || (wireless_mode == (ODM_WM_B | ODM_WM_G)) || (wireless_mode == ODM_WM_A) || (wireless_mode == ODM_WM_B)))
EDCA_BE_DL = edca_setting_dl_g_mode[iot_peer];
else if ((iot_peer == HT_IOT_PEER_AIRGO) && ((wireless_mode == ODM_WM_G) || (wireless_mode == ODM_WM_A)))
EDCA_BE_DL = 0xa630;
else if (iot_peer == HT_IOT_PEER_MARVELL) {
EDCA_BE_DL = edca_setting_DL[iot_peer];
EDCA_BE_UL = edca_setting_UL[iot_peer];
} else if (iot_peer == HT_IOT_PEER_ATHEROS) {
/* Set DL EDCA for Atheros peer to 0x3ea42b.*/
/* Suggested by SD3 Wilson for ASUS TP issue.*/
EDCA_BE_DL = edca_setting_DL[iot_peer];
}
if ((ic_type == RTL8812) || (ic_type == RTL8821) || (ic_type == RTL8192E) || (ic_type == RTL8192F)) { /* add 8812AU/8812AE */
EDCA_BE_UL = 0x5ea42b;
EDCA_BE_DL = 0x5ea42b;
RTW_DBG("8812A: EDCA_BE_UL=0x%x EDCA_BE_DL =0x%x\n", EDCA_BE_UL, EDCA_BE_DL);
}
if (interface_type == RTW_PCIE &&
((ic_type == RTL8822B)
|| (ic_type == RTL8822C)
|| (ic_type == RTL8814A))) {
EDCA_BE_UL = 0x6ea42b;
EDCA_BE_DL = 0x6ea42b;
}
if ((ic_type == RTL8822B)
&& (interface_type == RTW_SDIO))
EDCA_BE_DL = 0x00431c;
#ifdef CONFIG_RTW_TPT_MODE
if ( dvobj->tpt_mode > 0 ) {
EDCA_BE_UL = dvobj->edca_be_ul;
EDCA_BE_DL = dvobj->edca_be_dl;
}
#endif /* CONFIG_RTW_TPT_MODE */
/* keep this condition at last check */
if (hal_data->dis_turboedca == 2) {
if (hal_data->edca_param_mode < TURBO_EDCA_MODE_NUM) {
struct turbo_edca_setting param;
param = rtw_turbo_edca[hal_data->edca_param_mode];
EDCA_BE_UL = param.edca_ul;
EDCA_BE_DL = param.edca_dl;
} else {
EDCA_BE_UL = hal_data->edca_param_mode;
EDCA_BE_DL = hal_data->edca_param_mode;
}
}
if (traffic_index == DOWN_LINK)
edca_param = EDCA_BE_DL;
else
edca_param = EDCA_BE_UL;
#ifdef CONFIG_EXTEND_LOWRATE_TXOP
#define TXOP_CCK1M 0x01A6
#define TXOP_CCK2M 0x00E6
#define TXOP_CCK5M 0x006B
#define TXOP_OFD6M 0x0066
#define TXOP_MCS6M 0x0061
{
struct sta_info *psta;
struct macid_ctl_t *macid_ctl = dvobj_to_macidctl(dvobj);
u8 mac_id, role, current_rate_id;
/* search all used & connect2AP macid */
for (mac_id = 0; mac_id < macid_ctl->num; mac_id++) {
if (rtw_macid_is_used(macid_ctl, mac_id)) {
role = GET_H2CCMD_MSRRPT_PARM_ROLE(&(macid_ctl->h2c_msr[mac_id]));
if (role != H2C_MSR_ROLE_AP)
continue;
psta = macid_ctl->sta[mac_id];
current_rate_id = rtw_get_current_tx_rate(adapter, psta);
/* Check init tx_rate==1M and set 0x508[31:16]==0x019B(unit 32us) if it is */
switch (current_rate_id) {
case DESC_RATE1M:
edca_param &= 0x0000FFFF;
edca_param |= (TXOP_CCK1M<<16);
break;
case DESC_RATE2M:
edca_param &= 0x0000FFFF;
edca_param |= (TXOP_CCK2M<<16);
break;
case DESC_RATE5_5M:
edca_param &= 0x0000FFFF;
edca_param |= (TXOP_CCK5M<<16);
break;
case DESC_RATE6M:
edca_param &= 0x0000FFFF;
edca_param |= (TXOP_OFD6M<<16);
break;
case DESC_RATEMCS0:
edca_param &= 0x0000FFFF;
edca_param |= (TXOP_MCS6M<<16);
break;
default:
break;
}
}
}
}
#endif /* CONFIG_EXTEND_LOWRATE_TXOP */
#ifdef CONFIG_RTW_CUSTOMIZE_BEEDCA
edca_param = CONFIG_RTW_CUSTOMIZE_BEEDCA;
#endif
if ( edca_param != hal_data->ac_param_be) {
rtw_hal_set_hwreg(adapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
RTW_INFO("Turbo EDCA =0x%x\n", edca_param);
}
hal_data->prv_traffic_idx = traffic_index;
}
hal_data->is_turbo_edca = _TRUE;
} else {
/* */
/* Turn Off EDCA turbo here. */
/* Restore original EDCA according to the declaration of AP. */
/* */
if (hal_data->is_turbo_edca) {
edca_param = hal_data->ac_param_be;
rtw_hal_set_hwreg(adapter, HW_VAR_AC_PARAM_BE, (u8 *)(&edca_param));
hal_data->is_turbo_edca = _FALSE;
}
}
}
s8 rtw_dm_get_min_rssi(_adapter *adapter)
{
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
struct sta_info *sta;
s8 min_rssi = 127, rssi;
int i;
for (i = 0; i < MACID_NUM_SW_LIMIT; i++) {
sta = macid_ctl->sta[i];
if (!sta || !GET_H2CCMD_MSRRPT_PARM_OPMODE(macid_ctl->h2c_msr + i)
|| is_broadcast_mac_addr(sta->cmn.mac_addr))
continue;
rssi = sta->cmn.rssi_stat.rssi;
if (rssi >= 0 && min_rssi > rssi)
min_rssi = rssi;
}
return min_rssi == 127 ? 0 : min_rssi;
}
s8 rtw_phydm_get_min_rssi(_adapter *adapter)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
s8 rssi_min = 0;
rssi_min = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_RSSI_MIN);
return rssi_min;
}
u8 rtw_phydm_get_cur_igi(_adapter *adapter)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
u8 cur_igi = 0;
cur_igi = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CURR_IGI);
return cur_igi;
}
bool rtw_phydm_get_edcca_flag(_adapter *adapter)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
bool cur_edcca_flag = 0;
cur_edcca_flag = phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_EDCCA_FLAG);
return cur_edcca_flag;
}
u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
if (cnt == FA_OFDM)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_OFDM);
else if (cnt == FA_CCK)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_CCK);
else if (cnt == FA_TOTAL)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_FA_TOTAL);
else if (cnt == CCA_OFDM)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_OFDM);
else if (cnt == CCA_CCK)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_CCK);
else if (cnt == CCA_ALL)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CCA_ALL);
else if (cnt == CRC32_OK_VHT)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_VHT);
else if (cnt == CRC32_OK_HT)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_HT);
else if (cnt == CRC32_OK_LEGACY)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_LEGACY);
else if (cnt == CRC32_OK_CCK)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_OK_CCK);
else if (cnt == CRC32_ERROR_VHT)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_VHT);
else if (cnt == CRC32_ERROR_HT)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_HT);
else if (cnt == CRC32_ERROR_LEGACY)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_LEGACY);
else if (cnt == CRC32_ERROR_CCK)
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CRC32_ERROR_CCK);
else
return 0;
}
u8 rtw_phydm_is_iqk_in_progress(_adapter *adapter)
{
u8 rts = _FALSE;
struct dm_struct *podmpriv = adapter_to_phydm(adapter);
odm_acquire_spin_lock(podmpriv, RT_IQK_SPINLOCK);
if (podmpriv->rf_calibrate_info.is_iqk_in_progress == _TRUE) {
RTW_ERR("IQK InProgress\n");
rts = _TRUE;
}
odm_release_spin_lock(podmpriv, RT_IQK_SPINLOCK);
return rts;
}
void SetHalODMVar(
PADAPTER Adapter,
HAL_ODM_VARIABLE eVariable,
void *pValue1,
BOOLEAN bSet)
{
struct dm_struct *podmpriv = adapter_to_phydm(Adapter);
/* _irqL irqL; */
switch (eVariable) {
case HAL_ODM_STA_INFO: {
struct sta_info *psta = (struct sta_info *)pValue1;
if (bSet) {
RTW_INFO("### Set STA_(%d) info ###\n", psta->cmn.mac_id);
psta->cmn.dm_ctrl = STA_DM_CTRL_ACTIVE;
phydm_cmn_sta_info_hook(podmpriv, psta->cmn.mac_id, &(psta->cmn));
} else {
RTW_INFO("### Clean STA_(%d) info ###\n", psta->cmn.mac_id);
/* _enter_critical_bh(&pHalData->odm_stainfo_lock, &irqL); */
psta->cmn.dm_ctrl = 0;
phydm_cmn_sta_info_hook(podmpriv, psta->cmn.mac_id, NULL);
/* _exit_critical_bh(&pHalData->odm_stainfo_lock, &irqL); */
}
}
break;
case HAL_ODM_P2P_STATE:
odm_cmn_info_update(podmpriv, ODM_CMNINFO_WIFI_DIRECT, bSet);
break;
case HAL_ODM_WIFI_DISPLAY_STATE:
odm_cmn_info_update(podmpriv, ODM_CMNINFO_WIFI_DISPLAY, bSet);
break;
case HAL_ODM_REGULATION:
/* used to auto enable/disable adaptivity by SD7 */
phydm_adaptivity_info_update(podmpriv, PHYDM_ADAPINFO_DOMAIN_CODE_2G, 0);
phydm_adaptivity_info_update(podmpriv, PHYDM_ADAPINFO_DOMAIN_CODE_5G, 0);
break;
case HAL_ODM_INITIAL_GAIN: {
u8 rx_gain = *((u8 *)(pValue1));
/*printk("rx_gain:%x\n",rx_gain);*/
if (rx_gain == 0xff) {/*restore rx gain*/
/*odm_write_dig(podmpriv,pDigTable->backup_ig_value);*/
odm_pause_dig(podmpriv, PHYDM_RESUME, PHYDM_PAUSE_LEVEL_0, rx_gain);
} else {
/*pDigTable->backup_ig_value = pDigTable->cur_ig_value;*/
/*odm_write_dig(podmpriv,rx_gain);*/
odm_pause_dig(podmpriv, PHYDM_PAUSE, PHYDM_PAUSE_LEVEL_0, rx_gain);
}
}
break;
case HAL_ODM_RX_INFO_DUMP: {
u8 cur_igi = 0;
s8 rssi_min;
void *sel;
sel = pValue1;
cur_igi = rtw_phydm_get_cur_igi(Adapter);
rssi_min = rtw_phydm_get_min_rssi(Adapter);
_RTW_PRINT_SEL(sel, "============ Rx Info dump ===================\n");
_RTW_PRINT_SEL(sel, "is_linked = %d, rssi_min = %d(%%)(%d(%%)), current_igi = 0x%x\n"
, podmpriv->is_linked, rssi_min, rtw_dm_get_min_rssi(Adapter), cur_igi);
_RTW_PRINT_SEL(sel, "cnt_cck_fail = %d, cnt_ofdm_fail = %d, Total False Alarm = %d\n",
rtw_phydm_get_phy_cnt(Adapter, FA_CCK),
rtw_phydm_get_phy_cnt(Adapter, FA_OFDM),
rtw_phydm_get_phy_cnt(Adapter, FA_TOTAL));
if (podmpriv->is_linked) {
_RTW_PRINT_SEL(sel, "rx_rate = %s", HDATA_RATE(podmpriv->rx_rate));
if (IS_HARDWARE_TYPE_8814A(Adapter))
_RTW_PRINT_SEL(sel, " rssi_a = %d(%%), rssi_b = %d(%%), rssi_c = %d(%%), rssi_d = %d(%%)\n",
podmpriv->rssi_a, podmpriv->rssi_b, podmpriv->rssi_c, podmpriv->rssi_d);
else
_RTW_PRINT_SEL(sel, " rssi_a = %d(%%), rssi_b = %d(%%)\n", podmpriv->rssi_a, podmpriv->rssi_b);
#ifdef DBG_RX_SIGNAL_DISPLAY_RAW_DATA
rtw_dump_raw_rssi_info(Adapter, sel);
#endif
}
}
break;
case HAL_ODM_RX_Dframe_INFO: {
void *sel;
sel = pValue1;
/*_RTW_PRINT_SEL(sel , "HAL_ODM_RX_Dframe_INFO\n");*/
#ifdef DBG_RX_DFRAME_RAW_DATA
rtw_dump_rx_dframe_info(Adapter, sel);
#endif
}
break;
#ifdef CONFIG_ANTENNA_DIVERSITY
case HAL_ODM_ANTDIV_SELECT: {
u8 antenna = (*(u8 *)pValue1);
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
/*switch antenna*/
odm_update_rx_idle_ant(&pHalData->odmpriv, antenna);
/*RTW_INFO("==> HAL_ODM_ANTDIV_SELECT, Ant_(%s)\n", (antenna == MAIN_ANT) ? "MAIN_ANT" : "AUX_ANT");*/
}
break;
#endif
default:
break;
}
}
void GetHalODMVar(
PADAPTER Adapter,
HAL_ODM_VARIABLE eVariable,
void *pValue1,
void *pValue2)
{
struct dm_struct *podmpriv = adapter_to_phydm(Adapter);
switch (eVariable) {
#ifdef CONFIG_ANTENNA_DIVERSITY
case HAL_ODM_ANTDIV_SELECT: {
struct phydm_fat_struct *pDM_FatTable = &podmpriv->dm_fat_table;
*((u8 *)pValue1) = pDM_FatTable->rx_idle_ant;
}
break;
#endif
case HAL_ODM_INITIAL_GAIN:
*((u8 *)pValue1) = rtw_phydm_get_cur_igi(Adapter);
break;
default:
break;
}
}
#ifdef RTW_HALMAC
#include "../hal_halmac.h"
#endif
enum hal_status
rtw_phydm_fw_iqk(
struct dm_struct *p_dm_odm,
u8 clear,
u8 segment
)
{
#ifdef RTW_HALMAC
struct _ADAPTER *adapter = p_dm_odm->adapter;
if (rtw_halmac_iqk(adapter_to_dvobj(adapter), clear, segment) == 0)
return HAL_STATUS_SUCCESS;
#endif
return HAL_STATUS_FAILURE;
}
enum hal_status
rtw_phydm_cfg_phy_para(
struct dm_struct *p_dm_odm,
enum phydm_halmac_param config_type,
u32 offset,
u32 data,
u32 mask,
enum rf_path e_rf_path,
u32 delay_time)
{
#ifdef RTW_HALMAC
struct _ADAPTER *adapter = p_dm_odm->adapter;
struct rtw_phy_parameter para;
switch (config_type) {
case PHYDM_HALMAC_CMD_MAC_W8:
para.cmd = 0; /* MAC register */
para.data.mac.offset = offset;
para.data.mac.value = data;
para.data.mac.msk = mask;
para.data.mac.msk_en = (mask) ? 1 : 0;
para.data.mac.size = 1;
break;
case PHYDM_HALMAC_CMD_MAC_W16:
para.cmd = 0; /* MAC register */
para.data.mac.offset = offset;
para.data.mac.value = data;
para.data.mac.msk = mask;
para.data.mac.msk_en = (mask) ? 1 : 0;
para.data.mac.size = 2;
break;
case PHYDM_HALMAC_CMD_MAC_W32:
para.cmd = 0; /* MAC register */
para.data.mac.offset = offset;
para.data.mac.value = data;
para.data.mac.msk = mask;
para.data.mac.msk_en = (mask) ? 1 : 0;
para.data.mac.size = 4;
break;
case PHYDM_HALMAC_CMD_BB_W8:
para.cmd = 1; /* BB register */
para.data.bb.offset = offset;
para.data.bb.value = data;
para.data.bb.msk = mask;
para.data.bb.msk_en = (mask) ? 1 : 0;
para.data.bb.size = 1;
break;
case PHYDM_HALMAC_CMD_BB_W16:
para.cmd = 1; /* BB register */
para.data.bb.offset = offset;
para.data.bb.value = data;
para.data.bb.msk = mask;
para.data.bb.msk_en = (mask) ? 1 : 0;
para.data.bb.size = 2;
break;
case PHYDM_HALMAC_CMD_BB_W32:
para.cmd = 1; /* BB register */
para.data.bb.offset = offset;
para.data.bb.value = data;
para.data.bb.msk = mask;
para.data.bb.msk_en = (mask) ? 1 : 0;
para.data.bb.size = 4;
break;
case PHYDM_HALMAC_CMD_RF_W:
para.cmd = 2; /* RF register */
para.data.rf.offset = offset;
para.data.rf.value = data;
para.data.rf.msk = mask;
para.data.rf.msk_en = (mask) ? 1 : 0;
if (e_rf_path == RF_PATH_A)
para.data.rf.path = 0;
else if (e_rf_path == RF_PATH_B)
para.data.rf.path = 1;
else if (e_rf_path == RF_PATH_C)
para.data.rf.path = 2;
else if (e_rf_path == RF_PATH_D)
para.data.rf.path = 3;
else
para.data.rf.path = 0;
break;
case PHYDM_HALMAC_CMD_DELAY_US:
para.cmd = 3; /* Delay */
para.data.delay.unit = 0; /* microsecond */
para.data.delay.value = delay_time;
break;
case PHYDM_HALMAC_CMD_DELAY_MS:
para.cmd = 3; /* Delay */
para.data.delay.unit = 1; /* millisecond */
para.data.delay.value = delay_time;
break;
case PHYDM_HALMAC_CMD_END:
para.cmd = 0xFF; /* End command */
break;
default:
return HAL_STATUS_FAILURE;
}
if (rtw_halmac_cfg_phy_para(adapter_to_dvobj(adapter), ¶))
return HAL_STATUS_FAILURE;
#endif /*RTW_HALMAC*/
return HAL_STATUS_SUCCESS;
}
#ifdef CONFIG_LPS_LCLK_WD_TIMER
void rtw_phydm_wd_lps_lclk_hdl(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
struct dm_struct *podmpriv = &(pHalData->odmpriv);
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta = NULL;
u8 rssi_min = 0;
u32 rssi_rpt = 0;
bool is_linked = _FALSE;
if (!rtw_is_hw_init_completed(adapter))
return;
if (rtw_mi_check_status(adapter, MI_ASSOC))
is_linked = _TRUE;
if (is_linked == _FALSE)
return;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta == NULL)
return;
odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_LINK, is_linked);
phydm_watchdog_lps_32k(&pHalData->odmpriv);
}
void rtw_phydm_watchdog_in_lps_lclk(_adapter *adapter)
{
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct sta_priv *pstapriv = &adapter->stapriv;
u8 cur_igi = 0;
s8 min_rssi = 0;
if (!rtw_is_hw_init_completed(adapter))
return;
cur_igi = rtw_phydm_get_cur_igi(adapter);
min_rssi = rtw_dm_get_min_rssi(adapter);
/*RTW_INFO("%s "ADPT_FMT" cur_ig_value=%d, min_rssi = %d\n", __func__, ADPT_ARG(adapter), cur_igi, min_rssi);*/
if (min_rssi <= 0)
return;
if ((cur_igi > min_rssi + 5) ||
(cur_igi < min_rssi - 5)) {
#ifdef CONFIG_LPS
rtw_dm_in_lps_wk_cmd(adapter);
#endif
}
}
#endif /*CONFIG_LPS_LCLK_WD_TIMER*/
void dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta)
{
struct ra_sta_info *ra_info;
u8 curr_sgi = _FALSE;
u32 tx_tp_mbips, rx_tp_mbips, bi_tp_mbips;
if (!psta)
return;
RTW_PRINT_SEL(sel, "\n");
RTW_PRINT_SEL(sel, "====== mac_id : %d [" MAC_FMT "] ======\n",
psta->cmn.mac_id, MAC_ARG(psta->cmn.mac_addr));
if (is_client_associated_to_ap(psta->padapter))
RTW_PRINT_SEL(sel, "BCN counts : %d (per-%d second), DTIM Period:%d\n",
rtw_get_bcn_cnt(psta->padapter) / 2, 1, rtw_get_bcn_dtim_period(psta->padapter));
ra_info = &psta->cmn.ra_info;
curr_sgi = rtw_get_current_tx_sgi(adapter, psta);
RTW_PRINT_SEL(sel, "tx_rate : %s(%s) rx_rate : %s, rx_rate_bmc : %s, rssi : %d %%\n"
, HDATA_RATE(rtw_get_current_tx_rate(adapter, psta)), (curr_sgi) ? "S" : "L"
, HDATA_RATE((psta->curr_rx_rate & 0x7F)), HDATA_RATE((psta->curr_rx_rate_bmc & 0x7F)), psta->cmn.rssi_stat.rssi
);
if (0) {
RTW_PRINT_SEL(sel, "tx_bytes:%llu(%llu - %llu)\n"
, psta->sta_stats.tx_bytes - psta->sta_stats.last_tx_bytes
, psta->sta_stats.tx_bytes, psta->sta_stats.last_tx_bytes
);
RTW_PRINT_SEL(sel, "rx_uc_bytes:%llu(%llu - %llu)\n"
, sta_rx_uc_bytes(psta) - sta_last_rx_uc_bytes(psta)
, sta_rx_uc_bytes(psta), sta_last_rx_uc_bytes(psta)
);
RTW_PRINT_SEL(sel, "rx_mc_bytes:%llu(%llu - %llu)\n"
, psta->sta_stats.rx_mc_bytes - psta->sta_stats.last_rx_mc_bytes
, psta->sta_stats.rx_mc_bytes, psta->sta_stats.last_rx_mc_bytes
);
RTW_PRINT_SEL(sel, "rx_bc_bytes:%llu(%llu - %llu)\n"
, psta->sta_stats.rx_bc_bytes - psta->sta_stats.last_rx_bc_bytes
, psta->sta_stats.rx_bc_bytes, psta->sta_stats.last_rx_bc_bytes
);
}
_RTW_PRINT_SEL(sel, "RTW: [TP] ");
tx_tp_mbips = psta->sta_stats.tx_tp_kbits >> 10;
rx_tp_mbips = psta->sta_stats.rx_tp_kbits >> 10;
bi_tp_mbips = tx_tp_mbips + rx_tp_mbips;
if (tx_tp_mbips)
_RTW_PRINT_SEL(sel, "Tx : %d(Mbps) ", tx_tp_mbips);
else
_RTW_PRINT_SEL(sel, "Tx : %d(Kbps) ", psta->sta_stats.tx_tp_kbits);
if (rx_tp_mbips)
_RTW_PRINT_SEL(sel, "Rx : %d(Mbps) ", rx_tp_mbips);
else
_RTW_PRINT_SEL(sel, "Rx : %d(Kbps) ", psta->sta_stats.rx_tp_kbits);
if (bi_tp_mbips)
_RTW_PRINT_SEL(sel, "Total : %d(Mbps)\n", bi_tp_mbips);
else
_RTW_PRINT_SEL(sel, "Total : %d(Kbps)\n", psta->sta_stats.tx_tp_kbits + psta->sta_stats.rx_tp_kbits);
_RTW_PRINT_SEL(sel, "RTW: [Smooth TP] ");
tx_tp_mbips = psta->sta_stats.smooth_tx_tp_kbits >> 10;
rx_tp_mbips = psta->sta_stats.smooth_rx_tp_kbits >> 10;
bi_tp_mbips = tx_tp_mbips + rx_tp_mbips;
if (tx_tp_mbips)
_RTW_PRINT_SEL(sel, "Tx : %d(Mbps) ", tx_tp_mbips);
else
_RTW_PRINT_SEL(sel, "Tx : %d(Kbps) ", psta->sta_stats.smooth_tx_tp_kbits);
if (rx_tp_mbips)
_RTW_PRINT_SEL(sel, "Rx : %d(Mbps) ", rx_tp_mbips);
else
_RTW_PRINT_SEL(sel, "Rx : %d(Kbps) ", psta->sta_stats.smooth_rx_tp_kbits);
if (bi_tp_mbips)
_RTW_PRINT_SEL(sel, "Total : %d(Mbps)\n", bi_tp_mbips);
else
_RTW_PRINT_SEL(sel, "Total : %d(Kbps)\n", psta->sta_stats.smooth_tx_tp_kbits + psta->sta_stats.rx_tp_kbits);
#if 0
RTW_PRINT_SEL(sel, "Moving-AVG TP {Tx,Rx,Total} = { %d , %d , %d } Mbps\n\n",
(psta->cmn.tx_moving_average_tp << 3), (psta->cmn.rx_moving_average_tp << 3),
(psta->cmn.tx_moving_average_tp + psta->cmn.rx_moving_average_tp) << 3);
#endif
}
void dump_sta_info(void *sel, struct sta_info *psta)
{
struct ra_sta_info *ra_info;
u8 curr_tx_sgi = _FALSE;
u8 curr_tx_rate = 0;
if (!psta)
return;
ra_info = &psta->cmn.ra_info;
RTW_PRINT_SEL(sel, "============ STA [" MAC_FMT "] ===================\n",
MAC_ARG(psta->cmn.mac_addr));
RTW_PRINT_SEL(sel, "mac_id : %d\n", psta->cmn.mac_id);
RTW_PRINT_SEL(sel, "wireless_mode : 0x%02x\n", psta->wireless_mode);
RTW_PRINT_SEL(sel, "mimo_type : %d\n", psta->cmn.mimo_type);
RTW_PRINT_SEL(sel, "static smps : %s\n", (psta->cmn.sm_ps == SM_PS_STATIC) ? "Y" : "N");
RTW_PRINT_SEL(sel, "bw_mode : %s, ra_bw_mode : %s\n",
ch_width_str(psta->cmn.bw_mode), ch_width_str(ra_info->ra_bw_mode));
RTW_PRINT_SEL(sel, "rate_id : %d\n", ra_info->rate_id);
RTW_PRINT_SEL(sel, "rssi : %d (%%), rssi_level : %d\n", psta->cmn.rssi_stat.rssi, ra_info->rssi_level);
RTW_PRINT_SEL(sel, "is_support_sgi : %s, is_vht_enable : %s\n",
(ra_info->is_support_sgi) ? "Y" : "N", (ra_info->is_vht_enable) ? "Y" : "N");
RTW_PRINT_SEL(sel, "disable_ra : %s, disable_pt : %s\n",
(ra_info->disable_ra) ? "Y" : "N", (ra_info->disable_pt) ? "Y" : "N");
RTW_PRINT_SEL(sel, "is_noisy : %s\n", (ra_info->is_noisy) ? "Y" : "N");
RTW_PRINT_SEL(sel, "txrx_state : %d\n", ra_info->txrx_state);/*0: uplink, 1:downlink, 2:bi-direction*/
curr_tx_sgi = rtw_get_current_tx_sgi(psta->padapter, psta);
curr_tx_rate = rtw_get_current_tx_rate(psta->padapter, psta);
RTW_PRINT_SEL(sel, "curr_tx_rate : %s (%s)\n",
HDATA_RATE(curr_tx_rate), (curr_tx_sgi) ? "S" : "L");
RTW_PRINT_SEL(sel, "curr_tx_bw : %s\n", ch_width_str(ra_info->curr_tx_bw));
RTW_PRINT_SEL(sel, "curr_retry_ratio : %d\n", ra_info->curr_retry_ratio);
RTW_PRINT_SEL(sel, "ra_mask : 0x%016llx\n\n", ra_info->ramask);
}
void rtw_phydm_ra_registed(_adapter *adapter, struct sta_info *psta)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
if (psta == NULL) {
RTW_ERR(FUNC_ADPT_FMT" sta is NULL\n", FUNC_ADPT_ARG(adapter));
rtw_warn_on(1);
return;
}
phydm_ra_registed(&hal_data->odmpriv, psta->cmn.mac_id, psta->cmn.rssi_stat.rssi);
dump_sta_info(RTW_DBGDUMP, psta);
}
static void init_phydm_info(_adapter *adapter)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = &(hal_data->odmpriv);
odm_cmn_info_update(phydm, ODM_CMNINFO_IS_DOWNLOAD_FW, hal_data->bFWReady);
odm_cmn_info_init(phydm, ODM_CMNINFO_FW_VER, hal_data->firmware_version);
odm_cmn_info_init(phydm, ODM_CMNINFO_FW_SUB_VER, hal_data->firmware_sub_version);
}
void rtw_phydm_init(_adapter *adapter)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = &(hal_data->odmpriv);
init_phydm_info(adapter);
odm_dm_init(phydm);
#ifdef CONFIG_CUSTOMER01_SMART_ANTENNA
phydm_pathb_q_matrix_rotate_en(phydm);
#endif
}
bool rtw_phydm_set_crystal_cap(_adapter *adapter, u8 crystal_cap)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = &(hal_data->odmpriv);
return phydm_set_crystal_cap_reg(phydm, crystal_cap);
}
#ifdef CONFIG_LPS_PG
/*
static void _lps_pg_state_update(_adapter *adapter)
{
u8 is_in_lpspg = _FALSE;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(adapter);
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
struct sta_priv *pstapriv = &adapter->stapriv;
struct sta_info *psta = NULL;
if ((pwrpriv->lps_level == LPS_PG) && (pwrpriv->pwr_mode != PS_MODE_ACTIVE) && (pwrpriv->rpwm <= PS_STATE_S2))
is_in_lpspg = _TRUE;
psta = rtw_get_stainfo(pstapriv, get_bssid(pmlmepriv));
if (psta)
psta->cmn.ra_info.disable_ra = (is_in_lpspg) ? _TRUE : _FALSE;
}
*/
void rtw_phydm_lps_pg_hdl(_adapter *adapter, struct sta_info *sta, bool in_lpspg)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
/*u8 rate_id;*/
if(sta == NULL) {
RTW_ERR("%s sta is null\n", __func__);
rtw_warn_on(1);
return;
}
if (in_lpspg) {
sta->cmn.ra_info.disable_ra = _TRUE;
sta->cmn.ra_info.disable_pt = _TRUE;
/*TODO : DRV fix tx rate*/
/*rate_id = phydm_get_rate_from_rssi_lv(phydm, sta->cmn.mac_id);*/
} else {
sta->cmn.ra_info.disable_ra = _FALSE;
sta->cmn.ra_info.disable_pt = _FALSE;
}
rtw_phydm_ra_registed(adapter, sta);
}
#endif
/*#define DBG_PHYDM_STATE_CHK*/
static u8 _rtw_phydm_rfk_condition_check(_adapter *adapter, u8 is_scaning, u8 ifs_linked)
{
u8 rfk_allowed = _TRUE;
#ifdef CONFIG_SKIP_RFK_IN_DM
rfk_allowed = _FALSE;
if (0)
RTW_ERR("[RFK-CHK] RF-K not allowed due to CONFIG_SKIP_RFK_IN_DM\n");
return rfk_allowed;
#endif
#ifdef CONFIG_MCC_MODE
/*not in MCC State*/
if (MCC_EN(adapter) &&
rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
rfk_allowed = _FALSE;
if (0)
RTW_INFO("[RFK-CHK] RF-K not allowed due to doing MCC\n");
return rfk_allowed;
}
#endif
#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
#endif
if (ifs_linked) {
if (is_scaning) {
rfk_allowed = _FALSE;
RTW_DBG("[RFK-CHK] RF-K not allowed due to ifaces under site-survey\n");
}
else {
rfk_allowed = rtw_mi_stayin_union_ch_chk(adapter) ? _TRUE : _FALSE;
if (rfk_allowed == _FALSE)
RTW_ERR("[RFK-CHK] RF-K not allowed due to ld_iface not stayin union ch\n");
}
}
return rfk_allowed;
}
#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
static u8 _rtw_phydm_iqk_segment_chk(_adapter *adapter, u8 ifs_linked)
{
u8 iqk_sgt = _FALSE;
#if 0
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
if (ifs_linked && (dvobj->traffic_stat.cur_tx_tp > 2 || dvobj->traffic_stat.cur_rx_tp > 2))
rst = _TRUE;
#else
if (ifs_linked)
iqk_sgt = _TRUE;
#endif
return iqk_sgt;
}
#endif
/*check the tx low rate while unlinked to any AP;for pwr tracking */
static u8 _rtw_phydm_pwr_tracking_rate_check(_adapter *adapter)
{
int i;
_adapter *iface;
u8 if_tx_rate = 0xFF;
u8 tx_rate = 0xFF;
struct mlme_ext_priv *pmlmeext = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
pmlmeext = &(iface->mlmeextpriv);
if ((iface) && rtw_is_adapter_up(iface)) {
#ifdef CONFIG_P2P
if (!rtw_p2p_chk_role(&(iface)->wdinfo, P2P_ROLE_DISABLE))
if_tx_rate = IEEE80211_OFDM_RATE_6MB;
else
#endif
if_tx_rate = pmlmeext->tx_rate;
if(if_tx_rate < tx_rate)
tx_rate = if_tx_rate;
RTW_DBG("%s i=%d tx_rate =0x%x\n", __func__, i, if_tx_rate);
}
}
RTW_DBG("%s tx_low_rate (unlinked to any AP)=0x%x\n", __func__, tx_rate);
return tx_rate;
}
#ifdef CONFIG_DYNAMIC_SOML
void rtw_dyn_soml_byte_update(_adapter *adapter, u8 data_rate, u32 size)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
phydm_soml_bytes_acq(phydm, data_rate, size);
}
void rtw_dyn_soml_para_set(_adapter *adapter, u8 train_num, u8 intvl,
u8 period, u8 delay)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
phydm_adaptive_soml_para_set(phydm, train_num, intvl, period, delay);
RTW_INFO("%s.\n", __func__);
}
void rtw_dyn_soml_config(_adapter *adapter)
{
RTW_INFO("%s.\n", __func__);
if (adapter->registrypriv.dyn_soml_en == 1) {
/* Must after phydm_adaptive_soml_init() */
rtw_hal_set_hwreg(adapter , HW_VAR_SET_SOML_PARAM , NULL);
RTW_INFO("dyn_soml_en = 1\n");
} else {
if (adapter->registrypriv.dyn_soml_en == 2) {
rtw_dyn_soml_para_set(adapter,
adapter->registrypriv.dyn_soml_train_num,
adapter->registrypriv.dyn_soml_interval,
adapter->registrypriv.dyn_soml_period,
adapter->registrypriv.dyn_soml_delay);
RTW_INFO("dyn_soml_en = 2\n");
RTW_INFO("dyn_soml_en, param = %d, %d, %d, %d\n",
adapter->registrypriv.dyn_soml_train_num,
adapter->registrypriv.dyn_soml_interval,
adapter->registrypriv.dyn_soml_period,
adapter->registrypriv.dyn_soml_delay);
} else if (adapter->registrypriv.dyn_soml_en == 0) {
RTW_INFO("dyn_soml_en = 0\n");
} else
RTW_ERR("%s, wrong setting: dyn_soml_en = %d\n", __func__,
adapter->registrypriv.dyn_soml_en);
}
}
#endif
#ifdef RTW_DYNAMIC_RRSR
void rtw_phydm_set_rrsr(_adapter *adapter, u32 rrsr_value, bool write_rrsr)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
odm_cmn_info_update(phydm, ODM_CMNINFO_RRSR_VAL, rrsr_value);
if(write_rrsr)
phydm_rrsr_set_register(phydm, rrsr_value);
}
#endif/*RTW_DYNAMIC_RRSR*/
void rtw_phydm_read_efuse(_adapter *adapter)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = &(hal_data->odmpriv);
/*PHYDM API - thermal trim*/
phydm_get_thermal_trim_offset(phydm);
/*PHYDM API - power trim*/
phydm_get_power_trim_offset(phydm);
}
#ifdef CONFIG_LPS_PWR_TRACKING
void rtw_phydm_pwr_tracking_directly(_adapter *adapter)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA(adapter);
u8 rfk_forbidden = _TRUE;
u8 is_linked = _FALSE;
if (rtw_mi_check_status(adapter, MI_ASSOC))
is_linked = _TRUE;
rfk_forbidden = (_rtw_phydm_rfk_condition_check(adapter, hal_data->bScanInProcess, is_linked) == _TRUE) ? _FALSE : _TRUE;
halrf_cmn_info_set(&hal_data->odmpriv, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
odm_txpowertracking_direct_ce(&hal_data->odmpriv);
}
#endif
void rtw_phydm_watchdog(_adapter *adapter, bool in_lps)
{
u8 bLinked = _FALSE;
u8 bsta_state = _FALSE;
u8 bBtDisabled = _TRUE;
u8 rfk_forbidden = _FALSE;
#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
u8 segment_iqk = _FALSE;
#endif
u8 tx_unlinked_low_rate = 0xFF;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(adapter);
if (!rtw_is_hw_init_completed(adapter)) {
RTW_DBG("%s skip due to hw_init_completed == FALSE\n", __func__);
return;
}
if (rtw_mi_check_fwstate(adapter, _FW_UNDER_SURVEY))
pHalData->bScanInProcess = _TRUE;
else
pHalData->bScanInProcess = _FALSE;
if (rtw_mi_check_status(adapter, MI_ASSOC)) {
bLinked = _TRUE;
if (rtw_mi_check_status(adapter, MI_STA_LINKED))
bsta_state = _TRUE;
}
odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_LINK, bLinked);
odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_STATION_STATE, bsta_state);
#ifdef CONFIG_BT_COEXIST
bBtDisabled = rtw_btcoex_IsBtDisabled(adapter);
#endif /* CONFIG_BT_COEXIST */
odm_cmn_info_update(&pHalData->odmpriv, ODM_CMNINFO_BT_ENABLED,
(bBtDisabled == _TRUE) ? _FALSE : _TRUE);
rfk_forbidden = (_rtw_phydm_rfk_condition_check(adapter, pHalData->bScanInProcess, bLinked) == _TRUE) ? _FALSE : _TRUE;
halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
segment_iqk = _rtw_phydm_iqk_segment_chk(adapter, bLinked);
halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_IQK_SEGMENT, segment_iqk);
#endif
#ifdef DBG_PHYDM_STATE_CHK
RTW_INFO("%s rfk_forbidden = %s, segment_iqk = %s\n",
__func__, (rfk_forbidden) ? "Y" : "N", (segment_iqk) ? "Y" : "N");
#endif
if (bLinked == _FALSE) {
tx_unlinked_low_rate = _rtw_phydm_pwr_tracking_rate_check(adapter);
halrf_cmn_info_set(&pHalData->odmpriv, HALRF_CMNINFO_RATE_INDEX, tx_unlinked_low_rate);
}
/*if (!rtw_mi_stayin_union_band_chk(adapter)) {
#ifdef DBG_PHYDM_STATE_CHK
RTW_ERR("Not stay in union band, skip phydm\n");
#endif
goto _exit;
}*/
#ifdef CONFIG_TDMADIG
rtw_phydm_tdmadig(adapter, TDMADIG_NON_INIT);
#endif/*CONFIG_TDMADIG*/
if (in_lps)
phydm_watchdog_lps(&pHalData->odmpriv);
else
phydm_watchdog(&pHalData->odmpriv);
#ifdef CONFIG_RTW_ACS
rtw_acs_update_current_info(adapter);
#endif
return;
}
#ifdef CONFIG_CTRL_TXSS_BY_TP
void rtw_phydm_trx_cfg(_adapter *adapter, bool tx_1ss)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
enum bb_path txpath = BB_PATH_AB;
enum bb_path rxpath = BB_PATH_AB;
/*is_2tx = _FALSE for 8822B, or BB_PATH_AUTO for PATH_DIVERSITY for 8822B*/
enum bb_path txpath_1ss = BB_PATH_A;
rtw_hal_get_rf_path(adapter_to_dvobj(adapter), NULL, &txpath, &rxpath);
txpath = (tx_1ss) ? BB_PATH_A : txpath;
if (phydm_api_trx_mode(adapter_to_phydm(adapter), txpath, rxpath, txpath_1ss) == FALSE)
RTW_ERR("%s failed\n", __func__);
}
#endif
================================================
FILE: hal/hal_dm.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HAL_DM_H__
#define __HAL_DM_H__
#define adapter_to_phydm(adapter) (&(GET_HAL_DATA(adapter)->odmpriv))
#define dvobj_to_phydm(dvobj) adapter_to_phydm(dvobj_get_primary_adapter(dvobj))
#ifdef CONFIG_TDMADIG
void rtw_phydm_tdmadig(_adapter *adapter, u8 state);
#endif
void rtw_phydm_priv_init(_adapter *adapter);
void Init_ODM_ComInfo(_adapter *adapter);
void rtw_phydm_init(_adapter *adapter);
void rtw_hal_turbo_edca(_adapter *adapter);
u8 rtw_phydm_is_iqk_in_progress(_adapter *adapter);
void GetHalODMVar(
PADAPTER Adapter,
HAL_ODM_VARIABLE eVariable,
void *pValue1,
void *pValue2);
void SetHalODMVar(
PADAPTER Adapter,
HAL_ODM_VARIABLE eVariable,
void *pValue1,
BOOLEAN bSet);
void rtw_phydm_ra_registed(_adapter *adapter, struct sta_info *psta);
#ifdef CONFIG_DYNAMIC_SOML
void rtw_dyn_soml_byte_update(_adapter *adapter, u8 data_rate, u32 size);
void rtw_dyn_soml_para_set(_adapter *adapter, u8 train_num, u8 intvl,
u8 period, u8 delay);
void rtw_dyn_soml_config(_adapter *adapter);
#endif
#ifdef RTW_DYNAMIC_RRSR
void rtw_phydm_set_rrsr(_adapter *adapter, u32 rrsr_value, bool write_rrsr);
#endif
void rtw_phydm_watchdog(_adapter *adapter, bool in_lps);
void rtw_hal_update_iqk_fw_offload_cap(_adapter *adapter);
void dump_sta_info(void *sel, struct sta_info *psta);
void dump_sta_traffic(void *sel, _adapter *adapter, struct sta_info *psta);
#ifdef CONFIG_DBG_RF_CAL
void rtw_hal_iqk_test(_adapter *adapter, bool recovery, bool clear, bool segment);
void rtw_hal_lck_test(_adapter *adapter);
#endif
s8 rtw_dm_get_min_rssi(_adapter *adapter);
s8 rtw_phydm_get_min_rssi(_adapter *adapter);
u8 rtw_phydm_get_cur_igi(_adapter *adapter);
bool rtw_phydm_get_edcca_flag(_adapter *adapter);
#ifdef CONFIG_LPS_LCLK_WD_TIMER
extern void phydm_rssi_monitor_check(void *p_dm_void);
void rtw_phydm_wd_lps_lclk_hdl(_adapter *adapter);
void rtw_phydm_watchdog_in_lps_lclk(_adapter *adapter);
#endif
#ifdef CONFIG_TDMADIG
enum rtw_tdmadig_state{
TDMADIG_INIT,
TDMADIG_NON_INIT,
};
#endif
enum phy_cnt {
FA_OFDM,
FA_CCK,
FA_TOTAL,
CCA_OFDM,
CCA_CCK,
CCA_ALL,
CRC32_OK_VHT,
CRC32_OK_HT,
CRC32_OK_LEGACY,
CRC32_OK_CCK,
CRC32_ERROR_VHT,
CRC32_ERROR_HT,
CRC32_ERROR_LEGACY,
CRC32_ERROR_CCK,
};
u32 rtw_phydm_get_phy_cnt(_adapter *adapter, enum phy_cnt cnt);
#if ((RTL8822B_SUPPORT == 1) || (RTL8821C_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8822C_SUPPORT == 1))
void rtw_phydm_iqk_trigger(_adapter *adapter);
#endif
void rtw_phydm_read_efuse(_adapter *adapter);
bool rtw_phydm_set_crystal_cap(_adapter *adapter, u8 crystal_cap);
#ifdef CONFIG_SUPPORT_DYNAMIC_TXPWR
void rtw_phydm_set_dyntxpwr(_adapter *adapter, u8 *desc, u8 mac_id);
#endif
#ifdef CONFIG_RTW_TX_2PATH_EN
void rtw_phydm_tx_2path_en(_adapter *adapter);
#endif
#ifdef CONFIG_LPS_PG
void rtw_phydm_lps_pg_hdl(_adapter *adapter, struct sta_info *sta, bool in_lpspg);
#endif
#ifdef CONFIG_LPS_PWR_TRACKING
void rtw_phydm_pwr_tracking_directly(_adapter *adapter);
#endif
#ifdef CONFIG_CTRL_TXSS_BY_TP
void rtw_phydm_trx_cfg(_adapter *adapter, bool tx_1ss);
#endif
#endif /* __HAL_DM_H__ */
================================================
FILE: hal/hal_dm_acs.c
================================================
/******************************************************************************
*
* Copyright(c) 2014 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#if defined(CONFIG_RTW_ACS) || defined(CONFIG_BACKGROUND_NOISE_MONITOR)
static void _rtw_bss_nums_count(_adapter *adapter, u8 *pbss_nums)
{
struct mlme_priv *pmlmepriv = &(adapter->mlmepriv);
_queue *queue = &(pmlmepriv->scanned_queue);
struct wlan_network *pnetwork = NULL;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
_list *plist, *phead;
_irqL irqL;
int chan_idx = -1;
if (pbss_nums == NULL) {
RTW_ERR("%s pbss_nums is null pointer\n", __func__);
return;
}
_rtw_memset(pbss_nums, 0, MAX_CHANNEL_NUM);
_enter_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
phead = get_list_head(queue);
plist = get_next(phead);
while (1) {
if (rtw_end_of_queue_search(phead, plist) == _TRUE)
break;
pnetwork = LIST_CONTAINOR(plist, struct wlan_network, list);
if (!pnetwork)
break;
chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), pnetwork->network.Configuration.DSConfig);
if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
RTW_ERR("%s can't get chan_idx(CH:%d)\n",
__func__, pnetwork->network.Configuration.DSConfig);
chan_idx = 0;
}
/*if (pnetwork->network.Reserved[0] != BSS_TYPE_PROB_REQ)*/
pbss_nums[chan_idx]++;
plist = get_next(plist);
}
_exit_critical_bh(&(pmlmepriv->scanned_queue.lock), &irqL);
}
u8 rtw_get_ch_num_by_idx(_adapter *adapter, u8 idx)
{
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
RT_CHANNEL_INFO *pch_set = rfctl->channel_set;
u8 max_chan_nums = rfctl->max_chan_nums;
if (idx >= max_chan_nums)
return 0;
return pch_set[idx].ChannelNum;
}
#endif /*defined(CONFIG_RTW_ACS) || defined(CONFIG_BACKGROUND_NOISE_MONITOR)*/
#ifdef CONFIG_RTW_ACS
void rtw_acs_version_dump(void *sel, _adapter *adapter)
{
_RTW_PRINT_SEL(sel, "RTK_ACS VER_%d\n", RTK_ACS_VERSION);
}
u8 rtw_phydm_clm_ratio(_adapter *adapter)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_CLM_RATIO);
}
u8 rtw_phydm_nhm_ratio(_adapter *adapter)
{
struct dm_struct *phydm = adapter_to_phydm(adapter);
return phydm_cmn_info_query(phydm, (enum phydm_info_query) PHYDM_INFO_NHM_RATIO);
}
void rtw_acs_reset(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct auto_chan_sel *pacs = &hal_data->acs;
_rtw_memset(pacs, 0, sizeof(struct auto_chan_sel));
#ifdef CONFIG_RTW_ACS_DBG
rtw_acs_adv_reset(adapter);
#endif /*CONFIG_RTW_ACS_DBG*/
}
#ifdef CONFIG_RTW_ACS_DBG
u8 rtw_is_acs_igi_valid(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct auto_chan_sel *pacs = &hal_data->acs;
if ((pacs->igi) && ((pacs->igi >= 0x1E) || (pacs->igi < 0x60)))
return _TRUE;
return _FALSE;
}
void rtw_acs_adv_setting(_adapter *adapter, RT_SCAN_TYPE scan_type, u16 scan_time, u8 igi, u8 bw)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct auto_chan_sel *pacs = &hal_data->acs;
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
pacs->scan_type = scan_type;
pacs->scan_time = scan_time;
pacs->igi = igi;
pacs->bw = bw;
RTW_INFO("[ACS] ADV setting - scan_type:%c, ch_ms:%d(ms), igi:0x%02x, bw:%d\n",
pacs->scan_type ? 'A' : 'P', pacs->scan_time, pacs->igi, pacs->bw);
}
void rtw_acs_adv_reset(_adapter *adapter)
{
rtw_acs_adv_setting(adapter, SCAN_ACTIVE, 0, 0, 0);
}
#endif /*CONFIG_RTW_ACS_DBG*/
void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan, enum NHM_PID pid)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = adapter_to_phydm(adapter);
#if (RTK_ACS_VERSION == 3)
struct clm_para_info clm_para;
struct nhm_para_info nhm_para;
struct env_trig_rpt trig_rpt;
scan_time_ms -= 10;
init_acs_clm(clm_para, scan_time_ms);
if (pid == NHM_PID_IEEE_11K_HIGH)
init_11K_high_nhm(nhm_para, scan_time_ms);
else if (pid == NHM_PID_IEEE_11K_LOW)
init_11K_low_nhm(nhm_para, scan_time_ms);
else
init_acs_nhm(nhm_para, scan_time_ms);
hal_data->acs.trig_rst = phydm_env_mntr_trigger(phydm, &nhm_para, &clm_para, &trig_rpt);
if (hal_data->acs.trig_rst == (NHM_SUCCESS | CLM_SUCCESS)) {
hal_data->acs.trig_rpt.clm_rpt_stamp = trig_rpt.clm_rpt_stamp;
hal_data->acs.trig_rpt.nhm_rpt_stamp = trig_rpt.nhm_rpt_stamp;
/*RTW_INFO("[ACS] trigger success (rst = 0x%02x, clm_stamp:%d, nhm_stamp:%d)\n",
hal_data->acs.trig_rst, hal_data->acs.trig_rpt.clm_rpt_stamp, hal_data->acs.trig_rpt.nhm_rpt_stamp);*/
} else
RTW_ERR("[ACS] trigger failed (rst = 0x%02x)\n", hal_data->acs.trig_rst);
#else
phydm_ccx_monitor_trigger(phydm, scan_time_ms);
#endif
hal_data->acs.trigger_ch = scan_chan;
hal_data->acs.triggered = _TRUE;
#ifdef CONFIG_RTW_ACS_DBG
RTW_INFO("[ACS] Trigger CH:%d, Times:%d\n", hal_data->acs.trigger_ch, scan_time_ms);
#endif
}
void rtw_acs_get_rst(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = adapter_to_phydm(adapter);
int chan_idx = -1;
u8 cur_chan = hal_data->acs.trigger_ch;
if (cur_chan == 0)
return;
if (!hal_data->acs.triggered)
return;
chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), cur_chan);
if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
RTW_ERR("[ACS] %s can't get chan_idx(CH:%d)\n", __func__, cur_chan);
return;
}
#if (RTK_ACS_VERSION == 3)
if (!(hal_data->acs.trig_rst == (NHM_SUCCESS | CLM_SUCCESS))) {
RTW_ERR("[ACS] get_rst return, due to acs trigger failed\n");
return;
}
{
struct env_mntr_rpt rpt = {0};
u8 rst;
rst = phydm_env_mntr_result(phydm, &rpt);
if ((rst == (NHM_SUCCESS | CLM_SUCCESS)) &&
(rpt.clm_rpt_stamp == hal_data->acs.trig_rpt.clm_rpt_stamp) &&
(rpt.nhm_rpt_stamp == hal_data->acs.trig_rpt.nhm_rpt_stamp)){
hal_data->acs.clm_ratio[chan_idx] = rpt.clm_ratio;
hal_data->acs.nhm_ratio[chan_idx] = rpt.nhm_ratio;
_rtw_memcpy(&hal_data->acs.nhm[chan_idx][0], rpt.nhm_result, NHM_RPT_NUM);
/*RTW_INFO("[ACS] get_rst success (rst = 0x%02x, clm_stamp:%d:%d, nhm_stamp:%d:%d)\n",
rst,
hal_data->acs.trig_rpt.clm_rpt_stamp, rpt.clm_rpt_stamp,
hal_data->acs.trig_rpt.nhm_rpt_stamp, rpt.nhm_rpt_stamp);*/
} else {
RTW_ERR("[ACS] get_rst failed (rst = 0x%02x, clm_stamp:%d:%d, nhm_stamp:%d:%d)\n",
rst,
hal_data->acs.trig_rpt.clm_rpt_stamp, rpt.clm_rpt_stamp,
hal_data->acs.trig_rpt.nhm_rpt_stamp, rpt.nhm_rpt_stamp);
}
}
#else
phydm_ccx_monitor_result(phydm);
hal_data->acs.clm_ratio[chan_idx] = rtw_phydm_clm_ratio(adapter);
hal_data->acs.nhm_ratio[chan_idx] = rtw_phydm_nhm_ratio(adapter);
#endif
hal_data->acs.triggered = _FALSE;
#ifdef CONFIG_RTW_ACS_DBG
RTW_INFO("[ACS] Result CH:%d, CLM:%d NHM:%d\n",
cur_chan, hal_data->acs.clm_ratio[chan_idx], hal_data->acs.nhm_ratio[chan_idx]);
#endif
}
void _rtw_phydm_acs_select_best_chan(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
u8 ch_idx;
u8 ch_idx_24g = 0xFF, ch_idx_5g = 0xFF;
u8 min_itf_24g = 0xFF, min_itf_5g = 0xFF;
u8 *pbss_nums = hal_data->acs.bss_nums;
u8 *pclm_ratio = hal_data->acs.clm_ratio;
u8 *pnhm_ratio = hal_data->acs.nhm_ratio;
u8 *pinterference_time = hal_data->acs.interference_time;
u8 max_chan_nums = rfctl->max_chan_nums;
for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
if (pbss_nums[ch_idx])
pinterference_time[ch_idx] = (pclm_ratio[ch_idx] / 2) + pnhm_ratio[ch_idx];
else
pinterference_time[ch_idx] = pclm_ratio[ch_idx] + pnhm_ratio[ch_idx];
if (rtw_get_ch_num_by_idx(adapter, ch_idx) < 14) {
if (pinterference_time[ch_idx] < min_itf_24g) {
min_itf_24g = pinterference_time[ch_idx];
ch_idx_24g = ch_idx;
}
} else {
if (pinterference_time[ch_idx] < min_itf_5g) {
min_itf_5g = pinterference_time[ch_idx];
ch_idx_5g = ch_idx;
}
}
}
if (ch_idx_24g != 0xFF)
hal_data->acs.best_chan_24g = rtw_get_ch_num_by_idx(adapter, ch_idx_24g);
if (ch_idx_5g != 0xFF)
hal_data->acs.best_chan_5g = rtw_get_ch_num_by_idx(adapter, ch_idx_5g);
hal_data->acs.trigger_ch = 0;
}
void rtw_acs_info_dump(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
u8 max_chan_nums = rfctl->max_chan_nums;
u8 ch_idx, ch_num;
_RTW_PRINT_SEL(sel, "========== ACS (VER-%d) ==========\n", RTK_ACS_VERSION);
_RTW_PRINT_SEL(sel, "Best 24G Channel:%d\n", hal_data->acs.best_chan_24g);
_RTW_PRINT_SEL(sel, "Best 5G Channel:%d\n\n", hal_data->acs.best_chan_5g);
#ifdef CONFIG_RTW_ACS_DBG
_RTW_PRINT_SEL(sel, "Advanced setting - scan_type:%c, ch_ms:%d(ms), igi:0x%02x, bw:%d\n",
hal_data->acs.scan_type ? 'A' : 'P', hal_data->acs.scan_time, hal_data->acs.igi, hal_data->acs.bw);
_RTW_PRINT_SEL(sel, "BW 20MHz\n");
_RTW_PRINT_SEL(sel, "%5s %3s %3s %3s(%%) %3s(%%) %3s\n",
"Index", "CH", "BSS", "CLM", "NHM", "ITF");
for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
ch_num = rtw_get_ch_num_by_idx(adapter, ch_idx);
_RTW_PRINT_SEL(sel, "%5d %3d %3d %6d %6d %3d\n",
ch_idx, ch_num, hal_data->acs.bss_nums[ch_idx],
hal_data->acs.clm_ratio[ch_idx],
hal_data->acs.nhm_ratio[ch_idx],
hal_data->acs.interference_time[ch_idx]);
}
#endif
}
void rtw_acs_select_best_chan(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
_rtw_bss_nums_count(adapter, hal_data->acs.bss_nums);
_rtw_phydm_acs_select_best_chan(adapter);
rtw_acs_info_dump(RTW_DBGDUMP, adapter);
}
void rtw_acs_start(_adapter *adapter)
{
rtw_acs_reset(adapter);
if (GET_ACS_STATE(adapter) != ACS_ENABLE)
SET_ACS_STATE(adapter, ACS_ENABLE);
}
void rtw_acs_stop(_adapter *adapter)
{
SET_ACS_STATE(adapter, ACS_DISABLE);
}
u8 rtw_acs_get_clm_ratio_by_ch_num(_adapter *adapter, u8 chan)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
int chan_idx = -1;
chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
RTW_ERR("[ACS] Get CLM fail, can't get chan_idx(CH:%d)\n", chan);
return 0;
}
return hal_data->acs.clm_ratio[chan_idx];
}
u8 rtw_acs_get_clm_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
if (ch_idx >= MAX_CHANNEL_NUM) {
RTW_ERR("%s [ACS] ch_idx(%d) is invalid\n", __func__, ch_idx);
return 0;
}
return hal_data->acs.clm_ratio[ch_idx];
}
u8 rtw_acs_get_nhm_ratio_by_ch_num(_adapter *adapter, u8 chan)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
int chan_idx = -1;
chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
RTW_ERR("[ACS] Get NHM fail, can't get chan_idx(CH:%d)\n", chan);
return 0;
}
return hal_data->acs.nhm_ratio[chan_idx];
}
u8 rtw_acs_get_num_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
if (ch_idx >= MAX_CHANNEL_NUM) {
RTW_ERR("%s [ACS] ch_idx(%d) is invalid\n", __func__, ch_idx);
return 0;
}
return hal_data->acs.nhm_ratio[ch_idx];
}
void rtw_acs_chan_info_dump(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
u8 max_chan_nums = rfctl->max_chan_nums;
u8 ch_idx, ch_num;
u8 utilization;
_RTW_PRINT_SEL(sel, "BW 20MHz\n");
_RTW_PRINT_SEL(sel, "%5s %3s %7s(%%) %12s(%%) %11s(%%) %9s(%%) %8s(%%)\n",
"Index", "CH", "Quality", "Availability", "Utilization",
"WIFI Util", "Interference Util");
for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
ch_num = rtw_get_ch_num_by_idx(adapter, ch_idx);
utilization = hal_data->acs.clm_ratio[ch_idx] + hal_data->acs.nhm_ratio[ch_idx];
_RTW_PRINT_SEL(sel, "%5d %3d %7d %12d %12d %12d %12d\n",
ch_idx, ch_num,
(100-hal_data->acs.interference_time[ch_idx]),
(100-utilization),
utilization,
hal_data->acs.clm_ratio[ch_idx],
hal_data->acs.nhm_ratio[ch_idx]);
}
}
void rtw_acs_current_info_dump(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
u8 ch, cen_ch, bw, offset;
_RTW_PRINT_SEL(sel, "========== ACS (VER-%d) ==========\n", RTK_ACS_VERSION);
ch = rtw_get_oper_ch(adapter);
bw = rtw_get_oper_bw(adapter);
offset = rtw_get_oper_choffset(adapter);
_RTW_PRINT_SEL(sel, "Current Channel:%d\n", ch);
if ((bw == CHANNEL_WIDTH_80) ||(bw == CHANNEL_WIDTH_40)) {
cen_ch = rtw_get_center_ch(ch, bw, offset);
_RTW_PRINT_SEL(sel, "Center Channel:%d\n", cen_ch);
}
_RTW_PRINT_SEL(sel, "Current BW %s\n", ch_width_str(bw));
if (0)
_RTW_PRINT_SEL(sel, "Current IGI 0x%02x\n", rtw_phydm_get_cur_igi(adapter));
_RTW_PRINT_SEL(sel, "CLM:%d, NHM:%d\n\n",
hal_data->acs.cur_ch_clm_ratio, hal_data->acs.cur_ch_nhm_ratio);
}
void rtw_acs_update_current_info(_adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
hal_data->acs.cur_ch_clm_ratio = rtw_phydm_clm_ratio(adapter);
hal_data->acs.cur_ch_nhm_ratio = rtw_phydm_nhm_ratio(adapter);
#ifdef CONFIG_RTW_ACS_DBG
rtw_acs_current_info_dump(RTW_DBGDUMP, adapter);
#endif
}
#endif /*CONFIG_RTW_ACS*/
#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
void rtw_noise_monitor_version_dump(void *sel, _adapter *adapter)
{
_RTW_PRINT_SEL(sel, "RTK_NOISE_MONITOR VER_%d\n", RTK_NOISE_MONITOR_VERSION);
}
void rtw_nm_enable(_adapter *adapter)
{
SET_NM_STATE(adapter, NM_ENABLE);
}
void rtw_nm_disable(_adapter *adapter)
{
SET_NM_STATE(adapter, NM_DISABLE);
}
void rtw_noise_info_dump(void *sel, _adapter *adapter)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct rf_ctl_t *rfctl = adapter_to_rfctl(adapter);
u8 max_chan_nums = rfctl->max_chan_nums;
u8 ch_idx, ch_num;
_RTW_PRINT_SEL(sel, "========== NM (VER-%d) ==========\n", RTK_NOISE_MONITOR_VERSION);
_RTW_PRINT_SEL(sel, "%5s %3s %3s %10s", "Index", "CH", "BSS", "Noise(dBm)\n");
_rtw_bss_nums_count(adapter, hal_data->nm.bss_nums);
for (ch_idx = 0; ch_idx < max_chan_nums; ch_idx++) {
ch_num = rtw_get_ch_num_by_idx(adapter, ch_idx);
_RTW_PRINT_SEL(sel, "%5d %3d %3d %10d\n",
ch_idx, ch_num, hal_data->nm.bss_nums[ch_idx],
hal_data->nm.noise[ch_idx]);
}
}
void rtw_noise_measure(_adapter *adapter, u8 chan, u8 is_pause_dig, u8 igi_value, u32 max_time)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
struct dm_struct *phydm = &hal_data->odmpriv;
int chan_idx = -1;
s16 noise = 0;
#ifdef DBG_NOISE_MONITOR
RTW_INFO("[NM] chan(%d)-PauseDIG:%s, IGIValue:0x%02x, max_time:%d (ms)\n",
chan, (is_pause_dig) ? "Y" : "N", igi_value, max_time);
#endif
chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
RTW_ERR("[NM] Get noise fail, can't get chan_idx(CH:%d)\n", chan);
return;
}
noise = odm_inband_noise_monitor(phydm, is_pause_dig, igi_value, max_time); /*dBm*/
hal_data->nm.noise[chan_idx] = noise;
#ifdef DBG_NOISE_MONITOR
RTW_INFO("[NM] %s chan_%d, noise = %d (dBm)\n", __func__, chan, hal_data->nm.noise[chan_idx]);
RTW_INFO("[NM] noise_a = %d, noise_b = %d noise_all:%d\n",
phydm->noise_level.noise[RF_PATH_A],
phydm->noise_level.noise[RF_PATH_B],
phydm->noise_level.noise_all);
#endif /*DBG_NOISE_MONITOR*/
}
s16 rtw_noise_query_by_chan_num(_adapter *adapter, u8 chan)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
s16 noise = 0;
int chan_idx = -1;
chan_idx = rtw_chset_search_ch(adapter_to_chset(adapter), chan);
if ((chan_idx == -1) || (chan_idx >= MAX_CHANNEL_NUM)) {
RTW_ERR("[NM] Get noise fail, can't get chan_idx(CH:%d)\n", chan);
return noise;
}
noise = hal_data->nm.noise[chan_idx];
#ifdef DBG_NOISE_MONITOR
RTW_INFO("[NM] %s chan_%d, noise = %d (dBm)\n", __func__, chan, noise);
#endif/*DBG_NOISE_MONITOR*/
return noise;
}
s16 rtw_noise_query_by_chan_idx(_adapter *adapter, u8 ch_idx)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
s16 noise = 0;
if (ch_idx >= MAX_CHANNEL_NUM) {
RTW_ERR("[NM] %s ch_idx(%d) is invalid\n", __func__, ch_idx);
return noise;
}
noise = hal_data->nm.noise[ch_idx];
#ifdef DBG_NOISE_MONITOR
RTW_INFO("[NM] %s ch_idx %d, noise = %d (dBm)\n", __func__, ch_idx, noise);
#endif/*DBG_NOISE_MONITOR*/
return noise;
}
s16 rtw_noise_measure_curchan(_adapter *padapter)
{
s16 noise = 0;
u8 igi_value = 0x1E;
u32 max_time = 100;/* ms */
u8 is_pause_dig = _TRUE;
u8 cur_chan = rtw_get_oper_ch(padapter);
if (rtw_linked_check(padapter) == _FALSE)
return noise;
rtw_ps_deny(padapter, PS_DENY_IOCTL);
LeaveAllPowerSaveModeDirect(padapter);
rtw_noise_measure(padapter, cur_chan, is_pause_dig, igi_value, max_time);
noise = rtw_noise_query_by_chan_num(padapter, cur_chan);
rtw_ps_deny_cancel(padapter, PS_DENY_IOCTL);
return noise;
}
#endif /*CONFIG_BACKGROUND_NOISE_MONITOR*/
================================================
FILE: hal/hal_dm_acs.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HAL_DM_ACS_H__
#define __HAL_DM_ACS_H__
#ifdef CONFIG_RTW_ACS
#define RTK_ACS_VERSION 3
#if (RTK_ACS_VERSION == 3)
enum NHM_PID {
NHM_PID_ACS,
NHM_PID_IEEE_11K_HIGH,
NHM_PID_IEEE_11K_LOW,
};
#define init_clm_param(clm, app, lv, time) \
do {\
clm.clm_app = app;\
clm.clm_lv = lv;\
clm.mntr_time = time;\
} while (0)
#define init_nhm_param(nhm, txon, cca, cnt_opt, app, lv, time) \
do {\
nhm.incld_txon = txon;\
nhm.incld_cca = cca;\
nhm.div_opt = cnt_opt;\
nhm.nhm_app = app;\
nhm.nhm_lv = lv;\
nhm.mntr_time = time;\
} while (0)
#define init_acs_clm(clm, time) \
init_clm_param(clm, CLM_ACS, CLM_LV_2, time)
#define init_acs_nhm(nhm, time) \
init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, NHM_ACS, NHM_LV_2, time)
#define init_11K_high_nhm(nhm, time) \
init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, IEEE_11K_HIGH, NHM_LV_2, time)
#define init_11K_low_nhm(nhm, time) \
init_nhm_param(nhm, NHM_EXCLUDE_TXON, NHM_EXCLUDE_CCA, NHM_CNT_ALL, IEEE_11K_LOW, NHM_LV_2, time)
#endif /*(RTK_ACS_VERSION == 3)*/
void rtw_acs_version_dump(void *sel, _adapter *adapter);
extern void phydm_ccx_monitor_trigger(void *p_dm_void, u16 monitor_time);
extern void phydm_ccx_monitor_result(void *p_dm_void);
#define GET_ACS_STATE(padapter) (ATOMIC_READ(&GET_HAL_DATA(padapter)->acs.state))
#define SET_ACS_STATE(padapter, set_state) (ATOMIC_SET(&GET_HAL_DATA(padapter)->acs.state, set_state))
#define IS_ACS_ENABLE(padapter) ((GET_ACS_STATE(padapter) == ACS_ENABLE) ? _TRUE : _FALSE)
enum ACS_STATE {
ACS_DISABLE,
ACS_ENABLE,
};
#define ACS_BW_20M BIT(0)
#define ACS_BW_40M BIT(1)
#define ACS_BW_80M BIT(2)
#define ACS_BW_160M BIT(3)
struct auto_chan_sel {
ATOMIC_T state;
u8 trigger_ch;
bool triggered;
u8 clm_ratio[MAX_CHANNEL_NUM];
u8 nhm_ratio[MAX_CHANNEL_NUM];
#if (RTK_ACS_VERSION == 3)
u8 nhm[MAX_CHANNEL_NUM][NHM_RPT_NUM];
#endif
u8 bss_nums[MAX_CHANNEL_NUM];
u8 interference_time[MAX_CHANNEL_NUM];
u8 cur_ch_clm_ratio;
u8 cur_ch_nhm_ratio;
u8 best_chan_5g;
u8 best_chan_24g;
#if (RTK_ACS_VERSION == 3)
u8 trig_rst;
struct env_trig_rpt trig_rpt;
#endif
#ifdef CONFIG_RTW_ACS_DBG
RT_SCAN_TYPE scan_type;
u16 scan_time;
u8 igi;
u8 bw;
#endif
};
#define rtw_acs_get_best_chan_24g(adapter) (GET_HAL_DATA(adapter)->acs.best_chan_24g)
#define rtw_acs_get_best_chan_5g(adapter) (GET_HAL_DATA(adapter)->acs.best_chan_5g)
#ifdef CONFIG_RTW_ACS_DBG
#define rtw_is_acs_passiv_scan(adapter) (((GET_HAL_DATA(adapter)->acs.scan_type) == SCAN_PASSIVE) ? _TRUE : _FALSE)
#define rtw_acs_get_adv_st(adapter) (GET_HAL_DATA(adapter)->acs.scan_time)
#define rtw_is_acs_st_valid(adapter) ((GET_HAL_DATA(adapter)->acs.scan_time) ? _TRUE : _FALSE)
#define rtw_acs_get_adv_igi(adapter) (GET_HAL_DATA(adapter)->acs.igi)
u8 rtw_is_acs_igi_valid(_adapter *adapter);
#define rtw_acs_get_adv_bw(adapter) (GET_HAL_DATA(adapter)->acs.bw)
void rtw_acs_adv_setting(_adapter *adapter, RT_SCAN_TYPE scan_type, u16 scan_time, u8 igi, u8 bw);
void rtw_acs_adv_reset(_adapter *adapter);
#endif
u8 rtw_acs_get_clm_ratio_by_ch_num(_adapter *adapter, u8 chan);
u8 rtw_acs_get_clm_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx);
u8 rtw_acs_get_nhm_ratio_by_ch_num(_adapter *adapter, u8 chan);
u8 rtw_acs_get_num_ratio_by_ch_idx(_adapter *adapter, u8 ch_idx);
void rtw_acs_reset(_adapter *adapter);
void rtw_acs_trigger(_adapter *adapter, u16 scan_time_ms, u8 scan_chan, enum NHM_PID pid);
void rtw_acs_get_rst(_adapter *adapter);
void rtw_acs_select_best_chan(_adapter *adapter);
void rtw_acs_info_dump(void *sel, _adapter *adapter);
void rtw_acs_update_current_info(_adapter *adapter);
void rtw_acs_chan_info_dump(void *sel, _adapter *adapter);
void rtw_acs_current_info_dump(void *sel, _adapter *adapter);
void rtw_acs_start(_adapter *adapter);
void rtw_acs_stop(_adapter *adapter);
#endif /*CONFIG_RTW_ACS*/
#ifdef CONFIG_BACKGROUND_NOISE_MONITOR
#define RTK_NOISE_MONITOR_VERSION 3
#define GET_NM_STATE(padapter) (ATOMIC_READ(&GET_HAL_DATA(padapter)->nm.state))
#define SET_NM_STATE(padapter, set_state) (ATOMIC_SET(&GET_HAL_DATA(padapter)->nm.state, set_state))
#define IS_NM_ENABLE(padapter) ((GET_NM_STATE(padapter) == NM_ENABLE) ? _TRUE : _FALSE)
enum NM_STATE {
NM_DISABLE,
NM_ENABLE,
};
struct noise_monitor {
ATOMIC_T state;
s16 noise[MAX_CHANNEL_NUM];
u8 bss_nums[MAX_CHANNEL_NUM];
};
void rtw_nm_enable(_adapter *adapter);
void rtw_nm_disable(_adapter *adapter);
void rtw_noise_measure(_adapter *adapter, u8 chan, u8 is_pause_dig, u8 igi_value, u32 max_time);
s16 rtw_noise_query_by_chan_num(_adapter *adapter, u8 chan);
s16 rtw_noise_query_by_chan_idx(_adapter *adapter, u8 ch_idx);
s16 rtw_noise_measure_curchan(_adapter *padapter);
void rtw_noise_info_dump(void *sel, _adapter *adapter);
#endif
#endif /* __HAL_DM_ACS_H__ */
================================================
FILE: hal/hal_halmac.c
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_HALMAC_C_
#include /* PADAPTER, struct dvobj_priv, SDIO_ERR_VAL8 and etc. */
#include /* efuse, PHAL_DATA_TYPE and etc. */
#include "hal_halmac.h" /* dvobj_to_halmac() and ect. */
/*
* HALMAC take return value 0 for fail and 1 for success to replace
* _FALSE/_TRUE after V1_04_09
*/
#define RTW_HALMAC_FAIL 0
#define RTW_HALMAC_SUCCESS 1
#define DEFAULT_INDICATOR_TIMELMT 1000 /* ms */
#define MSG_PREFIX "[HALMAC]"
#define RTW_HALMAC_DLFW_MEM_NO_STOP_TX
/*
* Driver API for HALMAC operations
*/
#ifdef CONFIG_SDIO_HCI
#include
static u8 _halmac_mac_reg_page0_chk(const char *func, struct dvobj_priv *dvobj, u32 offset)
{
#if defined(CONFIG_IO_CHECK_IN_ANA_LOW_CLK) && defined(CONFIG_LPS_LCLK)
struct pwrctrl_priv *pwrpriv = &dvobj->pwrctl_priv;
u32 mac_reg_offset = 0;
if (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
return _TRUE;
if (pwrpriv->lps_level == LPS_NORMAL)
return _TRUE;
if (pwrpriv->rpwm >= PS_STATE_S2)
return _TRUE;
if (offset & (WLAN_IOREG_DEVICE_ID << 13)) { /*WLAN_IOREG_OFFSET*/
mac_reg_offset = offset & HALMAC_WLAN_MAC_REG_MSK;
if (mac_reg_offset < 0x100) {
RTW_ERR(FUNC_ADPT_FMT
"access MAC REG -0x%04x in PS-mode:0x%02x (rpwm:0x%02x, lps_level:0x%02x)\n",
FUNC_ADPT_ARG(dvobj_get_primary_adapter(dvobj)), mac_reg_offset,
pwrpriv->pwr_mode, pwrpriv->rpwm, pwrpriv->lps_level);
rtw_warn_on(1);
return _FALSE;
}
}
#endif
return _TRUE;
}
static u8 _halmac_sdio_cmd52_read(void *p, u32 offset)
{
struct dvobj_priv *d;
u8 val;
u8 ret;
d = (struct dvobj_priv *)p;
_halmac_mac_reg_page0_chk(__func__, d, offset);
ret = rtw_sdio_read_cmd52(d, offset, &val, 1);
if (_FAIL == ret) {
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
return SDIO_ERR_VAL8;
}
return val;
}
static void _halmac_sdio_cmd52_write(void *p, u32 offset, u8 val)
{
struct dvobj_priv *d;
u8 ret;
d = (struct dvobj_priv *)p;
_halmac_mac_reg_page0_chk(__func__, d, offset);
ret = rtw_sdio_write_cmd52(d, offset, &val, 1);
if (_FAIL == ret)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
}
static u8 _halmac_sdio_reg_read_8(void *p, u32 offset)
{
struct dvobj_priv *d;
u8 *pbuf;
u8 val;
u8 ret;
d = (struct dvobj_priv *)p;
val = SDIO_ERR_VAL8;
_halmac_mac_reg_page0_chk(__func__, d, offset);
pbuf = rtw_zmalloc(1);
if (!pbuf)
return val;
ret = rtw_sdio_read_cmd53(d, offset, pbuf, 1);
if (ret == _FAIL) {
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
goto exit;
}
val = *pbuf;
exit:
rtw_mfree(pbuf, 1);
return val;
}
static u16 _halmac_sdio_reg_read_16(void *p, u32 offset)
{
struct dvobj_priv *d;
u8 *pbuf;
u16 val;
u8 ret;
d = (struct dvobj_priv *)p;
val = SDIO_ERR_VAL16;
_halmac_mac_reg_page0_chk(__func__, d, offset);
pbuf = rtw_zmalloc(2);
if (!pbuf)
return val;
ret = rtw_sdio_read_cmd53(d, offset, pbuf, 2);
if (ret == _FAIL) {
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
goto exit;
}
val = le16_to_cpu(*(u16 *)pbuf);
exit:
rtw_mfree(pbuf, 2);
return val;
}
static u32 _halmac_sdio_reg_read_32(void *p, u32 offset)
{
struct dvobj_priv *d;
u8 *pbuf;
u32 val;
u8 ret;
d = (struct dvobj_priv *)p;
val = SDIO_ERR_VAL32;
_halmac_mac_reg_page0_chk(__func__, d, offset);
pbuf = rtw_zmalloc(4);
if (!pbuf)
return val;
ret = rtw_sdio_read_cmd53(d, offset, pbuf, 4);
if (ret == _FAIL) {
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
goto exit;
}
val = le32_to_cpu(*(u32 *)pbuf);
exit:
rtw_mfree(pbuf, 4);
return val;
}
static u8 _halmac_sdio_reg_read_n(void *p, u32 offset, u32 size, u8 *data)
{
struct dvobj_priv *d = (struct dvobj_priv *)p;
u8 *pbuf;
u8 ret;
u8 rst = RTW_HALMAC_FAIL;
u32 sdio_read_size;
if (!data)
return rst;
sdio_read_size = RND4(size);
sdio_read_size = rtw_sdio_cmd53_align_size(d, sdio_read_size);
pbuf = rtw_zmalloc(sdio_read_size);
if (!pbuf)
return rst;
ret = rtw_sdio_read_cmd53(d, offset, pbuf, sdio_read_size);
if (ret == _FAIL) {
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
goto exit;
}
_rtw_memcpy(data, pbuf, size);
rst = RTW_HALMAC_SUCCESS;
exit:
rtw_mfree(pbuf, sdio_read_size);
return rst;
}
static void _halmac_sdio_reg_write_8(void *p, u32 offset, u8 val)
{
struct dvobj_priv *d;
u8 *pbuf;
u8 ret;
d = (struct dvobj_priv *)p;
_halmac_mac_reg_page0_chk(__func__, d, offset);
pbuf = rtw_zmalloc(1);
if (!pbuf)
return;
_rtw_memcpy(pbuf, &val, 1);
ret = rtw_sdio_write_cmd53(d, offset, pbuf, 1);
if (ret == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
rtw_mfree(pbuf, 1);
}
static void _halmac_sdio_reg_write_16(void *p, u32 offset, u16 val)
{
struct dvobj_priv *d;
u8 *pbuf;
u8 ret;
d = (struct dvobj_priv *)p;
_halmac_mac_reg_page0_chk(__func__, d, offset);
val = cpu_to_le16(val);
pbuf = rtw_zmalloc(2);
if (!pbuf)
return;
_rtw_memcpy(pbuf, &val, 2);
ret = rtw_sdio_write_cmd53(d, offset, pbuf, 2);
if (ret == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
rtw_mfree(pbuf, 2);
}
static void _halmac_sdio_reg_write_32(void *p, u32 offset, u32 val)
{
struct dvobj_priv *d;
u8 *pbuf;
u8 ret;
d = (struct dvobj_priv *)p;
_halmac_mac_reg_page0_chk(__func__, d, offset);
val = cpu_to_le32(val);
pbuf = rtw_zmalloc(4);
if (!pbuf)
return;
_rtw_memcpy(pbuf, &val, 4);
ret = rtw_sdio_write_cmd53(d, offset, pbuf, 4);
if (ret == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
rtw_mfree(pbuf, 4);
}
static u8 _halmac_sdio_read_cia(void *p, u32 offset)
{
struct dvobj_priv *d;
u8 data = 0;
u8 ret;
d = (struct dvobj_priv *)p;
ret = rtw_sdio_f0_read(d, offset, &data, 1);
if (ret == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
return data;
}
#else /* !CONFIG_SDIO_HCI */
static u8 _halmac_reg_read_8(void *p, u32 offset)
{
struct dvobj_priv *d;
PADAPTER adapter;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
return rtw_read8(adapter, offset);
}
static u16 _halmac_reg_read_16(void *p, u32 offset)
{
struct dvobj_priv *d;
PADAPTER adapter;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
return rtw_read16(adapter, offset);
}
static u32 _halmac_reg_read_32(void *p, u32 offset)
{
struct dvobj_priv *d;
PADAPTER adapter;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
return rtw_read32(adapter, offset);
}
static void _halmac_reg_write_8(void *p, u32 offset, u8 val)
{
struct dvobj_priv *d;
PADAPTER adapter;
int err;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
err = rtw_write8(adapter, offset, val);
if (err == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
}
static void _halmac_reg_write_16(void *p, u32 offset, u16 val)
{
struct dvobj_priv *d;
PADAPTER adapter;
int err;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
err = rtw_write16(adapter, offset, val);
if (err == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
}
static void _halmac_reg_write_32(void *p, u32 offset, u32 val)
{
struct dvobj_priv *d;
PADAPTER adapter;
int err;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
err = rtw_write32(adapter, offset, val);
if (err == _FAIL)
RTW_ERR("%s: I/O FAIL!\n", __FUNCTION__);
}
#endif /* !CONFIG_SDIO_HCI */
static u8 _halmac_mfree(void *p, void *buffer, u32 size)
{
rtw_mfree(buffer, size);
return RTW_HALMAC_SUCCESS;
}
static void *_halmac_malloc(void *p, u32 size)
{
return rtw_zmalloc(size);
}
static u8 _halmac_memcpy(void *p, void *dest, void *src, u32 size)
{
_rtw_memcpy(dest, src, size);
return RTW_HALMAC_SUCCESS;
}
static u8 _halmac_memset(void *p, void *addr, u8 value, u32 size)
{
_rtw_memset(addr, value, size);
return RTW_HALMAC_SUCCESS;
}
static void _halmac_udelay(void *p, u32 us)
{
/* Most hardware polling wait time < 50us) */
if (us <= 50)
rtw_udelay_os(us);
else if (us <= 1000)
rtw_usleep_os(us);
else
rtw_msleep_os(RTW_DIV_ROUND_UP(us, 1000));
}
static u8 _halmac_mutex_init(void *p, HALMAC_MUTEX *pMutex)
{
_rtw_mutex_init(pMutex);
return RTW_HALMAC_SUCCESS;
}
static u8 _halmac_mutex_deinit(void *p, HALMAC_MUTEX *pMutex)
{
_rtw_mutex_free(pMutex);
return RTW_HALMAC_SUCCESS;
}
static u8 _halmac_mutex_lock(void *p, HALMAC_MUTEX *pMutex)
{
int err;
err = _enter_critical_mutex(pMutex, NULL);
if (err)
return RTW_HALMAC_FAIL;
return RTW_HALMAC_SUCCESS;
}
static u8 _halmac_mutex_unlock(void *p, HALMAC_MUTEX *pMutex)
{
_exit_critical_mutex(pMutex, NULL);
return RTW_HALMAC_SUCCESS;
}
#ifndef CONFIG_SDIO_HCI
#define DBG_MSG_FILTER
#endif
#ifdef DBG_MSG_FILTER
static u8 is_msg_allowed(uint drv_lv, u8 msg_lv)
{
switch (drv_lv) {
case _DRV_NONE_:
return _FALSE;
case _DRV_ALWAYS_:
if (msg_lv > HALMAC_DBG_ALWAYS)
return _FALSE;
break;
case _DRV_ERR_:
if (msg_lv > HALMAC_DBG_ERR)
return _FALSE;
break;
case _DRV_WARNING_:
if (msg_lv > HALMAC_DBG_WARN)
return _FALSE;
break;
case _DRV_INFO_:
if (msg_lv >= HALMAC_DBG_TRACE)
return _FALSE;
break;
}
return _TRUE;
}
#endif /* DBG_MSG_FILTER */
static u8 _halmac_msg_print(void *p, u32 msg_type, u8 msg_level, s8 *fmt, ...)
{
#define MSG_LEN 100
va_list args;
u8 str[MSG_LEN] = {0};
#ifdef DBG_MSG_FILTER
uint drv_level = _DRV_NONE_;
#endif
int err;
u8 ret = RTW_HALMAC_SUCCESS;
#ifdef DBG_MSG_FILTER
#ifdef CONFIG_RTW_DEBUG
drv_level = rtw_drv_log_level;
#endif
if (is_msg_allowed(drv_level, msg_level) == _FALSE)
return ret;
#endif
str[0] = '\n';
va_start(args, fmt);
err = vsnprintf(str, MSG_LEN, fmt, args);
va_end(args);
/* An output error is encountered */
if (err < 0)
return RTW_HALMAC_FAIL;
/* Output may be truncated due to size limit */
if ((err == (MSG_LEN - 1)) && (str[MSG_LEN - 2] != '\n'))
ret = RTW_HALMAC_FAIL;
if (msg_level == HALMAC_DBG_ALWAYS)
RTW_PRINT(MSG_PREFIX "%s", str);
else if (msg_level <= HALMAC_DBG_ERR)
RTW_ERR(MSG_PREFIX "%s", str);
else if (msg_level <= HALMAC_DBG_WARN)
RTW_WARN(MSG_PREFIX "%s", str);
else
RTW_DBG(MSG_PREFIX "%s", str);
return ret;
}
static u8 _halmac_buff_print(void *p, u32 msg_type, u8 msg_level, s8 *buf, u32 size)
{
if (msg_level <= HALMAC_DBG_WARN)
RTW_INFO_DUMP(MSG_PREFIX, buf, size);
else
RTW_DBG_DUMP(MSG_PREFIX, buf, size);
return RTW_HALMAC_SUCCESS;
}
const char *const RTW_HALMAC_FEATURE_NAME[] = {
"HALMAC_FEATURE_CFG_PARA",
"HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE",
"HALMAC_FEATURE_DUMP_LOGICAL_EFUSE",
"HALMAC_FEATURE_UPDATE_PACKET",
"HALMAC_FEATURE_UPDATE_DATAPACK",
"HALMAC_FEATURE_RUN_DATAPACK",
"HALMAC_FEATURE_CHANNEL_SWITCH",
"HALMAC_FEATURE_IQK",
"HALMAC_FEATURE_POWER_TRACKING",
"HALMAC_FEATURE_PSD",
"HALMAC_FEATURE_FW_SNDING",
"HALMAC_FEATURE_ALL"
};
static inline u8 is_valid_id_status(enum halmac_feature_id id, enum halmac_cmd_process_status status)
{
switch (id) {
case HALMAC_FEATURE_CFG_PARA:
RTW_DBG("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
if (HALMAC_CMD_PROCESS_DONE != status)
RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
__FUNCTION__, id, status);
break;
case HALMAC_FEATURE_DUMP_LOGICAL_EFUSE:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
if (HALMAC_CMD_PROCESS_DONE != status)
RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
__FUNCTION__, id, status);
break;
case HALMAC_FEATURE_UPDATE_PACKET:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
if (status != HALMAC_CMD_PROCESS_DONE)
RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
__FUNCTION__, id, status);
break;
case HALMAC_FEATURE_UPDATE_DATAPACK:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_RUN_DATAPACK:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_CHANNEL_SWITCH:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
if ((status != HALMAC_CMD_PROCESS_DONE) && (status != HALMAC_CMD_PROCESS_RCVD))
RTW_INFO("%s: id(%d) unspecified status(%d)!\n",
__FUNCTION__, id, status);
if (status == HALMAC_CMD_PROCESS_DONE)
return _FALSE;
break;
case HALMAC_FEATURE_IQK:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_POWER_TRACKING:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_PSD:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_FW_SNDING:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
case HALMAC_FEATURE_ALL:
RTW_INFO("%s: %s\n", __FUNCTION__, RTW_HALMAC_FEATURE_NAME[id]);
break;
default:
RTW_ERR("%s: unknown feature id(%d)\n", __FUNCTION__, id);
return _FALSE;
}
return _TRUE;
}
static int init_halmac_event_with_waittime(struct dvobj_priv *d, enum halmac_feature_id id, u8 *buf, u32 size, u32 time)
{
struct submit_ctx *sctx;
if (!d->hmpriv.indicator[id].sctx) {
sctx = (struct submit_ctx *)rtw_zmalloc(sizeof(*sctx));
if (!sctx)
return -1;
} else {
RTW_WARN("%s: id(%d) sctx is not NULL!!\n", __FUNCTION__, id);
sctx = d->hmpriv.indicator[id].sctx;
d->hmpriv.indicator[id].sctx = NULL;
}
rtw_sctx_init(sctx, time);
d->hmpriv.indicator[id].buffer = buf;
d->hmpriv.indicator[id].buf_size = size;
d->hmpriv.indicator[id].ret_size = 0;
d->hmpriv.indicator[id].status = 0;
/* fill sctx at least to sure other variables are all ready! */
d->hmpriv.indicator[id].sctx = sctx;
return 0;
}
static inline int init_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id, u8 *buf, u32 size)
{
return init_halmac_event_with_waittime(d, id, buf, size, DEFAULT_INDICATOR_TIMELMT);
}
static void free_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id)
{
struct submit_ctx *sctx;
if (!d->hmpriv.indicator[id].sctx)
return;
sctx = d->hmpriv.indicator[id].sctx;
d->hmpriv.indicator[id].sctx = NULL;
rtw_mfree((u8 *)sctx, sizeof(*sctx));
}
static int wait_halmac_event(struct dvobj_priv *d, enum halmac_feature_id id)
{
struct halmac_adapter *mac;
struct halmac_api *api;
struct submit_ctx *sctx;
int ret;
sctx = d->hmpriv.indicator[id].sctx;
if (!sctx)
return -1;
ret = rtw_sctx_wait(sctx, RTW_HALMAC_FEATURE_NAME[id]);
free_halmac_event(d, id);
if (_SUCCESS == ret)
return 0;
/* timeout! We have to reset halmac state */
RTW_ERR("%s: Wait id(%d, %s) TIMEOUT! Reset HALMAC state!\n",
__FUNCTION__, id, RTW_HALMAC_FEATURE_NAME[id]);
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
api->halmac_reset_feature(mac, id);
return -1;
}
/*
* Return:
* Always return RTW_HALMAC_SUCCESS, HALMAC don't care the return value.
*/
static u8 _halmac_event_indication(void *p, enum halmac_feature_id feature_id, enum halmac_cmd_process_status process_status, u8 *buf, u32 size)
{
struct dvobj_priv *d;
PADAPTER adapter;
PHAL_DATA_TYPE hal;
struct halmac_indicator *tbl, *indicator;
struct submit_ctx *sctx;
u32 cpsz;
u8 ret;
d = (struct dvobj_priv *)p;
adapter = dvobj_get_primary_adapter(d);
hal = GET_HAL_DATA(adapter);
tbl = d->hmpriv.indicator;
/* Filter(Skip) middle status indication */
ret = is_valid_id_status(feature_id, process_status);
if (_FALSE == ret)
goto exit;
indicator = &tbl[feature_id];
indicator->status = process_status;
indicator->ret_size = size;
if (!indicator->sctx) {
RTW_WARN("%s: No feature id(%d, %s) waiting!!\n", __FUNCTION__, feature_id, RTW_HALMAC_FEATURE_NAME[feature_id]);
goto exit;
}
sctx = indicator->sctx;
if (HALMAC_CMD_PROCESS_ERROR == process_status) {
RTW_ERR("%s: Something wrong id(%d, %s)!!\n", __FUNCTION__, feature_id, RTW_HALMAC_FEATURE_NAME[feature_id]);
rtw_sctx_done_err(&sctx, RTW_SCTX_DONE_UNKNOWN);
goto exit;
}
if (size > indicator->buf_size) {
RTW_WARN("%s: id(%d, %s) buffer is not enough(%d<%d), data will be truncated!\n",
__FUNCTION__, feature_id, RTW_HALMAC_FEATURE_NAME[feature_id], indicator->buf_size, size);
cpsz = indicator->buf_size;
} else {
cpsz = size;
}
if (cpsz && indicator->buffer)
_rtw_memcpy(indicator->buffer, buf, cpsz);
rtw_sctx_done(&sctx);
exit:
return RTW_HALMAC_SUCCESS;
}
struct halmac_platform_api rtw_halmac_platform_api = {
/* R/W register */
#ifdef CONFIG_SDIO_HCI
.SDIO_CMD52_READ = _halmac_sdio_cmd52_read,
.SDIO_CMD53_READ_8 = _halmac_sdio_reg_read_8,
.SDIO_CMD53_READ_16 = _halmac_sdio_reg_read_16,
.SDIO_CMD53_READ_32 = _halmac_sdio_reg_read_32,
.SDIO_CMD53_READ_N = _halmac_sdio_reg_read_n,
.SDIO_CMD52_WRITE = _halmac_sdio_cmd52_write,
.SDIO_CMD53_WRITE_8 = _halmac_sdio_reg_write_8,
.SDIO_CMD53_WRITE_16 = _halmac_sdio_reg_write_16,
.SDIO_CMD53_WRITE_32 = _halmac_sdio_reg_write_32,
.SDIO_CMD52_CIA_READ = _halmac_sdio_read_cia,
#endif /* CONFIG_SDIO_HCI */
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
.REG_READ_8 = _halmac_reg_read_8,
.REG_READ_16 = _halmac_reg_read_16,
.REG_READ_32 = _halmac_reg_read_32,
.REG_WRITE_8 = _halmac_reg_write_8,
.REG_WRITE_16 = _halmac_reg_write_16,
.REG_WRITE_32 = _halmac_reg_write_32,
#endif /* CONFIG_USB_HCI || CONFIG_PCI_HCI */
/* Write data */
#if 0
/* impletement in HAL-IC level */
.SEND_RSVD_PAGE = sdio_write_data_rsvd_page,
.SEND_H2C_PKT = sdio_write_data_h2c,
#endif
/* Memory allocate */
.RTL_FREE = _halmac_mfree,
.RTL_MALLOC = _halmac_malloc,
.RTL_MEMCPY = _halmac_memcpy,
.RTL_MEMSET = _halmac_memset,
/* Sleep */
.RTL_DELAY_US = _halmac_udelay,
/* Process Synchronization */
.MUTEX_INIT = _halmac_mutex_init,
.MUTEX_DEINIT = _halmac_mutex_deinit,
.MUTEX_LOCK = _halmac_mutex_lock,
.MUTEX_UNLOCK = _halmac_mutex_unlock,
.MSG_PRINT = _halmac_msg_print,
.BUFF_PRINT = _halmac_buff_print,
.EVENT_INDICATION = _halmac_event_indication,
};
u8 rtw_halmac_read8(struct intf_hdl *pintfhdl, u32 addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
return api->halmac_reg_read_8(mac, addr);
}
u16 rtw_halmac_read16(struct intf_hdl *pintfhdl, u32 addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
return api->halmac_reg_read_16(mac, addr);
}
u32 rtw_halmac_read32(struct intf_hdl *pintfhdl, u32 addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
return api->halmac_reg_read_32(mac, addr);
}
static void _read_register(struct dvobj_priv *d, u32 addr, u32 cnt, u8 *buf)
{
#if 1
struct _ADAPTER *a;
u32 i, n;
u16 val16;
u32 val32;
a = dvobj_get_primary_adapter(d);
i = addr & 0x3;
/* Handle address not start from 4 bytes alignment case */
if (i) {
val32 = cpu_to_le32(rtw_read32(a, addr & ~0x3));
n = 4 - i;
_rtw_memcpy(buf, ((u8 *)&val32) + i, n);
i = n;
cnt -= n;
}
while (cnt) {
if (cnt >= 4)
n = 4;
else if (cnt >= 2)
n = 2;
else
n = 1;
cnt -= n;
switch (n) {
case 1:
buf[i] = rtw_read8(a, addr+i);
i++;
break;
case 2:
val16 = cpu_to_le16(rtw_read16(a, addr+i));
_rtw_memcpy(&buf[i], &val16, 2);
i += 2;
break;
case 4:
val32 = cpu_to_le32(rtw_read32(a, addr+i));
_rtw_memcpy(&buf[i], &val32, 4);
i += 4;
break;
}
}
#else
struct _ADAPTER *a;
u32 i;
a = dvobj_get_primary_adapter(d);
for (i = 0; i < cnt; i++)
buf[i] = rtw_read8(a, addr + i);
#endif
}
#ifdef CONFIG_SDIO_HCI
static int _sdio_read_local(struct dvobj_priv *d, u32 addr, u32 cnt, u8 *buf)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
if (buf == NULL)
return -1;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_reg_sdio_cmd53_read_n(mac, addr, cnt, buf);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: addr=0x%08x cnt=%d err=%d\n",
__FUNCTION__, addr, cnt, status);
return -1;
}
return 0;
}
#endif /* CONFIG_SDIO_HCI */
void rtw_halmac_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem)
{
struct dvobj_priv *d;
if (pmem == NULL) {
RTW_ERR("pmem is NULL\n");
return;
}
d = pintfhdl->pintf_dev;
#ifdef CONFIG_SDIO_HCI
if (addr & 0xFFFF0000) {
int err = 0;
err = _sdio_read_local(d, addr, cnt, pmem);
if (!err)
return;
}
#endif /* CONFIG_SDIO_HCI */
_read_register(d, addr, cnt, pmem);
}
#ifdef CONFIG_SDIO_INDIRECT_ACCESS
u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
/*return api->halmac_reg_read_indirect_8(mac, addr);*/
return api->halmac_reg_read_8(mac, addr);
}
u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
u16 val16 = 0;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
/*return api->halmac_reg_read_indirect_16(mac, addr);*/
return api->halmac_reg_read_16(mac, addr);
}
u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
return api->halmac_reg_read_indirect_32(mac, addr);
}
#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
int rtw_halmac_write8(struct intf_hdl *pintfhdl, u32 addr, u8 value)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
status = api->halmac_reg_write_8(mac, addr, value);
if (status == HALMAC_RET_SUCCESS)
return 0;
return -1;
}
int rtw_halmac_write16(struct intf_hdl *pintfhdl, u32 addr, u16 value)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
status = api->halmac_reg_write_16(mac, addr, value);
if (status == HALMAC_RET_SUCCESS)
return 0;
return -1;
}
int rtw_halmac_write32(struct intf_hdl *pintfhdl, u32 addr, u32 value)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
/* WARNING: pintf_dev should not be null! */
mac = dvobj_to_halmac(pintfhdl->pintf_dev);
api = HALMAC_GET_API(mac);
status = api->halmac_reg_write_32(mac, addr, value);
if (status == HALMAC_RET_SUCCESS)
return 0;
return -1;
}
static int init_write_rsvd_page_size(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
u32 size = 0;
struct halmac_ofld_func_info ofld_info;
enum halmac_ret_status status;
int err = 0;
#ifdef CONFIG_USB_HCI
/* for USB do not exceed MAX_CMDBUF_SZ */
size = 0x1000;
#elif defined(CONFIG_PCI_HCI)
size = MAX_CMDBUF_SZ - TXDESC_OFFSET;
#elif defined(CONFIG_SDIO_HCI)
size = 0x7000; /* 28KB */
#endif
/* If size==0, use HALMAC default setting and don't call any function */
if (!size)
return 0;
err = rtw_halmac_set_max_dl_fw_size(d, size);
if (err) {
RTW_ERR("%s: Fail to set max download fw size!\n", __FUNCTION__);
return -1;
}
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
_rtw_memset(&ofld_info, 0, sizeof(ofld_info));
ofld_info.halmac_malloc_max_sz = 0xFFFFFFFF;
ofld_info.rsvd_pg_drv_buf_max_sz = size;
status = api->halmac_ofld_func_cfg(mac, &ofld_info);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: Fail to config offload parameters!\n", __FUNCTION__);
return -1;
}
return 0;
}
static int init_priv(struct halmacpriv *priv)
{
struct halmac_indicator *indicator;
u32 count, size;
if (priv->indicator)
RTW_WARN("%s: HALMAC private data is not CLEAR!\n", __FUNCTION__);
count = HALMAC_FEATURE_ALL + 1;
size = sizeof(*indicator) * count;
indicator = (struct halmac_indicator *)rtw_zmalloc(size);
if (!indicator)
return -1;
priv->indicator = indicator;
return 0;
}
static void deinit_priv(struct halmacpriv *priv)
{
struct halmac_indicator *indicator;
indicator = priv->indicator;
priv->indicator = NULL;
if (indicator) {
u32 count, size;
count = HALMAC_FEATURE_ALL + 1;
#ifdef CONFIG_RTW_DEBUG
{
struct submit_ctx *sctx;
u32 i;
for (i = 0; i < count; i++) {
if (!indicator[i].sctx)
continue;
RTW_WARN("%s: %s id(%d) sctx still exist!!\n",
__FUNCTION__, RTW_HALMAC_FEATURE_NAME[i], i);
sctx = indicator[i].sctx;
indicator[i].sctx = NULL;
rtw_mfree((u8 *)sctx, sizeof(*sctx));
}
}
#endif /* !CONFIG_RTW_DEBUG */
size = sizeof(*indicator) * count;
rtw_mfree((u8 *)indicator, size);
}
}
#ifdef CONFIG_SDIO_HCI
static enum halmac_sdio_spec_ver _sdio_ver_drv2halmac(struct dvobj_priv *d)
{
bool v3;
enum halmac_sdio_spec_ver ver;
v3 = rtw_is_sdio30(dvobj_get_primary_adapter(d));
if (v3)
ver = HALMAC_SDIO_SPEC_VER_3_00;
else
ver = HALMAC_SDIO_SPEC_VER_2_00;
return ver;
}
#endif /* CONFIG_SDIO_HCI */
void rtw_halmac_get_version(char *str, u32 len)
{
enum halmac_ret_status status;
struct halmac_ver ver;
status = halmac_get_version(&ver);
if (status != HALMAC_RET_SUCCESS)
return;
rtw_sprintf(str, len, "V%d_%02d_%02d",
ver.major_ver, ver.prototype_ver, ver.minor_ver);
}
int rtw_halmac_init_adapter(struct dvobj_priv *d, struct halmac_platform_api *pf_api)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_interface intf;
enum halmac_ret_status status;
int err = 0;
#ifdef CONFIG_SDIO_HCI
struct halmac_sdio_hw_info info;
#endif /* CONFIG_SDIO_HCI */
halmac = dvobj_to_halmac(d);
if (halmac) {
RTW_WARN("%s: initialize already completed!\n", __FUNCTION__);
goto error;
}
err = init_priv(&d->hmpriv);
if (err)
goto error;
#ifdef CONFIG_SDIO_HCI
intf = HALMAC_INTERFACE_SDIO;
#elif defined(CONFIG_USB_HCI)
intf = HALMAC_INTERFACE_USB;
#elif defined(CONFIG_PCI_HCI)
intf = HALMAC_INTERFACE_PCIE;
#else
#warning "INTERFACE(CONFIG_XXX_HCI) not be defined!!"
intf = HALMAC_INTERFACE_UNDEFINE;
#endif
status = halmac_init_adapter(d, pf_api, intf, &halmac, &api);
if (HALMAC_RET_SUCCESS != status) {
RTW_ERR("%s: halmac_init_adapter fail!(status=%d)\n", __FUNCTION__, status);
err = -1;
if (halmac)
goto deinit;
goto free;
}
dvobj_set_halmac(d, halmac);
status = api->halmac_interface_integration_tuning(halmac);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: halmac_interface_integration_tuning fail!(status=%d)\n", __FUNCTION__, status);
err = -1;
goto deinit;
}
status = api->halmac_phy_cfg(halmac, HALMAC_INTF_PHY_PLATFORM_ALL);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: halmac_phy_cfg fail!(status=%d)\n", __FUNCTION__, status);
err = -1;
goto deinit;
}
init_write_rsvd_page_size(d);
#ifdef CONFIG_SDIO_HCI
_rtw_memset(&info, 0, sizeof(info));
info.spec_ver = _sdio_ver_drv2halmac(d);
/* Convert clock speed unit to MHz from Hz */
info.clock_speed = RTW_DIV_ROUND_UP(rtw_sdio_get_clock(d), 1000000);
info.block_size = rtw_sdio_get_block_size(d);
RTW_DBG("%s: SDIO ver=%u clock=%uMHz blk_size=%u bytes\n",
__FUNCTION__, info.spec_ver+2, info.clock_speed,
info.block_size);
status = api->halmac_sdio_hw_info(halmac, &info);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: halmac_sdio_hw_info fail!(status=%d)\n",
__FUNCTION__, status);
err = -1;
goto deinit;
}
#endif /* CONFIG_SDIO_HCI */
return 0;
deinit:
status = halmac_deinit_adapter(halmac);
dvobj_set_halmac(d, NULL);
if (status != HALMAC_RET_SUCCESS)
RTW_ERR("%s: halmac_deinit_adapter fail!(status=%d)\n",
__FUNCTION__, status);
free:
deinit_priv(&d->hmpriv);
error:
return err;
}
int rtw_halmac_deinit_adapter(struct dvobj_priv *d)
{
struct halmac_adapter *halmac;
enum halmac_ret_status status;
int err = 0;
halmac = dvobj_to_halmac(d);
if (halmac) {
status = halmac_deinit_adapter(halmac);
dvobj_set_halmac(d, NULL);
if (status != HALMAC_RET_SUCCESS)
err = -1;
}
deinit_priv(&d->hmpriv);
return err;
}
static inline enum halmac_portid _hw_port_drv2halmac(enum _hw_port hwport)
{
enum halmac_portid port = HALMAC_PORTID_NUM;
switch (hwport) {
case HW_PORT0:
port = HALMAC_PORTID0;
break;
case HW_PORT1:
port = HALMAC_PORTID1;
break;
case HW_PORT2:
port = HALMAC_PORTID2;
break;
case HW_PORT3:
port = HALMAC_PORTID3;
break;
case HW_PORT4:
port = HALMAC_PORTID4;
break;
default:
break;
}
return port;
}
static enum halmac_network_type_select _network_type_drv2halmac(u8 type)
{
enum halmac_network_type_select network = HALMAC_NETWORK_UNDEFINE;
switch (type) {
case _HW_STATE_NOLINK_:
case _HW_STATE_MONITOR_:
network = HALMAC_NETWORK_NO_LINK;
break;
case _HW_STATE_ADHOC_:
network = HALMAC_NETWORK_ADHOC;
break;
case _HW_STATE_STATION_:
network = HALMAC_NETWORK_INFRASTRUCTURE;
break;
case _HW_STATE_AP_:
network = HALMAC_NETWORK_AP;
break;
}
return network;
}
static u8 _network_type_halmac2drv(enum halmac_network_type_select network)
{
u8 type = _HW_STATE_NOLINK_;
switch (network) {
case HALMAC_NETWORK_NO_LINK:
case HALMAC_NETWORK_UNDEFINE:
type = _HW_STATE_NOLINK_;
break;
case HALMAC_NETWORK_ADHOC:
type = _HW_STATE_ADHOC_;
break;
case HALMAC_NETWORK_INFRASTRUCTURE:
type = _HW_STATE_STATION_;
break;
case HALMAC_NETWORK_AP:
type = _HW_STATE_AP_;
break;
}
return type;
}
static void _beacon_ctrl_halmac2drv(struct halmac_bcn_ctrl *ctrl,
struct rtw_halmac_bcn_ctrl *drv_ctrl)
{
drv_ctrl->rx_bssid_fit = ctrl->dis_rx_bssid_fit ? 0 : 1;
drv_ctrl->txbcn_rpt = ctrl->en_txbcn_rpt ? 1 : 0;
drv_ctrl->tsf_update = ctrl->dis_tsf_udt ? 0 : 1;
drv_ctrl->enable_bcn = ctrl->en_bcn ? 1 : 0;
drv_ctrl->rxbcn_rpt = ctrl->en_rxbcn_rpt ? 1 : 0;
drv_ctrl->p2p_ctwin = ctrl->en_p2p_ctwin ? 1 : 0;
drv_ctrl->p2p_bcn_area = ctrl->en_p2p_bcn_area ? 1 : 0;
}
static void _beacon_ctrl_drv2halmac(struct rtw_halmac_bcn_ctrl *drv_ctrl,
struct halmac_bcn_ctrl *ctrl)
{
ctrl->dis_rx_bssid_fit = drv_ctrl->rx_bssid_fit ? 0 : 1;
ctrl->en_txbcn_rpt = drv_ctrl->txbcn_rpt ? 1 : 0;
ctrl->dis_tsf_udt = drv_ctrl->tsf_update ? 0 : 1;
ctrl->en_bcn = drv_ctrl->enable_bcn ? 1 : 0;
ctrl->en_rxbcn_rpt = drv_ctrl->rxbcn_rpt ? 1 : 0;
ctrl->en_p2p_ctwin = drv_ctrl->p2p_ctwin ? 1 : 0;
ctrl->en_p2p_bcn_area = drv_ctrl->p2p_bcn_area ? 1 : 0;
}
int rtw_halmac_get_hw_value(struct dvobj_priv *d, enum halmac_hw_id hw_id, void *pvalue)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_hw_value(mac, hw_id, pvalue);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
/**
* rtw_halmac_get_tx_fifo_size() - TX FIFO size
* @d: struct dvobj_priv*
* @size: TX FIFO size, unit is byte.
*
* Get TX FIFO size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_TXFIFO_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_rx_fifo_size() - RX FIFO size
* @d: struct dvobj_priv*
* @size: RX FIFO size, unit is byte
*
* Get RX FIFO size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_RXFIFO_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_rsvd_drv_pg_bndy() - Reserve page boundary of driver
* @d: struct dvobj_priv*
* @size: Page size, unit is byte
*
* Get reserve page boundary of driver from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u16 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_RSVD_PG_BNDY, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*bndy = val;
return 0;
}
/**
* rtw_halmac_get_page_size() - Page size
* @d: struct dvobj_priv*
* @size: Page size, unit is byte
*
* Get TX/RX page size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_page_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_PAGE_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_tx_agg_align_size() - TX aggregation align size
* @d: struct dvobj_priv*
* @size: TX aggregation align size, unit is byte
*
* Get TX aggregation align size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_tx_agg_align_size(struct dvobj_priv *d, u16 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u16 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_TX_AGG_ALIGN_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_rx_agg_align_size() - RX aggregation align size
* @d: struct dvobj_priv*
* @size: RX aggregation align size, unit is byte
*
* Get RX aggregation align size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_rx_agg_align_size(struct dvobj_priv *d, u8 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_RX_AGG_ALIGN_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/*
* Description:
* Get RX driver info size. RX driver info is a small memory space between
* scriptor and RX payload.
*
* +-------------------------+
* | RX descriptor |
* | usually 24 bytes |
* +-------------------------+
* | RX driver info |
* | depends on driver cfg |
* +-------------------------+
* | RX paylad |
* | |
* +-------------------------+
*
* Parameter:
* d pointer to struct dvobj_priv of driver
* sz rx driver info size in bytes.
*
* Rteurn:
* 0 Success
* other Fail
*/
int rtw_halmac_get_rx_drv_info_sz(struct dvobj_priv *d, u8 *sz)
{
enum halmac_ret_status status;
struct halmac_adapter *halmac = dvobj_to_halmac(d);
struct halmac_api *api = HALMAC_GET_API(halmac);
u8 dw = 0;
status = api->halmac_get_hw_value(halmac, HALMAC_HW_DRV_INFO_SIZE, &dw);
if (status != HALMAC_RET_SUCCESS)
return -1;
*sz = dw * 8;
return 0;
}
/**
* rtw_halmac_get_tx_desc_size() - TX descriptor size
* @d: struct dvobj_priv*
* @size: TX descriptor size, unit is byte.
*
* Get TX descriptor size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_tx_desc_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_TX_DESC_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_rx_desc_size() - RX descriptor size
* @d: struct dvobj_priv*
* @size: RX descriptor size, unit is byte.
*
* Get RX descriptor size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_rx_desc_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_RX_DESC_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_fw_max_size() - Firmware MAX size
* @d: struct dvobj_priv*
* @size: MAX Firmware size, unit is byte.
*
* Get Firmware MAX size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
static int rtw_halmac_get_fw_max_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_FW_MAX_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
/**
* rtw_halmac_get_ori_h2c_size() - Original H2C MAX size
* @d: struct dvobj_priv*
* @size: H2C MAX size, unit is byte.
*
* Get original H2C MAX size(byte) from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_ori_h2c_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_ORI_H2C_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
int rtw_halmac_get_oqt_size(struct dvobj_priv *d, u8 *size)
{
enum halmac_ret_status status;
struct halmac_adapter *halmac;
struct halmac_api *api;
u8 val;
if (!size)
return -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_AC_OQT_SIZE, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*size = val;
return 0;
}
int rtw_halmac_get_ac_queue_number(struct dvobj_priv *d, u8 *num)
{
enum halmac_ret_status status;
struct halmac_adapter *halmac;
struct halmac_api *api;
u8 val;
if (!num)
return -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_AC_QUEUE_NUM, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*num = val;
return 0;
}
/**
* rtw_halmac_get_mac_address() - Get MAC address of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @addr: buffer for storing MAC address
*
* Get MAC address of specific port from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
union halmac_wlan_addr hwa;
enum halmac_ret_status status;
int err = -1;
if (!addr)
goto out;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
_rtw_memset(&hwa, 0, sizeof(hwa));
status = api->halmac_get_mac_addr(halmac, port, &hwa);
if (status != HALMAC_RET_SUCCESS)
goto out;
_rtw_memcpy(addr, hwa.addr, 6);
err = 0;
out:
return err;
}
/**
* rtw_halmac_get_network_type() - Get network type of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @type: buffer to put network type (_HW_STATE_*)
*
* Get network type of specific port from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 *type)
{
#if 0
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
enum halmac_network_type_select network;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
network = HALMAC_NETWORK_UNDEFINE;
status = api->halmac_get_net_type(halmac, port, &network);
if (status != HALMAC_RET_SUCCESS)
goto out;
*type = _network_type_halmac2drv(network);
err = 0;
out:
return err;
#else
struct _ADAPTER *a;
enum halmac_portid port;
enum halmac_network_type_select network;
u32 val;
int err = -1;
a = dvobj_get_primary_adapter(d);
port = _hw_port_drv2halmac(hwport);
network = HALMAC_NETWORK_UNDEFINE;
switch (port) {
case HALMAC_PORTID0:
val = rtw_read32(a, REG_CR);
network = BIT_GET_NETYPE0(val);
break;
case HALMAC_PORTID1:
val = rtw_read32(a, REG_CR);
network = BIT_GET_NETYPE1(val);
break;
case HALMAC_PORTID2:
val = rtw_read32(a, REG_CR_EXT);
network = BIT_GET_NETYPE2(val);
break;
case HALMAC_PORTID3:
val = rtw_read32(a, REG_CR_EXT);
network = BIT_GET_NETYPE3(val);
break;
case HALMAC_PORTID4:
val = rtw_read32(a, REG_CR_EXT);
network = BIT_GET_NETYPE4(val);
break;
default:
goto out;
}
*type = _network_type_halmac2drv(network);
err = 0;
out:
return err;
#endif
}
/**
* rtw_halmac_get_bcn_ctrl() - Get beacon control setting of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @bcn_ctrl: setting of beacon control
*
* Get beacon control setting of specific port from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
struct rtw_halmac_bcn_ctrl *bcn_ctrl)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
struct halmac_bcn_ctrl ctrl;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
_rtw_memset(&ctrl, 0, sizeof(ctrl));
status = api->halmac_rw_bcn_ctrl(halmac, port, 0, &ctrl);
if (status != HALMAC_RET_SUCCESS)
goto out;
_beacon_ctrl_halmac2drv(&ctrl, bcn_ctrl);
err = 0;
out:
return err;
}
/*
* Note:
* When this function return, the register REG_RCR may be changed.
*/
int rtw_halmac_config_rx_info(struct dvobj_priv *d, enum halmac_drv_info info)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_cfg_drv_info(halmac, info);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
/* Sync driver RCR cache with register setting */
rtw_hal_get_hwreg(dvobj_get_primary_adapter(d), HW_VAR_RCR, NULL);
return err;
}
/**
* rtw_halmac_set_max_dl_fw_size() - Set the MAX download firmware size
* @d: struct dvobj_priv*
* @size: the max download firmware size in one I/O
*
* Set the max download firmware size in one I/O.
* Please also consider the max size of the callback function "SEND_RSVD_PAGE"
* could accept, because download firmware would call "SEND_RSVD_PAGE" to send
* firmware to IC.
*
* If the value of "size" is not even, it would be rounded down to nearest
* even, and 0 and 1 are both invalid value.
*
* Return 0 for setting OK, otherwise fail.
*/
int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
if (!size || (size == 1))
return -1;
mac = dvobj_to_halmac(d);
if (!mac) {
RTW_ERR("%s: HALMAC is not ready!!\n", __FUNCTION__);
return -1;
}
api = HALMAC_GET_API(mac);
size &= ~1; /* round down to even */
status = api->halmac_cfg_max_dl_size(mac, size);
if (status != HALMAC_RET_SUCCESS) {
RTW_WARN("%s: Fail to cfg_max_dl_size(%d), err=%d!!\n",
__FUNCTION__, size, status);
return -1;
}
return 0;
}
/**
* rtw_halmac_set_mac_address() - Set mac address of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @addr: mac address
*
* Set self mac address of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
union halmac_wlan_addr hwa;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
_rtw_memset(&hwa, 0, sizeof(hwa));
_rtw_memcpy(hwa.addr, addr, 6);
status = api->halmac_cfg_mac_addr(halmac, port, &hwa);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_set_bssid() - Set BSSID of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @addr: BSSID, mac address of AP
*
* Set BSSID of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
union halmac_wlan_addr hwa;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
_rtw_memset(&hwa, 0, sizeof(hwa));
_rtw_memcpy(hwa.addr, addr, 6);
status = api->halmac_cfg_bssid(halmac, port, &hwa);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_set_tx_address() - Set transmitter address of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @addr: transmitter address
*
* Set transmitter address of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_tx_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
union halmac_wlan_addr hwa;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
_rtw_memset(&hwa, 0, sizeof(hwa));
_rtw_memcpy(hwa.addr, addr, 6);
status = api->halmac_cfg_transmitter_addr(halmac, port, &hwa);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_set_network_type() - Set network type of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @type: network type (_HW_STATE_*)
*
* Set network type of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 type)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
enum halmac_network_type_select network;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
network = _network_type_drv2halmac(type);
status = api->halmac_cfg_net_type(halmac, port, network);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_reset_tsf() - Reset TSF timer of specific port
* @d: struct dvobj_priv*
* @hwport: port
*
* Notice HALMAC to reset timing synchronization function(TSF) timer of
* specific port.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_reset_tsf(struct dvobj_priv *d, enum _hw_port hwport)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
status = api->halmac_cfg_tsf_rst(halmac, port);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_set_bcn_interval() - Set beacon interval of each port
* @d: struct dvobj_priv*
* @hwport: port
* @space: beacon interval, unit is ms
*
* Set beacon interval of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_bcn_interval(struct dvobj_priv *d, enum _hw_port hwport,
u32 interval)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
status = api->halmac_cfg_bcn_space(halmac, port, interval);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_set_bcn_ctrl() - Set beacon control setting of each port
* @d: struct dvobj_priv*
* @hwport: port
* @bcn_ctrl: setting of beacon control
*
* Set beacon control setting of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport,
struct rtw_halmac_bcn_ctrl *bcn_ctrl)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
struct halmac_bcn_ctrl ctrl;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
_rtw_memset(&ctrl, 0, sizeof(ctrl));
_beacon_ctrl_drv2halmac(bcn_ctrl, &ctrl);
status = api->halmac_rw_bcn_ctrl(halmac, port, 1, &ctrl);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/**
* rtw_halmac_set_aid() - Set association identifier(AID) of specific port
* @d: struct dvobj_priv*
* @hwport: port
* @aid: Association identifier
*
* Set association identifier(AID) of specific port to HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_set_aid(struct dvobj_priv *d, enum _hw_port hwport, u16 aid)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_portid port;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
port = _hw_port_drv2halmac(hwport);
#if 0
status = api->halmac_cfg_aid(halmac, port, aid);
if (status != HALMAC_RET_SUCCESS)
goto out;
#else
{
struct _ADAPTER *a;
u32 addr;
u16 val;
a = dvobj_get_primary_adapter(d);
switch (port) {
case 0:
addr = REG_BCN_PSR_RPT;
val = rtw_read16(a, addr);
val = BIT_SET_PS_AID_0(val, aid);
rtw_write16(a, addr, val);
break;
case 1:
addr = REG_BCN_PSR_RPT1;
val = rtw_read16(a, addr);
val = BIT_SET_PS_AID_1(val, aid);
rtw_write16(a, addr, val);
break;
case 2:
addr = REG_BCN_PSR_RPT2;
val = rtw_read16(a, addr);
val = BIT_SET_PS_AID_2(val, aid);
rtw_write16(a, addr, val);
break;
case 3:
addr = REG_BCN_PSR_RPT3;
val = rtw_read16(a, addr);
val = BIT_SET_PS_AID_3(val, aid);
rtw_write16(a, addr, val);
break;
case 4:
addr = REG_BCN_PSR_RPT4;
val = rtw_read16(a, addr);
val = BIT_SET_PS_AID_4(val, aid);
rtw_write16(a, addr, val);
break;
default:
goto out;
}
}
#endif
err = 0;
out:
return err;
}
int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_cfg_ch_bw(mac, channel, pri_ch_idx, bw);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
/**
* rtw_halmac_set_edca() - config edca parameter
* @d: struct dvobj_priv*
* @queue: XMIT_[VO/VI/BE/BK]_QUEUE
* @aifs: Arbitration inter-frame space(AIFS)
* @cw: Contention window(CW)
* @txop: MAX Transmit Opportunity(TXOP)
*
* Return: 0 if process OK, otherwise -1.
*/
int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_acq_id ac;
struct halmac_edca_para edca;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
switch (queue) {
case XMIT_VO_QUEUE:
ac = HALMAC_ACQ_ID_VO;
break;
case XMIT_VI_QUEUE:
ac = HALMAC_ACQ_ID_VI;
break;
case XMIT_BE_QUEUE:
ac = HALMAC_ACQ_ID_BE;
break;
case XMIT_BK_QUEUE:
ac = HALMAC_ACQ_ID_BK;
break;
default:
return -1;
}
edca.aifs = aifs;
edca.cw = cw;
edca.txop_limit = txop;
status = api->halmac_cfg_edca_para(mac, ac, &edca);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
/**
* rtw_halmac_set_rts_full_bw() - Send RTS to all covered channels
* @d: struct dvobj_priv*
* @enable: _TRUE(enable), _FALSE(disable)
*
* Hradware will duplicate RTS packet to all channels which are covered in used
* bandwidth.
*
* Return 0 if process OK, otherwise -1.
*/
int rtw_halmac_set_rts_full_bw(struct dvobj_priv *d, u8 enable)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 full;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
full = (enable == _TRUE) ? 1 : 0;
status = api->halmac_set_hw_value(mac, HALMAC_HW_RTS_FULL_BW, &full);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
#ifdef RTW_HALMAC_DBG_POWER_SWITCH
static void _dump_mac_reg(struct dvobj_priv *d, u32 start, u32 end)
{
struct _ADAPTER *adapter;
int i, j = 1;
adapter = dvobj_get_primary_adapter(d);
for (i = start; i < end; i += 4) {
if (j % 4 == 1)
RTW_PRINT("0x%04x", i);
_RTW_PRINT(" 0x%08x ", rtw_read32(adapter, i));
if ((j++) % 4 == 0)
_RTW_PRINT("\n");
}
}
void dump_dbg_val(struct _ADAPTER *a, u32 reg)
{
u32 v32;
rtw_write8(a, 0x3A, reg);
v32 = rtw_read32(a, 0xC0);
RTW_PRINT("0x3A = %02x, 0xC0 = 0x%08x\n",reg, v32);
}
#ifdef CONFIG_PCI_HCI
static void _dump_pcie_cfg_space(struct dvobj_priv *d)
{
struct _ADAPTER *padapter = dvobj_get_primary_adapter(d);
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct pci_dev *pdev = pdvobjpriv->ppcidev;
struct pci_dev *bridge_pdev = pdev->bus->self;
u32 tmp[4] = { 0 };
u32 i, j;
RTW_PRINT("\n***** PCI Device Configuration Space *****\n\n");
for(i = 0; i < 0x100; i += 0x10)
{
for (j = 0 ; j < 4 ; j++)
pci_read_config_dword(pdev, i + j * 4, tmp+j);
RTW_PRINT("%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
}
RTW_PRINT("\n***** PCI Host Device Configuration Space*****\n\n");
for(i = 0; i < 0x100; i += 0x10)
{
for (j = 0 ; j < 4 ; j++)
pci_read_config_dword(bridge_pdev, i + j * 4, tmp+j);
RTW_PRINT("%03x: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n",
i, tmp[0] & 0xFF, (tmp[0] >> 8) & 0xFF, (tmp[0] >> 16) & 0xFF, (tmp[0] >> 24) & 0xFF,
tmp[1] & 0xFF, (tmp[1] >> 8) & 0xFF, (tmp[1] >> 16) & 0xFF, (tmp[1] >> 24) & 0xFF,
tmp[2] & 0xFF, (tmp[2] >> 8) & 0xFF, (tmp[2] >> 16) & 0xFF, (tmp[2] >> 24) & 0xFF,
tmp[3] & 0xFF, (tmp[3] >> 8) & 0xFF, (tmp[3] >> 16) & 0xFF, (tmp[3] >> 24) & 0xFF);
}
}
#endif
static void _dump_mac_reg_for_power_switch(struct dvobj_priv *d,
const char* caller, char* desc)
{
struct _ADAPTER *a;
u8 v8;
RTW_PRINT("%s: %s\n", caller, desc);
RTW_PRINT("======= MAC REG =======\n");
/* page 0/1 */
_dump_mac_reg(d, 0x0, 0x200);
_dump_mac_reg(d, 0x300, 0x400); /* also dump page 3 */
/* dump debug register */
a = dvobj_get_primary_adapter(d);
#ifdef CONFIG_PCI_HCI
_dump_pcie_cfg_space(d);
v8 = rtw_read8(a, 0xF6) | 0x01;
rtw_write8(a, 0xF6, v8);
RTW_PRINT("0xF6 = %02x\n", v8);
dump_dbg_val(a, 0x63);
dump_dbg_val(a, 0x64);
dump_dbg_val(a, 0x68);
dump_dbg_val(a, 0x69);
dump_dbg_val(a, 0x6a);
dump_dbg_val(a, 0x6b);
dump_dbg_val(a, 0x71);
dump_dbg_val(a, 0x72);
#endif
}
static enum halmac_ret_status _power_switch(struct halmac_adapter *halmac,
struct halmac_api *api,
enum halmac_mac_power pwr)
{
enum halmac_ret_status status;
char desc[80] = {0};
rtw_sprintf(desc, 80, "before calling power %s",
(pwr==HALMAC_MAC_POWER_ON)?"on":"off");
_dump_mac_reg_for_power_switch((struct dvobj_priv *)halmac->drv_adapter,
__FUNCTION__, desc);
status = api->halmac_mac_power_switch(halmac, pwr);
RTW_PRINT("%s: status=%d\n", __FUNCTION__, status);
rtw_sprintf(desc, 80, "after calling power %s",
(pwr==HALMAC_MAC_POWER_ON)?"on":"off");
_dump_mac_reg_for_power_switch((struct dvobj_priv *)halmac->drv_adapter,
__FUNCTION__, desc);
return status;
}
#else /* !RTW_HALMAC_DBG_POWER_SWITCH */
#define _power_switch(mac, api, pwr) (api)->halmac_mac_power_switch(mac, pwr)
#endif /* !RTW_HALMAC_DBG_POWER_SWITCH */
/*
* Description:
* Power on device hardware.
* [Notice!] If device's power state is on before,
* it would be power off first and turn on power again.
*
* Return:
* 0 power on success
* -1 power on fail
* -2 power state unchange
*/
int rtw_halmac_poweron(struct dvobj_priv *d)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
int err = -1;
#if defined(CONFIG_PCI_HCI) && defined(CONFIG_RTL8822B)
struct _ADAPTER *a;
u8 v8;
u32 addr;
a = dvobj_get_primary_adapter(d);
#endif
halmac = dvobj_to_halmac(d);
if (!halmac)
goto out;
api = HALMAC_GET_API(halmac);
status = api->halmac_pre_init_system_cfg(halmac);
if (status != HALMAC_RET_SUCCESS)
goto out;
#ifdef CONFIG_SDIO_HCI
status = api->halmac_sdio_cmd53_4byte(halmac, HALMAC_SDIO_CMD53_4BYTE_MODE_RW);
if (status != HALMAC_RET_SUCCESS)
goto out;
#endif /* CONFIG_SDIO_HCI */
#if defined(CONFIG_PCI_HCI) && defined(CONFIG_RTL8822B)
addr = 0x3F3;
v8 = rtw_read8(a, addr);
RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
/* are we in pcie debug mode? */
if (!(v8 & BIT(2))) {
RTW_PRINT("%s: Enable pcie debug mode\n", __FUNCTION__);
v8 |= BIT(2);
v8 = rtw_write8(a, addr, v8);
}
#endif
status = _power_switch(halmac, api, HALMAC_MAC_POWER_ON);
if (HALMAC_RET_PWR_UNCHANGE == status) {
#if defined(CONFIG_PCI_HCI) && defined(CONFIG_RTL8822B)
addr = 0x3F3;
v8 = rtw_read8(a, addr);
RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
/* are we in pcie debug mode? */
if (!(v8 & BIT(2))) {
RTW_PRINT("%s: Enable pcie debug mode\n", __FUNCTION__);
v8 |= BIT(2);
v8 = rtw_write8(a, addr, v8);
} else if (v8 & BIT(0)) {
/* DMA stuck */
addr = 0x1350;
v8 = rtw_read8(a, addr);
RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
RTW_PRINT("%s: recover DMA stuck\n", __FUNCTION__);
v8 |= BIT(6);
v8 = rtw_write8(a, addr, v8);
RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v8);
}
#endif
/*
* Work around for warm reboot but device not power off,
* but it would also fall into this case when auto power on is enabled.
*/
_power_switch(halmac, api, HALMAC_MAC_POWER_OFF);
status = _power_switch(halmac, api, HALMAC_MAC_POWER_ON);
RTW_WARN("%s: Power state abnormal, try to recover...%s\n",
__FUNCTION__, (HALMAC_RET_SUCCESS == status)?"OK":"FAIL!");
}
if (HALMAC_RET_SUCCESS != status) {
if (HALMAC_RET_PWR_UNCHANGE == status)
err = -2;
goto out;
}
status = api->halmac_init_system_cfg(halmac);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
/*
* Description:
* Power off device hardware.
*
* Return:
* 0 Power off success
* -1 Power off fail
*/
int rtw_halmac_poweroff(struct dvobj_priv *d)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
int err = -1;
halmac = dvobj_to_halmac(d);
if (!halmac)
goto out;
api = HALMAC_GET_API(halmac);
status = _power_switch(halmac, api, HALMAC_MAC_POWER_OFF);
if ((HALMAC_RET_SUCCESS != status)
&& (HALMAC_RET_PWR_UNCHANGE != status))
goto out;
err = 0;
out:
return err;
}
#ifdef CONFIG_SUPPORT_TRX_SHARED
static inline enum halmac_rx_fifo_expanding_mode _trx_share_mode_drv2halmac(u8 trx_share_mode)
{
if (0 == trx_share_mode)
return HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
else if (1 == trx_share_mode)
return HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK;
else if (2 == trx_share_mode)
return HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK;
else if (3 == trx_share_mode)
return HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK;
else
return HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
}
static enum halmac_rx_fifo_expanding_mode _rtw_get_trx_share_mode(struct _ADAPTER *adapter)
{
struct registry_priv *registry_par = &adapter->registrypriv;
return _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
}
void dump_trx_share_mode(void *sel, struct _ADAPTER *adapter)
{
struct registry_priv *registry_par = &adapter->registrypriv;
u8 mode = _trx_share_mode_drv2halmac(registry_par->trx_share_mode);
if (HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK == mode)
RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_1");
else if (HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK == mode)
RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_2");
else if (HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK == mode)
RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "RX_FIFO_EXPANDING_MODE_3");
else
RTW_PRINT_SEL(sel, "TRx share mode : %s\n", "DISABLE");
}
#endif
static enum halmac_drv_rsvd_pg_num _rsvd_page_num_drv2halmac(u16 num)
{
if (num <= 8)
return HALMAC_RSVD_PG_NUM8;
if (num <= 16)
return HALMAC_RSVD_PG_NUM16;
if (num <= 24)
return HALMAC_RSVD_PG_NUM24;
if (num <= 32)
return HALMAC_RSVD_PG_NUM32;
if (num <= 64)
return HALMAC_RSVD_PG_NUM64;
if (num <= 128)
return HALMAC_RSVD_PG_NUM128;
if (num > 256)
RTW_WARN("%s: Fail to allocate RSVD page(%d)!!"
" The MAX RSVD page number is 256...\n",
__FUNCTION__, num);
return HALMAC_RSVD_PG_NUM256;
}
static u16 _rsvd_page_num_halmac2drv(enum halmac_drv_rsvd_pg_num rsvd_page_number)
{
u16 num = 0;
switch (rsvd_page_number) {
case HALMAC_RSVD_PG_NUM8:
num = 8;
break;
case HALMAC_RSVD_PG_NUM16:
num = 16;
break;
case HALMAC_RSVD_PG_NUM24:
num = 24;
break;
case HALMAC_RSVD_PG_NUM32:
num = 32;
break;
case HALMAC_RSVD_PG_NUM64:
num = 64;
break;
case HALMAC_RSVD_PG_NUM128:
num = 128;
break;
case HALMAC_RSVD_PG_NUM256:
num = 256;
break;
}
return num;
}
static enum halmac_trx_mode _choose_trx_mode(struct dvobj_priv *d)
{
PADAPTER p;
p = dvobj_get_primary_adapter(d);
if (p->registrypriv.wifi_spec)
return HALMAC_TRX_MODE_WMM;
#ifdef CONFIG_SUPPORT_TRX_SHARED
if (_rtw_get_trx_share_mode(p))
return HALMAC_TRX_MODE_TRXSHARE;
#endif
return HALMAC_TRX_MODE_NORMAL;
}
static inline enum halmac_rf_type _rf_type_drv2halmac(enum rf_type rf_drv)
{
enum halmac_rf_type rf_mac;
switch (rf_drv) {
case RF_1T1R:
rf_mac = HALMAC_RF_1T1R;
break;
case RF_1T2R:
rf_mac = HALMAC_RF_1T2R;
break;
case RF_2T2R:
rf_mac = HALMAC_RF_2T2R;
break;
case RF_2T3R:
rf_mac = HALMAC_RF_2T3R;
break;
case RF_2T4R:
rf_mac = HALMAC_RF_2T4R;
break;
case RF_3T3R:
rf_mac = HALMAC_RF_3T3R;
break;
case RF_3T4R:
rf_mac = HALMAC_RF_3T4R;
break;
case RF_4T4R:
rf_mac = HALMAC_RF_4T4R;
break;
default:
rf_mac = HALMAC_RF_MAX_TYPE;
RTW_ERR("%s: Invalid RF type(0x%x)!\n", __FUNCTION__, rf_drv);
break;
}
return rf_mac;
}
static inline enum rf_type _rf_type_halmac2drv(enum halmac_rf_type rf_mac)
{
enum rf_type rf_drv;
switch (rf_mac) {
case HALMAC_RF_1T2R:
rf_drv = RF_1T2R;
break;
case HALMAC_RF_2T4R:
rf_drv = RF_2T4R;
break;
case HALMAC_RF_2T2R:
case HALMAC_RF_2T2R_GREEN:
rf_drv = RF_2T2R;
break;
case HALMAC_RF_2T3R:
rf_drv = RF_2T3R;
break;
case HALMAC_RF_1T1R:
rf_drv = RF_1T1R;
break;
case HALMAC_RF_3T3R:
rf_drv = RF_3T3R;
break;
case HALMAC_RF_3T4R:
rf_drv = RF_3T4R;
break;
case HALMAC_RF_4T4R:
rf_drv = RF_4T4R;
break;
default:
rf_drv = RF_TYPE_MAX;
RTW_ERR("%s: Invalid RF type(0x%x)!\n", __FUNCTION__, rf_mac);
break;
}
return rf_drv;
}
static enum odm_cut_version _cut_version_drv2phydm(
enum tag_HAL_Cut_Version_Definition cut_drv)
{
enum odm_cut_version cut_phydm = ODM_CUT_A;
u32 diff;
if (cut_drv > K_CUT_VERSION)
RTW_WARN("%s: unknown cut_ver=%d !!\n", __FUNCTION__, cut_drv);
diff = cut_drv - A_CUT_VERSION;
cut_phydm += diff;
return cut_phydm;
}
static int _send_general_info_by_reg(struct dvobj_priv *d,
struct halmac_general_info *info)
{
struct _ADAPTER *a;
struct hal_com_data *hal;
enum tag_HAL_Cut_Version_Definition cut_drv;
enum rf_type rftype;
enum odm_cut_version cut_phydm;
u8 h2c[RTW_HALMAC_H2C_MAX_SIZE] = {0};
a = dvobj_get_primary_adapter(d);
hal = GET_HAL_DATA(a);
rftype = _rf_type_halmac2drv(info->rf_type);
cut_drv = GET_CVID_CUT_VERSION(hal->version_id);
cut_phydm = _cut_version_drv2phydm(cut_drv);
#define CLASS_GENERAL_INFO_REG 0x02
#define CMD_ID_GENERAL_INFO_REG 0x0C
#define GENERAL_INFO_REG_SET_CMD_ID(buf, v) SET_BITS_TO_LE_4BYTE(buf, 0, 5, v)
#define GENERAL_INFO_REG_SET_CLASS(buf, v) SET_BITS_TO_LE_4BYTE(buf, 5, 3, v)
#define GENERAL_INFO_REG_SET_RFE_TYPE(buf, v) SET_BITS_TO_LE_4BYTE(buf, 8, 8, v)
#define GENERAL_INFO_REG_SET_RF_TYPE(buf, v) SET_BITS_TO_LE_4BYTE(buf, 16, 8, v)
#define GENERAL_INFO_REG_SET_CUT_VERSION(buf, v) SET_BITS_TO_LE_4BYTE(buf, 24, 8, v)
#define GENERAL_INFO_REG_SET_RX_ANT_STATUS(buf, v) SET_BITS_TO_LE_1BYTE(buf+4, 0, 4, v)
#define GENERAL_INFO_REG_SET_TX_ANT_STATUS(buf, v) SET_BITS_TO_LE_1BYTE(buf+4, 4, 4, v)
GENERAL_INFO_REG_SET_CMD_ID(h2c, CMD_ID_GENERAL_INFO_REG);
GENERAL_INFO_REG_SET_CLASS(h2c, CLASS_GENERAL_INFO_REG);
GENERAL_INFO_REG_SET_RFE_TYPE(h2c, info->rfe_type);
GENERAL_INFO_REG_SET_RF_TYPE(h2c, rftype);
GENERAL_INFO_REG_SET_CUT_VERSION(h2c, cut_phydm);
GENERAL_INFO_REG_SET_RX_ANT_STATUS(h2c, info->rx_ant_status);
GENERAL_INFO_REG_SET_TX_ANT_STATUS(h2c, info->tx_ant_status);
return rtw_halmac_send_h2c(d, h2c);
}
static int _send_general_info(struct dvobj_priv *d)
{
struct _ADAPTER *adapter;
struct hal_com_data *hal;
struct halmac_adapter *halmac;
struct halmac_api *api;
struct halmac_general_info info;
enum halmac_ret_status status;
enum rf_type rf = RF_1T1R;
enum bb_path txpath = BB_PATH_A;
enum bb_path rxpath = BB_PATH_A;
int err;
adapter = dvobj_get_primary_adapter(d);
hal = GET_HAL_DATA(adapter);
halmac = dvobj_to_halmac(d);
if (!halmac)
return -1;
api = HALMAC_GET_API(halmac);
_rtw_memset(&info, 0, sizeof(info));
info.rfe_type = (u8)hal->rfe_type;
rtw_hal_get_rf_path(d, &rf, &txpath, &rxpath);
info.rf_type = _rf_type_drv2halmac(rf);
info.tx_ant_status = (u8)txpath;
info.rx_ant_status = (u8)rxpath;
status = api->halmac_send_general_info(halmac, &info);
switch (status) {
case HALMAC_RET_SUCCESS:
break;
case HALMAC_RET_NO_DLFW:
RTW_WARN("%s: halmac_send_general_info() fail because fw not dl!\n",
__FUNCTION__);
/* go through */
default:
return -1;
}
err = _send_general_info_by_reg(d, &info);
if (err) {
RTW_ERR("%s: Fail to send general info by register!\n",
__FUNCTION__);
return -1;
}
return 0;
}
static int _cfg_drv_rsvd_pg_num(struct dvobj_priv *d)
{
struct _ADAPTER *a;
struct hal_com_data *hal;
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_drv_rsvd_pg_num rsvd_page_number;
enum halmac_ret_status status;
u16 drv_rsvd_num;
int ret = 0;
a = dvobj_get_primary_adapter(d);
hal = GET_HAL_DATA(a);
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
drv_rsvd_num = rtw_hal_get_rsvd_page_num(a);
rsvd_page_number = _rsvd_page_num_drv2halmac(drv_rsvd_num);
status = api->halmac_cfg_drv_rsvd_pg_num(halmac, rsvd_page_number);
if (status != HALMAC_RET_SUCCESS) {
ret = -1;
goto exit;
}
hal->drv_rsvd_page_number = _rsvd_page_num_halmac2drv(rsvd_page_number);
exit:
#ifndef DBG_RSVD_PAGE_CFG
if (drv_rsvd_num != _rsvd_page_num_halmac2drv(rsvd_page_number))
#endif
RTW_INFO("%s: request %d pages => halmac %d pages %s\n"
, __FUNCTION__, drv_rsvd_num, _rsvd_page_num_halmac2drv(rsvd_page_number)
, ret ? "fail" : "success");
return ret;
}
static void _debug_dlfw_fail(struct dvobj_priv *d)
{
struct _ADAPTER *a;
u32 addr;
u32 v32, i, n;
u8 data[0x100] = {0};
a = dvobj_get_primary_adapter(d);
/* read 0x80[15:0], 0x10F8[31:0] once */
addr = 0x80;
v32 = rtw_read16(a, addr);
RTW_PRINT("%s: 0x%X = 0x%04x\n", __FUNCTION__, addr, v32);
addr = 0x10F8;
v32 = rtw_read32(a, addr);
RTW_PRINT("%s: 0x%X = 0x%08x\n", __FUNCTION__, addr, v32);
/* read 0x10FC[31:0], 5 times */
addr = 0x10FC;
n = 5;
for (i = 0; i < n; i++) {
v32 = rtw_read32(a, addr);
RTW_PRINT("%s: 0x%X = 0x%08x (%u/%u)\n",
__FUNCTION__, addr, v32, i, n);
}
/*
* write 0x3A[7:0]=0x28 and 0xF6[7:0]=0x01
* and then read 0xC0[31:0] 5 times
*/
addr = 0x3A;
v32 = 0x28;
rtw_write8(a, addr, (u8)v32);
v32 = rtw_read8(a, addr);
RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v32);
addr = 0xF6;
v32 = 0x1;
rtw_write8(a, addr, (u8)v32);
v32 = rtw_read8(a, addr);
RTW_PRINT("%s: 0x%X = 0x%02x\n", __FUNCTION__, addr, v32);
addr = 0xC0;
n = 5;
for (i = 0; i < n; i++) {
v32 = rtw_read32(a, addr);
RTW_PRINT("%s: 0x%X = 0x%08x (%u/%u)\n",
__FUNCTION__, addr, v32, i, n);
}
/* 0x00~0xFF, 0x1000~0x10FF */
addr = 0;
n = 0x100;
for (i = 0; i < n; i+=4)
*(u32*)&data[i] = cpu_to_le32(rtw_read32(a, addr+i));
for (i = 0; i < n; i++) {
if (i % 16 == 0)
RTW_PRINT("0x%04x\t", addr+i);
_RTW_PRINT("0x%02x", data[i]);
if (i % 16 == 15)
_RTW_PRINT("\n");
else
_RTW_PRINT(" ");
}
addr = 0x1000;
n = 0x100;
for (i = 0; i < n; i+=4)
*(u32*)&data[i] = cpu_to_le32(rtw_read32(a, addr+i));
for (i = 0; i < n; i++) {
if (i % 16 == 0)
RTW_PRINT("0x%04x\t", addr+i);
_RTW_PRINT("0x%02x", data[i]);
if (i % 16 == 15)
_RTW_PRINT("\n");
else
_RTW_PRINT(" ");
}
/* read 0x80 after 10 secs */
rtw_msleep_os(10000);
addr = 0x80;
v32 = rtw_read16(a, addr);
RTW_PRINT("%s: 0x%X = 0x%04x (after 10 secs)\n",
__FUNCTION__, addr, v32);
}
static enum halmac_ret_status _enter_cpu_sleep_mode(struct dvobj_priv *d)
{
struct hal_com_data *hal;
struct halmac_adapter *mac;
struct halmac_api *api;
hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
#ifdef CONFIG_RTL8822B
/* Support after firmware version 21 */
if (hal->firmware_version < 21)
return HALMAC_RET_NOT_SUPPORT;
#elif defined(CONFIG_RTL8821C)
/* Support after firmware version 13.6 or 16 */
if (hal->firmware_version == 13) {
if (hal->firmware_sub_version < 6)
return HALMAC_RET_NOT_SUPPORT;
} else if (hal->firmware_version < 16) {
return HALMAC_RET_NOT_SUPPORT;
}
#endif
return api->halmac_enter_cpu_sleep_mode(mac);
}
/*
* _cpu_sleep() - Let IC CPU enter sleep mode
* @d: struct dvobj_priv*
* @timeout: time limit of wait, unit is ms
* 0 for no limit
*
* Rteurn 0 for CPU in sleep mode, otherwise fail to enter sleep mode.
* Error codes definition are as follow:
* -1 HALMAC enter sleep return fail
* -2 HALMAC get CPU mode return fail
* -110 timeout
*/
static int _cpu_sleep(struct dvobj_priv *d, u32 timeout)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_wlcpu_mode mode = HALMAC_WLCPU_UNDEFINE;
systime start_t;
s32 period = 0;
u32 cnt = 0;
int err = 0;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
start_t = rtw_get_current_time();
status = _enter_cpu_sleep_mode(d);
if (status != HALMAC_RET_SUCCESS) {
if (status != HALMAC_RET_NOT_SUPPORT)
err = -1;
goto exit;
}
do {
cnt++;
mode = HALMAC_WLCPU_UNDEFINE;
status = api->halmac_get_cpu_mode(mac, &mode);
period = rtw_get_passing_time_ms(start_t);
if (status != HALMAC_RET_SUCCESS) {
err = -2;
break;
}
if (mode == HALMAC_WLCPU_SLEEP)
break;
if (period > timeout) {
err = -110;
break;
}
rtw_msleep_os(1);
} while (1);
exit:
if (err)
RTW_ERR("%s: Fail to enter sleep mode! (%d, %d)\n",
__FUNCTION__, status, mode);
RTW_INFO("%s: Cost %dms to polling %u times. (err=%d)\n",
__FUNCTION__, period, cnt, err);
return err;
}
static void _init_trx_cfg_drv(struct dvobj_priv *d)
{
#ifdef CONFIG_PCI_HCI
rtw_hal_irp_reset(dvobj_get_primary_adapter(d));
#endif
}
/*
* Description:
* Downlaod Firmware Flow
*
* Parameters:
* d pointer of struct dvobj_priv
* fw firmware array
* fwsize firmware size
* re_dl re-download firmware or not
* 0: run in init hal flow, not re-download
* 1: it is a stand alone operation, not in init hal flow
*
* Return:
* 0 Success
* others Fail
*/
static int download_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize, u8 re_dl)
{
PHAL_DATA_TYPE hal;
struct halmac_adapter *mac;
struct halmac_api *api;
struct halmac_fw_version fw_vesion;
enum halmac_ret_status status;
int err = 0;
hal = GET_HAL_DATA(dvobj_get_primary_adapter(d));
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
if ((!fw) || (!fwsize))
return -1;
/* 1. Driver Stop Tx */
/* ToDo */
/* 2. Driver Check Tx FIFO is empty */
err = rtw_halmac_txfifo_wait_empty(d, 2000); /* wait 2s */
if (err) {
err = -1;
goto resume_tx;
}
/* 3. Config MAX download size */
/*
* Already done in rtw_halmac_init_adapter() or
* somewhere calling rtw_halmac_set_max_dl_fw_size().
*/
if (re_dl) {
/* 4. Enter IC CPU sleep mode */
err = _cpu_sleep(d, 2000);
if (err) {
RTW_ERR("%s: IC CPU fail to enter sleep mode!(%d)\n",
__FUNCTION__, err);
/* skip this error */
err = 0;
}
}
/* 5. Download Firmware */
status = api->halmac_download_firmware(mac, fw, fwsize);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: download firmware FAIL! status=0x%02x\n",
__FUNCTION__, status);
_debug_dlfw_fail(d);
err = -1;
goto resume_tx;
}
/* 5.1. (Driver) Reset driver variables if needed */
hal->LastHMEBoxNum = 0;
/* 5.2. (Driver) Get FW version */
status = api->halmac_get_fw_version(mac, &fw_vesion);
if (status == HALMAC_RET_SUCCESS) {
hal->firmware_version = fw_vesion.version;
hal->firmware_sub_version = fw_vesion.sub_version;
hal->firmware_size = fwsize;
}
resume_tx:
/* 6. Driver resume TX if needed */
/* ToDo */
if (err)
goto exit;
if (re_dl) {
enum halmac_trx_mode mode;
/* 7. Change reserved page size */
err = _cfg_drv_rsvd_pg_num(d);
if (err)
return -1;
/* 8. Init TRX Configuration */
mode = _choose_trx_mode(d);
status = api->halmac_init_trx_cfg(mac, mode);
if (HALMAC_RET_SUCCESS != status)
return -1;
_init_trx_cfg_drv(d);
/* 9. Config RX Aggregation */
err = rtw_halmac_rx_agg_switch(d, _TRUE);
if (err)
return -1;
/* 10. Send General Info */
err = _send_general_info(d);
if (err)
return -1;
}
exit:
return err;
}
static int init_mac_flow(struct dvobj_priv *d)
{
PADAPTER p;
struct hal_com_data *hal;
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_drv_rsvd_pg_num rsvd_page_number;
union halmac_wlan_addr hwa;
enum halmac_trx_mode trx_mode;
enum halmac_ret_status status;
u8 drv_rsvd_num;
u8 nettype;
int err, err_ret = -1;
p = dvobj_get_primary_adapter(d);
hal = GET_HAL_DATA(p);
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
#ifdef CONFIG_SUPPORT_TRX_SHARED
status = api->halmac_cfg_rxff_expand_mode(halmac,
_rtw_get_trx_share_mode(p));
if (status != HALMAC_RET_SUCCESS)
goto out;
#endif
#ifdef DBG_LA_MODE
if (dvobj_to_regsty(d)->la_mode_en) {
status = api->halmac_cfg_la_mode(halmac, HALMAC_LA_MODE_PARTIAL);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: Fail to enable LA mode!\n", __FUNCTION__);
goto out;
}
RTW_PRINT("%s: Enable LA mode OK.\n", __FUNCTION__);
}
#endif
err = _cfg_drv_rsvd_pg_num(d);
if (err)
goto out;
#ifdef CONFIG_USB_HCI
status = api->halmac_set_bulkout_num(halmac, d->RtNumOutPipes);
if (status != HALMAC_RET_SUCCESS)
goto out;
#endif /* CONFIG_USB_HCI */
trx_mode = _choose_trx_mode(d);
status = api->halmac_init_mac_cfg(halmac, trx_mode);
if (status != HALMAC_RET_SUCCESS)
goto out;
/* Driver insert flow: Sync driver setting with register */
/* Sync driver RCR cache with register setting */
rtw_hal_get_hwreg(dvobj_get_primary_adapter(d), HW_VAR_RCR, NULL);
_init_trx_cfg_drv(d);
/* Driver inser flow end */
err = rtw_halmac_rx_agg_switch(d, _TRUE);
if (err)
goto out;
nettype = dvobj_to_regsty(d)->wireless_mode;
if (is_supported_vht(nettype) == _TRUE)
status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_AC);
else if (is_supported_ht(nettype) == _TRUE)
status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_N);
else if (IsSupportedTxOFDM(nettype) == _TRUE)
status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_G);
else
status = api->halmac_cfg_operation_mode(halmac, HALMAC_WIRELESS_MODE_B);
if (status != HALMAC_RET_SUCCESS)
goto out;
err_ret = 0;
out:
return err_ret;
}
static int _drv_enable_trx(struct dvobj_priv *d)
{
struct _ADAPTER *adapter;
u32 status;
adapter = dvobj_get_primary_adapter(d);
if (adapter->bup == _FALSE) {
#ifdef CONFIG_NEW_NETDEV_HDL
status = rtw_mi_start_drv_threads(adapter);
#else
status = rtw_start_drv_threads(adapter);
#endif
if (status == _FAIL) {
RTW_ERR("%s: Start threads Failed!\n", __FUNCTION__);
return -1;
}
}
rtw_intf_start(adapter);
return 0;
}
/*
* Notices:
* Make sure
* 1. rtw_hal_get_hwreg(HW_VAR_RF_TYPE)
* 2. HAL_DATA_TYPE.rfe_type
* already ready for use before calling this function.
*/
static int _halmac_init_hal(struct dvobj_priv *d, u8 *fw, u32 fwsize)
{
PADAPTER adapter;
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 ok;
u8 fw_ok = _FALSE;
int err, err_ret = -1;
adapter = dvobj_get_primary_adapter(d);
halmac = dvobj_to_halmac(d);
if (!halmac)
goto out;
api = HALMAC_GET_API(halmac);
/* StatePowerOff */
/* SKIP: halmac_init_adapter (Already done before) */
/* halmac_pre_Init_system_cfg */
/* halmac_mac_power_switch(on) */
/* halmac_Init_system_cfg */
ok = rtw_hal_power_on(adapter);
if (_FAIL == ok)
goto out;
/* StatePowerOn */
/* DownloadFW */
if (fw && fwsize) {
err = download_fw(d, fw, fwsize, 0);
if (err)
goto out;
fw_ok = _TRUE;
}
/* InitMACFlow */
err = init_mac_flow(d);
if (err)
goto out;
/* Driver insert flow: Enable TR/RX */
err = _drv_enable_trx(d);
if (err)
goto out;
/* halmac_send_general_info */
if (_TRUE == fw_ok) {
err = _send_general_info(d);
if (err)
goto out;
}
/* Init Phy parameter-MAC */
ok = rtw_hal_init_mac_register(adapter);
if (_FALSE == ok)
goto out;
/* StateMacInitialized */
/* halmac_cfg_drv_info */
err = rtw_halmac_config_rx_info(d, HALMAC_DRV_INFO_PHY_STATUS);
if (err)
goto out;
/* halmac_set_hw_value(HALMAC_HW_EN_BB_RF) */
/* Init BB, RF */
ok = rtw_hal_init_phy(adapter);
if (_FALSE == ok)
goto out;
status = api->halmac_init_interface_cfg(halmac);
if (status != HALMAC_RET_SUCCESS)
goto out;
/* SKIP: halmac_verify_platform_api */
/* SKIP: halmac_h2c_lb */
/* StateRxIdle */
err_ret = 0;
out:
return err_ret;
}
int rtw_halmac_init_hal(struct dvobj_priv *d)
{
return _halmac_init_hal(d, NULL, 0);
}
/*
* Notices:
* Make sure
* 1. rtw_hal_get_hwreg(HW_VAR_RF_TYPE)
* 2. HAL_DATA_TYPE.rfe_type
* already ready for use before calling this function.
*/
int rtw_halmac_init_hal_fw(struct dvobj_priv *d, u8 *fw, u32 fwsize)
{
return _halmac_init_hal(d, fw, fwsize);
}
/*
* Notices:
* Make sure
* 1. rtw_hal_get_hwreg(HW_VAR_RF_TYPE)
* 2. HAL_DATA_TYPE.rfe_type
* already ready for use before calling this function.
*/
int rtw_halmac_init_hal_fw_file(struct dvobj_priv *d, u8 *fwpath)
{
u8 *fw = NULL;
u32 fwmaxsize = 0, size = 0;
int err = 0;
err = rtw_halmac_get_fw_max_size(d, &fwmaxsize);
if (err) {
RTW_ERR("%s: Fail to get Firmware MAX size(err=%d)\n", __FUNCTION__, err);
return -1;
}
fw = rtw_zmalloc(fwmaxsize);
if (!fw)
return -1;
size = rtw_retrieve_from_file(fwpath, fw, fwmaxsize);
if (!size) {
err = -1;
goto exit;
}
err = _halmac_init_hal(d, fw, size);
exit:
rtw_mfree(fw, fwmaxsize);
/*fw = NULL;*/
return err;
}
int rtw_halmac_deinit_hal(struct dvobj_priv *d)
{
PADAPTER adapter;
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
int err = -1;
adapter = dvobj_get_primary_adapter(d);
halmac = dvobj_to_halmac(d);
if (!halmac)
goto out;
api = HALMAC_GET_API(halmac);
status = api->halmac_deinit_interface_cfg(halmac);
if (status != HALMAC_RET_SUCCESS)
goto out;
rtw_hal_power_off(adapter);
err = 0;
out:
return err;
}
int rtw_halmac_self_verify(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
int err = -1;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_verify_platform_api(mac);
if (status != HALMAC_RET_SUCCESS)
goto out;
status = api->halmac_h2c_lb(mac);
if (status != HALMAC_RET_SUCCESS)
goto out;
err = 0;
out:
return err;
}
static u8 rtw_halmac_txfifo_is_empty(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 chk_num = 10;
u8 rst = _FALSE;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_txfifo_is_empty(mac, chk_num);
if (status == HALMAC_RET_SUCCESS)
rst = _TRUE;
return rst;
}
/**
* rtw_halmac_txfifo_wait_empty() - Wait TX FIFO to be emtpy
* @d: struct dvobj_priv*
* @timeout: time limit of wait, unit is ms
* 0 for no limit
*
* Wait TX FIFO to be emtpy.
*
* Rteurn 0 for TX FIFO is empty, otherwise not empty.
*/
int rtw_halmac_txfifo_wait_empty(struct dvobj_priv *d, u32 timeout)
{
struct _ADAPTER *a;
u8 empty = _FALSE;
u32 cnt = 0;
systime start_time = 0;
u32 pass_time; /* ms */
a = dvobj_get_primary_adapter(d);
start_time = rtw_get_current_time();
do {
cnt++;
empty = rtw_halmac_txfifo_is_empty(d);
if (empty == _TRUE)
break;
if (timeout) {
pass_time = rtw_get_passing_time_ms(start_time);
if (pass_time > timeout)
break;
}
if (RTW_CANNOT_IO(a)) {
RTW_WARN("%s: Interrupted by I/O forbiden!\n", __FUNCTION__);
break;
}
rtw_msleep_os(2);
} while (1);
if (empty == _FALSE) {
#ifdef CONFIG_RTW_DEBUG
u16 dbg_reg[] = {0x210, 0x230, 0x234, 0x238, 0x23C, 0x240,
0x418, 0x10FC, 0x10F8, 0x11F4, 0x11F8};
u8 i;
u32 val;
if (!RTW_CANNOT_IO(a)) {
for (i = 0; i < ARRAY_SIZE(dbg_reg); i++) {
val = rtw_read32(a, dbg_reg[i]);
RTW_ERR("REG_%X:0x%08x\n", dbg_reg[i], val);
}
}
#endif /* CONFIG_RTW_DEBUG */
RTW_ERR("%s: Fail to wait txfifo empty!(cnt=%d)\n",
__FUNCTION__, cnt);
return -1;
}
return 0;
}
static enum halmac_dlfw_mem _fw_mem_drv2halmac(enum fw_mem mem, u8 tx_stop)
{
enum halmac_dlfw_mem mem_halmac = HALMAC_DLFW_MEM_UNDEFINE;
switch (mem) {
case FW_EMEM:
if (tx_stop == _FALSE)
mem_halmac = HALMAC_DLFW_MEM_EMEM_RSVD_PG;
else
mem_halmac = HALMAC_DLFW_MEM_EMEM;
break;
case FW_IMEM:
case FW_DMEM:
mem_halmac = HALMAC_DLFW_MEM_UNDEFINE;
break;
}
return mem_halmac;
}
int rtw_halmac_dlfw_mem(struct dvobj_priv *d, u8 *fw, u32 fwsize, enum fw_mem mem)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_dlfw_mem dlfw_mem;
u8 tx_stop = _FALSE;
u32 chk_timeout = 2000; /* unit: ms */
int err = 0;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
if ((!fw) || (!fwsize))
return -1;
#ifndef RTW_HALMAC_DLFW_MEM_NO_STOP_TX
/* 1. Driver Stop Tx */
/* ToDo */
/* 2. Driver Check Tx FIFO is empty */
err = rtw_halmac_txfifo_wait_empty(d, chk_timeout);
if (err)
tx_stop = _FALSE;
else
tx_stop = _TRUE;
#endif /* !RTW_HALMAC_DLFW_MEM_NO_STOP_TX */
/* 3. Download Firmware MEM */
dlfw_mem = _fw_mem_drv2halmac(mem, tx_stop);
if (dlfw_mem == HALMAC_DLFW_MEM_UNDEFINE) {
err = -1;
goto resume_tx;
}
status = api->halmac_free_download_firmware(mac, dlfw_mem, fw, fwsize);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: halmac_free_download_firmware fail(err=0x%x)\n",
__FUNCTION__, status);
err = -1;
goto resume_tx;
}
resume_tx:
#ifndef RTW_HALMAC_DLFW_MEM_NO_STOP_TX
/* 4. Driver resume TX if needed */
/* ToDo */
#endif /* !RTW_HALMAC_DLFW_MEM_NO_STOP_TX */
return err;
}
int rtw_halmac_dlfw_mem_from_file(struct dvobj_priv *d, u8 *fwpath, enum fw_mem mem)
{
u8 *fw = NULL;
u32 fwmaxsize = 0, size = 0;
int err = 0;
err = rtw_halmac_get_fw_max_size(d, &fwmaxsize);
if (err) {
RTW_ERR("%s: Fail to get Firmware MAX size(err=%d)\n", __FUNCTION__, err);
return -1;
}
fw = rtw_zmalloc(fwmaxsize);
if (!fw)
return -1;
size = rtw_retrieve_from_file(fwpath, fw, fwmaxsize);
if (size)
err = rtw_halmac_dlfw_mem(d, fw, size, mem);
else
err = -1;
rtw_mfree(fw, fwmaxsize);
/*fw = NULL;*/
return err;
}
/*
* Return:
* 0 Success
* -22 Invalid arguemnt
*/
int rtw_halmac_dlfw(struct dvobj_priv *d, u8 *fw, u32 fwsize)
{
PADAPTER adapter;
enum halmac_ret_status status;
u32 ok;
int err, err_ret = -1;
if (!fw || !fwsize)
return -22;
adapter = dvobj_get_primary_adapter(d);
/* re-download firmware */
if (rtw_is_hw_init_completed(adapter))
return download_fw(d, fw, fwsize, 1);
/* Download firmware before hal init */
/* Power on, download firmware and init mac */
ok = rtw_hal_power_on(adapter);
if (_FAIL == ok)
goto out;
err = download_fw(d, fw, fwsize, 0);
if (err) {
err_ret = err;
goto out;
}
err = init_mac_flow(d);
if (err)
goto out;
err = _send_general_info(d);
if (err)
goto out;
err_ret = 0;
out:
return err_ret;
}
int rtw_halmac_dlfw_from_file(struct dvobj_priv *d, u8 *fwpath)
{
u8 *fw = NULL;
u32 fwmaxsize = 0, size = 0;
int err = 0;
err = rtw_halmac_get_fw_max_size(d, &fwmaxsize);
if (err) {
RTW_ERR("%s: Fail to get Firmware MAX size(err=%d)\n", __FUNCTION__, err);
return -1;
}
fw = rtw_zmalloc(fwmaxsize);
if (!fw)
return -1;
size = rtw_retrieve_from_file(fwpath, fw, fwmaxsize);
if (size)
err = rtw_halmac_dlfw(d, fw, size);
else
err = -1;
rtw_mfree(fw, fwmaxsize);
/*fw = NULL;*/
return err;
}
/*
* Description:
* Power on/off BB/RF domain.
*
* Parameters:
* enable _TRUE/_FALSE for power on/off
*
* Return:
* 0 Success
* others Fail
*/
int rtw_halmac_phy_power_switch(struct dvobj_priv *d, u8 enable)
{
PADAPTER adapter;
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 on;
adapter = dvobj_get_primary_adapter(d);
halmac = dvobj_to_halmac(d);
if (!halmac)
return -1;
api = HALMAC_GET_API(halmac);
on = (enable == _TRUE) ? 1 : 0;
status = api->halmac_set_hw_value(halmac, HALMAC_HW_EN_BB_RF, &on);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
static u8 _is_fw_read_cmd_down(PADAPTER adapter, u8 msgbox_num)
{
u8 read_down = _FALSE;
int retry_cnts = 100;
u8 valid;
do {
valid = rtw_read8(adapter, REG_HMETFR) & BIT(msgbox_num);
if (0 == valid)
read_down = _TRUE;
else
rtw_msleep_os(1);
} while ((!read_down) && (retry_cnts--));
if (_FALSE == read_down)
RTW_WARN("%s, reg_1cc(%x), msg_box(%d)...\n", __func__, rtw_read8(adapter, REG_HMETFR), msgbox_num);
return read_down;
}
/**
* rtw_halmac_send_h2c() - Send H2C to firmware
* @d: struct dvobj_priv*
* @h2c: H2C data buffer, suppose to be 8 bytes
*
* Send H2C to firmware by message box register(0x1D0~0x1D3 & 0x1F0~0x1F3).
*
* Assume firmware be ready to accept H2C here, please check
* (hal->bFWReady == _TRUE) before call this function or make sure firmware is
* ready.
*
* Return: 0 if process OK, otherwise fail to send this H2C.
*/
int rtw_halmac_send_h2c(struct dvobj_priv *d, u8 *h2c)
{
PADAPTER adapter = dvobj_get_primary_adapter(d);
PHAL_DATA_TYPE hal = GET_HAL_DATA(adapter);
u8 h2c_box_num = 0;
u32 msgbox_addr = 0;
u32 msgbox_ex_addr = 0;
u32 h2c_cmd = 0;
u32 h2c_cmd_ex = 0;
int err = -1;
if (!h2c) {
RTW_WARN("%s: pbuf is NULL\n", __FUNCTION__);
return err;
}
if (rtw_is_surprise_removed(adapter)) {
RTW_WARN("%s: surprise removed\n", __FUNCTION__);
return err;
}
_enter_critical_mutex(&d->h2c_fwcmd_mutex, NULL);
/* pay attention to if race condition happened in H2C cmd setting */
h2c_box_num = hal->LastHMEBoxNum;
if (!_is_fw_read_cmd_down(adapter, h2c_box_num)) {
RTW_WARN(" fw read cmd failed...\n");
#ifdef DBG_CONFIG_ERROR_DETECT
hal->srestpriv.self_dect_fw = _TRUE;
hal->srestpriv.self_dect_fw_cnt++;
#endif /* DBG_CONFIG_ERROR_DETECT */
goto exit;
}
/* Write Ext command (byte 4~7) */
msgbox_ex_addr = REG_HMEBOX_E0 + (h2c_box_num * EX_MESSAGE_BOX_SIZE);
_rtw_memcpy((u8 *)(&h2c_cmd_ex), h2c + 4, EX_MESSAGE_BOX_SIZE);
h2c_cmd_ex = le32_to_cpu(h2c_cmd_ex);
rtw_write32(adapter, msgbox_ex_addr, h2c_cmd_ex);
/* Write command (byte 0~3) */
msgbox_addr = REG_HMEBOX0 + (h2c_box_num * MESSAGE_BOX_SIZE);
_rtw_memcpy((u8 *)(&h2c_cmd), h2c, 4);
h2c_cmd = le32_to_cpu(h2c_cmd);
rtw_write32(adapter, msgbox_addr, h2c_cmd);
/* update last msg box number */
hal->LastHMEBoxNum = (h2c_box_num + 1) % MAX_H2C_BOX_NUMS;
err = 0;
#ifdef DBG_H2C_CONTENT
RTW_INFO_DUMP("[H2C] - ", h2c, RTW_HALMAC_H2C_MAX_SIZE);
#endif
exit:
_exit_critical_mutex(&d->h2c_fwcmd_mutex, NULL);
return err;
}
/**
* rtw_halmac_c2h_handle() - Handle C2H for HALMAC
* @d: struct dvobj_priv*
* @c2h: Full C2H packet, including RX description and payload
* @size: Size(byte) of c2h
*
* Send C2H packet to HALMAC to process C2H packets, and the expected C2H ID is
* 0xFF. This function won't have any I/O, so caller doesn't have to call it in
* I/O safe place(ex. command thread).
*
* Please sure doesn't call this function in the same thread as someone is
* waiting HALMAC C2H ack, otherwise there is a deadlock happen.
*
* Return: 0 if process OK, otherwise no action for this C2H.
*/
int rtw_halmac_c2h_handle(struct dvobj_priv *d, u8 *c2h, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_c2h_info(mac, c2h, size);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
int rtw_halmac_get_available_efuse_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_efuse_available_size(mac, &val);
if (HALMAC_RET_SUCCESS != status)
return -1;
*size = val;
return 0;
}
int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_efuse_size(mac, &val);
if (HALMAC_RET_SUCCESS != status)
return -1;
*size = val;
return 0;
}
int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_feature_id id;
int ret;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
id = HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE;
ret = init_halmac_event(d, id, map, size);
if (ret)
return -1;
status = api->halmac_dump_efuse_map(mac, HALMAC_EFUSE_R_DRV);
if (HALMAC_RET_SUCCESS != status) {
free_halmac_event(d, id);
return -1;
}
ret = wait_halmac_event(d, id);
if (ret)
return -1;
return 0;
}
int rtw_halmac_read_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 v;
u32 i;
u8 *efuse = NULL;
u32 size = 0;
int err = 0;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
if (api->halmac_read_efuse) {
for (i = 0; i < cnt; i++) {
status = api->halmac_read_efuse(mac, offset + i, &v);
if (HALMAC_RET_SUCCESS != status)
return -1;
data[i] = v;
}
} else {
err = rtw_halmac_get_physical_efuse_size(d, &size);
if (err)
return -1;
efuse = rtw_zmalloc(size);
if (!efuse)
return -1;
err = rtw_halmac_read_physical_efuse_map(d, efuse, size);
if (err)
err = -1;
else
_rtw_memcpy(data, efuse + offset, cnt);
rtw_mfree(efuse, size);
}
return err;
}
int rtw_halmac_write_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 i;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
if (api->halmac_write_efuse == NULL)
return -1;
for (i = 0; i < cnt; i++) {
status = api->halmac_write_efuse(mac, offset + i, data[i]);
if (HALMAC_RET_SUCCESS != status)
return -1;
}
return 0;
}
int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *d, u32 *size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 val;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_logical_efuse_size(mac, &val);
if (HALMAC_RET_SUCCESS != status)
return -1;
*size = val;
return 0;
}
int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_feature_id id;
int ret;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
id = HALMAC_FEATURE_DUMP_LOGICAL_EFUSE;
ret = init_halmac_event(d, id, map, size);
if (ret)
return -1;
status = api->halmac_dump_logical_efuse_map(mac, HALMAC_EFUSE_R_DRV);
if (HALMAC_RET_SUCCESS != status) {
free_halmac_event(d, id);
return -1;
}
ret = wait_halmac_event(d, id);
if (ret)
return -1;
if (maskmap && masksize) {
struct halmac_pg_efuse_info pginfo;
pginfo.efuse_map = map;
pginfo.efuse_map_size = size;
pginfo.efuse_mask = maskmap;
pginfo.efuse_mask_size = masksize;
status = api->halmac_mask_logical_efuse(mac, &pginfo);
if (status != HALMAC_RET_SUCCESS)
RTW_WARN("%s: mask logical efuse FAIL!\n", __FUNCTION__);
}
return 0;
}
int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size, u8 *maskmap, u32 masksize)
{
struct halmac_adapter *mac;
struct halmac_api *api;
struct halmac_pg_efuse_info pginfo;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
pginfo.efuse_map = map;
pginfo.efuse_map_size = size;
pginfo.efuse_mask = maskmap;
pginfo.efuse_mask_size = masksize;
status = api->halmac_pg_efuse_by_map(mac, &pginfo, HALMAC_EFUSE_R_AUTO);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
int rtw_halmac_read_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 v;
u32 i;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
for (i = 0; i < cnt; i++) {
status = api->halmac_read_logical_efuse(mac, offset + i, &v);
if (HALMAC_RET_SUCCESS != status)
return -1;
data[i] = v;
}
return 0;
}
int rtw_halmac_write_logical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 i;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
for (i = 0; i < cnt; i++) {
status = api->halmac_write_logical_efuse(mac, offset + i, data[i]);
if (HALMAC_RET_SUCCESS != status)
return -1;
}
return 0;
}
int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *d, u32 offset, u32 cnt, u8 *data)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 i;
u8 bank = 1;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
for (i = 0; i < cnt; i++) {
status = api->halmac_write_efuse_bt(mac, offset + i, data[i], bank);
if (HALMAC_RET_SUCCESS != status) {
printk("%s: halmac_write_efuse_bt status = %d\n", __FUNCTION__, status);
return -1;
}
}
printk("%s: halmac_write_efuse_bt status = HALMAC_RET_SUCCESS %d\n", __FUNCTION__, status);
return 0;
}
int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *d, u8 *map, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
int bank = 1;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_dump_efuse_map_bt(mac, bank, size, map);
if (HALMAC_RET_SUCCESS != status) {
printk("%s: halmac_dump_efuse_map_bt fail!\n", __FUNCTION__);
return -1;
}
printk("%s: OK!\n", __FUNCTION__);
return 0;
}
static enum hal_fifo_sel _fifo_sel_drv2halmac(u8 fifo_sel)
{
switch (fifo_sel) {
case 0:
return HAL_FIFO_SEL_TX;
case 1:
return HAL_FIFO_SEL_RX;
case 2:
return HAL_FIFO_SEL_RSVD_PAGE;
case 3:
return HAL_FIFO_SEL_REPORT;
case 4:
return HAL_FIFO_SEL_LLT;
case 5:
return HAL_FIFO_SEL_RXBUF_FW;
}
return HAL_FIFO_SEL_RSVD_PAGE;
}
/*#define CONFIG_HALMAC_FIFO_DUMP*/
int rtw_halmac_dump_fifo(struct dvobj_priv *d, u8 fifo_sel, u32 addr, u32 size, u8 *buffer)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum hal_fifo_sel halmac_fifo_sel;
enum halmac_ret_status status;
u8 *pfifo_map = NULL;
u32 fifo_size = 0;
s8 ret = 0;/* 0:success, -1:error */
u8 mem_created = _FALSE;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
if ((size != 0) && (buffer == NULL))
return -1;
halmac_fifo_sel = _fifo_sel_drv2halmac(fifo_sel);
if ((size) && (buffer)) {
pfifo_map = buffer;
fifo_size = size;
} else {
fifo_size = api->halmac_get_fifo_size(mac, halmac_fifo_sel);
if (fifo_size)
pfifo_map = rtw_zvmalloc(fifo_size);
if (pfifo_map == NULL)
return -1;
mem_created = _TRUE;
}
status = api->halmac_dump_fifo(mac, halmac_fifo_sel, addr, fifo_size, pfifo_map);
if (HALMAC_RET_SUCCESS != status) {
ret = -1;
goto _exit;
}
#ifdef CONFIG_HALMAC_FIFO_DUMP
{
static const char * const fifo_sel_str[] = {
"TX", "RX", "RSVD_PAGE", "REPORT", "LLT", "RXBUF_FW"
};
RTW_INFO("%s FIFO DUMP [start_addr:0x%04x , size:%d]\n", fifo_sel_str[halmac_fifo_sel], addr, fifo_size);
RTW_INFO_DUMP("\n", pfifo_map, fifo_size);
RTW_INFO(" ==================================================\n");
}
#endif /* CONFIG_HALMAC_FIFO_DUMP */
_exit:
if ((mem_created == _TRUE) && pfifo_map)
rtw_vmfree(pfifo_map, fifo_size);
return ret;
}
/*
* rtw_halmac_rx_agg_switch() - Switch RX aggregation function and setting
* @d struct dvobj_priv *
* @enable _FALSE/_TRUE for disable/enable RX aggregation function
*
* This function could help to on/off bus RX aggregation function, and is only
* useful for SDIO and USB interface. Although only "enable" flag is brough in,
* some setting would be taken from other places, and they are from:
* [DMA aggregation]
* struct hal_com_data.rxagg_dma_size
* struct hal_com_data.rxagg_dma_timeout
* [USB aggregation] (only use for USB interface)
* struct hal_com_data.rxagg_usb_size
* struct hal_com_data.rxagg_usb_timeout
* If above values of size and timeout are both 0 means driver would not
* control the threshold setting and leave it to HALMAC handle.
*
* From HALMAC V1_04_04, driver force the size threshold be hard limit, and the
* rx size can not exceed the setting.
*
* Return 0 for success, otherwise fail.
*/
int rtw_halmac_rx_agg_switch(struct dvobj_priv *d, u8 enable)
{
struct _ADAPTER *adapter;
struct hal_com_data *hal;
struct halmac_adapter *halmac;
struct halmac_api *api;
struct halmac_rxagg_cfg rxaggcfg;
enum halmac_ret_status status;
adapter = dvobj_get_primary_adapter(d);
hal = GET_HAL_DATA(adapter);
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
_rtw_memset((void *)&rxaggcfg, 0, sizeof(rxaggcfg));
rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
/*
* Always enable size limit to avoid rx size exceed
* driver defined size.
*/
rxaggcfg.threshold.size_limit_en = 1;
#ifdef RTW_RX_AGGREGATION
if (_TRUE == enable) {
#ifdef CONFIG_SDIO_HCI
rxaggcfg.mode = HALMAC_RX_AGG_MODE_DMA;
rxaggcfg.threshold.drv_define = 0;
if (hal->rxagg_dma_size || hal->rxagg_dma_timeout) {
rxaggcfg.threshold.drv_define = 1;
rxaggcfg.threshold.timeout = hal->rxagg_dma_timeout;
rxaggcfg.threshold.size = hal->rxagg_dma_size;
RTW_INFO("%s: RX aggregation threshold: "
"timeout=%u size=%u\n",
__FUNCTION__,
hal->rxagg_dma_timeout,
hal->rxagg_dma_size);
}
#elif defined(CONFIG_USB_HCI)
switch (hal->rxagg_mode) {
case RX_AGG_DISABLE:
rxaggcfg.mode = HALMAC_RX_AGG_MODE_NONE;
break;
case RX_AGG_DMA:
rxaggcfg.mode = HALMAC_RX_AGG_MODE_DMA;
if (hal->rxagg_dma_size || hal->rxagg_dma_timeout) {
rxaggcfg.threshold.drv_define = 1;
rxaggcfg.threshold.timeout = hal->rxagg_dma_timeout;
rxaggcfg.threshold.size = hal->rxagg_dma_size;
}
break;
case RX_AGG_USB:
case RX_AGG_MIX:
rxaggcfg.mode = HALMAC_RX_AGG_MODE_USB;
if (hal->rxagg_usb_size || hal->rxagg_usb_timeout) {
rxaggcfg.threshold.drv_define = 1;
rxaggcfg.threshold.timeout = hal->rxagg_usb_timeout;
rxaggcfg.threshold.size = hal->rxagg_usb_size;
}
break;
}
#endif /* CONFIG_USB_HCI */
}
#endif /* RTW_RX_AGGREGATION */
status = api->halmac_cfg_rx_aggregation(halmac, &rxaggcfg);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pbuf, u32 size)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_adapter *halmac = dvobj_to_halmac(dvobj);
struct halmac_api *api = HALMAC_GET_API(halmac);
status = api->halmac_dl_drv_rsvd_page(halmac, pg_offset, pbuf, size);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
/*
* Description
* Fill following spec info from HALMAC API:
* sec_cam_ent_num
*
* Return
* 0 Success
* others Fail
*/
int rtw_halmac_fill_hal_spec(struct dvobj_priv *dvobj, struct hal_spec_t *spec)
{
enum halmac_ret_status status;
struct halmac_adapter *halmac;
struct halmac_api *api;
u8 cam = 0; /* Security Cam Entry Number */
halmac = dvobj_to_halmac(dvobj);
api = HALMAC_GET_API(halmac);
/* Prepare data from HALMAC */
status = api->halmac_get_hw_value(halmac, HALMAC_HW_CAM_ENTRY_NUM, &cam);
if (status != HALMAC_RET_SUCCESS)
return -1;
/* Fill data to hal_spec_t */
spec->sec_cam_ent_num = cam;
return 0;
}
int rtw_halmac_p2pps(struct dvobj_priv *dvobj, struct hal_p2p_ps_para *pp2p_ps_para)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_adapter *halmac = dvobj_to_halmac(dvobj);
struct halmac_api *api = HALMAC_GET_API(halmac);
struct halmac_p2pps halmac_p2p_ps;
(&halmac_p2p_ps)->offload_en = pp2p_ps_para->offload_en;
(&halmac_p2p_ps)->role = pp2p_ps_para->role;
(&halmac_p2p_ps)->ctwindow_en = pp2p_ps_para->ctwindow_en;
(&halmac_p2p_ps)->noa_en = pp2p_ps_para->noa_en;
(&halmac_p2p_ps)->noa_sel = pp2p_ps_para->noa_sel;
(&halmac_p2p_ps)->all_sta_sleep = pp2p_ps_para->all_sta_sleep;
(&halmac_p2p_ps)->discovery = pp2p_ps_para->discovery;
(&halmac_p2p_ps)->disable_close_rf = pp2p_ps_para->disable_close_rf;
(&halmac_p2p_ps)->p2p_port_id = _hw_port_drv2halmac(pp2p_ps_para->p2p_port_id);
(&halmac_p2p_ps)->p2p_group = pp2p_ps_para->p2p_group;
(&halmac_p2p_ps)->p2p_macid = pp2p_ps_para->p2p_macid;
(&halmac_p2p_ps)->ctwindow_length = pp2p_ps_para->ctwindow_length;
(&halmac_p2p_ps)->noa_duration_para = pp2p_ps_para->noa_duration_para;
(&halmac_p2p_ps)->noa_interval_para = pp2p_ps_para->noa_interval_para;
(&halmac_p2p_ps)->noa_start_time_para = pp2p_ps_para->noa_start_time_para;
(&halmac_p2p_ps)->noa_count_para = pp2p_ps_para->noa_count_para;
status = api->halmac_p2pps(halmac, (&halmac_p2p_ps));
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
/**
* rtw_halmac_iqk() - Run IQ Calibration
* @d: struct dvobj_priv*
* @clear: IQK parameters
* @segment: IQK parameters
*
* Process IQ Calibration(IQK).
*
* Rteurn: 0 for OK, otherwise fail.
*/
int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_feature_id id;
struct halmac_iqk_para para;
int ret;
u8 retry = 3;
u8 delay = 1; /* ms */
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
id = HALMAC_FEATURE_IQK;
ret = init_halmac_event(d, id, NULL, 0);
if (ret)
return -1;
para.clear = clear;
para.segment_iqk = segment;
do {
status = api->halmac_start_iqk(mac, ¶);
if (status != HALMAC_RET_BUSY_STATE)
break;
RTW_WARN("%s: Fail to start IQK, status is BUSY! retry=%d\n", __FUNCTION__, retry);
if (!retry)
break;
retry--;
rtw_msleep_os(delay);
} while (1);
if (status != HALMAC_RET_SUCCESS) {
free_halmac_event(d, id);
return -1;
}
ret = wait_halmac_event(d, id);
if (ret)
return -1;
return 0;
}
static inline u32 _phy_parameter_val_drv2halmac(u32 val, u8 msk_en, u32 msk)
{
if (!msk_en)
return val;
return (val << bitshift(msk));
}
static int _phy_parameter_drv2halmac(struct rtw_phy_parameter *para, struct halmac_phy_parameter_info *info)
{
if (!para || !info)
return -1;
_rtw_memset(info, 0, sizeof(*info));
switch (para->cmd) {
case 0:
/* MAC register */
switch (para->data.mac.size) {
case 1:
info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W8;
break;
case 2:
info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W16;
break;
default:
info->cmd_id = HALMAC_PARAMETER_CMD_MAC_W32;
break;
}
info->content.MAC_REG_W.value = _phy_parameter_val_drv2halmac(
para->data.mac.value,
para->data.mac.msk_en,
para->data.mac.msk);
info->content.MAC_REG_W.msk = para->data.mac.msk;
info->content.MAC_REG_W.offset = para->data.mac.offset;
info->content.MAC_REG_W.msk_en = para->data.mac.msk_en;
break;
case 1:
/* BB register */
switch (para->data.bb.size) {
case 1:
info->cmd_id = HALMAC_PARAMETER_CMD_BB_W8;
break;
case 2:
info->cmd_id = HALMAC_PARAMETER_CMD_BB_W16;
break;
default:
info->cmd_id = HALMAC_PARAMETER_CMD_BB_W32;
break;
}
info->content.BB_REG_W.value = _phy_parameter_val_drv2halmac(
para->data.bb.value,
para->data.bb.msk_en,
para->data.bb.msk);
info->content.BB_REG_W.msk = para->data.bb.msk;
info->content.BB_REG_W.offset = para->data.bb.offset;
info->content.BB_REG_W.msk_en = para->data.bb.msk_en;
break;
case 2:
/* RF register */
info->cmd_id = HALMAC_PARAMETER_CMD_RF_W;
info->content.RF_REG_W.value = _phy_parameter_val_drv2halmac(
para->data.rf.value,
para->data.rf.msk_en,
para->data.rf.msk);
info->content.RF_REG_W.msk = para->data.rf.msk;
info->content.RF_REG_W.offset = para->data.rf.offset;
info->content.RF_REG_W.msk_en = para->data.rf.msk_en;
info->content.RF_REG_W.rf_path = para->data.rf.path;
break;
case 3:
/* Delay register */
if (para->data.delay.unit == 0)
info->cmd_id = HALMAC_PARAMETER_CMD_DELAY_US;
else
info->cmd_id = HALMAC_PARAMETER_CMD_DELAY_MS;
info->content.DELAY_TIME.delay_time = para->data.delay.value;
break;
case 0xFF:
/* Latest(End) command */
info->cmd_id = HALMAC_PARAMETER_CMD_END;
break;
default:
return -1;
}
return 0;
}
/**
* rtw_halmac_cfg_phy_para() - Register(Phy parameter) configuration
* @d: struct dvobj_priv*
* @para: phy parameter
*
* Configure registers by firmware using H2C/C2H mechanism.
* The latest command should be para->cmd==0xFF(End command) to finish all
* processes.
*
* Return: 0 for OK, otherwise fail.
*/
int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_feature_id id;
struct halmac_phy_parameter_info info;
u8 full_fifo;
int err, ret;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
id = HALMAC_FEATURE_CFG_PARA;
full_fifo = 1; /* ToDo: How to deciede? */
ret = 0;
err = _phy_parameter_drv2halmac(para, &info);
if (err)
return -1;
err = init_halmac_event(d, id, NULL, 0);
if (err)
return -1;
status = api->halmac_cfg_parameter(mac, &info, full_fifo);
if (info.cmd_id == HALMAC_PARAMETER_CMD_END) {
if (status == HALMAC_RET_SUCCESS) {
err = wait_halmac_event(d, id);
if (err)
ret = -1;
} else {
free_halmac_event(d, id);
ret = -1;
RTW_ERR("%s: Fail to send END of cfg parameter, status is 0x%x!\n", __FUNCTION__, status);
}
} else {
if (status == HALMAC_RET_PARA_SENDING) {
err = wait_halmac_event(d, id);
if (err)
ret = -1;
} else {
free_halmac_event(d, id);
if (status != HALMAC_RET_SUCCESS) {
ret = -1;
RTW_ERR("%s: Fail to cfg parameter, status is 0x%x!\n", __FUNCTION__, status);
}
}
}
return ret;
}
static enum halmac_wlled_mode _led_mode_drv2halmac(u8 drv_mode)
{
enum halmac_wlled_mode halmac_mode;
switch (drv_mode) {
case 1:
halmac_mode = HALMAC_WLLED_MODE_TX;
break;
case 2:
halmac_mode = HALMAC_WLLED_MODE_RX;
break;
case 3:
halmac_mode = HALMAC_WLLED_MODE_SW_CTRL;
break;
case 0:
default:
halmac_mode = HALMAC_WLLED_MODE_TRX;
break;
}
return halmac_mode;
}
/**
* rtw_halmac_led_cfg() - Configure Hardware LED Mode
* @d: struct dvobj_priv*
* @enable: enable or disable LED function
* 0: disable
* 1: enable
* @mode: WLan LED mode (valid when enable==1)
* 0: Blink when TX(transmit packet) and RX(receive packet)
* 1: Blink when TX only
* 2: Blink when RX only
* 3: Software control
*
* Configure hardware WLan LED mode.
* If want to change LED mode after enabled, need to disable LED first and
* enable again to set new mode.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_led_cfg(struct dvobj_priv *d, u8 enable, u8 mode)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_wlled_mode led_mode;
enum halmac_ret_status status;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
if (enable) {
status = api->halmac_pinmux_set_func(halmac,
HALMAC_GPIO_FUNC_WL_LED);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: pinmux set fail!(0x%x)\n",
__FUNCTION__, status);
return -1;
}
led_mode = _led_mode_drv2halmac(mode);
status = api->halmac_pinmux_wl_led_mode(halmac, led_mode);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: mode set fail!(0x%x)\n",
__FUNCTION__, status);
return -1;
}
} else {
/* Change LED to software control and turn off */
api->halmac_pinmux_wl_led_mode(halmac,
HALMAC_WLLED_MODE_SW_CTRL);
api->halmac_pinmux_wl_led_sw_ctrl(halmac, 0);
status = api->halmac_pinmux_free_func(halmac,
HALMAC_GPIO_FUNC_WL_LED);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: pinmux free fail!(0x%x)\n",
__FUNCTION__, status);
return -1;
}
}
return 0;
}
/**
* rtw_halmac_led_switch() - Turn Hardware LED on/off
* @d: struct dvobj_priv*
* @on: LED light or not
* 0: Off
* 1: On(Light)
*
* Turn Hardware WLan LED On/Off.
* Before use this function, user should call rtw_halmac_led_ctrl() to switch
* mode to "software control(3)" first, otherwise control would fail.
* The interval between on and off must be longer than 1 ms, or the LED would
* keep light or dark only.
* Ex. Turn off LED at first, turn on after 0.5ms and turn off again after
* 0.5ms. The LED during this flow will only keep dark, and miss the turn on
* operation between two turn off operations.
*/
void rtw_halmac_led_switch(struct dvobj_priv *d, u8 on)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
api->halmac_pinmux_wl_led_sw_ctrl(halmac, on);
}
/**
* rtw_halmac_bt_wake_cfg() - Configure BT wake host function
* @d: struct dvobj_priv*
* @enable: enable or disable BT wake host function
* 0: disable
* 1: enable
*
* Configure pinmux to allow BT to control BT wake host pin.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_bt_wake_cfg(struct dvobj_priv *d, u8 enable)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
if (enable) {
status = api->halmac_pinmux_set_func(halmac,
HALMAC_GPIO_FUNC_BT_HOST_WAKE1);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: pinmux set BT_HOST_WAKE1 fail!(0x%x)\n",
__FUNCTION__, status);
return -1;
}
} else {
status = api->halmac_pinmux_free_func(halmac,
HALMAC_GPIO_FUNC_BT_HOST_WAKE1);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: pinmux free BT_HOST_WAKE1 fail!(0x%x)\n",
__FUNCTION__, status);
return -1;
}
}
return 0;
}
#ifdef CONFIG_PNO_SUPPORT
/**
* _halmac_scanoffload() - Switch channel by firmware during scanning
* @d: struct dvobj_priv*
* @enable: 1: enable, 0: disable
* @nlo: 1: nlo mode (no c2h event), 0: normal mode
* @ssid: ssid of probe request
* @ssid_len: ssid length
*
* Switch Channel and Send Porbe Request Offloaded by FW
*
* Rteurn 0 for OK, otherwise fail.
*/
static int _halmac_scanoffload(struct dvobj_priv *d, u32 enable, u8 nlo,
u8 *ssid, u8 ssid_len)
{
struct _ADAPTER *adapter;
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
struct halmac_ch_info ch_info;
struct halmac_ch_switch_option cs_option;
struct mlme_ext_priv *pmlmeext;
enum halmac_feature_id id_update, id_ch_sw;
struct halmac_indicator *indicator, *tbl;
int err = 0;
u8 probereq[64];
u32 len = 0;
int i = 0;
struct pno_ssid pnossid;
struct rf_ctl_t *rfctl = NULL;
struct _RT_CHANNEL_INFO *ch_set;
tbl = d->hmpriv.indicator;
adapter = dvobj_get_primary_adapter(d);
mac = dvobj_to_halmac(d);
if (!mac)
return -1;
api = HALMAC_GET_API(mac);
id_update = HALMAC_FEATURE_UPDATE_PACKET;
id_ch_sw = HALMAC_FEATURE_CHANNEL_SWITCH;
pmlmeext = &(adapter->mlmeextpriv);
rfctl = adapter_to_rfctl(adapter);
ch_set = rfctl->channel_set;
RTW_INFO("%s: %s scanoffload, mode: %s\n",
__FUNCTION__, enable?"Enable":"Disable",
nlo?"PNO/NLO":"Normal");
if (enable) {
_rtw_memset(probereq, 0, sizeof(probereq));
_rtw_memset(&pnossid, 0, sizeof(pnossid));
if (ssid) {
if (ssid_len > sizeof(pnossid.SSID)) {
RTW_ERR("%s: SSID length(%d) is too long(>%d)!!\n",
__FUNCTION__, ssid_len, sizeof(pnossid.SSID));
return -1;
}
pnossid.SSID_len = ssid_len;
_rtw_memcpy(pnossid.SSID, ssid, ssid_len);
}
rtw_hal_construct_ProbeReq(adapter, probereq, &len, &pnossid);
if (!nlo) {
err = init_halmac_event(d, id_update, NULL, 0);
if (err)
return -1;
}
status = api->halmac_update_packet(mac, HALMAC_PACKET_PROBE_REQ,
probereq, len);
if (status != HALMAC_RET_SUCCESS) {
if (!nlo)
free_halmac_event(d, id_update);
RTW_ERR("%s: halmac_update_packet FAIL(%d)!!\n",
__FUNCTION__, status);
return -1;
}
if (!nlo) {
err = wait_halmac_event(d, id_update);
if (err)
RTW_ERR("%s: wait update packet FAIL(%d)!!\n",
__FUNCTION__, err);
}
api->halmac_clear_ch_info(mac);
for (i = 0; i < rfctl->max_chan_nums && ch_set[i].ChannelNum != 0; i++) {
_rtw_memset(&ch_info, 0, sizeof(ch_info));
ch_info.extra_info = 0;
ch_info.channel = ch_set[i].ChannelNum;
ch_info.bw = HALMAC_BW_20;
ch_info.pri_ch_idx = HALMAC_CH_IDX_1;
ch_info.action_id = HALMAC_CS_ACTIVE_SCAN;
ch_info.timeout = 1;
status = api->halmac_add_ch_info(mac, &ch_info);
if (status != HALMAC_RET_SUCCESS) {
RTW_ERR("%s: add_ch_info FAIL(%d)!!\n",
__FUNCTION__, status);
return -1;
}
}
/* set channel switch option */
_rtw_memset(&cs_option, 0, sizeof(cs_option));
cs_option.dest_bw = HALMAC_BW_20;
cs_option.periodic_option = HALMAC_CS_PERIODIC_2_PHASE;
cs_option.dest_pri_ch_idx = HALMAC_CH_IDX_UNDEFINE;
cs_option.tsf_low = 0;
cs_option.switch_en = 1;
cs_option.dest_ch_en = 1;
cs_option.absolute_time_en = 0;
cs_option.dest_ch = 1;
cs_option.normal_period = 5;
cs_option.normal_period_sel = 0;
cs_option.normal_cycle = 10;
cs_option.phase_2_period = 1;
cs_option.phase_2_period_sel = 1;
/* nlo is for wow fw, 1: no c2h response */
cs_option.nlo_en = nlo;
if (!nlo) {
err = init_halmac_event(d, id_ch_sw, NULL, 0);
if (err)
return -1;
}
status = api->halmac_ctrl_ch_switch(mac, &cs_option);
if (status != HALMAC_RET_SUCCESS) {
if (!nlo)
free_halmac_event(d, id_ch_sw);
RTW_ERR("%s: halmac_ctrl_ch_switch FAIL(%d)!!\n",
__FUNCTION__, status);
return -1;
}
if (!nlo) {
err = wait_halmac_event(d, id_ch_sw);
if (err)
RTW_ERR("%s: wait ctrl_ch_switch FAIL(%d)!!\n",
__FUNCTION__, err);
}
} else {
api->halmac_clear_ch_info(mac);
_rtw_memset(&cs_option, 0, sizeof(cs_option));
cs_option.switch_en = 0;
if (!nlo) {
err = init_halmac_event(d, id_ch_sw, NULL, 0);
if (err)
return -1;
}
status = api->halmac_ctrl_ch_switch(mac, &cs_option);
if (status != HALMAC_RET_SUCCESS) {
if (!nlo)
free_halmac_event(d, id_ch_sw);
RTW_ERR("%s: halmac_ctrl_ch_switch FAIL(%d)!!\n",
__FUNCTION__, status);
return -1;
}
if (!nlo) {
err = wait_halmac_event(d, id_ch_sw);
if (err)
RTW_ERR("%s: wait ctrl_ch_switch FAIL(%d)!!\n",
__FUNCTION__, err);
}
}
return 0;
}
/**
* rtw_halmac_pno_scanoffload() - Control firmware scan AP function for PNO
* @d: struct dvobj_priv*
* @enable: 1: enable, 0: disable
*
* Switch firmware scan AP function for PNO(prefer network offload) or
* NLO(network list offload).
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_pno_scanoffload(struct dvobj_priv *d, u32 enable)
{
return _halmac_scanoffload(d, enable, 1, NULL, 0);
}
#endif /* CONFIG_PNO_SUPPORT */
#ifdef CONFIG_SDIO_HCI
/*
* Description:
* Update queue allocated page number to driver
*
* Parameter:
* d pointer to struct dvobj_priv of driver
*
* Rteurn:
* 0 Success, "page" is valid.
* others Fail, "page" is invalid.
*/
int rtw_halmac_query_tx_page_num(struct dvobj_priv *d)
{
PADAPTER adapter;
struct halmacpriv *hmpriv;
struct halmac_adapter *halmac;
struct halmac_api *api;
struct halmac_rqpn_map rqpn;
enum halmac_dma_mapping dmaqueue;
struct halmac_txff_allocation fifosize;
enum halmac_ret_status status;
u8 i;
adapter = dvobj_get_primary_adapter(d);
hmpriv = &d->hmpriv;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
_rtw_memset((void *)&rqpn, 0, sizeof(rqpn));
_rtw_memset((void *)&fifosize, 0, sizeof(fifosize));
status = api->halmac_get_hw_value(halmac, HALMAC_HW_RQPN_MAPPING, &rqpn);
if (status != HALMAC_RET_SUCCESS)
return -1;
status = api->halmac_get_hw_value(halmac, HALMAC_HW_TXFF_ALLOCATION, &fifosize);
if (status != HALMAC_RET_SUCCESS)
return -1;
for (i = 0; i < HW_QUEUE_ENTRY; i++) {
hmpriv->txpage[i] = 0;
/* Driver index mapping to HALMAC DMA queue */
dmaqueue = HALMAC_DMA_MAPPING_UNDEFINE;
switch (i) {
case VO_QUEUE_INX:
dmaqueue = rqpn.dma_map_vo;
break;
case VI_QUEUE_INX:
dmaqueue = rqpn.dma_map_vi;
break;
case BE_QUEUE_INX:
dmaqueue = rqpn.dma_map_be;
break;
case BK_QUEUE_INX:
dmaqueue = rqpn.dma_map_bk;
break;
case MGT_QUEUE_INX:
dmaqueue = rqpn.dma_map_mg;
break;
case HIGH_QUEUE_INX:
dmaqueue = rqpn.dma_map_hi;
break;
case BCN_QUEUE_INX:
case TXCMD_QUEUE_INX:
/* Unlimited */
hmpriv->txpage[i] = 0xFFFF;
continue;
}
switch (dmaqueue) {
case HALMAC_DMA_MAPPING_EXTRA:
hmpriv->txpage[i] = fifosize.extra_queue_pg_num;
break;
case HALMAC_DMA_MAPPING_LOW:
hmpriv->txpage[i] = fifosize.low_queue_pg_num;
break;
case HALMAC_DMA_MAPPING_NORMAL:
hmpriv->txpage[i] = fifosize.normal_queue_pg_num;
break;
case HALMAC_DMA_MAPPING_HIGH:
hmpriv->txpage[i] = fifosize.high_queue_pg_num;
break;
case HALMAC_DMA_MAPPING_UNDEFINE:
break;
}
hmpriv->txpage[i] += fifosize.pub_queue_pg_num;
}
return 0;
}
/*
* Description:
* Get specific queue allocated page number
*
* Parameter:
* d pointer to struct dvobj_priv of driver
* queue target queue to query, VO/VI/BE/BK/.../TXCMD_QUEUE_INX
* page return allocated page number
*
* Rteurn:
* 0 Success, "page" is valid.
* others Fail, "page" is invalid.
*/
int rtw_halmac_get_tx_queue_page_num(struct dvobj_priv *d, u8 queue, u32 *page)
{
*page = 0;
if (queue < HW_QUEUE_ENTRY)
*page = d->hmpriv.txpage[queue];
return 0;
}
/*
* Return:
* address for SDIO command
*/
u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *d, u8 *desc, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 addr;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_sdio_tx_addr(mac, desc, size, &addr);
if (HALMAC_RET_SUCCESS != status)
return 0;
return addr;
}
int rtw_halmac_sdio_tx_allowed(struct dvobj_priv *d, u8 *buf, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_tx_allowed_sdio(mac, buf, size);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
u32 rtw_halmac_sdio_get_rx_addr(struct dvobj_priv *d, u8 *seq)
{
u8 id;
#define RTW_SDIO_ADDR_RX_RX0FF_PRFIX 0x0E000
#define RTW_SDIO_ADDR_RX_RX0FF_GEN(a) (RTW_SDIO_ADDR_RX_RX0FF_PRFIX|(a&0x3))
id = *seq;
(*seq)++;
return RTW_SDIO_ADDR_RX_RX0FF_GEN(id);
}
int rtw_halmac_sdio_set_tx_format(struct dvobj_priv *d, enum halmac_sdio_tx_format format)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_set_hw_value(mac, HALMAC_HW_SDIO_TX_FORMAT, &format);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
#ifdef CONFIG_SDIO_MONITOR
u32 rtw_halmac_sdio_get_int_lat(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 int_lat = 0;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_hw_value(mac, HALMAC_HW_SDIO_INT_LAT, &int_lat);
if (HALMAC_RET_SUCCESS != status)
return 0;
return int_lat;
}
u32 rtw_halmac_sdio_get_lk_cnt(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 clk_cnt = 0;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_hw_value(mac, HALMAC_HW_SDIO_CLK_CNT, &clk_cnt);
if (HALMAC_RET_SUCCESS != status)
return 0;
return clk_cnt;
}
int rtw_halmac_sdio_set_wt_en(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 enable = _TRUE;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_set_hw_value(mac, HALMAC_HW_SDIO_WT_EN, &enable);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
int rtw_halmac_set_sdio_clk_monitor(struct dvobj_priv *d, u8 clk_moni_mode)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u32 halmac_clk_moni_mode = 0;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
switch (clk_moni_mode) {
case SDIO_MONITOR_MODE_SDIO_CLK_5US:
halmac_clk_moni_mode = HALMAC_MONITOR_5US;
break;
case SDIO_MONITOR_MODE_SDIO_CLK_50US:
halmac_clk_moni_mode = HALMAC_MONITOR_50US;
break;
case SDIO_MONITOR_MODE_SDIO_CLK_9MS:
halmac_clk_moni_mode = HALMAC_MONITOR_9MS;
break;
}
status = api->halmac_set_hw_value(mac, HALMAC_HW_SDIO_CLK_MONITOR, &halmac_clk_moni_mode);
if (HALMAC_RET_SUCCESS != status)
return -1;
return 0;
}
#endif
#endif /* CONFIG_SDIO_HCI */
#ifdef CONFIG_USB_HCI
u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *d, u8 *buf, u32 size)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 bulkout_id;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_get_usb_bulkout_id(mac, buf, size, &bulkout_id);
if (HALMAC_RET_SUCCESS != status)
return 0;
return bulkout_id;
}
/**
* rtw_halmac_usb_get_txagg_desc_num() - MAX descriptor number in one bulk for TX
* @d: struct dvobj_priv*
* @size: TX FIFO size, unit is byte.
*
* Get MAX descriptor number in one bulk out from HALMAC.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_usb_get_txagg_desc_num(struct dvobj_priv *d, u8 *num)
{
struct halmac_adapter *halmac;
struct halmac_api *api;
enum halmac_ret_status status;
u8 val = 0;
halmac = dvobj_to_halmac(d);
api = HALMAC_GET_API(halmac);
status = api->halmac_get_hw_value(halmac, HALMAC_HW_USB_TXAGG_DESC_NUM, &val);
if (status != HALMAC_RET_SUCCESS)
return -1;
*num = val;
return 0;
}
static inline enum halmac_usb_mode _usb_mode_drv2halmac(enum RTW_USB_SPEED usb_mode)
{
enum halmac_usb_mode halmac_usb_mode = HALMAC_USB_MODE_U2;
switch (usb_mode) {
case RTW_USB_SPEED_2:
halmac_usb_mode = HALMAC_USB_MODE_U2;
break;
case RTW_USB_SPEED_3:
halmac_usb_mode = HALMAC_USB_MODE_U3;
break;
default:
halmac_usb_mode = HALMAC_USB_MODE_U2;
break;
}
return halmac_usb_mode;
}
u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode)
{
PADAPTER adapter;
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
enum halmac_usb_mode halmac_usb_mode;
adapter = dvobj_get_primary_adapter(d);
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
halmac_usb_mode = _usb_mode_drv2halmac(usb_mode);
status = api->halmac_set_hw_value(mac, HALMAC_HW_USB_MODE, (void *)&halmac_usb_mode);
if (HALMAC_RET_SUCCESS != status)
return _FAIL;
return _SUCCESS;
}
#endif /* CONFIG_USB_HCI */
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
int rtw_halmac_bf_add_mu_bfer(struct dvobj_priv *d, u16 paid, u16 csi_para,
u16 my_aid, enum halmac_csi_seg_len sel, u8 *addr)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
struct halmac_mu_bfer_init_para param;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
_rtw_memset(¶m, 0, sizeof(param));
param.paid = paid;
param.csi_para = csi_para;
param.my_aid = my_aid;
param.csi_length_sel = sel;
_rtw_memcpy(param.bfer_address.addr, addr, 6);
status = api->halmac_mu_bfer_entry_init(mac, ¶m);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
int rtw_halmac_bf_del_mu_bfer(struct dvobj_priv *d)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_mu_bfer_entry_del(mac);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
int rtw_halmac_bf_cfg_sounding(struct dvobj_priv *d,
enum halmac_snd_role role, enum halmac_data_rate rate)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_cfg_sounding(mac, role, rate);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
int rtw_halmac_bf_del_sounding(struct dvobj_priv *d,
enum halmac_snd_role role)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_del_sounding(mac, role);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
/**
* rtw_halmac_bf_cfg_csi_rate() - Config data rate for CSI report by CSSI
* @d: struct dvobj_priv*
* @rssi: RSSI vlaue, unit is percentage (0~100).
* @current_rate: Current CSI frame rate
* Valid value example
* 0 CCK 1M
* 3 CCK 11M
* 4 OFDM 6M
* and so on
* @fixrate_en: Enable to fix CSI frame in VHT rate, otherwise legacy OFDM rate.
* The value "0" for disable, otheriwse enable.
* @new_rate: Return new data rate, and value range is the same as current_rate
* @bmp_ofdm54: Return to suggest enabling OFDM 54M for CSI report frame or not,
* The valid values and meanings are:
* 0x00 disable
* 0x01 enable
* 0xFF Keep current setting
*
* According RSSI to config data rate for CSI report frame of Beamforming.
*
* Rteurn 0 for OK, otherwise fail.
*/
int rtw_halmac_bf_cfg_csi_rate(struct dvobj_priv *d,
u8 rssi, u8 current_rate, u8 fixrate_en,
u8 *new_rate, u8 *bmp_ofdm54)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
status = api->halmac_cfg_csi_rate(mac,
rssi, current_rate, fixrate_en, new_rate, bmp_ofdm54);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
int rtw_halmac_bf_cfg_mu_mimo(struct dvobj_priv *d, enum halmac_snd_role role,
u8 *sounding_sts, u16 grouping_bitmap, u8 mu_tx_en,
u32 *given_gid_tab, u32 *given_user_pos)
{
struct halmac_adapter *mac;
struct halmac_api *api;
enum halmac_ret_status status;
struct halmac_cfg_mumimo_para param;
mac = dvobj_to_halmac(d);
api = HALMAC_GET_API(mac);
_rtw_memset(¶m, 0, sizeof(param));
param.role = role;
param.grouping_bitmap = grouping_bitmap;
param.mu_tx_en = mu_tx_en;
if (sounding_sts)
_rtw_memcpy(param.sounding_sts, sounding_sts, 6);
if (given_gid_tab)
_rtw_memcpy(param.given_gid_tab, given_gid_tab, 8);
if (given_user_pos)
_rtw_memcpy(param.given_user_pos, given_user_pos, 16);
status = api->halmac_cfg_mumimo(mac, ¶m);
if (status != HALMAC_RET_SUCCESS)
return -1;
return 0;
}
#endif /* RTW_BEAMFORMING_VERSION_2 */
#endif /* CONFIG_BEAMFORMING */
================================================
FILE: hal/hal_halmac.h
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef _HAL_HALMAC_H_
#define _HAL_HALMAC_H_
#include /* adapter_to_dvobj(), struct intf_hdl and etc. */
#include /* struct hal_spec_t */
#include "halmac/halmac_api.h" /* struct halmac_adapter* and etc. */
/* HALMAC Definition for Driver */
#define RTW_HALMAC_H2C_MAX_SIZE 8
#define RTW_HALMAC_BA_SSN_RPT_SIZE 4
#define dvobj_set_halmac(d, mac) ((d)->halmac = (mac))
#define dvobj_to_halmac(d) ((struct halmac_adapter *)((d)->halmac))
#define adapter_to_halmac(p) dvobj_to_halmac(adapter_to_dvobj(p))
/* for H2C cmd */
#define MAX_H2C_BOX_NUMS 4
#define MESSAGE_BOX_SIZE 4
#define EX_MESSAGE_BOX_SIZE 4
typedef enum _RTW_HALMAC_MODE {
RTW_HALMAC_MODE_NORMAL,
RTW_HALMAC_MODE_WIFI_TEST,
} RTW_HALMAC_MODE;
union rtw_phy_para_data {
struct _mac {
u32 value; /* value to be set in bit mask(msk) */
u32 msk; /* bit mask */
u16 offset; /* address */
u8 msk_en; /* 0/1 for msk invalid/valid */
u8 size; /* Unit is bytes, and value should be 1/2/4 */
} mac;
struct _bb {
u32 value;
u32 msk;
u16 offset;
u8 msk_en;
u8 size;
} bb;
struct _rf {
u32 value;
u32 msk;
u8 offset;
u8 msk_en;
/*
* 0: path A
* 1: path B
* 2: path C
* 3: path D
*/
u8 path;
} rf;
struct _delay {
/*
* 0: microsecond (us)
* 1: millisecond (ms)
*/
u8 unit;
u16 value;
} delay;
};
struct rtw_phy_parameter {
/*
* 0: MAC register
* 1: BB register
* 2: RF register
* 3: Delay
* 0xFF: Latest(End) command
*/
u8 cmd;
union rtw_phy_para_data data;
};
struct rtw_halmac_bcn_ctrl {
u8 rx_bssid_fit:1; /* 0:HW handle beacon, 1:ignore */
u8 txbcn_rpt:1; /* Enable TXBCN report in ad hoc and AP mode */
u8 tsf_update:1; /* Update TSF when beacon or probe response */
u8 enable_bcn:1; /* Enable beacon related functions */
u8 rxbcn_rpt:1; /* Enable RXBCNOK report */
u8 p2p_ctwin:1; /* Enable P2P CTN WINDOWS function */
u8 p2p_bcn_area:1; /* Enable P2P BCN area on function */
};
extern struct halmac_platform_api rtw_halmac_platform_api;
/* HALMAC API for Driver(HAL) */
u8 rtw_halmac_read8(struct intf_hdl *, u32 addr);
u16 rtw_halmac_read16(struct intf_hdl *, u32 addr);
u32 rtw_halmac_read32(struct intf_hdl *, u32 addr);
void rtw_halmac_read_mem(struct intf_hdl *pintfhdl, u32 addr, u32 cnt, u8 *pmem);
#ifdef CONFIG_SDIO_INDIRECT_ACCESS
u8 rtw_halmac_iread8(struct intf_hdl *pintfhdl, u32 addr);
u16 rtw_halmac_iread16(struct intf_hdl *pintfhdl, u32 addr);
u32 rtw_halmac_iread32(struct intf_hdl *pintfhdl, u32 addr);
#endif /* CONFIG_SDIO_INDIRECT_ACCESS */
int rtw_halmac_write8(struct intf_hdl *, u32 addr, u8 value);
int rtw_halmac_write16(struct intf_hdl *, u32 addr, u16 value);
int rtw_halmac_write32(struct intf_hdl *, u32 addr, u32 value);
/* Software Information */
void rtw_halmac_get_version(char *str, u32 len);
/* Software Initialization */
int rtw_halmac_init_adapter(struct dvobj_priv *d, struct halmac_platform_api *pf_api);
int rtw_halmac_deinit_adapter(struct dvobj_priv *);
/* Get operations */
int rtw_halmac_get_hw_value(struct dvobj_priv *d, enum halmac_hw_id hw_id, void *pvalue);
int rtw_halmac_get_tx_fifo_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_rx_fifo_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_rsvd_drv_pg_bndy(struct dvobj_priv *d, u16 *bndy);
int rtw_halmac_get_page_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_tx_agg_align_size(struct dvobj_priv *d, u16 *size);
int rtw_halmac_get_rx_agg_align_size(struct dvobj_priv *d, u8 *size);
int rtw_halmac_get_rx_drv_info_sz(struct dvobj_priv *, u8 *sz);
int rtw_halmac_get_tx_desc_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_rx_desc_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_ori_h2c_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_oqt_size(struct dvobj_priv *d, u8 *size);
int rtw_halmac_get_ac_queue_number(struct dvobj_priv *d, u8 *num);
int rtw_halmac_get_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
int rtw_halmac_get_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 *type);
int rtw_halmac_get_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport, struct rtw_halmac_bcn_ctrl *bcn_ctrl);
/*int rtw_halmac_get_wow_reason(struct dvobj_priv *, u8 *reason);*/
/* Set operations */
int rtw_halmac_config_rx_info(struct dvobj_priv *d, enum halmac_drv_info info);
int rtw_halmac_set_max_dl_fw_size(struct dvobj_priv *d, u32 size);
int rtw_halmac_set_mac_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
int rtw_halmac_set_bssid(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
int rtw_halmac_set_tx_address(struct dvobj_priv *d, enum _hw_port hwport, u8 *addr);
int rtw_halmac_set_network_type(struct dvobj_priv *d, enum _hw_port hwport, u8 type);
int rtw_halmac_reset_tsf(struct dvobj_priv *d, enum _hw_port hwport);
int rtw_halmac_set_bcn_interval(struct dvobj_priv *d, enum _hw_port hwport, u32 space);
int rtw_halmac_set_bcn_ctrl(struct dvobj_priv *d, enum _hw_port hwport, struct rtw_halmac_bcn_ctrl *bcn_ctrl);
int rtw_halmac_set_aid(struct dvobj_priv *d, enum _hw_port hwport, u16 aid);
int rtw_halmac_set_bandwidth(struct dvobj_priv *d, u8 channel, u8 pri_ch_idx, u8 bw);
int rtw_halmac_set_edca(struct dvobj_priv *d, u8 queue, u8 aifs, u8 cw, u16 txop);
int rtw_halmac_set_rts_full_bw(struct dvobj_priv *d, u8 enable);
/* Functions */
int rtw_halmac_poweron(struct dvobj_priv *);
int rtw_halmac_poweroff(struct dvobj_priv *);
int rtw_halmac_init_hal(struct dvobj_priv *);
int rtw_halmac_init_hal_fw(struct dvobj_priv *, u8 *fw, u32 fwsize);
int rtw_halmac_init_hal_fw_file(struct dvobj_priv *, u8 *fwpath);
int rtw_halmac_deinit_hal(struct dvobj_priv *);
int rtw_halmac_self_verify(struct dvobj_priv *);
int rtw_halmac_txfifo_wait_empty(struct dvobj_priv *d, u32 timeout);
int rtw_halmac_dlfw(struct dvobj_priv *, u8 *fw, u32 fwsize);
int rtw_halmac_dlfw_from_file(struct dvobj_priv *, u8 *fwpath);
int rtw_halmac_dlfw_mem(struct dvobj_priv *d, u8 *fw, u32 fwsize, enum fw_mem mem);
int rtw_halmac_dlfw_mem_from_file(struct dvobj_priv *d, u8 *fwpath, enum fw_mem mem);
int rtw_halmac_phy_power_switch(struct dvobj_priv *, u8 enable);
int rtw_halmac_send_h2c(struct dvobj_priv *, u8 *h2c);
int rtw_halmac_c2h_handle(struct dvobj_priv *, u8 *c2h, u32 size);
/* eFuse */
int rtw_halmac_get_available_efuse_size(struct dvobj_priv *d, u32 *size);
int rtw_halmac_get_physical_efuse_size(struct dvobj_priv *, u32 *size);
int rtw_halmac_read_physical_efuse_map(struct dvobj_priv *, u8 *map, u32 size);
int rtw_halmac_read_physical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
int rtw_halmac_write_physical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
int rtw_halmac_get_logical_efuse_size(struct dvobj_priv *, u32 *size);
int rtw_halmac_read_logical_efuse_map(struct dvobj_priv *, u8 *map, u32 size, u8 *maskmap, u32 masksize);
int rtw_halmac_write_logical_efuse_map(struct dvobj_priv *, u8 *map, u32 size, u8 *maskmap, u32 masksize);
int rtw_halmac_read_logical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
int rtw_halmac_write_logical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
int rtw_halmac_write_bt_physical_efuse(struct dvobj_priv *, u32 offset, u32 cnt, u8 *data);
int rtw_halmac_read_bt_physical_efuse_map(struct dvobj_priv *, u8 *map, u32 size);
int rtw_halmac_dump_fifo(struct dvobj_priv *d, u8 fifo_sel, u32 addr, u32 size, u8 *buffer);
int rtw_halmac_rx_agg_switch(struct dvobj_priv *, u8 enable);
/* Specific function APIs*/
int rtw_halmac_download_rsvd_page(struct dvobj_priv *dvobj, u8 pg_offset, u8 *pbuf, u32 size);
int rtw_halmac_fill_hal_spec(struct dvobj_priv *, struct hal_spec_t *);
int rtw_halmac_p2pps(struct dvobj_priv *dvobj, PHAL_P2P_PS_PARA pp2p_ps_para);
int rtw_halmac_iqk(struct dvobj_priv *d, u8 clear, u8 segment);
int rtw_halmac_cfg_phy_para(struct dvobj_priv *d, struct rtw_phy_parameter *para);
int rtw_halmac_led_cfg(struct dvobj_priv *d, u8 enable, u8 mode);
void rtw_halmac_led_switch(struct dvobj_priv *d, u8 on);
int rtw_halmac_bt_wake_cfg(struct dvobj_priv *d, u8 enable);
#ifdef CONFIG_PNO_SUPPORT
int rtw_halmac_pno_scanoffload(struct dvobj_priv *d, u32 enable);
#endif
#ifdef CONFIG_SDIO_HCI
int rtw_halmac_query_tx_page_num(struct dvobj_priv *);
int rtw_halmac_get_tx_queue_page_num(struct dvobj_priv *, u8 queue, u32 *page);
u32 rtw_halmac_sdio_get_tx_addr(struct dvobj_priv *, u8 *desc, u32 size);
int rtw_halmac_sdio_tx_allowed(struct dvobj_priv *, u8 *buf, u32 size);
u32 rtw_halmac_sdio_get_rx_addr(struct dvobj_priv *, u8 *seq);
int rtw_halmac_sdio_set_tx_format(struct dvobj_priv *d, enum halmac_sdio_tx_format format);
#ifdef CONFIG_SDIO_MONITOR
u32 rtw_halmac_sdio_get_int_lat(struct dvobj_priv *d);
u32 rtw_halmac_sdio_get_lk_cnt(struct dvobj_priv *d);
int rtw_halmac_sdio_set_wt_en(struct dvobj_priv *d);
int rtw_halmac_set_sdio_clk_monitor(struct dvobj_priv *d, u8 clk_monitor_mode);
#endif
#endif /* CONFIG_SDIO_HCI */
#ifdef CONFIG_USB_HCI
u8 rtw_halmac_usb_get_bulkout_id(struct dvobj_priv *, u8 *buf, u32 size);
int rtw_halmac_usb_get_txagg_desc_num(struct dvobj_priv *d, u8 *num);
u8 rtw_halmac_switch_usb_mode(struct dvobj_priv *d, enum RTW_USB_SPEED usb_mode);
#endif /* CONFIG_USB_HCI */
#ifdef CONFIG_SUPPORT_TRX_SHARED
void dump_trx_share_mode(void *sel, _adapter *adapter);
#endif
#ifdef CONFIG_BEAMFORMING
#ifdef RTW_BEAMFORMING_VERSION_2
int rtw_halmac_bf_add_mu_bfer(struct dvobj_priv *d, u16 paid, u16 csi_para,
u16 my_aid, enum halmac_csi_seg_len sel, u8 *addr);
int rtw_halmac_bf_del_mu_bfer(struct dvobj_priv *d);
int rtw_halmac_bf_cfg_sounding(struct dvobj_priv *d, enum halmac_snd_role role,
enum halmac_data_rate rate);
int rtw_halmac_bf_del_sounding(struct dvobj_priv *d, enum halmac_snd_role role);
int rtw_halmac_bf_cfg_csi_rate(struct dvobj_priv *d, u8 rssi, u8 current_rate,
u8 fixrate_en, u8 *new_rate, u8 *bmp_ofdm54);
int rtw_halmac_bf_cfg_mu_mimo(struct dvobj_priv *d, enum halmac_snd_role role,
u8 *sounding_sts, u16 grouping_bitmap, u8 mu_tx_en,
u32 *given_gid_tab, u32 *given_user_pos);
#define rtw_halmac_bf_cfg_mu_bfee(d, gid_tab, user_pos) \
rtw_halmac_bf_cfg_mu_mimo(d, HAL_BFEE, NULL, 0, 0, gid_tab, user_pos)
#endif /* RTW_BEAMFORMING_VERSION_2 */
#endif /* CONFIG_BEAMFORMING */
#endif /* _HAL_HALMAC_H_ */
================================================
FILE: hal/hal_hci/hal_pci.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_PCI_C_
#include
#include
================================================
FILE: hal/hal_intf.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_INTF_C_
#include
#include
const u32 _chip_type_to_odm_ic_type[] = {
0,
ODM_RTL8188E,
ODM_RTL8192E,
ODM_RTL8812,
ODM_RTL8821,
ODM_RTL8723B,
ODM_RTL8814A,
ODM_RTL8703B,
ODM_RTL8188F,
ODM_RTL8188F,
ODM_RTL8822B,
ODM_RTL8723D,
ODM_RTL8821C,
ODM_RTL8710B,
ODM_RTL8192F,
ODM_RTL8822C,
0,
};
void rtw_hal_chip_configure(_adapter *padapter)
{
padapter->hal_func.intf_chip_configure(padapter);
}
/*
* Description:
* Read chip internal ROM data
*
* Return:
* _SUCCESS success
* _FAIL fail
*/
u8 rtw_hal_read_chip_info(_adapter *padapter)
{
u8 rtn = _SUCCESS;
u8 hci_type = rtw_get_intf_type(padapter);
systime start = rtw_get_current_time();
/* before access eFuse, make sure card enable has been called */
if ((hci_type == RTW_SDIO || hci_type == RTW_GSPI)
&& !rtw_is_hw_init_completed(padapter))
rtw_hal_power_on(padapter);
rtn = padapter->hal_func.read_adapter_info(padapter);
if ((hci_type == RTW_SDIO || hci_type == RTW_GSPI)
&& !rtw_is_hw_init_completed(padapter))
rtw_hal_power_off(padapter);
RTW_INFO("%s in %d ms\n", __func__, rtw_get_passing_time_ms(start));
return rtn;
}
void rtw_hal_read_chip_version(_adapter *padapter)
{
padapter->hal_func.read_chip_version(padapter);
rtw_odm_init_ic_type(padapter);
}
static void rtw_init_wireless_mode(_adapter *padapter)
{
u8 proto_wireless_mode = 0;
struct hal_spec_t *hal_spec = GET_HAL_SPEC(padapter);
if(hal_spec->proto_cap & PROTO_CAP_11B)
proto_wireless_mode |= WIRELESS_11B;
if(hal_spec->proto_cap & PROTO_CAP_11G)
proto_wireless_mode |= WIRELESS_11G;
#ifdef CONFIG_80211AC_VHT
if(hal_spec->band_cap & BAND_CAP_5G)
proto_wireless_mode |= WIRELESS_11A;
#endif
#ifdef CONFIG_80211N_HT
if(hal_spec->proto_cap & PROTO_CAP_11N) {
if(hal_spec->band_cap & BAND_CAP_2G)
proto_wireless_mode |= WIRELESS_11_24N;
if(hal_spec->band_cap & BAND_CAP_5G)
proto_wireless_mode |= WIRELESS_11_5N;
}
#endif
#ifdef CONFIG_80211AC_VHT
if(hal_spec->proto_cap & PROTO_CAP_11AC)
proto_wireless_mode |= WIRELESS_11AC;
#endif
padapter->registrypriv.wireless_mode &= proto_wireless_mode;
}
void rtw_hal_def_value_init(_adapter *padapter)
{
if (is_primary_adapter(padapter)) {
/*init fw_psmode_iface_id*/
adapter_to_pwrctl(padapter)->fw_psmode_iface_id = 0xff;
/*wireless_mode*/
rtw_init_wireless_mode(padapter);
padapter->hal_func.init_default_value(padapter);
rtw_init_hal_com_default_value(padapter);
#ifdef CONFIG_FW_MULTI_PORT_SUPPORT
adapter_to_dvobj(padapter)->dft.port_id = 0xFF;
adapter_to_dvobj(padapter)->dft.mac_id = 0xFF;
#endif
#ifdef CONFIG_HW_P0_TSF_SYNC
adapter_to_dvobj(padapter)->p0_tsf.sync_port = MAX_HW_PORT;
adapter_to_dvobj(padapter)->p0_tsf.offset = 0;
#endif
GET_HAL_DATA(padapter)->rx_tsf_addr_filter_config = 0;
}
}
u8 rtw_hal_data_init(_adapter *padapter)
{
if (is_primary_adapter(padapter)) {
padapter->hal_data_sz = sizeof(HAL_DATA_TYPE);
padapter->HalData = rtw_zvmalloc(padapter->hal_data_sz);
if (padapter->HalData == NULL) {
RTW_INFO("cant not alloc memory for HAL DATA\n");
return _FAIL;
}
rtw_phydm_priv_init(padapter);
}
return _SUCCESS;
}
void rtw_hal_data_deinit(_adapter *padapter)
{
if (is_primary_adapter(padapter)) {
if (padapter->HalData) {
#ifdef CONFIG_LOAD_PHY_PARA_FROM_FILE
phy_free_filebuf(padapter);
#endif
rtw_vmfree(padapter->HalData, padapter->hal_data_sz);
padapter->HalData = NULL;
padapter->hal_data_sz = 0;
}
}
}
void rtw_hal_free_data(_adapter *padapter)
{
/* free HAL Data */
rtw_hal_data_deinit(padapter);
}
void rtw_hal_dm_init(_adapter *padapter)
{
if (is_primary_adapter(padapter)) {
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
padapter->hal_func.dm_init(padapter);
_rtw_spinlock_init(&pHalData->IQKSpinLock);
phy_load_tx_power_ext_info(padapter, 1);
}
}
void rtw_hal_dm_deinit(_adapter *padapter)
{
if (is_primary_adapter(padapter)) {
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
padapter->hal_func.dm_deinit(padapter);
_rtw_spinlock_free(&pHalData->IQKSpinLock);
}
}
#ifdef CONFIG_RTW_SW_LED
void rtw_hal_sw_led_init(_adapter *padapter)
{
struct led_priv *ledpriv = adapter_to_led(padapter);
if (ledpriv->bRegUseLed == _FALSE)
return;
if (!is_primary_adapter(padapter))
return;
if (padapter->hal_func.InitSwLeds) {
padapter->hal_func.InitSwLeds(padapter);
rtw_led_set_ctl_en_mask_primary(padapter);
rtw_led_set_iface_en(padapter, 1);
}
}
void rtw_hal_sw_led_deinit(_adapter *padapter)
{
struct led_priv *ledpriv = adapter_to_led(padapter);
if (ledpriv->bRegUseLed == _FALSE)
return;
if (!is_primary_adapter(padapter))
return;
if (padapter->hal_func.DeInitSwLeds)
padapter->hal_func.DeInitSwLeds(padapter);
}
#endif
u32 rtw_hal_power_on(_adapter *padapter)
{
u32 ret = 0;
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
ret = padapter->hal_func.hal_power_on(padapter);
#ifdef CONFIG_BT_COEXIST
if ((ret == _SUCCESS) && (pHalData->EEPROMBluetoothCoexist == _TRUE))
rtw_btcoex_PowerOnSetting(padapter);
#endif
return ret;
}
void rtw_hal_power_off(_adapter *padapter)
{
struct macid_ctl_t *macid_ctl = &padapter->dvobj->macid_ctl;
_rtw_memset(macid_ctl->h2c_msr, 0, MACID_NUM_SW_LIMIT);
_rtw_memset(macid_ctl->op_num, 0, H2C_MSR_ROLE_MAX);
#ifdef CONFIG_LPS_1T1R
GET_HAL_DATA(padapter)->lps_1t1r = 0;
#endif
#ifdef CONFIG_BT_COEXIST
rtw_btcoex_PowerOffSetting(padapter);
#endif
padapter->hal_func.hal_power_off(padapter);
}
void rtw_hal_init_opmode(_adapter *padapter)
{
NDIS_802_11_NETWORK_INFRASTRUCTURE networkType = Ndis802_11InfrastructureMax;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
sint fw_state;
fw_state = get_fwstate(pmlmepriv);
if (fw_state & WIFI_ADHOC_STATE)
networkType = Ndis802_11IBSS;
else if (fw_state & WIFI_STATION_STATE)
networkType = Ndis802_11Infrastructure;
#ifdef CONFIG_AP_MODE
else if (fw_state & WIFI_AP_STATE)
networkType = Ndis802_11APMode;
#endif
#ifdef CONFIG_RTW_MESH
else if (fw_state & WIFI_MESH_STATE)
networkType = Ndis802_11_mesh;
#endif
else
return;
rtw_setopmode_cmd(padapter, networkType, RTW_CMDF_DIRECTLY);
}
#ifdef CONFIG_NEW_NETDEV_HDL
uint rtw_hal_iface_init(_adapter *adapter)
{
uint status = _SUCCESS;
rtw_hal_set_hwreg(adapter, HW_VAR_MAC_ADDR, adapter_mac_addr(adapter));
#ifdef RTW_HALMAC
rtw_hal_hw_port_enable(adapter);
#endif
rtw_sec_restore_wep_key(adapter);
rtw_hal_init_opmode(adapter);
rtw_hal_start_thread(adapter);
return status;
}
uint rtw_hal_init(_adapter *padapter)
{
uint status = _SUCCESS;
halrf_set_rfsupportability(adapter_to_phydm(padapter));
status = padapter->hal_func.hal_init(padapter);
if (status == _SUCCESS) {
rtw_set_hw_init_completed(padapter, _TRUE);
if (padapter->registrypriv.notch_filter == 1)
rtw_hal_notch_filter(padapter, 1);
rtw_led_control(padapter, LED_CTL_POWER_ON);
init_hw_mlme_ext(padapter);
#ifdef CONFIG_RF_POWER_TRIM
rtw_bb_rf_gain_offset(padapter);
#endif /*CONFIG_RF_POWER_TRIM*/
GET_PRIMARY_ADAPTER(padapter)->bup = _TRUE; /*temporary*/
#ifdef CONFIG_MI_WITH_MBSSID_CAM
rtw_mi_set_mbid_cam(padapter);
#endif
#ifdef CONFIG_SUPPORT_MULTI_BCN
rtw_ap_multi_bcn_cfg(padapter);
#endif
#if (RTL8822B_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)
#ifdef CONFIG_DYNAMIC_SOML
rtw_dyn_soml_config(padapter);
#endif
#endif
#ifdef CONFIG_TDMADIG
rtw_phydm_tdmadig(padapter, TDMADIG_INIT);
#endif/*CONFIG_TDMADIG*/
#ifdef CONFIG_RTW_TX_2PATH_EN
rtw_phydm_tx_2path_en(padapter);
#endif
} else {
rtw_set_hw_init_completed(padapter, _FALSE);
RTW_ERR("%s: hal_init fail\n", __func__);
}
return status;
}
#else
uint rtw_hal_init(_adapter *padapter)
{
uint status = _SUCCESS;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
int i;
halrf_set_rfsupportability(adapter_to_phydm(padapter));
status = padapter->hal_func.hal_init(padapter);
if (status == _SUCCESS) {
rtw_set_hw_init_completed(padapter, _TRUE);
rtw_mi_set_mac_addr(padapter);/*set mac addr of all ifaces*/
#ifdef RTW_HALMAC
rtw_restore_hw_port_cfg(padapter);
#endif
if (padapter->registrypriv.notch_filter == 1)
rtw_hal_notch_filter(padapter, 1);
for (i = 0; i < dvobj->iface_nums; i++)
rtw_sec_restore_wep_key(dvobj->padapters[i]);
rtw_led_control(padapter, LED_CTL_POWER_ON);
init_hw_mlme_ext(padapter);
rtw_hal_init_opmode(padapter);
#ifdef CONFIG_RF_POWER_TRIM
rtw_bb_rf_gain_offset(padapter);
#endif /*CONFIG_RF_POWER_TRIM*/
#ifdef CONFIG_SUPPORT_MULTI_BCN
rtw_ap_multi_bcn_cfg(padapter);
#endif
#if (RTL8822B_SUPPORT == 1) || (RTL8192F_SUPPORT == 1)
#ifdef CONFIG_DYNAMIC_SOML
rtw_dyn_soml_config(padapter);
#endif
#endif
#ifdef CONFIG_TDMADIG
rtw_phydm_tdmadig(padapter, TDMADIG_INIT);
#endif/*CONFIG_TDMADIG*/
#ifdef CONFIG_RTW_TX_2PATH_EN
rtw_phydm_tx_2path_en(padapter);
#endif
} else {
rtw_set_hw_init_completed(padapter, _FALSE);
RTW_ERR("%s: fail\n", __func__);
}
return status;
}
#endif
uint rtw_hal_deinit(_adapter *padapter)
{
uint status = _SUCCESS;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
int i;
status = padapter->hal_func.hal_deinit(padapter);
if (status == _SUCCESS) {
rtw_led_control(padapter, LED_CTL_POWER_OFF);
rtw_set_hw_init_completed(padapter, _FALSE);
} else
RTW_INFO("\n rtw_hal_deinit: hal_init fail\n");
return status;
}
u8 rtw_hal_set_hwreg(_adapter *padapter, u8 variable, u8 *val)
{
return padapter->hal_func.set_hw_reg_handler(padapter, variable, val);
}
void rtw_hal_get_hwreg(_adapter *padapter, u8 variable, u8 *val)
{
padapter->hal_func.GetHwRegHandler(padapter, variable, val);
}
u8 rtw_hal_set_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, void *pValue)
{
return padapter->hal_func.SetHalDefVarHandler(padapter, eVariable, pValue);
}
u8 rtw_hal_get_def_var(_adapter *padapter, HAL_DEF_VARIABLE eVariable, void *pValue)
{
return padapter->hal_func.get_hal_def_var_handler(padapter, eVariable, pValue);
}
void rtw_hal_set_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, void *pValue1, BOOLEAN bSet)
{
padapter->hal_func.SetHalODMVarHandler(padapter, eVariable, pValue1, bSet);
}
void rtw_hal_get_odm_var(_adapter *padapter, HAL_ODM_VARIABLE eVariable, void *pValue1, void *pValue2)
{
padapter->hal_func.GetHalODMVarHandler(padapter, eVariable, pValue1, pValue2);
}
/* FOR SDIO & PCIE */
void rtw_hal_enable_interrupt(_adapter *padapter)
{
#if defined(CONFIG_PCI_HCI) || defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
padapter->hal_func.enable_interrupt(padapter);
#endif /* #if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI) */
}
/* FOR SDIO & PCIE */
void rtw_hal_disable_interrupt(_adapter *padapter)
{
#if defined(CONFIG_PCI_HCI) || defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
padapter->hal_func.disable_interrupt(padapter);
#endif /* #if defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI) */
}
u8 rtw_hal_check_ips_status(_adapter *padapter)
{
u8 val = _FALSE;
if (padapter->hal_func.check_ips_status)
val = padapter->hal_func.check_ips_status(padapter);
else
RTW_INFO("%s: hal_func.check_ips_status is NULL!\n", __FUNCTION__);
return val;
}
s32 rtw_hal_fw_dl(_adapter *padapter, u8 wowlan)
{
s32 ret;
ret = padapter->hal_func.fw_dl(padapter, wowlan);
#ifdef CONFIG_LPS_1T1R
GET_HAL_DATA(padapter)->lps_1t1r = 0;
#endif
return ret;
}
#ifdef RTW_HALMAC
s32 rtw_hal_fw_mem_dl(_adapter *padapter, enum fw_mem mem)
{
systime dlfw_start_time = rtw_get_current_time();
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct debug_priv *pdbgpriv = &dvobj->drv_dbg;
s32 rst = _FALSE;
rst = padapter->hal_func.fw_mem_dl(padapter, mem);
RTW_INFO("%s in %dms\n", __func__, rtw_get_passing_time_ms(dlfw_start_time));
if (rst == _FALSE)
pdbgpriv->dbg_fw_mem_dl_error_cnt++;
if (1)
RTW_INFO("%s dbg_fw_mem_dl_error_cnt:%d\n", __func__, pdbgpriv->dbg_fw_mem_dl_error_cnt);
return rst;
}
#endif
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
void rtw_hal_clear_interrupt(_adapter *padapter)
{
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
padapter->hal_func.clear_interrupt(padapter);
#endif
}
#endif
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
u32 rtw_hal_inirp_init(_adapter *padapter)
{
if (is_primary_adapter(padapter))
return padapter->hal_func.inirp_init(padapter);
return _SUCCESS;
}
u32 rtw_hal_inirp_deinit(_adapter *padapter)
{
if (is_primary_adapter(padapter))
return padapter->hal_func.inirp_deinit(padapter);
return _SUCCESS;
}
#endif /* #if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI) */
#if defined(CONFIG_PCI_HCI)
void rtw_hal_irp_reset(_adapter *padapter)
{
padapter->hal_func.irp_reset(GET_PRIMARY_ADAPTER(padapter));
}
void rtw_hal_pci_dbi_write(_adapter *padapter, u16 addr, u8 data)
{
u16 cmd[2];
cmd[0] = addr;
cmd[1] = data;
padapter->hal_func.set_hw_reg_handler(padapter, HW_VAR_DBI, (u8 *) cmd);
}
u8 rtw_hal_pci_dbi_read(_adapter *padapter, u16 addr)
{
padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_DBI, (u8 *)(&addr));
return (u8)addr;
}
void rtw_hal_pci_mdio_write(_adapter *padapter, u8 addr, u16 data)
{
u16 cmd[2];
cmd[0] = (u16)addr;
cmd[1] = data;
padapter->hal_func.set_hw_reg_handler(padapter, HW_VAR_MDIO, (u8 *) cmd);
}
u16 rtw_hal_pci_mdio_read(_adapter *padapter, u8 addr)
{
padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_MDIO, &addr);
return (u8)addr;
}
u8 rtw_hal_pci_l1off_nic_support(_adapter *padapter)
{
u8 l1off;
padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_L1OFF_NIC_SUPPORT, &l1off);
return l1off;
}
u8 rtw_hal_pci_l1off_capability(_adapter *padapter)
{
u8 l1off;
padapter->hal_func.GetHwRegHandler(padapter, HW_VAR_L1OFF_CAPABILITY, &l1off);
return l1off;
}
#endif /* #if defined(CONFIG_PCI_HCI) */
/* for USB Auto-suspend */
u8 rtw_hal_intf_ps_func(_adapter *padapter, HAL_INTF_PS_FUNC efunc_id, u8 *val)
{
if (padapter->hal_func.interface_ps_func)
return padapter->hal_func.interface_ps_func(padapter, efunc_id, val);
return _FAIL;
}
s32 rtw_hal_xmitframe_enqueue(_adapter *padapter, struct xmit_frame *pxmitframe)
{
return padapter->hal_func.hal_xmitframe_enqueue(padapter, pxmitframe);
}
s32 rtw_hal_xmit(_adapter *padapter, struct xmit_frame *pxmitframe)
{
return padapter->hal_func.hal_xmit(padapter, pxmitframe);
}
/*
* [IMPORTANT] This function would be run in interrupt context.
*/
s32 rtw_hal_mgnt_xmit(_adapter *padapter, struct xmit_frame *pmgntframe)
{
s32 ret = _FAIL;
update_mgntframe_attrib_addr(padapter, pmgntframe);
#if defined(CONFIG_IEEE80211W) || defined(CONFIG_RTW_MESH)
if ((!MLME_IS_MESH(padapter) && SEC_IS_BIP_KEY_INSTALLED(&padapter->securitypriv) == _TRUE)
#ifdef CONFIG_RTW_MESH
|| (MLME_IS_MESH(padapter) && padapter->mesh_info.mesh_auth_id)
#endif
)
rtw_mgmt_xmitframe_coalesce(padapter, pmgntframe->pkt, pmgntframe);
#endif
ret = padapter->hal_func.mgnt_xmit(padapter, pmgntframe);
return ret;
}
s32 rtw_hal_init_xmit_priv(_adapter *padapter)
{
return padapter->hal_func.init_xmit_priv(padapter);
}
void rtw_hal_free_xmit_priv(_adapter *padapter)
{
padapter->hal_func.free_xmit_priv(padapter);
}
s32 rtw_hal_init_recv_priv(_adapter *padapter)
{
return padapter->hal_func.init_recv_priv(padapter);
}
void rtw_hal_free_recv_priv(_adapter *padapter)
{
padapter->hal_func.free_recv_priv(padapter);
}
void rtw_sta_ra_registed(_adapter *padapter, struct sta_info *psta)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(padapter);
if (psta == NULL) {
RTW_ERR(FUNC_ADPT_FMT" sta is NULL\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
return;
}
#ifdef CONFIG_AP_MODE
if (MLME_IS_AP(padapter) || MLME_IS_MESH(padapter)) {
if (psta->cmn.aid > padapter->stapriv.max_aid) {
RTW_ERR("station aid %d exceed the max number\n", psta->cmn.aid);
rtw_warn_on(1);
return;
}
rtw_ap_update_sta_ra_info(padapter, psta);
}
#endif
psta->cmn.ra_info.ra_bw_mode = rtw_get_tx_bw_mode(padapter, psta);
/*set correct initial date rate for each mac_id */
hal_data->INIDATA_RATE[psta->cmn.mac_id] = psta->init_rate;
rtw_phydm_ra_registed(padapter, psta);
}
void rtw_hal_update_ra_mask(struct sta_info *psta)
{
_adapter *padapter;
if (!psta)
return;
padapter = psta->padapter;
rtw_sta_ra_registed(padapter, psta);
}
/* Start specifical interface thread */
void rtw_hal_start_thread(_adapter *padapter)
{
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
#ifndef CONFIG_SDIO_TX_TASKLET
padapter->hal_func.run_thread(padapter);
#endif
#endif
}
/* Start specifical interface thread */
void rtw_hal_stop_thread(_adapter *padapter)
{
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
#ifndef CONFIG_SDIO_TX_TASKLET
padapter->hal_func.cancel_thread(padapter);
#endif
#endif
}
u32 rtw_hal_read_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask)
{
u32 data = 0;
if (padapter->hal_func.read_bbreg)
data = padapter->hal_func.read_bbreg(padapter, RegAddr, BitMask);
return data;
}
void rtw_hal_write_bbreg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data)
{
if (padapter->hal_func.write_bbreg)
padapter->hal_func.write_bbreg(padapter, RegAddr, BitMask, Data);
}
u32 rtw_hal_read_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask)
{
u32 data = 0;
if (padapter->hal_func.read_rfreg) {
data = padapter->hal_func.read_rfreg(padapter, eRFPath, RegAddr, BitMask);
#ifdef DBG_IO
if (match_rf_read_sniff_ranges(padapter, eRFPath, RegAddr, BitMask)) {
RTW_INFO("DBG_IO rtw_hal_read_rfreg(%u, 0x%04x, 0x%08x) read:0x%08x(0x%08x)\n"
, eRFPath, RegAddr, BitMask, (data << PHY_CalculateBitShift(BitMask)), data);
}
#endif
}
return data;
}
void rtw_hal_write_rfreg(_adapter *padapter, enum rf_path eRFPath, u32 RegAddr, u32 BitMask, u32 Data)
{
if (padapter->hal_func.write_rfreg) {
#ifdef DBG_IO
if (match_rf_write_sniff_ranges(padapter, eRFPath, RegAddr, BitMask)) {
RTW_INFO("DBG_IO rtw_hal_write_rfreg(%u, 0x%04x, 0x%08x) write:0x%08x(0x%08x)\n"
, eRFPath, RegAddr, BitMask, (Data << PHY_CalculateBitShift(BitMask)), Data);
}
#endif
padapter->hal_func.write_rfreg(padapter, eRFPath, RegAddr, BitMask, Data);
#ifdef CONFIG_PCI_HCI
if (!IS_HARDWARE_TYPE_JAGUAR_AND_JAGUAR2(padapter)) /*For N-Series IC, suggest by Jenyu*/
rtw_udelay_os(2);
#endif
}
}
#ifdef CONFIG_SYSON_INDIRECT_ACCESS
u32 rtw_hal_read_syson_reg(PADAPTER padapter, u32 RegAddr, u32 BitMask)
{
u32 data = 0;
if (padapter->hal_func.read_syson_reg)
data = padapter->hal_func.read_syson_reg(padapter, RegAddr, BitMask);
return data;
}
void rtw_hal_write_syson_reg(_adapter *padapter, u32 RegAddr, u32 BitMask, u32 Data)
{
if (padapter->hal_func.write_syson_reg)
padapter->hal_func.write_syson_reg(padapter, RegAddr, BitMask, Data);
}
#endif
#if defined(CONFIG_PCI_HCI)
s32 rtw_hal_interrupt_handler(_adapter *padapter)
{
s32 ret = _FAIL;
ret = padapter->hal_func.interrupt_handler(padapter);
return ret;
}
void rtw_hal_unmap_beacon_icf(_adapter *padapter)
{
padapter->hal_func.unmap_beacon_icf(padapter);
}
#endif
#if defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT)
void rtw_hal_interrupt_handler(_adapter *padapter, u16 pkt_len, u8 *pbuf)
{
padapter->hal_func.interrupt_handler(padapter, pkt_len, pbuf);
}
#endif
void rtw_hal_set_chnl_bw(_adapter *padapter, u8 channel, enum channel_width Bandwidth, u8 Offset40, u8 Offset80)
{
PHAL_DATA_TYPE pHalData = GET_HAL_DATA(padapter);
u8 cch_160 = Bandwidth == CHANNEL_WIDTH_160 ? channel : 0;
u8 cch_80 = Bandwidth == CHANNEL_WIDTH_80 ? channel : 0;
u8 cch_40 = Bandwidth == CHANNEL_WIDTH_40 ? channel : 0;
u8 cch_20 = Bandwidth == CHANNEL_WIDTH_20 ? channel : 0;
if (rtw_phydm_is_iqk_in_progress(padapter))
RTW_ERR("%s, %d, IQK may race condition\n", __func__, __LINE__);
#ifdef CONFIG_MP_INCLUDED
/* MP mode channel don't use secondary channel */
if (rtw_mp_mode_check(padapter) == _FALSE)
#endif
{
#if 0
if (cch_160 != 0)
cch_80 = rtw_get_scch_by_cch_offset(cch_160, CHANNEL_WIDTH_160, Offset80);
#endif
if (cch_80 != 0)
cch_40 = rtw_get_scch_by_cch_offset(cch_80, CHANNEL_WIDTH_80, Offset80);
if (cch_40 != 0)
cch_20 = rtw_get_scch_by_cch_offset(cch_40, CHANNEL_WIDTH_40, Offset40);
}
pHalData->cch_80 = cch_80;
pHalData->cch_40 = cch_40;
pHalData->cch_20 = cch_20;
if (0)
RTW_INFO("%s cch:%u, %s, offset40:%u, offset80:%u (%u, %u, %u)\n", __func__
, channel, ch_width_str(Bandwidth), Offset40, Offset80
, pHalData->cch_80, pHalData->cch_40, pHalData->cch_20);
padapter->hal_func.set_chnl_bw_handler(padapter, channel, Bandwidth, Offset40, Offset80);
pHalData->current_band_type = channel > 14 ? BAND_ON_5G:BAND_ON_2_4G;
}
void rtw_hal_dm_watchdog(_adapter *padapter)
{
rtw_hal_turbo_edca(padapter);
padapter->hal_func.hal_dm_watchdog(padapter);
#ifdef CONFIG_PCI_DYNAMIC_ASPM
rtw_pci_aspm_config_dynamic_l1_ilde_time(padapter);
#endif
}
#ifdef CONFIG_LPS_LCLK_WD_TIMER
void rtw_hal_dm_watchdog_in_lps(_adapter *padapter)
{
#if defined(CONFIG_CONCURRENT_MODE)
#ifndef CONFIG_FW_MULTI_PORT_SUPPORT
if (padapter->hw_port != HW_PORT0)
return;
#endif
#endif
if (adapter_to_pwrctl(padapter)->bFwCurrentInPSMode == _TRUE)
rtw_phydm_watchdog_in_lps_lclk(padapter);/* this function caller is in interrupt context */
}
#endif /*CONFIG_LPS_LCLK_WD_TIMER*/
void rtw_hal_bcn_related_reg_setting(_adapter *padapter)
{
padapter->hal_func.SetBeaconRelatedRegistersHandler(padapter);
}
#ifdef CONFIG_HOSTAPD_MLME
s32 rtw_hal_hostap_mgnt_xmit_entry(_adapter *padapter, _pkt *pkt)
{
if (padapter->hal_func.hostap_mgnt_xmit_entry)
return padapter->hal_func.hostap_mgnt_xmit_entry(padapter, pkt);
return _FAIL;
}
#endif /* CONFIG_HOSTAPD_MLME */
#ifdef DBG_CONFIG_ERROR_DETECT
void rtw_hal_sreset_init(_adapter *padapter)
{
padapter->hal_func.sreset_init_value(padapter);
}
void rtw_hal_sreset_reset(_adapter *padapter)
{
padapter = GET_PRIMARY_ADAPTER(padapter);
padapter->hal_func.silentreset(padapter);
}
void rtw_hal_sreset_reset_value(_adapter *padapter)
{
padapter->hal_func.sreset_reset_value(padapter);
}
void rtw_hal_sreset_xmit_status_check(_adapter *padapter)
{
padapter->hal_func.sreset_xmit_status_check(padapter);
}
void rtw_hal_sreset_linked_status_check(_adapter *padapter)
{
padapter->hal_func.sreset_linked_status_check(padapter);
}
u8 rtw_hal_sreset_get_wifi_status(_adapter *padapter)
{
return padapter->hal_func.sreset_get_wifi_status(padapter);
}
bool rtw_hal_sreset_inprogress(_adapter *padapter)
{
padapter = GET_PRIMARY_ADAPTER(padapter);
return padapter->hal_func.sreset_inprogress(padapter);
}
#endif /* DBG_CONFIG_ERROR_DETECT */
#ifdef CONFIG_IOL
int rtw_hal_iol_cmd(ADAPTER *adapter, struct xmit_frame *xmit_frame, u32 max_waiting_ms, u32 bndy_cnt)
{
if (adapter->hal_func.IOL_exec_cmds_sync)
return adapter->hal_func.IOL_exec_cmds_sync(adapter, xmit_frame, max_waiting_ms, bndy_cnt);
return _FAIL;
}
#endif
#ifdef CONFIG_XMIT_THREAD_MODE
s32 rtw_hal_xmit_thread_handler(_adapter *padapter)
{
return padapter->hal_func.xmit_thread_handler(padapter);
}
#endif
#ifdef CONFIG_RECV_THREAD_MODE
s32 rtw_hal_recv_hdl(_adapter *adapter)
{
return adapter->hal_func.recv_hdl(adapter);
}
#endif
void rtw_hal_notch_filter(_adapter *adapter, bool enable)
{
if (adapter->hal_func.hal_notch_filter)
adapter->hal_func.hal_notch_filter(adapter, enable);
}
#ifdef CONFIG_FW_C2H_REG
inline bool rtw_hal_c2h_valid(_adapter *adapter, u8 *buf)
{
HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
HAL_VERSION *hal_ver = &HalData->version_id;
bool ret = _FAIL;
ret = C2H_ID_88XX(buf) || C2H_PLEN_88XX(buf);
return ret;
}
inline s32 rtw_hal_c2h_evt_read(_adapter *adapter, u8 *buf)
{
HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
HAL_VERSION *hal_ver = &HalData->version_id;
s32 ret = _FAIL;
ret = c2h_evt_read_88xx(adapter, buf);
return ret;
}
bool rtw_hal_c2h_reg_hdr_parse(_adapter *adapter, u8 *buf, u8 *id, u8 *seq, u8 *plen, u8 **payload)
{
HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
HAL_VERSION *hal_ver = &HalData->version_id;
bool ret = _FAIL;
*id = C2H_ID_88XX(buf);
*seq = C2H_SEQ_88XX(buf);
*plen = C2H_PLEN_88XX(buf);
*payload = C2H_PAYLOAD_88XX(buf);
ret = _SUCCESS;
return ret;
}
#endif /* CONFIG_FW_C2H_REG */
#ifdef CONFIG_FW_C2H_PKT
bool rtw_hal_c2h_pkt_hdr_parse(_adapter *adapter, u8 *buf, u16 len, u8 *id, u8 *seq, u8 *plen, u8 **payload)
{
HAL_DATA_TYPE *HalData = GET_HAL_DATA(adapter);
HAL_VERSION *hal_ver = &HalData->version_id;
bool ret = _FAIL;
if (!buf || len > 256 || len < 3)
goto exit;
*id = C2H_ID_88XX(buf);
*seq = C2H_SEQ_88XX(buf);
*plen = len - 2;
*payload = C2H_PAYLOAD_88XX(buf);
ret = _SUCCESS;
exit:
return ret;
}
#endif /* CONFIG_FW_C2H_PKT */
#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTL8723B)
#include /* for MPTBT_FwC2hBtMpCtrl */
#endif
s32 c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
{
u8 sub_id = 0;
s32 ret = _SUCCESS;
switch (id) {
case C2H_FW_SCAN_COMPLETE:
RTW_INFO("[C2H], FW Scan Complete\n");
break;
#ifdef CONFIG_BT_COEXIST
case C2H_BT_INFO:
rtw_btcoex_BtInfoNotify(adapter, plen, payload);
break;
case C2H_BT_MP_INFO:
#if defined(CONFIG_MP_INCLUDED) && defined(CONFIG_RTL8723B)
MPTBT_FwC2hBtMpCtrl(adapter, payload, plen);
#endif
rtw_btcoex_BtMpRptNotify(adapter, plen, payload);
break;
case C2H_MAILBOX_STATUS:
RTW_DBG_DUMP("C2H_MAILBOX_STATUS: ", payload, plen);
break;
case C2H_WLAN_INFO:
rtw_btcoex_WlFwDbgInfoNotify(adapter, payload, plen);
break;
#endif /* CONFIG_BT_COEXIST */
case C2H_IQK_FINISH:
c2h_iqk_offload(adapter, payload, plen);
break;
#if defined(CONFIG_TDLS) && defined(CONFIG_TDLS_CH_SW)
case C2H_FW_CHNL_SWITCH_COMPLETE:
rtw_tdls_chsw_oper_done(adapter);
break;
case C2H_BCN_EARLY_RPT:
rtw_tdls_ch_sw_back_to_base_chnl(adapter);
break;
#endif
#ifdef CONFIG_MCC_MODE
case C2H_MCC:
rtw_hal_mcc_c2h_handler(adapter, plen, payload);
break;
#endif
#ifdef CONFIG_RTW_MAC_HIDDEN_RPT
case C2H_MAC_HIDDEN_RPT:
c2h_mac_hidden_rpt_hdl(adapter, payload, plen);
break;
case C2H_MAC_HIDDEN_RPT_2:
c2h_mac_hidden_rpt_2_hdl(adapter, payload, plen);
break;
#endif
case C2H_DEFEATURE_DBG:
c2h_defeature_dbg_hdl(adapter, payload, plen);
break;
#ifdef CONFIG_RTW_CUSTOMER_STR
case C2H_CUSTOMER_STR_RPT:
c2h_customer_str_rpt_hdl(adapter, payload, plen);
break;
case C2H_CUSTOMER_STR_RPT_2:
c2h_customer_str_rpt_2_hdl(adapter, payload, plen);
break;
#endif
#ifdef RTW_PER_CMD_SUPPORT_FW
case C2H_PER_RATE_RPT:
c2h_per_rate_rpt_hdl(adapter, payload, plen);
break;
#endif
case C2H_LPS_STATUS_RPT:
break;
case C2H_EXTEND:
sub_id = payload[0];
/* no handle, goto default */
default:
if (phydm_c2H_content_parsing(adapter_to_phydm(adapter), id, plen, payload) != TRUE)
ret = _FAIL;
break;
}
if (ret != _SUCCESS) {
if (id == C2H_EXTEND)
RTW_WARN("%s: unknown C2H(0x%02x, 0x%02x)\n", __func__, id, sub_id);
else
RTW_WARN("%s: unknown C2H(0x%02x)\n", __func__, id);
}
return ret;
}
#ifndef RTW_HALMAC
s32 rtw_hal_c2h_handler(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
{
s32 ret = _FAIL;
ret = adapter->hal_func.c2h_handler(adapter, id, seq, plen, payload);
if (ret != _SUCCESS)
ret = c2h_handler(adapter, id, seq, plen, payload);
return ret;
}
s32 rtw_hal_c2h_id_handle_directly(_adapter *adapter, u8 id, u8 seq, u8 plen, u8 *payload)
{
switch (id) {
case C2H_CCX_TX_RPT:
case C2H_BT_MP_INFO:
case C2H_FW_CHNL_SWITCH_COMPLETE:
case C2H_IQK_FINISH:
case C2H_MCC:
case C2H_BCN_EARLY_RPT:
case C2H_AP_REQ_TXRPT:
case C2H_SPC_STAT:
return _TRUE;
default:
return _FALSE;
}
}
#endif /* !RTW_HALMAC */
s32 rtw_hal_is_disable_sw_channel_plan(PADAPTER padapter)
{
return GET_HAL_DATA(padapter)->bDisableSWChannelPlan;
}
static s32 _rtw_hal_macid_sleep(_adapter *adapter, u8 macid, u8 sleep)
{
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
u16 reg_sleep;
u8 bit_shift;
u32 val32;
s32 ret = _FAIL;
if (macid >= macid_ctl->num) {
RTW_ERR(ADPT_FMT" %s invalid macid(%u)\n"
, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup" , macid);
goto exit;
}
if (macid < 32) {
reg_sleep = macid_ctl->reg_sleep_m0;
bit_shift = macid;
#if (MACID_NUM_SW_LIMIT > 32)
} else if (macid < 64) {
reg_sleep = macid_ctl->reg_sleep_m1;
bit_shift = macid - 32;
#endif
#if (MACID_NUM_SW_LIMIT > 64)
} else if (macid < 96) {
reg_sleep = macid_ctl->reg_sleep_m2;
bit_shift = macid - 64;
#endif
#if (MACID_NUM_SW_LIMIT > 96)
} else if (macid < 128) {
reg_sleep = macid_ctl->reg_sleep_m3;
bit_shift = macid - 96;
#endif
} else {
rtw_warn_on(1);
goto exit;
}
if (!reg_sleep) {
rtw_warn_on(1);
goto exit;
}
val32 = rtw_read32(adapter, reg_sleep);
RTW_INFO(ADPT_FMT" %s macid=%d, ori reg_0x%03x=0x%08x\n"
, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup"
, macid, reg_sleep, val32);
ret = _SUCCESS;
if (sleep) {
if (val32 & BIT(bit_shift))
goto exit;
val32 |= BIT(bit_shift);
} else {
if (!(val32 & BIT(bit_shift)))
goto exit;
val32 &= ~BIT(bit_shift);
}
rtw_write32(adapter, reg_sleep, val32);
exit:
return ret;
}
inline s32 rtw_hal_macid_sleep(_adapter *adapter, u8 macid)
{
return _rtw_hal_macid_sleep(adapter, macid, 1);
}
inline s32 rtw_hal_macid_wakeup(_adapter *adapter, u8 macid)
{
return _rtw_hal_macid_sleep(adapter, macid, 0);
}
static s32 _rtw_hal_macid_bmp_sleep(_adapter *adapter, struct macid_bmp *bmp, u8 sleep)
{
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
u16 reg_sleep;
u32 m;
u8 mid = 0;
u32 val32;
do {
if (mid == 0) {
m = bmp->m0;
reg_sleep = macid_ctl->reg_sleep_m0;
#if (MACID_NUM_SW_LIMIT > 32)
} else if (mid == 1) {
m = bmp->m1;
reg_sleep = macid_ctl->reg_sleep_m1;
#endif
#if (MACID_NUM_SW_LIMIT > 64)
} else if (mid == 2) {
m = bmp->m2;
reg_sleep = macid_ctl->reg_sleep_m2;
#endif
#if (MACID_NUM_SW_LIMIT > 96)
} else if (mid == 3) {
m = bmp->m3;
reg_sleep = macid_ctl->reg_sleep_m3;
#endif
} else {
rtw_warn_on(1);
break;
}
if (m == 0)
goto move_next;
if (!reg_sleep) {
rtw_warn_on(1);
break;
}
val32 = rtw_read32(adapter, reg_sleep);
RTW_INFO(ADPT_FMT" %s m%u=0x%08x, ori reg_0x%03x=0x%08x\n"
, ADPT_ARG(adapter), sleep ? "sleep" : "wakeup"
, mid, m, reg_sleep, val32);
if (sleep) {
if ((val32 & m) == m)
goto move_next;
val32 |= m;
} else {
if ((val32 & m) == 0)
goto move_next;
val32 &= ~m;
}
rtw_write32(adapter, reg_sleep, val32);
move_next:
mid++;
} while (mid * 32 < MACID_NUM_SW_LIMIT);
return _SUCCESS;
}
inline s32 rtw_hal_macid_sleep_all_used(_adapter *adapter)
{
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
return _rtw_hal_macid_bmp_sleep(adapter, &macid_ctl->used, 1);
}
inline s32 rtw_hal_macid_wakeup_all_used(_adapter *adapter)
{
struct macid_ctl_t *macid_ctl = adapter_to_macidctl(adapter);
return _rtw_hal_macid_bmp_sleep(adapter, &macid_ctl->used, 0);
}
s32 rtw_hal_fill_h2c_cmd(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer)
{
_adapter *pri_adapter = GET_PRIMARY_ADAPTER(padapter);
if (GET_HAL_DATA(pri_adapter)->bFWReady == _TRUE)
return padapter->hal_func.fill_h2c_cmd(padapter, ElementID, CmdLen, pCmdBuffer);
else if (padapter->registrypriv.mp_mode == 0)
RTW_PRINT(FUNC_ADPT_FMT" FW doesn't exit when no MP mode, by pass H2C id:0x%02x\n"
, FUNC_ADPT_ARG(padapter), ElementID);
return _FAIL;
}
void rtw_hal_fill_fake_txdesc(_adapter *padapter, u8 *pDesc, u32 BufferLen,
u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame)
{
padapter->hal_func.fill_fake_txdesc(padapter, pDesc, BufferLen, IsPsPoll, IsBTQosNull, bDataFrame);
}
u8 rtw_hal_get_txbuff_rsvd_page_num(_adapter *adapter, bool wowlan)
{
u8 num = 0;
if (adapter->hal_func.hal_get_tx_buff_rsvd_page_num) {
num = adapter->hal_func.hal_get_tx_buff_rsvd_page_num(adapter, wowlan);
} else {
#ifdef RTW_HALMAC
num = GET_HAL_DATA(adapter)->drv_rsvd_page_number;
#endif /* RTW_HALMAC */
}
return num;
}
#ifdef CONFIG_GPIO_API
void rtw_hal_update_hisr_hsisr_ind(_adapter *padapter, u32 flag)
{
if (padapter->hal_func.update_hisr_hsisr_ind)
padapter->hal_func.update_hisr_hsisr_ind(padapter, flag);
}
int rtw_hal_gpio_func_check(_adapter *padapter, u8 gpio_num)
{
int ret = _SUCCESS;
if (padapter->hal_func.hal_gpio_func_check)
ret = padapter->hal_func.hal_gpio_func_check(padapter, gpio_num);
return ret;
}
void rtw_hal_gpio_multi_func_reset(_adapter *padapter, u8 gpio_num)
{
if (padapter->hal_func.hal_gpio_multi_func_reset)
padapter->hal_func.hal_gpio_multi_func_reset(padapter, gpio_num);
}
#endif
#ifdef CONFIG_FW_CORRECT_BCN
void rtw_hal_fw_correct_bcn(_adapter *padapter)
{
if (padapter->hal_func.fw_correct_bcn)
padapter->hal_func.fw_correct_bcn(padapter);
}
#endif
void rtw_hal_set_tx_power_level(_adapter *adapter, u8 channel)
{
adapter->hal_func.set_tx_power_level_handler(adapter, channel);
rtw_hal_set_txpwr_done(adapter);
}
void rtw_hal_set_txpwr_done(_adapter *adapter)
{
if (adapter->hal_func.set_txpwr_done)
adapter->hal_func.set_txpwr_done(adapter);
}
void rtw_hal_set_tx_power_index(_adapter *adapter, u32 powerindex
, enum rf_path rfpath, u8 rate)
{
adapter->hal_func.set_tx_power_index_handler(adapter, powerindex, rfpath, rate);
}
u8 rtw_hal_get_tx_power_index(_adapter *adapter, enum rf_path rfpath, u8 rate
, u8 bandwidth, u8 channel, struct txpwr_idx_comp *tic)
{
return adapter->hal_func.get_tx_power_index_handler(adapter, rfpath, rate
, bandwidth, channel, tic);
}
#ifdef RTW_HALMAC
/*
* Description:
* Initialize MAC registers
*
* Return:
* _TRUE success
* _FALSE fail
*/
u8 rtw_hal_init_mac_register(PADAPTER adapter)
{
return adapter->hal_func.init_mac_register(adapter);
}
/*
* Description:
* Initialize PHY(BB/RF) related functions
*
* Return:
* _TRUE success
* _FALSE fail
*/
u8 rtw_hal_init_phy(PADAPTER adapter)
{
return adapter->hal_func.init_phy(adapter);
}
#endif /* RTW_HALMAC */
#ifdef CONFIG_RFKILL_POLL
bool rtw_hal_rfkill_poll(_adapter *adapter, u8 *valid)
{
bool ret;
if (adapter->hal_func.hal_radio_onoff_check)
ret = adapter->hal_func.hal_radio_onoff_check(adapter, valid);
else {
*valid = 0;
ret = _FALSE;
}
return ret;
}
#endif
#define rtw_hal_error_msg(ops_fun) \
RTW_PRINT("### %s - Error : Please hook hal_func.%s ###\n", __FUNCTION__, ops_fun)
u8 rtw_hal_ops_check(_adapter *padapter)
{
u8 ret = _SUCCESS;
#if 1
/*** initialize section ***/
if (NULL == padapter->hal_func.read_chip_version) {
rtw_hal_error_msg("read_chip_version");
ret = _FAIL;
}
if (NULL == padapter->hal_func.init_default_value) {
rtw_hal_error_msg("init_default_value");
ret = _FAIL;
}
if (NULL == padapter->hal_func.intf_chip_configure) {
rtw_hal_error_msg("intf_chip_configure");
ret = _FAIL;
}
if (NULL == padapter->hal_func.read_adapter_info) {
rtw_hal_error_msg("read_adapter_info");
ret = _FAIL;
}
if (NULL == padapter->hal_func.hal_power_on) {
rtw_hal_error_msg("hal_power_on");
ret = _FAIL;
}
if (NULL == padapter->hal_func.hal_power_off) {
rtw_hal_error_msg("hal_power_off");
ret = _FAIL;
}
if (NULL == padapter->hal_func.hal_init) {
rtw_hal_error_msg("hal_init");
ret = _FAIL;
}
if (NULL == padapter->hal_func.hal_deinit) {
rtw_hal_error_msg("hal_deinit");
ret = _FAIL;
}
/*** xmit section ***/
if (NULL == padapter->hal_func.init_xmit_priv) {
rtw_hal_error_msg("init_xmit_priv");
ret = _FAIL;
}
if (NULL == padapter->hal_func.free_xmit_priv) {
rtw_hal_error_msg("free_xmit_priv");
ret = _FAIL;
}
if (NULL == padapter->hal_func.hal_xmit) {
rtw_hal_error_msg("hal_xmit");
ret = _FAIL;
}
if (NULL == padapter->hal_func.mgnt_xmit) {
rtw_hal_error_msg("mgnt_xmit");
ret = _FAIL;
}
#ifdef CONFIG_XMIT_THREAD_MODE
if (NULL == padapter->hal_func.xmit_thread_handler) {
rtw_hal_error_msg("xmit_thread_handler");
ret = _FAIL;
}
#endif
if (NULL == padapter->hal_func.hal_xmitframe_enqueue) {
rtw_hal_error_msg("hal_xmitframe_enqueue");
ret = _FAIL;
}
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
#ifndef CONFIG_SDIO_TX_TASKLET
if (NULL == padapter->hal_func.run_thread) {
rtw_hal_error_msg("run_thread");
ret = _FAIL;
}
if (NULL == padapter->hal_func.cancel_thread) {
rtw_hal_error_msg("cancel_thread");
ret = _FAIL;
}
#endif
#endif
/*** recv section ***/
if (NULL == padapter->hal_func.init_recv_priv) {
rtw_hal_error_msg("init_recv_priv");
ret = _FAIL;
}
if (NULL == padapter->hal_func.free_recv_priv) {
rtw_hal_error_msg("free_recv_priv");
ret = _FAIL;
}
#ifdef CONFIG_RECV_THREAD_MODE
if (NULL == padapter->hal_func.recv_hdl) {
rtw_hal_error_msg("recv_hdl");
ret = _FAIL;
}
#endif
#if defined(CONFIG_USB_HCI) || defined(CONFIG_PCI_HCI)
if (NULL == padapter->hal_func.inirp_init) {
rtw_hal_error_msg("inirp_init");
ret = _FAIL;
}
if (NULL == padapter->hal_func.inirp_deinit) {
rtw_hal_error_msg("inirp_deinit");
ret = _FAIL;
}
#endif /* #if defined(CONFIG_USB_HCI) || defined (CONFIG_PCI_HCI) */
/*** interrupt hdl section ***/
#if defined(CONFIG_PCI_HCI)
if (NULL == padapter->hal_func.irp_reset) {
rtw_hal_error_msg("irp_reset");
ret = _FAIL;
}
#endif/*#if defined(CONFIG_PCI_HCI)*/
#if (defined(CONFIG_PCI_HCI)) || (defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT))
if (NULL == padapter->hal_func.interrupt_handler) {
rtw_hal_error_msg("interrupt_handler");
ret = _FAIL;
}
#endif /*#if (defined(CONFIG_PCI_HCI)) || (defined(CONFIG_USB_HCI) && defined(CONFIG_SUPPORT_USB_INT))*/
#if defined(CONFIG_PCI_HCI) || defined(CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI)
if (NULL == padapter->hal_func.enable_interrupt) {
rtw_hal_error_msg("enable_interrupt");
ret = _FAIL;
}
if (NULL == padapter->hal_func.disable_interrupt) {
rtw_hal_error_msg("disable_interrupt");
ret = _FAIL;
}
#endif /* defined(CONFIG_PCI_HCI) || defined (CONFIG_SDIO_HCI) || defined (CONFIG_GSPI_HCI) */
/*** DM section ***/
if (NULL == padapter->hal_func.dm_init) {
rtw_hal_error_msg("dm_init");
ret = _FAIL;
}
if (NULL == padapter->hal_func.dm_deinit) {
rtw_hal_error_msg("dm_deinit");
ret = _FAIL;
}
if (NULL == padapter->hal_func.hal_dm_watchdog) {
rtw_hal_error_msg("hal_dm_watchdog");
ret = _FAIL;
}
/*** xxx section ***/
if (NULL == padapter->hal_func.set_chnl_bw_handler) {
rtw_hal_error_msg("set_chnl_bw_handler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.set_hw_reg_handler) {
rtw_hal_error_msg("set_hw_reg_handler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.GetHwRegHandler) {
rtw_hal_error_msg("GetHwRegHandler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.get_hal_def_var_handler) {
rtw_hal_error_msg("get_hal_def_var_handler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.SetHalDefVarHandler) {
rtw_hal_error_msg("SetHalDefVarHandler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.GetHalODMVarHandler) {
rtw_hal_error_msg("GetHalODMVarHandler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.SetHalODMVarHandler) {
rtw_hal_error_msg("SetHalODMVarHandler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.SetBeaconRelatedRegistersHandler) {
rtw_hal_error_msg("SetBeaconRelatedRegistersHandler");
ret = _FAIL;
}
if (NULL == padapter->hal_func.fill_h2c_cmd) {
rtw_hal_error_msg("fill_h2c_cmd");
ret = _FAIL;
}
#ifdef RTW_HALMAC
if (NULL == padapter->hal_func.hal_mac_c2h_handler) {
rtw_hal_error_msg("hal_mac_c2h_handler");
ret = _FAIL;
}
#elif !defined(CONFIG_RTL8188E)
if (NULL == padapter->hal_func.c2h_handler) {
rtw_hal_error_msg("c2h_handler");
ret = _FAIL;
}
#endif
#if defined(CONFIG_LPS) || defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
if (NULL == padapter->hal_func.fill_fake_txdesc) {
rtw_hal_error_msg("fill_fake_txdesc");
ret = _FAIL;
}
#endif
#ifndef RTW_HALMAC
if (NULL == padapter->hal_func.hal_get_tx_buff_rsvd_page_num) {
rtw_hal_error_msg("hal_get_tx_buff_rsvd_page_num");
ret = _FAIL;
}
#endif /* !RTW_HALMAC */
#if defined(CONFIG_WOWLAN) || defined(CONFIG_AP_WOWLAN)
#if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI)
if (NULL == padapter->hal_func.clear_interrupt) {
rtw_hal_error_msg("clear_interrupt");
ret = _FAIL;
}
#endif
#endif /* CONFIG_WOWLAN */
if (NULL == padapter->hal_func.fw_dl) {
rtw_hal_error_msg("fw_dl");
ret = _FAIL;
}
#ifdef CONFIG_FW_CORRECT_BCN
if (IS_HARDWARE_TYPE_8814A(padapter)
&& NULL == padapter->hal_func.fw_correct_bcn) {
rtw_hal_error_msg("fw_correct_bcn");
ret = _FAIL;
}
#endif
if (!padapter->hal_func.set_tx_power_level_handler) {
rtw_hal_error_msg("set_tx_power_level_handler");
ret = _FAIL;
}
if (!padapter->hal_func.set_tx_power_index_handler) {
rtw_hal_error_msg("set_tx_power_index_handler");
ret = _FAIL;
}
if (!padapter->hal_func.get_tx_power_index_handler) {
rtw_hal_error_msg("get_tx_power_index_handler");
ret = _FAIL;
}
/*** SReset section ***/
#ifdef DBG_CONFIG_ERROR_DETECT
if (NULL == padapter->hal_func.sreset_init_value) {
rtw_hal_error_msg("sreset_init_value");
ret = _FAIL;
}
if (NULL == padapter->hal_func.sreset_reset_value) {
rtw_hal_error_msg("sreset_reset_value");
ret = _FAIL;
}
if (NULL == padapter->hal_func.silentreset) {
rtw_hal_error_msg("silentreset");
ret = _FAIL;
}
if (NULL == padapter->hal_func.sreset_xmit_status_check) {
rtw_hal_error_msg("sreset_xmit_status_check");
ret = _FAIL;
}
if (NULL == padapter->hal_func.sreset_linked_status_check) {
rtw_hal_error_msg("sreset_linked_status_check");
ret = _FAIL;
}
if (NULL == padapter->hal_func.sreset_get_wifi_status) {
rtw_hal_error_msg("sreset_get_wifi_status");
ret = _FAIL;
}
if (NULL == padapter->hal_func.sreset_inprogress) {
rtw_hal_error_msg("sreset_inprogress");
ret = _FAIL;
}
#endif /* #ifdef DBG_CONFIG_ERROR_DETECT */
#ifdef RTW_HALMAC
if (NULL == padapter->hal_func.init_mac_register) {
rtw_hal_error_msg("init_mac_register");
ret = _FAIL;
}
if (NULL == padapter->hal_func.init_phy) {
rtw_hal_error_msg("init_phy");
ret = _FAIL;
}
#endif /* RTW_HALMAC */
#ifdef CONFIG_RFKILL_POLL
if (padapter->hal_func.hal_radio_onoff_check == NULL) {
rtw_hal_error_msg("hal_radio_onoff_check");
ret = _FAIL;
}
#endif
#endif
return ret;
}
================================================
FILE: hal/hal_mcc.c
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifdef CONFIG_MCC_MODE
#define _HAL_MCC_C_
#include /* PADAPTER */
#include /* mcc structure */
#include /* HAL_DATA */
#include /* power control */
/* use for AP/GO + STA/GC case */
#define MCC_DURATION_IDX 0 /* druration for station side */
#define MCC_TSF_SYNC_OFFSET_IDX 1
#define MCC_START_TIME_OFFSET_IDX 2
#define MCC_INTERVAL_IDX 3
#define MCC_GUARD_OFFSET0_IDX 4
#define MCC_GUARD_OFFSET1_IDX 5
#define MCC_STOP_THRESHOLD 6
#define TU 1024 /* 1 TU equals 1024 microseconds */
/* druration, TSF sync offset, start time offset, interval (unit:TU (1024 microseconds))*/
u8 mcc_switch_channel_policy_table[][7]={
{20, 50, 40, 100, 0, 0, 30},
{80, 50, 10, 100, 0, 0, 30},
{36, 50, 32, 100, 0, 0, 30},
{30, 50, 35, 100, 0, 0, 30},
};
const int mcc_max_policy_num = sizeof(mcc_switch_channel_policy_table) /sizeof(u8) /7;
static void dump_iqk_val_table(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct hal_iqk_reg_backup *iqk_reg_backup = pHalData->iqk_reg_backup;
u8 total_rf_path = pHalData->NumTotalRFPath;
u8 rf_path_idx = 0;
u8 backup_chan_idx = 0;
u8 backup_reg_idx = 0;
#ifdef CONFIG_MCC_MODE_V2
#else
RTW_INFO("=============dump IQK backup table================\n");
for (backup_chan_idx = 0; backup_chan_idx < MAX_IQK_INFO_BACKUP_CHNL_NUM; backup_chan_idx++) {
for (rf_path_idx = 0; rf_path_idx < total_rf_path; rf_path_idx++) {
for(backup_reg_idx = 0; backup_reg_idx < MAX_IQK_INFO_BACKUP_REG_NUM; backup_reg_idx++) {
RTW_INFO("ch:%d. bw:%d. rf path:%d. reg[%d] = 0x%02x \n"
, iqk_reg_backup[backup_chan_idx].central_chnl
, iqk_reg_backup[backup_chan_idx].bw_mode
, rf_path_idx
, backup_reg_idx
, iqk_reg_backup[backup_chan_idx].reg_backup[rf_path_idx][backup_reg_idx]
);
}
}
}
RTW_INFO("=============================================\n");
#endif
}
static void rtw_hal_mcc_build_p2p_noa_attr(PADAPTER padapter, u8 *ie, u32 *ie_len)
{
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
u8 p2p_noa_attr_ie[MAX_P2P_IE_LEN] = {0x00};
u32 p2p_noa_attr_len = 0;
u8 noa_desc_num = 1;
u8 opp_ps = 0; /* Disable OppPS */
u8 noa_count = 255;
u32 noa_duration;
u32 noa_interval;
u8 noa_index = 0;
u8 mcc_policy_idx = 0;
mcc_policy_idx = pmccobjpriv->policy_index;
noa_duration = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX] * TU;
noa_interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX] * TU;
/* P2P OUI(4 bytes) */
_rtw_memcpy(p2p_noa_attr_ie, P2P_OUI, 4);
p2p_noa_attr_len = p2p_noa_attr_len + 4;
/* attrute ID(1 byte) */
p2p_noa_attr_ie[p2p_noa_attr_len] = P2P_ATTR_NOA;
p2p_noa_attr_len = p2p_noa_attr_len + 1;
/* attrute length(2 bytes) length = noa_desc_num*13 + 2 */
RTW_PUT_LE16(p2p_noa_attr_ie + p2p_noa_attr_len, (noa_desc_num * 13 + 2));
p2p_noa_attr_len = p2p_noa_attr_len + 2;
/* Index (1 byte) */
p2p_noa_attr_ie[p2p_noa_attr_len] = noa_index;
p2p_noa_attr_len = p2p_noa_attr_len + 1;
/* CTWindow and OppPS Parameters (1 byte) */
p2p_noa_attr_ie[p2p_noa_attr_len] = opp_ps;
p2p_noa_attr_len = p2p_noa_attr_len+ 1;
/* NoA Count (1 byte) */
p2p_noa_attr_ie[p2p_noa_attr_len] = noa_count;
p2p_noa_attr_len = p2p_noa_attr_len + 1;
/* NoA Duration (4 bytes) unit: microseconds */
RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, noa_duration);
p2p_noa_attr_len = p2p_noa_attr_len + 4;
/* NoA Interval (4 bytes) unit: microseconds */
RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, noa_interval);
p2p_noa_attr_len = p2p_noa_attr_len + 4;
/* NoA Start Time (4 bytes) unit: microseconds */
RTW_PUT_LE32(p2p_noa_attr_ie + p2p_noa_attr_len, pmccadapriv->noa_start_time);
if (0)
RTW_INFO("indxe:%d, start_time=0x%02x:0x%02x:0x%02x:0x%02x\n"
, noa_index
, p2p_noa_attr_ie[p2p_noa_attr_len]
, p2p_noa_attr_ie[p2p_noa_attr_len + 1]
, p2p_noa_attr_ie[p2p_noa_attr_len + 2]
, p2p_noa_attr_ie[p2p_noa_attr_len + 3]);
p2p_noa_attr_len = p2p_noa_attr_len + 4;
rtw_set_ie(ie, _VENDOR_SPECIFIC_IE_, p2p_noa_attr_len, (u8 *)p2p_noa_attr_ie, ie_len);
}
/**
* rtw_hal_mcc_update_go_p2p_ie - update go p2p ie(add NoA attribute)
* @padapter: the adapter to be update go p2p ie
*/
static void rtw_hal_mcc_update_go_p2p_ie(PADAPTER padapter)
{
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
u8 *pos = NULL;
/* no noa attribute, build it */
if (pmccadapriv->p2p_go_noa_ie_len == 0)
rtw_hal_mcc_build_p2p_noa_attr(padapter, pmccadapriv->p2p_go_noa_ie, &pmccadapriv->p2p_go_noa_ie_len);
else {
/* has noa attribut, modify it */
u32 noa_duration = 0;
/* update index */
pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 15;
/* 0~255 */
(*pos) = ((*pos) + 1) % 256;
if (0)
RTW_INFO("indxe:%d\n", (*pos));
/* update duration */
noa_duration = mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_DURATION_IDX] * TU;
pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 12;
RTW_PUT_LE32(pos, noa_duration);
/* update start time */
pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len - 4;
RTW_PUT_LE32(pos, pmccadapriv->noa_start_time);
if (0)
RTW_INFO("start_time=0x%02x:0x%02x:0x%02x:0x%02x\n"
, ((u8*)(pos))[0]
, ((u8*)(pos))[1]
, ((u8*)(pos))[2]
, ((u8*)(pos))[3]);
}
if (0) {
RTW_INFO("p2p_go_noa_ie_len:%d\n", pmccadapriv->p2p_go_noa_ie_len);
RTW_INFO_DUMP("\n", pmccadapriv->p2p_go_noa_ie, pmccadapriv->p2p_go_noa_ie_len);
}
update_beacon(padapter, _VENDOR_SPECIFIC_IE_, P2P_OUI, _TRUE, 0);
}
/**
* rtw_hal_mcc_remove_go_p2p_ie - remove go p2p ie(add NoA attribute)
* @padapter: the adapter to be update go p2p ie
*/
static void rtw_hal_mcc_remove_go_p2p_ie(PADAPTER padapter)
{
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
/* chech has noa ie or not */
if (pmccadapriv->p2p_go_noa_ie_len == 0)
return;
pmccadapriv->p2p_go_noa_ie_len = 0;
update_beacon(padapter, _VENDOR_SPECIFIC_IE_, P2P_OUI, _TRUE, 0);
}
/* restore IQK value for all interface */
void rtw_hal_mcc_restore_iqk_val(PADAPTER padapter)
{
u8 take_care_iqk = _FALSE;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface = NULL;
struct mcc_adapter_priv *mccadapriv = NULL;
u8 i = 0;
rtw_hal_get_hwreg(padapter, HW_VAR_CH_SW_NEED_TO_TAKE_CARE_IQK_INFO, &take_care_iqk);
if (take_care_iqk == _TRUE && MCC_EN(padapter)) {
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
rtw_hal_ch_sw_iqk_info_restore(iface, CH_SW_USE_CASE_MCC);
}
}
if (0)
dump_iqk_val_table(padapter);
}
u8 rtw_hal_check_mcc_status(PADAPTER padapter, u8 mcc_status)
{
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
if (pmccobjpriv->mcc_status & (mcc_status))
return _TRUE;
else
return _FALSE;
}
void rtw_hal_set_mcc_status(PADAPTER padapter, u8 mcc_status)
{
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
pmccobjpriv->mcc_status |= (mcc_status);
}
void rtw_hal_clear_mcc_status(PADAPTER padapter, u8 mcc_status)
{
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
pmccobjpriv->mcc_status &= (~mcc_status);
}
static void rtw_hal_mcc_update_policy_table(PADAPTER adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
u8 mcc_duration = mccobjpriv->duration;
s8 mcc_policy_idx = mccobjpriv->policy_index;
u8 interval = mcc_switch_channel_policy_table[mcc_policy_idx][MCC_INTERVAL_IDX];
u8 new_mcc_duration_time = 0;
u8 new_starttime_offset = 0;
/* convert % to ms */
new_mcc_duration_time = mcc_duration * interval / 100;
/* start time offset = (interval - duration time)/2 */
new_starttime_offset = (interval - new_mcc_duration_time) >> 1;
/* update modified parameters */
mcc_switch_channel_policy_table[mcc_policy_idx][MCC_DURATION_IDX]
= new_mcc_duration_time;
mcc_switch_channel_policy_table[mcc_policy_idx][MCC_START_TIME_OFFSET_IDX]
= new_starttime_offset;
}
static void rtw_hal_config_mcc_switch_channel_setting(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
struct registry_priv *registry_par = &padapter->registrypriv;
u8 mcc_duration = 0;
s8 mcc_policy_idx = 0;
mcc_policy_idx = registry_par->rtw_mcc_policy_table_idx;
mcc_duration = mccobjpriv->duration;
if (mcc_policy_idx < 0 || mcc_policy_idx >= mcc_max_policy_num) {
mccobjpriv->policy_index = 0;
RTW_INFO("[MCC] can't find table(%d), use default policy(%d)\n",
mcc_policy_idx, mccobjpriv->policy_index);
} else
mccobjpriv->policy_index = mcc_policy_idx;
/* convert % to time */
if (mcc_duration != 0)
rtw_hal_mcc_update_policy_table(padapter);
RTW_INFO("[MCC] policy(%d): %d,%d,%d,%d,%d,%d\n"
, mccobjpriv->policy_index
, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_DURATION_IDX]
, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_TSF_SYNC_OFFSET_IDX]
, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_START_TIME_OFFSET_IDX]
, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_INTERVAL_IDX]
, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
, mcc_switch_channel_policy_table[mccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX]);
}
static void rtw_hal_mcc_assign_tx_threshold(PADAPTER padapter)
{
struct registry_priv *preg = &padapter->registrypriv;
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
switch (pmccadapriv->role) {
case MCC_ROLE_STA:
case MCC_ROLE_GC:
switch (pmlmeext->cur_bwmode) {
case CHANNEL_WIDTH_20:
/*
* target tx byte(bytes) = target tx tp(Mbits/sec) * 1024 * 1024 / 8 * (duration(ms) / 1024)
* = target tx tp(Mbits/sec) * 128 * duration(ms)
* note:
* target tx tp(Mbits/sec) * 1024 * 1024 / 8 ==> Mbits to bytes
* duration(ms) / 1024 ==> msec to sec
*/
pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_sta_bw20_target_tx_tp * 128 * pmccadapriv->mcc_duration;
break;
case CHANNEL_WIDTH_40:
pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_sta_bw40_target_tx_tp * 128 * pmccadapriv->mcc_duration;
break;
case CHANNEL_WIDTH_80:
pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_sta_bw80_target_tx_tp * 128 * pmccadapriv->mcc_duration;
break;
case CHANNEL_WIDTH_160:
case CHANNEL_WIDTH_80_80:
RTW_INFO(FUNC_ADPT_FMT": not support bwmode = %d\n"
, FUNC_ADPT_ARG(padapter), pmlmeext->cur_bwmode);
break;
}
break;
case MCC_ROLE_AP:
case MCC_ROLE_GO:
switch (pmlmeext->cur_bwmode) {
case CHANNEL_WIDTH_20:
pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw20_target_tx_tp * 128 * pmccadapriv->mcc_duration;
break;
case CHANNEL_WIDTH_40:
pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw40_target_tx_tp * 128 * pmccadapriv->mcc_duration;
break;
case CHANNEL_WIDTH_80:
pmccadapriv->mcc_target_tx_bytes_to_port = preg->rtw_mcc_ap_bw80_target_tx_tp * 128 * pmccadapriv->mcc_duration;
break;
case CHANNEL_WIDTH_160:
case CHANNEL_WIDTH_80_80:
RTW_INFO(FUNC_ADPT_FMT": not support bwmode = %d\n"
, FUNC_ADPT_ARG(padapter), pmlmeext->cur_bwmode);
break;
}
break;
default:
RTW_INFO(FUNC_ADPT_FMT": unknown role = %d\n"
, FUNC_ADPT_ARG(padapter), pmccadapriv->role);
break;
}
}
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
static void mcc_cfg_phdym_rf_ch (_adapter *adapter)
{
struct mcc_adapter_priv *mccadapriv = &adapter->mcc_adapterpriv;
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
struct dm_struct *dm = &hal->odmpriv;
struct _phydm_mcc_dm_ *mcc_dm = &dm->mcc_dm;
u8 order = 0;
set_channel_bwmode(adapter, mlmeext->cur_channel, mlmeext->cur_ch_offset, mlmeext->cur_bwmode);
order = mccadapriv->order;
mcc_dm->mcc_rf_channel[order] = phy_query_rf_reg(adapter, RF_PATH_A, 0x18, 0xffffffff);
}
static void mcc_cfg_phdym_update_macid (_adapter *adapter, u8 add, u8 mac_id)
{
struct mcc_adapter_priv *mccadapriv = &adapter->mcc_adapterpriv;
struct mlme_ext_priv *mlmeext = &adapter->mlmeextpriv;
HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
struct dm_struct *dm = &hal->odmpriv;
struct _phydm_mcc_dm_ *mcc_dm = &dm->mcc_dm;
u8 order = 0, i = 0;
order = mccadapriv->order;
if (add) {
for (i = 0; i < NUM_STA; i++) {
if (mcc_dm->sta_macid[order][i] == 0xff) {
mcc_dm->sta_macid[order][i] = mac_id;
break;
}
}
} else {
for (i = 0; i < NUM_STA; i++) {
if (mcc_dm->sta_macid[order][i] == mac_id) {
mcc_dm->sta_macid[order][i] = 0xff;
break;
}
}
}
}
static void mcc_cfg_phdym_start(_adapter *adapter, u8 start)
{
struct dvobj_priv *dvobj;
struct mcc_obj_priv *mccobjpriv;
HAL_DATA_TYPE *hal;
struct dm_struct *dm;
struct _phydm_mcc_dm_ *mcc_dm;
u8 rfk_forbidden = _TRUE;
u8 i = 0, j = 0;
dvobj = adapter_to_dvobj(adapter);
mccobjpriv = adapter_to_mccobjpriv(adapter);
hal = GET_HAL_DATA(adapter);
dm = &hal->odmpriv;
mcc_dm = &dm->mcc_dm;
if (start) {
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
mcc_dm->mcc_status = mccobjpriv->mcc_phydm_offload;
#endif
rfk_forbidden = _TRUE;
halrf_cmn_info_set(dm, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
} else {
rfk_forbidden = _FALSE;
halrf_cmn_info_set(dm, HALRF_CMNINFO_RFK_FORBIDDEN, rfk_forbidden);
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
for(i = 0; i < MAX_MCC_NUM; i ++) {
for(j = 0; j < NUM_STA; j ++) {
if (mcc_dm->sta_macid[i][j] != 0xff)
/* clear all used value for mcc stop */
/* do nothing for mcc start due to phydm will init to 0xff */
mcc_dm->sta_macid[i][j] = 0xff;
}
mcc_dm->mcc_rf_channel[i] = 0xff;
}
mcc_dm->mcc_status = 0;
#endif
}
}
static void mcc_cfg_phdym_dump(_adapter *adapter, void *sel)
{
HAL_DATA_TYPE *hal;
struct dm_struct *dm;
struct _phydm_mcc_dm_ *mcc_dm;
u8 rfk_forbidden = _TRUE;
u8 i = 0, j = 0;
hal = GET_HAL_DATA(adapter);
dm = &hal->odmpriv;
mcc_dm = &dm->mcc_dm;
rfk_forbidden = halrf_cmn_info_get(dm, HALRF_CMNINFO_RFK_FORBIDDEN);
RTW_PRINT_SEL(sel, "dump mcc dm info\n");
RTW_PRINT_SEL(sel, "mcc_status=%d\n", mcc_dm->mcc_status);
RTW_PRINT_SEL(sel, "rfk_forbidden=%d\n", rfk_forbidden);
for(i = 0; i < MAX_MCC_NUM; i ++) {
if (mcc_dm->mcc_rf_channel[i] != 0xff)
RTW_PRINT_SEL(sel, "mcc_dm->mcc_rf_channel[%d] = 0x%02x\n", i, mcc_dm->mcc_rf_channel[i]);
for(j = 0; j < NUM_STA; j ++) {
if (mcc_dm->sta_macid[i][j] != 0xff)
RTW_PRINT_SEL(sel, "mcc_dm->sta_macid[%d][%d] = %d\n", i, j, mcc_dm->sta_macid[i][j]);
}
}
}
static void mcc_cfg_phdym_offload(_adapter *adapter, u8 enable)
{
struct mcc_obj_priv *mccobjpriv = adapter_to_mccobjpriv(adapter);
_adapter *iface = NULL;
struct mcc_adapter_priv *mccadapriv = NULL;
HAL_DATA_TYPE *hal = NULL;
struct dm_struct *dm = NULL;
struct _phydm_mcc_dm_ *mcc_dm = NULL;
struct sta_priv *stapriv = NULL;
struct sta_info *sta = NULL;
struct wlan_network *cur_network = NULL;
_irqL irqL;
_list *head = NULL, *list = NULL;
u8 i = 0;
hal = GET_HAL_DATA(adapter);
dm = &hal->odmpriv;
mcc_dm = &dm->mcc_dm;
/* due to phydm will rst related date, driver must set related data */
if (enable) {
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = mccobjpriv->iface[i];
if (!iface)
continue;
stapriv = &iface->stapriv;
mccadapriv = &iface->mcc_adapterpriv;
switch (mccadapriv->role) {
case MCC_ROLE_STA:
case MCC_ROLE_GC:
cur_network = &iface->mlmepriv.cur_network;
sta = rtw_get_stainfo(stapriv, cur_network->network.MacAddress);
if (sta)
mcc_cfg_phdym_update_macid(iface, _TRUE, sta->cmn.mac_id);
break;
case MCC_ROLE_AP:
case MCC_ROLE_GO:
_enter_critical_bh(&stapriv->asoc_list_lock, &irqL);
head = &stapriv->asoc_list;
list = get_next(head);
while ((rtw_end_of_queue_search(head, list)) == _FALSE) {
sta = LIST_CONTAINOR(list, struct sta_info, asoc_list);
list = get_next(list);
mcc_cfg_phdym_update_macid(iface, _TRUE, sta->cmn.mac_id);
}
_exit_critical_bh(&stapriv->asoc_list_lock, &irqL);
break;
default:
RTW_INFO("Unknown role\n");
rtw_warn_on(1);
break;
}
}
}
mcc_dm->mcc_status = enable;
}
static void rtw_hal_mcc_cfg_phydm (_adapter *adapter, enum mcc_cfg_phydm_ops ops, void *data)
{
switch (ops) {
case MCC_CFG_PHYDM_OFFLOAD:
mcc_cfg_phdym_offload(adapter, *(u8 *)data);
break;
case MCC_CFG_PHYDM_RF_CH:
mcc_cfg_phdym_rf_ch(adapter);
break;
case MCC_CFG_PHYDM_ADD_CLIENT:
mcc_cfg_phdym_update_macid(adapter, _TRUE, *(u8 *)data);
break;
case MCC_CFG_PHYDM_REMOVE_CLIENT:
mcc_cfg_phdym_update_macid(adapter, _FALSE, *(u8 *)data);
break;
case MCC_CFG_PHYDM_START:
mcc_cfg_phdym_start(adapter, _TRUE);
break;
case MCC_CFG_PHYDM_STOP:
mcc_cfg_phdym_start(adapter, _FALSE);
break;
case MCC_CFG_PHYDM_DUMP:
mcc_cfg_phdym_dump(adapter, data);
break;
case MCC_CFG_PHYDM_MAX:
default:
RTW_ERR("[MCC] rtw_hal_mcc_cfg_phydm ops error (%d)\n", ops);
break;
}
}
#endif
static void rtw_hal_config_mcc_role_setting(PADAPTER padapter, u8 order)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct wlan_network *cur_network = &(pmlmepriv->cur_network);
struct sta_priv *pstapriv = &padapter->stapriv;
struct sta_info *psta = NULL;
struct registry_priv *preg = &padapter->registrypriv;
_irqL irqL;
_list *phead =NULL, *plist = NULL;
u8 policy_index = 0;
u8 mcc_duration = 0;
u8 mcc_interval = 0;
u8 starting_ap_num = DEV_AP_STARTING_NUM(pdvobjpriv);
u8 ap_num = DEV_AP_NUM(pdvobjpriv);
policy_index = pmccobjpriv->policy_index;
mcc_duration = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_DURATION_IDX]
- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET0_IDX]
- mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_GUARD_OFFSET1_IDX];
mcc_interval = mcc_switch_channel_policy_table[pmccobjpriv->policy_index][MCC_INTERVAL_IDX];
if (starting_ap_num == 0 && ap_num == 0) {
pmccadapriv->order = order;
if (pmccadapriv->order == 0) {
/* setting is smiliar to GO/AP */
/* pmccadapriv->mcc_duration = mcc_interval - mcc_duration;*/
pmccadapriv->mgmt_queue_macid = MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID;
} else if (pmccadapriv->order == 1) {
/* pmccadapriv->mcc_duration = mcc_duration; */
pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
} else {
RTW_INFO("[MCC] not support >= 3 interface\n");
rtw_warn_on(1);
}
rtw_hal_mcc_assign_tx_threshold(padapter);
psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
if (psta) {
/* combine AP/GO macid and mgmt queue macid to bitmap */
pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_ADD_CLIENT, &psta->cmn.mac_id);
#endif
} else {
RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
}
} else {
/* GO/AP is 1nd order GC/STA is 2nd order */
switch (pmccadapriv->role) {
case MCC_ROLE_STA:
case MCC_ROLE_GC:
pmccadapriv->order = 1;
pmccadapriv->mcc_duration = mcc_duration;
rtw_hal_mcc_assign_tx_threshold(padapter);
/* assign used mac to avoid affecting RA */
pmccadapriv->mgmt_queue_macid = MCC_ROLE_STA_GC_MGMT_QUEUE_MACID;
psta = rtw_get_stainfo(pstapriv, cur_network->network.MacAddress);
if (psta) {
/* combine AP/GO macid and mgmt queue macid to bitmap */
pmccadapriv->mcc_macid_bitmap = BIT(psta->cmn.mac_id) | BIT(pmccadapriv->mgmt_queue_macid);
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_ADD_CLIENT, &psta->cmn.mac_id);
#endif
} else {
RTW_INFO(FUNC_ADPT_FMT":AP/GO station info is NULL\n", FUNC_ADPT_ARG(padapter));
rtw_warn_on(1);
}
break;
case MCC_ROLE_AP:
case MCC_ROLE_GO:
pmccadapriv->order = 0;
/* total druation value equals interval */
pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
pmccadapriv->p2p_go_noa_ie_len = 0; /* not NoA attribute at init time */
rtw_hal_mcc_assign_tx_threshold(padapter);
_enter_critical_bh(&pstapriv->asoc_list_lock, &irqL);
phead = &pstapriv->asoc_list;
plist = get_next(phead);
pmccadapriv->mcc_macid_bitmap = 0;
while ((rtw_end_of_queue_search(phead, plist)) == _FALSE) {
psta = LIST_CONTAINOR(plist, struct sta_info, asoc_list);
plist = get_next(plist);
pmccadapriv->mcc_macid_bitmap |= BIT(psta->cmn.mac_id);
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_ADD_CLIENT, &psta->cmn.mac_id);
#endif
}
_exit_critical_bh(&pstapriv->asoc_list_lock, &irqL);
psta = rtw_get_bcmc_stainfo(padapter);
if (psta != NULL)
pmccadapriv->mgmt_queue_macid = psta->cmn.mac_id;
else {
pmccadapriv->mgmt_queue_macid = MCC_ROLE_SOFTAP_GO_MGMT_QUEUE_MACID;
RTW_INFO(FUNC_ADPT_FMT":bcmc station is NULL, use macid %d\n"
, FUNC_ADPT_ARG(padapter), pmccadapriv->mgmt_queue_macid);
}
/* combine client macid and mgmt queue macid to bitmap */
pmccadapriv->mcc_macid_bitmap |= BIT(pmccadapriv->mgmt_queue_macid);
break;
default:
RTW_INFO("Unknown role\n");
rtw_warn_on(1);
break;
}
}
/* setting Null data parameters */
if (pmccadapriv->role == MCC_ROLE_STA) {
pmccadapriv->null_early = 3;
pmccadapriv->null_rty_num= 5;
} else if (pmccadapriv->role == MCC_ROLE_GC) {
pmccadapriv->null_early = 2;
pmccadapriv->null_rty_num= 5;
} else {
pmccadapriv->null_early = 0;
pmccadapriv->null_rty_num= 0;
}
RTW_INFO("********* "FUNC_ADPT_FMT" *********\n", FUNC_ADPT_ARG(padapter));
RTW_INFO("order:%d\n", pmccadapriv->order);
RTW_INFO("role:%d\n", pmccadapriv->role);
RTW_INFO("mcc duration:%d\n", pmccadapriv->mcc_duration);
RTW_INFO("null_early:%d\n", pmccadapriv->null_early);
RTW_INFO("null_rty_num:%d\n", pmccadapriv->null_rty_num);
RTW_INFO("mgmt queue macid:%d\n", pmccadapriv->mgmt_queue_macid);
RTW_INFO("bitmap:0x%02x\n", pmccadapriv->mcc_macid_bitmap);
RTW_INFO("target tx bytes:%d\n", pmccadapriv->mcc_target_tx_bytes_to_port);
RTW_INFO("**********************************\n");
pmccobjpriv->iface[pmccadapriv->order] = padapter;
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_RF_CH, NULL);
#endif
}
static void rtw_hal_mcc_rqt_tsf(PADAPTER padapter, u64 *out_tsf)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
PADAPTER order0_iface = NULL;
PADAPTER order1_iface = NULL;
struct submit_ctx *tsf_req_sctx = NULL;
enum _hw_port tsfx = MAX_HW_PORT;
enum _hw_port tsfy = MAX_HW_PORT;
u8 cmd[H2C_MCC_RQT_TSF_LEN] = {0};
_enter_critical_mutex(&mccobjpriv->mcc_tsf_req_mutex, NULL);
order0_iface = mccobjpriv->iface[0];
order1_iface = mccobjpriv->iface[1];
tsf_req_sctx = &mccobjpriv->mcc_tsf_req_sctx;
rtw_sctx_init(tsf_req_sctx, MCC_EXPIRE_TIME);
mccobjpriv->mcc_tsf_req_sctx_order = 0;
tsfx = rtw_hal_get_port(order0_iface);
tsfy = rtw_hal_get_port(order1_iface);
SET_H2CCMD_MCC_RQT_TSFX(cmd, tsfx);
SET_H2CCMD_MCC_RQT_TSFY(cmd, tsfy);
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_RQT_TSF, H2C_MCC_RQT_TSF_LEN, cmd);
if (!rtw_sctx_wait(tsf_req_sctx, __func__))
RTW_INFO(FUNC_ADPT_FMT": wait for mcc tsf req C2H time out\n", FUNC_ADPT_ARG(padapter));
if (tsf_req_sctx->status == RTW_SCTX_DONE_SUCCESS && out_tsf != NULL) {
out_tsf[0] = order0_iface->mcc_adapterpriv.tsf;
out_tsf[1] = order1_iface->mcc_adapterpriv.tsf;
}
_exit_critical_mutex(&mccobjpriv->mcc_tsf_req_mutex, NULL);
}
static u8 rtw_hal_mcc_check_start_time_is_valid(PADAPTER padapter, u8 case_num,
u32 tsfdiff, s8 *upper_bound_0, s8 *lower_bound_0, s8 *upper_bound_1, s8 *lower_bound_1)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
u8 duration_0 = 0, duration_1 = 0;
s8 final_upper_bound = 0, final_lower_bound = 0;
u8 intersection = _FALSE;
u8 min_start_time = 5;
u8 max_start_time = 95;
duration_0 = mccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration;
duration_1 = mccobjpriv->iface[1]->mcc_adapterpriv.mcc_duration;
switch(case_num) {
case 1:
*upper_bound_0 = tsfdiff;
*lower_bound_0 = tsfdiff - duration_1;
*upper_bound_1 = 150 - duration_1;
*lower_bound_1= 0;
break;
case 2:
*upper_bound_0 = tsfdiff + 100;
*lower_bound_0 = tsfdiff + 100 - duration_1;
*upper_bound_1 = 150 - duration_1;
*lower_bound_1= 0;
break;
case 3:
*upper_bound_0 = tsfdiff + 50;
*lower_bound_0 = tsfdiff + 50 - duration_1;
*upper_bound_1 = 150 - duration_1;
*lower_bound_1= 0;
break;
case 4:
*upper_bound_0 = tsfdiff;
*lower_bound_0 = tsfdiff - duration_1;
*upper_bound_1 = 150 - duration_1;
*lower_bound_1= 0;
break;
case 5:
*upper_bound_0 = 200 - tsfdiff;
*lower_bound_0 = 200 - tsfdiff - duration_1;
*upper_bound_1 = 150 - duration_1;
*lower_bound_1= 0;
break;
case 6:
*upper_bound_0 = tsfdiff - 50;
*lower_bound_0 = tsfdiff - 50 - duration_1;
*upper_bound_1 = 150 - duration_1;
*lower_bound_1= 0;
break;
default:
RTW_ERR("[MCC] %s: error case number(%d\n)", __func__, case_num);
}
/* check Intersection or not */
if ((*lower_bound_1 >= *upper_bound_0) ||
(*lower_bound_0 >= *upper_bound_1))
intersection = _FALSE;
else
intersection = _TRUE;
if (intersection) {
if (*upper_bound_0 > *upper_bound_1)
final_upper_bound = *upper_bound_1;
else
final_upper_bound = *upper_bound_0;
if (*lower_bound_0 > *lower_bound_1)
final_lower_bound = *lower_bound_0;
else
final_lower_bound = *lower_bound_1;
mccobjpriv->start_time = (final_lower_bound + final_upper_bound) / 2;
/* check start time less than 5ms, request by Pablo@SD1 */
if (mccobjpriv->start_time <= min_start_time) {
mccobjpriv->start_time = 6;
if (mccobjpriv->start_time < final_lower_bound && mccobjpriv->start_time > final_upper_bound) {
intersection = _FALSE;
goto exit;
}
}
/* check start time less than 95ms */
if (mccobjpriv->start_time >= max_start_time) {
mccobjpriv->start_time = 90;
if (mccobjpriv->start_time < final_lower_bound && mccobjpriv->start_time > final_upper_bound) {
intersection = _FALSE;
goto exit;
}
}
}
exit:
return intersection;
}
static void rtw_hal_mcc_decide_duration(PADAPTER padapter)
{
struct registry_priv *registry_par = &padapter->registrypriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
struct mcc_adapter_priv *mccadapriv = NULL, *mccadapriv_order0 = NULL, *mccadapriv_order1 = NULL;
_adapter *iface = NULL, *iface_order0 = NULL, *iface_order1 = NULL;
u8 duration = 0, i = 0, duration_time;
u8 mcc_interval = 150;
iface_order0 = mccobjpriv->iface[0];
iface_order1 = mccobjpriv->iface[1];
mccadapriv_order0 = &iface_order0->mcc_adapterpriv;
mccadapriv_order1 = &iface_order1->mcc_adapterpriv;
if (mccobjpriv->duration == 0) {
/* default */
duration = 30;/*(%)*/
RTW_INFO("%s: mccobjpriv->duration=0, use default value(%d)\n",
__FUNCTION__, duration);
} else {
duration = mccobjpriv->duration;/*(%)*/
RTW_INFO("%s: mccobjpriv->duration=%d\n",
__FUNCTION__, duration);
}
mccobjpriv->interval = mcc_interval;
mccobjpriv->mcc_stop_threshold = 2000 * 4 / 300 - 6;
/* convert % to ms, for primary adapter */
duration_time = mccobjpriv->interval * duration / 100;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
if (is_primary_adapter(iface))
mccadapriv->mcc_duration = duration_time;
else
mccadapriv->mcc_duration = mccobjpriv->interval - duration_time;
}
RTW_INFO("[MCC]" FUNC_ADPT_FMT " order 0 duration=%d\n", FUNC_ADPT_ARG(iface_order0), mccadapriv_order0->mcc_duration);
RTW_INFO("[MCC]" FUNC_ADPT_FMT " order 1 duration=%d\n", FUNC_ADPT_ARG(iface_order1), mccadapriv_order1->mcc_duration);
}
static u8 rtw_hal_mcc_update_timing_parameters(PADAPTER padapter, u8 force_update)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
u8 need_update = _FALSE;
u8 starting_ap_num = DEV_AP_STARTING_NUM(dvobj);
u8 ap_num = DEV_AP_NUM(dvobj);
/* for STA+STA, modify policy table */
if (starting_ap_num == 0 && ap_num == 0) {
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = NULL;
_adapter *iface = NULL;
u64 tsf[MAX_MCC_NUM] = {0};
u64 tsf0 = 0, tsf1 = 0;
u32 beaconperiod_0 = 0, beaconperiod_1 = 0, tsfdiff = 0;
s8 upper_bound_0 = 0, lower_bound_0 = 0;
s8 upper_bound_1 = 0, lower_bound_1 = 0;
u8 valid = _FALSE;
u8 case_num = 1;
u8 i = 0;
/* query TSF */
rtw_hal_mcc_rqt_tsf(padapter, tsf);
/* selecet policy table according TSF diff */
tsf0 = tsf[0];
beaconperiod_0 = pmccobjpriv->iface[0]->mlmepriv.cur_network.network.Configuration.BeaconPeriod;
tsf0 = rtw_modular64(tsf0, (beaconperiod_0 * TU));
tsf1 = tsf[1];
beaconperiod_1 = pmccobjpriv->iface[1]->mlmepriv.cur_network.network.Configuration.BeaconPeriod;
tsf1 = rtw_modular64(tsf1, (beaconperiod_1 * TU));
if (tsf0 > tsf1)
tsfdiff = tsf0- tsf1;
else
tsfdiff = (tsf0 + beaconperiod_0 * TU) - tsf1;
/* convert to ms */
tsfdiff = (tsfdiff / TU);
/* force update*/
if (force_update) {
RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
pmccobjpriv->last_tsfdiff = tsfdiff;
need_update = _TRUE;
} else {
if (pmccobjpriv->last_tsfdiff > tsfdiff) {
/* last tsfdiff - current tsfdiff > THRESHOLD, update parameters */
if (pmccobjpriv->last_tsfdiff > (tsfdiff + MCC_UPDATE_PARAMETER_THRESHOLD)) {
RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
pmccobjpriv->last_tsfdiff = tsfdiff;
need_update = _TRUE;
} else {
need_update = _FALSE;
}
} else if (tsfdiff > pmccobjpriv->last_tsfdiff){
/* current tsfdiff - last tsfdiff > THRESHOLD, update parameters */
if (tsfdiff > (pmccobjpriv->last_tsfdiff + MCC_UPDATE_PARAMETER_THRESHOLD)) {
RTW_INFO("orig TSF0:%lld, orig TSF1:%lld\n",
pmccobjpriv->iface[0]->mcc_adapterpriv.tsf, pmccobjpriv->iface[1]->mcc_adapterpriv.tsf);
RTW_INFO("tsf0:%lld, tsf1:%lld\n", tsf0, tsf1);
RTW_INFO("%s: force=%d, last_tsfdiff=%d, tsfdiff=%d, THRESHOLD=%d\n",
__func__, force_update, pmccobjpriv->last_tsfdiff, tsfdiff, MCC_UPDATE_PARAMETER_THRESHOLD);
pmccobjpriv->last_tsfdiff = tsfdiff;
need_update = _TRUE;
} else {
need_update = _FALSE;
}
} else {
need_update = _FALSE;
}
}
if (need_update == _FALSE)
goto exit;
rtw_hal_mcc_decide_duration(padapter);
if (tsfdiff <= 50) {
/* RX TBTT 0 */
case_num = 1;
valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
if (valid)
goto valid_result;
/* RX TBTT 1 */
case_num = 2;
valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
if (valid)
goto valid_result;
/* RX TBTT 2 */
case_num = 3;
valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
if (valid)
goto valid_result;
if (valid == _FALSE) {
RTW_INFO("[MCC] do not find fit start time\n");
RTW_INFO("[MCC] tsfdiff:%d, duration:%d(%c), interval:%d\n",
tsfdiff, pmccobjpriv->duration, 37, pmccobjpriv->interval);
}
} else {
/* RX TBTT 0 */
case_num = 4;
valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
if (valid)
goto valid_result;
/* RX TBTT 1 */
case_num = 5;
valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
if (valid)
goto valid_result;
/* RX TBTT 2 */
case_num = 6;
valid = rtw_hal_mcc_check_start_time_is_valid(padapter, case_num, tsfdiff,
&upper_bound_0, &lower_bound_0, &upper_bound_1, &lower_bound_1);
if (valid)
goto valid_result;
if (valid == _FALSE) {
RTW_INFO("[MCC] do not find fit start time\n");
RTW_INFO("[MCC] tsfdiff:%d, duration:%d(%c), interval:%d\n",
tsfdiff, pmccobjpriv->duration, 37, pmccobjpriv->interval);
}
}
valid_result:
RTW_INFO("********************\n");
RTW_INFO("%s: case_num:%d, start time:%d\n",
__func__, case_num, pmccobjpriv->start_time);
RTW_INFO("%s: upper_bound_0:%d, lower_bound_0:%d\n",
__func__, upper_bound_0, lower_bound_0);
RTW_INFO("%s: upper_bound_1:%d, lower_bound_1:%d\n",
__func__, upper_bound_1, lower_bound_1);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
pmccadapriv = &iface->mcc_adapterpriv;
pmccadapriv = &iface->mcc_adapterpriv;
if (pmccadapriv->role == MCC_ROLE_MAX)
continue;
#if 0
if (pmccadapriv->order == 0) {
pmccadapriv->mcc_duration = mcc_duration;
} else if (pmccadapriv->order == 1) {
pmccadapriv->mcc_duration = mcc_interval - mcc_duration;
} else {
RTW_INFO("[MCC] not support >= 3 interface\n");
rtw_warn_on(1);
}
#endif
RTW_INFO("********************\n");
RTW_INFO(FUNC_ADPT_FMT": order:%d, role:%d\n",
FUNC_ADPT_ARG(iface), pmccadapriv->order, pmccadapriv->role);
RTW_INFO(FUNC_ADPT_FMT": mcc duration:%d, target tx bytes:%d\n",
FUNC_ADPT_ARG(iface), pmccadapriv->mcc_duration, pmccadapriv->mcc_target_tx_bytes_to_port);
RTW_INFO(FUNC_ADPT_FMT": mgmt queue macid:%d, bitmap:0x%02x\n",
FUNC_ADPT_ARG(iface), pmccadapriv->mgmt_queue_macid, pmccadapriv->mcc_macid_bitmap);
RTW_INFO("********************\n");
}
}
exit:
return need_update;
}
static u8 rtw_hal_decide_mcc_role(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface = NULL;
struct mcc_adapter_priv *pmccadapriv = NULL;
struct wifidirect_info *pwdinfo = NULL;
struct mlme_priv *pmlmepriv = NULL;
u8 ret = _SUCCESS, i = 0;
u8 order = 1;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
pmccadapriv = &iface->mcc_adapterpriv;
pwdinfo = &iface->wdinfo;
if (MLME_IS_GO(iface))
pmccadapriv->role = MCC_ROLE_GO;
else if (MLME_IS_AP(iface))
pmccadapriv->role = MCC_ROLE_AP;
else if (MLME_IS_GC(iface))
pmccadapriv->role = MCC_ROLE_GC;
else if (MLME_IS_STA(iface)) {
if (MLME_IS_LINKING(iface) || MLME_IS_ASOC(iface))
pmccadapriv->role = MCC_ROLE_STA;
else {
/* bypass non-linked/non-linking interface */
RTW_INFO(FUNC_ADPT_FMT" mlme state:0x%2x\n",
FUNC_ADPT_ARG(iface), MLME_STATE(iface));
continue;
}
} else {
/* bypass non-linked/non-linking interface */
RTW_INFO(FUNC_ADPT_FMT" P2P Role:%d, mlme state:0x%2x\n",
FUNC_ADPT_ARG(iface), pwdinfo->role, MLME_STATE(iface));
continue;
}
if (padapter == iface) {
/* current adapter is order 0 */
rtw_hal_config_mcc_role_setting(iface, 0);
} else {
rtw_hal_config_mcc_role_setting(iface, order);
order ++;
}
}
rtw_hal_mcc_update_timing_parameters(padapter, _TRUE);
exit:
return ret;
}
static void rtw_hal_construct_CTS(PADAPTER padapter, u8 *pframe, u32 *pLength)
{
u8 broadcast_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
/* frame type, length = 1*/
set_frame_sub_type(pframe, WIFI_RTS);
/* frame control flag, length = 1 */
*(pframe + 1) = 0;
/* frame duration, length = 2 */
*(pframe + 2) = 0x00;
*(pframe + 3) = 0x78;
/* frame recvaddr, length = 6 */
_rtw_memcpy((pframe + 4), broadcast_addr, ETH_ALEN);
_rtw_memcpy((pframe + 4 + ETH_ALEN), adapter_mac_addr(padapter), ETH_ALEN);
_rtw_memcpy((pframe + 4 + ETH_ALEN*2), adapter_mac_addr(padapter), ETH_ALEN);
*pLength = 22;
}
/* avoid wrong information for power limit */
void rtw_hal_mcc_upadate_chnl_bw(_adapter *padapter, u8 ch, u8 ch_offset, u8 bw, u8 print)
{
u8 center_ch, chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
u8 cch_160, cch_80, cch_40, cch_20;
center_ch = rtw_get_center_ch(ch, bw, ch_offset);
if (bw == CHANNEL_WIDTH_80) {
if (center_ch > ch)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
else if (center_ch < ch)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
else
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
/* set Channel */
/* saved channel/bw info */
rtw_set_oper_ch(padapter, ch);
rtw_set_oper_bw(padapter, bw);
rtw_set_oper_choffset(padapter, ch_offset);
cch_80 = bw == CHANNEL_WIDTH_80 ? center_ch : 0;
cch_40 = bw == CHANNEL_WIDTH_40 ? center_ch : 0;
cch_20 = bw == CHANNEL_WIDTH_20 ? center_ch : 0;
if (cch_80 != 0)
cch_40 = rtw_get_scch_by_cch_offset(cch_80, CHANNEL_WIDTH_80, chnl_offset80);
if (cch_40 != 0)
cch_20 = rtw_get_scch_by_cch_offset(cch_40, CHANNEL_WIDTH_40, ch_offset);
hal->cch_80 = cch_80;
hal->cch_40 = cch_40;
hal->cch_20 = cch_20;
hal->current_channel = center_ch;
hal->CurrentCenterFrequencyIndex1 = center_ch;
hal->current_channel_bw = bw;
hal->nCur40MhzPrimeSC = ch_offset;
hal->nCur80MhzPrimeSC = chnl_offset80;
hal->current_band_type = ch > 14 ? BAND_ON_5G:BAND_ON_2_4G;
if (print) {
RTW_INFO(FUNC_ADPT_FMT" cch:%u, %s, offset40:%u, offset80:%u (%u, %u, %u), band:%s\n"
, FUNC_ADPT_ARG(padapter), center_ch, ch_width_str(bw)
, ch_offset, chnl_offset80
, hal->cch_80, hal->cch_40, hal->cch_20
, band_str(hal->current_band_type));
}
}
u8 rtw_hal_dl_mcc_fw_rsvd_page(_adapter *adapter, u8 *pframe, u16 *index,
u8 tx_desc, u32 page_size, u8 *total_page_num, RSVDPAGE_LOC *rsvd_page_loc, u8 *page_num)
{
u32 len = 0;
_adapter *iface = NULL;
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
struct mlme_ext_info *pmlmeinfo = NULL;
struct mlme_ext_priv *pmlmeext = NULL;
struct hal_com_data *hal = GET_HAL_DATA(adapter);
struct mcc_adapter_priv *mccadapriv = NULL;
u8 ret = _SUCCESS, i = 0, j =0, order = 0, CurtPktPageNum = 0;
u8 *start = NULL;
u8 path = RF_PATH_A;
if (page_num) {
#ifdef CONFIG_MCC_MODE_V2
if (!hal->RegIQKFWOffload)
RTW_WARN("[MCC] must enable FW IQK for New IC\n");
#endif /* CONFIG_MCC_MODE_V2 */
*total_page_num += (2 * MAX_MCC_NUM+ 1);
RTW_INFO("[MCC] allocate mcc rsvd page num = %d\n", *total_page_num);
goto exit;
}
/* check proccess mcc start setting */
if (!rtw_hal_check_mcc_status(adapter, MCC_STATUS_PROCESS_MCC_START_SETTING)) {
ret = _FAIL;
goto exit;
}
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
order = mccadapriv->order;
pmccobjpriv->mcc_loc_rsvd_paga[order] = *total_page_num;
switch (mccadapriv->role) {
case MCC_ROLE_STA:
case MCC_ROLE_GC:
/* Build NULL DATA */
RTW_INFO("LocNull(order:%d): %d\n"
, order, pmccobjpriv->mcc_loc_rsvd_paga[order]);
len = 0;
rtw_hal_construct_NullFunctionData(iface
, &pframe[*index], &len, _FALSE, 0, 0, _FALSE);
rtw_hal_fill_fake_txdesc(iface, &pframe[*index-tx_desc],
len, _FALSE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum(tx_desc + len, page_size);
*total_page_num += CurtPktPageNum;
*index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("LocNull", CurtPktPageNum, *total_page_num, *index);
break;
case MCC_ROLE_AP:
/* Bulid CTS */
RTW_INFO("LocCTS(order:%d): %d\n"
, order, pmccobjpriv->mcc_loc_rsvd_paga[order]);
len = 0;
rtw_hal_construct_CTS(iface, &pframe[*index], &len);
rtw_hal_fill_fake_txdesc(iface, &pframe[*index-tx_desc],
len, _FALSE, _FALSE, _FALSE);
CurtPktPageNum = (u8)PageNum(tx_desc + len, page_size);
*total_page_num += CurtPktPageNum;
*index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("LocCTS", CurtPktPageNum, *total_page_num, *index);
break;
case MCC_ROLE_GO:
/* To DO */
break;
default:
RTW_INFO(FUNC_ADPT_FMT": unknown role = %d\n"
, FUNC_ADPT_ARG(iface), mccadapriv->role);
break;
}
}
for (i = 0; i < MAX_MCC_NUM; i++) {
u8 center_ch = 0, ch = 0, bw = 0, bw_offset = 0;
u8 power_index = 0;
u8 rate_array_sz = 0;
u8 *rates = NULL;
u8 rate = 0;
u8 shift = 0;
u32 power_index_4bytes = 0;
u8 total_rate = 0;
u8 *total_rate_offset = NULL;
iface = pmccobjpriv->iface[i];
pmlmeext = &iface->mlmeextpriv;
ch = pmlmeext->cur_channel;
bw = pmlmeext->cur_bwmode;
bw_offset = pmlmeext->cur_ch_offset;
center_ch = rtw_get_center_ch(ch, bw, bw_offset);
rtw_hal_mcc_upadate_chnl_bw(iface, ch, bw_offset, bw, _TRUE);
start = &pframe[*index - tx_desc];
_rtw_memset(start, 0, page_size);
pmccobjpriv->mcc_pwr_idx_rsvd_page[i] = *total_page_num;
RTW_INFO(ADPT_FMT" order:%d, pwr_idx_rsvd_page location[%d]: %d\n",
ADPT_ARG(iface), mccadapriv->order,
i, pmccobjpriv->mcc_pwr_idx_rsvd_page[i]);
total_rate_offset = start;
for (path = RF_PATH_A; path < hal->NumTotalRFPath; ++path) {
total_rate = 0;
/* PATH A for 0~63 byte, PATH B for 64~127 byte*/
if (path == RF_PATH_A)
start = total_rate_offset + 1;
else if (path == RF_PATH_B)
start = total_rate_offset + 64;
else {
RTW_INFO("[MCC] %s: unknow RF PATH(%d)\n", __func__, path);
break;
}
/* CCK */
if (ch <= 14) {
rate_array_sz = rates_by_sections[CCK].rate_num;
rates = rates_by_sections[CCK].rates;
for (j = 0; j < rate_array_sz; ++j) {
power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
shift = rate % 4;
if (shift == 0) {
*start = rate;
start++;
total_rate++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
#endif
}
*start = power_index;
start++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
shift = rate % 4;
power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
if (shift == 3) {
rate = rate - 3;
RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
power_index_4bytes = 0;
total_rate++;
}
#endif
}
}
/* OFDM */
rate_array_sz = rates_by_sections[OFDM].rate_num;
rates = rates_by_sections[OFDM].rates;
for (j = 0; j < rate_array_sz; ++j) {
power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
shift = rate % 4;
if (shift == 0) {
*start = rate;
start++;
total_rate++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
#endif
}
*start = power_index;
start++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
shift = rate % 4;
power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
if (shift == 3) {
rate = rate - 3;
RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
power_index_4bytes = 0;
total_rate++;
}
#endif
}
/* HT_MCS0_MCS7 */
rate_array_sz = rates_by_sections[HT_MCS0_MCS7].rate_num;
rates = rates_by_sections[HT_MCS0_MCS7].rates;
for (j = 0; j < rate_array_sz; ++j) {
power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
shift = rate % 4;
if (shift == 0) {
*start = rate;
start++;
total_rate++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
#endif
}
*start = power_index;
start++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
shift = rate % 4;
power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
if (shift == 3) {
rate = rate - 3;
RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
power_index_4bytes = 0;
total_rate++;
}
#endif
}
/* HT_MCS8_MCS15 */
rate_array_sz = rates_by_sections[HT_MCS8_MCS15].rate_num;
rates = rates_by_sections[HT_MCS8_MCS15].rates;
for (j = 0; j < rate_array_sz; ++j) {
power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
shift = rate % 4;
if (shift == 0) {
*start = rate;
start++;
total_rate++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
#endif
}
*start = power_index;
start++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
shift = rate % 4;
power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
if (shift == 3) {
rate = rate - 3;
RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
power_index_4bytes = 0;
total_rate++;
}
#endif
}
/* VHT_1SSMCS0_1SSMCS9 */
rate_array_sz = rates_by_sections[VHT_1SSMCS0_1SSMCS9].rate_num;
rates = rates_by_sections[VHT_1SSMCS0_1SSMCS9].rates;
for (j = 0; j < rate_array_sz; ++j) {
power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
shift = rate % 4;
if (shift == 0) {
*start = rate;
start++;
total_rate++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:0x%02x\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
#endif
}
*start = power_index;
start++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
shift = rate % 4;
power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
if (shift == 3) {
rate = rate - 3;
RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
power_index_4bytes = 0;
total_rate++;
}
#endif
}
/* VHT_2SSMCS0_2SSMCS9 */
rate_array_sz = rates_by_sections[VHT_2SSMCS0_2SSMCS9].rate_num;
rates = rates_by_sections[VHT_2SSMCS0_2SSMCS9].rates;
for (j = 0; j < rate_array_sz; ++j) {
power_index = rtw_hal_get_tx_power_index(iface, path, rates[j], bw, center_ch, NULL);
rate = PHY_GetRateIndexOfTxPowerByRate(rates[j]);
shift = rate % 4;
if (shift == 0) {
*start = rate;
start++;
total_rate++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
#endif
}
*start = power_index;
start++;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("TXPWR("ADPT_FMT"): [%c][%s]ch:%u, %s, pwr_idx:%u\n",
ADPT_ARG(iface), rf_path_char(path), ch_width_str(bw),
center_ch, MGN_RATE_STR(rates[j]), power_index);
shift = rate % 4;
power_index_4bytes |= ((power_index & 0xff) << (shift * 8));
if (shift == 3) {
rate = rate - 3;
RTW_INFO("(index:0x%02x, rfpath:%d, rate:0x%02x)\n", index, path, rate);
power_index_4bytes = 0;
total_rate++;
}
#endif
}
}
/* total rate store in offset 0 */
*total_rate_offset = total_rate;
#ifdef DBG_PWR_IDX_RSVD_PAGE
RTW_INFO("total_rate=%d\n", total_rate);
RTW_INFO(" ======================="ADPT_FMT"===========================\n", ADPT_ARG(iface));
RTW_INFO_DUMP("\n", total_rate_offset, 128);
RTW_INFO(" ==================================================\n");
#endif
CurtPktPageNum = 1;
*total_page_num += CurtPktPageNum;
*index += (CurtPktPageNum * page_size);
RSVD_PAGE_CFG("mcc_pwr_idx_rsvd_page", CurtPktPageNum, *total_page_num, *index);
}
exit:
return ret;
}
/*
* 1. Download MCC rsvd page
* 2. Re-Download beacon after download rsvd page
*/
static void rtw_hal_set_fw_mcc_rsvd_page(PADAPTER padapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
PADAPTER port0_iface = dvobj_get_port0_adapter(dvobj);
PADAPTER iface = NULL;
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
u8 mstatus = RT_MEDIA_CONNECT, i = 0;
RTW_INFO(FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
rtw_hal_set_hwreg(port0_iface, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
/* Re-Download beacon */
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = pmccobjpriv->iface[i];
if (iface == NULL)
continue;
pmccadapriv = &iface->mcc_adapterpriv;
if (pmccadapriv->role == MCC_ROLE_AP
|| pmccadapriv->role == MCC_ROLE_GO) {
tx_beacon_hdl(iface, NULL);
}
}
}
static void rtw_hal_set_mcc_rsvdpage_cmd(_adapter *padapter)
{
u8 cmd[H2C_MCC_LOCATION_LEN] = {0}, i = 0, order = 0;
_adapter *iface = NULL;
PHAL_DATA_TYPE hal = GET_HAL_DATA(padapter);
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
SET_H2CCMD_MCC_PWRIDX_OFFLOAD_EN(cmd, _TRUE);
SET_H2CCMD_MCC_PWRIDX_OFFLOAD_RFNUM(cmd, hal->NumTotalRFPath);
for (order = 0; order < MAX_MCC_NUM; order++) {
iface = pmccobjpriv->iface[i];
SET_H2CCMD_MCC_RSVDPAGE_LOC((cmd + order), pmccobjpriv->mcc_loc_rsvd_paga[order]);
SET_H2CCMD_MCC_PWRIDX_RSVDPAGE_LOC ((cmd + order), pmccobjpriv->mcc_pwr_idx_rsvd_page[order]);
}
#ifdef CONFIG_MCC_MODE_DEBUG
RTW_INFO("=========================\n");
RTW_INFO("MCC RSVD PAGE LOC:\n");
for (i = 0; i < H2C_MCC_LOCATION_LEN; i++)
pr_dbg("0x%x ", cmd[i]);
pr_dbg("\n");
RTW_INFO("=========================\n");
#endif /* CONFIG_MCC_MODE_DEBUG */
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_LOCATION, H2C_MCC_LOCATION_LEN, cmd);
}
static void rtw_hal_set_mcc_time_setting_cmd(PADAPTER padapter)
{
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct mlme_priv *pmlmepriv = &(padapter->mlmepriv);
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
u8 cmd[H2C_MCC_TIME_SETTING_LEN] = {0};
u8 fw_eable = 1;
u8 swchannel_early_time = MCC_SWCH_FW_EARLY_TIME;
u8 starting_ap_num = DEV_AP_STARTING_NUM(dvobj);
u8 ap_num = DEV_AP_NUM(dvobj);
if (starting_ap_num == 0 && ap_num == 0)
/* For STA+GC/STA+STA, TSF of GC/STA does not need to sync from TSF of other STA/GC */
fw_eable = 0;
else
/* Only for STA+GO/STA+AP, TSF of AP/GO need to sync from TSF of STA */
fw_eable = 1;
if (fw_eable == 1) {
PADAPTER order0_iface = NULL;
PADAPTER order1_iface = NULL;
u8 policy_idx = mccobjpriv->policy_index;
u8 tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
u8 start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
u8 interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
enum _hw_port tsf_bsae_port = MAX_HW_PORT;
enum _hw_port tsf_sync_port = MAX_HW_PORT;
order0_iface = mccobjpriv->iface[0];
order1_iface = mccobjpriv->iface[1];
tsf_bsae_port = rtw_hal_get_port(order1_iface);
tsf_sync_port = rtw_hal_get_port(order0_iface);
/* FW set enable */
SET_H2CCMD_MCC_TIME_SETTING_FW_EN(cmd, fw_eable);
/* TSF Sync offset */
SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(cmd, tsf_sync_offset);
/* start time offset */
SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, (start_time_offset + guard_offset0));
/* interval */
SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
/* Early time to inform driver by C2H before switch channel */
SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
/* Port0 sync from Port1, not support multi-port */
SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(cmd, tsf_bsae_port);
SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(cmd, tsf_sync_port);
} else {
/* start time offset */
SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, mccobjpriv->start_time);
/* interval */
SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, mccobjpriv->interval);
/* Early time to inform driver by C2H before switch channel */
SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
}
#ifdef CONFIG_MCC_MODE_DEBUG
{
u8 i = 0;
RTW_INFO("=========================\n");
RTW_INFO("NoA:\n");
for (i = 0; i < H2C_MCC_TIME_SETTING_LEN; i++)
pr_dbg("0x%x ", cmd[i]);
pr_dbg("\n");
RTW_INFO("=========================\n");
}
#endif /* CONFIG_MCC_MODE_DEBUG */
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_TIME_SETTING, H2C_MCC_TIME_SETTING_LEN, cmd);
}
static void rtw_hal_set_mcc_IQK_offload_cmd(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = NULL;
_adapter *iface = NULL;
u8 cmd[H2C_MCC_IQK_PARAM_LEN] = {0}, bready = 0, i = 0, order = 0;
u16 TX_X = 0, TX_Y = 0, RX_X = 0, RX_Y = 0;
u8 total_rf_path = GET_HAL_DATA(padapter)->NumTotalRFPath;
u8 rf_path_idx = 0, last_order = MAX_MCC_NUM - 1, last_rf_path_index = total_rf_path - 1;
/* by order, last order & last_rf_path_index must set ready bit = 1 */
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = pmccobjpriv->iface[i];
if (iface == NULL)
continue;
pmccadapriv = &iface->mcc_adapterpriv;
order = pmccadapriv->order;
for (rf_path_idx = 0; rf_path_idx < total_rf_path; rf_path_idx ++) {
_rtw_memset(cmd, 0, H2C_MCC_IQK_PARAM_LEN);
TX_X = pmccadapriv->mcc_iqk_arr[rf_path_idx].TX_X & 0x7ff;/* [10:0] */
TX_Y = pmccadapriv->mcc_iqk_arr[rf_path_idx].TX_Y & 0x7ff;/* [10:0] */
RX_X = pmccadapriv->mcc_iqk_arr[rf_path_idx].RX_X & 0x3ff;/* [9:0] */
RX_Y = pmccadapriv->mcc_iqk_arr[rf_path_idx].RX_Y & 0x3ff;/* [9:0] */
/* ready or not */
if (order == last_order && rf_path_idx == last_rf_path_index)
bready = 1;
else
bready = 0;
SET_H2CCMD_MCC_IQK_READY(cmd, bready);
SET_H2CCMD_MCC_IQK_ORDER(cmd, order);
SET_H2CCMD_MCC_IQK_PATH(cmd, rf_path_idx);
/* fill RX_X[7:0] to (cmd+1)[7:0] bitlen=8 */
SET_H2CCMD_MCC_IQK_RX_L(cmd, (u8)(RX_X & 0xff));
/* fill RX_X[9:8] to (cmd+2)[1:0] bitlen=2 */
SET_H2CCMD_MCC_IQK_RX_M1(cmd, (u8)((RX_X >> 8) & 0x03));
/* fill RX_Y[5:0] to (cmd+2)[7:2] bitlen=6 */
SET_H2CCMD_MCC_IQK_RX_M2(cmd, (u8)(RX_Y & 0x3f));
/* fill RX_Y[9:6] to (cmd+3)[3:0] bitlen=4 */
SET_H2CCMD_MCC_IQK_RX_H(cmd, (u8)((RX_Y >> 6) & 0x0f));
/* fill TX_X[7:0] to (cmd+4)[7:0] bitlen=8 */
SET_H2CCMD_MCC_IQK_TX_L(cmd, (u8)(TX_X & 0xff));
/* fill TX_X[10:8] to (cmd+5)[2:0] bitlen=3 */
SET_H2CCMD_MCC_IQK_TX_M1(cmd, (u8)((TX_X >> 8) & 0x07));
/* fill TX_Y[4:0] to (cmd+5)[7:3] bitlen=5 */
SET_H2CCMD_MCC_IQK_TX_M2(cmd, (u8)(TX_Y & 0x1f));
/* fill TX_Y[10:5] to (cmd+6)[5:0] bitlen=6 */
SET_H2CCMD_MCC_IQK_TX_H(cmd, (u8)((TX_Y >> 5) & 0x3f));
#ifdef CONFIG_MCC_MODE_DEBUG
RTW_INFO("=========================\n");
RTW_INFO(FUNC_ADPT_FMT" IQK:\n", FUNC_ADPT_ARG(iface));
RTW_INFO("TX_X: 0x%02x\n", TX_X);
RTW_INFO("TX_Y: 0x%02x\n", TX_Y);
RTW_INFO("RX_X: 0x%02x\n", RX_X);
RTW_INFO("RX_Y: 0x%02x\n", RX_Y);
RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
RTW_INFO("=========================\n");
#endif /* CONFIG_MCC_MODE_DEBUG */
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_IQK_PARAM, H2C_MCC_IQK_PARAM_LEN, cmd);
}
}
}
static void rtw_hal_set_mcc_macid_cmd(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_adapter_priv *pmccadapriv = NULL;
_adapter *iface = NULL;
u8 cmd[H2C_MCC_MACID_BITMAP_LEN] = {0}, i = 0, order = 0;
u16 bitmap = 0;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
pmccadapriv = &iface->mcc_adapterpriv;
if (pmccadapriv->role == MCC_ROLE_MAX)
continue;
order = pmccadapriv->order;
bitmap = pmccadapriv->mcc_macid_bitmap;
if (order >= (H2C_MCC_MACID_BITMAP_LEN/2)) {
RTW_INFO(FUNC_ADPT_FMT" only support 3 interface at most(%d)\n"
, FUNC_ADPT_ARG(padapter), order);
continue;
}
SET_H2CCMD_MCC_MACID_BITMAP_L((cmd + order * 2), (u8)(bitmap & 0xff));
SET_H2CCMD_MCC_MACID_BITMAP_H((cmd + order * 2), (u8)((bitmap >> 8) & 0xff));
}
#ifdef CONFIG_MCC_MODE_DEBUG
RTW_INFO("=========================\n");
RTW_INFO("MACID BITMAP: ");
for (i = 0; i < H2C_MCC_MACID_BITMAP_LEN; i++)
printk("0x%x ", cmd[i]);
printk("\n");
RTW_INFO("=========================\n");
#endif /* CONFIG_MCC_MODE_DEBUG */
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_MACID_BITMAP, H2C_MCC_MACID_BITMAP_LEN, cmd);
}
#ifdef CONFIG_MCC_MODE_V2
static u8 get_pri_ch_idx_by_adapter(u8 center_ch, u8 channel, u8 bw, u8 ch_offset40)
{
u8 pri_ch_idx = 0, chnl_offset80 = 0;
if (bw == CHANNEL_WIDTH_80) {
if (center_ch > channel)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_LOWER;
else if (center_ch < channel)
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_UPPER;
else
chnl_offset80 = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
}
if (bw == CHANNEL_WIDTH_80) {
/* primary channel is at lower subband of 80MHz & 40MHz */
if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER))
pri_ch_idx = VHT_DATA_SC_20_LOWEST_OF_80MHZ;
/* primary channel is at lower subband of 80MHz & upper subband of 40MHz */
else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_UPPER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER))
pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
/* primary channel is at upper subband of 80MHz & lower subband of 40MHz */
else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER))
pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
/* primary channel is at upper subband of 80MHz & upper subband of 40MHz */
else if ((ch_offset40 == HAL_PRIME_CHNL_OFFSET_UPPER) && (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER))
pri_ch_idx = VHT_DATA_SC_20_UPPERST_OF_80MHZ;
else {
if (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_LOWER)
pri_ch_idx = VHT_DATA_SC_40_LOWER_OF_80MHZ;
else if (chnl_offset80 == HAL_PRIME_CHNL_OFFSET_UPPER)
pri_ch_idx = VHT_DATA_SC_40_UPPER_OF_80MHZ;
else
RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
}
} else if (bw == CHANNEL_WIDTH_40) {
/* primary channel is at upper subband of 40MHz */
if (ch_offset40== HAL_PRIME_CHNL_OFFSET_UPPER)
pri_ch_idx = VHT_DATA_SC_20_UPPER_OF_80MHZ;
/* primary channel is at lower subband of 40MHz */
else if (ch_offset40 == HAL_PRIME_CHNL_OFFSET_LOWER)
pri_ch_idx = VHT_DATA_SC_20_LOWER_OF_80MHZ;
else
RTW_INFO("SCMapping: DONOT CARE Mode Setting\n");
}
return pri_ch_idx;
}
static void rtw_hal_set_mcc_ctrl_cmd_v2(PADAPTER padapter, u8 stop)
{
u8 cmd[H2C_MCC_CTRL_LEN] = {0}, i = 0;
u8 order = 0, totalnum = 0;
u8 center_ch = 0, pri_ch_idx = 0, bw = 0;
u8 duration = 0, role = 0, incurch = 0, rfetype = 0, distxnull = 0, c2hrpt = 0;
u8 dis_sw_retry = 0, null_early_time=2, tsfx = 0, update_parm = 0;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
struct mcc_adapter_priv *mccadapriv = NULL;
struct mlme_ext_priv *pmlmeext = NULL;
struct mlme_ext_info *pmlmeinfo = NULL;
_adapter *iface = NULL;
RTW_INFO(FUNC_ADPT_FMT": stop=%d\n", FUNC_ADPT_ARG(padapter), stop);
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = pmccobjpriv->iface[i];
if (iface == NULL)
continue;
if (stop) {
if (iface != padapter)
continue;
}
mccadapriv = &iface->mcc_adapterpriv;
order = mccadapriv->order;
if (!stop)
totalnum = MAX_MCC_NUM;
else
totalnum = 0xff; /* 0xff means stop */
pmlmeext = &iface->mlmeextpriv;
center_ch = rtw_get_center_ch(pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
pri_ch_idx = get_pri_ch_idx_by_adapter(center_ch, pmlmeext->cur_channel, pmlmeext->cur_bwmode, pmlmeext->cur_ch_offset);
bw = pmlmeext->cur_bwmode;
duration = mccadapriv->mcc_duration;
role = mccadapriv->role;
incurch = _FALSE;
dis_sw_retry = _TRUE;
/* STA/GC TX NULL data to inform AP/GC for ps mode */
switch (role) {
case MCC_ROLE_GO:
case MCC_ROLE_AP:
distxnull = MCC_DISABLE_TX_NULL;
break;
case MCC_ROLE_GC:
set_channel_bwmode(iface, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
distxnull = MCC_ENABLE_TX_NULL;
break;
case MCC_ROLE_STA:
distxnull = MCC_ENABLE_TX_NULL;
break;
}
null_early_time = mccadapriv->null_early;
c2hrpt = MCC_C2H_REPORT_ALL_STATUS;
tsfx = rtw_hal_get_port(iface);
update_parm = 0;
SET_H2CCMD_MCC_CTRL_V2_ORDER(cmd, order);
SET_H2CCMD_MCC_CTRL_V2_TOTALNUM(cmd, totalnum);
SET_H2CCMD_MCC_CTRL_V2_CENTRAL_CH(cmd, center_ch);
SET_H2CCMD_MCC_CTRL_V2_PRIMARY_CH(cmd, pri_ch_idx);
SET_H2CCMD_MCC_CTRL_V2_BW(cmd, bw);
SET_H2CCMD_MCC_CTRL_V2_DURATION(cmd, duration);
SET_H2CCMD_MCC_CTRL_V2_ROLE(cmd, role);
SET_H2CCMD_MCC_CTRL_V2_INCURCH(cmd, incurch);
SET_H2CCMD_MCC_CTRL_V2_DIS_SW_RETRY(cmd, dis_sw_retry);
SET_H2CCMD_MCC_CTRL_V2_DISTXNULL(cmd, distxnull);
SET_H2CCMD_MCC_CTRL_V2_C2HRPT(cmd, c2hrpt);
SET_H2CCMD_MCC_CTRL_V2_TSFX(cmd, tsfx);
SET_H2CCMD_MCC_CTRL_V2_NULL_EARLY(cmd, null_early_time);
SET_H2CCMD_MCC_CTRL_V2_UPDATE_PARM(cmd, update_parm);
#ifdef CONFIG_MCC_MODE_DEBUG
RTW_INFO("=========================\n");
RTW_INFO(FUNC_ADPT_FMT" MCC INFO:\n", FUNC_ADPT_ARG(iface));
RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
RTW_INFO("=========================\n");
#endif /* CONFIG_MCC_MODE_DEBUG */
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL_V2, H2C_MCC_CTRL_LEN, cmd);
}
}
#else
static void rtw_hal_set_mcc_ctrl_cmd_v1(PADAPTER padapter, u8 stop)
{
u8 cmd[H2C_MCC_CTRL_LEN] = {0}, i = 0;
u8 order = 0, totalnum = 0, chidx = 0, bw = 0, bw40sc = 0, bw80sc = 0;
u8 duration = 0, role = 0, incurch = 0, rfetype = 0, distxnull = 0, c2hrpt = 0, chscan = 0;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
struct mcc_adapter_priv *mccadapriv = NULL;
struct mlme_ext_priv *pmlmeext = NULL;
struct mlme_ext_info *pmlmeinfo = NULL;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
_adapter *iface = NULL;
RTW_INFO(FUNC_ADPT_FMT": stop=%d\n", FUNC_ADPT_ARG(padapter), stop);
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = pmccobjpriv->iface[i];
if (iface == NULL)
continue;
if (stop) {
if (iface != padapter)
continue;
}
mccadapriv = &iface->mcc_adapterpriv;
order = mccadapriv->order;
if (!stop)
totalnum = MAX_MCC_NUM;
else
totalnum = 0xff; /* 0xff means stop */
pmlmeext = &iface->mlmeextpriv;
chidx = pmlmeext->cur_channel;
bw = pmlmeext->cur_bwmode;
bw40sc = pmlmeext->cur_ch_offset;
/* decide 80 band width offset */
if (bw == CHANNEL_WIDTH_80) {
u8 center_ch = rtw_get_center_ch(chidx, bw, bw40sc);
if (center_ch > chidx)
bw80sc = HAL_PRIME_CHNL_OFFSET_LOWER;
else if (center_ch < chidx)
bw80sc = HAL_PRIME_CHNL_OFFSET_UPPER;
else
bw80sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
} else
bw80sc = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
duration = mccadapriv->mcc_duration;
role = mccadapriv->role;
incurch = _FALSE;
if (IS_HARDWARE_TYPE_8812(padapter))
rfetype = pHalData->rfe_type; /* RFETYPE (only for 8812)*/
else
rfetype = 0;
/* STA/GC TX NULL data to inform AP/GC for ps mode */
switch (role) {
case MCC_ROLE_GO:
case MCC_ROLE_AP:
distxnull = MCC_DISABLE_TX_NULL;
break;
case MCC_ROLE_GC:
case MCC_ROLE_STA:
distxnull = MCC_ENABLE_TX_NULL;
break;
}
c2hrpt = MCC_C2H_REPORT_ALL_STATUS;
chscan = MCC_CHIDX;
SET_H2CCMD_MCC_CTRL_ORDER(cmd, order);
SET_H2CCMD_MCC_CTRL_TOTALNUM(cmd, totalnum);
SET_H2CCMD_MCC_CTRL_CHIDX(cmd, chidx);
SET_H2CCMD_MCC_CTRL_BW(cmd, bw);
SET_H2CCMD_MCC_CTRL_BW40SC(cmd, bw40sc);
SET_H2CCMD_MCC_CTRL_BW80SC(cmd, bw80sc);
SET_H2CCMD_MCC_CTRL_DURATION(cmd, duration);
SET_H2CCMD_MCC_CTRL_ROLE(cmd, role);
SET_H2CCMD_MCC_CTRL_INCURCH(cmd, incurch);
SET_H2CCMD_MCC_CTRL_RFETYPE(cmd, rfetype);
SET_H2CCMD_MCC_CTRL_DISTXNULL(cmd, distxnull);
SET_H2CCMD_MCC_CTRL_C2HRPT(cmd, c2hrpt);
SET_H2CCMD_MCC_CTRL_CHSCAN(cmd, chscan);
#ifdef CONFIG_MCC_MODE_DEBUG
RTW_INFO("=========================\n");
RTW_INFO(FUNC_ADPT_FMT" MCC INFO:\n", FUNC_ADPT_ARG(iface));
RTW_INFO("cmd[0]:0x%02x\n", cmd[0]);
RTW_INFO("cmd[1]:0x%02x\n", cmd[1]);
RTW_INFO("cmd[2]:0x%02x\n", cmd[2]);
RTW_INFO("cmd[3]:0x%02x\n", cmd[3]);
RTW_INFO("cmd[4]:0x%02x\n", cmd[4]);
RTW_INFO("cmd[5]:0x%02x\n", cmd[5]);
RTW_INFO("cmd[6]:0x%02x\n", cmd[6]);
RTW_INFO("=========================\n");
#endif /* CONFIG_MCC_MODE_DEBUG */
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_CTRL, H2C_MCC_CTRL_LEN, cmd);
}
}
#endif
static void rtw_hal_set_mcc_ctrl_cmd(PADAPTER padapter, u8 stop)
{
#ifdef CONFIG_MCC_MODE_V2
/* new cmd 0x17 */
rtw_hal_set_mcc_ctrl_cmd_v2(padapter, stop);
#else
/* old cmd 0x18 */
rtw_hal_set_mcc_ctrl_cmd_v1(padapter, stop);
#endif
}
static u8 check_mcc_support(PADAPTER adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
u8 sta_linked_num = DEV_STA_LD_NUM(dvobj);
u8 starting_ap_num = DEV_AP_STARTING_NUM(dvobj);
u8 ap_num = DEV_AP_NUM(dvobj);
u8 ret = _FAIL;
RTW_INFO("[MCC] sta_linked_num=%d, starting_ap_num=%d,ap_num=%d\n",
sta_linked_num, starting_ap_num, ap_num);
/* case for sta + sta case */
if (sta_linked_num == MAX_MCC_NUM) {
ret = _SUCCESS;
goto exit;
}
/* case for starting AP + linked sta */
if ((starting_ap_num + sta_linked_num) == MAX_MCC_NUM) {
ret = _SUCCESS;
goto exit;
}
/* case for started AP + linked sta */
if ((ap_num + sta_linked_num) == MAX_MCC_NUM) {
ret = _SUCCESS;
goto exit;
}
exit:
return ret;
}
static void rtw_hal_mcc_start_prehdl(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface = NULL;
struct mcc_adapter_priv *mccadapriv = NULL;
u8 i = 1;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
mccadapriv->role = MCC_ROLE_MAX;
}
}
static u8 rtw_hal_set_mcc_start_setting(PADAPTER padapter, u8 status)
{
u8 ret = _SUCCESS, enable_tsf_auto_sync = _FALSE;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
rtw_warn_on(1);
RTW_INFO("PS mode is not active before start mcc, force exit ps mode\n");
LeaveAllPowerSaveModeDirect(padapter);
}
if (check_mcc_support(padapter) == _FAIL) {
ret = _FAIL;
goto exit;
}
rtw_hal_mcc_start_prehdl(padapter);
/* configure mcc switch channel setting */
rtw_hal_config_mcc_switch_channel_setting(padapter);
if (rtw_hal_decide_mcc_role(padapter) == _FAIL) {
ret = _FAIL;
goto exit;
}
/* set mcc status to indicate process mcc start setting */
rtw_hal_set_mcc_status(padapter, MCC_STATUS_PROCESS_MCC_START_SETTING);
/* only download rsvd page for connect */
if (status == MCC_SETCMD_STATUS_START_CONNECT) {
/* download mcc rsvd page */
rtw_hal_set_fw_mcc_rsvd_page(padapter);
rtw_hal_set_mcc_rsvdpage_cmd(padapter);
}
/* configure time setting */
rtw_hal_set_mcc_time_setting_cmd(padapter);
#ifndef CONFIG_MCC_MODE_V2
/* IQK value offload */
rtw_hal_set_mcc_IQK_offload_cmd(padapter);
#endif
/* set mac id to fw */
rtw_hal_set_mcc_macid_cmd(padapter);
if (dvobj->p0_tsf.sync_port != MAX_HW_PORT ) {
/* disable tsf auto sync */
RTW_INFO("[MCC] disable HW TSF sync\n");
rtw_hal_set_hwreg(padapter, HW_VAR_TSF_AUTO_SYNC, &enable_tsf_auto_sync);
} else {
RTW_INFO("[MCC] already disable HW TSF sync\n");
}
/* set mcc parameter */
rtw_hal_set_mcc_ctrl_cmd(padapter, _FALSE);
exit:
return ret;
}
static void rtw_hal_set_mcc_stop_setting(PADAPTER padapter, u8 status)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &dvobj->mcc_objpriv;
_adapter *iface = NULL;
struct mcc_adapter_priv *mccadapriv = NULL;
u8 i = 0;
/*
* when adapter disconnect, stop mcc mod
* total=0xf means stop mcc mode
*/
switch (status) {
default:
/* let fw switch to other interface channel */
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = mccobjpriv->iface[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
/* use other interface to set cmd */
if (iface != padapter) {
rtw_hal_set_mcc_ctrl_cmd(iface, _TRUE);
break;
}
}
break;
}
}
static void rtw_hal_mcc_status_hdl(PADAPTER padapter, u8 status)
{
switch (status) {
case MCC_SETCMD_STATUS_STOP_DISCONNECT:
rtw_hal_clear_mcc_status(padapter, MCC_STATUS_NEED_MCC | MCC_STATUS_DOING_MCC);
break;
case MCC_SETCMD_STATUS_STOP_SCAN_START:
rtw_hal_set_mcc_status(padapter, MCC_STATUS_NEED_MCC);
rtw_hal_clear_mcc_status(padapter, MCC_STATUS_DOING_MCC);
break;
case MCC_SETCMD_STATUS_START_CONNECT:
case MCC_SETCMD_STATUS_START_SCAN_DONE:
rtw_hal_set_mcc_status(padapter, MCC_STATUS_NEED_MCC | MCC_STATUS_DOING_MCC);
break;
default:
RTW_INFO(FUNC_ADPT_FMT" error status(%d)\n", FUNC_ADPT_ARG(padapter), status);
break;
}
}
static void rtw_hal_mcc_stop_posthdl(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
struct mcc_adapter_priv *mccadapriv = NULL;
_adapter *iface = NULL;
PHAL_DATA_TYPE hal;
u8 i = 0;
u8 enable_rx_bar = _FALSE;
hal = GET_HAL_DATA(padapter);
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = mccobjpriv->iface[i];
if (iface == NULL)
continue;
/* release network queue */
rtw_netif_wake_queue(iface->pnetdev);
mccadapriv = &iface->mcc_adapterpriv;
mccadapriv->mcc_tx_bytes_from_kernel = 0;
mccadapriv->mcc_last_tx_bytes_from_kernel = 0;
mccadapriv->mcc_tx_bytes_to_port = 0;
if (mccadapriv->role == MCC_ROLE_GO)
rtw_hal_mcc_remove_go_p2p_ie(iface);
#ifdef CONFIG_TDLS
if (MLME_IS_STA(iface)) {
if (mccadapriv->backup_tdls_en) {
rtw_enable_tdls_func(iface);
RTW_INFO("%s: Disable MCC, Enable TDLS\n", __func__);
mccadapriv->backup_tdls_en = _FALSE;
}
}
#endif /* CONFIG_TDLS */
mccadapriv->role = MCC_ROLE_MAX;
mccobjpriv->iface[i] = NULL;
}
/* force switch channel */
hal->current_channel = 0;
hal->current_channel_bw = CHANNEL_WIDTH_MAX;
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_STOP, NULL);
#endif
}
static void rtw_hal_mcc_start_posthdl(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
struct mcc_adapter_priv *mccadapriv = NULL;
struct pwrctrl_priv *pwrpriv = adapter_to_pwrctl(padapter);
_adapter *iface = NULL;
u8 i = 0, order = 0;
u8 enable_rx_bar = _TRUE;
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = mccobjpriv->iface[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
mccadapriv->mcc_tx_bytes_from_kernel = 0;
mccadapriv->mcc_last_tx_bytes_from_kernel = 0;
mccadapriv->mcc_tx_bytes_to_port = 0;
#ifdef CONFIG_TDLS
if (MLME_IS_STA(iface)) {
if (rtw_is_tdls_enabled(iface)) {
mccadapriv->backup_tdls_en = _TRUE;
rtw_disable_tdls_func(iface, _TRUE);
RTW_INFO("%s: Enable MCC, Disable TDLS\n", __func__);
}
}
#endif /* CONFIG_TDLS */
}
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_START, NULL);
#endif
}
/*
* rtw_hal_set_mcc_setting - set mcc setting
* @padapter: currnet padapter to stop/start MCC
* @stop: stop mcc or not
* @return val: 1 for SUCCESS, 0 for fail
*/
static u8 rtw_hal_set_mcc_setting(PADAPTER padapter, u8 status)
{
u8 ret = _FAIL;
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
u8 stop = (status < MCC_SETCMD_STATUS_START_CONNECT) ? _TRUE : _FALSE;
u32 start_time = rtw_get_current_time();
RTW_INFO("===> "FUNC_ADPT_FMT"\n", FUNC_ADPT_ARG(padapter));
rtw_sctx_init(&pmccobjpriv->mcc_sctx, MCC_EXPIRE_TIME);
pmccobjpriv->mcc_c2h_status = MCC_RPT_MAX;
if (stop == _FALSE) {
/* handle mcc start */
if (rtw_hal_set_mcc_start_setting(padapter, status) == _FAIL)
goto exit;
/* wait for C2H */
if (!rtw_sctx_wait(&pmccobjpriv->mcc_sctx, __func__))
RTW_INFO(FUNC_ADPT_FMT": wait for mcc start C2H time out\n", FUNC_ADPT_ARG(padapter));
else
ret = _SUCCESS;
if (ret == _SUCCESS) {
RTW_INFO(FUNC_ADPT_FMT": mcc start sucecssfully\n", FUNC_ADPT_ARG(padapter));
rtw_hal_mcc_status_hdl(padapter, status);
rtw_hal_mcc_start_posthdl(padapter);
}
} else {
/* set mcc status to indicate process mcc start setting */
rtw_hal_set_mcc_status(padapter, MCC_STATUS_PROCESS_MCC_STOP_SETTING);
/* handle mcc stop */
rtw_hal_set_mcc_stop_setting(padapter, status);
/* wait for C2H */
if (!rtw_sctx_wait(&pmccobjpriv->mcc_sctx, __func__))
RTW_INFO(FUNC_ADPT_FMT": wait for mcc stop C2H time out\n", FUNC_ADPT_ARG(padapter));
else {
ret = _SUCCESS;
rtw_hal_mcc_status_hdl(padapter, status);
rtw_hal_mcc_stop_posthdl(padapter);
}
}
exit:
/* clear mcc status */
rtw_hal_clear_mcc_status(padapter
, MCC_STATUS_PROCESS_MCC_START_SETTING | MCC_STATUS_PROCESS_MCC_STOP_SETTING);
RTW_INFO(FUNC_ADPT_FMT" in %dms <===\n"
, FUNC_ADPT_ARG(padapter), rtw_get_passing_time_ms(start_time));
return ret;
}
/**
* rtw_hal_mcc_check_case_not_limit_traffic - handler flow ctrl for special case
* @cur_iface: fw stay channel setting of this iface
* @next_iface: fw will swich channel setting of this iface
*/
static void rtw_hal_mcc_check_case_not_limit_traffic(PADAPTER cur_iface, PADAPTER next_iface)
{
u8 cur_bw = cur_iface->mlmeextpriv.cur_bwmode;
u8 next_bw = next_iface->mlmeextpriv.cur_bwmode;
/* for both interface are VHT80, doesn't limit_traffic according to iperf results */
if (cur_bw == CHANNEL_WIDTH_80 && next_bw == CHANNEL_WIDTH_80) {
cur_iface->mcc_adapterpriv.mcc_tp_limit = _FALSE;
next_iface->mcc_adapterpriv.mcc_tp_limit = _FALSE;
}
}
/**
* rtw_hal_mcc_sw_ch_fw_notify_hdl - handler flow ctrl
*/
static void rtw_hal_mcc_sw_ch_fw_notify_hdl(PADAPTER padapter)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
struct mcc_adapter_priv *cur_mccadapriv = NULL, *next_mccadapriv = NULL;
_adapter *iface = NULL, *cur_iface = NULL, *next_iface = NULL;
struct registry_priv *preg = &padapter->registrypriv;
u8 cur_op_ch = pdvobjpriv->oper_channel;
u8 i = 0, iface_num = pdvobjpriv->iface_nums, cur_order = 0, next_order = 0;
static u8 cnt = 1;
u32 single_tx_cri = preg->rtw_mcc_single_tx_cri;
for (i = 0; i < iface_num; i++) {
iface = pdvobjpriv->padapters[i];
if (iface == NULL)
continue;
if (cur_op_ch == iface->mlmeextpriv.cur_channel) {
cur_iface = iface;
cur_mccadapriv = &cur_iface->mcc_adapterpriv;
cur_order = cur_mccadapriv->order;
next_order = (cur_order + 1) % iface_num;
next_iface = pmccobjpriv->iface[next_order];
next_mccadapriv = &next_iface->mcc_adapterpriv;
break;
}
}
if (cur_iface == NULL || next_iface == NULL) {
RTW_ERR("cur_iface=%p,next_iface=%p\n", cur_iface, next_iface);
rtw_warn_on(1);
return;
}
/* check other interface tx busy traffic or not under every 2 switch channel notify(Mbits/100ms) */
if (cnt == 2) {
cur_mccadapriv->mcc_tp = (cur_mccadapriv->mcc_tx_bytes_from_kernel
- cur_mccadapriv->mcc_last_tx_bytes_from_kernel) * 10 * 8 / 1024 / 1024;
cur_mccadapriv->mcc_last_tx_bytes_from_kernel = cur_mccadapriv->mcc_tx_bytes_from_kernel;
next_mccadapriv->mcc_tp = (next_mccadapriv->mcc_tx_bytes_from_kernel
- next_mccadapriv->mcc_last_tx_bytes_from_kernel) * 10 * 8 / 1024 / 1024;
next_mccadapriv->mcc_last_tx_bytes_from_kernel = next_mccadapriv->mcc_tx_bytes_from_kernel;
cnt = 1;
} else
cnt = 2;
/* check single TX or cuncurrnet TX */
if (next_mccadapriv->mcc_tp < single_tx_cri) {
/* single TX, does not stop */
cur_mccadapriv->mcc_tx_stop = _FALSE;
cur_mccadapriv->mcc_tp_limit = _FALSE;
} else {
/* concurrent TX, stop */
cur_mccadapriv->mcc_tx_stop = _TRUE;
cur_mccadapriv->mcc_tp_limit = _TRUE;
}
if (cur_mccadapriv->mcc_tp < single_tx_cri) {
next_mccadapriv->mcc_tx_stop = _FALSE;
next_mccadapriv->mcc_tp_limit = _FALSE;
} else {
next_mccadapriv->mcc_tx_stop = _FALSE;
next_mccadapriv->mcc_tp_limit = _TRUE;
next_mccadapriv->mcc_tx_bytes_to_port = 0;
}
/* stop current iface kernel queue or not */
if (cur_mccadapriv->mcc_tx_stop)
rtw_netif_stop_queue(cur_iface->pnetdev);
else
rtw_netif_wake_queue(cur_iface->pnetdev);
/* stop next iface kernel queue or not */
if (next_mccadapriv->mcc_tx_stop)
rtw_netif_stop_queue(next_iface->pnetdev);
else
rtw_netif_wake_queue(next_iface->pnetdev);
/* start xmit tasklet */
rtw_os_xmit_schedule(next_iface);
rtw_hal_mcc_check_case_not_limit_traffic(cur_iface, next_iface);
if (0) {
RTW_INFO("order:%d, mcc_tx_stop:%d, mcc_tp:%d\n",
cur_mccadapriv->order, cur_mccadapriv->mcc_tx_stop, cur_mccadapriv->mcc_tp);
dump_os_queue(0, cur_iface);
RTW_INFO("order:%d, mcc_tx_stop:%d, mcc_tp:%d\n",
next_mccadapriv->order, next_mccadapriv->mcc_tx_stop, next_mccadapriv->mcc_tp);
dump_os_queue(0, next_iface);
}
}
static void rtw_hal_mcc_update_noa_start_time_hdl(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(pdvobjpriv->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = NULL;
PADAPTER iface = NULL;
u8 i = 0;
u8 policy_idx = pmccobjpriv->policy_index;
u8 noa_tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
u8 noa_start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
for (i = 0; i < pdvobjpriv->iface_nums; i++) {
iface = pdvobjpriv->padapters[i];
if (iface == NULL)
continue;
pmccadapriv = &iface->mcc_adapterpriv;
if (pmccadapriv->role == MCC_ROLE_MAX)
continue;
/* GO & channel match */
if (pmccadapriv->role == MCC_ROLE_GO) {
/* convert GO TBTT from FW to noa_start_time(TU convert to mircosecond) */
pmccadapriv->noa_start_time = RTW_GET_LE32(tmpBuf + 2) + noa_start_time_offset * TU;
if (0) {
RTW_INFO("TBTT:0x%02x\n", RTW_GET_LE32(tmpBuf + 2));
RTW_INFO("noa_tsf_sync_offset:%d, noa_start_time_offset:%d\n", noa_tsf_sync_offset, noa_start_time_offset);
RTW_INFO(FUNC_ADPT_FMT"buf=0x%02x:0x%02x:0x%02x:0x%02x, noa_start_time=0x%02x\n"
, FUNC_ADPT_ARG(iface)
, tmpBuf[2]
, tmpBuf[3]
, tmpBuf[4]
, tmpBuf[5]
,pmccadapriv->noa_start_time);
}
rtw_hal_mcc_update_go_p2p_ie(iface);
break;
}
}
}
static u8 mcc_get_reg_hdl(PADAPTER adapter, const u8 *val)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
struct hal_com_data *hal = GET_HAL_DATA(adapter);
_adapter *cur_iface = NULL;
u8 ret = _SUCCESS;
u8 cur_order = 0;
u16 dbg_reg[DBG_MCC_REG_NUM] = {0x4d4,0x522,0xc50,0xe50};
u16 dbg_rf_reg[DBG_MCC_RF_REG_NUM] = {0x18};
u8 i;
u32 reg_val;
u8 path = 0, path_nums = 0;
if (!rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
ret = _FAIL;
goto exit;
}
if (!val)
cur_order = 0xff;
else
cur_order = *val;
if (cur_order >= MAX_MCC_NUM && cur_order != 0xff) {
RTW_ERR("%s: cur_order=%d\n", __func__, cur_order);
ret = _FAIL;
goto exit;
}
path_nums = hal->NumTotalRFPath;
if (cur_order == 0xff)
cur_iface = adapter;
else
cur_iface = mccobjpriv->iface[cur_order];
if (!cur_iface) {
RTW_ERR("%s: cur_iface = NULL, cur_order=%d\n", __func__, cur_order);
ret = _FAIL;
goto exit;
}
_enter_critical_mutex(&mccobjpriv->mcc_dbg_reg_mutex, NULL);
if (!RTW_CANNOT_IO(adapter)) {
/* RTW_INFO("=================================\n");
RTW_INFO(ADPT_FMT": cur_order:%d\n", ADPT_ARG(cur_iface), cur_order); */
for (i = 0; i < ARRAY_SIZE(dbg_reg); i++) {
reg_val = rtw_read32(adapter, dbg_reg[i]);
mccobjpriv->dbg_reg[i] = dbg_reg[i];
mccobjpriv->dbg_reg_val[i] = reg_val;
/* RTW_PRINT("REG_%X:0x%08x\n", dbg_reg[i], reg_val); */
}
for (i = 0; i < ARRAY_SIZE(dbg_rf_reg); i++) {
for (path = 0; path < path_nums; path++) {
reg_val = rtw_hal_read_rfreg(adapter, path, dbg_rf_reg[i], 0xffffffff);
/* RTW_PRINT("RF_PATH_%d_REG_%X:0x%08x\n",
path, dbg_rf_reg[i], reg_val); */
mccobjpriv->dbg_rf_reg[i] = dbg_rf_reg[i];
mccobjpriv->dbg_rf_reg_val[i][path] = reg_val;
}
}
}
_exit_critical_mutex(&mccobjpriv->mcc_dbg_reg_mutex, NULL);
exit:
return ret;
}
static u8 mcc_get_reg_cmd(_adapter *adapter, u8 cur_order)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 *mcc_cur_order = NULL;
u8 res = _SUCCESS;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
mcc_cur_order = rtw_zmalloc(sizeof(u8));
if (mcc_cur_order == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = MCC_CMD_WK_CID;
pdrvextra_cmd_parm->type = MCC_GET_DBG_REG_WK_CID;
pdrvextra_cmd_parm->size = 1;
pdrvextra_cmd_parm->pbuf = mcc_cur_order;
_rtw_memcpy(mcc_cur_order, &cur_order, 1);
init_h2fwcmd_w_parm_no_rsp(cmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
exit:
return res;
}
static void rtw_hal_mcc_rpt_tsf_hdl(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
{
struct dvobj_priv *dvobjpriv = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
struct submit_ctx *mcc_tsf_req_sctx = &mccobjpriv->mcc_tsf_req_sctx;
struct mcc_adapter_priv *mccadapriv = NULL;
_adapter *iface = NULL;
u8 order = 0;
order = mccobjpriv->mcc_tsf_req_sctx_order;
iface = mccobjpriv->iface[order];
mccadapriv = &iface->mcc_adapterpriv;
mccadapriv->tsf = RTW_GET_LE64(tmpBuf + 2);
if (0)
RTW_INFO(FUNC_ADPT_FMT" TSF(order:%d):0x%02llx\n", FUNC_ADPT_ARG(iface), mccadapriv->order, mccadapriv->tsf);
if (mccadapriv->order == (MAX_MCC_NUM - 1))
rtw_sctx_done(&mcc_tsf_req_sctx);
else
mccobjpriv->mcc_tsf_req_sctx_order ++;
}
/**
* rtw_hal_mcc_c2h_handler - mcc c2h handler
*/
void rtw_hal_mcc_c2h_handler(PADAPTER padapter, u8 buflen, u8 *tmpBuf)
{
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
struct submit_ctx *mcc_sctx = &pmccobjpriv->mcc_sctx;
_adapter *cur_adapter = NULL;
u8 cur_ch = 0, cur_bw = 0, cur_ch_offset = 0;
_irqL irqL;
/* RTW_INFO("[length]=%d, [C2H data]="MAC_FMT"\n", buflen, MAC_ARG(tmpBuf)); */
/* To avoid reg is set, but driver recive c2h to set wrong oper_channel */
if (MCC_RPT_STOPMCC == pmccobjpriv->mcc_c2h_status) {
RTW_INFO(FUNC_ADPT_FMT" MCC alread stops return\n", FUNC_ADPT_ARG(padapter));
return;
}
_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
pmccobjpriv->mcc_c2h_status = tmpBuf[0];
pmccobjpriv->current_order = tmpBuf[1];
cur_adapter = pmccobjpriv->iface[pmccobjpriv->current_order];
cur_ch = cur_adapter->mlmeextpriv.cur_channel;
cur_bw = cur_adapter->mlmeextpriv.cur_bwmode;
cur_ch_offset = cur_adapter->mlmeextpriv.cur_ch_offset;
rtw_set_oper_ch(cur_adapter, cur_ch);
rtw_set_oper_bw(cur_adapter, cur_bw);
rtw_set_oper_choffset(cur_adapter, cur_ch_offset);
_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
if (0)
RTW_INFO("%d,order:%d,TSF:0x%llx\n", tmpBuf[0], tmpBuf[1], RTW_GET_LE64(tmpBuf + 2));
switch (pmccobjpriv->mcc_c2h_status) {
case MCC_RPT_SUCCESS:
_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
pmccobjpriv->cur_mcc_success_cnt++;
rtw_hal_mcc_upadate_chnl_bw(cur_adapter, cur_ch, cur_ch_offset, cur_bw, _FALSE);
mcc_get_reg_cmd(padapter, pmccobjpriv->current_order);
_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
break;
case MCC_RPT_TXNULL_FAIL:
RTW_INFO("[MCC] TXNULL FAIL\n");
break;
case MCC_RPT_STOPMCC:
RTW_INFO("[MCC] MCC stop\n");
pmccobjpriv->mcc_c2h_status = MCC_RPT_STOPMCC;
rtw_hal_mcc_upadate_chnl_bw(cur_adapter, cur_ch, cur_ch_offset, cur_bw, _TRUE);
rtw_sctx_done(&mcc_sctx);
break;
case MCC_RPT_READY:
_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
/* initialize counter & time */
pmccobjpriv->mcc_launch_time = rtw_get_current_time();
pmccobjpriv->mcc_c2h_status = MCC_RPT_READY;
pmccobjpriv->cur_mcc_success_cnt = 0;
pmccobjpriv->prev_mcc_success_cnt = 0;
pmccobjpriv->mcc_tolerance_time = MCC_TOLERANCE_TIME;
_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
RTW_INFO("[MCC] MCC ready\n");
rtw_sctx_done(&mcc_sctx);
break;
case MCC_RPT_SWICH_CHANNEL_NOTIFY:
rtw_hal_mcc_sw_ch_fw_notify_hdl(padapter);
break;
case MCC_RPT_UPDATE_NOA_START_TIME:
rtw_hal_mcc_update_noa_start_time_hdl(padapter, buflen, tmpBuf);
break;
case MCC_RPT_TSF:
_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
rtw_hal_mcc_rpt_tsf_hdl(padapter, buflen, tmpBuf);
_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
break;
default:
/* RTW_INFO("[MCC] Other MCC status(%d)\n", pmccobjpriv->mcc_c2h_status); */
break;
}
}
void rtw_hal_mcc_update_parameter(PADAPTER padapter, u8 force_update)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
u8 cmd[H2C_MCC_TIME_SETTING_LEN] = {0};
u8 swchannel_early_time = MCC_SWCH_FW_EARLY_TIME;
u8 ap_num = DEV_AP_NUM(dvobj);
if (ap_num == 0) {
u8 need_update = _FALSE;
u8 start_time_offset = 0, interval = 0, duration = 0;
need_update = rtw_hal_mcc_update_timing_parameters(padapter, force_update);
if (need_update == _FALSE)
return;
start_time_offset = mccobjpriv->start_time;
interval = mccobjpriv->interval;
duration = mccobjpriv->iface[0]->mcc_adapterpriv.mcc_duration;
SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, start_time_offset);
SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
SET_H2CCMD_MCC_TIME_SETTING_UPDATE(cmd, _TRUE);
SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(cmd, duration);
} else {
PADAPTER order0_iface = NULL;
PADAPTER order1_iface = NULL;
u8 policy_idx = mccobjpriv->policy_index;
u8 duration = mcc_switch_channel_policy_table[policy_idx][MCC_DURATION_IDX];
u8 tsf_sync_offset = mcc_switch_channel_policy_table[policy_idx][MCC_TSF_SYNC_OFFSET_IDX];
u8 start_time_offset = mcc_switch_channel_policy_table[policy_idx][MCC_START_TIME_OFFSET_IDX];
u8 interval = mcc_switch_channel_policy_table[policy_idx][MCC_INTERVAL_IDX];
u8 guard_offset0 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET0_IDX];
u8 guard_offset1 = mcc_switch_channel_policy_table[policy_idx][MCC_GUARD_OFFSET1_IDX];
u8 order0_duration = 0;
u8 i = 0;
enum _hw_port tsf_bsae_port = MAX_HW_PORT;
enum _hw_port tsf_sync_port = MAX_HW_PORT;
RTW_INFO("%s: policy_idx=%d\n", __func__, policy_idx);
order0_iface = mccobjpriv->iface[0];
order1_iface = mccobjpriv->iface[1];
/* GO/AP is order 0, GC/STA is order 1 */
order0_duration = order0_iface->mcc_adapterpriv.mcc_duration = interval - duration;
order0_iface->mcc_adapterpriv.mcc_duration = duration;
tsf_bsae_port = rtw_hal_get_port(order1_iface);
tsf_sync_port = rtw_hal_get_port(order0_iface);
/* update IE */
for (i = 0; i < dvobj->iface_nums; i++) {
PADAPTER iface = NULL;
struct mcc_adapter_priv *mccadapriv = NULL;
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
if (mccadapriv->role == MCC_ROLE_GO)
rtw_hal_mcc_update_go_p2p_ie(iface);
}
/* update H2C cmd */
/* FW set enable */
SET_H2CCMD_MCC_TIME_SETTING_FW_EN(cmd, _TRUE);
/* TSF Sync offset */
SET_H2CCMD_MCC_TIME_SETTING_TSF_SYNC_OFFSET(cmd, tsf_sync_offset);
/* start time offset */
SET_H2CCMD_MCC_TIME_SETTING_START_TIME(cmd, (start_time_offset + guard_offset0));
/* interval */
SET_H2CCMD_MCC_TIME_SETTING_INTERVAL(cmd, interval);
/* Early time to inform driver by C2H before switch channel */
SET_H2CCMD_MCC_TIME_SETTING_EARLY_SWITCH_RPT(cmd, swchannel_early_time);
/* Port0 sync from Port1, not support multi-port */
SET_H2CCMD_MCC_TIME_SETTING_ORDER_BASE(cmd, tsf_bsae_port);
SET_H2CCMD_MCC_TIME_SETTING_ORDER_SYNC(cmd, tsf_sync_port);
SET_H2CCMD_MCC_TIME_SETTING_UPDATE(cmd, _TRUE);
SET_H2CCMD_MCC_TIME_SETTING_ORDER0_DURATION(cmd, order0_duration);
}
rtw_hal_fill_h2c_cmd(padapter, H2C_MCC_TIME_SETTING, H2C_MCC_TIME_SETTING_LEN, cmd);
}
/**
* rtw_hal_mcc_sw_status_check - check mcc swich channel status
* @padapter: primary adapter
*/
void rtw_hal_mcc_sw_status_check(PADAPTER padapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
struct pwrctrl_priv *pwrpriv = dvobj_to_pwrctl(dvobj);
struct mcc_adapter_priv *mccadapriv = NULL;
_adapter *iface = NULL;
u8 cur_cnt = 0, prev_cnt = 0, diff_cnt = 0, check_ret = _FAIL, threshold = 0;
u8 policy_idx = pmccobjpriv->policy_index;
u8 noa_enable = _FALSE;
u8 i = 0;
_irqL irqL;
u8 ap_num = DEV_AP_NUM(dvobj);
/* #define MCC_RESTART 1 */
if (!MCC_EN(padapter))
return;
_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
/* check noa enable or not */
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
if (iface->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
noa_enable = _TRUE;
break;
}
}
if (!noa_enable && ap_num == 0)
rtw_hal_mcc_update_parameter(padapter, _FALSE);
threshold = pmccobjpriv->mcc_stop_threshold;
if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
rtw_warn_on(1);
RTW_INFO("PS mode is not active under mcc, force exit ps mode\n");
LeaveAllPowerSaveModeDirect(padapter);
}
if (rtw_get_passing_time_ms(pmccobjpriv->mcc_launch_time) > 2000) {
_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
cur_cnt = pmccobjpriv->cur_mcc_success_cnt;
prev_cnt = pmccobjpriv->prev_mcc_success_cnt;
if (cur_cnt < prev_cnt)
diff_cnt = (cur_cnt + 255) - prev_cnt;
else
diff_cnt = cur_cnt - prev_cnt;
if (diff_cnt < threshold) {
pmccobjpriv->mcc_tolerance_time--;
RTW_INFO("%s: diff_cnt:%d, tolerance_time:%d\n",
__func__, diff_cnt, pmccobjpriv->mcc_tolerance_time);
} else
pmccobjpriv->mcc_tolerance_time = MCC_TOLERANCE_TIME;
pmccobjpriv->prev_mcc_success_cnt = pmccobjpriv->cur_mcc_success_cnt;
if (pmccobjpriv->mcc_tolerance_time != 0)
check_ret = _SUCCESS;
_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
if (check_ret != _SUCCESS) {
RTW_INFO("============ MCC swich channel check fail (%d)=============\n", diff_cnt);
/* restart MCC */
#ifdef MCC_RESTART
rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_STOP_DISCONNECT);
rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
#endif /* MCC_RESTART */
}
} else {
_enter_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
pmccobjpriv->prev_mcc_success_cnt = pmccobjpriv->cur_mcc_success_cnt;
_exit_critical_bh(&pmccobjpriv->mcc_lock, &irqL);
}
}
_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
}
/**
* rtw_hal_mcc_change_scan_flag - change scan flag under mcc
*
* MCC mode under sitesurvey goto AP channel to tx bcn & data
* MCC mode under sitesurvey doesn't support TX data for station mode (FW not support)
*
* @padapter: the adapter to be change scan flag
* @ch: pointer to rerurn ch
* @bw: pointer to rerurn bw
* @offset: pointer to rerurn offset
*/
u8 rtw_hal_mcc_change_scan_flag(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset)
{
u8 need_ch_setting_union = _TRUE, i = 0, flags = 0, back_op = _FALSE;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_adapter_priv *mccadapriv = NULL;
struct mlme_ext_priv *mlmeext = NULL;
_adapter *iface = NULL;
if (!MCC_EN(padapter))
goto exit;
if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC))
goto exit;
/* disable PS_ANNC & TX_RESUME for all interface */
/* ToDo: TX_RESUME by interface in SCAN_BACKING_OP */
mlmeext = &padapter->mlmeextpriv;
flags = mlmeext_scan_backop_flags(mlmeext);
if (mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_PS_ANNC))
flags &= ~SS_BACKOP_PS_ANNC;
if (mlmeext_chk_scan_backop_flags(mlmeext, SS_BACKOP_TX_RESUME))
flags &= ~SS_BACKOP_TX_RESUME;
mlmeext_assign_scan_backop_flags(mlmeext, flags);
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (!iface)
continue;
mlmeext = &iface->mlmeextpriv;
if (MLME_IS_GO(iface) || MLME_IS_AP(iface))
back_op = _TRUE;
else if (MLME_IS_GC(iface) && (iface != padapter))
/* switch to another linked interface(GO) to receive beacon to avoid no beacon disconnect */
back_op = _TRUE;
else if (MLME_IS_STA(iface) && MLME_IS_ASOC(iface) && (iface != padapter))
/* switch to another linked interface(STA) to receive beacon to avoid no beacon disconnect */
back_op = _TRUE;
else {
/* bypass non-linked/non-linking interface/scan interface */
continue;
}
if (back_op) {
*ch = mlmeext->cur_channel;
*bw = mlmeext->cur_bwmode;
*offset = mlmeext->cur_ch_offset;
need_ch_setting_union = _FALSE;
}
}
exit:
return need_ch_setting_union;
}
/**
* rtw_hal_mcc_calc_tx_bytes_from_kernel - calculte tx bytes from kernel to check concurrent tx or not
* @padapter: the adapter to be record tx bytes
* @len: data len
*/
inline void rtw_hal_mcc_calc_tx_bytes_from_kernel(PADAPTER padapter, u32 len)
{
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
if (MCC_EN(padapter)) {
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
pmccadapriv->mcc_tx_bytes_from_kernel += len;
if (0)
RTW_INFO("%s(order:%d): mcc tx bytes from kernel:%lld\n"
, __func__, pmccadapriv->order, pmccadapriv->mcc_tx_bytes_from_kernel);
}
}
}
/**
* rtw_hal_mcc_calc_tx_bytes_to_port - calculte tx bytes to write port in order to flow crtl
* @padapter: the adapter to be record tx bytes
* @len: data len
*/
inline void rtw_hal_mcc_calc_tx_bytes_to_port(PADAPTER padapter, u32 len)
{
if (MCC_EN(padapter)) {
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
pmccadapriv->mcc_tx_bytes_to_port += len;
if (0)
RTW_INFO("%s(order:%d): mcc tx bytes to port:%d, mcc target tx bytes to port:%d\n"
, __func__, pmccadapriv->order, pmccadapriv->mcc_tx_bytes_to_port
, pmccadapriv->mcc_target_tx_bytes_to_port);
}
}
}
/**
* rtw_hal_mcc_stop_tx_bytes_to_port - stop write port to hw or not
* @padapter: the adapter to be stopped
*/
inline u8 rtw_hal_mcc_stop_tx_bytes_to_port(PADAPTER padapter)
{
if (MCC_EN(padapter)) {
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
if (pmccadapriv->mcc_tp_limit) {
if (pmccadapriv->mcc_tx_bytes_to_port >= pmccadapriv->mcc_target_tx_bytes_to_port) {
pmccadapriv->mcc_tx_stop = _TRUE;
rtw_netif_stop_queue(padapter->pnetdev);
return _TRUE;
}
}
}
}
return _FALSE;
}
static void rtw_hal_mcc_assign_scan_flag(PADAPTER padapter, u8 scan_done)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_adapter_priv *mccadapriv = NULL;
_adapter *iface = NULL;
struct mlme_ext_priv *pmlmeext = NULL;
u8 i = 0, flags;
if (!MCC_EN(padapter))
return;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface == NULL)
continue;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv->role == MCC_ROLE_MAX)
continue;
pmlmeext = &iface->mlmeextpriv;
if (is_client_associated_to_ap(iface)) {
flags = mlmeext_scan_backop_flags_sta(pmlmeext);
if (scan_done) {
if (mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN)) {
flags &= ~SS_BACKOP_EN;
mlmeext_assign_scan_backop_flags_sta(pmlmeext, flags);
}
} else {
if (!mlmeext_chk_scan_backop_flags_sta(pmlmeext, SS_BACKOP_EN)) {
flags |= SS_BACKOP_EN;
mlmeext_assign_scan_backop_flags_sta(pmlmeext, flags);
}
}
}
}
}
/**
* rtw_hal_set_mcc_setting_scan_start - setting mcc under scan start
* @padapter: the adapter to be setted
* @ch_setting_changed: softap channel setting to be changed or not
*/
u8 rtw_hal_set_mcc_setting_scan_start(PADAPTER padapter)
{
u8 ret = _FAIL;
if (MCC_EN(padapter)) {
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_STOP_SCAN_START);
rtw_hal_mcc_assign_scan_flag(padapter, 0);
}
}
_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
}
return ret;
}
/**
* rtw_hal_set_mcc_setting_scan_complete - setting mcc after scan commplete
* @padapter: the adapter to be setted
* @ch_setting_changed: softap channel setting to be changed or not
*/
u8 rtw_hal_set_mcc_setting_scan_complete(PADAPTER padapter)
{
u8 ret = _FAIL;
if (MCC_EN(padapter)) {
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
rtw_hal_mcc_assign_scan_flag(padapter, 1);
ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_SCAN_DONE);
}
_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
}
return ret;
}
/**
* rtw_hal_set_mcc_setting_start_bss_network - setting mcc under softap start
* @padapter: the adapter to be setted
* @chbw_grouped: channel bw offset can not be allowed or not
*/
u8 rtw_hal_set_mcc_setting_start_bss_network(PADAPTER padapter, u8 chbw_allow)
{
u8 ret = _FAIL;
if (MCC_EN(padapter)) {
/* channel bw offset can not be allowed, start MCC */
if (chbw_allow == _FALSE) {
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
rtw_hal_mcc_restore_iqk_val(padapter);
_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
}
}
return ret;
}
/**
* rtw_hal_set_mcc_setting_disconnect - setting mcc under mlme disconnect(stop softap/disconnect from AP)
* @padapter: the adapter to be setted
*/
u8 rtw_hal_set_mcc_setting_disconnect(PADAPTER padapter)
{
u8 ret = _FAIL;
if (MCC_EN(padapter)) {
struct mcc_obj_priv *pmccobjpriv = &(adapter_to_dvobj(padapter)->mcc_objpriv);
_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_STOP_DISCONNECT);
}
_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
}
return ret;
}
/**
* rtw_hal_set_mcc_setting_join_done_chk_ch - setting mcc under join done
* @padapter: the adapter to be checked
*/
u8 rtw_hal_set_mcc_setting_join_done_chk_ch(PADAPTER padapter)
{
u8 ret = _FAIL;
if (MCC_EN(padapter)) {
struct mi_state mstate;
rtw_mi_status_no_self(padapter, &mstate);
if (MSTATE_STA_LD_NUM(&mstate) || MSTATE_STA_LG_NUM(&mstate) || MSTATE_AP_NUM(&mstate)) {
bool chbw_allow = _TRUE;
u8 u_ch, u_offset, u_bw;
struct mlme_ext_priv *cur_mlmeext = &padapter->mlmeextpriv;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
if (rtw_mi_get_ch_setting_union_no_self(padapter, &u_ch, &u_bw, &u_offset) <= 0) {
dump_adapters_status(RTW_DBGDUMP , dvobj);
rtw_warn_on(1);
}
RTW_INFO(FUNC_ADPT_FMT" union no self: %u,%u,%u\n"
, FUNC_ADPT_ARG(padapter), u_ch, u_bw, u_offset);
/* chbw_allow? */
chbw_allow = rtw_is_chbw_grouped(cur_mlmeext->cur_channel
, cur_mlmeext->cur_bwmode, cur_mlmeext->cur_ch_offset
, u_ch, u_bw, u_offset);
RTW_INFO(FUNC_ADPT_FMT" chbw_allow:%d\n"
, FUNC_ADPT_ARG(padapter), chbw_allow);
/* if chbw_allow = false, start MCC setting */
if (chbw_allow == _FALSE) {
struct mcc_obj_priv *pmccobjpriv = &dvobj->mcc_objpriv;
rtw_hal_mcc_restore_iqk_val(padapter);
_enter_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
ret = rtw_hal_set_mcc_setting(padapter, MCC_SETCMD_STATUS_START_CONNECT);
_exit_critical_mutex(&pmccobjpriv->mcc_mutex, NULL);
}
}
}
return ret;
}
/**
* rtw_hal_set_mcc_setting_chk_start_clnt_join - check change channel under start clnt join
* @padapter: the adapter to be checked
* @ch: pointer to rerurn ch
* @bw: pointer to rerurn bw
* @offset: pointer to rerurn offset
* @chbw_allow: allow to use adapter's channel setting
*/
u8 rtw_hal_set_mcc_setting_chk_start_clnt_join(PADAPTER padapter, u8 *ch, u8 *bw, u8 *offset, u8 chbw_allow)
{
u8 ret = _FAIL;
/* if chbw_allow = false under en_mcc = TRUE, we do not change channel related setting */
if (MCC_EN(padapter)) {
/* restore union channel related setting to current channel related setting */
if (chbw_allow == _FALSE) {
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
/* issue null data to other interface connected to AP */
rtw_hal_mcc_issue_null_data(padapter, chbw_allow, _TRUE);
*ch = pmlmeext->cur_channel;
*bw = pmlmeext->cur_bwmode;
*offset = pmlmeext->cur_ch_offset;
RTW_INFO(FUNC_ADPT_FMT" en_mcc:%d(%d,%d,%d,)\n"
, FUNC_ADPT_ARG(padapter), MCC_EN(padapter)
, *ch, *bw, *offset);
ret = _SUCCESS;
}
}
return ret;
}
static void rtw_hal_mcc_dump_noa_content(void *sel, PADAPTER padapter)
{
struct mcc_adapter_priv *pmccadapriv = NULL;
u8 *pos = NULL;
pmccadapriv = &padapter->mcc_adapterpriv;
/* last position for NoA attribute */
pos = pmccadapriv->p2p_go_noa_ie + pmccadapriv->p2p_go_noa_ie_len;
RTW_PRINT_SEL(sel, "\nStart to dump NoA Content\n");
RTW_PRINT_SEL(sel, "NoA Counts:%d\n", *(pos - 13));
RTW_PRINT_SEL(sel, "NoA Duration(TU):%d\n", (RTW_GET_LE32(pos - 12))/TU);
RTW_PRINT_SEL(sel, "NoA Interval(TU):%d\n", (RTW_GET_LE32(pos - 8))/TU);
RTW_PRINT_SEL(sel, "NoA Start time(microseconds):0x%02x\n", RTW_GET_LE32(pos - 4));
RTW_PRINT_SEL(sel, "End to dump NoA Content\n");
}
static void mcc_dump_dbg_reg(void *sel, _adapter *adapter)
{
struct mcc_obj_priv *mccobjpriv = adapter_to_mccobjpriv(adapter);
HAL_DATA_TYPE *hal = GET_HAL_DATA(adapter);
u8 i,j;
_irqL irqL;
_enter_critical_bh(&mccobjpriv->mcc_lock, &irqL);
RTW_PRINT_SEL(sel, "current order=%d\n", mccobjpriv->current_order);
_exit_critical_bh(&mccobjpriv->mcc_lock, &irqL);
_enter_critical_mutex(&mccobjpriv->mcc_dbg_reg_mutex, NULL);
for (i = 0; i < ARRAY_SIZE(mccobjpriv->dbg_reg); i++)
RTW_PRINT_SEL(sel, "REG_0x%X:0x%08x\n", mccobjpriv->dbg_reg[i], mccobjpriv->dbg_reg_val[i]);
for (i = 0; i < ARRAY_SIZE(mccobjpriv->dbg_rf_reg); i++) {
for (j = 0; j < hal->NumTotalRFPath; j++)
RTW_PRINT_SEL(sel, "RF_PATH_%d_REG_0x%X:0x%08x\n",
j, mccobjpriv->dbg_rf_reg[i], mccobjpriv->dbg_rf_reg_val[i][j]);
}
_exit_critical_mutex(&mccobjpriv->mcc_dbg_reg_mutex, NULL);
}
void rtw_hal_dump_mcc_info(void *sel, struct dvobj_priv *dvobj)
{
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
struct mcc_adapter_priv *mccadapriv = NULL;
_adapter *iface = NULL, *pri_adapter = NULL;
struct registry_priv *regpriv = NULL;
HAL_DATA_TYPE *hal = NULL;
u8 i = 0, j = 0;
u64 tsf[MAX_MCC_NUM] = {0};
/* regpriv is common for all adapter */
pri_adapter = dvobj_get_primary_adapter(dvobj);
hal = GET_HAL_DATA(pri_adapter);
RTW_PRINT_SEL(sel, "**********************************************\n");
RTW_PRINT_SEL(sel, "en_mcc:%d\n", MCC_EN(pri_adapter));
RTW_PRINT_SEL(sel, "primary adapter("ADPT_FMT") duration:%d%c\n",
ADPT_ARG(dvobj_get_primary_adapter(dvobj)), mccobjpriv->duration, 37);
RTW_PRINT_SEL(sel, "runtime duration:%s\n", mccobjpriv->enable_runtime_duration ? "enable":"disable");
RTW_PRINT_SEL(sel, "phydm offload:%s\n", mccobjpriv->mcc_phydm_offload ? "enable":"disable");
if (rtw_hal_check_mcc_status(pri_adapter, MCC_STATUS_DOING_MCC)) {
rtw_hal_mcc_rqt_tsf(pri_adapter, tsf);
for (i = 0; i < MAX_MCC_NUM; i++) {
iface = mccobjpriv->iface[i];
if (!iface)
continue;
regpriv = &iface->registrypriv;
mccadapriv = &iface->mcc_adapterpriv;
if (mccadapriv) {
u8 p2p_ps_mode = iface->wdinfo.p2p_ps_mode;
RTW_PRINT_SEL(sel, "adapter mcc info:\n");
RTW_PRINT_SEL(sel, "ifname:%s\n", ADPT_ARG(iface));
RTW_PRINT_SEL(sel, "order:%d\n", mccadapriv->order);
RTW_PRINT_SEL(sel, "duration:%d\n", mccadapriv->mcc_duration);
RTW_PRINT_SEL(sel, "target tx bytes:%d\n", mccadapriv->mcc_target_tx_bytes_to_port);
RTW_PRINT_SEL(sel, "current TP:%d\n", mccadapriv->mcc_tp);
RTW_PRINT_SEL(sel, "mgmt queue macid:%d\n", mccadapriv->mgmt_queue_macid);
RTW_PRINT_SEL(sel, "macid bitmap:0x%02x\n", mccadapriv->mcc_macid_bitmap);
RTW_PRINT_SEL(sel, "P2P NoA:%s\n\n", p2p_ps_mode == P2P_PS_NOA ? "enable":"disable");
RTW_PRINT_SEL(sel, "registry data:\n");
RTW_PRINT_SEL(sel, "ap target tx TP(BW:20M):%d Mbps\n", regpriv->rtw_mcc_ap_bw20_target_tx_tp);
RTW_PRINT_SEL(sel, "ap target tx TP(BW:40M):%d Mbps\n", regpriv->rtw_mcc_ap_bw40_target_tx_tp);
RTW_PRINT_SEL(sel, "ap target tx TP(BW:80M):%d Mbps\n", regpriv->rtw_mcc_ap_bw80_target_tx_tp);
RTW_PRINT_SEL(sel, "sta target tx TP(BW:20M):%d Mbps\n", regpriv->rtw_mcc_sta_bw20_target_tx_tp);
RTW_PRINT_SEL(sel, "sta target tx TP(BW:40M ):%d Mbps\n", regpriv->rtw_mcc_sta_bw40_target_tx_tp);
RTW_PRINT_SEL(sel, "sta target tx TP(BW:80M):%d Mbps\n", regpriv->rtw_mcc_sta_bw80_target_tx_tp);
RTW_PRINT_SEL(sel, "single tx criteria:%d Mbps\n", regpriv->rtw_mcc_single_tx_cri);
RTW_PRINT_SEL(sel, "HW TSF=0x%llx\n", tsf[mccadapriv->order]);
if (MLME_IS_GO(iface))
rtw_hal_mcc_dump_noa_content(sel, iface);
RTW_PRINT_SEL(sel, "**********************************************\n");
}
}
mcc_dump_dbg_reg(sel, pri_adapter);
}
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
RTW_PRINT_SEL(sel, "@@@@@@@@@@@@@@@@@@@@\n");
rtw_hal_mcc_cfg_phydm(pri_adapter, MCC_CFG_PHYDM_DUMP, sel);
RTW_PRINT_SEL(sel, "@@@@@@@@@@@@@@@@@@@@\n");
#endif
RTW_PRINT_SEL(sel, "------------------------------------------\n");
RTW_PRINT_SEL(sel, "policy index:%d\n", mccobjpriv->policy_index);
RTW_PRINT_SEL(sel, "------------------------------------------\n");
RTW_PRINT_SEL(sel, "define data:\n");
RTW_PRINT_SEL(sel, "ap target tx TP(BW:20M):%d Mbps\n", MCC_AP_BW20_TARGET_TX_TP);
RTW_PRINT_SEL(sel, "ap target tx TP(BW:40M):%d Mbps\n", MCC_AP_BW40_TARGET_TX_TP);
RTW_PRINT_SEL(sel, "ap target tx TP(BW:80M):%d Mbps\n", MCC_AP_BW80_TARGET_TX_TP);
RTW_PRINT_SEL(sel, "sta target tx TP(BW:20M):%d Mbps\n", MCC_STA_BW20_TARGET_TX_TP);
RTW_PRINT_SEL(sel, "sta target tx TP(BW:40M):%d Mbps\n", MCC_STA_BW40_TARGET_TX_TP);
RTW_PRINT_SEL(sel, "sta target tx TP(BW:80M):%d Mbps\n", MCC_STA_BW80_TARGET_TX_TP);
RTW_PRINT_SEL(sel, "single tx criteria:%d Mbps\n", MCC_SINGLE_TX_CRITERIA);
RTW_PRINT_SEL(sel, "------------------------------------------\n");
}
inline void update_mcc_mgntframe_attrib(_adapter *padapter, struct pkt_attrib *pattrib)
{
if (MCC_EN(padapter)) {
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC)) {
/* use QSLT_MGNT to check mgnt queue or bcn queue */
if (pattrib->qsel == QSLT_MGNT) {
pattrib->mac_id = padapter->mcc_adapterpriv.mgmt_queue_macid;
pattrib->qsel = QSLT_VO;
}
}
}
}
inline u8 rtw_hal_mcc_link_status_chk(_adapter *padapter, const char *msg)
{
u8 ret = _TRUE, i = 0;
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface;
struct mlme_ext_priv *mlmeext;
if (MCC_EN(padapter)) {
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_NEED_MCC)) {
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
mlmeext = &iface->mlmeextpriv;
if (mlmeext_scan_state(mlmeext) != SCAN_DISABLE) {
#ifdef DBG_EXPIRATION_CHK
RTW_INFO(FUNC_ADPT_FMT" don't enter %s under scan for MCC mode\n", FUNC_ADPT_ARG(padapter), msg);
#endif
ret = _FALSE;
goto exit;
}
}
}
}
exit:
return ret;
}
void rtw_hal_mcc_issue_null_data(_adapter *padapter, u8 chbw_allow, u8 ps_mode)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
_adapter *iface = NULL;
systime start = rtw_get_current_time();
u8 i = 0;
if (!MCC_EN(padapter))
return;
if (rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
return;
if (chbw_allow == _TRUE)
return;
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
/* issue null data to inform ap station will leave */
if (is_client_associated_to_ap(iface)) {
struct mlme_ext_priv *mlmeext = &iface->mlmeextpriv;
struct mlme_ext_info *mlmeextinfo = &mlmeext->mlmext_info;
u8 ch = mlmeext->cur_channel;
u8 bw = mlmeext->cur_bwmode;
u8 offset = mlmeext->cur_ch_offset;
struct sta_info *sta = rtw_get_stainfo(&iface->stapriv, get_my_bssid(&(mlmeextinfo->network)));
if (!sta)
continue;
set_channel_bwmode(iface, ch, offset, bw);
if (ps_mode)
rtw_hal_macid_sleep(iface, sta->cmn.mac_id);
else
rtw_hal_macid_wakeup(iface, sta->cmn.mac_id);
issue_nulldata(iface, NULL, ps_mode, 3, 50);
}
}
RTW_INFO("%s(%d ms)\n", __func__, rtw_get_passing_time_ms(start));
}
u8 *rtw_hal_mcc_append_go_p2p_ie(PADAPTER padapter, u8 *pframe, u32 *len)
{
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
if (!MCC_EN(padapter))
return pframe;
if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
return pframe;
if (pmccadapriv->p2p_go_noa_ie_len == 0)
return pframe;
_rtw_memcpy(pframe, pmccadapriv->p2p_go_noa_ie, pmccadapriv->p2p_go_noa_ie_len);
*len = *len + pmccadapriv->p2p_go_noa_ie_len;
return pframe + pmccadapriv->p2p_go_noa_ie_len;
}
void rtw_hal_dump_mcc_policy_table(void *sel)
{
u8 idx = 0;
RTW_PRINT_SEL(sel, "duration\t,tsf sync offset\t,start time offset\t,interval\t,guard offset0\t,guard offset1\n");
for (idx = 0; idx < mcc_max_policy_num; idx ++) {
RTW_PRINT_SEL(sel, "%d\t\t,%d\t\t\t,%d\t\t\t,%d\t\t,%d\t\t,%d\n"
, mcc_switch_channel_policy_table[idx][MCC_DURATION_IDX]
, mcc_switch_channel_policy_table[idx][MCC_TSF_SYNC_OFFSET_IDX]
, mcc_switch_channel_policy_table[idx][MCC_START_TIME_OFFSET_IDX]
, mcc_switch_channel_policy_table[idx][MCC_INTERVAL_IDX]
, mcc_switch_channel_policy_table[idx][MCC_GUARD_OFFSET0_IDX]
, mcc_switch_channel_policy_table[idx][MCC_GUARD_OFFSET1_IDX]);
}
}
void rtw_hal_mcc_update_macid_bitmap(PADAPTER padapter, int mac_id, u8 add)
{
struct mcc_adapter_priv *pmccadapriv = &padapter->mcc_adapterpriv;
if (!MCC_EN(padapter))
return;
if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
return;
if (pmccadapriv->role == MCC_ROLE_GC || pmccadapriv->role == MCC_ROLE_STA)
return;
if (mac_id < 0) {
RTW_WARN("%s: mac_id < 0(%d)\n", __func__, mac_id);
return;
}
RTW_INFO(ADPT_FMT" %s macid=%d, ori mcc_macid_bitmap=0x%08x\n"
, ADPT_ARG(padapter), add ? "add" : "clear"
, mac_id, pmccadapriv->mcc_macid_bitmap);
if (add) {
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_ADD_CLIENT, &mac_id);
#endif
pmccadapriv->mcc_macid_bitmap |= BIT(mac_id);
} else {
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
rtw_hal_mcc_cfg_phydm(padapter, MCC_CFG_PHYDM_REMOVE_CLIENT, &mac_id);
#endif
pmccadapriv->mcc_macid_bitmap &= ~(BIT(mac_id));
}
rtw_hal_set_mcc_macid_cmd(padapter);
}
void rtw_hal_mcc_process_noa(PADAPTER padapter)
{
struct wifidirect_info *pwdinfo = &(padapter->wdinfo);
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
struct mcc_obj_priv *pmccobjpriv = &(dvobj->mcc_objpriv);
if (!MCC_EN(padapter))
return;
if (!rtw_hal_check_mcc_status(padapter, MCC_STATUS_DOING_MCC))
return;
if (!MLME_IS_GC(padapter))
return;
switch(pwdinfo->p2p_ps_mode) {
case P2P_PS_NONE:
RTW_INFO("[MCC] Disable NoA under MCC\n");
rtw_hal_mcc_update_parameter(padapter, _TRUE);
break;
case P2P_PS_NOA:
RTW_INFO("[MCC] Enable NoA under MCC\n");
break;
default:
break;
}
}
void rtw_hal_mcc_parameter_init(PADAPTER padapter)
{
if (!padapter->registrypriv.en_mcc)
return;
if (is_primary_adapter(padapter)) {
SET_MCC_EN_FLAG(padapter, padapter->registrypriv.en_mcc);
SET_MCC_DURATION(padapter, padapter->registrypriv.rtw_mcc_duration);
SET_MCC_RUNTIME_DURATION(padapter, padapter->registrypriv.rtw_mcc_enable_runtime_duration);
SET_MCC_PHYDM_OFFLOAD(padapter, padapter->registrypriv.rtw_mcc_phydm_offload);
}
}
static u8 set_mcc_duration_hdl(PADAPTER adapter, const u8 *val)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct mcc_obj_priv *mccobjpriv = &(dvobj->mcc_objpriv);
_adapter *iface = NULL;
u8 duration = 50;
u8 ret = _SUCCESS, noa_enable = _FALSE, i = 0;
enum mcc_duration_setting type;
if (!mccobjpriv->enable_runtime_duration)
goto exit;
#ifdef CONFIG_P2P_PS
/* check noa enable or not */
for (i = 0; i < dvobj->iface_nums; i++) {
iface = dvobj->padapters[i];
if (iface->wdinfo.p2p_ps_mode == P2P_PS_NOA) {
noa_enable = _TRUE;
break;
}
}
#endif /* CONFIG_P2P_PS */
type = val[0];
duration = val[1];
if (type == MCC_DURATION_MAPPING) {
switch (duration) {
/* 0 = fair scheduling */
case 0:
mccobjpriv->duration= 40;
mccobjpriv->policy_index = 2;
mccobjpriv->mchan_sched_mode = MCC_FAIR_SCHEDULE;
break;
/* 1 = favor STA */
case 1:
mccobjpriv->duration= 70;
mccobjpriv->policy_index = 1;
mccobjpriv->mchan_sched_mode = MCC_FAVOR_STA;
break;
/* 2 = favor P2P*/
case 2:
default:
mccobjpriv->duration= 30;
mccobjpriv->policy_index = 0;
mccobjpriv->mchan_sched_mode = MCC_FAVOR_P2P;
break;
}
} else {
mccobjpriv->duration = duration;
rtw_hal_mcc_update_policy_table(adapter);
}
/* only update sw parameter under MCC
it will be force update during */
if (noa_enable)
goto exit;
if (rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC))
rtw_hal_mcc_update_parameter(adapter, _TRUE);
exit:
return ret;
}
u8 rtw_set_mcc_duration_cmd(_adapter *adapter, u8 type, u8 val)
{
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 *buf = NULL;
u8 sz = 2;
u8 res = _SUCCESS;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
buf = rtw_zmalloc(sizeof(u8) * sz);
if (buf == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = MCC_CMD_WK_CID;
pdrvextra_cmd_parm->type = MCC_SET_DURATION_WK_CID;
pdrvextra_cmd_parm->size = sz;
pdrvextra_cmd_parm->pbuf = buf;
_rtw_memcpy(buf, &type, 1);
_rtw_memcpy(buf + 1, &val, 1);
init_h2fwcmd_w_parm_no_rsp(cmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
exit:
return res;
}
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
static u8 mcc_phydm_offload_enable_hdl(_adapter *adapter, const u8 *val)
{
struct mcc_obj_priv *mccobjpriv = adapter_to_mccobjpriv(adapter);
u8 ret = _SUCCESS;
u8 enable = *val;
/*only modify driver parameter during non-mcc status */
if (!rtw_hal_check_mcc_status(adapter, MCC_STATUS_DOING_MCC)) {
mccobjpriv->mcc_phydm_offload = enable;
} else {
/*modify both driver & phydm parameter during mcc status */
mccobjpriv->mcc_phydm_offload = enable;
rtw_hal_mcc_cfg_phydm(adapter, MCC_CFG_PHYDM_OFFLOAD, &mccobjpriv->mcc_phydm_offload);
}
RTW_INFO("[MCC] phydm offload enable hdl(%d)\n", mccobjpriv->mcc_phydm_offload);
return ret;
}
u8 rtw_set_mcc_phydm_offload_enable_cmd(_adapter *adapter, u8 enable, u8 enqueue)
{
u8 res = _SUCCESS;
if (enqueue) {
struct cmd_obj *cmdobj;
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
u8 *mcc_phydm_offload_enable = NULL;
cmdobj = (struct cmd_obj *)rtw_zmalloc(sizeof(struct cmd_obj));
if (cmdobj == NULL) {
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm = (struct drvextra_cmd_parm *)rtw_zmalloc(sizeof(struct drvextra_cmd_parm));
if (pdrvextra_cmd_parm == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
res = _FAIL;
goto exit;
}
mcc_phydm_offload_enable = rtw_zmalloc(sizeof(u8));
if (mcc_phydm_offload_enable == NULL) {
rtw_mfree((u8 *)cmdobj, sizeof(struct cmd_obj));
rtw_mfree((u8 *)pdrvextra_cmd_parm, sizeof(struct drvextra_cmd_parm));
res = _FAIL;
goto exit;
}
pdrvextra_cmd_parm->ec_id = MCC_CMD_WK_CID;
pdrvextra_cmd_parm->type = MCC_SET_PHYDM_OFFLOAD_WK_CID;
pdrvextra_cmd_parm->size = 1;
pdrvextra_cmd_parm->pbuf = mcc_phydm_offload_enable;
_rtw_memcpy(mcc_phydm_offload_enable, &enable, 1);
init_h2fwcmd_w_parm_no_rsp(cmdobj, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
res = rtw_enqueue_cmd(pcmdpriv, cmdobj);
} else {
mcc_phydm_offload_enable_hdl(adapter, &enable);
}
exit:
return res;
}
#endif
u8 rtw_mcc_cmd_hdl(_adapter *adapter, u8 type, const u8 *val)
{
struct mcc_obj_priv *mccobjpriv = adapter_to_mccobjpriv(adapter);
u8 ret = _SUCCESS;
switch (type) {
case MCC_SET_DURATION_WK_CID:
set_mcc_duration_hdl(adapter, val);
break;
case MCC_GET_DBG_REG_WK_CID:
mcc_get_reg_hdl(adapter, val);
break;
#ifdef CONFIG_MCC_PHYDM_OFFLOAD
case MCC_SET_PHYDM_OFFLOAD_WK_CID:
mcc_phydm_offload_enable_hdl(adapter, val);
break;
#endif
default:
RTW_ERR("[MCC] rtw_mcc_cmd_hdl fail(%d)\n", type);
break;
}
return ret;
}
#endif /* CONFIG_MCC_MODE */
================================================
FILE: hal/hal_mp.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_MP_C_
#include
#ifdef CONFIG_MP_INCLUDED
#ifdef RTW_HALMAC
#include /* struct HAL_DATA_TYPE, RF register definition and etc. */
#else /* !RTW_HALMAC */
#ifdef CONFIG_RTL8188E
#include
#endif
#ifdef CONFIG_RTL8723B
#include
#endif
#ifdef CONFIG_RTL8192E
#include
#endif
#ifdef CONFIG_RTL8814A
#include
#endif
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
#include
#endif
#ifdef CONFIG_RTL8703B
#include
#endif
#ifdef CONFIG_RTL8723D
#include
#endif
#ifdef CONFIG_RTL8710B
#include
#endif
#ifdef CONFIG_RTL8188F
#include
#endif
#ifdef CONFIG_RTL8188GTV
#include
#endif
#ifdef CONFIG_RTL8192F
#include
#endif
#endif /* !RTW_HALMAC */
u8 MgntQuery_NssTxRate(u16 Rate)
{
u8 NssNum = RF_TX_NUM_NONIMPLEMENT;
if ((Rate >= MGN_MCS8 && Rate <= MGN_MCS15) ||
(Rate >= MGN_VHT2SS_MCS0 && Rate <= MGN_VHT2SS_MCS9))
NssNum = RF_2TX;
else if ((Rate >= MGN_MCS16 && Rate <= MGN_MCS23) ||
(Rate >= MGN_VHT3SS_MCS0 && Rate <= MGN_VHT3SS_MCS9))
NssNum = RF_3TX;
else if ((Rate >= MGN_MCS24 && Rate <= MGN_MCS31) ||
(Rate >= MGN_VHT4SS_MCS0 && Rate <= MGN_VHT4SS_MCS9))
NssNum = RF_4TX;
else
NssNum = RF_1TX;
return NssNum;
}
void hal_mpt_SwitchRfSetting(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u8 ChannelToSw = pMptCtx->MptChannelToSw;
u32 ulRateIdx = pMptCtx->mpt_rate_index;
u32 ulbandwidth = pMptCtx->MptBandWidth;
/* <20120525, Kordan> Dynamic mechanism for APK, asked by Dennis.*/
if (IS_HARDWARE_TYPE_8188ES(pAdapter) && (1 <= ChannelToSw && ChannelToSw <= 11) &&
(ulRateIdx == MPT_RATE_MCS0 || ulRateIdx == MPT_RATE_1M || ulRateIdx == MPT_RATE_6M)) {
pMptCtx->backup0x52_RF_A = (u8)phy_query_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0);
pMptCtx->backup0x52_RF_B = (u8)phy_query_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0);
if ((PlatformEFIORead4Byte(pAdapter, 0xF4) & BIT29) == BIT29) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xB);
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xB);
} else {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xD);
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xD);
}
} else if (IS_HARDWARE_TYPE_8188EE(pAdapter)) { /* <20140903, VincentL> Asked by RF Eason and Edlu*/
if (ChannelToSw == 3 && ulbandwidth == MPT_BW_40MHZ) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0xB); /*RF 0x52 = 0x0007E4BD*/
} else {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, 0x9); /*RF 0x52 = 0x0007E49D*/
}
} else if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_A);
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_0x52, 0x000F0, pMptCtx->backup0x52_RF_B);
}
}
s32 hal_mpt_SetPowerTracking(PADAPTER padapter, u8 enable)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
if (!netif_running(padapter->pnetdev)) {
return _FAIL;
}
if (check_fwstate(&padapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
return _FAIL;
}
if (enable)
pDM_Odm->rf_calibrate_info.txpowertrack_control = _TRUE;
else
pDM_Odm->rf_calibrate_info.txpowertrack_control = _FALSE;
return _SUCCESS;
}
void hal_mpt_GetPowerTracking(PADAPTER padapter, u8 *enable)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(padapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
*enable = pDM_Odm->rf_calibrate_info.txpowertrack_control;
}
void hal_mpt_CCKTxPowerAdjust(PADAPTER Adapter, BOOLEAN bInCH14)
{
u32 TempVal = 0, TempVal2 = 0, TempVal3 = 0;
u32 CurrCCKSwingVal = 0, CCKSwingIndex = 12;
u8 i;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
u8 u1Channel = pHalData->current_channel;
u32 ulRateIdx = pMptCtx->mpt_rate_index;
u8 DataRate = 0xFF;
/* Do not modify CCK TX filter parameters for 8822B*/
if(IS_HARDWARE_TYPE_8822B(Adapter) || IS_HARDWARE_TYPE_8821C(Adapter) ||
IS_HARDWARE_TYPE_8723D(Adapter) || IS_HARDWARE_TYPE_8192F(Adapter) || IS_HARDWARE_TYPE_8822C(Adapter))
return;
DataRate = mpt_to_mgnt_rate(ulRateIdx);
if (u1Channel == 14 && IS_CCK_RATE(DataRate))
pHalData->bCCKinCH14 = TRUE;
else
pHalData->bCCKinCH14 = FALSE;
if (IS_HARDWARE_TYPE_8703B(Adapter)) {
if ((u1Channel == 14) && IS_CCK_RATE(DataRate)) {
/* Channel 14 in CCK, need to set 0xA26~0xA29 to 0 for 8703B */
phy_set_bb_reg(Adapter, rCCK0_TxFilter2, bMaskHWord, 0);
phy_set_bb_reg(Adapter, rCCK0_DebugPort, bMaskLWord, 0);
} else {
/* Normal setting for 8703B, just recover to the default setting. */
/* This hardcore values reference from the parameter which BB team gave. */
for (i = 0 ; i < 2 ; ++i)
phy_set_bb_reg(Adapter, pHalData->RegForRecover[i].offset, bMaskDWord, pHalData->RegForRecover[i].value);
}
} else if (IS_HARDWARE_TYPE_8723D(Adapter)) {
/* 2.4G CCK TX DFIR */
/* 2016.01.20 Suggest from RS BB mingzhi*/
if ((u1Channel == 14)) {
phy_set_bb_reg(Adapter, rCCK0_TxFilter2, bMaskDWord, 0x0000B81C);
phy_set_bb_reg(Adapter, rCCK0_DebugPort, bMaskDWord, 0x00000000);
phy_set_bb_reg(Adapter, 0xAAC, bMaskDWord, 0x00003667);
} else {
for (i = 0 ; i < 3 ; ++i) {
phy_set_bb_reg(Adapter,
pHalData->RegForRecover[i].offset,
bMaskDWord,
pHalData->RegForRecover[i].value);
}
}
} else if (IS_HARDWARE_TYPE_8188F(Adapter) || IS_HARDWARE_TYPE_8188GTV(Adapter)) {
/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
CCKSwingIndex = 20; /* default index */
if (!pHalData->bCCKinCH14) {
/* Readback the current bb cck swing value and compare with the table to */
/* get the current swing index */
for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch1_ch13_88f[i][0]) &&
(((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch1_ch13_88f[i][1])) {
CCKSwingIndex = i;
break;
}
}
write_bbreg(Adapter, 0xa22, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][0]);
write_bbreg(Adapter, 0xa23, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][1]);
write_bbreg(Adapter, 0xa24, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][2]);
write_bbreg(Adapter, 0xa25, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][3]);
write_bbreg(Adapter, 0xa26, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][4]);
write_bbreg(Adapter, 0xa27, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][5]);
write_bbreg(Adapter, 0xa28, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][6]);
write_bbreg(Adapter, 0xa29, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][7]);
write_bbreg(Adapter, 0xa9a, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][8]);
write_bbreg(Adapter, 0xa9b, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][9]);
write_bbreg(Adapter, 0xa9c, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][10]);
write_bbreg(Adapter, 0xa9d, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][11]);
write_bbreg(Adapter, 0xaa0, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][12]);
write_bbreg(Adapter, 0xaa1, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][13]);
write_bbreg(Adapter, 0xaa2, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][14]);
write_bbreg(Adapter, 0xaa3, bMaskByte0, cck_swing_table_ch1_ch13_88f[CCKSwingIndex][15]);
RTW_INFO("%s , cck_swing_table_ch1_ch13_88f[%d]\n", __func__, CCKSwingIndex);
} else {
for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch14_88f[i][0]) &&
(((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch14_88f[i][1])) {
CCKSwingIndex = i;
break;
}
}
write_bbreg(Adapter, 0xa22, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][0]);
write_bbreg(Adapter, 0xa23, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][1]);
write_bbreg(Adapter, 0xa24, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][2]);
write_bbreg(Adapter, 0xa25, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][3]);
write_bbreg(Adapter, 0xa26, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][4]);
write_bbreg(Adapter, 0xa27, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][5]);
write_bbreg(Adapter, 0xa28, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][6]);
write_bbreg(Adapter, 0xa29, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][7]);
write_bbreg(Adapter, 0xa9a, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][8]);
write_bbreg(Adapter, 0xa9b, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][9]);
write_bbreg(Adapter, 0xa9c, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][10]);
write_bbreg(Adapter, 0xa9d, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][11]);
write_bbreg(Adapter, 0xaa0, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][12]);
write_bbreg(Adapter, 0xaa1, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][13]);
write_bbreg(Adapter, 0xaa2, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][14]);
write_bbreg(Adapter, 0xaa3, bMaskByte0, cck_swing_table_ch14_88f[CCKSwingIndex][15]);
RTW_INFO("%s , cck_swing_table_ch14_88f[%d]\n", __func__, CCKSwingIndex);
}
} else {
/* get current cck swing value and check 0xa22 & 0xa23 later to match the table.*/
CurrCCKSwingVal = read_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord);
if (!pHalData->bCCKinCH14) {
/* Readback the current bb cck swing value and compare with the table to */
/* get the current swing index */
for (i = 0; i < CCK_TABLE_SIZE; i++) {
if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch1_ch13[i][0]) &&
(((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch1_ch13[i][1])) {
CCKSwingIndex = i;
break;
}
}
/*Write 0xa22 0xa23*/
TempVal = cck_swing_table_ch1_ch13[CCKSwingIndex][0] +
(cck_swing_table_ch1_ch13[CCKSwingIndex][1] << 8);
/*Write 0xa24 ~ 0xa27*/
TempVal2 = 0;
TempVal2 = cck_swing_table_ch1_ch13[CCKSwingIndex][2] +
(cck_swing_table_ch1_ch13[CCKSwingIndex][3] << 8) +
(cck_swing_table_ch1_ch13[CCKSwingIndex][4] << 16) +
(cck_swing_table_ch1_ch13[CCKSwingIndex][5] << 24);
/*Write 0xa28 0xa29*/
TempVal3 = 0;
TempVal3 = cck_swing_table_ch1_ch13[CCKSwingIndex][6] +
(cck_swing_table_ch1_ch13[CCKSwingIndex][7] << 8);
} else {
for (i = 0; i < CCK_TABLE_SIZE; i++) {
if (((CurrCCKSwingVal & 0xff) == (u32)cck_swing_table_ch14[i][0]) &&
(((CurrCCKSwingVal & 0xff00) >> 8) == (u32)cck_swing_table_ch14[i][1])) {
CCKSwingIndex = i;
break;
}
}
/*Write 0xa22 0xa23*/
TempVal = cck_swing_table_ch14[CCKSwingIndex][0] +
(cck_swing_table_ch14[CCKSwingIndex][1] << 8);
/*Write 0xa24 ~ 0xa27*/
TempVal2 = 0;
TempVal2 = cck_swing_table_ch14[CCKSwingIndex][2] +
(cck_swing_table_ch14[CCKSwingIndex][3] << 8) +
(cck_swing_table_ch14[CCKSwingIndex][4] << 16) +
(cck_swing_table_ch14[CCKSwingIndex][5] << 24);
/*Write 0xa28 0xa29*/
TempVal3 = 0;
TempVal3 = cck_swing_table_ch14[CCKSwingIndex][6] +
(cck_swing_table_ch14[CCKSwingIndex][7] << 8);
}
write_bbreg(Adapter, rCCK0_TxFilter1, bMaskHWord, TempVal);
write_bbreg(Adapter, rCCK0_TxFilter2, bMaskDWord, TempVal2);
write_bbreg(Adapter, rCCK0_DebugPort, bMaskLWord, TempVal3);
}
}
void hal_mpt_SetChannel(PADAPTER pAdapter)
{
enum rf_path eRFPath;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
struct dm_struct *pDM_Odm = &(pHalData->odmpriv);
struct mp_priv *pmp = &pAdapter->mppriv;
u8 channel = pmp->channel;
u8 bandwidth = pmp->bandwidth;
hal_mpt_SwitchRfSetting(pAdapter);
pHalData->bSwChnl = _TRUE;
pHalData->bSetChnlBW = _TRUE;
if (bandwidth == 2) {
rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
} else if (bandwidth == 1) {
rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
} else
rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
rtw_btcoex_wifionly_scan_notify(pAdapter);
}
/*
* Notice
* Switch bandwitdth may change center frequency(channel)
*/
void hal_mpt_SetBandwidth(PADAPTER pAdapter)
{
struct mp_priv *pmp = &pAdapter->mppriv;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 channel = pmp->channel;
u8 bandwidth = pmp->bandwidth;
pHalData->bSwChnl = _TRUE;
pHalData->bSetChnlBW = _TRUE;
if (bandwidth == 2) {
rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_LOWER, HAL_PRIME_CHNL_OFFSET_UPPER);
} else if (bandwidth == 1) {
rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, HAL_PRIME_CHNL_OFFSET_UPPER, 0);
} else
rtw_hal_set_chnl_bw(pAdapter, channel, bandwidth, pmp->prime_channel_offset, 0);
hal_mpt_SwitchRfSetting(pAdapter);
rtw_btcoex_wifionly_scan_notify(pAdapter);
}
void mpt_SetTxPower_Old(PADAPTER pAdapter, MPT_TXPWR_DEF Rate, u8 *pTxPower)
{
switch (Rate) {
case MPT_CCK: {
u32 TxAGC = 0, pwr = 0;
u8 rf;
pwr = pTxPower[RF_PATH_A];
if (pwr < 0x3f) {
TxAGC = (pwr << 16) | (pwr << 8) | (pwr);
phy_set_bb_reg(pAdapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, pTxPower[RF_PATH_A]);
phy_set_bb_reg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, TxAGC);
}
pwr = pTxPower[RF_PATH_B];
if (pwr < 0x3f) {
TxAGC = (pwr << 16) | (pwr << 8) | (pwr);
phy_set_bb_reg(pAdapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte0, pTxPower[RF_PATH_B]);
phy_set_bb_reg(pAdapter, rTxAGC_B_CCK1_55_Mcs32, 0xffffff00, TxAGC);
}
}
break;
case MPT_OFDM_AND_HT: {
u32 TxAGC = 0;
u8 pwr = 0, rf;
pwr = pTxPower[0];
if (pwr < 0x3f) {
TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
RTW_INFO("HT Tx-rf(A) Power = 0x%x\n", TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_A_Rate18_06, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_A_Rate54_24, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs03_Mcs00, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs07_Mcs04, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs11_Mcs08, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_A_Mcs15_Mcs12, bMaskDWord, TxAGC);
}
TxAGC = 0;
pwr = pTxPower[1];
if (pwr < 0x3f) {
TxAGC |= ((pwr << 24) | (pwr << 16) | (pwr << 8) | pwr);
RTW_INFO("HT Tx-rf(B) Power = 0x%x\n", TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_B_Rate18_06, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_B_Rate54_24, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs03_Mcs00, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs07_Mcs04, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs11_Mcs08, bMaskDWord, TxAGC);
phy_set_bb_reg(pAdapter, rTxAGC_B_Mcs15_Mcs12, bMaskDWord, TxAGC);
}
}
break;
default:
break;
}
RTW_INFO("<===mpt_SetTxPower_Old()\n");
}
void
mpt_SetTxPower(
PADAPTER pAdapter,
MPT_TXPWR_DEF Rate,
u8 *pTxPower
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 path = 0 , i = 0, MaxRate = MGN_6M;
u8 StartPath = RF_PATH_A, EndPath = RF_PATH_B;
if (IS_HARDWARE_TYPE_8814A(pAdapter))
EndPath = RF_PATH_D;
else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)
|| IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter))
EndPath = RF_PATH_A;
switch (Rate) {
case MPT_CCK: {
u8 rate[] = {MGN_1M, MGN_2M, MGN_5_5M, MGN_11M};
for (path = StartPath; path <= EndPath; path++)
for (i = 0; i < sizeof(rate); ++i)
PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
}
break;
case MPT_OFDM: {
u8 rate[] = {
MGN_6M, MGN_9M, MGN_12M, MGN_18M,
MGN_24M, MGN_36M, MGN_48M, MGN_54M,
};
for (path = StartPath; path <= EndPath; path++)
for (i = 0; i < sizeof(rate); ++i)
PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
}
break;
case MPT_HT: {
u8 rate[] = {
MGN_MCS0, MGN_MCS1, MGN_MCS2, MGN_MCS3, MGN_MCS4,
MGN_MCS5, MGN_MCS6, MGN_MCS7, MGN_MCS8, MGN_MCS9,
MGN_MCS10, MGN_MCS11, MGN_MCS12, MGN_MCS13, MGN_MCS14,
MGN_MCS15, MGN_MCS16, MGN_MCS17, MGN_MCS18, MGN_MCS19,
MGN_MCS20, MGN_MCS21, MGN_MCS22, MGN_MCS23, MGN_MCS24,
MGN_MCS25, MGN_MCS26, MGN_MCS27, MGN_MCS28, MGN_MCS29,
MGN_MCS30, MGN_MCS31,
};
if (pHalData->rf_type == RF_3T3R)
MaxRate = MGN_MCS23;
else if (pHalData->rf_type == RF_2T2R)
MaxRate = MGN_MCS15;
else
MaxRate = MGN_MCS7;
for (path = StartPath; path <= EndPath; path++) {
for (i = 0; i < sizeof(rate); ++i) {
if (rate[i] > MaxRate)
break;
PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
}
}
}
break;
case MPT_VHT: {
u8 rate[] = {
MGN_VHT1SS_MCS0, MGN_VHT1SS_MCS1, MGN_VHT1SS_MCS2, MGN_VHT1SS_MCS3, MGN_VHT1SS_MCS4,
MGN_VHT1SS_MCS5, MGN_VHT1SS_MCS6, MGN_VHT1SS_MCS7, MGN_VHT1SS_MCS8, MGN_VHT1SS_MCS9,
MGN_VHT2SS_MCS0, MGN_VHT2SS_MCS1, MGN_VHT2SS_MCS2, MGN_VHT2SS_MCS3, MGN_VHT2SS_MCS4,
MGN_VHT2SS_MCS5, MGN_VHT2SS_MCS6, MGN_VHT2SS_MCS7, MGN_VHT2SS_MCS8, MGN_VHT2SS_MCS9,
MGN_VHT3SS_MCS0, MGN_VHT3SS_MCS1, MGN_VHT3SS_MCS2, MGN_VHT3SS_MCS3, MGN_VHT3SS_MCS4,
MGN_VHT3SS_MCS5, MGN_VHT3SS_MCS6, MGN_VHT3SS_MCS7, MGN_VHT3SS_MCS8, MGN_VHT3SS_MCS9,
MGN_VHT4SS_MCS0, MGN_VHT4SS_MCS1, MGN_VHT4SS_MCS2, MGN_VHT4SS_MCS3, MGN_VHT4SS_MCS4,
MGN_VHT4SS_MCS5, MGN_VHT4SS_MCS6, MGN_VHT4SS_MCS7, MGN_VHT4SS_MCS8, MGN_VHT4SS_MCS9,
};
if (pHalData->rf_type == RF_3T3R)
MaxRate = MGN_VHT3SS_MCS9;
else if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_2T4R)
MaxRate = MGN_VHT2SS_MCS9;
else
MaxRate = MGN_VHT1SS_MCS9;
for (path = StartPath; path <= EndPath; path++) {
for (i = 0; i < sizeof(rate); ++i) {
if (rate[i] > MaxRate)
break;
PHY_SetTxPowerIndex(pAdapter, pTxPower[path], path, rate[i]);
}
}
}
break;
default:
RTW_INFO("<===mpt_SetTxPower: Illegal channel!!\n");
break;
}
}
void hal_mpt_SetTxPower(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
if (pHalData->rf_chip < RF_CHIP_MAX) {
if (IS_HARDWARE_TYPE_8188E(pAdapter) ||
IS_HARDWARE_TYPE_8723B(pAdapter) ||
IS_HARDWARE_TYPE_8192E(pAdapter) ||
IS_HARDWARE_TYPE_8703B(pAdapter) ||
IS_HARDWARE_TYPE_8188F(pAdapter) ||
IS_HARDWARE_TYPE_8188GTV(pAdapter)
) {
u8 path = (pHalData->antenna_tx_path == ANTENNA_A) ? (RF_PATH_A) : (RF_PATH_B);
RTW_INFO("===> MPT_ProSetTxPower: Old\n");
mpt_SetTxPower_Old(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
mpt_SetTxPower_Old(pAdapter, MPT_OFDM_AND_HT, pMptCtx->TxPwrLevel);
} else {
mpt_SetTxPower(pAdapter, MPT_CCK, pMptCtx->TxPwrLevel);
mpt_SetTxPower(pAdapter, MPT_OFDM, pMptCtx->TxPwrLevel);
mpt_SetTxPower(pAdapter, MPT_HT, pMptCtx->TxPwrLevel);
if(IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
RTW_INFO("===> MPT_ProSetTxPower: Jaguar/Jaguar2\n");
mpt_SetTxPower(pAdapter, MPT_VHT, pMptCtx->TxPwrLevel);
}
}
rtw_hal_set_txpwr_done(pAdapter);
} else
RTW_INFO("RFChipID < RF_CHIP_MAX, the RF chip is not supported - %d\n", pHalData->rf_chip);
odm_clear_txpowertracking_state(pDM_Odm);
}
void hal_mpt_SetDataRate(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u32 DataRate;
DataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
hal_mpt_SwitchRfSetting(pAdapter);
hal_mpt_CCKTxPowerAdjust(pAdapter, pHalData->bCCKinCH14);
#ifdef CONFIG_RTL8723B
if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
if (IS_CCK_RATE(DataRate)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A)
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0x6);
else
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0x6);
} else {
if (pMptCtx->mpt_rf_path == RF_PATH_A)
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0xE);
else
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0xE);
}
}
if ((IS_HARDWARE_TYPE_8723BS(pAdapter) &&
((pHalData->PackageType == PACKAGE_TFBGA79) || (pHalData->PackageType == PACKAGE_TFBGA90)))) {
if (pMptCtx->mpt_rf_path == RF_PATH_A)
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x51, 0xF, 0xE);
else
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x71, 0xF, 0xE);
}
#endif
}
#define RF_PATH_AB 22
#ifdef CONFIG_RTL8814A
void mpt_ToggleIG_8814A(PADAPTER pAdapter)
{
u8 Path;
u32 IGReg = rA_IGI_Jaguar, IGvalue = 0;
for (Path = 0; Path <= RF_PATH_D; Path++) {
switch (Path) {
case RF_PATH_B:
IGReg = rB_IGI_Jaguar;
break;
case RF_PATH_C:
IGReg = rC_IGI_Jaguar2;
break;
case RF_PATH_D:
IGReg = rD_IGI_Jaguar2;
break;
default:
IGReg = rA_IGI_Jaguar;
break;
}
IGvalue = phy_query_bb_reg(pAdapter, IGReg, bMaskByte0);
phy_set_bb_reg(pAdapter, IGReg, bMaskByte0, IGvalue + 2);
phy_set_bb_reg(pAdapter, IGReg, bMaskByte0, IGvalue);
}
}
void mpt_SetRFPath_8814A(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &pAdapter->mppriv.mpt_ctx;
R_ANTENNA_SELECT_OFDM *p_ofdm_tx; /* OFDM Tx register */
R_ANTENNA_SELECT_CCK *p_cck_txrx;
u8 ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
/*/PRT_HIGH_THROUGHPUT pHTInfo = GET_HT_INFO(pMgntInfo);*/
/*/PRT_VERY_HIGH_THROUGHPUT pVHTInfo = GET_VHT_INFO(pMgntInfo);*/
u32 ulAntennaTx = pHalData->antenna_tx_path;
u32 ulAntennaRx = pHalData->AntennaRxPath;
u8 NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
if (NssforRate == RF_3TX) {
RTW_INFO("===> SetAntenna 3T Rate ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
switch (ulAntennaTx) {
case ANTENNA_BCD:
pMptCtx->mpt_rf_path = RF_PATH_BCD;
/*pHalData->ValidTxPath = 0x0e;*/
phy_set_bb_reg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x90e); /*/ 0x940[27:16]=12'b0010_0100_0111*/
break;
case ANTENNA_ABC:
default:
pMptCtx->mpt_rf_path = RF_PATH_ABC;
/*pHalData->ValidTxPath = 0x0d;*/
phy_set_bb_reg(pAdapter, rTxAnt_23Nsts_Jaguar2, 0x0fff0000, 0x247); /*/ 0x940[27:16]=12'b0010_0100_0111*/
break;
}
} else { /*/if(NssforRate == RF_1TX)*/
RTW_INFO("===> SetAntenna for 1T/2T Rate, ForcedDataRate %d NssforRate %d AntennaTx %d\n", ForcedDataRate, NssforRate, ulAntennaTx);
switch (ulAntennaTx) {
case ANTENNA_BCD:
pMptCtx->mpt_rf_path = RF_PATH_BCD;
/*pHalData->ValidTxPath = 0x0e;*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x7);
phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0x000f00000, 0xe);
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0xe);
break;
case ANTENNA_BC:
pMptCtx->mpt_rf_path = RF_PATH_BC;
/*pHalData->ValidTxPath = 0x06;*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x6);
phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0x000f00000, 0x6);
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x6);
break;
case ANTENNA_B:
pMptCtx->mpt_rf_path = RF_PATH_B;
/*pHalData->ValidTxPath = 0x02;*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x4); /*/ 0xa07[7:4] = 4'b0100*/
phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x002); /*/ 0x93C[31:20]=12'b0000_0000_0010*/
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x2); /* 0x80C[7:4] = 4'b0010*/
break;
case ANTENNA_C:
pMptCtx->mpt_rf_path = RF_PATH_C;
/*pHalData->ValidTxPath = 0x04;*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x2); /*/ 0xa07[7:4] = 4'b0010*/
phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x004); /*/ 0x93C[31:20]=12'b0000_0000_0100*/
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x4); /*/ 0x80C[7:4] = 4'b0100*/
break;
case ANTENNA_D:
pMptCtx->mpt_rf_path = RF_PATH_D;
/*pHalData->ValidTxPath = 0x08;*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x1); /*/ 0xa07[7:4] = 4'b0001*/
phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x008); /*/ 0x93C[31:20]=12'b0000_0000_1000*/
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x8); /*/ 0x80C[7:4] = 4'b1000*/
break;
case ANTENNA_A:
default:
pMptCtx->mpt_rf_path = RF_PATH_A;
/*pHalData->ValidTxPath = 0x01;*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0xf0000000, 0x8); /*/ 0xa07[7:4] = 4'b1000*/
phy_set_bb_reg(pAdapter, rTxAnt_1Nsts_Jaguar2, 0xfff00000, 0x001); /*/ 0x93C[31:20]=12'b0000_0000_0001*/
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, 0xf0, 0x1); /*/ 0x80C[7:4] = 4'b0001*/
break;
}
}
switch (ulAntennaRx) {
case ANTENNA_A:
/*pHalData->ValidRxPath = 0x01;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x0);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
break;
case ANTENNA_B:
/*pHalData->ValidRxPath = 0x02;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x1);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
break;
case ANTENNA_C:
/*pHalData->ValidRxPath = 0x04;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x44);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x2);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
break;
case ANTENNA_D:
/*pHalData->ValidRxPath = 0x08;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x88);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0C000000, 0x3);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_C_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
break;
case ANTENNA_BC:
/*pHalData->ValidRxPath = 0x06;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x66);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_D_0x0[19:16] = 1, Standby mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
break;
case ANTENNA_CD:
/*pHalData->ValidRxPath = 0x0C;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xcc);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0xB);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, Rx mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x5);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0xA);
break;
case ANTENNA_BCD:
/*pHalData->ValidRxPath = 0x0e;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xee);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x6);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_A_0x0[19:16] = 1, Standby mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, Rx mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
break;
case ANTENNA_ABCD:
/*pHalData->ValidRxPath = 0x0f;*/
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x2);
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0xff);
phy_set_bb_reg(pAdapter, 0x1000, bMaskByte2, 0x3);
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0);
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, 0x0f000000, 0x1);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_A_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_C, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_C_0x0[19:16] = 3, RX mode*/
phy_set_rf_reg(pAdapter, RF_PATH_D, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_D_0x0[19:16] = 3, RX mode*/
/*/ CCA related PD_delay_th*/
phy_set_bb_reg(pAdapter, rAGC_table_Jaguar, 0x0F000000, 0x3);
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, 0x0000000F, 0x8);
break;
default:
break;
}
PHY_Set_SecCCATH_by_RXANT_8814A(pAdapter, ulAntennaRx);
mpt_ToggleIG_8814A(pAdapter);
}
#endif /* CONFIG_RTL8814A */
#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
void
mpt_SetSingleTone_8814A(
PADAPTER pAdapter,
BOOLEAN bSingleTone,
BOOLEAN bEnPMacTx)
{
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u8 StartPath = RF_PATH_A, EndPath = RF_PATH_A, path;
static u32 regIG0 = 0, regIG1 = 0, regIG2 = 0, regIG3 = 0;
if (bSingleTone) {
regIG0 = phy_query_bb_reg(pAdapter, rA_TxScale_Jaguar, bMaskDWord); /*/ 0xC1C[31:21]*/
regIG1 = phy_query_bb_reg(pAdapter, rB_TxScale_Jaguar, bMaskDWord); /*/ 0xE1C[31:21]*/
regIG2 = phy_query_bb_reg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord); /*/ 0x181C[31:21]*/
regIG3 = phy_query_bb_reg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord); /*/ 0x1A1C[31:21]*/
switch (pMptCtx->mpt_rf_path) {
case RF_PATH_A:
case RF_PATH_B:
case RF_PATH_C:
case RF_PATH_D:
StartPath = pMptCtx->mpt_rf_path;
EndPath = pMptCtx->mpt_rf_path;
break;
case RF_PATH_AB:
EndPath = RF_PATH_B;
break;
case RF_PATH_BC:
StartPath = RF_PATH_B;
EndPath = RF_PATH_C;
break;
case RF_PATH_ABC:
EndPath = RF_PATH_C;
break;
case RF_PATH_BCD:
StartPath = RF_PATH_B;
EndPath = RF_PATH_D;
break;
case RF_PATH_ABCD:
EndPath = RF_PATH_D;
break;
}
if (bEnPMacTx == FALSE) {
hal_mpt_SetContinuousTx(pAdapter, _TRUE);
issue_nulldata(pAdapter, NULL, 1, 3, 500);
}
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x1); /*/ Disable CCA*/
for (path = StartPath; path <= EndPath; path++) {
phy_set_rf_reg(pAdapter, path, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
phy_set_rf_reg(pAdapter, path, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
phy_set_rf_reg(pAdapter, path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
}
phy_set_bb_reg(pAdapter, rA_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xC1C[31:21]*/
phy_set_bb_reg(pAdapter, rB_TxScale_Jaguar, 0xFFE00000, 0); /*/ 0xE1C[31:21]*/
phy_set_bb_reg(pAdapter, rC_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x181C[31:21]*/
phy_set_bb_reg(pAdapter, rD_TxScale_Jaguar2, 0xFFE00000, 0); /*/ 0x1A1C[31:21]*/
} else {
switch (pMptCtx->mpt_rf_path) {
case RF_PATH_A:
case RF_PATH_B:
case RF_PATH_C:
case RF_PATH_D:
StartPath = pMptCtx->mpt_rf_path;
EndPath = pMptCtx->mpt_rf_path;
break;
case RF_PATH_AB:
EndPath = RF_PATH_B;
break;
case RF_PATH_BC:
StartPath = RF_PATH_B;
EndPath = RF_PATH_C;
break;
case RF_PATH_ABC:
EndPath = RF_PATH_C;
break;
case RF_PATH_BCD:
StartPath = RF_PATH_B;
EndPath = RF_PATH_D;
break;
case RF_PATH_ABCD:
EndPath = RF_PATH_D;
break;
}
for (path = StartPath; path <= EndPath; path++)
phy_set_rf_reg(pAdapter, path, lna_low_gain_3, BIT1, 0x0); /* RF LO disabled */
phy_set_bb_reg(pAdapter, rCCAonSec_Jaguar, BIT1, 0x0); /* Enable CCA*/
if (bEnPMacTx == FALSE)
hal_mpt_SetContinuousTx(pAdapter, _FALSE);
phy_set_bb_reg(pAdapter, rA_TxScale_Jaguar, bMaskDWord, regIG0); /* 0xC1C[31:21]*/
phy_set_bb_reg(pAdapter, rB_TxScale_Jaguar, bMaskDWord, regIG1); /* 0xE1C[31:21]*/
phy_set_bb_reg(pAdapter, rC_TxScale_Jaguar2, bMaskDWord, regIG2); /* 0x181C[31:21]*/
phy_set_bb_reg(pAdapter, rD_TxScale_Jaguar2, bMaskDWord, regIG3); /* 0x1A1C[31:21]*/
}
}
#endif
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
void mpt_SetRFPath_8812A(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &pAdapter->mppriv.mpt_ctx;
struct mp_priv *pmp = &pAdapter->mppriv;
u8 channel = pmp->channel;
u8 bandwidth = pmp->bandwidth;
u8 eLNA_2g = pHalData->ExternalLNA_2G;
u32 ulAntennaTx, ulAntennaRx;
ulAntennaTx = pHalData->antenna_tx_path;
ulAntennaRx = pHalData->AntennaRxPath;
switch (ulAntennaTx) {
case ANTENNA_A:
pMptCtx->mpt_rf_path = RF_PATH_A;
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x1111);
if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
break;
case ANTENNA_B:
pMptCtx->mpt_rf_path = RF_PATH_B;
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x2222);
if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x1);
break;
case ANTENNA_AB:
pMptCtx->mpt_rf_path = RF_PATH_AB;
phy_set_bb_reg(pAdapter, rTxPath_Jaguar, bMaskLWord, 0x3333);
if (pHalData->rfe_type == 3 && IS_HARDWARE_TYPE_8812(pAdapter))
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, bMask_AntselPathFollow_Jaguar, 0x0);
break;
default:
pMptCtx->mpt_rf_path = RF_PATH_AB;
RTW_INFO("Unknown Tx antenna.\n");
break;
}
switch (ulAntennaRx) {
u32 reg0xC50 = 0;
case ANTENNA_A:
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x11);
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x1); /*/ RF_B_0x0[19:16] = 1, Standby mode*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, BIT19 | BIT18 | BIT17 | BIT16, 0x3);
/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
reg0xC50 = phy_query_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0);
phy_set_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50 + 2);
phy_set_bb_reg(pAdapter, rA_IGI_Jaguar, bMaskByte0, reg0xC50);
/* set PWED_TH for BB Yn user guide R29 */
if (IS_HARDWARE_TYPE_8812(pAdapter)) {
if (channel <= 14) { /* 2.4G */
if (bandwidth == CHANNEL_WIDTH_20
&& eLNA_2g == 0) {
/* 0x830[3:1]=3'b010 */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x02);
} else
/* 0x830[3:1]=3'b100 */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
} else
/* 0x830[3:1]=3'b100 for 5G */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
}
break;
case ANTENNA_B:
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x22);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, 0xF0000, 0x1);/*/ RF_A_0x0[19:16] = 1, Standby mode */
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x1);
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, BIT19 | BIT18 | BIT17 | BIT16, 0x3);
/*/ <20121101, Kordan> To prevent gain table from not switched, asked by Ynlin.*/
reg0xC50 = phy_query_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0);
phy_set_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50 + 2);
phy_set_bb_reg(pAdapter, rB_IGI_Jaguar, bMaskByte0, reg0xC50);
/* set PWED_TH for BB Yn user guide R29 */
if (IS_HARDWARE_TYPE_8812(pAdapter)) {
if (channel <= 14) {
if (bandwidth == CHANNEL_WIDTH_20
&& eLNA_2g == 0) {
/* 0x830[3:1]=3'b010 */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x02);
} else
/* 0x830[3:1]=3'b100 */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
} else
/* 0x830[3:1]=3'b100 for 5G */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
}
break;
case ANTENNA_AB:
phy_set_bb_reg(pAdapter, rRxPath_Jaguar, bMaskByte0, 0x33);
phy_set_rf_reg(pAdapter, RF_PATH_B, RF_AC_Jaguar, 0xF0000, 0x3); /*/ RF_B_0x0[19:16] = 3, Rx mode*/
phy_set_bb_reg(pAdapter, rCCK_RX_Jaguar, bCCK_RX_Jaguar, 0x0);
/* set PWED_TH for BB Yn user guide R29 */
phy_set_bb_reg(pAdapter, rPwed_TH_Jaguar, BIT1 | BIT2 | BIT3, 0x04);
break;
default:
RTW_INFO("Unknown Rx antenna.\n");
break;
}
if (pHalData->rfe_type == 5 || pHalData->rfe_type == 1) {
if (ulAntennaTx == ANTENNA_A || ulAntennaTx == ANTENNA_AB) {
/* WiFi */
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(1) | BIT(0), 0x2);
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(9) | BIT(8), 0x3);
} else {
/* BT */
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(1) | BIT(0), 0x1);
phy_set_bb_reg(pAdapter, r_ANTSEL_SW_Jaguar, BIT(9) | BIT(8), 0x3);
}
}
}
#endif
#ifdef CONFIG_RTL8723B
void mpt_SetRFPath_8723B(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u32 ulAntennaTx, ulAntennaRx;
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
struct dm_rf_calibration_struct *pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
ulAntennaTx = pHalData->antenna_tx_path;
ulAntennaRx = pHalData->AntennaRxPath;
if (pHalData->rf_chip >= RF_CHIP_MAX) {
RTW_INFO("This RF chip ID is not supported\n");
return;
}
switch (pAdapter->mppriv.antenna_tx) {
u8 p = 0, i = 0;
case ANTENNA_A: { /*/ Actually path S1 (Wi-Fi)*/
pMptCtx->mpt_rf_path = RF_PATH_A;
phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
for (i = 0; i < 3; ++i) {
u32 offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
u32 data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][1];
if (offset != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
for (i = 0; i < 2; ++i) {
u32 offset = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][0];
u32 data = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][1];
if (offset != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
}
break;
case ANTENNA_B: { /*/ Actually path S0 (BT)*/
u32 offset;
u32 data;
pMptCtx->mpt_rf_path = RF_PATH_B;
phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /*/ AGC Table Sel.*/
for (i = 0; i < 3; ++i) {
/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC to S1 instead of S0.*/
offset = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_A][i][0];
data = pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_B][i][1];
if (pRFCalibrateInfo->tx_iqc_8723b[RF_PATH_B][i][0] != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
/*/ <20130603, Kordan> Because BB suppors only 1T1R, we restore IQC to S1 instead of S0.*/
for (i = 0; i < 2; ++i) {
offset = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_A][i][0];
data = pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_B][i][1];
if (pRFCalibrateInfo->rx_iqc_8723b[RF_PATH_B][i][0] != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
}
break;
default:
pMptCtx->mpt_rf_path = RF_PATH_AB;
break;
}
}
#endif
#ifdef CONFIG_RTL8703B
void mpt_SetRFPath_8703B(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u32 ulAntennaTx, ulAntennaRx;
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
struct dm_rf_calibration_struct *pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
ulAntennaTx = pHalData->antenna_tx_path;
ulAntennaRx = pHalData->AntennaRxPath;
if (pHalData->rf_chip >= RF_CHIP_MAX) {
RTW_INFO("This RF chip ID is not supported\n");
return;
}
switch (pAdapter->mppriv.antenna_tx) {
u8 p = 0, i = 0;
case ANTENNA_A: { /* Actually path S1 (Wi-Fi) */
pMptCtx->mpt_rf_path = RF_PATH_A;
phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x0);
phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x0); /* AGC Table Sel*/
for (i = 0; i < 3; ++i) {
u32 offset = pRFCalibrateInfo->tx_iqc_8703b[i][0];
u32 data = pRFCalibrateInfo->tx_iqc_8703b[i][1];
if (offset != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S1 TxIQC(offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
for (i = 0; i < 2; ++i) {
u32 offset = pRFCalibrateInfo->rx_iqc_8703b[i][0];
u32 data = pRFCalibrateInfo->rx_iqc_8703b[i][1];
if (offset != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S1 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
}
break;
case ANTENNA_B: { /* Actually path S0 (BT)*/
pMptCtx->mpt_rf_path = RF_PATH_B;
phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9 | BIT8 | BIT7, 0x5);
phy_set_bb_reg(pAdapter, 0xB2C, BIT31, 0x1); /* AGC Table Sel */
for (i = 0; i < 3; ++i) {
u32 offset = pRFCalibrateInfo->tx_iqc_8703b[i][0];
u32 data = pRFCalibrateInfo->tx_iqc_8703b[i][1];
if (pRFCalibrateInfo->tx_iqc_8703b[i][0] != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S0 TxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
for (i = 0; i < 2; ++i) {
u32 offset = pRFCalibrateInfo->rx_iqc_8703b[i][0];
u32 data = pRFCalibrateInfo->rx_iqc_8703b[i][1];
if (pRFCalibrateInfo->rx_iqc_8703b[i][0] != 0) {
phy_set_bb_reg(pAdapter, offset, bMaskDWord, data);
RTW_INFO("Switch to S0 RxIQC (offset, data) = (0x%X, 0x%X)\n", offset, data);
}
}
}
break;
default:
pMptCtx->mpt_rf_path = RF_PATH_AB;
break;
}
}
#endif
#ifdef CONFIG_RTL8723D
void mpt_SetRFPath_8723D(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u8 p = 0, i = 0;
u32 ulAntennaTx, ulAntennaRx, offset = 0, data = 0, val32 = 0;
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
struct dm_rf_calibration_struct *pRFCalibrateInfo = &(pDM_Odm->rf_calibrate_info);
ulAntennaTx = pHalData->antenna_tx_path;
ulAntennaRx = pHalData->AntennaRxPath;
if (pHalData->rf_chip >= RF_CHIP_MAX) {
RTW_INFO("This RF chip ID is not supported\n");
return;
}
switch (pAdapter->mppriv.antenna_tx) {
/* Actually path S1 (Wi-Fi) */
case ANTENNA_A: {
pMptCtx->mpt_rf_path = RF_PATH_A;
phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7|BIT6, 0);
}
break;
/* Actually path S0 (BT) */
case ANTENNA_B: {
pMptCtx->mpt_rf_path = RF_PATH_B;
phy_set_bb_reg(pAdapter, rS0S1_PathSwitch, BIT9|BIT8|BIT7|BIT6, 0xA);
}
break;
default:
pMptCtx->mpt_rf_path = RF_PATH_AB;
break;
}
}
#endif
void mpt_SetRFPath_819X(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u32 ulAntennaTx, ulAntennaRx;
R_ANTENNA_SELECT_OFDM *p_ofdm_tx; /* OFDM Tx register */
R_ANTENNA_SELECT_CCK *p_cck_txrx;
u8 r_rx_antenna_ofdm = 0, r_ant_select_cck_val = 0;
u8 chgTx = 0, chgRx = 0;
u32 r_ant_sel_cck_val = 0, r_ant_select_ofdm_val = 0, r_ofdm_tx_en_val = 0;
ulAntennaTx = pHalData->antenna_tx_path;
ulAntennaRx = pHalData->AntennaRxPath;
p_ofdm_tx = (R_ANTENNA_SELECT_OFDM *)&r_ant_select_ofdm_val;
p_cck_txrx = (R_ANTENNA_SELECT_CCK *)&r_ant_select_cck_val;
p_ofdm_tx->r_ant_ht1 = 0x1;
p_ofdm_tx->r_ant_ht2 = 0x2;/*Second TX RF path is A*/
p_ofdm_tx->r_ant_non_ht = 0x3;/*/ 0x1+0x2=0x3 */
switch (ulAntennaTx) {
case ANTENNA_A:
p_ofdm_tx->r_tx_antenna = 0x1;
r_ofdm_tx_en_val = 0x1;
p_ofdm_tx->r_ant_l = 0x1;
p_ofdm_tx->r_ant_ht_s1 = 0x1;
p_ofdm_tx->r_ant_non_ht_s1 = 0x1;
p_cck_txrx->r_ccktx_enable = 0x8;
chgTx = 1;
/*/ From SD3 Willis suggestion !!! Set RF A=TX and B as standby*/
/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
{
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 1);
r_ofdm_tx_en_val = 0x3;
/*/ Power save*/
/*/cosa r_ant_select_ofdm_val = 0x11111111;*/
/*/ We need to close RFB by SW control*/
if (pHalData->rf_type == RF_2T2R) {
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 1);
phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 0);
}
}
pMptCtx->mpt_rf_path = RF_PATH_A;
break;
case ANTENNA_B:
p_ofdm_tx->r_tx_antenna = 0x2;
r_ofdm_tx_en_val = 0x2;
p_ofdm_tx->r_ant_l = 0x2;
p_ofdm_tx->r_ant_ht_s1 = 0x2;
p_ofdm_tx->r_ant_non_ht_s1 = 0x2;
p_cck_txrx->r_ccktx_enable = 0x4;
chgTx = 1;
/*/ From SD3 Willis suggestion !!! Set RF A as standby*/
/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
{
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 1);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
/*/ 2008/10/31 MH From SD3 Willi's suggestion. We must read RF 1T table.*/
/*/ 2009/01/08 MH From Sd3 Willis. We need to close RFA by SW control*/
if (pHalData->rf_type == RF_2T2R || pHalData->rf_type == RF_1T2R) {
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 1);
phy_set_bb_reg(pAdapter, rFPGA0_XA_RFInterfaceOE, BIT10, 0);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
/*/phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 0);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
}
}
pMptCtx->mpt_rf_path = RF_PATH_B;
break;
case ANTENNA_AB:/*/ For 8192S*/
p_ofdm_tx->r_tx_antenna = 0x3;
r_ofdm_tx_en_val = 0x3;
p_ofdm_tx->r_ant_l = 0x3;
p_ofdm_tx->r_ant_ht_s1 = 0x3;
p_ofdm_tx->r_ant_non_ht_s1 = 0x3;
p_cck_txrx->r_ccktx_enable = 0xC;
chgTx = 1;
/*/ From SD3Willis suggestion !!! Set RF B as standby*/
/*/if (IS_HARDWARE_TYPE_8192S(pAdapter))*/
{
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, 0xe, 2);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, 0xe, 2);
/* Disable Power save*/
/*cosa r_ant_select_ofdm_val = 0x3321333;*/
/* 2009/01/08 MH From Sd3 Willis. We need to enable RFA/B by SW control*/
if (pHalData->rf_type == RF_2T2R) {
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT10, 0);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT26, 0);
/*/phy_set_bb_reg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT10, 0);*/
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT1, 1);
phy_set_bb_reg(pAdapter, rFPGA0_XAB_RFParameter, BIT17, 1);
}
}
pMptCtx->mpt_rf_path = RF_PATH_AB;
break;
default:
break;
}
#if 0
/* r_rx_antenna_ofdm, bit0=A, bit1=B, bit2=C, bit3=D */
/* r_cckrx_enable : CCK default, 0=A, 1=B, 2=C, 3=D */
/* r_cckrx_enable_2 : CCK option, 0=A, 1=B, 2=C, 3=D */
#endif
switch (ulAntennaRx) {
case ANTENNA_A:
r_rx_antenna_ofdm = 0x1; /* A*/
p_cck_txrx->r_cckrx_enable = 0x0; /* default: A*/
p_cck_txrx->r_cckrx_enable_2 = 0x0; /* option: A*/
chgRx = 1;
break;
case ANTENNA_B:
r_rx_antenna_ofdm = 0x2; /*/ B*/
p_cck_txrx->r_cckrx_enable = 0x1; /*/ default: B*/
p_cck_txrx->r_cckrx_enable_2 = 0x1; /*/ option: B*/
chgRx = 1;
break;
case ANTENNA_AB:/*/ For 8192S and 8192E/U...*/
r_rx_antenna_ofdm = 0x3;/*/ AB*/
p_cck_txrx->r_cckrx_enable = 0x0;/*/ default:A*/
p_cck_txrx->r_cckrx_enable_2 = 0x1;/*/ option:B*/
chgRx = 1;
break;
default:
break;
}
if (chgTx && chgRx) {
switch (pHalData->rf_chip) {
case RF_8225:
case RF_8256:
case RF_6052:
/*/r_ant_sel_cck_val = r_ant_select_cck_val;*/
phy_set_bb_reg(pAdapter, rFPGA1_TxInfo, 0x7fffffff, r_ant_select_ofdm_val); /*/OFDM Tx*/
phy_set_bb_reg(pAdapter, rFPGA0_TxInfo, 0x0000000f, r_ofdm_tx_en_val); /*/OFDM Tx*/
phy_set_bb_reg(pAdapter, rOFDM0_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm); /*/OFDM Rx*/
phy_set_bb_reg(pAdapter, rOFDM1_TRxPathEnable, 0x0000000f, r_rx_antenna_ofdm); /*/OFDM Rx*/
if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
phy_set_bb_reg(pAdapter, rOFDM0_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm); /*/OFDM Rx*/
phy_set_bb_reg(pAdapter, rOFDM1_TRxPathEnable, 0x000000F0, r_rx_antenna_ofdm); /*/OFDM Rx*/
}
phy_set_bb_reg(pAdapter, rCCK0_AFESetting, bMaskByte3, r_ant_select_cck_val);/*/r_ant_sel_cck_val); /CCK TxRx*/
break;
default:
RTW_INFO("Unsupported RFChipID for switching antenna.\n");
break;
}
}
} /* MPT_ProSetRFPath */
#ifdef CONFIG_RTL8192F
void mpt_set_rfpath_8192f(PADAPTER pAdapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u16 ForcedDataRate = mpt_to_mgnt_rate(pMptCtx->mpt_rate_index);
u8 NssforRate, odmNssforRate;
u32 ulAntennaTx, ulAntennaRx;
u8 RxAntToPhyDm;
u8 TxAntToPhyDm;
ulAntennaTx = pHalData->antenna_tx_path;
ulAntennaRx = pHalData->AntennaRxPath;
NssforRate = MgntQuery_NssTxRate(ForcedDataRate);
if (pHalData->rf_chip >= RF_TYPE_MAX)
RTW_INFO("This RF chip ID is not supported\n");
switch (ulAntennaTx) {
case ANTENNA_A:
pMptCtx->mpt_rf_path = RF_PATH_A;
TxAntToPhyDm = BB_PATH_A;
break;
case ANTENNA_B:
pMptCtx->mpt_rf_path = RF_PATH_B;
TxAntToPhyDm = BB_PATH_B;
break;
case ANTENNA_AB:
pMptCtx->mpt_rf_path = RF_PATH_AB;
TxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
break;
default:
pMptCtx->mpt_rf_path = RF_PATH_AB;
TxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
break;
}
switch (ulAntennaRx) {
case ANTENNA_A:
RxAntToPhyDm = BB_PATH_A;
break;
case ANTENNA_B:
RxAntToPhyDm = BB_PATH_B;
break;
case ANTENNA_AB:
RxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
break;
default:
RxAntToPhyDm = (BB_PATH_A|BB_PATH_B);
break;
}
config_phydm_trx_mode_8192f(GET_PDM_ODM(pAdapter), TxAntToPhyDm, RxAntToPhyDm, FALSE);
}
#endif
void hal_mpt_SetAntenna(PADAPTER pAdapter)
{
RTW_INFO("Do %s\n", __func__);
#ifdef CONFIG_RTL8822C
if (IS_HARDWARE_TYPE_8822C(pAdapter)) {
rtl8822c_mp_config_rfpath(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8814A
if (IS_HARDWARE_TYPE_8814A(pAdapter)) {
mpt_SetRFPath_8814A(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8822B
if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
rtl8822b_mp_config_rfpath(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8821C
if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
rtl8821c_mp_config_rfpath(pAdapter);
return;
}
#endif
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A)
if (IS_HARDWARE_TYPE_JAGUAR(pAdapter)) {
mpt_SetRFPath_8812A(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8723B
if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
mpt_SetRFPath_8723B(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8703B
if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
mpt_SetRFPath_8703B(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8723D
if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
mpt_SetRFPath_8723D(pAdapter);
return;
}
#endif
#ifdef CONFIG_RTL8192F
if (IS_HARDWARE_TYPE_8192F(pAdapter)) {
mpt_set_rfpath_8192f(pAdapter);
return;
}
#endif
/* else if (IS_HARDWARE_TYPE_8821B(pAdapter))
mpt_SetRFPath_8821B(pAdapter);
Prepare for 8822B
else if (IS_HARDWARE_TYPE_8822B(Context))
mpt_SetRFPath_8822B(Context);
*/
mpt_SetRFPath_819X(pAdapter);
RTW_INFO("mpt_SetRFPath_819X Do %s\n", __func__);
}
s32 hal_mpt_SetThermalMeter(PADAPTER pAdapter, u8 target_ther)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
if (!netif_running(pAdapter->pnetdev)) {
return _FAIL;
}
if (check_fwstate(&pAdapter->mlmepriv, WIFI_MP_STATE) == _FALSE) {
return _FAIL;
}
target_ther &= 0xff;
if (target_ther < 0x07)
target_ther = 0x07;
else if (target_ther > 0x1d)
target_ther = 0x1d;
pHalData->eeprom_thermal_meter = target_ther;
return _SUCCESS;
}
void hal_mpt_TriggerRFThermalMeter(PADAPTER pAdapter)
{
if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT19, 0x1);
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT19, 0x0);
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT19, 0x1);
} else
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x42, BIT17 | BIT16, 0x03);
}
u8 hal_mpt_ReadRFThermalMeter(PADAPTER pAdapter, u8 rf_path)
{
struct dm_struct *p_dm_odm = adapter_to_phydm(pAdapter);
u32 ThermalValue = 0;
s32 thermal_value_temp = 0;
s8 thermal_offset = 0;
u32 thermal_reg_mask = 0;
if (IS_8822C_SERIES(GET_HAL_DATA(pAdapter)->version_id))
thermal_reg_mask = 0x007e; /*0x42: RF Reg[6:1], 35332(themal K & bias k & power trim) & 35325(tssi )*/
else
thermal_reg_mask = 0xfc00; /*0x42: RF Reg[15:10]*/
ThermalValue = (u8)phy_query_rf_reg(pAdapter, rf_path, 0x42, thermal_reg_mask);
thermal_offset = phydm_get_thermal_offset(p_dm_odm);
thermal_value_temp = ThermalValue + thermal_offset;
if (thermal_value_temp > 63)
ThermalValue = 63;
else if (thermal_value_temp < 0)
ThermalValue = 0;
else
ThermalValue = thermal_value_temp;
return (u8)ThermalValue;
}
void hal_mpt_GetThermalMeter(PADAPTER pAdapter, u8 rfpath, u8 *value)
{
#if 0
fw_cmd(pAdapter, IOCMD_GET_THERMAL_METER);
rtw_msleep_os(1000);
fw_cmd_data(pAdapter, value, 1);
*value &= 0xFF;
#else
hal_mpt_TriggerRFThermalMeter(pAdapter);
rtw_msleep_os(1000);
*value = hal_mpt_ReadRFThermalMeter(pAdapter, rfpath);
#endif
}
void hal_mpt_SetSingleCarrierTx(PADAPTER pAdapter, u8 bStart)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
pAdapter->mppriv.mpt_ctx.bSingleCarrier = bStart;
if (bStart) {/*/ Start Single Carrier.*/
/*/ Start Single Carrier.*/
/*/ 1. if OFDM block on?*/
if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1); /*set OFDM block on*/
/*/ 2. set CCK test mode off, set to CCK normal mode*/
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0);
/*/ 3. turn on scramble setting*/
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 1);
/*/ 4. Turn On Continue Tx and turn off the other test modes.*/
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_SingleCarrier);
else
#endif /* CONFIG_RTL8812A || CONFIG_RTL8821A || CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleCarrier);
} else {
/*/ Stop Single Carrier.*/
/*/ Stop Single Carrier.*/
/*/ Turn off all test modes.*/
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
else
#endif /* CONFIG_RTL8812A || CONFIG_RTL8821A || CONFIG_RTL8814A || CONFIG_RTL8822B || CONFIG_RTL8821C */
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
rtw_msleep_os(10);
/*/BB Reset*/
phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
}
}
void hal_mpt_SetSingleToneTx(PADAPTER pAdapter, u8 bStart)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
struct dm_struct *pDM_Odm = &pHalData->odmpriv;
u32 ulAntennaTx = pHalData->antenna_tx_path;
static u32 regRF = 0, regBB0 = 0, regBB1 = 0, regBB2 = 0, regBB3 = 0;
u8 rfPath;
if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
#ifdef PHYDM_MP_SUPPORT
phydm_mp_set_single_tone(pDM_Odm, bStart, pMptCtx->mpt_rf_path);
#endif
return;
}
switch (ulAntennaTx) {
case ANTENNA_B:
rfPath = RF_PATH_B;
break;
case ANTENNA_C:
rfPath = RF_PATH_C;
break;
case ANTENNA_D:
rfPath = RF_PATH_D;
break;
case ANTENNA_A:
default:
rfPath = RF_PATH_A;
break;
}
pAdapter->mppriv.mpt_ctx.is_single_tone = bStart;
if (bStart) {
/*/ Start Single Tone.*/
/*/ <20120326, Kordan> To amplify the power of tone for Xtal calibration. (asked by Edlu)*/
if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
regRF = phy_query_rf_reg(pAdapter, rfPath, lna_low_gain_3, bRFRegOffsetMask);
phy_set_rf_reg(pAdapter, RF_PATH_A, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x0);
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x0);
} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) { /*/ USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
/*/Set MAC REG 88C: Prevent SingleTone Fail*/
phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0xF);
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO disabled*/
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
} else if (IS_HARDWARE_TYPE_8192F(pAdapter)) { /* USB need to do RF LO disable first, PCIE isn't required to follow this order.*/
#ifdef CONFIG_RTL8192F
phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT23, 0x1);
phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT26, 0x1);
phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT7, 0x1);
phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT1, 0x1);
phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT0, 0x1);
phy_set_mac_reg(pAdapter, REG_AFE_CTRL_4_8192F, BIT16, 0x1);
phy_set_bb_reg(pAdapter, 0x88C, 0xF00000, 0xF);
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x57, BIT1, 0x1); /* RF LO disabled*/
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2); /* Tx mode*/
#endif
} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x56, 0xF, 0x1); /*/ RF LO enabled*/
} else {
/*/ S0/S1 both use PATH A to configure*/
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /*/ Tx mode*/
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x76, 0xF, 0x1); /*/ RF LO enabled*/
}
} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x2); /* Tx mode */
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x1); /* RF LO enabled */
}
} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
/*Set BB REG 88C: Prevent SingleTone Fail*/
phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xF);
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1);
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x2);
} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A) {
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, BIT0, 0x1);
} else {/* S0/S1 both use PATH A to configure */
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x0);
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x1);
}
} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
u8 p = RF_PATH_A;
regRF = phy_query_rf_reg(pAdapter, RF_PATH_A, RF_AC_Jaguar, bRFRegOffsetMask);
regBB0 = phy_query_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord);
regBB1 = phy_query_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord);
regBB2 = phy_query_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord);
regBB3 = phy_query_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord);
phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x0); /*/ Disable CCK and OFDM*/
if (pMptCtx->mpt_rf_path == RF_PATH_AB) {
for (p = RF_PATH_A; p <= RF_PATH_B; ++p) {
phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
}
} else {
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0xF0000, 0x2); /*/ Tx mode: RF0x00[19:16]=4'b0010 */
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC_Jaguar, 0x1F, 0x0); /*/ Lowest RF gain index: RF_0x0[4:0] = 0*/
#ifdef CONFIG_RTL8821C
if (IS_HARDWARE_TYPE_8821C(pAdapter) && pDM_Odm->current_rf_set_8821c == SWITCH_TO_BTG)
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x75, BIT16, 0x1); /* RF LO (for BTG) enabled */
else
#endif
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x1); /*/ RF LO enabled*/
}
if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777); /* 0xCB0=0x77777777*/
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, 0x77777777); /* 0xEB0=0x77777777*/
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777); /* 0xCB4[15:0] = 0x7777*/
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskLWord, 0x7777); /* 0xEB4[15:0] = 0x7777*/
phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xFFF, 0xb); /* 0xCBC[23:16] = 0x12*/
phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xFFF, 0x830); /* 0xEBC[23:16] = 0x12*/
} else if (IS_HARDWARE_TYPE_8821C(pAdapter)) {
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xF0F0, 0x707); /* 0xCB0[[15:12, 7:4] = 0x707*/
if (pHalData->external_pa_5g)
{
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
}
else if (pHalData->ExternalPA_2G)
{
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xA00000, 0x1); /* 0xCB4[23, 21] = 0x1*/
}
} else {
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007); /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, 0xFF00F0, 0x77007); /*/ 0xCB0[[23:16, 7:4] = 0x77007*/
if (pHalData->external_pa_5g) {
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xCB4[23:16] = 0x12*/
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x12); /*/ 0xEB4[23:16] = 0x12*/
} else if (pHalData->ExternalPA_2G) {
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xCB4[23:16] = 0x11*/
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, 0xFF00000, 0x11); /*/ 0xEB4[23:16] = 0x11*/
}
}
#endif
}
#if defined(CONFIG_RTL8814A)
else if (IS_HARDWARE_TYPE_8814A(pAdapter))
mpt_SetSingleTone_8814A(pAdapter, TRUE, FALSE);
#endif
else /*/ Turn On SingleTone and turn off the other test modes.*/
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_SingleTone);
write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
} else {/*/ Stop Single Ton e.*/
if (IS_HARDWARE_TYPE_8188E(pAdapter)) {
phy_set_rf_reg(pAdapter, RF_PATH_A, lna_low_gain_3, bRFRegOffsetMask, regRF);
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 0x1);
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
} else if (IS_HARDWARE_TYPE_8192E(pAdapter)) {
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3);/*/ Tx mode*/
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0);/*/ RF LO disabled */
/*/ RESTORE MAC REG 88C: Enable RF Functions*/
phy_set_mac_reg(pAdapter, 0x88C, 0xF00000, 0x0);
} else if (IS_HARDWARE_TYPE_8192F(pAdapter)){
#ifdef CONFIG_RTL8192F
phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT23, 0x0);
phy_set_mac_reg(pAdapter, REG_LEDCFG0_8192F, BIT26, 0x0);
phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT7, 0x0);
phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT1, 0x0);
phy_set_mac_reg(pAdapter, REG_PAD_CTRL1_8192F, BIT0, 0x0);
phy_set_mac_reg(pAdapter, REG_AFE_CTRL_4_8192F, BIT16, 0x0);
phy_set_bb_reg(pAdapter, 0x88C, 0xF00000, 0x0);
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, 0x57, BIT1, 0x0); /* RF LO disabled*/
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /* Rx mode*/
#endif
} else if (IS_HARDWARE_TYPE_8723B(pAdapter)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x56, 0xF, 0x0); /*/ RF LO disabled*/
} else {
/*/ S0/S1 both use PATH A to configure*/
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /*/ Rx mode*/
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x76, 0xF, 0x0); /*/ RF LO disabled*/
}
} else if (IS_HARDWARE_TYPE_8703B(pAdapter)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A) {
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, 0xF0000, 0x3); /* Rx mode */
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, 0xF000, 0x0); /* RF LO disabled */
}
} else if (IS_HARDWARE_TYPE_8188F(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, RF_AC, 0xF0000, 0x3); /*Tx mode*/
phy_set_rf_reg(pAdapter, pMptCtx->mpt_rf_path, lna_low_gain_3, BIT1, 0x0); /*RF LO disabled*/
/*Set BB REG 88C: Prevent SingleTone Fail*/
phy_set_bb_reg(pAdapter, rFPGA0_AnalogParameter4, 0xF00000, 0xc);
} else if (IS_HARDWARE_TYPE_8723D(pAdapter)) {
if (pMptCtx->mpt_rf_path == RF_PATH_A) {
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x3);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x53, BIT0, 0x0);
} else { /* S0/S1 both use PATH A to configure */
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn|bOFDMEn, 0x3);
phy_set_rf_reg(pAdapter, RF_PATH_A, RF_AC, BIT16, 0x1);
phy_set_rf_reg(pAdapter, RF_PATH_A, 0x63, BIT0, 0x0);
}
} else if (IS_HARDWARE_TYPE_JAGUAR(pAdapter) || IS_HARDWARE_TYPE_8822B(pAdapter) || IS_HARDWARE_TYPE_8821C(pAdapter)) {
#if defined(CONFIG_RTL8812A) || defined(CONFIG_RTL8821A) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C)
u8 p = RF_PATH_A;
phy_set_bb_reg(pAdapter, rOFDMCCKEN_Jaguar, BIT29 | BIT28, 0x3); /*/ Disable CCK and OFDM*/
if (pMptCtx->mpt_rf_path == RF_PATH_AB) {
for (p = RF_PATH_A; p <= RF_PATH_B; ++p) {
phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
}
} else {
p = pMptCtx->mpt_rf_path;
phy_set_rf_reg(pAdapter, p, RF_AC_Jaguar, bRFRegOffsetMask, regRF);
if (IS_HARDWARE_TYPE_8821C(pAdapter))
phy_set_rf_reg(pAdapter, p, 0x75, BIT16, 0x0); /* RF LO (for BTG) disabled */
phy_set_rf_reg(pAdapter, p, lna_low_gain_3, BIT1, 0x0); /*/ RF LO disabled*/
}
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar, bMaskDWord, regBB0);
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar, bMaskDWord, regBB1);
phy_set_bb_reg(pAdapter, rA_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB2);
phy_set_bb_reg(pAdapter, rB_RFE_Pinmux_Jaguar + 4, bMaskDWord, regBB3);
if (IS_HARDWARE_TYPE_8822B(pAdapter)) {
RTW_INFO("Restore RFE control Pin cbc\n");
phy_set_bb_reg(pAdapter, rA_RFE_Inverse_Jaguar, 0xfff, 0x0);
phy_set_bb_reg(pAdapter, rB_RFE_Inverse_Jaguar, 0xfff, 0x0);
}
#endif
}
#if defined(CONFIG_RTL8814A)
else if (IS_HARDWARE_TYPE_8814A(pAdapter))
mpt_SetSingleTone_8814A(pAdapter, FALSE, FALSE);
else/*/ Turn off all test modes.*/
phy_set_bb_reg(pAdapter, rSingleTone_ContTx_Jaguar, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
#endif
write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
}
}
void hal_mpt_SetCarrierSuppressionTx(PADAPTER pAdapter, u8 bStart)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
struct dm_struct *pdm_odm = &pHalData->odmpriv;
u8 Rate;
pAdapter->mppriv.mpt_ctx.is_carrier_suppression = bStart;
if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
#ifdef PHYDM_MP_SUPPORT
phydm_mp_set_carrier_supp(pdm_odm, bStart, pAdapter->mppriv.rateidx);
#endif
return;
}
Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
if (bStart) {/* Start Carrier Suppression.*/
if (Rate <= MPT_RATE_11M) {
/*/ 1. if CCK block on?*/
if (!read_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn))
write_bbreg(pAdapter, rFPGA0_RFMOD, bCCKEn, bEnable);/*set CCK block on*/
/*/Turn Off All Test Mode*/
if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF); /* rSingleTone_ContTx_Jaguar*/
else
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x2); /*/transmit mode*/
write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x0); /*/turn off scramble setting*/
/*/Set CCK Tx Test Rate*/
write_bbreg(pAdapter, rCCK0_System, bCCKTxRate, 0x0); /*/Set FTxRate to 1Mbps*/
}
/*Set for dynamic set Power index*/
write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
} else {/* Stop Carrier Suppression.*/
if (Rate <= MPT_RATE_11M) {
write_bbreg(pAdapter, rCCK0_System, bCCKBBMode, 0x0); /*normal mode*/
write_bbreg(pAdapter, rCCK0_System, bCCKScramble, 0x1); /*turn on scramble setting*/
/*BB Reset*/
write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
write_bbreg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
}
/*Stop for dynamic set Power index*/
write_bbreg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
write_bbreg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
}
RTW_INFO("\n MPT_ProSetCarrierSupp() is finished.\n");
}
u32 hal_mpt_query_phytxok(PADAPTER pAdapter)
{
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
RT_PMAC_TX_INFO PMacTxInfo = pMptCtx->PMacTxInfo;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
u16 count = 0;
#ifdef PHYDM_MP_SUPPORT
struct dm_struct *dm = (struct dm_struct *)&pHalData->odmpriv;
struct phydm_mp *mp = &dm->dm_mp_table;
if (IS_HARDWARE_TYPE_JAGUAR3(pAdapter)) {
phydm_mp_get_tx_ok(&pHalData->odmpriv, pAdapter->mppriv.rateidx);
count = mp->tx_phy_ok_cnt;
} else
#endif
{
if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
count = phy_query_bb_reg(pAdapter, 0xF50, bMaskLWord); /* [15:0]*/
else
count = phy_query_bb_reg(pAdapter, 0xF50, bMaskHWord); /* [31:16]*/
}
if (count > 50000) {
rtw_reset_phy_trx_ok_counters(pAdapter);
pAdapter->mppriv.tx.sended += count;
count = 0;
}
return pAdapter->mppriv.tx.sended + count;
}
static void mpt_StopCckContTx(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u8 u1bReg;
pMptCtx->bCckContTx = FALSE;
pMptCtx->bOfdmContTx = FALSE;
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0x0); /*normal mode*/
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 0x1); /*turn on scramble setting*/
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x0); /* 0xa15[1:0] = 2b00*/
phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0); /* 0xc08[16] = 0*/
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 0);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, BIT14, 0);
phy_set_bb_reg(pAdapter, 0x0B34, BIT14, 0);
}
/*BB Reset*/
phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
}
if (IS_HARDWARE_TYPE_8188E(pAdapter) || IS_HARDWARE_TYPE_8723B(pAdapter) ||
IS_HARDWARE_TYPE_8703B(pAdapter) || IS_HARDWARE_TYPE_8188F(pAdapter) ||
IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8192F(pAdapter) ||
IS_HARDWARE_TYPE_8821C(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
phy_set_bb_reg(pAdapter, 0xA70, BIT(14), bDisable);/* patch Count CCK adjust Rate*/
}
} /* mpt_StopCckContTx */
static void mpt_StopOfdmContTx(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u8 u1bReg;
u32 data;
pMptCtx->bCckContTx = FALSE;
pMptCtx->bOfdmContTx = FALSE;
if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
else
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
rtw_mdelay_os(10);
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)){
phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x0); /* 0xa15[1:0] = 0*/
phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x0); /* 0xc08[16] = 0*/
}
/*BB Reset*/
phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x0);
phy_set_bb_reg(pAdapter, rPMAC_Reset, bBBResetB, 0x1);
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000100);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000100);
}
} /* mpt_StopOfdmContTx */
static void mpt_StartCckContTx(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
u32 cckrate;
/* 1. if CCK block on */
if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn))
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bCCKEn, 1);/*set CCK block on*/
/*Turn Off All Test Mode*/
if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ALL_OFF);
else
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ALL_OFF);
cckrate = pAdapter->mppriv.rateidx;
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKTxRate, cckrate);
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0x2); /*transmit mode*/
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 0x1); /*turn on scramble setting*/
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x3); /* 0xa15[1:0] = 11 force cck rxiq = 0*/
phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1); /* 0xc08[16] = 1 force ofdm rxiq = ofdm txiq*/
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter2, BIT14, 1);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter2, BIT14, 1);
phy_set_bb_reg(pAdapter, 0x0B34, BIT14, 1);
}
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
}
if (IS_HARDWARE_TYPE_8188E(pAdapter) || IS_HARDWARE_TYPE_8723B(pAdapter) ||
IS_HARDWARE_TYPE_8703B(pAdapter) || IS_HARDWARE_TYPE_8188F(pAdapter) ||
IS_HARDWARE_TYPE_8723D(pAdapter) || IS_HARDWARE_TYPE_8192F(pAdapter) ||
IS_HARDWARE_TYPE_8821C(pAdapter) || IS_HARDWARE_TYPE_8188GTV(pAdapter)) {
if (pAdapter->mppriv.rateidx == MPT_RATE_1M) /* patch Count CCK adjust Rate*/
phy_set_bb_reg(pAdapter, 0xA70, BIT(14), bDisable);
else
phy_set_bb_reg(pAdapter, 0xA70, BIT(14), bEnable);
}
pMptCtx->bCckContTx = TRUE;
pMptCtx->bOfdmContTx = FALSE;
} /* mpt_StartCckContTx */
static void mpt_StartOfdmContTx(
PADAPTER pAdapter
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(pAdapter);
PMPT_CONTEXT pMptCtx = &(pAdapter->mppriv.mpt_ctx);
/* 1. if OFDM block on?*/
if (!phy_query_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn))
phy_set_bb_reg(pAdapter, rFPGA0_RFMOD, bOFDMEn, 1);/*set OFDM block on*/
/* 2. set CCK test mode off, set to CCK normal mode*/
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKBBMode, 0);
/* 3. turn on scramble setting*/
phy_set_bb_reg(pAdapter, rCCK0_System, bCCKScramble, 1);
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, 0xa14, 0x300, 0x3); /* 0xa15[1:0] = 2b'11*/
phy_set_bb_reg(pAdapter, rOFDM0_TRMuxPar, 0x10000, 0x1); /* 0xc08[16] = 1*/
}
/* 4. Turn On Continue Tx and turn off the other test modes.*/
if (IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter))
phy_set_bb_reg(pAdapter, 0x914, BIT18 | BIT17 | BIT16, OFDM_ContinuousTx);
else
phy_set_bb_reg(pAdapter, rOFDM1_LSTF, BIT30 | BIT29 | BIT28, OFDM_ContinuousTx);
if (!IS_HARDWARE_TYPE_JAGUAR_ALL(pAdapter)) {
phy_set_bb_reg(pAdapter, rFPGA0_XA_HSSIParameter1, bMaskDWord, 0x01000500);
phy_set_bb_reg(pAdapter, rFPGA0_XB_HSSIParameter1, bMaskDWord, 0x01000500);
}
pMptCtx->bCckContTx = FALSE;
pMptCtx->bOfdmContTx = TRUE;
} /* mpt_StartOfdmContTx */
#if defined(CONFIG_RTL8814A) || defined(CONFIG_RTL8821B) || defined(CONFIG_RTL8822B) || defined(CONFIG_RTL8821C) || defined(CONFIG_RTL8822C)
#ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
static void mpt_convert_phydm_txinfo_for_jaguar3(
RT_PMAC_TX_INFO pMacTxInfo, struct phydm_pmac_info *phydmtxinfo)
{
phydmtxinfo->en_pmac_tx = pMacTxInfo.bEnPMacTx;
phydmtxinfo->mode = pMacTxInfo.Mode;
phydmtxinfo->tx_rate = MRateToHwRate(mpt_to_mgnt_rate(pMacTxInfo.TX_RATE));
phydmtxinfo->tx_sc = pMacTxInfo.TX_SC;
phydmtxinfo->is_short_preamble = pMacTxInfo.bSPreamble;
phydmtxinfo->ndp_sound = pMacTxInfo.NDP_sound;
phydmtxinfo->bw = pMacTxInfo.BandWidth;
phydmtxinfo->m_stbc = pMacTxInfo.m_STBC;
phydmtxinfo->packet_period = pMacTxInfo.PacketPeriod;
phydmtxinfo->packet_count = pMacTxInfo.PacketCount;
phydmtxinfo->packet_pattern = pMacTxInfo.PacketPattern;
phydmtxinfo->sfd = pMacTxInfo.SFD;
phydmtxinfo->signal_field = pMacTxInfo.SignalField;
phydmtxinfo->service_field = pMacTxInfo.ServiceField;
phydmtxinfo->length = pMacTxInfo.LENGTH;
_rtw_memcpy(&phydmtxinfo->crc16,pMacTxInfo.CRC16, 2);
_rtw_memcpy(&phydmtxinfo->lsig , pMacTxInfo.LSIG,3);
_rtw_memcpy(&phydmtxinfo->ht_sig , pMacTxInfo.HT_SIG,6);
_rtw_memcpy(&phydmtxinfo->vht_sig_a , pMacTxInfo.VHT_SIG_A,6);
_rtw_memcpy(&phydmtxinfo->vht_sig_b , pMacTxInfo.VHT_SIG_B,4);
phydmtxinfo->vht_sig_b_crc = pMacTxInfo.VHT_SIG_B_CRC;
_rtw_memcpy(&phydmtxinfo->vht_delimiter,pMacTxInfo.VHT_Delimiter,4);
}
#endif
/* for HW TX mode */
void mpt_ProSetPMacTx(PADAPTER Adapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
PMPT_CONTEXT pMptCtx = &(Adapter->mppriv.mpt_ctx);
struct mp_priv *pmppriv = &Adapter->mppriv;
RT_PMAC_TX_INFO PMacTxInfo = pMptCtx->PMacTxInfo;
u32 u4bTmp;
struct dm_struct *p_dm_odm;
p_dm_odm = &pHalData->odmpriv;
#if 0
PRINT_DATA("LSIG ", PMacTxInfo.LSIG, 3);
PRINT_DATA("HT_SIG", PMacTxInfo.HT_SIG, 6);
PRINT_DATA("VHT_SIG_A", PMacTxInfo.VHT_SIG_A, 6);
PRINT_DATA("VHT_SIG_B", PMacTxInfo.VHT_SIG_B, 4);
dbg_print("VHT_SIG_B_CRC %x\n", PMacTxInfo.VHT_SIG_B_CRC);
PRINT_DATA("VHT_Delimiter", PMacTxInfo.VHT_Delimiter, 4);
PRINT_DATA("Src Address", Adapter->mac_addr, ETH_ALEN);
PRINT_DATA("Dest Address", PMacTxInfo.MacAddress, ETH_ALEN);
#endif
if (pmppriv->pktInterval != 0)
PMacTxInfo.PacketPeriod = pmppriv->pktInterval;
if (pmppriv->tx.count != 0)
PMacTxInfo.PacketCount = pmppriv->tx.count;
RTW_INFO("SGI %d bSPreamble %d bSTBC %d bLDPC %d NDP_sound %d\n", PMacTxInfo.bSGI, PMacTxInfo.bSPreamble, PMacTxInfo.bSTBC, PMacTxInfo.bLDPC, PMacTxInfo.NDP_sound);
RTW_INFO("TXSC %d BandWidth %d PacketPeriod %d PacketCount %d PacketLength %d PacketPattern %d\n", PMacTxInfo.TX_SC, PMacTxInfo.BandWidth, PMacTxInfo.PacketPeriod, PMacTxInfo.PacketCount,
PMacTxInfo.PacketLength, PMacTxInfo.PacketPattern);
if (IS_HARDWARE_TYPE_JAGUAR3(Adapter)) {
#ifdef PHYDM_PMAC_TX_SETTING_SUPPORT
struct phydm_pmac_info phydm_mactxinfo;
if (PMacTxInfo.bEnPMacTx == TRUE) {
pMptCtx->HWTxmode = PMacTxInfo.Mode;
pMptCtx->mpt_rate_index = PMacTxInfo.TX_RATE;
if (PMacTxInfo.Mode == CONTINUOUS_TX)
hal_mpt_SetTxPower(Adapter);
} else {
PMacTxInfo.Mode = pMptCtx->HWTxmode;
PMacTxInfo.TX_RATE = pMptCtx->mpt_rate_index;
pMptCtx->HWTxmode = TEST_NONE;
}
mpt_convert_phydm_txinfo_for_jaguar3(PMacTxInfo, &phydm_mactxinfo);
phydm_set_pmac_tx(p_dm_odm, &phydm_mactxinfo, pMptCtx->mpt_rf_path);
#endif
return;
}
if (PMacTxInfo.bEnPMacTx == FALSE) {
if (pMptCtx->HWTxmode == CONTINUOUS_TX) {
phy_set_bb_reg(Adapter, 0xb04, 0xf, 2); /* TX Stop*/
if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index))
mpt_StopCckContTx(Adapter);
else
mpt_StopOfdmContTx(Adapter);
} else if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index)) {
u4bTmp = phy_query_bb_reg(Adapter, 0xf50, bMaskLWord);
phy_set_bb_reg(Adapter, 0xb1c, bMaskLWord, u4bTmp + 50);
phy_set_bb_reg(Adapter, 0xb04, 0xf, 2); /*TX Stop*/
} else
phy_set_bb_reg(Adapter, 0xb04, 0xf, 2); /* TX Stop*/
if (pMptCtx->HWTxmode == OFDM_Single_Tone_TX) {
/* Stop HW TX -> Stop Continuous TX -> Stop RF Setting*/
if (IS_MPT_CCK_RATE(pMptCtx->mpt_rate_index))
mpt_StopCckContTx(Adapter);
else
mpt_StopOfdmContTx(Adapter);
mpt_SetSingleTone_8814A(Adapter, FALSE, TRUE);
}
pMptCtx->HWTxmode = TEST_NONE;
return;
}
pMptCtx->mpt_rate_index = PMacTxInfo.TX_RATE;
if (PMacTxInfo.Mode == CONTINUOUS_TX) {
pMptCtx->HWTxmode = CONTINUOUS_TX;
PMacTxInfo.PacketCount = 1;
hal_mpt_SetTxPower(Adapter);
if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
mpt_StartCckContTx(Adapter);
else
mpt_StartOfdmContTx(Adapter);
} else if (PMacTxInfo.Mode == OFDM_Single_Tone_TX) {
/* Continuous TX -> HW TX -> RF Setting */
pMptCtx->HWTxmode = OFDM_Single_Tone_TX;
PMacTxInfo.PacketCount = 1;
if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE))
mpt_StartCckContTx(Adapter);
else
mpt_StartOfdmContTx(Adapter);
} else if (PMacTxInfo.Mode == PACKETS_TX) {
pMptCtx->HWTxmode = PACKETS_TX;
if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE) && PMacTxInfo.PacketCount == 0)
PMacTxInfo.PacketCount = 0xffff;
}
if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
/* 0xb1c[0:15] TX packet count 0xb1C[31:16] SFD*/
u4bTmp = PMacTxInfo.PacketCount | (PMacTxInfo.SFD << 16);
phy_set_bb_reg(Adapter, 0xb1c, bMaskDWord, u4bTmp);
/* 0xb40 7:0 SIGNAL 15:8 SERVICE 31:16 LENGTH*/
u4bTmp = PMacTxInfo.SignalField | (PMacTxInfo.ServiceField << 8) | (PMacTxInfo.LENGTH << 16);
phy_set_bb_reg(Adapter, 0xb40, bMaskDWord, u4bTmp);
u4bTmp = PMacTxInfo.CRC16[0] | (PMacTxInfo.CRC16[1] << 8);
phy_set_bb_reg(Adapter, 0xb44, bMaskLWord, u4bTmp);
if (PMacTxInfo.bSPreamble)
phy_set_bb_reg(Adapter, 0xb0c, BIT27, 0);
else
phy_set_bb_reg(Adapter, 0xb0c, BIT27, 1);
} else {
phy_set_bb_reg(Adapter, 0xb18, 0xfffff, PMacTxInfo.PacketCount);
u4bTmp = PMacTxInfo.LSIG[0] | ((PMacTxInfo.LSIG[1]) << 8) | ((PMacTxInfo.LSIG[2]) << 16) | ((PMacTxInfo.PacketPattern) << 24);
phy_set_bb_reg(Adapter, 0xb08, bMaskDWord, u4bTmp); /* Set 0xb08[23:0] = LSIG, 0xb08[31:24] = Data init octet*/
if (PMacTxInfo.PacketPattern == 0x12)
u4bTmp = 0x3000000;
else
u4bTmp = 0;
}
if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE)) {
u4bTmp |= PMacTxInfo.HT_SIG[0] | ((PMacTxInfo.HT_SIG[1]) << 8) | ((PMacTxInfo.HT_SIG[2]) << 16);
phy_set_bb_reg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
u4bTmp = PMacTxInfo.HT_SIG[3] | ((PMacTxInfo.HT_SIG[4]) << 8) | ((PMacTxInfo.HT_SIG[5]) << 16);
phy_set_bb_reg(Adapter, 0xb10, 0xffffff, u4bTmp);
} else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
u4bTmp |= PMacTxInfo.VHT_SIG_A[0] | ((PMacTxInfo.VHT_SIG_A[1]) << 8) | ((PMacTxInfo.VHT_SIG_A[2]) << 16);
phy_set_bb_reg(Adapter, 0xb0c, bMaskDWord, u4bTmp);
u4bTmp = PMacTxInfo.VHT_SIG_A[3] | ((PMacTxInfo.VHT_SIG_A[4]) << 8) | ((PMacTxInfo.VHT_SIG_A[5]) << 16);
phy_set_bb_reg(Adapter, 0xb10, 0xffffff, u4bTmp);
_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_SIG_B, 4);
phy_set_bb_reg(Adapter, 0xb14, bMaskDWord, u4bTmp);
}
if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE)) {
u4bTmp = (PMacTxInfo.VHT_SIG_B_CRC << 24) | PMacTxInfo.PacketPeriod; /* for TX interval */
phy_set_bb_reg(Adapter, 0xb20, bMaskDWord, u4bTmp);
_rtw_memcpy(&u4bTmp, PMacTxInfo.VHT_Delimiter, 4);
phy_set_bb_reg(Adapter, 0xb24, bMaskDWord, u4bTmp);
/* 0xb28 - 0xb34 24 byte Probe Request MAC Header*/
/*& Duration & Frame control*/
phy_set_bb_reg(Adapter, 0xb28, bMaskDWord, 0x00000040);
/* Address1 [0:3]*/
u4bTmp = PMacTxInfo.MacAddress[0] | (PMacTxInfo.MacAddress[1] << 8) | (PMacTxInfo.MacAddress[2] << 16) | (PMacTxInfo.MacAddress[3] << 24);
phy_set_bb_reg(Adapter, 0xb2C, bMaskDWord, u4bTmp);
/* Address3 [3:0]*/
phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);
/* Address2[0:1] & Address1 [5:4]*/
u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8) | (Adapter->mac_addr[0] << 16) | (Adapter->mac_addr[1] << 24);
phy_set_bb_reg(Adapter, 0xb30, bMaskDWord, u4bTmp);
/* Address2 [5:2]*/
u4bTmp = Adapter->mac_addr[2] | (Adapter->mac_addr[3] << 8) | (Adapter->mac_addr[4] << 16) | (Adapter->mac_addr[5] << 24);
phy_set_bb_reg(Adapter, 0xb34, bMaskDWord, u4bTmp);
/* Sequence Control & Address3 [5:4]*/
/*u4bTmp = PMacTxInfo.MacAddress[4]|(PMacTxInfo.MacAddress[5] << 8) ;*/
/*phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);*/
} else {
phy_set_bb_reg(Adapter, 0xb20, bMaskDWord, PMacTxInfo.PacketPeriod); /* for TX interval*/
/* & Duration & Frame control */
phy_set_bb_reg(Adapter, 0xb24, bMaskDWord, 0x00000040);
/* 0xb24 - 0xb38 24 byte Probe Request MAC Header*/
/* Address1 [0:3]*/
u4bTmp = PMacTxInfo.MacAddress[0] | (PMacTxInfo.MacAddress[1] << 8) | (PMacTxInfo.MacAddress[2] << 16) | (PMacTxInfo.MacAddress[3] << 24);
phy_set_bb_reg(Adapter, 0xb28, bMaskDWord, u4bTmp);
/* Address3 [3:0]*/
phy_set_bb_reg(Adapter, 0xb34, bMaskDWord, u4bTmp);
/* Address2[0:1] & Address1 [5:4]*/
u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8) | (Adapter->mac_addr[0] << 16) | (Adapter->mac_addr[1] << 24);
phy_set_bb_reg(Adapter, 0xb2c, bMaskDWord, u4bTmp);
/* Address2 [5:2] */
u4bTmp = Adapter->mac_addr[2] | (Adapter->mac_addr[3] << 8) | (Adapter->mac_addr[4] << 16) | (Adapter->mac_addr[5] << 24);
phy_set_bb_reg(Adapter, 0xb30, bMaskDWord, u4bTmp);
/* Sequence Control & Address3 [5:4]*/
u4bTmp = PMacTxInfo.MacAddress[4] | (PMacTxInfo.MacAddress[5] << 8);
phy_set_bb_reg(Adapter, 0xb38, bMaskDWord, u4bTmp);
}
phy_set_bb_reg(Adapter, 0xb48, bMaskByte3, PMacTxInfo.TX_RATE_HEX);
/* 0xb4c 3:0 TXSC 5:4 BW 7:6 m_STBC 8 NDP_Sound*/
u4bTmp = (PMacTxInfo.TX_SC) | ((PMacTxInfo.BandWidth) << 4) | ((PMacTxInfo.m_STBC - 1) << 6) | ((PMacTxInfo.NDP_sound) << 8);
phy_set_bb_reg(Adapter, 0xb4c, 0x1ff, u4bTmp);
if (IS_HARDWARE_TYPE_JAGUAR2(Adapter)) {
u32 offset = 0xb44;
if (IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
phy_set_bb_reg(Adapter, offset, 0xc0000000, 0);
else if (IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
else if (IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
} else if(IS_HARDWARE_TYPE_JAGUAR(Adapter)) {
u32 offset = 0xb4c;
if(IS_MPT_OFDM_RATE(PMacTxInfo.TX_RATE))
phy_set_bb_reg(Adapter, offset, 0xc0000000, 0);
else if(IS_MPT_HT_RATE(PMacTxInfo.TX_RATE))
phy_set_bb_reg(Adapter, offset, 0xc0000000, 1);
else if(IS_MPT_VHT_RATE(PMacTxInfo.TX_RATE))
phy_set_bb_reg(Adapter, offset, 0xc0000000, 2);
}
phy_set_bb_reg(Adapter, 0xb00, BIT8, 1); /* Turn on PMAC*/
/* phy_set_bb_reg(Adapter, 0xb04, 0xf, 2); */ /* TX Stop */
if (IS_MPT_CCK_RATE(PMacTxInfo.TX_RATE)) {
phy_set_bb_reg(Adapter, 0xb04, 0xf, 8); /*TX CCK ON*/
phy_set_bb_reg(Adapter, 0xA84, BIT31, 0);
} else
phy_set_bb_reg(Adapter, 0xb04, 0xf, 4); /* TX Ofdm ON */
if (PMacTxInfo.Mode == OFDM_Single_Tone_TX)
mpt_SetSingleTone_8814A(Adapter, TRUE, TRUE);
}
#endif
void hal_mpt_SetContinuousTx(PADAPTER pAdapter, u8 bStart)
{
u8 Rate;
RTW_INFO("SetContinuousTx: rate:%d\n", pAdapter->mppriv.rateidx);
Rate = HwRateToMPTRate(pAdapter->mppriv.rateidx);
pAdapter->mppriv.mpt_ctx.is_start_cont_tx = bStart;
if (Rate <= MPT_RATE_11M) {
if (bStart)
mpt_StartCckContTx(pAdapter);
else
mpt_StopCckContTx(pAdapter);
} else if (Rate >= MPT_RATE_6M) {
if (bStart)
mpt_StartOfdmContTx(pAdapter);
else
mpt_StopOfdmContTx(pAdapter);
}
}
#endif /* CONFIG_MP_INCLUDE*/
================================================
FILE: hal/hal_phy.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#define _HAL_PHY_C_
#include
/**
* Function: PHY_CalculateBitShift
*
* OverView: Get shifted position of the BitMask
*
* Input:
* u32 BitMask,
*
* Output: none
* Return: u32 Return the shift bit bit position of the mask
*/
u32
PHY_CalculateBitShift(
u32 BitMask
)
{
u32 i;
for (i = 0; i <= 31; i++) {
if (((BitMask >> i) & 0x1) == 1)
break;
}
return i;
}
#ifdef CONFIG_RF_SHADOW_RW
/* ********************************************************************************
* Constant.
* ********************************************************************************
* 2008/11/20 MH For Debug only, RF */
static RF_SHADOW_T RF_Shadow[RF6052_MAX_PATH][RF6052_MAX_REG];
/*
* ==> RF shadow Operation API Code Section!!!
*
*-----------------------------------------------------------------------------
* Function: PHY_RFShadowRead
* PHY_RFShadowWrite
* PHY_RFShadowCompare
* PHY_RFShadowRecorver
* PHY_RFShadowCompareAll
* PHY_RFShadowRecorverAll
* PHY_RFShadowCompareFlagSet
* PHY_RFShadowRecorverFlagSet
*
* Overview: When we set RF register, we must write shadow at first.
* When we are running, we must compare shadow abd locate error addr.
* Decide to recorver or not.
*
* Input: NONE
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 11/20/2008 MHC Create Version 0.
*
*---------------------------------------------------------------------------*/
u32
PHY_RFShadowRead(
PADAPTER Adapter,
enum rf_path eRFPath,
u32 Offset)
{
return RF_Shadow[eRFPath][Offset].Value;
} /* PHY_RFShadowRead */
void
PHY_RFShadowWrite(
PADAPTER Adapter,
enum rf_path eRFPath,
u32 Offset,
u32 Data)
{
RF_Shadow[eRFPath][Offset].Value = (Data & bRFRegOffsetMask);
RF_Shadow[eRFPath][Offset].Driver_Write = _TRUE;
} /* PHY_RFShadowWrite */
BOOLEAN
PHY_RFShadowCompare(
PADAPTER Adapter,
enum rf_path eRFPath,
u32 Offset)
{
u32 reg;
/* Check if we need to check the register */
if (RF_Shadow[eRFPath][Offset].Compare == _TRUE) {
reg = rtw_hal_read_rfreg(Adapter, eRFPath, Offset, bRFRegOffsetMask);
/* Compare shadow and real rf register for 20bits!! */
if (RF_Shadow[eRFPath][Offset].Value != reg) {
/* Locate error position. */
RF_Shadow[eRFPath][Offset].ErrorOrNot = _TRUE;
}
return RF_Shadow[eRFPath][Offset].ErrorOrNot ;
}
return _FALSE;
} /* PHY_RFShadowCompare */
void
PHY_RFShadowRecorver(
PADAPTER Adapter,
enum rf_path eRFPath,
u32 Offset)
{
/* Check if the address is error */
if (RF_Shadow[eRFPath][Offset].ErrorOrNot == _TRUE) {
/* Check if we need to recorver the register. */
if (RF_Shadow[eRFPath][Offset].Recorver == _TRUE) {
rtw_hal_write_rfreg(Adapter, eRFPath, Offset, bRFRegOffsetMask,
RF_Shadow[eRFPath][Offset].Value);
}
}
} /* PHY_RFShadowRecorver */
void
PHY_RFShadowCompareAll(
PADAPTER Adapter)
{
enum rf_path eRFPath = RF_PATH_A;
u32 Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
for (Offset = 0; Offset < maxReg; Offset++)
PHY_RFShadowCompare(Adapter, eRFPath, Offset);
}
} /* PHY_RFShadowCompareAll */
void
PHY_RFShadowRecorverAll(
PADAPTER Adapter)
{
enum rf_path eRFPath = RF_PATH_A;
u32 Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
for (Offset = 0; Offset < maxReg; Offset++)
PHY_RFShadowRecorver(Adapter, eRFPath, Offset);
}
} /* PHY_RFShadowRecorverAll */
void
PHY_RFShadowCompareFlagSet(
PADAPTER Adapter,
enum rf_path eRFPath,
u32 Offset,
u8 Type)
{
/* Set True or False!!! */
RF_Shadow[eRFPath][Offset].Compare = Type;
} /* PHY_RFShadowCompareFlagSet */
void
PHY_RFShadowRecorverFlagSet(
PADAPTER Adapter,
enum rf_path eRFPath,
u32 Offset,
u8 Type)
{
/* Set True or False!!! */
RF_Shadow[eRFPath][Offset].Recorver = Type;
} /* PHY_RFShadowRecorverFlagSet */
void
PHY_RFShadowCompareFlagSetAll(
PADAPTER Adapter)
{
enum rf_path eRFPath = RF_PATH_A;
u32 Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
for (Offset = 0; Offset < maxReg; Offset++) {
/* 2008/11/20 MH For S3S4 test, we only check reg 26/27 now!!!! */
if (Offset != 0x26 && Offset != 0x27)
PHY_RFShadowCompareFlagSet(Adapter, eRFPath, Offset, _FALSE);
else
PHY_RFShadowCompareFlagSet(Adapter, eRFPath, Offset, _TRUE);
}
}
} /* PHY_RFShadowCompareFlagSetAll */
void
PHY_RFShadowRecorverFlagSetAll(
PADAPTER Adapter)
{
enum rf_path eRFPath = RF_PATH_A;
u32 Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
for (Offset = 0; Offset < maxReg; Offset++) {
/* 2008/11/20 MH For S3S4 test, we only check reg 26/27 now!!!! */
if (Offset != 0x26 && Offset != 0x27)
PHY_RFShadowRecorverFlagSet(Adapter, eRFPath, Offset, _FALSE);
else
PHY_RFShadowRecorverFlagSet(Adapter, eRFPath, Offset, _TRUE);
}
}
} /* PHY_RFShadowCompareFlagSetAll */
void
PHY_RFShadowRefresh(
PADAPTER Adapter)
{
enum rf_path eRFPath = RF_PATH_A;
u32 Offset = 0, maxReg = GET_RF6052_REAL_MAX_REG(Adapter);
for (eRFPath = 0; eRFPath < RF6052_MAX_PATH; eRFPath++) {
for (Offset = 0; Offset < maxReg; Offset++) {
RF_Shadow[eRFPath][Offset].Value = 0;
RF_Shadow[eRFPath][Offset].Compare = _FALSE;
RF_Shadow[eRFPath][Offset].Recorver = _FALSE;
RF_Shadow[eRFPath][Offset].ErrorOrNot = _FALSE;
RF_Shadow[eRFPath][Offset].Driver_Write = _FALSE;
}
}
} /* PHY_RFShadowRead */
#endif /*CONFIG_RF_SHADOW_RW*/
================================================
FILE: hal/halmac/halmac_2_platform.h
================================================
/******************************************************************************
*
* Copyright(c) 2015 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_2_PLATFORM_H_
#define _HALMAC_2_PLATFORM_H_
/*[Driver] always set BUILD_TEST =0*/
#define BUILD_TEST 0
#if BUILD_TEST
#include "../Platform/App/Test/halmac_2_platformapi.h"
#else
/*[Driver] use their own header files*/
#include /* for basic_types.h and osdep_service.h */
#include /* u8, u16, u32 and etc.*/
#include /* __BIG_ENDIAN, __LITTLE_ENDIAN, _sema, _mutex */
#endif
/*[Driver] provide the define of NULL, u8, u16, u32*/
#ifndef NULL
#define NULL ((void *)0)
#endif
#define HALMAC_INLINE inline
/*
* Ignore following typedef because Linux already have these
* u8, u16, u32, s8, s16, s32
* __le16, __le32, __be16, __be32
*/
#define HALMAC_PLATFORM_LITTLE_ENDIAN 1
#define HALMAC_PLATFORM_BIG_ENDIAN 0
/* Note : Named HALMAC_PLATFORM_LITTLE_ENDIAN / HALMAC_PLATFORM_BIG_ENDIAN
* is not mandatory. But Little endian must be '1'. Big endian must be '0'
*/
/*[Driver] config the system endian*/
#ifdef __LITTLE_ENDIAN
#define HALMAC_SYSTEM_ENDIAN HALMAC_PLATFORM_LITTLE_ENDIAN
#else /* !__LITTLE_ENDIAN */
#define HALMAC_SYSTEM_ENDIAN HALMAC_PLATFORM_BIG_ENDIAN
#endif /* !__LITTLE_ENDIAN */
/*[Driver] config if the operating platform*/
#define HALMAC_PLATFORM_WINDOWS 0
#define HALMAC_PLATFORM_LINUX 1
#define HALMAC_PLATFORM_AP 0
/*[Driver] must set HALMAC_PLATFORM_TESTPROGRAM = 0*/
#define HALMAC_PLATFORM_TESTPROGRAM 0
/*[Driver] config if enable the dbg msg or notl*/
#define HALMAC_DBG_MSG_ENABLE 1
#define HALMAC_MSG_LEVEL_TRACE 3
#define HALMAC_MSG_LEVEL_WARNING 2
#define HALMAC_MSG_LEVEL_ERR 1
#define HALMAC_MSG_LEVEL_NO_LOG 0
/*[Driver] config halmac msg level
* Use HALMAC_MSG_LEVEL_XXXX
*/
#define HALMAC_MSG_LEVEL HALMAC_MSG_LEVEL_TRACE
/*[Driver] define the Rx FIFO expanding mode packet size unit for 8821C and 8822B */
/*Should be 8 Byte alignment*/
#define HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE 80 /*Bytes*/
#define HALMAC_USE_TYPEDEF 0
/*[Driver] provide the type mutex*/
/* Mutex type */
typedef _mutex HALMAC_MUTEX;
#endif /* _HALMAC_2_PLATFORM_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_8822c_cfg.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_8822C_CFG_H_
#define _HALMAC_8822C_CFG_H_
#include "../../halmac_hw_cfg.h"
#include "../halmac_88xx_cfg.h"
#if HALMAC_8822C_SUPPORT
#define TX_FIFO_SIZE_8822C 262144
#define RX_FIFO_SIZE_8822C 24576
#define TRX_SHARE_SIZE0_8822C 40960
#define TRX_SHARE_SIZE1_8822C 24576
#define TRX_SHARE_SIZE2_8822C (TRX_SHARE_SIZE0_8822C + TRX_SHARE_SIZE1_8822C)
#define TX_FIFO_SIZE_LA_8822C (TX_FIFO_SIZE_8822C >> 1)
#define TX_FIFO_SIZE_RX_EXPAND_1BLK_8822C \
(TX_FIFO_SIZE_8822C - TRX_SHARE_SIZE0_8822C)
#define RX_FIFO_SIZE_RX_EXPAND_1BLK_8822C \
(RX_FIFO_SIZE_8822C + TRX_SHARE_SIZE0_8822C)
#define TX_FIFO_SIZE_RX_EXPAND_2BLK_8822C \
(TX_FIFO_SIZE_8822C - TRX_SHARE_SIZE2_8822C)
#define RX_FIFO_SIZE_RX_EXPAND_2BLK_8822C \
(RX_FIFO_SIZE_8822C + TRX_SHARE_SIZE2_8822C)
#define TX_FIFO_SIZE_RX_EXPAND_3BLK_8822C \
(TX_FIFO_SIZE_8822C - TRX_SHARE_SIZE2_8822C - TRX_SHARE_SIZE0_8822C)
#define RX_FIFO_SIZE_RX_EXPAND_3BLK_8822C \
(RX_FIFO_SIZE_8822C + TRX_SHARE_SIZE2_8822C + TRX_SHARE_SIZE0_8822C)
#define TX_FIFO_SIZE_RX_EXPAND_4BLK_8822C \
(TX_FIFO_SIZE_8822C - (2 * TRX_SHARE_SIZE2_8822C))
#define RX_FIFO_SIZE_RX_EXPAND_4BLK_8822C \
(RX_FIFO_SIZE_8822C + (2 * TRX_SHARE_SIZE2_8822C))
#define EFUSE_SIZE_8822C 512
#define EEPROM_SIZE_8822C 768
#define BT_EFUSE_SIZE_8822C 128
#define PRTCT_EFUSE_SIZE_8822C 124
#define SEC_CAM_NUM_8822C 64
#define OQT_ENTRY_AC_8822C 32
#define OQT_ENTRY_NOAC_8822C 32
#define MACID_MAX_8822C 128
#define WLAN_FW_IRAM_MAX_SIZE_8822C 65536
#define WLAN_FW_DRAM_MAX_SIZE_8822C 65536
#define WLAN_FW_ERAM_MAX_SIZE_8822C 131072
#define WLAN_FW_MAX_SIZE_8822C (WLAN_FW_IRAM_MAX_SIZE_8822C + \
WLAN_FW_DRAM_MAX_SIZE_8822C + WLAN_FW_ERAM_MAX_SIZE_8822C)
#endif /* HALMAC_8822C_SUPPORT*/
#endif
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_cfg_wmac_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_cfg_wmac_8822c.h"
#if HALMAC_8822C_SUPPORT
/**
* cfg_drv_info_8822c() - config driver info
* @adapter : the adapter of halmac
* @drv_info : driver information selection
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_drv_info_8822c(struct halmac_adapter *adapter,
enum halmac_drv_info drv_info)
{
u8 drv_info_size = 0;
u8 phy_status_en = 0;
u8 sniffer_en = 0;
u8 plcp_hdr_en = 0;
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
struct halmac_rx_ignore_info *info = &adapter->rx_ignore_info;
struct halmac_mac_rx_ignore_cfg cfg;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MSG_TRACE("[TRACE]drv info = %d\n", drv_info);
switch (drv_info) {
case HALMAC_DRV_INFO_NONE:
drv_info_size = 0;
phy_status_en = 0;
sniffer_en = 0;
plcp_hdr_en = 0;
info->hdr_chk_mask = 1;
info->fcs_chk_mask = 1;
break;
case HALMAC_DRV_INFO_PHY_STATUS:
drv_info_size = 4;
phy_status_en = 1;
sniffer_en = 0;
plcp_hdr_en = 0;
info->hdr_chk_mask = 1;
info->fcs_chk_mask = 1;
break;
case HALMAC_DRV_INFO_PHY_SNIFFER:
drv_info_size = 5; /* phy status 4byte, sniffer info 1byte */
phy_status_en = 1;
sniffer_en = 1;
plcp_hdr_en = 0;
info->hdr_chk_mask = 0;
info->fcs_chk_mask = 0;
break;
case HALMAC_DRV_INFO_PHY_PLCP:
drv_info_size = 6; /* phy status 4byte, plcp header 2byte */
phy_status_en = 1;
sniffer_en = 0;
plcp_hdr_en = 1;
info->hdr_chk_mask = 0;
info->fcs_chk_mask = 0;
break;
default:
return HALMAC_RET_SW_CASE_NOT_SUPPORT;
}
cfg.hdr_chk_en = info->hdr_chk_en;
cfg.fcs_chk_en = info->fcs_chk_en;
cfg.cck_rst_en = info->cck_rst_en;
cfg.fcs_chk_thr = info->fcs_chk_thr;
api->halmac_set_hw_value(adapter, HALMAC_HW_RX_IGNORE, &cfg);
HALMAC_REG_W8(REG_RX_DRVINFO_SZ, drv_info_size);
adapter->drv_info_size = drv_info_size;
value32 = HALMAC_REG_R32(REG_RCR);
value32 = (value32 & (~BIT_APP_PHYSTS));
if (phy_status_en == 1)
value32 = value32 | BIT_APP_PHYSTS;
HALMAC_REG_W32(REG_RCR, value32);
value32 = HALMAC_REG_R32(REG_WMAC_OPTION_FUNCTION + 4);
value32 = (value32 & (~(BIT(8) | BIT(9))));
if (sniffer_en == 1)
value32 = value32 | BIT(9);
if (plcp_hdr_en == 1)
value32 = value32 | BIT(8);
HALMAC_REG_W32(REG_WMAC_OPTION_FUNCTION + 4, value32);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* init_low_pwr_8822c() - config WMAC register
* @adapter
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_low_pwr_8822c(struct halmac_adapter *adapter)
{
u16 value16;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
/*RXGCK FIFO threshold CFG*/
value16 = (HALMAC_REG_R16(REG_RXPSF_CTRL + 2) & 0xF00F);
value16 |= BIT(10) | BIT(8) | BIT(6) | BIT(4);
HALMAC_REG_W16(REG_RXPSF_CTRL + 2, value16);
/*invalid_pkt CFG*/
value16 = 0;
value16 = BIT_SET_RXPSF_PKTLENTHR(value16, 1);
value16 |= BIT_RXPSF_CTRLEN | BIT_RXPSF_VHTCHKEN | BIT_RXPSF_HTCHKEN
| BIT_RXPSF_OFDMCHKEN | BIT_RXPSF_CCKCHKEN
| BIT_RXPSF_OFDMRST | BIT_RXPSF_CCKRST;
HALMAC_REG_W16(REG_RXPSF_CTRL, value16);
HALMAC_REG_W32(REG_RXPSF_TYPE_CTRL, 0xFFFFFFFF);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
void
cfg_rxgck_fifo_8822c(struct halmac_adapter *adapter, u8 enable)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (enable == 1) {
if (adapter->hw_cfg_info.trx_mode != HALMAC_TRNSFER_NORMAL)
PLTFM_MSG_ERR("[ERR]trx_mode != normal\n");
else
HALMAC_REG_W8_SET(REG_RXPSF_CTRL + 3, BIT(4));
} else {
HALMAC_REG_W8_CLR(REG_RXPSF_CTRL + 3, BIT(4));
}
}
void
cfg_rx_ignore_8822c(struct halmac_adapter *adapter,
struct halmac_mac_rx_ignore_cfg *cfg)
{
u16 value16;
struct halmac_rx_ignore_info *info = &adapter->rx_ignore_info;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value16 = HALMAC_REG_R16(REG_RXPSF_CTRL);
info->hdr_chk_en = cfg->hdr_chk_en;
info->fcs_chk_en = cfg->fcs_chk_en;
info->cck_rst_en = cfg->cck_rst_en;
info->fcs_chk_thr = cfg->fcs_chk_thr;
/*mac header check enable*/
if (cfg->hdr_chk_en == 1 && info->hdr_chk_mask == 1)
value16 |= BIT_RXPSF_MHCHKEN;
else
value16 &= ~(BIT_RXPSF_MHCHKEN);
/*continuous FCS error counter enable*/
if (cfg->fcs_chk_en == 1 && info->fcs_chk_mask == 1)
value16 |= BIT_RXPSF_CONT_ERRCHKEN;
else
value16 &= ~(BIT_RXPSF_CONT_ERRCHKEN);
/*MAC Rx reset when CCK enable*/
if (cfg->cck_rst_en == 1)
value16 |= BIT_RXPSF_CCKRST;
else
value16 &= ~(BIT_RXPSF_CCKRST);
/*FCS error counter threshold*/
value16 = BIT_SET_RXPSF_ERRTHR(value16, cfg->fcs_chk_thr);
HALMAC_REG_W16(REG_RXPSF_CTRL, value16);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
}
void
cfg_ampdu_8822c(struct halmac_adapter *adapter,
struct halmac_ampdu_config *cfg)
{
u32 ht_max_len;
u32 vht_max_len;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W8(REG_PROT_MODE_CTRL + 2, cfg->max_agg_num);
HALMAC_REG_W8(REG_PROT_MODE_CTRL + 3, cfg->max_agg_num);
if (cfg->max_len_en == 1) {
ht_max_len = cfg->ht_max_len & 0xFFFF;
vht_max_len = cfg->vht_max_len & 0xFFFFF;
HALMAC_REG_W32(REG_AMPDU_MAX_LENGTH_HT, ht_max_len);
HALMAC_REG_W32(REG_AMPDU_MAX_LENGTH_VHT, vht_max_len);
}
}
#endif /* HALMAC_8822C_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_cfg_wmac_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_CFG_WMAC_8822C_H_
#define _HALMAC_CFG_WMAC_8822C_H_
#include "../../halmac_api.h"
#if HALMAC_8822C_SUPPORT
enum halmac_ret_status
cfg_drv_info_8822c(struct halmac_adapter *adapter,
enum halmac_drv_info drv_info);
enum halmac_ret_status
init_low_pwr_8822c(struct halmac_adapter *adapter);
void
cfg_rxgck_fifo_8822c(struct halmac_adapter *adapter, u8 enable);
void
cfg_rx_ignore_8822c(struct halmac_adapter *adapter,
struct halmac_mac_rx_ignore_cfg *cfg);
void
cfg_ampdu_8822c(struct halmac_adapter *adapter,
struct halmac_ampdu_config *cfg);
#endif/* HALMAC_8822C_SUPPORT */
#endif/* _HALMAC_CFG_WMAC_8822C_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_common_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_8822c_cfg.h"
#include "halmac_common_8822c.h"
#include "../halmac_common_88xx.h"
#if HALMAC_SDIO_SUPPORT
#include "halmac_sdio_8822c.h"
#endif
#include "halmac_cfg_wmac_8822c.h"
#if HALMAC_8822C_SUPPORT
static void
cfg_ldo25_8822c(struct halmac_adapter *adapter, u8 enable);
/**
* get_hw_value_8822c() -get hw config value
* @adapter : the adapter of halmac
* @hw_id : hw id for driver to query
* @value : hw value, reference table to get data type
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_hw_value_8822c(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (!value) {
PLTFM_MSG_ERR("[ERR]%s (NULL ==value)\n", __func__);
return HALMAC_RET_NULL_POINTER;
}
if (get_hw_value_88xx(adapter, hw_id, value) == HALMAC_RET_SUCCESS)
return HALMAC_RET_SUCCESS;
switch (hw_id) {
case HALMAC_HW_FW_MAX_SIZE:
*(u32 *)value = WLAN_FW_MAX_SIZE_8822C;
break;
#if HALMAC_SDIO_SUPPORT
case HALMAC_HW_SDIO_INT_LAT:
if (adapter->intf != HALMAC_INTERFACE_SDIO)
return HALMAC_RET_WRONG_INTF;
*(u32 *)value = get_sdio_int_lat_8822c(adapter);
break;
case HALMAC_HW_SDIO_CLK_CNT:
if (adapter->intf != HALMAC_INTERFACE_SDIO)
return HALMAC_RET_WRONG_INTF;
status = get_sdio_clk_cnt_8822c(adapter, (u32 *)value);
break;
#endif
default:
return HALMAC_RET_PARA_NOT_SUPPORT;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
/**
* set_hw_value_8822c() -set hw config value
* @adapter : the adapter of halmac
* @hw_id : hw id for driver to config
* @value : hw value, reference table to get data type
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
set_hw_value_8822c(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (!value) {
PLTFM_MSG_ERR("[ERR]null pointer\n");
return HALMAC_RET_NULL_POINTER;
}
if (set_hw_value_88xx(adapter, hw_id, value) == HALMAC_RET_SUCCESS)
return HALMAC_RET_SUCCESS;
switch (hw_id) {
case HALMAC_HW_AMPDU_CONFIG:
cfg_ampdu_8822c(adapter, (struct halmac_ampdu_config *)value);
break;
case HALMAC_HW_RXGCK_FIFO:
cfg_rxgck_fifo_8822c(adapter, *(u8 *)value);
break;
case HALMAC_HW_RX_IGNORE:
cfg_rx_ignore_8822c(adapter,
(struct halmac_mac_rx_ignore_cfg *)value);
break;
case HALMAC_HW_LDO25_EN:
cfg_ldo25_8822c(adapter, *(u8 *)value);
break;
case HALMAC_HW_PCIE_REF_AUTOK:
break;
#if HALMAC_SDIO_SUPPORT
case HALMAC_HW_SDIO_TX_FORMAT:
if (adapter->intf != HALMAC_INTERFACE_SDIO)
return HALMAC_RET_WRONG_INTF;
status =
cfg_tx_fmt_sdio_8822c(adapter,
*(enum halmac_sdio_tx_format *)value);
break;
case HALMAC_HW_SDIO_WT_EN:
if (adapter->intf != HALMAC_INTERFACE_SDIO)
return HALMAC_RET_WRONG_INTF;
status = set_sdio_wt_en_8822c(adapter, 1);
break;
case HALMAC_HW_SDIO_CLK_MONITOR:
if (adapter->intf != HALMAC_INTERFACE_SDIO)
return HALMAC_RET_WRONG_INTF;
status =
set_sdio_clk_mon_8822c(adapter,
*(enum halmac_sdio_clk_monitor *)value);
break;
#endif
default:
return HALMAC_RET_PARA_NOT_SUPPORT;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
/**
* halmac_fill_txdesc_check_sum_88xx() - fill in tx desc check sum
* @adapter : the adapter of halmac
* @txdesc : tx desc packet
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
fill_txdesc_check_sum_8822c(struct halmac_adapter *adapter, u8 *txdesc)
{
__le16 chksum = 0;
u16 txdesc_size;
__le16 *data;
u32 i;
if (!txdesc) {
PLTFM_MSG_ERR("[ERR]null pointer\n");
return HALMAC_RET_NULL_POINTER;
}
if (adapter->tx_desc_checksum != 1)
PLTFM_MSG_TRACE("[TRACE]chksum disable\n");
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, 0x0000);
data = (u16 *)(txdesc);
/*unit: 4 Bytes*/
txdesc_size = (u16)((GET_TX_DESC_PKT_OFFSET(txdesc) +
(TX_DESC_SIZE_88XX >> 3)) << 1);
for (i = 0; i < txdesc_size; i++)
chksum ^= (*(data + 2 * i) ^ *(data + (2 * i + 1)));
/* *(data + 2 * i) & *(data + (2 * i + 1) have endain issue*/
/* Process eniadn issue after checksum calculation */
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, rtk_le16_to_cpu(chksum));
return HALMAC_RET_SUCCESS;
}
static void
cfg_ldo25_8822c(struct halmac_adapter *adapter, u8 enable)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_ANAPARLDO_POW_MAC);
if (enable == 1)
HALMAC_REG_W8(REG_ANAPARLDO_POW_MAC, (u8)(value8 | BIT(0)));
else
HALMAC_REG_W8(REG_ANAPARLDO_POW_MAC, (u8)(value8 & ~BIT(0)));
}
#endif /* HALMAC_8822C_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_common_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_COMMON_8822C_H_
#define _HALMAC_COMMON_8822C_H_
#include "../../halmac_api.h"
#if HALMAC_8822C_SUPPORT
enum halmac_ret_status
get_hw_value_8822c(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value);
enum halmac_ret_status
set_hw_value_8822c(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value);
enum halmac_ret_status
fill_txdesc_check_sum_8822c(struct halmac_adapter *adapter, u8 *txdesc);
#endif/* HALMAC_8822C_SUPPORT */
#endif/* _HALMAC_COMMON_8822C_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_gpio_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_gpio_8822c.h"
#include "../halmac_gpio_88xx.h"
#if HALMAC_8822C_SUPPORT
/* GPIO0 definition */
#define GPIO0_BT_GPIO0_8822C \
{HALMAC_BT_GPIO, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x66, BIT(2) | BIT(1) | BIT(0), BIT(2)}
#define GPIO0_BT_SDIO_INT_8822C \
{HALMAC_BT_SDIO_INT, HALMAC_GPIO0, HALMAC_GPIO_OUT, \
0x4F, BIT(5), BIT(5)}
#define GPIO0_USIN0_8822C \
{HALMAC_UART0, HALMAC_GPIO0, HALMAC_GPIO_IN, \
0x66, BIT(6), BIT(6)}
#define GPIO0_BT_ANT_SW_0_8822C \
{HALMAC_BT_RF, HALMAC_GPIO0, HALMAC_GPIO_OUT, \
0x4F, BIT(6), BIT(6)}
#define GPIO0_BT_ACT_8822C \
{HALMAC_BT_PTA, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x41, BIT(1), 0}
#define GPIO0_WL_ACT_8822C \
{HALMAC_WL_PTA, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x41, BIT(2), BIT(2)}
#define GPIO0_WLMAC_DBG_GPIO0_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO0, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO0_WLPHY_DBG_GPIO0_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO0_BT_DBG_GPIO0_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO0, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO0_ANT_SW_GPIO0_8822C \
{HALMAC_SW_DPDT_SEL, HALMAC_GPIO0, HALMAC_GPIO_OUT, \
0x4E, BIT(7), BIT(7)}
#define GPIO0_BT_RFE_CTRL_1_8822C \
{HALMAC_BT_DPDT_SEL, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO0_WL_RFE_CTRL_9_8822C \
{HALMAC_WL_DPDT_SEL, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO0_RFE_CTRL_10_4_5_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x40, BIT(2), BIT(2)}
#define GPIO0_RFE_CTRL_10_6_7_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO_2, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x40, BIT(3), BIT(3)}
#define GPIO0_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO0, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO 1 definition */
#define GPIO1_BT_GPIO1_8822C \
{HALMAC_BT_GPIO, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x66, BIT(2) | BIT(1) | BIT(0), BIT(2)}
#define GPIO1_USOUT0_8822C \
{HALMAC_UART0, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x66, BIT(6), BIT(6)}
#define GPIO1_BT_ANT_SW_1_8822C \
{HALMAC_BT_RF, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x4F, BIT(6), BIT(6)}
#define GPIO1_BT_3DD_SYNC_A_8822C \
{HALMAC_BT_3DDLS_A, HALMAC_GPIO1, HALMAC_GPIO_IN, \
0x66, BIT(2), 0}
#define GPIO1_WL_CK_8822C \
{HALMAC_BT_PTA, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x41, BIT(1), 0}
#define GPIO1_BT_CK_8822C \
{HALMAC_WL_PTA, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x41, BIT(2), BIT(2)}
#define GPIO1_WLMAC_DBG_GPIO1_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO1_WLPHY_DBG_GPIO1_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO1_BT_DBG_GPIO1_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO1_ANT_SWB_GPIO1_8822C \
{HALMAC_SW_DPDT_SEL, HALMAC_GPIO1, HALMAC_GPIO_OUT, \
0x4E, BIT(7), BIT(7)}
#define GPIO1_BT_RFE_CTRL_0_8822C \
{HALMAC_BT_DPDT_SEL, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO1_WL_RFE_CTRL_8_8822C \
{HALMAC_WL_DPDT_SEL, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO1_RFE_CTRL_5_4_5_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x40, BIT(2), BIT(2)}
#define GPIO1_RFE_CTRL_5_6_7_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO_2, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x40, BIT(3), BIT(3)}
#define GPIO1_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO1, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO2 definition */
#define GPIO2_BT_GPIO2_8822C \
{HALMAC_BT_GPIO, HALMAC_GPIO2, HALMAC_GPIO_IN_OUT, \
0x66, BIT(2) | BIT(1) | BIT(0), BIT(2)}
#define GPIO2_BT_ANT_SW_2_8822C \
{HALMAC_BT_RF, HALMAC_GPIO2, HALMAC_GPIO_OUT, \
0x4F, BIT(6), BIT(6)}
#define GPIO2_WL_STATE_8822C \
{HALMAC_BT_PTA, HALMAC_GPIO2, HALMAC_GPIO_OUT, \
0x41, BIT(1), 0}
#define GPIO2_BT_STATE_8822C \
{HALMAC_WL_PTA, HALMAC_GPIO2, HALMAC_GPIO_OUT, \
0x41, BIT(2), BIT(2)}
#define GPIO2_WLMAC_DBG_GPIO2_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO2, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO2_WLPHY_DBG_GPIO2_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO2, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO2_BT_DBG_GPIO2_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO2, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO2_RFE_CTRL_11_4_5_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO, HALMAC_GPIO2, HALMAC_GPIO_IN_OUT, \
0x40, BIT(2), BIT(2)}
#define GPIO2_RFE_CTRL_11_6_7_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO_2, HALMAC_GPIO2, HALMAC_GPIO_IN_OUT, \
0x40, BIT(3), BIT(3)}
#define GPIO2_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO2, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO3 definition */
#define GPIO3_BT_GPIO3_8822C \
{HALMAC_BT_GPIO, HALMAC_GPIO3, HALMAC_GPIO_IN_OUT, \
0x66, BIT(2) | BIT(1) | BIT(0), BIT(2)}
#define GPIO3_BT_ANT_SW_3_8822C \
{HALMAC_BT_RF, HALMAC_GPIO3, HALMAC_GPIO_OUT, \
0x4F, BIT(6), BIT(6)}
#define GPIO3_WL_PRI_8822C \
{HALMAC_BT_PTA, HALMAC_GPIO3, HALMAC_GPIO_OUT, \
0x41, BIT(1), 0}
#define GPIO3_BT_PRI_8822C \
{HALMAC_WL_PTA, HALMAC_GPIO3, HALMAC_GPIO_OUT, \
0x41, BIT(2), BIT(2)}
#define GPIO3_WLMAC_DBG_GPIO3_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO3, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO3_WLPHY_DBG_GPIO3_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO3, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO3_BT_DBG_GPIO3_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO3, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO3_LNAON_SEL_8822C \
{HALMAC_SW_LNAON_SET, HALMAC_GPIO3, HALMAC_GPIO_OUT, \
0x4F, BIT(2), BIT(2)}
#define GPIO3_BT_RFE_CTRL_5_8822C \
{HALMAC_BT_LNAON_SEL, HALMAC_GPIO3, HALMAC_GPIO_IN_OUT, \
0x42, BIT(0), BIT(0)}
#define GPIO3_RFE_CTRL_3_8822C \
{HALMAC_WLBT_LNAON_SEL, HALMAC_GPIO3, HALMAC_GPIO_IN_OUT, \
0x42, BIT(0), BIT(0)}
#define GPIO3_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO3, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO4 definition */
#define GPIO4_BT_SPI_D0_8822C \
{HALMAC_BT_SFLASH, HALMAC_GPIO4, HALMAC_GPIO_IN_OUT, \
0x66, BIT(4), BIT(4)}
#define GPIO4_WL_SPI_D0_8822C \
{HALMAC_WL_SFLASH, HALMAC_GPIO4, HALMAC_GPIO_IN_OUT, \
0x42, BIT(3), BIT(3)}
#define GPIO4_BT_JTAG_TRST_8822C \
{HALMAC_BT_JTAG, HALMAC_GPIO4, HALMAC_GPIO_IN, \
0x67, BIT(0), BIT(0)}
#define GPIO4_WL_JTAG_TRST_8822C \
{HALMAC_WL_JTAG, HALMAC_GPIO4, HALMAC_GPIO_IN, \
0x65, BIT(7), BIT(7)}
#define GPIO4_DBG_GNT_WL_8822C \
{HALMAC_DBG_GNT_WL_BT, HALMAC_GPIO4, HALMAC_GPIO_OUT, \
0x73, BIT(3), BIT(3)}
#define GPIO4_WLMAC_DBG_GPIO4_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO4, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO4_WLPHY_DBG_GPIO4_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO4, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO4_BT_DBG_GPIO4_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO4, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO4_ANT_SWB_GPIO4_8822C \
{HALMAC_SW_DPDT_SEL, HALMAC_GPIO4, HALMAC_GPIO_OUT, \
0x4E, BIT(7), BIT(7)}
#define GPIO4_BT_RFE_CTRL_0_8822C \
{HALMAC_BT_DPDT_SEL, HALMAC_GPIO4, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO4_WL_RFE_CTRL_8_8822C \
{HALMAC_WL_DPDT_SEL, HALMAC_GPIO4, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO4_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO4, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO5 definition */
#define GPIO5_BT_SPI_D1_8822C \
{HALMAC_BT_SFLASH, HALMAC_GPIO5, HALMAC_GPIO_OUT, \
0x66, BIT(4), BIT(4)}
#define GPIO5_WL_SPI_D1_8822C \
{HALMAC_WL_SFLASH, HALMAC_GPIO5, HALMAC_GPIO_OUT, \
0x42, BIT(3), BIT(3)}
#define GPIO5_BT_JTAG_TDI_8822C \
{HALMAC_BT_JTAG, HALMAC_GPIO5, HALMAC_GPIO_IN, \
0x67, BIT(0), BIT(0)}
#define GPIO5_WL_JTAG_TDI_8822C \
{HALMAC_WL_JTAG, HALMAC_GPIO5, HALMAC_GPIO_IN, \
0x65, BIT(7), BIT(7)}
#define GPIO5_DBG_GNT_BT_8822C \
{HALMAC_DBG_GNT_WL_BT, HALMAC_GPIO5, HALMAC_GPIO_OUT, \
0x73, BIT(3), BIT(3)}
#define GPIO5_BT_GPIO18_8822C \
{HALMAC_BT_GPIO, HALMAC_GPIO5, HALMAC_GPIO_IN_OUT, \
0x67, BIT(1), BIT(1)}
#define GPIO5_SOUT_8822C \
{HALMAC_WL_UART, HALMAC_GPIO5, HALMAC_GPIO_OUT, \
0x41, BIT(0), BIT(0)}
#define GPIO5_WLMAC_DBG_GPIO5_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO5, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO5_WLPHY_DBG_GPIO5_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO5, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO5_BT_DBG_GPIO5_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO5, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO5_I2C_INT_3_WIRE_8822C \
{HALMAC_MAILBOX_3W, HALMAC_GPIO5, HALMAC_GPIO_IN, \
0x4F, BIT(4), BIT(4)}
#define GPIO5_I2C_INT_1_WIRE_8822C \
{HALMAC_MAILBOX_1W, HALMAC_GPIO5, HALMAC_GPIO_IN, \
0x4F, BIT(7), BIT(7)}
#define GPIO5_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO5, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO6 definition */
#define GPIO6_BT_SPI_D2_8822C \
{HALMAC_BT_SFLASH, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x66, BIT(4), BIT(4)}
#define GPIO6_WL_SPI_D2_8822C \
{HALMAC_WL_SFLASH, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x42, BIT(3), BIT(3)}
#define GPIO6_EEDO_8822C \
{HALMAC_EEPROM, HALMAC_GPIO6, HALMAC_GPIO_IN, \
0x40, BIT(4), BIT(4)}
#define GPIO6_BT_JTAG_TDO_8822C \
{HALMAC_BT_JTAG, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x67, BIT(0), BIT(0)}
#define GPIO6_WL_JTAG_TDO_8822C \
{HALMAC_WL_JTAG, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x65, BIT(0), BIT(0)}
#define GPIO6_BT_3DD_SYNC_B_8822C \
{HALMAC_BT_3DDLS_B, HALMAC_GPIO6, HALMAC_GPIO_IN, \
0x67, BIT(1), BIT(1)}
#define GPIO6_SIN_8822C \
{HALMAC_WL_UART, HALMAC_GPIO6, HALMAC_GPIO_IN, \
0x41, BIT(0), BIT(0)}
#define GPIO6_WLMAC_DBG_GPIO6_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO6_WLPHY_DBG_GPIO6_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO6, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO6_BT_DBG_GPIO6_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO6_SW_PAPE_SEL_8822C \
{HALMAC_SW_PAPE_SEL, HALMAC_GPIO6, HALMAC_GPIO_OUT, \
0x4F, BIT(1), BIT(1)}
#define GPIO6_BT_RFE_CTRL_3_8822C \
{HALMAC_BT_PAPE_SEL, HALMAC_GPIO6, HALMAC_GPIO_IN_OUT, \
0x4F, BIT(3), BIT(3)}
#define GPIO6_RFE_CTRL_1_8822C \
{HALMAC_WLBT_PAPE_SEL, HALMAC_GPIO6, HALMAC_GPIO_IN_OUT, \
0x4F, BIT(3), BIT(3)}
#define GPIO6_EXT_SWR_CTRL_8822C \
{HALMAC_SWR_CTRL_EN, HALMAC_GPIO6, HALMAC_GPIO_IN, \
0x7F, BIT(7), BIT(7)}
#define GPIO6_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO6, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO7 definition */
#define GPIO7_BT_SPI_D3_8822C \
{HALMAC_BT_SFLASH, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x66, BIT(4), BIT(4)}
#define GPIO7_WL_SPI_D3_8822C \
{HALMAC_WL_SFLASH, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x42, BIT(3), BIT(3)}
#define GPIO7_EEDI_8822C \
{HALMAC_EEPROM, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x40, BIT(4), BIT(4)}
#define GPIO7_BT_JTAG_TMS_8822C \
{HALMAC_BT_JTAG, HALMAC_GPIO7, HALMAC_GPIO_IN, \
0x67, BIT(0), BIT(0)}
#define GPIO7_WL_JTAG_TMS_8822C \
{HALMAC_WL_JTAG, HALMAC_GPIO7, HALMAC_GPIO_IN, \
0x65, BIT(7), BIT(7)}
#define GPIO7_BT_GPIO16_8822C \
{HALMAC_BT_GPIO, HALMAC_GPIO7, HALMAC_GPIO_IN_OUT, \
0x67, BIT(2), BIT(2)}
#define GPIO7_SOUT_8822C \
{HALMAC_WL_UART, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x41, BIT(0), BIT(0)}
#define GPIO7_WLMAC_DBG_GPIO7_8822C \
{HALMAC_WLMAC_DBG, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(0)}
#define GPIO7_WLPHY_DBG_GPIO7_8822C \
{HALMAC_WLPHY_DBG, HALMAC_GPIO7, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), BIT(1)}
#define GPIO7_BT_DBG_GPIO7_8822C \
{HALMAC_BT_DBG, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x40, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO7_LNAON_SEL_8822C \
{HALMAC_SW_LNAON_SET, HALMAC_GPIO7, HALMAC_GPIO_OUT, \
0x4F, BIT(2), BIT(2)}
#define GPIO7_BT_RFE_CTRL_4_8822C \
{HALMAC_BT_LNAON_SEL, HALMAC_GPIO7, HALMAC_GPIO_IN_OUT, \
0x42, BIT(0), BIT(0)}
#define GPIO7_RFE_CTRL_2_8822C \
{HALMAC_WLBT_LNAON_SEL, HALMAC_GPIO7, HALMAC_GPIO_IN_OUT, \
0x42, BIT(0), BIT(0)}
#define GPIO7_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO7, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO8 definition */
#define GPIO8_WL_EXT_WOL_8822C \
{HALMAC_WL_HW_EXTWOL, HALMAC_GPIO8, HALMAC_GPIO_IN, \
0x4A, BIT(1) | BIT(0), BIT(1) | BIT(0)}
#define GPIO8_WL_LED_8822C \
{HALMAC_WL_LED, HALMAC_GPIO8, HALMAC_GPIO_OUT, \
0x4E, BIT(5), BIT(5)}
#define GPIO8_SOUT_8822C \
{HALMAC_WL_UART, HALMAC_GPIO8, HALMAC_GPIO_OUT, \
0x41, BIT(0), BIT(0)}
#define GPIO8_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO8, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO9 definition */
#define GPIO9_DIS_WL_N_8822C \
{HALMAC_WL_HWPDN, HALMAC_GPIO9, HALMAC_GPIO_IN, \
0x68, BIT(3) | BIT(0), BIT(3) | BIT(0)}
#define GPIO9_WL_EXT_WOL_8822C \
{HALMAC_WL_HW_EXTWOL, HALMAC_GPIO9, HALMAC_GPIO_IN, \
0x4A, BIT(1) | BIT(0), BIT(0)}
#define GPIO9_USIN0_8822C \
{HALMAC_UART0, HALMAC_GPIO9, HALMAC_GPIO_IN, \
0x66, BIT(6), BIT(6)}
#define GPIO9_I2C_SD_8822C \
{HALMAC_MAILBOX_3W, HALMAC_GPIO9, HALMAC_GPIO_IN, \
0x4F, BIT(4), BIT(4)}
#define GPIO9_LNAON_SEL_8822C \
{HALMAC_SW_LNAON_SET, HALMAC_GPIO9, HALMAC_GPIO_OUT, \
0x4F, BIT(2), BIT(2)}
#define GPIO9_BT_RFE_CTRL_4_8822C \
{HALMAC_BT_LNAON_SEL, HALMAC_GPIO9, HALMAC_GPIO_IN_OUT, \
0x42, BIT(0), BIT(0)}
#define GPIO9_RFE_CTRL_2_8822C \
{HALMAC_WLBT_LNAON_SEL, HALMAC_GPIO9, HALMAC_GPIO_IN_OUT, \
0x42, BIT(0), BIT(0)}
#define GPIO9_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO9, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO10 definition */
#define GPIO10_WL_SDIO_INT_8822C \
{HALMAC_SDIO_INT, HALMAC_GPIO10, HALMAC_GPIO_OUT, \
0x72, BIT(2), BIT(2)}
#define GPIO10_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO10, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO11 definition */
#define GPIO11_DIS_BT_N_8822C \
{HALMAC_BT_HWPDN, HALMAC_GPIO11, HALMAC_GPIO_IN, \
0x6A, BIT(3) | BIT(0), BIT(3) | BIT(0)}
#define GPIO11_USOUT0_8822C \
{HALMAC_UART0, HALMAC_GPIO11, HALMAC_GPIO_OUT, \
0x66, BIT(6), BIT(6)}
#define GPIO11_RFE_CTRL_11_4_5_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO, HALMAC_GPIO11, HALMAC_GPIO_IN_OUT, \
0x40, BIT(2), BIT(2)}
#define GPIO11_RFE_CTRL_11_6_7_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO_2, HALMAC_GPIO11, HALMAC_GPIO_IN_OUT, \
0x40, BIT(3), BIT(3)}
#define GPIO11_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO11, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO12 definition */
#define GPIO12_USCTS0_8822C \
{HALMAC_UART0, HALMAC_GPIO12, HALMAC_GPIO_IN, \
0x66, BIT(6), BIT(6)}
#define GPIO12_I2C_CLK_8822C \
{HALMAC_MAILBOX_3W, HALMAC_GPIO12, HALMAC_GPIO_IN, \
0x4F, BIT(4), BIT(4)}
#define GPIO12_ANT_SW_GPIO12_8822C \
{HALMAC_SW_DPDT_SEL, HALMAC_GPIO12, HALMAC_GPIO_OUT, \
0x4E, BIT(7), BIT(7)}
#define GPIO12_BT_RFE_CTRL_1_8822C \
{HALMAC_BT_DPDT_SEL, HALMAC_GPIO12, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO12_WL_RFE_CTRL_9_8822C \
{HALMAC_WL_DPDT_SEL, HALMAC_GPIO12, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO12_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO12, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO13 definition */
#define GPIO13_BT_WAKE_8822C \
{HALMAC_GPIO13_14_WL_CTRL_EN, HALMAC_GPIO13, HALMAC_GPIO_IN, \
0x4E, BIT(6), BIT(6)}
#define GPIO13_BT_ANT_SW_0_8822C \
{HALMAC_BT_RF, HALMAC_GPIO13, HALMAC_GPIO_OUT, \
0x4F, BIT(6), BIT(6)}
#define GPIO13_ANT_SW_GPIO13_8822C \
{HALMAC_SW_DPDT_SEL, HALMAC_GPIO13, HALMAC_GPIO_OUT, \
0x4E, BIT(7), BIT(7)}
#define GPIO13_BT_RFE_CTRL_1_8822C \
{HALMAC_BT_DPDT_SEL, HALMAC_GPIO13, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO13_WL_RFE_CTRL_9_8822C \
{HALMAC_WL_DPDT_SEL, HALMAC_GPIO13, HALMAC_GPIO_IN_OUT, \
0x42, BIT(1), BIT(1)}
#define GPIO13_RFE_CTRL_10_4_5_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO, HALMAC_GPIO13, HALMAC_GPIO_IN_OUT, \
0x40, BIT(2), BIT(2)}
#define GPIO13_RFE_CTRL_10_6_7_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO_2, HALMAC_GPIO13, HALMAC_GPIO_IN_OUT, \
0x40, BIT(3), BIT(3)}
#define GPIO13_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO13, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO14 definition */
#define GPIO14_UART_WAKE_8822C \
{HALMAC_GPIO13_14_WL_CTRL_EN, HALMAC_GPIO14, HALMAC_GPIO_OUT, \
0x4E, BIT(6), BIT(6)}
#define GPIO14_BT_ANT_SW_1_8822C \
{HALMAC_BT_RF, HALMAC_GPIO14, HALMAC_GPIO_OUT, \
0x4F, BIT(6), BIT(6)}
#define GPIO14_RFE_CTRL_5_4_5_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO, HALMAC_GPIO14, HALMAC_GPIO_IN_OUT, \
0x40, BIT(2), BIT(2)}
#define GPIO14_RFE_CTRL_5_6_7_8822C \
{HALMAC_WLPHY_RFE_CTRL2GPIO_2, HALMAC_GPIO14, HALMAC_GPIO_IN_OUT, \
0x40, BIT(3), BIT(3)}
#define GPIO14_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO14, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
/* GPIO15 definition */
#define GPIO15_EXT_XTAL_8822C \
{HALMAC_EXT_XTAL, HALMAC_GPIO15, HALMAC_GPIO_OUT, \
0x66, BIT(7), BIT(7)}
#define GPIO15_SW_IO_8822C \
{HALMAC_SW_IO, HALMAC_GPIO15, HALMAC_GPIO_IN_OUT, \
0x40, BIT(1) | BIT(0), 0}
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO0_8822C[] = {
GPIO0_BT_GPIO0_8822C,
GPIO0_BT_SDIO_INT_8822C,
GPIO0_USIN0_8822C,
GPIO0_BT_ANT_SW_0_8822C,
GPIO0_BT_ACT_8822C,
GPIO0_WL_ACT_8822C,
GPIO0_WLMAC_DBG_GPIO0_8822C,
GPIO0_WLPHY_DBG_GPIO0_8822C,
GPIO0_BT_DBG_GPIO0_8822C,
GPIO0_ANT_SW_GPIO0_8822C,
GPIO0_BT_RFE_CTRL_1_8822C,
GPIO0_WL_RFE_CTRL_9_8822C,
GPIO0_RFE_CTRL_10_4_5_8822C,
GPIO0_RFE_CTRL_10_6_7_8822C,
GPIO0_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO1_8822C[] = {
GPIO1_BT_GPIO1_8822C,
GPIO1_USOUT0_8822C,
GPIO1_BT_ANT_SW_1_8822C,
GPIO1_BT_3DD_SYNC_A_8822C,
GPIO1_WL_CK_8822C,
GPIO1_BT_CK_8822C,
GPIO1_WLMAC_DBG_GPIO1_8822C,
GPIO1_WLPHY_DBG_GPIO1_8822C,
GPIO1_BT_DBG_GPIO1_8822C,
GPIO1_ANT_SWB_GPIO1_8822C,
GPIO1_BT_RFE_CTRL_0_8822C,
GPIO1_WL_RFE_CTRL_8_8822C,
GPIO1_RFE_CTRL_5_4_5_8822C,
GPIO1_RFE_CTRL_5_6_7_8822C,
GPIO1_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO2_8822C[] = {
GPIO2_BT_GPIO2_8822C,
GPIO2_BT_ANT_SW_2_8822C,
GPIO2_WL_STATE_8822C,
GPIO2_BT_STATE_8822C,
GPIO2_WLMAC_DBG_GPIO2_8822C,
GPIO2_WLPHY_DBG_GPIO2_8822C,
GPIO2_BT_DBG_GPIO2_8822C,
GPIO2_RFE_CTRL_11_4_5_8822C,
GPIO2_RFE_CTRL_11_6_7_8822C,
GPIO2_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO3_8822C[] = {
GPIO3_BT_GPIO3_8822C,
GPIO3_BT_ANT_SW_3_8822C,
GPIO3_WL_PRI_8822C,
GPIO3_BT_PRI_8822C,
GPIO3_WLMAC_DBG_GPIO3_8822C,
GPIO3_WLPHY_DBG_GPIO3_8822C,
GPIO3_BT_DBG_GPIO3_8822C,
GPIO3_LNAON_SEL_8822C,
GPIO3_BT_RFE_CTRL_5_8822C,
GPIO3_RFE_CTRL_3_8822C,
GPIO3_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO4_8822C[] = {
GPIO4_BT_SPI_D0_8822C,
GPIO4_WL_SPI_D0_8822C,
GPIO4_BT_JTAG_TRST_8822C,
GPIO4_WL_JTAG_TRST_8822C,
GPIO4_DBG_GNT_WL_8822C,
GPIO4_WLMAC_DBG_GPIO4_8822C,
GPIO4_WLPHY_DBG_GPIO4_8822C,
GPIO4_BT_DBG_GPIO4_8822C,
GPIO4_ANT_SWB_GPIO4_8822C,
GPIO4_BT_RFE_CTRL_0_8822C,
GPIO4_WL_RFE_CTRL_8_8822C,
GPIO4_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO5_8822C[] = {
GPIO5_BT_SPI_D1_8822C,
GPIO5_WL_SPI_D1_8822C,
GPIO5_BT_JTAG_TDI_8822C,
GPIO5_WL_JTAG_TDI_8822C,
GPIO5_DBG_GNT_BT_8822C,
GPIO5_BT_GPIO18_8822C,
GPIO5_SOUT_8822C,
GPIO5_WLMAC_DBG_GPIO5_8822C,
GPIO5_WLPHY_DBG_GPIO5_8822C,
GPIO5_BT_DBG_GPIO5_8822C,
GPIO5_I2C_INT_3_WIRE_8822C,
GPIO5_I2C_INT_1_WIRE_8822C,
GPIO5_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO6_8822C[] = {
GPIO6_BT_SPI_D2_8822C,
GPIO6_WL_SPI_D2_8822C,
GPIO6_EEDO_8822C,
GPIO6_BT_JTAG_TDO_8822C,
GPIO6_WL_JTAG_TDO_8822C,
GPIO6_BT_3DD_SYNC_B_8822C,
GPIO6_SIN_8822C,
GPIO6_WLMAC_DBG_GPIO6_8822C,
GPIO6_WLPHY_DBG_GPIO6_8822C,
GPIO6_BT_DBG_GPIO6_8822C,
GPIO6_SW_PAPE_SEL_8822C,
GPIO6_BT_RFE_CTRL_3_8822C,
GPIO6_RFE_CTRL_1_8822C,
GPIO6_EXT_SWR_CTRL_8822C,
GPIO6_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO7_8822C[] = {
GPIO7_BT_SPI_D3_8822C,
GPIO7_WL_SPI_D3_8822C,
GPIO7_EEDI_8822C,
GPIO7_BT_JTAG_TMS_8822C,
GPIO7_WL_JTAG_TMS_8822C,
GPIO7_BT_GPIO16_8822C,
GPIO7_SOUT_8822C,
GPIO7_WLMAC_DBG_GPIO7_8822C,
GPIO7_WLPHY_DBG_GPIO7_8822C,
GPIO7_BT_DBG_GPIO7_8822C,
GPIO7_LNAON_SEL_8822C,
GPIO7_BT_RFE_CTRL_4_8822C,
GPIO7_RFE_CTRL_2_8822C,
GPIO7_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO8_8822C[] = {
GPIO8_WL_EXT_WOL_8822C,
GPIO8_WL_LED_8822C,
GPIO8_SOUT_8822C,
GPIO8_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO9_8822C[] = {
GPIO9_DIS_WL_N_8822C,
GPIO9_WL_EXT_WOL_8822C,
GPIO9_USIN0_8822C,
GPIO9_I2C_SD_8822C,
GPIO9_LNAON_SEL_8822C,
GPIO9_BT_RFE_CTRL_4_8822C,
GPIO9_RFE_CTRL_2_8822C,
GPIO9_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO10_8822C[] = {
GPIO10_WL_SDIO_INT_8822C,
GPIO10_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO11_8822C[] = {
GPIO11_DIS_BT_N_8822C,
GPIO11_USOUT0_8822C,
GPIO11_RFE_CTRL_11_4_5_8822C,
GPIO11_RFE_CTRL_11_6_7_8822C,
GPIO11_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO12_8822C[] = {
GPIO12_USCTS0_8822C,
GPIO12_I2C_CLK_8822C,
GPIO12_ANT_SW_GPIO12_8822C,
GPIO12_BT_RFE_CTRL_1_8822C,
GPIO12_WL_RFE_CTRL_9_8822C,
GPIO12_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO13_8822C[] = {
GPIO13_BT_WAKE_8822C,
GPIO13_BT_ANT_SW_0_8822C,
GPIO13_ANT_SW_GPIO13_8822C,
GPIO13_BT_RFE_CTRL_1_8822C,
GPIO13_WL_RFE_CTRL_9_8822C,
GPIO13_RFE_CTRL_10_4_5_8822C,
GPIO13_RFE_CTRL_10_6_7_8822C,
GPIO13_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO14_8822C[] = {
GPIO14_UART_WAKE_8822C,
GPIO14_BT_ANT_SW_1_8822C,
GPIO14_RFE_CTRL_5_4_5_8822C,
GPIO14_RFE_CTRL_5_6_7_8822C,
GPIO14_SW_IO_8822C
};
static const struct halmac_gpio_pimux_list PINMUX_LIST_GPIO15_8822C[] = {
GPIO15_EXT_XTAL_8822C,
GPIO15_SW_IO_8822C
};
static enum halmac_ret_status
get_pinmux_list_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func,
const struct halmac_gpio_pimux_list **list,
u32 *list_size, u32 *gpio_id);
static enum halmac_ret_status
chk_pinmux_valid_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func);
/**
* pinmux_get_func_8822c() -get current gpio status
* @adapter : the adapter of halmac
* @gpio_func : gpio function
* @enable : function is enable(1) or disable(0)
* Author : LIN YONG-CHING
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_get_func_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func, u8 *enable)
{
u32 list_size;
u32 cur_func;
u32 gpio_id;
enum halmac_ret_status status;
const struct halmac_gpio_pimux_list *list = NULL;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = get_pinmux_list_8822c(adapter, gpio_func, &list, &list_size,
&gpio_id);
if (status != HALMAC_RET_SUCCESS)
return status;
status = pinmux_parser_88xx(adapter, list, list_size, gpio_id,
&cur_func);
if (status != HALMAC_RET_SUCCESS)
return status;
switch (gpio_func) {
case HALMAC_GPIO_FUNC_WL_LED:
*enable = (cur_func == HALMAC_WL_LED) ? 1 : 0;
break;
case HALMAC_GPIO_FUNC_SDIO_INT:
*enable = (cur_func == HALMAC_SDIO_INT) ? 1 : 0;
break;
case HALMAC_GPIO_FUNC_BT_HOST_WAKE1:
case HALMAC_GPIO_FUNC_BT_DEV_WAKE1:
*enable = (cur_func == HALMAC_GPIO13_14_WL_CTRL_EN) ? 1 : 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_0:
case HALMAC_GPIO_FUNC_SW_IO_1:
case HALMAC_GPIO_FUNC_SW_IO_2:
case HALMAC_GPIO_FUNC_SW_IO_3:
case HALMAC_GPIO_FUNC_SW_IO_4:
case HALMAC_GPIO_FUNC_SW_IO_5:
case HALMAC_GPIO_FUNC_SW_IO_6:
case HALMAC_GPIO_FUNC_SW_IO_7:
case HALMAC_GPIO_FUNC_SW_IO_8:
case HALMAC_GPIO_FUNC_SW_IO_9:
case HALMAC_GPIO_FUNC_SW_IO_10:
case HALMAC_GPIO_FUNC_SW_IO_11:
case HALMAC_GPIO_FUNC_SW_IO_12:
case HALMAC_GPIO_FUNC_SW_IO_13:
case HALMAC_GPIO_FUNC_SW_IO_14:
case HALMAC_GPIO_FUNC_SW_IO_15:
*enable = (cur_func == HALMAC_SW_IO) ? 1 : 0;
break;
default:
*enable = 0;
return HALMAC_RET_GET_PINMUX_ERR;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* pinmux_set_func_8822c() -set gpio function
* @adapter : the adapter of halmac
* @gpio_func : gpio function
* Author : LIN YONG-CHING
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_set_func_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func)
{
u32 list_size;
u32 gpio_id;
enum halmac_ret_status status;
const struct halmac_gpio_pimux_list *list = NULL;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MSG_TRACE("[TRACE]func name : %d\n", gpio_func);
status = chk_pinmux_valid_8822c(adapter, gpio_func);
if (status != HALMAC_RET_SUCCESS)
return status;
status = get_pinmux_list_8822c(adapter, gpio_func, &list, &list_size,
&gpio_id);
if (status != HALMAC_RET_SUCCESS)
return status;
status = pinmux_switch_88xx(adapter, list, list_size, gpio_id,
gpio_func);
if (status != HALMAC_RET_SUCCESS)
return status;
status = pinmux_record_88xx(adapter, gpio_func, 1);
if (status != HALMAC_RET_SUCCESS)
return status;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* pinmux_free_func_8822c() -free locked gpio function
* @adapter : the adapter of halmac
* @gpio_func : gpio function
* Author : LIN YONG-CHING
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_free_func_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func)
{
struct halmac_pinmux_info *info = &adapter->pinmux_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (gpio_func) {
case HALMAC_GPIO_FUNC_SW_IO_0:
info->sw_io_0 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_1:
info->sw_io_1 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_2:
info->sw_io_2 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_3:
info->sw_io_3 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_4:
info->sw_io_4 = 0;
info->sdio_int = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_5:
info->sw_io_5 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_6:
info->sw_io_6 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_7:
info->sw_io_7 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_8:
case HALMAC_GPIO_FUNC_WL_LED:
info->sw_io_8 = 0;
info->wl_led = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_9:
info->sw_io_9 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_10:
case HALMAC_GPIO_FUNC_SDIO_INT:
info->sw_io_10 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_11:
info->sw_io_11 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_12:
info->sw_io_12 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_13:
case HALMAC_GPIO_FUNC_BT_DEV_WAKE1:
info->bt_dev_wake = 0;
info->sw_io_13 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_14:
case HALMAC_GPIO_FUNC_BT_HOST_WAKE1:
info->bt_host_wake = 0;
info->sw_io_14 = 0;
break;
case HALMAC_GPIO_FUNC_SW_IO_15:
info->sw_io_15 = 0;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
PLTFM_MSG_TRACE("[TRACE]func : %X\n", gpio_func);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_pinmux_list_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func,
const struct halmac_gpio_pimux_list **list,
u32 *list_size, u32 *gpio_id)
{
switch (gpio_func) {
case HALMAC_GPIO_FUNC_SW_IO_0:
*list = PINMUX_LIST_GPIO0_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO0_8822C);
*gpio_id = HALMAC_GPIO0;
break;
case HALMAC_GPIO_FUNC_SW_IO_1:
*list = PINMUX_LIST_GPIO1_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO1_8822C);
*gpio_id = HALMAC_GPIO1;
break;
case HALMAC_GPIO_FUNC_SW_IO_2:
*list = PINMUX_LIST_GPIO2_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO2_8822C);
*gpio_id = HALMAC_GPIO2;
break;
case HALMAC_GPIO_FUNC_SW_IO_3:
*list = PINMUX_LIST_GPIO3_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO3_8822C);
*gpio_id = HALMAC_GPIO3;
break;
case HALMAC_GPIO_FUNC_SW_IO_4:
*list = PINMUX_LIST_GPIO4_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO4_8822C);
*gpio_id = HALMAC_GPIO4;
break;
case HALMAC_GPIO_FUNC_SW_IO_5:
*list = PINMUX_LIST_GPIO5_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO5_8822C);
*gpio_id = HALMAC_GPIO5;
break;
case HALMAC_GPIO_FUNC_SW_IO_6:
*list = PINMUX_LIST_GPIO6_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO6_8822C);
*gpio_id = HALMAC_GPIO6;
break;
case HALMAC_GPIO_FUNC_SW_IO_7:
*list = PINMUX_LIST_GPIO7_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO7_8822C);
*gpio_id = HALMAC_GPIO7;
break;
case HALMAC_GPIO_FUNC_SW_IO_8:
case HALMAC_GPIO_FUNC_WL_LED:
*list = PINMUX_LIST_GPIO8_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO8_8822C);
*gpio_id = HALMAC_GPIO8;
break;
case HALMAC_GPIO_FUNC_SW_IO_9:
*list = PINMUX_LIST_GPIO9_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO9_8822C);
*gpio_id = HALMAC_GPIO9;
break;
case HALMAC_GPIO_FUNC_SW_IO_10:
case HALMAC_GPIO_FUNC_SDIO_INT:
*list = PINMUX_LIST_GPIO10_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO10_8822C);
*gpio_id = HALMAC_GPIO10;
break;
case HALMAC_GPIO_FUNC_SW_IO_11:
*list = PINMUX_LIST_GPIO11_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO11_8822C);
*gpio_id = HALMAC_GPIO11;
break;
case HALMAC_GPIO_FUNC_SW_IO_12:
*list = PINMUX_LIST_GPIO12_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO12_8822C);
*gpio_id = HALMAC_GPIO12;
break;
case HALMAC_GPIO_FUNC_SW_IO_13:
case HALMAC_GPIO_FUNC_BT_DEV_WAKE1:
*list = PINMUX_LIST_GPIO13_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO13_8822C);
*gpio_id = HALMAC_GPIO13;
break;
case HALMAC_GPIO_FUNC_SW_IO_14:
case HALMAC_GPIO_FUNC_BT_HOST_WAKE1:
*list = PINMUX_LIST_GPIO14_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO14_8822C);
*gpio_id = HALMAC_GPIO14;
break;
case HALMAC_GPIO_FUNC_SW_IO_15:
*list = PINMUX_LIST_GPIO15_8822C;
*list_size = ARRAY_SIZE(PINMUX_LIST_GPIO15_8822C);
*gpio_id = HALMAC_GPIO15;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
chk_pinmux_valid_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func)
{
struct halmac_pinmux_info *info = &adapter->pinmux_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
switch (gpio_func) {
case HALMAC_GPIO_FUNC_SW_IO_0:
if (info->sw_io_0 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_1:
if (info->sw_io_1 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_2:
if (info->sw_io_2 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_3:
if (info->sw_io_3 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_4:
if (info->sw_io_4 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_5:
if (info->sw_io_5 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_6:
if (info->sw_io_6 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_7:
if (info->sw_io_7 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_8:
if (info->sw_io_8 == 1 || info->wl_led == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_WL_LED:
if (info->sw_io_8 == 1 || info->wl_led == 1 ||
info->bt_dev_wake == 1 || info->bt_host_wake == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_9:
if (info->sw_io_9 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_10:
case HALMAC_GPIO_FUNC_SDIO_INT:
if (info->sw_io_10 == 1 || info->sdio_int == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_11:
if (info->sw_io_11 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_12:
if (info->sw_io_12 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_13:
if (info->sw_io_13 == 1 || info->bt_dev_wake == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_BT_DEV_WAKE1:
if (info->sw_io_13 == 1 || info->bt_dev_wake == 1 ||
info->wl_led == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_14:
if (info->sw_io_14 == 1 || info->bt_host_wake == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_BT_HOST_WAKE1:
if (info->sw_io_14 == 1 || info->bt_host_wake == 1 ||
info->wl_led == 1)
status = HALMAC_RET_PINMUX_USED;
break;
case HALMAC_GPIO_FUNC_SW_IO_15:
if (info->sw_io_15 == 1)
status = HALMAC_RET_PINMUX_USED;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
PLTFM_MSG_TRACE("[TRACE]chk_pinmux_valid func : %X status : %X\n",
gpio_func, status);
return status;
}
#endif /* HALMAC_8822C_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_gpio_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_GPIO_8822C_H_
#define _HALMAC_GPIO_8822C_H_
#include "../../halmac_api.h"
#include "../../halmac_gpio_cmd.h"
#if HALMAC_8822C_SUPPORT
enum halmac_ret_status
pinmux_get_func_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func, u8 *enable);
enum halmac_ret_status
pinmux_set_func_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func);
enum halmac_ret_status
pinmux_free_func_8822c(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func);
#endif /* HALMAC_8822C_SUPPORT */
#endif/* _HALMAC_GPIO_8822C_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_init_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_init_8822c.h"
#include "halmac_8822c_cfg.h"
#if HALMAC_PCIE_SUPPORT
#include "halmac_pcie_8822c.h"
#endif
#if HALMAC_SDIO_SUPPORT
#include "halmac_sdio_8822c.h"
#include "../halmac_sdio_88xx.h"
#endif
#if HALMAC_USB_SUPPORT
#include "halmac_usb_8822c.h"
#endif
#include "halmac_gpio_8822c.h"
#include "halmac_common_8822c.h"
#include "halmac_cfg_wmac_8822c.h"
#include "../halmac_common_88xx.h"
#include "../halmac_init_88xx.h"
#include "../halmac_cfg_wmac_88xx.h"
#if HALMAC_8822C_SUPPORT
#define SYS_FUNC_EN 0xD8
#define RSVD_PG_DRV_NUM 16
#define RSVD_PG_H2C_EXTRAINFO_NUM 24
#define RSVD_PG_H2C_STATICINFO_NUM 8
#define RSVD_PG_H2CQ_NUM 8
#define RSVD_PG_CPU_INSTRUCTION_NUM 0
#define RSVD_PG_FW_TXBUF_NUM 4
#define RSVD_PG_CSIBUF_NUM 50
#define RSVD_PG_DLLB_NUM (TX_FIFO_SIZE_8822C / 3 >> \
TX_PAGE_SIZE_SHIFT_88XX)
#define MAC_TRX_ENABLE (BIT_HCI_TXDMA_EN | BIT_HCI_RXDMA_EN | BIT_TXDMA_EN | \
BIT_RXDMA_EN | BIT_PROTOCOL_EN | BIT_SCHEDULE_EN | \
BIT_MACTXEN | BIT_MACRXEN)
#define WLAN_TXQ_RPT_EN 0x1F
#define BLK_DESC_NUM 0x3
#define RX_DLK_TIME 0x14
#define WLAN_SLOT_TIME 0x09
#define WLAN_PIFS_TIME 0x1C
#define WLAN_SIFS_CCK_CONT_TX 0x0A
#define WLAN_SIFS_OFDM_CONT_TX 0x0E
#define WLAN_SIFS_CCK_TRX 0x0A
#define WLAN_SIFS_OFDM_TRX 0x10
#define WLAN_NAV_MAX 0xC8
#define WLAN_RDG_NAV 0x05
#define WLAN_TXOP_NAV 0x1B
#define WLAN_CCK_RX_TSF 0x30
#define WLAN_OFDM_RX_TSF 0x30
#define WLAN_TBTT_PROHIBIT 0x04 /* unit : 32us */
#define WLAN_TBTT_HOLD_TIME 0x064 /* unit : 32us */
#define WLAN_DRV_EARLY_INT 0x04
#define WLAN_BCN_CTRL_CLT0 0x10
#define WLAN_BCN_DMA_TIME 0x02
#define WLAN_BCN_MAX_ERR 0xFF
#define WLAN_SIFS_CCK_DUR_TUNE 0x0A
#define WLAN_SIFS_OFDM_DUR_TUNE 0x10
#define WLAN_SIFS_CCK_CTX 0x0A
#define WLAN_SIFS_CCK_IRX 0x0A
#define WLAN_SIFS_OFDM_CTX 0x0E
#define WLAN_SIFS_OFDM_IRX 0x0E
#define WLAN_EIFS_DUR_TUNE 0x40
#define WLAN_EDCA_VO_PARAM 0x002FA226
#define WLAN_EDCA_VI_PARAM 0x005EA328
#define WLAN_EDCA_BE_PARAM 0x005EA42B
#define WLAN_EDCA_BK_PARAM 0x0000A44F
#define WLAN_RX_FILTER0 0xFFFFFFFF
#define WLAN_RX_FILTER2 0xFFFF
#define WLAN_RCR_CFG 0xE410220E
#define WLAN_RXPKT_MAX_SZ 12288
#define WLAN_RXPKT_MAX_SZ_512 (WLAN_RXPKT_MAX_SZ >> 9)
#define WLAN_AMPDU_MAX_TIME 0x70
#define WLAN_RTS_LEN_TH 0xFF
#define WLAN_RTS_TX_TIME_TH 0x08
#define WLAN_MAX_AGG_PKT_LIMIT 0x3F
#define WLAN_RTS_MAX_AGG_PKT_LIMIT 0x20
#define WLAN_PRE_TXCNT_TIME_TH 0x1E4
#define WALN_FAST_EDCA_VO_TH 0x06
#define WLAN_FAST_EDCA_VI_TH 0x06
#define WLAN_FAST_EDCA_BE_TH 0x06
#define WLAN_FAST_EDCA_BK_TH 0x06
#define WLAN_BAR_RETRY_LIMIT 0x01
#define WLAN_BAR_ACK_TYPE 0x05
#define WLAN_RA_TRY_RATE_AGG_LIMIT 0x08
#define WLAN_RESP_TXRATE 0x84
#define WLAN_ACK_TO 0x21
#define WLAN_ACK_TO_CCK 0x6A
#define WLAN_DATA_RATE_FB_CNT_1_4 0x01000000
#define WLAN_DATA_RATE_FB_CNT_5_8 0x08070504
#define WLAN_RTS_RATE_FB_CNT_5_8 0x08070504
#define WLAN_DATA_RATE_FB_RATE0 0xFE01F010
#define WLAN_DATA_RATE_FB_RATE0_H 0x40000000
#define WLAN_RTS_RATE_FB_RATE1 0x003FF010
#define WLAN_RTS_RATE_FB_RATE1_H 0x40000000
#define WLAN_RTS_RATE_FB_RATE4 0x0600F010
#define WLAN_RTS_RATE_FB_RATE4_H 0x400003E0
#define WLAN_RTS_RATE_FB_RATE5 0x0600F015
#define WLAN_RTS_RATE_FB_RATE5_H 0x000000E0
#define WLAN_TX_FUNC_CFG1 0x30
#define WLAN_TX_FUNC_CFG2 0x30
#define WLAN_MAC_OPT_NORM_FUNC1 0x98
#define WLAN_MAC_OPT_LB_FUNC1 0x80
#define WLAN_MAC_OPT_FUNC2 0xB1810041
#define WLAN_SIFS_CFG (WLAN_SIFS_CCK_CONT_TX | \
(WLAN_SIFS_OFDM_CONT_TX << BIT_SHIFT_SIFS_OFDM_CTX) | \
(WLAN_SIFS_CCK_TRX << BIT_SHIFT_SIFS_CCK_TRX) | \
(WLAN_SIFS_OFDM_TRX << BIT_SHIFT_SIFS_OFDM_TRX))
#define WLAN_SIFS_DUR_TUNE (WLAN_SIFS_CCK_DUR_TUNE | \
(WLAN_SIFS_OFDM_DUR_TUNE << 8))
#define WLAN_TBTT_TIME (WLAN_TBTT_PROHIBIT |\
(WLAN_TBTT_HOLD_TIME << BIT_SHIFT_TBTT_HOLD_TIME_AP))
#define WLAN_NAV_CFG (WLAN_RDG_NAV | (WLAN_TXOP_NAV << 16))
#define WLAN_RX_TSF_CFG (WLAN_CCK_RX_TSF | (WLAN_OFDM_RX_TSF) << 8)
#if HALMAC_PLATFORM_WINDOWS
/*SDIO RQPN Mapping for Windows, extra queue is not implemented in Driver code*/
static struct halmac_rqpn HALMAC_RQPN_SDIO_8822C[] = {
/* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
{HALMAC_TRX_MODE_NORMAL,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_TRXSHARE,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_WMM,
HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_P2P,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_DELAY_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
};
#else
/*SDIO RQPN Mapping*/
static struct halmac_rqpn HALMAC_RQPN_SDIO_8822C[] = {
/* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
{HALMAC_TRX_MODE_NORMAL,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_TRXSHARE,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_WMM,
HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_P2P,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_DELAY_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
};
#endif
/*PCIE RQPN Mapping*/
static struct halmac_rqpn HALMAC_RQPN_PCIE_8822C[] = {
/* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
{HALMAC_TRX_MODE_NORMAL,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_TRXSHARE,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_WMM,
HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_P2P,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_DELAY_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
};
/*USB 2 Bulkout RQPN Mapping*/
static struct halmac_rqpn HALMAC_RQPN_2BULKOUT_8822C[] = {
/* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
{HALMAC_TRX_MODE_NORMAL,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_TRXSHARE,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_WMM,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_HQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_P2P,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_LOOPBACK,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_DELAY_LOOPBACK,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
};
/*USB 3 Bulkout RQPN Mapping*/
static struct halmac_rqpn HALMAC_RQPN_3BULKOUT_8822C[] = {
/* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
{HALMAC_TRX_MODE_NORMAL,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_TRXSHARE,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_WMM,
HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_P2P,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_LOOPBACK,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_DELAY_LOOPBACK,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_HQ, HALMAC_MAP2_HQ},
};
/*USB 4 Bulkout RQPN Mapping*/
static struct halmac_rqpn HALMAC_RQPN_4BULKOUT_8822C[] = {
/* { mode, vo_map, vi_map, be_map, bk_map, mg_map, hi_map } */
{HALMAC_TRX_MODE_NORMAL,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_TRXSHARE,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_WMM,
HALMAC_MAP2_HQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_NQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_P2P,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
{HALMAC_TRX_MODE_DELAY_LOOPBACK,
HALMAC_MAP2_NQ, HALMAC_MAP2_NQ, HALMAC_MAP2_LQ, HALMAC_MAP2_LQ,
HALMAC_MAP2_EXQ, HALMAC_MAP2_HQ},
};
#if HALMAC_PLATFORM_WINDOWS
/*SDIO Page Number*/
static struct halmac_pg_num HALMAC_PG_NUM_SDIO_8822C[] = {
/* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
{HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_TRXSHARE, 32, 32, 32, 0, 1},
{HALMAC_TRX_MODE_WMM, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_P2P, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 0, 1},
};
#else
/*SDIO Page Number*/
static struct halmac_pg_num HALMAC_PG_NUM_SDIO_8822C[] = {
/* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
{HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_TRXSHARE, 32, 32, 32, 32, 1},
{HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 1},
};
#endif
/*PCIE Page Number*/
static struct halmac_pg_num HALMAC_PG_NUM_PCIE_8822C[] = {
/* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
{HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 1},
};
/*USB 2 Bulkout Page Number*/
static struct halmac_pg_num HALMAC_PG_NUM_2BULKOUT_8822C[] = {
/* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
{HALMAC_TRX_MODE_NORMAL, 64, 64, 0, 0, 1},
{HALMAC_TRX_MODE_TRXSHARE, 64, 64, 0, 0, 1},
{HALMAC_TRX_MODE_WMM, 64, 64, 0, 0, 1},
{HALMAC_TRX_MODE_P2P, 64, 64, 0, 0, 1},
{HALMAC_TRX_MODE_LOOPBACK, 64, 64, 0, 0, 1},
{HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 0, 0, 1},
};
/*USB 3 Bulkout Page Number*/
static struct halmac_pg_num HALMAC_PG_NUM_3BULKOUT_8822C[] = {
/* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
{HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_WMM, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_P2P, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 0, 1},
{HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 0, 1},
};
/*USB 4 Bulkout Page Number*/
static struct halmac_pg_num HALMAC_PG_NUM_4BULKOUT_8822C[] = {
/* { mode, hq_num, nq_num, lq_num, exq_num, gap_num} */
{HALMAC_TRX_MODE_NORMAL, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_TRXSHARE, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_WMM, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_P2P, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_LOOPBACK, 64, 64, 64, 64, 1},
{HALMAC_TRX_MODE_DELAY_LOOPBACK, 64, 64, 64, 64, 1},
};
static enum halmac_ret_status
txdma_queue_mapping_8822c(struct halmac_adapter *adapter,
enum halmac_trx_mode mode);
static enum halmac_ret_status
priority_queue_cfg_8822c(struct halmac_adapter *adapter,
enum halmac_trx_mode mode);
static enum halmac_ret_status
set_trx_fifo_info_8822c(struct halmac_adapter *adapter,
enum halmac_trx_mode mode);
static void
init_txq_ctrl_8822c(struct halmac_adapter *adapter);
static void
init_sifs_ctrl_8822c(struct halmac_adapter *adapter);
static void
init_rate_fallback_ctrl_8822c(struct halmac_adapter *adapter);
static enum halmac_ret_status
init_xtal_aac(struct halmac_adapter *adapter);
enum halmac_ret_status
mount_api_8822c(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
adapter->chip_id = HALMAC_CHIP_ID_8822C;
adapter->hw_cfg_info.efuse_size = EFUSE_SIZE_8822C;
adapter->hw_cfg_info.eeprom_size = EEPROM_SIZE_8822C;
adapter->hw_cfg_info.bt_efuse_size = BT_EFUSE_SIZE_8822C;
adapter->hw_cfg_info.prtct_efuse_size = PRTCT_EFUSE_SIZE_8822C;
adapter->hw_cfg_info.cam_entry_num = SEC_CAM_NUM_8822C;
adapter->hw_cfg_info.tx_fifo_size = TX_FIFO_SIZE_8822C;
adapter->hw_cfg_info.rx_fifo_size = RX_FIFO_SIZE_8822C;
adapter->hw_cfg_info.ac_oqt_size = OQT_ENTRY_AC_8822C;
adapter->hw_cfg_info.non_ac_oqt_size = OQT_ENTRY_NOAC_8822C;
adapter->hw_cfg_info.usb_txagg_num = BLK_DESC_NUM;
adapter->txff_alloc.rsvd_drv_pg_num = RSVD_PG_DRV_NUM;
api->halmac_init_trx_cfg = init_trx_cfg_8822c;
api->halmac_init_system_cfg = init_system_cfg_8822c;
api->halmac_init_protocol_cfg = init_protocol_cfg_8822c;
api->halmac_init_h2c = init_h2c_8822c;
api->halmac_pinmux_get_func = pinmux_get_func_8822c;
api->halmac_pinmux_set_func = pinmux_set_func_8822c;
api->halmac_pinmux_free_func = pinmux_free_func_8822c;
api->halmac_get_hw_value = get_hw_value_8822c;
api->halmac_set_hw_value = set_hw_value_8822c;
api->halmac_cfg_drv_info = cfg_drv_info_8822c;
api->halmac_fill_txdesc_checksum = fill_txdesc_check_sum_8822c;
api->halmac_init_low_pwr = init_low_pwr_8822c;
api->halmac_pre_init_system_cfg = pre_init_system_cfg_8822c;
api->halmac_init_wmac_cfg = init_wmac_cfg_8822c;
api->halmac_init_edca_cfg = init_edca_cfg_8822c;
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
#if HALMAC_SDIO_SUPPORT
adapter->sdio_hw_info.tx_addr_format = HALMAC_SDIO_AGG_MODE;
api->halmac_mac_power_switch = mac_pwr_switch_sdio_8822c;
api->halmac_phy_cfg = phy_cfg_sdio_8822c;
api->halmac_pcie_switch = pcie_switch_sdio_8822c;
api->halmac_interface_integration_tuning = intf_tun_sdio_8822c;
api->halmac_tx_allowed_sdio = tx_allowed_sdio_8822c;
api->halmac_get_sdio_tx_addr = get_sdio_tx_addr_8822c;
api->halmac_reg_read_8 = reg_r8_sdio_8822c;
api->halmac_reg_write_8 = reg_w8_sdio_8822c;
api->halmac_reg_read_16 = reg_r16_sdio_8822c;
api->halmac_reg_write_16 = reg_w16_sdio_8822c;
api->halmac_reg_read_32 = reg_r32_sdio_8822c;
api->halmac_reg_write_32 = reg_w32_sdio_8822c;
adapter->sdio_fs.macid_map_size = MACID_MAX_8822C << 1;
if (!adapter->sdio_fs.macid_map) {
adapter->sdio_fs.macid_map =
(u8 *)PLTFM_MALLOC(adapter->sdio_fs.macid_map_size);
if (!adapter->sdio_fs.macid_map)
PLTFM_MSG_ERR("[ERR]mac id map malloc!!\n");
}
#endif
} else if (adapter->intf == HALMAC_INTERFACE_USB) {
#if HALMAC_USB_SUPPORT
api->halmac_mac_power_switch = mac_pwr_switch_usb_8822c;
api->halmac_phy_cfg = phy_cfg_usb_8822c;
api->halmac_pcie_switch = pcie_switch_usb_8822c;
api->halmac_interface_integration_tuning = intf_tun_usb_8822c;
#endif
} else if (adapter->intf == HALMAC_INTERFACE_PCIE) {
#if HALMAC_PCIE_SUPPORT
api->halmac_mac_power_switch = mac_pwr_switch_pcie_8822c;
api->halmac_phy_cfg = phy_cfg_pcie_8822c;
api->halmac_pcie_switch = pcie_switch_8822c;
api->halmac_interface_integration_tuning = intf_tun_pcie_8822c;
api->halmac_cfgspc_set_pcie = cfgspc_set_pcie_8822c;
#endif
} else {
PLTFM_MSG_ERR("[ERR]Undefined IC\n");
return HALMAC_RET_CHIP_NOT_SUPPORT;
}
return HALMAC_RET_SUCCESS;
}
/**
* init_trx_cfg_8822c() - config trx dma register
* @adapter : the adapter of halmac
* @mode : trx mode selection
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_trx_cfg_8822c(struct halmac_adapter *adapter, enum halmac_trx_mode mode)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
u8 en_fwff;
u16 value16;
adapter->trx_mode = mode;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = txdma_queue_mapping_8822c(adapter, mode);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]queue mapping\n");
return status;
}
en_fwff = HALMAC_REG_R8(REG_WMAC_FWPKT_CR) & BIT_FWEN;
if (en_fwff) {
HALMAC_REG_W8_CLR(REG_WMAC_FWPKT_CR, BIT_FWEN);
if (fwff_is_empty_88xx(adapter) != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]fwff is not empty\n");
}
value8 = 0;
HALMAC_REG_W8(REG_CR, value8);
value16 = HALMAC_REG_R16(REG_FWFF_PKT_INFO);
HALMAC_REG_W16(REG_FWFF_CTRL, value16);
value8 = MAC_TRX_ENABLE;
HALMAC_REG_W8(REG_CR, value8);
if (en_fwff)
HALMAC_REG_W8_SET(REG_WMAC_FWPKT_CR, BIT_FWEN);
HALMAC_REG_W32(REG_H2CQ_CSR, BIT(31));
status = priority_queue_cfg_8822c(adapter, mode);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]priority queue cfg\n");
return status;
}
status = init_h2c_8822c(adapter);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]init h2cq!\n");
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
txdma_queue_mapping_8822c(struct halmac_adapter *adapter,
enum halmac_trx_mode mode)
{
u16 value16;
struct halmac_rqpn *cur_rqpn_sel = NULL;
enum halmac_ret_status status;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
cur_rqpn_sel = HALMAC_RQPN_SDIO_8822C;
} else if (adapter->intf == HALMAC_INTERFACE_PCIE) {
cur_rqpn_sel = HALMAC_RQPN_PCIE_8822C;
} else if (adapter->intf == HALMAC_INTERFACE_USB) {
if (adapter->bulkout_num == 2) {
cur_rqpn_sel = HALMAC_RQPN_2BULKOUT_8822C;
} else if (adapter->bulkout_num == 3) {
cur_rqpn_sel = HALMAC_RQPN_3BULKOUT_8822C;
} else if (adapter->bulkout_num == 4) {
cur_rqpn_sel = HALMAC_RQPN_4BULKOUT_8822C;
} else {
PLTFM_MSG_ERR("[ERR]interface not support\n");
return HALMAC_RET_NOT_SUPPORT;
}
} else {
return HALMAC_RET_NOT_SUPPORT;
}
status = rqpn_parser_88xx(adapter, mode, cur_rqpn_sel);
if (status != HALMAC_RET_SUCCESS)
return status;
value16 = 0;
value16 |= BIT_TXDMA_HIQ_MAP(adapter->pq_map[HALMAC_PQ_MAP_HI]);
value16 |= BIT_TXDMA_MGQ_MAP(adapter->pq_map[HALMAC_PQ_MAP_MG]);
value16 |= BIT_TXDMA_BKQ_MAP(adapter->pq_map[HALMAC_PQ_MAP_BK]);
value16 |= BIT_TXDMA_BEQ_MAP(adapter->pq_map[HALMAC_PQ_MAP_BE]);
value16 |= BIT_TXDMA_VIQ_MAP(adapter->pq_map[HALMAC_PQ_MAP_VI]);
value16 |= BIT_TXDMA_VOQ_MAP(adapter->pq_map[HALMAC_PQ_MAP_VO]);
HALMAC_REG_W16(REG_TXDMA_PQ_MAP, value16);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
priority_queue_cfg_8822c(struct halmac_adapter *adapter,
enum halmac_trx_mode mode)
{
u8 transfer_mode = 0;
u8 value8;
u32 cnt;
struct halmac_txff_allocation *txff_info = &adapter->txff_alloc;
enum halmac_ret_status status;
struct halmac_pg_num *cur_pg_num = NULL;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
status = set_trx_fifo_info_8822c(adapter, mode);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]set trx fifo!!\n");
return status;
}
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
cur_pg_num = HALMAC_PG_NUM_SDIO_8822C;
} else if (adapter->intf == HALMAC_INTERFACE_PCIE) {
cur_pg_num = HALMAC_PG_NUM_PCIE_8822C;
} else if (adapter->intf == HALMAC_INTERFACE_USB) {
if (adapter->bulkout_num == 2) {
cur_pg_num = HALMAC_PG_NUM_2BULKOUT_8822C;
} else if (adapter->bulkout_num == 3) {
cur_pg_num = HALMAC_PG_NUM_3BULKOUT_8822C;
} else if (adapter->bulkout_num == 4) {
cur_pg_num = HALMAC_PG_NUM_4BULKOUT_8822C;
} else {
PLTFM_MSG_ERR("[ERR]interface not support\n");
return HALMAC_RET_NOT_SUPPORT;
}
} else {
return HALMAC_RET_NOT_SUPPORT;
}
status = pg_num_parser_88xx(adapter, mode, cur_pg_num);
if (status != HALMAC_RET_SUCCESS)
return status;
PLTFM_MSG_TRACE("[TRACE]Set FIFO page\n");
HALMAC_REG_W16(REG_FIFOPAGE_INFO_1, txff_info->high_queue_pg_num);
HALMAC_REG_W16(REG_FIFOPAGE_INFO_2, txff_info->low_queue_pg_num);
HALMAC_REG_W16(REG_FIFOPAGE_INFO_3, txff_info->normal_queue_pg_num);
HALMAC_REG_W16(REG_FIFOPAGE_INFO_4, txff_info->extra_queue_pg_num);
HALMAC_REG_W16(REG_FIFOPAGE_INFO_5, txff_info->pub_queue_pg_num);
HALMAC_REG_W32_SET(REG_RQPN_CTRL_2, BIT(31));
adapter->sdio_fs.hiq_pg_num = txff_info->high_queue_pg_num;
adapter->sdio_fs.miq_pg_num = txff_info->normal_queue_pg_num;
adapter->sdio_fs.lowq_pg_num = txff_info->low_queue_pg_num;
adapter->sdio_fs.pubq_pg_num = txff_info->pub_queue_pg_num;
adapter->sdio_fs.exq_pg_num = txff_info->extra_queue_pg_num;
HALMAC_REG_W16(REG_FIFOPAGE_CTRL_2, txff_info->rsvd_boundary);
HALMAC_REG_W16(REG_WMAC_CSIDMA_CFG, txff_info->rsvd_csibuf_addr);
HALMAC_REG_W8_SET(REG_FWHW_TXQ_CTRL + 2, BIT(4));
/*20170411 Soar*/
/* SDIO sometimes use two CMD52 to do HALMAC_REG_W16 */
/* and may cause a mismatch between HW status and Reg value. */
/* A patch is to write high byte first, suggested by Argis */
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
value8 = (u8)(txff_info->rsvd_boundary >> 8 & 0xFF);
HALMAC_REG_W8(REG_BCNQ_BDNY_V1 + 1, value8);
value8 = (u8)(txff_info->rsvd_boundary & 0xFF);
HALMAC_REG_W8(REG_BCNQ_BDNY_V1, value8);
} else {
HALMAC_REG_W16(REG_BCNQ_BDNY_V1, txff_info->rsvd_boundary);
}
HALMAC_REG_W16(REG_FIFOPAGE_CTRL_2 + 2, txff_info->rsvd_boundary);
/*20170411 Soar*/
/* SDIO sometimes use two CMD52 to do HALMAC_REG_W16 */
/* and may cause a mismatch between HW status and Reg value. */
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
value8 = (u8)(txff_info->rsvd_boundary >> 8 & 0xFF);
HALMAC_REG_W8(REG_BCNQ1_BDNY_V1 + 1, value8);
value8 = (u8)(txff_info->rsvd_boundary & 0xFF);
HALMAC_REG_W8(REG_BCNQ1_BDNY_V1, value8);
} else {
HALMAC_REG_W16(REG_BCNQ1_BDNY_V1, txff_info->rsvd_boundary);
}
HALMAC_REG_W32(REG_RXFF_BNDY,
adapter->hw_cfg_info.rx_fifo_size -
C2H_PKT_BUF_88XX - 1);
if (adapter->intf == HALMAC_INTERFACE_USB) {
value8 = HALMAC_REG_R8(REG_AUTO_LLT_V1);
value8 &= ~(BIT_MASK_BLK_DESC_NUM << BIT_SHIFT_BLK_DESC_NUM);
value8 |= (BLK_DESC_NUM << BIT_SHIFT_BLK_DESC_NUM);
HALMAC_REG_W8(REG_AUTO_LLT_V1, value8);
HALMAC_REG_W8(REG_AUTO_LLT_V1 + 3, BLK_DESC_NUM);
HALMAC_REG_W8_SET(REG_TXDMA_OFFSET_CHK + 1, BIT(1));
}
HALMAC_REG_W8_SET(REG_AUTO_LLT_V1, BIT_AUTO_INIT_LLT_V1);
cnt = 1000;
while (HALMAC_REG_R8(REG_AUTO_LLT_V1) & BIT_AUTO_INIT_LLT_V1) {
cnt--;
if (cnt == 0)
return HALMAC_RET_INIT_LLT_FAIL;
}
if (mode == HALMAC_TRX_MODE_DELAY_LOOPBACK) {
transfer_mode = HALMAC_TRNSFER_LOOPBACK_DELAY;
HALMAC_REG_W16(REG_WMAC_LBK_BUF_HD_V1,
adapter->txff_alloc.rsvd_boundary);
} else if (mode == HALMAC_TRX_MODE_LOOPBACK) {
transfer_mode = HALMAC_TRNSFER_LOOPBACK_DIRECT;
} else {
transfer_mode = HALMAC_TRNSFER_NORMAL;
}
adapter->hw_cfg_info.trx_mode = transfer_mode;
HALMAC_REG_W8(REG_CR + 3, (u8)transfer_mode);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
set_trx_fifo_info_8822c(struct halmac_adapter *adapter,
enum halmac_trx_mode mode)
{
u16 cur_pg_addr;
u32 txff_size = TX_FIFO_SIZE_8822C;
u32 rxff_size = RX_FIFO_SIZE_8822C;
struct halmac_txff_allocation *info = &adapter->txff_alloc;
if (info->rx_fifo_exp_mode == HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK) {
txff_size = TX_FIFO_SIZE_RX_EXPAND_1BLK_8822C;
rxff_size = RX_FIFO_SIZE_RX_EXPAND_1BLK_8822C;
} else if (info->rx_fifo_exp_mode ==
HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK) {
txff_size = TX_FIFO_SIZE_RX_EXPAND_2BLK_8822C;
rxff_size = RX_FIFO_SIZE_RX_EXPAND_2BLK_8822C;
} else if (info->rx_fifo_exp_mode ==
HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK) {
txff_size = TX_FIFO_SIZE_RX_EXPAND_3BLK_8822C;
rxff_size = RX_FIFO_SIZE_RX_EXPAND_3BLK_8822C;
} else if (info->rx_fifo_exp_mode ==
HALMAC_RX_FIFO_EXPANDING_MODE_4_BLOCK) {
txff_size = TX_FIFO_SIZE_RX_EXPAND_4BLK_8822C;
rxff_size = RX_FIFO_SIZE_RX_EXPAND_4BLK_8822C;
}
if (info->la_mode != HALMAC_LA_MODE_DISABLE) {
txff_size = TX_FIFO_SIZE_LA_8822C;
rxff_size = RX_FIFO_SIZE_8822C;
}
adapter->hw_cfg_info.tx_fifo_size = txff_size;
adapter->hw_cfg_info.rx_fifo_size = rxff_size;
info->tx_fifo_pg_num = (u16)(txff_size >> TX_PAGE_SIZE_SHIFT_88XX);
info->rsvd_pg_num = info->rsvd_drv_pg_num +
RSVD_PG_H2C_EXTRAINFO_NUM +
RSVD_PG_H2C_STATICINFO_NUM +
RSVD_PG_H2CQ_NUM +
RSVD_PG_CPU_INSTRUCTION_NUM +
RSVD_PG_FW_TXBUF_NUM +
RSVD_PG_CSIBUF_NUM;
if (mode == HALMAC_TRX_MODE_DELAY_LOOPBACK)
info->rsvd_pg_num += RSVD_PG_DLLB_NUM;
if (info->rsvd_pg_num > info->tx_fifo_pg_num)
return HALMAC_RET_CFG_TXFIFO_PAGE_FAIL;
info->acq_pg_num = info->tx_fifo_pg_num - info->rsvd_pg_num;
info->rsvd_boundary = info->tx_fifo_pg_num - info->rsvd_pg_num;
cur_pg_addr = info->tx_fifo_pg_num;
cur_pg_addr -= RSVD_PG_CSIBUF_NUM;
info->rsvd_csibuf_addr = cur_pg_addr;
cur_pg_addr -= RSVD_PG_FW_TXBUF_NUM;
info->rsvd_fw_txbuf_addr = cur_pg_addr;
cur_pg_addr -= RSVD_PG_CPU_INSTRUCTION_NUM;
info->rsvd_cpu_instr_addr = cur_pg_addr;
cur_pg_addr -= RSVD_PG_H2CQ_NUM;
info->rsvd_h2cq_addr = cur_pg_addr;
cur_pg_addr -= RSVD_PG_H2C_STATICINFO_NUM;
info->rsvd_h2c_sta_info_addr = cur_pg_addr;
cur_pg_addr -= RSVD_PG_H2C_EXTRAINFO_NUM;
info->rsvd_h2c_info_addr = cur_pg_addr;
cur_pg_addr -= info->rsvd_drv_pg_num;
info->rsvd_drv_addr = cur_pg_addr;
if (mode == HALMAC_TRX_MODE_DELAY_LOOPBACK)
info->rsvd_drv_addr -= RSVD_PG_DLLB_NUM;
if (info->rsvd_boundary != info->rsvd_drv_addr)
return HALMAC_RET_CFG_TXFIFO_PAGE_FAIL;
return HALMAC_RET_SUCCESS;
}
/**
* init_system_cfg_8822c() - init system config
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_system_cfg_8822c(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 value8;
u32 tmp = 0;
u32 value32;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value32 = HALMAC_REG_R32(REG_CPU_DMEM_CON);
value32 |= (BIT_WL_PLATFORM_RST | BIT_DDMA_EN);
HALMAC_REG_W32(REG_CPU_DMEM_CON, value32);
HALMAC_REG_W8(REG_SYS_FUNC_EN + 1, SYS_FUNC_EN);
/*PHY_REQ_DELAY reg 0x1100[27:24] = 0x0C*/
value8 = (HALMAC_REG_R8(REG_CR_EXT + 3) & 0xF0) | 0x0C;
HALMAC_REG_W8(REG_CR_EXT + 3, value8);
/*disable boot-from-flash for driver's DL FW*/
tmp = HALMAC_REG_R32(REG_MCUFW_CTRL);
if (tmp & BIT_BOOT_FSPI_EN) {
HALMAC_REG_W32(REG_MCUFW_CTRL, tmp & (~BIT_BOOT_FSPI_EN));
value32 = HALMAC_REG_R32(REG_GPIO_MUXCFG) & (~BIT_FSPI_EN);
HALMAC_REG_W32(REG_GPIO_MUXCFG, value32);
}
if (adapter->chip_ver == HALMAC_CHIP_VER_B_CUT) {
value8 = HALMAC_REG_R8(REG_ANAPAR_MAC_0);
value8 = value8 & ~(BITS_LDO_VSEL);
HALMAC_REG_W8(REG_ANAPAR_MAC_0, value8);
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* init_protocol_cfg_8822c() - config protocol register
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_protocol_cfg_8822c(struct halmac_adapter *adapter)
{
u32 max_agg_num;
u32 max_rts_agg_num;
u32 value32;
u16 pre_txcnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
init_txq_ctrl_8822c(adapter);
init_sifs_ctrl_8822c(adapter);
init_rate_fallback_ctrl_8822c(adapter);
HALMAC_REG_W8(REG_AMPDU_MAX_TIME_V1, WLAN_AMPDU_MAX_TIME);
HALMAC_REG_W8_SET(REG_TX_HANG_CTRL, BIT_EN_EOF_V1);
pre_txcnt = WLAN_PRE_TXCNT_TIME_TH | BIT_EN_PRECNT;
HALMAC_REG_W8(REG_PRECNT_CTRL, (u8)(pre_txcnt & 0xFF));
HALMAC_REG_W8(REG_PRECNT_CTRL + 1, (u8)(pre_txcnt >> 8));
max_agg_num = WLAN_MAX_AGG_PKT_LIMIT;
max_rts_agg_num = WLAN_RTS_MAX_AGG_PKT_LIMIT;
value32 = WLAN_RTS_LEN_TH | (WLAN_RTS_TX_TIME_TH << 8) |
(max_agg_num << 16) | (max_rts_agg_num << 24);
HALMAC_REG_W32(REG_PROT_MODE_CTRL, value32);
HALMAC_REG_W16(REG_BAR_MODE_CTRL + 2,
WLAN_BAR_RETRY_LIMIT | WLAN_RA_TRY_RATE_AGG_LIMIT << 8);
HALMAC_REG_W8(REG_FAST_EDCA_VOVI_SETTING, WALN_FAST_EDCA_VO_TH);
HALMAC_REG_W8(REG_FAST_EDCA_VOVI_SETTING + 2, WLAN_FAST_EDCA_VI_TH);
HALMAC_REG_W8(REG_FAST_EDCA_BEBK_SETTING, WLAN_FAST_EDCA_BE_TH);
HALMAC_REG_W8(REG_FAST_EDCA_BEBK_SETTING + 2, WLAN_FAST_EDCA_BK_TH);
/*close BA parser*/
HALMAC_REG_W8_CLR(REG_LIFETIME_EN, BIT(5));
/*Bypass TXBF error protection due to sounding failure*/
value32 = HALMAC_REG_R32(REG_BF0_TIME_SETTING) & (~BIT_BF0_UPDATE_EN);
HALMAC_REG_W32(REG_BF0_TIME_SETTING, value32 | BIT_BF0_TIMER_EN);
value32 = HALMAC_REG_R32(REG_BF1_TIME_SETTING) & (~BIT_BF1_UPDATE_EN);
HALMAC_REG_W32(REG_BF1_TIME_SETTING, value32 | BIT_BF1_TIMER_EN);
value32 = HALMAC_REG_R32(REG_BF_TIMEOUT_EN) & (~BIT_BF0_TIMEOUT_EN) &
(~BIT_BF1_TIMEOUT_EN);
HALMAC_REG_W32(REG_BF_TIMEOUT_EN, value32);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* init_h2c_8822c() - config h2c packet buffer
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_h2c_8822c(struct halmac_adapter *adapter)
{
u8 value8;
u32 value32;
u32 h2cq_addr;
u32 h2cq_size;
struct halmac_txff_allocation *txff_info = &adapter->txff_alloc;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
h2cq_addr = txff_info->rsvd_h2cq_addr << TX_PAGE_SIZE_SHIFT_88XX;
h2cq_size = RSVD_PG_H2CQ_NUM << TX_PAGE_SIZE_SHIFT_88XX;
value32 = HALMAC_REG_R32(REG_H2C_HEAD);
value32 = (value32 & 0xFFFC0000) | h2cq_addr;
HALMAC_REG_W32(REG_H2C_HEAD, value32);
value32 = HALMAC_REG_R32(REG_H2C_READ_ADDR);
value32 = (value32 & 0xFFFC0000) | h2cq_addr;
HALMAC_REG_W32(REG_H2C_READ_ADDR, value32);
value32 = HALMAC_REG_R32(REG_H2C_TAIL);
value32 = (value32 & 0xFFFC0000);
value32 |= (h2cq_addr + h2cq_size);
HALMAC_REG_W32(REG_H2C_TAIL, value32);
value8 = HALMAC_REG_R8(REG_H2C_INFO);
value8 = (u8)((value8 & 0xFC) | 0x01);
HALMAC_REG_W8(REG_H2C_INFO, value8);
value8 = HALMAC_REG_R8(REG_H2C_INFO);
value8 = (u8)((value8 & 0xFB) | 0x04);
HALMAC_REG_W8(REG_H2C_INFO, value8);
value8 = HALMAC_REG_R8(REG_TXDMA_OFFSET_CHK + 1);
value8 = (u8)((value8 & 0x7f) | 0x80);
HALMAC_REG_W8(REG_TXDMA_OFFSET_CHK + 1, value8);
adapter->h2c_info.buf_size = h2cq_size;
get_h2c_buf_free_space_88xx(adapter);
if (adapter->h2c_info.buf_size != adapter->h2c_info.buf_fs) {
PLTFM_MSG_ERR("[ERR]get h2c free space error!\n");
return HALMAC_RET_GET_H2C_SPACE_ERR;
}
PLTFM_MSG_TRACE("[TRACE]h2c fs : %d\n", adapter->h2c_info.buf_fs);
return HALMAC_RET_SUCCESS;
}
/**
* init_edca_cfg_8822c() - init EDCA config
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_edca_cfg_8822c(struct halmac_adapter *adapter)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
HALMAC_REG_W32(REG_EDCA_VO_PARAM, WLAN_EDCA_VO_PARAM);
HALMAC_REG_W32(REG_EDCA_VI_PARAM, WLAN_EDCA_VI_PARAM);
HALMAC_REG_W32(REG_EDCA_BE_PARAM, WLAN_EDCA_BE_PARAM);
HALMAC_REG_W32(REG_EDCA_BK_PARAM, WLAN_EDCA_BK_PARAM);
HALMAC_REG_W8(REG_PIFS, WLAN_PIFS_TIME);
HALMAC_REG_W8_CLR(REG_TX_PTCL_CTRL + 1, BIT(4));
value8 = HALMAC_REG_R8(REG_RD_CTRL + 1);
value8 = (value8 | BIT(0) | BIT(1) | BIT(2));
HALMAC_REG_W8(REG_RD_CTRL + 1, value8);
cfg_mac_clk_88xx(adapter);
value8 = HALMAC_REG_R8(REG_MISC_CTRL);
value8 = (value8 | BIT(3) | BIT(1) | BIT(0));
HALMAC_REG_W8(REG_MISC_CTRL, value8);
/* Init SYNC_CLI_SEL : reg 0x5B4[6:4] = 0 */
HALMAC_REG_W8_CLR(REG_TIMER0_SRC_SEL, BIT(4) | BIT(5) | BIT(6));
/* Clear TX pause */
HALMAC_REG_W16(REG_TXPAUSE, 0x0000);
HALMAC_REG_W8(REG_SLOT, WLAN_SLOT_TIME);
HALMAC_REG_W32(REG_RD_NAV_NXT, WLAN_NAV_CFG);
HALMAC_REG_W16(REG_RXTSF_OFFSET_CCK, WLAN_RX_TSF_CFG);
/* Set beacon cotnrol - enable TSF and other related functions */
HALMAC_REG_W8(REG_BCN_CTRL, (u8)(HALMAC_REG_R8(REG_BCN_CTRL) |
BIT_EN_BCN_FUNCTION));
/* Set send beacon related registers */
HALMAC_REG_W32(REG_TBTT_PROHIBIT, WLAN_TBTT_TIME);
HALMAC_REG_W8(REG_DRVERLYINT, WLAN_DRV_EARLY_INT);
HALMAC_REG_W8(REG_BCN_CTRL_CLINT0, WLAN_BCN_CTRL_CLT0);
HALMAC_REG_W8(REG_BCNDMATIM, WLAN_BCN_DMA_TIME);
HALMAC_REG_W8(REG_BCN_MAX_ERR, WLAN_BCN_MAX_ERR);
/* MU primary packet fail, BAR packet will not issue */
HALMAC_REG_W8_SET(REG_BAR_TX_CTRL, BIT(0));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static void
init_txq_ctrl_8822c(struct halmac_adapter *adapter)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_FWHW_TXQ_CTRL);
value8 |= (BIT(7) & ~BIT(1) & ~BIT(2));
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL, value8);
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 1, WLAN_TXQ_RPT_EN);
}
static void
init_sifs_ctrl_8822c(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W16(REG_SPEC_SIFS, WLAN_SIFS_DUR_TUNE);
HALMAC_REG_W32(REG_SIFS, WLAN_SIFS_CFG);
HALMAC_REG_W16(REG_RESP_SIFS_CCK,
WLAN_SIFS_CCK_CTX | WLAN_SIFS_CCK_IRX << 8);
HALMAC_REG_W16(REG_RESP_SIFS_OFDM,
WLAN_SIFS_OFDM_CTX | WLAN_SIFS_OFDM_IRX << 8);
}
static void
init_rate_fallback_ctrl_8822c(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W32(REG_DARFRC, WLAN_DATA_RATE_FB_CNT_1_4);
HALMAC_REG_W32(REG_DARFRCH, WLAN_DATA_RATE_FB_CNT_5_8);
HALMAC_REG_W32(REG_RARFRCH, WLAN_RTS_RATE_FB_CNT_5_8);
HALMAC_REG_W32(REG_ARFR0, WLAN_DATA_RATE_FB_RATE0);
HALMAC_REG_W32(REG_ARFRH0, WLAN_DATA_RATE_FB_RATE0_H);
HALMAC_REG_W32(REG_ARFR1_V1, WLAN_RTS_RATE_FB_RATE1);
HALMAC_REG_W32(REG_ARFRH1_V1, WLAN_RTS_RATE_FB_RATE1_H);
HALMAC_REG_W32(REG_ARFR4, WLAN_RTS_RATE_FB_RATE4);
HALMAC_REG_W32(REG_ARFRH4, WLAN_RTS_RATE_FB_RATE4_H);
HALMAC_REG_W32(REG_ARFR5, WLAN_RTS_RATE_FB_RATE5);
HALMAC_REG_W32(REG_ARFRH5, WLAN_RTS_RATE_FB_RATE5_H);
}
/**
* init_wmac_cfg_8822c() - init wmac config
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_wmac_cfg_8822c(struct halmac_adapter *adapter)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
HALMAC_REG_W32(REG_MAR, 0xFFFFFFFF);
HALMAC_REG_W32(REG_MAR + 4, 0xFFFFFFFF);
HALMAC_REG_W8(REG_BBPSF_CTRL + 2, WLAN_RESP_TXRATE);
HALMAC_REG_W8(REG_ACKTO, WLAN_ACK_TO);
HALMAC_REG_W8(REG_ACKTO_CCK, WLAN_ACK_TO_CCK);
HALMAC_REG_W16(REG_EIFS, WLAN_EIFS_DUR_TUNE);
HALMAC_REG_W8(REG_NAV_CTRL + 2, WLAN_NAV_MAX);
HALMAC_REG_W8_SET(REG_WMAC_TRXPTCL_CTL_H, BIT_EN_TXCTS_IN_RXNAV_V1);
HALMAC_REG_W8(REG_WMAC_TRXPTCL_CTL_H + 2, WLAN_BAR_ACK_TYPE);
HALMAC_REG_W32(REG_RXFLTMAP0, WLAN_RX_FILTER0);
HALMAC_REG_W16(REG_RXFLTMAP2, WLAN_RX_FILTER2);
HALMAC_REG_W32(REG_RCR, WLAN_RCR_CFG);
value8 = HALMAC_REG_R8(REG_RXPSF_CTRL + 2);
value8 = value8 | 0xe;
HALMAC_REG_W8(REG_RXPSF_CTRL + 2, value8);
HALMAC_REG_W8(REG_RX_PKT_LIMIT, WLAN_RXPKT_MAX_SZ_512);
HALMAC_REG_W8(REG_TCR + 2, WLAN_TX_FUNC_CFG2);
HALMAC_REG_W8(REG_TCR + 1, WLAN_TX_FUNC_CFG1);
HALMAC_REG_W8_SET(REG_SND_PTCL_CTRL, BIT_R_DISABLE_CHECK_VHTSIGB_CRC);
HALMAC_REG_W32(REG_WMAC_OPTION_FUNCTION + 8, WLAN_MAC_OPT_FUNC2);
if (adapter->hw_cfg_info.trx_mode == HALMAC_TRNSFER_NORMAL)
value8 = WLAN_MAC_OPT_NORM_FUNC1;
else
value8 = WLAN_MAC_OPT_LB_FUNC1;
HALMAC_REG_W8(REG_WMAC_OPTION_FUNCTION_1, value8);
status = api->halmac_init_low_pwr(adapter);
if (status != HALMAC_RET_SUCCESS)
return status;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* pre_init_system_cfg_8822c() - pre-init system config
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pre_init_system_cfg_8822c(struct halmac_adapter *adapter)
{
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 enable_bb;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
HALMAC_REG_W8(REG_RSV_CTRL, 0);
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
#if HALMAC_SDIO_SUPPORT
if (leave_sdio_suspend_88xx(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_SDIO_LEAVE_SUSPEND_FAIL;
#endif
} else if (adapter->intf == HALMAC_INTERFACE_USB) {
#if HALMAC_USB_SUPPORT
if (HALMAC_REG_R8(REG_SYS_CFG2 + 3) == 0x20)
HALMAC_REG_W8(0xFE5B, HALMAC_REG_R8(0xFE5B) | BIT(4));
#endif
} else if (adapter->intf == HALMAC_INTERFACE_PCIE) {
#if HALMAC_PCIE_SUPPORT
/* For PCIE power on fail issue */
HALMAC_REG_W8(REG_HCI_OPT_CTRL + 1,
HALMAC_REG_R8(REG_HCI_OPT_CTRL + 1) | BIT(0));
#endif
}
/* Config PIN Mux */
value32 = HALMAC_REG_R32(REG_PAD_CTRL1);
value32 = value32 & (~(BIT(28) | BIT(29)));
value32 = value32 | BIT(28) | BIT(29);
HALMAC_REG_W32(REG_PAD_CTRL1, value32);
value32 = HALMAC_REG_R32(REG_LED_CFG);
value32 = value32 & (~(BIT(25) | BIT(26)));
HALMAC_REG_W32(REG_LED_CFG, value32);
value32 = HALMAC_REG_R32(REG_GPIO_MUXCFG);
value32 = value32 & (~(BIT(2)));
value32 = value32 | BIT(2);
HALMAC_REG_W32(REG_GPIO_MUXCFG, value32);
enable_bb = 0;
set_hw_value_88xx(adapter, HALMAC_HW_EN_BB_RF, &enable_bb);
/* if (init_xtal_aac(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_INIT_XTAL_AAC_FAIL; */
if (HALMAC_REG_R8(REG_SYS_CFG1 + 2) & BIT(4)) {
PLTFM_MSG_ERR("[ERR]test mode!!\n");
return HALMAC_RET_WLAN_MODE_FAIL;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
init_xtal_aac(struct halmac_adapter *adapter)
{
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W32_SET(REG_ANAPAR_XTAL_1, BIT_EN_XTAL_DRV_DIGI_V2);
HALMAC_REG_W32_SET(REG_ANAPAR_XTAL_AACK_0, BIT_RESET_N);
HALMAC_REG_W32_SET(REG_ANAPAR_XTAL_AACK_0, (BIT(3) | BIT(2)));
HALMAC_REG_W32_SET(REG_ANAPAR_XTAL_AACK_1, (BIT(4) | BIT(3)));
HALMAC_REG_W32_SET(REG_ANAPAR_XTAL_AACK_0, BIT_EN_XTAL_AAC_TRIG);
cnt = 3000;
while (!(HALMAC_REG_R8(REG_XTAL_AAC_OUTPUT) & BIT_XAAC_READY_V1)) {
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]Init XTAL ACC fail\n");
return HALMAC_RET_INIT_XTAL_AAC_FAIL;
}
cnt--;
PLTFM_DELAY_US(20);
}
return HALMAC_RET_SUCCESS;
}
#endif /* HALMAC_8822C_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_init_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_INIT_8822C_H_
#define _HALMAC_INIT_8822C_H_
#include "../../halmac_api.h"
#if HALMAC_8822C_SUPPORT
enum halmac_ret_status
mount_api_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
init_trx_cfg_8822c(struct halmac_adapter *adapter, enum halmac_trx_mode mode);
enum halmac_ret_status
init_system_cfg_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
init_protocol_cfg_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
init_h2c_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
init_edca_cfg_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
init_wmac_cfg_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
pre_init_system_cfg_8822c(struct halmac_adapter *adapter);
#endif /* HALMAC_8822C_SUPPORT */
#endif/* _HALMAC_INIT_8822C_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_pcie_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_pcie_8822c.h"
#include "halmac_pwr_seq_8822c.h"
#include "../halmac_init_88xx.h"
#include "../halmac_common_88xx.h"
#include "../halmac_pcie_88xx.h"
#include "../halmac_88xx_cfg.h"
#if (HALMAC_8822C_SUPPORT && HALMAC_PCIE_SUPPORT)
/**
* mac_pwr_switch_pcie_8822c() - switch mac power
* @adapter : the adapter of halmac
* @pwr : power state
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
#define INTF_INTGRA_MINREF_V1 90
#define INTF_INTGRA_HOSTREF_V1 100
static struct halmac_pcie_cfgspc_param pcie_cfgspc_param_def = {
0,
0,
HALMAC_DISABLE,
HALMAC_ENABLE,
HALMAC_ENABLE,
HALMAC_ENABLE,
HALMAC_IGNORE,
HALMAC_CLKDLY_0,
HALMAC_L0SDLY_7US,
HALMAC_L1DLY_16US,
};
enum pcie_clkdly_hw {
PCIE_CLKDLY_HW_0 = 0,
PCIE_CLKDLY_HW_30US = 0x1,
PCIE_CLKDLY_HW_50US = 0x2,
PCIE_CLKDLY_HW_100US = 0x3,
PCIE_CLKDLY_HW_150US = 0x4,
PCIE_CLKDLY_HW_200US = 0x5
};
enum pcie_l1dly_hw {
PCIE_L1DLY_HW_16US = 4,
PCIE_L1DLY_HW_32US = 5,
PCIE_L1DLY_HW_64US = 6,
PCIE_L1DLY_HW_INFI = 7
};
enum pcie_l0sdly_hw {
PCIE_L0SDLY_HW_1US = 0,
PCIE_L0SDLY_HW_3US = 2,
PCIE_L0SDLY_HW_5US = 4,
PCIE_L0SDLY_HW_7US = 6
};
#define GET_PCIE_FUNC_STUS(val, mask) \
((val & mask) ? HALMAC_ENABLE : HALMAC_DISABLE)
static u16
get_target(struct halmac_adapter *adapter);
static enum halmac_ret_status
pcie_cfgspc_write_8822c(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param);
static enum halmac_ret_status
pcie_cfgspc_read_8822c(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param);
static void
update_pcie_func_8822c(u8 *val, u8 bitmask, enum halmac_func_ctrl ctrl,
enum halmac_func_ctrl def_ctrl);
static u8
chk_stus_l1ss_8822c(struct halmac_adapter *adapter);
static enum halmac_ret_status
update_clkdly_8822c(struct halmac_adapter *adapter, u8 *val,
enum halmac_pcie_clkdly ctrl,
enum halmac_pcie_clkdly def_ctrl);
static enum halmac_ret_status
update_pcie_clk_8822c(struct halmac_adapter *adapter, u8 *val);
static enum halmac_ret_status
update_aspmdly_8822c(struct halmac_adapter *adapter, u8 *val,
struct halmac_pcie_cfgspc_param *param,
struct halmac_pcie_cfgspc_param *param_def);
enum halmac_ret_status
mac_pwr_switch_pcie_8822c(struct halmac_adapter *adapter,
enum halmac_mac_power pwr)
{
u8 value8;
u8 rpwm;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MSG_TRACE("[TRACE]pwr = %x\n", pwr);
PLTFM_MSG_TRACE("[TRACE]8822C pwr seq ver = %s\n",
HALMAC_8822C_PWR_SEQ_VER);
adapter->rpwm = HALMAC_REG_R8(REG_PCIE_HRPWM1_V1);
/* Check FW still exist or not */
if (HALMAC_REG_R16(REG_MCUFW_CTRL) == 0xC078) {
/* Leave 32K */
rpwm = (u8)((adapter->rpwm ^ BIT(7)) & 0x80);
HALMAC_REG_W8(REG_PCIE_HRPWM1_V1, rpwm);
}
value8 = HALMAC_REG_R8(REG_CR);
if (value8 == 0xEA)
adapter->halmac_state.mac_pwr = HALMAC_MAC_POWER_OFF;
else
adapter->halmac_state.mac_pwr = HALMAC_MAC_POWER_ON;
/* Check if power switch is needed */
if (pwr == HALMAC_MAC_POWER_ON &&
adapter->halmac_state.mac_pwr == HALMAC_MAC_POWER_ON) {
PLTFM_MSG_WARN("[WARN]power state unchange!!\n");
return HALMAC_RET_PWR_UNCHANGE;
}
if (pwr == HALMAC_MAC_POWER_OFF) {
if (pwr_seq_parser_88xx(adapter, card_dis_flow_8822c) !=
HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]Handle power off cmd error\n");
return HALMAC_RET_POWER_OFF_FAIL;
}
adapter->halmac_state.mac_pwr = HALMAC_MAC_POWER_OFF;
adapter->halmac_state.dlfw_state = HALMAC_DLFW_NONE;
init_adapter_dynamic_param_88xx(adapter);
} else {
if (pwr_seq_parser_88xx(adapter, card_en_flow_8822c) !=
HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]Handle power on cmd error\n");
return HALMAC_RET_POWER_ON_FAIL;
}
adapter->halmac_state.mac_pwr = HALMAC_MAC_POWER_ON;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* halmac_pcie_switch_8822c() - pcie gen1/gen2 switch
* @adapter : the adapter of halmac
* @cfg : gen1/gen2 selection
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pcie_switch_8822c(struct halmac_adapter *adapter, enum halmac_pcie_cfg cfg)
{
u8 value8;
u32 value32;
u8 speed = 0;
u32 cnt = 0;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (cfg == HALMAC_PCIE_GEN1) {
value8 = dbi_r8_88xx(adapter, LINK_CTRL2_REG_OFFSET) & 0xF0;
dbi_w8_88xx(adapter, LINK_CTRL2_REG_OFFSET, value8 | BIT(0));
value32 = dbi_r32_88xx(adapter, GEN2_CTRL_OFFSET);
dbi_w32_88xx(adapter, GEN2_CTRL_OFFSET, value32 | BIT(17));
speed = dbi_r8_88xx(adapter, LINK_STATUS_REG_OFFSET) & 0x0F;
cnt = 2000;
while ((speed != PCIE_GEN1_SPEED) && (cnt != 0)) {
PLTFM_DELAY_US(50);
speed = dbi_r8_88xx(adapter, LINK_STATUS_REG_OFFSET);
speed &= 0x0F;
cnt--;
}
if (speed != PCIE_GEN1_SPEED) {
PLTFM_MSG_ERR("[ERR]Speed change to GEN1 fail !\n");
return HALMAC_RET_FAIL;
}
} else if (cfg == HALMAC_PCIE_GEN2) {
value8 = dbi_r8_88xx(adapter, LINK_CTRL2_REG_OFFSET) & 0xF0;
dbi_w8_88xx(adapter, LINK_CTRL2_REG_OFFSET, value8 | BIT(1));
value32 = dbi_r32_88xx(adapter, GEN2_CTRL_OFFSET);
dbi_w32_88xx(adapter, GEN2_CTRL_OFFSET, value32 | BIT(17));
speed = dbi_r8_88xx(adapter, LINK_STATUS_REG_OFFSET) & 0x0F;
cnt = 2000;
while ((speed != PCIE_GEN2_SPEED) && (cnt != 0)) {
PLTFM_DELAY_US(50);
speed = dbi_r8_88xx(adapter, LINK_STATUS_REG_OFFSET);
speed &= 0x0F;
cnt--;
}
if (speed != PCIE_GEN2_SPEED) {
PLTFM_MSG_ERR("[ERR]Speed change to GEN1 fail !\n");
return HALMAC_RET_FAIL;
}
} else {
PLTFM_MSG_ERR("[ERR]Error Speed !\n");
return HALMAC_RET_FAIL;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* phy_cfg_pcie_8822c() - phy config
* @adapter : the adapter of halmac
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
phy_cfg_pcie_8822c(struct halmac_adapter *adapter,
enum halmac_intf_phy_platform pltfm)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = parse_intf_phy_88xx(adapter, pcie_gen1_phy_param_8822c, pltfm,
HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return status;
status = parse_intf_phy_88xx(adapter, pcie_gen2_phy_param_8822c, pltfm,
HAL_INTF_PHY_PCIE_GEN2);
if (status != HALMAC_RET_SUCCESS)
return status;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* intf_tun_pcie_8822c() - pcie interface fine tuning
* @adapter : the adapter of halmac
* Author : Rick Liu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
intf_tun_pcie_8822c(struct halmac_adapter *adapter)
{
return HALMAC_RET_SUCCESS;
}
/**
* cfgspc_set_pcie_8822c() - pcie configuration space setting
* @adapter : the adapter of halmac
* Author : Rick Liu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfgspc_set_pcie_8822c(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (param->write == 1)
status = pcie_cfgspc_write_8822c(adapter, param);
if (param->read == 1)
status = pcie_cfgspc_read_8822c(adapter, param);
return status;
}
static enum halmac_ret_status
pcie_cfgspc_write_8822c(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param)
{
u8 l1_val;
u8 aspm_val;
u8 l1ss_val;
u8 clk_val;
struct halmac_pcie_cfgspc_param *param_def = &pcie_cfgspc_param_def;
enum halmac_ret_status status;
l1_val = dbi_r8_88xx(adapter, PCIE_L1_CTRL);
aspm_val = dbi_r8_88xx(adapter, PCIE_ASPM_CTRL);
l1ss_val = dbi_r8_88xx(adapter, PCIE_L1SS_CTRL);
clk_val = dbi_r8_88xx(adapter, PCIE_CLK_CTRL);
if (l1_val == 0xFF || aspm_val == 0xFF || l1ss_val == 0xFF ||
clk_val == 0xFF) {
PLTFM_MSG_ERR("[ERR] PCIE CFG reg read 0xFF!\n");
return HALMAC_RET_FAIL;
}
update_pcie_func_8822c(&aspm_val, PCIE_BIT_L0S,
param->l0s_ctrl, param_def->l0s_ctrl);
status = update_pcie_clk_8822c(adapter, &l1_val);
if (status != HALMAC_RET_SUCCESS)
return status;
update_pcie_func_8822c(&l1_val, PCIE_BIT_L1,
param->l1_ctrl, param_def->l1_ctrl);
update_pcie_func_8822c(&l1_val, PCIE_BIT_WAKE,
param->wake_ctrl, param_def->wake_ctrl);
if (chk_stus_l1ss_8822c(adapter) == 1)
update_pcie_func_8822c(&l1ss_val, PCIE_BIT_L1SS,
param->l1ss_ctrl, param_def->l1ss_ctrl);
status = update_clkdly_8822c(adapter, &clk_val,
param->clkdly_ctrl,
param_def->clkdly_ctrl);
if (status != HALMAC_RET_SUCCESS)
return status;
status = update_aspmdly_8822c(adapter, &aspm_val, param, param_def);
if (status != HALMAC_RET_SUCCESS)
return status;
if (param->l0s_ctrl != HALMAC_IGNORE ||
param->l1dly_ctrl != HALMAC_L1DLY_IGNORE ||
param->l0sdly_ctrl != HALMAC_L0SDLY_IGNORE) {
status = dbi_w8_88xx(adapter, PCIE_ASPM_CTRL, aspm_val);
if (status != HALMAC_RET_SUCCESS)
return status;
}
if (param->l1_ctrl != HALMAC_IGNORE ||
param->wake_ctrl != HALMAC_IGNORE) {
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, l1_val);
if (status != HALMAC_RET_SUCCESS)
return status;
}
if (param->l1ss_ctrl != HALMAC_IGNORE) {
status = dbi_w8_88xx(adapter, PCIE_L1SS_CTRL, l1ss_val);
if (status != HALMAC_RET_SUCCESS)
return status;
}
if (param->clkdly_ctrl != HALMAC_CLKDLY_IGNORE) {
status = dbi_w8_88xx(adapter, PCIE_CLK_CTRL, clk_val);
if (status != HALMAC_RET_SUCCESS)
return status;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
pcie_cfgspc_read_8822c(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param)
{
u8 l1_val;
u8 aspm_val;
u8 l1ss_val;
u8 clk_val;
u8 l0smask;
u8 l1mask;
l1_val = dbi_r8_88xx(adapter, PCIE_L1_CTRL);
aspm_val = dbi_r8_88xx(adapter, PCIE_ASPM_CTRL);
l1ss_val = dbi_r8_88xx(adapter, PCIE_L1SS_CTRL);
clk_val = dbi_r8_88xx(adapter, PCIE_CLK_CTRL);
if (l1_val == 0xFF || aspm_val == 0xFF ||
l1ss_val == 0xFF || clk_val == 0xFF) {
PLTFM_MSG_ERR("[ERR] (2nd)PCIE CFG reg read 0xFF!\n");
return HALMAC_RET_FAIL;
}
param->l0s_ctrl = GET_PCIE_FUNC_STUS(aspm_val, PCIE_BIT_L0S);
param->l1_ctrl = GET_PCIE_FUNC_STUS(l1_val, PCIE_BIT_L1);
param->l1ss_ctrl = GET_PCIE_FUNC_STUS(l1ss_val, PCIE_BIT_L1SS);
param->wake_ctrl = GET_PCIE_FUNC_STUS(l1_val, PCIE_BIT_WAKE);
param->crq_ctrl = GET_PCIE_FUNC_STUS(l1_val, PCIE_BIT_CLK);
switch (clk_val) {
case PCIE_CLKDLY_HW_0:
param->clkdly_ctrl = HALMAC_CLKDLY_0;
break;
case PCIE_CLKDLY_HW_30US:
param->clkdly_ctrl = HALMAC_CLKDLY_30US;
break;
case PCIE_CLKDLY_HW_50US:
param->clkdly_ctrl = HALMAC_CLKDLY_50US;
break;
case PCIE_CLKDLY_HW_100US:
param->clkdly_ctrl = HALMAC_CLKDLY_100US;
break;
case PCIE_CLKDLY_HW_150US:
param->clkdly_ctrl = HALMAC_CLKDLY_150US;
break;
case PCIE_CLKDLY_HW_200US:
param->clkdly_ctrl = HALMAC_CLKDLY_200US;
break;
default:
param->clkdly_ctrl = HALMAC_CLKDLY_R_ERR;
break;
}
l0smask = PCIE_ASPMDLY_MASK << SHFT_L0SDLY;
l1mask = PCIE_ASPMDLY_MASK << SHFT_L1DLY;
switch ((aspm_val & l0smask) >> SHFT_L0SDLY) {
case PCIE_L0SDLY_HW_1US:
param->l0sdly_ctrl = HALMAC_L0SDLY_1US;
break;
case PCIE_L0SDLY_HW_3US:
param->l0sdly_ctrl = HALMAC_L0SDLY_3US;
break;
case PCIE_L0SDLY_HW_5US:
param->l0sdly_ctrl = HALMAC_L0SDLY_5US;
break;
case PCIE_L0SDLY_HW_7US:
param->l0sdly_ctrl = HALMAC_L0SDLY_7US;
break;
default:
param->l0sdly_ctrl = HALMAC_L0SDLY_R_ERR;
break;
}
switch ((aspm_val & l1mask) >> SHFT_L1DLY) {
case PCIE_L1DLY_HW_16US:
param->l1dly_ctrl = HALMAC_L1DLY_16US;
break;
case PCIE_L1DLY_HW_32US:
param->l1dly_ctrl = HALMAC_L1DLY_32US;
break;
case PCIE_L1DLY_HW_64US:
param->l1dly_ctrl = HALMAC_L1DLY_64US;
break;
case PCIE_L1DLY_HW_INFI:
param->l1dly_ctrl = HALMAC_L1DLY_INFI;
break;
default:
param->l1dly_ctrl = HALMAC_L1DLY_R_ERR;
break;
}
return HALMAC_RET_SUCCESS;
}
static void
update_pcie_func_8822c(u8 *val, u8 bitmask, enum halmac_func_ctrl ctrl,
enum halmac_func_ctrl def_ctrl)
{
if ((ctrl == HALMAC_DEFAULT &&
(def_ctrl == HALMAC_IGNORE || def_ctrl == HALMAC_DEFAULT)) ||
ctrl == HALMAC_IGNORE)
return;
if ((ctrl == HALMAC_DEFAULT && def_ctrl == HALMAC_DISABLE) ||
ctrl == HALMAC_DISABLE)
*val &= ~(bitmask);
else
*val |= bitmask;
}
static u8
chk_stus_l1ss_8822c(struct halmac_adapter *adapter)
{
u16 cap_val;
u8 stus_val;
u8 sup_val;
cap_val = (u16)((dbi_r8_88xx(adapter, PCIE_L1SS_CAP + 1) << 8) |
dbi_r8_88xx(adapter, PCIE_L1SS_CAP));
sup_val = dbi_r8_88xx(adapter, PCIE_L1SS_SUP);
stus_val = dbi_r8_88xx(adapter, PCIE_L1SS_STS);
if (cap_val == PCIE_L1SS_ID &&
(sup_val & PCIE_BIT_L1SSSUP) &&
(sup_val & PCIE_L1SS_MASK) != 0 &&
(stus_val & PCIE_L1SS_MASK) != 0)
return 1;
return 0;
}
static enum halmac_ret_status
update_clkdly_8822c(struct halmac_adapter *adapter, u8 *val,
enum halmac_pcie_clkdly ctrl,
enum halmac_pcie_clkdly def_ctrl)
{
u8 tmp;
if (ctrl == HALMAC_CLKDLY_IGNORE)
return HALMAC_RET_SUCCESS;
tmp = (ctrl == HALMAC_CLKDLY_DEF) ? def_ctrl : ctrl;
switch (tmp) {
case HALMAC_CLKDLY_0:
*val = PCIE_CLKDLY_HW_0;
break;
case HALMAC_CLKDLY_30US:
*val = PCIE_CLKDLY_HW_30US;
break;
case HALMAC_CLKDLY_50US:
*val = PCIE_CLKDLY_HW_50US;
break;
case HALMAC_CLKDLY_100US:
*val = PCIE_CLKDLY_HW_100US;
break;
case HALMAC_CLKDLY_150US:
*val = PCIE_CLKDLY_HW_150US;
break;
case HALMAC_CLKDLY_200US:
*val = PCIE_CLKDLY_HW_200US;
break;
default:
PLTFM_MSG_ERR("[ERR]CLKDLY wt val illegal!\n");
return HALMAC_RET_FAIL;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
update_pcie_clk_8822c(struct halmac_adapter *adapter, u8 *val)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (*val & PCIE_BIT_CLK)
return HALMAC_RET_SUCCESS;
if (*val & PCIE_BIT_L1) {
*val &= ~(PCIE_BIT_L1);
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, *val);
if (status != HALMAC_RET_SUCCESS)
return status;
*val |= PCIE_BIT_CLK;
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, *val);
if (status != HALMAC_RET_SUCCESS)
return status;
*val |= PCIE_BIT_L1;
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, *val);
PLTFM_MSG_WARN("[WARN] L1 enable & CLKREQ disable!\n");
} else {
*val |= PCIE_BIT_CLK;
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, *val);
}
return status;
}
static enum halmac_ret_status
update_aspmdly_8822c(struct halmac_adapter *adapter, u8 *val,
struct halmac_pcie_cfgspc_param *param,
struct halmac_pcie_cfgspc_param *param_def)
{
u8 l1mask = PCIE_ASPMDLY_MASK << SHFT_L1DLY;
u8 l0smask = PCIE_ASPMDLY_MASK << SHFT_L0SDLY;
u8 l1updval = param->l1dly_ctrl;
u8 l0supdval = param->l0sdly_ctrl;
u8 l1defval = param_def->l1dly_ctrl;
u8 l0sdefval = param_def->l0sdly_ctrl;
u8 tmp;
u8 hwval;
if (l1updval != HALMAC_L1DLY_IGNORE) {
tmp = (l1updval == HALMAC_L1DLY_DEF) ? l1defval : l1updval;
switch (tmp) {
case HALMAC_L1DLY_16US:
hwval = PCIE_L1DLY_HW_16US;
break;
case HALMAC_L1DLY_32US:
hwval = PCIE_L1DLY_HW_32US;
break;
case HALMAC_L1DLY_64US:
hwval = PCIE_L1DLY_HW_64US;
break;
case HALMAC_L1DLY_INFI:
hwval = PCIE_L1DLY_HW_INFI;
break;
default:
PLTFM_MSG_ERR("[ERR]L1DLY wt val illegal!\n");
return HALMAC_RET_FAIL;
}
tmp = (hwval << SHFT_L1DLY) & l1mask;
*val = (*val & ~(l1mask)) | tmp;
}
if (l0supdval != HALMAC_L0SDLY_IGNORE) {
tmp = (l0supdval == HALMAC_L0SDLY_DEF) ? l0sdefval : l0supdval;
switch (tmp) {
case HALMAC_L0SDLY_1US:
hwval = PCIE_L0SDLY_HW_1US;
break;
case HALMAC_L0SDLY_3US:
hwval = PCIE_L0SDLY_HW_3US;
break;
case HALMAC_L0SDLY_5US:
hwval = PCIE_L0SDLY_HW_5US;
break;
case HALMAC_L0SDLY_7US:
hwval = PCIE_L0SDLY_HW_7US;
break;
default:
PLTFM_MSG_ERR("[ERR]L0SDLY wt val illegal!\n");
return HALMAC_RET_FAIL;
}
tmp = (hwval << SHFT_L0SDLY) & l0smask;
*val = (*val & ~(l0smask)) | tmp;
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
auto_refclk_cal_8822c_pcie(struct halmac_adapter *adapter)
{
u8 bdr_ori;
u16 tmp_u16;
u16 div_set;
u16 mgn_tmp;
u16 mgn_set;
u16 tar;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
u8 l1_flag = 0;
#if (INTF_INTGRA_HOSTREF_V1 <= INTF_INTGRA_MINREF_V1)
return status;
#endif
/* Disable L1BD */
bdr_ori = dbi_r8_88xx(adapter, PCIE_L1_CTRL);
if (bdr_ori & PCIE_BIT_L1) {
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL,
bdr_ori & ~(PCIE_BIT_L1));
if (status != HALMAC_RET_SUCCESS)
return status;
l1_flag = 1;
}
/* Disable function */
tmp_u16 = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1,
HAL_INTF_PHY_PCIE_GEN1);
if (tmp_u16 & BIT(13)) {
status = mdio_write_88xx(adapter, RAC_CTRL_PPR_V1,
tmp_u16 & ~(BIT(13)),
HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return status;
}
if (adapter->pcie_refautok_en == 0) {
if (l1_flag == 1)
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, bdr_ori);
return status;
}
/* Set div */
tmp_u16 = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1
, HAL_INTF_PHY_PCIE_GEN1);
status = mdio_write_88xx(adapter, RAC_CTRL_PPR_V1,
tmp_u16 & ~(BIT(15) | BIT(14)),
HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return status;
/* Obtain div and margin */
tar = get_target(adapter);
if (tar == 0xFFFF)
return HALMAC_RET_FAIL;
mgn_tmp = tar * INTF_INTGRA_HOSTREF_V1 / INTF_INTGRA_MINREF_V1 - tar;
if (mgn_tmp >= 128) {
div_set = 0x0003;
mgn_set = 0x000F;
} else if (mgn_tmp >= 64) {
div_set = 0x0003;
mgn_set = mgn_tmp >> 3;
} else if (mgn_tmp >= 32) {
div_set = 0x0002;
mgn_set = mgn_tmp >> 2;
} else if (mgn_tmp >= 16) {
div_set = 0x0001;
mgn_set = mgn_tmp >> 1;
} else if (mgn_tmp == 0) {
div_set = 0x0000;
mgn_set = 0x0001;
} else {
div_set = 0x0000;
mgn_set = mgn_tmp;
}
/* Set div, margin, target*/
tmp_u16 = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1,
HAL_INTF_PHY_PCIE_GEN1);
tmp_u16 = (tmp_u16 & ~(BIT(15) | BIT(14))) | (div_set << 6);
status = mdio_write_88xx(adapter, RAC_CTRL_PPR_V1,
tmp_u16, HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return status;
tar = get_target(adapter);
if (tar == 0xFFFF)
return HALMAC_RET_FAIL;
PLTFM_MSG_TRACE("[TRACE]target = 0x%X, div = 0x%X, margin = 0x%X\n",
tar, div_set, mgn_set);
status = mdio_write_88xx(adapter, RAC_SET_PPR_V1,
(tar & 0x0FFF) | (mgn_set << 12),
HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return status;
/* Enable function */
tmp_u16 = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1,
HAL_INTF_PHY_PCIE_GEN1);
status = mdio_write_88xx(adapter, RAC_CTRL_PPR_V1, tmp_u16 | BIT(13),
HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return status;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
/* Set L1BD to ori */
if (l1_flag == 1)
status = dbi_w8_88xx(adapter, PCIE_L1_CTRL, bdr_ori);
return status;
}
static u16
get_target(struct halmac_adapter *adapter)
{
u16 tmp_u16;
u16 tar;
u16 count;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
/* Enable counter */
tmp_u16 = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1,
HAL_INTF_PHY_PCIE_GEN1);
status = mdio_write_88xx(adapter, RAC_CTRL_PPR_V1,
tmp_u16 | BIT(12), HAL_INTF_PHY_PCIE_GEN1);
if (status != HALMAC_RET_SUCCESS)
return 0xFFFF;
/* Obtain target */
count = 0;
do {
PLTFM_DELAY_US(10);
tmp_u16 = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1,
HAL_INTF_PHY_PCIE_GEN1);
count++;
if (count > 100)
break;
} while ((tmp_u16 & BIT(12)) == BIT(12));
if (count > 100) {
PLTFM_MSG_ERR("[ERR]Get target timeout.\n");
return 0xFFFF;
}
tar = mdio_read_88xx(adapter, RAC_CTRL_PPR_V1, HAL_INTF_PHY_PCIE_GEN1);
tar = tar & 0x0FFF;
if (tar == 0) {
PLTFM_MSG_ERR("[ERR]Get target failed.\n");
return 0xFFFF;
}
return tar;
}
#endif /* HALMAC_8822C_SUPPORT*/
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_pcie_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_API_8822C_PCIE_H_
#define _HALMAC_API_8822C_PCIE_H_
#include "../../halmac_api.h"
#if (HALMAC_8822C_SUPPORT && HALMAC_PCIE_SUPPORT)
extern struct halmac_intf_phy_para pcie_gen1_phy_param_8822c[];
extern struct halmac_intf_phy_para pcie_gen2_phy_param_8822c[];
enum halmac_ret_status
mac_pwr_switch_pcie_8822c(struct halmac_adapter *adapter,
enum halmac_mac_power pwr);
enum halmac_ret_status
pcie_switch_8822c(struct halmac_adapter *adapter, enum halmac_pcie_cfg cfg);
enum halmac_ret_status
phy_cfg_pcie_8822c(struct halmac_adapter *adapter,
enum halmac_intf_phy_platform pltfm);
enum halmac_ret_status
intf_tun_pcie_8822c(struct halmac_adapter *adapter);
enum halmac_ret_status
cfgspc_set_pcie_8822c(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param);
enum halmac_ret_status
auto_refclk_cal_8822c_pcie(struct halmac_adapter *adapter);
#endif /* HALMAC_8822C_SUPPORT*/
#endif/* _HALMAC_API_8822C_PCIE_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_phy_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "../../halmac_type.h"
#if HALMAC_USB_SUPPORT
#include "halmac_usb_8822c.h"
#endif
#if HALMAC_PCIE_SUPPORT
#include "halmac_pcie_8822c.h"
#endif
/**
* ============ip sel item list============
* HALMAC_IP_INTF_PHY
* USB2 : usb2 phy, 1byte value
* USB3 : usb3 phy, 2byte value
* PCIE1 : pcie gen1 mdio, 2byte value
* PCIE2 : pcie gen2 mdio, 2byte value
* HALMAC_IP_SEL_MAC
* USB2, USB3, PCIE1, PCIE2 : mac ip, 1byte value
* HALMAC_IP_PCIE_DBI
* USB2 USB3 : none
* PCIE1, PCIE2 : pcie dbi, 1byte value
*/
#if HALMAC_8822C_SUPPORT
struct halmac_intf_phy_para usb2_phy_param_8822c[] = {
/* {offset, value, ip sel, cut mask, platform mask} */
{0xFFFF, 0x00,
HALMAC_IP_INTF_PHY,
HALMAC_INTF_PHY_CUT_ALL,
HALMAC_INTF_PHY_PLATFORM_ALL},
};
struct halmac_intf_phy_para usb3_phy_param_8822c[] = {
/* {offset, value, ip sel, cut mask, platform mask} */
{0xFFFF, 0x0000,
HALMAC_IP_INTF_PHY,
HALMAC_INTF_PHY_CUT_ALL,
HALMAC_INTF_PHY_PLATFORM_ALL},
};
struct halmac_intf_phy_para pcie_gen1_phy_param_8822c[] = {
/* {offset, value, ip sel, cut mask, platform mask} */
{0xFFFF, 0x0000,
HALMAC_IP_INTF_PHY,
HALMAC_INTF_PHY_CUT_ALL,
HALMAC_INTF_PHY_PLATFORM_ALL},
};
struct halmac_intf_phy_para pcie_gen2_phy_param_8822c[] = {
/* {offset, value, ip sel, cut mask, platform mask} */
{0xFFFF, 0x0000,
HALMAC_IP_INTF_PHY,
HALMAC_INTF_PHY_CUT_ALL,
HALMAC_INTF_PHY_PLATFORM_ALL},
};
#endif /* HALMAC_8822C_SUPPORT*/
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_pwr_seq_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2019 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_pwr_seq_8822c.h"
#if HALMAC_8822C_SUPPORT
static struct halmac_wlan_pwr_cfg TRANS_CARDDIS_TO_CARDEMU_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_POLLING, BIT(1), BIT(1)},
{0x002E,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), BIT(2)},
{0x002D,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x007F,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), 0},
{0x004A,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3) | BIT(4), 0},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_CARDEMU_TO_ACT_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0000,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK | HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(5), 0},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, (BIT(4) | BIT(3) | BIT(2)), 0},
{0x0075,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0006,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, BIT(1), BIT(1)},
{0x0075,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0xFF1A,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0},
{0x002E,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3), 0},
{0x0006,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, (BIT(4) | BIT(3)), 0},
{0x1018,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), BIT(2)},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, BIT(0), 0},
{0x0074,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(5), BIT(5)},
{0x0071,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4), 0},
{0x0062,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, (BIT(7) | BIT(6) | BIT(5)),
(BIT(7) | BIT(6) | BIT(5))},
{0x0061,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, (BIT(7) | BIT(6) | BIT(5)), 0},
{0x001F,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, (BIT(7) | BIT(6)), BIT(7)},
{0x00EF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, (BIT(7) | BIT(6)), BIT(7)},
{0x1045,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4), BIT(4)},
{0x0010,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), BIT(2)},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_ACT_TO_CARDEMU_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3), 0},
{0x001F,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0},
{0x00EF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0},
{0x1045,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4), 0},
{0xFF1A,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x30},
{0x0049,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), 0},
{0x0006,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), 0},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), BIT(1)},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, BIT(1), 0},
{0x0000,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK | HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(5), BIT(5)},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_CARDEMU_TO_CARDDIS_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0007,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK | HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x00},
{0x0067,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(5), 0},
{0x004A,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0081,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7) | BIT(6), 0},
{0x0090,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), 0},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x20},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x04},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK | HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3) | BIT(4), BIT(3)},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), BIT(2)},
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
/* Card Enable Array */
struct halmac_wlan_pwr_cfg *card_en_flow_8822c[] = {
TRANS_CARDDIS_TO_CARDEMU_8822C,
TRANS_CARDEMU_TO_ACT_8822C,
NULL
};
/* Card Disable Array */
struct halmac_wlan_pwr_cfg *card_dis_flow_8822c[] = {
TRANS_ACT_TO_CARDEMU_8822C,
TRANS_CARDEMU_TO_CARDDIS_8822C,
NULL
};
#if HALMAC_PLATFORM_TESTPROGRAM
static struct halmac_wlan_pwr_cfg TRANS_CARDEMU_TO_SUS_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4) | BIT(3), (BIT(4) | BIT(3))},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK | HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3) | BIT(4), BIT(3)},
{0x0007,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x20},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3) | BIT(4), BIT(3) | BIT(4)},
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_POLLING, BIT(1), 0},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_SUS_TO_CARDEMU_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3) | BIT(7), 0},
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0086,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_POLLING, BIT(1), BIT(1)},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3) | BIT(4), 0},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_CARDEMU_TO_PDN_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0007,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK | HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x20},
{0x0006,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), BIT(7)},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_PDN_TO_CARDEMU_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0005,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), 0},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_ACT_TO_LPS_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0101,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), BIT(2)},
{0x0199,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3), BIT(3)},
{0x019B,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), BIT(7)},
{0x1138,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0) | BIT(1), BIT(0) | BIT(1)},
{0x0194,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x06},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x68},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x02},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x68},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x03},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x68},
{0x0090,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), BIT(1)},
{0x0301,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0x7F, 0xFF},
{0x0522,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF},
{0x05F8,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x05F9,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x05FA,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x05FB,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_DELAY, 0, HALMAC_PWR_DELAY_US},
{0x0100,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x3F},
{0x0008,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4), BIT(4)},
{0x0109,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, BIT(7), BIT(7)},
{0x0090,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_ACT_TO_DEEP_LPS_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0101,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), BIT(2)},
{0x0199,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(3), BIT(3)},
{0x019B,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), BIT(7)},
{0x1138,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0) | BIT(1), BIT(0) | BIT(1)},
{0x0194,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x04},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x28},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x00},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x28},
{0x0093,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x01},
{0x0092,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x28},
{0x0090,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), BIT(1)},
{0x0301,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0x7F, 0xFF},
{0x0522,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF},
{0x05F8,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x05F9,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x05FA,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x05FB,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, 0xFF, 0},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), 0},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_DELAY, 0, HALMAC_PWR_DELAY_US},
{0x0100,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x3F},
{0x0008,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4), BIT(4)},
{0x0109,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, BIT(7), BIT(7)},
{0x0090,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(0), BIT(0)},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
static struct halmac_wlan_pwr_cfg TRANS_LPS_TO_ACT_8822C[] = {
/* { offset, cut_msk, interface_msk, base|cmd, msk, value } */
{0x0080,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_WRITE, BIT(7), BIT(7)},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_DELAY, 0, HALMAC_PWR_DELAY_MS},
{0x0080,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_SDIO_MSK,
HALMAC_PWR_ADDR_SDIO,
HALMAC_PWR_CMD_WRITE, BIT(7), 0},
{0xFE58,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_USB_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x84},
{0x03D9,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), BIT(7)},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_DELAY, 0, HALMAC_PWR_DELAY_MS},
{0x03D9,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(7), 0},
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_DELAY, 0, HALMAC_PWR_DELAY_MS},
{0x0008,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(4), 0},
{0x0109,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_POLLING, BIT(7), 0},
{0x0100,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF },
{0x0002,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1) | BIT(0), BIT(1) | BIT(0)},
{0x0522,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0},
{0x113C,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0x03},
{0x0124,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF},
{0x0125,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF},
{0x0126,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF},
{0x0127,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0xFF, 0xFF},
{0x0090,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(1), 0},
{0x0101,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, BIT(2), 0},
{0x0301,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_PCI_MSK,
HALMAC_PWR_ADDR_MAC,
HALMAC_PWR_CMD_WRITE, 0x7F, 0x00},
{0xFFFF,
HALMAC_PWR_CUT_ALL_MSK,
HALMAC_PWR_INTF_ALL_MSK,
0,
HALMAC_PWR_CMD_END, 0, 0},
};
/* Suspend Array */
struct halmac_wlan_pwr_cfg *suspend_flow_8822c[] = {
TRANS_ACT_TO_CARDEMU_8822C,
TRANS_CARDEMU_TO_SUS_8822C,
NULL
};
/* Resume Array */
struct halmac_wlan_pwr_cfg *resume_flow_8822c[] = {
TRANS_SUS_TO_CARDEMU_8822C,
TRANS_CARDEMU_TO_ACT_8822C,
NULL
};
/* HWPDN Array - HW behavior */
struct halmac_wlan_pwr_cfg *hwpdn_flow_8822c[] = {
NULL
};
/* Enter LPS - FW behavior */
struct halmac_wlan_pwr_cfg *enter_lps_flow_8822c[] = {
TRANS_ACT_TO_LPS_8822C,
NULL
};
/* Enter Deep LPS - FW behavior */
struct halmac_wlan_pwr_cfg *enter_dlps_flow_8822c[] = {
TRANS_ACT_TO_DEEP_LPS_8822C,
NULL
};
/* Leave LPS -FW behavior */
struct halmac_wlan_pwr_cfg *leave_lps_flow_8822c[] = {
TRANS_LPS_TO_ACT_8822C,
NULL
};
#endif
#endif /* HALMAC_8822C_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_8822c/halmac_pwr_seq_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2019 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef HALMAC_POWER_SEQUENCE_8822C
#define HALMAC_POWER_SEQUENCE_8822C
#include "../../halmac_pwr_seq_cmd.h"
#include "../../halmac_hw_cfg.h"
#if HALMAC_8822C_SUPPORT
#define HALMAC_8822C_PWR_SEQ_VER "V15"
extern struct halmac_wlan_pwr_cfg *card_en_flow_8822c[];
extern struct halmac_wlan_pwr_cfg *card_dis_flow_8822c[];
#if HALMAC_PLATFORM_TESTPROGRAM
extern struct halmac_wlan_pwr_cfg *suspend_flow_8822c[];
extern struct halmac_wlan_pwr_cfg *resume_flow_8822c[];
extern struct halmac_wlan_pwr_cfg *hwpdn_flow_8822c[];
extern struct halmac_wlan_pwr_cfg *enter_lps_flow_8822c[];
extern struct halmac_wlan_pwr_cfg *enter_dlps_flow_8822c[];
extern struct halmac_wlan_pwr_cfg *leave_lps_flow_8822c[];
#endif
#endif /* HALMAC_8822C_SUPPORT*/
#endif
================================================
FILE: hal/halmac/halmac_88xx/halmac_88xx_cfg.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_88XX_CFG_H_
#define _HALMAC_88XX_CFG_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
#define TX_PAGE_SIZE_88XX 128
#define TX_PAGE_SIZE_SHIFT_88XX 7 /* 128 = 2^7 */
#define TX_ALIGN_SIZE_88XX 8
#define SDIO_TX_MAX_SIZE_88XX 31744
#define RX_BUF_FW_88XX 12288
#define TX_DESC_SIZE_88XX 48
#define RX_DESC_SIZE_88XX 24
#define H2C_PKT_SIZE_88XX 32 /* Only support 32 byte packet now */
#define H2C_PKT_HDR_SIZE_88XX 8
#define C2H_DATA_OFFSET_88XX 10
#define C2H_PKT_BUF_88XX 256
/* HW memory address */
#define OCPBASE_TXBUF_88XX 0x18780000
#define OCPBASE_DMEM_88XX 0x00200000
#define OCPBASE_EMEM_88XX 0x00100000
#endif /* HALMAC_88XX_SUPPORT */
#endif
================================================
FILE: hal/halmac/halmac_88xx/halmac_bb_rf_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_bb_rf_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_common_88xx.h"
#include "halmac_init_88xx.h"
#if HALMAC_88XX_SUPPORT
/**
* start_iqk_88xx() -trigger FW IQK
* @adapter : the adapter of halmac
* @param : IQK parameter
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
start_iqk_88xx(struct halmac_adapter *adapter, struct halmac_iqk_para *param)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_h2c_header_info hdr_info;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.iqk_state.proc_status;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_TRACE("[TRACE]Wait event(iqk)\n");
return HALMAC_RET_BUSY_STATE;
}
*proc_status = HALMAC_CMD_PROCESS_SENDING;
IQK_SET_CLEAR(h2c_buf, param->clear);
IQK_SET_SEGMENT_IQK(h2c_buf, param->segment_iqk);
hdr_info.sub_cmd_id = SUB_CMD_ID_IQK;
hdr_info.content_size = 1;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.iqk_state.seq_num = seq_num;
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c pkt fail!!\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_IQK);
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* ctrl_pwr_tracking_88xx() -trigger FW power tracking
* @adapter : the adapter of halmac
* @opt : power tracking option
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
ctrl_pwr_tracking_88xx(struct halmac_adapter *adapter,
struct halmac_pwr_tracking_option *opt)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_h2c_header_info hdr_info;
struct halmac_pwr_tracking_para *param;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.pwr_trk_state.proc_status;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_TRACE("[TRACE]Wait event(pwr tracking)...\n");
return HALMAC_RET_BUSY_STATE;
}
*proc_status = HALMAC_CMD_PROCESS_SENDING;
PWR_TRK_SET_TYPE(h2c_buf, opt->type);
PWR_TRK_SET_BBSWING_INDEX(h2c_buf, opt->bbswing_index);
param = &opt->pwr_tracking_para[HALMAC_RF_PATH_A];
PWR_TRK_SET_ENABLE_A(h2c_buf, param->enable);
PWR_TRK_SET_TX_PWR_INDEX_A(h2c_buf, param->tx_pwr_index);
PWR_TRK_SET_TSSI_VALUE_A(h2c_buf, param->tssi_value);
PWR_TRK_SET_OFFSET_VALUE_A(h2c_buf, param->pwr_tracking_offset_value);
param = &opt->pwr_tracking_para[HALMAC_RF_PATH_B];
PWR_TRK_SET_ENABLE_B(h2c_buf, param->enable);
PWR_TRK_SET_TX_PWR_INDEX_B(h2c_buf, param->tx_pwr_index);
PWR_TRK_SET_TSSI_VALUE_B(h2c_buf, param->tssi_value);
PWR_TRK_SET_OFFSET_VALUE_B(h2c_buf, param->pwr_tracking_offset_value);
param = &opt->pwr_tracking_para[HALMAC_RF_PATH_C];
PWR_TRK_SET_ENABLE_C(h2c_buf, param->enable);
PWR_TRK_SET_TX_PWR_INDEX_C(h2c_buf, param->tx_pwr_index);
PWR_TRK_SET_TSSI_VALUE_C(h2c_buf, param->tssi_value);
PWR_TRK_SET_OFFSET_VALUE_C(h2c_buf, param->pwr_tracking_offset_value);
param = &opt->pwr_tracking_para[HALMAC_RF_PATH_D];
PWR_TRK_SET_ENABLE_D(h2c_buf, param->enable);
PWR_TRK_SET_TX_PWR_INDEX_D(h2c_buf, param->tx_pwr_index);
PWR_TRK_SET_TSSI_VALUE_D(h2c_buf, param->tssi_value);
PWR_TRK_SET_OFFSET_VALUE_D(h2c_buf, param->pwr_tracking_offset_value);
hdr_info.sub_cmd_id = SUB_CMD_ID_PWR_TRK;
hdr_info.content_size = 20;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.pwr_trk_state.seq_num = seq_num;
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c pkt fail!!\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_POWER_TRACKING);
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_iqk_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status)
{
*proc_status = adapter->halmac_state.iqk_state.proc_status;
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_pwr_trk_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status)
{
*proc_status = adapter->halmac_state.pwr_trk_state.proc_status;
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_psd_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status, u8 *data,
u32 *size)
{
struct halmac_psd_state *state = &adapter->halmac_state.psd_state;
*proc_status = state->proc_status;
if (!data)
return HALMAC_RET_NULL_POINTER;
if (!size)
return HALMAC_RET_NULL_POINTER;
if (*proc_status == HALMAC_CMD_PROCESS_DONE) {
if (*size < state->data_size) {
*size = state->data_size;
return HALMAC_RET_BUFFER_TOO_SMALL;
}
*size = state->data_size;
PLTFM_MEMCPY(data, state->data, *size);
}
return HALMAC_RET_SUCCESS;
}
/**
* psd_88xx() - trigger fw psd
* @adapter : the adapter of halmac
* @start_psd : start PSD
* @end_psd : end PSD
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
psd_88xx(struct halmac_adapter *adapter, u16 start_psd, u16 end_psd)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_h2c_header_info hdr_info;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.psd_state.proc_status;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_TRACE("[TRACE]Wait event(psd)\n");
return HALMAC_RET_BUSY_STATE;
}
if (adapter->halmac_state.psd_state.data) {
PLTFM_FREE(adapter->halmac_state.psd_state.data,
adapter->halmac_state.psd_state.data_size);
adapter->halmac_state.psd_state.data = (u8 *)NULL;
}
adapter->halmac_state.psd_state.data_size = 0;
adapter->halmac_state.psd_state.seg_size = 0;
*proc_status = HALMAC_CMD_PROCESS_SENDING;
PSD_SET_START_PSD(h2c_buf, start_psd);
PSD_SET_END_PSD(h2c_buf, end_psd);
hdr_info.sub_cmd_id = SUB_CMD_ID_PSD;
hdr_info.content_size = 4;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c pkt fail!!\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_PSD);
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_h2c_ack_iqk_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num;
u8 fw_rc;
struct halmac_iqk_state *state = &adapter->halmac_state.iqk_state;
enum halmac_cmd_process_status proc_status;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
if ((enum halmac_h2c_return_code)fw_rc == HALMAC_H2C_RETURN_SUCCESS) {
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_IQK, proc_status, NULL, 0);
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_IQK, proc_status, &fw_rc, 1);
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_h2c_ack_pwr_trk_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num;
u8 fw_rc;
struct halmac_pwr_tracking_state *state;
enum halmac_cmd_process_status proc_status;
state = &adapter->halmac_state.pwr_trk_state;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
if ((enum halmac_h2c_return_code)fw_rc == HALMAC_H2C_RETURN_SUCCESS) {
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_POWER_TRACKING, proc_status,
NULL, 0);
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_POWER_TRACKING, proc_status,
&fw_rc, 1);
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_psd_data_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seg_id;
u8 seg_size;
u8 seq_num;
u16 total_size;
enum halmac_cmd_process_status proc_status;
struct halmac_psd_state *state = &adapter->halmac_state.psd_state;
seq_num = (u8)PSD_DATA_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
total_size = (u16)PSD_DATA_GET_TOTAL_SIZE(buf);
seg_id = (u8)PSD_DATA_GET_SEGMENT_ID(buf);
seg_size = (u8)PSD_DATA_GET_SEGMENT_SIZE(buf);
state->data_size = total_size;
if (!state->data)
state->data = (u8 *)PLTFM_MALLOC(state->data_size);
if (seg_id == 0)
state->seg_size = seg_size;
PLTFM_MEMCPY(state->data + seg_id * state->seg_size,
buf + C2H_DATA_OFFSET_88XX, seg_size);
if (PSD_DATA_GET_END_SEGMENT(buf) == 0)
return HALMAC_RET_SUCCESS;
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_PSD, proc_status, state->data,
state->data_size);
return HALMAC_RET_SUCCESS;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_bb_rf_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_BB_RF_88XX_H_
#define _HALMAC_BB_RF_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
start_iqk_88xx(struct halmac_adapter *adapter, struct halmac_iqk_para *param);
enum halmac_ret_status
ctrl_pwr_tracking_88xx(struct halmac_adapter *adapter,
struct halmac_pwr_tracking_option *opt);
enum halmac_ret_status
get_iqk_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status);
enum halmac_ret_status
get_pwr_trk_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status);
enum halmac_ret_status
get_psd_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status, u8 *data,
u32 *size);
enum halmac_ret_status
psd_88xx(struct halmac_adapter *adapter, u16 start_psd, u16 end_psd);
enum halmac_ret_status
get_h2c_ack_iqk_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
get_h2c_ack_pwr_trk_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
get_psd_data_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_BB_RF_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_cfg_wmac_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_cfg_wmac_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_efuse_88xx.h"
#if HALMAC_88XX_SUPPORT
#define MAC_CLK_SPEED 80 /* 80M */
#define EFUSE_PCB_INFO_OFFSET 0xCA
enum mac_clock_hw_def {
MAC_CLK_HW_DEF_80M = 0,
MAC_CLK_HW_DEF_40M = 1,
MAC_CLK_HW_DEF_20M = 2,
};
static enum halmac_ret_status
board_rf_fine_tune_88xx(struct halmac_adapter *adapter);
/**
* cfg_mac_addr_88xx() - config mac address
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @addr : mac address
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_mac_addr_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr)
{
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (port >= HALMAC_PORTID_NUM) {
PLTFM_MSG_ERR("[ERR]port index >= 5\n");
return HALMAC_RET_PORT_NOT_SUPPORT;
}
switch (port) {
case HALMAC_PORTID0:
offset = REG_MACID;
break;
case HALMAC_PORTID1:
offset = REG_MACID1;
break;
case HALMAC_PORTID2:
offset = REG_MACID2;
break;
case HALMAC_PORTID3:
offset = REG_MACID3;
break;
case HALMAC_PORTID4:
offset = REG_MACID4;
break;
default:
return HALMAC_RET_PORT_NOT_SUPPORT;
}
HALMAC_REG_W32(offset, rtk_le32_to_cpu(addr->addr_l_h.low));
HALMAC_REG_W16(offset + 4, rtk_le16_to_cpu(addr->addr_l_h.high));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_bssid_88xx() - config BSSID
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @addr : bssid
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_bssid_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr)
{
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (port >= HALMAC_PORTID_NUM) {
PLTFM_MSG_ERR("[ERR]port index > 5\n");
return HALMAC_RET_PORT_NOT_SUPPORT;
}
switch (port) {
case HALMAC_PORTID0:
offset = REG_BSSID;
break;
case HALMAC_PORTID1:
offset = REG_BSSID1;
break;
case HALMAC_PORTID2:
offset = REG_BSSID2;
break;
case HALMAC_PORTID3:
offset = REG_BSSID3;
break;
case HALMAC_PORTID4:
offset = REG_BSSID4;
break;
default:
return HALMAC_RET_PORT_NOT_SUPPORT;
}
HALMAC_REG_W32(offset, rtk_le32_to_cpu(addr->addr_l_h.low));
HALMAC_REG_W16(offset + 4, rtk_le16_to_cpu(addr->addr_l_h.high));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_transmitter_addr_88xx() - config transmitter address
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @addr :
* Author : Alan
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
cfg_transmitter_addr_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr)
{
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (port >= HALMAC_PORTID_NUM) {
PLTFM_MSG_ERR("[ERR]port index > 5\n");
return HALMAC_RET_PORT_NOT_SUPPORT;
}
switch (port) {
case HALMAC_PORTID0:
offset = REG_TRANSMIT_ADDRSS_0;
break;
case HALMAC_PORTID1:
offset = REG_TRANSMIT_ADDRSS_1;
break;
case HALMAC_PORTID2:
offset = REG_TRANSMIT_ADDRSS_2;
break;
case HALMAC_PORTID3:
offset = REG_TRANSMIT_ADDRSS_3;
break;
case HALMAC_PORTID4:
offset = REG_TRANSMIT_ADDRSS_4;
break;
default:
return HALMAC_RET_PORT_NOT_SUPPORT;
}
HALMAC_REG_W32(offset, rtk_le32_to_cpu(addr->addr_l_h.low));
HALMAC_REG_W16(offset + 4, rtk_le16_to_cpu(addr->addr_l_h.high));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_net_type_88xx() - config network type
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @addr : mac address
* Author : Alan
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
cfg_net_type_88xx(struct halmac_adapter *adapter, u8 port,
enum halmac_network_type_select net_type)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 value8 = 0;
u8 net_type_tmp = 0;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (net_type == HALMAC_NETWORK_AP) {
if (port >= HALMAC_PORTID1) {
PLTFM_MSG_ERR("[ERR]AP port > 1\n");
return HALMAC_RET_PORT_NOT_SUPPORT;
}
}
switch (port) {
case HALMAC_PORTID0:
net_type_tmp = net_type;
value8 = ((HALMAC_REG_R8(REG_CR + 2) & 0xFC) | net_type_tmp);
HALMAC_REG_W8(REG_CR + 2, value8);
break;
case HALMAC_PORTID1:
net_type_tmp = (net_type << 2);
value8 = ((HALMAC_REG_R8(REG_CR + 2) & 0xF3) | net_type_tmp);
HALMAC_REG_W8(REG_CR + 2, value8);
break;
case HALMAC_PORTID2:
net_type_tmp = net_type;
value8 = ((HALMAC_REG_R8(REG_CR_EXT) & 0xFC) | net_type_tmp);
HALMAC_REG_W8(REG_CR_EXT, value8);
break;
case HALMAC_PORTID3:
net_type_tmp = (net_type << 2);
value8 = ((HALMAC_REG_R8(REG_CR_EXT) & 0xF3) | net_type_tmp);
HALMAC_REG_W8(REG_CR_EXT, value8);
break;
case HALMAC_PORTID4:
net_type_tmp = (net_type << 4);
value8 = ((HALMAC_REG_R8(REG_CR_EXT) & 0xCF) | net_type_tmp);
HALMAC_REG_W8(REG_CR_EXT, value8);
break;
default:
break;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_tsf_rst_88xx() - tsf reset
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* Author : Alan
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
cfg_tsf_rst_88xx(struct halmac_adapter *adapter, u8 port)
{
u8 tsf_rst = 0;
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (port) {
case HALMAC_PORTID0:
tsf_rst = BIT_TSFTR_RST;
break;
case HALMAC_PORTID1:
tsf_rst = BIT_TSFTR_CLI0_RST;
break;
case HALMAC_PORTID2:
tsf_rst = BIT_TSFTR_CLI1_RST;
break;
case HALMAC_PORTID3:
tsf_rst = BIT_TSFTR_CLI2_RST;
break;
case HALMAC_PORTID4:
tsf_rst = BIT_TSFTR_CLI3_RST;
break;
default:
break;
}
value8 = HALMAC_REG_R8(REG_DUAL_TSF_RST);
HALMAC_REG_W8(REG_DUAL_TSF_RST, value8 | tsf_rst);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_bcn_space_88xx() - config beacon space
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @bcn_space : beacon space
* Author : Alan
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
cfg_bcn_space_88xx(struct halmac_adapter *adapter, u8 port, u32 bcn_space)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u16 bcn_space_real = 0;
u16 value16 = 0;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
bcn_space_real = ((u16)bcn_space);
switch (port) {
case HALMAC_PORTID0:
HALMAC_REG_W16(REG_MBSSID_BCN_SPACE, bcn_space_real);
break;
case HALMAC_PORTID1:
value16 = HALMAC_REG_R16(REG_MBSSID_BCN_SPACE + 2) & 0xF000;
value16 |= bcn_space_real;
HALMAC_REG_W16(REG_MBSSID_BCN_SPACE + 2, value16);
break;
case HALMAC_PORTID2:
value16 = HALMAC_REG_R16(REG_MBSSID_BCN_SPACE2) & 0xF000;
value16 |= bcn_space_real;
HALMAC_REG_W16(REG_MBSSID_BCN_SPACE2, value16);
break;
case HALMAC_PORTID3:
value16 = HALMAC_REG_R16(REG_MBSSID_BCN_SPACE2 + 2) & 0xF000;
value16 |= bcn_space_real;
HALMAC_REG_W16(REG_MBSSID_BCN_SPACE2 + 2, value16);
break;
case HALMAC_PORTID4:
value16 = HALMAC_REG_R16(REG_MBSSID_BCN_SPACE3) & 0xF000;
value16 |= bcn_space_real;
HALMAC_REG_W16(REG_MBSSID_BCN_SPACE3, value16);
break;
default:
break;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* rw_bcn_ctrl_88xx() - r/w beacon control
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @write_en : 1->write beacon function 0->read beacon function
* @pBcn_ctrl : beacon control info
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
rw_bcn_ctrl_88xx(struct halmac_adapter *adapter, u8 port, u8 write_en,
struct halmac_bcn_ctrl *ctrl)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 ctrl_value = 0;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (write_en) {
if (ctrl->dis_rx_bssid_fit == 1)
ctrl_value |= BIT_DIS_RX_BSSID_FIT;
if (ctrl->en_txbcn_rpt == 1)
ctrl_value |= BIT_P0_EN_TXBCN_RPT;
if (ctrl->dis_tsf_udt == 1)
ctrl_value |= BIT_DIS_TSF_UDT;
if (ctrl->en_bcn == 1)
ctrl_value |= BIT_EN_BCN_FUNCTION;
if (ctrl->en_rxbcn_rpt == 1)
ctrl_value |= BIT_P0_EN_RXBCN_RPT;
if (ctrl->en_p2p_ctwin == 1)
ctrl_value |= BIT_EN_P2P_CTWINDOW;
if (ctrl->en_p2p_bcn_area == 1)
ctrl_value |= BIT_EN_P2P_BCNQ_AREA;
switch (port) {
case HALMAC_PORTID0:
HALMAC_REG_W8(REG_BCN_CTRL, ctrl_value);
break;
case HALMAC_PORTID1:
HALMAC_REG_W8(REG_BCN_CTRL_CLINT0, ctrl_value);
break;
case HALMAC_PORTID2:
HALMAC_REG_W8(REG_BCN_CTRL_CLINT1, ctrl_value);
break;
case HALMAC_PORTID3:
HALMAC_REG_W8(REG_BCN_CTRL_CLINT2, ctrl_value);
break;
case HALMAC_PORTID4:
HALMAC_REG_W8(REG_BCN_CTRL_CLINT3, ctrl_value);
break;
default:
break;
}
} else {
switch (port) {
case HALMAC_PORTID0:
ctrl_value = HALMAC_REG_R8(REG_BCN_CTRL);
break;
case HALMAC_PORTID1:
ctrl_value = HALMAC_REG_R8(REG_BCN_CTRL_CLINT0);
break;
case HALMAC_PORTID2:
ctrl_value = HALMAC_REG_R8(REG_BCN_CTRL_CLINT1);
break;
case HALMAC_PORTID3:
ctrl_value = HALMAC_REG_R8(REG_BCN_CTRL_CLINT2);
break;
case HALMAC_PORTID4:
ctrl_value = HALMAC_REG_R8(REG_BCN_CTRL_CLINT3);
break;
default:
break;
}
if (ctrl_value & BIT_EN_P2P_BCNQ_AREA)
ctrl->en_p2p_bcn_area = 1;
else
ctrl->en_p2p_bcn_area = 0;
if (ctrl_value & BIT_EN_P2P_CTWINDOW)
ctrl->en_p2p_ctwin = 1;
else
ctrl->en_p2p_ctwin = 0;
if (ctrl_value & BIT_P0_EN_RXBCN_RPT)
ctrl->en_rxbcn_rpt = 1;
else
ctrl->en_rxbcn_rpt = 0;
if (ctrl_value & BIT_EN_BCN_FUNCTION)
ctrl->en_bcn = 1;
else
ctrl->en_bcn = 0;
if (ctrl_value & BIT_DIS_TSF_UDT)
ctrl->dis_tsf_udt = 1;
else
ctrl->dis_tsf_udt = 0;
if (ctrl_value & BIT_P0_EN_TXBCN_RPT)
ctrl->en_txbcn_rpt = 1;
else
ctrl->en_txbcn_rpt = 0;
if (ctrl_value & BIT_DIS_RX_BSSID_FIT)
ctrl->dis_rx_bssid_fit = 1;
else
ctrl->dis_rx_bssid_fit = 0;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_multicast_addr_88xx() - config multicast address
* @adapter : the adapter of halmac
* @addr : multicast address
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_multicast_addr_88xx(struct halmac_adapter *adapter,
union halmac_wlan_addr *addr)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
HALMAC_REG_W32(REG_MAR, rtk_le32_to_cpu(addr->addr_l_h.low));
HALMAC_REG_W16(REG_MAR + 4, rtk_le16_to_cpu(addr->addr_l_h.high));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_operation_mode_88xx() - config operation mode
* @adapter : the adapter of halmac
* @mode : 802.11 standard(b/g/n/ac)
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_operation_mode_88xx(struct halmac_adapter *adapter,
enum halmac_wireless_mode mode)
{
return HALMAC_RET_SUCCESS;
}
/**
* cfg_ch_bw_88xx() - config channel & bandwidth
* @adapter : the adapter of halmac
* @ch : WLAN channel, support 2.4G & 5G
* @idx : primary channel index, idx1, idx2, idx3, idx4
* @bw : band width, 20, 40, 80, 160, 5 ,10
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_ch_bw_88xx(struct halmac_adapter *adapter, u8 ch,
enum halmac_pri_ch_idx idx, enum halmac_bw bw)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
cfg_pri_ch_idx_88xx(adapter, idx);
cfg_bw_88xx(adapter, bw);
cfg_ch_88xx(adapter, ch);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
cfg_ch_88xx(struct halmac_adapter *adapter, u8 ch)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value8 = HALMAC_REG_R8(REG_CCK_CHECK);
value8 = value8 & (~(BIT(7)));
if (ch > 35)
value8 = value8 | BIT(7);
HALMAC_REG_W8(REG_CCK_CHECK, value8);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
cfg_pri_ch_idx_88xx(struct halmac_adapter *adapter, enum halmac_pri_ch_idx idx)
{
u8 txsc40 = 0, txsc20 = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
txsc20 = idx;
if (txsc20 == HALMAC_CH_IDX_1 || txsc20 == HALMAC_CH_IDX_3)
txsc40 = 9;
else
txsc40 = 10;
HALMAC_REG_W8(REG_DATA_SC, BIT_TXSC_20M(txsc20) | BIT_TXSC_40M(txsc40));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_bw_88xx() - config bandwidth
* @adapter : the adapter of halmac
* @bw : band width, 20, 40, 80, 160, 5 ,10
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_bw_88xx(struct halmac_adapter *adapter, enum halmac_bw bw)
{
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value32 = HALMAC_REG_R32(REG_WMAC_TRXPTCL_CTL);
value32 = value32 & (~(BIT(7) | BIT(8)));
switch (bw) {
case HALMAC_BW_80:
value32 |= BIT(8);
break;
case HALMAC_BW_40:
value32 |= BIT(7);
break;
case HALMAC_BW_20:
case HALMAC_BW_10:
case HALMAC_BW_5:
break;
default:
break;
}
HALMAC_REG_W32(REG_WMAC_TRXPTCL_CTL, value32);
cfg_mac_clk_88xx(adapter);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
void
cfg_txfifo_lt_88xx(struct halmac_adapter *adapter,
struct halmac_txfifo_lifetime_cfg *cfg)
{
u8 value8;
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (cfg->enable == 1) {
value8 = HALMAC_REG_R8(REG_LIFETIME_EN);
value8 = value8 | BIT(0) | BIT(1) | BIT(2) | BIT(3);
HALMAC_REG_W8(REG_LIFETIME_EN, value8);
value32 = (cfg->lifetime) >> 8;
value32 = value32 + (value32 << 16);
HALMAC_REG_W32(REG_PKT_LIFE_TIME, value32);
} else {
value8 = HALMAC_REG_R8(REG_LIFETIME_EN);
value8 = value8 & (~(BIT(0) | BIT(1) | BIT(2) | BIT(3)));
HALMAC_REG_W8(REG_LIFETIME_EN, value8);
}
}
enum halmac_ret_status
enable_bb_rf_88xx(struct halmac_adapter *adapter, u8 enable)
{
u8 value8;
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (enable == 1) {
status = board_rf_fine_tune_88xx(adapter);
value8 = HALMAC_REG_R8(REG_SYS_FUNC_EN);
value8 = value8 | BIT(0) | BIT(1);
HALMAC_REG_W8(REG_SYS_FUNC_EN, value8);
value8 = HALMAC_REG_R8(REG_RF_CTRL);
value8 = value8 | BIT(0) | BIT(1) | BIT(2);
HALMAC_REG_W8(REG_RF_CTRL, value8);
value32 = HALMAC_REG_R32(REG_WLRF1);
value32 = value32 | BIT(24) | BIT(25) | BIT(26);
HALMAC_REG_W32(REG_WLRF1, value32);
} else {
value8 = HALMAC_REG_R8(REG_SYS_FUNC_EN);
value8 = value8 & (~(BIT(0) | BIT(1)));
HALMAC_REG_W8(REG_SYS_FUNC_EN, value8);
value8 = HALMAC_REG_R8(REG_RF_CTRL);
value8 = value8 & (~(BIT(0) | BIT(1) | BIT(2)));
HALMAC_REG_W8(REG_RF_CTRL, value8);
value32 = HALMAC_REG_R32(REG_WLRF1);
value32 = value32 & (~(BIT(24) | BIT(25) | BIT(26)));
HALMAC_REG_W32(REG_WLRF1, value32);
}
return status;
}
static enum halmac_ret_status
board_rf_fine_tune_88xx(struct halmac_adapter *adapter)
{
u8 *map = NULL;
u32 size = adapter->hw_cfg_info.eeprom_size;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (adapter->chip_id == HALMAC_CHIP_ID_8822B) {
if (!adapter->efuse_map_valid || !adapter->efuse_map) {
PLTFM_MSG_ERR("[ERR]efuse map invalid!!\n");
return HALMAC_RET_EFUSE_R_FAIL;
}
map = (u8 *)PLTFM_MALLOC(size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, size);
if (eeprom_parser_88xx(adapter, adapter->efuse_map, map) !=
HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, size);
return HALMAC_RET_EEPROM_PARSING_FAIL;
}
/* Fine-tune XTAL voltage for 2L PCB board */
if (*(map + EFUSE_PCB_INFO_OFFSET) == 0x0C)
HALMAC_REG_W8_SET(REG_AFE_CTRL1 + 1, BIT(1));
PLTFM_FREE(map, size);
}
return HALMAC_RET_SUCCESS;
}
void
cfg_mac_clk_88xx(struct halmac_adapter *adapter)
{
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value32 = HALMAC_REG_R32(REG_AFE_CTRL1) & ~(BIT(20) | BIT(21));
value32 |= (MAC_CLK_HW_DEF_80M << BIT_SHIFT_MAC_CLK_SEL);
HALMAC_REG_W32(REG_AFE_CTRL1, value32);
HALMAC_REG_W8(REG_USTIME_TSF, MAC_CLK_SPEED);
HALMAC_REG_W8(REG_USTIME_EDCA, MAC_CLK_SPEED);
}
/**
* cfg_la_mode_88xx() - config la mode
* @adapter : the adapter of halmac
* @mode :
* disable : no TXFF space reserved for LA debug
* partial : partial TXFF space is reserved for LA debug
* full : all TXFF space is reserved for LA debug
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_la_mode_88xx(struct halmac_adapter *adapter, enum halmac_la_mode mode)
{
if (adapter->api_registry.la_mode_en == 0)
return HALMAC_RET_NOT_SUPPORT;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
adapter->txff_alloc.la_mode = mode;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_rxfifo_expand_mode_88xx() - rx fifo expanding
* @adapter : the adapter of halmac
* @mode :
* disable : normal mode
* 1 block : Rx FIFO + 1 FIFO block; Tx fifo - 1 FIFO block
* 2 block : Rx FIFO + 2 FIFO block; Tx fifo - 2 FIFO block
* 3 block : Rx FIFO + 3 FIFO block; Tx fifo - 3 FIFO block
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_rxfifo_expand_mode_88xx(struct halmac_adapter *adapter,
enum halmac_rx_fifo_expanding_mode mode)
{
if (adapter->api_registry.rx_exp_en == 0)
return HALMAC_RET_NOT_SUPPORT;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
adapter->txff_alloc.rx_fifo_exp_mode = mode;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
config_security_88xx(struct halmac_adapter *adapter,
struct halmac_security_setting *setting)
{
u8 sec_cfg;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
HALMAC_REG_W16_SET(REG_CR, BIT_MAC_SEC_EN);
if (setting->compare_keyid == 1) {
HALMAC_REG_W8_SET(REG_SECCFG + 1, BIT(0));
adapter->hw_cfg_info.chk_security_keyid = 1;
} else {
adapter->hw_cfg_info.chk_security_keyid = 0;
}
sec_cfg = HALMAC_REG_R8(REG_SECCFG);
/* BC/MC uses default key */
/* cam entry 0~3, kei id = 0 -> entry0, kei id = 1 -> entry1... */
sec_cfg |= (BIT_TXBCUSEDK | BIT_RXBCUSEDK);
if (setting->tx_encryption == 1)
sec_cfg |= BIT_TXENC;
else
sec_cfg &= ~BIT_TXENC;
if (setting->rx_decryption == 1)
sec_cfg |= BIT_RXDEC;
else
sec_cfg &= ~BIT_RXDEC;
HALMAC_REG_W8(REG_SECCFG, sec_cfg);
if (setting->bip_enable == 1) {
if (adapter->chip_id == HALMAC_CHIP_ID_8822B)
return HALMAC_RET_BIP_NO_SUPPORT;
#if (HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
sec_cfg = HALMAC_REG_R8(REG_WSEC_OPTION + 2);
if (setting->tx_encryption == 1)
sec_cfg |= (BIT(3) | BIT(5));
else
sec_cfg &= ~(BIT(3) | BIT(5));
if (setting->rx_decryption == 1)
sec_cfg |= (BIT(4) | BIT(6));
else
sec_cfg &= ~(BIT(4) | BIT(6));
HALMAC_REG_W8(REG_WSEC_OPTION + 2, sec_cfg);
#endif
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
u8
get_used_cam_entry_num_88xx(struct halmac_adapter *adapter,
enum hal_security_type sec_type)
{
u8 entry_num;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (sec_type) {
case HAL_SECURITY_TYPE_WEP40:
case HAL_SECURITY_TYPE_WEP104:
case HAL_SECURITY_TYPE_TKIP:
case HAL_SECURITY_TYPE_AES128:
case HAL_SECURITY_TYPE_GCMP128:
case HAL_SECURITY_TYPE_GCMSMS4:
case HAL_SECURITY_TYPE_BIP:
entry_num = 1;
break;
case HAL_SECURITY_TYPE_WAPI:
case HAL_SECURITY_TYPE_AES256:
case HAL_SECURITY_TYPE_GCMP256:
entry_num = 2;
break;
default:
entry_num = 0;
break;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return entry_num;
}
enum halmac_ret_status
write_cam_88xx(struct halmac_adapter *adapter, u32 idx,
struct halmac_cam_entry_info *info)
{
u32 i;
u32 cmd = 0x80010000;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
struct halmac_cam_entry_format *fmt = NULL;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (idx >= adapter->hw_cfg_info.cam_entry_num)
return HALMAC_RET_ENTRY_INDEX_ERROR;
if (info->key_id > 3)
return HALMAC_RET_FAIL;
fmt = (struct halmac_cam_entry_format *)PLTFM_MALLOC(sizeof(*fmt));
if (!fmt)
return HALMAC_RET_NULL_POINTER;
PLTFM_MEMSET(fmt, 0x00, sizeof(*fmt));
if (adapter->hw_cfg_info.chk_security_keyid == 1)
fmt->key_id = info->key_id;
fmt->valid = info->valid;
PLTFM_MEMCPY(fmt->mac_address, info->mac_address, 6);
PLTFM_MEMCPY(fmt->key, info->key, 16);
switch (info->security_type) {
case HAL_SECURITY_TYPE_NONE:
fmt->type = 0;
break;
case HAL_SECURITY_TYPE_WEP40:
fmt->type = 1;
break;
case HAL_SECURITY_TYPE_WEP104:
fmt->type = 5;
break;
case HAL_SECURITY_TYPE_TKIP:
fmt->type = 2;
break;
case HAL_SECURITY_TYPE_AES128:
fmt->type = 4;
break;
case HAL_SECURITY_TYPE_WAPI:
fmt->type = 6;
break;
case HAL_SECURITY_TYPE_AES256:
fmt->type = 4;
fmt->ext_sectype = 1;
break;
case HAL_SECURITY_TYPE_GCMP128:
fmt->type = 7;
break;
case HAL_SECURITY_TYPE_GCMP256:
case HAL_SECURITY_TYPE_GCMSMS4:
fmt->type = 7;
fmt->ext_sectype = 1;
break;
case HAL_SECURITY_TYPE_BIP:
fmt->type = (info->unicast == 1) ? 4 : 0;
fmt->mgnt = 1;
fmt->grp = (info->unicast == 1) ? 0 : 1;
break;
default:
PLTFM_FREE(fmt, sizeof(*fmt));
return HALMAC_RET_FAIL;
}
for (i = 0; i < 8; i++) {
HALMAC_REG_W32(REG_CAMWRITE, *((u32 *)fmt + i));
HALMAC_REG_W32(REG_CAMCMD, cmd | ((idx << 3) + i));
}
if (info->security_type == HAL_SECURITY_TYPE_WAPI ||
info->security_type == HAL_SECURITY_TYPE_AES256 ||
info->security_type == HAL_SECURITY_TYPE_GCMP256 ||
info->security_type == HAL_SECURITY_TYPE_GCMSMS4) {
fmt->mic = 1;
PLTFM_MEMCPY(fmt->key, info->key_ext, 16);
idx++;
for (i = 0; i < 8; i++) {
HALMAC_REG_W32(REG_CAMWRITE, *((u32 *)fmt + i));
HALMAC_REG_W32(REG_CAMCMD, cmd | ((idx << 3) + i));
}
}
PLTFM_FREE(fmt, sizeof(*fmt));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
read_cam_entry_88xx(struct halmac_adapter *adapter, u32 idx,
struct halmac_cam_entry_format *content)
{
u32 i;
u32 cmd = 0x80000000;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (idx >= adapter->hw_cfg_info.cam_entry_num)
return HALMAC_RET_ENTRY_INDEX_ERROR;
for (i = 0; i < 8; i++) {
HALMAC_REG_W32(REG_CAMCMD, cmd | ((idx << 3) + i));
*((u32 *)content + i) = HALMAC_REG_R32(REG_CAMREAD);
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
clear_cam_entry_88xx(struct halmac_adapter *adapter, u32 idx)
{
u32 i;
u32 cmd = 0x80010000;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
struct halmac_cam_entry_format *fmt = NULL;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (idx >= adapter->hw_cfg_info.cam_entry_num)
return HALMAC_RET_ENTRY_INDEX_ERROR;
fmt = (struct halmac_cam_entry_format *)PLTFM_MALLOC(sizeof(*fmt));
if (!fmt)
return HALMAC_RET_NULL_POINTER;
PLTFM_MEMSET(fmt, 0x00, sizeof(*fmt));
for (i = 0; i < 8; i++) {
HALMAC_REG_W32(REG_CAMWRITE, *((u32 *)fmt + i));
HALMAC_REG_W32(REG_CAMCMD, cmd | ((idx << 3) + i));
}
PLTFM_FREE(fmt, sizeof(*fmt));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
void
rx_shift_88xx(struct halmac_adapter *adapter, u8 enable)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_TXDMA_PQ_MAP);
if (enable == 1)
HALMAC_REG_W8(REG_TXDMA_PQ_MAP, value8 | BIT(1));
else
HALMAC_REG_W8(REG_TXDMA_PQ_MAP, value8 & ~(BIT(1)));
}
/**
* cfg_edca_para_88xx() - config edca parameter
* @adapter : the adapter of halmac
* @acq_id : VO/VI/BE/BK
* @param : aifs, cw, txop limit
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_edca_para_88xx(struct halmac_adapter *adapter, enum halmac_acq_id acq_id,
struct halmac_edca_para *param)
{
u32 offset;
u32 value32;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (acq_id) {
case HALMAC_ACQ_ID_VO:
offset = REG_EDCA_VO_PARAM;
break;
case HALMAC_ACQ_ID_VI:
offset = REG_EDCA_VI_PARAM;
break;
case HALMAC_ACQ_ID_BE:
offset = REG_EDCA_BE_PARAM;
break;
case HALMAC_ACQ_ID_BK:
offset = REG_EDCA_BK_PARAM;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
param->txop_limit &= 0x7FF;
value32 = (param->aifs) | (param->cw << 8) | (param->txop_limit << 16);
HALMAC_REG_W32(offset, value32);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
void
rx_clk_gate_88xx(struct halmac_adapter *adapter, u8 enable)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_RCR + 2);
if (enable == 1)
HALMAC_REG_W8(REG_RCR + 2, value8 & ~(BIT(3)));
else
HALMAC_REG_W8(REG_RCR + 2, value8 | BIT(3));
}
enum halmac_ret_status
rx_cut_amsdu_cfg_88xx(struct halmac_adapter *adapter,
struct halmac_cut_amsdu_cfg *cfg)
{
return HALMAC_RET_NOT_SUPPORT;
}
enum halmac_ret_status
fast_edca_cfg_88xx(struct halmac_adapter *adapter,
struct halmac_fast_edca_cfg *cfg)
{
u16 value16;
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (cfg->acq_id) {
case HALMAC_ACQ_ID_VO:
offset = REG_FAST_EDCA_VOVI_SETTING;
break;
case HALMAC_ACQ_ID_VI:
offset = REG_FAST_EDCA_VOVI_SETTING + 2;
break;
case HALMAC_ACQ_ID_BE:
offset = REG_FAST_EDCA_BEBK_SETTING;
break;
case HALMAC_ACQ_ID_BK:
offset = REG_FAST_EDCA_BEBK_SETTING + 2;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
value16 = HALMAC_REG_R16(offset);
value16 &= 0xFF;
value16 = value16 | (cfg->queue_to << 8);
HALMAC_REG_W16(offset, value16);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* get_mac_addr_88xx() - get mac address
* @adapter : the adapter of halmac
* @port : 0 for port0, 1 for port1, 2 for port2, 3 for port3, 4 for port4
* @addr : mac address
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_mac_addr_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr)
{
u16 mac_addr_h;
u32 mac_addr_l;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (port >= HALMAC_PORTID_NUM) {
PLTFM_MSG_ERR("[ERR]port index >= 5\n");
return HALMAC_RET_PORT_NOT_SUPPORT;
}
switch (port) {
case HALMAC_PORTID0:
mac_addr_l = HALMAC_REG_R32(REG_MACID);
mac_addr_h = HALMAC_REG_R16(REG_MACID + 4);
break;
case HALMAC_PORTID1:
mac_addr_l = HALMAC_REG_R32(REG_MACID1);
mac_addr_h = HALMAC_REG_R16(REG_MACID1 + 4);
break;
case HALMAC_PORTID2:
mac_addr_l = HALMAC_REG_R32(REG_MACID2);
mac_addr_h = HALMAC_REG_R16(REG_MACID2 + 4);
break;
case HALMAC_PORTID3:
mac_addr_l = HALMAC_REG_R32(REG_MACID3);
mac_addr_h = HALMAC_REG_R16(REG_MACID3 + 4);
break;
case HALMAC_PORTID4:
mac_addr_l = HALMAC_REG_R32(REG_MACID4);
mac_addr_h = HALMAC_REG_R16(REG_MACID4 + 4);
break;
default:
return HALMAC_RET_PORT_NOT_SUPPORT;
}
addr->addr_l_h.low = rtk_cpu_to_le32(mac_addr_l);
addr->addr_l_h.high = rtk_cpu_to_le16(mac_addr_h);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
void
rts_full_bw_88xx(struct halmac_adapter *adapter, u8 enable)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_INIRTS_RATE_SEL);
if (enable == 1)
HALMAC_REG_W8(REG_INIRTS_RATE_SEL, value8 | BIT(5));
else
HALMAC_REG_W8(REG_INIRTS_RATE_SEL, value8 & ~(BIT(5)));
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_cfg_wmac_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_CFG_WMAC_88XX_H_
#define _HALMAC_CFG_WMAC_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
cfg_mac_addr_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
enum halmac_ret_status
cfg_bssid_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
enum halmac_ret_status
cfg_transmitter_addr_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
enum halmac_ret_status
cfg_net_type_88xx(struct halmac_adapter *adapter, u8 port,
enum halmac_network_type_select net_type);
enum halmac_ret_status
cfg_tsf_rst_88xx(struct halmac_adapter *adapter, u8 port);
enum halmac_ret_status
cfg_bcn_space_88xx(struct halmac_adapter *adapter, u8 port, u32 bcn_space);
enum halmac_ret_status
rw_bcn_ctrl_88xx(struct halmac_adapter *adapter, u8 port, u8 write_en,
struct halmac_bcn_ctrl *ctrl);
enum halmac_ret_status
cfg_multicast_addr_88xx(struct halmac_adapter *adapter,
union halmac_wlan_addr *addr);
enum halmac_ret_status
cfg_operation_mode_88xx(struct halmac_adapter *adapter,
enum halmac_wireless_mode mode);
enum halmac_ret_status
cfg_ch_bw_88xx(struct halmac_adapter *adapter, u8 ch,
enum halmac_pri_ch_idx idx, enum halmac_bw bw);
enum halmac_ret_status
cfg_ch_88xx(struct halmac_adapter *adapter, u8 ch);
enum halmac_ret_status
cfg_pri_ch_idx_88xx(struct halmac_adapter *adapter, enum halmac_pri_ch_idx idx);
enum halmac_ret_status
cfg_bw_88xx(struct halmac_adapter *adapter, enum halmac_bw bw);
void
cfg_txfifo_lt_88xx(struct halmac_adapter *adapter,
struct halmac_txfifo_lifetime_cfg *cfg);
enum halmac_ret_status
enable_bb_rf_88xx(struct halmac_adapter *adapter, u8 enable);
enum halmac_ret_status
cfg_la_mode_88xx(struct halmac_adapter *adapter, enum halmac_la_mode mode);
enum halmac_ret_status
cfg_rxfifo_expand_mode_88xx(struct halmac_adapter *adapter,
enum halmac_rx_fifo_expanding_mode mode);
enum halmac_ret_status
config_security_88xx(struct halmac_adapter *adapter,
struct halmac_security_setting *setting);
u8
get_used_cam_entry_num_88xx(struct halmac_adapter *adapter,
enum hal_security_type sec_type);
enum halmac_ret_status
write_cam_88xx(struct halmac_adapter *adapter, u32 idx,
struct halmac_cam_entry_info *info);
enum halmac_ret_status
read_cam_entry_88xx(struct halmac_adapter *adapter, u32 idx,
struct halmac_cam_entry_format *content);
enum halmac_ret_status
clear_cam_entry_88xx(struct halmac_adapter *adapter, u32 idx);
void
rx_shift_88xx(struct halmac_adapter *adapter, u8 enable);
enum halmac_ret_status
cfg_edca_para_88xx(struct halmac_adapter *adapter, enum halmac_acq_id acq_id,
struct halmac_edca_para *param);
void
rx_clk_gate_88xx(struct halmac_adapter *adapter, u8 enable);
enum halmac_ret_status
rx_cut_amsdu_cfg_88xx(struct halmac_adapter *adapter,
struct halmac_cut_amsdu_cfg *cfg);
enum halmac_ret_status
fast_edca_cfg_88xx(struct halmac_adapter *adapter,
struct halmac_fast_edca_cfg *cfg);
enum halmac_ret_status
get_mac_addr_88xx(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
void
rts_full_bw_88xx(struct halmac_adapter *adapter, u8 enable);
void
cfg_mac_clk_88xx(struct halmac_adapter *adapter);
#endif/* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_CFG_WMAC_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_common_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_common_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_init_88xx.h"
#include "halmac_cfg_wmac_88xx.h"
#include "halmac_efuse_88xx.h"
#include "halmac_bb_rf_88xx.h"
#if HALMAC_USB_SUPPORT
#include "halmac_usb_88xx.h"
#endif
#if HALMAC_SDIO_SUPPORT
#include "halmac_sdio_88xx.h"
#endif
#if HALMAC_PCIE_SUPPORT
#include "halmac_pcie_88xx.h"
#endif
#include "halmac_mimo_88xx.h"
#if HALMAC_88XX_SUPPORT
#define CFG_PARAM_H2C_INFO_SIZE 12
#define ORIGINAL_H2C_CMD_SIZE 8
#define WLHDR_PROT_VER 0
#define WLHDR_TYPE_MGMT 0
#define WLHDR_TYPE_CTRL 1
#define WLHDR_TYPE_DATA 2
/* mgmt frame */
#define WLHDR_SUB_TYPE_ASSOC_REQ 0
#define WLHDR_SUB_TYPE_ASSOC_RSPNS 1
#define WLHDR_SUB_TYPE_REASSOC_REQ 2
#define WLHDR_SUB_TYPE_REASSOC_RSPNS 3
#define WLHDR_SUB_TYPE_PROBE_REQ 4
#define WLHDR_SUB_TYPE_PROBE_RSPNS 5
#define WLHDR_SUB_TYPE_BCN 8
#define WLHDR_SUB_TYPE_DISASSOC 10
#define WLHDR_SUB_TYPE_AUTH 11
#define WLHDR_SUB_TYPE_DEAUTH 12
#define WLHDR_SUB_TYPE_ACTION 13
#define WLHDR_SUB_TYPE_ACTION_NOACK 14
/* ctrl frame */
#define WLHDR_SUB_TYPE_BF_RPT_POLL 4
#define WLHDR_SUB_TYPE_NDPA 5
/* data frame */
#define WLHDR_SUB_TYPE_DATA 0
#define WLHDR_SUB_TYPE_NULL 4
#define WLHDR_SUB_TYPE_QOS_DATA 8
#define WLHDR_SUB_TYPE_QOS_NULL 12
#define LTECOEX_ACCESS_CTRL REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1
struct wlhdr_frame_ctrl {
u16 protocol:2;
u16 type:2;
u16 sub_type:4;
u16 to_ds:1;
u16 from_ds:1;
u16 more_frag:1;
u16 retry:1;
u16 pwr_mgmt:1;
u16 more_data:1;
u16 protect_frame:1;
u16 order:1;
};
static enum halmac_ret_status
parse_c2h_pkt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_c2h_dbg_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_h2c_ack_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_scan_rpt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_h2c_ack_cfg_param_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_h2c_ack_update_pkt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_h2c_ack_update_datapkt_88xx(struct halmac_adapter *adapter, u8 *buf,
u32 size);
static enum halmac_ret_status
get_h2c_ack_run_datapkt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
get_h2c_ack_ch_switch_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
static enum halmac_ret_status
malloc_cfg_param_buf_88xx(struct halmac_adapter *adapter, u8 full_fifo);
static enum halmac_cmd_construct_state
cfg_param_cmd_cnstr_state_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
proc_cfg_param_88xx(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *param, u8 full_fifo);
static enum halmac_ret_status
send_cfg_param_h2c_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
cnv_cfg_param_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state);
static enum halmac_ret_status
add_param_buf_88xx(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *param, u8 *buf,
u8 *end_cmd);
static enum halmac_ret_status
gen_cfg_param_h2c_88xx(struct halmac_adapter *adapter, u8 *buff);
static enum halmac_ret_status
send_h2c_update_packet_88xx(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id, u8 *pkt, u32 size);
static enum halmac_ret_status
send_bt_coex_cmd_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
u8 ack);
static enum halmac_ret_status
read_buf_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
enum hal_fifo_sel sel, u8 *data);
static enum halmac_cmd_construct_state
scan_cmd_cnstr_state_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
cnv_scan_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state);
static enum halmac_ret_status
proc_ctrl_ch_switch_88xx(struct halmac_adapter *adapter,
struct halmac_ch_switch_option *opt);
static enum halmac_ret_status
proc_p2pps_88xx(struct halmac_adapter *adapter, struct halmac_p2pps *info);
static enum halmac_ret_status
get_cfg_param_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status);
static enum halmac_ret_status
get_ch_switch_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status);
static enum halmac_ret_status
get_update_packet_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status);
static enum halmac_ret_status
pwr_sub_seq_parser_88xx(struct halmac_adapter *adapter, u8 cut, u8 intf,
struct halmac_wlan_pwr_cfg *cmd);
static void
pwr_state_88xx(struct halmac_adapter *adapter, enum halmac_mac_power *state);
static enum halmac_ret_status
pwr_cmd_polling_88xx(struct halmac_adapter *adapter,
struct halmac_wlan_pwr_cfg *cmd);
static void
get_pq_mapping_88xx(struct halmac_adapter *adapter,
struct halmac_rqpn_map *mapping);
static void
dump_reg_sdio_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
wlhdr_valid_88xx(struct halmac_adapter *adapter, u8 *buf);
static u8
wlhdr_mgmt_valid_88xx(struct halmac_adapter *adapter,
struct wlhdr_frame_ctrl *wlhdr);
static u8
wlhdr_ctrl_valid_88xx(struct halmac_adapter *adapter,
struct wlhdr_frame_ctrl *wlhdr);
static u8
wlhdr_data_valid_88xx(struct halmac_adapter *adapter,
struct wlhdr_frame_ctrl *wlhdr);
static void
dump_reg_88xx(struct halmac_adapter *adapter);
static u8
packet_in_nlo_88xx(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id);
static enum halmac_packet_id
get_real_pkt_id_88xx(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id);
/**
* ofld_func_cfg_88xx() - config offload function
* @adapter : the adapter of halmac
* @info : offload function information
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
ofld_func_cfg_88xx(struct halmac_adapter *adapter,
struct halmac_ofld_func_info *info)
{
if (adapter->intf == HALMAC_INTERFACE_SDIO &&
info->rsvd_pg_drv_buf_max_sz > SDIO_TX_MAX_SIZE_88XX)
return HALMAC_RET_FAIL;
adapter->pltfm_info.malloc_size = info->halmac_malloc_max_sz;
adapter->pltfm_info.rsvd_pg_size = info->rsvd_pg_drv_buf_max_sz;
return HALMAC_RET_SUCCESS;
}
/**
* dl_drv_rsvd_page_88xx() - download packet to rsvd page
* @adapter : the adapter of halmac
* @pg_offset : page offset of driver's rsvd page
* @halmac_buf : data to be downloaded, tx_desc is not included
* @halmac_size : data size to be downloaded
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
dl_drv_rsvd_page_88xx(struct halmac_adapter *adapter, u8 pg_offset, u8 *buf,
u32 size)
{
enum halmac_ret_status status;
u32 pg_size;
u32 pg_num = 0;
u16 pg_addr = 0;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
pg_size = adapter->hw_cfg_info.page_size;
pg_num = size / pg_size + ((size & (pg_size - 1)) ? 1 : 0);
if (pg_offset + pg_num > adapter->txff_alloc.rsvd_drv_pg_num) {
PLTFM_MSG_ERR("[ERR] pkt overflow!!\n");
return HALMAC_RET_DRV_DL_ERR;
}
pg_addr = adapter->txff_alloc.rsvd_drv_addr + pg_offset;
status = dl_rsvd_page_88xx(adapter, pg_addr, buf, size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dl rsvd page fail!!\n");
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
dl_rsvd_page_88xx(struct halmac_adapter *adapter, u16 pg_addr, u8 *buf,
u32 size)
{
u8 restore[2];
u8 value8;
u16 rsvd_pg_head;
u32 cnt;
enum halmac_rsvd_pg_state *state = &adapter->halmac_state.rsvd_pg_state;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (size == 0) {
PLTFM_MSG_TRACE("[TRACE]pkt size = 0\n");
return HALMAC_RET_ZERO_LEN_RSVD_PACKET;
}
if (*state == HALMAC_RSVD_PG_STATE_BUSY)
return HALMAC_RET_BUSY_STATE;
*state = HALMAC_RSVD_PG_STATE_BUSY;
pg_addr &= BIT_MASK_BCN_HEAD_1_V1;
HALMAC_REG_W16(REG_FIFOPAGE_CTRL_2, (u16)(pg_addr | BIT(15)));
value8 = HALMAC_REG_R8(REG_CR + 1);
restore[0] = value8;
value8 = (u8)(value8 | BIT(0));
HALMAC_REG_W8(REG_CR + 1, value8);
value8 = HALMAC_REG_R8(REG_FWHW_TXQ_CTRL + 2);
restore[1] = value8;
value8 = (u8)(value8 & ~(BIT(6)));
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 2, value8);
if (PLTFM_SEND_RSVD_PAGE(buf, size) == 0) {
PLTFM_MSG_ERR("[ERR]send rvsd pg(pltfm)!!\n");
status = HALMAC_RET_DL_RSVD_PAGE_FAIL;
goto DL_RSVD_PG_END;
}
cnt = 1000;
while (!(HALMAC_REG_R8(REG_FIFOPAGE_CTRL_2 + 1) & BIT(7))) {
PLTFM_DELAY_US(10);
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]bcn valid!!\n");
status = HALMAC_RET_POLLING_BCN_VALID_FAIL;
break;
}
}
DL_RSVD_PG_END:
rsvd_pg_head = adapter->txff_alloc.rsvd_boundary;
HALMAC_REG_W16(REG_FIFOPAGE_CTRL_2, rsvd_pg_head | BIT(15));
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 2, restore[1]);
HALMAC_REG_W8(REG_CR + 1, restore[0]);
*state = HALMAC_RSVD_PG_STATE_IDLE;
return status;
}
enum halmac_ret_status
get_hw_value_88xx(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (hw_id) {
case HALMAC_HW_RQPN_MAPPING:
get_pq_mapping_88xx(adapter, (struct halmac_rqpn_map *)value);
break;
case HALMAC_HW_EFUSE_SIZE:
*(u32 *)value = adapter->hw_cfg_info.efuse_size;
break;
case HALMAC_HW_EEPROM_SIZE:
*(u32 *)value = adapter->hw_cfg_info.eeprom_size;
break;
case HALMAC_HW_BT_BANK_EFUSE_SIZE:
*(u32 *)value = adapter->hw_cfg_info.bt_efuse_size;
break;
case HALMAC_HW_BT_BANK1_EFUSE_SIZE:
case HALMAC_HW_BT_BANK2_EFUSE_SIZE:
*(u32 *)value = 0;
break;
case HALMAC_HW_TXFIFO_SIZE:
*(u32 *)value = adapter->hw_cfg_info.tx_fifo_size;
break;
case HALMAC_HW_RXFIFO_SIZE:
*(u32 *)value = adapter->hw_cfg_info.rx_fifo_size;
break;
case HALMAC_HW_RSVD_PG_BNDY:
*(u16 *)value = adapter->txff_alloc.rsvd_drv_addr;
break;
case HALMAC_HW_CAM_ENTRY_NUM:
*(u8 *)value = adapter->hw_cfg_info.cam_entry_num;
break;
case HALMAC_HW_WLAN_EFUSE_AVAILABLE_SIZE:
get_efuse_available_size_88xx(adapter, (u32 *)value);
break;
case HALMAC_HW_IC_VERSION:
*(u8 *)value = adapter->chip_ver;
break;
case HALMAC_HW_PAGE_SIZE:
*(u32 *)value = adapter->hw_cfg_info.page_size;
break;
case HALMAC_HW_TX_AGG_ALIGN_SIZE:
*(u16 *)value = adapter->hw_cfg_info.tx_align_size;
break;
case HALMAC_HW_RX_AGG_ALIGN_SIZE:
*(u8 *)value = 8;
break;
case HALMAC_HW_DRV_INFO_SIZE:
*(u8 *)value = adapter->drv_info_size;
break;
case HALMAC_HW_TXFF_ALLOCATION:
PLTFM_MEMCPY(value, &adapter->txff_alloc,
sizeof(struct halmac_txff_allocation));
break;
case HALMAC_HW_RSVD_EFUSE_SIZE:
*(u32 *)value = get_rsvd_efuse_size_88xx(adapter);
break;
case HALMAC_HW_FW_HDR_SIZE:
*(u32 *)value = WLAN_FW_HDR_SIZE;
break;
case HALMAC_HW_TX_DESC_SIZE:
*(u32 *)value = adapter->hw_cfg_info.txdesc_size;
break;
case HALMAC_HW_RX_DESC_SIZE:
*(u32 *)value = adapter->hw_cfg_info.rxdesc_size;
break;
case HALMAC_HW_ORI_H2C_SIZE:
*(u32 *)value = ORIGINAL_H2C_CMD_SIZE;
break;
case HALMAC_HW_RSVD_DRV_PGNUM:
*(u16 *)value = adapter->txff_alloc.rsvd_drv_pg_num;
break;
case HALMAC_HW_TX_PAGE_SIZE:
*(u16 *)value = TX_PAGE_SIZE_88XX;
break;
case HALMAC_HW_USB_TXAGG_DESC_NUM:
*(u8 *)value = adapter->hw_cfg_info.usb_txagg_num;
break;
case HALMAC_HW_AC_OQT_SIZE:
*(u8 *)value = adapter->hw_cfg_info.ac_oqt_size;
break;
case HALMAC_HW_NON_AC_OQT_SIZE:
*(u8 *)value = adapter->hw_cfg_info.non_ac_oqt_size;
break;
case HALMAC_HW_AC_QUEUE_NUM:
*(u8 *)value = adapter->hw_cfg_info.acq_num;
break;
case HALMAC_HW_PWR_STATE:
pwr_state_88xx(adapter, (enum halmac_mac_power *)value);
break;
default:
return HALMAC_RET_PARA_NOT_SUPPORT;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static void
get_pq_mapping_88xx(struct halmac_adapter *adapter,
struct halmac_rqpn_map *mapping)
{
mapping->dma_map_vo = adapter->pq_map[HALMAC_PQ_MAP_VO];
mapping->dma_map_vi = adapter->pq_map[HALMAC_PQ_MAP_VI];
mapping->dma_map_be = adapter->pq_map[HALMAC_PQ_MAP_BE];
mapping->dma_map_bk = adapter->pq_map[HALMAC_PQ_MAP_BK];
mapping->dma_map_mg = adapter->pq_map[HALMAC_PQ_MAP_MG];
mapping->dma_map_hi = adapter->pq_map[HALMAC_PQ_MAP_HI];
}
/**
* set_hw_value_88xx() -set hw config value
* @adapter : the adapter of halmac
* @hw_id : hw id for driver to config
* @value : hw value, reference table to get data type
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
set_hw_value_88xx(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_tx_page_threshold_info *th_info = NULL;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (!value) {
PLTFM_MSG_ERR("[ERR]null ptr-set hw value\n");
return HALMAC_RET_NULL_POINTER;
}
switch (hw_id) {
#if HALMAC_USB_SUPPORT
case HALMAC_HW_USB_MODE:
status = set_usb_mode_88xx(adapter,
*(enum halmac_usb_mode *)value);
if (status != HALMAC_RET_SUCCESS)
return status;
break;
#endif
case HALMAC_HW_BANDWIDTH:
cfg_bw_88xx(adapter, *(enum halmac_bw *)value);
break;
case HALMAC_HW_CHANNEL:
cfg_ch_88xx(adapter, *(u8 *)value);
break;
case HALMAC_HW_PRI_CHANNEL_IDX:
cfg_pri_ch_idx_88xx(adapter, *(enum halmac_pri_ch_idx *)value);
break;
case HALMAC_HW_EN_BB_RF:
status = enable_bb_rf_88xx(adapter, *(u8 *)value);
if (status != HALMAC_RET_SUCCESS)
return status;
break;
#if HALMAC_SDIO_SUPPORT
case HALMAC_HW_SDIO_TX_PAGE_THRESHOLD:
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
th_info = (struct halmac_tx_page_threshold_info *)value;
cfg_sdio_tx_page_threshold_88xx(adapter, th_info);
} else {
return HALMAC_RET_FAIL;
}
break;
#endif
case HALMAC_HW_RX_SHIFT:
rx_shift_88xx(adapter, *(u8 *)value);
break;
case HALMAC_HW_TXDESC_CHECKSUM:
tx_desc_chksum_88xx(adapter, *(u8 *)value);
break;
case HALMAC_HW_RX_CLK_GATE:
rx_clk_gate_88xx(adapter, *(u8 *)value);
break;
case HALMAC_HW_FAST_EDCA:
fast_edca_cfg_88xx(adapter,
(struct halmac_fast_edca_cfg *)value);
break;
case HALMAC_HW_RTS_FULL_BW:
rts_full_bw_88xx(adapter, *(u8 *)value);
break;
case HALMAC_HW_FREE_CNT_EN:
HALMAC_REG_W8_SET(REG_MISC_CTRL, BIT_EN_FREECNT);
break;
case HALMAC_HW_TXFIFO_LIFETIME:
cfg_txfifo_lt_88xx(adapter,
(struct halmac_txfifo_lifetime_cfg *)value);
default:
return HALMAC_RET_PARA_NOT_SUPPORT;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
set_h2c_pkt_hdr_88xx(struct halmac_adapter *adapter, u8 *hdr,
struct halmac_h2c_header_info *info, u16 *seq_num)
{
u16 total_size;
PLTFM_MSG_TRACE("[TRACE]%s!!\n", __func__);
total_size = H2C_PKT_HDR_SIZE_88XX + info->content_size;
FW_OFFLOAD_H2C_SET_TOTAL_LEN(hdr, total_size);
FW_OFFLOAD_H2C_SET_SUB_CMD_ID(hdr, info->sub_cmd_id);
FW_OFFLOAD_H2C_SET_CATEGORY(hdr, 0x01);
FW_OFFLOAD_H2C_SET_CMD_ID(hdr, 0xFF);
PLTFM_MUTEX_LOCK(&adapter->h2c_seq_mutex);
FW_OFFLOAD_H2C_SET_SEQ_NUM(hdr, adapter->h2c_info.seq_num);
*seq_num = adapter->h2c_info.seq_num;
(adapter->h2c_info.seq_num)++;
PLTFM_MUTEX_UNLOCK(&adapter->h2c_seq_mutex);
if (info->ack == 1)
FW_OFFLOAD_H2C_SET_ACK(hdr, 1);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
send_h2c_pkt_88xx(struct halmac_adapter *adapter, u8 *pkt)
{
u32 cnt = 100;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
while (adapter->h2c_info.buf_fs <= H2C_PKT_SIZE_88XX) {
get_h2c_buf_free_space_88xx(adapter);
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]h2c free space!!\n");
return HALMAC_RET_H2C_SPACE_FULL;
}
}
cnt = 100;
do {
if (PLTFM_SEND_H2C_PKT(pkt, H2C_PKT_SIZE_88XX) == 1)
break;
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]pltfm - sned h2c pkt!!\n");
return HALMAC_RET_SEND_H2C_FAIL;
}
PLTFM_DELAY_US(5);
} while (1);
adapter->h2c_info.buf_fs -= H2C_PKT_SIZE_88XX;
return status;
}
enum halmac_ret_status
get_h2c_buf_free_space_88xx(struct halmac_adapter *adapter)
{
u32 hw_wptr;
u32 fw_rptr;
struct halmac_h2c_info *info = &adapter->h2c_info;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
hw_wptr = HALMAC_REG_R32(REG_H2C_PKT_WRITEADDR) & 0x3FFFF;
fw_rptr = HALMAC_REG_R32(REG_H2C_PKT_READADDR) & 0x3FFFF;
if (hw_wptr >= fw_rptr)
info->buf_fs = info->buf_size - (hw_wptr - fw_rptr);
else
info->buf_fs = fw_rptr - hw_wptr;
return HALMAC_RET_SUCCESS;
}
/**
* get_c2h_info_88xx() - process halmac C2H packet
* @adapter : the adapter of halmac
* @buf : RX Packet pointer
* @size : RX Packet size
*
* Note : Don't use any IO or DELAY in this API
*
* Author : KaiYuan Chang/Ivan Lin
*
* Used to process c2h packet info from RX path. After receiving the packet,
* user need to call this api and pass the packet pointer.
*
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_c2h_info_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (GET_RX_DESC_C2H(buf) == 1) {
PLTFM_MSG_TRACE("[TRACE]Parse c2h pkt\n");
status = parse_c2h_pkt_88xx(adapter, buf, size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]Parse c2h pkt\n");
return status;
}
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
parse_c2h_pkt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 cmd_id;
u8 sub_cmd_id;
u8 *c2h_pkt = buf + adapter->hw_cfg_info.rxdesc_size;
u32 c2h_size = size - adapter->hw_cfg_info.rxdesc_size;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
cmd_id = (u8)C2H_HDR_GET_CMD_ID(c2h_pkt);
if (cmd_id != 0xFF) {
PLTFM_MSG_TRACE("[TRACE]Not 0xFF cmd!!\n");
return HALMAC_RET_C2H_NOT_HANDLED;
}
sub_cmd_id = (u8)C2H_HDR_GET_C2H_SUB_CMD_ID(c2h_pkt);
switch (sub_cmd_id) {
case C2H_SUB_CMD_ID_C2H_DBG:
status = get_c2h_dbg_88xx(adapter, c2h_pkt, c2h_size);
break;
case C2H_SUB_CMD_ID_H2C_ACK_HDR:
status = get_h2c_ack_88xx(adapter, c2h_pkt, c2h_size);
break;
case C2H_SUB_CMD_ID_BT_COEX_INFO:
status = HALMAC_RET_C2H_NOT_HANDLED;
break;
case C2H_SUB_CMD_ID_SCAN_STATUS_RPT:
status = get_scan_rpt_88xx(adapter, c2h_pkt, c2h_size);
break;
case C2H_SUB_CMD_ID_PSD_DATA:
status = get_psd_data_88xx(adapter, c2h_pkt, c2h_size);
break;
case C2H_SUB_CMD_ID_EFUSE_DATA:
status = get_efuse_data_88xx(adapter, c2h_pkt, c2h_size);
break;
default:
PLTFM_MSG_WARN("[WARN]Sub cmd id!!\n");
status = HALMAC_RET_C2H_NOT_HANDLED;
break;
}
return status;
}
static enum halmac_ret_status
get_c2h_dbg_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 i;
u8 next_msg = 0;
u8 cur_msg = 0;
u8 msg_len = 0;
char *c2h_buf = (char *)NULL;
u8 content_len = 0;
u8 seq_num = 0;
content_len = (u8)C2H_HDR_GET_LEN((u8 *)buf);
if (content_len > C2H_DBG_CONTENT_MAX_LENGTH) {
PLTFM_MSG_ERR("[ERR]c2h size > max len!\n");
return HALMAC_RET_C2H_NOT_HANDLED;
}
for (i = 0; i < content_len; i++) {
if (*(buf + C2H_DBG_HDR_LEN + i) == '\n') {
if ((*(buf + C2H_DBG_HDR_LEN + i + 1) == '\0') ||
(*(buf + C2H_DBG_HDR_LEN + i + 1) == 0xff)) {
next_msg = C2H_DBG_HDR_LEN + i + 1;
goto _ENDFOUND;
}
}
}
_ENDFOUND:
msg_len = next_msg - C2H_DBG_HDR_LEN;
c2h_buf = (char *)PLTFM_MALLOC(msg_len);
if (!c2h_buf)
return HALMAC_RET_MALLOC_FAIL;
PLTFM_MEMCPY(c2h_buf, buf + C2H_DBG_HDR_LEN, msg_len);
seq_num = (u8)(*(c2h_buf));
*(c2h_buf + msg_len - 1) = '\0';
PLTFM_MSG_ALWAYS("[RTKFW, SEQ=%d]: %s\n",
seq_num, (char *)(c2h_buf + 1));
PLTFM_FREE(c2h_buf, msg_len);
while (*(buf + next_msg) != '\0') {
cur_msg = next_msg;
msg_len = (u8)(*(buf + cur_msg + 3)) - 1;
next_msg += C2H_DBG_HDR_LEN + msg_len;
c2h_buf = (char *)PLTFM_MALLOC(msg_len);
if (!c2h_buf)
return HALMAC_RET_MALLOC_FAIL;
PLTFM_MEMCPY(c2h_buf, buf + cur_msg + C2H_DBG_HDR_LEN, msg_len);
*(c2h_buf + msg_len - 1) = '\0';
seq_num = (u8)(*(c2h_buf));
PLTFM_MSG_ALWAYS("[RTKFW, SEQ=%d]: %s\n",
seq_num, (char *)(c2h_buf + 1));
PLTFM_FREE(c2h_buf, msg_len);
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_h2c_ack_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 cmd_id;
u8 sub_cmd_id;
u8 fw_rc;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]Ack for C2H!!\n");
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
if (HALMAC_H2C_RETURN_SUCCESS != (enum halmac_h2c_return_code)fw_rc)
PLTFM_MSG_TRACE("[TRACE]fw rc = %d\n", fw_rc);
cmd_id = (u8)H2C_ACK_HDR_GET_H2C_CMD_ID(buf);
if (cmd_id != 0xFF) {
PLTFM_MSG_ERR("[ERR]h2c ack cmd id!!\n");
return HALMAC_RET_C2H_NOT_HANDLED;
}
sub_cmd_id = (u8)H2C_ACK_HDR_GET_H2C_SUB_CMD_ID(buf);
switch (sub_cmd_id) {
case H2C_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK:
status = get_h2c_ack_phy_efuse_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_CFG_PARAM_ACK:
status = get_h2c_ack_cfg_param_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_UPDATE_PKT_ACK:
status = get_h2c_ack_update_pkt_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_UPDATE_DATAPACK_ACK:
status = get_h2c_ack_update_datapkt_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_RUN_DATAPACK_ACK:
status = get_h2c_ack_run_datapkt_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_CH_SWITCH_ACK:
status = get_h2c_ack_ch_switch_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_IQK_ACK:
status = get_h2c_ack_iqk_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_PWR_TRK_ACK:
status = get_h2c_ack_pwr_trk_88xx(adapter, buf, size);
break;
case H2C_SUB_CMD_ID_PSD_ACK:
break;
case H2C_SUB_CMD_ID_FW_SNDING_ACK:
status = get_h2c_ack_fw_snding_88xx(adapter, buf, size);
break;
default:
status = HALMAC_RET_C2H_NOT_HANDLED;
break;
}
return status;
}
static enum halmac_ret_status
get_scan_rpt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 fw_rc;
enum halmac_cmd_process_status proc_status;
fw_rc = (u8)SCAN_STATUS_RPT_GET_H2C_RETURN_CODE(buf);
proc_status = (HALMAC_H2C_RETURN_SUCCESS ==
(enum halmac_h2c_return_code)fw_rc) ?
HALMAC_CMD_PROCESS_DONE : HALMAC_CMD_PROCESS_ERROR;
PLTFM_EVENT_SIG(HALMAC_FEATURE_CHANNEL_SWITCH, proc_status, NULL, 0);
adapter->halmac_state.scan_state.proc_status = proc_status;
PLTFM_MSG_TRACE("[TRACE]scan : %X\n", proc_status);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_h2c_ack_cfg_param_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num;
u8 fw_rc;
u32 offset_accum;
u32 value_accum;
struct halmac_cfg_param_state *state =
&adapter->halmac_state.cfg_param_state;
enum halmac_cmd_process_status proc_status =
HALMAC_CMD_PROCESS_UNDEFINE;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
offset_accum = CFG_PARAM_ACK_GET_OFFSET_ACCUMULATION(buf);
value_accum = CFG_PARAM_ACK_GET_VALUE_ACCUMULATION(buf);
if (offset_accum != adapter->cfg_param_info.offset_accum ||
value_accum != adapter->cfg_param_info.value_accum) {
PLTFM_MSG_ERR("[ERR][C2H]offset_accu : %x, value_accu : %xn",
offset_accum, value_accum);
PLTFM_MSG_ERR("[ERR][Ada]offset_accu : %x, value_accu : %x\n",
adapter->cfg_param_info.offset_accum,
adapter->cfg_param_info.value_accum);
proc_status = HALMAC_CMD_PROCESS_ERROR;
}
if ((enum halmac_h2c_return_code)fw_rc == HALMAC_H2C_RETURN_SUCCESS &&
proc_status != HALMAC_CMD_PROCESS_ERROR) {
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_CFG_PARA, proc_status, NULL, 0);
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_CFG_PARA, proc_status,
&fw_rc, 1);
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_h2c_ack_update_pkt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num;
u8 fw_rc;
struct halmac_update_pkt_state *state =
&adapter->halmac_state.update_pkt_state;
enum halmac_cmd_process_status proc_status;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
if (HALMAC_H2C_RETURN_SUCCESS == (enum halmac_h2c_return_code)fw_rc) {
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_UPDATE_PACKET, proc_status,
NULL, 0);
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_UPDATE_PACKET, proc_status,
&state->fw_rc, 1);
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_h2c_ack_update_datapkt_88xx(struct halmac_adapter *adapter, u8 *buf,
u32 size)
{
return HALMAC_RET_NOT_SUPPORT;
}
static enum halmac_ret_status
get_h2c_ack_run_datapkt_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
return HALMAC_RET_NOT_SUPPORT;
}
static enum halmac_ret_status
get_h2c_ack_ch_switch_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num;
u8 fw_rc;
struct halmac_scan_state *state = &adapter->halmac_state.scan_state;
enum halmac_cmd_process_status proc_status;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
if ((enum halmac_h2c_return_code)fw_rc == HALMAC_H2C_RETURN_SUCCESS) {
proc_status = HALMAC_CMD_PROCESS_RCVD;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_CHANNEL_SWITCH, proc_status,
NULL, 0);
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_CHANNEL_SWITCH, proc_status,
&fw_rc, 1);
}
return HALMAC_RET_SUCCESS;
}
/**
* mac_debug_88xx_v1() - read some registers for debug
* @adapter
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
mac_debug_88xx(struct halmac_adapter *adapter)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (adapter->intf == HALMAC_INTERFACE_SDIO)
dump_reg_sdio_88xx(adapter);
else
dump_reg_88xx(adapter);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static void
dump_reg_sdio_88xx(struct halmac_adapter *adapter)
{
u8 tmp8;
u32 i;
/* Dump CCCR, it needs new platform api */
/*Dump SDIO Local Register, use CMD52*/
for (i = 0x10250000; i < 0x102500ff; i++) {
tmp8 = PLTFM_SDIO_CMD52_R(i);
PLTFM_MSG_TRACE("[TRACE]dbg-sdio[%x]=%x\n", i, tmp8);
}
/*Dump MAC Register*/
for (i = 0x0000; i < 0x17ff; i++) {
tmp8 = PLTFM_SDIO_CMD52_R(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp8);
}
tmp8 = PLTFM_SDIO_CMD52_R(REG_SDIO_CRC_ERR_IDX);
if (tmp8)
PLTFM_MSG_ERR("[ERR]sdio crc=%x\n", tmp8);
/*Check RX Fifo status*/
i = REG_RXFF_PTR_V1;
tmp8 = PLTFM_SDIO_CMD52_R(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp8);
i = REG_RXFF_WTR_V1;
tmp8 = PLTFM_SDIO_CMD52_R(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp8);
i = REG_RXFF_PTR_V1;
tmp8 = PLTFM_SDIO_CMD52_R(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp8);
i = REG_RXFF_WTR_V1;
tmp8 = PLTFM_SDIO_CMD52_R(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp8);
}
static void
dump_reg_88xx(struct halmac_adapter *adapter)
{
u32 tmp32;
u32 i;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
/*Dump MAC Register*/
for (i = 0x0000; i < 0x17fc; i += 4) {
tmp32 = HALMAC_REG_R32(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp32);
}
/*Check RX Fifo status*/
i = REG_RXFF_PTR_V1;
tmp32 = HALMAC_REG_R32(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp32);
i = REG_RXFF_WTR_V1;
tmp32 = HALMAC_REG_R32(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp32);
i = REG_RXFF_PTR_V1;
tmp32 = HALMAC_REG_R32(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp32);
i = REG_RXFF_WTR_V1;
tmp32 = HALMAC_REG_R32(i);
PLTFM_MSG_TRACE("[TRACE]dbg-mac[%x]=%x\n", i, tmp32);
}
/**
* cfg_parameter_88xx() - config parameter by FW
* @adapter : the adapter of halmac
* @info : cmd id, content
* @full_fifo : parameter information
*
* If msk_en = 1, the format of array is {reg_info, mask, value}.
* If msk_en =_FAUSE, the format of array is {reg_info, value}
* The format of reg_info is
* reg_info[31]=rf_reg, 0: MAC_BB reg, 1: RF reg
* reg_info[27:24]=rf_path, 0: path_A, 1: path_B
* if rf_reg=0(MAC_BB reg), rf_path is meaningless.
* ref_info[15:0]=offset
*
* Example: msk_en = 0
* {0x8100000a, 0x00001122}
* =>Set RF register, path_B, offset 0xA to 0x00001122
* {0x00000824, 0x11224433}
* =>Set MAC_BB register, offset 0x800 to 0x11224433
*
* Note : full fifo mode only for init flow
*
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_parameter_88xx(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *info, u8 full_fifo)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
enum halmac_cmd_construct_state cmd_state;
proc_status = &adapter->halmac_state.cfg_param_state.proc_status;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (adapter->fw_ver.h2c_version < 4)
return HALMAC_RET_FW_NO_SUPPORT;
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_TRACE("[TRACE]Wait event(para)\n");
return HALMAC_RET_BUSY_STATE;
}
cmd_state = cfg_param_cmd_cnstr_state_88xx(adapter);
if (cmd_state != HALMAC_CMD_CNSTR_IDLE &&
cmd_state != HALMAC_CMD_CNSTR_CNSTR) {
PLTFM_MSG_TRACE("[TRACE]Not idle(para)\n");
return HALMAC_RET_BUSY_STATE;
}
*proc_status = HALMAC_CMD_PROCESS_IDLE;
status = proc_cfg_param_88xx(adapter, info, full_fifo);
if (status != HALMAC_RET_SUCCESS && status != HALMAC_RET_PARA_SENDING) {
PLTFM_MSG_ERR("[ERR]send param h2c\n");
return status;
}
return status;
}
static enum halmac_cmd_construct_state
cfg_param_cmd_cnstr_state_88xx(struct halmac_adapter *adapter)
{
return adapter->halmac_state.cfg_param_state.cmd_cnstr_state;
}
static enum halmac_ret_status
proc_cfg_param_88xx(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *param, u8 full_fifo)
{
u8 end_cmd = 0;
u32 rsvd_size;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_cfg_param_info *info = &adapter->cfg_param_info;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.cfg_param_state.proc_status;
status = malloc_cfg_param_buf_88xx(adapter, full_fifo);
if (status != HALMAC_RET_SUCCESS)
return status;
if (cnv_cfg_param_state_88xx(adapter, HALMAC_CMD_CNSTR_CNSTR) !=
HALMAC_RET_SUCCESS) {
PLTFM_FREE(info->buf, info->buf_size);
info->buf = NULL;
info->buf_wptr = NULL;
return HALMAC_RET_ERROR_STATE;
}
add_param_buf_88xx(adapter, param, info->buf_wptr, &end_cmd);
if (param->cmd_id != HALMAC_PARAMETER_CMD_END) {
info->num++;
info->buf_wptr += CFG_PARAM_H2C_INFO_SIZE;
info->avl_buf_size -= CFG_PARAM_H2C_INFO_SIZE;
}
rsvd_size = info->avl_buf_size - adapter->hw_cfg_info.txdesc_size;
if (rsvd_size > CFG_PARAM_H2C_INFO_SIZE && end_cmd == 0)
return HALMAC_RET_SUCCESS;
if (info->num == 0) {
PLTFM_FREE(info->buf, info->buf_size);
info->buf = NULL;
info->buf_wptr = NULL;
PLTFM_MSG_TRACE("[TRACE]param num = 0!!\n");
*proc_status = HALMAC_CMD_PROCESS_DONE;
PLTFM_EVENT_SIG(HALMAC_FEATURE_CFG_PARA, *proc_status, NULL, 0);
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_CFG_PARA);
return HALMAC_RET_SUCCESS;
}
status = send_cfg_param_h2c_88xx(adapter);
if (status != HALMAC_RET_SUCCESS) {
if (info->buf) {
PLTFM_FREE(info->buf, info->buf_size);
info->buf = NULL;
info->buf_wptr = NULL;
}
return status;
}
if (end_cmd == 0) {
PLTFM_MSG_TRACE("[TRACE]send h2c-buf full\n");
return HALMAC_RET_PARA_SENDING;
}
return status;
}
static enum halmac_ret_status
send_cfg_param_h2c_88xx(struct halmac_adapter *adapter)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 pg_addr;
u16 seq_num = 0;
u32 info_size;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_cfg_param_info *info = &adapter->cfg_param_info;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.cfg_param_state.proc_status;
if (cnv_cfg_param_state_88xx(adapter, HALMAC_CMD_CNSTR_H2C_SENT) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
*proc_status = HALMAC_CMD_PROCESS_SENDING;
if (info->full_fifo_mode == 1)
pg_addr = 0;
else
pg_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
info_size = info->num * CFG_PARAM_H2C_INFO_SIZE;
status = dl_rsvd_page_88xx(adapter, pg_addr, info->buf, info_size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dl rsvd pg!!\n");
goto CFG_PARAM_H2C_FAIL;
}
gen_cfg_param_h2c_88xx(adapter, h2c_buf);
hdr_info.sub_cmd_id = SUB_CMD_ID_CFG_PARAM;
hdr_info.content_size = 4;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.cfg_param_state.seq_num = seq_num;
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_CFG_PARA);
}
CFG_PARAM_H2C_FAIL:
PLTFM_FREE(info->buf, info->buf_size);
info->buf = NULL;
info->buf_wptr = NULL;
if (cnv_cfg_param_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
return status;
}
static enum halmac_ret_status
cnv_cfg_param_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state)
{
enum halmac_cmd_construct_state *state;
state = &adapter->halmac_state.cfg_param_state.cmd_cnstr_state;
if ((*state != HALMAC_CMD_CNSTR_IDLE) &&
(*state != HALMAC_CMD_CNSTR_CNSTR) &&
(*state != HALMAC_CMD_CNSTR_H2C_SENT))
return HALMAC_RET_ERROR_STATE;
if (dest_state == HALMAC_CMD_CNSTR_IDLE) {
if (*state == HALMAC_CMD_CNSTR_CNSTR)
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_CNSTR) {
if (*state == HALMAC_CMD_CNSTR_H2C_SENT)
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_H2C_SENT) {
if ((*state == HALMAC_CMD_CNSTR_IDLE) ||
(*state == HALMAC_CMD_CNSTR_H2C_SENT))
return HALMAC_RET_ERROR_STATE;
}
*state = dest_state;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
add_param_buf_88xx(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *param, u8 *buf,
u8 *end_cmd)
{
struct halmac_cfg_param_info *info = &adapter->cfg_param_info;
union halmac_parameter_content *content = ¶m->content;
*end_cmd = 0;
PARAM_INFO_SET_LEN(buf, CFG_PARAM_H2C_INFO_SIZE);
PARAM_INFO_SET_IO_CMD(buf, param->cmd_id);
switch (param->cmd_id) {
case HALMAC_PARAMETER_CMD_BB_W8:
case HALMAC_PARAMETER_CMD_BB_W16:
case HALMAC_PARAMETER_CMD_BB_W32:
case HALMAC_PARAMETER_CMD_MAC_W8:
case HALMAC_PARAMETER_CMD_MAC_W16:
case HALMAC_PARAMETER_CMD_MAC_W32:
PARAM_INFO_SET_IO_ADDR(buf, content->MAC_REG_W.offset);
PARAM_INFO_SET_DATA(buf, content->MAC_REG_W.value);
PARAM_INFO_SET_MASK(buf, content->MAC_REG_W.msk);
PARAM_INFO_SET_MSK_EN(buf, content->MAC_REG_W.msk_en);
info->value_accum += content->MAC_REG_W.value;
info->offset_accum += content->MAC_REG_W.offset;
break;
case HALMAC_PARAMETER_CMD_RF_W:
/*In rf register, the address is only 1 byte*/
PARAM_INFO_SET_RF_ADDR(buf, content->RF_REG_W.offset);
PARAM_INFO_SET_RF_PATH(buf, content->RF_REG_W.rf_path);
PARAM_INFO_SET_DATA(buf, content->RF_REG_W.value);
PARAM_INFO_SET_MASK(buf, content->RF_REG_W.msk);
PARAM_INFO_SET_MSK_EN(buf, content->RF_REG_W.msk_en);
info->value_accum += content->RF_REG_W.value;
info->offset_accum += (content->RF_REG_W.offset +
(content->RF_REG_W.rf_path << 8));
break;
case HALMAC_PARAMETER_CMD_DELAY_US:
case HALMAC_PARAMETER_CMD_DELAY_MS:
PARAM_INFO_SET_DELAY_VAL(buf, content->DELAY_TIME.delay_time);
break;
case HALMAC_PARAMETER_CMD_END:
*end_cmd = 1;
break;
default:
PLTFM_MSG_ERR("[ERR]cmd id!!\n");
break;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
gen_cfg_param_h2c_88xx(struct halmac_adapter *adapter, u8 *buff)
{
struct halmac_cfg_param_info *info = &adapter->cfg_param_info;
u16 h2c_info_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
u16 rsvd_pg_addr = adapter->txff_alloc.rsvd_boundary;
CFG_PARAM_SET_NUM(buff, info->num);
if (info->full_fifo_mode == 1) {
CFG_PARAM_SET_INIT_CASE(buff, 0x1);
CFG_PARAM_SET_LOC(buff, 0);
} else {
CFG_PARAM_SET_INIT_CASE(buff, 0x0);
CFG_PARAM_SET_LOC(buff, h2c_info_addr - rsvd_pg_addr);
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
malloc_cfg_param_buf_88xx(struct halmac_adapter *adapter, u8 full_fifo)
{
struct halmac_cfg_param_info *info = &adapter->cfg_param_info;
struct halmac_pltfm_cfg_info *pltfm_info = &adapter->pltfm_info;
if (info->buf)
return HALMAC_RET_SUCCESS;
if (full_fifo == 1)
info->buf_size = pltfm_info->malloc_size;
else
info->buf_size = CFG_PARAM_RSVDPG_SIZE;
if (info->buf_size > pltfm_info->rsvd_pg_size)
info->buf_size = pltfm_info->rsvd_pg_size;
info->buf = smart_malloc_88xx(adapter, info->buf_size, &info->buf_size);
if (info->buf) {
PLTFM_MEMSET(info->buf, 0x00, info->buf_size);
info->full_fifo_mode = full_fifo;
info->buf_wptr = info->buf;
info->num = 0;
info->avl_buf_size = info->buf_size;
info->value_accum = 0;
info->offset_accum = 0;
} else {
return HALMAC_RET_MALLOC_FAIL;
}
return HALMAC_RET_SUCCESS;
}
/**
* update_packet_88xx() - send specific packet to FW
* @adapter : the adapter of halmac
* @pkt_id : packet id, to know the purpose of this packet
* @pkt : packet
* @size : packet size
*
* Note : TX_DESC is not included in the pkt
*
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
update_packet_88xx(struct halmac_adapter *adapter, enum halmac_packet_id pkt_id,
u8 *pkt, u32 size)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status =
&adapter->halmac_state.update_pkt_state.proc_status;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (adapter->fw_ver.h2c_version < 4)
return HALMAC_RET_FW_NO_SUPPORT;
if (size > UPDATE_PKT_RSVDPG_SIZE)
return HALMAC_RET_RSVD_PG_OVERFLOW_FAIL;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_TRACE("[TRACE]Wait event(upd)\n");
return HALMAC_RET_BUSY_STATE;
}
*proc_status = HALMAC_CMD_PROCESS_SENDING;
status = send_h2c_update_packet_88xx(adapter, pkt_id, pkt, size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
PLTFM_MSG_ERR("[ERR]pkt id : %X!!\n", pkt_id);
return status;
}
if (packet_in_nlo_88xx(adapter, pkt_id)) {
*proc_status = HALMAC_CMD_PROCESS_DONE;
adapter->nlo_flag = 1;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
send_h2c_update_packet_88xx(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id, u8 *pkt, u32 size)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
u16 pg_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
u16 pg_offset;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_packet_id real_pkt_id;
status = dl_rsvd_page_88xx(adapter, pg_addr, pkt, size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dl rsvd pg!!\n");
return status;
}
real_pkt_id = get_real_pkt_id_88xx(adapter, pkt_id);
pg_offset = pg_addr - adapter->txff_alloc.rsvd_boundary;
UPDATE_PKT_SET_SIZE(h2c_buf, size + adapter->hw_cfg_info.txdesc_size);
UPDATE_PKT_SET_ID(h2c_buf, real_pkt_id);
UPDATE_PKT_SET_LOC(h2c_buf, pg_offset);
hdr_info.sub_cmd_id = SUB_CMD_ID_UPDATE_PKT;
hdr_info.content_size = 8;
if (packet_in_nlo_88xx(adapter, pkt_id))
hdr_info.ack = 0;
else
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.update_pkt_state.seq_num = seq_num;
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_UPDATE_PACKET);
return status;
}
return status;
}
enum halmac_ret_status
bcn_ie_filter_88xx(struct halmac_adapter *adapter,
struct halmac_bcn_ie_info *info)
{
return HALMAC_RET_NOT_SUPPORT;
}
enum halmac_ret_status
update_datapack_88xx(struct halmac_adapter *adapter,
enum halmac_data_type data_type,
struct halmac_phy_parameter_info *info)
{
return HALMAC_RET_NOT_SUPPORT;
}
enum halmac_ret_status
run_datapack_88xx(struct halmac_adapter *adapter,
enum halmac_data_type data_type)
{
return HALMAC_RET_NOT_SUPPORT;
}
enum halmac_ret_status
send_bt_coex_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size, u8 ack)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = send_bt_coex_cmd_88xx(adapter, buf, size, ack);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]bt coex cmd!!\n");
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
send_bt_coex_cmd_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
u8 ack)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MEMCPY(h2c_buf + 8, buf, size);
hdr_info.sub_cmd_id = SUB_CMD_ID_BT_COEX;
hdr_info.content_size = (u16)size;
hdr_info.ack = ack;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
return status;
}
return HALMAC_RET_SUCCESS;
}
/**
* dump_fifo_88xx() - dump fifo data
* @adapter : the adapter of halmac
* @sel : FIFO selection
* @start_addr : start address of selected FIFO
* @size : dump size of selected FIFO
* @data : FIFO data
*
* Note : before dump fifo, user need to call halmac_get_fifo_size to
* get fifo size. Then input this size to halmac_dump_fifo.
*
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
dump_fifo_88xx(struct halmac_adapter *adapter, enum hal_fifo_sel sel,
u32 start_addr, u32 size, u8 *data)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
u8 tmp8;
u8 enable;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (sel == HAL_FIFO_SEL_TX &&
(start_addr + size) > adapter->hw_cfg_info.tx_fifo_size) {
PLTFM_MSG_ERR("[ERR]size overflow!!\n");
return HALMAC_RET_DUMP_FIFOSIZE_INCORRECT;
}
if (sel == HAL_FIFO_SEL_RX &&
(start_addr + size) > adapter->hw_cfg_info.rx_fifo_size) {
PLTFM_MSG_ERR("[ERR]size overflow!!\n");
return HALMAC_RET_DUMP_FIFOSIZE_INCORRECT;
}
if ((size & (4 - 1)) != 0) {
PLTFM_MSG_ERR("[ERR]not 4byte alignment!!\n");
return HALMAC_RET_DUMP_FIFOSIZE_INCORRECT;
}
if (!data)
return HALMAC_RET_NULL_POINTER;
tmp8 = HALMAC_REG_R8(REG_RCR + 2);
enable = 0;
status = api->halmac_set_hw_value(adapter, HALMAC_HW_RX_CLK_GATE,
&enable);
if (status != HALMAC_RET_SUCCESS)
return status;
status = read_buf_88xx(adapter, start_addr, size, sel, data);
HALMAC_REG_W8(REG_RCR + 2, tmp8);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]read buf!!\n");
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
read_buf_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
enum hal_fifo_sel sel, u8 *data)
{
u32 start_pg;
u32 value32;
u32 i;
u32 residue;
u32 cnt = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (sel == HAL_FIFO_SEL_RSVD_PAGE)
offset += (adapter->txff_alloc.rsvd_boundary <<
TX_PAGE_SIZE_SHIFT_88XX);
start_pg = offset >> 12;
residue = offset & (4096 - 1);
if (sel == HAL_FIFO_SEL_TX || sel == HAL_FIFO_SEL_RSVD_PAGE)
start_pg += 0x780;
else if (sel == HAL_FIFO_SEL_RX)
start_pg += 0x700;
else if (sel == HAL_FIFO_SEL_REPORT)
start_pg += 0x660;
else if (sel == HAL_FIFO_SEL_LLT)
start_pg += 0x650;
else if (sel == HAL_FIFO_SEL_RXBUF_FW)
start_pg += 0x680;
else
return HALMAC_RET_NOT_SUPPORT;
value32 = HALMAC_REG_R16(REG_PKTBUF_DBG_CTRL) & 0xF000;
do {
HALMAC_REG_W16(REG_PKTBUF_DBG_CTRL, (u16)(start_pg | value32));
for (i = 0x8000 + residue; i <= 0x8FFF; i += 4) {
*(u32 *)(data + cnt) = HALMAC_REG_R32(i);
*(u32 *)(data + cnt) =
rtk_le32_to_cpu(*(u32 *)(data + cnt));
cnt += 4;
if (size == cnt)
goto HALMAC_BUF_READ_OK;
}
residue = 0;
start_pg++;
} while (1);
HALMAC_BUF_READ_OK:
HALMAC_REG_W16(REG_PKTBUF_DBG_CTRL, (u16)value32);
return HALMAC_RET_SUCCESS;
}
/**
* get_fifo_size_88xx() - get fifo size
* @adapter : the adapter of halmac
* @sel : FIFO selection
* Author : Ivan Lin/KaiYuan Chang
* Return : u32
* More details of status code can be found in prototype document
*/
u32
get_fifo_size_88xx(struct halmac_adapter *adapter, enum hal_fifo_sel sel)
{
u32 size = 0;
if (sel == HAL_FIFO_SEL_TX)
size = adapter->hw_cfg_info.tx_fifo_size;
else if (sel == HAL_FIFO_SEL_RX)
size = adapter->hw_cfg_info.rx_fifo_size;
else if (sel == HAL_FIFO_SEL_RSVD_PAGE)
size = adapter->hw_cfg_info.tx_fifo_size -
(adapter->txff_alloc.rsvd_boundary <<
TX_PAGE_SIZE_SHIFT_88XX);
else if (sel == HAL_FIFO_SEL_REPORT)
size = 65536;
else if (sel == HAL_FIFO_SEL_LLT)
size = 65536;
else if (sel == HAL_FIFO_SEL_RXBUF_FW)
size = RX_BUF_FW_88XX;
return size;
}
enum halmac_ret_status
set_h2c_header_88xx(struct halmac_adapter *adapter, u8 *hdr, u16 *seq, u8 ack)
{
PLTFM_MSG_TRACE("[TRACE]%s!!\n", __func__);
H2C_CMD_HEADER_SET_CATEGORY(hdr, 0x00);
H2C_CMD_HEADER_SET_TOTAL_LEN(hdr, 16);
PLTFM_MUTEX_LOCK(&adapter->h2c_seq_mutex);
H2C_CMD_HEADER_SET_SEQ_NUM(hdr, adapter->h2c_info.seq_num);
*seq = adapter->h2c_info.seq_num;
(adapter->h2c_info.seq_num)++;
PLTFM_MUTEX_UNLOCK(&adapter->h2c_seq_mutex);
if (ack == 1)
H2C_CMD_HEADER_SET_ACK(hdr, 1);
return HALMAC_RET_SUCCESS;
}
/**
* add_ch_info_88xx() -add channel information
* @adapter : the adapter of halmac
* @info : channel information
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
add_ch_info_88xx(struct halmac_adapter *adapter, struct halmac_ch_info *info)
{
struct halmac_ch_sw_info *ch_sw_info = &adapter->ch_sw_info;
enum halmac_cmd_construct_state state;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (adapter->halmac_state.dlfw_state != HALMAC_GEN_INFO_SENT) {
PLTFM_MSG_ERR("[ERR]gen info\n");
return HALMAC_RET_GEN_INFO_NOT_SENT;
}
state = scan_cmd_cnstr_state_88xx(adapter);
if (state != HALMAC_CMD_CNSTR_BUF_CLR &&
state != HALMAC_CMD_CNSTR_CNSTR) {
PLTFM_MSG_WARN("[WARN]cmd state (scan)\n");
return HALMAC_RET_ERROR_STATE;
}
if (!ch_sw_info->buf) {
ch_sw_info->buf = (u8 *)PLTFM_MALLOC(SCAN_INFO_RSVDPG_SIZE);
if (!ch_sw_info->buf)
return HALMAC_RET_NULL_POINTER;
ch_sw_info->buf_wptr = ch_sw_info->buf;
ch_sw_info->buf_size = SCAN_INFO_RSVDPG_SIZE;
ch_sw_info->avl_buf_size = SCAN_INFO_RSVDPG_SIZE;
ch_sw_info->total_size = 0;
ch_sw_info->extra_info_en = 0;
ch_sw_info->ch_num = 0;
}
if (ch_sw_info->extra_info_en == 1) {
PLTFM_MSG_ERR("[ERR]extra info = 1!!\n");
return HALMAC_RET_CH_SW_SEQ_WRONG;
}
if (ch_sw_info->avl_buf_size < 4) {
PLTFM_MSG_ERR("[ERR]buf full!!\n");
return HALMAC_RET_CH_SW_NO_BUF;
}
if (cnv_scan_state_88xx(adapter, HALMAC_CMD_CNSTR_CNSTR) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
CH_INFO_SET_CH(ch_sw_info->buf_wptr, info->channel);
CH_INFO_SET_PRI_CH_IDX(ch_sw_info->buf_wptr, info->pri_ch_idx);
CH_INFO_SET_BW(ch_sw_info->buf_wptr, info->bw);
CH_INFO_SET_TIMEOUT(ch_sw_info->buf_wptr, info->timeout);
CH_INFO_SET_ACTION_ID(ch_sw_info->buf_wptr, info->action_id);
CH_INFO_SET_EXTRA_INFO(ch_sw_info->buf_wptr, info->extra_info);
ch_sw_info->avl_buf_size = ch_sw_info->avl_buf_size - 4;
ch_sw_info->total_size = ch_sw_info->total_size + 4;
ch_sw_info->ch_num++;
ch_sw_info->extra_info_en = info->extra_info;
ch_sw_info->buf_wptr = ch_sw_info->buf_wptr + 4;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_cmd_construct_state
scan_cmd_cnstr_state_88xx(struct halmac_adapter *adapter)
{
return adapter->halmac_state.scan_state.cmd_cnstr_state;
}
static enum halmac_ret_status
cnv_scan_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state)
{
enum halmac_cmd_construct_state *state;
state = &adapter->halmac_state.scan_state.cmd_cnstr_state;
if (dest_state == HALMAC_CMD_CNSTR_IDLE) {
if ((*state == HALMAC_CMD_CNSTR_BUF_CLR) ||
(*state == HALMAC_CMD_CNSTR_CNSTR))
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_BUF_CLR) {
if (*state == HALMAC_CMD_CNSTR_H2C_SENT)
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_CNSTR) {
if ((*state == HALMAC_CMD_CNSTR_IDLE) ||
(*state == HALMAC_CMD_CNSTR_H2C_SENT))
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_H2C_SENT) {
if ((*state != HALMAC_CMD_CNSTR_CNSTR) &&
(*state != HALMAC_CMD_CNSTR_BUF_CLR))
return HALMAC_RET_ERROR_STATE;
}
*state = dest_state;
return HALMAC_RET_SUCCESS;
}
/**
* add_extra_ch_info_88xx() -add extra channel information
* @adapter : the adapter of halmac
* @info : extra channel information
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
add_extra_ch_info_88xx(struct halmac_adapter *adapter,
struct halmac_ch_extra_info *info)
{
struct halmac_ch_sw_info *ch_sw_info = &adapter->ch_sw_info;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (!ch_sw_info->buf) {
PLTFM_MSG_ERR("[ERR]buf = null!!\n");
return HALMAC_RET_CH_SW_SEQ_WRONG;
}
if (ch_sw_info->extra_info_en == 0) {
PLTFM_MSG_ERR("[ERR]extra info = 0!!\n");
return HALMAC_RET_CH_SW_SEQ_WRONG;
}
if (ch_sw_info->avl_buf_size < (u32)(info->extra_info_size + 2)) {
PLTFM_MSG_ERR("[ERR]no available buffer!!\n");
return HALMAC_RET_CH_SW_NO_BUF;
}
if (scan_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_CNSTR) {
PLTFM_MSG_WARN("[WARN]cmd state (ex scan)\n");
return HALMAC_RET_ERROR_STATE;
}
if (cnv_scan_state_88xx(adapter, HALMAC_CMD_CNSTR_CNSTR) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
CH_EXTRA_INFO_SET_ID(ch_sw_info->buf_wptr, info->extra_action_id);
CH_EXTRA_INFO_SET_INFO(ch_sw_info->buf_wptr, info->extra_info);
CH_EXTRA_INFO_SET_SIZE(ch_sw_info->buf_wptr, info->extra_info_size);
PLTFM_MEMCPY(ch_sw_info->buf_wptr + 2, info->extra_info_data,
info->extra_info_size);
ch_sw_info->avl_buf_size -= (2 + info->extra_info_size);
ch_sw_info->total_size += (2 + info->extra_info_size);
ch_sw_info->extra_info_en = info->extra_info;
ch_sw_info->buf_wptr += (2 + info->extra_info_size);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* ctrl_ch_switch_88xx() -send channel switch cmd
* @adapter : the adapter of halmac
* @opt : channel switch config
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
ctrl_ch_switch_88xx(struct halmac_adapter *adapter,
struct halmac_ch_switch_option *opt)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_construct_state state;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.scan_state.proc_status;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (adapter->fw_ver.h2c_version < 4)
return HALMAC_RET_FW_NO_SUPPORT;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (opt->switch_en == 0)
*proc_status = HALMAC_CMD_PROCESS_IDLE;
if ((*proc_status == HALMAC_CMD_PROCESS_SENDING) ||
(*proc_status == HALMAC_CMD_PROCESS_RCVD)) {
PLTFM_MSG_TRACE("[TRACE]Wait event(scan)\n");
return HALMAC_RET_BUSY_STATE;
}
state = scan_cmd_cnstr_state_88xx(adapter);
if (opt->switch_en == 1) {
if (state != HALMAC_CMD_CNSTR_CNSTR) {
PLTFM_MSG_ERR("[ERR]state(en = 1)\n");
return HALMAC_RET_ERROR_STATE;
}
} else {
if (state != HALMAC_CMD_CNSTR_BUF_CLR) {
PLTFM_MSG_ERR("[ERR]state(en = 0)\n");
return HALMAC_RET_ERROR_STATE;
}
}
status = proc_ctrl_ch_switch_88xx(adapter, opt);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]ctrl ch sw!!\n");
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
proc_ctrl_ch_switch_88xx(struct halmac_adapter *adapter,
struct halmac_ch_switch_option *opt)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
u16 pg_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.scan_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (opt->nlo_en == 1 && adapter->nlo_flag != 1)
PLTFM_MSG_WARN("[WARN]probe req is NOT nlo pkt!!\n");
if (cnv_scan_state_88xx(adapter, HALMAC_CMD_CNSTR_H2C_SENT) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
*proc_status = HALMAC_CMD_PROCESS_SENDING;
if (opt->switch_en != 0) {
status = dl_rsvd_page_88xx(adapter, pg_addr,
adapter->ch_sw_info.buf,
adapter->ch_sw_info.total_size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dl rsvd pg!!\n");
return status;
}
}
CH_SWITCH_SET_START(h2c_buf, opt->switch_en);
CH_SWITCH_SET_CH_NUM(h2c_buf, adapter->ch_sw_info.ch_num);
CH_SWITCH_SET_INFO_LOC(h2c_buf,
pg_addr - adapter->txff_alloc.rsvd_boundary);
CH_SWITCH_SET_DEST_CH_EN(h2c_buf, opt->dest_ch_en);
CH_SWITCH_SET_DEST_CH(h2c_buf, opt->dest_ch);
CH_SWITCH_SET_PRI_CH_IDX(h2c_buf, opt->dest_pri_ch_idx);
CH_SWITCH_SET_ABSOLUTE_TIME(h2c_buf, opt->absolute_time_en);
CH_SWITCH_SET_TSF_LOW(h2c_buf, opt->tsf_low);
CH_SWITCH_SET_PERIODIC_OPT(h2c_buf, opt->periodic_option);
CH_SWITCH_SET_NORMAL_CYCLE(h2c_buf, opt->normal_cycle);
CH_SWITCH_SET_NORMAL_PERIOD(h2c_buf, opt->normal_period);
CH_SWITCH_SET_SLOW_PERIOD(h2c_buf, opt->phase_2_period);
CH_SWITCH_SET_NORMAL_PERIOD_SEL(h2c_buf, opt->normal_period_sel);
CH_SWITCH_SET_SLOW_PERIOD_SEL(h2c_buf, opt->phase_2_period_sel);
CH_SWITCH_SET_INFO_SIZE(h2c_buf, adapter->ch_sw_info.total_size);
hdr_info.sub_cmd_id = SUB_CMD_ID_CH_SWITCH;
hdr_info.content_size = 20;
if (opt->nlo_en == 1)
hdr_info.ack = 0;
else
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.scan_state.seq_num = seq_num;
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_CHANNEL_SWITCH);
}
PLTFM_FREE(adapter->ch_sw_info.buf, adapter->ch_sw_info.buf_size);
adapter->ch_sw_info.buf = NULL;
adapter->ch_sw_info.buf_wptr = NULL;
adapter->ch_sw_info.extra_info_en = 0;
adapter->ch_sw_info.buf_size = 0;
adapter->ch_sw_info.avl_buf_size = 0;
adapter->ch_sw_info.total_size = 0;
adapter->ch_sw_info.ch_num = 0;
if (cnv_scan_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
adapter->nlo_flag = 0;
return status;
}
/**
* clear_ch_info_88xx() -clear channel information
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
clear_ch_info_88xx(struct halmac_adapter *adapter)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (scan_cmd_cnstr_state_88xx(adapter) == HALMAC_CMD_CNSTR_H2C_SENT) {
PLTFM_MSG_WARN("[WARN]state(clear)\n");
return HALMAC_RET_ERROR_STATE;
}
if (cnv_scan_state_88xx(adapter, HALMAC_CMD_CNSTR_BUF_CLR) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_FREE(adapter->ch_sw_info.buf, adapter->ch_sw_info.buf_size);
adapter->ch_sw_info.buf = NULL;
adapter->ch_sw_info.buf_wptr = NULL;
adapter->ch_sw_info.extra_info_en = 0;
adapter->ch_sw_info.buf_size = 0;
adapter->ch_sw_info.avl_buf_size = 0;
adapter->ch_sw_info.total_size = 0;
adapter->ch_sw_info.ch_num = 0;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* chk_txdesc_88xx() -check if the tx packet format is incorrect
* @adapter : the adapter of halmac
* @buf : tx Packet buffer, tx desc is included
* @size : tx packet size
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
chk_txdesc_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u32 mac_clk = 0;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (GET_TX_DESC_BMC(buf) == 1 && GET_TX_DESC_AGG_EN(buf) == 1)
PLTFM_MSG_ERR("[ERR]txdesc - agg + bmc\n");
if (size < (GET_TX_DESC_TXPKTSIZE(buf) +
adapter->hw_cfg_info.txdesc_size +
(GET_TX_DESC_PKT_OFFSET(buf) << 3))) {
PLTFM_MSG_ERR("[ERR]txdesc - total size\n");
status = HALMAC_RET_TXDESC_SET_FAIL;
}
if (wlhdr_valid_88xx(adapter, buf) != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]wlhdr\n");
status = HALMAC_RET_WLHDR_FAIL;
}
if (GET_TX_DESC_AMSDU_PAD_EN(buf) != 0) {
PLTFM_MSG_ERR("[ERR]txdesc - amsdu_pad\n");
status = HALMAC_RET_TXDESC_SET_FAIL;
}
switch (BIT_GET_MAC_CLK_SEL(HALMAC_REG_R32(REG_AFE_CTRL1))) {
case 0x0:
mac_clk = 80;
break;
case 0x1:
mac_clk = 40;
break;
case 0x2:
mac_clk = 20;
break;
case 0x3:
mac_clk = 10;
break;
}
PLTFM_MSG_ALWAYS("MAC clock : 0x%XM\n", mac_clk);
PLTFM_MSG_ALWAYS("mac agg en : 0x%X\n", GET_TX_DESC_AGG_EN(buf));
PLTFM_MSG_ALWAYS("mac agg num : 0x%X\n", GET_TX_DESC_MAX_AGG_NUM(buf));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
static enum halmac_ret_status
wlhdr_valid_88xx(struct halmac_adapter *adapter, u8 *buf)
{
u32 txdesc_size = adapter->hw_cfg_info.txdesc_size +
GET_TX_DESC_PKT_OFFSET(buf);
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct wlhdr_frame_ctrl *wlhdr;
wlhdr = (struct wlhdr_frame_ctrl *)(buf + txdesc_size);
if (wlhdr->protocol != WLHDR_PROT_VER) {
PLTFM_MSG_ERR("[ERR]prot ver!!\n");
return HALMAC_RET_WLHDR_FAIL;
}
switch (wlhdr->type) {
case WLHDR_TYPE_MGMT:
if (wlhdr_mgmt_valid_88xx(adapter, wlhdr) != 1)
status = HALMAC_RET_WLHDR_FAIL;
break;
case WLHDR_TYPE_CTRL:
if (wlhdr_ctrl_valid_88xx(adapter, wlhdr) != 1)
status = HALMAC_RET_WLHDR_FAIL;
break;
case WLHDR_TYPE_DATA:
if (wlhdr_data_valid_88xx(adapter, wlhdr) != 1)
status = HALMAC_RET_WLHDR_FAIL;
break;
default:
PLTFM_MSG_ERR("[ERR]undefined type!!\n");
status = HALMAC_RET_WLHDR_FAIL;
break;
}
return status;
}
static u8
wlhdr_mgmt_valid_88xx(struct halmac_adapter *adapter,
struct wlhdr_frame_ctrl *wlhdr)
{
u8 state;
switch (wlhdr->sub_type) {
case WLHDR_SUB_TYPE_ASSOC_REQ:
case WLHDR_SUB_TYPE_ASSOC_RSPNS:
case WLHDR_SUB_TYPE_REASSOC_REQ:
case WLHDR_SUB_TYPE_REASSOC_RSPNS:
case WLHDR_SUB_TYPE_PROBE_REQ:
case WLHDR_SUB_TYPE_PROBE_RSPNS:
case WLHDR_SUB_TYPE_BCN:
case WLHDR_SUB_TYPE_DISASSOC:
case WLHDR_SUB_TYPE_AUTH:
case WLHDR_SUB_TYPE_DEAUTH:
case WLHDR_SUB_TYPE_ACTION:
case WLHDR_SUB_TYPE_ACTION_NOACK:
state = 1;
break;
default:
PLTFM_MSG_ERR("[ERR]mgmt invalid!!\n");
state = 0;
break;
}
return state;
}
static u8
wlhdr_ctrl_valid_88xx(struct halmac_adapter *adapter,
struct wlhdr_frame_ctrl *wlhdr)
{
u8 state;
switch (wlhdr->sub_type) {
case WLHDR_SUB_TYPE_BF_RPT_POLL:
case WLHDR_SUB_TYPE_NDPA:
state = 1;
break;
default:
PLTFM_MSG_ERR("[ERR]ctrl invalid!!\n");
state = 0;
break;
}
return state;
}
static u8
wlhdr_data_valid_88xx(struct halmac_adapter *adapter,
struct wlhdr_frame_ctrl *wlhdr)
{
u8 state;
switch (wlhdr->sub_type) {
case WLHDR_SUB_TYPE_DATA:
case WLHDR_SUB_TYPE_NULL:
case WLHDR_SUB_TYPE_QOS_DATA:
case WLHDR_SUB_TYPE_QOS_NULL:
state = 1;
break;
default:
PLTFM_MSG_ERR("[ERR]data invalid!!\n");
state = 0;
break;
}
return state;
}
/**
* get_version_88xx() - get HALMAC version
* @ver : return version of major, prototype and minor information
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_version_88xx(struct halmac_adapter *adapter, struct halmac_ver *ver)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
ver->major_ver = (u8)HALMAC_MAJOR_VER;
ver->prototype_ver = (u8)HALMAC_PROTOTYPE_VER;
ver->minor_ver = (u8)HALMAC_MINOR_VER;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
p2pps_88xx(struct halmac_adapter *adapter, struct halmac_p2pps *info)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (adapter->fw_ver.h2c_version < 6)
return HALMAC_RET_FW_NO_SUPPORT;
status = proc_p2pps_88xx(adapter, info);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]p2pps!!\n");
return status;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
proc_p2pps_88xx(struct halmac_adapter *adapter, struct halmac_p2pps *info)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
P2PPS_SET_OFFLOAD_EN(h2c_buf, info->offload_en);
P2PPS_SET_ROLE(h2c_buf, info->role);
P2PPS_SET_CTWINDOW_EN(h2c_buf, info->ctwindow_en);
P2PPS_SET_NOA_EN(h2c_buf, info->noa_en);
P2PPS_SET_NOA_SEL(h2c_buf, info->noa_sel);
P2PPS_SET_ALLSTASLEEP(h2c_buf, info->all_sta_sleep);
P2PPS_SET_DISCOVERY(h2c_buf, info->discovery);
P2PPS_SET_DISABLE_CLOSERF(h2c_buf, info->disable_close_rf);
P2PPS_SET_P2P_PORT_ID(h2c_buf, info->p2p_port_id);
P2PPS_SET_P2P_GROUP(h2c_buf, info->p2p_group);
P2PPS_SET_P2P_MACID(h2c_buf, info->p2p_macid);
P2PPS_SET_CTWINDOW_LENGTH(h2c_buf, info->ctwindow_length);
P2PPS_SET_NOA_DURATION_PARA(h2c_buf, info->noa_duration_para);
P2PPS_SET_NOA_INTERVAL_PARA(h2c_buf, info->noa_interval_para);
P2PPS_SET_NOA_START_TIME_PARA(h2c_buf, info->noa_start_time_para);
P2PPS_SET_NOA_COUNT_PARA(h2c_buf, info->noa_count_para);
hdr_info.sub_cmd_id = SUB_CMD_ID_P2PPS;
hdr_info.content_size = 24;
hdr_info.ack = 0;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
return status;
}
/**
* query_status_88xx() -query the offload feature status
* @adapter : the adapter of halmac
* @feature_id : feature_id
* @proc_status : feature_status
* @data : data buffer
* @size : data size
*
* Note :
* If user wants to know the data size, user can allocate zero
* size buffer first. If this size less than the data size, halmac
* will return HALMAC_RET_BUFFER_TOO_SMALL. User need to
* re-allocate data buffer with correct data size.
*
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
query_status_88xx(struct halmac_adapter *adapter,
enum halmac_feature_id feature_id,
enum halmac_cmd_process_status *proc_status, u8 *data,
u32 *size)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (!proc_status)
return HALMAC_RET_NULL_POINTER;
switch (feature_id) {
case HALMAC_FEATURE_CFG_PARA:
status = get_cfg_param_status_88xx(adapter, proc_status);
break;
case HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE:
status = get_dump_phy_efuse_status_88xx(adapter, proc_status,
data, size);
break;
case HALMAC_FEATURE_DUMP_LOGICAL_EFUSE:
status = get_dump_log_efuse_status_88xx(adapter, proc_status,
data, size);
break;
case HALMAC_FEATURE_CHANNEL_SWITCH:
status = get_ch_switch_status_88xx(adapter, proc_status);
break;
case HALMAC_FEATURE_UPDATE_PACKET:
status = get_update_packet_status_88xx(adapter, proc_status);
break;
case HALMAC_FEATURE_IQK:
status = get_iqk_status_88xx(adapter, proc_status);
break;
case HALMAC_FEATURE_POWER_TRACKING:
status = get_pwr_trk_status_88xx(adapter, proc_status);
break;
case HALMAC_FEATURE_PSD:
status = get_psd_status_88xx(adapter, proc_status, data, size);
break;
case HALMAC_FEATURE_FW_SNDING:
status = get_fw_snding_status_88xx(adapter, proc_status);
break;
default:
return HALMAC_RET_INVALID_FEATURE_ID;
}
return status;
}
static enum halmac_ret_status
get_cfg_param_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status)
{
*proc_status = adapter->halmac_state.cfg_param_state.proc_status;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_ch_switch_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status)
{
*proc_status = adapter->halmac_state.scan_state.proc_status;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_update_packet_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status)
{
*proc_status = adapter->halmac_state.update_pkt_state.proc_status;
return HALMAC_RET_SUCCESS;
}
/**
* cfg_drv_rsvd_pg_num_88xx() -config reserved page number for driver
* @adapter : the adapter of halmac
* @pg_num : page number
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_drv_rsvd_pg_num_88xx(struct halmac_adapter *adapter,
enum halmac_drv_rsvd_pg_num pg_num)
{
if (adapter->api_registry.cfg_drv_rsvd_pg_en == 0)
return HALMAC_RET_NOT_SUPPORT;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MSG_TRACE("[TRACE]pg_num = %d\n", pg_num);
switch (pg_num) {
case HALMAC_RSVD_PG_NUM8:
adapter->txff_alloc.rsvd_drv_pg_num = 8;
break;
case HALMAC_RSVD_PG_NUM16:
adapter->txff_alloc.rsvd_drv_pg_num = 16;
break;
case HALMAC_RSVD_PG_NUM24:
adapter->txff_alloc.rsvd_drv_pg_num = 24;
break;
case HALMAC_RSVD_PG_NUM32:
adapter->txff_alloc.rsvd_drv_pg_num = 32;
break;
case HALMAC_RSVD_PG_NUM64:
adapter->txff_alloc.rsvd_drv_pg_num = 64;
break;
case HALMAC_RSVD_PG_NUM128:
adapter->txff_alloc.rsvd_drv_pg_num = 128;
break;
case HALMAC_RSVD_PG_NUM256:
adapter->txff_alloc.rsvd_drv_pg_num = 256;
break;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* (debug API)h2c_lb_88xx() - send h2c loopback packet
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
h2c_lb_88xx(struct halmac_adapter *adapter)
{
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
pwr_seq_parser_88xx(struct halmac_adapter *adapter,
struct halmac_wlan_pwr_cfg **cmd_seq)
{
u8 cut;
u8 intf;
u32 idx = 0;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_wlan_pwr_cfg *cmd;
switch (adapter->chip_ver) {
case HALMAC_CHIP_VER_A_CUT:
cut = HALMAC_PWR_CUT_A_MSK;
break;
case HALMAC_CHIP_VER_B_CUT:
cut = HALMAC_PWR_CUT_B_MSK;
break;
case HALMAC_CHIP_VER_C_CUT:
cut = HALMAC_PWR_CUT_C_MSK;
break;
case HALMAC_CHIP_VER_D_CUT:
cut = HALMAC_PWR_CUT_D_MSK;
break;
case HALMAC_CHIP_VER_E_CUT:
cut = HALMAC_PWR_CUT_E_MSK;
break;
case HALMAC_CHIP_VER_F_CUT:
cut = HALMAC_PWR_CUT_F_MSK;
break;
case HALMAC_CHIP_VER_TEST:
cut = HALMAC_PWR_CUT_TESTCHIP_MSK;
break;
default:
PLTFM_MSG_ERR("[ERR]cut version!!\n");
return HALMAC_RET_SWITCH_CASE_ERROR;
}
switch (adapter->intf) {
case HALMAC_INTERFACE_PCIE:
case HALMAC_INTERFACE_AXI:
intf = HALMAC_PWR_INTF_PCI_MSK;
break;
case HALMAC_INTERFACE_USB:
intf = HALMAC_PWR_INTF_USB_MSK;
break;
case HALMAC_INTERFACE_SDIO:
intf = HALMAC_PWR_INTF_SDIO_MSK;
break;
default:
PLTFM_MSG_ERR("[ERR]interface!!\n");
return HALMAC_RET_SWITCH_CASE_ERROR;
}
do {
cmd = cmd_seq[idx];
if (!cmd)
break;
status = pwr_sub_seq_parser_88xx(adapter, cut, intf, cmd);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]pwr sub seq!!\n");
return status;
}
idx++;
} while (1);
return status;
}
static enum halmac_ret_status
pwr_sub_seq_parser_88xx(struct halmac_adapter *adapter, u8 cut, u8 intf,
struct halmac_wlan_pwr_cfg *cmd)
{
u8 value;
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
do {
if ((cmd->interface_msk & intf) && (cmd->cut_msk & cut)) {
switch (cmd->cmd) {
case HALMAC_PWR_CMD_WRITE:
offset = cmd->offset;
if (cmd->base == HALMAC_PWR_ADDR_SDIO)
offset |= SDIO_LOCAL_OFFSET;
value = HALMAC_REG_R8(offset);
value = (u8)(value & (u8)(~(cmd->msk)));
value = (u8)(value | (cmd->value & cmd->msk));
HALMAC_REG_W8(offset, value);
break;
case HALMAC_PWR_CMD_POLLING:
if (pwr_cmd_polling_88xx(adapter, cmd) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_PWRSEQ_POLLING_FAIL;
break;
case HALMAC_PWR_CMD_DELAY:
if (cmd->value == HALMAC_PWR_DELAY_US)
PLTFM_DELAY_US(cmd->offset);
else
PLTFM_DELAY_US(1000 * cmd->offset);
break;
case HALMAC_PWR_CMD_READ:
break;
case HALMAC_PWR_CMD_END:
return HALMAC_RET_SUCCESS;
default:
return HALMAC_RET_PWRSEQ_CMD_INCORRECT;
}
}
cmd++;
} while (1);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
pwr_cmd_polling_88xx(struct halmac_adapter *adapter,
struct halmac_wlan_pwr_cfg *cmd)
{
u8 value;
u8 flg;
u8 poll_bit;
u32 offset;
u32 cnt;
static u32 stats;
enum halmac_interface intf;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
poll_bit = 0;
cnt = HALMAC_PWR_POLLING_CNT;
flg = 0;
intf = adapter->intf;
if (cmd->base == HALMAC_PWR_ADDR_SDIO)
offset = cmd->offset | SDIO_LOCAL_OFFSET;
else
offset = cmd->offset;
do {
cnt--;
value = HALMAC_REG_R8(offset);
value = (u8)(value & cmd->msk);
if (value == (cmd->value & cmd->msk)) {
poll_bit = 1;
} else {
if (cnt == 0) {
if (intf == HALMAC_INTERFACE_PCIE && flg == 0) {
/* PCIE + USB package */
/* power bit polling timeout issue */
stats++;
PLTFM_MSG_WARN("[WARN]PCIE stats:%d\n",
stats);
value = HALMAC_REG_R8(REG_SYS_PW_CTRL);
value |= BIT(3);
HALMAC_REG_W8(REG_SYS_PW_CTRL, value);
value &= ~BIT(3);
HALMAC_REG_W8(REG_SYS_PW_CTRL, value);
poll_bit = 0;
cnt = HALMAC_PWR_POLLING_CNT;
flg = 1;
} else {
PLTFM_MSG_ERR("[ERR]polling to!!\n");
PLTFM_MSG_ERR("[ERR]cmd offset:%X\n",
cmd->offset);
PLTFM_MSG_ERR("[ERR]cmd value:%X\n",
cmd->value);
PLTFM_MSG_ERR("[ERR]cmd msk:%X\n",
cmd->msk);
PLTFM_MSG_ERR("[ERR]offset = %X\n",
offset);
PLTFM_MSG_ERR("[ERR]value = %X\n",
value);
return HALMAC_RET_PWRSEQ_POLLING_FAIL;
}
} else {
PLTFM_DELAY_US(50);
}
}
} while (!poll_bit);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
parse_intf_phy_88xx(struct halmac_adapter *adapter,
struct halmac_intf_phy_para *param,
enum halmac_intf_phy_platform pltfm,
enum hal_intf_phy intf_phy)
{
u16 value;
u16 cur_cut;
u16 offset;
u16 ip_sel;
struct halmac_intf_phy_para *cur_param;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 result = HALMAC_RET_SUCCESS;
switch (adapter->chip_ver) {
case HALMAC_CHIP_VER_A_CUT:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_A;
break;
case HALMAC_CHIP_VER_B_CUT:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_B;
break;
case HALMAC_CHIP_VER_C_CUT:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_C;
break;
case HALMAC_CHIP_VER_D_CUT:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_D;
break;
case HALMAC_CHIP_VER_E_CUT:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_E;
break;
case HALMAC_CHIP_VER_F_CUT:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_F;
break;
case HALMAC_CHIP_VER_TEST:
cur_cut = (u16)HALMAC_INTF_PHY_CUT_TESTCHIP;
break;
default:
return HALMAC_RET_FAIL;
}
cur_param = param;
do {
if ((cur_param->cut & cur_cut) &&
(cur_param->plaform & (u16)pltfm)) {
offset = cur_param->offset;
value = cur_param->value;
ip_sel = cur_param->ip_sel;
if (offset == 0xFFFF)
break;
if (ip_sel == HALMAC_IP_SEL_MAC) {
HALMAC_REG_W8((u32)offset, (u8)value);
} else if (intf_phy == HAL_INTF_PHY_USB2 ||
intf_phy == HAL_INTF_PHY_USB3) {
#if HALMAC_USB_SUPPORT
result = usbphy_write_88xx(adapter, (u8)offset,
value, intf_phy);
if (result != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]usb phy!!\n");
#endif
} else if (intf_phy == HAL_INTF_PHY_PCIE_GEN1 ||
intf_phy == HAL_INTF_PHY_PCIE_GEN2) {
#if HALMAC_PCIE_SUPPORT
if (ip_sel == HALMAC_IP_INTF_PHY)
result = mdio_write_88xx(adapter,
(u8)offset,
value,
intf_phy);
else
result = dbi_w8_88xx(adapter, offset,
(u8)value);
if (result != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]mdio/dbi!!\n");
#endif
} else {
PLTFM_MSG_ERR("[ERR]intf phy sel!!\n");
}
}
cur_param++;
} while (1);
return HALMAC_RET_SUCCESS;
}
/**
* txfifo_is_empty_88xx() -check if txfifo is empty
* @adapter : the adapter of halmac
* @chk_num : check number
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
txfifo_is_empty_88xx(struct halmac_adapter *adapter, u32 chk_num)
{
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
cnt = (chk_num <= 10) ? 10 : chk_num;
do {
if (HALMAC_REG_R8(REG_TXPKT_EMPTY) != 0xFF)
return HALMAC_RET_TXFIFO_NO_EMPTY;
if ((HALMAC_REG_R8(REG_TXPKT_EMPTY + 1) & 0x06) != 0x06)
return HALMAC_RET_TXFIFO_NO_EMPTY;
cnt--;
} while (cnt != 0);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* (internal use)
* smart_malloc_88xx() - adapt malloc size
* @adapter : the adapter of halmac
* @size : expected malloc size
* @pNew_size : real malloc size
* Author : Ivan Lin
* Return : address pointer
*/
u8*
smart_malloc_88xx(struct halmac_adapter *adapter, u32 size, u32 *new_size)
{
u8 retry_num;
u8 *malloc_buf = NULL;
for (retry_num = 0; retry_num < 5; retry_num++) {
malloc_buf = (u8 *)PLTFM_MALLOC(size);
if (malloc_buf) {
*new_size = size;
return malloc_buf;
}
size = size >> 1;
if (size == 0)
break;
}
PLTFM_MSG_ERR("[ERR]adptive malloc!!\n");
return NULL;
}
/**
* (internal use)
* ltecoex_reg_read_88xx() - read ltecoex register
* @adapter : the adapter of halmac
* @offset : offset
* @pValue : value
* Author : Ivan Lin
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
ltecoex_reg_read_88xx(struct halmac_adapter *adapter, u16 offset, u32 *value)
{
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
cnt = 10000;
while ((HALMAC_REG_R8(LTECOEX_ACCESS_CTRL + 3) & BIT(5)) == 0) {
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]lte ready(R)\n");
return HALMAC_RET_LTECOEX_READY_FAIL;
}
cnt--;
PLTFM_DELAY_US(50);
}
HALMAC_REG_W32(LTECOEX_ACCESS_CTRL, 0x800F0000 | offset);
*value = HALMAC_REG_R32(REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1);
return HALMAC_RET_SUCCESS;
}
/**
* (internal use)
* ltecoex_reg_write_88xx() - write ltecoex register
* @adapter : the adapter of halmac
* @offset : offset
* @value : value
* Author : Ivan Lin
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
ltecoex_reg_write_88xx(struct halmac_adapter *adapter, u16 offset, u32 value)
{
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
cnt = 10000;
while ((HALMAC_REG_R8(LTECOEX_ACCESS_CTRL + 3) & BIT(5)) == 0) {
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]lte ready(W)\n");
return HALMAC_RET_LTECOEX_READY_FAIL;
}
cnt--;
PLTFM_DELAY_US(50);
}
HALMAC_REG_W32(REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1, value);
HALMAC_REG_W32(LTECOEX_ACCESS_CTRL, 0xC00F0000 | offset);
return HALMAC_RET_SUCCESS;
}
static void
pwr_state_88xx(struct halmac_adapter *adapter, enum halmac_mac_power *state)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if ((HALMAC_REG_R8(REG_SYS_FUNC_EN + 1) & BIT(3)) == 0)
*state = HALMAC_MAC_POWER_OFF;
else
*state = HALMAC_MAC_POWER_ON;
}
static u8
packet_in_nlo_88xx(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id)
{
enum halmac_packet_id nlo_pkt = HALMAC_PACKET_PROBE_REQ_NLO;
if (pkt_id >= nlo_pkt)
return 1;
else
return 0;
}
static enum halmac_packet_id
get_real_pkt_id_88xx(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id)
{
enum halmac_packet_id real_pkt_id;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (pkt_id) {
case HALMAC_PACKET_PROBE_REQ_NLO:
real_pkt_id = HALMAC_PACKET_PROBE_REQ;
break;
case HALMAC_PACKET_SYNC_BCN_NLO:
real_pkt_id = HALMAC_PACKET_SYNC_BCN;
break;
case HALMAC_PACKET_DISCOVERY_BCN_NLO:
real_pkt_id = HALMAC_PACKET_DISCOVERY_BCN;
break;
default:
real_pkt_id = pkt_id;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return real_pkt_id;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_common_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_COMMON_88XX_H_
#define _HALMAC_COMMON_88XX_H_
#include "../halmac_api.h"
#include "../halmac_pwr_seq_cmd.h"
#include "../halmac_gpio_cmd.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
ofld_func_cfg_88xx(struct halmac_adapter *adapter,
struct halmac_ofld_func_info *info);
enum halmac_ret_status
dl_drv_rsvd_page_88xx(struct halmac_adapter *adapter, u8 pg_offset, u8 *buf,
u32 size);
enum halmac_ret_status
dl_rsvd_page_88xx(struct halmac_adapter *adapter, u16 pg_addr, u8 *buf,
u32 size);
enum halmac_ret_status
get_hw_value_88xx(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value);
enum halmac_ret_status
set_hw_value_88xx(struct halmac_adapter *adapter, enum halmac_hw_id hw_id,
void *value);
enum halmac_ret_status
set_h2c_pkt_hdr_88xx(struct halmac_adapter *adapter, u8 *hdr,
struct halmac_h2c_header_info *info, u16 *seq_num);
enum halmac_ret_status
send_h2c_pkt_88xx(struct halmac_adapter *adapter, u8 *pkt);
enum halmac_ret_status
get_h2c_buf_free_space_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
get_c2h_info_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
mac_debug_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
cfg_parameter_88xx(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *info, u8 full_fifo);
enum halmac_ret_status
update_packet_88xx(struct halmac_adapter *adapter, enum halmac_packet_id pkt_id,
u8 *pkt, u32 size);
enum halmac_ret_status
bcn_ie_filter_88xx(struct halmac_adapter *adapter,
struct halmac_bcn_ie_info *info);
enum halmac_ret_status
update_datapack_88xx(struct halmac_adapter *adapter,
enum halmac_data_type data_type,
struct halmac_phy_parameter_info *info);
enum halmac_ret_status
run_datapack_88xx(struct halmac_adapter *adapter,
enum halmac_data_type data_type);
enum halmac_ret_status
send_bt_coex_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size, u8 ack);
enum halmac_ret_status
dump_fifo_88xx(struct halmac_adapter *adapter, enum hal_fifo_sel sel,
u32 start_addr, u32 size, u8 *data);
u32
get_fifo_size_88xx(struct halmac_adapter *adapter, enum hal_fifo_sel sel);
enum halmac_ret_status
set_h2c_header_88xx(struct halmac_adapter *adapter, u8 *hdr, u16 *seq, u8 ack);
enum halmac_ret_status
add_ch_info_88xx(struct halmac_adapter *adapter, struct halmac_ch_info *info);
enum halmac_ret_status
add_extra_ch_info_88xx(struct halmac_adapter *adapter,
struct halmac_ch_extra_info *info);
enum halmac_ret_status
ctrl_ch_switch_88xx(struct halmac_adapter *adapter,
struct halmac_ch_switch_option *opt);
enum halmac_ret_status
clear_ch_info_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
chk_txdesc_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
get_version_88xx(struct halmac_adapter *adapter, struct halmac_ver *ver);
enum halmac_ret_status
p2pps_88xx(struct halmac_adapter *adapter, struct halmac_p2pps *info);
enum halmac_ret_status
query_status_88xx(struct halmac_adapter *adapter,
enum halmac_feature_id feature_id,
enum halmac_cmd_process_status *proc_status, u8 *data,
u32 *size);
enum halmac_ret_status
cfg_drv_rsvd_pg_num_88xx(struct halmac_adapter *adapter,
enum halmac_drv_rsvd_pg_num pg_num);
enum halmac_ret_status
h2c_lb_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
pwr_seq_parser_88xx(struct halmac_adapter *adapter,
struct halmac_wlan_pwr_cfg **cmd_seq);
enum halmac_ret_status
parse_intf_phy_88xx(struct halmac_adapter *adapter,
struct halmac_intf_phy_para *param,
enum halmac_intf_phy_platform pltfm,
enum hal_intf_phy intf_phy);
enum halmac_ret_status
txfifo_is_empty_88xx(struct halmac_adapter *adapter, u32 chk_num);
u8*
smart_malloc_88xx(struct halmac_adapter *adapter, u32 size, u32 *new_size);
enum halmac_ret_status
ltecoex_reg_read_88xx(struct halmac_adapter *adapter, u16 offset, u32 *value);
enum halmac_ret_status
ltecoex_reg_write_88xx(struct halmac_adapter *adapter, u16 offset, u32 value);
#endif/* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_COMMON_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_efuse_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_efuse_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_common_88xx.h"
#include "halmac_init_88xx.h"
#if HALMAC_88XX_SUPPORT
#define RSVD_EFUSE_SIZE 16
#define RSVD_CS_EFUSE_SIZE 24
#define FEATURE_DUMP_PHY_EFUSE HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE
#define FEATURE_DUMP_LOG_EFUSE HALMAC_FEATURE_DUMP_LOGICAL_EFUSE
static enum halmac_cmd_construct_state
efuse_cmd_cnstr_state_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
proc_dump_efuse_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg);
static enum halmac_ret_status
read_hw_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
u8 *map);
static enum halmac_ret_status
read_log_efuse_map_88xx(struct halmac_adapter *adapter, u8 *map);
static enum halmac_ret_status
proc_pg_efuse_by_map_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info,
enum halmac_efuse_read_cfg cfg);
static enum halmac_ret_status
dump_efuse_fw_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
dump_efuse_drv_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
proc_write_log_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 value);
static enum halmac_ret_status
update_eeprom_mask_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 *updated_mask);
static enum halmac_ret_status
check_efuse_enough_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 *updated_mask);
static enum halmac_ret_status
pg_extend_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 word_en,
u8 pre_word_en, u32 eeprom_offset);
static enum halmac_ret_status
proc_pg_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 word_en,
u8 pre_word_en, u32 eeprom_offset);
static enum halmac_ret_status
program_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 *updated_mask);
static void
mask_eeprom_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info);
/**
* dump_efuse_map_88xx() - dump "physical" efuse map
* @adapter : the adapter of halmac
* @cfg : dump efuse method
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
dump_efuse_map_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg)
{
u8 *map = NULL;
u8 *efuse_map;
u32 efuse_size = adapter->hw_cfg_info.efuse_size;
u32 prtct_efuse_size = adapter->hw_cfg_info.prtct_efuse_size;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
if (cfg == HALMAC_EFUSE_R_FW &&
halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MSG_TRACE("[TRACE]cfg = %d\n", cfg);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
if (adapter->halmac_state.mac_pwr == HALMAC_MAC_POWER_OFF)
PLTFM_MSG_ERR("[ERR]Dump efuse in suspend\n");
*proc_status = HALMAC_CMD_PROCESS_IDLE;
adapter->evnt.phy_efuse_map = 1;
status = switch_efuse_bank_88xx(adapter, HALMAC_EFUSE_BANK_WIFI);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank!!\n");
return status;
}
status = proc_dump_efuse_88xx(adapter, cfg);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dump efuse!!\n");
return status;
}
if (adapter->efuse_map_valid == 1) {
*proc_status = HALMAC_CMD_PROCESS_DONE;
efuse_map = adapter->efuse_map;
map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc!!\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, efuse_size);
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
#if HALMAC_PLATFORM_WINDOWS
PLTFM_MEMCPY(map, efuse_map, efuse_size);
#else
PLTFM_MEMCPY(map, efuse_map, efuse_size - prtct_efuse_size);
PLTFM_MEMCPY(map + efuse_size - prtct_efuse_size +
RSVD_CS_EFUSE_SIZE,
efuse_map + efuse_size - prtct_efuse_size +
RSVD_CS_EFUSE_SIZE,
prtct_efuse_size - RSVD_EFUSE_SIZE -
RSVD_CS_EFUSE_SIZE);
#endif
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
PLTFM_EVENT_SIG(HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE,
*proc_status, map, efuse_size);
adapter->evnt.phy_efuse_map = 0;
PLTFM_FREE(map, efuse_size);
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* dump_efuse_map_bt_88xx() - dump "BT physical" efuse map
* @adapter : the adapter of halmac
* @bank : bt efuse bank
* @size : bt efuse map size. get from halmac_get_efuse_size API
* @map : bt efuse map
* Author : Soar / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
dump_efuse_map_bt_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_bank bank, u32 size, u8 *map)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (adapter->hw_cfg_info.bt_efuse_size != size)
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
if (bank >= HALMAC_EFUSE_BANK_MAX || bank == HALMAC_EFUSE_BANK_WIFI) {
PLTFM_MSG_ERR("[ERR]Undefined BT bank\n");
return HALMAC_RET_EFUSE_BANK_INCORRECT;
}
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
status = switch_efuse_bank_88xx(adapter, bank);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank!!\n");
return status;
}
status = read_hw_efuse_88xx(adapter, 0, size, map);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]read hw efuse\n");
return status;
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* write_efuse_bt_88xx() - write "BT physical" efuse offset
* @adapter : the adapter of halmac
* @offset : offset
* @value : Write value
* @map : bt efuse map
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
write_efuse_bt_88xx(struct halmac_adapter *adapter, u32 offset, u8 value,
enum halmac_efuse_bank bank)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
if (offset >= adapter->hw_cfg_info.efuse_size) {
PLTFM_MSG_ERR("[ERR]Offset is too large\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (bank > HALMAC_EFUSE_BANK_MAX || bank == HALMAC_EFUSE_BANK_WIFI) {
PLTFM_MSG_ERR("[ERR]Undefined BT bank\n");
return HALMAC_RET_EFUSE_BANK_INCORRECT;
}
status = switch_efuse_bank_88xx(adapter, bank);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank!!\n");
return status;
}
status = write_hw_efuse_88xx(adapter, offset, value);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse\n");
return status;
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* read_efuse_bt_88xx() - read "BT physical" efuse offset
* @adapter : the adapter of halmac
* @offset : offset
* @value : 1 byte efuse value
* @bank : efuse bank
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
read_efuse_bt_88xx(struct halmac_adapter *adapter, u32 offset, u8 *value,
enum halmac_efuse_bank bank)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
if (offset >= adapter->hw_cfg_info.efuse_size) {
PLTFM_MSG_ERR("[ERR]Offset is too large\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (bank > HALMAC_EFUSE_BANK_MAX || bank == HALMAC_EFUSE_BANK_WIFI) {
PLTFM_MSG_ERR("[ERR]Undefined BT bank\n");
return HALMAC_RET_EFUSE_BANK_INCORRECT;
}
status = switch_efuse_bank_88xx(adapter, bank);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank\n");
return status;
}
status = read_efuse_88xx(adapter, offset, 1, value);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]read efuse\n");
return status;
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_efuse_auto_check_88xx() - check efuse after writing it
* @adapter : the adapter of halmac
* @enable : 1, enable efuse auto check. others, disable
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_efuse_auto_check_88xx(struct halmac_adapter *adapter, u8 enable)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
adapter->efuse_auto_check_en = enable;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* get_efuse_available_size_88xx() - get efuse available size
* @adapter : the adapter of halmac
* @size : physical efuse available size
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_efuse_available_size_88xx(struct halmac_adapter *adapter, u32 *size)
{
enum halmac_ret_status status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = dump_log_efuse_map_88xx(adapter, HALMAC_EFUSE_R_DRV);
if (status != HALMAC_RET_SUCCESS)
return status;
*size = adapter->hw_cfg_info.efuse_size -
adapter->hw_cfg_info.prtct_efuse_size - adapter->efuse_end;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* get_efuse_size_88xx() - get "physical" efuse size
* @adapter : the adapter of halmac
* @size : physical efuse size
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_efuse_size_88xx(struct halmac_adapter *adapter, u32 *size)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
*size = adapter->hw_cfg_info.efuse_size;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* get_log_efuse_size_88xx() - get "logical" efuse size
* @adapter : the adapter of halmac
* @size : logical efuse size
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_log_efuse_size_88xx(struct halmac_adapter *adapter, u32 *size)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
*size = adapter->hw_cfg_info.eeprom_size;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* dump_log_efuse_map_88xx() - dump "logical" efuse map
* @adapter : the adapter of halmac
* @cfg : dump efuse method
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
dump_log_efuse_map_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg)
{
u8 *map = NULL;
u32 size = adapter->hw_cfg_info.eeprom_size;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
if (cfg == HALMAC_EFUSE_R_FW &&
halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MSG_TRACE("[TRACE]cfg = %d\n", cfg);
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
if (adapter->halmac_state.mac_pwr == HALMAC_MAC_POWER_OFF)
PLTFM_MSG_ERR("[ERR]Dump efuse in suspend\n");
*proc_status = HALMAC_CMD_PROCESS_IDLE;
adapter->evnt.log_efuse_map = 1;
status = switch_efuse_bank_88xx(adapter, HALMAC_EFUSE_BANK_WIFI);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank\n");
return status;
}
status = proc_dump_efuse_88xx(adapter, cfg);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dump efuse\n");
return status;
}
if (adapter->efuse_map_valid == 1) {
*proc_status = HALMAC_CMD_PROCESS_DONE;
map = (u8 *)PLTFM_MALLOC(size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, size);
if (eeprom_parser_88xx(adapter, adapter->efuse_map, map) !=
HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, size);
return HALMAC_RET_EEPROM_PARSING_FAIL;
}
PLTFM_EVENT_SIG(HALMAC_FEATURE_DUMP_LOGICAL_EFUSE,
*proc_status, map, size);
adapter->evnt.log_efuse_map = 0;
PLTFM_FREE(map, size);
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* read_logical_efuse_88xx() - read logical efuse map 1 byte
* @adapter : the adapter of halmac
* @offset : offset
* @value : 1 byte efuse value
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
read_logical_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 *value)
{
u8 *map = NULL;
u32 size = adapter->hw_cfg_info.eeprom_size;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (offset >= size) {
PLTFM_MSG_ERR("[ERR]Offset is too large\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
status = switch_efuse_bank_88xx(adapter, HALMAC_EFUSE_BANK_WIFI);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank\n");
return status;
}
map = (u8 *)PLTFM_MALLOC(size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, size);
status = read_log_efuse_map_88xx(adapter, map);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]read logical efuse\n");
PLTFM_FREE(map, size);
return status;
}
*value = *(map + offset);
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, size);
return HALMAC_RET_ERROR_STATE;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
PLTFM_FREE(map, size);
return HALMAC_RET_SUCCESS;
}
/**
* write_log_efuse_88xx() - write "logical" efuse offset
* @adapter : the adapter of halmac
* @offset : offset
* @value : value
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
write_log_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 value)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (offset >= adapter->hw_cfg_info.eeprom_size) {
PLTFM_MSG_ERR("[ERR]Offset is too large\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
status = switch_efuse_bank_88xx(adapter, HALMAC_EFUSE_BANK_WIFI);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank\n");
return status;
}
status = proc_write_log_efuse_88xx(adapter, offset, value);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write logical efuse\n");
return status;
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* pg_efuse_by_map_88xx() - pg logical efuse by map
* @adapter : the adapter of halmac
* @info : efuse map information
* @cfg : dump efuse method
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pg_efuse_by_map_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info,
enum halmac_efuse_read_cfg cfg)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (info->efuse_map_size != adapter->hw_cfg_info.eeprom_size) {
PLTFM_MSG_ERR("[ERR]map size error\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if ((info->efuse_map_size & 0xF) > 0) {
PLTFM_MSG_ERR("[ERR]not multiple of 16\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (info->efuse_mask_size != info->efuse_map_size >> 4) {
PLTFM_MSG_ERR("[ERR]mask size error\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (!info->efuse_map) {
PLTFM_MSG_ERR("[ERR]map is NULL\n");
return HALMAC_RET_NULL_POINTER;
}
if (!info->efuse_mask) {
PLTFM_MSG_ERR("[ERR]mask is NULL\n");
return HALMAC_RET_NULL_POINTER;
}
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_WARN("[WARN]Wait event(efuse)\n");
return HALMAC_RET_BUSY_STATE;
}
if (efuse_cmd_cnstr_state_88xx(adapter) != HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_WARN("[WARN]Not idle(efuse)\n");
return HALMAC_RET_ERROR_STATE;
}
status = switch_efuse_bank_88xx(adapter, HALMAC_EFUSE_BANK_WIFI);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]switch efuse bank\n");
return status;
}
status = proc_pg_efuse_by_map_88xx(adapter, info, cfg);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]pg efuse\n");
return status;
}
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_IDLE) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* mask_log_efuse_88xx() - mask logical efuse
* @adapter : the adapter of halmac
* @info : efuse map information
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
mask_log_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (info->efuse_map_size != adapter->hw_cfg_info.eeprom_size) {
PLTFM_MSG_ERR("[ERR]map size error\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if ((info->efuse_map_size & 0xF) > 0) {
PLTFM_MSG_ERR("[ERR]not multiple of 16\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (info->efuse_mask_size != info->efuse_map_size >> 4) {
PLTFM_MSG_ERR("[ERR]mask size error\n");
return HALMAC_RET_EFUSE_SIZE_INCORRECT;
}
if (!info->efuse_map) {
PLTFM_MSG_ERR("[ERR]map is NULL\n");
return HALMAC_RET_NULL_POINTER;
}
if (!info->efuse_mask) {
PLTFM_MSG_ERR("[ERR]mask is NULL\n");
return HALMAC_RET_NULL_POINTER;
}
mask_eeprom_88xx(adapter, info);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_cmd_construct_state
efuse_cmd_cnstr_state_88xx(struct halmac_adapter *adapter)
{
return adapter->halmac_state.efuse_state.cmd_cnstr_state;
}
enum halmac_ret_status
switch_efuse_bank_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_bank bank)
{
u8 reg_value;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_BUSY) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
reg_value = HALMAC_REG_R8(REG_LDO_EFUSE_CTRL + 1);
if (bank == (reg_value & (BIT(0) | BIT(1))))
return HALMAC_RET_SUCCESS;
reg_value &= ~(BIT(0) | BIT(1));
reg_value |= bank;
HALMAC_REG_W8(REG_LDO_EFUSE_CTRL + 1, reg_value);
reg_value = HALMAC_REG_R8(REG_LDO_EFUSE_CTRL + 1);
if ((reg_value & (BIT(0) | BIT(1))) != bank)
return HALMAC_RET_SWITCH_EFUSE_BANK_FAIL;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
proc_dump_efuse_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg)
{
u32 h2c_init;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
enum halmac_cmd_process_status *proc_status;
proc_status = &adapter->halmac_state.efuse_state.proc_status;
*proc_status = HALMAC_CMD_PROCESS_SENDING;
if (cnv_efuse_state_88xx(adapter, HALMAC_CMD_CNSTR_H2C_SENT) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
if (cfg == HALMAC_EFUSE_R_AUTO) {
h2c_init = HALMAC_REG_R32(REG_H2C_PKT_READADDR);
if (adapter->halmac_state.dlfw_state == HALMAC_DLFW_NONE ||
h2c_init == 0)
status = dump_efuse_drv_88xx(adapter);
else
status = dump_efuse_fw_88xx(adapter);
} else if (cfg == HALMAC_EFUSE_R_FW) {
status = dump_efuse_fw_88xx(adapter);
} else {
status = dump_efuse_drv_88xx(adapter);
}
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dump efsue drv/fw\n");
return status;
}
return status;
}
enum halmac_ret_status
cnv_efuse_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state)
{
struct halmac_efuse_state *state = &adapter->halmac_state.efuse_state;
if (state->cmd_cnstr_state != HALMAC_CMD_CNSTR_IDLE &&
state->cmd_cnstr_state != HALMAC_CMD_CNSTR_BUSY &&
state->cmd_cnstr_state != HALMAC_CMD_CNSTR_H2C_SENT)
return HALMAC_RET_ERROR_STATE;
if (state->cmd_cnstr_state == dest_state)
return HALMAC_RET_ERROR_STATE;
if (dest_state == HALMAC_CMD_CNSTR_BUSY) {
if (state->cmd_cnstr_state == HALMAC_CMD_CNSTR_H2C_SENT)
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_H2C_SENT) {
if (state->cmd_cnstr_state == HALMAC_CMD_CNSTR_IDLE)
return HALMAC_RET_ERROR_STATE;
}
state->cmd_cnstr_state = dest_state;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
read_hw_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
u8 *map)
{
u8 enable;
u32 value32;
u32 addr;
u32 tmp32;
u32 cnt;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
/* Read efuse no need 2.5V LDO */
enable = 0;
status = api->halmac_set_hw_value(adapter, HALMAC_HW_LDO25_EN, &enable);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dis ldo25\n");
return status;
}
value32 = HALMAC_REG_R32(REG_EFUSE_CTRL);
for (addr = offset; addr < offset + size; addr++) {
value32 &= ~(BIT_MASK_EF_DATA | BITS_EF_ADDR);
value32 |= ((addr & BIT_MASK_EF_ADDR) << BIT_SHIFT_EF_ADDR);
HALMAC_REG_W32(REG_EFUSE_CTRL, value32 & (~BIT_EF_FLAG));
cnt = 1000000;
do {
PLTFM_DELAY_US(1);
tmp32 = HALMAC_REG_R32(REG_EFUSE_CTRL);
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]read\n");
return HALMAC_RET_EFUSE_R_FAIL;
}
} while ((tmp32 & BIT_EF_FLAG) == 0);
*(map + addr - offset) = (u8)(tmp32 & BIT_MASK_EF_DATA);
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
write_hw_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 value)
{
const u8 unlock_code = 0x69;
u8 value_read = 0;
u8 enable;
u32 value32;
u32 tmp32;
u32 cnt;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
adapter->efuse_map_valid = 0;
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
HALMAC_REG_W8(REG_PMC_DBG_CTRL2 + 3, unlock_code);
/* Enable 2.5V LDO */
enable = 1;
status = api->halmac_set_hw_value(adapter, HALMAC_HW_LDO25_EN, &enable);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]en ldo25\n");
return status;
}
value32 = HALMAC_REG_R32(REG_EFUSE_CTRL);
value32 &= ~(BIT_MASK_EF_DATA | BITS_EF_ADDR);
value32 = value32 | ((offset & BIT_MASK_EF_ADDR) << BIT_SHIFT_EF_ADDR) |
(value & BIT_MASK_EF_DATA);
HALMAC_REG_W32(REG_EFUSE_CTRL, value32 | BIT_EF_FLAG);
cnt = 1000000;
do {
PLTFM_DELAY_US(1);
tmp32 = HALMAC_REG_R32(REG_EFUSE_CTRL);
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]write!!\n");
return HALMAC_RET_EFUSE_W_FAIL;
}
} while (BIT_EF_FLAG == (tmp32 & BIT_EF_FLAG));
HALMAC_REG_W8(REG_PMC_DBG_CTRL2 + 3, 0x00);
/* Disable 2.5V LDO */
enable = 0;
status = api->halmac_set_hw_value(adapter, HALMAC_HW_LDO25_EN, &enable);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dis ldo25\n");
return status;
}
if (adapter->efuse_auto_check_en == 1) {
if (read_hw_efuse_88xx(adapter, offset, 1, &value_read) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_EFUSE_R_FAIL;
if (value_read != value) {
PLTFM_MSG_ERR("[ERR]efuse compare\n");
return HALMAC_RET_EFUSE_W_FAIL;
}
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
eeprom_parser_88xx(struct halmac_adapter *adapter, u8 *phy_map, u8 *log_map)
{
u8 i;
u8 value8;
u8 blk_idx;
u8 word_en;
u8 valid;
u8 hdr;
u8 hdr2 = 0;
u32 eeprom_idx;
u32 efuse_idx = 0;
u32 prtct_efuse_size = adapter->hw_cfg_info.prtct_efuse_size;
struct halmac_hw_cfg_info *hw_info = &adapter->hw_cfg_info;
PLTFM_MEMSET(log_map, 0xFF, hw_info->eeprom_size);
do {
value8 = *(phy_map + efuse_idx);
hdr = value8;
if ((hdr & 0x1f) == 0x0f) {
efuse_idx++;
value8 = *(phy_map + efuse_idx);
hdr2 = value8;
if (hdr2 == 0xff)
break;
blk_idx = ((hdr2 & 0xF0) >> 1) | ((hdr >> 5) & 0x07);
word_en = hdr2 & 0x0F;
} else {
blk_idx = (hdr & 0xF0) >> 4;
word_en = hdr & 0x0F;
}
if (hdr == 0xff)
break;
efuse_idx++;
if (efuse_idx >= hw_info->efuse_size - prtct_efuse_size - 1)
return HALMAC_RET_EEPROM_PARSING_FAIL;
for (i = 0; i < 4; i++) {
valid = (u8)((~(word_en >> i)) & BIT(0));
if (valid == 1) {
eeprom_idx = (blk_idx << 3) + (i << 1);
if ((eeprom_idx + 1) > hw_info->eeprom_size) {
PLTFM_MSG_ERR("[ERR]efuse idx:0x%X\n",
efuse_idx - 1);
PLTFM_MSG_ERR("[ERR]read hdr:0x%X\n",
hdr);
PLTFM_MSG_ERR("[ERR]rad hdr2:0x%X\n",
hdr2);
return HALMAC_RET_EEPROM_PARSING_FAIL;
}
value8 = *(phy_map + efuse_idx);
*(log_map + eeprom_idx) = value8;
eeprom_idx++;
efuse_idx++;
if (efuse_idx > hw_info->efuse_size -
prtct_efuse_size - 1)
return HALMAC_RET_EEPROM_PARSING_FAIL;
value8 = *(phy_map + efuse_idx);
*(log_map + eeprom_idx) = value8;
efuse_idx++;
if (efuse_idx > hw_info->efuse_size -
prtct_efuse_size)
return HALMAC_RET_EEPROM_PARSING_FAIL;
}
}
} while (1);
adapter->efuse_end = efuse_idx;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
read_log_efuse_map_88xx(struct halmac_adapter *adapter, u8 *map)
{
u8 *local_map = NULL;
u32 efuse_size;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (adapter->efuse_map_valid == 0) {
efuse_size = adapter->hw_cfg_info.efuse_size;
local_map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!local_map) {
PLTFM_MSG_ERR("[ERR]local map\n");
return HALMAC_RET_MALLOC_FAIL;
}
status = read_efuse_88xx(adapter, 0, efuse_size, local_map);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]read efuse\n");
PLTFM_FREE(local_map, efuse_size);
return status;
}
if (!adapter->efuse_map) {
adapter->efuse_map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!adapter->efuse_map) {
PLTFM_MSG_ERR("[ERR]malloc adapter map\n");
PLTFM_FREE(local_map, efuse_size);
return HALMAC_RET_MALLOC_FAIL;
}
}
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
PLTFM_MEMCPY(adapter->efuse_map, local_map, efuse_size);
adapter->efuse_map_valid = 1;
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
PLTFM_FREE(local_map, efuse_size);
}
if (eeprom_parser_88xx(adapter, adapter->efuse_map, map) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_EEPROM_PARSING_FAIL;
return status;
}
static enum halmac_ret_status
proc_pg_efuse_by_map_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info,
enum halmac_efuse_read_cfg cfg)
{
u8 *updated_mask = NULL;
u32 mask_size = adapter->hw_cfg_info.eeprom_size >> 4;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
updated_mask = (u8 *)PLTFM_MALLOC(mask_size);
if (!updated_mask) {
PLTFM_MSG_ERR("[ERR]malloc updated mask\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(updated_mask, 0x00, mask_size);
status = update_eeprom_mask_88xx(adapter, info, updated_mask);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]update eeprom mask\n");
PLTFM_FREE(updated_mask, mask_size);
return status;
}
status = check_efuse_enough_88xx(adapter, info, updated_mask);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]chk efuse enough\n");
PLTFM_FREE(updated_mask, mask_size);
return status;
}
status = program_efuse_88xx(adapter, info, updated_mask);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]pg efuse\n");
PLTFM_FREE(updated_mask, mask_size);
return status;
}
PLTFM_FREE(updated_mask, mask_size);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
dump_efuse_drv_88xx(struct halmac_adapter *adapter)
{
u8 *map = NULL;
u32 efuse_size = adapter->hw_cfg_info.efuse_size;
if (!adapter->efuse_map) {
adapter->efuse_map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!adapter->efuse_map) {
PLTFM_MSG_ERR("[ERR]malloc adapter map!!\n");
reset_ofld_feature_88xx(adapter,
FEATURE_DUMP_PHY_EFUSE);
return HALMAC_RET_MALLOC_FAIL;
}
}
if (adapter->efuse_map_valid == 0) {
map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
if (read_hw_efuse_88xx(adapter, 0, efuse_size, map) !=
HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, efuse_size);
return HALMAC_RET_EFUSE_R_FAIL;
}
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
PLTFM_MEMCPY(adapter->efuse_map, map, efuse_size);
adapter->efuse_map_valid = 1;
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
PLTFM_FREE(map, efuse_size);
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
dump_efuse_fw_88xx(struct halmac_adapter *adapter)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
u32 efuse_size = adapter->hw_cfg_info.efuse_size;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
hdr_info.sub_cmd_id = SUB_CMD_ID_DUMP_PHYSICAL_EFUSE;
hdr_info.content_size = 0;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.efuse_state.seq_num = seq_num;
if (!adapter->efuse_map) {
adapter->efuse_map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!adapter->efuse_map) {
PLTFM_MSG_ERR("[ERR]malloc adapter map\n");
reset_ofld_feature_88xx(adapter,
FEATURE_DUMP_PHY_EFUSE);
return HALMAC_RET_MALLOC_FAIL;
}
}
if (adapter->efuse_map_valid == 0) {
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c pkt\n");
reset_ofld_feature_88xx(adapter,
FEATURE_DUMP_PHY_EFUSE);
return status;
}
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
proc_write_log_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 value)
{
u8 byte1;
u8 byte2;
u8 blk;
u8 blk_idx;
u8 hdr;
u8 hdr2;
u8 *map = NULL;
u32 eeprom_size = adapter->hw_cfg_info.eeprom_size;
u32 prtct_efuse_size = adapter->hw_cfg_info.prtct_efuse_size;
u32 end;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
map = (u8 *)PLTFM_MALLOC(eeprom_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, eeprom_size);
status = read_log_efuse_map_88xx(adapter, map);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]read logical efuse\n");
PLTFM_FREE(map, eeprom_size);
return status;
}
if (*(map + offset) != value) {
end = adapter->efuse_end;
blk = (u8)(offset >> 3);
blk_idx = (u8)((offset & (8 - 1)) >> 1);
if (offset > 0x7f) {
hdr = (((blk & 0x07) << 5) & 0xE0) | 0x0F;
hdr2 = (u8)(((blk & 0x78) << 1) +
((0x1 << blk_idx) ^ 0x0F));
} else {
hdr = (u8)((blk << 4) + ((0x01 << blk_idx) ^ 0x0F));
}
if ((offset & 1) == 0) {
byte1 = value;
byte2 = *(map + offset + 1);
} else {
byte1 = *(map + offset - 1);
byte2 = value;
}
if (offset > 0x7f) {
if (adapter->hw_cfg_info.efuse_size <=
4 + prtct_efuse_size + end) {
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_EFUSE_NOT_ENOUGH;
}
status = write_hw_efuse_88xx(adapter, end, hdr);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
status = write_hw_efuse_88xx(adapter, end + 1, hdr2);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
status = write_hw_efuse_88xx(adapter, end + 2, byte1);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
status = write_hw_efuse_88xx(adapter, end + 3, byte2);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
} else {
if (adapter->hw_cfg_info.efuse_size <=
3 + prtct_efuse_size + end) {
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_EFUSE_NOT_ENOUGH;
}
status = write_hw_efuse_88xx(adapter, end, hdr);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
status = write_hw_efuse_88xx(adapter, end + 1, byte1);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
status = write_hw_efuse_88xx(adapter, end + 2, byte2);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
}
}
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
read_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u32 size, u8 *map)
{
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_NULL_POINTER;
}
if (adapter->efuse_map_valid == 1) {
PLTFM_MEMCPY(map, adapter->efuse_map + offset, size);
} else {
if (read_hw_efuse_88xx(adapter, offset, size, map) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_EFUSE_R_FAIL;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
update_eeprom_mask_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 *updated_mask)
{
u8 *map = NULL;
u8 clr_bit = 0;
u32 eeprom_size = adapter->hw_cfg_info.eeprom_size;
u8 *map_pg;
u8 *efuse_mask;
u16 i;
u16 j;
u16 map_offset;
u16 mask_offset;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
map = (u8 *)PLTFM_MALLOC(eeprom_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, eeprom_size);
PLTFM_MEMSET(updated_mask, 0x00, info->efuse_mask_size);
status = read_log_efuse_map_88xx(adapter, map);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return status;
}
map_pg = info->efuse_map;
efuse_mask = info->efuse_mask;
for (i = 0; i < info->efuse_mask_size; i++)
*(updated_mask + i) = *(efuse_mask + i);
for (i = 0; i < info->efuse_map_size; i += 16) {
for (j = 0; j < 16; j += 2) {
map_offset = i + j;
mask_offset = i >> 4;
if (*(u16 *)(map_pg + map_offset) ==
*(u16 *)(map + map_offset)) {
switch (j) {
case 0:
clr_bit = BIT(4);
break;
case 2:
clr_bit = BIT(5);
break;
case 4:
clr_bit = BIT(6);
break;
case 6:
clr_bit = BIT(7);
break;
case 8:
clr_bit = BIT(0);
break;
case 10:
clr_bit = BIT(1);
break;
case 12:
clr_bit = BIT(2);
break;
case 14:
clr_bit = BIT(3);
break;
default:
break;
}
*(updated_mask + mask_offset) &= ~clr_bit;
}
}
}
PLTFM_FREE(map, eeprom_size);
return status;
}
static enum halmac_ret_status
check_efuse_enough_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 *updated_mask)
{
u8 pre_word_en;
u16 i;
u16 j;
u32 eeprom_offset;
u32 pg_num = 0;
for (i = 0; i < info->efuse_map_size; i = i + 8) {
eeprom_offset = i;
if ((eeprom_offset & 7) > 0)
pre_word_en = (*(updated_mask + (i >> 4)) & 0x0F);
else
pre_word_en = (*(updated_mask + (i >> 4)) >> 4);
if (pre_word_en > 0) {
if (eeprom_offset > 0x7f) {
pg_num += 2;
for (j = 0; j < 4; j++) {
if (((pre_word_en >> j) & 0x1) > 0)
pg_num += 2;
}
} else {
pg_num++;
for (j = 0; j < 4; j++) {
if (((pre_word_en >> j) & 0x1) > 0)
pg_num += 2;
}
}
}
}
if (adapter->hw_cfg_info.efuse_size <=
(pg_num + adapter->hw_cfg_info.prtct_efuse_size +
adapter->efuse_end))
return HALMAC_RET_EFUSE_NOT_ENOUGH;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
pg_extend_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 word_en,
u8 pre_word_en, u32 eeprom_offset)
{
u8 blk;
u8 hdr;
u8 hdr2;
u16 i;
u32 efuse_end;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
efuse_end = adapter->efuse_end;
blk = (u8)(eeprom_offset >> 3);
hdr = (((blk & 0x07) << 5) & 0xE0) | 0x0F;
hdr2 = (u8)(((blk & 0x78) << 1) + word_en);
status = write_hw_efuse_88xx(adapter, efuse_end, hdr);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse\n");
return status;
}
status = write_hw_efuse_88xx(adapter, efuse_end + 1, hdr2);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse(+1)\n");
return status;
}
efuse_end = efuse_end + 2;
for (i = 0; i < 4; i++) {
if (((pre_word_en >> i) & 0x1) > 0) {
status = write_hw_efuse_88xx(adapter, efuse_end,
*(info->efuse_map +
eeprom_offset +
(i << 1)));
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse(<<1)\n");
return status;
}
status = write_hw_efuse_88xx(adapter, efuse_end + 1,
*(info->efuse_map +
eeprom_offset + (i << 1)
+ 1));
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse(<<1)+1\n");
return status;
}
efuse_end = efuse_end + 2;
}
}
adapter->efuse_end = efuse_end;
return status;
}
static enum halmac_ret_status
proc_pg_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 word_en,
u8 pre_word_en, u32 eeprom_offset)
{
u8 blk;
u8 hdr;
u16 i;
u32 efuse_end;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
efuse_end = adapter->efuse_end;
blk = (u8)(eeprom_offset >> 3);
hdr = (u8)((blk << 4) + word_en);
status = write_hw_efuse_88xx(adapter, efuse_end, hdr);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse\n");
return status;
}
efuse_end = efuse_end + 1;
for (i = 0; i < 4; i++) {
if (((pre_word_en >> i) & 0x1) > 0) {
status = write_hw_efuse_88xx(adapter, efuse_end,
*(info->efuse_map +
eeprom_offset +
(i << 1)));
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse(<<1)\n");
return status;
}
status = write_hw_efuse_88xx(adapter, efuse_end + 1,
*(info->efuse_map +
eeprom_offset + (i << 1)
+ 1));
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]write efuse(<<1)+1\n");
return status;
}
efuse_end = efuse_end + 2;
}
}
adapter->efuse_end = efuse_end;
return status;
}
static enum halmac_ret_status
program_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info, u8 *updated_mask)
{
u8 pre_word_en;
u8 word_en;
u16 i;
u32 eeprom_offset;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
for (i = 0; i < info->efuse_map_size; i = i + 8) {
eeprom_offset = i;
if (((eeprom_offset >> 3) & 1) > 0) {
pre_word_en = (*(updated_mask + (i >> 4)) & 0x0F);
word_en = pre_word_en ^ 0x0F;
} else {
pre_word_en = (*(updated_mask + (i >> 4)) >> 4);
word_en = pre_word_en ^ 0x0F;
}
if (pre_word_en > 0) {
if (eeprom_offset > 0x7f) {
status = pg_extend_efuse_88xx(adapter, info,
word_en,
pre_word_en,
eeprom_offset);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]extend efuse\n");
return status;
}
} else {
status = proc_pg_efuse_88xx(adapter, info,
word_en,
pre_word_en,
eeprom_offset);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]extend efuse");
return status;
}
}
}
}
return status;
}
static void
mask_eeprom_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info)
{
u8 pre_word_en;
u8 *updated_mask;
u8 *efuse_map;
u16 i;
u16 j;
u32 offset;
updated_mask = info->efuse_mask;
efuse_map = info->efuse_map;
for (i = 0; i < info->efuse_map_size; i = i + 8) {
offset = i;
if (((offset >> 3) & 1) > 0)
pre_word_en = (*(updated_mask + (i >> 4)) & 0x0F);
else
pre_word_en = (*(updated_mask + (i >> 4)) >> 4);
for (j = 0; j < 4; j++) {
if (((pre_word_en >> j) & 0x1) == 0) {
*(efuse_map + offset + (j << 1)) = 0xFF;
*(efuse_map + offset + (j << 1) + 1) = 0xFF;
}
}
}
}
enum halmac_ret_status
get_efuse_data_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seg_id;
u8 seg_size;
u8 seq_num;
u8 fw_rc;
u8 *map = NULL;
u32 eeprom_size = adapter->hw_cfg_info.eeprom_size;
struct halmac_efuse_state *state = &adapter->halmac_state.efuse_state;
enum halmac_cmd_process_status proc_status;
seq_num = (u8)EFUSE_DATA_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
seg_id = (u8)EFUSE_DATA_GET_SEGMENT_ID(buf);
seg_size = (u8)EFUSE_DATA_GET_SEGMENT_SIZE(buf);
if (seg_id == 0)
adapter->efuse_seg_size = seg_size;
map = (u8 *)PLTFM_MALLOC(eeprom_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, eeprom_size);
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
PLTFM_MEMCPY(adapter->efuse_map + seg_id * adapter->efuse_seg_size,
buf + C2H_DATA_OFFSET_88XX, seg_size);
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
if (EFUSE_DATA_GET_END_SEGMENT(buf) == 0) {
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_SUCCESS;
}
fw_rc = state->fw_rc;
if ((enum halmac_h2c_return_code)fw_rc == HALMAC_H2C_RETURN_SUCCESS) {
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
adapter->efuse_map_valid = 1;
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
if (adapter->evnt.phy_efuse_map == 1) {
PLTFM_EVENT_SIG(FEATURE_DUMP_PHY_EFUSE,
proc_status, adapter->efuse_map,
adapter->hw_cfg_info.efuse_size);
adapter->evnt.phy_efuse_map = 0;
}
if (adapter->evnt.log_efuse_map == 1) {
if (eeprom_parser_88xx(adapter, adapter->efuse_map,
map) != HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_EEPROM_PARSING_FAIL;
}
PLTFM_EVENT_SIG(FEATURE_DUMP_LOG_EFUSE, proc_status,
map, eeprom_size);
adapter->evnt.log_efuse_map = 0;
}
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
if (adapter->evnt.phy_efuse_map == 1) {
PLTFM_EVENT_SIG(FEATURE_DUMP_PHY_EFUSE, proc_status,
&state->fw_rc, 1);
adapter->evnt.phy_efuse_map = 0;
}
if (adapter->evnt.log_efuse_map == 1) {
PLTFM_EVENT_SIG(FEATURE_DUMP_LOG_EFUSE, proc_status,
&state->fw_rc, 1);
adapter->evnt.log_efuse_map = 0;
}
}
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_dump_phy_efuse_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status,
u8 *data, u32 *size)
{
u8 *map = NULL;
u32 efuse_size = adapter->hw_cfg_info.efuse_size;
u32 prtct_efuse_size = adapter->hw_cfg_info.prtct_efuse_size;
struct halmac_efuse_state *state = &adapter->halmac_state.efuse_state;
*proc_status = state->proc_status;
if (!data)
return HALMAC_RET_NULL_POINTER;
if (!size)
return HALMAC_RET_NULL_POINTER;
if (*proc_status == HALMAC_CMD_PROCESS_DONE) {
if (*size < efuse_size) {
*size = efuse_size;
return HALMAC_RET_BUFFER_TOO_SMALL;
}
*size = efuse_size;
map = (u8 *)PLTFM_MALLOC(efuse_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, efuse_size);
PLTFM_MUTEX_LOCK(&adapter->efuse_mutex);
PLTFM_MEMCPY(map, adapter->efuse_map,
efuse_size - prtct_efuse_size);
PLTFM_MEMCPY(map + efuse_size - prtct_efuse_size +
RSVD_CS_EFUSE_SIZE,
adapter->efuse_map + efuse_size -
prtct_efuse_size + RSVD_CS_EFUSE_SIZE,
prtct_efuse_size - RSVD_EFUSE_SIZE -
RSVD_CS_EFUSE_SIZE);
PLTFM_MUTEX_UNLOCK(&adapter->efuse_mutex);
PLTFM_MEMCPY(data, map, *size);
PLTFM_FREE(map, efuse_size);
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_dump_log_efuse_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status,
u8 *data, u32 *size)
{
u8 *map = NULL;
u32 eeprom_size = adapter->hw_cfg_info.eeprom_size;
struct halmac_efuse_state *state = &adapter->halmac_state.efuse_state;
*proc_status = state->proc_status;
if (!data)
return HALMAC_RET_NULL_POINTER;
if (!size)
return HALMAC_RET_NULL_POINTER;
if (*proc_status == HALMAC_CMD_PROCESS_DONE) {
if (*size < eeprom_size) {
*size = eeprom_size;
return HALMAC_RET_BUFFER_TOO_SMALL;
}
*size = eeprom_size;
map = (u8 *)PLTFM_MALLOC(eeprom_size);
if (!map) {
PLTFM_MSG_ERR("[ERR]malloc map\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(map, 0xFF, eeprom_size);
if (eeprom_parser_88xx(adapter, adapter->efuse_map, map) !=
HALMAC_RET_SUCCESS) {
PLTFM_FREE(map, eeprom_size);
return HALMAC_RET_EEPROM_PARSING_FAIL;
}
PLTFM_MEMCPY(data, map, *size);
PLTFM_FREE(map, eeprom_size);
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_h2c_ack_phy_efuse_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num = 0;
u8 fw_rc;
struct halmac_efuse_state *state = &adapter->halmac_state.efuse_state;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch : h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not cmd sending\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
return HALMAC_RET_SUCCESS;
}
u32
get_rsvd_efuse_size_88xx(struct halmac_adapter *adapter)
{
return adapter->hw_cfg_info.prtct_efuse_size;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_efuse_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_EFUSE_88XX_H_
#define _HALMAC_EFUSE_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
dump_efuse_map_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg);
enum halmac_ret_status
eeprom_parser_88xx(struct halmac_adapter *adapter, u8 *phy_map, u8 *log_map);
enum halmac_ret_status
dump_efuse_map_bt_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_bank bank, u32 size, u8 *map);
enum halmac_ret_status
write_efuse_bt_88xx(struct halmac_adapter *adapter, u32 offset, u8 value,
enum halmac_efuse_bank bank);
enum halmac_ret_status
read_efuse_bt_88xx(struct halmac_adapter *adapter, u32 offset, u8 *value,
enum halmac_efuse_bank bank);
enum halmac_ret_status
cfg_efuse_auto_check_88xx(struct halmac_adapter *adapter, u8 enable);
enum halmac_ret_status
get_efuse_available_size_88xx(struct halmac_adapter *adapter, u32 *size);
enum halmac_ret_status
get_efuse_size_88xx(struct halmac_adapter *adapter, u32 *size);
enum halmac_ret_status
get_log_efuse_size_88xx(struct halmac_adapter *adapter, u32 *size);
enum halmac_ret_status
dump_log_efuse_map_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg);
enum halmac_ret_status
read_logical_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 *value);
enum halmac_ret_status
write_log_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 value);
enum halmac_ret_status
pg_efuse_by_map_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info,
enum halmac_efuse_read_cfg cfg);
enum halmac_ret_status
mask_log_efuse_88xx(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info);
enum halmac_ret_status
read_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u32 size, u8 *map);
enum halmac_ret_status
write_hw_efuse_88xx(struct halmac_adapter *adapter, u32 offset, u8 value);
enum halmac_ret_status
switch_efuse_bank_88xx(struct halmac_adapter *adapter,
enum halmac_efuse_bank bank);
enum halmac_ret_status
get_efuse_data_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
cnv_efuse_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state);
enum halmac_ret_status
get_dump_phy_efuse_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status,
u8 *data, u32 *size);
enum halmac_ret_status
get_dump_log_efuse_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status,
u8 *data, u32 *size);
enum halmac_ret_status
get_h2c_ack_phy_efuse_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
u32
get_rsvd_efuse_size_88xx(struct halmac_adapter *adapter);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_EFUSE_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_flash_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_flash_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_common_88xx.h"
#if HALMAC_88XX_SUPPORT
/**
* download_flash_88xx() -download firmware to flash
* @adapter : the adapter of halmac
* @fw_bin : pointer to fw
* @size : fw size
* @rom_addr : flash start address where fw should be download
* Author : Pablo Chiu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
download_flash_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size,
u32 rom_addr)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status rc;
struct halmac_h2c_header_info hdr_info;
u8 value8;
u8 restore[3];
u8 h2c_buf[H2C_PKT_SIZE_88XX] = {0};
u16 seq_num = 0;
u16 h2c_info_offset;
u32 pkt_size;
u32 mem_offset;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value8 = HALMAC_REG_R8(REG_CR + 1);
restore[0] = value8;
value8 = (u8)(value8 | BIT(0));
HALMAC_REG_W8(REG_CR + 1, value8);
value8 = HALMAC_REG_R8(REG_BCN_CTRL);
restore[1] = value8;
value8 = (u8)((value8 & ~(BIT(3))) | BIT(4));
HALMAC_REG_W8(REG_BCN_CTRL, value8);
value8 = HALMAC_REG_R8(REG_FWHW_TXQ_CTRL + 2);
restore[2] = value8;
value8 = (u8)(value8 & ~(BIT(6)));
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 2, value8);
/* Download FW to Flash flow */
h2c_info_offset = adapter->txff_alloc.rsvd_h2c_info_addr -
adapter->txff_alloc.rsvd_boundary;
mem_offset = 0;
while (size != 0) {
if (size >= (DL_FLASH_RSVDPG_SIZE - 48))
pkt_size = DL_FLASH_RSVDPG_SIZE - 48;
else
pkt_size = size;
rc = dl_rsvd_page_88xx(adapter,
adapter->txff_alloc.rsvd_h2c_info_addr,
fw_bin + mem_offset, pkt_size);
if (rc != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dl rsvd pg!!\n");
return rc;
}
DOWNLOAD_FLASH_SET_SPI_CMD(h2c_buf, 0x02);
DOWNLOAD_FLASH_SET_LOCATION(h2c_buf, h2c_info_offset);
DOWNLOAD_FLASH_SET_SIZE(h2c_buf, pkt_size);
DOWNLOAD_FLASH_SET_START_ADDR(h2c_buf, rom_addr);
hdr_info.sub_cmd_id = SUB_CMD_ID_DOWNLOAD_FLASH;
hdr_info.content_size = 20;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
rc = send_h2c_pkt_88xx(adapter, h2c_buf);
if (rc != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
return rc;
}
value8 = HALMAC_REG_R8(REG_MCUTST_I);
value8 |= BIT(0);
HALMAC_REG_W8(REG_MCUTST_I, value8);
rom_addr += pkt_size;
mem_offset += pkt_size;
size -= pkt_size;
while (((HALMAC_REG_R8(REG_MCUTST_I)) & BIT(0)) != 0)
PLTFM_DELAY_US(1000);
if (((HALMAC_REG_R8(REG_MCUTST_I)) & BIT(0)) != 0) {
PLTFM_MSG_ERR("[ERR]dl flash!!\n");
return HALMAC_RET_DLFW_FAIL;
}
}
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 2, restore[2]);
HALMAC_REG_W8(REG_BCN_CTRL, restore[1]);
HALMAC_REG_W8(REG_CR + 1, restore[0]);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* read_flash_88xx() -read data from flash
* @adapter : the adapter of halmac
* @addr : flash start address where fw should be read
* Author : Pablo Chiu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
read_flash_88xx(struct halmac_adapter *adapter, u32 addr, u32 length)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status;
struct halmac_h2c_header_info hdr_info;
u8 value8;
u8 restore[3];
u8 h2c_buf[H2C_PKT_SIZE_88XX] = {0};
u16 seq_num = 0;
u16 h2c_info_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
u16 rsvd_pg_addr = adapter->txff_alloc.rsvd_boundary;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value8 = HALMAC_REG_R8(REG_CR + 1);
restore[0] = value8;
value8 = (u8)(value8 | BIT(0));
HALMAC_REG_W8(REG_CR + 1, value8);
value8 = HALMAC_REG_R8(REG_BCN_CTRL);
restore[1] = value8;
value8 = (u8)((value8 & ~(BIT(3))) | BIT(4));
HALMAC_REG_W8(REG_BCN_CTRL, value8);
value8 = HALMAC_REG_R8(REG_FWHW_TXQ_CTRL + 2);
restore[2] = value8;
value8 = (u8)(value8 & ~(BIT(6)));
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 2, value8);
HALMAC_REG_W16(REG_FIFOPAGE_CTRL_2, h2c_info_addr);
value8 = HALMAC_REG_R8(REG_MCUTST_I);
value8 |= BIT(0);
HALMAC_REG_W8(REG_MCUTST_I, value8);
/* Construct H2C Content */
DOWNLOAD_FLASH_SET_SPI_CMD(h2c_buf, 0x03);
DOWNLOAD_FLASH_SET_LOCATION(h2c_buf, h2c_info_addr - rsvd_pg_addr);
DOWNLOAD_FLASH_SET_SIZE(h2c_buf, length);
DOWNLOAD_FLASH_SET_START_ADDR(h2c_buf, addr);
/* Fill in H2C Header */
hdr_info.sub_cmd_id = SUB_CMD_ID_DOWNLOAD_FLASH;
hdr_info.content_size = 16;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
/* Send H2C Cmd Packet */
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
return status;
}
while (((HALMAC_REG_R8(REG_MCUTST_I)) & BIT(0)) != 0)
PLTFM_DELAY_US(1000);
HALMAC_REG_W16(REG_FIFOPAGE_CTRL_2, rsvd_pg_addr);
HALMAC_REG_W8(REG_FWHW_TXQ_CTRL + 2, restore[2]);
HALMAC_REG_W8(REG_BCN_CTRL, restore[1]);
HALMAC_REG_W8(REG_CR + 1, restore[0]);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* erase_flash_88xx() -erase flash data
* @adapter : the adapter of halmac
* @erase_cmd : erase command
* @addr : flash start address where fw should be erased
* Author : Pablo Chiu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
erase_flash_88xx(struct halmac_adapter *adapter, u8 erase_cmd, u32 addr)
{
enum halmac_ret_status status;
struct halmac_h2c_header_info hdr_info;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 value8;
u8 h2c_buf[H2C_PKT_SIZE_88XX] = {0};
u16 seq_num = 0;
u32 cnt;
/* Construct H2C Content */
DOWNLOAD_FLASH_SET_SPI_CMD(h2c_buf, erase_cmd);
DOWNLOAD_FLASH_SET_LOCATION(h2c_buf, 0);
DOWNLOAD_FLASH_SET_START_ADDR(h2c_buf, addr);
DOWNLOAD_FLASH_SET_SIZE(h2c_buf, 0);
value8 = HALMAC_REG_R8(REG_MCUTST_I);
value8 |= BIT(0);
HALMAC_REG_W8(REG_MCUTST_I, value8);
/* Fill in H2C Header */
hdr_info.sub_cmd_id = SUB_CMD_ID_DOWNLOAD_FLASH;
hdr_info.content_size = 16;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
/* Send H2C Cmd Packet */
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
cnt = 5000;
while (((HALMAC_REG_R8(REG_MCUTST_I)) & BIT(0)) != 0 && cnt != 0) {
PLTFM_DELAY_US(1000);
cnt--;
}
if (cnt == 0)
return HALMAC_RET_FAIL;
else
return HALMAC_RET_SUCCESS;
}
/**
* check_flash_88xx() -check flash data
* @adapter : the adapter of halmac
* @fw_bin : pointer to fw
* @size : fw size
* @addr : flash start address where fw should be checked
* Author : Pablo Chiu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
check_flash_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size,
u32 addr)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 value8;
u16 i;
u16 residue;
u16 pg_addr;
u32 pkt_size;
u32 start_page;
u32 cnt;
pg_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
while (size != 0) {
start_page = ((pg_addr << 7) >> 12) + 0x780;
residue = (pg_addr << 7) & (4096 - 1);
if (size >= DL_FLASH_RSVDPG_SIZE)
pkt_size = DL_FLASH_RSVDPG_SIZE;
else
pkt_size = size;
read_flash_88xx(adapter, addr, 4096);
cnt = 0;
while (cnt < pkt_size) {
HALMAC_REG_W16(REG_PKTBUF_DBG_CTRL, (u16)(start_page));
for (i = 0x8000 + residue; i <= 0x8FFF; i++) {
value8 = HALMAC_REG_R8(i);
if (*fw_bin != value8) {
PLTFM_MSG_ERR("[ERR]check flash!!\n");
return HALMAC_RET_FAIL;
}
fw_bin++;
cnt++;
if (cnt == pkt_size)
break;
}
residue = 0;
start_page++;
}
addr += pkt_size;
size -= pkt_size;
}
return HALMAC_RET_SUCCESS;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_flash_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_FLASH_88XX_H_
#define _HALMAC_FLASH_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
download_flash_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size,
u32 rom_addr);
enum halmac_ret_status
read_flash_88xx(struct halmac_adapter *adapter, u32 addr, u32 length);
enum halmac_ret_status
erase_flash_88xx(struct halmac_adapter *adapter, u8 erase_cmd, u32 addr);
enum halmac_ret_status
check_flash_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size,
u32 addr);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_FLASH_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_fw_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_fw_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_common_88xx.h"
#include "halmac_init_88xx.h"
#if HALMAC_88XX_SUPPORT
#define DLFW_RESTORE_REG_NUM 6
#define ILLEGAL_KEY_GROUP 0xFAAAAA00
/* Max dlfw size can not over 31K, due to SDIO HW limitation */
#define DLFW_PKT_SIZE_LIMIT 31744
#define ID_INFORM_DLEMEM_RDY 0x80
#define ID_INFORM_ENETR_CPU_SLEEP 0x20
#define ID_CHECK_DLEMEM_RDY 0x80
#define ID_CHECK_ENETR_CPU_SLEEP 0x05
#define FW_STATUS_CHK_FATAL (BIT(1) | BIT(20))
#define FW_STATUS_CHK_ERR (BIT(4) | BIT(5) | BIT(6) | BIT(7) | BIT(8) | \
BIT(9) | BIT(12) | BIT(14) | BIT(15) | \
BIT(16) | BIT(17) | BIT(18) | BIT(19) | \
BIT(21) | BIT(22) | BIT(25))
#define FW_STATUS_CHK_WARN ~(FW_STATUS_CHK_FATAL | FW_STATUS_CHK_ERR)
struct halmac_backup_info {
u32 mac_register;
u32 value;
u8 length;
};
static enum halmac_ret_status
update_fw_info_88xx(struct halmac_adapter *adapter, u8 *fw_bin);
static void
restore_mac_reg_88xx(struct halmac_adapter *adapter,
struct halmac_backup_info *info, u32 num);
static enum halmac_ret_status
dlfw_to_mem_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 src, u32 dest,
u32 size);
static enum halmac_ret_status
dlfw_end_flow_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
free_dl_fw_end_flow_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
send_fwpkt_88xx(struct halmac_adapter *adapter, u16 pg_addr, u8 *fw_bin,
u32 size);
static enum halmac_ret_status
iddma_dlfw_88xx(struct halmac_adapter *adapter, u32 src, u32 dest, u32 len,
u8 first);
static enum halmac_ret_status
iddma_en_88xx(struct halmac_adapter *adapter, u32 src, u32 dest, u32 ctrl);
static enum halmac_ret_status
check_fw_chksum_88xx(struct halmac_adapter *adapter, u32 mem_addr);
static void
fw_fatal_status_debug_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
start_dlfw_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size,
u32 dl_addr, u8 emem_only);
static enum halmac_ret_status
chk_fw_size_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size);
static void
chk_h2c_ver_88xx(struct halmac_adapter *adapter, u8 *fw_bin);
static void
wlan_cpu_en_88xx(struct halmac_adapter *adapter, u8 enable);
static void
pltfm_reset_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
proc_send_general_info_88xx(struct halmac_adapter *adapter,
struct halmac_general_info *info);
static enum halmac_ret_status
proc_send_phydm_info_88xx(struct halmac_adapter *adapter,
struct halmac_general_info *info);
/**
* download_firmware_88xx() - download Firmware
* @adapter : the adapter of halmac
* @fw_bin : firmware bin
* @size : firmware size
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
download_firmware_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size)
{
u8 value8;
u32 bckp_idx = 0;
u32 lte_coex_backup = 0;
struct halmac_backup_info bckp[DLFW_RESTORE_REG_NUM];
enum halmac_ret_status status;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (adapter->halmac_state.mac_pwr == HALMAC_MAC_POWER_OFF)
return HALMAC_RET_POWER_STATE_INVALID;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = chk_fw_size_88xx(adapter, fw_bin, size);
if (status != HALMAC_RET_SUCCESS)
return status;
chk_h2c_ver_88xx(adapter, fw_bin);
if (adapter->halmac_state.wlcpu_mode == HALMAC_WLCPU_ENTER_SLEEP)
PLTFM_MSG_WARN("[WARN]Enter Sleep..zZZ\n");
adapter->halmac_state.dlfw_state = HALMAC_DLFW_NONE;
status = ltecoex_reg_read_88xx(adapter, 0x38, <e_coex_backup);
if (status != HALMAC_RET_SUCCESS)
return status;
wlan_cpu_en_88xx(adapter, 0);
/* set HIQ to hi priority */
bckp[bckp_idx].length = 1;
bckp[bckp_idx].mac_register = REG_TXDMA_PQ_MAP + 1;
bckp[bckp_idx].value = HALMAC_REG_R8(REG_TXDMA_PQ_MAP + 1);
bckp_idx++;
value8 = HALMAC_DMA_MAPPING_HIGH << 6;
HALMAC_REG_W8(REG_TXDMA_PQ_MAP + 1, value8);
/* DLFW only use HIQ, map HIQ to hi priority */
adapter->pq_map[HALMAC_PQ_MAP_HI] = HALMAC_DMA_MAPPING_HIGH;
bckp[bckp_idx].length = 1;
bckp[bckp_idx].mac_register = REG_CR;
bckp[bckp_idx].value = HALMAC_REG_R8(REG_CR);
bckp_idx++;
bckp[bckp_idx].length = 4;
bckp[bckp_idx].mac_register = REG_H2CQ_CSR;
bckp[bckp_idx].value = BIT(31);
bckp_idx++;
value8 = BIT_HCI_TXDMA_EN | BIT_TXDMA_EN;
HALMAC_REG_W8(REG_CR, value8);
HALMAC_REG_W32(REG_H2CQ_CSR, BIT(31));
/* Config hi priority queue and public priority queue page number */
bckp[bckp_idx].length = 2;
bckp[bckp_idx].mac_register = REG_FIFOPAGE_INFO_1;
bckp[bckp_idx].value = HALMAC_REG_R16(REG_FIFOPAGE_INFO_1);
bckp_idx++;
bckp[bckp_idx].length = 4;
bckp[bckp_idx].mac_register = REG_RQPN_CTRL_2;
bckp[bckp_idx].value = HALMAC_REG_R32(REG_RQPN_CTRL_2) | BIT(31);
bckp_idx++;
HALMAC_REG_W16(REG_FIFOPAGE_INFO_1, 0x200);
HALMAC_REG_W32(REG_RQPN_CTRL_2, bckp[bckp_idx - 1].value);
/* Disable beacon related functions */
value8 = HALMAC_REG_R8(REG_BCN_CTRL);
bckp[bckp_idx].length = 1;
bckp[bckp_idx].mac_register = REG_BCN_CTRL;
bckp[bckp_idx].value = value8;
bckp_idx++;
value8 = (u8)((value8 & (~BIT(3))) | BIT(4));
HALMAC_REG_W8(REG_BCN_CTRL, value8);
if (adapter->intf == HALMAC_INTERFACE_SDIO)
HALMAC_REG_R32(REG_SDIO_FREE_TXPG);
pltfm_reset_88xx(adapter);
status = start_dlfw_88xx(adapter, fw_bin, size, 0, 0);
restore_mac_reg_88xx(adapter, bckp, DLFW_RESTORE_REG_NUM);
if (status != HALMAC_RET_SUCCESS)
goto DLFW_FAIL;
status = dlfw_end_flow_88xx(adapter);
if (status != HALMAC_RET_SUCCESS)
goto DLFW_FAIL;
status = ltecoex_reg_write_88xx(adapter, 0x38, lte_coex_backup);
if (status != HALMAC_RET_SUCCESS)
return status;
adapter->halmac_state.dlfw_state = HALMAC_DLFW_DONE;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
DLFW_FAIL:
/* Disable FWDL_EN */
value8 = HALMAC_REG_R8(REG_MCUFW_CTRL);
value8 &= ~BIT(0);
HALMAC_REG_W8(REG_MCUFW_CTRL, value8);
value8 = HALMAC_REG_R8(REG_SYS_FUNC_EN + 1);
value8 |= BIT(2);
HALMAC_REG_W8(REG_SYS_FUNC_EN + 1, value8);
if (ltecoex_reg_write_88xx(adapter, 0x38, lte_coex_backup) !=
HALMAC_RET_SUCCESS)
return HALMAC_RET_LTECOEX_READY_FAIL;
return status;
}
static enum halmac_ret_status
start_dlfw_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size,
u32 dl_addr, u8 emem_only)
{
u8 *cur_fw;
u16 value16;
u32 imem_size;
u32 dmem_size;
u32 emem_size = 0;
u32 addr;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status;
dmem_size =
rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_DMEM_SIZE)));
imem_size =
rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_IMEM_SIZE)));
if (0 != ((*(fw_bin + WLAN_FW_HDR_MEM_USAGE)) & BIT(4)))
emem_size =
rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_EMEM_SIZE)));
dmem_size += WLAN_FW_HDR_CHKSUM_SIZE;
imem_size += WLAN_FW_HDR_CHKSUM_SIZE;
if (emem_size != 0)
emem_size += WLAN_FW_HDR_CHKSUM_SIZE;
if (emem_only == 1) {
if (!emem_size)
return HALMAC_RET_SUCCESS;
goto DLFW_EMEM;
}
value16 = (u16)(HALMAC_REG_R16(REG_MCUFW_CTRL) & 0x3800);
value16 |= BIT(0);
HALMAC_REG_W16(REG_MCUFW_CTRL, value16);
cur_fw = fw_bin + WLAN_FW_HDR_SIZE;
addr = rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_DMEM_ADDR)));
addr &= ~BIT(31);
status = dlfw_to_mem_88xx(adapter, cur_fw, 0, addr, dmem_size);
if (status != HALMAC_RET_SUCCESS)
return status;
cur_fw = fw_bin + WLAN_FW_HDR_SIZE + dmem_size;
addr = rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_IMEM_ADDR)));
addr &= ~BIT(31);
status = dlfw_to_mem_88xx(adapter, cur_fw, 0, addr, imem_size);
if (status != HALMAC_RET_SUCCESS)
return status;
DLFW_EMEM:
if (emem_size) {
cur_fw = fw_bin + WLAN_FW_HDR_SIZE +
dmem_size + imem_size;
addr = rtk_le32_to_cpu(*((__le32 *)(fw_bin +
WLAN_FW_HDR_EMEM_ADDR)));
addr &= ~BIT(31);
status = dlfw_to_mem_88xx(adapter, cur_fw, dl_addr << 7, addr,
emem_size);
if (status != HALMAC_RET_SUCCESS)
return status;
if (emem_only == 1)
return HALMAC_RET_SUCCESS;
}
update_fw_info_88xx(adapter, fw_bin);
init_ofld_feature_state_machine_88xx(adapter);
return HALMAC_RET_SUCCESS;
}
static void
chk_h2c_ver_88xx(struct halmac_adapter *adapter, u8 *fw_bin)
{
u16 halmac_h2c_ver;
u16 fw_h2c_ver;
fw_h2c_ver = rtk_le16_to_cpu(*((__le16 *)(fw_bin +
WLAN_FW_HDR_H2C_FMT_VER)));
halmac_h2c_ver = H2C_FORMAT_VERSION;
PLTFM_MSG_TRACE("[TRACE]halmac h2c ver = %x, fw h2c ver = %x!!\n",
halmac_h2c_ver, fw_h2c_ver);
}
static enum halmac_ret_status
chk_fw_size_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size)
{
u32 imem_size;
u32 dmem_size;
u32 emem_size = 0;
u32 real_size;
if (size < WLAN_FW_HDR_SIZE) {
PLTFM_MSG_ERR("[ERR]FW size error!\n");
return HALMAC_RET_FW_SIZE_ERR;
}
dmem_size =
rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_DMEM_SIZE)));
imem_size =
rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_IMEM_SIZE)));
if (0 != ((*(fw_bin + WLAN_FW_HDR_MEM_USAGE)) & BIT(4)))
emem_size =
rtk_le32_to_cpu(*((__le32 *)(fw_bin + WLAN_FW_HDR_EMEM_SIZE)));
dmem_size += WLAN_FW_HDR_CHKSUM_SIZE;
imem_size += WLAN_FW_HDR_CHKSUM_SIZE;
if (emem_size != 0)
emem_size += WLAN_FW_HDR_CHKSUM_SIZE;
real_size = WLAN_FW_HDR_SIZE + dmem_size + imem_size + emem_size;
if (size != real_size) {
PLTFM_MSG_ERR("[ERR]size != real size!\n");
return HALMAC_RET_FW_SIZE_ERR;
}
return HALMAC_RET_SUCCESS;
}
static void
wlan_cpu_en_88xx(struct halmac_adapter *adapter, u8 enable)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (enable == 1) {
/* cpu io interface enable or disable */
value8 = HALMAC_REG_R8(REG_RSV_CTRL + 1);
value8 |= BIT(0);
HALMAC_REG_W8(REG_RSV_CTRL + 1, value8);
/* cpu enable or disable */
value8 = HALMAC_REG_R8(REG_SYS_FUNC_EN + 1);
value8 |= BIT(2);
HALMAC_REG_W8(REG_SYS_FUNC_EN + 1, value8);
} else {
/* cpu enable or disable */
value8 = HALMAC_REG_R8(REG_SYS_FUNC_EN + 1);
value8 &= ~BIT(2);
HALMAC_REG_W8(REG_SYS_FUNC_EN + 1, value8);
/* cpu io interface enable or disable */
value8 = HALMAC_REG_R8(REG_RSV_CTRL + 1);
value8 &= ~BIT(0);
HALMAC_REG_W8(REG_RSV_CTRL + 1, value8);
}
}
static void
pltfm_reset_88xx(struct halmac_adapter *adapter)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_CPU_DMEM_CON + 2) & ~BIT(0);
HALMAC_REG_W8(REG_CPU_DMEM_CON + 2, value8);
/* For 8822B & 8821C clock sync issue */
if (adapter->chip_id == HALMAC_CHIP_ID_8821C ||
adapter->chip_id == HALMAC_CHIP_ID_8822B) {
value8 = HALMAC_REG_R8(REG_SYS_CLK_CTRL + 1) & ~BIT(6);
HALMAC_REG_W8(REG_SYS_CLK_CTRL + 1, value8);
}
value8 = HALMAC_REG_R8(REG_CPU_DMEM_CON + 2) | BIT(0);
HALMAC_REG_W8(REG_CPU_DMEM_CON + 2, value8);
if (adapter->chip_id == HALMAC_CHIP_ID_8821C ||
adapter->chip_id == HALMAC_CHIP_ID_8822B) {
value8 = HALMAC_REG_R8(REG_SYS_CLK_CTRL + 1) | BIT(6);
HALMAC_REG_W8(REG_SYS_CLK_CTRL + 1, value8);
}
}
/**
* free_download_firmware_88xx() - download specific memory firmware
* @adapter
* @mem_sel : memory selection
* @fw_bin : firmware bin
* @size : firmware size
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
*/
enum halmac_ret_status
free_download_firmware_88xx(struct halmac_adapter *adapter,
enum halmac_dlfw_mem mem_sel, u8 *fw_bin, u32 size)
{
u8 tx_pause_bckp;
u32 dl_addr;
u32 dlfw_size_bckp;
enum halmac_ret_status status;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = chk_fw_size_88xx(adapter, fw_bin, size);
if (status != HALMAC_RET_SUCCESS)
return status;
if (((*(fw_bin + WLAN_FW_HDR_MEM_USAGE)) & BIT(4)) == 0)
return HALMAC_RET_SUCCESS;
dlfw_size_bckp = adapter->dlfw_pkt_size;
if (mem_sel == HALMAC_DLFW_MEM_EMEM) {
dl_addr = 0;
} else {
dl_addr = adapter->txff_alloc.rsvd_h2c_info_addr;
adapter->dlfw_pkt_size = (dlfw_size_bckp > DLFW_RSVDPG_SIZE) ?
DLFW_RSVDPG_SIZE : dlfw_size_bckp;
}
tx_pause_bckp = HALMAC_REG_R8(REG_TXPAUSE);
HALMAC_REG_W8(REG_TXPAUSE, tx_pause_bckp | BIT(7));
status = start_dlfw_88xx(adapter, fw_bin, size, dl_addr, 1);
if (status != HALMAC_RET_SUCCESS)
goto DL_FREE_FW_END;
status = free_dl_fw_end_flow_88xx(adapter);
DL_FREE_FW_END:
HALMAC_REG_W8(REG_TXPAUSE, tx_pause_bckp);
adapter->dlfw_pkt_size = dlfw_size_bckp;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
/**
* reset_wifi_fw_88xx() - reset wifi fw
* @adapter : the adapter of halmac
* Author : LIN YONG-CHING
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
reset_wifi_fw_88xx(struct halmac_adapter *adapter)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
wlan_cpu_en_88xx(adapter, 0);
pltfm_reset_88xx(adapter);
init_ofld_feature_state_machine_88xx(adapter);
wlan_cpu_en_88xx(adapter, 1);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* get_fw_version_88xx() - get FW version
* @adapter : the adapter of halmac
* @ver : fw version info
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_fw_version_88xx(struct halmac_adapter *adapter,
struct halmac_fw_version *ver)
{
struct halmac_fw_version *info = &adapter->fw_ver;
if (!ver)
return HALMAC_RET_NULL_POINTER;
if (adapter->halmac_state.dlfw_state == HALMAC_DLFW_NONE)
return HALMAC_RET_NO_DLFW;
ver->version = info->version;
ver->sub_version = info->sub_version;
ver->sub_index = info->sub_index;
ver->h2c_version = info->h2c_version;
ver->build_time.month = info->build_time.month;
ver->build_time.date = info->build_time.date;
ver->build_time.hour = info->build_time.hour;
ver->build_time.min = info->build_time.min;
ver->build_time.year = info->build_time.year;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
update_fw_info_88xx(struct halmac_adapter *adapter, u8 *fw_bin)
{
struct halmac_fw_version *info = &adapter->fw_ver;
info->version =
rtk_le16_to_cpu(*((__le16 *)(fw_bin + WLAN_FW_HDR_VERSION)));
info->sub_version = *(fw_bin + WLAN_FW_HDR_SUBVERSION);
info->sub_index = *(fw_bin + WLAN_FW_HDR_SUBINDEX);
info->h2c_version = rtk_le16_to_cpu(*((__le16 *)(fw_bin +
WLAN_FW_HDR_H2C_FMT_VER)));
info->build_time.month = *(fw_bin + WLAN_FW_HDR_MONTH);
info->build_time.date = *(fw_bin + WLAN_FW_HDR_DATE);
info->build_time.hour = *(fw_bin + WLAN_FW_HDR_HOUR);
info->build_time.min = *(fw_bin + WLAN_FW_HDR_MIN);
info->build_time.year =
rtk_le16_to_cpu(*((__le16 *)(fw_bin + WLAN_FW_HDR_YEAR)));
PLTFM_MSG_TRACE("[TRACE]=== FW info ===\n");
PLTFM_MSG_TRACE("[TRACE]ver : %X\n", info->version);
PLTFM_MSG_TRACE("[TRACE]sub-ver : %X\n",
info->sub_version);
PLTFM_MSG_TRACE("[TRACE]sub-idx : %X\n",
info->sub_index);
PLTFM_MSG_TRACE("[TRACE]build : %d/%d/%d %d:%d\n",
info->build_time.year, info->build_time.month,
info->build_time.date, info->build_time.hour,
info->build_time.min);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
dlfw_to_mem_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 src, u32 dest,
u32 size)
{
u8 first_part;
u32 mem_offset;
u32 residue_size;
u32 pkt_size;
enum halmac_ret_status status;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
mem_offset = 0;
first_part = 1;
residue_size = size;
HALMAC_REG_W32_SET(REG_DDMA_CH0CTRL, BIT_DDMACH0_RESET_CHKSUM_STS);
while (residue_size != 0) {
if (residue_size >= adapter->dlfw_pkt_size)
pkt_size = adapter->dlfw_pkt_size;
else
pkt_size = residue_size;
status = send_fwpkt_88xx(adapter, (u16)(src >> 7),
fw_bin + mem_offset, pkt_size);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send fw pkt!!\n");
return status;
}
status = iddma_dlfw_88xx(adapter,
OCPBASE_TXBUF_88XX +
src + adapter->hw_cfg_info.txdesc_size,
dest + mem_offset, pkt_size,
first_part);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]iddma dlfw!!\n");
return status;
}
first_part = 0;
mem_offset += pkt_size;
residue_size -= pkt_size;
}
status = check_fw_chksum_88xx(adapter, dest);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]chk fw chksum!!\n");
return status;
}
return HALMAC_RET_SUCCESS;
}
static void
restore_mac_reg_88xx(struct halmac_adapter *adapter,
struct halmac_backup_info *info, u32 num)
{
u8 len;
u32 i;
u32 reg;
u32 value;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
struct halmac_backup_info *curr_info = info;
for (i = 0; i < num; i++) {
reg = curr_info->mac_register;
value = curr_info->value;
len = curr_info->length;
if (len == 1)
HALMAC_REG_W8(reg, (u8)value);
else if (len == 2)
HALMAC_REG_W16(reg, (u16)value);
else if (len == 4)
HALMAC_REG_W32(reg, value);
curr_info++;
}
}
static enum halmac_ret_status
dlfw_end_flow_88xx(struct halmac_adapter *adapter)
{
u16 fw_ctrl;
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W32(REG_TXDMA_STATUS, BIT(2));
/* Check IMEM & DMEM checksum is OK or not */
fw_ctrl = HALMAC_REG_R16(REG_MCUFW_CTRL);
if ((fw_ctrl & 0x50) != 0x50)
return HALMAC_RET_IDMEM_CHKSUM_FAIL;
HALMAC_REG_W16(REG_MCUFW_CTRL, (fw_ctrl | BIT_FW_DW_RDY) & ~BIT(0));
wlan_cpu_en_88xx(adapter, 1);
PLTFM_MSG_TRACE("[TRACE]Dlfw OK, enable CPU\n");
cnt = 5000;
while (HALMAC_REG_R16(REG_MCUFW_CTRL) != 0xC078) {
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]Check 0x80 = 0xC078 fail\n");
if ((HALMAC_REG_R32(REG_FW_DBG7) & 0xFFFFFF00) ==
ILLEGAL_KEY_GROUP) {
PLTFM_MSG_ERR("[ERR]Key!!\n");
return HALMAC_RET_ILLEGAL_KEY_FAIL;
}
return HALMAC_RET_FW_READY_CHK_FAIL;
}
cnt--;
PLTFM_DELAY_US(50);
}
PLTFM_MSG_TRACE("[TRACE]0x80=0xC078, cnt=%d\n", cnt);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
free_dl_fw_end_flow_88xx(struct halmac_adapter *adapter)
{
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
cnt = 100;
while (HALMAC_REG_R8(REG_HMETFR + 3) != 0) {
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]0x1CF != 0\n");
return HALMAC_RET_DLFW_FAIL;
}
PLTFM_DELAY_US(50);
}
HALMAC_REG_W8(REG_HMETFR + 3, ID_INFORM_DLEMEM_RDY);
cnt = 10000;
while (HALMAC_REG_R8(REG_MCU_TST_CFG) != ID_CHECK_DLEMEM_RDY) {
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]0x84 != 0x80\n");
return HALMAC_RET_DLFW_FAIL;
}
PLTFM_DELAY_US(50);
}
HALMAC_REG_W8(REG_MCU_TST_CFG, 0);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
send_fwpkt_88xx(struct halmac_adapter *adapter, u16 pg_addr, u8 *fw_bin,
u32 size)
{
u8 *fw_add_dum = NULL;
enum halmac_ret_status status;
if (adapter->intf == HALMAC_INTERFACE_USB &&
!((size + TX_DESC_SIZE_88XX) & (512 - 1))) {
fw_add_dum = (u8 *)PLTFM_MALLOC(size + 1);
if (!fw_add_dum) {
PLTFM_MSG_ERR("[ERR]fw bin malloc!!\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMCPY(fw_add_dum, fw_bin, size);
status = dl_rsvd_page_88xx(adapter, pg_addr,
fw_add_dum, size + 1);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]dl rsvd page - dum!!\n");
PLTFM_FREE(fw_add_dum, size + 1);
return status;
}
status = dl_rsvd_page_88xx(adapter, pg_addr, fw_bin, size);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]dl rsvd page!!\n");
return status;
}
static enum halmac_ret_status
iddma_dlfw_88xx(struct halmac_adapter *adapter, u32 src, u32 dest, u32 len,
u8 first)
{
u32 cnt;
u32 ch0_ctrl = (u32)(BIT_DDMACH0_CHKSUM_EN | BIT_DDMACH0_OWN);
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
cnt = HALMC_DDMA_POLLING_COUNT;
while (HALMAC_REG_R32(REG_DDMA_CH0CTRL) & BIT_DDMACH0_OWN) {
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]ch0 ready!!\n");
return HALMAC_RET_DDMA_FAIL;
}
}
ch0_ctrl |= (len & BIT_MASK_DDMACH0_DLEN);
if (first == 0)
ch0_ctrl |= BIT_DDMACH0_CHKSUM_CONT;
if (iddma_en_88xx(adapter, src, dest, ch0_ctrl) !=
HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]iddma en!!\n");
return HALMAC_RET_DDMA_FAIL;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
iddma_en_88xx(struct halmac_adapter *adapter, u32 src, u32 dest, u32 ctrl)
{
u32 cnt = HALMC_DDMA_POLLING_COUNT;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W32(REG_DDMA_CH0SA, src);
HALMAC_REG_W32(REG_DDMA_CH0DA, dest);
HALMAC_REG_W32(REG_DDMA_CH0CTRL, ctrl);
while (HALMAC_REG_R32(REG_DDMA_CH0CTRL) & BIT_DDMACH0_OWN) {
cnt--;
if (cnt == 0)
return HALMAC_RET_DDMA_FAIL;
}
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
check_fw_chksum_88xx(struct halmac_adapter *adapter, u32 mem_addr)
{
u8 fw_ctrl;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
fw_ctrl = HALMAC_REG_R8(REG_MCUFW_CTRL);
if (HALMAC_REG_R32(REG_DDMA_CH0CTRL) & BIT_DDMACH0_CHKSUM_STS) {
if (mem_addr < OCPBASE_DMEM_88XX) {
fw_ctrl |= BIT_IMEM_DW_OK;
fw_ctrl &= ~BIT_IMEM_CHKSUM_OK;
HALMAC_REG_W8(REG_MCUFW_CTRL, fw_ctrl);
} else {
fw_ctrl |= BIT_DMEM_DW_OK;
fw_ctrl &= ~BIT_DMEM_CHKSUM_OK;
HALMAC_REG_W8(REG_MCUFW_CTRL, fw_ctrl);
}
PLTFM_MSG_ERR("[ERR]fw chksum!!\n");
return HALMAC_RET_FW_CHECKSUM_FAIL;
}
if (mem_addr < OCPBASE_DMEM_88XX) {
fw_ctrl |= (BIT_IMEM_DW_OK | BIT_IMEM_CHKSUM_OK);
HALMAC_REG_W8(REG_MCUFW_CTRL, fw_ctrl);
} else {
fw_ctrl |= (BIT_DMEM_DW_OK | BIT_DMEM_CHKSUM_OK);
HALMAC_REG_W8(REG_MCUFW_CTRL, fw_ctrl);
}
return HALMAC_RET_SUCCESS;
}
/**
* check_fw_status_88xx() -check fw status
* @adapter : the adapter of halmac
* @status : fw status
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
check_fw_status_88xx(struct halmac_adapter *adapter, u8 *fw_status)
{
u32 cnt;
u32 fw_dbg6;
u32 fw_pc;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
*fw_status = 1;
fw_dbg6 = HALMAC_REG_R32(REG_FW_DBG6);
if (fw_dbg6 != 0) {
PLTFM_MSG_ERR("[ERR]REG_FW_DBG6 !=0\n");
if ((fw_dbg6 & FW_STATUS_CHK_WARN) != 0)
PLTFM_MSG_WARN("[WARN]fw status(warn):%X\n", fw_dbg6);
if ((fw_dbg6 & FW_STATUS_CHK_ERR) != 0)
PLTFM_MSG_ERR("[ERR]fw status(err):%X\n", fw_dbg6);
if ((fw_dbg6 & FW_STATUS_CHK_FATAL) != 0) {
PLTFM_MSG_ERR("[ERR]fw status(fatal):%X\n", fw_dbg6);
fw_fatal_status_debug_88xx(adapter);
*fw_status = 0;
return status;
}
}
fw_pc = HALMAC_REG_R32(REG_FW_DBG7);
cnt = 10;
while (HALMAC_REG_R32(REG_FW_DBG7) == fw_pc) {
cnt--;
if (cnt == 0)
break;
}
if (cnt == 0) {
cnt = 200;
while (HALMAC_REG_R32(REG_FW_DBG7) == fw_pc) {
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]fw pc\n");
*fw_status = 0;
return status;
}
PLTFM_DELAY_US(50);
}
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
static void
fw_fatal_status_debug_88xx(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_ERR("[ERR]0x%X = %X\n",
REG_FW_DBG6, HALMAC_REG_R32(REG_FW_DBG6));
PLTFM_MSG_ERR("[ERR]0x%X = %X\n",
REG_ARFR5, HALMAC_REG_R32(REG_ARFR5));
PLTFM_MSG_ERR("[ERR]0x%X = %X\n",
REG_MCUTST_I, HALMAC_REG_R32(REG_MCUTST_I));
}
enum halmac_ret_status
dump_fw_dmem_88xx(struct halmac_adapter *adapter, u8 *dmem, u32 *size)
{
return HALMAC_RET_SUCCESS;
}
/**
* cfg_max_dl_size_88xx() - config max download FW size
* @adapter : the adapter of halmac
* @size : max download fw size
*
* Halmac uses this setting to set max packet size for
* download FW.
* If user has not called this API, halmac use default
* setting for download FW
* Note1 : size need multiple of 2
* Note2 : max size is 31K
*
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_max_dl_size_88xx(struct halmac_adapter *adapter, u32 size)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (size > DLFW_PKT_SIZE_LIMIT) {
PLTFM_MSG_ERR("[ERR]size > max dl size!\n");
return HALMAC_RET_CFG_DLFW_SIZE_FAIL;
}
if ((size & (2 - 1)) != 0) {
PLTFM_MSG_ERR("[ERR]not multiple of 2!\n");
return HALMAC_RET_CFG_DLFW_SIZE_FAIL;
}
adapter->dlfw_pkt_size = size;
PLTFM_MSG_TRACE("[TRACE]Cfg max size:%X\n", size);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* enter_cpu_sleep_mode_88xx() -wlan cpu enter sleep mode
* @adapter : the adapter of halmac
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
enter_cpu_sleep_mode_88xx(struct halmac_adapter *adapter)
{
u32 cnt;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_wlcpu_mode *cur_mode = &adapter->halmac_state.wlcpu_mode;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (*cur_mode != HALMAC_WLCPU_ACTIVE)
return HALMAC_RET_ERROR_STATE;
cnt = 100;
while (HALMAC_REG_R8(REG_HMETFR + 3) != 0) {
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]0x1CF != 0\n");
return HALMAC_RET_STATE_INCORRECT;
}
PLTFM_DELAY_US(50);
}
HALMAC_REG_W8(REG_HMETFR + 3, ID_INFORM_ENETR_CPU_SLEEP);
*cur_mode = HALMAC_WLCPU_ENTER_SLEEP;
return HALMAC_RET_SUCCESS;
}
/**
* get_cpu_mode_88xx() -get wlcpu mode
* @adapter : the adapter of halmac
* @mode : cpu mode
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_cpu_mode_88xx(struct halmac_adapter *adapter,
enum halmac_wlcpu_mode *mode)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_wlcpu_mode *cur_mode = &adapter->halmac_state.wlcpu_mode;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (*cur_mode == HALMAC_WLCPU_ACTIVE) {
*mode = HALMAC_WLCPU_ACTIVE;
return HALMAC_RET_SUCCESS;
}
if (*cur_mode == HALMAC_WLCPU_SLEEP) {
*mode = HALMAC_WLCPU_SLEEP;
return HALMAC_RET_SUCCESS;
}
if (HALMAC_REG_R8(REG_MCU_TST_CFG) == ID_CHECK_ENETR_CPU_SLEEP) {
*mode = HALMAC_WLCPU_SLEEP;
HALMAC_REG_W8(REG_MCU_TST_CFG, 0);
} else {
*mode = HALMAC_WLCPU_ENTER_SLEEP;
}
return HALMAC_RET_SUCCESS;
}
/**
* send_general_info_88xx() -send general information to FW
* @adapter : the adapter of halmac
* @info : general information
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
send_general_info_88xx(struct halmac_adapter *adapter,
struct halmac_general_info *info)
{
u8 h2cq_ele[4] = {0};
u32 h2cq_addr;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (adapter->fw_ver.h2c_version < 4)
return HALMAC_RET_FW_NO_SUPPORT;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (adapter->halmac_state.dlfw_state == HALMAC_DLFW_NONE) {
PLTFM_MSG_ERR("[ERR]no dl fw!!\n");
return HALMAC_RET_NO_DLFW;
}
status = proc_send_general_info_88xx(adapter, info);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send gen info!!\n");
return status;
}
status = proc_send_phydm_info_88xx(adapter, info);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send phydm info\n");
return status;
}
h2cq_addr = adapter->txff_alloc.rsvd_h2cq_addr;
h2cq_addr <<= TX_PAGE_SIZE_SHIFT_88XX;
status = dump_fifo_88xx(adapter, HAL_FIFO_SEL_TX,
h2cq_addr, 4, h2cq_ele);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dump h2cq!!\n");
return status;
}
if ((h2cq_ele[0] & 0x7F) != 0x01 || h2cq_ele[1] != 0xFF) {
PLTFM_MSG_ERR("[ERR]h2cq compare!!\n");
return HALMAC_RET_SEND_H2C_FAIL;
}
if (adapter->halmac_state.dlfw_state == HALMAC_DLFW_DONE)
adapter->halmac_state.dlfw_state = HALMAC_GEN_INFO_SENT;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
proc_send_general_info_88xx(struct halmac_adapter *adapter,
struct halmac_general_info *info)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s\n", __func__);
GENERAL_INFO_SET_FW_TX_BOUNDARY(h2c_buf,
adapter->txff_alloc.rsvd_fw_txbuf_addr -
adapter->txff_alloc.rsvd_boundary);
hdr_info.sub_cmd_id = SUB_CMD_ID_GENERAL_INFO;
hdr_info.content_size = 4;
hdr_info.ack = 0;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
return status;
}
static enum halmac_ret_status
proc_send_phydm_info_88xx(struct halmac_adapter *adapter,
struct halmac_general_info *info)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s\n", __func__);
PHYDM_INFO_SET_REF_TYPE(h2c_buf, info->rfe_type);
PHYDM_INFO_SET_RF_TYPE(h2c_buf, info->rf_type);
PHYDM_INFO_SET_CUT_VER(h2c_buf, adapter->chip_ver);
PHYDM_INFO_SET_RX_ANT_STATUS(h2c_buf, info->rx_ant_status);
PHYDM_INFO_SET_TX_ANT_STATUS(h2c_buf, info->tx_ant_status);
hdr_info.sub_cmd_id = SUB_CMD_ID_PHYDM_INFO;
hdr_info.content_size = 8;
hdr_info.ack = 0;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
return status;
}
/**
* drv_fwctrl_88xx() - send drv-defined h2c pkt
* @adapter : the adapter of halmac
* @payload : no include offload pkt h2c header
* @size : no include offload pkt h2c header
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
drv_fwctrl_88xx(struct halmac_adapter *adapter, u8 *payload, u32 size, u8 ack)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num = 0;
struct halmac_h2c_header_info hdr_info;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
if (!payload)
return HALMAC_RET_DATA_BUF_NULL;
if (size > H2C_PKT_SIZE_88XX - H2C_PKT_HDR_SIZE_88XX)
return HALMAC_RET_DATA_SIZE_INCORRECT;
PLTFM_MEMCPY(h2c_buf + H2C_PKT_HDR_SIZE_88XX, payload, size);
hdr_info.sub_cmd_id = SUB_CMD_ID_FW_FWCTRL;
hdr_info.content_size = (u16)size;
hdr_info.ack = ack;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS)
PLTFM_MSG_ERR("[ERR]send h2c!!\n");
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_fw_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_FW_88XX_H_
#define _HALMAC_FW_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
#define HALMC_DDMA_POLLING_COUNT 1000
enum halmac_ret_status
download_firmware_88xx(struct halmac_adapter *adapter, u8 *fw_bin, u32 size);
enum halmac_ret_status
free_download_firmware_88xx(struct halmac_adapter *adapter,
enum halmac_dlfw_mem mem_sel, u8 *fw_bin, u32 size);
enum halmac_ret_status
reset_wifi_fw_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
get_fw_version_88xx(struct halmac_adapter *adapter,
struct halmac_fw_version *ver);
enum halmac_ret_status
check_fw_status_88xx(struct halmac_adapter *adapter, u8 *fw_status);
enum halmac_ret_status
dump_fw_dmem_88xx(struct halmac_adapter *adapter, u8 *dmem, u32 *size);
enum halmac_ret_status
cfg_max_dl_size_88xx(struct halmac_adapter *adapter, u32 size);
enum halmac_ret_status
enter_cpu_sleep_mode_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
get_cpu_mode_88xx(struct halmac_adapter *adapter,
enum halmac_wlcpu_mode *mode);
enum halmac_ret_status
send_general_info_88xx(struct halmac_adapter *adapter,
struct halmac_general_info *info);
enum halmac_ret_status
drv_fwctrl_88xx(struct halmac_adapter *adapter, u8 *payload, u32 size, u8 ack);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_FW_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_gpio_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_gpio_88xx.h"
#if HALMAC_88XX_SUPPORT
/**
* pinmux_wl_led_mode_88xx() -control wlan led gpio function
* @adapter : the adapter of halmac
* @mode : wlan led mode
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_wl_led_mode_88xx(struct halmac_adapter *adapter,
enum halmac_wlled_mode mode)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
value8 = HALMAC_REG_R8(REG_LED_CFG + 2);
value8 &= ~(BIT(6));
value8 |= BIT(3);
value8 &= ~(BIT(0) | BIT(1) | BIT(2));
switch (mode) {
case HALMAC_WLLED_MODE_TRX:
value8 |= 2;
break;
case HALMAC_WLLED_MODE_TX:
value8 |= 4;
break;
case HALMAC_WLLED_MODE_RX:
value8 |= 6;
break;
case HALMAC_WLLED_MODE_SW_CTRL:
value8 |= 0;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
HALMAC_REG_W8(REG_LED_CFG + 2, value8);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* pinmux_wl_led_sw_ctrl_88xx() -control wlan led on/off
* @adapter : the adapter of halmac
* @on : on(1), off(0)
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
void
pinmux_wl_led_sw_ctrl_88xx(struct halmac_adapter *adapter, u8 on)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_LED_CFG + 2);
value8 = (on == 0) ? value8 | BIT(3) : value8 & ~(BIT(3));
HALMAC_REG_W8(REG_LED_CFG + 2, value8);
}
/**
* pinmux_sdio_int_polarity_88xx() -control sdio int polarity
* @adapter : the adapter of halmac
* @low_active : low active(1), high active(0)
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
void
pinmux_sdio_int_polarity_88xx(struct halmac_adapter *adapter, u8 low_active)
{
u8 value8;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
value8 = HALMAC_REG_R8(REG_SYS_SDIO_CTRL + 2);
value8 = (low_active == 0) ? value8 | BIT(3) : value8 & ~(BIT(3));
HALMAC_REG_W8(REG_SYS_SDIO_CTRL + 2, value8);
}
/**
* pinmux_gpio_mode_88xx() -control gpio io mode
* @adapter : the adapter of halmac
* @gpio_id : gpio0~15(0~15)
* @output : output(1), input(0)
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_gpio_mode_88xx(struct halmac_adapter *adapter, u8 gpio_id, u8 output)
{
u16 value16;
u8 in_out;
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (gpio_id <= 7)
offset = REG_GPIO_PIN_CTRL + 2;
else if (gpio_id >= 8 && gpio_id <= 15)
offset = REG_GPIO_EXT_CTRL + 2;
else
return HALMAC_RET_WRONG_GPIO;
in_out = (output == 0) ? 0 : 1;
gpio_id &= (8 - 1);
value16 = HALMAC_REG_R16(offset);
value16 &= ~((1 << gpio_id) | (1 << gpio_id << 8));
value16 |= (in_out << gpio_id);
HALMAC_REG_W16(offset, value16);
return HALMAC_RET_SUCCESS;
}
/**
* pinmux_gpio_output_88xx() -control gpio output high/low
* @adapter : the adapter of halmac
* @gpio_id : gpio0~15(0~15)
* @high : high(1), low(0)
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_gpio_output_88xx(struct halmac_adapter *adapter, u8 gpio_id, u8 high)
{
u8 value8;
u8 hi_low;
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (gpio_id <= 7)
offset = REG_GPIO_PIN_CTRL + 1;
else if (gpio_id >= 8 && gpio_id <= 15)
offset = REG_GPIO_EXT_CTRL + 1;
else
return HALMAC_RET_WRONG_GPIO;
hi_low = (high == 0) ? 0 : 1;
gpio_id &= (8 - 1);
value8 = HALMAC_REG_R8(offset);
value8 &= ~(1 << gpio_id);
value8 |= (hi_low << gpio_id);
HALMAC_REG_W8(offset, value8);
return HALMAC_RET_SUCCESS;
}
/**
* halmac_pinmux_status_88xx() -get current gpio status(high/low)
* @adapter : the adapter of halmac
* @pin_id : 0~15(0~15)
* @phigh : high(1), low(0)
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pinmux_pin_status_88xx(struct halmac_adapter *adapter, u8 pin_id, u8 *high)
{
u8 value8;
u32 offset;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (pin_id <= 7)
offset = REG_GPIO_PIN_CTRL;
else if (pin_id >= 8 && pin_id <= 15)
offset = REG_GPIO_EXT_CTRL;
else
return HALMAC_RET_WRONG_GPIO;
pin_id &= (8 - 1);
value8 = HALMAC_REG_R8(offset);
*high = (value8 & (1 << pin_id)) >> pin_id;
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
pinmux_parser_88xx(struct halmac_adapter *adapter,
const struct halmac_gpio_pimux_list *list, u32 size,
u32 gpio_id, u32 *cur_func)
{
u32 i;
u8 value8;
const struct halmac_gpio_pimux_list *cur_list = list;
enum halmac_gpio_cfg_state *state;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
state = &adapter->halmac_state.gpio_cfg_state;
if (*state == HALMAC_GPIO_CFG_STATE_BUSY)
return HALMAC_RET_BUSY_STATE;
*state = HALMAC_GPIO_CFG_STATE_BUSY;
for (i = 0; i < size; i++) {
if (gpio_id != cur_list->id) {
PLTFM_MSG_ERR("[ERR]offset:%X, value:%X, func:%X\n",
cur_list->offset, cur_list->value,
cur_list->func);
PLTFM_MSG_ERR("[ERR]id1 : %X, id2 : %X\n",
gpio_id, cur_list->id);
*state = HALMAC_GPIO_CFG_STATE_IDLE;
return HALMAC_RET_GET_PINMUX_ERR;
}
value8 = HALMAC_REG_R8(cur_list->offset);
value8 &= cur_list->msk;
if (value8 == cur_list->value) {
*cur_func = cur_list->func;
break;
}
cur_list++;
}
*state = HALMAC_GPIO_CFG_STATE_IDLE;
if (i == size)
return HALMAC_RET_GET_PINMUX_ERR;
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
pinmux_switch_88xx(struct halmac_adapter *adapter,
const struct halmac_gpio_pimux_list *list, u32 size,
u32 gpio_id, enum halmac_gpio_func gpio_func)
{
u32 i;
u8 value8;
u16 switch_func;
const struct halmac_gpio_pimux_list *cur_list = list;
enum halmac_gpio_cfg_state *state;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
state = &adapter->halmac_state.gpio_cfg_state;
if (*state == HALMAC_GPIO_CFG_STATE_BUSY)
return HALMAC_RET_BUSY_STATE;
switch (gpio_func) {
case HALMAC_GPIO_FUNC_WL_LED:
switch_func = HALMAC_WL_LED;
break;
case HALMAC_GPIO_FUNC_SDIO_INT:
switch_func = HALMAC_SDIO_INT;
break;
case HALMAC_GPIO_FUNC_BT_HOST_WAKE1:
case HALMAC_GPIO_FUNC_BT_DEV_WAKE1:
switch_func = HALMAC_GPIO13_14_WL_CTRL_EN;
break;
case HALMAC_GPIO_FUNC_SW_IO_0:
case HALMAC_GPIO_FUNC_SW_IO_1:
case HALMAC_GPIO_FUNC_SW_IO_2:
case HALMAC_GPIO_FUNC_SW_IO_3:
case HALMAC_GPIO_FUNC_SW_IO_4:
case HALMAC_GPIO_FUNC_SW_IO_5:
case HALMAC_GPIO_FUNC_SW_IO_6:
case HALMAC_GPIO_FUNC_SW_IO_7:
case HALMAC_GPIO_FUNC_SW_IO_8:
case HALMAC_GPIO_FUNC_SW_IO_9:
case HALMAC_GPIO_FUNC_SW_IO_10:
case HALMAC_GPIO_FUNC_SW_IO_11:
case HALMAC_GPIO_FUNC_SW_IO_12:
case HALMAC_GPIO_FUNC_SW_IO_13:
case HALMAC_GPIO_FUNC_SW_IO_14:
case HALMAC_GPIO_FUNC_SW_IO_15:
switch_func = HALMAC_SW_IO;
break;
default:
return HALMAC_RET_SWITCH_CASE_ERROR;
}
for (i = 0; i < size; i++) {
if (gpio_id != cur_list->id) {
PLTFM_MSG_ERR("[ERR]offset:%X, value:%X, func:%X\n",
cur_list->offset, cur_list->value,
cur_list->func);
PLTFM_MSG_ERR("[ERR]id1 : %X, id2 : %X\n",
gpio_id, cur_list->id);
return HALMAC_RET_GET_PINMUX_ERR;
}
if (switch_func == cur_list->func)
break;
cur_list++;
}
if (i == size) {
PLTFM_MSG_ERR("[ERR]gpio func error:%X %X\n",
gpio_id, cur_list->id);
return HALMAC_RET_GET_PINMUX_ERR;
}
*state = HALMAC_GPIO_CFG_STATE_BUSY;
cur_list = list;
for (i = 0; i < size; i++) {
value8 = HALMAC_REG_R8(cur_list->offset);
value8 &= ~(cur_list->msk);
if (switch_func == cur_list->func) {
value8 |= (cur_list->value & cur_list->msk);
HALMAC_REG_W8(cur_list->offset, value8);
break;
}
value8 |= (~cur_list->value & cur_list->msk);
HALMAC_REG_W8(cur_list->offset, value8);
cur_list++;
}
*state = HALMAC_GPIO_CFG_STATE_IDLE;
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
pinmux_record_88xx(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func, u8 val)
{
switch (gpio_func) {
case HALMAC_GPIO_FUNC_WL_LED:
adapter->pinmux_info.wl_led = val;
break;
case HALMAC_GPIO_FUNC_SDIO_INT:
adapter->pinmux_info.sdio_int = val;
break;
case HALMAC_GPIO_FUNC_BT_HOST_WAKE1:
adapter->pinmux_info.bt_host_wake = val;
break;
case HALMAC_GPIO_FUNC_BT_DEV_WAKE1:
adapter->pinmux_info.bt_dev_wake = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_0:
adapter->pinmux_info.sw_io_0 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_1:
adapter->pinmux_info.sw_io_1 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_2:
adapter->pinmux_info.sw_io_2 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_3:
adapter->pinmux_info.sw_io_3 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_4:
adapter->pinmux_info.sw_io_4 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_5:
adapter->pinmux_info.sw_io_5 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_6:
adapter->pinmux_info.sw_io_6 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_7:
adapter->pinmux_info.sw_io_7 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_8:
adapter->pinmux_info.sw_io_8 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_9:
adapter->pinmux_info.sw_io_9 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_10:
adapter->pinmux_info.sw_io_10 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_11:
adapter->pinmux_info.sw_io_11 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_12:
adapter->pinmux_info.sw_io_12 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_13:
adapter->pinmux_info.sw_io_13 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_14:
adapter->pinmux_info.sw_io_14 = val;
break;
case HALMAC_GPIO_FUNC_SW_IO_15:
adapter->pinmux_info.sw_io_15 = val;
break;
default:
return HALMAC_RET_GET_PINMUX_ERR;
}
return HALMAC_RET_SUCCESS;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_gpio_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_GPIO_88XX_H_
#define _HALMAC_GPIO_88XX_H_
#include "../halmac_api.h"
#include "../halmac_gpio_cmd.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
pinmux_wl_led_mode_88xx(struct halmac_adapter *adapter,
enum halmac_wlled_mode mode);
void
pinmux_wl_led_sw_ctrl_88xx(struct halmac_adapter *adapter, u8 on);
void
pinmux_sdio_int_polarity_88xx(struct halmac_adapter *adapter, u8 low_active);
enum halmac_ret_status
pinmux_gpio_mode_88xx(struct halmac_adapter *adapter, u8 gpio_id, u8 output);
enum halmac_ret_status
pinmux_gpio_output_88xx(struct halmac_adapter *adapter, u8 gpio_id, u8 high);
enum halmac_ret_status
pinmux_pin_status_88xx(struct halmac_adapter *adapter, u8 pin_id, u8 *high);
enum halmac_ret_status
pinmux_parser_88xx(struct halmac_adapter *adapter,
const struct halmac_gpio_pimux_list *list, u32 size,
u32 gpio_id, u32 *cur_func);
enum halmac_ret_status
pinmux_switch_88xx(struct halmac_adapter *adapter,
const struct halmac_gpio_pimux_list *list, u32 size,
u32 gpio_id, enum halmac_gpio_func gpio_func);
enum halmac_ret_status
pinmux_record_88xx(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func, u8 val);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_GPIO_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_init_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_init_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_fw_88xx.h"
#include "halmac_common_88xx.h"
#include "halmac_cfg_wmac_88xx.h"
#include "halmac_efuse_88xx.h"
#include "halmac_mimo_88xx.h"
#include "halmac_bb_rf_88xx.h"
#if HALMAC_SDIO_SUPPORT
#include "halmac_sdio_88xx.h"
#endif
#if HALMAC_USB_SUPPORT
#include "halmac_usb_88xx.h"
#endif
#if HALMAC_PCIE_SUPPORT
#include "halmac_pcie_88xx.h"
#endif
#include "halmac_gpio_88xx.h"
#include "halmac_flash_88xx.h"
#if HALMAC_8822B_SUPPORT
#include "halmac_8822b/halmac_init_8822b.h"
#endif
#if HALMAC_8821C_SUPPORT
#include "halmac_8821c/halmac_init_8821c.h"
#endif
#if HALMAC_8822C_SUPPORT
#include "halmac_8822c/halmac_init_8822c.h"
#endif
#if HALMAC_8812F_SUPPORT
#include "halmac_8812f/halmac_init_8812f.h"
#endif
#if HALMAC_PLATFORM_TESTPROGRAM
#include "halmisc_api_88xx.h"
#endif
#if HALMAC_88XX_SUPPORT
#define PLTFM_INFO_MALLOC_MAX_SIZE 16384
#define PLTFM_INFO_RSVD_PG_SIZE 16384
#define DLFW_PKT_MAX_SIZE 8192 /* need multiple of 2 */
static void
init_state_machine_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
verify_io_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
verify_send_rsvd_page_88xx(struct halmac_adapter *adapter);
void
init_adapter_param_88xx(struct halmac_adapter *adapter)
{
adapter->api_registry.rx_exp_en = 1;
adapter->api_registry.la_mode_en = 1;
adapter->api_registry.cfg_drv_rsvd_pg_en = 1;
adapter->api_registry.sdio_cmd53_4byte_en = 1;
adapter->efuse_map = (u8 *)NULL;
adapter->efuse_map_valid = 0;
adapter->efuse_end = 0;
adapter->dlfw_pkt_size = DLFW_PKT_MAX_SIZE;
adapter->pltfm_info.malloc_size = PLTFM_INFO_MALLOC_MAX_SIZE;
adapter->pltfm_info.rsvd_pg_size = PLTFM_INFO_RSVD_PG_SIZE;
adapter->cfg_param_info.buf = NULL;
adapter->cfg_param_info.buf_wptr = NULL;
adapter->cfg_param_info.num = 0;
adapter->cfg_param_info.full_fifo_mode = 0;
adapter->cfg_param_info.buf_size = 0;
adapter->cfg_param_info.avl_buf_size = 0;
adapter->cfg_param_info.offset_accum = 0;
adapter->cfg_param_info.value_accum = 0;
adapter->ch_sw_info.buf = NULL;
adapter->ch_sw_info.buf_wptr = NULL;
adapter->ch_sw_info.extra_info_en = 0;
adapter->ch_sw_info.buf_size = 0;
adapter->ch_sw_info.avl_buf_size = 0;
adapter->ch_sw_info.total_size = 0;
adapter->ch_sw_info.ch_num = 0;
adapter->drv_info_size = 0;
adapter->tx_desc_transfer = 0;
adapter->txff_alloc.tx_fifo_pg_num = 0;
adapter->txff_alloc.acq_pg_num = 0;
adapter->txff_alloc.rsvd_boundary = 0;
adapter->txff_alloc.rsvd_drv_addr = 0;
adapter->txff_alloc.rsvd_h2c_info_addr = 0;
adapter->txff_alloc.rsvd_h2cq_addr = 0;
adapter->txff_alloc.rsvd_cpu_instr_addr = 0;
adapter->txff_alloc.rsvd_fw_txbuf_addr = 0;
adapter->txff_alloc.pub_queue_pg_num = 0;
adapter->txff_alloc.high_queue_pg_num = 0;
adapter->txff_alloc.low_queue_pg_num = 0;
adapter->txff_alloc.normal_queue_pg_num = 0;
adapter->txff_alloc.extra_queue_pg_num = 0;
adapter->txff_alloc.la_mode = HALMAC_LA_MODE_DISABLE;
adapter->txff_alloc.rx_fifo_exp_mode =
HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE;
adapter->hw_cfg_info.chk_security_keyid = 0;
adapter->hw_cfg_info.acq_num = 8;
adapter->hw_cfg_info.page_size = TX_PAGE_SIZE_88XX;
adapter->hw_cfg_info.tx_align_size = TX_ALIGN_SIZE_88XX;
adapter->hw_cfg_info.txdesc_size = TX_DESC_SIZE_88XX;
adapter->hw_cfg_info.rxdesc_size = RX_DESC_SIZE_88XX;
adapter->hw_cfg_info.rx_desc_fifo_size = 0;
adapter->sdio_cmd53_4byte = HALMAC_SDIO_CMD53_4BYTE_MODE_DISABLE;
adapter->sdio_hw_info.io_hi_speed_flag = 0;
adapter->sdio_hw_info.io_indir_flag = 0;
adapter->sdio_hw_info.spec_ver = HALMAC_SDIO_SPEC_VER_2_00;
adapter->sdio_hw_info.clock_speed = 50;
adapter->sdio_hw_info.block_size = 512;
adapter->sdio_hw_info.tx_seq = 1;
adapter->sdio_fs.macid_map = (u8 *)NULL;
adapter->pinmux_info.wl_led = 0;
adapter->pinmux_info.sdio_int = 0;
adapter->pinmux_info.sw_io_0 = 0;
adapter->pinmux_info.sw_io_1 = 0;
adapter->pinmux_info.sw_io_2 = 0;
adapter->pinmux_info.sw_io_3 = 0;
adapter->pinmux_info.sw_io_4 = 0;
adapter->pinmux_info.sw_io_5 = 0;
adapter->pinmux_info.sw_io_6 = 0;
adapter->pinmux_info.sw_io_7 = 0;
adapter->pinmux_info.sw_io_8 = 0;
adapter->pinmux_info.sw_io_9 = 0;
adapter->pinmux_info.sw_io_10 = 0;
adapter->pinmux_info.sw_io_11 = 0;
adapter->pinmux_info.sw_io_12 = 0;
adapter->pinmux_info.sw_io_13 = 0;
adapter->pinmux_info.sw_io_14 = 0;
adapter->pinmux_info.sw_io_15 = 0;
adapter->pcie_refautok_en = 1;
adapter->pwr_off_flow_flag = 0;
adapter->rx_ignore_info.hdr_chk_mask = 1;
adapter->rx_ignore_info.fcs_chk_mask = 1;
adapter->rx_ignore_info.hdr_chk_en = 0;
adapter->rx_ignore_info.fcs_chk_en = 0;
adapter->rx_ignore_info.cck_rst_en = 0;
adapter->rx_ignore_info.fcs_chk_thr = HALMAC_PSF_FCS_CHK_THR_28;
init_adapter_dynamic_param_88xx(adapter);
init_state_machine_88xx(adapter);
}
void
init_adapter_dynamic_param_88xx(struct halmac_adapter *adapter)
{
adapter->h2c_info.seq_num = 0;
adapter->h2c_info.buf_fs = 0;
}
enum halmac_ret_status
mount_api_88xx(struct halmac_adapter *adapter)
{
struct halmac_api *api = NULL;
adapter->halmac_api =
(struct halmac_api *)PLTFM_MALLOC(sizeof(struct halmac_api));
if (!adapter->halmac_api)
return HALMAC_RET_MALLOC_FAIL;
api = (struct halmac_api *)adapter->halmac_api;
api->halmac_read_efuse = NULL;
api->halmac_write_efuse = NULL;
/* Mount function pointer */
api->halmac_register_api = register_api_88xx;
api->halmac_download_firmware = download_firmware_88xx;
api->halmac_free_download_firmware = free_download_firmware_88xx;
api->halmac_reset_wifi_fw = reset_wifi_fw_88xx;
api->halmac_get_fw_version = get_fw_version_88xx;
api->halmac_cfg_mac_addr = cfg_mac_addr_88xx;
api->halmac_cfg_bssid = cfg_bssid_88xx;
api->halmac_cfg_transmitter_addr = cfg_transmitter_addr_88xx;
api->halmac_cfg_net_type = cfg_net_type_88xx;
api->halmac_cfg_tsf_rst = cfg_tsf_rst_88xx;
api->halmac_cfg_bcn_space = cfg_bcn_space_88xx;
api->halmac_rw_bcn_ctrl = rw_bcn_ctrl_88xx;
api->halmac_cfg_multicast_addr = cfg_multicast_addr_88xx;
api->halmac_cfg_operation_mode = cfg_operation_mode_88xx;
api->halmac_cfg_ch_bw = cfg_ch_bw_88xx;
api->halmac_cfg_bw = cfg_bw_88xx;
api->halmac_init_mac_cfg = init_mac_cfg_88xx;
api->halmac_dump_efuse_map = dump_efuse_map_88xx;
api->halmac_dump_efuse_map_bt = dump_efuse_map_bt_88xx;
api->halmac_write_efuse_bt = write_efuse_bt_88xx;
api->halmac_read_efuse_bt = read_efuse_bt_88xx;
api->halmac_cfg_efuse_auto_check = cfg_efuse_auto_check_88xx;
api->halmac_dump_logical_efuse_map = dump_log_efuse_map_88xx;
api->halmac_pg_efuse_by_map = pg_efuse_by_map_88xx;
api->halmac_mask_logical_efuse = mask_log_efuse_88xx;
api->halmac_get_efuse_size = get_efuse_size_88xx;
api->halmac_get_efuse_available_size = get_efuse_available_size_88xx;
api->halmac_get_c2h_info = get_c2h_info_88xx;
api->halmac_get_logical_efuse_size = get_log_efuse_size_88xx;
api->halmac_write_logical_efuse = write_log_efuse_88xx;
api->halmac_read_logical_efuse = read_logical_efuse_88xx;
api->halmac_ofld_func_cfg = ofld_func_cfg_88xx;
api->halmac_h2c_lb = h2c_lb_88xx;
api->halmac_debug = mac_debug_88xx;
api->halmac_cfg_parameter = cfg_parameter_88xx;
api->halmac_update_datapack = update_datapack_88xx;
api->halmac_run_datapack = run_datapack_88xx;
api->halmac_send_bt_coex = send_bt_coex_88xx;
api->halmac_verify_platform_api = verify_platform_api_88xx;
api->halmac_update_packet = update_packet_88xx;
api->halmac_bcn_ie_filter = bcn_ie_filter_88xx;
api->halmac_cfg_txbf = cfg_txbf_88xx;
api->halmac_cfg_mumimo = cfg_mumimo_88xx;
api->halmac_cfg_sounding = cfg_sounding_88xx;
api->halmac_del_sounding = del_sounding_88xx;
api->halmac_su_bfer_entry_init = su_bfer_entry_init_88xx;
api->halmac_su_bfee_entry_init = su_bfee_entry_init_88xx;
api->halmac_mu_bfer_entry_init = mu_bfer_entry_init_88xx;
api->halmac_mu_bfee_entry_init = mu_bfee_entry_init_88xx;
api->halmac_su_bfer_entry_del = su_bfer_entry_del_88xx;
api->halmac_su_bfee_entry_del = su_bfee_entry_del_88xx;
api->halmac_mu_bfer_entry_del = mu_bfer_entry_del_88xx;
api->halmac_mu_bfee_entry_del = mu_bfee_entry_del_88xx;
api->halmac_add_ch_info = add_ch_info_88xx;
api->halmac_add_extra_ch_info = add_extra_ch_info_88xx;
api->halmac_ctrl_ch_switch = ctrl_ch_switch_88xx;
api->halmac_p2pps = p2pps_88xx;
api->halmac_clear_ch_info = clear_ch_info_88xx;
api->halmac_send_general_info = send_general_info_88xx;
api->halmac_start_iqk = start_iqk_88xx;
api->halmac_ctrl_pwr_tracking = ctrl_pwr_tracking_88xx;
api->halmac_psd = psd_88xx;
api->halmac_cfg_la_mode = cfg_la_mode_88xx;
api->halmac_cfg_rxff_expand_mode = cfg_rxfifo_expand_mode_88xx;
api->halmac_config_security = config_security_88xx;
api->halmac_get_used_cam_entry_num = get_used_cam_entry_num_88xx;
api->halmac_read_cam_entry = read_cam_entry_88xx;
api->halmac_write_cam = write_cam_88xx;
api->halmac_clear_cam_entry = clear_cam_entry_88xx;
api->halmac_cfg_drv_rsvd_pg_num = cfg_drv_rsvd_pg_num_88xx;
api->halmac_get_chip_version = get_version_88xx;
api->halmac_query_status = query_status_88xx;
api->halmac_reset_feature = reset_ofld_feature_88xx;
api->halmac_check_fw_status = check_fw_status_88xx;
api->halmac_dump_fw_dmem = dump_fw_dmem_88xx;
api->halmac_cfg_max_dl_size = cfg_max_dl_size_88xx;
api->halmac_dump_fifo = dump_fifo_88xx;
api->halmac_get_fifo_size = get_fifo_size_88xx;
api->halmac_chk_txdesc = chk_txdesc_88xx;
api->halmac_dl_drv_rsvd_page = dl_drv_rsvd_page_88xx;
api->halmac_cfg_csi_rate = cfg_csi_rate_88xx;
api->halmac_txfifo_is_empty = txfifo_is_empty_88xx;
api->halmac_download_flash = download_flash_88xx;
api->halmac_read_flash = read_flash_88xx;
api->halmac_erase_flash = erase_flash_88xx;
api->halmac_check_flash = check_flash_88xx;
api->halmac_cfg_edca_para = cfg_edca_para_88xx;
api->halmac_pinmux_wl_led_mode = pinmux_wl_led_mode_88xx;
api->halmac_pinmux_wl_led_sw_ctrl = pinmux_wl_led_sw_ctrl_88xx;
api->halmac_pinmux_sdio_int_polarity = pinmux_sdio_int_polarity_88xx;
api->halmac_pinmux_gpio_mode = pinmux_gpio_mode_88xx;
api->halmac_pinmux_gpio_output = pinmux_gpio_output_88xx;
api->halmac_pinmux_pin_status = pinmux_pin_status_88xx;
api->halmac_rx_cut_amsdu_cfg = rx_cut_amsdu_cfg_88xx;
api->halmac_fw_snding = fw_snding_88xx;
api->halmac_get_mac_addr = get_mac_addr_88xx;
api->halmac_enter_cpu_sleep_mode = enter_cpu_sleep_mode_88xx;
api->halmac_get_cpu_mode = get_cpu_mode_88xx;
api->halmac_drv_fwctrl = drv_fwctrl_88xx;
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
#if HALMAC_SDIO_SUPPORT
api->halmac_init_sdio_cfg = init_sdio_cfg_88xx;
api->halmac_deinit_sdio_cfg = deinit_sdio_cfg_88xx;
api->halmac_cfg_rx_aggregation = cfg_sdio_rx_agg_88xx;
api->halmac_init_interface_cfg = init_sdio_cfg_88xx;
api->halmac_deinit_interface_cfg = deinit_sdio_cfg_88xx;
api->halmac_cfg_tx_agg_align = cfg_txagg_sdio_align_88xx;
api->halmac_set_bulkout_num = set_sdio_bulkout_num_88xx;
api->halmac_get_usb_bulkout_id = get_sdio_bulkout_id_88xx;
api->halmac_reg_read_indirect_32 = sdio_indirect_reg_r32_88xx;
api->halmac_reg_sdio_cmd53_read_n = sdio_reg_rn_88xx;
api->halmac_sdio_cmd53_4byte = sdio_cmd53_4byte_88xx;
api->halmac_sdio_hw_info = sdio_hw_info_88xx;
#endif
} else if (adapter->intf == HALMAC_INTERFACE_USB) {
#if HALMAC_USB_SUPPORT
api->halmac_init_usb_cfg = init_usb_cfg_88xx;
api->halmac_deinit_usb_cfg = deinit_usb_cfg_88xx;
api->halmac_cfg_rx_aggregation = cfg_usb_rx_agg_88xx;
api->halmac_init_interface_cfg = init_usb_cfg_88xx;
api->halmac_deinit_interface_cfg = deinit_usb_cfg_88xx;
api->halmac_cfg_tx_agg_align = cfg_txagg_usb_align_88xx;
api->halmac_tx_allowed_sdio = tx_allowed_usb_88xx;
api->halmac_set_bulkout_num = set_usb_bulkout_num_88xx;
api->halmac_get_sdio_tx_addr = get_usb_tx_addr_88xx;
api->halmac_get_usb_bulkout_id = get_usb_bulkout_id_88xx;
api->halmac_reg_read_8 = reg_r8_usb_88xx;
api->halmac_reg_write_8 = reg_w8_usb_88xx;
api->halmac_reg_read_16 = reg_r16_usb_88xx;
api->halmac_reg_write_16 = reg_w16_usb_88xx;
api->halmac_reg_read_32 = reg_r32_usb_88xx;
api->halmac_reg_write_32 = reg_w32_usb_88xx;
api->halmac_reg_read_indirect_32 = usb_indirect_reg_r32_88xx;
api->halmac_reg_sdio_cmd53_read_n = usb_reg_rn_88xx;
#endif
} else if (adapter->intf == HALMAC_INTERFACE_PCIE) {
#if HALMAC_PCIE_SUPPORT
api->halmac_init_pcie_cfg = init_pcie_cfg_88xx;
api->halmac_deinit_pcie_cfg = deinit_pcie_cfg_88xx;
api->halmac_cfg_rx_aggregation = cfg_pcie_rx_agg_88xx;
api->halmac_init_interface_cfg = init_pcie_cfg_88xx;
api->halmac_deinit_interface_cfg = deinit_pcie_cfg_88xx;
api->halmac_cfg_tx_agg_align = cfg_txagg_pcie_align_88xx;
api->halmac_tx_allowed_sdio = tx_allowed_pcie_88xx;
api->halmac_set_bulkout_num = set_pcie_bulkout_num_88xx;
api->halmac_get_sdio_tx_addr = get_pcie_tx_addr_88xx;
api->halmac_get_usb_bulkout_id = get_pcie_bulkout_id_88xx;
api->halmac_reg_read_8 = reg_r8_pcie_88xx;
api->halmac_reg_write_8 = reg_w8_pcie_88xx;
api->halmac_reg_read_16 = reg_r16_pcie_88xx;
api->halmac_reg_write_16 = reg_w16_pcie_88xx;
api->halmac_reg_read_32 = reg_r32_pcie_88xx;
api->halmac_reg_write_32 = reg_w32_pcie_88xx;
api->halmac_reg_read_indirect_32 = pcie_indirect_reg_r32_88xx;
api->halmac_reg_sdio_cmd53_read_n = pcie_reg_rn_88xx;
api->halmac_en_ref_autok_pcie = en_ref_autok_88xx;
#endif
} else {
PLTFM_MSG_ERR("[ERR]Set halmac io function Error!!\n");
}
if (adapter->chip_id == HALMAC_CHIP_ID_8822B) {
#if HALMAC_8822B_SUPPORT
mount_api_8822b(adapter);
#endif
} else if (adapter->chip_id == HALMAC_CHIP_ID_8821C) {
#if HALMAC_8821C_SUPPORT
mount_api_8821c(adapter);
#endif
} else if (adapter->chip_id == HALMAC_CHIP_ID_8822C) {
#if HALMAC_8822C_SUPPORT
mount_api_8822c(adapter);
#endif
} else if (adapter->chip_id == HALMAC_CHIP_ID_8812F) {
#if HALMAC_8812F_SUPPORT
mount_api_8812f(adapter);
#endif
} else {
PLTFM_MSG_ERR("[ERR]Chip ID undefine!!\n");
return HALMAC_RET_CHIP_NOT_SUPPORT;
}
#if HALMAC_PLATFORM_TESTPROGRAM
halmac_mount_misc_api_88xx(adapter);
#endif
return HALMAC_RET_SUCCESS;
}
static void
init_state_machine_88xx(struct halmac_adapter *adapter)
{
struct halmac_state *state = &adapter->halmac_state;
init_ofld_feature_state_machine_88xx(adapter);
state->api_state = HALMAC_API_STATE_INIT;
state->dlfw_state = HALMAC_DLFW_NONE;
state->mac_pwr = HALMAC_MAC_POWER_OFF;
state->gpio_cfg_state = HALMAC_GPIO_CFG_STATE_IDLE;
state->rsvd_pg_state = HALMAC_RSVD_PG_STATE_IDLE;
}
void
init_ofld_feature_state_machine_88xx(struct halmac_adapter *adapter)
{
struct halmac_state *state = &adapter->halmac_state;
state->efuse_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->efuse_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->efuse_state.seq_num = adapter->h2c_info.seq_num;
state->cfg_param_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->cfg_param_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->cfg_param_state.seq_num = adapter->h2c_info.seq_num;
state->scan_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->scan_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->scan_state.seq_num = adapter->h2c_info.seq_num;
state->update_pkt_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->update_pkt_state.seq_num = adapter->h2c_info.seq_num;
state->iqk_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->iqk_state.seq_num = adapter->h2c_info.seq_num;
state->pwr_trk_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->pwr_trk_state.seq_num = adapter->h2c_info.seq_num;
state->psd_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->psd_state.seq_num = adapter->h2c_info.seq_num;
state->psd_state.data_size = 0;
state->psd_state.seg_size = 0;
state->psd_state.data = NULL;
state->fw_snding_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->fw_snding_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->fw_snding_state.seq_num = adapter->h2c_info.seq_num;
state->wlcpu_mode = HALMAC_WLCPU_ACTIVE;
}
/**
* register_api_88xx() - register feature list
* @adapter
* @registry : feature list, 1->enable 0->disable
* Author : Ivan Lin
*
* Default is enable all api registry
*
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
register_api_88xx(struct halmac_adapter *adapter,
struct halmac_api_registry *registry)
{
if (!registry)
return HALMAC_RET_NULL_POINTER;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MEMCPY(&adapter->api_registry, registry, sizeof(*registry));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* init_mac_cfg_88xx() - config page1~page7 register
* @adapter : the adapter of halmac
* @mode : trx mode
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_mac_cfg_88xx(struct halmac_adapter *adapter, enum halmac_trx_mode mode)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
status = api->halmac_init_trx_cfg(adapter, mode);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]init trx %x\n", status);
return status;
}
status = api->halmac_init_protocol_cfg(adapter);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]init ptcl %x\n", status);
return status;
}
status = api->halmac_init_edca_cfg(adapter);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]init edca %x\n", status);
return status;
}
status = api->halmac_init_wmac_cfg(adapter);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]init wmac %x\n", status);
return status;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
/**
* reset_ofld_feature_88xx() -reset async api cmd status
* @adapter : the adapter of halmac
* @feature_id : feature_id
* Author : Ivan Lin/KaiYuan Chang
* Return : enum halmac_ret_status.
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
reset_ofld_feature_88xx(struct halmac_adapter *adapter,
enum halmac_feature_id feature_id)
{
struct halmac_state *state = &adapter->halmac_state;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
switch (feature_id) {
case HALMAC_FEATURE_CFG_PARA:
state->cfg_param_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->cfg_param_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
break;
case HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE:
case HALMAC_FEATURE_DUMP_LOGICAL_EFUSE:
state->efuse_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->efuse_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
break;
case HALMAC_FEATURE_CHANNEL_SWITCH:
state->scan_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->scan_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
break;
case HALMAC_FEATURE_UPDATE_PACKET:
state->update_pkt_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
break;
case HALMAC_FEATURE_IQK:
state->iqk_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
break;
case HALMAC_FEATURE_POWER_TRACKING:
state->pwr_trk_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
break;
case HALMAC_FEATURE_PSD:
state->psd_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
break;
case HALMAC_FEATURE_FW_SNDING:
state->fw_snding_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->fw_snding_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
break;
case HALMAC_FEATURE_ALL:
state->cfg_param_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->cfg_param_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->efuse_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->efuse_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->scan_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->scan_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
state->update_pkt_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->iqk_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->pwr_trk_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->psd_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->fw_snding_state.proc_status = HALMAC_CMD_PROCESS_IDLE;
state->fw_snding_state.cmd_cnstr_state = HALMAC_CMD_CNSTR_IDLE;
break;
default:
PLTFM_MSG_ERR("[ERR]invalid feature id\n");
return HALMAC_RET_INVALID_FEATURE_ID;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* (debug API)verify_platform_api_88xx() - verify platform api
* @adapter : the adapter of halmac
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
verify_platform_api_88xx(struct halmac_adapter *adapter)
{
enum halmac_ret_status ret_status = HALMAC_RET_SUCCESS;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
ret_status = verify_io_88xx(adapter);
if (ret_status != HALMAC_RET_SUCCESS)
return ret_status;
if (adapter->txff_alloc.la_mode != HALMAC_LA_MODE_FULL)
ret_status = verify_send_rsvd_page_88xx(adapter);
if (ret_status != HALMAC_RET_SUCCESS)
return ret_status;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return ret_status;
}
void
tx_desc_chksum_88xx(struct halmac_adapter *adapter, u8 enable)
{
u16 value16;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
adapter->tx_desc_checksum = enable;
value16 = HALMAC_REG_R16(REG_TXDMA_OFFSET_CHK);
if (enable == 1)
HALMAC_REG_W16(REG_TXDMA_OFFSET_CHK, value16 | BIT(13));
else
HALMAC_REG_W16(REG_TXDMA_OFFSET_CHK, value16 & ~BIT(13));
}
static enum halmac_ret_status
verify_io_88xx(struct halmac_adapter *adapter)
{
u8 value8;
u8 wvalue8;
u32 value32;
u32 value32_2;
u32 wvalue32;
u32 offset;
enum halmac_ret_status ret_status = HALMAC_RET_SUCCESS;
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
offset = REG_PAGE5_DUMMY;
if (0 == (offset & 0xFFFF0000))
offset |= WLAN_IOREG_OFFSET;
#if HALMAC_SDIO_SUPPORT
ret_status = cnv_to_sdio_bus_offset_88xx(adapter, &offset);
#else
return HALMAC_RET_WRONG_INTF;
#endif
/* Verify CMD52 R/W */
wvalue8 = 0xab;
PLTFM_SDIO_CMD52_W(offset, wvalue8);
value8 = PLTFM_SDIO_CMD52_R(offset);
if (value8 != wvalue8) {
PLTFM_MSG_ERR("[ERR]cmd52 r/w\n");
ret_status = HALMAC_RET_PLATFORM_API_INCORRECT;
}
/* Verify CMD53 R/W */
PLTFM_SDIO_CMD52_W(offset, 0xaa);
PLTFM_SDIO_CMD52_W(offset + 1, 0xbb);
PLTFM_SDIO_CMD52_W(offset + 2, 0xcc);
PLTFM_SDIO_CMD52_W(offset + 3, 0xdd);
value32 = PLTFM_SDIO_CMD53_R32(offset);
if (value32 != 0xddccbbaa) {
PLTFM_MSG_ERR("[ERR]cmd53 r\n");
ret_status = HALMAC_RET_PLATFORM_API_INCORRECT;
}
wvalue32 = 0x11223344;
PLTFM_SDIO_CMD53_W32(offset, wvalue32);
value32 = PLTFM_SDIO_CMD53_R32(offset);
if (value32 != wvalue32) {
PLTFM_MSG_ERR("[ERR]cmd53 w\n");
ret_status = HALMAC_RET_PLATFORM_API_INCORRECT;
}
/* value32 should be 0x33441122 */
value32 = PLTFM_SDIO_CMD53_R32(offset + 2);
wvalue32 = 0x11225566;
PLTFM_SDIO_CMD53_W32(offset, wvalue32);
/* value32 should be 0x55661122 */
value32_2 = PLTFM_SDIO_CMD53_R32(offset + 2);
if (value32_2 == value32) {
PLTFM_MSG_ERR("[ERR]cmd52 is used\n");
ret_status = HALMAC_RET_PLATFORM_API_INCORRECT;
}
} else {
wvalue32 = 0x77665511;
PLTFM_REG_W32(REG_PAGE5_DUMMY, wvalue32);
value32 = PLTFM_REG_R32(REG_PAGE5_DUMMY);
if (value32 != wvalue32) {
PLTFM_MSG_ERR("[ERR]reg rw\n");
ret_status = HALMAC_RET_PLATFORM_API_INCORRECT;
}
}
return ret_status;
}
static enum halmac_ret_status
verify_send_rsvd_page_88xx(struct halmac_adapter *adapter)
{
u8 txdesc_size = adapter->hw_cfg_info.txdesc_size;
u8 *rsvd_buf = NULL;
u8 *rsvd_page = NULL;
u32 i;
u32 pkt_size = 64;
u32 payload = 0xab;
enum halmac_ret_status ret_status = HALMAC_RET_SUCCESS;
rsvd_buf = (u8 *)PLTFM_MALLOC(pkt_size);
if (!rsvd_buf) {
PLTFM_MSG_ERR("[ERR]rsvd buf malloc!!\n");
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(rsvd_buf, (u8)payload, pkt_size);
ret_status = dl_rsvd_page_88xx(adapter,
adapter->txff_alloc.rsvd_boundary,
rsvd_buf, pkt_size);
if (ret_status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(rsvd_buf, pkt_size);
return ret_status;
}
rsvd_page = (u8 *)PLTFM_MALLOC(pkt_size + txdesc_size);
if (!rsvd_page) {
PLTFM_MSG_ERR("[ERR]rsvd page malloc!!\n");
PLTFM_FREE(rsvd_buf, pkt_size);
return HALMAC_RET_MALLOC_FAIL;
}
PLTFM_MEMSET(rsvd_page, 0x00, pkt_size + txdesc_size);
ret_status = dump_fifo_88xx(adapter, HAL_FIFO_SEL_RSVD_PAGE, 0,
pkt_size + txdesc_size, rsvd_page);
if (ret_status != HALMAC_RET_SUCCESS) {
PLTFM_FREE(rsvd_buf, pkt_size);
PLTFM_FREE(rsvd_page, pkt_size + txdesc_size);
return ret_status;
}
for (i = 0; i < pkt_size; i++) {
if (*(rsvd_buf + i) != *(rsvd_page + (i + txdesc_size))) {
PLTFM_MSG_ERR("[ERR]Compare RSVD page Fail\n");
ret_status = HALMAC_RET_PLATFORM_API_INCORRECT;
}
}
PLTFM_FREE(rsvd_buf, pkt_size);
PLTFM_FREE(rsvd_page, pkt_size + txdesc_size);
return ret_status;
}
enum halmac_ret_status
pg_num_parser_88xx(struct halmac_adapter *adapter, enum halmac_trx_mode mode,
struct halmac_pg_num *tbl)
{
u8 flag;
u16 hpq_num = 0;
u16 lpq_num = 0;
u16 npq_num = 0;
u16 gapq_num = 0;
u16 expq_num = 0;
u16 pubq_num = 0;
u32 i = 0;
flag = 0;
for (i = 0; i < HALMAC_TRX_MODE_MAX; i++) {
if (mode == tbl[i].mode) {
hpq_num = tbl[i].hq_num;
lpq_num = tbl[i].lq_num;
npq_num = tbl[i].nq_num;
expq_num = tbl[i].exq_num;
gapq_num = tbl[i].gap_num;
pubq_num = adapter->txff_alloc.acq_pg_num - hpq_num -
lpq_num - npq_num - expq_num - gapq_num;
flag = 1;
PLTFM_MSG_TRACE("[TRACE]%s done\n", __func__);
break;
}
}
if (flag == 0) {
PLTFM_MSG_ERR("[ERR]trx mode!!\n");
return HALMAC_RET_TRX_MODE_NOT_SUPPORT;
}
if (adapter->txff_alloc.acq_pg_num <
hpq_num + lpq_num + npq_num + expq_num + gapq_num) {
PLTFM_MSG_ERR("[ERR]acqnum = %d\n",
adapter->txff_alloc.acq_pg_num);
PLTFM_MSG_ERR("[ERR]hpq_num = %d\n", hpq_num);
PLTFM_MSG_ERR("[ERR]LPQ_num = %d\n", lpq_num);
PLTFM_MSG_ERR("[ERR]npq_num = %d\n", npq_num);
PLTFM_MSG_ERR("[ERR]EPQ_num = %d\n", expq_num);
PLTFM_MSG_ERR("[ERR]gapq_num = %d\n", gapq_num);
return HALMAC_RET_CFG_TXFIFO_PAGE_FAIL;
}
adapter->txff_alloc.high_queue_pg_num = hpq_num;
adapter->txff_alloc.low_queue_pg_num = lpq_num;
adapter->txff_alloc.normal_queue_pg_num = npq_num;
adapter->txff_alloc.extra_queue_pg_num = expq_num;
adapter->txff_alloc.pub_queue_pg_num = pubq_num;
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
rqpn_parser_88xx(struct halmac_adapter *adapter, enum halmac_trx_mode mode,
struct halmac_rqpn *tbl)
{
u8 flag;
u32 i;
flag = 0;
for (i = 0; i < HALMAC_TRX_MODE_MAX; i++) {
if (mode == tbl[i].mode) {
adapter->pq_map[HALMAC_PQ_MAP_VO] = tbl[i].dma_map_vo;
adapter->pq_map[HALMAC_PQ_MAP_VI] = tbl[i].dma_map_vi;
adapter->pq_map[HALMAC_PQ_MAP_BE] = tbl[i].dma_map_be;
adapter->pq_map[HALMAC_PQ_MAP_BK] = tbl[i].dma_map_bk;
adapter->pq_map[HALMAC_PQ_MAP_MG] = tbl[i].dma_map_mg;
adapter->pq_map[HALMAC_PQ_MAP_HI] = tbl[i].dma_map_hi;
flag = 1;
PLTFM_MSG_TRACE("[TRACE]%s done\n", __func__);
break;
}
}
if (flag == 0) {
PLTFM_MSG_ERR("[ERR]trx mdoe!!\n");
return HALMAC_RET_TRX_MODE_NOT_SUPPORT;
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
fwff_is_empty_88xx(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u32 cnt;
cnt = 5000;
while (HALMAC_REG_R16(REG_FWFF_CTRL) !=
HALMAC_REG_R16(REG_FWFF_PKT_INFO)) {
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]polling fwff empty fail\n");
return HALMAC_RET_FWFF_NO_EMPTY;
}
cnt--;
PLTFM_DELAY_US(50);
}
return HALMAC_RET_SUCCESS;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_init_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_INIT_88XX_H_
#define _HALMAC_INIT_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
register_api_88xx(struct halmac_adapter *adapter,
struct halmac_api_registry *registry);
void
init_adapter_param_88xx(struct halmac_adapter *adapter);
void
init_adapter_dynamic_param_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
mount_api_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
init_mac_cfg_88xx(struct halmac_adapter *adapter, enum halmac_trx_mode mode);
enum halmac_ret_status
reset_ofld_feature_88xx(struct halmac_adapter *adapter,
enum halmac_feature_id feature_id);
enum halmac_ret_status
verify_platform_api_88xx(struct halmac_adapter *adapter);
void
tx_desc_chksum_88xx(struct halmac_adapter *adapter, u8 enable);
enum halmac_ret_status
pg_num_parser_88xx(struct halmac_adapter *adapter, enum halmac_trx_mode mode,
struct halmac_pg_num *tbl);
enum halmac_ret_status
rqpn_parser_88xx(struct halmac_adapter *adapter, enum halmac_trx_mode mode,
struct halmac_rqpn *tbl);
void
init_ofld_feature_state_machine_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
fwff_is_empty_88xx(struct halmac_adapter *adapter);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_INIT_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_mimo_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_mimo_88xx.h"
#include "halmac_88xx_cfg.h"
#include "halmac_common_88xx.h"
#include "halmac_init_88xx.h"
#if HALMAC_88XX_SUPPORT
#define TXBF_CTRL_CFG (BIT_R_ENABLE_NDPA | BIT_USE_NDPA_PARAMETER | \
BIT_R_EN_NDPA_INT | BIT_DIS_NDP_BFEN)
#define CSI_RATE_MAP 0x55
static void
cfg_mu_bfee_88xx(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param);
static void
cfg_mu_bfer_88xx(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param);
static enum halmac_cmd_construct_state
fw_snding_cmd_cnstr_state_88xx(struct halmac_adapter *adapter);
static enum halmac_ret_status
cnv_fw_snding_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state);
static u8
snding_pkt_chk_88xx(struct halmac_adapter *adapter, u8 *pkt);
/**
* cfg_txbf_88xx() - enable/disable specific user's txbf
* @adapter : the adapter of halmac
* @userid : su bfee userid = 0 or 1 to apply TXBF
* @bw : the sounding bandwidth
* @txbf_en : 0: disable TXBF, 1: enable TXBF
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_txbf_88xx(struct halmac_adapter *adapter, u8 userid, enum halmac_bw bw,
u8 txbf_en)
{
u16 tmp42c = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (txbf_en) {
switch (bw) {
case HALMAC_BW_80:
tmp42c |= BIT_R_TXBF0_80M;
case HALMAC_BW_40:
tmp42c |= BIT_R_TXBF0_40M;
case HALMAC_BW_20:
tmp42c |= BIT_R_TXBF0_20M;
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
}
switch (userid) {
case 0:
tmp42c |= HALMAC_REG_R16(REG_TXBF_CTRL) &
~(BIT_R_TXBF0_20M | BIT_R_TXBF0_40M | BIT_R_TXBF0_80M);
HALMAC_REG_W16(REG_TXBF_CTRL, tmp42c);
break;
case 1:
tmp42c |= HALMAC_REG_R16(REG_TXBF_CTRL + 2) &
~(BIT_R_TXBF0_20M | BIT_R_TXBF0_40M | BIT_R_TXBF0_80M);
HALMAC_REG_W16(REG_TXBF_CTRL + 2, tmp42c);
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_mumimo_88xx() -config mumimo
* @adapter : the adapter of halmac
* @param : parameters to configure MU PPDU Tx/Rx
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_mumimo_88xx(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param)
{
if (param->role == HAL_BFEE)
cfg_mu_bfee_88xx(adapter, param);
else
cfg_mu_bfer_88xx(adapter, param);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
static void
cfg_mu_bfee_88xx(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param)
{
u8 mu_tbl_sel;
u8 tmp14c0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
tmp14c0 = HALMAC_REG_R8(REG_MU_TX_CTL) & ~BIT_MASK_R_MU_TABLE_VALID;
HALMAC_REG_W8(REG_MU_TX_CTL, (tmp14c0 | BIT(0) | BIT(1)) & ~(BIT(7)));
/*config GID valid table and user position table*/
mu_tbl_sel = HALMAC_REG_R8(REG_MU_TX_CTL + 1) & 0xF8;
HALMAC_REG_W8(REG_MU_TX_CTL + 1, mu_tbl_sel);
HALMAC_REG_W32(REG_MU_STA_GID_VLD, param->given_gid_tab[0]);
HALMAC_REG_W32(REG_MU_STA_USER_POS_INFO, param->given_user_pos[0]);
HALMAC_REG_W32(REG_MU_STA_USER_POS_INFO + 4, param->given_user_pos[1]);
HALMAC_REG_W8(REG_MU_TX_CTL + 1, mu_tbl_sel | 1);
HALMAC_REG_W32(REG_MU_STA_GID_VLD, param->given_gid_tab[1]);
HALMAC_REG_W32(REG_MU_STA_USER_POS_INFO, param->given_user_pos[2]);
HALMAC_REG_W32(REG_MU_STA_USER_POS_INFO + 4, param->given_user_pos[3]);
}
static void
cfg_mu_bfer_88xx(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param)
{
u8 i;
u8 idx;
u8 id0;
u8 id1;
u8 gid;
u8 mu_tbl_sel;
u8 mu_tbl_valid = 0;
u32 gid_valid[6] = {0};
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (param->mu_tx_en == 0) {
HALMAC_REG_W8(REG_MU_TX_CTL,
HALMAC_REG_R8(REG_MU_TX_CTL) & ~(BIT(7)));
return;
}
for (idx = 0; idx < 15; idx++) {
if (idx < 5) {
/*grouping_bitmap bit0~4, MU_STA0 with MUSTA1~5*/
id0 = 0;
id1 = (u8)(idx + 1);
} else if (idx < 9) {
/*grouping_bitmap bit5~8, MU_STA1 with MUSTA2~5*/
id0 = 1;
id1 = (u8)(idx - 3);
} else if (idx < 12) {
/*grouping_bitmap bit9~11, MU_STA2 with MUSTA3~5*/
id0 = 2;
id1 = (u8)(idx - 6);
} else if (idx < 14) {
/*grouping_bitmap bit12~13, MU_STA3 with MUSTA4~5*/
id0 = 3;
id1 = (u8)(idx - 8);
} else {
/*grouping_bitmap bit14, MU_STA4 with MUSTA5*/
id0 = 4;
id1 = (u8)(idx - 9);
}
if (param->grouping_bitmap & BIT(idx)) {
/*Pair 1*/
gid = (idx << 1) + 1;
gid_valid[id0] |= (BIT(gid));
gid_valid[id1] |= (BIT(gid));
/*Pair 2*/
gid += 1;
gid_valid[id0] |= (BIT(gid));
gid_valid[id1] |= (BIT(gid));
} else {
/*Pair 1*/
gid = (idx << 1) + 1;
gid_valid[id0] &= ~(BIT(gid));
gid_valid[id1] &= ~(BIT(gid));
/*Pair 2*/
gid += 1;
gid_valid[id0] &= ~(BIT(gid));
gid_valid[id1] &= ~(BIT(gid));
}
}
/*set MU STA GID valid TABLE*/
mu_tbl_sel = HALMAC_REG_R8(REG_MU_TX_CTL + 1) & 0xF8;
for (idx = 0; idx < 6; idx++) {
HALMAC_REG_W8(REG_MU_TX_CTL + 1, idx | mu_tbl_sel);
HALMAC_REG_W32(REG_MU_STA_GID_VLD, gid_valid[idx]);
}
/*To validate the sounding successful MU STA and enable MU TX*/
for (i = 0; i < 6; i++) {
if (param->sounding_sts[i] == 1)
mu_tbl_valid |= BIT(i);
}
HALMAC_REG_W8(REG_MU_TX_CTL, mu_tbl_valid | BIT(7));
}
/**
* cfg_sounding_88xx() - configure general sounding
* @adapter : the adapter of halmac
* @role : driver's role, BFer or BFee
* @rate : set ndpa tx rate if driver is BFer,
* or set csi response rate if driver is BFee
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_sounding_88xx(struct halmac_adapter *adapter, enum halmac_snd_role role,
enum halmac_data_rate rate)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u32 tmp6dc = 0;
u8 csi_rsc = 0x0;
/*use ndpa rx rate to decide csi rate*/
tmp6dc = HALMAC_REG_R32(REG_BBPSF_CTRL) | BIT_WMAC_USE_NDPARATE
| (csi_rsc << 13);
switch (role) {
case HAL_BFER:
HALMAC_REG_W32_SET(REG_TXBF_CTRL, TXBF_CTRL_CFG);
HALMAC_REG_W8(REG_NDPA_RATE, rate);
HALMAC_REG_W8(REG_SND_PTCL_CTRL + 1, 0x2 | BIT(7));
HALMAC_REG_W8(REG_SND_PTCL_CTRL + 2, 0x2);
break;
case HAL_BFEE:
HALMAC_REG_W8(REG_SND_PTCL_CTRL, 0xDB);
HALMAC_REG_W8(REG_SND_PTCL_CTRL + 3, 0x26);
HALMAC_REG_W8_CLR(REG_RXFLTMAP1, BIT(4));
HALMAC_REG_W8_CLR(REG_RXFLTMAP4, BIT(4));
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
if (adapter->chip_id == HALMAC_CHIP_ID_8822C)
HALMAC_REG_W32(REG_CSI_RRSR,
BIT_CSI_RRSC_BITMAP(CSI_RATE_MAP) |
BIT_OFDM_LEN_TH(0));
else if (adapter->chip_id == HALMAC_CHIP_ID_8812F)
HALMAC_REG_W32(REG_CSI_RRSR,
BIT_CSI_RRSC_BITMAP(CSI_RATE_MAP) |
BIT_OFDM_LEN_TH(3));
#endif
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
/*AP mode set tx gid to 63*/
/*STA mode set tx gid to 0*/
if (BIT_GET_NETYPE0(HALMAC_REG_R32(REG_CR)) == 0x3)
HALMAC_REG_W32(REG_BBPSF_CTRL, tmp6dc | BIT(12));
else
HALMAC_REG_W32(REG_BBPSF_CTRL, tmp6dc & ~(BIT(12)));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* del_sounding_88xx() - reset general sounding
* @adapter : the adapter of halmac
* @role : driver's role, BFer or BFee
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
del_sounding_88xx(struct halmac_adapter *adapter, enum halmac_snd_role role)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
switch (role) {
case HAL_BFER:
HALMAC_REG_W8(REG_TXBF_CTRL + 3, 0);
break;
case HAL_BFEE:
HALMAC_REG_W8(REG_SND_PTCL_CTRL, 0);
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* su_bfee_entry_init_88xx() - config SU beamformee's registers
* @adapter : the adapter of halmac
* @userid : SU bfee userid = 0 or 1 to be added
* @paid : partial AID of this bfee
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
su_bfee_entry_init_88xx(struct halmac_adapter *adapter, u8 userid, u16 paid)
{
u16 tmp42c = 0;
u16 tmp168x = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
switch (userid) {
case 0:
tmp42c = HALMAC_REG_R16(REG_TXBF_CTRL) &
~(BIT_MASK_R_TXBF0_AID | BIT_R_TXBF0_20M |
BIT_R_TXBF0_40M | BIT_R_TXBF0_80M);
HALMAC_REG_W16(REG_TXBF_CTRL, tmp42c | paid);
HALMAC_REG_W16(REG_ASSOCIATED_BFMEE_SEL, paid);
#if HALMAC_8822C_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8822C)
HALMAC_REG_W16(REG_ASSOCIATED_BFMEE_SEL, paid | BIT(9));
#endif
break;
case 1:
tmp42c = HALMAC_REG_R16(REG_TXBF_CTRL + 2) &
~(BIT_MASK_R_TXBF1_AID | BIT_R_TXBF0_20M |
BIT_R_TXBF0_40M | BIT_R_TXBF0_80M);
HALMAC_REG_W16(REG_TXBF_CTRL + 2, tmp42c | paid);
HALMAC_REG_W16(REG_ASSOCIATED_BFMEE_SEL + 2, paid | BIT(9));
break;
case 2:
tmp168x = HALMAC_REG_R16(REG_WMAC_ASSOCIATED_MU_BFMEE2);
tmp168x = BIT_CLEAR_WMAC_MU_BFEE2_AID(tmp168x);
tmp168x |= (paid | BIT(9));
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE2, tmp168x);
break;
case 3:
tmp168x = HALMAC_REG_R16(REG_WMAC_ASSOCIATED_MU_BFMEE3);
tmp168x = BIT_CLEAR_WMAC_MU_BFEE3_AID(tmp168x);
tmp168x |= (paid | BIT(9));
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE3, tmp168x);
break;
case 4:
tmp168x = HALMAC_REG_R16(REG_WMAC_ASSOCIATED_MU_BFMEE4);
tmp168x = BIT_CLEAR_WMAC_MU_BFEE4_AID(tmp168x);
tmp168x |= (paid | BIT(9));
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE4, tmp168x);
break;
case 5:
tmp168x = HALMAC_REG_R16(REG_WMAC_ASSOCIATED_MU_BFMEE5);
tmp168x = BIT_CLEAR_WMAC_MU_BFEE5_AID(tmp168x);
tmp168x |= (paid | BIT(9));
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE5, tmp168x);
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* su_bfee_entry_init_88xx() - config SU beamformer's registers
* @adapter : the adapter of halmac
* @param : parameters to configure SU BFER entry
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
su_bfer_entry_init_88xx(struct halmac_adapter *adapter,
struct halmac_su_bfer_init_para *param)
{
u16 mac_addr_h;
u32 mac_addr_l;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
mac_addr_l = rtk_le32_to_cpu(param->bfer_address.addr_l_h.low);
mac_addr_h = rtk_le16_to_cpu(param->bfer_address.addr_l_h.high);
switch (param->userid) {
case 0:
HALMAC_REG_W32(REG_ASSOCIATED_BFMER0_INFO, mac_addr_l);
HALMAC_REG_W16(REG_ASSOCIATED_BFMER0_INFO + 4, mac_addr_h);
HALMAC_REG_W16(REG_ASSOCIATED_BFMER0_INFO + 6, param->paid);
HALMAC_REG_W16(REG_TX_CSI_RPT_PARAM_BW20, param->csi_para);
break;
case 1:
HALMAC_REG_W32(REG_ASSOCIATED_BFMER1_INFO, mac_addr_l);
HALMAC_REG_W16(REG_ASSOCIATED_BFMER1_INFO + 4, mac_addr_h);
HALMAC_REG_W16(REG_ASSOCIATED_BFMER1_INFO + 6, param->paid);
HALMAC_REG_W16(REG_TX_CSI_RPT_PARAM_BW20 + 2, param->csi_para);
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* mu_bfee_entry_init_88xx() - config MU beamformee's registers
* @adapter : the adapter of halmac
* @param : parameters to configure MU BFEE entry
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
mu_bfee_entry_init_88xx(struct halmac_adapter *adapter,
struct halmac_mu_bfee_init_para *param)
{
u16 tmp168x = 0;
u16 tmp14c0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
tmp168x |= param->paid | BIT(9);
HALMAC_REG_W16((0x1680 + param->userid * 2), tmp168x);
tmp14c0 = HALMAC_REG_R16(REG_MU_TX_CTL) & ~(BIT(8) | BIT(9) | BIT(10));
HALMAC_REG_W16(REG_MU_TX_CTL, tmp14c0 | ((param->userid - 2) << 8));
HALMAC_REG_W32(REG_MU_STA_GID_VLD, 0);
HALMAC_REG_W32(REG_MU_STA_USER_POS_INFO, param->user_position_l);
HALMAC_REG_W32(REG_MU_STA_USER_POS_INFO + 4, param->user_position_h);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* mu_bfer_entry_init_88xx() - config MU beamformer's registers
* @adapter : the adapter of halmac
* @param : parameters to configure MU BFER entry
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
mu_bfer_entry_init_88xx(struct halmac_adapter *adapter,
struct halmac_mu_bfer_init_para *param)
{
u16 tmp1680 = 0;
u16 mac_addr_h;
u32 mac_addr_l;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
mac_addr_l = rtk_le32_to_cpu(param->bfer_address.addr_l_h.low);
mac_addr_h = rtk_le16_to_cpu(param->bfer_address.addr_l_h.high);
HALMAC_REG_W32(REG_ASSOCIATED_BFMER0_INFO, mac_addr_l);
HALMAC_REG_W16(REG_ASSOCIATED_BFMER0_INFO + 4, mac_addr_h);
HALMAC_REG_W16(REG_ASSOCIATED_BFMER0_INFO + 6, param->paid);
HALMAC_REG_W16(REG_TX_CSI_RPT_PARAM_BW20, param->csi_para);
tmp1680 = HALMAC_REG_R16(0x1680) & 0xC000;
tmp1680 |= param->my_aid | (param->csi_length_sel << 12);
HALMAC_REG_W16(0x1680, tmp1680);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* su_bfee_entry_del_88xx() - reset SU beamformee's registers
* @adapter : the adapter of halmac
* @userid : the SU BFee userid to be deleted
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
su_bfee_entry_del_88xx(struct halmac_adapter *adapter, u8 userid)
{
u16 value16;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
switch (userid) {
case 0:
value16 = HALMAC_REG_R16(REG_TXBF_CTRL);
value16 &= ~(BIT_MASK_R_TXBF0_AID | BIT_R_TXBF0_20M |
BIT_R_TXBF0_40M | BIT_R_TXBF0_80M);
HALMAC_REG_W16(REG_TXBF_CTRL, value16);
HALMAC_REG_W16(REG_ASSOCIATED_BFMEE_SEL, 0);
break;
case 1:
value16 = HALMAC_REG_R16(REG_TXBF_CTRL + 2);
value16 &= ~(BIT_MASK_R_TXBF1_AID | BIT_R_TXBF0_20M |
BIT_R_TXBF0_40M | BIT_R_TXBF0_80M);
HALMAC_REG_W16(REG_TXBF_CTRL + 2, value16);
HALMAC_REG_W16(REG_ASSOCIATED_BFMEE_SEL + 2, 0);
break;
case 2:
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE2, 0);
break;
case 3:
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE3, 0);
break;
case 4:
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE4, 0);
break;
case 5:
HALMAC_REG_W16(REG_WMAC_ASSOCIATED_MU_BFMEE5, 0);
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* su_bfee_entry_del_88xx() - reset SU beamformer's registers
* @adapter : the adapter of halmac
* @userid : the SU BFer userid to be deleted
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
su_bfer_entry_del_88xx(struct halmac_adapter *adapter, u8 userid)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
switch (userid) {
case 0:
HALMAC_REG_W32(REG_ASSOCIATED_BFMER0_INFO, 0);
HALMAC_REG_W32(REG_ASSOCIATED_BFMER0_INFO + 4, 0);
break;
case 1:
HALMAC_REG_W32(REG_ASSOCIATED_BFMER1_INFO, 0);
HALMAC_REG_W32(REG_ASSOCIATED_BFMER1_INFO + 4, 0);
break;
default:
return HALMAC_RET_INVALID_SOUNDING_SETTING;
}
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* mu_bfee_entry_del_88xx() - reset MU beamformee's registers
* @adapter : the adapter of halmac
* @userid : the MU STA userid to be deleted
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
mu_bfee_entry_del_88xx(struct halmac_adapter *adapter, u8 userid)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W16(0x1680 + userid * 2, 0);
HALMAC_REG_W8_CLR(REG_MU_TX_CTL, BIT(userid - 2));
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* mu_bfer_entry_del_88xx() -reset MU beamformer's registers
* @adapter : the adapter of halmac
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
mu_bfer_entry_del_88xx(struct halmac_adapter *adapter)
{
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W32(REG_ASSOCIATED_BFMER0_INFO, 0);
HALMAC_REG_W32(REG_ASSOCIATED_BFMER0_INFO + 4, 0);
HALMAC_REG_W16(0x1680, 0);
HALMAC_REG_W8(REG_MU_TX_CTL, 0);
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_csi_rate_88xx() - config CSI frame Tx rate
* @adapter : the adapter of halmac
* @rssi : rssi in decimal value
* @cur_rate : current CSI frame rate
* @fixrate_en : enable to fix CSI frame in VHT rate, otherwise legacy OFDM rate
* @new_rate : API returns the final CSI frame rate
* Author : chunchu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_csi_rate_88xx(struct halmac_adapter *adapter, u8 rssi, u8 cur_rate,
u8 fixrate_en, u8 *new_rate, u8 *bmp_ofdm54)
{
u32 csi_cfg;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
*bmp_ofdm54 = 0xFF;
#if HALMAC_8821C_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8821C && fixrate_en) {
csi_cfg = HALMAC_REG_R32(REG_BBPSF_CTRL) & ~BITS_WMAC_CSI_RATE;
HALMAC_REG_W32(REG_BBPSF_CTRL,
csi_cfg | BIT_CSI_FORCE_RATE_EN |
BIT_CSI_RSC(1) |
BIT_WMAC_CSI_RATE(HALMAC_VHT_NSS1_MCS3));
*new_rate = HALMAC_VHT_NSS1_MCS3;
return HALMAC_RET_SUCCESS;
}
csi_cfg = HALMAC_REG_R32(REG_BBPSF_CTRL) & ~BITS_WMAC_CSI_RATE &
~BIT_CSI_FORCE_RATE_EN;
#else
csi_cfg = HALMAC_REG_R32(REG_BBPSF_CTRL) & ~BITS_WMAC_CSI_RATE;
#endif
if (rssi >= 40) {
if (cur_rate != HALMAC_OFDM54) {
csi_cfg |= BIT_WMAC_CSI_RATE(HALMAC_OFDM54);
HALMAC_REG_W32(REG_BBPSF_CTRL, csi_cfg);
*bmp_ofdm54 = 1;
}
*new_rate = HALMAC_OFDM54;
} else {
if (cur_rate != HALMAC_OFDM24) {
csi_cfg |= BIT_WMAC_CSI_RATE(HALMAC_OFDM24);
HALMAC_REG_W32(REG_BBPSF_CTRL, csi_cfg);
*bmp_ofdm54 = 0;
}
*new_rate = HALMAC_OFDM24;
}
return HALMAC_RET_SUCCESS;
}
/**
* fw_snding_88xx() - fw sounding control
* @adapter : the adapter of halmac
* @su_info :
* su0_en : enable/disable fw sounding
* su0_ndpa_pkt : ndpa pkt, shall include txdesc
* su0_pkt_sz : ndpa pkt size, shall include txdesc
* @mu_info : currently not in use, input NULL is acceptable
* @period : sounding period, unit is 5ms
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
fw_snding_88xx(struct halmac_adapter *adapter,
struct halmac_su_snding_info *su_info,
struct halmac_mu_snding_info *mu_info, u8 period)
{
u8 h2c_buf[H2C_PKT_SIZE_88XX] = { 0 };
u16 seq_num;
u16 snding_info_addr;
struct halmac_h2c_header_info hdr_info;
enum halmac_cmd_process_status *proc_status;
enum halmac_ret_status status;
proc_status = &adapter->halmac_state.fw_snding_state.proc_status;
if (adapter->chip_id == HALMAC_CHIP_ID_8821C)
return HALMAC_RET_NOT_SUPPORT;
if (halmac_fw_validate(adapter) != HALMAC_RET_SUCCESS)
return HALMAC_RET_NO_DLFW;
if (adapter->fw_ver.h2c_version < 9)
return HALMAC_RET_FW_NO_SUPPORT;
if (*proc_status == HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_TRACE("[TRACE]Wait event(snd)\n");
return HALMAC_RET_BUSY_STATE;
}
if (su_info->su0_en == 1) {
if (!su_info->su0_ndpa_pkt)
return HALMAC_RET_NULL_POINTER;
if (su_info->su0_pkt_sz > (u32)SU0_SNDING_PKT_RSVDPG_SIZE -
adapter->hw_cfg_info.txdesc_size)
return HALMAC_RET_DATA_SIZE_INCORRECT;
if (!snding_pkt_chk_88xx(adapter, su_info->su0_ndpa_pkt))
return HALMAC_RET_TXDESC_SET_FAIL;
if (fw_snding_cmd_cnstr_state_88xx(adapter) !=
HALMAC_CMD_CNSTR_IDLE) {
PLTFM_MSG_ERR("[ERR]Not idle(snd)\n");
return HALMAC_RET_ERROR_STATE;
}
snding_info_addr = adapter->txff_alloc.rsvd_h2c_sta_info_addr +
SU0_SNDING_PKT_OFFSET;
status = dl_rsvd_page_88xx(adapter, snding_info_addr,
su_info->su0_ndpa_pkt,
su_info->su0_pkt_sz);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]dl rsvd page\n");
return status;
}
FW_SNDING_SET_SU0(h2c_buf, 1);
FW_SNDING_SET_PERIOD(h2c_buf, period);
FW_SNDING_SET_NDPA0_HEAD_PG(h2c_buf, snding_info_addr -
adapter->txff_alloc.rsvd_boundary);
} else {
if (fw_snding_cmd_cnstr_state_88xx(adapter) !=
HALMAC_CMD_CNSTR_BUSY) {
PLTFM_MSG_ERR("[ERR]Not snd(snd)\n");
return HALMAC_RET_ERROR_STATE;
}
FW_SNDING_SET_SU0(h2c_buf, 0);
}
*proc_status = HALMAC_CMD_PROCESS_SENDING;
hdr_info.sub_cmd_id = SUB_CMD_ID_FW_SNDING;
hdr_info.content_size = 8;
hdr_info.ack = 1;
set_h2c_pkt_hdr_88xx(adapter, h2c_buf, &hdr_info, &seq_num);
adapter->halmac_state.fw_snding_state.seq_num = seq_num;
status = send_h2c_pkt_88xx(adapter, h2c_buf);
if (status != HALMAC_RET_SUCCESS) {
PLTFM_MSG_ERR("[ERR]send h2c\n");
reset_ofld_feature_88xx(adapter, HALMAC_FEATURE_FW_SNDING);
return status;
}
if (cnv_fw_snding_state_88xx(adapter, su_info->su0_en == 1 ?
HALMAC_CMD_CNSTR_BUSY :
HALMAC_CMD_CNSTR_IDLE)
!= HALMAC_RET_SUCCESS)
return HALMAC_RET_ERROR_STATE;
return HALMAC_RET_SUCCESS;
}
static u8
snding_pkt_chk_88xx(struct halmac_adapter *adapter, u8 *pkt)
{
u8 data_rate;
if (GET_TX_DESC_NDPA(pkt) == 0) {
PLTFM_MSG_ERR("[ERR]txdesc ndpa = 0\n");
return 0;
}
data_rate = (u8)GET_TX_DESC_DATARATE(pkt);
if (!(data_rate >= HALMAC_VHT_NSS2_MCS0 &&
data_rate <= HALMAC_VHT_NSS2_MCS9)) {
if (!(data_rate >= HALMAC_MCS8 && data_rate <= HALMAC_MCS15)) {
PLTFM_MSG_ERR("[ERR]txdesc rate\n");
return 0;
}
}
if (GET_TX_DESC_NAVUSEHDR(pkt) == 0) {
PLTFM_MSG_ERR("[ERR]txdesc navusehdr = 0\n");
return 0;
}
if (GET_TX_DESC_USE_RATE(pkt) == 0) {
PLTFM_MSG_ERR("[ERR]txdesc userate = 0\n");
return 0;
}
return 1;
}
static enum halmac_cmd_construct_state
fw_snding_cmd_cnstr_state_88xx(struct halmac_adapter *adapter)
{
return adapter->halmac_state.fw_snding_state.cmd_cnstr_state;
}
enum halmac_ret_status
get_h2c_ack_fw_snding_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
u8 seq_num = 0;
u8 fw_rc;
struct halmac_fw_snding_state *state;
enum halmac_cmd_process_status proc_status;
state = &adapter->halmac_state.fw_snding_state;
seq_num = (u8)H2C_ACK_HDR_GET_H2C_SEQ(buf);
PLTFM_MSG_TRACE("[TRACE]Seq num:h2c->%d c2h->%d\n",
state->seq_num, seq_num);
if (seq_num != state->seq_num) {
PLTFM_MSG_ERR("[ERR]Seq num mismatch:h2c->%d c2h->%d\n",
state->seq_num, seq_num);
return HALMAC_RET_SUCCESS;
}
if (state->proc_status != HALMAC_CMD_PROCESS_SENDING) {
PLTFM_MSG_ERR("[ERR]not sending(snd)\n");
return HALMAC_RET_SUCCESS;
}
fw_rc = (u8)H2C_ACK_HDR_GET_H2C_RETURN_CODE(buf);
state->fw_rc = fw_rc;
if ((enum halmac_h2c_return_code)fw_rc == HALMAC_H2C_RETURN_SUCCESS) {
proc_status = HALMAC_CMD_PROCESS_DONE;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_FW_SNDING, proc_status,
NULL, 0);
} else {
proc_status = HALMAC_CMD_PROCESS_ERROR;
state->proc_status = proc_status;
PLTFM_EVENT_SIG(HALMAC_FEATURE_FW_SNDING, proc_status,
&fw_rc, 1);
}
return HALMAC_RET_SUCCESS;
}
enum halmac_ret_status
get_fw_snding_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status)
{
*proc_status = adapter->halmac_state.fw_snding_state.proc_status;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
cnv_fw_snding_state_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_construct_state dest_state)
{
struct halmac_fw_snding_state *state;
state = &adapter->halmac_state.fw_snding_state;
if (state->cmd_cnstr_state != HALMAC_CMD_CNSTR_IDLE &&
state->cmd_cnstr_state != HALMAC_CMD_CNSTR_BUSY)
return HALMAC_RET_ERROR_STATE;
if (dest_state == HALMAC_CMD_CNSTR_IDLE) {
if (state->cmd_cnstr_state == HALMAC_CMD_CNSTR_IDLE)
return HALMAC_RET_ERROR_STATE;
} else if (dest_state == HALMAC_CMD_CNSTR_BUSY) {
if (state->cmd_cnstr_state == HALMAC_CMD_CNSTR_BUSY)
return HALMAC_RET_ERROR_STATE;
}
state->cmd_cnstr_state = dest_state;
return HALMAC_RET_SUCCESS;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_mimo_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_MIMO_88XX_H_
#define _HALMAC_MIMO_88XX_H_
#include "../halmac_api.h"
#if HALMAC_88XX_SUPPORT
enum halmac_ret_status
cfg_txbf_88xx(struct halmac_adapter *adapter, u8 userid, enum halmac_bw bw,
u8 txbf_en);
enum halmac_ret_status
cfg_mumimo_88xx(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param);
enum halmac_ret_status
cfg_sounding_88xx(struct halmac_adapter *adapter, enum halmac_snd_role role,
enum halmac_data_rate rate);
enum halmac_ret_status
del_sounding_88xx(struct halmac_adapter *adapter, enum halmac_snd_role role);
enum halmac_ret_status
su_bfee_entry_init_88xx(struct halmac_adapter *adapter, u8 userid, u16 paid);
enum halmac_ret_status
su_bfer_entry_init_88xx(struct halmac_adapter *adapter,
struct halmac_su_bfer_init_para *param);
enum halmac_ret_status
mu_bfee_entry_init_88xx(struct halmac_adapter *adapter,
struct halmac_mu_bfee_init_para *param);
enum halmac_ret_status
mu_bfer_entry_init_88xx(struct halmac_adapter *adapter,
struct halmac_mu_bfer_init_para *param);
enum halmac_ret_status
su_bfee_entry_del_88xx(struct halmac_adapter *adapter, u8 userid);
enum halmac_ret_status
su_bfer_entry_del_88xx(struct halmac_adapter *adapter, u8 userid);
enum halmac_ret_status
mu_bfee_entry_del_88xx(struct halmac_adapter *adapter, u8 userid);
enum halmac_ret_status
mu_bfer_entry_del_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
cfg_csi_rate_88xx(struct halmac_adapter *adapter, u8 rssi, u8 cur_rate,
u8 fixrate_en, u8 *new_rate, u8 *bmp_ofdm54);
enum halmac_ret_status
fw_snding_88xx(struct halmac_adapter *adapter,
struct halmac_su_snding_info *su_info,
struct halmac_mu_snding_info *mu_info, u8 period);
enum halmac_ret_status
get_h2c_ack_fw_snding_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
get_fw_snding_status_88xx(struct halmac_adapter *adapter,
enum halmac_cmd_process_status *proc_status);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_MIMO_88XX_H_ */
================================================
FILE: hal/halmac/halmac_88xx/halmac_pcie_88xx.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_pcie_88xx.h"
#if (HALMAC_88XX_SUPPORT && HALMAC_PCIE_SUPPORT)
/**
* init_pcie_cfg_88xx() - init PCIe
* @adapter : the adapter of halmac
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
init_pcie_cfg_88xx(struct halmac_adapter *adapter)
{
#if HALMAC_8822C_SUPPORT
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
if (adapter->chip_id == HALMAC_CHIP_ID_8822C) {
if (adapter->chip_ver == HALMAC_CHIP_VER_D_CUT ||
adapter->chip_ver == HALMAC_CHIP_VER_E_CUT ||
adapter->chip_ver == HALMAC_CHIP_VER_F_CUT)
/* defined after 8822C D CUT */
HALMAC_REG_W8_SET(REG_HCI_MIX_CFG + 3, BIT(2));
}
#endif
return HALMAC_RET_SUCCESS;
}
/**
* deinit_pcie_cfg_88xx() - deinit PCIE
* @adapter : the adapter of halmac
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
deinit_pcie_cfg_88xx(struct halmac_adapter *adapter)
{
return HALMAC_RET_SUCCESS;
}
/**
* cfg_pcie_rx_agg_88xx() - config rx aggregation
* @adapter : the adapter of halmac
* @halmac_rx_agg_mode
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_pcie_rx_agg_88xx(struct halmac_adapter *adapter,
struct halmac_rxagg_cfg *cfg)
{
return HALMAC_RET_SUCCESS;
}
/**
* reg_r8_pcie_88xx() - read 1byte register
* @adapter : the adapter of halmac
* @offset : register offset
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
u8
reg_r8_pcie_88xx(struct halmac_adapter *adapter, u32 offset)
{
return PLTFM_REG_R8(offset);
}
/**
* reg_w8_pcie_88xx() - write 1byte register
* @adapter : the adapter of halmac
* @offset : register offset
* @value : register value
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
reg_w8_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u8 value)
{
PLTFM_REG_W8(offset, value);
return HALMAC_RET_SUCCESS;
}
/**
* reg_r16_pcie_88xx() - read 2byte register
* @adapter : the adapter of halmac
* @offset : register offset
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
u16
reg_r16_pcie_88xx(struct halmac_adapter *adapter, u32 offset)
{
return PLTFM_REG_R16(offset);
}
/**
* reg_w16_pcie_88xx() - write 2byte register
* @adapter : the adapter of halmac
* @offset : register offset
* @value : register value
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
reg_w16_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u16 value)
{
PLTFM_REG_W16(offset, value);
return HALMAC_RET_SUCCESS;
}
/**
* reg_r32_pcie_88xx() - read 4byte register
* @adapter : the adapter of halmac
* @offset : register offset
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
u32
reg_r32_pcie_88xx(struct halmac_adapter *adapter, u32 offset)
{
return PLTFM_REG_R32(offset);
}
/**
* reg_w32_pcie_88xx() - write 4byte register
* @adapter : the adapter of halmac
* @offset : register offset
* @value : register value
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
reg_w32_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u32 value)
{
PLTFM_REG_W32(offset, value);
return HALMAC_RET_SUCCESS;
}
/**
* cfg_txagg_pcie_align_88xx() -config sdio bus tx agg alignment
* @adapter : the adapter of halmac
* @enable : function enable(1)/disable(0)
* @align_size : sdio bus tx agg alignment size (2^n, n = 3~11)
* Author : Soar Tu
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
cfg_txagg_pcie_align_88xx(struct halmac_adapter *adapter, u8 enable,
u16 align_size)
{
return HALMAC_RET_NOT_SUPPORT;
}
/**
* tx_allowed_pcie_88xx() - check tx status
* @adapter : the adapter of halmac
* @buf : tx packet, include txdesc
* @size : tx packet size, include txdesc
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
tx_allowed_pcie_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size)
{
return HALMAC_RET_NOT_SUPPORT;
}
/**
* pcie_indirect_reg_r32_88xx() - read MAC reg by SDIO reg
* @adapter : the adapter of halmac
* @offset : register offset
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
u32
pcie_indirect_reg_r32_88xx(struct halmac_adapter *adapter, u32 offset)
{
return 0xFFFFFFFF;
}
/**
* pcie_reg_rn_88xx() - read n byte register
* @adapter : the adapter of halmac
* @offset : register offset
* @size : register value size
* @value : register value
* Author : Soar
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
pcie_reg_rn_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
u8 *value)
{
return HALMAC_RET_NOT_SUPPORT;
}
/**
* set_pcie_bulkout_num_88xx() - inform bulk-out num
* @adapter : the adapter of halmac
* @num : usb bulk-out number
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
set_pcie_bulkout_num_88xx(struct halmac_adapter *adapter, u8 num)
{
return HALMAC_RET_NOT_SUPPORT;
}
/**
* get_pcie_tx_addr_88xx() - get CMD53 addr for the TX packet
* @adapter : the adapter of halmac
* @buf : tx packet, include txdesc
* @size : tx packet size
* @cmd53_addr : cmd53 addr value
* Author : KaiYuan Chang/Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_pcie_tx_addr_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
u32 *cmd53_addr)
{
return HALMAC_RET_NOT_SUPPORT;
}
/**
* get_pcie_bulkout_id_88xx() - get bulk out id for the TX packet
* @adapter : the adapter of halmac
* @buf : tx packet, include txdesc
* @size : tx packet size
* @id : usb bulk-out id
* Author : KaiYuan Chang
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
get_pcie_bulkout_id_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
u8 *id)
{
return HALMAC_RET_NOT_SUPPORT;
}
enum halmac_ret_status
mdio_write_88xx(struct halmac_adapter *adapter, u8 addr, u16 data, u8 speed)
{
u8 tmp_u1b = 0;
u32 cnt = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 real_addr = 0;
HALMAC_REG_W16(REG_MDIO_V1, data);
real_addr = (addr & 0x1F);
HALMAC_REG_W8(REG_PCIE_MIX_CFG, real_addr);
if (speed == HAL_INTF_PHY_PCIE_GEN1) {
if (addr < 0x20)
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x00);
else
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x01);
} else if (speed == HAL_INTF_PHY_PCIE_GEN2) {
if (addr < 0x20)
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x02);
else
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x03);
} else {
PLTFM_MSG_ERR("[ERR]Error Speed !\n");
}
HALMAC_REG_W8_SET(REG_PCIE_MIX_CFG, BIT_MDIO_WFLAG_V1);
tmp_u1b = HALMAC_REG_R8(REG_PCIE_MIX_CFG) & BIT_MDIO_WFLAG_V1;
cnt = 20;
while (tmp_u1b && (cnt != 0)) {
PLTFM_DELAY_US(10);
tmp_u1b = HALMAC_REG_R8(REG_PCIE_MIX_CFG) & BIT_MDIO_WFLAG_V1;
cnt--;
}
if (tmp_u1b) {
PLTFM_MSG_ERR("[ERR]MDIO write fail!\n");
return HALMAC_RET_FAIL;
}
return HALMAC_RET_SUCCESS;
}
u16
mdio_read_88xx(struct halmac_adapter *adapter, u8 addr, u8 speed)
{
u16 ret = 0;
u8 tmp_u1b = 0;
u32 cnt = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
u8 real_addr = 0;
real_addr = (addr & 0x1F);
HALMAC_REG_W8(REG_PCIE_MIX_CFG, real_addr);
if (speed == HAL_INTF_PHY_PCIE_GEN1) {
if (addr < 0x20)
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x00);
else
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x01);
} else if (speed == HAL_INTF_PHY_PCIE_GEN2) {
if (addr < 0x20)
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x02);
else
HALMAC_REG_W8(REG_PCIE_MIX_CFG + 3, 0x03);
} else {
PLTFM_MSG_ERR("[ERR]Error Speed !\n");
}
HALMAC_REG_W8_SET(REG_PCIE_MIX_CFG, BIT_MDIO_RFLAG_V1);
tmp_u1b = HALMAC_REG_R8(REG_PCIE_MIX_CFG) & BIT_MDIO_RFLAG_V1;
cnt = 20;
while (tmp_u1b && (cnt != 0)) {
PLTFM_DELAY_US(10);
tmp_u1b = HALMAC_REG_R8(REG_PCIE_MIX_CFG) & BIT_MDIO_RFLAG_V1;
cnt--;
}
if (tmp_u1b) {
ret = 0xFFFF;
PLTFM_MSG_ERR("[ERR]MDIO read fail!\n");
} else {
ret = HALMAC_REG_R16(REG_MDIO_V1 + 2);
PLTFM_MSG_TRACE("[TRACE]Value-R = %x\n", ret);
}
return ret;
}
enum halmac_ret_status
dbi_w32_88xx(struct halmac_adapter *adapter, u16 addr, u32 data)
{
u8 tmp_u1b = 0;
u32 cnt = 0;
u16 write_addr = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W32(REG_DBI_WDATA_V1, data);
write_addr = ((addr & 0x0ffc) | (0x000F << 12));
HALMAC_REG_W16(REG_DBI_FLAG_V1, write_addr);
PLTFM_MSG_TRACE("[TRACE]Addr-W = %x\n", write_addr);
HALMAC_REG_W8(REG_DBI_FLAG_V1 + 2, 0x01);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt = 20;
while (tmp_u1b && (cnt != 0)) {
PLTFM_DELAY_US(10);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt--;
}
if (tmp_u1b) {
PLTFM_MSG_ERR("[ERR]DBI write fail!\n");
return HALMAC_RET_FAIL;
}
return HALMAC_RET_SUCCESS;
}
u32
dbi_r32_88xx(struct halmac_adapter *adapter, u16 addr)
{
u16 read_addr = addr & 0x0ffc;
u8 tmp_u1b = 0;
u32 cnt = 0;
u32 ret = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W16(REG_DBI_FLAG_V1, read_addr);
HALMAC_REG_W8(REG_DBI_FLAG_V1 + 2, 0x2);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt = 20;
while (tmp_u1b && (cnt != 0)) {
PLTFM_DELAY_US(10);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt--;
}
if (tmp_u1b) {
ret = 0xFFFF;
PLTFM_MSG_ERR("[ERR]DBI read fail!\n");
} else {
ret = HALMAC_REG_R32(REG_DBI_RDATA_V1);
PLTFM_MSG_TRACE("[TRACE]Value-R = %x\n", ret);
}
return ret;
}
enum halmac_ret_status
dbi_w8_88xx(struct halmac_adapter *adapter, u16 addr, u8 data)
{
u8 tmp_u1b = 0;
u32 cnt = 0;
u16 write_addr = 0;
u16 remainder = addr & (4 - 1);
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W8(REG_DBI_WDATA_V1 + remainder, data);
write_addr = ((addr & 0x0ffc) | (BIT(0) << (remainder + 12)));
HALMAC_REG_W16(REG_DBI_FLAG_V1, write_addr);
PLTFM_MSG_TRACE("[TRACE]Addr-W = %x\n", write_addr);
HALMAC_REG_W8(REG_DBI_FLAG_V1 + 2, 0x01);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt = 20;
while (tmp_u1b && (cnt != 0)) {
PLTFM_DELAY_US(10);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt--;
}
if (tmp_u1b) {
PLTFM_MSG_ERR("[ERR]DBI write fail!\n");
return HALMAC_RET_FAIL;
}
return HALMAC_RET_SUCCESS;
}
u8
dbi_r8_88xx(struct halmac_adapter *adapter, u16 addr)
{
u16 read_addr = addr & 0x0ffc;
u8 tmp_u1b = 0;
u32 cnt = 0;
u8 ret = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
HALMAC_REG_W16(REG_DBI_FLAG_V1, read_addr);
HALMAC_REG_W8(REG_DBI_FLAG_V1 + 2, 0x2);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt = 20;
while (tmp_u1b && (cnt != 0)) {
PLTFM_DELAY_US(10);
tmp_u1b = HALMAC_REG_R8(REG_DBI_FLAG_V1 + 2);
cnt--;
}
if (tmp_u1b) {
ret = 0xFF;
PLTFM_MSG_ERR("[ERR]DBI read fail!\n");
} else {
ret = HALMAC_REG_R8(REG_DBI_RDATA_V1 + (addr & (4 - 1)));
PLTFM_MSG_TRACE("[TRACE]Value-R = %x\n", ret);
}
return ret;
}
enum halmac_ret_status
trxdma_check_idle_88xx(struct halmac_adapter *adapter)
{
u32 cnt = 0;
struct halmac_api *api = (struct halmac_api *)adapter->halmac_api;
/* Stop Tx & Rx DMA */
HALMAC_REG_W32_SET(REG_RXPKT_NUM, BIT(18));
HALMAC_REG_W16_SET(REG_PCIE_CTRL, ~(BIT(15) | BIT(8)));
/* Stop FW */
HALMAC_REG_W16_CLR(REG_SYS_FUNC_EN, BIT(10));
/* Check Tx DMA is idle */
cnt = 20;
while ((HALMAC_REG_R8(REG_SYS_CFG5) & BIT(2)) == BIT(2)) {
PLTFM_DELAY_US(10);
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]Chk tx idle\n");
return HALMAC_RET_POWER_OFF_FAIL;
}
}
/* Check Rx DMA is idle */
cnt = 20;
while ((HALMAC_REG_R32(REG_RXPKT_NUM) & BIT(17)) != BIT(17)) {
PLTFM_DELAY_US(10);
cnt--;
if (cnt == 0) {
PLTFM_MSG_ERR("[ERR]Chk rx idle\n");
return HALMAC_RET_POWER_OFF_FAIL;
}
}
return HALMAC_RET_SUCCESS;
}
void
en_ref_autok_88xx(struct halmac_adapter *adapter, u8 en)
{
if (en == 1)
adapter->pcie_refautok_en = 1;
else
adapter->pcie_refautok_en = 0;
}
#endif /* HALMAC_88XX_SUPPORT */
================================================
FILE: hal/halmac/halmac_88xx/halmac_pcie_88xx.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_PCIE_88XX_H_
#define _HALMAC_PCIE_88XX_H_
#include "../halmac_api.h"
#if (HALMAC_88XX_SUPPORT && HALMAC_PCIE_SUPPORT)
enum halmac_ret_status
init_pcie_cfg_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
deinit_pcie_cfg_88xx(struct halmac_adapter *adapter);
enum halmac_ret_status
cfg_pcie_rx_agg_88xx(struct halmac_adapter *adapter,
struct halmac_rxagg_cfg *cfg);
u8
reg_r8_pcie_88xx(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
reg_w8_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u8 value);
u16
reg_r16_pcie_88xx(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
reg_w16_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u16 value);
u32
reg_r32_pcie_88xx(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
reg_w32_pcie_88xx(struct halmac_adapter *adapter, u32 offset, u32 value);
enum halmac_ret_status
cfg_txagg_pcie_align_88xx(struct halmac_adapter *adapter, u8 enable,
u16 align_size);
enum halmac_ret_status
tx_allowed_pcie_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size);
u32
pcie_indirect_reg_r32_88xx(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
pcie_reg_rn_88xx(struct halmac_adapter *adapter, u32 offset, u32 size,
u8 *value);
enum halmac_ret_status
set_pcie_bulkout_num_88xx(struct halmac_adapter *adapter, u8 num);
enum halmac_ret_status
get_pcie_tx_addr_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
u32 *cmd53_addr);
enum halmac_ret_status
get_pcie_bulkout_id_88xx(struct halmac_adapter *adapter, u8 *buf, u32 size,
u8 *id);
enum halmac_ret_status
mdio_write_88xx(struct halmac_adapter *adapter, u8 addr, u16 data, u8 speed);
u16
mdio_read_88xx(struct halmac_adapter *adapter, u8 addr, u8 speed);
enum halmac_ret_status
dbi_w32_88xx(struct halmac_adapter *adapter, u16 addr, u32 data);
u32
dbi_r32_88xx(struct halmac_adapter *adapter, u16 addr);
enum halmac_ret_status
dbi_w8_88xx(struct halmac_adapter *adapter, u16 addr, u8 data);
u8
dbi_r8_88xx(struct halmac_adapter *adapter, u16 addr);
enum halmac_ret_status
trxdma_check_idle_88xx(struct halmac_adapter *adapter);
void
en_ref_autok_88xx(struct halmac_adapter *dapter, u8 en);
#endif /* HALMAC_88XX_SUPPORT */
#endif/* _HALMAC_PCIE_88XX_H_ */
================================================
FILE: hal/halmac/halmac_api.c
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#include "halmac_type.h"
#include "halmac_api.h"
#if (HALMAC_PLATFORM_WINDOWS)
#if HALMAC_8822B_SUPPORT
#include "halmac_88xx/halmac_init_win8822b.h"
#endif
#if HALMAC_8821C_SUPPORT
#include "halmac_88xx/halmac_init_win8821c.h"
#endif
#if HALMAC_8814B_SUPPORT
#include "halmac_88xx_v1/halmac_init_win8814b_v1.h"
#endif
#if HALMAC_8822C_SUPPORT
#include "halmac_88xx/halmac_init_win8822c.h"
#endif
#else
#if HALMAC_88XX_SUPPORT
#include "halmac_88xx/halmac_init_88xx.h"
#endif
#if HALMAC_88XX_V1_SUPPORT
#include "halmac_88xx_v1/halmac_init_88xx_v1.h"
#if defined(HALMAC_DATA_CPU_EN)
#include "halmac_88xxd_v1/halmac_init_88xxd_v1.h"
#endif
#endif
#endif
enum chip_id_hw_def {
CHIP_ID_HW_DEF_8723A = 0x01,
CHIP_ID_HW_DEF_8188E = 0x02,
CHIP_ID_HW_DEF_8881A = 0x03,
CHIP_ID_HW_DEF_8812A = 0x04,
CHIP_ID_HW_DEF_8821A = 0x05,
CHIP_ID_HW_DEF_8723B = 0x06,
CHIP_ID_HW_DEF_8192E = 0x07,
CHIP_ID_HW_DEF_8814A = 0x08,
CHIP_ID_HW_DEF_8821C = 0x09,
CHIP_ID_HW_DEF_8822B = 0x0A,
CHIP_ID_HW_DEF_8703B = 0x0B,
CHIP_ID_HW_DEF_8188F = 0x0C,
CHIP_ID_HW_DEF_8192F = 0x0D,
CHIP_ID_HW_DEF_8197F = 0x0E,
CHIP_ID_HW_DEF_8723D = 0x0F,
CHIP_ID_HW_DEF_8814B = 0x11,
CHIP_ID_HW_DEF_8822C = 0x13,
CHIP_ID_HW_DEF_8812F = 0x14,
CHIP_ID_HW_DEF_UNDEFINE = 0x7F,
CHIP_ID_HW_DEF_PS = 0xEA,
};
static enum halmac_ret_status
chk_pltfm_api(void *drv_adapter, enum halmac_interface intf,
struct halmac_platform_api *pltfm_api);
static enum halmac_ret_status
get_chip_info(void *drv_adapter, struct halmac_platform_api *pltfm_api,
enum halmac_interface intf, struct halmac_adapter *adapter);
static u8
pltfm_reg_r8_sdio(void *drv_adapter, struct halmac_platform_api *pltfm_api,
u32 offset);
static enum halmac_ret_status
pltfm_reg_w8_sdio(void *drv_adapter, struct halmac_platform_api *pltfm_api,
u32 offset, u8 data);
static u8
pltfm_reg_r_indir_sdio(void *drv_adapter, struct halmac_platform_api *pltfm_api,
u32 offset);
static enum halmac_ret_status
cnv_to_sdio_bus_offset(u32 *offset);
/**
* halmac_init_adapter() - init halmac_adapter
* @drv_adapter : the adapter of caller
* @pltfm_api : the platform APIs which is used in halmac
* @intf : bus interface
* @halmac_adapter : the adapter of halmac
* @halmac_api : the function pointer of APIs
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
halmac_init_adapter(void *drv_adapter, struct halmac_platform_api *pltfm_api,
enum halmac_interface intf,
struct halmac_adapter **halmac_adapter,
struct halmac_api **halmac_api)
{
struct halmac_adapter *adapter = NULL;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
u8 *buf = NULL;
union {
u32 i;
u8 x[4];
} ENDIAN_CHECK = { 0x01000000 };
status = chk_pltfm_api(drv_adapter, intf, pltfm_api);
if (status != HALMAC_RET_SUCCESS)
return status;
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT, HALMAC_DBG_ALWAYS,
HALMAC_SVN_VER "\n"
"HALMAC_MAJOR_VER = %x\n"
"HALMAC_PROTOTYPE_VER = %x\n"
"HALMAC_MINOR_VER = %x\n"
"HALMAC_PATCH_VER = %x\n",
HALMAC_MAJOR_VER, HALMAC_PROTOTYPE_VER,
HALMAC_MINOR_VER, HALMAC_PATCH_VER);
if (ENDIAN_CHECK.x[0] == HALMAC_SYSTEM_ENDIAN) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR,
"[ERR]Endian setting err!!\n");
return HALMAC_RET_ENDIAN_ERR;
}
buf = (u8 *)pltfm_api->RTL_MALLOC(drv_adapter, sizeof(*adapter));
if (!buf) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR,
"[ERR]Malloc HAL adapter err!!\n");
return HALMAC_RET_MALLOC_FAIL;
}
pltfm_api->RTL_MEMSET(drv_adapter, buf, 0x00, sizeof(*adapter));
adapter = (struct halmac_adapter *)buf;
*halmac_adapter = adapter;
adapter->pltfm_api = pltfm_api;
adapter->drv_adapter = drv_adapter;
intf = (intf == HALMAC_INTERFACE_AXI) ? HALMAC_INTERFACE_PCIE : intf;
adapter->intf = intf;
if (get_chip_info(drv_adapter, pltfm_api, intf, adapter)
!= HALMAC_RET_SUCCESS) {
PLTFM_FREE(*halmac_adapter, sizeof(**halmac_adapter));
*halmac_adapter = NULL;
return HALMAC_RET_CHIP_NOT_SUPPORT;
}
PLTFM_MUTEX_INIT(&adapter->efuse_mutex);
PLTFM_MUTEX_INIT(&adapter->h2c_seq_mutex);
PLTFM_MUTEX_INIT(&adapter->sdio_indir_mutex);
#if (HALMAC_PLATFORM_WINDOWS == 0)
#if HALMAC_88XX_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8822B ||
adapter->chip_id == HALMAC_CHIP_ID_8821C ||
adapter->chip_id == HALMAC_CHIP_ID_8822C ||
adapter->chip_id == HALMAC_CHIP_ID_8812F) {
init_adapter_param_88xx(adapter);
status = mount_api_88xx(adapter);
}
#endif
#if HALMAC_88XX_V1_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8814B) {
init_adapter_param_88xx_v1(adapter);
status = mount_api_88xx_v1(adapter);
}
#if defined(HALMAC_DATA_CPU_EN)
if (adapter->chip_id == HALMAC_CHIP_ID_8814B) {
init_adapter_param_88xxd_v1(adapter);
status = mount_api_88xxd_v1(adapter);
}
#endif
#endif
#else
#if HALMAC_8822B_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8822B) {
init_adapter_param_win8822b(adapter);
status = mount_api_win8822b(adapter);
}
#endif
#if HALMAC_8821C_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8821C) {
init_adapter_param_win8821c(adapter);
status = mount_api_win8821c(adapter);
}
#endif
#if HALMAC_8814B_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8814B) {
init_adapter_param_win8814b_v1(adapter);
status = mount_api_win8814b_v1(adapter);
}
#endif
#if HALMAC_8822C_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8822C) {
init_adapter_param_win8822c(adapter);
status = mount_api_win8822c(adapter);
}
#endif
#if HALMAC_8812F_SUPPORT
if (adapter->chip_id == HALMAC_CHIP_ID_8812F) {
init_adapter_param_win8812f(adapter);
status = mount_api_win8812f(adapter);
}
#endif
#endif
*halmac_api = (struct halmac_api *)adapter->halmac_api;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return status;
}
/**
* halmac_halt_api() - stop halmac_api action
* @adapter : the adapter of halmac
* Author : Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
halmac_halt_api(struct halmac_adapter *adapter)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
adapter->halmac_state.api_state = HALMAC_API_STATE_HALT;
PLTFM_MSG_TRACE("[TRACE]%s <===\n", __func__);
return HALMAC_RET_SUCCESS;
}
/**
* halmac_deinit_adapter() - deinit halmac adapter
* @adapter : the adapter of halmac
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
halmac_deinit_adapter(struct halmac_adapter *adapter)
{
PLTFM_MSG_TRACE("[TRACE]%s ===>\n", __func__);
PLTFM_MUTEX_DEINIT(&adapter->efuse_mutex);
PLTFM_MUTEX_DEINIT(&adapter->h2c_seq_mutex);
PLTFM_MUTEX_DEINIT(&adapter->sdio_indir_mutex);
if (adapter->efuse_map) {
PLTFM_FREE(adapter->efuse_map, adapter->hw_cfg_info.efuse_size);
adapter->efuse_map = (u8 *)NULL;
}
if (adapter->sdio_fs.macid_map) {
PLTFM_FREE(adapter->sdio_fs.macid_map,
adapter->sdio_fs.macid_map_size);
adapter->sdio_fs.macid_map = (u8 *)NULL;
}
if (adapter->halmac_state.psd_state.data) {
PLTFM_FREE(adapter->halmac_state.psd_state.data,
adapter->halmac_state.psd_state.data_size);
adapter->halmac_state.psd_state.data = (u8 *)NULL;
}
if (adapter->halmac_api) {
PLTFM_FREE(adapter->halmac_api, sizeof(struct halmac_api));
adapter->halmac_api = NULL;
}
PLTFM_FREE(adapter, sizeof(*adapter));
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
chk_pltfm_api(void *drv_adapter, enum halmac_interface intf,
struct halmac_platform_api *pltfm_api)
{
if (!pltfm_api)
return HALMAC_RET_PLATFORM_API_NULL;
if (!pltfm_api->MSG_PRINT)
return HALMAC_RET_PLATFORM_API_NULL;
if (intf == HALMAC_INTERFACE_SDIO) {
if (!pltfm_api->SDIO_CMD52_READ) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-r\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_READ_8) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-r8\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_READ_16) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-r16\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_READ_32) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-r32\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_READ_N) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-rn\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD52_WRITE) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-w\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_WRITE_8) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-w8\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_WRITE_16) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-w16\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD53_WRITE_32) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-w32\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->SDIO_CMD52_CIA_READ) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio-cia\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
}
if (intf == HALMAC_INTERFACE_USB || intf == HALMAC_INTERFACE_PCIE) {
if (!pltfm_api->REG_READ_8) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]reg-r8\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->REG_READ_16) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]reg-r16\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->REG_READ_32) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]reg-r32\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->REG_WRITE_8) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]reg-w8\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->REG_WRITE_16) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]reg-w16\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->REG_WRITE_32) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]reg-w32\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
}
if (!pltfm_api->RTL_FREE) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mem-free\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->RTL_MALLOC) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mem-malloc\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->RTL_MEMCPY) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mem-cpy\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->RTL_MEMSET) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mem-set\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->RTL_DELAY_US) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]time-delay\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->MUTEX_INIT) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mutex-init\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->MUTEX_DEINIT) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mutex-deinit\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->MUTEX_LOCK) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mutex-lock\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->MUTEX_UNLOCK) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]mutex-unlock\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
if (!pltfm_api->EVENT_INDICATION) {
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]event-indication\n");
return HALMAC_RET_PLATFORM_API_NULL;
}
return HALMAC_RET_SUCCESS;
}
/**
* halmac_get_version() - get HALMAC version
* @version : return version of major, prototype and minor information
* Author : KaiYuan Chang / Ivan Lin
* Return : enum halmac_ret_status
* More details of status code can be found in prototype document
*/
enum halmac_ret_status
halmac_get_version(struct halmac_ver *version)
{
version->major_ver = (u8)HALMAC_MAJOR_VER;
version->prototype_ver = (u8)HALMAC_PROTOTYPE_VER;
version->minor_ver = (u8)HALMAC_MINOR_VER;
return HALMAC_RET_SUCCESS;
}
static enum halmac_ret_status
get_chip_info(void *drv_adapter, struct halmac_platform_api *pltfm_api,
enum halmac_interface intf, struct halmac_adapter *adapter)
{
u8 chip_id;
u8 chip_ver;
u32 cnt;
if (adapter->intf == HALMAC_INTERFACE_SDIO) {
pltfm_reg_w8_sdio(drv_adapter, pltfm_api, REG_SDIO_HSUS_CTRL,
pltfm_reg_r8_sdio(drv_adapter, pltfm_api,
REG_SDIO_HSUS_CTRL) &
~(BIT(0)));
cnt = 10000;
while (!(pltfm_reg_r8_sdio(drv_adapter, pltfm_api,
REG_SDIO_HSUS_CTRL) & BIT(1))) {
cnt--;
if (cnt == 0)
return HALMAC_RET_SDIO_LEAVE_SUSPEND_FAIL;
}
chip_id = pltfm_reg_r_indir_sdio(drv_adapter, pltfm_api,
REG_SYS_CFG2);
chip_ver = pltfm_reg_r_indir_sdio(drv_adapter, pltfm_api,
REG_SYS_CFG1 + 1) >> 4;
} else {
chip_id = pltfm_api->REG_READ_8(drv_adapter, REG_SYS_CFG2);
chip_ver = pltfm_api->REG_READ_8(drv_adapter,
REG_SYS_CFG1 + 1) >> 4;
}
adapter->chip_ver = (enum halmac_chip_ver)chip_ver;
if (chip_id == CHIP_ID_HW_DEF_8822B) {
adapter->chip_id = HALMAC_CHIP_ID_8822B;
} else if (chip_id == CHIP_ID_HW_DEF_8821C) {
adapter->chip_id = HALMAC_CHIP_ID_8821C;
} else if (chip_id == CHIP_ID_HW_DEF_8814B) {
adapter->chip_id = HALMAC_CHIP_ID_8814B;
} else if (chip_id == CHIP_ID_HW_DEF_8197F) {
adapter->chip_id = HALMAC_CHIP_ID_8197F;
} else if (chip_id == CHIP_ID_HW_DEF_8822C) {
adapter->chip_id = HALMAC_CHIP_ID_8822C;
} else if (chip_id == CHIP_ID_HW_DEF_8812F) {
adapter->chip_id = HALMAC_CHIP_ID_8812F;
} else {
adapter->chip_id = HALMAC_CHIP_ID_UNDEFINE;
PLTFM_MSG_ERR("[ERR]Chip id is undefined\n");
return HALMAC_RET_CHIP_NOT_SUPPORT;
}
return HALMAC_RET_SUCCESS;
}
static u8
pltfm_reg_r8_sdio(void *drv_adapter, struct halmac_platform_api *pltfm_api,
u32 offset)
{
u8 value8;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (0 == (offset & 0xFFFF0000))
offset |= WLAN_IOREG_OFFSET;
status = cnv_to_sdio_bus_offset(&offset);
if (status != HALMAC_RET_SUCCESS)
return status;
value8 = pltfm_api->SDIO_CMD52_READ(drv_adapter, offset);
return value8;
}
static enum halmac_ret_status
pltfm_reg_w8_sdio(void *drv_adapter, struct halmac_platform_api *pltfm_api,
u32 offset, u8 data)
{
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
if (0 == (offset & 0xFFFF0000))
offset |= WLAN_IOREG_OFFSET;
status = cnv_to_sdio_bus_offset(&offset);
if (status != HALMAC_RET_SUCCESS)
return status;
pltfm_api->SDIO_CMD52_WRITE(drv_adapter, offset, data);
return HALMAC_RET_SUCCESS;
}
static u8
pltfm_reg_r_indir_sdio(void *drv_adapter, struct halmac_platform_api *pltfm_api,
u32 offset)
{
u8 value8, tmp, cnt = 50;
u32 reg_cfg = REG_SDIO_INDIRECT_REG_CFG;
u32 reg_data = REG_SDIO_INDIRECT_REG_DATA;
enum halmac_ret_status status = HALMAC_RET_SUCCESS;
status = cnv_to_sdio_bus_offset(®_cfg);
if (status != HALMAC_RET_SUCCESS)
return status;
status = cnv_to_sdio_bus_offset(®_data);
if (status != HALMAC_RET_SUCCESS)
return status;
pltfm_api->SDIO_CMD52_WRITE(drv_adapter, reg_cfg, (u8)offset);
pltfm_api->SDIO_CMD52_WRITE(drv_adapter, reg_cfg + 1,
(u8)(offset >> 8));
pltfm_api->SDIO_CMD52_WRITE(drv_adapter, reg_cfg + 2,
(u8)(BIT(3) | BIT(4)));
do {
tmp = pltfm_api->SDIO_CMD52_READ(drv_adapter, reg_cfg + 2);
cnt--;
} while (((tmp & BIT(4)) == 0) && (cnt > 0));
if (((cnt & BIT(4)) == 0) && cnt == 0)
pltfm_api->MSG_PRINT(drv_adapter, HALMAC_MSG_INIT,
HALMAC_DBG_ERR, "[ERR]sdio indir read\n");
value8 = pltfm_api->SDIO_CMD52_READ(drv_adapter, reg_data);
return value8;
}
/*Note: copy from cnv_to_sdio_bus_offset_88xx*/
static enum halmac_ret_status
cnv_to_sdio_bus_offset(u32 *offset)
{
switch ((*offset) & 0xFFFF0000) {
case WLAN_IOREG_OFFSET:
*offset &= HALMAC_WLAN_MAC_REG_MSK;
*offset |= HALMAC_SDIO_CMD_ADDR_MAC_REG << 13;
break;
case SDIO_LOCAL_OFFSET:
*offset &= HALMAC_SDIO_LOCAL_MSK;
*offset |= HALMAC_SDIO_CMD_ADDR_SDIO_REG << 13;
break;
default:
*offset = 0xFFFFFFFF;
return HALMAC_RET_CONVERT_SDIO_OFFSET_FAIL;
}
return HALMAC_RET_SUCCESS;
}
================================================
FILE: hal/halmac/halmac_api.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_API_H_
#define _HALMAC_API_H_
#define HALMAC_SVN_VER "11692M"
#define HALMAC_MAJOR_VER 0x0001
#define HALMAC_PROTOTYPE_VER 0x0005
#define HALMAC_MINOR_VER 0x0014
#define HALMAC_PATCH_VER 0x0030
#define HALMAC_88XX_SUPPORT (HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define HALMAC_88XX_V1_SUPPORT HALMAC_8814B_SUPPORT
#include "halmac_2_platform.h"
#include "halmac_type.h"
#include "halmac_hw_cfg.h"
#include "halmac_usb_reg.h"
#include "halmac_sdio_reg.h"
#include "halmac_pcie_reg.h"
#include "halmac_bit2.h"
#include "halmac_reg2.h"
#if HALMAC_PLATFORM_TESTPROGRAM
#include "halmac_type_testprogram.h"
#endif
#ifndef HALMAC_USE_TYPEDEF
#define HALMAC_USE_TYPEDEF 1
#endif
#if HALMAC_USE_TYPEDEF
#include "halmac_typedef.h"
#endif
#if HALMAC_8822B_SUPPORT
#include "halmac_reg_8822b.h"
#include "halmac_bit_8822b.h"
#endif
#if HALMAC_8821C_SUPPORT
#include "halmac_reg_8821c.h"
#include "halmac_bit_8821c.h"
#endif
#if HALMAC_8814B_SUPPORT
#include "halmac_reg_8814b.h"
#include "halmac_bit_8814b.h"
#endif
#if HALMAC_8822C_SUPPORT
#include "halmac_reg_8822c.h"
#include "halmac_bit_8822c.h"
#endif
#if (HALMAC_PLATFORM_WINDOWS || HALMAC_PLATFORM_LINUX)
#include "halmac_tx_desc_nic.h"
#include "halmac_tx_desc_buffer_nic.h"
#include "halmac_tx_desc_ie_nic.h"
#include "halmac_rx_desc_nic.h"
#include "halmac_tx_bd_nic.h"
#include "halmac_rx_bd_nic.h"
#include "halmac_fw_offload_c2h_nic.h"
#include "halmac_fw_offload_h2c_nic.h"
#include "halmac_h2c_extra_info_nic.h"
#include "halmac_original_c2h_nic.h"
#include "halmac_original_h2c_nic.h"
#endif
#if (HALMAC_PLATFORM_AP)
#include "halmac_rx_desc_ap.h"
#include "halmac_tx_desc_ap.h"
#include "halmac_tx_desc_buffer_ap.h"
#include "halmac_tx_desc_ie_ap.h"
#include "halmac_fw_offload_c2h_ap.h"
#include "halmac_fw_offload_h2c_ap.h"
#include "halmac_h2c_extra_info_ap.h"
#include "halmac_original_c2h_ap.h"
#include "halmac_original_h2c_ap.h"
#endif
#include "halmac_tx_desc_chip.h"
#include "halmac_rx_desc_chip.h"
#include "halmac_tx_desc_buffer_chip.h"
#include "halmac_tx_desc_ie_chip.h"
enum halmac_ret_status
halmac_init_adapter(void *drv_adapter, struct halmac_platform_api *pltfm_api,
enum halmac_interface intf,
struct halmac_adapter **halmac_adapter,
struct halmac_api **halmac_api);
enum halmac_ret_status
halmac_deinit_adapter(struct halmac_adapter *adapter);
enum halmac_ret_status
halmac_halt_api(struct halmac_adapter *adapter);
enum halmac_ret_status
halmac_get_version(struct halmac_ver *version);
#endif
================================================
FILE: hal/halmac/halmac_bit2.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __RTL_WLAN_BITDEF_H__
#define __RTL_WLAN_BITDEF_H__
#include "halmac_hw_cfg.h"
#define CPU_OPT_WIDTH 0x1F
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define BIT_WRITE_ENABLE BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define BIT_MEM_RMV_SIGN BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_SHIFT_LLTE_RWM 30
#define BIT_MASK_LLTE_RWM 0x3
#define BIT_LLTE_RWM(x) (((x) & BIT_MASK_LLTE_RWM) << BIT_SHIFT_LLTE_RWM)
#define BITS_LLTE_RWM (BIT_MASK_LLTE_RWM << BIT_SHIFT_LLTE_RWM)
#define BIT_CLEAR_LLTE_RWM(x) ((x) & (~BITS_LLTE_RWM))
#define BIT_GET_LLTE_RWM(x) (((x) >> BIT_SHIFT_LLTE_RWM) & BIT_MASK_LLTE_RWM)
#define BIT_SET_LLTE_RWM(x, v) (BIT_CLEAR_LLTE_RWM(x) | BIT_LLTE_RWM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define BIT_MEM_RMV_2PRF1 BIT(29)
#define BIT_MEM_RMV_2PRF0 BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_GTAB_ID 28
#define BIT_MASK_GTAB_ID 0x7
#define BIT_GTAB_ID(x) (((x) & BIT_MASK_GTAB_ID) << BIT_SHIFT_GTAB_ID)
#define BITS_GTAB_ID (BIT_MASK_GTAB_ID << BIT_SHIFT_GTAB_ID)
#define BIT_CLEAR_GTAB_ID(x) ((x) & (~BITS_GTAB_ID))
#define BIT_GET_GTAB_ID(x) (((x) >> BIT_SHIFT_GTAB_ID) & BIT_MASK_GTAB_ID)
#define BIT_SET_GTAB_ID(x, v) (BIT_CLEAR_GTAB_ID(x) | BIT_GTAB_ID(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define BIT_MULRW BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define BIT_MEM_RMV_1PRF1 BIT(27)
#define BIT_MEM_RMV_1PRF0 BIT(26)
#define BIT_MEM_RMV_1PSR BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define BIT_SHIFT_MBIDCAM_ADDR 24
#define BIT_MASK_MBIDCAM_ADDR 0x1f
#define BIT_MBIDCAM_ADDR(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR) << BIT_SHIFT_MBIDCAM_ADDR)
#define BITS_MBIDCAM_ADDR (BIT_MASK_MBIDCAM_ADDR << BIT_SHIFT_MBIDCAM_ADDR)
#define BIT_CLEAR_MBIDCAM_ADDR(x) ((x) & (~BITS_MBIDCAM_ADDR))
#define BIT_GET_MBIDCAM_ADDR(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR) & BIT_MASK_MBIDCAM_ADDR)
#define BIT_SET_MBIDCAM_ADDR(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR(x) | BIT_MBIDCAM_ADDR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define BIT_MEM_RMV_ROM BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define BIT_CPRST BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_CTS_EN BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_R_OFDM_LEN_V1 16
#define BIT_MASK_R_OFDM_LEN_V1 0xffff
#define BIT_R_OFDM_LEN_V1(x) \
(((x) & BIT_MASK_R_OFDM_LEN_V1) << BIT_SHIFT_R_OFDM_LEN_V1)
#define BITS_R_OFDM_LEN_V1 (BIT_MASK_R_OFDM_LEN_V1 << BIT_SHIFT_R_OFDM_LEN_V1)
#define BIT_CLEAR_R_OFDM_LEN_V1(x) ((x) & (~BITS_R_OFDM_LEN_V1))
#define BIT_GET_R_OFDM_LEN_V1(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN_V1) & BIT_MASK_R_OFDM_LEN_V1)
#define BIT_SET_R_OFDM_LEN_V1(x, v) \
(BIT_CLEAR_R_OFDM_LEN_V1(x) | BIT_R_OFDM_LEN_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_COUNTER_BASE 16
#define BIT_MASK_COUNTER_BASE 0x1fff
#define BIT_COUNTER_BASE(x) \
(((x) & BIT_MASK_COUNTER_BASE) << BIT_SHIFT_COUNTER_BASE)
#define BITS_COUNTER_BASE (BIT_MASK_COUNTER_BASE << BIT_SHIFT_COUNTER_BASE)
#define BIT_CLEAR_COUNTER_BASE(x) ((x) & (~BITS_COUNTER_BASE))
#define BIT_GET_COUNTER_BASE(x) \
(((x) >> BIT_SHIFT_COUNTER_BASE) & BIT_MASK_COUNTER_BASE)
#define BIT_SET_COUNTER_BASE(x, v) \
(BIT_CLEAR_COUNTER_BASE(x) | BIT_COUNTER_BASE(v))
#define BIT_SHIFT_AGG_VALUE2 16
#define BIT_MASK_AGG_VALUE2 0x7f
#define BIT_AGG_VALUE2(x) (((x) & BIT_MASK_AGG_VALUE2) << BIT_SHIFT_AGG_VALUE2)
#define BITS_AGG_VALUE2 (BIT_MASK_AGG_VALUE2 << BIT_SHIFT_AGG_VALUE2)
#define BIT_CLEAR_AGG_VALUE2(x) ((x) & (~BITS_AGG_VALUE2))
#define BIT_GET_AGG_VALUE2(x) \
(((x) >> BIT_SHIFT_AGG_VALUE2) & BIT_MASK_AGG_VALUE2)
#define BIT_SET_AGG_VALUE2(x, v) (BIT_CLEAR_AGG_VALUE2(x) | BIT_AGG_VALUE2(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_WMAC_SRCH_FIFOFULL BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1 BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_XTAL_DRV_RF1 13
#define BIT_MASK_XTAL_DRV_RF1 0x3
#define BIT_XTAL_DRV_RF1(x) \
(((x) & BIT_MASK_XTAL_DRV_RF1) << BIT_SHIFT_XTAL_DRV_RF1)
#define BITS_XTAL_DRV_RF1 (BIT_MASK_XTAL_DRV_RF1 << BIT_SHIFT_XTAL_DRV_RF1)
#define BIT_CLEAR_XTAL_DRV_RF1(x) ((x) & (~BITS_XTAL_DRV_RF1))
#define BIT_GET_XTAL_DRV_RF1(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF1) & BIT_MASK_XTAL_DRV_RF1)
#define BIT_SET_XTAL_DRV_RF1(x, v) \
(BIT_CLEAR_XTAL_DRV_RF1(x) | BIT_XTAL_DRV_RF1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
#define BIT_DISABLE_B0 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_ATIMEND BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_GTAB_ID_V1 12
#define BIT_MASK_GTAB_ID_V1 0x7
#define BIT_GTAB_ID_V1(x) (((x) & BIT_MASK_GTAB_ID_V1) << BIT_SHIFT_GTAB_ID_V1)
#define BITS_GTAB_ID_V1 (BIT_MASK_GTAB_ID_V1 << BIT_SHIFT_GTAB_ID_V1)
#define BIT_CLEAR_GTAB_ID_V1(x) ((x) & (~BITS_GTAB_ID_V1))
#define BIT_GET_GTAB_ID_V1(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1) & BIT_MASK_GTAB_ID_V1)
#define BIT_SET_GTAB_ID_V1(x, v) (BIT_CLEAR_GTAB_ID_V1(x) | BIT_GTAB_ID_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_SHIFT_WATCH_DOG_RECORD_V1 10
#define BIT_MASK_WATCH_DOG_RECORD_V1 0x3fff
#define BIT_WATCH_DOG_RECORD_V1(x) \
(((x) & BIT_MASK_WATCH_DOG_RECORD_V1) << BIT_SHIFT_WATCH_DOG_RECORD_V1)
#define BITS_WATCH_DOG_RECORD_V1 \
(BIT_MASK_WATCH_DOG_RECORD_V1 << BIT_SHIFT_WATCH_DOG_RECORD_V1)
#define BIT_CLEAR_WATCH_DOG_RECORD_V1(x) ((x) & (~BITS_WATCH_DOG_RECORD_V1))
#define BIT_GET_WATCH_DOG_RECORD_V1(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_RECORD_V1) & BIT_MASK_WATCH_DOG_RECORD_V1)
#define BIT_SET_WATCH_DOG_RECORD_V1(x, v) \
(BIT_CLEAR_WATCH_DOG_RECORD_V1(x) | BIT_WATCH_DOG_RECORD_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_R_8051_SPD BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_R_IO_TIMEOUT_FLAG_V1 BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_EN_RTS_REQ BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define BIT_EN_WATCH_DOG_V1 BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_EN_EDCA_REQ BIT(8)
#define BIT_SHIFT_AGG_VALUE1 8
#define BIT_MASK_AGG_VALUE1 0x7f
#define BIT_AGG_VALUE1(x) (((x) & BIT_MASK_AGG_VALUE1) << BIT_SHIFT_AGG_VALUE1)
#define BITS_AGG_VALUE1 (BIT_MASK_AGG_VALUE1 << BIT_SHIFT_AGG_VALUE1)
#define BIT_CLEAR_AGG_VALUE1(x) ((x) & (~BITS_AGG_VALUE1))
#define BIT_GET_AGG_VALUE1(x) \
(((x) >> BIT_SHIFT_AGG_VALUE1) & BIT_MASK_AGG_VALUE1)
#define BIT_SET_AGG_VALUE1(x, v) (BIT_CLEAR_AGG_VALUE1(x) | BIT_AGG_VALUE1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_DIS_TXDMA_PRE BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_RAM_DL_SEL BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_EN_PTCL_REQ BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_DIS_RXDMA_PRE BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
#define BIT_WINTINI_RDY BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_EN_SCH_REQ BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_CLR_HGQ_REQ_BLOCK BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_I2C_M_BUS_GNT_FW 4
#define BIT_MASK_I2C_M_BUS_GNT_FW 0x7
#define BIT_I2C_M_BUS_GNT_FW(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT_FW) << BIT_SHIFT_I2C_M_BUS_GNT_FW)
#define BITS_I2C_M_BUS_GNT_FW \
(BIT_MASK_I2C_M_BUS_GNT_FW << BIT_SHIFT_I2C_M_BUS_GNT_FW)
#define BIT_CLEAR_I2C_M_BUS_GNT_FW(x) ((x) & (~BITS_I2C_M_BUS_GNT_FW))
#define BIT_GET_I2C_M_BUS_GNT_FW(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT_FW) & BIT_MASK_I2C_M_BUS_GNT_FW)
#define BIT_SET_I2C_M_BUS_GNT_FW(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT_FW(x) | BIT_I2C_M_BUS_GNT_FW(v))
#define BIT_I2C_M_GNT_FW BIT(3)
#endif
#if (HALMAC_8197G_SUPPORT)
#define BIT_SYM_LPS_STATUS BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_TXFLAG_EXIT_L1_EN BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT)
#define BIT_SYM_HCI_TXDMA_BUSY BIT(2)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_DATA_FW_STS_FILTER BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define BIT_EN_RXDMA_ALIGN_V1 BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_I2C_M_SPEED 1
#define BIT_MASK_I2C_M_SPEED 0x3
#define BIT_I2C_M_SPEED(x) \
(((x) & BIT_MASK_I2C_M_SPEED) << BIT_SHIFT_I2C_M_SPEED)
#define BITS_I2C_M_SPEED (BIT_MASK_I2C_M_SPEED << BIT_SHIFT_I2C_M_SPEED)
#define BIT_CLEAR_I2C_M_SPEED(x) ((x) & (~BITS_I2C_M_SPEED))
#define BIT_GET_I2C_M_SPEED(x) \
(((x) >> BIT_SHIFT_I2C_M_SPEED) & BIT_MASK_I2C_M_SPEED)
#define BIT_SET_I2C_M_SPEED(x, v) \
(BIT_CLEAR_I2C_M_SPEED(x) | BIT_I2C_M_SPEED(v))
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_CTRL_FW_STS_FILTER BIT(1)
#endif
#if (HALMAC_8881A_SUPPORT)
#define BIT_AFE_MBIAS BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT)
#define BIT_SHIFT_MDIO_REG_ADDR 0
#define BIT_MASK_MDIO_REG_ADDR 0x1f
#define BIT_MDIO_REG_ADDR(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR) << BIT_SHIFT_MDIO_REG_ADDR)
#define BITS_MDIO_REG_ADDR (BIT_MASK_MDIO_REG_ADDR << BIT_SHIFT_MDIO_REG_ADDR)
#define BIT_CLEAR_MDIO_REG_ADDR(x) ((x) & (~BITS_MDIO_REG_ADDR))
#define BIT_GET_MDIO_REG_ADDR(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR) & BIT_MASK_MDIO_REG_ADDR)
#define BIT_SET_MDIO_REG_ADDR(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR(x) | BIT_MDIO_REG_ADDR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define BIT_EN_TXDMA_ALIGN_V1 BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_RXFF0_BNDY_V2 0
#define BIT_MASK_RXFF0_BNDY_V2 0x3ffff
#define BIT_RXFF0_BNDY_V2(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V2) << BIT_SHIFT_RXFF0_BNDY_V2)
#define BITS_RXFF0_BNDY_V2 (BIT_MASK_RXFF0_BNDY_V2 << BIT_SHIFT_RXFF0_BNDY_V2)
#define BIT_CLEAR_RXFF0_BNDY_V2(x) ((x) & (~BITS_RXFF0_BNDY_V2))
#define BIT_GET_RXFF0_BNDY_V2(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V2) & BIT_MASK_RXFF0_BNDY_V2)
#define BIT_SET_RXFF0_BNDY_V2(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V2(x) | BIT_RXFF0_BNDY_V2(v))
#define BIT_SHIFT_RXFF0_RDPTR_V2 0
#define BIT_MASK_RXFF0_RDPTR_V2 0x3ffff
#define BIT_RXFF0_RDPTR_V2(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V2) << BIT_SHIFT_RXFF0_RDPTR_V2)
#define BITS_RXFF0_RDPTR_V2 \
(BIT_MASK_RXFF0_RDPTR_V2 << BIT_SHIFT_RXFF0_RDPTR_V2)
#define BIT_CLEAR_RXFF0_RDPTR_V2(x) ((x) & (~BITS_RXFF0_RDPTR_V2))
#define BIT_GET_RXFF0_RDPTR_V2(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V2) & BIT_MASK_RXFF0_RDPTR_V2)
#define BIT_SET_RXFF0_RDPTR_V2(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V2(x) | BIT_RXFF0_RDPTR_V2(v))
#define BIT_SHIFT_RXFF0_WTPTR_V2 0
#define BIT_MASK_RXFF0_WTPTR_V2 0x3ffff
#define BIT_RXFF0_WTPTR_V2(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V2) << BIT_SHIFT_RXFF0_WTPTR_V2)
#define BITS_RXFF0_WTPTR_V2 \
(BIT_MASK_RXFF0_WTPTR_V2 << BIT_SHIFT_RXFF0_WTPTR_V2)
#define BIT_CLEAR_RXFF0_WTPTR_V2(x) ((x) & (~BITS_RXFF0_WTPTR_V2))
#define BIT_GET_RXFF0_WTPTR_V2(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V2) & BIT_MASK_RXFF0_WTPTR_V2)
#define BIT_SET_RXFF0_WTPTR_V2(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V2(x) | BIT_RXFF0_WTPTR_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_AGG_VALUE0 0
#define BIT_MASK_AGG_VALUE0 0x7f
#define BIT_AGG_VALUE0(x) (((x) & BIT_MASK_AGG_VALUE0) << BIT_SHIFT_AGG_VALUE0)
#define BITS_AGG_VALUE0 (BIT_MASK_AGG_VALUE0 << BIT_SHIFT_AGG_VALUE0)
#define BIT_CLEAR_AGG_VALUE0(x) ((x) & (~BITS_AGG_VALUE0))
#define BIT_GET_AGG_VALUE0(x) \
(((x) >> BIT_SHIFT_AGG_VALUE0) & BIT_MASK_AGG_VALUE0)
#define BIT_SET_AGG_VALUE0(x, v) (BIT_CLEAR_AGG_VALUE0(x) | BIT_AGG_VALUE0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_SHIFT_BW_CFG 0
#define BIT_MASK_BW_CFG 0x3
#define BIT_BW_CFG(x) (((x) & BIT_MASK_BW_CFG) << BIT_SHIFT_BW_CFG)
#define BITS_BW_CFG (BIT_MASK_BW_CFG << BIT_SHIFT_BW_CFG)
#define BIT_CLEAR_BW_CFG(x) ((x) & (~BITS_BW_CFG))
#define BIT_GET_BW_CFG(x) (((x) >> BIT_SHIFT_BW_CFG) & BIT_MASK_BW_CFG)
#define BIT_SET_BW_CFG(x, v) (BIT_CLEAR_BW_CFG(x) | BIT_BW_CFG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_I2C_M_UNLOCK BIT(0)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define BIT_MGNT_FW_STS_FILTER BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define BIT_ISO_MD2PP BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_SHIFT_SDIO_INT_TIMEOUT 16
#define BIT_MASK_SDIO_INT_TIMEOUT 0xffff
#define BIT_SDIO_INT_TIMEOUT(x) \
(((x) & BIT_MASK_SDIO_INT_TIMEOUT) << BIT_SHIFT_SDIO_INT_TIMEOUT)
#define BITS_SDIO_INT_TIMEOUT \
(BIT_MASK_SDIO_INT_TIMEOUT << BIT_SHIFT_SDIO_INT_TIMEOUT)
#define BIT_CLEAR_SDIO_INT_TIMEOUT(x) ((x) & (~BITS_SDIO_INT_TIMEOUT))
#define BIT_GET_SDIO_INT_TIMEOUT(x) \
(((x) >> BIT_SHIFT_SDIO_INT_TIMEOUT) & BIT_MASK_SDIO_INT_TIMEOUT)
#define BIT_SET_SDIO_INT_TIMEOUT(x, v) \
(BIT_CLEAR_SDIO_INT_TIMEOUT(x) | BIT_SDIO_INT_TIMEOUT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PWC_EV12V BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PWC_ON2EF BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_IO_ERR_STATUS BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PWC_EBCOEB BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PWC_EV25V BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PWC_EV2EF BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_CMD53_W_MIX BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PA33V_EN BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_CMD53_TX_FORMAT BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PA12V_EN BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_CMD53_R_TIMEOUT_MASK BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_PC_A15V BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_UA33V_EN BIT(11)
#define BIT_UA12V_EN BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_SHIFT_CMD53_R_TIMEOUT_UNIT 10
#define BIT_MASK_CMD53_R_TIMEOUT_UNIT 0x3
#define BIT_CMD53_R_TIMEOUT_UNIT(x) \
(((x) & BIT_MASK_CMD53_R_TIMEOUT_UNIT) \
<< BIT_SHIFT_CMD53_R_TIMEOUT_UNIT)
#define BITS_CMD53_R_TIMEOUT_UNIT \
(BIT_MASK_CMD53_R_TIMEOUT_UNIT << BIT_SHIFT_CMD53_R_TIMEOUT_UNIT)
#define BIT_CLEAR_CMD53_R_TIMEOUT_UNIT(x) ((x) & (~BITS_CMD53_R_TIMEOUT_UNIT))
#define BIT_GET_CMD53_R_TIMEOUT_UNIT(x) \
(((x) >> BIT_SHIFT_CMD53_R_TIMEOUT_UNIT) & \
BIT_MASK_CMD53_R_TIMEOUT_UNIT)
#define BIT_SET_CMD53_R_TIMEOUT_UNIT(x, v) \
(BIT_CLEAR_CMD53_R_TIMEOUT_UNIT(x) | BIT_CMD53_R_TIMEOUT_UNIT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_AFE_OUTPUT_SIGNAL BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_RFDIO BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_REPLY_ERRCRC_IN_DATA BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_EB2CORE BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_EF2PP BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_EN_CMD53_OVERLAP BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_DIOE BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_EXTIO BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_REPLY_ERR_IN_R5 BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_DIOP BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_WLPON2PP BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_R18A_EN BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_IP2MAC_WA2PP BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_WA2PP BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_SDIO_CMD_FORCE_VLD BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_PD2CORE BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_PD2PP BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_INIT_CMD_EN BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_PA2PCIE BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_PA2PD BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_RXINT_READ_MASK_DIS BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_EN_32K_TRANS BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_UD2CORE BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_UD2PP BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_EN_RXDMA_MASK_INT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_HD2CORE BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_UA2USB BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_UA2UD BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_EN_MASK_TIMER BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_WD2PP BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_ISO_CTRL (Offset 0x0000) */
#define BIT_ISO_WL2PP BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TX_CTRL (Offset 0x10250000) */
#define BIT_CMD_ERR_STOP_INT_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_MREGEN BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_WLMACPON BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_HWPDN BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_AIP_PD12_N BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_EN_25_1 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_ELDR BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_DCORE BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_WLMACPOF BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_CPUEN BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_DIOE BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_EXTIO BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_PCIED BIT(8)
#define BIT_FEN_PPLL BIT(7)
#define BIT_FEN_PCIEA BIT(6)
#define BIT_FEN_DIO_PCIE BIT(5)
#define BIT_FEN_USBD BIT(4)
#define BIT_FEN_UPLL BIT(3)
#define BIT_FEN_USBA BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_BB_GLB_RSTN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_WLPHYGLB BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_BBRSTB BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_FUNC_EN (Offset 0x0002) */
#define BIT_FEN_WLPHYFUN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_EABM BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SKP_ALD BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_ACKF BIT(30)
#define BIT_SOP_ERCK BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_ESWR BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_AFEP BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_PWMM BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_EPWM BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_EECK BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PMC_RATIO_BIT2 BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_ANA_CLK_DIVISION_2 BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_ROP_ENXT BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_EXTL BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PMC_RATIO_BIT1 BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_CHIPOFF_EN BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SYM_OP_RING_12M BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_DIS_USB3_SUS_ALD BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_ROP_SWPR BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_DIS_HW_LPLDM BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SOP_ALD BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_OPT_SWRST_WLMCU BIT(19)
#define BIT_RDY_SYSPWR BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_EN_WLON BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_APDM_HPDN BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PMC_RATIO_BIT0 BIT(14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_HSUS BIT(14)
#define BIT_PDN_SEL BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_AFSM_PCIE_SUS_EN BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_AFSM_WLSUS_EN BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_APFM_SWLPS BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_APFM_SWLPS_EN BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_APFM_OFFMAC BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_HW_AUTO_CTRL_EXT_SWR BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_APFN_ONMAC BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_USE_INTERNAL_SWR_AND_LDO BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_CHIP_PDN_EN BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_BT_SUSEN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_RDY_MACDIS BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PD_RF BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_RING_CLK_12M_EN BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_CMD11_VOL_SWITCH (Offset 0x10250004) */
#define BIT_SHIFT_CMD11_SEQ_END_DELAY 4
#define BIT_MASK_CMD11_SEQ_END_DELAY 0xf
#define BIT_CMD11_SEQ_END_DELAY(x) \
(((x) & BIT_MASK_CMD11_SEQ_END_DELAY) << BIT_SHIFT_CMD11_SEQ_END_DELAY)
#define BITS_CMD11_SEQ_END_DELAY \
(BIT_MASK_CMD11_SEQ_END_DELAY << BIT_SHIFT_CMD11_SEQ_END_DELAY)
#define BIT_CLEAR_CMD11_SEQ_END_DELAY(x) ((x) & (~BITS_CMD11_SEQ_END_DELAY))
#define BIT_GET_CMD11_SEQ_END_DELAY(x) \
(((x) >> BIT_SHIFT_CMD11_SEQ_END_DELAY) & BIT_MASK_CMD11_SEQ_END_DELAY)
#define BIT_SET_CMD11_SEQ_END_DELAY(x, v) \
(BIT_CLEAR_CMD11_SEQ_END_DELAY(x) | BIT_CMD11_SEQ_END_DELAY(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_ENPDN BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PFM_WOWL BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_SW_WAKE BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PFM_LDKP BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_WL_HCI_ALD BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_ANA_CLK_DIVISION_2 BIT(1)
#define BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL 1
#define BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL 0x7
#define BIT_CMD11_SEQ_SAMPLE_INTERVAL(x) \
(((x) & BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL) \
<< BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL)
#define BITS_CMD11_SEQ_SAMPLE_INTERVAL \
(BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL \
<< BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL)
#define BIT_CLEAR_CMD11_SEQ_SAMPLE_INTERVAL(x) \
((x) & (~BITS_CMD11_SEQ_SAMPLE_INTERVAL))
#define BIT_GET_CMD11_SEQ_SAMPLE_INTERVAL(x) \
(((x) >> BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL) & \
BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL)
#define BIT_SET_CMD11_SEQ_SAMPLE_INTERVAL(x, v) \
(BIT_CLEAR_CMD11_SEQ_SAMPLE_INTERVAL(x) | \
BIT_CMD11_SEQ_SAMPLE_INTERVAL(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PFM_ALDN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_PW_CTRL (Offset 0x0004) */
#define BIT_PFM_LDALL BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_CMD11_VOL_SWITCH (Offset 0x10250004) */
#define BIT_CMD11_SEQ_EN BIT(0)
/* 2 REG_SDIO_CTRL (Offset 0x10250005) */
#define BIT_SIG_OUT_PH BIT(0)
/* 2 REG_SDIO_DRIVING (Offset 0x10250006) */
#define BIT_SHIFT_SDIO_DRV_TYPE_D 12
#define BIT_MASK_SDIO_DRV_TYPE_D 0xf
#define BIT_SDIO_DRV_TYPE_D(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_D) << BIT_SHIFT_SDIO_DRV_TYPE_D)
#define BITS_SDIO_DRV_TYPE_D \
(BIT_MASK_SDIO_DRV_TYPE_D << BIT_SHIFT_SDIO_DRV_TYPE_D)
#define BIT_CLEAR_SDIO_DRV_TYPE_D(x) ((x) & (~BITS_SDIO_DRV_TYPE_D))
#define BIT_GET_SDIO_DRV_TYPE_D(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_D) & BIT_MASK_SDIO_DRV_TYPE_D)
#define BIT_SET_SDIO_DRV_TYPE_D(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_D(x) | BIT_SDIO_DRV_TYPE_D(v))
#define BIT_SHIFT_SDIO_DRV_TYPE_C 8
#define BIT_MASK_SDIO_DRV_TYPE_C 0xf
#define BIT_SDIO_DRV_TYPE_C(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_C) << BIT_SHIFT_SDIO_DRV_TYPE_C)
#define BITS_SDIO_DRV_TYPE_C \
(BIT_MASK_SDIO_DRV_TYPE_C << BIT_SHIFT_SDIO_DRV_TYPE_C)
#define BIT_CLEAR_SDIO_DRV_TYPE_C(x) ((x) & (~BITS_SDIO_DRV_TYPE_C))
#define BIT_GET_SDIO_DRV_TYPE_C(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_C) & BIT_MASK_SDIO_DRV_TYPE_C)
#define BIT_SET_SDIO_DRV_TYPE_C(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_C(x) | BIT_SDIO_DRV_TYPE_C(v))
#define BIT_SHIFT_SDIO_DRV_TYPE_B 4
#define BIT_MASK_SDIO_DRV_TYPE_B 0xf
#define BIT_SDIO_DRV_TYPE_B(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_B) << BIT_SHIFT_SDIO_DRV_TYPE_B)
#define BITS_SDIO_DRV_TYPE_B \
(BIT_MASK_SDIO_DRV_TYPE_B << BIT_SHIFT_SDIO_DRV_TYPE_B)
#define BIT_CLEAR_SDIO_DRV_TYPE_B(x) ((x) & (~BITS_SDIO_DRV_TYPE_B))
#define BIT_GET_SDIO_DRV_TYPE_B(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_B) & BIT_MASK_SDIO_DRV_TYPE_B)
#define BIT_SET_SDIO_DRV_TYPE_B(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_B(x) | BIT_SDIO_DRV_TYPE_B(v))
#define BIT_SHIFT_SDIO_DRV_TYPE_A 0
#define BIT_MASK_SDIO_DRV_TYPE_A 0xf
#define BIT_SDIO_DRV_TYPE_A(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_A) << BIT_SHIFT_SDIO_DRV_TYPE_A)
#define BITS_SDIO_DRV_TYPE_A \
(BIT_MASK_SDIO_DRV_TYPE_A << BIT_SHIFT_SDIO_DRV_TYPE_A)
#define BIT_CLEAR_SDIO_DRV_TYPE_A(x) ((x) & (~BITS_SDIO_DRV_TYPE_A))
#define BIT_GET_SDIO_DRV_TYPE_A(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_A) & BIT_MASK_SDIO_DRV_TYPE_A)
#define BIT_SET_SDIO_DRV_TYPE_A(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_A(x) | BIT_SDIO_DRV_TYPE_A(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_CPHY_LDO_CL_EN BIT(19)
#define BIT_CPHY_LDO_OK BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_LDO_DUMMY BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_ANA_CLK_EN BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_DATA_CPU_CLK_EN BIT(15)
#define BIT_DATA_CPU_PWC BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_CPU_CLK_EN BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_SYMREG_CLK_EN BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_RING_CLK_EN BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_HCI_CLK_EN BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_SYS_CLK_EN BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_MAC_CLK_EN BIT(11)
#define BIT_SEC_CLK_EN BIT(10)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_CTRL_SPS_PWM_FREQ BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_PHY_SSC_RSTB BIT(9)
#define BIT_EXT_32K_EN BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_EXT32K_EN BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_DISABLE_OPEN_SPS_LDO BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_WL_CLK_TEST BIT(7)
#define BIT_OP_SPS_PWM_EN BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_SHIFT_MAC_CLK_SEL_V1 6
#define BIT_MASK_MAC_CLK_SEL_V1 0x3
#define BIT_MAC_CLK_SEL_V1(x) \
(((x) & BIT_MASK_MAC_CLK_SEL_V1) << BIT_SHIFT_MAC_CLK_SEL_V1)
#define BITS_MAC_CLK_SEL_V1 \
(BIT_MASK_MAC_CLK_SEL_V1 << BIT_SHIFT_MAC_CLK_SEL_V1)
#define BIT_CLEAR_MAC_CLK_SEL_V1(x) ((x) & (~BITS_MAC_CLK_SEL_V1))
#define BIT_GET_MAC_CLK_SEL_V1(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL_V1) & BIT_MASK_MAC_CLK_SEL_V1)
#define BIT_SET_MAC_CLK_SEL_V1(x, v) \
(BIT_CLEAR_MAC_CLK_SEL_V1(x) | BIT_MAC_CLK_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_LOADER_CLK_EN BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_POW_PC_LDO3 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_MACSLP BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_POW_PC_LDO2 BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_WAKEPAD_EN BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_ENB_LDO_DIODE_L BIT(3)
#define BIT_POW_PC_LDO1 BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_ROMD16V_EN BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_AFE_BGEN_PCIE_OP BIT(2)
#define BIT_POW_PC_LDO0 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_CKANA8M_EN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_CKANA12M_EN BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_ANA8M_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_CNTD16V_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_MONITOR (Offset 0x10250008) */
#define BIT_SHIFT_SDIO_INT_START 0
#define BIT_MASK_SDIO_INT_START 0xffffffffL
#define BIT_SDIO_INT_START(x) \
(((x) & BIT_MASK_SDIO_INT_START) << BIT_SHIFT_SDIO_INT_START)
#define BITS_SDIO_INT_START \
(BIT_MASK_SDIO_INT_START << BIT_SHIFT_SDIO_INT_START)
#define BIT_CLEAR_SDIO_INT_START(x) ((x) & (~BITS_SDIO_INT_START))
#define BIT_GET_SDIO_INT_START(x) \
(((x) >> BIT_SHIFT_SDIO_INT_START) & BIT_MASK_SDIO_INT_START)
#define BIT_SET_SDIO_INT_START(x, v) \
(BIT_CLEAR_SDIO_INT_START(x) | BIT_SDIO_INT_START(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CLK_CTRL (Offset 0x0008) */
#define BIT_POW_POWER_CUT BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_EEPROM_CTRL (Offset 0x000A) */
#define BIT_SHIFT_VPDIDX 8
#define BIT_MASK_VPDIDX 0xff
#define BIT_VPDIDX(x) (((x) & BIT_MASK_VPDIDX) << BIT_SHIFT_VPDIDX)
#define BITS_VPDIDX (BIT_MASK_VPDIDX << BIT_SHIFT_VPDIDX)
#define BIT_CLEAR_VPDIDX(x) ((x) & (~BITS_VPDIDX))
#define BIT_GET_VPDIDX(x) (((x) >> BIT_SHIFT_VPDIDX) & BIT_MASK_VPDIDX)
#define BIT_SET_VPDIDX(x, v) (BIT_CLEAR_VPDIDX(x) | BIT_VPDIDX(v))
#define BIT_SHIFT_EEM1_0 6
#define BIT_MASK_EEM1_0 0x3
#define BIT_EEM1_0(x) (((x) & BIT_MASK_EEM1_0) << BIT_SHIFT_EEM1_0)
#define BITS_EEM1_0 (BIT_MASK_EEM1_0 << BIT_SHIFT_EEM1_0)
#define BIT_CLEAR_EEM1_0(x) ((x) & (~BITS_EEM1_0))
#define BIT_GET_EEM1_0(x) (((x) >> BIT_SHIFT_EEM1_0) & BIT_MASK_EEM1_0)
#define BIT_SET_EEM1_0(x, v) (BIT_CLEAR_EEM1_0(x) | BIT_EEM1_0(v))
#define BIT_AUTOLOAD_SUS BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_EEPROM_CTRL (Offset 0x000A) */
#define BIT_EERPOMSEL BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_EEPROM_CTRL (Offset 0x000A) */
#define BIT_EEPROMSEL BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_EEPROM_CTRL (Offset 0x000A) */
#define BIT_EECS_V1 BIT(3)
#define BIT_EESK_V1 BIT(2)
#define BIT_EEDI_V1 BIT(1)
#define BIT_EEDO_V1 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_MONITOR_2 (Offset 0x1025000C) */
#define BIT_CMD53_WT_EN BIT(23)
#define BIT_SHIFT_SDIO_CLK_MONITOR 21
#define BIT_MASK_SDIO_CLK_MONITOR 0x3
#define BIT_SDIO_CLK_MONITOR(x) \
(((x) & BIT_MASK_SDIO_CLK_MONITOR) << BIT_SHIFT_SDIO_CLK_MONITOR)
#define BITS_SDIO_CLK_MONITOR \
(BIT_MASK_SDIO_CLK_MONITOR << BIT_SHIFT_SDIO_CLK_MONITOR)
#define BIT_CLEAR_SDIO_CLK_MONITOR(x) ((x) & (~BITS_SDIO_CLK_MONITOR))
#define BIT_GET_SDIO_CLK_MONITOR(x) \
(((x) >> BIT_SHIFT_SDIO_CLK_MONITOR) & BIT_MASK_SDIO_CLK_MONITOR)
#define BIT_SET_SDIO_CLK_MONITOR(x, v) \
(BIT_CLEAR_SDIO_CLK_MONITOR(x) | BIT_SDIO_CLK_MONITOR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_EE_VPD (Offset 0x000C) */
#define BIT_SHIFT_VPD_DATA 0
#define BIT_MASK_VPD_DATA 0xffffffffL
#define BIT_VPD_DATA(x) (((x) & BIT_MASK_VPD_DATA) << BIT_SHIFT_VPD_DATA)
#define BITS_VPD_DATA (BIT_MASK_VPD_DATA << BIT_SHIFT_VPD_DATA)
#define BIT_CLEAR_VPD_DATA(x) ((x) & (~BITS_VPD_DATA))
#define BIT_GET_VPD_DATA(x) (((x) >> BIT_SHIFT_VPD_DATA) & BIT_MASK_VPD_DATA)
#define BIT_SET_VPD_DATA(x, v) (BIT_CLEAR_VPD_DATA(x) | BIT_VPD_DATA(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_MONITOR_2 (Offset 0x1025000C) */
#define BIT_SHIFT_SDIO_CLK_CNT 0
#define BIT_MASK_SDIO_CLK_CNT 0x1fffff
#define BIT_SDIO_CLK_CNT(x) \
(((x) & BIT_MASK_SDIO_CLK_CNT) << BIT_SHIFT_SDIO_CLK_CNT)
#define BITS_SDIO_CLK_CNT (BIT_MASK_SDIO_CLK_CNT << BIT_SHIFT_SDIO_CLK_CNT)
#define BIT_CLEAR_SDIO_CLK_CNT(x) ((x) & (~BITS_SDIO_CLK_CNT))
#define BIT_GET_SDIO_CLK_CNT(x) \
(((x) >> BIT_SHIFT_SDIO_CLK_CNT) & BIT_MASK_SDIO_CLK_CNT)
#define BIT_SET_SDIO_CLK_CNT(x, v) \
(BIT_CLEAR_SDIO_CLK_CNT(x) | BIT_SDIO_CLK_CNT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_EE_VPD (Offset 0x000C) */
#define BIT_SHIFT_VDP_DATA 0
#define BIT_MASK_VDP_DATA 0xffffffffL
#define BIT_VDP_DATA(x) (((x) & BIT_MASK_VDP_DATA) << BIT_SHIFT_VDP_DATA)
#define BITS_VDP_DATA (BIT_MASK_VDP_DATA << BIT_SHIFT_VDP_DATA)
#define BIT_CLEAR_VDP_DATA(x) ((x) & (~BITS_VDP_DATA))
#define BIT_GET_VDP_DATA(x) (((x) >> BIT_SHIFT_VDP_DATA) & BIT_MASK_VDP_DATA)
#define BIT_SET_VDP_DATA(x, v) (BIT_CLEAR_VDP_DATA(x) | BIT_VDP_DATA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SW18_C2_BIT0 BIT(31)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_C2_L_BIT0 BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_R1_L1_V1 30
#define BIT_MASK_R1_L1_V1 0x3
#define BIT_R1_L1_V1(x) (((x) & BIT_MASK_R1_L1_V1) << BIT_SHIFT_R1_L1_V1)
#define BITS_R1_L1_V1 (BIT_MASK_R1_L1_V1 << BIT_SHIFT_R1_L1_V1)
#define BIT_CLEAR_R1_L1_V1(x) ((x) & (~BITS_R1_L1_V1))
#define BIT_GET_R1_L1_V1(x) (((x) >> BIT_SHIFT_R1_L1_V1) & BIT_MASK_R1_L1_V1)
#define BIT_SET_R1_L1_V1(x, v) (BIT_CLEAR_R1_L1_V1(x) | BIT_R1_L1_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_SW18_C1 29
#define BIT_MASK_SW18_C1 0x3
#define BIT_SW18_C1(x) (((x) & BIT_MASK_SW18_C1) << BIT_SHIFT_SW18_C1)
#define BITS_SW18_C1 (BIT_MASK_SW18_C1 << BIT_SHIFT_SW18_C1)
#define BIT_CLEAR_SW18_C1(x) ((x) & (~BITS_SW18_C1))
#define BIT_GET_SW18_C1(x) (((x) >> BIT_SHIFT_SW18_C1) & BIT_MASK_SW18_C1)
#define BIT_SET_SW18_C1(x, v) (BIT_CLEAR_SW18_C1(x) | BIT_SW18_C1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_C1_L 29
#define BIT_MASK_C1_L 0x3
#define BIT_C1_L(x) (((x) & BIT_MASK_C1_L) << BIT_SHIFT_C1_L)
#define BITS_C1_L (BIT_MASK_C1_L << BIT_SHIFT_C1_L)
#define BIT_CLEAR_C1_L(x) ((x) & (~BITS_C1_L))
#define BIT_GET_C1_L(x) (((x) >> BIT_SHIFT_C1_L) & BIT_MASK_C1_L)
#define BIT_SET_C1_L(x, v) (BIT_CLEAR_C1_L(x) | BIT_C1_L(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_C3_L1_V1 28
#define BIT_MASK_C3_L1_V1 0x3
#define BIT_C3_L1_V1(x) (((x) & BIT_MASK_C3_L1_V1) << BIT_SHIFT_C3_L1_V1)
#define BITS_C3_L1_V1 (BIT_MASK_C3_L1_V1 << BIT_SHIFT_C3_L1_V1)
#define BIT_CLEAR_C3_L1_V1(x) ((x) & (~BITS_C3_L1_V1))
#define BIT_GET_C3_L1_V1(x) (((x) >> BIT_SHIFT_C3_L1_V1) & BIT_MASK_C3_L1_V1)
#define BIT_SET_C3_L1_V1(x, v) (BIT_CLEAR_C3_L1_V1(x) | BIT_C3_L1_V1(v))
#define BIT_SHIFT_C2_L1_V1 26
#define BIT_MASK_C2_L1_V1 0x3
#define BIT_C2_L1_V1(x) (((x) & BIT_MASK_C2_L1_V1) << BIT_SHIFT_C2_L1_V1)
#define BITS_C2_L1_V1 (BIT_MASK_C2_L1_V1 << BIT_SHIFT_C2_L1_V1)
#define BIT_CLEAR_C2_L1_V1(x) ((x) & (~BITS_C2_L1_V1))
#define BIT_GET_C2_L1_V1(x) (((x) >> BIT_SHIFT_C2_L1_V1) & BIT_MASK_C2_L1_V1)
#define BIT_SET_C2_L1_V1(x, v) (BIT_CLEAR_C2_L1_V1(x) | BIT_C2_L1_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_REG_FREQ_L 25
#define BIT_MASK_REG_FREQ_L 0x7
#define BIT_REG_FREQ_L(x) (((x) & BIT_MASK_REG_FREQ_L) << BIT_SHIFT_REG_FREQ_L)
#define BITS_REG_FREQ_L (BIT_MASK_REG_FREQ_L << BIT_SHIFT_REG_FREQ_L)
#define BIT_CLEAR_REG_FREQ_L(x) ((x) & (~BITS_REG_FREQ_L))
#define BIT_GET_REG_FREQ_L(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L) & BIT_MASK_REG_FREQ_L)
#define BIT_SET_REG_FREQ_L(x, v) (BIT_CLEAR_REG_FREQ_L(x) | BIT_REG_FREQ_L(v))
#define BIT_REG_EN_DUTY BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_C1_L1_V1 24
#define BIT_MASK_C1_L1_V1 0x3
#define BIT_C1_L1_V1(x) (((x) & BIT_MASK_C1_L1_V1) << BIT_SHIFT_C1_L1_V1)
#define BITS_C1_L1_V1 (BIT_MASK_C1_L1_V1 << BIT_SHIFT_C1_L1_V1)
#define BIT_CLEAR_C1_L1_V1(x) ((x) & (~BITS_C1_L1_V1))
#define BIT_GET_C1_L1_V1(x) (((x) >> BIT_SHIFT_C1_L1_V1) & BIT_MASK_C1_L1_V1)
#define BIT_SET_C1_L1_V1(x, v) (BIT_CLEAR_C1_L1_V1(x) | BIT_C1_L1_V1(v))
#define BIT_REG_TYPE_L_V3 BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_REG_MODE 22
#define BIT_MASK_REG_MODE 0x3
#define BIT_REG_MODE(x) (((x) & BIT_MASK_REG_MODE) << BIT_SHIFT_REG_MODE)
#define BITS_REG_MODE (BIT_MASK_REG_MODE << BIT_SHIFT_REG_MODE)
#define BIT_CLEAR_REG_MODE(x) ((x) & (~BITS_REG_MODE))
#define BIT_GET_REG_MODE(x) (((x) >> BIT_SHIFT_REG_MODE) & BIT_MASK_REG_MODE)
#define BIT_SET_REG_MODE(x, v) (BIT_CLEAR_REG_MODE(x) | BIT_REG_MODE(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_FPWM_L1_V1 BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_REG_EN_SP BIT(21)
#define BIT_REG_AUTO_L BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SW18_SELD_BIT0 BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_V15ADJ_L1 19
#define BIT_MASK_V15ADJ_L1 0x7
#define BIT_V15ADJ_L1(x) (((x) & BIT_MASK_V15ADJ_L1) << BIT_SHIFT_V15ADJ_L1)
#define BITS_V15ADJ_L1 (BIT_MASK_V15ADJ_L1 << BIT_SHIFT_V15ADJ_L1)
#define BIT_CLEAR_V15ADJ_L1(x) ((x) & (~BITS_V15ADJ_L1))
#define BIT_GET_V15ADJ_L1(x) (((x) >> BIT_SHIFT_V15ADJ_L1) & BIT_MASK_V15ADJ_L1)
#define BIT_SET_V15ADJ_L1(x, v) (BIT_CLEAR_V15ADJ_L1(x) | BIT_V15ADJ_L1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SW18_POWOCP BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_IN_L1 16
#define BIT_MASK_IN_L1 0x7
#define BIT_IN_L1(x) (((x) & BIT_MASK_IN_L1) << BIT_SHIFT_IN_L1)
#define BITS_IN_L1 (BIT_MASK_IN_L1 << BIT_SHIFT_IN_L1)
#define BIT_CLEAR_IN_L1(x) ((x) & (~BITS_IN_L1))
#define BIT_GET_IN_L1(x) (((x) >> BIT_SHIFT_IN_L1) & BIT_MASK_IN_L1)
#define BIT_SET_IN_L1(x, v) (BIT_CLEAR_IN_L1(x) | BIT_IN_L1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_SW18_OCP 15
#define BIT_MASK_SW18_OCP 0x7
#define BIT_SW18_OCP(x) (((x) & BIT_MASK_SW18_OCP) << BIT_SHIFT_SW18_OCP)
#define BITS_SW18_OCP (BIT_MASK_SW18_OCP << BIT_SHIFT_SW18_OCP)
#define BIT_CLEAR_SW18_OCP(x) ((x) & (~BITS_SW18_OCP))
#define BIT_GET_SW18_OCP(x) (((x) >> BIT_SHIFT_SW18_OCP) & BIT_MASK_SW18_OCP)
#define BIT_SET_SW18_OCP(x, v) (BIT_CLEAR_SW18_OCP(x) | BIT_SW18_OCP(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_OCP_L1 15
#define BIT_MASK_OCP_L1 0x7
#define BIT_OCP_L1(x) (((x) & BIT_MASK_OCP_L1) << BIT_SHIFT_OCP_L1)
#define BITS_OCP_L1 (BIT_MASK_OCP_L1 << BIT_SHIFT_OCP_L1)
#define BIT_CLEAR_OCP_L1(x) ((x) & (~BITS_OCP_L1))
#define BIT_GET_OCP_L1(x) (((x) >> BIT_SHIFT_OCP_L1) & BIT_MASK_OCP_L1)
#define BIT_SET_OCP_L1(x, v) (BIT_CLEAR_OCP_L1(x) | BIT_OCP_L1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_STD_L1 14
#define BIT_MASK_STD_L1 0x3
#define BIT_STD_L1(x) (((x) & BIT_MASK_STD_L1) << BIT_SHIFT_STD_L1)
#define BITS_STD_L1 (BIT_MASK_STD_L1 << BIT_SHIFT_STD_L1)
#define BIT_CLEAR_STD_L1(x) ((x) & (~BITS_STD_L1))
#define BIT_GET_STD_L1(x) (((x) >> BIT_SHIFT_STD_L1) & BIT_MASK_STD_L1)
#define BIT_SET_STD_L1(x, v) (BIT_CLEAR_STD_L1(x) | BIT_STD_L1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_CF_L_BIT0_TO_1 13
#define BIT_MASK_CF_L_BIT0_TO_1 0x3
#define BIT_CF_L_BIT0_TO_1(x) \
(((x) & BIT_MASK_CF_L_BIT0_TO_1) << BIT_SHIFT_CF_L_BIT0_TO_1)
#define BITS_CF_L_BIT0_TO_1 \
(BIT_MASK_CF_L_BIT0_TO_1 << BIT_SHIFT_CF_L_BIT0_TO_1)
#define BIT_CLEAR_CF_L_BIT0_TO_1(x) ((x) & (~BITS_CF_L_BIT0_TO_1))
#define BIT_GET_CF_L_BIT0_TO_1(x) \
(((x) >> BIT_SHIFT_CF_L_BIT0_TO_1) & BIT_MASK_CF_L_BIT0_TO_1)
#define BIT_SET_CF_L_BIT0_TO_1(x, v) \
(BIT_CLEAR_CF_L_BIT0_TO_1(x) | BIT_CF_L_BIT0_TO_1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_CF_L 13
#define BIT_MASK_CF_L 0x3
#define BIT_CF_L(x) (((x) & BIT_MASK_CF_L) << BIT_SHIFT_CF_L)
#define BITS_CF_L (BIT_MASK_CF_L << BIT_SHIFT_CF_L)
#define BIT_CLEAR_CF_L(x) ((x) & (~BITS_CF_L))
#define BIT_GET_CF_L(x) (((x) >> BIT_SHIFT_CF_L) & BIT_MASK_CF_L)
#define BIT_SET_CF_L(x, v) (BIT_CLEAR_CF_L(x) | BIT_CF_L(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SW18_FPWM BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SPS_FPWM BIT(11)
#define BIT_WL_CTRL_SPS_PWMFREQ BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SHIFT_VOL_L1 10
#define BIT_MASK_VOL_L1 0xf
#define BIT_VOL_L1(x) (((x) & BIT_MASK_VOL_L1) << BIT_SHIFT_VOL_L1)
#define BITS_VOL_L1 (BIT_MASK_VOL_L1 << BIT_SHIFT_VOL_L1)
#define BIT_CLEAR_VOL_L1(x) ((x) & (~BITS_VOL_L1))
#define BIT_GET_VOL_L1(x) (((x) >> BIT_SHIFT_VOL_L1) & BIT_MASK_VOL_L1)
#define BIT_SET_VOL_L1(x, v) (BIT_CLEAR_VOL_L1(x) | BIT_VOL_L1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SW18_SWEN BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SPS_SWEN BIT(9)
#define BIT_HALF_L BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SW18_LDEN BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_SPS_LDEN BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_MAC_ID_EN BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_WL_CTRL_XTAL_CADJ BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_LDO11_EN BIT(6)
#define BIT_AFE_P3_PC BIT(5)
#define BIT_AFE_P2_PC BIT(4)
#define BIT_AFE_P1_PC BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_AFE_MBEN_PCIE_OPT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_AFE_P0_PC BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_AFE_MBEN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL1 (Offset 0x0010) */
#define BIT_AFE_BGEN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_POW_ZCD_L BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_CRCERR_MSK BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_IO_READY_SIGNAL_ERR_MSK BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_ENABLE_ZCDOUT_L BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_AUTOZCD_L BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_HSISR3_IND_MSK BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_TX_CRC__MSK BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_HSISR2_IND_MSK BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_REG_DELAY 28
#define BIT_MASK_REG_DELAY 0x3
#define BIT_REG_DELAY(x) (((x) & BIT_MASK_REG_DELAY) << BIT_SHIFT_REG_DELAY)
#define BITS_REG_DELAY (BIT_MASK_REG_DELAY << BIT_SHIFT_REG_DELAY)
#define BIT_CLEAR_REG_DELAY(x) ((x) & (~BITS_REG_DELAY))
#define BIT_GET_REG_DELAY(x) (((x) >> BIT_SHIFT_REG_DELAY) & BIT_MASK_REG_DELAY)
#define BIT_SET_REG_DELAY(x, v) (BIT_CLEAR_REG_DELAY(x) | BIT_REG_DELAY(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_HEISR_IND_MSK BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_CTWEND_MSK BIT(27)
#define BIT_SDIO_ATIMEND_E_MSK BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIIO_ATIMEND_MSK BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_ATIMEND_MSK BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_V15ADJ 24
#define BIT_MASK_SW18_V15ADJ 0x7
#define BIT_SW18_V15ADJ(x) \
(((x) & BIT_MASK_SW18_V15ADJ) << BIT_SHIFT_SW18_V15ADJ)
#define BITS_SW18_V15ADJ (BIT_MASK_SW18_V15ADJ << BIT_SHIFT_SW18_V15ADJ)
#define BIT_CLEAR_SW18_V15ADJ(x) ((x) & (~BITS_SW18_V15ADJ))
#define BIT_GET_SW18_V15ADJ(x) \
(((x) >> BIT_SHIFT_SW18_V15ADJ) & BIT_MASK_SW18_V15ADJ)
#define BIT_SET_SW18_V15ADJ(x, v) \
(BIT_CLEAR_SW18_V15ADJ(x) | BIT_SW18_V15ADJ(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_V15ADJ_L1_V1 24
#define BIT_MASK_V15ADJ_L1_V1 0x7
#define BIT_V15ADJ_L1_V1(x) \
(((x) & BIT_MASK_V15ADJ_L1_V1) << BIT_SHIFT_V15ADJ_L1_V1)
#define BITS_V15ADJ_L1_V1 (BIT_MASK_V15ADJ_L1_V1 << BIT_SHIFT_V15ADJ_L1_V1)
#define BIT_CLEAR_V15ADJ_L1_V1(x) ((x) & (~BITS_V15ADJ_L1_V1))
#define BIT_GET_V15ADJ_L1_V1(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_V1) & BIT_MASK_V15ADJ_L1_V1)
#define BIT_SET_V15ADJ_L1_V1(x, v) \
(BIT_CLEAR_V15ADJ_L1_V1(x) | BIT_V15ADJ_L1_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_OCPINT_MSK BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_OCPSL BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_PSTIMEOUT_MSK BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_REG_LDOF_L_V1 BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_GTINT4_MSK BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_PARSW_DUMMY BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_GTINT3_MSK BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_CLAMP_MAX_DUTY BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_VOL 20
#define BIT_MASK_SW18_VOL 0xf
#define BIT_SW18_VOL(x) (((x) & BIT_MASK_SW18_VOL) << BIT_SHIFT_SW18_VOL)
#define BITS_SW18_VOL (BIT_MASK_SW18_VOL << BIT_SHIFT_SW18_VOL)
#define BIT_CLEAR_SW18_VOL(x) ((x) & (~BITS_SW18_VOL))
#define BIT_GET_SW18_VOL(x) (((x) >> BIT_SHIFT_SW18_VOL) & BIT_MASK_SW18_VOL)
#define BIT_SET_SW18_VOL(x, v) (BIT_CLEAR_SW18_VOL(x) | BIT_SW18_VOL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_VOL_L1_V1 20
#define BIT_MASK_VOL_L1_V1 0xf
#define BIT_VOL_L1_V1(x) (((x) & BIT_MASK_VOL_L1_V1) << BIT_SHIFT_VOL_L1_V1)
#define BITS_VOL_L1_V1 (BIT_MASK_VOL_L1_V1 << BIT_SHIFT_VOL_L1_V1)
#define BIT_CLEAR_VOL_L1_V1(x) ((x) & (~BITS_VOL_L1_V1))
#define BIT_GET_VOL_L1_V1(x) (((x) >> BIT_SHIFT_VOL_L1_V1) & BIT_MASK_VOL_L1_V1)
#define BIT_SET_VOL_L1_V1(x, v) (BIT_CLEAR_VOL_L1_V1(x) | BIT_VOL_L1_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_HSISR_IND_MSK BIT(20)
#define BIT_SDIO_CPWM2_MSK BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_TBOX_L1_V1 19
#define BIT_MASK_TBOX_L1_V1 0x3
#define BIT_TBOX_L1_V1(x) (((x) & BIT_MASK_TBOX_L1_V1) << BIT_SHIFT_TBOX_L1_V1)
#define BITS_TBOX_L1_V1 (BIT_MASK_TBOX_L1_V1 << BIT_SHIFT_TBOX_L1_V1)
#define BIT_CLEAR_TBOX_L1_V1(x) ((x) & (~BITS_TBOX_L1_V1))
#define BIT_GET_TBOX_L1_V1(x) \
(((x) >> BIT_SHIFT_TBOX_L1_V1) & BIT_MASK_TBOX_L1_V1)
#define BIT_SET_TBOX_L1_V1(x, v) (BIT_CLEAR_TBOX_L1_V1(x) | BIT_TBOX_L1_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_CPWM1_MSK BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_IN 17
#define BIT_MASK_SW18_IN 0x7
#define BIT_SW18_IN(x) (((x) & BIT_MASK_SW18_IN) << BIT_SHIFT_SW18_IN)
#define BITS_SW18_IN (BIT_MASK_SW18_IN << BIT_SHIFT_SW18_IN)
#define BIT_CLEAR_SW18_IN(x) ((x) & (~BITS_SW18_IN))
#define BIT_GET_SW18_IN(x) (((x) >> BIT_SHIFT_SW18_IN) & BIT_MASK_SW18_IN)
#define BIT_SET_SW18_IN(x, v) (BIT_CLEAR_SW18_IN(x) | BIT_SW18_IN(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_IN_L1_V1 17
#define BIT_MASK_IN_L1_V1 0x7
#define BIT_IN_L1_V1(x) (((x) & BIT_MASK_IN_L1_V1) << BIT_SHIFT_IN_L1_V1)
#define BITS_IN_L1_V1 (BIT_MASK_IN_L1_V1 << BIT_SHIFT_IN_L1_V1)
#define BIT_CLEAR_IN_L1_V1(x) ((x) & (~BITS_IN_L1_V1))
#define BIT_GET_IN_L1_V1(x) (((x) >> BIT_SHIFT_IN_L1_V1) & BIT_MASK_IN_L1_V1)
#define BIT_SET_IN_L1_V1(x, v) (BIT_CLEAR_IN_L1_V1(x) | BIT_IN_L1_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_C2HCMD_INT_MSK BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_REG_DELAY_V3 17
#define BIT_MASK_REG_DELAY_V3 0x3
#define BIT_REG_DELAY_V3(x) \
(((x) & BIT_MASK_REG_DELAY_V3) << BIT_SHIFT_REG_DELAY_V3)
#define BITS_REG_DELAY_V3 (BIT_MASK_REG_DELAY_V3 << BIT_SHIFT_REG_DELAY_V3)
#define BIT_CLEAR_REG_DELAY_V3(x) ((x) & (~BITS_REG_DELAY_V3))
#define BIT_GET_REG_DELAY_V3(x) \
(((x) >> BIT_SHIFT_REG_DELAY_V3) & BIT_MASK_REG_DELAY_V3)
#define BIT_SET_REG_DELAY_V3(x, v) \
(BIT_CLEAR_REG_DELAY_V3(x) | BIT_REG_DELAY_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_BCNERLY_INT_MSK BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_REG_CLAMP_D_L_V2 BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_TBOX 15
#define BIT_MASK_SW18_TBOX 0x3
#define BIT_SW18_TBOX(x) (((x) & BIT_MASK_SW18_TBOX) << BIT_SHIFT_SW18_TBOX)
#define BITS_SW18_TBOX (BIT_MASK_SW18_TBOX << BIT_SHIFT_SW18_TBOX)
#define BIT_CLEAR_SW18_TBOX(x) ((x) & (~BITS_SW18_TBOX))
#define BIT_GET_SW18_TBOX(x) (((x) >> BIT_SHIFT_SW18_TBOX) & BIT_MASK_SW18_TBOX)
#define BIT_SET_SW18_TBOX(x, v) (BIT_CLEAR_SW18_TBOX(x) | BIT_SW18_TBOX(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_REG_BYPASS_L_V3 BIT(15)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_TBOX_L1 15
#define BIT_MASK_TBOX_L1 0x3
#define BIT_TBOX_L1(x) (((x) & BIT_MASK_TBOX_L1) << BIT_SHIFT_TBOX_L1)
#define BITS_TBOX_L1 (BIT_MASK_TBOX_L1 << BIT_SHIFT_TBOX_L1)
#define BIT_CLEAR_TBOX_L1(x) ((x) & (~BITS_TBOX_L1))
#define BIT_GET_TBOX_L1(x) (((x) >> BIT_SHIFT_TBOX_L1) & BIT_MASK_TBOX_L1)
#define BIT_SET_TBOX_L1(x, v) (BIT_CLEAR_TBOX_L1(x) | BIT_TBOX_L1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_ENABLE_ZCDOUT_L_V3 BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SW18_SEL BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_POW_ZCD_L_V3 BIT(13)
#define BIT_AREN_L1_V1 BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_STD 11
#define BIT_MASK_SW18_STD 0x3
#define BIT_SW18_STD(x) (((x) & BIT_MASK_SW18_STD) << BIT_SHIFT_SW18_STD)
#define BITS_SW18_STD (BIT_MASK_SW18_STD << BIT_SHIFT_SW18_STD)
#define BIT_CLEAR_SW18_STD(x) ((x) & (~BITS_SW18_STD))
#define BIT_GET_SW18_STD(x) (((x) >> BIT_SHIFT_SW18_STD) & BIT_MASK_SW18_STD)
#define BIT_SET_SW18_STD(x, v) (BIT_CLEAR_SW18_STD(x) | BIT_SW18_STD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SW18_SD BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SW18_AREN BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_OCP_V3 9
#define BIT_MASK_OCP_V3 0x7
#define BIT_OCP_V3(x) (((x) & BIT_MASK_OCP_V3) << BIT_SHIFT_OCP_V3)
#define BITS_OCP_V3 (BIT_MASK_OCP_V3 << BIT_SHIFT_OCP_V3)
#define BIT_CLEAR_OCP_V3(x) ((x) & (~BITS_OCP_V3))
#define BIT_GET_OCP_V3(x) (((x) >> BIT_SHIFT_OCP_V3) & BIT_MASK_OCP_V3)
#define BIT_SET_OCP_V3(x, v) (BIT_CLEAR_OCP_V3(x) | BIT_OCP_V3(v))
#define BIT_POWOCP_V3 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_R3 7
#define BIT_MASK_SW18_R3 0x3
#define BIT_SW18_R3(x) (((x) & BIT_MASK_SW18_R3) << BIT_SHIFT_SW18_R3)
#define BITS_SW18_R3 (BIT_MASK_SW18_R3 << BIT_SHIFT_SW18_R3)
#define BIT_CLEAR_SW18_R3(x) ((x) & (~BITS_SW18_R3))
#define BIT_GET_SW18_R3(x) (((x) >> BIT_SHIFT_SW18_R3) & BIT_MASK_SW18_R3)
#define BIT_SET_SW18_R3(x, v) (BIT_CLEAR_SW18_R3(x) | BIT_SW18_R3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_TXBCNERR_MSK BIT(7)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_R3_L 7
#define BIT_MASK_R3_L 0x3
#define BIT_R3_L(x) (((x) & BIT_MASK_R3_L) << BIT_SHIFT_R3_L)
#define BITS_R3_L (BIT_MASK_R3_L << BIT_SHIFT_R3_L)
#define BIT_CLEAR_R3_L(x) ((x) & (~BITS_R3_L))
#define BIT_GET_R3_L(x) (((x) >> BIT_SHIFT_R3_L) & BIT_MASK_R3_L)
#define BIT_SET_R3_L(x, v) (BIT_CLEAR_R3_L(x) | BIT_R3_L(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_TXBCNOK_MSK BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_CF_L_V3 6
#define BIT_MASK_CF_L_V3 0x3
#define BIT_CF_L_V3(x) (((x) & BIT_MASK_CF_L_V3) << BIT_SHIFT_CF_L_V3)
#define BITS_CF_L_V3 (BIT_MASK_CF_L_V3 << BIT_SHIFT_CF_L_V3)
#define BIT_CLEAR_CF_L_V3(x) ((x) & (~BITS_CF_L_V3))
#define BIT_GET_CF_L_V3(x) (((x) >> BIT_SHIFT_CF_L_V3) & BIT_MASK_CF_L_V3)
#define BIT_SET_CF_L_V3(x, v) (BIT_CLEAR_CF_L_V3(x) | BIT_CF_L_V3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_R2 5
#define BIT_MASK_SW18_R2 0x3
#define BIT_SW18_R2(x) (((x) & BIT_MASK_SW18_R2) << BIT_SHIFT_SW18_R2)
#define BITS_SW18_R2 (BIT_MASK_SW18_R2 << BIT_SHIFT_SW18_R2)
#define BIT_CLEAR_SW18_R2(x) ((x) & (~BITS_SW18_R2))
#define BIT_GET_SW18_R2(x) (((x) >> BIT_SHIFT_SW18_R2) & BIT_MASK_SW18_R2)
#define BIT_SET_SW18_R2(x, v) (BIT_CLEAR_SW18_R2(x) | BIT_SW18_R2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_RXFOVW_MSK BIT(5)
#define BIT_SDIO_TXFOVW_MSK BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_CFC_L_BIT0_TO_1_V1 4
#define BIT_MASK_CFC_L_BIT0_TO_1_V1 0x3
#define BIT_CFC_L_BIT0_TO_1_V1(x) \
(((x) & BIT_MASK_CFC_L_BIT0_TO_1_V1) << BIT_SHIFT_CFC_L_BIT0_TO_1_V1)
#define BITS_CFC_L_BIT0_TO_1_V1 \
(BIT_MASK_CFC_L_BIT0_TO_1_V1 << BIT_SHIFT_CFC_L_BIT0_TO_1_V1)
#define BIT_CLEAR_CFC_L_BIT0_TO_1_V1(x) ((x) & (~BITS_CFC_L_BIT0_TO_1_V1))
#define BIT_GET_CFC_L_BIT0_TO_1_V1(x) \
(((x) >> BIT_SHIFT_CFC_L_BIT0_TO_1_V1) & BIT_MASK_CFC_L_BIT0_TO_1_V1)
#define BIT_SET_CFC_L_BIT0_TO_1_V1(x, v) \
(BIT_CLEAR_CFC_L_BIT0_TO_1_V1(x) | BIT_CFC_L_BIT0_TO_1_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_R1 3
#define BIT_MASK_SW18_R1 0x3
#define BIT_SW18_R1(x) (((x) & BIT_MASK_SW18_R1) << BIT_SHIFT_SW18_R1)
#define BITS_SW18_R1 (BIT_MASK_SW18_R1 << BIT_SHIFT_SW18_R1)
#define BIT_CLEAR_SW18_R1(x) ((x) & (~BITS_SW18_R1))
#define BIT_GET_SW18_R1(x) (((x) >> BIT_SHIFT_SW18_R1) & BIT_MASK_SW18_R1)
#define BIT_SET_SW18_R1(x, v) (BIT_CLEAR_SW18_R1(x) | BIT_SW18_R1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_RXERR_MSK BIT(3)
#define BIT_SDIO_TXERR_MSK BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_R3_L1_V1 2
#define BIT_MASK_R3_L1_V1 0x3
#define BIT_R3_L1_V1(x) (((x) & BIT_MASK_R3_L1_V1) << BIT_SHIFT_R3_L1_V1)
#define BITS_R3_L1_V1 (BIT_MASK_R3_L1_V1 << BIT_SHIFT_R3_L1_V1)
#define BIT_CLEAR_R3_L1_V1(x) ((x) & (~BITS_R3_L1_V1))
#define BIT_GET_R3_L1_V1(x) (((x) >> BIT_SHIFT_R3_L1_V1) & BIT_MASK_R3_L1_V1)
#define BIT_SET_R3_L1_V1(x, v) (BIT_CLEAR_R3_L1_V1(x) | BIT_R3_L1_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_SW18_C3 1
#define BIT_MASK_SW18_C3 0x3
#define BIT_SW18_C3(x) (((x) & BIT_MASK_SW18_C3) << BIT_SHIFT_SW18_C3)
#define BITS_SW18_C3 (BIT_MASK_SW18_C3 << BIT_SHIFT_SW18_C3)
#define BIT_CLEAR_SW18_C3(x) ((x) & (~BITS_SW18_C3))
#define BIT_GET_SW18_C3(x) (((x) >> BIT_SHIFT_SW18_C3) & BIT_MASK_SW18_C3)
#define BIT_SET_SW18_C3(x, v) (BIT_CLEAR_SW18_C3(x) | BIT_SW18_C3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_SDIO_AVAL_MSK BIT(1)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_C3_L_C3 1
#define BIT_MASK_C3_L_C3 0x3
#define BIT_C3_L_C3(x) (((x) & BIT_MASK_C3_L_C3) << BIT_SHIFT_C3_L_C3)
#define BITS_C3_L_C3 (BIT_MASK_C3_L_C3 << BIT_SHIFT_C3_L_C3)
#define BIT_CLEAR_C3_L_C3(x) ((x) & (~BITS_C3_L_C3))
#define BIT_GET_C3_L_C3(x) (((x) >> BIT_SHIFT_C3_L_C3) & BIT_MASK_C3_L_C3)
#define BIT_SET_C3_L_C3(x, v) (BIT_CLEAR_C3_L_C3(x) | BIT_C3_L_C3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SW18_C2_BIT1 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HIMR (Offset 0x10250014) */
#define BIT_RX_REQUEST_MSK BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_SHIFT_R2_L1_V1 0
#define BIT_MASK_R2_L1_V1 0x3
#define BIT_R2_L1_V1(x) (((x) & BIT_MASK_R2_L1_V1) << BIT_SHIFT_R2_L1_V1)
#define BITS_R2_L1_V1 (BIT_MASK_R2_L1_V1 << BIT_SHIFT_R2_L1_V1)
#define BIT_CLEAR_R2_L1_V1(x) ((x) & (~BITS_R2_L1_V1))
#define BIT_GET_R2_L1_V1(x) (((x) >> BIT_SHIFT_R2_L1_V1) & BIT_MASK_R2_L1_V1)
#define BIT_SET_R2_L1_V1(x, v) (BIT_CLEAR_R2_L1_V1(x) | BIT_R2_L1_V1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SWR_CTRL2 (Offset 0x0014) */
#define BIT_C2_L_BIT1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL3 (Offset 0x0018) */
#define BIT_SPS18_OCP_DIS BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_SDIO_CRCERR BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_IO_READY_SIGNAL_ERR BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_SDIO_HSISR3_IND BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_TX_CRC BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_SDIO_HSISR2_IND BIT(29)
#define BIT_SDIO_HEISR_IND BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_SDIO_CTWEND BIT(27)
#define BIT_SDIO_ATIMEND_E BIT(26)
#define BIT_SDIO_ATIMEND BIT(25)
#define BIT_SDIO_OCPINT BIT(24)
#define BIT_SDIO_PSTIMEOUT BIT(23)
#define BIT_SDIO_GTINT4 BIT(22)
#define BIT_SDIO_GTINT3 BIT(21)
#define BIT_SDIO_HSISR_IND BIT(20)
#define BIT_SDIO_CPWM2 BIT(19)
#define BIT_SDIO_CPWM1 BIT(18)
#define BIT_SDIO_C2HCMD_INT BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL3 (Offset 0x0018) */
#define BIT_SHIFT_SPS18_OCP_TH 16
#define BIT_MASK_SPS18_OCP_TH 0x7fff
#define BIT_SPS18_OCP_TH(x) \
(((x) & BIT_MASK_SPS18_OCP_TH) << BIT_SHIFT_SPS18_OCP_TH)
#define BITS_SPS18_OCP_TH (BIT_MASK_SPS18_OCP_TH << BIT_SHIFT_SPS18_OCP_TH)
#define BIT_CLEAR_SPS18_OCP_TH(x) ((x) & (~BITS_SPS18_OCP_TH))
#define BIT_GET_SPS18_OCP_TH(x) \
(((x) >> BIT_SHIFT_SPS18_OCP_TH) & BIT_MASK_SPS18_OCP_TH)
#define BIT_SET_SPS18_OCP_TH(x, v) \
(BIT_CLEAR_SPS18_OCP_TH(x) | BIT_SPS18_OCP_TH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_SDIO_BCNERLY_INT BIT(16)
#define BIT_SDIO_TXBCNERR BIT(7)
#define BIT_SDIO_TXBCNOK BIT(6)
#define BIT_SDIO_RXFOVW BIT(5)
#define BIT_SDIO_TXFOVW BIT(4)
#define BIT_SDIO_RXERR BIT(3)
#define BIT_SDIO_TXERR BIT(2)
#define BIT_SDIO_AVAL BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SWR_CTRL3 (Offset 0x0018) */
#define BIT_SHIFT_OCP_WINDOW 0
#define BIT_MASK_OCP_WINDOW 0xffff
#define BIT_OCP_WINDOW(x) (((x) & BIT_MASK_OCP_WINDOW) << BIT_SHIFT_OCP_WINDOW)
#define BITS_OCP_WINDOW (BIT_MASK_OCP_WINDOW << BIT_SHIFT_OCP_WINDOW)
#define BIT_CLEAR_OCP_WINDOW(x) ((x) & (~BITS_OCP_WINDOW))
#define BIT_GET_OCP_WINDOW(x) \
(((x) >> BIT_SHIFT_OCP_WINDOW) & BIT_MASK_OCP_WINDOW)
#define BIT_SET_OCP_WINDOW(x, v) (BIT_CLEAR_OCP_WINDOW(x) | BIT_OCP_WINDOW(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HISR (Offset 0x10250018) */
#define BIT_RX_REQUEST BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_HREG_DBG BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_SHIFT_HREG_DBG_V1 12
#define BIT_MASK_HREG_DBG_V1 0xfff
#define BIT_HREG_DBG_V1(x) \
(((x) & BIT_MASK_HREG_DBG_V1) << BIT_SHIFT_HREG_DBG_V1)
#define BITS_HREG_DBG_V1 (BIT_MASK_HREG_DBG_V1 << BIT_SHIFT_HREG_DBG_V1)
#define BIT_CLEAR_HREG_DBG_V1(x) ((x) & (~BITS_HREG_DBG_V1))
#define BIT_GET_HREG_DBG_V1(x) \
(((x) >> BIT_SHIFT_HREG_DBG_V1) & BIT_MASK_HREG_DBG_V1)
#define BIT_SET_HREG_DBG_V1(x, v) \
(BIT_CLEAR_HREG_DBG_V1(x) | BIT_HREG_DBG_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_MCU_RST BIT(11)
#define BIT_WLOCK_90 BIT(10)
#define BIT_WLOCK_70 BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_WLMCUIOIF BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_WLOCK_78 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_LOCK_ALL_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_R_DIS_PRST BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_R_DIS_PRST_1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_WLOCK_1C_B6 BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_R_DIS_PRST_0 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RSV_CTRL (Offset 0x001C) */
#define BIT_WLOCK_40 BIT(4)
#define BIT_WLOCK_08 BIT(3)
#define BIT_WLOCK_04 BIT(2)
#define BIT_WLOCK_00 BIT(1)
#define BIT_WLOCK_ALL BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_RX_REQ_LEN (Offset 0x1025001C) */
#define BIT_SHIFT_RX_REQ_LEN_V1 0
#define BIT_MASK_RX_REQ_LEN_V1 0x3ffff
#define BIT_RX_REQ_LEN_V1(x) \
(((x) & BIT_MASK_RX_REQ_LEN_V1) << BIT_SHIFT_RX_REQ_LEN_V1)
#define BITS_RX_REQ_LEN_V1 (BIT_MASK_RX_REQ_LEN_V1 << BIT_SHIFT_RX_REQ_LEN_V1)
#define BIT_CLEAR_RX_REQ_LEN_V1(x) ((x) & (~BITS_RX_REQ_LEN_V1))
#define BIT_GET_RX_REQ_LEN_V1(x) \
(((x) >> BIT_SHIFT_RX_REQ_LEN_V1) & BIT_MASK_RX_REQ_LEN_V1)
#define BIT_SET_RX_REQ_LEN_V1(x, v) \
(BIT_CLEAR_RX_REQ_LEN_V1(x) | BIT_RX_REQ_LEN_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RF_CTRL (Offset 0x001F) */
#define BIT_RF_SDMRSTB BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RF0_CTRL (Offset 0x001F) */
#define BIT_RF0_SDMRSTB BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RF_CTRL (Offset 0x001F) */
#define BIT_RF_RSTB BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RF0_CTRL (Offset 0x001F) */
#define BIT_RF0_RSTB BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RF_CTRL (Offset 0x001F) */
#define BIT_RF_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RF0_CTRL (Offset 0x001F) */
#define BIT_RF0_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_FREE_TXPG_SEQ_V1 (Offset 0x1025001F) */
#define BIT_SHIFT_FREE_TXPG_SEQ 0
#define BIT_MASK_FREE_TXPG_SEQ 0xff
#define BIT_FREE_TXPG_SEQ(x) \
(((x) & BIT_MASK_FREE_TXPG_SEQ) << BIT_SHIFT_FREE_TXPG_SEQ)
#define BITS_FREE_TXPG_SEQ (BIT_MASK_FREE_TXPG_SEQ << BIT_SHIFT_FREE_TXPG_SEQ)
#define BIT_CLEAR_FREE_TXPG_SEQ(x) ((x) & (~BITS_FREE_TXPG_SEQ))
#define BIT_GET_FREE_TXPG_SEQ(x) \
(((x) >> BIT_SHIFT_FREE_TXPG_SEQ) & BIT_MASK_FREE_TXPG_SEQ)
#define BIT_SET_FREE_TXPG_SEQ(x, v) \
(BIT_CLEAR_FREE_TXPG_SEQ(x) | BIT_FREE_TXPG_SEQ(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLPON_EMEM1_EN BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_LPLDH12_RSV1 BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLPON_EMEM0_EN BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_LPLDH12_RSV0 BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_SHIFT_LPLDH12_RSV 29
#define BIT_MASK_LPLDH12_RSV 0x7
#define BIT_LPLDH12_RSV(x) \
(((x) & BIT_MASK_LPLDH12_RSV) << BIT_SHIFT_LPLDH12_RSV)
#define BITS_LPLDH12_RSV (BIT_MASK_LPLDH12_RSV << BIT_SHIFT_LPLDH12_RSV)
#define BIT_CLEAR_LPLDH12_RSV(x) ((x) & (~BITS_LPLDH12_RSV))
#define BIT_GET_LPLDH12_RSV(x) \
(((x) >> BIT_SHIFT_LPLDH12_RSV) & BIT_MASK_LPLDH12_RSV)
#define BIT_SET_LPLDH12_RSV(x, v) \
(BIT_CLEAR_LPLDH12_RSV(x) | BIT_LPLDH12_RSV(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_LPLDH12_SLP BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLPOFF_P4EN BIT(28)
#define BIT_R_SYM_WLPOFF_P3EN BIT(27)
#define BIT_R_SYM_WLPOFF_P2EN BIT(26)
#define BIT_R_SYM_WLPOFF_P1EN BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_SHIFT_LPLDH12_VADJ 24
#define BIT_MASK_LPLDH12_VADJ 0xf
#define BIT_LPLDH12_VADJ(x) \
(((x) & BIT_MASK_LPLDH12_VADJ) << BIT_SHIFT_LPLDH12_VADJ)
#define BITS_LPLDH12_VADJ (BIT_MASK_LPLDH12_VADJ << BIT_SHIFT_LPLDH12_VADJ)
#define BIT_CLEAR_LPLDH12_VADJ(x) ((x) & (~BITS_LPLDH12_VADJ))
#define BIT_GET_LPLDH12_VADJ(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ) & BIT_MASK_LPLDH12_VADJ)
#define BIT_SET_LPLDH12_VADJ(x, v) \
(BIT_CLEAR_LPLDH12_VADJ(x) | BIT_LPLDH12_VADJ(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLPOFF_EN BIT(24)
#define BIT_R_SYM_WLPON_P3EN BIT(21)
#define BIT_R_SYM_WLPON_P2EN BIT(20)
#define BIT_R_SYM_WLPON_P1EN BIT(19)
#define BIT_R_SYM_WLPON_EN BIT(18)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_PCIE_CALIB_EN BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_LDH12_EN BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_FREE_TXPG (Offset 0x10250020) */
#define BIT_SHIFT_MID_FREEPG_V1 16
#define BIT_MASK_MID_FREEPG_V1 0xfff
#define BIT_MID_FREEPG_V1(x) \
(((x) & BIT_MASK_MID_FREEPG_V1) << BIT_SHIFT_MID_FREEPG_V1)
#define BITS_MID_FREEPG_V1 (BIT_MASK_MID_FREEPG_V1 << BIT_SHIFT_MID_FREEPG_V1)
#define BIT_CLEAR_MID_FREEPG_V1(x) ((x) & (~BITS_MID_FREEPG_V1))
#define BIT_GET_MID_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_MID_FREEPG_V1) & BIT_MASK_MID_FREEPG_V1)
#define BIT_SET_MID_FREEPG_V1(x, v) \
(BIT_CLEAR_MID_FREEPG_V1(x) | BIT_MID_FREEPG_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_LDOV12D_STBY BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_BB_POWER_CUT_CTRL_BY_BB BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_WLBBOFF_BIG_PWC_EN BIT(14)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_SHIFT_XTAL_GM_REP_V8 13
#define BIT_MASK_XTAL_GM_REP_V8 0x3
#define BIT_XTAL_GM_REP_V8(x) \
(((x) & BIT_MASK_XTAL_GM_REP_V8) << BIT_SHIFT_XTAL_GM_REP_V8)
#define BITS_XTAL_GM_REP_V8 \
(BIT_MASK_XTAL_GM_REP_V8 << BIT_SHIFT_XTAL_GM_REP_V8)
#define BIT_CLEAR_XTAL_GM_REP_V8(x) ((x) & (~BITS_XTAL_GM_REP_V8))
#define BIT_GET_XTAL_GM_REP_V8(x) \
(((x) >> BIT_SHIFT_XTAL_GM_REP_V8) & BIT_MASK_XTAL_GM_REP_V8)
#define BIT_SET_XTAL_GM_REP_V8(x, v) \
(BIT_CLEAR_XTAL_GM_REP_V8(x) | BIT_XTAL_GM_REP_V8(v))
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_WLBBOFF_SMALL_PWC_EN BIT(13)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_POW_REGU_P3 BIT(12)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_WLMACOFF_BIG_PWC_EN BIT(12)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_POW_REGU_P2 BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_WLPON_PWC_EN BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_POW_REGU_P1 BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_MEM_DS_EN BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF1_P4_EN BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_LDOV12W_EN BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF1_P3_EN BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_SHIFT_ANAPAR_RFC2 8
#define BIT_MASK_ANAPAR_RFC2 0xff
#define BIT_ANAPAR_RFC2(x) \
(((x) & BIT_MASK_ANAPAR_RFC2) << BIT_SHIFT_ANAPAR_RFC2)
#define BITS_ANAPAR_RFC2 (BIT_MASK_ANAPAR_RFC2 << BIT_SHIFT_ANAPAR_RFC2)
#define BIT_CLEAR_ANAPAR_RFC2(x) ((x) & (~BITS_ANAPAR_RFC2))
#define BIT_GET_ANAPAR_RFC2(x) \
(((x) >> BIT_SHIFT_ANAPAR_RFC2) & BIT_MASK_ANAPAR_RFC2)
#define BIT_SET_ANAPAR_RFC2(x, v) \
(BIT_CLEAR_ANAPAR_RFC2(x) | BIT_ANAPAR_RFC2(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_EX_XTAL_DRV_DIGI BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF1_P2_EN BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_EX_XTAL_DRV_USB BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF1_P1_EN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_EX_XTAL_DRV_AFE BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_SHIFT_LDA12_VOADJ 4
#define BIT_MASK_LDA12_VOADJ 0xf
#define BIT_LDA12_VOADJ(x) \
(((x) & BIT_MASK_LDA12_VOADJ) << BIT_SHIFT_LDA12_VOADJ)
#define BITS_LDA12_VOADJ (BIT_MASK_LDA12_VOADJ << BIT_SHIFT_LDA12_VOADJ)
#define BIT_CLEAR_LDA12_VOADJ(x) ((x) & (~BITS_LDA12_VOADJ))
#define BIT_GET_LDA12_VOADJ(x) \
(((x) >> BIT_SHIFT_LDA12_VOADJ) & BIT_MASK_LDA12_VOADJ)
#define BIT_SET_LDA12_VOADJ(x, v) \
(BIT_CLEAR_LDA12_VOADJ(x) | BIT_LDA12_VOADJ(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_EX_XTAL_DRV_RF2 BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF_P4_EN BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_REG_VOS BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_EX_XTAL_DRV_RF1 BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF_P3_EN BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_POW_REGU_P0 BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF_P2_EN BIT(2)
#define BIT_R_SYM_WLBBOFF_P1_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_LDA12_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_POW_PLL_LDO BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_FREE_TXPG (Offset 0x10250020) */
#define BIT_SHIFT_HIQ_FREEPG_V1 0
#define BIT_MASK_HIQ_FREEPG_V1 0xfff
#define BIT_HIQ_FREEPG_V1(x) \
(((x) & BIT_MASK_HIQ_FREEPG_V1) << BIT_SHIFT_HIQ_FREEPG_V1)
#define BITS_HIQ_FREEPG_V1 (BIT_MASK_HIQ_FREEPG_V1 << BIT_SHIFT_HIQ_FREEPG_V1)
#define BIT_CLEAR_HIQ_FREEPG_V1(x) ((x) & (~BITS_HIQ_FREEPG_V1))
#define BIT_GET_HIQ_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_HIQ_FREEPG_V1) & BIT_MASK_HIQ_FREEPG_V1)
#define BIT_SET_HIQ_FREEPG_V1(x, v) \
(BIT_CLEAR_HIQ_FREEPG_V1(x) | BIT_HIQ_FREEPG_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_R_SYM_WLBBOFF_EN BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_LDO_CTRL (Offset 0x0020) */
#define BIT_SHIFT_ANAPAR_RFC1 0
#define BIT_MASK_ANAPAR_RFC1 0xff
#define BIT_ANAPAR_RFC1(x) \
(((x) & BIT_MASK_ANAPAR_RFC1) << BIT_SHIFT_ANAPAR_RFC1)
#define BITS_ANAPAR_RFC1 (BIT_MASK_ANAPAR_RFC1 << BIT_SHIFT_ANAPAR_RFC1)
#define BIT_CLEAR_ANAPAR_RFC1(x) ((x) & (~BITS_ANAPAR_RFC1))
#define BIT_GET_ANAPAR_RFC1(x) \
(((x) >> BIT_SHIFT_ANAPAR_RFC1) & BIT_MASK_ANAPAR_RFC1)
#define BIT_SET_ANAPAR_RFC1(x, v) \
(BIT_CLEAR_ANAPAR_RFC1(x) | BIT_ANAPAR_RFC1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_AGPIO_GPE BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XQSEL_V3 BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_REG_CC 30
#define BIT_MASK_REG_CC 0x3
#define BIT_REG_CC(x) (((x) & BIT_MASK_REG_CC) << BIT_SHIFT_REG_CC)
#define BITS_REG_CC (BIT_MASK_REG_CC << BIT_SHIFT_REG_CC)
#define BIT_CLEAR_REG_CC(x) ((x) & (~BITS_REG_CC))
#define BIT_GET_REG_CC(x) (((x) >> BIT_SHIFT_REG_CC) & BIT_MASK_REG_CC)
#define BIT_SET_REG_CC(x, v) (BIT_CLEAR_REG_CC(x) | BIT_REG_CC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_CKDELAY_AFE_V1 BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_CKDLY_DIG BIT(28)
#define BIT_CKDLY_USB BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GPIO_V1 27
#define BIT_MASK_XTAL_GPIO_V1 0x7
#define BIT_XTAL_GPIO_V1(x) \
(((x) & BIT_MASK_XTAL_GPIO_V1) << BIT_SHIFT_XTAL_GPIO_V1)
#define BITS_XTAL_GPIO_V1 (BIT_MASK_XTAL_GPIO_V1 << BIT_SHIFT_XTAL_GPIO_V1)
#define BIT_CLEAR_XTAL_GPIO_V1(x) ((x) & (~BITS_XTAL_GPIO_V1))
#define BIT_GET_XTAL_GPIO_V1(x) \
(((x) >> BIT_SHIFT_XTAL_GPIO_V1) & BIT_MASK_XTAL_GPIO_V1)
#define BIT_SET_XTAL_GPIO_V1(x, v) \
(BIT_CLEAR_XTAL_GPIO_V1(x) | BIT_XTAL_GPIO_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_CKDLY_AFE BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_CAP_XI 25
#define BIT_MASK_XTAL_CAP_XI 0x3f
#define BIT_XTAL_CAP_XI(x) \
(((x) & BIT_MASK_XTAL_CAP_XI) << BIT_SHIFT_XTAL_CAP_XI)
#define BITS_XTAL_CAP_XI (BIT_MASK_XTAL_CAP_XI << BIT_SHIFT_XTAL_CAP_XI)
#define BIT_CLEAR_XTAL_CAP_XI(x) ((x) & (~BITS_XTAL_CAP_XI))
#define BIT_GET_XTAL_CAP_XI(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XI) & BIT_MASK_XTAL_CAP_XI)
#define BIT_SET_XTAL_CAP_XI(x, v) \
(BIT_CLEAR_XTAL_CAP_XI(x) | BIT_XTAL_CAP_XI(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_DIG_DRV_1_TO_0 25
#define BIT_MASK_XTAL_DIG_DRV_1_TO_0 0x3
#define BIT_XTAL_DIG_DRV_1_TO_0(x) \
(((x) & BIT_MASK_XTAL_DIG_DRV_1_TO_0) << BIT_SHIFT_XTAL_DIG_DRV_1_TO_0)
#define BITS_XTAL_DIG_DRV_1_TO_0 \
(BIT_MASK_XTAL_DIG_DRV_1_TO_0 << BIT_SHIFT_XTAL_DIG_DRV_1_TO_0)
#define BIT_CLEAR_XTAL_DIG_DRV_1_TO_0(x) ((x) & (~BITS_XTAL_DIG_DRV_1_TO_0))
#define BIT_GET_XTAL_DIG_DRV_1_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_DIG_DRV_1_TO_0) & BIT_MASK_XTAL_DIG_DRV_1_TO_0)
#define BIT_SET_XTAL_DIG_DRV_1_TO_0(x, v) \
(BIT_CLEAR_XTAL_DIG_DRV_1_TO_0(x) | BIT_XTAL_DIG_DRV_1_TO_0(v))
#define BIT_XTAL_GDIG BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GPIO 23
#define BIT_MASK_XTAL_GPIO 0x7
#define BIT_XTAL_GPIO(x) (((x) & BIT_MASK_XTAL_GPIO) << BIT_SHIFT_XTAL_GPIO)
#define BITS_XTAL_GPIO (BIT_MASK_XTAL_GPIO << BIT_SHIFT_XTAL_GPIO)
#define BIT_CLEAR_XTAL_GPIO(x) ((x) & (~BITS_XTAL_GPIO))
#define BIT_GET_XTAL_GPIO(x) (((x) >> BIT_SHIFT_XTAL_GPIO) & BIT_MASK_XTAL_GPIO)
#define BIT_SET_XTAL_GPIO(x, v) (BIT_CLEAR_XTAL_GPIO(x) | BIT_XTAL_GPIO(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_DRV_DIGI 23
#define BIT_MASK_XTAL_DRV_DIGI 0x3
#define BIT_XTAL_DRV_DIGI(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI) << BIT_SHIFT_XTAL_DRV_DIGI)
#define BITS_XTAL_DRV_DIGI (BIT_MASK_XTAL_DRV_DIGI << BIT_SHIFT_XTAL_DRV_DIGI)
#define BIT_CLEAR_XTAL_DRV_DIGI(x) ((x) & (~BITS_XTAL_DRV_DIGI))
#define BIT_GET_XTAL_DRV_DIGI(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI) & BIT_MASK_XTAL_DRV_DIGI)
#define BIT_SET_XTAL_DRV_DIGI(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI(x) | BIT_XTAL_DRV_DIGI(v))
#define BIT_XTAL_DRV_USB_BIT1 BIT(22)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_DRV_RF_LATCH_V2 BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_RDRV_RF2_1_TO_0 22
#define BIT_MASK_XTAL_RDRV_RF2_1_TO_0 0x3
#define BIT_XTAL_RDRV_RF2_1_TO_0(x) \
(((x) & BIT_MASK_XTAL_RDRV_RF2_1_TO_0) \
<< BIT_SHIFT_XTAL_RDRV_RF2_1_TO_0)
#define BITS_XTAL_RDRV_RF2_1_TO_0 \
(BIT_MASK_XTAL_RDRV_RF2_1_TO_0 << BIT_SHIFT_XTAL_RDRV_RF2_1_TO_0)
#define BIT_CLEAR_XTAL_RDRV_RF2_1_TO_0(x) ((x) & (~BITS_XTAL_RDRV_RF2_1_TO_0))
#define BIT_GET_XTAL_RDRV_RF2_1_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_RDRV_RF2_1_TO_0) & \
BIT_MASK_XTAL_RDRV_RF2_1_TO_0)
#define BIT_SET_XTAL_RDRV_RF2_1_TO_0(x, v) \
(BIT_CLEAR_XTAL_RDRV_RF2_1_TO_0(x) | BIT_XTAL_RDRV_RF2_1_TO_0(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GMN_4 BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_MAC_CLK_SEL 20
#define BIT_MASK_MAC_CLK_SEL 0x3
#define BIT_MAC_CLK_SEL(x) \
(((x) & BIT_MASK_MAC_CLK_SEL) << BIT_SHIFT_MAC_CLK_SEL)
#define BITS_MAC_CLK_SEL (BIT_MASK_MAC_CLK_SEL << BIT_SHIFT_MAC_CLK_SEL)
#define BIT_CLEAR_MAC_CLK_SEL(x) ((x) & (~BITS_MAC_CLK_SEL))
#define BIT_GET_MAC_CLK_SEL(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL) & BIT_MASK_MAC_CLK_SEL)
#define BIT_SET_MAC_CLK_SEL(x, v) \
(BIT_CLEAR_MAC_CLK_SEL(x) | BIT_MAC_CLK_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_DRV_USB_BIT0 BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_RDRV_1_TO_0 19
#define BIT_MASK_XTAL_RDRV_1_TO_0 0x3
#define BIT_XTAL_RDRV_1_TO_0(x) \
(((x) & BIT_MASK_XTAL_RDRV_1_TO_0) << BIT_SHIFT_XTAL_RDRV_1_TO_0)
#define BITS_XTAL_RDRV_1_TO_0 \
(BIT_MASK_XTAL_RDRV_1_TO_0 << BIT_SHIFT_XTAL_RDRV_1_TO_0)
#define BIT_CLEAR_XTAL_RDRV_1_TO_0(x) ((x) & (~BITS_XTAL_RDRV_1_TO_0))
#define BIT_GET_XTAL_RDRV_1_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_RDRV_1_TO_0) & BIT_MASK_XTAL_RDRV_1_TO_0)
#define BIT_SET_XTAL_RDRV_1_TO_0(x, v) \
(BIT_CLEAR_XTAL_RDRV_1_TO_0(x) | BIT_XTAL_RDRV_1_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_DIG_DRV 18
#define BIT_MASK_XTAL_DIG_DRV 0x3
#define BIT_XTAL_DIG_DRV(x) \
(((x) & BIT_MASK_XTAL_DIG_DRV) << BIT_SHIFT_XTAL_DIG_DRV)
#define BITS_XTAL_DIG_DRV (BIT_MASK_XTAL_DIG_DRV << BIT_SHIFT_XTAL_DIG_DRV)
#define BIT_CLEAR_XTAL_DIG_DRV(x) ((x) & (~BITS_XTAL_DIG_DRV))
#define BIT_GET_XTAL_DIG_DRV(x) \
(((x) >> BIT_SHIFT_XTAL_DIG_DRV) & BIT_MASK_XTAL_DIG_DRV)
#define BIT_SET_XTAL_DIG_DRV(x, v) \
(BIT_CLEAR_XTAL_DIG_DRV(x) | BIT_XTAL_DIG_DRV(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GMP_4 BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GATE_DIG BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_DRV_AFE 17
#define BIT_MASK_XTAL_DRV_AFE 0x3
#define BIT_XTAL_DRV_AFE(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE) << BIT_SHIFT_XTAL_DRV_AFE)
#define BITS_XTAL_DRV_AFE (BIT_MASK_XTAL_DRV_AFE << BIT_SHIFT_XTAL_DRV_AFE)
#define BIT_CLEAR_XTAL_DRV_AFE(x) ((x) & (~BITS_XTAL_DRV_AFE))
#define BIT_GET_XTAL_DRV_AFE(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE) & BIT_MASK_XTAL_DRV_AFE)
#define BIT_SET_XTAL_DRV_AFE(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE(x) | BIT_XTAL_DRV_AFE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_FREE_TXPG2 (Offset 0x10250024) */
#define BIT_SHIFT_PUB_FREEPG_V1 16
#define BIT_MASK_PUB_FREEPG_V1 0xfff
#define BIT_PUB_FREEPG_V1(x) \
(((x) & BIT_MASK_PUB_FREEPG_V1) << BIT_SHIFT_PUB_FREEPG_V1)
#define BITS_PUB_FREEPG_V1 (BIT_MASK_PUB_FREEPG_V1 << BIT_SHIFT_PUB_FREEPG_V1)
#define BIT_CLEAR_PUB_FREEPG_V1(x) ((x) & (~BITS_PUB_FREEPG_V1))
#define BIT_GET_PUB_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_PUB_FREEPG_V1) & BIT_MASK_PUB_FREEPG_V1)
#define BIT_SET_PUB_FREEPG_V1(x, v) \
(BIT_CLEAR_PUB_FREEPG_V1(x) | BIT_PUB_FREEPG_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_ADRV_1_TO_0 16
#define BIT_MASK_XTAL_ADRV_1_TO_0 0x3
#define BIT_XTAL_ADRV_1_TO_0(x) \
(((x) & BIT_MASK_XTAL_ADRV_1_TO_0) << BIT_SHIFT_XTAL_ADRV_1_TO_0)
#define BITS_XTAL_ADRV_1_TO_0 \
(BIT_MASK_XTAL_ADRV_1_TO_0 << BIT_SHIFT_XTAL_ADRV_1_TO_0)
#define BIT_CLEAR_XTAL_ADRV_1_TO_0(x) ((x) & (~BITS_XTAL_ADRV_1_TO_0))
#define BIT_GET_XTAL_ADRV_1_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_ADRV_1_TO_0) & BIT_MASK_XTAL_ADRV_1_TO_0)
#define BIT_SET_XTAL_ADRV_1_TO_0(x, v) \
(BIT_CLEAR_XTAL_ADRV_1_TO_0(x) | BIT_XTAL_ADRV_1_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_RF_DRV 15
#define BIT_MASK_XTAL_RF_DRV 0x3
#define BIT_XTAL_RF_DRV(x) \
(((x) & BIT_MASK_XTAL_RF_DRV) << BIT_SHIFT_XTAL_RF_DRV)
#define BITS_XTAL_RF_DRV (BIT_MASK_XTAL_RF_DRV << BIT_SHIFT_XTAL_RF_DRV)
#define BIT_CLEAR_XTAL_RF_DRV(x) ((x) & (~BITS_XTAL_RF_DRV))
#define BIT_GET_XTAL_RF_DRV(x) \
(((x) >> BIT_SHIFT_XTAL_RF_DRV) & BIT_MASK_XTAL_RF_DRV)
#define BIT_SET_XTAL_RF_DRV(x, v) \
(BIT_CLEAR_XTAL_RF_DRV(x) | BIT_XTAL_RF_DRV(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_DRV_RF2 15
#define BIT_MASK_XTAL_DRV_RF2 0x3
#define BIT_XTAL_DRV_RF2(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2) << BIT_SHIFT_XTAL_DRV_RF2)
#define BITS_XTAL_DRV_RF2 (BIT_MASK_XTAL_DRV_RF2 << BIT_SHIFT_XTAL_DRV_RF2)
#define BIT_CLEAR_XTAL_DRV_RF2(x) ((x) & (~BITS_XTAL_DRV_RF2))
#define BIT_GET_XTAL_DRV_RF2(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2) & BIT_MASK_XTAL_DRV_RF2)
#define BIT_SET_XTAL_DRV_RF2(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2(x) | BIT_XTAL_DRV_RF2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GAFE BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_RF_GATE BIT(14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_DDRV_1_TO_0 13
#define BIT_MASK_XTAL_DDRV_1_TO_0 0x3
#define BIT_XTAL_DDRV_1_TO_0(x) \
(((x) & BIT_MASK_XTAL_DDRV_1_TO_0) << BIT_SHIFT_XTAL_DDRV_1_TO_0)
#define BITS_XTAL_DDRV_1_TO_0 \
(BIT_MASK_XTAL_DDRV_1_TO_0 << BIT_SHIFT_XTAL_DDRV_1_TO_0)
#define BIT_CLEAR_XTAL_DDRV_1_TO_0(x) ((x) & (~BITS_XTAL_DDRV_1_TO_0))
#define BIT_GET_XTAL_DDRV_1_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_DDRV_1_TO_0) & BIT_MASK_XTAL_DDRV_1_TO_0)
#define BIT_SET_XTAL_DDRV_1_TO_0(x, v) \
(BIT_CLEAR_XTAL_DDRV_1_TO_0(x) | BIT_XTAL_DDRV_1_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_AFE_DRV 12
#define BIT_MASK_XTAL_AFE_DRV 0x3
#define BIT_XTAL_AFE_DRV(x) \
(((x) & BIT_MASK_XTAL_AFE_DRV) << BIT_SHIFT_XTAL_AFE_DRV)
#define BITS_XTAL_AFE_DRV (BIT_MASK_XTAL_AFE_DRV << BIT_SHIFT_XTAL_AFE_DRV)
#define BIT_CLEAR_XTAL_AFE_DRV(x) ((x) & (~BITS_XTAL_AFE_DRV))
#define BIT_GET_XTAL_AFE_DRV(x) \
(((x) >> BIT_SHIFT_XTAL_AFE_DRV) & BIT_MASK_XTAL_AFE_DRV)
#define BIT_SET_XTAL_AFE_DRV(x, v) \
(BIT_CLEAR_XTAL_AFE_DRV(x) | BIT_XTAL_AFE_DRV(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_DELAY_DIGI BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GUSB BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GATE_AFE BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_DELAY_USB BIT(11)
#define BIT_XTAL_DELAY_AFE BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_USB_DRV 9
#define BIT_MASK_XTAL_USB_DRV 0x3
#define BIT_XTAL_USB_DRV(x) \
(((x) & BIT_MASK_XTAL_USB_DRV) << BIT_SHIFT_XTAL_USB_DRV)
#define BITS_XTAL_USB_DRV (BIT_MASK_XTAL_USB_DRV << BIT_SHIFT_XTAL_USB_DRV)
#define BIT_CLEAR_XTAL_USB_DRV(x) ((x) & (~BITS_XTAL_USB_DRV))
#define BIT_GET_XTAL_USB_DRV(x) \
(((x) >> BIT_SHIFT_XTAL_USB_DRV) & BIT_MASK_XTAL_USB_DRV)
#define BIT_SET_XTAL_USB_DRV(x, v) \
(BIT_CLEAR_XTAL_USB_DRV(x) | BIT_XTAL_USB_DRV(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_LP_V1 BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GATE_USB BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_GM_SEP_V1 BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMN_3_TO_0 8
#define BIT_MASK_XTAL_GMN_3_TO_0 0xf
#define BIT_XTAL_GMN_3_TO_0(x) \
(((x) & BIT_MASK_XTAL_GMN_3_TO_0) << BIT_SHIFT_XTAL_GMN_3_TO_0)
#define BITS_XTAL_GMN_3_TO_0 \
(BIT_MASK_XTAL_GMN_3_TO_0 << BIT_SHIFT_XTAL_GMN_3_TO_0)
#define BIT_CLEAR_XTAL_GMN_3_TO_0(x) ((x) & (~BITS_XTAL_GMN_3_TO_0))
#define BIT_GET_XTAL_GMN_3_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_3_TO_0) & BIT_MASK_XTAL_GMN_3_TO_0)
#define BIT_SET_XTAL_GMN_3_TO_0(x, v) \
(BIT_CLEAR_XTAL_GMN_3_TO_0(x) | BIT_XTAL_GMN_3_TO_0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_LDO_VREF_V1 BIT(7)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_LDO_VREF 7
#define BIT_MASK_XTAL_LDO_VREF 0x7
#define BIT_XTAL_LDO_VREF(x) \
(((x) & BIT_MASK_XTAL_LDO_VREF) << BIT_SHIFT_XTAL_LDO_VREF)
#define BITS_XTAL_LDO_VREF (BIT_MASK_XTAL_LDO_VREF << BIT_SHIFT_XTAL_LDO_VREF)
#define BIT_CLEAR_XTAL_LDO_VREF(x) ((x) & (~BITS_XTAL_LDO_VREF))
#define BIT_GET_XTAL_LDO_VREF(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_VREF) & BIT_MASK_XTAL_LDO_VREF)
#define BIT_SET_XTAL_LDO_VREF(x, v) \
(BIT_CLEAR_XTAL_LDO_VREF(x) | BIT_XTAL_LDO_VREF(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_XQSEL_RF BIT(6)
#define BIT_XTAL_XQSEL BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMP 4
#define BIT_MASK_XTAL_GMP 0xf
#define BIT_XTAL_GMP(x) (((x) & BIT_MASK_XTAL_GMP) << BIT_SHIFT_XTAL_GMP)
#define BITS_XTAL_GMP (BIT_MASK_XTAL_GMP << BIT_SHIFT_XTAL_GMP)
#define BIT_CLEAR_XTAL_GMP(x) ((x) & (~BITS_XTAL_GMP))
#define BIT_GET_XTAL_GMP(x) (((x) >> BIT_SHIFT_XTAL_GMP) & BIT_MASK_XTAL_GMP)
#define BIT_SET_XTAL_GMP(x, v) (BIT_CLEAR_XTAL_GMP(x) | BIT_XTAL_GMP(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMP_3_TO_0 4
#define BIT_MASK_XTAL_GMP_3_TO_0 0xf
#define BIT_XTAL_GMP_3_TO_0(x) \
(((x) & BIT_MASK_XTAL_GMP_3_TO_0) << BIT_SHIFT_XTAL_GMP_3_TO_0)
#define BITS_XTAL_GMP_3_TO_0 \
(BIT_MASK_XTAL_GMP_3_TO_0 << BIT_SHIFT_XTAL_GMP_3_TO_0)
#define BIT_CLEAR_XTAL_GMP_3_TO_0(x) ((x) & (~BITS_XTAL_GMP_3_TO_0))
#define BIT_GET_XTAL_GMP_3_TO_0(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_3_TO_0) & BIT_MASK_XTAL_GMP_3_TO_0)
#define BIT_SET_XTAL_GMP_3_TO_0(x, v) \
(BIT_CLEAR_XTAL_GMP_3_TO_0(x) | BIT_XTAL_GMP_3_TO_0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMN_V2 3
#define BIT_MASK_XTAL_GMN_V2 0x3
#define BIT_XTAL_GMN_V2(x) \
(((x) & BIT_MASK_XTAL_GMN_V2) << BIT_SHIFT_XTAL_GMN_V2)
#define BITS_XTAL_GMN_V2 (BIT_MASK_XTAL_GMN_V2 << BIT_SHIFT_XTAL_GMN_V2)
#define BIT_CLEAR_XTAL_GMN_V2(x) ((x) & (~BITS_XTAL_GMN_V2))
#define BIT_GET_XTAL_GMN_V2(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V2) & BIT_MASK_XTAL_GMN_V2)
#define BIT_SET_XTAL_GMN_V2(x, v) \
(BIT_CLEAR_XTAL_GMN_V2(x) | BIT_XTAL_GMN_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMN_V1 3
#define BIT_MASK_XTAL_GMN_V1 0x3
#define BIT_XTAL_GMN_V1(x) \
(((x) & BIT_MASK_XTAL_GMN_V1) << BIT_SHIFT_XTAL_GMN_V1)
#define BITS_XTAL_GMN_V1 (BIT_MASK_XTAL_GMN_V1 << BIT_SHIFT_XTAL_GMN_V1)
#define BIT_CLEAR_XTAL_GMN_V1(x) ((x) & (~BITS_XTAL_GMN_V1))
#define BIT_GET_XTAL_GMN_V1(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V1) & BIT_MASK_XTAL_GMN_V1)
#define BIT_SET_XTAL_GMN_V1(x, v) \
(BIT_CLEAR_XTAL_GMN_V1(x) | BIT_XTAL_GMN_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_LDO_VCM 2
#define BIT_MASK_XTAL_LDO_VCM 0x3
#define BIT_XTAL_LDO_VCM(x) \
(((x) & BIT_MASK_XTAL_LDO_VCM) << BIT_SHIFT_XTAL_LDO_VCM)
#define BITS_XTAL_LDO_VCM (BIT_MASK_XTAL_LDO_VCM << BIT_SHIFT_XTAL_LDO_VCM)
#define BIT_CLEAR_XTAL_LDO_VCM(x) ((x) & (~BITS_XTAL_LDO_VCM))
#define BIT_GET_XTAL_LDO_VCM(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_VCM) & BIT_MASK_XTAL_LDO_VCM)
#define BIT_SET_XTAL_LDO_VCM(x, v) \
(BIT_CLEAR_XTAL_LDO_VCM(x) | BIT_XTAL_LDO_VCM(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_DRV_LDO_VCM_1_TO_0 2
#define BIT_MASK_DRV_LDO_VCM_1_TO_0 0x3
#define BIT_DRV_LDO_VCM_1_TO_0(x) \
(((x) & BIT_MASK_DRV_LDO_VCM_1_TO_0) << BIT_SHIFT_DRV_LDO_VCM_1_TO_0)
#define BITS_DRV_LDO_VCM_1_TO_0 \
(BIT_MASK_DRV_LDO_VCM_1_TO_0 << BIT_SHIFT_DRV_LDO_VCM_1_TO_0)
#define BIT_CLEAR_DRV_LDO_VCM_1_TO_0(x) ((x) & (~BITS_DRV_LDO_VCM_1_TO_0))
#define BIT_GET_DRV_LDO_VCM_1_TO_0(x) \
(((x) >> BIT_SHIFT_DRV_LDO_VCM_1_TO_0) & BIT_MASK_DRV_LDO_VCM_1_TO_0)
#define BIT_SET_DRV_LDO_VCM_1_TO_0(x, v) \
(BIT_CLEAR_DRV_LDO_VCM_1_TO_0(x) | BIT_DRV_LDO_VCM_1_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_DUMMY BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMP_V2 1
#define BIT_MASK_XTAL_GMP_V2 0x3
#define BIT_XTAL_GMP_V2(x) \
(((x) & BIT_MASK_XTAL_GMP_V2) << BIT_SHIFT_XTAL_GMP_V2)
#define BITS_XTAL_GMP_V2 (BIT_MASK_XTAL_GMP_V2 << BIT_SHIFT_XTAL_GMP_V2)
#define BIT_CLEAR_XTAL_GMP_V2(x) ((x) & (~BITS_XTAL_GMP_V2))
#define BIT_GET_XTAL_GMP_V2(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V2) & BIT_MASK_XTAL_GMP_V2)
#define BIT_SET_XTAL_GMP_V2(x, v) \
(BIT_CLEAR_XTAL_GMP_V2(x) | BIT_XTAL_GMP_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_SHIFT_XTAL_GMP_V1 1
#define BIT_MASK_XTAL_GMP_V1 0x3
#define BIT_XTAL_GMP_V1(x) \
(((x) & BIT_MASK_XTAL_GMP_V1) << BIT_SHIFT_XTAL_GMP_V1)
#define BITS_XTAL_GMP_V1 (BIT_MASK_XTAL_GMP_V1 << BIT_SHIFT_XTAL_GMP_V1)
#define BIT_CLEAR_XTAL_GMP_V1(x) ((x) & (~BITS_XTAL_GMP_V1))
#define BIT_GET_XTAL_GMP_V1(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V1) & BIT_MASK_XTAL_GMP_V1)
#define BIT_SET_XTAL_GMP_V1(x, v) \
(BIT_CLEAR_XTAL_GMP_V1(x) | BIT_XTAL_GMP_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XQSEL_RF_INITIAL_V1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL1 (Offset 0x0024) */
#define BIT_XTAL_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_FREE_TXPG2 (Offset 0x10250024) */
#define BIT_SHIFT_LOW_FREEPG_V1 0
#define BIT_MASK_LOW_FREEPG_V1 0xfff
#define BIT_LOW_FREEPG_V1(x) \
(((x) & BIT_MASK_LOW_FREEPG_V1) << BIT_SHIFT_LOW_FREEPG_V1)
#define BITS_LOW_FREEPG_V1 (BIT_MASK_LOW_FREEPG_V1 << BIT_SHIFT_LOW_FREEPG_V1)
#define BIT_CLEAR_LOW_FREEPG_V1(x) ((x) & (~BITS_LOW_FREEPG_V1))
#define BIT_GET_LOW_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_LOW_FREEPG_V1) & BIT_MASK_LOW_FREEPG_V1)
#define BIT_SET_LOW_FREEPG_V1(x, v) \
(BIT_CLEAR_LOW_FREEPG_V1(x) | BIT_LOW_FREEPG_V1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_C3_V4 30
#define BIT_MASK_REG_C3_V4 0x3
#define BIT_REG_C3_V4(x) (((x) & BIT_MASK_REG_C3_V4) << BIT_SHIFT_REG_C3_V4)
#define BITS_REG_C3_V4 (BIT_MASK_REG_C3_V4 << BIT_SHIFT_REG_C3_V4)
#define BIT_CLEAR_REG_C3_V4(x) ((x) & (~BITS_REG_C3_V4))
#define BIT_GET_REG_C3_V4(x) (((x) >> BIT_SHIFT_REG_C3_V4) & BIT_MASK_REG_C3_V4)
#define BIT_SET_REG_C3_V4(x, v) (BIT_CLEAR_REG_C3_V4(x) | BIT_REG_C3_V4(v))
#define BIT_REG_CP_BIT1 BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_XTAL_GMN 28
#define BIT_MASK_XTAL_GMN 0xf
#define BIT_XTAL_GMN(x) (((x) & BIT_MASK_XTAL_GMN) << BIT_SHIFT_XTAL_GMN)
#define BITS_XTAL_GMN (BIT_MASK_XTAL_GMN << BIT_SHIFT_XTAL_GMN)
#define BIT_CLEAR_XTAL_GMN(x) ((x) & (~BITS_XTAL_GMN))
#define BIT_GET_XTAL_GMN(x) (((x) >> BIT_SHIFT_XTAL_GMN) & BIT_MASK_XTAL_GMN)
#define BIT_SET_XTAL_GMN(x, v) (BIT_CLEAR_XTAL_GMN(x) | BIT_XTAL_GMN(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_IOOFFSET_3_TO_0 28
#define BIT_MASK_IOOFFSET_3_TO_0 0xf
#define BIT_IOOFFSET_3_TO_0(x) \
(((x) & BIT_MASK_IOOFFSET_3_TO_0) << BIT_SHIFT_IOOFFSET_3_TO_0)
#define BITS_IOOFFSET_3_TO_0 \
(BIT_MASK_IOOFFSET_3_TO_0 << BIT_SHIFT_IOOFFSET_3_TO_0)
#define BIT_CLEAR_IOOFFSET_3_TO_0(x) ((x) & (~BITS_IOOFFSET_3_TO_0))
#define BIT_GET_IOOFFSET_3_TO_0(x) \
(((x) >> BIT_SHIFT_IOOFFSET_3_TO_0) & BIT_MASK_IOOFFSET_3_TO_0)
#define BIT_SET_IOOFFSET_3_TO_0(x, v) \
(BIT_CLEAR_IOOFFSET_3_TO_0(x) | BIT_IOOFFSET_3_TO_0(v))
#define BIT_REG_FREF_SEL_BIT3_V1 BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_VO_AD 26
#define BIT_MASK_REG_VO_AD 0x3
#define BIT_REG_VO_AD(x) (((x) & BIT_MASK_REG_VO_AD) << BIT_SHIFT_REG_VO_AD)
#define BITS_REG_VO_AD (BIT_MASK_REG_VO_AD << BIT_SHIFT_REG_VO_AD)
#define BIT_CLEAR_REG_VO_AD(x) ((x) & (~BITS_REG_VO_AD))
#define BIT_GET_REG_VO_AD(x) (((x) >> BIT_SHIFT_REG_VO_AD) & BIT_MASK_REG_VO_AD)
#define BIT_SET_REG_VO_AD(x, v) (BIT_CLEAR_REG_VO_AD(x) | BIT_REG_VO_AD(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_RS_SET 26
#define BIT_MASK_RS_SET 0x7
#define BIT_RS_SET(x) (((x) & BIT_MASK_RS_SET) << BIT_SHIFT_RS_SET)
#define BITS_RS_SET (BIT_MASK_RS_SET << BIT_SHIFT_RS_SET)
#define BIT_CLEAR_RS_SET(x) ((x) & (~BITS_RS_SET))
#define BIT_GET_RS_SET(x) (((x) >> BIT_SHIFT_RS_SET) & BIT_MASK_RS_SET)
#define BIT_SET_RS_SET(x, v) (BIT_CLEAR_RS_SET(x) | BIT_RS_SET(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_RS_SET_V2 26
#define BIT_MASK_RS_SET_V2 0x7
#define BIT_RS_SET_V2(x) (((x) & BIT_MASK_RS_SET_V2) << BIT_SHIFT_RS_SET_V2)
#define BITS_RS_SET_V2 (BIT_MASK_RS_SET_V2 << BIT_SHIFT_RS_SET_V2)
#define BIT_CLEAR_RS_SET_V2(x) ((x) & (~BITS_RS_SET_V2))
#define BIT_GET_RS_SET_V2(x) (((x) >> BIT_SHIFT_RS_SET_V2) & BIT_MASK_RS_SET_V2)
#define BIT_SET_RS_SET_V2(x, v) (BIT_CLEAR_RS_SET_V2(x) | BIT_RS_SET_V2(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_RS_V4 26
#define BIT_MASK_REG_RS_V4 0x7
#define BIT_REG_RS_V4(x) (((x) & BIT_MASK_REG_RS_V4) << BIT_SHIFT_REG_RS_V4)
#define BITS_REG_RS_V4 (BIT_MASK_REG_RS_V4 << BIT_SHIFT_REG_RS_V4)
#define BIT_CLEAR_REG_RS_V4(x) ((x) & (~BITS_REG_RS_V4))
#define BIT_GET_REG_RS_V4(x) (((x) >> BIT_SHIFT_REG_RS_V4) & BIT_MASK_REG_RS_V4)
#define BIT_SET_REG_RS_V4(x, v) (BIT_CLEAR_REG_RS_V4(x) | BIT_REG_RS_V4(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_V12ADJ_V1 25
#define BIT_MASK_V12ADJ_V1 0x3
#define BIT_V12ADJ_V1(x) (((x) & BIT_MASK_V12ADJ_V1) << BIT_SHIFT_V12ADJ_V1)
#define BITS_V12ADJ_V1 (BIT_MASK_V12ADJ_V1 << BIT_SHIFT_V12ADJ_V1)
#define BIT_CLEAR_V12ADJ_V1(x) ((x) & (~BITS_V12ADJ_V1))
#define BIT_GET_V12ADJ_V1(x) (((x) >> BIT_SHIFT_V12ADJ_V1) & BIT_MASK_V12ADJ_V1)
#define BIT_SET_V12ADJ_V1(x, v) (BIT_CLEAR_V12ADJ_V1(x) | BIT_V12ADJ_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_OQT_FREE_TXPG_V1 (Offset 0x10250028) */
#define BIT_SHIFT_NOAC_OQT_FREEPG_V1 24
#define BIT_MASK_NOAC_OQT_FREEPG_V1 0xff
#define BIT_NOAC_OQT_FREEPG_V1(x) \
(((x) & BIT_MASK_NOAC_OQT_FREEPG_V1) << BIT_SHIFT_NOAC_OQT_FREEPG_V1)
#define BITS_NOAC_OQT_FREEPG_V1 \
(BIT_MASK_NOAC_OQT_FREEPG_V1 << BIT_SHIFT_NOAC_OQT_FREEPG_V1)
#define BIT_CLEAR_NOAC_OQT_FREEPG_V1(x) ((x) & (~BITS_NOAC_OQT_FREEPG_V1))
#define BIT_GET_NOAC_OQT_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_NOAC_OQT_FREEPG_V1) & BIT_MASK_NOAC_OQT_FREEPG_V1)
#define BIT_SET_NOAC_OQT_FREEPG_V1(x, v) \
(BIT_CLEAR_NOAC_OQT_FREEPG_V1(x) | BIT_NOAC_OQT_FREEPG_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_PS_EN BIT(24)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG__CS 24
#define BIT_MASK_REG__CS 0x3
#define BIT_REG__CS(x) (((x) & BIT_MASK_REG__CS) << BIT_SHIFT_REG__CS)
#define BITS_REG__CS (BIT_MASK_REG__CS << BIT_SHIFT_REG__CS)
#define BIT_CLEAR_REG__CS(x) ((x) & (~BITS_REG__CS))
#define BIT_GET_REG__CS(x) (((x) >> BIT_SHIFT_REG__CS) & BIT_MASK_REG__CS)
#define BIT_SET_REG__CS(x, v) (BIT_CLEAR_REG__CS(x) | BIT_REG__CS(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_EN_CK320M_V1 BIT(23)
#define BIT_AGPIO BIT(22)
#define BIT_REG_EDGE_SEL_V1 BIT(21)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_CP_OFFSET 21
#define BIT_MASK_REG_CP_OFFSET 0x7
#define BIT_REG_CP_OFFSET(x) \
(((x) & BIT_MASK_REG_CP_OFFSET) << BIT_SHIFT_REG_CP_OFFSET)
#define BITS_REG_CP_OFFSET (BIT_MASK_REG_CP_OFFSET << BIT_SHIFT_REG_CP_OFFSET)
#define BIT_CLEAR_REG_CP_OFFSET(x) ((x) & (~BITS_REG_CP_OFFSET))
#define BIT_GET_REG_CP_OFFSET(x) \
(((x) >> BIT_SHIFT_REG_CP_OFFSET) & BIT_MASK_REG_CP_OFFSET)
#define BIT_SET_REG_CP_OFFSET(x, v) \
(BIT_CLEAR_REG_CP_OFFSET(x) | BIT_REG_CP_OFFSET(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_REG_VCO_BIAS_0 BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_CP_BIAS 18
#define BIT_MASK_CP_BIAS 0x7
#define BIT_CP_BIAS(x) (((x) & BIT_MASK_CP_BIAS) << BIT_SHIFT_CP_BIAS)
#define BITS_CP_BIAS (BIT_MASK_CP_BIAS << BIT_SHIFT_CP_BIAS)
#define BIT_CLEAR_CP_BIAS(x) ((x) & (~BITS_CP_BIAS))
#define BIT_GET_CP_BIAS(x) (((x) >> BIT_SHIFT_CP_BIAS) & BIT_MASK_CP_BIAS)
#define BIT_SET_CP_BIAS(x, v) (BIT_CLEAR_CP_BIAS(x) | BIT_CP_BIAS(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_CP_BIAS_V2 18
#define BIT_MASK_CP_BIAS_V2 0x7
#define BIT_CP_BIAS_V2(x) (((x) & BIT_MASK_CP_BIAS_V2) << BIT_SHIFT_CP_BIAS_V2)
#define BITS_CP_BIAS_V2 (BIT_MASK_CP_BIAS_V2 << BIT_SHIFT_CP_BIAS_V2)
#define BIT_CLEAR_CP_BIAS_V2(x) ((x) & (~BITS_CP_BIAS_V2))
#define BIT_GET_CP_BIAS_V2(x) \
(((x) >> BIT_SHIFT_CP_BIAS_V2) & BIT_MASK_CP_BIAS_V2)
#define BIT_SET_CP_BIAS_V2(x, v) (BIT_CLEAR_CP_BIAS_V2(x) | BIT_CP_BIAS_V2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_PLLBIAS_2_TO_0_V1 17
#define BIT_MASK_REG_PLLBIAS_2_TO_0_V1 0x7
#define BIT_REG_PLLBIAS_2_TO_0_V1(x) \
(((x) & BIT_MASK_REG_PLLBIAS_2_TO_0_V1) \
<< BIT_SHIFT_REG_PLLBIAS_2_TO_0_V1)
#define BITS_REG_PLLBIAS_2_TO_0_V1 \
(BIT_MASK_REG_PLLBIAS_2_TO_0_V1 << BIT_SHIFT_REG_PLLBIAS_2_TO_0_V1)
#define BIT_CLEAR_REG_PLLBIAS_2_TO_0_V1(x) ((x) & (~BITS_REG_PLLBIAS_2_TO_0_V1))
#define BIT_GET_REG_PLLBIAS_2_TO_0_V1(x) \
(((x) >> BIT_SHIFT_REG_PLLBIAS_2_TO_0_V1) & \
BIT_MASK_REG_PLLBIAS_2_TO_0_V1)
#define BIT_SET_REG_PLLBIAS_2_TO_0_V1(x, v) \
(BIT_CLEAR_REG_PLLBIAS_2_TO_0_V1(x) | BIT_REG_PLLBIAS_2_TO_0_V1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_REG_IDOUBLE_V2 BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_FREF_SEL BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_OQT_FREE_TXPG_V1 (Offset 0x10250028) */
#define BIT_SHIFT_AC_OQT_FREEPG_V1 16
#define BIT_MASK_AC_OQT_FREEPG_V1 0xff
#define BIT_AC_OQT_FREEPG_V1(x) \
(((x) & BIT_MASK_AC_OQT_FREEPG_V1) << BIT_SHIFT_AC_OQT_FREEPG_V1)
#define BITS_AC_OQT_FREEPG_V1 \
(BIT_MASK_AC_OQT_FREEPG_V1 << BIT_SHIFT_AC_OQT_FREEPG_V1)
#define BIT_CLEAR_AC_OQT_FREEPG_V1(x) ((x) & (~BITS_AC_OQT_FREEPG_V1))
#define BIT_GET_AC_OQT_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_AC_OQT_FREEPG_V1) & BIT_MASK_AC_OQT_FREEPG_V1)
#define BIT_SET_AC_OQT_FREEPG_V1(x, v) \
(BIT_CLEAR_AC_OQT_FREEPG_V1(x) | BIT_AC_OQT_FREEPG_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_REG_IDOUBLE_V1 BIT(16)
#define BIT_SHIFT_AC_OQT__FREEPG_V1 16
#define BIT_MASK_AC_OQT__FREEPG_V1 0xff
#define BIT_AC_OQT__FREEPG_V1(x) \
(((x) & BIT_MASK_AC_OQT__FREEPG_V1) << BIT_SHIFT_AC_OQT__FREEPG_V1)
#define BITS_AC_OQT__FREEPG_V1 \
(BIT_MASK_AC_OQT__FREEPG_V1 << BIT_SHIFT_AC_OQT__FREEPG_V1)
#define BIT_CLEAR_AC_OQT__FREEPG_V1(x) ((x) & (~BITS_AC_OQT__FREEPG_V1))
#define BIT_GET_AC_OQT__FREEPG_V1(x) \
(((x) >> BIT_SHIFT_AC_OQT__FREEPG_V1) & BIT_MASK_AC_OQT__FREEPG_V1)
#define BIT_SET_AC_OQT__FREEPG_V1(x, v) \
(BIT_CLEAR_AC_OQT__FREEPG_V1(x) | BIT_AC_OQT__FREEPG_V1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_EN_SYN BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_REG_KVCO_V1 BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_APLL_320_GATEB BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_MCCO 14
#define BIT_MASK_MCCO 0x3
#define BIT_MCCO(x) (((x) & BIT_MASK_MCCO) << BIT_SHIFT_MCCO)
#define BITS_MCCO (BIT_MASK_MCCO << BIT_SHIFT_MCCO)
#define BIT_CLEAR_MCCO(x) ((x) & (~BITS_MCCO))
#define BIT_GET_MCCO(x) (((x) >> BIT_SHIFT_MCCO) & BIT_MASK_MCCO)
#define BIT_SET_MCCO(x, v) (BIT_CLEAR_MCCO(x) | BIT_MCCO(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_MCCO_V2 14
#define BIT_MASK_MCCO_V2 0x3
#define BIT_MCCO_V2(x) (((x) & BIT_MASK_MCCO_V2) << BIT_SHIFT_MCCO_V2)
#define BITS_MCCO_V2 (BIT_MASK_MCCO_V2 << BIT_SHIFT_MCCO_V2)
#define BIT_CLEAR_MCCO_V2(x) ((x) & (~BITS_MCCO_V2))
#define BIT_GET_MCCO_V2(x) (((x) >> BIT_SHIFT_MCCO_V2) & BIT_MASK_MCCO_V2)
#define BIT_SET_MCCO_V2(x, v) (BIT_CLEAR_MCCO_V2(x) | BIT_MCCO_V2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_REG_VCO_BIAS_1_V1 BIT(14)
#define BIT_REG_DOGB_V1 BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_CK320_EN 12
#define BIT_MASK_CK320_EN 0x3
#define BIT_CK320_EN(x) (((x) & BIT_MASK_CK320_EN) << BIT_SHIFT_CK320_EN)
#define BITS_CK320_EN (BIT_MASK_CK320_EN << BIT_SHIFT_CK320_EN)
#define BIT_CLEAR_CK320_EN(x) ((x) & (~BITS_CK320_EN))
#define BIT_GET_CK320_EN(x) (((x) >> BIT_SHIFT_CK320_EN) & BIT_MASK_CK320_EN)
#define BIT_SET_CK320_EN(x, v) (BIT_CLEAR_CK320_EN(x) | BIT_CK320_EN(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_LDO_SEL 12
#define BIT_MASK_REG_LDO_SEL 0x3
#define BIT_REG_LDO_SEL(x) \
(((x) & BIT_MASK_REG_LDO_SEL) << BIT_SHIFT_REG_LDO_SEL)
#define BITS_REG_LDO_SEL (BIT_MASK_REG_LDO_SEL << BIT_SHIFT_REG_LDO_SEL)
#define BIT_CLEAR_REG_LDO_SEL(x) ((x) & (~BITS_REG_LDO_SEL))
#define BIT_GET_REG_LDO_SEL(x) \
(((x) >> BIT_SHIFT_REG_LDO_SEL) & BIT_MASK_REG_LDO_SEL)
#define BIT_SET_REG_LDO_SEL(x, v) \
(BIT_CLEAR_REG_LDO_SEL(x) | BIT_REG_LDO_SEL(v))
#define BIT_REG_KVCO_V2 BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_AGPIO_GPO BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_APLL_BIAS 8
#define BIT_MASK_APLL_BIAS 0x7
#define BIT_APLL_BIAS(x) (((x) & BIT_MASK_APLL_BIAS) << BIT_SHIFT_APLL_BIAS)
#define BITS_APLL_BIAS (BIT_MASK_APLL_BIAS << BIT_SHIFT_APLL_BIAS)
#define BIT_CLEAR_APLL_BIAS(x) ((x) & (~BITS_APLL_BIAS))
#define BIT_GET_APLL_BIAS(x) (((x) >> BIT_SHIFT_APLL_BIAS) & BIT_MASK_APLL_BIAS)
#define BIT_SET_APLL_BIAS(x, v) (BIT_CLEAR_APLL_BIAS(x) | BIT_APLL_BIAS(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_AGPIO_DRV 7
#define BIT_MASK_AGPIO_DRV 0x3
#define BIT_AGPIO_DRV(x) (((x) & BIT_MASK_AGPIO_DRV) << BIT_SHIFT_AGPIO_DRV)
#define BITS_AGPIO_DRV (BIT_MASK_AGPIO_DRV << BIT_SHIFT_AGPIO_DRV)
#define BIT_CLEAR_AGPIO_DRV(x) ((x) & (~BITS_AGPIO_DRV))
#define BIT_GET_AGPIO_DRV(x) (((x) >> BIT_SHIFT_AGPIO_DRV) & BIT_MASK_AGPIO_DRV)
#define BIT_SET_AGPIO_DRV(x, v) (BIT_CLEAR_AGPIO_DRV(x) | BIT_AGPIO_DRV(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_V15_3_TO_0_V1 7
#define BIT_MASK_REG_V15_3_TO_0_V1 0xf
#define BIT_REG_V15_3_TO_0_V1(x) \
(((x) & BIT_MASK_REG_V15_3_TO_0_V1) << BIT_SHIFT_REG_V15_3_TO_0_V1)
#define BITS_REG_V15_3_TO_0_V1 \
(BIT_MASK_REG_V15_3_TO_0_V1 << BIT_SHIFT_REG_V15_3_TO_0_V1)
#define BIT_CLEAR_REG_V15_3_TO_0_V1(x) ((x) & (~BITS_REG_V15_3_TO_0_V1))
#define BIT_GET_REG_V15_3_TO_0_V1(x) \
(((x) >> BIT_SHIFT_REG_V15_3_TO_0_V1) & BIT_MASK_REG_V15_3_TO_0_V1)
#define BIT_SET_REG_V15_3_TO_0_V1(x, v) \
(BIT_CLEAR_REG_V15_3_TO_0_V1(x) | BIT_REG_V15_3_TO_0_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_APLL_KVCO BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_REG_SEL_LDO_PC BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_APLL_WDOGB BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_REG_CC_1_TO_0_V1 4
#define BIT_MASK_REG_CC_1_TO_0_V1 0x3
#define BIT_REG_CC_1_TO_0_V1(x) \
(((x) & BIT_MASK_REG_CC_1_TO_0_V1) << BIT_SHIFT_REG_CC_1_TO_0_V1)
#define BITS_REG_CC_1_TO_0_V1 \
(BIT_MASK_REG_CC_1_TO_0_V1 << BIT_SHIFT_REG_CC_1_TO_0_V1)
#define BIT_CLEAR_REG_CC_1_TO_0_V1(x) ((x) & (~BITS_REG_CC_1_TO_0_V1))
#define BIT_GET_REG_CC_1_TO_0_V1(x) \
(((x) >> BIT_SHIFT_REG_CC_1_TO_0_V1) & BIT_MASK_REG_CC_1_TO_0_V1)
#define BIT_SET_REG_CC_1_TO_0_V1(x, v) \
(BIT_CLEAR_REG_CC_1_TO_0_V1(x) | BIT_REG_CC_1_TO_0_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_APLL_EDGE_SEL BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_CKDELAY_USB_V1 BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_APLL_FREF_SEL_BIT0 BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_POW_MAC (Offset 0x0028) */
#define BIT_POW_LDO15 BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_CKDELAY_DIG_V1 BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_SHIFT_XTAL_CAP_XO 1
#define BIT_MASK_XTAL_CAP_XO 0x3f
#define BIT_XTAL_CAP_XO(x) \
(((x) & BIT_MASK_XTAL_CAP_XO) << BIT_SHIFT_XTAL_CAP_XO)
#define BITS_XTAL_CAP_XO (BIT_MASK_XTAL_CAP_XO << BIT_SHIFT_XTAL_CAP_XO)
#define BIT_CLEAR_XTAL_CAP_XO(x) ((x) & (~BITS_XTAL_CAP_XO))
#define BIT_GET_XTAL_CAP_XO(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XO) & BIT_MASK_XTAL_CAP_XO)
#define BIT_SET_XTAL_CAP_XO(x, v) \
(BIT_CLEAR_XTAL_CAP_XO(x) | BIT_XTAL_CAP_XO(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_POW_MAC (Offset 0x0028) */
#define BIT_POW_SW BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_MPLL_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_APLL_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL2 (Offset 0x0028) */
#define BIT_POW_PLL BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_OQT_FREE_TXPG_V1 (Offset 0x10250028) */
#define BIT_SHIFT_EXQ_FREEPG_V1 0
#define BIT_MASK_EXQ_FREEPG_V1 0xfff
#define BIT_EXQ_FREEPG_V1(x) \
(((x) & BIT_MASK_EXQ_FREEPG_V1) << BIT_SHIFT_EXQ_FREEPG_V1)
#define BITS_EXQ_FREEPG_V1 (BIT_MASK_EXQ_FREEPG_V1 << BIT_SHIFT_EXQ_FREEPG_V1)
#define BIT_CLEAR_EXQ_FREEPG_V1(x) ((x) & (~BITS_EXQ_FREEPG_V1))
#define BIT_GET_EXQ_FREEPG_V1(x) \
(((x) >> BIT_SHIFT_EXQ_FREEPG_V1) & BIT_MASK_EXQ_FREEPG_V1)
#define BIT_SET_EXQ_FREEPG_V1(x, v) \
(BIT_CLEAR_EXQ_FREEPG_V1(x) | BIT_EXQ_FREEPG_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_POW_MAC (Offset 0x0028) */
#define BIT_POW_LDO14 BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_OQT_FREE_TXPG_V1 (Offset 0x10250028) */
#define BIT_SHIFT_EXQ__FREEPG_V1 0
#define BIT_MASK_EXQ__FREEPG_V1 0xfff
#define BIT_EXQ__FREEPG_V1(x) \
(((x) & BIT_MASK_EXQ__FREEPG_V1) << BIT_SHIFT_EXQ__FREEPG_V1)
#define BITS_EXQ__FREEPG_V1 \
(BIT_MASK_EXQ__FREEPG_V1 << BIT_SHIFT_EXQ__FREEPG_V1)
#define BIT_CLEAR_EXQ__FREEPG_V1(x) ((x) & (~BITS_EXQ__FREEPG_V1))
#define BIT_GET_EXQ__FREEPG_V1(x) \
(((x) >> BIT_SHIFT_EXQ__FREEPG_V1) & BIT_MASK_EXQ__FREEPG_V1)
#define BIT_SET_EXQ__FREEPG_V1(x, v) \
(BIT_CLEAR_EXQ__FREEPG_V1(x) | BIT_EXQ__FREEPG_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARLDO_POW_MAC (Offset 0x0029) */
#define BIT_LDOE25_POW_L BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_POW_MAC (Offset 0x002A) */
#define BIT_REG_STANDBY_L BIT(19)
#define BIT_PD_REGU_L BIT(18)
#define BIT_EN_PC_BT_L BIT(17)
#define BIT_SHIFT_REG_LDOADJ_L 13
#define BIT_MASK_REG_LDOADJ_L 0xf
#define BIT_REG_LDOADJ_L(x) \
(((x) & BIT_MASK_REG_LDOADJ_L) << BIT_SHIFT_REG_LDOADJ_L)
#define BITS_REG_LDOADJ_L (BIT_MASK_REG_LDOADJ_L << BIT_SHIFT_REG_LDOADJ_L)
#define BIT_CLEAR_REG_LDOADJ_L(x) ((x) & (~BITS_REG_LDOADJ_L))
#define BIT_GET_REG_LDOADJ_L(x) \
(((x) >> BIT_SHIFT_REG_LDOADJ_L) & BIT_MASK_REG_LDOADJ_L)
#define BIT_SET_REG_LDOADJ_L(x, v) \
(BIT_CLEAR_REG_LDOADJ_L(x) | BIT_REG_LDOADJ_L(v))
#define BIT_CK12M_EN BIT(11)
#define BIT_CK12M_SEL BIT(10)
#define BIT_EN_25_L BIT(9)
#define BIT_EN_SLEEP BIT(8)
#define BIT_DUMMY_V4 BIT(7)
#define BIT_DUMMY_V3 BIT(6)
#define BIT_DUMMY_V2 BIT(5)
#define BIT_DUMMY_V1 BIT(4)
#define BIT_SHIFT_LDOH12_V12ADJ_L 4
#define BIT_MASK_LDOH12_V12ADJ_L 0xf
#define BIT_LDOH12_V12ADJ_L(x) \
(((x) & BIT_MASK_LDOH12_V12ADJ_L) << BIT_SHIFT_LDOH12_V12ADJ_L)
#define BITS_LDOH12_V12ADJ_L \
(BIT_MASK_LDOH12_V12ADJ_L << BIT_SHIFT_LDOH12_V12ADJ_L)
#define BIT_CLEAR_LDOH12_V12ADJ_L(x) ((x) & (~BITS_LDOH12_V12ADJ_L))
#define BIT_GET_LDOH12_V12ADJ_L(x) \
(((x) >> BIT_SHIFT_LDOH12_V12ADJ_L) & BIT_MASK_LDOH12_V12ADJ_L)
#define BIT_SET_LDOH12_V12ADJ_L(x, v) \
(BIT_CLEAR_LDOH12_V12ADJ_L(x) | BIT_LDOH12_V12ADJ_L(v))
#define BIT_POW_PC_LDO_PORT1 BIT(3)
#define BIT_POW_PC_LDO_PORT0 BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_POW_MAC (Offset 0x002A) */
#define BIT_POW_PLL_V1 BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_POW_MAC (Offset 0x002A) */
#define BIT_POW_POWER_CUT_POW_LDO BIT(0)
#define BIT_SHIFT_LDOE25_V12ADJ_L_V1 0
#define BIT_MASK_LDOE25_V12ADJ_L_V1 0xf
#define BIT_LDOE25_V12ADJ_L_V1(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L_V1) << BIT_SHIFT_LDOE25_V12ADJ_L_V1)
#define BITS_LDOE25_V12ADJ_L_V1 \
(BIT_MASK_LDOE25_V12ADJ_L_V1 << BIT_SHIFT_LDOE25_V12ADJ_L_V1)
#define BIT_CLEAR_LDOE25_V12ADJ_L_V1(x) ((x) & (~BITS_LDOE25_V12ADJ_L_V1))
#define BIT_GET_LDOE25_V12ADJ_L_V1(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L_V1) & BIT_MASK_LDOE25_V12ADJ_L_V1)
#define BIT_SET_LDOE25_V12ADJ_L_V1(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L_V1(x) | BIT_LDOE25_V12ADJ_L_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_POW_XTAL (Offset 0x002B) */
#define BIT_PSTIMER_2 BIT(31)
#define BIT_PSTIMER_1 BIT(30)
#define BIT_PSTIMER_0 BIT(29)
#define BIT_TXDMA_START_INT BIT(23)
#define BIT_TXDMA_STOP_INT BIT(22)
#define BIT_HISR7_IND BIT(21)
#define BIT_HISR6_IND BIT(19)
#define BIT_HISR5_IND BIT(18)
#define BIT_HISR4_IND BIT(17)
#define BIT_HISR3_IND BIT(14)
#define BIT_HISR2_IND BIT(13)
#define BIT_POW_XTAL BIT(1)
#define BIT_POW_BG BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_XTAL_RF2_DRV 30
#define BIT_MASK_XTAL_RF2_DRV 0x3
#define BIT_XTAL_RF2_DRV(x) \
(((x) & BIT_MASK_XTAL_RF2_DRV) << BIT_SHIFT_XTAL_RF2_DRV)
#define BITS_XTAL_RF2_DRV (BIT_MASK_XTAL_RF2_DRV << BIT_SHIFT_XTAL_RF2_DRV)
#define BIT_CLEAR_XTAL_RF2_DRV(x) ((x) & (~BITS_XTAL_RF2_DRV))
#define BIT_GET_XTAL_RF2_DRV(x) \
(((x) >> BIT_SHIFT_XTAL_RF2_DRV) & BIT_MASK_XTAL_RF2_DRV)
#define BIT_SET_XTAL_RF2_DRV(x, v) \
(BIT_CLEAR_XTAL_RF2_DRV(x) | BIT_XTAL_RF2_DRV(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_REG_REF_SEL_V3 BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_XTAL_GMN_BIT4 BIT(29)
#define BIT_XTAL_GMP_BIT4 BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_XQSEL BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_FREF_SEL_2_TO_0 27
#define BIT_MASK_REG_FREF_SEL_2_TO_0 0x7
#define BIT_REG_FREF_SEL_2_TO_0(x) \
(((x) & BIT_MASK_REG_FREF_SEL_2_TO_0) << BIT_SHIFT_REG_FREF_SEL_2_TO_0)
#define BITS_REG_FREF_SEL_2_TO_0 \
(BIT_MASK_REG_FREF_SEL_2_TO_0 << BIT_SHIFT_REG_FREF_SEL_2_TO_0)
#define BIT_CLEAR_REG_FREF_SEL_2_TO_0(x) ((x) & (~BITS_REG_FREF_SEL_2_TO_0))
#define BIT_GET_REG_FREF_SEL_2_TO_0(x) \
(((x) >> BIT_SHIFT_REG_FREF_SEL_2_TO_0) & BIT_MASK_REG_FREF_SEL_2_TO_0)
#define BIT_SET_REG_FREF_SEL_2_TO_0(x, v) \
(BIT_CLEAR_REG_FREF_SEL_2_TO_0(x) | BIT_REG_FREF_SEL_2_TO_0(v))
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_XQSEL_BIT0 BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_APLL_DUMMY BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_XTAL_CADJ_XOUT_5_TO_0_V1 21
#define BIT_MASK_XTAL_CADJ_XOUT_5_TO_0_V1 0x3f
#define BIT_XTAL_CADJ_XOUT_5_TO_0_V1(x) \
(((x) & BIT_MASK_XTAL_CADJ_XOUT_5_TO_0_V1) \
<< BIT_SHIFT_XTAL_CADJ_XOUT_5_TO_0_V1)
#define BITS_XTAL_CADJ_XOUT_5_TO_0_V1 \
(BIT_MASK_XTAL_CADJ_XOUT_5_TO_0_V1 \
<< BIT_SHIFT_XTAL_CADJ_XOUT_5_TO_0_V1)
#define BIT_CLEAR_XTAL_CADJ_XOUT_5_TO_0_V1(x) \
((x) & (~BITS_XTAL_CADJ_XOUT_5_TO_0_V1))
#define BIT_GET_XTAL_CADJ_XOUT_5_TO_0_V1(x) \
(((x) >> BIT_SHIFT_XTAL_CADJ_XOUT_5_TO_0_V1) & \
BIT_MASK_XTAL_CADJ_XOUT_5_TO_0_V1)
#define BIT_SET_XTAL_CADJ_XOUT_5_TO_0_V1(x, v) \
(BIT_CLEAR_XTAL_CADJ_XOUT_5_TO_0_V1(x) | \
BIT_XTAL_CADJ_XOUT_5_TO_0_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_XTAL_CADJ_XOUT 18
#define BIT_MASK_XTAL_CADJ_XOUT 0x3f
#define BIT_XTAL_CADJ_XOUT(x) \
(((x) & BIT_MASK_XTAL_CADJ_XOUT) << BIT_SHIFT_XTAL_CADJ_XOUT)
#define BITS_XTAL_CADJ_XOUT \
(BIT_MASK_XTAL_CADJ_XOUT << BIT_SHIFT_XTAL_CADJ_XOUT)
#define BIT_CLEAR_XTAL_CADJ_XOUT(x) ((x) & (~BITS_XTAL_CADJ_XOUT))
#define BIT_GET_XTAL_CADJ_XOUT(x) \
(((x) >> BIT_SHIFT_XTAL_CADJ_XOUT) & BIT_MASK_XTAL_CADJ_XOUT)
#define BIT_SET_XTAL_CADJ_XOUT(x, v) \
(BIT_CLEAR_XTAL_CADJ_XOUT(x) | BIT_XTAL_CADJ_XOUT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_XTAL_CADJ_XIN_V2 15
#define BIT_MASK_XTAL_CADJ_XIN_V2 0x3f
#define BIT_XTAL_CADJ_XIN_V2(x) \
(((x) & BIT_MASK_XTAL_CADJ_XIN_V2) << BIT_SHIFT_XTAL_CADJ_XIN_V2)
#define BITS_XTAL_CADJ_XIN_V2 \
(BIT_MASK_XTAL_CADJ_XIN_V2 << BIT_SHIFT_XTAL_CADJ_XIN_V2)
#define BIT_CLEAR_XTAL_CADJ_XIN_V2(x) ((x) & (~BITS_XTAL_CADJ_XIN_V2))
#define BIT_GET_XTAL_CADJ_XIN_V2(x) \
(((x) >> BIT_SHIFT_XTAL_CADJ_XIN_V2) & BIT_MASK_XTAL_CADJ_XIN_V2)
#define BIT_SET_XTAL_CADJ_XIN_V2(x, v) \
(BIT_CLEAR_XTAL_CADJ_XIN_V2(x) | BIT_XTAL_CADJ_XIN_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_XTAL_CADJ_XIN 12
#define BIT_MASK_XTAL_CADJ_XIN 0x3f
#define BIT_XTAL_CADJ_XIN(x) \
(((x) & BIT_MASK_XTAL_CADJ_XIN) << BIT_SHIFT_XTAL_CADJ_XIN)
#define BITS_XTAL_CADJ_XIN (BIT_MASK_XTAL_CADJ_XIN << BIT_SHIFT_XTAL_CADJ_XIN)
#define BIT_CLEAR_XTAL_CADJ_XIN(x) ((x) & (~BITS_XTAL_CADJ_XIN))
#define BIT_GET_XTAL_CADJ_XIN(x) \
(((x) >> BIT_SHIFT_XTAL_CADJ_XIN) & BIT_MASK_XTAL_CADJ_XIN)
#define BIT_SET_XTAL_CADJ_XIN(x, v) \
(BIT_CLEAR_XTAL_CADJ_XIN(x) | BIT_XTAL_CADJ_XIN(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_RS_V3 12
#define BIT_MASK_REG_RS_V3 0x7
#define BIT_REG_RS_V3(x) (((x) & BIT_MASK_REG_RS_V3) << BIT_SHIFT_REG_RS_V3)
#define BITS_REG_RS_V3 (BIT_MASK_REG_RS_V3 << BIT_SHIFT_REG_RS_V3)
#define BIT_CLEAR_REG_RS_V3(x) ((x) & (~BITS_REG_RS_V3))
#define BIT_GET_REG_RS_V3(x) (((x) >> BIT_SHIFT_REG_RS_V3) & BIT_MASK_REG_RS_V3)
#define BIT_SET_REG_RS_V3(x, v) (BIT_CLEAR_REG_RS_V3(x) | BIT_REG_RS_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_BCNQ_EMPTY BIT(11)
#define BIT_SDIO_HQQ_EMPTY BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_RS 9
#define BIT_MASK_REG_RS 0x7
#define BIT_REG_RS(x) (((x) & BIT_MASK_REG_RS) << BIT_SHIFT_REG_RS)
#define BITS_REG_RS (BIT_MASK_REG_RS << BIT_SHIFT_REG_RS)
#define BIT_CLEAR_REG_RS(x) ((x) & (~BITS_REG_RS))
#define BIT_GET_REG_RS(x) (((x) >> BIT_SHIFT_REG_RS) & BIT_MASK_REG_RS)
#define BIT_SET_REG_RS(x, v) (BIT_CLEAR_REG_RS(x) | BIT_REG_RS(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_MQQ_EMPTY BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_R3_V3 9
#define BIT_MASK_REG_R3_V3 0x7
#define BIT_REG_R3_V3(x) (((x) & BIT_MASK_REG_R3_V3) << BIT_SHIFT_REG_R3_V3)
#define BITS_REG_R3_V3 (BIT_MASK_REG_R3_V3 << BIT_SHIFT_REG_R3_V3)
#define BIT_CLEAR_REG_R3_V3(x) ((x) & (~BITS_REG_R3_V3))
#define BIT_GET_REG_R3_V3(x) (((x) >> BIT_SHIFT_REG_R3_V3) & BIT_MASK_REG_R3_V3)
#define BIT_SET_REG_R3_V3(x, v) (BIT_CLEAR_REG_R3_V3(x) | BIT_REG_R3_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_MGQ_CPU_EMPTY BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_PS_V2 7
#define BIT_MASK_PS_V2 0x7
#define BIT_PS_V2(x) (((x) & BIT_MASK_PS_V2) << BIT_SHIFT_PS_V2)
#define BITS_PS_V2 (BIT_MASK_PS_V2 << BIT_SHIFT_PS_V2)
#define BIT_CLEAR_PS_V2(x) ((x) & (~BITS_PS_V2))
#define BIT_GET_PS_V2(x) (((x) >> BIT_SHIFT_PS_V2) & BIT_MASK_PS_V2)
#define BIT_SET_PS_V2(x, v) (BIT_CLEAR_PS_V2(x) | BIT_PS_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC7Q_EMPTY BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_CS_V3 7
#define BIT_MASK_REG_CS_V3 0x3
#define BIT_REG_CS_V3(x) (((x) & BIT_MASK_REG_CS_V3) << BIT_SHIFT_REG_CS_V3)
#define BITS_REG_CS_V3 (BIT_MASK_REG_CS_V3 << BIT_SHIFT_REG_CS_V3)
#define BIT_CLEAR_REG_CS_V3(x) ((x) & (~BITS_REG_CS_V3))
#define BIT_GET_REG_CS_V3(x) (((x) >> BIT_SHIFT_REG_CS_V3) & BIT_MASK_REG_CS_V3)
#define BIT_SET_REG_CS_V3(x, v) (BIT_CLEAR_REG_CS_V3(x) | BIT_REG_CS_V3(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_PS 7
#define BIT_MASK_PS 0x7
#define BIT_PS(x) (((x) & BIT_MASK_PS) << BIT_SHIFT_PS)
#define BITS_PS (BIT_MASK_PS << BIT_SHIFT_PS)
#define BIT_CLEAR_PS(x) ((x) & (~BITS_PS))
#define BIT_GET_PS(x) (((x) >> BIT_SHIFT_PS) & BIT_MASK_PS)
#define BIT_SET_PS(x, v) (BIT_CLEAR_PS(x) | BIT_PS(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_R3 6
#define BIT_MASK_REG_R3 0x7
#define BIT_REG_R3(x) (((x) & BIT_MASK_REG_R3) << BIT_SHIFT_REG_R3)
#define BITS_REG_R3 (BIT_MASK_REG_R3 << BIT_SHIFT_REG_R3)
#define BIT_CLEAR_REG_R3(x) ((x) & (~BITS_REG_R3))
#define BIT_GET_REG_R3(x) (((x) >> BIT_SHIFT_REG_R3) & BIT_MASK_REG_R3)
#define BIT_SET_REG_R3(x, v) (BIT_CLEAR_REG_R3(x) | BIT_REG_R3(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_PSEN BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC6Q_EMPTY BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_DOGENB BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC5Q_EMPTY BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_CP_V3 5
#define BIT_MASK_REG_CP_V3 0x3
#define BIT_REG_CP_V3(x) (((x) & BIT_MASK_REG_CP_V3) << BIT_SHIFT_REG_CP_V3)
#define BITS_REG_CP_V3 (BIT_MASK_REG_CP_V3 << BIT_SHIFT_REG_CP_V3)
#define BIT_CLEAR_REG_CP_V3(x) ((x) & (~BITS_REG_CP_V3))
#define BIT_GET_REG_CP_V3(x) (((x) >> BIT_SHIFT_REG_CP_V3) & BIT_MASK_REG_CP_V3)
#define BIT_SET_REG_CP_V3(x, v) (BIT_CLEAR_REG_CP_V3(x) | BIT_REG_CP_V3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_CS 4
#define BIT_MASK_REG_CS 0x3
#define BIT_REG_CS(x) (((x) & BIT_MASK_REG_CS) << BIT_SHIFT_REG_CS)
#define BITS_REG_CS (BIT_MASK_REG_CS << BIT_SHIFT_REG_CS)
#define BIT_CLEAR_REG_CS(x) ((x) & (~BITS_REG_CS))
#define BIT_GET_REG_CS(x) (((x) >> BIT_SHIFT_REG_CS) & BIT_MASK_REG_CS)
#define BIT_SET_REG_CS(x, v) (BIT_CLEAR_REG_CS(x) | BIT_REG_CS(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC4Q_EMPTY BIT(4)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_REG_MBIAS BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC3Q_EMPTY BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_C3_V3 3
#define BIT_MASK_REG_C3_V3 0x3
#define BIT_REG_C3_V3(x) (((x) & BIT_MASK_REG_C3_V3) << BIT_SHIFT_REG_C3_V3)
#define BITS_REG_C3_V3 (BIT_MASK_REG_C3_V3 << BIT_SHIFT_REG_C3_V3)
#define BIT_CLEAR_REG_C3_V3(x) ((x) & (~BITS_REG_C3_V3))
#define BIT_GET_REG_C3_V3(x) (((x) >> BIT_SHIFT_REG_C3_V3) & BIT_MASK_REG_C3_V3)
#define BIT_SET_REG_C3_V3(x, v) (BIT_CLEAR_REG_C3_V3(x) | BIT_REG_C3_V3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_CP 2
#define BIT_MASK_REG_CP 0x3
#define BIT_REG_CP(x) (((x) & BIT_MASK_REG_CP) << BIT_SHIFT_REG_CP)
#define BITS_REG_CP (BIT_MASK_REG_CP << BIT_SHIFT_REG_CP)
#define BIT_CLEAR_REG_CP(x) ((x) & (~BITS_REG_CP))
#define BIT_GET_REG_CP(x) (((x) >> BIT_SHIFT_REG_CP) & BIT_MASK_REG_CP)
#define BIT_SET_REG_CP(x, v) (BIT_CLEAR_REG_CP(x) | BIT_REG_CP(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC2Q_EMPTY BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_REG_320_SEL_V3 BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC1Q_EMPTY BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_EN_SYN_V1 BIT(1)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_R3_V4 1
#define BIT_MASK_REG_R3_V4 0x7
#define BIT_REG_R3_V4(x) (((x) & BIT_MASK_REG_R3_V4) << BIT_SHIFT_REG_R3_V4)
#define BITS_REG_R3_V4 (BIT_MASK_REG_R3_V4 << BIT_SHIFT_REG_R3_V4)
#define BIT_CLEAR_REG_R3_V4(x) ((x) & (~BITS_REG_R3_V4))
#define BIT_GET_REG_R3_V4(x) (((x) >> BIT_SHIFT_REG_R3_V4) & BIT_MASK_REG_R3_V4)
#define BIT_SET_REG_R3_V4(x, v) (BIT_CLEAR_REG_R3_V4(x) | BIT_REG_R3_V4(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_SHIFT_REG_C3 0
#define BIT_MASK_REG_C3 0x3
#define BIT_REG_C3(x) (((x) & BIT_MASK_REG_C3) << BIT_SHIFT_REG_C3)
#define BITS_REG_C3 (BIT_MASK_REG_C3 << BIT_SHIFT_REG_C3)
#define BIT_CLEAR_REG_C3(x) ((x) & (~BITS_REG_C3))
#define BIT_GET_REG_C3(x) (((x) >> BIT_SHIFT_REG_C3) & BIT_MASK_REG_C3)
#define BIT_SET_REG_C3(x, v) (BIT_CLEAR_REG_C3(x) | BIT_REG_C3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TXPKT_EMPTY (Offset 0x1025002C) */
#define BIT_SDIO_AC0Q_EMPTY BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_IOOFFSET_BIT4 BIT(0)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL3 (Offset 0x002C) */
#define BIT_REG_CP_BIT0 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_EFUSE_CTRL (Offset 0x0030) */
#define BIT_EF_FLAG BIT(31)
#define BIT_SHIFT_EF_PGPD 28
#define BIT_MASK_EF_PGPD 0x7
#define BIT_EF_PGPD(x) (((x) & BIT_MASK_EF_PGPD) << BIT_SHIFT_EF_PGPD)
#define BITS_EF_PGPD (BIT_MASK_EF_PGPD << BIT_SHIFT_EF_PGPD)
#define BIT_CLEAR_EF_PGPD(x) ((x) & (~BITS_EF_PGPD))
#define BIT_GET_EF_PGPD(x) (((x) >> BIT_SHIFT_EF_PGPD) & BIT_MASK_EF_PGPD)
#define BIT_SET_EF_PGPD(x, v) (BIT_CLEAR_EF_PGPD(x) | BIT_EF_PGPD(v))
#define BIT_SHIFT_EF_RDT 24
#define BIT_MASK_EF_RDT 0xf
#define BIT_EF_RDT(x) (((x) & BIT_MASK_EF_RDT) << BIT_SHIFT_EF_RDT)
#define BITS_EF_RDT (BIT_MASK_EF_RDT << BIT_SHIFT_EF_RDT)
#define BIT_CLEAR_EF_RDT(x) ((x) & (~BITS_EF_RDT))
#define BIT_GET_EF_RDT(x) (((x) >> BIT_SHIFT_EF_RDT) & BIT_MASK_EF_RDT)
#define BIT_SET_EF_RDT(x, v) (BIT_CLEAR_EF_RDT(x) | BIT_EF_RDT(v))
#define BIT_SHIFT_EF_PGTS 20
#define BIT_MASK_EF_PGTS 0xf
#define BIT_EF_PGTS(x) (((x) & BIT_MASK_EF_PGTS) << BIT_SHIFT_EF_PGTS)
#define BITS_EF_PGTS (BIT_MASK_EF_PGTS << BIT_SHIFT_EF_PGTS)
#define BIT_CLEAR_EF_PGTS(x) ((x) & (~BITS_EF_PGTS))
#define BIT_GET_EF_PGTS(x) (((x) >> BIT_SHIFT_EF_PGTS) & BIT_MASK_EF_PGTS)
#define BIT_SET_EF_PGTS(x, v) (BIT_CLEAR_EF_PGTS(x) | BIT_EF_PGTS(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_EFUSE_CTRL (Offset 0x0030) */
#define BIT_EF_PDWN BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_EFUSE_CTRL (Offset 0x0030) */
#define BIT_EF_ALDEN BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HTSFR_INFO (Offset 0x10250030) */
#define BIT_SHIFT_HTSFR1 16
#define BIT_MASK_HTSFR1 0xffff
#define BIT_HTSFR1(x) (((x) & BIT_MASK_HTSFR1) << BIT_SHIFT_HTSFR1)
#define BITS_HTSFR1 (BIT_MASK_HTSFR1 << BIT_SHIFT_HTSFR1)
#define BIT_CLEAR_HTSFR1(x) ((x) & (~BITS_HTSFR1))
#define BIT_GET_HTSFR1(x) (((x) >> BIT_SHIFT_HTSFR1) & BIT_MASK_HTSFR1)
#define BIT_SET_HTSFR1(x, v) (BIT_CLEAR_HTSFR1(x) | BIT_HTSFR1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_EFUSE_CTRL (Offset 0x0030) */
#define BIT_SHIFT_EF_ADDR 8
#define BIT_MASK_EF_ADDR 0x3ff
#define BIT_EF_ADDR(x) (((x) & BIT_MASK_EF_ADDR) << BIT_SHIFT_EF_ADDR)
#define BITS_EF_ADDR (BIT_MASK_EF_ADDR << BIT_SHIFT_EF_ADDR)
#define BIT_CLEAR_EF_ADDR(x) ((x) & (~BITS_EF_ADDR))
#define BIT_GET_EF_ADDR(x) (((x) >> BIT_SHIFT_EF_ADDR) & BIT_MASK_EF_ADDR)
#define BIT_SET_EF_ADDR(x, v) (BIT_CLEAR_EF_ADDR(x) | BIT_EF_ADDR(v))
#define BIT_SHIFT_EF_DATA 0
#define BIT_MASK_EF_DATA 0xff
#define BIT_EF_DATA(x) (((x) & BIT_MASK_EF_DATA) << BIT_SHIFT_EF_DATA)
#define BITS_EF_DATA (BIT_MASK_EF_DATA << BIT_SHIFT_EF_DATA)
#define BIT_CLEAR_EF_DATA(x) ((x) & (~BITS_EF_DATA))
#define BIT_GET_EF_DATA(x) (((x) >> BIT_SHIFT_EF_DATA) & BIT_MASK_EF_DATA)
#define BIT_SET_EF_DATA(x, v) (BIT_CLEAR_EF_DATA(x) | BIT_EF_DATA(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HTSFR_INFO (Offset 0x10250030) */
#define BIT_SHIFT_HTSFR0 0
#define BIT_MASK_HTSFR0 0xffff
#define BIT_HTSFR0(x) (((x) & BIT_MASK_HTSFR0) << BIT_SHIFT_HTSFR0)
#define BITS_HTSFR0 (BIT_MASK_HTSFR0 << BIT_SHIFT_HTSFR0)
#define BIT_CLEAR_HTSFR0(x) ((x) & (~BITS_HTSFR0))
#define BIT_GET_HTSFR0(x) (((x) >> BIT_SHIFT_HTSFR0) & BIT_MASK_HTSFR0)
#define BIT_SET_HTSFR0(x, v) (BIT_CLEAR_HTSFR0(x) | BIT_HTSFR0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_LDOE25_EN BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_LDOE25_VADJ_BIT0_TO_2 28
#define BIT_MASK_LDOE25_VADJ_BIT0_TO_2 0x7
#define BIT_LDOE25_VADJ_BIT0_TO_2(x) \
(((x) & BIT_MASK_LDOE25_VADJ_BIT0_TO_2) \
<< BIT_SHIFT_LDOE25_VADJ_BIT0_TO_2)
#define BITS_LDOE25_VADJ_BIT0_TO_2 \
(BIT_MASK_LDOE25_VADJ_BIT0_TO_2 << BIT_SHIFT_LDOE25_VADJ_BIT0_TO_2)
#define BIT_CLEAR_LDOE25_VADJ_BIT0_TO_2(x) ((x) & (~BITS_LDOE25_VADJ_BIT0_TO_2))
#define BIT_GET_LDOE25_VADJ_BIT0_TO_2(x) \
(((x) >> BIT_SHIFT_LDOE25_VADJ_BIT0_TO_2) & \
BIT_MASK_LDOE25_VADJ_BIT0_TO_2)
#define BIT_SET_LDOE25_VADJ_BIT0_TO_2(x, v) \
(BIT_CLEAR_LDOE25_VADJ_BIT0_TO_2(x) | BIT_LDOE25_VADJ_BIT0_TO_2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_LDOE25_V12ADJ_L_LOW 28
#define BIT_MASK_LDOE25_V12ADJ_L_LOW 0x7
#define BIT_LDOE25_V12ADJ_L_LOW(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L_LOW) << BIT_SHIFT_LDOE25_V12ADJ_L_LOW)
#define BITS_LDOE25_V12ADJ_L_LOW \
(BIT_MASK_LDOE25_V12ADJ_L_LOW << BIT_SHIFT_LDOE25_V12ADJ_L_LOW)
#define BIT_CLEAR_LDOE25_V12ADJ_L_LOW(x) ((x) & (~BITS_LDOE25_V12ADJ_L_LOW))
#define BIT_GET_LDOE25_V12ADJ_L_LOW(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L_LOW) & BIT_MASK_LDOE25_V12ADJ_L_LOW)
#define BIT_SET_LDOE25_V12ADJ_L_LOW(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L_LOW(x) | BIT_LDOE25_V12ADJ_L_LOW(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_LDOE25_VADJ_BIT3 BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_LDOE25_V12ADJ_L_HIGH BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_LDOE25_V12ADJ_L 27
#define BIT_MASK_LDOE25_V12ADJ_L 0xf
#define BIT_LDOE25_V12ADJ_L(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L) << BIT_SHIFT_LDOE25_V12ADJ_L)
#define BITS_LDOE25_V12ADJ_L \
(BIT_MASK_LDOE25_V12ADJ_L << BIT_SHIFT_LDOE25_V12ADJ_L)
#define BIT_CLEAR_LDOE25_V12ADJ_L(x) ((x) & (~BITS_LDOE25_V12ADJ_L))
#define BIT_GET_LDOE25_V12ADJ_L(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L) & BIT_MASK_LDOE25_V12ADJ_L)
#define BIT_SET_LDOE25_V12ADJ_L(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L(x) | BIT_LDOE25_V12ADJ_L(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_LDOE25_VADJ_3_TO_0 27
#define BIT_MASK_LDOE25_VADJ_3_TO_0 0xf
#define BIT_LDOE25_VADJ_3_TO_0(x) \
(((x) & BIT_MASK_LDOE25_VADJ_3_TO_0) << BIT_SHIFT_LDOE25_VADJ_3_TO_0)
#define BITS_LDOE25_VADJ_3_TO_0 \
(BIT_MASK_LDOE25_VADJ_3_TO_0 << BIT_SHIFT_LDOE25_VADJ_3_TO_0)
#define BIT_CLEAR_LDOE25_VADJ_3_TO_0(x) ((x) & (~BITS_LDOE25_VADJ_3_TO_0))
#define BIT_GET_LDOE25_VADJ_3_TO_0(x) \
(((x) >> BIT_SHIFT_LDOE25_VADJ_3_TO_0) & BIT_MASK_LDOE25_VADJ_3_TO_0)
#define BIT_SET_LDOE25_VADJ_3_TO_0(x, v) \
(BIT_CLEAR_LDOE25_VADJ_3_TO_0(x) | BIT_LDOE25_VADJ_3_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_EFCRES_SEL BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_EF_CRES_SEL BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_EF_CSER BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_EF_SCAN_START 16
#define BIT_MASK_EF_SCAN_START 0x1ff
#define BIT_EF_SCAN_START(x) \
(((x) & BIT_MASK_EF_SCAN_START) << BIT_SHIFT_EF_SCAN_START)
#define BITS_EF_SCAN_START (BIT_MASK_EF_SCAN_START << BIT_SHIFT_EF_SCAN_START)
#define BIT_CLEAR_EF_SCAN_START(x) ((x) & (~BITS_EF_SCAN_START))
#define BIT_GET_EF_SCAN_START(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START) & BIT_MASK_EF_SCAN_START)
#define BIT_SET_EF_SCAN_START(x, v) \
(BIT_CLEAR_EF_SCAN_START(x) | BIT_EF_SCAN_START(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_EF_SCAN_START_V1 16
#define BIT_MASK_EF_SCAN_START_V1 0x3ff
#define BIT_EF_SCAN_START_V1(x) \
(((x) & BIT_MASK_EF_SCAN_START_V1) << BIT_SHIFT_EF_SCAN_START_V1)
#define BITS_EF_SCAN_START_V1 \
(BIT_MASK_EF_SCAN_START_V1 << BIT_SHIFT_EF_SCAN_START_V1)
#define BIT_CLEAR_EF_SCAN_START_V1(x) ((x) & (~BITS_EF_SCAN_START_V1))
#define BIT_GET_EF_SCAN_START_V1(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START_V1) & BIT_MASK_EF_SCAN_START_V1)
#define BIT_SET_EF_SCAN_START_V1(x, v) \
(BIT_CLEAR_EF_SCAN_START_V1(x) | BIT_EF_SCAN_START_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_EF_SCAN_END 12
#define BIT_MASK_EF_SCAN_END 0xf
#define BIT_EF_SCAN_END(x) \
(((x) & BIT_MASK_EF_SCAN_END) << BIT_SHIFT_EF_SCAN_END)
#define BITS_EF_SCAN_END (BIT_MASK_EF_SCAN_END << BIT_SHIFT_EF_SCAN_END)
#define BIT_CLEAR_EF_SCAN_END(x) ((x) & (~BITS_EF_SCAN_END))
#define BIT_GET_EF_SCAN_END(x) \
(((x) >> BIT_SHIFT_EF_SCAN_END) & BIT_MASK_EF_SCAN_END)
#define BIT_SET_EF_SCAN_END(x, v) \
(BIT_CLEAR_EF_SCAN_END(x) | BIT_EF_SCAN_END(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_EF_FORCE_PGMEN BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_EF_PD_DIS BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SCAN_EN BIT(11)
#define BIT_SW_PG_EN BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_SHIFT_EF_CELL_SEL 8
#define BIT_MASK_EF_CELL_SEL 0x3
#define BIT_EF_CELL_SEL(x) \
(((x) & BIT_MASK_EF_CELL_SEL) << BIT_SHIFT_EF_CELL_SEL)
#define BITS_EF_CELL_SEL (BIT_MASK_EF_CELL_SEL << BIT_SHIFT_EF_CELL_SEL)
#define BIT_CLEAR_EF_CELL_SEL(x) ((x) & (~BITS_EF_CELL_SEL))
#define BIT_GET_EF_CELL_SEL(x) \
(((x) >> BIT_SHIFT_EF_CELL_SEL) & BIT_MASK_EF_CELL_SEL)
#define BIT_SET_EF_CELL_SEL(x, v) \
(BIT_CLEAR_EF_CELL_SEL(x) | BIT_EF_CELL_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_EFUSE_CTRL (Offset 0x0034) */
#define BIT_EF_TRPT BIT(7)
#define BIT_SHIFT_EF_TTHD 0
#define BIT_MASK_EF_TTHD 0x7f
#define BIT_EF_TTHD(x) (((x) & BIT_MASK_EF_TTHD) << BIT_SHIFT_EF_TTHD)
#define BITS_EF_TTHD (BIT_MASK_EF_TTHD << BIT_SHIFT_EF_TTHD)
#define BIT_CLEAR_EF_TTHD(x) ((x) & (~BITS_EF_TTHD))
#define BIT_GET_EF_TTHD(x) (((x) >> BIT_SHIFT_EF_TTHD) & BIT_MASK_EF_TTHD)
#define BIT_SET_EF_TTHD(x, v) (BIT_CLEAR_EF_TTHD(x) | BIT_EF_TTHD(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_UPHY_BG_ON_OPT 30
#define BIT_MASK_UPHY_BG_ON_OPT 0x3
#define BIT_UPHY_BG_ON_OPT(x) \
(((x) & BIT_MASK_UPHY_BG_ON_OPT) << BIT_SHIFT_UPHY_BG_ON_OPT)
#define BITS_UPHY_BG_ON_OPT \
(BIT_MASK_UPHY_BG_ON_OPT << BIT_SHIFT_UPHY_BG_ON_OPT)
#define BIT_CLEAR_UPHY_BG_ON_OPT(x) ((x) & (~BITS_UPHY_BG_ON_OPT))
#define BIT_GET_UPHY_BG_ON_OPT(x) \
(((x) >> BIT_SHIFT_UPHY_BG_ON_OPT) & BIT_MASK_UPHY_BG_ON_OPT)
#define BIT_SET_UPHY_BG_ON_OPT(x, v) \
(BIT_CLEAR_UPHY_BG_ON_OPT(x) | BIT_UPHY_BG_ON_OPT(v))
#define BIT_UPHY_BG_ON_USB2 BIT(29)
#define BIT_UPHY_BG_ON_PCIE BIT(28)
#define BIT_VD33IO_LEFT_SHD_N_ BIT(27)
#define BIT_VDIO_RIGHT1_SHD_N_ BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_AFE_USB_CURRENT_SEL 26
#define BIT_MASK_AFE_USB_CURRENT_SEL 0x7
#define BIT_AFE_USB_CURRENT_SEL(x) \
(((x) & BIT_MASK_AFE_USB_CURRENT_SEL) << BIT_SHIFT_AFE_USB_CURRENT_SEL)
#define BITS_AFE_USB_CURRENT_SEL \
(BIT_MASK_AFE_USB_CURRENT_SEL << BIT_SHIFT_AFE_USB_CURRENT_SEL)
#define BIT_CLEAR_AFE_USB_CURRENT_SEL(x) ((x) & (~BITS_AFE_USB_CURRENT_SEL))
#define BIT_GET_AFE_USB_CURRENT_SEL(x) \
(((x) >> BIT_SHIFT_AFE_USB_CURRENT_SEL) & BIT_MASK_AFE_USB_CURRENT_SEL)
#define BIT_SET_AFE_USB_CURRENT_SEL(x, v) \
(BIT_CLEAR_AFE_USB_CURRENT_SEL(x) | BIT_AFE_USB_CURRENT_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_VDIO_RIGHT0_SHD_N_ BIT(25)
#define BIT_DIS_LPS_WT_PDNSUS BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_AFE_USB_PATH_SEL 24
#define BIT_MASK_AFE_USB_PATH_SEL 0x3
#define BIT_AFE_USB_PATH_SEL(x) \
(((x) & BIT_MASK_AFE_USB_PATH_SEL) << BIT_SHIFT_AFE_USB_PATH_SEL)
#define BITS_AFE_USB_PATH_SEL \
(BIT_MASK_AFE_USB_PATH_SEL << BIT_SHIFT_AFE_USB_PATH_SEL)
#define BIT_CLEAR_AFE_USB_PATH_SEL(x) ((x) & (~BITS_AFE_USB_PATH_SEL))
#define BIT_GET_AFE_USB_PATH_SEL(x) \
(((x) >> BIT_SHIFT_AFE_USB_PATH_SEL) & BIT_MASK_AFE_USB_PATH_SEL)
#define BIT_SET_AFE_USB_PATH_SEL(x, v) \
(BIT_CLEAR_AFE_USB_PATH_SEL(x) | BIT_AFE_USB_PATH_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_DBG_SEL_V1 16
#define BIT_MASK_DBG_SEL_V1 0xff
#define BIT_DBG_SEL_V1(x) (((x) & BIT_MASK_DBG_SEL_V1) << BIT_SHIFT_DBG_SEL_V1)
#define BITS_DBG_SEL_V1 (BIT_MASK_DBG_SEL_V1 << BIT_SHIFT_DBG_SEL_V1)
#define BIT_CLEAR_DBG_SEL_V1(x) ((x) & (~BITS_DBG_SEL_V1))
#define BIT_GET_DBG_SEL_V1(x) \
(((x) >> BIT_SHIFT_DBG_SEL_V1) & BIT_MASK_DBG_SEL_V1)
#define BIT_SET_DBG_SEL_V1(x, v) (BIT_CLEAR_DBG_SEL_V1(x) | BIT_DBG_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_CLK_REQ_INPUT BIT(15)
#define BIT_USB_XTAL_CLK_SEL BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_DBG_SEL_BYTE 14
#define BIT_MASK_DBG_SEL_BYTE 0x3
#define BIT_DBG_SEL_BYTE(x) \
(((x) & BIT_MASK_DBG_SEL_BYTE) << BIT_SHIFT_DBG_SEL_BYTE)
#define BITS_DBG_SEL_BYTE (BIT_MASK_DBG_SEL_BYTE << BIT_SHIFT_DBG_SEL_BYTE)
#define BIT_CLEAR_DBG_SEL_BYTE(x) ((x) & (~BITS_DBG_SEL_BYTE))
#define BIT_GET_DBG_SEL_BYTE(x) \
(((x) >> BIT_SHIFT_DBG_SEL_BYTE) & BIT_MASK_DBG_SEL_BYTE)
#define BIT_SET_DBG_SEL_BYTE(x, v) \
(BIT_CLEAR_DBG_SEL_BYTE(x) | BIT_DBG_SEL_BYTE(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_USB_REG_XTAL_SEL BIT(14)
#define BIT_SYSON_BTIO1POW_PAD_E2 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_SPS0_STD_L1 12
#define BIT_MASK_SYSON_SPS0_STD_L1 0x3
#define BIT_SYSON_SPS0_STD_L1(x) \
(((x) & BIT_MASK_SYSON_SPS0_STD_L1) << BIT_SHIFT_SYSON_SPS0_STD_L1)
#define BITS_SYSON_SPS0_STD_L1 \
(BIT_MASK_SYSON_SPS0_STD_L1 << BIT_SHIFT_SYSON_SPS0_STD_L1)
#define BIT_CLEAR_SYSON_SPS0_STD_L1(x) ((x) & (~BITS_SYSON_SPS0_STD_L1))
#define BIT_GET_SYSON_SPS0_STD_L1(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0_STD_L1) & BIT_MASK_SYSON_SPS0_STD_L1)
#define BIT_SET_SYSON_SPS0_STD_L1(x, v) \
(BIT_CLEAR_SYSON_SPS0_STD_L1(x) | BIT_SYSON_SPS0_STD_L1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_STD_L1_V1 12
#define BIT_MASK_STD_L1_V1 0x3
#define BIT_STD_L1_V1(x) (((x) & BIT_MASK_STD_L1_V1) << BIT_SHIFT_STD_L1_V1)
#define BITS_STD_L1_V1 (BIT_MASK_STD_L1_V1 << BIT_SHIFT_STD_L1_V1)
#define BIT_CLEAR_STD_L1_V1(x) ((x) & (~BITS_STD_L1_V1))
#define BIT_GET_STD_L1_V1(x) (((x) >> BIT_SHIFT_STD_L1_V1) & BIT_MASK_STD_L1_V1)
#define BIT_SET_STD_L1_V1(x, v) (BIT_CLEAR_STD_L1_V1(x) | BIT_STD_L1_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_BTIOPOW_PAD_E2 BIT(12)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_LDOA12V_WT 12
#define BIT_MASK_SYSON_LDOA12V_WT 0x3
#define BIT_SYSON_LDOA12V_WT(x) \
(((x) & BIT_MASK_SYSON_LDOA12V_WT) << BIT_SHIFT_SYSON_LDOA12V_WT)
#define BITS_SYSON_LDOA12V_WT \
(BIT_MASK_SYSON_LDOA12V_WT << BIT_SHIFT_SYSON_LDOA12V_WT)
#define BIT_CLEAR_SYSON_LDOA12V_WT(x) ((x) & (~BITS_SYSON_LDOA12V_WT))
#define BIT_GET_SYSON_LDOA12V_WT(x) \
(((x) >> BIT_SHIFT_SYSON_LDOA12V_WT) & BIT_MASK_SYSON_LDOA12V_WT)
#define BIT_SET_SYSON_LDOA12V_WT(x, v) \
(BIT_CLEAR_SYSON_LDOA12V_WT(x) | BIT_SYSON_LDOA12V_WT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_DBG_PAD_E2 BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_SDIOPOW_PAD_E2 BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_LED_PAD_E2 BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_GPEE_PAD_E2 BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_GPEE_PAD_E2_V33 BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SYSON_PCI_PAD_E2 BIT(8)
#define BIT_SHIFT_MATCH_CNT 8
#define BIT_MASK_MATCH_CNT 0xff
#define BIT_MATCH_CNT(x) (((x) & BIT_MASK_MATCH_CNT) << BIT_SHIFT_MATCH_CNT)
#define BITS_MATCH_CNT (BIT_MASK_MATCH_CNT << BIT_SHIFT_MATCH_CNT)
#define BIT_CLEAR_MATCH_CNT(x) ((x) & (~BITS_MATCH_CNT))
#define BIT_GET_MATCH_CNT(x) (((x) >> BIT_SHIFT_MATCH_CNT) & BIT_MASK_MATCH_CNT)
#define BIT_SET_MATCH_CNT(x, v) (BIT_CLEAR_MATCH_CNT(x) | BIT_MATCH_CNT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_AUTO_SW_LDO_VOL_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_AUTO_SW_LDO_VOL_EN_V1 BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_ADJ_LDO_VOLT BIT(6)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_LDOHCI12_WT 6
#define BIT_MASK_SYSON_LDOHCI12_WT 0x3
#define BIT_SYSON_LDOHCI12_WT(x) \
(((x) & BIT_MASK_SYSON_LDOHCI12_WT) << BIT_SHIFT_SYSON_LDOHCI12_WT)
#define BITS_SYSON_LDOHCI12_WT \
(BIT_MASK_SYSON_LDOHCI12_WT << BIT_SHIFT_SYSON_LDOHCI12_WT)
#define BIT_CLEAR_SYSON_LDOHCI12_WT(x) ((x) & (~BITS_SYSON_LDOHCI12_WT))
#define BIT_GET_SYSON_LDOHCI12_WT(x) \
(((x) >> BIT_SHIFT_SYSON_LDOHCI12_WT) & BIT_MASK_SYSON_LDOHCI12_WT)
#define BIT_SET_SYSON_LDOHCI12_WT(x, v) \
(BIT_CLEAR_SYSON_LDOHCI12_WT(x) | BIT_SYSON_LDOHCI12_WT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_SPS0WWV_WT 4
#define BIT_MASK_SYSON_SPS0WWV_WT 0x3
#define BIT_SYSON_SPS0WWV_WT(x) \
(((x) & BIT_MASK_SYSON_SPS0WWV_WT) << BIT_SHIFT_SYSON_SPS0WWV_WT)
#define BITS_SYSON_SPS0WWV_WT \
(BIT_MASK_SYSON_SPS0WWV_WT << BIT_SHIFT_SYSON_SPS0WWV_WT)
#define BIT_CLEAR_SYSON_SPS0WWV_WT(x) ((x) & (~BITS_SYSON_SPS0WWV_WT))
#define BIT_GET_SYSON_SPS0WWV_WT(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0WWV_WT) & BIT_MASK_SYSON_SPS0WWV_WT)
#define BIT_SET_SYSON_SPS0WWV_WT(x, v) \
(BIT_CLEAR_SYSON_SPS0WWV_WT(x) | BIT_SYSON_SPS0WWV_WT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_SPS0SPS_WT 4
#define BIT_MASK_SYSON_SPS0SPS_WT 0x3
#define BIT_SYSON_SPS0SPS_WT(x) \
(((x) & BIT_MASK_SYSON_SPS0SPS_WT) << BIT_SHIFT_SYSON_SPS0SPS_WT)
#define BITS_SYSON_SPS0SPS_WT \
(BIT_MASK_SYSON_SPS0SPS_WT << BIT_SHIFT_SYSON_SPS0SPS_WT)
#define BIT_CLEAR_SYSON_SPS0SPS_WT(x) ((x) & (~BITS_SYSON_SPS0SPS_WT))
#define BIT_GET_SYSON_SPS0SPS_WT(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0SPS_WT) & BIT_MASK_SYSON_SPS0SPS_WT)
#define BIT_SET_SYSON_SPS0SPS_WT(x, v) \
(BIT_CLEAR_SYSON_SPS0SPS_WT(x) | BIT_SYSON_SPS0SPS_WT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_SPS0LDO_WT 2
#define BIT_MASK_SYSON_SPS0LDO_WT 0x3
#define BIT_SYSON_SPS0LDO_WT(x) \
(((x) & BIT_MASK_SYSON_SPS0LDO_WT) << BIT_SHIFT_SYSON_SPS0LDO_WT)
#define BITS_SYSON_SPS0LDO_WT \
(BIT_MASK_SYSON_SPS0LDO_WT << BIT_SHIFT_SYSON_SPS0LDO_WT)
#define BIT_CLEAR_SYSON_SPS0LDO_WT(x) ((x) & (~BITS_SYSON_SPS0LDO_WT))
#define BIT_GET_SYSON_SPS0LDO_WT(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0LDO_WT) & BIT_MASK_SYSON_SPS0LDO_WT)
#define BIT_SET_SYSON_SPS0LDO_WT(x, v) \
(BIT_CLEAR_SYSON_SPS0LDO_WT(x) | BIT_SYSON_SPS0LDO_WT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_SPS11VLDO_WT 2
#define BIT_MASK_SYSON_SPS11VLDO_WT 0x3
#define BIT_SYSON_SPS11VLDO_WT(x) \
(((x) & BIT_MASK_SYSON_SPS11VLDO_WT) << BIT_SHIFT_SYSON_SPS11VLDO_WT)
#define BITS_SYSON_SPS11VLDO_WT \
(BIT_MASK_SYSON_SPS11VLDO_WT << BIT_SHIFT_SYSON_SPS11VLDO_WT)
#define BIT_CLEAR_SYSON_SPS11VLDO_WT(x) ((x) & (~BITS_SYSON_SPS11VLDO_WT))
#define BIT_GET_SYSON_SPS11VLDO_WT(x) \
(((x) >> BIT_SHIFT_SYSON_SPS11VLDO_WT) & BIT_MASK_SYSON_SPS11VLDO_WT)
#define BIT_SET_SYSON_SPS11VLDO_WT(x, v) \
(BIT_CLEAR_SYSON_SPS11VLDO_WT(x) | BIT_SYSON_SPS11VLDO_WT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PWR_OPTION_CTRL (Offset 0x0038) */
#define BIT_SHIFT_SYSON_RCLK_SCALE 0
#define BIT_MASK_SYSON_RCLK_SCALE 0x3
#define BIT_SYSON_RCLK_SCALE(x) \
(((x) & BIT_MASK_SYSON_RCLK_SCALE) << BIT_SHIFT_SYSON_RCLK_SCALE)
#define BITS_SYSON_RCLK_SCALE \
(BIT_MASK_SYSON_RCLK_SCALE << BIT_SHIFT_SYSON_RCLK_SCALE)
#define BIT_CLEAR_SYSON_RCLK_SCALE(x) ((x) & (~BITS_SYSON_RCLK_SCALE))
#define BIT_GET_SYSON_RCLK_SCALE(x) \
(((x) >> BIT_SHIFT_SYSON_RCLK_SCALE) & BIT_MASK_SYSON_RCLK_SCALE)
#define BIT_SET_SYSON_RCLK_SCALE(x, v) \
(BIT_CLEAR_SYSON_RCLK_SCALE(x) | BIT_SYSON_RCLK_SCALE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HCPWM1_V2 (Offset 0x10250038) */
#define BIT_CUR_PS BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CAL_TIMER (Offset 0x003C) */
#define BIT_SHIFT_CAL_SCAL 0
#define BIT_MASK_CAL_SCAL 0xff
#define BIT_CAL_SCAL(x) (((x) & BIT_MASK_CAL_SCAL) << BIT_SHIFT_CAL_SCAL)
#define BITS_CAL_SCAL (BIT_MASK_CAL_SCAL << BIT_SHIFT_CAL_SCAL)
#define BIT_CLEAR_CAL_SCAL(x) ((x) & (~BITS_CAL_SCAL))
#define BIT_GET_CAL_SCAL(x) (((x) >> BIT_SHIFT_CAL_SCAL) & BIT_MASK_CAL_SCAL)
#define BIT_SET_CAL_SCAL(x, v) (BIT_CLEAR_CAL_SCAL(x) | BIT_CAL_SCAL(v))
/* 2 REG_ACLK_MON (Offset 0x003E) */
#define BIT_SHIFT_RCLK_MON 5
#define BIT_MASK_RCLK_MON 0x7ff
#define BIT_RCLK_MON(x) (((x) & BIT_MASK_RCLK_MON) << BIT_SHIFT_RCLK_MON)
#define BITS_RCLK_MON (BIT_MASK_RCLK_MON << BIT_SHIFT_RCLK_MON)
#define BIT_CLEAR_RCLK_MON(x) ((x) & (~BITS_RCLK_MON))
#define BIT_GET_RCLK_MON(x) (((x) >> BIT_SHIFT_RCLK_MON) & BIT_MASK_RCLK_MON)
#define BIT_SET_RCLK_MON(x, v) (BIT_CLEAR_RCLK_MON(x) | BIT_RCLK_MON(v))
#define BIT_CAL_EN BIT(4)
#define BIT_SHIFT_DPSTU 2
#define BIT_MASK_DPSTU 0x3
#define BIT_DPSTU(x) (((x) & BIT_MASK_DPSTU) << BIT_SHIFT_DPSTU)
#define BITS_DPSTU (BIT_MASK_DPSTU << BIT_SHIFT_DPSTU)
#define BIT_CLEAR_DPSTU(x) ((x) & (~BITS_DPSTU))
#define BIT_GET_DPSTU(x) (((x) >> BIT_SHIFT_DPSTU) & BIT_MASK_DPSTU)
#define BIT_SET_DPSTU(x, v) (BIT_CLEAR_DPSTU(x) | BIT_DPSTU(v))
#define BIT_SUS_16X BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_ACLK_MON (Offset 0x003E) */
#define BIT_RSM_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG_2 (Offset 0x003F) */
#define BIT_SOUT_GPIO8 BIT(7)
#define BIT_SOUT_GPIO5 BIT(6)
#define BIT_RFE_CTRL_5_GPIO14_V1 BIT(5)
#define BIT_RFE_CTRL_10_GPIO13_V1 BIT(4)
#define BIT_RFE_CTRL_11_GPIO4_V1 BIT(3)
#define BIT_RFE_CTRL_5_GPIO14 BIT(2)
#define BIT_RFE_CTRL_10_GPIO13 BIT(1)
#define BIT_RFE_CTRL_11_GPIO4 BIT(0)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_RFE_CTRL_3_GPIO12 BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_PAPE_2G_E BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BT_RFE_CTRL_5_GPIO12 BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_PAPE_5G_E BIT(30)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SIC_LOWEST_PRIORITY_V1 BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_S0_TRSW_GPIO12 BIT(29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_TRSW_E BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SIC_PRI_LOWEST BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SIC_LOWEST_PRIORITY BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_RFE_CTRL_9_GPIO13 BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_TRSWB_E BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WL_DSS_RSTN BIT(27)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_RFE_CTRL_9_GPIO12 BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_PAPE_2G_O BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WL_DSS_EN_CLK BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_RFE_CTRL_8_GPIO4 BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_PAPE_5G_O BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BT_RFE_CTRL_1_GPIO13 BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_TRSW_O BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SHIFT_PIN_USECASE 24
#define BIT_MASK_PIN_USECASE 0xf
#define BIT_PIN_USECASE(x) \
(((x) & BIT_MASK_PIN_USECASE) << BIT_SHIFT_PIN_USECASE)
#define BITS_PIN_USECASE (BIT_MASK_PIN_USECASE << BIT_SHIFT_PIN_USECASE)
#define BIT_CLEAR_PIN_USECASE(x) ((x) & (~BITS_PIN_USECASE))
#define BIT_GET_PIN_USECASE(x) \
(((x) >> BIT_SHIFT_PIN_USECASE) & BIT_MASK_PIN_USECASE)
#define BIT_SET_PIN_USECASE(x, v) \
(BIT_CLEAR_PIN_USECASE(x) | BIT_PIN_USECASE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SHIFT_PIN_USECASE_V1 24
#define BIT_MASK_PIN_USECASE_V1 0x1f
#define BIT_PIN_USECASE_V1(x) \
(((x) & BIT_MASK_PIN_USECASE_V1) << BIT_SHIFT_PIN_USECASE_V1)
#define BITS_PIN_USECASE_V1 \
(BIT_MASK_PIN_USECASE_V1 << BIT_SHIFT_PIN_USECASE_V1)
#define BIT_CLEAR_PIN_USECASE_V1(x) ((x) & (~BITS_PIN_USECASE_V1))
#define BIT_GET_PIN_USECASE_V1(x) \
(((x) >> BIT_SHIFT_PIN_USECASE_V1) & BIT_MASK_PIN_USECASE_V1)
#define BIT_SET_PIN_USECASE_V1(x, v) \
(BIT_CLEAR_PIN_USECASE_V1(x) | BIT_PIN_USECASE_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BT_RFE_CTRL_1_GPIO12 BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PAD_D_TRSWB_O BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_DATACPU_GPIO2 BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BT_RFE_CTRL_0_GPIO4 BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_A_ANTSEL BIT(23)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_DATACPU_GPIO BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ANTSW_GPIO13 BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_A_ANTSELB BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_DATACPU_UART BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ANTSW_GPIO12 BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_D_PAPE_2G BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_DATACPU_FSPI_EN BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_INDIRECT_REG_CFG (Offset 0x10250040) */
#define BIT_INDIRECT_REG_RDY BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ANTSWB_GPIO4 BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_D_PAPE_5G BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_GPIO8_UART_OUT BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_FSPI_EN BIT(19)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SW_IO_EN BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_INDIRECT_REG_CFG (Offset 0x10250040) */
#define BIT_INDIRECT_REG_R BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WL_RTS_EXT_32K_SEL BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_INDIRECT_REG_CFG (Offset 0x10250040) */
#define BIT_INDIRECT_REG_W BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_CKOUT33_EN BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLBT_DPDT_SEL_EN BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_XTAL_OUT_EN BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLGP_SPI_EN BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLGP_CKOUT BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_INDIRECT_REG_CFG (Offset 0x10250040) */
#define BIT_SHIFT_INDIRECT_REG_SIZE 16
#define BIT_MASK_INDIRECT_REG_SIZE 0x3
#define BIT_INDIRECT_REG_SIZE(x) \
(((x) & BIT_MASK_INDIRECT_REG_SIZE) << BIT_SHIFT_INDIRECT_REG_SIZE)
#define BITS_INDIRECT_REG_SIZE \
(BIT_MASK_INDIRECT_REG_SIZE << BIT_SHIFT_INDIRECT_REG_SIZE)
#define BIT_CLEAR_INDIRECT_REG_SIZE(x) ((x) & (~BITS_INDIRECT_REG_SIZE))
#define BIT_GET_INDIRECT_REG_SIZE(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_SIZE) & BIT_MASK_INDIRECT_REG_SIZE)
#define BIT_SET_INDIRECT_REG_SIZE(x, v) \
(BIT_CLEAR_INDIRECT_REG_SIZE(x) | BIT_INDIRECT_REG_SIZE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLBT_LNAON_SEL_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SIC_LBK BIT(15)
#define BIT_ENHTP BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PHY_TEST_EN BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLPHY_DBG_EN BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BT_AOD_GPIO3 BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SIC_23 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ENSIC BIT(12)
#define BIT_SIC_SWRST BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PO_WIFI_PTA_PINS BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ENPMAC BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ENBTCMD BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_COEX_MBOX BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BTCOEX_MBOX_EN BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_PO_BT_PTA_PINS BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_BTCMD_OUT_EN BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ENUART BIT(8)
#define BIT_SHIFT_BTMODE 6
#define BIT_MASK_BTMODE 0x3
#define BIT_BTMODE(x) (((x) & BIT_MASK_BTMODE) << BIT_SHIFT_BTMODE)
#define BITS_BTMODE (BIT_MASK_BTMODE << BIT_SHIFT_BTMODE)
#define BIT_CLEAR_BTMODE(x) ((x) & (~BITS_BTMODE))
#define BIT_GET_BTMODE(x) (((x) >> BIT_SHIFT_BTMODE) & BIT_MASK_BTMODE)
#define BIT_SET_BTMODE(x, v) (BIT_CLEAR_BTMODE(x) | BIT_BTMODE(v))
#define BIT_ENBT BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_GEN1GEN2_SWITCH BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EROM_EN BIT(4)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_ENUARTTX BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLRFE_6_7_EN BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLRFE_12_EN BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_D_TRSW BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_WLRFE_4_5_EN BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SPDT_SEL BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_EN_D_TRSWB BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_MUXCFG (Offset 0x0040) */
#define BIT_SHIFT_GPIOSEL 0
#define BIT_MASK_GPIOSEL 0x3
#define BIT_GPIOSEL(x) (((x) & BIT_MASK_GPIOSEL) << BIT_SHIFT_GPIOSEL)
#define BITS_GPIOSEL (BIT_MASK_GPIOSEL << BIT_SHIFT_GPIOSEL)
#define BIT_CLEAR_GPIOSEL(x) ((x) & (~BITS_GPIOSEL))
#define BIT_GET_GPIOSEL(x) (((x) >> BIT_SHIFT_GPIOSEL) & BIT_MASK_GPIOSEL)
#define BIT_SET_GPIOSEL(x, v) (BIT_CLEAR_GPIOSEL(x) | BIT_GPIOSEL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_INDIRECT_REG_CFG (Offset 0x10250040) */
#define BIT_SHIFT_INDIRECT_REG_ADDR 0
#define BIT_MASK_INDIRECT_REG_ADDR 0xffff
#define BIT_INDIRECT_REG_ADDR(x) \
(((x) & BIT_MASK_INDIRECT_REG_ADDR) << BIT_SHIFT_INDIRECT_REG_ADDR)
#define BITS_INDIRECT_REG_ADDR \
(BIT_MASK_INDIRECT_REG_ADDR << BIT_SHIFT_INDIRECT_REG_ADDR)
#define BIT_CLEAR_INDIRECT_REG_ADDR(x) ((x) & (~BITS_INDIRECT_REG_ADDR))
#define BIT_GET_INDIRECT_REG_ADDR(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_ADDR) & BIT_MASK_INDIRECT_REG_ADDR)
#define BIT_SET_INDIRECT_REG_ADDR(x, v) \
(BIT_CLEAR_INDIRECT_REG_ADDR(x) | BIT_INDIRECT_REG_ADDR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_PIN_CTRL (Offset 0x0044) */
#define BIT_SHIFT_GPIO_MOD_7_TO_0 24
#define BIT_MASK_GPIO_MOD_7_TO_0 0xff
#define BIT_GPIO_MOD_7_TO_0(x) \
(((x) & BIT_MASK_GPIO_MOD_7_TO_0) << BIT_SHIFT_GPIO_MOD_7_TO_0)
#define BITS_GPIO_MOD_7_TO_0 \
(BIT_MASK_GPIO_MOD_7_TO_0 << BIT_SHIFT_GPIO_MOD_7_TO_0)
#define BIT_CLEAR_GPIO_MOD_7_TO_0(x) ((x) & (~BITS_GPIO_MOD_7_TO_0))
#define BIT_GET_GPIO_MOD_7_TO_0(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_7_TO_0) & BIT_MASK_GPIO_MOD_7_TO_0)
#define BIT_SET_GPIO_MOD_7_TO_0(x, v) \
(BIT_CLEAR_GPIO_MOD_7_TO_0(x) | BIT_GPIO_MOD_7_TO_0(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_PIN_CTRL (Offset 0x0044) */
#define BIT_SHIFT_WLGP1_SWIOMOD 24
#define BIT_MASK_WLGP1_SWIOMOD 0xff
#define BIT_WLGP1_SWIOMOD(x) \
(((x) & BIT_MASK_WLGP1_SWIOMOD) << BIT_SHIFT_WLGP1_SWIOMOD)
#define BITS_WLGP1_SWIOMOD (BIT_MASK_WLGP1_SWIOMOD << BIT_SHIFT_WLGP1_SWIOMOD)
#define BIT_CLEAR_WLGP1_SWIOMOD(x) ((x) & (~BITS_WLGP1_SWIOMOD))
#define BIT_GET_WLGP1_SWIOMOD(x) \
(((x) >> BIT_SHIFT_WLGP1_SWIOMOD) & BIT_MASK_WLGP1_SWIOMOD)
#define BIT_SET_WLGP1_SWIOMOD(x, v) \
(BIT_CLEAR_WLGP1_SWIOMOD(x) | BIT_WLGP1_SWIOMOD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_PIN_CTRL (Offset 0x0044) */
#define BIT_SHIFT_GPIO_IO_SEL_7_TO_0 16
#define BIT_MASK_GPIO_IO_SEL_7_TO_0 0xff
#define BIT_GPIO_IO_SEL_7_TO_0(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_7_TO_0) << BIT_SHIFT_GPIO_IO_SEL_7_TO_0)
#define BITS_GPIO_IO_SEL_7_TO_0 \
(BIT_MASK_GPIO_IO_SEL_7_TO_0 << BIT_SHIFT_GPIO_IO_SEL_7_TO_0)
#define BIT_CLEAR_GPIO_IO_SEL_7_TO_0(x) ((x) & (~BITS_GPIO_IO_SEL_7_TO_0))
#define BIT_GET_GPIO_IO_SEL_7_TO_0(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_7_TO_0) & BIT_MASK_GPIO_IO_SEL_7_TO_0)
#define BIT_SET_GPIO_IO_SEL_7_TO_0(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_7_TO_0(x) | BIT_GPIO_IO_SEL_7_TO_0(v))
#define BIT_SHIFT_GPIO_OUT_7_TO_0 8
#define BIT_MASK_GPIO_OUT_7_TO_0 0xff
#define BIT_GPIO_OUT_7_TO_0(x) \
(((x) & BIT_MASK_GPIO_OUT_7_TO_0) << BIT_SHIFT_GPIO_OUT_7_TO_0)
#define BITS_GPIO_OUT_7_TO_0 \
(BIT_MASK_GPIO_OUT_7_TO_0 << BIT_SHIFT_GPIO_OUT_7_TO_0)
#define BIT_CLEAR_GPIO_OUT_7_TO_0(x) ((x) & (~BITS_GPIO_OUT_7_TO_0))
#define BIT_GET_GPIO_OUT_7_TO_0(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_7_TO_0) & BIT_MASK_GPIO_OUT_7_TO_0)
#define BIT_SET_GPIO_OUT_7_TO_0(x, v) \
(BIT_CLEAR_GPIO_OUT_7_TO_0(x) | BIT_GPIO_OUT_7_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_PIN_CTRL (Offset 0x0044) */
#define BIT_SHIFT_GPIO_IN_7_TO_0 0
#define BIT_MASK_GPIO_IN_7_TO_0 0xff
#define BIT_GPIO_IN_7_TO_0(x) \
(((x) & BIT_MASK_GPIO_IN_7_TO_0) << BIT_SHIFT_GPIO_IN_7_TO_0)
#define BITS_GPIO_IN_7_TO_0 \
(BIT_MASK_GPIO_IN_7_TO_0 << BIT_SHIFT_GPIO_IN_7_TO_0)
#define BIT_CLEAR_GPIO_IN_7_TO_0(x) ((x) & (~BITS_GPIO_IN_7_TO_0))
#define BIT_GET_GPIO_IN_7_TO_0(x) \
(((x) >> BIT_SHIFT_GPIO_IN_7_TO_0) & BIT_MASK_GPIO_IN_7_TO_0)
#define BIT_SET_GPIO_IN_7_TO_0(x, v) \
(BIT_CLEAR_GPIO_IN_7_TO_0(x) | BIT_GPIO_IN_7_TO_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_INDIRECT_REG_DATA (Offset 0x10250044) */
#define BIT_SHIFT_INDIRECT_REG_DATA 0
#define BIT_MASK_INDIRECT_REG_DATA 0xffffffffL
#define BIT_INDIRECT_REG_DATA(x) \
(((x) & BIT_MASK_INDIRECT_REG_DATA) << BIT_SHIFT_INDIRECT_REG_DATA)
#define BITS_INDIRECT_REG_DATA \
(BIT_MASK_INDIRECT_REG_DATA << BIT_SHIFT_INDIRECT_REG_DATA)
#define BIT_CLEAR_INDIRECT_REG_DATA(x) ((x) & (~BITS_INDIRECT_REG_DATA))
#define BIT_GET_INDIRECT_REG_DATA(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_DATA) & BIT_MASK_INDIRECT_REG_DATA)
#define BIT_SET_INDIRECT_REG_DATA(x, v) \
(BIT_CLEAR_INDIRECT_REG_DATA(x) | BIT_INDIRECT_REG_DATA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_SHIFT_MUXDBG_SEL 30
#define BIT_MASK_MUXDBG_SEL 0x3
#define BIT_MUXDBG_SEL(x) (((x) & BIT_MASK_MUXDBG_SEL) << BIT_SHIFT_MUXDBG_SEL)
#define BITS_MUXDBG_SEL (BIT_MASK_MUXDBG_SEL << BIT_SHIFT_MUXDBG_SEL)
#define BIT_CLEAR_MUXDBG_SEL(x) ((x) & (~BITS_MUXDBG_SEL))
#define BIT_GET_MUXDBG_SEL(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL) & BIT_MASK_MUXDBG_SEL)
#define BIT_SET_MUXDBG_SEL(x, v) (BIT_CLEAR_MUXDBG_SEL(x) | BIT_MUXDBG_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_PCI_LPS_LDACT BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_SHIFT_MUXDBG_SEL2 28
#define BIT_MASK_MUXDBG_SEL2 0x3
#define BIT_MUXDBG_SEL2(x) \
(((x) & BIT_MASK_MUXDBG_SEL2) << BIT_SHIFT_MUXDBG_SEL2)
#define BITS_MUXDBG_SEL2 (BIT_MASK_MUXDBG_SEL2 << BIT_SHIFT_MUXDBG_SEL2)
#define BIT_CLEAR_MUXDBG_SEL2(x) ((x) & (~BITS_MUXDBG_SEL2))
#define BIT_GET_MUXDBG_SEL2(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL2) & BIT_MASK_MUXDBG_SEL2)
#define BIT_SET_MUXDBG_SEL2(x, v) \
(BIT_CLEAR_MUXDBG_SEL2(x) | BIT_MUXDBG_SEL2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_GPIO_EXT_EN BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_EXTWOL1_SEL BIT(19)
#define BIT_EXTWOL1_EN BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_EXTWOL0_SEL BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_BT_EXTWOL_DIS BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_EXTWOL_SEL BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_EXTWOL0_EN BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_EXTWOL_EN BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_SHIFT_GPIO_EXT_WOL_V1 16
#define BIT_MASK_GPIO_EXT_WOL_V1 0xf
#define BIT_GPIO_EXT_WOL_V1(x) \
(((x) & BIT_MASK_GPIO_EXT_WOL_V1) << BIT_SHIFT_GPIO_EXT_WOL_V1)
#define BITS_GPIO_EXT_WOL_V1 \
(BIT_MASK_GPIO_EXT_WOL_V1 << BIT_SHIFT_GPIO_EXT_WOL_V1)
#define BIT_CLEAR_GPIO_EXT_WOL_V1(x) ((x) & (~BITS_GPIO_EXT_WOL_V1))
#define BIT_GET_GPIO_EXT_WOL_V1(x) \
(((x) >> BIT_SHIFT_GPIO_EXT_WOL_V1) & BIT_MASK_GPIO_EXT_WOL_V1)
#define BIT_SET_GPIO_EXT_WOL_V1(x, v) \
(BIT_CLEAR_GPIO_EXT_WOL_V1(x) | BIT_GPIO_EXT_WOL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_INTM (Offset 0x0048) */
#define BIT_GPIOF_INT_MD BIT(15)
#define BIT_GPIOE_INT_MD BIT(14)
#define BIT_GPIOD_INT_MD BIT(13)
#define BIT_GPIOC_INT_MD BIT(12)
#define BIT_GPIOB_INT_MD BIT(11)
#define BIT_GPIOA_INT_MD BIT(10)
#define BIT_GPIO9_INT_MD BIT(9)
#define BIT_GPIO8_INT_MD BIT(8)
#define BIT_GPIO7_INT_MD BIT(7)
#define BIT_GPIO6_INT_MD BIT(6)
#define BIT_GPIO5_INT_MD BIT(5)
#define BIT_GPIO4_INT_MD BIT(4)
#define BIT_GPIO3_INT_MD BIT(3)
#define BIT_GPIO2_INT_MD BIT(2)
#define BIT_GPIO1_INT_MD BIT(1)
#define BIT_GPIO0_INT_MD BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_MAILBOX_1WIRE_GPIO_CFG BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAD_ANTSEL_I BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_ANT_SEL7_EN BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_BT_RF_GPIO_CFG BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAD_ANTSELB_I BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_ANT_SEL46_EN BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_BT_SDIO_INT_GPIO_CFG BIT(29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAD_D_PAPE_2G_I BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_ANT_SEL3_EN BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_MAILBOX_3WIRE_GPIO_CFG BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAD_D_PAPE_5G_I BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_TRSW_SEL_EN BIT(27)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_WLBT_PAPE_SEL_EN BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAD_D_TRSW_I BIT(27)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_GPIO3_WL_CTRL_EN BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAPE1_SEL_EN BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LNAON_SEL_EN BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAD_D_TRSWB_I BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAPE0_SEL_EN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_PAPE_SEL_EN BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_DWH_EN BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_ANTSEL2_EN BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_ANT01_EN BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_DPDT_WLBT_SEL BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_DHW_EN BIT(24)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_RFE_ANT_EXT_SEL BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_ANTSEL_EN BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_DPDT_SEL_EN BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_GPIO13_14_WL_CTRL_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_SW_SPDT_SEL BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LED2DIS_V1 BIT(22)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_TRXIQ_DBG_EN BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LED2DIS BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LED0_GPIO_EN BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LED2EN BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LED2PL BIT(20)
#define BIT_LED2SV BIT(19)
#define BIT_SHIFT_LED2CM 16
#define BIT_MASK_LED2CM 0x7
#define BIT_LED2CM(x) (((x) & BIT_MASK_LED2CM) << BIT_SHIFT_LED2CM)
#define BITS_LED2CM (BIT_MASK_LED2CM << BIT_SHIFT_LED2CM)
#define BIT_CLEAR_LED2CM(x) ((x) & (~BITS_LED2CM))
#define BIT_GET_LED2CM(x) (((x) >> BIT_SHIFT_LED2CM) & BIT_MASK_LED2CM)
#define BIT_SET_LED2CM(x, v) (BIT_CLEAR_LED2CM(x) | BIT_LED2CM(v))
#define BIT_LED1DIS BIT(15)
#define BIT_LED1PL BIT(12)
#define BIT_LED1SV BIT(11)
#define BIT_SHIFT_LED1CM 8
#define BIT_MASK_LED1CM 0x7
#define BIT_LED1CM(x) (((x) & BIT_MASK_LED1CM) << BIT_SHIFT_LED1CM)
#define BITS_LED1CM (BIT_MASK_LED1CM << BIT_SHIFT_LED1CM)
#define BIT_CLEAR_LED1CM(x) ((x) & (~BITS_LED1CM))
#define BIT_GET_LED1CM(x) (((x) >> BIT_SHIFT_LED1CM) & BIT_MASK_LED1CM)
#define BIT_SET_LED1CM(x, v) (BIT_CLEAR_LED1CM(x) | BIT_LED1CM(v))
#define BIT_LED0DIS BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_SHIFT_AFE_LDO_SWR_CHECK 5
#define BIT_MASK_AFE_LDO_SWR_CHECK 0x3
#define BIT_AFE_LDO_SWR_CHECK(x) \
(((x) & BIT_MASK_AFE_LDO_SWR_CHECK) << BIT_SHIFT_AFE_LDO_SWR_CHECK)
#define BITS_AFE_LDO_SWR_CHECK \
(BIT_MASK_AFE_LDO_SWR_CHECK << BIT_SHIFT_AFE_LDO_SWR_CHECK)
#define BIT_CLEAR_AFE_LDO_SWR_CHECK(x) ((x) & (~BITS_AFE_LDO_SWR_CHECK))
#define BIT_GET_AFE_LDO_SWR_CHECK(x) \
(((x) >> BIT_SHIFT_AFE_LDO_SWR_CHECK) & BIT_MASK_AFE_LDO_SWR_CHECK)
#define BIT_SET_AFE_LDO_SWR_CHECK(x, v) \
(BIT_CLEAR_AFE_LDO_SWR_CHECK(x) | BIT_AFE_LDO_SWR_CHECK(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LED_CFG (Offset 0x004C) */
#define BIT_LED0PL BIT(4)
#define BIT_LED0SV BIT(3)
#define BIT_SHIFT_LED0CM 0
#define BIT_MASK_LED0CM 0x7
#define BIT_LED0CM(x) (((x) & BIT_MASK_LED0CM) << BIT_SHIFT_LED0CM)
#define BITS_LED0CM (BIT_MASK_LED0CM << BIT_SHIFT_LED0CM)
#define BIT_CLEAR_LED0CM(x) ((x) & (~BITS_LED0CM))
#define BIT_GET_LED0CM(x) (((x) >> BIT_SHIFT_LED0CM) & BIT_MASK_LED0CM)
#define BIT_SET_LED0CM(x, v) (BIT_CLEAR_LED0CM(x) | BIT_LED0CM(v))
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_PDNINT_EN BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_NFC_INT_PAD_EN BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_SPS_OCP_INT_EN BIT(29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_SW_SPS_OCP_INT_EN BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_PWMERR_INT_EN BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_PWM_HW_ERR_EN BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOF_INT_EN BIT(27)
#define BIT_FS_GPIOE_INT_EN BIT(26)
#define BIT_FS_GPIOD_INT_EN BIT(25)
#define BIT_FS_GPIOC_INT_EN BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_ACT2RECOVERY_INT_EN BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOB_INT_EN BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_PCIE_GEN12_SWITCH_EN BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOA_INT_EN BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_HCI_SUS_EN_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO9_INT_EN BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_HCI_RES_EN_V1 BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO8_INT_EN BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_HCI_RESET_EN_V1 BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO7_INT_EN BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_32K_LEAVE_SETTING_EN BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO6_INT_EN BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_32K_ENTER_SETTING_EN BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO5_INT_EN BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_SIE_LPM_RSM_EN_V1 BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO4_INT_EN BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_SIE_LPM_ACT_EN_V1 BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO3_INT_EN BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOF_INT_EN_V1 BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO2_INT_EN BIT(14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOE_INT_EN_V1 BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO1_INT_EN BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOD_INT_EN_V1 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO0_INT_EN BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOC_INT_EN_V1 BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_HCI_SUS_EN BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOB_INT_EN_V1 BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_HCI_RES_EN BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIOA_INT_EN_V1 BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_HCI_RESET_EN BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO9_INT_EN_V1 BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_AXI_EXCEPT_FINT_EN BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_USB_SCSI_CMD_EN BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO8_INT_EN_V1 BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_BTON_STS_UPDATE_MSK_EN BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO7_INT_EN_V1 BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_ACT2RECOVERY_INT_EN_V1 BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO6_INT_EN_V1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_TRPC_TO_INT_EN BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO5_INT_EN_V1 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_RPC_O_T_INT_EN BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_HCI_TXDMA_REQ_HIMR BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO4_INT_EN_V1 BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_32K_LEAVE_SETTING_MAK BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO3_INT_EN_V1 BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_32K_ENTER_SETTING_MAK BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO2_INT_EN_V1 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_USB_LPMRSM_MSK BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO1_INT_EN_V1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_USB_LPMINT_MSK BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSIMR (Offset 0x0050) */
#define BIT_FS_GPIO0_INT_EN_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_PDNINT BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_SPS_OCP_INT BIT(29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_SW_SPS_OCP_INT BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_PWMERR_INT BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_PWM_HW_ERR BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOF_INT BIT(27)
#define BIT_FS_GPIOE_INT BIT(26)
#define BIT_FS_GPIOD_INT BIT(25)
#define BIT_FS_GPIOC_INT BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_ACT2RECOVERY_INT BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOB_INT BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_PCIE_GEN12_SWITCH BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOA_INT BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_HCI_SUS_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO9_INT BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_HCI_RES_V1 BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO8_INT BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_HCI_RESET_V1 BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO7_INT BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_32K_LEAVE_SETTING BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO6_INT BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_32K_ENTER_SETTING BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO5_INT BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_SIE_LPM_RSM_V1 BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO4_INT BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_SIE_LPM_ACT_V1 BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO3_INT BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOF_INT_V1 BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO2_INT BIT(14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOE_INT_V1 BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO1_INT BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOD_INT_V1 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO0_INT BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOC_INT_V1 BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_HCI_SUS_INT BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOB_INT_V1 BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_HCI_RES_INT BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIOA_INT_V1 BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_HCI_RESET_INT BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO9_INT_V1 BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_AXI_EXCEPT_FINT BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_USB_SCSI_CMD_INT BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO8_INT_V1 BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_BTON_STS_UPDATE_INT BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO7_INT_V1 BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_ACT2RECOVERY_INT_V1 BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_ACT2RECOVERY BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO6_INT_V1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_TRPC_TO_INT_INT BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO5_INT_V1 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_RPC_O_T_INT_INT BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_HCI_TXDMA_REQ_HISR BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO4_INT_V1 BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_32K_LEAVE_SETTING_INT BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO3_INT_V1 BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_32K_ENTER_SETTING_INT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO2_INT_V1 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_USB_LPMRSM_INT BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO1_INT_V1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_USB_LPMINT_INT BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FSISR (Offset 0x0054) */
#define BIT_FS_GPIO0_INT_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_GPIOF_INT_EN BIT(31)
#define BIT_GPIOE_INT_EN BIT(30)
#define BIT_GPIOD_INT_EN BIT(29)
#define BIT_GPIOC_INT_EN BIT(28)
#define BIT_GPIOB_INT_EN BIT(27)
#define BIT_GPIOA_INT_EN BIT(26)
#define BIT_GPIO9_INT_EN BIT(25)
#define BIT_GPIO8_INT_EN BIT(24)
#define BIT_GPIO7_INT_EN BIT(23)
#define BIT_GPIO6_INT_EN BIT(22)
#define BIT_GPIO5_INT_EN BIT(21)
#define BIT_GPIO4_INT_EN BIT(20)
#define BIT_GPIO3_INT_EN BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_GPIO2_INT_EN BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_GPIO2_INT_EN_V1 BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_GPIO1_INT_EN BIT(17)
#define BIT_GPIO0_INT_EN BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_AXI_EXCEPT_HINT_EN BIT(9)
#define BIT_PDNINT_EN_V2 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_PDNINT_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_PDNINT_EN_V1 BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_PDN_INT_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_RON_INT_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_RON_INT_EN_V1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_SPS_OCP_INT_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_SPS_OCP_INT_EN_V1 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_GPIO15_0_INT_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSIMR (Offset 0x0058) */
#define BIT_GPIO15_0_INT_EN_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_GPIOF_INT BIT(31)
#define BIT_GPIOE_INT BIT(30)
#define BIT_GPIOD_INT BIT(29)
#define BIT_GPIOC_INT BIT(28)
#define BIT_GPIOB_INT BIT(27)
#define BIT_GPIOA_INT BIT(26)
#define BIT_GPIO9_INT BIT(25)
#define BIT_GPIO8_INT BIT(24)
#define BIT_GPIO7_INT BIT(23)
#define BIT_GPIO6_INT BIT(22)
#define BIT_GPIO5_INT BIT(21)
#define BIT_GPIO4_INT BIT(20)
#define BIT_GPIO3_INT BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_GPIO2_INT BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_GPIO2_INT_V1 BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_GPIO1_INT BIT(17)
#define BIT_GPIO0_INT BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_AXI_EXCEPT_HINT BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_PDNINT BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_PDNINT_V1 BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_PDN_INT BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_RON_INT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_RON_INT_V1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_SPS_OCP_INT BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_SPS_OCP_INT_V1 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_GPIO15_0_INT BIT(0)
#define BIT_MCUFWDL_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HSISR (Offset 0x005C) */
#define BIT_GPIO15_0_INT_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_EXT_CTRL (Offset 0x0060) */
#define BIT_SHIFT_GPIO_MOD_15_TO_8 24
#define BIT_MASK_GPIO_MOD_15_TO_8 0xff
#define BIT_GPIO_MOD_15_TO_8(x) \
(((x) & BIT_MASK_GPIO_MOD_15_TO_8) << BIT_SHIFT_GPIO_MOD_15_TO_8)
#define BITS_GPIO_MOD_15_TO_8 \
(BIT_MASK_GPIO_MOD_15_TO_8 << BIT_SHIFT_GPIO_MOD_15_TO_8)
#define BIT_CLEAR_GPIO_MOD_15_TO_8(x) ((x) & (~BITS_GPIO_MOD_15_TO_8))
#define BIT_GET_GPIO_MOD_15_TO_8(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_15_TO_8) & BIT_MASK_GPIO_MOD_15_TO_8)
#define BIT_SET_GPIO_MOD_15_TO_8(x, v) \
(BIT_CLEAR_GPIO_MOD_15_TO_8(x) | BIT_GPIO_MOD_15_TO_8(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_EXT_CTRL (Offset 0x0060) */
#define BIT_ROM_DLEN BIT(19)
#define BIT_SHIFT_GPIO_IO_SEL_15_TO_8 16
#define BIT_MASK_GPIO_IO_SEL_15_TO_8 0xff
#define BIT_GPIO_IO_SEL_15_TO_8(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_15_TO_8) << BIT_SHIFT_GPIO_IO_SEL_15_TO_8)
#define BITS_GPIO_IO_SEL_15_TO_8 \
(BIT_MASK_GPIO_IO_SEL_15_TO_8 << BIT_SHIFT_GPIO_IO_SEL_15_TO_8)
#define BIT_CLEAR_GPIO_IO_SEL_15_TO_8(x) ((x) & (~BITS_GPIO_IO_SEL_15_TO_8))
#define BIT_GET_GPIO_IO_SEL_15_TO_8(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_15_TO_8) & BIT_MASK_GPIO_IO_SEL_15_TO_8)
#define BIT_SET_GPIO_IO_SEL_15_TO_8(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_15_TO_8(x) | BIT_GPIO_IO_SEL_15_TO_8(v))
#define BIT_SHIFT_ROM_PGE 16
#define BIT_MASK_ROM_PGE 0x7
#define BIT_ROM_PGE(x) (((x) & BIT_MASK_ROM_PGE) << BIT_SHIFT_ROM_PGE)
#define BITS_ROM_PGE (BIT_MASK_ROM_PGE << BIT_SHIFT_ROM_PGE)
#define BIT_CLEAR_ROM_PGE(x) ((x) & (~BITS_ROM_PGE))
#define BIT_GET_ROM_PGE(x) (((x) >> BIT_SHIFT_ROM_PGE) & BIT_MASK_ROM_PGE)
#define BIT_SET_ROM_PGE(x, v) (BIT_CLEAR_ROM_PGE(x) | BIT_ROM_PGE(v))
#define BIT_SHIFT_GPIO_OUT_15_TO_8 8
#define BIT_MASK_GPIO_OUT_15_TO_8 0xff
#define BIT_GPIO_OUT_15_TO_8(x) \
(((x) & BIT_MASK_GPIO_OUT_15_TO_8) << BIT_SHIFT_GPIO_OUT_15_TO_8)
#define BITS_GPIO_OUT_15_TO_8 \
(BIT_MASK_GPIO_OUT_15_TO_8 << BIT_SHIFT_GPIO_OUT_15_TO_8)
#define BIT_CLEAR_GPIO_OUT_15_TO_8(x) ((x) & (~BITS_GPIO_OUT_15_TO_8))
#define BIT_GET_GPIO_OUT_15_TO_8(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_15_TO_8) & BIT_MASK_GPIO_OUT_15_TO_8)
#define BIT_SET_GPIO_OUT_15_TO_8(x, v) \
(BIT_CLEAR_GPIO_OUT_15_TO_8(x) | BIT_GPIO_OUT_15_TO_8(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_EXT_CTRL (Offset 0x0060) */
#define BIT_SHIFT_GPIO_IN_15_TO_8 0
#define BIT_MASK_GPIO_IN_15_TO_8 0xff
#define BIT_GPIO_IN_15_TO_8(x) \
(((x) & BIT_MASK_GPIO_IN_15_TO_8) << BIT_SHIFT_GPIO_IN_15_TO_8)
#define BITS_GPIO_IN_15_TO_8 \
(BIT_MASK_GPIO_IN_15_TO_8 << BIT_SHIFT_GPIO_IN_15_TO_8)
#define BIT_CLEAR_GPIO_IN_15_TO_8(x) ((x) & (~BITS_GPIO_IN_15_TO_8))
#define BIT_GET_GPIO_IN_15_TO_8(x) \
(((x) >> BIT_SHIFT_GPIO_IN_15_TO_8) & BIT_MASK_GPIO_IN_15_TO_8)
#define BIT_SET_GPIO_IN_15_TO_8(x, v) \
(BIT_CLEAR_GPIO_IN_15_TO_8(x) | BIT_GPIO_IN_15_TO_8(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_H2C (Offset 0x10250060) */
#define BIT_SHIFT_SDIO_H2C_MSG 0
#define BIT_MASK_SDIO_H2C_MSG 0xffffffffL
#define BIT_SDIO_H2C_MSG(x) \
(((x) & BIT_MASK_SDIO_H2C_MSG) << BIT_SHIFT_SDIO_H2C_MSG)
#define BITS_SDIO_H2C_MSG (BIT_MASK_SDIO_H2C_MSG << BIT_SHIFT_SDIO_H2C_MSG)
#define BIT_CLEAR_SDIO_H2C_MSG(x) ((x) & (~BITS_SDIO_H2C_MSG))
#define BIT_GET_SDIO_H2C_MSG(x) \
(((x) >> BIT_SHIFT_SDIO_H2C_MSG) & BIT_MASK_SDIO_H2C_MSG)
#define BIT_SET_SDIO_H2C_MSG(x, v) \
(BIT_CLEAR_SDIO_H2C_MSG(x) | BIT_SDIO_H2C_MSG(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_DATA_CPU_JTAG BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAPE_WLBT_SEL BIT(29)
#define BIT_LNAON_WLBT_SEL BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BDEN BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BT_BQB_GPIO_SEL BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_GPG3_FEN BIT(26)
#define BIT_BTGP_GPG2_FEN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_JTAG_EN BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BB2PP_ISO BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_XTAL_CLK_EXTARNAL_EN BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTBRI_UART_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_UART0_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_UART1_EN BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTCOEX_PU BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_SPI_EN BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_EEPROM_SEL_PD BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_GPIO_E2 BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_TST_MOD_PD BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTGP_GPIO_EN BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BOOT_FLUSH_PD BIT(18)
#define BIT_USB_XTAL_SEL1_PD BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SHIFT_BTGP_GPIO_SL 16
#define BIT_MASK_BTGP_GPIO_SL 0x3
#define BIT_BTGP_GPIO_SL(x) \
(((x) & BIT_MASK_BTGP_GPIO_SL) << BIT_SHIFT_BTGP_GPIO_SL)
#define BITS_BTGP_GPIO_SL (BIT_MASK_BTGP_GPIO_SL << BIT_SHIFT_BTGP_GPIO_SL)
#define BIT_CLEAR_BTGP_GPIO_SL(x) ((x) & (~BITS_BTGP_GPIO_SL))
#define BIT_GET_BTGP_GPIO_SL(x) \
(((x) >> BIT_SHIFT_BTGP_GPIO_SL) & BIT_MASK_BTGP_GPIO_SL)
#define BIT_SET_BTGP_GPIO_SL(x, v) \
(BIT_CLEAR_BTGP_GPIO_SL(x) | BIT_BTGP_GPIO_SL(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_USB_XTAL_SEL0_PD BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_HST_WKE_DEV_SL BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_BTSUSB_PL BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_WL_JTAG BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_SDIO_SR BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_GPIO14_OUTPUT_PL BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_DEVWHOST_POLARITY BIT(13)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_GPIO15_OUTPUT_PL BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_HOST_WAKE_PAD_PULL_EN BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_HOST_WAKE_DEV_PLL_EN BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_HOST_WAKE_PAD_SL BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_TRSW_3 BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_HOST_WAKE_DEV_POLARITY BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_TRSW_SR BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_LNAON_SR BIT(10)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_TRSW_2 BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_TRSW_E2 BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_LNAON_E2 BIT(9)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_TRSW_1 BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_A_ANTSEL_SR BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_TRSW_P_SEL_DATA BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_LNAON_G_SEL_DATA BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_TRSW_0 BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_A_ANTSEL_E2 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_TRSW_N_SEL_DATA BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_LNAON_A_SEL_DATA BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_3 BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_PAPE_2G_SR BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_PAPE_SR BIT(6)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_2 BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_PAPE_5G_SR BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_PAPE_E2 BIT(5)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_1 BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_TRSW_SR BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_1_SEL_DATA BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_G_SEL_DATA BIT(4)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_0 BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_TRSWB_SR BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_0_SEL_DATA BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_PAPE_A_SEL_DATA BIT(3)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_3 BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_PAPE_2G_E2 BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_2_SEL_DATA BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_DPDT_SR BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_2 BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_PAPE_5G_E2 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_N_SEL_DATA BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_DPDT_PAD_E2 BIT(1)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_1 BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_TRSW_E2 BIT(1)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_PAD_DPDT_E2 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_P_SEL_DATA BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_DPDT_SEL_DATA BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_SW_ANTSEL_0 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_C2H (Offset 0x10250064) */
#define BIT_SHIFT_SDIO_C2H_MSG 0
#define BIT_MASK_SDIO_C2H_MSG 0xffffffffL
#define BIT_SDIO_C2H_MSG(x) \
(((x) & BIT_MASK_SDIO_C2H_MSG) << BIT_SHIFT_SDIO_C2H_MSG)
#define BITS_SDIO_C2H_MSG (BIT_MASK_SDIO_C2H_MSG << BIT_SHIFT_SDIO_C2H_MSG)
#define BIT_CLEAR_SDIO_C2H_MSG(x) ((x) & (~BITS_SDIO_C2H_MSG))
#define BIT_GET_SDIO_C2H_MSG(x) \
(((x) >> BIT_SHIFT_SDIO_C2H_MSG) & BIT_MASK_SDIO_C2H_MSG)
#define BIT_SET_SDIO_C2H_MSG(x, v) \
(BIT_CLEAR_SDIO_C2H_MSG(x) | BIT_SDIO_C2H_MSG(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL1 (Offset 0x0064) */
#define BIT_D_TRSWB_E2 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_ISO_BD2PP BIT(31)
#define BIT_LDOV12B_EN BIT(30)
#define BIT_CKEN_BTGPS BIT(29)
#define BIT_FEN_BTGPS BIT(28)
#define BIT_BTCPU_BOOTSEL BIT(27)
#define BIT_SPI_SPEEDUP BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_LPS_EN BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_LDO_MODE BIT(25)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_SUS BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_DEVWAKE_PAD_TYPE_SEL BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_CLKREQ_PAD_PL BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_CLKREQ_PAD_TYPE_SEL BIT(23)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_CKSL_BZSLP BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_EN_CPL_TIMEOUT_PS BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_WAKE_HST_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BTGP_WAKE_HST_EN BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_ISO_BTPON2PP BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_REG_TXDMA_FAIL_PS BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WAKE_BT_EN BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BTGP_WAKE_BT_EN BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BTCOEX_CMD BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_EN_BT BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BTGP_EN BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_UART_INTF BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_EN_HWENTR_L1 BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_SUSN_EN BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BTGP_SUS_EN BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_HWROF_EN BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_S3_RF_HW_EN BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_EN_ADV_CLKGATE BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_FUNC_EN BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_S2_RF_HW_EN BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_HWPDN_SL BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_S1_RF_HW_EN BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_DISN_EN BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_HWPDEN BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_S0_RF_HW_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_PDN_PULL_EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WL_PDN_PULL_EN BIT(14)
#define BIT_EXTERNAL_REQUEST_PL BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_GPIO0_2_3_PULL_LOW_EN BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_ISO_BA2PP BIT(11)
#define BIT_BT_AFE_LDO_EN BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_PDN_PIN_SEL BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_GPIO11_PULL_LOW_EN BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_AFE_PLL_EN BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_GPIO4_PULL_LOW_EN BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_DIG_CLK_EN BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_WAKE_HST_SL BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BT_WAKE_HST_PL BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_ASSERT_SPS_EN BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_UART_BRIDGE BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WAKE_BT_SL BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WAKE_BT_PL BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WLAN_32K_SEL BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_MASK_CHIPEN BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_OSC32K_CTRL_SEL BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WL_DRV_EXIST_IDX BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_ASSERT_RF_EN BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_DOP_EHPAD BIT(4)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_BIT_DOP_EHPAD BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WL_HWROF_EN BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_SDIO_PAD_SHUTDOWNB BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WL_FUNC_EN BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_SDIO_CLK_SMT BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WL_BT_PWR_CTRL (Offset 0x0068) */
#define BIT_WL_HWPDN_SL BIT(1)
#define BIT_WL_HWPDN_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_SHIFT_F0N 23
#define BIT_MASK_F0N 0x7
#define BIT_F0N(x) (((x) & BIT_MASK_F0N) << BIT_SHIFT_F0N)
#define BITS_F0N (BIT_MASK_F0N << BIT_SHIFT_F0N)
#define BIT_CLEAR_F0N(x) ((x) & (~BITS_F0N))
#define BIT_GET_F0N(x) (((x) >> BIT_SHIFT_F0N) & BIT_MASK_F0N)
#define BIT_SET_F0N(x, v) (BIT_CLEAR_F0N(x) | BIT_F0N(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_BT_WAKE_DEV_EN_V1 BIT(19)
#define BIT_BT_WAKE_HST_EN_V1 BIT(18)
#define BIT_BT_WAKE_HST_PL_V1 BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GSSR (Offset 0x006C) */
#define BIT_SHIFT_GPIO_15_TO_0_VAL 16
#define BIT_MASK_GPIO_15_TO_0_VAL 0xffff
#define BIT_GPIO_15_TO_0_VAL(x) \
(((x) & BIT_MASK_GPIO_15_TO_0_VAL) << BIT_SHIFT_GPIO_15_TO_0_VAL)
#define BITS_GPIO_15_TO_0_VAL \
(BIT_MASK_GPIO_15_TO_0_VAL << BIT_SHIFT_GPIO_15_TO_0_VAL)
#define BIT_CLEAR_GPIO_15_TO_0_VAL(x) ((x) & (~BITS_GPIO_15_TO_0_VAL))
#define BIT_GET_GPIO_15_TO_0_VAL(x) \
(((x) >> BIT_SHIFT_GPIO_15_TO_0_VAL) & BIT_MASK_GPIO_15_TO_0_VAL)
#define BIT_SET_GPIO_15_TO_0_VAL(x, v) \
(BIT_CLEAR_GPIO_15_TO_0_VAL(x) | BIT_GPIO_15_TO_0_VAL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_BT_CLKREQ_EN_V1 BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_SHIFT_F0F 10
#define BIT_MASK_F0F 0x1fff
#define BIT_F0F(x) (((x) & BIT_MASK_F0F) << BIT_SHIFT_F0F)
#define BITS_F0F (BIT_MASK_F0F << BIT_SHIFT_F0F)
#define BIT_CLEAR_F0F(x) ((x) & (~BITS_F0F))
#define BIT_GET_F0F(x) (((x) >> BIT_SHIFT_F0F) & BIT_MASK_F0F)
#define BIT_SET_F0F(x, v) (BIT_CLEAR_F0F(x) | BIT_F0F(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_GPIO_IE_V18 BIT(10)
#define BIT_PCIE_IE_V18 BIT(9)
#define BIT_UART_IE_V18 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_SHIFT_DIVN 4
#define BIT_MASK_DIVN 0x3f
#define BIT_DIVN(x) (((x) & BIT_MASK_DIVN) << BIT_SHIFT_DIVN)
#define BITS_DIVN (BIT_MASK_DIVN << BIT_SHIFT_DIVN)
#define BIT_CLEAR_DIVN(x) ((x) & (~BITS_DIVN))
#define BIT_GET_DIVN(x) (((x) >> BIT_SHIFT_DIVN) & BIT_MASK_DIVN)
#define BIT_SET_DIVN(x, v) (BIT_CLEAR_DIVN(x) | BIT_DIVN(v))
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM 0
#define BIT_MASK_BB_DBG_SEL_AFE_SDM 0xf
#define BIT_BB_DBG_SEL_AFE_SDM(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM) << BIT_SHIFT_BB_DBG_SEL_AFE_SDM)
#define BITS_BB_DBG_SEL_AFE_SDM \
(BIT_MASK_BB_DBG_SEL_AFE_SDM << BIT_SHIFT_BB_DBG_SEL_AFE_SDM)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM(x) ((x) & (~BITS_BB_DBG_SEL_AFE_SDM))
#define BIT_GET_BB_DBG_SEL_AFE_SDM(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM) & BIT_MASK_BB_DBG_SEL_AFE_SDM)
#define BIT_SET_BB_DBG_SEL_AFE_SDM(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM(x) | BIT_BB_DBG_SEL_AFE_SDM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDM_DEBUG (Offset 0x006C) */
#define BIT_SHIFT_WLCLK_PHASE 0
#define BIT_MASK_WLCLK_PHASE 0x1f
#define BIT_WLCLK_PHASE(x) \
(((x) & BIT_MASK_WLCLK_PHASE) << BIT_SHIFT_WLCLK_PHASE)
#define BITS_WLCLK_PHASE (BIT_MASK_WLCLK_PHASE << BIT_SHIFT_WLCLK_PHASE)
#define BIT_CLEAR_WLCLK_PHASE(x) ((x) & (~BITS_WLCLK_PHASE))
#define BIT_GET_WLCLK_PHASE(x) \
(((x) >> BIT_SHIFT_WLCLK_PHASE) & BIT_MASK_WLCLK_PHASE)
#define BIT_SET_WLCLK_PHASE(x, v) \
(BIT_CLEAR_WLCLK_PHASE(x) | BIT_WLCLK_PHASE(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_GSSR (Offset 0x006C) */
#define BIT_SHIFT_GPIO_15_TO_0_EN 0
#define BIT_MASK_GPIO_15_TO_0_EN 0xffff
#define BIT_GPIO_15_TO_0_EN(x) \
(((x) & BIT_MASK_GPIO_15_TO_0_EN) << BIT_SHIFT_GPIO_15_TO_0_EN)
#define BITS_GPIO_15_TO_0_EN \
(BIT_MASK_GPIO_15_TO_0_EN << BIT_SHIFT_GPIO_15_TO_0_EN)
#define BIT_CLEAR_GPIO_15_TO_0_EN(x) ((x) & (~BITS_GPIO_15_TO_0_EN))
#define BIT_GET_GPIO_15_TO_0_EN(x) \
(((x) >> BIT_SHIFT_GPIO_15_TO_0_EN) & BIT_MASK_GPIO_15_TO_0_EN)
#define BIT_SET_GPIO_15_TO_0_EN(x, v) \
(BIT_CLEAR_GPIO_15_TO_0_EN(x) | BIT_GPIO_15_TO_0_EN(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_FORCE_RST_PCIE_APHY BIT(30)
#define BIT_FORCE_OFF_EPC BIT(29)
#define BIT_PTA_3W_MODE BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_BBRSTB_STANDBY_V1 BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_DBG_GNT_WL_BT BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_AFE_PORT3_ISO BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_LTE_MUX_CTRL_PATH BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_AFE_PORT2_ISO BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_LTE_COEX_EN BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_LTE_COEX_UART BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_AFE_PORT1_ISO BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_3W_LTE_GPIO_EN BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_3W_LTE_WL_GPIO BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_AFE_PORT0_ISO BIT(24)
#define BIT_USB_PWR_OFF_SEL BIT(23)
#define BIT_USB_HOST_PWR_OFF_EN_V1 BIT(22)
#define BIT_SYM_LPS_BLOCK_EN_V1 BIT(21)
#define BIT_USB_LPM_ACT_EN_V1 BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_SDIO_INT_POLARITY BIT(19)
#define BIT_SDIO_INT BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_SDIO_OFF_EN BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_SDIO_OFF_EN_V1 BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_SDIO_ON_EN BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_SDIO_ON_EN_V1 BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_PCIE_FORCE_PWR_NGAT BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_DIS_U3MB_INU2 BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_PCIE_CALIB_EN_V1 BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_USB3_MDIO_EN BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_PAGE3_AUXCLK_GATE BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_USB3_BG_EN BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_PCIE_WAIT_TIMEOUT_EVENT BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_USB3_MB_EN BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_PCIE_WAIT_TIME BIT(9)
#define BIT_MPCIE_REFCLK_XTAL_SEL BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_SHIFT_USB3_CK_MD 8
#define BIT_MASK_USB3_CK_MD 0x3
#define BIT_USB3_CK_MD(x) (((x) & BIT_MASK_USB3_CK_MD) << BIT_SHIFT_USB3_CK_MD)
#define BITS_USB3_CK_MD (BIT_MASK_USB3_CK_MD << BIT_SHIFT_USB3_CK_MD)
#define BIT_CLEAR_USB3_CK_MD(x) ((x) & (~BITS_USB3_CK_MD))
#define BIT_GET_USB3_CK_MD(x) \
(((x) >> BIT_SHIFT_USB3_CK_MD) & BIT_MASK_USB3_CK_MD)
#define BIT_SET_USB3_CK_MD(x, v) (BIT_CLEAR_USB3_CK_MD(x) | BIT_USB3_CK_MD(v))
#define BIT_USB3_CKBUF BIT(7)
#define BIT_USB3_IBX_EN BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_BT_CLKREQ_EN BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_BT_CTRL_USB_PWR_BACKDOOR BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_U3_MB_MASK BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_USB_D_STATE_HOLD BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_U3_BG_MASK BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_SHIFT_USB_CKREF_CML_R 4
#define BIT_MASK_USB_CKREF_CML_R 0x3
#define BIT_USB_CKREF_CML_R(x) \
(((x) & BIT_MASK_USB_CKREF_CML_R) << BIT_SHIFT_USB_CKREF_CML_R)
#define BITS_USB_CKREF_CML_R \
(BIT_MASK_USB_CKREF_CML_R << BIT_SHIFT_USB_CKREF_CML_R)
#define BIT_CLEAR_USB_CKREF_CML_R(x) ((x) & (~BITS_USB_CKREF_CML_R))
#define BIT_GET_USB_CKREF_CML_R(x) \
(((x) >> BIT_SHIFT_USB_CKREF_CML_R) & BIT_MASK_USB_CKREF_CML_R)
#define BIT_SET_USB_CKREF_CML_R(x, v) \
(BIT_CLEAR_USB_CKREF_CML_R(x) | BIT_USB_CKREF_CML_R(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_REG_FORCE_DP BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_DIS_USB3_MB_POLLING BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_BTGP_CLKREQ_EN BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_REG_DP_MODE BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_PDN_MASK BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_SHIFT_USB_CKREF_D2S_I 2
#define BIT_MASK_USB_CKREF_D2S_I 0x3
#define BIT_USB_CKREF_D2S_I(x) \
(((x) & BIT_MASK_USB_CKREF_D2S_I) << BIT_SHIFT_USB_CKREF_D2S_I)
#define BITS_USB_CKREF_D2S_I \
(BIT_MASK_USB_CKREF_D2S_I << BIT_SHIFT_USB_CKREF_D2S_I)
#define BIT_CLEAR_USB_CKREF_D2S_I(x) ((x) & (~BITS_USB_CKREF_D2S_I))
#define BIT_GET_USB_CKREF_D2S_I(x) \
(((x) >> BIT_SHIFT_USB_CKREF_D2S_I) & BIT_MASK_USB_CKREF_D2S_I)
#define BIT_SET_USB_CKREF_D2S_I(x, v) \
(BIT_CLEAR_USB_CKREF_D2S_I(x) | BIT_USB_CKREF_D2S_I(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_USB_INSTALL_EN BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_RES_USB_MASS_STORAGE_DESC BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_NO_PDN_CHIPOFF BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_USB_BT_CLKSEL BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_USB_WAIT_TIME BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CLKR (Offset 0x0070) */
#define BIT_PDN_HCOUNT BIT(0)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_SDIO_CTRL (Offset 0x0070) */
#define BIT_SHIFT_SI_AUTHORIZATION 0
#define BIT_MASK_SI_AUTHORIZATION 0xff
#define BIT_SI_AUTHORIZATION(x) \
(((x) & BIT_MASK_SI_AUTHORIZATION) << BIT_SHIFT_SI_AUTHORIZATION)
#define BITS_SI_AUTHORIZATION \
(BIT_MASK_SI_AUTHORIZATION << BIT_SHIFT_SI_AUTHORIZATION)
#define BIT_CLEAR_SI_AUTHORIZATION(x) ((x) & (~BITS_SI_AUTHORIZATION))
#define BIT_GET_SI_AUTHORIZATION(x) \
(((x) >> BIT_SHIFT_SI_AUTHORIZATION) & BIT_MASK_SI_AUTHORIZATION)
#define BIT_SET_SI_AUTHORIZATION(x, v) \
(BIT_CLEAR_SI_AUTHORIZATION(x) | BIT_SI_AUTHORIZATION(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_HCI_RATIO 30
#define BIT_MASK_HCI_RATIO 0x3
#define BIT_HCI_RATIO(x) (((x) & BIT_MASK_HCI_RATIO) << BIT_SHIFT_HCI_RATIO)
#define BITS_HCI_RATIO (BIT_MASK_HCI_RATIO << BIT_SHIFT_HCI_RATIO)
#define BIT_CLEAR_HCI_RATIO(x) ((x) & (~BITS_HCI_RATIO))
#define BIT_GET_HCI_RATIO(x) (((x) >> BIT_SHIFT_HCI_RATIO) & BIT_MASK_HCI_RATIO)
#define BIT_SET_HCI_RATIO(x, v) (BIT_CLEAR_HCI_RATIO(x) | BIT_HCI_RATIO(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_TSFT_SEL 29
#define BIT_MASK_TSFT_SEL 0x7
#define BIT_TSFT_SEL(x) (((x) & BIT_MASK_TSFT_SEL) << BIT_SHIFT_TSFT_SEL)
#define BITS_TSFT_SEL (BIT_MASK_TSFT_SEL << BIT_SHIFT_TSFT_SEL)
#define BIT_CLEAR_TSFT_SEL(x) ((x) & (~BITS_TSFT_SEL))
#define BIT_GET_TSFT_SEL(x) (((x) >> BIT_SHIFT_TSFT_SEL) & BIT_MASK_TSFT_SEL)
#define BIT_SET_TSFT_SEL(x, v) (BIT_CLEAR_TSFT_SEL(x) | BIT_TSFT_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_WAIT_HPOW_TIME 28
#define BIT_MASK_WAIT_HPOW_TIME 0x3
#define BIT_WAIT_HPOW_TIME(x) \
(((x) & BIT_MASK_WAIT_HPOW_TIME) << BIT_SHIFT_WAIT_HPOW_TIME)
#define BITS_WAIT_HPOW_TIME \
(BIT_MASK_WAIT_HPOW_TIME << BIT_SHIFT_WAIT_HPOW_TIME)
#define BIT_CLEAR_WAIT_HPOW_TIME(x) ((x) & (~BITS_WAIT_HPOW_TIME))
#define BIT_GET_WAIT_HPOW_TIME(x) \
(((x) >> BIT_SHIFT_WAIT_HPOW_TIME) & BIT_MASK_WAIT_HPOW_TIME)
#define BIT_SET_WAIT_HPOW_TIME(x, v) \
(BIT_CLEAR_WAIT_HPOW_TIME(x) | BIT_WAIT_HPOW_TIME(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_XTAL_SEL_0_V1 28
#define BIT_MASK_XTAL_SEL_0_V1 0xf
#define BIT_XTAL_SEL_0_V1(x) \
(((x) & BIT_MASK_XTAL_SEL_0_V1) << BIT_SHIFT_XTAL_SEL_0_V1)
#define BITS_XTAL_SEL_0_V1 (BIT_MASK_XTAL_SEL_0_V1 << BIT_SHIFT_XTAL_SEL_0_V1)
#define BIT_CLEAR_XTAL_SEL_0_V1(x) ((x) & (~BITS_XTAL_SEL_0_V1))
#define BIT_GET_XTAL_SEL_0_V1(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_0_V1) & BIT_MASK_XTAL_SEL_0_V1)
#define BIT_SET_XTAL_SEL_0_V1(x, v) \
(BIT_CLEAR_XTAL_SEL_0_V1(x) | BIT_XTAL_SEL_0_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_TSFT_BAND_SEL BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCIE_HPOW_OPT2 BIT(27)
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_ISO_RFC2RF_3 BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCIE_HPOW_OPT1 BIT(26)
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_ISO_RFC2RF_2 BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCIE_HPOW_OPT0 BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_RPWM 24
#define BIT_MASK_RPWM 0xff
#define BIT_RPWM(x) (((x) & BIT_MASK_RPWM) << BIT_SHIFT_RPWM)
#define BITS_RPWM (BIT_MASK_RPWM << BIT_SHIFT_RPWM)
#define BIT_CLEAR_RPWM(x) ((x) & (~BITS_RPWM))
#define BIT_GET_RPWM(x) (((x) >> BIT_SHIFT_RPWM) & BIT_MASK_RPWM)
#define BIT_SET_RPWM(x, v) (BIT_CLEAR_RPWM(x) | BIT_RPWM(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCIE_EPC_ISO BIT(24)
#define BIT_PCIE_EPC_OPT BIT(23)
#define BIT_PCIE_SUS_OPT BIT(22)
#define BIT_PCIE_L1OF_OPT BIT(21)
#define BIT_PCIE_L1OF_LDOA BIT(20)
#define BIT_USB_SUS_LDOA BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SDIO_PAD_E5 BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB_HOST_PWR_OFF_SEL BIT(13)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_R_FORCE_CLK_U3 BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB_HOST_PWR_OFF_EN BIT(12)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_R_USB2_AUTOLOAD BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SYM_LPS_BLOCK_EN BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_FORCE_U2CK BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB_LPM_ACT_EN BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_FORCE_CLK BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB_LPM_NY BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_IBX_EN_VALUE BIT(9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_U2_FORCE BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB_SUS_DIS BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_IB_EN_VALUE BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_U3_FORCE BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_EN_LW_PWR BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_SDIO_PAD_E 5
#define BIT_MASK_SDIO_PAD_E 0x7
#define BIT_SDIO_PAD_E(x) (((x) & BIT_MASK_SDIO_PAD_E) << BIT_SHIFT_SDIO_PAD_E)
#define BITS_SDIO_PAD_E (BIT_MASK_SDIO_PAD_E << BIT_SHIFT_SDIO_PAD_E)
#define BIT_CLEAR_SDIO_PAD_E(x) ((x) & (~BITS_SDIO_PAD_E))
#define BIT_GET_SDIO_PAD_E(x) \
(((x) >> BIT_SHIFT_SDIO_PAD_E) & BIT_MASK_SDIO_PAD_E)
#define BIT_SET_SDIO_PAD_E(x, v) (BIT_CLEAR_SDIO_PAD_E(x) | BIT_SDIO_PAD_E(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_EN_REGU BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB_LPPLL_EN BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_FORCED_IB_EN BIT(4)
#define BIT_EN_PC BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SDIO_H3L1 BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PERST_SYNC_EN BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_USB1_1_USB2_0_DECISION BIT(3)
#define BIT_EN_REGBG BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_ROP_SW15 BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_REG_BG_LPF BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_USB23_SW_MODE 2
#define BIT_MASK_USB23_SW_MODE 0x3
#define BIT_USB23_SW_MODE(x) \
(((x) & BIT_MASK_USB23_SW_MODE) << BIT_SHIFT_USB23_SW_MODE)
#define BITS_USB23_SW_MODE (BIT_MASK_USB23_SW_MODE << BIT_SHIFT_USB23_SW_MODE)
#define BIT_CLEAR_USB23_SW_MODE(x) ((x) & (~BITS_USB23_SW_MODE))
#define BIT_GET_USB23_SW_MODE(x) \
(((x) >> BIT_SHIFT_USB23_SW_MODE) & BIT_MASK_USB23_SW_MODE)
#define BIT_SET_USB23_SW_MODE(x, v) \
(BIT_CLEAR_USB23_SW_MODE(x) | BIT_USB23_SW_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCI_CKRDY_OPT BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCLK_VLD_SEL BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_PCI_VAUX_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_SHIFT_REG_BG 0
#define BIT_MASK_REG_BG 0x3
#define BIT_REG_BG(x) (((x) & BIT_MASK_REG_BG) << BIT_SHIFT_REG_BG)
#define BITS_REG_BG (BIT_MASK_REG_BG << BIT_SHIFT_REG_BG)
#define BIT_CLEAR_REG_BG(x) ((x) & (~BITS_REG_BG))
#define BIT_GET_REG_BG(x) (((x) >> BIT_SHIFT_REG_BG) & BIT_MASK_REG_BG)
#define BIT_SET_REG_BG(x, v) (BIT_CLEAR_REG_BG(x) | BIT_REG_BG(v))
#define BIT_SHIFT_REG_VADJ 0
#define BIT_MASK_REG_VADJ 0xf
#define BIT_REG_VADJ(x) (((x) & BIT_MASK_REG_VADJ) << BIT_SHIFT_REG_VADJ)
#define BITS_REG_VADJ (BIT_MASK_REG_VADJ << BIT_SHIFT_REG_VADJ)
#define BIT_CLEAR_REG_VADJ(x) ((x) & (~BITS_REG_VADJ))
#define BIT_GET_REG_VADJ(x) (((x) >> BIT_SHIFT_REG_VADJ) & BIT_MASK_REG_VADJ)
#define BIT_SET_REG_VADJ(x, v) (BIT_CLEAR_REG_VADJ(x) | BIT_REG_VADJ(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_OPT_CTRL (Offset 0x0074) */
#define BIT_VAUX_EN BIT(0)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_SDM_ORDER BIT(30)
#define BIT_XTAL_DRV_RF_LATCH_V1 BIT(29)
#define BIT_XTAL_VDD_SEL_V1 BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XTAL_DRV_RF_LATCH BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_XQSEL_RF_AWAKE_V1 BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XTAL_VDD_SEL BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF1_SDMRSTB BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_GATED_XTAL_OK0_V1 BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XQSEL_RF BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF1_RSTB BIT(25)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XQSEL_RF_AWAKE BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XQSEL_RF_INITIAL BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF1_EN BIT(24)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XQSEL_BIT1 BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_REG_VREF_SEL BIT(23)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_DITHER_SDM_BIT3 BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_SHIFT_F0N_2_TO_0 23
#define BIT_MASK_F0N_2_TO_0 0x7
#define BIT_F0N_2_TO_0(x) (((x) & BIT_MASK_F0N_2_TO_0) << BIT_SHIFT_F0N_2_TO_0)
#define BITS_F0N_2_TO_0 (BIT_MASK_F0N_2_TO_0 << BIT_SHIFT_F0N_2_TO_0)
#define BIT_CLEAR_F0N_2_TO_0(x) ((x) & (~BITS_F0N_2_TO_0))
#define BIT_GET_F0N_2_TO_0(x) \
(((x) >> BIT_SHIFT_F0N_2_TO_0) & BIT_MASK_F0N_2_TO_0)
#define BIT_SET_F0N_2_TO_0(x, v) (BIT_CLEAR_F0N_2_TO_0(x) | BIT_F0N_2_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_REG_LPFEN BIT(22)
#define BIT_REG_KVCO BIT(21)
#define BIT_XTAL_DRV_AGPIO_BIT1 BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_SHIFT_XTAL_LDO 20
#define BIT_MASK_XTAL_LDO 0x7
#define BIT_XTAL_LDO(x) (((x) & BIT_MASK_XTAL_LDO) << BIT_SHIFT_XTAL_LDO)
#define BITS_XTAL_LDO (BIT_MASK_XTAL_LDO << BIT_SHIFT_XTAL_LDO)
#define BIT_CLEAR_XTAL_LDO(x) ((x) & (~BITS_XTAL_LDO))
#define BIT_GET_XTAL_LDO(x) (((x) >> BIT_SHIFT_XTAL_LDO) & BIT_MASK_XTAL_LDO)
#define BIT_SET_XTAL_LDO(x, v) (BIT_CLEAR_XTAL_LDO(x) | BIT_XTAL_LDO(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XTAL_DRV_AGPIO_BIT0 BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_XTAL_GRF2 BIT(18)
#define BIT_REG_REF_SEL BIT(17)
#define BIT_REG_320_SEL BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_ADC_CK_SYNC_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_EN_SYM BIT(15)
#define BIT_SHIFT_IOFFSET 10
#define BIT_MASK_IOFFSET 0x1f
#define BIT_IOFFSET(x) (((x) & BIT_MASK_IOFFSET) << BIT_SHIFT_IOFFSET)
#define BITS_IOFFSET (BIT_MASK_IOFFSET << BIT_SHIFT_IOFFSET)
#define BIT_CLEAR_IOFFSET(x) ((x) & (~BITS_IOFFSET))
#define BIT_GET_IOFFSET(x) (((x) >> BIT_SHIFT_IOFFSET) & BIT_MASK_IOFFSET)
#define BIT_SET_IOFFSET(x, v) (BIT_CLEAR_IOFFSET(x) | BIT_IOFFSET(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF2_SDMRSTB BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_SHIFT_F0F_12_TO_0 10
#define BIT_MASK_F0F_12_TO_0 0x1fff
#define BIT_F0F_12_TO_0(x) \
(((x) & BIT_MASK_F0F_12_TO_0) << BIT_SHIFT_F0F_12_TO_0)
#define BITS_F0F_12_TO_0 (BIT_MASK_F0F_12_TO_0 << BIT_SHIFT_F0F_12_TO_0)
#define BIT_CLEAR_F0F_12_TO_0(x) ((x) & (~BITS_F0F_12_TO_0))
#define BIT_GET_F0F_12_TO_0(x) \
(((x) >> BIT_SHIFT_F0F_12_TO_0) & BIT_MASK_F0F_12_TO_0)
#define BIT_SET_F0F_12_TO_0(x, v) \
(BIT_CLEAR_F0F_12_TO_0(x) | BIT_F0F_12_TO_0(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF2_RSTB BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_SHIFT_APLL_FREF_SEL_BIT_2_TO_1 8
#define BIT_MASK_APLL_FREF_SEL_BIT_2_TO_1 0x3
#define BIT_APLL_FREF_SEL_BIT_2_TO_1(x) \
(((x) & BIT_MASK_APLL_FREF_SEL_BIT_2_TO_1) \
<< BIT_SHIFT_APLL_FREF_SEL_BIT_2_TO_1)
#define BITS_APLL_FREF_SEL_BIT_2_TO_1 \
(BIT_MASK_APLL_FREF_SEL_BIT_2_TO_1 \
<< BIT_SHIFT_APLL_FREF_SEL_BIT_2_TO_1)
#define BIT_CLEAR_APLL_FREF_SEL_BIT_2_TO_1(x) \
((x) & (~BITS_APLL_FREF_SEL_BIT_2_TO_1))
#define BIT_GET_APLL_FREF_SEL_BIT_2_TO_1(x) \
(((x) >> BIT_SHIFT_APLL_FREF_SEL_BIT_2_TO_1) & \
BIT_MASK_APLL_FREF_SEL_BIT_2_TO_1)
#define BIT_SET_APLL_FREF_SEL_BIT_2_TO_1(x, v) \
(BIT_CLEAR_APLL_FREF_SEL_BIT_2_TO_1(x) | \
BIT_APLL_FREF_SEL_BIT_2_TO_1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF2_EN BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_APLL_FREF_SEL_BIT3 BIT(7)
#define BIT_SHIFT_APLL_LDO_V12ADJ 5
#define BIT_MASK_APLL_LDO_V12ADJ 0x3
#define BIT_APLL_LDO_V12ADJ(x) \
(((x) & BIT_MASK_APLL_LDO_V12ADJ) << BIT_SHIFT_APLL_LDO_V12ADJ)
#define BITS_APLL_LDO_V12ADJ \
(BIT_MASK_APLL_LDO_V12ADJ << BIT_SHIFT_APLL_LDO_V12ADJ)
#define BIT_CLEAR_APLL_LDO_V12ADJ(x) ((x) & (~BITS_APLL_LDO_V12ADJ))
#define BIT_GET_APLL_LDO_V12ADJ(x) \
(((x) >> BIT_SHIFT_APLL_LDO_V12ADJ) & BIT_MASK_APLL_LDO_V12ADJ)
#define BIT_SET_APLL_LDO_V12ADJ(x, v) \
(BIT_CLEAR_APLL_LDO_V12ADJ(x) | BIT_APLL_LDO_V12ADJ(v))
#define BIT_APLL_160_GATEB BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_SHIFT_DIVN_5_TO_0 4
#define BIT_MASK_DIVN_5_TO_0 0x3f
#define BIT_DIVN_5_TO_0(x) \
(((x) & BIT_MASK_DIVN_5_TO_0) << BIT_SHIFT_DIVN_5_TO_0)
#define BITS_DIVN_5_TO_0 (BIT_MASK_DIVN_5_TO_0 << BIT_SHIFT_DIVN_5_TO_0)
#define BIT_CLEAR_DIVN_5_TO_0(x) ((x) & (~BITS_DIVN_5_TO_0))
#define BIT_GET_DIVN_5_TO_0(x) \
(((x) >> BIT_SHIFT_DIVN_5_TO_0) & BIT_MASK_DIVN_5_TO_0)
#define BIT_SET_DIVN_5_TO_0(x, v) \
(BIT_CLEAR_DIVN_5_TO_0(x) | BIT_DIVN_5_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_AFE_DUMMY BIT(3)
#define BIT_REG_IDOUBLE BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF3_SDMRSTB BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_REG_VCO_BIAS_BIT0 BIT(1)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF3_RSTB BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_REG_VCO_BIAS_BIT1 BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL4 (Offset 0x0078) */
#define BIT_RF3_EN BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_AFE_XTAL_CTRL_EXT (Offset 0x0078) */
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM_3_TO_0 0
#define BIT_MASK_BB_DBG_SEL_AFE_SDM_3_TO_0 0xf
#define BIT_BB_DBG_SEL_AFE_SDM_3_TO_0(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM_3_TO_0) \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_3_TO_0)
#define BITS_BB_DBG_SEL_AFE_SDM_3_TO_0 \
(BIT_MASK_BB_DBG_SEL_AFE_SDM_3_TO_0 \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_3_TO_0)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM_3_TO_0(x) \
((x) & (~BITS_BB_DBG_SEL_AFE_SDM_3_TO_0))
#define BIT_GET_BB_DBG_SEL_AFE_SDM_3_TO_0(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM_3_TO_0) & \
BIT_MASK_BB_DBG_SEL_AFE_SDM_3_TO_0)
#define BIT_SET_BB_DBG_SEL_AFE_SDM_3_TO_0(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM_3_TO_0(x) | \
BIT_BB_DBG_SEL_AFE_SDM_3_TO_0(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SPS_EN_DIODE BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_EXT_SWR_CTRL_EN BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REF_FREF_EDGE BIT(29)
#define BIT_REG_VREF_SEL_V1 BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_ZCD_HW_AUTO_EN BIT(27)
#define BIT_ZCD_REGSEL BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_CP_OFFSET_4_TO_0 23
#define BIT_MASK_REG_CP_OFFSET_4_TO_0 0x1f
#define BIT_REG_CP_OFFSET_4_TO_0(x) \
(((x) & BIT_MASK_REG_CP_OFFSET_4_TO_0) \
<< BIT_SHIFT_REG_CP_OFFSET_4_TO_0)
#define BITS_REG_CP_OFFSET_4_TO_0 \
(BIT_MASK_REG_CP_OFFSET_4_TO_0 << BIT_SHIFT_REG_CP_OFFSET_4_TO_0)
#define BIT_CLEAR_REG_CP_OFFSET_4_TO_0(x) ((x) & (~BITS_REG_CP_OFFSET_4_TO_0))
#define BIT_GET_REG_CP_OFFSET_4_TO_0(x) \
(((x) >> BIT_SHIFT_REG_CP_OFFSET_4_TO_0) & \
BIT_MASK_REG_CP_OFFSET_4_TO_0)
#define BIT_SET_REG_CP_OFFSET_4_TO_0(x, v) \
(BIT_CLEAR_REG_CP_OFFSET_4_TO_0(x) | BIT_REG_CP_OFFSET_4_TO_0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_AUTO_ZCD_IN_CODE 21
#define BIT_MASK_AUTO_ZCD_IN_CODE 0x1f
#define BIT_AUTO_ZCD_IN_CODE(x) \
(((x) & BIT_MASK_AUTO_ZCD_IN_CODE) << BIT_SHIFT_AUTO_ZCD_IN_CODE)
#define BITS_AUTO_ZCD_IN_CODE \
(BIT_MASK_AUTO_ZCD_IN_CODE << BIT_SHIFT_AUTO_ZCD_IN_CODE)
#define BIT_CLEAR_AUTO_ZCD_IN_CODE(x) ((x) & (~BITS_AUTO_ZCD_IN_CODE))
#define BIT_GET_AUTO_ZCD_IN_CODE(x) \
(((x) >> BIT_SHIFT_AUTO_ZCD_IN_CODE) & BIT_MASK_AUTO_ZCD_IN_CODE)
#define BIT_SET_AUTO_ZCD_IN_CODE(x, v) \
(BIT_CLEAR_AUTO_ZCD_IN_CODE(x) | BIT_AUTO_ZCD_IN_CODE(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_RS_SET_2_TO_0 20
#define BIT_MASK_REG_RS_SET_2_TO_0 0x7
#define BIT_REG_RS_SET_2_TO_0(x) \
(((x) & BIT_MASK_REG_RS_SET_2_TO_0) << BIT_SHIFT_REG_RS_SET_2_TO_0)
#define BITS_REG_RS_SET_2_TO_0 \
(BIT_MASK_REG_RS_SET_2_TO_0 << BIT_SHIFT_REG_RS_SET_2_TO_0)
#define BIT_CLEAR_REG_RS_SET_2_TO_0(x) ((x) & (~BITS_REG_RS_SET_2_TO_0))
#define BIT_GET_REG_RS_SET_2_TO_0(x) \
(((x) >> BIT_SHIFT_REG_RS_SET_2_TO_0) & BIT_MASK_REG_RS_SET_2_TO_0)
#define BIT_SET_REG_RS_SET_2_TO_0(x, v) \
(BIT_CLEAR_REG_RS_SET_2_TO_0(x) | BIT_REG_RS_SET_2_TO_0(v))
#define BIT_SHIFT_REG_CS_SET_1_TO_0 18
#define BIT_MASK_REG_CS_SET_1_TO_0 0x3
#define BIT_REG_CS_SET_1_TO_0(x) \
(((x) & BIT_MASK_REG_CS_SET_1_TO_0) << BIT_SHIFT_REG_CS_SET_1_TO_0)
#define BITS_REG_CS_SET_1_TO_0 \
(BIT_MASK_REG_CS_SET_1_TO_0 << BIT_SHIFT_REG_CS_SET_1_TO_0)
#define BIT_CLEAR_REG_CS_SET_1_TO_0(x) ((x) & (~BITS_REG_CS_SET_1_TO_0))
#define BIT_GET_REG_CS_SET_1_TO_0(x) \
(((x) >> BIT_SHIFT_REG_CS_SET_1_TO_0) & BIT_MASK_REG_CS_SET_1_TO_0)
#define BIT_SET_REG_CS_SET_1_TO_0(x, v) \
(BIT_CLEAR_REG_CS_SET_1_TO_0(x) | BIT_REG_CS_SET_1_TO_0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_ZCD_CODE_IN_L 16
#define BIT_MASK_ZCD_CODE_IN_L 0x1f
#define BIT_ZCD_CODE_IN_L(x) \
(((x) & BIT_MASK_ZCD_CODE_IN_L) << BIT_SHIFT_ZCD_CODE_IN_L)
#define BITS_ZCD_CODE_IN_L (BIT_MASK_ZCD_CODE_IN_L << BIT_SHIFT_ZCD_CODE_IN_L)
#define BIT_CLEAR_ZCD_CODE_IN_L(x) ((x) & (~BITS_ZCD_CODE_IN_L))
#define BIT_GET_ZCD_CODE_IN_L(x) \
(((x) >> BIT_SHIFT_ZCD_CODE_IN_L) & BIT_MASK_ZCD_CODE_IN_L)
#define BIT_SET_ZCD_CODE_IN_L(x, v) \
(BIT_CLEAR_ZCD_CODE_IN_L(x) | BIT_ZCD_CODE_IN_L(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_CP_SET_1_TO_0 16
#define BIT_MASK_REG_CP_SET_1_TO_0 0x3
#define BIT_REG_CP_SET_1_TO_0(x) \
(((x) & BIT_MASK_REG_CP_SET_1_TO_0) << BIT_SHIFT_REG_CP_SET_1_TO_0)
#define BITS_REG_CP_SET_1_TO_0 \
(BIT_MASK_REG_CP_SET_1_TO_0 << BIT_SHIFT_REG_CP_SET_1_TO_0)
#define BIT_CLEAR_REG_CP_SET_1_TO_0(x) ((x) & (~BITS_REG_CP_SET_1_TO_0))
#define BIT_GET_REG_CP_SET_1_TO_0(x) \
(((x) >> BIT_SHIFT_REG_CP_SET_1_TO_0) & BIT_MASK_REG_CP_SET_1_TO_0)
#define BIT_SET_REG_CP_SET_1_TO_0(x, v) \
(BIT_CLEAR_REG_CP_SET_1_TO_0(x) | BIT_REG_CP_SET_1_TO_0(v))
#define BIT_LPFEN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_LDO_HV5_DUMMY 14
#define BIT_MASK_LDO_HV5_DUMMY 0x3
#define BIT_LDO_HV5_DUMMY(x) \
(((x) & BIT_MASK_LDO_HV5_DUMMY) << BIT_SHIFT_LDO_HV5_DUMMY)
#define BITS_LDO_HV5_DUMMY (BIT_MASK_LDO_HV5_DUMMY << BIT_SHIFT_LDO_HV5_DUMMY)
#define BIT_CLEAR_LDO_HV5_DUMMY(x) ((x) & (~BITS_LDO_HV5_DUMMY))
#define BIT_GET_LDO_HV5_DUMMY(x) \
(((x) >> BIT_SHIFT_LDO_HV5_DUMMY) & BIT_MASK_LDO_HV5_DUMMY)
#define BIT_SET_LDO_HV5_DUMMY(x, v) \
(BIT_CLEAR_LDO_HV5_DUMMY(x) | BIT_LDO_HV5_DUMMY(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_DOGENB BIT(14)
#define BIT_REG_TEST_EN BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_VTUNE33 12
#define BIT_MASK_REG_VTUNE33 0x3
#define BIT_REG_VTUNE33(x) \
(((x) & BIT_MASK_REG_VTUNE33) << BIT_SHIFT_REG_VTUNE33)
#define BITS_REG_VTUNE33 (BIT_MASK_REG_VTUNE33 << BIT_SHIFT_REG_VTUNE33)
#define BIT_CLEAR_REG_VTUNE33(x) ((x) & (~BITS_REG_VTUNE33))
#define BIT_GET_REG_VTUNE33(x) \
(((x) >> BIT_SHIFT_REG_VTUNE33) & BIT_MASK_REG_VTUNE33)
#define BIT_SET_REG_VTUNE33(x, v) \
(BIT_CLEAR_REG_VTUNE33(x) | BIT_REG_VTUNE33(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1 12
#define BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1 0x3
#define BIT_REG_VTUNE33_BIT0_TO_BIT1(x) \
(((x) & BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1) \
<< BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1)
#define BITS_REG_VTUNE33_BIT0_TO_BIT1 \
(BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1 \
<< BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1)
#define BIT_CLEAR_REG_VTUNE33_BIT0_TO_BIT1(x) \
((x) & (~BITS_REG_VTUNE33_BIT0_TO_BIT1))
#define BIT_GET_REG_VTUNE33_BIT0_TO_BIT1(x) \
(((x) >> BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1) & \
BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1)
#define BIT_SET_REG_VTUNE33_BIT0_TO_BIT1(x, v) \
(BIT_CLEAR_REG_VTUNE33_BIT0_TO_BIT1(x) | \
BIT_REG_VTUNE33_BIT0_TO_BIT1(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_STANDBY33 10
#define BIT_MASK_REG_STANDBY33 0x3
#define BIT_REG_STANDBY33(x) \
(((x) & BIT_MASK_REG_STANDBY33) << BIT_SHIFT_REG_STANDBY33)
#define BITS_REG_STANDBY33 (BIT_MASK_REG_STANDBY33 << BIT_SHIFT_REG_STANDBY33)
#define BIT_CLEAR_REG_STANDBY33(x) ((x) & (~BITS_REG_STANDBY33))
#define BIT_GET_REG_STANDBY33(x) \
(((x) >> BIT_SHIFT_REG_STANDBY33) & BIT_MASK_REG_STANDBY33)
#define BIT_SET_REG_STANDBY33(x, v) \
(BIT_CLEAR_REG_STANDBY33(x) | BIT_REG_STANDBY33(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1 10
#define BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1 0x3
#define BIT_REG_STANDBY33_BIT0_TO_BIT1(x) \
(((x) & BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1) \
<< BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1)
#define BITS_REG_STANDBY33_BIT0_TO_BIT1 \
(BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1 \
<< BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1)
#define BIT_CLEAR_REG_STANDBY33_BIT0_TO_BIT1(x) \
((x) & (~BITS_REG_STANDBY33_BIT0_TO_BIT1))
#define BIT_GET_REG_STANDBY33_BIT0_TO_BIT1(x) \
(((x) >> BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1) & \
BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1)
#define BIT_SET_REG_STANDBY33_BIT0_TO_BIT1(x, v) \
(BIT_CLEAR_REG_STANDBY33_BIT0_TO_BIT1(x) | \
BIT_REG_STANDBY33_BIT0_TO_BIT1(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_LOAD33 8
#define BIT_MASK_REG_LOAD33 0x3
#define BIT_REG_LOAD33(x) (((x) & BIT_MASK_REG_LOAD33) << BIT_SHIFT_REG_LOAD33)
#define BITS_REG_LOAD33 (BIT_MASK_REG_LOAD33 << BIT_SHIFT_REG_LOAD33)
#define BIT_CLEAR_REG_LOAD33(x) ((x) & (~BITS_REG_LOAD33))
#define BIT_GET_REG_LOAD33(x) \
(((x) >> BIT_SHIFT_REG_LOAD33) & BIT_MASK_REG_LOAD33)
#define BIT_SET_REG_LOAD33(x, v) (BIT_CLEAR_REG_LOAD33(x) | BIT_REG_LOAD33(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1 8
#define BIT_MASK_REG_LOAD33_BIT0_TO_BIT1 0x3
#define BIT_REG_LOAD33_BIT0_TO_BIT1(x) \
(((x) & BIT_MASK_REG_LOAD33_BIT0_TO_BIT1) \
<< BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1)
#define BITS_REG_LOAD33_BIT0_TO_BIT1 \
(BIT_MASK_REG_LOAD33_BIT0_TO_BIT1 << BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1)
#define BIT_CLEAR_REG_LOAD33_BIT0_TO_BIT1(x) \
((x) & (~BITS_REG_LOAD33_BIT0_TO_BIT1))
#define BIT_GET_REG_LOAD33_BIT0_TO_BIT1(x) \
(((x) >> BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1) & \
BIT_MASK_REG_LOAD33_BIT0_TO_BIT1)
#define BIT_SET_REG_LOAD33_BIT0_TO_BIT1(x, v) \
(BIT_CLEAR_REG_LOAD33_BIT0_TO_BIT1(x) | BIT_REG_LOAD33_BIT0_TO_BIT1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_DIV_SEL 8
#define BIT_MASK_REG_DIV_SEL 0x1f
#define BIT_REG_DIV_SEL(x) \
(((x) & BIT_MASK_REG_DIV_SEL) << BIT_SHIFT_REG_DIV_SEL)
#define BITS_REG_DIV_SEL (BIT_MASK_REG_DIV_SEL << BIT_SHIFT_REG_DIV_SEL)
#define BIT_CLEAR_REG_DIV_SEL(x) ((x) & (~BITS_REG_DIV_SEL))
#define BIT_GET_REG_DIV_SEL(x) \
(((x) >> BIT_SHIFT_REG_DIV_SEL) & BIT_MASK_REG_DIV_SEL)
#define BIT_SET_REG_DIV_SEL(x, v) \
(BIT_CLEAR_REG_DIV_SEL(x) | BIT_REG_DIV_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_BYPASS_L BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_EN_CK200M BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_LDOF_L BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_OCPS_L BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_KVCO_200M_1_TO_0 5
#define BIT_MASK_REG_KVCO_200M_1_TO_0 0x3
#define BIT_REG_KVCO_200M_1_TO_0(x) \
(((x) & BIT_MASK_REG_KVCO_200M_1_TO_0) \
<< BIT_SHIFT_REG_KVCO_200M_1_TO_0)
#define BITS_REG_KVCO_200M_1_TO_0 \
(BIT_MASK_REG_KVCO_200M_1_TO_0 << BIT_SHIFT_REG_KVCO_200M_1_TO_0)
#define BIT_CLEAR_REG_KVCO_200M_1_TO_0(x) ((x) & (~BITS_REG_KVCO_200M_1_TO_0))
#define BIT_GET_REG_KVCO_200M_1_TO_0(x) \
(((x) >> BIT_SHIFT_REG_KVCO_200M_1_TO_0) & \
BIT_MASK_REG_KVCO_200M_1_TO_0)
#define BIT_SET_REG_KVCO_200M_1_TO_0(x, v) \
(BIT_CLEAR_REG_KVCO_200M_1_TO_0(x) | BIT_REG_KVCO_200M_1_TO_0(v))
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_TYPE_L_V1 BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_ARENB_L BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_REG_CP_BIAS_200M_2_TO_0 2
#define BIT_MASK_REG_CP_BIAS_200M_2_TO_0 0x7
#define BIT_REG_CP_BIAS_200M_2_TO_0(x) \
(((x) & BIT_MASK_REG_CP_BIAS_200M_2_TO_0) \
<< BIT_SHIFT_REG_CP_BIAS_200M_2_TO_0)
#define BITS_REG_CP_BIAS_200M_2_TO_0 \
(BIT_MASK_REG_CP_BIAS_200M_2_TO_0 << BIT_SHIFT_REG_CP_BIAS_200M_2_TO_0)
#define BIT_CLEAR_REG_CP_BIAS_200M_2_TO_0(x) \
((x) & (~BITS_REG_CP_BIAS_200M_2_TO_0))
#define BIT_GET_REG_CP_BIAS_200M_2_TO_0(x) \
(((x) >> BIT_SHIFT_REG_CP_BIAS_200M_2_TO_0) & \
BIT_MASK_REG_CP_BIAS_200M_2_TO_0)
#define BIT_SET_REG_CP_BIAS_200M_2_TO_0(x, v) \
(BIT_CLEAR_REG_CP_BIAS_200M_2_TO_0(x) | BIT_REG_CP_BIAS_200M_2_TO_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_CFC_L_BIT_1_TO_0 1
#define BIT_MASK_CFC_L_BIT_1_TO_0 0x3
#define BIT_CFC_L_BIT_1_TO_0(x) \
(((x) & BIT_MASK_CFC_L_BIT_1_TO_0) << BIT_SHIFT_CFC_L_BIT_1_TO_0)
#define BITS_CFC_L_BIT_1_TO_0 \
(BIT_MASK_CFC_L_BIT_1_TO_0 << BIT_SHIFT_CFC_L_BIT_1_TO_0)
#define BIT_CLEAR_CFC_L_BIT_1_TO_0(x) ((x) & (~BITS_CFC_L_BIT_1_TO_0))
#define BIT_GET_CFC_L_BIT_1_TO_0(x) \
(((x) >> BIT_SHIFT_CFC_L_BIT_1_TO_0) & BIT_MASK_CFC_L_BIT_1_TO_0)
#define BIT_SET_CFC_L_BIT_1_TO_0(x, v) \
(BIT_CLEAR_CFC_L_BIT_1_TO_0(x) | BIT_CFC_L_BIT_1_TO_0(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_SHIFT_CFC_L 1
#define BIT_MASK_CFC_L 0x3
#define BIT_CFC_L(x) (((x) & BIT_MASK_CFC_L) << BIT_SHIFT_CFC_L)
#define BITS_CFC_L (BIT_MASK_CFC_L << BIT_SHIFT_CFC_L)
#define BIT_CLEAR_CFC_L(x) ((x) & (~BITS_CFC_L))
#define BIT_GET_CFC_L(x) (((x) >> BIT_SHIFT_CFC_L) & BIT_MASK_CFC_L)
#define BIT_SET_CFC_L(x, v) (BIT_CLEAR_CFC_L(x) | BIT_CFC_L(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_TYPE_L BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_XCK_OUT_EN BIT(0)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_LDO_SWR_CTRL (Offset 0x007C) */
#define BIT_REG_OCPS_L_V1 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUSUS_EN BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_ANA_PORT_EN BIT(22)
#define BIT_MAC_PORT_EN BIT(21)
#define BIT_BOOT_FSPI_EN BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_SHIFT_MCUROM_DL 16
#define BIT_MASK_MCUROM_DL 0xf
#define BIT_MCUROM_DL(x) (((x) & BIT_MASK_MCUROM_DL) << BIT_SHIFT_MCUROM_DL)
#define BITS_MCUROM_DL (BIT_MASK_MCUROM_DL << BIT_SHIFT_MCUROM_DL)
#define BIT_CLEAR_MCUROM_DL(x) ((x) & (~BITS_MCUROM_DL))
#define BIT_GET_MCUROM_DL(x) (((x) >> BIT_SHIFT_MCUROM_DL) & BIT_MASK_MCUROM_DL)
#define BIT_SET_MCUROM_DL(x, v) (BIT_CLEAR_MCUROM_DL(x) | BIT_MCUROM_DL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_FW_INIT_RDY BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_SHIFT_MCUFWDL_DMA_2KB_SEL 14
#define BIT_MASK_MCUFWDL_DMA_2KB_SEL 0x3
#define BIT_MCUFWDL_DMA_2KB_SEL(x) \
(((x) & BIT_MASK_MCUFWDL_DMA_2KB_SEL) << BIT_SHIFT_MCUFWDL_DMA_2KB_SEL)
#define BITS_MCUFWDL_DMA_2KB_SEL \
(BIT_MASK_MCUFWDL_DMA_2KB_SEL << BIT_SHIFT_MCUFWDL_DMA_2KB_SEL)
#define BIT_CLEAR_MCUFWDL_DMA_2KB_SEL(x) ((x) & (~BITS_MCUFWDL_DMA_2KB_SEL))
#define BIT_GET_MCUFWDL_DMA_2KB_SEL(x) \
(((x) >> BIT_SHIFT_MCUFWDL_DMA_2KB_SEL) & BIT_MASK_MCUFWDL_DMA_2KB_SEL)
#define BIT_SET_MCUFWDL_DMA_2KB_SEL(x, v) \
(BIT_CLEAR_MCUFWDL_DMA_2KB_SEL(x) | BIT_MCUFWDL_DMA_2KB_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_FW_DW_RDY BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_FWDL_RSVDPAGE_RDY BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_SHIFT_CPU_CLK_SEL 12
#define BIT_MASK_CPU_CLK_SEL 0x3
#define BIT_CPU_CLK_SEL(x) \
(((x) & BIT_MASK_CPU_CLK_SEL) << BIT_SHIFT_CPU_CLK_SEL)
#define BITS_CPU_CLK_SEL (BIT_MASK_CPU_CLK_SEL << BIT_SHIFT_CPU_CLK_SEL)
#define BIT_CLEAR_CPU_CLK_SEL(x) ((x) & (~BITS_CPU_CLK_SEL))
#define BIT_GET_CPU_CLK_SEL(x) \
(((x) >> BIT_SHIFT_CPU_CLK_SEL) & BIT_MASK_CPU_CLK_SEL)
#define BIT_SET_CPU_CLK_SEL(x, v) \
(BIT_CLEAR_CPU_CLK_SEL(x) | BIT_CPU_CLK_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_R_8051_ROMDLFW_EN BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUFWDL_DMA_EN BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_CCLK_CHG_MASK BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_R_8051_INIT_RDY BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUINI_WROMRDY BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_FW_INIT_RDY_V1 BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_EMEM__TXBUF_CHKSUM_OK BIT(10)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_EMEM_TXBUF_CHKSUM_OK BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUTXA_SPD BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_EMEM_TXBUF_DW_RDY BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_R_8051_GAT BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUCLK_TEN BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCU_CLK_EN BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_EMEM_CHKSUM_OK BIT(8)
#define BIT_EMEM_DW_OK BIT(7)
#define BIT_TOGGLE BIT(7)
#define BIT_DMEM_CHKSUM_OK BIT(6)
#define BIT_ACK BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_RFINI_RDY BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUINI_WRFCRDY BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_RF_INIT_RDY BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_DMEM_DW_OK BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_BBINI_RDY BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUINI_WPHYRDY BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_BB_INIT_RDY BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_IMEM_CHKSUM_OK BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_MACINI_RDY BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCUINI_WMACRDY BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MAC_INIT_RDY BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_IMEM_DW_OK BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_FWDL_CHK_RPT BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_IMEM_BOOT_LOAD_CHKSUM_OK BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_8051FW_CTRL (Offset 0x0080) */
#define BIT_MCUFWDL_RDY BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_IMEM_BOOT_LOAD_DW_OK BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MCUFW_CTRL (Offset 0x0080) */
#define BIT_MCU_FWDL_RDY BIT(1)
#define BIT_MCU_FWDL_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HRPWM1 (Offset 0x10250080) */
#define BIT_REQ_PS BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MCU_TST_CFG (Offset 0x0084) */
#define BIT_SHIFT_8051CODE_OFS 16
#define BIT_MASK_8051CODE_OFS 0xffff
#define BIT_8051CODE_OFS(x) \
(((x) & BIT_MASK_8051CODE_OFS) << BIT_SHIFT_8051CODE_OFS)
#define BITS_8051CODE_OFS (BIT_MASK_8051CODE_OFS << BIT_SHIFT_8051CODE_OFS)
#define BIT_CLEAR_8051CODE_OFS(x) ((x) & (~BITS_8051CODE_OFS))
#define BIT_GET_8051CODE_OFS(x) \
(((x) >> BIT_SHIFT_8051CODE_OFS) & BIT_MASK_8051CODE_OFS)
#define BIT_SET_8051CODE_OFS(x, v) \
(BIT_CLEAR_8051CODE_OFS(x) | BIT_8051CODE_OFS(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MCU_TST_CFG (Offset 0x0084) */
#define BIT_SHIFT_LBKTST 0
#define BIT_MASK_LBKTST 0xffff
#define BIT_LBKTST(x) (((x) & BIT_MASK_LBKTST) << BIT_SHIFT_LBKTST)
#define BITS_LBKTST (BIT_MASK_LBKTST << BIT_SHIFT_LBKTST)
#define BIT_CLEAR_LBKTST(x) ((x) & (~BITS_LBKTST))
#define BIT_GET_LBKTST(x) (((x) >> BIT_SHIFT_LBKTST) & BIT_MASK_LBKTST)
#define BIT_SET_LBKTST(x, v) (BIT_CLEAR_LBKTST(x) | BIT_LBKTST(v))
#endif
#if (HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_MCU_TST_CFG (Offset 0x0084) */
#define BIT_SHIFT_C2H_MSG 0
#define BIT_MASK_C2H_MSG 0xffff
#define BIT_C2H_MSG(x) (((x) & BIT_MASK_C2H_MSG) << BIT_SHIFT_C2H_MSG)
#define BITS_C2H_MSG (BIT_MASK_C2H_MSG << BIT_SHIFT_C2H_MSG)
#define BIT_CLEAR_C2H_MSG(x) ((x) & (~BITS_C2H_MSG))
#define BIT_GET_C2H_MSG(x) (((x) >> BIT_SHIFT_C2H_MSG) & BIT_MASK_C2H_MSG)
#define BIT_SET_C2H_MSG(x, v) (BIT_CLEAR_C2H_MSG(x) | BIT_C2H_MSG(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_BUS_CTRL (Offset 0x10250085) */
#define BIT_INT_MASK_DIS BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_BUS_CTRL (Offset 0x10250085) */
#define BIT_PAD_CLK_XHGE_EN BIT(3)
#define BIT_INTER_CLK_EN BIT(2)
#define BIT_EN_RPT_TXCRC BIT(1)
#define BIT_DIS_RXDMA_STS BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_SDIO_HSUS_CTRL (Offset 0x10250086) */
#define BIT_SPI_PHASE BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HSUS_CTRL (Offset 0x10250086) */
#define BIT_INTR_CTRL BIT(4)
#define BIT_SDIO_VOLTAGE BIT(3)
#define BIT_BYPASS_INIT BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HSUS_CTRL (Offset 0x10250086) */
#define BIT_HCI_RESUME_RDY BIT(1)
#define BIT_HCI_SUS_REQ BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HMEBOX_E0_E1 (Offset 0x0088) */
#define BIT_SHIFT_HOST_MSG_E1 16
#define BIT_MASK_HOST_MSG_E1 0xffff
#define BIT_HOST_MSG_E1(x) \
(((x) & BIT_MASK_HOST_MSG_E1) << BIT_SHIFT_HOST_MSG_E1)
#define BITS_HOST_MSG_E1 (BIT_MASK_HOST_MSG_E1 << BIT_SHIFT_HOST_MSG_E1)
#define BIT_CLEAR_HOST_MSG_E1(x) ((x) & (~BITS_HOST_MSG_E1))
#define BIT_GET_HOST_MSG_E1(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E1) & BIT_MASK_HOST_MSG_E1)
#define BIT_SET_HOST_MSG_E1(x, v) \
(BIT_CLEAR_HOST_MSG_E1(x) | BIT_HOST_MSG_E1(v))
#define BIT_SHIFT_HOST_MSG_E0 0
#define BIT_MASK_HOST_MSG_E0 0xffff
#define BIT_HOST_MSG_E0(x) \
(((x) & BIT_MASK_HOST_MSG_E0) << BIT_SHIFT_HOST_MSG_E0)
#define BITS_HOST_MSG_E0 (BIT_MASK_HOST_MSG_E0 << BIT_SHIFT_HOST_MSG_E0)
#define BIT_CLEAR_HOST_MSG_E0(x) ((x) & (~BITS_HOST_MSG_E0))
#define BIT_GET_HOST_MSG_E0(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E0) & BIT_MASK_HOST_MSG_E0)
#define BIT_SET_HOST_MSG_E0(x, v) \
(BIT_CLEAR_HOST_MSG_E0(x) | BIT_HOST_MSG_E0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_RESPONSE_TIMER (Offset 0x10250088) */
#define BIT_SHIFT_CMDIN_2RESP_TIMER 0
#define BIT_MASK_CMDIN_2RESP_TIMER 0xffff
#define BIT_CMDIN_2RESP_TIMER(x) \
(((x) & BIT_MASK_CMDIN_2RESP_TIMER) << BIT_SHIFT_CMDIN_2RESP_TIMER)
#define BITS_CMDIN_2RESP_TIMER \
(BIT_MASK_CMDIN_2RESP_TIMER << BIT_SHIFT_CMDIN_2RESP_TIMER)
#define BIT_CLEAR_CMDIN_2RESP_TIMER(x) ((x) & (~BITS_CMDIN_2RESP_TIMER))
#define BIT_GET_CMDIN_2RESP_TIMER(x) \
(((x) >> BIT_SHIFT_CMDIN_2RESP_TIMER) & BIT_MASK_CMDIN_2RESP_TIMER)
#define BIT_SET_CMDIN_2RESP_TIMER(x, v) \
(BIT_CLEAR_CMDIN_2RESP_TIMER(x) | BIT_CMDIN_2RESP_TIMER(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_CMD_CRC (Offset 0x1025008A) */
#define BIT_SHIFT_SDIO_CMD_CRC 1
#define BIT_MASK_SDIO_CMD_CRC 0x7f
#define BIT_SDIO_CMD_CRC(x) \
(((x) & BIT_MASK_SDIO_CMD_CRC) << BIT_SHIFT_SDIO_CMD_CRC)
#define BITS_SDIO_CMD_CRC (BIT_MASK_SDIO_CMD_CRC << BIT_SHIFT_SDIO_CMD_CRC)
#define BIT_CLEAR_SDIO_CMD_CRC(x) ((x) & (~BITS_SDIO_CMD_CRC))
#define BIT_GET_SDIO_CMD_CRC(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_CRC) & BIT_MASK_SDIO_CMD_CRC)
#define BIT_SET_SDIO_CMD_CRC(x, v) \
(BIT_CLEAR_SDIO_CMD_CRC(x) | BIT_SDIO_CMD_CRC(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_CMD_CRC (Offset 0x1025008A) */
#define BIT_SHIFT_SDIO_CMD_CRC_V1 0
#define BIT_MASK_SDIO_CMD_CRC_V1 0xff
#define BIT_SDIO_CMD_CRC_V1(x) \
(((x) & BIT_MASK_SDIO_CMD_CRC_V1) << BIT_SHIFT_SDIO_CMD_CRC_V1)
#define BITS_SDIO_CMD_CRC_V1 \
(BIT_MASK_SDIO_CMD_CRC_V1 << BIT_SHIFT_SDIO_CMD_CRC_V1)
#define BIT_CLEAR_SDIO_CMD_CRC_V1(x) ((x) & (~BITS_SDIO_CMD_CRC_V1))
#define BIT_GET_SDIO_CMD_CRC_V1(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_CRC_V1) & BIT_MASK_SDIO_CMD_CRC_V1)
#define BIT_SET_SDIO_CMD_CRC_V1(x, v) \
(BIT_CLEAR_SDIO_CMD_CRC_V1(x) | BIT_SDIO_CMD_CRC_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SDIO_CMD_CRC (Offset 0x1025008A) */
#define BIT_SDIO_CMD_E_BIT BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HMEBOX_E2_E3 (Offset 0x008C) */
#define BIT_SHIFT_HOST_MSG_E3 16
#define BIT_MASK_HOST_MSG_E3 0xffff
#define BIT_HOST_MSG_E3(x) \
(((x) & BIT_MASK_HOST_MSG_E3) << BIT_SHIFT_HOST_MSG_E3)
#define BITS_HOST_MSG_E3 (BIT_MASK_HOST_MSG_E3 << BIT_SHIFT_HOST_MSG_E3)
#define BIT_CLEAR_HOST_MSG_E3(x) ((x) & (~BITS_HOST_MSG_E3))
#define BIT_GET_HOST_MSG_E3(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E3) & BIT_MASK_HOST_MSG_E3)
#define BIT_SET_HOST_MSG_E3(x, v) \
(BIT_CLEAR_HOST_MSG_E3(x) | BIT_HOST_MSG_E3(v))
#define BIT_SHIFT_HOST_MSG_E2 0
#define BIT_MASK_HOST_MSG_E2 0xffff
#define BIT_HOST_MSG_E2(x) \
(((x) & BIT_MASK_HOST_MSG_E2) << BIT_SHIFT_HOST_MSG_E2)
#define BITS_HOST_MSG_E2 (BIT_MASK_HOST_MSG_E2 << BIT_SHIFT_HOST_MSG_E2)
#define BIT_CLEAR_HOST_MSG_E2(x) ((x) & (~BITS_HOST_MSG_E2))
#define BIT_GET_HOST_MSG_E2(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E2) & BIT_MASK_HOST_MSG_E2)
#define BIT_SET_HOST_MSG_E2(x, v) \
(BIT_CLEAR_HOST_MSG_E2(x) | BIT_HOST_MSG_E2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_EABM BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_ACKF BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_TXFIFO_TH_INT BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_DLDM BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_NODS BIT(29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_AFEP BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_ESWR BIT(28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LPS_DIS_SW BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_PWMM BIT(27)
#define BIT_WLLPSOP_EECK BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_WLPON BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_WLMACOFF BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_ELDO BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_EXTAL BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WL_SYNPON_VOLTSPDN BIT(23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LPS_BB_REG_EN BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LOP_SKIP BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_WLBBOFF BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LPS_BB_PWR_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LOP_MEMDS BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_WLMEM_DS BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LPS_BB_GLB_EN BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WLLPSOP_LDO_WAIT_TIME BIT(20)
#define BIT_WLLPSOP_ANA_CLK_DIVISION_2 BIT(19)
#define BIT_AFE_BCN BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_SUS_DIS_SW BIT(15)
#define BIT_SUS_SKP_PAGE0_ALD BIT(14)
#define BIT_SUS_LDO_SLEEP BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_SHIFT_LPLDH12_VADJ_STEP_DN 12
#define BIT_MASK_LPLDH12_VADJ_STEP_DN 0xf
#define BIT_LPLDH12_VADJ_STEP_DN(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_STEP_DN) \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN)
#define BITS_LPLDH12_VADJ_STEP_DN \
(BIT_MASK_LPLDH12_VADJ_STEP_DN << BIT_SHIFT_LPLDH12_VADJ_STEP_DN)
#define BIT_CLEAR_LPLDH12_VADJ_STEP_DN(x) ((x) & (~BITS_LPLDH12_VADJ_STEP_DN))
#define BIT_GET_LPLDH12_VADJ_STEP_DN(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_STEP_DN) & \
BIT_MASK_LPLDH12_VADJ_STEP_DN)
#define BIT_SET_LPLDH12_VADJ_STEP_DN(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_STEP_DN(x) | BIT_LPLDH12_VADJ_STEP_DN(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_PFM_EN_ZCD BIT(12)
#define BIT_KEEP_RFC_EN BIT(11)
#define BIT_MACON_NO_RFCISO_RELEASE BIT(10)
#define BIT_MACON_NO_AFEPORT_PWR BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_SHIFT_V15ADJ_L1_STEP_DN 8
#define BIT_MASK_V15ADJ_L1_STEP_DN 0x7
#define BIT_V15ADJ_L1_STEP_DN(x) \
(((x) & BIT_MASK_V15ADJ_L1_STEP_DN) << BIT_SHIFT_V15ADJ_L1_STEP_DN)
#define BITS_V15ADJ_L1_STEP_DN \
(BIT_MASK_V15ADJ_L1_STEP_DN << BIT_SHIFT_V15ADJ_L1_STEP_DN)
#define BIT_CLEAR_V15ADJ_L1_STEP_DN(x) ((x) & (~BITS_V15ADJ_L1_STEP_DN))
#define BIT_GET_V15ADJ_L1_STEP_DN(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_STEP_DN) & BIT_MASK_V15ADJ_L1_STEP_DN)
#define BIT_SET_V15ADJ_L1_STEP_DN(x, v) \
(BIT_CLEAR_V15ADJ_L1_STEP_DN(x) | BIT_V15ADJ_L1_STEP_DN(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_SHIFT_V15ADJ_L1_STEP_DN_V1 8
#define BIT_MASK_V15ADJ_L1_STEP_DN_V1 0xf
#define BIT_V15ADJ_L1_STEP_DN_V1(x) \
(((x) & BIT_MASK_V15ADJ_L1_STEP_DN_V1) \
<< BIT_SHIFT_V15ADJ_L1_STEP_DN_V1)
#define BITS_V15ADJ_L1_STEP_DN_V1 \
(BIT_MASK_V15ADJ_L1_STEP_DN_V1 << BIT_SHIFT_V15ADJ_L1_STEP_DN_V1)
#define BIT_CLEAR_V15ADJ_L1_STEP_DN_V1(x) ((x) & (~BITS_V15ADJ_L1_STEP_DN_V1))
#define BIT_GET_V15ADJ_L1_STEP_DN_V1(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_STEP_DN_V1) & \
BIT_MASK_V15ADJ_L1_STEP_DN_V1)
#define BIT_SET_V15ADJ_L1_STEP_DN_V1(x, v) \
(BIT_CLEAR_V15ADJ_L1_STEP_DN_V1(x) | BIT_V15ADJ_L1_STEP_DN_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_MACON_NO_CPU_EN BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_LD_B15V_EN BIT(7)
#define BIT_LPRX_BCN_EN BIT(5)
#define BIT_LBN BIT(4)
#define BIT_LXSPS_UNUSED BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_FORCE_LEAVE_LPS BIT(3)
#define BIT_SW_AFE_MODE BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_REGU_32K_CLK_EN BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HSISR (Offset 0x10250090) */
#define BIT_DRV_WLAN_INT_CLR BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WLLPS_CTRL (Offset 0x0090) */
#define BIT_WL_LPS_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HSISR (Offset 0x10250090) */
#define BIT_DRV_WLAN_INT BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_HSIMR (Offset 0x10250091) */
#define BIT_HISR_MASK BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_BB_DBG_SEL_AFE_SDM_V3 BIT(31)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_BB_DBG_SEL_AFE_SDM_BIT0 BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_ORDER_SDM BIT(30)
#define BIT_RFE_SEL_SDM BIT(29)
#define BIT_SHIFT_REF_SEL 25
#define BIT_MASK_REF_SEL 0xf
#define BIT_REF_SEL(x) (((x) & BIT_MASK_REF_SEL) << BIT_SHIFT_REF_SEL)
#define BITS_REF_SEL (BIT_MASK_REF_SEL << BIT_SHIFT_REF_SEL)
#define BIT_CLEAR_REF_SEL(x) ((x) & (~BITS_REF_SEL))
#define BIT_GET_REF_SEL(x) (((x) >> BIT_SHIFT_REF_SEL) & BIT_MASK_REF_SEL)
#define BIT_SET_REF_SEL(x, v) (BIT_CLEAR_REF_SEL(x) | BIT_REF_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_F0F_SDM_V2 12
#define BIT_MASK_F0F_SDM_V2 0x1fff
#define BIT_F0F_SDM_V2(x) (((x) & BIT_MASK_F0F_SDM_V2) << BIT_SHIFT_F0F_SDM_V2)
#define BITS_F0F_SDM_V2 (BIT_MASK_F0F_SDM_V2 << BIT_SHIFT_F0F_SDM_V2)
#define BIT_CLEAR_F0F_SDM_V2(x) ((x) & (~BITS_F0F_SDM_V2))
#define BIT_GET_F0F_SDM_V2(x) \
(((x) >> BIT_SHIFT_F0F_SDM_V2) & BIT_MASK_F0F_SDM_V2)
#define BIT_SET_F0F_SDM_V2(x, v) (BIT_CLEAR_F0F_SDM_V2(x) | BIT_F0F_SDM_V2(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_F0F_SDM 12
#define BIT_MASK_F0F_SDM 0x1fff
#define BIT_F0F_SDM(x) (((x) & BIT_MASK_F0F_SDM) << BIT_SHIFT_F0F_SDM)
#define BITS_F0F_SDM (BIT_MASK_F0F_SDM << BIT_SHIFT_F0F_SDM)
#define BIT_CLEAR_F0F_SDM(x) ((x) & (~BITS_F0F_SDM))
#define BIT_GET_F0F_SDM(x) (((x) >> BIT_SHIFT_F0F_SDM) & BIT_MASK_F0F_SDM)
#define BIT_SET_F0F_SDM(x, v) (BIT_CLEAR_F0F_SDM(x) | BIT_F0F_SDM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_F0N_SDM_V2 9
#define BIT_MASK_F0N_SDM_V2 0x7
#define BIT_F0N_SDM_V2(x) (((x) & BIT_MASK_F0N_SDM_V2) << BIT_SHIFT_F0N_SDM_V2)
#define BITS_F0N_SDM_V2 (BIT_MASK_F0N_SDM_V2 << BIT_SHIFT_F0N_SDM_V2)
#define BIT_CLEAR_F0N_SDM_V2(x) ((x) & (~BITS_F0N_SDM_V2))
#define BIT_GET_F0N_SDM_V2(x) \
(((x) >> BIT_SHIFT_F0N_SDM_V2) & BIT_MASK_F0N_SDM_V2)
#define BIT_SET_F0N_SDM_V2(x, v) (BIT_CLEAR_F0N_SDM_V2(x) | BIT_F0N_SDM_V2(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_F0N_SDM 9
#define BIT_MASK_F0N_SDM 0x7
#define BIT_F0N_SDM(x) (((x) & BIT_MASK_F0N_SDM) << BIT_SHIFT_F0N_SDM)
#define BITS_F0N_SDM (BIT_MASK_F0N_SDM << BIT_SHIFT_F0N_SDM)
#define BIT_CLEAR_F0N_SDM(x) ((x) & (~BITS_F0N_SDM))
#define BIT_GET_F0N_SDM(x) (((x) >> BIT_SHIFT_F0N_SDM) & BIT_MASK_F0N_SDM)
#define BIT_SET_F0N_SDM(x, v) (BIT_CLEAR_F0N_SDM(x) | BIT_F0N_SDM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_DIVN_SDM_V2 3
#define BIT_MASK_DIVN_SDM_V2 0x3f
#define BIT_DIVN_SDM_V2(x) \
(((x) & BIT_MASK_DIVN_SDM_V2) << BIT_SHIFT_DIVN_SDM_V2)
#define BITS_DIVN_SDM_V2 (BIT_MASK_DIVN_SDM_V2 << BIT_SHIFT_DIVN_SDM_V2)
#define BIT_CLEAR_DIVN_SDM_V2(x) ((x) & (~BITS_DIVN_SDM_V2))
#define BIT_GET_DIVN_SDM_V2(x) \
(((x) >> BIT_SHIFT_DIVN_SDM_V2) & BIT_MASK_DIVN_SDM_V2)
#define BIT_SET_DIVN_SDM_V2(x, v) \
(BIT_CLEAR_DIVN_SDM_V2(x) | BIT_DIVN_SDM_V2(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_DIVN_SDM 3
#define BIT_MASK_DIVN_SDM 0x3f
#define BIT_DIVN_SDM(x) (((x) & BIT_MASK_DIVN_SDM) << BIT_SHIFT_DIVN_SDM)
#define BITS_DIVN_SDM (BIT_MASK_DIVN_SDM << BIT_SHIFT_DIVN_SDM)
#define BIT_CLEAR_DIVN_SDM(x) ((x) & (~BITS_DIVN_SDM))
#define BIT_GET_DIVN_SDM(x) (((x) >> BIT_SHIFT_DIVN_SDM) & BIT_MASK_DIVN_SDM)
#define BIT_SET_DIVN_SDM(x, v) (BIT_CLEAR_DIVN_SDM(x) | BIT_DIVN_SDM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL5 (Offset 0x0094) */
#define BIT_SHIFT_DITHER_SDM_V2 0
#define BIT_MASK_DITHER_SDM_V2 0x7
#define BIT_DITHER_SDM_V2(x) \
(((x) & BIT_MASK_DITHER_SDM_V2) << BIT_SHIFT_DITHER_SDM_V2)
#define BITS_DITHER_SDM_V2 (BIT_MASK_DITHER_SDM_V2 << BIT_SHIFT_DITHER_SDM_V2)
#define BIT_CLEAR_DITHER_SDM_V2(x) ((x) & (~BITS_DITHER_SDM_V2))
#define BIT_GET_DITHER_SDM_V2(x) \
(((x) >> BIT_SHIFT_DITHER_SDM_V2) & BIT_MASK_DITHER_SDM_V2)
#define BIT_SET_DITHER_SDM_V2(x, v) \
(BIT_CLEAR_DITHER_SDM_V2(x) | BIT_DITHER_SDM_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_GPIO_DEBOUNCE_CTRL (Offset 0x0098) */
#define BIT_WLGP_DBC1EN BIT(15)
#define BIT_SHIFT_WLGP_DBC1 8
#define BIT_MASK_WLGP_DBC1 0xf
#define BIT_WLGP_DBC1(x) (((x) & BIT_MASK_WLGP_DBC1) << BIT_SHIFT_WLGP_DBC1)
#define BITS_WLGP_DBC1 (BIT_MASK_WLGP_DBC1 << BIT_SHIFT_WLGP_DBC1)
#define BIT_CLEAR_WLGP_DBC1(x) ((x) & (~BITS_WLGP_DBC1))
#define BIT_GET_WLGP_DBC1(x) (((x) >> BIT_SHIFT_WLGP_DBC1) & BIT_MASK_WLGP_DBC1)
#define BIT_SET_WLGP_DBC1(x, v) (BIT_CLEAR_WLGP_DBC1(x) | BIT_WLGP_DBC1(v))
#define BIT_WLGP_DBC0EN BIT(7)
#define BIT_SHIFT_WLGP_DBC0 0
#define BIT_MASK_WLGP_DBC0 0xf
#define BIT_WLGP_DBC0(x) (((x) & BIT_MASK_WLGP_DBC0) << BIT_SHIFT_WLGP_DBC0)
#define BITS_WLGP_DBC0 (BIT_MASK_WLGP_DBC0 << BIT_SHIFT_WLGP_DBC0)
#define BIT_CLEAR_WLGP_DBC0(x) ((x) & (~BITS_WLGP_DBC0))
#define BIT_GET_WLGP_DBC0(x) (((x) >> BIT_SHIFT_WLGP_DBC0) & BIT_MASK_WLGP_DBC0)
#define BIT_SET_WLGP_DBC0(x, v) (BIT_CLEAR_WLGP_DBC0(x) | BIT_WLGP_DBC0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RPWM2 (Offset 0x009C) */
#define BIT_SHIFT_RPWM2 16
#define BIT_MASK_RPWM2 0xffff
#define BIT_RPWM2(x) (((x) & BIT_MASK_RPWM2) << BIT_SHIFT_RPWM2)
#define BITS_RPWM2 (BIT_MASK_RPWM2 << BIT_SHIFT_RPWM2)
#define BIT_CLEAR_RPWM2(x) ((x) & (~BITS_RPWM2))
#define BIT_GET_RPWM2(x) (((x) >> BIT_SHIFT_RPWM2) & BIT_MASK_RPWM2)
#define BIT_SET_RPWM2(x, v) (BIT_CLEAR_RPWM2(x) | BIT_RPWM2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYSON_FSM_MON (Offset 0x00A0) */
#define BIT_SHIFT_FSM_MON_SEL 24
#define BIT_MASK_FSM_MON_SEL 0x7
#define BIT_FSM_MON_SEL(x) \
(((x) & BIT_MASK_FSM_MON_SEL) << BIT_SHIFT_FSM_MON_SEL)
#define BITS_FSM_MON_SEL (BIT_MASK_FSM_MON_SEL << BIT_SHIFT_FSM_MON_SEL)
#define BIT_CLEAR_FSM_MON_SEL(x) ((x) & (~BITS_FSM_MON_SEL))
#define BIT_GET_FSM_MON_SEL(x) \
(((x) >> BIT_SHIFT_FSM_MON_SEL) & BIT_MASK_FSM_MON_SEL)
#define BIT_SET_FSM_MON_SEL(x, v) \
(BIT_CLEAR_FSM_MON_SEL(x) | BIT_FSM_MON_SEL(v))
#define BIT_DOP_ELDO BIT(23)
#define BIT_FSM_MON_UPD BIT(15)
#define BIT_SHIFT_FSM_PAR 0
#define BIT_MASK_FSM_PAR 0x7fff
#define BIT_FSM_PAR(x) (((x) & BIT_MASK_FSM_PAR) << BIT_SHIFT_FSM_PAR)
#define BITS_FSM_PAR (BIT_MASK_FSM_PAR << BIT_SHIFT_FSM_PAR)
#define BIT_CLEAR_FSM_PAR(x) ((x) & (~BITS_FSM_PAR))
#define BIT_GET_FSM_PAR(x) (((x) >> BIT_SHIFT_FSM_PAR) & BIT_MASK_FSM_PAR)
#define BIT_SET_FSM_PAR(x, v) (BIT_CLEAR_FSM_PAR(x) | BIT_FSM_PAR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL6 (Offset 0x00A4) */
#define BIT_SHIFT_TSFT_SEL_V1 0
#define BIT_MASK_TSFT_SEL_V1 0x7
#define BIT_TSFT_SEL_V1(x) \
(((x) & BIT_MASK_TSFT_SEL_V1) << BIT_SHIFT_TSFT_SEL_V1)
#define BITS_TSFT_SEL_V1 (BIT_MASK_TSFT_SEL_V1 << BIT_SHIFT_TSFT_SEL_V1)
#define BIT_CLEAR_TSFT_SEL_V1(x) ((x) & (~BITS_TSFT_SEL_V1))
#define BIT_GET_TSFT_SEL_V1(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_V1) & BIT_MASK_TSFT_SEL_V1)
#define BIT_SET_TSFT_SEL_V1(x, v) \
(BIT_CLEAR_TSFT_SEL_V1(x) | BIT_TSFT_SEL_V1(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL6 (Offset 0x00A4) */
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1 0
#define BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1 0x7
#define BIT_BB_DBG_SEL_AFE_SDM_BIT3_1(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1) \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1)
#define BITS_BB_DBG_SEL_AFE_SDM_BIT3_1 \
(BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1 \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM_BIT3_1(x) \
((x) & (~BITS_BB_DBG_SEL_AFE_SDM_BIT3_1))
#define BIT_GET_BB_DBG_SEL_AFE_SDM_BIT3_1(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1) & \
BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1)
#define BIT_SET_BB_DBG_SEL_AFE_SDM_BIT3_1(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM_BIT3_1(x) | \
BIT_BB_DBG_SEL_AFE_SDM_BIT3_1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PMC_DBG_CTRL1 (Offset 0x00A8) */
#define BIT_BT_INT_EN BIT(31)
#define BIT_SHIFT_RD_WR_WIFI_BT_INFO 16
#define BIT_MASK_RD_WR_WIFI_BT_INFO 0x7fff
#define BIT_RD_WR_WIFI_BT_INFO(x) \
(((x) & BIT_MASK_RD_WR_WIFI_BT_INFO) << BIT_SHIFT_RD_WR_WIFI_BT_INFO)
#define BITS_RD_WR_WIFI_BT_INFO \
(BIT_MASK_RD_WR_WIFI_BT_INFO << BIT_SHIFT_RD_WR_WIFI_BT_INFO)
#define BIT_CLEAR_RD_WR_WIFI_BT_INFO(x) ((x) & (~BITS_RD_WR_WIFI_BT_INFO))
#define BIT_GET_RD_WR_WIFI_BT_INFO(x) \
(((x) >> BIT_SHIFT_RD_WR_WIFI_BT_INFO) & BIT_MASK_RD_WR_WIFI_BT_INFO)
#define BIT_SET_RD_WR_WIFI_BT_INFO(x, v) \
(BIT_CLEAR_RD_WR_WIFI_BT_INFO(x) | BIT_RD_WR_WIFI_BT_INFO(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PMC_DBG_CTRL1 (Offset 0x00A8) */
#define BIT_PMC_WR_OVF BIT(8)
#define BIT_SHIFT_WLPMC_ERRINT 0
#define BIT_MASK_WLPMC_ERRINT 0xff
#define BIT_WLPMC_ERRINT(x) \
(((x) & BIT_MASK_WLPMC_ERRINT) << BIT_SHIFT_WLPMC_ERRINT)
#define BITS_WLPMC_ERRINT (BIT_MASK_WLPMC_ERRINT << BIT_SHIFT_WLPMC_ERRINT)
#define BIT_CLEAR_WLPMC_ERRINT(x) ((x) & (~BITS_WLPMC_ERRINT))
#define BIT_GET_WLPMC_ERRINT(x) \
(((x) >> BIT_SHIFT_WLPMC_ERRINT) & BIT_MASK_WLPMC_ERRINT)
#define BIT_SET_WLPMC_ERRINT(x, v) \
(BIT_CLEAR_WLPMC_ERRINT(x) | BIT_WLPMC_ERRINT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_SHIFT_SEL_V 30
#define BIT_MASK_SEL_V 0x3
#define BIT_SEL_V(x) (((x) & BIT_MASK_SEL_V) << BIT_SHIFT_SEL_V)
#define BITS_SEL_V (BIT_MASK_SEL_V << BIT_SHIFT_SEL_V)
#define BIT_CLEAR_SEL_V(x) ((x) & (~BITS_SEL_V))
#define BIT_GET_SEL_V(x) (((x) >> BIT_SHIFT_SEL_V) & BIT_MASK_SEL_V)
#define BIT_SET_SEL_V(x, v) (BIT_CLEAR_SEL_V(x) | BIT_SEL_V(v))
#define BIT_SEL_LDO_PC BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_SHIFT_CK_MON_SEL 26
#define BIT_MASK_CK_MON_SEL 0x7
#define BIT_CK_MON_SEL(x) (((x) & BIT_MASK_CK_MON_SEL) << BIT_SHIFT_CK_MON_SEL)
#define BITS_CK_MON_SEL (BIT_MASK_CK_MON_SEL << BIT_SHIFT_CK_MON_SEL)
#define BIT_CLEAR_CK_MON_SEL(x) ((x) & (~BITS_CK_MON_SEL))
#define BIT_GET_CK_MON_SEL(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL) & BIT_MASK_CK_MON_SEL)
#define BIT_SET_CK_MON_SEL(x, v) (BIT_CLEAR_CK_MON_SEL(x) | BIT_CK_MON_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_SHIFT_CK_MON_SEL_V2 26
#define BIT_MASK_CK_MON_SEL_V2 0x7
#define BIT_CK_MON_SEL_V2(x) \
(((x) & BIT_MASK_CK_MON_SEL_V2) << BIT_SHIFT_CK_MON_SEL_V2)
#define BITS_CK_MON_SEL_V2 (BIT_MASK_CK_MON_SEL_V2 << BIT_SHIFT_CK_MON_SEL_V2)
#define BIT_CLEAR_CK_MON_SEL_V2(x) ((x) & (~BITS_CK_MON_SEL_V2))
#define BIT_GET_CK_MON_SEL_V2(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL_V2) & BIT_MASK_CK_MON_SEL_V2)
#define BIT_SET_CK_MON_SEL_V2(x, v) \
(BIT_CLEAR_CK_MON_SEL_V2(x) | BIT_CK_MON_SEL_V2(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_CK_MON_EN BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_WL_DSS_SPEED_EN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_FREF_EDGE BIT(24)
#define BIT_CK320M_EN BIT(23)
#define BIT_CK_5M_EN BIT(22)
#define BIT_TESTEN BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL7 (Offset 0x00AC) */
#define BIT_LD_B12V_EN_V1 BIT(7)
#define BIT_SHIFT_WL_DSS_COUNT_OUT 0
#define BIT_MASK_WL_DSS_COUNT_OUT 0xfffff
#define BIT_WL_DSS_COUNT_OUT(x) \
(((x) & BIT_MASK_WL_DSS_COUNT_OUT) << BIT_SHIFT_WL_DSS_COUNT_OUT)
#define BITS_WL_DSS_COUNT_OUT \
(BIT_MASK_WL_DSS_COUNT_OUT << BIT_SHIFT_WL_DSS_COUNT_OUT)
#define BIT_CLEAR_WL_DSS_COUNT_OUT(x) ((x) & (~BITS_WL_DSS_COUNT_OUT))
#define BIT_GET_WL_DSS_COUNT_OUT(x) \
(((x) >> BIT_SHIFT_WL_DSS_COUNT_OUT) & BIT_MASK_WL_DSS_COUNT_OUT)
#define BIT_SET_WL_DSS_COUNT_OUT(x, v) \
(BIT_CLEAR_WL_DSS_COUNT_OUT(x) | BIT_WL_DSS_COUNT_OUT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TIMEOUT_INTERRUPT2_MASK BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_PSTIMER_2_MSK BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TIMEOUT_INTERRUTP1_MASK BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_PSTIMER_1_MSK BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_PSTIMEOUT_MSK BIT(29)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_PSTIMER_0_MSK BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_GTINT4_MSK BIT(28)
#define BIT_GTINT4 BIT(28)
#define BIT_GTINT3_MSK BIT(27)
#define BIT_GTINT3 BIT(27)
#define BIT_TXBCN0ERR_MSK BIT(26)
#define BIT_TXBCN0ERR BIT(26)
#define BIT_TXBCN0OK_MSK BIT(25)
#define BIT_TXBCN0OK BIT(25)
#define BIT_TSF_BIT32_TOGGLE_MSK BIT(24)
#define BIT_TSF_BIT32_TOGGLE BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMA_START_INT_MSK BIT(23)
#define BIT_TXDMA_STOP_INT_MSK BIT(22)
#define BIT_HISR7_IND_MSK BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_BCNDMAINT0_MSK BIT(20)
#define BIT_BCNDMAINT0 BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR6_IND_MSK BIT(19)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR5_MSK BIT(18)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR5_IND_MSK BIT(18)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR4_MSK BIT(17)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR4_IND_MSK BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_BCNDERR0_MSK BIT(16)
#define BIT_BCNDERR0 BIT(16)
#define BIT_HSISR_IND_ON_INT_MSK BIT(15)
#define BIT_HSISR_IND_ON_INT BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_BCNDMAINT_E_MSK BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR3_IND_INT_MSK BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR3_IND_MSK BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR2_IND_INT_MSK BIT(13)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR2_IND_MSK BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_CTWEND_MSK BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR1_IND_MSK BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HISR1_IND_INT_MSK BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_C2HCMD_MSK BIT(10)
#define BIT_C2HCMD BIT(10)
#define BIT_CPWM2_MSK BIT(9)
#define BIT_CPWM2 BIT(9)
#define BIT_CPWM_MSK BIT(8)
#define BIT_CPWM BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_HIGHDOK_MSK BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMAOK_CHANNEL15_MSK BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_MGTDOK_MSK BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMAOK_CHANNEL14_MSK BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_BKDOK_MSK BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMAOK_CHANNEL3_MSK BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_BEDOK_MSK BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMAOK_CHANNEL2_MSK BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_VIDOK_MSK BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMAOK_CHANNEL1_MSK BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_VODOK_MSK BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_TXDMAOK_CHANNEL0_MSK BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR0 (Offset 0x00B0) */
#define BIT_RDU_MSK BIT(1)
#define BIT_RDU BIT(1)
#define BIT_RXOK_MSK BIT(0)
#define BIT_RXOK BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HISR0 (Offset 0x00B4) */
#define BIT_PSTIMEOUT2 BIT(31)
#define BIT_PSTIMEOUT1 BIT(30)
#define BIT_PSTIMEOUT BIT(29)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HISR0 (Offset 0x00B4) */
#define BIT_HISR5_IND_INT BIT(18)
#define BIT_HISR4_IND_INT BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HISR0 (Offset 0x00B4) */
#define BIT_BCNDMAINT_E BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HISR0 (Offset 0x00B4) */
#define BIT_HISR3_IND_INT BIT(14)
#define BIT_HISR2_IND_INT BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HISR0 (Offset 0x00B4) */
#define BIT_CTWEND BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HISR0 (Offset 0x00B4) */
#define BIT_HISR1_IND_INT BIT(11)
#define BIT_HIGHDOK BIT(7)
#define BIT_MGTDOK BIT(6)
#define BIT_BKDOK BIT(5)
#define BIT_BEDOK BIT(4)
#define BIT_VIDOK BIT(3)
#define BIT_VODOK BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PRETXERR_HANDLE_MSK BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PRE_TX_ERR_INT_MSK BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BTON_STS_UPDATE_INT BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BTON_STS_UPDATE_MSK BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BTON_STS_UPDATE_MASK BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_MCU_ERR_MASK BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT7 BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT7_MSK BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT7__MSK BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT6 BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT6_MSK BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT6__MSK BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT5 BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT5_MSK BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT5__MSK BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT4 BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT4_MSK BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT4__MSK BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BCNDMAINT3_MSK BIT(23)
#define BIT_BCNDMAINT3 BIT(23)
#define BIT_BCNDMAINT2_MSK BIT(22)
#define BIT_BCNDMAINT2 BIT(22)
#define BIT_BCNDMAINT1_MSK BIT(21)
#define BIT_BCNDMAINT1 BIT(21)
#define BIT_BCNDERR7_MSK BIT(20)
#define BIT_BCNDERR7 BIT(20)
#define BIT_BCNDERR6_MSK BIT(19)
#define BIT_BCNDERR6 BIT(19)
#define BIT_BCNDERR5_MSK BIT(18)
#define BIT_BCNDERR5 BIT(18)
#define BIT_BCNDERR4_MSK BIT(17)
#define BIT_BCNDERR4 BIT(17)
#define BIT_BCNDERR3_MSK BIT(16)
#define BIT_BCNDERR3 BIT(16)
#define BIT_BCNDERR2_MSK BIT(15)
#define BIT_BCNDERR2 BIT(15)
#define BIT_BCNDERR1_MSK BIT(14)
#define BIT_BCNDERR1 BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_ATIMEND_E_MSK BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_ATIMEND_MSK BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_ATIMEND__MSK BIT(12)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_ATIMEND_E_V1_MSK BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_TXERR_MSK BIT(11)
#define BIT_TXERR_INT BIT(11)
#define BIT_RXERR_MSK BIT(10)
#define BIT_RXERR_INT BIT(10)
#define BIT_TXFOVW_MSK BIT(9)
#define BIT_TXFOVW BIT(9)
#define BIT_FOVW_MSK BIT(8)
#define BIT_FOVW BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_CPU_MGQ_EARLY_INT_MSK BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_CPU_MGQ_TXDONE_MSK BIT(5)
#define BIT_CPU_MGQ_TXDONE BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PS_TIMER_C_MSK BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PSTIMER_5_MSK BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PS_TIMER_B_MSK BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PSTIMER_4_MSK BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PS_TIMER_A_MSK BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_PSTIMER_3_MSK BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_CPUMGQ_TX_TIMER_MSK BIT(1)
#define BIT_CPUMGQ_TX_TIMER BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR1 (Offset 0x00B8) */
#define BIT_BB_STOPRX_INT_MSK BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HISR1 (Offset 0x00BC) */
#define BIT_PRETXERR_HANDLE_INT BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HISR1 (Offset 0x00BC) */
#define BIT_MCU_ERR BIT(28)
#define BIT_ATIMEND_E BIT(13)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_HISR1 (Offset 0x00BC) */
#define BIT_ATIMEND_E_V1_INT BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HISR1 (Offset 0x00BC) */
#define BIT_PS_TIMER_C BIT(4)
#define BIT_PS_TIMER_B BIT(3)
#define BIT_PS_TIMER_A BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HISR1 (Offset 0x00BC) */
#define BIT_SHIFT_SYS_PINMUX_EN 0
#define BIT_MASK_SYS_PINMUX_EN 0xfffffff
#define BIT_SYS_PINMUX_EN(x) \
(((x) & BIT_MASK_SYS_PINMUX_EN) << BIT_SHIFT_SYS_PINMUX_EN)
#define BITS_SYS_PINMUX_EN (BIT_MASK_SYS_PINMUX_EN << BIT_SHIFT_SYS_PINMUX_EN)
#define BIT_CLEAR_SYS_PINMUX_EN(x) ((x) & (~BITS_SYS_PINMUX_EN))
#define BIT_GET_SYS_PINMUX_EN(x) \
(((x) >> BIT_SHIFT_SYS_PINMUX_EN) & BIT_MASK_SYS_PINMUX_EN)
#define BIT_SET_SYS_PINMUX_EN(x, v) \
(BIT_CLEAR_SYS_PINMUX_EN(x) | BIT_SYS_PINMUX_EN(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SDIO_ERR_RPT (Offset 0x102500C0) */
#define BIT_HR_FF_OVF BIT(6)
#define BIT_HR_FF_UDN BIT(5)
#define BIT_TXDMA_BUSY_ERR BIT(4)
#define BIT_TXDMA_VLD_ERR BIT(3)
#define BIT_QSEL_UNKNOWN_ERR BIT(2)
#define BIT_QSEL_MIS_ERR BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DBG_PORT_SEL (Offset 0x00C0) */
#define BIT_SHIFT_DEBUG_ST 0
#define BIT_MASK_DEBUG_ST 0xffffffffL
#define BIT_DEBUG_ST(x) (((x) & BIT_MASK_DEBUG_ST) << BIT_SHIFT_DEBUG_ST)
#define BITS_DEBUG_ST (BIT_MASK_DEBUG_ST << BIT_SHIFT_DEBUG_ST)
#define BIT_CLEAR_DEBUG_ST(x) ((x) & (~BITS_DEBUG_ST))
#define BIT_GET_DEBUG_ST(x) (((x) >> BIT_SHIFT_DEBUG_ST) & BIT_MASK_DEBUG_ST)
#define BIT_SET_DEBUG_ST(x, v) (BIT_CLEAR_DEBUG_ST(x) | BIT_DEBUG_ST(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_DIOERR_RPT (Offset 0x102500C0) */
#define BIT_SDIO_PAGE_ERR BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SDIO_ERR_RPT (Offset 0x102500C0) */
#define BIT_SDIO_OVERRD_ERR BIT(0)
#define BIT_SHIFT_SDIO_DATA_REPLY_TIME 0
#define BIT_MASK_SDIO_DATA_REPLY_TIME 0x7
#define BIT_SDIO_DATA_REPLY_TIME(x) \
(((x) & BIT_MASK_SDIO_DATA_REPLY_TIME) \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME)
#define BITS_SDIO_DATA_REPLY_TIME \
(BIT_MASK_SDIO_DATA_REPLY_TIME << BIT_SHIFT_SDIO_DATA_REPLY_TIME)
#define BIT_CLEAR_SDIO_DATA_REPLY_TIME(x) ((x) & (~BITS_SDIO_DATA_REPLY_TIME))
#define BIT_GET_SDIO_DATA_REPLY_TIME(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_REPLY_TIME) & \
BIT_MASK_SDIO_DATA_REPLY_TIME)
#define BIT_SET_SDIO_DATA_REPLY_TIME(x, v) \
(BIT_CLEAR_SDIO_DATA_REPLY_TIME(x) | BIT_SDIO_DATA_REPLY_TIME(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_CMD_ERRCNT (Offset 0x102500C2) */
#define BIT_SHIFT_CMD_CRC_ERR_CNT 0
#define BIT_MASK_CMD_CRC_ERR_CNT 0xff
#define BIT_CMD_CRC_ERR_CNT(x) \
(((x) & BIT_MASK_CMD_CRC_ERR_CNT) << BIT_SHIFT_CMD_CRC_ERR_CNT)
#define BITS_CMD_CRC_ERR_CNT \
(BIT_MASK_CMD_CRC_ERR_CNT << BIT_SHIFT_CMD_CRC_ERR_CNT)
#define BIT_CLEAR_CMD_CRC_ERR_CNT(x) ((x) & (~BITS_CMD_CRC_ERR_CNT))
#define BIT_GET_CMD_CRC_ERR_CNT(x) \
(((x) >> BIT_SHIFT_CMD_CRC_ERR_CNT) & BIT_MASK_CMD_CRC_ERR_CNT)
#define BIT_SET_CMD_CRC_ERR_CNT(x, v) \
(BIT_CLEAR_CMD_CRC_ERR_CNT(x) | BIT_CMD_CRC_ERR_CNT(v))
/* 2 REG_SDIO_DATA_ERRCNT (Offset 0x102500C3) */
#define BIT_SHIFT_DATA_CRC_ERR_CNT 0
#define BIT_MASK_DATA_CRC_ERR_CNT 0xff
#define BIT_DATA_CRC_ERR_CNT(x) \
(((x) & BIT_MASK_DATA_CRC_ERR_CNT) << BIT_SHIFT_DATA_CRC_ERR_CNT)
#define BITS_DATA_CRC_ERR_CNT \
(BIT_MASK_DATA_CRC_ERR_CNT << BIT_SHIFT_DATA_CRC_ERR_CNT)
#define BIT_CLEAR_DATA_CRC_ERR_CNT(x) ((x) & (~BITS_DATA_CRC_ERR_CNT))
#define BIT_GET_DATA_CRC_ERR_CNT(x) \
(((x) >> BIT_SHIFT_DATA_CRC_ERR_CNT) & BIT_MASK_DATA_CRC_ERR_CNT)
#define BIT_SET_DATA_CRC_ERR_CNT(x, v) \
(BIT_CLEAR_DATA_CRC_ERR_CNT(x) | BIT_DATA_CRC_ERR_CNT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_MAC_SOP BIT(25)
#define BIT_LDO11_ST_EXT BIT(24)
#define BIT_ANTSELB_S2 BIT(23)
#define BIT_ANTSELB_S1 BIT(22)
#define BIT_ANTSEL_S3 BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_USB3_USB2_TRANSITION BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_ANTSEL_S2 BIT(20)
#define BIT_ANTSEL_S1 BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_SHIFT_USB23_SW_MODE_V1 18
#define BIT_MASK_USB23_SW_MODE_V1 0x3
#define BIT_USB23_SW_MODE_V1(x) \
(((x) & BIT_MASK_USB23_SW_MODE_V1) << BIT_SHIFT_USB23_SW_MODE_V1)
#define BITS_USB23_SW_MODE_V1 \
(BIT_MASK_USB23_SW_MODE_V1 << BIT_SHIFT_USB23_SW_MODE_V1)
#define BIT_CLEAR_USB23_SW_MODE_V1(x) ((x) & (~BITS_USB23_SW_MODE_V1))
#define BIT_GET_USB23_SW_MODE_V1(x) \
(((x) >> BIT_SHIFT_USB23_SW_MODE_V1) & BIT_MASK_USB23_SW_MODE_V1)
#define BIT_SET_USB23_SW_MODE_V1(x, v) \
(BIT_CLEAR_USB23_SW_MODE_V1(x) | BIT_USB23_SW_MODE_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_FCSN_PU BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_NO_PDN_CHIPOFF_V1 BIT(17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_KEEP_PAD BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_RSM_EN_V1 BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_PAD_ALD_SKP BIT(16)
#define BIT_PAD_A_ANTSEL_E BIT(11)
#define BIT_PAD_A_ANTSELB_E BIT(10)
#define BIT_PAD_A_ANTSEL_O BIT(9)
#define BIT_PAD_A_ANTSELB_O BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_LD_B12V_EN BIT(7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_B15V_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EESK_IOSEL BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EECS_IOSEL_V1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EESK_DATA_O BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EECS_DATA_O_V1 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EESK_DATA_I BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EECS_DATA_I_V1 BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EECS_IOSEL BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EESK_IOSEL_V1 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EECS_DATA_O BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EESK_DATA_O_V1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EECS_DATA_I BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PAD_CTRL2 (Offset 0x00C4) */
#define BIT_EESK_DATA_I_V1 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_CMD_ERR_CONTENT (Offset 0x102500C4) */
#define BIT_SHIFT_SDIO_CMD_ERR_CONTENT 0
#define BIT_MASK_SDIO_CMD_ERR_CONTENT 0xffffffffffL
#define BIT_SDIO_CMD_ERR_CONTENT(x) \
(((x) & BIT_MASK_SDIO_CMD_ERR_CONTENT) \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT)
#define BITS_SDIO_CMD_ERR_CONTENT \
(BIT_MASK_SDIO_CMD_ERR_CONTENT << BIT_SHIFT_SDIO_CMD_ERR_CONTENT)
#define BIT_CLEAR_SDIO_CMD_ERR_CONTENT(x) ((x) & (~BITS_SDIO_CMD_ERR_CONTENT))
#define BIT_GET_SDIO_CMD_ERR_CONTENT(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_ERR_CONTENT) & \
BIT_MASK_SDIO_CMD_ERR_CONTENT)
#define BIT_SET_SDIO_CMD_ERR_CONTENT(x, v) \
(BIT_CLEAR_SDIO_CMD_ERR_CONTENT(x) | BIT_SDIO_CMD_ERR_CONTENT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_MEM_RMC (Offset 0x00C8) */
#define BIT_SHIFT_MEM_RME_WL_V2 4
#define BIT_MASK_MEM_RME_WL_V2 0x3f
#define BIT_MEM_RME_WL_V2(x) \
(((x) & BIT_MASK_MEM_RME_WL_V2) << BIT_SHIFT_MEM_RME_WL_V2)
#define BITS_MEM_RME_WL_V2 (BIT_MASK_MEM_RME_WL_V2 << BIT_SHIFT_MEM_RME_WL_V2)
#define BIT_CLEAR_MEM_RME_WL_V2(x) ((x) & (~BITS_MEM_RME_WL_V2))
#define BIT_GET_MEM_RME_WL_V2(x) \
(((x) >> BIT_SHIFT_MEM_RME_WL_V2) & BIT_MASK_MEM_RME_WL_V2)
#define BIT_SET_MEM_RME_WL_V2(x, v) \
(BIT_CLEAR_MEM_RME_WL_V2(x) | BIT_MEM_RME_WL_V2(v))
#define BIT_SHIFT_MEM_RME_HCI_V2 0
#define BIT_MASK_MEM_RME_HCI_V2 0x1f
#define BIT_MEM_RME_HCI_V2(x) \
(((x) & BIT_MASK_MEM_RME_HCI_V2) << BIT_SHIFT_MEM_RME_HCI_V2)
#define BITS_MEM_RME_HCI_V2 \
(BIT_MASK_MEM_RME_HCI_V2 << BIT_SHIFT_MEM_RME_HCI_V2)
#define BIT_CLEAR_MEM_RME_HCI_V2(x) ((x) & (~BITS_MEM_RME_HCI_V2))
#define BIT_GET_MEM_RME_HCI_V2(x) \
(((x) >> BIT_SHIFT_MEM_RME_HCI_V2) & BIT_MASK_MEM_RME_HCI_V2)
#define BIT_SET_MEM_RME_HCI_V2(x, v) \
(BIT_CLEAR_MEM_RME_HCI_V2(x) | BIT_MEM_RME_HCI_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_CRC_ERR_IDX (Offset 0x102500C9) */
#define BIT_D3_CRC_ERR BIT(4)
#define BIT_D2_CRC_ERR BIT(3)
#define BIT_D1_CRC_ERR BIT(2)
#define BIT_D0_CRC_ERR BIT(1)
#define BIT_CMD_CRC_ERR BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_DATA_CRC (Offset 0x102500CA) */
#define BIT_SHIFT_SDIO_DATA_CRC 0
#define BIT_MASK_SDIO_DATA_CRC 0xffff
#define BIT_SDIO_DATA_CRC(x) \
(((x) & BIT_MASK_SDIO_DATA_CRC) << BIT_SHIFT_SDIO_DATA_CRC)
#define BITS_SDIO_DATA_CRC (BIT_MASK_SDIO_DATA_CRC << BIT_SHIFT_SDIO_DATA_CRC)
#define BIT_CLEAR_SDIO_DATA_CRC(x) ((x) & (~BITS_SDIO_DATA_CRC))
#define BIT_GET_SDIO_DATA_CRC(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_CRC) & BIT_MASK_SDIO_DATA_CRC)
#define BIT_SET_SDIO_DATA_CRC(x, v) \
(BIT_CLEAR_SDIO_DATA_CRC(x) | BIT_SDIO_DATA_CRC(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_SHIFT_EFUSE_BURN_GNT 24
#define BIT_MASK_EFUSE_BURN_GNT 0xff
#define BIT_EFUSE_BURN_GNT(x) \
(((x) & BIT_MASK_EFUSE_BURN_GNT) << BIT_SHIFT_EFUSE_BURN_GNT)
#define BITS_EFUSE_BURN_GNT \
(BIT_MASK_EFUSE_BURN_GNT << BIT_SHIFT_EFUSE_BURN_GNT)
#define BIT_CLEAR_EFUSE_BURN_GNT(x) ((x) & (~BITS_EFUSE_BURN_GNT))
#define BIT_GET_EFUSE_BURN_GNT(x) \
(((x) >> BIT_SHIFT_EFUSE_BURN_GNT) & BIT_MASK_EFUSE_BURN_GNT)
#define BIT_SET_EFUSE_BURN_GNT(x, v) \
(BIT_CLEAR_EFUSE_BURN_GNT(x) | BIT_EFUSE_BURN_GNT(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_SHIFT_EFUSE_PG_PWD 24
#define BIT_MASK_EFUSE_PG_PWD 0xff
#define BIT_EFUSE_PG_PWD(x) \
(((x) & BIT_MASK_EFUSE_PG_PWD) << BIT_SHIFT_EFUSE_PG_PWD)
#define BITS_EFUSE_PG_PWD (BIT_MASK_EFUSE_PG_PWD << BIT_SHIFT_EFUSE_PG_PWD)
#define BIT_CLEAR_EFUSE_PG_PWD(x) ((x) & (~BITS_EFUSE_PG_PWD))
#define BIT_GET_EFUSE_PG_PWD(x) \
(((x) >> BIT_SHIFT_EFUSE_PG_PWD) & BIT_MASK_EFUSE_PG_PWD)
#define BIT_SET_EFUSE_PG_PWD(x, v) \
(BIT_CLEAR_EFUSE_PG_PWD(x) | BIT_EFUSE_PG_PWD(v))
#define BIT_DBG_READ_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_STOP_WL_PMC BIT(9)
#define BIT_STOP_SYM_PMC BIT(8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_SHIFT_EDATA1_V1 8
#define BIT_MASK_EDATA1_V1 0xff
#define BIT_EDATA1_V1(x) (((x) & BIT_MASK_EDATA1_V1) << BIT_SHIFT_EDATA1_V1)
#define BITS_EDATA1_V1 (BIT_MASK_EDATA1_V1 << BIT_SHIFT_EDATA1_V1)
#define BIT_CLEAR_EDATA1_V1(x) ((x) & (~BITS_EDATA1_V1))
#define BIT_GET_EDATA1_V1(x) (((x) >> BIT_SHIFT_EDATA1_V1) & BIT_MASK_EDATA1_V1)
#define BIT_SET_EDATA1_V1(x, v) (BIT_CLEAR_EDATA1_V1(x) | BIT_EDATA1_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_BT_ACCESS_WL_PAGE0 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_REG_RST_WLPMC BIT(5)
#define BIT_REG_RST_PD12N BIT(4)
#define BIT_SYSON_DIS_WLREG_WRMSK BIT(3)
#define BIT_SYSON_DIS_PMCREG_WRMSK BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TRANS_FIFO_STATUS (Offset 0x102500CC) */
#define BIT_TRANS_FIFO_UNDERFLOW BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_SHIFT_SYSON_REG_ARB 0
#define BIT_MASK_SYSON_REG_ARB 0x3
#define BIT_SYSON_REG_ARB(x) \
(((x) & BIT_MASK_SYSON_REG_ARB) << BIT_SHIFT_SYSON_REG_ARB)
#define BITS_SYSON_REG_ARB (BIT_MASK_SYSON_REG_ARB << BIT_SHIFT_SYSON_REG_ARB)
#define BIT_CLEAR_SYSON_REG_ARB(x) ((x) & (~BITS_SYSON_REG_ARB))
#define BIT_GET_SYSON_REG_ARB(x) \
(((x) >> BIT_SHIFT_SYSON_REG_ARB) & BIT_MASK_SYSON_REG_ARB)
#define BIT_SET_SYSON_REG_ARB(x, v) \
(BIT_CLEAR_SYSON_REG_ARB(x) | BIT_SYSON_REG_ARB(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SDIO_TRANS_FIFO_STATUS (Offset 0x102500CC) */
#define BIT_TRANS_FIFO_OVERFLOW BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PMC_DBG_CTRL2 (Offset 0x00CC) */
#define BIT_SHIFT_EDATA0_V1 0
#define BIT_MASK_EDATA0_V1 0xff
#define BIT_EDATA0_V1(x) (((x) & BIT_MASK_EDATA0_V1) << BIT_SHIFT_EDATA0_V1)
#define BITS_EDATA0_V1 (BIT_MASK_EDATA0_V1 << BIT_SHIFT_EDATA0_V1)
#define BIT_CLEAR_EDATA0_V1(x) ((x) & (~BITS_EDATA0_V1))
#define BIT_GET_EDATA0_V1(x) (((x) >> BIT_SHIFT_EDATA0_V1) & BIT_MASK_EDATA0_V1)
#define BIT_SET_EDATA0_V1(x, v) (BIT_CLEAR_EDATA0_V1(x) | BIT_EDATA0_V1(v))
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SCAN_PLL_BYPASS BIT(30)
#define BIT_DRF_BIST_FAIL_V1 BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_USB_DIS BIT(27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_DRF_BIST_READY_V1 BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_PCI_DIS BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_FAIL_V1 BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_BT_DIS BIT(25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_READY_V1 BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_WL_DIS BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_START_PAUSE_V1 BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SHIFT_BIST_RPT_SEL_V1 20
#define BIT_MASK_BIST_RPT_SEL_V1 0xf
#define BIT_BIST_RPT_SEL_V1(x) \
(((x) & BIT_MASK_BIST_RPT_SEL_V1) << BIT_SHIFT_BIST_RPT_SEL_V1)
#define BITS_BIST_RPT_SEL_V1 \
(BIT_MASK_BIST_RPT_SEL_V1 << BIT_SHIFT_BIST_RPT_SEL_V1)
#define BIT_CLEAR_BIST_RPT_SEL_V1(x) ((x) & (~BITS_BIST_RPT_SEL_V1))
#define BIT_GET_BIST_RPT_SEL_V1(x) \
(((x) >> BIT_SHIFT_BIST_RPT_SEL_V1) & BIT_MASK_BIST_RPT_SEL_V1)
#define BIT_SET_BIST_RPT_SEL_V1(x, v) \
(BIT_CLEAR_BIST_RPT_SEL_V1(x) | BIT_BIST_RPT_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SHIFT_BIST_RPT_SEL 16
#define BIT_MASK_BIST_RPT_SEL 0xf
#define BIT_BIST_RPT_SEL(x) \
(((x) & BIT_MASK_BIST_RPT_SEL) << BIT_SHIFT_BIST_RPT_SEL)
#define BITS_BIST_RPT_SEL (BIT_MASK_BIST_RPT_SEL << BIT_SHIFT_BIST_RPT_SEL)
#define BIT_CLEAR_BIST_RPT_SEL(x) ((x) & (~BITS_BIST_RPT_SEL))
#define BIT_GET_BIST_RPT_SEL(x) \
(((x) >> BIT_SHIFT_BIST_RPT_SEL) & BIT_MASK_BIST_RPT_SEL)
#define BIT_SET_BIST_RPT_SEL(x, v) \
(BIT_CLEAR_BIST_RPT_SEL(x) | BIT_BIST_RPT_SEL(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SHIFT_MBIST_RSTNI 8
#define BIT_MASK_MBIST_RSTNI 0x3ff
#define BIT_MBIST_RSTNI(x) \
(((x) & BIT_MASK_MBIST_RSTNI) << BIT_SHIFT_MBIST_RSTNI)
#define BITS_MBIST_RSTNI (BIT_MASK_MBIST_RSTNI << BIT_SHIFT_MBIST_RSTNI)
#define BIT_CLEAR_MBIST_RSTNI(x) ((x) & (~BITS_MBIST_RSTNI))
#define BIT_GET_MBIST_RSTNI(x) \
(((x) >> BIT_SHIFT_MBIST_RSTNI) & BIT_MASK_MBIST_RSTNI)
#define BIT_SET_MBIST_RSTNI(x, v) \
(BIT_CLEAR_MBIST_RSTNI(x) | BIT_MBIST_RSTNI(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BISD_MODE BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_RESUME_PS_V1 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_RESUME_PS BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_RESUME_V1 BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_RESUME BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_DRF BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_NORMAL BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SHIFT_BIST_MODE 2
#define BIT_MASK_BIST_MODE 0x3
#define BIT_BIST_MODE(x) (((x) & BIT_MASK_BIST_MODE) << BIT_SHIFT_BIST_MODE)
#define BITS_BIST_MODE (BIT_MASK_BIST_MODE << BIT_SHIFT_BIST_MODE)
#define BIT_CLEAR_BIST_MODE(x) ((x) & (~BITS_BIST_MODE))
#define BIT_GET_BIST_MODE(x) (((x) >> BIT_SHIFT_BIST_MODE) & BIT_MASK_BIST_MODE)
#define BIT_SET_BIST_MODE(x, v) (BIT_CLEAR_BIST_MODE(x) | BIT_BIST_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_RSTN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SYM_HCI_TADMA_ALLOW BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_BIST_CLK_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BIST_CTRL (Offset 0x00D0) */
#define BIT_SYM_FW_CTL_HCI_TXDMA_EN BIT(0)
#define BIT_SHIFT_TDE_H2C_RD_ADDR 0
#define BIT_MASK_TDE_H2C_RD_ADDR 0x3ffff
#define BIT_TDE_H2C_RD_ADDR(x) \
(((x) & BIT_MASK_TDE_H2C_RD_ADDR) << BIT_SHIFT_TDE_H2C_RD_ADDR)
#define BITS_TDE_H2C_RD_ADDR \
(BIT_MASK_TDE_H2C_RD_ADDR << BIT_SHIFT_TDE_H2C_RD_ADDR)
#define BIT_CLEAR_TDE_H2C_RD_ADDR(x) ((x) & (~BITS_TDE_H2C_RD_ADDR))
#define BIT_GET_TDE_H2C_RD_ADDR(x) \
(((x) >> BIT_SHIFT_TDE_H2C_RD_ADDR) & BIT_MASK_TDE_H2C_RD_ADDR)
#define BIT_SET_TDE_H2C_RD_ADDR(x, v) \
(BIT_CLEAR_TDE_H2C_RD_ADDR(x) | BIT_TDE_H2C_RD_ADDR(v))
#define BIT_SHIFT_TDE_H2C_WR_ADDR 0
#define BIT_MASK_TDE_H2C_WR_ADDR 0x3ffff
#define BIT_TDE_H2C_WR_ADDR(x) \
(((x) & BIT_MASK_TDE_H2C_WR_ADDR) << BIT_SHIFT_TDE_H2C_WR_ADDR)
#define BITS_TDE_H2C_WR_ADDR \
(BIT_MASK_TDE_H2C_WR_ADDR << BIT_SHIFT_TDE_H2C_WR_ADDR)
#define BIT_CLEAR_TDE_H2C_WR_ADDR(x) ((x) & (~BITS_TDE_H2C_WR_ADDR))
#define BIT_GET_TDE_H2C_WR_ADDR(x) \
(((x) >> BIT_SHIFT_TDE_H2C_WR_ADDR) & BIT_MASK_TDE_H2C_WR_ADDR)
#define BIT_SET_TDE_H2C_WR_ADDR(x, v) \
(BIT_CLEAR_TDE_H2C_WR_ADDR(x) | BIT_TDE_H2C_WR_ADDR(v))
#define BIT_SHIFT_BCAM_CTRL 0
#define BIT_MASK_BCAM_CTRL 0xffffffffL
#define BIT_BCAM_CTRL(x) (((x) & BIT_MASK_BCAM_CTRL) << BIT_SHIFT_BCAM_CTRL)
#define BITS_BCAM_CTRL (BIT_MASK_BCAM_CTRL << BIT_SHIFT_BCAM_CTRL)
#define BIT_CLEAR_BCAM_CTRL(x) ((x) & (~BITS_BCAM_CTRL))
#define BIT_GET_BCAM_CTRL(x) (((x) >> BIT_SHIFT_BCAM_CTRL) & BIT_MASK_BCAM_CTRL)
#define BIT_SET_BCAM_CTRL(x, v) (BIT_CLEAR_BCAM_CTRL(x) | BIT_BCAM_CTRL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BIST_RPT (Offset 0x00D4) */
#define BIT_SHIFT_MBIST_REPORT 0
#define BIT_MASK_MBIST_REPORT 0xffffffffL
#define BIT_MBIST_REPORT(x) \
(((x) & BIT_MASK_MBIST_REPORT) << BIT_SHIFT_MBIST_REPORT)
#define BITS_MBIST_REPORT (BIT_MASK_MBIST_REPORT << BIT_SHIFT_MBIST_REPORT)
#define BIT_CLEAR_MBIST_REPORT(x) ((x) & (~BITS_MBIST_REPORT))
#define BIT_GET_MBIST_REPORT(x) \
(((x) >> BIT_SHIFT_MBIST_REPORT) & BIT_MASK_MBIST_REPORT)
#define BIT_SET_MBIST_REPORT(x, v) \
(BIT_CLEAR_MBIST_REPORT(x) | BIT_MBIST_REPORT(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_RMV_SIGN BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_UMEM_RME BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_RMV_2PRF1 BIT(29)
#define BIT_RMV_2PRF0 BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_BT_SPRAM 28
#define BIT_MASK_BT_SPRAM 0x3
#define BIT_BT_SPRAM(x) (((x) & BIT_MASK_BT_SPRAM) << BIT_SHIFT_BT_SPRAM)
#define BITS_BT_SPRAM (BIT_MASK_BT_SPRAM << BIT_SHIFT_BT_SPRAM)
#define BIT_CLEAR_BT_SPRAM(x) ((x) & (~BITS_BT_SPRAM))
#define BIT_GET_BT_SPRAM(x) (((x) >> BIT_SHIFT_BT_SPRAM) & BIT_MASK_BT_SPRAM)
#define BIT_SET_BT_SPRAM(x, v) (BIT_CLEAR_BT_SPRAM(x) | BIT_BT_SPRAM(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_RMV_1PRF1 BIT(27)
#define BIT_RMV_1PRF0 BIT(26)
#define BIT_RMV_1PSR BIT(25)
#define BIT_RMV_ROM BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_BT_ROM 24
#define BIT_MASK_BT_ROM 0xf
#define BIT_BT_ROM(x) (((x) & BIT_MASK_BT_ROM) << BIT_SHIFT_BT_ROM)
#define BITS_BT_ROM (BIT_MASK_BT_ROM << BIT_SHIFT_BT_ROM)
#define BIT_CLEAR_BT_ROM(x) ((x) & (~BITS_BT_ROM))
#define BIT_GET_BT_ROM(x) (((x) >> BIT_SHIFT_BT_ROM) & BIT_MASK_BT_ROM)
#define BIT_SET_BT_ROM(x, v) (BIT_CLEAR_BT_ROM(x) | BIT_BT_ROM(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_MEM_RMV1_2PRF1 BIT(19)
#define BIT_MEM_RMV1_2PRF0 BIT(18)
#define BIT_MEM_RMV1_1PRF1 BIT(17)
#define BIT_MEM_RMV1_1PRF0 BIT(16)
#define BIT_MEM_RMV1_1PSR BIT(15)
#define BIT_MEM_RMV1_ROM BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_PCI_DPRAM 10
#define BIT_MASK_PCI_DPRAM 0x3
#define BIT_PCI_DPRAM(x) (((x) & BIT_MASK_PCI_DPRAM) << BIT_SHIFT_PCI_DPRAM)
#define BITS_PCI_DPRAM (BIT_MASK_PCI_DPRAM << BIT_SHIFT_PCI_DPRAM)
#define BIT_CLEAR_PCI_DPRAM(x) ((x) & (~BITS_PCI_DPRAM))
#define BIT_GET_PCI_DPRAM(x) (((x) >> BIT_SHIFT_PCI_DPRAM) & BIT_MASK_PCI_DPRAM)
#define BIT_SET_PCI_DPRAM(x, v) (BIT_CLEAR_PCI_DPRAM(x) | BIT_PCI_DPRAM(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_MEM_RME_BT 8
#define BIT_MASK_MEM_RME_BT 0xf
#define BIT_MEM_RME_BT(x) (((x) & BIT_MASK_MEM_RME_BT) << BIT_SHIFT_MEM_RME_BT)
#define BITS_MEM_RME_BT (BIT_MASK_MEM_RME_BT << BIT_SHIFT_MEM_RME_BT)
#define BIT_CLEAR_MEM_RME_BT(x) ((x) & (~BITS_MEM_RME_BT))
#define BIT_GET_MEM_RME_BT(x) \
(((x) >> BIT_SHIFT_MEM_RME_BT) & BIT_MASK_MEM_RME_BT)
#define BIT_SET_MEM_RME_BT(x, v) (BIT_CLEAR_MEM_RME_BT(x) | BIT_MEM_RME_BT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_PCI_SPRAM 8
#define BIT_MASK_PCI_SPRAM 0x3
#define BIT_PCI_SPRAM(x) (((x) & BIT_MASK_PCI_SPRAM) << BIT_SHIFT_PCI_SPRAM)
#define BITS_PCI_SPRAM (BIT_MASK_PCI_SPRAM << BIT_SHIFT_PCI_SPRAM)
#define BIT_CLEAR_PCI_SPRAM(x) ((x) & (~BITS_PCI_SPRAM))
#define BIT_GET_PCI_SPRAM(x) (((x) >> BIT_SHIFT_PCI_SPRAM) & BIT_MASK_PCI_SPRAM)
#define BIT_SET_PCI_SPRAM(x, v) (BIT_CLEAR_PCI_SPRAM(x) | BIT_PCI_SPRAM(v))
#define BIT_SHIFT_USB_SPRAM 6
#define BIT_MASK_USB_SPRAM 0x3
#define BIT_USB_SPRAM(x) (((x) & BIT_MASK_USB_SPRAM) << BIT_SHIFT_USB_SPRAM)
#define BITS_USB_SPRAM (BIT_MASK_USB_SPRAM << BIT_SHIFT_USB_SPRAM)
#define BIT_CLEAR_USB_SPRAM(x) ((x) & (~BITS_USB_SPRAM))
#define BIT_GET_USB_SPRAM(x) (((x) >> BIT_SHIFT_USB_SPRAM) & BIT_MASK_USB_SPRAM)
#define BIT_SET_USB_SPRAM(x, v) (BIT_CLEAR_USB_SPRAM(x) | BIT_USB_SPRAM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_MEM_RME_WL 4
#define BIT_MASK_MEM_RME_WL 0xf
#define BIT_MEM_RME_WL(x) (((x) & BIT_MASK_MEM_RME_WL) << BIT_SHIFT_MEM_RME_WL)
#define BITS_MEM_RME_WL (BIT_MASK_MEM_RME_WL << BIT_SHIFT_MEM_RME_WL)
#define BIT_CLEAR_MEM_RME_WL(x) ((x) & (~BITS_MEM_RME_WL))
#define BIT_GET_MEM_RME_WL(x) \
(((x) >> BIT_SHIFT_MEM_RME_WL) & BIT_MASK_MEM_RME_WL)
#define BIT_SET_MEM_RME_WL(x, v) (BIT_CLEAR_MEM_RME_WL(x) | BIT_MEM_RME_WL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_USB_SPRF 4
#define BIT_MASK_USB_SPRF 0x3
#define BIT_USB_SPRF(x) (((x) & BIT_MASK_USB_SPRF) << BIT_SHIFT_USB_SPRF)
#define BITS_USB_SPRF (BIT_MASK_USB_SPRF << BIT_SHIFT_USB_SPRF)
#define BIT_CLEAR_USB_SPRF(x) ((x) & (~BITS_USB_SPRF))
#define BIT_GET_USB_SPRF(x) (((x) >> BIT_SHIFT_USB_SPRF) & BIT_MASK_USB_SPRF)
#define BIT_SET_USB_SPRF(x, v) (BIT_CLEAR_USB_SPRF(x) | BIT_USB_SPRF(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_MEM_RME_HCI 0
#define BIT_MASK_MEM_RME_HCI 0xf
#define BIT_MEM_RME_HCI(x) \
(((x) & BIT_MASK_MEM_RME_HCI) << BIT_SHIFT_MEM_RME_HCI)
#define BITS_MEM_RME_HCI (BIT_MASK_MEM_RME_HCI << BIT_SHIFT_MEM_RME_HCI)
#define BIT_CLEAR_MEM_RME_HCI(x) ((x) & (~BITS_MEM_RME_HCI))
#define BIT_GET_MEM_RME_HCI(x) \
(((x) >> BIT_SHIFT_MEM_RME_HCI) & BIT_MASK_MEM_RME_HCI)
#define BIT_SET_MEM_RME_HCI(x, v) \
(BIT_CLEAR_MEM_RME_HCI(x) | BIT_MEM_RME_HCI(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_MCU_ROM 0
#define BIT_MASK_MCU_ROM 0xf
#define BIT_MCU_ROM(x) (((x) & BIT_MASK_MCU_ROM) << BIT_SHIFT_MCU_ROM)
#define BITS_MCU_ROM (BIT_MASK_MCU_ROM << BIT_SHIFT_MCU_ROM)
#define BIT_CLEAR_MCU_ROM(x) ((x) & (~BITS_MCU_ROM))
#define BIT_GET_MCU_ROM(x) (((x) >> BIT_SHIFT_MCU_ROM) & BIT_MASK_MCU_ROM)
#define BIT_SET_MCU_ROM(x, v) (BIT_CLEAR_MCU_ROM(x) | BIT_MCU_ROM(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_MEM_CTRL (Offset 0x00D8) */
#define BIT_SHIFT_BIST_ROM 0
#define BIT_MASK_BIST_ROM 0xffffffffL
#define BIT_BIST_ROM(x) (((x) & BIT_MASK_BIST_ROM) << BIT_SHIFT_BIST_ROM)
#define BITS_BIST_ROM (BIT_MASK_BIST_ROM << BIT_SHIFT_BIST_ROM)
#define BIT_CLEAR_BIST_ROM(x) ((x) & (~BITS_BIST_ROM))
#define BIT_GET_BIST_ROM(x) (((x) >> BIT_SHIFT_BIST_ROM) & BIT_MASK_BIST_ROM)
#define BIT_SET_BIST_ROM(x, v) (BIT_CLEAR_BIST_ROM(x) | BIT_BIST_ROM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL8 (Offset 0x00DC) */
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4 26
#define BIT_MASK_BB_DBG_SEL_AFE_SDM_V4 0x7
#define BIT_BB_DBG_SEL_AFE_SDM_V4(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM_V4) \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4)
#define BITS_BB_DBG_SEL_AFE_SDM_V4 \
(BIT_MASK_BB_DBG_SEL_AFE_SDM_V4 << BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM_V4(x) ((x) & (~BITS_BB_DBG_SEL_AFE_SDM_V4))
#define BIT_GET_BB_DBG_SEL_AFE_SDM_V4(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4) & \
BIT_MASK_BB_DBG_SEL_AFE_SDM_V4)
#define BIT_SET_BB_DBG_SEL_AFE_SDM_V4(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM_V4(x) | BIT_BB_DBG_SEL_AFE_SDM_V4(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL8 (Offset 0x00DC) */
#define BIT_SYN_AGPIO BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYN_RFC_CTRL (Offset 0x00DC) */
#define BIT_SHIFT_SYN_RF1_CTRL 8
#define BIT_MASK_SYN_RF1_CTRL 0xff
#define BIT_SYN_RF1_CTRL(x) \
(((x) & BIT_MASK_SYN_RF1_CTRL) << BIT_SHIFT_SYN_RF1_CTRL)
#define BITS_SYN_RF1_CTRL (BIT_MASK_SYN_RF1_CTRL << BIT_SHIFT_SYN_RF1_CTRL)
#define BIT_CLEAR_SYN_RF1_CTRL(x) ((x) & (~BITS_SYN_RF1_CTRL))
#define BIT_GET_SYN_RF1_CTRL(x) \
(((x) >> BIT_SHIFT_SYN_RF1_CTRL) & BIT_MASK_SYN_RF1_CTRL)
#define BIT_SET_SYN_RF1_CTRL(x, v) \
(BIT_CLEAR_SYN_RF1_CTRL(x) | BIT_SYN_RF1_CTRL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_AFE_CTRL8 (Offset 0x00DC) */
#define BIT_SHIFT_XTAL_GM_REP 6
#define BIT_MASK_XTAL_GM_REP 0x3
#define BIT_XTAL_GM_REP(x) \
(((x) & BIT_MASK_XTAL_GM_REP) << BIT_SHIFT_XTAL_GM_REP)
#define BITS_XTAL_GM_REP (BIT_MASK_XTAL_GM_REP << BIT_SHIFT_XTAL_GM_REP)
#define BIT_CLEAR_XTAL_GM_REP(x) ((x) & (~BITS_XTAL_GM_REP))
#define BIT_GET_XTAL_GM_REP(x) \
(((x) >> BIT_SHIFT_XTAL_GM_REP) & BIT_MASK_XTAL_GM_REP)
#define BIT_SET_XTAL_GM_REP(x, v) \
(BIT_CLEAR_XTAL_GM_REP(x) | BIT_XTAL_GM_REP(v))
#define BIT_XTAL_DRV_RF_LATCH_V5 BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL8 (Offset 0x00DC) */
#define BIT_XTAL_LP BIT(4)
#define BIT_XTAL_GM_SEP BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_AFE_CTRL8 (Offset 0x00DC) */
#define BIT_SHIFT_XTAL_SEL_TOK_V2 0
#define BIT_MASK_XTAL_SEL_TOK_V2 0x7
#define BIT_XTAL_SEL_TOK_V2(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_V2) << BIT_SHIFT_XTAL_SEL_TOK_V2)
#define BITS_XTAL_SEL_TOK_V2 \
(BIT_MASK_XTAL_SEL_TOK_V2 << BIT_SHIFT_XTAL_SEL_TOK_V2)
#define BIT_CLEAR_XTAL_SEL_TOK_V2(x) ((x) & (~BITS_XTAL_SEL_TOK_V2))
#define BIT_GET_XTAL_SEL_TOK_V2(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_V2) & BIT_MASK_XTAL_SEL_TOK_V2)
#define BIT_SET_XTAL_SEL_TOK_V2(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_V2(x) | BIT_XTAL_SEL_TOK_V2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WLAN_DBG (Offset 0x00DC) */
#define BIT_SHIFT_WLAN_DBG 0
#define BIT_MASK_WLAN_DBG 0xffffffffL
#define BIT_WLAN_DBG(x) (((x) & BIT_MASK_WLAN_DBG) << BIT_SHIFT_WLAN_DBG)
#define BITS_WLAN_DBG (BIT_MASK_WLAN_DBG << BIT_SHIFT_WLAN_DBG)
#define BIT_CLEAR_WLAN_DBG(x) ((x) & (~BITS_WLAN_DBG))
#define BIT_GET_WLAN_DBG(x) (((x) >> BIT_SHIFT_WLAN_DBG) & BIT_MASK_WLAN_DBG)
#define BIT_SET_WLAN_DBG(x, v) (BIT_CLEAR_WLAN_DBG(x) | BIT_WLAN_DBG(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYN_RFC_CTRL (Offset 0x00DC) */
#define BIT_SHIFT_SYN_RF0_CTRL 0
#define BIT_MASK_SYN_RF0_CTRL 0xff
#define BIT_SYN_RF0_CTRL(x) \
(((x) & BIT_MASK_SYN_RF0_CTRL) << BIT_SHIFT_SYN_RF0_CTRL)
#define BITS_SYN_RF0_CTRL (BIT_MASK_SYN_RF0_CTRL << BIT_SHIFT_SYN_RF0_CTRL)
#define BIT_CLEAR_SYN_RF0_CTRL(x) ((x) & (~BITS_SYN_RF0_CTRL))
#define BIT_GET_SYN_RF0_CTRL(x) \
(((x) >> BIT_SHIFT_SYN_RF0_CTRL) & BIT_MASK_SYN_RF0_CTRL)
#define BIT_SET_SYN_RF0_CTRL(x, v) \
(BIT_CLEAR_SYN_RF0_CTRL(x) | BIT_SYN_RF0_CTRL(v))
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AFE_CTRL8 (Offset 0x00DC) */
#define BIT_SHIFT_XTAL_SEL_TOK 0
#define BIT_MASK_XTAL_SEL_TOK 0x7
#define BIT_XTAL_SEL_TOK(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK) << BIT_SHIFT_XTAL_SEL_TOK)
#define BITS_XTAL_SEL_TOK (BIT_MASK_XTAL_SEL_TOK << BIT_SHIFT_XTAL_SEL_TOK)
#define BIT_CLEAR_XTAL_SEL_TOK(x) ((x) & (~BITS_XTAL_SEL_TOK))
#define BIT_GET_XTAL_SEL_TOK(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK) & BIT_MASK_XTAL_SEL_TOK)
#define BIT_SET_XTAL_SEL_TOK(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK(x) | BIT_XTAL_SEL_TOK(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_RD_SEL BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_CPU_REG_SEL BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_USB_SIE_INTF_WE_V1 BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_USB3_REG_SEL BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_USB_SIE_INTF_BYIOREG_V1 BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_SHIFT_USB_SIE_EN 28
#define BIT_MASK_USB_SIE_EN 0x3
#define BIT_USB_SIE_EN(x) (((x) & BIT_MASK_USB_SIE_EN) << BIT_SHIFT_USB_SIE_EN)
#define BITS_USB_SIE_EN (BIT_MASK_USB_SIE_EN << BIT_SHIFT_USB_SIE_EN)
#define BIT_CLEAR_USB_SIE_EN(x) ((x) & (~BITS_USB_SIE_EN))
#define BIT_GET_USB_SIE_EN(x) \
(((x) >> BIT_SHIFT_USB_SIE_EN) & BIT_MASK_USB_SIE_EN)
#define BIT_SET_USB_SIE_EN(x, v) (BIT_CLEAR_USB_SIE_EN(x) | BIT_USB_SIE_EN(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_USB_SIE_SELECT BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_USB_SIE_INTF_WE BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_USB_SIE_INTF_BYIOREG BIT(24)
#define BIT_SHIFT_USB_SIE_INTF_ADDR 16
#define BIT_MASK_USB_SIE_INTF_ADDR 0xff
#define BIT_USB_SIE_INTF_ADDR(x) \
(((x) & BIT_MASK_USB_SIE_INTF_ADDR) << BIT_SHIFT_USB_SIE_INTF_ADDR)
#define BITS_USB_SIE_INTF_ADDR \
(BIT_MASK_USB_SIE_INTF_ADDR << BIT_SHIFT_USB_SIE_INTF_ADDR)
#define BIT_CLEAR_USB_SIE_INTF_ADDR(x) ((x) & (~BITS_USB_SIE_INTF_ADDR))
#define BIT_GET_USB_SIE_INTF_ADDR(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_ADDR) & BIT_MASK_USB_SIE_INTF_ADDR)
#define BIT_SET_USB_SIE_INTF_ADDR(x, v) \
(BIT_CLEAR_USB_SIE_INTF_ADDR(x) | BIT_USB_SIE_INTF_ADDR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_SHIFT_USB_SIE_INTF_ADDR_V1 16
#define BIT_MASK_USB_SIE_INTF_ADDR_V1 0x1ff
#define BIT_USB_SIE_INTF_ADDR_V1(x) \
(((x) & BIT_MASK_USB_SIE_INTF_ADDR_V1) \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1)
#define BITS_USB_SIE_INTF_ADDR_V1 \
(BIT_MASK_USB_SIE_INTF_ADDR_V1 << BIT_SHIFT_USB_SIE_INTF_ADDR_V1)
#define BIT_CLEAR_USB_SIE_INTF_ADDR_V1(x) ((x) & (~BITS_USB_SIE_INTF_ADDR_V1))
#define BIT_GET_USB_SIE_INTF_ADDR_V1(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_ADDR_V1) & \
BIT_MASK_USB_SIE_INTF_ADDR_V1)
#define BIT_SET_USB_SIE_INTF_ADDR_V1(x, v) \
(BIT_CLEAR_USB_SIE_INTF_ADDR_V1(x) | BIT_USB_SIE_INTF_ADDR_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_SHIFT_USB_SIE_INTF_RD 8
#define BIT_MASK_USB_SIE_INTF_RD 0xff
#define BIT_USB_SIE_INTF_RD(x) \
(((x) & BIT_MASK_USB_SIE_INTF_RD) << BIT_SHIFT_USB_SIE_INTF_RD)
#define BITS_USB_SIE_INTF_RD \
(BIT_MASK_USB_SIE_INTF_RD << BIT_SHIFT_USB_SIE_INTF_RD)
#define BIT_CLEAR_USB_SIE_INTF_RD(x) ((x) & (~BITS_USB_SIE_INTF_RD))
#define BIT_GET_USB_SIE_INTF_RD(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_RD) & BIT_MASK_USB_SIE_INTF_RD)
#define BIT_SET_USB_SIE_INTF_RD(x, v) \
(BIT_CLEAR_USB_SIE_INTF_RD(x) | BIT_USB_SIE_INTF_RD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_SHIFT_NPQ_AVAL_PG 8
#define BIT_MASK_NPQ_AVAL_PG 0xff
#define BIT_NPQ_AVAL_PG(x) \
(((x) & BIT_MASK_NPQ_AVAL_PG) << BIT_SHIFT_NPQ_AVAL_PG)
#define BITS_NPQ_AVAL_PG (BIT_MASK_NPQ_AVAL_PG << BIT_SHIFT_NPQ_AVAL_PG)
#define BIT_CLEAR_NPQ_AVAL_PG(x) ((x) & (~BITS_NPQ_AVAL_PG))
#define BIT_GET_NPQ_AVAL_PG(x) \
(((x) >> BIT_SHIFT_NPQ_AVAL_PG) & BIT_MASK_NPQ_AVAL_PG)
#define BIT_SET_NPQ_AVAL_PG(x, v) \
(BIT_CLEAR_NPQ_AVAL_PG(x) | BIT_NPQ_AVAL_PG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_USB_SIE_INTF (Offset 0x00E0) */
#define BIT_SHIFT_USB_SIE_INTF_WD 0
#define BIT_MASK_USB_SIE_INTF_WD 0xff
#define BIT_USB_SIE_INTF_WD(x) \
(((x) & BIT_MASK_USB_SIE_INTF_WD) << BIT_SHIFT_USB_SIE_INTF_WD)
#define BITS_USB_SIE_INTF_WD \
(BIT_MASK_USB_SIE_INTF_WD << BIT_SHIFT_USB_SIE_INTF_WD)
#define BIT_CLEAR_USB_SIE_INTF_WD(x) ((x) & (~BITS_USB_SIE_INTF_WD))
#define BIT_GET_USB_SIE_INTF_WD(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_WD) & BIT_MASK_USB_SIE_INTF_WD)
#define BIT_SET_USB_SIE_INTF_WD(x, v) \
(BIT_CLEAR_USB_SIE_INTF_WD(x) | BIT_USB_SIE_INTF_WD(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PCIE_MIO_INTF (Offset 0x00E4) */
#define BIT_PCIE_MIO_EXIT_L1 BIT(19)
#define BIT_PCIE_MIO_EXT BIT(18)
#define BIT_PCIE_MIO_ACK BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PCIE_MIO_INTF (Offset 0x00E4) */
#define BIT_PCIE_MIO_RIO BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_MIO_INTF (Offset 0x00E4) */
#define BIT_SHIFT_PCIE_MIO_ADDR_PAGE 16
#define BIT_MASK_PCIE_MIO_ADDR_PAGE 0x3
#define BIT_PCIE_MIO_ADDR_PAGE(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_PAGE) << BIT_SHIFT_PCIE_MIO_ADDR_PAGE)
#define BITS_PCIE_MIO_ADDR_PAGE \
(BIT_MASK_PCIE_MIO_ADDR_PAGE << BIT_SHIFT_PCIE_MIO_ADDR_PAGE)
#define BIT_CLEAR_PCIE_MIO_ADDR_PAGE(x) ((x) & (~BITS_PCIE_MIO_ADDR_PAGE))
#define BIT_GET_PCIE_MIO_ADDR_PAGE(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_PAGE) & BIT_MASK_PCIE_MIO_ADDR_PAGE)
#define BIT_SET_PCIE_MIO_ADDR_PAGE(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_PAGE(x) | BIT_PCIE_MIO_ADDR_PAGE(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_PCIE_MIO_INTF (Offset 0x00E4) */
#define BIT_PCIE_MIO_IOREG BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_MIO_INTF (Offset 0x00E4) */
#define BIT_PCIE_MIO_BYIOREG BIT(13)
#define BIT_PCIE_MIO_RE BIT(12)
#define BIT_SHIFT_PCIE_MIO_WE 8
#define BIT_MASK_PCIE_MIO_WE 0xf
#define BIT_PCIE_MIO_WE(x) \
(((x) & BIT_MASK_PCIE_MIO_WE) << BIT_SHIFT_PCIE_MIO_WE)
#define BITS_PCIE_MIO_WE (BIT_MASK_PCIE_MIO_WE << BIT_SHIFT_PCIE_MIO_WE)
#define BIT_CLEAR_PCIE_MIO_WE(x) ((x) & (~BITS_PCIE_MIO_WE))
#define BIT_GET_PCIE_MIO_WE(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_WE) & BIT_MASK_PCIE_MIO_WE)
#define BIT_SET_PCIE_MIO_WE(x, v) \
(BIT_CLEAR_PCIE_MIO_WE(x) | BIT_PCIE_MIO_WE(v))
#define BIT_SHIFT_PCIE_MIO_ADDR 0
#define BIT_MASK_PCIE_MIO_ADDR 0xff
#define BIT_PCIE_MIO_ADDR(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR) << BIT_SHIFT_PCIE_MIO_ADDR)
#define BITS_PCIE_MIO_ADDR (BIT_MASK_PCIE_MIO_ADDR << BIT_SHIFT_PCIE_MIO_ADDR)
#define BIT_CLEAR_PCIE_MIO_ADDR(x) ((x) & (~BITS_PCIE_MIO_ADDR))
#define BIT_GET_PCIE_MIO_ADDR(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR) & BIT_MASK_PCIE_MIO_ADDR)
#define BIT_SET_PCIE_MIO_ADDR(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR(x) | BIT_PCIE_MIO_ADDR(v))
/* 2 REG_PCIE_MIO_INTD (Offset 0x00E8) */
#define BIT_SHIFT_PCIE_MIO_DATA 0
#define BIT_MASK_PCIE_MIO_DATA 0xffffffffL
#define BIT_PCIE_MIO_DATA(x) \
(((x) & BIT_MASK_PCIE_MIO_DATA) << BIT_SHIFT_PCIE_MIO_DATA)
#define BITS_PCIE_MIO_DATA (BIT_MASK_PCIE_MIO_DATA << BIT_SHIFT_PCIE_MIO_DATA)
#define BIT_CLEAR_PCIE_MIO_DATA(x) ((x) & (~BITS_PCIE_MIO_DATA))
#define BIT_GET_PCIE_MIO_DATA(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_DATA) & BIT_MASK_PCIE_MIO_DATA)
#define BIT_SET_PCIE_MIO_DATA(x, v) \
(BIT_CLEAR_PCIE_MIO_DATA(x) | BIT_PCIE_MIO_DATA(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HPON_FSM (Offset 0x00EC) */
#define BIT_SUSPEND_V1 BIT(31)
#define BIT_FSM_RESUME_V1 BIT(30)
#define BIT_HOST_RESUME_SYNC_V1 BIT(29)
#define BIT_CHIP_PDNB_V1 BIT(28)
#define BIT_SHIFT_FSM_SUSPEND_V1 25
#define BIT_MASK_FSM_SUSPEND_V1 0x7
#define BIT_FSM_SUSPEND_V1(x) \
(((x) & BIT_MASK_FSM_SUSPEND_V1) << BIT_SHIFT_FSM_SUSPEND_V1)
#define BITS_FSM_SUSPEND_V1 \
(BIT_MASK_FSM_SUSPEND_V1 << BIT_SHIFT_FSM_SUSPEND_V1)
#define BIT_CLEAR_FSM_SUSPEND_V1(x) ((x) & (~BITS_FSM_SUSPEND_V1))
#define BIT_GET_FSM_SUSPEND_V1(x) \
(((x) >> BIT_SHIFT_FSM_SUSPEND_V1) & BIT_MASK_FSM_SUSPEND_V1)
#define BIT_SET_FSM_SUSPEND_V1(x, v) \
(BIT_CLEAR_FSM_SUSPEND_V1(x) | BIT_FSM_SUSPEND_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WLRF1 (Offset 0x00EC) */
#define BIT_SHIFT_XTAL_SEL 25
#define BIT_MASK_XTAL_SEL 0x3
#define BIT_XTAL_SEL(x) (((x) & BIT_MASK_XTAL_SEL) << BIT_SHIFT_XTAL_SEL)
#define BITS_XTAL_SEL (BIT_MASK_XTAL_SEL << BIT_SHIFT_XTAL_SEL)
#define BIT_CLEAR_XTAL_SEL(x) ((x) & (~BITS_XTAL_SEL))
#define BIT_GET_XTAL_SEL(x) (((x) >> BIT_SHIFT_XTAL_SEL) & BIT_MASK_XTAL_SEL)
#define BIT_SET_XTAL_SEL(x, v) (BIT_CLEAR_XTAL_SEL(x) | BIT_XTAL_SEL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLRF1 (Offset 0x00EC) */
#define BIT_SHIFT_WLRF1_CTRL 24
#define BIT_MASK_WLRF1_CTRL 0xff
#define BIT_WLRF1_CTRL(x) (((x) & BIT_MASK_WLRF1_CTRL) << BIT_SHIFT_WLRF1_CTRL)
#define BITS_WLRF1_CTRL (BIT_MASK_WLRF1_CTRL << BIT_SHIFT_WLRF1_CTRL)
#define BIT_CLEAR_WLRF1_CTRL(x) ((x) & (~BITS_WLRF1_CTRL))
#define BIT_GET_WLRF1_CTRL(x) \
(((x) >> BIT_SHIFT_WLRF1_CTRL) & BIT_MASK_WLRF1_CTRL)
#define BIT_SET_WLRF1_CTRL(x, v) (BIT_CLEAR_WLRF1_CTRL(x) | BIT_WLRF1_CTRL(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HPON_FSM (Offset 0x00EC) */
#define BIT_PMC_ALD_V1 BIT(24)
#define BIT_SHIFT_HCI_SEL_1 22
#define BIT_MASK_HCI_SEL_1 0x3
#define BIT_HCI_SEL_1(x) (((x) & BIT_MASK_HCI_SEL_1) << BIT_SHIFT_HCI_SEL_1)
#define BITS_HCI_SEL_1 (BIT_MASK_HCI_SEL_1 << BIT_SHIFT_HCI_SEL_1)
#define BIT_CLEAR_HCI_SEL_1(x) ((x) & (~BITS_HCI_SEL_1))
#define BIT_GET_HCI_SEL_1(x) (((x) >> BIT_SHIFT_HCI_SEL_1) & BIT_MASK_HCI_SEL_1)
#define BIT_SET_HCI_SEL_1(x, v) (BIT_CLEAR_HCI_SEL_1(x) | BIT_HCI_SEL_1(v))
#define BIT_LOAD_DONE_V1 BIT(21)
#define BIT_CNT_MATCH BIT(20)
#define BIT_TIMEUP_V1 BIT(19)
#define BIT_SPS_12V_VLD BIT(18)
#define BIT_PCIERST_V1 BIT(17)
#define BIT_HOST_CLK_VLD BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WLRF1 (Offset 0x00EC) */
#define BIT_SHIFT_WLRF2_CTRL 16
#define BIT_MASK_WLRF2_CTRL 0xff
#define BIT_WLRF2_CTRL(x) (((x) & BIT_MASK_WLRF2_CTRL) << BIT_SHIFT_WLRF2_CTRL)
#define BITS_WLRF2_CTRL (BIT_MASK_WLRF2_CTRL << BIT_SHIFT_WLRF2_CTRL)
#define BIT_CLEAR_WLRF2_CTRL(x) ((x) & (~BITS_WLRF2_CTRL))
#define BIT_GET_WLRF2_CTRL(x) \
(((x) >> BIT_SHIFT_WLRF2_CTRL) & BIT_MASK_WLRF2_CTRL)
#define BIT_SET_WLRF2_CTRL(x, v) (BIT_CLEAR_WLRF2_CTRL(x) | BIT_WLRF2_CTRL(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HPON_FSM (Offset 0x00EC) */
#define BIT_PMC_WR_V1 BIT(15)
#define BIT_PMC_DATA_V1 BIT(14)
#define BIT_SHIFT_PMC_ADDR_V1 8
#define BIT_MASK_PMC_ADDR_V1 0x3f
#define BIT_PMC_ADDR_V1(x) \
(((x) & BIT_MASK_PMC_ADDR_V1) << BIT_SHIFT_PMC_ADDR_V1)
#define BITS_PMC_ADDR_V1 (BIT_MASK_PMC_ADDR_V1 << BIT_SHIFT_PMC_ADDR_V1)
#define BIT_CLEAR_PMC_ADDR_V1(x) ((x) & (~BITS_PMC_ADDR_V1))
#define BIT_GET_PMC_ADDR_V1(x) \
(((x) >> BIT_SHIFT_PMC_ADDR_V1) & BIT_MASK_PMC_ADDR_V1)
#define BIT_SET_PMC_ADDR_V1(x, v) \
(BIT_CLEAR_PMC_ADDR_V1(x) | BIT_PMC_ADDR_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WLRF1 (Offset 0x00EC) */
#define BIT_SHIFT_WLRF3_CTRL 8
#define BIT_MASK_WLRF3_CTRL 0xff
#define BIT_WLRF3_CTRL(x) (((x) & BIT_MASK_WLRF3_CTRL) << BIT_SHIFT_WLRF3_CTRL)
#define BITS_WLRF3_CTRL (BIT_MASK_WLRF3_CTRL << BIT_SHIFT_WLRF3_CTRL)
#define BIT_CLEAR_WLRF3_CTRL(x) ((x) & (~BITS_WLRF3_CTRL))
#define BIT_GET_WLRF3_CTRL(x) \
(((x) >> BIT_SHIFT_WLRF3_CTRL) & BIT_MASK_WLRF3_CTRL)
#define BIT_SET_WLRF3_CTRL(x, v) (BIT_CLEAR_WLRF3_CTRL(x) | BIT_WLRF3_CTRL(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HPON_FSM (Offset 0x00EC) */
#define BIT_PMC_COUNT_EN_V1 BIT(7)
#define BIT_SHIFT_FSM_STATE_V1 0
#define BIT_MASK_FSM_STATE_V1 0x7f
#define BIT_FSM_STATE_V1(x) \
(((x) & BIT_MASK_FSM_STATE_V1) << BIT_SHIFT_FSM_STATE_V1)
#define BITS_FSM_STATE_V1 (BIT_MASK_FSM_STATE_V1 << BIT_SHIFT_FSM_STATE_V1)
#define BIT_CLEAR_FSM_STATE_V1(x) ((x) & (~BITS_FSM_STATE_V1))
#define BIT_GET_FSM_STATE_V1(x) \
(((x) >> BIT_SHIFT_FSM_STATE_V1) & BIT_MASK_FSM_STATE_V1)
#define BIT_SET_FSM_STATE_V1(x, v) \
(BIT_CLEAR_FSM_STATE_V1(x) | BIT_FSM_STATE_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SHIFT_TRP_ICFG 28
#define BIT_MASK_TRP_ICFG 0xf
#define BIT_TRP_ICFG(x) (((x) & BIT_MASK_TRP_ICFG) << BIT_SHIFT_TRP_ICFG)
#define BITS_TRP_ICFG (BIT_MASK_TRP_ICFG << BIT_SHIFT_TRP_ICFG)
#define BIT_CLEAR_TRP_ICFG(x) ((x) & (~BITS_TRP_ICFG))
#define BIT_GET_TRP_ICFG(x) (((x) >> BIT_SHIFT_TRP_ICFG) & BIT_MASK_TRP_ICFG)
#define BIT_SET_TRP_ICFG(x, v) (BIT_CLEAR_TRP_ICFG(x) | BIT_TRP_ICFG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_RF_TYPE_ID BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_BD_HCI_SEL BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_LDO_VLD BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SHIFT_BD_HCI_SEL_V1 26
#define BIT_MASK_BD_HCI_SEL_V1 0x3
#define BIT_BD_HCI_SEL_V1(x) \
(((x) & BIT_MASK_BD_HCI_SEL_V1) << BIT_SHIFT_BD_HCI_SEL_V1)
#define BITS_BD_HCI_SEL_V1 (BIT_MASK_BD_HCI_SEL_V1 << BIT_SHIFT_BD_HCI_SEL_V1)
#define BIT_CLEAR_BD_HCI_SEL_V1(x) ((x) & (~BITS_BD_HCI_SEL_V1))
#define BIT_GET_BD_HCI_SEL_V1(x) \
(((x) >> BIT_SHIFT_BD_HCI_SEL_V1) & BIT_MASK_BD_HCI_SEL_V1)
#define BIT_SET_BD_HCI_SEL_V1(x, v) \
(BIT_CLEAR_BD_HCI_SEL_V1(x) | BIT_BD_HCI_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_BD_PKG_SEL BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SPSLDO_SEL BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_INTERNAL_EXTERNAL_SWR BIT(24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_LDO_SPS_SEL BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_RTL_ID BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_PAD_HWPD_IDN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_DIS_WL BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_TESTMODE BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SHIFT_PSC_TESTCFG 20
#define BIT_MASK_PSC_TESTCFG 0x3
#define BIT_PSC_TESTCFG(x) \
(((x) & BIT_MASK_PSC_TESTCFG) << BIT_SHIFT_PSC_TESTCFG)
#define BITS_PSC_TESTCFG (BIT_MASK_PSC_TESTCFG << BIT_SHIFT_PSC_TESTCFG)
#define BIT_CLEAR_PSC_TESTCFG(x) ((x) & (~BITS_PSC_TESTCFG))
#define BIT_GET_PSC_TESTCFG(x) \
(((x) >> BIT_SHIFT_PSC_TESTCFG) & BIT_MASK_PSC_TESTCFG)
#define BIT_SET_PSC_TESTCFG(x, v) \
(BIT_CLEAR_PSC_TESTCFG(x) | BIT_PSC_TESTCFG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SHIFT_VENDOR_ID 16
#define BIT_MASK_VENDOR_ID 0xf
#define BIT_VENDOR_ID(x) (((x) & BIT_MASK_VENDOR_ID) << BIT_SHIFT_VENDOR_ID)
#define BITS_VENDOR_ID (BIT_MASK_VENDOR_ID << BIT_SHIFT_VENDOR_ID)
#define BIT_CLEAR_VENDOR_ID(x) ((x) & (~BITS_VENDOR_ID))
#define BIT_GET_VENDOR_ID(x) (((x) >> BIT_SHIFT_VENDOR_ID) & BIT_MASK_VENDOR_ID)
#define BIT_SET_VENDOR_ID(x, v) (BIT_CLEAR_VENDOR_ID(x) | BIT_VENDOR_ID(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SHIFT_CHIP_VER_V2 16
#define BIT_MASK_CHIP_VER_V2 0xf
#define BIT_CHIP_VER_V2(x) \
(((x) & BIT_MASK_CHIP_VER_V2) << BIT_SHIFT_CHIP_VER_V2)
#define BITS_CHIP_VER_V2 (BIT_MASK_CHIP_VER_V2 << BIT_SHIFT_CHIP_VER_V2)
#define BIT_CLEAR_CHIP_VER_V2(x) ((x) & (~BITS_CHIP_VER_V2))
#define BIT_GET_CHIP_VER_V2(x) \
(((x) >> BIT_SHIFT_CHIP_VER_V2) & BIT_MASK_CHIP_VER_V2)
#define BIT_SET_CHIP_VER_V2(x, v) \
(BIT_CLEAR_CHIP_VER_V2(x) | BIT_CHIP_VER_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SHIFT_CHIP_VER 12
#define BIT_MASK_CHIP_VER 0xf
#define BIT_CHIP_VER(x) (((x) & BIT_MASK_CHIP_VER) << BIT_SHIFT_CHIP_VER)
#define BITS_CHIP_VER (BIT_MASK_CHIP_VER << BIT_SHIFT_CHIP_VER)
#define BIT_CLEAR_CHIP_VER(x) ((x) & (~BITS_CHIP_VER))
#define BIT_GET_CHIP_VER(x) (((x) >> BIT_SHIFT_CHIP_VER) & BIT_MASK_CHIP_VER)
#define BIT_SET_CHIP_VER(x, v) (BIT_CLEAR_CHIP_VER(x) | BIT_CHIP_VER(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_TST_MODE_SEL BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_BD_MAC3 BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_IC_MACPHY_MODE BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_BD_MAC1 BIT(10)
#define BIT_BD_MAC2 BIT(9)
#define BIT_SIC_IDLE BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_SW_OFFLOAD_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_OCP_SHUTDN BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_OCP_SHUTDN_1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_V15_VLD BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_V12_VLD BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_PCIRSTB BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_PCLK_VLD BIT(3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_PCLK_VLD_1 BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_UCLK_VLD BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_ACLK_VLD BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_M200CLK_VLD_V1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG1 (Offset 0x00F0) */
#define BIT_XCLK_VLD BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SYM_OSC32K_OUTSEL BIT(31)
#define BIT_BTGP_WAKE_BT_LOC_BIT0 BIT(31)
#define BIT_SHIFT_SYM_SEC_CLKSEL 30
#define BIT_MASK_SYM_SEC_CLKSEL 0x3
#define BIT_SYM_SEC_CLKSEL(x) \
(((x) & BIT_MASK_SYM_SEC_CLKSEL) << BIT_SHIFT_SYM_SEC_CLKSEL)
#define BITS_SYM_SEC_CLKSEL \
(BIT_MASK_SYM_SEC_CLKSEL << BIT_SHIFT_SYM_SEC_CLKSEL)
#define BIT_CLEAR_SYM_SEC_CLKSEL(x) ((x) & (~BITS_SYM_SEC_CLKSEL))
#define BIT_GET_SYM_SEC_CLKSEL(x) \
(((x) >> BIT_SHIFT_SYM_SEC_CLKSEL) & BIT_MASK_SYM_SEC_CLKSEL)
#define BIT_SET_SYM_SEC_CLKSEL(x, v) \
(BIT_CLEAR_SYM_SEC_CLKSEL(x) | BIT_SYM_SEC_CLKSEL(v))
#define BIT_SHIFT_WL_GPIO_SEL 30
#define BIT_MASK_WL_GPIO_SEL 0x3
#define BIT_WL_GPIO_SEL(x) \
(((x) & BIT_MASK_WL_GPIO_SEL) << BIT_SHIFT_WL_GPIO_SEL)
#define BITS_WL_GPIO_SEL (BIT_MASK_WL_GPIO_SEL << BIT_SHIFT_WL_GPIO_SEL)
#define BIT_CLEAR_WL_GPIO_SEL(x) ((x) & (~BITS_WL_GPIO_SEL))
#define BIT_GET_WL_GPIO_SEL(x) \
(((x) >> BIT_SHIFT_WL_GPIO_SEL) & BIT_MASK_WL_GPIO_SEL)
#define BIT_SET_WL_GPIO_SEL(x, v) \
(BIT_CLEAR_WL_GPIO_SEL(x) | BIT_WL_GPIO_SEL(v))
#define BIT_SHIFT_BT_MCM_CTRL_LOC 29
#define BIT_MASK_BT_MCM_CTRL_LOC 0x3
#define BIT_BT_MCM_CTRL_LOC(x) \
(((x) & BIT_MASK_BT_MCM_CTRL_LOC) << BIT_SHIFT_BT_MCM_CTRL_LOC)
#define BITS_BT_MCM_CTRL_LOC \
(BIT_MASK_BT_MCM_CTRL_LOC << BIT_SHIFT_BT_MCM_CTRL_LOC)
#define BIT_CLEAR_BT_MCM_CTRL_LOC(x) ((x) & (~BITS_BT_MCM_CTRL_LOC))
#define BIT_GET_BT_MCM_CTRL_LOC(x) \
(((x) >> BIT_SHIFT_BT_MCM_CTRL_LOC) & BIT_MASK_BT_MCM_CTRL_LOC)
#define BIT_SET_BT_MCM_CTRL_LOC(x, v) \
(BIT_CLEAR_BT_MCM_CTRL_LOC(x) | BIT_BT_MCM_CTRL_LOC(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_RF_RL_ID 28
#define BIT_MASK_RF_RL_ID 0xf
#define BIT_RF_RL_ID(x) (((x) & BIT_MASK_RF_RL_ID) << BIT_SHIFT_RF_RL_ID)
#define BITS_RF_RL_ID (BIT_MASK_RF_RL_ID << BIT_SHIFT_RF_RL_ID)
#define BIT_CLEAR_RF_RL_ID(x) ((x) & (~BITS_RF_RL_ID))
#define BIT_GET_RF_RL_ID(x) (((x) >> BIT_SHIFT_RF_RL_ID) & BIT_MASK_RF_RL_ID)
#define BIT_SET_RF_RL_ID(x, v) (BIT_CLEAR_RF_RL_ID(x) | BIT_RF_RL_ID(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_SYM_MAC_CLKSEL 28
#define BIT_MASK_SYM_MAC_CLKSEL 0x3
#define BIT_SYM_MAC_CLKSEL(x) \
(((x) & BIT_MASK_SYM_MAC_CLKSEL) << BIT_SHIFT_SYM_MAC_CLKSEL)
#define BITS_SYM_MAC_CLKSEL \
(BIT_MASK_SYM_MAC_CLKSEL << BIT_SHIFT_SYM_MAC_CLKSEL)
#define BIT_CLEAR_SYM_MAC_CLKSEL(x) ((x) & (~BITS_SYM_MAC_CLKSEL))
#define BIT_GET_SYM_MAC_CLKSEL(x) \
(((x) >> BIT_SHIFT_SYM_MAC_CLKSEL) & BIT_MASK_SYM_MAC_CLKSEL)
#define BIT_SET_SYM_MAC_CLKSEL(x, v) \
(BIT_CLEAR_SYM_MAC_CLKSEL(x) | BIT_SYM_MAC_CLKSEL(v))
#define BIT_SHIFT_SW_DPDT_LOC 27
#define BIT_MASK_SW_DPDT_LOC 0x3
#define BIT_SW_DPDT_LOC(x) \
(((x) & BIT_MASK_SW_DPDT_LOC) << BIT_SHIFT_SW_DPDT_LOC)
#define BITS_SW_DPDT_LOC (BIT_MASK_SW_DPDT_LOC << BIT_SHIFT_SW_DPDT_LOC)
#define BIT_CLEAR_SW_DPDT_LOC(x) ((x) & (~BITS_SW_DPDT_LOC))
#define BIT_GET_SW_DPDT_LOC(x) \
(((x) >> BIT_SHIFT_SW_DPDT_LOC) & BIT_MASK_SW_DPDT_LOC)
#define BIT_SET_SW_DPDT_LOC(x, v) \
(BIT_CLEAR_SW_DPDT_LOC(x) | BIT_SW_DPDT_LOC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_U3_CLK_VLD BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_WLGP_HW_DIS_LOC_BIT0 BIT(26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_PRST_VLD_V1 BIT(26)
#define BIT_PDN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_PKG_SEL 24
#define BIT_MASK_PKG_SEL 0x3
#define BIT_PKG_SEL(x) (((x) & BIT_MASK_PKG_SEL) << BIT_SHIFT_PKG_SEL)
#define BITS_PKG_SEL (BIT_MASK_PKG_SEL << BIT_SHIFT_PKG_SEL)
#define BIT_CLEAR_PKG_SEL(x) ((x) & (~BITS_PKG_SEL))
#define BIT_GET_PKG_SEL(x) (((x) >> BIT_SHIFT_PKG_SEL) & BIT_MASK_PKG_SEL)
#define BIT_SET_PKG_SEL(x, v) (BIT_CLEAR_PKG_SEL(x) | BIT_PKG_SEL(v))
#define BIT_SHIFT_SYM_OSC32K_RCAL 24
#define BIT_MASK_SYM_OSC32K_RCAL 0x3f
#define BIT_SYM_OSC32K_RCAL(x) \
(((x) & BIT_MASK_SYM_OSC32K_RCAL) << BIT_SHIFT_SYM_OSC32K_RCAL)
#define BITS_SYM_OSC32K_RCAL \
(BIT_MASK_SYM_OSC32K_RCAL << BIT_SHIFT_SYM_OSC32K_RCAL)
#define BIT_CLEAR_SYM_OSC32K_RCAL(x) ((x) & (~BITS_SYM_OSC32K_RCAL))
#define BIT_GET_SYM_OSC32K_RCAL(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_RCAL) & BIT_MASK_SYM_OSC32K_RCAL)
#define BIT_SET_SYM_OSC32K_RCAL(x, v) \
(BIT_CLEAR_SYM_OSC32K_RCAL(x) | BIT_SYM_OSC32K_RCAL(v))
#define BIT_SHIFT_SW_GPIO_B_PD 24
#define BIT_MASK_SW_GPIO_B_PD 0xff
#define BIT_SW_GPIO_B_PD(x) \
(((x) & BIT_MASK_SW_GPIO_B_PD) << BIT_SHIFT_SW_GPIO_B_PD)
#define BITS_SW_GPIO_B_PD (BIT_MASK_SW_GPIO_B_PD << BIT_SHIFT_SW_GPIO_B_PD)
#define BIT_CLEAR_SW_GPIO_B_PD(x) ((x) & (~BITS_SW_GPIO_B_PD))
#define BIT_GET_SW_GPIO_B_PD(x) \
(((x) >> BIT_SHIFT_SW_GPIO_B_PD) & BIT_MASK_SW_GPIO_B_PD)
#define BIT_SET_SW_GPIO_B_PD(x, v) \
(BIT_CLEAR_SW_GPIO_B_PD(x) | BIT_SW_GPIO_B_PD(v))
#define BIT_SHIFT_SW_GPIO_B_IN 24
#define BIT_MASK_SW_GPIO_B_IN 0xff
#define BIT_SW_GPIO_B_IN(x) \
(((x) & BIT_MASK_SW_GPIO_B_IN) << BIT_SHIFT_SW_GPIO_B_IN)
#define BITS_SW_GPIO_B_IN (BIT_MASK_SW_GPIO_B_IN << BIT_SHIFT_SW_GPIO_B_IN)
#define BIT_CLEAR_SW_GPIO_B_IN(x) ((x) & (~BITS_SW_GPIO_B_IN))
#define BIT_GET_SW_GPIO_B_IN(x) \
(((x) >> BIT_SHIFT_SW_GPIO_B_IN) & BIT_MASK_SW_GPIO_B_IN)
#define BIT_SET_SW_GPIO_B_IN(x, v) \
(BIT_CLEAR_SW_GPIO_B_IN(x) | BIT_SW_GPIO_B_IN(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_OCP_SHUTDN_V1 BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_ANT_SEL_01_LOC 23
#define BIT_MASK_ANT_SEL_01_LOC 0x7
#define BIT_ANT_SEL_01_LOC(x) \
(((x) & BIT_MASK_ANT_SEL_01_LOC) << BIT_SHIFT_ANT_SEL_01_LOC)
#define BITS_ANT_SEL_01_LOC \
(BIT_MASK_ANT_SEL_01_LOC << BIT_SHIFT_ANT_SEL_01_LOC)
#define BIT_CLEAR_ANT_SEL_01_LOC(x) ((x) & (~BITS_ANT_SEL_01_LOC))
#define BIT_GET_ANT_SEL_01_LOC(x) \
(((x) >> BIT_SHIFT_ANT_SEL_01_LOC) & BIT_MASK_ANT_SEL_01_LOC)
#define BIT_SET_ANT_SEL_01_LOC(x, v) \
(BIT_CLEAR_ANT_SEL_01_LOC(x) | BIT_ANT_SEL_01_LOC(v))
#define BIT_SHIFT_AUTOLOADABLE_AT_1FC 23
#define BIT_MASK_AUTOLOADABLE_AT_1FC 0x3f
#define BIT_AUTOLOADABLE_AT_1FC(x) \
(((x) & BIT_MASK_AUTOLOADABLE_AT_1FC) << BIT_SHIFT_AUTOLOADABLE_AT_1FC)
#define BITS_AUTOLOADABLE_AT_1FC \
(BIT_MASK_AUTOLOADABLE_AT_1FC << BIT_SHIFT_AUTOLOADABLE_AT_1FC)
#define BIT_CLEAR_AUTOLOADABLE_AT_1FC(x) ((x) & (~BITS_AUTOLOADABLE_AT_1FC))
#define BIT_GET_AUTOLOADABLE_AT_1FC(x) \
(((x) >> BIT_SHIFT_AUTOLOADABLE_AT_1FC) & BIT_MASK_AUTOLOADABLE_AT_1FC)
#define BIT_SET_AUTOLOADABLE_AT_1FC(x, v) \
(BIT_CLEAR_AUTOLOADABLE_AT_1FC(x) | BIT_AUTOLOADABLE_AT_1FC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_PCLK_VLD_V1 BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BT_DISN_EN_V1 BIT(22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_U2_CLK_VLD BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_ANT_SEL_23_LOC 21
#define BIT_MASK_ANT_SEL_23_LOC 0x3
#define BIT_ANT_SEL_23_LOC(x) \
(((x) & BIT_MASK_ANT_SEL_23_LOC) << BIT_SHIFT_ANT_SEL_23_LOC)
#define BITS_ANT_SEL_23_LOC \
(BIT_MASK_ANT_SEL_23_LOC << BIT_SHIFT_ANT_SEL_23_LOC)
#define BIT_CLEAR_ANT_SEL_23_LOC(x) ((x) & (~BITS_ANT_SEL_23_LOC))
#define BIT_GET_ANT_SEL_23_LOC(x) \
(((x) >> BIT_SHIFT_ANT_SEL_23_LOC) & BIT_MASK_ANT_SEL_23_LOC)
#define BIT_SET_ANT_SEL_23_LOC(x, v) \
(BIT_CLEAR_ANT_SEL_23_LOC(x) | BIT_ANT_SEL_23_LOC(v))
#define BIT_BT_SUSN_LOC BIT(21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_PLL_CLK_VLD BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_SW_ICFG 20
#define BIT_MASK_SW_ICFG 0xf
#define BIT_SW_ICFG(x) (((x) & BIT_MASK_SW_ICFG) << BIT_SHIFT_SW_ICFG)
#define BITS_SW_ICFG (BIT_MASK_SW_ICFG << BIT_SHIFT_SW_ICFG)
#define BIT_CLEAR_SW_ICFG(x) ((x) & (~BITS_SW_ICFG))
#define BIT_GET_SW_ICFG(x) (((x) >> BIT_SHIFT_SW_ICFG) & BIT_MASK_SW_ICFG)
#define BIT_SET_SW_ICFG(x, v) (BIT_CLEAR_SW_ICFG(x) | BIT_SW_ICFG(v))
#define BIT_SYM_CONF_BYTE_ENB BIT(20)
#define BIT_WLBB_RFE_LED1 BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_XCK_VLD BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_HPHY_ICFG BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_EXTCK32K_LOC 19
#define BIT_MASK_EXTCK32K_LOC 0x3
#define BIT_EXTCK32K_LOC(x) \
(((x) & BIT_MASK_EXTCK32K_LOC) << BIT_SHIFT_EXTCK32K_LOC)
#define BITS_EXTCK32K_LOC (BIT_MASK_EXTCK32K_LOC << BIT_SHIFT_EXTCK32K_LOC)
#define BIT_CLEAR_EXTCK32K_LOC(x) ((x) & (~BITS_EXTCK32K_LOC))
#define BIT_GET_EXTCK32K_LOC(x) \
(((x) >> BIT_SHIFT_EXTCK32K_LOC) & BIT_MASK_EXTCK32K_LOC)
#define BIT_SET_EXTCK32K_LOC(x, v) \
(BIT_CLEAR_EXTCK32K_LOC(x) | BIT_EXTCK32K_LOC(v))
#define BIT_WLGP_LED1_EN BIT(19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_CK200M_VLD BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BT_COEX_MBOX_LOC BIT(18)
#define BIT_WLGP_ANT23_EN BIT(18)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_HCI_SEL_EMBEDDED BIT(18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BTEN_TRAP BIT(18)
#define BIT_PKG_EN_V1 BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_SEL_0XC0 16
#define BIT_MASK_SEL_0XC0 0x3
#define BIT_SEL_0XC0(x) (((x) & BIT_MASK_SEL_0XC0) << BIT_SHIFT_SEL_0XC0)
#define BITS_SEL_0XC0 (BIT_MASK_SEL_0XC0 << BIT_SHIFT_SEL_0XC0)
#define BIT_CLEAR_SEL_0XC0(x) ((x) & (~BITS_SEL_0XC0))
#define BIT_GET_SEL_0XC0(x) (((x) >> BIT_SHIFT_SEL_0XC0) & BIT_MASK_SEL_0XC0)
#define BIT_SET_SEL_0XC0(x, v) (BIT_CLEAR_SEL_0XC0(x) | BIT_SEL_0XC0(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SYM_MCUFWDL_DDMA_EN BIT(16)
#define BIT_SYM_SPIC_BOOT_ADDR_CMP BIT(16)
#define BIT_SHIFT_SYM_OSC32K_CLKGEN0 16
#define BIT_MASK_SYM_OSC32K_CLKGEN0 0xff
#define BIT_SYM_OSC32K_CLKGEN0(x) \
(((x) & BIT_MASK_SYM_OSC32K_CLKGEN0) << BIT_SHIFT_SYM_OSC32K_CLKGEN0)
#define BITS_SYM_OSC32K_CLKGEN0 \
(BIT_MASK_SYM_OSC32K_CLKGEN0 << BIT_SHIFT_SYM_OSC32K_CLKGEN0)
#define BIT_CLEAR_SYM_OSC32K_CLKGEN0(x) ((x) & (~BITS_SYM_OSC32K_CLKGEN0))
#define BIT_GET_SYM_OSC32K_CLKGEN0(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_CLKGEN0) & BIT_MASK_SYM_OSC32K_CLKGEN0)
#define BIT_SET_SYM_OSC32K_CLKGEN0(x, v) \
(BIT_CLEAR_SYM_OSC32K_CLKGEN0(x) | BIT_SYM_OSC32K_CLKGEN0(v))
#define BIT_SHIFT_CRC16_RESULT 16
#define BIT_MASK_CRC16_RESULT 0xffff
#define BIT_CRC16_RESULT(x) \
(((x) & BIT_MASK_CRC16_RESULT) << BIT_SHIFT_CRC16_RESULT)
#define BITS_CRC16_RESULT (BIT_MASK_CRC16_RESULT << BIT_SHIFT_CRC16_RESULT)
#define BIT_CLEAR_CRC16_RESULT(x) ((x) & (~BITS_CRC16_RESULT))
#define BIT_GET_CRC16_RESULT(x) \
(((x) >> BIT_SHIFT_CRC16_RESULT) & BIT_MASK_CRC16_RESULT)
#define BIT_SET_CRC16_RESULT(x, v) \
(BIT_CLEAR_CRC16_RESULT(x) | BIT_CRC16_RESULT(v))
#define BIT_SHIFT_BTGP_LEDIO_LOC 16
#define BIT_MASK_BTGP_LEDIO_LOC 0x3
#define BIT_BTGP_LEDIO_LOC(x) \
(((x) & BIT_MASK_BTGP_LEDIO_LOC) << BIT_SHIFT_BTGP_LEDIO_LOC)
#define BITS_BTGP_LEDIO_LOC \
(BIT_MASK_BTGP_LEDIO_LOC << BIT_SHIFT_BTGP_LEDIO_LOC)
#define BIT_CLEAR_BTGP_LEDIO_LOC(x) ((x) & (~BITS_BTGP_LEDIO_LOC))
#define BIT_GET_BTGP_LEDIO_LOC(x) \
(((x) >> BIT_SHIFT_BTGP_LEDIO_LOC) & BIT_MASK_BTGP_LEDIO_LOC)
#define BIT_SET_BTGP_LEDIO_LOC(x, v) \
(BIT_CLEAR_BTGP_LEDIO_LOC(x) | BIT_BTGP_LEDIO_LOC(v))
#define BIT_SHIFT_FEM_EN 16
#define BIT_MASK_FEM_EN 0x3
#define BIT_FEM_EN(x) (((x) & BIT_MASK_FEM_EN) << BIT_SHIFT_FEM_EN)
#define BITS_FEM_EN (BIT_MASK_FEM_EN << BIT_SHIFT_FEM_EN)
#define BIT_CLEAR_FEM_EN(x) ((x) & (~BITS_FEM_EN))
#define BIT_GET_FEM_EN(x) (((x) >> BIT_SHIFT_FEM_EN) & BIT_MASK_FEM_EN)
#define BIT_SET_FEM_EN(x, v) (BIT_CLEAR_FEM_EN(x) | BIT_FEM_EN(v))
#define BIT_SHIFT_SW_GPIO_B_PU 16
#define BIT_MASK_SW_GPIO_B_PU 0xff
#define BIT_SW_GPIO_B_PU(x) \
(((x) & BIT_MASK_SW_GPIO_B_PU) << BIT_SHIFT_SW_GPIO_B_PU)
#define BITS_SW_GPIO_B_PU (BIT_MASK_SW_GPIO_B_PU << BIT_SHIFT_SW_GPIO_B_PU)
#define BIT_CLEAR_SW_GPIO_B_PU(x) ((x) & (~BITS_SW_GPIO_B_PU))
#define BIT_GET_SW_GPIO_B_PU(x) \
(((x) >> BIT_SHIFT_SW_GPIO_B_PU) & BIT_MASK_SW_GPIO_B_PU)
#define BIT_SET_SW_GPIO_B_PU(x, v) \
(BIT_CLEAR_SW_GPIO_B_PU(x) | BIT_SW_GPIO_B_PU(v))
#define BIT_SHIFT_SYM_INT_PERIODIC 16
#define BIT_MASK_SYM_INT_PERIODIC 0x3ff
#define BIT_SYM_INT_PERIODIC(x) \
(((x) & BIT_MASK_SYM_INT_PERIODIC) << BIT_SHIFT_SYM_INT_PERIODIC)
#define BITS_SYM_INT_PERIODIC \
(BIT_MASK_SYM_INT_PERIODIC << BIT_SHIFT_SYM_INT_PERIODIC)
#define BIT_CLEAR_SYM_INT_PERIODIC(x) ((x) & (~BITS_SYM_INT_PERIODIC))
#define BIT_GET_SYM_INT_PERIODIC(x) \
(((x) >> BIT_SHIFT_SYM_INT_PERIODIC) & BIT_MASK_SYM_INT_PERIODIC)
#define BIT_SET_SYM_INT_PERIODIC(x, v) \
(BIT_CLEAR_SYM_INT_PERIODIC(x) | BIT_SYM_INT_PERIODIC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_TRAP_LDO_SPS_V1 BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_IDV_DPDTSEL_P BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_MACRDY BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_LTE_COEX_UART_LOC 14
#define BIT_MASK_LTE_COEX_UART_LOC 0x3
#define BIT_LTE_COEX_UART_LOC(x) \
(((x) & BIT_MASK_LTE_COEX_UART_LOC) << BIT_SHIFT_LTE_COEX_UART_LOC)
#define BITS_LTE_COEX_UART_LOC \
(BIT_MASK_LTE_COEX_UART_LOC << BIT_SHIFT_LTE_COEX_UART_LOC)
#define BIT_CLEAR_LTE_COEX_UART_LOC(x) ((x) & (~BITS_LTE_COEX_UART_LOC))
#define BIT_GET_LTE_COEX_UART_LOC(x) \
(((x) >> BIT_SHIFT_LTE_COEX_UART_LOC) & BIT_MASK_LTE_COEX_UART_LOC)
#define BIT_SET_LTE_COEX_UART_LOC(x, v) \
(BIT_CLEAR_LTE_COEX_UART_LOC(x) | BIT_LTE_COEX_UART_LOC(v))
#define BIT_IDV_DPDTSEL_N BIT(14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_12V_VLD BIT(14)
#define BIT_U3PHY_RST BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_SYM_LDOA12V_WT 12
#define BIT_MASK_SYM_LDOA12V_WT 0x3
#define BIT_SYM_LDOA12V_WT(x) \
(((x) & BIT_MASK_SYM_LDOA12V_WT) << BIT_SHIFT_SYM_LDOA12V_WT)
#define BITS_SYM_LDOA12V_WT \
(BIT_MASK_SYM_LDOA12V_WT << BIT_SHIFT_SYM_LDOA12V_WT)
#define BIT_CLEAR_SYM_LDOA12V_WT(x) ((x) & (~BITS_SYM_LDOA12V_WT))
#define BIT_GET_SYM_LDOA12V_WT(x) \
(((x) >> BIT_SHIFT_SYM_LDOA12V_WT) & BIT_MASK_SYM_LDOA12V_WT)
#define BIT_SET_SYM_LDOA12V_WT(x, v) \
(BIT_CLEAR_SYM_LDOA12V_WT(x) | BIT_SYM_LDOA12V_WT(v))
#define BIT_SHIFT_SYM_OSC32K_TEMP_COMP 12
#define BIT_MASK_SYM_OSC32K_TEMP_COMP 0xf
#define BIT_SYM_OSC32K_TEMP_COMP(x) \
(((x) & BIT_MASK_SYM_OSC32K_TEMP_COMP) \
<< BIT_SHIFT_SYM_OSC32K_TEMP_COMP)
#define BITS_SYM_OSC32K_TEMP_COMP \
(BIT_MASK_SYM_OSC32K_TEMP_COMP << BIT_SHIFT_SYM_OSC32K_TEMP_COMP)
#define BIT_CLEAR_SYM_OSC32K_TEMP_COMP(x) ((x) & (~BITS_SYM_OSC32K_TEMP_COMP))
#define BIT_GET_SYM_OSC32K_TEMP_COMP(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_TEMP_COMP) & \
BIT_MASK_SYM_OSC32K_TEMP_COMP)
#define BIT_SET_SYM_OSC32K_TEMP_COMP(x, v) \
(BIT_CLEAR_SYM_OSC32K_TEMP_COMP(x) | BIT_SYM_OSC32K_TEMP_COMP(v))
#define BIT_SHIFT_LTE_3W_LOC 12
#define BIT_MASK_LTE_3W_LOC 0x3
#define BIT_LTE_3W_LOC(x) (((x) & BIT_MASK_LTE_3W_LOC) << BIT_SHIFT_LTE_3W_LOC)
#define BITS_LTE_3W_LOC (BIT_MASK_LTE_3W_LOC << BIT_SHIFT_LTE_3W_LOC)
#define BIT_CLEAR_LTE_3W_LOC(x) ((x) & (~BITS_LTE_3W_LOC))
#define BIT_GET_LTE_3W_LOC(x) \
(((x) >> BIT_SHIFT_LTE_3W_LOC) & BIT_MASK_LTE_3W_LOC)
#define BIT_SET_LTE_3W_LOC(x, v) (BIT_CLEAR_LTE_3W_LOC(x) | BIT_LTE_3W_LOC(v))
#define BIT_SHIFT_HW_EXTWOL_LOC 12
#define BIT_MASK_HW_EXTWOL_LOC 0x3
#define BIT_HW_EXTWOL_LOC(x) \
(((x) & BIT_MASK_HW_EXTWOL_LOC) << BIT_SHIFT_HW_EXTWOL_LOC)
#define BITS_HW_EXTWOL_LOC (BIT_MASK_HW_EXTWOL_LOC << BIT_SHIFT_HW_EXTWOL_LOC)
#define BIT_CLEAR_HW_EXTWOL_LOC(x) ((x) & (~BITS_HW_EXTWOL_LOC))
#define BIT_GET_HW_EXTWOL_LOC(x) \
(((x) >> BIT_SHIFT_HW_EXTWOL_LOC) & BIT_MASK_HW_EXTWOL_LOC)
#define BIT_SET_HW_EXTWOL_LOC(x, v) \
(BIT_CLEAR_HW_EXTWOL_LOC(x) | BIT_HW_EXTWOL_LOC(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_HCI_SEL_V4 12
#define BIT_MASK_HCI_SEL_V4 0x3
#define BIT_HCI_SEL_V4(x) (((x) & BIT_MASK_HCI_SEL_V4) << BIT_SHIFT_HCI_SEL_V4)
#define BITS_HCI_SEL_V4 (BIT_MASK_HCI_SEL_V4 << BIT_SHIFT_HCI_SEL_V4)
#define BIT_CLEAR_HCI_SEL_V4(x) ((x) & (~BITS_HCI_SEL_V4))
#define BIT_GET_HCI_SEL_V4(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V4) & BIT_MASK_HCI_SEL_V4)
#define BIT_SET_HCI_SEL_V4(x, v) (BIT_CLEAR_HCI_SEL_V4(x) | BIT_HCI_SEL_V4(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_USB2_SEL_V1 BIT(12)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_HCI_SEL_V3 12
#define BIT_MASK_HCI_SEL_V3 0x7
#define BIT_HCI_SEL_V3(x) (((x) & BIT_MASK_HCI_SEL_V3) << BIT_SHIFT_HCI_SEL_V3)
#define BITS_HCI_SEL_V3 (BIT_MASK_HCI_SEL_V3 << BIT_SHIFT_HCI_SEL_V3)
#define BIT_CLEAR_HCI_SEL_V3(x) ((x) & (~BITS_HCI_SEL_V3))
#define BIT_GET_HCI_SEL_V3(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V3) & BIT_MASK_HCI_SEL_V3)
#define BIT_SET_HCI_SEL_V3(x, v) (BIT_CLEAR_HCI_SEL_V3(x) | BIT_HCI_SEL_V3(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SIC_LOC BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_USB_OPERATION_MODE BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_BTGP_WAKE_LOC 10
#define BIT_MASK_BTGP_WAKE_LOC 0x3
#define BIT_BTGP_WAKE_LOC(x) \
(((x) & BIT_MASK_BTGP_WAKE_LOC) << BIT_SHIFT_BTGP_WAKE_LOC)
#define BITS_BTGP_WAKE_LOC (BIT_MASK_BTGP_WAKE_LOC << BIT_SHIFT_BTGP_WAKE_LOC)
#define BIT_CLEAR_BTGP_WAKE_LOC(x) ((x) & (~BITS_BTGP_WAKE_LOC))
#define BIT_GET_BTGP_WAKE_LOC(x) \
(((x) >> BIT_SHIFT_BTGP_WAKE_LOC) & BIT_MASK_BTGP_WAKE_LOC)
#define BIT_SET_BTGP_WAKE_LOC(x, v) \
(BIT_CLEAR_BTGP_WAKE_LOC(x) | BIT_BTGP_WAKE_LOC(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BT_PDN BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_WLMAC_DBG_LOC 9
#define BIT_MASK_WLMAC_DBG_LOC 0x3
#define BIT_WLMAC_DBG_LOC(x) \
(((x) & BIT_MASK_WLMAC_DBG_LOC) << BIT_SHIFT_WLMAC_DBG_LOC)
#define BITS_WLMAC_DBG_LOC (BIT_MASK_WLMAC_DBG_LOC << BIT_SHIFT_WLMAC_DBG_LOC)
#define BIT_CLEAR_WLMAC_DBG_LOC(x) ((x) & (~BITS_WLMAC_DBG_LOC))
#define BIT_GET_WLMAC_DBG_LOC(x) \
(((x) >> BIT_SHIFT_WLMAC_DBG_LOC) & BIT_MASK_WLMAC_DBG_LOC)
#define BIT_SET_WLMAC_DBG_LOC(x, v) \
(BIT_CLEAR_WLMAC_DBG_LOC(x) | BIT_WLMAC_DBG_LOC(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_AUTO_WLPON BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SYM_MCU_CLK_DIV2 BIT(8)
#define BIT_SHIFT_SYM_OSC32K_LDO_V18ADJ 8
#define BIT_MASK_SYM_OSC32K_LDO_V18ADJ 0xf
#define BIT_SYM_OSC32K_LDO_V18ADJ(x) \
(((x) & BIT_MASK_SYM_OSC32K_LDO_V18ADJ) \
<< BIT_SHIFT_SYM_OSC32K_LDO_V18ADJ)
#define BITS_SYM_OSC32K_LDO_V18ADJ \
(BIT_MASK_SYM_OSC32K_LDO_V18ADJ << BIT_SHIFT_SYM_OSC32K_LDO_V18ADJ)
#define BIT_CLEAR_SYM_OSC32K_LDO_V18ADJ(x) ((x) & (~BITS_SYM_OSC32K_LDO_V18ADJ))
#define BIT_GET_SYM_OSC32K_LDO_V18ADJ(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_LDO_V18ADJ) & \
BIT_MASK_SYM_OSC32K_LDO_V18ADJ)
#define BIT_SET_SYM_OSC32K_LDO_V18ADJ(x, v) \
(BIT_CLEAR_SYM_OSC32K_LDO_V18ADJ(x) | BIT_SYM_OSC32K_LDO_V18ADJ(v))
#define BIT_SHIFT_HOST_WAKE_WL_LOC 8
#define BIT_MASK_HOST_WAKE_WL_LOC 0x3
#define BIT_HOST_WAKE_WL_LOC(x) \
(((x) & BIT_MASK_HOST_WAKE_WL_LOC) << BIT_SHIFT_HOST_WAKE_WL_LOC)
#define BITS_HOST_WAKE_WL_LOC \
(BIT_MASK_HOST_WAKE_WL_LOC << BIT_SHIFT_HOST_WAKE_WL_LOC)
#define BIT_CLEAR_HOST_WAKE_WL_LOC(x) ((x) & (~BITS_HOST_WAKE_WL_LOC))
#define BIT_GET_HOST_WAKE_WL_LOC(x) \
(((x) >> BIT_SHIFT_HOST_WAKE_WL_LOC) & BIT_MASK_HOST_WAKE_WL_LOC)
#define BIT_SET_HOST_WAKE_WL_LOC(x, v) \
(BIT_CLEAR_HOST_WAKE_WL_LOC(x) | BIT_HOST_WAKE_WL_LOC(v))
#define BIT_SHIFT_SW_GPIO_B_OE2 8
#define BIT_MASK_SW_GPIO_B_OE2 0xff
#define BIT_SW_GPIO_B_OE2(x) \
(((x) & BIT_MASK_SW_GPIO_B_OE2) << BIT_SHIFT_SW_GPIO_B_OE2)
#define BITS_SW_GPIO_B_OE2 (BIT_MASK_SW_GPIO_B_OE2 << BIT_SHIFT_SW_GPIO_B_OE2)
#define BIT_CLEAR_SW_GPIO_B_OE2(x) ((x) & (~BITS_SW_GPIO_B_OE2))
#define BIT_GET_SW_GPIO_B_OE2(x) \
(((x) >> BIT_SHIFT_SW_GPIO_B_OE2) & BIT_MASK_SW_GPIO_B_OE2)
#define BIT_SET_SW_GPIO_B_OE2(x, v) \
(BIT_CLEAR_SW_GPIO_B_OE2(x) | BIT_SW_GPIO_B_OE2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_TRAP_ICFG 8
#define BIT_MASK_TRAP_ICFG 0xf
#define BIT_TRAP_ICFG(x) (((x) & BIT_MASK_TRAP_ICFG) << BIT_SHIFT_TRAP_ICFG)
#define BITS_TRAP_ICFG (BIT_MASK_TRAP_ICFG << BIT_SHIFT_TRAP_ICFG)
#define BIT_CLEAR_TRAP_ICFG(x) ((x) & (~BITS_TRAP_ICFG))
#define BIT_GET_TRAP_ICFG(x) (((x) >> BIT_SHIFT_TRAP_ICFG) & BIT_MASK_TRAP_ICFG)
#define BIT_SET_TRAP_ICFG(x, v) (BIT_CLEAR_TRAP_ICFG(x) | BIT_TRAP_ICFG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_WL_MODE BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SPI_FLASH_LOC BIT(7)
#define BIT_SHIFT_WLPHY_DBG_LOC 7
#define BIT_MASK_WLPHY_DBG_LOC 0x3
#define BIT_WLPHY_DBG_LOC(x) \
(((x) & BIT_MASK_WLPHY_DBG_LOC) << BIT_SHIFT_WLPHY_DBG_LOC)
#define BITS_WLPHY_DBG_LOC (BIT_MASK_WLPHY_DBG_LOC << BIT_SHIFT_WLPHY_DBG_LOC)
#define BIT_CLEAR_WLPHY_DBG_LOC(x) ((x) & (~BITS_WLPHY_DBG_LOC))
#define BIT_GET_WLPHY_DBG_LOC(x) \
(((x) >> BIT_SHIFT_WLPHY_DBG_LOC) & BIT_MASK_WLPHY_DBG_LOC)
#define BIT_SET_WLPHY_DBG_LOC(x, v) \
(BIT_CLEAR_WLPHY_DBG_LOC(x) | BIT_WLPHY_DBG_LOC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_WLAN_ID BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_PKG_SEL_HCI BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_SYM_OSC32K_COMP_LOAD_CUR 6
#define BIT_MASK_SYM_OSC32K_COMP_LOAD_CUR 0x3
#define BIT_SYM_OSC32K_COMP_LOAD_CUR(x) \
(((x) & BIT_MASK_SYM_OSC32K_COMP_LOAD_CUR) \
<< BIT_SHIFT_SYM_OSC32K_COMP_LOAD_CUR)
#define BITS_SYM_OSC32K_COMP_LOAD_CUR \
(BIT_MASK_SYM_OSC32K_COMP_LOAD_CUR \
<< BIT_SHIFT_SYM_OSC32K_COMP_LOAD_CUR)
#define BIT_CLEAR_SYM_OSC32K_COMP_LOAD_CUR(x) \
((x) & (~BITS_SYM_OSC32K_COMP_LOAD_CUR))
#define BIT_GET_SYM_OSC32K_COMP_LOAD_CUR(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_COMP_LOAD_CUR) & \
BIT_MASK_SYM_OSC32K_COMP_LOAD_CUR)
#define BIT_SET_SYM_OSC32K_COMP_LOAD_CUR(x, v) \
(BIT_CLEAR_SYM_OSC32K_COMP_LOAD_CUR(x) | \
BIT_SYM_OSC32K_COMP_LOAD_CUR(v))
#define BIT_WLGP_HW_DIS_LOC_BIT1 BIT(6)
#define BIT_XTAL_CKOUT_LOC BIT(6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_ALDN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_XTAL_CLKREQ_EN BIT(5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BTCOEX_CMDEN BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_HCI_SEL 4
#define BIT_MASK_HCI_SEL 0x3
#define BIT_HCI_SEL(x) (((x) & BIT_MASK_HCI_SEL) << BIT_SHIFT_HCI_SEL)
#define BITS_HCI_SEL (BIT_MASK_HCI_SEL << BIT_SHIFT_HCI_SEL)
#define BIT_CLEAR_HCI_SEL(x) ((x) & (~BITS_HCI_SEL))
#define BIT_GET_HCI_SEL(x) (((x) >> BIT_SHIFT_HCI_SEL) & BIT_MASK_HCI_SEL)
#define BIT_SET_HCI_SEL(x, v) (BIT_CLEAR_HCI_SEL(x) | BIT_HCI_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SYM_BOOT_SEL BIT(4)
#define BIT_SHIFT_SYM_OSC32K_COMP_LATCH_CUR 4
#define BIT_MASK_SYM_OSC32K_COMP_LATCH_CUR 0x3
#define BIT_SYM_OSC32K_COMP_LATCH_CUR(x) \
(((x) & BIT_MASK_SYM_OSC32K_COMP_LATCH_CUR) \
<< BIT_SHIFT_SYM_OSC32K_COMP_LATCH_CUR)
#define BITS_SYM_OSC32K_COMP_LATCH_CUR \
(BIT_MASK_SYM_OSC32K_COMP_LATCH_CUR \
<< BIT_SHIFT_SYM_OSC32K_COMP_LATCH_CUR)
#define BIT_CLEAR_SYM_OSC32K_COMP_LATCH_CUR(x) \
((x) & (~BITS_SYM_OSC32K_COMP_LATCH_CUR))
#define BIT_GET_SYM_OSC32K_COMP_LATCH_CUR(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_COMP_LATCH_CUR) & \
BIT_MASK_SYM_OSC32K_COMP_LATCH_CUR)
#define BIT_SET_SYM_OSC32K_COMP_LATCH_CUR(x, v) \
(BIT_CLEAR_SYM_OSC32K_COMP_LATCH_CUR(x) | \
BIT_SYM_OSC32K_COMP_LATCH_CUR(v))
#define BIT_SHIFT_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY 4
#define BIT_MASK_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY 0x3ff
#define BIT_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY(x) \
(((x) & BIT_MASK_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY) \
<< BIT_SHIFT_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY)
#define BITS_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY \
(BIT_MASK_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY \
<< BIT_SHIFT_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY)
#define BIT_CLEAR_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY(x) \
((x) & (~BITS_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY))
#define BIT_GET_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY(x) \
(((x) >> BIT_SHIFT_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY) & \
BIT_MASK_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY)
#define BIT_SET_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY(x, v) \
(BIT_CLEAR_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY(x) | \
BIT_CRC16_CHECK_MAXIMUM_ADDRESS_BOUNDARY(v))
#define BIT_HOST_WAKE_WL_EN BIT(4)
#define BIT_SHIFT_XTAL_CLKREQ_LOC 4
#define BIT_MASK_XTAL_CLKREQ_LOC 0x3
#define BIT_XTAL_CLKREQ_LOC(x) \
(((x) & BIT_MASK_XTAL_CLKREQ_LOC) << BIT_SHIFT_XTAL_CLKREQ_LOC)
#define BITS_XTAL_CLKREQ_LOC \
(BIT_MASK_XTAL_CLKREQ_LOC << BIT_SHIFT_XTAL_CLKREQ_LOC)
#define BIT_CLEAR_XTAL_CLKREQ_LOC(x) ((x) & (~BITS_XTAL_CLKREQ_LOC))
#define BIT_GET_XTAL_CLKREQ_LOC(x) \
(((x) >> BIT_SHIFT_XTAL_CLKREQ_LOC) & BIT_MASK_XTAL_CLKREQ_LOC)
#define BIT_SET_XTAL_CLKREQ_LOC(x, v) \
(BIT_CLEAR_XTAL_CLKREQ_LOC(x) | BIT_XTAL_CLKREQ_LOC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BT_EN BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BTGP_MCM_UART_EN BIT(3)
#define BIT_WLGP_UART_LOC BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_PAD_HCI_SEL_V2 3
#define BIT_MASK_PAD_HCI_SEL_V2 0x3
#define BIT_PAD_HCI_SEL_V2(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_V2) << BIT_SHIFT_PAD_HCI_SEL_V2)
#define BITS_PAD_HCI_SEL_V2 \
(BIT_MASK_PAD_HCI_SEL_V2 << BIT_SHIFT_PAD_HCI_SEL_V2)
#define BIT_CLEAR_PAD_HCI_SEL_V2(x) ((x) & (~BITS_PAD_HCI_SEL_V2))
#define BIT_GET_PAD_HCI_SEL_V2(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_V2) & BIT_MASK_PAD_HCI_SEL_V2)
#define BIT_SET_PAD_HCI_SEL_V2(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_V2(x) | BIT_PAD_HCI_SEL_V2(v))
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_PAD_HCI_SEL_V1 3
#define BIT_MASK_PAD_HCI_SEL_V1 0x7
#define BIT_PAD_HCI_SEL_V1(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_V1) << BIT_SHIFT_PAD_HCI_SEL_V1)
#define BITS_PAD_HCI_SEL_V1 \
(BIT_MASK_PAD_HCI_SEL_V1 << BIT_SHIFT_PAD_HCI_SEL_V1)
#define BIT_CLEAR_PAD_HCI_SEL_V1(x) ((x) & (~BITS_PAD_HCI_SEL_V1))
#define BIT_GET_PAD_HCI_SEL_V1(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_V1) & BIT_MASK_PAD_HCI_SEL_V1)
#define BIT_SET_PAD_HCI_SEL_V1(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_V1(x) | BIT_PAD_HCI_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_PAD_HCI_SEL 2
#define BIT_MASK_PAD_HCI_SEL 0x3
#define BIT_PAD_HCI_SEL(x) \
(((x) & BIT_MASK_PAD_HCI_SEL) << BIT_SHIFT_PAD_HCI_SEL)
#define BITS_PAD_HCI_SEL (BIT_MASK_PAD_HCI_SEL << BIT_SHIFT_PAD_HCI_SEL)
#define BIT_CLEAR_PAD_HCI_SEL(x) ((x) & (~BITS_PAD_HCI_SEL))
#define BIT_GET_PAD_HCI_SEL(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL) & BIT_MASK_PAD_HCI_SEL)
#define BIT_SET_PAD_HCI_SEL(x, v) \
(BIT_CLEAR_PAD_HCI_SEL(x) | BIT_PAD_HCI_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_SYM_OSC32K_COMP_GM_CUR 2
#define BIT_MASK_SYM_OSC32K_COMP_GM_CUR 0x3
#define BIT_SYM_OSC32K_COMP_GM_CUR(x) \
(((x) & BIT_MASK_SYM_OSC32K_COMP_GM_CUR) \
<< BIT_SHIFT_SYM_OSC32K_COMP_GM_CUR)
#define BITS_SYM_OSC32K_COMP_GM_CUR \
(BIT_MASK_SYM_OSC32K_COMP_GM_CUR << BIT_SHIFT_SYM_OSC32K_COMP_GM_CUR)
#define BIT_CLEAR_SYM_OSC32K_COMP_GM_CUR(x) \
((x) & (~BITS_SYM_OSC32K_COMP_GM_CUR))
#define BIT_GET_SYM_OSC32K_COMP_GM_CUR(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_COMP_GM_CUR) & \
BIT_MASK_SYM_OSC32K_COMP_GM_CUR)
#define BIT_SET_SYM_OSC32K_COMP_GM_CUR(x, v) \
(BIT_CLEAR_SYM_OSC32K_COMP_GM_CUR(x) | BIT_SYM_OSC32K_COMP_GM_CUR(v))
#define BIT_WLGP_MCM_COEXFEN BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_HCI_SEL_V2 2
#define BIT_MASK_HCI_SEL_V2 0x3
#define BIT_HCI_SEL_V2(x) (((x) & BIT_MASK_HCI_SEL_V2) << BIT_SHIFT_HCI_SEL_V2)
#define BITS_HCI_SEL_V2 (BIT_MASK_HCI_SEL_V2 << BIT_SHIFT_HCI_SEL_V2)
#define BIT_CLEAR_HCI_SEL_V2(x) ((x) & (~BITS_HCI_SEL_V2))
#define BIT_GET_HCI_SEL_V2(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V2) & BIT_MASK_HCI_SEL_V2)
#define BIT_SET_HCI_SEL_V2(x, v) (BIT_CLEAR_HCI_SEL_V2(x) | BIT_HCI_SEL_V2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_BT_COEX_MCM_MBOX BIT(1)
#define BIT_SHIFT_BTGP_WAKE_HST_LOC 1
#define BIT_MASK_BTGP_WAKE_HST_LOC 0x3
#define BIT_BTGP_WAKE_HST_LOC(x) \
(((x) & BIT_MASK_BTGP_WAKE_HST_LOC) << BIT_SHIFT_BTGP_WAKE_HST_LOC)
#define BITS_BTGP_WAKE_HST_LOC \
(BIT_MASK_BTGP_WAKE_HST_LOC << BIT_SHIFT_BTGP_WAKE_HST_LOC)
#define BIT_CLEAR_BTGP_WAKE_HST_LOC(x) ((x) & (~BITS_BTGP_WAKE_HST_LOC))
#define BIT_GET_BTGP_WAKE_HST_LOC(x) \
(((x) >> BIT_SHIFT_BTGP_WAKE_HST_LOC) & BIT_MASK_BTGP_WAKE_HST_LOC)
#define BIT_SET_BTGP_WAKE_HST_LOC(x, v) \
(BIT_CLEAR_BTGP_WAKE_HST_LOC(x) | BIT_BTGP_WAKE_HST_LOC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_TST_MOD_SEL BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_EFS_HCI_SEL 0
#define BIT_MASK_EFS_HCI_SEL 0x3
#define BIT_EFS_HCI_SEL(x) \
(((x) & BIT_MASK_EFS_HCI_SEL) << BIT_SHIFT_EFS_HCI_SEL)
#define BITS_EFS_HCI_SEL (BIT_MASK_EFS_HCI_SEL << BIT_SHIFT_EFS_HCI_SEL)
#define BIT_CLEAR_EFS_HCI_SEL(x) ((x) & (~BITS_EFS_HCI_SEL))
#define BIT_GET_EFS_HCI_SEL(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL) & BIT_MASK_EFS_HCI_SEL)
#define BIT_SET_EFS_HCI_SEL(x, v) \
(BIT_CLEAR_EFS_HCI_SEL(x) | BIT_EFS_HCI_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SYM_BOOT_CFG BIT(0)
#define BIT_SHIFT_SYM_SPIC_BOOT_EXT_ADDR 0
#define BIT_MASK_SYM_SPIC_BOOT_EXT_ADDR 0xffff
#define BIT_SYM_SPIC_BOOT_EXT_ADDR(x) \
(((x) & BIT_MASK_SYM_SPIC_BOOT_EXT_ADDR) \
<< BIT_SHIFT_SYM_SPIC_BOOT_EXT_ADDR)
#define BITS_SYM_SPIC_BOOT_EXT_ADDR \
(BIT_MASK_SYM_SPIC_BOOT_EXT_ADDR << BIT_SHIFT_SYM_SPIC_BOOT_EXT_ADDR)
#define BIT_CLEAR_SYM_SPIC_BOOT_EXT_ADDR(x) \
((x) & (~BITS_SYM_SPIC_BOOT_EXT_ADDR))
#define BIT_GET_SYM_SPIC_BOOT_EXT_ADDR(x) \
(((x) >> BIT_SHIFT_SYM_SPIC_BOOT_EXT_ADDR) & \
BIT_MASK_SYM_SPIC_BOOT_EXT_ADDR)
#define BIT_SET_SYM_SPIC_BOOT_EXT_ADDR(x, v) \
(BIT_CLEAR_SYM_SPIC_BOOT_EXT_ADDR(x) | BIT_SYM_SPIC_BOOT_EXT_ADDR(v))
#define BIT_SHIFT_SYM_OSC32K_FREQSEL 0
#define BIT_MASK_SYM_OSC32K_FREQSEL 0x3
#define BIT_SYM_OSC32K_FREQSEL(x) \
(((x) & BIT_MASK_SYM_OSC32K_FREQSEL) << BIT_SHIFT_SYM_OSC32K_FREQSEL)
#define BITS_SYM_OSC32K_FREQSEL \
(BIT_MASK_SYM_OSC32K_FREQSEL << BIT_SHIFT_SYM_OSC32K_FREQSEL)
#define BIT_CLEAR_SYM_OSC32K_FREQSEL(x) ((x) & (~BITS_SYM_OSC32K_FREQSEL))
#define BIT_GET_SYM_OSC32K_FREQSEL(x) \
(((x) >> BIT_SHIFT_SYM_OSC32K_FREQSEL) & BIT_MASK_SYM_OSC32K_FREQSEL)
#define BIT_SET_SYM_OSC32K_FREQSEL(x, v) \
(BIT_CLEAR_SYM_OSC32K_FREQSEL(x) | BIT_SYM_OSC32K_FREQSEL(v))
#define BIT_CRC16_CHECK_ENABLE BIT(0)
#define BIT_SW_GPIO_FUNC BIT(0)
#define BIT_BTGP_WAKE_BT_LOC BIT(0)
#define BIT_SHIFT_SW_GPIO_A_OUT 0
#define BIT_MASK_SW_GPIO_A_OUT 0xffffffffL
#define BIT_SW_GPIO_A_OUT(x) \
(((x) & BIT_MASK_SW_GPIO_A_OUT) << BIT_SHIFT_SW_GPIO_A_OUT)
#define BITS_SW_GPIO_A_OUT (BIT_MASK_SW_GPIO_A_OUT << BIT_SHIFT_SW_GPIO_A_OUT)
#define BIT_CLEAR_SW_GPIO_A_OUT(x) ((x) & (~BITS_SW_GPIO_A_OUT))
#define BIT_GET_SW_GPIO_A_OUT(x) \
(((x) >> BIT_SHIFT_SW_GPIO_A_OUT) & BIT_MASK_SW_GPIO_A_OUT)
#define BIT_SET_SW_GPIO_A_OUT(x, v) \
(BIT_CLEAR_SW_GPIO_A_OUT(x) | BIT_SW_GPIO_A_OUT(v))
#define BIT_SHIFT_SW_GPIO_A_OEN 0
#define BIT_MASK_SW_GPIO_A_OEN 0xffffffffL
#define BIT_SW_GPIO_A_OEN(x) \
(((x) & BIT_MASK_SW_GPIO_A_OEN) << BIT_SHIFT_SW_GPIO_A_OEN)
#define BITS_SW_GPIO_A_OEN (BIT_MASK_SW_GPIO_A_OEN << BIT_SHIFT_SW_GPIO_A_OEN)
#define BIT_CLEAR_SW_GPIO_A_OEN(x) ((x) & (~BITS_SW_GPIO_A_OEN))
#define BIT_GET_SW_GPIO_A_OEN(x) \
(((x) >> BIT_SHIFT_SW_GPIO_A_OEN) & BIT_MASK_SW_GPIO_A_OEN)
#define BIT_SET_SW_GPIO_A_OEN(x, v) \
(BIT_CLEAR_SW_GPIO_A_OEN(x) | BIT_SW_GPIO_A_OEN(v))
#define BIT_SHIFT_SW_GPIO_A_OE2 0
#define BIT_MASK_SW_GPIO_A_OE2 0xffffffffL
#define BIT_SW_GPIO_A_OE2(x) \
(((x) & BIT_MASK_SW_GPIO_A_OE2) << BIT_SHIFT_SW_GPIO_A_OE2)
#define BITS_SW_GPIO_A_OE2 (BIT_MASK_SW_GPIO_A_OE2 << BIT_SHIFT_SW_GPIO_A_OE2)
#define BIT_CLEAR_SW_GPIO_A_OE2(x) ((x) & (~BITS_SW_GPIO_A_OE2))
#define BIT_GET_SW_GPIO_A_OE2(x) \
(((x) >> BIT_SHIFT_SW_GPIO_A_OE2) & BIT_MASK_SW_GPIO_A_OE2)
#define BIT_SET_SW_GPIO_A_OE2(x, v) \
(BIT_CLEAR_SW_GPIO_A_OE2(x) | BIT_SW_GPIO_A_OE2(v))
#define BIT_SHIFT_SW_GPIO_A_PU 0
#define BIT_MASK_SW_GPIO_A_PU 0xffffffffL
#define BIT_SW_GPIO_A_PU(x) \
(((x) & BIT_MASK_SW_GPIO_A_PU) << BIT_SHIFT_SW_GPIO_A_PU)
#define BITS_SW_GPIO_A_PU (BIT_MASK_SW_GPIO_A_PU << BIT_SHIFT_SW_GPIO_A_PU)
#define BIT_CLEAR_SW_GPIO_A_PU(x) ((x) & (~BITS_SW_GPIO_A_PU))
#define BIT_GET_SW_GPIO_A_PU(x) \
(((x) >> BIT_SHIFT_SW_GPIO_A_PU) & BIT_MASK_SW_GPIO_A_PU)
#define BIT_SET_SW_GPIO_A_PU(x, v) \
(BIT_CLEAR_SW_GPIO_A_PU(x) | BIT_SW_GPIO_A_PU(v))
#define BIT_SHIFT_SW_GPIO_A_PD 0
#define BIT_MASK_SW_GPIO_A_PD 0xffffffffL
#define BIT_SW_GPIO_A_PD(x) \
(((x) & BIT_MASK_SW_GPIO_A_PD) << BIT_SHIFT_SW_GPIO_A_PD)
#define BITS_SW_GPIO_A_PD (BIT_MASK_SW_GPIO_A_PD << BIT_SHIFT_SW_GPIO_A_PD)
#define BIT_CLEAR_SW_GPIO_A_PD(x) ((x) & (~BITS_SW_GPIO_A_PD))
#define BIT_GET_SW_GPIO_A_PD(x) \
(((x) >> BIT_SHIFT_SW_GPIO_A_PD) & BIT_MASK_SW_GPIO_A_PD)
#define BIT_SET_SW_GPIO_A_PD(x, v) \
(BIT_CLEAR_SW_GPIO_A_PD(x) | BIT_SW_GPIO_A_PD(v))
#define BIT_SHIFT_SW_GPIO_A_IN 0
#define BIT_MASK_SW_GPIO_A_IN 0xffffffffL
#define BIT_SW_GPIO_A_IN(x) \
(((x) & BIT_MASK_SW_GPIO_A_IN) << BIT_SHIFT_SW_GPIO_A_IN)
#define BITS_SW_GPIO_A_IN (BIT_MASK_SW_GPIO_A_IN << BIT_SHIFT_SW_GPIO_A_IN)
#define BIT_CLEAR_SW_GPIO_A_IN(x) ((x) & (~BITS_SW_GPIO_A_IN))
#define BIT_GET_SW_GPIO_A_IN(x) \
(((x) >> BIT_SHIFT_SW_GPIO_A_IN) & BIT_MASK_SW_GPIO_A_IN)
#define BIT_SET_SW_GPIO_A_IN(x, v) \
(BIT_CLEAR_SW_GPIO_A_IN(x) | BIT_SW_GPIO_A_IN(v))
#define BIT_SHIFT_SW_GPIO_B_OEN 0
#define BIT_MASK_SW_GPIO_B_OEN 0xff
#define BIT_SW_GPIO_B_OEN(x) \
(((x) & BIT_MASK_SW_GPIO_B_OEN) << BIT_SHIFT_SW_GPIO_B_OEN)
#define BITS_SW_GPIO_B_OEN (BIT_MASK_SW_GPIO_B_OEN << BIT_SHIFT_SW_GPIO_B_OEN)
#define BIT_CLEAR_SW_GPIO_B_OEN(x) ((x) & (~BITS_SW_GPIO_B_OEN))
#define BIT_GET_SW_GPIO_B_OEN(x) \
(((x) >> BIT_SHIFT_SW_GPIO_B_OEN) & BIT_MASK_SW_GPIO_B_OEN)
#define BIT_SET_SW_GPIO_B_OEN(x, v) \
(BIT_CLEAR_SW_GPIO_B_OEN(x) | BIT_SW_GPIO_B_OEN(v))
#define BIT_SHIFT_SW_GPIO_B_OUT 0
#define BIT_MASK_SW_GPIO_B_OUT 0xff
#define BIT_SW_GPIO_B_OUT(x) \
(((x) & BIT_MASK_SW_GPIO_B_OUT) << BIT_SHIFT_SW_GPIO_B_OUT)
#define BITS_SW_GPIO_B_OUT (BIT_MASK_SW_GPIO_B_OUT << BIT_SHIFT_SW_GPIO_B_OUT)
#define BIT_CLEAR_SW_GPIO_B_OUT(x) ((x) & (~BITS_SW_GPIO_B_OUT))
#define BIT_GET_SW_GPIO_B_OUT(x) \
(((x) >> BIT_SHIFT_SW_GPIO_B_OUT) & BIT_MASK_SW_GPIO_B_OUT)
#define BIT_SET_SW_GPIO_B_OUT(x, v) \
(BIT_CLEAR_SW_GPIO_B_OUT(x) | BIT_SW_GPIO_B_OUT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_SHIFT_EFS_HCI_SEL_V1 0
#define BIT_MASK_EFS_HCI_SEL_V1 0x7
#define BIT_EFS_HCI_SEL_V1(x) \
(((x) & BIT_MASK_EFS_HCI_SEL_V1) << BIT_SHIFT_EFS_HCI_SEL_V1)
#define BITS_EFS_HCI_SEL_V1 \
(BIT_MASK_EFS_HCI_SEL_V1 << BIT_SHIFT_EFS_HCI_SEL_V1)
#define BIT_CLEAR_EFS_HCI_SEL_V1(x) ((x) & (~BITS_EFS_HCI_SEL_V1))
#define BIT_GET_EFS_HCI_SEL_V1(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL_V1) & BIT_MASK_EFS_HCI_SEL_V1)
#define BIT_SET_EFS_HCI_SEL_V1(x, v) \
(BIT_CLEAR_EFS_HCI_SEL_V1(x) | BIT_EFS_HCI_SEL_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_STATUS1 (Offset 0x00F4) */
#define BIT_PAD_HWPDB BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_STATUS2 (Offset 0x00F8) */
#define BIT_HIOE_ON_TIMEOUT BIT(23)
#define BIT_SIC_ON_TIMEOUT BIT(22)
#define BIT_CPU_ON_TIMEOUT BIT(21)
#define BIT_HCI_ON_TIMEOUT BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_STATUS2 (Offset 0x00F8) */
#define BIT_SIO_ALDN BIT(19)
#define BIT_USB_ALDN BIT(18)
#define BIT_PCI_ALDN BIT(17)
#define BIT_SYS_ALDN BIT(16)
#define BIT_SHIFT_EPVID1 8
#define BIT_MASK_EPVID1 0xff
#define BIT_EPVID1(x) (((x) & BIT_MASK_EPVID1) << BIT_SHIFT_EPVID1)
#define BITS_EPVID1 (BIT_MASK_EPVID1 << BIT_SHIFT_EPVID1)
#define BIT_CLEAR_EPVID1(x) ((x) & (~BITS_EPVID1))
#define BIT_GET_EPVID1(x) (((x) >> BIT_SHIFT_EPVID1) & BIT_MASK_EPVID1)
#define BIT_SET_EPVID1(x, v) (BIT_CLEAR_EPVID1(x) | BIT_EPVID1(v))
#define BIT_SHIFT_EPVID0 0
#define BIT_MASK_EPVID0 0xff
#define BIT_EPVID0(x) (((x) & BIT_MASK_EPVID0) << BIT_SHIFT_EPVID0)
#define BITS_EPVID0 (BIT_MASK_EPVID0 << BIT_SHIFT_EPVID0)
#define BIT_CLEAR_EPVID0(x) ((x) & (~BITS_EPVID0))
#define BIT_GET_EPVID0(x) (((x) >> BIT_SHIFT_EPVID0) & BIT_MASK_EPVID0)
#define BIT_SET_EPVID0(x, v) (BIT_CLEAR_EPVID0(x) | BIT_EPVID0(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_USB2_SEL_1 BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_USB2_SEL BIT(31)
#define BIT_FEN_WLMAC_OFF BIT(31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_USB3PHY_RST BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_U3PHY_RST_V1 BIT(30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_U3_TERM_DET BIT(29)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_U3_TERM_DETECT BIT(29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_USB23_DBG_SEL BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_HCI_SEL_EMBEDDED BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_ISO_BB2PP BIT(7)
#define BIT_ISO_DENG2PP BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_SHIFT_HW_ID 0
#define BIT_MASK_HW_ID 0xff
#define BIT_HW_ID(x) (((x) & BIT_MASK_HW_ID) << BIT_SHIFT_HW_ID)
#define BITS_HW_ID (BIT_MASK_HW_ID << BIT_SHIFT_HW_ID)
#define BIT_CLEAR_HW_ID(x) ((x) & (~BITS_HW_ID))
#define BIT_GET_HW_ID(x) (((x) >> BIT_SHIFT_HW_ID) & BIT_MASK_HW_ID)
#define BIT_SET_HW_ID(x, v) (BIT_CLEAR_HW_ID(x) | BIT_HW_ID(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG2 (Offset 0x00FC) */
#define BIT_SHIFT_CHIPID 0
#define BIT_MASK_CHIPID 0xff
#define BIT_CHIPID(x) (((x) & BIT_MASK_CHIPID) << BIT_SHIFT_CHIPID)
#define BITS_CHIPID (BIT_MASK_CHIPID << BIT_SHIFT_CHIPID)
#define BIT_CLEAR_CHIPID(x) ((x) & (~BITS_CHIPID))
#define BIT_GET_CHIPID(x) (((x) >> BIT_SHIFT_CHIPID) & BIT_MASK_CHIPID)
#define BIT_SET_CHIPID(x, v) (BIT_CLEAR_CHIPID(x) | BIT_CHIPID(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_BIST_H32BIT_SEL BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_MACIO_TIMEOUT_EN BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_SHIFT_LBMODE 24
#define BIT_MASK_LBMODE 0x1f
#define BIT_LBMODE(x) (((x) & BIT_MASK_LBMODE) << BIT_SHIFT_LBMODE)
#define BITS_LBMODE (BIT_MASK_LBMODE << BIT_SHIFT_LBMODE)
#define BIT_CLEAR_LBMODE(x) ((x) & (~BITS_LBMODE))
#define BIT_GET_LBMODE(x) (((x) >> BIT_SHIFT_LBMODE) & BIT_MASK_LBMODE)
#define BIT_SET_LBMODE(x, v) (BIT_CLEAR_LBMODE(x) | BIT_LBMODE(v))
#define BIT_SHIFT_NETYPE1 18
#define BIT_MASK_NETYPE1 0x3
#define BIT_NETYPE1(x) (((x) & BIT_MASK_NETYPE1) << BIT_SHIFT_NETYPE1)
#define BITS_NETYPE1 (BIT_MASK_NETYPE1 << BIT_SHIFT_NETYPE1)
#define BIT_CLEAR_NETYPE1(x) ((x) & (~BITS_NETYPE1))
#define BIT_GET_NETYPE1(x) (((x) >> BIT_SHIFT_NETYPE1) & BIT_MASK_NETYPE1)
#define BIT_SET_NETYPE1(x, v) (BIT_CLEAR_NETYPE1(x) | BIT_NETYPE1(v))
#define BIT_SHIFT_NETYPE0 16
#define BIT_MASK_NETYPE0 0x3
#define BIT_NETYPE0(x) (((x) & BIT_MASK_NETYPE0) << BIT_SHIFT_NETYPE0)
#define BITS_NETYPE0 (BIT_MASK_NETYPE0 << BIT_SHIFT_NETYPE0)
#define BIT_CLEAR_NETYPE0(x) ((x) & (~BITS_NETYPE0))
#define BIT_GET_NETYPE0(x) (((x) >> BIT_SHIFT_NETYPE0) & BIT_MASK_NETYPE0)
#define BIT_SET_NETYPE0(x, v) (BIT_CLEAR_NETYPE0(x) | BIT_NETYPE0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_STAT_FUNC_RST BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_COUNTER_STS_EN BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_PTA_I2C_MBOX_EN BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_I2C_MAILBOX_EN BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_SHCUT_EN BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CR (Offset 0x0100) */
#define BIT_32K_CAL_TMR_EN BIT(10)
#define BIT_MAC_SEC_EN BIT(9)
#define BIT_ENSWBCN BIT(8)
#define BIT_MACRXEN BIT(7)
#define BIT_MACTXEN BIT(6)
#define BIT_SCHEDULE_EN BIT(5)
#define BIT_PROTOCOL_EN BIT(4)
#define BIT_RXDMA_EN BIT(3)
#define BIT_TXDMA_EN BIT(2)
#define BIT_HCI_RXDMA_EN BIT(1)
#define BIT_HCI_TXDMA_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PG_SIZE (Offset 0x0104) */
#define BIT_SHIFT_DBG_FIFO_SEL 16
#define BIT_MASK_DBG_FIFO_SEL 0xff
#define BIT_DBG_FIFO_SEL(x) \
(((x) & BIT_MASK_DBG_FIFO_SEL) << BIT_SHIFT_DBG_FIFO_SEL)
#define BITS_DBG_FIFO_SEL (BIT_MASK_DBG_FIFO_SEL << BIT_SHIFT_DBG_FIFO_SEL)
#define BIT_CLEAR_DBG_FIFO_SEL(x) ((x) & (~BITS_DBG_FIFO_SEL))
#define BIT_GET_DBG_FIFO_SEL(x) \
(((x) >> BIT_SHIFT_DBG_FIFO_SEL) & BIT_MASK_DBG_FIFO_SEL)
#define BIT_SET_DBG_FIFO_SEL(x, v) \
(BIT_CLEAR_DBG_FIFO_SEL(x) | BIT_DBG_FIFO_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PKT_BUFF_ACCESS_CTRL (Offset 0x0106) */
#define BIT_SHIFT_PKT_BUFF_ACCESS_CTRL 0
#define BIT_MASK_PKT_BUFF_ACCESS_CTRL 0xff
#define BIT_PKT_BUFF_ACCESS_CTRL(x) \
(((x) & BIT_MASK_PKT_BUFF_ACCESS_CTRL) \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL)
#define BITS_PKT_BUFF_ACCESS_CTRL \
(BIT_MASK_PKT_BUFF_ACCESS_CTRL << BIT_SHIFT_PKT_BUFF_ACCESS_CTRL)
#define BIT_CLEAR_PKT_BUFF_ACCESS_CTRL(x) ((x) & (~BITS_PKT_BUFF_ACCESS_CTRL))
#define BIT_GET_PKT_BUFF_ACCESS_CTRL(x) \
(((x) >> BIT_SHIFT_PKT_BUFF_ACCESS_CTRL) & \
BIT_MASK_PKT_BUFF_ACCESS_CTRL)
#define BIT_SET_PKT_BUFF_ACCESS_CTRL(x, v) \
(BIT_CLEAR_PKT_BUFF_ACCESS_CTRL(x) | BIT_PKT_BUFF_ACCESS_CTRL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_CLK_STATE (Offset 0x0108) */
#define BIT_RXPKTBUF_DBG BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TSF_CLK_STATE (Offset 0x0108) */
#define BIT_TSF_CLK_IDX BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_CLK_STATE (Offset 0x0108) */
#define BIT_TSF_CLK_STABLE BIT(15)
#define BIT_SHIFT_PKTBUF_DBG_ADDR 0
#define BIT_MASK_PKTBUF_DBG_ADDR 0x1fff
#define BIT_PKTBUF_DBG_ADDR(x) \
(((x) & BIT_MASK_PKTBUF_DBG_ADDR) << BIT_SHIFT_PKTBUF_DBG_ADDR)
#define BITS_PKTBUF_DBG_ADDR \
(BIT_MASK_PKTBUF_DBG_ADDR << BIT_SHIFT_PKTBUF_DBG_ADDR)
#define BIT_CLEAR_PKTBUF_DBG_ADDR(x) ((x) & (~BITS_PKTBUF_DBG_ADDR))
#define BIT_GET_PKTBUF_DBG_ADDR(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_ADDR) & BIT_MASK_PKTBUF_DBG_ADDR)
#define BIT_SET_PKTBUF_DBG_ADDR(x, v) \
(BIT_CLEAR_PKTBUF_DBG_ADDR(x) | BIT_PKTBUF_DBG_ADDR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_CSI_BW_EN BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_HIQ_MAP_V1 19
#define BIT_MASK_TXDMA_HIQ_MAP_V1 0x7
#define BIT_TXDMA_HIQ_MAP_V1(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP_V1) << BIT_SHIFT_TXDMA_HIQ_MAP_V1)
#define BITS_TXDMA_HIQ_MAP_V1 \
(BIT_MASK_TXDMA_HIQ_MAP_V1 << BIT_SHIFT_TXDMA_HIQ_MAP_V1)
#define BIT_CLEAR_TXDMA_HIQ_MAP_V1(x) ((x) & (~BITS_TXDMA_HIQ_MAP_V1))
#define BIT_GET_TXDMA_HIQ_MAP_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP_V1) & BIT_MASK_TXDMA_HIQ_MAP_V1)
#define BIT_SET_TXDMA_HIQ_MAP_V1(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP_V1(x) | BIT_TXDMA_HIQ_MAP_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_CMQ_MAP 16
#define BIT_MASK_TXDMA_CMQ_MAP 0x3
#define BIT_TXDMA_CMQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_CMQ_MAP) << BIT_SHIFT_TXDMA_CMQ_MAP)
#define BITS_TXDMA_CMQ_MAP (BIT_MASK_TXDMA_CMQ_MAP << BIT_SHIFT_TXDMA_CMQ_MAP)
#define BIT_CLEAR_TXDMA_CMQ_MAP(x) ((x) & (~BITS_TXDMA_CMQ_MAP))
#define BIT_GET_TXDMA_CMQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_CMQ_MAP) & BIT_MASK_TXDMA_CMQ_MAP)
#define BIT_SET_TXDMA_CMQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_CMQ_MAP(x) | BIT_TXDMA_CMQ_MAP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_MGQ_MAP_V1 16
#define BIT_MASK_TXDMA_MGQ_MAP_V1 0x7
#define BIT_TXDMA_MGQ_MAP_V1(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP_V1) << BIT_SHIFT_TXDMA_MGQ_MAP_V1)
#define BITS_TXDMA_MGQ_MAP_V1 \
(BIT_MASK_TXDMA_MGQ_MAP_V1 << BIT_SHIFT_TXDMA_MGQ_MAP_V1)
#define BIT_CLEAR_TXDMA_MGQ_MAP_V1(x) ((x) & (~BITS_TXDMA_MGQ_MAP_V1))
#define BIT_GET_TXDMA_MGQ_MAP_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP_V1) & BIT_MASK_TXDMA_MGQ_MAP_V1)
#define BIT_SET_TXDMA_MGQ_MAP_V1(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP_V1(x) | BIT_TXDMA_MGQ_MAP_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_H2C_MAP 16
#define BIT_MASK_TXDMA_H2C_MAP 0x3
#define BIT_TXDMA_H2C_MAP(x) \
(((x) & BIT_MASK_TXDMA_H2C_MAP) << BIT_SHIFT_TXDMA_H2C_MAP)
#define BITS_TXDMA_H2C_MAP (BIT_MASK_TXDMA_H2C_MAP << BIT_SHIFT_TXDMA_H2C_MAP)
#define BIT_CLEAR_TXDMA_H2C_MAP(x) ((x) & (~BITS_TXDMA_H2C_MAP))
#define BIT_GET_TXDMA_H2C_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_H2C_MAP) & BIT_MASK_TXDMA_H2C_MAP)
#define BIT_SET_TXDMA_H2C_MAP(x, v) \
(BIT_CLEAR_TXDMA_H2C_MAP(x) | BIT_TXDMA_H2C_MAP(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_HIQ_MAP 14
#define BIT_MASK_TXDMA_HIQ_MAP 0x3
#define BIT_TXDMA_HIQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP) << BIT_SHIFT_TXDMA_HIQ_MAP)
#define BITS_TXDMA_HIQ_MAP (BIT_MASK_TXDMA_HIQ_MAP << BIT_SHIFT_TXDMA_HIQ_MAP)
#define BIT_CLEAR_TXDMA_HIQ_MAP(x) ((x) & (~BITS_TXDMA_HIQ_MAP))
#define BIT_GET_TXDMA_HIQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP) & BIT_MASK_TXDMA_HIQ_MAP)
#define BIT_SET_TXDMA_HIQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP(x) | BIT_TXDMA_HIQ_MAP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_BKQ_MAP_V1 13
#define BIT_MASK_TXDMA_BKQ_MAP_V1 0x7
#define BIT_TXDMA_BKQ_MAP_V1(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP_V1) << BIT_SHIFT_TXDMA_BKQ_MAP_V1)
#define BITS_TXDMA_BKQ_MAP_V1 \
(BIT_MASK_TXDMA_BKQ_MAP_V1 << BIT_SHIFT_TXDMA_BKQ_MAP_V1)
#define BIT_CLEAR_TXDMA_BKQ_MAP_V1(x) ((x) & (~BITS_TXDMA_BKQ_MAP_V1))
#define BIT_GET_TXDMA_BKQ_MAP_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP_V1) & BIT_MASK_TXDMA_BKQ_MAP_V1)
#define BIT_SET_TXDMA_BKQ_MAP_V1(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP_V1(x) | BIT_TXDMA_BKQ_MAP_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_MGQ_MAP 12
#define BIT_MASK_TXDMA_MGQ_MAP 0x3
#define BIT_TXDMA_MGQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP) << BIT_SHIFT_TXDMA_MGQ_MAP)
#define BITS_TXDMA_MGQ_MAP (BIT_MASK_TXDMA_MGQ_MAP << BIT_SHIFT_TXDMA_MGQ_MAP)
#define BIT_CLEAR_TXDMA_MGQ_MAP(x) ((x) & (~BITS_TXDMA_MGQ_MAP))
#define BIT_GET_TXDMA_MGQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP) & BIT_MASK_TXDMA_MGQ_MAP)
#define BIT_SET_TXDMA_MGQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP(x) | BIT_TXDMA_MGQ_MAP(v))
#define BIT_SHIFT_TXDMA_BKQ_MAP 10
#define BIT_MASK_TXDMA_BKQ_MAP 0x3
#define BIT_TXDMA_BKQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP) << BIT_SHIFT_TXDMA_BKQ_MAP)
#define BITS_TXDMA_BKQ_MAP (BIT_MASK_TXDMA_BKQ_MAP << BIT_SHIFT_TXDMA_BKQ_MAP)
#define BIT_CLEAR_TXDMA_BKQ_MAP(x) ((x) & (~BITS_TXDMA_BKQ_MAP))
#define BIT_GET_TXDMA_BKQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP) & BIT_MASK_TXDMA_BKQ_MAP)
#define BIT_SET_TXDMA_BKQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP(x) | BIT_TXDMA_BKQ_MAP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_BEQ_MAP_V1 10
#define BIT_MASK_TXDMA_BEQ_MAP_V1 0x7
#define BIT_TXDMA_BEQ_MAP_V1(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP_V1) << BIT_SHIFT_TXDMA_BEQ_MAP_V1)
#define BITS_TXDMA_BEQ_MAP_V1 \
(BIT_MASK_TXDMA_BEQ_MAP_V1 << BIT_SHIFT_TXDMA_BEQ_MAP_V1)
#define BIT_CLEAR_TXDMA_BEQ_MAP_V1(x) ((x) & (~BITS_TXDMA_BEQ_MAP_V1))
#define BIT_GET_TXDMA_BEQ_MAP_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP_V1) & BIT_MASK_TXDMA_BEQ_MAP_V1)
#define BIT_SET_TXDMA_BEQ_MAP_V1(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP_V1(x) | BIT_TXDMA_BEQ_MAP_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_BEQ_MAP 8
#define BIT_MASK_TXDMA_BEQ_MAP 0x3
#define BIT_TXDMA_BEQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP) << BIT_SHIFT_TXDMA_BEQ_MAP)
#define BITS_TXDMA_BEQ_MAP (BIT_MASK_TXDMA_BEQ_MAP << BIT_SHIFT_TXDMA_BEQ_MAP)
#define BIT_CLEAR_TXDMA_BEQ_MAP(x) ((x) & (~BITS_TXDMA_BEQ_MAP))
#define BIT_GET_TXDMA_BEQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP) & BIT_MASK_TXDMA_BEQ_MAP)
#define BIT_SET_TXDMA_BEQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP(x) | BIT_TXDMA_BEQ_MAP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_VIQ_MAP_V1 7
#define BIT_MASK_TXDMA_VIQ_MAP_V1 0x7
#define BIT_TXDMA_VIQ_MAP_V1(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP_V1) << BIT_SHIFT_TXDMA_VIQ_MAP_V1)
#define BITS_TXDMA_VIQ_MAP_V1 \
(BIT_MASK_TXDMA_VIQ_MAP_V1 << BIT_SHIFT_TXDMA_VIQ_MAP_V1)
#define BIT_CLEAR_TXDMA_VIQ_MAP_V1(x) ((x) & (~BITS_TXDMA_VIQ_MAP_V1))
#define BIT_GET_TXDMA_VIQ_MAP_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP_V1) & BIT_MASK_TXDMA_VIQ_MAP_V1)
#define BIT_SET_TXDMA_VIQ_MAP_V1(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP_V1(x) | BIT_TXDMA_VIQ_MAP_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_VIQ_MAP 6
#define BIT_MASK_TXDMA_VIQ_MAP 0x3
#define BIT_TXDMA_VIQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP) << BIT_SHIFT_TXDMA_VIQ_MAP)
#define BITS_TXDMA_VIQ_MAP (BIT_MASK_TXDMA_VIQ_MAP << BIT_SHIFT_TXDMA_VIQ_MAP)
#define BIT_CLEAR_TXDMA_VIQ_MAP(x) ((x) & (~BITS_TXDMA_VIQ_MAP))
#define BIT_GET_TXDMA_VIQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP) & BIT_MASK_TXDMA_VIQ_MAP)
#define BIT_SET_TXDMA_VIQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP(x) | BIT_TXDMA_VIQ_MAP(v))
#define BIT_SHIFT_TXDMA_VOQ_MAP 4
#define BIT_MASK_TXDMA_VOQ_MAP 0x3
#define BIT_TXDMA_VOQ_MAP(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP) << BIT_SHIFT_TXDMA_VOQ_MAP)
#define BITS_TXDMA_VOQ_MAP (BIT_MASK_TXDMA_VOQ_MAP << BIT_SHIFT_TXDMA_VOQ_MAP)
#define BIT_CLEAR_TXDMA_VOQ_MAP(x) ((x) & (~BITS_TXDMA_VOQ_MAP))
#define BIT_GET_TXDMA_VOQ_MAP(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP) & BIT_MASK_TXDMA_VOQ_MAP)
#define BIT_SET_TXDMA_VOQ_MAP(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP(x) | BIT_TXDMA_VOQ_MAP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_SHIFT_TXDMA_VOQ_MAP_V1 4
#define BIT_MASK_TXDMA_VOQ_MAP_V1 0x7
#define BIT_TXDMA_VOQ_MAP_V1(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP_V1) << BIT_SHIFT_TXDMA_VOQ_MAP_V1)
#define BITS_TXDMA_VOQ_MAP_V1 \
(BIT_MASK_TXDMA_VOQ_MAP_V1 << BIT_SHIFT_TXDMA_VOQ_MAP_V1)
#define BIT_CLEAR_TXDMA_VOQ_MAP_V1(x) ((x) & (~BITS_TXDMA_VOQ_MAP_V1))
#define BIT_GET_TXDMA_VOQ_MAP_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP_V1) & BIT_MASK_TXDMA_VOQ_MAP_V1)
#define BIT_SET_TXDMA_VOQ_MAP_V1(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP_V1(x) | BIT_TXDMA_VOQ_MAP_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_TXDMA_BW_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_PQ_MAP (Offset 0x010C) */
#define BIT_RXDMA_AGG_EN BIT(2)
#define BIT_RXSHFT_EN BIT(1)
#define BIT_RXDMA_ARBBW_EN BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_RXFFOVFL_RSV_V1 28
#define BIT_MASK_RXFFOVFL_RSV_V1 0xf
#define BIT_RXFFOVFL_RSV_V1(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V1) << BIT_SHIFT_RXFFOVFL_RSV_V1)
#define BITS_RXFFOVFL_RSV_V1 \
(BIT_MASK_RXFFOVFL_RSV_V1 << BIT_SHIFT_RXFFOVFL_RSV_V1)
#define BIT_CLEAR_RXFFOVFL_RSV_V1(x) ((x) & (~BITS_RXFFOVFL_RSV_V1))
#define BIT_GET_RXFFOVFL_RSV_V1(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V1) & BIT_MASK_RXFFOVFL_RSV_V1)
#define BIT_SET_RXFFOVFL_RSV_V1(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V1(x) | BIT_RXFFOVFL_RSV_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_RXFF0_BNDY 16
#define BIT_MASK_RXFF0_BNDY 0xffff
#define BIT_RXFF0_BNDY(x) (((x) & BIT_MASK_RXFF0_BNDY) << BIT_SHIFT_RXFF0_BNDY)
#define BITS_RXFF0_BNDY (BIT_MASK_RXFF0_BNDY << BIT_SHIFT_RXFF0_BNDY)
#define BIT_CLEAR_RXFF0_BNDY(x) ((x) & (~BITS_RXFF0_BNDY))
#define BIT_GET_RXFF0_BNDY(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY) & BIT_MASK_RXFF0_BNDY)
#define BIT_SET_RXFF0_BNDY(x, v) (BIT_CLEAR_RXFF0_BNDY(x) | BIT_RXFF0_BNDY(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_FWFFOVFL_RSV 16
#define BIT_MASK_FWFFOVFL_RSV 0xf
#define BIT_FWFFOVFL_RSV(x) \
(((x) & BIT_MASK_FWFFOVFL_RSV) << BIT_SHIFT_FWFFOVFL_RSV)
#define BITS_FWFFOVFL_RSV (BIT_MASK_FWFFOVFL_RSV << BIT_SHIFT_FWFFOVFL_RSV)
#define BIT_CLEAR_FWFFOVFL_RSV(x) ((x) & (~BITS_FWFFOVFL_RSV))
#define BIT_GET_FWFFOVFL_RSV(x) \
(((x) >> BIT_SHIFT_FWFFOVFL_RSV) & BIT_MASK_FWFFOVFL_RSV)
#define BIT_SET_FWFFOVFL_RSV(x, v) \
(BIT_CLEAR_FWFFOVFL_RSV(x) | BIT_FWFFOVFL_RSV(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_RXFFOVFL_RSV 8
#define BIT_MASK_RXFFOVFL_RSV 0xf
#define BIT_RXFFOVFL_RSV(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV) << BIT_SHIFT_RXFFOVFL_RSV)
#define BITS_RXFFOVFL_RSV (BIT_MASK_RXFFOVFL_RSV << BIT_SHIFT_RXFFOVFL_RSV)
#define BIT_CLEAR_RXFFOVFL_RSV(x) ((x) & (~BITS_RXFFOVFL_RSV))
#define BIT_GET_RXFFOVFL_RSV(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV) & BIT_MASK_RXFFOVFL_RSV)
#define BIT_SET_RXFFOVFL_RSV(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV(x) | BIT_RXFFOVFL_RSV(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_RXFFOVFL_RSV_V2 8
#define BIT_MASK_RXFFOVFL_RSV_V2 0xf
#define BIT_RXFFOVFL_RSV_V2(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V2) << BIT_SHIFT_RXFFOVFL_RSV_V2)
#define BITS_RXFFOVFL_RSV_V2 \
(BIT_MASK_RXFFOVFL_RSV_V2 << BIT_SHIFT_RXFFOVFL_RSV_V2)
#define BIT_CLEAR_RXFFOVFL_RSV_V2(x) ((x) & (~BITS_RXFFOVFL_RSV_V2))
#define BIT_GET_RXFFOVFL_RSV_V2(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V2) & BIT_MASK_RXFFOVFL_RSV_V2)
#define BIT_SET_RXFFOVFL_RSV_V2(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V2(x) | BIT_RXFFOVFL_RSV_V2(v))
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_RXFF0_BNDY_V1 8
#define BIT_MASK_RXFF0_BNDY_V1 0x3ffff
#define BIT_RXFF0_BNDY_V1(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V1) << BIT_SHIFT_RXFF0_BNDY_V1)
#define BITS_RXFF0_BNDY_V1 (BIT_MASK_RXFF0_BNDY_V1 << BIT_SHIFT_RXFF0_BNDY_V1)
#define BIT_CLEAR_RXFF0_BNDY_V1(x) ((x) & (~BITS_RXFF0_BNDY_V1))
#define BIT_GET_RXFF0_BNDY_V1(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V1) & BIT_MASK_RXFF0_BNDY_V1)
#define BIT_SET_RXFF0_BNDY_V1(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V1(x) | BIT_RXFF0_BNDY_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TRXFF_BNDY (Offset 0x0114) */
#define BIT_SHIFT_TXPKTBUF_PGBNDY 0
#define BIT_MASK_TXPKTBUF_PGBNDY 0xff
#define BIT_TXPKTBUF_PGBNDY(x) \
(((x) & BIT_MASK_TXPKTBUF_PGBNDY) << BIT_SHIFT_TXPKTBUF_PGBNDY)
#define BITS_TXPKTBUF_PGBNDY \
(BIT_MASK_TXPKTBUF_PGBNDY << BIT_SHIFT_TXPKTBUF_PGBNDY)
#define BIT_CLEAR_TXPKTBUF_PGBNDY(x) ((x) & (~BITS_TXPKTBUF_PGBNDY))
#define BIT_GET_TXPKTBUF_PGBNDY(x) \
(((x) >> BIT_SHIFT_TXPKTBUF_PGBNDY) & BIT_MASK_TXPKTBUF_PGBNDY)
#define BIT_SET_TXPKTBUF_PGBNDY(x, v) \
(BIT_CLEAR_TXPKTBUF_PGBNDY(x) | BIT_TXPKTBUF_PGBNDY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PTA_I2C_MBOX (Offset 0x0118) */
#define BIT_SHIFT_RESP_TXPOWER 18
#define BIT_MASK_RESP_TXPOWER 0x7
#define BIT_RESP_TXPOWER(x) \
(((x) & BIT_MASK_RESP_TXPOWER) << BIT_SHIFT_RESP_TXPOWER)
#define BITS_RESP_TXPOWER (BIT_MASK_RESP_TXPOWER << BIT_SHIFT_RESP_TXPOWER)
#define BIT_CLEAR_RESP_TXPOWER(x) ((x) & (~BITS_RESP_TXPOWER))
#define BIT_GET_RESP_TXPOWER(x) \
(((x) >> BIT_SHIFT_RESP_TXPOWER) & BIT_MASK_RESP_TXPOWER)
#define BIT_SET_RESP_TXPOWER(x, v) \
(BIT_CLEAR_RESP_TXPOWER(x) | BIT_RESP_TXPOWER(v))
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_FF_STATUS (Offset 0x0118) */
#define BIT_SHIFT_RXFF0_RDPTR_V1 13
#define BIT_MASK_RXFF0_RDPTR_V1 0x3ffff
#define BIT_RXFF0_RDPTR_V1(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V1) << BIT_SHIFT_RXFF0_RDPTR_V1)
#define BITS_RXFF0_RDPTR_V1 \
(BIT_MASK_RXFF0_RDPTR_V1 << BIT_SHIFT_RXFF0_RDPTR_V1)
#define BIT_CLEAR_RXFF0_RDPTR_V1(x) ((x) & (~BITS_RXFF0_RDPTR_V1))
#define BIT_GET_RXFF0_RDPTR_V1(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V1) & BIT_MASK_RXFF0_RDPTR_V1)
#define BIT_SET_RXFF0_RDPTR_V1(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V1(x) | BIT_RXFF0_RDPTR_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PTA_I2C_MBOX (Offset 0x0118) */
#define BIT_SHIFT_I2C_M_STATUS 8
#define BIT_MASK_I2C_M_STATUS 0xf
#define BIT_I2C_M_STATUS(x) \
(((x) & BIT_MASK_I2C_M_STATUS) << BIT_SHIFT_I2C_M_STATUS)
#define BITS_I2C_M_STATUS (BIT_MASK_I2C_M_STATUS << BIT_SHIFT_I2C_M_STATUS)
#define BIT_CLEAR_I2C_M_STATUS(x) ((x) & (~BITS_I2C_M_STATUS))
#define BIT_GET_I2C_M_STATUS(x) \
(((x) >> BIT_SHIFT_I2C_M_STATUS) & BIT_MASK_I2C_M_STATUS)
#define BIT_SET_I2C_M_STATUS(x, v) \
(BIT_CLEAR_I2C_M_STATUS(x) | BIT_I2C_M_STATUS(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PTA_I2C_MBOX (Offset 0x0118) */
#define BIT_SHIFT_I2C_M_BUS_GNT 4
#define BIT_MASK_I2C_M_BUS_GNT 0x7
#define BIT_I2C_M_BUS_GNT(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT) << BIT_SHIFT_I2C_M_BUS_GNT)
#define BITS_I2C_M_BUS_GNT (BIT_MASK_I2C_M_BUS_GNT << BIT_SHIFT_I2C_M_BUS_GNT)
#define BIT_CLEAR_I2C_M_BUS_GNT(x) ((x) & (~BITS_I2C_M_BUS_GNT))
#define BIT_GET_I2C_M_BUS_GNT(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT) & BIT_MASK_I2C_M_BUS_GNT)
#define BIT_SET_I2C_M_BUS_GNT(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT(x) | BIT_I2C_M_BUS_GNT(v))
#define BIT_I2C_GNT_FW BIT(3)
#define BIT_SHIFT_I2C_DATA_RATE 1
#define BIT_MASK_I2C_DATA_RATE 0x3
#define BIT_I2C_DATA_RATE(x) \
(((x) & BIT_MASK_I2C_DATA_RATE) << BIT_SHIFT_I2C_DATA_RATE)
#define BITS_I2C_DATA_RATE (BIT_MASK_I2C_DATA_RATE << BIT_SHIFT_I2C_DATA_RATE)
#define BIT_CLEAR_I2C_DATA_RATE(x) ((x) & (~BITS_I2C_DATA_RATE))
#define BIT_GET_I2C_DATA_RATE(x) \
(((x) >> BIT_SHIFT_I2C_DATA_RATE) & BIT_MASK_I2C_DATA_RATE)
#define BIT_SET_I2C_DATA_RATE(x, v) \
(BIT_CLEAR_I2C_DATA_RATE(x) | BIT_I2C_DATA_RATE(v))
#define BIT_I2C_SW_CONTROL_UNLOCK BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT)
/* 2 REG_FF_STATUS (Offset 0x0118) */
#define BIT_SHIFT_RXFF0_WTPTR_V1 0
#define BIT_MASK_RXFF0_WTPTR_V1 0x3ffff
#define BIT_RXFF0_WTPTR_V1(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V1) << BIT_SHIFT_RXFF0_WTPTR_V1)
#define BITS_RXFF0_WTPTR_V1 \
(BIT_MASK_RXFF0_WTPTR_V1 << BIT_SHIFT_RXFF0_WTPTR_V1)
#define BIT_CLEAR_RXFF0_WTPTR_V1(x) ((x) & (~BITS_RXFF0_WTPTR_V1))
#define BIT_GET_RXFF0_WTPTR_V1(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V1) & BIT_MASK_RXFF0_WTPTR_V1)
#define BIT_SET_RXFF0_WTPTR_V1(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V1(x) | BIT_RXFF0_WTPTR_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXFF_PTR (Offset 0x011C) */
#define BIT_SHIFT_RXFF0_RDPTR 16
#define BIT_MASK_RXFF0_RDPTR 0xffff
#define BIT_RXFF0_RDPTR(x) \
(((x) & BIT_MASK_RXFF0_RDPTR) << BIT_SHIFT_RXFF0_RDPTR)
#define BITS_RXFF0_RDPTR (BIT_MASK_RXFF0_RDPTR << BIT_SHIFT_RXFF0_RDPTR)
#define BIT_CLEAR_RXFF0_RDPTR(x) ((x) & (~BITS_RXFF0_RDPTR))
#define BIT_GET_RXFF0_RDPTR(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR) & BIT_MASK_RXFF0_RDPTR)
#define BIT_SET_RXFF0_RDPTR(x, v) \
(BIT_CLEAR_RXFF0_RDPTR(x) | BIT_RXFF0_RDPTR(v))
#define BIT_SHIFT_RXFF0_WTPTR 0
#define BIT_MASK_RXFF0_WTPTR 0xffff
#define BIT_RXFF0_WTPTR(x) \
(((x) & BIT_MASK_RXFF0_WTPTR) << BIT_SHIFT_RXFF0_WTPTR)
#define BITS_RXFF0_WTPTR (BIT_MASK_RXFF0_WTPTR << BIT_SHIFT_RXFF0_WTPTR)
#define BIT_CLEAR_RXFF0_WTPTR(x) ((x) & (~BITS_RXFF0_WTPTR))
#define BIT_GET_RXFF0_WTPTR(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR) & BIT_MASK_RXFF0_WTPTR)
#define BIT_SET_RXFF0_WTPTR(x, v) \
(BIT_CLEAR_RXFF0_WTPTR(x) | BIT_RXFF0_WTPTR(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_H2C_OK_INT_MSK BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_SW_PLL_LEAVE_32K_INT_EN BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_CPUMGQ_DROP_BY_HOLD_TIME_INT_EN BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_H2C_CMD_FULL_INT_MSK BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_FWFF_FULL_INT_EN BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FWFF_FULL_INT_EN BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PWR_INT_127_MSK_V1 BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_BB_STOP_RX_INT_EN BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_BB_STOP_RX_INT_EN BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PWR_INT_126_MSK BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RXDMA2_DONE_INT_EN BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PWR_INT_125TO96_MSK BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RXDONE3_INT_EN BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PWR_INT_95TO64_MSK_V1 BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RXDONE2_INT_EN BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PWR_INT_63TO32_MSK_V1 BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_BCN_P4_INT_EN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PWR_INT_31TO0_MSK_V1 BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_BCN_P3_INT_EN BIT(24)
#define BIT_FS_RX_BCN_P2_INT_EN BIT(23)
#define BIT_FS_RX_BCN_P1_INT_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_BF0_TIMEOUT_INT_MSK BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_BCN_P0_INT_EN BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_BF1_TIMEOUT_INT_MSK BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_UMD0_INT_EN BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_EVTQ_TXDONE_INT_MSK BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_UMD1_INT_EN BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_EVTQ_START_INT_MSK BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_BMD0_INT_EN BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_TXBCN2_OK_INT_MSK BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RX_BMD1_INT_EN BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_TXBCN2_ERR_INT_MSK BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RXDONE_INT_EN BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_DWWIN_END_INT_MSK BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_WWLAN_INT_EN BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_BCN2_EARLY_INT_MSK BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_SOUND_DONE_INT_EN BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_TBTT1_INT_MSK BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_LP_STBY_INT_EN BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PSTIMERB_INT_MSK BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_TRL_MTR_INT_EN BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_PSTIMERA_INT_MSK BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_BF1_PRETO_INT_EN BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_P2P_RFOFF_EARLY_INT_MSK BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_BF0_PRETO_INT_EN BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_MACID_RELEASE_INT_MSK BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_PTCL_RELEASE_MACID_INT_EN BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_NANRPT_DONE_INT_MSK BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_PRETXERR_HANDLE_FSIMR BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_PRETX_ERRHLD_INT_EN BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_PRETX_ERRHLD_INT_EN BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_FTM_PTT_INT_MSK_V1 BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_GTRD_INT_EN BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_RXFTMREQ_OK_INT_MSK BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_LTE_COEX_EN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_RXFTM_INT_MSK_V1 BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_WLACTOFF_INT_EN BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_TXFTM_INT_MSK_V1 BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_WLACTON_INT_EN BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_LTECOEX_INT_MSK BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_BTCMD_INT_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_REG_MAILBOX_TO_I2C_INT BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_MAILBOX_INT_MSK BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_REG_MAILBOX_TO_I2C_INT_EN BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_TRPC_TO_INT_EN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_FLC_DRUTO_INT_MSK BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_TRPC_TO_INT_EN_V1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_BIT_RPC_O_T_INT_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEIMR (Offset 0x0120) */
#define BIT_FLC_PKTTH_INT_MSK BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1IMR (Offset 0x0120) */
#define BIT_FS_RPC_O_T_INT_EN_V1 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_H2C_OK_INT BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_SW_PLL_LEAVE_32K_INT BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_CPUMGQ_DROP_BY_HOLD_TIME_INT BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_H2C_CMD_FULL_INT BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_FS_FWFF_FULL_INT BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FWFF_FULL_INT BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PWR_INT_127_V2 BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_BB_STOP_RX_INT BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_BB_STOP_RX_INT BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PWR_INT_126 BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RXDMA2_DONE_INT BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PWR_INT_125TO96 BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RXDONE3_INT BIT(27)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RXDONE3_INT_INT BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PWR_INT_95TO64_V1 BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RXDONE2_INT BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PWR_INT_63TO32_V1 BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RX_BCN_P4_INT BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PWR_INT_31TO0_V1 BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RX_BCN_P3_INT BIT(24)
#define BIT_FS_RX_BCN_P2_INT BIT(23)
#define BIT_FS_RX_BCN_P1_INT BIT(22)
#define BIT_FS_RX_BCN_P0_INT BIT(21)
#define BIT_FS_RX_UMD0_INT BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_EVTQ_TXDONE_INT BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RX_UMD1_INT BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_EVTQ_START_INT BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RX_BMD0_INT BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_TXBCN2_OK_INT BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RX_BMD1_INT BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_TXBCN2_ERR_INT BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RXDONE_INT BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_DWWIN_END_INT BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_WWLAN_INT BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_BCN2_EARLY_INT BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_SOUND_DONE_INT BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_TBTT1_INT BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_LP_STBY_INT BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PSTIMERB_INT BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_TRL_MTR_INT BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_PSTIMERA_INT BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_BF1_PRETO_INT BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_P2P_RFOFF_EARLY_INT BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_BF0_PRETO_INT BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_MACID_RELEASE_INT BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_PTCL_RELEASE_MACID_INT BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_NANRPT_DONE_INT BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_PRETXERR_HANDLE_FSISR BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_PRETX_ERRHLD_INT BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_PRETX_ERRHLD_INT BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_FTM_PTT_INT_V1 BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_SND_RDY_INT BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_RXFTMREQ_OK_INT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_LTE_COEX_INT BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_RXFTM_INT_V1 BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_WLACTOFF_INT BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_TXFTM_INT_V1 BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_WLACTON_INT BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_LTECOEX_INT BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_BCN_RX_INT_INT BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_BT_CMD_INT BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_MAILBOX_TO_I2C BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_MAILBOX_INT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_MAILBOX_TO_I2C_INT BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_TRPC_TO_INT BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_FLC_DRUTO_INT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_TRPC_TO_INT BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_RPC_O_T_INT BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FEISR (Offset 0x0124) */
#define BIT_FLC_PKTTH_INT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE1ISR (Offset 0x0124) */
#define BIT_FS_RPC_O_T_INT BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CPWM (Offset 0x012C) */
#define BIT_CPWM_TOGGLING BIT(31)
#define BIT_SHIFT_CPWM_MOD 24
#define BIT_MASK_CPWM_MOD 0x7f
#define BIT_CPWM_MOD(x) (((x) & BIT_MASK_CPWM_MOD) << BIT_SHIFT_CPWM_MOD)
#define BITS_CPWM_MOD (BIT_MASK_CPWM_MOD << BIT_SHIFT_CPWM_MOD)
#define BIT_CLEAR_CPWM_MOD(x) ((x) & (~BITS_CPWM_MOD))
#define BIT_GET_CPWM_MOD(x) (((x) >> BIT_SHIFT_CPWM_MOD) & BIT_MASK_CPWM_MOD)
#define BIT_SET_CPWM_MOD(x, v) (BIT_CLEAR_CPWM_MOD(x) | BIT_CPWM_MOD(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_PCIE_BCNDMAERR_INT_MSK BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB7_INT_EN BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_SOUND_DONE_MSK BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_SOUND_DONE_INT_MSK BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB6_INT_EN BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TRY_DONE_MSK BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TRY_DONE_INT_MSK BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB5_INT_EN BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXRPT_CNT_FULL_MSK BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXRPT_CNT_FULL_INT_MSK BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB4_INT_EN BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_WLACTOFF_INT_EN BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_WLACTOFF_INT_MSK BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB3_INT_EN BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_WLACTON_INT_EN BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_WLACTON_INT_MSK BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB2_INT_EN BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXPKTIN_INT_EN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXPKTIN_INT_MSK BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB1_INT_EN BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXBCNOK_MSK BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXBCNOK_INT_MSK BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNOK_MB0_INT_EN BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXBCNERR_MSK BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXBCNERR_INT_MSK BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB7_INT_EN BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_UMD0_EN BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_UMD0_INT_MSK BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB6_INT_EN BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_UMD1_EN BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_UMD1_INT_MSK BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB5_INT_EN BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_BMD0_EN BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_BMD0_INT_MSK BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB4_INT_EN BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_BMD1_EN BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RX_BMD1_INT_MSK BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB3_INT_EN BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCN_RX_INT_EN BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCN_RX_INT_INT_MSK BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB2_INT_EN BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TBTTINT_MSK BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TBTTINT_INT_MSK BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB1_INT_EN BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNERLY_MSK BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNERLY_INT_MSK BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXBCNERR_MB0_INT_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA7_MSK BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA7_INT_MSK BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_CPUMGN_POLLED_PKT_DONE_INT_EN BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_CPU_MGQ_TXDONE_INT_EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA6_MSK BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA6_INT_MSK BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_SIFS_OVERSPEC_INT_EN BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA5_MSK BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA5_INT_MSK BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_EN BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA4_MSK BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA4_INT_MSK BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_MGNTQFF_TO_INT_EN BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA3_MSK BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA3_INT_MSK BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_DDMA1_LP_INT_ENBIT_CPUMGN_POLLED_PKT_BUSY_ERR_INT_EN BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_CPUMGQ_ERR_INT_EN BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_DDMA1_LP_INT_EN BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA2_MSK BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA2_INT_MSK BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_DDMA1_HP_INT_EN BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA1_MSK BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA1_INT_MSK BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_DDMA0_LP_INT_EN BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA0_MSK BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_BCNDMA0_INT_MSK BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_DDMA0_HP_INT_EN BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_LP_STBY_MSK BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_LP_STBY_INT_MSK BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TRXRPT_INT_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_CTWENDINT_MSK BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_CTWENDINT_INT_MSK BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_C2H_W_READY_INT_EN BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_HRCV_MSK BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_HRCV_INT_MSK BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_HRCV_INT_EN BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_H2CCMD_MSK BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_H2CCMD_INT_MSK BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_H2CCMD_INT_EN BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RXDONE_MSK BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_RXDONE_INT_MSK BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXPKTIN_INT_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_ERRORHDL_MSK BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_ERRORHDL_INT_MSK BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_ERRORHDL_INT_EN BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXCCX_MSK_FW BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXCCX_INT_MSK BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXCCX_INT_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXCLOSE_MSK BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_TXCLOSE_INT_MSK BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWIMR (Offset 0x0130) */
#define BIT_FS_TXCLOSE_INT_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_PCIE_BCNDMAERR_INT BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB7_INT BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_SOUND_DONE_INT BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB6_INT BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TRY_DONE_INT BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB5_INT BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TXRPT_CNT_FULL_INT BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB4_INT BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_WLACTOFF_INT BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB3_INT BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_WLACTON_INT BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB2_INT BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TXPKTIN_INT BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB1_INT BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TXBCNOK_INT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNOK_MB0_INT BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TXBCNERR_INT BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB7_INT BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_RX_UMD0_INT BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB6_INT BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_RX_UMD1_INT BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB5_INT BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_RX_BMD0_INT BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB4_INT BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_RX_BMD1_INT BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB3_INT BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCN_RX_INT_INT BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB2_INT BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TBTTINT_INT BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB1_INT BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNERLY_INT BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXBCNERR_MB0_INT BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA7_INT BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_CPUMGN_POLLED_PKT_DONE_INT BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_CPU_MGQ_TXDONE_INT BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA6_INT BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_SIFS_OVERSPEC_INT BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA5_INT BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA4_INT BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_MGNTQFF_TO_INT BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA3_INT BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_DDMA1_LP_INTBIT_CPUMGN_POLLED_PKT_BUSY_ERR_INT BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_CPUMGQ_ERR_INT BIT(11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_DDMA1_LP_INT BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA2_INT BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_DDMA1_HP_INT BIT(10)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FWCMD_PKTIN_INT BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA1_INT BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_DDMA0_LP_INT BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_BCNDMA0_INT BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_DDMA0_HP_INT BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_LP_STBY_INT BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TRXRPT_INT BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_CTWENDINT_INT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_C2H_W_READY_INT BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_HRCV_INT BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_HRCV_INT BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_H2CCMD_INT BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_H2CCMD_INT BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_RXDONE_INT BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXPKTIN_INT BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_ERRORHDL_INT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_ERRORHDL_INT BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TXCCX_INT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXCCX_INT BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_TXCLOSE_INT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWISR (Offset 0x0134) */
#define BIT_FS_TXCLOSE_INT BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GTINT6_MSK BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GT6INT_MSK BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TX_NULL1_INT_MSK BIT(30)
#define BIT_TX_NULL0_INT_MSK BIT(29)
#define BIT_MTI_BCNIVLEAR_INT_MSK BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_ATIMINT_MSK BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_ATIM_INT_MSK BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_WWLAN_INT_EN BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_WWLAN_INT_MSK BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_C2H_W_READY_EN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_C2H_W_READY_MSK BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TRL_MTR_EN BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TRL_MTR_INT_MSK BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_CLR_PS_STATUS_MSK BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PS_TIMER_C_EARLY_INT_EN BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RETRIEVE_BUFFERED_MSK BIT(22)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RETRIEVE_BUFFERED_INT_MSK BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PS_TIMER_B_EARLY_INT_EN BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RPWMINT2_MSK BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RPWM2INT_MSK BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PS_TIMER_A_EARLY_INT_EN BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TSF_BIT32_TOGGLE_MSK_V1 BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TSF_BIT32_TOGGLE_INT_MSK BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_EN BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TRIGGER_PKT_MSK BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PS_TIMER_C_INT_EN BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FW_BTCMD_INTMSK BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FW_BTCMD_INT_MSK BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PS_TIMER_B_INT_EN BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_P2P_RFOFF_INTMSK BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_P2P_RFOFF_INT_MSK BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PS_TIMER_A_INT_EN BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_P2P_RFON_INTMSK BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_P2P_RFON_INT_MSK BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_CPUMGQ_TX_TIMER_INT_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TXBCN1ERR_MSK BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TX_BCN1ERR_INT_MSK BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_PS_TIMEOUT2_EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TXBCN1OK_MSK BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TX_BCN1OK_INT_MSK BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_PS_TIMEOUT1_EN BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FT_ATIMEND_EMSK BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FT_ATIMEND_E_MSK BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_PS_TIMEOUT0_EN BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_BCNDMAINT_EMSK BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_BCNDMAINT_E_MSK_V1 BIT(12)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT12_EN BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GTINT5_MSK BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GT5INT_MSK BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT11_EN BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_EOSP_INT_MSK BIT(10)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT10_EN BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RX_BCN_E_MSK BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RX_BCN_E_INT_MSK BIT(9)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT9_EN BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RPWM_INT_EN BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_RPWMINT_MSK BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT8_EN BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PSTIMER_MSK BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_PSTIMER_INT_MSK BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT7_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TIMEOUT1_MSK BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TIMEOUT1_INT_MSK BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT6_EN BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TIMEOUT0_MSK BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_TIMEOUT0_INT_MSK BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT5_EN BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FT_GTINT4_MSK BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FT_GT4INT_MSK BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT4_EN BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FT_GTINT3_MSK BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FT_GT3INT_MSK BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT3_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GTINT2_MSK BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GT2INT_MSK BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT2_EN BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GTINT1_MSK BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GT1INT_MSK BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT1_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GTINT0_MSK BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_GT0INT_MSK BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTIMR (Offset 0x0138) */
#define BIT_FS_GTINT0_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_GT6INT BIT(31)
#define BIT_TX_NULL1_INT BIT(30)
#define BIT_TX_NULL0_INT BIT(29)
#define BIT_MTI_BCNIVLEAR_INT BIT(28)
#define BIT_ATIM_INT BIT(27)
#define BIT_WWLAN_INT BIT(26)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_5_EARLY__INT BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_C2H_W_READY BIT(25)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_4_EARLY__INT BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TRL_MTR_INT BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_3_EARLY__INT BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_CLR_PS_STATUS BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_C_EARLY__INT BIT(23)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_2_EARLY__INT BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_RETRIEVE_BUFFERED_INT BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_B_EARLY__INT BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_1_EARLY__INT BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_RPWM2INT BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_A_EARLY__INT BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_0_EARLY__INT BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TSF_BIT32_TOGGLE_INT_V1 BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TRIGGER_PKT BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_C_INT BIT(19)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_5_INT BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FW_BTCMD_INT BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_B_INT BIT(18)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_4_INT BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_P2P_RFOFF_INT BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_A_INT BIT(17)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_3_INT BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_P2P_RFON_INT BIT(16)
#define BIT_SHIFT_LLTINI_PDATA 16
#define BIT_MASK_LLTINI_PDATA 0xff
#define BIT_LLTINI_PDATA(x) \
(((x) & BIT_MASK_LLTINI_PDATA) << BIT_SHIFT_LLTINI_PDATA)
#define BITS_LLTINI_PDATA (BIT_MASK_LLTINI_PDATA << BIT_SHIFT_LLTINI_PDATA)
#define BIT_CLEAR_LLTINI_PDATA(x) ((x) & (~BITS_LLTINI_PDATA))
#define BIT_GET_LLTINI_PDATA(x) \
(((x) >> BIT_SHIFT_LLTINI_PDATA) & BIT_MASK_LLTINI_PDATA)
#define BIT_SET_LLTINI_PDATA(x, v) \
(BIT_CLEAR_LLTINI_PDATA(x) | BIT_LLTINI_PDATA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_CPUMGQ_TX_TIMER_INT BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TX_BCN1ERR_INT BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_PS_TIMEOUT2_INT BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_2_INT BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TX_BCN1OK_INT BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_PS_TIMEOUT1_INT BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_1_INT BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FT_ATIMEND_E BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_PS_TIMEOUT0_INT BIT(13)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PS_TIMER_0_INT BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_BCNDMAINT_E_V1 BIT(12)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT12_INT BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_GT5INT BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT11_INT BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_EOSP_INT BIT(10)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT10_INT BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_RX_BCN_E_INT BIT(9)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT9_INT BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_RPWMINT BIT(8)
#define BIT_SHIFT_LLTINI_ADDR 8
#define BIT_MASK_LLTINI_ADDR 0xff
#define BIT_LLTINI_ADDR(x) \
(((x) & BIT_MASK_LLTINI_ADDR) << BIT_SHIFT_LLTINI_ADDR)
#define BITS_LLTINI_ADDR (BIT_MASK_LLTINI_ADDR << BIT_SHIFT_LLTINI_ADDR)
#define BIT_CLEAR_LLTINI_ADDR(x) ((x) & (~BITS_LLTINI_ADDR))
#define BIT_GET_LLTINI_ADDR(x) \
(((x) >> BIT_SHIFT_LLTINI_ADDR) & BIT_MASK_LLTINI_ADDR)
#define BIT_SET_LLTINI_ADDR(x, v) \
(BIT_CLEAR_LLTINI_ADDR(x) | BIT_LLTINI_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT8_INT BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_PSTIMER_INT BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT7_INT BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TIMEOUT1_INT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT6_INT BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_TIMEOUT0_INT BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT5_INT BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FT_GT4INT BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT4_INT BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FT_GT3INT BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT3_INT BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_GT2INT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT2_INT BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_GT1INT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT1_INT BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_GT0INT BIT(0)
#define BIT_SHIFT_LLTINI_HDATA 0
#define BIT_MASK_LLTINI_HDATA 0xff
#define BIT_LLTINI_HDATA(x) \
(((x) & BIT_MASK_LLTINI_HDATA) << BIT_SHIFT_LLTINI_HDATA)
#define BITS_LLTINI_HDATA (BIT_MASK_LLTINI_HDATA << BIT_SHIFT_LLTINI_HDATA)
#define BIT_CLEAR_LLTINI_HDATA(x) ((x) & (~BITS_LLTINI_HDATA))
#define BIT_GET_LLTINI_HDATA(x) \
(((x) >> BIT_SHIFT_LLTINI_HDATA) & BIT_MASK_LLTINI_HDATA)
#define BIT_SET_LLTINI_HDATA(x, v) \
(BIT_CLEAR_LLTINI_HDATA(x) | BIT_LLTINI_HDATA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FTISR (Offset 0x013C) */
#define BIT_FS_GTINT0_INT BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_SHIFT_PKTBUF_WRITE_EN 24
#define BIT_MASK_PKTBUF_WRITE_EN 0xff
#define BIT_PKTBUF_WRITE_EN(x) \
(((x) & BIT_MASK_PKTBUF_WRITE_EN) << BIT_SHIFT_PKTBUF_WRITE_EN)
#define BITS_PKTBUF_WRITE_EN \
(BIT_MASK_PKTBUF_WRITE_EN << BIT_SHIFT_PKTBUF_WRITE_EN)
#define BIT_CLEAR_PKTBUF_WRITE_EN(x) ((x) & (~BITS_PKTBUF_WRITE_EN))
#define BIT_GET_PKTBUF_WRITE_EN(x) \
(((x) >> BIT_SHIFT_PKTBUF_WRITE_EN) & BIT_MASK_PKTBUF_WRITE_EN)
#define BIT_SET_PKTBUF_WRITE_EN(x, v) \
(BIT_CLEAR_PKTBUF_WRITE_EN(x) | BIT_PKTBUF_WRITE_EN(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_TXPKT_BUF_READ_EN BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_TXPKTBUF_DBG BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_TXRPTBUF_DBG BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_TXRPT_BUF_READ_EN BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_TXRPTBUF_DBG_V2 BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_TXPKTBUF_DBG_V2 BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PKTBUF_DBG_CTRL (Offset 0x0140) */
#define BIT_RXPKT_BUF_READ_EN BIT(16)
#define BIT_SHIFT_PKTBUF_ADDR 0
#define BIT_MASK_PKTBUF_ADDR 0x1fff
#define BIT_PKTBUF_ADDR(x) \
(((x) & BIT_MASK_PKTBUF_ADDR) << BIT_SHIFT_PKTBUF_ADDR)
#define BITS_PKTBUF_ADDR (BIT_MASK_PKTBUF_ADDR << BIT_SHIFT_PKTBUF_ADDR)
#define BIT_CLEAR_PKTBUF_ADDR(x) ((x) & (~BITS_PKTBUF_ADDR))
#define BIT_GET_PKTBUF_ADDR(x) \
(((x) >> BIT_SHIFT_PKTBUF_ADDR) & BIT_MASK_PKTBUF_ADDR)
#define BIT_SET_PKTBUF_ADDR(x, v) \
(BIT_CLEAR_PKTBUF_ADDR(x) | BIT_PKTBUF_ADDR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PKTBUF_DBG_DATA_L (Offset 0x0144) */
#define BIT_SHIFT_PKTBUF_DBG_DATA_L 0
#define BIT_MASK_PKTBUF_DBG_DATA_L 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_L(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_L) << BIT_SHIFT_PKTBUF_DBG_DATA_L)
#define BITS_PKTBUF_DBG_DATA_L \
(BIT_MASK_PKTBUF_DBG_DATA_L << BIT_SHIFT_PKTBUF_DBG_DATA_L)
#define BIT_CLEAR_PKTBUF_DBG_DATA_L(x) ((x) & (~BITS_PKTBUF_DBG_DATA_L))
#define BIT_GET_PKTBUF_DBG_DATA_L(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_L) & BIT_MASK_PKTBUF_DBG_DATA_L)
#define BIT_SET_PKTBUF_DBG_DATA_L(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_L(x) | BIT_PKTBUF_DBG_DATA_L(v))
/* 2 REG_PKTBUF_DBG_DATA_H (Offset 0x0148) */
#define BIT_SHIFT_PKTBUF_DBG_DATA_H 0
#define BIT_MASK_PKTBUF_DBG_DATA_H 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_H(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_H) << BIT_SHIFT_PKTBUF_DBG_DATA_H)
#define BITS_PKTBUF_DBG_DATA_H \
(BIT_MASK_PKTBUF_DBG_DATA_H << BIT_SHIFT_PKTBUF_DBG_DATA_H)
#define BIT_CLEAR_PKTBUF_DBG_DATA_H(x) ((x) & (~BITS_PKTBUF_DBG_DATA_H))
#define BIT_GET_PKTBUF_DBG_DATA_H(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_H) & BIT_MASK_PKTBUF_DBG_DATA_H)
#define BIT_SET_PKTBUF_DBG_DATA_H(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_H(x) | BIT_PKTBUF_DBG_DATA_H(v))
/* 2 REG_CPWM2 (Offset 0x014C) */
#define BIT_SHIFT_L0S_TO_RCVY_NUM 16
#define BIT_MASK_L0S_TO_RCVY_NUM 0xff
#define BIT_L0S_TO_RCVY_NUM(x) \
(((x) & BIT_MASK_L0S_TO_RCVY_NUM) << BIT_SHIFT_L0S_TO_RCVY_NUM)
#define BITS_L0S_TO_RCVY_NUM \
(BIT_MASK_L0S_TO_RCVY_NUM << BIT_SHIFT_L0S_TO_RCVY_NUM)
#define BIT_CLEAR_L0S_TO_RCVY_NUM(x) ((x) & (~BITS_L0S_TO_RCVY_NUM))
#define BIT_GET_L0S_TO_RCVY_NUM(x) \
(((x) >> BIT_SHIFT_L0S_TO_RCVY_NUM) & BIT_MASK_L0S_TO_RCVY_NUM)
#define BIT_SET_L0S_TO_RCVY_NUM(x, v) \
(BIT_CLEAR_L0S_TO_RCVY_NUM(x) | BIT_L0S_TO_RCVY_NUM(v))
#define BIT_CPWM2_TOGGLING BIT(15)
#define BIT_SHIFT_CPWM2_MOD 0
#define BIT_MASK_CPWM2_MOD 0x7fff
#define BIT_CPWM2_MOD(x) (((x) & BIT_MASK_CPWM2_MOD) << BIT_SHIFT_CPWM2_MOD)
#define BITS_CPWM2_MOD (BIT_MASK_CPWM2_MOD << BIT_SHIFT_CPWM2_MOD)
#define BIT_CLEAR_CPWM2_MOD(x) ((x) & (~BITS_CPWM2_MOD))
#define BIT_GET_CPWM2_MOD(x) (((x) >> BIT_SHIFT_CPWM2_MOD) & BIT_MASK_CPWM2_MOD)
#define BIT_SET_CPWM2_MOD(x, v) (BIT_CLEAR_CPWM2_MOD(x) | BIT_CPWM2_MOD(v))
/* 2 REG_TC0_CTRL (Offset 0x0150) */
#define BIT_TC0INT_EN BIT(26)
#define BIT_TC0MODE BIT(25)
#define BIT_TC0EN BIT(24)
#define BIT_SHIFT_TC0DATA 0
#define BIT_MASK_TC0DATA 0xffffff
#define BIT_TC0DATA(x) (((x) & BIT_MASK_TC0DATA) << BIT_SHIFT_TC0DATA)
#define BITS_TC0DATA (BIT_MASK_TC0DATA << BIT_SHIFT_TC0DATA)
#define BIT_CLEAR_TC0DATA(x) ((x) & (~BITS_TC0DATA))
#define BIT_GET_TC0DATA(x) (((x) >> BIT_SHIFT_TC0DATA) & BIT_MASK_TC0DATA)
#define BIT_SET_TC0DATA(x, v) (BIT_CLEAR_TC0DATA(x) | BIT_TC0DATA(v))
/* 2 REG_TC1_CTRL (Offset 0x0154) */
#define BIT_TC1INT_EN BIT(26)
#define BIT_TC1MODE BIT(25)
#define BIT_TC1EN BIT(24)
#define BIT_SHIFT_TC1DATA 0
#define BIT_MASK_TC1DATA 0xffffff
#define BIT_TC1DATA(x) (((x) & BIT_MASK_TC1DATA) << BIT_SHIFT_TC1DATA)
#define BITS_TC1DATA (BIT_MASK_TC1DATA << BIT_SHIFT_TC1DATA)
#define BIT_CLEAR_TC1DATA(x) ((x) & (~BITS_TC1DATA))
#define BIT_GET_TC1DATA(x) (((x) >> BIT_SHIFT_TC1DATA) & BIT_MASK_TC1DATA)
#define BIT_SET_TC1DATA(x, v) (BIT_CLEAR_TC1DATA(x) | BIT_TC1DATA(v))
/* 2 REG_TC2_CTRL (Offset 0x0158) */
#define BIT_TC2INT_EN BIT(26)
#define BIT_TC2MODE BIT(25)
#define BIT_TC2EN BIT(24)
#define BIT_SHIFT_TC2DATA 0
#define BIT_MASK_TC2DATA 0xffffff
#define BIT_TC2DATA(x) (((x) & BIT_MASK_TC2DATA) << BIT_SHIFT_TC2DATA)
#define BITS_TC2DATA (BIT_MASK_TC2DATA << BIT_SHIFT_TC2DATA)
#define BIT_CLEAR_TC2DATA(x) ((x) & (~BITS_TC2DATA))
#define BIT_GET_TC2DATA(x) (((x) >> BIT_SHIFT_TC2DATA) & BIT_MASK_TC2DATA)
#define BIT_SET_TC2DATA(x, v) (BIT_CLEAR_TC2DATA(x) | BIT_TC2DATA(v))
/* 2 REG_TC3_CTRL (Offset 0x015C) */
#define BIT_TC3INT_EN BIT(26)
#define BIT_TC3MODE BIT(25)
#define BIT_TC3EN BIT(24)
#define BIT_SHIFT_TC3DATA 0
#define BIT_MASK_TC3DATA 0xffffff
#define BIT_TC3DATA(x) (((x) & BIT_MASK_TC3DATA) << BIT_SHIFT_TC3DATA)
#define BITS_TC3DATA (BIT_MASK_TC3DATA << BIT_SHIFT_TC3DATA)
#define BIT_CLEAR_TC3DATA(x) ((x) & (~BITS_TC3DATA))
#define BIT_GET_TC3DATA(x) (((x) >> BIT_SHIFT_TC3DATA) & BIT_MASK_TC3DATA)
#define BIT_SET_TC3DATA(x, v) (BIT_CLEAR_TC3DATA(x) | BIT_TC3DATA(v))
/* 2 REG_TC4_CTRL (Offset 0x0160) */
#define BIT_TC4INT_EN BIT(26)
#define BIT_TC4MODE BIT(25)
#define BIT_TC4EN BIT(24)
#define BIT_SHIFT_TC4DATA 0
#define BIT_MASK_TC4DATA 0xffffff
#define BIT_TC4DATA(x) (((x) & BIT_MASK_TC4DATA) << BIT_SHIFT_TC4DATA)
#define BITS_TC4DATA (BIT_MASK_TC4DATA << BIT_SHIFT_TC4DATA)
#define BIT_CLEAR_TC4DATA(x) ((x) & (~BITS_TC4DATA))
#define BIT_GET_TC4DATA(x) (((x) >> BIT_SHIFT_TC4DATA) & BIT_MASK_TC4DATA)
#define BIT_SET_TC4DATA(x, v) (BIT_CLEAR_TC4DATA(x) | BIT_TC4DATA(v))
/* 2 REG_TCUNIT_BASE (Offset 0x0164) */
#define BIT_SHIFT_TCUNIT_BASE 0
#define BIT_MASK_TCUNIT_BASE 0x3fff
#define BIT_TCUNIT_BASE(x) \
(((x) & BIT_MASK_TCUNIT_BASE) << BIT_SHIFT_TCUNIT_BASE)
#define BITS_TCUNIT_BASE (BIT_MASK_TCUNIT_BASE << BIT_SHIFT_TCUNIT_BASE)
#define BIT_CLEAR_TCUNIT_BASE(x) ((x) & (~BITS_TCUNIT_BASE))
#define BIT_GET_TCUNIT_BASE(x) \
(((x) >> BIT_SHIFT_TCUNIT_BASE) & BIT_MASK_TCUNIT_BASE)
#define BIT_SET_TCUNIT_BASE(x, v) \
(BIT_CLEAR_TCUNIT_BASE(x) | BIT_TCUNIT_BASE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TC5_CTRL (Offset 0x0168) */
#define BIT_TC50INT_EN BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TC5_CTRL (Offset 0x0168) */
#define BIT_TC5INT_EN BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TC5_CTRL (Offset 0x0168) */
#define BIT_TC5MODE BIT(25)
#define BIT_TC5EN BIT(24)
#define BIT_SHIFT_TC5DATA 0
#define BIT_MASK_TC5DATA 0xffffff
#define BIT_TC5DATA(x) (((x) & BIT_MASK_TC5DATA) << BIT_SHIFT_TC5DATA)
#define BITS_TC5DATA (BIT_MASK_TC5DATA << BIT_SHIFT_TC5DATA)
#define BIT_CLEAR_TC5DATA(x) ((x) & (~BITS_TC5DATA))
#define BIT_GET_TC5DATA(x) (((x) >> BIT_SHIFT_TC5DATA) & BIT_MASK_TC5DATA)
#define BIT_SET_TC5DATA(x, v) (BIT_CLEAR_TC5DATA(x) | BIT_TC5DATA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TC6_CTRL (Offset 0x016C) */
#define BIT_TC60INT_EN BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TC6_CTRL (Offset 0x016C) */
#define BIT_TC6INT_EN BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TC6_CTRL (Offset 0x016C) */
#define BIT_TC6MODE BIT(25)
#define BIT_TC6EN BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TC6_CTRL (Offset 0x016C) */
#define BIT_SHIFT_SEQNUM_MID 16
#define BIT_MASK_SEQNUM_MID 0xffff
#define BIT_SEQNUM_MID(x) (((x) & BIT_MASK_SEQNUM_MID) << BIT_SHIFT_SEQNUM_MID)
#define BITS_SEQNUM_MID (BIT_MASK_SEQNUM_MID << BIT_SHIFT_SEQNUM_MID)
#define BIT_CLEAR_SEQNUM_MID(x) ((x) & (~BITS_SEQNUM_MID))
#define BIT_GET_SEQNUM_MID(x) \
(((x) >> BIT_SHIFT_SEQNUM_MID) & BIT_MASK_SEQNUM_MID)
#define BIT_SET_SEQNUM_MID(x, v) (BIT_CLEAR_SEQNUM_MID(x) | BIT_SEQNUM_MID(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TC6_CTRL (Offset 0x016C) */
#define BIT_SHIFT_TC6DATA 0
#define BIT_MASK_TC6DATA 0xffffff
#define BIT_TC6DATA(x) (((x) & BIT_MASK_TC6DATA) << BIT_SHIFT_TC6DATA)
#define BITS_TC6DATA (BIT_MASK_TC6DATA << BIT_SHIFT_TC6DATA)
#define BIT_CLEAR_TC6DATA(x) ((x) & (~BITS_TC6DATA))
#define BIT_GET_TC6DATA(x) (((x) >> BIT_SHIFT_TC6DATA) & BIT_MASK_TC6DATA)
#define BIT_SET_TC6DATA(x, v) (BIT_CLEAR_TC6DATA(x) | BIT_TC6DATA(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_DRF_FAIL (Offset 0x0170) */
#define BIT_SHIFT_WLON_MBIST_DRF_FAIL 30
#define BIT_MASK_WLON_MBIST_DRF_FAIL 0x3
#define BIT_WLON_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_WLON_MBIST_DRF_FAIL) << BIT_SHIFT_WLON_MBIST_DRF_FAIL)
#define BITS_WLON_MBIST_DRF_FAIL \
(BIT_MASK_WLON_MBIST_DRF_FAIL << BIT_SHIFT_WLON_MBIST_DRF_FAIL)
#define BIT_CLEAR_WLON_MBIST_DRF_FAIL(x) ((x) & (~BITS_WLON_MBIST_DRF_FAIL))
#define BIT_GET_WLON_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_WLON_MBIST_DRF_FAIL) & BIT_MASK_WLON_MBIST_DRF_FAIL)
#define BIT_SET_WLON_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_WLON_MBIST_DRF_FAIL(x) | BIT_WLON_MBIST_DRF_FAIL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_FAIL (Offset 0x0170) */
#define BIT_SHIFT_8051_MBIST_FAIL 26
#define BIT_MASK_8051_MBIST_FAIL 0x7
#define BIT_8051_MBIST_FAIL(x) \
(((x) & BIT_MASK_8051_MBIST_FAIL) << BIT_SHIFT_8051_MBIST_FAIL)
#define BITS_8051_MBIST_FAIL \
(BIT_MASK_8051_MBIST_FAIL << BIT_SHIFT_8051_MBIST_FAIL)
#define BIT_CLEAR_8051_MBIST_FAIL(x) ((x) & (~BITS_8051_MBIST_FAIL))
#define BIT_GET_8051_MBIST_FAIL(x) \
(((x) >> BIT_SHIFT_8051_MBIST_FAIL) & BIT_MASK_8051_MBIST_FAIL)
#define BIT_SET_8051_MBIST_FAIL(x, v) \
(BIT_CLEAR_8051_MBIST_FAIL(x) | BIT_8051_MBIST_FAIL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_DRF_FAIL (Offset 0x0170) */
#define BIT_SHIFT_8051_MBIST_DRF_FAIL 26
#define BIT_MASK_8051_MBIST_DRF_FAIL 0x3f
#define BIT_8051_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_8051_MBIST_DRF_FAIL) << BIT_SHIFT_8051_MBIST_DRF_FAIL)
#define BITS_8051_MBIST_DRF_FAIL \
(BIT_MASK_8051_MBIST_DRF_FAIL << BIT_SHIFT_8051_MBIST_DRF_FAIL)
#define BIT_CLEAR_8051_MBIST_DRF_FAIL(x) ((x) & (~BITS_8051_MBIST_DRF_FAIL))
#define BIT_GET_8051_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DRF_FAIL) & BIT_MASK_8051_MBIST_DRF_FAIL)
#define BIT_SET_8051_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_8051_MBIST_DRF_FAIL(x) | BIT_8051_MBIST_DRF_FAIL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_FAIL (Offset 0x0170) */
#define BIT_SHIFT_USB_MBIST_FAIL 24
#define BIT_MASK_USB_MBIST_FAIL 0x3
#define BIT_USB_MBIST_FAIL(x) \
(((x) & BIT_MASK_USB_MBIST_FAIL) << BIT_SHIFT_USB_MBIST_FAIL)
#define BITS_USB_MBIST_FAIL \
(BIT_MASK_USB_MBIST_FAIL << BIT_SHIFT_USB_MBIST_FAIL)
#define BIT_CLEAR_USB_MBIST_FAIL(x) ((x) & (~BITS_USB_MBIST_FAIL))
#define BIT_GET_USB_MBIST_FAIL(x) \
(((x) >> BIT_SHIFT_USB_MBIST_FAIL) & BIT_MASK_USB_MBIST_FAIL)
#define BIT_SET_USB_MBIST_FAIL(x, v) \
(BIT_CLEAR_USB_MBIST_FAIL(x) | BIT_USB_MBIST_FAIL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_DRF_FAIL (Offset 0x0170) */
#define BIT_SHIFT_USB_MBIST_DRF_FAIL 24
#define BIT_MASK_USB_MBIST_DRF_FAIL 0x3
#define BIT_USB_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_USB_MBIST_DRF_FAIL) << BIT_SHIFT_USB_MBIST_DRF_FAIL)
#define BITS_USB_MBIST_DRF_FAIL \
(BIT_MASK_USB_MBIST_DRF_FAIL << BIT_SHIFT_USB_MBIST_DRF_FAIL)
#define BIT_CLEAR_USB_MBIST_DRF_FAIL(x) ((x) & (~BITS_USB_MBIST_DRF_FAIL))
#define BIT_GET_USB_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DRF_FAIL) & BIT_MASK_USB_MBIST_DRF_FAIL)
#define BIT_SET_USB_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_USB_MBIST_DRF_FAIL(x) | BIT_USB_MBIST_DRF_FAIL(v))
#define BIT_SHIFT_PCIE_MBIST_DRF_FAIL 18
#define BIT_MASK_PCIE_MBIST_DRF_FAIL 0x3f
#define BIT_PCIE_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_PCIE_MBIST_DRF_FAIL) << BIT_SHIFT_PCIE_MBIST_DRF_FAIL)
#define BITS_PCIE_MBIST_DRF_FAIL \
(BIT_MASK_PCIE_MBIST_DRF_FAIL << BIT_SHIFT_PCIE_MBIST_DRF_FAIL)
#define BIT_CLEAR_PCIE_MBIST_DRF_FAIL(x) ((x) & (~BITS_PCIE_MBIST_DRF_FAIL))
#define BIT_GET_PCIE_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DRF_FAIL) & BIT_MASK_PCIE_MBIST_DRF_FAIL)
#define BIT_SET_PCIE_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_PCIE_MBIST_DRF_FAIL(x) | BIT_PCIE_MBIST_DRF_FAIL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_FAIL (Offset 0x0170) */
#define BIT_SHIFT_PCIE_MBIST_FAIL 16
#define BIT_MASK_PCIE_MBIST_FAIL 0x3f
#define BIT_PCIE_MBIST_FAIL(x) \
(((x) & BIT_MASK_PCIE_MBIST_FAIL) << BIT_SHIFT_PCIE_MBIST_FAIL)
#define BITS_PCIE_MBIST_FAIL \
(BIT_MASK_PCIE_MBIST_FAIL << BIT_SHIFT_PCIE_MBIST_FAIL)
#define BIT_CLEAR_PCIE_MBIST_FAIL(x) ((x) & (~BITS_PCIE_MBIST_FAIL))
#define BIT_GET_PCIE_MBIST_FAIL(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_FAIL) & BIT_MASK_PCIE_MBIST_FAIL)
#define BIT_SET_PCIE_MBIST_FAIL(x, v) \
(BIT_CLEAR_PCIE_MBIST_FAIL(x) | BIT_PCIE_MBIST_FAIL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_DRF_FAIL (Offset 0x0170) */
#define BIT_SHIFT_WLOFF_MBIST_DRF_FAIL 16
#define BIT_MASK_WLOFF_MBIST_DRF_FAIL 0x3fff
#define BIT_WLOFF_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_WLOFF_MBIST_DRF_FAIL) \
<< BIT_SHIFT_WLOFF_MBIST_DRF_FAIL)
#define BITS_WLOFF_MBIST_DRF_FAIL \
(BIT_MASK_WLOFF_MBIST_DRF_FAIL << BIT_SHIFT_WLOFF_MBIST_DRF_FAIL)
#define BIT_CLEAR_WLOFF_MBIST_DRF_FAIL(x) ((x) & (~BITS_WLOFF_MBIST_DRF_FAIL))
#define BIT_GET_WLOFF_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_WLOFF_MBIST_DRF_FAIL) & \
BIT_MASK_WLOFF_MBIST_DRF_FAIL)
#define BIT_SET_WLOFF_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_WLOFF_MBIST_DRF_FAIL(x) | BIT_WLOFF_MBIST_DRF_FAIL(v))
#define BIT_SHIFT_PCIE_MBIST_DRF_FAIL_V1 11
#define BIT_MASK_PCIE_MBIST_DRF_FAIL_V1 0x1f
#define BIT_PCIE_MBIST_DRF_FAIL_V1(x) \
(((x) & BIT_MASK_PCIE_MBIST_DRF_FAIL_V1) \
<< BIT_SHIFT_PCIE_MBIST_DRF_FAIL_V1)
#define BITS_PCIE_MBIST_DRF_FAIL_V1 \
(BIT_MASK_PCIE_MBIST_DRF_FAIL_V1 << BIT_SHIFT_PCIE_MBIST_DRF_FAIL_V1)
#define BIT_CLEAR_PCIE_MBIST_DRF_FAIL_V1(x) \
((x) & (~BITS_PCIE_MBIST_DRF_FAIL_V1))
#define BIT_GET_PCIE_MBIST_DRF_FAIL_V1(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DRF_FAIL_V1) & \
BIT_MASK_PCIE_MBIST_DRF_FAIL_V1)
#define BIT_SET_PCIE_MBIST_DRF_FAIL_V1(x, v) \
(BIT_CLEAR_PCIE_MBIST_DRF_FAIL_V1(x) | BIT_PCIE_MBIST_DRF_FAIL_V1(v))
#define BIT_SHIFT_USB_MBIST_DRF_FAIL_V1 4
#define BIT_MASK_USB_MBIST_DRF_FAIL_V1 0x7f
#define BIT_USB_MBIST_DRF_FAIL_V1(x) \
(((x) & BIT_MASK_USB_MBIST_DRF_FAIL_V1) \
<< BIT_SHIFT_USB_MBIST_DRF_FAIL_V1)
#define BITS_USB_MBIST_DRF_FAIL_V1 \
(BIT_MASK_USB_MBIST_DRF_FAIL_V1 << BIT_SHIFT_USB_MBIST_DRF_FAIL_V1)
#define BIT_CLEAR_USB_MBIST_DRF_FAIL_V1(x) ((x) & (~BITS_USB_MBIST_DRF_FAIL_V1))
#define BIT_GET_USB_MBIST_DRF_FAIL_V1(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DRF_FAIL_V1) & \
BIT_MASK_USB_MBIST_DRF_FAIL_V1)
#define BIT_SET_USB_MBIST_DRF_FAIL_V1(x, v) \
(BIT_CLEAR_USB_MBIST_DRF_FAIL_V1(x) | BIT_USB_MBIST_DRF_FAIL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_FAIL (Offset 0x0170) */
#define BIT_SHIFT_MAC_MBIST_FAIL 0
#define BIT_MASK_MAC_MBIST_FAIL 0xfff
#define BIT_MAC_MBIST_FAIL(x) \
(((x) & BIT_MASK_MAC_MBIST_FAIL) << BIT_SHIFT_MAC_MBIST_FAIL)
#define BITS_MAC_MBIST_FAIL \
(BIT_MASK_MAC_MBIST_FAIL << BIT_SHIFT_MAC_MBIST_FAIL)
#define BIT_CLEAR_MAC_MBIST_FAIL(x) ((x) & (~BITS_MAC_MBIST_FAIL))
#define BIT_GET_MAC_MBIST_FAIL(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_FAIL) & BIT_MASK_MAC_MBIST_FAIL)
#define BIT_SET_MAC_MBIST_FAIL(x, v) \
(BIT_CLEAR_MAC_MBIST_FAIL(x) | BIT_MAC_MBIST_FAIL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_DRF_FAIL (Offset 0x0170) */
#define BIT_SHIFT_USB_WLON_MBIST_DRF_FAIL 0
#define BIT_MASK_USB_WLON_MBIST_DRF_FAIL 0xf
#define BIT_USB_WLON_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_USB_WLON_MBIST_DRF_FAIL) \
<< BIT_SHIFT_USB_WLON_MBIST_DRF_FAIL)
#define BITS_USB_WLON_MBIST_DRF_FAIL \
(BIT_MASK_USB_WLON_MBIST_DRF_FAIL << BIT_SHIFT_USB_WLON_MBIST_DRF_FAIL)
#define BIT_CLEAR_USB_WLON_MBIST_DRF_FAIL(x) \
((x) & (~BITS_USB_WLON_MBIST_DRF_FAIL))
#define BIT_GET_USB_WLON_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_USB_WLON_MBIST_DRF_FAIL) & \
BIT_MASK_USB_WLON_MBIST_DRF_FAIL)
#define BIT_SET_USB_WLON_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_USB_WLON_MBIST_DRF_FAIL(x) | BIT_USB_WLON_MBIST_DRF_FAIL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MBIST_FAIL (Offset 0x0170) */
#define BIT_SHIFT_MAC_MBIST_FAIL_DRF 0
#define BIT_MASK_MAC_MBIST_FAIL_DRF 0x3ffff
#define BIT_MAC_MBIST_FAIL_DRF(x) \
(((x) & BIT_MASK_MAC_MBIST_FAIL_DRF) << BIT_SHIFT_MAC_MBIST_FAIL_DRF)
#define BITS_MAC_MBIST_FAIL_DRF \
(BIT_MASK_MAC_MBIST_FAIL_DRF << BIT_SHIFT_MAC_MBIST_FAIL_DRF)
#define BIT_CLEAR_MAC_MBIST_FAIL_DRF(x) ((x) & (~BITS_MAC_MBIST_FAIL_DRF))
#define BIT_GET_MAC_MBIST_FAIL_DRF(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_FAIL_DRF) & BIT_MASK_MAC_MBIST_FAIL_DRF)
#define BIT_SET_MAC_MBIST_FAIL_DRF(x, v) \
(BIT_CLEAR_MAC_MBIST_FAIL_DRF(x) | BIT_MAC_MBIST_FAIL_DRF(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_MBIST_FAIL (Offset 0x0170) */
#define BIT_SHIFT_MAC_MBIST_FAIL_DRF_V1 0
#define BIT_MASK_MAC_MBIST_FAIL_DRF_V1 0x7ffff
#define BIT_MAC_MBIST_FAIL_DRF_V1(x) \
(((x) & BIT_MASK_MAC_MBIST_FAIL_DRF_V1) \
<< BIT_SHIFT_MAC_MBIST_FAIL_DRF_V1)
#define BITS_MAC_MBIST_FAIL_DRF_V1 \
(BIT_MASK_MAC_MBIST_FAIL_DRF_V1 << BIT_SHIFT_MAC_MBIST_FAIL_DRF_V1)
#define BIT_CLEAR_MAC_MBIST_FAIL_DRF_V1(x) ((x) & (~BITS_MAC_MBIST_FAIL_DRF_V1))
#define BIT_GET_MAC_MBIST_FAIL_DRF_V1(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_FAIL_DRF_V1) & \
BIT_MASK_MAC_MBIST_FAIL_DRF_V1)
#define BIT_SET_MAC_MBIST_FAIL_DRF_V1(x, v) \
(BIT_CLEAR_MAC_MBIST_FAIL_DRF_V1(x) | BIT_MAC_MBIST_FAIL_DRF_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_DRF_FAIL (Offset 0x0170) */
#define BIT_SHIFT_MAC_MBIST_DRF_FAIL 0
#define BIT_MASK_MAC_MBIST_DRF_FAIL 0x3ffff
#define BIT_MAC_MBIST_DRF_FAIL(x) \
(((x) & BIT_MASK_MAC_MBIST_DRF_FAIL) << BIT_SHIFT_MAC_MBIST_DRF_FAIL)
#define BITS_MAC_MBIST_DRF_FAIL \
(BIT_MASK_MAC_MBIST_DRF_FAIL << BIT_SHIFT_MAC_MBIST_DRF_FAIL)
#define BIT_CLEAR_MAC_MBIST_DRF_FAIL(x) ((x) & (~BITS_MAC_MBIST_DRF_FAIL))
#define BIT_GET_MAC_MBIST_DRF_FAIL(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DRF_FAIL) & BIT_MASK_MAC_MBIST_DRF_FAIL)
#define BIT_SET_MAC_MBIST_DRF_FAIL(x, v) \
(BIT_CLEAR_MAC_MBIST_DRF_FAIL(x) | BIT_MAC_MBIST_DRF_FAIL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_8051_MBIST_START_PAUSE 26
#define BIT_MASK_8051_MBIST_START_PAUSE 0x7
#define BIT_8051_MBIST_START_PAUSE(x) \
(((x) & BIT_MASK_8051_MBIST_START_PAUSE) \
<< BIT_SHIFT_8051_MBIST_START_PAUSE)
#define BITS_8051_MBIST_START_PAUSE \
(BIT_MASK_8051_MBIST_START_PAUSE << BIT_SHIFT_8051_MBIST_START_PAUSE)
#define BIT_CLEAR_8051_MBIST_START_PAUSE(x) \
((x) & (~BITS_8051_MBIST_START_PAUSE))
#define BIT_GET_8051_MBIST_START_PAUSE(x) \
(((x) >> BIT_SHIFT_8051_MBIST_START_PAUSE) & \
BIT_MASK_8051_MBIST_START_PAUSE)
#define BIT_SET_8051_MBIST_START_PAUSE(x, v) \
(BIT_CLEAR_8051_MBIST_START_PAUSE(x) | BIT_8051_MBIST_START_PAUSE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_8051_MBIST_START_PAUSE_V1 26
#define BIT_MASK_8051_MBIST_START_PAUSE_V1 0x3f
#define BIT_8051_MBIST_START_PAUSE_V1(x) \
(((x) & BIT_MASK_8051_MBIST_START_PAUSE_V1) \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_V1)
#define BITS_8051_MBIST_START_PAUSE_V1 \
(BIT_MASK_8051_MBIST_START_PAUSE_V1 \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_V1)
#define BIT_CLEAR_8051_MBIST_START_PAUSE_V1(x) \
((x) & (~BITS_8051_MBIST_START_PAUSE_V1))
#define BIT_GET_8051_MBIST_START_PAUSE_V1(x) \
(((x) >> BIT_SHIFT_8051_MBIST_START_PAUSE_V1) & \
BIT_MASK_8051_MBIST_START_PAUSE_V1)
#define BIT_SET_8051_MBIST_START_PAUSE_V1(x, v) \
(BIT_CLEAR_8051_MBIST_START_PAUSE_V1(x) | \
BIT_8051_MBIST_START_PAUSE_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_USB_MBIST_START_PAUSE 24
#define BIT_MASK_USB_MBIST_START_PAUSE 0x3
#define BIT_USB_MBIST_START_PAUSE(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE)
#define BITS_USB_MBIST_START_PAUSE \
(BIT_MASK_USB_MBIST_START_PAUSE << BIT_SHIFT_USB_MBIST_START_PAUSE)
#define BIT_CLEAR_USB_MBIST_START_PAUSE(x) ((x) & (~BITS_USB_MBIST_START_PAUSE))
#define BIT_GET_USB_MBIST_START_PAUSE(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE) & \
BIT_MASK_USB_MBIST_START_PAUSE)
#define BIT_SET_USB_MBIST_START_PAUSE(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE(x) | BIT_USB_MBIST_START_PAUSE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_USB_MBIST_START_PAUSE_V1 24
#define BIT_MASK_USB_MBIST_START_PAUSE_V1 0x3
#define BIT_USB_MBIST_START_PAUSE_V1(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE_V1) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V1)
#define BITS_USB_MBIST_START_PAUSE_V1 \
(BIT_MASK_USB_MBIST_START_PAUSE_V1 \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V1)
#define BIT_CLEAR_USB_MBIST_START_PAUSE_V1(x) \
((x) & (~BITS_USB_MBIST_START_PAUSE_V1))
#define BIT_GET_USB_MBIST_START_PAUSE_V1(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE_V1) & \
BIT_MASK_USB_MBIST_START_PAUSE_V1)
#define BIT_SET_USB_MBIST_START_PAUSE_V1(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE_V1(x) | \
BIT_USB_MBIST_START_PAUSE_V1(v))
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1 18
#define BIT_MASK_PCIE_MBIST_START_PAUSE_V1 0x3f
#define BIT_PCIE_MBIST_START_PAUSE_V1(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE_V1) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1)
#define BITS_PCIE_MBIST_START_PAUSE_V1 \
(BIT_MASK_PCIE_MBIST_START_PAUSE_V1 \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE_V1(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE_V1))
#define BIT_GET_PCIE_MBIST_START_PAUSE_V1(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1) & \
BIT_MASK_PCIE_MBIST_START_PAUSE_V1)
#define BIT_SET_PCIE_MBIST_START_PAUSE_V1(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE_V1(x) | \
BIT_PCIE_MBIST_START_PAUSE_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE 16
#define BIT_MASK_PCIE_MBIST_START_PAUSE 0x3f
#define BIT_PCIE_MBIST_START_PAUSE(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE)
#define BITS_PCIE_MBIST_START_PAUSE \
(BIT_MASK_PCIE_MBIST_START_PAUSE << BIT_SHIFT_PCIE_MBIST_START_PAUSE)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE))
#define BIT_GET_PCIE_MBIST_START_PAUSE(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE) & \
BIT_MASK_PCIE_MBIST_START_PAUSE)
#define BIT_SET_PCIE_MBIST_START_PAUSE(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE(x) | BIT_PCIE_MBIST_START_PAUSE(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_WLON_MBIST_START_PAUSE_V1 9
#define BIT_MASK_WLON_MBIST_START_PAUSE_V1 0x3
#define BIT_WLON_MBIST_START_PAUSE_V1(x) \
(((x) & BIT_MASK_WLON_MBIST_START_PAUSE_V1) \
<< BIT_SHIFT_WLON_MBIST_START_PAUSE_V1)
#define BITS_WLON_MBIST_START_PAUSE_V1 \
(BIT_MASK_WLON_MBIST_START_PAUSE_V1 \
<< BIT_SHIFT_WLON_MBIST_START_PAUSE_V1)
#define BIT_CLEAR_WLON_MBIST_START_PAUSE_V1(x) \
((x) & (~BITS_WLON_MBIST_START_PAUSE_V1))
#define BIT_GET_WLON_MBIST_START_PAUSE_V1(x) \
(((x) >> BIT_SHIFT_WLON_MBIST_START_PAUSE_V1) & \
BIT_MASK_WLON_MBIST_START_PAUSE_V1)
#define BIT_SET_WLON_MBIST_START_PAUSE_V1(x, v) \
(BIT_CLEAR_WLON_MBIST_START_PAUSE_V1(x) | \
BIT_WLON_MBIST_START_PAUSE_V1(v))
#define BIT_SHIFT_WLOFF_MBIST_START_PAUSE_V1 4
#define BIT_MASK_WLOFF_MBIST_START_PAUSE_V1 0x1f
#define BIT_WLOFF_MBIST_START_PAUSE_V1(x) \
(((x) & BIT_MASK_WLOFF_MBIST_START_PAUSE_V1) \
<< BIT_SHIFT_WLOFF_MBIST_START_PAUSE_V1)
#define BITS_WLOFF_MBIST_START_PAUSE_V1 \
(BIT_MASK_WLOFF_MBIST_START_PAUSE_V1 \
<< BIT_SHIFT_WLOFF_MBIST_START_PAUSE_V1)
#define BIT_CLEAR_WLOFF_MBIST_START_PAUSE_V1(x) \
((x) & (~BITS_WLOFF_MBIST_START_PAUSE_V1))
#define BIT_GET_WLOFF_MBIST_START_PAUSE_V1(x) \
(((x) >> BIT_SHIFT_WLOFF_MBIST_START_PAUSE_V1) & \
BIT_MASK_WLOFF_MBIST_START_PAUSE_V1)
#define BIT_SET_WLOFF_MBIST_START_PAUSE_V1(x, v) \
(BIT_CLEAR_WLOFF_MBIST_START_PAUSE_V1(x) | \
BIT_WLOFF_MBIST_START_PAUSE_V1(v))
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE_V2 2
#define BIT_MASK_PCIE_MBIST_START_PAUSE_V2 0x3
#define BIT_PCIE_MBIST_START_PAUSE_V2(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE_V2) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V2)
#define BITS_PCIE_MBIST_START_PAUSE_V2 \
(BIT_MASK_PCIE_MBIST_START_PAUSE_V2 \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V2)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE_V2(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE_V2))
#define BIT_GET_PCIE_MBIST_START_PAUSE_V2(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE_V2) & \
BIT_MASK_PCIE_MBIST_START_PAUSE_V2)
#define BIT_SET_PCIE_MBIST_START_PAUSE_V2(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE_V2(x) | \
BIT_PCIE_MBIST_START_PAUSE_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_MAC_MBIST_START_PAUSE 0
#define BIT_MASK_MAC_MBIST_START_PAUSE 0xfff
#define BIT_MAC_MBIST_START_PAUSE(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE)
#define BITS_MAC_MBIST_START_PAUSE \
(BIT_MASK_MAC_MBIST_START_PAUSE << BIT_SHIFT_MAC_MBIST_START_PAUSE)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE(x) ((x) & (~BITS_MAC_MBIST_START_PAUSE))
#define BIT_GET_MAC_MBIST_START_PAUSE(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE) & \
BIT_MASK_MAC_MBIST_START_PAUSE)
#define BIT_SET_MAC_MBIST_START_PAUSE(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE(x) | BIT_MAC_MBIST_START_PAUSE(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_USB_MBIST_START_PAUSE_V2 0
#define BIT_MASK_USB_MBIST_START_PAUSE_V2 0x3
#define BIT_USB_MBIST_START_PAUSE_V2(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE_V2) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V2)
#define BITS_USB_MBIST_START_PAUSE_V2 \
(BIT_MASK_USB_MBIST_START_PAUSE_V2 \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V2)
#define BIT_CLEAR_USB_MBIST_START_PAUSE_V2(x) \
((x) & (~BITS_USB_MBIST_START_PAUSE_V2))
#define BIT_GET_USB_MBIST_START_PAUSE_V2(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE_V2) & \
BIT_MASK_USB_MBIST_START_PAUSE_V2)
#define BIT_SET_USB_MBIST_START_PAUSE_V2(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE_V2(x) | \
BIT_USB_MBIST_START_PAUSE_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_MAC_MBIST_START_PAUSE_V1 0
#define BIT_MASK_MAC_MBIST_START_PAUSE_V1 0x3ffff
#define BIT_MAC_MBIST_START_PAUSE_V1(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE_V1) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1)
#define BITS_MAC_MBIST_START_PAUSE_V1 \
(BIT_MASK_MAC_MBIST_START_PAUSE_V1 \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE_V1(x) \
((x) & (~BITS_MAC_MBIST_START_PAUSE_V1))
#define BIT_GET_MAC_MBIST_START_PAUSE_V1(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE_V1) & \
BIT_MASK_MAC_MBIST_START_PAUSE_V1)
#define BIT_SET_MAC_MBIST_START_PAUSE_V1(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE_V1(x) | \
BIT_MAC_MBIST_START_PAUSE_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_MBIST_START_PAUSE (Offset 0x0174) */
#define BIT_SHIFT_MAC_MBIST_START_PAUSE_V2 0
#define BIT_MASK_MAC_MBIST_START_PAUSE_V2 0x1ff
#define BIT_MAC_MBIST_START_PAUSE_V2(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE_V2) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V2)
#define BITS_MAC_MBIST_START_PAUSE_V2 \
(BIT_MASK_MAC_MBIST_START_PAUSE_V2 \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V2)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE_V2(x) \
((x) & (~BITS_MAC_MBIST_START_PAUSE_V2))
#define BIT_GET_MAC_MBIST_START_PAUSE_V2(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE_V2) & \
BIT_MASK_MAC_MBIST_START_PAUSE_V2)
#define BIT_SET_MAC_MBIST_START_PAUSE_V2(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE_V2(x) | \
BIT_MAC_MBIST_START_PAUSE_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_8051_MBIST_DONE 26
#define BIT_MASK_8051_MBIST_DONE 0x7
#define BIT_8051_MBIST_DONE(x) \
(((x) & BIT_MASK_8051_MBIST_DONE) << BIT_SHIFT_8051_MBIST_DONE)
#define BITS_8051_MBIST_DONE \
(BIT_MASK_8051_MBIST_DONE << BIT_SHIFT_8051_MBIST_DONE)
#define BIT_CLEAR_8051_MBIST_DONE(x) ((x) & (~BITS_8051_MBIST_DONE))
#define BIT_GET_8051_MBIST_DONE(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DONE) & BIT_MASK_8051_MBIST_DONE)
#define BIT_SET_8051_MBIST_DONE(x, v) \
(BIT_CLEAR_8051_MBIST_DONE(x) | BIT_8051_MBIST_DONE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_8051_MBIST_DONE_V1 26
#define BIT_MASK_8051_MBIST_DONE_V1 0x3f
#define BIT_8051_MBIST_DONE_V1(x) \
(((x) & BIT_MASK_8051_MBIST_DONE_V1) << BIT_SHIFT_8051_MBIST_DONE_V1)
#define BITS_8051_MBIST_DONE_V1 \
(BIT_MASK_8051_MBIST_DONE_V1 << BIT_SHIFT_8051_MBIST_DONE_V1)
#define BIT_CLEAR_8051_MBIST_DONE_V1(x) ((x) & (~BITS_8051_MBIST_DONE_V1))
#define BIT_GET_8051_MBIST_DONE_V1(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DONE_V1) & BIT_MASK_8051_MBIST_DONE_V1)
#define BIT_SET_8051_MBIST_DONE_V1(x, v) \
(BIT_CLEAR_8051_MBIST_DONE_V1(x) | BIT_8051_MBIST_DONE_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_USB_MBIST_DONE 24
#define BIT_MASK_USB_MBIST_DONE 0x3
#define BIT_USB_MBIST_DONE(x) \
(((x) & BIT_MASK_USB_MBIST_DONE) << BIT_SHIFT_USB_MBIST_DONE)
#define BITS_USB_MBIST_DONE \
(BIT_MASK_USB_MBIST_DONE << BIT_SHIFT_USB_MBIST_DONE)
#define BIT_CLEAR_USB_MBIST_DONE(x) ((x) & (~BITS_USB_MBIST_DONE))
#define BIT_GET_USB_MBIST_DONE(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE) & BIT_MASK_USB_MBIST_DONE)
#define BIT_SET_USB_MBIST_DONE(x, v) \
(BIT_CLEAR_USB_MBIST_DONE(x) | BIT_USB_MBIST_DONE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_USB_MBIST_DONE_V1 24
#define BIT_MASK_USB_MBIST_DONE_V1 0x3
#define BIT_USB_MBIST_DONE_V1(x) \
(((x) & BIT_MASK_USB_MBIST_DONE_V1) << BIT_SHIFT_USB_MBIST_DONE_V1)
#define BITS_USB_MBIST_DONE_V1 \
(BIT_MASK_USB_MBIST_DONE_V1 << BIT_SHIFT_USB_MBIST_DONE_V1)
#define BIT_CLEAR_USB_MBIST_DONE_V1(x) ((x) & (~BITS_USB_MBIST_DONE_V1))
#define BIT_GET_USB_MBIST_DONE_V1(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE_V1) & BIT_MASK_USB_MBIST_DONE_V1)
#define BIT_SET_USB_MBIST_DONE_V1(x, v) \
(BIT_CLEAR_USB_MBIST_DONE_V1(x) | BIT_USB_MBIST_DONE_V1(v))
#define BIT_SHIFT_PCIE_MBIST_DONE_V1 18
#define BIT_MASK_PCIE_MBIST_DONE_V1 0x3f
#define BIT_PCIE_MBIST_DONE_V1(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE_V1) << BIT_SHIFT_PCIE_MBIST_DONE_V1)
#define BITS_PCIE_MBIST_DONE_V1 \
(BIT_MASK_PCIE_MBIST_DONE_V1 << BIT_SHIFT_PCIE_MBIST_DONE_V1)
#define BIT_CLEAR_PCIE_MBIST_DONE_V1(x) ((x) & (~BITS_PCIE_MBIST_DONE_V1))
#define BIT_GET_PCIE_MBIST_DONE_V1(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE_V1) & BIT_MASK_PCIE_MBIST_DONE_V1)
#define BIT_SET_PCIE_MBIST_DONE_V1(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE_V1(x) | BIT_PCIE_MBIST_DONE_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_PCIE_MBIST_DONE 16
#define BIT_MASK_PCIE_MBIST_DONE 0x3f
#define BIT_PCIE_MBIST_DONE(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE) << BIT_SHIFT_PCIE_MBIST_DONE)
#define BITS_PCIE_MBIST_DONE \
(BIT_MASK_PCIE_MBIST_DONE << BIT_SHIFT_PCIE_MBIST_DONE)
#define BIT_CLEAR_PCIE_MBIST_DONE(x) ((x) & (~BITS_PCIE_MBIST_DONE))
#define BIT_GET_PCIE_MBIST_DONE(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE) & BIT_MASK_PCIE_MBIST_DONE)
#define BIT_SET_PCIE_MBIST_DONE(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE(x) | BIT_PCIE_MBIST_DONE(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_WLON_MBIST_DONE_V1 9
#define BIT_MASK_WLON_MBIST_DONE_V1 0x3
#define BIT_WLON_MBIST_DONE_V1(x) \
(((x) & BIT_MASK_WLON_MBIST_DONE_V1) << BIT_SHIFT_WLON_MBIST_DONE_V1)
#define BITS_WLON_MBIST_DONE_V1 \
(BIT_MASK_WLON_MBIST_DONE_V1 << BIT_SHIFT_WLON_MBIST_DONE_V1)
#define BIT_CLEAR_WLON_MBIST_DONE_V1(x) ((x) & (~BITS_WLON_MBIST_DONE_V1))
#define BIT_GET_WLON_MBIST_DONE_V1(x) \
(((x) >> BIT_SHIFT_WLON_MBIST_DONE_V1) & BIT_MASK_WLON_MBIST_DONE_V1)
#define BIT_SET_WLON_MBIST_DONE_V1(x, v) \
(BIT_CLEAR_WLON_MBIST_DONE_V1(x) | BIT_WLON_MBIST_DONE_V1(v))
#define BIT_SHIFT_WLOFF_MBIST_DONE_V1 4
#define BIT_MASK_WLOFF_MBIST_DONE_V1 0x1f
#define BIT_WLOFF_MBIST_DONE_V1(x) \
(((x) & BIT_MASK_WLOFF_MBIST_DONE_V1) << BIT_SHIFT_WLOFF_MBIST_DONE_V1)
#define BITS_WLOFF_MBIST_DONE_V1 \
(BIT_MASK_WLOFF_MBIST_DONE_V1 << BIT_SHIFT_WLOFF_MBIST_DONE_V1)
#define BIT_CLEAR_WLOFF_MBIST_DONE_V1(x) ((x) & (~BITS_WLOFF_MBIST_DONE_V1))
#define BIT_GET_WLOFF_MBIST_DONE_V1(x) \
(((x) >> BIT_SHIFT_WLOFF_MBIST_DONE_V1) & BIT_MASK_WLOFF_MBIST_DONE_V1)
#define BIT_SET_WLOFF_MBIST_DONE_V1(x, v) \
(BIT_CLEAR_WLOFF_MBIST_DONE_V1(x) | BIT_WLOFF_MBIST_DONE_V1(v))
#define BIT_SHIFT_PCIE_MBIST_DONE_V2 2
#define BIT_MASK_PCIE_MBIST_DONE_V2 0x3
#define BIT_PCIE_MBIST_DONE_V2(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE_V2) << BIT_SHIFT_PCIE_MBIST_DONE_V2)
#define BITS_PCIE_MBIST_DONE_V2 \
(BIT_MASK_PCIE_MBIST_DONE_V2 << BIT_SHIFT_PCIE_MBIST_DONE_V2)
#define BIT_CLEAR_PCIE_MBIST_DONE_V2(x) ((x) & (~BITS_PCIE_MBIST_DONE_V2))
#define BIT_GET_PCIE_MBIST_DONE_V2(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE_V2) & BIT_MASK_PCIE_MBIST_DONE_V2)
#define BIT_SET_PCIE_MBIST_DONE_V2(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE_V2(x) | BIT_PCIE_MBIST_DONE_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_MAC_MBIST_DONE 0
#define BIT_MASK_MAC_MBIST_DONE 0xfff
#define BIT_MAC_MBIST_DONE(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE) << BIT_SHIFT_MAC_MBIST_DONE)
#define BITS_MAC_MBIST_DONE \
(BIT_MASK_MAC_MBIST_DONE << BIT_SHIFT_MAC_MBIST_DONE)
#define BIT_CLEAR_MAC_MBIST_DONE(x) ((x) & (~BITS_MAC_MBIST_DONE))
#define BIT_GET_MAC_MBIST_DONE(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE) & BIT_MASK_MAC_MBIST_DONE)
#define BIT_SET_MAC_MBIST_DONE(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE(x) | BIT_MAC_MBIST_DONE(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_USB_MBIST_DONE_V2 0
#define BIT_MASK_USB_MBIST_DONE_V2 0x3
#define BIT_USB_MBIST_DONE_V2(x) \
(((x) & BIT_MASK_USB_MBIST_DONE_V2) << BIT_SHIFT_USB_MBIST_DONE_V2)
#define BITS_USB_MBIST_DONE_V2 \
(BIT_MASK_USB_MBIST_DONE_V2 << BIT_SHIFT_USB_MBIST_DONE_V2)
#define BIT_CLEAR_USB_MBIST_DONE_V2(x) ((x) & (~BITS_USB_MBIST_DONE_V2))
#define BIT_GET_USB_MBIST_DONE_V2(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE_V2) & BIT_MASK_USB_MBIST_DONE_V2)
#define BIT_SET_USB_MBIST_DONE_V2(x, v) \
(BIT_CLEAR_USB_MBIST_DONE_V2(x) | BIT_USB_MBIST_DONE_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_MAC_MBIST_DONE_V1 0
#define BIT_MASK_MAC_MBIST_DONE_V1 0x3ffff
#define BIT_MAC_MBIST_DONE_V1(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE_V1) << BIT_SHIFT_MAC_MBIST_DONE_V1)
#define BITS_MAC_MBIST_DONE_V1 \
(BIT_MASK_MAC_MBIST_DONE_V1 << BIT_SHIFT_MAC_MBIST_DONE_V1)
#define BIT_CLEAR_MAC_MBIST_DONE_V1(x) ((x) & (~BITS_MAC_MBIST_DONE_V1))
#define BIT_GET_MAC_MBIST_DONE_V1(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE_V1) & BIT_MASK_MAC_MBIST_DONE_V1)
#define BIT_SET_MAC_MBIST_DONE_V1(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE_V1(x) | BIT_MAC_MBIST_DONE_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_MBIST_DONE (Offset 0x0178) */
#define BIT_SHIFT_MAC_MBIST_DONE_V2 0
#define BIT_MASK_MAC_MBIST_DONE_V2 0x1ff
#define BIT_MAC_MBIST_DONE_V2(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE_V2) << BIT_SHIFT_MAC_MBIST_DONE_V2)
#define BITS_MAC_MBIST_DONE_V2 \
(BIT_MASK_MAC_MBIST_DONE_V2 << BIT_SHIFT_MAC_MBIST_DONE_V2)
#define BIT_CLEAR_MAC_MBIST_DONE_V2(x) ((x) & (~BITS_MAC_MBIST_DONE_V2))
#define BIT_GET_MAC_MBIST_DONE_V2(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE_V2) & BIT_MASK_MAC_MBIST_DONE_V2)
#define BIT_SET_MAC_MBIST_DONE_V2(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE_V2(x) | BIT_MAC_MBIST_DONE_V2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_NRML_FAIL (Offset 0x017C) */
#define BIT_SHIFT_WLON_MBIST_NRML_FAIL 30
#define BIT_MASK_WLON_MBIST_NRML_FAIL 0x3
#define BIT_WLON_MBIST_NRML_FAIL(x) \
(((x) & BIT_MASK_WLON_MBIST_NRML_FAIL) \
<< BIT_SHIFT_WLON_MBIST_NRML_FAIL)
#define BITS_WLON_MBIST_NRML_FAIL \
(BIT_MASK_WLON_MBIST_NRML_FAIL << BIT_SHIFT_WLON_MBIST_NRML_FAIL)
#define BIT_CLEAR_WLON_MBIST_NRML_FAIL(x) ((x) & (~BITS_WLON_MBIST_NRML_FAIL))
#define BIT_GET_WLON_MBIST_NRML_FAIL(x) \
(((x) >> BIT_SHIFT_WLON_MBIST_NRML_FAIL) & \
BIT_MASK_WLON_MBIST_NRML_FAIL)
#define BIT_SET_WLON_MBIST_NRML_FAIL(x, v) \
(BIT_CLEAR_WLON_MBIST_NRML_FAIL(x) | BIT_WLON_MBIST_NRML_FAIL(v))
#define BIT_SHIFT_WLOFF_MBIST_NRML_FAIL 16
#define BIT_MASK_WLOFF_MBIST_NRML_FAIL 0x3fff
#define BIT_WLOFF_MBIST_NRML_FAIL(x) \
(((x) & BIT_MASK_WLOFF_MBIST_NRML_FAIL) \
<< BIT_SHIFT_WLOFF_MBIST_NRML_FAIL)
#define BITS_WLOFF_MBIST_NRML_FAIL \
(BIT_MASK_WLOFF_MBIST_NRML_FAIL << BIT_SHIFT_WLOFF_MBIST_NRML_FAIL)
#define BIT_CLEAR_WLOFF_MBIST_NRML_FAIL(x) ((x) & (~BITS_WLOFF_MBIST_NRML_FAIL))
#define BIT_GET_WLOFF_MBIST_NRML_FAIL(x) \
(((x) >> BIT_SHIFT_WLOFF_MBIST_NRML_FAIL) & \
BIT_MASK_WLOFF_MBIST_NRML_FAIL)
#define BIT_SET_WLOFF_MBIST_NRML_FAIL(x, v) \
(BIT_CLEAR_WLOFF_MBIST_NRML_FAIL(x) | BIT_WLOFF_MBIST_NRML_FAIL(v))
#define BIT_SHIFT_PCIE_MBIST_NRML_FAIL 11
#define BIT_MASK_PCIE_MBIST_NRML_FAIL 0x1f
#define BIT_PCIE_MBIST_NRML_FAIL(x) \
(((x) & BIT_MASK_PCIE_MBIST_NRML_FAIL) \
<< BIT_SHIFT_PCIE_MBIST_NRML_FAIL)
#define BITS_PCIE_MBIST_NRML_FAIL \
(BIT_MASK_PCIE_MBIST_NRML_FAIL << BIT_SHIFT_PCIE_MBIST_NRML_FAIL)
#define BIT_CLEAR_PCIE_MBIST_NRML_FAIL(x) ((x) & (~BITS_PCIE_MBIST_NRML_FAIL))
#define BIT_GET_PCIE_MBIST_NRML_FAIL(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_NRML_FAIL) & \
BIT_MASK_PCIE_MBIST_NRML_FAIL)
#define BIT_SET_PCIE_MBIST_NRML_FAIL(x, v) \
(BIT_CLEAR_PCIE_MBIST_NRML_FAIL(x) | BIT_PCIE_MBIST_NRML_FAIL(v))
#define BIT_SHIFT_USB_MBIST_NRML_FAIL 4
#define BIT_MASK_USB_MBIST_NRML_FAIL 0x7f
#define BIT_USB_MBIST_NRML_FAIL(x) \
(((x) & BIT_MASK_USB_MBIST_NRML_FAIL) << BIT_SHIFT_USB_MBIST_NRML_FAIL)
#define BITS_USB_MBIST_NRML_FAIL \
(BIT_MASK_USB_MBIST_NRML_FAIL << BIT_SHIFT_USB_MBIST_NRML_FAIL)
#define BIT_CLEAR_USB_MBIST_NRML_FAIL(x) ((x) & (~BITS_USB_MBIST_NRML_FAIL))
#define BIT_GET_USB_MBIST_NRML_FAIL(x) \
(((x) >> BIT_SHIFT_USB_MBIST_NRML_FAIL) & BIT_MASK_USB_MBIST_NRML_FAIL)
#define BIT_SET_USB_MBIST_NRML_FAIL(x, v) \
(BIT_CLEAR_USB_MBIST_NRML_FAIL(x) | BIT_USB_MBIST_NRML_FAIL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIST_ROM_CRC_DATA (Offset 0x017C) */
#define BIT_SHIFT_MBIST_ROM_CRC_DATA 0
#define BIT_MASK_MBIST_ROM_CRC_DATA 0xffffffffL
#define BIT_MBIST_ROM_CRC_DATA(x) \
(((x) & BIT_MASK_MBIST_ROM_CRC_DATA) << BIT_SHIFT_MBIST_ROM_CRC_DATA)
#define BITS_MBIST_ROM_CRC_DATA \
(BIT_MASK_MBIST_ROM_CRC_DATA << BIT_SHIFT_MBIST_ROM_CRC_DATA)
#define BIT_CLEAR_MBIST_ROM_CRC_DATA(x) ((x) & (~BITS_MBIST_ROM_CRC_DATA))
#define BIT_GET_MBIST_ROM_CRC_DATA(x) \
(((x) >> BIT_SHIFT_MBIST_ROM_CRC_DATA) & BIT_MASK_MBIST_ROM_CRC_DATA)
#define BIT_SET_MBIST_ROM_CRC_DATA(x, v) \
(BIT_CLEAR_MBIST_ROM_CRC_DATA(x) | BIT_MBIST_ROM_CRC_DATA(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIST_NRML_FAIL (Offset 0x017C) */
#define BIT_SHIFT_USB_WLON_MBIST_NRML_FAIL 0
#define BIT_MASK_USB_WLON_MBIST_NRML_FAIL 0xf
#define BIT_USB_WLON_MBIST_NRML_FAIL(x) \
(((x) & BIT_MASK_USB_WLON_MBIST_NRML_FAIL) \
<< BIT_SHIFT_USB_WLON_MBIST_NRML_FAIL)
#define BITS_USB_WLON_MBIST_NRML_FAIL \
(BIT_MASK_USB_WLON_MBIST_NRML_FAIL \
<< BIT_SHIFT_USB_WLON_MBIST_NRML_FAIL)
#define BIT_CLEAR_USB_WLON_MBIST_NRML_FAIL(x) \
((x) & (~BITS_USB_WLON_MBIST_NRML_FAIL))
#define BIT_GET_USB_WLON_MBIST_NRML_FAIL(x) \
(((x) >> BIT_SHIFT_USB_WLON_MBIST_NRML_FAIL) & \
BIT_MASK_USB_WLON_MBIST_NRML_FAIL)
#define BIT_SET_USB_WLON_MBIST_NRML_FAIL(x, v) \
(BIT_CLEAR_USB_WLON_MBIST_NRML_FAIL(x) | \
BIT_USB_WLON_MBIST_NRML_FAIL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MBIST_FAIL_NRML (Offset 0x017C) */
#define BIT_SHIFT_MBIST_FAIL_NRML_V1 0
#define BIT_MASK_MBIST_FAIL_NRML_V1 0x3ffff
#define BIT_MBIST_FAIL_NRML_V1(x) \
(((x) & BIT_MASK_MBIST_FAIL_NRML_V1) << BIT_SHIFT_MBIST_FAIL_NRML_V1)
#define BITS_MBIST_FAIL_NRML_V1 \
(BIT_MASK_MBIST_FAIL_NRML_V1 << BIT_SHIFT_MBIST_FAIL_NRML_V1)
#define BIT_CLEAR_MBIST_FAIL_NRML_V1(x) ((x) & (~BITS_MBIST_FAIL_NRML_V1))
#define BIT_GET_MBIST_FAIL_NRML_V1(x) \
(((x) >> BIT_SHIFT_MBIST_FAIL_NRML_V1) & BIT_MASK_MBIST_FAIL_NRML_V1)
#define BIT_SET_MBIST_FAIL_NRML_V1(x, v) \
(BIT_CLEAR_MBIST_FAIL_NRML_V1(x) | BIT_MBIST_FAIL_NRML_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_MBIST_FAIL_NRML (Offset 0x017C) */
#define BIT_SHIFT_MBIST_FAIL_NRML_V2 0
#define BIT_MASK_MBIST_FAIL_NRML_V2 0x7ffff
#define BIT_MBIST_FAIL_NRML_V2(x) \
(((x) & BIT_MASK_MBIST_FAIL_NRML_V2) << BIT_SHIFT_MBIST_FAIL_NRML_V2)
#define BITS_MBIST_FAIL_NRML_V2 \
(BIT_MASK_MBIST_FAIL_NRML_V2 << BIT_SHIFT_MBIST_FAIL_NRML_V2)
#define BIT_CLEAR_MBIST_FAIL_NRML_V2(x) ((x) & (~BITS_MBIST_FAIL_NRML_V2))
#define BIT_GET_MBIST_FAIL_NRML_V2(x) \
(((x) >> BIT_SHIFT_MBIST_FAIL_NRML_V2) & BIT_MASK_MBIST_FAIL_NRML_V2)
#define BIT_SET_MBIST_FAIL_NRML_V2(x, v) \
(BIT_CLEAR_MBIST_FAIL_NRML_V2(x) | BIT_MBIST_FAIL_NRML_V2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MBIST_FAIL_NRML (Offset 0x017C) */
#define BIT_SHIFT_MBIST_FAIL_NRML 0
#define BIT_MASK_MBIST_FAIL_NRML 0xffffffffL
#define BIT_MBIST_FAIL_NRML(x) \
(((x) & BIT_MASK_MBIST_FAIL_NRML) << BIT_SHIFT_MBIST_FAIL_NRML)
#define BITS_MBIST_FAIL_NRML \
(BIT_MASK_MBIST_FAIL_NRML << BIT_SHIFT_MBIST_FAIL_NRML)
#define BIT_CLEAR_MBIST_FAIL_NRML(x) ((x) & (~BITS_MBIST_FAIL_NRML))
#define BIT_GET_MBIST_FAIL_NRML(x) \
(((x) >> BIT_SHIFT_MBIST_FAIL_NRML) & BIT_MASK_MBIST_FAIL_NRML)
#define BIT_SET_MBIST_FAIL_NRML(x, v) \
(BIT_CLEAR_MBIST_FAIL_NRML(x) | BIT_MBIST_FAIL_NRML(v))
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD 0xffffffffffffffffffffffffffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD) << BIT_SHIFT_R_WMAC_IPV6_MYIPAD)
#define BITS_R_WMAC_IPV6_MYIPAD \
(BIT_MASK_R_WMAC_IPV6_MYIPAD << BIT_SHIFT_R_WMAC_IPV6_MYIPAD)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD(x) ((x) & (~BITS_R_WMAC_IPV6_MYIPAD))
#define BIT_GET_R_WMAC_IPV6_MYIPAD(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD) & BIT_MASK_R_WMAC_IPV6_MYIPAD)
#define BIT_SET_R_WMAC_IPV6_MYIPAD(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD(x) | BIT_R_WMAC_IPV6_MYIPAD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AES_DECRPT_DATA (Offset 0x0180) */
#define BIT_SHIFT_IPS_CFG_ADDR 0
#define BIT_MASK_IPS_CFG_ADDR 0xff
#define BIT_IPS_CFG_ADDR(x) \
(((x) & BIT_MASK_IPS_CFG_ADDR) << BIT_SHIFT_IPS_CFG_ADDR)
#define BITS_IPS_CFG_ADDR (BIT_MASK_IPS_CFG_ADDR << BIT_SHIFT_IPS_CFG_ADDR)
#define BIT_CLEAR_IPS_CFG_ADDR(x) ((x) & (~BITS_IPS_CFG_ADDR))
#define BIT_GET_IPS_CFG_ADDR(x) \
(((x) >> BIT_SHIFT_IPS_CFG_ADDR) & BIT_MASK_IPS_CFG_ADDR)
#define BIT_SET_IPS_CFG_ADDR(x, v) \
(BIT_CLEAR_IPS_CFG_ADDR(x) | BIT_IPS_CFG_ADDR(v))
/* 2 REG_AES_DECRPT_CFG (Offset 0x0184) */
#define BIT_SHIFT_IPS_CFG_DATA 0
#define BIT_MASK_IPS_CFG_DATA 0xffffffffL
#define BIT_IPS_CFG_DATA(x) \
(((x) & BIT_MASK_IPS_CFG_DATA) << BIT_SHIFT_IPS_CFG_DATA)
#define BITS_IPS_CFG_DATA (BIT_MASK_IPS_CFG_DATA << BIT_SHIFT_IPS_CFG_DATA)
#define BIT_CLEAR_IPS_CFG_DATA(x) ((x) & (~BITS_IPS_CFG_DATA))
#define BIT_GET_IPS_CFG_DATA(x) \
(((x) >> BIT_SHIFT_IPS_CFG_DATA) & BIT_MASK_IPS_CFG_DATA)
#define BIT_SET_IPS_CFG_DATA(x, v) \
(BIT_CLEAR_IPS_CFG_DATA(x) | BIT_IPS_CFG_DATA(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIOE_CTRL (Offset 0x0188) */
#define BIT_HIOE_CFG_FILE_LOC_SEL BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIOE_CTRL (Offset 0x0188) */
#define BIT_HIOE_WRITE_REQ BIT(30)
#define BIT_HIOE_READ_REQ BIT(29)
#define BIT_INST_FORMAT_ERR BIT(25)
#define BIT_OP_TIMEOUT_ERR BIT(24)
#define BIT_SHIFT_HIOE_OP_TIMEOUT 16
#define BIT_MASK_HIOE_OP_TIMEOUT 0xff
#define BIT_HIOE_OP_TIMEOUT(x) \
(((x) & BIT_MASK_HIOE_OP_TIMEOUT) << BIT_SHIFT_HIOE_OP_TIMEOUT)
#define BITS_HIOE_OP_TIMEOUT \
(BIT_MASK_HIOE_OP_TIMEOUT << BIT_SHIFT_HIOE_OP_TIMEOUT)
#define BIT_CLEAR_HIOE_OP_TIMEOUT(x) ((x) & (~BITS_HIOE_OP_TIMEOUT))
#define BIT_GET_HIOE_OP_TIMEOUT(x) \
(((x) >> BIT_SHIFT_HIOE_OP_TIMEOUT) & BIT_MASK_HIOE_OP_TIMEOUT)
#define BIT_SET_HIOE_OP_TIMEOUT(x, v) \
(BIT_CLEAR_HIOE_OP_TIMEOUT(x) | BIT_HIOE_OP_TIMEOUT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MBIST_READ_BIST_RPT_V1 (Offset 0x0188) */
#define BIT_SHIFT_MBIST_READ_BIST_RPT 0
#define BIT_MASK_MBIST_READ_BIST_RPT 0xffffffffL
#define BIT_MBIST_READ_BIST_RPT(x) \
(((x) & BIT_MASK_MBIST_READ_BIST_RPT) << BIT_SHIFT_MBIST_READ_BIST_RPT)
#define BITS_MBIST_READ_BIST_RPT \
(BIT_MASK_MBIST_READ_BIST_RPT << BIT_SHIFT_MBIST_READ_BIST_RPT)
#define BIT_CLEAR_MBIST_READ_BIST_RPT(x) ((x) & (~BITS_MBIST_READ_BIST_RPT))
#define BIT_GET_MBIST_READ_BIST_RPT(x) \
(((x) >> BIT_SHIFT_MBIST_READ_BIST_RPT) & BIT_MASK_MBIST_READ_BIST_RPT)
#define BIT_SET_MBIST_READ_BIST_RPT(x, v) \
(BIT_CLEAR_MBIST_READ_BIST_RPT(x) | BIT_MBIST_READ_BIST_RPT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIOE_CTRL (Offset 0x0188) */
#define BIT_SHIFT_BITDATA_CHECKSUM 0
#define BIT_MASK_BITDATA_CHECKSUM 0xffff
#define BIT_BITDATA_CHECKSUM(x) \
(((x) & BIT_MASK_BITDATA_CHECKSUM) << BIT_SHIFT_BITDATA_CHECKSUM)
#define BITS_BITDATA_CHECKSUM \
(BIT_MASK_BITDATA_CHECKSUM << BIT_SHIFT_BITDATA_CHECKSUM)
#define BIT_CLEAR_BITDATA_CHECKSUM(x) ((x) & (~BITS_BITDATA_CHECKSUM))
#define BIT_GET_BITDATA_CHECKSUM(x) \
(((x) >> BIT_SHIFT_BITDATA_CHECKSUM) & BIT_MASK_BITDATA_CHECKSUM)
#define BIT_SET_BITDATA_CHECKSUM(x, v) \
(BIT_CLEAR_BITDATA_CHECKSUM(x) | BIT_BITDATA_CHECKSUM(v))
/* 2 REG_HIOE_CFG_FILE (Offset 0x018C) */
#define BIT_SHIFT_TXBF_END_ADDR 16
#define BIT_MASK_TXBF_END_ADDR 0xffff
#define BIT_TXBF_END_ADDR(x) \
(((x) & BIT_MASK_TXBF_END_ADDR) << BIT_SHIFT_TXBF_END_ADDR)
#define BITS_TXBF_END_ADDR (BIT_MASK_TXBF_END_ADDR << BIT_SHIFT_TXBF_END_ADDR)
#define BIT_CLEAR_TXBF_END_ADDR(x) ((x) & (~BITS_TXBF_END_ADDR))
#define BIT_GET_TXBF_END_ADDR(x) \
(((x) >> BIT_SHIFT_TXBF_END_ADDR) & BIT_MASK_TXBF_END_ADDR)
#define BIT_SET_TXBF_END_ADDR(x, v) \
(BIT_CLEAR_TXBF_END_ADDR(x) | BIT_TXBF_END_ADDR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_MACCLKFRQ (Offset 0x018C) */
#define BIT_SHIFT_MACCLK_FREQ_LOW32 0
#define BIT_MASK_MACCLK_FREQ_LOW32 0xffffffffL
#define BIT_MACCLK_FREQ_LOW32(x) \
(((x) & BIT_MASK_MACCLK_FREQ_LOW32) << BIT_SHIFT_MACCLK_FREQ_LOW32)
#define BITS_MACCLK_FREQ_LOW32 \
(BIT_MASK_MACCLK_FREQ_LOW32 << BIT_SHIFT_MACCLK_FREQ_LOW32)
#define BIT_CLEAR_MACCLK_FREQ_LOW32(x) ((x) & (~BITS_MACCLK_FREQ_LOW32))
#define BIT_GET_MACCLK_FREQ_LOW32(x) \
(((x) >> BIT_SHIFT_MACCLK_FREQ_LOW32) & BIT_MASK_MACCLK_FREQ_LOW32)
#define BIT_SET_MACCLK_FREQ_LOW32(x, v) \
(BIT_CLEAR_MACCLK_FREQ_LOW32(x) | BIT_MACCLK_FREQ_LOW32(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIOE_CFG_FILE (Offset 0x018C) */
#define BIT_SHIFT_TXBF_STR_ADDR 0
#define BIT_MASK_TXBF_STR_ADDR 0xffff
#define BIT_TXBF_STR_ADDR(x) \
(((x) & BIT_MASK_TXBF_STR_ADDR) << BIT_SHIFT_TXBF_STR_ADDR)
#define BITS_TXBF_STR_ADDR (BIT_MASK_TXBF_STR_ADDR << BIT_SHIFT_TXBF_STR_ADDR)
#define BIT_CLEAR_TXBF_STR_ADDR(x) ((x) & (~BITS_TXBF_STR_ADDR))
#define BIT_GET_TXBF_STR_ADDR(x) \
(((x) >> BIT_SHIFT_TXBF_STR_ADDR) & BIT_MASK_TXBF_STR_ADDR)
#define BIT_SET_TXBF_STR_ADDR(x, v) \
(BIT_CLEAR_TXBF_STR_ADDR(x) | BIT_TXBF_STR_ADDR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TMETER (Offset 0x0190) */
#define BIT_TEMP_VALID BIT(31)
#define BIT_SHIFT_TEMP_VALUE 24
#define BIT_MASK_TEMP_VALUE 0x3f
#define BIT_TEMP_VALUE(x) (((x) & BIT_MASK_TEMP_VALUE) << BIT_SHIFT_TEMP_VALUE)
#define BITS_TEMP_VALUE (BIT_MASK_TEMP_VALUE << BIT_SHIFT_TEMP_VALUE)
#define BIT_CLEAR_TEMP_VALUE(x) ((x) & (~BITS_TEMP_VALUE))
#define BIT_GET_TEMP_VALUE(x) \
(((x) >> BIT_SHIFT_TEMP_VALUE) & BIT_MASK_TEMP_VALUE)
#define BIT_SET_TEMP_VALUE(x, v) (BIT_CLEAR_TEMP_VALUE(x) | BIT_TEMP_VALUE(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TMETER (Offset 0x0190) */
#define BIT_SHIFT_NCO_OUTCLK_FREQ 12
#define BIT_MASK_NCO_OUTCLK_FREQ 0xfffff
#define BIT_NCO_OUTCLK_FREQ(x) \
(((x) & BIT_MASK_NCO_OUTCLK_FREQ) << BIT_SHIFT_NCO_OUTCLK_FREQ)
#define BITS_NCO_OUTCLK_FREQ \
(BIT_MASK_NCO_OUTCLK_FREQ << BIT_SHIFT_NCO_OUTCLK_FREQ)
#define BIT_CLEAR_NCO_OUTCLK_FREQ(x) ((x) & (~BITS_NCO_OUTCLK_FREQ))
#define BIT_GET_NCO_OUTCLK_FREQ(x) \
(((x) >> BIT_SHIFT_NCO_OUTCLK_FREQ) & BIT_MASK_NCO_OUTCLK_FREQ)
#define BIT_SET_NCO_OUTCLK_FREQ(x, v) \
(BIT_CLEAR_NCO_OUTCLK_FREQ(x) | BIT_NCO_OUTCLK_FREQ(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TMETER (Offset 0x0190) */
#define BIT_SHIFT_REG_TMETER_TIMER 8
#define BIT_MASK_REG_TMETER_TIMER 0xfff
#define BIT_REG_TMETER_TIMER(x) \
(((x) & BIT_MASK_REG_TMETER_TIMER) << BIT_SHIFT_REG_TMETER_TIMER)
#define BITS_REG_TMETER_TIMER \
(BIT_MASK_REG_TMETER_TIMER << BIT_SHIFT_REG_TMETER_TIMER)
#define BIT_CLEAR_REG_TMETER_TIMER(x) ((x) & (~BITS_REG_TMETER_TIMER))
#define BIT_GET_REG_TMETER_TIMER(x) \
(((x) >> BIT_SHIFT_REG_TMETER_TIMER) & BIT_MASK_REG_TMETER_TIMER)
#define BIT_SET_REG_TMETER_TIMER(x, v) \
(BIT_CLEAR_REG_TMETER_TIMER(x) | BIT_REG_TMETER_TIMER(v))
#define BIT_SHIFT_REG_TEMP_DELTA 2
#define BIT_MASK_REG_TEMP_DELTA 0x3f
#define BIT_REG_TEMP_DELTA(x) \
(((x) & BIT_MASK_REG_TEMP_DELTA) << BIT_SHIFT_REG_TEMP_DELTA)
#define BITS_REG_TEMP_DELTA \
(BIT_MASK_REG_TEMP_DELTA << BIT_SHIFT_REG_TEMP_DELTA)
#define BIT_CLEAR_REG_TEMP_DELTA(x) ((x) & (~BITS_REG_TEMP_DELTA))
#define BIT_GET_REG_TEMP_DELTA(x) \
(((x) >> BIT_SHIFT_REG_TEMP_DELTA) & BIT_MASK_REG_TEMP_DELTA)
#define BIT_SET_REG_TEMP_DELTA(x, v) \
(BIT_CLEAR_REG_TEMP_DELTA(x) | BIT_REG_TEMP_DELTA(v))
#define BIT_REG_TMETER_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_TMETER (Offset 0x0190) */
#define BIT_SHIFT_MACCLK_FREQ_HIGH10 0
#define BIT_MASK_MACCLK_FREQ_HIGH10 0x3ff
#define BIT_MACCLK_FREQ_HIGH10(x) \
(((x) & BIT_MASK_MACCLK_FREQ_HIGH10) << BIT_SHIFT_MACCLK_FREQ_HIGH10)
#define BITS_MACCLK_FREQ_HIGH10 \
(BIT_MASK_MACCLK_FREQ_HIGH10 << BIT_SHIFT_MACCLK_FREQ_HIGH10)
#define BIT_CLEAR_MACCLK_FREQ_HIGH10(x) ((x) & (~BITS_MACCLK_FREQ_HIGH10))
#define BIT_GET_MACCLK_FREQ_HIGH10(x) \
(((x) >> BIT_SHIFT_MACCLK_FREQ_HIGH10) & BIT_MASK_MACCLK_FREQ_HIGH10)
#define BIT_SET_MACCLK_FREQ_HIGH10(x, v) \
(BIT_CLEAR_MACCLK_FREQ_HIGH10(x) | BIT_MACCLK_FREQ_HIGH10(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_OSC_32K_CTRL (Offset 0x0194) */
#define BIT_SHIFT_OSC_32K_CLKGEN_0 16
#define BIT_MASK_OSC_32K_CLKGEN_0 0xffff
#define BIT_OSC_32K_CLKGEN_0(x) \
(((x) & BIT_MASK_OSC_32K_CLKGEN_0) << BIT_SHIFT_OSC_32K_CLKGEN_0)
#define BITS_OSC_32K_CLKGEN_0 \
(BIT_MASK_OSC_32K_CLKGEN_0 << BIT_SHIFT_OSC_32K_CLKGEN_0)
#define BIT_CLEAR_OSC_32K_CLKGEN_0(x) ((x) & (~BITS_OSC_32K_CLKGEN_0))
#define BIT_GET_OSC_32K_CLKGEN_0(x) \
(((x) >> BIT_SHIFT_OSC_32K_CLKGEN_0) & BIT_MASK_OSC_32K_CLKGEN_0)
#define BIT_SET_OSC_32K_CLKGEN_0(x, v) \
(BIT_CLEAR_OSC_32K_CLKGEN_0(x) | BIT_OSC_32K_CLKGEN_0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_OSC_32K_CTRL (Offset 0x0194) */
#define BIT_32K_CLK_OUT_RDY BIT(12)
#define BIT_SHIFT_MONITOR_CYCLE_LOG2 8
#define BIT_MASK_MONITOR_CYCLE_LOG2 0xf
#define BIT_MONITOR_CYCLE_LOG2(x) \
(((x) & BIT_MASK_MONITOR_CYCLE_LOG2) << BIT_SHIFT_MONITOR_CYCLE_LOG2)
#define BITS_MONITOR_CYCLE_LOG2 \
(BIT_MASK_MONITOR_CYCLE_LOG2 << BIT_SHIFT_MONITOR_CYCLE_LOG2)
#define BIT_CLEAR_MONITOR_CYCLE_LOG2(x) ((x) & (~BITS_MONITOR_CYCLE_LOG2))
#define BIT_GET_MONITOR_CYCLE_LOG2(x) \
(((x) >> BIT_SHIFT_MONITOR_CYCLE_LOG2) & BIT_MASK_MONITOR_CYCLE_LOG2)
#define BIT_SET_MONITOR_CYCLE_LOG2(x, v) \
(BIT_CLEAR_MONITOR_CYCLE_LOG2(x) | BIT_MONITOR_CYCLE_LOG2(v))
#define BIT_SHIFT_FREQVALUE_UNREGCLK 8
#define BIT_MASK_FREQVALUE_UNREGCLK 0xffffff
#define BIT_FREQVALUE_UNREGCLK(x) \
(((x) & BIT_MASK_FREQVALUE_UNREGCLK) << BIT_SHIFT_FREQVALUE_UNREGCLK)
#define BITS_FREQVALUE_UNREGCLK \
(BIT_MASK_FREQVALUE_UNREGCLK << BIT_SHIFT_FREQVALUE_UNREGCLK)
#define BIT_CLEAR_FREQVALUE_UNREGCLK(x) ((x) & (~BITS_FREQVALUE_UNREGCLK))
#define BIT_GET_FREQVALUE_UNREGCLK(x) \
(((x) >> BIT_SHIFT_FREQVALUE_UNREGCLK) & BIT_MASK_FREQVALUE_UNREGCLK)
#define BIT_SET_FREQVALUE_UNREGCLK(x, v) \
(BIT_CLEAR_FREQVALUE_UNREGCLK(x) | BIT_FREQVALUE_UNREGCLK(v))
#define BIT_CAL32K_DBGMOD BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_OSC_32K_CTRL (Offset 0x0194) */
#define BIT_SHIFT_OSC_32K_RES_COMP 4
#define BIT_MASK_OSC_32K_RES_COMP 0x3
#define BIT_OSC_32K_RES_COMP(x) \
(((x) & BIT_MASK_OSC_32K_RES_COMP) << BIT_SHIFT_OSC_32K_RES_COMP)
#define BITS_OSC_32K_RES_COMP \
(BIT_MASK_OSC_32K_RES_COMP << BIT_SHIFT_OSC_32K_RES_COMP)
#define BIT_CLEAR_OSC_32K_RES_COMP(x) ((x) & (~BITS_OSC_32K_RES_COMP))
#define BIT_GET_OSC_32K_RES_COMP(x) \
(((x) >> BIT_SHIFT_OSC_32K_RES_COMP) & BIT_MASK_OSC_32K_RES_COMP)
#define BIT_SET_OSC_32K_RES_COMP(x, v) \
(BIT_CLEAR_OSC_32K_RES_COMP(x) | BIT_OSC_32K_RES_COMP(v))
#define BIT_OSC_32K_OUT_SEL BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_OSC_32K_CTRL (Offset 0x0194) */
#define BIT_ISO_WL_2_OSC_32K BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_OSC_32K_CTRL (Offset 0x0194) */
#define BIT_POW_CKGEN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_OSC_32K_CTRL (Offset 0x0194) */
#define BIT_SHIFT_NCO_THRS 0
#define BIT_MASK_NCO_THRS 0x7f
#define BIT_NCO_THRS(x) (((x) & BIT_MASK_NCO_THRS) << BIT_SHIFT_NCO_THRS)
#define BITS_NCO_THRS (BIT_MASK_NCO_THRS << BIT_SHIFT_NCO_THRS)
#define BIT_CLEAR_NCO_THRS(x) ((x) & (~BITS_NCO_THRS))
#define BIT_GET_NCO_THRS(x) (((x) >> BIT_SHIFT_NCO_THRS) & BIT_MASK_NCO_THRS)
#define BIT_SET_NCO_THRS(x, v) (BIT_CLEAR_NCO_THRS(x) | BIT_NCO_THRS(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_32K_CAL_REG1 (Offset 0x0198) */
#define BIT_CAL_32K_REG_WR BIT(31)
#define BIT_CAL_32K_DBG_SEL BIT(22)
#define BIT_SHIFT_CAL_32K_REG_ADDR 16
#define BIT_MASK_CAL_32K_REG_ADDR 0x3f
#define BIT_CAL_32K_REG_ADDR(x) \
(((x) & BIT_MASK_CAL_32K_REG_ADDR) << BIT_SHIFT_CAL_32K_REG_ADDR)
#define BITS_CAL_32K_REG_ADDR \
(BIT_MASK_CAL_32K_REG_ADDR << BIT_SHIFT_CAL_32K_REG_ADDR)
#define BIT_CLEAR_CAL_32K_REG_ADDR(x) ((x) & (~BITS_CAL_32K_REG_ADDR))
#define BIT_GET_CAL_32K_REG_ADDR(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_ADDR) & BIT_MASK_CAL_32K_REG_ADDR)
#define BIT_SET_CAL_32K_REG_ADDR(x, v) \
(BIT_CLEAR_CAL_32K_REG_ADDR(x) | BIT_CAL_32K_REG_ADDR(v))
#define BIT_SHIFT_CAL_32K_REG_DATA 0
#define BIT_MASK_CAL_32K_REG_DATA 0xffff
#define BIT_CAL_32K_REG_DATA(x) \
(((x) & BIT_MASK_CAL_32K_REG_DATA) << BIT_SHIFT_CAL_32K_REG_DATA)
#define BITS_CAL_32K_REG_DATA \
(BIT_MASK_CAL_32K_REG_DATA << BIT_SHIFT_CAL_32K_REG_DATA)
#define BIT_CLEAR_CAL_32K_REG_DATA(x) ((x) & (~BITS_CAL_32K_REG_DATA))
#define BIT_GET_CAL_32K_REG_DATA(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_DATA) & BIT_MASK_CAL_32K_REG_DATA)
#define BIT_SET_CAL_32K_REG_DATA(x, v) \
(BIT_CLEAR_CAL_32K_REG_DATA(x) | BIT_CAL_32K_REG_DATA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_C2HEVT (Offset 0x01A0) */
#define BIT_SHIFT_C2HEVT_MSG 0
#define BIT_MASK_C2HEVT_MSG 0xffffffffffffffffffffffffffffffffL
#define BIT_C2HEVT_MSG(x) (((x) & BIT_MASK_C2HEVT_MSG) << BIT_SHIFT_C2HEVT_MSG)
#define BITS_C2HEVT_MSG (BIT_MASK_C2HEVT_MSG << BIT_SHIFT_C2HEVT_MSG)
#define BIT_CLEAR_C2HEVT_MSG(x) ((x) & (~BITS_C2HEVT_MSG))
#define BIT_GET_C2HEVT_MSG(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG) & BIT_MASK_C2HEVT_MSG)
#define BIT_SET_C2HEVT_MSG(x, v) (BIT_CLEAR_C2HEVT_MSG(x) | BIT_C2HEVT_MSG(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_C2HEVT (Offset 0x01A0) */
#define BIT_SHIFT_C2HEVT_MSG_V1 0
#define BIT_MASK_C2HEVT_MSG_V1 0xffffffffL
#define BIT_C2HEVT_MSG_V1(x) \
(((x) & BIT_MASK_C2HEVT_MSG_V1) << BIT_SHIFT_C2HEVT_MSG_V1)
#define BITS_C2HEVT_MSG_V1 (BIT_MASK_C2HEVT_MSG_V1 << BIT_SHIFT_C2HEVT_MSG_V1)
#define BIT_CLEAR_C2HEVT_MSG_V1(x) ((x) & (~BITS_C2HEVT_MSG_V1))
#define BIT_GET_C2HEVT_MSG_V1(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_V1) & BIT_MASK_C2HEVT_MSG_V1)
#define BIT_SET_C2HEVT_MSG_V1(x, v) \
(BIT_CLEAR_C2HEVT_MSG_V1(x) | BIT_C2HEVT_MSG_V1(v))
/* 2 REG_C2HEVT_1 (Offset 0x01A4) */
#define BIT_SHIFT_C2HEVT_MSG_1 0
#define BIT_MASK_C2HEVT_MSG_1 0xffffffffL
#define BIT_C2HEVT_MSG_1(x) \
(((x) & BIT_MASK_C2HEVT_MSG_1) << BIT_SHIFT_C2HEVT_MSG_1)
#define BITS_C2HEVT_MSG_1 (BIT_MASK_C2HEVT_MSG_1 << BIT_SHIFT_C2HEVT_MSG_1)
#define BIT_CLEAR_C2HEVT_MSG_1(x) ((x) & (~BITS_C2HEVT_MSG_1))
#define BIT_GET_C2HEVT_MSG_1(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_1) & BIT_MASK_C2HEVT_MSG_1)
#define BIT_SET_C2HEVT_MSG_1(x, v) \
(BIT_CLEAR_C2HEVT_MSG_1(x) | BIT_C2HEVT_MSG_1(v))
/* 2 REG_C2HEVT_2 (Offset 0x01A8) */
#define BIT_SHIFT_C2HEVT_MSG_2 0
#define BIT_MASK_C2HEVT_MSG_2 0xffffffffL
#define BIT_C2HEVT_MSG_2(x) \
(((x) & BIT_MASK_C2HEVT_MSG_2) << BIT_SHIFT_C2HEVT_MSG_2)
#define BITS_C2HEVT_MSG_2 (BIT_MASK_C2HEVT_MSG_2 << BIT_SHIFT_C2HEVT_MSG_2)
#define BIT_CLEAR_C2HEVT_MSG_2(x) ((x) & (~BITS_C2HEVT_MSG_2))
#define BIT_GET_C2HEVT_MSG_2(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_2) & BIT_MASK_C2HEVT_MSG_2)
#define BIT_SET_C2HEVT_MSG_2(x, v) \
(BIT_CLEAR_C2HEVT_MSG_2(x) | BIT_C2HEVT_MSG_2(v))
/* 2 REG_C2HEVT_3 (Offset 0x01AC) */
#define BIT_SHIFT_C2HEVT_MSG_3 0
#define BIT_MASK_C2HEVT_MSG_3 0xffffffffL
#define BIT_C2HEVT_MSG_3(x) \
(((x) & BIT_MASK_C2HEVT_MSG_3) << BIT_SHIFT_C2HEVT_MSG_3)
#define BITS_C2HEVT_MSG_3 (BIT_MASK_C2HEVT_MSG_3 << BIT_SHIFT_C2HEVT_MSG_3)
#define BIT_CLEAR_C2HEVT_MSG_3(x) ((x) & (~BITS_C2HEVT_MSG_3))
#define BIT_GET_C2HEVT_MSG_3(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_3) & BIT_MASK_C2HEVT_MSG_3)
#define BIT_SET_C2HEVT_MSG_3(x, v) \
(BIT_CLEAR_C2HEVT_MSG_3(x) | BIT_C2HEVT_MSG_3(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MISC_CTRL_V1 (Offset 0x01B0) */
#define BIT_SHIFT_PHYWR_SETUP_CNT 28
#define BIT_MASK_PHYWR_SETUP_CNT 0xf
#define BIT_PHYWR_SETUP_CNT(x) \
(((x) & BIT_MASK_PHYWR_SETUP_CNT) << BIT_SHIFT_PHYWR_SETUP_CNT)
#define BITS_PHYWR_SETUP_CNT \
(BIT_MASK_PHYWR_SETUP_CNT << BIT_SHIFT_PHYWR_SETUP_CNT)
#define BIT_CLEAR_PHYWR_SETUP_CNT(x) ((x) & (~BITS_PHYWR_SETUP_CNT))
#define BIT_GET_PHYWR_SETUP_CNT(x) \
(((x) >> BIT_SHIFT_PHYWR_SETUP_CNT) & BIT_MASK_PHYWR_SETUP_CNT)
#define BIT_SET_PHYWR_SETUP_CNT(x, v) \
(BIT_CLEAR_PHYWR_SETUP_CNT(x) | BIT_PHYWR_SETUP_CNT(v))
#define BIT_SHIFT_PHYWR_HOLD_CNT 24
#define BIT_MASK_PHYWR_HOLD_CNT 0xf
#define BIT_PHYWR_HOLD_CNT(x) \
(((x) & BIT_MASK_PHYWR_HOLD_CNT) << BIT_SHIFT_PHYWR_HOLD_CNT)
#define BITS_PHYWR_HOLD_CNT \
(BIT_MASK_PHYWR_HOLD_CNT << BIT_SHIFT_PHYWR_HOLD_CNT)
#define BIT_CLEAR_PHYWR_HOLD_CNT(x) ((x) & (~BITS_PHYWR_HOLD_CNT))
#define BIT_GET_PHYWR_HOLD_CNT(x) \
(((x) >> BIT_SHIFT_PHYWR_HOLD_CNT) & BIT_MASK_PHYWR_HOLD_CNT)
#define BIT_SET_PHYWR_HOLD_CNT(x, v) \
(BIT_CLEAR_PHYWR_HOLD_CNT(x) | BIT_PHYWR_HOLD_CNT(v))
#define BIT_SHIFT_TXBUF_WKCAM_OFFSET 8
#define BIT_MASK_TXBUF_WKCAM_OFFSET 0x1fff
#define BIT_TXBUF_WKCAM_OFFSET(x) \
(((x) & BIT_MASK_TXBUF_WKCAM_OFFSET) << BIT_SHIFT_TXBUF_WKCAM_OFFSET)
#define BITS_TXBUF_WKCAM_OFFSET \
(BIT_MASK_TXBUF_WKCAM_OFFSET << BIT_SHIFT_TXBUF_WKCAM_OFFSET)
#define BIT_CLEAR_TXBUF_WKCAM_OFFSET(x) ((x) & (~BITS_TXBUF_WKCAM_OFFSET))
#define BIT_GET_TXBUF_WKCAM_OFFSET(x) \
(((x) >> BIT_SHIFT_TXBUF_WKCAM_OFFSET) & BIT_MASK_TXBUF_WKCAM_OFFSET)
#define BIT_SET_TXBUF_WKCAM_OFFSET(x, v) \
(BIT_CLEAR_TXBUF_WKCAM_OFFSET(x) | BIT_TXBUF_WKCAM_OFFSET(v))
#define BIT_SHIFT_PHYRD_WAIT_CNT 4
#define BIT_MASK_PHYRD_WAIT_CNT 0xf
#define BIT_PHYRD_WAIT_CNT(x) \
(((x) & BIT_MASK_PHYRD_WAIT_CNT) << BIT_SHIFT_PHYRD_WAIT_CNT)
#define BITS_PHYRD_WAIT_CNT \
(BIT_MASK_PHYRD_WAIT_CNT << BIT_SHIFT_PHYRD_WAIT_CNT)
#define BIT_CLEAR_PHYRD_WAIT_CNT(x) ((x) & (~BITS_PHYRD_WAIT_CNT))
#define BIT_GET_PHYRD_WAIT_CNT(x) \
(((x) >> BIT_SHIFT_PHYRD_WAIT_CNT) & BIT_MASK_PHYRD_WAIT_CNT)
#define BIT_SET_PHYRD_WAIT_CNT(x, v) \
(BIT_CLEAR_PHYRD_WAIT_CNT(x) | BIT_PHYRD_WAIT_CNT(v))
#define BIT_SHIFT_H2CQ_PRI 0
#define BIT_MASK_H2CQ_PRI 0x3
#define BIT_H2CQ_PRI(x) (((x) & BIT_MASK_H2CQ_PRI) << BIT_SHIFT_H2CQ_PRI)
#define BITS_H2CQ_PRI (BIT_MASK_H2CQ_PRI << BIT_SHIFT_H2CQ_PRI)
#define BIT_CLEAR_H2CQ_PRI(x) ((x) & (~BITS_H2CQ_PRI))
#define BIT_GET_H2CQ_PRI(x) (((x) >> BIT_SHIFT_H2CQ_PRI) & BIT_MASK_H2CQ_PRI)
#define BIT_SET_H2CQ_PRI(x, v) (BIT_CLEAR_H2CQ_PRI(x) | BIT_H2CQ_PRI(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RXDESC_BUFF_RPTR (Offset 0x01B0) */
#define BIT_SHIFT_RXDESC_BUFF_RPTR 0
#define BIT_MASK_RXDESC_BUFF_RPTR 0xffffffffL
#define BIT_RXDESC_BUFF_RPTR(x) \
(((x) & BIT_MASK_RXDESC_BUFF_RPTR) << BIT_SHIFT_RXDESC_BUFF_RPTR)
#define BITS_RXDESC_BUFF_RPTR \
(BIT_MASK_RXDESC_BUFF_RPTR << BIT_SHIFT_RXDESC_BUFF_RPTR)
#define BIT_CLEAR_RXDESC_BUFF_RPTR(x) ((x) & (~BITS_RXDESC_BUFF_RPTR))
#define BIT_GET_RXDESC_BUFF_RPTR(x) \
(((x) >> BIT_SHIFT_RXDESC_BUFF_RPTR) & BIT_MASK_RXDESC_BUFF_RPTR)
#define BIT_SET_RXDESC_BUFF_RPTR(x, v) \
(BIT_CLEAR_RXDESC_BUFF_RPTR(x) | BIT_RXDESC_BUFF_RPTR(v))
/* 2 REG_RXDESC_BUFF_WPTR (Offset 0x01B4) */
#define BIT_SHIFT_RXDESC_BUFF_WPTR 0
#define BIT_MASK_RXDESC_BUFF_WPTR 0xffffffffL
#define BIT_RXDESC_BUFF_WPTR(x) \
(((x) & BIT_MASK_RXDESC_BUFF_WPTR) << BIT_SHIFT_RXDESC_BUFF_WPTR)
#define BITS_RXDESC_BUFF_WPTR \
(BIT_MASK_RXDESC_BUFF_WPTR << BIT_SHIFT_RXDESC_BUFF_WPTR)
#define BIT_CLEAR_RXDESC_BUFF_WPTR(x) ((x) & (~BITS_RXDESC_BUFF_WPTR))
#define BIT_GET_RXDESC_BUFF_WPTR(x) \
(((x) >> BIT_SHIFT_RXDESC_BUFF_WPTR) & BIT_MASK_RXDESC_BUFF_WPTR)
#define BIT_SET_RXDESC_BUFF_WPTR(x, v) \
(BIT_CLEAR_RXDESC_BUFF_WPTR(x) | BIT_RXDESC_BUFF_WPTR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SW_DEFINED_PAGE1 (Offset 0x01B8) */
#define BIT_SHIFT_SW_DEFINED_PAGE1 0
#define BIT_MASK_SW_DEFINED_PAGE1 0xffffffffffffffffL
#define BIT_SW_DEFINED_PAGE1(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1) << BIT_SHIFT_SW_DEFINED_PAGE1)
#define BITS_SW_DEFINED_PAGE1 \
(BIT_MASK_SW_DEFINED_PAGE1 << BIT_SHIFT_SW_DEFINED_PAGE1)
#define BIT_CLEAR_SW_DEFINED_PAGE1(x) ((x) & (~BITS_SW_DEFINED_PAGE1))
#define BIT_GET_SW_DEFINED_PAGE1(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1) & BIT_MASK_SW_DEFINED_PAGE1)
#define BIT_SET_SW_DEFINED_PAGE1(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1(x) | BIT_SW_DEFINED_PAGE1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SW_DEFINED_PAGE1 (Offset 0x01B8) */
#define BIT_SHIFT_SW_DEFINED_PAGE1_V1 0
#define BIT_MASK_SW_DEFINED_PAGE1_V1 0xffffffffL
#define BIT_SW_DEFINED_PAGE1_V1(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1_V1) << BIT_SHIFT_SW_DEFINED_PAGE1_V1)
#define BITS_SW_DEFINED_PAGE1_V1 \
(BIT_MASK_SW_DEFINED_PAGE1_V1 << BIT_SHIFT_SW_DEFINED_PAGE1_V1)
#define BIT_CLEAR_SW_DEFINED_PAGE1_V1(x) ((x) & (~BITS_SW_DEFINED_PAGE1_V1))
#define BIT_GET_SW_DEFINED_PAGE1_V1(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1_V1) & BIT_MASK_SW_DEFINED_PAGE1_V1)
#define BIT_SET_SW_DEFINED_PAGE1_V1(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1_V1(x) | BIT_SW_DEFINED_PAGE1_V1(v))
/* 2 REG_SW_DEFINED_PAGE2 (Offset 0x01BC) */
#define BIT_SHIFT_SW_DEFINED_PAGE2 0
#define BIT_MASK_SW_DEFINED_PAGE2 0xffffffffL
#define BIT_SW_DEFINED_PAGE2(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE2) << BIT_SHIFT_SW_DEFINED_PAGE2)
#define BITS_SW_DEFINED_PAGE2 \
(BIT_MASK_SW_DEFINED_PAGE2 << BIT_SHIFT_SW_DEFINED_PAGE2)
#define BIT_CLEAR_SW_DEFINED_PAGE2(x) ((x) & (~BITS_SW_DEFINED_PAGE2))
#define BIT_GET_SW_DEFINED_PAGE2(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE2) & BIT_MASK_SW_DEFINED_PAGE2)
#define BIT_SET_SW_DEFINED_PAGE2(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE2(x) | BIT_SW_DEFINED_PAGE2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_MCUTST_I (Offset 0x01C0) */
#define BIT_SHIFT_MCUDMSG_I 0
#define BIT_MASK_MCUDMSG_I 0xffffffffL
#define BIT_MCUDMSG_I(x) (((x) & BIT_MASK_MCUDMSG_I) << BIT_SHIFT_MCUDMSG_I)
#define BITS_MCUDMSG_I (BIT_MASK_MCUDMSG_I << BIT_SHIFT_MCUDMSG_I)
#define BIT_CLEAR_MCUDMSG_I(x) ((x) & (~BITS_MCUDMSG_I))
#define BIT_GET_MCUDMSG_I(x) (((x) >> BIT_SHIFT_MCUDMSG_I) & BIT_MASK_MCUDMSG_I)
#define BIT_SET_MCUDMSG_I(x, v) (BIT_CLEAR_MCUDMSG_I(x) | BIT_MCUDMSG_I(v))
/* 2 REG_MCUTST_II (Offset 0x01C4) */
#define BIT_SHIFT_MCUDMSG_II 0
#define BIT_MASK_MCUDMSG_II 0xffffffffL
#define BIT_MCUDMSG_II(x) (((x) & BIT_MASK_MCUDMSG_II) << BIT_SHIFT_MCUDMSG_II)
#define BITS_MCUDMSG_II (BIT_MASK_MCUDMSG_II << BIT_SHIFT_MCUDMSG_II)
#define BIT_CLEAR_MCUDMSG_II(x) ((x) & (~BITS_MCUDMSG_II))
#define BIT_GET_MCUDMSG_II(x) \
(((x) >> BIT_SHIFT_MCUDMSG_II) & BIT_MASK_MCUDMSG_II)
#define BIT_SET_MCUDMSG_II(x, v) (BIT_CLEAR_MCUDMSG_II(x) | BIT_MCUDMSG_II(v))
/* 2 REG_FMETHR (Offset 0x01C8) */
#define BIT_FMSG_INT BIT(31)
#define BIT_SHIFT_FW_MSG 0
#define BIT_MASK_FW_MSG 0xffffffffL
#define BIT_FW_MSG(x) (((x) & BIT_MASK_FW_MSG) << BIT_SHIFT_FW_MSG)
#define BITS_FW_MSG (BIT_MASK_FW_MSG << BIT_SHIFT_FW_MSG)
#define BIT_CLEAR_FW_MSG(x) ((x) & (~BITS_FW_MSG))
#define BIT_GET_FW_MSG(x) (((x) >> BIT_SHIFT_FW_MSG) & BIT_MASK_FW_MSG)
#define BIT_SET_FW_MSG(x, v) (BIT_CLEAR_FW_MSG(x) | BIT_FW_MSG(v))
/* 2 REG_HMETFR (Offset 0x01CC) */
#define BIT_SHIFT_HRCV_MSG 24
#define BIT_MASK_HRCV_MSG 0xff
#define BIT_HRCV_MSG(x) (((x) & BIT_MASK_HRCV_MSG) << BIT_SHIFT_HRCV_MSG)
#define BITS_HRCV_MSG (BIT_MASK_HRCV_MSG << BIT_SHIFT_HRCV_MSG)
#define BIT_CLEAR_HRCV_MSG(x) ((x) & (~BITS_HRCV_MSG))
#define BIT_GET_HRCV_MSG(x) (((x) >> BIT_SHIFT_HRCV_MSG) & BIT_MASK_HRCV_MSG)
#define BIT_SET_HRCV_MSG(x, v) (BIT_CLEAR_HRCV_MSG(x) | BIT_HRCV_MSG(v))
#define BIT_INT_BOX3 BIT(3)
#define BIT_INT_BOX2 BIT(2)
#define BIT_INT_BOX1 BIT(1)
#define BIT_INT_BOX0 BIT(0)
/* 2 REG_HMEBOX0 (Offset 0x01D0) */
#define BIT_SHIFT_HOST_MSG_0 0
#define BIT_MASK_HOST_MSG_0 0xffffffffL
#define BIT_HOST_MSG_0(x) (((x) & BIT_MASK_HOST_MSG_0) << BIT_SHIFT_HOST_MSG_0)
#define BITS_HOST_MSG_0 (BIT_MASK_HOST_MSG_0 << BIT_SHIFT_HOST_MSG_0)
#define BIT_CLEAR_HOST_MSG_0(x) ((x) & (~BITS_HOST_MSG_0))
#define BIT_GET_HOST_MSG_0(x) \
(((x) >> BIT_SHIFT_HOST_MSG_0) & BIT_MASK_HOST_MSG_0)
#define BIT_SET_HOST_MSG_0(x, v) (BIT_CLEAR_HOST_MSG_0(x) | BIT_HOST_MSG_0(v))
/* 2 REG_HMEBOX1 (Offset 0x01D4) */
#define BIT_SHIFT_HOST_MSG_1 0
#define BIT_MASK_HOST_MSG_1 0xffffffffL
#define BIT_HOST_MSG_1(x) (((x) & BIT_MASK_HOST_MSG_1) << BIT_SHIFT_HOST_MSG_1)
#define BITS_HOST_MSG_1 (BIT_MASK_HOST_MSG_1 << BIT_SHIFT_HOST_MSG_1)
#define BIT_CLEAR_HOST_MSG_1(x) ((x) & (~BITS_HOST_MSG_1))
#define BIT_GET_HOST_MSG_1(x) \
(((x) >> BIT_SHIFT_HOST_MSG_1) & BIT_MASK_HOST_MSG_1)
#define BIT_SET_HOST_MSG_1(x, v) (BIT_CLEAR_HOST_MSG_1(x) | BIT_HOST_MSG_1(v))
/* 2 REG_HMEBOX2 (Offset 0x01D8) */
#define BIT_SHIFT_HOST_MSG_2 0
#define BIT_MASK_HOST_MSG_2 0xffffffffL
#define BIT_HOST_MSG_2(x) (((x) & BIT_MASK_HOST_MSG_2) << BIT_SHIFT_HOST_MSG_2)
#define BITS_HOST_MSG_2 (BIT_MASK_HOST_MSG_2 << BIT_SHIFT_HOST_MSG_2)
#define BIT_CLEAR_HOST_MSG_2(x) ((x) & (~BITS_HOST_MSG_2))
#define BIT_GET_HOST_MSG_2(x) \
(((x) >> BIT_SHIFT_HOST_MSG_2) & BIT_MASK_HOST_MSG_2)
#define BIT_SET_HOST_MSG_2(x, v) (BIT_CLEAR_HOST_MSG_2(x) | BIT_HOST_MSG_2(v))
/* 2 REG_HMEBOX3 (Offset 0x01DC) */
#define BIT_SHIFT_HOST_MSG_3 0
#define BIT_MASK_HOST_MSG_3 0xffffffffL
#define BIT_HOST_MSG_3(x) (((x) & BIT_MASK_HOST_MSG_3) << BIT_SHIFT_HOST_MSG_3)
#define BITS_HOST_MSG_3 (BIT_MASK_HOST_MSG_3 << BIT_SHIFT_HOST_MSG_3)
#define BIT_CLEAR_HOST_MSG_3(x) ((x) & (~BITS_HOST_MSG_3))
#define BIT_GET_HOST_MSG_3(x) \
(((x) >> BIT_SHIFT_HOST_MSG_3) & BIT_MASK_HOST_MSG_3)
#define BIT_SET_HOST_MSG_3(x, v) (BIT_CLEAR_HOST_MSG_3(x) | BIT_HOST_MSG_3(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RXDESC_BUFF_BNDY (Offset 0x01E0) */
#define BIT_FW_FIFO_PTR_RST BIT(18)
#define BIT_PHY_FIFO_PTR_RST BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LLT_INIT (Offset 0x01E0) */
#define BIT_SHIFT_LLTINI_PDATA_V1 16
#define BIT_MASK_LLTINI_PDATA_V1 0xfff
#define BIT_LLTINI_PDATA_V1(x) \
(((x) & BIT_MASK_LLTINI_PDATA_V1) << BIT_SHIFT_LLTINI_PDATA_V1)
#define BITS_LLTINI_PDATA_V1 \
(BIT_MASK_LLTINI_PDATA_V1 << BIT_SHIFT_LLTINI_PDATA_V1)
#define BIT_CLEAR_LLTINI_PDATA_V1(x) ((x) & (~BITS_LLTINI_PDATA_V1))
#define BIT_GET_LLTINI_PDATA_V1(x) \
(((x) >> BIT_SHIFT_LLTINI_PDATA_V1) & BIT_MASK_LLTINI_PDATA_V1)
#define BIT_SET_LLTINI_PDATA_V1(x, v) \
(BIT_CLEAR_LLTINI_PDATA_V1(x) | BIT_LLTINI_PDATA_V1(v))
#define BIT_SHIFT_LLTINI_HDATA_V1 0
#define BIT_MASK_LLTINI_HDATA_V1 0xfff
#define BIT_LLTINI_HDATA_V1(x) \
(((x) & BIT_MASK_LLTINI_HDATA_V1) << BIT_SHIFT_LLTINI_HDATA_V1)
#define BITS_LLTINI_HDATA_V1 \
(BIT_MASK_LLTINI_HDATA_V1 << BIT_SHIFT_LLTINI_HDATA_V1)
#define BIT_CLEAR_LLTINI_HDATA_V1(x) ((x) & (~BITS_LLTINI_HDATA_V1))
#define BIT_GET_LLTINI_HDATA_V1(x) \
(((x) >> BIT_SHIFT_LLTINI_HDATA_V1) & BIT_MASK_LLTINI_HDATA_V1)
#define BIT_SET_LLTINI_HDATA_V1(x, v) \
(BIT_CLEAR_LLTINI_HDATA_V1(x) | BIT_LLTINI_HDATA_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RXDESC_BUFF_BNDY (Offset 0x01E0) */
#define BIT_SHIFT_RXDESC_BUFF_BNDY 0
#define BIT_MASK_RXDESC_BUFF_BNDY 0xffffffffL
#define BIT_RXDESC_BUFF_BNDY(x) \
(((x) & BIT_MASK_RXDESC_BUFF_BNDY) << BIT_SHIFT_RXDESC_BUFF_BNDY)
#define BITS_RXDESC_BUFF_BNDY \
(BIT_MASK_RXDESC_BUFF_BNDY << BIT_SHIFT_RXDESC_BUFF_BNDY)
#define BIT_CLEAR_RXDESC_BUFF_BNDY(x) ((x) & (~BITS_RXDESC_BUFF_BNDY))
#define BIT_GET_RXDESC_BUFF_BNDY(x) \
(((x) >> BIT_SHIFT_RXDESC_BUFF_BNDY) & BIT_MASK_RXDESC_BUFF_BNDY)
#define BIT_SET_RXDESC_BUFF_BNDY(x, v) \
(BIT_CLEAR_RXDESC_BUFF_BNDY(x) | BIT_RXDESC_BUFF_BNDY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_GENTST (Offset 0x01E4) */
#define BIT_SHIFT_GENTST 0
#define BIT_MASK_GENTST 0xffffffffL
#define BIT_GENTST(x) (((x) & BIT_MASK_GENTST) << BIT_SHIFT_GENTST)
#define BITS_GENTST (BIT_MASK_GENTST << BIT_SHIFT_GENTST)
#define BIT_CLEAR_GENTST(x) ((x) & (~BITS_GENTST))
#define BIT_GET_GENTST(x) (((x) >> BIT_SHIFT_GENTST) & BIT_MASK_GENTST)
#define BIT_SET_GENTST(x, v) (BIT_CLEAR_GENTST(x) | BIT_GENTST(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_LLT_INIT_ADDR (Offset 0x01E4) */
#define BIT_SHIFT_LLTINI_ADDR_V1 0
#define BIT_MASK_LLTINI_ADDR_V1 0xfff
#define BIT_LLTINI_ADDR_V1(x) \
(((x) & BIT_MASK_LLTINI_ADDR_V1) << BIT_SHIFT_LLTINI_ADDR_V1)
#define BITS_LLTINI_ADDR_V1 \
(BIT_MASK_LLTINI_ADDR_V1 << BIT_SHIFT_LLTINI_ADDR_V1)
#define BIT_CLEAR_LLTINI_ADDR_V1(x) ((x) & (~BITS_LLTINI_ADDR_V1))
#define BIT_GET_LLTINI_ADDR_V1(x) \
(((x) >> BIT_SHIFT_LLTINI_ADDR_V1) & BIT_MASK_LLTINI_ADDR_V1)
#define BIT_SET_LLTINI_ADDR_V1(x, v) \
(BIT_CLEAR_LLTINI_ADDR_V1(x) | BIT_LLTINI_ADDR_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BB_ACCESS_CTRL (Offset 0x01E8) */
#define BIT_SHIFT_BB_WRITE_READ 30
#define BIT_MASK_BB_WRITE_READ 0x3
#define BIT_BB_WRITE_READ(x) \
(((x) & BIT_MASK_BB_WRITE_READ) << BIT_SHIFT_BB_WRITE_READ)
#define BITS_BB_WRITE_READ (BIT_MASK_BB_WRITE_READ << BIT_SHIFT_BB_WRITE_READ)
#define BIT_CLEAR_BB_WRITE_READ(x) ((x) & (~BITS_BB_WRITE_READ))
#define BIT_GET_BB_WRITE_READ(x) \
(((x) >> BIT_SHIFT_BB_WRITE_READ) & BIT_MASK_BB_WRITE_READ)
#define BIT_SET_BB_WRITE_READ(x, v) \
(BIT_CLEAR_BB_WRITE_READ(x) | BIT_BB_WRITE_READ(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_BB_ACCESS_CTRL (Offset 0x01E8) */
#define BIT_SHIFT_BB_WRITE_EN_V1 16
#define BIT_MASK_BB_WRITE_EN_V1 0xf
#define BIT_BB_WRITE_EN_V1(x) \
(((x) & BIT_MASK_BB_WRITE_EN_V1) << BIT_SHIFT_BB_WRITE_EN_V1)
#define BITS_BB_WRITE_EN_V1 \
(BIT_MASK_BB_WRITE_EN_V1 << BIT_SHIFT_BB_WRITE_EN_V1)
#define BIT_CLEAR_BB_WRITE_EN_V1(x) ((x) & (~BITS_BB_WRITE_EN_V1))
#define BIT_GET_BB_WRITE_EN_V1(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN_V1) & BIT_MASK_BB_WRITE_EN_V1)
#define BIT_SET_BB_WRITE_EN_V1(x, v) \
(BIT_CLEAR_BB_WRITE_EN_V1(x) | BIT_BB_WRITE_EN_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BB_ACCESS_CTRL (Offset 0x01E8) */
#define BIT_SHIFT_BB_WRITE_EN 12
#define BIT_MASK_BB_WRITE_EN 0xf
#define BIT_BB_WRITE_EN(x) \
(((x) & BIT_MASK_BB_WRITE_EN) << BIT_SHIFT_BB_WRITE_EN)
#define BITS_BB_WRITE_EN (BIT_MASK_BB_WRITE_EN << BIT_SHIFT_BB_WRITE_EN)
#define BIT_CLEAR_BB_WRITE_EN(x) ((x) & (~BITS_BB_WRITE_EN))
#define BIT_GET_BB_WRITE_EN(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN) & BIT_MASK_BB_WRITE_EN)
#define BIT_SET_BB_WRITE_EN(x, v) \
(BIT_CLEAR_BB_WRITE_EN(x) | BIT_BB_WRITE_EN(v))
#define BIT_SHIFT_BB_ADDR 2
#define BIT_MASK_BB_ADDR 0x1ff
#define BIT_BB_ADDR(x) (((x) & BIT_MASK_BB_ADDR) << BIT_SHIFT_BB_ADDR)
#define BITS_BB_ADDR (BIT_MASK_BB_ADDR << BIT_SHIFT_BB_ADDR)
#define BIT_CLEAR_BB_ADDR(x) ((x) & (~BITS_BB_ADDR))
#define BIT_GET_BB_ADDR(x) (((x) >> BIT_SHIFT_BB_ADDR) & BIT_MASK_BB_ADDR)
#define BIT_SET_BB_ADDR(x, v) (BIT_CLEAR_BB_ADDR(x) | BIT_BB_ADDR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_BB_ACCESS_CTRL (Offset 0x01E8) */
#define BIT_SHIFT_BB_ADDR_V1 2
#define BIT_MASK_BB_ADDR_V1 0xfff
#define BIT_BB_ADDR_V1(x) (((x) & BIT_MASK_BB_ADDR_V1) << BIT_SHIFT_BB_ADDR_V1)
#define BITS_BB_ADDR_V1 (BIT_MASK_BB_ADDR_V1 << BIT_SHIFT_BB_ADDR_V1)
#define BIT_CLEAR_BB_ADDR_V1(x) ((x) & (~BITS_BB_ADDR_V1))
#define BIT_GET_BB_ADDR_V1(x) \
(((x) >> BIT_SHIFT_BB_ADDR_V1) & BIT_MASK_BB_ADDR_V1)
#define BIT_SET_BB_ADDR_V1(x, v) (BIT_CLEAR_BB_ADDR_V1(x) | BIT_BB_ADDR_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BB_ACCESS_CTRL (Offset 0x01E8) */
#define BIT_BB_ERRACC BIT(0)
/* 2 REG_BB_ACCESS_DATA (Offset 0x01EC) */
#define BIT_SHIFT_BB_DATA 0
#define BIT_MASK_BB_DATA 0xffffffffL
#define BIT_BB_DATA(x) (((x) & BIT_MASK_BB_DATA) << BIT_SHIFT_BB_DATA)
#define BITS_BB_DATA (BIT_MASK_BB_DATA << BIT_SHIFT_BB_DATA)
#define BIT_CLEAR_BB_DATA(x) ((x) & (~BITS_BB_DATA))
#define BIT_GET_BB_DATA(x) (((x) >> BIT_SHIFT_BB_DATA) & BIT_MASK_BB_DATA)
#define BIT_SET_BB_DATA(x, v) (BIT_CLEAR_BB_DATA(x) | BIT_BB_DATA(v))
/* 2 REG_HMEBOX_E0 (Offset 0x01F0) */
#define BIT_SHIFT_HMEBOX_E0 0
#define BIT_MASK_HMEBOX_E0 0xffffffffL
#define BIT_HMEBOX_E0(x) (((x) & BIT_MASK_HMEBOX_E0) << BIT_SHIFT_HMEBOX_E0)
#define BITS_HMEBOX_E0 (BIT_MASK_HMEBOX_E0 << BIT_SHIFT_HMEBOX_E0)
#define BIT_CLEAR_HMEBOX_E0(x) ((x) & (~BITS_HMEBOX_E0))
#define BIT_GET_HMEBOX_E0(x) (((x) >> BIT_SHIFT_HMEBOX_E0) & BIT_MASK_HMEBOX_E0)
#define BIT_SET_HMEBOX_E0(x, v) (BIT_CLEAR_HMEBOX_E0(x) | BIT_HMEBOX_E0(v))
/* 2 REG_HMEBOX_E1 (Offset 0x01F4) */
#define BIT_SHIFT_HMEBOX_E1 0
#define BIT_MASK_HMEBOX_E1 0xffffffffL
#define BIT_HMEBOX_E1(x) (((x) & BIT_MASK_HMEBOX_E1) << BIT_SHIFT_HMEBOX_E1)
#define BITS_HMEBOX_E1 (BIT_MASK_HMEBOX_E1 << BIT_SHIFT_HMEBOX_E1)
#define BIT_CLEAR_HMEBOX_E1(x) ((x) & (~BITS_HMEBOX_E1))
#define BIT_GET_HMEBOX_E1(x) (((x) >> BIT_SHIFT_HMEBOX_E1) & BIT_MASK_HMEBOX_E1)
#define BIT_SET_HMEBOX_E1(x, v) (BIT_CLEAR_HMEBOX_E1(x) | BIT_HMEBOX_E1(v))
/* 2 REG_HMEBOX_E2 (Offset 0x01F8) */
#define BIT_SHIFT_HMEBOX_E2 0
#define BIT_MASK_HMEBOX_E2 0xffffffffL
#define BIT_HMEBOX_E2(x) (((x) & BIT_MASK_HMEBOX_E2) << BIT_SHIFT_HMEBOX_E2)
#define BITS_HMEBOX_E2 (BIT_MASK_HMEBOX_E2 << BIT_SHIFT_HMEBOX_E2)
#define BIT_CLEAR_HMEBOX_E2(x) ((x) & (~BITS_HMEBOX_E2))
#define BIT_GET_HMEBOX_E2(x) (((x) >> BIT_SHIFT_HMEBOX_E2) & BIT_MASK_HMEBOX_E2)
#define BIT_SET_HMEBOX_E2(x, v) (BIT_CLEAR_HMEBOX_E2(x) | BIT_HMEBOX_E2(v))
/* 2 REG_HMEBOX_E3 (Offset 0x01FC) */
#define BIT_SHIFT_HMEBOX_E3 0
#define BIT_MASK_HMEBOX_E3 0xffffffffL
#define BIT_HMEBOX_E3(x) (((x) & BIT_MASK_HMEBOX_E3) << BIT_SHIFT_HMEBOX_E3)
#define BITS_HMEBOX_E3 (BIT_MASK_HMEBOX_E3 << BIT_SHIFT_HMEBOX_E3)
#define BIT_CLEAR_HMEBOX_E3(x) ((x) & (~BITS_HMEBOX_E3))
#define BIT_GET_HMEBOX_E3(x) (((x) >> BIT_SHIFT_HMEBOX_E3) & BIT_MASK_HMEBOX_E3)
#define BIT_SET_HMEBOX_E3(x, v) (BIT_CLEAR_HMEBOX_E3(x) | BIT_HMEBOX_E3(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_0 (Offset 0x0200) */
#define BIT_BCN1_VALID BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_RQPN_CTRL_HLPQ (Offset 0x0200) */
#define BIT_EP2Q_PUBLIC_DIS BIT(29)
#define BIT_EP1Q_PUBLIC_DIS BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RQPN_CTRL_HLPQ (Offset 0x0200) */
#define BIT_EPQ_PUBLIC_DIS BIT(27)
#define BIT_NPQ_PUBLIC_DIS BIT(26)
#define BIT_LPQ_PUBLIC_DIS BIT(25)
#define BIT_HPQ_PUBLIC_DIS BIT(24)
#define BIT_SHIFT_PUBQ 16
#define BIT_MASK_PUBQ 0xff
#define BIT_PUBQ(x) (((x) & BIT_MASK_PUBQ) << BIT_SHIFT_PUBQ)
#define BITS_PUBQ (BIT_MASK_PUBQ << BIT_SHIFT_PUBQ)
#define BIT_CLEAR_PUBQ(x) ((x) & (~BITS_PUBQ))
#define BIT_GET_PUBQ(x) (((x) >> BIT_SHIFT_PUBQ) & BIT_MASK_PUBQ)
#define BIT_SET_PUBQ(x, v) (BIT_CLEAR_PUBQ(x) | BIT_PUBQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_1 (Offset 0x0200) */
#define BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1 16
#define BIT_MASK_TX_OQT_HE_FREE_SPACE_V1 0xff
#define BIT_TX_OQT_HE_FREE_SPACE_V1(x) \
(((x) & BIT_MASK_TX_OQT_HE_FREE_SPACE_V1) \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1)
#define BITS_TX_OQT_HE_FREE_SPACE_V1 \
(BIT_MASK_TX_OQT_HE_FREE_SPACE_V1 << BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1)
#define BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1(x) \
((x) & (~BITS_TX_OQT_HE_FREE_SPACE_V1))
#define BIT_GET_TX_OQT_HE_FREE_SPACE_V1(x) \
(((x) >> BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1) & \
BIT_MASK_TX_OQT_HE_FREE_SPACE_V1)
#define BIT_SET_TX_OQT_HE_FREE_SPACE_V1(x, v) \
(BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1(x) | BIT_TX_OQT_HE_FREE_SPACE_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_0 (Offset 0x0200) */
#define BIT_SHIFT_BCN1_HEAD 16
#define BIT_MASK_BCN1_HEAD 0xfff
#define BIT_BCN1_HEAD(x) (((x) & BIT_MASK_BCN1_HEAD) << BIT_SHIFT_BCN1_HEAD)
#define BITS_BCN1_HEAD (BIT_MASK_BCN1_HEAD << BIT_SHIFT_BCN1_HEAD)
#define BIT_CLEAR_BCN1_HEAD(x) ((x) & (~BITS_BCN1_HEAD))
#define BIT_GET_BCN1_HEAD(x) (((x) >> BIT_SHIFT_BCN1_HEAD) & BIT_MASK_BCN1_HEAD)
#define BIT_SET_BCN1_HEAD(x, v) (BIT_CLEAR_BCN1_HEAD(x) | BIT_BCN1_HEAD(v))
#define BIT_BCN0_VALID BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RQPN_CTRL_HLPQ (Offset 0x0200) */
#define BIT_SHIFT_LPQ 8
#define BIT_MASK_LPQ 0xff
#define BIT_LPQ(x) (((x) & BIT_MASK_LPQ) << BIT_SHIFT_LPQ)
#define BITS_LPQ (BIT_MASK_LPQ << BIT_SHIFT_LPQ)
#define BIT_CLEAR_LPQ(x) ((x) & (~BITS_LPQ))
#define BIT_GET_LPQ(x) (((x) >> BIT_SHIFT_LPQ) & BIT_MASK_LPQ)
#define BIT_SET_LPQ(x, v) (BIT_CLEAR_LPQ(x) | BIT_LPQ(v))
#define BIT_SHIFT_HPQ 0
#define BIT_MASK_HPQ 0xff
#define BIT_HPQ(x) (((x) & BIT_MASK_HPQ) << BIT_SHIFT_HPQ)
#define BITS_HPQ (BIT_MASK_HPQ << BIT_SHIFT_HPQ)
#define BIT_CLEAR_HPQ(x) ((x) & (~BITS_HPQ))
#define BIT_GET_HPQ(x) (((x) >> BIT_SHIFT_HPQ) & BIT_MASK_HPQ)
#define BIT_SET_HPQ(x, v) (BIT_CLEAR_HPQ(x) | BIT_HPQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_1 (Offset 0x0200) */
#define BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1 0
#define BIT_MASK_TX_OQT_NL_FREE_SPACE_V1 0xff
#define BIT_TX_OQT_NL_FREE_SPACE_V1(x) \
(((x) & BIT_MASK_TX_OQT_NL_FREE_SPACE_V1) \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1)
#define BITS_TX_OQT_NL_FREE_SPACE_V1 \
(BIT_MASK_TX_OQT_NL_FREE_SPACE_V1 << BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1)
#define BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1(x) \
((x) & (~BITS_TX_OQT_NL_FREE_SPACE_V1))
#define BIT_GET_TX_OQT_NL_FREE_SPACE_V1(x) \
(((x) >> BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1) & \
BIT_MASK_TX_OQT_NL_FREE_SPACE_V1)
#define BIT_SET_TX_OQT_NL_FREE_SPACE_V1(x, v) \
(BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1(x) | BIT_TX_OQT_NL_FREE_SPACE_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_0 (Offset 0x0200) */
#define BIT_SHIFT_BCN0_HEAD 0
#define BIT_MASK_BCN0_HEAD 0xfff
#define BIT_BCN0_HEAD(x) (((x) & BIT_MASK_BCN0_HEAD) << BIT_SHIFT_BCN0_HEAD)
#define BITS_BCN0_HEAD (BIT_MASK_BCN0_HEAD << BIT_SHIFT_BCN0_HEAD)
#define BIT_CLEAR_BCN0_HEAD(x) ((x) & (~BITS_BCN0_HEAD))
#define BIT_GET_BCN0_HEAD(x) (((x) >> BIT_SHIFT_BCN0_HEAD) & BIT_MASK_BCN0_HEAD)
#define BIT_SET_BCN0_HEAD(x, v) (BIT_CLEAR_BCN0_HEAD(x) | BIT_BCN0_HEAD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_2 (Offset 0x0204) */
#define BIT_BCN_VALID_1_V1 BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_1 (Offset 0x0204) */
#define BIT_BCN3_VALID BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FIFOPAGE_INFO (Offset 0x0204) */
#define BIT_SHIFT_TXPKTNUM 24
#define BIT_MASK_TXPKTNUM 0xff
#define BIT_TXPKTNUM(x) (((x) & BIT_MASK_TXPKTNUM) << BIT_SHIFT_TXPKTNUM)
#define BITS_TXPKTNUM (BIT_MASK_TXPKTNUM << BIT_SHIFT_TXPKTNUM)
#define BIT_CLEAR_TXPKTNUM(x) ((x) & (~BITS_TXPKTNUM))
#define BIT_GET_TXPKTNUM(x) (((x) >> BIT_SHIFT_TXPKTNUM) & BIT_MASK_TXPKTNUM)
#define BIT_SET_TXPKTNUM(x, v) (BIT_CLEAR_TXPKTNUM(x) | BIT_TXPKTNUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_1 (Offset 0x0204) */
#define BIT_SHIFT_R_BCN_HEAD_SEL_V1 20
#define BIT_MASK_R_BCN_HEAD_SEL_V1 0x7
#define BIT_R_BCN_HEAD_SEL_V1(x) \
(((x) & BIT_MASK_R_BCN_HEAD_SEL_V1) << BIT_SHIFT_R_BCN_HEAD_SEL_V1)
#define BITS_R_BCN_HEAD_SEL_V1 \
(BIT_MASK_R_BCN_HEAD_SEL_V1 << BIT_SHIFT_R_BCN_HEAD_SEL_V1)
#define BIT_CLEAR_R_BCN_HEAD_SEL_V1(x) ((x) & (~BITS_R_BCN_HEAD_SEL_V1))
#define BIT_GET_R_BCN_HEAD_SEL_V1(x) \
(((x) >> BIT_SHIFT_R_BCN_HEAD_SEL_V1) & BIT_MASK_R_BCN_HEAD_SEL_V1)
#define BIT_SET_R_BCN_HEAD_SEL_V1(x, v) \
(BIT_CLEAR_R_BCN_HEAD_SEL_V1(x) | BIT_R_BCN_HEAD_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FIFOPAGE_INFO (Offset 0x0204) */
#define BIT_SHIFT_PUBQ_AVAL_PG 16
#define BIT_MASK_PUBQ_AVAL_PG 0xff
#define BIT_PUBQ_AVAL_PG(x) \
(((x) & BIT_MASK_PUBQ_AVAL_PG) << BIT_SHIFT_PUBQ_AVAL_PG)
#define BITS_PUBQ_AVAL_PG (BIT_MASK_PUBQ_AVAL_PG << BIT_SHIFT_PUBQ_AVAL_PG)
#define BIT_CLEAR_PUBQ_AVAL_PG(x) ((x) & (~BITS_PUBQ_AVAL_PG))
#define BIT_GET_PUBQ_AVAL_PG(x) \
(((x) >> BIT_SHIFT_PUBQ_AVAL_PG) & BIT_MASK_PUBQ_AVAL_PG)
#define BIT_SET_PUBQ_AVAL_PG(x, v) \
(BIT_CLEAR_PUBQ_AVAL_PG(x) | BIT_PUBQ_AVAL_PG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_2 (Offset 0x0204) */
#define BIT_SHIFT_BCN_HEAD_1_V1 16
#define BIT_MASK_BCN_HEAD_1_V1 0xfff
#define BIT_BCN_HEAD_1_V1(x) \
(((x) & BIT_MASK_BCN_HEAD_1_V1) << BIT_SHIFT_BCN_HEAD_1_V1)
#define BITS_BCN_HEAD_1_V1 (BIT_MASK_BCN_HEAD_1_V1 << BIT_SHIFT_BCN_HEAD_1_V1)
#define BIT_CLEAR_BCN_HEAD_1_V1(x) ((x) & (~BITS_BCN_HEAD_1_V1))
#define BIT_GET_BCN_HEAD_1_V1(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_1_V1) & BIT_MASK_BCN_HEAD_1_V1)
#define BIT_SET_BCN_HEAD_1_V1(x, v) \
(BIT_CLEAR_BCN_HEAD_1_V1(x) | BIT_BCN_HEAD_1_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_1 (Offset 0x0204) */
#define BIT_SHIFT_BCN3_HEAD 16
#define BIT_MASK_BCN3_HEAD 0xfff
#define BIT_BCN3_HEAD(x) (((x) & BIT_MASK_BCN3_HEAD) << BIT_SHIFT_BCN3_HEAD)
#define BITS_BCN3_HEAD (BIT_MASK_BCN3_HEAD << BIT_SHIFT_BCN3_HEAD)
#define BIT_CLEAR_BCN3_HEAD(x) ((x) & (~BITS_BCN3_HEAD))
#define BIT_GET_BCN3_HEAD(x) (((x) >> BIT_SHIFT_BCN3_HEAD) & BIT_MASK_BCN3_HEAD)
#define BIT_SET_BCN3_HEAD(x, v) (BIT_CLEAR_BCN3_HEAD(x) | BIT_BCN3_HEAD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_2 (Offset 0x0204) */
#define BIT_BCN_VALID_V1 BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_1 (Offset 0x0204) */
#define BIT_BCN2_VALID BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FIFOPAGE_INFO (Offset 0x0204) */
#define BIT_SHIFT_LPQ_AVAL_PG 8
#define BIT_MASK_LPQ_AVAL_PG 0xff
#define BIT_LPQ_AVAL_PG(x) \
(((x) & BIT_MASK_LPQ_AVAL_PG) << BIT_SHIFT_LPQ_AVAL_PG)
#define BITS_LPQ_AVAL_PG (BIT_MASK_LPQ_AVAL_PG << BIT_SHIFT_LPQ_AVAL_PG)
#define BIT_CLEAR_LPQ_AVAL_PG(x) ((x) & (~BITS_LPQ_AVAL_PG))
#define BIT_GET_LPQ_AVAL_PG(x) \
(((x) >> BIT_SHIFT_LPQ_AVAL_PG) & BIT_MASK_LPQ_AVAL_PG)
#define BIT_SET_LPQ_AVAL_PG(x, v) \
(BIT_CLEAR_LPQ_AVAL_PG(x) | BIT_LPQ_AVAL_PG(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_1 (Offset 0x0204) */
#define BIT_TDE_ERROR_STOP BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FIFOPAGE_INFO (Offset 0x0204) */
#define BIT_SHIFT_HPQ_AVAL_PG 0
#define BIT_MASK_HPQ_AVAL_PG 0xff
#define BIT_HPQ_AVAL_PG(x) \
(((x) & BIT_MASK_HPQ_AVAL_PG) << BIT_SHIFT_HPQ_AVAL_PG)
#define BITS_HPQ_AVAL_PG (BIT_MASK_HPQ_AVAL_PG << BIT_SHIFT_HPQ_AVAL_PG)
#define BIT_CLEAR_HPQ_AVAL_PG(x) ((x) & (~BITS_HPQ_AVAL_PG))
#define BIT_GET_HPQ_AVAL_PG(x) \
(((x) >> BIT_SHIFT_HPQ_AVAL_PG) & BIT_MASK_HPQ_AVAL_PG)
#define BIT_SET_HPQ_AVAL_PG(x, v) \
(BIT_CLEAR_HPQ_AVAL_PG(x) | BIT_HPQ_AVAL_PG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_2 (Offset 0x0204) */
#define BIT_SHIFT_BCN_HEAD_V1 0
#define BIT_MASK_BCN_HEAD_V1 0xfff
#define BIT_BCN_HEAD_V1(x) \
(((x) & BIT_MASK_BCN_HEAD_V1) << BIT_SHIFT_BCN_HEAD_V1)
#define BITS_BCN_HEAD_V1 (BIT_MASK_BCN_HEAD_V1 << BIT_SHIFT_BCN_HEAD_V1)
#define BIT_CLEAR_BCN_HEAD_V1(x) ((x) & (~BITS_BCN_HEAD_V1))
#define BIT_GET_BCN_HEAD_V1(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_V1) & BIT_MASK_BCN_HEAD_V1)
#define BIT_SET_BCN_HEAD_V1(x, v) \
(BIT_CLEAR_BCN_HEAD_V1(x) | BIT_BCN_HEAD_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_1 (Offset 0x0204) */
#define BIT_SHIFT_BCN2_HEAD 0
#define BIT_MASK_BCN2_HEAD 0xfff
#define BIT_BCN2_HEAD(x) (((x) & BIT_MASK_BCN2_HEAD) << BIT_SHIFT_BCN2_HEAD)
#define BITS_BCN2_HEAD (BIT_MASK_BCN2_HEAD << BIT_SHIFT_BCN2_HEAD)
#define BIT_CLEAR_BCN2_HEAD(x) ((x) & (~BITS_BCN2_HEAD))
#define BIT_GET_BCN2_HEAD(x) (((x) >> BIT_SHIFT_BCN2_HEAD) & BIT_MASK_BCN2_HEAD)
#define BIT_SET_BCN2_HEAD(x, v) (BIT_CLEAR_BCN2_HEAD(x) | BIT_BCN2_HEAD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DWBCN0_CTRL (Offset 0x0208) */
#define BIT_SHIFT_LLT_FREE_PAGE 24
#define BIT_MASK_LLT_FREE_PAGE 0xff
#define BIT_LLT_FREE_PAGE(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE) << BIT_SHIFT_LLT_FREE_PAGE)
#define BITS_LLT_FREE_PAGE (BIT_MASK_LLT_FREE_PAGE << BIT_SHIFT_LLT_FREE_PAGE)
#define BIT_CLEAR_LLT_FREE_PAGE(x) ((x) & (~BITS_LLT_FREE_PAGE))
#define BIT_GET_LLT_FREE_PAGE(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE) & BIT_MASK_LLT_FREE_PAGE)
#define BIT_SET_LLT_FREE_PAGE(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE(x) | BIT_LLT_FREE_PAGE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1 24
#define BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1 0xff
#define BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1(x) \
(((x) & BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1) \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1)
#define BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1 \
(BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1 \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1)
#define BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1(x) \
((x) & (~BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1))
#define BIT_GET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1) & \
BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1)
#define BIT_SET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1(x, v) \
(BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1(x) | \
BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_SHIFT_MAX_TX_PKT_V1 24
#define BIT_MASK_MAX_TX_PKT_V1 0xff
#define BIT_MAX_TX_PKT_V1(x) \
(((x) & BIT_MASK_MAX_TX_PKT_V1) << BIT_SHIFT_MAX_TX_PKT_V1)
#define BITS_MAX_TX_PKT_V1 (BIT_MASK_MAX_TX_PKT_V1 << BIT_SHIFT_MAX_TX_PKT_V1)
#define BIT_CLEAR_MAX_TX_PKT_V1(x) ((x) & (~BITS_MAX_TX_PKT_V1))
#define BIT_GET_MAX_TX_PKT_V1(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_V1) & BIT_MASK_MAX_TX_PKT_V1)
#define BIT_SET_MAX_TX_PKT_V1(x, v) \
(BIT_CLEAR_MAX_TX_PKT_V1(x) | BIT_MAX_TX_PKT_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_TDE_ERROR_STOP_V1 BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DWBCN0_CTRL (Offset 0x0208) */
#define BIT_BCN_VALID BIT(16)
#define BIT_SHIFT_BCN_HEAD 8
#define BIT_MASK_BCN_HEAD 0xff
#define BIT_BCN_HEAD(x) (((x) & BIT_MASK_BCN_HEAD) << BIT_SHIFT_BCN_HEAD)
#define BITS_BCN_HEAD (BIT_MASK_BCN_HEAD << BIT_SHIFT_BCN_HEAD)
#define BIT_CLEAR_BCN_HEAD(x) ((x) & (~BITS_BCN_HEAD))
#define BIT_GET_BCN_HEAD(x) (((x) >> BIT_SHIFT_BCN_HEAD) & BIT_MASK_BCN_HEAD)
#define BIT_SET_BCN_HEAD(x, v) (BIT_CLEAR_BCN_HEAD(x) | BIT_BCN_HEAD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_SHIFT_LLT_FREE_PAGE_V1 8
#define BIT_MASK_LLT_FREE_PAGE_V1 0xffff
#define BIT_LLT_FREE_PAGE_V1(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V1) << BIT_SHIFT_LLT_FREE_PAGE_V1)
#define BITS_LLT_FREE_PAGE_V1 \
(BIT_MASK_LLT_FREE_PAGE_V1 << BIT_SHIFT_LLT_FREE_PAGE_V1)
#define BIT_CLEAR_LLT_FREE_PAGE_V1(x) ((x) & (~BITS_LLT_FREE_PAGE_V1))
#define BIT_GET_LLT_FREE_PAGE_V1(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V1) & BIT_MASK_LLT_FREE_PAGE_V1)
#define BIT_SET_LLT_FREE_PAGE_V1(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V1(x) | BIT_LLT_FREE_PAGE_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_SHIFT_LLT_FREE_PAGE_V2 8
#define BIT_MASK_LLT_FREE_PAGE_V2 0xfff
#define BIT_LLT_FREE_PAGE_V2(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V2) << BIT_SHIFT_LLT_FREE_PAGE_V2)
#define BITS_LLT_FREE_PAGE_V2 \
(BIT_MASK_LLT_FREE_PAGE_V2 << BIT_SHIFT_LLT_FREE_PAGE_V2)
#define BIT_CLEAR_LLT_FREE_PAGE_V2(x) ((x) & (~BITS_LLT_FREE_PAGE_V2))
#define BIT_GET_LLT_FREE_PAGE_V2(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V2) & BIT_MASK_LLT_FREE_PAGE_V2)
#define BIT_SET_LLT_FREE_PAGE_V2(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V2(x) | BIT_LLT_FREE_PAGE_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_SHIFT_BLK_DESC_NUM 4
#define BIT_MASK_BLK_DESC_NUM 0xf
#define BIT_BLK_DESC_NUM(x) \
(((x) & BIT_MASK_BLK_DESC_NUM) << BIT_SHIFT_BLK_DESC_NUM)
#define BITS_BLK_DESC_NUM (BIT_MASK_BLK_DESC_NUM << BIT_SHIFT_BLK_DESC_NUM)
#define BIT_CLEAR_BLK_DESC_NUM(x) ((x) & (~BITS_BLK_DESC_NUM))
#define BIT_GET_BLK_DESC_NUM(x) \
(((x) >> BIT_SHIFT_BLK_DESC_NUM) & BIT_MASK_BLK_DESC_NUM)
#define BIT_SET_BLK_DESC_NUM(x, v) \
(BIT_CLEAR_BLK_DESC_NUM(x) | BIT_BLK_DESC_NUM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_R_BCN_HEAD_SEL BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_R_EN_BCN_SW_HEAD_SEL BIT(2)
#define BIT_LLT_DBG_SEL BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DWBCN0_CTRL (Offset 0x0208) */
#define BIT_BLK_DESC_OPT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_AUTO_LLT_V1 (Offset 0x0208) */
#define BIT_AUTO_INIT_LLT_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EM_CHKSUM_FIN BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EN_CHKSUM_ERR_FIN BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EMN_PCIE_DMA_MOD BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EN_PCIE_DMA_MOD BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EN_TXQUE_CLR BIT(29)
#define BIT_EN_PCIE_FIFO_MODE BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_SHIFT_PG_UNDER_TH 16
#define BIT_MASK_PG_UNDER_TH 0xff
#define BIT_PG_UNDER_TH(x) \
(((x) & BIT_MASK_PG_UNDER_TH) << BIT_SHIFT_PG_UNDER_TH)
#define BITS_PG_UNDER_TH (BIT_MASK_PG_UNDER_TH << BIT_SHIFT_PG_UNDER_TH)
#define BIT_CLEAR_PG_UNDER_TH(x) ((x) & (~BITS_PG_UNDER_TH))
#define BIT_GET_PG_UNDER_TH(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH) & BIT_MASK_PG_UNDER_TH)
#define BIT_SET_PG_UNDER_TH(x, v) \
(BIT_CLEAR_PG_UNDER_TH(x) | BIT_PG_UNDER_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_SHIFT_PG_UNDER_TH_V2 16
#define BIT_MASK_PG_UNDER_TH_V2 0xff
#define BIT_PG_UNDER_TH_V2(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V2) << BIT_SHIFT_PG_UNDER_TH_V2)
#define BITS_PG_UNDER_TH_V2 \
(BIT_MASK_PG_UNDER_TH_V2 << BIT_SHIFT_PG_UNDER_TH_V2)
#define BIT_CLEAR_PG_UNDER_TH_V2(x) ((x) & (~BITS_PG_UNDER_TH_V2))
#define BIT_GET_PG_UNDER_TH_V2(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V2) & BIT_MASK_PG_UNDER_TH_V2)
#define BIT_SET_PG_UNDER_TH_V2(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V2(x) | BIT_PG_UNDER_TH_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_SHIFT_PG_UNDER_TH_V1 16
#define BIT_MASK_PG_UNDER_TH_V1 0xfff
#define BIT_PG_UNDER_TH_V1(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V1) << BIT_SHIFT_PG_UNDER_TH_V1)
#define BITS_PG_UNDER_TH_V1 \
(BIT_MASK_PG_UNDER_TH_V1 << BIT_SHIFT_PG_UNDER_TH_V1)
#define BIT_CLEAR_PG_UNDER_TH_V1(x) ((x) & (~BITS_PG_UNDER_TH_V1))
#define BIT_GET_PG_UNDER_TH_V1(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V1) & BIT_MASK_PG_UNDER_TH_V1)
#define BIT_SET_PG_UNDER_TH_V1(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V1(x) | BIT_PG_UNDER_TH_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EN_RESTORE_H2C_BY_RST BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_EN_RESET_RESTORE_H2C BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_R_EN_RESET_RESTORE_H2C BIT(15)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_RESTORE_H2C_ADDRESS BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_SDIO_TDE_FINISH BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_OFFSET_CHK (Offset 0x020C) */
#define BIT_SDIO_TXDESC_CHKSUM_EN BIT(13)
#define BIT_RST_RDPTR BIT(12)
#define BIT_RST_WRPTR BIT(11)
#define BIT_CHK_PG_TH_EN BIT(10)
#define BIT_DROP_DATA_EN BIT(9)
#define BIT_CHECK_OFFSET_EN BIT(8)
#define BIT_SHIFT_CHECK_OFFSET 0
#define BIT_MASK_CHECK_OFFSET 0xff
#define BIT_CHECK_OFFSET(x) \
(((x) & BIT_MASK_CHECK_OFFSET) << BIT_SHIFT_CHECK_OFFSET)
#define BITS_CHECK_OFFSET (BIT_MASK_CHECK_OFFSET << BIT_SHIFT_CHECK_OFFSET)
#define BIT_CLEAR_CHECK_OFFSET(x) ((x) & (~BITS_CHECK_OFFSET))
#define BIT_GET_CHECK_OFFSET(x) \
(((x) >> BIT_SHIFT_CHECK_OFFSET) & BIT_MASK_CHECK_OFFSET)
#define BIT_SET_CHECK_OFFSET(x, v) \
(BIT_CLEAR_CHECK_OFFSET(x) | BIT_CHECK_OFFSET(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_LD_RQPN BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_AMSDU_PKT_SIZE_ERR BIT(31)
#define BIT_AMSDU_EN_ERR BIT(30)
#define BIT_CHKSUM_AMSDU_EN_ERR BIT(29)
#define BIT_TXPKTBF_REQ_ERR BIT(28)
#define BIT_OQT_UDN_16 BIT(27)
#define BIT_OQT_OVF_16 BIT(26)
#define BIT_OQT_UDN_14_15 BIT(25)
#define BIT_OQT_OVF_14_15 BIT(24)
#define BIT_OQT_UDN_13 BIT(23)
#define BIT_OQT_OVF_13 BIT(22)
#define BIT_OQT_UDN_12 BIT(21)
#define BIT_OQT_OVF_12 BIT(20)
#define BIT_OQT_UDN_8_11 BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXPKTBUF_REQ_ERR BIT(18)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_OQT_OVF_8_11 BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_HI_OQT_UDN BIT(17)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_OQT_UDN_4_7 BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_HI_OQT_OVF BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_OQT_OVF_4_7 BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_PAYLOAD_CHKSUM_ERR BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_RX_CLOSE_EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_PAYLOAD_UDN BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_BCNQ BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_PAYLOAD_OVF BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_MGQ BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_DSC_CHKSUM_FAIL BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_VOQ BIT(12)
#define BIT_UNKNOWN_QSEL BIT(11)
#define BIT_STOP_VIQ BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_EP_QSEL_DIFF BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_BEQ BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TX_OFFS_UNMATCH BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_BKQ BIT(9)
#define BIT_TXOQT_UDN BIT(8)
#define BIT_STOP_RXQ BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXOQT_UDN_0_3 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXOQT_OVF BIT(7)
#define BIT_STOP_HI7Q BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXOQT_OVF_0_3 BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXDMA_SFF_UDN BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI6Q BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXDMA_SFF_OVF BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI5Q BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_LLT_NULL_PG BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI4Q BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_PAGE_UDN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI3Q BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_PAGE_OVF BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI2Q BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXFF_PG_UDN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI1Q BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_TXFF_PG_OVF BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXDMA_STATUS (Offset 0x0210) */
#define BIT_STOP_HI0Q BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RQPN_NPQ (Offset 0x0214) */
#define BIT_SHIFT_EXQ_AVAL_PG 24
#define BIT_MASK_EXQ_AVAL_PG 0xff
#define BIT_EXQ_AVAL_PG(x) \
(((x) & BIT_MASK_EXQ_AVAL_PG) << BIT_SHIFT_EXQ_AVAL_PG)
#define BITS_EXQ_AVAL_PG (BIT_MASK_EXQ_AVAL_PG << BIT_SHIFT_EXQ_AVAL_PG)
#define BIT_CLEAR_EXQ_AVAL_PG(x) ((x) & (~BITS_EXQ_AVAL_PG))
#define BIT_GET_EXQ_AVAL_PG(x) \
(((x) >> BIT_SHIFT_EXQ_AVAL_PG) & BIT_MASK_EXQ_AVAL_PG)
#define BIT_SET_EXQ_AVAL_PG(x, v) \
(BIT_CLEAR_EXQ_AVAL_PG(x) | BIT_EXQ_AVAL_PG(v))
#define BIT_SHIFT_EXQ 16
#define BIT_MASK_EXQ 0xff
#define BIT_EXQ(x) (((x) & BIT_MASK_EXQ) << BIT_SHIFT_EXQ)
#define BITS_EXQ (BIT_MASK_EXQ << BIT_SHIFT_EXQ)
#define BIT_CLEAR_EXQ(x) ((x) & (~BITS_EXQ))
#define BIT_GET_EXQ(x) (((x) >> BIT_SHIFT_EXQ) & BIT_MASK_EXQ)
#define BIT_SET_EXQ(x, v) (BIT_CLEAR_EXQ(x) | BIT_EXQ(v))
#define BIT_SHIFT_NPQ 0
#define BIT_MASK_NPQ 0xff
#define BIT_NPQ(x) (((x) & BIT_MASK_NPQ) << BIT_SHIFT_NPQ)
#define BITS_NPQ (BIT_MASK_NPQ << BIT_SHIFT_NPQ)
#define BIT_CLEAR_NPQ(x) ((x) & (~BITS_NPQ))
#define BIT_GET_NPQ(x) (((x) >> BIT_SHIFT_NPQ) & BIT_MASK_NPQ)
#define BIT_SET_NPQ(x, v) (BIT_CLEAR_NPQ(x) | BIT_NPQ(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT1 (Offset 0x0218) */
#define BIT_HPQ_INT_EN BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TQPNT1 (Offset 0x0218) */
#define BIT_SHIFT_NPQ_HIGH_TH 24
#define BIT_MASK_NPQ_HIGH_TH 0xff
#define BIT_NPQ_HIGH_TH(x) \
(((x) & BIT_MASK_NPQ_HIGH_TH) << BIT_SHIFT_NPQ_HIGH_TH)
#define BITS_NPQ_HIGH_TH (BIT_MASK_NPQ_HIGH_TH << BIT_SHIFT_NPQ_HIGH_TH)
#define BIT_CLEAR_NPQ_HIGH_TH(x) ((x) & (~BITS_NPQ_HIGH_TH))
#define BIT_GET_NPQ_HIGH_TH(x) \
(((x) >> BIT_SHIFT_NPQ_HIGH_TH) & BIT_MASK_NPQ_HIGH_TH)
#define BIT_SET_NPQ_HIGH_TH(x, v) \
(BIT_CLEAR_NPQ_HIGH_TH(x) | BIT_NPQ_HIGH_TH(v))
#define BIT_SHIFT_NPQ_LOW_TH 16
#define BIT_MASK_NPQ_LOW_TH 0xff
#define BIT_NPQ_LOW_TH(x) (((x) & BIT_MASK_NPQ_LOW_TH) << BIT_SHIFT_NPQ_LOW_TH)
#define BITS_NPQ_LOW_TH (BIT_MASK_NPQ_LOW_TH << BIT_SHIFT_NPQ_LOW_TH)
#define BIT_CLEAR_NPQ_LOW_TH(x) ((x) & (~BITS_NPQ_LOW_TH))
#define BIT_GET_NPQ_LOW_TH(x) \
(((x) >> BIT_SHIFT_NPQ_LOW_TH) & BIT_MASK_NPQ_LOW_TH)
#define BIT_SET_NPQ_LOW_TH(x, v) (BIT_CLEAR_NPQ_LOW_TH(x) | BIT_NPQ_LOW_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT1 (Offset 0x0218) */
#define BIT_SHIFT_HPQ_HIGH_TH_V1 16
#define BIT_MASK_HPQ_HIGH_TH_V1 0xfff
#define BIT_HPQ_HIGH_TH_V1(x) \
(((x) & BIT_MASK_HPQ_HIGH_TH_V1) << BIT_SHIFT_HPQ_HIGH_TH_V1)
#define BITS_HPQ_HIGH_TH_V1 \
(BIT_MASK_HPQ_HIGH_TH_V1 << BIT_SHIFT_HPQ_HIGH_TH_V1)
#define BIT_CLEAR_HPQ_HIGH_TH_V1(x) ((x) & (~BITS_HPQ_HIGH_TH_V1))
#define BIT_GET_HPQ_HIGH_TH_V1(x) \
(((x) >> BIT_SHIFT_HPQ_HIGH_TH_V1) & BIT_MASK_HPQ_HIGH_TH_V1)
#define BIT_SET_HPQ_HIGH_TH_V1(x, v) \
(BIT_CLEAR_HPQ_HIGH_TH_V1(x) | BIT_HPQ_HIGH_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DMA_RQPN_INFO_PUB (Offset 0x0218) */
#define BIT_SHIFT_PUB_AVAL_PG 16
#define BIT_MASK_PUB_AVAL_PG 0xfff
#define BIT_PUB_AVAL_PG(x) \
(((x) & BIT_MASK_PUB_AVAL_PG) << BIT_SHIFT_PUB_AVAL_PG)
#define BITS_PUB_AVAL_PG (BIT_MASK_PUB_AVAL_PG << BIT_SHIFT_PUB_AVAL_PG)
#define BIT_CLEAR_PUB_AVAL_PG(x) ((x) & (~BITS_PUB_AVAL_PG))
#define BIT_GET_PUB_AVAL_PG(x) \
(((x) >> BIT_SHIFT_PUB_AVAL_PG) & BIT_MASK_PUB_AVAL_PG)
#define BIT_SET_PUB_AVAL_PG(x, v) \
(BIT_CLEAR_PUB_AVAL_PG(x) | BIT_PUB_AVAL_PG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TQPNT1 (Offset 0x0218) */
#define BIT_SHIFT_HPQ_HIGH_TH 8
#define BIT_MASK_HPQ_HIGH_TH 0xff
#define BIT_HPQ_HIGH_TH(x) \
(((x) & BIT_MASK_HPQ_HIGH_TH) << BIT_SHIFT_HPQ_HIGH_TH)
#define BITS_HPQ_HIGH_TH (BIT_MASK_HPQ_HIGH_TH << BIT_SHIFT_HPQ_HIGH_TH)
#define BIT_CLEAR_HPQ_HIGH_TH(x) ((x) & (~BITS_HPQ_HIGH_TH))
#define BIT_GET_HPQ_HIGH_TH(x) \
(((x) >> BIT_SHIFT_HPQ_HIGH_TH) & BIT_MASK_HPQ_HIGH_TH)
#define BIT_SET_HPQ_HIGH_TH(x, v) \
(BIT_CLEAR_HPQ_HIGH_TH(x) | BIT_HPQ_HIGH_TH(v))
#define BIT_SHIFT_HPQ_LOW_TH 0
#define BIT_MASK_HPQ_LOW_TH 0xff
#define BIT_HPQ_LOW_TH(x) (((x) & BIT_MASK_HPQ_LOW_TH) << BIT_SHIFT_HPQ_LOW_TH)
#define BITS_HPQ_LOW_TH (BIT_MASK_HPQ_LOW_TH << BIT_SHIFT_HPQ_LOW_TH)
#define BIT_CLEAR_HPQ_LOW_TH(x) ((x) & (~BITS_HPQ_LOW_TH))
#define BIT_GET_HPQ_LOW_TH(x) \
(((x) >> BIT_SHIFT_HPQ_LOW_TH) & BIT_MASK_HPQ_LOW_TH)
#define BIT_SET_HPQ_LOW_TH(x, v) (BIT_CLEAR_HPQ_LOW_TH(x) | BIT_HPQ_LOW_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT1 (Offset 0x0218) */
#define BIT_SHIFT_HPQ_LOW_TH_V1 0
#define BIT_MASK_HPQ_LOW_TH_V1 0xfff
#define BIT_HPQ_LOW_TH_V1(x) \
(((x) & BIT_MASK_HPQ_LOW_TH_V1) << BIT_SHIFT_HPQ_LOW_TH_V1)
#define BITS_HPQ_LOW_TH_V1 (BIT_MASK_HPQ_LOW_TH_V1 << BIT_SHIFT_HPQ_LOW_TH_V1)
#define BIT_CLEAR_HPQ_LOW_TH_V1(x) ((x) & (~BITS_HPQ_LOW_TH_V1))
#define BIT_GET_HPQ_LOW_TH_V1(x) \
(((x) >> BIT_SHIFT_HPQ_LOW_TH_V1) & BIT_MASK_HPQ_LOW_TH_V1)
#define BIT_SET_HPQ_LOW_TH_V1(x, v) \
(BIT_CLEAR_HPQ_LOW_TH_V1(x) | BIT_HPQ_LOW_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DMA_RQPN_INFO_PUB (Offset 0x0218) */
#define BIT_SHIFT_PUB_RSVD_PG 0
#define BIT_MASK_PUB_RSVD_PG 0xfff
#define BIT_PUB_RSVD_PG(x) \
(((x) & BIT_MASK_PUB_RSVD_PG) << BIT_SHIFT_PUB_RSVD_PG)
#define BITS_PUB_RSVD_PG (BIT_MASK_PUB_RSVD_PG << BIT_SHIFT_PUB_RSVD_PG)
#define BIT_CLEAR_PUB_RSVD_PG(x) ((x) & (~BITS_PUB_RSVD_PG))
#define BIT_GET_PUB_RSVD_PG(x) \
(((x) >> BIT_SHIFT_PUB_RSVD_PG) & BIT_MASK_PUB_RSVD_PG)
#define BIT_SET_PUB_RSVD_PG(x, v) \
(BIT_CLEAR_PUB_RSVD_PG(x) | BIT_PUB_RSVD_PG(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT2 (Offset 0x021C) */
#define BIT_NPQ_INT_EN BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RQPN_CTRL_2_V1 (Offset 0x021C) */
#define BIT_LD_RQPN_V1 BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TQPNT2 (Offset 0x021C) */
#define BIT_SHIFT_EXQ_HIGH_TH 24
#define BIT_MASK_EXQ_HIGH_TH 0xff
#define BIT_EXQ_HIGH_TH(x) \
(((x) & BIT_MASK_EXQ_HIGH_TH) << BIT_SHIFT_EXQ_HIGH_TH)
#define BITS_EXQ_HIGH_TH (BIT_MASK_EXQ_HIGH_TH << BIT_SHIFT_EXQ_HIGH_TH)
#define BIT_CLEAR_EXQ_HIGH_TH(x) ((x) & (~BITS_EXQ_HIGH_TH))
#define BIT_GET_EXQ_HIGH_TH(x) \
(((x) >> BIT_SHIFT_EXQ_HIGH_TH) & BIT_MASK_EXQ_HIGH_TH)
#define BIT_SET_EXQ_HIGH_TH(x, v) \
(BIT_CLEAR_EXQ_HIGH_TH(x) | BIT_EXQ_HIGH_TH(v))
#define BIT_SHIFT_EXQ_LOW_TH 16
#define BIT_MASK_EXQ_LOW_TH 0xff
#define BIT_EXQ_LOW_TH(x) (((x) & BIT_MASK_EXQ_LOW_TH) << BIT_SHIFT_EXQ_LOW_TH)
#define BITS_EXQ_LOW_TH (BIT_MASK_EXQ_LOW_TH << BIT_SHIFT_EXQ_LOW_TH)
#define BIT_CLEAR_EXQ_LOW_TH(x) ((x) & (~BITS_EXQ_LOW_TH))
#define BIT_GET_EXQ_LOW_TH(x) \
(((x) >> BIT_SHIFT_EXQ_LOW_TH) & BIT_MASK_EXQ_LOW_TH)
#define BIT_SET_EXQ_LOW_TH(x, v) (BIT_CLEAR_EXQ_LOW_TH(x) | BIT_EXQ_LOW_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT2 (Offset 0x021C) */
#define BIT_SHIFT_NPQ_HIGH_TH_V1 16
#define BIT_MASK_NPQ_HIGH_TH_V1 0xfff
#define BIT_NPQ_HIGH_TH_V1(x) \
(((x) & BIT_MASK_NPQ_HIGH_TH_V1) << BIT_SHIFT_NPQ_HIGH_TH_V1)
#define BITS_NPQ_HIGH_TH_V1 \
(BIT_MASK_NPQ_HIGH_TH_V1 << BIT_SHIFT_NPQ_HIGH_TH_V1)
#define BIT_CLEAR_NPQ_HIGH_TH_V1(x) ((x) & (~BITS_NPQ_HIGH_TH_V1))
#define BIT_GET_NPQ_HIGH_TH_V1(x) \
(((x) >> BIT_SHIFT_NPQ_HIGH_TH_V1) & BIT_MASK_NPQ_HIGH_TH_V1)
#define BIT_SET_NPQ_HIGH_TH_V1(x, v) \
(BIT_CLEAR_NPQ_HIGH_TH_V1(x) | BIT_NPQ_HIGH_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RQPN_CTRL_2_V1 (Offset 0x021C) */
#define BIT_CH16_PUBLIC_DIS BIT(16)
#define BIT_CH15_PUBLIC_DIS BIT(15)
#define BIT_CH14_PUBLIC_DIS BIT(14)
#define BIT_CH13_PUBLIC_DIS BIT(13)
#define BIT_CH12_PUBLIC_DIS BIT(12)
#define BIT_CH11_PUBLIC_DIS BIT(11)
#define BIT_CH10_PUBLIC_DIS BIT(10)
#define BIT_CH9_PUBLIC_DIS BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TQPNT2 (Offset 0x021C) */
#define BIT_SHIFT_LPQ_HIGH_TH 8
#define BIT_MASK_LPQ_HIGH_TH 0xff
#define BIT_LPQ_HIGH_TH(x) \
(((x) & BIT_MASK_LPQ_HIGH_TH) << BIT_SHIFT_LPQ_HIGH_TH)
#define BITS_LPQ_HIGH_TH (BIT_MASK_LPQ_HIGH_TH << BIT_SHIFT_LPQ_HIGH_TH)
#define BIT_CLEAR_LPQ_HIGH_TH(x) ((x) & (~BITS_LPQ_HIGH_TH))
#define BIT_GET_LPQ_HIGH_TH(x) \
(((x) >> BIT_SHIFT_LPQ_HIGH_TH) & BIT_MASK_LPQ_HIGH_TH)
#define BIT_SET_LPQ_HIGH_TH(x, v) \
(BIT_CLEAR_LPQ_HIGH_TH(x) | BIT_LPQ_HIGH_TH(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RQPN_CTRL_2_V1 (Offset 0x021C) */
#define BIT_CH8_PUBLIC_DIS BIT(8)
#define BIT_CH7_PUBLIC_DIS BIT(7)
#define BIT_CH6_PUBLIC_DIS BIT(6)
#define BIT_CH5_PUBLIC_DIS BIT(5)
#define BIT_CH4_PUBLIC_DIS BIT(4)
#define BIT_CH3_PUBLIC_DIS BIT(3)
#define BIT_CH2_PUBLIC_DIS BIT(2)
#define BIT_CH1_PUBLIC_DIS BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TQPNT2 (Offset 0x021C) */
#define BIT_SHIFT_LPQ_LOW_TH 0
#define BIT_MASK_LPQ_LOW_TH 0xff
#define BIT_LPQ_LOW_TH(x) (((x) & BIT_MASK_LPQ_LOW_TH) << BIT_SHIFT_LPQ_LOW_TH)
#define BITS_LPQ_LOW_TH (BIT_MASK_LPQ_LOW_TH << BIT_SHIFT_LPQ_LOW_TH)
#define BIT_CLEAR_LPQ_LOW_TH(x) ((x) & (~BITS_LPQ_LOW_TH))
#define BIT_GET_LPQ_LOW_TH(x) \
(((x) >> BIT_SHIFT_LPQ_LOW_TH) & BIT_MASK_LPQ_LOW_TH)
#define BIT_SET_LPQ_LOW_TH(x, v) (BIT_CLEAR_LPQ_LOW_TH(x) | BIT_LPQ_LOW_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT2 (Offset 0x021C) */
#define BIT_SHIFT_NPQ_LOW_TH_V1 0
#define BIT_MASK_NPQ_LOW_TH_V1 0xfff
#define BIT_NPQ_LOW_TH_V1(x) \
(((x) & BIT_MASK_NPQ_LOW_TH_V1) << BIT_SHIFT_NPQ_LOW_TH_V1)
#define BITS_NPQ_LOW_TH_V1 (BIT_MASK_NPQ_LOW_TH_V1 << BIT_SHIFT_NPQ_LOW_TH_V1)
#define BIT_CLEAR_NPQ_LOW_TH_V1(x) ((x) & (~BITS_NPQ_LOW_TH_V1))
#define BIT_GET_NPQ_LOW_TH_V1(x) \
(((x) >> BIT_SHIFT_NPQ_LOW_TH_V1) & BIT_MASK_NPQ_LOW_TH_V1)
#define BIT_SET_NPQ_LOW_TH_V1(x, v) \
(BIT_CLEAR_NPQ_LOW_TH_V1(x) | BIT_NPQ_LOW_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RQPN_CTRL_2_V1 (Offset 0x021C) */
#define BIT_CH0_PUBLIC_DIS BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT3 (Offset 0x0220) */
#define BIT_LPQ_INT_EN BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_2 (Offset 0x0220) */
#define BIT_BCN0_EXT_VALID BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT3 (Offset 0x0220) */
#define BIT_SHIFT_LPQ_HIGH_TH_V1 16
#define BIT_MASK_LPQ_HIGH_TH_V1 0xfff
#define BIT_LPQ_HIGH_TH_V1(x) \
(((x) & BIT_MASK_LPQ_HIGH_TH_V1) << BIT_SHIFT_LPQ_HIGH_TH_V1)
#define BITS_LPQ_HIGH_TH_V1 \
(BIT_MASK_LPQ_HIGH_TH_V1 << BIT_SHIFT_LPQ_HIGH_TH_V1)
#define BIT_CLEAR_LPQ_HIGH_TH_V1(x) ((x) & (~BITS_LPQ_HIGH_TH_V1))
#define BIT_GET_LPQ_HIGH_TH_V1(x) \
(((x) >> BIT_SHIFT_LPQ_HIGH_TH_V1) & BIT_MASK_LPQ_HIGH_TH_V1)
#define BIT_SET_LPQ_HIGH_TH_V1(x, v) \
(BIT_CLEAR_LPQ_HIGH_TH_V1(x) | BIT_LPQ_HIGH_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_2 (Offset 0x0220) */
#define BIT_SHIFT_BCN0_EXT_HEAD 16
#define BIT_MASK_BCN0_EXT_HEAD 0xfff
#define BIT_BCN0_EXT_HEAD(x) \
(((x) & BIT_MASK_BCN0_EXT_HEAD) << BIT_SHIFT_BCN0_EXT_HEAD)
#define BITS_BCN0_EXT_HEAD (BIT_MASK_BCN0_EXT_HEAD << BIT_SHIFT_BCN0_EXT_HEAD)
#define BIT_CLEAR_BCN0_EXT_HEAD(x) ((x) & (~BITS_BCN0_EXT_HEAD))
#define BIT_GET_BCN0_EXT_HEAD(x) \
(((x) >> BIT_SHIFT_BCN0_EXT_HEAD) & BIT_MASK_BCN0_EXT_HEAD)
#define BIT_SET_BCN0_EXT_HEAD(x, v) \
(BIT_CLEAR_BCN0_EXT_HEAD(x) | BIT_BCN0_EXT_HEAD(v))
#define BIT_SHIFT_TXPKTNUM_CH4_7 16
#define BIT_MASK_TXPKTNUM_CH4_7 0xfff
#define BIT_TXPKTNUM_CH4_7(x) \
(((x) & BIT_MASK_TXPKTNUM_CH4_7) << BIT_SHIFT_TXPKTNUM_CH4_7)
#define BITS_TXPKTNUM_CH4_7 \
(BIT_MASK_TXPKTNUM_CH4_7 << BIT_SHIFT_TXPKTNUM_CH4_7)
#define BIT_CLEAR_TXPKTNUM_CH4_7(x) ((x) & (~BITS_TXPKTNUM_CH4_7))
#define BIT_GET_TXPKTNUM_CH4_7(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH4_7) & BIT_MASK_TXPKTNUM_CH4_7)
#define BIT_SET_TXPKTNUM_CH4_7(x, v) \
(BIT_CLEAR_TXPKTNUM_CH4_7(x) | BIT_TXPKTNUM_CH4_7(v))
#define BIT_SHIFT_TXPKTNUM_CH12 16
#define BIT_MASK_TXPKTNUM_CH12 0xfff
#define BIT_TXPKTNUM_CH12(x) \
(((x) & BIT_MASK_TXPKTNUM_CH12) << BIT_SHIFT_TXPKTNUM_CH12)
#define BITS_TXPKTNUM_CH12 (BIT_MASK_TXPKTNUM_CH12 << BIT_SHIFT_TXPKTNUM_CH12)
#define BIT_CLEAR_TXPKTNUM_CH12(x) ((x) & (~BITS_TXPKTNUM_CH12))
#define BIT_GET_TXPKTNUM_CH12(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH12) & BIT_MASK_TXPKTNUM_CH12)
#define BIT_SET_TXPKTNUM_CH12(x, v) \
(BIT_CLEAR_TXPKTNUM_CH12(x) | BIT_TXPKTNUM_CH12(v))
#define BIT_SHIFT_TXPKTNUM_CH14_15 16
#define BIT_MASK_TXPKTNUM_CH14_15 0xfff
#define BIT_TXPKTNUM_CH14_15(x) \
(((x) & BIT_MASK_TXPKTNUM_CH14_15) << BIT_SHIFT_TXPKTNUM_CH14_15)
#define BITS_TXPKTNUM_CH14_15 \
(BIT_MASK_TXPKTNUM_CH14_15 << BIT_SHIFT_TXPKTNUM_CH14_15)
#define BIT_CLEAR_TXPKTNUM_CH14_15(x) ((x) & (~BITS_TXPKTNUM_CH14_15))
#define BIT_GET_TXPKTNUM_CH14_15(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH14_15) & BIT_MASK_TXPKTNUM_CH14_15)
#define BIT_SET_TXPKTNUM_CH14_15(x, v) \
(BIT_CLEAR_TXPKTNUM_CH14_15(x) | BIT_TXPKTNUM_CH14_15(v))
#define BIT_BCN4_VALID BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TDE_DEBUG (Offset 0x0220) */
#define BIT_SHIFT_TDE_DEBUG 0
#define BIT_MASK_TDE_DEBUG 0xffffffffL
#define BIT_TDE_DEBUG(x) (((x) & BIT_MASK_TDE_DEBUG) << BIT_SHIFT_TDE_DEBUG)
#define BITS_TDE_DEBUG (BIT_MASK_TDE_DEBUG << BIT_SHIFT_TDE_DEBUG)
#define BIT_CLEAR_TDE_DEBUG(x) ((x) & (~BITS_TDE_DEBUG))
#define BIT_GET_TDE_DEBUG(x) (((x) >> BIT_SHIFT_TDE_DEBUG) & BIT_MASK_TDE_DEBUG)
#define BIT_SET_TDE_DEBUG(x, v) (BIT_CLEAR_TDE_DEBUG(x) | BIT_TDE_DEBUG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT3 (Offset 0x0220) */
#define BIT_SHIFT_LPQ_LOW_TH_V1 0
#define BIT_MASK_LPQ_LOW_TH_V1 0xfff
#define BIT_LPQ_LOW_TH_V1(x) \
(((x) & BIT_MASK_LPQ_LOW_TH_V1) << BIT_SHIFT_LPQ_LOW_TH_V1)
#define BITS_LPQ_LOW_TH_V1 (BIT_MASK_LPQ_LOW_TH_V1 << BIT_SHIFT_LPQ_LOW_TH_V1)
#define BIT_CLEAR_LPQ_LOW_TH_V1(x) ((x) & (~BITS_LPQ_LOW_TH_V1))
#define BIT_GET_LPQ_LOW_TH_V1(x) \
(((x) >> BIT_SHIFT_LPQ_LOW_TH_V1) & BIT_MASK_LPQ_LOW_TH_V1)
#define BIT_SET_LPQ_LOW_TH_V1(x, v) \
(BIT_CLEAR_LPQ_LOW_TH_V1(x) | BIT_LPQ_LOW_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_CTRL_2 (Offset 0x0220) */
#define BIT_SHIFT_BCN4_HEAD 0
#define BIT_MASK_BCN4_HEAD 0xfff
#define BIT_BCN4_HEAD(x) (((x) & BIT_MASK_BCN4_HEAD) << BIT_SHIFT_BCN4_HEAD)
#define BITS_BCN4_HEAD (BIT_MASK_BCN4_HEAD << BIT_SHIFT_BCN4_HEAD)
#define BIT_CLEAR_BCN4_HEAD(x) ((x) & (~BITS_BCN4_HEAD))
#define BIT_GET_BCN4_HEAD(x) (((x) >> BIT_SHIFT_BCN4_HEAD) & BIT_MASK_BCN4_HEAD)
#define BIT_SET_BCN4_HEAD(x, v) (BIT_CLEAR_BCN4_HEAD(x) | BIT_BCN4_HEAD(v))
#define BIT_SHIFT_TXPKTNUM_CH0_3 0
#define BIT_MASK_TXPKTNUM_CH0_3 0xfff
#define BIT_TXPKTNUM_CH0_3(x) \
(((x) & BIT_MASK_TXPKTNUM_CH0_3) << BIT_SHIFT_TXPKTNUM_CH0_3)
#define BITS_TXPKTNUM_CH0_3 \
(BIT_MASK_TXPKTNUM_CH0_3 << BIT_SHIFT_TXPKTNUM_CH0_3)
#define BIT_CLEAR_TXPKTNUM_CH0_3(x) ((x) & (~BITS_TXPKTNUM_CH0_3))
#define BIT_GET_TXPKTNUM_CH0_3(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH0_3) & BIT_MASK_TXPKTNUM_CH0_3)
#define BIT_SET_TXPKTNUM_CH0_3(x, v) \
(BIT_CLEAR_TXPKTNUM_CH0_3(x) | BIT_TXPKTNUM_CH0_3(v))
#define BIT_SHIFT_TXPKTNUM_CH8_11 0
#define BIT_MASK_TXPKTNUM_CH8_11 0xfff
#define BIT_TXPKTNUM_CH8_11(x) \
(((x) & BIT_MASK_TXPKTNUM_CH8_11) << BIT_SHIFT_TXPKTNUM_CH8_11)
#define BITS_TXPKTNUM_CH8_11 \
(BIT_MASK_TXPKTNUM_CH8_11 << BIT_SHIFT_TXPKTNUM_CH8_11)
#define BIT_CLEAR_TXPKTNUM_CH8_11(x) ((x) & (~BITS_TXPKTNUM_CH8_11))
#define BIT_GET_TXPKTNUM_CH8_11(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH8_11) & BIT_MASK_TXPKTNUM_CH8_11)
#define BIT_SET_TXPKTNUM_CH8_11(x, v) \
(BIT_CLEAR_TXPKTNUM_CH8_11(x) | BIT_TXPKTNUM_CH8_11(v))
#define BIT_SHIFT_TXPKTNUM_CH13 0
#define BIT_MASK_TXPKTNUM_CH13 0xfff
#define BIT_TXPKTNUM_CH13(x) \
(((x) & BIT_MASK_TXPKTNUM_CH13) << BIT_SHIFT_TXPKTNUM_CH13)
#define BITS_TXPKTNUM_CH13 (BIT_MASK_TXPKTNUM_CH13 << BIT_SHIFT_TXPKTNUM_CH13)
#define BIT_CLEAR_TXPKTNUM_CH13(x) ((x) & (~BITS_TXPKTNUM_CH13))
#define BIT_GET_TXPKTNUM_CH13(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH13) & BIT_MASK_TXPKTNUM_CH13)
#define BIT_SET_TXPKTNUM_CH13(x, v) \
(BIT_CLEAR_TXPKTNUM_CH13(x) | BIT_TXPKTNUM_CH13(v))
#define BIT_SHIFT_TXPKTNUM_CH16 0
#define BIT_MASK_TXPKTNUM_CH16 0xfff
#define BIT_TXPKTNUM_CH16(x) \
(((x) & BIT_MASK_TXPKTNUM_CH16) << BIT_SHIFT_TXPKTNUM_CH16)
#define BITS_TXPKTNUM_CH16 (BIT_MASK_TXPKTNUM_CH16 << BIT_SHIFT_TXPKTNUM_CH16)
#define BIT_CLEAR_TXPKTNUM_CH16(x) ((x) & (~BITS_TXPKTNUM_CH16))
#define BIT_GET_TXPKTNUM_CH16(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH16) & BIT_MASK_TXPKTNUM_CH16)
#define BIT_SET_TXPKTNUM_CH16(x, v) \
(BIT_CLEAR_TXPKTNUM_CH16(x) | BIT_TXPKTNUM_CH16(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT4 (Offset 0x0224) */
#define BIT_EXQ_INT_EN BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AUTO_LLT (Offset 0x0224) */
#define BIT_SHIFT_TXPKTNUM_V1 24
#define BIT_MASK_TXPKTNUM_V1 0xff
#define BIT_TXPKTNUM_V1(x) \
(((x) & BIT_MASK_TXPKTNUM_V1) << BIT_SHIFT_TXPKTNUM_V1)
#define BITS_TXPKTNUM_V1 (BIT_MASK_TXPKTNUM_V1 << BIT_SHIFT_TXPKTNUM_V1)
#define BIT_CLEAR_TXPKTNUM_V1(x) ((x) & (~BITS_TXPKTNUM_V1))
#define BIT_GET_TXPKTNUM_V1(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_V1) & BIT_MASK_TXPKTNUM_V1)
#define BIT_SET_TXPKTNUM_V1(x, v) \
(BIT_CLEAR_TXPKTNUM_V1(x) | BIT_TXPKTNUM_V1(v))
#define BIT_TDE_DBG_SEL BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_AUTO_LLT (Offset 0x0224) */
#define BIT_MASK_QSEL_DIFF BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AUTO_LLT (Offset 0x0224) */
#define BIT_AUTO_INIT_LLT BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT4 (Offset 0x0224) */
#define BIT_SHIFT_EXQ_HIGH_TH_V1 16
#define BIT_MASK_EXQ_HIGH_TH_V1 0xfff
#define BIT_EXQ_HIGH_TH_V1(x) \
(((x) & BIT_MASK_EXQ_HIGH_TH_V1) << BIT_SHIFT_EXQ_HIGH_TH_V1)
#define BITS_EXQ_HIGH_TH_V1 \
(BIT_MASK_EXQ_HIGH_TH_V1 << BIT_SHIFT_EXQ_HIGH_TH_V1)
#define BIT_CLEAR_EXQ_HIGH_TH_V1(x) ((x) & (~BITS_EXQ_HIGH_TH_V1))
#define BIT_GET_EXQ_HIGH_TH_V1(x) \
(((x) >> BIT_SHIFT_EXQ_HIGH_TH_V1) & BIT_MASK_EXQ_HIGH_TH_V1)
#define BIT_SET_EXQ_HIGH_TH_V1(x, v) \
(BIT_CLEAR_EXQ_HIGH_TH_V1(x) | BIT_EXQ_HIGH_TH_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AUTO_LLT (Offset 0x0224) */
#define BIT_SHIFT_TX_OQT_HE_FREE_SPACE 8
#define BIT_MASK_TX_OQT_HE_FREE_SPACE 0xff
#define BIT_TX_OQT_HE_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_HE_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE)
#define BITS_TX_OQT_HE_FREE_SPACE \
(BIT_MASK_TX_OQT_HE_FREE_SPACE << BIT_SHIFT_TX_OQT_HE_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_HE_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_HE_FREE_SPACE))
#define BIT_GET_TX_OQT_HE_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_HE_FREE_SPACE) & \
BIT_MASK_TX_OQT_HE_FREE_SPACE)
#define BIT_SET_TX_OQT_HE_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_HE_FREE_SPACE(x) | BIT_TX_OQT_HE_FREE_SPACE(v))
#define BIT_SHIFT_TX_OQT_NL_FREE_SPACE 0
#define BIT_MASK_TX_OQT_NL_FREE_SPACE 0xff
#define BIT_TX_OQT_NL_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_NL_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE)
#define BITS_TX_OQT_NL_FREE_SPACE \
(BIT_MASK_TX_OQT_NL_FREE_SPACE << BIT_SHIFT_TX_OQT_NL_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_NL_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_NL_FREE_SPACE))
#define BIT_GET_TX_OQT_NL_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_NL_FREE_SPACE) & \
BIT_MASK_TX_OQT_NL_FREE_SPACE)
#define BIT_SET_TX_OQT_NL_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_NL_FREE_SPACE(x) | BIT_TX_OQT_NL_FREE_SPACE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TQPNT4 (Offset 0x0224) */
#define BIT_SHIFT_EXQ_LOW_TH_V1 0
#define BIT_MASK_EXQ_LOW_TH_V1 0xfff
#define BIT_EXQ_LOW_TH_V1(x) \
(((x) & BIT_MASK_EXQ_LOW_TH_V1) << BIT_SHIFT_EXQ_LOW_TH_V1)
#define BITS_EXQ_LOW_TH_V1 (BIT_MASK_EXQ_LOW_TH_V1 << BIT_SHIFT_EXQ_LOW_TH_V1)
#define BIT_CLEAR_EXQ_LOW_TH_V1(x) ((x) & (~BITS_EXQ_LOW_TH_V1))
#define BIT_GET_EXQ_LOW_TH_V1(x) \
(((x) >> BIT_SHIFT_EXQ_LOW_TH_V1) & BIT_MASK_EXQ_LOW_TH_V1)
#define BIT_SET_EXQ_LOW_TH_V1(x, v) \
(BIT_CLEAR_EXQ_LOW_TH_V1(x) | BIT_EXQ_LOW_TH_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SHIFT_BCN_HEAD_2 24
#define BIT_MASK_BCN_HEAD_2 0xff
#define BIT_BCN_HEAD_2(x) (((x) & BIT_MASK_BCN_HEAD_2) << BIT_SHIFT_BCN_HEAD_2)
#define BITS_BCN_HEAD_2 (BIT_MASK_BCN_HEAD_2 << BIT_SHIFT_BCN_HEAD_2)
#define BIT_CLEAR_BCN_HEAD_2(x) ((x) & (~BITS_BCN_HEAD_2))
#define BIT_GET_BCN_HEAD_2(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_2) & BIT_MASK_BCN_HEAD_2)
#define BIT_SET_BCN_HEAD_2(x, v) (BIT_CLEAR_BCN_HEAD_2(x) | BIT_BCN_HEAD_2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SW_BCN_SEL BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SHIFT_SW_BCN_SEL_V1 20
#define BIT_MASK_SW_BCN_SEL_V1 0x3
#define BIT_SW_BCN_SEL_V1(x) \
(((x) & BIT_MASK_SW_BCN_SEL_V1) << BIT_SHIFT_SW_BCN_SEL_V1)
#define BITS_SW_BCN_SEL_V1 (BIT_MASK_SW_BCN_SEL_V1 << BIT_SHIFT_SW_BCN_SEL_V1)
#define BIT_CLEAR_SW_BCN_SEL_V1(x) ((x) & (~BITS_SW_BCN_SEL_V1))
#define BIT_GET_SW_BCN_SEL_V1(x) \
(((x) >> BIT_SHIFT_SW_BCN_SEL_V1) & BIT_MASK_SW_BCN_SEL_V1)
#define BIT_SET_SW_BCN_SEL_V1(x, v) \
(BIT_CLEAR_SW_BCN_SEL_V1(x) | BIT_SW_BCN_SEL_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_ENABLE_GEN_RANDON_SLOT_TX BIT(20)
#define BIT_ENABLE_RANDOM_SHIFT_TX BIT(19)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_BCN_VALID_2 BIT(18)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_ENABLE_EDCA_REF_FUNCTION BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SW_BCN_SEL_EN BIT(17)
#define BIT_BCN_VALID_1 BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_SHIFT_TXPKTNUM_H 16
#define BIT_MASK_TXPKTNUM_H 0xffff
#define BIT_TXPKTNUM_H(x) (((x) & BIT_MASK_TXPKTNUM_H) << BIT_SHIFT_TXPKTNUM_H)
#define BITS_TXPKTNUM_H (BIT_MASK_TXPKTNUM_H << BIT_SHIFT_TXPKTNUM_H)
#define BIT_CLEAR_TXPKTNUM_H(x) ((x) & (~BITS_TXPKTNUM_H))
#define BIT_GET_TXPKTNUM_H(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H) & BIT_MASK_TXPKTNUM_H)
#define BIT_SET_TXPKTNUM_H(x, v) (BIT_CLEAR_TXPKTNUM_H(x) | BIT_TXPKTNUM_H(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_SHIFT_TXPKTNUM_H_V2 16
#define BIT_MASK_TXPKTNUM_H_V2 0xfff
#define BIT_TXPKTNUM_H_V2(x) \
(((x) & BIT_MASK_TXPKTNUM_H_V2) << BIT_SHIFT_TXPKTNUM_H_V2)
#define BITS_TXPKTNUM_H_V2 (BIT_MASK_TXPKTNUM_H_V2 << BIT_SHIFT_TXPKTNUM_H_V2)
#define BIT_CLEAR_TXPKTNUM_H_V2(x) ((x) & (~BITS_TXPKTNUM_H_V2))
#define BIT_GET_TXPKTNUM_H_V2(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_V2) & BIT_MASK_TXPKTNUM_H_V2)
#define BIT_SET_TXPKTNUM_H_V2(x, v) \
(BIT_CLEAR_TXPKTNUM_H_V2(x) | BIT_TXPKTNUM_H_V2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_ADJUSTABLE_SIZE_EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SHIFT_BCN_HEAD_1 8
#define BIT_MASK_BCN_HEAD_1 0xff
#define BIT_BCN_HEAD_1(x) (((x) & BIT_MASK_BCN_HEAD_1) << BIT_SHIFT_BCN_HEAD_1)
#define BITS_BCN_HEAD_1 (BIT_MASK_BCN_HEAD_1 << BIT_SHIFT_BCN_HEAD_1)
#define BIT_CLEAR_BCN_HEAD_1(x) ((x) & (~BITS_BCN_HEAD_1))
#define BIT_GET_BCN_HEAD_1(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_1) & BIT_MASK_BCN_HEAD_1)
#define BIT_SET_BCN_HEAD_1(x, v) (BIT_CLEAR_BCN_HEAD_1(x) | BIT_BCN_HEAD_1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_RST_PGSUB_CNT BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO 0
#define BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO 0xff
#define BIT_MAX_TX_PKT_FOR_USB_AND_SDIO(x) \
(((x) & BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO) \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO)
#define BITS_MAX_TX_PKT_FOR_USB_AND_SDIO \
(BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO)
#define BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO(x) \
((x) & (~BITS_MAX_TX_PKT_FOR_USB_AND_SDIO))
#define BIT_GET_MAX_TX_PKT_FOR_USB_AND_SDIO(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO) & \
BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO)
#define BIT_SET_MAX_TX_PKT_FOR_USB_AND_SDIO(x, v) \
(BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO(x) | \
BIT_MAX_TX_PKT_FOR_USB_AND_SDIO(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DWBCN1_CTRL (Offset 0x0228) */
#define BIT_SHIFT_ALIGNMENT_SIZE 0
#define BIT_MASK_ALIGNMENT_SIZE 0xfff
#define BIT_ALIGNMENT_SIZE(x) \
(((x) & BIT_MASK_ALIGNMENT_SIZE) << BIT_SHIFT_ALIGNMENT_SIZE)
#define BITS_ALIGNMENT_SIZE \
(BIT_MASK_ALIGNMENT_SIZE << BIT_SHIFT_ALIGNMENT_SIZE)
#define BIT_CLEAR_ALIGNMENT_SIZE(x) ((x) & (~BITS_ALIGNMENT_SIZE))
#define BIT_GET_ALIGNMENT_SIZE(x) \
(((x) >> BIT_SHIFT_ALIGNMENT_SIZE) & BIT_MASK_ALIGNMENT_SIZE)
#define BIT_SET_ALIGNMENT_SIZE(x, v) \
(BIT_CLEAR_ALIGNMENT_SIZE(x) | BIT_ALIGNMENT_SIZE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_SHIFT_TXPKTNUM_H_V1 0
#define BIT_MASK_TXPKTNUM_H_V1 0xffff
#define BIT_TXPKTNUM_H_V1(x) \
(((x) & BIT_MASK_TXPKTNUM_H_V1) << BIT_SHIFT_TXPKTNUM_H_V1)
#define BITS_TXPKTNUM_H_V1 (BIT_MASK_TXPKTNUM_H_V1 << BIT_SHIFT_TXPKTNUM_H_V1)
#define BIT_CLEAR_TXPKTNUM_H_V1(x) ((x) & (~BITS_TXPKTNUM_H_V1))
#define BIT_GET_TXPKTNUM_H_V1(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_V1) & BIT_MASK_TXPKTNUM_H_V1)
#define BIT_SET_TXPKTNUM_H_V1(x, v) \
(BIT_CLEAR_TXPKTNUM_H_V1(x) | BIT_TXPKTNUM_H_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_SHIFT_TXPKTNUM_H_V3 0
#define BIT_MASK_TXPKTNUM_H_V3 0xfff
#define BIT_TXPKTNUM_H_V3(x) \
(((x) & BIT_MASK_TXPKTNUM_H_V3) << BIT_SHIFT_TXPKTNUM_H_V3)
#define BITS_TXPKTNUM_H_V3 (BIT_MASK_TXPKTNUM_H_V3 << BIT_SHIFT_TXPKTNUM_H_V3)
#define BIT_CLEAR_TXPKTNUM_H_V3(x) ((x) & (~BITS_TXPKTNUM_H_V3))
#define BIT_GET_TXPKTNUM_H_V3(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_V3) & BIT_MASK_TXPKTNUM_H_V3)
#define BIT_SET_TXPKTNUM_H_V3(x, v) \
(BIT_CLEAR_TXPKTNUM_H_V3(x) | BIT_TXPKTNUM_H_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_SHIFT_TXPKTNUM_V3 0
#define BIT_MASK_TXPKTNUM_V3 0xfff
#define BIT_TXPKTNUM_V3(x) \
(((x) & BIT_MASK_TXPKTNUM_V3) << BIT_SHIFT_TXPKTNUM_V3)
#define BITS_TXPKTNUM_V3 (BIT_MASK_TXPKTNUM_V3 << BIT_SHIFT_TXPKTNUM_V3)
#define BIT_CLEAR_TXPKTNUM_V3(x) ((x) & (~BITS_TXPKTNUM_V3))
#define BIT_GET_TXPKTNUM_V3(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_V3) & BIT_MASK_TXPKTNUM_V3)
#define BIT_SET_TXPKTNUM_V3(x, v) \
(BIT_CLEAR_TXPKTNUM_V3(x) | BIT_TXPKTNUM_V3(v))
#define BIT_PGSUB_CNT_EN BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_RQPN_CTRL_1 (Offset 0x0228) */
#define BIT_SHIFT_TXPKTNUM_V2 0
#define BIT_MASK_TXPKTNUM_V2 0xffff
#define BIT_TXPKTNUM_V2(x) \
(((x) & BIT_MASK_TXPKTNUM_V2) << BIT_SHIFT_TXPKTNUM_V2)
#define BITS_TXPKTNUM_V2 (BIT_MASK_TXPKTNUM_V2 << BIT_SHIFT_TXPKTNUM_V2)
#define BIT_CLEAR_TXPKTNUM_V2(x) ((x) & (~BITS_TXPKTNUM_V2))
#define BIT_GET_TXPKTNUM_V2(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_V2) & BIT_MASK_TXPKTNUM_V2)
#define BIT_SET_TXPKTNUM_V2(x, v) \
(BIT_CLEAR_TXPKTNUM_V2(x) | BIT_TXPKTNUM_V2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RQPN_CTRL_2 (Offset 0x022C) */
#define BIT_EX2Q_PUBLIC_DIS_V1 BIT(21)
#define BIT_EX1Q_PUBLIC_DIS_V1 BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_2 (Offset 0x022C) */
#define BIT_EXQ_PUBLIC_DIS_V1 BIT(19)
#define BIT_NPQ_PUBLIC_DIS_V1 BIT(18)
#define BIT_LPQ_PUBLIC_DIS_V1 BIT(17)
#define BIT_HPQ_PUBLIC_DIS_V1 BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RQPN_CTRL_2 (Offset 0x022C) */
#define BIT_SDIO_TXAGG_ALIGN_ADJUST_EN BIT(15)
#define BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE 0
#define BIT_MASK_SDIO_TXAGG_ALIGN_SIZE 0xfff
#define BIT_SDIO_TXAGG_ALIGN_SIZE(x) \
(((x) & BIT_MASK_SDIO_TXAGG_ALIGN_SIZE) \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE)
#define BITS_SDIO_TXAGG_ALIGN_SIZE \
(BIT_MASK_SDIO_TXAGG_ALIGN_SIZE << BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE)
#define BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE(x) ((x) & (~BITS_SDIO_TXAGG_ALIGN_SIZE))
#define BIT_GET_SDIO_TXAGG_ALIGN_SIZE(x) \
(((x) >> BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE) & \
BIT_MASK_SDIO_TXAGG_ALIGN_SIZE)
#define BIT_SET_SDIO_TXAGG_ALIGN_SIZE(x, v) \
(BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE(x) | BIT_SDIO_TXAGG_ALIGN_SIZE(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_RQPN_EXQ1_EXQ2 (Offset 0x0230) */
#define BIT_SHIFT_EXQ2_AVAL_PG 24
#define BIT_MASK_EXQ2_AVAL_PG 0xff
#define BIT_EXQ2_AVAL_PG(x) \
(((x) & BIT_MASK_EXQ2_AVAL_PG) << BIT_SHIFT_EXQ2_AVAL_PG)
#define BITS_EXQ2_AVAL_PG (BIT_MASK_EXQ2_AVAL_PG << BIT_SHIFT_EXQ2_AVAL_PG)
#define BIT_CLEAR_EXQ2_AVAL_PG(x) ((x) & (~BITS_EXQ2_AVAL_PG))
#define BIT_GET_EXQ2_AVAL_PG(x) \
(((x) >> BIT_SHIFT_EXQ2_AVAL_PG) & BIT_MASK_EXQ2_AVAL_PG)
#define BIT_SET_EXQ2_AVAL_PG(x, v) \
(BIT_CLEAR_EXQ2_AVAL_PG(x) | BIT_EXQ2_AVAL_PG(v))
#define BIT_SHIFT_EXQ2 16
#define BIT_MASK_EXQ2 0xff
#define BIT_EXQ2(x) (((x) & BIT_MASK_EXQ2) << BIT_SHIFT_EXQ2)
#define BITS_EXQ2 (BIT_MASK_EXQ2 << BIT_SHIFT_EXQ2)
#define BIT_CLEAR_EXQ2(x) ((x) & (~BITS_EXQ2))
#define BIT_GET_EXQ2(x) (((x) >> BIT_SHIFT_EXQ2) & BIT_MASK_EXQ2)
#define BIT_SET_EXQ2(x, v) (BIT_CLEAR_EXQ2(x) | BIT_EXQ2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_1 (Offset 0x0230) */
#define BIT_SHIFT_HPQ_AVAL_PG_V1 16
#define BIT_MASK_HPQ_AVAL_PG_V1 0xfff
#define BIT_HPQ_AVAL_PG_V1(x) \
(((x) & BIT_MASK_HPQ_AVAL_PG_V1) << BIT_SHIFT_HPQ_AVAL_PG_V1)
#define BITS_HPQ_AVAL_PG_V1 \
(BIT_MASK_HPQ_AVAL_PG_V1 << BIT_SHIFT_HPQ_AVAL_PG_V1)
#define BIT_CLEAR_HPQ_AVAL_PG_V1(x) ((x) & (~BITS_HPQ_AVAL_PG_V1))
#define BIT_GET_HPQ_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_HPQ_AVAL_PG_V1) & BIT_MASK_HPQ_AVAL_PG_V1)
#define BIT_SET_HPQ_AVAL_PG_V1(x, v) \
(BIT_CLEAR_HPQ_AVAL_PG_V1(x) | BIT_HPQ_AVAL_PG_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_RQPN_EXQ1_EXQ2 (Offset 0x0230) */
#define BIT_SHIFT_EXQ1_AVAL_PG 8
#define BIT_MASK_EXQ1_AVAL_PG 0xff
#define BIT_EXQ1_AVAL_PG(x) \
(((x) & BIT_MASK_EXQ1_AVAL_PG) << BIT_SHIFT_EXQ1_AVAL_PG)
#define BITS_EXQ1_AVAL_PG (BIT_MASK_EXQ1_AVAL_PG << BIT_SHIFT_EXQ1_AVAL_PG)
#define BIT_CLEAR_EXQ1_AVAL_PG(x) ((x) & (~BITS_EXQ1_AVAL_PG))
#define BIT_GET_EXQ1_AVAL_PG(x) \
(((x) >> BIT_SHIFT_EXQ1_AVAL_PG) & BIT_MASK_EXQ1_AVAL_PG)
#define BIT_SET_EXQ1_AVAL_PG(x, v) \
(BIT_CLEAR_EXQ1_AVAL_PG(x) | BIT_EXQ1_AVAL_PG(v))
#define BIT_SHIFT_EXQ1 0
#define BIT_MASK_EXQ1 0xff
#define BIT_EXQ1(x) (((x) & BIT_MASK_EXQ1) << BIT_SHIFT_EXQ1)
#define BITS_EXQ1 (BIT_MASK_EXQ1 << BIT_SHIFT_EXQ1)
#define BIT_CLEAR_EXQ1(x) ((x) & (~BITS_EXQ1))
#define BIT_GET_EXQ1(x) (((x) >> BIT_SHIFT_EXQ1) & BIT_MASK_EXQ1)
#define BIT_SET_EXQ1(x, v) (BIT_CLEAR_EXQ1(x) | BIT_EXQ1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_1 (Offset 0x0230) */
#define BIT_SHIFT_HPQ_V1 0
#define BIT_MASK_HPQ_V1 0xfff
#define BIT_HPQ_V1(x) (((x) & BIT_MASK_HPQ_V1) << BIT_SHIFT_HPQ_V1)
#define BITS_HPQ_V1 (BIT_MASK_HPQ_V1 << BIT_SHIFT_HPQ_V1)
#define BIT_CLEAR_HPQ_V1(x) ((x) & (~BITS_HPQ_V1))
#define BIT_GET_HPQ_V1(x) (((x) >> BIT_SHIFT_HPQ_V1) & BIT_MASK_HPQ_V1)
#define BIT_SET_HPQ_V1(x, v) (BIT_CLEAR_HPQ_V1(x) | BIT_HPQ_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TQPNT3_V1 (Offset 0x0234) */
#define BIT_SHIFT_EXQ2_HIGH_TH 24
#define BIT_MASK_EXQ2_HIGH_TH 0xff
#define BIT_EXQ2_HIGH_TH(x) \
(((x) & BIT_MASK_EXQ2_HIGH_TH) << BIT_SHIFT_EXQ2_HIGH_TH)
#define BITS_EXQ2_HIGH_TH (BIT_MASK_EXQ2_HIGH_TH << BIT_SHIFT_EXQ2_HIGH_TH)
#define BIT_CLEAR_EXQ2_HIGH_TH(x) ((x) & (~BITS_EXQ2_HIGH_TH))
#define BIT_GET_EXQ2_HIGH_TH(x) \
(((x) >> BIT_SHIFT_EXQ2_HIGH_TH) & BIT_MASK_EXQ2_HIGH_TH)
#define BIT_SET_EXQ2_HIGH_TH(x, v) \
(BIT_CLEAR_EXQ2_HIGH_TH(x) | BIT_EXQ2_HIGH_TH(v))
#define BIT_SHIFT_EXQ2_LOW_TH 16
#define BIT_MASK_EXQ2_LOW_TH 0xff
#define BIT_EXQ2_LOW_TH(x) \
(((x) & BIT_MASK_EXQ2_LOW_TH) << BIT_SHIFT_EXQ2_LOW_TH)
#define BITS_EXQ2_LOW_TH (BIT_MASK_EXQ2_LOW_TH << BIT_SHIFT_EXQ2_LOW_TH)
#define BIT_CLEAR_EXQ2_LOW_TH(x) ((x) & (~BITS_EXQ2_LOW_TH))
#define BIT_GET_EXQ2_LOW_TH(x) \
(((x) >> BIT_SHIFT_EXQ2_LOW_TH) & BIT_MASK_EXQ2_LOW_TH)
#define BIT_SET_EXQ2_LOW_TH(x, v) \
(BIT_CLEAR_EXQ2_LOW_TH(x) | BIT_EXQ2_LOW_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_2 (Offset 0x0234) */
#define BIT_SHIFT_LPQ_AVAL_PG_V1 16
#define BIT_MASK_LPQ_AVAL_PG_V1 0xfff
#define BIT_LPQ_AVAL_PG_V1(x) \
(((x) & BIT_MASK_LPQ_AVAL_PG_V1) << BIT_SHIFT_LPQ_AVAL_PG_V1)
#define BITS_LPQ_AVAL_PG_V1 \
(BIT_MASK_LPQ_AVAL_PG_V1 << BIT_SHIFT_LPQ_AVAL_PG_V1)
#define BIT_CLEAR_LPQ_AVAL_PG_V1(x) ((x) & (~BITS_LPQ_AVAL_PG_V1))
#define BIT_GET_LPQ_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_LPQ_AVAL_PG_V1) & BIT_MASK_LPQ_AVAL_PG_V1)
#define BIT_SET_LPQ_AVAL_PG_V1(x, v) \
(BIT_CLEAR_LPQ_AVAL_PG_V1(x) | BIT_LPQ_AVAL_PG_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TQPNT3_V1 (Offset 0x0234) */
#define BIT_SHIFT_EXQ1_HIGH_TH 8
#define BIT_MASK_EXQ1_HIGH_TH 0xff
#define BIT_EXQ1_HIGH_TH(x) \
(((x) & BIT_MASK_EXQ1_HIGH_TH) << BIT_SHIFT_EXQ1_HIGH_TH)
#define BITS_EXQ1_HIGH_TH (BIT_MASK_EXQ1_HIGH_TH << BIT_SHIFT_EXQ1_HIGH_TH)
#define BIT_CLEAR_EXQ1_HIGH_TH(x) ((x) & (~BITS_EXQ1_HIGH_TH))
#define BIT_GET_EXQ1_HIGH_TH(x) \
(((x) >> BIT_SHIFT_EXQ1_HIGH_TH) & BIT_MASK_EXQ1_HIGH_TH)
#define BIT_SET_EXQ1_HIGH_TH(x, v) \
(BIT_CLEAR_EXQ1_HIGH_TH(x) | BIT_EXQ1_HIGH_TH(v))
#define BIT_SHIFT_EXQ1_LOW_TH 0
#define BIT_MASK_EXQ1_LOW_TH 0xff
#define BIT_EXQ1_LOW_TH(x) \
(((x) & BIT_MASK_EXQ1_LOW_TH) << BIT_SHIFT_EXQ1_LOW_TH)
#define BITS_EXQ1_LOW_TH (BIT_MASK_EXQ1_LOW_TH << BIT_SHIFT_EXQ1_LOW_TH)
#define BIT_CLEAR_EXQ1_LOW_TH(x) ((x) & (~BITS_EXQ1_LOW_TH))
#define BIT_GET_EXQ1_LOW_TH(x) \
(((x) >> BIT_SHIFT_EXQ1_LOW_TH) & BIT_MASK_EXQ1_LOW_TH)
#define BIT_SET_EXQ1_LOW_TH(x, v) \
(BIT_CLEAR_EXQ1_LOW_TH(x) | BIT_EXQ1_LOW_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_2 (Offset 0x0234) */
#define BIT_SHIFT_LPQ_V1 0
#define BIT_MASK_LPQ_V1 0xfff
#define BIT_LPQ_V1(x) (((x) & BIT_MASK_LPQ_V1) << BIT_SHIFT_LPQ_V1)
#define BITS_LPQ_V1 (BIT_MASK_LPQ_V1 << BIT_SHIFT_LPQ_V1)
#define BIT_CLEAR_LPQ_V1(x) ((x) & (~BITS_LPQ_V1))
#define BIT_GET_LPQ_V1(x) (((x) >> BIT_SHIFT_LPQ_V1) & BIT_MASK_LPQ_V1)
#define BIT_SET_LPQ_V1(x, v) (BIT_CLEAR_LPQ_V1(x) | BIT_LPQ_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_3 (Offset 0x0238) */
#define BIT_SHIFT_NPQ_AVAL_PG_V1 16
#define BIT_MASK_NPQ_AVAL_PG_V1 0xfff
#define BIT_NPQ_AVAL_PG_V1(x) \
(((x) & BIT_MASK_NPQ_AVAL_PG_V1) << BIT_SHIFT_NPQ_AVAL_PG_V1)
#define BITS_NPQ_AVAL_PG_V1 \
(BIT_MASK_NPQ_AVAL_PG_V1 << BIT_SHIFT_NPQ_AVAL_PG_V1)
#define BIT_CLEAR_NPQ_AVAL_PG_V1(x) ((x) & (~BITS_NPQ_AVAL_PG_V1))
#define BIT_GET_NPQ_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_NPQ_AVAL_PG_V1) & BIT_MASK_NPQ_AVAL_PG_V1)
#define BIT_SET_NPQ_AVAL_PG_V1(x, v) \
(BIT_CLEAR_NPQ_AVAL_PG_V1(x) | BIT_NPQ_AVAL_PG_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_3 (Offset 0x0238) */
#define BIT_SHIFT_NPQ_V1 0
#define BIT_MASK_NPQ_V1 0xfff
#define BIT_NPQ_V1(x) (((x) & BIT_MASK_NPQ_V1) << BIT_SHIFT_NPQ_V1)
#define BITS_NPQ_V1 (BIT_MASK_NPQ_V1 << BIT_SHIFT_NPQ_V1)
#define BIT_CLEAR_NPQ_V1(x) ((x) & (~BITS_NPQ_V1))
#define BIT_GET_NPQ_V1(x) (((x) >> BIT_SHIFT_NPQ_V1) & BIT_MASK_NPQ_V1)
#define BIT_SET_NPQ_V1(x, v) (BIT_CLEAR_NPQ_V1(x) | BIT_NPQ_V1(v))
/* 2 REG_FIFOPAGE_INFO_4 (Offset 0x023C) */
#define BIT_SHIFT_EXQ_AVAL_PG_V1 16
#define BIT_MASK_EXQ_AVAL_PG_V1 0xfff
#define BIT_EXQ_AVAL_PG_V1(x) \
(((x) & BIT_MASK_EXQ_AVAL_PG_V1) << BIT_SHIFT_EXQ_AVAL_PG_V1)
#define BITS_EXQ_AVAL_PG_V1 \
(BIT_MASK_EXQ_AVAL_PG_V1 << BIT_SHIFT_EXQ_AVAL_PG_V1)
#define BIT_CLEAR_EXQ_AVAL_PG_V1(x) ((x) & (~BITS_EXQ_AVAL_PG_V1))
#define BIT_GET_EXQ_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_EXQ_AVAL_PG_V1) & BIT_MASK_EXQ_AVAL_PG_V1)
#define BIT_SET_EXQ_AVAL_PG_V1(x, v) \
(BIT_CLEAR_EXQ_AVAL_PG_V1(x) | BIT_EXQ_AVAL_PG_V1(v))
#define BIT_SHIFT_EXQ_V1 0
#define BIT_MASK_EXQ_V1 0xfff
#define BIT_EXQ_V1(x) (((x) & BIT_MASK_EXQ_V1) << BIT_SHIFT_EXQ_V1)
#define BITS_EXQ_V1 (BIT_MASK_EXQ_V1 << BIT_SHIFT_EXQ_V1)
#define BIT_CLEAR_EXQ_V1(x) ((x) & (~BITS_EXQ_V1))
#define BIT_GET_EXQ_V1(x) (((x) >> BIT_SHIFT_EXQ_V1) & BIT_MASK_EXQ_V1)
#define BIT_SET_EXQ_V1(x, v) (BIT_CLEAR_EXQ_V1(x) | BIT_EXQ_V1(v))
/* 2 REG_FIFOPAGE_INFO_5 (Offset 0x0240) */
#define BIT_SHIFT_PUBQ_AVAL_PG_V1 16
#define BIT_MASK_PUBQ_AVAL_PG_V1 0xfff
#define BIT_PUBQ_AVAL_PG_V1(x) \
(((x) & BIT_MASK_PUBQ_AVAL_PG_V1) << BIT_SHIFT_PUBQ_AVAL_PG_V1)
#define BITS_PUBQ_AVAL_PG_V1 \
(BIT_MASK_PUBQ_AVAL_PG_V1 << BIT_SHIFT_PUBQ_AVAL_PG_V1)
#define BIT_CLEAR_PUBQ_AVAL_PG_V1(x) ((x) & (~BITS_PUBQ_AVAL_PG_V1))
#define BIT_GET_PUBQ_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_PUBQ_AVAL_PG_V1) & BIT_MASK_PUBQ_AVAL_PG_V1)
#define BIT_SET_PUBQ_AVAL_PG_V1(x, v) \
(BIT_CLEAR_PUBQ_AVAL_PG_V1(x) | BIT_PUBQ_AVAL_PG_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TX_AGG_ALIGN (Offset 0x0240) */
#define BIT_SHIFT_HW_FLOW_CTL_EN 16
#define BIT_MASK_HW_FLOW_CTL_EN 0xffff
#define BIT_HW_FLOW_CTL_EN(x) \
(((x) & BIT_MASK_HW_FLOW_CTL_EN) << BIT_SHIFT_HW_FLOW_CTL_EN)
#define BITS_HW_FLOW_CTL_EN \
(BIT_MASK_HW_FLOW_CTL_EN << BIT_SHIFT_HW_FLOW_CTL_EN)
#define BIT_CLEAR_HW_FLOW_CTL_EN(x) ((x) & (~BITS_HW_FLOW_CTL_EN))
#define BIT_GET_HW_FLOW_CTL_EN(x) \
(((x) >> BIT_SHIFT_HW_FLOW_CTL_EN) & BIT_MASK_HW_FLOW_CTL_EN)
#define BIT_SET_HW_FLOW_CTL_EN(x, v) \
(BIT_CLEAR_HW_FLOW_CTL_EN(x) | BIT_HW_FLOW_CTL_EN(v))
#define BIT_SDIO_TXAGG_ALIGN_ADJUST_EN_V1 BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FIFOPAGE_INFO_5 (Offset 0x0240) */
#define BIT_SHIFT_PUBQ_V1 0
#define BIT_MASK_PUBQ_V1 0xfff
#define BIT_PUBQ_V1(x) (((x) & BIT_MASK_PUBQ_V1) << BIT_SHIFT_PUBQ_V1)
#define BITS_PUBQ_V1 (BIT_MASK_PUBQ_V1 << BIT_SHIFT_PUBQ_V1)
#define BIT_CLEAR_PUBQ_V1(x) ((x) & (~BITS_PUBQ_V1))
#define BIT_GET_PUBQ_V1(x) (((x) >> BIT_SHIFT_PUBQ_V1) & BIT_MASK_PUBQ_V1)
#define BIT_SET_PUBQ_V1(x, v) (BIT_CLEAR_PUBQ_V1(x) | BIT_PUBQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TX_AGG_ALIGN (Offset 0x0240) */
#define BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1 0
#define BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1 0xfff
#define BIT_SDIO_TXAGG_ALIGN_SIZE_V1(x) \
(((x) & BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1) \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1)
#define BITS_SDIO_TXAGG_ALIGN_SIZE_V1 \
(BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1 \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1)
#define BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_V1(x) \
((x) & (~BITS_SDIO_TXAGG_ALIGN_SIZE_V1))
#define BIT_GET_SDIO_TXAGG_ALIGN_SIZE_V1(x) \
(((x) >> BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1) & \
BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1)
#define BIT_SET_SDIO_TXAGG_ALIGN_SIZE_V1(x, v) \
(BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_V1(x) | \
BIT_SDIO_TXAGG_ALIGN_SIZE_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_H2C_HEAD (Offset 0x0244) */
#define BIT_SHIFT_H2C_HEAD_V2 0
#define BIT_MASK_H2C_HEAD_V2 0xffff
#define BIT_H2C_HEAD_V2(x) \
(((x) & BIT_MASK_H2C_HEAD_V2) << BIT_SHIFT_H2C_HEAD_V2)
#define BITS_H2C_HEAD_V2 (BIT_MASK_H2C_HEAD_V2 << BIT_SHIFT_H2C_HEAD_V2)
#define BIT_CLEAR_H2C_HEAD_V2(x) ((x) & (~BITS_H2C_HEAD_V2))
#define BIT_GET_H2C_HEAD_V2(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_V2) & BIT_MASK_H2C_HEAD_V2)
#define BIT_SET_H2C_HEAD_V2(x, v) \
(BIT_CLEAR_H2C_HEAD_V2(x) | BIT_H2C_HEAD_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_HEAD (Offset 0x0244) */
#define BIT_SHIFT_H2C_HEAD 0
#define BIT_MASK_H2C_HEAD 0x3ffff
#define BIT_H2C_HEAD(x) (((x) & BIT_MASK_H2C_HEAD) << BIT_SHIFT_H2C_HEAD)
#define BITS_H2C_HEAD (BIT_MASK_H2C_HEAD << BIT_SHIFT_H2C_HEAD)
#define BIT_CLEAR_H2C_HEAD(x) ((x) & (~BITS_H2C_HEAD))
#define BIT_GET_H2C_HEAD(x) (((x) >> BIT_SHIFT_H2C_HEAD) & BIT_MASK_H2C_HEAD)
#define BIT_SET_H2C_HEAD(x, v) (BIT_CLEAR_H2C_HEAD(x) | BIT_H2C_HEAD(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_H2C_HEAD (Offset 0x0244) */
#define BIT_SHIFT_H2C_HEAD_V1 0
#define BIT_MASK_H2C_HEAD_V1 0x7ffff
#define BIT_H2C_HEAD_V1(x) \
(((x) & BIT_MASK_H2C_HEAD_V1) << BIT_SHIFT_H2C_HEAD_V1)
#define BITS_H2C_HEAD_V1 (BIT_MASK_H2C_HEAD_V1 << BIT_SHIFT_H2C_HEAD_V1)
#define BIT_CLEAR_H2C_HEAD_V1(x) ((x) & (~BITS_H2C_HEAD_V1))
#define BIT_GET_H2C_HEAD_V1(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_V1) & BIT_MASK_H2C_HEAD_V1)
#define BIT_SET_H2C_HEAD_V1(x, v) \
(BIT_CLEAR_H2C_HEAD_V1(x) | BIT_H2C_HEAD_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_H2C_TAIL (Offset 0x0248) */
#define BIT_SHIFT_H2C_TAIL_V2 0
#define BIT_MASK_H2C_TAIL_V2 0xffff
#define BIT_H2C_TAIL_V2(x) \
(((x) & BIT_MASK_H2C_TAIL_V2) << BIT_SHIFT_H2C_TAIL_V2)
#define BITS_H2C_TAIL_V2 (BIT_MASK_H2C_TAIL_V2 << BIT_SHIFT_H2C_TAIL_V2)
#define BIT_CLEAR_H2C_TAIL_V2(x) ((x) & (~BITS_H2C_TAIL_V2))
#define BIT_GET_H2C_TAIL_V2(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_V2) & BIT_MASK_H2C_TAIL_V2)
#define BIT_SET_H2C_TAIL_V2(x, v) \
(BIT_CLEAR_H2C_TAIL_V2(x) | BIT_H2C_TAIL_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_TAIL (Offset 0x0248) */
#define BIT_SHIFT_H2C_TAIL 0
#define BIT_MASK_H2C_TAIL 0x3ffff
#define BIT_H2C_TAIL(x) (((x) & BIT_MASK_H2C_TAIL) << BIT_SHIFT_H2C_TAIL)
#define BITS_H2C_TAIL (BIT_MASK_H2C_TAIL << BIT_SHIFT_H2C_TAIL)
#define BIT_CLEAR_H2C_TAIL(x) ((x) & (~BITS_H2C_TAIL))
#define BIT_GET_H2C_TAIL(x) (((x) >> BIT_SHIFT_H2C_TAIL) & BIT_MASK_H2C_TAIL)
#define BIT_SET_H2C_TAIL(x, v) (BIT_CLEAR_H2C_TAIL(x) | BIT_H2C_TAIL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_H2C_TAIL (Offset 0x0248) */
#define BIT_SHIFT_H2C_TAIL_V1 0
#define BIT_MASK_H2C_TAIL_V1 0x7ffff
#define BIT_H2C_TAIL_V1(x) \
(((x) & BIT_MASK_H2C_TAIL_V1) << BIT_SHIFT_H2C_TAIL_V1)
#define BITS_H2C_TAIL_V1 (BIT_MASK_H2C_TAIL_V1 << BIT_SHIFT_H2C_TAIL_V1)
#define BIT_CLEAR_H2C_TAIL_V1(x) ((x) & (~BITS_H2C_TAIL_V1))
#define BIT_GET_H2C_TAIL_V1(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_V1) & BIT_MASK_H2C_TAIL_V1)
#define BIT_SET_H2C_TAIL_V1(x, v) \
(BIT_CLEAR_H2C_TAIL_V1(x) | BIT_H2C_TAIL_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_H2C_READ_ADDR (Offset 0x024C) */
#define BIT_SHIFT_H2C_READ_ADDR_V2 0
#define BIT_MASK_H2C_READ_ADDR_V2 0xffff
#define BIT_H2C_READ_ADDR_V2(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_V2) << BIT_SHIFT_H2C_READ_ADDR_V2)
#define BITS_H2C_READ_ADDR_V2 \
(BIT_MASK_H2C_READ_ADDR_V2 << BIT_SHIFT_H2C_READ_ADDR_V2)
#define BIT_CLEAR_H2C_READ_ADDR_V2(x) ((x) & (~BITS_H2C_READ_ADDR_V2))
#define BIT_GET_H2C_READ_ADDR_V2(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_V2) & BIT_MASK_H2C_READ_ADDR_V2)
#define BIT_SET_H2C_READ_ADDR_V2(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_V2(x) | BIT_H2C_READ_ADDR_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_READ_ADDR (Offset 0x024C) */
#define BIT_SHIFT_H2C_READ_ADDR 0
#define BIT_MASK_H2C_READ_ADDR 0x3ffff
#define BIT_H2C_READ_ADDR(x) \
(((x) & BIT_MASK_H2C_READ_ADDR) << BIT_SHIFT_H2C_READ_ADDR)
#define BITS_H2C_READ_ADDR (BIT_MASK_H2C_READ_ADDR << BIT_SHIFT_H2C_READ_ADDR)
#define BIT_CLEAR_H2C_READ_ADDR(x) ((x) & (~BITS_H2C_READ_ADDR))
#define BIT_GET_H2C_READ_ADDR(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR) & BIT_MASK_H2C_READ_ADDR)
#define BIT_SET_H2C_READ_ADDR(x, v) \
(BIT_CLEAR_H2C_READ_ADDR(x) | BIT_H2C_READ_ADDR(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_H2C_READ_ADDR (Offset 0x024C) */
#define BIT_SHIFT_H2C_READ_ADDR_V1 0
#define BIT_MASK_H2C_READ_ADDR_V1 0x7ffff
#define BIT_H2C_READ_ADDR_V1(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_V1) << BIT_SHIFT_H2C_READ_ADDR_V1)
#define BITS_H2C_READ_ADDR_V1 \
(BIT_MASK_H2C_READ_ADDR_V1 << BIT_SHIFT_H2C_READ_ADDR_V1)
#define BIT_CLEAR_H2C_READ_ADDR_V1(x) ((x) & (~BITS_H2C_READ_ADDR_V1))
#define BIT_GET_H2C_READ_ADDR_V1(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_V1) & BIT_MASK_H2C_READ_ADDR_V1)
#define BIT_SET_H2C_READ_ADDR_V1(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_V1(x) | BIT_H2C_READ_ADDR_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_H2C_WR_ADDR (Offset 0x0250) */
#define BIT_SHIFT_H2C_WR_ADDR_V2 0
#define BIT_MASK_H2C_WR_ADDR_V2 0xffff
#define BIT_H2C_WR_ADDR_V2(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_V2) << BIT_SHIFT_H2C_WR_ADDR_V2)
#define BITS_H2C_WR_ADDR_V2 \
(BIT_MASK_H2C_WR_ADDR_V2 << BIT_SHIFT_H2C_WR_ADDR_V2)
#define BIT_CLEAR_H2C_WR_ADDR_V2(x) ((x) & (~BITS_H2C_WR_ADDR_V2))
#define BIT_GET_H2C_WR_ADDR_V2(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_V2) & BIT_MASK_H2C_WR_ADDR_V2)
#define BIT_SET_H2C_WR_ADDR_V2(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_V2(x) | BIT_H2C_WR_ADDR_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_WR_ADDR (Offset 0x0250) */
#define BIT_SHIFT_H2C_WR_ADDR 0
#define BIT_MASK_H2C_WR_ADDR 0x3ffff
#define BIT_H2C_WR_ADDR(x) \
(((x) & BIT_MASK_H2C_WR_ADDR) << BIT_SHIFT_H2C_WR_ADDR)
#define BITS_H2C_WR_ADDR (BIT_MASK_H2C_WR_ADDR << BIT_SHIFT_H2C_WR_ADDR)
#define BIT_CLEAR_H2C_WR_ADDR(x) ((x) & (~BITS_H2C_WR_ADDR))
#define BIT_GET_H2C_WR_ADDR(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR) & BIT_MASK_H2C_WR_ADDR)
#define BIT_SET_H2C_WR_ADDR(x, v) \
(BIT_CLEAR_H2C_WR_ADDR(x) | BIT_H2C_WR_ADDR(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_H2C_WR_ADDR (Offset 0x0250) */
#define BIT_SHIFT_H2C_WR_ADDR_V1 0
#define BIT_MASK_H2C_WR_ADDR_V1 0x7ffff
#define BIT_H2C_WR_ADDR_V1(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_V1) << BIT_SHIFT_H2C_WR_ADDR_V1)
#define BITS_H2C_WR_ADDR_V1 \
(BIT_MASK_H2C_WR_ADDR_V1 << BIT_SHIFT_H2C_WR_ADDR_V1)
#define BIT_CLEAR_H2C_WR_ADDR_V1(x) ((x) & (~BITS_H2C_WR_ADDR_V1))
#define BIT_GET_H2C_WR_ADDR_V1(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_V1) & BIT_MASK_H2C_WR_ADDR_V1)
#define BIT_SET_H2C_WR_ADDR_V1(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_V1(x) | BIT_H2C_WR_ADDR_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_SHIFT_MDIO_PHY_ADDR 24
#define BIT_MASK_MDIO_PHY_ADDR 0x1f
#define BIT_MDIO_PHY_ADDR(x) \
(((x) & BIT_MASK_MDIO_PHY_ADDR) << BIT_SHIFT_MDIO_PHY_ADDR)
#define BITS_MDIO_PHY_ADDR (BIT_MASK_MDIO_PHY_ADDR << BIT_SHIFT_MDIO_PHY_ADDR)
#define BIT_CLEAR_MDIO_PHY_ADDR(x) ((x) & (~BITS_MDIO_PHY_ADDR))
#define BIT_GET_MDIO_PHY_ADDR(x) \
(((x) >> BIT_SHIFT_MDIO_PHY_ADDR) & BIT_MASK_MDIO_PHY_ADDR)
#define BIT_SET_MDIO_PHY_ADDR(x, v) \
(BIT_CLEAR_MDIO_PHY_ADDR(x) | BIT_MDIO_PHY_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_SHIFT_VI_PUB_LIMIT 16
#define BIT_MASK_VI_PUB_LIMIT 0xfff
#define BIT_VI_PUB_LIMIT(x) \
(((x) & BIT_MASK_VI_PUB_LIMIT) << BIT_SHIFT_VI_PUB_LIMIT)
#define BITS_VI_PUB_LIMIT (BIT_MASK_VI_PUB_LIMIT << BIT_SHIFT_VI_PUB_LIMIT)
#define BIT_CLEAR_VI_PUB_LIMIT(x) ((x) & (~BITS_VI_PUB_LIMIT))
#define BIT_GET_VI_PUB_LIMIT(x) \
(((x) >> BIT_SHIFT_VI_PUB_LIMIT) & BIT_MASK_VI_PUB_LIMIT)
#define BIT_SET_VI_PUB_LIMIT(x, v) \
(BIT_CLEAR_VI_PUB_LIMIT(x) | BIT_VI_PUB_LIMIT(v))
#define BIT_SHIFT_BK_PUB_LIMIT 16
#define BIT_MASK_BK_PUB_LIMIT 0xfff
#define BIT_BK_PUB_LIMIT(x) \
(((x) & BIT_MASK_BK_PUB_LIMIT) << BIT_SHIFT_BK_PUB_LIMIT)
#define BITS_BK_PUB_LIMIT (BIT_MASK_BK_PUB_LIMIT << BIT_SHIFT_BK_PUB_LIMIT)
#define BIT_CLEAR_BK_PUB_LIMIT(x) ((x) & (~BITS_BK_PUB_LIMIT))
#define BIT_GET_BK_PUB_LIMIT(x) \
(((x) >> BIT_SHIFT_BK_PUB_LIMIT) & BIT_MASK_BK_PUB_LIMIT)
#define BIT_SET_BK_PUB_LIMIT(x, v) \
(BIT_CLEAR_BK_PUB_LIMIT(x) | BIT_BK_PUB_LIMIT(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_EX2Q_EN_PUBLIC_LIMIT BIT(13)
#define BIT_EX1Q_EN_PUBLIC_LIMIT BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_EXQ_EN_PUBLIC_LIMIT BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_EQ_EN_PUBLIC_LIMIT BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_NPQ_EN_PUBLIC_LIMIT BIT(10)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_NQ_EN_PUBLIC_LIMIT BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_LPQ_EN_PUBLIC_LIMIT BIT(9)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_LQ_EN_PUBLIC_LIMIT BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_HPQ_EN_PUBLIC_LIMIT BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_HQ_EN_PUBLIC_LIMIT BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_H2C_SPACE_VLD BIT(3)
#define BIT_H2C_WR_ADDR_RST BIT(2)
#define BIT_SHIFT_H2C_LEN_SEL 0
#define BIT_MASK_H2C_LEN_SEL 0x3
#define BIT_H2C_LEN_SEL(x) \
(((x) & BIT_MASK_H2C_LEN_SEL) << BIT_SHIFT_H2C_LEN_SEL)
#define BITS_H2C_LEN_SEL (BIT_MASK_H2C_LEN_SEL << BIT_SHIFT_H2C_LEN_SEL)
#define BIT_CLEAR_H2C_LEN_SEL(x) ((x) & (~BITS_H2C_LEN_SEL))
#define BIT_GET_H2C_LEN_SEL(x) \
(((x) >> BIT_SHIFT_H2C_LEN_SEL) & BIT_MASK_H2C_LEN_SEL)
#define BIT_SET_H2C_LEN_SEL(x, v) \
(BIT_CLEAR_H2C_LEN_SEL(x) | BIT_H2C_LEN_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_H2C_INFO (Offset 0x0254) */
#define BIT_SHIFT_VO_PUB_LIMIT 0
#define BIT_MASK_VO_PUB_LIMIT 0xfff
#define BIT_VO_PUB_LIMIT(x) \
(((x) & BIT_MASK_VO_PUB_LIMIT) << BIT_SHIFT_VO_PUB_LIMIT)
#define BITS_VO_PUB_LIMIT (BIT_MASK_VO_PUB_LIMIT << BIT_SHIFT_VO_PUB_LIMIT)
#define BIT_CLEAR_VO_PUB_LIMIT(x) ((x) & (~BITS_VO_PUB_LIMIT))
#define BIT_GET_VO_PUB_LIMIT(x) \
(((x) >> BIT_SHIFT_VO_PUB_LIMIT) & BIT_MASK_VO_PUB_LIMIT)
#define BIT_SET_VO_PUB_LIMIT(x, v) \
(BIT_CLEAR_VO_PUB_LIMIT(x) | BIT_VO_PUB_LIMIT(v))
#define BIT_SHIFT_BE_PUB_LIMIT 0
#define BIT_MASK_BE_PUB_LIMIT 0xfff
#define BIT_BE_PUB_LIMIT(x) \
(((x) & BIT_MASK_BE_PUB_LIMIT) << BIT_SHIFT_BE_PUB_LIMIT)
#define BITS_BE_PUB_LIMIT (BIT_MASK_BE_PUB_LIMIT << BIT_SHIFT_BE_PUB_LIMIT)
#define BIT_CLEAR_BE_PUB_LIMIT(x) ((x) & (~BITS_BE_PUB_LIMIT))
#define BIT_GET_BE_PUB_LIMIT(x) \
(((x) >> BIT_SHIFT_BE_PUB_LIMIT) & BIT_MASK_BE_PUB_LIMIT)
#define BIT_SET_BE_PUB_LIMIT(x, v) \
(BIT_CLEAR_BE_PUB_LIMIT(x) | BIT_BE_PUB_LIMIT(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_5 (Offset 0x0258) */
#define BIT_SHIFT_NQ_PG_PUBLIC_LIMIT 16
#define BIT_MASK_NQ_PG_PUBLIC_LIMIT 0xfff
#define BIT_NQ_PG_PUBLIC_LIMIT(x) \
(((x) & BIT_MASK_NQ_PG_PUBLIC_LIMIT) << BIT_SHIFT_NQ_PG_PUBLIC_LIMIT)
#define BITS_NQ_PG_PUBLIC_LIMIT \
(BIT_MASK_NQ_PG_PUBLIC_LIMIT << BIT_SHIFT_NQ_PG_PUBLIC_LIMIT)
#define BIT_CLEAR_NQ_PG_PUBLIC_LIMIT(x) ((x) & (~BITS_NQ_PG_PUBLIC_LIMIT))
#define BIT_GET_NQ_PG_PUBLIC_LIMIT(x) \
(((x) >> BIT_SHIFT_NQ_PG_PUBLIC_LIMIT) & BIT_MASK_NQ_PG_PUBLIC_LIMIT)
#define BIT_SET_NQ_PG_PUBLIC_LIMIT(x, v) \
(BIT_CLEAR_NQ_PG_PUBLIC_LIMIT(x) | BIT_NQ_PG_PUBLIC_LIMIT(v))
#define BIT_SHIFT_HQ_PG_PUBLIC_LIMIT 0
#define BIT_MASK_HQ_PG_PUBLIC_LIMIT 0xfff
#define BIT_HQ_PG_PUBLIC_LIMIT(x) \
(((x) & BIT_MASK_HQ_PG_PUBLIC_LIMIT) << BIT_SHIFT_HQ_PG_PUBLIC_LIMIT)
#define BITS_HQ_PG_PUBLIC_LIMIT \
(BIT_MASK_HQ_PG_PUBLIC_LIMIT << BIT_SHIFT_HQ_PG_PUBLIC_LIMIT)
#define BIT_CLEAR_HQ_PG_PUBLIC_LIMIT(x) ((x) & (~BITS_HQ_PG_PUBLIC_LIMIT))
#define BIT_GET_HQ_PG_PUBLIC_LIMIT(x) \
(((x) >> BIT_SHIFT_HQ_PG_PUBLIC_LIMIT) & BIT_MASK_HQ_PG_PUBLIC_LIMIT)
#define BIT_SET_HQ_PG_PUBLIC_LIMIT(x, v) \
(BIT_CLEAR_HQ_PG_PUBLIC_LIMIT(x) | BIT_HQ_PG_PUBLIC_LIMIT(v))
/* 2 REG_FIFOPAGE_CTRL_3 (Offset 0x025C) */
#define BIT_SHIFT_EQ_PG_PUBLIC_LIMIT 16
#define BIT_MASK_EQ_PG_PUBLIC_LIMIT 0xfff
#define BIT_EQ_PG_PUBLIC_LIMIT(x) \
(((x) & BIT_MASK_EQ_PG_PUBLIC_LIMIT) << BIT_SHIFT_EQ_PG_PUBLIC_LIMIT)
#define BITS_EQ_PG_PUBLIC_LIMIT \
(BIT_MASK_EQ_PG_PUBLIC_LIMIT << BIT_SHIFT_EQ_PG_PUBLIC_LIMIT)
#define BIT_CLEAR_EQ_PG_PUBLIC_LIMIT(x) ((x) & (~BITS_EQ_PG_PUBLIC_LIMIT))
#define BIT_GET_EQ_PG_PUBLIC_LIMIT(x) \
(((x) >> BIT_SHIFT_EQ_PG_PUBLIC_LIMIT) & BIT_MASK_EQ_PG_PUBLIC_LIMIT)
#define BIT_SET_EQ_PG_PUBLIC_LIMIT(x, v) \
(BIT_CLEAR_EQ_PG_PUBLIC_LIMIT(x) | BIT_EQ_PG_PUBLIC_LIMIT(v))
#define BIT_SHIFT_LQ_PG_PUBLIC_LIMIT 0
#define BIT_MASK_LQ_PG_PUBLIC_LIMIT 0xfff
#define BIT_LQ_PG_PUBLIC_LIMIT(x) \
(((x) & BIT_MASK_LQ_PG_PUBLIC_LIMIT) << BIT_SHIFT_LQ_PG_PUBLIC_LIMIT)
#define BITS_LQ_PG_PUBLIC_LIMIT \
(BIT_MASK_LQ_PG_PUBLIC_LIMIT << BIT_SHIFT_LQ_PG_PUBLIC_LIMIT)
#define BIT_CLEAR_LQ_PG_PUBLIC_LIMIT(x) ((x) & (~BITS_LQ_PG_PUBLIC_LIMIT))
#define BIT_GET_LQ_PG_PUBLIC_LIMIT(x) \
(((x) >> BIT_SHIFT_LQ_PG_PUBLIC_LIMIT) & BIT_MASK_LQ_PG_PUBLIC_LIMIT)
#define BIT_SET_LQ_PG_PUBLIC_LIMIT(x, v) \
(BIT_CLEAR_LQ_PG_PUBLIC_LIMIT(x) | BIT_LQ_PG_PUBLIC_LIMIT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DMA_OQT_0 (Offset 0x0260) */
#define BIT_SHIFT_TX_OQT_12_FREE_SPACE 24
#define BIT_MASK_TX_OQT_12_FREE_SPACE 0xff
#define BIT_TX_OQT_12_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_12_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_12_FREE_SPACE)
#define BITS_TX_OQT_12_FREE_SPACE \
(BIT_MASK_TX_OQT_12_FREE_SPACE << BIT_SHIFT_TX_OQT_12_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_12_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_12_FREE_SPACE))
#define BIT_GET_TX_OQT_12_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_12_FREE_SPACE) & \
BIT_MASK_TX_OQT_12_FREE_SPACE)
#define BIT_SET_TX_OQT_12_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_12_FREE_SPACE(x) | BIT_TX_OQT_12_FREE_SPACE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TQPNT5 (Offset 0x0260) */
#define BIT_SHIFT_EX1Q_HIGH_TH_V1 16
#define BIT_MASK_EX1Q_HIGH_TH_V1 0xfff
#define BIT_EX1Q_HIGH_TH_V1(x) \
(((x) & BIT_MASK_EX1Q_HIGH_TH_V1) << BIT_SHIFT_EX1Q_HIGH_TH_V1)
#define BITS_EX1Q_HIGH_TH_V1 \
(BIT_MASK_EX1Q_HIGH_TH_V1 << BIT_SHIFT_EX1Q_HIGH_TH_V1)
#define BIT_CLEAR_EX1Q_HIGH_TH_V1(x) ((x) & (~BITS_EX1Q_HIGH_TH_V1))
#define BIT_GET_EX1Q_HIGH_TH_V1(x) \
(((x) >> BIT_SHIFT_EX1Q_HIGH_TH_V1) & BIT_MASK_EX1Q_HIGH_TH_V1)
#define BIT_SET_EX1Q_HIGH_TH_V1(x, v) \
(BIT_CLEAR_EX1Q_HIGH_TH_V1(x) | BIT_EX1Q_HIGH_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DMA_OQT_0 (Offset 0x0260) */
#define BIT_SHIFT_TX_OQT_8_11_FREE_SPACE 16
#define BIT_MASK_TX_OQT_8_11_FREE_SPACE 0xff
#define BIT_TX_OQT_8_11_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_8_11_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_8_11_FREE_SPACE)
#define BITS_TX_OQT_8_11_FREE_SPACE \
(BIT_MASK_TX_OQT_8_11_FREE_SPACE << BIT_SHIFT_TX_OQT_8_11_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_8_11_FREE_SPACE(x) \
((x) & (~BITS_TX_OQT_8_11_FREE_SPACE))
#define BIT_GET_TX_OQT_8_11_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_8_11_FREE_SPACE) & \
BIT_MASK_TX_OQT_8_11_FREE_SPACE)
#define BIT_SET_TX_OQT_8_11_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_8_11_FREE_SPACE(x) | BIT_TX_OQT_8_11_FREE_SPACE(v))
#define BIT_SHIFT_TX_OQT_16_FREE_SPACE 16
#define BIT_MASK_TX_OQT_16_FREE_SPACE 0xff
#define BIT_TX_OQT_16_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_16_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_16_FREE_SPACE)
#define BITS_TX_OQT_16_FREE_SPACE \
(BIT_MASK_TX_OQT_16_FREE_SPACE << BIT_SHIFT_TX_OQT_16_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_16_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_16_FREE_SPACE))
#define BIT_GET_TX_OQT_16_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_16_FREE_SPACE) & \
BIT_MASK_TX_OQT_16_FREE_SPACE)
#define BIT_SET_TX_OQT_16_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_16_FREE_SPACE(x) | BIT_TX_OQT_16_FREE_SPACE(v))
#define BIT_SHIFT_TX_OQT_4_7_FREE_SPACE 8
#define BIT_MASK_TX_OQT_4_7_FREE_SPACE 0xff
#define BIT_TX_OQT_4_7_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_4_7_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_4_7_FREE_SPACE)
#define BITS_TX_OQT_4_7_FREE_SPACE \
(BIT_MASK_TX_OQT_4_7_FREE_SPACE << BIT_SHIFT_TX_OQT_4_7_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_4_7_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_4_7_FREE_SPACE))
#define BIT_GET_TX_OQT_4_7_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_4_7_FREE_SPACE) & \
BIT_MASK_TX_OQT_4_7_FREE_SPACE)
#define BIT_SET_TX_OQT_4_7_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_4_7_FREE_SPACE(x) | BIT_TX_OQT_4_7_FREE_SPACE(v))
#define BIT_SHIFT_TX_OQT_14_15_FREE_SPACE 8
#define BIT_MASK_TX_OQT_14_15_FREE_SPACE 0xff
#define BIT_TX_OQT_14_15_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_14_15_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_14_15_FREE_SPACE)
#define BITS_TX_OQT_14_15_FREE_SPACE \
(BIT_MASK_TX_OQT_14_15_FREE_SPACE << BIT_SHIFT_TX_OQT_14_15_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_14_15_FREE_SPACE(x) \
((x) & (~BITS_TX_OQT_14_15_FREE_SPACE))
#define BIT_GET_TX_OQT_14_15_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_14_15_FREE_SPACE) & \
BIT_MASK_TX_OQT_14_15_FREE_SPACE)
#define BIT_SET_TX_OQT_14_15_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_14_15_FREE_SPACE(x) | BIT_TX_OQT_14_15_FREE_SPACE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TQPNT5 (Offset 0x0260) */
#define BIT_SHIFT_EX1Q_LOW_TH_V1 0
#define BIT_MASK_EX1Q_LOW_TH_V1 0xfff
#define BIT_EX1Q_LOW_TH_V1(x) \
(((x) & BIT_MASK_EX1Q_LOW_TH_V1) << BIT_SHIFT_EX1Q_LOW_TH_V1)
#define BITS_EX1Q_LOW_TH_V1 \
(BIT_MASK_EX1Q_LOW_TH_V1 << BIT_SHIFT_EX1Q_LOW_TH_V1)
#define BIT_CLEAR_EX1Q_LOW_TH_V1(x) ((x) & (~BITS_EX1Q_LOW_TH_V1))
#define BIT_GET_EX1Q_LOW_TH_V1(x) \
(((x) >> BIT_SHIFT_EX1Q_LOW_TH_V1) & BIT_MASK_EX1Q_LOW_TH_V1)
#define BIT_SET_EX1Q_LOW_TH_V1(x, v) \
(BIT_CLEAR_EX1Q_LOW_TH_V1(x) | BIT_EX1Q_LOW_TH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DMA_OQT_0 (Offset 0x0260) */
#define BIT_SHIFT_TX_OQT_0_3_FREE_SPACE 0
#define BIT_MASK_TX_OQT_0_3_FREE_SPACE 0xff
#define BIT_TX_OQT_0_3_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_0_3_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_0_3_FREE_SPACE)
#define BITS_TX_OQT_0_3_FREE_SPACE \
(BIT_MASK_TX_OQT_0_3_FREE_SPACE << BIT_SHIFT_TX_OQT_0_3_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_0_3_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_0_3_FREE_SPACE))
#define BIT_GET_TX_OQT_0_3_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_0_3_FREE_SPACE) & \
BIT_MASK_TX_OQT_0_3_FREE_SPACE)
#define BIT_SET_TX_OQT_0_3_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_0_3_FREE_SPACE(x) | BIT_TX_OQT_0_3_FREE_SPACE(v))
#define BIT_SHIFT_TX_OQT_13_FREE_SPACE 0
#define BIT_MASK_TX_OQT_13_FREE_SPACE 0xff
#define BIT_TX_OQT_13_FREE_SPACE(x) \
(((x) & BIT_MASK_TX_OQT_13_FREE_SPACE) \
<< BIT_SHIFT_TX_OQT_13_FREE_SPACE)
#define BITS_TX_OQT_13_FREE_SPACE \
(BIT_MASK_TX_OQT_13_FREE_SPACE << BIT_SHIFT_TX_OQT_13_FREE_SPACE)
#define BIT_CLEAR_TX_OQT_13_FREE_SPACE(x) ((x) & (~BITS_TX_OQT_13_FREE_SPACE))
#define BIT_GET_TX_OQT_13_FREE_SPACE(x) \
(((x) >> BIT_SHIFT_TX_OQT_13_FREE_SPACE) & \
BIT_MASK_TX_OQT_13_FREE_SPACE)
#define BIT_SET_TX_OQT_13_FREE_SPACE(x, v) \
(BIT_CLEAR_TX_OQT_13_FREE_SPACE(x) | BIT_TX_OQT_13_FREE_SPACE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TQPNT6 (Offset 0x0264) */
#define BIT_SHIFT_EX2Q_HIGH_TH_V1 16
#define BIT_MASK_EX2Q_HIGH_TH_V1 0xfff
#define BIT_EX2Q_HIGH_TH_V1(x) \
(((x) & BIT_MASK_EX2Q_HIGH_TH_V1) << BIT_SHIFT_EX2Q_HIGH_TH_V1)
#define BITS_EX2Q_HIGH_TH_V1 \
(BIT_MASK_EX2Q_HIGH_TH_V1 << BIT_SHIFT_EX2Q_HIGH_TH_V1)
#define BIT_CLEAR_EX2Q_HIGH_TH_V1(x) ((x) & (~BITS_EX2Q_HIGH_TH_V1))
#define BIT_GET_EX2Q_HIGH_TH_V1(x) \
(((x) >> BIT_SHIFT_EX2Q_HIGH_TH_V1) & BIT_MASK_EX2Q_HIGH_TH_V1)
#define BIT_SET_EX2Q_HIGH_TH_V1(x, v) \
(BIT_CLEAR_EX2Q_HIGH_TH_V1(x) | BIT_EX2Q_HIGH_TH_V1(v))
#define BIT_SHIFT_EX2Q_LOW_TH_V1 0
#define BIT_MASK_EX2Q_LOW_TH_V1 0xfff
#define BIT_EX2Q_LOW_TH_V1(x) \
(((x) & BIT_MASK_EX2Q_LOW_TH_V1) << BIT_SHIFT_EX2Q_LOW_TH_V1)
#define BITS_EX2Q_LOW_TH_V1 \
(BIT_MASK_EX2Q_LOW_TH_V1 << BIT_SHIFT_EX2Q_LOW_TH_V1)
#define BIT_CLEAR_EX2Q_LOW_TH_V1(x) ((x) & (~BITS_EX2Q_LOW_TH_V1))
#define BIT_GET_EX2Q_LOW_TH_V1(x) \
(((x) >> BIT_SHIFT_EX2Q_LOW_TH_V1) & BIT_MASK_EX2Q_LOW_TH_V1)
#define BIT_SET_EX2Q_LOW_TH_V1(x, v) \
(BIT_CLEAR_EX2Q_LOW_TH_V1(x) | BIT_EX2Q_LOW_TH_V1(v))
/* 2 REG_FIFOPAGE_INFO_6 (Offset 0x0268) */
#define BIT_SHIFT_EX1Q_AVAL_PG_V1 16
#define BIT_MASK_EX1Q_AVAL_PG_V1 0xfff
#define BIT_EX1Q_AVAL_PG_V1(x) \
(((x) & BIT_MASK_EX1Q_AVAL_PG_V1) << BIT_SHIFT_EX1Q_AVAL_PG_V1)
#define BITS_EX1Q_AVAL_PG_V1 \
(BIT_MASK_EX1Q_AVAL_PG_V1 << BIT_SHIFT_EX1Q_AVAL_PG_V1)
#define BIT_CLEAR_EX1Q_AVAL_PG_V1(x) ((x) & (~BITS_EX1Q_AVAL_PG_V1))
#define BIT_GET_EX1Q_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_EX1Q_AVAL_PG_V1) & BIT_MASK_EX1Q_AVAL_PG_V1)
#define BIT_SET_EX1Q_AVAL_PG_V1(x, v) \
(BIT_CLEAR_EX1Q_AVAL_PG_V1(x) | BIT_EX1Q_AVAL_PG_V1(v))
#define BIT_SHIFT_EX1Q_V1 0
#define BIT_MASK_EX1Q_V1 0xfff
#define BIT_EX1Q_V1(x) (((x) & BIT_MASK_EX1Q_V1) << BIT_SHIFT_EX1Q_V1)
#define BITS_EX1Q_V1 (BIT_MASK_EX1Q_V1 << BIT_SHIFT_EX1Q_V1)
#define BIT_CLEAR_EX1Q_V1(x) ((x) & (~BITS_EX1Q_V1))
#define BIT_GET_EX1Q_V1(x) (((x) >> BIT_SHIFT_EX1Q_V1) & BIT_MASK_EX1Q_V1)
#define BIT_SET_EX1Q_V1(x, v) (BIT_CLEAR_EX1Q_V1(x) | BIT_EX1Q_V1(v))
/* 2 REG_FIFOPAGE_INFO_7 (Offset 0x026C) */
#define BIT_SHIFT_EX2Q_AVAL_PG_V1 16
#define BIT_MASK_EX2Q_AVAL_PG_V1 0xfff
#define BIT_EX2Q_AVAL_PG_V1(x) \
(((x) & BIT_MASK_EX2Q_AVAL_PG_V1) << BIT_SHIFT_EX2Q_AVAL_PG_V1)
#define BITS_EX2Q_AVAL_PG_V1 \
(BIT_MASK_EX2Q_AVAL_PG_V1 << BIT_SHIFT_EX2Q_AVAL_PG_V1)
#define BIT_CLEAR_EX2Q_AVAL_PG_V1(x) ((x) & (~BITS_EX2Q_AVAL_PG_V1))
#define BIT_GET_EX2Q_AVAL_PG_V1(x) \
(((x) >> BIT_SHIFT_EX2Q_AVAL_PG_V1) & BIT_MASK_EX2Q_AVAL_PG_V1)
#define BIT_SET_EX2Q_AVAL_PG_V1(x, v) \
(BIT_CLEAR_EX2Q_AVAL_PG_V1(x) | BIT_EX2Q_AVAL_PG_V1(v))
#define BIT_SHIFT_EX2Q_V1 0
#define BIT_MASK_EX2Q_V1 0xfff
#define BIT_EX2Q_V1(x) (((x) & BIT_MASK_EX2Q_V1) << BIT_SHIFT_EX2Q_V1)
#define BITS_EX2Q_V1 (BIT_MASK_EX2Q_V1 << BIT_SHIFT_EX2Q_V1)
#define BIT_CLEAR_EX2Q_V1(x) ((x) & (~BITS_EX2Q_V1))
#define BIT_GET_EX2Q_V1(x) (((x) >> BIT_SHIFT_EX2Q_V1) & BIT_MASK_EX2Q_V1)
#define BIT_SET_EX2Q_V1(x, v) (BIT_CLEAR_EX2Q_V1(x) | BIT_EX2Q_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_FIFOPAGE_CTRL_4 (Offset 0x0270) */
#define BIT_SHIFT_EX1Q_PG_PUBLIC_LIMIT 16
#define BIT_MASK_EX1Q_PG_PUBLIC_LIMIT 0xfff
#define BIT_EX1Q_PG_PUBLIC_LIMIT(x) \
(((x) & BIT_MASK_EX1Q_PG_PUBLIC_LIMIT) \
<< BIT_SHIFT_EX1Q_PG_PUBLIC_LIMIT)
#define BITS_EX1Q_PG_PUBLIC_LIMIT \
(BIT_MASK_EX1Q_PG_PUBLIC_LIMIT << BIT_SHIFT_EX1Q_PG_PUBLIC_LIMIT)
#define BIT_CLEAR_EX1Q_PG_PUBLIC_LIMIT(x) ((x) & (~BITS_EX1Q_PG_PUBLIC_LIMIT))
#define BIT_GET_EX1Q_PG_PUBLIC_LIMIT(x) \
(((x) >> BIT_SHIFT_EX1Q_PG_PUBLIC_LIMIT) & \
BIT_MASK_EX1Q_PG_PUBLIC_LIMIT)
#define BIT_SET_EX1Q_PG_PUBLIC_LIMIT(x, v) \
(BIT_CLEAR_EX1Q_PG_PUBLIC_LIMIT(x) | BIT_EX1Q_PG_PUBLIC_LIMIT(v))
#define BIT_SHIFT_EX2Q_PG_PUBLIC_LIMIT 0
#define BIT_MASK_EX2Q_PG_PUBLIC_LIMIT 0xfff
#define BIT_EX2Q_PG_PUBLIC_LIMIT(x) \
(((x) & BIT_MASK_EX2Q_PG_PUBLIC_LIMIT) \
<< BIT_SHIFT_EX2Q_PG_PUBLIC_LIMIT)
#define BITS_EX2Q_PG_PUBLIC_LIMIT \
(BIT_MASK_EX2Q_PG_PUBLIC_LIMIT << BIT_SHIFT_EX2Q_PG_PUBLIC_LIMIT)
#define BIT_CLEAR_EX2Q_PG_PUBLIC_LIMIT(x) ((x) & (~BITS_EX2Q_PG_PUBLIC_LIMIT))
#define BIT_GET_EX2Q_PG_PUBLIC_LIMIT(x) \
(((x) >> BIT_SHIFT_EX2Q_PG_PUBLIC_LIMIT) & \
BIT_MASK_EX2Q_PG_PUBLIC_LIMIT)
#define BIT_SET_EX2Q_PG_PUBLIC_LIMIT(x, v) \
(BIT_CLEAR_EX2Q_PG_PUBLIC_LIMIT(x) | BIT_EX2Q_PG_PUBLIC_LIMIT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PGSUB_H (Offset 0x0270) */
#define BIT_SHIFT_HPQ_PGSUB_CNT 0
#define BIT_MASK_HPQ_PGSUB_CNT 0xffffffffL
#define BIT_HPQ_PGSUB_CNT(x) \
(((x) & BIT_MASK_HPQ_PGSUB_CNT) << BIT_SHIFT_HPQ_PGSUB_CNT)
#define BITS_HPQ_PGSUB_CNT (BIT_MASK_HPQ_PGSUB_CNT << BIT_SHIFT_HPQ_PGSUB_CNT)
#define BIT_CLEAR_HPQ_PGSUB_CNT(x) ((x) & (~BITS_HPQ_PGSUB_CNT))
#define BIT_GET_HPQ_PGSUB_CNT(x) \
(((x) >> BIT_SHIFT_HPQ_PGSUB_CNT) & BIT_MASK_HPQ_PGSUB_CNT)
#define BIT_SET_HPQ_PGSUB_CNT(x, v) \
(BIT_CLEAR_HPQ_PGSUB_CNT(x) | BIT_HPQ_PGSUB_CNT(v))
/* 2 REG_PGSUB_N (Offset 0x0274) */
#define BIT_SHIFT_NPQ_PGSUB_CNT 0
#define BIT_MASK_NPQ_PGSUB_CNT 0xffffffffL
#define BIT_NPQ_PGSUB_CNT(x) \
(((x) & BIT_MASK_NPQ_PGSUB_CNT) << BIT_SHIFT_NPQ_PGSUB_CNT)
#define BITS_NPQ_PGSUB_CNT (BIT_MASK_NPQ_PGSUB_CNT << BIT_SHIFT_NPQ_PGSUB_CNT)
#define BIT_CLEAR_NPQ_PGSUB_CNT(x) ((x) & (~BITS_NPQ_PGSUB_CNT))
#define BIT_GET_NPQ_PGSUB_CNT(x) \
(((x) >> BIT_SHIFT_NPQ_PGSUB_CNT) & BIT_MASK_NPQ_PGSUB_CNT)
#define BIT_SET_NPQ_PGSUB_CNT(x, v) \
(BIT_CLEAR_NPQ_PGSUB_CNT(x) | BIT_NPQ_PGSUB_CNT(v))
/* 2 REG_PGSUB_L (Offset 0x0278) */
#define BIT_SHIFT_LPQ_PGSUB_CNT 0
#define BIT_MASK_LPQ_PGSUB_CNT 0xffffffffL
#define BIT_LPQ_PGSUB_CNT(x) \
(((x) & BIT_MASK_LPQ_PGSUB_CNT) << BIT_SHIFT_LPQ_PGSUB_CNT)
#define BITS_LPQ_PGSUB_CNT (BIT_MASK_LPQ_PGSUB_CNT << BIT_SHIFT_LPQ_PGSUB_CNT)
#define BIT_CLEAR_LPQ_PGSUB_CNT(x) ((x) & (~BITS_LPQ_PGSUB_CNT))
#define BIT_GET_LPQ_PGSUB_CNT(x) \
(((x) >> BIT_SHIFT_LPQ_PGSUB_CNT) & BIT_MASK_LPQ_PGSUB_CNT)
#define BIT_SET_LPQ_PGSUB_CNT(x, v) \
(BIT_CLEAR_LPQ_PGSUB_CNT(x) | BIT_LPQ_PGSUB_CNT(v))
/* 2 REG_PGSUB_E (Offset 0x027C) */
#define BIT_SHIFT_EPQ_PGSUB_CNT 0
#define BIT_MASK_EPQ_PGSUB_CNT 0xffffffffL
#define BIT_EPQ_PGSUB_CNT(x) \
(((x) & BIT_MASK_EPQ_PGSUB_CNT) << BIT_SHIFT_EPQ_PGSUB_CNT)
#define BITS_EPQ_PGSUB_CNT (BIT_MASK_EPQ_PGSUB_CNT << BIT_SHIFT_EPQ_PGSUB_CNT)
#define BIT_CLEAR_EPQ_PGSUB_CNT(x) ((x) & (~BITS_EPQ_PGSUB_CNT))
#define BIT_GET_EPQ_PGSUB_CNT(x) \
(((x) >> BIT_SHIFT_EPQ_PGSUB_CNT) & BIT_MASK_EPQ_PGSUB_CNT)
#define BIT_SET_EPQ_PGSUB_CNT(x, v) \
(BIT_CLEAR_EPQ_PGSUB_CNT(x) | BIT_EPQ_PGSUB_CNT(v))
#define BIT_SHIFT_FWFF_PKT_STR_ADDR_V2 0
#define BIT_MASK_FWFF_PKT_STR_ADDR_V2 0x3fff
#define BIT_FWFF_PKT_STR_ADDR_V2(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR_V2) \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_V2)
#define BITS_FWFF_PKT_STR_ADDR_V2 \
(BIT_MASK_FWFF_PKT_STR_ADDR_V2 << BIT_SHIFT_FWFF_PKT_STR_ADDR_V2)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR_V2(x) ((x) & (~BITS_FWFF_PKT_STR_ADDR_V2))
#define BIT_GET_FWFF_PKT_STR_ADDR_V2(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR_V2) & \
BIT_MASK_FWFF_PKT_STR_ADDR_V2)
#define BIT_SET_FWFF_PKT_STR_ADDR_V2(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR_V2(x) | BIT_FWFF_PKT_STR_ADDR_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_USB_RXDMA_AGG_EN BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_RXDMA_AGG_OLD_MOD_V1 BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_DMA_STORE_MODE BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_DMA_STORE BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_EN_FW_ADD BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_RXAGG_TH_MODE BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_EN_PRE_CALC BIT(29)
#define BIT_RXAGG_SW_EN BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_RXAGG_SW_TRIG BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_BCNERR_CNT_OTHERS 24
#define BIT_MASK_BCNERR_CNT_OTHERS 0xff
#define BIT_BCNERR_CNT_OTHERS(x) \
(((x) & BIT_MASK_BCNERR_CNT_OTHERS) << BIT_SHIFT_BCNERR_CNT_OTHERS)
#define BITS_BCNERR_CNT_OTHERS \
(BIT_MASK_BCNERR_CNT_OTHERS << BIT_SHIFT_BCNERR_CNT_OTHERS)
#define BIT_CLEAR_BCNERR_CNT_OTHERS(x) ((x) & (~BITS_BCNERR_CNT_OTHERS))
#define BIT_GET_BCNERR_CNT_OTHERS(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_OTHERS) & BIT_MASK_BCNERR_CNT_OTHERS)
#define BIT_SET_BCNERR_CNT_OTHERS(x, v) \
(BIT_CLEAR_BCNERR_CNT_OTHERS(x) | BIT_BCNERR_CNT_OTHERS(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_RXDMA_AGG_OLD_MOD 24
#define BIT_MASK_RXDMA_AGG_OLD_MOD 0xff
#define BIT_RXDMA_AGG_OLD_MOD(x) \
(((x) & BIT_MASK_RXDMA_AGG_OLD_MOD) << BIT_SHIFT_RXDMA_AGG_OLD_MOD)
#define BITS_RXDMA_AGG_OLD_MOD \
(BIT_MASK_RXDMA_AGG_OLD_MOD << BIT_SHIFT_RXDMA_AGG_OLD_MOD)
#define BIT_CLEAR_RXDMA_AGG_OLD_MOD(x) ((x) & (~BITS_RXDMA_AGG_OLD_MOD))
#define BIT_GET_RXDMA_AGG_OLD_MOD(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_OLD_MOD) & BIT_MASK_RXDMA_AGG_OLD_MOD)
#define BIT_SET_RXDMA_AGG_OLD_MOD(x, v) \
(BIT_CLEAR_RXDMA_AGG_OLD_MOD(x) | BIT_RXDMA_AGG_OLD_MOD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_PKT_NUM_WOL 16
#define BIT_MASK_PKT_NUM_WOL 0xff
#define BIT_PKT_NUM_WOL(x) \
(((x) & BIT_MASK_PKT_NUM_WOL) << BIT_SHIFT_PKT_NUM_WOL)
#define BITS_PKT_NUM_WOL (BIT_MASK_PKT_NUM_WOL << BIT_SHIFT_PKT_NUM_WOL)
#define BIT_CLEAR_PKT_NUM_WOL(x) ((x) & (~BITS_PKT_NUM_WOL))
#define BIT_GET_PKT_NUM_WOL(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL) & BIT_MASK_PKT_NUM_WOL)
#define BIT_SET_PKT_NUM_WOL(x, v) \
(BIT_CLEAR_PKT_NUM_WOL(x) | BIT_PKT_NUM_WOL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_RXBCN_TIMER 16
#define BIT_MASK_RXBCN_TIMER 0xffff
#define BIT_RXBCN_TIMER(x) \
(((x) & BIT_MASK_RXBCN_TIMER) << BIT_SHIFT_RXBCN_TIMER)
#define BITS_RXBCN_TIMER (BIT_MASK_RXBCN_TIMER << BIT_SHIFT_RXBCN_TIMER)
#define BIT_CLEAR_RXBCN_TIMER(x) ((x) & (~BITS_RXBCN_TIMER))
#define BIT_GET_RXBCN_TIMER(x) \
(((x) >> BIT_SHIFT_RXBCN_TIMER) & BIT_MASK_RXBCN_TIMER)
#define BIT_SET_RXBCN_TIMER(x, v) \
(BIT_CLEAR_RXBCN_TIMER(x) | BIT_RXBCN_TIMER(v))
#define BIT_SHIFT_BCNERR_CNT_INVALID 16
#define BIT_MASK_BCNERR_CNT_INVALID 0xff
#define BIT_BCNERR_CNT_INVALID(x) \
(((x) & BIT_MASK_BCNERR_CNT_INVALID) << BIT_SHIFT_BCNERR_CNT_INVALID)
#define BITS_BCNERR_CNT_INVALID \
(BIT_MASK_BCNERR_CNT_INVALID << BIT_SHIFT_BCNERR_CNT_INVALID)
#define BIT_CLEAR_BCNERR_CNT_INVALID(x) ((x) & (~BITS_BCNERR_CNT_INVALID))
#define BIT_GET_BCNERR_CNT_INVALID(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_INVALID) & BIT_MASK_BCNERR_CNT_INVALID)
#define BIT_SET_BCNERR_CNT_INVALID(x, v) \
(BIT_CLEAR_BCNERR_CNT_INVALID(x) | BIT_BCNERR_CNT_INVALID(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_DMA_AGG_TO_V1 8
#define BIT_MASK_DMA_AGG_TO_V1 0xff
#define BIT_DMA_AGG_TO_V1(x) \
(((x) & BIT_MASK_DMA_AGG_TO_V1) << BIT_SHIFT_DMA_AGG_TO_V1)
#define BITS_DMA_AGG_TO_V1 (BIT_MASK_DMA_AGG_TO_V1 << BIT_SHIFT_DMA_AGG_TO_V1)
#define BIT_CLEAR_DMA_AGG_TO_V1(x) ((x) & (~BITS_DMA_AGG_TO_V1))
#define BIT_GET_DMA_AGG_TO_V1(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO_V1) & BIT_MASK_DMA_AGG_TO_V1)
#define BIT_SET_DMA_AGG_TO_V1(x, v) \
(BIT_CLEAR_DMA_AGG_TO_V1(x) | BIT_DMA_AGG_TO_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_BCNERR_CNT_MAC 8
#define BIT_MASK_BCNERR_CNT_MAC 0xff
#define BIT_BCNERR_CNT_MAC(x) \
(((x) & BIT_MASK_BCNERR_CNT_MAC) << BIT_SHIFT_BCNERR_CNT_MAC)
#define BITS_BCNERR_CNT_MAC \
(BIT_MASK_BCNERR_CNT_MAC << BIT_SHIFT_BCNERR_CNT_MAC)
#define BIT_CLEAR_BCNERR_CNT_MAC(x) ((x) & (~BITS_BCNERR_CNT_MAC))
#define BIT_GET_BCNERR_CNT_MAC(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_MAC) & BIT_MASK_BCNERR_CNT_MAC)
#define BIT_SET_BCNERR_CNT_MAC(x, v) \
(BIT_CLEAR_BCNERR_CNT_MAC(x) | BIT_BCNERR_CNT_MAC(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_DMA_AGG_TO 8
#define BIT_MASK_DMA_AGG_TO 0xf
#define BIT_DMA_AGG_TO(x) (((x) & BIT_MASK_DMA_AGG_TO) << BIT_SHIFT_DMA_AGG_TO)
#define BITS_DMA_AGG_TO (BIT_MASK_DMA_AGG_TO << BIT_SHIFT_DMA_AGG_TO)
#define BIT_CLEAR_DMA_AGG_TO(x) ((x) & (~BITS_DMA_AGG_TO))
#define BIT_GET_DMA_AGG_TO(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO) & BIT_MASK_DMA_AGG_TO)
#define BIT_SET_DMA_AGG_TO(x, v) (BIT_CLEAR_DMA_AGG_TO(x) | BIT_DMA_AGG_TO(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_RXDMA_AGG_PG_TH_V1 0
#define BIT_MASK_RXDMA_AGG_PG_TH_V1 0xf
#define BIT_RXDMA_AGG_PG_TH_V1(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_V1) << BIT_SHIFT_RXDMA_AGG_PG_TH_V1)
#define BITS_RXDMA_AGG_PG_TH_V1 \
(BIT_MASK_RXDMA_AGG_PG_TH_V1 << BIT_SHIFT_RXDMA_AGG_PG_TH_V1)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_V1(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_V1))
#define BIT_GET_RXDMA_AGG_PG_TH_V1(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_V1) & BIT_MASK_RXDMA_AGG_PG_TH_V1)
#define BIT_SET_RXDMA_AGG_PG_TH_V1(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_V1(x) | BIT_RXDMA_AGG_PG_TH_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_RXDMA_AGG_PG_TH 0
#define BIT_MASK_RXDMA_AGG_PG_TH 0xff
#define BIT_RXDMA_AGG_PG_TH(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH) << BIT_SHIFT_RXDMA_AGG_PG_TH)
#define BITS_RXDMA_AGG_PG_TH \
(BIT_MASK_RXDMA_AGG_PG_TH << BIT_SHIFT_RXDMA_AGG_PG_TH)
#define BIT_CLEAR_RXDMA_AGG_PG_TH(x) ((x) & (~BITS_RXDMA_AGG_PG_TH))
#define BIT_GET_RXDMA_AGG_PG_TH(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH) & BIT_MASK_RXDMA_AGG_PG_TH)
#define BIT_SET_RXDMA_AGG_PG_TH(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH(x) | BIT_RXDMA_AGG_PG_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_QINFO_INDEX 0
#define BIT_MASK_QINFO_INDEX 0x1f
#define BIT_QINFO_INDEX(x) \
(((x) & BIT_MASK_QINFO_INDEX) << BIT_SHIFT_QINFO_INDEX)
#define BITS_QINFO_INDEX (BIT_MASK_QINFO_INDEX << BIT_SHIFT_QINFO_INDEX)
#define BIT_CLEAR_QINFO_INDEX(x) ((x) & (~BITS_QINFO_INDEX))
#define BIT_GET_QINFO_INDEX(x) \
(((x) >> BIT_SHIFT_QINFO_INDEX) & BIT_MASK_QINFO_INDEX)
#define BIT_SET_QINFO_INDEX(x, v) \
(BIT_CLEAR_QINFO_INDEX(x) | BIT_QINFO_INDEX(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_BCNERR_CNT_CCA 0
#define BIT_MASK_BCNERR_CNT_CCA 0xff
#define BIT_BCNERR_CNT_CCA(x) \
(((x) & BIT_MASK_BCNERR_CNT_CCA) << BIT_SHIFT_BCNERR_CNT_CCA)
#define BITS_BCNERR_CNT_CCA \
(BIT_MASK_BCNERR_CNT_CCA << BIT_SHIFT_BCNERR_CNT_CCA)
#define BIT_CLEAR_BCNERR_CNT_CCA(x) ((x) & (~BITS_BCNERR_CNT_CCA))
#define BIT_GET_BCNERR_CNT_CCA(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_CCA) & BIT_MASK_BCNERR_CNT_CCA)
#define BIT_SET_BCNERR_CNT_CCA(x, v) \
(BIT_CLEAR_BCNERR_CNT_CCA(x) | BIT_BCNERR_CNT_CCA(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_RXDMA_AGG_PG_TH (Offset 0x0280) */
#define BIT_SHIFT_RXDMA_AGG_PG_TH_V2 0
#define BIT_MASK_RXDMA_AGG_PG_TH_V2 0xff
#define BIT_RXDMA_AGG_PG_TH_V2(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_V2) << BIT_SHIFT_RXDMA_AGG_PG_TH_V2)
#define BITS_RXDMA_AGG_PG_TH_V2 \
(BIT_MASK_RXDMA_AGG_PG_TH_V2 << BIT_SHIFT_RXDMA_AGG_PG_TH_V2)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_V2(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_V2))
#define BIT_GET_RXDMA_AGG_PG_TH_V2(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_V2) & BIT_MASK_RXDMA_AGG_PG_TH_V2)
#define BIT_SET_RXDMA_AGG_PG_TH_V2(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_V2(x) | BIT_RXDMA_AGG_PG_TH_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXPKT_NUM (Offset 0x0284) */
#define BIT_SHIFT_RXPKT_NUM 24
#define BIT_MASK_RXPKT_NUM 0xff
#define BIT_RXPKT_NUM(x) (((x) & BIT_MASK_RXPKT_NUM) << BIT_SHIFT_RXPKT_NUM)
#define BITS_RXPKT_NUM (BIT_MASK_RXPKT_NUM << BIT_SHIFT_RXPKT_NUM)
#define BIT_CLEAR_RXPKT_NUM(x) ((x) & (~BITS_RXPKT_NUM))
#define BIT_GET_RXPKT_NUM(x) (((x) >> BIT_SHIFT_RXPKT_NUM) & BIT_MASK_RXPKT_NUM)
#define BIT_SET_RXPKT_NUM(x, v) (BIT_CLEAR_RXPKT_NUM(x) | BIT_RXPKT_NUM(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_RXPKT_NUM (Offset 0x0284) */
#define BIT_STOP_RXDMA BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXPKT_NUM (Offset 0x0284) */
#define BIT_SHIFT_FW_UPD_RDPTR19_TO_16 20
#define BIT_MASK_FW_UPD_RDPTR19_TO_16 0xf
#define BIT_FW_UPD_RDPTR19_TO_16(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR19_TO_16) \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16)
#define BITS_FW_UPD_RDPTR19_TO_16 \
(BIT_MASK_FW_UPD_RDPTR19_TO_16 << BIT_SHIFT_FW_UPD_RDPTR19_TO_16)
#define BIT_CLEAR_FW_UPD_RDPTR19_TO_16(x) ((x) & (~BITS_FW_UPD_RDPTR19_TO_16))
#define BIT_GET_FW_UPD_RDPTR19_TO_16(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR19_TO_16) & \
BIT_MASK_FW_UPD_RDPTR19_TO_16)
#define BIT_SET_FW_UPD_RDPTR19_TO_16(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR19_TO_16(x) | BIT_FW_UPD_RDPTR19_TO_16(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXPKT_NUM (Offset 0x0284) */
#define BIT_RXDMA_REQ BIT(19)
#define BIT_RW_RELEASE_EN BIT(18)
#define BIT_RXDMA_IDLE BIT(17)
#define BIT_RXPKT_RELEASE_POLL BIT(16)
#define BIT_SHIFT_FW_UPD_RDPTR 0
#define BIT_MASK_FW_UPD_RDPTR 0xffff
#define BIT_FW_UPD_RDPTR(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR) << BIT_SHIFT_FW_UPD_RDPTR)
#define BITS_FW_UPD_RDPTR (BIT_MASK_FW_UPD_RDPTR << BIT_SHIFT_FW_UPD_RDPTR)
#define BIT_CLEAR_FW_UPD_RDPTR(x) ((x) & (~BITS_FW_UPD_RDPTR))
#define BIT_GET_FW_UPD_RDPTR(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR) & BIT_MASK_FW_UPD_RDPTR)
#define BIT_SET_FW_UPD_RDPTR(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR(x) | BIT_FW_UPD_RDPTR(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_FC2H_PKT_OVERFLOW BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_FC2H_PKT_OVF BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_C2H_PKT_OVF BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_AGG_CFG_ISSUE BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_AGG_CONFGI_ISSUE BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_FW_POLL_ISSUE BIT(5)
#define BIT_RX_DATA_UDN BIT(4)
#define BIT_RX_SFF_UDN BIT(3)
#define BIT_RX_SFF_OVF BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_USB_REQ_LEN_OVF BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_STATUS (Offset 0x0288) */
#define BIT_RXPKT_OVF BIT(0)
/* 2 REG_RXDMA_DPR (Offset 0x028C) */
#define BIT_SHIFT_RDE_DEBUG 0
#define BIT_MASK_RDE_DEBUG 0xffffffffL
#define BIT_RDE_DEBUG(x) (((x) & BIT_MASK_RDE_DEBUG) << BIT_SHIFT_RDE_DEBUG)
#define BITS_RDE_DEBUG (BIT_MASK_RDE_DEBUG << BIT_SHIFT_RDE_DEBUG)
#define BIT_CLEAR_RDE_DEBUG(x) ((x) & (~BITS_RDE_DEBUG))
#define BIT_GET_RDE_DEBUG(x) (((x) >> BIT_SHIFT_RDE_DEBUG) & BIT_MASK_RDE_DEBUG)
#define BIT_SET_RDE_DEBUG(x, v) (BIT_CLEAR_RDE_DEBUG(x) | BIT_RDE_DEBUG(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_SHIFT_PKTNUM_TH_V2 24
#define BIT_MASK_PKTNUM_TH_V2 0x1f
#define BIT_PKTNUM_TH_V2(x) \
(((x) & BIT_MASK_PKTNUM_TH_V2) << BIT_SHIFT_PKTNUM_TH_V2)
#define BITS_PKTNUM_TH_V2 (BIT_MASK_PKTNUM_TH_V2 << BIT_SHIFT_PKTNUM_TH_V2)
#define BIT_CLEAR_PKTNUM_TH_V2(x) ((x) & (~BITS_PKTNUM_TH_V2))
#define BIT_GET_PKTNUM_TH_V2(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V2) & BIT_MASK_PKTNUM_TH_V2)
#define BIT_SET_PKTNUM_TH_V2(x, v) \
(BIT_CLEAR_PKTNUM_TH_V2(x) | BIT_PKTNUM_TH_V2(v))
#define BIT_TXBA_BREAK_USBAGG BIT(23)
#define BIT_SHIFT_PKTLEN_PARA 16
#define BIT_MASK_PKTLEN_PARA 0x7
#define BIT_PKTLEN_PARA(x) \
(((x) & BIT_MASK_PKTLEN_PARA) << BIT_SHIFT_PKTLEN_PARA)
#define BITS_PKTLEN_PARA (BIT_MASK_PKTLEN_PARA << BIT_SHIFT_PKTLEN_PARA)
#define BIT_CLEAR_PKTLEN_PARA(x) ((x) & (~BITS_PKTLEN_PARA))
#define BIT_GET_PKTLEN_PARA(x) \
(((x) >> BIT_SHIFT_PKTLEN_PARA) & BIT_MASK_PKTLEN_PARA)
#define BIT_SET_PKTLEN_PARA(x, v) \
(BIT_CLEAR_PKTLEN_PARA(x) | BIT_PKTLEN_PARA(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_EN_SDIO_FAIL BIT(9)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_GRAYCODE_SYNC_WITH_BIN BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_RXDMA_DBD_SEL BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_RX_DBG_SEL BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_EN_SPD BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_SHIFT_BURST_SIZE 4
#define BIT_MASK_BURST_SIZE 0x3
#define BIT_BURST_SIZE(x) (((x) & BIT_MASK_BURST_SIZE) << BIT_SHIFT_BURST_SIZE)
#define BITS_BURST_SIZE (BIT_MASK_BURST_SIZE << BIT_SHIFT_BURST_SIZE)
#define BIT_CLEAR_BURST_SIZE(x) ((x) & (~BITS_BURST_SIZE))
#define BIT_GET_BURST_SIZE(x) \
(((x) >> BIT_SHIFT_BURST_SIZE) & BIT_MASK_BURST_SIZE)
#define BIT_SET_BURST_SIZE(x, v) (BIT_CLEAR_BURST_SIZE(x) | BIT_BURST_SIZE(v))
#define BIT_SHIFT_BURST_CNT 2
#define BIT_MASK_BURST_CNT 0x3
#define BIT_BURST_CNT(x) (((x) & BIT_MASK_BURST_CNT) << BIT_SHIFT_BURST_CNT)
#define BITS_BURST_CNT (BIT_MASK_BURST_CNT << BIT_SHIFT_BURST_CNT)
#define BIT_CLEAR_BURST_CNT(x) ((x) & (~BITS_BURST_CNT))
#define BIT_GET_BURST_CNT(x) (((x) >> BIT_SHIFT_BURST_CNT) & BIT_MASK_BURST_CNT)
#define BIT_SET_BURST_CNT(x, v) (BIT_CLEAR_BURST_CNT(x) | BIT_BURST_CNT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_DAM_MODE BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_MODE (Offset 0x0290) */
#define BIT_DMA_MODE BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_C2H_PKT (Offset 0x0294) */
#define BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19 24
#define BIT_MASK_R_C2H_STR_ADDR_16_TO_19 0xf
#define BIT_R_C2H_STR_ADDR_16_TO_19(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_16_TO_19) \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19)
#define BITS_R_C2H_STR_ADDR_16_TO_19 \
(BIT_MASK_R_C2H_STR_ADDR_16_TO_19 << BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19)
#define BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19(x) \
((x) & (~BITS_R_C2H_STR_ADDR_16_TO_19))
#define BIT_GET_R_C2H_STR_ADDR_16_TO_19(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19) & \
BIT_MASK_R_C2H_STR_ADDR_16_TO_19)
#define BIT_SET_R_C2H_STR_ADDR_16_TO_19(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19(x) | BIT_R_C2H_STR_ADDR_16_TO_19(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_C2H_PKT (Offset 0x0294) */
#define BIT_R_C2H_PKT_REQ BIT(16)
#define BIT_SHIFT_R_C2H_STR_ADDR 0
#define BIT_MASK_R_C2H_STR_ADDR 0xffff
#define BIT_R_C2H_STR_ADDR(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR) << BIT_SHIFT_R_C2H_STR_ADDR)
#define BITS_R_C2H_STR_ADDR \
(BIT_MASK_R_C2H_STR_ADDR << BIT_SHIFT_R_C2H_STR_ADDR)
#define BIT_CLEAR_R_C2H_STR_ADDR(x) ((x) & (~BITS_R_C2H_STR_ADDR))
#define BIT_GET_R_C2H_STR_ADDR(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR) & BIT_MASK_R_C2H_STR_ADDR)
#define BIT_SET_R_C2H_STR_ADDR(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR(x) | BIT_R_C2H_STR_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWFF_C2H (Offset 0x0298) */
#define BIT_SHIFT_C2H_DMA_ADDR 0
#define BIT_MASK_C2H_DMA_ADDR 0x3ffff
#define BIT_C2H_DMA_ADDR(x) \
(((x) & BIT_MASK_C2H_DMA_ADDR) << BIT_SHIFT_C2H_DMA_ADDR)
#define BITS_C2H_DMA_ADDR (BIT_MASK_C2H_DMA_ADDR << BIT_SHIFT_C2H_DMA_ADDR)
#define BIT_CLEAR_C2H_DMA_ADDR(x) ((x) & (~BITS_C2H_DMA_ADDR))
#define BIT_GET_C2H_DMA_ADDR(x) \
(((x) >> BIT_SHIFT_C2H_DMA_ADDR) & BIT_MASK_C2H_DMA_ADDR)
#define BIT_SET_C2H_DMA_ADDR(x, v) \
(BIT_CLEAR_C2H_DMA_ADDR(x) | BIT_C2H_DMA_ADDR(v))
/* 2 REG_FWFF_CTRL (Offset 0x029C) */
#define BIT_FWFF_DMAPKT_REQ BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWFF_CTRL (Offset 0x029C) */
#define BIT_SHIFT_FWFF_DMA_PKT_NUM 16
#define BIT_MASK_FWFF_DMA_PKT_NUM 0xff
#define BIT_FWFF_DMA_PKT_NUM(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM) << BIT_SHIFT_FWFF_DMA_PKT_NUM)
#define BITS_FWFF_DMA_PKT_NUM \
(BIT_MASK_FWFF_DMA_PKT_NUM << BIT_SHIFT_FWFF_DMA_PKT_NUM)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM(x) ((x) & (~BITS_FWFF_DMA_PKT_NUM))
#define BIT_GET_FWFF_DMA_PKT_NUM(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM) & BIT_MASK_FWFF_DMA_PKT_NUM)
#define BIT_SET_FWFF_DMA_PKT_NUM(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM(x) | BIT_FWFF_DMA_PKT_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWFF_CTRL (Offset 0x029C) */
#define BIT_SHIFT_FWFF_DMA_PKT_NUM_V1 16
#define BIT_MASK_FWFF_DMA_PKT_NUM_V1 0x7fff
#define BIT_FWFF_DMA_PKT_NUM_V1(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM_V1) << BIT_SHIFT_FWFF_DMA_PKT_NUM_V1)
#define BITS_FWFF_DMA_PKT_NUM_V1 \
(BIT_MASK_FWFF_DMA_PKT_NUM_V1 << BIT_SHIFT_FWFF_DMA_PKT_NUM_V1)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM_V1(x) ((x) & (~BITS_FWFF_DMA_PKT_NUM_V1))
#define BIT_GET_FWFF_DMA_PKT_NUM_V1(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM_V1) & BIT_MASK_FWFF_DMA_PKT_NUM_V1)
#define BIT_SET_FWFF_DMA_PKT_NUM_V1(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM_V1(x) | BIT_FWFF_DMA_PKT_NUM_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWFF_CTRL (Offset 0x029C) */
#define BIT_SHIFT_FWFF_STR_ADDR 0
#define BIT_MASK_FWFF_STR_ADDR 0xffff
#define BIT_FWFF_STR_ADDR(x) \
(((x) & BIT_MASK_FWFF_STR_ADDR) << BIT_SHIFT_FWFF_STR_ADDR)
#define BITS_FWFF_STR_ADDR (BIT_MASK_FWFF_STR_ADDR << BIT_SHIFT_FWFF_STR_ADDR)
#define BIT_CLEAR_FWFF_STR_ADDR(x) ((x) & (~BITS_FWFF_STR_ADDR))
#define BIT_GET_FWFF_STR_ADDR(x) \
(((x) >> BIT_SHIFT_FWFF_STR_ADDR) & BIT_MASK_FWFF_STR_ADDR)
#define BIT_SET_FWFF_STR_ADDR(x, v) \
(BIT_CLEAR_FWFF_STR_ADDR(x) | BIT_FWFF_STR_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWFF_PKT_INFO (Offset 0x02A0) */
#define BIT_SHIFT_FWFF_PKT_QUEUED 16
#define BIT_MASK_FWFF_PKT_QUEUED 0xff
#define BIT_FWFF_PKT_QUEUED(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED) << BIT_SHIFT_FWFF_PKT_QUEUED)
#define BITS_FWFF_PKT_QUEUED \
(BIT_MASK_FWFF_PKT_QUEUED << BIT_SHIFT_FWFF_PKT_QUEUED)
#define BIT_CLEAR_FWFF_PKT_QUEUED(x) ((x) & (~BITS_FWFF_PKT_QUEUED))
#define BIT_GET_FWFF_PKT_QUEUED(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED) & BIT_MASK_FWFF_PKT_QUEUED)
#define BIT_SET_FWFF_PKT_QUEUED(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED(x) | BIT_FWFF_PKT_QUEUED(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWFF_PKT_INFO (Offset 0x02A0) */
#define BIT_SHIFT_FWFF_PKT_READ_ADDR 16
#define BIT_MASK_FWFF_PKT_READ_ADDR 0xffff
#define BIT_FWFF_PKT_READ_ADDR(x) \
(((x) & BIT_MASK_FWFF_PKT_READ_ADDR) << BIT_SHIFT_FWFF_PKT_READ_ADDR)
#define BITS_FWFF_PKT_READ_ADDR \
(BIT_MASK_FWFF_PKT_READ_ADDR << BIT_SHIFT_FWFF_PKT_READ_ADDR)
#define BIT_CLEAR_FWFF_PKT_READ_ADDR(x) ((x) & (~BITS_FWFF_PKT_READ_ADDR))
#define BIT_GET_FWFF_PKT_READ_ADDR(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_READ_ADDR) & BIT_MASK_FWFF_PKT_READ_ADDR)
#define BIT_SET_FWFF_PKT_READ_ADDR(x, v) \
(BIT_CLEAR_FWFF_PKT_READ_ADDR(x) | BIT_FWFF_PKT_READ_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FWFF_PKT_INFO (Offset 0x02A0) */
#define BIT_SHIFT_FWFF_PKT_STR_ADDR 0
#define BIT_MASK_FWFF_PKT_STR_ADDR 0xffff
#define BIT_FWFF_PKT_STR_ADDR(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR) << BIT_SHIFT_FWFF_PKT_STR_ADDR)
#define BITS_FWFF_PKT_STR_ADDR \
(BIT_MASK_FWFF_PKT_STR_ADDR << BIT_SHIFT_FWFF_PKT_STR_ADDR)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR(x) ((x) & (~BITS_FWFF_PKT_STR_ADDR))
#define BIT_GET_FWFF_PKT_STR_ADDR(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR) & BIT_MASK_FWFF_PKT_STR_ADDR)
#define BIT_SET_FWFF_PKT_STR_ADDR(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR(x) | BIT_FWFF_PKT_STR_ADDR(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_FWFF_PKT_INFO (Offset 0x02A0) */
#define BIT_SHIFT_FWFF_PKT_STR_ADDR_V1 0
#define BIT_MASK_FWFF_PKT_STR_ADDR_V1 0x7ff
#define BIT_FWFF_PKT_STR_ADDR_V1(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR_V1) \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_V1)
#define BITS_FWFF_PKT_STR_ADDR_V1 \
(BIT_MASK_FWFF_PKT_STR_ADDR_V1 << BIT_SHIFT_FWFF_PKT_STR_ADDR_V1)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR_V1(x) ((x) & (~BITS_FWFF_PKT_STR_ADDR_V1))
#define BIT_GET_FWFF_PKT_STR_ADDR_V1(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR_V1) & \
BIT_MASK_FWFF_PKT_STR_ADDR_V1)
#define BIT_SET_FWFF_PKT_STR_ADDR_V1(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR_V1(x) | BIT_FWFF_PKT_STR_ADDR_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWFF_PKT_INFO (Offset 0x02A0) */
#define BIT_SHIFT_FWFF_PKT_WRITE_ADDR 0
#define BIT_MASK_FWFF_PKT_WRITE_ADDR 0xffff
#define BIT_FWFF_PKT_WRITE_ADDR(x) \
(((x) & BIT_MASK_FWFF_PKT_WRITE_ADDR) << BIT_SHIFT_FWFF_PKT_WRITE_ADDR)
#define BITS_FWFF_PKT_WRITE_ADDR \
(BIT_MASK_FWFF_PKT_WRITE_ADDR << BIT_SHIFT_FWFF_PKT_WRITE_ADDR)
#define BIT_CLEAR_FWFF_PKT_WRITE_ADDR(x) ((x) & (~BITS_FWFF_PKT_WRITE_ADDR))
#define BIT_GET_FWFF_PKT_WRITE_ADDR(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_WRITE_ADDR) & BIT_MASK_FWFF_PKT_WRITE_ADDR)
#define BIT_SET_FWFF_PKT_WRITE_ADDR(x, v) \
(BIT_CLEAR_FWFF_PKT_WRITE_ADDR(x) | BIT_FWFF_PKT_WRITE_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_FC2H_INFO (Offset 0x02A4) */
#define BIT_FC2H_PKT_REQ BIT(16)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FC2H_INFO (Offset 0x02A4) */
#define BIT_FC2H_DMAPKT_REQ BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FC2H_INFO (Offset 0x02A4) */
#define BIT_SHIFT_FC2H_STR_ADDR 0
#define BIT_MASK_FC2H_STR_ADDR 0xffff
#define BIT_FC2H_STR_ADDR(x) \
(((x) & BIT_MASK_FC2H_STR_ADDR) << BIT_SHIFT_FC2H_STR_ADDR)
#define BITS_FC2H_STR_ADDR (BIT_MASK_FC2H_STR_ADDR << BIT_SHIFT_FC2H_STR_ADDR)
#define BIT_CLEAR_FC2H_STR_ADDR(x) ((x) & (~BITS_FC2H_STR_ADDR))
#define BIT_GET_FC2H_STR_ADDR(x) \
(((x) >> BIT_SHIFT_FC2H_STR_ADDR) & BIT_MASK_FC2H_STR_ADDR)
#define BIT_SET_FC2H_STR_ADDR(x, v) \
(BIT_CLEAR_FC2H_STR_ADDR(x) | BIT_FC2H_STR_ADDR(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWFF_PKT_INFO2 (Offset 0x02A4) */
#define BIT_SHIFT_FWFF_PKT_QUEUED_V1 0
#define BIT_MASK_FWFF_PKT_QUEUED_V1 0xffff
#define BIT_FWFF_PKT_QUEUED_V1(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED_V1) << BIT_SHIFT_FWFF_PKT_QUEUED_V1)
#define BITS_FWFF_PKT_QUEUED_V1 \
(BIT_MASK_FWFF_PKT_QUEUED_V1 << BIT_SHIFT_FWFF_PKT_QUEUED_V1)
#define BIT_CLEAR_FWFF_PKT_QUEUED_V1(x) ((x) & (~BITS_FWFF_PKT_QUEUED_V1))
#define BIT_GET_FWFF_PKT_QUEUED_V1(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED_V1) & BIT_MASK_FWFF_PKT_QUEUED_V1)
#define BIT_SET_FWFF_PKT_QUEUED_V1(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED_V1(x) | BIT_FWFF_PKT_QUEUED_V1(v))
#define BIT_SHIFT_FW_UPD_RXDES_RD_PTR 0
#define BIT_MASK_FW_UPD_RXDES_RD_PTR 0x3ffff
#define BIT_FW_UPD_RXDES_RD_PTR(x) \
(((x) & BIT_MASK_FW_UPD_RXDES_RD_PTR) << BIT_SHIFT_FW_UPD_RXDES_RD_PTR)
#define BITS_FW_UPD_RXDES_RD_PTR \
(BIT_MASK_FW_UPD_RXDES_RD_PTR << BIT_SHIFT_FW_UPD_RXDES_RD_PTR)
#define BIT_CLEAR_FW_UPD_RXDES_RD_PTR(x) ((x) & (~BITS_FW_UPD_RXDES_RD_PTR))
#define BIT_GET_FW_UPD_RXDES_RD_PTR(x) \
(((x) >> BIT_SHIFT_FW_UPD_RXDES_RD_PTR) & BIT_MASK_FW_UPD_RXDES_RD_PTR)
#define BIT_SET_FW_UPD_RXDES_RD_PTR(x, v) \
(BIT_CLEAR_FW_UPD_RXDES_RD_PTR(x) | BIT_FW_UPD_RXDES_RD_PTR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXPKTNUM (Offset 0x02B0) */
#define BIT_SHIFT_PKT_NUM_WOL_V1 16
#define BIT_MASK_PKT_NUM_WOL_V1 0xffff
#define BIT_PKT_NUM_WOL_V1(x) \
(((x) & BIT_MASK_PKT_NUM_WOL_V1) << BIT_SHIFT_PKT_NUM_WOL_V1)
#define BITS_PKT_NUM_WOL_V1 \
(BIT_MASK_PKT_NUM_WOL_V1 << BIT_SHIFT_PKT_NUM_WOL_V1)
#define BIT_CLEAR_PKT_NUM_WOL_V1(x) ((x) & (~BITS_PKT_NUM_WOL_V1))
#define BIT_GET_PKT_NUM_WOL_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL_V1) & BIT_MASK_PKT_NUM_WOL_V1)
#define BIT_SET_PKT_NUM_WOL_V1(x, v) \
(BIT_CLEAR_PKT_NUM_WOL_V1(x) | BIT_PKT_NUM_WOL_V1(v))
#define BIT_SHIFT_RXPKT_NUM_V1 0
#define BIT_MASK_RXPKT_NUM_V1 0xffff
#define BIT_RXPKT_NUM_V1(x) \
(((x) & BIT_MASK_RXPKT_NUM_V1) << BIT_SHIFT_RXPKT_NUM_V1)
#define BITS_RXPKT_NUM_V1 (BIT_MASK_RXPKT_NUM_V1 << BIT_SHIFT_RXPKT_NUM_V1)
#define BIT_CLEAR_RXPKT_NUM_V1(x) ((x) & (~BITS_RXPKT_NUM_V1))
#define BIT_GET_RXPKT_NUM_V1(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_V1) & BIT_MASK_RXPKT_NUM_V1)
#define BIT_SET_RXPKT_NUM_V1(x, v) \
(BIT_CLEAR_RXPKT_NUM_V1(x) | BIT_RXPKT_NUM_V1(v))
#define BIT_SHIFT_RXPKT_NUM_TH 0
#define BIT_MASK_RXPKT_NUM_TH 0xff
#define BIT_RXPKT_NUM_TH(x) \
(((x) & BIT_MASK_RXPKT_NUM_TH) << BIT_SHIFT_RXPKT_NUM_TH)
#define BITS_RXPKT_NUM_TH (BIT_MASK_RXPKT_NUM_TH << BIT_SHIFT_RXPKT_NUM_TH)
#define BIT_CLEAR_RXPKT_NUM_TH(x) ((x) & (~BITS_RXPKT_NUM_TH))
#define BIT_GET_RXPKT_NUM_TH(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_TH) & BIT_MASK_RXPKT_NUM_TH)
#define BIT_SET_RXPKT_NUM_TH(x, v) \
(BIT_CLEAR_RXPKT_NUM_TH(x) | BIT_RXPKT_NUM_TH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FW_MSG1 (Offset 0x02E0) */
#define BIT_SHIFT_FW_MSG_REG1 0
#define BIT_MASK_FW_MSG_REG1 0xffffffffL
#define BIT_FW_MSG_REG1(x) \
(((x) & BIT_MASK_FW_MSG_REG1) << BIT_SHIFT_FW_MSG_REG1)
#define BITS_FW_MSG_REG1 (BIT_MASK_FW_MSG_REG1 << BIT_SHIFT_FW_MSG_REG1)
#define BIT_CLEAR_FW_MSG_REG1(x) ((x) & (~BITS_FW_MSG_REG1))
#define BIT_GET_FW_MSG_REG1(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG1) & BIT_MASK_FW_MSG_REG1)
#define BIT_SET_FW_MSG_REG1(x, v) \
(BIT_CLEAR_FW_MSG_REG1(x) | BIT_FW_MSG_REG1(v))
/* 2 REG_FW_MSG2 (Offset 0x02E4) */
#define BIT_SHIFT_FW_MSG_REG2 0
#define BIT_MASK_FW_MSG_REG2 0xffffffffL
#define BIT_FW_MSG_REG2(x) \
(((x) & BIT_MASK_FW_MSG_REG2) << BIT_SHIFT_FW_MSG_REG2)
#define BITS_FW_MSG_REG2 (BIT_MASK_FW_MSG_REG2 << BIT_SHIFT_FW_MSG_REG2)
#define BIT_CLEAR_FW_MSG_REG2(x) ((x) & (~BITS_FW_MSG_REG2))
#define BIT_GET_FW_MSG_REG2(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG2) & BIT_MASK_FW_MSG_REG2)
#define BIT_SET_FW_MSG_REG2(x, v) \
(BIT_CLEAR_FW_MSG_REG2(x) | BIT_FW_MSG_REG2(v))
/* 2 REG_FW_MSG3 (Offset 0x02E8) */
#define BIT_SHIFT_FW_MSG_REG3 0
#define BIT_MASK_FW_MSG_REG3 0xffffffffL
#define BIT_FW_MSG_REG3(x) \
(((x) & BIT_MASK_FW_MSG_REG3) << BIT_SHIFT_FW_MSG_REG3)
#define BITS_FW_MSG_REG3 (BIT_MASK_FW_MSG_REG3 << BIT_SHIFT_FW_MSG_REG3)
#define BIT_CLEAR_FW_MSG_REG3(x) ((x) & (~BITS_FW_MSG_REG3))
#define BIT_GET_FW_MSG_REG3(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG3) & BIT_MASK_FW_MSG_REG3)
#define BIT_SET_FW_MSG_REG3(x, v) \
(BIT_CLEAR_FW_MSG_REG3(x) | BIT_FW_MSG_REG3(v))
/* 2 REG_FW_MSG4 (Offset 0x02EC) */
#define BIT_SHIFT_FW_MSG_REG4 0
#define BIT_MASK_FW_MSG_REG4 0xffffffffL
#define BIT_FW_MSG_REG4(x) \
(((x) & BIT_MASK_FW_MSG_REG4) << BIT_SHIFT_FW_MSG_REG4)
#define BITS_FW_MSG_REG4 (BIT_MASK_FW_MSG_REG4 << BIT_SHIFT_FW_MSG_REG4)
#define BIT_CLEAR_FW_MSG_REG4(x) ((x) & (~BITS_FW_MSG_REG4))
#define BIT_GET_FW_MSG_REG4(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG4) & BIT_MASK_FW_MSG_REG4)
#define BIT_SET_FW_MSG_REG4(x, v) \
(BIT_CLEAR_FW_MSG_REG4(x) | BIT_FW_MSG_REG4(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_PCIEIO_PERSTB_SEL BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL (Offset 0x0300) */
#define BIT_HCIIO_PERSTB_SEL BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_SHIFT_PCIE_MAX_RXDMA 28
#define BIT_MASK_PCIE_MAX_RXDMA 0x7
#define BIT_PCIE_MAX_RXDMA(x) \
(((x) & BIT_MASK_PCIE_MAX_RXDMA) << BIT_SHIFT_PCIE_MAX_RXDMA)
#define BITS_PCIE_MAX_RXDMA \
(BIT_MASK_PCIE_MAX_RXDMA << BIT_SHIFT_PCIE_MAX_RXDMA)
#define BIT_CLEAR_PCIE_MAX_RXDMA(x) ((x) & (~BITS_PCIE_MAX_RXDMA))
#define BIT_GET_PCIE_MAX_RXDMA(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_RXDMA) & BIT_MASK_PCIE_MAX_RXDMA)
#define BIT_SET_PCIE_MAX_RXDMA(x, v) \
(BIT_CLEAR_PCIE_MAX_RXDMA(x) | BIT_PCIE_MAX_RXDMA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL (Offset 0x0300) */
#define BIT_SHIFT_HCI_MAX_RXDMA 28
#define BIT_MASK_HCI_MAX_RXDMA 0x7
#define BIT_HCI_MAX_RXDMA(x) \
(((x) & BIT_MASK_HCI_MAX_RXDMA) << BIT_SHIFT_HCI_MAX_RXDMA)
#define BITS_HCI_MAX_RXDMA (BIT_MASK_HCI_MAX_RXDMA << BIT_SHIFT_HCI_MAX_RXDMA)
#define BIT_CLEAR_HCI_MAX_RXDMA(x) ((x) & (~BITS_HCI_MAX_RXDMA))
#define BIT_GET_HCI_MAX_RXDMA(x) \
(((x) >> BIT_SHIFT_HCI_MAX_RXDMA) & BIT_MASK_HCI_MAX_RXDMA)
#define BIT_SET_HCI_MAX_RXDMA(x, v) \
(BIT_CLEAR_HCI_MAX_RXDMA(x) | BIT_HCI_MAX_RXDMA(v))
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_LX_CTRL1 (Offset 0x0300) */
#define BIT_RX_LIT_EDN_SEL BIT(27)
#define BIT_TX_LIT_EDN_SEL BIT(26)
#define BIT_WT_LIT_EDN BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_SHIFT_PCIE_MAX_TXDMA 24
#define BIT_MASK_PCIE_MAX_TXDMA 0x7
#define BIT_PCIE_MAX_TXDMA(x) \
(((x) & BIT_MASK_PCIE_MAX_TXDMA) << BIT_SHIFT_PCIE_MAX_TXDMA)
#define BITS_PCIE_MAX_TXDMA \
(BIT_MASK_PCIE_MAX_TXDMA << BIT_SHIFT_PCIE_MAX_TXDMA)
#define BIT_CLEAR_PCIE_MAX_TXDMA(x) ((x) & (~BITS_PCIE_MAX_TXDMA))
#define BIT_GET_PCIE_MAX_TXDMA(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_TXDMA) & BIT_MASK_PCIE_MAX_TXDMA)
#define BIT_SET_PCIE_MAX_TXDMA(x, v) \
(BIT_CLEAR_PCIE_MAX_TXDMA(x) | BIT_PCIE_MAX_TXDMA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL (Offset 0x0300) */
#define BIT_SHIFT_HCI_MAX_TXDMA 24
#define BIT_MASK_HCI_MAX_TXDMA 0x7
#define BIT_HCI_MAX_TXDMA(x) \
(((x) & BIT_MASK_HCI_MAX_TXDMA) << BIT_SHIFT_HCI_MAX_TXDMA)
#define BITS_HCI_MAX_TXDMA (BIT_MASK_HCI_MAX_TXDMA << BIT_SHIFT_HCI_MAX_TXDMA)
#define BIT_CLEAR_HCI_MAX_TXDMA(x) ((x) & (~BITS_HCI_MAX_TXDMA))
#define BIT_GET_HCI_MAX_TXDMA(x) \
(((x) >> BIT_SHIFT_HCI_MAX_TXDMA) & BIT_MASK_HCI_MAX_TXDMA)
#define BIT_SET_HCI_MAX_TXDMA(x, v) \
(BIT_CLEAR_HCI_MAX_TXDMA(x) | BIT_HCI_MAX_TXDMA(v))
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_LX_CTRL1 (Offset 0x0300) */
#define BIT_RD_LITT_EDN BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_PWR_SCALE_START_PS BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_PCIE_RST_TRXDMA_INTF BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL (Offset 0x0300) */
#define BIT_HCI_RST_TRXDMA_INTF BIT(20)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_LX_CTRL1 (Offset 0x0300) */
#define BIT_SHIFT_MAX_RXDMA 20
#define BIT_MASK_MAX_RXDMA 0x7
#define BIT_MAX_RXDMA(x) (((x) & BIT_MASK_MAX_RXDMA) << BIT_SHIFT_MAX_RXDMA)
#define BITS_MAX_RXDMA (BIT_MASK_MAX_RXDMA << BIT_SHIFT_MAX_RXDMA)
#define BIT_CLEAR_MAX_RXDMA(x) ((x) & (~BITS_MAX_RXDMA))
#define BIT_GET_MAX_RXDMA(x) (((x) >> BIT_SHIFT_MAX_RXDMA) & BIT_MASK_MAX_RXDMA)
#define BIT_SET_MAX_RXDMA(x, v) (BIT_CLEAR_MAX_RXDMA(x) | BIT_MAX_RXDMA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_PCIE_EN_SWENT_L23 BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL (Offset 0x0300) */
#define BIT_HCI_EN_SWENT_L23 BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_PCIE_EN_HWEXT_L1 BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL (Offset 0x0300) */
#define BIT_HCI_EN_HWEXT_L1 BIT(16)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_LX_CTRL1 (Offset 0x0300) */
#define BIT_SHIFT_MAX_TXDMA 16
#define BIT_MASK_MAX_TXDMA 0x7
#define BIT_MAX_TXDMA(x) (((x) & BIT_MASK_MAX_TXDMA) << BIT_SHIFT_MAX_TXDMA)
#define BITS_MAX_TXDMA (BIT_MASK_MAX_TXDMA << BIT_SHIFT_MAX_TXDMA)
#define BIT_CLEAR_MAX_TXDMA(x) ((x) & (~BITS_MAX_TXDMA))
#define BIT_GET_MAX_TXDMA(x) (((x) >> BIT_SHIFT_MAX_TXDMA) & BIT_MASK_MAX_TXDMA)
#define BIT_SET_MAX_TXDMA(x, v) (BIT_CLEAR_MAX_TXDMA(x) | BIT_MAX_TXDMA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CTRL (Offset 0x0300) */
#define BIT_STOP_P0_MPRT_BCNQ4 BIT(6)
#define BIT_STOP_P0_MPRT_BCNQ3 BIT(4)
#define BIT_STOP_P0_MPRT_BCNQ2 BIT(2)
#define BIT_STOP_P0_MPRT_BCNQ1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_TXTTIMER_MATCH_NUM 28
#define BIT_MASK_TXTTIMER_MATCH_NUM 0xf
#define BIT_TXTTIMER_MATCH_NUM(x) \
(((x) & BIT_MASK_TXTTIMER_MATCH_NUM) << BIT_SHIFT_TXTTIMER_MATCH_NUM)
#define BITS_TXTTIMER_MATCH_NUM \
(BIT_MASK_TXTTIMER_MATCH_NUM << BIT_SHIFT_TXTTIMER_MATCH_NUM)
#define BIT_CLEAR_TXTTIMER_MATCH_NUM(x) ((x) & (~BITS_TXTTIMER_MATCH_NUM))
#define BIT_GET_TXTTIMER_MATCH_NUM(x) \
(((x) >> BIT_SHIFT_TXTTIMER_MATCH_NUM) & BIT_MASK_TXTTIMER_MATCH_NUM)
#define BIT_SET_TXTTIMER_MATCH_NUM(x, v) \
(BIT_CLEAR_TXTTIMER_MATCH_NUM(x) | BIT_TXTTIMER_MATCH_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH_CTRL (Offset 0x0304) */
#define BIT_STOP_P0HIQ19 BIT(27)
#define BIT_STOP_P0HIQ18 BIT(26)
#define BIT_STOP_P0HIQ17 BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_TXPKT_NUM_MATCH 24
#define BIT_MASK_TXPKT_NUM_MATCH 0xf
#define BIT_TXPKT_NUM_MATCH(x) \
(((x) & BIT_MASK_TXPKT_NUM_MATCH) << BIT_SHIFT_TXPKT_NUM_MATCH)
#define BITS_TXPKT_NUM_MATCH \
(BIT_MASK_TXPKT_NUM_MATCH << BIT_SHIFT_TXPKT_NUM_MATCH)
#define BIT_CLEAR_TXPKT_NUM_MATCH(x) ((x) & (~BITS_TXPKT_NUM_MATCH))
#define BIT_GET_TXPKT_NUM_MATCH(x) \
(((x) >> BIT_SHIFT_TXPKT_NUM_MATCH) & BIT_MASK_TXPKT_NUM_MATCH)
#define BIT_SET_TXPKT_NUM_MATCH(x, v) \
(BIT_CLEAR_TXPKT_NUM_MATCH(x) | BIT_TXPKT_NUM_MATCH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_TRXCOUNTER_MATCH 24
#define BIT_MASK_TRXCOUNTER_MATCH 0xff
#define BIT_TRXCOUNTER_MATCH(x) \
(((x) & BIT_MASK_TRXCOUNTER_MATCH) << BIT_SHIFT_TRXCOUNTER_MATCH)
#define BITS_TRXCOUNTER_MATCH \
(BIT_MASK_TRXCOUNTER_MATCH << BIT_SHIFT_TRXCOUNTER_MATCH)
#define BIT_CLEAR_TRXCOUNTER_MATCH(x) ((x) & (~BITS_TRXCOUNTER_MATCH))
#define BIT_GET_TRXCOUNTER_MATCH(x) \
(((x) >> BIT_SHIFT_TRXCOUNTER_MATCH) & BIT_MASK_TRXCOUNTER_MATCH)
#define BIT_SET_TRXCOUNTER_MATCH(x, v) \
(BIT_CLEAR_TRXCOUNTER_MATCH(x) | BIT_TRXCOUNTER_MATCH(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH_CTRL (Offset 0x0304) */
#define BIT_STOP_P0HIQ16 BIT(24)
#define BIT_RX_CLOSE_EN_V1 BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_RXTTIMER_MATCH_NUM 20
#define BIT_MASK_RXTTIMER_MATCH_NUM 0xf
#define BIT_RXTTIMER_MATCH_NUM(x) \
(((x) & BIT_MASK_RXTTIMER_MATCH_NUM) << BIT_SHIFT_RXTTIMER_MATCH_NUM)
#define BITS_RXTTIMER_MATCH_NUM \
(BIT_MASK_RXTTIMER_MATCH_NUM << BIT_SHIFT_RXTTIMER_MATCH_NUM)
#define BIT_CLEAR_RXTTIMER_MATCH_NUM(x) ((x) & (~BITS_RXTTIMER_MATCH_NUM))
#define BIT_GET_RXTTIMER_MATCH_NUM(x) \
(((x) >> BIT_SHIFT_RXTTIMER_MATCH_NUM) & BIT_MASK_RXTTIMER_MATCH_NUM)
#define BIT_SET_RXTTIMER_MATCH_NUM(x, v) \
(BIT_CLEAR_RXTTIMER_MATCH_NUM(x) | BIT_RXTTIMER_MATCH_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH_CTRL (Offset 0x0304) */
#define BIT_STOP_FWCMDQ BIT(20)
#define BIT_STOP_P0BCNQ BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_RXPKT_NUM_MATCH 16
#define BIT_MASK_RXPKT_NUM_MATCH 0xf
#define BIT_RXPKT_NUM_MATCH(x) \
(((x) & BIT_MASK_RXPKT_NUM_MATCH) << BIT_SHIFT_RXPKT_NUM_MATCH)
#define BITS_RXPKT_NUM_MATCH \
(BIT_MASK_RXPKT_NUM_MATCH << BIT_SHIFT_RXPKT_NUM_MATCH)
#define BIT_CLEAR_RXPKT_NUM_MATCH(x) ((x) & (~BITS_RXPKT_NUM_MATCH))
#define BIT_GET_RXPKT_NUM_MATCH(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_MATCH) & BIT_MASK_RXPKT_NUM_MATCH)
#define BIT_SET_RXPKT_NUM_MATCH(x, v) \
(BIT_CLEAR_RXPKT_NUM_MATCH(x) | BIT_RXPKT_NUM_MATCH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_TRXTIMER_MATCH 16
#define BIT_MASK_TRXTIMER_MATCH 0xff
#define BIT_TRXTIMER_MATCH(x) \
(((x) & BIT_MASK_TRXTIMER_MATCH) << BIT_SHIFT_TRXTIMER_MATCH)
#define BITS_TRXTIMER_MATCH \
(BIT_MASK_TRXTIMER_MATCH << BIT_SHIFT_TRXTIMER_MATCH)
#define BIT_CLEAR_TRXTIMER_MATCH(x) ((x) & (~BITS_TRXTIMER_MATCH))
#define BIT_GET_TRXTIMER_MATCH(x) \
(((x) >> BIT_SHIFT_TRXTIMER_MATCH) & BIT_MASK_TRXTIMER_MATCH)
#define BIT_SET_TRXTIMER_MATCH(x, v) \
(BIT_CLEAR_TRXTIMER_MATCH(x) | BIT_TRXTIMER_MATCH(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH_CTRL (Offset 0x0304) */
#define BIT_STOP_P0MGQ BIT(16)
#define BIT_STOP_ACH13 BIT(15)
#define BIT_STOP_ACH12 BIT(14)
#define BIT_STOP_ACH11 BIT(13)
#define BIT_STOP_ACH10 BIT(12)
#define BIT_STOP_ACH9 BIT(11)
#define BIT_STOP_ACH8 BIT(10)
#define BIT_STOP_ACH7 BIT(9)
#define BIT_STOP_ACH6 BIT(8)
#define BIT_STOP_ACH5 BIT(7)
#define BIT_STOP_ACH4 BIT(6)
#define BIT_STOP_ACH3 BIT(5)
#define BIT_STOP_ACH2 BIT(4)
#define BIT_STOP_ACH1 BIT(3)
#define BIT_STOP_ACH0 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_MIGRATE_TIMER 0
#define BIT_MASK_MIGRATE_TIMER 0xffff
#define BIT_MIGRATE_TIMER(x) \
(((x) & BIT_MASK_MIGRATE_TIMER) << BIT_SHIFT_MIGRATE_TIMER)
#define BITS_MIGRATE_TIMER (BIT_MASK_MIGRATE_TIMER << BIT_SHIFT_MIGRATE_TIMER)
#define BIT_CLEAR_MIGRATE_TIMER(x) ((x) & (~BITS_MIGRATE_TIMER))
#define BIT_GET_MIGRATE_TIMER(x) \
(((x) >> BIT_SHIFT_MIGRATE_TIMER) & BIT_MASK_MIGRATE_TIMER)
#define BIT_SET_MIGRATE_TIMER(x, v) \
(BIT_CLEAR_MIGRATE_TIMER(x) | BIT_MIGRATE_TIMER(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_INT_MIG (Offset 0x0304) */
#define BIT_SHIFT_TRXTIMER_UNIT 0
#define BIT_MASK_TRXTIMER_UNIT 0x3
#define BIT_TRXTIMER_UNIT(x) \
(((x) & BIT_MASK_TRXTIMER_UNIT) << BIT_SHIFT_TRXTIMER_UNIT)
#define BITS_TRXTIMER_UNIT (BIT_MASK_TRXTIMER_UNIT << BIT_SHIFT_TRXTIMER_UNIT)
#define BIT_CLEAR_TRXTIMER_UNIT(x) ((x) & (~BITS_TRXTIMER_UNIT))
#define BIT_GET_TRXTIMER_UNIT(x) \
(((x) >> BIT_SHIFT_TRXTIMER_UNIT) & BIT_MASK_TRXTIMER_UNIT)
#define BIT_SET_TRXTIMER_UNIT(x, v) \
(BIT_CLEAR_TRXTIMER_UNIT(x) | BIT_TRXTIMER_UNIT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH_CTRL (Offset 0x0304) */
#define BIT_STOP_P0RX BIT(0)
/* 2 REG_HIQ_CTRL (Offset 0x0308) */
#define BIT_STOP_P0HIQ15 BIT(15)
#define BIT_STOP_P0HIQ14 BIT(14)
#define BIT_STOP_P0HIQ13 BIT(13)
#define BIT_STOP_P0HIQ12 BIT(12)
#define BIT_STOP_P0HIQ11 BIT(11)
#define BIT_STOP_P0HIQ10 BIT(10)
#define BIT_STOP_P0HIQ9 BIT(9)
#define BIT_STOP_P0HIQ8 BIT(8)
#define BIT_STOP_P0HIQ7 BIT(7)
#define BIT_STOP_P0HIQ6 BIT(6)
#define BIT_STOP_P0HIQ5 BIT(5)
#define BIT_STOP_P0HIQ4 BIT(4)
#define BIT_STOP_P0HIQ3 BIT(3)
#define BIT_STOP_P0HIQ2 BIT(2)
#define BIT_STOP_P0HIQ1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCNQ_TXBD_DESA (Offset 0x0308) */
#define BIT_SHIFT_BCNQ_TXBD_DESA 0
#define BIT_MASK_BCNQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_BCNQ_TXBD_DESA(x) \
(((x) & BIT_MASK_BCNQ_TXBD_DESA) << BIT_SHIFT_BCNQ_TXBD_DESA)
#define BITS_BCNQ_TXBD_DESA \
(BIT_MASK_BCNQ_TXBD_DESA << BIT_SHIFT_BCNQ_TXBD_DESA)
#define BIT_CLEAR_BCNQ_TXBD_DESA(x) ((x) & (~BITS_BCNQ_TXBD_DESA))
#define BIT_GET_BCNQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_BCNQ_TXBD_DESA) & BIT_MASK_BCNQ_TXBD_DESA)
#define BIT_SET_BCNQ_TXBD_DESA(x, v) \
(BIT_CLEAR_BCNQ_TXBD_DESA(x) | BIT_BCNQ_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIQ_CTRL (Offset 0x0308) */
#define BIT_STOP_P0HIQ0 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_TXBD_DESA (Offset 0x0310) */
#define BIT_SHIFT_MGQ_TXBD_DESA 0
#define BIT_MASK_MGQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_MGQ_TXBD_DESA(x) \
(((x) & BIT_MASK_MGQ_TXBD_DESA) << BIT_SHIFT_MGQ_TXBD_DESA)
#define BITS_MGQ_TXBD_DESA (BIT_MASK_MGQ_TXBD_DESA << BIT_SHIFT_MGQ_TXBD_DESA)
#define BIT_CLEAR_MGQ_TXBD_DESA(x) ((x) & (~BITS_MGQ_TXBD_DESA))
#define BIT_GET_MGQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_MGQ_TXBD_DESA) & BIT_MASK_MGQ_TXBD_DESA)
#define BIT_SET_MGQ_TXBD_DESA(x, v) \
(BIT_CLEAR_MGQ_TXBD_DESA(x) | BIT_MGQ_TXBD_DESA(v))
/* 2 REG_VOQ_TXBD_DESA (Offset 0x0318) */
#define BIT_SHIFT_VOQ_TXBD_DESA 0
#define BIT_MASK_VOQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_VOQ_TXBD_DESA(x) \
(((x) & BIT_MASK_VOQ_TXBD_DESA) << BIT_SHIFT_VOQ_TXBD_DESA)
#define BITS_VOQ_TXBD_DESA (BIT_MASK_VOQ_TXBD_DESA << BIT_SHIFT_VOQ_TXBD_DESA)
#define BIT_CLEAR_VOQ_TXBD_DESA(x) ((x) & (~BITS_VOQ_TXBD_DESA))
#define BIT_GET_VOQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_VOQ_TXBD_DESA) & BIT_MASK_VOQ_TXBD_DESA)
#define BIT_SET_VOQ_TXBD_DESA(x, v) \
(BIT_CLEAR_VOQ_TXBD_DESA(x) | BIT_VOQ_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_TXBD_DESA_L (Offset 0x0318) */
#define BIT_SHIFT_ACH0_TXBD_DESA_L 0
#define BIT_MASK_ACH0_TXBD_DESA_L 0xffffffffL
#define BIT_ACH0_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH0_TXBD_DESA_L) << BIT_SHIFT_ACH0_TXBD_DESA_L)
#define BITS_ACH0_TXBD_DESA_L \
(BIT_MASK_ACH0_TXBD_DESA_L << BIT_SHIFT_ACH0_TXBD_DESA_L)
#define BIT_CLEAR_ACH0_TXBD_DESA_L(x) ((x) & (~BITS_ACH0_TXBD_DESA_L))
#define BIT_GET_ACH0_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH0_TXBD_DESA_L) & BIT_MASK_ACH0_TXBD_DESA_L)
#define BIT_SET_ACH0_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH0_TXBD_DESA_L(x) | BIT_ACH0_TXBD_DESA_L(v))
/* 2 REG_ACH0_TXBD_DESA_H (Offset 0x031C) */
#define BIT_SHIFT_ACH0_TXBD_DESA_H 0
#define BIT_MASK_ACH0_TXBD_DESA_H 0xffffffffL
#define BIT_ACH0_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH0_TXBD_DESA_H) << BIT_SHIFT_ACH0_TXBD_DESA_H)
#define BITS_ACH0_TXBD_DESA_H \
(BIT_MASK_ACH0_TXBD_DESA_H << BIT_SHIFT_ACH0_TXBD_DESA_H)
#define BIT_CLEAR_ACH0_TXBD_DESA_H(x) ((x) & (~BITS_ACH0_TXBD_DESA_H))
#define BIT_GET_ACH0_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH0_TXBD_DESA_H) & BIT_MASK_ACH0_TXBD_DESA_H)
#define BIT_SET_ACH0_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH0_TXBD_DESA_H(x) | BIT_ACH0_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VIQ_TXBD_DESA (Offset 0x0320) */
#define BIT_SHIFT_VIQ_TXBD_DESA 0
#define BIT_MASK_VIQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_VIQ_TXBD_DESA(x) \
(((x) & BIT_MASK_VIQ_TXBD_DESA) << BIT_SHIFT_VIQ_TXBD_DESA)
#define BITS_VIQ_TXBD_DESA (BIT_MASK_VIQ_TXBD_DESA << BIT_SHIFT_VIQ_TXBD_DESA)
#define BIT_CLEAR_VIQ_TXBD_DESA(x) ((x) & (~BITS_VIQ_TXBD_DESA))
#define BIT_GET_VIQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_VIQ_TXBD_DESA) & BIT_MASK_VIQ_TXBD_DESA)
#define BIT_SET_VIQ_TXBD_DESA(x, v) \
(BIT_CLEAR_VIQ_TXBD_DESA(x) | BIT_VIQ_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH1_TXBD_DESA_L (Offset 0x0320) */
#define BIT_SHIFT_ACH1_TXBD_DESA_L 0
#define BIT_MASK_ACH1_TXBD_DESA_L 0xffffffffL
#define BIT_ACH1_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH1_TXBD_DESA_L) << BIT_SHIFT_ACH1_TXBD_DESA_L)
#define BITS_ACH1_TXBD_DESA_L \
(BIT_MASK_ACH1_TXBD_DESA_L << BIT_SHIFT_ACH1_TXBD_DESA_L)
#define BIT_CLEAR_ACH1_TXBD_DESA_L(x) ((x) & (~BITS_ACH1_TXBD_DESA_L))
#define BIT_GET_ACH1_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH1_TXBD_DESA_L) & BIT_MASK_ACH1_TXBD_DESA_L)
#define BIT_SET_ACH1_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH1_TXBD_DESA_L(x) | BIT_ACH1_TXBD_DESA_L(v))
/* 2 REG_ACH1_TXBD_DESA_H (Offset 0x0324) */
#define BIT_SHIFT_ACH1_TXBD_DESA_H 0
#define BIT_MASK_ACH1_TXBD_DESA_H 0xffffffffL
#define BIT_ACH1_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH1_TXBD_DESA_H) << BIT_SHIFT_ACH1_TXBD_DESA_H)
#define BITS_ACH1_TXBD_DESA_H \
(BIT_MASK_ACH1_TXBD_DESA_H << BIT_SHIFT_ACH1_TXBD_DESA_H)
#define BIT_CLEAR_ACH1_TXBD_DESA_H(x) ((x) & (~BITS_ACH1_TXBD_DESA_H))
#define BIT_GET_ACH1_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH1_TXBD_DESA_H) & BIT_MASK_ACH1_TXBD_DESA_H)
#define BIT_SET_ACH1_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH1_TXBD_DESA_H(x) | BIT_ACH1_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BEQ_TXBD_DESA (Offset 0x0328) */
#define BIT_SHIFT_BEQ_TXBD_DESA 0
#define BIT_MASK_BEQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_BEQ_TXBD_DESA(x) \
(((x) & BIT_MASK_BEQ_TXBD_DESA) << BIT_SHIFT_BEQ_TXBD_DESA)
#define BITS_BEQ_TXBD_DESA (BIT_MASK_BEQ_TXBD_DESA << BIT_SHIFT_BEQ_TXBD_DESA)
#define BIT_CLEAR_BEQ_TXBD_DESA(x) ((x) & (~BITS_BEQ_TXBD_DESA))
#define BIT_GET_BEQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_BEQ_TXBD_DESA) & BIT_MASK_BEQ_TXBD_DESA)
#define BIT_SET_BEQ_TXBD_DESA(x, v) \
(BIT_CLEAR_BEQ_TXBD_DESA(x) | BIT_BEQ_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_TXBD_DESA_L (Offset 0x0328) */
#define BIT_SHIFT_ACH2_TXBD_DESA_L 0
#define BIT_MASK_ACH2_TXBD_DESA_L 0xffffffffL
#define BIT_ACH2_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH2_TXBD_DESA_L) << BIT_SHIFT_ACH2_TXBD_DESA_L)
#define BITS_ACH2_TXBD_DESA_L \
(BIT_MASK_ACH2_TXBD_DESA_L << BIT_SHIFT_ACH2_TXBD_DESA_L)
#define BIT_CLEAR_ACH2_TXBD_DESA_L(x) ((x) & (~BITS_ACH2_TXBD_DESA_L))
#define BIT_GET_ACH2_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH2_TXBD_DESA_L) & BIT_MASK_ACH2_TXBD_DESA_L)
#define BIT_SET_ACH2_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH2_TXBD_DESA_L(x) | BIT_ACH2_TXBD_DESA_L(v))
/* 2 REG_ACH2_TXBD_DESA_H (Offset 0x032C) */
#define BIT_SHIFT_ACH2_TXBD_DESA_H 0
#define BIT_MASK_ACH2_TXBD_DESA_H 0xffffffffL
#define BIT_ACH2_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH2_TXBD_DESA_H) << BIT_SHIFT_ACH2_TXBD_DESA_H)
#define BITS_ACH2_TXBD_DESA_H \
(BIT_MASK_ACH2_TXBD_DESA_H << BIT_SHIFT_ACH2_TXBD_DESA_H)
#define BIT_CLEAR_ACH2_TXBD_DESA_H(x) ((x) & (~BITS_ACH2_TXBD_DESA_H))
#define BIT_GET_ACH2_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH2_TXBD_DESA_H) & BIT_MASK_ACH2_TXBD_DESA_H)
#define BIT_SET_ACH2_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH2_TXBD_DESA_H(x) | BIT_ACH2_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BKQ_TXBD_DESA (Offset 0x0330) */
#define BIT_SHIFT_BKQ_TXBD_DESA 0
#define BIT_MASK_BKQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_BKQ_TXBD_DESA(x) \
(((x) & BIT_MASK_BKQ_TXBD_DESA) << BIT_SHIFT_BKQ_TXBD_DESA)
#define BITS_BKQ_TXBD_DESA (BIT_MASK_BKQ_TXBD_DESA << BIT_SHIFT_BKQ_TXBD_DESA)
#define BIT_CLEAR_BKQ_TXBD_DESA(x) ((x) & (~BITS_BKQ_TXBD_DESA))
#define BIT_GET_BKQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_BKQ_TXBD_DESA) & BIT_MASK_BKQ_TXBD_DESA)
#define BIT_SET_BKQ_TXBD_DESA(x, v) \
(BIT_CLEAR_BKQ_TXBD_DESA(x) | BIT_BKQ_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH3_TXBD_DESA_L (Offset 0x0330) */
#define BIT_SHIFT_ACH3_TXBD_DESA_L 0
#define BIT_MASK_ACH3_TXBD_DESA_L 0xffffffffL
#define BIT_ACH3_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH3_TXBD_DESA_L) << BIT_SHIFT_ACH3_TXBD_DESA_L)
#define BITS_ACH3_TXBD_DESA_L \
(BIT_MASK_ACH3_TXBD_DESA_L << BIT_SHIFT_ACH3_TXBD_DESA_L)
#define BIT_CLEAR_ACH3_TXBD_DESA_L(x) ((x) & (~BITS_ACH3_TXBD_DESA_L))
#define BIT_GET_ACH3_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH3_TXBD_DESA_L) & BIT_MASK_ACH3_TXBD_DESA_L)
#define BIT_SET_ACH3_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH3_TXBD_DESA_L(x) | BIT_ACH3_TXBD_DESA_L(v))
/* 2 REG_ACH3_TXBD_DESA_H (Offset 0x0334) */
#define BIT_SHIFT_ACH3_TXBD_DESA_H 0
#define BIT_MASK_ACH3_TXBD_DESA_H 0xffffffffL
#define BIT_ACH3_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH3_TXBD_DESA_H) << BIT_SHIFT_ACH3_TXBD_DESA_H)
#define BITS_ACH3_TXBD_DESA_H \
(BIT_MASK_ACH3_TXBD_DESA_H << BIT_SHIFT_ACH3_TXBD_DESA_H)
#define BIT_CLEAR_ACH3_TXBD_DESA_H(x) ((x) & (~BITS_ACH3_TXBD_DESA_H))
#define BIT_GET_ACH3_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH3_TXBD_DESA_H) & BIT_MASK_ACH3_TXBD_DESA_H)
#define BIT_SET_ACH3_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH3_TXBD_DESA_H(x) | BIT_ACH3_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXQ_RXBD_DESA (Offset 0x0338) */
#define BIT_SHIFT_RXQ_RXBD_DESA 0
#define BIT_MASK_RXQ_RXBD_DESA 0xffffffffffffffffL
#define BIT_RXQ_RXBD_DESA(x) \
(((x) & BIT_MASK_RXQ_RXBD_DESA) << BIT_SHIFT_RXQ_RXBD_DESA)
#define BITS_RXQ_RXBD_DESA (BIT_MASK_RXQ_RXBD_DESA << BIT_SHIFT_RXQ_RXBD_DESA)
#define BIT_CLEAR_RXQ_RXBD_DESA(x) ((x) & (~BITS_RXQ_RXBD_DESA))
#define BIT_GET_RXQ_RXBD_DESA(x) \
(((x) >> BIT_SHIFT_RXQ_RXBD_DESA) & BIT_MASK_RXQ_RXBD_DESA)
#define BIT_SET_RXQ_RXBD_DESA(x, v) \
(BIT_CLEAR_RXQ_RXBD_DESA(x) | BIT_RXQ_RXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0RXQ_RXBD_DESA_L (Offset 0x0338) */
#define BIT_SHIFT_P0RXQ_RXBD_DESA_L 0
#define BIT_MASK_P0RXQ_RXBD_DESA_L 0xffffffffL
#define BIT_P0RXQ_RXBD_DESA_L(x) \
(((x) & BIT_MASK_P0RXQ_RXBD_DESA_L) << BIT_SHIFT_P0RXQ_RXBD_DESA_L)
#define BITS_P0RXQ_RXBD_DESA_L \
(BIT_MASK_P0RXQ_RXBD_DESA_L << BIT_SHIFT_P0RXQ_RXBD_DESA_L)
#define BIT_CLEAR_P0RXQ_RXBD_DESA_L(x) ((x) & (~BITS_P0RXQ_RXBD_DESA_L))
#define BIT_GET_P0RXQ_RXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_P0RXQ_RXBD_DESA_L) & BIT_MASK_P0RXQ_RXBD_DESA_L)
#define BIT_SET_P0RXQ_RXBD_DESA_L(x, v) \
(BIT_CLEAR_P0RXQ_RXBD_DESA_L(x) | BIT_P0RXQ_RXBD_DESA_L(v))
/* 2 REG_P0RXQ_RXBD_DESA_H (Offset 0x033C) */
#define BIT_SHIFT_P0RXQ_RXBD_DESA_H 0
#define BIT_MASK_P0RXQ_RXBD_DESA_H 0xffffffffL
#define BIT_P0RXQ_RXBD_DESA_H(x) \
(((x) & BIT_MASK_P0RXQ_RXBD_DESA_H) << BIT_SHIFT_P0RXQ_RXBD_DESA_H)
#define BITS_P0RXQ_RXBD_DESA_H \
(BIT_MASK_P0RXQ_RXBD_DESA_H << BIT_SHIFT_P0RXQ_RXBD_DESA_H)
#define BIT_CLEAR_P0RXQ_RXBD_DESA_H(x) ((x) & (~BITS_P0RXQ_RXBD_DESA_H))
#define BIT_GET_P0RXQ_RXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_P0RXQ_RXBD_DESA_H) & BIT_MASK_P0RXQ_RXBD_DESA_H)
#define BIT_SET_P0RXQ_RXBD_DESA_H(x, v) \
(BIT_CLEAR_P0RXQ_RXBD_DESA_H(x) | BIT_P0RXQ_RXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI0Q_TXBD_DESA (Offset 0x0340) */
#define BIT_SHIFT_HI0Q_TXBD_DESA 0
#define BIT_MASK_HI0Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI0Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA) << BIT_SHIFT_HI0Q_TXBD_DESA)
#define BITS_HI0Q_TXBD_DESA \
(BIT_MASK_HI0Q_TXBD_DESA << BIT_SHIFT_HI0Q_TXBD_DESA)
#define BIT_CLEAR_HI0Q_TXBD_DESA(x) ((x) & (~BITS_HI0Q_TXBD_DESA))
#define BIT_GET_HI0Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA) & BIT_MASK_HI0Q_TXBD_DESA)
#define BIT_SET_HI0Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA(x) | BIT_HI0Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0BCNQ_TXBD_DESA_L (Offset 0x0340) */
#define BIT_SHIFT_P0BCNQ_TXBD_DESA_L 0
#define BIT_MASK_P0BCNQ_TXBD_DESA_L 0xffffffffL
#define BIT_P0BCNQ_TXBD_DESA_L(x) \
(((x) & BIT_MASK_P0BCNQ_TXBD_DESA_L) << BIT_SHIFT_P0BCNQ_TXBD_DESA_L)
#define BITS_P0BCNQ_TXBD_DESA_L \
(BIT_MASK_P0BCNQ_TXBD_DESA_L << BIT_SHIFT_P0BCNQ_TXBD_DESA_L)
#define BIT_CLEAR_P0BCNQ_TXBD_DESA_L(x) ((x) & (~BITS_P0BCNQ_TXBD_DESA_L))
#define BIT_GET_P0BCNQ_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_P0BCNQ_TXBD_DESA_L) & BIT_MASK_P0BCNQ_TXBD_DESA_L)
#define BIT_SET_P0BCNQ_TXBD_DESA_L(x, v) \
(BIT_CLEAR_P0BCNQ_TXBD_DESA_L(x) | BIT_P0BCNQ_TXBD_DESA_L(v))
/* 2 REG_P0BCNQ_TXBD_DESA_H (Offset 0x0344) */
#define BIT_SHIFT_P0BCNQ_TXBD_DESA_H 0
#define BIT_MASK_P0BCNQ_TXBD_DESA_H 0xffffffffL
#define BIT_P0BCNQ_TXBD_DESA_H(x) \
(((x) & BIT_MASK_P0BCNQ_TXBD_DESA_H) << BIT_SHIFT_P0BCNQ_TXBD_DESA_H)
#define BITS_P0BCNQ_TXBD_DESA_H \
(BIT_MASK_P0BCNQ_TXBD_DESA_H << BIT_SHIFT_P0BCNQ_TXBD_DESA_H)
#define BIT_CLEAR_P0BCNQ_TXBD_DESA_H(x) ((x) & (~BITS_P0BCNQ_TXBD_DESA_H))
#define BIT_GET_P0BCNQ_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_P0BCNQ_TXBD_DESA_H) & BIT_MASK_P0BCNQ_TXBD_DESA_H)
#define BIT_SET_P0BCNQ_TXBD_DESA_H(x, v) \
(BIT_CLEAR_P0BCNQ_TXBD_DESA_H(x) | BIT_P0BCNQ_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI1Q_TXBD_DESA (Offset 0x0348) */
#define BIT_SHIFT_HI1Q_TXBD_DESA 0
#define BIT_MASK_HI1Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI1Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA) << BIT_SHIFT_HI1Q_TXBD_DESA)
#define BITS_HI1Q_TXBD_DESA \
(BIT_MASK_HI1Q_TXBD_DESA << BIT_SHIFT_HI1Q_TXBD_DESA)
#define BIT_CLEAR_HI1Q_TXBD_DESA(x) ((x) & (~BITS_HI1Q_TXBD_DESA))
#define BIT_GET_HI1Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA) & BIT_MASK_HI1Q_TXBD_DESA)
#define BIT_SET_HI1Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA(x) | BIT_HI1Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWCMDQ_TXBD_DESA_L (Offset 0x0348) */
#define BIT_SHIFT_FWCMDQ_TXBD_DESA_L 0
#define BIT_MASK_FWCMDQ_TXBD_DESA_L 0xffffffffL
#define BIT_FWCMDQ_TXBD_DESA_L(x) \
(((x) & BIT_MASK_FWCMDQ_TXBD_DESA_L) << BIT_SHIFT_FWCMDQ_TXBD_DESA_L)
#define BITS_FWCMDQ_TXBD_DESA_L \
(BIT_MASK_FWCMDQ_TXBD_DESA_L << BIT_SHIFT_FWCMDQ_TXBD_DESA_L)
#define BIT_CLEAR_FWCMDQ_TXBD_DESA_L(x) ((x) & (~BITS_FWCMDQ_TXBD_DESA_L))
#define BIT_GET_FWCMDQ_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TXBD_DESA_L) & BIT_MASK_FWCMDQ_TXBD_DESA_L)
#define BIT_SET_FWCMDQ_TXBD_DESA_L(x, v) \
(BIT_CLEAR_FWCMDQ_TXBD_DESA_L(x) | BIT_FWCMDQ_TXBD_DESA_L(v))
/* 2 REG_FWCMDQ_TXBD_DESA_H (Offset 0x034C) */
#define BIT_SHIFT_FWCMDQ_TXBD_DESA_H 0
#define BIT_MASK_FWCMDQ_TXBD_DESA_H 0xffffffffL
#define BIT_FWCMDQ_TXBD_DESA_H(x) \
(((x) & BIT_MASK_FWCMDQ_TXBD_DESA_H) << BIT_SHIFT_FWCMDQ_TXBD_DESA_H)
#define BITS_FWCMDQ_TXBD_DESA_H \
(BIT_MASK_FWCMDQ_TXBD_DESA_H << BIT_SHIFT_FWCMDQ_TXBD_DESA_H)
#define BIT_CLEAR_FWCMDQ_TXBD_DESA_H(x) ((x) & (~BITS_FWCMDQ_TXBD_DESA_H))
#define BIT_GET_FWCMDQ_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TXBD_DESA_H) & BIT_MASK_FWCMDQ_TXBD_DESA_H)
#define BIT_SET_FWCMDQ_TXBD_DESA_H(x, v) \
(BIT_CLEAR_FWCMDQ_TXBD_DESA_H(x) | BIT_FWCMDQ_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI2Q_TXBD_DESA (Offset 0x0350) */
#define BIT_SHIFT_HI2Q_TXBD_DESA 0
#define BIT_MASK_HI2Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI2Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA) << BIT_SHIFT_HI2Q_TXBD_DESA)
#define BITS_HI2Q_TXBD_DESA \
(BIT_MASK_HI2Q_TXBD_DESA << BIT_SHIFT_HI2Q_TXBD_DESA)
#define BIT_CLEAR_HI2Q_TXBD_DESA(x) ((x) & (~BITS_HI2Q_TXBD_DESA))
#define BIT_GET_HI2Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA) & BIT_MASK_HI2Q_TXBD_DESA)
#define BIT_SET_HI2Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA(x) | BIT_HI2Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_HRPWM1_HCPWM1_DCPU (Offset 0x0354) */
#define BIT_SHIFT_PCIE_HCPWM1_DCPU 16
#define BIT_MASK_PCIE_HCPWM1_DCPU 0xff
#define BIT_PCIE_HCPWM1_DCPU(x) \
(((x) & BIT_MASK_PCIE_HCPWM1_DCPU) << BIT_SHIFT_PCIE_HCPWM1_DCPU)
#define BITS_PCIE_HCPWM1_DCPU \
(BIT_MASK_PCIE_HCPWM1_DCPU << BIT_SHIFT_PCIE_HCPWM1_DCPU)
#define BIT_CLEAR_PCIE_HCPWM1_DCPU(x) ((x) & (~BITS_PCIE_HCPWM1_DCPU))
#define BIT_GET_PCIE_HCPWM1_DCPU(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM1_DCPU) & BIT_MASK_PCIE_HCPWM1_DCPU)
#define BIT_SET_PCIE_HCPWM1_DCPU(x, v) \
(BIT_CLEAR_PCIE_HCPWM1_DCPU(x) | BIT_PCIE_HCPWM1_DCPU(v))
#define BIT_SHIFT_PCIE_HRPWM1_DCPU 8
#define BIT_MASK_PCIE_HRPWM1_DCPU 0xff
#define BIT_PCIE_HRPWM1_DCPU(x) \
(((x) & BIT_MASK_PCIE_HRPWM1_DCPU) << BIT_SHIFT_PCIE_HRPWM1_DCPU)
#define BITS_PCIE_HRPWM1_DCPU \
(BIT_MASK_PCIE_HRPWM1_DCPU << BIT_SHIFT_PCIE_HRPWM1_DCPU)
#define BIT_CLEAR_PCIE_HRPWM1_DCPU(x) ((x) & (~BITS_PCIE_HRPWM1_DCPU))
#define BIT_GET_PCIE_HRPWM1_DCPU(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM1_DCPU) & BIT_MASK_PCIE_HRPWM1_DCPU)
#define BIT_SET_PCIE_HRPWM1_DCPU(x, v) \
(BIT_CLEAR_PCIE_HRPWM1_DCPU(x) | BIT_PCIE_HRPWM1_DCPU(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI3Q_TXBD_DESA (Offset 0x0358) */
#define BIT_SHIFT_HI3Q_TXBD_DESA 0
#define BIT_MASK_HI3Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI3Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA) << BIT_SHIFT_HI3Q_TXBD_DESA)
#define BITS_HI3Q_TXBD_DESA \
(BIT_MASK_HI3Q_TXBD_DESA << BIT_SHIFT_HI3Q_TXBD_DESA)
#define BIT_CLEAR_HI3Q_TXBD_DESA(x) ((x) & (~BITS_HI3Q_TXBD_DESA))
#define BIT_GET_HI3Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA) & BIT_MASK_HI3Q_TXBD_DESA)
#define BIT_SET_HI3Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA(x) | BIT_HI3Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0_MPRT_BCNQ_TXBD_DESA_L (Offset 0x0358) */
#define BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L 0
#define BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L 0xffffffffL
#define BIT_P0_MPRT_BCNQ_TXBD_DESA_L(x) \
(((x) & BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L) \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L)
#define BITS_P0_MPRT_BCNQ_TXBD_DESA_L \
(BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L)
#define BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_L(x) \
((x) & (~BITS_P0_MPRT_BCNQ_TXBD_DESA_L))
#define BIT_GET_P0_MPRT_BCNQ_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L) & \
BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L)
#define BIT_SET_P0_MPRT_BCNQ_TXBD_DESA_L(x, v) \
(BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_L(x) | \
BIT_P0_MPRT_BCNQ_TXBD_DESA_L(v))
/* 2 REG_P0_MPRT_BCNQ_TXBD_DESA_H (Offset 0x035C) */
#define BIT_CLR_P0HI15Q_HW_IDX BIT(29)
#define BIT_CLR_P0HI14Q_HW_IDX BIT(28)
#define BIT_CLR_P0HI13Q_HW_IDX BIT(27)
#define BIT_CLR_P0HI12Q_HW_IDX BIT(26)
#define BIT_CLR_P0HI11Q_HW_IDX BIT(25)
#define BIT_CLR_P0HI10Q_HW_IDX BIT(24)
#define BIT_CLR_P0HI9Q_HW_IDX BIT(23)
#define BIT_CLR_P0HI8Q_HW_IDX BIT(22)
#define BIT_CLR_ACH7_HW_IDX BIT(21)
#define BIT_CLR_ACH13_HW_IDX BIT(21)
#define BIT_CLR_ACH6_HW_IDX BIT(20)
#define BIT_CLR_ACH12_HW_IDX BIT(20)
#define BIT_CLR_ACH5_HW_IDX BIT(19)
#define BIT_CLR_ACH11_HW_IDX BIT(19)
#define BIT_CLR_ACH4_HW_IDX BIT(18)
#define BIT_CLR_ACH10_HW_IDX BIT(18)
#define BIT_CLR_ACH9_HW_IDX BIT(17)
#define BIT_CLR_ACH8_HW_IDX BIT(16)
#define BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE 13
#define BIT_MASK_P0_MPRT_BCNQ_DESC_MODE 0x3
#define BIT_P0_MPRT_BCNQ_DESC_MODE(x) \
(((x) & BIT_MASK_P0_MPRT_BCNQ_DESC_MODE) \
<< BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE)
#define BITS_P0_MPRT_BCNQ_DESC_MODE \
(BIT_MASK_P0_MPRT_BCNQ_DESC_MODE << BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE)
#define BIT_CLEAR_P0_MPRT_BCNQ_DESC_MODE(x) \
((x) & (~BITS_P0_MPRT_BCNQ_DESC_MODE))
#define BIT_GET_P0_MPRT_BCNQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE) & \
BIT_MASK_P0_MPRT_BCNQ_DESC_MODE)
#define BIT_SET_P0_MPRT_BCNQ_DESC_MODE(x, v) \
(BIT_CLEAR_P0_MPRT_BCNQ_DESC_MODE(x) | BIT_P0_MPRT_BCNQ_DESC_MODE(v))
#define BIT_CLR_P0HI15Q_HOST_IDX BIT(13)
#define BIT_CLR_P0HI14Q_HOST_IDX BIT(12)
#define BIT_PCIE_P0MPRT_BCNQ4_FLAG BIT(11)
#define BIT_CLR_P0HI13Q_HOST_IDX BIT(11)
#define BIT_PCIE_P0MPRT_BCNQ3_FLAG BIT(10)
#define BIT_CLR_P0HI12Q_HOST_IDX BIT(10)
#define BIT_PCIE_P0MPRT_BCNQ2_FLAG BIT(9)
#define BIT_CLR_P0HI11Q_HOST_IDX BIT(9)
#define BIT_PCIE_P0MPRT_BCNQ1_FLAG BIT(8)
#define BIT_CLR_P0HI10Q_HOST_IDX BIT(8)
#define BIT_CLR_P0HI9Q_HOST_IDX BIT(7)
#define BIT_CLR_P0HI8Q_HOST_IDX BIT(6)
#define BIT_CLR_ACH7_HOST_IDX BIT(5)
#define BIT_CLR_ACH13_HOST_IDX BIT(5)
#define BIT_CLR_ACH6_HOST_IDX BIT(4)
#define BIT_CLR_ACH12_HOST_IDX BIT(4)
#define BIT_CLR_ACH5_HOST_IDX BIT(3)
#define BIT_CLR_ACH11_HOST_IDX BIT(3)
#define BIT_CLR_ACH4_HOST_IDX BIT(2)
#define BIT_CLR_ACH10_HOST_IDX BIT(2)
#define BIT_EPHY_CAL_DONE BIT(1)
#define BIT_CLR_ACH9_HOST_IDX BIT(1)
#define BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H 0
#define BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H 0xffffffffL
#define BIT_P0_MPRT_BCNQ_TXBD_DESA_H(x) \
(((x) & BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H) \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H)
#define BITS_P0_MPRT_BCNQ_TXBD_DESA_H \
(BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H)
#define BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_H(x) \
((x) & (~BITS_P0_MPRT_BCNQ_TXBD_DESA_H))
#define BIT_GET_P0_MPRT_BCNQ_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H) & \
BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H)
#define BIT_SET_P0_MPRT_BCNQ_TXBD_DESA_H(x, v) \
(BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_H(x) | \
BIT_P0_MPRT_BCNQ_TXBD_DESA_H(v))
#define BIT_RESET_APHY BIT(0)
#define BIT_CLR_ACH8_HOST_IDX BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI4Q_TXBD_DESA (Offset 0x0360) */
#define BIT_SHIFT_HI4Q_TXBD_DESA 0
#define BIT_MASK_HI4Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI4Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA) << BIT_SHIFT_HI4Q_TXBD_DESA)
#define BITS_HI4Q_TXBD_DESA \
(BIT_MASK_HI4Q_TXBD_DESA << BIT_SHIFT_HI4Q_TXBD_DESA)
#define BIT_CLEAR_HI4Q_TXBD_DESA(x) ((x) & (~BITS_HI4Q_TXBD_DESA))
#define BIT_GET_HI4Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA) & BIT_MASK_HI4Q_TXBD_DESA)
#define BIT_SET_HI4Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA(x) | BIT_HI4Q_TXBD_DESA(v))
/* 2 REG_HI5Q_TXBD_DESA (Offset 0x0368) */
#define BIT_SHIFT_HI5Q_TXBD_DESA 0
#define BIT_MASK_HI5Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI5Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA) << BIT_SHIFT_HI5Q_TXBD_DESA)
#define BITS_HI5Q_TXBD_DESA \
(BIT_MASK_HI5Q_TXBD_DESA << BIT_SHIFT_HI5Q_TXBD_DESA)
#define BIT_CLEAR_HI5Q_TXBD_DESA(x) ((x) & (~BITS_HI5Q_TXBD_DESA))
#define BIT_GET_HI5Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA) & BIT_MASK_HI5Q_TXBD_DESA)
#define BIT_SET_HI5Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA(x) | BIT_HI5Q_TXBD_DESA(v))
/* 2 REG_HI6Q_TXBD_DESA (Offset 0x0370) */
#define BIT_SHIFT_HI6Q_TXBD_DESA 0
#define BIT_MASK_HI6Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI6Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA) << BIT_SHIFT_HI6Q_TXBD_DESA)
#define BITS_HI6Q_TXBD_DESA \
(BIT_MASK_HI6Q_TXBD_DESA << BIT_SHIFT_HI6Q_TXBD_DESA)
#define BIT_CLEAR_HI6Q_TXBD_DESA(x) ((x) & (~BITS_HI6Q_TXBD_DESA))
#define BIT_GET_HI6Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA) & BIT_MASK_HI6Q_TXBD_DESA)
#define BIT_SET_HI6Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA(x) | BIT_HI6Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0MGQ_RXQ_TXRXBD_NUM (Offset 0x0378) */
#define BIT_SYS_32_64_V1 BIT(31)
#define BIT_SHIFT_P0BCNQ_DESC_MODE 29
#define BIT_MASK_P0BCNQ_DESC_MODE 0x3
#define BIT_P0BCNQ_DESC_MODE(x) \
(((x) & BIT_MASK_P0BCNQ_DESC_MODE) << BIT_SHIFT_P0BCNQ_DESC_MODE)
#define BITS_P0BCNQ_DESC_MODE \
(BIT_MASK_P0BCNQ_DESC_MODE << BIT_SHIFT_P0BCNQ_DESC_MODE)
#define BIT_CLEAR_P0BCNQ_DESC_MODE(x) ((x) & (~BITS_P0BCNQ_DESC_MODE))
#define BIT_GET_P0BCNQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0BCNQ_DESC_MODE) & BIT_MASK_P0BCNQ_DESC_MODE)
#define BIT_SET_P0BCNQ_DESC_MODE(x, v) \
(BIT_CLEAR_P0BCNQ_DESC_MODE(x) | BIT_P0BCNQ_DESC_MODE(v))
#define BIT_PCIE_P0BCNQ_FLAG BIT(28)
#define BIT_SHIFT_P0RXQ_DESC_NUM 16
#define BIT_MASK_P0RXQ_DESC_NUM 0xfff
#define BIT_P0RXQ_DESC_NUM(x) \
(((x) & BIT_MASK_P0RXQ_DESC_NUM) << BIT_SHIFT_P0RXQ_DESC_NUM)
#define BITS_P0RXQ_DESC_NUM \
(BIT_MASK_P0RXQ_DESC_NUM << BIT_SHIFT_P0RXQ_DESC_NUM)
#define BIT_CLEAR_P0RXQ_DESC_NUM(x) ((x) & (~BITS_P0RXQ_DESC_NUM))
#define BIT_GET_P0RXQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0RXQ_DESC_NUM) & BIT_MASK_P0RXQ_DESC_NUM)
#define BIT_SET_P0RXQ_DESC_NUM(x, v) \
(BIT_CLEAR_P0RXQ_DESC_NUM(x) | BIT_P0RXQ_DESC_NUM(v))
#define BIT_PCIE_P0MGQ_FLAG BIT(14)
#define BIT_SHIFT_P0MGQ_DESC_MODE 12
#define BIT_MASK_P0MGQ_DESC_MODE 0x3
#define BIT_P0MGQ_DESC_MODE(x) \
(((x) & BIT_MASK_P0MGQ_DESC_MODE) << BIT_SHIFT_P0MGQ_DESC_MODE)
#define BITS_P0MGQ_DESC_MODE \
(BIT_MASK_P0MGQ_DESC_MODE << BIT_SHIFT_P0MGQ_DESC_MODE)
#define BIT_CLEAR_P0MGQ_DESC_MODE(x) ((x) & (~BITS_P0MGQ_DESC_MODE))
#define BIT_GET_P0MGQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0MGQ_DESC_MODE) & BIT_MASK_P0MGQ_DESC_MODE)
#define BIT_SET_P0MGQ_DESC_MODE(x, v) \
(BIT_CLEAR_P0MGQ_DESC_MODE(x) | BIT_P0MGQ_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI7Q_TXBD_DESA (Offset 0x0378) */
#define BIT_SHIFT_HI7Q_TXBD_DESA 0
#define BIT_MASK_HI7Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI7Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA) << BIT_SHIFT_HI7Q_TXBD_DESA)
#define BITS_HI7Q_TXBD_DESA \
(BIT_MASK_HI7Q_TXBD_DESA << BIT_SHIFT_HI7Q_TXBD_DESA)
#define BIT_CLEAR_HI7Q_TXBD_DESA(x) ((x) & (~BITS_HI7Q_TXBD_DESA))
#define BIT_GET_HI7Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA) & BIT_MASK_HI7Q_TXBD_DESA)
#define BIT_SET_HI7Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA(x) | BIT_HI7Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0MGQ_RXQ_TXRXBD_NUM (Offset 0x0378) */
#define BIT_SHIFT_P0MGQ_DESC_NUM 0
#define BIT_MASK_P0MGQ_DESC_NUM 0xfff
#define BIT_P0MGQ_DESC_NUM(x) \
(((x) & BIT_MASK_P0MGQ_DESC_NUM) << BIT_SHIFT_P0MGQ_DESC_NUM)
#define BITS_P0MGQ_DESC_NUM \
(BIT_MASK_P0MGQ_DESC_NUM << BIT_SHIFT_P0MGQ_DESC_NUM)
#define BIT_CLEAR_P0MGQ_DESC_NUM(x) ((x) & (~BITS_P0MGQ_DESC_NUM))
#define BIT_GET_P0MGQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0MGQ_DESC_NUM) & BIT_MASK_P0MGQ_DESC_NUM)
#define BIT_SET_P0MGQ_DESC_NUM(x, v) \
(BIT_CLEAR_P0MGQ_DESC_NUM(x) | BIT_P0MGQ_DESC_NUM(v))
/* 2 REG_CHNL_DMA_CFG (Offset 0x037C) */
#define BIT_TXHCI_EN BIT(26)
#define BIT_TXHCI_IDLE BIT(25)
#define BIT_DMA_PRI_EN BIT(24)
#define BIT_PCIE_FWCMDQ_FLAG BIT(14)
#define BIT_SHIFT_FWCMDQ_DESC_MODE 12
#define BIT_MASK_FWCMDQ_DESC_MODE 0x3
#define BIT_FWCMDQ_DESC_MODE(x) \
(((x) & BIT_MASK_FWCMDQ_DESC_MODE) << BIT_SHIFT_FWCMDQ_DESC_MODE)
#define BITS_FWCMDQ_DESC_MODE \
(BIT_MASK_FWCMDQ_DESC_MODE << BIT_SHIFT_FWCMDQ_DESC_MODE)
#define BIT_CLEAR_FWCMDQ_DESC_MODE(x) ((x) & (~BITS_FWCMDQ_DESC_MODE))
#define BIT_GET_FWCMDQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_FWCMDQ_DESC_MODE) & BIT_MASK_FWCMDQ_DESC_MODE)
#define BIT_SET_FWCMDQ_DESC_MODE(x, v) \
(BIT_CLEAR_FWCMDQ_DESC_MODE(x) | BIT_FWCMDQ_DESC_MODE(v))
#define BIT_SHIFT_FWCMDQ_DESC_NUM 0
#define BIT_MASK_FWCMDQ_DESC_NUM 0xfff
#define BIT_FWCMDQ_DESC_NUM(x) \
(((x) & BIT_MASK_FWCMDQ_DESC_NUM) << BIT_SHIFT_FWCMDQ_DESC_NUM)
#define BITS_FWCMDQ_DESC_NUM \
(BIT_MASK_FWCMDQ_DESC_NUM << BIT_SHIFT_FWCMDQ_DESC_NUM)
#define BIT_CLEAR_FWCMDQ_DESC_NUM(x) ((x) & (~BITS_FWCMDQ_DESC_NUM))
#define BIT_GET_FWCMDQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_FWCMDQ_DESC_NUM) & BIT_MASK_FWCMDQ_DESC_NUM)
#define BIT_SET_FWCMDQ_DESC_NUM(x, v) \
(BIT_CLEAR_FWCMDQ_DESC_NUM(x) | BIT_FWCMDQ_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_TXBD_NUM (Offset 0x0380) */
#define BIT_PCIE_MGQ_FLAG BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MGQ_TXBD_NUM (Offset 0x0380) */
#define BIT_HCI_MGQ_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_TXBD_NUM (Offset 0x0380) */
#define BIT_SHIFT_MGQ_DESC_MODE 12
#define BIT_MASK_MGQ_DESC_MODE 0x3
#define BIT_MGQ_DESC_MODE(x) \
(((x) & BIT_MASK_MGQ_DESC_MODE) << BIT_SHIFT_MGQ_DESC_MODE)
#define BITS_MGQ_DESC_MODE (BIT_MASK_MGQ_DESC_MODE << BIT_SHIFT_MGQ_DESC_MODE)
#define BIT_CLEAR_MGQ_DESC_MODE(x) ((x) & (~BITS_MGQ_DESC_MODE))
#define BIT_GET_MGQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_MODE) & BIT_MASK_MGQ_DESC_MODE)
#define BIT_SET_MGQ_DESC_MODE(x, v) \
(BIT_CLEAR_MGQ_DESC_MODE(x) | BIT_MGQ_DESC_MODE(v))
#define BIT_SHIFT_MGQ_DESC_NUM 0
#define BIT_MASK_MGQ_DESC_NUM 0xfff
#define BIT_MGQ_DESC_NUM(x) \
(((x) & BIT_MASK_MGQ_DESC_NUM) << BIT_SHIFT_MGQ_DESC_NUM)
#define BITS_MGQ_DESC_NUM (BIT_MASK_MGQ_DESC_NUM << BIT_SHIFT_MGQ_DESC_NUM)
#define BIT_CLEAR_MGQ_DESC_NUM(x) ((x) & (~BITS_MGQ_DESC_NUM))
#define BIT_GET_MGQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_NUM) & BIT_MASK_MGQ_DESC_NUM)
#define BIT_SET_MGQ_DESC_NUM(x, v) \
(BIT_CLEAR_MGQ_DESC_NUM(x) | BIT_MGQ_DESC_NUM(v))
/* 2 REG_RX_RXBD_NUM (Offset 0x0382) */
#define BIT_SYS_32_64 BIT(15)
#define BIT_SHIFT_BCNQ_DESC_MODE 13
#define BIT_MASK_BCNQ_DESC_MODE 0x3
#define BIT_BCNQ_DESC_MODE(x) \
(((x) & BIT_MASK_BCNQ_DESC_MODE) << BIT_SHIFT_BCNQ_DESC_MODE)
#define BITS_BCNQ_DESC_MODE \
(BIT_MASK_BCNQ_DESC_MODE << BIT_SHIFT_BCNQ_DESC_MODE)
#define BIT_CLEAR_BCNQ_DESC_MODE(x) ((x) & (~BITS_BCNQ_DESC_MODE))
#define BIT_GET_BCNQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_BCNQ_DESC_MODE) & BIT_MASK_BCNQ_DESC_MODE)
#define BIT_SET_BCNQ_DESC_MODE(x, v) \
(BIT_CLEAR_BCNQ_DESC_MODE(x) | BIT_BCNQ_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RX_RXBD_NUM (Offset 0x0382) */
#define BIT_PCIE_BCNQ_FLAG BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RX_RXBD_NUM (Offset 0x0382) */
#define BIT_HCI_BCNQ_FLAG BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RX_RXBD_NUM (Offset 0x0382) */
#define BIT_SHIFT_RXQ_DESC_NUM 0
#define BIT_MASK_RXQ_DESC_NUM 0xfff
#define BIT_RXQ_DESC_NUM(x) \
(((x) & BIT_MASK_RXQ_DESC_NUM) << BIT_SHIFT_RXQ_DESC_NUM)
#define BITS_RXQ_DESC_NUM (BIT_MASK_RXQ_DESC_NUM << BIT_SHIFT_RXQ_DESC_NUM)
#define BIT_CLEAR_RXQ_DESC_NUM(x) ((x) & (~BITS_RXQ_DESC_NUM))
#define BIT_GET_RXQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_RXQ_DESC_NUM) & BIT_MASK_RXQ_DESC_NUM)
#define BIT_SET_RXQ_DESC_NUM(x, v) \
(BIT_CLEAR_RXQ_DESC_NUM(x) | BIT_RXQ_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_ACH1_TXBD_NUM (Offset 0x0384) */
#define BIT_PCIE_ACH1_FLAG_V1 BIT(30)
#define BIT_SHIFT_ACH1_DESC_MODE_V1 28
#define BIT_MASK_ACH1_DESC_MODE_V1 0x3
#define BIT_ACH1_DESC_MODE_V1(x) \
(((x) & BIT_MASK_ACH1_DESC_MODE_V1) << BIT_SHIFT_ACH1_DESC_MODE_V1)
#define BITS_ACH1_DESC_MODE_V1 \
(BIT_MASK_ACH1_DESC_MODE_V1 << BIT_SHIFT_ACH1_DESC_MODE_V1)
#define BIT_CLEAR_ACH1_DESC_MODE_V1(x) ((x) & (~BITS_ACH1_DESC_MODE_V1))
#define BIT_GET_ACH1_DESC_MODE_V1(x) \
(((x) >> BIT_SHIFT_ACH1_DESC_MODE_V1) & BIT_MASK_ACH1_DESC_MODE_V1)
#define BIT_SET_ACH1_DESC_MODE_V1(x, v) \
(BIT_CLEAR_ACH1_DESC_MODE_V1(x) | BIT_ACH1_DESC_MODE_V1(v))
#define BIT_SHIFT_ACH1_DESC_NUM_V1 16
#define BIT_MASK_ACH1_DESC_NUM_V1 0xfff
#define BIT_ACH1_DESC_NUM_V1(x) \
(((x) & BIT_MASK_ACH1_DESC_NUM_V1) << BIT_SHIFT_ACH1_DESC_NUM_V1)
#define BITS_ACH1_DESC_NUM_V1 \
(BIT_MASK_ACH1_DESC_NUM_V1 << BIT_SHIFT_ACH1_DESC_NUM_V1)
#define BIT_CLEAR_ACH1_DESC_NUM_V1(x) ((x) & (~BITS_ACH1_DESC_NUM_V1))
#define BIT_GET_ACH1_DESC_NUM_V1(x) \
(((x) >> BIT_SHIFT_ACH1_DESC_NUM_V1) & BIT_MASK_ACH1_DESC_NUM_V1)
#define BIT_SET_ACH1_DESC_NUM_V1(x, v) \
(BIT_CLEAR_ACH1_DESC_NUM_V1(x) | BIT_ACH1_DESC_NUM_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VOQ_TXBD_NUM (Offset 0x0384) */
#define BIT_PCIE_VOQ_FLAG BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_VOQ_TXBD_NUM (Offset 0x0384) */
#define BIT_HCI_VOQ_FLAG BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_ACH1_TXBD_NUM (Offset 0x0384) */
#define BIT_PCIE_ACH0_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VOQ_TXBD_NUM (Offset 0x0384) */
#define BIT_SHIFT_VOQ_DESC_MODE 12
#define BIT_MASK_VOQ_DESC_MODE 0x3
#define BIT_VOQ_DESC_MODE(x) \
(((x) & BIT_MASK_VOQ_DESC_MODE) << BIT_SHIFT_VOQ_DESC_MODE)
#define BITS_VOQ_DESC_MODE (BIT_MASK_VOQ_DESC_MODE << BIT_SHIFT_VOQ_DESC_MODE)
#define BIT_CLEAR_VOQ_DESC_MODE(x) ((x) & (~BITS_VOQ_DESC_MODE))
#define BIT_GET_VOQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_MODE) & BIT_MASK_VOQ_DESC_MODE)
#define BIT_SET_VOQ_DESC_MODE(x, v) \
(BIT_CLEAR_VOQ_DESC_MODE(x) | BIT_VOQ_DESC_MODE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_ACH1_TXBD_NUM (Offset 0x0384) */
#define BIT_SHIFT_ACH0_DESC_MODE 12
#define BIT_MASK_ACH0_DESC_MODE 0x3
#define BIT_ACH0_DESC_MODE(x) \
(((x) & BIT_MASK_ACH0_DESC_MODE) << BIT_SHIFT_ACH0_DESC_MODE)
#define BITS_ACH0_DESC_MODE \
(BIT_MASK_ACH0_DESC_MODE << BIT_SHIFT_ACH0_DESC_MODE)
#define BIT_CLEAR_ACH0_DESC_MODE(x) ((x) & (~BITS_ACH0_DESC_MODE))
#define BIT_GET_ACH0_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH0_DESC_MODE) & BIT_MASK_ACH0_DESC_MODE)
#define BIT_SET_ACH0_DESC_MODE(x, v) \
(BIT_CLEAR_ACH0_DESC_MODE(x) | BIT_ACH0_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VOQ_TXBD_NUM (Offset 0x0384) */
#define BIT_SHIFT_VOQ_DESC_NUM 0
#define BIT_MASK_VOQ_DESC_NUM 0xfff
#define BIT_VOQ_DESC_NUM(x) \
(((x) & BIT_MASK_VOQ_DESC_NUM) << BIT_SHIFT_VOQ_DESC_NUM)
#define BITS_VOQ_DESC_NUM (BIT_MASK_VOQ_DESC_NUM << BIT_SHIFT_VOQ_DESC_NUM)
#define BIT_CLEAR_VOQ_DESC_NUM(x) ((x) & (~BITS_VOQ_DESC_NUM))
#define BIT_GET_VOQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_NUM) & BIT_MASK_VOQ_DESC_NUM)
#define BIT_SET_VOQ_DESC_NUM(x, v) \
(BIT_CLEAR_VOQ_DESC_NUM(x) | BIT_VOQ_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_ACH1_TXBD_NUM (Offset 0x0384) */
#define BIT_SHIFT_ACH0_DESC_NUM 0
#define BIT_MASK_ACH0_DESC_NUM 0xfff
#define BIT_ACH0_DESC_NUM(x) \
(((x) & BIT_MASK_ACH0_DESC_NUM) << BIT_SHIFT_ACH0_DESC_NUM)
#define BITS_ACH0_DESC_NUM (BIT_MASK_ACH0_DESC_NUM << BIT_SHIFT_ACH0_DESC_NUM)
#define BIT_CLEAR_ACH0_DESC_NUM(x) ((x) & (~BITS_ACH0_DESC_NUM))
#define BIT_GET_ACH0_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH0_DESC_NUM) & BIT_MASK_ACH0_DESC_NUM)
#define BIT_SET_ACH0_DESC_NUM(x, v) \
(BIT_CLEAR_ACH0_DESC_NUM(x) | BIT_ACH0_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VIQ_TXBD_NUM (Offset 0x0386) */
#define BIT_PCIE_VIQ_FLAG BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_VIQ_TXBD_NUM (Offset 0x0386) */
#define BIT_HCI_VIQ_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VIQ_TXBD_NUM (Offset 0x0386) */
#define BIT_SHIFT_VIQ_DESC_MODE 12
#define BIT_MASK_VIQ_DESC_MODE 0x3
#define BIT_VIQ_DESC_MODE(x) \
(((x) & BIT_MASK_VIQ_DESC_MODE) << BIT_SHIFT_VIQ_DESC_MODE)
#define BITS_VIQ_DESC_MODE (BIT_MASK_VIQ_DESC_MODE << BIT_SHIFT_VIQ_DESC_MODE)
#define BIT_CLEAR_VIQ_DESC_MODE(x) ((x) & (~BITS_VIQ_DESC_MODE))
#define BIT_GET_VIQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_MODE) & BIT_MASK_VIQ_DESC_MODE)
#define BIT_SET_VIQ_DESC_MODE(x, v) \
(BIT_CLEAR_VIQ_DESC_MODE(x) | BIT_VIQ_DESC_MODE(v))
#define BIT_SHIFT_VIQ_DESC_NUM 0
#define BIT_MASK_VIQ_DESC_NUM 0xfff
#define BIT_VIQ_DESC_NUM(x) \
(((x) & BIT_MASK_VIQ_DESC_NUM) << BIT_SHIFT_VIQ_DESC_NUM)
#define BITS_VIQ_DESC_NUM (BIT_MASK_VIQ_DESC_NUM << BIT_SHIFT_VIQ_DESC_NUM)
#define BIT_CLEAR_VIQ_DESC_NUM(x) ((x) & (~BITS_VIQ_DESC_NUM))
#define BIT_GET_VIQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_NUM) & BIT_MASK_VIQ_DESC_NUM)
#define BIT_SET_VIQ_DESC_NUM(x, v) \
(BIT_CLEAR_VIQ_DESC_NUM(x) | BIT_VIQ_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_ACH3_TXBD_NUM (Offset 0x0388) */
#define BIT_PCIE_ACH3_FLAG_V1 BIT(30)
#define BIT_SHIFT_ACH3_DESC_MODE_V1 28
#define BIT_MASK_ACH3_DESC_MODE_V1 0x3
#define BIT_ACH3_DESC_MODE_V1(x) \
(((x) & BIT_MASK_ACH3_DESC_MODE_V1) << BIT_SHIFT_ACH3_DESC_MODE_V1)
#define BITS_ACH3_DESC_MODE_V1 \
(BIT_MASK_ACH3_DESC_MODE_V1 << BIT_SHIFT_ACH3_DESC_MODE_V1)
#define BIT_CLEAR_ACH3_DESC_MODE_V1(x) ((x) & (~BITS_ACH3_DESC_MODE_V1))
#define BIT_GET_ACH3_DESC_MODE_V1(x) \
(((x) >> BIT_SHIFT_ACH3_DESC_MODE_V1) & BIT_MASK_ACH3_DESC_MODE_V1)
#define BIT_SET_ACH3_DESC_MODE_V1(x, v) \
(BIT_CLEAR_ACH3_DESC_MODE_V1(x) | BIT_ACH3_DESC_MODE_V1(v))
#define BIT_SHIFT_ACH3_DESC_NUM_V1 16
#define BIT_MASK_ACH3_DESC_NUM_V1 0xfff
#define BIT_ACH3_DESC_NUM_V1(x) \
(((x) & BIT_MASK_ACH3_DESC_NUM_V1) << BIT_SHIFT_ACH3_DESC_NUM_V1)
#define BITS_ACH3_DESC_NUM_V1 \
(BIT_MASK_ACH3_DESC_NUM_V1 << BIT_SHIFT_ACH3_DESC_NUM_V1)
#define BIT_CLEAR_ACH3_DESC_NUM_V1(x) ((x) & (~BITS_ACH3_DESC_NUM_V1))
#define BIT_GET_ACH3_DESC_NUM_V1(x) \
(((x) >> BIT_SHIFT_ACH3_DESC_NUM_V1) & BIT_MASK_ACH3_DESC_NUM_V1)
#define BIT_SET_ACH3_DESC_NUM_V1(x, v) \
(BIT_CLEAR_ACH3_DESC_NUM_V1(x) | BIT_ACH3_DESC_NUM_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BEQ_TXBD_NUM (Offset 0x0388) */
#define BIT_PCIE_BEQ_FLAG BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BEQ_TXBD_NUM (Offset 0x0388) */
#define BIT_HCI_BEQ_FLAG BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_ACH3_TXBD_NUM (Offset 0x0388) */
#define BIT_PCIE_ACH2_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BEQ_TXBD_NUM (Offset 0x0388) */
#define BIT_SHIFT_BEQ_DESC_MODE 12
#define BIT_MASK_BEQ_DESC_MODE 0x3
#define BIT_BEQ_DESC_MODE(x) \
(((x) & BIT_MASK_BEQ_DESC_MODE) << BIT_SHIFT_BEQ_DESC_MODE)
#define BITS_BEQ_DESC_MODE (BIT_MASK_BEQ_DESC_MODE << BIT_SHIFT_BEQ_DESC_MODE)
#define BIT_CLEAR_BEQ_DESC_MODE(x) ((x) & (~BITS_BEQ_DESC_MODE))
#define BIT_GET_BEQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_MODE) & BIT_MASK_BEQ_DESC_MODE)
#define BIT_SET_BEQ_DESC_MODE(x, v) \
(BIT_CLEAR_BEQ_DESC_MODE(x) | BIT_BEQ_DESC_MODE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_ACH3_TXBD_NUM (Offset 0x0388) */
#define BIT_SHIFT_ACH2_DESC_MODE 12
#define BIT_MASK_ACH2_DESC_MODE 0x3
#define BIT_ACH2_DESC_MODE(x) \
(((x) & BIT_MASK_ACH2_DESC_MODE) << BIT_SHIFT_ACH2_DESC_MODE)
#define BITS_ACH2_DESC_MODE \
(BIT_MASK_ACH2_DESC_MODE << BIT_SHIFT_ACH2_DESC_MODE)
#define BIT_CLEAR_ACH2_DESC_MODE(x) ((x) & (~BITS_ACH2_DESC_MODE))
#define BIT_GET_ACH2_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH2_DESC_MODE) & BIT_MASK_ACH2_DESC_MODE)
#define BIT_SET_ACH2_DESC_MODE(x, v) \
(BIT_CLEAR_ACH2_DESC_MODE(x) | BIT_ACH2_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BEQ_TXBD_NUM (Offset 0x0388) */
#define BIT_SHIFT_BEQ_DESC_NUM 0
#define BIT_MASK_BEQ_DESC_NUM 0xfff
#define BIT_BEQ_DESC_NUM(x) \
(((x) & BIT_MASK_BEQ_DESC_NUM) << BIT_SHIFT_BEQ_DESC_NUM)
#define BITS_BEQ_DESC_NUM (BIT_MASK_BEQ_DESC_NUM << BIT_SHIFT_BEQ_DESC_NUM)
#define BIT_CLEAR_BEQ_DESC_NUM(x) ((x) & (~BITS_BEQ_DESC_NUM))
#define BIT_GET_BEQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_NUM) & BIT_MASK_BEQ_DESC_NUM)
#define BIT_SET_BEQ_DESC_NUM(x, v) \
(BIT_CLEAR_BEQ_DESC_NUM(x) | BIT_BEQ_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_ACH3_TXBD_NUM (Offset 0x0388) */
#define BIT_SHIFT_ACH2_DESC_NUM 0
#define BIT_MASK_ACH2_DESC_NUM 0xfff
#define BIT_ACH2_DESC_NUM(x) \
(((x) & BIT_MASK_ACH2_DESC_NUM) << BIT_SHIFT_ACH2_DESC_NUM)
#define BITS_ACH2_DESC_NUM (BIT_MASK_ACH2_DESC_NUM << BIT_SHIFT_ACH2_DESC_NUM)
#define BIT_CLEAR_ACH2_DESC_NUM(x) ((x) & (~BITS_ACH2_DESC_NUM))
#define BIT_GET_ACH2_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH2_DESC_NUM) & BIT_MASK_ACH2_DESC_NUM)
#define BIT_SET_ACH2_DESC_NUM(x, v) \
(BIT_CLEAR_ACH2_DESC_NUM(x) | BIT_ACH2_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BKQ_TXBD_NUM (Offset 0x038A) */
#define BIT_PCIE_BKQ_FLAG BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BKQ_TXBD_NUM (Offset 0x038A) */
#define BIT_HCI_BKQ_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BKQ_TXBD_NUM (Offset 0x038A) */
#define BIT_SHIFT_BKQ_DESC_MODE 12
#define BIT_MASK_BKQ_DESC_MODE 0x3
#define BIT_BKQ_DESC_MODE(x) \
(((x) & BIT_MASK_BKQ_DESC_MODE) << BIT_SHIFT_BKQ_DESC_MODE)
#define BITS_BKQ_DESC_MODE (BIT_MASK_BKQ_DESC_MODE << BIT_SHIFT_BKQ_DESC_MODE)
#define BIT_CLEAR_BKQ_DESC_MODE(x) ((x) & (~BITS_BKQ_DESC_MODE))
#define BIT_GET_BKQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_MODE) & BIT_MASK_BKQ_DESC_MODE)
#define BIT_SET_BKQ_DESC_MODE(x, v) \
(BIT_CLEAR_BKQ_DESC_MODE(x) | BIT_BKQ_DESC_MODE(v))
#define BIT_SHIFT_BKQ_DESC_NUM 0
#define BIT_MASK_BKQ_DESC_NUM 0xfff
#define BIT_BKQ_DESC_NUM(x) \
(((x) & BIT_MASK_BKQ_DESC_NUM) << BIT_SHIFT_BKQ_DESC_NUM)
#define BITS_BKQ_DESC_NUM (BIT_MASK_BKQ_DESC_NUM << BIT_SHIFT_BKQ_DESC_NUM)
#define BIT_CLEAR_BKQ_DESC_NUM(x) ((x) & (~BITS_BKQ_DESC_NUM))
#define BIT_GET_BKQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_NUM) & BIT_MASK_BKQ_DESC_NUM)
#define BIT_SET_BKQ_DESC_NUM(x, v) \
(BIT_CLEAR_BKQ_DESC_NUM(x) | BIT_BKQ_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI0Q_HI1Q_TXBD_NUM (Offset 0x038C) */
#define BIT_P0HI1Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI1Q_DESC_MODE 28
#define BIT_MASK_P0HI1Q_DESC_MODE 0x3
#define BIT_P0HI1Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI1Q_DESC_MODE) << BIT_SHIFT_P0HI1Q_DESC_MODE)
#define BITS_P0HI1Q_DESC_MODE \
(BIT_MASK_P0HI1Q_DESC_MODE << BIT_SHIFT_P0HI1Q_DESC_MODE)
#define BIT_CLEAR_P0HI1Q_DESC_MODE(x) ((x) & (~BITS_P0HI1Q_DESC_MODE))
#define BIT_GET_P0HI1Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI1Q_DESC_MODE) & BIT_MASK_P0HI1Q_DESC_MODE)
#define BIT_SET_P0HI1Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI1Q_DESC_MODE(x) | BIT_P0HI1Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI1Q_DESC_NUM 16
#define BIT_MASK_P0HI1Q_DESC_NUM 0xfff
#define BIT_P0HI1Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI1Q_DESC_NUM) << BIT_SHIFT_P0HI1Q_DESC_NUM)
#define BITS_P0HI1Q_DESC_NUM \
(BIT_MASK_P0HI1Q_DESC_NUM << BIT_SHIFT_P0HI1Q_DESC_NUM)
#define BIT_CLEAR_P0HI1Q_DESC_NUM(x) ((x) & (~BITS_P0HI1Q_DESC_NUM))
#define BIT_GET_P0HI1Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI1Q_DESC_NUM) & BIT_MASK_P0HI1Q_DESC_NUM)
#define BIT_SET_P0HI1Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI1Q_DESC_NUM(x) | BIT_P0HI1Q_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI0Q_TXBD_NUM (Offset 0x038C) */
#define BIT_HI0Q_FLAG BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI0Q_HI1Q_TXBD_NUM (Offset 0x038C) */
#define BIT_P0HI0Q_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI0Q_TXBD_NUM (Offset 0x038C) */
#define BIT_SHIFT_HI0Q_DESC_MODE 12
#define BIT_MASK_HI0Q_DESC_MODE 0x3
#define BIT_HI0Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI0Q_DESC_MODE) << BIT_SHIFT_HI0Q_DESC_MODE)
#define BITS_HI0Q_DESC_MODE \
(BIT_MASK_HI0Q_DESC_MODE << BIT_SHIFT_HI0Q_DESC_MODE)
#define BIT_CLEAR_HI0Q_DESC_MODE(x) ((x) & (~BITS_HI0Q_DESC_MODE))
#define BIT_GET_HI0Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_MODE) & BIT_MASK_HI0Q_DESC_MODE)
#define BIT_SET_HI0Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI0Q_DESC_MODE(x) | BIT_HI0Q_DESC_MODE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI0Q_HI1Q_TXBD_NUM (Offset 0x038C) */
#define BIT_SHIFT_P0HI0Q_DESC_MODE 12
#define BIT_MASK_P0HI0Q_DESC_MODE 0x3
#define BIT_P0HI0Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI0Q_DESC_MODE) << BIT_SHIFT_P0HI0Q_DESC_MODE)
#define BITS_P0HI0Q_DESC_MODE \
(BIT_MASK_P0HI0Q_DESC_MODE << BIT_SHIFT_P0HI0Q_DESC_MODE)
#define BIT_CLEAR_P0HI0Q_DESC_MODE(x) ((x) & (~BITS_P0HI0Q_DESC_MODE))
#define BIT_GET_P0HI0Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI0Q_DESC_MODE) & BIT_MASK_P0HI0Q_DESC_MODE)
#define BIT_SET_P0HI0Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI0Q_DESC_MODE(x) | BIT_P0HI0Q_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI0Q_TXBD_NUM (Offset 0x038C) */
#define BIT_SHIFT_HI0Q_DESC_NUM 0
#define BIT_MASK_HI0Q_DESC_NUM 0xfff
#define BIT_HI0Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI0Q_DESC_NUM) << BIT_SHIFT_HI0Q_DESC_NUM)
#define BITS_HI0Q_DESC_NUM (BIT_MASK_HI0Q_DESC_NUM << BIT_SHIFT_HI0Q_DESC_NUM)
#define BIT_CLEAR_HI0Q_DESC_NUM(x) ((x) & (~BITS_HI0Q_DESC_NUM))
#define BIT_GET_HI0Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_NUM) & BIT_MASK_HI0Q_DESC_NUM)
#define BIT_SET_HI0Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI0Q_DESC_NUM(x) | BIT_HI0Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI0Q_HI1Q_TXBD_NUM (Offset 0x038C) */
#define BIT_SHIFT_P0HI0Q_DESC_NUM 0
#define BIT_MASK_P0HI0Q_DESC_NUM 0xfff
#define BIT_P0HI0Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI0Q_DESC_NUM) << BIT_SHIFT_P0HI0Q_DESC_NUM)
#define BITS_P0HI0Q_DESC_NUM \
(BIT_MASK_P0HI0Q_DESC_NUM << BIT_SHIFT_P0HI0Q_DESC_NUM)
#define BIT_CLEAR_P0HI0Q_DESC_NUM(x) ((x) & (~BITS_P0HI0Q_DESC_NUM))
#define BIT_GET_P0HI0Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI0Q_DESC_NUM) & BIT_MASK_P0HI0Q_DESC_NUM)
#define BIT_SET_P0HI0Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI0Q_DESC_NUM(x) | BIT_P0HI0Q_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI1Q_TXBD_NUM (Offset 0x038E) */
#define BIT_HI1Q_FLAG BIT(14)
#define BIT_SHIFT_HI1Q_DESC_MODE 12
#define BIT_MASK_HI1Q_DESC_MODE 0x3
#define BIT_HI1Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI1Q_DESC_MODE) << BIT_SHIFT_HI1Q_DESC_MODE)
#define BITS_HI1Q_DESC_MODE \
(BIT_MASK_HI1Q_DESC_MODE << BIT_SHIFT_HI1Q_DESC_MODE)
#define BIT_CLEAR_HI1Q_DESC_MODE(x) ((x) & (~BITS_HI1Q_DESC_MODE))
#define BIT_GET_HI1Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_MODE) & BIT_MASK_HI1Q_DESC_MODE)
#define BIT_SET_HI1Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI1Q_DESC_MODE(x) | BIT_HI1Q_DESC_MODE(v))
#define BIT_SHIFT_HI1Q_DESC_NUM 0
#define BIT_MASK_HI1Q_DESC_NUM 0xfff
#define BIT_HI1Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI1Q_DESC_NUM) << BIT_SHIFT_HI1Q_DESC_NUM)
#define BITS_HI1Q_DESC_NUM (BIT_MASK_HI1Q_DESC_NUM << BIT_SHIFT_HI1Q_DESC_NUM)
#define BIT_CLEAR_HI1Q_DESC_NUM(x) ((x) & (~BITS_HI1Q_DESC_NUM))
#define BIT_GET_HI1Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_NUM) & BIT_MASK_HI1Q_DESC_NUM)
#define BIT_SET_HI1Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI1Q_DESC_NUM(x) | BIT_HI1Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI2Q_HI3Q_TXBD_NUM (Offset 0x0390) */
#define BIT_P0HI3Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI3Q_DESC_MODE 28
#define BIT_MASK_P0HI3Q_DESC_MODE 0x3
#define BIT_P0HI3Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI3Q_DESC_MODE) << BIT_SHIFT_P0HI3Q_DESC_MODE)
#define BITS_P0HI3Q_DESC_MODE \
(BIT_MASK_P0HI3Q_DESC_MODE << BIT_SHIFT_P0HI3Q_DESC_MODE)
#define BIT_CLEAR_P0HI3Q_DESC_MODE(x) ((x) & (~BITS_P0HI3Q_DESC_MODE))
#define BIT_GET_P0HI3Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI3Q_DESC_MODE) & BIT_MASK_P0HI3Q_DESC_MODE)
#define BIT_SET_P0HI3Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI3Q_DESC_MODE(x) | BIT_P0HI3Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI3Q_DESC_NUM 16
#define BIT_MASK_P0HI3Q_DESC_NUM 0xfff
#define BIT_P0HI3Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI3Q_DESC_NUM) << BIT_SHIFT_P0HI3Q_DESC_NUM)
#define BITS_P0HI3Q_DESC_NUM \
(BIT_MASK_P0HI3Q_DESC_NUM << BIT_SHIFT_P0HI3Q_DESC_NUM)
#define BIT_CLEAR_P0HI3Q_DESC_NUM(x) ((x) & (~BITS_P0HI3Q_DESC_NUM))
#define BIT_GET_P0HI3Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI3Q_DESC_NUM) & BIT_MASK_P0HI3Q_DESC_NUM)
#define BIT_SET_P0HI3Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI3Q_DESC_NUM(x) | BIT_P0HI3Q_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI2Q_TXBD_NUM (Offset 0x0390) */
#define BIT_HI2Q_FLAG BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI2Q_HI3Q_TXBD_NUM (Offset 0x0390) */
#define BIT_P0HI2Q_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI2Q_TXBD_NUM (Offset 0x0390) */
#define BIT_SHIFT_HI2Q_DESC_MODE 12
#define BIT_MASK_HI2Q_DESC_MODE 0x3
#define BIT_HI2Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI2Q_DESC_MODE) << BIT_SHIFT_HI2Q_DESC_MODE)
#define BITS_HI2Q_DESC_MODE \
(BIT_MASK_HI2Q_DESC_MODE << BIT_SHIFT_HI2Q_DESC_MODE)
#define BIT_CLEAR_HI2Q_DESC_MODE(x) ((x) & (~BITS_HI2Q_DESC_MODE))
#define BIT_GET_HI2Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_MODE) & BIT_MASK_HI2Q_DESC_MODE)
#define BIT_SET_HI2Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI2Q_DESC_MODE(x) | BIT_HI2Q_DESC_MODE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI2Q_HI3Q_TXBD_NUM (Offset 0x0390) */
#define BIT_SHIFT_P0HI2Q_DESC_MODE 12
#define BIT_MASK_P0HI2Q_DESC_MODE 0x3
#define BIT_P0HI2Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI2Q_DESC_MODE) << BIT_SHIFT_P0HI2Q_DESC_MODE)
#define BITS_P0HI2Q_DESC_MODE \
(BIT_MASK_P0HI2Q_DESC_MODE << BIT_SHIFT_P0HI2Q_DESC_MODE)
#define BIT_CLEAR_P0HI2Q_DESC_MODE(x) ((x) & (~BITS_P0HI2Q_DESC_MODE))
#define BIT_GET_P0HI2Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI2Q_DESC_MODE) & BIT_MASK_P0HI2Q_DESC_MODE)
#define BIT_SET_P0HI2Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI2Q_DESC_MODE(x) | BIT_P0HI2Q_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI2Q_TXBD_NUM (Offset 0x0390) */
#define BIT_SHIFT_HI2Q_DESC_NUM 0
#define BIT_MASK_HI2Q_DESC_NUM 0xfff
#define BIT_HI2Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI2Q_DESC_NUM) << BIT_SHIFT_HI2Q_DESC_NUM)
#define BITS_HI2Q_DESC_NUM (BIT_MASK_HI2Q_DESC_NUM << BIT_SHIFT_HI2Q_DESC_NUM)
#define BIT_CLEAR_HI2Q_DESC_NUM(x) ((x) & (~BITS_HI2Q_DESC_NUM))
#define BIT_GET_HI2Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_NUM) & BIT_MASK_HI2Q_DESC_NUM)
#define BIT_SET_HI2Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI2Q_DESC_NUM(x) | BIT_HI2Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI2Q_HI3Q_TXBD_NUM (Offset 0x0390) */
#define BIT_SHIFT_P0HI2Q_DESC_NUM 0
#define BIT_MASK_P0HI2Q_DESC_NUM 0xfff
#define BIT_P0HI2Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI2Q_DESC_NUM) << BIT_SHIFT_P0HI2Q_DESC_NUM)
#define BITS_P0HI2Q_DESC_NUM \
(BIT_MASK_P0HI2Q_DESC_NUM << BIT_SHIFT_P0HI2Q_DESC_NUM)
#define BIT_CLEAR_P0HI2Q_DESC_NUM(x) ((x) & (~BITS_P0HI2Q_DESC_NUM))
#define BIT_GET_P0HI2Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI2Q_DESC_NUM) & BIT_MASK_P0HI2Q_DESC_NUM)
#define BIT_SET_P0HI2Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI2Q_DESC_NUM(x) | BIT_P0HI2Q_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI3Q_TXBD_NUM (Offset 0x0392) */
#define BIT_HI3Q_FLAG BIT(14)
#define BIT_SHIFT_HI3Q_DESC_MODE 12
#define BIT_MASK_HI3Q_DESC_MODE 0x3
#define BIT_HI3Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI3Q_DESC_MODE) << BIT_SHIFT_HI3Q_DESC_MODE)
#define BITS_HI3Q_DESC_MODE \
(BIT_MASK_HI3Q_DESC_MODE << BIT_SHIFT_HI3Q_DESC_MODE)
#define BIT_CLEAR_HI3Q_DESC_MODE(x) ((x) & (~BITS_HI3Q_DESC_MODE))
#define BIT_GET_HI3Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_MODE) & BIT_MASK_HI3Q_DESC_MODE)
#define BIT_SET_HI3Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI3Q_DESC_MODE(x) | BIT_HI3Q_DESC_MODE(v))
#define BIT_SHIFT_HI3Q_DESC_NUM 0
#define BIT_MASK_HI3Q_DESC_NUM 0xfff
#define BIT_HI3Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI3Q_DESC_NUM) << BIT_SHIFT_HI3Q_DESC_NUM)
#define BITS_HI3Q_DESC_NUM (BIT_MASK_HI3Q_DESC_NUM << BIT_SHIFT_HI3Q_DESC_NUM)
#define BIT_CLEAR_HI3Q_DESC_NUM(x) ((x) & (~BITS_HI3Q_DESC_NUM))
#define BIT_GET_HI3Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_NUM) & BIT_MASK_HI3Q_DESC_NUM)
#define BIT_SET_HI3Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI3Q_DESC_NUM(x) | BIT_HI3Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI4Q_HI5Q_TXBD_NUM (Offset 0x0394) */
#define BIT_P0HI5Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI5Q_DESC_MODE 28
#define BIT_MASK_P0HI5Q_DESC_MODE 0x3
#define BIT_P0HI5Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI5Q_DESC_MODE) << BIT_SHIFT_P0HI5Q_DESC_MODE)
#define BITS_P0HI5Q_DESC_MODE \
(BIT_MASK_P0HI5Q_DESC_MODE << BIT_SHIFT_P0HI5Q_DESC_MODE)
#define BIT_CLEAR_P0HI5Q_DESC_MODE(x) ((x) & (~BITS_P0HI5Q_DESC_MODE))
#define BIT_GET_P0HI5Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI5Q_DESC_MODE) & BIT_MASK_P0HI5Q_DESC_MODE)
#define BIT_SET_P0HI5Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI5Q_DESC_MODE(x) | BIT_P0HI5Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI5Q_DESC_NUM 16
#define BIT_MASK_P0HI5Q_DESC_NUM 0xfff
#define BIT_P0HI5Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI5Q_DESC_NUM) << BIT_SHIFT_P0HI5Q_DESC_NUM)
#define BITS_P0HI5Q_DESC_NUM \
(BIT_MASK_P0HI5Q_DESC_NUM << BIT_SHIFT_P0HI5Q_DESC_NUM)
#define BIT_CLEAR_P0HI5Q_DESC_NUM(x) ((x) & (~BITS_P0HI5Q_DESC_NUM))
#define BIT_GET_P0HI5Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI5Q_DESC_NUM) & BIT_MASK_P0HI5Q_DESC_NUM)
#define BIT_SET_P0HI5Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI5Q_DESC_NUM(x) | BIT_P0HI5Q_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI4Q_TXBD_NUM (Offset 0x0394) */
#define BIT_HI4Q_FLAG BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI4Q_HI5Q_TXBD_NUM (Offset 0x0394) */
#define BIT_P0HI4Q_FLAG BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI4Q_TXBD_NUM (Offset 0x0394) */
#define BIT_SHIFT_HI4Q_DESC_MODE 12
#define BIT_MASK_HI4Q_DESC_MODE 0x3
#define BIT_HI4Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI4Q_DESC_MODE) << BIT_SHIFT_HI4Q_DESC_MODE)
#define BITS_HI4Q_DESC_MODE \
(BIT_MASK_HI4Q_DESC_MODE << BIT_SHIFT_HI4Q_DESC_MODE)
#define BIT_CLEAR_HI4Q_DESC_MODE(x) ((x) & (~BITS_HI4Q_DESC_MODE))
#define BIT_GET_HI4Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_MODE) & BIT_MASK_HI4Q_DESC_MODE)
#define BIT_SET_HI4Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI4Q_DESC_MODE(x) | BIT_HI4Q_DESC_MODE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI4Q_HI5Q_TXBD_NUM (Offset 0x0394) */
#define BIT_SHIFT_P0HI4Q_DESC_MODE 12
#define BIT_MASK_P0HI4Q_DESC_MODE 0x3
#define BIT_P0HI4Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI4Q_DESC_MODE) << BIT_SHIFT_P0HI4Q_DESC_MODE)
#define BITS_P0HI4Q_DESC_MODE \
(BIT_MASK_P0HI4Q_DESC_MODE << BIT_SHIFT_P0HI4Q_DESC_MODE)
#define BIT_CLEAR_P0HI4Q_DESC_MODE(x) ((x) & (~BITS_P0HI4Q_DESC_MODE))
#define BIT_GET_P0HI4Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI4Q_DESC_MODE) & BIT_MASK_P0HI4Q_DESC_MODE)
#define BIT_SET_P0HI4Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI4Q_DESC_MODE(x) | BIT_P0HI4Q_DESC_MODE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI4Q_TXBD_NUM (Offset 0x0394) */
#define BIT_SHIFT_HI4Q_DESC_NUM 0
#define BIT_MASK_HI4Q_DESC_NUM 0xfff
#define BIT_HI4Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI4Q_DESC_NUM) << BIT_SHIFT_HI4Q_DESC_NUM)
#define BITS_HI4Q_DESC_NUM (BIT_MASK_HI4Q_DESC_NUM << BIT_SHIFT_HI4Q_DESC_NUM)
#define BIT_CLEAR_HI4Q_DESC_NUM(x) ((x) & (~BITS_HI4Q_DESC_NUM))
#define BIT_GET_HI4Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_NUM) & BIT_MASK_HI4Q_DESC_NUM)
#define BIT_SET_HI4Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI4Q_DESC_NUM(x) | BIT_HI4Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI4Q_HI5Q_TXBD_NUM (Offset 0x0394) */
#define BIT_SHIFT_P0HI4Q_DESC_NUM 0
#define BIT_MASK_P0HI4Q_DESC_NUM 0xfff
#define BIT_P0HI4Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI4Q_DESC_NUM) << BIT_SHIFT_P0HI4Q_DESC_NUM)
#define BITS_P0HI4Q_DESC_NUM \
(BIT_MASK_P0HI4Q_DESC_NUM << BIT_SHIFT_P0HI4Q_DESC_NUM)
#define BIT_CLEAR_P0HI4Q_DESC_NUM(x) ((x) & (~BITS_P0HI4Q_DESC_NUM))
#define BIT_GET_P0HI4Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI4Q_DESC_NUM) & BIT_MASK_P0HI4Q_DESC_NUM)
#define BIT_SET_P0HI4Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI4Q_DESC_NUM(x) | BIT_P0HI4Q_DESC_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI5Q_TXBD_NUM (Offset 0x0396) */
#define BIT_HI5Q_FLAG BIT(14)
#define BIT_SHIFT_HI5Q_DESC_MODE 12
#define BIT_MASK_HI5Q_DESC_MODE 0x3
#define BIT_HI5Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI5Q_DESC_MODE) << BIT_SHIFT_HI5Q_DESC_MODE)
#define BITS_HI5Q_DESC_MODE \
(BIT_MASK_HI5Q_DESC_MODE << BIT_SHIFT_HI5Q_DESC_MODE)
#define BIT_CLEAR_HI5Q_DESC_MODE(x) ((x) & (~BITS_HI5Q_DESC_MODE))
#define BIT_GET_HI5Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_MODE) & BIT_MASK_HI5Q_DESC_MODE)
#define BIT_SET_HI5Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI5Q_DESC_MODE(x) | BIT_HI5Q_DESC_MODE(v))
#define BIT_SHIFT_HI5Q_DESC_NUM 0
#define BIT_MASK_HI5Q_DESC_NUM 0xfff
#define BIT_HI5Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI5Q_DESC_NUM) << BIT_SHIFT_HI5Q_DESC_NUM)
#define BITS_HI5Q_DESC_NUM (BIT_MASK_HI5Q_DESC_NUM << BIT_SHIFT_HI5Q_DESC_NUM)
#define BIT_CLEAR_HI5Q_DESC_NUM(x) ((x) & (~BITS_HI5Q_DESC_NUM))
#define BIT_GET_HI5Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_NUM) & BIT_MASK_HI5Q_DESC_NUM)
#define BIT_SET_HI5Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI5Q_DESC_NUM(x) | BIT_HI5Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI6Q_HI7Q_TXBD_NUM (Offset 0x0398) */
#define BIT_P0HI7Q_FLAG BIT(30)
#define BIT_CLR_FWCMDQ_HW_IDX BIT(30)
#define BIT_CLR_P0HI7Q_HW_IDX BIT(29)
#define BIT_SHIFT_P0HI7Q_DESC_MODE 28
#define BIT_MASK_P0HI7Q_DESC_MODE 0x3
#define BIT_P0HI7Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI7Q_DESC_MODE) << BIT_SHIFT_P0HI7Q_DESC_MODE)
#define BITS_P0HI7Q_DESC_MODE \
(BIT_MASK_P0HI7Q_DESC_MODE << BIT_SHIFT_P0HI7Q_DESC_MODE)
#define BIT_CLEAR_P0HI7Q_DESC_MODE(x) ((x) & (~BITS_P0HI7Q_DESC_MODE))
#define BIT_GET_P0HI7Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI7Q_DESC_MODE) & BIT_MASK_P0HI7Q_DESC_MODE)
#define BIT_SET_P0HI7Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI7Q_DESC_MODE(x) | BIT_P0HI7Q_DESC_MODE(v))
#define BIT_CLR_P0HI6Q_HW_IDX BIT(28)
#define BIT_CLR_P0HI5Q_HW_IDX BIT(27)
#define BIT_CLR_P0HI4Q_HW_IDX BIT(26)
#define BIT_CLR_P0HI3Q_HW_IDX BIT(25)
#define BIT_CLR_P0HI2Q_HW_IDX BIT(24)
#define BIT_CLR_P0HI1Q_HW_IDX BIT(23)
#define BIT_CLR_P0HI0Q_HW_IDX BIT(22)
#define BIT_CLR_ACH3_HW_IDX BIT(21)
#define BIT_CLR_ACH2_HW_IDX BIT(20)
#define BIT_CLR_ACH1_HW_IDX BIT(19)
#define BIT_CLR_ACH0_HW_IDX BIT(18)
#define BIT_CLR_P0MGQ_HW_IDX BIT(17)
#define BIT_SHIFT_P0HI7Q_DESC_NUM 16
#define BIT_MASK_P0HI7Q_DESC_NUM 0xfff
#define BIT_P0HI7Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI7Q_DESC_NUM) << BIT_SHIFT_P0HI7Q_DESC_NUM)
#define BITS_P0HI7Q_DESC_NUM \
(BIT_MASK_P0HI7Q_DESC_NUM << BIT_SHIFT_P0HI7Q_DESC_NUM)
#define BIT_CLEAR_P0HI7Q_DESC_NUM(x) ((x) & (~BITS_P0HI7Q_DESC_NUM))
#define BIT_GET_P0HI7Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI7Q_DESC_NUM) & BIT_MASK_P0HI7Q_DESC_NUM)
#define BIT_SET_P0HI7Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI7Q_DESC_NUM(x) | BIT_P0HI7Q_DESC_NUM(v))
#define BIT_CLR_P0RXQ_HW_IDX BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI6Q_TXBD_NUM (Offset 0x0398) */
#define BIT_HI6Q_FLAG BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI6Q_HI7Q_TXBD_NUM (Offset 0x0398) */
#define BIT_P0HI6Q_FLAG BIT(14)
#define BIT_CLR_PFWCMDQ_HOST_IDX BIT(14)
#define BIT_CLR_P0HI7Q_HOST_IDX BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI6Q_TXBD_NUM (Offset 0x0398) */
#define BIT_SHIFT_HI6Q_DESC_MODE 12
#define BIT_MASK_HI6Q_DESC_MODE 0x3
#define BIT_HI6Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI6Q_DESC_MODE) << BIT_SHIFT_HI6Q_DESC_MODE)
#define BITS_HI6Q_DESC_MODE \
(BIT_MASK_HI6Q_DESC_MODE << BIT_SHIFT_HI6Q_DESC_MODE)
#define BIT_CLEAR_HI6Q_DESC_MODE(x) ((x) & (~BITS_HI6Q_DESC_MODE))
#define BIT_GET_HI6Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_MODE) & BIT_MASK_HI6Q_DESC_MODE)
#define BIT_SET_HI6Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI6Q_DESC_MODE(x) | BIT_HI6Q_DESC_MODE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI6Q_HI7Q_TXBD_NUM (Offset 0x0398) */
#define BIT_SHIFT_P0HI6Q_DESC_MODE 12
#define BIT_MASK_P0HI6Q_DESC_MODE 0x3
#define BIT_P0HI6Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI6Q_DESC_MODE) << BIT_SHIFT_P0HI6Q_DESC_MODE)
#define BITS_P0HI6Q_DESC_MODE \
(BIT_MASK_P0HI6Q_DESC_MODE << BIT_SHIFT_P0HI6Q_DESC_MODE)
#define BIT_CLEAR_P0HI6Q_DESC_MODE(x) ((x) & (~BITS_P0HI6Q_DESC_MODE))
#define BIT_GET_P0HI6Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI6Q_DESC_MODE) & BIT_MASK_P0HI6Q_DESC_MODE)
#define BIT_SET_P0HI6Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI6Q_DESC_MODE(x) | BIT_P0HI6Q_DESC_MODE(v))
#define BIT_CLR_P0HI6Q_HOST_IDX BIT(12)
#define BIT_CLR_P0HI5Q_HOST_IDX BIT(11)
#define BIT_CLR_P0HI4Q_HOST_IDX BIT(10)
#define BIT_CLR_P0HI3Q_HOST_IDX BIT(9)
#define BIT_CLR_P0HI2Q_HOST_IDX BIT(8)
#define BIT_CLR_P0HI1Q_HOST_IDX BIT(7)
#define BIT_CLR_P0HI0Q_HOST_IDX BIT(6)
#define BIT_CLR_ACH3_HOST_IDX BIT(5)
#define BIT_CLR_ACH2_HOST_IDX BIT(4)
#define BIT_CLR_ACH1_HOST_IDX BIT(3)
#define BIT_CLR_ACH0_HOST_IDX BIT(2)
#define BIT_CLR_P0MGQ_HOST_IDX BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI6Q_TXBD_NUM (Offset 0x0398) */
#define BIT_SHIFT_HI6Q_DESC_NUM 0
#define BIT_MASK_HI6Q_DESC_NUM 0xfff
#define BIT_HI6Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI6Q_DESC_NUM) << BIT_SHIFT_HI6Q_DESC_NUM)
#define BITS_HI6Q_DESC_NUM (BIT_MASK_HI6Q_DESC_NUM << BIT_SHIFT_HI6Q_DESC_NUM)
#define BIT_CLEAR_HI6Q_DESC_NUM(x) ((x) & (~BITS_HI6Q_DESC_NUM))
#define BIT_GET_HI6Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_NUM) & BIT_MASK_HI6Q_DESC_NUM)
#define BIT_SET_HI6Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI6Q_DESC_NUM(x) | BIT_HI6Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI6Q_HI7Q_TXBD_NUM (Offset 0x0398) */
#define BIT_SHIFT_P0HI6Q_DESC_NUM 0
#define BIT_MASK_P0HI6Q_DESC_NUM 0xfff
#define BIT_P0HI6Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI6Q_DESC_NUM) << BIT_SHIFT_P0HI6Q_DESC_NUM)
#define BITS_P0HI6Q_DESC_NUM \
(BIT_MASK_P0HI6Q_DESC_NUM << BIT_SHIFT_P0HI6Q_DESC_NUM)
#define BIT_CLEAR_P0HI6Q_DESC_NUM(x) ((x) & (~BITS_P0HI6Q_DESC_NUM))
#define BIT_GET_P0HI6Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI6Q_DESC_NUM) & BIT_MASK_P0HI6Q_DESC_NUM)
#define BIT_SET_P0HI6Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI6Q_DESC_NUM(x) | BIT_P0HI6Q_DESC_NUM(v))
#define BIT_CLR_P0RXQ_HOST_IDX BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI7Q_TXBD_NUM (Offset 0x039A) */
#define BIT_HI7Q_FLAG BIT(14)
#define BIT_SHIFT_HI7Q_DESC_MODE 12
#define BIT_MASK_HI7Q_DESC_MODE 0x3
#define BIT_HI7Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI7Q_DESC_MODE) << BIT_SHIFT_HI7Q_DESC_MODE)
#define BITS_HI7Q_DESC_MODE \
(BIT_MASK_HI7Q_DESC_MODE << BIT_SHIFT_HI7Q_DESC_MODE)
#define BIT_CLEAR_HI7Q_DESC_MODE(x) ((x) & (~BITS_HI7Q_DESC_MODE))
#define BIT_GET_HI7Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_MODE) & BIT_MASK_HI7Q_DESC_MODE)
#define BIT_SET_HI7Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI7Q_DESC_MODE(x) | BIT_HI7Q_DESC_MODE(v))
#define BIT_SHIFT_HI7Q_DESC_NUM 0
#define BIT_MASK_HI7Q_DESC_NUM 0xfff
#define BIT_HI7Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI7Q_DESC_NUM) << BIT_SHIFT_HI7Q_DESC_NUM)
#define BITS_HI7Q_DESC_NUM (BIT_MASK_HI7Q_DESC_NUM << BIT_SHIFT_HI7Q_DESC_NUM)
#define BIT_CLEAR_HI7Q_DESC_NUM(x) ((x) & (~BITS_HI7Q_DESC_NUM))
#define BIT_GET_HI7Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_NUM) & BIT_MASK_HI7Q_DESC_NUM)
#define BIT_SET_HI7Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI7Q_DESC_NUM(x) | BIT_HI7Q_DESC_NUM(v))
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI7Q_HW_IDX BIT(29)
#define BIT_CLR_HI6Q_HW_IDX BIT(28)
#define BIT_CLR_HI5Q_HW_IDX BIT(27)
#define BIT_CLR_HI4Q_HW_IDX BIT(26)
#define BIT_CLR_HI3Q_HW_IDX BIT(25)
#define BIT_CLR_HI2Q_HW_IDX BIT(24)
#define BIT_CLR_HI1Q_HW_IDX BIT(23)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN7DOK BIT(23)
#define BIT_BCN7DOKM BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI0Q_HW_IDX BIT(22)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN6DOK BIT(22)
#define BIT_BCN6DOKM BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_BKQ_HW_IDX BIT(21)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN5DOK BIT(21)
#define BIT_BCN5DOKM BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_BEQ_HW_IDX BIT(20)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN4DOK BIT(20)
#define BIT_BCN4DOKM BIT(20)
#define BIT_RX_OVER_RD_ERR BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_VIQ_HW_IDX BIT(19)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN3DOK BIT(19)
#define BIT_BCN3DOKM BIT(19)
#define BIT_RXDMA_STUCK BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_VOQ_HW_IDX BIT(18)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN2DOK BIT(18)
#define BIT_BCN2DOKM BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_MGQ_HW_IDX BIT(17)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN1DOK BIT(17)
#define BIT_BCN1DOKM BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TSFTIMER_HCI (Offset 0x039C) */
#define BIT_SHIFT_TSFT2_HCI 16
#define BIT_MASK_TSFT2_HCI 0xffff
#define BIT_TSFT2_HCI(x) (((x) & BIT_MASK_TSFT2_HCI) << BIT_SHIFT_TSFT2_HCI)
#define BITS_TSFT2_HCI (BIT_MASK_TSFT2_HCI << BIT_SHIFT_TSFT2_HCI)
#define BIT_CLEAR_TSFT2_HCI(x) ((x) & (~BITS_TSFT2_HCI))
#define BIT_GET_TSFT2_HCI(x) (((x) >> BIT_SHIFT_TSFT2_HCI) & BIT_MASK_TSFT2_HCI)
#define BIT_SET_TSFT2_HCI(x, v) (BIT_CLEAR_TSFT2_HCI(x) | BIT_TSFT2_HCI(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_RXQ_HW_IDX BIT(16)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BCN0DOK BIT(16)
#define BIT_BCN0DOKM BIT(16)
#define BIT_SHIFT_RX_STATE 16
#define BIT_MASK_RX_STATE 0x7
#define BIT_RX_STATE(x) (((x) & BIT_MASK_RX_STATE) << BIT_SHIFT_RX_STATE)
#define BITS_RX_STATE (BIT_MASK_RX_STATE << BIT_SHIFT_RX_STATE)
#define BIT_CLEAR_RX_STATE(x) ((x) & (~BITS_RX_STATE))
#define BIT_GET_RX_STATE(x) (((x) >> BIT_SHIFT_RX_STATE) & BIT_MASK_RX_STATE)
#define BIT_SET_RX_STATE(x, v) (BIT_CLEAR_RX_STATE(x) | BIT_RX_STATE(v))
#define BIT_SRST_TX BIT(15)
#define BIT_M7DOK BIT(15)
#define BIT_M7DOKM BIT(15)
#define BIT_TDE_NO_IDLE BIT(15)
#define BIT_SRST_RX BIT(14)
#define BIT_M6DOK BIT(14)
#define BIT_M6DOKM BIT(14)
#define BIT_TXDMA_STUCK BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI7Q_HOST_IDX BIT(13)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_M5DOK BIT(13)
#define BIT_M5DOKM BIT(13)
#define BIT_TDE_FULL_ERR BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI6Q_HOST_IDX BIT(12)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_M4DOK BIT(12)
#define BIT_M4DOKM BIT(12)
#define BIT_HD_SIZE_ERR BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI5Q_HOST_IDX BIT(11)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_M3DOK BIT(11)
#define BIT_M3DOKM BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI4Q_HOST_IDX BIT(10)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_M2DOK BIT(10)
#define BIT_M2DOKM BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI3Q_HOST_IDX BIT(9)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_M1DOK BIT(9)
#define BIT_M1DOKM BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI2Q_HOST_IDX BIT(8)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_M0DOK BIT(8)
#define BIT_M0DOKM BIT(8)
#define BIT_SHIFT_TX_STATE 8
#define BIT_MASK_TX_STATE 0xf
#define BIT_TX_STATE(x) (((x) & BIT_MASK_TX_STATE) << BIT_SHIFT_TX_STATE)
#define BITS_TX_STATE (BIT_MASK_TX_STATE << BIT_SHIFT_TX_STATE)
#define BIT_CLEAR_TX_STATE(x) ((x) & (~BITS_TX_STATE))
#define BIT_GET_TX_STATE(x) (((x) >> BIT_SHIFT_TX_STATE) & BIT_MASK_TX_STATE)
#define BIT_SET_TX_STATE(x, v) (BIT_CLEAR_TX_STATE(x) | BIT_TX_STATE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_HI1Q_HOST_IDX BIT(7)
#define BIT_CLR_HI0Q_HOST_IDX BIT(6)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_MGQDOK BIT(6)
#define BIT_MGQDOKM BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_BKQ_HOST_IDX BIT(5)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_BKQDOK BIT(5)
#define BIT_BKQDOKM BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_BEQ_HOST_IDX BIT(4)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_SHIFT_HPS_CLKR 4
#define BIT_MASK_HPS_CLKR 0x3
#define BIT_HPS_CLKR(x) (((x) & BIT_MASK_HPS_CLKR) << BIT_SHIFT_HPS_CLKR)
#define BITS_HPS_CLKR (BIT_MASK_HPS_CLKR << BIT_SHIFT_HPS_CLKR)
#define BIT_CLEAR_HPS_CLKR(x) ((x) & (~BITS_HPS_CLKR))
#define BIT_GET_HPS_CLKR(x) (((x) >> BIT_SHIFT_HPS_CLKR) & BIT_MASK_HPS_CLKR)
#define BIT_SET_HPS_CLKR(x, v) (BIT_CLEAR_HPS_CLKR(x) | BIT_HPS_CLKR(v))
#define BIT_BEQDOK BIT(4)
#define BIT_BEQDOKM BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_VIQ_HOST_IDX BIT(3)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_LX_INT BIT(3)
#define BIT_VIQDOK BIT(3)
#define BIT_VIQDOKM BIT(3)
#define BIT_MST_BUSY BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_VOQ_HOST_IDX BIT(2)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_VOQDOK BIT(2)
#define BIT_VOQDOKM BIT(2)
#define BIT_SLV_BUSY BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_MGQ_HOST_IDX BIT(1)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_RDUM BIT(1)
#define BIT_RXDES_UNAVAIL BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TSFTIMER_HCI (Offset 0x039C) */
#define BIT_SHIFT_TSFT1_HCI 0
#define BIT_MASK_TSFT1_HCI 0xffff
#define BIT_TSFT1_HCI(x) (((x) & BIT_MASK_TSFT1_HCI) << BIT_SHIFT_TSFT1_HCI)
#define BITS_TSFT1_HCI (BIT_MASK_TSFT1_HCI << BIT_SHIFT_TSFT1_HCI)
#define BIT_CLEAR_TSFT1_HCI(x) ((x) & (~BITS_TSFT1_HCI))
#define BIT_GET_TSFT1_HCI(x) (((x) >> BIT_SHIFT_TSFT1_HCI) & BIT_MASK_TSFT1_HCI)
#define BIT_SET_TSFT1_HCI(x, v) (BIT_CLEAR_TSFT1_HCI(x) | BIT_TSFT1_HCI(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_CLR_RXQ_HOST_IDX BIT(0)
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BD_RWPTR_CLR (Offset 0x039C) */
#define BIT_RXDOK BIT(0)
#define BIT_RXDOKM BIT(0)
#define BIT_EN_DBG_STUCK BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VOQ_TXBD_IDX (Offset 0x03A0) */
#define BIT_SHIFT_VOQ_HW_IDX 16
#define BIT_MASK_VOQ_HW_IDX 0xfff
#define BIT_VOQ_HW_IDX(x) (((x) & BIT_MASK_VOQ_HW_IDX) << BIT_SHIFT_VOQ_HW_IDX)
#define BITS_VOQ_HW_IDX (BIT_MASK_VOQ_HW_IDX << BIT_SHIFT_VOQ_HW_IDX)
#define BIT_CLEAR_VOQ_HW_IDX(x) ((x) & (~BITS_VOQ_HW_IDX))
#define BIT_GET_VOQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_VOQ_HW_IDX) & BIT_MASK_VOQ_HW_IDX)
#define BIT_SET_VOQ_HW_IDX(x, v) (BIT_CLEAR_VOQ_HW_IDX(x) | BIT_VOQ_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_TXBD_IDX (Offset 0x03A0) */
#define BIT_SHIFT_ACH0_HW_IDX 16
#define BIT_MASK_ACH0_HW_IDX 0xfff
#define BIT_ACH0_HW_IDX(x) \
(((x) & BIT_MASK_ACH0_HW_IDX) << BIT_SHIFT_ACH0_HW_IDX)
#define BITS_ACH0_HW_IDX (BIT_MASK_ACH0_HW_IDX << BIT_SHIFT_ACH0_HW_IDX)
#define BIT_CLEAR_ACH0_HW_IDX(x) ((x) & (~BITS_ACH0_HW_IDX))
#define BIT_GET_ACH0_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH0_HW_IDX) & BIT_MASK_ACH0_HW_IDX)
#define BIT_SET_ACH0_HW_IDX(x, v) \
(BIT_CLEAR_ACH0_HW_IDX(x) | BIT_ACH0_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VOQ_TXBD_IDX (Offset 0x03A0) */
#define BIT_SHIFT_VOQ_HOST_IDX 0
#define BIT_MASK_VOQ_HOST_IDX 0xfff
#define BIT_VOQ_HOST_IDX(x) \
(((x) & BIT_MASK_VOQ_HOST_IDX) << BIT_SHIFT_VOQ_HOST_IDX)
#define BITS_VOQ_HOST_IDX (BIT_MASK_VOQ_HOST_IDX << BIT_SHIFT_VOQ_HOST_IDX)
#define BIT_CLEAR_VOQ_HOST_IDX(x) ((x) & (~BITS_VOQ_HOST_IDX))
#define BIT_GET_VOQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_VOQ_HOST_IDX) & BIT_MASK_VOQ_HOST_IDX)
#define BIT_SET_VOQ_HOST_IDX(x, v) \
(BIT_CLEAR_VOQ_HOST_IDX(x) | BIT_VOQ_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH0_TXBD_IDX (Offset 0x03A0) */
#define BIT_SHIFT_ACH0_HOST_IDX 0
#define BIT_MASK_ACH0_HOST_IDX 0xfff
#define BIT_ACH0_HOST_IDX(x) \
(((x) & BIT_MASK_ACH0_HOST_IDX) << BIT_SHIFT_ACH0_HOST_IDX)
#define BITS_ACH0_HOST_IDX (BIT_MASK_ACH0_HOST_IDX << BIT_SHIFT_ACH0_HOST_IDX)
#define BIT_CLEAR_ACH0_HOST_IDX(x) ((x) & (~BITS_ACH0_HOST_IDX))
#define BIT_GET_ACH0_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH0_HOST_IDX) & BIT_MASK_ACH0_HOST_IDX)
#define BIT_SET_ACH0_HOST_IDX(x, v) \
(BIT_CLEAR_ACH0_HOST_IDX(x) | BIT_ACH0_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VIQ_TXBD_IDX (Offset 0x03A4) */
#define BIT_SHIFT_VIQ_HW_IDX 16
#define BIT_MASK_VIQ_HW_IDX 0xfff
#define BIT_VIQ_HW_IDX(x) (((x) & BIT_MASK_VIQ_HW_IDX) << BIT_SHIFT_VIQ_HW_IDX)
#define BITS_VIQ_HW_IDX (BIT_MASK_VIQ_HW_IDX << BIT_SHIFT_VIQ_HW_IDX)
#define BIT_CLEAR_VIQ_HW_IDX(x) ((x) & (~BITS_VIQ_HW_IDX))
#define BIT_GET_VIQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_VIQ_HW_IDX) & BIT_MASK_VIQ_HW_IDX)
#define BIT_SET_VIQ_HW_IDX(x, v) (BIT_CLEAR_VIQ_HW_IDX(x) | BIT_VIQ_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH1_TXBD_IDX (Offset 0x03A4) */
#define BIT_SHIFT_ACH1_HW_IDX 16
#define BIT_MASK_ACH1_HW_IDX 0xfff
#define BIT_ACH1_HW_IDX(x) \
(((x) & BIT_MASK_ACH1_HW_IDX) << BIT_SHIFT_ACH1_HW_IDX)
#define BITS_ACH1_HW_IDX (BIT_MASK_ACH1_HW_IDX << BIT_SHIFT_ACH1_HW_IDX)
#define BIT_CLEAR_ACH1_HW_IDX(x) ((x) & (~BITS_ACH1_HW_IDX))
#define BIT_GET_ACH1_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH1_HW_IDX) & BIT_MASK_ACH1_HW_IDX)
#define BIT_SET_ACH1_HW_IDX(x, v) \
(BIT_CLEAR_ACH1_HW_IDX(x) | BIT_ACH1_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_VIQ_TXBD_IDX (Offset 0x03A4) */
#define BIT_SHIFT_VIQ_HOST_IDX 0
#define BIT_MASK_VIQ_HOST_IDX 0xfff
#define BIT_VIQ_HOST_IDX(x) \
(((x) & BIT_MASK_VIQ_HOST_IDX) << BIT_SHIFT_VIQ_HOST_IDX)
#define BITS_VIQ_HOST_IDX (BIT_MASK_VIQ_HOST_IDX << BIT_SHIFT_VIQ_HOST_IDX)
#define BIT_CLEAR_VIQ_HOST_IDX(x) ((x) & (~BITS_VIQ_HOST_IDX))
#define BIT_GET_VIQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_VIQ_HOST_IDX) & BIT_MASK_VIQ_HOST_IDX)
#define BIT_SET_VIQ_HOST_IDX(x, v) \
(BIT_CLEAR_VIQ_HOST_IDX(x) | BIT_VIQ_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH1_TXBD_IDX (Offset 0x03A4) */
#define BIT_SHIFT_ACH1_HOST_IDX 0
#define BIT_MASK_ACH1_HOST_IDX 0xfff
#define BIT_ACH1_HOST_IDX(x) \
(((x) & BIT_MASK_ACH1_HOST_IDX) << BIT_SHIFT_ACH1_HOST_IDX)
#define BITS_ACH1_HOST_IDX (BIT_MASK_ACH1_HOST_IDX << BIT_SHIFT_ACH1_HOST_IDX)
#define BIT_CLEAR_ACH1_HOST_IDX(x) ((x) & (~BITS_ACH1_HOST_IDX))
#define BIT_GET_ACH1_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH1_HOST_IDX) & BIT_MASK_ACH1_HOST_IDX)
#define BIT_SET_ACH1_HOST_IDX(x, v) \
(BIT_CLEAR_ACH1_HOST_IDX(x) | BIT_ACH1_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BEQ_TXBD_IDX (Offset 0x03A8) */
#define BIT_SHIFT_BEQ_HW_IDX 16
#define BIT_MASK_BEQ_HW_IDX 0xfff
#define BIT_BEQ_HW_IDX(x) (((x) & BIT_MASK_BEQ_HW_IDX) << BIT_SHIFT_BEQ_HW_IDX)
#define BITS_BEQ_HW_IDX (BIT_MASK_BEQ_HW_IDX << BIT_SHIFT_BEQ_HW_IDX)
#define BIT_CLEAR_BEQ_HW_IDX(x) ((x) & (~BITS_BEQ_HW_IDX))
#define BIT_GET_BEQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_BEQ_HW_IDX) & BIT_MASK_BEQ_HW_IDX)
#define BIT_SET_BEQ_HW_IDX(x, v) (BIT_CLEAR_BEQ_HW_IDX(x) | BIT_BEQ_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_TXBD_IDX (Offset 0x03A8) */
#define BIT_SHIFT_ACH2_HW_IDX 16
#define BIT_MASK_ACH2_HW_IDX 0xfff
#define BIT_ACH2_HW_IDX(x) \
(((x) & BIT_MASK_ACH2_HW_IDX) << BIT_SHIFT_ACH2_HW_IDX)
#define BITS_ACH2_HW_IDX (BIT_MASK_ACH2_HW_IDX << BIT_SHIFT_ACH2_HW_IDX)
#define BIT_CLEAR_ACH2_HW_IDX(x) ((x) & (~BITS_ACH2_HW_IDX))
#define BIT_GET_ACH2_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH2_HW_IDX) & BIT_MASK_ACH2_HW_IDX)
#define BIT_SET_ACH2_HW_IDX(x, v) \
(BIT_CLEAR_ACH2_HW_IDX(x) | BIT_ACH2_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BEQ_TXBD_IDX (Offset 0x03A8) */
#define BIT_SHIFT_BEQ_HOST_IDX 0
#define BIT_MASK_BEQ_HOST_IDX 0xfff
#define BIT_BEQ_HOST_IDX(x) \
(((x) & BIT_MASK_BEQ_HOST_IDX) << BIT_SHIFT_BEQ_HOST_IDX)
#define BITS_BEQ_HOST_IDX (BIT_MASK_BEQ_HOST_IDX << BIT_SHIFT_BEQ_HOST_IDX)
#define BIT_CLEAR_BEQ_HOST_IDX(x) ((x) & (~BITS_BEQ_HOST_IDX))
#define BIT_GET_BEQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_BEQ_HOST_IDX) & BIT_MASK_BEQ_HOST_IDX)
#define BIT_SET_BEQ_HOST_IDX(x, v) \
(BIT_CLEAR_BEQ_HOST_IDX(x) | BIT_BEQ_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH2_TXBD_IDX (Offset 0x03A8) */
#define BIT_SHIFT_ACH2_HOST_IDX 0
#define BIT_MASK_ACH2_HOST_IDX 0xfff
#define BIT_ACH2_HOST_IDX(x) \
(((x) & BIT_MASK_ACH2_HOST_IDX) << BIT_SHIFT_ACH2_HOST_IDX)
#define BITS_ACH2_HOST_IDX (BIT_MASK_ACH2_HOST_IDX << BIT_SHIFT_ACH2_HOST_IDX)
#define BIT_CLEAR_ACH2_HOST_IDX(x) ((x) & (~BITS_ACH2_HOST_IDX))
#define BIT_GET_ACH2_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH2_HOST_IDX) & BIT_MASK_ACH2_HOST_IDX)
#define BIT_SET_ACH2_HOST_IDX(x, v) \
(BIT_CLEAR_ACH2_HOST_IDX(x) | BIT_ACH2_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BKQ_TXBD_IDX (Offset 0x03AC) */
#define BIT_SHIFT_BKQ_HW_IDX 16
#define BIT_MASK_BKQ_HW_IDX 0xfff
#define BIT_BKQ_HW_IDX(x) (((x) & BIT_MASK_BKQ_HW_IDX) << BIT_SHIFT_BKQ_HW_IDX)
#define BITS_BKQ_HW_IDX (BIT_MASK_BKQ_HW_IDX << BIT_SHIFT_BKQ_HW_IDX)
#define BIT_CLEAR_BKQ_HW_IDX(x) ((x) & (~BITS_BKQ_HW_IDX))
#define BIT_GET_BKQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_BKQ_HW_IDX) & BIT_MASK_BKQ_HW_IDX)
#define BIT_SET_BKQ_HW_IDX(x, v) (BIT_CLEAR_BKQ_HW_IDX(x) | BIT_BKQ_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH3_TXBD_IDX (Offset 0x03AC) */
#define BIT_SHIFT_ACH3_HW_IDX 16
#define BIT_MASK_ACH3_HW_IDX 0xfff
#define BIT_ACH3_HW_IDX(x) \
(((x) & BIT_MASK_ACH3_HW_IDX) << BIT_SHIFT_ACH3_HW_IDX)
#define BITS_ACH3_HW_IDX (BIT_MASK_ACH3_HW_IDX << BIT_SHIFT_ACH3_HW_IDX)
#define BIT_CLEAR_ACH3_HW_IDX(x) ((x) & (~BITS_ACH3_HW_IDX))
#define BIT_GET_ACH3_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH3_HW_IDX) & BIT_MASK_ACH3_HW_IDX)
#define BIT_SET_ACH3_HW_IDX(x, v) \
(BIT_CLEAR_ACH3_HW_IDX(x) | BIT_ACH3_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BKQ_TXBD_IDX (Offset 0x03AC) */
#define BIT_SHIFT_BKQ_HOST_IDX 0
#define BIT_MASK_BKQ_HOST_IDX 0xfff
#define BIT_BKQ_HOST_IDX(x) \
(((x) & BIT_MASK_BKQ_HOST_IDX) << BIT_SHIFT_BKQ_HOST_IDX)
#define BITS_BKQ_HOST_IDX (BIT_MASK_BKQ_HOST_IDX << BIT_SHIFT_BKQ_HOST_IDX)
#define BIT_CLEAR_BKQ_HOST_IDX(x) ((x) & (~BITS_BKQ_HOST_IDX))
#define BIT_GET_BKQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_BKQ_HOST_IDX) & BIT_MASK_BKQ_HOST_IDX)
#define BIT_SET_BKQ_HOST_IDX(x, v) \
(BIT_CLEAR_BKQ_HOST_IDX(x) | BIT_BKQ_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH3_TXBD_IDX (Offset 0x03AC) */
#define BIT_SHIFT_ACH3_HOST_IDX 0
#define BIT_MASK_ACH3_HOST_IDX 0xfff
#define BIT_ACH3_HOST_IDX(x) \
(((x) & BIT_MASK_ACH3_HOST_IDX) << BIT_SHIFT_ACH3_HOST_IDX)
#define BITS_ACH3_HOST_IDX (BIT_MASK_ACH3_HOST_IDX << BIT_SHIFT_ACH3_HOST_IDX)
#define BIT_CLEAR_ACH3_HOST_IDX(x) ((x) & (~BITS_ACH3_HOST_IDX))
#define BIT_GET_ACH3_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH3_HOST_IDX) & BIT_MASK_ACH3_HOST_IDX)
#define BIT_SET_ACH3_HOST_IDX(x, v) \
(BIT_CLEAR_ACH3_HOST_IDX(x) | BIT_ACH3_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_TXBD_IDX (Offset 0x03B0) */
#define BIT_SHIFT_MGQ_HW_IDX 16
#define BIT_MASK_MGQ_HW_IDX 0xfff
#define BIT_MGQ_HW_IDX(x) (((x) & BIT_MASK_MGQ_HW_IDX) << BIT_SHIFT_MGQ_HW_IDX)
#define BITS_MGQ_HW_IDX (BIT_MASK_MGQ_HW_IDX << BIT_SHIFT_MGQ_HW_IDX)
#define BIT_CLEAR_MGQ_HW_IDX(x) ((x) & (~BITS_MGQ_HW_IDX))
#define BIT_GET_MGQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_MGQ_HW_IDX) & BIT_MASK_MGQ_HW_IDX)
#define BIT_SET_MGQ_HW_IDX(x, v) (BIT_CLEAR_MGQ_HW_IDX(x) | BIT_MGQ_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0MGQ_TXBD_IDX (Offset 0x03B0) */
#define BIT_SHIFT_P0MGQ_HW_IDX 16
#define BIT_MASK_P0MGQ_HW_IDX 0xfff
#define BIT_P0MGQ_HW_IDX(x) \
(((x) & BIT_MASK_P0MGQ_HW_IDX) << BIT_SHIFT_P0MGQ_HW_IDX)
#define BITS_P0MGQ_HW_IDX (BIT_MASK_P0MGQ_HW_IDX << BIT_SHIFT_P0MGQ_HW_IDX)
#define BIT_CLEAR_P0MGQ_HW_IDX(x) ((x) & (~BITS_P0MGQ_HW_IDX))
#define BIT_GET_P0MGQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0MGQ_HW_IDX) & BIT_MASK_P0MGQ_HW_IDX)
#define BIT_SET_P0MGQ_HW_IDX(x, v) \
(BIT_CLEAR_P0MGQ_HW_IDX(x) | BIT_P0MGQ_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_TXBD_IDX (Offset 0x03B0) */
#define BIT_SHIFT_MGQ_HOST_IDX 0
#define BIT_MASK_MGQ_HOST_IDX 0xfff
#define BIT_MGQ_HOST_IDX(x) \
(((x) & BIT_MASK_MGQ_HOST_IDX) << BIT_SHIFT_MGQ_HOST_IDX)
#define BITS_MGQ_HOST_IDX (BIT_MASK_MGQ_HOST_IDX << BIT_SHIFT_MGQ_HOST_IDX)
#define BIT_CLEAR_MGQ_HOST_IDX(x) ((x) & (~BITS_MGQ_HOST_IDX))
#define BIT_GET_MGQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_MGQ_HOST_IDX) & BIT_MASK_MGQ_HOST_IDX)
#define BIT_SET_MGQ_HOST_IDX(x, v) \
(BIT_CLEAR_MGQ_HOST_IDX(x) | BIT_MGQ_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0MGQ_TXBD_IDX (Offset 0x03B0) */
#define BIT_SHIFT_P0MGQ_HOST_IDX 0
#define BIT_MASK_P0MGQ_HOST_IDX 0xfff
#define BIT_P0MGQ_HOST_IDX(x) \
(((x) & BIT_MASK_P0MGQ_HOST_IDX) << BIT_SHIFT_P0MGQ_HOST_IDX)
#define BITS_P0MGQ_HOST_IDX \
(BIT_MASK_P0MGQ_HOST_IDX << BIT_SHIFT_P0MGQ_HOST_IDX)
#define BIT_CLEAR_P0MGQ_HOST_IDX(x) ((x) & (~BITS_P0MGQ_HOST_IDX))
#define BIT_GET_P0MGQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0MGQ_HOST_IDX) & BIT_MASK_P0MGQ_HOST_IDX)
#define BIT_SET_P0MGQ_HOST_IDX(x, v) \
(BIT_CLEAR_P0MGQ_HOST_IDX(x) | BIT_P0MGQ_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXQ_RXBD_IDX (Offset 0x03B4) */
#define BIT_SHIFT_RXQ_HW_IDX 16
#define BIT_MASK_RXQ_HW_IDX 0xfff
#define BIT_RXQ_HW_IDX(x) (((x) & BIT_MASK_RXQ_HW_IDX) << BIT_SHIFT_RXQ_HW_IDX)
#define BITS_RXQ_HW_IDX (BIT_MASK_RXQ_HW_IDX << BIT_SHIFT_RXQ_HW_IDX)
#define BIT_CLEAR_RXQ_HW_IDX(x) ((x) & (~BITS_RXQ_HW_IDX))
#define BIT_GET_RXQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_RXQ_HW_IDX) & BIT_MASK_RXQ_HW_IDX)
#define BIT_SET_RXQ_HW_IDX(x, v) (BIT_CLEAR_RXQ_HW_IDX(x) | BIT_RXQ_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0RXQ_RXBD_IDX (Offset 0x03B4) */
#define BIT_SHIFT_P0RXQ_HW_IDX 16
#define BIT_MASK_P0RXQ_HW_IDX 0xfff
#define BIT_P0RXQ_HW_IDX(x) \
(((x) & BIT_MASK_P0RXQ_HW_IDX) << BIT_SHIFT_P0RXQ_HW_IDX)
#define BITS_P0RXQ_HW_IDX (BIT_MASK_P0RXQ_HW_IDX << BIT_SHIFT_P0RXQ_HW_IDX)
#define BIT_CLEAR_P0RXQ_HW_IDX(x) ((x) & (~BITS_P0RXQ_HW_IDX))
#define BIT_GET_P0RXQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0RXQ_HW_IDX) & BIT_MASK_P0RXQ_HW_IDX)
#define BIT_SET_P0RXQ_HW_IDX(x, v) \
(BIT_CLEAR_P0RXQ_HW_IDX(x) | BIT_P0RXQ_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXQ_RXBD_IDX (Offset 0x03B4) */
#define BIT_SHIFT_RXQ_HOST_IDX 0
#define BIT_MASK_RXQ_HOST_IDX 0xfff
#define BIT_RXQ_HOST_IDX(x) \
(((x) & BIT_MASK_RXQ_HOST_IDX) << BIT_SHIFT_RXQ_HOST_IDX)
#define BITS_RXQ_HOST_IDX (BIT_MASK_RXQ_HOST_IDX << BIT_SHIFT_RXQ_HOST_IDX)
#define BIT_CLEAR_RXQ_HOST_IDX(x) ((x) & (~BITS_RXQ_HOST_IDX))
#define BIT_GET_RXQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_RXQ_HOST_IDX) & BIT_MASK_RXQ_HOST_IDX)
#define BIT_SET_RXQ_HOST_IDX(x, v) \
(BIT_CLEAR_RXQ_HOST_IDX(x) | BIT_RXQ_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0RXQ_RXBD_IDX (Offset 0x03B4) */
#define BIT_SHIFT_P0RXQ_HOST_IDX 0
#define BIT_MASK_P0RXQ_HOST_IDX 0xfff
#define BIT_P0RXQ_HOST_IDX(x) \
(((x) & BIT_MASK_P0RXQ_HOST_IDX) << BIT_SHIFT_P0RXQ_HOST_IDX)
#define BITS_P0RXQ_HOST_IDX \
(BIT_MASK_P0RXQ_HOST_IDX << BIT_SHIFT_P0RXQ_HOST_IDX)
#define BIT_CLEAR_P0RXQ_HOST_IDX(x) ((x) & (~BITS_P0RXQ_HOST_IDX))
#define BIT_GET_P0RXQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0RXQ_HOST_IDX) & BIT_MASK_P0RXQ_HOST_IDX)
#define BIT_SET_P0RXQ_HOST_IDX(x, v) \
(BIT_CLEAR_P0RXQ_HOST_IDX(x) | BIT_P0RXQ_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI0Q_TXBD_IDX (Offset 0x03B8) */
#define BIT_SHIFT_HI0Q_HW_IDX 16
#define BIT_MASK_HI0Q_HW_IDX 0xfff
#define BIT_HI0Q_HW_IDX(x) \
(((x) & BIT_MASK_HI0Q_HW_IDX) << BIT_SHIFT_HI0Q_HW_IDX)
#define BITS_HI0Q_HW_IDX (BIT_MASK_HI0Q_HW_IDX << BIT_SHIFT_HI0Q_HW_IDX)
#define BIT_CLEAR_HI0Q_HW_IDX(x) ((x) & (~BITS_HI0Q_HW_IDX))
#define BIT_GET_HI0Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI0Q_HW_IDX) & BIT_MASK_HI0Q_HW_IDX)
#define BIT_SET_HI0Q_HW_IDX(x, v) \
(BIT_CLEAR_HI0Q_HW_IDX(x) | BIT_HI0Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI0Q_TXBD_IDX (Offset 0x03B8) */
#define BIT_SHIFT_P0HI0Q_HW_IDX 16
#define BIT_MASK_P0HI0Q_HW_IDX 0xfff
#define BIT_P0HI0Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI0Q_HW_IDX) << BIT_SHIFT_P0HI0Q_HW_IDX)
#define BITS_P0HI0Q_HW_IDX (BIT_MASK_P0HI0Q_HW_IDX << BIT_SHIFT_P0HI0Q_HW_IDX)
#define BIT_CLEAR_P0HI0Q_HW_IDX(x) ((x) & (~BITS_P0HI0Q_HW_IDX))
#define BIT_GET_P0HI0Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI0Q_HW_IDX) & BIT_MASK_P0HI0Q_HW_IDX)
#define BIT_SET_P0HI0Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI0Q_HW_IDX(x) | BIT_P0HI0Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI0Q_TXBD_IDX (Offset 0x03B8) */
#define BIT_SHIFT_HI0Q_HOST_IDX 0
#define BIT_MASK_HI0Q_HOST_IDX 0xfff
#define BIT_HI0Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI0Q_HOST_IDX) << BIT_SHIFT_HI0Q_HOST_IDX)
#define BITS_HI0Q_HOST_IDX (BIT_MASK_HI0Q_HOST_IDX << BIT_SHIFT_HI0Q_HOST_IDX)
#define BIT_CLEAR_HI0Q_HOST_IDX(x) ((x) & (~BITS_HI0Q_HOST_IDX))
#define BIT_GET_HI0Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI0Q_HOST_IDX) & BIT_MASK_HI0Q_HOST_IDX)
#define BIT_SET_HI0Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI0Q_HOST_IDX(x) | BIT_HI0Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI0Q_TXBD_IDX (Offset 0x03B8) */
#define BIT_SHIFT_P0HI0Q_HOST_IDX 0
#define BIT_MASK_P0HI0Q_HOST_IDX 0xfff
#define BIT_P0HI0Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI0Q_HOST_IDX) << BIT_SHIFT_P0HI0Q_HOST_IDX)
#define BITS_P0HI0Q_HOST_IDX \
(BIT_MASK_P0HI0Q_HOST_IDX << BIT_SHIFT_P0HI0Q_HOST_IDX)
#define BIT_CLEAR_P0HI0Q_HOST_IDX(x) ((x) & (~BITS_P0HI0Q_HOST_IDX))
#define BIT_GET_P0HI0Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI0Q_HOST_IDX) & BIT_MASK_P0HI0Q_HOST_IDX)
#define BIT_SET_P0HI0Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI0Q_HOST_IDX(x) | BIT_P0HI0Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI1Q_TXBD_IDX (Offset 0x03BC) */
#define BIT_SHIFT_HI1Q_HW_IDX 16
#define BIT_MASK_HI1Q_HW_IDX 0xfff
#define BIT_HI1Q_HW_IDX(x) \
(((x) & BIT_MASK_HI1Q_HW_IDX) << BIT_SHIFT_HI1Q_HW_IDX)
#define BITS_HI1Q_HW_IDX (BIT_MASK_HI1Q_HW_IDX << BIT_SHIFT_HI1Q_HW_IDX)
#define BIT_CLEAR_HI1Q_HW_IDX(x) ((x) & (~BITS_HI1Q_HW_IDX))
#define BIT_GET_HI1Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI1Q_HW_IDX) & BIT_MASK_HI1Q_HW_IDX)
#define BIT_SET_HI1Q_HW_IDX(x, v) \
(BIT_CLEAR_HI1Q_HW_IDX(x) | BIT_HI1Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI1Q_TXBD_IDX (Offset 0x03BC) */
#define BIT_SHIFT_P0HI1Q_HW_IDX 16
#define BIT_MASK_P0HI1Q_HW_IDX 0xfff
#define BIT_P0HI1Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI1Q_HW_IDX) << BIT_SHIFT_P0HI1Q_HW_IDX)
#define BITS_P0HI1Q_HW_IDX (BIT_MASK_P0HI1Q_HW_IDX << BIT_SHIFT_P0HI1Q_HW_IDX)
#define BIT_CLEAR_P0HI1Q_HW_IDX(x) ((x) & (~BITS_P0HI1Q_HW_IDX))
#define BIT_GET_P0HI1Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI1Q_HW_IDX) & BIT_MASK_P0HI1Q_HW_IDX)
#define BIT_SET_P0HI1Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI1Q_HW_IDX(x) | BIT_P0HI1Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI1Q_TXBD_IDX (Offset 0x03BC) */
#define BIT_SHIFT_HI1Q_HOST_IDX 0
#define BIT_MASK_HI1Q_HOST_IDX 0xfff
#define BIT_HI1Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI1Q_HOST_IDX) << BIT_SHIFT_HI1Q_HOST_IDX)
#define BITS_HI1Q_HOST_IDX (BIT_MASK_HI1Q_HOST_IDX << BIT_SHIFT_HI1Q_HOST_IDX)
#define BIT_CLEAR_HI1Q_HOST_IDX(x) ((x) & (~BITS_HI1Q_HOST_IDX))
#define BIT_GET_HI1Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI1Q_HOST_IDX) & BIT_MASK_HI1Q_HOST_IDX)
#define BIT_SET_HI1Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI1Q_HOST_IDX(x) | BIT_HI1Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI1Q_TXBD_IDX (Offset 0x03BC) */
#define BIT_SHIFT_P0HI1Q_HOST_IDX 0
#define BIT_MASK_P0HI1Q_HOST_IDX 0xfff
#define BIT_P0HI1Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI1Q_HOST_IDX) << BIT_SHIFT_P0HI1Q_HOST_IDX)
#define BITS_P0HI1Q_HOST_IDX \
(BIT_MASK_P0HI1Q_HOST_IDX << BIT_SHIFT_P0HI1Q_HOST_IDX)
#define BIT_CLEAR_P0HI1Q_HOST_IDX(x) ((x) & (~BITS_P0HI1Q_HOST_IDX))
#define BIT_GET_P0HI1Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI1Q_HOST_IDX) & BIT_MASK_P0HI1Q_HOST_IDX)
#define BIT_SET_P0HI1Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI1Q_HOST_IDX(x) | BIT_P0HI1Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI2Q_TXBD_IDX (Offset 0x03C0) */
#define BIT_SHIFT_HI2Q_HW_IDX 16
#define BIT_MASK_HI2Q_HW_IDX 0xfff
#define BIT_HI2Q_HW_IDX(x) \
(((x) & BIT_MASK_HI2Q_HW_IDX) << BIT_SHIFT_HI2Q_HW_IDX)
#define BITS_HI2Q_HW_IDX (BIT_MASK_HI2Q_HW_IDX << BIT_SHIFT_HI2Q_HW_IDX)
#define BIT_CLEAR_HI2Q_HW_IDX(x) ((x) & (~BITS_HI2Q_HW_IDX))
#define BIT_GET_HI2Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI2Q_HW_IDX) & BIT_MASK_HI2Q_HW_IDX)
#define BIT_SET_HI2Q_HW_IDX(x, v) \
(BIT_CLEAR_HI2Q_HW_IDX(x) | BIT_HI2Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI2Q_TXBD_IDX (Offset 0x03C0) */
#define BIT_SHIFT_P0HI2Q_HW_IDX 16
#define BIT_MASK_P0HI2Q_HW_IDX 0xfff
#define BIT_P0HI2Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI2Q_HW_IDX) << BIT_SHIFT_P0HI2Q_HW_IDX)
#define BITS_P0HI2Q_HW_IDX (BIT_MASK_P0HI2Q_HW_IDX << BIT_SHIFT_P0HI2Q_HW_IDX)
#define BIT_CLEAR_P0HI2Q_HW_IDX(x) ((x) & (~BITS_P0HI2Q_HW_IDX))
#define BIT_GET_P0HI2Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI2Q_HW_IDX) & BIT_MASK_P0HI2Q_HW_IDX)
#define BIT_SET_P0HI2Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI2Q_HW_IDX(x) | BIT_P0HI2Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI2Q_TXBD_IDX (Offset 0x03C0) */
#define BIT_SHIFT_HI2Q_HOST_IDX 0
#define BIT_MASK_HI2Q_HOST_IDX 0xfff
#define BIT_HI2Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI2Q_HOST_IDX) << BIT_SHIFT_HI2Q_HOST_IDX)
#define BITS_HI2Q_HOST_IDX (BIT_MASK_HI2Q_HOST_IDX << BIT_SHIFT_HI2Q_HOST_IDX)
#define BIT_CLEAR_HI2Q_HOST_IDX(x) ((x) & (~BITS_HI2Q_HOST_IDX))
#define BIT_GET_HI2Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI2Q_HOST_IDX) & BIT_MASK_HI2Q_HOST_IDX)
#define BIT_SET_HI2Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI2Q_HOST_IDX(x) | BIT_HI2Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI2Q_TXBD_IDX (Offset 0x03C0) */
#define BIT_SHIFT_P0HI2Q_HOST_IDX 0
#define BIT_MASK_P0HI2Q_HOST_IDX 0xfff
#define BIT_P0HI2Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI2Q_HOST_IDX) << BIT_SHIFT_P0HI2Q_HOST_IDX)
#define BITS_P0HI2Q_HOST_IDX \
(BIT_MASK_P0HI2Q_HOST_IDX << BIT_SHIFT_P0HI2Q_HOST_IDX)
#define BIT_CLEAR_P0HI2Q_HOST_IDX(x) ((x) & (~BITS_P0HI2Q_HOST_IDX))
#define BIT_GET_P0HI2Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI2Q_HOST_IDX) & BIT_MASK_P0HI2Q_HOST_IDX)
#define BIT_SET_P0HI2Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI2Q_HOST_IDX(x) | BIT_P0HI2Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI3Q_TXBD_IDX (Offset 0x03C4) */
#define BIT_SHIFT_HI3Q_HW_IDX 16
#define BIT_MASK_HI3Q_HW_IDX 0xfff
#define BIT_HI3Q_HW_IDX(x) \
(((x) & BIT_MASK_HI3Q_HW_IDX) << BIT_SHIFT_HI3Q_HW_IDX)
#define BITS_HI3Q_HW_IDX (BIT_MASK_HI3Q_HW_IDX << BIT_SHIFT_HI3Q_HW_IDX)
#define BIT_CLEAR_HI3Q_HW_IDX(x) ((x) & (~BITS_HI3Q_HW_IDX))
#define BIT_GET_HI3Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI3Q_HW_IDX) & BIT_MASK_HI3Q_HW_IDX)
#define BIT_SET_HI3Q_HW_IDX(x, v) \
(BIT_CLEAR_HI3Q_HW_IDX(x) | BIT_HI3Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI3Q_TXBD_IDX (Offset 0x03C4) */
#define BIT_SHIFT_P0HI3Q_HW_IDX 16
#define BIT_MASK_P0HI3Q_HW_IDX 0xfff
#define BIT_P0HI3Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI3Q_HW_IDX) << BIT_SHIFT_P0HI3Q_HW_IDX)
#define BITS_P0HI3Q_HW_IDX (BIT_MASK_P0HI3Q_HW_IDX << BIT_SHIFT_P0HI3Q_HW_IDX)
#define BIT_CLEAR_P0HI3Q_HW_IDX(x) ((x) & (~BITS_P0HI3Q_HW_IDX))
#define BIT_GET_P0HI3Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI3Q_HW_IDX) & BIT_MASK_P0HI3Q_HW_IDX)
#define BIT_SET_P0HI3Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI3Q_HW_IDX(x) | BIT_P0HI3Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI3Q_TXBD_IDX (Offset 0x03C4) */
#define BIT_SHIFT_HI3Q_HOST_IDX 0
#define BIT_MASK_HI3Q_HOST_IDX 0xfff
#define BIT_HI3Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI3Q_HOST_IDX) << BIT_SHIFT_HI3Q_HOST_IDX)
#define BITS_HI3Q_HOST_IDX (BIT_MASK_HI3Q_HOST_IDX << BIT_SHIFT_HI3Q_HOST_IDX)
#define BIT_CLEAR_HI3Q_HOST_IDX(x) ((x) & (~BITS_HI3Q_HOST_IDX))
#define BIT_GET_HI3Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI3Q_HOST_IDX) & BIT_MASK_HI3Q_HOST_IDX)
#define BIT_SET_HI3Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI3Q_HOST_IDX(x) | BIT_HI3Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI3Q_TXBD_IDX (Offset 0x03C4) */
#define BIT_SHIFT_P0HI3Q_HOST_IDX 0
#define BIT_MASK_P0HI3Q_HOST_IDX 0xfff
#define BIT_P0HI3Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI3Q_HOST_IDX) << BIT_SHIFT_P0HI3Q_HOST_IDX)
#define BITS_P0HI3Q_HOST_IDX \
(BIT_MASK_P0HI3Q_HOST_IDX << BIT_SHIFT_P0HI3Q_HOST_IDX)
#define BIT_CLEAR_P0HI3Q_HOST_IDX(x) ((x) & (~BITS_P0HI3Q_HOST_IDX))
#define BIT_GET_P0HI3Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI3Q_HOST_IDX) & BIT_MASK_P0HI3Q_HOST_IDX)
#define BIT_SET_P0HI3Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI3Q_HOST_IDX(x) | BIT_P0HI3Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI4Q_TXBD_IDX (Offset 0x03C8) */
#define BIT_SHIFT_HI4Q_HW_IDX 16
#define BIT_MASK_HI4Q_HW_IDX 0xfff
#define BIT_HI4Q_HW_IDX(x) \
(((x) & BIT_MASK_HI4Q_HW_IDX) << BIT_SHIFT_HI4Q_HW_IDX)
#define BITS_HI4Q_HW_IDX (BIT_MASK_HI4Q_HW_IDX << BIT_SHIFT_HI4Q_HW_IDX)
#define BIT_CLEAR_HI4Q_HW_IDX(x) ((x) & (~BITS_HI4Q_HW_IDX))
#define BIT_GET_HI4Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI4Q_HW_IDX) & BIT_MASK_HI4Q_HW_IDX)
#define BIT_SET_HI4Q_HW_IDX(x, v) \
(BIT_CLEAR_HI4Q_HW_IDX(x) | BIT_HI4Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI4Q_TXBD_IDX (Offset 0x03C8) */
#define BIT_SHIFT_P0HI4Q_HW_IDX 16
#define BIT_MASK_P0HI4Q_HW_IDX 0xfff
#define BIT_P0HI4Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI4Q_HW_IDX) << BIT_SHIFT_P0HI4Q_HW_IDX)
#define BITS_P0HI4Q_HW_IDX (BIT_MASK_P0HI4Q_HW_IDX << BIT_SHIFT_P0HI4Q_HW_IDX)
#define BIT_CLEAR_P0HI4Q_HW_IDX(x) ((x) & (~BITS_P0HI4Q_HW_IDX))
#define BIT_GET_P0HI4Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI4Q_HW_IDX) & BIT_MASK_P0HI4Q_HW_IDX)
#define BIT_SET_P0HI4Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI4Q_HW_IDX(x) | BIT_P0HI4Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI4Q_TXBD_IDX (Offset 0x03C8) */
#define BIT_SHIFT_HI4Q_HOST_IDX 0
#define BIT_MASK_HI4Q_HOST_IDX 0xfff
#define BIT_HI4Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI4Q_HOST_IDX) << BIT_SHIFT_HI4Q_HOST_IDX)
#define BITS_HI4Q_HOST_IDX (BIT_MASK_HI4Q_HOST_IDX << BIT_SHIFT_HI4Q_HOST_IDX)
#define BIT_CLEAR_HI4Q_HOST_IDX(x) ((x) & (~BITS_HI4Q_HOST_IDX))
#define BIT_GET_HI4Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI4Q_HOST_IDX) & BIT_MASK_HI4Q_HOST_IDX)
#define BIT_SET_HI4Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI4Q_HOST_IDX(x) | BIT_HI4Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI4Q_TXBD_IDX (Offset 0x03C8) */
#define BIT_SHIFT_P0HI4Q_HOST_IDX 0
#define BIT_MASK_P0HI4Q_HOST_IDX 0xfff
#define BIT_P0HI4Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI4Q_HOST_IDX) << BIT_SHIFT_P0HI4Q_HOST_IDX)
#define BITS_P0HI4Q_HOST_IDX \
(BIT_MASK_P0HI4Q_HOST_IDX << BIT_SHIFT_P0HI4Q_HOST_IDX)
#define BIT_CLEAR_P0HI4Q_HOST_IDX(x) ((x) & (~BITS_P0HI4Q_HOST_IDX))
#define BIT_GET_P0HI4Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI4Q_HOST_IDX) & BIT_MASK_P0HI4Q_HOST_IDX)
#define BIT_SET_P0HI4Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI4Q_HOST_IDX(x) | BIT_P0HI4Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI5Q_TXBD_IDX (Offset 0x03CC) */
#define BIT_SHIFT_HI5Q_HW_IDX 16
#define BIT_MASK_HI5Q_HW_IDX 0xfff
#define BIT_HI5Q_HW_IDX(x) \
(((x) & BIT_MASK_HI5Q_HW_IDX) << BIT_SHIFT_HI5Q_HW_IDX)
#define BITS_HI5Q_HW_IDX (BIT_MASK_HI5Q_HW_IDX << BIT_SHIFT_HI5Q_HW_IDX)
#define BIT_CLEAR_HI5Q_HW_IDX(x) ((x) & (~BITS_HI5Q_HW_IDX))
#define BIT_GET_HI5Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI5Q_HW_IDX) & BIT_MASK_HI5Q_HW_IDX)
#define BIT_SET_HI5Q_HW_IDX(x, v) \
(BIT_CLEAR_HI5Q_HW_IDX(x) | BIT_HI5Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI5Q_TXBD_IDX (Offset 0x03CC) */
#define BIT_SHIFT_P0HI5Q_HW_IDX 16
#define BIT_MASK_P0HI5Q_HW_IDX 0xfff
#define BIT_P0HI5Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI5Q_HW_IDX) << BIT_SHIFT_P0HI5Q_HW_IDX)
#define BITS_P0HI5Q_HW_IDX (BIT_MASK_P0HI5Q_HW_IDX << BIT_SHIFT_P0HI5Q_HW_IDX)
#define BIT_CLEAR_P0HI5Q_HW_IDX(x) ((x) & (~BITS_P0HI5Q_HW_IDX))
#define BIT_GET_P0HI5Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI5Q_HW_IDX) & BIT_MASK_P0HI5Q_HW_IDX)
#define BIT_SET_P0HI5Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI5Q_HW_IDX(x) | BIT_P0HI5Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI5Q_TXBD_IDX (Offset 0x03CC) */
#define BIT_SHIFT_HI5Q_HOST_IDX 0
#define BIT_MASK_HI5Q_HOST_IDX 0xfff
#define BIT_HI5Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI5Q_HOST_IDX) << BIT_SHIFT_HI5Q_HOST_IDX)
#define BITS_HI5Q_HOST_IDX (BIT_MASK_HI5Q_HOST_IDX << BIT_SHIFT_HI5Q_HOST_IDX)
#define BIT_CLEAR_HI5Q_HOST_IDX(x) ((x) & (~BITS_HI5Q_HOST_IDX))
#define BIT_GET_HI5Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI5Q_HOST_IDX) & BIT_MASK_HI5Q_HOST_IDX)
#define BIT_SET_HI5Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI5Q_HOST_IDX(x) | BIT_HI5Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI5Q_TXBD_IDX (Offset 0x03CC) */
#define BIT_SHIFT_P0HI5Q_HOST_IDX 0
#define BIT_MASK_P0HI5Q_HOST_IDX 0xfff
#define BIT_P0HI5Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI5Q_HOST_IDX) << BIT_SHIFT_P0HI5Q_HOST_IDX)
#define BITS_P0HI5Q_HOST_IDX \
(BIT_MASK_P0HI5Q_HOST_IDX << BIT_SHIFT_P0HI5Q_HOST_IDX)
#define BIT_CLEAR_P0HI5Q_HOST_IDX(x) ((x) & (~BITS_P0HI5Q_HOST_IDX))
#define BIT_GET_P0HI5Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI5Q_HOST_IDX) & BIT_MASK_P0HI5Q_HOST_IDX)
#define BIT_SET_P0HI5Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI5Q_HOST_IDX(x) | BIT_P0HI5Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI6Q_TXBD_IDX (Offset 0x03D0) */
#define BIT_SHIFT_HI6Q_HW_IDX 16
#define BIT_MASK_HI6Q_HW_IDX 0xfff
#define BIT_HI6Q_HW_IDX(x) \
(((x) & BIT_MASK_HI6Q_HW_IDX) << BIT_SHIFT_HI6Q_HW_IDX)
#define BITS_HI6Q_HW_IDX (BIT_MASK_HI6Q_HW_IDX << BIT_SHIFT_HI6Q_HW_IDX)
#define BIT_CLEAR_HI6Q_HW_IDX(x) ((x) & (~BITS_HI6Q_HW_IDX))
#define BIT_GET_HI6Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI6Q_HW_IDX) & BIT_MASK_HI6Q_HW_IDX)
#define BIT_SET_HI6Q_HW_IDX(x, v) \
(BIT_CLEAR_HI6Q_HW_IDX(x) | BIT_HI6Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI6Q_TXBD_IDX (Offset 0x03D0) */
#define BIT_SHIFT_P0HI6Q_HW_IDX 16
#define BIT_MASK_P0HI6Q_HW_IDX 0xfff
#define BIT_P0HI6Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI6Q_HW_IDX) << BIT_SHIFT_P0HI6Q_HW_IDX)
#define BITS_P0HI6Q_HW_IDX (BIT_MASK_P0HI6Q_HW_IDX << BIT_SHIFT_P0HI6Q_HW_IDX)
#define BIT_CLEAR_P0HI6Q_HW_IDX(x) ((x) & (~BITS_P0HI6Q_HW_IDX))
#define BIT_GET_P0HI6Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI6Q_HW_IDX) & BIT_MASK_P0HI6Q_HW_IDX)
#define BIT_SET_P0HI6Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI6Q_HW_IDX(x) | BIT_P0HI6Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI6Q_TXBD_IDX (Offset 0x03D0) */
#define BIT_SHIFT_HI6Q_HOST_IDX 0
#define BIT_MASK_HI6Q_HOST_IDX 0xfff
#define BIT_HI6Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI6Q_HOST_IDX) << BIT_SHIFT_HI6Q_HOST_IDX)
#define BITS_HI6Q_HOST_IDX (BIT_MASK_HI6Q_HOST_IDX << BIT_SHIFT_HI6Q_HOST_IDX)
#define BIT_CLEAR_HI6Q_HOST_IDX(x) ((x) & (~BITS_HI6Q_HOST_IDX))
#define BIT_GET_HI6Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI6Q_HOST_IDX) & BIT_MASK_HI6Q_HOST_IDX)
#define BIT_SET_HI6Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI6Q_HOST_IDX(x) | BIT_HI6Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI6Q_TXBD_IDX (Offset 0x03D0) */
#define BIT_SHIFT_P0HI6Q_HOST_IDX 0
#define BIT_MASK_P0HI6Q_HOST_IDX 0xfff
#define BIT_P0HI6Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI6Q_HOST_IDX) << BIT_SHIFT_P0HI6Q_HOST_IDX)
#define BITS_P0HI6Q_HOST_IDX \
(BIT_MASK_P0HI6Q_HOST_IDX << BIT_SHIFT_P0HI6Q_HOST_IDX)
#define BIT_CLEAR_P0HI6Q_HOST_IDX(x) ((x) & (~BITS_P0HI6Q_HOST_IDX))
#define BIT_GET_P0HI6Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI6Q_HOST_IDX) & BIT_MASK_P0HI6Q_HOST_IDX)
#define BIT_SET_P0HI6Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI6Q_HOST_IDX(x) | BIT_P0HI6Q_HOST_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI7Q_TXBD_IDX (Offset 0x03D4) */
#define BIT_SHIFT_HI7Q_HW_IDX 16
#define BIT_MASK_HI7Q_HW_IDX 0xfff
#define BIT_HI7Q_HW_IDX(x) \
(((x) & BIT_MASK_HI7Q_HW_IDX) << BIT_SHIFT_HI7Q_HW_IDX)
#define BITS_HI7Q_HW_IDX (BIT_MASK_HI7Q_HW_IDX << BIT_SHIFT_HI7Q_HW_IDX)
#define BIT_CLEAR_HI7Q_HW_IDX(x) ((x) & (~BITS_HI7Q_HW_IDX))
#define BIT_GET_HI7Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI7Q_HW_IDX) & BIT_MASK_HI7Q_HW_IDX)
#define BIT_SET_HI7Q_HW_IDX(x, v) \
(BIT_CLEAR_HI7Q_HW_IDX(x) | BIT_HI7Q_HW_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI7Q_TXBD_IDX (Offset 0x03D4) */
#define BIT_SHIFT_P0HI7Q_HW_IDX 16
#define BIT_MASK_P0HI7Q_HW_IDX 0xfff
#define BIT_P0HI7Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI7Q_HW_IDX) << BIT_SHIFT_P0HI7Q_HW_IDX)
#define BITS_P0HI7Q_HW_IDX (BIT_MASK_P0HI7Q_HW_IDX << BIT_SHIFT_P0HI7Q_HW_IDX)
#define BIT_CLEAR_P0HI7Q_HW_IDX(x) ((x) & (~BITS_P0HI7Q_HW_IDX))
#define BIT_GET_P0HI7Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI7Q_HW_IDX) & BIT_MASK_P0HI7Q_HW_IDX)
#define BIT_SET_P0HI7Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI7Q_HW_IDX(x) | BIT_P0HI7Q_HW_IDX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HI7Q_TXBD_IDX (Offset 0x03D4) */
#define BIT_SHIFT_HI7Q_HOST_IDX 0
#define BIT_MASK_HI7Q_HOST_IDX 0xfff
#define BIT_HI7Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI7Q_HOST_IDX) << BIT_SHIFT_HI7Q_HOST_IDX)
#define BITS_HI7Q_HOST_IDX (BIT_MASK_HI7Q_HOST_IDX << BIT_SHIFT_HI7Q_HOST_IDX)
#define BIT_CLEAR_HI7Q_HOST_IDX(x) ((x) & (~BITS_HI7Q_HOST_IDX))
#define BIT_GET_HI7Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI7Q_HOST_IDX) & BIT_MASK_HI7Q_HOST_IDX)
#define BIT_SET_HI7Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI7Q_HOST_IDX(x) | BIT_HI7Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI7Q_TXBD_IDX (Offset 0x03D4) */
#define BIT_SHIFT_P0HI7Q_HOST_IDX 0
#define BIT_MASK_P0HI7Q_HOST_IDX 0xfff
#define BIT_P0HI7Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI7Q_HOST_IDX) << BIT_SHIFT_P0HI7Q_HOST_IDX)
#define BITS_P0HI7Q_HOST_IDX \
(BIT_MASK_P0HI7Q_HOST_IDX << BIT_SHIFT_P0HI7Q_HOST_IDX)
#define BIT_CLEAR_P0HI7Q_HOST_IDX(x) ((x) & (~BITS_P0HI7Q_HOST_IDX))
#define BIT_GET_P0HI7Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI7Q_HOST_IDX) & BIT_MASK_P0HI7Q_HOST_IDX)
#define BIT_SET_P0HI7Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI7Q_HOST_IDX(x) | BIT_P0HI7Q_HOST_IDX(v))
/* 2 REG_DBGSEL_PCIE_HRPWM1_HCPWM1_V1 (Offset 0x03D8) */
#define BIT_DIS_TXDMA_PRE_V1 BIT(31)
#define BIT_DIS_RXDMA_PRE_V1 BIT(30)
#define BIT_SHIFT_HPS_CLKR_PCIE_V1 28
#define BIT_MASK_HPS_CLKR_PCIE_V1 0x3
#define BIT_HPS_CLKR_PCIE_V1(x) \
(((x) & BIT_MASK_HPS_CLKR_PCIE_V1) << BIT_SHIFT_HPS_CLKR_PCIE_V1)
#define BITS_HPS_CLKR_PCIE_V1 \
(BIT_MASK_HPS_CLKR_PCIE_V1 << BIT_SHIFT_HPS_CLKR_PCIE_V1)
#define BIT_CLEAR_HPS_CLKR_PCIE_V1(x) ((x) & (~BITS_HPS_CLKR_PCIE_V1))
#define BIT_GET_HPS_CLKR_PCIE_V1(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_PCIE_V1) & BIT_MASK_HPS_CLKR_PCIE_V1)
#define BIT_SET_HPS_CLKR_PCIE_V1(x, v) \
(BIT_CLEAR_HPS_CLKR_PCIE_V1(x) | BIT_HPS_CLKR_PCIE_V1(v))
#define BIT_PCIE_INT_V1 BIT(27)
#define BIT_TXFLAG_EXIT_L1_EN_V1 BIT(26)
#define BIT_EN_RXDMA_ALIGN_V2 BIT(25)
#define BIT_EN_TXDMA_ALIGN_V2 BIT(24)
#define BIT_SHIFT_PCIE_HCPWM_V1 16
#define BIT_MASK_PCIE_HCPWM_V1 0xff
#define BIT_PCIE_HCPWM_V1(x) \
(((x) & BIT_MASK_PCIE_HCPWM_V1) << BIT_SHIFT_PCIE_HCPWM_V1)
#define BITS_PCIE_HCPWM_V1 (BIT_MASK_PCIE_HCPWM_V1 << BIT_SHIFT_PCIE_HCPWM_V1)
#define BIT_CLEAR_PCIE_HCPWM_V1(x) ((x) & (~BITS_PCIE_HCPWM_V1))
#define BIT_GET_PCIE_HCPWM_V1(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM_V1) & BIT_MASK_PCIE_HCPWM_V1)
#define BIT_SET_PCIE_HCPWM_V1(x, v) \
(BIT_CLEAR_PCIE_HCPWM_V1(x) | BIT_PCIE_HCPWM_V1(v))
#define BIT_SHIFT_PCIE_HRPWM_V1 8
#define BIT_MASK_PCIE_HRPWM_V1 0xff
#define BIT_PCIE_HRPWM_V1(x) \
(((x) & BIT_MASK_PCIE_HRPWM_V1) << BIT_SHIFT_PCIE_HRPWM_V1)
#define BITS_PCIE_HRPWM_V1 (BIT_MASK_PCIE_HRPWM_V1 << BIT_SHIFT_PCIE_HRPWM_V1)
#define BIT_CLEAR_PCIE_HRPWM_V1(x) ((x) & (~BITS_PCIE_HRPWM_V1))
#define BIT_GET_PCIE_HRPWM_V1(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM_V1) & BIT_MASK_PCIE_HRPWM_V1)
#define BIT_SET_PCIE_HRPWM_V1(x, v) \
(BIT_CLEAR_PCIE_HRPWM_V1(x) | BIT_PCIE_HRPWM_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DBG_SEL_V1 (Offset 0x03D8) */
#define BIT_SHIFT_DBG_SEL 0
#define BIT_MASK_DBG_SEL 0xff
#define BIT_DBG_SEL(x) (((x) & BIT_MASK_DBG_SEL) << BIT_SHIFT_DBG_SEL)
#define BITS_DBG_SEL (BIT_MASK_DBG_SEL << BIT_SHIFT_DBG_SEL)
#define BIT_CLEAR_DBG_SEL(x) ((x) & (~BITS_DBG_SEL))
#define BIT_GET_DBG_SEL(x) (((x) >> BIT_SHIFT_DBG_SEL) & BIT_MASK_DBG_SEL)
#define BIT_SET_DBG_SEL(x, v) (BIT_CLEAR_DBG_SEL(x) | BIT_DBG_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_HRPWM1_V1 (Offset 0x03D9) */
#define BIT_SHIFT_PCIE_HRPWM 0
#define BIT_MASK_PCIE_HRPWM 0xff
#define BIT_PCIE_HRPWM(x) (((x) & BIT_MASK_PCIE_HRPWM) << BIT_SHIFT_PCIE_HRPWM)
#define BITS_PCIE_HRPWM (BIT_MASK_PCIE_HRPWM << BIT_SHIFT_PCIE_HRPWM)
#define BIT_CLEAR_PCIE_HRPWM(x) ((x) & (~BITS_PCIE_HRPWM))
#define BIT_GET_PCIE_HRPWM(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM) & BIT_MASK_PCIE_HRPWM)
#define BIT_SET_PCIE_HRPWM(x, v) (BIT_CLEAR_PCIE_HRPWM(x) | BIT_PCIE_HRPWM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_HRPWM1_V1 (Offset 0x03D9) */
#define BIT_SHIFT_HCI_HRPWM 0
#define BIT_MASK_HCI_HRPWM 0xff
#define BIT_HCI_HRPWM(x) (((x) & BIT_MASK_HCI_HRPWM) << BIT_SHIFT_HCI_HRPWM)
#define BITS_HCI_HRPWM (BIT_MASK_HCI_HRPWM << BIT_SHIFT_HCI_HRPWM)
#define BIT_CLEAR_HCI_HRPWM(x) ((x) & (~BITS_HCI_HRPWM))
#define BIT_GET_HCI_HRPWM(x) (((x) >> BIT_SHIFT_HCI_HRPWM) & BIT_MASK_HCI_HRPWM)
#define BIT_SET_HCI_HRPWM(x, v) (BIT_CLEAR_HCI_HRPWM(x) | BIT_HCI_HRPWM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_HCPWM1_V1 (Offset 0x03DA) */
#define BIT_SHIFT_PCIE_HCPWM 0
#define BIT_MASK_PCIE_HCPWM 0xff
#define BIT_PCIE_HCPWM(x) (((x) & BIT_MASK_PCIE_HCPWM) << BIT_SHIFT_PCIE_HCPWM)
#define BITS_PCIE_HCPWM (BIT_MASK_PCIE_HCPWM << BIT_SHIFT_PCIE_HCPWM)
#define BIT_CLEAR_PCIE_HCPWM(x) ((x) & (~BITS_PCIE_HCPWM))
#define BIT_GET_PCIE_HCPWM(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM) & BIT_MASK_PCIE_HCPWM)
#define BIT_SET_PCIE_HCPWM(x, v) (BIT_CLEAR_PCIE_HCPWM(x) | BIT_PCIE_HCPWM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_HCPWM1_V1 (Offset 0x03DA) */
#define BIT_SHIFT_HCI_HCPWM 0
#define BIT_MASK_HCI_HCPWM 0xff
#define BIT_HCI_HCPWM(x) (((x) & BIT_MASK_HCI_HCPWM) << BIT_SHIFT_HCI_HCPWM)
#define BITS_HCI_HCPWM (BIT_MASK_HCI_HCPWM << BIT_SHIFT_HCI_HCPWM)
#define BIT_CLEAR_HCI_HCPWM(x) ((x) & (~BITS_HCI_HCPWM))
#define BIT_GET_HCI_HCPWM(x) (((x) >> BIT_SHIFT_HCI_HCPWM) & BIT_MASK_HCI_HCPWM)
#define BIT_SET_HCI_HCPWM(x, v) (BIT_CLEAR_HCI_HCPWM(x) | BIT_HCI_HCPWM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL2 (Offset 0x03DB) */
#define BIT_SHIFT_HPS_CLKR_PCIE 4
#define BIT_MASK_HPS_CLKR_PCIE 0x3
#define BIT_HPS_CLKR_PCIE(x) \
(((x) & BIT_MASK_HPS_CLKR_PCIE) << BIT_SHIFT_HPS_CLKR_PCIE)
#define BITS_HPS_CLKR_PCIE (BIT_MASK_HPS_CLKR_PCIE << BIT_SHIFT_HPS_CLKR_PCIE)
#define BIT_CLEAR_HPS_CLKR_PCIE(x) ((x) & (~BITS_HPS_CLKR_PCIE))
#define BIT_GET_HPS_CLKR_PCIE(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_PCIE) & BIT_MASK_HPS_CLKR_PCIE)
#define BIT_SET_HPS_CLKR_PCIE(x, v) \
(BIT_CLEAR_HPS_CLKR_PCIE(x) | BIT_HPS_CLKR_PCIE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL2 (Offset 0x03DB) */
#define BIT_SHIFT_HPS_CLKR_HCI 4
#define BIT_MASK_HPS_CLKR_HCI 0x3
#define BIT_HPS_CLKR_HCI(x) \
(((x) & BIT_MASK_HPS_CLKR_HCI) << BIT_SHIFT_HPS_CLKR_HCI)
#define BITS_HPS_CLKR_HCI (BIT_MASK_HPS_CLKR_HCI << BIT_SHIFT_HPS_CLKR_HCI)
#define BIT_CLEAR_HPS_CLKR_HCI(x) ((x) & (~BITS_HPS_CLKR_HCI))
#define BIT_GET_HPS_CLKR_HCI(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_HCI) & BIT_MASK_HPS_CLKR_HCI)
#define BIT_SET_HPS_CLKR_HCI(x, v) \
(BIT_CLEAR_HPS_CLKR_HCI(x) | BIT_HPS_CLKR_HCI(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL2 (Offset 0x03DB) */
#define BIT_PCIE_INT BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_CTRL2 (Offset 0x03DB) */
#define BIT_HCI_INT BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_CTRL2 (Offset 0x03DB) */
#define BIT_EN_RXDMA_ALIGN BIT(1)
#define BIT_EN_TXDMA_ALIGN BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_HRPWM2_HCPWM2_V1 (Offset 0x03DC) */
#define BIT_SHIFT_PCIE_HCPWM2_V1 16
#define BIT_MASK_PCIE_HCPWM2_V1 0xffff
#define BIT_PCIE_HCPWM2_V1(x) \
(((x) & BIT_MASK_PCIE_HCPWM2_V1) << BIT_SHIFT_PCIE_HCPWM2_V1)
#define BITS_PCIE_HCPWM2_V1 \
(BIT_MASK_PCIE_HCPWM2_V1 << BIT_SHIFT_PCIE_HCPWM2_V1)
#define BIT_CLEAR_PCIE_HCPWM2_V1(x) ((x) & (~BITS_PCIE_HCPWM2_V1))
#define BIT_GET_PCIE_HCPWM2_V1(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM2_V1) & BIT_MASK_PCIE_HCPWM2_V1)
#define BIT_SET_PCIE_HCPWM2_V1(x, v) \
(BIT_CLEAR_PCIE_HCPWM2_V1(x) | BIT_PCIE_HCPWM2_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_HRPWM2_V1 (Offset 0x03DC) */
#define BIT_SHIFT_PCIE_HRPWM2 0
#define BIT_MASK_PCIE_HRPWM2 0xffff
#define BIT_PCIE_HRPWM2(x) \
(((x) & BIT_MASK_PCIE_HRPWM2) << BIT_SHIFT_PCIE_HRPWM2)
#define BITS_PCIE_HRPWM2 (BIT_MASK_PCIE_HRPWM2 << BIT_SHIFT_PCIE_HRPWM2)
#define BIT_CLEAR_PCIE_HRPWM2(x) ((x) & (~BITS_PCIE_HRPWM2))
#define BIT_GET_PCIE_HRPWM2(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM2) & BIT_MASK_PCIE_HRPWM2)
#define BIT_SET_PCIE_HRPWM2(x, v) \
(BIT_CLEAR_PCIE_HRPWM2(x) | BIT_PCIE_HRPWM2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_HRPWM2_V1 (Offset 0x03DC) */
#define BIT_SHIFT_HCI_HRPWM2 0
#define BIT_MASK_HCI_HRPWM2 0xffff
#define BIT_HCI_HRPWM2(x) (((x) & BIT_MASK_HCI_HRPWM2) << BIT_SHIFT_HCI_HRPWM2)
#define BITS_HCI_HRPWM2 (BIT_MASK_HCI_HRPWM2 << BIT_SHIFT_HCI_HRPWM2)
#define BIT_CLEAR_HCI_HRPWM2(x) ((x) & (~BITS_HCI_HRPWM2))
#define BIT_GET_HCI_HRPWM2(x) \
(((x) >> BIT_SHIFT_HCI_HRPWM2) & BIT_MASK_HCI_HRPWM2)
#define BIT_SET_HCI_HRPWM2(x, v) (BIT_CLEAR_HCI_HRPWM2(x) | BIT_HCI_HRPWM2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_HCPWM2_V1 (Offset 0x03DE) */
#define BIT_SHIFT_PCIE_HCPWM2 0
#define BIT_MASK_PCIE_HCPWM2 0xffff
#define BIT_PCIE_HCPWM2(x) \
(((x) & BIT_MASK_PCIE_HCPWM2) << BIT_SHIFT_PCIE_HCPWM2)
#define BITS_PCIE_HCPWM2 (BIT_MASK_PCIE_HCPWM2 << BIT_SHIFT_PCIE_HCPWM2)
#define BIT_CLEAR_PCIE_HCPWM2(x) ((x) & (~BITS_PCIE_HCPWM2))
#define BIT_GET_PCIE_HCPWM2(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM2) & BIT_MASK_PCIE_HCPWM2)
#define BIT_SET_PCIE_HCPWM2(x, v) \
(BIT_CLEAR_PCIE_HCPWM2(x) | BIT_PCIE_HCPWM2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_HCPWM2_V1 (Offset 0x03DE) */
#define BIT_SHIFT_HCI_HCPWM2 0
#define BIT_MASK_HCI_HCPWM2 0xffff
#define BIT_HCI_HCPWM2(x) (((x) & BIT_MASK_HCI_HCPWM2) << BIT_SHIFT_HCI_HCPWM2)
#define BITS_HCI_HCPWM2 (BIT_MASK_HCI_HCPWM2 << BIT_SHIFT_HCI_HCPWM2)
#define BIT_CLEAR_HCI_HCPWM2(x) ((x) & (~BITS_HCI_HCPWM2))
#define BIT_GET_HCI_HCPWM2(x) \
(((x) >> BIT_SHIFT_HCI_HCPWM2) & BIT_MASK_HCI_HCPWM2)
#define BIT_SET_HCI_HCPWM2(x, v) (BIT_CLEAR_HCI_HCPWM2(x) | BIT_HCI_HCPWM2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_H2C_MSG_V1 (Offset 0x03E0) */
#define BIT_AC7Q_EMPTY BIT(7)
#define BIT_AC6Q_EMPTY BIT(6)
#define BIT_AC5Q_EMPTY BIT(5)
#define BIT_AC4Q_EMPTY BIT(4)
#define BIT_AC3Q_EMPTY BIT(3)
#define BIT_AC2Q_EMPTY BIT(2)
#define BIT_AC1Q_EMPTY BIT(1)
#define BIT_SHIFT_DRV2FW_INFO 0
#define BIT_MASK_DRV2FW_INFO 0xffffffffL
#define BIT_DRV2FW_INFO(x) \
(((x) & BIT_MASK_DRV2FW_INFO) << BIT_SHIFT_DRV2FW_INFO)
#define BITS_DRV2FW_INFO (BIT_MASK_DRV2FW_INFO << BIT_SHIFT_DRV2FW_INFO)
#define BIT_CLEAR_DRV2FW_INFO(x) ((x) & (~BITS_DRV2FW_INFO))
#define BIT_GET_DRV2FW_INFO(x) \
(((x) >> BIT_SHIFT_DRV2FW_INFO) & BIT_MASK_DRV2FW_INFO)
#define BIT_SET_DRV2FW_INFO(x, v) \
(BIT_CLEAR_DRV2FW_INFO(x) | BIT_DRV2FW_INFO(v))
#define BIT_AC0Q_EMPTY BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PCIE_C2H_MSG_V1 (Offset 0x03E4) */
#define BIT_SHIFT_HCI_PCIE_C2H_MSG 0
#define BIT_MASK_HCI_PCIE_C2H_MSG 0xffffffffL
#define BIT_HCI_PCIE_C2H_MSG(x) \
(((x) & BIT_MASK_HCI_PCIE_C2H_MSG) << BIT_SHIFT_HCI_PCIE_C2H_MSG)
#define BITS_HCI_PCIE_C2H_MSG \
(BIT_MASK_HCI_PCIE_C2H_MSG << BIT_SHIFT_HCI_PCIE_C2H_MSG)
#define BIT_CLEAR_HCI_PCIE_C2H_MSG(x) ((x) & (~BITS_HCI_PCIE_C2H_MSG))
#define BIT_GET_HCI_PCIE_C2H_MSG(x) \
(((x) >> BIT_SHIFT_HCI_PCIE_C2H_MSG) & BIT_MASK_HCI_PCIE_C2H_MSG)
#define BIT_SET_HCI_PCIE_C2H_MSG(x, v) \
(BIT_CLEAR_HCI_PCIE_C2H_MSG(x) | BIT_HCI_PCIE_C2H_MSG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_C2H_MSG_V1 (Offset 0x03E4) */
#define BIT_SHIFT_HCI_C2H_MSG 0
#define BIT_MASK_HCI_C2H_MSG 0xffffffffL
#define BIT_HCI_C2H_MSG(x) \
(((x) & BIT_MASK_HCI_C2H_MSG) << BIT_SHIFT_HCI_C2H_MSG)
#define BITS_HCI_C2H_MSG (BIT_MASK_HCI_C2H_MSG << BIT_SHIFT_HCI_C2H_MSG)
#define BIT_CLEAR_HCI_C2H_MSG(x) ((x) & (~BITS_HCI_C2H_MSG))
#define BIT_GET_HCI_C2H_MSG(x) \
(((x) >> BIT_SHIFT_HCI_C2H_MSG) & BIT_MASK_HCI_C2H_MSG)
#define BIT_SET_HCI_C2H_MSG(x, v) \
(BIT_CLEAR_HCI_C2H_MSG(x) | BIT_HCI_C2H_MSG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DBI_WDATA_V1 (Offset 0x03E8) */
#define BIT_SHIFT_DBI_WDATA 0
#define BIT_MASK_DBI_WDATA 0xffffffffL
#define BIT_DBI_WDATA(x) (((x) & BIT_MASK_DBI_WDATA) << BIT_SHIFT_DBI_WDATA)
#define BITS_DBI_WDATA (BIT_MASK_DBI_WDATA << BIT_SHIFT_DBI_WDATA)
#define BIT_CLEAR_DBI_WDATA(x) ((x) & (~BITS_DBI_WDATA))
#define BIT_GET_DBI_WDATA(x) (((x) >> BIT_SHIFT_DBI_WDATA) & BIT_MASK_DBI_WDATA)
#define BIT_SET_DBI_WDATA(x, v) (BIT_CLEAR_DBI_WDATA(x) | BIT_DBI_WDATA(v))
/* 2 REG_DBI_RDATA_V1 (Offset 0x03EC) */
#define BIT_SHIFT_DBI_RDATA 0
#define BIT_MASK_DBI_RDATA 0xffffffffL
#define BIT_DBI_RDATA(x) (((x) & BIT_MASK_DBI_RDATA) << BIT_SHIFT_DBI_RDATA)
#define BITS_DBI_RDATA (BIT_MASK_DBI_RDATA << BIT_SHIFT_DBI_RDATA)
#define BIT_CLEAR_DBI_RDATA(x) ((x) & (~BITS_DBI_RDATA))
#define BIT_GET_DBI_RDATA(x) (((x) >> BIT_SHIFT_DBI_RDATA) & BIT_MASK_DBI_RDATA)
#define BIT_SET_DBI_RDATA(x, v) (BIT_CLEAR_DBI_RDATA(x) | BIT_DBI_RDATA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DBI_FLAG_V1 (Offset 0x03F0) */
#define BIT_SHIFT_LOOPBACK_DBG_SEL 28
#define BIT_MASK_LOOPBACK_DBG_SEL 0xf
#define BIT_LOOPBACK_DBG_SEL(x) \
(((x) & BIT_MASK_LOOPBACK_DBG_SEL) << BIT_SHIFT_LOOPBACK_DBG_SEL)
#define BITS_LOOPBACK_DBG_SEL \
(BIT_MASK_LOOPBACK_DBG_SEL << BIT_SHIFT_LOOPBACK_DBG_SEL)
#define BIT_CLEAR_LOOPBACK_DBG_SEL(x) ((x) & (~BITS_LOOPBACK_DBG_SEL))
#define BIT_GET_LOOPBACK_DBG_SEL(x) \
(((x) >> BIT_SHIFT_LOOPBACK_DBG_SEL) & BIT_MASK_LOOPBACK_DBG_SEL)
#define BIT_SET_LOOPBACK_DBG_SEL(x, v) \
(BIT_CLEAR_LOOPBACK_DBG_SEL(x) | BIT_LOOPBACK_DBG_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_STUCK_FLAG_V1 (Offset 0x03F0) */
#define BIT_EN_STUCK_DBG BIT(26)
#define BIT_RX_STUCK BIT(25)
#define BIT_TX_STUCK BIT(24)
#define BIT_DBI_RFLAG BIT(17)
#define BIT_DBI_WFLAG BIT(16)
#define BIT_SHIFT_DBI_WREN 12
#define BIT_MASK_DBI_WREN 0xf
#define BIT_DBI_WREN(x) (((x) & BIT_MASK_DBI_WREN) << BIT_SHIFT_DBI_WREN)
#define BITS_DBI_WREN (BIT_MASK_DBI_WREN << BIT_SHIFT_DBI_WREN)
#define BIT_CLEAR_DBI_WREN(x) ((x) & (~BITS_DBI_WREN))
#define BIT_GET_DBI_WREN(x) (((x) >> BIT_SHIFT_DBI_WREN) & BIT_MASK_DBI_WREN)
#define BIT_SET_DBI_WREN(x, v) (BIT_CLEAR_DBI_WREN(x) | BIT_DBI_WREN(v))
#define BIT_SHIFT_DBI_ADDR 0
#define BIT_MASK_DBI_ADDR 0xfff
#define BIT_DBI_ADDR(x) (((x) & BIT_MASK_DBI_ADDR) << BIT_SHIFT_DBI_ADDR)
#define BITS_DBI_ADDR (BIT_MASK_DBI_ADDR << BIT_SHIFT_DBI_ADDR)
#define BIT_CLEAR_DBI_ADDR(x) ((x) & (~BITS_DBI_ADDR))
#define BIT_GET_DBI_ADDR(x) (((x) >> BIT_SHIFT_DBI_ADDR) & BIT_MASK_DBI_ADDR)
#define BIT_SET_DBI_ADDR(x, v) (BIT_CLEAR_DBI_ADDR(x) | BIT_DBI_ADDR(v))
/* 2 REG_MDIO_V1 (Offset 0x03F4) */
#define BIT_SHIFT_MDIO_RDATA 16
#define BIT_MASK_MDIO_RDATA 0xffff
#define BIT_MDIO_RDATA(x) (((x) & BIT_MASK_MDIO_RDATA) << BIT_SHIFT_MDIO_RDATA)
#define BITS_MDIO_RDATA (BIT_MASK_MDIO_RDATA << BIT_SHIFT_MDIO_RDATA)
#define BIT_CLEAR_MDIO_RDATA(x) ((x) & (~BITS_MDIO_RDATA))
#define BIT_GET_MDIO_RDATA(x) \
(((x) >> BIT_SHIFT_MDIO_RDATA) & BIT_MASK_MDIO_RDATA)
#define BIT_SET_MDIO_RDATA(x, v) (BIT_CLEAR_MDIO_RDATA(x) | BIT_MDIO_RDATA(v))
#define BIT_SHIFT_MDIO_WDATA 0
#define BIT_MASK_MDIO_WDATA 0xffff
#define BIT_MDIO_WDATA(x) (((x) & BIT_MASK_MDIO_WDATA) << BIT_SHIFT_MDIO_WDATA)
#define BITS_MDIO_WDATA (BIT_MASK_MDIO_WDATA << BIT_SHIFT_MDIO_WDATA)
#define BIT_CLEAR_MDIO_WDATA(x) ((x) & (~BITS_MDIO_WDATA))
#define BIT_GET_MDIO_WDATA(x) \
(((x) >> BIT_SHIFT_MDIO_WDATA) & BIT_MASK_MDIO_WDATA)
#define BIT_SET_MDIO_WDATA(x, v) (BIT_CLEAR_MDIO_WDATA(x) | BIT_MDIO_WDATA(v))
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_BUS_MIX_CFG (Offset 0x03F8) */
#define BIT_SHIFT_DELAY_TIME 24
#define BIT_MASK_DELAY_TIME 0xff
#define BIT_DELAY_TIME(x) (((x) & BIT_MASK_DELAY_TIME) << BIT_SHIFT_DELAY_TIME)
#define BITS_DELAY_TIME (BIT_MASK_DELAY_TIME << BIT_SHIFT_DELAY_TIME)
#define BIT_CLEAR_DELAY_TIME(x) ((x) & (~BITS_DELAY_TIME))
#define BIT_GET_DELAY_TIME(x) \
(((x) >> BIT_SHIFT_DELAY_TIME) & BIT_MASK_DELAY_TIME)
#define BIT_SET_DELAY_TIME(x, v) (BIT_CLEAR_DELAY_TIME(x) | BIT_DELAY_TIME(v))
#define BIT_RX_TIMER_DELAY_EN BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_MIX_CFG (Offset 0x03F8) */
#define BIT_EN_WATCH_DOG BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_MDIO2_V1 (Offset 0x03F8) */
#define BIT_ECRC_EN BIT(7)
#define BIT_MDIO_RFLAG BIT(6)
#define BIT_MDIO_WFLAG BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_MDIO2_V1 (Offset 0x03F8) */
#define BIT_SHIFT_MDIO_ADDR 0
#define BIT_MASK_MDIO_ADDR 0x1f
#define BIT_MDIO_ADDR(x) (((x) & BIT_MASK_MDIO_ADDR) << BIT_SHIFT_MDIO_ADDR)
#define BITS_MDIO_ADDR (BIT_MASK_MDIO_ADDR << BIT_SHIFT_MDIO_ADDR)
#define BIT_CLEAR_MDIO_ADDR(x) ((x) & (~BITS_MDIO_ADDR))
#define BIT_GET_MDIO_ADDR(x) (((x) >> BIT_SHIFT_MDIO_ADDR) & BIT_MASK_MDIO_ADDR)
#define BIT_SET_MDIO_ADDR(x, v) (BIT_CLEAR_MDIO_ADDR(x) | BIT_MDIO_ADDR(v))
#define BIT_SHIFT_TXFAIL_DROPCNT 0
#define BIT_MASK_TXFAIL_DROPCNT 0xffff
#define BIT_TXFAIL_DROPCNT(x) \
(((x) & BIT_MASK_TXFAIL_DROPCNT) << BIT_SHIFT_TXFAIL_DROPCNT)
#define BITS_TXFAIL_DROPCNT \
(BIT_MASK_TXFAIL_DROPCNT << BIT_SHIFT_TXFAIL_DROPCNT)
#define BIT_CLEAR_TXFAIL_DROPCNT(x) ((x) & (~BITS_TXFAIL_DROPCNT))
#define BIT_GET_TXFAIL_DROPCNT(x) \
(((x) >> BIT_SHIFT_TXFAIL_DROPCNT) & BIT_MASK_TXFAIL_DROPCNT)
#define BIT_SET_TXFAIL_DROPCNT(x, v) \
(BIT_CLEAR_TXFAIL_DROPCNT(x) | BIT_TXFAIL_DROPCNT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_MIX_CFG (Offset 0x03F8) */
#define BIT_SHIFT_MDIO_REG_ADDR_V1 0
#define BIT_MASK_MDIO_REG_ADDR_V1 0x1f
#define BIT_MDIO_REG_ADDR_V1(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR_V1) << BIT_SHIFT_MDIO_REG_ADDR_V1)
#define BITS_MDIO_REG_ADDR_V1 \
(BIT_MASK_MDIO_REG_ADDR_V1 << BIT_SHIFT_MDIO_REG_ADDR_V1)
#define BIT_CLEAR_MDIO_REG_ADDR_V1(x) ((x) & (~BITS_MDIO_REG_ADDR_V1))
#define BIT_GET_MDIO_REG_ADDR_V1(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR_V1) & BIT_MASK_MDIO_REG_ADDR_V1)
#define BIT_SET_MDIO_REG_ADDR_V1(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR_V1(x) | BIT_MDIO_REG_ADDR_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_RXRST_BACKDOOR BIT(31)
#define BIT_TXRST_BACKDOOR BIT(30)
#define BIT_RXIDX_RSTB BIT(29)
#define BIT_TXIDX_RSTB BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_SHIFT_WATCH_DOG_TIMER 28
#define BIT_MASK_WATCH_DOG_TIMER 0xf
#define BIT_WATCH_DOG_TIMER(x) \
(((x) & BIT_MASK_WATCH_DOG_TIMER) << BIT_SHIFT_WATCH_DOG_TIMER)
#define BITS_WATCH_DOG_TIMER \
(BIT_MASK_WATCH_DOG_TIMER << BIT_SHIFT_WATCH_DOG_TIMER)
#define BIT_CLEAR_WATCH_DOG_TIMER(x) ((x) & (~BITS_WATCH_DOG_TIMER))
#define BIT_GET_WATCH_DOG_TIMER(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_TIMER) & BIT_MASK_WATCH_DOG_TIMER)
#define BIT_SET_WATCH_DOG_TIMER(x, v) \
(BIT_CLEAR_WATCH_DOG_TIMER(x) | BIT_WATCH_DOG_TIMER(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_DROP_NEXT_RXPKT BIT(27)
#define BIT_SHORT_CORE_RST_SEL BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EXCEPT_RESUME_EN BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EXCEPT_FLAG BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EXCEPT_RESUME_FLAG BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_ALIGN_MTU BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_ALIGN_MTU BIT(23)
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EARLY_TAG_RETURN BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_SHIFT_LATENCY_CONTROL 21
#define BIT_MASK_LATENCY_CONTROL 0x3
#define BIT_LATENCY_CONTROL(x) \
(((x) & BIT_MASK_LATENCY_CONTROL) << BIT_SHIFT_LATENCY_CONTROL)
#define BITS_LATENCY_CONTROL \
(BIT_MASK_LATENCY_CONTROL << BIT_SHIFT_LATENCY_CONTROL)
#define BIT_CLEAR_LATENCY_CONTROL(x) ((x) & (~BITS_LATENCY_CONTROL))
#define BIT_GET_LATENCY_CONTROL(x) \
(((x) >> BIT_SHIFT_LATENCY_CONTROL) & BIT_MASK_LATENCY_CONTROL)
#define BIT_SET_LATENCY_CONTROL(x, v) \
(BIT_CLEAR_LATENCY_CONTROL(x) | BIT_LATENCY_CONTROL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_HOST_GEN2_SUPPORT BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_SHIFT_TXDMA_ERR_FLAG 16
#define BIT_MASK_TXDMA_ERR_FLAG 0xf
#define BIT_TXDMA_ERR_FLAG(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG) << BIT_SHIFT_TXDMA_ERR_FLAG)
#define BITS_TXDMA_ERR_FLAG \
(BIT_MASK_TXDMA_ERR_FLAG << BIT_SHIFT_TXDMA_ERR_FLAG)
#define BIT_CLEAR_TXDMA_ERR_FLAG(x) ((x) & (~BITS_TXDMA_ERR_FLAG))
#define BIT_GET_TXDMA_ERR_FLAG(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG) & BIT_MASK_TXDMA_ERR_FLAG)
#define BIT_SET_TXDMA_ERR_FLAG(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG(x) | BIT_TXDMA_ERR_FLAG(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_SHIFT_TXDMA_ERR_FLAG_V1 15
#define BIT_MASK_TXDMA_ERR_FLAG_V1 0x1f
#define BIT_TXDMA_ERR_FLAG_V1(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG_V1) << BIT_SHIFT_TXDMA_ERR_FLAG_V1)
#define BITS_TXDMA_ERR_FLAG_V1 \
(BIT_MASK_TXDMA_ERR_FLAG_V1 << BIT_SHIFT_TXDMA_ERR_FLAG_V1)
#define BIT_CLEAR_TXDMA_ERR_FLAG_V1(x) ((x) & (~BITS_TXDMA_ERR_FLAG_V1))
#define BIT_GET_TXDMA_ERR_FLAG_V1(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG_V1) & BIT_MASK_TXDMA_ERR_FLAG_V1)
#define BIT_SET_TXDMA_ERR_FLAG_V1(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG_V1(x) | BIT_TXDMA_ERR_FLAG_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_SHIFT_EARLY_MODE_SEL 12
#define BIT_MASK_EARLY_MODE_SEL 0xf
#define BIT_EARLY_MODE_SEL(x) \
(((x) & BIT_MASK_EARLY_MODE_SEL) << BIT_SHIFT_EARLY_MODE_SEL)
#define BITS_EARLY_MODE_SEL \
(BIT_MASK_EARLY_MODE_SEL << BIT_SHIFT_EARLY_MODE_SEL)
#define BIT_CLEAR_EARLY_MODE_SEL(x) ((x) & (~BITS_EARLY_MODE_SEL))
#define BIT_GET_EARLY_MODE_SEL(x) \
(((x) >> BIT_SHIFT_EARLY_MODE_SEL) & BIT_MASK_EARLY_MODE_SEL)
#define BIT_SET_EARLY_MODE_SEL(x, v) \
(BIT_CLEAR_EARLY_MODE_SEL(x) | BIT_EARLY_MODE_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EPHY_RX50_EN BIT(11)
#define BIT_SHIFT_MSI_TIMEOUT_ID_V1 8
#define BIT_MASK_MSI_TIMEOUT_ID_V1 0x7
#define BIT_MSI_TIMEOUT_ID_V1(x) \
(((x) & BIT_MASK_MSI_TIMEOUT_ID_V1) << BIT_SHIFT_MSI_TIMEOUT_ID_V1)
#define BITS_MSI_TIMEOUT_ID_V1 \
(BIT_MASK_MSI_TIMEOUT_ID_V1 << BIT_SHIFT_MSI_TIMEOUT_ID_V1)
#define BIT_CLEAR_MSI_TIMEOUT_ID_V1(x) ((x) & (~BITS_MSI_TIMEOUT_ID_V1))
#define BIT_GET_MSI_TIMEOUT_ID_V1(x) \
(((x) >> BIT_SHIFT_MSI_TIMEOUT_ID_V1) & BIT_MASK_MSI_TIMEOUT_ID_V1)
#define BIT_SET_MSI_TIMEOUT_ID_V1(x, v) \
(BIT_CLEAR_MSI_TIMEOUT_ID_V1(x) | BIT_MSI_TIMEOUT_ID_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_SHIFT_RXDMA_ERR_CNT 8
#define BIT_MASK_RXDMA_ERR_CNT 0xff
#define BIT_RXDMA_ERR_CNT(x) \
(((x) & BIT_MASK_RXDMA_ERR_CNT) << BIT_SHIFT_RXDMA_ERR_CNT)
#define BITS_RXDMA_ERR_CNT (BIT_MASK_RXDMA_ERR_CNT << BIT_SHIFT_RXDMA_ERR_CNT)
#define BIT_CLEAR_RXDMA_ERR_CNT(x) ((x) & (~BITS_RXDMA_ERR_CNT))
#define BIT_GET_RXDMA_ERR_CNT(x) \
(((x) >> BIT_SHIFT_RXDMA_ERR_CNT) & BIT_MASK_RXDMA_ERR_CNT)
#define BIT_SET_RXDMA_ERR_CNT(x, v) \
(BIT_CLEAR_RXDMA_ERR_CNT(x) | BIT_RXDMA_ERR_CNT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_RADDR_RD BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_TXDMA_ERR_HANDLE_REQ BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_MUL_TAG BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_TXDMA_ERROR_PS BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_L1OFF_PWR_OFF_EN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_EARLY_MODE BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_TXDMA_STUCK_ERR_HANDLE BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_L0S_LINK_OFF BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_TXDMA_RTN_ERR_HANDLE BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_ACT_LINK_OFF BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_RXDMA_ERR_HANDLE_REQ BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_SLOW_MAC_TX BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_RXDMA_ERROR_PS BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_SLOW_MAC_RX BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HCI_MIX_CFG (Offset 0x03FC) */
#define BIT_EN_RXDMA_STUCK_ERR_HANDLE BIT(1)
#define BIT_EN_SLOW_MAC_HW BIT(0)
#define BIT_EN_RXDMA_RTN_ERR_HANDLE BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_SHIFT_QUEUEMACID_Q0_V1 25
#define BIT_MASK_QUEUEMACID_Q0_V1 0x7f
#define BIT_QUEUEMACID_Q0_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q0_V1) << BIT_SHIFT_QUEUEMACID_Q0_V1)
#define BITS_QUEUEMACID_Q0_V1 \
(BIT_MASK_QUEUEMACID_Q0_V1 << BIT_SHIFT_QUEUEMACID_Q0_V1)
#define BIT_CLEAR_QUEUEMACID_Q0_V1(x) ((x) & (~BITS_QUEUEMACID_Q0_V1))
#define BIT_GET_QUEUEMACID_Q0_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q0_V1) & BIT_MASK_QUEUEMACID_Q0_V1)
#define BIT_SET_QUEUEMACID_Q0_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q0_V1(x) | BIT_QUEUEMACID_Q0_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INFO1 (Offset 0x0400) */
#define BIT_SHIFT_QUEUEMACID 25
#define BIT_MASK_QUEUEMACID 0x7f
#define BIT_QUEUEMACID(x) (((x) & BIT_MASK_QUEUEMACID) << BIT_SHIFT_QUEUEMACID)
#define BITS_QUEUEMACID (BIT_MASK_QUEUEMACID << BIT_SHIFT_QUEUEMACID)
#define BIT_CLEAR_QUEUEMACID(x) ((x) & (~BITS_QUEUEMACID))
#define BIT_GET_QUEUEMACID(x) \
(((x) >> BIT_SHIFT_QUEUEMACID) & BIT_MASK_QUEUEMACID)
#define BIT_SET_QUEUEMACID(x, v) (BIT_CLEAR_QUEUEMACID(x) | BIT_QUEUEMACID(v))
#define BIT_DONE BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_SHIFT_QUEUEAC_Q0_V1 23
#define BIT_MASK_QUEUEAC_Q0_V1 0x3
#define BIT_QUEUEAC_Q0_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q0_V1) << BIT_SHIFT_QUEUEAC_Q0_V1)
#define BITS_QUEUEAC_Q0_V1 (BIT_MASK_QUEUEAC_Q0_V1 << BIT_SHIFT_QUEUEAC_Q0_V1)
#define BIT_CLEAR_QUEUEAC_Q0_V1(x) ((x) & (~BITS_QUEUEAC_Q0_V1))
#define BIT_GET_QUEUEAC_Q0_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q0_V1) & BIT_MASK_QUEUEAC_Q0_V1)
#define BIT_SET_QUEUEAC_Q0_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q0_V1(x) | BIT_QUEUEAC_Q0_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INFO1 (Offset 0x0400) */
#define BIT_SHIFT_QUEUEAC 23
#define BIT_MASK_QUEUEAC 0x3
#define BIT_QUEUEAC(x) (((x) & BIT_MASK_QUEUEAC) << BIT_SHIFT_QUEUEAC)
#define BITS_QUEUEAC (BIT_MASK_QUEUEAC << BIT_SHIFT_QUEUEAC)
#define BIT_CLEAR_QUEUEAC(x) ((x) & (~BITS_QUEUEAC))
#define BIT_GET_QUEUEAC(x) (((x) >> BIT_SHIFT_QUEUEAC) & BIT_MASK_QUEUEAC)
#define BIT_SET_QUEUEAC(x, v) (BIT_CLEAR_QUEUEAC(x) | BIT_QUEUEAC(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_TIDEMPTY_Q0_V1 BIT(22)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INFO1 (Offset 0x0400) */
#define BIT_TIDEMPTY BIT(22)
#define BIT_SHIFT_ACCWBITEN 20
#define BIT_MASK_ACCWBITEN 0xf
#define BIT_ACCWBITEN(x) (((x) & BIT_MASK_ACCWBITEN) << BIT_SHIFT_ACCWBITEN)
#define BITS_ACCWBITEN (BIT_MASK_ACCWBITEN << BIT_SHIFT_ACCWBITEN)
#define BIT_CLEAR_ACCWBITEN(x) ((x) & (~BITS_ACCWBITEN))
#define BIT_GET_ACCWBITEN(x) (((x) >> BIT_SHIFT_ACCWBITEN) & BIT_MASK_ACCWBITEN)
#define BIT_SET_ACCWBITEN(x, v) (BIT_CLEAR_ACCWBITEN(x) | BIT_ACCWBITEN(v))
#define BIT_BCNQ_EMPTY_V1 BIT(19)
#define BIT_HIQ_EMPTY_V1 BIT(18)
#define BIT_MQQ_EMPTY_V1 BIT(17)
#define BIT_SHIFT_COL_CNT 16
#define BIT_MASK_COL_CNT 0xf
#define BIT_COL_CNT(x) (((x) & BIT_MASK_COL_CNT) << BIT_SHIFT_COL_CNT)
#define BITS_COL_CNT (BIT_MASK_COL_CNT << BIT_SHIFT_COL_CNT)
#define BIT_CLEAR_COL_CNT(x) ((x) & (~BITS_COL_CNT))
#define BIT_GET_COL_CNT(x) (((x) >> BIT_SHIFT_COL_CNT) & BIT_MASK_COL_CNT)
#define BIT_SET_COL_CNT(x, v) (BIT_CLEAR_COL_CNT(x) | BIT_COL_CNT(v))
#define BIT_CPU_MGT_EMPTY BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_SHIFT_TAIL_PKT_Q0_V1 15
#define BIT_MASK_TAIL_PKT_Q0_V1 0xff
#define BIT_TAIL_PKT_Q0_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q0_V1) << BIT_SHIFT_TAIL_PKT_Q0_V1)
#define BITS_TAIL_PKT_Q0_V1 \
(BIT_MASK_TAIL_PKT_Q0_V1 << BIT_SHIFT_TAIL_PKT_Q0_V1)
#define BIT_CLEAR_TAIL_PKT_Q0_V1(x) ((x) & (~BITS_TAIL_PKT_Q0_V1))
#define BIT_GET_TAIL_PKT_Q0_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q0_V1) & BIT_MASK_TAIL_PKT_Q0_V1)
#define BIT_SET_TAIL_PKT_Q0_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q0_V1(x) | BIT_TAIL_PKT_Q0_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INFO1 (Offset 0x0400) */
#define BIT_AC_MACID_NOT_SAME BIT(15)
#define BIT_SHIFT_GROUP_TABLE_ID 12
#define BIT_MASK_GROUP_TABLE_ID 0x7
#define BIT_GROUP_TABLE_ID(x) \
(((x) & BIT_MASK_GROUP_TABLE_ID) << BIT_SHIFT_GROUP_TABLE_ID)
#define BITS_GROUP_TABLE_ID \
(BIT_MASK_GROUP_TABLE_ID << BIT_SHIFT_GROUP_TABLE_ID)
#define BIT_CLEAR_GROUP_TABLE_ID(x) ((x) & (~BITS_GROUP_TABLE_ID))
#define BIT_GET_GROUP_TABLE_ID(x) \
(((x) >> BIT_SHIFT_GROUP_TABLE_ID) & BIT_MASK_GROUP_TABLE_ID)
#define BIT_SET_GROUP_TABLE_ID(x, v) \
(BIT_CLEAR_GROUP_TABLE_ID(x) | BIT_GROUP_TABLE_ID(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_SHIFT_TAIL_PKT_Q0_V2 11
#define BIT_MASK_TAIL_PKT_Q0_V2 0x7ff
#define BIT_TAIL_PKT_Q0_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q0_V2) << BIT_SHIFT_TAIL_PKT_Q0_V2)
#define BITS_TAIL_PKT_Q0_V2 \
(BIT_MASK_TAIL_PKT_Q0_V2 << BIT_SHIFT_TAIL_PKT_Q0_V2)
#define BIT_CLEAR_TAIL_PKT_Q0_V2(x) ((x) & (~BITS_TAIL_PKT_Q0_V2))
#define BIT_GET_TAIL_PKT_Q0_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q0_V2) & BIT_MASK_TAIL_PKT_Q0_V2)
#define BIT_SET_TAIL_PKT_Q0_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q0_V2(x) | BIT_TAIL_PKT_Q0_V2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INFO1 (Offset 0x0400) */
#define BIT_SHIFT_TAIL_PKT 11
#define BIT_MASK_TAIL_PKT 0x7ff
#define BIT_TAIL_PKT(x) (((x) & BIT_MASK_TAIL_PKT) << BIT_SHIFT_TAIL_PKT)
#define BITS_TAIL_PKT (BIT_MASK_TAIL_PKT << BIT_SHIFT_TAIL_PKT)
#define BIT_CLEAR_TAIL_PKT(x) ((x) & (~BITS_TAIL_PKT))
#define BIT_GET_TAIL_PKT(x) (((x) >> BIT_SHIFT_TAIL_PKT) & BIT_MASK_TAIL_PKT)
#define BIT_SET_TAIL_PKT(x, v) (BIT_CLEAR_TAIL_PKT(x) | BIT_TAIL_PKT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_SHIFT_PKT_NUM_Q0_V1 8
#define BIT_MASK_PKT_NUM_Q0_V1 0x7f
#define BIT_PKT_NUM_Q0_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q0_V1) << BIT_SHIFT_PKT_NUM_Q0_V1)
#define BITS_PKT_NUM_Q0_V1 (BIT_MASK_PKT_NUM_Q0_V1 << BIT_SHIFT_PKT_NUM_Q0_V1)
#define BIT_CLEAR_PKT_NUM_Q0_V1(x) ((x) & (~BITS_PKT_NUM_Q0_V1))
#define BIT_GET_PKT_NUM_Q0_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q0_V1) & BIT_MASK_PKT_NUM_Q0_V1)
#define BIT_SET_PKT_NUM_Q0_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q0_V1(x) | BIT_PKT_NUM_Q0_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q0 0
#define BIT_MASK_HEAD_PKT_Q0 0xff
#define BIT_HEAD_PKT_Q0(x) \
(((x) & BIT_MASK_HEAD_PKT_Q0) << BIT_SHIFT_HEAD_PKT_Q0)
#define BITS_HEAD_PKT_Q0 (BIT_MASK_HEAD_PKT_Q0 << BIT_SHIFT_HEAD_PKT_Q0)
#define BIT_CLEAR_HEAD_PKT_Q0(x) ((x) & (~BITS_HEAD_PKT_Q0))
#define BIT_GET_HEAD_PKT_Q0(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q0) & BIT_MASK_HEAD_PKT_Q0)
#define BIT_SET_HEAD_PKT_Q0(x, v) \
(BIT_CLEAR_HEAD_PKT_Q0(x) | BIT_HEAD_PKT_Q0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q0_INFO (Offset 0x0400) */
#define BIT_SHIFT_HEAD_PKT_Q0_V1 0
#define BIT_MASK_HEAD_PKT_Q0_V1 0x7ff
#define BIT_HEAD_PKT_Q0_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q0_V1) << BIT_SHIFT_HEAD_PKT_Q0_V1)
#define BITS_HEAD_PKT_Q0_V1 \
(BIT_MASK_HEAD_PKT_Q0_V1 << BIT_SHIFT_HEAD_PKT_Q0_V1)
#define BIT_CLEAR_HEAD_PKT_Q0_V1(x) ((x) & (~BITS_HEAD_PKT_Q0_V1))
#define BIT_GET_HEAD_PKT_Q0_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q0_V1) & BIT_MASK_HEAD_PKT_Q0_V1)
#define BIT_SET_HEAD_PKT_Q0_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q0_V1(x) | BIT_HEAD_PKT_Q0_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INFO1 (Offset 0x0400) */
#define BIT_SHIFT_HEAD_PKT 0
#define BIT_MASK_HEAD_PKT 0x7ff
#define BIT_HEAD_PKT(x) (((x) & BIT_MASK_HEAD_PKT) << BIT_SHIFT_HEAD_PKT)
#define BITS_HEAD_PKT (BIT_MASK_HEAD_PKT << BIT_SHIFT_HEAD_PKT)
#define BIT_CLEAR_HEAD_PKT(x) ((x) & (~BITS_HEAD_PKT))
#define BIT_GET_HEAD_PKT(x) (((x) >> BIT_SHIFT_HEAD_PKT) & BIT_MASK_HEAD_PKT)
#define BIT_SET_HEAD_PKT(x, v) (BIT_CLEAR_HEAD_PKT(x) | BIT_HEAD_PKT(v))
#define BIT_SHIFT_PKT_NUMBER 0
#define BIT_MASK_PKT_NUMBER 0xfff
#define BIT_PKT_NUMBER(x) (((x) & BIT_MASK_PKT_NUMBER) << BIT_SHIFT_PKT_NUMBER)
#define BITS_PKT_NUMBER (BIT_MASK_PKT_NUMBER << BIT_SHIFT_PKT_NUMBER)
#define BIT_CLEAR_PKT_NUMBER(x) ((x) & (~BITS_PKT_NUMBER))
#define BIT_GET_PKT_NUMBER(x) \
(((x) >> BIT_SHIFT_PKT_NUMBER) & BIT_MASK_PKT_NUMBER)
#define BIT_SET_PKT_NUMBER(x, v) (BIT_CLEAR_PKT_NUMBER(x) | BIT_PKT_NUMBER(v))
#define BIT_SHIFT_ACCW 0
#define BIT_MASK_ACCW 0x3ff
#define BIT_ACCW(x) (((x) & BIT_MASK_ACCW) << BIT_SHIFT_ACCW)
#define BITS_ACCW (BIT_MASK_ACCW << BIT_SHIFT_ACCW)
#define BIT_CLEAR_ACCW(x) ((x) & (~BITS_ACCW))
#define BIT_GET_ACCW(x) (((x) >> BIT_SHIFT_ACCW) & BIT_MASK_ACCW)
#define BIT_SET_ACCW(x, v) (BIT_CLEAR_ACCW(x) | BIT_ACCW(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO0 (Offset 0x0400) */
#define BIT_SHIFT_QINFO0 0
#define BIT_MASK_QINFO0 0xffffffffL
#define BIT_QINFO0(x) (((x) & BIT_MASK_QINFO0) << BIT_SHIFT_QINFO0)
#define BITS_QINFO0 (BIT_MASK_QINFO0 << BIT_SHIFT_QINFO0)
#define BIT_CLEAR_QINFO0(x) ((x) & (~BITS_QINFO0))
#define BIT_GET_QINFO0(x) (((x) >> BIT_SHIFT_QINFO0) & BIT_MASK_QINFO0)
#define BIT_SET_QINFO0(x, v) (BIT_CLEAR_QINFO0(x) | BIT_QINFO0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q1_INFO (Offset 0x0404) */
#define BIT_SHIFT_QUEUEMACID_Q1_V1 25
#define BIT_MASK_QUEUEMACID_Q1_V1 0x7f
#define BIT_QUEUEMACID_Q1_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q1_V1) << BIT_SHIFT_QUEUEMACID_Q1_V1)
#define BITS_QUEUEMACID_Q1_V1 \
(BIT_MASK_QUEUEMACID_Q1_V1 << BIT_SHIFT_QUEUEMACID_Q1_V1)
#define BIT_CLEAR_QUEUEMACID_Q1_V1(x) ((x) & (~BITS_QUEUEMACID_Q1_V1))
#define BIT_GET_QUEUEMACID_Q1_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q1_V1) & BIT_MASK_QUEUEMACID_Q1_V1)
#define BIT_SET_QUEUEMACID_Q1_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q1_V1(x) | BIT_QUEUEMACID_Q1_V1(v))
#define BIT_SHIFT_QUEUEAC_Q1_V1 23
#define BIT_MASK_QUEUEAC_Q1_V1 0x3
#define BIT_QUEUEAC_Q1_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q1_V1) << BIT_SHIFT_QUEUEAC_Q1_V1)
#define BITS_QUEUEAC_Q1_V1 (BIT_MASK_QUEUEAC_Q1_V1 << BIT_SHIFT_QUEUEAC_Q1_V1)
#define BIT_CLEAR_QUEUEAC_Q1_V1(x) ((x) & (~BITS_QUEUEAC_Q1_V1))
#define BIT_GET_QUEUEAC_Q1_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q1_V1) & BIT_MASK_QUEUEAC_Q1_V1)
#define BIT_SET_QUEUEAC_Q1_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q1_V1(x) | BIT_QUEUEAC_Q1_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q1_INFO (Offset 0x0404) */
#define BIT_TIDEMPTY_Q1_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q1_INFO (Offset 0x0404) */
#define BIT_SHIFT_TAIL_PKT_Q1_V1 15
#define BIT_MASK_TAIL_PKT_Q1_V1 0xff
#define BIT_TAIL_PKT_Q1_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q1_V1) << BIT_SHIFT_TAIL_PKT_Q1_V1)
#define BITS_TAIL_PKT_Q1_V1 \
(BIT_MASK_TAIL_PKT_Q1_V1 << BIT_SHIFT_TAIL_PKT_Q1_V1)
#define BIT_CLEAR_TAIL_PKT_Q1_V1(x) ((x) & (~BITS_TAIL_PKT_Q1_V1))
#define BIT_GET_TAIL_PKT_Q1_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q1_V1) & BIT_MASK_TAIL_PKT_Q1_V1)
#define BIT_SET_TAIL_PKT_Q1_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q1_V1(x) | BIT_TAIL_PKT_Q1_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q1_INFO (Offset 0x0404) */
#define BIT_SHIFT_TAIL_PKT_Q1_V2 11
#define BIT_MASK_TAIL_PKT_Q1_V2 0x7ff
#define BIT_TAIL_PKT_Q1_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q1_V2) << BIT_SHIFT_TAIL_PKT_Q1_V2)
#define BITS_TAIL_PKT_Q1_V2 \
(BIT_MASK_TAIL_PKT_Q1_V2 << BIT_SHIFT_TAIL_PKT_Q1_V2)
#define BIT_CLEAR_TAIL_PKT_Q1_V2(x) ((x) & (~BITS_TAIL_PKT_Q1_V2))
#define BIT_GET_TAIL_PKT_Q1_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q1_V2) & BIT_MASK_TAIL_PKT_Q1_V2)
#define BIT_SET_TAIL_PKT_Q1_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q1_V2(x) | BIT_TAIL_PKT_Q1_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q1_INFO (Offset 0x0404) */
#define BIT_SHIFT_PKT_NUM_Q1_V1 8
#define BIT_MASK_PKT_NUM_Q1_V1 0x7f
#define BIT_PKT_NUM_Q1_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q1_V1) << BIT_SHIFT_PKT_NUM_Q1_V1)
#define BITS_PKT_NUM_Q1_V1 (BIT_MASK_PKT_NUM_Q1_V1 << BIT_SHIFT_PKT_NUM_Q1_V1)
#define BIT_CLEAR_PKT_NUM_Q1_V1(x) ((x) & (~BITS_PKT_NUM_Q1_V1))
#define BIT_GET_PKT_NUM_Q1_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q1_V1) & BIT_MASK_PKT_NUM_Q1_V1)
#define BIT_SET_PKT_NUM_Q1_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q1_V1(x) | BIT_PKT_NUM_Q1_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q1 0
#define BIT_MASK_HEAD_PKT_Q1 0xff
#define BIT_HEAD_PKT_Q1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q1) << BIT_SHIFT_HEAD_PKT_Q1)
#define BITS_HEAD_PKT_Q1 (BIT_MASK_HEAD_PKT_Q1 << BIT_SHIFT_HEAD_PKT_Q1)
#define BIT_CLEAR_HEAD_PKT_Q1(x) ((x) & (~BITS_HEAD_PKT_Q1))
#define BIT_GET_HEAD_PKT_Q1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q1) & BIT_MASK_HEAD_PKT_Q1)
#define BIT_SET_HEAD_PKT_Q1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q1(x) | BIT_HEAD_PKT_Q1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q1_INFO (Offset 0x0404) */
#define BIT_SHIFT_HEAD_PKT_Q1_V1 0
#define BIT_MASK_HEAD_PKT_Q1_V1 0x7ff
#define BIT_HEAD_PKT_Q1_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q1_V1) << BIT_SHIFT_HEAD_PKT_Q1_V1)
#define BITS_HEAD_PKT_Q1_V1 \
(BIT_MASK_HEAD_PKT_Q1_V1 << BIT_SHIFT_HEAD_PKT_Q1_V1)
#define BIT_CLEAR_HEAD_PKT_Q1_V1(x) ((x) & (~BITS_HEAD_PKT_Q1_V1))
#define BIT_GET_HEAD_PKT_Q1_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q1_V1) & BIT_MASK_HEAD_PKT_Q1_V1)
#define BIT_SET_HEAD_PKT_Q1_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q1_V1(x) | BIT_HEAD_PKT_Q1_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO1 (Offset 0x0404) */
#define BIT_SHIFT_QINFO1 0
#define BIT_MASK_QINFO1 0xffffffffL
#define BIT_QINFO1(x) (((x) & BIT_MASK_QINFO1) << BIT_SHIFT_QINFO1)
#define BITS_QINFO1 (BIT_MASK_QINFO1 << BIT_SHIFT_QINFO1)
#define BIT_CLEAR_QINFO1(x) ((x) & (~BITS_QINFO1))
#define BIT_GET_QINFO1(x) (((x) >> BIT_SHIFT_QINFO1) & BIT_MASK_QINFO1)
#define BIT_SET_QINFO1(x, v) (BIT_CLEAR_QINFO1(x) | BIT_QINFO1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q2_INFO (Offset 0x0408) */
#define BIT_SHIFT_QUEUEMACID_Q2_V1 25
#define BIT_MASK_QUEUEMACID_Q2_V1 0x7f
#define BIT_QUEUEMACID_Q2_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q2_V1) << BIT_SHIFT_QUEUEMACID_Q2_V1)
#define BITS_QUEUEMACID_Q2_V1 \
(BIT_MASK_QUEUEMACID_Q2_V1 << BIT_SHIFT_QUEUEMACID_Q2_V1)
#define BIT_CLEAR_QUEUEMACID_Q2_V1(x) ((x) & (~BITS_QUEUEMACID_Q2_V1))
#define BIT_GET_QUEUEMACID_Q2_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q2_V1) & BIT_MASK_QUEUEMACID_Q2_V1)
#define BIT_SET_QUEUEMACID_Q2_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q2_V1(x) | BIT_QUEUEMACID_Q2_V1(v))
#define BIT_SHIFT_QUEUEAC_Q2_V1 23
#define BIT_MASK_QUEUEAC_Q2_V1 0x3
#define BIT_QUEUEAC_Q2_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q2_V1) << BIT_SHIFT_QUEUEAC_Q2_V1)
#define BITS_QUEUEAC_Q2_V1 (BIT_MASK_QUEUEAC_Q2_V1 << BIT_SHIFT_QUEUEAC_Q2_V1)
#define BIT_CLEAR_QUEUEAC_Q2_V1(x) ((x) & (~BITS_QUEUEAC_Q2_V1))
#define BIT_GET_QUEUEAC_Q2_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q2_V1) & BIT_MASK_QUEUEAC_Q2_V1)
#define BIT_SET_QUEUEAC_Q2_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q2_V1(x) | BIT_QUEUEAC_Q2_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q2_INFO (Offset 0x0408) */
#define BIT_TIDEMPTY_Q2_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q2_INFO (Offset 0x0408) */
#define BIT_SHIFT_TAIL_PKT_Q2_V1 15
#define BIT_MASK_TAIL_PKT_Q2_V1 0xff
#define BIT_TAIL_PKT_Q2_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q2_V1) << BIT_SHIFT_TAIL_PKT_Q2_V1)
#define BITS_TAIL_PKT_Q2_V1 \
(BIT_MASK_TAIL_PKT_Q2_V1 << BIT_SHIFT_TAIL_PKT_Q2_V1)
#define BIT_CLEAR_TAIL_PKT_Q2_V1(x) ((x) & (~BITS_TAIL_PKT_Q2_V1))
#define BIT_GET_TAIL_PKT_Q2_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q2_V1) & BIT_MASK_TAIL_PKT_Q2_V1)
#define BIT_SET_TAIL_PKT_Q2_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q2_V1(x) | BIT_TAIL_PKT_Q2_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q2_INFO (Offset 0x0408) */
#define BIT_SHIFT_TAIL_PKT_Q2_V2 11
#define BIT_MASK_TAIL_PKT_Q2_V2 0x7ff
#define BIT_TAIL_PKT_Q2_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q2_V2) << BIT_SHIFT_TAIL_PKT_Q2_V2)
#define BITS_TAIL_PKT_Q2_V2 \
(BIT_MASK_TAIL_PKT_Q2_V2 << BIT_SHIFT_TAIL_PKT_Q2_V2)
#define BIT_CLEAR_TAIL_PKT_Q2_V2(x) ((x) & (~BITS_TAIL_PKT_Q2_V2))
#define BIT_GET_TAIL_PKT_Q2_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q2_V2) & BIT_MASK_TAIL_PKT_Q2_V2)
#define BIT_SET_TAIL_PKT_Q2_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q2_V2(x) | BIT_TAIL_PKT_Q2_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q2_INFO (Offset 0x0408) */
#define BIT_SHIFT_PKT_NUM_Q2_V1 8
#define BIT_MASK_PKT_NUM_Q2_V1 0x7f
#define BIT_PKT_NUM_Q2_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q2_V1) << BIT_SHIFT_PKT_NUM_Q2_V1)
#define BITS_PKT_NUM_Q2_V1 (BIT_MASK_PKT_NUM_Q2_V1 << BIT_SHIFT_PKT_NUM_Q2_V1)
#define BIT_CLEAR_PKT_NUM_Q2_V1(x) ((x) & (~BITS_PKT_NUM_Q2_V1))
#define BIT_GET_PKT_NUM_Q2_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q2_V1) & BIT_MASK_PKT_NUM_Q2_V1)
#define BIT_SET_PKT_NUM_Q2_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q2_V1(x) | BIT_PKT_NUM_Q2_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q2 0
#define BIT_MASK_HEAD_PKT_Q2 0xff
#define BIT_HEAD_PKT_Q2(x) \
(((x) & BIT_MASK_HEAD_PKT_Q2) << BIT_SHIFT_HEAD_PKT_Q2)
#define BITS_HEAD_PKT_Q2 (BIT_MASK_HEAD_PKT_Q2 << BIT_SHIFT_HEAD_PKT_Q2)
#define BIT_CLEAR_HEAD_PKT_Q2(x) ((x) & (~BITS_HEAD_PKT_Q2))
#define BIT_GET_HEAD_PKT_Q2(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q2) & BIT_MASK_HEAD_PKT_Q2)
#define BIT_SET_HEAD_PKT_Q2(x, v) \
(BIT_CLEAR_HEAD_PKT_Q2(x) | BIT_HEAD_PKT_Q2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q2_INFO (Offset 0x0408) */
#define BIT_SHIFT_HEAD_PKT_Q2_V1 0
#define BIT_MASK_HEAD_PKT_Q2_V1 0x7ff
#define BIT_HEAD_PKT_Q2_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q2_V1) << BIT_SHIFT_HEAD_PKT_Q2_V1)
#define BITS_HEAD_PKT_Q2_V1 \
(BIT_MASK_HEAD_PKT_Q2_V1 << BIT_SHIFT_HEAD_PKT_Q2_V1)
#define BIT_CLEAR_HEAD_PKT_Q2_V1(x) ((x) & (~BITS_HEAD_PKT_Q2_V1))
#define BIT_GET_HEAD_PKT_Q2_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q2_V1) & BIT_MASK_HEAD_PKT_Q2_V1)
#define BIT_SET_HEAD_PKT_Q2_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q2_V1(x) | BIT_HEAD_PKT_Q2_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO2 (Offset 0x0408) */
#define BIT_SHIFT_QINFO2 0
#define BIT_MASK_QINFO2 0xffffffffL
#define BIT_QINFO2(x) (((x) & BIT_MASK_QINFO2) << BIT_SHIFT_QINFO2)
#define BITS_QINFO2 (BIT_MASK_QINFO2 << BIT_SHIFT_QINFO2)
#define BIT_CLEAR_QINFO2(x) ((x) & (~BITS_QINFO2))
#define BIT_GET_QINFO2(x) (((x) >> BIT_SHIFT_QINFO2) & BIT_MASK_QINFO2)
#define BIT_SET_QINFO2(x, v) (BIT_CLEAR_QINFO2(x) | BIT_QINFO2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q3_INFO (Offset 0x040C) */
#define BIT_SHIFT_QUEUEMACID_Q3_V1 25
#define BIT_MASK_QUEUEMACID_Q3_V1 0x7f
#define BIT_QUEUEMACID_Q3_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q3_V1) << BIT_SHIFT_QUEUEMACID_Q3_V1)
#define BITS_QUEUEMACID_Q3_V1 \
(BIT_MASK_QUEUEMACID_Q3_V1 << BIT_SHIFT_QUEUEMACID_Q3_V1)
#define BIT_CLEAR_QUEUEMACID_Q3_V1(x) ((x) & (~BITS_QUEUEMACID_Q3_V1))
#define BIT_GET_QUEUEMACID_Q3_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q3_V1) & BIT_MASK_QUEUEMACID_Q3_V1)
#define BIT_SET_QUEUEMACID_Q3_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q3_V1(x) | BIT_QUEUEMACID_Q3_V1(v))
#define BIT_SHIFT_QUEUEAC_Q3_V1 23
#define BIT_MASK_QUEUEAC_Q3_V1 0x3
#define BIT_QUEUEAC_Q3_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q3_V1) << BIT_SHIFT_QUEUEAC_Q3_V1)
#define BITS_QUEUEAC_Q3_V1 (BIT_MASK_QUEUEAC_Q3_V1 << BIT_SHIFT_QUEUEAC_Q3_V1)
#define BIT_CLEAR_QUEUEAC_Q3_V1(x) ((x) & (~BITS_QUEUEAC_Q3_V1))
#define BIT_GET_QUEUEAC_Q3_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q3_V1) & BIT_MASK_QUEUEAC_Q3_V1)
#define BIT_SET_QUEUEAC_Q3_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q3_V1(x) | BIT_QUEUEAC_Q3_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q3_INFO (Offset 0x040C) */
#define BIT_TIDEMPTY_Q3_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q3_INFO (Offset 0x040C) */
#define BIT_SHIFT_TAIL_PKT_Q3_V1 15
#define BIT_MASK_TAIL_PKT_Q3_V1 0xff
#define BIT_TAIL_PKT_Q3_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q3_V1) << BIT_SHIFT_TAIL_PKT_Q3_V1)
#define BITS_TAIL_PKT_Q3_V1 \
(BIT_MASK_TAIL_PKT_Q3_V1 << BIT_SHIFT_TAIL_PKT_Q3_V1)
#define BIT_CLEAR_TAIL_PKT_Q3_V1(x) ((x) & (~BITS_TAIL_PKT_Q3_V1))
#define BIT_GET_TAIL_PKT_Q3_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q3_V1) & BIT_MASK_TAIL_PKT_Q3_V1)
#define BIT_SET_TAIL_PKT_Q3_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q3_V1(x) | BIT_TAIL_PKT_Q3_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q3_INFO (Offset 0x040C) */
#define BIT_SHIFT_TAIL_PKT_Q3_V2 11
#define BIT_MASK_TAIL_PKT_Q3_V2 0x7ff
#define BIT_TAIL_PKT_Q3_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q3_V2) << BIT_SHIFT_TAIL_PKT_Q3_V2)
#define BITS_TAIL_PKT_Q3_V2 \
(BIT_MASK_TAIL_PKT_Q3_V2 << BIT_SHIFT_TAIL_PKT_Q3_V2)
#define BIT_CLEAR_TAIL_PKT_Q3_V2(x) ((x) & (~BITS_TAIL_PKT_Q3_V2))
#define BIT_GET_TAIL_PKT_Q3_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q3_V2) & BIT_MASK_TAIL_PKT_Q3_V2)
#define BIT_SET_TAIL_PKT_Q3_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q3_V2(x) | BIT_TAIL_PKT_Q3_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q3_INFO (Offset 0x040C) */
#define BIT_SHIFT_PKT_NUM_Q3_V1 8
#define BIT_MASK_PKT_NUM_Q3_V1 0x7f
#define BIT_PKT_NUM_Q3_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q3_V1) << BIT_SHIFT_PKT_NUM_Q3_V1)
#define BITS_PKT_NUM_Q3_V1 (BIT_MASK_PKT_NUM_Q3_V1 << BIT_SHIFT_PKT_NUM_Q3_V1)
#define BIT_CLEAR_PKT_NUM_Q3_V1(x) ((x) & (~BITS_PKT_NUM_Q3_V1))
#define BIT_GET_PKT_NUM_Q3_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q3_V1) & BIT_MASK_PKT_NUM_Q3_V1)
#define BIT_SET_PKT_NUM_Q3_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q3_V1(x) | BIT_PKT_NUM_Q3_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q3 0
#define BIT_MASK_HEAD_PKT_Q3 0xff
#define BIT_HEAD_PKT_Q3(x) \
(((x) & BIT_MASK_HEAD_PKT_Q3) << BIT_SHIFT_HEAD_PKT_Q3)
#define BITS_HEAD_PKT_Q3 (BIT_MASK_HEAD_PKT_Q3 << BIT_SHIFT_HEAD_PKT_Q3)
#define BIT_CLEAR_HEAD_PKT_Q3(x) ((x) & (~BITS_HEAD_PKT_Q3))
#define BIT_GET_HEAD_PKT_Q3(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q3) & BIT_MASK_HEAD_PKT_Q3)
#define BIT_SET_HEAD_PKT_Q3(x, v) \
(BIT_CLEAR_HEAD_PKT_Q3(x) | BIT_HEAD_PKT_Q3(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q3_INFO (Offset 0x040C) */
#define BIT_SHIFT_HEAD_PKT_Q3_V1 0
#define BIT_MASK_HEAD_PKT_Q3_V1 0x7ff
#define BIT_HEAD_PKT_Q3_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q3_V1) << BIT_SHIFT_HEAD_PKT_Q3_V1)
#define BITS_HEAD_PKT_Q3_V1 \
(BIT_MASK_HEAD_PKT_Q3_V1 << BIT_SHIFT_HEAD_PKT_Q3_V1)
#define BIT_CLEAR_HEAD_PKT_Q3_V1(x) ((x) & (~BITS_HEAD_PKT_Q3_V1))
#define BIT_GET_HEAD_PKT_Q3_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q3_V1) & BIT_MASK_HEAD_PKT_Q3_V1)
#define BIT_SET_HEAD_PKT_Q3_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q3_V1(x) | BIT_HEAD_PKT_Q3_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO3 (Offset 0x040C) */
#define BIT_SHIFT_QINFO3 0
#define BIT_MASK_QINFO3 0xffffffffL
#define BIT_QINFO3(x) (((x) & BIT_MASK_QINFO3) << BIT_SHIFT_QINFO3)
#define BITS_QINFO3 (BIT_MASK_QINFO3 << BIT_SHIFT_QINFO3)
#define BIT_CLEAR_QINFO3(x) ((x) & (~BITS_QINFO3))
#define BIT_GET_QINFO3(x) (((x) >> BIT_SHIFT_QINFO3) & BIT_MASK_QINFO3)
#define BIT_SET_QINFO3(x, v) (BIT_CLEAR_QINFO3(x) | BIT_QINFO3(v))
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_FWCMDQ_EMPTY BIT(31)
#define BIT_MGQ_CPU_EMPTY_V1 BIT(30)
#define BIT_BCNQ_EMPTY_EXTP0 BIT(29)
#define BIT_BCNQ_EMPTY_PORT4 BIT(28)
#define BIT_BCNQ_EMPTY_PORT3 BIT(27)
#define BIT_BCNQ_EMPTY_PORT2 BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_QUEUEMACID_MGQ_V1 25
#define BIT_MASK_QUEUEMACID_MGQ_V1 0x7f
#define BIT_QUEUEMACID_MGQ_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_MGQ_V1) << BIT_SHIFT_QUEUEMACID_MGQ_V1)
#define BITS_QUEUEMACID_MGQ_V1 \
(BIT_MASK_QUEUEMACID_MGQ_V1 << BIT_SHIFT_QUEUEMACID_MGQ_V1)
#define BIT_CLEAR_QUEUEMACID_MGQ_V1(x) ((x) & (~BITS_QUEUEMACID_MGQ_V1))
#define BIT_GET_QUEUEMACID_MGQ_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_MGQ_V1) & BIT_MASK_QUEUEMACID_MGQ_V1)
#define BIT_SET_QUEUEMACID_MGQ_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_MGQ_V1(x) | BIT_QUEUEMACID_MGQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_BCNQ_EMPTY_PORT1 BIT(25)
#define BIT_BCNQ_EMPTY_PORT0 BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_QUEUEAC_MGQ_V1 23
#define BIT_MASK_QUEUEAC_MGQ_V1 0x3
#define BIT_QUEUEAC_MGQ_V1(x) \
(((x) & BIT_MASK_QUEUEAC_MGQ_V1) << BIT_SHIFT_QUEUEAC_MGQ_V1)
#define BITS_QUEUEAC_MGQ_V1 \
(BIT_MASK_QUEUEAC_MGQ_V1 << BIT_SHIFT_QUEUEAC_MGQ_V1)
#define BIT_CLEAR_QUEUEAC_MGQ_V1(x) ((x) & (~BITS_QUEUEAC_MGQ_V1))
#define BIT_GET_QUEUEAC_MGQ_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_MGQ_V1) & BIT_MASK_QUEUEAC_MGQ_V1)
#define BIT_SET_QUEUEAC_MGQ_V1(x, v) \
(BIT_CLEAR_QUEUEAC_MGQ_V1(x) | BIT_QUEUEAC_MGQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_HQQ_EMPTY_V1 BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_TIDEMPTY_MGQ_V1 BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_MQQ_EMPTY_V2 BIT(22)
#define BIT_S1_EMPTY BIT(21)
#define BIT_S0_EMPTY BIT(20)
#define BIT_AC19Q_EMPTY BIT(19)
#define BIT_AC18Q_EMPTY BIT(18)
#define BIT_AC17Q_EMPTY BIT(17)
#define BIT_AC16Q_EMPTY BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_TAIL_PKT_MGQ_V1 15
#define BIT_MASK_TAIL_PKT_MGQ_V1 0xff
#define BIT_TAIL_PKT_MGQ_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_MGQ_V1) << BIT_SHIFT_TAIL_PKT_MGQ_V1)
#define BITS_TAIL_PKT_MGQ_V1 \
(BIT_MASK_TAIL_PKT_MGQ_V1 << BIT_SHIFT_TAIL_PKT_MGQ_V1)
#define BIT_CLEAR_TAIL_PKT_MGQ_V1(x) ((x) & (~BITS_TAIL_PKT_MGQ_V1))
#define BIT_GET_TAIL_PKT_MGQ_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_MGQ_V1) & BIT_MASK_TAIL_PKT_MGQ_V1)
#define BIT_SET_TAIL_PKT_MGQ_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_MGQ_V1(x) | BIT_TAIL_PKT_MGQ_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_AC15Q_EMPTY BIT(15)
#define BIT_AC14Q_EMPTY BIT(14)
#define BIT_AC13Q_EMPTY BIT(13)
#define BIT_AC12Q_EMPTY BIT(12)
#define BIT_AC11Q_EMPTY BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_TAIL_PKT_MGQ_V2 11
#define BIT_MASK_TAIL_PKT_MGQ_V2 0x7ff
#define BIT_TAIL_PKT_MGQ_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_MGQ_V2) << BIT_SHIFT_TAIL_PKT_MGQ_V2)
#define BITS_TAIL_PKT_MGQ_V2 \
(BIT_MASK_TAIL_PKT_MGQ_V2 << BIT_SHIFT_TAIL_PKT_MGQ_V2)
#define BIT_CLEAR_TAIL_PKT_MGQ_V2(x) ((x) & (~BITS_TAIL_PKT_MGQ_V2))
#define BIT_GET_TAIL_PKT_MGQ_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_MGQ_V2) & BIT_MASK_TAIL_PKT_MGQ_V2)
#define BIT_SET_TAIL_PKT_MGQ_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_MGQ_V2(x) | BIT_TAIL_PKT_MGQ_V2(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_AC10Q_EMPTY BIT(10)
#define BIT_AC9Q_EMPTY BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_PKT_NUM_MGQ_V1 8
#define BIT_MASK_PKT_NUM_MGQ_V1 0x7f
#define BIT_PKT_NUM_MGQ_V1(x) \
(((x) & BIT_MASK_PKT_NUM_MGQ_V1) << BIT_SHIFT_PKT_NUM_MGQ_V1)
#define BITS_PKT_NUM_MGQ_V1 \
(BIT_MASK_PKT_NUM_MGQ_V1 << BIT_SHIFT_PKT_NUM_MGQ_V1)
#define BIT_CLEAR_PKT_NUM_MGQ_V1(x) ((x) & (~BITS_PKT_NUM_MGQ_V1))
#define BIT_GET_PKT_NUM_MGQ_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_MGQ_V1) & BIT_MASK_PKT_NUM_MGQ_V1)
#define BIT_SET_PKT_NUM_MGQ_V1(x, v) \
(BIT_CLEAR_PKT_NUM_MGQ_V1(x) | BIT_PKT_NUM_MGQ_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_INFO_EMPTY (Offset 0x0410) */
#define BIT_AC8Q_EMPTY BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_HEAD_PKT_MGQ 0
#define BIT_MASK_HEAD_PKT_MGQ 0xff
#define BIT_HEAD_PKT_MGQ(x) \
(((x) & BIT_MASK_HEAD_PKT_MGQ) << BIT_SHIFT_HEAD_PKT_MGQ)
#define BITS_HEAD_PKT_MGQ (BIT_MASK_HEAD_PKT_MGQ << BIT_SHIFT_HEAD_PKT_MGQ)
#define BIT_CLEAR_HEAD_PKT_MGQ(x) ((x) & (~BITS_HEAD_PKT_MGQ))
#define BIT_GET_HEAD_PKT_MGQ(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_MGQ) & BIT_MASK_HEAD_PKT_MGQ)
#define BIT_SET_HEAD_PKT_MGQ(x, v) \
(BIT_CLEAR_HEAD_PKT_MGQ(x) | BIT_HEAD_PKT_MGQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_INFO (Offset 0x0410) */
#define BIT_SHIFT_HEAD_PKT_MGQ_V1 0
#define BIT_MASK_HEAD_PKT_MGQ_V1 0x7ff
#define BIT_HEAD_PKT_MGQ_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_MGQ_V1) << BIT_SHIFT_HEAD_PKT_MGQ_V1)
#define BITS_HEAD_PKT_MGQ_V1 \
(BIT_MASK_HEAD_PKT_MGQ_V1 << BIT_SHIFT_HEAD_PKT_MGQ_V1)
#define BIT_CLEAR_HEAD_PKT_MGQ_V1(x) ((x) & (~BITS_HEAD_PKT_MGQ_V1))
#define BIT_GET_HEAD_PKT_MGQ_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_MGQ_V1) & BIT_MASK_HEAD_PKT_MGQ_V1)
#define BIT_SET_HEAD_PKT_MGQ_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_MGQ_V1(x) | BIT_HEAD_PKT_MGQ_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_QUEUEMACID_HIQ_V1 25
#define BIT_MASK_QUEUEMACID_HIQ_V1 0x7f
#define BIT_QUEUEMACID_HIQ_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_HIQ_V1) << BIT_SHIFT_QUEUEMACID_HIQ_V1)
#define BITS_QUEUEMACID_HIQ_V1 \
(BIT_MASK_QUEUEMACID_HIQ_V1 << BIT_SHIFT_QUEUEMACID_HIQ_V1)
#define BIT_CLEAR_QUEUEMACID_HIQ_V1(x) ((x) & (~BITS_QUEUEMACID_HIQ_V1))
#define BIT_GET_QUEUEMACID_HIQ_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_HIQ_V1) & BIT_MASK_QUEUEMACID_HIQ_V1)
#define BIT_SET_QUEUEMACID_HIQ_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_HIQ_V1(x) | BIT_QUEUEMACID_HIQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_ACQ_EN (Offset 0x0414) */
#define BIT_SHIFT_QINFO_CTRL 24
#define BIT_MASK_QINFO_CTRL 0x3f
#define BIT_QINFO_CTRL(x) (((x) & BIT_MASK_QINFO_CTRL) << BIT_SHIFT_QINFO_CTRL)
#define BITS_QINFO_CTRL (BIT_MASK_QINFO_CTRL << BIT_SHIFT_QINFO_CTRL)
#define BIT_CLEAR_QINFO_CTRL(x) ((x) & (~BITS_QINFO_CTRL))
#define BIT_GET_QINFO_CTRL(x) \
(((x) >> BIT_SHIFT_QINFO_CTRL) & BIT_MASK_QINFO_CTRL)
#define BIT_SET_QINFO_CTRL(x, v) (BIT_CLEAR_QINFO_CTRL(x) | BIT_QINFO_CTRL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_QUEUEAC_HIQ_V1 23
#define BIT_MASK_QUEUEAC_HIQ_V1 0x3
#define BIT_QUEUEAC_HIQ_V1(x) \
(((x) & BIT_MASK_QUEUEAC_HIQ_V1) << BIT_SHIFT_QUEUEAC_HIQ_V1)
#define BITS_QUEUEAC_HIQ_V1 \
(BIT_MASK_QUEUEAC_HIQ_V1 << BIT_SHIFT_QUEUEAC_HIQ_V1)
#define BIT_CLEAR_QUEUEAC_HIQ_V1(x) ((x) & (~BITS_QUEUEAC_HIQ_V1))
#define BIT_GET_QUEUEAC_HIQ_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_HIQ_V1) & BIT_MASK_QUEUEAC_HIQ_V1)
#define BIT_SET_QUEUEAC_HIQ_V1(x, v) \
(BIT_CLEAR_QUEUEAC_HIQ_V1(x) | BIT_QUEUEAC_HIQ_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_TIDEMPTY_HIQ_V1 BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_ACQ_EN (Offset 0x0414) */
#define BIT_SHIFT_QINFO_MODE_BAND 20
#define BIT_MASK_QINFO_MODE_BAND 0x7
#define BIT_QINFO_MODE_BAND(x) \
(((x) & BIT_MASK_QINFO_MODE_BAND) << BIT_SHIFT_QINFO_MODE_BAND)
#define BITS_QINFO_MODE_BAND \
(BIT_MASK_QINFO_MODE_BAND << BIT_SHIFT_QINFO_MODE_BAND)
#define BIT_CLEAR_QINFO_MODE_BAND(x) ((x) & (~BITS_QINFO_MODE_BAND))
#define BIT_GET_QINFO_MODE_BAND(x) \
(((x) >> BIT_SHIFT_QINFO_MODE_BAND) & BIT_MASK_QINFO_MODE_BAND)
#define BIT_SET_QINFO_MODE_BAND(x, v) \
(BIT_CLEAR_QINFO_MODE_BAND(x) | BIT_QINFO_MODE_BAND(v))
#define BIT_ACQ19_ENABLE BIT(19)
#define BIT_ACQ18_ENABLE BIT(18)
#define BIT_ACQ17_ENABLE BIT(17)
#define BIT_ACQ16_ENABLE BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_TAIL_PKT_HIQ_V1 15
#define BIT_MASK_TAIL_PKT_HIQ_V1 0xff
#define BIT_TAIL_PKT_HIQ_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_HIQ_V1) << BIT_SHIFT_TAIL_PKT_HIQ_V1)
#define BITS_TAIL_PKT_HIQ_V1 \
(BIT_MASK_TAIL_PKT_HIQ_V1 << BIT_SHIFT_TAIL_PKT_HIQ_V1)
#define BIT_CLEAR_TAIL_PKT_HIQ_V1(x) ((x) & (~BITS_TAIL_PKT_HIQ_V1))
#define BIT_GET_TAIL_PKT_HIQ_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_HIQ_V1) & BIT_MASK_TAIL_PKT_HIQ_V1)
#define BIT_SET_TAIL_PKT_HIQ_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_HIQ_V1(x) | BIT_TAIL_PKT_HIQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_ACQ_EN (Offset 0x0414) */
#define BIT_ACQ15_ENABLE BIT(15)
#define BIT_ACQ14_ENABLE BIT(14)
#define BIT_ACQ13_ENABLE BIT(13)
#define BIT_ACQ12_ENABLE BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_TAIL_PKT_HIQ_V2 11
#define BIT_MASK_TAIL_PKT_HIQ_V2 0x7ff
#define BIT_TAIL_PKT_HIQ_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_HIQ_V2) << BIT_SHIFT_TAIL_PKT_HIQ_V2)
#define BITS_TAIL_PKT_HIQ_V2 \
(BIT_MASK_TAIL_PKT_HIQ_V2 << BIT_SHIFT_TAIL_PKT_HIQ_V2)
#define BIT_CLEAR_TAIL_PKT_HIQ_V2(x) ((x) & (~BITS_TAIL_PKT_HIQ_V2))
#define BIT_GET_TAIL_PKT_HIQ_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_HIQ_V2) & BIT_MASK_TAIL_PKT_HIQ_V2)
#define BIT_SET_TAIL_PKT_HIQ_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_HIQ_V2(x) | BIT_TAIL_PKT_HIQ_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_ACQ_EN (Offset 0x0414) */
#define BIT_ACQ11_ENABLE BIT(11)
#define BIT_ACQ10_ENABLE BIT(10)
#define BIT_ACQ9_ENABLE BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_PKT_NUM_HIQ_V1 8
#define BIT_MASK_PKT_NUM_HIQ_V1 0x7f
#define BIT_PKT_NUM_HIQ_V1(x) \
(((x) & BIT_MASK_PKT_NUM_HIQ_V1) << BIT_SHIFT_PKT_NUM_HIQ_V1)
#define BITS_PKT_NUM_HIQ_V1 \
(BIT_MASK_PKT_NUM_HIQ_V1 << BIT_SHIFT_PKT_NUM_HIQ_V1)
#define BIT_CLEAR_PKT_NUM_HIQ_V1(x) ((x) & (~BITS_PKT_NUM_HIQ_V1))
#define BIT_GET_PKT_NUM_HIQ_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_HIQ_V1) & BIT_MASK_PKT_NUM_HIQ_V1)
#define BIT_SET_PKT_NUM_HIQ_V1(x, v) \
(BIT_CLEAR_PKT_NUM_HIQ_V1(x) | BIT_PKT_NUM_HIQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_ACQ_EN (Offset 0x0414) */
#define BIT_ACQ8_ENABLE BIT(8)
#define BIT_ACQ7_ENABLE BIT(7)
#define BIT_ACQ6_ENABLE BIT(6)
#define BIT_ACQ5_ENABLE BIT(5)
#define BIT_ACQ4_ENABLE BIT(4)
#define BIT_ACQ3_ENABLE BIT(3)
#define BIT_ACQ2_ENABLE BIT(2)
#define BIT_ACQ1_ENABLE BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_HEAD_PKT_HIQ 0
#define BIT_MASK_HEAD_PKT_HIQ 0xff
#define BIT_HEAD_PKT_HIQ(x) \
(((x) & BIT_MASK_HEAD_PKT_HIQ) << BIT_SHIFT_HEAD_PKT_HIQ)
#define BITS_HEAD_PKT_HIQ (BIT_MASK_HEAD_PKT_HIQ << BIT_SHIFT_HEAD_PKT_HIQ)
#define BIT_CLEAR_HEAD_PKT_HIQ(x) ((x) & (~BITS_HEAD_PKT_HIQ))
#define BIT_GET_HEAD_PKT_HIQ(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_HIQ) & BIT_MASK_HEAD_PKT_HIQ)
#define BIT_SET_HEAD_PKT_HIQ(x, v) \
(BIT_CLEAR_HEAD_PKT_HIQ(x) | BIT_HEAD_PKT_HIQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIQ_INFO (Offset 0x0414) */
#define BIT_SHIFT_HEAD_PKT_HIQ_V1 0
#define BIT_MASK_HEAD_PKT_HIQ_V1 0x7ff
#define BIT_HEAD_PKT_HIQ_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_HIQ_V1) << BIT_SHIFT_HEAD_PKT_HIQ_V1)
#define BITS_HEAD_PKT_HIQ_V1 \
(BIT_MASK_HEAD_PKT_HIQ_V1 << BIT_SHIFT_HEAD_PKT_HIQ_V1)
#define BIT_CLEAR_HEAD_PKT_HIQ_V1(x) ((x) & (~BITS_HEAD_PKT_HIQ_V1))
#define BIT_GET_HEAD_PKT_HIQ_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_HIQ_V1) & BIT_MASK_HEAD_PKT_HIQ_V1)
#define BIT_SET_HEAD_PKT_HIQ_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_HIQ_V1(x) | BIT_HEAD_PKT_HIQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUELIST_ACQ_EN (Offset 0x0414) */
#define BIT_ACQ0_ENABLE BIT(0)
/* 2 REG_BCNQ_BDNY_V2 (Offset 0x0418) */
#define BIT_SHIFT_BCNQ_PGBNDY_WSEL 28
#define BIT_MASK_BCNQ_PGBNDY_WSEL 0x7
#define BIT_BCNQ_PGBNDY_WSEL(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_WSEL) << BIT_SHIFT_BCNQ_PGBNDY_WSEL)
#define BITS_BCNQ_PGBNDY_WSEL \
(BIT_MASK_BCNQ_PGBNDY_WSEL << BIT_SHIFT_BCNQ_PGBNDY_WSEL)
#define BIT_CLEAR_BCNQ_PGBNDY_WSEL(x) ((x) & (~BITS_BCNQ_PGBNDY_WSEL))
#define BIT_GET_BCNQ_PGBNDY_WSEL(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_WSEL) & BIT_MASK_BCNQ_PGBNDY_WSEL)
#define BIT_SET_BCNQ_PGBNDY_WSEL(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_WSEL(x) | BIT_BCNQ_PGBNDY_WSEL(v))
#define BIT_SHIFT_BCNQ_PGBNDY_RCONTENT 12
#define BIT_MASK_BCNQ_PGBNDY_RCONTENT 0xfff
#define BIT_BCNQ_PGBNDY_RCONTENT(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_RCONTENT) \
<< BIT_SHIFT_BCNQ_PGBNDY_RCONTENT)
#define BITS_BCNQ_PGBNDY_RCONTENT \
(BIT_MASK_BCNQ_PGBNDY_RCONTENT << BIT_SHIFT_BCNQ_PGBNDY_RCONTENT)
#define BIT_CLEAR_BCNQ_PGBNDY_RCONTENT(x) ((x) & (~BITS_BCNQ_PGBNDY_RCONTENT))
#define BIT_GET_BCNQ_PGBNDY_RCONTENT(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_RCONTENT) & \
BIT_MASK_BCNQ_PGBNDY_RCONTENT)
#define BIT_SET_BCNQ_PGBNDY_RCONTENT(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_RCONTENT(x) | BIT_BCNQ_PGBNDY_RCONTENT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCNQ_INFO (Offset 0x0418) */
#define BIT_SHIFT_PKT_NUM_BCNQ 8
#define BIT_MASK_PKT_NUM_BCNQ 0xff
#define BIT_PKT_NUM_BCNQ(x) \
(((x) & BIT_MASK_PKT_NUM_BCNQ) << BIT_SHIFT_PKT_NUM_BCNQ)
#define BITS_PKT_NUM_BCNQ (BIT_MASK_PKT_NUM_BCNQ << BIT_SHIFT_PKT_NUM_BCNQ)
#define BIT_CLEAR_PKT_NUM_BCNQ(x) ((x) & (~BITS_PKT_NUM_BCNQ))
#define BIT_GET_PKT_NUM_BCNQ(x) \
(((x) >> BIT_SHIFT_PKT_NUM_BCNQ) & BIT_MASK_PKT_NUM_BCNQ)
#define BIT_SET_PKT_NUM_BCNQ(x, v) \
(BIT_CLEAR_PKT_NUM_BCNQ(x) | BIT_PKT_NUM_BCNQ(v))
#define BIT_SHIFT_BCNQ_HEAD_PG 0
#define BIT_MASK_BCNQ_HEAD_PG 0xff
#define BIT_BCNQ_HEAD_PG(x) \
(((x) & BIT_MASK_BCNQ_HEAD_PG) << BIT_SHIFT_BCNQ_HEAD_PG)
#define BITS_BCNQ_HEAD_PG (BIT_MASK_BCNQ_HEAD_PG << BIT_SHIFT_BCNQ_HEAD_PG)
#define BIT_CLEAR_BCNQ_HEAD_PG(x) ((x) & (~BITS_BCNQ_HEAD_PG))
#define BIT_GET_BCNQ_HEAD_PG(x) \
(((x) >> BIT_SHIFT_BCNQ_HEAD_PG) & BIT_MASK_BCNQ_HEAD_PG)
#define BIT_SET_BCNQ_HEAD_PG(x, v) \
(BIT_CLEAR_BCNQ_HEAD_PG(x) | BIT_BCNQ_HEAD_PG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCNQ_INFO (Offset 0x0418) */
#define BIT_SHIFT_BCNQ_HEAD_PG_V1 0
#define BIT_MASK_BCNQ_HEAD_PG_V1 0xfff
#define BIT_BCNQ_HEAD_PG_V1(x) \
(((x) & BIT_MASK_BCNQ_HEAD_PG_V1) << BIT_SHIFT_BCNQ_HEAD_PG_V1)
#define BITS_BCNQ_HEAD_PG_V1 \
(BIT_MASK_BCNQ_HEAD_PG_V1 << BIT_SHIFT_BCNQ_HEAD_PG_V1)
#define BIT_CLEAR_BCNQ_HEAD_PG_V1(x) ((x) & (~BITS_BCNQ_HEAD_PG_V1))
#define BIT_GET_BCNQ_HEAD_PG_V1(x) \
(((x) >> BIT_SHIFT_BCNQ_HEAD_PG_V1) & BIT_MASK_BCNQ_HEAD_PG_V1)
#define BIT_SET_BCNQ_HEAD_PG_V1(x, v) \
(BIT_CLEAR_BCNQ_HEAD_PG_V1(x) | BIT_BCNQ_HEAD_PG_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCNQ_BDNY_V2 (Offset 0x0418) */
#define BIT_SHIFT_BCNQ_PGBNDY_WCONTENT 0
#define BIT_MASK_BCNQ_PGBNDY_WCONTENT 0xfff
#define BIT_BCNQ_PGBNDY_WCONTENT(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_WCONTENT) \
<< BIT_SHIFT_BCNQ_PGBNDY_WCONTENT)
#define BITS_BCNQ_PGBNDY_WCONTENT \
(BIT_MASK_BCNQ_PGBNDY_WCONTENT << BIT_SHIFT_BCNQ_PGBNDY_WCONTENT)
#define BIT_CLEAR_BCNQ_PGBNDY_WCONTENT(x) ((x) & (~BITS_BCNQ_PGBNDY_WCONTENT))
#define BIT_GET_BCNQ_PGBNDY_WCONTENT(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_WCONTENT) & \
BIT_MASK_BCNQ_PGBNDY_WCONTENT)
#define BIT_SET_BCNQ_PGBNDY_WCONTENT(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_WCONTENT(x) | BIT_BCNQ_PGBNDY_WCONTENT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXPKT_EMPTY (Offset 0x041A) */
#define BIT_BCNQ_EMPTY BIT(11)
#define BIT_HQQ_EMPTY BIT(10)
#define BIT_MQQ_EMPTY BIT(9)
#define BIT_MGQ_CPU_EMPTY BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_BCN_POLL2 BIT(31)
#define BIT_BCN_POLL1 BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_BCN1_POLL BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGT_CLR_V1 BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGT_POLL BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGT_POLL_SET BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_BCN_POLL BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGT_POLL_CLR BIT(27)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGT_CLR BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_EVTQ_VALID BIT(26)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_BCN_EXT_POLL BIT(21)
#define BIT_BCN4_POLL BIT(20)
#define BIT_BCN3_POLL BIT(19)
#define BIT_BCN2_POLL BIT(18)
#define BIT_BCN1_POLL_V1 BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_EN_RTY_BK_COND BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_BCN_POLL_V1 BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGQ_FW_NUM_V1 BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_CPUMGQ_FW_NUM BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_EN_EVTQ_RPT BIT(2)
#define BIT_HWSEQ_EVTQ_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_SHIFT_CPUMGQ_HEAD_PG 0
#define BIT_MASK_CPUMGQ_HEAD_PG 0xff
#define BIT_CPUMGQ_HEAD_PG(x) \
(((x) & BIT_MASK_CPUMGQ_HEAD_PG) << BIT_SHIFT_CPUMGQ_HEAD_PG)
#define BITS_CPUMGQ_HEAD_PG \
(BIT_MASK_CPUMGQ_HEAD_PG << BIT_SHIFT_CPUMGQ_HEAD_PG)
#define BIT_CLEAR_CPUMGQ_HEAD_PG(x) ((x) & (~BITS_CPUMGQ_HEAD_PG))
#define BIT_GET_CPUMGQ_HEAD_PG(x) \
(((x) >> BIT_SHIFT_CPUMGQ_HEAD_PG) & BIT_MASK_CPUMGQ_HEAD_PG)
#define BIT_SET_CPUMGQ_HEAD_PG(x, v) \
(BIT_CLEAR_CPUMGQ_HEAD_PG(x) | BIT_CPUMGQ_HEAD_PG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_SHIFT_FW_FREE_TAIL_V1 0
#define BIT_MASK_FW_FREE_TAIL_V1 0xfff
#define BIT_FW_FREE_TAIL_V1(x) \
(((x) & BIT_MASK_FW_FREE_TAIL_V1) << BIT_SHIFT_FW_FREE_TAIL_V1)
#define BITS_FW_FREE_TAIL_V1 \
(BIT_MASK_FW_FREE_TAIL_V1 << BIT_SHIFT_FW_FREE_TAIL_V1)
#define BIT_CLEAR_FW_FREE_TAIL_V1(x) ((x) & (~BITS_FW_FREE_TAIL_V1))
#define BIT_GET_FW_FREE_TAIL_V1(x) \
(((x) >> BIT_SHIFT_FW_FREE_TAIL_V1) & BIT_MASK_FW_FREE_TAIL_V1)
#define BIT_SET_FW_FREE_TAIL_V1(x, v) \
(BIT_CLEAR_FW_FREE_TAIL_V1(x) | BIT_FW_FREE_TAIL_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPU_MGQ_INFO (Offset 0x041C) */
#define BIT_SHIFT_FREE_TAIL_PAGE 0
#define BIT_MASK_FREE_TAIL_PAGE 0xfff
#define BIT_FREE_TAIL_PAGE(x) \
(((x) & BIT_MASK_FREE_TAIL_PAGE) << BIT_SHIFT_FREE_TAIL_PAGE)
#define BITS_FREE_TAIL_PAGE \
(BIT_MASK_FREE_TAIL_PAGE << BIT_SHIFT_FREE_TAIL_PAGE)
#define BIT_CLEAR_FREE_TAIL_PAGE(x) ((x) & (~BITS_FREE_TAIL_PAGE))
#define BIT_GET_FREE_TAIL_PAGE(x) \
(((x) >> BIT_SHIFT_FREE_TAIL_PAGE) & BIT_MASK_FREE_TAIL_PAGE)
#define BIT_SET_FREE_TAIL_PAGE(x, v) \
(BIT_CLEAR_FREE_TAIL_PAGE(x) | BIT_FREE_TAIL_PAGE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_RTS_LIMIT_IN_OFDM BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_BCNQ_DL BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_RD_RESP_NAV_BK BIT(21)
#define BIT_EN_WR_FREE_TAIL BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_TXRPT_DIS BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_NOTXRPT_USERATE_EN BIT(19)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_DIS_TXFAIL_RPT BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_FTM_TIMEOUT_BYPASS BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_BCNQ_DL5 BIT(13)
#define BIT_EN_BCNQ_DL4 BIT(12)
#define BIT_EN_BCNQ_DL3 BIT(11)
#define BIT_EN_BCNQ_DL2 BIT(10)
#define BIT_EN_BCNQ_DL1 BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_SHIFT_EN_QUEUE_RPT 8
#define BIT_MASK_EN_QUEUE_RPT 0xff
#define BIT_EN_QUEUE_RPT(x) \
(((x) & BIT_MASK_EN_QUEUE_RPT) << BIT_SHIFT_EN_QUEUE_RPT)
#define BITS_EN_QUEUE_RPT (BIT_MASK_EN_QUEUE_RPT << BIT_SHIFT_EN_QUEUE_RPT)
#define BIT_CLEAR_EN_QUEUE_RPT(x) ((x) & (~BITS_EN_QUEUE_RPT))
#define BIT_GET_EN_QUEUE_RPT(x) \
(((x) >> BIT_SHIFT_EN_QUEUE_RPT) & BIT_MASK_EN_QUEUE_RPT)
#define BIT_SET_EN_QUEUE_RPT(x, v) \
(BIT_CLEAR_EN_QUEUE_RPT(x) | BIT_EN_QUEUE_RPT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_BCNQ_DL0 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_RTY_BK BIT(7)
#define BIT_EN_USE_INI_RAT BIT(6)
#define BIT_EN_RTS_NAV_BK BIT(5)
#define BIT_DIS_SSN_CHECK BIT(4)
#define BIT_MACID_MATCH_RTS BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_BCN_TRXRPT_V1 BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_R_EN_FTMRPT BIT(1)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_R_EN_FTMRPT_V1 BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_FTMRPT_V1 BIT(1)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_FTMACKRPT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_R_BMC_NAV_PROTECT BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_BMC_NAV_PROTECT BIT(0)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_FWHW_TXQ_CTRL (Offset 0x0420) */
#define BIT_EN_FTMRPT BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HWSEQ_CTRL (Offset 0x0423) */
#define BIT_HWSEQ_CPUM_EN BIT(7)
#define BIT_HWSEQ_BCN_EN BIT(6)
#define BIT_HWSEQ_HI_EN BIT(5)
#define BIT_HWSEQ_MGT_EN BIT(4)
#define BIT_HWSEQ_BK_EN BIT(3)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DATAFB_SEL (Offset 0x0423) */
#define BIT_BROADCAST_RTY_EN BIT(3)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_DATAFB_SEL (Offset 0x0423) */
#define BIT_R_BROADCAST_RETRY_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HWSEQ_CTRL (Offset 0x0423) */
#define BIT_HWSEQ_BE_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DATAFB_SEL (Offset 0x0423) */
#define BIT__R_EN_RTY_BK_COD BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DATAFB_SEL (Offset 0x0423) */
#define BIT_EN_RTY_BK_COD BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HWSEQ_CTRL (Offset 0x0423) */
#define BIT_HWSEQ_VI_EN BIT(1)
#define BIT_HWSEQ_VO_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DATAFB_SEL (Offset 0x0423) */
#define BIT_SHIFT__R_DATA_FALLBACK_SEL 0
#define BIT_MASK__R_DATA_FALLBACK_SEL 0x3
#define BIT__R_DATA_FALLBACK_SEL(x) \
(((x) & BIT_MASK__R_DATA_FALLBACK_SEL) \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL)
#define BITS__R_DATA_FALLBACK_SEL \
(BIT_MASK__R_DATA_FALLBACK_SEL << BIT_SHIFT__R_DATA_FALLBACK_SEL)
#define BIT_CLEAR__R_DATA_FALLBACK_SEL(x) ((x) & (~BITS__R_DATA_FALLBACK_SEL))
#define BIT_GET__R_DATA_FALLBACK_SEL(x) \
(((x) >> BIT_SHIFT__R_DATA_FALLBACK_SEL) & \
BIT_MASK__R_DATA_FALLBACK_SEL)
#define BIT_SET__R_DATA_FALLBACK_SEL(x, v) \
(BIT_CLEAR__R_DATA_FALLBACK_SEL(x) | BIT__R_DATA_FALLBACK_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATAFB_SEL (Offset 0x0423) */
#define BIT_SHIFT__DATA_FALLBACK_SEL 0
#define BIT_MASK__DATA_FALLBACK_SEL 0x3
#define BIT__DATA_FALLBACK_SEL(x) \
(((x) & BIT_MASK__DATA_FALLBACK_SEL) << BIT_SHIFT__DATA_FALLBACK_SEL)
#define BITS__DATA_FALLBACK_SEL \
(BIT_MASK__DATA_FALLBACK_SEL << BIT_SHIFT__DATA_FALLBACK_SEL)
#define BIT_CLEAR__DATA_FALLBACK_SEL(x) ((x) & (~BITS__DATA_FALLBACK_SEL))
#define BIT_GET__DATA_FALLBACK_SEL(x) \
(((x) >> BIT_SHIFT__DATA_FALLBACK_SEL) & BIT_MASK__DATA_FALLBACK_SEL)
#define BIT_SET__DATA_FALLBACK_SEL(x, v) \
(BIT_CLEAR__DATA_FALLBACK_SEL(x) | BIT__DATA_FALLBACK_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_BCNQ_BDNY (Offset 0x0424) */
#define BIT_SHIFT_MGQ_PGBNDY_V2 8
#define BIT_MASK_MGQ_PGBNDY_V2 0xff
#define BIT_MGQ_PGBNDY_V2(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V2) << BIT_SHIFT_MGQ_PGBNDY_V2)
#define BITS_MGQ_PGBNDY_V2 (BIT_MASK_MGQ_PGBNDY_V2 << BIT_SHIFT_MGQ_PGBNDY_V2)
#define BIT_CLEAR_MGQ_PGBNDY_V2(x) ((x) & (~BITS_MGQ_PGBNDY_V2))
#define BIT_GET_MGQ_PGBNDY_V2(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V2) & BIT_MASK_MGQ_PGBNDY_V2)
#define BIT_SET_MGQ_PGBNDY_V2(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V2(x) | BIT_MGQ_PGBNDY_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCNQ_BDNY (Offset 0x0424) */
#define BIT_SHIFT_BCNQ_PGBNDY 0
#define BIT_MASK_BCNQ_PGBNDY 0xff
#define BIT_BCNQ_PGBNDY(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY) << BIT_SHIFT_BCNQ_PGBNDY)
#define BITS_BCNQ_PGBNDY (BIT_MASK_BCNQ_PGBNDY << BIT_SHIFT_BCNQ_PGBNDY)
#define BIT_CLEAR_BCNQ_PGBNDY(x) ((x) & (~BITS_BCNQ_PGBNDY))
#define BIT_GET_BCNQ_PGBNDY(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY) & BIT_MASK_BCNQ_PGBNDY)
#define BIT_SET_BCNQ_PGBNDY(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY(x) | BIT_BCNQ_PGBNDY(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCNQ_BDNY_V1 (Offset 0x0424) */
#define BIT_SHIFT_BCNQ_PGBNDY_V1 0
#define BIT_MASK_BCNQ_PGBNDY_V1 0xfff
#define BIT_BCNQ_PGBNDY_V1(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_V1) << BIT_SHIFT_BCNQ_PGBNDY_V1)
#define BITS_BCNQ_PGBNDY_V1 \
(BIT_MASK_BCNQ_PGBNDY_V1 << BIT_SHIFT_BCNQ_PGBNDY_V1)
#define BIT_CLEAR_BCNQ_PGBNDY_V1(x) ((x) & (~BITS_BCNQ_PGBNDY_V1))
#define BIT_GET_BCNQ_PGBNDY_V1(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_V1) & BIT_MASK_BCNQ_PGBNDY_V1)
#define BIT_SET_BCNQ_PGBNDY_V1(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_V1(x) | BIT_BCNQ_PGBNDY_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXBDNY (Offset 0x0424) */
#define BIT_SHIFT_TXBNDY 0
#define BIT_MASK_TXBNDY 0xfff
#define BIT_TXBNDY(x) (((x) & BIT_MASK_TXBNDY) << BIT_SHIFT_TXBNDY)
#define BITS_TXBNDY (BIT_MASK_TXBNDY << BIT_SHIFT_TXBNDY)
#define BIT_CLEAR_TXBNDY(x) ((x) & (~BITS_TXBNDY))
#define BIT_GET_TXBNDY(x) (((x) >> BIT_SHIFT_TXBNDY) & BIT_MASK_TXBNDY)
#define BIT_SET_TXBNDY(x, v) (BIT_CLEAR_TXBNDY(x) | BIT_TXBNDY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MGQ_BDNY (Offset 0x0425) */
#define BIT_SHIFT_MGQ_PGBNDY 0
#define BIT_MASK_MGQ_PGBNDY 0xff
#define BIT_MGQ_PGBNDY(x) (((x) & BIT_MASK_MGQ_PGBNDY) << BIT_SHIFT_MGQ_PGBNDY)
#define BITS_MGQ_PGBNDY (BIT_MASK_MGQ_PGBNDY << BIT_SHIFT_MGQ_PGBNDY)
#define BIT_CLEAR_MGQ_PGBNDY(x) ((x) & (~BITS_MGQ_PGBNDY))
#define BIT_GET_MGQ_PGBNDY(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY) & BIT_MASK_MGQ_PGBNDY)
#define BIT_SET_MGQ_PGBNDY(x, v) (BIT_CLEAR_MGQ_PGBNDY(x) | BIT_MGQ_PGBNDY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LIFETIME_EN (Offset 0x0426) */
#define BIT_BT_INT_CPU BIT(7)
#define BIT_BT_INT_PTA BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LIFETIME_EN (Offset 0x0426) */
#define BIT_SPERPT_ENTRY BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LIFETIME_EN (Offset 0x0426) */
#define BIT_RTYCNT_FB BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LIFETIME_EN (Offset 0x0426) */
#define BIT_EN_CTRL_RTYBIT BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LIFETIME_EN (Offset 0x0426) */
#define BIT_LIFETIME_BK_EN BIT(3)
#define BIT_LIFETIME_BE_EN BIT(2)
#define BIT_LIFETIME_VI_EN BIT(1)
#define BIT_LIFETIME_VO_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FW_FREE_TAIL (Offset 0x0427) */
#define BIT_SHIFT_FW_FREE_TAIL 0
#define BIT_MASK_FW_FREE_TAIL 0xff
#define BIT_FW_FREE_TAIL(x) \
(((x) & BIT_MASK_FW_FREE_TAIL) << BIT_SHIFT_FW_FREE_TAIL)
#define BITS_FW_FREE_TAIL (BIT_MASK_FW_FREE_TAIL << BIT_SHIFT_FW_FREE_TAIL)
#define BIT_CLEAR_FW_FREE_TAIL(x) ((x) & (~BITS_FW_FREE_TAIL))
#define BIT_GET_FW_FREE_TAIL(x) \
(((x) >> BIT_SHIFT_FW_FREE_TAIL) & BIT_MASK_FW_FREE_TAIL)
#define BIT_SET_FW_FREE_TAIL(x, v) \
(BIT_CLEAR_FW_FREE_TAIL(x) | BIT_FW_FREE_TAIL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SPEC_SIFS (Offset 0x0428) */
#define BIT_SHIFT_SPEC_SIFS_OFDM_PTCL 8
#define BIT_MASK_SPEC_SIFS_OFDM_PTCL 0xff
#define BIT_SPEC_SIFS_OFDM_PTCL(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_PTCL) << BIT_SHIFT_SPEC_SIFS_OFDM_PTCL)
#define BITS_SPEC_SIFS_OFDM_PTCL \
(BIT_MASK_SPEC_SIFS_OFDM_PTCL << BIT_SHIFT_SPEC_SIFS_OFDM_PTCL)
#define BIT_CLEAR_SPEC_SIFS_OFDM_PTCL(x) ((x) & (~BITS_SPEC_SIFS_OFDM_PTCL))
#define BIT_GET_SPEC_SIFS_OFDM_PTCL(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_PTCL) & BIT_MASK_SPEC_SIFS_OFDM_PTCL)
#define BIT_SET_SPEC_SIFS_OFDM_PTCL(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_PTCL(x) | BIT_SPEC_SIFS_OFDM_PTCL(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_PTCL 0
#define BIT_MASK_SPEC_SIFS_CCK_PTCL 0xff
#define BIT_SPEC_SIFS_CCK_PTCL(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_PTCL) << BIT_SHIFT_SPEC_SIFS_CCK_PTCL)
#define BITS_SPEC_SIFS_CCK_PTCL \
(BIT_MASK_SPEC_SIFS_CCK_PTCL << BIT_SHIFT_SPEC_SIFS_CCK_PTCL)
#define BIT_CLEAR_SPEC_SIFS_CCK_PTCL(x) ((x) & (~BITS_SPEC_SIFS_CCK_PTCL))
#define BIT_GET_SPEC_SIFS_CCK_PTCL(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_PTCL) & BIT_MASK_SPEC_SIFS_CCK_PTCL)
#define BIT_SET_SPEC_SIFS_CCK_PTCL(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_PTCL(x) | BIT_SPEC_SIFS_CCK_PTCL(v))
/* 2 REG_RETRY_LIMIT (Offset 0x042A) */
#define BIT_SHIFT_SRL 8
#define BIT_MASK_SRL 0x3f
#define BIT_SRL(x) (((x) & BIT_MASK_SRL) << BIT_SHIFT_SRL)
#define BITS_SRL (BIT_MASK_SRL << BIT_SHIFT_SRL)
#define BIT_CLEAR_SRL(x) ((x) & (~BITS_SRL))
#define BIT_GET_SRL(x) (((x) >> BIT_SHIFT_SRL) & BIT_MASK_SRL)
#define BIT_SET_SRL(x, v) (BIT_CLEAR_SRL(x) | BIT_SRL(v))
#define BIT_SHIFT_LRL 0
#define BIT_MASK_LRL 0x3f
#define BIT_LRL(x) (((x) & BIT_MASK_LRL) << BIT_SHIFT_LRL)
#define BITS_LRL (BIT_MASK_LRL << BIT_SHIFT_LRL)
#define BIT_CLEAR_LRL(x) ((x) & (~BITS_LRL))
#define BIT_GET_LRL(x) (((x) >> BIT_SHIFT_LRL) & BIT_MASK_LRL)
#define BIT_SET_LRL(x, v) (BIT_CLEAR_LRL(x) | BIT_LRL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_ENABLE_NDPA BIT(31)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_ENABLE_NDPA BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_USE_NDPA_PARAMETER BIT(30)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_NDPA_PARA BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_PROP_TXBF BIT(29)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_PROP_TXBF BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_EN_NDPA_INT BIT(28)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_EN_NDPA_INT BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBF1_80M BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF1_80M BIT(27)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF1_80M_160M BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBF1_40M BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF1_40M BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBF1_20M BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF1_20M BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_SHIFT_R_TXBF1_AID 16
#define BIT_MASK_R_TXBF1_AID 0x1ff
#define BIT_R_TXBF1_AID(x) \
(((x) & BIT_MASK_R_TXBF1_AID) << BIT_SHIFT_R_TXBF1_AID)
#define BITS_R_TXBF1_AID (BIT_MASK_R_TXBF1_AID << BIT_SHIFT_R_TXBF1_AID)
#define BIT_CLEAR_R_TXBF1_AID(x) ((x) & (~BITS_R_TXBF1_AID))
#define BIT_GET_R_TXBF1_AID(x) \
(((x) >> BIT_SHIFT_R_TXBF1_AID) & BIT_MASK_R_TXBF1_AID)
#define BIT_SET_R_TXBF1_AID(x, v) \
(BIT_CLEAR_R_TXBF1_AID(x) | BIT_R_TXBF1_AID(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_SHIFT_TXBF1_AID 16
#define BIT_MASK_TXBF1_AID 0x1ff
#define BIT_TXBF1_AID(x) (((x) & BIT_MASK_TXBF1_AID) << BIT_SHIFT_TXBF1_AID)
#define BITS_TXBF1_AID (BIT_MASK_TXBF1_AID << BIT_SHIFT_TXBF1_AID)
#define BIT_CLEAR_TXBF1_AID(x) ((x) & (~BITS_TXBF1_AID))
#define BIT_GET_TXBF1_AID(x) (((x) >> BIT_SHIFT_TXBF1_AID) & BIT_MASK_TXBF1_AID)
#define BIT_SET_TXBF1_AID(x, v) (BIT_CLEAR_TXBF1_AID(x) | BIT_TXBF1_AID(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_DIS_NDP_BFEN BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBCN_NOBLOCK_NDP BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBCN_NOBLOCK_NDP BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBF0_80M BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF0_80M BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF0_80M_160M BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBF0_40M BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF0_40M BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_R_TXBF0_20M BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_TXBF0_20M BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_SHIFT_R_TXBF0_AID 0
#define BIT_MASK_R_TXBF0_AID 0x1ff
#define BIT_R_TXBF0_AID(x) \
(((x) & BIT_MASK_R_TXBF0_AID) << BIT_SHIFT_R_TXBF0_AID)
#define BITS_R_TXBF0_AID (BIT_MASK_R_TXBF0_AID << BIT_SHIFT_R_TXBF0_AID)
#define BIT_CLEAR_R_TXBF0_AID(x) ((x) & (~BITS_R_TXBF0_AID))
#define BIT_GET_R_TXBF0_AID(x) \
(((x) >> BIT_SHIFT_R_TXBF0_AID) & BIT_MASK_R_TXBF0_AID)
#define BIT_SET_R_TXBF0_AID(x, v) \
(BIT_CLEAR_R_TXBF0_AID(x) | BIT_R_TXBF0_AID(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TXBF_CTRL (Offset 0x042C) */
#define BIT_SHIFT_TXBF0_AID 0
#define BIT_MASK_TXBF0_AID 0x1ff
#define BIT_TXBF0_AID(x) (((x) & BIT_MASK_TXBF0_AID) << BIT_SHIFT_TXBF0_AID)
#define BITS_TXBF0_AID (BIT_MASK_TXBF0_AID << BIT_SHIFT_TXBF0_AID)
#define BIT_CLEAR_TXBF0_AID(x) ((x) & (~BITS_TXBF0_AID))
#define BIT_GET_TXBF0_AID(x) (((x) >> BIT_SHIFT_TXBF0_AID) & BIT_MASK_TXBF0_AID)
#define BIT_SET_TXBF0_AID(x, v) (BIT_CLEAR_TXBF0_AID(x) | BIT_TXBF0_AID(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC8 (56 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC8 0x1f
#define BIT_DARF_RC8(x) (((x) & BIT_MASK_DARF_RC8) << BIT_SHIFT_DARF_RC8)
#define BITS_DARF_RC8 (BIT_MASK_DARF_RC8 << BIT_SHIFT_DARF_RC8)
#define BIT_CLEAR_DARF_RC8(x) ((x) & (~BITS_DARF_RC8))
#define BIT_GET_DARF_RC8(x) (((x) >> BIT_SHIFT_DARF_RC8) & BIT_MASK_DARF_RC8)
#define BIT_SET_DARF_RC8(x, v) (BIT_CLEAR_DARF_RC8(x) | BIT_DARF_RC8(v))
#define BIT_SHIFT_DARF_RC7 (48 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC7 0x1f
#define BIT_DARF_RC7(x) (((x) & BIT_MASK_DARF_RC7) << BIT_SHIFT_DARF_RC7)
#define BITS_DARF_RC7 (BIT_MASK_DARF_RC7 << BIT_SHIFT_DARF_RC7)
#define BIT_CLEAR_DARF_RC7(x) ((x) & (~BITS_DARF_RC7))
#define BIT_GET_DARF_RC7(x) (((x) >> BIT_SHIFT_DARF_RC7) & BIT_MASK_DARF_RC7)
#define BIT_SET_DARF_RC7(x, v) (BIT_CLEAR_DARF_RC7(x) | BIT_DARF_RC7(v))
#define BIT_SHIFT_DARF_RC6 (40 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC6 0x1f
#define BIT_DARF_RC6(x) (((x) & BIT_MASK_DARF_RC6) << BIT_SHIFT_DARF_RC6)
#define BITS_DARF_RC6 (BIT_MASK_DARF_RC6 << BIT_SHIFT_DARF_RC6)
#define BIT_CLEAR_DARF_RC6(x) ((x) & (~BITS_DARF_RC6))
#define BIT_GET_DARF_RC6(x) (((x) >> BIT_SHIFT_DARF_RC6) & BIT_MASK_DARF_RC6)
#define BIT_SET_DARF_RC6(x, v) (BIT_CLEAR_DARF_RC6(x) | BIT_DARF_RC6(v))
#define BIT_SHIFT_DARF_RC5 (32 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC5 0x1f
#define BIT_DARF_RC5(x) (((x) & BIT_MASK_DARF_RC5) << BIT_SHIFT_DARF_RC5)
#define BITS_DARF_RC5 (BIT_MASK_DARF_RC5 << BIT_SHIFT_DARF_RC5)
#define BIT_CLEAR_DARF_RC5(x) ((x) & (~BITS_DARF_RC5))
#define BIT_GET_DARF_RC5(x) (((x) >> BIT_SHIFT_DARF_RC5) & BIT_MASK_DARF_RC5)
#define BIT_SET_DARF_RC5(x, v) (BIT_CLEAR_DARF_RC5(x) | BIT_DARF_RC5(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC4 24
#define BIT_MASK_DARF_RC4 0x1f
#define BIT_DARF_RC4(x) (((x) & BIT_MASK_DARF_RC4) << BIT_SHIFT_DARF_RC4)
#define BITS_DARF_RC4 (BIT_MASK_DARF_RC4 << BIT_SHIFT_DARF_RC4)
#define BIT_CLEAR_DARF_RC4(x) ((x) & (~BITS_DARF_RC4))
#define BIT_GET_DARF_RC4(x) (((x) >> BIT_SHIFT_DARF_RC4) & BIT_MASK_DARF_RC4)
#define BIT_SET_DARF_RC4(x, v) (BIT_CLEAR_DARF_RC4(x) | BIT_DARF_RC4(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC4_V2 24
#define BIT_MASK_DARF_RC4_V2 0x1f
#define BIT_DARF_RC4_V2(x) \
(((x) & BIT_MASK_DARF_RC4_V2) << BIT_SHIFT_DARF_RC4_V2)
#define BITS_DARF_RC4_V2 (BIT_MASK_DARF_RC4_V2 << BIT_SHIFT_DARF_RC4_V2)
#define BIT_CLEAR_DARF_RC4_V2(x) ((x) & (~BITS_DARF_RC4_V2))
#define BIT_GET_DARF_RC4_V2(x) \
(((x) >> BIT_SHIFT_DARF_RC4_V2) & BIT_MASK_DARF_RC4_V2)
#define BIT_SET_DARF_RC4_V2(x, v) \
(BIT_CLEAR_DARF_RC4_V2(x) | BIT_DARF_RC4_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC4_V1 24
#define BIT_MASK_DARF_RC4_V1 0x3f
#define BIT_DARF_RC4_V1(x) \
(((x) & BIT_MASK_DARF_RC4_V1) << BIT_SHIFT_DARF_RC4_V1)
#define BITS_DARF_RC4_V1 (BIT_MASK_DARF_RC4_V1 << BIT_SHIFT_DARF_RC4_V1)
#define BIT_CLEAR_DARF_RC4_V1(x) ((x) & (~BITS_DARF_RC4_V1))
#define BIT_GET_DARF_RC4_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC4_V1) & BIT_MASK_DARF_RC4_V1)
#define BIT_SET_DARF_RC4_V1(x, v) \
(BIT_CLEAR_DARF_RC4_V1(x) | BIT_DARF_RC4_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC3 16
#define BIT_MASK_DARF_RC3 0x1f
#define BIT_DARF_RC3(x) (((x) & BIT_MASK_DARF_RC3) << BIT_SHIFT_DARF_RC3)
#define BITS_DARF_RC3 (BIT_MASK_DARF_RC3 << BIT_SHIFT_DARF_RC3)
#define BIT_CLEAR_DARF_RC3(x) ((x) & (~BITS_DARF_RC3))
#define BIT_GET_DARF_RC3(x) (((x) >> BIT_SHIFT_DARF_RC3) & BIT_MASK_DARF_RC3)
#define BIT_SET_DARF_RC3(x, v) (BIT_CLEAR_DARF_RC3(x) | BIT_DARF_RC3(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC3_V2 16
#define BIT_MASK_DARF_RC3_V2 0x1f
#define BIT_DARF_RC3_V2(x) \
(((x) & BIT_MASK_DARF_RC3_V2) << BIT_SHIFT_DARF_RC3_V2)
#define BITS_DARF_RC3_V2 (BIT_MASK_DARF_RC3_V2 << BIT_SHIFT_DARF_RC3_V2)
#define BIT_CLEAR_DARF_RC3_V2(x) ((x) & (~BITS_DARF_RC3_V2))
#define BIT_GET_DARF_RC3_V2(x) \
(((x) >> BIT_SHIFT_DARF_RC3_V2) & BIT_MASK_DARF_RC3_V2)
#define BIT_SET_DARF_RC3_V2(x, v) \
(BIT_CLEAR_DARF_RC3_V2(x) | BIT_DARF_RC3_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC3_V1 16
#define BIT_MASK_DARF_RC3_V1 0x3f
#define BIT_DARF_RC3_V1(x) \
(((x) & BIT_MASK_DARF_RC3_V1) << BIT_SHIFT_DARF_RC3_V1)
#define BITS_DARF_RC3_V1 (BIT_MASK_DARF_RC3_V1 << BIT_SHIFT_DARF_RC3_V1)
#define BIT_CLEAR_DARF_RC3_V1(x) ((x) & (~BITS_DARF_RC3_V1))
#define BIT_GET_DARF_RC3_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC3_V1) & BIT_MASK_DARF_RC3_V1)
#define BIT_SET_DARF_RC3_V1(x, v) \
(BIT_CLEAR_DARF_RC3_V1(x) | BIT_DARF_RC3_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC2 8
#define BIT_MASK_DARF_RC2 0x1f
#define BIT_DARF_RC2(x) (((x) & BIT_MASK_DARF_RC2) << BIT_SHIFT_DARF_RC2)
#define BITS_DARF_RC2 (BIT_MASK_DARF_RC2 << BIT_SHIFT_DARF_RC2)
#define BIT_CLEAR_DARF_RC2(x) ((x) & (~BITS_DARF_RC2))
#define BIT_GET_DARF_RC2(x) (((x) >> BIT_SHIFT_DARF_RC2) & BIT_MASK_DARF_RC2)
#define BIT_SET_DARF_RC2(x, v) (BIT_CLEAR_DARF_RC2(x) | BIT_DARF_RC2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC2_V2 8
#define BIT_MASK_DARF_RC2_V2 0x1f
#define BIT_DARF_RC2_V2(x) \
(((x) & BIT_MASK_DARF_RC2_V2) << BIT_SHIFT_DARF_RC2_V2)
#define BITS_DARF_RC2_V2 (BIT_MASK_DARF_RC2_V2 << BIT_SHIFT_DARF_RC2_V2)
#define BIT_CLEAR_DARF_RC2_V2(x) ((x) & (~BITS_DARF_RC2_V2))
#define BIT_GET_DARF_RC2_V2(x) \
(((x) >> BIT_SHIFT_DARF_RC2_V2) & BIT_MASK_DARF_RC2_V2)
#define BIT_SET_DARF_RC2_V2(x, v) \
(BIT_CLEAR_DARF_RC2_V2(x) | BIT_DARF_RC2_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC2_V1 8
#define BIT_MASK_DARF_RC2_V1 0x3f
#define BIT_DARF_RC2_V1(x) \
(((x) & BIT_MASK_DARF_RC2_V1) << BIT_SHIFT_DARF_RC2_V1)
#define BITS_DARF_RC2_V1 (BIT_MASK_DARF_RC2_V1 << BIT_SHIFT_DARF_RC2_V1)
#define BIT_CLEAR_DARF_RC2_V1(x) ((x) & (~BITS_DARF_RC2_V1))
#define BIT_GET_DARF_RC2_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC2_V1) & BIT_MASK_DARF_RC2_V1)
#define BIT_SET_DARF_RC2_V1(x, v) \
(BIT_CLEAR_DARF_RC2_V1(x) | BIT_DARF_RC2_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC1 0
#define BIT_MASK_DARF_RC1 0x1f
#define BIT_DARF_RC1(x) (((x) & BIT_MASK_DARF_RC1) << BIT_SHIFT_DARF_RC1)
#define BITS_DARF_RC1 (BIT_MASK_DARF_RC1 << BIT_SHIFT_DARF_RC1)
#define BIT_CLEAR_DARF_RC1(x) ((x) & (~BITS_DARF_RC1))
#define BIT_GET_DARF_RC1(x) (((x) >> BIT_SHIFT_DARF_RC1) & BIT_MASK_DARF_RC1)
#define BIT_SET_DARF_RC1(x, v) (BIT_CLEAR_DARF_RC1(x) | BIT_DARF_RC1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC1_V2 0
#define BIT_MASK_DARF_RC1_V2 0x1f
#define BIT_DARF_RC1_V2(x) \
(((x) & BIT_MASK_DARF_RC1_V2) << BIT_SHIFT_DARF_RC1_V2)
#define BITS_DARF_RC1_V2 (BIT_MASK_DARF_RC1_V2 << BIT_SHIFT_DARF_RC1_V2)
#define BIT_CLEAR_DARF_RC1_V2(x) ((x) & (~BITS_DARF_RC1_V2))
#define BIT_GET_DARF_RC1_V2(x) \
(((x) >> BIT_SHIFT_DARF_RC1_V2) & BIT_MASK_DARF_RC1_V2)
#define BIT_SET_DARF_RC1_V2(x, v) \
(BIT_CLEAR_DARF_RC1_V2(x) | BIT_DARF_RC1_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_DARFRC (Offset 0x0430) */
#define BIT_SHIFT_DARF_RC1_V1 0
#define BIT_MASK_DARF_RC1_V1 0x3f
#define BIT_DARF_RC1_V1(x) \
(((x) & BIT_MASK_DARF_RC1_V1) << BIT_SHIFT_DARF_RC1_V1)
#define BITS_DARF_RC1_V1 (BIT_MASK_DARF_RC1_V1 << BIT_SHIFT_DARF_RC1_V1)
#define BIT_CLEAR_DARF_RC1_V1(x) ((x) & (~BITS_DARF_RC1_V1))
#define BIT_GET_DARF_RC1_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC1_V1) & BIT_MASK_DARF_RC1_V1)
#define BIT_SET_DARF_RC1_V1(x, v) \
(BIT_CLEAR_DARF_RC1_V1(x) | BIT_DARF_RC1_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC8_V3 24
#define BIT_MASK_DARF_RC8_V3 0x1f
#define BIT_DARF_RC8_V3(x) \
(((x) & BIT_MASK_DARF_RC8_V3) << BIT_SHIFT_DARF_RC8_V3)
#define BITS_DARF_RC8_V3 (BIT_MASK_DARF_RC8_V3 << BIT_SHIFT_DARF_RC8_V3)
#define BIT_CLEAR_DARF_RC8_V3(x) ((x) & (~BITS_DARF_RC8_V3))
#define BIT_GET_DARF_RC8_V3(x) \
(((x) >> BIT_SHIFT_DARF_RC8_V3) & BIT_MASK_DARF_RC8_V3)
#define BIT_SET_DARF_RC8_V3(x, v) \
(BIT_CLEAR_DARF_RC8_V3(x) | BIT_DARF_RC8_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC8_V1 24
#define BIT_MASK_DARF_RC8_V1 0x1f
#define BIT_DARF_RC8_V1(x) \
(((x) & BIT_MASK_DARF_RC8_V1) << BIT_SHIFT_DARF_RC8_V1)
#define BITS_DARF_RC8_V1 (BIT_MASK_DARF_RC8_V1 << BIT_SHIFT_DARF_RC8_V1)
#define BIT_CLEAR_DARF_RC8_V1(x) ((x) & (~BITS_DARF_RC8_V1))
#define BIT_GET_DARF_RC8_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC8_V1) & BIT_MASK_DARF_RC8_V1)
#define BIT_SET_DARF_RC8_V1(x, v) \
(BIT_CLEAR_DARF_RC8_V1(x) | BIT_DARF_RC8_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC7_V3 16
#define BIT_MASK_DARF_RC7_V3 0x1f
#define BIT_DARF_RC7_V3(x) \
(((x) & BIT_MASK_DARF_RC7_V3) << BIT_SHIFT_DARF_RC7_V3)
#define BITS_DARF_RC7_V3 (BIT_MASK_DARF_RC7_V3 << BIT_SHIFT_DARF_RC7_V3)
#define BIT_CLEAR_DARF_RC7_V3(x) ((x) & (~BITS_DARF_RC7_V3))
#define BIT_GET_DARF_RC7_V3(x) \
(((x) >> BIT_SHIFT_DARF_RC7_V3) & BIT_MASK_DARF_RC7_V3)
#define BIT_SET_DARF_RC7_V3(x, v) \
(BIT_CLEAR_DARF_RC7_V3(x) | BIT_DARF_RC7_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC7_V1 16
#define BIT_MASK_DARF_RC7_V1 0x1f
#define BIT_DARF_RC7_V1(x) \
(((x) & BIT_MASK_DARF_RC7_V1) << BIT_SHIFT_DARF_RC7_V1)
#define BITS_DARF_RC7_V1 (BIT_MASK_DARF_RC7_V1 << BIT_SHIFT_DARF_RC7_V1)
#define BIT_CLEAR_DARF_RC7_V1(x) ((x) & (~BITS_DARF_RC7_V1))
#define BIT_GET_DARF_RC7_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC7_V1) & BIT_MASK_DARF_RC7_V1)
#define BIT_SET_DARF_RC7_V1(x, v) \
(BIT_CLEAR_DARF_RC7_V1(x) | BIT_DARF_RC7_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC6_V3 8
#define BIT_MASK_DARF_RC6_V3 0x1f
#define BIT_DARF_RC6_V3(x) \
(((x) & BIT_MASK_DARF_RC6_V3) << BIT_SHIFT_DARF_RC6_V3)
#define BITS_DARF_RC6_V3 (BIT_MASK_DARF_RC6_V3 << BIT_SHIFT_DARF_RC6_V3)
#define BIT_CLEAR_DARF_RC6_V3(x) ((x) & (~BITS_DARF_RC6_V3))
#define BIT_GET_DARF_RC6_V3(x) \
(((x) >> BIT_SHIFT_DARF_RC6_V3) & BIT_MASK_DARF_RC6_V3)
#define BIT_SET_DARF_RC6_V3(x, v) \
(BIT_CLEAR_DARF_RC6_V3(x) | BIT_DARF_RC6_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC6_V1 8
#define BIT_MASK_DARF_RC6_V1 0x1f
#define BIT_DARF_RC6_V1(x) \
(((x) & BIT_MASK_DARF_RC6_V1) << BIT_SHIFT_DARF_RC6_V1)
#define BITS_DARF_RC6_V1 (BIT_MASK_DARF_RC6_V1 << BIT_SHIFT_DARF_RC6_V1)
#define BIT_CLEAR_DARF_RC6_V1(x) ((x) & (~BITS_DARF_RC6_V1))
#define BIT_GET_DARF_RC6_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC6_V1) & BIT_MASK_DARF_RC6_V1)
#define BIT_SET_DARF_RC6_V1(x, v) \
(BIT_CLEAR_DARF_RC6_V1(x) | BIT_DARF_RC6_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC5_V3 0
#define BIT_MASK_DARF_RC5_V3 0x1f
#define BIT_DARF_RC5_V3(x) \
(((x) & BIT_MASK_DARF_RC5_V3) << BIT_SHIFT_DARF_RC5_V3)
#define BITS_DARF_RC5_V3 (BIT_MASK_DARF_RC5_V3 << BIT_SHIFT_DARF_RC5_V3)
#define BIT_CLEAR_DARF_RC5_V3(x) ((x) & (~BITS_DARF_RC5_V3))
#define BIT_GET_DARF_RC5_V3(x) \
(((x) >> BIT_SHIFT_DARF_RC5_V3) & BIT_MASK_DARF_RC5_V3)
#define BIT_SET_DARF_RC5_V3(x, v) \
(BIT_CLEAR_DARF_RC5_V3(x) | BIT_DARF_RC5_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DARFRCH (Offset 0x0434) */
#define BIT_SHIFT_DARF_RC5_V1 0
#define BIT_MASK_DARF_RC5_V1 0x1f
#define BIT_DARF_RC5_V1(x) \
(((x) & BIT_MASK_DARF_RC5_V1) << BIT_SHIFT_DARF_RC5_V1)
#define BITS_DARF_RC5_V1 (BIT_MASK_DARF_RC5_V1 << BIT_SHIFT_DARF_RC5_V1)
#define BIT_CLEAR_DARF_RC5_V1(x) ((x) & (~BITS_DARF_RC5_V1))
#define BIT_GET_DARF_RC5_V1(x) \
(((x) >> BIT_SHIFT_DARF_RC5_V1) & BIT_MASK_DARF_RC5_V1)
#define BIT_SET_DARF_RC5_V1(x, v) \
(BIT_CLEAR_DARF_RC5_V1(x) | BIT_DARF_RC5_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RARFRC (Offset 0x0438) */
#define BIT_SHIFT_RARF_RC8 (56 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC8 0x1f
#define BIT_RARF_RC8(x) (((x) & BIT_MASK_RARF_RC8) << BIT_SHIFT_RARF_RC8)
#define BITS_RARF_RC8 (BIT_MASK_RARF_RC8 << BIT_SHIFT_RARF_RC8)
#define BIT_CLEAR_RARF_RC8(x) ((x) & (~BITS_RARF_RC8))
#define BIT_GET_RARF_RC8(x) (((x) >> BIT_SHIFT_RARF_RC8) & BIT_MASK_RARF_RC8)
#define BIT_SET_RARF_RC8(x, v) (BIT_CLEAR_RARF_RC8(x) | BIT_RARF_RC8(v))
#define BIT_SHIFT_RARF_RC7 (48 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC7 0x1f
#define BIT_RARF_RC7(x) (((x) & BIT_MASK_RARF_RC7) << BIT_SHIFT_RARF_RC7)
#define BITS_RARF_RC7 (BIT_MASK_RARF_RC7 << BIT_SHIFT_RARF_RC7)
#define BIT_CLEAR_RARF_RC7(x) ((x) & (~BITS_RARF_RC7))
#define BIT_GET_RARF_RC7(x) (((x) >> BIT_SHIFT_RARF_RC7) & BIT_MASK_RARF_RC7)
#define BIT_SET_RARF_RC7(x, v) (BIT_CLEAR_RARF_RC7(x) | BIT_RARF_RC7(v))
#define BIT_SHIFT_RARF_RC6 (40 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC6 0x1f
#define BIT_RARF_RC6(x) (((x) & BIT_MASK_RARF_RC6) << BIT_SHIFT_RARF_RC6)
#define BITS_RARF_RC6 (BIT_MASK_RARF_RC6 << BIT_SHIFT_RARF_RC6)
#define BIT_CLEAR_RARF_RC6(x) ((x) & (~BITS_RARF_RC6))
#define BIT_GET_RARF_RC6(x) (((x) >> BIT_SHIFT_RARF_RC6) & BIT_MASK_RARF_RC6)
#define BIT_SET_RARF_RC6(x, v) (BIT_CLEAR_RARF_RC6(x) | BIT_RARF_RC6(v))
#define BIT_SHIFT_RARF_RC5 (32 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC5 0x1f
#define BIT_RARF_RC5(x) (((x) & BIT_MASK_RARF_RC5) << BIT_SHIFT_RARF_RC5)
#define BITS_RARF_RC5 (BIT_MASK_RARF_RC5 << BIT_SHIFT_RARF_RC5)
#define BIT_CLEAR_RARF_RC5(x) ((x) & (~BITS_RARF_RC5))
#define BIT_GET_RARF_RC5(x) (((x) >> BIT_SHIFT_RARF_RC5) & BIT_MASK_RARF_RC5)
#define BIT_SET_RARF_RC5(x, v) (BIT_CLEAR_RARF_RC5(x) | BIT_RARF_RC5(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RARFRC (Offset 0x0438) */
#define BIT_SHIFT_RARF_RC4 24
#define BIT_MASK_RARF_RC4 0x1f
#define BIT_RARF_RC4(x) (((x) & BIT_MASK_RARF_RC4) << BIT_SHIFT_RARF_RC4)
#define BITS_RARF_RC4 (BIT_MASK_RARF_RC4 << BIT_SHIFT_RARF_RC4)
#define BIT_CLEAR_RARF_RC4(x) ((x) & (~BITS_RARF_RC4))
#define BIT_GET_RARF_RC4(x) (((x) >> BIT_SHIFT_RARF_RC4) & BIT_MASK_RARF_RC4)
#define BIT_SET_RARF_RC4(x, v) (BIT_CLEAR_RARF_RC4(x) | BIT_RARF_RC4(v))
#define BIT_SHIFT_RARF_RC3 16
#define BIT_MASK_RARF_RC3 0x1f
#define BIT_RARF_RC3(x) (((x) & BIT_MASK_RARF_RC3) << BIT_SHIFT_RARF_RC3)
#define BITS_RARF_RC3 (BIT_MASK_RARF_RC3 << BIT_SHIFT_RARF_RC3)
#define BIT_CLEAR_RARF_RC3(x) ((x) & (~BITS_RARF_RC3))
#define BIT_GET_RARF_RC3(x) (((x) >> BIT_SHIFT_RARF_RC3) & BIT_MASK_RARF_RC3)
#define BIT_SET_RARF_RC3(x, v) (BIT_CLEAR_RARF_RC3(x) | BIT_RARF_RC3(v))
#define BIT_SHIFT_RARF_RC2 8
#define BIT_MASK_RARF_RC2 0x1f
#define BIT_RARF_RC2(x) (((x) & BIT_MASK_RARF_RC2) << BIT_SHIFT_RARF_RC2)
#define BITS_RARF_RC2 (BIT_MASK_RARF_RC2 << BIT_SHIFT_RARF_RC2)
#define BIT_CLEAR_RARF_RC2(x) ((x) & (~BITS_RARF_RC2))
#define BIT_GET_RARF_RC2(x) (((x) >> BIT_SHIFT_RARF_RC2) & BIT_MASK_RARF_RC2)
#define BIT_SET_RARF_RC2(x, v) (BIT_CLEAR_RARF_RC2(x) | BIT_RARF_RC2(v))
#define BIT_SHIFT_RARF_RC1 0
#define BIT_MASK_RARF_RC1 0x1f
#define BIT_RARF_RC1(x) (((x) & BIT_MASK_RARF_RC1) << BIT_SHIFT_RARF_RC1)
#define BITS_RARF_RC1 (BIT_MASK_RARF_RC1 << BIT_SHIFT_RARF_RC1)
#define BIT_CLEAR_RARF_RC1(x) ((x) & (~BITS_RARF_RC1))
#define BIT_GET_RARF_RC1(x) (((x) >> BIT_SHIFT_RARF_RC1) & BIT_MASK_RARF_RC1)
#define BIT_SET_RARF_RC1(x, v) (BIT_CLEAR_RARF_RC1(x) | BIT_RARF_RC1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RARFRCH (Offset 0x043C) */
#define BIT_SHIFT_RARF_RC8_V1 24
#define BIT_MASK_RARF_RC8_V1 0x1f
#define BIT_RARF_RC8_V1(x) \
(((x) & BIT_MASK_RARF_RC8_V1) << BIT_SHIFT_RARF_RC8_V1)
#define BITS_RARF_RC8_V1 (BIT_MASK_RARF_RC8_V1 << BIT_SHIFT_RARF_RC8_V1)
#define BIT_CLEAR_RARF_RC8_V1(x) ((x) & (~BITS_RARF_RC8_V1))
#define BIT_GET_RARF_RC8_V1(x) \
(((x) >> BIT_SHIFT_RARF_RC8_V1) & BIT_MASK_RARF_RC8_V1)
#define BIT_SET_RARF_RC8_V1(x, v) \
(BIT_CLEAR_RARF_RC8_V1(x) | BIT_RARF_RC8_V1(v))
#define BIT_SHIFT_RARF_RC7_V1 16
#define BIT_MASK_RARF_RC7_V1 0x1f
#define BIT_RARF_RC7_V1(x) \
(((x) & BIT_MASK_RARF_RC7_V1) << BIT_SHIFT_RARF_RC7_V1)
#define BITS_RARF_RC7_V1 (BIT_MASK_RARF_RC7_V1 << BIT_SHIFT_RARF_RC7_V1)
#define BIT_CLEAR_RARF_RC7_V1(x) ((x) & (~BITS_RARF_RC7_V1))
#define BIT_GET_RARF_RC7_V1(x) \
(((x) >> BIT_SHIFT_RARF_RC7_V1) & BIT_MASK_RARF_RC7_V1)
#define BIT_SET_RARF_RC7_V1(x, v) \
(BIT_CLEAR_RARF_RC7_V1(x) | BIT_RARF_RC7_V1(v))
#define BIT_SHIFT_RARF_RC6_V1 8
#define BIT_MASK_RARF_RC6_V1 0x1f
#define BIT_RARF_RC6_V1(x) \
(((x) & BIT_MASK_RARF_RC6_V1) << BIT_SHIFT_RARF_RC6_V1)
#define BITS_RARF_RC6_V1 (BIT_MASK_RARF_RC6_V1 << BIT_SHIFT_RARF_RC6_V1)
#define BIT_CLEAR_RARF_RC6_V1(x) ((x) & (~BITS_RARF_RC6_V1))
#define BIT_GET_RARF_RC6_V1(x) \
(((x) >> BIT_SHIFT_RARF_RC6_V1) & BIT_MASK_RARF_RC6_V1)
#define BIT_SET_RARF_RC6_V1(x, v) \
(BIT_CLEAR_RARF_RC6_V1(x) | BIT_RARF_RC6_V1(v))
#define BIT_SHIFT_RARF_RC5_V1 0
#define BIT_MASK_RARF_RC5_V1 0x1f
#define BIT_RARF_RC5_V1(x) \
(((x) & BIT_MASK_RARF_RC5_V1) << BIT_SHIFT_RARF_RC5_V1)
#define BITS_RARF_RC5_V1 (BIT_MASK_RARF_RC5_V1 << BIT_SHIFT_RARF_RC5_V1)
#define BIT_CLEAR_RARF_RC5_V1(x) ((x) & (~BITS_RARF_RC5_V1))
#define BIT_GET_RARF_RC5_V1(x) \
(((x) >> BIT_SHIFT_RARF_RC5_V1) & BIT_MASK_RARF_RC5_V1)
#define BIT_SET_RARF_RC5_V1(x, v) \
(BIT_CLEAR_RARF_RC5_V1(x) | BIT_RARF_RC5_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RRSR (Offset 0x0440) */
#define BIT_EN_VHTBW_FALL BIT(31)
#define BIT_EN_HTBW_FALL BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RRSR (Offset 0x0440) */
#define BIT_SHIFT_RRSR_RSC 21
#define BIT_MASK_RRSR_RSC 0x3
#define BIT_RRSR_RSC(x) (((x) & BIT_MASK_RRSR_RSC) << BIT_SHIFT_RRSR_RSC)
#define BITS_RRSR_RSC (BIT_MASK_RRSR_RSC << BIT_SHIFT_RRSR_RSC)
#define BIT_CLEAR_RRSR_RSC(x) ((x) & (~BITS_RRSR_RSC))
#define BIT_GET_RRSR_RSC(x) (((x) >> BIT_SHIFT_RRSR_RSC) & BIT_MASK_RRSR_RSC)
#define BIT_SET_RRSR_RSC(x, v) (BIT_CLEAR_RRSR_RSC(x) | BIT_RRSR_RSC(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RRSR (Offset 0x0440) */
#define BIT_RRSR_BW BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RRSR (Offset 0x0440) */
#define BIT_SHIFT_RRSC_BITMAP 0
#define BIT_MASK_RRSC_BITMAP 0xfffff
#define BIT_RRSC_BITMAP(x) \
(((x) & BIT_MASK_RRSC_BITMAP) << BIT_SHIFT_RRSC_BITMAP)
#define BITS_RRSC_BITMAP (BIT_MASK_RRSC_BITMAP << BIT_SHIFT_RRSC_BITMAP)
#define BIT_CLEAR_RRSC_BITMAP(x) ((x) & (~BITS_RRSC_BITMAP))
#define BIT_GET_RRSC_BITMAP(x) \
(((x) >> BIT_SHIFT_RRSC_BITMAP) & BIT_MASK_RRSC_BITMAP)
#define BIT_SET_RRSC_BITMAP(x, v) \
(BIT_CLEAR_RRSC_BITMAP(x) | BIT_RRSC_BITMAP(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_RRSR_H (Offset 0x0443) */
#define BIT_EN_VHTBW_FALL_V1 BIT(7)
#define BIT_EN_HTBW_FALL_V1 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ARFR0 (Offset 0x0444) */
#define BIT_SHIFT_ARFR0_V1 0
#define BIT_MASK_ARFR0_V1 0xffffffffffffffffL
#define BIT_ARFR0_V1(x) (((x) & BIT_MASK_ARFR0_V1) << BIT_SHIFT_ARFR0_V1)
#define BITS_ARFR0_V1 (BIT_MASK_ARFR0_V1 << BIT_SHIFT_ARFR0_V1)
#define BIT_CLEAR_ARFR0_V1(x) ((x) & (~BITS_ARFR0_V1))
#define BIT_GET_ARFR0_V1(x) (((x) >> BIT_SHIFT_ARFR0_V1) & BIT_MASK_ARFR0_V1)
#define BIT_SET_ARFR0_V1(x, v) (BIT_CLEAR_ARFR0_V1(x) | BIT_ARFR0_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFR0 (Offset 0x0444) */
#define BIT_SHIFT_ARFRL0 0
#define BIT_MASK_ARFRL0 0xffffffffL
#define BIT_ARFRL0(x) (((x) & BIT_MASK_ARFRL0) << BIT_SHIFT_ARFRL0)
#define BITS_ARFRL0 (BIT_MASK_ARFRL0 << BIT_SHIFT_ARFRL0)
#define BIT_CLEAR_ARFRL0(x) ((x) & (~BITS_ARFRL0))
#define BIT_GET_ARFRL0(x) (((x) >> BIT_SHIFT_ARFRL0) & BIT_MASK_ARFRL0)
#define BIT_SET_ARFRL0(x, v) (BIT_CLEAR_ARFRL0(x) | BIT_ARFRL0(v))
/* 2 REG_ARFRH0 (Offset 0x0448) */
#define BIT_SHIFT_ARFRH0 0
#define BIT_MASK_ARFRH0 0xffffffffL
#define BIT_ARFRH0(x) (((x) & BIT_MASK_ARFRH0) << BIT_SHIFT_ARFRH0)
#define BITS_ARFRH0 (BIT_MASK_ARFRH0 << BIT_SHIFT_ARFRH0)
#define BIT_CLEAR_ARFRH0(x) ((x) & (~BITS_ARFRH0))
#define BIT_GET_ARFRH0(x) (((x) >> BIT_SHIFT_ARFRH0) & BIT_MASK_ARFRH0)
#define BIT_SET_ARFRH0(x, v) (BIT_CLEAR_ARFRH0(x) | BIT_ARFRH0(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_REG_ARFR_WT0 (Offset 0x044C) */
#define BIT_SHIFT_RATE7_WEIGHTING 28
#define BIT_MASK_RATE7_WEIGHTING 0xf
#define BIT_RATE7_WEIGHTING(x) \
(((x) & BIT_MASK_RATE7_WEIGHTING) << BIT_SHIFT_RATE7_WEIGHTING)
#define BITS_RATE7_WEIGHTING \
(BIT_MASK_RATE7_WEIGHTING << BIT_SHIFT_RATE7_WEIGHTING)
#define BIT_CLEAR_RATE7_WEIGHTING(x) ((x) & (~BITS_RATE7_WEIGHTING))
#define BIT_GET_RATE7_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE7_WEIGHTING) & BIT_MASK_RATE7_WEIGHTING)
#define BIT_SET_RATE7_WEIGHTING(x, v) \
(BIT_CLEAR_RATE7_WEIGHTING(x) | BIT_RATE7_WEIGHTING(v))
#define BIT_SHIFT_RATE6_WEIGHTING 24
#define BIT_MASK_RATE6_WEIGHTING 0xf
#define BIT_RATE6_WEIGHTING(x) \
(((x) & BIT_MASK_RATE6_WEIGHTING) << BIT_SHIFT_RATE6_WEIGHTING)
#define BITS_RATE6_WEIGHTING \
(BIT_MASK_RATE6_WEIGHTING << BIT_SHIFT_RATE6_WEIGHTING)
#define BIT_CLEAR_RATE6_WEIGHTING(x) ((x) & (~BITS_RATE6_WEIGHTING))
#define BIT_GET_RATE6_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE6_WEIGHTING) & BIT_MASK_RATE6_WEIGHTING)
#define BIT_SET_RATE6_WEIGHTING(x, v) \
(BIT_CLEAR_RATE6_WEIGHTING(x) | BIT_RATE6_WEIGHTING(v))
#define BIT_SHIFT_RATE5_WEIGHTING 20
#define BIT_MASK_RATE5_WEIGHTING 0xf
#define BIT_RATE5_WEIGHTING(x) \
(((x) & BIT_MASK_RATE5_WEIGHTING) << BIT_SHIFT_RATE5_WEIGHTING)
#define BITS_RATE5_WEIGHTING \
(BIT_MASK_RATE5_WEIGHTING << BIT_SHIFT_RATE5_WEIGHTING)
#define BIT_CLEAR_RATE5_WEIGHTING(x) ((x) & (~BITS_RATE5_WEIGHTING))
#define BIT_GET_RATE5_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE5_WEIGHTING) & BIT_MASK_RATE5_WEIGHTING)
#define BIT_SET_RATE5_WEIGHTING(x, v) \
(BIT_CLEAR_RATE5_WEIGHTING(x) | BIT_RATE5_WEIGHTING(v))
#define BIT_SHIFT_RATE4_WEIGHTING 16
#define BIT_MASK_RATE4_WEIGHTING 0xf
#define BIT_RATE4_WEIGHTING(x) \
(((x) & BIT_MASK_RATE4_WEIGHTING) << BIT_SHIFT_RATE4_WEIGHTING)
#define BITS_RATE4_WEIGHTING \
(BIT_MASK_RATE4_WEIGHTING << BIT_SHIFT_RATE4_WEIGHTING)
#define BIT_CLEAR_RATE4_WEIGHTING(x) ((x) & (~BITS_RATE4_WEIGHTING))
#define BIT_GET_RATE4_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE4_WEIGHTING) & BIT_MASK_RATE4_WEIGHTING)
#define BIT_SET_RATE4_WEIGHTING(x, v) \
(BIT_CLEAR_RATE4_WEIGHTING(x) | BIT_RATE4_WEIGHTING(v))
#define BIT_SHIFT_RATE3_WEIGHTING 12
#define BIT_MASK_RATE3_WEIGHTING 0xf
#define BIT_RATE3_WEIGHTING(x) \
(((x) & BIT_MASK_RATE3_WEIGHTING) << BIT_SHIFT_RATE3_WEIGHTING)
#define BITS_RATE3_WEIGHTING \
(BIT_MASK_RATE3_WEIGHTING << BIT_SHIFT_RATE3_WEIGHTING)
#define BIT_CLEAR_RATE3_WEIGHTING(x) ((x) & (~BITS_RATE3_WEIGHTING))
#define BIT_GET_RATE3_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE3_WEIGHTING) & BIT_MASK_RATE3_WEIGHTING)
#define BIT_SET_RATE3_WEIGHTING(x, v) \
(BIT_CLEAR_RATE3_WEIGHTING(x) | BIT_RATE3_WEIGHTING(v))
#define BIT_SHIFT_RATE2_WEIGHTING 8
#define BIT_MASK_RATE2_WEIGHTING 0xf
#define BIT_RATE2_WEIGHTING(x) \
(((x) & BIT_MASK_RATE2_WEIGHTING) << BIT_SHIFT_RATE2_WEIGHTING)
#define BITS_RATE2_WEIGHTING \
(BIT_MASK_RATE2_WEIGHTING << BIT_SHIFT_RATE2_WEIGHTING)
#define BIT_CLEAR_RATE2_WEIGHTING(x) ((x) & (~BITS_RATE2_WEIGHTING))
#define BIT_GET_RATE2_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE2_WEIGHTING) & BIT_MASK_RATE2_WEIGHTING)
#define BIT_SET_RATE2_WEIGHTING(x, v) \
(BIT_CLEAR_RATE2_WEIGHTING(x) | BIT_RATE2_WEIGHTING(v))
#define BIT_SHIFT_RATE1_WEIGHTING 4
#define BIT_MASK_RATE1_WEIGHTING 0xf
#define BIT_RATE1_WEIGHTING(x) \
(((x) & BIT_MASK_RATE1_WEIGHTING) << BIT_SHIFT_RATE1_WEIGHTING)
#define BITS_RATE1_WEIGHTING \
(BIT_MASK_RATE1_WEIGHTING << BIT_SHIFT_RATE1_WEIGHTING)
#define BIT_CLEAR_RATE1_WEIGHTING(x) ((x) & (~BITS_RATE1_WEIGHTING))
#define BIT_GET_RATE1_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE1_WEIGHTING) & BIT_MASK_RATE1_WEIGHTING)
#define BIT_SET_RATE1_WEIGHTING(x, v) \
(BIT_CLEAR_RATE1_WEIGHTING(x) | BIT_RATE1_WEIGHTING(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ARFR1_V1 (Offset 0x044C) */
#define BIT_SHIFT_ARFR1_V1 0
#define BIT_MASK_ARFR1_V1 0xffffffffffffffffL
#define BIT_ARFR1_V1(x) (((x) & BIT_MASK_ARFR1_V1) << BIT_SHIFT_ARFR1_V1)
#define BITS_ARFR1_V1 (BIT_MASK_ARFR1_V1 << BIT_SHIFT_ARFR1_V1)
#define BIT_CLEAR_ARFR1_V1(x) ((x) & (~BITS_ARFR1_V1))
#define BIT_GET_ARFR1_V1(x) (((x) >> BIT_SHIFT_ARFR1_V1) & BIT_MASK_ARFR1_V1)
#define BIT_SET_ARFR1_V1(x, v) (BIT_CLEAR_ARFR1_V1(x) | BIT_ARFR1_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFR1_V1 (Offset 0x044C) */
#define BIT_SHIFT_ARFRL1 0
#define BIT_MASK_ARFRL1 0xffffffffL
#define BIT_ARFRL1(x) (((x) & BIT_MASK_ARFRL1) << BIT_SHIFT_ARFRL1)
#define BITS_ARFRL1 (BIT_MASK_ARFRL1 << BIT_SHIFT_ARFRL1)
#define BIT_CLEAR_ARFRL1(x) ((x) & (~BITS_ARFRL1))
#define BIT_GET_ARFRL1(x) (((x) >> BIT_SHIFT_ARFRL1) & BIT_MASK_ARFRL1)
#define BIT_SET_ARFRL1(x, v) (BIT_CLEAR_ARFRL1(x) | BIT_ARFRL1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_REG_ARFR_WT0 (Offset 0x044C) */
#define BIT_SHIFT_RATE0_WEIGHTING 0
#define BIT_MASK_RATE0_WEIGHTING 0xf
#define BIT_RATE0_WEIGHTING(x) \
(((x) & BIT_MASK_RATE0_WEIGHTING) << BIT_SHIFT_RATE0_WEIGHTING)
#define BITS_RATE0_WEIGHTING \
(BIT_MASK_RATE0_WEIGHTING << BIT_SHIFT_RATE0_WEIGHTING)
#define BIT_CLEAR_RATE0_WEIGHTING(x) ((x) & (~BITS_RATE0_WEIGHTING))
#define BIT_GET_RATE0_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE0_WEIGHTING) & BIT_MASK_RATE0_WEIGHTING)
#define BIT_SET_RATE0_WEIGHTING(x, v) \
(BIT_CLEAR_RATE0_WEIGHTING(x) | BIT_RATE0_WEIGHTING(v))
/* 2 REG_REG_ARFR_WT1 (Offset 0x0450) */
#define BIT_SHIFT_RATE15_WEIGHTING 28
#define BIT_MASK_RATE15_WEIGHTING 0xf
#define BIT_RATE15_WEIGHTING(x) \
(((x) & BIT_MASK_RATE15_WEIGHTING) << BIT_SHIFT_RATE15_WEIGHTING)
#define BITS_RATE15_WEIGHTING \
(BIT_MASK_RATE15_WEIGHTING << BIT_SHIFT_RATE15_WEIGHTING)
#define BIT_CLEAR_RATE15_WEIGHTING(x) ((x) & (~BITS_RATE15_WEIGHTING))
#define BIT_GET_RATE15_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE15_WEIGHTING) & BIT_MASK_RATE15_WEIGHTING)
#define BIT_SET_RATE15_WEIGHTING(x, v) \
(BIT_CLEAR_RATE15_WEIGHTING(x) | BIT_RATE15_WEIGHTING(v))
#define BIT_SHIFT_RATE14_WEIGHTING 24
#define BIT_MASK_RATE14_WEIGHTING 0xf
#define BIT_RATE14_WEIGHTING(x) \
(((x) & BIT_MASK_RATE14_WEIGHTING) << BIT_SHIFT_RATE14_WEIGHTING)
#define BITS_RATE14_WEIGHTING \
(BIT_MASK_RATE14_WEIGHTING << BIT_SHIFT_RATE14_WEIGHTING)
#define BIT_CLEAR_RATE14_WEIGHTING(x) ((x) & (~BITS_RATE14_WEIGHTING))
#define BIT_GET_RATE14_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE14_WEIGHTING) & BIT_MASK_RATE14_WEIGHTING)
#define BIT_SET_RATE14_WEIGHTING(x, v) \
(BIT_CLEAR_RATE14_WEIGHTING(x) | BIT_RATE14_WEIGHTING(v))
#define BIT_SHIFT_RATE13_WEIGHTING 20
#define BIT_MASK_RATE13_WEIGHTING 0xf
#define BIT_RATE13_WEIGHTING(x) \
(((x) & BIT_MASK_RATE13_WEIGHTING) << BIT_SHIFT_RATE13_WEIGHTING)
#define BITS_RATE13_WEIGHTING \
(BIT_MASK_RATE13_WEIGHTING << BIT_SHIFT_RATE13_WEIGHTING)
#define BIT_CLEAR_RATE13_WEIGHTING(x) ((x) & (~BITS_RATE13_WEIGHTING))
#define BIT_GET_RATE13_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE13_WEIGHTING) & BIT_MASK_RATE13_WEIGHTING)
#define BIT_SET_RATE13_WEIGHTING(x, v) \
(BIT_CLEAR_RATE13_WEIGHTING(x) | BIT_RATE13_WEIGHTING(v))
#define BIT_SHIFT_RATE12_WEIGHTING 16
#define BIT_MASK_RATE12_WEIGHTING 0xf
#define BIT_RATE12_WEIGHTING(x) \
(((x) & BIT_MASK_RATE12_WEIGHTING) << BIT_SHIFT_RATE12_WEIGHTING)
#define BITS_RATE12_WEIGHTING \
(BIT_MASK_RATE12_WEIGHTING << BIT_SHIFT_RATE12_WEIGHTING)
#define BIT_CLEAR_RATE12_WEIGHTING(x) ((x) & (~BITS_RATE12_WEIGHTING))
#define BIT_GET_RATE12_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE12_WEIGHTING) & BIT_MASK_RATE12_WEIGHTING)
#define BIT_SET_RATE12_WEIGHTING(x, v) \
(BIT_CLEAR_RATE12_WEIGHTING(x) | BIT_RATE12_WEIGHTING(v))
#define BIT_SHIFT_RATE11_WEIGHTING 12
#define BIT_MASK_RATE11_WEIGHTING 0xf
#define BIT_RATE11_WEIGHTING(x) \
(((x) & BIT_MASK_RATE11_WEIGHTING) << BIT_SHIFT_RATE11_WEIGHTING)
#define BITS_RATE11_WEIGHTING \
(BIT_MASK_RATE11_WEIGHTING << BIT_SHIFT_RATE11_WEIGHTING)
#define BIT_CLEAR_RATE11_WEIGHTING(x) ((x) & (~BITS_RATE11_WEIGHTING))
#define BIT_GET_RATE11_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE11_WEIGHTING) & BIT_MASK_RATE11_WEIGHTING)
#define BIT_SET_RATE11_WEIGHTING(x, v) \
(BIT_CLEAR_RATE11_WEIGHTING(x) | BIT_RATE11_WEIGHTING(v))
#define BIT_SHIFT_RATE10_WEIGHTING 8
#define BIT_MASK_RATE10_WEIGHTING 0xf
#define BIT_RATE10_WEIGHTING(x) \
(((x) & BIT_MASK_RATE10_WEIGHTING) << BIT_SHIFT_RATE10_WEIGHTING)
#define BITS_RATE10_WEIGHTING \
(BIT_MASK_RATE10_WEIGHTING << BIT_SHIFT_RATE10_WEIGHTING)
#define BIT_CLEAR_RATE10_WEIGHTING(x) ((x) & (~BITS_RATE10_WEIGHTING))
#define BIT_GET_RATE10_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE10_WEIGHTING) & BIT_MASK_RATE10_WEIGHTING)
#define BIT_SET_RATE10_WEIGHTING(x, v) \
(BIT_CLEAR_RATE10_WEIGHTING(x) | BIT_RATE10_WEIGHTING(v))
#define BIT_SHIFT_RATE9_WEIGHTING 4
#define BIT_MASK_RATE9_WEIGHTING 0xf
#define BIT_RATE9_WEIGHTING(x) \
(((x) & BIT_MASK_RATE9_WEIGHTING) << BIT_SHIFT_RATE9_WEIGHTING)
#define BITS_RATE9_WEIGHTING \
(BIT_MASK_RATE9_WEIGHTING << BIT_SHIFT_RATE9_WEIGHTING)
#define BIT_CLEAR_RATE9_WEIGHTING(x) ((x) & (~BITS_RATE9_WEIGHTING))
#define BIT_GET_RATE9_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE9_WEIGHTING) & BIT_MASK_RATE9_WEIGHTING)
#define BIT_SET_RATE9_WEIGHTING(x, v) \
(BIT_CLEAR_RATE9_WEIGHTING(x) | BIT_RATE9_WEIGHTING(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFRH1 (Offset 0x0450) */
#define BIT_SHIFT_ARFRH1 0
#define BIT_MASK_ARFRH1 0xffffffffL
#define BIT_ARFRH1(x) (((x) & BIT_MASK_ARFRH1) << BIT_SHIFT_ARFRH1)
#define BITS_ARFRH1 (BIT_MASK_ARFRH1 << BIT_SHIFT_ARFRH1)
#define BIT_CLEAR_ARFRH1(x) ((x) & (~BITS_ARFRH1))
#define BIT_GET_ARFRH1(x) (((x) >> BIT_SHIFT_ARFRH1) & BIT_MASK_ARFRH1)
#define BIT_SET_ARFRH1(x, v) (BIT_CLEAR_ARFRH1(x) | BIT_ARFRH1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_REG_ARFR_WT1 (Offset 0x0450) */
#define BIT_SHIFT_RATE8_WEIGHTING 0
#define BIT_MASK_RATE8_WEIGHTING 0xf
#define BIT_RATE8_WEIGHTING(x) \
(((x) & BIT_MASK_RATE8_WEIGHTING) << BIT_SHIFT_RATE8_WEIGHTING)
#define BITS_RATE8_WEIGHTING \
(BIT_MASK_RATE8_WEIGHTING << BIT_SHIFT_RATE8_WEIGHTING)
#define BIT_CLEAR_RATE8_WEIGHTING(x) ((x) & (~BITS_RATE8_WEIGHTING))
#define BIT_GET_RATE8_WEIGHTING(x) \
(((x) >> BIT_SHIFT_RATE8_WEIGHTING) & BIT_MASK_RATE8_WEIGHTING)
#define BIT_SET_RATE8_WEIGHTING(x, v) \
(BIT_CLEAR_RATE8_WEIGHTING(x) | BIT_RATE8_WEIGHTING(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_CHECK_CCK_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_EN_BCN_PKT_REL BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_EN_BCN_PKT_REL_P0 BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_BCN_PORT_SEL BIT(5)
#define BIT_MOREDATA_BYPASS BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_EN_CLR_CMD_REL_BCN_PKT BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P0 BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_EN_SET_MOREDATA BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT_R_EN_SET_MOREDATA BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CCK_CHECK (Offset 0x0454) */
#define BIT__R_DIS_CLEAR_MACID_RELEASE BIT(1)
#define BIT__R_MACID_RELEASE_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AMPDU_MAX_TIME_V1 (Offset 0x0455) */
#define BIT_SHIFT_AMPDU_MAX_TIME 0
#define BIT_MASK_AMPDU_MAX_TIME 0xff
#define BIT_AMPDU_MAX_TIME(x) \
(((x) & BIT_MASK_AMPDU_MAX_TIME) << BIT_SHIFT_AMPDU_MAX_TIME)
#define BITS_AMPDU_MAX_TIME \
(BIT_MASK_AMPDU_MAX_TIME << BIT_SHIFT_AMPDU_MAX_TIME)
#define BIT_CLEAR_AMPDU_MAX_TIME(x) ((x) & (~BITS_AMPDU_MAX_TIME))
#define BIT_GET_AMPDU_MAX_TIME(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_TIME) & BIT_MASK_AMPDU_MAX_TIME)
#define BIT_SET_AMPDU_MAX_TIME(x, v) \
(BIT_CLEAR_AMPDU_MAX_TIME(x) | BIT_AMPDU_MAX_TIME(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_AMPDU_BURST_CTRL (Offset 0x0455) */
#define BIT_AMPDU_BURST_GLOBAL_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_BCNQ2_HEAD (Offset 0x0455) */
#define BIT_SHIFT_BCNQ2_HEAD 0
#define BIT_MASK_BCNQ2_HEAD 0xff
#define BIT_BCNQ2_HEAD(x) (((x) & BIT_MASK_BCNQ2_HEAD) << BIT_SHIFT_BCNQ2_HEAD)
#define BITS_BCNQ2_HEAD (BIT_MASK_BCNQ2_HEAD << BIT_SHIFT_BCNQ2_HEAD)
#define BIT_CLEAR_BCNQ2_HEAD(x) ((x) & (~BITS_BCNQ2_HEAD))
#define BIT_GET_BCNQ2_HEAD(x) \
(((x) >> BIT_SHIFT_BCNQ2_HEAD) & BIT_MASK_BCNQ2_HEAD)
#define BIT_SET_BCNQ2_HEAD(x, v) (BIT_CLEAR_BCNQ2_HEAD(x) | BIT_BCNQ2_HEAD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCNQ1_BDNY_V1 (Offset 0x0456) */
#define BIT_SHIFT_BCNQ1_PGBNDY_V1 0
#define BIT_MASK_BCNQ1_PGBNDY_V1 0xfff
#define BIT_BCNQ1_PGBNDY_V1(x) \
(((x) & BIT_MASK_BCNQ1_PGBNDY_V1) << BIT_SHIFT_BCNQ1_PGBNDY_V1)
#define BITS_BCNQ1_PGBNDY_V1 \
(BIT_MASK_BCNQ1_PGBNDY_V1 << BIT_SHIFT_BCNQ1_PGBNDY_V1)
#define BIT_CLEAR_BCNQ1_PGBNDY_V1(x) ((x) & (~BITS_BCNQ1_PGBNDY_V1))
#define BIT_GET_BCNQ1_PGBNDY_V1(x) \
(((x) >> BIT_SHIFT_BCNQ1_PGBNDY_V1) & BIT_MASK_BCNQ1_PGBNDY_V1)
#define BIT_SET_BCNQ1_PGBNDY_V1(x, v) \
(BIT_CLEAR_BCNQ1_PGBNDY_V1(x) | BIT_BCNQ1_PGBNDY_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TAB_SEL (Offset 0x0456) */
#define BIT_SHIFT_RATE_SEL 0
#define BIT_MASK_RATE_SEL 0xf
#define BIT_RATE_SEL(x) (((x) & BIT_MASK_RATE_SEL) << BIT_SHIFT_RATE_SEL)
#define BITS_RATE_SEL (BIT_MASK_RATE_SEL << BIT_SHIFT_RATE_SEL)
#define BIT_CLEAR_RATE_SEL(x) ((x) & (~BITS_RATE_SEL))
#define BIT_GET_RATE_SEL(x) (((x) >> BIT_SHIFT_RATE_SEL) & BIT_MASK_RATE_SEL)
#define BIT_SET_RATE_SEL(x, v) (BIT_CLEAR_RATE_SEL(x) | BIT_RATE_SEL(v))
/* 2 REG_BCN_INVALID_CTRL (Offset 0x0457) */
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P4 BIT(7)
#define BIT_EN_BCN_PKT_REL_P4 BIT(6)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P3 BIT(5)
#define BIT_EN_BCN_PKT_REL_P3 BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P2 BIT(3)
#define BIT_EN_BCN_PKT_REL_P2 BIT(2)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCNQ1_BDNY (Offset 0x0457) */
#define BIT_SHIFT_BCNQ1_PGBNDY 0
#define BIT_MASK_BCNQ1_PGBNDY 0xff
#define BIT_BCNQ1_PGBNDY(x) \
(((x) & BIT_MASK_BCNQ1_PGBNDY) << BIT_SHIFT_BCNQ1_PGBNDY)
#define BITS_BCNQ1_PGBNDY (BIT_MASK_BCNQ1_PGBNDY << BIT_SHIFT_BCNQ1_PGBNDY)
#define BIT_CLEAR_BCNQ1_PGBNDY(x) ((x) & (~BITS_BCNQ1_PGBNDY))
#define BIT_GET_BCNQ1_PGBNDY(x) \
(((x) >> BIT_SHIFT_BCNQ1_PGBNDY) & BIT_MASK_BCNQ1_PGBNDY)
#define BIT_SET_BCNQ1_PGBNDY(x, v) \
(BIT_CLEAR_BCNQ1_PGBNDY(x) | BIT_BCNQ1_PGBNDY(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_BCNQ1_BDNY (Offset 0x0457) */
#define BIT_SHIFT_BCNQ1_HEAD 0
#define BIT_MASK_BCNQ1_HEAD 0xff
#define BIT_BCNQ1_HEAD(x) (((x) & BIT_MASK_BCNQ1_HEAD) << BIT_SHIFT_BCNQ1_HEAD)
#define BITS_BCNQ1_HEAD (BIT_MASK_BCNQ1_HEAD << BIT_SHIFT_BCNQ1_HEAD)
#define BIT_CLEAR_BCNQ1_HEAD(x) ((x) & (~BITS_BCNQ1_HEAD))
#define BIT_GET_BCNQ1_HEAD(x) \
(((x) >> BIT_SHIFT_BCNQ1_HEAD) & BIT_MASK_BCNQ1_HEAD)
#define BIT_SET_BCNQ1_HEAD(x, v) (BIT_CLEAR_BCNQ1_HEAD(x) | BIT_BCNQ1_HEAD(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_INVALID_CTRL (Offset 0x0457) */
#define BIT_EN_BCN_PKT_REL_P1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AMPDU_MAX_LENGTH (Offset 0x0458) */
#define BIT_SHIFT_AMPDU_MAX_LENGTH 0
#define BIT_MASK_AMPDU_MAX_LENGTH 0xffffffffL
#define BIT_AMPDU_MAX_LENGTH(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH) << BIT_SHIFT_AMPDU_MAX_LENGTH)
#define BITS_AMPDU_MAX_LENGTH \
(BIT_MASK_AMPDU_MAX_LENGTH << BIT_SHIFT_AMPDU_MAX_LENGTH)
#define BIT_CLEAR_AMPDU_MAX_LENGTH(x) ((x) & (~BITS_AMPDU_MAX_LENGTH))
#define BIT_GET_AMPDU_MAX_LENGTH(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH) & BIT_MASK_AMPDU_MAX_LENGTH)
#define BIT_SET_AMPDU_MAX_LENGTH(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH(x) | BIT_AMPDU_MAX_LENGTH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AMPDU_MAX_LENGTH_HT (Offset 0x0458) */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_HT 0
#define BIT_MASK_AMPDU_MAX_LENGTH_HT 0xffff
#define BIT_AMPDU_MAX_LENGTH_HT(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_HT) << BIT_SHIFT_AMPDU_MAX_LENGTH_HT)
#define BITS_AMPDU_MAX_LENGTH_HT \
(BIT_MASK_AMPDU_MAX_LENGTH_HT << BIT_SHIFT_AMPDU_MAX_LENGTH_HT)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_HT(x) ((x) & (~BITS_AMPDU_MAX_LENGTH_HT))
#define BIT_GET_AMPDU_MAX_LENGTH_HT(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_HT) & BIT_MASK_AMPDU_MAX_LENGTH_HT)
#define BIT_SET_AMPDU_MAX_LENGTH_HT(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_HT(x) | BIT_AMPDU_MAX_LENGTH_HT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_ACQ_STOP (Offset 0x045C) */
#define BIT_AC7Q_STOP BIT(7)
#define BIT_AC6Q_STOP BIT(6)
#define BIT_AC5Q_STOP BIT(5)
#define BIT_AC4Q_STOP BIT(4)
#define BIT_AC3Q_STOP BIT(3)
#define BIT_AC2Q_STOP BIT(2)
#define BIT_AC1Q_STOP BIT(1)
#define BIT_AC0Q_STOP BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_LBK_BUF_HD (Offset 0x045D) */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD 0xff
#define BIT_WMAC_LBK_BUF_HEAD(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD) << BIT_SHIFT_WMAC_LBK_BUF_HEAD)
#define BITS_WMAC_LBK_BUF_HEAD \
(BIT_MASK_WMAC_LBK_BUF_HEAD << BIT_SHIFT_WMAC_LBK_BUF_HEAD)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD(x) ((x) & (~BITS_WMAC_LBK_BUF_HEAD))
#define BIT_GET_WMAC_LBK_BUF_HEAD(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD) & BIT_MASK_WMAC_LBK_BUF_HEAD)
#define BIT_SET_WMAC_LBK_BUF_HEAD(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD(x) | BIT_WMAC_LBK_BUF_HEAD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NDPA_RATE (Offset 0x045D) */
#define BIT_SHIFT_R_NDPA_RATE_V1 0
#define BIT_MASK_R_NDPA_RATE_V1 0xff
#define BIT_R_NDPA_RATE_V1(x) \
(((x) & BIT_MASK_R_NDPA_RATE_V1) << BIT_SHIFT_R_NDPA_RATE_V1)
#define BITS_R_NDPA_RATE_V1 \
(BIT_MASK_R_NDPA_RATE_V1 << BIT_SHIFT_R_NDPA_RATE_V1)
#define BIT_CLEAR_R_NDPA_RATE_V1(x) ((x) & (~BITS_R_NDPA_RATE_V1))
#define BIT_GET_R_NDPA_RATE_V1(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE_V1) & BIT_MASK_R_NDPA_RATE_V1)
#define BIT_SET_R_NDPA_RATE_V1(x, v) \
(BIT_CLEAR_R_NDPA_RATE_V1(x) | BIT_R_NDPA_RATE_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_TX_HANG_CTRL (Offset 0x045E) */
#define BIT_EN_GNT_BT_AWAKE BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TX_HANG_CTRL (Offset 0x045E) */
#define BIT_R_EN_GNT_BT_AWAKE BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TX_HANG_CTRL (Offset 0x045E) */
#define BIT_DIS_RELEASE_RETRY BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TX_HANG_CTRL (Offset 0x045E) */
#define BIT_EN_EOF_V1 BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TX_HANG_CTRL (Offset 0x045E) */
#define BIT_DIS_OQT_BLOCK BIT(1)
#define BIT_SEARCH_QUEUE_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_R_DIS_MACID_RELEASE_RTY BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_DIS_MACID_RELEASE_RTY BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_SHIFT_BW_SIGTA 3
#define BIT_MASK_BW_SIGTA 0x3
#define BIT_BW_SIGTA(x) (((x) & BIT_MASK_BW_SIGTA) << BIT_SHIFT_BW_SIGTA)
#define BITS_BW_SIGTA (BIT_MASK_BW_SIGTA << BIT_SHIFT_BW_SIGTA)
#define BIT_CLEAR_BW_SIGTA(x) ((x) & (~BITS_BW_SIGTA))
#define BIT_GET_BW_SIGTA(x) (((x) >> BIT_SHIFT_BW_SIGTA) & BIT_MASK_BW_SIGTA)
#define BIT_SET_BW_SIGTA(x, v) (BIT_CLEAR_BW_SIGTA(x) | BIT_BW_SIGTA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_SHIFT_R_NDPA_RATE 2
#define BIT_MASK_R_NDPA_RATE 0x3f
#define BIT_R_NDPA_RATE(x) \
(((x) & BIT_MASK_R_NDPA_RATE) << BIT_SHIFT_R_NDPA_RATE)
#define BITS_R_NDPA_RATE (BIT_MASK_R_NDPA_RATE << BIT_SHIFT_R_NDPA_RATE)
#define BIT_CLEAR_R_NDPA_RATE(x) ((x) & (~BITS_R_NDPA_RATE))
#define BIT_GET_R_NDPA_RATE(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE) & BIT_MASK_R_NDPA_RATE)
#define BIT_SET_R_NDPA_RATE(x, v) \
(BIT_CLEAR_R_NDPA_RATE(x) | BIT_R_NDPA_RATE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_EN_BAR_SIGTA BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_SHIFT_R_NDPA_BW 0
#define BIT_MASK_R_NDPA_BW 0x3
#define BIT_R_NDPA_BW(x) (((x) & BIT_MASK_R_NDPA_BW) << BIT_SHIFT_R_NDPA_BW)
#define BITS_R_NDPA_BW (BIT_MASK_R_NDPA_BW << BIT_SHIFT_R_NDPA_BW)
#define BIT_CLEAR_R_NDPA_BW(x) ((x) & (~BITS_R_NDPA_BW))
#define BIT_GET_R_NDPA_BW(x) (((x) >> BIT_SHIFT_R_NDPA_BW) & BIT_MASK_R_NDPA_BW)
#define BIT_SET_R_NDPA_BW(x, v) (BIT_CLEAR_R_NDPA_BW(x) | BIT_R_NDPA_BW(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_NDPA_OPT_CTRL (Offset 0x045F) */
#define BIT_SHIFT_NDPA_BW 0
#define BIT_MASK_NDPA_BW 0x3
#define BIT_NDPA_BW(x) (((x) & BIT_MASK_NDPA_BW) << BIT_SHIFT_NDPA_BW)
#define BITS_NDPA_BW (BIT_MASK_NDPA_BW << BIT_SHIFT_NDPA_BW)
#define BIT_CLEAR_NDPA_BW(x) ((x) & (~BITS_NDPA_BW))
#define BIT_GET_NDPA_BW(x) (((x) >> BIT_SHIFT_NDPA_BW) & BIT_MASK_NDPA_BW)
#define BIT_SET_NDPA_BW(x, v) (BIT_CLEAR_NDPA_BW(x) | BIT_NDPA_BW(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FAST_EDCA_CTRL (Offset 0x0460) */
#define BIT_SHIFT_FAST_EDCA_TO_V1 16
#define BIT_MASK_FAST_EDCA_TO_V1 0xff
#define BIT_FAST_EDCA_TO_V1(x) \
(((x) & BIT_MASK_FAST_EDCA_TO_V1) << BIT_SHIFT_FAST_EDCA_TO_V1)
#define BITS_FAST_EDCA_TO_V1 \
(BIT_MASK_FAST_EDCA_TO_V1 << BIT_SHIFT_FAST_EDCA_TO_V1)
#define BIT_CLEAR_FAST_EDCA_TO_V1(x) ((x) & (~BITS_FAST_EDCA_TO_V1))
#define BIT_GET_FAST_EDCA_TO_V1(x) \
(((x) >> BIT_SHIFT_FAST_EDCA_TO_V1) & BIT_MASK_FAST_EDCA_TO_V1)
#define BIT_SET_FAST_EDCA_TO_V1(x, v) \
(BIT_CLEAR_FAST_EDCA_TO_V1(x) | BIT_FAST_EDCA_TO_V1(v))
#define BIT_SHIFT_AC3_AC7_FAST_EDCA_PKT_TH 12
#define BIT_MASK_AC3_AC7_FAST_EDCA_PKT_TH 0xf
#define BIT_AC3_AC7_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_AC3_AC7_FAST_EDCA_PKT_TH) \
<< BIT_SHIFT_AC3_AC7_FAST_EDCA_PKT_TH)
#define BITS_AC3_AC7_FAST_EDCA_PKT_TH \
(BIT_MASK_AC3_AC7_FAST_EDCA_PKT_TH \
<< BIT_SHIFT_AC3_AC7_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_AC3_AC7_FAST_EDCA_PKT_TH(x) \
((x) & (~BITS_AC3_AC7_FAST_EDCA_PKT_TH))
#define BIT_GET_AC3_AC7_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_AC3_AC7_FAST_EDCA_PKT_TH) & \
BIT_MASK_AC3_AC7_FAST_EDCA_PKT_TH)
#define BIT_SET_AC3_AC7_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_AC3_AC7_FAST_EDCA_PKT_TH(x) | \
BIT_AC3_AC7_FAST_EDCA_PKT_TH(v))
#define BIT_SHIFT_AC2_FAST_EDCA_PKT_TH 8
#define BIT_MASK_AC2_FAST_EDCA_PKT_TH 0xf
#define BIT_AC2_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_AC2_FAST_EDCA_PKT_TH) \
<< BIT_SHIFT_AC2_FAST_EDCA_PKT_TH)
#define BITS_AC2_FAST_EDCA_PKT_TH \
(BIT_MASK_AC2_FAST_EDCA_PKT_TH << BIT_SHIFT_AC2_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_AC2_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_AC2_FAST_EDCA_PKT_TH))
#define BIT_GET_AC2_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_AC2_FAST_EDCA_PKT_TH) & \
BIT_MASK_AC2_FAST_EDCA_PKT_TH)
#define BIT_SET_AC2_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_AC2_FAST_EDCA_PKT_TH(x) | BIT_AC2_FAST_EDCA_PKT_TH(v))
#define BIT_SHIFT_AC1_FAST_EDCA_PKT_TH 4
#define BIT_MASK_AC1_FAST_EDCA_PKT_TH 0xf
#define BIT_AC1_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_AC1_FAST_EDCA_PKT_TH) \
<< BIT_SHIFT_AC1_FAST_EDCA_PKT_TH)
#define BITS_AC1_FAST_EDCA_PKT_TH \
(BIT_MASK_AC1_FAST_EDCA_PKT_TH << BIT_SHIFT_AC1_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_AC1_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_AC1_FAST_EDCA_PKT_TH))
#define BIT_GET_AC1_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_AC1_FAST_EDCA_PKT_TH) & \
BIT_MASK_AC1_FAST_EDCA_PKT_TH)
#define BIT_SET_AC1_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_AC1_FAST_EDCA_PKT_TH(x) | BIT_AC1_FAST_EDCA_PKT_TH(v))
#define BIT_SHIFT_AC0_FAST_EDCA_PKT_TH 0
#define BIT_MASK_AC0_FAST_EDCA_PKT_TH 0xf
#define BIT_AC0_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_AC0_FAST_EDCA_PKT_TH) \
<< BIT_SHIFT_AC0_FAST_EDCA_PKT_TH)
#define BITS_AC0_FAST_EDCA_PKT_TH \
(BIT_MASK_AC0_FAST_EDCA_PKT_TH << BIT_SHIFT_AC0_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_AC0_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_AC0_FAST_EDCA_PKT_TH))
#define BIT_GET_AC0_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_AC0_FAST_EDCA_PKT_TH) & \
BIT_MASK_AC0_FAST_EDCA_PKT_TH)
#define BIT_SET_AC0_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_AC0_FAST_EDCA_PKT_TH(x) | BIT_AC0_FAST_EDCA_PKT_TH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AMPDU_MAX_LENGTH_VHT (Offset 0x0460) */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1 0
#define BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1 0xfffff
#define BIT_AMPDU_MAX_LENGTH_VHT_V1(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1)
#define BITS_AMPDU_MAX_LENGTH_VHT_V1 \
(BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1 << BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_VHT_V1(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_VHT_V1))
#define BIT_GET_AMPDU_MAX_LENGTH_VHT_V1(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1) & \
BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1)
#define BIT_SET_AMPDU_MAX_LENGTH_VHT_V1(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_VHT_V1(x) | BIT_AMPDU_MAX_LENGTH_VHT_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_AMPDU_MAX_LENGTH_VHT (Offset 0x0460) */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_VHT 0
#define BIT_MASK_AMPDU_MAX_LENGTH_VHT 0x3ffff
#define BIT_AMPDU_MAX_LENGTH_VHT(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_VHT) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_VHT)
#define BITS_AMPDU_MAX_LENGTH_VHT \
(BIT_MASK_AMPDU_MAX_LENGTH_VHT << BIT_SHIFT_AMPDU_MAX_LENGTH_VHT)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_VHT(x) ((x) & (~BITS_AMPDU_MAX_LENGTH_VHT))
#define BIT_GET_AMPDU_MAX_LENGTH_VHT(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_VHT) & \
BIT_MASK_AMPDU_MAX_LENGTH_VHT)
#define BIT_SET_AMPDU_MAX_LENGTH_VHT(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_VHT(x) | BIT_AMPDU_MAX_LENGTH_VHT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RD_RESP_PKT_TH (Offset 0x0463) */
#define BIT_SHIFT_RD_RESP_PKT_TH 0
#define BIT_MASK_RD_RESP_PKT_TH 0x1f
#define BIT_RD_RESP_PKT_TH(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH) << BIT_SHIFT_RD_RESP_PKT_TH)
#define BITS_RD_RESP_PKT_TH \
(BIT_MASK_RD_RESP_PKT_TH << BIT_SHIFT_RD_RESP_PKT_TH)
#define BIT_CLEAR_RD_RESP_PKT_TH(x) ((x) & (~BITS_RD_RESP_PKT_TH))
#define BIT_GET_RD_RESP_PKT_TH(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH) & BIT_MASK_RD_RESP_PKT_TH)
#define BIT_SET_RD_RESP_PKT_TH(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH(x) | BIT_RD_RESP_PKT_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RD_RESP_PKT_TH (Offset 0x0463) */
#define BIT_SHIFT_RD_RESP_PKT_TH_V1 0
#define BIT_MASK_RD_RESP_PKT_TH_V1 0x3f
#define BIT_RD_RESP_PKT_TH_V1(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH_V1) << BIT_SHIFT_RD_RESP_PKT_TH_V1)
#define BITS_RD_RESP_PKT_TH_V1 \
(BIT_MASK_RD_RESP_PKT_TH_V1 << BIT_SHIFT_RD_RESP_PKT_TH_V1)
#define BIT_CLEAR_RD_RESP_PKT_TH_V1(x) ((x) & (~BITS_RD_RESP_PKT_TH_V1))
#define BIT_GET_RD_RESP_PKT_TH_V1(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH_V1) & BIT_MASK_RD_RESP_PKT_TH_V1)
#define BIT_SET_RD_RESP_PKT_TH_V1(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH_V1(x) | BIT_RD_RESP_PKT_TH_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_QUEUEMACID_CMDQ_V1 25
#define BIT_MASK_QUEUEMACID_CMDQ_V1 0x7f
#define BIT_QUEUEMACID_CMDQ_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_CMDQ_V1) << BIT_SHIFT_QUEUEMACID_CMDQ_V1)
#define BITS_QUEUEMACID_CMDQ_V1 \
(BIT_MASK_QUEUEMACID_CMDQ_V1 << BIT_SHIFT_QUEUEMACID_CMDQ_V1)
#define BIT_CLEAR_QUEUEMACID_CMDQ_V1(x) ((x) & (~BITS_QUEUEMACID_CMDQ_V1))
#define BIT_GET_QUEUEMACID_CMDQ_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_CMDQ_V1) & BIT_MASK_QUEUEMACID_CMDQ_V1)
#define BIT_SET_QUEUEMACID_CMDQ_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_CMDQ_V1(x) | BIT_QUEUEMACID_CMDQ_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_PKT_NUM_CMDQ_V2 24
#define BIT_MASK_PKT_NUM_CMDQ_V2 0xff
#define BIT_PKT_NUM_CMDQ_V2(x) \
(((x) & BIT_MASK_PKT_NUM_CMDQ_V2) << BIT_SHIFT_PKT_NUM_CMDQ_V2)
#define BITS_PKT_NUM_CMDQ_V2 \
(BIT_MASK_PKT_NUM_CMDQ_V2 << BIT_SHIFT_PKT_NUM_CMDQ_V2)
#define BIT_CLEAR_PKT_NUM_CMDQ_V2(x) ((x) & (~BITS_PKT_NUM_CMDQ_V2))
#define BIT_GET_PKT_NUM_CMDQ_V2(x) \
(((x) >> BIT_SHIFT_PKT_NUM_CMDQ_V2) & BIT_MASK_PKT_NUM_CMDQ_V2)
#define BIT_SET_PKT_NUM_CMDQ_V2(x, v) \
(BIT_CLEAR_PKT_NUM_CMDQ_V2(x) | BIT_PKT_NUM_CMDQ_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_PKT_NUM 23
#define BIT_MASK_PKT_NUM 0x1ff
#define BIT_PKT_NUM(x) (((x) & BIT_MASK_PKT_NUM) << BIT_SHIFT_PKT_NUM)
#define BITS_PKT_NUM (BIT_MASK_PKT_NUM << BIT_SHIFT_PKT_NUM)
#define BIT_CLEAR_PKT_NUM(x) ((x) & (~BITS_PKT_NUM))
#define BIT_GET_PKT_NUM(x) (((x) >> BIT_SHIFT_PKT_NUM) & BIT_MASK_PKT_NUM)
#define BIT_SET_PKT_NUM(x, v) (BIT_CLEAR_PKT_NUM(x) | BIT_PKT_NUM(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_QUEUEAC_CMDQ_V1 23
#define BIT_MASK_QUEUEAC_CMDQ_V1 0x3
#define BIT_QUEUEAC_CMDQ_V1(x) \
(((x) & BIT_MASK_QUEUEAC_CMDQ_V1) << BIT_SHIFT_QUEUEAC_CMDQ_V1)
#define BITS_QUEUEAC_CMDQ_V1 \
(BIT_MASK_QUEUEAC_CMDQ_V1 << BIT_SHIFT_QUEUEAC_CMDQ_V1)
#define BIT_CLEAR_QUEUEAC_CMDQ_V1(x) ((x) & (~BITS_QUEUEAC_CMDQ_V1))
#define BIT_GET_QUEUEAC_CMDQ_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_CMDQ_V1) & BIT_MASK_QUEUEAC_CMDQ_V1)
#define BIT_SET_QUEUEAC_CMDQ_V1(x, v) \
(BIT_CLEAR_QUEUEAC_CMDQ_V1(x) | BIT_QUEUEAC_CMDQ_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_TIDEMPTY_CMDQ_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_TAIL_PKT_CMDQ 16
#define BIT_MASK_TAIL_PKT_CMDQ 0xff
#define BIT_TAIL_PKT_CMDQ(x) \
(((x) & BIT_MASK_TAIL_PKT_CMDQ) << BIT_SHIFT_TAIL_PKT_CMDQ)
#define BITS_TAIL_PKT_CMDQ (BIT_MASK_TAIL_PKT_CMDQ << BIT_SHIFT_TAIL_PKT_CMDQ)
#define BIT_CLEAR_TAIL_PKT_CMDQ(x) ((x) & (~BITS_TAIL_PKT_CMDQ))
#define BIT_GET_TAIL_PKT_CMDQ(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_CMDQ) & BIT_MASK_TAIL_PKT_CMDQ)
#define BIT_SET_TAIL_PKT_CMDQ(x, v) \
(BIT_CLEAR_TAIL_PKT_CMDQ(x) | BIT_TAIL_PKT_CMDQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_TAIL_PKT_CMDQ_V2 11
#define BIT_MASK_TAIL_PKT_CMDQ_V2 0x7ff
#define BIT_TAIL_PKT_CMDQ_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_CMDQ_V2) << BIT_SHIFT_TAIL_PKT_CMDQ_V2)
#define BITS_TAIL_PKT_CMDQ_V2 \
(BIT_MASK_TAIL_PKT_CMDQ_V2 << BIT_SHIFT_TAIL_PKT_CMDQ_V2)
#define BIT_CLEAR_TAIL_PKT_CMDQ_V2(x) ((x) & (~BITS_TAIL_PKT_CMDQ_V2))
#define BIT_GET_TAIL_PKT_CMDQ_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_CMDQ_V2) & BIT_MASK_TAIL_PKT_CMDQ_V2)
#define BIT_SET_TAIL_PKT_CMDQ_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_CMDQ_V2(x) | BIT_TAIL_PKT_CMDQ_V2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_NEW_EDCA_CTRL_V1 (Offset 0x0464) */
#define BIT_SHIFT_RANDOM_VALUE_SHIFT 9
#define BIT_MASK_RANDOM_VALUE_SHIFT 0x7
#define BIT_RANDOM_VALUE_SHIFT(x) \
(((x) & BIT_MASK_RANDOM_VALUE_SHIFT) << BIT_SHIFT_RANDOM_VALUE_SHIFT)
#define BITS_RANDOM_VALUE_SHIFT \
(BIT_MASK_RANDOM_VALUE_SHIFT << BIT_SHIFT_RANDOM_VALUE_SHIFT)
#define BIT_CLEAR_RANDOM_VALUE_SHIFT(x) ((x) & (~BITS_RANDOM_VALUE_SHIFT))
#define BIT_GET_RANDOM_VALUE_SHIFT(x) \
(((x) >> BIT_SHIFT_RANDOM_VALUE_SHIFT) & BIT_MASK_RANDOM_VALUE_SHIFT)
#define BIT_SET_RANDOM_VALUE_SHIFT(x, v) \
(BIT_CLEAR_RANDOM_VALUE_SHIFT(x) | BIT_RANDOM_VALUE_SHIFT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_PKT_NUM_CMDQ 8
#define BIT_MASK_PKT_NUM_CMDQ 0xff
#define BIT_PKT_NUM_CMDQ(x) \
(((x) & BIT_MASK_PKT_NUM_CMDQ) << BIT_SHIFT_PKT_NUM_CMDQ)
#define BITS_PKT_NUM_CMDQ (BIT_MASK_PKT_NUM_CMDQ << BIT_SHIFT_PKT_NUM_CMDQ)
#define BIT_CLEAR_PKT_NUM_CMDQ(x) ((x) & (~BITS_PKT_NUM_CMDQ))
#define BIT_GET_PKT_NUM_CMDQ(x) \
(((x) >> BIT_SHIFT_PKT_NUM_CMDQ) & BIT_MASK_PKT_NUM_CMDQ)
#define BIT_SET_PKT_NUM_CMDQ(x, v) \
(BIT_CLEAR_PKT_NUM_CMDQ(x) | BIT_PKT_NUM_CMDQ(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_NEW_EDCA_CTRL_V1 (Offset 0x0464) */
#define BIT_ENABLE_NEW_EDCA BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_HEAD_PKT_CMDQ 0
#define BIT_MASK_HEAD_PKT_CMDQ 0xff
#define BIT_HEAD_PKT_CMDQ(x) \
(((x) & BIT_MASK_HEAD_PKT_CMDQ) << BIT_SHIFT_HEAD_PKT_CMDQ)
#define BITS_HEAD_PKT_CMDQ (BIT_MASK_HEAD_PKT_CMDQ << BIT_SHIFT_HEAD_PKT_CMDQ)
#define BIT_CLEAR_HEAD_PKT_CMDQ(x) ((x) & (~BITS_HEAD_PKT_CMDQ))
#define BIT_GET_HEAD_PKT_CMDQ(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_CMDQ) & BIT_MASK_HEAD_PKT_CMDQ)
#define BIT_SET_HEAD_PKT_CMDQ(x, v) \
(BIT_CLEAR_HEAD_PKT_CMDQ(x) | BIT_HEAD_PKT_CMDQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CMDQ_INFO (Offset 0x0464) */
#define BIT_SHIFT_HEAD_PKT_CMDQ_V1 0
#define BIT_MASK_HEAD_PKT_CMDQ_V1 0x7ff
#define BIT_HEAD_PKT_CMDQ_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_CMDQ_V1) << BIT_SHIFT_HEAD_PKT_CMDQ_V1)
#define BITS_HEAD_PKT_CMDQ_V1 \
(BIT_MASK_HEAD_PKT_CMDQ_V1 << BIT_SHIFT_HEAD_PKT_CMDQ_V1)
#define BIT_CLEAR_HEAD_PKT_CMDQ_V1(x) ((x) & (~BITS_HEAD_PKT_CMDQ_V1))
#define BIT_GET_HEAD_PKT_CMDQ_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_CMDQ_V1) & BIT_MASK_HEAD_PKT_CMDQ_V1)
#define BIT_SET_HEAD_PKT_CMDQ_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_CMDQ_V1(x) | BIT_HEAD_PKT_CMDQ_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_NEW_EDCA_CTRL_V1 (Offset 0x0464) */
#define BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER 0
#define BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER 0xff
#define BIT_MEDIUM_HAS_IDKE_TRIGGER(x) \
(((x) & BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER) \
<< BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER)
#define BITS_MEDIUM_HAS_IDKE_TRIGGER \
(BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER << BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER)
#define BIT_CLEAR_MEDIUM_HAS_IDKE_TRIGGER(x) \
((x) & (~BITS_MEDIUM_HAS_IDKE_TRIGGER))
#define BIT_GET_MEDIUM_HAS_IDKE_TRIGGER(x) \
(((x) >> BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER) & \
BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER)
#define BIT_SET_MEDIUM_HAS_IDKE_TRIGGER(x, v) \
(BIT_CLEAR_MEDIUM_HAS_IDKE_TRIGGER(x) | BIT_MEDIUM_HAS_IDKE_TRIGGER(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_SHIFT_QUEUEMACID_Q4_V1 25
#define BIT_MASK_QUEUEMACID_Q4_V1 0x7f
#define BIT_QUEUEMACID_Q4_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q4_V1) << BIT_SHIFT_QUEUEMACID_Q4_V1)
#define BITS_QUEUEMACID_Q4_V1 \
(BIT_MASK_QUEUEMACID_Q4_V1 << BIT_SHIFT_QUEUEMACID_Q4_V1)
#define BIT_CLEAR_QUEUEMACID_Q4_V1(x) ((x) & (~BITS_QUEUEMACID_Q4_V1))
#define BIT_GET_QUEUEMACID_Q4_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q4_V1) & BIT_MASK_QUEUEMACID_Q4_V1)
#define BIT_SET_QUEUEMACID_Q4_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q4_V1(x) | BIT_QUEUEMACID_Q4_V1(v))
#define BIT_SHIFT_QUEUEAC_Q4_V1 23
#define BIT_MASK_QUEUEAC_Q4_V1 0x3
#define BIT_QUEUEAC_Q4_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q4_V1) << BIT_SHIFT_QUEUEAC_Q4_V1)
#define BITS_QUEUEAC_Q4_V1 (BIT_MASK_QUEUEAC_Q4_V1 << BIT_SHIFT_QUEUEAC_Q4_V1)
#define BIT_CLEAR_QUEUEAC_Q4_V1(x) ((x) & (~BITS_QUEUEAC_Q4_V1))
#define BIT_GET_QUEUEAC_Q4_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q4_V1) & BIT_MASK_QUEUEAC_Q4_V1)
#define BIT_SET_QUEUEAC_Q4_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q4_V1(x) | BIT_QUEUEAC_Q4_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_TIDEMPTY_Q4_V1 BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACQ_STOP_V2 (Offset 0x0468) */
#define BIT_AC19Q_STOP BIT(19)
#define BIT_AC18Q_STOP BIT(18)
#define BIT_AC17Q_STOP BIT(17)
#define BIT_AC16Q_STOP BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_SHIFT_TAIL_PKT_Q4_V1 15
#define BIT_MASK_TAIL_PKT_Q4_V1 0xff
#define BIT_TAIL_PKT_Q4_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V1) << BIT_SHIFT_TAIL_PKT_Q4_V1)
#define BITS_TAIL_PKT_Q4_V1 \
(BIT_MASK_TAIL_PKT_Q4_V1 << BIT_SHIFT_TAIL_PKT_Q4_V1)
#define BIT_CLEAR_TAIL_PKT_Q4_V1(x) ((x) & (~BITS_TAIL_PKT_Q4_V1))
#define BIT_GET_TAIL_PKT_Q4_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V1) & BIT_MASK_TAIL_PKT_Q4_V1)
#define BIT_SET_TAIL_PKT_Q4_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V1(x) | BIT_TAIL_PKT_Q4_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_ACQ_STOP_V2 (Offset 0x0468) */
#define BIT_AC15Q_STOP BIT(15)
#define BIT_AC14Q_STOP BIT(14)
#define BIT_AC13Q_STOP BIT(13)
#define BIT_AC12Q_STOP BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_SHIFT_TAIL_PKT_Q4_V2 11
#define BIT_MASK_TAIL_PKT_Q4_V2 0x7ff
#define BIT_TAIL_PKT_Q4_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2) << BIT_SHIFT_TAIL_PKT_Q4_V2)
#define BITS_TAIL_PKT_Q4_V2 \
(BIT_MASK_TAIL_PKT_Q4_V2 << BIT_SHIFT_TAIL_PKT_Q4_V2)
#define BIT_CLEAR_TAIL_PKT_Q4_V2(x) ((x) & (~BITS_TAIL_PKT_Q4_V2))
#define BIT_GET_TAIL_PKT_Q4_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2) & BIT_MASK_TAIL_PKT_Q4_V2)
#define BIT_SET_TAIL_PKT_Q4_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2(x) | BIT_TAIL_PKT_Q4_V2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_ACQ_STOP_V2 (Offset 0x0468) */
#define BIT_AC11Q_STOP BIT(11)
#define BIT_AC10Q_STOP BIT(10)
#define BIT_AC9Q_STOP BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_SHIFT_PKT_NUM_Q4_V1 8
#define BIT_MASK_PKT_NUM_Q4_V1 0x7f
#define BIT_PKT_NUM_Q4_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q4_V1) << BIT_SHIFT_PKT_NUM_Q4_V1)
#define BITS_PKT_NUM_Q4_V1 (BIT_MASK_PKT_NUM_Q4_V1 << BIT_SHIFT_PKT_NUM_Q4_V1)
#define BIT_CLEAR_PKT_NUM_Q4_V1(x) ((x) & (~BITS_PKT_NUM_Q4_V1))
#define BIT_GET_PKT_NUM_Q4_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q4_V1) & BIT_MASK_PKT_NUM_Q4_V1)
#define BIT_SET_PKT_NUM_Q4_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q4_V1(x) | BIT_PKT_NUM_Q4_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_ACQ_STOP_V2 (Offset 0x0468) */
#define BIT_AC8Q_STOP BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_SHIFT_HEAD_PKT_Q4 0
#define BIT_MASK_HEAD_PKT_Q4 0xff
#define BIT_HEAD_PKT_Q4(x) \
(((x) & BIT_MASK_HEAD_PKT_Q4) << BIT_SHIFT_HEAD_PKT_Q4)
#define BITS_HEAD_PKT_Q4 (BIT_MASK_HEAD_PKT_Q4 << BIT_SHIFT_HEAD_PKT_Q4)
#define BIT_CLEAR_HEAD_PKT_Q4(x) ((x) & (~BITS_HEAD_PKT_Q4))
#define BIT_GET_HEAD_PKT_Q4(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q4) & BIT_MASK_HEAD_PKT_Q4)
#define BIT_SET_HEAD_PKT_Q4(x, v) \
(BIT_CLEAR_HEAD_PKT_Q4(x) | BIT_HEAD_PKT_Q4(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q4_INFO (Offset 0x0468) */
#define BIT_SHIFT_HEAD_PKT_Q4_V1 0
#define BIT_MASK_HEAD_PKT_Q4_V1 0x7ff
#define BIT_HEAD_PKT_Q4_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q4_V1) << BIT_SHIFT_HEAD_PKT_Q4_V1)
#define BITS_HEAD_PKT_Q4_V1 \
(BIT_MASK_HEAD_PKT_Q4_V1 << BIT_SHIFT_HEAD_PKT_Q4_V1)
#define BIT_CLEAR_HEAD_PKT_Q4_V1(x) ((x) & (~BITS_HEAD_PKT_Q4_V1))
#define BIT_GET_HEAD_PKT_Q4_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q4_V1) & BIT_MASK_HEAD_PKT_Q4_V1)
#define BIT_SET_HEAD_PKT_Q4_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q4_V1(x) | BIT_HEAD_PKT_Q4_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q5_INFO (Offset 0x046C) */
#define BIT_SHIFT_QUEUEMACID_Q5_V1 25
#define BIT_MASK_QUEUEMACID_Q5_V1 0x7f
#define BIT_QUEUEMACID_Q5_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q5_V1) << BIT_SHIFT_QUEUEMACID_Q5_V1)
#define BITS_QUEUEMACID_Q5_V1 \
(BIT_MASK_QUEUEMACID_Q5_V1 << BIT_SHIFT_QUEUEMACID_Q5_V1)
#define BIT_CLEAR_QUEUEMACID_Q5_V1(x) ((x) & (~BITS_QUEUEMACID_Q5_V1))
#define BIT_GET_QUEUEMACID_Q5_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q5_V1) & BIT_MASK_QUEUEMACID_Q5_V1)
#define BIT_SET_QUEUEMACID_Q5_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q5_V1(x) | BIT_QUEUEMACID_Q5_V1(v))
#define BIT_SHIFT_QUEUEAC_Q5_V1 23
#define BIT_MASK_QUEUEAC_Q5_V1 0x3
#define BIT_QUEUEAC_Q5_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q5_V1) << BIT_SHIFT_QUEUEAC_Q5_V1)
#define BITS_QUEUEAC_Q5_V1 (BIT_MASK_QUEUEAC_Q5_V1 << BIT_SHIFT_QUEUEAC_Q5_V1)
#define BIT_CLEAR_QUEUEAC_Q5_V1(x) ((x) & (~BITS_QUEUEAC_Q5_V1))
#define BIT_GET_QUEUEAC_Q5_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q5_V1) & BIT_MASK_QUEUEAC_Q5_V1)
#define BIT_SET_QUEUEAC_Q5_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q5_V1(x) | BIT_QUEUEAC_Q5_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q5_INFO (Offset 0x046C) */
#define BIT_TIDEMPTY_Q5_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q5_INFO (Offset 0x046C) */
#define BIT_SHIFT_TAIL_PKT_Q5_V1 15
#define BIT_MASK_TAIL_PKT_Q5_V1 0xff
#define BIT_TAIL_PKT_Q5_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q5_V1) << BIT_SHIFT_TAIL_PKT_Q5_V1)
#define BITS_TAIL_PKT_Q5_V1 \
(BIT_MASK_TAIL_PKT_Q5_V1 << BIT_SHIFT_TAIL_PKT_Q5_V1)
#define BIT_CLEAR_TAIL_PKT_Q5_V1(x) ((x) & (~BITS_TAIL_PKT_Q5_V1))
#define BIT_GET_TAIL_PKT_Q5_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q5_V1) & BIT_MASK_TAIL_PKT_Q5_V1)
#define BIT_SET_TAIL_PKT_Q5_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q5_V1(x) | BIT_TAIL_PKT_Q5_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q5_INFO (Offset 0x046C) */
#define BIT_SHIFT_TAIL_PKT_Q5_V2 11
#define BIT_MASK_TAIL_PKT_Q5_V2 0x7ff
#define BIT_TAIL_PKT_Q5_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q5_V2) << BIT_SHIFT_TAIL_PKT_Q5_V2)
#define BITS_TAIL_PKT_Q5_V2 \
(BIT_MASK_TAIL_PKT_Q5_V2 << BIT_SHIFT_TAIL_PKT_Q5_V2)
#define BIT_CLEAR_TAIL_PKT_Q5_V2(x) ((x) & (~BITS_TAIL_PKT_Q5_V2))
#define BIT_GET_TAIL_PKT_Q5_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q5_V2) & BIT_MASK_TAIL_PKT_Q5_V2)
#define BIT_SET_TAIL_PKT_Q5_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q5_V2(x) | BIT_TAIL_PKT_Q5_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q5_INFO (Offset 0x046C) */
#define BIT_SHIFT_PKT_NUM_Q5_V1 8
#define BIT_MASK_PKT_NUM_Q5_V1 0x7f
#define BIT_PKT_NUM_Q5_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q5_V1) << BIT_SHIFT_PKT_NUM_Q5_V1)
#define BITS_PKT_NUM_Q5_V1 (BIT_MASK_PKT_NUM_Q5_V1 << BIT_SHIFT_PKT_NUM_Q5_V1)
#define BIT_CLEAR_PKT_NUM_Q5_V1(x) ((x) & (~BITS_PKT_NUM_Q5_V1))
#define BIT_GET_PKT_NUM_Q5_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q5_V1) & BIT_MASK_PKT_NUM_Q5_V1)
#define BIT_SET_PKT_NUM_Q5_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q5_V1(x) | BIT_PKT_NUM_Q5_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q5 0
#define BIT_MASK_HEAD_PKT_Q5 0xff
#define BIT_HEAD_PKT_Q5(x) \
(((x) & BIT_MASK_HEAD_PKT_Q5) << BIT_SHIFT_HEAD_PKT_Q5)
#define BITS_HEAD_PKT_Q5 (BIT_MASK_HEAD_PKT_Q5 << BIT_SHIFT_HEAD_PKT_Q5)
#define BIT_CLEAR_HEAD_PKT_Q5(x) ((x) & (~BITS_HEAD_PKT_Q5))
#define BIT_GET_HEAD_PKT_Q5(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q5) & BIT_MASK_HEAD_PKT_Q5)
#define BIT_SET_HEAD_PKT_Q5(x, v) \
(BIT_CLEAR_HEAD_PKT_Q5(x) | BIT_HEAD_PKT_Q5(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q5_INFO (Offset 0x046C) */
#define BIT_SHIFT_HEAD_PKT_Q5_V1 0
#define BIT_MASK_HEAD_PKT_Q5_V1 0x7ff
#define BIT_HEAD_PKT_Q5_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q5_V1) << BIT_SHIFT_HEAD_PKT_Q5_V1)
#define BITS_HEAD_PKT_Q5_V1 \
(BIT_MASK_HEAD_PKT_Q5_V1 << BIT_SHIFT_HEAD_PKT_Q5_V1)
#define BIT_CLEAR_HEAD_PKT_Q5_V1(x) ((x) & (~BITS_HEAD_PKT_Q5_V1))
#define BIT_GET_HEAD_PKT_Q5_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q5_V1) & BIT_MASK_HEAD_PKT_Q5_V1)
#define BIT_SET_HEAD_PKT_Q5_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q5_V1(x) | BIT_HEAD_PKT_Q5_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q6_INFO (Offset 0x0470) */
#define BIT_SHIFT_QUEUEMACID_Q6_V1 25
#define BIT_MASK_QUEUEMACID_Q6_V1 0x7f
#define BIT_QUEUEMACID_Q6_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q6_V1) << BIT_SHIFT_QUEUEMACID_Q6_V1)
#define BITS_QUEUEMACID_Q6_V1 \
(BIT_MASK_QUEUEMACID_Q6_V1 << BIT_SHIFT_QUEUEMACID_Q6_V1)
#define BIT_CLEAR_QUEUEMACID_Q6_V1(x) ((x) & (~BITS_QUEUEMACID_Q6_V1))
#define BIT_GET_QUEUEMACID_Q6_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q6_V1) & BIT_MASK_QUEUEMACID_Q6_V1)
#define BIT_SET_QUEUEMACID_Q6_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q6_V1(x) | BIT_QUEUEMACID_Q6_V1(v))
#define BIT_SHIFT_QUEUEAC_Q6_V1 23
#define BIT_MASK_QUEUEAC_Q6_V1 0x3
#define BIT_QUEUEAC_Q6_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q6_V1) << BIT_SHIFT_QUEUEAC_Q6_V1)
#define BITS_QUEUEAC_Q6_V1 (BIT_MASK_QUEUEAC_Q6_V1 << BIT_SHIFT_QUEUEAC_Q6_V1)
#define BIT_CLEAR_QUEUEAC_Q6_V1(x) ((x) & (~BITS_QUEUEAC_Q6_V1))
#define BIT_GET_QUEUEAC_Q6_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q6_V1) & BIT_MASK_QUEUEAC_Q6_V1)
#define BIT_SET_QUEUEAC_Q6_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q6_V1(x) | BIT_QUEUEAC_Q6_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q6_INFO (Offset 0x0470) */
#define BIT_TIDEMPTY_Q6_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q6_INFO (Offset 0x0470) */
#define BIT_SHIFT_TAIL_PKT_Q6_V1 15
#define BIT_MASK_TAIL_PKT_Q6_V1 0xff
#define BIT_TAIL_PKT_Q6_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q6_V1) << BIT_SHIFT_TAIL_PKT_Q6_V1)
#define BITS_TAIL_PKT_Q6_V1 \
(BIT_MASK_TAIL_PKT_Q6_V1 << BIT_SHIFT_TAIL_PKT_Q6_V1)
#define BIT_CLEAR_TAIL_PKT_Q6_V1(x) ((x) & (~BITS_TAIL_PKT_Q6_V1))
#define BIT_GET_TAIL_PKT_Q6_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q6_V1) & BIT_MASK_TAIL_PKT_Q6_V1)
#define BIT_SET_TAIL_PKT_Q6_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q6_V1(x) | BIT_TAIL_PKT_Q6_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q6_INFO (Offset 0x0470) */
#define BIT_SHIFT_TAIL_PKT_Q6_V2 11
#define BIT_MASK_TAIL_PKT_Q6_V2 0x7ff
#define BIT_TAIL_PKT_Q6_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q6_V2) << BIT_SHIFT_TAIL_PKT_Q6_V2)
#define BITS_TAIL_PKT_Q6_V2 \
(BIT_MASK_TAIL_PKT_Q6_V2 << BIT_SHIFT_TAIL_PKT_Q6_V2)
#define BIT_CLEAR_TAIL_PKT_Q6_V2(x) ((x) & (~BITS_TAIL_PKT_Q6_V2))
#define BIT_GET_TAIL_PKT_Q6_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q6_V2) & BIT_MASK_TAIL_PKT_Q6_V2)
#define BIT_SET_TAIL_PKT_Q6_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q6_V2(x) | BIT_TAIL_PKT_Q6_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q6_INFO (Offset 0x0470) */
#define BIT_SHIFT_PKT_NUM_Q6_V1 8
#define BIT_MASK_PKT_NUM_Q6_V1 0x7f
#define BIT_PKT_NUM_Q6_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q6_V1) << BIT_SHIFT_PKT_NUM_Q6_V1)
#define BITS_PKT_NUM_Q6_V1 (BIT_MASK_PKT_NUM_Q6_V1 << BIT_SHIFT_PKT_NUM_Q6_V1)
#define BIT_CLEAR_PKT_NUM_Q6_V1(x) ((x) & (~BITS_PKT_NUM_Q6_V1))
#define BIT_GET_PKT_NUM_Q6_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q6_V1) & BIT_MASK_PKT_NUM_Q6_V1)
#define BIT_SET_PKT_NUM_Q6_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q6_V1(x) | BIT_PKT_NUM_Q6_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q6 0
#define BIT_MASK_HEAD_PKT_Q6 0xff
#define BIT_HEAD_PKT_Q6(x) \
(((x) & BIT_MASK_HEAD_PKT_Q6) << BIT_SHIFT_HEAD_PKT_Q6)
#define BITS_HEAD_PKT_Q6 (BIT_MASK_HEAD_PKT_Q6 << BIT_SHIFT_HEAD_PKT_Q6)
#define BIT_CLEAR_HEAD_PKT_Q6(x) ((x) & (~BITS_HEAD_PKT_Q6))
#define BIT_GET_HEAD_PKT_Q6(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q6) & BIT_MASK_HEAD_PKT_Q6)
#define BIT_SET_HEAD_PKT_Q6(x, v) \
(BIT_CLEAR_HEAD_PKT_Q6(x) | BIT_HEAD_PKT_Q6(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q6_INFO (Offset 0x0470) */
#define BIT_SHIFT_HEAD_PKT_Q6_V1 0
#define BIT_MASK_HEAD_PKT_Q6_V1 0x7ff
#define BIT_HEAD_PKT_Q6_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q6_V1) << BIT_SHIFT_HEAD_PKT_Q6_V1)
#define BITS_HEAD_PKT_Q6_V1 \
(BIT_MASK_HEAD_PKT_Q6_V1 << BIT_SHIFT_HEAD_PKT_Q6_V1)
#define BIT_CLEAR_HEAD_PKT_Q6_V1(x) ((x) & (~BITS_HEAD_PKT_Q6_V1))
#define BIT_GET_HEAD_PKT_Q6_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q6_V1) & BIT_MASK_HEAD_PKT_Q6_V1)
#define BIT_SET_HEAD_PKT_Q6_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q6_V1(x) | BIT_HEAD_PKT_Q6_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q7_INFO (Offset 0x0474) */
#define BIT_SHIFT_QUEUEMACID_Q7_V1 25
#define BIT_MASK_QUEUEMACID_Q7_V1 0x7f
#define BIT_QUEUEMACID_Q7_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_Q7_V1) << BIT_SHIFT_QUEUEMACID_Q7_V1)
#define BITS_QUEUEMACID_Q7_V1 \
(BIT_MASK_QUEUEMACID_Q7_V1 << BIT_SHIFT_QUEUEMACID_Q7_V1)
#define BIT_CLEAR_QUEUEMACID_Q7_V1(x) ((x) & (~BITS_QUEUEMACID_Q7_V1))
#define BIT_GET_QUEUEMACID_Q7_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q7_V1) & BIT_MASK_QUEUEMACID_Q7_V1)
#define BIT_SET_QUEUEMACID_Q7_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_Q7_V1(x) | BIT_QUEUEMACID_Q7_V1(v))
#define BIT_SHIFT_QUEUEAC_Q7_V1 23
#define BIT_MASK_QUEUEAC_Q7_V1 0x3
#define BIT_QUEUEAC_Q7_V1(x) \
(((x) & BIT_MASK_QUEUEAC_Q7_V1) << BIT_SHIFT_QUEUEAC_Q7_V1)
#define BITS_QUEUEAC_Q7_V1 (BIT_MASK_QUEUEAC_Q7_V1 << BIT_SHIFT_QUEUEAC_Q7_V1)
#define BIT_CLEAR_QUEUEAC_Q7_V1(x) ((x) & (~BITS_QUEUEAC_Q7_V1))
#define BIT_GET_QUEUEAC_Q7_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q7_V1) & BIT_MASK_QUEUEAC_Q7_V1)
#define BIT_SET_QUEUEAC_Q7_V1(x, v) \
(BIT_CLEAR_QUEUEAC_Q7_V1(x) | BIT_QUEUEAC_Q7_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q7_INFO (Offset 0x0474) */
#define BIT_TIDEMPTY_Q7_V1 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q7_INFO (Offset 0x0474) */
#define BIT_SHIFT_TAIL_PKT_Q7_V1 15
#define BIT_MASK_TAIL_PKT_Q7_V1 0xff
#define BIT_TAIL_PKT_Q7_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_Q7_V1) << BIT_SHIFT_TAIL_PKT_Q7_V1)
#define BITS_TAIL_PKT_Q7_V1 \
(BIT_MASK_TAIL_PKT_Q7_V1 << BIT_SHIFT_TAIL_PKT_Q7_V1)
#define BIT_CLEAR_TAIL_PKT_Q7_V1(x) ((x) & (~BITS_TAIL_PKT_Q7_V1))
#define BIT_GET_TAIL_PKT_Q7_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q7_V1) & BIT_MASK_TAIL_PKT_Q7_V1)
#define BIT_SET_TAIL_PKT_Q7_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_Q7_V1(x) | BIT_TAIL_PKT_Q7_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q7_INFO (Offset 0x0474) */
#define BIT_SHIFT_TAIL_PKT_Q7_V2 11
#define BIT_MASK_TAIL_PKT_Q7_V2 0x7ff
#define BIT_TAIL_PKT_Q7_V2(x) \
(((x) & BIT_MASK_TAIL_PKT_Q7_V2) << BIT_SHIFT_TAIL_PKT_Q7_V2)
#define BITS_TAIL_PKT_Q7_V2 \
(BIT_MASK_TAIL_PKT_Q7_V2 << BIT_SHIFT_TAIL_PKT_Q7_V2)
#define BIT_CLEAR_TAIL_PKT_Q7_V2(x) ((x) & (~BITS_TAIL_PKT_Q7_V2))
#define BIT_GET_TAIL_PKT_Q7_V2(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q7_V2) & BIT_MASK_TAIL_PKT_Q7_V2)
#define BIT_SET_TAIL_PKT_Q7_V2(x, v) \
(BIT_CLEAR_TAIL_PKT_Q7_V2(x) | BIT_TAIL_PKT_Q7_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_Q7_INFO (Offset 0x0474) */
#define BIT_SHIFT_PKT_NUM_Q7_V1 8
#define BIT_MASK_PKT_NUM_Q7_V1 0x7f
#define BIT_PKT_NUM_Q7_V1(x) \
(((x) & BIT_MASK_PKT_NUM_Q7_V1) << BIT_SHIFT_PKT_NUM_Q7_V1)
#define BITS_PKT_NUM_Q7_V1 (BIT_MASK_PKT_NUM_Q7_V1 << BIT_SHIFT_PKT_NUM_Q7_V1)
#define BIT_CLEAR_PKT_NUM_Q7_V1(x) ((x) & (~BITS_PKT_NUM_Q7_V1))
#define BIT_GET_PKT_NUM_Q7_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_Q7_V1) & BIT_MASK_PKT_NUM_Q7_V1)
#define BIT_SET_PKT_NUM_Q7_V1(x, v) \
(BIT_CLEAR_PKT_NUM_Q7_V1(x) | BIT_PKT_NUM_Q7_V1(v))
#define BIT_SHIFT_HEAD_PKT_Q7 0
#define BIT_MASK_HEAD_PKT_Q7 0xff
#define BIT_HEAD_PKT_Q7(x) \
(((x) & BIT_MASK_HEAD_PKT_Q7) << BIT_SHIFT_HEAD_PKT_Q7)
#define BITS_HEAD_PKT_Q7 (BIT_MASK_HEAD_PKT_Q7 << BIT_SHIFT_HEAD_PKT_Q7)
#define BIT_CLEAR_HEAD_PKT_Q7(x) ((x) & (~BITS_HEAD_PKT_Q7))
#define BIT_GET_HEAD_PKT_Q7(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q7) & BIT_MASK_HEAD_PKT_Q7)
#define BIT_SET_HEAD_PKT_Q7(x, v) \
(BIT_CLEAR_HEAD_PKT_Q7(x) | BIT_HEAD_PKT_Q7(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q7_INFO (Offset 0x0474) */
#define BIT_SHIFT_HEAD_PKT_Q7_V1 0
#define BIT_MASK_HEAD_PKT_Q7_V1 0x7ff
#define BIT_HEAD_PKT_Q7_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_Q7_V1) << BIT_SHIFT_HEAD_PKT_Q7_V1)
#define BITS_HEAD_PKT_Q7_V1 \
(BIT_MASK_HEAD_PKT_Q7_V1 << BIT_SHIFT_HEAD_PKT_Q7_V1)
#define BIT_CLEAR_HEAD_PKT_Q7_V1(x) ((x) & (~BITS_HEAD_PKT_Q7_V1))
#define BIT_GET_HEAD_PKT_Q7_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q7_V1) & BIT_MASK_HEAD_PKT_Q7_V1)
#define BIT_SET_HEAD_PKT_Q7_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_Q7_V1(x) | BIT_HEAD_PKT_Q7_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_LBK_BUF_HD_V1 (Offset 0x0478) */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD_V1 0xfff
#define BIT_WMAC_LBK_BUF_HEAD_V1(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD_V1) \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1)
#define BITS_WMAC_LBK_BUF_HEAD_V1 \
(BIT_MASK_WMAC_LBK_BUF_HEAD_V1 << BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1(x) ((x) & (~BITS_WMAC_LBK_BUF_HEAD_V1))
#define BIT_GET_WMAC_LBK_BUF_HEAD_V1(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1) & \
BIT_MASK_WMAC_LBK_BUF_HEAD_V1)
#define BIT_SET_WMAC_LBK_BUF_HEAD_V1(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1(x) | BIT_WMAC_LBK_BUF_HEAD_V1(v))
/* 2 REG_MGQ_BDNY_V1 (Offset 0x047A) */
#define BIT_SHIFT_MGQ_PGBNDY_V1 0
#define BIT_MASK_MGQ_PGBNDY_V1 0xfff
#define BIT_MGQ_PGBNDY_V1(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V1) << BIT_SHIFT_MGQ_PGBNDY_V1)
#define BITS_MGQ_PGBNDY_V1 (BIT_MASK_MGQ_PGBNDY_V1 << BIT_SHIFT_MGQ_PGBNDY_V1)
#define BIT_CLEAR_MGQ_PGBNDY_V1(x) ((x) & (~BITS_MGQ_PGBNDY_V1))
#define BIT_GET_MGQ_PGBNDY_V1(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V1) & BIT_MASK_MGQ_PGBNDY_V1)
#define BIT_SET_MGQ_PGBNDY_V1(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V1(x) | BIT_MGQ_PGBNDY_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_SPC_READ_PTR 24
#define BIT_MASK_SPC_READ_PTR 0xf
#define BIT_SPC_READ_PTR(x) \
(((x) & BIT_MASK_SPC_READ_PTR) << BIT_SHIFT_SPC_READ_PTR)
#define BITS_SPC_READ_PTR (BIT_MASK_SPC_READ_PTR << BIT_SHIFT_SPC_READ_PTR)
#define BIT_CLEAR_SPC_READ_PTR(x) ((x) & (~BITS_SPC_READ_PTR))
#define BIT_GET_SPC_READ_PTR(x) \
(((x) >> BIT_SHIFT_SPC_READ_PTR) & BIT_MASK_SPC_READ_PTR)
#define BIT_SET_SPC_READ_PTR(x, v) \
(BIT_CLEAR_SPC_READ_PTR(x) | BIT_SPC_READ_PTR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_TRXRPT_TIMER_TH 24
#define BIT_MASK_TRXRPT_TIMER_TH 0xff
#define BIT_TRXRPT_TIMER_TH(x) \
(((x) & BIT_MASK_TRXRPT_TIMER_TH) << BIT_SHIFT_TRXRPT_TIMER_TH)
#define BITS_TRXRPT_TIMER_TH \
(BIT_MASK_TRXRPT_TIMER_TH << BIT_SHIFT_TRXRPT_TIMER_TH)
#define BIT_CLEAR_TRXRPT_TIMER_TH(x) ((x) & (~BITS_TRXRPT_TIMER_TH))
#define BIT_GET_TRXRPT_TIMER_TH(x) \
(((x) >> BIT_SHIFT_TRXRPT_TIMER_TH) & BIT_MASK_TRXRPT_TIMER_TH)
#define BIT_SET_TRXRPT_TIMER_TH(x, v) \
(BIT_CLEAR_TRXRPT_TIMER_TH(x) | BIT_TRXRPT_TIMER_TH(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_SPC_WRITE_PTR 16
#define BIT_MASK_SPC_WRITE_PTR 0xf
#define BIT_SPC_WRITE_PTR(x) \
(((x) & BIT_MASK_SPC_WRITE_PTR) << BIT_SHIFT_SPC_WRITE_PTR)
#define BITS_SPC_WRITE_PTR (BIT_MASK_SPC_WRITE_PTR << BIT_SHIFT_SPC_WRITE_PTR)
#define BIT_CLEAR_SPC_WRITE_PTR(x) ((x) & (~BITS_SPC_WRITE_PTR))
#define BIT_GET_SPC_WRITE_PTR(x) \
(((x) >> BIT_SHIFT_SPC_WRITE_PTR) & BIT_MASK_SPC_WRITE_PTR)
#define BIT_SET_SPC_WRITE_PTR(x, v) \
(BIT_CLEAR_SPC_WRITE_PTR(x) | BIT_SPC_WRITE_PTR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_TRXRPT_LEN_TH 16
#define BIT_MASK_TRXRPT_LEN_TH 0xff
#define BIT_TRXRPT_LEN_TH(x) \
(((x) & BIT_MASK_TRXRPT_LEN_TH) << BIT_SHIFT_TRXRPT_LEN_TH)
#define BITS_TRXRPT_LEN_TH (BIT_MASK_TRXRPT_LEN_TH << BIT_SHIFT_TRXRPT_LEN_TH)
#define BIT_CLEAR_TRXRPT_LEN_TH(x) ((x) & (~BITS_TRXRPT_LEN_TH))
#define BIT_GET_TRXRPT_LEN_TH(x) \
(((x) >> BIT_SHIFT_TRXRPT_LEN_TH) & BIT_MASK_TRXRPT_LEN_TH)
#define BIT_SET_TRXRPT_LEN_TH(x, v) \
(BIT_CLEAR_TRXRPT_LEN_TH(x) | BIT_TRXRPT_LEN_TH(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_AC_READ_PTR 8
#define BIT_MASK_AC_READ_PTR 0xf
#define BIT_AC_READ_PTR(x) \
(((x) & BIT_MASK_AC_READ_PTR) << BIT_SHIFT_AC_READ_PTR)
#define BITS_AC_READ_PTR (BIT_MASK_AC_READ_PTR << BIT_SHIFT_AC_READ_PTR)
#define BIT_CLEAR_AC_READ_PTR(x) ((x) & (~BITS_AC_READ_PTR))
#define BIT_GET_AC_READ_PTR(x) \
(((x) >> BIT_SHIFT_AC_READ_PTR) & BIT_MASK_AC_READ_PTR)
#define BIT_SET_AC_READ_PTR(x, v) \
(BIT_CLEAR_AC_READ_PTR(x) | BIT_AC_READ_PTR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_TRXRPT_READ_PTR 8
#define BIT_MASK_TRXRPT_READ_PTR 0xff
#define BIT_TRXRPT_READ_PTR(x) \
(((x) & BIT_MASK_TRXRPT_READ_PTR) << BIT_SHIFT_TRXRPT_READ_PTR)
#define BITS_TRXRPT_READ_PTR \
(BIT_MASK_TRXRPT_READ_PTR << BIT_SHIFT_TRXRPT_READ_PTR)
#define BIT_CLEAR_TRXRPT_READ_PTR(x) ((x) & (~BITS_TRXRPT_READ_PTR))
#define BIT_GET_TRXRPT_READ_PTR(x) \
(((x) >> BIT_SHIFT_TRXRPT_READ_PTR) & BIT_MASK_TRXRPT_READ_PTR)
#define BIT_SET_TRXRPT_READ_PTR(x, v) \
(BIT_CLEAR_TRXRPT_READ_PTR(x) | BIT_TRXRPT_READ_PTR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_AC_WRITE_PTR 0
#define BIT_MASK_AC_WRITE_PTR 0xf
#define BIT_AC_WRITE_PTR(x) \
(((x) & BIT_MASK_AC_WRITE_PTR) << BIT_SHIFT_AC_WRITE_PTR)
#define BITS_AC_WRITE_PTR (BIT_MASK_AC_WRITE_PTR << BIT_SHIFT_AC_WRITE_PTR)
#define BIT_CLEAR_AC_WRITE_PTR(x) ((x) & (~BITS_AC_WRITE_PTR))
#define BIT_GET_AC_WRITE_PTR(x) \
(((x) >> BIT_SHIFT_AC_WRITE_PTR) & BIT_MASK_AC_WRITE_PTR)
#define BIT_SET_AC_WRITE_PTR(x, v) \
(BIT_CLEAR_AC_WRITE_PTR(x) | BIT_AC_WRITE_PTR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_CTRL (Offset 0x047C) */
#define BIT_SHIFT_TRXRPT_WRITE_PTR 0
#define BIT_MASK_TRXRPT_WRITE_PTR 0xff
#define BIT_TRXRPT_WRITE_PTR(x) \
(((x) & BIT_MASK_TRXRPT_WRITE_PTR) << BIT_SHIFT_TRXRPT_WRITE_PTR)
#define BITS_TRXRPT_WRITE_PTR \
(BIT_MASK_TRXRPT_WRITE_PTR << BIT_SHIFT_TRXRPT_WRITE_PTR)
#define BIT_CLEAR_TRXRPT_WRITE_PTR(x) ((x) & (~BITS_TRXRPT_WRITE_PTR))
#define BIT_GET_TRXRPT_WRITE_PTR(x) \
(((x) >> BIT_SHIFT_TRXRPT_WRITE_PTR) & BIT_MASK_TRXRPT_WRITE_PTR)
#define BIT_SET_TRXRPT_WRITE_PTR(x, v) \
(BIT_CLEAR_TRXRPT_WRITE_PTR(x) | BIT_TRXRPT_WRITE_PTR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_INIRTS_RATE_SEL (Offset 0x0480) */
#define BIT_LEAG_RTS_BW_DUP BIT(5)
/* 2 REG_BASIC_CFEND_RATE (Offset 0x0481) */
#define BIT_SHIFT_BASIC_CFEND_RATE 0
#define BIT_MASK_BASIC_CFEND_RATE 0x1f
#define BIT_BASIC_CFEND_RATE(x) \
(((x) & BIT_MASK_BASIC_CFEND_RATE) << BIT_SHIFT_BASIC_CFEND_RATE)
#define BITS_BASIC_CFEND_RATE \
(BIT_MASK_BASIC_CFEND_RATE << BIT_SHIFT_BASIC_CFEND_RATE)
#define BIT_CLEAR_BASIC_CFEND_RATE(x) ((x) & (~BITS_BASIC_CFEND_RATE))
#define BIT_GET_BASIC_CFEND_RATE(x) \
(((x) >> BIT_SHIFT_BASIC_CFEND_RATE) & BIT_MASK_BASIC_CFEND_RATE)
#define BIT_SET_BASIC_CFEND_RATE(x, v) \
(BIT_CLEAR_BASIC_CFEND_RATE(x) | BIT_BASIC_CFEND_RATE(v))
/* 2 REG_STBC_CFEND_RATE (Offset 0x0482) */
#define BIT_SHIFT_STBC_CFEND_RATE 0
#define BIT_MASK_STBC_CFEND_RATE 0x1f
#define BIT_STBC_CFEND_RATE(x) \
(((x) & BIT_MASK_STBC_CFEND_RATE) << BIT_SHIFT_STBC_CFEND_RATE)
#define BITS_STBC_CFEND_RATE \
(BIT_MASK_STBC_CFEND_RATE << BIT_SHIFT_STBC_CFEND_RATE)
#define BIT_CLEAR_STBC_CFEND_RATE(x) ((x) & (~BITS_STBC_CFEND_RATE))
#define BIT_GET_STBC_CFEND_RATE(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_RATE) & BIT_MASK_STBC_CFEND_RATE)
#define BIT_SET_STBC_CFEND_RATE(x, v) \
(BIT_CLEAR_STBC_CFEND_RATE(x) | BIT_STBC_CFEND_RATE(v))
/* 2 REG_DATA_SC (Offset 0x0483) */
#define BIT_SHIFT_TXSC_40M 4
#define BIT_MASK_TXSC_40M 0xf
#define BIT_TXSC_40M(x) (((x) & BIT_MASK_TXSC_40M) << BIT_SHIFT_TXSC_40M)
#define BITS_TXSC_40M (BIT_MASK_TXSC_40M << BIT_SHIFT_TXSC_40M)
#define BIT_CLEAR_TXSC_40M(x) ((x) & (~BITS_TXSC_40M))
#define BIT_GET_TXSC_40M(x) (((x) >> BIT_SHIFT_TXSC_40M) & BIT_MASK_TXSC_40M)
#define BIT_SET_TXSC_40M(x, v) (BIT_CLEAR_TXSC_40M(x) | BIT_TXSC_40M(v))
#define BIT_SHIFT_TXSC_20M 0
#define BIT_MASK_TXSC_20M 0xf
#define BIT_TXSC_20M(x) (((x) & BIT_MASK_TXSC_20M) << BIT_SHIFT_TXSC_20M)
#define BITS_TXSC_20M (BIT_MASK_TXSC_20M << BIT_SHIFT_TXSC_20M)
#define BIT_CLEAR_TXSC_20M(x) ((x) & (~BITS_TXSC_20M))
#define BIT_GET_TXSC_20M(x) (((x) >> BIT_SHIFT_TXSC_20M) & BIT_MASK_TXSC_20M)
#define BIT_SET_TXSC_20M(x, v) (BIT_CLEAR_TXSC_20M(x) | BIT_TXSC_20M(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MACID_SLEEP3 (Offset 0x0484) */
#define BIT_SHIFT_MACID127_96_PKTSLEEP 0
#define BIT_MASK_MACID127_96_PKTSLEEP 0xffffffffL
#define BIT_MACID127_96_PKTSLEEP(x) \
(((x) & BIT_MASK_MACID127_96_PKTSLEEP) \
<< BIT_SHIFT_MACID127_96_PKTSLEEP)
#define BITS_MACID127_96_PKTSLEEP \
(BIT_MASK_MACID127_96_PKTSLEEP << BIT_SHIFT_MACID127_96_PKTSLEEP)
#define BIT_CLEAR_MACID127_96_PKTSLEEP(x) ((x) & (~BITS_MACID127_96_PKTSLEEP))
#define BIT_GET_MACID127_96_PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID127_96_PKTSLEEP) & \
BIT_MASK_MACID127_96_PKTSLEEP)
#define BIT_SET_MACID127_96_PKTSLEEP(x, v) \
(BIT_CLEAR_MACID127_96_PKTSLEEP(x) | BIT_MACID127_96_PKTSLEEP(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MACID_SLEEP3 (Offset 0x0484) */
#define BIT_SHIFT_MACID103_96_PKTSLEEP 0
#define BIT_MASK_MACID103_96_PKTSLEEP 0xff
#define BIT_MACID103_96_PKTSLEEP(x) \
(((x) & BIT_MASK_MACID103_96_PKTSLEEP) \
<< BIT_SHIFT_MACID103_96_PKTSLEEP)
#define BITS_MACID103_96_PKTSLEEP \
(BIT_MASK_MACID103_96_PKTSLEEP << BIT_SHIFT_MACID103_96_PKTSLEEP)
#define BIT_CLEAR_MACID103_96_PKTSLEEP(x) ((x) & (~BITS_MACID103_96_PKTSLEEP))
#define BIT_GET_MACID103_96_PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID103_96_PKTSLEEP) & \
BIT_MASK_MACID103_96_PKTSLEEP)
#define BIT_SET_MACID103_96_PKTSLEEP(x, v) \
(BIT_CLEAR_MACID103_96_PKTSLEEP(x) | BIT_MACID103_96_PKTSLEEP(v))
/* 2 REG_MACID_SLEEP4 (Offset 0x0485) */
#define BIT_SHIFT_MACID119_104_PKTSLEEP 0
#define BIT_MASK_MACID119_104_PKTSLEEP 0xffff
#define BIT_MACID119_104_PKTSLEEP(x) \
(((x) & BIT_MASK_MACID119_104_PKTSLEEP) \
<< BIT_SHIFT_MACID119_104_PKTSLEEP)
#define BITS_MACID119_104_PKTSLEEP \
(BIT_MASK_MACID119_104_PKTSLEEP << BIT_SHIFT_MACID119_104_PKTSLEEP)
#define BIT_CLEAR_MACID119_104_PKTSLEEP(x) ((x) & (~BITS_MACID119_104_PKTSLEEP))
#define BIT_GET_MACID119_104_PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID119_104_PKTSLEEP) & \
BIT_MASK_MACID119_104_PKTSLEEP)
#define BIT_SET_MACID119_104_PKTSLEEP(x, v) \
(BIT_CLEAR_MACID119_104_PKTSLEEP(x) | BIT_MACID119_104_PKTSLEEP(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_SC1 (Offset 0x0487) */
#define BIT_SHIFT_TXSC_160M 4
#define BIT_MASK_TXSC_160M 0xf
#define BIT_TXSC_160M(x) (((x) & BIT_MASK_TXSC_160M) << BIT_SHIFT_TXSC_160M)
#define BITS_TXSC_160M (BIT_MASK_TXSC_160M << BIT_SHIFT_TXSC_160M)
#define BIT_CLEAR_TXSC_160M(x) ((x) & (~BITS_TXSC_160M))
#define BIT_GET_TXSC_160M(x) (((x) >> BIT_SHIFT_TXSC_160M) & BIT_MASK_TXSC_160M)
#define BIT_SET_TXSC_160M(x, v) (BIT_CLEAR_TXSC_160M(x) | BIT_TXSC_160M(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MACID_SLEEP5 (Offset 0x0487) */
#define BIT_SHIFT_MACID127_120_PKTSLEEP 0
#define BIT_MASK_MACID127_120_PKTSLEEP 0xff
#define BIT_MACID127_120_PKTSLEEP(x) \
(((x) & BIT_MASK_MACID127_120_PKTSLEEP) \
<< BIT_SHIFT_MACID127_120_PKTSLEEP)
#define BITS_MACID127_120_PKTSLEEP \
(BIT_MASK_MACID127_120_PKTSLEEP << BIT_SHIFT_MACID127_120_PKTSLEEP)
#define BIT_CLEAR_MACID127_120_PKTSLEEP(x) ((x) & (~BITS_MACID127_120_PKTSLEEP))
#define BIT_GET_MACID127_120_PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID127_120_PKTSLEEP) & \
BIT_MASK_MACID127_120_PKTSLEEP)
#define BIT_SET_MACID127_120_PKTSLEEP(x, v) \
(BIT_CLEAR_MACID127_120_PKTSLEEP(x) | BIT_MACID127_120_PKTSLEEP(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_SC1 (Offset 0x0487) */
#define BIT_SHIFT_TXSC_80M 0
#define BIT_MASK_TXSC_80M 0xf
#define BIT_TXSC_80M(x) (((x) & BIT_MASK_TXSC_80M) << BIT_SHIFT_TXSC_80M)
#define BITS_TXSC_80M (BIT_MASK_TXSC_80M << BIT_SHIFT_TXSC_80M)
#define BIT_CLEAR_TXSC_80M(x) ((x) & (~BITS_TXSC_80M))
#define BIT_GET_TXSC_80M(x) (((x) >> BIT_SHIFT_TXSC_80M) & BIT_MASK_TXSC_80M)
#define BIT_SET_TXSC_80M(x, v) (BIT_CLEAR_TXSC_80M(x) | BIT_TXSC_80M(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MACID_SLEEP1 (Offset 0x0488) */
#define BIT_SHIFT_MACID63_32_PKTSLEEP 0
#define BIT_MASK_MACID63_32_PKTSLEEP 0xffffffffL
#define BIT_MACID63_32_PKTSLEEP(x) \
(((x) & BIT_MASK_MACID63_32_PKTSLEEP) << BIT_SHIFT_MACID63_32_PKTSLEEP)
#define BITS_MACID63_32_PKTSLEEP \
(BIT_MASK_MACID63_32_PKTSLEEP << BIT_SHIFT_MACID63_32_PKTSLEEP)
#define BIT_CLEAR_MACID63_32_PKTSLEEP(x) ((x) & (~BITS_MACID63_32_PKTSLEEP))
#define BIT_GET_MACID63_32_PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID63_32_PKTSLEEP) & BIT_MASK_MACID63_32_PKTSLEEP)
#define BIT_SET_MACID63_32_PKTSLEEP(x, v) \
(BIT_CLEAR_MACID63_32_PKTSLEEP(x) | BIT_MACID63_32_PKTSLEEP(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ARFR2_V1 (Offset 0x048C) */
#define BIT_SHIFT_ARFR2_V1 0
#define BIT_MASK_ARFR2_V1 0xffffffffffffffffL
#define BIT_ARFR2_V1(x) (((x) & BIT_MASK_ARFR2_V1) << BIT_SHIFT_ARFR2_V1)
#define BITS_ARFR2_V1 (BIT_MASK_ARFR2_V1 << BIT_SHIFT_ARFR2_V1)
#define BIT_CLEAR_ARFR2_V1(x) ((x) & (~BITS_ARFR2_V1))
#define BIT_GET_ARFR2_V1(x) (((x) >> BIT_SHIFT_ARFR2_V1) & BIT_MASK_ARFR2_V1)
#define BIT_SET_ARFR2_V1(x, v) (BIT_CLEAR_ARFR2_V1(x) | BIT_ARFR2_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFR2 (Offset 0x048C) */
#define BIT_SHIFT_ARFRL2 0
#define BIT_MASK_ARFRL2 0xffffffffL
#define BIT_ARFRL2(x) (((x) & BIT_MASK_ARFRL2) << BIT_SHIFT_ARFRL2)
#define BITS_ARFRL2 (BIT_MASK_ARFRL2 << BIT_SHIFT_ARFRL2)
#define BIT_CLEAR_ARFRL2(x) ((x) & (~BITS_ARFRL2))
#define BIT_GET_ARFRL2(x) (((x) >> BIT_SHIFT_ARFRL2) & BIT_MASK_ARFRL2)
#define BIT_SET_ARFRL2(x, v) (BIT_CLEAR_ARFRL2(x) | BIT_ARFRL2(v))
/* 2 REG_ARFRH2 (Offset 0x0490) */
#define BIT_SHIFT_ARFRH2 0
#define BIT_MASK_ARFRH2 0xffffffffL
#define BIT_ARFRH2(x) (((x) & BIT_MASK_ARFRH2) << BIT_SHIFT_ARFRH2)
#define BITS_ARFRH2 (BIT_MASK_ARFRH2 << BIT_SHIFT_ARFRH2)
#define BIT_CLEAR_ARFRH2(x) ((x) & (~BITS_ARFRH2))
#define BIT_GET_ARFRH2(x) (((x) >> BIT_SHIFT_ARFRH2) & BIT_MASK_ARFRH2)
#define BIT_SET_ARFRH2(x, v) (BIT_CLEAR_ARFRH2(x) | BIT_ARFRH2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ARFR3_V1 (Offset 0x0494) */
#define BIT_SHIFT_ARFR3_V1 0
#define BIT_MASK_ARFR3_V1 0xffffffffffffffffL
#define BIT_ARFR3_V1(x) (((x) & BIT_MASK_ARFR3_V1) << BIT_SHIFT_ARFR3_V1)
#define BITS_ARFR3_V1 (BIT_MASK_ARFR3_V1 << BIT_SHIFT_ARFR3_V1)
#define BIT_CLEAR_ARFR3_V1(x) ((x) & (~BITS_ARFR3_V1))
#define BIT_GET_ARFR3_V1(x) (((x) >> BIT_SHIFT_ARFR3_V1) & BIT_MASK_ARFR3_V1)
#define BIT_SET_ARFR3_V1(x, v) (BIT_CLEAR_ARFR3_V1(x) | BIT_ARFR3_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFR3_V1 (Offset 0x0494) */
#define BIT_SHIFT_ARFRL3 0
#define BIT_MASK_ARFRL3 0xffffffffL
#define BIT_ARFRL3(x) (((x) & BIT_MASK_ARFRL3) << BIT_SHIFT_ARFRL3)
#define BITS_ARFRL3 (BIT_MASK_ARFRL3 << BIT_SHIFT_ARFRL3)
#define BIT_CLEAR_ARFRL3(x) ((x) & (~BITS_ARFRL3))
#define BIT_GET_ARFRL3(x) (((x) >> BIT_SHIFT_ARFRL3) & BIT_MASK_ARFRL3)
#define BIT_SET_ARFRL3(x, v) (BIT_CLEAR_ARFRL3(x) | BIT_ARFRL3(v))
/* 2 REG_ARFRH3_V1 (Offset 0x0498) */
#define BIT_SHIFT_ARFRH3 0
#define BIT_MASK_ARFRH3 0xffffffffL
#define BIT_ARFRH3(x) (((x) & BIT_MASK_ARFRH3) << BIT_SHIFT_ARFRH3)
#define BITS_ARFRH3 (BIT_MASK_ARFRH3 << BIT_SHIFT_ARFRH3)
#define BIT_CLEAR_ARFRH3(x) ((x) & (~BITS_ARFRH3))
#define BIT_GET_ARFRH3(x) (((x) >> BIT_SHIFT_ARFRH3) & BIT_MASK_ARFRH3)
#define BIT_SET_ARFRH3(x, v) (BIT_CLEAR_ARFRH3(x) | BIT_ARFRH3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ARFR4 (Offset 0x049C) */
#define BIT_SHIFT_ARFR4 0
#define BIT_MASK_ARFR4 0xffffffffffffffffL
#define BIT_ARFR4(x) (((x) & BIT_MASK_ARFR4) << BIT_SHIFT_ARFR4)
#define BITS_ARFR4 (BIT_MASK_ARFR4 << BIT_SHIFT_ARFR4)
#define BIT_CLEAR_ARFR4(x) ((x) & (~BITS_ARFR4))
#define BIT_GET_ARFR4(x) (((x) >> BIT_SHIFT_ARFR4) & BIT_MASK_ARFR4)
#define BIT_SET_ARFR4(x, v) (BIT_CLEAR_ARFR4(x) | BIT_ARFR4(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFR4 (Offset 0x049C) */
#define BIT_SHIFT_ARFRL4 0
#define BIT_MASK_ARFRL4 0xffffffffL
#define BIT_ARFRL4(x) (((x) & BIT_MASK_ARFRL4) << BIT_SHIFT_ARFRL4)
#define BITS_ARFRL4 (BIT_MASK_ARFRL4 << BIT_SHIFT_ARFRL4)
#define BIT_CLEAR_ARFRL4(x) ((x) & (~BITS_ARFRL4))
#define BIT_GET_ARFRL4(x) (((x) >> BIT_SHIFT_ARFRL4) & BIT_MASK_ARFRL4)
#define BIT_SET_ARFRL4(x, v) (BIT_CLEAR_ARFRL4(x) | BIT_ARFRL4(v))
/* 2 REG_ARFRH4 (Offset 0x04A0) */
#define BIT_SHIFT_ARFRH4 0
#define BIT_MASK_ARFRH4 0xffffffffL
#define BIT_ARFRH4(x) (((x) & BIT_MASK_ARFRH4) << BIT_SHIFT_ARFRH4)
#define BITS_ARFRH4 (BIT_MASK_ARFRH4 << BIT_SHIFT_ARFRH4)
#define BIT_CLEAR_ARFRH4(x) ((x) & (~BITS_ARFRH4))
#define BIT_GET_ARFRH4(x) (((x) >> BIT_SHIFT_ARFRH4) & BIT_MASK_ARFRH4)
#define BIT_SET_ARFRH4(x, v) (BIT_CLEAR_ARFRH4(x) | BIT_ARFRH4(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ARFR5 (Offset 0x04A4) */
#define BIT_SHIFT_ARFR5 0
#define BIT_MASK_ARFR5 0xffffffffffffffffL
#define BIT_ARFR5(x) (((x) & BIT_MASK_ARFR5) << BIT_SHIFT_ARFR5)
#define BITS_ARFR5 (BIT_MASK_ARFR5 << BIT_SHIFT_ARFR5)
#define BIT_CLEAR_ARFR5(x) ((x) & (~BITS_ARFR5))
#define BIT_GET_ARFR5(x) (((x) >> BIT_SHIFT_ARFR5) & BIT_MASK_ARFR5)
#define BIT_SET_ARFR5(x, v) (BIT_CLEAR_ARFR5(x) | BIT_ARFR5(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ARFR5 (Offset 0x04A4) */
#define BIT_SHIFT_ARFRL5 0
#define BIT_MASK_ARFRL5 0xffffffffL
#define BIT_ARFRL5(x) (((x) & BIT_MASK_ARFRL5) << BIT_SHIFT_ARFRL5)
#define BITS_ARFRL5 (BIT_MASK_ARFRL5 << BIT_SHIFT_ARFRL5)
#define BIT_CLEAR_ARFRL5(x) ((x) & (~BITS_ARFRL5))
#define BIT_GET_ARFRL5(x) (((x) >> BIT_SHIFT_ARFRL5) & BIT_MASK_ARFRL5)
#define BIT_SET_ARFRL5(x, v) (BIT_CLEAR_ARFRL5(x) | BIT_ARFRL5(v))
/* 2 REG_ARFRH5 (Offset 0x04A8) */
#define BIT_SHIFT_ARFRH5 0
#define BIT_MASK_ARFRH5 0xffffffffL
#define BIT_ARFRH5(x) (((x) & BIT_MASK_ARFRH5) << BIT_SHIFT_ARFRH5)
#define BITS_ARFRH5 (BIT_MASK_ARFRH5 << BIT_SHIFT_ARFRH5)
#define BIT_CLEAR_ARFRH5(x) ((x) & (~BITS_ARFRH5))
#define BIT_GET_ARFRH5(x) (((x) >> BIT_SHIFT_ARFRH5) & BIT_MASK_ARFRH5)
#define BIT_SET_ARFRH5(x, v) (BIT_CLEAR_ARFRH5(x) | BIT_ARFRH5(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_RPTFIFO_RPTNUM_OPT BIT(31)
#define BIT_SHIFT_MISSED_RPT_NUM 28
#define BIT_MASK_MISSED_RPT_NUM 0x7
#define BIT_MISSED_RPT_NUM(x) \
(((x) & BIT_MASK_MISSED_RPT_NUM) << BIT_SHIFT_MISSED_RPT_NUM)
#define BITS_MISSED_RPT_NUM \
(BIT_MASK_MISSED_RPT_NUM << BIT_SHIFT_MISSED_RPT_NUM)
#define BIT_CLEAR_MISSED_RPT_NUM(x) ((x) & (~BITS_MISSED_RPT_NUM))
#define BIT_GET_MISSED_RPT_NUM(x) \
(((x) >> BIT_SHIFT_MISSED_RPT_NUM) & BIT_MASK_MISSED_RPT_NUM)
#define BIT_SET_MISSED_RPT_NUM(x, v) \
(BIT_CLEAR_MISSED_RPT_NUM(x) | BIT_MISSED_RPT_NUM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHCUT_PARSE_DASA BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_INDEX_15 24
#define BIT_MASK_INDEX_15 0xff
#define BIT_INDEX_15(x) (((x) & BIT_MASK_INDEX_15) << BIT_SHIFT_INDEX_15)
#define BITS_INDEX_15 (BIT_MASK_INDEX_15 << BIT_SHIFT_INDEX_15)
#define BIT_CLEAR_INDEX_15(x) ((x) & (~BITS_INDEX_15))
#define BIT_GET_INDEX_15(x) (((x) >> BIT_SHIFT_INDEX_15) & BIT_MASK_INDEX_15)
#define BIT_SET_INDEX_15(x, v) (BIT_CLEAR_INDEX_15(x) | BIT_INDEX_15(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_LOC_AMPDU_BURST_CTRL 24
#define BIT_MASK_LOC_AMPDU_BURST_CTRL 0xff
#define BIT_LOC_AMPDU_BURST_CTRL(x) \
(((x) & BIT_MASK_LOC_AMPDU_BURST_CTRL) \
<< BIT_SHIFT_LOC_AMPDU_BURST_CTRL)
#define BITS_LOC_AMPDU_BURST_CTRL \
(BIT_MASK_LOC_AMPDU_BURST_CTRL << BIT_SHIFT_LOC_AMPDU_BURST_CTRL)
#define BIT_CLEAR_LOC_AMPDU_BURST_CTRL(x) ((x) & (~BITS_LOC_AMPDU_BURST_CTRL))
#define BIT_GET_LOC_AMPDU_BURST_CTRL(x) \
(((x) >> BIT_SHIFT_LOC_AMPDU_BURST_CTRL) & \
BIT_MASK_LOC_AMPDU_BURST_CTRL)
#define BIT_SET_LOC_AMPDU_BURST_CTRL(x, v) \
(BIT_CLEAR_LOC_AMPDU_BURST_CTRL(x) | BIT_LOC_AMPDU_BURST_CTRL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_LOC_SWPS_RPT_CTRL 24
#define BIT_MASK_LOC_SWPS_RPT_CTRL 0xff
#define BIT_LOC_SWPS_RPT_CTRL(x) \
(((x) & BIT_MASK_LOC_SWPS_RPT_CTRL) << BIT_SHIFT_LOC_SWPS_RPT_CTRL)
#define BITS_LOC_SWPS_RPT_CTRL \
(BIT_MASK_LOC_SWPS_RPT_CTRL << BIT_SHIFT_LOC_SWPS_RPT_CTRL)
#define BIT_CLEAR_LOC_SWPS_RPT_CTRL(x) ((x) & (~BITS_LOC_SWPS_RPT_CTRL))
#define BIT_GET_LOC_SWPS_RPT_CTRL(x) \
(((x) >> BIT_SHIFT_LOC_SWPS_RPT_CTRL) & BIT_MASK_LOC_SWPS_RPT_CTRL)
#define BIT_SET_LOC_SWPS_RPT_CTRL(x, v) \
(BIT_CLEAR_LOC_SWPS_RPT_CTRL(x) | BIT_LOC_SWPS_RPT_CTRL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHCUT_BYPASS BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_MACID_MURATE_OFFSET 24
#define BIT_MASK_MACID_MURATE_OFFSET 0xff
#define BIT_MACID_MURATE_OFFSET(x) \
(((x) & BIT_MASK_MACID_MURATE_OFFSET) << BIT_SHIFT_MACID_MURATE_OFFSET)
#define BITS_MACID_MURATE_OFFSET \
(BIT_MASK_MACID_MURATE_OFFSET << BIT_SHIFT_MACID_MURATE_OFFSET)
#define BIT_CLEAR_MACID_MURATE_OFFSET(x) ((x) & (~BITS_MACID_MURATE_OFFSET))
#define BIT_GET_MACID_MURATE_OFFSET(x) \
(((x) >> BIT_SHIFT_MACID_MURATE_OFFSET) & BIT_MASK_MACID_MURATE_OFFSET)
#define BIT_SET_MACID_MURATE_OFFSET(x, v) \
(BIT_CLEAR_MACID_MURATE_OFFSET(x) | BIT_MACID_MURATE_OFFSET(v))
#endif
#if (HALMAC_8821C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_R_MUTAB_TXRPT_OFFSET 24
#define BIT_MASK_R_MUTAB_TXRPT_OFFSET 0xff
#define BIT_R_MUTAB_TXRPT_OFFSET(x) \
(((x) & BIT_MASK_R_MUTAB_TXRPT_OFFSET) \
<< BIT_SHIFT_R_MUTAB_TXRPT_OFFSET)
#define BITS_R_MUTAB_TXRPT_OFFSET \
(BIT_MASK_R_MUTAB_TXRPT_OFFSET << BIT_SHIFT_R_MUTAB_TXRPT_OFFSET)
#define BIT_CLEAR_R_MUTAB_TXRPT_OFFSET(x) ((x) & (~BITS_R_MUTAB_TXRPT_OFFSET))
#define BIT_GET_R_MUTAB_TXRPT_OFFSET(x) \
(((x) >> BIT_SHIFT_R_MUTAB_TXRPT_OFFSET) & \
BIT_MASK_R_MUTAB_TXRPT_OFFSET)
#define BIT_SET_R_MUTAB_TXRPT_OFFSET(x, v) \
(BIT_CLEAR_R_MUTAB_TXRPT_OFFSET(x) | BIT_R_MUTAB_TXRPT_OFFSET(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_TXRPT_MISS_COUNT 17
#define BIT_MASK_TXRPT_MISS_COUNT 0x7
#define BIT_TXRPT_MISS_COUNT(x) \
(((x) & BIT_MASK_TXRPT_MISS_COUNT) << BIT_SHIFT_TXRPT_MISS_COUNT)
#define BITS_TXRPT_MISS_COUNT \
(BIT_MASK_TXRPT_MISS_COUNT << BIT_SHIFT_TXRPT_MISS_COUNT)
#define BIT_CLEAR_TXRPT_MISS_COUNT(x) ((x) & (~BITS_TXRPT_MISS_COUNT))
#define BIT_GET_TXRPT_MISS_COUNT(x) \
(((x) >> BIT_SHIFT_TXRPT_MISS_COUNT) & BIT_MASK_TXRPT_MISS_COUNT)
#define BIT_SET_TXRPT_MISS_COUNT(x, v) \
(BIT_CLEAR_TXRPT_MISS_COUNT(x) | BIT_TXRPT_MISS_COUNT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_LOC_BCN_RPT 16
#define BIT_MASK_LOC_BCN_RPT 0xff
#define BIT_LOC_BCN_RPT(x) \
(((x) & BIT_MASK_LOC_BCN_RPT) << BIT_SHIFT_LOC_BCN_RPT)
#define BITS_LOC_BCN_RPT (BIT_MASK_LOC_BCN_RPT << BIT_SHIFT_LOC_BCN_RPT)
#define BIT_CLEAR_LOC_BCN_RPT(x) ((x) & (~BITS_LOC_BCN_RPT))
#define BIT_GET_LOC_BCN_RPT(x) \
(((x) >> BIT_SHIFT_LOC_BCN_RPT) & BIT_MASK_LOC_BCN_RPT)
#define BIT_SET_LOC_BCN_RPT(x, v) \
(BIT_CLEAR_LOC_BCN_RPT(x) | BIT_LOC_BCN_RPT(v))
#define BIT_SHIFT_INDEX_14 16
#define BIT_MASK_INDEX_14 0xff
#define BIT_INDEX_14(x) (((x) & BIT_MASK_INDEX_14) << BIT_SHIFT_INDEX_14)
#define BITS_INDEX_14 (BIT_MASK_INDEX_14 << BIT_SHIFT_INDEX_14)
#define BIT_CLEAR_INDEX_14(x) ((x) & (~BITS_INDEX_14))
#define BIT_GET_INDEX_14(x) (((x) >> BIT_SHIFT_INDEX_14) & BIT_MASK_INDEX_14)
#define BIT_SET_INDEX_14(x, v) (BIT_CLEAR_INDEX_14(x) | BIT_INDEX_14(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT__R_RPTFIFO_1K BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_RPTFIFO_SIZE_OPT BIT(16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_MACID_SHCUT_OFFSET 16
#define BIT_MASK_MACID_SHCUT_OFFSET 0xff
#define BIT_MACID_SHCUT_OFFSET(x) \
(((x) & BIT_MASK_MACID_SHCUT_OFFSET) << BIT_SHIFT_MACID_SHCUT_OFFSET)
#define BITS_MACID_SHCUT_OFFSET \
(BIT_MASK_MACID_SHCUT_OFFSET << BIT_SHIFT_MACID_SHCUT_OFFSET)
#define BIT_CLEAR_MACID_SHCUT_OFFSET(x) ((x) & (~BITS_MACID_SHCUT_OFFSET))
#define BIT_GET_MACID_SHCUT_OFFSET(x) \
(((x) >> BIT_SHIFT_MACID_SHCUT_OFFSET) & BIT_MASK_MACID_SHCUT_OFFSET)
#define BIT_SET_MACID_SHCUT_OFFSET(x, v) \
(BIT_CLEAR_MACID_SHCUT_OFFSET(x) | BIT_MACID_SHCUT_OFFSET(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_MACID_CTRL_OFFSET_V1 16
#define BIT_MASK_MACID_CTRL_OFFSET_V1 0x1ff
#define BIT_MACID_CTRL_OFFSET_V1(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET_V1) \
<< BIT_SHIFT_MACID_CTRL_OFFSET_V1)
#define BITS_MACID_CTRL_OFFSET_V1 \
(BIT_MASK_MACID_CTRL_OFFSET_V1 << BIT_SHIFT_MACID_CTRL_OFFSET_V1)
#define BIT_CLEAR_MACID_CTRL_OFFSET_V1(x) ((x) & (~BITS_MACID_CTRL_OFFSET_V1))
#define BIT_GET_MACID_CTRL_OFFSET_V1(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET_V1) & \
BIT_MASK_MACID_CTRL_OFFSET_V1)
#define BIT_SET_MACID_CTRL_OFFSET_V1(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET_V1(x) | BIT_MACID_CTRL_OFFSET_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_LOC_TXRPT 8
#define BIT_MASK_LOC_TXRPT 0xff
#define BIT_LOC_TXRPT(x) (((x) & BIT_MASK_LOC_TXRPT) << BIT_SHIFT_LOC_TXRPT)
#define BITS_LOC_TXRPT (BIT_MASK_LOC_TXRPT << BIT_SHIFT_LOC_TXRPT)
#define BIT_CLEAR_LOC_TXRPT(x) ((x) & (~BITS_LOC_TXRPT))
#define BIT_GET_LOC_TXRPT(x) (((x) >> BIT_SHIFT_LOC_TXRPT) & BIT_MASK_LOC_TXRPT)
#define BIT_SET_LOC_TXRPT(x, v) (BIT_CLEAR_LOC_TXRPT(x) | BIT_LOC_TXRPT(v))
#define BIT_SHIFT_INDEX_13 8
#define BIT_MASK_INDEX_13 0xff
#define BIT_INDEX_13(x) (((x) & BIT_MASK_INDEX_13) << BIT_SHIFT_INDEX_13)
#define BITS_INDEX_13 (BIT_MASK_INDEX_13 << BIT_SHIFT_INDEX_13)
#define BIT_CLEAR_INDEX_13(x) ((x) & (~BITS_INDEX_13))
#define BIT_GET_INDEX_13(x) (((x) >> BIT_SHIFT_INDEX_13) & BIT_MASK_INDEX_13)
#define BIT_SET_INDEX_13(x, v) (BIT_CLEAR_INDEX_13(x) | BIT_INDEX_13(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_MACID_CTRL_OFFSET 8
#define BIT_MASK_MACID_CTRL_OFFSET 0xff
#define BIT_MACID_CTRL_OFFSET(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET) << BIT_SHIFT_MACID_CTRL_OFFSET)
#define BITS_MACID_CTRL_OFFSET \
(BIT_MASK_MACID_CTRL_OFFSET << BIT_SHIFT_MACID_CTRL_OFFSET)
#define BIT_CLEAR_MACID_CTRL_OFFSET(x) ((x) & (~BITS_MACID_CTRL_OFFSET))
#define BIT_GET_MACID_CTRL_OFFSET(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET) & BIT_MASK_MACID_CTRL_OFFSET)
#define BIT_SET_MACID_CTRL_OFFSET(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET(x) | BIT_MACID_CTRL_OFFSET(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_LOC_SRFF 0
#define BIT_MASK_LOC_SRFF 0xff
#define BIT_LOC_SRFF(x) (((x) & BIT_MASK_LOC_SRFF) << BIT_SHIFT_LOC_SRFF)
#define BITS_LOC_SRFF (BIT_MASK_LOC_SRFF << BIT_SHIFT_LOC_SRFF)
#define BIT_CLEAR_LOC_SRFF(x) ((x) & (~BITS_LOC_SRFF))
#define BIT_GET_LOC_SRFF(x) (((x) >> BIT_SHIFT_LOC_SRFF) & BIT_MASK_LOC_SRFF)
#define BIT_SET_LOC_SRFF(x, v) (BIT_CLEAR_LOC_SRFF(x) | BIT_LOC_SRFF(v))
#define BIT_SHIFT_INDEX_12 0
#define BIT_MASK_INDEX_12 0xff
#define BIT_INDEX_12(x) (((x) & BIT_MASK_INDEX_12) << BIT_SHIFT_INDEX_12)
#define BITS_INDEX_12 (BIT_MASK_INDEX_12 << BIT_SHIFT_INDEX_12)
#define BIT_CLEAR_INDEX_12(x) ((x) & (~BITS_INDEX_12))
#define BIT_GET_INDEX_12(x) (((x) >> BIT_SHIFT_INDEX_12) & BIT_MASK_INDEX_12)
#define BIT_SET_INDEX_12(x, v) (BIT_CLEAR_INDEX_12(x) | BIT_INDEX_12(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT 0x1f
#define BIT_RA_TRY_RATE_AGG_LMT(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT) << BIT_SHIFT_RA_TRY_RATE_AGG_LMT)
#define BITS_RA_TRY_RATE_AGG_LMT \
(BIT_MASK_RA_TRY_RATE_AGG_LMT << BIT_SHIFT_RA_TRY_RATE_AGG_LMT)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT(x) ((x) & (~BITS_RA_TRY_RATE_AGG_LMT))
#define BIT_GET_RA_TRY_RATE_AGG_LMT(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT) & BIT_MASK_RA_TRY_RATE_AGG_LMT)
#define BIT_SET_RA_TRY_RATE_AGG_LMT(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT(x) | BIT_RA_TRY_RATE_AGG_LMT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET 0xff
#define BIT_AMPDU_TXRPT_OFFSET(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET) << BIT_SHIFT_AMPDU_TXRPT_OFFSET)
#define BITS_AMPDU_TXRPT_OFFSET \
(BIT_MASK_AMPDU_TXRPT_OFFSET << BIT_SHIFT_AMPDU_TXRPT_OFFSET)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET(x) ((x) & (~BITS_AMPDU_TXRPT_OFFSET))
#define BIT_GET_AMPDU_TXRPT_OFFSET(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET) & BIT_MASK_AMPDU_TXRPT_OFFSET)
#define BIT_SET_AMPDU_TXRPT_OFFSET(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET(x) | BIT_AMPDU_TXRPT_OFFSET(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXRPT_START_OFFSET (Offset 0x04AC) */
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET_V1 0x1ff
#define BIT_AMPDU_TXRPT_OFFSET_V1(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET_V1) \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1)
#define BITS_AMPDU_TXRPT_OFFSET_V1 \
(BIT_MASK_AMPDU_TXRPT_OFFSET_V1 << BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET_V1(x) ((x) & (~BITS_AMPDU_TXRPT_OFFSET_V1))
#define BIT_GET_AMPDU_TXRPT_OFFSET_V1(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1) & \
BIT_MASK_AMPDU_TXRPT_OFFSET_V1)
#define BIT_SET_AMPDU_TXRPT_OFFSET_V1(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET_V1(x) | BIT_AMPDU_TXRPT_OFFSET_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_RRSR_CTS (Offset 0x04B0) */
#define BIT_SHIFT_RRCTSSR_RSC 21
#define BIT_MASK_RRCTSSR_RSC 0x3
#define BIT_RRCTSSR_RSC(x) \
(((x) & BIT_MASK_RRCTSSR_RSC) << BIT_SHIFT_RRCTSSR_RSC)
#define BITS_RRCTSSR_RSC (BIT_MASK_RRCTSSR_RSC << BIT_SHIFT_RRCTSSR_RSC)
#define BIT_CLEAR_RRCTSSR_RSC(x) ((x) & (~BITS_RRCTSSR_RSC))
#define BIT_GET_RRCTSSR_RSC(x) \
(((x) >> BIT_SHIFT_RRCTSSR_RSC) & BIT_MASK_RRCTSSR_RSC)
#define BIT_SET_RRCTSSR_RSC(x, v) \
(BIT_CLEAR_RRCTSSR_RSC(x) | BIT_RRCTSSR_RSC(v))
#define BIT_SHIFT_RRCTSSC_BITMAP 0
#define BIT_MASK_RRCTSSC_BITMAP 0xfffff
#define BIT_RRCTSSC_BITMAP(x) \
(((x) & BIT_MASK_RRCTSSC_BITMAP) << BIT_SHIFT_RRCTSSC_BITMAP)
#define BITS_RRCTSSC_BITMAP \
(BIT_MASK_RRCTSSC_BITMAP << BIT_SHIFT_RRCTSSC_BITMAP)
#define BIT_CLEAR_RRCTSSC_BITMAP(x) ((x) & (~BITS_RRCTSSC_BITMAP))
#define BIT_GET_RRCTSSC_BITMAP(x) \
(((x) >> BIT_SHIFT_RRCTSSC_BITMAP) & BIT_MASK_RRCTSSC_BITMAP)
#define BIT_SET_RRCTSSC_BITMAP(x, v) \
(BIT_CLEAR_RRCTSSC_BITMAP(x) | BIT_RRCTSSC_BITMAP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_POWER_STAGE1 (Offset 0x04B4) */
#define BIT_PTA_WL_PRI_MASK_CPU_MGQ BIT(31)
#define BIT_PTA_WL_PRI_MASK_BCNQ BIT(30)
#define BIT_PTA_WL_PRI_MASK_HIQ BIT(29)
#define BIT_PTA_WL_PRI_MASK_MGQ BIT(28)
#define BIT_PTA_WL_PRI_MASK_BK BIT(27)
#define BIT_PTA_WL_PRI_MASK_BE BIT(26)
#define BIT_PTA_WL_PRI_MASK_VI BIT(25)
#define BIT_PTA_WL_PRI_MASK_VO BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_POWER_STAGE1 (Offset 0x04B4) */
#define BIT_SHIFT_POWER_STAGE1 0
#define BIT_MASK_POWER_STAGE1 0xffffff
#define BIT_POWER_STAGE1(x) \
(((x) & BIT_MASK_POWER_STAGE1) << BIT_SHIFT_POWER_STAGE1)
#define BITS_POWER_STAGE1 (BIT_MASK_POWER_STAGE1 << BIT_SHIFT_POWER_STAGE1)
#define BIT_CLEAR_POWER_STAGE1(x) ((x) & (~BITS_POWER_STAGE1))
#define BIT_GET_POWER_STAGE1(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1) & BIT_MASK_POWER_STAGE1)
#define BIT_SET_POWER_STAGE1(x, v) \
(BIT_CLEAR_POWER_STAGE1(x) | BIT_POWER_STAGE1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_POWER_STAGE2 (Offset 0x04B8) */
#define BIT_SHIFT_EVTQ_TXRPT 27
#define BIT_MASK_EVTQ_TXRPT 0x7
#define BIT_EVTQ_TXRPT(x) (((x) & BIT_MASK_EVTQ_TXRPT) << BIT_SHIFT_EVTQ_TXRPT)
#define BITS_EVTQ_TXRPT (BIT_MASK_EVTQ_TXRPT << BIT_SHIFT_EVTQ_TXRPT)
#define BIT_CLEAR_EVTQ_TXRPT(x) ((x) & (~BITS_EVTQ_TXRPT))
#define BIT_GET_EVTQ_TXRPT(x) \
(((x) >> BIT_SHIFT_EVTQ_TXRPT) & BIT_MASK_EVTQ_TXRPT)
#define BIT_SET_EVTQ_TXRPT(x, v) (BIT_CLEAR_EVTQ_TXRPT(x) | BIT_EVTQ_TXRPT(v))
#define BIT_PTA_WL_PRI_MASK_EVT BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_POWER_STAGE2 (Offset 0x04B8) */
#define BIT__CTRL_PKT_POW_ADJ BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_POWER_STAGE2 (Offset 0x04B8) */
#define BIT__R_CTRL_PKT_POW_ADJ BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_POWER_STAGE2 (Offset 0x04B8) */
#define BIT_SHIFT_POWER_STAGE2 0
#define BIT_MASK_POWER_STAGE2 0xffffff
#define BIT_POWER_STAGE2(x) \
(((x) & BIT_MASK_POWER_STAGE2) << BIT_SHIFT_POWER_STAGE2)
#define BITS_POWER_STAGE2 (BIT_MASK_POWER_STAGE2 << BIT_SHIFT_POWER_STAGE2)
#define BIT_CLEAR_POWER_STAGE2(x) ((x) & (~BITS_POWER_STAGE2))
#define BIT_GET_POWER_STAGE2(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2) & BIT_MASK_POWER_STAGE2)
#define BIT_SET_POWER_STAGE2(x, v) \
(BIT_CLEAR_POWER_STAGE2(x) | BIT_POWER_STAGE2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_SHIFT_EVTQ_HEAD 24
#define BIT_MASK_EVTQ_HEAD 0xff
#define BIT_EVTQ_HEAD(x) (((x) & BIT_MASK_EVTQ_HEAD) << BIT_SHIFT_EVTQ_HEAD)
#define BITS_EVTQ_HEAD (BIT_MASK_EVTQ_HEAD << BIT_SHIFT_EVTQ_HEAD)
#define BIT_CLEAR_EVTQ_HEAD(x) ((x) & (~BITS_EVTQ_HEAD))
#define BIT_GET_EVTQ_HEAD(x) (((x) >> BIT_SHIFT_EVTQ_HEAD) & BIT_MASK_EVTQ_HEAD)
#define BIT_SET_EVTQ_HEAD(x, v) (BIT_CLEAR_EVTQ_HEAD(x) | BIT_EVTQ_HEAD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_SHIFT_PAD_NUM_THRES 24
#define BIT_MASK_PAD_NUM_THRES 0x3f
#define BIT_PAD_NUM_THRES(x) \
(((x) & BIT_MASK_PAD_NUM_THRES) << BIT_SHIFT_PAD_NUM_THRES)
#define BITS_PAD_NUM_THRES (BIT_MASK_PAD_NUM_THRES << BIT_SHIFT_PAD_NUM_THRES)
#define BIT_CLEAR_PAD_NUM_THRES(x) ((x) & (~BITS_PAD_NUM_THRES))
#define BIT_GET_PAD_NUM_THRES(x) \
(((x) >> BIT_SHIFT_PAD_NUM_THRES) & BIT_MASK_PAD_NUM_THRES)
#define BIT_SET_PAD_NUM_THRES(x, v) \
(BIT_CLEAR_PAD_NUM_THRES(x) | BIT_PAD_NUM_THRES(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_R_DMA_THIS_QUEUE_BK BIT(23)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_DMA_THIS_QUEUE_BK BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_R_DMA_THIS_QUEUE_BE BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_DMA_THIS_QUEUE_BE BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_R_DMA_THIS_QUEUE_VI BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_DMA_THIS_QUEUE_VI BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_R_DMA_THIS_QUEUE_VO BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_DMA_THIS_QUEUE_VO BIT(20)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_SHIFT_R_TOTAL_LEN_TH 8
#define BIT_MASK_R_TOTAL_LEN_TH 0xfff
#define BIT_R_TOTAL_LEN_TH(x) \
(((x) & BIT_MASK_R_TOTAL_LEN_TH) << BIT_SHIFT_R_TOTAL_LEN_TH)
#define BITS_R_TOTAL_LEN_TH \
(BIT_MASK_R_TOTAL_LEN_TH << BIT_SHIFT_R_TOTAL_LEN_TH)
#define BIT_CLEAR_R_TOTAL_LEN_TH(x) ((x) & (~BITS_R_TOTAL_LEN_TH))
#define BIT_GET_R_TOTAL_LEN_TH(x) \
(((x) >> BIT_SHIFT_R_TOTAL_LEN_TH) & BIT_MASK_R_TOTAL_LEN_TH)
#define BIT_SET_R_TOTAL_LEN_TH(x, v) \
(BIT_CLEAR_R_TOTAL_LEN_TH(x) | BIT_R_TOTAL_LEN_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_SHIFT_TOTAL_LEN_TH 8
#define BIT_MASK_TOTAL_LEN_TH 0xfff
#define BIT_TOTAL_LEN_TH(x) \
(((x) & BIT_MASK_TOTAL_LEN_TH) << BIT_SHIFT_TOTAL_LEN_TH)
#define BITS_TOTAL_LEN_TH (BIT_MASK_TOTAL_LEN_TH << BIT_SHIFT_TOTAL_LEN_TH)
#define BIT_CLEAR_TOTAL_LEN_TH(x) ((x) & (~BITS_TOTAL_LEN_TH))
#define BIT_GET_TOTAL_LEN_TH(x) \
(((x) >> BIT_SHIFT_TOTAL_LEN_TH) & BIT_MASK_TOTAL_LEN_TH)
#define BIT_SET_TOTAL_LEN_TH(x, v) \
(BIT_CLEAR_TOTAL_LEN_TH(x) | BIT_TOTAL_LEN_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_WEP_PRETX_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_EN_NEW_EARLY BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL (Offset 0x04BC) */
#define BIT_PRE_TX_CMD BIT(6)
#define BIT_SHIFT_NUM_SCL_EN 4
#define BIT_MASK_NUM_SCL_EN 0x3
#define BIT_NUM_SCL_EN(x) (((x) & BIT_MASK_NUM_SCL_EN) << BIT_SHIFT_NUM_SCL_EN)
#define BITS_NUM_SCL_EN (BIT_MASK_NUM_SCL_EN << BIT_SHIFT_NUM_SCL_EN)
#define BIT_CLEAR_NUM_SCL_EN(x) ((x) & (~BITS_NUM_SCL_EN))
#define BIT_GET_NUM_SCL_EN(x) \
(((x) >> BIT_SHIFT_NUM_SCL_EN) & BIT_MASK_NUM_SCL_EN)
#define BIT_SET_NUM_SCL_EN(x, v) (BIT_CLEAR_NUM_SCL_EN(x) | BIT_NUM_SCL_EN(v))
#define BIT_BK_EN BIT(3)
#define BIT_BE_EN BIT(2)
#define BIT_VI_EN BIT(1)
#define BIT_VO_EN BIT(0)
/* 2 REG_PKT_LIFE_TIME (Offset 0x04C0) */
#define BIT_SHIFT_PKT_LIFTIME_BEBK 16
#define BIT_MASK_PKT_LIFTIME_BEBK 0xffff
#define BIT_PKT_LIFTIME_BEBK(x) \
(((x) & BIT_MASK_PKT_LIFTIME_BEBK) << BIT_SHIFT_PKT_LIFTIME_BEBK)
#define BITS_PKT_LIFTIME_BEBK \
(BIT_MASK_PKT_LIFTIME_BEBK << BIT_SHIFT_PKT_LIFTIME_BEBK)
#define BIT_CLEAR_PKT_LIFTIME_BEBK(x) ((x) & (~BITS_PKT_LIFTIME_BEBK))
#define BIT_GET_PKT_LIFTIME_BEBK(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_BEBK) & BIT_MASK_PKT_LIFTIME_BEBK)
#define BIT_SET_PKT_LIFTIME_BEBK(x, v) \
(BIT_CLEAR_PKT_LIFTIME_BEBK(x) | BIT_PKT_LIFTIME_BEBK(v))
#define BIT_SHIFT_PKT_LIFTIME_VOVI 0
#define BIT_MASK_PKT_LIFTIME_VOVI 0xffff
#define BIT_PKT_LIFTIME_VOVI(x) \
(((x) & BIT_MASK_PKT_LIFTIME_VOVI) << BIT_SHIFT_PKT_LIFTIME_VOVI)
#define BITS_PKT_LIFTIME_VOVI \
(BIT_MASK_PKT_LIFTIME_VOVI << BIT_SHIFT_PKT_LIFTIME_VOVI)
#define BIT_CLEAR_PKT_LIFTIME_VOVI(x) ((x) & (~BITS_PKT_LIFTIME_VOVI))
#define BIT_GET_PKT_LIFTIME_VOVI(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_VOVI) & BIT_MASK_PKT_LIFTIME_VOVI)
#define BIT_SET_PKT_LIFTIME_VOVI(x, v) \
(BIT_CLEAR_PKT_LIFTIME_VOVI(x) | BIT_PKT_LIFTIME_VOVI(v))
/* 2 REG_STBC_SETTING (Offset 0x04C4) */
#define BIT_SHIFT_CDEND_TXTIME_L 4
#define BIT_MASK_CDEND_TXTIME_L 0xf
#define BIT_CDEND_TXTIME_L(x) \
(((x) & BIT_MASK_CDEND_TXTIME_L) << BIT_SHIFT_CDEND_TXTIME_L)
#define BITS_CDEND_TXTIME_L \
(BIT_MASK_CDEND_TXTIME_L << BIT_SHIFT_CDEND_TXTIME_L)
#define BIT_CLEAR_CDEND_TXTIME_L(x) ((x) & (~BITS_CDEND_TXTIME_L))
#define BIT_GET_CDEND_TXTIME_L(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_L) & BIT_MASK_CDEND_TXTIME_L)
#define BIT_SET_CDEND_TXTIME_L(x, v) \
(BIT_CLEAR_CDEND_TXTIME_L(x) | BIT_CDEND_TXTIME_L(v))
#define BIT_SHIFT_NESS 2
#define BIT_MASK_NESS 0x3
#define BIT_NESS(x) (((x) & BIT_MASK_NESS) << BIT_SHIFT_NESS)
#define BITS_NESS (BIT_MASK_NESS << BIT_SHIFT_NESS)
#define BIT_CLEAR_NESS(x) ((x) & (~BITS_NESS))
#define BIT_GET_NESS(x) (((x) >> BIT_SHIFT_NESS) & BIT_MASK_NESS)
#define BIT_SET_NESS(x, v) (BIT_CLEAR_NESS(x) | BIT_NESS(v))
#define BIT_SHIFT_STBC_CFEND 0
#define BIT_MASK_STBC_CFEND 0x3
#define BIT_STBC_CFEND(x) (((x) & BIT_MASK_STBC_CFEND) << BIT_SHIFT_STBC_CFEND)
#define BITS_STBC_CFEND (BIT_MASK_STBC_CFEND << BIT_SHIFT_STBC_CFEND)
#define BIT_CLEAR_STBC_CFEND(x) ((x) & (~BITS_STBC_CFEND))
#define BIT_GET_STBC_CFEND(x) \
(((x) >> BIT_SHIFT_STBC_CFEND) & BIT_MASK_STBC_CFEND)
#define BIT_SET_STBC_CFEND(x, v) (BIT_CLEAR_STBC_CFEND(x) | BIT_STBC_CFEND(v))
/* 2 REG_STBC_SETTING2 (Offset 0x04C5) */
#define BIT_SHIFT_CDEND_TXTIME_H 0
#define BIT_MASK_CDEND_TXTIME_H 0x1f
#define BIT_CDEND_TXTIME_H(x) \
(((x) & BIT_MASK_CDEND_TXTIME_H) << BIT_SHIFT_CDEND_TXTIME_H)
#define BITS_CDEND_TXTIME_H \
(BIT_MASK_CDEND_TXTIME_H << BIT_SHIFT_CDEND_TXTIME_H)
#define BIT_CLEAR_CDEND_TXTIME_H(x) ((x) & (~BITS_CDEND_TXTIME_H))
#define BIT_GET_CDEND_TXTIME_H(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_H) & BIT_MASK_CDEND_TXTIME_H)
#define BIT_SET_CDEND_TXTIME_H(x, v) \
(BIT_CLEAR_CDEND_TXTIME_H(x) | BIT_CDEND_TXTIME_H(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_QUEUE_CTRL (Offset 0x04C6) */
#define BIT_FORCE_RND_PRI BIT(6)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_CTRL (Offset 0x04C6) */
#define BIT_R_FORCE_RND_PRI BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_QUEUE_CTRL (Offset 0x04C6) */
#define BIT_PTA_EDCCA_EN BIT(5)
#define BIT_PTA_WL_TX_EN BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_QUEUE_CTRL (Offset 0x04C6) */
#define BIT_R_USE_DATA_BW BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_QUEUE_CTRL (Offset 0x04C6) */
#define BIT_USE_DATA_BW BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_QUEUE_CTRL (Offset 0x04C6) */
#define BIT_TRI_PKT_INT_MODE1 BIT(2)
#define BIT_TRI_PKT_INT_MODE0 BIT(1)
#define BIT_ACQ_MODE_SEL BIT(0)
/* 2 REG_SINGLE_AMPDU_CTRL (Offset 0x04C7) */
#define BIT_EN_SINGLE_APMDU BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SINGLE_AMPDU_CTRL (Offset 0x04C7) */
#define BIT_SHIFT_SNDTX_MAXTIME 0
#define BIT_MASK_SNDTX_MAXTIME 0x7f
#define BIT_SNDTX_MAXTIME(x) \
(((x) & BIT_MASK_SNDTX_MAXTIME) << BIT_SHIFT_SNDTX_MAXTIME)
#define BITS_SNDTX_MAXTIME (BIT_MASK_SNDTX_MAXTIME << BIT_SHIFT_SNDTX_MAXTIME)
#define BIT_CLEAR_SNDTX_MAXTIME(x) ((x) & (~BITS_SNDTX_MAXTIME))
#define BIT_GET_SNDTX_MAXTIME(x) \
(((x) >> BIT_SHIFT_SNDTX_MAXTIME) & BIT_MASK_SNDTX_MAXTIME)
#define BIT_SET_SNDTX_MAXTIME(x, v) \
(BIT_CLEAR_SNDTX_MAXTIME(x) | BIT_SNDTX_MAXTIME(v))
/* 2 REG_PROT_MODE_CTRL (Offset 0x04C8) */
#define BIT_SND_SIFS_TXDATA BIT(31)
#define BIT_TX_SND_MATCH_MACID BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PROT_MODE_CTRL (Offset 0x04C8) */
#define BIT_SHIFT_RTS_MAX_AGG_NUM 24
#define BIT_MASK_RTS_MAX_AGG_NUM 0x3f
#define BIT_RTS_MAX_AGG_NUM(x) \
(((x) & BIT_MASK_RTS_MAX_AGG_NUM) << BIT_SHIFT_RTS_MAX_AGG_NUM)
#define BITS_RTS_MAX_AGG_NUM \
(BIT_MASK_RTS_MAX_AGG_NUM << BIT_SHIFT_RTS_MAX_AGG_NUM)
#define BIT_CLEAR_RTS_MAX_AGG_NUM(x) ((x) & (~BITS_RTS_MAX_AGG_NUM))
#define BIT_GET_RTS_MAX_AGG_NUM(x) \
(((x) >> BIT_SHIFT_RTS_MAX_AGG_NUM) & BIT_MASK_RTS_MAX_AGG_NUM)
#define BIT_SET_RTS_MAX_AGG_NUM(x, v) \
(BIT_CLEAR_RTS_MAX_AGG_NUM(x) | BIT_RTS_MAX_AGG_NUM(v))
#define BIT_SHIFT_MAX_AGG_NUM 16
#define BIT_MASK_MAX_AGG_NUM 0x3f
#define BIT_MAX_AGG_NUM(x) \
(((x) & BIT_MASK_MAX_AGG_NUM) << BIT_SHIFT_MAX_AGG_NUM)
#define BITS_MAX_AGG_NUM (BIT_MASK_MAX_AGG_NUM << BIT_SHIFT_MAX_AGG_NUM)
#define BIT_CLEAR_MAX_AGG_NUM(x) ((x) & (~BITS_MAX_AGG_NUM))
#define BIT_GET_MAX_AGG_NUM(x) \
(((x) >> BIT_SHIFT_MAX_AGG_NUM) & BIT_MASK_MAX_AGG_NUM)
#define BIT_SET_MAX_AGG_NUM(x, v) \
(BIT_CLEAR_MAX_AGG_NUM(x) | BIT_MAX_AGG_NUM(v))
#define BIT_SHIFT_RTS_TXTIME_TH 8
#define BIT_MASK_RTS_TXTIME_TH 0xff
#define BIT_RTS_TXTIME_TH(x) \
(((x) & BIT_MASK_RTS_TXTIME_TH) << BIT_SHIFT_RTS_TXTIME_TH)
#define BITS_RTS_TXTIME_TH (BIT_MASK_RTS_TXTIME_TH << BIT_SHIFT_RTS_TXTIME_TH)
#define BIT_CLEAR_RTS_TXTIME_TH(x) ((x) & (~BITS_RTS_TXTIME_TH))
#define BIT_GET_RTS_TXTIME_TH(x) \
(((x) >> BIT_SHIFT_RTS_TXTIME_TH) & BIT_MASK_RTS_TXTIME_TH)
#define BIT_SET_RTS_TXTIME_TH(x, v) \
(BIT_CLEAR_RTS_TXTIME_TH(x) | BIT_RTS_TXTIME_TH(v))
#define BIT_SHIFT_RTS_LEN_TH 0
#define BIT_MASK_RTS_LEN_TH 0xff
#define BIT_RTS_LEN_TH(x) (((x) & BIT_MASK_RTS_LEN_TH) << BIT_SHIFT_RTS_LEN_TH)
#define BITS_RTS_LEN_TH (BIT_MASK_RTS_LEN_TH << BIT_SHIFT_RTS_LEN_TH)
#define BIT_CLEAR_RTS_LEN_TH(x) ((x) & (~BITS_RTS_LEN_TH))
#define BIT_GET_RTS_LEN_TH(x) \
(((x) >> BIT_SHIFT_RTS_LEN_TH) & BIT_MASK_RTS_LEN_TH)
#define BIT_SET_RTS_LEN_TH(x, v) (BIT_CLEAR_RTS_LEN_TH(x) | BIT_RTS_LEN_TH(v))
/* 2 REG_BAR_MODE_CTRL (Offset 0x04CC) */
#define BIT_SHIFT_BAR_RTY_LMT 16
#define BIT_MASK_BAR_RTY_LMT 0x3
#define BIT_BAR_RTY_LMT(x) \
(((x) & BIT_MASK_BAR_RTY_LMT) << BIT_SHIFT_BAR_RTY_LMT)
#define BITS_BAR_RTY_LMT (BIT_MASK_BAR_RTY_LMT << BIT_SHIFT_BAR_RTY_LMT)
#define BIT_CLEAR_BAR_RTY_LMT(x) ((x) & (~BITS_BAR_RTY_LMT))
#define BIT_GET_BAR_RTY_LMT(x) \
(((x) >> BIT_SHIFT_BAR_RTY_LMT) & BIT_MASK_BAR_RTY_LMT)
#define BIT_SET_BAR_RTY_LMT(x, v) \
(BIT_CLEAR_BAR_RTY_LMT(x) | BIT_BAR_RTY_LMT(v))
#define BIT_SHIFT_BAR_PKT_TXTIME_TH 8
#define BIT_MASK_BAR_PKT_TXTIME_TH 0xff
#define BIT_BAR_PKT_TXTIME_TH(x) \
(((x) & BIT_MASK_BAR_PKT_TXTIME_TH) << BIT_SHIFT_BAR_PKT_TXTIME_TH)
#define BITS_BAR_PKT_TXTIME_TH \
(BIT_MASK_BAR_PKT_TXTIME_TH << BIT_SHIFT_BAR_PKT_TXTIME_TH)
#define BIT_CLEAR_BAR_PKT_TXTIME_TH(x) ((x) & (~BITS_BAR_PKT_TXTIME_TH))
#define BIT_GET_BAR_PKT_TXTIME_TH(x) \
(((x) >> BIT_SHIFT_BAR_PKT_TXTIME_TH) & BIT_MASK_BAR_PKT_TXTIME_TH)
#define BIT_SET_BAR_PKT_TXTIME_TH(x, v) \
(BIT_CLEAR_BAR_PKT_TXTIME_TH(x) | BIT_BAR_PKT_TXTIME_TH(v))
#define BIT_BAR_EN_V1 BIT(6)
#define BIT_SHIFT_BAR_PKTNUM_TH_V1 0
#define BIT_MASK_BAR_PKTNUM_TH_V1 0x3f
#define BIT_BAR_PKTNUM_TH_V1(x) \
(((x) & BIT_MASK_BAR_PKTNUM_TH_V1) << BIT_SHIFT_BAR_PKTNUM_TH_V1)
#define BITS_BAR_PKTNUM_TH_V1 \
(BIT_MASK_BAR_PKTNUM_TH_V1 << BIT_SHIFT_BAR_PKTNUM_TH_V1)
#define BIT_CLEAR_BAR_PKTNUM_TH_V1(x) ((x) & (~BITS_BAR_PKTNUM_TH_V1))
#define BIT_GET_BAR_PKTNUM_TH_V1(x) \
(((x) >> BIT_SHIFT_BAR_PKTNUM_TH_V1) & BIT_MASK_BAR_PKTNUM_TH_V1)
#define BIT_SET_BAR_PKTNUM_TH_V1(x, v) \
(BIT_CLEAR_BAR_PKTNUM_TH_V1(x) | BIT_BAR_PKTNUM_TH_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RA_TRY_RATE_AGG_LMT (Offset 0x04CF) */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT_V1 0x3f
#define BIT_RA_TRY_RATE_AGG_LMT_V1(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT_V1) \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1)
#define BITS_RA_TRY_RATE_AGG_LMT_V1 \
(BIT_MASK_RA_TRY_RATE_AGG_LMT_V1 << BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1(x) \
((x) & (~BITS_RA_TRY_RATE_AGG_LMT_V1))
#define BIT_GET_RA_TRY_RATE_AGG_LMT_V1(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1) & \
BIT_MASK_RA_TRY_RATE_AGG_LMT_V1)
#define BIT_SET_RA_TRY_RATE_AGG_LMT_V1(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1(x) | BIT_RA_TRY_RATE_AGG_LMT_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_SLEEP_CTRL (Offset 0x04D0) */
#define BIT_SHIFT_DEBUG_PROTOCOL 24
#define BIT_MASK_DEBUG_PROTOCOL 0xff
#define BIT_DEBUG_PROTOCOL(x) \
(((x) & BIT_MASK_DEBUG_PROTOCOL) << BIT_SHIFT_DEBUG_PROTOCOL)
#define BITS_DEBUG_PROTOCOL \
(BIT_MASK_DEBUG_PROTOCOL << BIT_SHIFT_DEBUG_PROTOCOL)
#define BIT_CLEAR_DEBUG_PROTOCOL(x) ((x) & (~BITS_DEBUG_PROTOCOL))
#define BIT_GET_DEBUG_PROTOCOL(x) \
(((x) >> BIT_SHIFT_DEBUG_PROTOCOL) & BIT_MASK_DEBUG_PROTOCOL)
#define BIT_SET_DEBUG_PROTOCOL(x, v) \
(BIT_CLEAR_DEBUG_PROTOCOL(x) | BIT_DEBUG_PROTOCOL(v))
#define BIT_SHIFT_BCNQ_PGBNDY_RSEL 16
#define BIT_MASK_BCNQ_PGBNDY_RSEL 0x7
#define BIT_BCNQ_PGBNDY_RSEL(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_RSEL) << BIT_SHIFT_BCNQ_PGBNDY_RSEL)
#define BITS_BCNQ_PGBNDY_RSEL \
(BIT_MASK_BCNQ_PGBNDY_RSEL << BIT_SHIFT_BCNQ_PGBNDY_RSEL)
#define BIT_CLEAR_BCNQ_PGBNDY_RSEL(x) ((x) & (~BITS_BCNQ_PGBNDY_RSEL))
#define BIT_GET_BCNQ_PGBNDY_RSEL(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_RSEL) & BIT_MASK_BCNQ_PGBNDY_RSEL)
#define BIT_SET_BCNQ_PGBNDY_RSEL(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_RSEL(x) | BIT_BCNQ_PGBNDY_RSEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MACID_SLEEP2 (Offset 0x04D0) */
#define BIT_SHIFT_MACID95_64PKTSLEEP 0
#define BIT_MASK_MACID95_64PKTSLEEP 0xffffffffL
#define BIT_MACID95_64PKTSLEEP(x) \
(((x) & BIT_MASK_MACID95_64PKTSLEEP) << BIT_SHIFT_MACID95_64PKTSLEEP)
#define BITS_MACID95_64PKTSLEEP \
(BIT_MASK_MACID95_64PKTSLEEP << BIT_SHIFT_MACID95_64PKTSLEEP)
#define BIT_CLEAR_MACID95_64PKTSLEEP(x) ((x) & (~BITS_MACID95_64PKTSLEEP))
#define BIT_GET_MACID95_64PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID95_64PKTSLEEP) & BIT_MASK_MACID95_64PKTSLEEP)
#define BIT_SET_MACID95_64PKTSLEEP(x, v) \
(BIT_CLEAR_MACID95_64PKTSLEEP(x) | BIT_MACID95_64PKTSLEEP(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_SLEEP_CTRL (Offset 0x04D0) */
#define BIT_SHIFT_MACID_SLEEP_SEL 0
#define BIT_MASK_MACID_SLEEP_SEL 0x7
#define BIT_MACID_SLEEP_SEL(x) \
(((x) & BIT_MASK_MACID_SLEEP_SEL) << BIT_SHIFT_MACID_SLEEP_SEL)
#define BITS_MACID_SLEEP_SEL \
(BIT_MASK_MACID_SLEEP_SEL << BIT_SHIFT_MACID_SLEEP_SEL)
#define BIT_CLEAR_MACID_SLEEP_SEL(x) ((x) & (~BITS_MACID_SLEEP_SEL))
#define BIT_GET_MACID_SLEEP_SEL(x) \
(((x) >> BIT_SHIFT_MACID_SLEEP_SEL) & BIT_MASK_MACID_SLEEP_SEL)
#define BIT_SET_MACID_SLEEP_SEL(x, v) \
(BIT_CLEAR_MACID_SLEEP_SEL(x) | BIT_MACID_SLEEP_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MACID_SLEEP (Offset 0x04D4) */
#define BIT_SHIFT_MACID31_0_PKTSLEEP 0
#define BIT_MASK_MACID31_0_PKTSLEEP 0xffffffffL
#define BIT_MACID31_0_PKTSLEEP(x) \
(((x) & BIT_MASK_MACID31_0_PKTSLEEP) << BIT_SHIFT_MACID31_0_PKTSLEEP)
#define BITS_MACID31_0_PKTSLEEP \
(BIT_MASK_MACID31_0_PKTSLEEP << BIT_SHIFT_MACID31_0_PKTSLEEP)
#define BIT_CLEAR_MACID31_0_PKTSLEEP(x) ((x) & (~BITS_MACID31_0_PKTSLEEP))
#define BIT_GET_MACID31_0_PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID31_0_PKTSLEEP) & BIT_MASK_MACID31_0_PKTSLEEP)
#define BIT_SET_MACID31_0_PKTSLEEP(x, v) \
(BIT_CLEAR_MACID31_0_PKTSLEEP(x) | BIT_MACID31_0_PKTSLEEP(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MACID_SLEEP (Offset 0x04D4) */
#define BIT_SHIFT_MACID31_0PKTSLEEP 0
#define BIT_MASK_MACID31_0PKTSLEEP 0xffffffffL
#define BIT_MACID31_0PKTSLEEP(x) \
(((x) & BIT_MASK_MACID31_0PKTSLEEP) << BIT_SHIFT_MACID31_0PKTSLEEP)
#define BITS_MACID31_0PKTSLEEP \
(BIT_MASK_MACID31_0PKTSLEEP << BIT_SHIFT_MACID31_0PKTSLEEP)
#define BIT_CLEAR_MACID31_0PKTSLEEP(x) ((x) & (~BITS_MACID31_0PKTSLEEP))
#define BIT_GET_MACID31_0PKTSLEEP(x) \
(((x) >> BIT_SHIFT_MACID31_0PKTSLEEP) & BIT_MASK_MACID31_0PKTSLEEP)
#define BIT_SET_MACID31_0PKTSLEEP(x, v) \
(BIT_CLEAR_MACID31_0PKTSLEEP(x) | BIT_MACID31_0PKTSLEEP(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_SLEEP_INFO (Offset 0x04D4) */
#define BIT_SHIFT_MACID_SLEEP_INFO 0
#define BIT_MASK_MACID_SLEEP_INFO 0xffffffffL
#define BIT_MACID_SLEEP_INFO(x) \
(((x) & BIT_MASK_MACID_SLEEP_INFO) << BIT_SHIFT_MACID_SLEEP_INFO)
#define BITS_MACID_SLEEP_INFO \
(BIT_MASK_MACID_SLEEP_INFO << BIT_SHIFT_MACID_SLEEP_INFO)
#define BIT_CLEAR_MACID_SLEEP_INFO(x) ((x) & (~BITS_MACID_SLEEP_INFO))
#define BIT_GET_MACID_SLEEP_INFO(x) \
(((x) >> BIT_SHIFT_MACID_SLEEP_INFO) & BIT_MASK_MACID_SLEEP_INFO)
#define BIT_SET_MACID_SLEEP_INFO(x, v) \
(BIT_CLEAR_MACID_SLEEP_INFO(x) | BIT_MACID_SLEEP_INFO(v))
#define BIT_SHIFT_PTCL_TOTAL_PG_V3 0
#define BIT_MASK_PTCL_TOTAL_PG_V3 0x1fff
#define BIT_PTCL_TOTAL_PG_V3(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V3) << BIT_SHIFT_PTCL_TOTAL_PG_V3)
#define BITS_PTCL_TOTAL_PG_V3 \
(BIT_MASK_PTCL_TOTAL_PG_V3 << BIT_SHIFT_PTCL_TOTAL_PG_V3)
#define BIT_CLEAR_PTCL_TOTAL_PG_V3(x) ((x) & (~BITS_PTCL_TOTAL_PG_V3))
#define BIT_GET_PTCL_TOTAL_PG_V3(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V3) & BIT_MASK_PTCL_TOTAL_PG_V3)
#define BIT_SET_PTCL_TOTAL_PG_V3(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V3(x) | BIT_PTCL_TOTAL_PG_V3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HW_SEQ0 (Offset 0x04D8) */
#define BIT_SHIFT_HW_SSN_SEQ0 0
#define BIT_MASK_HW_SSN_SEQ0 0xfff
#define BIT_HW_SSN_SEQ0(x) \
(((x) & BIT_MASK_HW_SSN_SEQ0) << BIT_SHIFT_HW_SSN_SEQ0)
#define BITS_HW_SSN_SEQ0 (BIT_MASK_HW_SSN_SEQ0 << BIT_SHIFT_HW_SSN_SEQ0)
#define BIT_CLEAR_HW_SSN_SEQ0(x) ((x) & (~BITS_HW_SSN_SEQ0))
#define BIT_GET_HW_SSN_SEQ0(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ0) & BIT_MASK_HW_SSN_SEQ0)
#define BIT_SET_HW_SSN_SEQ0(x, v) \
(BIT_CLEAR_HW_SSN_SEQ0(x) | BIT_HW_SSN_SEQ0(v))
/* 2 REG_HW_SEQ1 (Offset 0x04DA) */
#define BIT_SHIFT_HW_SSN_SEQ1 0
#define BIT_MASK_HW_SSN_SEQ1 0xfff
#define BIT_HW_SSN_SEQ1(x) \
(((x) & BIT_MASK_HW_SSN_SEQ1) << BIT_SHIFT_HW_SSN_SEQ1)
#define BITS_HW_SSN_SEQ1 (BIT_MASK_HW_SSN_SEQ1 << BIT_SHIFT_HW_SSN_SEQ1)
#define BIT_CLEAR_HW_SSN_SEQ1(x) ((x) & (~BITS_HW_SSN_SEQ1))
#define BIT_GET_HW_SSN_SEQ1(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ1) & BIT_MASK_HW_SSN_SEQ1)
#define BIT_SET_HW_SSN_SEQ1(x, v) \
(BIT_CLEAR_HW_SSN_SEQ1(x) | BIT_HW_SSN_SEQ1(v))
/* 2 REG_HW_SEQ2 (Offset 0x04DC) */
#define BIT_SHIFT_HW_SSN_SEQ2 0
#define BIT_MASK_HW_SSN_SEQ2 0xfff
#define BIT_HW_SSN_SEQ2(x) \
(((x) & BIT_MASK_HW_SSN_SEQ2) << BIT_SHIFT_HW_SSN_SEQ2)
#define BITS_HW_SSN_SEQ2 (BIT_MASK_HW_SSN_SEQ2 << BIT_SHIFT_HW_SSN_SEQ2)
#define BIT_CLEAR_HW_SSN_SEQ2(x) ((x) & (~BITS_HW_SSN_SEQ2))
#define BIT_GET_HW_SSN_SEQ2(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ2) & BIT_MASK_HW_SSN_SEQ2)
#define BIT_SET_HW_SSN_SEQ2(x, v) \
(BIT_CLEAR_HW_SSN_SEQ2(x) | BIT_HW_SSN_SEQ2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_HW_SEQ3 (Offset 0x04DE) */
#define BIT_SHIFT_CSI_HWSSN_SEL 12
#define BIT_MASK_CSI_HWSSN_SEL 0x3
#define BIT_CSI_HWSSN_SEL(x) \
(((x) & BIT_MASK_CSI_HWSSN_SEL) << BIT_SHIFT_CSI_HWSSN_SEL)
#define BITS_CSI_HWSSN_SEL (BIT_MASK_CSI_HWSSN_SEL << BIT_SHIFT_CSI_HWSSN_SEL)
#define BIT_CLEAR_CSI_HWSSN_SEL(x) ((x) & (~BITS_CSI_HWSSN_SEL))
#define BIT_GET_CSI_HWSSN_SEL(x) \
(((x) >> BIT_SHIFT_CSI_HWSSN_SEL) & BIT_MASK_CSI_HWSSN_SEL)
#define BIT_SET_CSI_HWSSN_SEL(x, v) \
(BIT_CLEAR_CSI_HWSSN_SEL(x) | BIT_CSI_HWSSN_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HW_SEQ3 (Offset 0x04DE) */
#define BIT_SHIFT_CSI_HWSEQ_SEL 12
#define BIT_MASK_CSI_HWSEQ_SEL 0x3
#define BIT_CSI_HWSEQ_SEL(x) \
(((x) & BIT_MASK_CSI_HWSEQ_SEL) << BIT_SHIFT_CSI_HWSEQ_SEL)
#define BITS_CSI_HWSEQ_SEL (BIT_MASK_CSI_HWSEQ_SEL << BIT_SHIFT_CSI_HWSEQ_SEL)
#define BIT_CLEAR_CSI_HWSEQ_SEL(x) ((x) & (~BITS_CSI_HWSEQ_SEL))
#define BIT_GET_CSI_HWSEQ_SEL(x) \
(((x) >> BIT_SHIFT_CSI_HWSEQ_SEL) & BIT_MASK_CSI_HWSEQ_SEL)
#define BIT_SET_CSI_HWSEQ_SEL(x, v) \
(BIT_CLEAR_CSI_HWSEQ_SEL(x) | BIT_CSI_HWSEQ_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HW_SEQ3 (Offset 0x04DE) */
#define BIT_SHIFT_HW_SSN_SEQ3 0
#define BIT_MASK_HW_SSN_SEQ3 0xfff
#define BIT_HW_SSN_SEQ3(x) \
(((x) & BIT_MASK_HW_SSN_SEQ3) << BIT_SHIFT_HW_SSN_SEQ3)
#define BITS_HW_SSN_SEQ3 (BIT_MASK_HW_SSN_SEQ3 << BIT_SHIFT_HW_SSN_SEQ3)
#define BIT_CLEAR_HW_SSN_SEQ3(x) ((x) & (~BITS_HW_SSN_SEQ3))
#define BIT_GET_HW_SSN_SEQ3(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ3) & BIT_MASK_HW_SSN_SEQ3)
#define BIT_SET_HW_SSN_SEQ3(x, v) \
(BIT_CLEAR_HW_SSN_SEQ3(x) | BIT_HW_SSN_SEQ3(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_CSI_SEQ (Offset 0x04DE) */
#define BIT_SHIFT_HW_CSI_SEQ 0
#define BIT_MASK_HW_CSI_SEQ 0xfff
#define BIT_HW_CSI_SEQ(x) (((x) & BIT_MASK_HW_CSI_SEQ) << BIT_SHIFT_HW_CSI_SEQ)
#define BITS_HW_CSI_SEQ (BIT_MASK_HW_CSI_SEQ << BIT_SHIFT_HW_CSI_SEQ)
#define BIT_CLEAR_HW_CSI_SEQ(x) ((x) & (~BITS_HW_CSI_SEQ))
#define BIT_GET_HW_CSI_SEQ(x) \
(((x) >> BIT_SHIFT_HW_CSI_SEQ) & BIT_MASK_HW_CSI_SEQ)
#define BIT_SET_HW_CSI_SEQ(x, v) (BIT_CLEAR_HW_CSI_SEQ(x) | BIT_HW_CSI_SEQ(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V1 (Offset 0x04E0) */
#define BIT_SHIFT_PTCL_TOTAL_PG_V1 2
#define BIT_MASK_PTCL_TOTAL_PG_V1 0x1fff
#define BIT_PTCL_TOTAL_PG_V1(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V1) << BIT_SHIFT_PTCL_TOTAL_PG_V1)
#define BITS_PTCL_TOTAL_PG_V1 \
(BIT_MASK_PTCL_TOTAL_PG_V1 << BIT_SHIFT_PTCL_TOTAL_PG_V1)
#define BIT_CLEAR_PTCL_TOTAL_PG_V1(x) ((x) & (~BITS_PTCL_TOTAL_PG_V1))
#define BIT_GET_PTCL_TOTAL_PG_V1(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V1) & BIT_MASK_PTCL_TOTAL_PG_V1)
#define BIT_SET_PTCL_TOTAL_PG_V1(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V1(x) | BIT_PTCL_TOTAL_PG_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V1 (Offset 0x04E0) */
#define BIT_SHIFT_PTCL_TOTAL_PG_V5 2
#define BIT_MASK_PTCL_TOTAL_PG_V5 0x1fff
#define BIT_PTCL_TOTAL_PG_V5(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V5) << BIT_SHIFT_PTCL_TOTAL_PG_V5)
#define BITS_PTCL_TOTAL_PG_V5 \
(BIT_MASK_PTCL_TOTAL_PG_V5 << BIT_SHIFT_PTCL_TOTAL_PG_V5)
#define BIT_CLEAR_PTCL_TOTAL_PG_V5(x) ((x) & (~BITS_PTCL_TOTAL_PG_V5))
#define BIT_GET_PTCL_TOTAL_PG_V5(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V5) & BIT_MASK_PTCL_TOTAL_PG_V5)
#define BIT_SET_PTCL_TOTAL_PG_V5(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V5(x) | BIT_PTCL_TOTAL_PG_V5(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V1 (Offset 0x04E0) */
#define BIT_SHIFT_PTCL_TOTAL_PG_V2 2
#define BIT_MASK_PTCL_TOTAL_PG_V2 0x3fff
#define BIT_PTCL_TOTAL_PG_V2(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V2) << BIT_SHIFT_PTCL_TOTAL_PG_V2)
#define BITS_PTCL_TOTAL_PG_V2 \
(BIT_MASK_PTCL_TOTAL_PG_V2 << BIT_SHIFT_PTCL_TOTAL_PG_V2)
#define BIT_CLEAR_PTCL_TOTAL_PG_V2(x) ((x) & (~BITS_PTCL_TOTAL_PG_V2))
#define BIT_GET_PTCL_TOTAL_PG_V2(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V2) & BIT_MASK_PTCL_TOTAL_PG_V2)
#define BIT_SET_PTCL_TOTAL_PG_V2(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V2(x) | BIT_PTCL_TOTAL_PG_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_NULL_PKT_STATUS (Offset 0x04E0) */
#define BIT_TX_NULL_1 BIT(1)
#define BIT_TX_NULL_0 BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_MUARB_SEARCH_ERR BIT(14)
#define BIT_MU_BFEN_ERR BIT(12)
#define BIT_NDPA_DROPNULL_ERR BIT(11)
#define BIT_NDPA_DROPPKT_ERR BIT(10)
#define BIT_PTCL_PKYIN_ERR BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_SHIFT_PTCL_TOTAL_PG_V4 8
#define BIT_MASK_PTCL_TOTAL_PG_V4 0xff
#define BIT_PTCL_TOTAL_PG_V4(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V4) << BIT_SHIFT_PTCL_TOTAL_PG_V4)
#define BITS_PTCL_TOTAL_PG_V4 \
(BIT_MASK_PTCL_TOTAL_PG_V4 << BIT_SHIFT_PTCL_TOTAL_PG_V4)
#define BIT_CLEAR_PTCL_TOTAL_PG_V4(x) ((x) & (~BITS_PTCL_TOTAL_PG_V4))
#define BIT_GET_PTCL_TOTAL_PG_V4(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V4) & BIT_MASK_PTCL_TOTAL_PG_V4)
#define BIT_SET_PTCL_TOTAL_PG_V4(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V4(x) | BIT_PTCL_TOTAL_PG_V4(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_PTCL_QSELCNL_ERR BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_PTCL_TOTAL_PG_8 BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_PTCL_RATE_TABLE_INVALID BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_P2P_OFF_DISTX_EN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_PTCL_RATE_TABLE_INVALID_V1 BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_FTM_T2R_ERROR BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_PTCL_ERR0 BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_TXTIMEOUT_ERR BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_PTCL_ERR1 BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_NULLPAGE_ERR BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_PTCL_ERR2 BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_CONTENTION_ERR BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_PTCL_ERR3 BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_HEADNULL_ERR BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_PTCL_ERR4 BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_OVERFLOW_ERR BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS (Offset 0x04E2) */
#define BIT_PTCL_ERR5 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_ERR_STATUS_V1 (Offset 0x04E2) */
#define BIT_QUEUE_INDEX_ERR BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_EXTEND (Offset 0x04E3) */
#define BIT_CLI3_TX_NULL_1 BIT(7)
#define BIT_CLI3_TX_NULL_0 BIT(6)
#define BIT_CLI2_TX_NULL_1 BIT(5)
#define BIT_CLI2_TX_NULL_0 BIT(4)
#define BIT_CLI1_TX_NULL_1 BIT(3)
#define BIT_CLI1_TX_NULL_0 BIT(2)
#define BIT_CLI0_TX_NULL_1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_PKT_NUM (Offset 0x04E3) */
#define BIT_SHIFT_PTCL_TOTAL_PG 0
#define BIT_MASK_PTCL_TOTAL_PG 0xff
#define BIT_PTCL_TOTAL_PG(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG) << BIT_SHIFT_PTCL_TOTAL_PG)
#define BITS_PTCL_TOTAL_PG (BIT_MASK_PTCL_TOTAL_PG << BIT_SHIFT_PTCL_TOTAL_PG)
#define BIT_CLEAR_PTCL_TOTAL_PG(x) ((x) & (~BITS_PTCL_TOTAL_PG))
#define BIT_GET_PTCL_TOTAL_PG(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG) & BIT_MASK_PTCL_TOTAL_PG)
#define BIT_SET_PTCL_TOTAL_PG(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG(x) | BIT_PTCL_TOTAL_PG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_EXTEND (Offset 0x04E3) */
#define BIT_CLI0_TX_NULL_0 BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_TRXRPT_MISS_CNT (Offset 0x04E3) */
#define BIT_SHIFT_TRXRPT_MISS_CNT 0
#define BIT_MASK_TRXRPT_MISS_CNT 0x7
#define BIT_TRXRPT_MISS_CNT(x) \
(((x) & BIT_MASK_TRXRPT_MISS_CNT) << BIT_SHIFT_TRXRPT_MISS_CNT)
#define BITS_TRXRPT_MISS_CNT \
(BIT_MASK_TRXRPT_MISS_CNT << BIT_SHIFT_TRXRPT_MISS_CNT)
#define BIT_CLEAR_TRXRPT_MISS_CNT(x) ((x) & (~BITS_TRXRPT_MISS_CNT))
#define BIT_GET_TRXRPT_MISS_CNT(x) \
(((x) >> BIT_SHIFT_TRXRPT_MISS_CNT) & BIT_MASK_TRXRPT_MISS_CNT)
#define BIT_SET_TRXRPT_MISS_CNT(x, v) \
(BIT_CLEAR_TRXRPT_MISS_CNT(x) | BIT_TRXRPT_MISS_CNT(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_VIDEO_ENHANCEMENT_FUN (Offset 0x04E4) */
#define BIT_MAX_PRETX_AGGR_EN BIT(19)
#define BIT_SHIFT_MAX_PRETX_AGGR_TIME 8
#define BIT_MASK_MAX_PRETX_AGGR_TIME 0x7ff
#define BIT_MAX_PRETX_AGGR_TIME(x) \
(((x) & BIT_MASK_MAX_PRETX_AGGR_TIME) << BIT_SHIFT_MAX_PRETX_AGGR_TIME)
#define BITS_MAX_PRETX_AGGR_TIME \
(BIT_MASK_MAX_PRETX_AGGR_TIME << BIT_SHIFT_MAX_PRETX_AGGR_TIME)
#define BIT_CLEAR_MAX_PRETX_AGGR_TIME(x) ((x) & (~BITS_MAX_PRETX_AGGR_TIME))
#define BIT_GET_MAX_PRETX_AGGR_TIME(x) \
(((x) >> BIT_SHIFT_MAX_PRETX_AGGR_TIME) & BIT_MASK_MAX_PRETX_AGGR_TIME)
#define BIT_SET_MAX_PRETX_AGGR_TIME(x, v) \
(BIT_CLEAR_MAX_PRETX_AGGR_TIME(x) | BIT_MAX_PRETX_AGGR_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V2 (Offset 0x04E4) */
#define BIT_HIQ_DROP BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_VIDEO_ENHANCEMENT_FUN (Offset 0x04E4) */
#define BIT_HGQ_DEL_EN BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V2 (Offset 0x04E4) */
#define BIT_MGQ_DROP BIT(6)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_VIDEO_ENHANCEMENT_FUN (Offset 0x04E4) */
#define BIT_MGQ_DEL_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_VIDEO_ENHANCEMENT_FUN (Offset 0x04E4) */
#define BIT_VIDEO_JUST_DROP BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V2 (Offset 0x04E4) */
#define BIT_TX_NULL_1_V1 BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_VIDEO_ENHANCEMENT_FUN (Offset 0x04E4) */
#define BIT_VIDEO_ENHANCEMENT_FUN_EN BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_VIDEO_ENHANCEMENT_FUN (Offset 0x04E4) */
#define BIT_SHIFT_MEDIUM_HAS_IDLE_TRIGGER 0
#define BIT_MASK_MEDIUM_HAS_IDLE_TRIGGER 0xff
#define BIT_MEDIUM_HAS_IDLE_TRIGGER(x) \
(((x) & BIT_MASK_MEDIUM_HAS_IDLE_TRIGGER) \
<< BIT_SHIFT_MEDIUM_HAS_IDLE_TRIGGER)
#define BITS_MEDIUM_HAS_IDLE_TRIGGER \
(BIT_MASK_MEDIUM_HAS_IDLE_TRIGGER << BIT_SHIFT_MEDIUM_HAS_IDLE_TRIGGER)
#define BIT_CLEAR_MEDIUM_HAS_IDLE_TRIGGER(x) \
((x) & (~BITS_MEDIUM_HAS_IDLE_TRIGGER))
#define BIT_GET_MEDIUM_HAS_IDLE_TRIGGER(x) \
(((x) >> BIT_SHIFT_MEDIUM_HAS_IDLE_TRIGGER) & \
BIT_MASK_MEDIUM_HAS_IDLE_TRIGGER)
#define BIT_SET_MEDIUM_HAS_IDLE_TRIGGER(x, v) \
(BIT_CLEAR_MEDIUM_HAS_IDLE_TRIGGER(x) | BIT_MEDIUM_HAS_IDLE_TRIGGER(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_V2 (Offset 0x04E4) */
#define BIT_TX_NULL_0_V1 BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT)
/* 2 REG_PRECNT_CTRL (Offset 0x04E5) */
#define BIT_SHIFT_COLLISION_DETECT_TIME 12
#define BIT_MASK_COLLISION_DETECT_TIME 0xf
#define BIT_COLLISION_DETECT_TIME(x) \
(((x) & BIT_MASK_COLLISION_DETECT_TIME) \
<< BIT_SHIFT_COLLISION_DETECT_TIME)
#define BITS_COLLISION_DETECT_TIME \
(BIT_MASK_COLLISION_DETECT_TIME << BIT_SHIFT_COLLISION_DETECT_TIME)
#define BIT_CLEAR_COLLISION_DETECT_TIME(x) ((x) & (~BITS_COLLISION_DETECT_TIME))
#define BIT_GET_COLLISION_DETECT_TIME(x) \
(((x) >> BIT_SHIFT_COLLISION_DETECT_TIME) & \
BIT_MASK_COLLISION_DETECT_TIME)
#define BIT_SET_COLLISION_DETECT_TIME(x, v) \
(BIT_CLEAR_COLLISION_DETECT_TIME(x) | BIT_COLLISION_DETECT_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PRECNT_CTRL (Offset 0x04E5) */
#define BIT_EN_PRECNT BIT(11)
#define BIT_SHIFT_PRECNT_TH 0
#define BIT_MASK_PRECNT_TH 0x7ff
#define BIT_PRECNT_TH(x) (((x) & BIT_MASK_PRECNT_TH) << BIT_SHIFT_PRECNT_TH)
#define BITS_PRECNT_TH (BIT_MASK_PRECNT_TH << BIT_SHIFT_PRECNT_TH)
#define BIT_CLEAR_PRECNT_TH(x) ((x) & (~BITS_PRECNT_TH))
#define BIT_GET_PRECNT_TH(x) (((x) >> BIT_SHIFT_PRECNT_TH) & BIT_MASK_PRECNT_TH)
#define BIT_SET_PRECNT_TH(x, v) (BIT_CLEAR_PRECNT_TH(x) | BIT_PRECNT_TH(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_NULL_PKT_STATUS_EXTEND_V1 (Offset 0x04E7) */
#define BIT_CLI3_TX_NULL_1_V1 BIT(7)
#define BIT_CLI3_TX_NULL_0_V1 BIT(6)
#define BIT_CLI2_TX_NULL_1_V1 BIT(5)
#define BIT_CLI2_TX_NULL_0_V1 BIT(4)
#define BIT_CLI1_TX_NULL_1_V1 BIT(3)
#define BIT_CLI1_TX_NULL_0_V1 BIT(2)
#define BIT_CLI0_TX_NULL_1_V1 BIT(1)
#define BIT_CLI0_TX_NULL_0_V1 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_POLLUTE_PKT_CNT (Offset 0x04E8) */
#define BIT_SHIFT_BT_POLLUTE_PKT_CNT 0
#define BIT_MASK_BT_POLLUTE_PKT_CNT 0xffff
#define BIT_BT_POLLUTE_PKT_CNT(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKT_CNT) << BIT_SHIFT_BT_POLLUTE_PKT_CNT)
#define BITS_BT_POLLUTE_PKT_CNT \
(BIT_MASK_BT_POLLUTE_PKT_CNT << BIT_SHIFT_BT_POLLUTE_PKT_CNT)
#define BIT_CLEAR_BT_POLLUTE_PKT_CNT(x) ((x) & (~BITS_BT_POLLUTE_PKT_CNT))
#define BIT_GET_BT_POLLUTE_PKT_CNT(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKT_CNT) & BIT_MASK_BT_POLLUTE_PKT_CNT)
#define BIT_SET_BT_POLLUTE_PKT_CNT(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKT_CNT(x) | BIT_BT_POLLUTE_PKT_CNT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DROP_NUM (Offset 0x04EC) */
#define BIT_SHIFT_DROP_PKT_NUM 0
#define BIT_MASK_DROP_PKT_NUM 0xffff
#define BIT_DROP_PKT_NUM(x) \
(((x) & BIT_MASK_DROP_PKT_NUM) << BIT_SHIFT_DROP_PKT_NUM)
#define BITS_DROP_PKT_NUM (BIT_MASK_DROP_PKT_NUM << BIT_SHIFT_DROP_PKT_NUM)
#define BIT_CLEAR_DROP_PKT_NUM(x) ((x) & (~BITS_DROP_PKT_NUM))
#define BIT_GET_DROP_PKT_NUM(x) \
(((x) >> BIT_SHIFT_DROP_PKT_NUM) & BIT_MASK_DROP_PKT_NUM)
#define BIT_SET_DROP_PKT_NUM(x, v) \
(BIT_CLEAR_DROP_PKT_NUM(x) | BIT_DROP_PKT_NUM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PTCL_DBG_V1 (Offset 0x04EC) */
#define BIT_SHIFT_PTCL_DBG 0
#define BIT_MASK_PTCL_DBG 0xffffffffL
#define BIT_PTCL_DBG(x) (((x) & BIT_MASK_PTCL_DBG) << BIT_SHIFT_PTCL_DBG)
#define BITS_PTCL_DBG (BIT_MASK_PTCL_DBG << BIT_SHIFT_PTCL_DBG)
#define BIT_CLEAR_PTCL_DBG(x) ((x) & (~BITS_PTCL_DBG))
#define BIT_GET_PTCL_DBG(x) (((x) >> BIT_SHIFT_PTCL_DBG) & BIT_MASK_PTCL_DBG)
#define BIT_SET_PTCL_DBG(x, v) (BIT_CLEAR_PTCL_DBG(x) | BIT_PTCL_DBG(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PTCL_TX_RPT (Offset 0x04F0) */
#define BIT_SHIFT_AC_TX_RPT_INFO 0
#define BIT_MASK_AC_TX_RPT_INFO 0xffffffffffffffffL
#define BIT_AC_TX_RPT_INFO(x) \
(((x) & BIT_MASK_AC_TX_RPT_INFO) << BIT_SHIFT_AC_TX_RPT_INFO)
#define BITS_AC_TX_RPT_INFO \
(BIT_MASK_AC_TX_RPT_INFO << BIT_SHIFT_AC_TX_RPT_INFO)
#define BIT_CLEAR_AC_TX_RPT_INFO(x) ((x) & (~BITS_AC_TX_RPT_INFO))
#define BIT_GET_AC_TX_RPT_INFO(x) \
(((x) >> BIT_SHIFT_AC_TX_RPT_INFO) & BIT_MASK_AC_TX_RPT_INFO)
#define BIT_SET_AC_TX_RPT_INFO(x, v) \
(BIT_CLEAR_AC_TX_RPT_INFO(x) | BIT_AC_TX_RPT_INFO(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TX_RPT_INFO_L32 (Offset 0x04F0) */
#define BIT_SHIFT_AC_TX_RPT_INFO_L32 0
#define BIT_MASK_AC_TX_RPT_INFO_L32 0xffffffffL
#define BIT_AC_TX_RPT_INFO_L32(x) \
(((x) & BIT_MASK_AC_TX_RPT_INFO_L32) << BIT_SHIFT_AC_TX_RPT_INFO_L32)
#define BITS_AC_TX_RPT_INFO_L32 \
(BIT_MASK_AC_TX_RPT_INFO_L32 << BIT_SHIFT_AC_TX_RPT_INFO_L32)
#define BIT_CLEAR_AC_TX_RPT_INFO_L32(x) ((x) & (~BITS_AC_TX_RPT_INFO_L32))
#define BIT_GET_AC_TX_RPT_INFO_L32(x) \
(((x) >> BIT_SHIFT_AC_TX_RPT_INFO_L32) & BIT_MASK_AC_TX_RPT_INFO_L32)
#define BIT_SET_AC_TX_RPT_INFO_L32(x, v) \
(BIT_CLEAR_AC_TX_RPT_INFO_L32(x) | BIT_AC_TX_RPT_INFO_L32(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TXOP_EXTRA_CTRL (Offset 0x04F0) */
#define BIT_TXOP_EFFICIENCY_EN BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BT_POLLUTE_PKTCNT (Offset 0x04F0) */
#define BIT_SHIFT_BT_POLLUTE_PKTCNT 0
#define BIT_MASK_BT_POLLUTE_PKTCNT 0xffff
#define BIT_BT_POLLUTE_PKTCNT(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKTCNT) << BIT_SHIFT_BT_POLLUTE_PKTCNT)
#define BITS_BT_POLLUTE_PKTCNT \
(BIT_MASK_BT_POLLUTE_PKTCNT << BIT_SHIFT_BT_POLLUTE_PKTCNT)
#define BIT_CLEAR_BT_POLLUTE_PKTCNT(x) ((x) & (~BITS_BT_POLLUTE_PKTCNT))
#define BIT_GET_BT_POLLUTE_PKTCNT(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKTCNT) & BIT_MASK_BT_POLLUTE_PKTCNT)
#define BIT_SET_BT_POLLUTE_PKTCNT(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKTCNT(x) | BIT_BT_POLLUTE_PKTCNT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPUMGQ_TIMER_CTRL2 (Offset 0x04F4) */
#define BIT_SHIFT_TRI_HEAD_ADDR 16
#define BIT_MASK_TRI_HEAD_ADDR 0xfff
#define BIT_TRI_HEAD_ADDR(x) \
(((x) & BIT_MASK_TRI_HEAD_ADDR) << BIT_SHIFT_TRI_HEAD_ADDR)
#define BITS_TRI_HEAD_ADDR (BIT_MASK_TRI_HEAD_ADDR << BIT_SHIFT_TRI_HEAD_ADDR)
#define BIT_CLEAR_TRI_HEAD_ADDR(x) ((x) & (~BITS_TRI_HEAD_ADDR))
#define BIT_GET_TRI_HEAD_ADDR(x) \
(((x) >> BIT_SHIFT_TRI_HEAD_ADDR) & BIT_MASK_TRI_HEAD_ADDR)
#define BIT_SET_TRI_HEAD_ADDR(x, v) \
(BIT_CLEAR_TRI_HEAD_ADDR(x) | BIT_TRI_HEAD_ADDR(v))
#define BIT_DROP_TH_EN BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TX_RPT_INFO_H32 (Offset 0x04F4) */
#define BIT_SHIFT_AC_TX_RPT_INFO_H32 0
#define BIT_MASK_AC_TX_RPT_INFO_H32 0xffffffffL
#define BIT_AC_TX_RPT_INFO_H32(x) \
(((x) & BIT_MASK_AC_TX_RPT_INFO_H32) << BIT_SHIFT_AC_TX_RPT_INFO_H32)
#define BITS_AC_TX_RPT_INFO_H32 \
(BIT_MASK_AC_TX_RPT_INFO_H32 << BIT_SHIFT_AC_TX_RPT_INFO_H32)
#define BIT_CLEAR_AC_TX_RPT_INFO_H32(x) ((x) & (~BITS_AC_TX_RPT_INFO_H32))
#define BIT_GET_AC_TX_RPT_INFO_H32(x) \
(((x) >> BIT_SHIFT_AC_TX_RPT_INFO_H32) & BIT_MASK_AC_TX_RPT_INFO_H32)
#define BIT_SET_AC_TX_RPT_INFO_H32(x, v) \
(BIT_CLEAR_AC_TX_RPT_INFO_H32(x) | BIT_AC_TX_RPT_INFO_H32(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPUMGQ_TIMER_CTRL2 (Offset 0x04F4) */
#define BIT_SHIFT_DROP_TH 0
#define BIT_MASK_DROP_TH 0xff
#define BIT_DROP_TH(x) (((x) & BIT_MASK_DROP_TH) << BIT_SHIFT_DROP_TH)
#define BITS_DROP_TH (BIT_MASK_DROP_TH << BIT_SHIFT_DROP_TH)
#define BIT_CLEAR_DROP_TH(x) ((x) & (~BITS_DROP_TH))
#define BIT_GET_DROP_TH(x) (((x) >> BIT_SHIFT_DROP_TH) & BIT_MASK_DROP_TH)
#define BIT_SET_DROP_TH(x, v) (BIT_CLEAR_DROP_TH(x) | BIT_DROP_TH(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PTCL_DBG_OUT (Offset 0x04F8) */
#define BIT_SHIFT_PTCL_DBG_OUT 0
#define BIT_MASK_PTCL_DBG_OUT 0xffffffffL
#define BIT_PTCL_DBG_OUT(x) \
(((x) & BIT_MASK_PTCL_DBG_OUT) << BIT_SHIFT_PTCL_DBG_OUT)
#define BITS_PTCL_DBG_OUT (BIT_MASK_PTCL_DBG_OUT << BIT_SHIFT_PTCL_DBG_OUT)
#define BIT_CLEAR_PTCL_DBG_OUT(x) ((x) & (~BITS_PTCL_DBG_OUT))
#define BIT_GET_PTCL_DBG_OUT(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_OUT) & BIT_MASK_PTCL_DBG_OUT)
#define BIT_SET_PTCL_DBG_OUT(x, v) \
(BIT_CLEAR_PTCL_DBG_OUT(x) | BIT_PTCL_DBG_OUT(v))
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_DUMMY_PAGE4 (Offset 0x04FC) */
#define BIT_MOREDATA_CTRL2_EN BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DUMMY_PAGE4 (Offset 0x04FC) */
#define BIT_MOREDATA_CTRL2_EN_V2 BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT)
/* 2 REG_DUMMY_PAGE4 (Offset 0x04FC) */
#define BIT_MOREDATA_CTRL1_EN BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DUMMY_PAGE4 (Offset 0x04FC) */
#define BIT_MOREDATA_CTRL1_EN_V2 BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUMMY_PAGE4 (Offset 0x04FC) */
#define BIT_EN_BCN_TRXRPT BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_DUMMY_PAGE4 (Offset 0x04FC) */
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE BIT(16)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_DUMMY_PAGE4_V1 (Offset 0x04FC) */
#define BIT_BCN_EN_EXTHWSEQ BIT(1)
#define BIT_BCN_EN_HWSEQ BIT(0)
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION 0xffffffffffffffffL
#define BIT_R_MU_STA_GTAB_POSITION(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION)
#define BITS_R_MU_STA_GTAB_POSITION \
(BIT_MASK_R_MU_STA_GTAB_POSITION << BIT_SHIFT_R_MU_STA_GTAB_POSITION)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION))
#define BIT_GET_R_MU_STA_GTAB_POSITION(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION) & \
BIT_MASK_R_MU_STA_GTAB_POSITION)
#define BIT_SET_R_MU_STA_GTAB_POSITION(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION(x) | BIT_R_MU_STA_GTAB_POSITION(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MOREDATA (Offset 0x04FE) */
#define BIT_MOREDATA_CTRL2_EN_V1 BIT(3)
#define BIT_MOREDATA_CTRL1_EN_V1 BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DUMMY_PAGE4_1 (Offset 0x04FE) */
#define BIT_EN_BCN_TRXRPT_V2 BIT(1)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MOREDATA (Offset 0x04FE) */
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_EDCA_VO_PARAM (Offset 0x0500) */
#define BIT_SHIFT_TXOPLIMIT 16
#define BIT_MASK_TXOPLIMIT 0x7ff
#define BIT_TXOPLIMIT(x) (((x) & BIT_MASK_TXOPLIMIT) << BIT_SHIFT_TXOPLIMIT)
#define BITS_TXOPLIMIT (BIT_MASK_TXOPLIMIT << BIT_SHIFT_TXOPLIMIT)
#define BIT_CLEAR_TXOPLIMIT(x) ((x) & (~BITS_TXOPLIMIT))
#define BIT_GET_TXOPLIMIT(x) (((x) >> BIT_SHIFT_TXOPLIMIT) & BIT_MASK_TXOPLIMIT)
#define BIT_SET_TXOPLIMIT(x, v) (BIT_CLEAR_TXOPLIMIT(x) | BIT_TXOPLIMIT(v))
#define BIT_SHIFT_CW 8
#define BIT_MASK_CW 0xff
#define BIT_CW(x) (((x) & BIT_MASK_CW) << BIT_SHIFT_CW)
#define BITS_CW (BIT_MASK_CW << BIT_SHIFT_CW)
#define BIT_CLEAR_CW(x) ((x) & (~BITS_CW))
#define BIT_GET_CW(x) (((x) >> BIT_SHIFT_CW) & BIT_MASK_CW)
#define BIT_SET_CW(x, v) (BIT_CLEAR_CW(x) | BIT_CW(v))
#define BIT_SHIFT_AIFS 0
#define BIT_MASK_AIFS 0xff
#define BIT_AIFS(x) (((x) & BIT_MASK_AIFS) << BIT_SHIFT_AIFS)
#define BITS_AIFS (BIT_MASK_AIFS << BIT_SHIFT_AIFS)
#define BIT_CLEAR_AIFS(x) ((x) & (~BITS_AIFS))
#define BIT_GET_AIFS(x) (((x) >> BIT_SHIFT_AIFS) & BIT_MASK_AIFS)
#define BIT_SET_AIFS(x, v) (BIT_CLEAR_AIFS(x) | BIT_AIFS(v))
/* 2 REG_BCNTCFG (Offset 0x0510) */
#define BIT_SHIFT_BCNCW_MAX 12
#define BIT_MASK_BCNCW_MAX 0xf
#define BIT_BCNCW_MAX(x) (((x) & BIT_MASK_BCNCW_MAX) << BIT_SHIFT_BCNCW_MAX)
#define BITS_BCNCW_MAX (BIT_MASK_BCNCW_MAX << BIT_SHIFT_BCNCW_MAX)
#define BIT_CLEAR_BCNCW_MAX(x) ((x) & (~BITS_BCNCW_MAX))
#define BIT_GET_BCNCW_MAX(x) (((x) >> BIT_SHIFT_BCNCW_MAX) & BIT_MASK_BCNCW_MAX)
#define BIT_SET_BCNCW_MAX(x, v) (BIT_CLEAR_BCNCW_MAX(x) | BIT_BCNCW_MAX(v))
#define BIT_SHIFT_BCNCW_MIN 8
#define BIT_MASK_BCNCW_MIN 0xf
#define BIT_BCNCW_MIN(x) (((x) & BIT_MASK_BCNCW_MIN) << BIT_SHIFT_BCNCW_MIN)
#define BITS_BCNCW_MIN (BIT_MASK_BCNCW_MIN << BIT_SHIFT_BCNCW_MIN)
#define BIT_CLEAR_BCNCW_MIN(x) ((x) & (~BITS_BCNCW_MIN))
#define BIT_GET_BCNCW_MIN(x) (((x) >> BIT_SHIFT_BCNCW_MIN) & BIT_MASK_BCNCW_MIN)
#define BIT_SET_BCNCW_MIN(x, v) (BIT_CLEAR_BCNCW_MIN(x) | BIT_BCNCW_MIN(v))
#define BIT_SHIFT_BCNIFS 0
#define BIT_MASK_BCNIFS 0xff
#define BIT_BCNIFS(x) (((x) & BIT_MASK_BCNIFS) << BIT_SHIFT_BCNIFS)
#define BITS_BCNIFS (BIT_MASK_BCNIFS << BIT_SHIFT_BCNIFS)
#define BIT_CLEAR_BCNIFS(x) ((x) & (~BITS_BCNIFS))
#define BIT_GET_BCNIFS(x) (((x) >> BIT_SHIFT_BCNIFS) & BIT_MASK_BCNIFS)
#define BIT_SET_BCNIFS(x, v) (BIT_CLEAR_BCNIFS(x) | BIT_BCNIFS(v))
/* 2 REG_PIFS (Offset 0x0512) */
#define BIT_SHIFT_PIFS 0
#define BIT_MASK_PIFS 0xff
#define BIT_PIFS(x) (((x) & BIT_MASK_PIFS) << BIT_SHIFT_PIFS)
#define BITS_PIFS (BIT_MASK_PIFS << BIT_SHIFT_PIFS)
#define BIT_CLEAR_PIFS(x) ((x) & (~BITS_PIFS))
#define BIT_GET_PIFS(x) (((x) >> BIT_SHIFT_PIFS) & BIT_MASK_PIFS)
#define BIT_SET_PIFS(x, v) (BIT_CLEAR_PIFS(x) | BIT_PIFS(v))
/* 2 REG_RDG_PIFS (Offset 0x0513) */
#define BIT_SHIFT_RDG_PIFS 0
#define BIT_MASK_RDG_PIFS 0xff
#define BIT_RDG_PIFS(x) (((x) & BIT_MASK_RDG_PIFS) << BIT_SHIFT_RDG_PIFS)
#define BITS_RDG_PIFS (BIT_MASK_RDG_PIFS << BIT_SHIFT_RDG_PIFS)
#define BIT_CLEAR_RDG_PIFS(x) ((x) & (~BITS_RDG_PIFS))
#define BIT_GET_RDG_PIFS(x) (((x) >> BIT_SHIFT_RDG_PIFS) & BIT_MASK_RDG_PIFS)
#define BIT_SET_RDG_PIFS(x, v) (BIT_CLEAR_RDG_PIFS(x) | BIT_RDG_PIFS(v))
/* 2 REG_SIFS (Offset 0x0514) */
#define BIT_SHIFT_SIFS_OFDM_TRX 24
#define BIT_MASK_SIFS_OFDM_TRX 0xff
#define BIT_SIFS_OFDM_TRX(x) \
(((x) & BIT_MASK_SIFS_OFDM_TRX) << BIT_SHIFT_SIFS_OFDM_TRX)
#define BITS_SIFS_OFDM_TRX (BIT_MASK_SIFS_OFDM_TRX << BIT_SHIFT_SIFS_OFDM_TRX)
#define BIT_CLEAR_SIFS_OFDM_TRX(x) ((x) & (~BITS_SIFS_OFDM_TRX))
#define BIT_GET_SIFS_OFDM_TRX(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_TRX) & BIT_MASK_SIFS_OFDM_TRX)
#define BIT_SET_SIFS_OFDM_TRX(x, v) \
(BIT_CLEAR_SIFS_OFDM_TRX(x) | BIT_SIFS_OFDM_TRX(v))
#define BIT_SHIFT_SIFS_CCK_TRX 16
#define BIT_MASK_SIFS_CCK_TRX 0xff
#define BIT_SIFS_CCK_TRX(x) \
(((x) & BIT_MASK_SIFS_CCK_TRX) << BIT_SHIFT_SIFS_CCK_TRX)
#define BITS_SIFS_CCK_TRX (BIT_MASK_SIFS_CCK_TRX << BIT_SHIFT_SIFS_CCK_TRX)
#define BIT_CLEAR_SIFS_CCK_TRX(x) ((x) & (~BITS_SIFS_CCK_TRX))
#define BIT_GET_SIFS_CCK_TRX(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_TRX) & BIT_MASK_SIFS_CCK_TRX)
#define BIT_SET_SIFS_CCK_TRX(x, v) \
(BIT_CLEAR_SIFS_CCK_TRX(x) | BIT_SIFS_CCK_TRX(v))
#define BIT_SHIFT_SIFS_OFDM_CTX 8
#define BIT_MASK_SIFS_OFDM_CTX 0xff
#define BIT_SIFS_OFDM_CTX(x) \
(((x) & BIT_MASK_SIFS_OFDM_CTX) << BIT_SHIFT_SIFS_OFDM_CTX)
#define BITS_SIFS_OFDM_CTX (BIT_MASK_SIFS_OFDM_CTX << BIT_SHIFT_SIFS_OFDM_CTX)
#define BIT_CLEAR_SIFS_OFDM_CTX(x) ((x) & (~BITS_SIFS_OFDM_CTX))
#define BIT_GET_SIFS_OFDM_CTX(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_CTX) & BIT_MASK_SIFS_OFDM_CTX)
#define BIT_SET_SIFS_OFDM_CTX(x, v) \
(BIT_CLEAR_SIFS_OFDM_CTX(x) | BIT_SIFS_OFDM_CTX(v))
#define BIT_SHIFT_SIFS_CCK_CTX 0
#define BIT_MASK_SIFS_CCK_CTX 0xff
#define BIT_SIFS_CCK_CTX(x) \
(((x) & BIT_MASK_SIFS_CCK_CTX) << BIT_SHIFT_SIFS_CCK_CTX)
#define BITS_SIFS_CCK_CTX (BIT_MASK_SIFS_CCK_CTX << BIT_SHIFT_SIFS_CCK_CTX)
#define BIT_CLEAR_SIFS_CCK_CTX(x) ((x) & (~BITS_SIFS_CCK_CTX))
#define BIT_GET_SIFS_CCK_CTX(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_CTX) & BIT_MASK_SIFS_CCK_CTX)
#define BIT_SET_SIFS_CCK_CTX(x, v) \
(BIT_CLEAR_SIFS_CCK_CTX(x) | BIT_SIFS_CCK_CTX(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TSFTR_SYN_OFFSET (Offset 0x0518) */
#define BIT_SHIFT_TSFTR_SNC_OFFSET 0
#define BIT_MASK_TSFTR_SNC_OFFSET 0xffff
#define BIT_TSFTR_SNC_OFFSET(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET) << BIT_SHIFT_TSFTR_SNC_OFFSET)
#define BITS_TSFTR_SNC_OFFSET \
(BIT_MASK_TSFTR_SNC_OFFSET << BIT_SHIFT_TSFTR_SNC_OFFSET)
#define BIT_CLEAR_TSFTR_SNC_OFFSET(x) ((x) & (~BITS_TSFTR_SNC_OFFSET))
#define BIT_GET_TSFTR_SNC_OFFSET(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET) & BIT_MASK_TSFTR_SNC_OFFSET)
#define BIT_SET_TSFTR_SNC_OFFSET(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET(x) | BIT_TSFTR_SNC_OFFSET(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_AGGR_BREAK_TIME (Offset 0x051A) */
#define BIT_SHIFT_AGGR_BK_TIME 0
#define BIT_MASK_AGGR_BK_TIME 0xff
#define BIT_AGGR_BK_TIME(x) \
(((x) & BIT_MASK_AGGR_BK_TIME) << BIT_SHIFT_AGGR_BK_TIME)
#define BITS_AGGR_BK_TIME (BIT_MASK_AGGR_BK_TIME << BIT_SHIFT_AGGR_BK_TIME)
#define BIT_CLEAR_AGGR_BK_TIME(x) ((x) & (~BITS_AGGR_BK_TIME))
#define BIT_GET_AGGR_BK_TIME(x) \
(((x) >> BIT_SHIFT_AGGR_BK_TIME) & BIT_MASK_AGGR_BK_TIME)
#define BIT_SET_AGGR_BK_TIME(x, v) \
(BIT_CLEAR_AGGR_BK_TIME(x) | BIT_AGGR_BK_TIME(v))
/* 2 REG_SLOT (Offset 0x051B) */
#define BIT_SHIFT_SLOT 0
#define BIT_MASK_SLOT 0xff
#define BIT_SLOT(x) (((x) & BIT_MASK_SLOT) << BIT_SHIFT_SLOT)
#define BITS_SLOT (BIT_MASK_SLOT << BIT_SHIFT_SLOT)
#define BIT_CLEAR_SLOT(x) ((x) & (~BITS_SLOT))
#define BIT_GET_SLOT(x) (((x) >> BIT_SHIFT_SLOT) & BIT_MASK_SLOT)
#define BIT_SET_SLOT(x, v) (BIT_CLEAR_SLOT(x) | BIT_SLOT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_EDCA_CPUMGQ_PARAM (Offset 0x051C) */
#define BIT_SHIFT_CW_V1 8
#define BIT_MASK_CW_V1 0xff
#define BIT_CW_V1(x) (((x) & BIT_MASK_CW_V1) << BIT_SHIFT_CW_V1)
#define BITS_CW_V1 (BIT_MASK_CW_V1 << BIT_SHIFT_CW_V1)
#define BIT_CLEAR_CW_V1(x) ((x) & (~BITS_CW_V1))
#define BIT_GET_CW_V1(x) (((x) >> BIT_SHIFT_CW_V1) & BIT_MASK_CW_V1)
#define BIT_SET_CW_V1(x, v) (BIT_CLEAR_CW_V1(x) | BIT_CW_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NOA_ON_ERLY_TIME (Offset 0x051C) */
#define BIT_SHIFT__NOA_ON_ERLY_TIME 0
#define BIT_MASK__NOA_ON_ERLY_TIME 0xff
#define BIT__NOA_ON_ERLY_TIME(x) \
(((x) & BIT_MASK__NOA_ON_ERLY_TIME) << BIT_SHIFT__NOA_ON_ERLY_TIME)
#define BITS__NOA_ON_ERLY_TIME \
(BIT_MASK__NOA_ON_ERLY_TIME << BIT_SHIFT__NOA_ON_ERLY_TIME)
#define BIT_CLEAR__NOA_ON_ERLY_TIME(x) ((x) & (~BITS__NOA_ON_ERLY_TIME))
#define BIT_GET__NOA_ON_ERLY_TIME(x) \
(((x) >> BIT_SHIFT__NOA_ON_ERLY_TIME) & BIT_MASK__NOA_ON_ERLY_TIME)
#define BIT_SET__NOA_ON_ERLY_TIME(x, v) \
(BIT_CLEAR__NOA_ON_ERLY_TIME(x) | BIT__NOA_ON_ERLY_TIME(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_EDCA_CPUMGQ_PARAM (Offset 0x051C) */
#define BIT_SHIFT_AIFS_V1 0
#define BIT_MASK_AIFS_V1 0xff
#define BIT_AIFS_V1(x) (((x) & BIT_MASK_AIFS_V1) << BIT_SHIFT_AIFS_V1)
#define BITS_AIFS_V1 (BIT_MASK_AIFS_V1 << BIT_SHIFT_AIFS_V1)
#define BIT_CLEAR_AIFS_V1(x) ((x) & (~BITS_AIFS_V1))
#define BIT_GET_AIFS_V1(x) (((x) >> BIT_SHIFT_AIFS_V1) & BIT_MASK_AIFS_V1)
#define BIT_SET_AIFS_V1(x, v) (BIT_CLEAR_AIFS_V1(x) | BIT_AIFS_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NOA_OFF_ERLY_TIME (Offset 0x051D) */
#define BIT_SHIFT__NOA_OFF_ERLY_TIME 0
#define BIT_MASK__NOA_OFF_ERLY_TIME 0xff
#define BIT__NOA_OFF_ERLY_TIME(x) \
(((x) & BIT_MASK__NOA_OFF_ERLY_TIME) << BIT_SHIFT__NOA_OFF_ERLY_TIME)
#define BITS__NOA_OFF_ERLY_TIME \
(BIT_MASK__NOA_OFF_ERLY_TIME << BIT_SHIFT__NOA_OFF_ERLY_TIME)
#define BIT_CLEAR__NOA_OFF_ERLY_TIME(x) ((x) & (~BITS__NOA_OFF_ERLY_TIME))
#define BIT_GET__NOA_OFF_ERLY_TIME(x) \
(((x) >> BIT_SHIFT__NOA_OFF_ERLY_TIME) & BIT_MASK__NOA_OFF_ERLY_TIME)
#define BIT_SET__NOA_OFF_ERLY_TIME(x, v) \
(BIT_CLEAR__NOA_OFF_ERLY_TIME(x) | BIT__NOA_OFF_ERLY_TIME(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPUMGQ_PAUSE (Offset 0x051E) */
#define BIT_MAC_STOP_CPUMGQ_V1 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PS_TIMER_CTRL (Offset 0x051F) */
#define BIT_PS_TIMER_B_EN_V1 BIT(7)
#define BIT_SHIFT_PS_TIMER_B_TSF_SEL_V1 4
#define BIT_MASK_PS_TIMER_B_TSF_SEL_V1 0x3
#define BIT_PS_TIMER_B_TSF_SEL_V1(x) \
(((x) & BIT_MASK_PS_TIMER_B_TSF_SEL_V1) \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_V1)
#define BITS_PS_TIMER_B_TSF_SEL_V1 \
(BIT_MASK_PS_TIMER_B_TSF_SEL_V1 << BIT_SHIFT_PS_TIMER_B_TSF_SEL_V1)
#define BIT_CLEAR_PS_TIMER_B_TSF_SEL_V1(x) ((x) & (~BITS_PS_TIMER_B_TSF_SEL_V1))
#define BIT_GET_PS_TIMER_B_TSF_SEL_V1(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_TSF_SEL_V1) & \
BIT_MASK_PS_TIMER_B_TSF_SEL_V1)
#define BIT_SET_PS_TIMER_B_TSF_SEL_V1(x, v) \
(BIT_CLEAR_PS_TIMER_B_TSF_SEL_V1(x) | BIT_PS_TIMER_B_TSF_SEL_V1(v))
#define BIT_PS_TIMER_A_EN_V1 BIT(3)
#define BIT_SHIFT_PS_TIMER_A_TSF_SEL_V1 0
#define BIT_MASK_PS_TIMER_A_TSF_SEL_V1 0x3
#define BIT_PS_TIMER_A_TSF_SEL_V1(x) \
(((x) & BIT_MASK_PS_TIMER_A_TSF_SEL_V1) \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_V1)
#define BITS_PS_TIMER_A_TSF_SEL_V1 \
(BIT_MASK_PS_TIMER_A_TSF_SEL_V1 << BIT_SHIFT_PS_TIMER_A_TSF_SEL_V1)
#define BIT_CLEAR_PS_TIMER_A_TSF_SEL_V1(x) ((x) & (~BITS_PS_TIMER_A_TSF_SEL_V1))
#define BIT_GET_PS_TIMER_A_TSF_SEL_V1(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_TSF_SEL_V1) & \
BIT_MASK_PS_TIMER_A_TSF_SEL_V1)
#define BIT_SET_PS_TIMER_A_TSF_SEL_V1(x, v) \
(BIT_CLEAR_PS_TIMER_A_TSF_SEL_V1(x) | BIT_PS_TIMER_A_TSF_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TX_PTCL_CTRL (Offset 0x0520) */
#define BIT_DIS_EDCCA BIT(15)
#define BIT_DIS_CCA BIT(14)
#define BIT_LSIG_TXOP_TXCMD_NAV BIT(13)
#define BIT_SIFS_BK_EN BIT(12)
#define BIT_SHIFT_TXQ_NAV_MSK 8
#define BIT_MASK_TXQ_NAV_MSK 0xf
#define BIT_TXQ_NAV_MSK(x) \
(((x) & BIT_MASK_TXQ_NAV_MSK) << BIT_SHIFT_TXQ_NAV_MSK)
#define BITS_TXQ_NAV_MSK (BIT_MASK_TXQ_NAV_MSK << BIT_SHIFT_TXQ_NAV_MSK)
#define BIT_CLEAR_TXQ_NAV_MSK(x) ((x) & (~BITS_TXQ_NAV_MSK))
#define BIT_GET_TXQ_NAV_MSK(x) \
(((x) >> BIT_SHIFT_TXQ_NAV_MSK) & BIT_MASK_TXQ_NAV_MSK)
#define BIT_SET_TXQ_NAV_MSK(x, v) \
(BIT_CLEAR_TXQ_NAV_MSK(x) | BIT_TXQ_NAV_MSK(v))
#define BIT_DIS_CW BIT(7)
#define BIT_NAV_END_TXOP BIT(6)
#define BIT_RDG_END_TXOP BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TX_PTCL_CTRL (Offset 0x0520) */
#define BIT_AC_INBCN_HOLD BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TX_PTCL_CTRL (Offset 0x0520) */
#define BIT_MGTQ_TXOP_EN BIT(3)
#define BIT_MGTQ_RTSMF_EN BIT(2)
#define BIT_HIQ_RTSMF_EN BIT(1)
#define BIT_BCN_RTSMF_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXPAUSE (Offset 0x0522) */
#define BIT_STOP_BCN_HI_MGT BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXPAUSE (Offset 0x0522) */
#define BIT_MAC_STOPCPUMGQ BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXPAUSE (Offset 0x0522) */
#define BIT_MAC_STOPBCNQ BIT(6)
#define BIT_MAC_STOPHIQ BIT(5)
#define BIT_MAC_STOPMGQ BIT(4)
#define BIT_MAC_STOPBK BIT(3)
#define BIT_MAC_STOPBE BIT(2)
#define BIT_MAC_STOPVI BIT(1)
#define BIT_MAC_STOPVO BIT(0)
/* 2 REG_DIS_TXREQ_CLR (Offset 0x0523) */
#define BIT_DIS_BT_CCA BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DIS_TXREQ_CLR (Offset 0x0523) */
#define BIT_DIS_TXREQ_CLR_CPUMGQ BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_DIS_TXREQ_CLR (Offset 0x0523) */
#define BIT_DIS_TXREQ_CLR_HI BIT(5)
#define BIT_DIS_TXREQ_CLR_MGQ BIT(4)
#define BIT_DIS_TXREQ_CLR_VO BIT(3)
#define BIT_DIS_TXREQ_CLR_VI BIT(2)
#define BIT_DIS_TXREQ_CLR_BE BIT(1)
#define BIT_DIS_TXREQ_CLR_BK BIT(0)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_EN_CLR_TXREQ_INCCA BIT(15)
#define BIT_DIS_TX_OVER_BCNQ BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_EN_BCNERR_INCCCA BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_EN_BCNERR_INCCA BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_EN_BCNERR_INEDCCA BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_EDCCA_MSK_CNTDOWN_EN BIT(11)
#define BIT_DIS_TXOP_CFE BIT(10)
#define BIT_DIS_LSIG_CFE BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_DIS_STBC_CFE BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RD_CTRL (Offset 0x0524) */
#define BIT_BKQ_RD_INIT_EN BIT(7)
#define BIT_BEQ_RD_INIT_EN BIT(6)
#define BIT_VIQ_RD_INIT_EN BIT(5)
#define BIT_VOQ_RD_INIT_EN BIT(4)
#define BIT_BKQ_RD_RESP_EN BIT(3)
#define BIT_BEQ_RD_RESP_EN BIT(2)
#define BIT_VIQ_RD_RESP_EN BIT(1)
#define BIT_VOQ_RD_RESP_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBSSID_CTRL (Offset 0x0526) */
#define BIT_MBID_BCNQ7_EN BIT(7)
#define BIT_MBID_BCNQ6_EN BIT(6)
#define BIT_MBID_BCNQ5_EN BIT(5)
#define BIT_MBID_BCNQ4_EN BIT(4)
#define BIT_MBID_BCNQ3_EN BIT(3)
#define BIT_MBID_BCNQ2_EN BIT(2)
#define BIT_MBID_BCNQ1_EN BIT(1)
#define BIT_MBID_BCNQ0_EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2PPS_CTRL (Offset 0x0527) */
#define BIT_P2P_CTW_ALLSTASLEEP BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_P2PPS_CTRL (Offset 0x0527) */
#define BIT_P2P_DISTX_SEL BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2PPS_CTRL (Offset 0x0527) */
#define BIT_PWR_MGT_EN BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2PPS_CTRL (Offset 0x0527) */
#define BIT_P2P_BCN_AREA_EN BIT(4)
#define BIT_P2P_CTWND_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2PPS_CTRL (Offset 0x0527) */
#define BIT_P2P_NOA1_EN BIT(2)
#define BIT_P2P_NOA0_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2PPS_CTRL (Offset 0x0527) */
#define BIT_P2P_BCN_SEL BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PKT_LIFETIME_CTRL (Offset 0x0528) */
#define BIT_EN_P2P_CTWND1 BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_PKT_LIFETIME_CTRL (Offset 0x0528) */
#define BIT_EN_TBTT_AREA_FOR_BB BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PKT_LIFETIME_CTRL (Offset 0x0528) */
#define BIT_EN_BKF_CLR_TXREQ BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PKT_LIFETIME_CTRL (Offset 0x0528) */
#define BIT_EN_TSFBIT32_RST_P2P BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PKT_LIFETIME_CTRL (Offset 0x0528) */
#define BIT_EN_BCN_TX_BTCCA BIT(20)
#define BIT_DIS_PKT_TX_ATIM BIT(19)
#define BIT_DIS_BCN_DIS_CTN BIT(18)
#define BIT_EN_NAVEND_RST_TXOP BIT(17)
#define BIT_EN_FILTER_CCA BIT(16)
#define BIT_SHIFT_CCA_FILTER_THRS 8
#define BIT_MASK_CCA_FILTER_THRS 0xff
#define BIT_CCA_FILTER_THRS(x) \
(((x) & BIT_MASK_CCA_FILTER_THRS) << BIT_SHIFT_CCA_FILTER_THRS)
#define BITS_CCA_FILTER_THRS \
(BIT_MASK_CCA_FILTER_THRS << BIT_SHIFT_CCA_FILTER_THRS)
#define BIT_CLEAR_CCA_FILTER_THRS(x) ((x) & (~BITS_CCA_FILTER_THRS))
#define BIT_GET_CCA_FILTER_THRS(x) \
(((x) >> BIT_SHIFT_CCA_FILTER_THRS) & BIT_MASK_CCA_FILTER_THRS)
#define BIT_SET_CCA_FILTER_THRS(x, v) \
(BIT_CLEAR_CCA_FILTER_THRS(x) | BIT_CCA_FILTER_THRS(v))
#define BIT_SHIFT_EDCCA_THRS 0
#define BIT_MASK_EDCCA_THRS 0xff
#define BIT_EDCCA_THRS(x) (((x) & BIT_MASK_EDCCA_THRS) << BIT_SHIFT_EDCCA_THRS)
#define BITS_EDCCA_THRS (BIT_MASK_EDCCA_THRS << BIT_SHIFT_EDCCA_THRS)
#define BIT_CLEAR_EDCCA_THRS(x) ((x) & (~BITS_EDCCA_THRS))
#define BIT_GET_EDCCA_THRS(x) \
(((x) >> BIT_SHIFT_EDCCA_THRS) & BIT_MASK_EDCCA_THRS)
#define BIT_SET_EDCCA_THRS(x, v) (BIT_CLEAR_EDCCA_THRS(x) | BIT_EDCCA_THRS(v))
/* 2 REG_P2PPS_SPEC_STATE (Offset 0x052B) */
#define BIT_SPEC_POWER_STATE BIT(7)
#define BIT_SPEC_CTWINDOW_ON BIT(6)
#define BIT_SPEC_BEACON_AREA_ON BIT(5)
#define BIT_SPEC_CTWIN_EARLY_DISTX BIT(4)
#define BIT_SPEC_NOA1_OFF_PERIOD BIT(3)
#define BIT_SPEC_FORCE_DOZE1 BIT(2)
#define BIT_SPEC_NOA0_OFF_PERIOD BIT(1)
#define BIT_SPEC_FORCE_DOZE0 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXOP_LIMIT_CTRL (Offset 0x052C) */
#define BIT_SHIFT_TXOP_TBTT_CNT 24
#define BIT_MASK_TXOP_TBTT_CNT 0xff
#define BIT_TXOP_TBTT_CNT(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT) << BIT_SHIFT_TXOP_TBTT_CNT)
#define BITS_TXOP_TBTT_CNT (BIT_MASK_TXOP_TBTT_CNT << BIT_SHIFT_TXOP_TBTT_CNT)
#define BIT_CLEAR_TXOP_TBTT_CNT(x) ((x) & (~BITS_TXOP_TBTT_CNT))
#define BIT_GET_TXOP_TBTT_CNT(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT) & BIT_MASK_TXOP_TBTT_CNT)
#define BIT_SET_TXOP_TBTT_CNT(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT(x) | BIT_TXOP_TBTT_CNT(v))
#define BIT_SHIFT_TXOP_TBTT_CNT_SEL 20
#define BIT_MASK_TXOP_TBTT_CNT_SEL 0xf
#define BIT_TXOP_TBTT_CNT_SEL(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_SEL) << BIT_SHIFT_TXOP_TBTT_CNT_SEL)
#define BITS_TXOP_TBTT_CNT_SEL \
(BIT_MASK_TXOP_TBTT_CNT_SEL << BIT_SHIFT_TXOP_TBTT_CNT_SEL)
#define BIT_CLEAR_TXOP_TBTT_CNT_SEL(x) ((x) & (~BITS_TXOP_TBTT_CNT_SEL))
#define BIT_GET_TXOP_TBTT_CNT_SEL(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_SEL) & BIT_MASK_TXOP_TBTT_CNT_SEL)
#define BIT_SET_TXOP_TBTT_CNT_SEL(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_SEL(x) | BIT_TXOP_TBTT_CNT_SEL(v))
#define BIT_SHIFT_TXOP_LMT_EN 16
#define BIT_MASK_TXOP_LMT_EN 0xf
#define BIT_TXOP_LMT_EN(x) \
(((x) & BIT_MASK_TXOP_LMT_EN) << BIT_SHIFT_TXOP_LMT_EN)
#define BITS_TXOP_LMT_EN (BIT_MASK_TXOP_LMT_EN << BIT_SHIFT_TXOP_LMT_EN)
#define BIT_CLEAR_TXOP_LMT_EN(x) ((x) & (~BITS_TXOP_LMT_EN))
#define BIT_GET_TXOP_LMT_EN(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_EN) & BIT_MASK_TXOP_LMT_EN)
#define BIT_SET_TXOP_LMT_EN(x, v) \
(BIT_CLEAR_TXOP_LMT_EN(x) | BIT_TXOP_LMT_EN(v))
#define BIT_SHIFT_TXOP_LMT_TX_TIME 8
#define BIT_MASK_TXOP_LMT_TX_TIME 0xff
#define BIT_TXOP_LMT_TX_TIME(x) \
(((x) & BIT_MASK_TXOP_LMT_TX_TIME) << BIT_SHIFT_TXOP_LMT_TX_TIME)
#define BITS_TXOP_LMT_TX_TIME \
(BIT_MASK_TXOP_LMT_TX_TIME << BIT_SHIFT_TXOP_LMT_TX_TIME)
#define BIT_CLEAR_TXOP_LMT_TX_TIME(x) ((x) & (~BITS_TXOP_LMT_TX_TIME))
#define BIT_GET_TXOP_LMT_TX_TIME(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_TX_TIME) & BIT_MASK_TXOP_LMT_TX_TIME)
#define BIT_SET_TXOP_LMT_TX_TIME(x, v) \
(BIT_CLEAR_TXOP_LMT_TX_TIME(x) | BIT_TXOP_LMT_TX_TIME(v))
#define BIT_TXOP_CNT_TRIGGER_RESET BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TBTT_AREA_BLK_4AC (Offset 0x052C) */
#define BIT_EN_TBTT_AREA_BLK_4AC BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PS_TIMER_A_V2 (Offset 0x052C) */
#define BIT_SHIFT_PS_TIMER_A_V2 0
#define BIT_MASK_PS_TIMER_A_V2 0xffffffffL
#define BIT_PS_TIMER_A_V2(x) \
(((x) & BIT_MASK_PS_TIMER_A_V2) << BIT_SHIFT_PS_TIMER_A_V2)
#define BITS_PS_TIMER_A_V2 (BIT_MASK_PS_TIMER_A_V2 << BIT_SHIFT_PS_TIMER_A_V2)
#define BIT_CLEAR_PS_TIMER_A_V2(x) ((x) & (~BITS_PS_TIMER_A_V2))
#define BIT_GET_PS_TIMER_A_V2(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_V2) & BIT_MASK_PS_TIMER_A_V2)
#define BIT_SET_PS_TIMER_A_V2(x, v) \
(BIT_CLEAR_PS_TIMER_A_V2(x) | BIT_PS_TIMER_A_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXOP_LIMIT_CTRL (Offset 0x052C) */
#define BIT_SHIFT_TXOP_LMT_PKT_NUM 0
#define BIT_MASK_TXOP_LMT_PKT_NUM 0x3f
#define BIT_TXOP_LMT_PKT_NUM(x) \
(((x) & BIT_MASK_TXOP_LMT_PKT_NUM) << BIT_SHIFT_TXOP_LMT_PKT_NUM)
#define BITS_TXOP_LMT_PKT_NUM \
(BIT_MASK_TXOP_LMT_PKT_NUM << BIT_SHIFT_TXOP_LMT_PKT_NUM)
#define BIT_CLEAR_TXOP_LMT_PKT_NUM(x) ((x) & (~BITS_TXOP_LMT_PKT_NUM))
#define BIT_GET_TXOP_LMT_PKT_NUM(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_PKT_NUM) & BIT_MASK_TXOP_LMT_PKT_NUM)
#define BIT_SET_TXOP_LMT_PKT_NUM(x, v) \
(BIT_CLEAR_TXOP_LMT_PKT_NUM(x) | BIT_TXOP_LMT_PKT_NUM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PON_DIS_TXTIME (Offset 0x0531) */
#define BIT_SHIFT_P2PON_DIS_TXTIME 0
#define BIT_MASK_P2PON_DIS_TXTIME 0xff
#define BIT_P2PON_DIS_TXTIME(x) \
(((x) & BIT_MASK_P2PON_DIS_TXTIME) << BIT_SHIFT_P2PON_DIS_TXTIME)
#define BITS_P2PON_DIS_TXTIME \
(BIT_MASK_P2PON_DIS_TXTIME << BIT_SHIFT_P2PON_DIS_TXTIME)
#define BIT_CLEAR_P2PON_DIS_TXTIME(x) ((x) & (~BITS_P2PON_DIS_TXTIME))
#define BIT_GET_P2PON_DIS_TXTIME(x) \
(((x) >> BIT_SHIFT_P2PON_DIS_TXTIME) & BIT_MASK_P2PON_DIS_TXTIME)
#define BIT_SET_P2PON_DIS_TXTIME(x, v) \
(BIT_CLEAR_P2PON_DIS_TXTIME(x) | BIT_P2PON_DIS_TXTIME(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PS_TIMER_B_V2 (Offset 0x0534) */
#define BIT_FTM_PTT_TSF_R2T_SEL_V1 BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CCA_TXEN_CNT (Offset 0x0534) */
#define BIT_ENABLE_STOP_UPDATE_NAV BIT(21)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PS_TIMER_B_V2 (Offset 0x0534) */
#define BIT_TBTT_DIG BIT(20)
#define BIT_FTM_PTT_TSF_T2R_SEL_V1 BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CCA_TXEN_CNT (Offset 0x0534) */
#define BIT_CCA_TXEN_CNT_SWITCH BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PS_TIMER_B_V2 (Offset 0x0534) */
#define BIT_FTM_PTT_TSF_SEL_V1 BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CCA_TXEN_CNT (Offset 0x0534) */
#define BIT_CCA_TXEN_CNT_EN BIT(16)
#define BIT_SHIFT_CCA_TXEN_BIG_CNT 8
#define BIT_MASK_CCA_TXEN_BIG_CNT 0xff
#define BIT_CCA_TXEN_BIG_CNT(x) \
(((x) & BIT_MASK_CCA_TXEN_BIG_CNT) << BIT_SHIFT_CCA_TXEN_BIG_CNT)
#define BITS_CCA_TXEN_BIG_CNT \
(BIT_MASK_CCA_TXEN_BIG_CNT << BIT_SHIFT_CCA_TXEN_BIG_CNT)
#define BIT_CLEAR_CCA_TXEN_BIG_CNT(x) ((x) & (~BITS_CCA_TXEN_BIG_CNT))
#define BIT_GET_CCA_TXEN_BIG_CNT(x) \
(((x) >> BIT_SHIFT_CCA_TXEN_BIG_CNT) & BIT_MASK_CCA_TXEN_BIG_CNT)
#define BIT_SET_CCA_TXEN_BIG_CNT(x, v) \
(BIT_CLEAR_CCA_TXEN_BIG_CNT(x) | BIT_CCA_TXEN_BIG_CNT(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PS_TIMER_B_V2 (Offset 0x0534) */
#define BIT_SHIFT_PS_TIMER_B_V2 0
#define BIT_MASK_PS_TIMER_B_V2 0xffffffffL
#define BIT_PS_TIMER_B_V2(x) \
(((x) & BIT_MASK_PS_TIMER_B_V2) << BIT_SHIFT_PS_TIMER_B_V2)
#define BITS_PS_TIMER_B_V2 (BIT_MASK_PS_TIMER_B_V2 << BIT_SHIFT_PS_TIMER_B_V2)
#define BIT_CLEAR_PS_TIMER_B_V2(x) ((x) & (~BITS_PS_TIMER_B_V2))
#define BIT_GET_PS_TIMER_B_V2(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_V2) & BIT_MASK_PS_TIMER_B_V2)
#define BIT_SET_PS_TIMER_B_V2(x, v) \
(BIT_CLEAR_PS_TIMER_B_V2(x) | BIT_PS_TIMER_B_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CCA_TXEN_CNT (Offset 0x0534) */
#define BIT_SHIFT_CCA_TXEN_SMALL_CNT 0
#define BIT_MASK_CCA_TXEN_SMALL_CNT 0xff
#define BIT_CCA_TXEN_SMALL_CNT(x) \
(((x) & BIT_MASK_CCA_TXEN_SMALL_CNT) << BIT_SHIFT_CCA_TXEN_SMALL_CNT)
#define BITS_CCA_TXEN_SMALL_CNT \
(BIT_MASK_CCA_TXEN_SMALL_CNT << BIT_SHIFT_CCA_TXEN_SMALL_CNT)
#define BIT_CLEAR_CCA_TXEN_SMALL_CNT(x) ((x) & (~BITS_CCA_TXEN_SMALL_CNT))
#define BIT_GET_CCA_TXEN_SMALL_CNT(x) \
(((x) >> BIT_SHIFT_CCA_TXEN_SMALL_CNT) & BIT_MASK_CCA_TXEN_SMALL_CNT)
#define BIT_SET_CCA_TXEN_SMALL_CNT(x, v) \
(BIT_CLEAR_CCA_TXEN_SMALL_CNT(x) | BIT_CCA_TXEN_SMALL_CNT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_THR (Offset 0x0538) */
#define BIT_SHIFT_BK_QUEUE_THR 24
#define BIT_MASK_BK_QUEUE_THR 0xff
#define BIT_BK_QUEUE_THR(x) \
(((x) & BIT_MASK_BK_QUEUE_THR) << BIT_SHIFT_BK_QUEUE_THR)
#define BITS_BK_QUEUE_THR (BIT_MASK_BK_QUEUE_THR << BIT_SHIFT_BK_QUEUE_THR)
#define BIT_CLEAR_BK_QUEUE_THR(x) ((x) & (~BITS_BK_QUEUE_THR))
#define BIT_GET_BK_QUEUE_THR(x) \
(((x) >> BIT_SHIFT_BK_QUEUE_THR) & BIT_MASK_BK_QUEUE_THR)
#define BIT_SET_BK_QUEUE_THR(x, v) \
(BIT_CLEAR_BK_QUEUE_THR(x) | BIT_BK_QUEUE_THR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION (Offset 0x0538) */
#define BIT_SHIFT_MAX_INTER_COLLISION_BK 24
#define BIT_MASK_MAX_INTER_COLLISION_BK 0xff
#define BIT_MAX_INTER_COLLISION_BK(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_BK) \
<< BIT_SHIFT_MAX_INTER_COLLISION_BK)
#define BITS_MAX_INTER_COLLISION_BK \
(BIT_MASK_MAX_INTER_COLLISION_BK << BIT_SHIFT_MAX_INTER_COLLISION_BK)
#define BIT_CLEAR_MAX_INTER_COLLISION_BK(x) \
((x) & (~BITS_MAX_INTER_COLLISION_BK))
#define BIT_GET_MAX_INTER_COLLISION_BK(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_BK) & \
BIT_MASK_MAX_INTER_COLLISION_BK)
#define BIT_SET_MAX_INTER_COLLISION_BK(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_BK(x) | BIT_MAX_INTER_COLLISION_BK(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_THR (Offset 0x0538) */
#define BIT_SHIFT_BE_QUEUE_THR 16
#define BIT_MASK_BE_QUEUE_THR 0xff
#define BIT_BE_QUEUE_THR(x) \
(((x) & BIT_MASK_BE_QUEUE_THR) << BIT_SHIFT_BE_QUEUE_THR)
#define BITS_BE_QUEUE_THR (BIT_MASK_BE_QUEUE_THR << BIT_SHIFT_BE_QUEUE_THR)
#define BIT_CLEAR_BE_QUEUE_THR(x) ((x) & (~BITS_BE_QUEUE_THR))
#define BIT_GET_BE_QUEUE_THR(x) \
(((x) >> BIT_SHIFT_BE_QUEUE_THR) & BIT_MASK_BE_QUEUE_THR)
#define BIT_SET_BE_QUEUE_THR(x, v) \
(BIT_CLEAR_BE_QUEUE_THR(x) | BIT_BE_QUEUE_THR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION (Offset 0x0538) */
#define BIT_SHIFT_MAX_INTER_COLLISION_BE 16
#define BIT_MASK_MAX_INTER_COLLISION_BE 0xff
#define BIT_MAX_INTER_COLLISION_BE(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_BE) \
<< BIT_SHIFT_MAX_INTER_COLLISION_BE)
#define BITS_MAX_INTER_COLLISION_BE \
(BIT_MASK_MAX_INTER_COLLISION_BE << BIT_SHIFT_MAX_INTER_COLLISION_BE)
#define BIT_CLEAR_MAX_INTER_COLLISION_BE(x) \
((x) & (~BITS_MAX_INTER_COLLISION_BE))
#define BIT_GET_MAX_INTER_COLLISION_BE(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_BE) & \
BIT_MASK_MAX_INTER_COLLISION_BE)
#define BIT_SET_MAX_INTER_COLLISION_BE(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_BE(x) | BIT_MAX_INTER_COLLISION_BE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_THR (Offset 0x0538) */
#define BIT_SHIFT_VI_QUEUE_THR 8
#define BIT_MASK_VI_QUEUE_THR 0xff
#define BIT_VI_QUEUE_THR(x) \
(((x) & BIT_MASK_VI_QUEUE_THR) << BIT_SHIFT_VI_QUEUE_THR)
#define BITS_VI_QUEUE_THR (BIT_MASK_VI_QUEUE_THR << BIT_SHIFT_VI_QUEUE_THR)
#define BIT_CLEAR_VI_QUEUE_THR(x) ((x) & (~BITS_VI_QUEUE_THR))
#define BIT_GET_VI_QUEUE_THR(x) \
(((x) >> BIT_SHIFT_VI_QUEUE_THR) & BIT_MASK_VI_QUEUE_THR)
#define BIT_SET_VI_QUEUE_THR(x, v) \
(BIT_CLEAR_VI_QUEUE_THR(x) | BIT_VI_QUEUE_THR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION (Offset 0x0538) */
#define BIT_SHIFT_MAX_INTER_COLLISION_VI 8
#define BIT_MASK_MAX_INTER_COLLISION_VI 0xff
#define BIT_MAX_INTER_COLLISION_VI(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_VI) \
<< BIT_SHIFT_MAX_INTER_COLLISION_VI)
#define BITS_MAX_INTER_COLLISION_VI \
(BIT_MASK_MAX_INTER_COLLISION_VI << BIT_SHIFT_MAX_INTER_COLLISION_VI)
#define BIT_CLEAR_MAX_INTER_COLLISION_VI(x) \
((x) & (~BITS_MAX_INTER_COLLISION_VI))
#define BIT_GET_MAX_INTER_COLLISION_VI(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_VI) & \
BIT_MASK_MAX_INTER_COLLISION_VI)
#define BIT_SET_MAX_INTER_COLLISION_VI(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_VI(x) | BIT_MAX_INTER_COLLISION_VI(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_THR (Offset 0x0538) */
#define BIT_SHIFT_VO_QUEUE_THR 0
#define BIT_MASK_VO_QUEUE_THR 0xff
#define BIT_VO_QUEUE_THR(x) \
(((x) & BIT_MASK_VO_QUEUE_THR) << BIT_SHIFT_VO_QUEUE_THR)
#define BITS_VO_QUEUE_THR (BIT_MASK_VO_QUEUE_THR << BIT_SHIFT_VO_QUEUE_THR)
#define BIT_CLEAR_VO_QUEUE_THR(x) ((x) & (~BITS_VO_QUEUE_THR))
#define BIT_GET_VO_QUEUE_THR(x) \
(((x) >> BIT_SHIFT_VO_QUEUE_THR) & BIT_MASK_VO_QUEUE_THR)
#define BIT_SET_VO_QUEUE_THR(x, v) \
(BIT_CLEAR_VO_QUEUE_THR(x) | BIT_VO_QUEUE_THR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION (Offset 0x0538) */
#define BIT_SHIFT_MAX_INTER_COLLISION_VO 0
#define BIT_MASK_MAX_INTER_COLLISION_VO 0xff
#define BIT_MAX_INTER_COLLISION_VO(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_VO) \
<< BIT_SHIFT_MAX_INTER_COLLISION_VO)
#define BITS_MAX_INTER_COLLISION_VO \
(BIT_MASK_MAX_INTER_COLLISION_VO << BIT_SHIFT_MAX_INTER_COLLISION_VO)
#define BIT_CLEAR_MAX_INTER_COLLISION_VO(x) \
((x) & (~BITS_MAX_INTER_COLLISION_VO))
#define BIT_GET_MAX_INTER_COLLISION_VO(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_VO) & \
BIT_MASK_MAX_INTER_COLLISION_VO)
#define BIT_SET_MAX_INTER_COLLISION_VO(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_VO(x) | BIT_MAX_INTER_COLLISION_VO(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_QUEUE_INCOL_EN BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION_CNT (Offset 0x053C) */
#define BIT_MAX_INTER_COLLISION_EN BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_SHIFT_BK_TRIGGER_NUM_V1 12
#define BIT_MASK_BK_TRIGGER_NUM_V1 0xf
#define BIT_BK_TRIGGER_NUM_V1(x) \
(((x) & BIT_MASK_BK_TRIGGER_NUM_V1) << BIT_SHIFT_BK_TRIGGER_NUM_V1)
#define BITS_BK_TRIGGER_NUM_V1 \
(BIT_MASK_BK_TRIGGER_NUM_V1 << BIT_SHIFT_BK_TRIGGER_NUM_V1)
#define BIT_CLEAR_BK_TRIGGER_NUM_V1(x) ((x) & (~BITS_BK_TRIGGER_NUM_V1))
#define BIT_GET_BK_TRIGGER_NUM_V1(x) \
(((x) >> BIT_SHIFT_BK_TRIGGER_NUM_V1) & BIT_MASK_BK_TRIGGER_NUM_V1)
#define BIT_SET_BK_TRIGGER_NUM_V1(x, v) \
(BIT_CLEAR_BK_TRIGGER_NUM_V1(x) | BIT_BK_TRIGGER_NUM_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION_CNT (Offset 0x053C) */
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK 12
#define BIT_MASK_MAX_INTER_COLLISION_CNT_BK 0xf
#define BIT_MAX_INTER_COLLISION_CNT_BK(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_BK) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK)
#define BITS_MAX_INTER_COLLISION_CNT_BK \
(BIT_MASK_MAX_INTER_COLLISION_CNT_BK \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_BK(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_BK))
#define BIT_GET_MAX_INTER_COLLISION_CNT_BK(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_BK)
#define BIT_SET_MAX_INTER_COLLISION_CNT_BK(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_BK(x) | \
BIT_MAX_INTER_COLLISION_CNT_BK(v))
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_SHIFT_BE_TRIGGER_NUM 12
#define BIT_MASK_BE_TRIGGER_NUM 0xf
#define BIT_BE_TRIGGER_NUM(x) \
(((x) & BIT_MASK_BE_TRIGGER_NUM) << BIT_SHIFT_BE_TRIGGER_NUM)
#define BITS_BE_TRIGGER_NUM \
(BIT_MASK_BE_TRIGGER_NUM << BIT_SHIFT_BE_TRIGGER_NUM)
#define BIT_CLEAR_BE_TRIGGER_NUM(x) ((x) & (~BITS_BE_TRIGGER_NUM))
#define BIT_GET_BE_TRIGGER_NUM(x) \
(((x) >> BIT_SHIFT_BE_TRIGGER_NUM) & BIT_MASK_BE_TRIGGER_NUM)
#define BIT_SET_BE_TRIGGER_NUM(x, v) \
(BIT_CLEAR_BE_TRIGGER_NUM(x) | BIT_BE_TRIGGER_NUM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_SHIFT_BE_TRIGGER_NUM_V1 8
#define BIT_MASK_BE_TRIGGER_NUM_V1 0xf
#define BIT_BE_TRIGGER_NUM_V1(x) \
(((x) & BIT_MASK_BE_TRIGGER_NUM_V1) << BIT_SHIFT_BE_TRIGGER_NUM_V1)
#define BITS_BE_TRIGGER_NUM_V1 \
(BIT_MASK_BE_TRIGGER_NUM_V1 << BIT_SHIFT_BE_TRIGGER_NUM_V1)
#define BIT_CLEAR_BE_TRIGGER_NUM_V1(x) ((x) & (~BITS_BE_TRIGGER_NUM_V1))
#define BIT_GET_BE_TRIGGER_NUM_V1(x) \
(((x) >> BIT_SHIFT_BE_TRIGGER_NUM_V1) & BIT_MASK_BE_TRIGGER_NUM_V1)
#define BIT_SET_BE_TRIGGER_NUM_V1(x, v) \
(BIT_CLEAR_BE_TRIGGER_NUM_V1(x) | BIT_BE_TRIGGER_NUM_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION_CNT (Offset 0x053C) */
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE 8
#define BIT_MASK_MAX_INTER_COLLISION_CNT_BE 0xf
#define BIT_MAX_INTER_COLLISION_CNT_BE(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_BE) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE)
#define BITS_MAX_INTER_COLLISION_CNT_BE \
(BIT_MASK_MAX_INTER_COLLISION_CNT_BE \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_BE(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_BE))
#define BIT_GET_MAX_INTER_COLLISION_CNT_BE(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_BE)
#define BIT_SET_MAX_INTER_COLLISION_CNT_BE(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_BE(x) | \
BIT_MAX_INTER_COLLISION_CNT_BE(v))
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_SHIFT_BK_TRIGGER_NUM 8
#define BIT_MASK_BK_TRIGGER_NUM 0xf
#define BIT_BK_TRIGGER_NUM(x) \
(((x) & BIT_MASK_BK_TRIGGER_NUM) << BIT_SHIFT_BK_TRIGGER_NUM)
#define BITS_BK_TRIGGER_NUM \
(BIT_MASK_BK_TRIGGER_NUM << BIT_SHIFT_BK_TRIGGER_NUM)
#define BIT_CLEAR_BK_TRIGGER_NUM(x) ((x) & (~BITS_BK_TRIGGER_NUM))
#define BIT_GET_BK_TRIGGER_NUM(x) \
(((x) >> BIT_SHIFT_BK_TRIGGER_NUM) & BIT_MASK_BK_TRIGGER_NUM)
#define BIT_SET_BK_TRIGGER_NUM(x, v) \
(BIT_CLEAR_BK_TRIGGER_NUM(x) | BIT_BK_TRIGGER_NUM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_SHIFT_VI_TRIGGER_NUM 4
#define BIT_MASK_VI_TRIGGER_NUM 0xf
#define BIT_VI_TRIGGER_NUM(x) \
(((x) & BIT_MASK_VI_TRIGGER_NUM) << BIT_SHIFT_VI_TRIGGER_NUM)
#define BITS_VI_TRIGGER_NUM \
(BIT_MASK_VI_TRIGGER_NUM << BIT_SHIFT_VI_TRIGGER_NUM)
#define BIT_CLEAR_VI_TRIGGER_NUM(x) ((x) & (~BITS_VI_TRIGGER_NUM))
#define BIT_GET_VI_TRIGGER_NUM(x) \
(((x) >> BIT_SHIFT_VI_TRIGGER_NUM) & BIT_MASK_VI_TRIGGER_NUM)
#define BIT_SET_VI_TRIGGER_NUM(x, v) \
(BIT_CLEAR_VI_TRIGGER_NUM(x) | BIT_VI_TRIGGER_NUM(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION_CNT (Offset 0x053C) */
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI 4
#define BIT_MASK_MAX_INTER_COLLISION_CNT_VI 0xf
#define BIT_MAX_INTER_COLLISION_CNT_VI(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_VI) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI)
#define BITS_MAX_INTER_COLLISION_CNT_VI \
(BIT_MASK_MAX_INTER_COLLISION_CNT_VI \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_VI(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_VI))
#define BIT_GET_MAX_INTER_COLLISION_CNT_VI(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_VI)
#define BIT_SET_MAX_INTER_COLLISION_CNT_VI(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_VI(x) | \
BIT_MAX_INTER_COLLISION_CNT_VI(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_QUEUE_INCOL_EN (Offset 0x053C) */
#define BIT_SHIFT_VO_TRIGGER_NUM 0
#define BIT_MASK_VO_TRIGGER_NUM 0xf
#define BIT_VO_TRIGGER_NUM(x) \
(((x) & BIT_MASK_VO_TRIGGER_NUM) << BIT_SHIFT_VO_TRIGGER_NUM)
#define BITS_VO_TRIGGER_NUM \
(BIT_MASK_VO_TRIGGER_NUM << BIT_SHIFT_VO_TRIGGER_NUM)
#define BIT_CLEAR_VO_TRIGGER_NUM(x) ((x) & (~BITS_VO_TRIGGER_NUM))
#define BIT_GET_VO_TRIGGER_NUM(x) \
(((x) >> BIT_SHIFT_VO_TRIGGER_NUM) & BIT_MASK_VO_TRIGGER_NUM)
#define BIT_SET_VO_TRIGGER_NUM(x, v) \
(BIT_CLEAR_VO_TRIGGER_NUM(x) | BIT_VO_TRIGGER_NUM(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAX_INTER_COLLISION_CNT (Offset 0x053C) */
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO 0
#define BIT_MASK_MAX_INTER_COLLISION_CNT_VO 0xf
#define BIT_MAX_INTER_COLLISION_CNT_VO(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_VO) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO)
#define BITS_MAX_INTER_COLLISION_CNT_VO \
(BIT_MASK_MAX_INTER_COLLISION_CNT_VO \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_VO(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_VO))
#define BIT_GET_MAX_INTER_COLLISION_CNT_VO(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_VO)
#define BIT_SET_MAX_INTER_COLLISION_CNT_VO(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_VO(x) | \
BIT_MAX_INTER_COLLISION_CNT_VO(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TBTT_PROHIBIT (Offset 0x0540) */
#define BIT_SHIFT_TBTT_HOLD_TIME_AP 8
#define BIT_MASK_TBTT_HOLD_TIME_AP 0xfff
#define BIT_TBTT_HOLD_TIME_AP(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_AP) << BIT_SHIFT_TBTT_HOLD_TIME_AP)
#define BITS_TBTT_HOLD_TIME_AP \
(BIT_MASK_TBTT_HOLD_TIME_AP << BIT_SHIFT_TBTT_HOLD_TIME_AP)
#define BIT_CLEAR_TBTT_HOLD_TIME_AP(x) ((x) & (~BITS_TBTT_HOLD_TIME_AP))
#define BIT_GET_TBTT_HOLD_TIME_AP(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_AP) & BIT_MASK_TBTT_HOLD_TIME_AP)
#define BIT_SET_TBTT_HOLD_TIME_AP(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_AP(x) | BIT_TBTT_HOLD_TIME_AP(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TBTT_PROHIBIT (Offset 0x0540) */
#define BIT_SHIFT_TBTT_HOLD_TIME_INFRA 4
#define BIT_MASK_TBTT_HOLD_TIME_INFRA 0xf
#define BIT_TBTT_HOLD_TIME_INFRA(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_INFRA) \
<< BIT_SHIFT_TBTT_HOLD_TIME_INFRA)
#define BITS_TBTT_HOLD_TIME_INFRA \
(BIT_MASK_TBTT_HOLD_TIME_INFRA << BIT_SHIFT_TBTT_HOLD_TIME_INFRA)
#define BIT_CLEAR_TBTT_HOLD_TIME_INFRA(x) ((x) & (~BITS_TBTT_HOLD_TIME_INFRA))
#define BIT_GET_TBTT_HOLD_TIME_INFRA(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_INFRA) & \
BIT_MASK_TBTT_HOLD_TIME_INFRA)
#define BIT_SET_TBTT_HOLD_TIME_INFRA(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_INFRA(x) | BIT_TBTT_HOLD_TIME_INFRA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_P2PPS_STATE (Offset 0x0543) */
#define BIT_POWER_STATE BIT(7)
#define BIT_CTWINDOW_ON BIT(6)
#define BIT_BEACON_AREA_ON BIT(5)
#define BIT_CTWIN_EARLY_DISTX BIT(4)
#define BIT_NOA1_OFF_PERIOD BIT(3)
#define BIT_FORCE_DOZE1 BIT(2)
#define BIT_NOA0_OFF_PERIOD BIT(1)
#define BIT_FORCE_DOZE0 BIT(0)
/* 2 REG_RD_NAV_NXT (Offset 0x0544) */
#define BIT_SHIFT_RD_NAV_PROT_NXT 0
#define BIT_MASK_RD_NAV_PROT_NXT 0xffff
#define BIT_RD_NAV_PROT_NXT(x) \
(((x) & BIT_MASK_RD_NAV_PROT_NXT) << BIT_SHIFT_RD_NAV_PROT_NXT)
#define BITS_RD_NAV_PROT_NXT \
(BIT_MASK_RD_NAV_PROT_NXT << BIT_SHIFT_RD_NAV_PROT_NXT)
#define BIT_CLEAR_RD_NAV_PROT_NXT(x) ((x) & (~BITS_RD_NAV_PROT_NXT))
#define BIT_GET_RD_NAV_PROT_NXT(x) \
(((x) >> BIT_SHIFT_RD_NAV_PROT_NXT) & BIT_MASK_RD_NAV_PROT_NXT)
#define BIT_SET_RD_NAV_PROT_NXT(x, v) \
(BIT_CLEAR_RD_NAV_PROT_NXT(x) | BIT_RD_NAV_PROT_NXT(v))
/* 2 REG_NAV_PROT_LEN (Offset 0x0546) */
#define BIT_SHIFT_NAV_PROT_LEN 0
#define BIT_MASK_NAV_PROT_LEN 0xffff
#define BIT_NAV_PROT_LEN(x) \
(((x) & BIT_MASK_NAV_PROT_LEN) << BIT_SHIFT_NAV_PROT_LEN)
#define BITS_NAV_PROT_LEN (BIT_MASK_NAV_PROT_LEN << BIT_SHIFT_NAV_PROT_LEN)
#define BIT_CLEAR_NAV_PROT_LEN(x) ((x) & (~BITS_NAV_PROT_LEN))
#define BIT_GET_NAV_PROT_LEN(x) \
(((x) >> BIT_SHIFT_NAV_PROT_LEN) & BIT_MASK_NAV_PROT_LEN)
#define BIT_SET_NAV_PROT_LEN(x, v) \
(BIT_CLEAR_NAV_PROT_LEN(x) | BIT_NAV_PROT_LEN(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FTM_CTRL (Offset 0x0548) */
#define BIT_SHIFT_FTM_TSF_R2T_PORT 22
#define BIT_MASK_FTM_TSF_R2T_PORT 0x7
#define BIT_FTM_TSF_R2T_PORT(x) \
(((x) & BIT_MASK_FTM_TSF_R2T_PORT) << BIT_SHIFT_FTM_TSF_R2T_PORT)
#define BITS_FTM_TSF_R2T_PORT \
(BIT_MASK_FTM_TSF_R2T_PORT << BIT_SHIFT_FTM_TSF_R2T_PORT)
#define BIT_CLEAR_FTM_TSF_R2T_PORT(x) ((x) & (~BITS_FTM_TSF_R2T_PORT))
#define BIT_GET_FTM_TSF_R2T_PORT(x) \
(((x) >> BIT_SHIFT_FTM_TSF_R2T_PORT) & BIT_MASK_FTM_TSF_R2T_PORT)
#define BIT_SET_FTM_TSF_R2T_PORT(x, v) \
(BIT_CLEAR_FTM_TSF_R2T_PORT(x) | BIT_FTM_TSF_R2T_PORT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTM_PTT (Offset 0x0548) */
#define BIT_SHIFT_FTM_PTT_TSF_R2T_SEL 22
#define BIT_MASK_FTM_PTT_TSF_R2T_SEL 0x7
#define BIT_FTM_PTT_TSF_R2T_SEL(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_R2T_SEL) << BIT_SHIFT_FTM_PTT_TSF_R2T_SEL)
#define BITS_FTM_PTT_TSF_R2T_SEL \
(BIT_MASK_FTM_PTT_TSF_R2T_SEL << BIT_SHIFT_FTM_PTT_TSF_R2T_SEL)
#define BIT_CLEAR_FTM_PTT_TSF_R2T_SEL(x) ((x) & (~BITS_FTM_PTT_TSF_R2T_SEL))
#define BIT_GET_FTM_PTT_TSF_R2T_SEL(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_R2T_SEL) & BIT_MASK_FTM_PTT_TSF_R2T_SEL)
#define BIT_SET_FTM_PTT_TSF_R2T_SEL(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_R2T_SEL(x) | BIT_FTM_PTT_TSF_R2T_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FTM_CTRL (Offset 0x0548) */
#define BIT_SHIFT_FTM_TSF_T2R_PORT 19
#define BIT_MASK_FTM_TSF_T2R_PORT 0x7
#define BIT_FTM_TSF_T2R_PORT(x) \
(((x) & BIT_MASK_FTM_TSF_T2R_PORT) << BIT_SHIFT_FTM_TSF_T2R_PORT)
#define BITS_FTM_TSF_T2R_PORT \
(BIT_MASK_FTM_TSF_T2R_PORT << BIT_SHIFT_FTM_TSF_T2R_PORT)
#define BIT_CLEAR_FTM_TSF_T2R_PORT(x) ((x) & (~BITS_FTM_TSF_T2R_PORT))
#define BIT_GET_FTM_TSF_T2R_PORT(x) \
(((x) >> BIT_SHIFT_FTM_TSF_T2R_PORT) & BIT_MASK_FTM_TSF_T2R_PORT)
#define BIT_SET_FTM_TSF_T2R_PORT(x, v) \
(BIT_CLEAR_FTM_TSF_T2R_PORT(x) | BIT_FTM_TSF_T2R_PORT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTM_PTT (Offset 0x0548) */
#define BIT_SHIFT_FTM_PTT_TSF_T2R_SEL 19
#define BIT_MASK_FTM_PTT_TSF_T2R_SEL 0x7
#define BIT_FTM_PTT_TSF_T2R_SEL(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_T2R_SEL) << BIT_SHIFT_FTM_PTT_TSF_T2R_SEL)
#define BITS_FTM_PTT_TSF_T2R_SEL \
(BIT_MASK_FTM_PTT_TSF_T2R_SEL << BIT_SHIFT_FTM_PTT_TSF_T2R_SEL)
#define BIT_CLEAR_FTM_PTT_TSF_T2R_SEL(x) ((x) & (~BITS_FTM_PTT_TSF_T2R_SEL))
#define BIT_GET_FTM_PTT_TSF_T2R_SEL(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_T2R_SEL) & BIT_MASK_FTM_PTT_TSF_T2R_SEL)
#define BIT_SET_FTM_PTT_TSF_T2R_SEL(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_T2R_SEL(x) | BIT_FTM_PTT_TSF_T2R_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FTM_CTRL (Offset 0x0548) */
#define BIT_SHIFT_FTM_PTT_PORT 16
#define BIT_MASK_FTM_PTT_PORT 0x7
#define BIT_FTM_PTT_PORT(x) \
(((x) & BIT_MASK_FTM_PTT_PORT) << BIT_SHIFT_FTM_PTT_PORT)
#define BITS_FTM_PTT_PORT (BIT_MASK_FTM_PTT_PORT << BIT_SHIFT_FTM_PTT_PORT)
#define BIT_CLEAR_FTM_PTT_PORT(x) ((x) & (~BITS_FTM_PTT_PORT))
#define BIT_GET_FTM_PTT_PORT(x) \
(((x) >> BIT_SHIFT_FTM_PTT_PORT) & BIT_MASK_FTM_PTT_PORT)
#define BIT_SET_FTM_PTT_PORT(x, v) \
(BIT_CLEAR_FTM_PTT_PORT(x) | BIT_FTM_PTT_PORT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTM_PTT (Offset 0x0548) */
#define BIT_SHIFT_FTM_PTT_TSF_SEL 16
#define BIT_MASK_FTM_PTT_TSF_SEL 0x7
#define BIT_FTM_PTT_TSF_SEL(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_SEL) << BIT_SHIFT_FTM_PTT_TSF_SEL)
#define BITS_FTM_PTT_TSF_SEL \
(BIT_MASK_FTM_PTT_TSF_SEL << BIT_SHIFT_FTM_PTT_TSF_SEL)
#define BIT_CLEAR_FTM_PTT_TSF_SEL(x) ((x) & (~BITS_FTM_PTT_TSF_SEL))
#define BIT_GET_FTM_PTT_TSF_SEL(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_SEL) & BIT_MASK_FTM_PTT_TSF_SEL)
#define BIT_SET_FTM_PTT_TSF_SEL(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_SEL(x) | BIT_FTM_PTT_TSF_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_FTM_CTRL (Offset 0x0548) */
#define BIT_SHIFT_FTM_PTT 0
#define BIT_MASK_FTM_PTT 0xffff
#define BIT_FTM_PTT(x) (((x) & BIT_MASK_FTM_PTT) << BIT_SHIFT_FTM_PTT)
#define BITS_FTM_PTT (BIT_MASK_FTM_PTT << BIT_SHIFT_FTM_PTT)
#define BIT_CLEAR_FTM_PTT(x) ((x) & (~BITS_FTM_PTT))
#define BIT_GET_FTM_PTT(x) (((x) >> BIT_SHIFT_FTM_PTT) & BIT_MASK_FTM_PTT)
#define BIT_SET_FTM_PTT(x, v) (BIT_CLEAR_FTM_PTT(x) | BIT_FTM_PTT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTM_PTT (Offset 0x0548) */
#define BIT_SHIFT_FTM_PTT_VALUE 0
#define BIT_MASK_FTM_PTT_VALUE 0xffff
#define BIT_FTM_PTT_VALUE(x) \
(((x) & BIT_MASK_FTM_PTT_VALUE) << BIT_SHIFT_FTM_PTT_VALUE)
#define BITS_FTM_PTT_VALUE (BIT_MASK_FTM_PTT_VALUE << BIT_SHIFT_FTM_PTT_VALUE)
#define BIT_CLEAR_FTM_PTT_VALUE(x) ((x) & (~BITS_FTM_PTT_VALUE))
#define BIT_GET_FTM_PTT_VALUE(x) \
(((x) >> BIT_SHIFT_FTM_PTT_VALUE) & BIT_MASK_FTM_PTT_VALUE)
#define BIT_SET_FTM_PTT_VALUE(x, v) \
(BIT_CLEAR_FTM_PTT_VALUE(x) | BIT_FTM_PTT_VALUE(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_FTM_TSF_CNT (Offset 0x054C) */
#define BIT_SHIFT_FTM_TSF_R2T 16
#define BIT_MASK_FTM_TSF_R2T 0xffff
#define BIT_FTM_TSF_R2T(x) \
(((x) & BIT_MASK_FTM_TSF_R2T) << BIT_SHIFT_FTM_TSF_R2T)
#define BITS_FTM_TSF_R2T (BIT_MASK_FTM_TSF_R2T << BIT_SHIFT_FTM_TSF_R2T)
#define BIT_CLEAR_FTM_TSF_R2T(x) ((x) & (~BITS_FTM_TSF_R2T))
#define BIT_GET_FTM_TSF_R2T(x) \
(((x) >> BIT_SHIFT_FTM_TSF_R2T) & BIT_MASK_FTM_TSF_R2T)
#define BIT_SET_FTM_TSF_R2T(x, v) \
(BIT_CLEAR_FTM_TSF_R2T(x) | BIT_FTM_TSF_R2T(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTM_TSF (Offset 0x054C) */
#define BIT_SHIFT_FTM_T2_TSF 16
#define BIT_MASK_FTM_T2_TSF 0xffff
#define BIT_FTM_T2_TSF(x) (((x) & BIT_MASK_FTM_T2_TSF) << BIT_SHIFT_FTM_T2_TSF)
#define BITS_FTM_T2_TSF (BIT_MASK_FTM_T2_TSF << BIT_SHIFT_FTM_T2_TSF)
#define BIT_CLEAR_FTM_T2_TSF(x) ((x) & (~BITS_FTM_T2_TSF))
#define BIT_GET_FTM_T2_TSF(x) \
(((x) >> BIT_SHIFT_FTM_T2_TSF) & BIT_MASK_FTM_T2_TSF)
#define BIT_SET_FTM_T2_TSF(x, v) (BIT_CLEAR_FTM_T2_TSF(x) | BIT_FTM_T2_TSF(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_FTM_TSF_CNT (Offset 0x054C) */
#define BIT_SHIFT_FTM_TSF_T2R 0
#define BIT_MASK_FTM_TSF_T2R 0xffff
#define BIT_FTM_TSF_T2R(x) \
(((x) & BIT_MASK_FTM_TSF_T2R) << BIT_SHIFT_FTM_TSF_T2R)
#define BITS_FTM_TSF_T2R (BIT_MASK_FTM_TSF_T2R << BIT_SHIFT_FTM_TSF_T2R)
#define BIT_CLEAR_FTM_TSF_T2R(x) ((x) & (~BITS_FTM_TSF_T2R))
#define BIT_GET_FTM_TSF_T2R(x) \
(((x) >> BIT_SHIFT_FTM_TSF_T2R) & BIT_MASK_FTM_TSF_T2R)
#define BIT_SET_FTM_TSF_T2R(x, v) \
(BIT_CLEAR_FTM_TSF_T2R(x) | BIT_FTM_TSF_T2R(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FTM_TSF (Offset 0x054C) */
#define BIT_SHIFT_FTM_T1_TSF 0
#define BIT_MASK_FTM_T1_TSF 0xffff
#define BIT_FTM_T1_TSF(x) (((x) & BIT_MASK_FTM_T1_TSF) << BIT_SHIFT_FTM_T1_TSF)
#define BITS_FTM_T1_TSF (BIT_MASK_FTM_T1_TSF << BIT_SHIFT_FTM_T1_TSF)
#define BIT_CLEAR_FTM_T1_TSF(x) ((x) & (~BITS_FTM_T1_TSF))
#define BIT_GET_FTM_T1_TSF(x) \
(((x) >> BIT_SHIFT_FTM_T1_TSF) & BIT_MASK_FTM_T1_TSF)
#define BIT_SET_FTM_T1_TSF(x, v) (BIT_CLEAR_FTM_T1_TSF(x) | BIT_FTM_T1_TSF(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL (Offset 0x0550) */
#define BIT_P0_EN_TXBCN_RPT BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL (Offset 0x0550) */
#define BIT_EN_BCN_FUNCTION BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL (Offset 0x0550) */
#define BIT_EN_TXBCN_RPT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL (Offset 0x0550) */
#define BIT_P0_EN_RXBCN_RPT BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL (Offset 0x0550) */
#define BIT_DIS_BCNQ_SUB BIT(1)
/* 2 REG_BCN_CTRL1 (Offset 0x0551) */
#define BIT_DIS_RX_BSSID_FIT1 BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT0 (Offset 0x0551) */
#define BIT_CLI0_DIS_RX_BSSID_FIT BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL1 (Offset 0x0551) */
#define BIT_DIS_TSF1_UDT BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT0 (Offset 0x0551) */
#define BIT_CLI0_DIS_TSF_UDT BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL1 (Offset 0x0551) */
#define BIT_EN_BCN1_FUNCTION BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT0 (Offset 0x0551) */
#define BIT_CLI0_EN_BCN_FUNCTION BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL1 (Offset 0x0551) */
#define BIT_EN_TXBCN1_RPT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT0 (Offset 0x0551) */
#define BIT_CLI0_EN_RXBCN_RPT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT0 (Offset 0x0551) */
#define BIT_CLI0_EN_BCN_RPT BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_CTRL1 (Offset 0x0551) */
#define BIT_DIS_BCNQ1_SUB BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT0 (Offset 0x0551) */
#define BIT_CLI0_ENP2P_CTWINDOW BIT(1)
#define BIT_CLI0_ENP2P_BCNQ_AREA BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MBID_NUM (Offset 0x0552) */
#define BIT_SHIFT_MBID_BCN_NUM_V2 4
#define BIT_MASK_MBID_BCN_NUM_V2 0xf
#define BIT_MBID_BCN_NUM_V2(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_V2) << BIT_SHIFT_MBID_BCN_NUM_V2)
#define BITS_MBID_BCN_NUM_V2 \
(BIT_MASK_MBID_BCN_NUM_V2 << BIT_SHIFT_MBID_BCN_NUM_V2)
#define BIT_CLEAR_MBID_BCN_NUM_V2(x) ((x) & (~BITS_MBID_BCN_NUM_V2))
#define BIT_GET_MBID_BCN_NUM_V2(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_V2) & BIT_MASK_MBID_BCN_NUM_V2)
#define BIT_SET_MBID_BCN_NUM_V2(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_V2(x) | BIT_MBID_BCN_NUM_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBID_NUM (Offset 0x0552) */
#define BIT_EN_PRE_DL_BEACON BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_MBID_NUM (Offset 0x0552) */
#define BIT_SHIFT_MBID_BCN_NUM 0
#define BIT_MASK_MBID_BCN_NUM 0x7
#define BIT_MBID_BCN_NUM(x) \
(((x) & BIT_MASK_MBID_BCN_NUM) << BIT_SHIFT_MBID_BCN_NUM)
#define BITS_MBID_BCN_NUM (BIT_MASK_MBID_BCN_NUM << BIT_SHIFT_MBID_BCN_NUM)
#define BIT_CLEAR_MBID_BCN_NUM(x) ((x) & (~BITS_MBID_BCN_NUM))
#define BIT_GET_MBID_BCN_NUM(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM) & BIT_MASK_MBID_BCN_NUM)
#define BIT_SET_MBID_BCN_NUM(x, v) \
(BIT_CLEAR_MBID_BCN_NUM(x) | BIT_MBID_BCN_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_P2P_PWR_RST1 BIT(6)
#define BIT_SCHEDULER_RST BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_FREECNT_RST BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_P2P_PWR_RST0 BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR_CLI3_RST BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR1_SYNC_EN BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR_CLI2_RST BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR_SYNC_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR_CLI1_RST BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR1_RST BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR_CLI0_RST BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DUAL_TSF_RST (Offset 0x0553) */
#define BIT_TSFTR_RST BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBSSID_BCN_SPACE (Offset 0x0554) */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD 28
#define BIT_MASK_BCN_TIMER_SEL_FWRD 0x7
#define BIT_BCN_TIMER_SEL_FWRD(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD) << BIT_SHIFT_BCN_TIMER_SEL_FWRD)
#define BITS_BCN_TIMER_SEL_FWRD \
(BIT_MASK_BCN_TIMER_SEL_FWRD << BIT_SHIFT_BCN_TIMER_SEL_FWRD)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD(x) ((x) & (~BITS_BCN_TIMER_SEL_FWRD))
#define BIT_GET_BCN_TIMER_SEL_FWRD(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD) & BIT_MASK_BCN_TIMER_SEL_FWRD)
#define BIT_SET_BCN_TIMER_SEL_FWRD(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD(x) | BIT_BCN_TIMER_SEL_FWRD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBSSID_BCN_SPACE (Offset 0x0554) */
#define BIT_SHIFT_BCN_SPACE1 16
#define BIT_MASK_BCN_SPACE1 0xffff
#define BIT_BCN_SPACE1(x) (((x) & BIT_MASK_BCN_SPACE1) << BIT_SHIFT_BCN_SPACE1)
#define BITS_BCN_SPACE1 (BIT_MASK_BCN_SPACE1 << BIT_SHIFT_BCN_SPACE1)
#define BIT_CLEAR_BCN_SPACE1(x) ((x) & (~BITS_BCN_SPACE1))
#define BIT_GET_BCN_SPACE1(x) \
(((x) >> BIT_SHIFT_BCN_SPACE1) & BIT_MASK_BCN_SPACE1)
#define BIT_SET_BCN_SPACE1(x, v) (BIT_CLEAR_BCN_SPACE1(x) | BIT_BCN_SPACE1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBSSID_BCN_SPACE (Offset 0x0554) */
#define BIT_SHIFT_BCN_SPACE_CLINT0 16
#define BIT_MASK_BCN_SPACE_CLINT0 0xfff
#define BIT_BCN_SPACE_CLINT0(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT0) << BIT_SHIFT_BCN_SPACE_CLINT0)
#define BITS_BCN_SPACE_CLINT0 \
(BIT_MASK_BCN_SPACE_CLINT0 << BIT_SHIFT_BCN_SPACE_CLINT0)
#define BIT_CLEAR_BCN_SPACE_CLINT0(x) ((x) & (~BITS_BCN_SPACE_CLINT0))
#define BIT_GET_BCN_SPACE_CLINT0(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT0) & BIT_MASK_BCN_SPACE_CLINT0)
#define BIT_SET_BCN_SPACE_CLINT0(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT0(x) | BIT_BCN_SPACE_CLINT0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBSSID_BCN_SPACE (Offset 0x0554) */
#define BIT_SHIFT_BCN_SPACE0 0
#define BIT_MASK_BCN_SPACE0 0xffff
#define BIT_BCN_SPACE0(x) (((x) & BIT_MASK_BCN_SPACE0) << BIT_SHIFT_BCN_SPACE0)
#define BITS_BCN_SPACE0 (BIT_MASK_BCN_SPACE0 << BIT_SHIFT_BCN_SPACE0)
#define BIT_CLEAR_BCN_SPACE0(x) ((x) & (~BITS_BCN_SPACE0))
#define BIT_GET_BCN_SPACE0(x) \
(((x) >> BIT_SHIFT_BCN_SPACE0) & BIT_MASK_BCN_SPACE0)
#define BIT_SET_BCN_SPACE0(x, v) (BIT_CLEAR_BCN_SPACE0(x) | BIT_BCN_SPACE0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND (Offset 0x055A) */
#define BIT_SHIFT_ATIMWND 0
#define BIT_MASK_ATIMWND 0xffff
#define BIT_ATIMWND(x) (((x) & BIT_MASK_ATIMWND) << BIT_SHIFT_ATIMWND)
#define BITS_ATIMWND (BIT_MASK_ATIMWND << BIT_SHIFT_ATIMWND)
#define BIT_CLEAR_ATIMWND(x) ((x) & (~BITS_ATIMWND))
#define BIT_GET_ATIMWND(x) (((x) >> BIT_SHIFT_ATIMWND) & BIT_MASK_ATIMWND)
#define BIT_SET_ATIMWND(x, v) (BIT_CLEAR_ATIMWND(x) | BIT_ATIMWND(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ATIMWND (Offset 0x055A) */
#define BIT_SHIFT_ATIMWND0 0
#define BIT_MASK_ATIMWND0 0xffff
#define BIT_ATIMWND0(x) (((x) & BIT_MASK_ATIMWND0) << BIT_SHIFT_ATIMWND0)
#define BITS_ATIMWND0 (BIT_MASK_ATIMWND0 << BIT_SHIFT_ATIMWND0)
#define BIT_CLEAR_ATIMWND0(x) ((x) & (~BITS_ATIMWND0))
#define BIT_GET_ATIMWND0(x) (((x) >> BIT_SHIFT_ATIMWND0) & BIT_MASK_ATIMWND0)
#define BIT_SET_ATIMWND0(x, v) (BIT_CLEAR_ATIMWND0(x) | BIT_ATIMWND0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_USTIME_TSF (Offset 0x055C) */
#define BIT_SHIFT_USTIME_TSF_V1 0
#define BIT_MASK_USTIME_TSF_V1 0xff
#define BIT_USTIME_TSF_V1(x) \
(((x) & BIT_MASK_USTIME_TSF_V1) << BIT_SHIFT_USTIME_TSF_V1)
#define BITS_USTIME_TSF_V1 (BIT_MASK_USTIME_TSF_V1 << BIT_SHIFT_USTIME_TSF_V1)
#define BIT_CLEAR_USTIME_TSF_V1(x) ((x) & (~BITS_USTIME_TSF_V1))
#define BIT_GET_USTIME_TSF_V1(x) \
(((x) >> BIT_SHIFT_USTIME_TSF_V1) & BIT_MASK_USTIME_TSF_V1)
#define BIT_SET_USTIME_TSF_V1(x, v) \
(BIT_CLEAR_USTIME_TSF_V1(x) | BIT_USTIME_TSF_V1(v))
/* 2 REG_BCN_MAX_ERR (Offset 0x055D) */
#define BIT_SHIFT_BCN_MAX_ERR 0
#define BIT_MASK_BCN_MAX_ERR 0xff
#define BIT_BCN_MAX_ERR(x) \
(((x) & BIT_MASK_BCN_MAX_ERR) << BIT_SHIFT_BCN_MAX_ERR)
#define BITS_BCN_MAX_ERR (BIT_MASK_BCN_MAX_ERR << BIT_SHIFT_BCN_MAX_ERR)
#define BIT_CLEAR_BCN_MAX_ERR(x) ((x) & (~BITS_BCN_MAX_ERR))
#define BIT_GET_BCN_MAX_ERR(x) \
(((x) >> BIT_SHIFT_BCN_MAX_ERR) & BIT_MASK_BCN_MAX_ERR)
#define BIT_SET_BCN_MAX_ERR(x, v) \
(BIT_CLEAR_BCN_MAX_ERR(x) | BIT_BCN_MAX_ERR(v))
/* 2 REG_RXTSF_OFFSET_CCK (Offset 0x055E) */
#define BIT_SHIFT_CCK_RXTSF_OFFSET 0
#define BIT_MASK_CCK_RXTSF_OFFSET 0xff
#define BIT_CCK_RXTSF_OFFSET(x) \
(((x) & BIT_MASK_CCK_RXTSF_OFFSET) << BIT_SHIFT_CCK_RXTSF_OFFSET)
#define BITS_CCK_RXTSF_OFFSET \
(BIT_MASK_CCK_RXTSF_OFFSET << BIT_SHIFT_CCK_RXTSF_OFFSET)
#define BIT_CLEAR_CCK_RXTSF_OFFSET(x) ((x) & (~BITS_CCK_RXTSF_OFFSET))
#define BIT_GET_CCK_RXTSF_OFFSET(x) \
(((x) >> BIT_SHIFT_CCK_RXTSF_OFFSET) & BIT_MASK_CCK_RXTSF_OFFSET)
#define BIT_SET_CCK_RXTSF_OFFSET(x, v) \
(BIT_CLEAR_CCK_RXTSF_OFFSET(x) | BIT_CCK_RXTSF_OFFSET(v))
/* 2 REG_RXTSF_OFFSET_OFDM (Offset 0x055F) */
#define BIT_SHIFT_OFDM_RXTSF_OFFSET 0
#define BIT_MASK_OFDM_RXTSF_OFFSET 0xff
#define BIT_OFDM_RXTSF_OFFSET(x) \
(((x) & BIT_MASK_OFDM_RXTSF_OFFSET) << BIT_SHIFT_OFDM_RXTSF_OFFSET)
#define BITS_OFDM_RXTSF_OFFSET \
(BIT_MASK_OFDM_RXTSF_OFFSET << BIT_SHIFT_OFDM_RXTSF_OFFSET)
#define BIT_CLEAR_OFDM_RXTSF_OFFSET(x) ((x) & (~BITS_OFDM_RXTSF_OFFSET))
#define BIT_GET_OFDM_RXTSF_OFFSET(x) \
(((x) >> BIT_SHIFT_OFDM_RXTSF_OFFSET) & BIT_MASK_OFDM_RXTSF_OFFSET)
#define BIT_SET_OFDM_RXTSF_OFFSET(x, v) \
(BIT_CLEAR_OFDM_RXTSF_OFFSET(x) | BIT_OFDM_RXTSF_OFFSET(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TSFTR (Offset 0x0560) */
#define BIT_SHIFT_TSF_TIMER 0
#define BIT_MASK_TSF_TIMER 0xffffffffffffffffL
#define BIT_TSF_TIMER(x) (((x) & BIT_MASK_TSF_TIMER) << BIT_SHIFT_TSF_TIMER)
#define BITS_TSF_TIMER (BIT_MASK_TSF_TIMER << BIT_SHIFT_TSF_TIMER)
#define BIT_CLEAR_TSF_TIMER(x) ((x) & (~BITS_TSF_TIMER))
#define BIT_GET_TSF_TIMER(x) (((x) >> BIT_SHIFT_TSF_TIMER) & BIT_MASK_TSF_TIMER)
#define BIT_SET_TSF_TIMER(x, v) (BIT_CLEAR_TSF_TIMER(x) | BIT_TSF_TIMER(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFTR0_L (Offset 0x0560) */
#define BIT_SHIFT_TSF0_TIMER_L 0
#define BIT_MASK_TSF0_TIMER_L 0xffffffffL
#define BIT_TSF0_TIMER_L(x) \
(((x) & BIT_MASK_TSF0_TIMER_L) << BIT_SHIFT_TSF0_TIMER_L)
#define BITS_TSF0_TIMER_L (BIT_MASK_TSF0_TIMER_L << BIT_SHIFT_TSF0_TIMER_L)
#define BIT_CLEAR_TSF0_TIMER_L(x) ((x) & (~BITS_TSF0_TIMER_L))
#define BIT_GET_TSF0_TIMER_L(x) \
(((x) >> BIT_SHIFT_TSF0_TIMER_L) & BIT_MASK_TSF0_TIMER_L)
#define BIT_SET_TSF0_TIMER_L(x, v) \
(BIT_CLEAR_TSF0_TIMER_L(x) | BIT_TSF0_TIMER_L(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TSFTR (Offset 0x0560) */
#define BIT_SHIFT_TSF_TIMER_V1 0
#define BIT_MASK_TSF_TIMER_V1 0xffffffffL
#define BIT_TSF_TIMER_V1(x) \
(((x) & BIT_MASK_TSF_TIMER_V1) << BIT_SHIFT_TSF_TIMER_V1)
#define BITS_TSF_TIMER_V1 (BIT_MASK_TSF_TIMER_V1 << BIT_SHIFT_TSF_TIMER_V1)
#define BIT_CLEAR_TSF_TIMER_V1(x) ((x) & (~BITS_TSF_TIMER_V1))
#define BIT_GET_TSF_TIMER_V1(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_V1) & BIT_MASK_TSF_TIMER_V1)
#define BIT_SET_TSF_TIMER_V1(x, v) \
(BIT_CLEAR_TSF_TIMER_V1(x) | BIT_TSF_TIMER_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFTR0_H (Offset 0x0564) */
#define BIT_SHIFT_TSF0_TIMER_H 0
#define BIT_MASK_TSF0_TIMER_H 0xffffffffL
#define BIT_TSF0_TIMER_H(x) \
(((x) & BIT_MASK_TSF0_TIMER_H) << BIT_SHIFT_TSF0_TIMER_H)
#define BITS_TSF0_TIMER_H (BIT_MASK_TSF0_TIMER_H << BIT_SHIFT_TSF0_TIMER_H)
#define BIT_CLEAR_TSF0_TIMER_H(x) ((x) & (~BITS_TSF0_TIMER_H))
#define BIT_GET_TSF0_TIMER_H(x) \
(((x) >> BIT_SHIFT_TSF0_TIMER_H) & BIT_MASK_TSF0_TIMER_H)
#define BIT_SET_TSF0_TIMER_H(x, v) \
(BIT_CLEAR_TSF0_TIMER_H(x) | BIT_TSF0_TIMER_H(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TSFTR_1 (Offset 0x0564) */
#define BIT_SHIFT_TSF_TIMER_V2 0
#define BIT_MASK_TSF_TIMER_V2 0xffffffffL
#define BIT_TSF_TIMER_V2(x) \
(((x) & BIT_MASK_TSF_TIMER_V2) << BIT_SHIFT_TSF_TIMER_V2)
#define BITS_TSF_TIMER_V2 (BIT_MASK_TSF_TIMER_V2 << BIT_SHIFT_TSF_TIMER_V2)
#define BIT_CLEAR_TSF_TIMER_V2(x) ((x) & (~BITS_TSF_TIMER_V2))
#define BIT_GET_TSF_TIMER_V2(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_V2) & BIT_MASK_TSF_TIMER_V2)
#define BIT_SET_TSF_TIMER_V2(x, v) \
(BIT_CLEAR_TSF_TIMER_V2(x) | BIT_TSF_TIMER_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TSFTR1 (Offset 0x0568) */
#define BIT_SHIFT_TSF_TIMER1 0
#define BIT_MASK_TSF_TIMER1 0xffffffffffffffffL
#define BIT_TSF_TIMER1(x) (((x) & BIT_MASK_TSF_TIMER1) << BIT_SHIFT_TSF_TIMER1)
#define BITS_TSF_TIMER1 (BIT_MASK_TSF_TIMER1 << BIT_SHIFT_TSF_TIMER1)
#define BIT_CLEAR_TSF_TIMER1(x) ((x) & (~BITS_TSF_TIMER1))
#define BIT_GET_TSF_TIMER1(x) \
(((x) >> BIT_SHIFT_TSF_TIMER1) & BIT_MASK_TSF_TIMER1)
#define BIT_SET_TSF_TIMER1(x, v) (BIT_CLEAR_TSF_TIMER1(x) | BIT_TSF_TIMER1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFTR1_L (Offset 0x0568) */
#define BIT_SHIFT_TSF1_TIMER_L 0
#define BIT_MASK_TSF1_TIMER_L 0xffffffffL
#define BIT_TSF1_TIMER_L(x) \
(((x) & BIT_MASK_TSF1_TIMER_L) << BIT_SHIFT_TSF1_TIMER_L)
#define BITS_TSF1_TIMER_L (BIT_MASK_TSF1_TIMER_L << BIT_SHIFT_TSF1_TIMER_L)
#define BIT_CLEAR_TSF1_TIMER_L(x) ((x) & (~BITS_TSF1_TIMER_L))
#define BIT_GET_TSF1_TIMER_L(x) \
(((x) >> BIT_SHIFT_TSF1_TIMER_L) & BIT_MASK_TSF1_TIMER_L)
#define BIT_SET_TSF1_TIMER_L(x, v) \
(BIT_CLEAR_TSF1_TIMER_L(x) | BIT_TSF1_TIMER_L(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FREERUN_CNT (Offset 0x0568) */
#define BIT_SHIFT_FREERUN_CNT 0
#define BIT_MASK_FREERUN_CNT 0xffffffffffffffffL
#define BIT_FREERUN_CNT(x) \
(((x) & BIT_MASK_FREERUN_CNT) << BIT_SHIFT_FREERUN_CNT)
#define BITS_FREERUN_CNT (BIT_MASK_FREERUN_CNT << BIT_SHIFT_FREERUN_CNT)
#define BIT_CLEAR_FREERUN_CNT(x) ((x) & (~BITS_FREERUN_CNT))
#define BIT_GET_FREERUN_CNT(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT) & BIT_MASK_FREERUN_CNT)
#define BIT_SET_FREERUN_CNT(x, v) \
(BIT_CLEAR_FREERUN_CNT(x) | BIT_FREERUN_CNT(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FREERUN_CNT (Offset 0x0568) */
#define BIT_SHIFT_FREERUN_CNT_V1 0
#define BIT_MASK_FREERUN_CNT_V1 0xffffffffL
#define BIT_FREERUN_CNT_V1(x) \
(((x) & BIT_MASK_FREERUN_CNT_V1) << BIT_SHIFT_FREERUN_CNT_V1)
#define BITS_FREERUN_CNT_V1 \
(BIT_MASK_FREERUN_CNT_V1 << BIT_SHIFT_FREERUN_CNT_V1)
#define BIT_CLEAR_FREERUN_CNT_V1(x) ((x) & (~BITS_FREERUN_CNT_V1))
#define BIT_GET_FREERUN_CNT_V1(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_V1) & BIT_MASK_FREERUN_CNT_V1)
#define BIT_SET_FREERUN_CNT_V1(x, v) \
(BIT_CLEAR_FREERUN_CNT_V1(x) | BIT_FREERUN_CNT_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFTR1_H (Offset 0x056C) */
#define BIT_SHIFT_TSF1_TIMER_H 0
#define BIT_MASK_TSF1_TIMER_H 0xffffffffL
#define BIT_TSF1_TIMER_H(x) \
(((x) & BIT_MASK_TSF1_TIMER_H) << BIT_SHIFT_TSF1_TIMER_H)
#define BITS_TSF1_TIMER_H (BIT_MASK_TSF1_TIMER_H << BIT_SHIFT_TSF1_TIMER_H)
#define BIT_CLEAR_TSF1_TIMER_H(x) ((x) & (~BITS_TSF1_TIMER_H))
#define BIT_GET_TSF1_TIMER_H(x) \
(((x) >> BIT_SHIFT_TSF1_TIMER_H) & BIT_MASK_TSF1_TIMER_H)
#define BIT_SET_TSF1_TIMER_H(x, v) \
(BIT_CLEAR_TSF1_TIMER_H(x) | BIT_TSF1_TIMER_H(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FREERUN_CNT_1 (Offset 0x056C) */
#define BIT_SHIFT_FREERUN_CNT_V2 0
#define BIT_MASK_FREERUN_CNT_V2 0xffffffffL
#define BIT_FREERUN_CNT_V2(x) \
(((x) & BIT_MASK_FREERUN_CNT_V2) << BIT_SHIFT_FREERUN_CNT_V2)
#define BITS_FREERUN_CNT_V2 \
(BIT_MASK_FREERUN_CNT_V2 << BIT_SHIFT_FREERUN_CNT_V2)
#define BIT_CLEAR_FREERUN_CNT_V2(x) ((x) & (~BITS_FREERUN_CNT_V2))
#define BIT_GET_FREERUN_CNT_V2(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_V2) & BIT_MASK_FREERUN_CNT_V2)
#define BIT_SET_FREERUN_CNT_V2(x, v) \
(BIT_CLEAR_FREERUN_CNT_V2(x) | BIT_FREERUN_CNT_V2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND1 (Offset 0x0570) */
#define BIT_SHIFT_ATIMWND1 0
#define BIT_MASK_ATIMWND1 0xffff
#define BIT_ATIMWND1(x) (((x) & BIT_MASK_ATIMWND1) << BIT_SHIFT_ATIMWND1)
#define BITS_ATIMWND1 (BIT_MASK_ATIMWND1 << BIT_SHIFT_ATIMWND1)
#define BIT_CLEAR_ATIMWND1(x) ((x) & (~BITS_ATIMWND1))
#define BIT_GET_ATIMWND1(x) (((x) >> BIT_SHIFT_ATIMWND1) & BIT_MASK_ATIMWND1)
#define BIT_SET_ATIMWND1(x, v) (BIT_CLEAR_ATIMWND1(x) | BIT_ATIMWND1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_ATIMWND1_V1 (Offset 0x0570) */
#define BIT_SHIFT_ATIMWND1_V2 0
#define BIT_MASK_ATIMWND1_V2 0xffff
#define BIT_ATIMWND1_V2(x) \
(((x) & BIT_MASK_ATIMWND1_V2) << BIT_SHIFT_ATIMWND1_V2)
#define BITS_ATIMWND1_V2 (BIT_MASK_ATIMWND1_V2 << BIT_SHIFT_ATIMWND1_V2)
#define BIT_CLEAR_ATIMWND1_V2(x) ((x) & (~BITS_ATIMWND1_V2))
#define BIT_GET_ATIMWND1_V2(x) \
(((x) >> BIT_SHIFT_ATIMWND1_V2) & BIT_MASK_ATIMWND1_V2)
#define BIT_SET_ATIMWND1_V2(x, v) \
(BIT_CLEAR_ATIMWND1_V2(x) | BIT_ATIMWND1_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ATIMWND1_V1 (Offset 0x0570) */
#define BIT_SHIFT_ATIMWND1_V1 0
#define BIT_MASK_ATIMWND1_V1 0xff
#define BIT_ATIMWND1_V1(x) \
(((x) & BIT_MASK_ATIMWND1_V1) << BIT_SHIFT_ATIMWND1_V1)
#define BITS_ATIMWND1_V1 (BIT_MASK_ATIMWND1_V1 << BIT_SHIFT_ATIMWND1_V1)
#define BIT_CLEAR_ATIMWND1_V1(x) ((x) & (~BITS_ATIMWND1_V1))
#define BIT_GET_ATIMWND1_V1(x) \
(((x) >> BIT_SHIFT_ATIMWND1_V1) & BIT_MASK_ATIMWND1_V1)
#define BIT_SET_ATIMWND1_V1(x, v) \
(BIT_CLEAR_ATIMWND1_V1(x) | BIT_ATIMWND1_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TBTT_PROHIBIT_INFRA (Offset 0x0571) */
#define BIT_SHIFT_TBTT_PROHIBIT_INFRA 0
#define BIT_MASK_TBTT_PROHIBIT_INFRA 0xff
#define BIT_TBTT_PROHIBIT_INFRA(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_INFRA) << BIT_SHIFT_TBTT_PROHIBIT_INFRA)
#define BITS_TBTT_PROHIBIT_INFRA \
(BIT_MASK_TBTT_PROHIBIT_INFRA << BIT_SHIFT_TBTT_PROHIBIT_INFRA)
#define BIT_CLEAR_TBTT_PROHIBIT_INFRA(x) ((x) & (~BITS_TBTT_PROHIBIT_INFRA))
#define BIT_GET_TBTT_PROHIBIT_INFRA(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_INFRA) & BIT_MASK_TBTT_PROHIBIT_INFRA)
#define BIT_SET_TBTT_PROHIBIT_INFRA(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_INFRA(x) | BIT_TBTT_PROHIBIT_INFRA(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BCNIVLCUNT (Offset 0x0573) */
#define BIT_SHIFT_BCNIVLCUNT 0
#define BIT_MASK_BCNIVLCUNT 0x7f
#define BIT_BCNIVLCUNT(x) (((x) & BIT_MASK_BCNIVLCUNT) << BIT_SHIFT_BCNIVLCUNT)
#define BITS_BCNIVLCUNT (BIT_MASK_BCNIVLCUNT << BIT_SHIFT_BCNIVLCUNT)
#define BIT_CLEAR_BCNIVLCUNT(x) ((x) & (~BITS_BCNIVLCUNT))
#define BIT_GET_BCNIVLCUNT(x) \
(((x) >> BIT_SHIFT_BCNIVLCUNT) & BIT_MASK_BCNIVLCUNT)
#define BIT_SET_BCNIVLCUNT(x, v) (BIT_CLEAR_BCNIVLCUNT(x) | BIT_BCNIVLCUNT(v))
/* 2 REG_BCNDROPCTRL (Offset 0x0574) */
#define BIT_BEACON_DROP_EN BIT(7)
#define BIT_SHIFT_BEACON_DROP_IVL 0
#define BIT_MASK_BEACON_DROP_IVL 0x7f
#define BIT_BEACON_DROP_IVL(x) \
(((x) & BIT_MASK_BEACON_DROP_IVL) << BIT_SHIFT_BEACON_DROP_IVL)
#define BITS_BEACON_DROP_IVL \
(BIT_MASK_BEACON_DROP_IVL << BIT_SHIFT_BEACON_DROP_IVL)
#define BIT_CLEAR_BEACON_DROP_IVL(x) ((x) & (~BITS_BEACON_DROP_IVL))
#define BIT_GET_BEACON_DROP_IVL(x) \
(((x) >> BIT_SHIFT_BEACON_DROP_IVL) & BIT_MASK_BEACON_DROP_IVL)
#define BIT_SET_BEACON_DROP_IVL(x, v) \
(BIT_CLEAR_BEACON_DROP_IVL(x) | BIT_BEACON_DROP_IVL(v))
/* 2 REG_HGQ_TIMEOUT_PERIOD (Offset 0x0575) */
#define BIT_SHIFT_HGQ_TIMEOUT_PERIOD 0
#define BIT_MASK_HGQ_TIMEOUT_PERIOD 0xff
#define BIT_HGQ_TIMEOUT_PERIOD(x) \
(((x) & BIT_MASK_HGQ_TIMEOUT_PERIOD) << BIT_SHIFT_HGQ_TIMEOUT_PERIOD)
#define BITS_HGQ_TIMEOUT_PERIOD \
(BIT_MASK_HGQ_TIMEOUT_PERIOD << BIT_SHIFT_HGQ_TIMEOUT_PERIOD)
#define BIT_CLEAR_HGQ_TIMEOUT_PERIOD(x) ((x) & (~BITS_HGQ_TIMEOUT_PERIOD))
#define BIT_GET_HGQ_TIMEOUT_PERIOD(x) \
(((x) >> BIT_SHIFT_HGQ_TIMEOUT_PERIOD) & BIT_MASK_HGQ_TIMEOUT_PERIOD)
#define BIT_SET_HGQ_TIMEOUT_PERIOD(x, v) \
(BIT_CLEAR_HGQ_TIMEOUT_PERIOD(x) | BIT_HGQ_TIMEOUT_PERIOD(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXCMD_TIMEOUT_PERIOD (Offset 0x0576) */
#define BIT_SHIFT_TXCMD_TIMEOUT_PERIOD 0
#define BIT_MASK_TXCMD_TIMEOUT_PERIOD 0xff
#define BIT_TXCMD_TIMEOUT_PERIOD(x) \
(((x) & BIT_MASK_TXCMD_TIMEOUT_PERIOD) \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD)
#define BITS_TXCMD_TIMEOUT_PERIOD \
(BIT_MASK_TXCMD_TIMEOUT_PERIOD << BIT_SHIFT_TXCMD_TIMEOUT_PERIOD)
#define BIT_CLEAR_TXCMD_TIMEOUT_PERIOD(x) ((x) & (~BITS_TXCMD_TIMEOUT_PERIOD))
#define BIT_GET_TXCMD_TIMEOUT_PERIOD(x) \
(((x) >> BIT_SHIFT_TXCMD_TIMEOUT_PERIOD) & \
BIT_MASK_TXCMD_TIMEOUT_PERIOD)
#define BIT_SET_TXCMD_TIMEOUT_PERIOD(x, v) \
(BIT_CLEAR_TXCMD_TIMEOUT_PERIOD(x) | BIT_TXCMD_TIMEOUT_PERIOD(v))
#define BIT_SHIFT_EARLY_128US 0
#define BIT_MASK_EARLY_128US 0x7
#define BIT_EARLY_128US(x) \
(((x) & BIT_MASK_EARLY_128US) << BIT_SHIFT_EARLY_128US)
#define BITS_EARLY_128US (BIT_MASK_EARLY_128US << BIT_SHIFT_EARLY_128US)
#define BIT_CLEAR_EARLY_128US(x) ((x) & (~BITS_EARLY_128US))
#define BIT_GET_EARLY_128US(x) \
(((x) >> BIT_SHIFT_EARLY_128US) & BIT_MASK_EARLY_128US)
#define BIT_SET_EARLY_128US(x, v) \
(BIT_CLEAR_EARLY_128US(x) | BIT_EARLY_128US(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_DIS_MARK_TSF_US BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_DIS_MARK_TSF_US_V2 BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_EN_TSFAUTO_SYNC BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_AUTO_SYNC_BY_TBTT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_DIS_TRX_CAL_BCN BIT(5)
#define BIT_DIS_TX_CAL_TBTT BIT(4)
#define BIT_EN_FREECNT BIT(3)
#define BIT_BCN_AGGRESSION BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_DIS_SECONDARY_CCA_80M BIT(2)
#define BIT_DIS_SECONDARY_CCA_40M BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_SHIFT_DIS_SECONDARY_CCA 0
#define BIT_MASK_DIS_SECONDARY_CCA 0x3
#define BIT_DIS_SECONDARY_CCA(x) \
(((x) & BIT_MASK_DIS_SECONDARY_CCA) << BIT_SHIFT_DIS_SECONDARY_CCA)
#define BITS_DIS_SECONDARY_CCA \
(BIT_MASK_DIS_SECONDARY_CCA << BIT_SHIFT_DIS_SECONDARY_CCA)
#define BIT_CLEAR_DIS_SECONDARY_CCA(x) ((x) & (~BITS_DIS_SECONDARY_CCA))
#define BIT_GET_DIS_SECONDARY_CCA(x) \
(((x) >> BIT_SHIFT_DIS_SECONDARY_CCA) & BIT_MASK_DIS_SECONDARY_CCA)
#define BIT_SET_DIS_SECONDARY_CCA(x, v) \
(BIT_CLEAR_DIS_SECONDARY_CCA(x) | BIT_DIS_SECONDARY_CCA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI0 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI0 0x7f
#define BIT_TBTT_INT_SHIFT_CLI0(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI0) << BIT_SHIFT_TBTT_INT_SHIFT_CLI0)
#define BITS_TBTT_INT_SHIFT_CLI0 \
(BIT_MASK_TBTT_INT_SHIFT_CLI0 << BIT_SHIFT_TBTT_INT_SHIFT_CLI0)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI0(x) ((x) & (~BITS_TBTT_INT_SHIFT_CLI0))
#define BIT_GET_TBTT_INT_SHIFT_CLI0(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI0) & BIT_MASK_TBTT_INT_SHIFT_CLI0)
#define BIT_SET_TBTT_INT_SHIFT_CLI0(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI0(x) | BIT_TBTT_INT_SHIFT_CLI0(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MISC_CTRL (Offset 0x0577) */
#define BIT_DIS_SECONDARY_CCA_20M BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT1 (Offset 0x0578) */
#define BIT_CLI1_DIS_RX_BSSID_FIT BIT(6)
#define BIT_CLI1_DIS_TSF_UDT BIT(4)
#define BIT_CLI1_EN_BCN_FUNCTION BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT1 (Offset 0x0578) */
#define BIT_CLI1_EN_RXBCN_RPT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT1 (Offset 0x0578) */
#define BIT_CLI1_EN_BCN_RPT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT1 (Offset 0x0578) */
#define BIT_CLI1_ENP2P_CTWINDOW BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFTR2_L (Offset 0x0578) */
#define BIT_SHIFT_TSF2_TIMER_L 0
#define BIT_MASK_TSF2_TIMER_L 0xffffffffL
#define BIT_TSF2_TIMER_L(x) \
(((x) & BIT_MASK_TSF2_TIMER_L) << BIT_SHIFT_TSF2_TIMER_L)
#define BITS_TSF2_TIMER_L (BIT_MASK_TSF2_TIMER_L << BIT_SHIFT_TSF2_TIMER_L)
#define BIT_CLEAR_TSF2_TIMER_L(x) ((x) & (~BITS_TSF2_TIMER_L))
#define BIT_GET_TSF2_TIMER_L(x) \
(((x) >> BIT_SHIFT_TSF2_TIMER_L) & BIT_MASK_TSF2_TIMER_L)
#define BIT_SET_TSF2_TIMER_L(x, v) \
(BIT_CLEAR_TSF2_TIMER_L(x) | BIT_TSF2_TIMER_L(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT1 (Offset 0x0578) */
#define BIT_CLI1_ENP2P_BCNQ_AREA BIT(0)
/* 2 REG_BCN_CTRL_CLINT2 (Offset 0x0579) */
#define BIT_CLI2_DIS_RX_BSSID_FIT BIT(6)
#define BIT_CLI2_DIS_TSF_UDT BIT(4)
#define BIT_CLI2_EN_BCN_FUNCTION BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT2 (Offset 0x0579) */
#define BIT_CLI2_EN_RXBCN_RPT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT2 (Offset 0x0579) */
#define BIT_CLI2_EN_BCN_RPT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT2 (Offset 0x0579) */
#define BIT_CLI2_ENP2P_CTWINDOW BIT(1)
#define BIT_CLI2_ENP2P_BCNQ_AREA BIT(0)
/* 2 REG_BCN_CTRL_CLINT3 (Offset 0x057A) */
#define BIT_CLI3_DIS_RX_BSSID_FIT BIT(6)
#define BIT_CLI3_DIS_TSF_UDT BIT(4)
#define BIT_CLI3_EN_BCN_FUNCTION BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT3 (Offset 0x057A) */
#define BIT_CLI3_EN_RXBCN_RPT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT3 (Offset 0x057A) */
#define BIT_CLI3_EN_BCN_RPT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_CTRL_CLINT3 (Offset 0x057A) */
#define BIT_CLI3_ENP2P_CTWINDOW BIT(1)
#define BIT_CLI3_ENP2P_BCNQ_AREA BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_EXTEND_CTRL (Offset 0x057B) */
#define BIT_EN_TSFBIT32_RST_P2P2 BIT(5)
#define BIT_EN_TSFBIT32_RST_P2P1 BIT(4)
#define BIT_SHIFT_PORT_SEL 0
#define BIT_MASK_PORT_SEL 0x7
#define BIT_PORT_SEL(x) (((x) & BIT_MASK_PORT_SEL) << BIT_SHIFT_PORT_SEL)
#define BITS_PORT_SEL (BIT_MASK_PORT_SEL << BIT_SHIFT_PORT_SEL)
#define BIT_CLEAR_PORT_SEL(x) ((x) & (~BITS_PORT_SEL))
#define BIT_GET_PORT_SEL(x) (((x) >> BIT_SHIFT_PORT_SEL) & BIT_MASK_PORT_SEL)
#define BIT_SET_PORT_SEL(x, v) (BIT_CLEAR_PORT_SEL(x) | BIT_PORT_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_SPEC_STATE (Offset 0x057C) */
#define BIT_P2P1_SPEC_POWER_STATE BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_SPEC_STATE (Offset 0x057C) */
#define BIT_P2P1_SPEC_CTWINDOW_ON BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_SPEC_STATE (Offset 0x057C) */
#define BIT_P2P1_SPEC_BCN_AREA_ON BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_SPEC_STATE (Offset 0x057C) */
#define BIT_P2P1_SPEC_CTWIN_EARLY_DISTX BIT(4)
#define BIT_P2P1_SPEC_NOA1_OFF_PERIOD BIT(3)
#define BIT_P2P1_SPEC_FORCE_DOZE1 BIT(2)
#define BIT_P2P1_SPEC_NOA0_OFF_PERIOD BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFTR2_H (Offset 0x057C) */
#define BIT_SHIFT_TSF2_TIMER_H 0
#define BIT_MASK_TSF2_TIMER_H 0xffffffffL
#define BIT_TSF2_TIMER_H(x) \
(((x) & BIT_MASK_TSF2_TIMER_H) << BIT_SHIFT_TSF2_TIMER_H)
#define BITS_TSF2_TIMER_H (BIT_MASK_TSF2_TIMER_H << BIT_SHIFT_TSF2_TIMER_H)
#define BIT_CLEAR_TSF2_TIMER_H(x) ((x) & (~BITS_TSF2_TIMER_H))
#define BIT_GET_TSF2_TIMER_H(x) \
(((x) >> BIT_SHIFT_TSF2_TIMER_H) & BIT_MASK_TSF2_TIMER_H)
#define BIT_SET_TSF2_TIMER_H(x, v) \
(BIT_CLEAR_TSF2_TIMER_H(x) | BIT_TSF2_TIMER_H(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_SPEC_STATE (Offset 0x057C) */
#define BIT_P2P1_SPEC_FORCE_DOZE0 BIT(0)
/* 2 REG_P2PPS1_STATE (Offset 0x057D) */
#define BIT_P2P1_POWER_STATE BIT(7)
#define BIT_P2P1_CTWINDOW_ON BIT(6)
#define BIT_P2P1_BEACON_AREA_ON BIT(5)
#define BIT_P2P1_CTWIN_EARLY_DISTX BIT(4)
#define BIT_P2P1_NOA1_OFF_PERIOD BIT(3)
#define BIT_P2P1_FORCE_DOZE1 BIT(2)
#define BIT_P2P1_NOA0_OFF_PERIOD BIT(1)
#define BIT_P2P1_FORCE_DOZE0 BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_SPEC_STATE (Offset 0x057E) */
#define BIT_P2P2_SPEC_POWER_STATE BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_SPEC_STATE (Offset 0x057E) */
#define BIT_P2P2_SPEC_CTWINDOW_ON BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_SPEC_STATE (Offset 0x057E) */
#define BIT_P2P2_SPEC_BCN_AREA_ON BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_SPEC_STATE (Offset 0x057E) */
#define BIT_P2P2_SPEC_CTWIN_EARLY_DISTX BIT(4)
#define BIT_P2P2_SPEC_NOA1_OFF_PERIOD BIT(3)
#define BIT_P2P2_SPEC_FORCE_DOZE1 BIT(2)
#define BIT_P2P2_SPEC_NOA0_OFF_PERIOD BIT(1)
#define BIT_P2P2_SPEC_FORCE_DOZE0 BIT(0)
/* 2 REG_P2PPS2_STATE (Offset 0x057F) */
#define BIT_P2P2_POWER_STATE BIT(7)
#define BIT_P2P2_CTWINDOW_ON BIT(6)
#define BIT_P2P2_BEACON_AREA_ON BIT(5)
#define BIT_P2P2_CTWIN_EARLY_DISTX BIT(4)
#define BIT_P2P2_NOA1_OFF_PERIOD BIT(3)
#define BIT_P2P2_FORCE_DOZE1 BIT(2)
#define BIT_P2P2_NOA0_OFF_PERIOD BIT(1)
#define BIT_P2P2_FORCE_DOZE0 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_PS_TIMER (Offset 0x0580) */
#define BIT_SHIFT_PSTIMER 5
#define BIT_MASK_PSTIMER 0x7ffffff
#define BIT_PSTIMER(x) (((x) & BIT_MASK_PSTIMER) << BIT_SHIFT_PSTIMER)
#define BITS_PSTIMER (BIT_MASK_PSTIMER << BIT_SHIFT_PSTIMER)
#define BIT_CLEAR_PSTIMER(x) ((x) & (~BITS_PSTIMER))
#define BIT_GET_PSTIMER(x) (((x) >> BIT_SHIFT_PSTIMER) & BIT_MASK_PSTIMER)
#define BIT_SET_PSTIMER(x, v) (BIT_CLEAR_PSTIMER(x) | BIT_PSTIMER(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PS_TIMER0 (Offset 0x0580) */
#define BIT_SHIFT_PSTIMER0_INT 5
#define BIT_MASK_PSTIMER0_INT 0x7ffffff
#define BIT_PSTIMER0_INT(x) \
(((x) & BIT_MASK_PSTIMER0_INT) << BIT_SHIFT_PSTIMER0_INT)
#define BITS_PSTIMER0_INT (BIT_MASK_PSTIMER0_INT << BIT_SHIFT_PSTIMER0_INT)
#define BIT_CLEAR_PSTIMER0_INT(x) ((x) & (~BITS_PSTIMER0_INT))
#define BIT_GET_PSTIMER0_INT(x) \
(((x) >> BIT_SHIFT_PSTIMER0_INT) & BIT_MASK_PSTIMER0_INT)
#define BIT_SET_PSTIMER0_INT(x, v) \
(BIT_CLEAR_PSTIMER0_INT(x) | BIT_PSTIMER0_INT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TIMER0 (Offset 0x0584) */
#define BIT_SHIFT_TIMER0_INT 5
#define BIT_MASK_TIMER0_INT 0x7ffffff
#define BIT_TIMER0_INT(x) (((x) & BIT_MASK_TIMER0_INT) << BIT_SHIFT_TIMER0_INT)
#define BITS_TIMER0_INT (BIT_MASK_TIMER0_INT << BIT_SHIFT_TIMER0_INT)
#define BIT_CLEAR_TIMER0_INT(x) ((x) & (~BITS_TIMER0_INT))
#define BIT_GET_TIMER0_INT(x) \
(((x) >> BIT_SHIFT_TIMER0_INT) & BIT_MASK_TIMER0_INT)
#define BIT_SET_TIMER0_INT(x, v) (BIT_CLEAR_TIMER0_INT(x) | BIT_TIMER0_INT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PS_TIMER1 (Offset 0x0584) */
#define BIT_SHIFT_PSTIMER1_INT 5
#define BIT_MASK_PSTIMER1_INT 0x7ffffff
#define BIT_PSTIMER1_INT(x) \
(((x) & BIT_MASK_PSTIMER1_INT) << BIT_SHIFT_PSTIMER1_INT)
#define BITS_PSTIMER1_INT (BIT_MASK_PSTIMER1_INT << BIT_SHIFT_PSTIMER1_INT)
#define BIT_CLEAR_PSTIMER1_INT(x) ((x) & (~BITS_PSTIMER1_INT))
#define BIT_GET_PSTIMER1_INT(x) \
(((x) >> BIT_SHIFT_PSTIMER1_INT) & BIT_MASK_PSTIMER1_INT)
#define BIT_SET_PSTIMER1_INT(x, v) \
(BIT_CLEAR_PSTIMER1_INT(x) | BIT_PSTIMER1_INT(v))
/* 2 REG_PS_TIMER2 (Offset 0x0588) */
#define BIT_SHIFT_INFO_INDEX_OFFSET 16
#define BIT_MASK_INFO_INDEX_OFFSET 0x1fff
#define BIT_INFO_INDEX_OFFSET(x) \
(((x) & BIT_MASK_INFO_INDEX_OFFSET) << BIT_SHIFT_INFO_INDEX_OFFSET)
#define BITS_INFO_INDEX_OFFSET \
(BIT_MASK_INFO_INDEX_OFFSET << BIT_SHIFT_INFO_INDEX_OFFSET)
#define BIT_CLEAR_INFO_INDEX_OFFSET(x) ((x) & (~BITS_INFO_INDEX_OFFSET))
#define BIT_GET_INFO_INDEX_OFFSET(x) \
(((x) >> BIT_SHIFT_INFO_INDEX_OFFSET) & BIT_MASK_INFO_INDEX_OFFSET)
#define BIT_SET_INFO_INDEX_OFFSET(x, v) \
(BIT_CLEAR_INFO_INDEX_OFFSET(x) | BIT_INFO_INDEX_OFFSET(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TIMER1 (Offset 0x0588) */
#define BIT_SHIFT_TIMER1_INT 5
#define BIT_MASK_TIMER1_INT 0x7ffffff
#define BIT_TIMER1_INT(x) (((x) & BIT_MASK_TIMER1_INT) << BIT_SHIFT_TIMER1_INT)
#define BITS_TIMER1_INT (BIT_MASK_TIMER1_INT << BIT_SHIFT_TIMER1_INT)
#define BIT_CLEAR_TIMER1_INT(x) ((x) & (~BITS_TIMER1_INT))
#define BIT_GET_TIMER1_INT(x) \
(((x) >> BIT_SHIFT_TIMER1_INT) & BIT_MASK_TIMER1_INT)
#define BIT_SET_TIMER1_INT(x, v) (BIT_CLEAR_TIMER1_INT(x) | BIT_TIMER1_INT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PS_TIMER2 (Offset 0x0588) */
#define BIT_SHIFT_PSTIMER2_INT 5
#define BIT_MASK_PSTIMER2_INT 0x7ffffff
#define BIT_PSTIMER2_INT(x) \
(((x) & BIT_MASK_PSTIMER2_INT) << BIT_SHIFT_PSTIMER2_INT)
#define BITS_PSTIMER2_INT (BIT_MASK_PSTIMER2_INT << BIT_SHIFT_PSTIMER2_INT)
#define BIT_CLEAR_PSTIMER2_INT(x) ((x) & (~BITS_PSTIMER2_INT))
#define BIT_GET_PSTIMER2_INT(x) \
(((x) >> BIT_SHIFT_PSTIMER2_INT) & BIT_MASK_PSTIMER2_INT)
#define BIT_SET_PSTIMER2_INT(x, v) \
(BIT_CLEAR_PSTIMER2_INT(x) | BIT_PSTIMER2_INT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TBTT_CTN_AREA (Offset 0x058C) */
#define BIT_SHIFT_TBTT_CTN_AREA 0
#define BIT_MASK_TBTT_CTN_AREA 0xff
#define BIT_TBTT_CTN_AREA(x) \
(((x) & BIT_MASK_TBTT_CTN_AREA) << BIT_SHIFT_TBTT_CTN_AREA)
#define BITS_TBTT_CTN_AREA (BIT_MASK_TBTT_CTN_AREA << BIT_SHIFT_TBTT_CTN_AREA)
#define BIT_CLEAR_TBTT_CTN_AREA(x) ((x) & (~BITS_TBTT_CTN_AREA))
#define BIT_GET_TBTT_CTN_AREA(x) \
(((x) >> BIT_SHIFT_TBTT_CTN_AREA) & BIT_MASK_TBTT_CTN_AREA)
#define BIT_SET_TBTT_CTN_AREA(x, v) \
(BIT_CLEAR_TBTT_CTN_AREA(x) | BIT_TBTT_CTN_AREA(v))
/* 2 REG_FORCE_BCN_IFS (Offset 0x058E) */
#define BIT_SHIFT_FORCE_BCN_IFS 0
#define BIT_MASK_FORCE_BCN_IFS 0xff
#define BIT_FORCE_BCN_IFS(x) \
(((x) & BIT_MASK_FORCE_BCN_IFS) << BIT_SHIFT_FORCE_BCN_IFS)
#define BITS_FORCE_BCN_IFS (BIT_MASK_FORCE_BCN_IFS << BIT_SHIFT_FORCE_BCN_IFS)
#define BIT_CLEAR_FORCE_BCN_IFS(x) ((x) & (~BITS_FORCE_BCN_IFS))
#define BIT_GET_FORCE_BCN_IFS(x) \
(((x) >> BIT_SHIFT_FORCE_BCN_IFS) & BIT_MASK_FORCE_BCN_IFS)
#define BIT_SET_FORCE_BCN_IFS(x, v) \
(BIT_CLEAR_FORCE_BCN_IFS(x) | BIT_FORCE_BCN_IFS(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DRVERLYINT_V1 (Offset 0x058F) */
#define BIT_SHIFT_PRE_BCN_DMATIM 0
#define BIT_MASK_PRE_BCN_DMATIM 0xff
#define BIT_PRE_BCN_DMATIM(x) \
(((x) & BIT_MASK_PRE_BCN_DMATIM) << BIT_SHIFT_PRE_BCN_DMATIM)
#define BITS_PRE_BCN_DMATIM \
(BIT_MASK_PRE_BCN_DMATIM << BIT_SHIFT_PRE_BCN_DMATIM)
#define BIT_CLEAR_PRE_BCN_DMATIM(x) ((x) & (~BITS_PRE_BCN_DMATIM))
#define BIT_GET_PRE_BCN_DMATIM(x) \
(((x) >> BIT_SHIFT_PRE_BCN_DMATIM) & BIT_MASK_PRE_BCN_DMATIM)
#define BIT_SET_PRE_BCN_DMATIM(x, v) \
(BIT_CLEAR_PRE_BCN_DMATIM(x) | BIT_PRE_BCN_DMATIM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_TXOP_MIN (Offset 0x0590) */
#define BIT_NAV_BLK_HGQ BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXOP_MIN (Offset 0x0590) */
#define BIT_HIQ_NAV_BREAK_EN BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_TXOP_MIN (Offset 0x0590) */
#define BIT_NAV_BLK_MGQ BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXOP_MIN (Offset 0x0590) */
#define BIT_MGQ_NAV_BREAK_EN BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_TXOP_MIN (Offset 0x0590) */
#define BIT_SHIFT_TXPAUSE1 8
#define BIT_MASK_TXPAUSE1 0xff
#define BIT_TXPAUSE1(x) (((x) & BIT_MASK_TXPAUSE1) << BIT_SHIFT_TXPAUSE1)
#define BITS_TXPAUSE1 (BIT_MASK_TXPAUSE1 << BIT_SHIFT_TXPAUSE1)
#define BIT_CLEAR_TXPAUSE1(x) ((x) & (~BITS_TXPAUSE1))
#define BIT_GET_TXPAUSE1(x) (((x) >> BIT_SHIFT_TXPAUSE1) & BIT_MASK_TXPAUSE1)
#define BIT_SET_TXPAUSE1(x, v) (BIT_CLEAR_TXPAUSE1(x) | BIT_TXPAUSE1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TXOP_MIN (Offset 0x0590) */
#define BIT_SHIFT_TXOP_MIN 0
#define BIT_MASK_TXOP_MIN 0x3fff
#define BIT_TXOP_MIN(x) (((x) & BIT_MASK_TXOP_MIN) << BIT_SHIFT_TXOP_MIN)
#define BITS_TXOP_MIN (BIT_MASK_TXOP_MIN << BIT_SHIFT_TXOP_MIN)
#define BIT_CLEAR_TXOP_MIN(x) ((x) & (~BITS_TXOP_MIN))
#define BIT_GET_TXOP_MIN(x) (((x) >> BIT_SHIFT_TXOP_MIN) & BIT_MASK_TXOP_MIN)
#define BIT_SET_TXOP_MIN(x, v) (BIT_CLEAR_TXOP_MIN(x) | BIT_TXOP_MIN(v))
/* 2 REG_PRE_BKF_TIME (Offset 0x0592) */
#define BIT_SHIFT_PRE_BKF_TIME 0
#define BIT_MASK_PRE_BKF_TIME 0xff
#define BIT_PRE_BKF_TIME(x) \
(((x) & BIT_MASK_PRE_BKF_TIME) << BIT_SHIFT_PRE_BKF_TIME)
#define BITS_PRE_BKF_TIME (BIT_MASK_PRE_BKF_TIME << BIT_SHIFT_PRE_BKF_TIME)
#define BIT_CLEAR_PRE_BKF_TIME(x) ((x) & (~BITS_PRE_BKF_TIME))
#define BIT_GET_PRE_BKF_TIME(x) \
(((x) >> BIT_SHIFT_PRE_BKF_TIME) & BIT_MASK_PRE_BKF_TIME)
#define BIT_SET_PRE_BKF_TIME(x, v) \
(BIT_CLEAR_PRE_BKF_TIME(x) | BIT_PRE_BKF_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_NOPKT_END_RTSMF BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_TBTT_RETRY BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_SHIFT_PRETX_US 3
#define BIT_MASK_PRETX_US 0xf
#define BIT_PRETX_US(x) (((x) & BIT_MASK_PRETX_US) << BIT_SHIFT_PRETX_US)
#define BITS_PRETX_US (BIT_MASK_PRETX_US << BIT_SHIFT_PRETX_US)
#define BIT_CLEAR_PRETX_US(x) ((x) & (~BITS_PRETX_US))
#define BIT_GET_PRETX_US(x) (((x) >> BIT_SHIFT_PRETX_US) & BIT_MASK_PRETX_US)
#define BIT_SET_PRETX_US(x, v) (BIT_CLEAR_PRETX_US(x) | BIT_PRETX_US(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_TXOP_FAIL_BREAK BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_TXFAIL_BREACK_TXOP_EN BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_DTIM_BYPASS BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CROSS_TXOP_CTRL (Offset 0x0593) */
#define BIT_RTS_NAV_TXOP BIT(1)
#define BIT_NOT_CROSS_TXOP BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_CLI (Offset 0x0594) */
#define BIT_TBTT_INT_SHIFT_DIR_CLI3_V1 BIT(31)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI3_V1 24
#define BIT_MASK_TBTT_INT_SHIFT_CLI3_V1 0x7f
#define BIT_TBTT_INT_SHIFT_CLI3_V1(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI3_V1) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI3_V1)
#define BITS_TBTT_INT_SHIFT_CLI3_V1 \
(BIT_MASK_TBTT_INT_SHIFT_CLI3_V1 << BIT_SHIFT_TBTT_INT_SHIFT_CLI3_V1)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI3_V1(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI3_V1))
#define BIT_GET_TBTT_INT_SHIFT_CLI3_V1(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI3_V1) & \
BIT_MASK_TBTT_INT_SHIFT_CLI3_V1)
#define BIT_SET_TBTT_INT_SHIFT_CLI3_V1(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI3_V1(x) | BIT_TBTT_INT_SHIFT_CLI3_V1(v))
#define BIT_TBTT_INT_SHIFT_DIR_CLI2_V1 BIT(23)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI2_V1 16
#define BIT_MASK_TBTT_INT_SHIFT_CLI2_V1 0x7f
#define BIT_TBTT_INT_SHIFT_CLI2_V1(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI2_V1) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI2_V1)
#define BITS_TBTT_INT_SHIFT_CLI2_V1 \
(BIT_MASK_TBTT_INT_SHIFT_CLI2_V1 << BIT_SHIFT_TBTT_INT_SHIFT_CLI2_V1)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI2_V1(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI2_V1))
#define BIT_GET_TBTT_INT_SHIFT_CLI2_V1(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI2_V1) & \
BIT_MASK_TBTT_INT_SHIFT_CLI2_V1)
#define BIT_SET_TBTT_INT_SHIFT_CLI2_V1(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI2_V1(x) | BIT_TBTT_INT_SHIFT_CLI2_V1(v))
#define BIT_SHIFT_DIS_ATIM_V1 16
#define BIT_MASK_DIS_ATIM_V1 0xff
#define BIT_DIS_ATIM_V1(x) \
(((x) & BIT_MASK_DIS_ATIM_V1) << BIT_SHIFT_DIS_ATIM_V1)
#define BITS_DIS_ATIM_V1 (BIT_MASK_DIS_ATIM_V1 << BIT_SHIFT_DIS_ATIM_V1)
#define BIT_CLEAR_DIS_ATIM_V1(x) ((x) & (~BITS_DIS_ATIM_V1))
#define BIT_GET_DIS_ATIM_V1(x) \
(((x) >> BIT_SHIFT_DIS_ATIM_V1) & BIT_MASK_DIS_ATIM_V1)
#define BIT_SET_DIS_ATIM_V1(x, v) \
(BIT_CLEAR_DIS_ATIM_V1(x) | BIT_DIS_ATIM_V1(v))
#define BIT_TBTT_INT_SHIFT_DIR_CLI1_V1 BIT(15)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI1_V1 8
#define BIT_MASK_TBTT_INT_SHIFT_CLI1_V1 0x7f
#define BIT_TBTT_INT_SHIFT_CLI1_V1(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI1_V1) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI1_V1)
#define BITS_TBTT_INT_SHIFT_CLI1_V1 \
(BIT_MASK_TBTT_INT_SHIFT_CLI1_V1 << BIT_SHIFT_TBTT_INT_SHIFT_CLI1_V1)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI1_V1(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI1_V1))
#define BIT_GET_TBTT_INT_SHIFT_CLI1_V1(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI1_V1) & \
BIT_MASK_TBTT_INT_SHIFT_CLI1_V1)
#define BIT_SET_TBTT_INT_SHIFT_CLI1_V1(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI1_V1(x) | BIT_TBTT_INT_SHIFT_CLI1_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_CLI0 (Offset 0x0594) */
#define BIT_TBTT_INT_SHIFT_DIR_CLI0 BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_CLI (Offset 0x0594) */
#define BIT_TBTT_INT_SHIFT_DIR_CLI0_V1 BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FREERUN_CNT_L (Offset 0x0594) */
#define BIT_SHIFT_FREERUN_CNT_L 0
#define BIT_MASK_FREERUN_CNT_L 0xffffffffL
#define BIT_FREERUN_CNT_L(x) \
(((x) & BIT_MASK_FREERUN_CNT_L) << BIT_SHIFT_FREERUN_CNT_L)
#define BITS_FREERUN_CNT_L (BIT_MASK_FREERUN_CNT_L << BIT_SHIFT_FREERUN_CNT_L)
#define BIT_CLEAR_FREERUN_CNT_L(x) ((x) & (~BITS_FREERUN_CNT_L))
#define BIT_GET_FREERUN_CNT_L(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_L) & BIT_MASK_FREERUN_CNT_L)
#define BIT_SET_FREERUN_CNT_L(x, v) \
(BIT_CLEAR_FREERUN_CNT_L(x) | BIT_FREERUN_CNT_L(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_CLI (Offset 0x0594) */
#define BIT_SHIFT_MBID_BCNQ_EN_V1 0
#define BIT_MASK_MBID_BCNQ_EN_V1 0xff
#define BIT_MBID_BCNQ_EN_V1(x) \
(((x) & BIT_MASK_MBID_BCNQ_EN_V1) << BIT_SHIFT_MBID_BCNQ_EN_V1)
#define BITS_MBID_BCNQ_EN_V1 \
(BIT_MASK_MBID_BCNQ_EN_V1 << BIT_SHIFT_MBID_BCNQ_EN_V1)
#define BIT_CLEAR_MBID_BCNQ_EN_V1(x) ((x) & (~BITS_MBID_BCNQ_EN_V1))
#define BIT_GET_MBID_BCNQ_EN_V1(x) \
(((x) >> BIT_SHIFT_MBID_BCNQ_EN_V1) & BIT_MASK_MBID_BCNQ_EN_V1)
#define BIT_SET_MBID_BCNQ_EN_V1(x, v) \
(BIT_CLEAR_MBID_BCNQ_EN_V1(x) | BIT_MBID_BCNQ_EN_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_CLI1 (Offset 0x0595) */
#define BIT_TBTT_INT_SHIFT_DIR_CLI1 BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI1 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI1 0x7f
#define BIT_TBTT_INT_SHIFT_CLI1(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI1) << BIT_SHIFT_TBTT_INT_SHIFT_CLI1)
#define BITS_TBTT_INT_SHIFT_CLI1 \
(BIT_MASK_TBTT_INT_SHIFT_CLI1 << BIT_SHIFT_TBTT_INT_SHIFT_CLI1)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI1(x) ((x) & (~BITS_TBTT_INT_SHIFT_CLI1))
#define BIT_GET_TBTT_INT_SHIFT_CLI1(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI1) & BIT_MASK_TBTT_INT_SHIFT_CLI1)
#define BIT_SET_TBTT_INT_SHIFT_CLI1(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI1(x) | BIT_TBTT_INT_SHIFT_CLI1(v))
/* 2 REG_TBTT_INT_SHIFT_CLI2 (Offset 0x0596) */
#define BIT_TBTT_INT_SHIFT_DIR_CLI2 BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI2 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI2 0x7f
#define BIT_TBTT_INT_SHIFT_CLI2(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI2) << BIT_SHIFT_TBTT_INT_SHIFT_CLI2)
#define BITS_TBTT_INT_SHIFT_CLI2 \
(BIT_MASK_TBTT_INT_SHIFT_CLI2 << BIT_SHIFT_TBTT_INT_SHIFT_CLI2)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI2(x) ((x) & (~BITS_TBTT_INT_SHIFT_CLI2))
#define BIT_GET_TBTT_INT_SHIFT_CLI2(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI2) & BIT_MASK_TBTT_INT_SHIFT_CLI2)
#define BIT_SET_TBTT_INT_SHIFT_CLI2(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI2(x) | BIT_TBTT_INT_SHIFT_CLI2(v))
/* 2 REG_TBTT_INT_SHIFT_CLI3 (Offset 0x0597) */
#define BIT_TBTT_INT_SHIFT_DIR_CLI3 BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI3 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI3 0x7f
#define BIT_TBTT_INT_SHIFT_CLI3(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI3) << BIT_SHIFT_TBTT_INT_SHIFT_CLI3)
#define BITS_TBTT_INT_SHIFT_CLI3 \
(BIT_MASK_TBTT_INT_SHIFT_CLI3 << BIT_SHIFT_TBTT_INT_SHIFT_CLI3)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI3(x) ((x) & (~BITS_TBTT_INT_SHIFT_CLI3))
#define BIT_GET_TBTT_INT_SHIFT_CLI3(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI3) & BIT_MASK_TBTT_INT_SHIFT_CLI3)
#define BIT_SET_TBTT_INT_SHIFT_CLI3(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI3(x) | BIT_TBTT_INT_SHIFT_CLI3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_TBTT_SHIFT_V1 (Offset 0x0598) */
#define BIT_RX_TBTT_SHIFT_RW_FLAG_V1 BIT(31)
#define BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1 16
#define BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1 0xfff
#define BIT_RX_TBTT_SHIFT_OFFSET_V1(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1) \
<< BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1)
#define BITS_RX_TBTT_SHIFT_OFFSET_V1 \
(BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1 << BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1)
#define BIT_CLEAR_RX_TBTT_SHIFT_OFFSET_V1(x) \
((x) & (~BITS_RX_TBTT_SHIFT_OFFSET_V1))
#define BIT_GET_RX_TBTT_SHIFT_OFFSET_V1(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1) & \
BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1)
#define BIT_SET_RX_TBTT_SHIFT_OFFSET_V1(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_OFFSET_V1(x) | BIT_RX_TBTT_SHIFT_OFFSET_V1(v))
#define BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1 8
#define BIT_MASK_RX_TBTT_SHIFT_SEL_V1 0x7
#define BIT_RX_TBTT_SHIFT_SEL_V1(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_SEL_V1) \
<< BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1)
#define BITS_RX_TBTT_SHIFT_SEL_V1 \
(BIT_MASK_RX_TBTT_SHIFT_SEL_V1 << BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1)
#define BIT_CLEAR_RX_TBTT_SHIFT_SEL_V1(x) ((x) & (~BITS_RX_TBTT_SHIFT_SEL_V1))
#define BIT_GET_RX_TBTT_SHIFT_SEL_V1(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1) & \
BIT_MASK_RX_TBTT_SHIFT_SEL_V1)
#define BIT_SET_RX_TBTT_SHIFT_SEL_V1(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_SEL_V1(x) | BIT_RX_TBTT_SHIFT_SEL_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_ENABLE (Offset 0x0598) */
#define BIT_EN_TBTT_RTY BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FREERUN_CNT_H (Offset 0x0598) */
#define BIT_SHIFT_FREERUN_CNT_H 0
#define BIT_MASK_FREERUN_CNT_H 0xffffffffL
#define BIT_FREERUN_CNT_H(x) \
(((x) & BIT_MASK_FREERUN_CNT_H) << BIT_SHIFT_FREERUN_CNT_H)
#define BITS_FREERUN_CNT_H (BIT_MASK_FREERUN_CNT_H << BIT_SHIFT_FREERUN_CNT_H)
#define BIT_CLEAR_FREERUN_CNT_H(x) ((x) & (~BITS_FREERUN_CNT_H))
#define BIT_GET_FREERUN_CNT_H(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_H) & BIT_MASK_FREERUN_CNT_H)
#define BIT_SET_FREERUN_CNT_H(x, v) \
(BIT_CLEAR_FREERUN_CNT_H(x) | BIT_FREERUN_CNT_H(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TBTT_INT_SHIFT_ENABLE (Offset 0x0598) */
#define BIT_TBTT_INT_SHIFT_ENABLE BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND2 (Offset 0x05A0) */
#define BIT_SHIFT_ATIMWND2 0
#define BIT_MASK_ATIMWND2 0xff
#define BIT_ATIMWND2(x) (((x) & BIT_MASK_ATIMWND2) << BIT_SHIFT_ATIMWND2)
#define BITS_ATIMWND2 (BIT_MASK_ATIMWND2 << BIT_SHIFT_ATIMWND2)
#define BIT_CLEAR_ATIMWND2(x) ((x) & (~BITS_ATIMWND2))
#define BIT_GET_ATIMWND2(x) (((x) >> BIT_SHIFT_ATIMWND2) & BIT_MASK_ATIMWND2)
#define BIT_SET_ATIMWND2(x, v) (BIT_CLEAR_ATIMWND2(x) | BIT_ATIMWND2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_ATIMWND_GROUP1 (Offset 0x05A0) */
#define BIT_SHIFT_ATIMWND_GROUP1 0
#define BIT_MASK_ATIMWND_GROUP1 0xff
#define BIT_ATIMWND_GROUP1(x) \
(((x) & BIT_MASK_ATIMWND_GROUP1) << BIT_SHIFT_ATIMWND_GROUP1)
#define BITS_ATIMWND_GROUP1 \
(BIT_MASK_ATIMWND_GROUP1 << BIT_SHIFT_ATIMWND_GROUP1)
#define BIT_CLEAR_ATIMWND_GROUP1(x) ((x) & (~BITS_ATIMWND_GROUP1))
#define BIT_GET_ATIMWND_GROUP1(x) \
(((x) >> BIT_SHIFT_ATIMWND_GROUP1) & BIT_MASK_ATIMWND_GROUP1)
#define BIT_SET_ATIMWND_GROUP1(x, v) \
(BIT_CLEAR_ATIMWND_GROUP1(x) | BIT_ATIMWND_GROUP1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND3 (Offset 0x05A1) */
#define BIT_SHIFT_ATIMWND3 0
#define BIT_MASK_ATIMWND3 0xff
#define BIT_ATIMWND3(x) (((x) & BIT_MASK_ATIMWND3) << BIT_SHIFT_ATIMWND3)
#define BITS_ATIMWND3 (BIT_MASK_ATIMWND3 << BIT_SHIFT_ATIMWND3)
#define BIT_CLEAR_ATIMWND3(x) ((x) & (~BITS_ATIMWND3))
#define BIT_GET_ATIMWND3(x) (((x) >> BIT_SHIFT_ATIMWND3) & BIT_MASK_ATIMWND3)
#define BIT_SET_ATIMWND3(x, v) (BIT_CLEAR_ATIMWND3(x) | BIT_ATIMWND3(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_ATIMWND_GROUP2 (Offset 0x05A1) */
#define BIT_SHIFT_ATIMWND_GROUP2 0
#define BIT_MASK_ATIMWND_GROUP2 0xff
#define BIT_ATIMWND_GROUP2(x) \
(((x) & BIT_MASK_ATIMWND_GROUP2) << BIT_SHIFT_ATIMWND_GROUP2)
#define BITS_ATIMWND_GROUP2 \
(BIT_MASK_ATIMWND_GROUP2 << BIT_SHIFT_ATIMWND_GROUP2)
#define BIT_CLEAR_ATIMWND_GROUP2(x) ((x) & (~BITS_ATIMWND_GROUP2))
#define BIT_GET_ATIMWND_GROUP2(x) \
(((x) >> BIT_SHIFT_ATIMWND_GROUP2) & BIT_MASK_ATIMWND_GROUP2)
#define BIT_SET_ATIMWND_GROUP2(x, v) \
(BIT_CLEAR_ATIMWND_GROUP2(x) | BIT_ATIMWND_GROUP2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND4 (Offset 0x05A2) */
#define BIT_SHIFT_ATIMWND4 0
#define BIT_MASK_ATIMWND4 0xff
#define BIT_ATIMWND4(x) (((x) & BIT_MASK_ATIMWND4) << BIT_SHIFT_ATIMWND4)
#define BITS_ATIMWND4 (BIT_MASK_ATIMWND4 << BIT_SHIFT_ATIMWND4)
#define BIT_CLEAR_ATIMWND4(x) ((x) & (~BITS_ATIMWND4))
#define BIT_GET_ATIMWND4(x) (((x) >> BIT_SHIFT_ATIMWND4) & BIT_MASK_ATIMWND4)
#define BIT_SET_ATIMWND4(x, v) (BIT_CLEAR_ATIMWND4(x) | BIT_ATIMWND4(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_ATIMWND_GROUP3 (Offset 0x05A2) */
#define BIT_SHIFT_ATIMWND_GROUP3 0
#define BIT_MASK_ATIMWND_GROUP3 0xff
#define BIT_ATIMWND_GROUP3(x) \
(((x) & BIT_MASK_ATIMWND_GROUP3) << BIT_SHIFT_ATIMWND_GROUP3)
#define BITS_ATIMWND_GROUP3 \
(BIT_MASK_ATIMWND_GROUP3 << BIT_SHIFT_ATIMWND_GROUP3)
#define BIT_CLEAR_ATIMWND_GROUP3(x) ((x) & (~BITS_ATIMWND_GROUP3))
#define BIT_GET_ATIMWND_GROUP3(x) \
(((x) >> BIT_SHIFT_ATIMWND_GROUP3) & BIT_MASK_ATIMWND_GROUP3)
#define BIT_SET_ATIMWND_GROUP3(x, v) \
(BIT_CLEAR_ATIMWND_GROUP3(x) | BIT_ATIMWND_GROUP3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND5 (Offset 0x05A3) */
#define BIT_SHIFT_ATIMWND5 0
#define BIT_MASK_ATIMWND5 0xff
#define BIT_ATIMWND5(x) (((x) & BIT_MASK_ATIMWND5) << BIT_SHIFT_ATIMWND5)
#define BITS_ATIMWND5 (BIT_MASK_ATIMWND5 << BIT_SHIFT_ATIMWND5)
#define BIT_CLEAR_ATIMWND5(x) ((x) & (~BITS_ATIMWND5))
#define BIT_GET_ATIMWND5(x) (((x) >> BIT_SHIFT_ATIMWND5) & BIT_MASK_ATIMWND5)
#define BIT_SET_ATIMWND5(x, v) (BIT_CLEAR_ATIMWND5(x) | BIT_ATIMWND5(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_ATIMWND_GROUP4 (Offset 0x05A3) */
#define BIT_SHIFT_ATIMWND_GROUP4 0
#define BIT_MASK_ATIMWND_GROUP4 0xff
#define BIT_ATIMWND_GROUP4(x) \
(((x) & BIT_MASK_ATIMWND_GROUP4) << BIT_SHIFT_ATIMWND_GROUP4)
#define BITS_ATIMWND_GROUP4 \
(BIT_MASK_ATIMWND_GROUP4 << BIT_SHIFT_ATIMWND_GROUP4)
#define BIT_CLEAR_ATIMWND_GROUP4(x) ((x) & (~BITS_ATIMWND_GROUP4))
#define BIT_GET_ATIMWND_GROUP4(x) \
(((x) >> BIT_SHIFT_ATIMWND_GROUP4) & BIT_MASK_ATIMWND_GROUP4)
#define BIT_SET_ATIMWND_GROUP4(x, v) \
(BIT_CLEAR_ATIMWND_GROUP4(x) | BIT_ATIMWND_GROUP4(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND6 (Offset 0x05A4) */
#define BIT_SHIFT_ATIMWND6 0
#define BIT_MASK_ATIMWND6 0xff
#define BIT_ATIMWND6(x) (((x) & BIT_MASK_ATIMWND6) << BIT_SHIFT_ATIMWND6)
#define BITS_ATIMWND6 (BIT_MASK_ATIMWND6 << BIT_SHIFT_ATIMWND6)
#define BIT_CLEAR_ATIMWND6(x) ((x) & (~BITS_ATIMWND6))
#define BIT_GET_ATIMWND6(x) (((x) >> BIT_SHIFT_ATIMWND6) & BIT_MASK_ATIMWND6)
#define BIT_SET_ATIMWND6(x, v) (BIT_CLEAR_ATIMWND6(x) | BIT_ATIMWND6(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DTIM_COUNT_GROUP1 (Offset 0x05A4) */
#define BIT_SHIFT_DTIM_COUNT_GROUP1 0
#define BIT_MASK_DTIM_COUNT_GROUP1 0xff
#define BIT_DTIM_COUNT_GROUP1(x) \
(((x) & BIT_MASK_DTIM_COUNT_GROUP1) << BIT_SHIFT_DTIM_COUNT_GROUP1)
#define BITS_DTIM_COUNT_GROUP1 \
(BIT_MASK_DTIM_COUNT_GROUP1 << BIT_SHIFT_DTIM_COUNT_GROUP1)
#define BIT_CLEAR_DTIM_COUNT_GROUP1(x) ((x) & (~BITS_DTIM_COUNT_GROUP1))
#define BIT_GET_DTIM_COUNT_GROUP1(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_GROUP1) & BIT_MASK_DTIM_COUNT_GROUP1)
#define BIT_SET_DTIM_COUNT_GROUP1(x, v) \
(BIT_CLEAR_DTIM_COUNT_GROUP1(x) | BIT_DTIM_COUNT_GROUP1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMWND7 (Offset 0x05A5) */
#define BIT_SHIFT_ATIMWND7 0
#define BIT_MASK_ATIMWND7 0xff
#define BIT_ATIMWND7(x) (((x) & BIT_MASK_ATIMWND7) << BIT_SHIFT_ATIMWND7)
#define BITS_ATIMWND7 (BIT_MASK_ATIMWND7 << BIT_SHIFT_ATIMWND7)
#define BIT_CLEAR_ATIMWND7(x) ((x) & (~BITS_ATIMWND7))
#define BIT_GET_ATIMWND7(x) (((x) >> BIT_SHIFT_ATIMWND7) & BIT_MASK_ATIMWND7)
#define BIT_SET_ATIMWND7(x, v) (BIT_CLEAR_ATIMWND7(x) | BIT_ATIMWND7(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DTIM_COUNT_GROUP2 (Offset 0x05A5) */
#define BIT_SHIFT_DTIM_COUNT_GROUP2 0
#define BIT_MASK_DTIM_COUNT_GROUP2 0xff
#define BIT_DTIM_COUNT_GROUP2(x) \
(((x) & BIT_MASK_DTIM_COUNT_GROUP2) << BIT_SHIFT_DTIM_COUNT_GROUP2)
#define BITS_DTIM_COUNT_GROUP2 \
(BIT_MASK_DTIM_COUNT_GROUP2 << BIT_SHIFT_DTIM_COUNT_GROUP2)
#define BIT_CLEAR_DTIM_COUNT_GROUP2(x) ((x) & (~BITS_DTIM_COUNT_GROUP2))
#define BIT_GET_DTIM_COUNT_GROUP2(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_GROUP2) & BIT_MASK_DTIM_COUNT_GROUP2)
#define BIT_SET_DTIM_COUNT_GROUP2(x, v) \
(BIT_CLEAR_DTIM_COUNT_GROUP2(x) | BIT_DTIM_COUNT_GROUP2(v))
/* 2 REG_DTIM_COUNT_GROUP3 (Offset 0x05A6) */
#define BIT_SHIFT_DTIM_COUNT_GROUP3 0
#define BIT_MASK_DTIM_COUNT_GROUP3 0xff
#define BIT_DTIM_COUNT_GROUP3(x) \
(((x) & BIT_MASK_DTIM_COUNT_GROUP3) << BIT_SHIFT_DTIM_COUNT_GROUP3)
#define BITS_DTIM_COUNT_GROUP3 \
(BIT_MASK_DTIM_COUNT_GROUP3 << BIT_SHIFT_DTIM_COUNT_GROUP3)
#define BIT_CLEAR_DTIM_COUNT_GROUP3(x) ((x) & (~BITS_DTIM_COUNT_GROUP3))
#define BIT_GET_DTIM_COUNT_GROUP3(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_GROUP3) & BIT_MASK_DTIM_COUNT_GROUP3)
#define BIT_SET_DTIM_COUNT_GROUP3(x, v) \
(BIT_CLEAR_DTIM_COUNT_GROUP3(x) | BIT_DTIM_COUNT_GROUP3(v))
/* 2 REG_DTIM_COUNT_GROUP4 (Offset 0x05A7) */
#define BIT_SHIFT_ATIM_CFG_SEL 24
#define BIT_MASK_ATIM_CFG_SEL 0x3
#define BIT_ATIM_CFG_SEL(x) \
(((x) & BIT_MASK_ATIM_CFG_SEL) << BIT_SHIFT_ATIM_CFG_SEL)
#define BITS_ATIM_CFG_SEL (BIT_MASK_ATIM_CFG_SEL << BIT_SHIFT_ATIM_CFG_SEL)
#define BIT_CLEAR_ATIM_CFG_SEL(x) ((x) & (~BITS_ATIM_CFG_SEL))
#define BIT_GET_ATIM_CFG_SEL(x) \
(((x) >> BIT_SHIFT_ATIM_CFG_SEL) & BIT_MASK_ATIM_CFG_SEL)
#define BIT_SET_ATIM_CFG_SEL(x, v) \
(BIT_CLEAR_ATIM_CFG_SEL(x) | BIT_ATIM_CFG_SEL(v))
#define BIT_SHIFT_ATIM_URGENT_V1 16
#define BIT_MASK_ATIM_URGENT_V1 0xff
#define BIT_ATIM_URGENT_V1(x) \
(((x) & BIT_MASK_ATIM_URGENT_V1) << BIT_SHIFT_ATIM_URGENT_V1)
#define BITS_ATIM_URGENT_V1 \
(BIT_MASK_ATIM_URGENT_V1 << BIT_SHIFT_ATIM_URGENT_V1)
#define BIT_CLEAR_ATIM_URGENT_V1(x) ((x) & (~BITS_ATIM_URGENT_V1))
#define BIT_GET_ATIM_URGENT_V1(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT_V1) & BIT_MASK_ATIM_URGENT_V1)
#define BIT_SET_ATIM_URGENT_V1(x, v) \
(BIT_CLEAR_ATIM_URGENT_V1(x) | BIT_ATIM_URGENT_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_NO_LMT_EN (Offset 0x05A7) */
#define BIT_HIQ_NO_LMT_EN_VAP7 BIT(7)
#define BIT_HIQ_NO_LMT_EN_VAP6 BIT(6)
#define BIT_HIQ_NO_LMT_EN_VAP5 BIT(5)
#define BIT_HIQ_NO_LMT_EN_VAP4 BIT(4)
#define BIT_HIQ_NO_LMT_EN_VAP3 BIT(3)
#define BIT_HIQ_NO_LMT_EN_VAP2 BIT(2)
#define BIT_HIQ_NO_LMT_EN_VAP1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_HIQ_NO_LMT_EN (Offset 0x05A7) */
#define BIT_HIQ_NO_LMT_EN_ROOT BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DTIM_COUNT_GROUP4 (Offset 0x05A7) */
#define BIT_SHIFT_DTIM_COUNT_GROUP4 0
#define BIT_MASK_DTIM_COUNT_GROUP4 0xff
#define BIT_DTIM_COUNT_GROUP4(x) \
(((x) & BIT_MASK_DTIM_COUNT_GROUP4) << BIT_SHIFT_DTIM_COUNT_GROUP4)
#define BITS_DTIM_COUNT_GROUP4 \
(BIT_MASK_DTIM_COUNT_GROUP4 << BIT_SHIFT_DTIM_COUNT_GROUP4)
#define BIT_CLEAR_DTIM_COUNT_GROUP4(x) ((x) & (~BITS_DTIM_COUNT_GROUP4))
#define BIT_GET_DTIM_COUNT_GROUP4(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_GROUP4) & BIT_MASK_DTIM_COUNT_GROUP4)
#define BIT_SET_DTIM_COUNT_GROUP4(x, v) \
(BIT_CLEAR_DTIM_COUNT_GROUP4(x) | BIT_DTIM_COUNT_GROUP4(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIQ_NO_LMT_EN_V2 (Offset 0x05A8) */
#define BIT_SHIFT_DIS_ATIM 16
#define BIT_MASK_DIS_ATIM 0xffff
#define BIT_DIS_ATIM(x) (((x) & BIT_MASK_DIS_ATIM) << BIT_SHIFT_DIS_ATIM)
#define BITS_DIS_ATIM (BIT_MASK_DIS_ATIM << BIT_SHIFT_DIS_ATIM)
#define BIT_CLEAR_DIS_ATIM(x) ((x) & (~BITS_DIS_ATIM))
#define BIT_GET_DIS_ATIM(x) (((x) >> BIT_SHIFT_DIS_ATIM) & BIT_MASK_DIS_ATIM)
#define BIT_SET_DIS_ATIM(x, v) (BIT_CLEAR_DIS_ATIM(x) | BIT_DIS_ATIM(v))
#define BIT_SHIFT_BCNERR_PORT_SEL_V1 16
#define BIT_MASK_BCNERR_PORT_SEL_V1 0xf
#define BIT_BCNERR_PORT_SEL_V1(x) \
(((x) & BIT_MASK_BCNERR_PORT_SEL_V1) << BIT_SHIFT_BCNERR_PORT_SEL_V1)
#define BITS_BCNERR_PORT_SEL_V1 \
(BIT_MASK_BCNERR_PORT_SEL_V1 << BIT_SHIFT_BCNERR_PORT_SEL_V1)
#define BIT_CLEAR_BCNERR_PORT_SEL_V1(x) ((x) & (~BITS_BCNERR_PORT_SEL_V1))
#define BIT_GET_BCNERR_PORT_SEL_V1(x) \
(((x) >> BIT_SHIFT_BCNERR_PORT_SEL_V1) & BIT_MASK_BCNERR_PORT_SEL_V1)
#define BIT_SET_BCNERR_PORT_SEL_V1(x, v) \
(BIT_CLEAR_BCNERR_PORT_SEL_V1(x) | BIT_BCNERR_PORT_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_DTIM_COUNTER_ROOT (Offset 0x05A8) */
#define BIT_SHIFT_DTIM_COUNT_ROOT 0
#define BIT_MASK_DTIM_COUNT_ROOT 0xff
#define BIT_DTIM_COUNT_ROOT(x) \
(((x) & BIT_MASK_DTIM_COUNT_ROOT) << BIT_SHIFT_DTIM_COUNT_ROOT)
#define BITS_DTIM_COUNT_ROOT \
(BIT_MASK_DTIM_COUNT_ROOT << BIT_SHIFT_DTIM_COUNT_ROOT)
#define BIT_CLEAR_DTIM_COUNT_ROOT(x) ((x) & (~BITS_DTIM_COUNT_ROOT))
#define BIT_GET_DTIM_COUNT_ROOT(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_ROOT) & BIT_MASK_DTIM_COUNT_ROOT)
#define BIT_SET_DTIM_COUNT_ROOT(x, v) \
(BIT_CLEAR_DTIM_COUNT_ROOT(x) | BIT_DTIM_COUNT_ROOT(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIQ_NO_LMT_EN_V2 (Offset 0x05A8) */
#define BIT_SHIFT_MBID_BCNQ_EN 0
#define BIT_MASK_MBID_BCNQ_EN 0xffff
#define BIT_MBID_BCNQ_EN(x) \
(((x) & BIT_MASK_MBID_BCNQ_EN) << BIT_SHIFT_MBID_BCNQ_EN)
#define BITS_MBID_BCNQ_EN (BIT_MASK_MBID_BCNQ_EN << BIT_SHIFT_MBID_BCNQ_EN)
#define BIT_CLEAR_MBID_BCNQ_EN(x) ((x) & (~BITS_MBID_BCNQ_EN))
#define BIT_GET_MBID_BCNQ_EN(x) \
(((x) >> BIT_SHIFT_MBID_BCNQ_EN) & BIT_MASK_MBID_BCNQ_EN)
#define BIT_SET_MBID_BCNQ_EN(x, v) \
(BIT_CLEAR_MBID_BCNQ_EN(x) | BIT_MBID_BCNQ_EN(v))
#define BIT_TSF_SYNC_SIGNAL BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_DTIM_COUNTER_VAP1 (Offset 0x05A9) */
#define BIT_SHIFT_DTIM_COUNT_VAP1 0
#define BIT_MASK_DTIM_COUNT_VAP1 0xff
#define BIT_DTIM_COUNT_VAP1(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP1) << BIT_SHIFT_DTIM_COUNT_VAP1)
#define BITS_DTIM_COUNT_VAP1 \
(BIT_MASK_DTIM_COUNT_VAP1 << BIT_SHIFT_DTIM_COUNT_VAP1)
#define BIT_CLEAR_DTIM_COUNT_VAP1(x) ((x) & (~BITS_DTIM_COUNT_VAP1))
#define BIT_GET_DTIM_COUNT_VAP1(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP1) & BIT_MASK_DTIM_COUNT_VAP1)
#define BIT_SET_DTIM_COUNT_VAP1(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP1(x) | BIT_DTIM_COUNT_VAP1(v))
/* 2 REG_DTIM_COUNTER_VAP2 (Offset 0x05AA) */
#define BIT_SHIFT_DTIM_COUNT_VAP2 0
#define BIT_MASK_DTIM_COUNT_VAP2 0xff
#define BIT_DTIM_COUNT_VAP2(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP2) << BIT_SHIFT_DTIM_COUNT_VAP2)
#define BITS_DTIM_COUNT_VAP2 \
(BIT_MASK_DTIM_COUNT_VAP2 << BIT_SHIFT_DTIM_COUNT_VAP2)
#define BIT_CLEAR_DTIM_COUNT_VAP2(x) ((x) & (~BITS_DTIM_COUNT_VAP2))
#define BIT_GET_DTIM_COUNT_VAP2(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP2) & BIT_MASK_DTIM_COUNT_VAP2)
#define BIT_SET_DTIM_COUNT_VAP2(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP2(x) | BIT_DTIM_COUNT_VAP2(v))
/* 2 REG_DTIM_COUNTER_VAP3 (Offset 0x05AB) */
#define BIT_SHIFT_DTIM_COUNT_VAP3 0
#define BIT_MASK_DTIM_COUNT_VAP3 0xff
#define BIT_DTIM_COUNT_VAP3(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP3) << BIT_SHIFT_DTIM_COUNT_VAP3)
#define BITS_DTIM_COUNT_VAP3 \
(BIT_MASK_DTIM_COUNT_VAP3 << BIT_SHIFT_DTIM_COUNT_VAP3)
#define BIT_CLEAR_DTIM_COUNT_VAP3(x) ((x) & (~BITS_DTIM_COUNT_VAP3))
#define BIT_GET_DTIM_COUNT_VAP3(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP3) & BIT_MASK_DTIM_COUNT_VAP3)
#define BIT_SET_DTIM_COUNT_VAP3(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP3(x) | BIT_DTIM_COUNT_VAP3(v))
/* 2 REG_DTIM_COUNTER_VAP4 (Offset 0x05AC) */
#define BIT_SHIFT_DTIM_COUNT_VAP4 0
#define BIT_MASK_DTIM_COUNT_VAP4 0xff
#define BIT_DTIM_COUNT_VAP4(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP4) << BIT_SHIFT_DTIM_COUNT_VAP4)
#define BITS_DTIM_COUNT_VAP4 \
(BIT_MASK_DTIM_COUNT_VAP4 << BIT_SHIFT_DTIM_COUNT_VAP4)
#define BIT_CLEAR_DTIM_COUNT_VAP4(x) ((x) & (~BITS_DTIM_COUNT_VAP4))
#define BIT_GET_DTIM_COUNT_VAP4(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP4) & BIT_MASK_DTIM_COUNT_VAP4)
#define BIT_SET_DTIM_COUNT_VAP4(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP4(x) | BIT_DTIM_COUNT_VAP4(v))
/* 2 REG_DTIM_COUNTER_VAP5 (Offset 0x05AD) */
#define BIT_SHIFT_DTIM_COUNT_VAP5 0
#define BIT_MASK_DTIM_COUNT_VAP5 0xff
#define BIT_DTIM_COUNT_VAP5(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP5) << BIT_SHIFT_DTIM_COUNT_VAP5)
#define BITS_DTIM_COUNT_VAP5 \
(BIT_MASK_DTIM_COUNT_VAP5 << BIT_SHIFT_DTIM_COUNT_VAP5)
#define BIT_CLEAR_DTIM_COUNT_VAP5(x) ((x) & (~BITS_DTIM_COUNT_VAP5))
#define BIT_GET_DTIM_COUNT_VAP5(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP5) & BIT_MASK_DTIM_COUNT_VAP5)
#define BIT_SET_DTIM_COUNT_VAP5(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP5(x) | BIT_DTIM_COUNT_VAP5(v))
/* 2 REG_DTIM_COUNTER_VAP6 (Offset 0x05AE) */
#define BIT_SHIFT_DTIM_COUNT_VAP6 0
#define BIT_MASK_DTIM_COUNT_VAP6 0xff
#define BIT_DTIM_COUNT_VAP6(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP6) << BIT_SHIFT_DTIM_COUNT_VAP6)
#define BITS_DTIM_COUNT_VAP6 \
(BIT_MASK_DTIM_COUNT_VAP6 << BIT_SHIFT_DTIM_COUNT_VAP6)
#define BIT_CLEAR_DTIM_COUNT_VAP6(x) ((x) & (~BITS_DTIM_COUNT_VAP6))
#define BIT_GET_DTIM_COUNT_VAP6(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP6) & BIT_MASK_DTIM_COUNT_VAP6)
#define BIT_SET_DTIM_COUNT_VAP6(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP6(x) | BIT_DTIM_COUNT_VAP6(v))
/* 2 REG_DTIM_COUNTER_VAP7 (Offset 0x05AF) */
#define BIT_SHIFT_DTIM_COUNT_VAP7 0
#define BIT_MASK_DTIM_COUNT_VAP7 0xff
#define BIT_DTIM_COUNT_VAP7(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP7) << BIT_SHIFT_DTIM_COUNT_VAP7)
#define BITS_DTIM_COUNT_VAP7 \
(BIT_MASK_DTIM_COUNT_VAP7 << BIT_SHIFT_DTIM_COUNT_VAP7)
#define BIT_CLEAR_DTIM_COUNT_VAP7(x) ((x) & (~BITS_DTIM_COUNT_VAP7))
#define BIT_GET_DTIM_COUNT_VAP7(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP7) & BIT_MASK_DTIM_COUNT_VAP7)
#define BIT_SET_DTIM_COUNT_VAP7(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP7(x) | BIT_DTIM_COUNT_VAP7(v))
/* 2 REG_DIS_ATIM (Offset 0x05B0) */
#define BIT_MBIDCAM_VALID BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_DIS_ATIM (Offset 0x05B0) */
#define BIT_DIS_ATIM_VAP7 BIT(7)
#define BIT_DIS_ATIM_VAP6 BIT(6)
#define BIT_DIS_ATIM_VAP5 BIT(5)
#define BIT_DIS_ATIM_VAP4 BIT(4)
#define BIT_DIS_ATIM_VAP3 BIT(3)
#define BIT_DIS_ATIM_VAP2 BIT(2)
#define BIT_DIS_ATIM_VAP1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_DIS_ATIM (Offset 0x05B0) */
#define BIT_DIS_ATIM_ROOT BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_EARLY_128US (Offset 0x05B1) */
#define BIT_SHIFT_EARLY_128US_2ST 3
#define BIT_MASK_EARLY_128US_2ST 0x7
#define BIT_EARLY_128US_2ST(x) \
(((x) & BIT_MASK_EARLY_128US_2ST) << BIT_SHIFT_EARLY_128US_2ST)
#define BITS_EARLY_128US_2ST \
(BIT_MASK_EARLY_128US_2ST << BIT_SHIFT_EARLY_128US_2ST)
#define BIT_CLEAR_EARLY_128US_2ST(x) ((x) & (~BITS_EARLY_128US_2ST))
#define BIT_GET_EARLY_128US_2ST(x) \
(((x) >> BIT_SHIFT_EARLY_128US_2ST) & BIT_MASK_EARLY_128US_2ST)
#define BIT_SET_EARLY_128US_2ST(x, v) \
(BIT_CLEAR_EARLY_128US_2ST(x) | BIT_EARLY_128US_2ST(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_EARLY_128US (Offset 0x05B1) */
#define BIT_SHIFT_TSFT_SEL_TIMER1 3
#define BIT_MASK_TSFT_SEL_TIMER1 0x7
#define BIT_TSFT_SEL_TIMER1(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER1) << BIT_SHIFT_TSFT_SEL_TIMER1)
#define BITS_TSFT_SEL_TIMER1 \
(BIT_MASK_TSFT_SEL_TIMER1 << BIT_SHIFT_TSFT_SEL_TIMER1)
#define BIT_CLEAR_TSFT_SEL_TIMER1(x) ((x) & (~BITS_TSFT_SEL_TIMER1))
#define BIT_GET_TSFT_SEL_TIMER1(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER1) & BIT_MASK_TSFT_SEL_TIMER1)
#define BIT_SET_TSFT_SEL_TIMER1(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER1(x) | BIT_TSFT_SEL_TIMER1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TBTT_HOLD_PREDICT_P1 (Offset 0x05B2) */
#define BIT_DIS_BCN_3RD BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_CTRL (Offset 0x05B2) */
#define BIT_P2P1_CTW_ALLSTASLEEP BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TBTT_HOLD_PREDICT_P1 (Offset 0x05B2) */
#define BIT_DIS_BCN_2ST BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_CTRL (Offset 0x05B2) */
#define BIT_P2P1_OFF_DISTX_EN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TBTT_HOLD_PREDICT_P1 (Offset 0x05B2) */
#define BIT_DIS_BCN_1ST BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS1_CTRL (Offset 0x05B2) */
#define BIT_P2P1_PWR_MGT_EN BIT(5)
#define BIT_P2P1_NOA1_EN BIT(2)
#define BIT_P2P1_NOA0_EN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TBTT_HOLD_PREDICT_P1 (Offset 0x05B2) */
#define BIT_SHIFT_TBTT_HOLD_PREDICT_P1 0
#define BIT_MASK_TBTT_HOLD_PREDICT_P1 0x1f
#define BIT_TBTT_HOLD_PREDICT_P1(x) \
(((x) & BIT_MASK_TBTT_HOLD_PREDICT_P1) \
<< BIT_SHIFT_TBTT_HOLD_PREDICT_P1)
#define BITS_TBTT_HOLD_PREDICT_P1 \
(BIT_MASK_TBTT_HOLD_PREDICT_P1 << BIT_SHIFT_TBTT_HOLD_PREDICT_P1)
#define BIT_CLEAR_TBTT_HOLD_PREDICT_P1(x) ((x) & (~BITS_TBTT_HOLD_PREDICT_P1))
#define BIT_GET_TBTT_HOLD_PREDICT_P1(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_PREDICT_P1) & \
BIT_MASK_TBTT_HOLD_PREDICT_P1)
#define BIT_SET_TBTT_HOLD_PREDICT_P1(x, v) \
(BIT_CLEAR_TBTT_HOLD_PREDICT_P1(x) | BIT_TBTT_HOLD_PREDICT_P1(v))
/* 2 REG_MULTI_BCN_CS (Offset 0x05B3) */
#define BIT_EN_FREECNT_V2 BIT(13)
#define BIT_RESET_FREECNT_P BIT(12)
#define BIT_TSFTR3_SYNC_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_CTRL (Offset 0x05B3) */
#define BIT_P2P2_CTW_ALLSTASLEEP BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MULTI_BCN_CS (Offset 0x05B3) */
#define BIT_SHIFT_P1_TSFT_SHIFT 6
#define BIT_MASK_P1_TSFT_SHIFT 0x3f
#define BIT_P1_TSFT_SHIFT(x) \
(((x) & BIT_MASK_P1_TSFT_SHIFT) << BIT_SHIFT_P1_TSFT_SHIFT)
#define BITS_P1_TSFT_SHIFT (BIT_MASK_P1_TSFT_SHIFT << BIT_SHIFT_P1_TSFT_SHIFT)
#define BIT_CLEAR_P1_TSFT_SHIFT(x) ((x) & (~BITS_P1_TSFT_SHIFT))
#define BIT_GET_P1_TSFT_SHIFT(x) \
(((x) >> BIT_SHIFT_P1_TSFT_SHIFT) & BIT_MASK_P1_TSFT_SHIFT)
#define BIT_SET_P1_TSFT_SHIFT(x, v) \
(BIT_CLEAR_P1_TSFT_SHIFT(x) | BIT_P1_TSFT_SHIFT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_CTRL (Offset 0x05B3) */
#define BIT_P2P2_OFF_DISTX_EN BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MULTI_BCN_CS (Offset 0x05B3) */
#define BIT_TSFTR2_SYNC_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_CTRL (Offset 0x05B3) */
#define BIT_P2P2_PWR_MGT_EN BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MULTI_BCN_CS (Offset 0x05B3) */
#define BIT_TSFTR2_RST BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS2_CTRL (Offset 0x05B3) */
#define BIT_P2P2_NOA1_EN BIT(2)
#define BIT_P2P2_NOA0_EN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MULTI_BCN_CS (Offset 0x05B3) */
#define BIT_SHIFT_MULTI_BCN_CS 0
#define BIT_MASK_MULTI_BCN_CS 0xf
#define BIT_MULTI_BCN_CS(x) \
(((x) & BIT_MASK_MULTI_BCN_CS) << BIT_SHIFT_MULTI_BCN_CS)
#define BITS_MULTI_BCN_CS (BIT_MASK_MULTI_BCN_CS << BIT_SHIFT_MULTI_BCN_CS)
#define BIT_CLEAR_MULTI_BCN_CS(x) ((x) & (~BITS_MULTI_BCN_CS))
#define BIT_GET_MULTI_BCN_CS(x) \
(((x) >> BIT_SHIFT_MULTI_BCN_CS) & BIT_MASK_MULTI_BCN_CS)
#define BIT_SET_MULTI_BCN_CS(x, v) \
(BIT_CLEAR_MULTI_BCN_CS(x) | BIT_MULTI_BCN_CS(v))
#define BIT_SHIFT_P0_TSFT_SHIFT 0
#define BIT_MASK_P0_TSFT_SHIFT 0x3f
#define BIT_P0_TSFT_SHIFT(x) \
(((x) & BIT_MASK_P0_TSFT_SHIFT) << BIT_SHIFT_P0_TSFT_SHIFT)
#define BITS_P0_TSFT_SHIFT (BIT_MASK_P0_TSFT_SHIFT << BIT_SHIFT_P0_TSFT_SHIFT)
#define BIT_CLEAR_P0_TSFT_SHIFT(x) ((x) & (~BITS_P0_TSFT_SHIFT))
#define BIT_GET_P0_TSFT_SHIFT(x) \
(((x) >> BIT_SHIFT_P0_TSFT_SHIFT) & BIT_MASK_P0_TSFT_SHIFT)
#define BIT_SET_P0_TSFT_SHIFT(x, v) \
(BIT_CLEAR_P0_TSFT_SHIFT(x) | BIT_P0_TSFT_SHIFT(v))
#define BIT_DIS_NDPA_NAV_CHK_V1 BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TIMER0_SRC_SEL (Offset 0x05B4) */
#define BIT_SHIFT_SYNC_CLI_SEL 4
#define BIT_MASK_SYNC_CLI_SEL 0x7
#define BIT_SYNC_CLI_SEL(x) \
(((x) & BIT_MASK_SYNC_CLI_SEL) << BIT_SHIFT_SYNC_CLI_SEL)
#define BITS_SYNC_CLI_SEL (BIT_MASK_SYNC_CLI_SEL << BIT_SHIFT_SYNC_CLI_SEL)
#define BIT_CLEAR_SYNC_CLI_SEL(x) ((x) & (~BITS_SYNC_CLI_SEL))
#define BIT_GET_SYNC_CLI_SEL(x) \
(((x) >> BIT_SHIFT_SYNC_CLI_SEL) & BIT_MASK_SYNC_CLI_SEL)
#define BIT_SET_SYNC_CLI_SEL(x, v) \
(BIT_CLEAR_SYNC_CLI_SEL(x) | BIT_SYNC_CLI_SEL(v))
#define BIT_SHIFT_TSFT_SEL_TIMER0 0
#define BIT_MASK_TSFT_SEL_TIMER0 0x7
#define BIT_TSFT_SEL_TIMER0(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER0) << BIT_SHIFT_TSFT_SEL_TIMER0)
#define BITS_TSFT_SEL_TIMER0 \
(BIT_MASK_TSFT_SEL_TIMER0 << BIT_SHIFT_TSFT_SEL_TIMER0)
#define BIT_CLEAR_TSFT_SEL_TIMER0(x) ((x) & (~BITS_TSFT_SEL_TIMER0))
#define BIT_GET_TSFT_SEL_TIMER0(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER0) & BIT_MASK_TSFT_SEL_TIMER0)
#define BIT_SET_TSFT_SEL_TIMER0(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER0(x) | BIT_TSFT_SEL_TIMER0(v))
/* 2 REG_NOA_UNIT_SEL (Offset 0x05B5) */
#define BIT_SHIFT_NOA_UNIT2_SEL 8
#define BIT_MASK_NOA_UNIT2_SEL 0x7
#define BIT_NOA_UNIT2_SEL(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL) << BIT_SHIFT_NOA_UNIT2_SEL)
#define BITS_NOA_UNIT2_SEL (BIT_MASK_NOA_UNIT2_SEL << BIT_SHIFT_NOA_UNIT2_SEL)
#define BIT_CLEAR_NOA_UNIT2_SEL(x) ((x) & (~BITS_NOA_UNIT2_SEL))
#define BIT_GET_NOA_UNIT2_SEL(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL) & BIT_MASK_NOA_UNIT2_SEL)
#define BIT_SET_NOA_UNIT2_SEL(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL(x) | BIT_NOA_UNIT2_SEL(v))
#define BIT_SHIFT_NOA_UNIT1_SEL 4
#define BIT_MASK_NOA_UNIT1_SEL 0x7
#define BIT_NOA_UNIT1_SEL(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL) << BIT_SHIFT_NOA_UNIT1_SEL)
#define BITS_NOA_UNIT1_SEL (BIT_MASK_NOA_UNIT1_SEL << BIT_SHIFT_NOA_UNIT1_SEL)
#define BIT_CLEAR_NOA_UNIT1_SEL(x) ((x) & (~BITS_NOA_UNIT1_SEL))
#define BIT_GET_NOA_UNIT1_SEL(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL) & BIT_MASK_NOA_UNIT1_SEL)
#define BIT_SET_NOA_UNIT1_SEL(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL(x) | BIT_NOA_UNIT1_SEL(v))
#define BIT_SHIFT_NOA_UNIT0_SEL 0
#define BIT_MASK_NOA_UNIT0_SEL 0x7
#define BIT_NOA_UNIT0_SEL(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL) << BIT_SHIFT_NOA_UNIT0_SEL)
#define BITS_NOA_UNIT0_SEL (BIT_MASK_NOA_UNIT0_SEL << BIT_SHIFT_NOA_UNIT0_SEL)
#define BIT_CLEAR_NOA_UNIT0_SEL(x) ((x) & (~BITS_NOA_UNIT0_SEL))
#define BIT_GET_NOA_UNIT0_SEL(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL) & BIT_MASK_NOA_UNIT0_SEL)
#define BIT_SET_NOA_UNIT0_SEL(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL(x) | BIT_NOA_UNIT0_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2POFF_DIS_TXTIME (Offset 0x05B7) */
#define BIT_SHIFT_P2POFF_DIS_TXTIME 0
#define BIT_MASK_P2POFF_DIS_TXTIME 0xff
#define BIT_P2POFF_DIS_TXTIME(x) \
(((x) & BIT_MASK_P2POFF_DIS_TXTIME) << BIT_SHIFT_P2POFF_DIS_TXTIME)
#define BITS_P2POFF_DIS_TXTIME \
(BIT_MASK_P2POFF_DIS_TXTIME << BIT_SHIFT_P2POFF_DIS_TXTIME)
#define BIT_CLEAR_P2POFF_DIS_TXTIME(x) ((x) & (~BITS_P2POFF_DIS_TXTIME))
#define BIT_GET_P2POFF_DIS_TXTIME(x) \
(((x) >> BIT_SHIFT_P2POFF_DIS_TXTIME) & BIT_MASK_P2POFF_DIS_TXTIME)
#define BIT_SET_P2POFF_DIS_TXTIME(x, v) \
(BIT_CLEAR_P2POFF_DIS_TXTIME(x) | BIT_P2POFF_DIS_TXTIME(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MBSSID_BCN_SPACE2 (Offset 0x05B8) */
#define BIT_SHIFT_BCN_SPACE_CLINT2 16
#define BIT_MASK_BCN_SPACE_CLINT2 0xfff
#define BIT_BCN_SPACE_CLINT2(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT2) << BIT_SHIFT_BCN_SPACE_CLINT2)
#define BITS_BCN_SPACE_CLINT2 \
(BIT_MASK_BCN_SPACE_CLINT2 << BIT_SHIFT_BCN_SPACE_CLINT2)
#define BIT_CLEAR_BCN_SPACE_CLINT2(x) ((x) & (~BITS_BCN_SPACE_CLINT2))
#define BIT_GET_BCN_SPACE_CLINT2(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT2) & BIT_MASK_BCN_SPACE_CLINT2)
#define BIT_SET_BCN_SPACE_CLINT2(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT2(x) | BIT_BCN_SPACE_CLINT2(v))
#define BIT_SHIFT_BCN_SPACE_CLINT1 0
#define BIT_MASK_BCN_SPACE_CLINT1 0xfff
#define BIT_BCN_SPACE_CLINT1(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT1) << BIT_SHIFT_BCN_SPACE_CLINT1)
#define BITS_BCN_SPACE_CLINT1 \
(BIT_MASK_BCN_SPACE_CLINT1 << BIT_SHIFT_BCN_SPACE_CLINT1)
#define BIT_CLEAR_BCN_SPACE_CLINT1(x) ((x) & (~BITS_BCN_SPACE_CLINT1))
#define BIT_GET_BCN_SPACE_CLINT1(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT1) & BIT_MASK_BCN_SPACE_CLINT1)
#define BIT_SET_BCN_SPACE_CLINT1(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT1(x) | BIT_BCN_SPACE_CLINT1(v))
/* 2 REG_MBSSID_BCN_SPACE3 (Offset 0x05BC) */
#define BIT_SHIFT_SUB_BCN_SPACE 16
#define BIT_MASK_SUB_BCN_SPACE 0xff
#define BIT_SUB_BCN_SPACE(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE) << BIT_SHIFT_SUB_BCN_SPACE)
#define BITS_SUB_BCN_SPACE (BIT_MASK_SUB_BCN_SPACE << BIT_SHIFT_SUB_BCN_SPACE)
#define BIT_CLEAR_SUB_BCN_SPACE(x) ((x) & (~BITS_SUB_BCN_SPACE))
#define BIT_GET_SUB_BCN_SPACE(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE) & BIT_MASK_SUB_BCN_SPACE)
#define BIT_SET_SUB_BCN_SPACE(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE(x) | BIT_SUB_BCN_SPACE(v))
#define BIT_SHIFT_BCN_SPACE_CLINT3 0
#define BIT_MASK_BCN_SPACE_CLINT3 0xfff
#define BIT_BCN_SPACE_CLINT3(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT3) << BIT_SHIFT_BCN_SPACE_CLINT3)
#define BITS_BCN_SPACE_CLINT3 \
(BIT_MASK_BCN_SPACE_CLINT3 << BIT_SHIFT_BCN_SPACE_CLINT3)
#define BIT_CLEAR_BCN_SPACE_CLINT3(x) ((x) & (~BITS_BCN_SPACE_CLINT3))
#define BIT_GET_BCN_SPACE_CLINT3(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT3) & BIT_MASK_BCN_SPACE_CLINT3)
#define BIT_SET_BCN_SPACE_CLINT3(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT3(x) | BIT_BCN_SPACE_CLINT3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ACMHWCTRL (Offset 0x05C0) */
#define BIT_BEQ_ACM_STATUS BIT(7)
#define BIT_VIQ_ACM_STATUS BIT(6)
#define BIT_VOQ_ACM_STATUS BIT(5)
#define BIT_BEQ_ACM_EN BIT(3)
#define BIT_VIQ_ACM_EN BIT(2)
#define BIT_VOQ_ACM_EN BIT(1)
#define BIT_ACMHWEN BIT(0)
/* 2 REG_ACMRSTCTRL (Offset 0x05C1) */
#define BIT_BE_ACM_RESET_USED_TIME BIT(2)
#define BIT_VI_ACM_RESET_USED_TIME BIT(1)
#define BIT_VO_ACM_RESET_USED_TIME BIT(0)
/* 2 REG_ACMAVG (Offset 0x05C2) */
#define BIT_SHIFT_AVGPERIOD 0
#define BIT_MASK_AVGPERIOD 0xffff
#define BIT_AVGPERIOD(x) (((x) & BIT_MASK_AVGPERIOD) << BIT_SHIFT_AVGPERIOD)
#define BITS_AVGPERIOD (BIT_MASK_AVGPERIOD << BIT_SHIFT_AVGPERIOD)
#define BIT_CLEAR_AVGPERIOD(x) ((x) & (~BITS_AVGPERIOD))
#define BIT_GET_AVGPERIOD(x) (((x) >> BIT_SHIFT_AVGPERIOD) & BIT_MASK_AVGPERIOD)
#define BIT_SET_AVGPERIOD(x, v) (BIT_CLEAR_AVGPERIOD(x) | BIT_AVGPERIOD(v))
/* 2 REG_VO_ADMTIME (Offset 0x05C4) */
#define BIT_SHIFT_VO_ADMITTED_TIME 0
#define BIT_MASK_VO_ADMITTED_TIME 0xffff
#define BIT_VO_ADMITTED_TIME(x) \
(((x) & BIT_MASK_VO_ADMITTED_TIME) << BIT_SHIFT_VO_ADMITTED_TIME)
#define BITS_VO_ADMITTED_TIME \
(BIT_MASK_VO_ADMITTED_TIME << BIT_SHIFT_VO_ADMITTED_TIME)
#define BIT_CLEAR_VO_ADMITTED_TIME(x) ((x) & (~BITS_VO_ADMITTED_TIME))
#define BIT_GET_VO_ADMITTED_TIME(x) \
(((x) >> BIT_SHIFT_VO_ADMITTED_TIME) & BIT_MASK_VO_ADMITTED_TIME)
#define BIT_SET_VO_ADMITTED_TIME(x, v) \
(BIT_CLEAR_VO_ADMITTED_TIME(x) | BIT_VO_ADMITTED_TIME(v))
/* 2 REG_VI_ADMTIME (Offset 0x05C6) */
#define BIT_SHIFT_VI_ADMITTED_TIME 0
#define BIT_MASK_VI_ADMITTED_TIME 0xffff
#define BIT_VI_ADMITTED_TIME(x) \
(((x) & BIT_MASK_VI_ADMITTED_TIME) << BIT_SHIFT_VI_ADMITTED_TIME)
#define BITS_VI_ADMITTED_TIME \
(BIT_MASK_VI_ADMITTED_TIME << BIT_SHIFT_VI_ADMITTED_TIME)
#define BIT_CLEAR_VI_ADMITTED_TIME(x) ((x) & (~BITS_VI_ADMITTED_TIME))
#define BIT_GET_VI_ADMITTED_TIME(x) \
(((x) >> BIT_SHIFT_VI_ADMITTED_TIME) & BIT_MASK_VI_ADMITTED_TIME)
#define BIT_SET_VI_ADMITTED_TIME(x, v) \
(BIT_CLEAR_VI_ADMITTED_TIME(x) | BIT_VI_ADMITTED_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BE_ADMTIME (Offset 0x05C8) */
#define BIT_PRETX_ERRHDL_EN BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BE_ADMTIME (Offset 0x05C8) */
#define BIT_CHANGE_POW_BCN_AREA BIT(9)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BE_ADMTIME (Offset 0x05C8) */
#define BIT_DIS_NDPA_NAV_CHK BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BE_ADMTIME (Offset 0x05C8) */
#define BIT_SHIFT_BE_ADMITTED_TIME 0
#define BIT_MASK_BE_ADMITTED_TIME 0xffff
#define BIT_BE_ADMITTED_TIME(x) \
(((x) & BIT_MASK_BE_ADMITTED_TIME) << BIT_SHIFT_BE_ADMITTED_TIME)
#define BITS_BE_ADMITTED_TIME \
(BIT_MASK_BE_ADMITTED_TIME << BIT_SHIFT_BE_ADMITTED_TIME)
#define BIT_CLEAR_BE_ADMITTED_TIME(x) ((x) & (~BITS_BE_ADMITTED_TIME))
#define BIT_GET_BE_ADMITTED_TIME(x) \
(((x) >> BIT_SHIFT_BE_ADMITTED_TIME) & BIT_MASK_BE_ADMITTED_TIME)
#define BIT_SET_BE_ADMITTED_TIME(x, v) \
(BIT_CLEAR_BE_ADMITTED_TIME(x) | BIT_BE_ADMITTED_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BE_ADMTIME (Offset 0x05C8) */
#define BIT_SHIFT_MHDR_NAV_OFFSET 0
#define BIT_MASK_MHDR_NAV_OFFSET 0xff
#define BIT_MHDR_NAV_OFFSET(x) \
(((x) & BIT_MASK_MHDR_NAV_OFFSET) << BIT_SHIFT_MHDR_NAV_OFFSET)
#define BITS_MHDR_NAV_OFFSET \
(BIT_MASK_MHDR_NAV_OFFSET << BIT_SHIFT_MHDR_NAV_OFFSET)
#define BIT_CLEAR_MHDR_NAV_OFFSET(x) ((x) & (~BITS_MHDR_NAV_OFFSET))
#define BIT_GET_MHDR_NAV_OFFSET(x) \
(((x) >> BIT_SHIFT_MHDR_NAV_OFFSET) & BIT_MASK_MHDR_NAV_OFFSET)
#define BIT_SET_MHDR_NAV_OFFSET(x, v) \
(BIT_CLEAR_MHDR_NAV_OFFSET(x) | BIT_MHDR_NAV_OFFSET(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAC_HEADER_NAV_OFFSET (Offset 0x05CA) */
#define BIT_SHIFT_MAC_HEADER_NAV_OFFSET 0
#define BIT_MASK_MAC_HEADER_NAV_OFFSET 0xff
#define BIT_MAC_HEADER_NAV_OFFSET(x) \
(((x) & BIT_MASK_MAC_HEADER_NAV_OFFSET) \
<< BIT_SHIFT_MAC_HEADER_NAV_OFFSET)
#define BITS_MAC_HEADER_NAV_OFFSET \
(BIT_MASK_MAC_HEADER_NAV_OFFSET << BIT_SHIFT_MAC_HEADER_NAV_OFFSET)
#define BIT_CLEAR_MAC_HEADER_NAV_OFFSET(x) ((x) & (~BITS_MAC_HEADER_NAV_OFFSET))
#define BIT_GET_MAC_HEADER_NAV_OFFSET(x) \
(((x) >> BIT_SHIFT_MAC_HEADER_NAV_OFFSET) & \
BIT_MASK_MAC_HEADER_NAV_OFFSET)
#define BIT_SET_MAC_HEADER_NAV_OFFSET(x, v) \
(BIT_CLEAR_MAC_HEADER_NAV_OFFSET(x) | BIT_MAC_HEADER_NAV_OFFSET(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DIS_NDPA_NAV_CHECK (Offset 0x05CB) */
#define BIT_CHG_POWER_BCN_AREA_V1 BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DIS_NDPA_NAV_CHECK (Offset 0x05CB) */
#define BIT_DIS_NDPA_NAV_CHECK BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_EDCA_RANDOM_GEN (Offset 0x05CC) */
#define BIT_SHIFT_RANDOM_GEN 0
#define BIT_MASK_RANDOM_GEN 0xffffff
#define BIT_RANDOM_GEN(x) (((x) & BIT_MASK_RANDOM_GEN) << BIT_SHIFT_RANDOM_GEN)
#define BITS_RANDOM_GEN (BIT_MASK_RANDOM_GEN << BIT_SHIFT_RANDOM_GEN)
#define BIT_CLEAR_RANDOM_GEN(x) ((x) & (~BITS_RANDOM_GEN))
#define BIT_GET_RANDOM_GEN(x) \
(((x) >> BIT_SHIFT_RANDOM_GEN) & BIT_MASK_RANDOM_GEN)
#define BIT_SET_RANDOM_GEN(x, v) (BIT_CLEAR_RANDOM_GEN(x) | BIT_RANDOM_GEN(v))
#define BIT_SHIFT_TXCMD_SEG_SEL 0
#define BIT_MASK_TXCMD_SEG_SEL 0xf
#define BIT_TXCMD_SEG_SEL(x) \
(((x) & BIT_MASK_TXCMD_SEG_SEL) << BIT_SHIFT_TXCMD_SEG_SEL)
#define BITS_TXCMD_SEG_SEL (BIT_MASK_TXCMD_SEG_SEL << BIT_SHIFT_TXCMD_SEG_SEL)
#define BIT_CLEAR_TXCMD_SEG_SEL(x) ((x) & (~BITS_TXCMD_SEG_SEL))
#define BIT_GET_TXCMD_SEG_SEL(x) \
(((x) >> BIT_SHIFT_TXCMD_SEG_SEL) & BIT_MASK_TXCMD_SEG_SEL)
#define BIT_SET_TXCMD_SEG_SEL(x, v) \
(BIT_CLEAR_TXCMD_SEG_SEL(x) | BIT_TXCMD_SEG_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TXCMD_NOA_SEL (Offset 0x05CF) */
#define BIT_SHIFT_EVTQ_EARLY 5
#define BIT_MASK_EVTQ_EARLY 0x7
#define BIT_EVTQ_EARLY(x) (((x) & BIT_MASK_EVTQ_EARLY) << BIT_SHIFT_EVTQ_EARLY)
#define BITS_EVTQ_EARLY (BIT_MASK_EVTQ_EARLY << BIT_SHIFT_EVTQ_EARLY)
#define BIT_CLEAR_EVTQ_EARLY(x) ((x) & (~BITS_EVTQ_EARLY))
#define BIT_GET_EVTQ_EARLY(x) \
(((x) >> BIT_SHIFT_EVTQ_EARLY) & BIT_MASK_EVTQ_EARLY)
#define BIT_SET_EVTQ_EARLY(x, v) (BIT_CLEAR_EVTQ_EARLY(x) | BIT_EVTQ_EARLY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TXCMD_NOA_SEL (Offset 0x05CF) */
#define BIT_NOA_SEL BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXCMD_NOA_SEL (Offset 0x05CF) */
#define BIT_SHIFT_NOA_SEL_V2 4
#define BIT_MASK_NOA_SEL_V2 0x7
#define BIT_NOA_SEL_V2(x) (((x) & BIT_MASK_NOA_SEL_V2) << BIT_SHIFT_NOA_SEL_V2)
#define BITS_NOA_SEL_V2 (BIT_MASK_NOA_SEL_V2 << BIT_SHIFT_NOA_SEL_V2)
#define BIT_CLEAR_NOA_SEL_V2(x) ((x) & (~BITS_NOA_SEL_V2))
#define BIT_GET_NOA_SEL_V2(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V2) & BIT_MASK_NOA_SEL_V2)
#define BIT_SET_NOA_SEL_V2(x, v) (BIT_CLEAR_NOA_SEL_V2(x) | BIT_NOA_SEL_V2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BCNERR_CFG (Offset 0x05D0) */
#define BIT_BCNERR_CNT_EN BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_32K_CLK_SEL (Offset 0x05D0) */
#define BIT_R_BCNERR_CNT_EN BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DRVERLYINT2 (Offset 0x05D0) */
#define BIT_SHIFT_TSF_DIFF_P1P2 16
#define BIT_MASK_TSF_DIFF_P1P2 0xffff
#define BIT_TSF_DIFF_P1P2(x) \
(((x) & BIT_MASK_TSF_DIFF_P1P2) << BIT_SHIFT_TSF_DIFF_P1P2)
#define BITS_TSF_DIFF_P1P2 (BIT_MASK_TSF_DIFF_P1P2 << BIT_SHIFT_TSF_DIFF_P1P2)
#define BIT_CLEAR_TSF_DIFF_P1P2(x) ((x) & (~BITS_TSF_DIFF_P1P2))
#define BIT_GET_TSF_DIFF_P1P2(x) \
(((x) >> BIT_SHIFT_TSF_DIFF_P1P2) & BIT_MASK_TSF_DIFF_P1P2)
#define BIT_SET_TSF_DIFF_P1P2(x, v) \
(BIT_CLEAR_TSF_DIFF_P1P2(x) | BIT_TSF_DIFF_P1P2(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_BCNERR_CFG (Offset 0x05D0) */
#define BIT_SHIFT_BCNERR_PORT_SEL_V2 16
#define BIT_MASK_BCNERR_PORT_SEL_V2 0x7
#define BIT_BCNERR_PORT_SEL_V2(x) \
(((x) & BIT_MASK_BCNERR_PORT_SEL_V2) << BIT_SHIFT_BCNERR_PORT_SEL_V2)
#define BITS_BCNERR_PORT_SEL_V2 \
(BIT_MASK_BCNERR_PORT_SEL_V2 << BIT_SHIFT_BCNERR_PORT_SEL_V2)
#define BIT_CLEAR_BCNERR_PORT_SEL_V2(x) ((x) & (~BITS_BCNERR_PORT_SEL_V2))
#define BIT_GET_BCNERR_PORT_SEL_V2(x) \
(((x) >> BIT_SHIFT_BCNERR_PORT_SEL_V2) & BIT_MASK_BCNERR_PORT_SEL_V2)
#define BIT_SET_BCNERR_PORT_SEL_V2(x, v) \
(BIT_CLEAR_BCNERR_PORT_SEL_V2(x) | BIT_BCNERR_PORT_SEL_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_32K_CLK_SEL (Offset 0x05D0) */
#define BIT_SHIFT_R_BCNERR_PORT_SEL 16
#define BIT_MASK_R_BCNERR_PORT_SEL 0x7
#define BIT_R_BCNERR_PORT_SEL(x) \
(((x) & BIT_MASK_R_BCNERR_PORT_SEL) << BIT_SHIFT_R_BCNERR_PORT_SEL)
#define BITS_R_BCNERR_PORT_SEL \
(BIT_MASK_R_BCNERR_PORT_SEL << BIT_SHIFT_R_BCNERR_PORT_SEL)
#define BIT_CLEAR_R_BCNERR_PORT_SEL(x) ((x) & (~BITS_R_BCNERR_PORT_SEL))
#define BIT_GET_R_BCNERR_PORT_SEL(x) \
(((x) >> BIT_SHIFT_R_BCNERR_PORT_SEL) & BIT_MASK_R_BCNERR_PORT_SEL)
#define BIT_SET_R_BCNERR_PORT_SEL(x, v) \
(BIT_CLEAR_R_BCNERR_PORT_SEL(x) | BIT_R_BCNERR_PORT_SEL(v))
#define BIT_SHIFT_R_TXPAUSE1 8
#define BIT_MASK_R_TXPAUSE1 0xff
#define BIT_R_TXPAUSE1(x) (((x) & BIT_MASK_R_TXPAUSE1) << BIT_SHIFT_R_TXPAUSE1)
#define BITS_R_TXPAUSE1 (BIT_MASK_R_TXPAUSE1 << BIT_SHIFT_R_TXPAUSE1)
#define BIT_CLEAR_R_TXPAUSE1(x) ((x) & (~BITS_R_TXPAUSE1))
#define BIT_GET_R_TXPAUSE1(x) \
(((x) >> BIT_SHIFT_R_TXPAUSE1) & BIT_MASK_R_TXPAUSE1)
#define BIT_SET_R_TXPAUSE1(x, v) (BIT_CLEAR_R_TXPAUSE1(x) | BIT_R_TXPAUSE1(v))
#define BIT_SLEEP_32K_EN_V1 BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_DRVERLYINT2 (Offset 0x05D0) */
#define BIT_SHIFT_DRVERLYITV2 0
#define BIT_MASK_DRVERLYITV2 0xff
#define BIT_DRVERLYITV2(x) \
(((x) & BIT_MASK_DRVERLYITV2) << BIT_SHIFT_DRVERLYITV2)
#define BITS_DRVERLYITV2 (BIT_MASK_DRVERLYITV2 << BIT_SHIFT_DRVERLYITV2)
#define BIT_CLEAR_DRVERLYITV2(x) ((x) & (~BITS_DRVERLYITV2))
#define BIT_GET_DRVERLYITV2(x) \
(((x) >> BIT_SHIFT_DRVERLYITV2) & BIT_MASK_DRVERLYITV2)
#define BIT_SET_DRVERLYITV2(x, v) \
(BIT_CLEAR_DRVERLYITV2(x) | BIT_DRVERLYITV2(v))
/* 2 REG_NAN_SETTING (Offset 0x05D4) */
#define BIT_EN_MULTI_BCN BIT(31)
#define BIT_ENP2P_DW_AREA BIT(30)
#define BIT_SHIFT_TBTT_PROHIBIT_HOLD_P2 18
#define BIT_MASK_TBTT_PROHIBIT_HOLD_P2 0xfff
#define BIT_TBTT_PROHIBIT_HOLD_P2(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_HOLD_P2) \
<< BIT_SHIFT_TBTT_PROHIBIT_HOLD_P2)
#define BITS_TBTT_PROHIBIT_HOLD_P2 \
(BIT_MASK_TBTT_PROHIBIT_HOLD_P2 << BIT_SHIFT_TBTT_PROHIBIT_HOLD_P2)
#define BIT_CLEAR_TBTT_PROHIBIT_HOLD_P2(x) ((x) & (~BITS_TBTT_PROHIBIT_HOLD_P2))
#define BIT_GET_TBTT_PROHIBIT_HOLD_P2(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_HOLD_P2) & \
BIT_MASK_TBTT_PROHIBIT_HOLD_P2)
#define BIT_SET_TBTT_PROHIBIT_HOLD_P2(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_HOLD_P2(x) | BIT_TBTT_PROHIBIT_HOLD_P2(v))
#define BIT_SHIFT_BCN_PORT_PRI 16
#define BIT_MASK_BCN_PORT_PRI 0x3
#define BIT_BCN_PORT_PRI(x) \
(((x) & BIT_MASK_BCN_PORT_PRI) << BIT_SHIFT_BCN_PORT_PRI)
#define BITS_BCN_PORT_PRI (BIT_MASK_BCN_PORT_PRI << BIT_SHIFT_BCN_PORT_PRI)
#define BIT_CLEAR_BCN_PORT_PRI(x) ((x) & (~BITS_BCN_PORT_PRI))
#define BIT_GET_BCN_PORT_PRI(x) \
(((x) >> BIT_SHIFT_BCN_PORT_PRI) & BIT_MASK_BCN_PORT_PRI)
#define BIT_SET_BCN_PORT_PRI(x, v) \
(BIT_CLEAR_BCN_PORT_PRI(x) | BIT_BCN_PORT_PRI(v))
#define BIT_SHIFT_DRVERLYITV1 8
#define BIT_MASK_DRVERLYITV1 0xff
#define BIT_DRVERLYITV1(x) \
(((x) & BIT_MASK_DRVERLYITV1) << BIT_SHIFT_DRVERLYITV1)
#define BITS_DRVERLYITV1 (BIT_MASK_DRVERLYITV1 << BIT_SHIFT_DRVERLYITV1)
#define BIT_CLEAR_DRVERLYITV1(x) ((x) & (~BITS_DRVERLYITV1))
#define BIT_GET_DRVERLYITV1(x) \
(((x) >> BIT_SHIFT_DRVERLYITV1) & BIT_MASK_DRVERLYITV1)
#define BIT_SET_DRVERLYITV1(x, v) \
(BIT_CLEAR_DRVERLYITV1(x) | BIT_DRVERLYITV1(v))
#define BIT_DIS_RX_BSSID_FIT2 BIT(6)
#define BIT_DIS_TSF2_UDT BIT(4)
#define BIT_EN_BCN2_FUNCTION BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BCN_ELY_ADJ (Offset 0x05D4) */
#define BIT_SHIFT_BCN_ELY_ADJ 0
#define BIT_MASK_BCN_ELY_ADJ 0xffff
#define BIT_BCN_ELY_ADJ(x) \
(((x) & BIT_MASK_BCN_ELY_ADJ) << BIT_SHIFT_BCN_ELY_ADJ)
#define BITS_BCN_ELY_ADJ (BIT_MASK_BCN_ELY_ADJ << BIT_SHIFT_BCN_ELY_ADJ)
#define BIT_CLEAR_BCN_ELY_ADJ(x) ((x) & (~BITS_BCN_ELY_ADJ))
#define BIT_GET_BCN_ELY_ADJ(x) \
(((x) >> BIT_SHIFT_BCN_ELY_ADJ) & BIT_MASK_BCN_ELY_ADJ)
#define BIT_SET_BCN_ELY_ADJ(x, v) \
(BIT_CLEAR_BCN_ELY_ADJ(x) | BIT_BCN_ELY_ADJ(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_EARLYINT_ADJUST (Offset 0x05D4) */
#define BIT_SHIFT_R_ERLYINTADJ 0
#define BIT_MASK_R_ERLYINTADJ 0xffff
#define BIT_R_ERLYINTADJ(x) \
(((x) & BIT_MASK_R_ERLYINTADJ) << BIT_SHIFT_R_ERLYINTADJ)
#define BITS_R_ERLYINTADJ (BIT_MASK_R_ERLYINTADJ << BIT_SHIFT_R_ERLYINTADJ)
#define BIT_CLEAR_R_ERLYINTADJ(x) ((x) & (~BITS_R_ERLYINTADJ))
#define BIT_GET_R_ERLYINTADJ(x) \
(((x) >> BIT_SHIFT_R_ERLYINTADJ) & BIT_MASK_R_ERLYINTADJ)
#define BIT_SET_R_ERLYINTADJ(x, v) \
(BIT_CLEAR_R_ERLYINTADJ(x) | BIT_R_ERLYINTADJ(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_NAN_BCNSPACE (Offset 0x05D8) */
#define BIT_SHIFT_BCN_SPACE4 16
#define BIT_MASK_BCN_SPACE4 0xffff
#define BIT_BCN_SPACE4(x) (((x) & BIT_MASK_BCN_SPACE4) << BIT_SHIFT_BCN_SPACE4)
#define BITS_BCN_SPACE4 (BIT_MASK_BCN_SPACE4 << BIT_SHIFT_BCN_SPACE4)
#define BIT_CLEAR_BCN_SPACE4(x) ((x) & (~BITS_BCN_SPACE4))
#define BIT_GET_BCN_SPACE4(x) \
(((x) >> BIT_SHIFT_BCN_SPACE4) & BIT_MASK_BCN_SPACE4)
#define BIT_SET_BCN_SPACE4(x, v) (BIT_CLEAR_BCN_SPACE4(x) | BIT_BCN_SPACE4(v))
#define BIT_SHIFT_BCN_SPACE3 0
#define BIT_MASK_BCN_SPACE3 0xffff
#define BIT_BCN_SPACE3(x) (((x) & BIT_MASK_BCN_SPACE3) << BIT_SHIFT_BCN_SPACE3)
#define BITS_BCN_SPACE3 (BIT_MASK_BCN_SPACE3 << BIT_SHIFT_BCN_SPACE3)
#define BIT_CLEAR_BCN_SPACE3(x) ((x) & (~BITS_BCN_SPACE3))
#define BIT_GET_BCN_SPACE3(x) \
(((x) >> BIT_SHIFT_BCN_SPACE3) & BIT_MASK_BCN_SPACE3)
#define BIT_SET_BCN_SPACE3(x, v) (BIT_CLEAR_BCN_SPACE3(x) | BIT_BCN_SPACE3(v))
/* 2 REG_NAN_SETTING1 (Offset 0x05DC) */
#define BIT_SHIFT_SYNCBCN_RXNUM 27
#define BIT_MASK_SYNCBCN_RXNUM 0x1f
#define BIT_SYNCBCN_RXNUM(x) \
(((x) & BIT_MASK_SYNCBCN_RXNUM) << BIT_SHIFT_SYNCBCN_RXNUM)
#define BITS_SYNCBCN_RXNUM (BIT_MASK_SYNCBCN_RXNUM << BIT_SHIFT_SYNCBCN_RXNUM)
#define BIT_CLEAR_SYNCBCN_RXNUM(x) ((x) & (~BITS_SYNCBCN_RXNUM))
#define BIT_GET_SYNCBCN_RXNUM(x) \
(((x) >> BIT_SHIFT_SYNCBCN_RXNUM) & BIT_MASK_SYNCBCN_RXNUM)
#define BIT_SET_SYNCBCN_RXNUM(x, v) \
(BIT_CLEAR_SYNCBCN_RXNUM(x) | BIT_SYNCBCN_RXNUM(v))
#define BIT_DW_END_EARLY BIT(26)
#define BIT_SHIFT_NAN_ROLE 24
#define BIT_MASK_NAN_ROLE 0x3
#define BIT_NAN_ROLE(x) (((x) & BIT_MASK_NAN_ROLE) << BIT_SHIFT_NAN_ROLE)
#define BITS_NAN_ROLE (BIT_MASK_NAN_ROLE << BIT_SHIFT_NAN_ROLE)
#define BIT_CLEAR_NAN_ROLE(x) ((x) & (~BITS_NAN_ROLE))
#define BIT_GET_NAN_ROLE(x) (((x) >> BIT_SHIFT_NAN_ROLE) & BIT_MASK_NAN_ROLE)
#define BIT_SET_NAN_ROLE(x, v) (BIT_CLEAR_NAN_ROLE(x) | BIT_NAN_ROLE(v))
#define BIT_SHIFT_MSLOT_EVTQ 16
#define BIT_MASK_MSLOT_EVTQ 0xff
#define BIT_MSLOT_EVTQ(x) (((x) & BIT_MASK_MSLOT_EVTQ) << BIT_SHIFT_MSLOT_EVTQ)
#define BITS_MSLOT_EVTQ (BIT_MASK_MSLOT_EVTQ << BIT_SHIFT_MSLOT_EVTQ)
#define BIT_CLEAR_MSLOT_EVTQ(x) ((x) & (~BITS_MSLOT_EVTQ))
#define BIT_GET_MSLOT_EVTQ(x) \
(((x) >> BIT_SHIFT_MSLOT_EVTQ) & BIT_MASK_MSLOT_EVTQ)
#define BIT_SET_MSLOT_EVTQ(x, v) (BIT_CLEAR_MSLOT_EVTQ(x) | BIT_MSLOT_EVTQ(v))
#define BIT_SHIFT_MDW_EVTQ 8
#define BIT_MASK_MDW_EVTQ 0xff
#define BIT_MDW_EVTQ(x) (((x) & BIT_MASK_MDW_EVTQ) << BIT_SHIFT_MDW_EVTQ)
#define BITS_MDW_EVTQ (BIT_MASK_MDW_EVTQ << BIT_SHIFT_MDW_EVTQ)
#define BIT_CLEAR_MDW_EVTQ(x) ((x) & (~BITS_MDW_EVTQ))
#define BIT_GET_MDW_EVTQ(x) (((x) >> BIT_SHIFT_MDW_EVTQ) & BIT_MASK_MDW_EVTQ)
#define BIT_SET_MDW_EVTQ(x, v) (BIT_CLEAR_MDW_EVTQ(x) | BIT_MDW_EVTQ(v))
#define BIT_SHIFT_HC 0
#define BIT_MASK_HC 0xff
#define BIT_HC(x) (((x) & BIT_MASK_HC) << BIT_SHIFT_HC)
#define BITS_HC (BIT_MASK_HC << BIT_SHIFT_HC)
#define BIT_CLEAR_HC(x) ((x) & (~BITS_HC))
#define BIT_GET_HC(x) (((x) >> BIT_SHIFT_HC) & BIT_MASK_HC)
#define BIT_SET_HC(x, v) (BIT_CLEAR_HC(x) | BIT_HC(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_NOA_PARAM (Offset 0x05E0) */
#define BIT_SHIFT_NOA_COUNT (96 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_COUNT 0xff
#define BIT_NOA_COUNT(x) (((x) & BIT_MASK_NOA_COUNT) << BIT_SHIFT_NOA_COUNT)
#define BITS_NOA_COUNT (BIT_MASK_NOA_COUNT << BIT_SHIFT_NOA_COUNT)
#define BIT_CLEAR_NOA_COUNT(x) ((x) & (~BITS_NOA_COUNT))
#define BIT_GET_NOA_COUNT(x) (((x) >> BIT_SHIFT_NOA_COUNT) & BIT_MASK_NOA_COUNT)
#define BIT_SET_NOA_COUNT(x, v) (BIT_CLEAR_NOA_COUNT(x) | BIT_NOA_COUNT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_NOA_PARAM (Offset 0x05E0) */
#define BIT_SHIFT_NOA_DURATION 0
#define BIT_MASK_NOA_DURATION 0xffffffffL
#define BIT_NOA_DURATION(x) \
(((x) & BIT_MASK_NOA_DURATION) << BIT_SHIFT_NOA_DURATION)
#define BITS_NOA_DURATION (BIT_MASK_NOA_DURATION << BIT_SHIFT_NOA_DURATION)
#define BIT_CLEAR_NOA_DURATION(x) ((x) & (~BITS_NOA_DURATION))
#define BIT_GET_NOA_DURATION(x) \
(((x) >> BIT_SHIFT_NOA_DURATION) & BIT_MASK_NOA_DURATION)
#define BIT_SET_NOA_DURATION(x, v) \
(BIT_CLEAR_NOA_DURATION(x) | BIT_NOA_DURATION(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NOA_PARAM (Offset 0x05E0) */
#define BIT_SHIFT_NOA_DURATION_V1 0
#define BIT_MASK_NOA_DURATION_V1 0xffffffffL
#define BIT_NOA_DURATION_V1(x) \
(((x) & BIT_MASK_NOA_DURATION_V1) << BIT_SHIFT_NOA_DURATION_V1)
#define BITS_NOA_DURATION_V1 \
(BIT_MASK_NOA_DURATION_V1 << BIT_SHIFT_NOA_DURATION_V1)
#define BIT_CLEAR_NOA_DURATION_V1(x) ((x) & (~BITS_NOA_DURATION_V1))
#define BIT_GET_NOA_DURATION_V1(x) \
(((x) >> BIT_SHIFT_NOA_DURATION_V1) & BIT_MASK_NOA_DURATION_V1)
#define BIT_SET_NOA_DURATION_V1(x, v) \
(BIT_CLEAR_NOA_DURATION_V1(x) | BIT_NOA_DURATION_V1(v))
/* 2 REG_NOA_PARAM_1 (Offset 0x05E4) */
#define BIT_SHIFT_NOA_INTERVAL_V1 0
#define BIT_MASK_NOA_INTERVAL_V1 0xffffffffL
#define BIT_NOA_INTERVAL_V1(x) \
(((x) & BIT_MASK_NOA_INTERVAL_V1) << BIT_SHIFT_NOA_INTERVAL_V1)
#define BITS_NOA_INTERVAL_V1 \
(BIT_MASK_NOA_INTERVAL_V1 << BIT_SHIFT_NOA_INTERVAL_V1)
#define BIT_CLEAR_NOA_INTERVAL_V1(x) ((x) & (~BITS_NOA_INTERVAL_V1))
#define BIT_GET_NOA_INTERVAL_V1(x) \
(((x) >> BIT_SHIFT_NOA_INTERVAL_V1) & BIT_MASK_NOA_INTERVAL_V1)
#define BIT_SET_NOA_INTERVAL_V1(x, v) \
(BIT_CLEAR_NOA_INTERVAL_V1(x) | BIT_NOA_INTERVAL_V1(v))
/* 2 REG_NOA_PARAM_2 (Offset 0x05E8) */
#define BIT_SHIFT_NOA_START_TIME_V1 0
#define BIT_MASK_NOA_START_TIME_V1 0xffffffffL
#define BIT_NOA_START_TIME_V1(x) \
(((x) & BIT_MASK_NOA_START_TIME_V1) << BIT_SHIFT_NOA_START_TIME_V1)
#define BITS_NOA_START_TIME_V1 \
(BIT_MASK_NOA_START_TIME_V1 << BIT_SHIFT_NOA_START_TIME_V1)
#define BIT_CLEAR_NOA_START_TIME_V1(x) ((x) & (~BITS_NOA_START_TIME_V1))
#define BIT_GET_NOA_START_TIME_V1(x) \
(((x) >> BIT_SHIFT_NOA_START_TIME_V1) & BIT_MASK_NOA_START_TIME_V1)
#define BIT_SET_NOA_START_TIME_V1(x, v) \
(BIT_CLEAR_NOA_START_TIME_V1(x) | BIT_NOA_START_TIME_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_DBG_INFO (Offset 0x05E8) */
#define BIT_SHIFT_MU_DBG_INFO 0
#define BIT_MASK_MU_DBG_INFO 0xffffffffL
#define BIT_MU_DBG_INFO(x) \
(((x) & BIT_MASK_MU_DBG_INFO) << BIT_SHIFT_MU_DBG_INFO)
#define BITS_MU_DBG_INFO (BIT_MASK_MU_DBG_INFO << BIT_SHIFT_MU_DBG_INFO)
#define BIT_CLEAR_MU_DBG_INFO(x) ((x) & (~BITS_MU_DBG_INFO))
#define BIT_GET_MU_DBG_INFO(x) \
(((x) >> BIT_SHIFT_MU_DBG_INFO) & BIT_MASK_MU_DBG_INFO)
#define BIT_SET_MU_DBG_INFO(x, v) \
(BIT_CLEAR_MU_DBG_INFO(x) | BIT_MU_DBG_INFO(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_NOA_PARAM_3 (Offset 0x05EC) */
#define BIT_SHIFT_NOA_COUNT_V3 0
#define BIT_MASK_NOA_COUNT_V3 0xff
#define BIT_NOA_COUNT_V3(x) \
(((x) & BIT_MASK_NOA_COUNT_V3) << BIT_SHIFT_NOA_COUNT_V3)
#define BITS_NOA_COUNT_V3 (BIT_MASK_NOA_COUNT_V3 << BIT_SHIFT_NOA_COUNT_V3)
#define BIT_CLEAR_NOA_COUNT_V3(x) ((x) & (~BITS_NOA_COUNT_V3))
#define BIT_GET_NOA_COUNT_V3(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_V3) & BIT_MASK_NOA_COUNT_V3)
#define BIT_SET_NOA_COUNT_V3(x, v) \
(BIT_CLEAR_NOA_COUNT_V3(x) | BIT_NOA_COUNT_V3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NOA_PARAM_3 (Offset 0x05EC) */
#define BIT_SHIFT_NOA_COUNT_V1 0
#define BIT_MASK_NOA_COUNT_V1 0xffffffffL
#define BIT_NOA_COUNT_V1(x) \
(((x) & BIT_MASK_NOA_COUNT_V1) << BIT_SHIFT_NOA_COUNT_V1)
#define BITS_NOA_COUNT_V1 (BIT_MASK_NOA_COUNT_V1 << BIT_SHIFT_NOA_COUNT_V1)
#define BIT_CLEAR_NOA_COUNT_V1(x) ((x) & (~BITS_NOA_COUNT_V1))
#define BIT_GET_NOA_COUNT_V1(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_V1) & BIT_MASK_NOA_COUNT_V1)
#define BIT_SET_NOA_COUNT_V1(x, v) \
(BIT_CLEAR_NOA_COUNT_V1(x) | BIT_NOA_COUNT_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_DBG_INFO_1 (Offset 0x05EC) */
#define BIT_SHIFT_MU_DBG_INFO_1 0
#define BIT_MASK_MU_DBG_INFO_1 0xffffffffL
#define BIT_MU_DBG_INFO_1(x) \
(((x) & BIT_MASK_MU_DBG_INFO_1) << BIT_SHIFT_MU_DBG_INFO_1)
#define BITS_MU_DBG_INFO_1 (BIT_MASK_MU_DBG_INFO_1 << BIT_SHIFT_MU_DBG_INFO_1)
#define BIT_CLEAR_MU_DBG_INFO_1(x) ((x) & (~BITS_MU_DBG_INFO_1))
#define BIT_GET_MU_DBG_INFO_1(x) \
(((x) >> BIT_SHIFT_MU_DBG_INFO_1) & BIT_MASK_MU_DBG_INFO_1)
#define BIT_SET_MU_DBG_INFO_1(x, v) \
(BIT_CLEAR_MU_DBG_INFO_1(x) | BIT_MU_DBG_INFO_1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_NOA_SUBIE (Offset 0x05ED) */
#define BIT_MORE_NOA_DESC BIT(19)
#define BIT_NOA_DESC1_VALID BIT(18)
#define BIT_NOA_DESC0_VALID BIT(17)
#define BIT_NOA_HEAD_VALID BIT(16)
#define BIT_NOA_OPP_PS BIT(15)
#define BIT_SHIFT_NOA_CTW 8
#define BIT_MASK_NOA_CTW 0x7f
#define BIT_NOA_CTW(x) (((x) & BIT_MASK_NOA_CTW) << BIT_SHIFT_NOA_CTW)
#define BITS_NOA_CTW (BIT_MASK_NOA_CTW << BIT_SHIFT_NOA_CTW)
#define BIT_CLEAR_NOA_CTW(x) ((x) & (~BITS_NOA_CTW))
#define BIT_GET_NOA_CTW(x) (((x) >> BIT_SHIFT_NOA_CTW) & BIT_MASK_NOA_CTW)
#define BIT_SET_NOA_CTW(x, v) (BIT_CLEAR_NOA_CTW(x) | BIT_NOA_CTW(v))
#define BIT_SHIFT_NOA_INDEX 0
#define BIT_MASK_NOA_INDEX 0xff
#define BIT_NOA_INDEX(x) (((x) & BIT_MASK_NOA_INDEX) << BIT_SHIFT_NOA_INDEX)
#define BITS_NOA_INDEX (BIT_MASK_NOA_INDEX << BIT_SHIFT_NOA_INDEX)
#define BIT_CLEAR_NOA_INDEX(x) ((x) & (~BITS_NOA_INDEX))
#define BIT_GET_NOA_INDEX(x) (((x) >> BIT_SHIFT_NOA_INDEX) & BIT_MASK_NOA_INDEX)
#define BIT_SET_NOA_INDEX(x, v) (BIT_CLEAR_NOA_INDEX(x) | BIT_NOA_INDEX(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2P_RST (Offset 0x05F0) */
#define BIT_P2P2_PWR_RST1 BIT(5)
#define BIT_P2P2_PWR_RST0 BIT(4)
#define BIT_P2P1_PWR_RST1 BIT(3)
#define BIT_P2P1_PWR_RST0 BIT(2)
#define BIT_P2P_PWR_RST1_V1 BIT(1)
#define BIT_P2P_PWR_RST0_V1 BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SCH_DBG_SEL (Offset 0x05F0) */
#define BIT_SHIFT_SCH_DBG_SEL 0
#define BIT_MASK_SCH_DBG_SEL 0xff
#define BIT_SCH_DBG_SEL(x) \
(((x) & BIT_MASK_SCH_DBG_SEL) << BIT_SHIFT_SCH_DBG_SEL)
#define BITS_SCH_DBG_SEL (BIT_MASK_SCH_DBG_SEL << BIT_SHIFT_SCH_DBG_SEL)
#define BIT_CLEAR_SCH_DBG_SEL(x) ((x) & (~BITS_SCH_DBG_SEL))
#define BIT_GET_SCH_DBG_SEL(x) \
(((x) >> BIT_SHIFT_SCH_DBG_SEL) & BIT_MASK_SCH_DBG_SEL)
#define BIT_SET_SCH_DBG_SEL(x, v) \
(BIT_CLEAR_SCH_DBG_SEL(x) | BIT_SCH_DBG_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_MAC_STOP_CPUMGQ BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_SYNC_TSF_NOW BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_SYNC_CLI_ONCE_RIGHT_NOW BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_EN_P2P_CTWINDOW BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_SYNC_CLI BIT(1)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_SYNC_CLI_ONCE_BY_TBTT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_RST (Offset 0x05F1) */
#define BIT_SCHEDULER_RST_V1 BIT(0)
#define BIT_EN_P2P_BCNQ_AREA BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_DBG_ERR_FLAG (Offset 0x05F2) */
#define BIT_BCN_PORTID_ERR BIT(2)
#define BIT_SHIFT_MU_DBG_ERR_FLAG 0
#define BIT_MASK_MU_DBG_ERR_FLAG 0x3
#define BIT_MU_DBG_ERR_FLAG(x) \
(((x) & BIT_MASK_MU_DBG_ERR_FLAG) << BIT_SHIFT_MU_DBG_ERR_FLAG)
#define BITS_MU_DBG_ERR_FLAG \
(BIT_MASK_MU_DBG_ERR_FLAG << BIT_SHIFT_MU_DBG_ERR_FLAG)
#define BIT_CLEAR_MU_DBG_ERR_FLAG(x) ((x) & (~BITS_MU_DBG_ERR_FLAG))
#define BIT_GET_MU_DBG_ERR_FLAG(x) \
(((x) >> BIT_SHIFT_MU_DBG_ERR_FLAG) & BIT_MASK_MU_DBG_ERR_FLAG)
#define BIT_SET_MU_DBG_ERR_FLAG(x, v) \
(BIT_CLEAR_MU_DBG_ERR_FLAG(x) | BIT_MU_DBG_ERR_FLAG(v))
/* 2 REG_TX_ERR_RECOVERY_RST (Offset 0x05F3) */
#define BIT_SHIFT_ERR_RECOVER_CNT 4
#define BIT_MASK_ERR_RECOVER_CNT 0xf
#define BIT_ERR_RECOVER_CNT(x) \
(((x) & BIT_MASK_ERR_RECOVER_CNT) << BIT_SHIFT_ERR_RECOVER_CNT)
#define BITS_ERR_RECOVER_CNT \
(BIT_MASK_ERR_RECOVER_CNT << BIT_SHIFT_ERR_RECOVER_CNT)
#define BIT_CLEAR_ERR_RECOVER_CNT(x) ((x) & (~BITS_ERR_RECOVER_CNT))
#define BIT_GET_ERR_RECOVER_CNT(x) \
(((x) >> BIT_SHIFT_ERR_RECOVER_CNT) & BIT_MASK_ERR_RECOVER_CNT)
#define BIT_SET_ERR_RECOVER_CNT(x, v) \
(BIT_CLEAR_ERR_RECOVER_CNT(x) | BIT_ERR_RECOVER_CNT(v))
#define BIT_RX_HANG_ERR BIT(2)
#define BIT_TX_HANG_ERR BIT(1)
#define BIT_TX_ERR_RECOVERY_RST BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SCH_DBG (Offset 0x05F4) */
#define BIT_SHIFT_SCH_DBG 0
#define BIT_MASK_SCH_DBG 0xffffffffL
#define BIT_SCH_DBG(x) (((x) & BIT_MASK_SCH_DBG) << BIT_SHIFT_SCH_DBG)
#define BITS_SCH_DBG (BIT_MASK_SCH_DBG << BIT_SHIFT_SCH_DBG)
#define BIT_CLEAR_SCH_DBG(x) ((x) & (~BITS_SCH_DBG))
#define BIT_GET_SCH_DBG(x) (((x) >> BIT_SHIFT_SCH_DBG) & BIT_MASK_SCH_DBG)
#define BIT_SET_SCH_DBG(x, v) (BIT_CLEAR_SCH_DBG(x) | BIT_SCH_DBG(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCH_DBG_VALUE (Offset 0x05F4) */
#define BIT_SHIFT_SCH_DBG_VALUE 0
#define BIT_MASK_SCH_DBG_VALUE 0xffffffffL
#define BIT_SCH_DBG_VALUE(x) \
(((x) & BIT_MASK_SCH_DBG_VALUE) << BIT_SHIFT_SCH_DBG_VALUE)
#define BITS_SCH_DBG_VALUE (BIT_MASK_SCH_DBG_VALUE << BIT_SHIFT_SCH_DBG_VALUE)
#define BIT_CLEAR_SCH_DBG_VALUE(x) ((x) & (~BITS_SCH_DBG_VALUE))
#define BIT_GET_SCH_DBG_VALUE(x) \
(((x) >> BIT_SHIFT_SCH_DBG_VALUE) & BIT_MASK_SCH_DBG_VALUE)
#define BIT_SET_SCH_DBG_VALUE(x, v) \
(BIT_CLEAR_SCH_DBG_VALUE(x) | BIT_SCH_DBG_VALUE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SCH_TXCMD (Offset 0x05F8) */
#define BIT_DIS_RX_BSSID_FIT BIT(6)
#define BIT_DIS_TSF_UDT BIT(4)
#define BIT_SHIFT_SCH_TXCMD 0
#define BIT_MASK_SCH_TXCMD 0xffffffffL
#define BIT_SCH_TXCMD(x) (((x) & BIT_MASK_SCH_TXCMD) << BIT_SHIFT_SCH_TXCMD)
#define BITS_SCH_TXCMD (BIT_MASK_SCH_TXCMD << BIT_SHIFT_SCH_TXCMD)
#define BIT_CLEAR_SCH_TXCMD(x) ((x) & (~BITS_SCH_TXCMD))
#define BIT_GET_SCH_TXCMD(x) (((x) >> BIT_SHIFT_SCH_TXCMD) & BIT_MASK_SCH_TXCMD)
#define BIT_SET_SCH_TXCMD(x, v) (BIT_CLEAR_SCH_TXCMD(x) | BIT_SCH_TXCMD(v))
#define BIT_SHIFT_TBTT_PROHIBIT_SETUP 0
#define BIT_MASK_TBTT_PROHIBIT_SETUP 0xf
#define BIT_TBTT_PROHIBIT_SETUP(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_SETUP) << BIT_SHIFT_TBTT_PROHIBIT_SETUP)
#define BITS_TBTT_PROHIBIT_SETUP \
(BIT_MASK_TBTT_PROHIBIT_SETUP << BIT_SHIFT_TBTT_PROHIBIT_SETUP)
#define BIT_CLEAR_TBTT_PROHIBIT_SETUP(x) ((x) & (~BITS_TBTT_PROHIBIT_SETUP))
#define BIT_GET_TBTT_PROHIBIT_SETUP(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_SETUP) & BIT_MASK_TBTT_PROHIBIT_SETUP)
#define BIT_SET_TBTT_PROHIBIT_SETUP(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_SETUP(x) | BIT_TBTT_PROHIBIT_SETUP(v))
#define BIT_SHIFT_DRVERLYITV 0
#define BIT_MASK_DRVERLYITV 0xff
#define BIT_DRVERLYITV(x) (((x) & BIT_MASK_DRVERLYITV) << BIT_SHIFT_DRVERLYITV)
#define BITS_DRVERLYITV (BIT_MASK_DRVERLYITV << BIT_SHIFT_DRVERLYITV)
#define BIT_CLEAR_DRVERLYITV(x) ((x) & (~BITS_DRVERLYITV))
#define BIT_GET_DRVERLYITV(x) \
(((x) >> BIT_SHIFT_DRVERLYITV) & BIT_MASK_DRVERLYITV)
#define BIT_SET_DRVERLYITV(x, v) (BIT_CLEAR_DRVERLYITV(x) | BIT_DRVERLYITV(v))
#define BIT_SHIFT_BCNDMATIM 0
#define BIT_MASK_BCNDMATIM 0xff
#define BIT_BCNDMATIM(x) (((x) & BIT_MASK_BCNDMATIM) << BIT_SHIFT_BCNDMATIM)
#define BITS_BCNDMATIM (BIT_MASK_BCNDMATIM << BIT_SHIFT_BCNDMATIM)
#define BIT_CLEAR_BCNDMATIM(x) ((x) & (~BITS_BCNDMATIM))
#define BIT_GET_BCNDMATIM(x) (((x) >> BIT_SHIFT_BCNDMATIM) & BIT_MASK_BCNDMATIM)
#define BIT_SET_BCNDMATIM(x, v) (BIT_CLEAR_BCNDMATIM(x) | BIT_BCNDMATIM(v))
#define BIT_SHIFT_CTWND 0
#define BIT_MASK_CTWND 0xff
#define BIT_CTWND(x) (((x) & BIT_MASK_CTWND) << BIT_SHIFT_CTWND)
#define BITS_CTWND (BIT_MASK_CTWND << BIT_SHIFT_CTWND)
#define BIT_CLEAR_CTWND(x) ((x) & (~BITS_CTWND))
#define BIT_GET_CTWND(x) (((x) >> BIT_SHIFT_CTWND) & BIT_MASK_CTWND)
#define BIT_SET_CTWND(x, v) (BIT_CLEAR_CTWND(x) | BIT_CTWND(v))
#endif
#if (HALMAC_8821C_SUPPORT)
/* 2 REG_PAGE5_DUMMY (Offset 0x05FC) */
#define BIT_ECO_TXOP_BREAK_FORCE_CFEND BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_CR (Offset 0x0600) */
#define BIT_APSDOFF_STATUS BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_CR (Offset 0x0600) */
#define BIT_APSDOFF BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_CR (Offset 0x0600) */
#define BIT_STANDBY_STATUS BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_CR (Offset 0x0600) */
#define BIT_IC_MACPHY_M BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FWPKT_CR (Offset 0x0601) */
#define BIT_FWEN BIT(7)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_WMAC_FWPKT_CR (Offset 0x0601) */
#define BIT_FWRX_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FWPKT_CR (Offset 0x0601) */
#define BIT_PHYSTS_PKT_CTRL BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_WMAC_FWPKT_CR (Offset 0x0601) */
#define BIT_FWFULL_TO_RXFF_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FWPKT_CR (Offset 0x0601) */
#define BIT_APPHDR_MIDSRCH_FAIL BIT(4)
#define BIT_FWPARSING_EN BIT(3)
#define BIT_SHIFT_APPEND_MHDR_LEN 0
#define BIT_MASK_APPEND_MHDR_LEN 0x7
#define BIT_APPEND_MHDR_LEN(x) \
(((x) & BIT_MASK_APPEND_MHDR_LEN) << BIT_SHIFT_APPEND_MHDR_LEN)
#define BITS_APPEND_MHDR_LEN \
(BIT_MASK_APPEND_MHDR_LEN << BIT_SHIFT_APPEND_MHDR_LEN)
#define BIT_CLEAR_APPEND_MHDR_LEN(x) ((x) & (~BITS_APPEND_MHDR_LEN))
#define BIT_GET_APPEND_MHDR_LEN(x) \
(((x) >> BIT_SHIFT_APPEND_MHDR_LEN) & BIT_MASK_APPEND_MHDR_LEN)
#define BIT_SET_APPEND_MHDR_LEN(x, v) \
(BIT_CLEAR_APPEND_MHDR_LEN(x) | BIT_APPEND_MHDR_LEN(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_EN_RTS_ADDR BIT(31)
#define BIT_WMAC_DISABLE_CCK BIT(30)
#define BIT_WMAC_RAW_LEN BIT(29)
#define BIT_WMAC_NOTX_IN_RXNDP BIT(28)
#define BIT_WMAC_EN_EOF BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCRPWRMGT_HWCTL_V1 BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_BF_SEL BIT(26)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_BF_SEL BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_ANTMODE_SEL BIT(25)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_RXLEN_SEL BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCRPWRMGT_HWCTL BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCRPWRMGT_HWCTL_EN BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_SMOOTH_VAL BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_EN_SCRAM_INC BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_UNDERFLOWEN_CMPLEN_SEL BIT(21)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_SHIFT_TSFT_CMP 20
#define BIT_MASK_TSFT_CMP 0xf
#define BIT_TSFT_CMP(x) (((x) & BIT_MASK_TSFT_CMP) << BIT_SHIFT_TSFT_CMP)
#define BITS_TSFT_CMP (BIT_MASK_TSFT_CMP << BIT_SHIFT_TSFT_CMP)
#define BIT_CLEAR_TSFT_CMP(x) ((x) & (~BITS_TSFT_CMP))
#define BIT_GET_TSFT_CMP(x) (((x) >> BIT_SHIFT_TSFT_CMP) & BIT_MASK_TSFT_CMP)
#define BIT_SET_TSFT_CMP(x, v) (BIT_CLEAR_TSFT_CMP(x) | BIT_TSFT_CMP(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_FETCH_MPDU_AFTER_WSEC_RDY BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCR_EN_20MST BIT(19)
#define BIT_WMAC_DIS_SIGTA BIT(18)
#define BIT_WMAC_DIS_A2B0 BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_SHIFT_TSFT_CMP_CCK 16
#define BIT_MASK_TSFT_CMP_CCK 0xf
#define BIT_TSFT_CMP_CCK(x) \
(((x) & BIT_MASK_TSFT_CMP_CCK) << BIT_SHIFT_TSFT_CMP_CCK)
#define BITS_TSFT_CMP_CCK (BIT_MASK_TSFT_CMP_CCK << BIT_SHIFT_TSFT_CMP_CCK)
#define BIT_CLEAR_TSFT_CMP_CCK(x) ((x) & (~BITS_TSFT_CMP_CCK))
#define BIT_GET_TSFT_CMP_CCK(x) \
(((x) >> BIT_SHIFT_TSFT_CMP_CCK) & BIT_MASK_TSFT_CMP_CCK)
#define BIT_SET_TSFT_CMP_CCK(x, v) \
(BIT_CLEAR_TSFT_CMP_CCK(x) | BIT_TSFT_CMP_CCK(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_MSK_SIGBCRC BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCR_ERRSTEN_3 BIT(15)
#define BIT_WMAC_TCR_ERRSTEN_2 BIT(14)
#define BIT_WMAC_TCR_ERRSTEN_1 BIT(13)
#define BIT_WMAC_TCR_ERRSTEN_0 BIT(12)
#define BIT_WMAC_TCR_TXSK_PERPKT BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT__TXSK_PERPKT BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_ICV BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_CFEND_FORMAT BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_CFENDFORM BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_CRC BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_PWRBIT_OW_EN BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_PWRMGT_CTL BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCRPWRMGT_HWDATA_EN BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_PWR_ST BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_PWRMGT_VAL BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCR_UPD_TIMIE BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_UPD_TIMIE BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCR_UPD_HGQMD BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_UPD_HGQMD BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_VHTSIGA1_TXPS BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_PAD_SEL BIT(2)
#define BIT_DIS_GCLK BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_TSFRST BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_WMAC_TCRPWRMGT_HWACT_EN BIT(0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_TCR (Offset 0x0604) */
#define BIT_R_WMAC_TCR_LSIG BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_APP_FCS BIT(31)
#define BIT_APP_MIC BIT(30)
#define BIT_APP_ICV BIT(29)
#define BIT_APP_PHYSTS BIT(28)
#define BIT_APP_BASSN BIT(27)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_VHT_DACK BIT(26)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_TCPOFLD_EN BIT(25)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_ENMBID BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_ENADDRCAM BIT(24)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_LSIGEN BIT(23)
#define BIT_MFBEN BIT(22)
#define BIT_DISCHKPPDLLEN BIT(21)
#define BIT_PKTCTL_DLEN BIT(20)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_DISGCLK BIT(19)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_TIM_PARSER_EN BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_TIMPSR_EN BIT(18)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_BC_MD_EN BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_BCMDINT_EN BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_UC_MD_EN BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_UCMDINT_EN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_RXSK_PERPKT BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_HTC_LOC_CTRL BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_HTCBFMC BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_AMF BIT(13)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_CHK_PREVTCA2 BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_ACK_WITH_CBSSID_DATA_OPTION BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_ACF BIT(12)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_ACK_WITH_CBSSID_DATA_OPTION_V1 BIT(12)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_RPFM_CAM_ENABLE BIT(12)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_ADF BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_TA_BCN BIT(11)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_DISDECMYPKT BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_DISDECNMYPKT BIT(10)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_AICV BIT(9)
#define BIT_ACRC32 BIT(8)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_CBSSID_BCN BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_CBSSID_MGNT BIT(7)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RCR (Offset 0x0608) */
#define BIT_CBSSID_DATA BIT(6)
#define BIT_APWRMGT BIT(5)
#define BIT_ADD3 BIT(4)
#define BIT_AB BIT(3)
#define BIT_AM BIT(2)
#define BIT_APM BIT(1)
#define BIT_AAP BIT(0)
#define BIT_SHIFT_RXPKTLMT 0
#define BIT_MASK_RXPKTLMT 0x3f
#define BIT_RXPKTLMT(x) (((x) & BIT_MASK_RXPKTLMT) << BIT_SHIFT_RXPKTLMT)
#define BITS_RXPKTLMT (BIT_MASK_RXPKTLMT << BIT_SHIFT_RXPKTLMT)
#define BIT_CLEAR_RXPKTLMT(x) ((x) & (~BITS_RXPKTLMT))
#define BIT_GET_RXPKTLMT(x) (((x) >> BIT_SHIFT_RXPKTLMT) & BIT_MASK_RXPKTLMT)
#define BIT_SET_RXPKTLMT(x, v) (BIT_CLEAR_RXPKTLMT(x) | BIT_RXPKTLMT(v))
/* 2 REG_RX_DLK_TIME (Offset 0x060D) */
#define BIT_SHIFT_RX_DLK_TIME 0
#define BIT_MASK_RX_DLK_TIME 0xff
#define BIT_RX_DLK_TIME(x) \
(((x) & BIT_MASK_RX_DLK_TIME) << BIT_SHIFT_RX_DLK_TIME)
#define BITS_RX_DLK_TIME (BIT_MASK_RX_DLK_TIME << BIT_SHIFT_RX_DLK_TIME)
#define BIT_CLEAR_RX_DLK_TIME(x) ((x) & (~BITS_RX_DLK_TIME))
#define BIT_GET_RX_DLK_TIME(x) \
(((x) >> BIT_SHIFT_RX_DLK_TIME) & BIT_MASK_RX_DLK_TIME)
#define BIT_SET_RX_DLK_TIME(x, v) \
(BIT_CLEAR_RX_DLK_TIME(x) | BIT_RX_DLK_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SDIO_RXINT_LEN_TH (Offset 0x1025060E) */
#define BIT_SHIFT_SDIO_RXINT_LEN_TH 0
#define BIT_MASK_SDIO_RXINT_LEN_TH 0xff
#define BIT_SDIO_RXINT_LEN_TH(x) \
(((x) & BIT_MASK_SDIO_RXINT_LEN_TH) << BIT_SHIFT_SDIO_RXINT_LEN_TH)
#define BITS_SDIO_RXINT_LEN_TH \
(BIT_MASK_SDIO_RXINT_LEN_TH << BIT_SHIFT_SDIO_RXINT_LEN_TH)
#define BIT_CLEAR_SDIO_RXINT_LEN_TH(x) ((x) & (~BITS_SDIO_RXINT_LEN_TH))
#define BIT_GET_SDIO_RXINT_LEN_TH(x) \
(((x) >> BIT_SHIFT_SDIO_RXINT_LEN_TH) & BIT_MASK_SDIO_RXINT_LEN_TH)
#define BIT_SET_SDIO_RXINT_LEN_TH(x, v) \
(BIT_CLEAR_SDIO_RXINT_LEN_TH(x) | BIT_SDIO_RXINT_LEN_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_RX_DRVINFO_SZ (Offset 0x060F) */
#define BIT_APP_PHYSTS_PER_SUBMPDU BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_DRVINFO_SZ (Offset 0x060F) */
#define BIT_PHYSTS_PER_PKT_MODE BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_RX_DRVINFO_SZ (Offset 0x060F) */
#define BIT_APP_MH_SHIFT_VAL BIT(6)
#define BIT_WMAC_ENSHIFT BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_DRVINFO_SZ (Offset 0x060F) */
#define BIT_SHIFT_BITMAP_SSNBK_COUNTER 2
#define BIT_MASK_BITMAP_SSNBK_COUNTER 0x3f
#define BIT_BITMAP_SSNBK_COUNTER(x) \
(((x) & BIT_MASK_BITMAP_SSNBK_COUNTER) \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER)
#define BITS_BITMAP_SSNBK_COUNTER \
(BIT_MASK_BITMAP_SSNBK_COUNTER << BIT_SHIFT_BITMAP_SSNBK_COUNTER)
#define BIT_CLEAR_BITMAP_SSNBK_COUNTER(x) ((x) & (~BITS_BITMAP_SSNBK_COUNTER))
#define BIT_GET_BITMAP_SSNBK_COUNTER(x) \
(((x) >> BIT_SHIFT_BITMAP_SSNBK_COUNTER) & \
BIT_MASK_BITMAP_SSNBK_COUNTER)
#define BIT_SET_BITMAP_SSNBK_COUNTER(x, v) \
(BIT_CLEAR_BITMAP_SSNBK_COUNTER(x) | BIT_BITMAP_SSNBK_COUNTER(v))
#define BIT_BITMAP_EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RX_DRVINFO_SZ (Offset 0x060F) */
#define BIT_SHIFT_DRVINFO_SZ 0
#define BIT_MASK_DRVINFO_SZ 0xff
#define BIT_DRVINFO_SZ(x) (((x) & BIT_MASK_DRVINFO_SZ) << BIT_SHIFT_DRVINFO_SZ)
#define BITS_DRVINFO_SZ (BIT_MASK_DRVINFO_SZ << BIT_SHIFT_DRVINFO_SZ)
#define BIT_CLEAR_DRVINFO_SZ(x) ((x) & (~BITS_DRVINFO_SZ))
#define BIT_GET_DRVINFO_SZ(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ) & BIT_MASK_DRVINFO_SZ)
#define BIT_SET_DRVINFO_SZ(x, v) (BIT_CLEAR_DRVINFO_SZ(x) | BIT_DRVINFO_SZ(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_DRVINFO_SZ (Offset 0x060F) */
#define BIT_SHIFT_DRVINFO_SZ_V1 0
#define BIT_MASK_DRVINFO_SZ_V1 0xf
#define BIT_DRVINFO_SZ_V1(x) \
(((x) & BIT_MASK_DRVINFO_SZ_V1) << BIT_SHIFT_DRVINFO_SZ_V1)
#define BITS_DRVINFO_SZ_V1 (BIT_MASK_DRVINFO_SZ_V1 << BIT_SHIFT_DRVINFO_SZ_V1)
#define BIT_CLEAR_DRVINFO_SZ_V1(x) ((x) & (~BITS_DRVINFO_SZ_V1))
#define BIT_GET_DRVINFO_SZ_V1(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ_V1) & BIT_MASK_DRVINFO_SZ_V1)
#define BIT_SET_DRVINFO_SZ_V1(x, v) \
(BIT_CLEAR_DRVINFO_SZ_V1(x) | BIT_DRVINFO_SZ_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_MACID (Offset 0x0610) */
#define BIT_SHIFT_MACID 0
#define BIT_MASK_MACID 0xffffffffffffL
#define BIT_MACID(x) (((x) & BIT_MASK_MACID) << BIT_SHIFT_MACID)
#define BITS_MACID (BIT_MASK_MACID << BIT_SHIFT_MACID)
#define BIT_CLEAR_MACID(x) ((x) & (~BITS_MACID))
#define BIT_GET_MACID(x) (((x) >> BIT_SHIFT_MACID) & BIT_MASK_MACID)
#define BIT_SET_MACID(x, v) (BIT_CLEAR_MACID(x) | BIT_MACID(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID (Offset 0x0610) */
#define BIT_SHIFT_MACID_V1 0
#define BIT_MASK_MACID_V1 0xffffffffL
#define BIT_MACID_V1(x) (((x) & BIT_MASK_MACID_V1) << BIT_SHIFT_MACID_V1)
#define BITS_MACID_V1 (BIT_MASK_MACID_V1 << BIT_SHIFT_MACID_V1)
#define BIT_CLEAR_MACID_V1(x) ((x) & (~BITS_MACID_V1))
#define BIT_GET_MACID_V1(x) (((x) >> BIT_SHIFT_MACID_V1) & BIT_MASK_MACID_V1)
#define BIT_SET_MACID_V1(x, v) (BIT_CLEAR_MACID_V1(x) | BIT_MACID_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_MACID_H (Offset 0x0614) */
#define BIT_SHIFT_MACID_H 0
#define BIT_MASK_MACID_H 0xffff
#define BIT_MACID_H(x) (((x) & BIT_MASK_MACID_H) << BIT_SHIFT_MACID_H)
#define BITS_MACID_H (BIT_MASK_MACID_H << BIT_SHIFT_MACID_H)
#define BIT_CLEAR_MACID_H(x) ((x) & (~BITS_MACID_H))
#define BIT_GET_MACID_H(x) (((x) >> BIT_SHIFT_MACID_H) & BIT_MASK_MACID_H)
#define BIT_SET_MACID_H(x, v) (BIT_CLEAR_MACID_H(x) | BIT_MACID_H(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_H (Offset 0x0614) */
#define BIT_SHIFT_MACID_H_V1 0
#define BIT_MASK_MACID_H_V1 0xffff
#define BIT_MACID_H_V1(x) (((x) & BIT_MASK_MACID_H_V1) << BIT_SHIFT_MACID_H_V1)
#define BITS_MACID_H_V1 (BIT_MASK_MACID_H_V1 << BIT_SHIFT_MACID_H_V1)
#define BIT_CLEAR_MACID_H_V1(x) ((x) & (~BITS_MACID_H_V1))
#define BIT_GET_MACID_H_V1(x) \
(((x) >> BIT_SHIFT_MACID_H_V1) & BIT_MASK_MACID_H_V1)
#define BIT_SET_MACID_H_V1(x, v) (BIT_CLEAR_MACID_H_V1(x) | BIT_MACID_H_V1(v))
#define BIT_SHIFT_BSSID_H_V1 0
#define BIT_MASK_BSSID_H_V1 0xffff
#define BIT_BSSID_H_V1(x) (((x) & BIT_MASK_BSSID_H_V1) << BIT_SHIFT_BSSID_H_V1)
#define BITS_BSSID_H_V1 (BIT_MASK_BSSID_H_V1 << BIT_SHIFT_BSSID_H_V1)
#define BIT_CLEAR_BSSID_H_V1(x) ((x) & (~BITS_BSSID_H_V1))
#define BIT_GET_BSSID_H_V1(x) \
(((x) >> BIT_SHIFT_BSSID_H_V1) & BIT_MASK_BSSID_H_V1)
#define BIT_SET_BSSID_H_V1(x, v) (BIT_CLEAR_BSSID_H_V1(x) | BIT_BSSID_H_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BSSID (Offset 0x0618) */
#define BIT_SHIFT_BSSID 0
#define BIT_MASK_BSSID 0xffffffffffffL
#define BIT_BSSID(x) (((x) & BIT_MASK_BSSID) << BIT_SHIFT_BSSID)
#define BITS_BSSID (BIT_MASK_BSSID << BIT_SHIFT_BSSID)
#define BIT_CLEAR_BSSID(x) ((x) & (~BITS_BSSID))
#define BIT_GET_BSSID(x) (((x) >> BIT_SHIFT_BSSID) & BIT_MASK_BSSID)
#define BIT_SET_BSSID(x, v) (BIT_CLEAR_BSSID(x) | BIT_BSSID(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BSSID (Offset 0x0618) */
#define BIT_SHIFT_BSSID_V1 0
#define BIT_MASK_BSSID_V1 0xffffffffL
#define BIT_BSSID_V1(x) (((x) & BIT_MASK_BSSID_V1) << BIT_SHIFT_BSSID_V1)
#define BITS_BSSID_V1 (BIT_MASK_BSSID_V1 << BIT_SHIFT_BSSID_V1)
#define BIT_CLEAR_BSSID_V1(x) ((x) & (~BITS_BSSID_V1))
#define BIT_GET_BSSID_V1(x) (((x) >> BIT_SHIFT_BSSID_V1) & BIT_MASK_BSSID_V1)
#define BIT_SET_BSSID_V1(x, v) (BIT_CLEAR_BSSID_V1(x) | BIT_BSSID_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BSSID_H (Offset 0x061C) */
#define BIT_SHIFT_BSSID_H 0
#define BIT_MASK_BSSID_H 0xffff
#define BIT_BSSID_H(x) (((x) & BIT_MASK_BSSID_H) << BIT_SHIFT_BSSID_H)
#define BITS_BSSID_H (BIT_MASK_BSSID_H << BIT_SHIFT_BSSID_H)
#define BIT_CLEAR_BSSID_H(x) ((x) & (~BITS_BSSID_H))
#define BIT_GET_BSSID_H(x) (((x) >> BIT_SHIFT_BSSID_H) & BIT_MASK_BSSID_H)
#define BIT_SET_BSSID_H(x, v) (BIT_CLEAR_BSSID_H(x) | BIT_BSSID_H(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_MAR (Offset 0x0620) */
#define BIT_SHIFT_MAR 0
#define BIT_MASK_MAR 0xffffffffffffffffL
#define BIT_MAR(x) (((x) & BIT_MASK_MAR) << BIT_SHIFT_MAR)
#define BITS_MAR (BIT_MASK_MAR << BIT_SHIFT_MAR)
#define BIT_CLEAR_MAR(x) ((x) & (~BITS_MAR))
#define BIT_GET_MAR(x) (((x) >> BIT_SHIFT_MAR) & BIT_MASK_MAR)
#define BIT_SET_MAR(x, v) (BIT_CLEAR_MAR(x) | BIT_MAR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MAR (Offset 0x0620) */
#define BIT_SHIFT_MAR_V1 0
#define BIT_MASK_MAR_V1 0xffffffffL
#define BIT_MAR_V1(x) (((x) & BIT_MASK_MAR_V1) << BIT_SHIFT_MAR_V1)
#define BITS_MAR_V1 (BIT_MASK_MAR_V1 << BIT_SHIFT_MAR_V1)
#define BIT_CLEAR_MAR_V1(x) ((x) & (~BITS_MAR_V1))
#define BIT_GET_MAR_V1(x) (((x) >> BIT_SHIFT_MAR_V1) & BIT_MASK_MAR_V1)
#define BIT_SET_MAR_V1(x, v) (BIT_CLEAR_MAR_V1(x) | BIT_MAR_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_MAR_H (Offset 0x0624) */
#define BIT_SHIFT_MAR_H 0
#define BIT_MASK_MAR_H 0xffffffffL
#define BIT_MAR_H(x) (((x) & BIT_MASK_MAR_H) << BIT_SHIFT_MAR_H)
#define BITS_MAR_H (BIT_MASK_MAR_H << BIT_SHIFT_MAR_H)
#define BIT_CLEAR_MAR_H(x) ((x) & (~BITS_MAR_H))
#define BIT_GET_MAR_H(x) (((x) >> BIT_SHIFT_MAR_H) & BIT_MASK_MAR_H)
#define BIT_SET_MAR_H(x, v) (BIT_CLEAR_MAR_H(x) | BIT_MAR_H(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MAR_H (Offset 0x0624) */
#define BIT_SHIFT_MAR_H_V1 0
#define BIT_MASK_MAR_H_V1 0xffffffffL
#define BIT_MAR_H_V1(x) (((x) & BIT_MASK_MAR_H_V1) << BIT_SHIFT_MAR_H_V1)
#define BITS_MAR_H_V1 (BIT_MASK_MAR_H_V1 << BIT_SHIFT_MAR_H_V1)
#define BIT_CLEAR_MAR_H_V1(x) ((x) & (~BITS_MAR_H_V1))
#define BIT_GET_MAR_H_V1(x) (((x) >> BIT_SHIFT_MAR_H_V1) & BIT_MASK_MAR_H_V1)
#define BIT_SET_MAR_H_V1(x, v) (BIT_CLEAR_MAR_H_V1(x) | BIT_MAR_H_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MBIDCAMCFG_1 (Offset 0x0628) */
#define BIT_MBIDCAM_POLL BIT(31)
#define BIT_MBIDCAM_WT_EN BIT(30)
#define BIT_LSIC_TXOP_EN BIT(17)
#define BIT_SHIFT_MBIDCAM_RWDATA_L 0
#define BIT_MASK_MBIDCAM_RWDATA_L 0xffffffffL
#define BIT_MBIDCAM_RWDATA_L(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_L) << BIT_SHIFT_MBIDCAM_RWDATA_L)
#define BITS_MBIDCAM_RWDATA_L \
(BIT_MASK_MBIDCAM_RWDATA_L << BIT_SHIFT_MBIDCAM_RWDATA_L)
#define BIT_CLEAR_MBIDCAM_RWDATA_L(x) ((x) & (~BITS_MBIDCAM_RWDATA_L))
#define BIT_GET_MBIDCAM_RWDATA_L(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_L) & BIT_MASK_MBIDCAM_RWDATA_L)
#define BIT_SET_MBIDCAM_RWDATA_L(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_L(x) | BIT_MBIDCAM_RWDATA_L(v))
#define BIT_SHIFT_MBIDCAM_RWDATA_H 0
#define BIT_MASK_MBIDCAM_RWDATA_H 0xffff
#define BIT_MBIDCAM_RWDATA_H(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_H) << BIT_SHIFT_MBIDCAM_RWDATA_H)
#define BITS_MBIDCAM_RWDATA_H \
(BIT_MASK_MBIDCAM_RWDATA_H << BIT_SHIFT_MBIDCAM_RWDATA_H)
#define BIT_CLEAR_MBIDCAM_RWDATA_H(x) ((x) & (~BITS_MBIDCAM_RWDATA_H))
#define BIT_GET_MBIDCAM_RWDATA_H(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_H) & BIT_MASK_MBIDCAM_RWDATA_H)
#define BIT_SET_MBIDCAM_RWDATA_H(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_H(x) | BIT_MBIDCAM_RWDATA_H(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_MBIDCAM_CFG (Offset 0x062C) */
#define BIT_MBIDCAM_RST_V1 BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MBIDCAMCFG_2 (Offset 0x062C) */
#define BIT_SHIFT_MBIDCAM_ADDR_V1 24
#define BIT_MASK_MBIDCAM_ADDR_V1 0x3f
#define BIT_MBIDCAM_ADDR_V1(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR_V1) << BIT_SHIFT_MBIDCAM_ADDR_V1)
#define BITS_MBIDCAM_ADDR_V1 \
(BIT_MASK_MBIDCAM_ADDR_V1 << BIT_SHIFT_MBIDCAM_ADDR_V1)
#define BIT_CLEAR_MBIDCAM_ADDR_V1(x) ((x) & (~BITS_MBIDCAM_ADDR_V1))
#define BIT_GET_MBIDCAM_ADDR_V1(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR_V1) & BIT_MASK_MBIDCAM_ADDR_V1)
#define BIT_SET_MBIDCAM_ADDR_V1(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR_V1(x) | BIT_MBIDCAM_ADDR_V1(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_MBIDCAMCFG_2 (Offset 0x062C) */
#define BIT_SHIFT_MBIDCAM_ADDR_V2 23
#define BIT_MASK_MBIDCAM_ADDR_V2 0x7f
#define BIT_MBIDCAM_ADDR_V2(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR_V2) << BIT_SHIFT_MBIDCAM_ADDR_V2)
#define BITS_MBIDCAM_ADDR_V2 \
(BIT_MASK_MBIDCAM_ADDR_V2 << BIT_SHIFT_MBIDCAM_ADDR_V2)
#define BIT_CLEAR_MBIDCAM_ADDR_V2(x) ((x) & (~BITS_MBIDCAM_ADDR_V2))
#define BIT_GET_MBIDCAM_ADDR_V2(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR_V2) & BIT_MASK_MBIDCAM_ADDR_V2)
#define BIT_SET_MBIDCAM_ADDR_V2(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR_V2(x) | BIT_MBIDCAM_ADDR_V2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_MBIDCAMCFG_2 (Offset 0x062C) */
#define BIT_MBIDCAM_RST BIT(19)
#define BIT_MBIDCAM_VALID_V1 BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_MBIDCAMCFG_2 (Offset 0x062C) */
#define BIT_REPEAT_MODE_EN BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WMAC_DEBUG_SEL (Offset 0x062C) */
#define BIT_SHIFT_WMAC_ARB_DBG_SEL 3
#define BIT_MASK_WMAC_ARB_DBG_SEL 0x3
#define BIT_WMAC_ARB_DBG_SEL(x) \
(((x) & BIT_MASK_WMAC_ARB_DBG_SEL) << BIT_SHIFT_WMAC_ARB_DBG_SEL)
#define BITS_WMAC_ARB_DBG_SEL \
(BIT_MASK_WMAC_ARB_DBG_SEL << BIT_SHIFT_WMAC_ARB_DBG_SEL)
#define BIT_CLEAR_WMAC_ARB_DBG_SEL(x) ((x) & (~BITS_WMAC_ARB_DBG_SEL))
#define BIT_GET_WMAC_ARB_DBG_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_ARB_DBG_SEL) & BIT_MASK_WMAC_ARB_DBG_SEL)
#define BIT_SET_WMAC_ARB_DBG_SEL(x, v) \
(BIT_CLEAR_WMAC_ARB_DBG_SEL(x) | BIT_WMAC_ARB_DBG_SEL(v))
#define BIT_WMAC_EXT_DBG_SEL BIT(2)
#define BIT_SHIFT_WMAC_MU_DBGSEL_V1 0
#define BIT_MASK_WMAC_MU_DBGSEL_V1 0x3
#define BIT_WMAC_MU_DBGSEL_V1(x) \
(((x) & BIT_MASK_WMAC_MU_DBGSEL_V1) << BIT_SHIFT_WMAC_MU_DBGSEL_V1)
#define BITS_WMAC_MU_DBGSEL_V1 \
(BIT_MASK_WMAC_MU_DBGSEL_V1 << BIT_SHIFT_WMAC_MU_DBGSEL_V1)
#define BIT_CLEAR_WMAC_MU_DBGSEL_V1(x) ((x) & (~BITS_WMAC_MU_DBGSEL_V1))
#define BIT_GET_WMAC_MU_DBGSEL_V1(x) \
(((x) >> BIT_SHIFT_WMAC_MU_DBGSEL_V1) & BIT_MASK_WMAC_MU_DBGSEL_V1)
#define BIT_SET_WMAC_MU_DBGSEL_V1(x, v) \
(BIT_CLEAR_WMAC_MU_DBGSEL_V1(x) | BIT_WMAC_MU_DBGSEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MCU_TEST_1 (Offset 0x0630) */
#define BIT_SHIFT_MCU_RSVD 0
#define BIT_MASK_MCU_RSVD 0xffffffffL
#define BIT_MCU_RSVD(x) (((x) & BIT_MASK_MCU_RSVD) << BIT_SHIFT_MCU_RSVD)
#define BITS_MCU_RSVD (BIT_MASK_MCU_RSVD << BIT_SHIFT_MCU_RSVD)
#define BIT_CLEAR_MCU_RSVD(x) ((x) & (~BITS_MCU_RSVD))
#define BIT_GET_MCU_RSVD(x) (((x) >> BIT_SHIFT_MCU_RSVD) & BIT_MASK_MCU_RSVD)
#define BIT_SET_MCU_RSVD(x, v) (BIT_CLEAR_MCU_RSVD(x) | BIT_MCU_RSVD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TCR_TSFT_OFS (Offset 0x0630) */
#define BIT_SHIFT_WMAC_TCR_TSFT_OFS 0
#define BIT_MASK_WMAC_TCR_TSFT_OFS 0xffff
#define BIT_WMAC_TCR_TSFT_OFS(x) \
(((x) & BIT_MASK_WMAC_TCR_TSFT_OFS) << BIT_SHIFT_WMAC_TCR_TSFT_OFS)
#define BITS_WMAC_TCR_TSFT_OFS \
(BIT_MASK_WMAC_TCR_TSFT_OFS << BIT_SHIFT_WMAC_TCR_TSFT_OFS)
#define BIT_CLEAR_WMAC_TCR_TSFT_OFS(x) ((x) & (~BITS_WMAC_TCR_TSFT_OFS))
#define BIT_GET_WMAC_TCR_TSFT_OFS(x) \
(((x) >> BIT_SHIFT_WMAC_TCR_TSFT_OFS) & BIT_MASK_WMAC_TCR_TSFT_OFS)
#define BIT_SET_WMAC_TCR_TSFT_OFS(x, v) \
(BIT_CLEAR_WMAC_TCR_TSFT_OFS(x) | BIT_WMAC_TCR_TSFT_OFS(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_UDF_THSD (Offset 0x0632) */
#define BIT_CSIRPT_LEN_BB_MORE_THAN_MAC BIT(23)
#define BIT_CSI_CHKSUM_ERROR BIT(22)
#define BIT_MACRX_ERR_4 BIT(20)
#define BIT_MACRX_ERR_3 BIT(19)
#define BIT_MACRX_ERR_2 BIT(18)
#define BIT_SHIFT_WMAC_RESP_ANTD 12
#define BIT_MASK_WMAC_RESP_ANTD 0xf
#define BIT_WMAC_RESP_ANTD(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTD) << BIT_SHIFT_WMAC_RESP_ANTD)
#define BITS_WMAC_RESP_ANTD \
(BIT_MASK_WMAC_RESP_ANTD << BIT_SHIFT_WMAC_RESP_ANTD)
#define BIT_CLEAR_WMAC_RESP_ANTD(x) ((x) & (~BITS_WMAC_RESP_ANTD))
#define BIT_GET_WMAC_RESP_ANTD(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTD) & BIT_MASK_WMAC_RESP_ANTD)
#define BIT_SET_WMAC_RESP_ANTD(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTD(x) | BIT_WMAC_RESP_ANTD(v))
#define BIT_SHIFT_WMAC_RESP_ANTC 8
#define BIT_MASK_WMAC_RESP_ANTC 0xf
#define BIT_WMAC_RESP_ANTC(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTC) << BIT_SHIFT_WMAC_RESP_ANTC)
#define BITS_WMAC_RESP_ANTC \
(BIT_MASK_WMAC_RESP_ANTC << BIT_SHIFT_WMAC_RESP_ANTC)
#define BIT_CLEAR_WMAC_RESP_ANTC(x) ((x) & (~BITS_WMAC_RESP_ANTC))
#define BIT_GET_WMAC_RESP_ANTC(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTC) & BIT_MASK_WMAC_RESP_ANTC)
#define BIT_SET_WMAC_RESP_ANTC(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTC(x) | BIT_WMAC_RESP_ANTC(v))
#define BIT_UDF_THSD_V1 BIT(7)
#define BIT_SHIFT_WMAC_RESP_ANTB 4
#define BIT_MASK_WMAC_RESP_ANTB 0xf
#define BIT_WMAC_RESP_ANTB(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTB) << BIT_SHIFT_WMAC_RESP_ANTB)
#define BITS_WMAC_RESP_ANTB \
(BIT_MASK_WMAC_RESP_ANTB << BIT_SHIFT_WMAC_RESP_ANTB)
#define BIT_CLEAR_WMAC_RESP_ANTB(x) ((x) & (~BITS_WMAC_RESP_ANTB))
#define BIT_GET_WMAC_RESP_ANTB(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTB) & BIT_MASK_WMAC_RESP_ANTB)
#define BIT_SET_WMAC_RESP_ANTB(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTB(x) | BIT_WMAC_RESP_ANTB(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_UDF_THSD (Offset 0x0632) */
#define BIT_SHIFT_UDF_THSD 0
#define BIT_MASK_UDF_THSD 0xff
#define BIT_UDF_THSD(x) (((x) & BIT_MASK_UDF_THSD) << BIT_SHIFT_UDF_THSD)
#define BITS_UDF_THSD (BIT_MASK_UDF_THSD << BIT_SHIFT_UDF_THSD)
#define BIT_CLEAR_UDF_THSD(x) ((x) & (~BITS_UDF_THSD))
#define BIT_GET_UDF_THSD(x) (((x) >> BIT_SHIFT_UDF_THSD) & BIT_MASK_UDF_THSD)
#define BIT_SET_UDF_THSD(x, v) (BIT_CLEAR_UDF_THSD(x) | BIT_UDF_THSD(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_UDF_THSD (Offset 0x0632) */
#define BIT_SHIFT_UDF_THSD_VALUE 0
#define BIT_MASK_UDF_THSD_VALUE 0x7f
#define BIT_UDF_THSD_VALUE(x) \
(((x) & BIT_MASK_UDF_THSD_VALUE) << BIT_SHIFT_UDF_THSD_VALUE)
#define BITS_UDF_THSD_VALUE \
(BIT_MASK_UDF_THSD_VALUE << BIT_SHIFT_UDF_THSD_VALUE)
#define BIT_CLEAR_UDF_THSD_VALUE(x) ((x) & (~BITS_UDF_THSD_VALUE))
#define BIT_GET_UDF_THSD_VALUE(x) \
(((x) >> BIT_SHIFT_UDF_THSD_VALUE) & BIT_MASK_UDF_THSD_VALUE)
#define BIT_SET_UDF_THSD_VALUE(x, v) \
(BIT_CLEAR_UDF_THSD_VALUE(x) | BIT_UDF_THSD_VALUE(v))
#define BIT_SHIFT_WMAC_RESP_ANTA 0
#define BIT_MASK_WMAC_RESP_ANTA 0xf
#define BIT_WMAC_RESP_ANTA(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTA) << BIT_SHIFT_WMAC_RESP_ANTA)
#define BITS_WMAC_RESP_ANTA \
(BIT_MASK_WMAC_RESP_ANTA << BIT_SHIFT_WMAC_RESP_ANTA)
#define BIT_CLEAR_WMAC_RESP_ANTA(x) ((x) & (~BITS_WMAC_RESP_ANTA))
#define BIT_GET_WMAC_RESP_ANTA(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTA) & BIT_MASK_WMAC_RESP_ANTA)
#define BIT_SET_WMAC_RESP_ANTA(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTA(x) | BIT_WMAC_RESP_ANTA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_ZLD_NUM (Offset 0x0633) */
#define BIT_SHIFT_ZLD_NUM 0
#define BIT_MASK_ZLD_NUM 0xff
#define BIT_ZLD_NUM(x) (((x) & BIT_MASK_ZLD_NUM) << BIT_SHIFT_ZLD_NUM)
#define BITS_ZLD_NUM (BIT_MASK_ZLD_NUM << BIT_SHIFT_ZLD_NUM)
#define BIT_CLEAR_ZLD_NUM(x) ((x) & (~BITS_ZLD_NUM))
#define BIT_GET_ZLD_NUM(x) (((x) >> BIT_SHIFT_ZLD_NUM) & BIT_MASK_ZLD_NUM)
#define BIT_SET_ZLD_NUM(x, v) (BIT_CLEAR_ZLD_NUM(x) | BIT_ZLD_NUM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_MCU_TEST_2 (Offset 0x0634) */
#define BIT_SHIFT_MCU_RSVD_2 0
#define BIT_MASK_MCU_RSVD_2 0xffffffffL
#define BIT_MCU_RSVD_2(x) (((x) & BIT_MASK_MCU_RSVD_2) << BIT_SHIFT_MCU_RSVD_2)
#define BITS_MCU_RSVD_2 (BIT_MASK_MCU_RSVD_2 << BIT_SHIFT_MCU_RSVD_2)
#define BIT_CLEAR_MCU_RSVD_2(x) ((x) & (~BITS_MCU_RSVD_2))
#define BIT_GET_MCU_RSVD_2(x) \
(((x) >> BIT_SHIFT_MCU_RSVD_2) & BIT_MASK_MCU_RSVD_2)
#define BIT_SET_MCU_RSVD_2(x, v) (BIT_CLEAR_MCU_RSVD_2(x) | BIT_MCU_RSVD_2(v))
#define BIT_SHIFT_WKFCAM_NUM 0
#define BIT_MASK_WKFCAM_NUM 0x7f
#define BIT_WKFCAM_NUM(x) (((x) & BIT_MASK_WKFCAM_NUM) << BIT_SHIFT_WKFCAM_NUM)
#define BITS_WKFCAM_NUM (BIT_MASK_WKFCAM_NUM << BIT_SHIFT_WKFCAM_NUM)
#define BIT_CLEAR_WKFCAM_NUM(x) ((x) & (~BITS_WKFCAM_NUM))
#define BIT_GET_WKFCAM_NUM(x) \
(((x) >> BIT_SHIFT_WKFCAM_NUM) & BIT_MASK_WKFCAM_NUM)
#define BIT_SET_WKFCAM_NUM(x, v) (BIT_CLEAR_WKFCAM_NUM(x) | BIT_WKFCAM_NUM(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_STMP_THSD (Offset 0x0634) */
#define BIT_SHIFT_STMP_THSD 0
#define BIT_MASK_STMP_THSD 0xff
#define BIT_STMP_THSD(x) (((x) & BIT_MASK_STMP_THSD) << BIT_SHIFT_STMP_THSD)
#define BITS_STMP_THSD (BIT_MASK_STMP_THSD << BIT_SHIFT_STMP_THSD)
#define BIT_CLEAR_STMP_THSD(x) ((x) & (~BITS_STMP_THSD))
#define BIT_GET_STMP_THSD(x) (((x) >> BIT_SHIFT_STMP_THSD) & BIT_MASK_STMP_THSD)
#define BIT_SET_STMP_THSD(x, v) (BIT_CLEAR_STMP_THSD(x) | BIT_STMP_THSD(v))
/* 2 REG_WMAC_TXTIMEOUT (Offset 0x0635) */
#define BIT_SHIFT_WMAC_TXTIMEOUT 0
#define BIT_MASK_WMAC_TXTIMEOUT 0xff
#define BIT_WMAC_TXTIMEOUT(x) \
(((x) & BIT_MASK_WMAC_TXTIMEOUT) << BIT_SHIFT_WMAC_TXTIMEOUT)
#define BITS_WMAC_TXTIMEOUT \
(BIT_MASK_WMAC_TXTIMEOUT << BIT_SHIFT_WMAC_TXTIMEOUT)
#define BIT_CLEAR_WMAC_TXTIMEOUT(x) ((x) & (~BITS_WMAC_TXTIMEOUT))
#define BIT_GET_WMAC_TXTIMEOUT(x) \
(((x) >> BIT_SHIFT_WMAC_TXTIMEOUT) & BIT_MASK_WMAC_TXTIMEOUT)
#define BIT_SET_WMAC_TXTIMEOUT(x, v) \
(BIT_CLEAR_WMAC_TXTIMEOUT(x) | BIT_WMAC_TXTIMEOUT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_MCU_TEST_2_V1 (Offset 0x0636) */
#define BIT_SHIFT_MCU_RSVD_2_V1 0
#define BIT_MASK_MCU_RSVD_2_V1 0xffff
#define BIT_MCU_RSVD_2_V1(x) \
(((x) & BIT_MASK_MCU_RSVD_2_V1) << BIT_SHIFT_MCU_RSVD_2_V1)
#define BITS_MCU_RSVD_2_V1 (BIT_MASK_MCU_RSVD_2_V1 << BIT_SHIFT_MCU_RSVD_2_V1)
#define BIT_CLEAR_MCU_RSVD_2_V1(x) ((x) & (~BITS_MCU_RSVD_2_V1))
#define BIT_GET_MCU_RSVD_2_V1(x) \
(((x) >> BIT_SHIFT_MCU_RSVD_2_V1) & BIT_MASK_MCU_RSVD_2_V1)
#define BIT_SET_MCU_RSVD_2_V1(x, v) \
(BIT_CLEAR_MCU_RSVD_2_V1(x) | BIT_MCU_RSVD_2_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_USTIME_EDCA (Offset 0x0638) */
#define BIT_SHIFT_USTIME_EDCA 0
#define BIT_MASK_USTIME_EDCA 0xff
#define BIT_USTIME_EDCA(x) \
(((x) & BIT_MASK_USTIME_EDCA) << BIT_SHIFT_USTIME_EDCA)
#define BITS_USTIME_EDCA (BIT_MASK_USTIME_EDCA << BIT_SHIFT_USTIME_EDCA)
#define BIT_CLEAR_USTIME_EDCA(x) ((x) & (~BITS_USTIME_EDCA))
#define BIT_GET_USTIME_EDCA(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA) & BIT_MASK_USTIME_EDCA)
#define BIT_SET_USTIME_EDCA(x, v) \
(BIT_CLEAR_USTIME_EDCA(x) | BIT_USTIME_EDCA(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_USTIME_EDCA (Offset 0x0638) */
#define BIT_SHIFT_USTIME 0
#define BIT_MASK_USTIME 0xff
#define BIT_USTIME(x) (((x) & BIT_MASK_USTIME) << BIT_SHIFT_USTIME)
#define BITS_USTIME (BIT_MASK_USTIME << BIT_SHIFT_USTIME)
#define BIT_CLEAR_USTIME(x) ((x) & (~BITS_USTIME))
#define BIT_GET_USTIME(x) (((x) >> BIT_SHIFT_USTIME) & BIT_MASK_USTIME)
#define BIT_SET_USTIME(x, v) (BIT_CLEAR_USTIME(x) | BIT_USTIME(v))
#endif
#if (HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_USTIME_EDCA (Offset 0x0638) */
#define BIT_SHIFT_USTIME_EDCA_V1 0
#define BIT_MASK_USTIME_EDCA_V1 0x1ff
#define BIT_USTIME_EDCA_V1(x) \
(((x) & BIT_MASK_USTIME_EDCA_V1) << BIT_SHIFT_USTIME_EDCA_V1)
#define BITS_USTIME_EDCA_V1 \
(BIT_MASK_USTIME_EDCA_V1 << BIT_SHIFT_USTIME_EDCA_V1)
#define BIT_CLEAR_USTIME_EDCA_V1(x) ((x) & (~BITS_USTIME_EDCA_V1))
#define BIT_GET_USTIME_EDCA_V1(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA_V1) & BIT_MASK_USTIME_EDCA_V1)
#define BIT_SET_USTIME_EDCA_V1(x, v) \
(BIT_CLEAR_USTIME_EDCA_V1(x) | BIT_USTIME_EDCA_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ACKTO_CCK (Offset 0x0639) */
#define BIT_SHIFT_ACKTO_CCK 0
#define BIT_MASK_ACKTO_CCK 0xff
#define BIT_ACKTO_CCK(x) (((x) & BIT_MASK_ACKTO_CCK) << BIT_SHIFT_ACKTO_CCK)
#define BITS_ACKTO_CCK (BIT_MASK_ACKTO_CCK << BIT_SHIFT_ACKTO_CCK)
#define BIT_CLEAR_ACKTO_CCK(x) ((x) & (~BITS_ACKTO_CCK))
#define BIT_GET_ACKTO_CCK(x) (((x) >> BIT_SHIFT_ACKTO_CCK) & BIT_MASK_ACKTO_CCK)
#define BIT_SET_ACKTO_CCK(x, v) (BIT_CLEAR_ACKTO_CCK(x) | BIT_ACKTO_CCK(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_MAC_SPEC_SIFS (Offset 0x063A) */
#define BIT_SHIFT_SPEC_SIFS_OFDM 8
#define BIT_MASK_SPEC_SIFS_OFDM 0xff
#define BIT_SPEC_SIFS_OFDM(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM) << BIT_SHIFT_SPEC_SIFS_OFDM)
#define BITS_SPEC_SIFS_OFDM \
(BIT_MASK_SPEC_SIFS_OFDM << BIT_SHIFT_SPEC_SIFS_OFDM)
#define BIT_CLEAR_SPEC_SIFS_OFDM(x) ((x) & (~BITS_SPEC_SIFS_OFDM))
#define BIT_GET_SPEC_SIFS_OFDM(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM) & BIT_MASK_SPEC_SIFS_OFDM)
#define BIT_SET_SPEC_SIFS_OFDM(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM(x) | BIT_SPEC_SIFS_OFDM(v))
#define BIT_SHIFT_SPEC_SIFS_CCK 0
#define BIT_MASK_SPEC_SIFS_CCK 0xff
#define BIT_SPEC_SIFS_CCK(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK) << BIT_SHIFT_SPEC_SIFS_CCK)
#define BITS_SPEC_SIFS_CCK (BIT_MASK_SPEC_SIFS_CCK << BIT_SHIFT_SPEC_SIFS_CCK)
#define BIT_CLEAR_SPEC_SIFS_CCK(x) ((x) & (~BITS_SPEC_SIFS_CCK))
#define BIT_GET_SPEC_SIFS_CCK(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK) & BIT_MASK_SPEC_SIFS_CCK)
#define BIT_SET_SPEC_SIFS_CCK(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK(x) | BIT_SPEC_SIFS_CCK(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RESP_SIFS_CCK (Offset 0x063C) */
#define BIT_SHIFT_SIFS_R2T_CCK 8
#define BIT_MASK_SIFS_R2T_CCK 0xff
#define BIT_SIFS_R2T_CCK(x) \
(((x) & BIT_MASK_SIFS_R2T_CCK) << BIT_SHIFT_SIFS_R2T_CCK)
#define BITS_SIFS_R2T_CCK (BIT_MASK_SIFS_R2T_CCK << BIT_SHIFT_SIFS_R2T_CCK)
#define BIT_CLEAR_SIFS_R2T_CCK(x) ((x) & (~BITS_SIFS_R2T_CCK))
#define BIT_GET_SIFS_R2T_CCK(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_CCK) & BIT_MASK_SIFS_R2T_CCK)
#define BIT_SET_SIFS_R2T_CCK(x, v) \
(BIT_CLEAR_SIFS_R2T_CCK(x) | BIT_SIFS_R2T_CCK(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_SIFS_CCK (Offset 0x063C) */
#define BIT_SHIFT_R2T_SIFS_CCK 8
#define BIT_MASK_R2T_SIFS_CCK 0xff
#define BIT_R2T_SIFS_CCK(x) \
(((x) & BIT_MASK_R2T_SIFS_CCK) << BIT_SHIFT_R2T_SIFS_CCK)
#define BITS_R2T_SIFS_CCK (BIT_MASK_R2T_SIFS_CCK << BIT_SHIFT_R2T_SIFS_CCK)
#define BIT_CLEAR_R2T_SIFS_CCK(x) ((x) & (~BITS_R2T_SIFS_CCK))
#define BIT_GET_R2T_SIFS_CCK(x) \
(((x) >> BIT_SHIFT_R2T_SIFS_CCK) & BIT_MASK_R2T_SIFS_CCK)
#define BIT_SET_R2T_SIFS_CCK(x, v) \
(BIT_CLEAR_R2T_SIFS_CCK(x) | BIT_R2T_SIFS_CCK(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RESP_SIFS_CCK (Offset 0x063C) */
#define BIT_SHIFT_SIFS_T2T_CCK 0
#define BIT_MASK_SIFS_T2T_CCK 0xff
#define BIT_SIFS_T2T_CCK(x) \
(((x) & BIT_MASK_SIFS_T2T_CCK) << BIT_SHIFT_SIFS_T2T_CCK)
#define BITS_SIFS_T2T_CCK (BIT_MASK_SIFS_T2T_CCK << BIT_SHIFT_SIFS_T2T_CCK)
#define BIT_CLEAR_SIFS_T2T_CCK(x) ((x) & (~BITS_SIFS_T2T_CCK))
#define BIT_GET_SIFS_T2T_CCK(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_CCK) & BIT_MASK_SIFS_T2T_CCK)
#define BIT_SET_SIFS_T2T_CCK(x, v) \
(BIT_CLEAR_SIFS_T2T_CCK(x) | BIT_SIFS_T2T_CCK(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_SIFS_CCK (Offset 0x063C) */
#define BIT_SHIFT_T2T_SIFS_CCK 0
#define BIT_MASK_T2T_SIFS_CCK 0xff
#define BIT_T2T_SIFS_CCK(x) \
(((x) & BIT_MASK_T2T_SIFS_CCK) << BIT_SHIFT_T2T_SIFS_CCK)
#define BITS_T2T_SIFS_CCK (BIT_MASK_T2T_SIFS_CCK << BIT_SHIFT_T2T_SIFS_CCK)
#define BIT_CLEAR_T2T_SIFS_CCK(x) ((x) & (~BITS_T2T_SIFS_CCK))
#define BIT_GET_T2T_SIFS_CCK(x) \
(((x) >> BIT_SHIFT_T2T_SIFS_CCK) & BIT_MASK_T2T_SIFS_CCK)
#define BIT_SET_T2T_SIFS_CCK(x, v) \
(BIT_CLEAR_T2T_SIFS_CCK(x) | BIT_T2T_SIFS_CCK(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RESP_SIFS_OFDM (Offset 0x063E) */
#define BIT_SHIFT_SIFS_R2T_OFDM 8
#define BIT_MASK_SIFS_R2T_OFDM 0xff
#define BIT_SIFS_R2T_OFDM(x) \
(((x) & BIT_MASK_SIFS_R2T_OFDM) << BIT_SHIFT_SIFS_R2T_OFDM)
#define BITS_SIFS_R2T_OFDM (BIT_MASK_SIFS_R2T_OFDM << BIT_SHIFT_SIFS_R2T_OFDM)
#define BIT_CLEAR_SIFS_R2T_OFDM(x) ((x) & (~BITS_SIFS_R2T_OFDM))
#define BIT_GET_SIFS_R2T_OFDM(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_OFDM) & BIT_MASK_SIFS_R2T_OFDM)
#define BIT_SET_SIFS_R2T_OFDM(x, v) \
(BIT_CLEAR_SIFS_R2T_OFDM(x) | BIT_SIFS_R2T_OFDM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_SIFS_OFDM (Offset 0x063E) */
#define BIT_SHIFT_R2T_SIFS_OFDM 8
#define BIT_MASK_R2T_SIFS_OFDM 0xff
#define BIT_R2T_SIFS_OFDM(x) \
(((x) & BIT_MASK_R2T_SIFS_OFDM) << BIT_SHIFT_R2T_SIFS_OFDM)
#define BITS_R2T_SIFS_OFDM (BIT_MASK_R2T_SIFS_OFDM << BIT_SHIFT_R2T_SIFS_OFDM)
#define BIT_CLEAR_R2T_SIFS_OFDM(x) ((x) & (~BITS_R2T_SIFS_OFDM))
#define BIT_GET_R2T_SIFS_OFDM(x) \
(((x) >> BIT_SHIFT_R2T_SIFS_OFDM) & BIT_MASK_R2T_SIFS_OFDM)
#define BIT_SET_R2T_SIFS_OFDM(x, v) \
(BIT_CLEAR_R2T_SIFS_OFDM(x) | BIT_R2T_SIFS_OFDM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RESP_SIFS_OFDM (Offset 0x063E) */
#define BIT_SHIFT_SIFS_T2T_OFDM 0
#define BIT_MASK_SIFS_T2T_OFDM 0xff
#define BIT_SIFS_T2T_OFDM(x) \
(((x) & BIT_MASK_SIFS_T2T_OFDM) << BIT_SHIFT_SIFS_T2T_OFDM)
#define BITS_SIFS_T2T_OFDM (BIT_MASK_SIFS_T2T_OFDM << BIT_SHIFT_SIFS_T2T_OFDM)
#define BIT_CLEAR_SIFS_T2T_OFDM(x) ((x) & (~BITS_SIFS_T2T_OFDM))
#define BIT_GET_SIFS_T2T_OFDM(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_OFDM) & BIT_MASK_SIFS_T2T_OFDM)
#define BIT_SET_SIFS_T2T_OFDM(x, v) \
(BIT_CLEAR_SIFS_T2T_OFDM(x) | BIT_SIFS_T2T_OFDM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_SIFS_OFDM (Offset 0x063E) */
#define BIT_SHIFT_T2T_SIFS_OFDM 0
#define BIT_MASK_T2T_SIFS_OFDM 0xff
#define BIT_T2T_SIFS_OFDM(x) \
(((x) & BIT_MASK_T2T_SIFS_OFDM) << BIT_SHIFT_T2T_SIFS_OFDM)
#define BITS_T2T_SIFS_OFDM (BIT_MASK_T2T_SIFS_OFDM << BIT_SHIFT_T2T_SIFS_OFDM)
#define BIT_CLEAR_T2T_SIFS_OFDM(x) ((x) & (~BITS_T2T_SIFS_OFDM))
#define BIT_GET_T2T_SIFS_OFDM(x) \
(((x) >> BIT_SHIFT_T2T_SIFS_OFDM) & BIT_MASK_T2T_SIFS_OFDM)
#define BIT_SET_T2T_SIFS_OFDM(x, v) \
(BIT_CLEAR_T2T_SIFS_OFDM(x) | BIT_T2T_SIFS_OFDM(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ACKTO (Offset 0x0640) */
#define BIT_SHIFT_ACKTO 0
#define BIT_MASK_ACKTO 0xff
#define BIT_ACKTO(x) (((x) & BIT_MASK_ACKTO) << BIT_SHIFT_ACKTO)
#define BITS_ACKTO (BIT_MASK_ACKTO << BIT_SHIFT_ACKTO)
#define BIT_CLEAR_ACKTO(x) ((x) & (~BITS_ACKTO))
#define BIT_GET_ACKTO(x) (((x) >> BIT_SHIFT_ACKTO) & BIT_MASK_ACKTO)
#define BIT_SET_ACKTO(x, v) (BIT_CLEAR_ACKTO(x) | BIT_ACKTO(v))
/* 2 REG_CTS2TO (Offset 0x0641) */
#define BIT_SHIFT_CTS2TO 0
#define BIT_MASK_CTS2TO 0xff
#define BIT_CTS2TO(x) (((x) & BIT_MASK_CTS2TO) << BIT_SHIFT_CTS2TO)
#define BITS_CTS2TO (BIT_MASK_CTS2TO << BIT_SHIFT_CTS2TO)
#define BIT_CLEAR_CTS2TO(x) ((x) & (~BITS_CTS2TO))
#define BIT_GET_CTS2TO(x) (((x) >> BIT_SHIFT_CTS2TO) & BIT_MASK_CTS2TO)
#define BIT_SET_CTS2TO(x, v) (BIT_CLEAR_CTS2TO(x) | BIT_CTS2TO(v))
/* 2 REG_EIFS (Offset 0x0642) */
#define BIT_SHIFT_EIFS 0
#define BIT_MASK_EIFS 0xffff
#define BIT_EIFS(x) (((x) & BIT_MASK_EIFS) << BIT_SHIFT_EIFS)
#define BITS_EIFS (BIT_MASK_EIFS << BIT_SHIFT_EIFS)
#define BIT_CLEAR_EIFS(x) ((x) & (~BITS_EIFS))
#define BIT_GET_EIFS(x) (((x) >> BIT_SHIFT_EIFS) & BIT_MASK_EIFS)
#define BIT_SET_EIFS(x, v) (BIT_CLEAR_EIFS(x) | BIT_EIFS(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_MAP0 (Offset 0x0644) */
#define BIT_MGT_RPFM15EN BIT(15)
#define BIT_MGT_RPFM14EN BIT(14)
#define BIT_MGT_RPFM13EN BIT(13)
#define BIT_MGT_RPFM12EN BIT(12)
#define BIT_MGT_RPFM11EN BIT(11)
#define BIT_MGT_RPFM10EN BIT(10)
#define BIT_MGT_RPFM9EN BIT(9)
#define BIT_MGT_RPFM8EN BIT(8)
#define BIT_MGT_RPFM7EN BIT(7)
#define BIT_MGT_RPFM6EN BIT(6)
#define BIT_MGT_RPFM5EN BIT(5)
#define BIT_MGT_RPFM4EN BIT(4)
#define BIT_MGT_RPFM3EN BIT(3)
#define BIT_MGT_RPFM2EN BIT(2)
#define BIT_MGT_RPFM1EN BIT(1)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RPFM_MAP0 (Offset 0x0644) */
#define BIT_SHIFT_RPFM_MAP0 0
#define BIT_MASK_RPFM_MAP0 0xffff
#define BIT_RPFM_MAP0(x) (((x) & BIT_MASK_RPFM_MAP0) << BIT_SHIFT_RPFM_MAP0)
#define BITS_RPFM_MAP0 (BIT_MASK_RPFM_MAP0 << BIT_SHIFT_RPFM_MAP0)
#define BIT_CLEAR_RPFM_MAP0(x) ((x) & (~BITS_RPFM_MAP0))
#define BIT_GET_RPFM_MAP0(x) (((x) >> BIT_SHIFT_RPFM_MAP0) & BIT_MASK_RPFM_MAP0)
#define BIT_SET_RPFM_MAP0(x, v) (BIT_CLEAR_RPFM_MAP0(x) | BIT_RPFM_MAP0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_MAP0 (Offset 0x0644) */
#define BIT_MGT_RPFM0EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_MAP1_V1 (Offset 0x0646) */
#define BIT_DATA_RPFM15EN BIT(15)
#define BIT_DATA_RPFM14EN BIT(14)
#define BIT_DATA_RPFM13EN BIT(13)
#define BIT_DATA_RPFM12EN BIT(12)
#define BIT_DATA_RPFM11EN BIT(11)
#define BIT_DATA_RPFM10EN BIT(10)
#define BIT_DATA_RPFM9EN BIT(9)
#define BIT_DATA_RPFM8EN BIT(8)
#define BIT_DATA_RPFM7EN BIT(7)
#define BIT_DATA_RPFM6EN BIT(6)
#define BIT_DATA_RPFM5EN BIT(5)
#define BIT_DATA_RPFM4EN BIT(4)
#define BIT_DATA_RPFM3EN BIT(3)
#define BIT_DATA_RPFM2EN BIT(2)
#define BIT_DATA_RPFM1EN BIT(1)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RPFM_MAP1 (Offset 0x0646) */
#define BIT_SHIFT_RPFM_MAP1 0
#define BIT_MASK_RPFM_MAP1 0xffff
#define BIT_RPFM_MAP1(x) (((x) & BIT_MASK_RPFM_MAP1) << BIT_SHIFT_RPFM_MAP1)
#define BITS_RPFM_MAP1 (BIT_MASK_RPFM_MAP1 << BIT_SHIFT_RPFM_MAP1)
#define BIT_CLEAR_RPFM_MAP1(x) ((x) & (~BITS_RPFM_MAP1))
#define BIT_GET_RPFM_MAP1(x) (((x) >> BIT_SHIFT_RPFM_MAP1) & BIT_MASK_RPFM_MAP1)
#define BIT_SET_RPFM_MAP1(x, v) (BIT_CLEAR_RPFM_MAP1(x) | BIT_RPFM_MAP1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_MAP1_V1 (Offset 0x0646) */
#define BIT_DATA_RPFM0EN BIT(0)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_CAM_CMD (Offset 0x0648) */
#define BIT_RPFM_CAM_POLLING BIT(31)
#define BIT_RPFM_CAM_CLR BIT(30)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RPFM_CAM_CMD (Offset 0x0648) */
#define BIT_RPFM_CAM_WR BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_CAM_CMD (Offset 0x0648) */
#define BIT_RPFM_CAM_WE BIT(16)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RPFM_CAM_CMD (Offset 0x0648) */
#define BIT_SHIFT_RPFM_CAM_ADDR 0
#define BIT_MASK_RPFM_CAM_ADDR 0x7f
#define BIT_RPFM_CAM_ADDR(x) \
(((x) & BIT_MASK_RPFM_CAM_ADDR) << BIT_SHIFT_RPFM_CAM_ADDR)
#define BITS_RPFM_CAM_ADDR (BIT_MASK_RPFM_CAM_ADDR << BIT_SHIFT_RPFM_CAM_ADDR)
#define BIT_CLEAR_RPFM_CAM_ADDR(x) ((x) & (~BITS_RPFM_CAM_ADDR))
#define BIT_GET_RPFM_CAM_ADDR(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_ADDR) & BIT_MASK_RPFM_CAM_ADDR)
#define BIT_SET_RPFM_CAM_ADDR(x, v) \
(BIT_CLEAR_RPFM_CAM_ADDR(x) | BIT_RPFM_CAM_ADDR(v))
/* 2 REG_RPFM_CAM_RWD (Offset 0x064C) */
#define BIT_SHIFT_RPFM_CAM_RWD 0
#define BIT_MASK_RPFM_CAM_RWD 0xffffffffL
#define BIT_RPFM_CAM_RWD(x) \
(((x) & BIT_MASK_RPFM_CAM_RWD) << BIT_SHIFT_RPFM_CAM_RWD)
#define BITS_RPFM_CAM_RWD (BIT_MASK_RPFM_CAM_RWD << BIT_SHIFT_RPFM_CAM_RWD)
#define BIT_CLEAR_RPFM_CAM_RWD(x) ((x) & (~BITS_RPFM_CAM_RWD))
#define BIT_GET_RPFM_CAM_RWD(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_RWD) & BIT_MASK_RPFM_CAM_RWD)
#define BIT_SET_RPFM_CAM_RWD(x, v) \
(BIT_CLEAR_RPFM_CAM_RWD(x) | BIT_RPFM_CAM_RWD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_NAV_CTRL (Offset 0x0650) */
#define BIT_SHIFT_NAV_UPPER 16
#define BIT_MASK_NAV_UPPER 0xff
#define BIT_NAV_UPPER(x) (((x) & BIT_MASK_NAV_UPPER) << BIT_SHIFT_NAV_UPPER)
#define BITS_NAV_UPPER (BIT_MASK_NAV_UPPER << BIT_SHIFT_NAV_UPPER)
#define BIT_CLEAR_NAV_UPPER(x) ((x) & (~BITS_NAV_UPPER))
#define BIT_GET_NAV_UPPER(x) (((x) >> BIT_SHIFT_NAV_UPPER) & BIT_MASK_NAV_UPPER)
#define BIT_SET_NAV_UPPER(x, v) (BIT_CLEAR_NAV_UPPER(x) | BIT_NAV_UPPER(v))
#define BIT_SHIFT_RXMYRTS_NAV 8
#define BIT_MASK_RXMYRTS_NAV 0xf
#define BIT_RXMYRTS_NAV(x) \
(((x) & BIT_MASK_RXMYRTS_NAV) << BIT_SHIFT_RXMYRTS_NAV)
#define BITS_RXMYRTS_NAV (BIT_MASK_RXMYRTS_NAV << BIT_SHIFT_RXMYRTS_NAV)
#define BIT_CLEAR_RXMYRTS_NAV(x) ((x) & (~BITS_RXMYRTS_NAV))
#define BIT_GET_RXMYRTS_NAV(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV) & BIT_MASK_RXMYRTS_NAV)
#define BIT_SET_RXMYRTS_NAV(x, v) \
(BIT_CLEAR_RXMYRTS_NAV(x) | BIT_RXMYRTS_NAV(v))
#define BIT_SHIFT_RTSRST 0
#define BIT_MASK_RTSRST 0xff
#define BIT_RTSRST(x) (((x) & BIT_MASK_RTSRST) << BIT_SHIFT_RTSRST)
#define BITS_RTSRST (BIT_MASK_RTSRST << BIT_SHIFT_RTSRST)
#define BIT_CLEAR_RTSRST(x) ((x) & (~BITS_RTSRST))
#define BIT_GET_RTSRST(x) (((x) >> BIT_SHIFT_RTSRST) & BIT_MASK_RTSRST)
#define BIT_SET_RTSRST(x, v) (BIT_CLEAR_RTSRST(x) | BIT_RTSRST(v))
/* 2 REG_BACAMCMD (Offset 0x0654) */
#define BIT_BACAM_POLL BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BACAMCMD (Offset 0x0654) */
#define BIT_BACAM_RST BIT(17)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BACAMCMD (Offset 0x0654) */
#define BIT_BACAM_RW BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_BACAMCMD (Offset 0x0654) */
#define BIT_SHIFT_TXSBM 14
#define BIT_MASK_TXSBM 0x3
#define BIT_TXSBM(x) (((x) & BIT_MASK_TXSBM) << BIT_SHIFT_TXSBM)
#define BITS_TXSBM (BIT_MASK_TXSBM << BIT_SHIFT_TXSBM)
#define BIT_CLEAR_TXSBM(x) ((x) & (~BITS_TXSBM))
#define BIT_GET_TXSBM(x) (((x) >> BIT_SHIFT_TXSBM) & BIT_MASK_TXSBM)
#define BIT_SET_TXSBM(x, v) (BIT_CLEAR_TXSBM(x) | BIT_TXSBM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BACAMCMD (Offset 0x0654) */
#define BIT_SHIFT_TXSBMPMOD 14
#define BIT_MASK_TXSBMPMOD 0x3
#define BIT_TXSBMPMOD(x) (((x) & BIT_MASK_TXSBMPMOD) << BIT_SHIFT_TXSBMPMOD)
#define BITS_TXSBMPMOD (BIT_MASK_TXSBMPMOD << BIT_SHIFT_TXSBMPMOD)
#define BIT_CLEAR_TXSBMPMOD(x) ((x) & (~BITS_TXSBMPMOD))
#define BIT_GET_TXSBMPMOD(x) (((x) >> BIT_SHIFT_TXSBMPMOD) & BIT_MASK_TXSBMPMOD)
#define BIT_SET_TXSBMPMOD(x, v) (BIT_CLEAR_TXSBMPMOD(x) | BIT_TXSBMPMOD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BACAMCMD (Offset 0x0654) */
#define BIT_SHIFT_BACAM_ADDR 0
#define BIT_MASK_BACAM_ADDR 0x3f
#define BIT_BACAM_ADDR(x) (((x) & BIT_MASK_BACAM_ADDR) << BIT_SHIFT_BACAM_ADDR)
#define BITS_BACAM_ADDR (BIT_MASK_BACAM_ADDR << BIT_SHIFT_BACAM_ADDR)
#define BIT_CLEAR_BACAM_ADDR(x) ((x) & (~BITS_BACAM_ADDR))
#define BIT_GET_BACAM_ADDR(x) \
(((x) >> BIT_SHIFT_BACAM_ADDR) & BIT_MASK_BACAM_ADDR)
#define BIT_SET_BACAM_ADDR(x, v) (BIT_CLEAR_BACAM_ADDR(x) | BIT_BACAM_ADDR(v))
#define BIT_SHIFT_BA_CONTENT_L 0
#define BIT_MASK_BA_CONTENT_L 0xffffffffL
#define BIT_BA_CONTENT_L(x) \
(((x) & BIT_MASK_BA_CONTENT_L) << BIT_SHIFT_BA_CONTENT_L)
#define BITS_BA_CONTENT_L (BIT_MASK_BA_CONTENT_L << BIT_SHIFT_BA_CONTENT_L)
#define BIT_CLEAR_BA_CONTENT_L(x) ((x) & (~BITS_BA_CONTENT_L))
#define BIT_GET_BA_CONTENT_L(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_L) & BIT_MASK_BA_CONTENT_L)
#define BIT_SET_BA_CONTENT_L(x, v) \
(BIT_CLEAR_BA_CONTENT_L(x) | BIT_BA_CONTENT_L(v))
#define BIT_SHIFT_LBDLY 0
#define BIT_MASK_LBDLY 0x1f
#define BIT_LBDLY(x) (((x) & BIT_MASK_LBDLY) << BIT_SHIFT_LBDLY)
#define BITS_LBDLY (BIT_MASK_LBDLY << BIT_SHIFT_LBDLY)
#define BIT_CLEAR_LBDLY(x) ((x) & (~BITS_LBDLY))
#define BIT_GET_LBDLY(x) (((x) >> BIT_SHIFT_LBDLY) & BIT_MASK_LBDLY)
#define BIT_SET_LBDLY(x, v) (BIT_CLEAR_LBDLY(x) | BIT_LBDLY(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_BITMAP_CMD (Offset 0x0661) */
#define BIT_BACAM_RPMEN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_BACAM_RPMEN (Offset 0x0661) */
#define BIT_WMAC_BACAM_RPMEN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TX_RX (Offset 0x0662) */
#define BIT_SHIFT_RXPKT_TYPE 2
#define BIT_MASK_RXPKT_TYPE 0x3f
#define BIT_RXPKT_TYPE(x) (((x) & BIT_MASK_RXPKT_TYPE) << BIT_SHIFT_RXPKT_TYPE)
#define BITS_RXPKT_TYPE (BIT_MASK_RXPKT_TYPE << BIT_SHIFT_RXPKT_TYPE)
#define BIT_CLEAR_RXPKT_TYPE(x) ((x) & (~BITS_RXPKT_TYPE))
#define BIT_GET_RXPKT_TYPE(x) \
(((x) >> BIT_SHIFT_RXPKT_TYPE) & BIT_MASK_RXPKT_TYPE)
#define BIT_SET_RXPKT_TYPE(x, v) (BIT_CLEAR_RXPKT_TYPE(x) | BIT_RXPKT_TYPE(v))
#define BIT_TXACT_IND BIT(1)
#define BIT_RXACT_IND BIT(0)
/* 2 REG_WMAC_BITMAP_CTL (Offset 0x0663) */
#define BIT_BITMAP_VO BIT(7)
#define BIT_BITMAP_VI BIT(6)
#define BIT_BITMAP_BE BIT(5)
#define BIT_BITMAP_BK BIT(4)
#define BIT_SHIFT_BITMAP_CONDITION 2
#define BIT_MASK_BITMAP_CONDITION 0x3
#define BIT_BITMAP_CONDITION(x) \
(((x) & BIT_MASK_BITMAP_CONDITION) << BIT_SHIFT_BITMAP_CONDITION)
#define BITS_BITMAP_CONDITION \
(BIT_MASK_BITMAP_CONDITION << BIT_SHIFT_BITMAP_CONDITION)
#define BIT_CLEAR_BITMAP_CONDITION(x) ((x) & (~BITS_BITMAP_CONDITION))
#define BIT_GET_BITMAP_CONDITION(x) \
(((x) >> BIT_SHIFT_BITMAP_CONDITION) & BIT_MASK_BITMAP_CONDITION)
#define BIT_SET_BITMAP_CONDITION(x, v) \
(BIT_CLEAR_BITMAP_CONDITION(x) | BIT_BITMAP_CONDITION(v))
#define BIT_BITMAP_SSNBK_COUNTER_CLR BIT(1)
#define BIT_BITMAP_FORCE BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_SHIFT_RXERR_RPT_SEL_V1_3_0 28
#define BIT_MASK_RXERR_RPT_SEL_V1_3_0 0xf
#define BIT_RXERR_RPT_SEL_V1_3_0(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL_V1_3_0) \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0)
#define BITS_RXERR_RPT_SEL_V1_3_0 \
(BIT_MASK_RXERR_RPT_SEL_V1_3_0 << BIT_SHIFT_RXERR_RPT_SEL_V1_3_0)
#define BIT_CLEAR_RXERR_RPT_SEL_V1_3_0(x) ((x) & (~BITS_RXERR_RPT_SEL_V1_3_0))
#define BIT_GET_RXERR_RPT_SEL_V1_3_0(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL_V1_3_0) & \
BIT_MASK_RXERR_RPT_SEL_V1_3_0)
#define BIT_SET_RXERR_RPT_SEL_V1_3_0(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL_V1_3_0(x) | BIT_RXERR_RPT_SEL_V1_3_0(v))
#endif
#if (HALMAC_8881A_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_SHIFT_RXERR_RPT_SEL 28
#define BIT_MASK_RXERR_RPT_SEL 0xf
#define BIT_RXERR_RPT_SEL(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL) << BIT_SHIFT_RXERR_RPT_SEL)
#define BITS_RXERR_RPT_SEL (BIT_MASK_RXERR_RPT_SEL << BIT_SHIFT_RXERR_RPT_SEL)
#define BIT_CLEAR_RXERR_RPT_SEL(x) ((x) & (~BITS_RXERR_RPT_SEL))
#define BIT_GET_RXERR_RPT_SEL(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL) & BIT_MASK_RXERR_RPT_SEL)
#define BIT_SET_RXERR_RPT_SEL(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL(x) | BIT_RXERR_RPT_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_RXERR_RPT_RST BIT(27)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_RXERR_RPT_SEL_V1_4 BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_SHIFT_UD_SELECT_BSSID_2_1 24
#define BIT_MASK_UD_SELECT_BSSID_2_1 0x3
#define BIT_UD_SELECT_BSSID_2_1(x) \
(((x) & BIT_MASK_UD_SELECT_BSSID_2_1) << BIT_SHIFT_UD_SELECT_BSSID_2_1)
#define BITS_UD_SELECT_BSSID_2_1 \
(BIT_MASK_UD_SELECT_BSSID_2_1 << BIT_SHIFT_UD_SELECT_BSSID_2_1)
#define BIT_CLEAR_UD_SELECT_BSSID_2_1(x) ((x) & (~BITS_UD_SELECT_BSSID_2_1))
#define BIT_GET_UD_SELECT_BSSID_2_1(x) \
(((x) >> BIT_SHIFT_UD_SELECT_BSSID_2_1) & BIT_MASK_UD_SELECT_BSSID_2_1)
#define BIT_SET_UD_SELECT_BSSID_2_1(x, v) \
(BIT_CLEAR_UD_SELECT_BSSID_2_1(x) | BIT_UD_SELECT_BSSID_2_1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_W1S BIT(23)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_UD_SELECT_BSSID BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_UD_SELECT_BSSID_0 BIT(22)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_SHIFT_UD_SUB_TYPE 18
#define BIT_MASK_UD_SUB_TYPE 0xf
#define BIT_UD_SUB_TYPE(x) \
(((x) & BIT_MASK_UD_SUB_TYPE) << BIT_SHIFT_UD_SUB_TYPE)
#define BITS_UD_SUB_TYPE (BIT_MASK_UD_SUB_TYPE << BIT_SHIFT_UD_SUB_TYPE)
#define BIT_CLEAR_UD_SUB_TYPE(x) ((x) & (~BITS_UD_SUB_TYPE))
#define BIT_GET_UD_SUB_TYPE(x) \
(((x) >> BIT_SHIFT_UD_SUB_TYPE) & BIT_MASK_UD_SUB_TYPE)
#define BIT_SET_UD_SUB_TYPE(x, v) \
(BIT_CLEAR_UD_SUB_TYPE(x) | BIT_UD_SUB_TYPE(v))
#define BIT_SHIFT_UD_TYPE 16
#define BIT_MASK_UD_TYPE 0x3
#define BIT_UD_TYPE(x) (((x) & BIT_MASK_UD_TYPE) << BIT_SHIFT_UD_TYPE)
#define BITS_UD_TYPE (BIT_MASK_UD_TYPE << BIT_SHIFT_UD_TYPE)
#define BIT_CLEAR_UD_TYPE(x) ((x) & (~BITS_UD_TYPE))
#define BIT_GET_UD_TYPE(x) (((x) >> BIT_SHIFT_UD_TYPE) & BIT_MASK_UD_TYPE)
#define BIT_SET_UD_TYPE(x, v) (BIT_CLEAR_UD_TYPE(x) | BIT_UD_TYPE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_CTRLFLT5EN BIT(5)
#define BIT_CTRLFLT4EN BIT(4)
#define BIT_CTRLFLT3EN BIT(3)
#define BIT_CTRLFLT2EN BIT(2)
#define BIT_CTRLFLT1EN BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_SHIFT_RPT_COUNTER 0
#define BIT_MASK_RPT_COUNTER 0xffff
#define BIT_RPT_COUNTER(x) \
(((x) & BIT_MASK_RPT_COUNTER) << BIT_SHIFT_RPT_COUNTER)
#define BITS_RPT_COUNTER (BIT_MASK_RPT_COUNTER << BIT_SHIFT_RPT_COUNTER)
#define BIT_CLEAR_RPT_COUNTER(x) ((x) & (~BITS_RPT_COUNTER))
#define BIT_GET_RPT_COUNTER(x) \
(((x) >> BIT_SHIFT_RPT_COUNTER) & BIT_MASK_RPT_COUNTER)
#define BIT_SET_RPT_COUNTER(x, v) \
(BIT_CLEAR_RPT_COUNTER(x) | BIT_RPT_COUNTER(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXERR_RPT (Offset 0x0664) */
#define BIT_CTRLFLT0EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_RXBA_IGNOREA2 BIT(42)
#define BIT_EN_SAVE_ALL_TXOPADDR BIT(41)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV BIT(40)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_DIS_TXBA_AMPDUFCSERR BIT(39)
#define BIT_DIS_TXBA_RXBARINFULL BIT(38)
#define BIT_DIS_TXCFE_INFULL BIT(37)
#define BIT_DIS_TXCTS_INFULL BIT(36)
#define BIT_EN_TXACKBA_IN_TX_RDG BIT(35)
#define BIT_EN_TXACKBA_IN_TXOP BIT(34)
#define BIT_EN_TXCTS_IN_RXNAV BIT(33)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_EN_TXCTS_INTXOP BIT(32)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_BLK_EDCA_BBSLP BIT(31)
#define BIT_BLK_EDCA_BBSBY BIT(30)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_ENABLE_STOP_UPDATE_NAV_V1 BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_ACKTO_BLOCK_SCH_EN BIT(27)
#define BIT_EIFS_BLOCK_SCH_EN BIT(26)
#define BIT_PLCPCHK_RST_EIFS BIT(25)
#define BIT_CCA_RST_EIFS BIT(24)
#define BIT_DIS_UPD_MYRXPKTNAV BIT(23)
#define BIT_EARLY_TXBA BIT(22)
#define BIT_SHIFT_RESP_CHNBUSY 20
#define BIT_MASK_RESP_CHNBUSY 0x3
#define BIT_RESP_CHNBUSY(x) \
(((x) & BIT_MASK_RESP_CHNBUSY) << BIT_SHIFT_RESP_CHNBUSY)
#define BITS_RESP_CHNBUSY (BIT_MASK_RESP_CHNBUSY << BIT_SHIFT_RESP_CHNBUSY)
#define BIT_CLEAR_RESP_CHNBUSY(x) ((x) & (~BITS_RESP_CHNBUSY))
#define BIT_GET_RESP_CHNBUSY(x) \
(((x) >> BIT_SHIFT_RESP_CHNBUSY) & BIT_MASK_RESP_CHNBUSY)
#define BIT_SET_RESP_CHNBUSY(x, v) \
(BIT_CLEAR_RESP_CHNBUSY(x) | BIT_RESP_CHNBUSY(v))
#define BIT_RESP_DCTS_EN BIT(19)
#define BIT_RESP_DCFE_EN BIT(18)
#define BIT_RESP_SPLCPEN BIT(17)
#define BIT_RESP_SGIEN BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_RESP_LDPC_EN BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_MGTFLT15EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_DIS_RESP_ACKINCCA BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_MGTFLT14EN BIT(14)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_DIS_RESP_CTSINCCA BIT(13)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER 10
#define BIT_MASK_R_WMAC_SECOND_CCA_TIMER 0x7
#define BIT_R_WMAC_SECOND_CCA_TIMER(x) \
(((x) & BIT_MASK_R_WMAC_SECOND_CCA_TIMER) \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER)
#define BITS_R_WMAC_SECOND_CCA_TIMER \
(BIT_MASK_R_WMAC_SECOND_CCA_TIMER << BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER)
#define BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER(x) \
((x) & (~BITS_R_WMAC_SECOND_CCA_TIMER))
#define BIT_GET_R_WMAC_SECOND_CCA_TIMER(x) \
(((x) >> BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER) & \
BIT_MASK_R_WMAC_SECOND_CCA_TIMER)
#define BIT_SET_R_WMAC_SECOND_CCA_TIMER(x, v) \
(BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER(x) | BIT_R_WMAC_SECOND_CCA_TIMER(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_SECOND_CCA_CNT 10
#define BIT_MASK_SECOND_CCA_CNT 0x7
#define BIT_SECOND_CCA_CNT(x) \
(((x) & BIT_MASK_SECOND_CCA_CNT) << BIT_SHIFT_SECOND_CCA_CNT)
#define BITS_SECOND_CCA_CNT \
(BIT_MASK_SECOND_CCA_CNT << BIT_SHIFT_SECOND_CCA_CNT)
#define BIT_CLEAR_SECOND_CCA_CNT(x) ((x) & (~BITS_SECOND_CCA_CNT))
#define BIT_GET_SECOND_CCA_CNT(x) \
(((x) >> BIT_SHIFT_SECOND_CCA_CNT) & BIT_MASK_SECOND_CCA_CNT)
#define BIT_SET_SECOND_CCA_CNT(x, v) \
(BIT_CLEAR_SECOND_CCA_CNT(x) | BIT_SECOND_CCA_CNT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_RFMOD 7
#define BIT_MASK_RFMOD 0x3
#define BIT_RFMOD(x) (((x) & BIT_MASK_RFMOD) << BIT_SHIFT_RFMOD)
#define BITS_RFMOD (BIT_MASK_RFMOD << BIT_SHIFT_RFMOD)
#define BIT_CLEAR_RFMOD(x) ((x) & (~BITS_RFMOD))
#define BIT_GET_RFMOD(x) (((x) >> BIT_SHIFT_RFMOD) & BIT_MASK_RFMOD)
#define BIT_SET_RFMOD(x, v) (BIT_CLEAR_RFMOD(x) | BIT_RFMOD(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_MGTFLT7EN BIT(7)
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_RF_MOD 7
#define BIT_MASK_RF_MOD 0x3
#define BIT_RF_MOD(x) (((x) & BIT_MASK_RF_MOD) << BIT_SHIFT_RF_MOD)
#define BITS_RF_MOD (BIT_MASK_RF_MOD << BIT_SHIFT_RF_MOD)
#define BIT_CLEAR_RF_MOD(x) ((x) & (~BITS_RF_MOD))
#define BIT_GET_RF_MOD(x) (((x) >> BIT_SHIFT_RF_MOD) & BIT_MASK_RF_MOD)
#define BIT_SET_RF_MOD(x, v) (BIT_CLEAR_RF_MOD(x) | BIT_RF_MOD(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_MGTFLT6EN BIT(6)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_RESP_CTS_DYNBW_SEL 5
#define BIT_MASK_RESP_CTS_DYNBW_SEL 0x3
#define BIT_RESP_CTS_DYNBW_SEL(x) \
(((x) & BIT_MASK_RESP_CTS_DYNBW_SEL) << BIT_SHIFT_RESP_CTS_DYNBW_SEL)
#define BITS_RESP_CTS_DYNBW_SEL \
(BIT_MASK_RESP_CTS_DYNBW_SEL << BIT_SHIFT_RESP_CTS_DYNBW_SEL)
#define BIT_CLEAR_RESP_CTS_DYNBW_SEL(x) ((x) & (~BITS_RESP_CTS_DYNBW_SEL))
#define BIT_GET_RESP_CTS_DYNBW_SEL(x) \
(((x) >> BIT_SHIFT_RESP_CTS_DYNBW_SEL) & BIT_MASK_RESP_CTS_DYNBW_SEL)
#define BIT_SET_RESP_CTS_DYNBW_SEL(x, v) \
(BIT_CLEAR_RESP_CTS_DYNBW_SEL(x) | BIT_RESP_CTS_DYNBW_SEL(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_RESP_CTS_BW_DYNBW_SEL 5
#define BIT_MASK_RESP_CTS_BW_DYNBW_SEL 0x3
#define BIT_RESP_CTS_BW_DYNBW_SEL(x) \
(((x) & BIT_MASK_RESP_CTS_BW_DYNBW_SEL) \
<< BIT_SHIFT_RESP_CTS_BW_DYNBW_SEL)
#define BITS_RESP_CTS_BW_DYNBW_SEL \
(BIT_MASK_RESP_CTS_BW_DYNBW_SEL << BIT_SHIFT_RESP_CTS_BW_DYNBW_SEL)
#define BIT_CLEAR_RESP_CTS_BW_DYNBW_SEL(x) ((x) & (~BITS_RESP_CTS_BW_DYNBW_SEL))
#define BIT_GET_RESP_CTS_BW_DYNBW_SEL(x) \
(((x) >> BIT_SHIFT_RESP_CTS_BW_DYNBW_SEL) & \
BIT_MASK_RESP_CTS_BW_DYNBW_SEL)
#define BIT_SET_RESP_CTS_BW_DYNBW_SEL(x, v) \
(BIT_CLEAR_RESP_CTS_BW_DYNBW_SEL(x) | BIT_RESP_CTS_BW_DYNBW_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_DLY_TX_WAIT_RXANTSEL BIT(4)
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_DELAY_TX_USE_RX_ANTSEL BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_TXRESP_BY_RXANTSEL BIT(3)
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_TX_USE_RX_ANTSEL BIT(3)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_RESP_EARLY_TXACK_RWEPTKIP BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL (Offset 0x0668) */
#define BIT_SHIFT_ORIG_DCTS_CHK 0
#define BIT_MASK_ORIG_DCTS_CHK 0x3
#define BIT_ORIG_DCTS_CHK(x) \
(((x) & BIT_MASK_ORIG_DCTS_CHK) << BIT_SHIFT_ORIG_DCTS_CHK)
#define BITS_ORIG_DCTS_CHK (BIT_MASK_ORIG_DCTS_CHK << BIT_SHIFT_ORIG_DCTS_CHK)
#define BIT_CLEAR_ORIG_DCTS_CHK(x) ((x) & (~BITS_ORIG_DCTS_CHK))
#define BIT_GET_ORIG_DCTS_CHK(x) \
(((x) >> BIT_SHIFT_ORIG_DCTS_CHK) & BIT_MASK_ORIG_DCTS_CHK)
#define BIT_SET_ORIG_DCTS_CHK(x, v) \
(BIT_CLEAR_ORIG_DCTS_CHK(x) | BIT_ORIG_DCTS_CHK(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_TRXPTCL_CTL_H (Offset 0x066C) */
#define BIT_RXBA_IGNOREA2_V1 BIT(10)
#define BIT_EN_SAVE_ALL_TXOPADDR_V1 BIT(9)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV_V1 BIT(8)
#define BIT_DIS_TXBA_AMPDUFCSERR_V1 BIT(7)
#define BIT_DIS_TXBA_RXBARINFULL_V1 BIT(6)
#define BIT_DIS_TXCFE_INFULL_V1 BIT(5)
#define BIT_DIS_TXCTS_INFULL_V1 BIT(4)
#define BIT_EN_TXACKBA_IN_TX_RDG_V1 BIT(3)
#define BIT_EN_TXACKBA_IN_TXOP_V1 BIT(2)
#define BIT_EN_TXCTS_IN_RXNAV_V1 BIT(1)
#define BIT_EN_TXCTS_INTXOP_V1 BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_SECCAM_POLLING BIT(31)
#define BIT_SECCAM_CLR BIT(30)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_MFBCAM_CLR BIT(29)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_SECCAM_WE BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_SHIFT_SECCAM_ADDR_V1 0
#define BIT_MASK_SECCAM_ADDR_V1 0xff
#define BIT_SECCAM_ADDR_V1(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V1) << BIT_SHIFT_SECCAM_ADDR_V1)
#define BITS_SECCAM_ADDR_V1 \
(BIT_MASK_SECCAM_ADDR_V1 << BIT_SHIFT_SECCAM_ADDR_V1)
#define BIT_CLEAR_SECCAM_ADDR_V1(x) ((x) & (~BITS_SECCAM_ADDR_V1))
#define BIT_GET_SECCAM_ADDR_V1(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V1) & BIT_MASK_SECCAM_ADDR_V1)
#define BIT_SET_SECCAM_ADDR_V1(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V1(x) | BIT_SECCAM_ADDR_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_SHIFT_SECCAM_ADDR_V2 0
#define BIT_MASK_SECCAM_ADDR_V2 0x3ff
#define BIT_SECCAM_ADDR_V2(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V2) << BIT_SHIFT_SECCAM_ADDR_V2)
#define BITS_SECCAM_ADDR_V2 \
(BIT_MASK_SECCAM_ADDR_V2 << BIT_SHIFT_SECCAM_ADDR_V2)
#define BIT_CLEAR_SECCAM_ADDR_V2(x) ((x) & (~BITS_SECCAM_ADDR_V2))
#define BIT_GET_SECCAM_ADDR_V2(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V2) & BIT_MASK_SECCAM_ADDR_V2)
#define BIT_SET_SECCAM_ADDR_V2(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V2(x) | BIT_SECCAM_ADDR_V2(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_SHIFT_SECCAM_ADDR_V3 0
#define BIT_MASK_SECCAM_ADDR_V3 0x1ff
#define BIT_SECCAM_ADDR_V3(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V3) << BIT_SHIFT_SECCAM_ADDR_V3)
#define BITS_SECCAM_ADDR_V3 \
(BIT_MASK_SECCAM_ADDR_V3 << BIT_SHIFT_SECCAM_ADDR_V3)
#define BIT_CLEAR_SECCAM_ADDR_V3(x) ((x) & (~BITS_SECCAM_ADDR_V3))
#define BIT_GET_SECCAM_ADDR_V3(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V3) & BIT_MASK_SECCAM_ADDR_V3)
#define BIT_SET_SECCAM_ADDR_V3(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V3(x) | BIT_SECCAM_ADDR_V3(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_CAMCMD (Offset 0x0670) */
#define BIT_SHIFT_SECCAM_ADDR 0
#define BIT_MASK_SECCAM_ADDR 0xff
#define BIT_SECCAM_ADDR(x) \
(((x) & BIT_MASK_SECCAM_ADDR) << BIT_SHIFT_SECCAM_ADDR)
#define BITS_SECCAM_ADDR (BIT_MASK_SECCAM_ADDR << BIT_SHIFT_SECCAM_ADDR)
#define BIT_CLEAR_SECCAM_ADDR(x) ((x) & (~BITS_SECCAM_ADDR))
#define BIT_GET_SECCAM_ADDR(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR) & BIT_MASK_SECCAM_ADDR)
#define BIT_SET_SECCAM_ADDR(x, v) \
(BIT_CLEAR_SECCAM_ADDR(x) | BIT_SECCAM_ADDR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_CAMWRITE (Offset 0x0674) */
#define BIT_SHIFT_CAMW_DATA 0
#define BIT_MASK_CAMW_DATA 0xffffffffL
#define BIT_CAMW_DATA(x) (((x) & BIT_MASK_CAMW_DATA) << BIT_SHIFT_CAMW_DATA)
#define BITS_CAMW_DATA (BIT_MASK_CAMW_DATA << BIT_SHIFT_CAMW_DATA)
#define BIT_CLEAR_CAMW_DATA(x) ((x) & (~BITS_CAMW_DATA))
#define BIT_GET_CAMW_DATA(x) (((x) >> BIT_SHIFT_CAMW_DATA) & BIT_MASK_CAMW_DATA)
#define BIT_SET_CAMW_DATA(x, v) (BIT_CLEAR_CAMW_DATA(x) | BIT_CAMW_DATA(v))
/* 2 REG_CAMREAD (Offset 0x0678) */
#define BIT_SHIFT_CAMR_DATA 0
#define BIT_MASK_CAMR_DATA 0xffffffffL
#define BIT_CAMR_DATA(x) (((x) & BIT_MASK_CAMR_DATA) << BIT_SHIFT_CAMR_DATA)
#define BITS_CAMR_DATA (BIT_MASK_CAMR_DATA << BIT_SHIFT_CAMR_DATA)
#define BIT_CLEAR_CAMR_DATA(x) ((x) & (~BITS_CAMR_DATA))
#define BIT_GET_CAMR_DATA(x) (((x) >> BIT_SHIFT_CAMR_DATA) & BIT_MASK_CAMR_DATA)
#define BIT_SET_CAMR_DATA(x, v) (BIT_CLEAR_CAMR_DATA(x) | BIT_CAMR_DATA(v))
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SECCAM_INFO BIT(31)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SEC_KEYFOUND_V1 BIT(19)
#define BIT_SHIFT_CAMDBG_SEC_TYPE_V1 16
#define BIT_MASK_CAMDBG_SEC_TYPE_V1 0x7
#define BIT_CAMDBG_SEC_TYPE_V1(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE_V1) << BIT_SHIFT_CAMDBG_SEC_TYPE_V1)
#define BITS_CAMDBG_SEC_TYPE_V1 \
(BIT_MASK_CAMDBG_SEC_TYPE_V1 << BIT_SHIFT_CAMDBG_SEC_TYPE_V1)
#define BIT_CLEAR_CAMDBG_SEC_TYPE_V1(x) ((x) & (~BITS_CAMDBG_SEC_TYPE_V1))
#define BIT_GET_CAMDBG_SEC_TYPE_V1(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE_V1) & BIT_MASK_CAMDBG_SEC_TYPE_V1)
#define BIT_SET_CAMDBG_SEC_TYPE_V1(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE_V1(x) | BIT_CAMDBG_SEC_TYPE_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SEC_KEYFOUND BIT(15)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_EXT_SECTYPE BIT(15)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_CAMDBG_EXT_SEC_TYPE_V1 BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SHIFT_CAMDBG_SEC_TYPE 12
#define BIT_MASK_CAMDBG_SEC_TYPE 0x7
#define BIT_CAMDBG_SEC_TYPE(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE) << BIT_SHIFT_CAMDBG_SEC_TYPE)
#define BITS_CAMDBG_SEC_TYPE \
(BIT_MASK_CAMDBG_SEC_TYPE << BIT_SHIFT_CAMDBG_SEC_TYPE)
#define BIT_CLEAR_CAMDBG_SEC_TYPE(x) ((x) & (~BITS_CAMDBG_SEC_TYPE))
#define BIT_GET_CAMDBG_SEC_TYPE(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE) & BIT_MASK_CAMDBG_SEC_TYPE)
#define BIT_SET_CAMDBG_SEC_TYPE(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE(x) | BIT_CAMDBG_SEC_TYPE(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_CAMDBG_EXT_SEC_TYPE BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_CAMDBG_EXT_SECTYPE BIT(11)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V1 7
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_V1 0x7f
#define BIT_CAMDBG_MIC_KEY_IDX_V1(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_V1) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V1)
#define BITS_CAMDBG_MIC_KEY_IDX_V1 \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_V1 << BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V1)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_V1(x) ((x) & (~BITS_CAMDBG_MIC_KEY_IDX_V1))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_V1(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V1) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_V1)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_V1(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_V1(x) | BIT_CAMDBG_MIC_KEY_IDX_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V3 6
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_V3 0x3f
#define BIT_CAMDBG_MIC_KEY_IDX_V3(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_V3) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V3)
#define BITS_CAMDBG_MIC_KEY_IDX_V3 \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_V3 << BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V3)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_V3(x) ((x) & (~BITS_CAMDBG_MIC_KEY_IDX_V3))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_V3(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_V3) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_V3)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_V3(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_V3(x) | BIT_CAMDBG_MIC_KEY_IDX_V3(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX 5
#define BIT_MASK_CAMDBG_MIC_KEY_IDX 0x1f
#define BIT_CAMDBG_MIC_KEY_IDX(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX) << BIT_SHIFT_CAMDBG_MIC_KEY_IDX)
#define BITS_CAMDBG_MIC_KEY_IDX \
(BIT_MASK_CAMDBG_MIC_KEY_IDX << BIT_SHIFT_CAMDBG_MIC_KEY_IDX)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX(x) ((x) & (~BITS_CAMDBG_MIC_KEY_IDX))
#define BIT_GET_CAMDBG_MIC_KEY_IDX(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX) & BIT_MASK_CAMDBG_MIC_KEY_IDX)
#define BIT_SET_CAMDBG_MIC_KEY_IDX(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX(x) | BIT_CAMDBG_MIC_KEY_IDX(v))
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX 0x1f
#define BIT_CAMDBG_SEC_KEY_IDX(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX) << BIT_SHIFT_CAMDBG_SEC_KEY_IDX)
#define BITS_CAMDBG_SEC_KEY_IDX \
(BIT_MASK_CAMDBG_SEC_KEY_IDX << BIT_SHIFT_CAMDBG_SEC_KEY_IDX)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX(x) ((x) & (~BITS_CAMDBG_SEC_KEY_IDX))
#define BIT_GET_CAMDBG_SEC_KEY_IDX(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX) & BIT_MASK_CAMDBG_SEC_KEY_IDX)
#define BIT_SET_CAMDBG_SEC_KEY_IDX(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX(x) | BIT_CAMDBG_SEC_KEY_IDX(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V2 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_V2 0x3f
#define BIT_CAMDBG_SEC_KEY_IDX_V2(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_V2) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V2)
#define BITS_CAMDBG_SEC_KEY_IDX_V2 \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_V2 << BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V2)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_V2(x) ((x) & (~BITS_CAMDBG_SEC_KEY_IDX_V2))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_V2(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V2) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_V2)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_V2(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_V2(x) | BIT_CAMDBG_SEC_KEY_IDX_V2(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_CAMDBG (Offset 0x067C) */
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V1 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_V1 0x7f
#define BIT_CAMDBG_SEC_KEY_IDX_V1(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_V1) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V1)
#define BITS_CAMDBG_SEC_KEY_IDX_V1 \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_V1 << BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V1)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_V1(x) ((x) & (~BITS_CAMDBG_SEC_KEY_IDX_V1))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_V1(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_V1) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_V1)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_V1(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_V1(x) | BIT_CAMDBG_SEC_KEY_IDX_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SECCFG (Offset 0x0680) */
#define BIT_RXDEC_BM_MGNT_V1 BIT(19)
#define BIT_TXENC_BM_MGNT_V1 BIT(18)
#define BIT_RXDEC_UNI_MGNT_V1 BIT(17)
#define BIT_TXENC_UNI_MGNT_V1 BIT(16)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SECCFG (Offset 0x0680) */
#define BIT_DIS_GCLK_WAPI BIT(15)
#define BIT_DIS_GCLK_AES BIT(14)
#define BIT_DIS_GCLK_TKIP BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SECCFG (Offset 0x0680) */
#define BIT_AES_SEL_QC_1 BIT(12)
#define BIT_AES_SEL_QC_0 BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_SECCFG (Offset 0x0680) */
#define BIT_WMAC_CKECK_BMC BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SECCFG (Offset 0x0680) */
#define BIT_CHK_BMC BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_SECCFG (Offset 0x0680) */
#define BIT_CHK_KEYID BIT(8)
#define BIT_RXBCUSEDK BIT(7)
#define BIT_TXBCUSEDK BIT(6)
#define BIT_NOSKMC BIT(5)
#define BIT_SKBYA2 BIT(4)
#define BIT_RXDEC BIT(3)
#define BIT_TXENC BIT(2)
#define BIT_RXUHUSEDK BIT(1)
#define BIT_TXUHUSEDK BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXFILTER_CATEGORY_1 (Offset 0x0682) */
#define BIT_SHIFT_RXFILTER_CATEGORY_1 0
#define BIT_MASK_RXFILTER_CATEGORY_1 0xff
#define BIT_RXFILTER_CATEGORY_1(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_1) << BIT_SHIFT_RXFILTER_CATEGORY_1)
#define BITS_RXFILTER_CATEGORY_1 \
(BIT_MASK_RXFILTER_CATEGORY_1 << BIT_SHIFT_RXFILTER_CATEGORY_1)
#define BIT_CLEAR_RXFILTER_CATEGORY_1(x) ((x) & (~BITS_RXFILTER_CATEGORY_1))
#define BIT_GET_RXFILTER_CATEGORY_1(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_1) & BIT_MASK_RXFILTER_CATEGORY_1)
#define BIT_SET_RXFILTER_CATEGORY_1(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_1(x) | BIT_RXFILTER_CATEGORY_1(v))
/* 2 REG_RXFILTER_ACTION_1 (Offset 0x0683) */
#define BIT_SHIFT_RXFILTER_ACTION_1 0
#define BIT_MASK_RXFILTER_ACTION_1 0xff
#define BIT_RXFILTER_ACTION_1(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_1) << BIT_SHIFT_RXFILTER_ACTION_1)
#define BITS_RXFILTER_ACTION_1 \
(BIT_MASK_RXFILTER_ACTION_1 << BIT_SHIFT_RXFILTER_ACTION_1)
#define BIT_CLEAR_RXFILTER_ACTION_1(x) ((x) & (~BITS_RXFILTER_ACTION_1))
#define BIT_GET_RXFILTER_ACTION_1(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_1) & BIT_MASK_RXFILTER_ACTION_1)
#define BIT_SET_RXFILTER_ACTION_1(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_1(x) | BIT_RXFILTER_ACTION_1(v))
/* 2 REG_RXFILTER_CATEGORY_2 (Offset 0x0684) */
#define BIT_SHIFT_RXFILTER_CATEGORY_2 0
#define BIT_MASK_RXFILTER_CATEGORY_2 0xff
#define BIT_RXFILTER_CATEGORY_2(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_2) << BIT_SHIFT_RXFILTER_CATEGORY_2)
#define BITS_RXFILTER_CATEGORY_2 \
(BIT_MASK_RXFILTER_CATEGORY_2 << BIT_SHIFT_RXFILTER_CATEGORY_2)
#define BIT_CLEAR_RXFILTER_CATEGORY_2(x) ((x) & (~BITS_RXFILTER_CATEGORY_2))
#define BIT_GET_RXFILTER_CATEGORY_2(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_2) & BIT_MASK_RXFILTER_CATEGORY_2)
#define BIT_SET_RXFILTER_CATEGORY_2(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_2(x) | BIT_RXFILTER_CATEGORY_2(v))
/* 2 REG_RXFILTER_ACTION_2 (Offset 0x0685) */
#define BIT_SHIFT_RXFILTER_ACTION_2 0
#define BIT_MASK_RXFILTER_ACTION_2 0xff
#define BIT_RXFILTER_ACTION_2(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_2) << BIT_SHIFT_RXFILTER_ACTION_2)
#define BITS_RXFILTER_ACTION_2 \
(BIT_MASK_RXFILTER_ACTION_2 << BIT_SHIFT_RXFILTER_ACTION_2)
#define BIT_CLEAR_RXFILTER_ACTION_2(x) ((x) & (~BITS_RXFILTER_ACTION_2))
#define BIT_GET_RXFILTER_ACTION_2(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_2) & BIT_MASK_RXFILTER_ACTION_2)
#define BIT_SET_RXFILTER_ACTION_2(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_2(x) | BIT_RXFILTER_ACTION_2(v))
/* 2 REG_RXFILTER_CATEGORY_3 (Offset 0x0686) */
#define BIT_SHIFT_RXFILTER_CATEGORY_3 0
#define BIT_MASK_RXFILTER_CATEGORY_3 0xff
#define BIT_RXFILTER_CATEGORY_3(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_3) << BIT_SHIFT_RXFILTER_CATEGORY_3)
#define BITS_RXFILTER_CATEGORY_3 \
(BIT_MASK_RXFILTER_CATEGORY_3 << BIT_SHIFT_RXFILTER_CATEGORY_3)
#define BIT_CLEAR_RXFILTER_CATEGORY_3(x) ((x) & (~BITS_RXFILTER_CATEGORY_3))
#define BIT_GET_RXFILTER_CATEGORY_3(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_3) & BIT_MASK_RXFILTER_CATEGORY_3)
#define BIT_SET_RXFILTER_CATEGORY_3(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_3(x) | BIT_RXFILTER_CATEGORY_3(v))
/* 2 REG_RXFILTER_ACTION_3 (Offset 0x0687) */
#define BIT_SHIFT_RXFILTER_ACTION_3 0
#define BIT_MASK_RXFILTER_ACTION_3 0xff
#define BIT_RXFILTER_ACTION_3(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_3) << BIT_SHIFT_RXFILTER_ACTION_3)
#define BITS_RXFILTER_ACTION_3 \
(BIT_MASK_RXFILTER_ACTION_3 << BIT_SHIFT_RXFILTER_ACTION_3)
#define BIT_CLEAR_RXFILTER_ACTION_3(x) ((x) & (~BITS_RXFILTER_ACTION_3))
#define BIT_GET_RXFILTER_ACTION_3(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_3) & BIT_MASK_RXFILTER_ACTION_3)
#define BIT_SET_RXFILTER_ACTION_3(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_3(x) | BIT_RXFILTER_ACTION_3(v))
/* 2 REG_RXFLTMAP3 (Offset 0x0688) */
#define BIT_MGTFLT15EN_FW BIT(15)
#define BIT_MGTFLT14EN_FW BIT(14)
#define BIT_MGTFLT13EN_FW BIT(13)
#define BIT_MGTFLT12EN_FW BIT(12)
#define BIT_MGTFLT11EN_FW BIT(11)
#define BIT_MGTFLT10EN_FW BIT(10)
#define BIT_MGTFLT9EN_FW BIT(9)
#define BIT_MGTFLT8EN_FW BIT(8)
#define BIT_MGTFLT7EN_FW BIT(7)
#define BIT_MGTFLT6EN_FW BIT(6)
#define BIT_MGTFLT5EN_FW BIT(5)
#define BIT_MGTFLT4EN_FW BIT(4)
#define BIT_MGTFLT3EN_FW BIT(3)
#define BIT_MGTFLT2EN_FW BIT(2)
#define BIT_MGTFLT1EN_FW BIT(1)
#define BIT_MGTFLT0EN_FW BIT(0)
/* 2 REG_RXFLTMAP4 (Offset 0x068A) */
#define BIT_CTRLFLT15EN_FW BIT(15)
#define BIT_CTRLFLT14EN_FW BIT(14)
#define BIT_CTRLFLT13EN_FW BIT(13)
#define BIT_CTRLFLT12EN_FW BIT(12)
#define BIT_CTRLFLT11EN_FW BIT(11)
#define BIT_CTRLFLT10EN_FW BIT(10)
#define BIT_CTRLFLT9EN_FW BIT(9)
#define BIT_CTRLFLT8EN_FW BIT(8)
#define BIT_CTRLFLT7EN_FW BIT(7)
#define BIT_CTRLFLT6EN_FW BIT(6)
#define BIT_CTRLFLT5EN_FW BIT(5)
#define BIT_CTRLFLT4EN_FW BIT(4)
#define BIT_CTRLFLT3EN_FW BIT(3)
#define BIT_CTRLFLT2EN_FW BIT(2)
#define BIT_CTRLFLT1EN_FW BIT(1)
#define BIT_CTRLFLT0EN_FW BIT(0)
/* 2 REG_RXFLTMAP5 (Offset 0x068C) */
#define BIT_DATAFLT15EN_FW BIT(15)
#define BIT_DATAFLT14EN_FW BIT(14)
#define BIT_DATAFLT13EN_FW BIT(13)
#define BIT_DATAFLT12EN_FW BIT(12)
#define BIT_DATAFLT11EN_FW BIT(11)
#define BIT_DATAFLT10EN_FW BIT(10)
#define BIT_DATAFLT9EN_FW BIT(9)
#define BIT_DATAFLT8EN_FW BIT(8)
#define BIT_DATAFLT7EN_FW BIT(7)
#define BIT_DATAFLT6EN_FW BIT(6)
#define BIT_DATAFLT5EN_FW BIT(5)
#define BIT_DATAFLT4EN_FW BIT(4)
#define BIT_DATAFLT3EN_FW BIT(3)
#define BIT_DATAFLT2EN_FW BIT(2)
#define BIT_DATAFLT1EN_FW BIT(1)
#define BIT_DATAFLT0EN_FW BIT(0)
/* 2 REG_RXFLTMAP6 (Offset 0x068E) */
#define BIT_ACTIONFLT15EN_FW BIT(15)
#define BIT_ACTIONFLT14EN_FW BIT(14)
#define BIT_ACTIONFLT13EN_FW BIT(13)
#define BIT_ACTIONFLT12EN_FW BIT(12)
#define BIT_ACTIONFLT11EN_FW BIT(11)
#define BIT_ACTIONFLT10EN_FW BIT(10)
#define BIT_ACTIONFLT9EN_FW BIT(9)
#define BIT_ACTIONFLT8EN_FW BIT(8)
#define BIT_ACTIONFLT7EN_FW BIT(7)
#define BIT_ACTIONFLT6EN_FW BIT(6)
#define BIT_ACTIONFLT5EN_FW BIT(5)
#define BIT_ACTIONFLT4EN_FW BIT(4)
#define BIT_ACTIONFLT3EN_FW BIT(3)
#define BIT_ACTIONFLT2EN_FW BIT(2)
#define BIT_ACTIONFLT1EN_FW BIT(1)
#define BIT_ACTIONFLT0EN_FW BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_SHIFT_PSF_BSSIDSEL_B2B1 6
#define BIT_MASK_PSF_BSSIDSEL_B2B1 0x3
#define BIT_PSF_BSSIDSEL_B2B1(x) \
(((x) & BIT_MASK_PSF_BSSIDSEL_B2B1) << BIT_SHIFT_PSF_BSSIDSEL_B2B1)
#define BITS_PSF_BSSIDSEL_B2B1 \
(BIT_MASK_PSF_BSSIDSEL_B2B1 << BIT_SHIFT_PSF_BSSIDSEL_B2B1)
#define BIT_CLEAR_PSF_BSSIDSEL_B2B1(x) ((x) & (~BITS_PSF_BSSIDSEL_B2B1))
#define BIT_GET_PSF_BSSIDSEL_B2B1(x) \
(((x) >> BIT_SHIFT_PSF_BSSIDSEL_B2B1) & BIT_MASK_PSF_BSSIDSEL_B2B1)
#define BIT_SET_PSF_BSSIDSEL_B2B1(x, v) \
(BIT_CLEAR_PSF_BSSIDSEL_B2B1(x) | BIT_PSF_BSSIDSEL_B2B1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_WOWHCI BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_PSF_BSSIDSEL BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_PSF_BSSIDSEL_B0 BIT(4)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_UWF BIT(3)
#define BIT_MAGIC BIT(2)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_WOWEN BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_WFMSK BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WOW_CTRL (Offset 0x0690) */
#define BIT_FORCE_WAKEUP BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_NAN_RX_TSF_FILTER (Offset 0x0691) */
#define BIT_CHK_TSF_TA BIT(2)
#define BIT_CHK_TSF_CBSSID BIT(1)
#define BIT_CHK_TSF_EN BIT(0)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_WMAC_RESP_NONSTA1_DIS BIT(7)
#define BIT_SHIFT_PORTSEL__PS_RX_INFO 5
#define BIT_MASK_PORTSEL__PS_RX_INFO 0x7
#define BIT_PORTSEL__PS_RX_INFO(x) \
(((x) & BIT_MASK_PORTSEL__PS_RX_INFO) << BIT_SHIFT_PORTSEL__PS_RX_INFO)
#define BITS_PORTSEL__PS_RX_INFO \
(BIT_MASK_PORTSEL__PS_RX_INFO << BIT_SHIFT_PORTSEL__PS_RX_INFO)
#define BIT_CLEAR_PORTSEL__PS_RX_INFO(x) ((x) & (~BITS_PORTSEL__PS_RX_INFO))
#define BIT_GET_PORTSEL__PS_RX_INFO(x) \
(((x) >> BIT_SHIFT_PORTSEL__PS_RX_INFO) & BIT_MASK_PORTSEL__PS_RX_INFO)
#define BIT_SET_PORTSEL__PS_RX_INFO(x, v) \
(BIT_CLEAR_PORTSEL__PS_RX_INFO(x) | BIT_PORTSEL__PS_RX_INFO(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_RXCTRLIN0 BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_SHIFT_WMAC_TXMU_ACKPOLICY 4
#define BIT_MASK_WMAC_TXMU_ACKPOLICY 0x3
#define BIT_WMAC_TXMU_ACKPOLICY(x) \
(((x) & BIT_MASK_WMAC_TXMU_ACKPOLICY) << BIT_SHIFT_WMAC_TXMU_ACKPOLICY)
#define BITS_WMAC_TXMU_ACKPOLICY \
(BIT_MASK_WMAC_TXMU_ACKPOLICY << BIT_SHIFT_WMAC_TXMU_ACKPOLICY)
#define BIT_CLEAR_WMAC_TXMU_ACKPOLICY(x) ((x) & (~BITS_WMAC_TXMU_ACKPOLICY))
#define BIT_GET_WMAC_TXMU_ACKPOLICY(x) \
(((x) >> BIT_SHIFT_WMAC_TXMU_ACKPOLICY) & BIT_MASK_WMAC_TXMU_ACKPOLICY)
#define BIT_SET_WMAC_TXMU_ACKPOLICY(x, v) \
(BIT_CLEAR_WMAC_TXMU_ACKPOLICY(x) | BIT_WMAC_TXMU_ACKPOLICY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_RXMGTIN0 BIT(3)
#define BIT_RXDATAIN2 BIT(2)
#define BIT_RXDATAIN1 BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL 1
#define BIT_MASK_WMAC_MU_BFEE_PORT_SEL 0x7
#define BIT_WMAC_MU_BFEE_PORT_SEL(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE_PORT_SEL) \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL)
#define BITS_WMAC_MU_BFEE_PORT_SEL \
(BIT_MASK_WMAC_MU_BFEE_PORT_SEL << BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL)
#define BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL(x) ((x) & (~BITS_WMAC_MU_BFEE_PORT_SEL))
#define BIT_GET_WMAC_MU_BFEE_PORT_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL) & \
BIT_MASK_WMAC_MU_BFEE_PORT_SEL)
#define BIT_SET_WMAC_MU_BFEE_PORT_SEL(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL(x) | BIT_WMAC_MU_BFEE_PORT_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_RXDATAIN0 BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PS_RX_INFO (Offset 0x0692) */
#define BIT_WMAC_MU_BFEE_DIS BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_WMMPS_UAPSD_TID (Offset 0x0693) */
#define BIT_SHIFT_DTIM_CNT 24
#define BIT_MASK_DTIM_CNT 0xff
#define BIT_DTIM_CNT(x) (((x) & BIT_MASK_DTIM_CNT) << BIT_SHIFT_DTIM_CNT)
#define BITS_DTIM_CNT (BIT_MASK_DTIM_CNT << BIT_SHIFT_DTIM_CNT)
#define BIT_CLEAR_DTIM_CNT(x) ((x) & (~BITS_DTIM_CNT))
#define BIT_GET_DTIM_CNT(x) (((x) >> BIT_SHIFT_DTIM_CNT) & BIT_MASK_DTIM_CNT)
#define BIT_SET_DTIM_CNT(x, v) (BIT_CLEAR_DTIM_CNT(x) | BIT_DTIM_CNT(v))
#define BIT_CTRLFLT15EN BIT(15)
#define BIT_DATAFLT15EN BIT(15)
#define BIT_CTRLFLT14EN BIT(14)
#define BIT_DATAFLT14EN BIT(14)
#define BIT_MGTFLT13EN BIT(13)
#define BIT_CTRLFLT13EN BIT(13)
#define BIT_DATAFLT13EN BIT(13)
#define BIT_MGTFLT12EN BIT(12)
#define BIT_CTRLFLT12EN BIT(12)
#define BIT_DATAFLT12EN BIT(12)
#define BIT_MGTFLT11EN BIT(11)
#define BIT_CTRLFLT11EN BIT(11)
#define BIT_DATAFLT11EN BIT(11)
#define BIT_MGTFLT10EN BIT(10)
#define BIT_CTRLFLT10EN BIT(10)
#define BIT_DATAFLT10EN BIT(10)
#define BIT_MGTFLT9EN BIT(9)
#define BIT_CTRLFLT9EN BIT(9)
#define BIT_DATAFLT9EN BIT(9)
#define BIT_MGTFLT8EN BIT(8)
#define BIT_CTRLFLT8EN BIT(8)
#define BIT_DATAFLT8EN BIT(8)
#define BIT_WMMPS_UAPSD_TID7 BIT(7)
#define BIT_CTRLFLT7EN BIT(7)
#define BIT_DATAFLT7EN BIT(7)
#define BIT_WMMPS_UAPSD_TID6 BIT(6)
#define BIT_CTRLFLT6EN BIT(6)
#define BIT_DATAFLT6EN BIT(6)
#define BIT_WMMPS_UAPSD_TID5 BIT(5)
#define BIT_MGTFLT5EN BIT(5)
#define BIT_DATAFLT5EN BIT(5)
#define BIT_WMMPS_UAPSD_TID4 BIT(4)
#define BIT_MGTFLT4EN BIT(4)
#define BIT_DATAFLT4EN BIT(4)
#define BIT_WMMPS_UAPSD_TID3 BIT(3)
#define BIT_MGTFLT3EN BIT(3)
#define BIT_DATAFLT3EN BIT(3)
#define BIT_WMMPS_UAPSD_TID2 BIT(2)
#define BIT_MGTFLT2EN BIT(2)
#define BIT_DATAFLT2EN BIT(2)
#define BIT_WMMPS_UAPSD_TID1 BIT(1)
#define BIT_MGTFLT1EN BIT(1)
#define BIT_DATAFLT1EN BIT(1)
#define BIT_WMMPS_UAPSD_TID0 BIT(0)
#define BIT_MGTFLT0EN BIT(0)
#define BIT_DATAFLT0EN BIT(0)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_LPNAV_CTRL (Offset 0x0694) */
#define BIT_LPNAV_EN BIT(31)
#define BIT_SHIFT_LPNAV_EARLY 16
#define BIT_MASK_LPNAV_EARLY 0x7fff
#define BIT_LPNAV_EARLY(x) \
(((x) & BIT_MASK_LPNAV_EARLY) << BIT_SHIFT_LPNAV_EARLY)
#define BITS_LPNAV_EARLY (BIT_MASK_LPNAV_EARLY << BIT_SHIFT_LPNAV_EARLY)
#define BIT_CLEAR_LPNAV_EARLY(x) ((x) & (~BITS_LPNAV_EARLY))
#define BIT_GET_LPNAV_EARLY(x) \
(((x) >> BIT_SHIFT_LPNAV_EARLY) & BIT_MASK_LPNAV_EARLY)
#define BIT_SET_LPNAV_EARLY(x, v) \
(BIT_CLEAR_LPNAV_EARLY(x) | BIT_LPNAV_EARLY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_LPNAV_CTRL (Offset 0x0694) */
#define BIT_SHIFT_LPNAV_TH 0
#define BIT_MASK_LPNAV_TH 0xffff
#define BIT_LPNAV_TH(x) (((x) & BIT_MASK_LPNAV_TH) << BIT_SHIFT_LPNAV_TH)
#define BITS_LPNAV_TH (BIT_MASK_LPNAV_TH << BIT_SHIFT_LPNAV_TH)
#define BIT_CLEAR_LPNAV_TH(x) ((x) & (~BITS_LPNAV_TH))
#define BIT_GET_LPNAV_TH(x) (((x) >> BIT_SHIFT_LPNAV_TH) & BIT_MASK_LPNAV_TH)
#define BIT_SET_LPNAV_TH(x, v) (BIT_CLEAR_LPNAV_TH(x) | BIT_LPNAV_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_LPNAV_CTRL (Offset 0x0694) */
#define BIT_SHIFT_LPNAV_THR 0
#define BIT_MASK_LPNAV_THR 0xffff
#define BIT_LPNAV_THR(x) (((x) & BIT_MASK_LPNAV_THR) << BIT_SHIFT_LPNAV_THR)
#define BITS_LPNAV_THR (BIT_MASK_LPNAV_THR << BIT_SHIFT_LPNAV_THR)
#define BIT_CLEAR_LPNAV_THR(x) ((x) & (~BITS_LPNAV_THR))
#define BIT_GET_LPNAV_THR(x) (((x) >> BIT_SHIFT_LPNAV_THR) & BIT_MASK_LPNAV_THR)
#define BIT_SET_LPNAV_THR(x, v) (BIT_CLEAR_LPNAV_THR(x) | BIT_LPNAV_THR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WKFMCAM_CMD (Offset 0x0698) */
#define BIT_WKFCAM_POLLING_V1 BIT(31)
#define BIT_WKFCAM_CLR_V1 BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WKFMCAM_CMD (Offset 0x0698) */
#define BIT_WKFCAM_WE BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WKFMCAM_CMD (Offset 0x0698) */
#define BIT_SHIFT_WKFCAM_ADDR_V2 8
#define BIT_MASK_WKFCAM_ADDR_V2 0xff
#define BIT_WKFCAM_ADDR_V2(x) \
(((x) & BIT_MASK_WKFCAM_ADDR_V2) << BIT_SHIFT_WKFCAM_ADDR_V2)
#define BITS_WKFCAM_ADDR_V2 \
(BIT_MASK_WKFCAM_ADDR_V2 << BIT_SHIFT_WKFCAM_ADDR_V2)
#define BIT_CLEAR_WKFCAM_ADDR_V2(x) ((x) & (~BITS_WKFCAM_ADDR_V2))
#define BIT_GET_WKFCAM_ADDR_V2(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR_V2) & BIT_MASK_WKFCAM_ADDR_V2)
#define BIT_SET_WKFCAM_ADDR_V2(x, v) \
(BIT_CLEAR_WKFCAM_ADDR_V2(x) | BIT_WKFCAM_ADDR_V2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WKFMCAM_CMD (Offset 0x0698) */
#define BIT_SHIFT_WKFCAM_NUM_V1 0
#define BIT_MASK_WKFCAM_NUM_V1 0xff
#define BIT_WKFCAM_NUM_V1(x) \
(((x) & BIT_MASK_WKFCAM_NUM_V1) << BIT_SHIFT_WKFCAM_NUM_V1)
#define BITS_WKFCAM_NUM_V1 (BIT_MASK_WKFCAM_NUM_V1 << BIT_SHIFT_WKFCAM_NUM_V1)
#define BIT_CLEAR_WKFCAM_NUM_V1(x) ((x) & (~BITS_WKFCAM_NUM_V1))
#define BIT_GET_WKFCAM_NUM_V1(x) \
(((x) >> BIT_SHIFT_WKFCAM_NUM_V1) & BIT_MASK_WKFCAM_NUM_V1)
#define BIT_SET_WKFCAM_NUM_V1(x, v) \
(BIT_CLEAR_WKFCAM_NUM_V1(x) | BIT_WKFCAM_NUM_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WKFMCAM_CMD (Offset 0x0698) */
#define BIT_SHIFT_WKFCAM_CAM_NUM_V1 0
#define BIT_MASK_WKFCAM_CAM_NUM_V1 0xff
#define BIT_WKFCAM_CAM_NUM_V1(x) \
(((x) & BIT_MASK_WKFCAM_CAM_NUM_V1) << BIT_SHIFT_WKFCAM_CAM_NUM_V1)
#define BITS_WKFCAM_CAM_NUM_V1 \
(BIT_MASK_WKFCAM_CAM_NUM_V1 << BIT_SHIFT_WKFCAM_CAM_NUM_V1)
#define BIT_CLEAR_WKFCAM_CAM_NUM_V1(x) ((x) & (~BITS_WKFCAM_CAM_NUM_V1))
#define BIT_GET_WKFCAM_CAM_NUM_V1(x) \
(((x) >> BIT_SHIFT_WKFCAM_CAM_NUM_V1) & BIT_MASK_WKFCAM_CAM_NUM_V1)
#define BIT_SET_WKFCAM_CAM_NUM_V1(x, v) \
(BIT_CLEAR_WKFCAM_CAM_NUM_V1(x) | BIT_WKFCAM_CAM_NUM_V1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_WKFMCAM_CMD (Offset 0x0698) */
#define BIT_SHIFT_WKFCAM_ADDR 0
#define BIT_MASK_WKFCAM_ADDR 0x7f
#define BIT_WKFCAM_ADDR(x) \
(((x) & BIT_MASK_WKFCAM_ADDR) << BIT_SHIFT_WKFCAM_ADDR)
#define BITS_WKFCAM_ADDR (BIT_MASK_WKFCAM_ADDR << BIT_SHIFT_WKFCAM_ADDR)
#define BIT_CLEAR_WKFCAM_ADDR(x) ((x) & (~BITS_WKFCAM_ADDR))
#define BIT_GET_WKFCAM_ADDR(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR) & BIT_MASK_WKFCAM_ADDR)
#define BIT_SET_WKFCAM_ADDR(x, v) \
(BIT_CLEAR_WKFCAM_ADDR(x) | BIT_WKFCAM_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WKFMCAM_RWD (Offset 0x069C) */
#define BIT_SHIFT_WKFMCAM_RWD 0
#define BIT_MASK_WKFMCAM_RWD 0xffffffffL
#define BIT_WKFMCAM_RWD(x) \
(((x) & BIT_MASK_WKFMCAM_RWD) << BIT_SHIFT_WKFMCAM_RWD)
#define BITS_WKFMCAM_RWD (BIT_MASK_WKFMCAM_RWD << BIT_SHIFT_WKFMCAM_RWD)
#define BIT_CLEAR_WKFMCAM_RWD(x) ((x) & (~BITS_WKFMCAM_RWD))
#define BIT_GET_WKFMCAM_RWD(x) \
(((x) >> BIT_SHIFT_WKFMCAM_RWD) & BIT_MASK_WKFMCAM_RWD)
#define BIT_SET_WKFMCAM_RWD(x, v) \
(BIT_CLEAR_WKFMCAM_RWD(x) | BIT_WKFMCAM_RWD(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BCN_PSR_RPT (Offset 0x06A8) */
#define BIT_SHIFT_DTIM_PERIOD 16
#define BIT_MASK_DTIM_PERIOD 0xff
#define BIT_DTIM_PERIOD(x) \
(((x) & BIT_MASK_DTIM_PERIOD) << BIT_SHIFT_DTIM_PERIOD)
#define BITS_DTIM_PERIOD (BIT_MASK_DTIM_PERIOD << BIT_SHIFT_DTIM_PERIOD)
#define BIT_CLEAR_DTIM_PERIOD(x) ((x) & (~BITS_DTIM_PERIOD))
#define BIT_GET_DTIM_PERIOD(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD) & BIT_MASK_DTIM_PERIOD)
#define BIT_SET_DTIM_PERIOD(x, v) \
(BIT_CLEAR_DTIM_PERIOD(x) | BIT_DTIM_PERIOD(v))
#define BIT_DTIM BIT(15)
#define BIT_TIM BIT(14)
#define BIT_SHIFT_PS_AID_0 0
#define BIT_MASK_PS_AID_0 0x7ff
#define BIT_PS_AID_0(x) (((x) & BIT_MASK_PS_AID_0) << BIT_SHIFT_PS_AID_0)
#define BITS_PS_AID_0 (BIT_MASK_PS_AID_0 << BIT_SHIFT_PS_AID_0)
#define BIT_CLEAR_PS_AID_0(x) ((x) & (~BITS_PS_AID_0))
#define BIT_GET_PS_AID_0(x) (((x) >> BIT_SHIFT_PS_AID_0) & BIT_MASK_PS_AID_0)
#define BIT_SET_PS_AID_0(x, v) (BIT_CLEAR_PS_AID_0(x) | BIT_PS_AID_0(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_FLC_RPC (Offset 0x06AC) */
#define BIT_SHIFT_FLC_RPC 0
#define BIT_MASK_FLC_RPC 0xff
#define BIT_FLC_RPC(x) (((x) & BIT_MASK_FLC_RPC) << BIT_SHIFT_FLC_RPC)
#define BITS_FLC_RPC (BIT_MASK_FLC_RPC << BIT_SHIFT_FLC_RPC)
#define BIT_CLEAR_FLC_RPC(x) ((x) & (~BITS_FLC_RPC))
#define BIT_GET_FLC_RPC(x) (((x) >> BIT_SHIFT_FLC_RPC) & BIT_MASK_FLC_RPC)
#define BIT_SET_FLC_RPC(x, v) (BIT_CLEAR_FLC_RPC(x) | BIT_FLC_RPC(v))
/* 2 REG_FLC_RPCT (Offset 0x06AD) */
#define BIT_SHIFT_FLC_RPCT 0
#define BIT_MASK_FLC_RPCT 0xff
#define BIT_FLC_RPCT(x) (((x) & BIT_MASK_FLC_RPCT) << BIT_SHIFT_FLC_RPCT)
#define BITS_FLC_RPCT (BIT_MASK_FLC_RPCT << BIT_SHIFT_FLC_RPCT)
#define BIT_CLEAR_FLC_RPCT(x) ((x) & (~BITS_FLC_RPCT))
#define BIT_GET_FLC_RPCT(x) (((x) >> BIT_SHIFT_FLC_RPCT) & BIT_MASK_FLC_RPCT)
#define BIT_SET_FLC_RPCT(x, v) (BIT_CLEAR_FLC_RPCT(x) | BIT_FLC_RPCT(v))
/* 2 REG_FLC_PTS (Offset 0x06AE) */
#define BIT_CMF BIT(2)
#define BIT_CCF BIT(1)
#define BIT_CDF BIT(0)
/* 2 REG_FLC_TRPC (Offset 0x06AF) */
#define BIT_FLC_RPCT_V1 BIT(7)
#define BIT_MODE BIT(6)
#define BIT_SHIFT_TRPCD 0
#define BIT_MASK_TRPCD 0x3f
#define BIT_TRPCD(x) (((x) & BIT_MASK_TRPCD) << BIT_SHIFT_TRPCD)
#define BITS_TRPCD (BIT_MASK_TRPCD << BIT_SHIFT_TRPCD)
#define BIT_CLEAR_TRPCD(x) ((x) & (~BITS_TRPCD))
#define BIT_GET_TRPCD(x) (((x) >> BIT_SHIFT_TRPCD) & BIT_MASK_TRPCD)
#define BIT_SET_TRPCD(x, v) (BIT_CLEAR_TRPCD(x) | BIT_TRPCD(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXPKTMON_CTRL (Offset 0x06B0) */
#define BIT_SHIFT_RXBKQPKT_SEQ 20
#define BIT_MASK_RXBKQPKT_SEQ 0xf
#define BIT_RXBKQPKT_SEQ(x) \
(((x) & BIT_MASK_RXBKQPKT_SEQ) << BIT_SHIFT_RXBKQPKT_SEQ)
#define BITS_RXBKQPKT_SEQ (BIT_MASK_RXBKQPKT_SEQ << BIT_SHIFT_RXBKQPKT_SEQ)
#define BIT_CLEAR_RXBKQPKT_SEQ(x) ((x) & (~BITS_RXBKQPKT_SEQ))
#define BIT_GET_RXBKQPKT_SEQ(x) \
(((x) >> BIT_SHIFT_RXBKQPKT_SEQ) & BIT_MASK_RXBKQPKT_SEQ)
#define BIT_SET_RXBKQPKT_SEQ(x, v) \
(BIT_CLEAR_RXBKQPKT_SEQ(x) | BIT_RXBKQPKT_SEQ(v))
#define BIT_SHIFT_RXBEQPKT_SEQ 16
#define BIT_MASK_RXBEQPKT_SEQ 0xf
#define BIT_RXBEQPKT_SEQ(x) \
(((x) & BIT_MASK_RXBEQPKT_SEQ) << BIT_SHIFT_RXBEQPKT_SEQ)
#define BITS_RXBEQPKT_SEQ (BIT_MASK_RXBEQPKT_SEQ << BIT_SHIFT_RXBEQPKT_SEQ)
#define BIT_CLEAR_RXBEQPKT_SEQ(x) ((x) & (~BITS_RXBEQPKT_SEQ))
#define BIT_GET_RXBEQPKT_SEQ(x) \
(((x) >> BIT_SHIFT_RXBEQPKT_SEQ) & BIT_MASK_RXBEQPKT_SEQ)
#define BIT_SET_RXBEQPKT_SEQ(x, v) \
(BIT_CLEAR_RXBEQPKT_SEQ(x) | BIT_RXBEQPKT_SEQ(v))
#define BIT_SHIFT_RXVIQPKT_SEQ 12
#define BIT_MASK_RXVIQPKT_SEQ 0xf
#define BIT_RXVIQPKT_SEQ(x) \
(((x) & BIT_MASK_RXVIQPKT_SEQ) << BIT_SHIFT_RXVIQPKT_SEQ)
#define BITS_RXVIQPKT_SEQ (BIT_MASK_RXVIQPKT_SEQ << BIT_SHIFT_RXVIQPKT_SEQ)
#define BIT_CLEAR_RXVIQPKT_SEQ(x) ((x) & (~BITS_RXVIQPKT_SEQ))
#define BIT_GET_RXVIQPKT_SEQ(x) \
(((x) >> BIT_SHIFT_RXVIQPKT_SEQ) & BIT_MASK_RXVIQPKT_SEQ)
#define BIT_SET_RXVIQPKT_SEQ(x, v) \
(BIT_CLEAR_RXVIQPKT_SEQ(x) | BIT_RXVIQPKT_SEQ(v))
#define BIT_SHIFT_RXVOQPKT_SEQ 8
#define BIT_MASK_RXVOQPKT_SEQ 0xf
#define BIT_RXVOQPKT_SEQ(x) \
(((x) & BIT_MASK_RXVOQPKT_SEQ) << BIT_SHIFT_RXVOQPKT_SEQ)
#define BITS_RXVOQPKT_SEQ (BIT_MASK_RXVOQPKT_SEQ << BIT_SHIFT_RXVOQPKT_SEQ)
#define BIT_CLEAR_RXVOQPKT_SEQ(x) ((x) & (~BITS_RXVOQPKT_SEQ))
#define BIT_GET_RXVOQPKT_SEQ(x) \
(((x) >> BIT_SHIFT_RXVOQPKT_SEQ) & BIT_MASK_RXVOQPKT_SEQ)
#define BIT_SET_RXVOQPKT_SEQ(x, v) \
(BIT_CLEAR_RXVOQPKT_SEQ(x) | BIT_RXVOQPKT_SEQ(v))
#define BIT_RXBKQPKT_ERR BIT(7)
#define BIT_RXBEQPKT_ERR BIT(6)
#define BIT_RXVIQPKT_ERR BIT(5)
#define BIT_RXVOQPKT_ERR BIT(4)
#define BIT_RXDMA_MON_EN BIT(2)
#define BIT_RXPKT_MON_RST BIT(1)
#define BIT_RXPKT_MON_EN BIT(0)
/* 2 REG_STATE_MON (Offset 0x06B4) */
#define BIT_EN_TXRPTBUF_CLK BIT(31)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_STATE_MON (Offset 0x06B4) */
#define BIT_SHIFT_DMA_MON_EN 24
#define BIT_MASK_DMA_MON_EN 0x1f
#define BIT_DMA_MON_EN(x) (((x) & BIT_MASK_DMA_MON_EN) << BIT_SHIFT_DMA_MON_EN)
#define BITS_DMA_MON_EN (BIT_MASK_DMA_MON_EN << BIT_SHIFT_DMA_MON_EN)
#define BIT_CLEAR_DMA_MON_EN(x) ((x) & (~BITS_DMA_MON_EN))
#define BIT_GET_DMA_MON_EN(x) \
(((x) >> BIT_SHIFT_DMA_MON_EN) & BIT_MASK_DMA_MON_EN)
#define BIT_SET_DMA_MON_EN(x, v) (BIT_CLEAR_DMA_MON_EN(x) | BIT_DMA_MON_EN(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_STATE_MON (Offset 0x06B4) */
#define BIT_SHIFT_STATE_SEL 24
#define BIT_MASK_STATE_SEL 0x1f
#define BIT_STATE_SEL(x) (((x) & BIT_MASK_STATE_SEL) << BIT_SHIFT_STATE_SEL)
#define BITS_STATE_SEL (BIT_MASK_STATE_SEL << BIT_SHIFT_STATE_SEL)
#define BIT_CLEAR_STATE_SEL(x) ((x) & (~BITS_STATE_SEL))
#define BIT_GET_STATE_SEL(x) (((x) >> BIT_SHIFT_STATE_SEL) & BIT_MASK_STATE_SEL)
#define BIT_SET_STATE_SEL(x, v) (BIT_CLEAR_STATE_SEL(x) | BIT_STATE_SEL(v))
#define BIT_MACRX_ERR_1 BIT(17)
#define BIT_MACRX_ERR_0 BIT(16)
#define BIT_DIS_INFOSRCH BIT(14)
#define BIT_SHIFT_STATE_INFO 8
#define BIT_MASK_STATE_INFO 0xff
#define BIT_STATE_INFO(x) (((x) & BIT_MASK_STATE_INFO) << BIT_SHIFT_STATE_INFO)
#define BITS_STATE_INFO (BIT_MASK_STATE_INFO << BIT_SHIFT_STATE_INFO)
#define BIT_CLEAR_STATE_INFO(x) ((x) & (~BITS_STATE_INFO))
#define BIT_GET_STATE_INFO(x) \
(((x) >> BIT_SHIFT_STATE_INFO) & BIT_MASK_STATE_INFO)
#define BIT_SET_STATE_INFO(x, v) (BIT_CLEAR_STATE_INFO(x) | BIT_STATE_INFO(v))
#define BIT_UPD_NXT_STATE BIT(7)
#define BIT_MACTX_ERR_3 BIT(3)
#define BIT_MACTX_ERR_2 BIT(2)
#define BIT_MACTX_ERR_1 BIT(1)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_STATE_MON (Offset 0x06B4) */
#define BIT_SHIFT_PKT_MON_EN 0
#define BIT_MASK_PKT_MON_EN 0x7f
#define BIT_PKT_MON_EN(x) (((x) & BIT_MASK_PKT_MON_EN) << BIT_SHIFT_PKT_MON_EN)
#define BITS_PKT_MON_EN (BIT_MASK_PKT_MON_EN << BIT_SHIFT_PKT_MON_EN)
#define BIT_CLEAR_PKT_MON_EN(x) ((x) & (~BITS_PKT_MON_EN))
#define BIT_GET_PKT_MON_EN(x) \
(((x) >> BIT_SHIFT_PKT_MON_EN) & BIT_MASK_PKT_MON_EN)
#define BIT_SET_PKT_MON_EN(x, v) (BIT_CLEAR_PKT_MON_EN(x) | BIT_PKT_MON_EN(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_STATE_MON (Offset 0x06B4) */
#define BIT_SHIFT_CUR_STATE 0
#define BIT_MASK_CUR_STATE 0x7f
#define BIT_CUR_STATE(x) (((x) & BIT_MASK_CUR_STATE) << BIT_SHIFT_CUR_STATE)
#define BITS_CUR_STATE (BIT_MASK_CUR_STATE << BIT_SHIFT_CUR_STATE)
#define BIT_CLEAR_CUR_STATE(x) ((x) & (~BITS_CUR_STATE))
#define BIT_GET_CUR_STATE(x) (((x) >> BIT_SHIFT_CUR_STATE) & BIT_MASK_CUR_STATE)
#define BIT_SET_CUR_STATE(x, v) (BIT_CLEAR_CUR_STATE(x) | BIT_CUR_STATE(v))
#define BIT_MACTX_ERR_0 BIT(0)
#define BIT_SHIFT_INFO_ADDR_OFFSET 0
#define BIT_MASK_INFO_ADDR_OFFSET 0x1fff
#define BIT_INFO_ADDR_OFFSET(x) \
(((x) & BIT_MASK_INFO_ADDR_OFFSET) << BIT_SHIFT_INFO_ADDR_OFFSET)
#define BITS_INFO_ADDR_OFFSET \
(BIT_MASK_INFO_ADDR_OFFSET << BIT_SHIFT_INFO_ADDR_OFFSET)
#define BIT_CLEAR_INFO_ADDR_OFFSET(x) ((x) & (~BITS_INFO_ADDR_OFFSET))
#define BIT_GET_INFO_ADDR_OFFSET(x) \
(((x) >> BIT_SHIFT_INFO_ADDR_OFFSET) & BIT_MASK_INFO_ADDR_OFFSET)
#define BIT_SET_INFO_ADDR_OFFSET(x, v) \
(BIT_CLEAR_INFO_ADDR_OFFSET(x) | BIT_INFO_ADDR_OFFSET(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_ERROR_MON (Offset 0x06B8) */
#define BIT_BFM_RPTNUM_ERROR BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ERROR_MON (Offset 0x06B8) */
#define BIT_MACRX_ERR_5 BIT(21)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_ERROR_MON (Offset 0x06B8) */
#define BIT_BFM_CHECKSUM_ERROR BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ERROR_MON (Offset 0x06B8) */
#define BIT_WMAC_PRETX_ERRHDL_EN BIT(15)
#define BIT_MACTX_ERR_5 BIT(5)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BT_COEX_TABLE (Offset 0x06C0) */
#define BIT_PRI_MASK_RX_RESP BIT(126)
#define BIT_PRI_MASK_RXOFDM BIT(125)
#define BIT_PRI_MASK_RXCCK BIT(124)
#define BIT_PRI_MASK_CCK BIT(108)
#define BIT_PRI_MASK_OFDM BIT(107)
#define BIT_PRI_MASK_RTY BIT(106)
#define BIT_OOB BIT(97)
#define BIT_ANT_SEL BIT(96)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_BT_COEX_TABLE (Offset 0x06C0) */
#define BIT_SHIFT_R_WMAC_BFINFO_20M_1 16
#define BIT_MASK_R_WMAC_BFINFO_20M_1 0xfff
#define BIT_R_WMAC_BFINFO_20M_1(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_1) << BIT_SHIFT_R_WMAC_BFINFO_20M_1)
#define BITS_R_WMAC_BFINFO_20M_1 \
(BIT_MASK_R_WMAC_BFINFO_20M_1 << BIT_SHIFT_R_WMAC_BFINFO_20M_1)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_1(x) ((x) & (~BITS_R_WMAC_BFINFO_20M_1))
#define BIT_GET_R_WMAC_BFINFO_20M_1(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_1) & BIT_MASK_R_WMAC_BFINFO_20M_1)
#define BIT_SET_R_WMAC_BFINFO_20M_1(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_1(x) | BIT_R_WMAC_BFINFO_20M_1(v))
#define BIT_SHIFT_COEX_TABLE_1 0
#define BIT_MASK_COEX_TABLE_1 0xffffffffL
#define BIT_COEX_TABLE_1(x) \
(((x) & BIT_MASK_COEX_TABLE_1) << BIT_SHIFT_COEX_TABLE_1)
#define BITS_COEX_TABLE_1 (BIT_MASK_COEX_TABLE_1 << BIT_SHIFT_COEX_TABLE_1)
#define BIT_CLEAR_COEX_TABLE_1(x) ((x) & (~BITS_COEX_TABLE_1))
#define BIT_GET_COEX_TABLE_1(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_1) & BIT_MASK_COEX_TABLE_1)
#define BIT_SET_COEX_TABLE_1(x, v) \
(BIT_CLEAR_COEX_TABLE_1(x) | BIT_COEX_TABLE_1(v))
#define BIT_SHIFT_R_WMAC_BFINFO_20M_0 0
#define BIT_MASK_R_WMAC_BFINFO_20M_0 0xfff
#define BIT_R_WMAC_BFINFO_20M_0(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_0) << BIT_SHIFT_R_WMAC_BFINFO_20M_0)
#define BITS_R_WMAC_BFINFO_20M_0 \
(BIT_MASK_R_WMAC_BFINFO_20M_0 << BIT_SHIFT_R_WMAC_BFINFO_20M_0)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_0(x) ((x) & (~BITS_R_WMAC_BFINFO_20M_0))
#define BIT_GET_R_WMAC_BFINFO_20M_0(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_0) & BIT_MASK_R_WMAC_BFINFO_20M_0)
#define BIT_SET_R_WMAC_BFINFO_20M_0(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_0(x) | BIT_R_WMAC_BFINFO_20M_0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_COEX_TABLE_H (Offset 0x06CC) */
#define BIT_PRI_MASK_RX_RESP_V1 BIT(30)
#define BIT_PRI_MASK_RXOFDM_V1 BIT(29)
#define BIT_PRI_MASK_RXCCK_V1 BIT(28)
#define BIT_PRI_MASK_CCK_V1 BIT(12)
#define BIT_PRI_MASK_OFDM_V1 BIT(11)
#define BIT_PRI_MASK_RTY_V1 BIT(10)
#define BIT_OOB_V1 BIT(1)
#define BIT_ANT_SEL_V1 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXCMD_0 (Offset 0x06D0) */
#define BIT_RXCMD_EN BIT(31)
#define BIT_SHIFT_RXCMD_INFO 0
#define BIT_MASK_RXCMD_INFO 0x7fffffffL
#define BIT_RXCMD_INFO(x) (((x) & BIT_MASK_RXCMD_INFO) << BIT_SHIFT_RXCMD_INFO)
#define BITS_RXCMD_INFO (BIT_MASK_RXCMD_INFO << BIT_SHIFT_RXCMD_INFO)
#define BIT_CLEAR_RXCMD_INFO(x) ((x) & (~BITS_RXCMD_INFO))
#define BIT_GET_RXCMD_INFO(x) \
(((x) >> BIT_SHIFT_RXCMD_INFO) & BIT_MASK_RXCMD_INFO)
#define BIT_SET_RXCMD_INFO(x, v) (BIT_CLEAR_RXCMD_INFO(x) | BIT_RXCMD_INFO(v))
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_TXUSER_ID1 BIT(25)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_SHIFT_CSI_RADDR_LATCH_V1 24
#define BIT_MASK_CSI_RADDR_LATCH_V1 0x3f
#define BIT_CSI_RADDR_LATCH_V1(x) \
(((x) & BIT_MASK_CSI_RADDR_LATCH_V1) << BIT_SHIFT_CSI_RADDR_LATCH_V1)
#define BITS_CSI_RADDR_LATCH_V1 \
(BIT_MASK_CSI_RADDR_LATCH_V1 << BIT_SHIFT_CSI_RADDR_LATCH_V1)
#define BIT_CLEAR_CSI_RADDR_LATCH_V1(x) ((x) & (~BITS_CSI_RADDR_LATCH_V1))
#define BIT_GET_CSI_RADDR_LATCH_V1(x) \
(((x) >> BIT_SHIFT_CSI_RADDR_LATCH_V1) & BIT_MASK_CSI_RADDR_LATCH_V1)
#define BIT_SET_CSI_RADDR_LATCH_V1(x, v) \
(BIT_CLEAR_CSI_RADDR_LATCH_V1(x) | BIT_CSI_RADDR_LATCH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_SHIFT_CSI_RADDR_LATCH 24
#define BIT_MASK_CSI_RADDR_LATCH 0xff
#define BIT_CSI_RADDR_LATCH(x) \
(((x) & BIT_MASK_CSI_RADDR_LATCH) << BIT_SHIFT_CSI_RADDR_LATCH)
#define BITS_CSI_RADDR_LATCH \
(BIT_MASK_CSI_RADDR_LATCH << BIT_SHIFT_CSI_RADDR_LATCH)
#define BIT_CLEAR_CSI_RADDR_LATCH(x) ((x) & (~BITS_CSI_RADDR_LATCH))
#define BIT_GET_CSI_RADDR_LATCH(x) \
(((x) >> BIT_SHIFT_CSI_RADDR_LATCH) & BIT_MASK_CSI_RADDR_LATCH)
#define BIT_SET_CSI_RADDR_LATCH(x, v) \
(BIT_CLEAR_CSI_RADDR_LATCH(x) | BIT_CSI_RADDR_LATCH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_SHIFT_AID1 16
#define BIT_MASK_AID1 0x1ff
#define BIT_AID1(x) (((x) & BIT_MASK_AID1) << BIT_SHIFT_AID1)
#define BITS_AID1 (BIT_MASK_AID1 << BIT_SHIFT_AID1)
#define BIT_CLEAR_AID1(x) ((x) & (~BITS_AID1))
#define BIT_GET_AID1(x) (((x) >> BIT_SHIFT_AID1) & BIT_MASK_AID1)
#define BIT_SET_AID1(x, v) (BIT_CLEAR_AID1(x) | BIT_AID1(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_SHIFT_CSI_WADDR_LATCH_V1 16
#define BIT_MASK_CSI_WADDR_LATCH_V1 0x3f
#define BIT_CSI_WADDR_LATCH_V1(x) \
(((x) & BIT_MASK_CSI_WADDR_LATCH_V1) << BIT_SHIFT_CSI_WADDR_LATCH_V1)
#define BITS_CSI_WADDR_LATCH_V1 \
(BIT_MASK_CSI_WADDR_LATCH_V1 << BIT_SHIFT_CSI_WADDR_LATCH_V1)
#define BIT_CLEAR_CSI_WADDR_LATCH_V1(x) ((x) & (~BITS_CSI_WADDR_LATCH_V1))
#define BIT_GET_CSI_WADDR_LATCH_V1(x) \
(((x) >> BIT_SHIFT_CSI_WADDR_LATCH_V1) & BIT_MASK_CSI_WADDR_LATCH_V1)
#define BIT_SET_CSI_WADDR_LATCH_V1(x, v) \
(BIT_CLEAR_CSI_WADDR_LATCH_V1(x) | BIT_CSI_WADDR_LATCH_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_SHIFT_CSI_WADDR_LATCH 16
#define BIT_MASK_CSI_WADDR_LATCH 0xff
#define BIT_CSI_WADDR_LATCH(x) \
(((x) & BIT_MASK_CSI_WADDR_LATCH) << BIT_SHIFT_CSI_WADDR_LATCH)
#define BITS_CSI_WADDR_LATCH \
(BIT_MASK_CSI_WADDR_LATCH << BIT_SHIFT_CSI_WADDR_LATCH)
#define BIT_CLEAR_CSI_WADDR_LATCH(x) ((x) & (~BITS_CSI_WADDR_LATCH))
#define BIT_GET_CSI_WADDR_LATCH(x) \
(((x) >> BIT_SHIFT_CSI_WADDR_LATCH) & BIT_MASK_CSI_WADDR_LATCH)
#define BIT_SET_CSI_WADDR_LATCH(x, v) \
(BIT_CLEAR_CSI_WADDR_LATCH(x) | BIT_CSI_WADDR_LATCH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RXCMD_1 (Offset 0x06D4) */
#define BIT_TXUSER_ID0 BIT(9)
#define BIT_SHIFT_RXCMD_PRD 0
#define BIT_MASK_RXCMD_PRD 0xffff
#define BIT_RXCMD_PRD(x) (((x) & BIT_MASK_RXCMD_PRD) << BIT_SHIFT_RXCMD_PRD)
#define BITS_RXCMD_PRD (BIT_MASK_RXCMD_PRD << BIT_SHIFT_RXCMD_PRD)
#define BIT_CLEAR_RXCMD_PRD(x) ((x) & (~BITS_RXCMD_PRD))
#define BIT_GET_RXCMD_PRD(x) (((x) >> BIT_SHIFT_RXCMD_PRD) & BIT_MASK_RXCMD_PRD)
#define BIT_SET_RXCMD_PRD(x, v) (BIT_CLEAR_RXCMD_PRD(x) | BIT_RXCMD_PRD(v))
#define BIT_SHIFT_AID0 0
#define BIT_MASK_AID0 0x1ff
#define BIT_AID0(x) (((x) & BIT_MASK_AID0) << BIT_SHIFT_AID0)
#define BITS_AID0 (BIT_MASK_AID0 << BIT_SHIFT_AID0)
#define BIT_CLEAR_AID0(x) ((x) & (~BITS_AID0))
#define BIT_GET_AID0(x) (((x) >> BIT_SHIFT_AID0) & BIT_MASK_AID0)
#define BIT_SET_AID0(x, v) (BIT_CLEAR_AID0(x) | BIT_AID0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_TXINFO_CFG (Offset 0x06D8) */
#define BIT_SHIFT_RESP_MFB 25
#define BIT_MASK_RESP_MFB 0x7f
#define BIT_RESP_MFB(x) (((x) & BIT_MASK_RESP_MFB) << BIT_SHIFT_RESP_MFB)
#define BITS_RESP_MFB (BIT_MASK_RESP_MFB << BIT_SHIFT_RESP_MFB)
#define BIT_CLEAR_RESP_MFB(x) ((x) & (~BITS_RESP_MFB))
#define BIT_GET_RESP_MFB(x) (((x) >> BIT_SHIFT_RESP_MFB) & BIT_MASK_RESP_MFB)
#define BIT_SET_RESP_MFB(x, v) (BIT_CLEAR_RESP_MFB(x) | BIT_RESP_MFB(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_WMAC_RESP_MFB 25
#define BIT_MASK_WMAC_RESP_MFB 0x7f
#define BIT_WMAC_RESP_MFB(x) \
(((x) & BIT_MASK_WMAC_RESP_MFB) << BIT_SHIFT_WMAC_RESP_MFB)
#define BITS_WMAC_RESP_MFB (BIT_MASK_WMAC_RESP_MFB << BIT_SHIFT_WMAC_RESP_MFB)
#define BIT_CLEAR_WMAC_RESP_MFB(x) ((x) & (~BITS_WMAC_RESP_MFB))
#define BIT_GET_WMAC_RESP_MFB(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_MFB) & BIT_MASK_WMAC_RESP_MFB)
#define BIT_SET_WMAC_RESP_MFB(x, v) \
(BIT_CLEAR_WMAC_RESP_MFB(x) | BIT_WMAC_RESP_MFB(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_TXINFO_CFG (Offset 0x06D8) */
#define BIT_SHIFT_ANTINF_SEL 23
#define BIT_MASK_ANTINF_SEL 0x3
#define BIT_ANTINF_SEL(x) (((x) & BIT_MASK_ANTINF_SEL) << BIT_SHIFT_ANTINF_SEL)
#define BITS_ANTINF_SEL (BIT_MASK_ANTINF_SEL << BIT_SHIFT_ANTINF_SEL)
#define BIT_CLEAR_ANTINF_SEL(x) ((x) & (~BITS_ANTINF_SEL))
#define BIT_GET_ANTINF_SEL(x) \
(((x) >> BIT_SHIFT_ANTINF_SEL) & BIT_MASK_ANTINF_SEL)
#define BIT_SET_ANTINF_SEL(x, v) (BIT_CLEAR_ANTINF_SEL(x) | BIT_ANTINF_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_WMAC_ANTINF_SEL 23
#define BIT_MASK_WMAC_ANTINF_SEL 0x3
#define BIT_WMAC_ANTINF_SEL(x) \
(((x) & BIT_MASK_WMAC_ANTINF_SEL) << BIT_SHIFT_WMAC_ANTINF_SEL)
#define BITS_WMAC_ANTINF_SEL \
(BIT_MASK_WMAC_ANTINF_SEL << BIT_SHIFT_WMAC_ANTINF_SEL)
#define BIT_CLEAR_WMAC_ANTINF_SEL(x) ((x) & (~BITS_WMAC_ANTINF_SEL))
#define BIT_GET_WMAC_ANTINF_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_ANTINF_SEL) & BIT_MASK_WMAC_ANTINF_SEL)
#define BIT_SET_WMAC_ANTINF_SEL(x, v) \
(BIT_CLEAR_WMAC_ANTINF_SEL(x) | BIT_WMAC_ANTINF_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_TXINFO_CFG (Offset 0x06D8) */
#define BIT_SHIFT_ANTSEL_SEL 21
#define BIT_MASK_ANTSEL_SEL 0x3
#define BIT_ANTSEL_SEL(x) (((x) & BIT_MASK_ANTSEL_SEL) << BIT_SHIFT_ANTSEL_SEL)
#define BITS_ANTSEL_SEL (BIT_MASK_ANTSEL_SEL << BIT_SHIFT_ANTSEL_SEL)
#define BIT_CLEAR_ANTSEL_SEL(x) ((x) & (~BITS_ANTSEL_SEL))
#define BIT_GET_ANTSEL_SEL(x) \
(((x) >> BIT_SHIFT_ANTSEL_SEL) & BIT_MASK_ANTSEL_SEL)
#define BIT_SET_ANTSEL_SEL(x, v) (BIT_CLEAR_ANTSEL_SEL(x) | BIT_ANTSEL_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_WMAC_ANTSEL_SEL 21
#define BIT_MASK_WMAC_ANTSEL_SEL 0x3
#define BIT_WMAC_ANTSEL_SEL(x) \
(((x) & BIT_MASK_WMAC_ANTSEL_SEL) << BIT_SHIFT_WMAC_ANTSEL_SEL)
#define BITS_WMAC_ANTSEL_SEL \
(BIT_MASK_WMAC_ANTSEL_SEL << BIT_SHIFT_WMAC_ANTSEL_SEL)
#define BIT_CLEAR_WMAC_ANTSEL_SEL(x) ((x) & (~BITS_WMAC_ANTSEL_SEL))
#define BIT_GET_WMAC_ANTSEL_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_ANTSEL_SEL) & BIT_MASK_WMAC_ANTSEL_SEL)
#define BIT_SET_WMAC_ANTSEL_SEL(x, v) \
(BIT_CLEAR_WMAC_ANTSEL_SEL(x) | BIT_WMAC_ANTSEL_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_R_WMAC_RESP_TXPOWER 18
#define BIT_MASK_R_WMAC_RESP_TXPOWER 0x7
#define BIT_R_WMAC_RESP_TXPOWER(x) \
(((x) & BIT_MASK_R_WMAC_RESP_TXPOWER) << BIT_SHIFT_R_WMAC_RESP_TXPOWER)
#define BITS_R_WMAC_RESP_TXPOWER \
(BIT_MASK_R_WMAC_RESP_TXPOWER << BIT_SHIFT_R_WMAC_RESP_TXPOWER)
#define BIT_CLEAR_R_WMAC_RESP_TXPOWER(x) ((x) & (~BITS_R_WMAC_RESP_TXPOWER))
#define BIT_GET_R_WMAC_RESP_TXPOWER(x) \
(((x) >> BIT_SHIFT_R_WMAC_RESP_TXPOWER) & BIT_MASK_R_WMAC_RESP_TXPOWER)
#define BIT_SET_R_WMAC_RESP_TXPOWER(x, v) \
(BIT_CLEAR_R_WMAC_RESP_TXPOWER(x) | BIT_R_WMAC_RESP_TXPOWER(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE 18
#define BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE 0x3
#define BIT_WMAC_RESP_TXPOWER_OFFSET_TYPE(x) \
(((x) & BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE) \
<< BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE)
#define BITS_WMAC_RESP_TXPOWER_OFFSET_TYPE \
(BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE \
<< BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE)
#define BIT_CLEAR_WMAC_RESP_TXPOWER_OFFSET_TYPE(x) \
((x) & (~BITS_WMAC_RESP_TXPOWER_OFFSET_TYPE))
#define BIT_GET_WMAC_RESP_TXPOWER_OFFSET_TYPE(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE) & \
BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE)
#define BIT_SET_WMAC_RESP_TXPOWER_OFFSET_TYPE(x, v) \
(BIT_CLEAR_WMAC_RESP_TXPOWER_OFFSET_TYPE(x) | \
BIT_WMAC_RESP_TXPOWER_OFFSET_TYPE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_RESP_TXAGC_B 13
#define BIT_MASK_RESP_TXAGC_B 0x1f
#define BIT_RESP_TXAGC_B(x) \
(((x) & BIT_MASK_RESP_TXAGC_B) << BIT_SHIFT_RESP_TXAGC_B)
#define BITS_RESP_TXAGC_B (BIT_MASK_RESP_TXAGC_B << BIT_SHIFT_RESP_TXAGC_B)
#define BIT_CLEAR_RESP_TXAGC_B(x) ((x) & (~BITS_RESP_TXAGC_B))
#define BIT_GET_RESP_TXAGC_B(x) \
(((x) >> BIT_SHIFT_RESP_TXAGC_B) & BIT_MASK_RESP_TXAGC_B)
#define BIT_SET_RESP_TXAGC_B(x, v) \
(BIT_CLEAR_RESP_TXAGC_B(x) | BIT_RESP_TXAGC_B(v))
#define BIT_SHIFT_RESP_TXAGC_A 8
#define BIT_MASK_RESP_TXAGC_A 0x1f
#define BIT_RESP_TXAGC_A(x) \
(((x) & BIT_MASK_RESP_TXAGC_A) << BIT_SHIFT_RESP_TXAGC_A)
#define BITS_RESP_TXAGC_A (BIT_MASK_RESP_TXAGC_A << BIT_SHIFT_RESP_TXAGC_A)
#define BIT_CLEAR_RESP_TXAGC_A(x) ((x) & (~BITS_RESP_TXAGC_A))
#define BIT_GET_RESP_TXAGC_A(x) \
(((x) >> BIT_SHIFT_RESP_TXAGC_A) & BIT_MASK_RESP_TXAGC_A)
#define BIT_SET_RESP_TXAGC_A(x, v) \
(BIT_CLEAR_RESP_TXAGC_A(x) | BIT_RESP_TXAGC_A(v))
#define BIT_RESP_ANTSEL_B BIT(7)
#define BIT_RESP_ANTSEL_A BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_WMAC_RESP_TXANT_V1 6
#define BIT_MASK_WMAC_RESP_TXANT_V1 0xfff
#define BIT_WMAC_RESP_TXANT_V1(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT_V1) << BIT_SHIFT_WMAC_RESP_TXANT_V1)
#define BITS_WMAC_RESP_TXANT_V1 \
(BIT_MASK_WMAC_RESP_TXANT_V1 << BIT_SHIFT_WMAC_RESP_TXANT_V1)
#define BIT_CLEAR_WMAC_RESP_TXANT_V1(x) ((x) & (~BITS_WMAC_RESP_TXANT_V1))
#define BIT_GET_WMAC_RESP_TXANT_V1(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT_V1) & BIT_MASK_WMAC_RESP_TXANT_V1)
#define BIT_SET_WMAC_RESP_TXANT_V1(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT_V1(x) | BIT_WMAC_RESP_TXANT_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_RESP_TXANT_CCK 4
#define BIT_MASK_RESP_TXANT_CCK 0x3
#define BIT_RESP_TXANT_CCK(x) \
(((x) & BIT_MASK_RESP_TXANT_CCK) << BIT_SHIFT_RESP_TXANT_CCK)
#define BITS_RESP_TXANT_CCK \
(BIT_MASK_RESP_TXANT_CCK << BIT_SHIFT_RESP_TXANT_CCK)
#define BIT_CLEAR_RESP_TXANT_CCK(x) ((x) & (~BITS_RESP_TXANT_CCK))
#define BIT_GET_RESP_TXANT_CCK(x) \
(((x) >> BIT_SHIFT_RESP_TXANT_CCK) & BIT_MASK_RESP_TXANT_CCK)
#define BIT_SET_RESP_TXANT_CCK(x, v) \
(BIT_CLEAR_RESP_TXANT_CCK(x) | BIT_RESP_TXANT_CCK(v))
#define BIT_SHIFT_RESP_TXANT_L 2
#define BIT_MASK_RESP_TXANT_L 0x3
#define BIT_RESP_TXANT_L(x) \
(((x) & BIT_MASK_RESP_TXANT_L) << BIT_SHIFT_RESP_TXANT_L)
#define BITS_RESP_TXANT_L (BIT_MASK_RESP_TXANT_L << BIT_SHIFT_RESP_TXANT_L)
#define BIT_CLEAR_RESP_TXANT_L(x) ((x) & (~BITS_RESP_TXANT_L))
#define BIT_GET_RESP_TXANT_L(x) \
(((x) >> BIT_SHIFT_RESP_TXANT_L) & BIT_MASK_RESP_TXANT_L)
#define BIT_SET_RESP_TXANT_L(x, v) \
(BIT_CLEAR_RESP_TXANT_L(x) | BIT_RESP_TXANT_L(v))
#define BIT_SHIFT_RESP_TXANT_HT 0
#define BIT_MASK_RESP_TXANT_HT 0x3
#define BIT_RESP_TXANT_HT(x) \
(((x) & BIT_MASK_RESP_TXANT_HT) << BIT_SHIFT_RESP_TXANT_HT)
#define BITS_RESP_TXANT_HT (BIT_MASK_RESP_TXANT_HT << BIT_SHIFT_RESP_TXANT_HT)
#define BIT_CLEAR_RESP_TXANT_HT(x) ((x) & (~BITS_RESP_TXANT_HT))
#define BIT_GET_RESP_TXANT_HT(x) \
(((x) >> BIT_SHIFT_RESP_TXANT_HT) & BIT_MASK_RESP_TXANT_HT)
#define BIT_SET_RESP_TXANT_HT(x, v) \
(BIT_CLEAR_RESP_TXANT_HT(x) | BIT_RESP_TXANT_HT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_TXINFO_CFG (Offset 0x06D8) */
#define BIT_SHIFT_RESP_TXANT 0
#define BIT_MASK_RESP_TXANT 0x3ffff
#define BIT_RESP_TXANT(x) (((x) & BIT_MASK_RESP_TXANT) << BIT_SHIFT_RESP_TXANT)
#define BITS_RESP_TXANT (BIT_MASK_RESP_TXANT << BIT_SHIFT_RESP_TXANT)
#define BIT_CLEAR_RESP_TXANT(x) ((x) & (~BITS_RESP_TXANT))
#define BIT_GET_RESP_TXANT(x) \
(((x) >> BIT_SHIFT_RESP_TXANT) & BIT_MASK_RESP_TXANT)
#define BIT_SET_RESP_TXANT(x, v) (BIT_CLEAR_RESP_TXANT(x) | BIT_RESP_TXANT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_RESP_TXINFO (Offset 0x06D8) */
#define BIT_SHIFT_WMAC_RESP_TXANT 0
#define BIT_MASK_WMAC_RESP_TXANT 0x3ffff
#define BIT_WMAC_RESP_TXANT(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT) << BIT_SHIFT_WMAC_RESP_TXANT)
#define BITS_WMAC_RESP_TXANT \
(BIT_MASK_WMAC_RESP_TXANT << BIT_SHIFT_WMAC_RESP_TXANT)
#define BIT_CLEAR_WMAC_RESP_TXANT(x) ((x) & (~BITS_WMAC_RESP_TXANT))
#define BIT_GET_WMAC_RESP_TXANT(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT) & BIT_MASK_WMAC_RESP_TXANT)
#define BIT_SET_WMAC_RESP_TXANT(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT(x) | BIT_WMAC_RESP_TXANT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_CTL_IDLE_CLR_CSI_RPT BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_WMAC_USE_NDPARATE BIT(30)
#define BIT_SHIFT_WMAC_CSI_RATE 24
#define BIT_MASK_WMAC_CSI_RATE 0x3f
#define BIT_WMAC_CSI_RATE(x) \
(((x) & BIT_MASK_WMAC_CSI_RATE) << BIT_SHIFT_WMAC_CSI_RATE)
#define BITS_WMAC_CSI_RATE (BIT_MASK_WMAC_CSI_RATE << BIT_SHIFT_WMAC_CSI_RATE)
#define BIT_CLEAR_WMAC_CSI_RATE(x) ((x) & (~BITS_WMAC_CSI_RATE))
#define BIT_GET_WMAC_CSI_RATE(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RATE) & BIT_MASK_WMAC_CSI_RATE)
#define BIT_SET_WMAC_CSI_RATE(x, v) \
(BIT_CLEAR_WMAC_CSI_RATE(x) | BIT_WMAC_CSI_RATE(v))
#define BIT_SHIFT_WMAC_RESP_TXRATE 16
#define BIT_MASK_WMAC_RESP_TXRATE 0xff
#define BIT_WMAC_RESP_TXRATE(x) \
(((x) & BIT_MASK_WMAC_RESP_TXRATE) << BIT_SHIFT_WMAC_RESP_TXRATE)
#define BITS_WMAC_RESP_TXRATE \
(BIT_MASK_WMAC_RESP_TXRATE << BIT_SHIFT_WMAC_RESP_TXRATE)
#define BIT_CLEAR_WMAC_RESP_TXRATE(x) ((x) & (~BITS_WMAC_RESP_TXRATE))
#define BIT_GET_WMAC_RESP_TXRATE(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXRATE) & BIT_MASK_WMAC_RESP_TXRATE)
#define BIT_SET_WMAC_RESP_TXRATE(x, v) \
(BIT_CLEAR_WMAC_RESP_TXRATE(x) | BIT_WMAC_RESP_TXRATE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_WMAC_CSI_RATE_FORCE_EN BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_CSI_FORCE_RATE_EN BIT(15)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_SHIFT_WMAC_CSI_RSC_FORCE 13
#define BIT_MASK_WMAC_CSI_RSC_FORCE 0x3
#define BIT_WMAC_CSI_RSC_FORCE(x) \
(((x) & BIT_MASK_WMAC_CSI_RSC_FORCE) << BIT_SHIFT_WMAC_CSI_RSC_FORCE)
#define BITS_WMAC_CSI_RSC_FORCE \
(BIT_MASK_WMAC_CSI_RSC_FORCE << BIT_SHIFT_WMAC_CSI_RSC_FORCE)
#define BIT_CLEAR_WMAC_CSI_RSC_FORCE(x) ((x) & (~BITS_WMAC_CSI_RSC_FORCE))
#define BIT_GET_WMAC_CSI_RSC_FORCE(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RSC_FORCE) & BIT_MASK_WMAC_CSI_RSC_FORCE)
#define BIT_SET_WMAC_CSI_RSC_FORCE(x, v) \
(BIT_CLEAR_WMAC_CSI_RSC_FORCE(x) | BIT_WMAC_CSI_RSC_FORCE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_SHIFT_CSI_RSC 13
#define BIT_MASK_CSI_RSC 0x3
#define BIT_CSI_RSC(x) (((x) & BIT_MASK_CSI_RSC) << BIT_SHIFT_CSI_RSC)
#define BITS_CSI_RSC (BIT_MASK_CSI_RSC << BIT_SHIFT_CSI_RSC)
#define BIT_CLEAR_CSI_RSC(x) ((x) & (~BITS_CSI_RSC))
#define BIT_GET_CSI_RSC(x) (((x) >> BIT_SHIFT_CSI_RSC) & BIT_MASK_CSI_RSC)
#define BIT_SET_CSI_RSC(x, v) (BIT_CLEAR_CSI_RSC(x) | BIT_CSI_RSC(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_WMAC_CSI_GID_SEL BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_CSI_GID_SEL BIT(12)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_RDCSIMD_FLAG_TRIG_SEL BIT(11)
#define BIT_NDPVLD_POS_RST_FFPTR_DIS_V1 BIT(10)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_NDPVLD_PROTECT_RDRDY_DIS BIT(9)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_CSIRD_EMPTY_APPZERO BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_RDCSI_EMPTY_APPZERO BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_WMC_CSI_RATE_FB_EN BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_CSI_RATE_FB_EN BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_RXFIFO_WRPTR_WO_CHKSUM BIT(6)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_BBPSF_MPDUCHKEN BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_BBPSF_CTRL (Offset 0x06DC) */
#define BIT_BBPSF_MHCHKEN BIT(4)
#define BIT_BBPSF_ERRCHKEN BIT(3)
#define BIT_SHIFT_BBPSF_ERRTHR 0
#define BIT_MASK_BBPSF_ERRTHR 0x7
#define BIT_BBPSF_ERRTHR(x) \
(((x) & BIT_MASK_BBPSF_ERRTHR) << BIT_SHIFT_BBPSF_ERRTHR)
#define BITS_BBPSF_ERRTHR (BIT_MASK_BBPSF_ERRTHR << BIT_SHIFT_BBPSF_ERRTHR)
#define BIT_CLEAR_BBPSF_ERRTHR(x) ((x) & (~BITS_BBPSF_ERRTHR))
#define BIT_GET_BBPSF_ERRTHR(x) \
(((x) >> BIT_SHIFT_BBPSF_ERRTHR) & BIT_MASK_BBPSF_ERRTHR)
#define BIT_SET_BBPSF_ERRTHR(x, v) \
(BIT_CLEAR_BBPSF_ERRTHR(x) | BIT_BBPSF_ERRTHR(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_TXINFO_RATE (Offset 0x06DE) */
#define BIT_CTL_IDLE_CLR_CSI_RPT_V1 BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_RESP_TXINFO_RATE (Offset 0x06DE) */
#define BIT_USE_NDPARATE BIT(14)
#define BIT_SHIFT_CSI_RATE 8
#define BIT_MASK_CSI_RATE 0x3f
#define BIT_CSI_RATE(x) (((x) & BIT_MASK_CSI_RATE) << BIT_SHIFT_CSI_RATE)
#define BITS_CSI_RATE (BIT_MASK_CSI_RATE << BIT_SHIFT_CSI_RATE)
#define BIT_CLEAR_CSI_RATE(x) ((x) & (~BITS_CSI_RATE))
#define BIT_GET_CSI_RATE(x) (((x) >> BIT_SHIFT_CSI_RATE) & BIT_MASK_CSI_RATE)
#define BIT_SET_CSI_RATE(x, v) (BIT_CLEAR_CSI_RATE(x) | BIT_CSI_RATE(v))
#define BIT_SHIFT_RESP_TXRATE 0
#define BIT_MASK_RESP_TXRATE 0xff
#define BIT_RESP_TXRATE(x) \
(((x) & BIT_MASK_RESP_TXRATE) << BIT_SHIFT_RESP_TXRATE)
#define BITS_RESP_TXRATE (BIT_MASK_RESP_TXRATE << BIT_SHIFT_RESP_TXRATE)
#define BIT_CLEAR_RESP_TXRATE(x) ((x) & (~BITS_RESP_TXRATE))
#define BIT_GET_RESP_TXRATE(x) \
(((x) >> BIT_SHIFT_RESP_TXRATE) & BIT_MASK_RESP_TXRATE)
#define BIT_SET_RESP_TXRATE(x, v) \
(BIT_CLEAR_RESP_TXRATE(x) | BIT_RESP_TXRATE(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2P_RX_BCN_NOA (Offset 0x06E0) */
#define BIT_NOA_PARSER_EN BIT(15)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2P_RX_BCN_NOA (Offset 0x06E0) */
#define BIT_BSSID_SEL BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2P_RX_BCN_NOA (Offset 0x06E0) */
#define BIT_SHIFT_BSSID_SEL_V1 12
#define BIT_MASK_BSSID_SEL_V1 0x7
#define BIT_BSSID_SEL_V1(x) \
(((x) & BIT_MASK_BSSID_SEL_V1) << BIT_SHIFT_BSSID_SEL_V1)
#define BITS_BSSID_SEL_V1 (BIT_MASK_BSSID_SEL_V1 << BIT_SHIFT_BSSID_SEL_V1)
#define BIT_CLEAR_BSSID_SEL_V1(x) ((x) & (~BITS_BSSID_SEL_V1))
#define BIT_GET_BSSID_SEL_V1(x) \
(((x) >> BIT_SHIFT_BSSID_SEL_V1) & BIT_MASK_BSSID_SEL_V1)
#define BIT_SET_BSSID_SEL_V1(x, v) \
(BIT_CLEAR_BSSID_SEL_V1(x) | BIT_BSSID_SEL_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_P2P_RX_BCN_NOA (Offset 0x06E0) */
#define BIT_SHIFT_P2P_OUI_TYPE 0
#define BIT_MASK_P2P_OUI_TYPE 0xff
#define BIT_P2P_OUI_TYPE(x) \
(((x) & BIT_MASK_P2P_OUI_TYPE) << BIT_SHIFT_P2P_OUI_TYPE)
#define BITS_P2P_OUI_TYPE (BIT_MASK_P2P_OUI_TYPE << BIT_SHIFT_P2P_OUI_TYPE)
#define BIT_CLEAR_P2P_OUI_TYPE(x) ((x) & (~BITS_P2P_OUI_TYPE))
#define BIT_GET_P2P_OUI_TYPE(x) \
(((x) >> BIT_SHIFT_P2P_OUI_TYPE) & BIT_MASK_P2P_OUI_TYPE)
#define BIT_SET_P2P_OUI_TYPE(x, v) \
(BIT_CLEAR_P2P_OUI_TYPE(x) | BIT_P2P_OUI_TYPE(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_P2P_RX_BCN_NOA (Offset 0x06E0) */
#define BIT_SHIFT_INFO_TXRPT_OFFSET_V1 0
#define BIT_MASK_INFO_TXRPT_OFFSET_V1 0x1fff
#define BIT_INFO_TXRPT_OFFSET_V1(x) \
(((x) & BIT_MASK_INFO_TXRPT_OFFSET_V1) \
<< BIT_SHIFT_INFO_TXRPT_OFFSET_V1)
#define BITS_INFO_TXRPT_OFFSET_V1 \
(BIT_MASK_INFO_TXRPT_OFFSET_V1 << BIT_SHIFT_INFO_TXRPT_OFFSET_V1)
#define BIT_CLEAR_INFO_TXRPT_OFFSET_V1(x) ((x) & (~BITS_INFO_TXRPT_OFFSET_V1))
#define BIT_GET_INFO_TXRPT_OFFSET_V1(x) \
(((x) >> BIT_SHIFT_INFO_TXRPT_OFFSET_V1) & \
BIT_MASK_INFO_TXRPT_OFFSET_V1)
#define BIT_SET_INFO_TXRPT_OFFSET_V1(x, v) \
(BIT_CLEAR_INFO_TXRPT_OFFSET_V1(x) | BIT_INFO_TXRPT_OFFSET_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ASSOCIATED_BFMER0_INFO (Offset 0x06E4) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0 0xffffffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0)
#define BITS_R_WMAC_SOUNDING_RXADD_R0 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ASSOCIATED_BFMER0_INFO (Offset 0x06E4) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0_V1(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_V1 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_V1))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_V1(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_V1(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_SOUNDING_CFG1 (Offset 0x06E8) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R0_H(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_H \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_H))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_H(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_H(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_H(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_ASSOCIATED_BFMER0_INFO_H (Offset 0x06E8) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_H_V1(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_H_V1(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_ASSOCIATED_BFMER1_INFO (Offset 0x06EC) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1 0xffffffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1)
#define BITS_R_WMAC_SOUNDING_RXADD_R1 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_SOUNDING_CFG2 (Offset 0x06EC) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V2 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V2 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_V2(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V2) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V2)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_V2 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V2 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V2)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V2(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_V2))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_V2(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V2) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V2)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_V2(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V2(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_ASSOCIATED_BFMER1_INFO (Offset 0x06EC) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_V1(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_V1 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_V1))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_V1(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_V1(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_SOUNDING_CFG3 (Offset 0x06F0) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V2 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V2 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R1_H_V2(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V2) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V2)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_H_V2 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V2 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V2)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V2(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_H_V2))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_H_V2(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V2) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V2)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_H_V2(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V2(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_H_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_ASSOCIATED_BFMER1_INFO_H (Offset 0x06F0) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1 \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1 \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_H_V1(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_H_V1(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TX_CSI_RPT_PARAM_BW40 (Offset 0x06F8) */
#define BIT_SHIFT_R_WMAC_BFINFO_40M_1 13
#define BIT_MASK_R_WMAC_BFINFO_40M_1 0x7fff
#define BIT_R_WMAC_BFINFO_40M_1(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_40M_1) << BIT_SHIFT_R_WMAC_BFINFO_40M_1)
#define BITS_R_WMAC_BFINFO_40M_1 \
(BIT_MASK_R_WMAC_BFINFO_40M_1 << BIT_SHIFT_R_WMAC_BFINFO_40M_1)
#define BIT_CLEAR_R_WMAC_BFINFO_40M_1(x) ((x) & (~BITS_R_WMAC_BFINFO_40M_1))
#define BIT_GET_R_WMAC_BFINFO_40M_1(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_40M_1) & BIT_MASK_R_WMAC_BFINFO_40M_1)
#define BIT_SET_R_WMAC_BFINFO_40M_1(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_40M_1(x) | BIT_R_WMAC_BFINFO_40M_1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_ANTCD_INFO (Offset 0x06F8) */
#define BIT_RESP_SMOOTH BIT(8)
#define BIT_SHIFT_POWER_STAGE2_NORETRY 6
#define BIT_MASK_POWER_STAGE2_NORETRY 0x3
#define BIT_POWER_STAGE2_NORETRY(x) \
(((x) & BIT_MASK_POWER_STAGE2_NORETRY) \
<< BIT_SHIFT_POWER_STAGE2_NORETRY)
#define BITS_POWER_STAGE2_NORETRY \
(BIT_MASK_POWER_STAGE2_NORETRY << BIT_SHIFT_POWER_STAGE2_NORETRY)
#define BIT_CLEAR_POWER_STAGE2_NORETRY(x) ((x) & (~BITS_POWER_STAGE2_NORETRY))
#define BIT_GET_POWER_STAGE2_NORETRY(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2_NORETRY) & \
BIT_MASK_POWER_STAGE2_NORETRY)
#define BIT_SET_POWER_STAGE2_NORETRY(x, v) \
(BIT_CLEAR_POWER_STAGE2_NORETRY(x) | BIT_POWER_STAGE2_NORETRY(v))
#define BIT_SHIFT_POWER_STAGE1_NORETRY 4
#define BIT_MASK_POWER_STAGE1_NORETRY 0x3
#define BIT_POWER_STAGE1_NORETRY(x) \
(((x) & BIT_MASK_POWER_STAGE1_NORETRY) \
<< BIT_SHIFT_POWER_STAGE1_NORETRY)
#define BITS_POWER_STAGE1_NORETRY \
(BIT_MASK_POWER_STAGE1_NORETRY << BIT_SHIFT_POWER_STAGE1_NORETRY)
#define BIT_CLEAR_POWER_STAGE1_NORETRY(x) ((x) & (~BITS_POWER_STAGE1_NORETRY))
#define BIT_GET_POWER_STAGE1_NORETRY(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1_NORETRY) & \
BIT_MASK_POWER_STAGE1_NORETRY)
#define BIT_SET_POWER_STAGE1_NORETRY(x, v) \
(BIT_CLEAR_POWER_STAGE1_NORETRY(x) | BIT_POWER_STAGE1_NORETRY(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_TX_CSI_RPT_PARAM_BW40 (Offset 0x06F8) */
#define BIT_SHIFT_R_WMAC_BFINFO_40M_0 0
#define BIT_MASK_R_WMAC_BFINFO_40M_0 0xfff
#define BIT_R_WMAC_BFINFO_40M_0(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_40M_0) << BIT_SHIFT_R_WMAC_BFINFO_40M_0)
#define BITS_R_WMAC_BFINFO_40M_0 \
(BIT_MASK_R_WMAC_BFINFO_40M_0 << BIT_SHIFT_R_WMAC_BFINFO_40M_0)
#define BIT_CLEAR_R_WMAC_BFINFO_40M_0(x) ((x) & (~BITS_R_WMAC_BFINFO_40M_0))
#define BIT_GET_R_WMAC_BFINFO_40M_0(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_40M_0) & BIT_MASK_R_WMAC_BFINFO_40M_0)
#define BIT_SET_R_WMAC_BFINFO_40M_0(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_40M_0(x) | BIT_R_WMAC_BFINFO_40M_0(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_ANTCD_INFO (Offset 0x06F8) */
#define BIT_SHIFT_RESP_ANTCD 0
#define BIT_MASK_RESP_ANTCD 0xf
#define BIT_RESP_ANTCD(x) (((x) & BIT_MASK_RESP_ANTCD) << BIT_SHIFT_RESP_ANTCD)
#define BITS_RESP_ANTCD (BIT_MASK_RESP_ANTCD << BIT_SHIFT_RESP_ANTCD)
#define BIT_CLEAR_RESP_ANTCD(x) ((x) & (~BITS_RESP_ANTCD))
#define BIT_GET_RESP_ANTCD(x) \
(((x) >> BIT_SHIFT_RESP_ANTCD) & BIT_MASK_RESP_ANTCD)
#define BIT_SET_RESP_ANTCD(x, v) (BIT_CLEAR_RESP_ANTCD(x) | BIT_RESP_ANTCD(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TX_CSI_RPT_PARAM_BW40 (Offset 0x06F8) */
#define BIT_SHIFT_WMAC_RESP_ANTCD 0
#define BIT_MASK_WMAC_RESP_ANTCD 0xf
#define BIT_WMAC_RESP_ANTCD(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTCD) << BIT_SHIFT_WMAC_RESP_ANTCD)
#define BITS_WMAC_RESP_ANTCD \
(BIT_MASK_WMAC_RESP_ANTCD << BIT_SHIFT_WMAC_RESP_ANTCD)
#define BIT_CLEAR_WMAC_RESP_ANTCD(x) ((x) & (~BITS_WMAC_RESP_ANTCD))
#define BIT_GET_WMAC_RESP_ANTCD(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTCD) & BIT_MASK_WMAC_RESP_ANTCD)
#define BIT_SET_WMAC_RESP_ANTCD(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTCD(x) | BIT_WMAC_RESP_ANTCD(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_CSI_RRSR_V1 (Offset 0x06FC) */
#define BIT_WMAC_CSI_LDPC_EN BIT(29)
#define BIT_WMAC_CSI_STBC_EN BIT(28)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TX_CSI_RPT_PARAM_BW80 (Offset 0x06FC) */
#define BIT_SHIFT_R_WMAC_BFINFO_80M_1 16
#define BIT_MASK_R_WMAC_BFINFO_80M_1 0xfff
#define BIT_R_WMAC_BFINFO_80M_1(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_80M_1) << BIT_SHIFT_R_WMAC_BFINFO_80M_1)
#define BITS_R_WMAC_BFINFO_80M_1 \
(BIT_MASK_R_WMAC_BFINFO_80M_1 << BIT_SHIFT_R_WMAC_BFINFO_80M_1)
#define BIT_CLEAR_R_WMAC_BFINFO_80M_1(x) ((x) & (~BITS_R_WMAC_BFINFO_80M_1))
#define BIT_GET_R_WMAC_BFINFO_80M_1(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_80M_1) & BIT_MASK_R_WMAC_BFINFO_80M_1)
#define BIT_SET_R_WMAC_BFINFO_80M_1(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_80M_1(x) | BIT_R_WMAC_BFINFO_80M_1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CSI_PTR (Offset 0x06FC) */
#define BIT_SHIFT_CSI_RADDR_LATCH_V2 16
#define BIT_MASK_CSI_RADDR_LATCH_V2 0xffff
#define BIT_CSI_RADDR_LATCH_V2(x) \
(((x) & BIT_MASK_CSI_RADDR_LATCH_V2) << BIT_SHIFT_CSI_RADDR_LATCH_V2)
#define BITS_CSI_RADDR_LATCH_V2 \
(BIT_MASK_CSI_RADDR_LATCH_V2 << BIT_SHIFT_CSI_RADDR_LATCH_V2)
#define BIT_CLEAR_CSI_RADDR_LATCH_V2(x) ((x) & (~BITS_CSI_RADDR_LATCH_V2))
#define BIT_GET_CSI_RADDR_LATCH_V2(x) \
(((x) >> BIT_SHIFT_CSI_RADDR_LATCH_V2) & BIT_MASK_CSI_RADDR_LATCH_V2)
#define BIT_SET_CSI_RADDR_LATCH_V2(x, v) \
(BIT_CLEAR_CSI_RADDR_LATCH_V2(x) | BIT_CSI_RADDR_LATCH_V2(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_CSI_RRSR_V1 (Offset 0x06FC) */
#define BIT_SHIFT_WMAC_CSI_RRSC_BITMAP 4
#define BIT_MASK_WMAC_CSI_RRSC_BITMAP 0xffffff
#define BIT_WMAC_CSI_RRSC_BITMAP(x) \
(((x) & BIT_MASK_WMAC_CSI_RRSC_BITMAP) \
<< BIT_SHIFT_WMAC_CSI_RRSC_BITMAP)
#define BITS_WMAC_CSI_RRSC_BITMAP \
(BIT_MASK_WMAC_CSI_RRSC_BITMAP << BIT_SHIFT_WMAC_CSI_RRSC_BITMAP)
#define BIT_CLEAR_WMAC_CSI_RRSC_BITMAP(x) ((x) & (~BITS_WMAC_CSI_RRSC_BITMAP))
#define BIT_GET_WMAC_CSI_RRSC_BITMAP(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RRSC_BITMAP) & \
BIT_MASK_WMAC_CSI_RRSC_BITMAP)
#define BIT_SET_WMAC_CSI_RRSC_BITMAP(x, v) \
(BIT_CLEAR_WMAC_CSI_RRSC_BITMAP(x) | BIT_WMAC_CSI_RRSC_BITMAP(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_TX_CSI_RPT_PARAM_BW80 (Offset 0x06FC) */
#define BIT_SHIFT_R_WMAC_BFINFO_80M_0 0
#define BIT_MASK_R_WMAC_BFINFO_80M_0 0xfff
#define BIT_R_WMAC_BFINFO_80M_0(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_80M_0) << BIT_SHIFT_R_WMAC_BFINFO_80M_0)
#define BITS_R_WMAC_BFINFO_80M_0 \
(BIT_MASK_R_WMAC_BFINFO_80M_0 << BIT_SHIFT_R_WMAC_BFINFO_80M_0)
#define BIT_CLEAR_R_WMAC_BFINFO_80M_0(x) ((x) & (~BITS_R_WMAC_BFINFO_80M_0))
#define BIT_GET_R_WMAC_BFINFO_80M_0(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_80M_0) & BIT_MASK_R_WMAC_BFINFO_80M_0)
#define BIT_SET_R_WMAC_BFINFO_80M_0(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_80M_0(x) | BIT_R_WMAC_BFINFO_80M_0(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CSI_PTR (Offset 0x06FC) */
#define BIT_SHIFT_CSI_WADDR_LATCH_V2 0
#define BIT_MASK_CSI_WADDR_LATCH_V2 0xffff
#define BIT_CSI_WADDR_LATCH_V2(x) \
(((x) & BIT_MASK_CSI_WADDR_LATCH_V2) << BIT_SHIFT_CSI_WADDR_LATCH_V2)
#define BITS_CSI_WADDR_LATCH_V2 \
(BIT_MASK_CSI_WADDR_LATCH_V2 << BIT_SHIFT_CSI_WADDR_LATCH_V2)
#define BIT_CLEAR_CSI_WADDR_LATCH_V2(x) ((x) & (~BITS_CSI_WADDR_LATCH_V2))
#define BIT_GET_CSI_WADDR_LATCH_V2(x) \
(((x) >> BIT_SHIFT_CSI_WADDR_LATCH_V2) & BIT_MASK_CSI_WADDR_LATCH_V2)
#define BIT_SET_CSI_WADDR_LATCH_V2(x, v) \
(BIT_CLEAR_CSI_WADDR_LATCH_V2(x) | BIT_CSI_WADDR_LATCH_V2(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_CSI_RRSR_V1 (Offset 0x06FC) */
#define BIT_SHIFT_WMAC_CSI_OFDM_LEN_TH 0
#define BIT_MASK_WMAC_CSI_OFDM_LEN_TH 0xf
#define BIT_WMAC_CSI_OFDM_LEN_TH(x) \
(((x) & BIT_MASK_WMAC_CSI_OFDM_LEN_TH) \
<< BIT_SHIFT_WMAC_CSI_OFDM_LEN_TH)
#define BITS_WMAC_CSI_OFDM_LEN_TH \
(BIT_MASK_WMAC_CSI_OFDM_LEN_TH << BIT_SHIFT_WMAC_CSI_OFDM_LEN_TH)
#define BIT_CLEAR_WMAC_CSI_OFDM_LEN_TH(x) ((x) & (~BITS_WMAC_CSI_OFDM_LEN_TH))
#define BIT_GET_WMAC_CSI_OFDM_LEN_TH(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_OFDM_LEN_TH) & \
BIT_MASK_WMAC_CSI_OFDM_LEN_TH)
#define BIT_SET_WMAC_CSI_OFDM_LEN_TH(x, v) \
(BIT_CLEAR_WMAC_CSI_OFDM_LEN_TH(x) | BIT_WMAC_CSI_OFDM_LEN_TH(v))
#define BIT_SHIFT_CSI_PARA_RDY_DLYCNT 0
#define BIT_MASK_CSI_PARA_RDY_DLYCNT 0x1f
#define BIT_CSI_PARA_RDY_DLYCNT(x) \
(((x) & BIT_MASK_CSI_PARA_RDY_DLYCNT) << BIT_SHIFT_CSI_PARA_RDY_DLYCNT)
#define BITS_CSI_PARA_RDY_DLYCNT \
(BIT_MASK_CSI_PARA_RDY_DLYCNT << BIT_SHIFT_CSI_PARA_RDY_DLYCNT)
#define BIT_CLEAR_CSI_PARA_RDY_DLYCNT(x) ((x) & (~BITS_CSI_PARA_RDY_DLYCNT))
#define BIT_GET_CSI_PARA_RDY_DLYCNT(x) \
(((x) >> BIT_SHIFT_CSI_PARA_RDY_DLYCNT) & BIT_MASK_CSI_PARA_RDY_DLYCNT)
#define BIT_SET_CSI_PARA_RDY_DLYCNT(x, v) \
(BIT_CLEAR_CSI_PARA_RDY_DLYCNT(x) | BIT_CSI_PARA_RDY_DLYCNT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
/* 2 REG_MACID1 (Offset 0x0700) */
#define BIT_SHIFT_MACID1 0
#define BIT_MASK_MACID1 0xffffffffffffL
#define BIT_MACID1(x) (((x) & BIT_MASK_MACID1) << BIT_SHIFT_MACID1)
#define BITS_MACID1 (BIT_MASK_MACID1 << BIT_SHIFT_MACID1)
#define BIT_CLEAR_MACID1(x) ((x) & (~BITS_MACID1))
#define BIT_GET_MACID1(x) (((x) >> BIT_SHIFT_MACID1) & BIT_MASK_MACID1)
#define BIT_SET_MACID1(x, v) (BIT_CLEAR_MACID1(x) | BIT_MACID1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID1 (Offset 0x0700) */
#define BIT_SHIFT_MACID1_0 0
#define BIT_MASK_MACID1_0 0xffffffffL
#define BIT_MACID1_0(x) (((x) & BIT_MASK_MACID1_0) << BIT_SHIFT_MACID1_0)
#define BITS_MACID1_0 (BIT_MASK_MACID1_0 << BIT_SHIFT_MACID1_0)
#define BIT_CLEAR_MACID1_0(x) ((x) & (~BITS_MACID1_0))
#define BIT_GET_MACID1_0(x) (((x) >> BIT_SHIFT_MACID1_0) & BIT_MASK_MACID1_0)
#define BIT_SET_MACID1_0(x, v) (BIT_CLEAR_MACID1_0(x) | BIT_MACID1_0(v))
/* 2 REG_MACID1_1 (Offset 0x0704) */
#define BIT_SHIFT_MACID1_1 0
#define BIT_MASK_MACID1_1 0xffff
#define BIT_MACID1_1(x) (((x) & BIT_MASK_MACID1_1) << BIT_SHIFT_MACID1_1)
#define BITS_MACID1_1 (BIT_MASK_MACID1_1 << BIT_SHIFT_MACID1_1)
#define BIT_CLEAR_MACID1_1(x) ((x) & (~BITS_MACID1_1))
#define BIT_GET_MACID1_1(x) (((x) >> BIT_SHIFT_MACID1_1) & BIT_MASK_MACID1_1)
#define BIT_SET_MACID1_1(x, v) (BIT_CLEAR_MACID1_1(x) | BIT_MACID1_1(v))
/* 2 REG_BSSID1 (Offset 0x0708) */
#define BIT_SHIFT_BSSID1_0 0
#define BIT_MASK_BSSID1_0 0xffffffffL
#define BIT_BSSID1_0(x) (((x) & BIT_MASK_BSSID1_0) << BIT_SHIFT_BSSID1_0)
#define BITS_BSSID1_0 (BIT_MASK_BSSID1_0 << BIT_SHIFT_BSSID1_0)
#define BIT_CLEAR_BSSID1_0(x) ((x) & (~BITS_BSSID1_0))
#define BIT_GET_BSSID1_0(x) (((x) >> BIT_SHIFT_BSSID1_0) & BIT_MASK_BSSID1_0)
#define BIT_SET_BSSID1_0(x, v) (BIT_CLEAR_BSSID1_0(x) | BIT_BSSID1_0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BSSID1 (Offset 0x0708) */
#define BIT_SHIFT_BSSID1 0
#define BIT_MASK_BSSID1 0xffffffffffffL
#define BIT_BSSID1(x) (((x) & BIT_MASK_BSSID1) << BIT_SHIFT_BSSID1)
#define BITS_BSSID1 (BIT_MASK_BSSID1 << BIT_SHIFT_BSSID1)
#define BIT_CLEAR_BSSID1(x) ((x) & (~BITS_BSSID1))
#define BIT_GET_BSSID1(x) (((x) >> BIT_SHIFT_BSSID1) & BIT_MASK_BSSID1)
#define BIT_SET_BSSID1(x, v) (BIT_CLEAR_BSSID1(x) | BIT_BSSID1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_FORCE_LINK_L (Offset 0x0709) */
#define BIT_PCIE_CFG_FORCE_EN BIT(7)
/* 2 REG_PCIE_CFG_FORCE_LINK_H (Offset 0x070A) */
#define BIT_PCIE_CFG_TRXACT_DIS_IDLE_TIMER BIT(6)
#define BIT_SHIFT_PCIE_CFG_LINK_STATE 0
#define BIT_MASK_PCIE_CFG_LINK_STATE 0x3f
#define BIT_PCIE_CFG_LINK_STATE(x) \
(((x) & BIT_MASK_PCIE_CFG_LINK_STATE) << BIT_SHIFT_PCIE_CFG_LINK_STATE)
#define BITS_PCIE_CFG_LINK_STATE \
(BIT_MASK_PCIE_CFG_LINK_STATE << BIT_SHIFT_PCIE_CFG_LINK_STATE)
#define BIT_CLEAR_PCIE_CFG_LINK_STATE(x) ((x) & (~BITS_PCIE_CFG_LINK_STATE))
#define BIT_GET_PCIE_CFG_LINK_STATE(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_LINK_STATE) & BIT_MASK_PCIE_CFG_LINK_STATE)
#define BIT_SET_PCIE_CFG_LINK_STATE(x, v) \
(BIT_CLEAR_PCIE_CFG_LINK_STATE(x) | BIT_PCIE_CFG_LINK_STATE(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BSSID1_1 (Offset 0x070C) */
#define BIT_SHIFT_BSSID1_1 0
#define BIT_MASK_BSSID1_1 0xffff
#define BIT_BSSID1_1(x) (((x) & BIT_MASK_BSSID1_1) << BIT_SHIFT_BSSID1_1)
#define BITS_BSSID1_1 (BIT_MASK_BSSID1_1 << BIT_SHIFT_BSSID1_1)
#define BIT_CLEAR_BSSID1_1(x) ((x) & (~BITS_BSSID1_1))
#define BIT_GET_BSSID1_1(x) (((x) >> BIT_SHIFT_BSSID1_1) & BIT_MASK_BSSID1_1)
#define BIT_SET_BSSID1_1(x, v) (BIT_CLEAR_BSSID1_1(x) | BIT_BSSID1_1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_DEFAULT_ACK_FREQUENCY (Offset 0x070C) */
#define BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY 0
#define BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY 0xff
#define BIT_PCIE_CFG_DEFAULT_ACK_FREQUENCY(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY)
#define BITS_PCIE_CFG_DEFAULT_ACK_FREQUENCY \
(BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_ACK_FREQUENCY(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_ACK_FREQUENCY))
#define BIT_GET_PCIE_CFG_DEFAULT_ACK_FREQUENCY(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY) & \
BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY)
#define BIT_SET_PCIE_CFG_DEFAULT_ACK_FREQUENCY(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_ACK_FREQUENCY(x) | \
BIT_PCIE_CFG_DEFAULT_ACK_FREQUENCY(v))
/* 2 REG_PCIE_CFG_CX_NFTS (Offset 0x070D) */
#define BIT_SHIFT_PCIE_CFG_CX_NFTS 0
#define BIT_MASK_PCIE_CFG_CX_NFTS 0xff
#define BIT_PCIE_CFG_CX_NFTS(x) \
(((x) & BIT_MASK_PCIE_CFG_CX_NFTS) << BIT_SHIFT_PCIE_CFG_CX_NFTS)
#define BITS_PCIE_CFG_CX_NFTS \
(BIT_MASK_PCIE_CFG_CX_NFTS << BIT_SHIFT_PCIE_CFG_CX_NFTS)
#define BIT_CLEAR_PCIE_CFG_CX_NFTS(x) ((x) & (~BITS_PCIE_CFG_CX_NFTS))
#define BIT_GET_PCIE_CFG_CX_NFTS(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_CX_NFTS) & BIT_MASK_PCIE_CFG_CX_NFTS)
#define BIT_SET_PCIE_CFG_CX_NFTS(x, v) \
(BIT_CLEAR_PCIE_CFG_CX_NFTS(x) | BIT_PCIE_CFG_CX_NFTS(v))
/* 2 REG_PCIE_CFG_DEFAULT_ENTR_LATENCY (Offset 0x070F) */
#define BIT_PCIE_CFG_REAL_EN_L0S BIT(7)
#define BIT_PCIE_CFG_ENTER_ASPM BIT(6)
#define BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY 3
#define BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY 0x7
#define BIT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY)
#define BITS_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY \
(BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY))
#define BIT_GET_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY) & \
BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY)
#define BIT_SET_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY(x) | \
BIT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY(v))
#define BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY 0
#define BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY 0x7
#define BIT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY)
#define BITS_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY \
(BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY))
#define BIT_GET_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY) & \
BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY)
#define BIT_SET_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY(x) | \
BIT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_PSR_RPT1 (Offset 0x0710) */
#define BIT_SHIFT_DTIM_CNT1 24
#define BIT_MASK_DTIM_CNT1 0xff
#define BIT_DTIM_CNT1(x) (((x) & BIT_MASK_DTIM_CNT1) << BIT_SHIFT_DTIM_CNT1)
#define BITS_DTIM_CNT1 (BIT_MASK_DTIM_CNT1 << BIT_SHIFT_DTIM_CNT1)
#define BIT_CLEAR_DTIM_CNT1(x) ((x) & (~BITS_DTIM_CNT1))
#define BIT_GET_DTIM_CNT1(x) (((x) >> BIT_SHIFT_DTIM_CNT1) & BIT_MASK_DTIM_CNT1)
#define BIT_SET_DTIM_CNT1(x, v) (BIT_CLEAR_DTIM_CNT1(x) | BIT_DTIM_CNT1(v))
#define BIT_SHIFT_DTIM_PERIOD1 16
#define BIT_MASK_DTIM_PERIOD1 0xff
#define BIT_DTIM_PERIOD1(x) \
(((x) & BIT_MASK_DTIM_PERIOD1) << BIT_SHIFT_DTIM_PERIOD1)
#define BITS_DTIM_PERIOD1 (BIT_MASK_DTIM_PERIOD1 << BIT_SHIFT_DTIM_PERIOD1)
#define BIT_CLEAR_DTIM_PERIOD1(x) ((x) & (~BITS_DTIM_PERIOD1))
#define BIT_GET_DTIM_PERIOD1(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD1) & BIT_MASK_DTIM_PERIOD1)
#define BIT_SET_DTIM_PERIOD1(x, v) \
(BIT_CLEAR_DTIM_PERIOD1(x) | BIT_DTIM_PERIOD1(v))
#define BIT_DTIM1 BIT(15)
#define BIT_TIM1 BIT(14)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_PSR_RPT1 (Offset 0x0710) */
#define BIT_BCN_VALID_V2 BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_PSR_RPT1 (Offset 0x0710) */
#define BIT_SHIFT_PS_AID_1 0
#define BIT_MASK_PS_AID_1 0x7ff
#define BIT_PS_AID_1(x) (((x) & BIT_MASK_PS_AID_1) << BIT_SHIFT_PS_AID_1)
#define BITS_PS_AID_1 (BIT_MASK_PS_AID_1 << BIT_SHIFT_PS_AID_1)
#define BIT_CLEAR_PS_AID_1(x) ((x) & (~BITS_PS_AID_1))
#define BIT_GET_PS_AID_1(x) (((x) >> BIT_SHIFT_PS_AID_1) & BIT_MASK_PS_AID_1)
#define BIT_SET_PS_AID_1(x, v) (BIT_CLEAR_PS_AID_1(x) | BIT_PS_AID_1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_L1_MISC_SEL (Offset 0x0711) */
#define BIT_PCIE_CFG_L1_RIDLE_SEL BIT(6)
#define BIT_PCIE_CFG_L1_TIMEOUT_SEL BIT(5)
#define BIT_PCIE_CFG_L1_EIDLE_SEL BIT(4)
#define BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE 0
#define BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE 0xf
#define BIT_PCIE_CFG_DEFAULT_LINK_RATE(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE)
#define BITS_PCIE_CFG_DEFAULT_LINK_RATE \
(BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_LINK_RATE(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_LINK_RATE))
#define BIT_GET_PCIE_CFG_DEFAULT_LINK_RATE(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE) & \
BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE)
#define BIT_SET_PCIE_CFG_DEFAULT_LINK_RATE(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_LINK_RATE(x) | \
BIT_PCIE_CFG_DEFAULT_LINK_RATE(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_ASSOCIATED_BFMEE_SEL (Offset 0x0714) */
#define BIT_SHIFT_RD_BF_SEL 29
#define BIT_MASK_RD_BF_SEL 0x7
#define BIT_RD_BF_SEL(x) (((x) & BIT_MASK_RD_BF_SEL) << BIT_SHIFT_RD_BF_SEL)
#define BITS_RD_BF_SEL (BIT_MASK_RD_BF_SEL << BIT_SHIFT_RD_BF_SEL)
#define BIT_CLEAR_RD_BF_SEL(x) ((x) & (~BITS_RD_BF_SEL))
#define BIT_GET_RD_BF_SEL(x) (((x) >> BIT_SHIFT_RD_BF_SEL) & BIT_MASK_RD_BF_SEL)
#define BIT_SET_RD_BF_SEL(x, v) (BIT_CLEAR_RD_BF_SEL(x) | BIT_RD_BF_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_NDP_RX_STANDBY_TIMER 24
#define BIT_MASK_NDP_RX_STANDBY_TIMER 0xff
#define BIT_NDP_RX_STANDBY_TIMER(x) \
(((x) & BIT_MASK_NDP_RX_STANDBY_TIMER) \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER)
#define BITS_NDP_RX_STANDBY_TIMER \
(BIT_MASK_NDP_RX_STANDBY_TIMER << BIT_SHIFT_NDP_RX_STANDBY_TIMER)
#define BIT_CLEAR_NDP_RX_STANDBY_TIMER(x) ((x) & (~BITS_NDP_RX_STANDBY_TIMER))
#define BIT_GET_NDP_RX_STANDBY_TIMER(x) \
(((x) >> BIT_SHIFT_NDP_RX_STANDBY_TIMER) & \
BIT_MASK_NDP_RX_STANDBY_TIMER)
#define BIT_SET_NDP_RX_STANDBY_TIMER(x, v) \
(BIT_CLEAR_NDP_RX_STANDBY_TIMER(x) | BIT_NDP_RX_STANDBY_TIMER(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_WMAC_CHK_RPTPOLL_A2_DIS BIT(23)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_WMAC_CHK_RPTPOLL_A2_DIS BIT(23)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_WMAC_CHK_UCNDPA_A2_DIS BIT(22)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_WMAC_CHK_UCNDPA_A2_DIS BIT(22)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_ANTTRN_SWITCH BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_CSI_RPT_OFFSET_HT 16
#define BIT_MASK_CSI_RPT_OFFSET_HT 0xff
#define BIT_CSI_RPT_OFFSET_HT(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT) << BIT_SHIFT_CSI_RPT_OFFSET_HT)
#define BITS_CSI_RPT_OFFSET_HT \
(BIT_MASK_CSI_RPT_OFFSET_HT << BIT_SHIFT_CSI_RPT_OFFSET_HT)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT(x) ((x) & (~BITS_CSI_RPT_OFFSET_HT))
#define BIT_GET_CSI_RPT_OFFSET_HT(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT) & BIT_MASK_CSI_RPT_OFFSET_HT)
#define BIT_SET_CSI_RPT_OFFSET_HT(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT(x) | BIT_CSI_RPT_OFFSET_HT(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_CSI_RPT_OFFSET_HT_V1 16
#define BIT_MASK_CSI_RPT_OFFSET_HT_V1 0x3f
#define BIT_CSI_RPT_OFFSET_HT_V1(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT_V1) \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_V1)
#define BITS_CSI_RPT_OFFSET_HT_V1 \
(BIT_MASK_CSI_RPT_OFFSET_HT_V1 << BIT_SHIFT_CSI_RPT_OFFSET_HT_V1)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT_V1(x) ((x) & (~BITS_CSI_RPT_OFFSET_HT_V1))
#define BIT_GET_CSI_RPT_OFFSET_HT_V1(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT_V1) & \
BIT_MASK_CSI_RPT_OFFSET_HT_V1)
#define BIT_SET_CSI_RPT_OFFSET_HT_V1(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT_V1(x) | BIT_CSI_RPT_OFFSET_HT_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_WMAC_OFFSET_RPTPOLL_EN BIT(15)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_WMAC_OFFSET_RPTPOLL_EN BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_VHTNDP_RPTPOLL_CSI_STR_OFFSET_SEL BIT(15)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_WMAC_CSI_CHKSUM_DIS BIT(14)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_WMAC_CSI_CHKSUM_DIS BIT(14)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_NDPVLD_POS_RST_FFPTR_DIS BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_R_WMAC_VHT_CATEGORY 8
#define BIT_MASK_R_WMAC_VHT_CATEGORY 0xff
#define BIT_R_WMAC_VHT_CATEGORY(x) \
(((x) & BIT_MASK_R_WMAC_VHT_CATEGORY) << BIT_SHIFT_R_WMAC_VHT_CATEGORY)
#define BITS_R_WMAC_VHT_CATEGORY \
(BIT_MASK_R_WMAC_VHT_CATEGORY << BIT_SHIFT_R_WMAC_VHT_CATEGORY)
#define BIT_CLEAR_R_WMAC_VHT_CATEGORY(x) ((x) & (~BITS_R_WMAC_VHT_CATEGORY))
#define BIT_GET_R_WMAC_VHT_CATEGORY(x) \
(((x) >> BIT_SHIFT_R_WMAC_VHT_CATEGORY) & BIT_MASK_R_WMAC_VHT_CATEGORY)
#define BIT_SET_R_WMAC_VHT_CATEGORY(x, v) \
(BIT_CLEAR_R_WMAC_VHT_CATEGORY(x) | BIT_R_WMAC_VHT_CATEGORY(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_CSI_RPT_OFFSET_VHT 8
#define BIT_MASK_CSI_RPT_OFFSET_VHT 0xff
#define BIT_CSI_RPT_OFFSET_VHT(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_VHT) << BIT_SHIFT_CSI_RPT_OFFSET_VHT)
#define BITS_CSI_RPT_OFFSET_VHT \
(BIT_MASK_CSI_RPT_OFFSET_VHT << BIT_SHIFT_CSI_RPT_OFFSET_VHT)
#define BIT_CLEAR_CSI_RPT_OFFSET_VHT(x) ((x) & (~BITS_CSI_RPT_OFFSET_VHT))
#define BIT_GET_CSI_RPT_OFFSET_VHT(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_VHT) & BIT_MASK_CSI_RPT_OFFSET_VHT)
#define BIT_SET_CSI_RPT_OFFSET_VHT(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_VHT(x) | BIT_CSI_RPT_OFFSET_VHT(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1 8
#define BIT_MASK_R_WMAC_VHT_CATEGORY_V1 0x3f
#define BIT_R_WMAC_VHT_CATEGORY_V1(x) \
(((x) & BIT_MASK_R_WMAC_VHT_CATEGORY_V1) \
<< BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1)
#define BITS_R_WMAC_VHT_CATEGORY_V1 \
(BIT_MASK_R_WMAC_VHT_CATEGORY_V1 << BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1)
#define BIT_CLEAR_R_WMAC_VHT_CATEGORY_V1(x) \
((x) & (~BITS_R_WMAC_VHT_CATEGORY_V1))
#define BIT_GET_R_WMAC_VHT_CATEGORY_V1(x) \
(((x) >> BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1) & \
BIT_MASK_R_WMAC_VHT_CATEGORY_V1)
#define BIT_SET_R_WMAC_VHT_CATEGORY_V1(x, v) \
(BIT_CLEAR_R_WMAC_VHT_CATEGORY_V1(x) | BIT_R_WMAC_VHT_CATEGORY_V1(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_CSI_RPT_OFFSET_VHT_V1 8
#define BIT_MASK_CSI_RPT_OFFSET_VHT_V1 0x3f
#define BIT_CSI_RPT_OFFSET_VHT_V1(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_VHT_V1) \
<< BIT_SHIFT_CSI_RPT_OFFSET_VHT_V1)
#define BITS_CSI_RPT_OFFSET_VHT_V1 \
(BIT_MASK_CSI_RPT_OFFSET_VHT_V1 << BIT_SHIFT_CSI_RPT_OFFSET_VHT_V1)
#define BIT_CLEAR_CSI_RPT_OFFSET_VHT_V1(x) ((x) & (~BITS_CSI_RPT_OFFSET_VHT_V1))
#define BIT_GET_CSI_RPT_OFFSET_VHT_V1(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_VHT_V1) & \
BIT_MASK_CSI_RPT_OFFSET_VHT_V1)
#define BIT_SET_CSI_RPT_OFFSET_VHT_V1(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_VHT_V1(x) | BIT_CSI_RPT_OFFSET_VHT_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1 8
#define BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1 0x3f
#define BIT_R_CSI_RPT_OFFSET_VHT_V1(x) \
(((x) & BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1) \
<< BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1)
#define BITS_R_CSI_RPT_OFFSET_VHT_V1 \
(BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1 << BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1)
#define BIT_CLEAR_R_CSI_RPT_OFFSET_VHT_V1(x) \
((x) & (~BITS_R_CSI_RPT_OFFSET_VHT_V1))
#define BIT_GET_R_CSI_RPT_OFFSET_VHT_V1(x) \
(((x) >> BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1) & \
BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1)
#define BIT_SET_R_CSI_RPT_OFFSET_VHT_V1(x, v) \
(BIT_CLEAR_R_CSI_RPT_OFFSET_VHT_V1(x) | BIT_R_CSI_RPT_OFFSET_VHT_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_WMAC_USE_NSTS BIT(7)
#define BIT_R_DISABLE_CHECK_VHTSIGB_CRC BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF (Offset 0x0718) */
#define BIT_PCIE_CFG_REAL_PTM_ENABLE BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_DISABLE_CHECK_VHTSIGA_CRC BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF (Offset 0x0718) */
#define BIT_PCIE_CFG_REAL_EN_L1SUB BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SND_PTCL_CTRL (Offset 0x0718) */
#define BIT_R_WMAC_BFPARAM_SEL BIT(4)
#define BIT_R_WMAC_CSISEQ_SEL BIT(3)
#define BIT_R_WMAC_CSI_WITHHTC_EN BIT(2)
#define BIT_R_WMAC_HT_NDPA_EN BIT(1)
#define BIT_R_WMAC_VHT_NDPA_EN BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF (Offset 0x0718) */
#define BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM 0
#define BIT_MASK_PCIE_CFG_MAX_FUNC_NUM 0x7
#define BIT_PCIE_CFG_MAX_FUNC_NUM(x) \
(((x) & BIT_MASK_PCIE_CFG_MAX_FUNC_NUM) \
<< BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM)
#define BITS_PCIE_CFG_MAX_FUNC_NUM \
(BIT_MASK_PCIE_CFG_MAX_FUNC_NUM << BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM)
#define BIT_CLEAR_PCIE_CFG_MAX_FUNC_NUM(x) ((x) & (~BITS_PCIE_CFG_MAX_FUNC_NUM))
#define BIT_GET_PCIE_CFG_MAX_FUNC_NUM(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM) & \
BIT_MASK_PCIE_CFG_MAX_FUNC_NUM)
#define BIT_SET_PCIE_CFG_MAX_FUNC_NUM(x, v) \
(BIT_CLEAR_PCIE_CFG_MAX_FUNC_NUM(x) | BIT_PCIE_CFG_MAX_FUNC_NUM(v))
/* 2 REG_PCIE_CFG_FORCE_CLKREQ_N_PAD (Offset 0x0719) */
#define BIT_PCIE_CFG_REAL_EN_64BITS BIT(5)
#define BIT_PCIE_CFG_REAL_EN_CLKREQ BIT(4)
#define BIT_PCIE_CFG_REAL_EN_L1 BIT(3)
#define BIT_PCIE_CFG_WAKE_N_EN BIT(2)
#define BIT_PCIE_CFG_BYPASS_LTR_OPTION BIT(1)
#define BIT_PCIE_CFG_FORCE_CLKREQ_N_PAD BIT(0)
/* 2 REG_PCIE_CFG_TIMER_MODIFIER_FOR_ACK_NAK_LATENCY (Offset 0x071A) */
#define BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK 0
#define BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK 0xff
#define BIT_PCIE_CFG_TIMER_MOD_ACK_NAK(x) \
(((x) & BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK) \
<< BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK)
#define BITS_PCIE_CFG_TIMER_MOD_ACK_NAK \
(BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK \
<< BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK)
#define BIT_CLEAR_PCIE_CFG_TIMER_MOD_ACK_NAK(x) \
((x) & (~BITS_PCIE_CFG_TIMER_MOD_ACK_NAK))
#define BIT_GET_PCIE_CFG_TIMER_MOD_ACK_NAK(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK) & \
BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK)
#define BIT_SET_PCIE_CFG_TIMER_MOD_ACK_NAK(x, v) \
(BIT_CLEAR_PCIE_CFG_TIMER_MOD_ACK_NAK(x) | \
BIT_PCIE_CFG_TIMER_MOD_ACK_NAK(v))
/* 2 REG_PCIE_CFG_TIMER_MODIFIER_FOR_FLOW_CONTROL_WATCHDOG (Offset 0x071B) */
#define BIT_PCIE_CFG_BYPASS_L1_SUBSTATE_OPTION BIT(7)
#define BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR 5
#define BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR 0x3
#define BIT_PCIE_CFG_FAST_LINK_SCALING_FACTOR(x) \
(((x) & BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR) \
<< BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR)
#define BITS_PCIE_CFG_FAST_LINK_SCALING_FACTOR \
(BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR \
<< BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR)
#define BIT_CLEAR_PCIE_CFG_FAST_LINK_SCALING_FACTOR(x) \
((x) & (~BITS_PCIE_CFG_FAST_LINK_SCALING_FACTOR))
#define BIT_GET_PCIE_CFG_FAST_LINK_SCALING_FACTOR(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR) & \
BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR)
#define BIT_SET_PCIE_CFG_FAST_LINK_SCALING_FACTOR(x, v) \
(BIT_CLEAR_PCIE_CFG_FAST_LINK_SCALING_FACTOR(x) | \
BIT_PCIE_CFG_FAST_LINK_SCALING_FACTOR(v))
#define BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER 0
#define BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER 0x1f
#define BIT_PCIE_CFG_UPDATE_FREQ_TIMER(x) \
(((x) & BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER) \
<< BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER)
#define BITS_PCIE_CFG_UPDATE_FREQ_TIMER \
(BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER \
<< BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER)
#define BIT_CLEAR_PCIE_CFG_UPDATE_FREQ_TIMER(x) \
((x) & (~BITS_PCIE_CFG_UPDATE_FREQ_TIMER))
#define BIT_GET_PCIE_CFG_UPDATE_FREQ_TIMER(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER) & \
BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER)
#define BIT_SET_PCIE_CFG_UPDATE_FREQ_TIMER(x, v) \
(BIT_CLEAR_PCIE_CFG_UPDATE_FREQ_TIMER(x) | \
BIT_PCIE_CFG_UPDATE_FREQ_TIMER(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO (Offset 0x071C) */
#define BIT_WMAC_CHECK_SOUNDING_SEQ BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_SKP_INTERVAL_VALUE_L (Offset 0x071C) */
#define BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L 0
#define BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L 0xff
#define BIT_PCIE_CFG_SKP_INTERVAL_VALUE_L(x) \
(((x) & BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L) \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L)
#define BITS_PCIE_CFG_SKP_INTERVAL_VALUE_L \
(BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L)
#define BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_L(x) \
((x) & (~BITS_PCIE_CFG_SKP_INTERVAL_VALUE_L))
#define BIT_GET_PCIE_CFG_SKP_INTERVAL_VALUE_L(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L) & \
BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L)
#define BIT_SET_PCIE_CFG_SKP_INTERVAL_VALUE_L(x, v) \
(BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_L(x) | \
BIT_PCIE_CFG_SKP_INTERVAL_VALUE_L(v))
/* 2 REG_PCIE_CFG_SKP_INTERVAL_VALUE_H (Offset 0x071D) */
#define BIT_PCIE_CFG_DISABLE_FC_WATCHDOG_TIMER BIT(7)
#define BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H 0
#define BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H 0x7
#define BIT_PCIE_CFG_SKP_INTERVAL_VALUE_H(x) \
(((x) & BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H) \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H)
#define BITS_PCIE_CFG_SKP_INTERVAL_VALUE_H \
(BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H)
#define BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_H(x) \
((x) & (~BITS_PCIE_CFG_SKP_INTERVAL_VALUE_H))
#define BIT_GET_PCIE_CFG_SKP_INTERVAL_VALUE_H(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H) & \
BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H)
#define BIT_SET_PCIE_CFG_SKP_INTERVAL_VALUE_H(x, v) \
(BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_H(x) | \
BIT_PCIE_CFG_SKP_INTERVAL_VALUE_H(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NS_ARP_CTRL (Offset 0x0720) */
#define BIT_R_WMAC_NSARP_RSPEN BIT(15)
#define BIT_R_WMAC_NSARP_RARP BIT(9)
#define BIT_R_WMAC_NSARP_RIPV6 BIT(8)
#define BIT_SHIFT_R_WMAC_NSARP_MODEN 6
#define BIT_MASK_R_WMAC_NSARP_MODEN 0x3
#define BIT_R_WMAC_NSARP_MODEN(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_MODEN) << BIT_SHIFT_R_WMAC_NSARP_MODEN)
#define BITS_R_WMAC_NSARP_MODEN \
(BIT_MASK_R_WMAC_NSARP_MODEN << BIT_SHIFT_R_WMAC_NSARP_MODEN)
#define BIT_CLEAR_R_WMAC_NSARP_MODEN(x) ((x) & (~BITS_R_WMAC_NSARP_MODEN))
#define BIT_GET_R_WMAC_NSARP_MODEN(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_MODEN) & BIT_MASK_R_WMAC_NSARP_MODEN)
#define BIT_SET_R_WMAC_NSARP_MODEN(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_MODEN(x) | BIT_R_WMAC_NSARP_MODEN(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPFTP 4
#define BIT_MASK_R_WMAC_NSARP_RSPFTP 0x3
#define BIT_R_WMAC_NSARP_RSPFTP(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPFTP) << BIT_SHIFT_R_WMAC_NSARP_RSPFTP)
#define BITS_R_WMAC_NSARP_RSPFTP \
(BIT_MASK_R_WMAC_NSARP_RSPFTP << BIT_SHIFT_R_WMAC_NSARP_RSPFTP)
#define BIT_CLEAR_R_WMAC_NSARP_RSPFTP(x) ((x) & (~BITS_R_WMAC_NSARP_RSPFTP))
#define BIT_GET_R_WMAC_NSARP_RSPFTP(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPFTP) & BIT_MASK_R_WMAC_NSARP_RSPFTP)
#define BIT_SET_R_WMAC_NSARP_RSPFTP(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPFTP(x) | BIT_R_WMAC_NSARP_RSPFTP(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPSEC 0
#define BIT_MASK_R_WMAC_NSARP_RSPSEC 0xf
#define BIT_R_WMAC_NSARP_RSPSEC(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPSEC) << BIT_SHIFT_R_WMAC_NSARP_RSPSEC)
#define BITS_R_WMAC_NSARP_RSPSEC \
(BIT_MASK_R_WMAC_NSARP_RSPSEC << BIT_SHIFT_R_WMAC_NSARP_RSPSEC)
#define BIT_CLEAR_R_WMAC_NSARP_RSPSEC(x) ((x) & (~BITS_R_WMAC_NSARP_RSPSEC))
#define BIT_GET_R_WMAC_NSARP_RSPSEC(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPSEC) & BIT_MASK_R_WMAC_NSARP_RSPSEC)
#define BIT_SET_R_WMAC_NSARP_RSPSEC(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPSEC(x) | BIT_R_WMAC_NSARP_RSPSEC(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NS_ARP_INFO (Offset 0x0724) */
#define BIT_REQ_IS_MCNS BIT(23)
#define BIT_REQ_IS_UCNS BIT(22)
#define BIT_REQ_IS_USNS BIT(21)
#define BIT_REQ_IS_ARP BIT(20)
#define BIT_EXPRSP_MH_WITHQC BIT(19)
#define BIT_SHIFT_EXPRSP_SECTYPE 16
#define BIT_MASK_EXPRSP_SECTYPE 0x7
#define BIT_EXPRSP_SECTYPE(x) \
(((x) & BIT_MASK_EXPRSP_SECTYPE) << BIT_SHIFT_EXPRSP_SECTYPE)
#define BITS_EXPRSP_SECTYPE \
(BIT_MASK_EXPRSP_SECTYPE << BIT_SHIFT_EXPRSP_SECTYPE)
#define BIT_CLEAR_EXPRSP_SECTYPE(x) ((x) & (~BITS_EXPRSP_SECTYPE))
#define BIT_GET_EXPRSP_SECTYPE(x) \
(((x) >> BIT_SHIFT_EXPRSP_SECTYPE) & BIT_MASK_EXPRSP_SECTYPE)
#define BIT_SET_EXPRSP_SECTYPE(x, v) \
(BIT_CLEAR_EXPRSP_SECTYPE(x) | BIT_EXPRSP_SECTYPE(v))
#define BIT_SHIFT_EXPRSP_CHKSM_7_TO_0 8
#define BIT_MASK_EXPRSP_CHKSM_7_TO_0 0xff
#define BIT_EXPRSP_CHKSM_7_TO_0(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_7_TO_0) << BIT_SHIFT_EXPRSP_CHKSM_7_TO_0)
#define BITS_EXPRSP_CHKSM_7_TO_0 \
(BIT_MASK_EXPRSP_CHKSM_7_TO_0 << BIT_SHIFT_EXPRSP_CHKSM_7_TO_0)
#define BIT_CLEAR_EXPRSP_CHKSM_7_TO_0(x) ((x) & (~BITS_EXPRSP_CHKSM_7_TO_0))
#define BIT_GET_EXPRSP_CHKSM_7_TO_0(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_7_TO_0) & BIT_MASK_EXPRSP_CHKSM_7_TO_0)
#define BIT_SET_EXPRSP_CHKSM_7_TO_0(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_7_TO_0(x) | BIT_EXPRSP_CHKSM_7_TO_0(v))
#define BIT_SHIFT_EXPRSP_CHKSM_15_TO_8 0
#define BIT_MASK_EXPRSP_CHKSM_15_TO_8 0xff
#define BIT_EXPRSP_CHKSM_15_TO_8(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_15_TO_8) \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8)
#define BITS_EXPRSP_CHKSM_15_TO_8 \
(BIT_MASK_EXPRSP_CHKSM_15_TO_8 << BIT_SHIFT_EXPRSP_CHKSM_15_TO_8)
#define BIT_CLEAR_EXPRSP_CHKSM_15_TO_8(x) ((x) & (~BITS_EXPRSP_CHKSM_15_TO_8))
#define BIT_GET_EXPRSP_CHKSM_15_TO_8(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_15_TO_8) & \
BIT_MASK_EXPRSP_CHKSM_15_TO_8)
#define BIT_SET_EXPRSP_CHKSM_15_TO_8(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_15_TO_8(x) | BIT_EXPRSP_CHKSM_15_TO_8(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PCIE_CFG_L1_UNIT_SEL (Offset 0x0724) */
#define BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL 0
#define BIT_MASK_PCIE_CFG_L1_UNIT_SEL 0xff
#define BIT_PCIE_CFG_L1_UNIT_SEL(x) \
(((x) & BIT_MASK_PCIE_CFG_L1_UNIT_SEL) \
<< BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL)
#define BITS_PCIE_CFG_L1_UNIT_SEL \
(BIT_MASK_PCIE_CFG_L1_UNIT_SEL << BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL)
#define BIT_CLEAR_PCIE_CFG_L1_UNIT_SEL(x) ((x) & (~BITS_PCIE_CFG_L1_UNIT_SEL))
#define BIT_GET_PCIE_CFG_L1_UNIT_SEL(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL) & \
BIT_MASK_PCIE_CFG_L1_UNIT_SEL)
#define BIT_SET_PCIE_CFG_L1_UNIT_SEL(x, v) \
(BIT_CLEAR_PCIE_CFG_L1_UNIT_SEL(x) | BIT_PCIE_CFG_L1_UNIT_SEL(v))
/* 2 REG_PCIE_CFG_MIN_CLKREQ_SEL (Offset 0x0725) */
#define BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL 0
#define BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL 0xf
#define BIT_PCIE_CFG_MIN_CLKREQ_SEL(x) \
(((x) & BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL) \
<< BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL)
#define BITS_PCIE_CFG_MIN_CLKREQ_SEL \
(BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL << BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL)
#define BIT_CLEAR_PCIE_CFG_MIN_CLKREQ_SEL(x) \
((x) & (~BITS_PCIE_CFG_MIN_CLKREQ_SEL))
#define BIT_GET_PCIE_CFG_MIN_CLKREQ_SEL(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL) & \
BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL)
#define BIT_SET_PCIE_CFG_MIN_CLKREQ_SEL(x, v) \
(BIT_CLEAR_PCIE_CFG_MIN_CLKREQ_SEL(x) | BIT_PCIE_CFG_MIN_CLKREQ_SEL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP_V1 (Offset 0x0728) */
#define BIT_SHIFT_WMAC_ARPIP 0
#define BIT_MASK_WMAC_ARPIP 0xffffffffL
#define BIT_WMAC_ARPIP(x) (((x) & BIT_MASK_WMAC_ARPIP) << BIT_SHIFT_WMAC_ARPIP)
#define BITS_WMAC_ARPIP (BIT_MASK_WMAC_ARPIP << BIT_SHIFT_WMAC_ARPIP)
#define BIT_CLEAR_WMAC_ARPIP(x) ((x) & (~BITS_WMAC_ARPIP))
#define BIT_GET_WMAC_ARPIP(x) \
(((x) >> BIT_SHIFT_WMAC_ARPIP) & BIT_MASK_WMAC_ARPIP)
#define BIT_SET_WMAC_ARPIP(x, v) (BIT_CLEAR_WMAC_ARPIP(x) | BIT_WMAC_ARPIP(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_USERID 13
#define BIT_MASK_UPD_BFMEE_USERID 0x7
#define BIT_UPD_BFMEE_USERID(x) \
(((x) & BIT_MASK_UPD_BFMEE_USERID) << BIT_SHIFT_UPD_BFMEE_USERID)
#define BITS_UPD_BFMEE_USERID \
(BIT_MASK_UPD_BFMEE_USERID << BIT_SHIFT_UPD_BFMEE_USERID)
#define BIT_CLEAR_UPD_BFMEE_USERID(x) ((x) & (~BITS_UPD_BFMEE_USERID))
#define BIT_GET_UPD_BFMEE_USERID(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_USERID) & BIT_MASK_UPD_BFMEE_USERID)
#define BIT_SET_UPD_BFMEE_USERID(x, v) \
(BIT_CLEAR_UPD_BFMEE_USERID(x) | BIT_UPD_BFMEE_USERID(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO_V1 (Offset 0x072C) */
#define BIT_WRITE_USERID BIT(12)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_UPD_BFMEE_FBTP BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO_V1 (Offset 0x072C) */
#define BIT_SHIFT_WRITE_BW 10
#define BIT_MASK_WRITE_BW 0x3
#define BIT_WRITE_BW(x) (((x) & BIT_MASK_WRITE_BW) << BIT_SHIFT_WRITE_BW)
#define BITS_WRITE_BW (BIT_MASK_WRITE_BW << BIT_SHIFT_WRITE_BW)
#define BIT_CLEAR_WRITE_BW(x) ((x) & (~BITS_WRITE_BW))
#define BIT_GET_WRITE_BW(x) (((x) >> BIT_SHIFT_WRITE_BW) & BIT_MASK_WRITE_BW)
#define BIT_SET_WRITE_BW(x, v) (BIT_CLEAR_WRITE_BW(x) | BIT_WRITE_BW(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_BW_V1 10
#define BIT_MASK_UPD_BFMEE_BW_V1 0x3
#define BIT_UPD_BFMEE_BW_V1(x) \
(((x) & BIT_MASK_UPD_BFMEE_BW_V1) << BIT_SHIFT_UPD_BFMEE_BW_V1)
#define BITS_UPD_BFMEE_BW_V1 \
(BIT_MASK_UPD_BFMEE_BW_V1 << BIT_SHIFT_UPD_BFMEE_BW_V1)
#define BIT_CLEAR_UPD_BFMEE_BW_V1(x) ((x) & (~BITS_UPD_BFMEE_BW_V1))
#define BIT_GET_UPD_BFMEE_BW_V1(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_BW_V1) & BIT_MASK_UPD_BFMEE_BW_V1)
#define BIT_SET_UPD_BFMEE_BW_V1(x, v) \
(BIT_CLEAR_UPD_BFMEE_BW_V1(x) | BIT_UPD_BFMEE_BW_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO_V1 (Offset 0x072C) */
#define BIT_SHIFT_WRITE_CB 8
#define BIT_MASK_WRITE_CB 0x3
#define BIT_WRITE_CB(x) (((x) & BIT_MASK_WRITE_CB) << BIT_SHIFT_WRITE_CB)
#define BITS_WRITE_CB (BIT_MASK_WRITE_CB << BIT_SHIFT_WRITE_CB)
#define BIT_CLEAR_WRITE_CB(x) ((x) & (~BITS_WRITE_CB))
#define BIT_GET_WRITE_CB(x) (((x) >> BIT_SHIFT_WRITE_CB) & BIT_MASK_WRITE_CB)
#define BIT_SET_WRITE_CB(x, v) (BIT_CLEAR_WRITE_CB(x) | BIT_WRITE_CB(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_CB 8
#define BIT_MASK_UPD_BFMEE_CB 0x3
#define BIT_UPD_BFMEE_CB(x) \
(((x) & BIT_MASK_UPD_BFMEE_CB) << BIT_SHIFT_UPD_BFMEE_CB)
#define BITS_UPD_BFMEE_CB (BIT_MASK_UPD_BFMEE_CB << BIT_SHIFT_UPD_BFMEE_CB)
#define BIT_CLEAR_UPD_BFMEE_CB(x) ((x) & (~BITS_UPD_BFMEE_CB))
#define BIT_GET_UPD_BFMEE_CB(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_CB) & BIT_MASK_UPD_BFMEE_CB)
#define BIT_SET_UPD_BFMEE_CB(x, v) \
(BIT_CLEAR_UPD_BFMEE_CB(x) | BIT_UPD_BFMEE_CB(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO_V1 (Offset 0x072C) */
#define BIT_SHIFT_WRITE_GROUPING 6
#define BIT_MASK_WRITE_GROUPING 0x3
#define BIT_WRITE_GROUPING(x) \
(((x) & BIT_MASK_WRITE_GROUPING) << BIT_SHIFT_WRITE_GROUPING)
#define BITS_WRITE_GROUPING \
(BIT_MASK_WRITE_GROUPING << BIT_SHIFT_WRITE_GROUPING)
#define BIT_CLEAR_WRITE_GROUPING(x) ((x) & (~BITS_WRITE_GROUPING))
#define BIT_GET_WRITE_GROUPING(x) \
(((x) >> BIT_SHIFT_WRITE_GROUPING) & BIT_MASK_WRITE_GROUPING)
#define BIT_SET_WRITE_GROUPING(x, v) \
(BIT_CLEAR_WRITE_GROUPING(x) | BIT_WRITE_GROUPING(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_NG 6
#define BIT_MASK_UPD_BFMEE_NG 0x3
#define BIT_UPD_BFMEE_NG(x) \
(((x) & BIT_MASK_UPD_BFMEE_NG) << BIT_SHIFT_UPD_BFMEE_NG)
#define BITS_UPD_BFMEE_NG (BIT_MASK_UPD_BFMEE_NG << BIT_SHIFT_UPD_BFMEE_NG)
#define BIT_CLEAR_UPD_BFMEE_NG(x) ((x) & (~BITS_UPD_BFMEE_NG))
#define BIT_GET_UPD_BFMEE_NG(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_NG) & BIT_MASK_UPD_BFMEE_NG)
#define BIT_SET_UPD_BFMEE_NG(x, v) \
(BIT_CLEAR_UPD_BFMEE_NG(x) | BIT_UPD_BFMEE_NG(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO_V1 (Offset 0x072C) */
#define BIT_SHIFT_WRITE_NR 3
#define BIT_MASK_WRITE_NR 0x7
#define BIT_WRITE_NR(x) (((x) & BIT_MASK_WRITE_NR) << BIT_SHIFT_WRITE_NR)
#define BITS_WRITE_NR (BIT_MASK_WRITE_NR << BIT_SHIFT_WRITE_NR)
#define BIT_CLEAR_WRITE_NR(x) ((x) & (~BITS_WRITE_NR))
#define BIT_GET_WRITE_NR(x) (((x) >> BIT_SHIFT_WRITE_NR) & BIT_MASK_WRITE_NR)
#define BIT_SET_WRITE_NR(x, v) (BIT_CLEAR_WRITE_NR(x) | BIT_WRITE_NR(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_NR 3
#define BIT_MASK_UPD_BFMEE_NR 0x7
#define BIT_UPD_BFMEE_NR(x) \
(((x) & BIT_MASK_UPD_BFMEE_NR) << BIT_SHIFT_UPD_BFMEE_NR)
#define BITS_UPD_BFMEE_NR (BIT_MASK_UPD_BFMEE_NR << BIT_SHIFT_UPD_BFMEE_NR)
#define BIT_CLEAR_UPD_BFMEE_NR(x) ((x) & (~BITS_UPD_BFMEE_NR))
#define BIT_GET_UPD_BFMEE_NR(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_NR) & BIT_MASK_UPD_BFMEE_NR)
#define BIT_SET_UPD_BFMEE_NR(x, v) \
(BIT_CLEAR_UPD_BFMEE_NR(x) | BIT_UPD_BFMEE_NR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_RX_CSI_RPT_INFO_V1 (Offset 0x072C) */
#define BIT_SHIFT_WRITE_NC 0
#define BIT_MASK_WRITE_NC 0x7
#define BIT_WRITE_NC(x) (((x) & BIT_MASK_WRITE_NC) << BIT_SHIFT_WRITE_NC)
#define BITS_WRITE_NC (BIT_MASK_WRITE_NC << BIT_SHIFT_WRITE_NC)
#define BIT_CLEAR_WRITE_NC(x) ((x) & (~BITS_WRITE_NC))
#define BIT_GET_WRITE_NC(x) (((x) >> BIT_SHIFT_WRITE_NC) & BIT_MASK_WRITE_NC)
#define BIT_SET_WRITE_NC(x, v) (BIT_CLEAR_WRITE_NC(x) | BIT_WRITE_NC(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_NC 0
#define BIT_MASK_UPD_BFMEE_NC 0x7
#define BIT_UPD_BFMEE_NC(x) \
(((x) & BIT_MASK_UPD_BFMEE_NC) << BIT_SHIFT_UPD_BFMEE_NC)
#define BITS_UPD_BFMEE_NC (BIT_MASK_UPD_BFMEE_NC << BIT_SHIFT_UPD_BFMEE_NC)
#define BIT_CLEAR_UPD_BFMEE_NC(x) ((x) & (~BITS_UPD_BFMEE_NC))
#define BIT_GET_UPD_BFMEE_NC(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_NC) & BIT_MASK_UPD_BFMEE_NC)
#define BIT_SET_UPD_BFMEE_NC(x, v) \
(BIT_CLEAR_UPD_BFMEE_NC(x) | BIT_UPD_BFMEE_NC(v))
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_BEAMFORMING_INFO 0
#define BIT_MASK_BEAMFORMING_INFO 0xffffffffL
#define BIT_BEAMFORMING_INFO(x) \
(((x) & BIT_MASK_BEAMFORMING_INFO) << BIT_SHIFT_BEAMFORMING_INFO)
#define BITS_BEAMFORMING_INFO \
(BIT_MASK_BEAMFORMING_INFO << BIT_SHIFT_BEAMFORMING_INFO)
#define BIT_CLEAR_BEAMFORMING_INFO(x) ((x) & (~BITS_BEAMFORMING_INFO))
#define BIT_GET_BEAMFORMING_INFO(x) \
(((x) >> BIT_SHIFT_BEAMFORMING_INFO) & BIT_MASK_BEAMFORMING_INFO)
#define BIT_SET_BEAMFORMING_INFO(x, v) \
(BIT_CLEAR_BEAMFORMING_INFO(x) | BIT_BEAMFORMING_INFO(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BEAMFORMING_INFO_NSARP (Offset 0x072C) */
#define BIT_SHIFT_UPD_BFMEE_BW 0
#define BIT_MASK_UPD_BFMEE_BW 0xfff
#define BIT_UPD_BFMEE_BW(x) \
(((x) & BIT_MASK_UPD_BFMEE_BW) << BIT_SHIFT_UPD_BFMEE_BW)
#define BITS_UPD_BFMEE_BW (BIT_MASK_UPD_BFMEE_BW << BIT_SHIFT_UPD_BFMEE_BW)
#define BIT_CLEAR_UPD_BFMEE_BW(x) ((x) & (~BITS_UPD_BFMEE_BW))
#define BIT_GET_UPD_BFMEE_BW(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_BW) & BIT_MASK_UPD_BFMEE_BW)
#define BIT_SET_UPD_BFMEE_BW(x, v) \
(BIT_CLEAR_UPD_BFMEE_BW(x) | BIT_UPD_BFMEE_BW(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_IPV6 (Offset 0x0730) */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_0 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_0(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_0) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0)
#define BITS_R_WMAC_IPV6_MYIPAD_0 \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_0 << BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0(x) ((x) & (~BITS_R_WMAC_IPV6_MYIPAD_0))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_0(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_0)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_0(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0(x) | BIT_R_WMAC_IPV6_MYIPAD_0(v))
/* 2 REG_IPV6_1 (Offset 0x0734) */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_1 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_1(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_1) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1)
#define BITS_R_WMAC_IPV6_MYIPAD_1 \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_1 << BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1(x) ((x) & (~BITS_R_WMAC_IPV6_MYIPAD_1))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_1(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_1)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_1(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1(x) | BIT_R_WMAC_IPV6_MYIPAD_1(v))
/* 2 REG_IPV6_2 (Offset 0x0738) */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_2 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_2(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_2) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2)
#define BITS_R_WMAC_IPV6_MYIPAD_2 \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_2 << BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2(x) ((x) & (~BITS_R_WMAC_IPV6_MYIPAD_2))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_2(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_2)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_2(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2(x) | BIT_R_WMAC_IPV6_MYIPAD_2(v))
/* 2 REG_IPV6_3 (Offset 0x073C) */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_3 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_3(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_3) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3)
#define BITS_R_WMAC_IPV6_MYIPAD_3 \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_3 << BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3(x) ((x) & (~BITS_R_WMAC_IPV6_MYIPAD_3))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_3(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_3)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_3(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3(x) | BIT_R_WMAC_IPV6_MYIPAD_3(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG (Offset 0x0750) */
#define BIT_SHIFT_R_WMAC_CTX_SUBTYPE 4
#define BIT_MASK_R_WMAC_CTX_SUBTYPE 0xf
#define BIT_R_WMAC_CTX_SUBTYPE(x) \
(((x) & BIT_MASK_R_WMAC_CTX_SUBTYPE) << BIT_SHIFT_R_WMAC_CTX_SUBTYPE)
#define BITS_R_WMAC_CTX_SUBTYPE \
(BIT_MASK_R_WMAC_CTX_SUBTYPE << BIT_SHIFT_R_WMAC_CTX_SUBTYPE)
#define BIT_CLEAR_R_WMAC_CTX_SUBTYPE(x) ((x) & (~BITS_R_WMAC_CTX_SUBTYPE))
#define BIT_GET_R_WMAC_CTX_SUBTYPE(x) \
(((x) >> BIT_SHIFT_R_WMAC_CTX_SUBTYPE) & BIT_MASK_R_WMAC_CTX_SUBTYPE)
#define BIT_SET_R_WMAC_CTX_SUBTYPE(x, v) \
(BIT_CLEAR_R_WMAC_CTX_SUBTYPE(x) | BIT_R_WMAC_CTX_SUBTYPE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG (Offset 0x0750) */
#define BIT_SHIFT_R_WMAC_RTX_SUBTYPE 0
#define BIT_MASK_R_WMAC_RTX_SUBTYPE 0xf
#define BIT_R_WMAC_RTX_SUBTYPE(x) \
(((x) & BIT_MASK_R_WMAC_RTX_SUBTYPE) << BIT_SHIFT_R_WMAC_RTX_SUBTYPE)
#define BITS_R_WMAC_RTX_SUBTYPE \
(BIT_MASK_R_WMAC_RTX_SUBTYPE << BIT_SHIFT_R_WMAC_RTX_SUBTYPE)
#define BIT_CLEAR_R_WMAC_RTX_SUBTYPE(x) ((x) & (~BITS_R_WMAC_RTX_SUBTYPE))
#define BIT_GET_R_WMAC_RTX_SUBTYPE(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTX_SUBTYPE) & BIT_MASK_R_WMAC_RTX_SUBTYPE)
#define BIT_SET_R_WMAC_RTX_SUBTYPE(x, v) \
(BIT_CLEAR_R_WMAC_RTX_SUBTYPE(x) | BIT_R_WMAC_RTX_SUBTYPE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_SWAES_DIO_B63_B32 (Offset 0x0754) */
#define BIT_SHIFT_WMAC_SWAES_DIO_B63_B32 0
#define BIT_MASK_WMAC_SWAES_DIO_B63_B32 0xffffffffL
#define BIT_WMAC_SWAES_DIO_B63_B32(x) \
(((x) & BIT_MASK_WMAC_SWAES_DIO_B63_B32) \
<< BIT_SHIFT_WMAC_SWAES_DIO_B63_B32)
#define BITS_WMAC_SWAES_DIO_B63_B32 \
(BIT_MASK_WMAC_SWAES_DIO_B63_B32 << BIT_SHIFT_WMAC_SWAES_DIO_B63_B32)
#define BIT_CLEAR_WMAC_SWAES_DIO_B63_B32(x) \
((x) & (~BITS_WMAC_SWAES_DIO_B63_B32))
#define BIT_GET_WMAC_SWAES_DIO_B63_B32(x) \
(((x) >> BIT_SHIFT_WMAC_SWAES_DIO_B63_B32) & \
BIT_MASK_WMAC_SWAES_DIO_B63_B32)
#define BIT_SET_WMAC_SWAES_DIO_B63_B32(x, v) \
(BIT_CLEAR_WMAC_SWAES_DIO_B63_B32(x) | BIT_WMAC_SWAES_DIO_B63_B32(v))
/* 2 REG_WMAC_SWAES_DIO_B95_B64 (Offset 0x0758) */
#define BIT_SHIFT_WMAC_SWAES_DIO_B95_B64 0
#define BIT_MASK_WMAC_SWAES_DIO_B95_B64 0xffffffffL
#define BIT_WMAC_SWAES_DIO_B95_B64(x) \
(((x) & BIT_MASK_WMAC_SWAES_DIO_B95_B64) \
<< BIT_SHIFT_WMAC_SWAES_DIO_B95_B64)
#define BITS_WMAC_SWAES_DIO_B95_B64 \
(BIT_MASK_WMAC_SWAES_DIO_B95_B64 << BIT_SHIFT_WMAC_SWAES_DIO_B95_B64)
#define BIT_CLEAR_WMAC_SWAES_DIO_B95_B64(x) \
((x) & (~BITS_WMAC_SWAES_DIO_B95_B64))
#define BIT_GET_WMAC_SWAES_DIO_B95_B64(x) \
(((x) >> BIT_SHIFT_WMAC_SWAES_DIO_B95_B64) & \
BIT_MASK_WMAC_SWAES_DIO_B95_B64)
#define BIT_SET_WMAC_SWAES_DIO_B95_B64(x, v) \
(BIT_CLEAR_WMAC_SWAES_DIO_B95_B64(x) | BIT_WMAC_SWAES_DIO_B95_B64(v))
/* 2 REG_WMAC_SWAES_DIO_B127_B96 (Offset 0x075C) */
#define BIT_SHIFT_WMAC_SWAES_DIO_B127_B96 0
#define BIT_MASK_WMAC_SWAES_DIO_B127_B96 0xffffffffL
#define BIT_WMAC_SWAES_DIO_B127_B96(x) \
(((x) & BIT_MASK_WMAC_SWAES_DIO_B127_B96) \
<< BIT_SHIFT_WMAC_SWAES_DIO_B127_B96)
#define BITS_WMAC_SWAES_DIO_B127_B96 \
(BIT_MASK_WMAC_SWAES_DIO_B127_B96 << BIT_SHIFT_WMAC_SWAES_DIO_B127_B96)
#define BIT_CLEAR_WMAC_SWAES_DIO_B127_B96(x) \
((x) & (~BITS_WMAC_SWAES_DIO_B127_B96))
#define BIT_GET_WMAC_SWAES_DIO_B127_B96(x) \
(((x) >> BIT_SHIFT_WMAC_SWAES_DIO_B127_B96) & \
BIT_MASK_WMAC_SWAES_DIO_B127_B96)
#define BIT_SET_WMAC_SWAES_DIO_B127_B96(x, v) \
(BIT_CLEAR_WMAC_SWAES_DIO_B127_B96(x) | BIT_WMAC_SWAES_DIO_B127_B96(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_WMAC_SWAES_CFG (Offset 0x0760) */
#define BIT_SWAES_REQ BIT(7)
#define BIT_CLR_SWAES_REQ BIT(6)
#define BIT_R_WMAC_SWAES_WE BIT(3)
#define BIT_R_WMAC_SWAES_SEL BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_COEX_V2 (Offset 0x0762) */
#define BIT_GNT_BT_POLARITY BIT(12)
#define BIT_GNT_BT_BYPASS_PRIORITY BIT(8)
#define BIT_SHIFT_TIMER 0
#define BIT_MASK_TIMER 0xff
#define BIT_TIMER(x) (((x) & BIT_MASK_TIMER) << BIT_SHIFT_TIMER)
#define BITS_TIMER (BIT_MASK_TIMER << BIT_SHIFT_TIMER)
#define BIT_CLEAR_TIMER(x) ((x) & (~BITS_TIMER))
#define BIT_GET_TIMER(x) (((x) >> BIT_SHIFT_TIMER) & BIT_MASK_TIMER)
#define BIT_SET_TIMER(x, v) (BIT_CLEAR_TIMER(x) | BIT_TIMER(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_COEX (Offset 0x0764) */
#define BIT_R_GNT_BT_RFC_SW BIT(12)
#define BIT_R_GNT_BT_RFC_SW_EN BIT(11)
#define BIT_R_GNT_BT_BB_SW BIT(10)
#define BIT_R_GNT_BT_BB_SW_EN BIT(9)
#define BIT_R_BT_CNT_THREN BIT(8)
#define BIT_SHIFT_R_BT_CNT_THR 0
#define BIT_MASK_R_BT_CNT_THR 0xff
#define BIT_R_BT_CNT_THR(x) \
(((x) & BIT_MASK_R_BT_CNT_THR) << BIT_SHIFT_R_BT_CNT_THR)
#define BITS_R_BT_CNT_THR (BIT_MASK_R_BT_CNT_THR << BIT_SHIFT_R_BT_CNT_THR)
#define BIT_CLEAR_R_BT_CNT_THR(x) ((x) & (~BITS_R_BT_CNT_THR))
#define BIT_GET_R_BT_CNT_THR(x) \
(((x) >> BIT_SHIFT_R_BT_CNT_THR) & BIT_MASK_R_BT_CNT_THR)
#define BIT_SET_R_BT_CNT_THR(x, v) \
(BIT_CLEAR_R_BT_CNT_THR(x) | BIT_R_BT_CNT_THR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WLAN_ACT_MASK_CTRL (Offset 0x0768) */
#define BIT_WLRX_TER_BY_CTL BIT(43)
#define BIT_WLRX_TER_BY_AD BIT(42)
#define BIT_ANT_DIVERSITY_SEL BIT(41)
#define BIT_ANTSEL_FOR_BT_CTRL_EN BIT(40)
#define BIT_WLACT_LOW_GNTWL_EN BIT(34)
#define BIT_WLACT_HIGH_GNTBT_EN BIT(33)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_WLAN_ACT_MASK_CTRL (Offset 0x0768) */
#define BIT_NAV_UPPER_V1 BIT(32)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WLAN_ACT_MASK_CTRL (Offset 0x0768) */
#define BIT_SHIFT_RXMYRTS_NAV_V1 8
#define BIT_MASK_RXMYRTS_NAV_V1 0xff
#define BIT_RXMYRTS_NAV_V1(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_V1) << BIT_SHIFT_RXMYRTS_NAV_V1)
#define BITS_RXMYRTS_NAV_V1 \
(BIT_MASK_RXMYRTS_NAV_V1 << BIT_SHIFT_RXMYRTS_NAV_V1)
#define BIT_CLEAR_RXMYRTS_NAV_V1(x) ((x) & (~BITS_RXMYRTS_NAV_V1))
#define BIT_GET_RXMYRTS_NAV_V1(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_V1) & BIT_MASK_RXMYRTS_NAV_V1)
#define BIT_SET_RXMYRTS_NAV_V1(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_V1(x) | BIT_RXMYRTS_NAV_V1(v))
#define BIT_SHIFT_RTSRST_V1 0
#define BIT_MASK_RTSRST_V1 0xff
#define BIT_RTSRST_V1(x) (((x) & BIT_MASK_RTSRST_V1) << BIT_SHIFT_RTSRST_V1)
#define BITS_RTSRST_V1 (BIT_MASK_RTSRST_V1 << BIT_SHIFT_RTSRST_V1)
#define BIT_CLEAR_RTSRST_V1(x) ((x) & (~BITS_RTSRST_V1))
#define BIT_GET_RTSRST_V1(x) (((x) >> BIT_SHIFT_RTSRST_V1) & BIT_MASK_RTSRST_V1)
#define BIT_SET_RTSRST_V1(x, v) (BIT_CLEAR_RTSRST_V1(x) | BIT_RTSRST_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WLAN_ACT_MASK_CTRL_1 (Offset 0x076C) */
#define BIT_WLRX_TER_BY_CTL_1 BIT(11)
#define BIT_WLRX_TER_BY_AD_1 BIT(10)
#define BIT_ANT_DIVERSITY_SEL_1 BIT(9)
#define BIT_ANTSEL_FOR_BT_CTRL_EN_1 BIT(8)
#define BIT_WLACT_LOW_GNTWL_EN_1 BIT(2)
#define BIT_WLACT_HIGH_GNTBT_EN_1 BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WLAN_ACT_MASK_CTRL_1 (Offset 0x076C) */
#define BIT_NAV_UPPER_1_V1 BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_COEX_ENHANCED_INTR_CTRL (Offset 0x076E) */
#define BIT_SHIFT_BT_STAT_DELAY 12
#define BIT_MASK_BT_STAT_DELAY 0xf
#define BIT_BT_STAT_DELAY(x) \
(((x) & BIT_MASK_BT_STAT_DELAY) << BIT_SHIFT_BT_STAT_DELAY)
#define BITS_BT_STAT_DELAY (BIT_MASK_BT_STAT_DELAY << BIT_SHIFT_BT_STAT_DELAY)
#define BIT_CLEAR_BT_STAT_DELAY(x) ((x) & (~BITS_BT_STAT_DELAY))
#define BIT_GET_BT_STAT_DELAY(x) \
(((x) >> BIT_SHIFT_BT_STAT_DELAY) & BIT_MASK_BT_STAT_DELAY)
#define BIT_SET_BT_STAT_DELAY(x, v) \
(BIT_CLEAR_BT_STAT_DELAY(x) | BIT_BT_STAT_DELAY(v))
#define BIT_SHIFT_BT_TRX_INIT_DETECT 8
#define BIT_MASK_BT_TRX_INIT_DETECT 0xf
#define BIT_BT_TRX_INIT_DETECT(x) \
(((x) & BIT_MASK_BT_TRX_INIT_DETECT) << BIT_SHIFT_BT_TRX_INIT_DETECT)
#define BITS_BT_TRX_INIT_DETECT \
(BIT_MASK_BT_TRX_INIT_DETECT << BIT_SHIFT_BT_TRX_INIT_DETECT)
#define BIT_CLEAR_BT_TRX_INIT_DETECT(x) ((x) & (~BITS_BT_TRX_INIT_DETECT))
#define BIT_GET_BT_TRX_INIT_DETECT(x) \
(((x) >> BIT_SHIFT_BT_TRX_INIT_DETECT) & BIT_MASK_BT_TRX_INIT_DETECT)
#define BIT_SET_BT_TRX_INIT_DETECT(x, v) \
(BIT_CLEAR_BT_TRX_INIT_DETECT(x) | BIT_BT_TRX_INIT_DETECT(v))
#define BIT_SHIFT_BT_PRI_DETECT_TO 4
#define BIT_MASK_BT_PRI_DETECT_TO 0xf
#define BIT_BT_PRI_DETECT_TO(x) \
(((x) & BIT_MASK_BT_PRI_DETECT_TO) << BIT_SHIFT_BT_PRI_DETECT_TO)
#define BITS_BT_PRI_DETECT_TO \
(BIT_MASK_BT_PRI_DETECT_TO << BIT_SHIFT_BT_PRI_DETECT_TO)
#define BIT_CLEAR_BT_PRI_DETECT_TO(x) ((x) & (~BITS_BT_PRI_DETECT_TO))
#define BIT_GET_BT_PRI_DETECT_TO(x) \
(((x) >> BIT_SHIFT_BT_PRI_DETECT_TO) & BIT_MASK_BT_PRI_DETECT_TO)
#define BIT_SET_BT_PRI_DETECT_TO(x, v) \
(BIT_CLEAR_BT_PRI_DETECT_TO(x) | BIT_BT_PRI_DETECT_TO(v))
#define BIT_R_GRANTALL_WLMASK BIT(3)
#define BIT_STATIS_BT_EN BIT(2)
#define BIT_WL_ACT_MASK_ENABLE BIT(1)
#define BIT_ENHANCED_BT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BT_ACT_STATISTICS (Offset 0x0770) */
#define BIT_SHIFT_STATIS_BT_LO_RX (48 & CPU_OPT_WIDTH)
#define BIT_MASK_STATIS_BT_LO_RX 0xffff
#define BIT_STATIS_BT_LO_RX(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX) << BIT_SHIFT_STATIS_BT_LO_RX)
#define BITS_STATIS_BT_LO_RX \
(BIT_MASK_STATIS_BT_LO_RX << BIT_SHIFT_STATIS_BT_LO_RX)
#define BIT_CLEAR_STATIS_BT_LO_RX(x) ((x) & (~BITS_STATIS_BT_LO_RX))
#define BIT_GET_STATIS_BT_LO_RX(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX) & BIT_MASK_STATIS_BT_LO_RX)
#define BIT_SET_STATIS_BT_LO_RX(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX(x) | BIT_STATIS_BT_LO_RX(v))
#define BIT_SHIFT_STATIS_BT_LO_TX (32 & CPU_OPT_WIDTH)
#define BIT_MASK_STATIS_BT_LO_TX 0xffff
#define BIT_STATIS_BT_LO_TX(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX) << BIT_SHIFT_STATIS_BT_LO_TX)
#define BITS_STATIS_BT_LO_TX \
(BIT_MASK_STATIS_BT_LO_TX << BIT_SHIFT_STATIS_BT_LO_TX)
#define BIT_CLEAR_STATIS_BT_LO_TX(x) ((x) & (~BITS_STATIS_BT_LO_TX))
#define BIT_GET_STATIS_BT_LO_TX(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX) & BIT_MASK_STATIS_BT_LO_TX)
#define BIT_SET_STATIS_BT_LO_TX(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX(x) | BIT_STATIS_BT_LO_TX(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ACT_STATISTICS (Offset 0x0770) */
#define BIT_SHIFT_STATIS_BT_HI_RX 16
#define BIT_MASK_STATIS_BT_HI_RX 0xffff
#define BIT_STATIS_BT_HI_RX(x) \
(((x) & BIT_MASK_STATIS_BT_HI_RX) << BIT_SHIFT_STATIS_BT_HI_RX)
#define BITS_STATIS_BT_HI_RX \
(BIT_MASK_STATIS_BT_HI_RX << BIT_SHIFT_STATIS_BT_HI_RX)
#define BIT_CLEAR_STATIS_BT_HI_RX(x) ((x) & (~BITS_STATIS_BT_HI_RX))
#define BIT_GET_STATIS_BT_HI_RX(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_RX) & BIT_MASK_STATIS_BT_HI_RX)
#define BIT_SET_STATIS_BT_HI_RX(x, v) \
(BIT_CLEAR_STATIS_BT_HI_RX(x) | BIT_STATIS_BT_HI_RX(v))
#define BIT_SHIFT_STATIS_BT_HI_TX 0
#define BIT_MASK_STATIS_BT_HI_TX 0xffff
#define BIT_STATIS_BT_HI_TX(x) \
(((x) & BIT_MASK_STATIS_BT_HI_TX) << BIT_SHIFT_STATIS_BT_HI_TX)
#define BITS_STATIS_BT_HI_TX \
(BIT_MASK_STATIS_BT_HI_TX << BIT_SHIFT_STATIS_BT_HI_TX)
#define BIT_CLEAR_STATIS_BT_HI_TX(x) ((x) & (~BITS_STATIS_BT_HI_TX))
#define BIT_GET_STATIS_BT_HI_TX(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_TX) & BIT_MASK_STATIS_BT_HI_TX)
#define BIT_SET_STATIS_BT_HI_TX(x, v) \
(BIT_CLEAR_STATIS_BT_HI_TX(x) | BIT_STATIS_BT_HI_TX(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ACT_STATISTICS_1 (Offset 0x0774) */
#define BIT_APPEND_MACID_IN_RESP_EN_1 BIT(18)
#define BIT_ADDR2_MATCH_EN_1 BIT(17)
#define BIT_SHIFT_STATIS_BT_LO_RX_1 16
#define BIT_MASK_STATIS_BT_LO_RX_1 0xffff
#define BIT_STATIS_BT_LO_RX_1(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX_1) << BIT_SHIFT_STATIS_BT_LO_RX_1)
#define BITS_STATIS_BT_LO_RX_1 \
(BIT_MASK_STATIS_BT_LO_RX_1 << BIT_SHIFT_STATIS_BT_LO_RX_1)
#define BIT_CLEAR_STATIS_BT_LO_RX_1(x) ((x) & (~BITS_STATIS_BT_LO_RX_1))
#define BIT_GET_STATIS_BT_LO_RX_1(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX_1) & BIT_MASK_STATIS_BT_LO_RX_1)
#define BIT_SET_STATIS_BT_LO_RX_1(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX_1(x) | BIT_STATIS_BT_LO_RX_1(v))
#define BIT_ANTTRN_EN_1 BIT(16)
#define BIT_SHIFT_STATIS_BT_LO_TX_1 0
#define BIT_MASK_STATIS_BT_LO_TX_1 0xffff
#define BIT_STATIS_BT_LO_TX_1(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX_1) << BIT_SHIFT_STATIS_BT_LO_TX_1)
#define BITS_STATIS_BT_LO_TX_1 \
(BIT_MASK_STATIS_BT_LO_TX_1 << BIT_SHIFT_STATIS_BT_LO_TX_1)
#define BIT_CLEAR_STATIS_BT_LO_TX_1(x) ((x) & (~BITS_STATIS_BT_LO_TX_1))
#define BIT_GET_STATIS_BT_LO_TX_1(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX_1) & BIT_MASK_STATIS_BT_LO_TX_1)
#define BIT_SET_STATIS_BT_LO_TX_1(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX_1(x) | BIT_STATIS_BT_LO_TX_1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_STATISTICS_CONTROL_REGISTER (Offset 0x0778) */
#define BIT_SHIFT_R_BT_CMD_RPT 16
#define BIT_MASK_R_BT_CMD_RPT 0xffff
#define BIT_R_BT_CMD_RPT(x) \
(((x) & BIT_MASK_R_BT_CMD_RPT) << BIT_SHIFT_R_BT_CMD_RPT)
#define BITS_R_BT_CMD_RPT (BIT_MASK_R_BT_CMD_RPT << BIT_SHIFT_R_BT_CMD_RPT)
#define BIT_CLEAR_R_BT_CMD_RPT(x) ((x) & (~BITS_R_BT_CMD_RPT))
#define BIT_GET_R_BT_CMD_RPT(x) \
(((x) >> BIT_SHIFT_R_BT_CMD_RPT) & BIT_MASK_R_BT_CMD_RPT)
#define BIT_SET_R_BT_CMD_RPT(x, v) \
(BIT_CLEAR_R_BT_CMD_RPT(x) | BIT_R_BT_CMD_RPT(v))
#define BIT_SHIFT_R_RPT_FROM_BT 8
#define BIT_MASK_R_RPT_FROM_BT 0xff
#define BIT_R_RPT_FROM_BT(x) \
(((x) & BIT_MASK_R_RPT_FROM_BT) << BIT_SHIFT_R_RPT_FROM_BT)
#define BITS_R_RPT_FROM_BT (BIT_MASK_R_RPT_FROM_BT << BIT_SHIFT_R_RPT_FROM_BT)
#define BIT_CLEAR_R_RPT_FROM_BT(x) ((x) & (~BITS_R_RPT_FROM_BT))
#define BIT_GET_R_RPT_FROM_BT(x) \
(((x) >> BIT_SHIFT_R_RPT_FROM_BT) & BIT_MASK_R_RPT_FROM_BT)
#define BIT_SET_R_RPT_FROM_BT(x, v) \
(BIT_CLEAR_R_RPT_FROM_BT(x) | BIT_R_RPT_FROM_BT(v))
#define BIT_SHIFT_BT_HID_ISR_SET 6
#define BIT_MASK_BT_HID_ISR_SET 0x3
#define BIT_BT_HID_ISR_SET(x) \
(((x) & BIT_MASK_BT_HID_ISR_SET) << BIT_SHIFT_BT_HID_ISR_SET)
#define BITS_BT_HID_ISR_SET \
(BIT_MASK_BT_HID_ISR_SET << BIT_SHIFT_BT_HID_ISR_SET)
#define BIT_CLEAR_BT_HID_ISR_SET(x) ((x) & (~BITS_BT_HID_ISR_SET))
#define BIT_GET_BT_HID_ISR_SET(x) \
(((x) >> BIT_SHIFT_BT_HID_ISR_SET) & BIT_MASK_BT_HID_ISR_SET)
#define BIT_SET_BT_HID_ISR_SET(x, v) \
(BIT_CLEAR_BT_HID_ISR_SET(x) | BIT_BT_HID_ISR_SET(v))
#define BIT_TDMA_BT_START_NOTIFY BIT(5)
#define BIT_ENABLE_TDMA_FW_MODE BIT(4)
#define BIT_ENABLE_PTA_TDMA_MODE BIT(3)
#define BIT_ENABLE_COEXIST_TAB_IN_TDMA BIT(2)
#define BIT_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA BIT(1)
#define BIT_RTK_BT_ENABLE BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_STATUS_REPORT_REGISTER (Offset 0x077C) */
#define BIT_SHIFT_BT_PROFILE 24
#define BIT_MASK_BT_PROFILE 0xff
#define BIT_BT_PROFILE(x) (((x) & BIT_MASK_BT_PROFILE) << BIT_SHIFT_BT_PROFILE)
#define BITS_BT_PROFILE (BIT_MASK_BT_PROFILE << BIT_SHIFT_BT_PROFILE)
#define BIT_CLEAR_BT_PROFILE(x) ((x) & (~BITS_BT_PROFILE))
#define BIT_GET_BT_PROFILE(x) \
(((x) >> BIT_SHIFT_BT_PROFILE) & BIT_MASK_BT_PROFILE)
#define BIT_SET_BT_PROFILE(x, v) (BIT_CLEAR_BT_PROFILE(x) | BIT_BT_PROFILE(v))
#define BIT_SHIFT_BT_POWER 16
#define BIT_MASK_BT_POWER 0xff
#define BIT_BT_POWER(x) (((x) & BIT_MASK_BT_POWER) << BIT_SHIFT_BT_POWER)
#define BITS_BT_POWER (BIT_MASK_BT_POWER << BIT_SHIFT_BT_POWER)
#define BIT_CLEAR_BT_POWER(x) ((x) & (~BITS_BT_POWER))
#define BIT_GET_BT_POWER(x) (((x) >> BIT_SHIFT_BT_POWER) & BIT_MASK_BT_POWER)
#define BIT_SET_BT_POWER(x, v) (BIT_CLEAR_BT_POWER(x) | BIT_BT_POWER(v))
#define BIT_SHIFT_BT_PREDECT_STATUS 8
#define BIT_MASK_BT_PREDECT_STATUS 0xff
#define BIT_BT_PREDECT_STATUS(x) \
(((x) & BIT_MASK_BT_PREDECT_STATUS) << BIT_SHIFT_BT_PREDECT_STATUS)
#define BITS_BT_PREDECT_STATUS \
(BIT_MASK_BT_PREDECT_STATUS << BIT_SHIFT_BT_PREDECT_STATUS)
#define BIT_CLEAR_BT_PREDECT_STATUS(x) ((x) & (~BITS_BT_PREDECT_STATUS))
#define BIT_GET_BT_PREDECT_STATUS(x) \
(((x) >> BIT_SHIFT_BT_PREDECT_STATUS) & BIT_MASK_BT_PREDECT_STATUS)
#define BIT_SET_BT_PREDECT_STATUS(x, v) \
(BIT_CLEAR_BT_PREDECT_STATUS(x) | BIT_BT_PREDECT_STATUS(v))
#define BIT_SHIFT_BT_CMD_INFO 0
#define BIT_MASK_BT_CMD_INFO 0xff
#define BIT_BT_CMD_INFO(x) \
(((x) & BIT_MASK_BT_CMD_INFO) << BIT_SHIFT_BT_CMD_INFO)
#define BITS_BT_CMD_INFO (BIT_MASK_BT_CMD_INFO << BIT_SHIFT_BT_CMD_INFO)
#define BIT_CLEAR_BT_CMD_INFO(x) ((x) & (~BITS_BT_CMD_INFO))
#define BIT_GET_BT_CMD_INFO(x) \
(((x) >> BIT_SHIFT_BT_CMD_INFO) & BIT_MASK_BT_CMD_INFO)
#define BIT_SET_BT_CMD_INFO(x, v) \
(BIT_CLEAR_BT_CMD_INFO(x) | BIT_BT_CMD_INFO(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_INTERRUPT_CONTROL_REGISTER (Offset 0x0780) */
#define BIT_EN_MAC_NULL_PKT_NOTIFY BIT(31)
#define BIT_EN_WLAN_RPT_AND_BT_QUERY BIT(30)
#define BIT_EN_BT_STSTUS_RPT BIT(29)
#define BIT_EN_BT_POWER BIT(28)
#define BIT_EN_BT_CHANNEL BIT(27)
#define BIT_EN_BT_SLOT_CHANGE BIT(26)
#define BIT_EN_BT_PROFILE_OR_HID BIT(25)
#define BIT_WLAN_RPT_NOTIFY BIT(24)
#define BIT_SHIFT_WLAN_RPT_DATA 16
#define BIT_MASK_WLAN_RPT_DATA 0xff
#define BIT_WLAN_RPT_DATA(x) \
(((x) & BIT_MASK_WLAN_RPT_DATA) << BIT_SHIFT_WLAN_RPT_DATA)
#define BITS_WLAN_RPT_DATA (BIT_MASK_WLAN_RPT_DATA << BIT_SHIFT_WLAN_RPT_DATA)
#define BIT_CLEAR_WLAN_RPT_DATA(x) ((x) & (~BITS_WLAN_RPT_DATA))
#define BIT_GET_WLAN_RPT_DATA(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_DATA) & BIT_MASK_WLAN_RPT_DATA)
#define BIT_SET_WLAN_RPT_DATA(x, v) \
(BIT_CLEAR_WLAN_RPT_DATA(x) | BIT_WLAN_RPT_DATA(v))
#define BIT_SHIFT_CMD_ID 8
#define BIT_MASK_CMD_ID 0xff
#define BIT_CMD_ID(x) (((x) & BIT_MASK_CMD_ID) << BIT_SHIFT_CMD_ID)
#define BITS_CMD_ID (BIT_MASK_CMD_ID << BIT_SHIFT_CMD_ID)
#define BIT_CLEAR_CMD_ID(x) ((x) & (~BITS_CMD_ID))
#define BIT_GET_CMD_ID(x) (((x) >> BIT_SHIFT_CMD_ID) & BIT_MASK_CMD_ID)
#define BIT_SET_CMD_ID(x, v) (BIT_CLEAR_CMD_ID(x) | BIT_CMD_ID(v))
#define BIT_SHIFT_BT_DATA 0
#define BIT_MASK_BT_DATA 0xff
#define BIT_BT_DATA(x) (((x) & BIT_MASK_BT_DATA) << BIT_SHIFT_BT_DATA)
#define BITS_BT_DATA (BIT_MASK_BT_DATA << BIT_SHIFT_BT_DATA)
#define BIT_CLEAR_BT_DATA(x) ((x) & (~BITS_BT_DATA))
#define BIT_GET_BT_DATA(x) (((x) >> BIT_SHIFT_BT_DATA) & BIT_MASK_BT_DATA)
#define BIT_SET_BT_DATA(x, v) (BIT_CLEAR_BT_DATA(x) | BIT_BT_DATA(v))
/* 2 REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER (Offset 0x0784) */
#define BIT_SHIFT_WLAN_RPT_TO 0
#define BIT_MASK_WLAN_RPT_TO 0xff
#define BIT_WLAN_RPT_TO(x) \
(((x) & BIT_MASK_WLAN_RPT_TO) << BIT_SHIFT_WLAN_RPT_TO)
#define BITS_WLAN_RPT_TO (BIT_MASK_WLAN_RPT_TO << BIT_SHIFT_WLAN_RPT_TO)
#define BIT_CLEAR_WLAN_RPT_TO(x) ((x) & (~BITS_WLAN_RPT_TO))
#define BIT_GET_WLAN_RPT_TO(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_TO) & BIT_MASK_WLAN_RPT_TO)
#define BIT_SET_WLAN_RPT_TO(x, v) \
(BIT_CLEAR_WLAN_RPT_TO(x) | BIT_WLAN_RPT_TO(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER (Offset 0x0785) */
#define BIT_SHIFT_ISOLATION_CHK_0 1
#define BIT_MASK_ISOLATION_CHK_0 0x7fffff
#define BIT_ISOLATION_CHK_0(x) \
(((x) & BIT_MASK_ISOLATION_CHK_0) << BIT_SHIFT_ISOLATION_CHK_0)
#define BITS_ISOLATION_CHK_0 \
(BIT_MASK_ISOLATION_CHK_0 << BIT_SHIFT_ISOLATION_CHK_0)
#define BIT_CLEAR_ISOLATION_CHK_0(x) ((x) & (~BITS_ISOLATION_CHK_0))
#define BIT_GET_ISOLATION_CHK_0(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_0) & BIT_MASK_ISOLATION_CHK_0)
#define BIT_SET_ISOLATION_CHK_0(x, v) \
(BIT_CLEAR_ISOLATION_CHK_0(x) | BIT_ISOLATION_CHK_0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER (Offset 0x0785) */
#define BIT_SHIFT_ISOLATION_CHK 1
#define BIT_MASK_ISOLATION_CHK 0x7fffffffffffffffffffL
#define BIT_ISOLATION_CHK(x) \
(((x) & BIT_MASK_ISOLATION_CHK) << BIT_SHIFT_ISOLATION_CHK)
#define BITS_ISOLATION_CHK (BIT_MASK_ISOLATION_CHK << BIT_SHIFT_ISOLATION_CHK)
#define BIT_CLEAR_ISOLATION_CHK(x) ((x) & (~BITS_ISOLATION_CHK))
#define BIT_GET_ISOLATION_CHK(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK) & BIT_MASK_ISOLATION_CHK)
#define BIT_SET_ISOLATION_CHK(x, v) \
(BIT_CLEAR_ISOLATION_CHK(x) | BIT_ISOLATION_CHK(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER (Offset 0x0785) */
#define BIT_ISOLATION_EN BIT(0)
#define BIT_SHIFT_R_CCK_LEN 0
#define BIT_MASK_R_CCK_LEN 0xffff
#define BIT_R_CCK_LEN(x) (((x) & BIT_MASK_R_CCK_LEN) << BIT_SHIFT_R_CCK_LEN)
#define BITS_R_CCK_LEN (BIT_MASK_R_CCK_LEN << BIT_SHIFT_R_CCK_LEN)
#define BIT_CLEAR_R_CCK_LEN(x) ((x) & (~BITS_R_CCK_LEN))
#define BIT_GET_R_CCK_LEN(x) (((x) >> BIT_SHIFT_R_CCK_LEN) & BIT_MASK_R_CCK_LEN)
#define BIT_SET_R_CCK_LEN(x, v) (BIT_CLEAR_R_CCK_LEN(x) | BIT_R_CCK_LEN(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1 (Offset 0x0788) */
#define BIT_SHIFT_ISOLATION_CHK_1 0
#define BIT_MASK_ISOLATION_CHK_1 0xffffffffL
#define BIT_ISOLATION_CHK_1(x) \
(((x) & BIT_MASK_ISOLATION_CHK_1) << BIT_SHIFT_ISOLATION_CHK_1)
#define BITS_ISOLATION_CHK_1 \
(BIT_MASK_ISOLATION_CHK_1 << BIT_SHIFT_ISOLATION_CHK_1)
#define BIT_CLEAR_ISOLATION_CHK_1(x) ((x) & (~BITS_ISOLATION_CHK_1))
#define BIT_GET_ISOLATION_CHK_1(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_1) & BIT_MASK_ISOLATION_CHK_1)
#define BIT_SET_ISOLATION_CHK_1(x, v) \
(BIT_CLEAR_ISOLATION_CHK_1(x) | BIT_ISOLATION_CHK_1(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2 (Offset 0x078C) */
#define BIT_SHIFT_ISOLATION_CHK_2 0
#define BIT_MASK_ISOLATION_CHK_2 0xffffff
#define BIT_ISOLATION_CHK_2(x) \
(((x) & BIT_MASK_ISOLATION_CHK_2) << BIT_SHIFT_ISOLATION_CHK_2)
#define BITS_ISOLATION_CHK_2 \
(BIT_MASK_ISOLATION_CHK_2 << BIT_SHIFT_ISOLATION_CHK_2)
#define BIT_CLEAR_ISOLATION_CHK_2(x) ((x) & (~BITS_ISOLATION_CHK_2))
#define BIT_GET_ISOLATION_CHK_2(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_2) & BIT_MASK_ISOLATION_CHK_2)
#define BIT_SET_ISOLATION_CHK_2(x, v) \
(BIT_CLEAR_ISOLATION_CHK_2(x) | BIT_ISOLATION_CHK_2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_INTERRUPT_STATUS_REGISTER (Offset 0x078F) */
#define BIT_BT_HID_ISR BIT(7)
#define BIT_BT_QUERY_ISR BIT(6)
#define BIT_MAC_NULL_PKT_NOTIFY_ISR BIT(5)
#define BIT_WLAN_RPT_ISR BIT(4)
#define BIT_BT_POWER_ISR BIT(3)
#define BIT_BT_CHANNEL_ISR BIT(2)
#define BIT_BT_SLOT_CHANGE_ISR BIT(1)
#define BIT_BT_PROFILE_ISR BIT(0)
/* 2 REG_BT_TDMA_TIME_REGISTER (Offset 0x0790) */
#define BIT_SHIFT_BT_TIME 6
#define BIT_MASK_BT_TIME 0x3ffffff
#define BIT_BT_TIME(x) (((x) & BIT_MASK_BT_TIME) << BIT_SHIFT_BT_TIME)
#define BITS_BT_TIME (BIT_MASK_BT_TIME << BIT_SHIFT_BT_TIME)
#define BIT_CLEAR_BT_TIME(x) ((x) & (~BITS_BT_TIME))
#define BIT_GET_BT_TIME(x) (((x) >> BIT_SHIFT_BT_TIME) & BIT_MASK_BT_TIME)
#define BIT_SET_BT_TIME(x, v) (BIT_CLEAR_BT_TIME(x) | BIT_BT_TIME(v))
#define BIT_SHIFT_BT_RPT_SAMPLE_RATE 0
#define BIT_MASK_BT_RPT_SAMPLE_RATE 0x3f
#define BIT_BT_RPT_SAMPLE_RATE(x) \
(((x) & BIT_MASK_BT_RPT_SAMPLE_RATE) << BIT_SHIFT_BT_RPT_SAMPLE_RATE)
#define BITS_BT_RPT_SAMPLE_RATE \
(BIT_MASK_BT_RPT_SAMPLE_RATE << BIT_SHIFT_BT_RPT_SAMPLE_RATE)
#define BIT_CLEAR_BT_RPT_SAMPLE_RATE(x) ((x) & (~BITS_BT_RPT_SAMPLE_RATE))
#define BIT_GET_BT_RPT_SAMPLE_RATE(x) \
(((x) >> BIT_SHIFT_BT_RPT_SAMPLE_RATE) & BIT_MASK_BT_RPT_SAMPLE_RATE)
#define BIT_SET_BT_RPT_SAMPLE_RATE(x, v) \
(BIT_CLEAR_BT_RPT_SAMPLE_RATE(x) | BIT_BT_RPT_SAMPLE_RATE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_BT_ACT_REGISTER (Offset 0x0794) */
#define BIT_SHIFT_R_OFDM_LEN 26
#define BIT_MASK_R_OFDM_LEN 0x3f
#define BIT_R_OFDM_LEN(x) (((x) & BIT_MASK_R_OFDM_LEN) << BIT_SHIFT_R_OFDM_LEN)
#define BITS_R_OFDM_LEN (BIT_MASK_R_OFDM_LEN << BIT_SHIFT_R_OFDM_LEN)
#define BIT_CLEAR_R_OFDM_LEN(x) ((x) & (~BITS_R_OFDM_LEN))
#define BIT_GET_R_OFDM_LEN(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN) & BIT_MASK_R_OFDM_LEN)
#define BIT_SET_R_OFDM_LEN(x, v) (BIT_CLEAR_R_OFDM_LEN(x) | BIT_R_OFDM_LEN(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ACT_REGISTER (Offset 0x0794) */
#define BIT_SHIFT_BT_EISR_EN 16
#define BIT_MASK_BT_EISR_EN 0xff
#define BIT_BT_EISR_EN(x) (((x) & BIT_MASK_BT_EISR_EN) << BIT_SHIFT_BT_EISR_EN)
#define BITS_BT_EISR_EN (BIT_MASK_BT_EISR_EN << BIT_SHIFT_BT_EISR_EN)
#define BIT_CLEAR_BT_EISR_EN(x) ((x) & (~BITS_BT_EISR_EN))
#define BIT_GET_BT_EISR_EN(x) \
(((x) >> BIT_SHIFT_BT_EISR_EN) & BIT_MASK_BT_EISR_EN)
#define BIT_SET_BT_EISR_EN(x, v) (BIT_CLEAR_BT_EISR_EN(x) | BIT_BT_EISR_EN(v))
#define BIT_BT_ACT_FALLING_ISR BIT(10)
#define BIT_BT_ACT_RISING_ISR BIT(9)
#define BIT_TDMA_TO_ISR BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_BT_ACT_REGISTER (Offset 0x0794) */
#define BIT_SHIFT_BT_CH 0
#define BIT_MASK_BT_CH 0xff
#define BIT_BT_CH(x) (((x) & BIT_MASK_BT_CH) << BIT_SHIFT_BT_CH)
#define BITS_BT_CH (BIT_MASK_BT_CH << BIT_SHIFT_BT_CH)
#define BIT_CLEAR_BT_CH(x) ((x) & (~BITS_BT_CH))
#define BIT_GET_BT_CH(x) (((x) >> BIT_SHIFT_BT_CH) & BIT_MASK_BT_CH)
#define BIT_SET_BT_CH(x, v) (BIT_CLEAR_BT_CH(x) | BIT_BT_CH(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BT_ACT_REGISTER (Offset 0x0794) */
#define BIT_SHIFT_BT_CH_V1 0
#define BIT_MASK_BT_CH_V1 0x7f
#define BIT_BT_CH_V1(x) (((x) & BIT_MASK_BT_CH_V1) << BIT_SHIFT_BT_CH_V1)
#define BITS_BT_CH_V1 (BIT_MASK_BT_CH_V1 << BIT_SHIFT_BT_CH_V1)
#define BIT_CLEAR_BT_CH_V1(x) ((x) & (~BITS_BT_CH_V1))
#define BIT_GET_BT_CH_V1(x) (((x) >> BIT_SHIFT_BT_CH_V1) & BIT_MASK_BT_CH_V1)
#define BIT_SET_BT_CH_V1(x, v) (BIT_CLEAR_BT_CH_V1(x) | BIT_BT_CH_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_OBFF_CTRL_BASIC (Offset 0x0798) */
#define BIT_OBFF_EN_V1 BIT(31)
#define BIT_SHIFT_OBFF_STATE_V1 28
#define BIT_MASK_OBFF_STATE_V1 0x3
#define BIT_OBFF_STATE_V1(x) \
(((x) & BIT_MASK_OBFF_STATE_V1) << BIT_SHIFT_OBFF_STATE_V1)
#define BITS_OBFF_STATE_V1 (BIT_MASK_OBFF_STATE_V1 << BIT_SHIFT_OBFF_STATE_V1)
#define BIT_CLEAR_OBFF_STATE_V1(x) ((x) & (~BITS_OBFF_STATE_V1))
#define BIT_GET_OBFF_STATE_V1(x) \
(((x) >> BIT_SHIFT_OBFF_STATE_V1) & BIT_MASK_OBFF_STATE_V1)
#define BIT_SET_OBFF_STATE_V1(x, v) \
(BIT_CLEAR_OBFF_STATE_V1(x) | BIT_OBFF_STATE_V1(v))
#define BIT_OBFF_ACT_RXDMA_EN BIT(27)
#define BIT_OBFF_BLOCK_INT_EN BIT(26)
#define BIT_OBFF_AUTOACT_EN BIT(25)
#define BIT_OBFF_AUTOIDLE_EN BIT(24)
#define BIT_SHIFT_WAKE_MAX_PLS 20
#define BIT_MASK_WAKE_MAX_PLS 0x7
#define BIT_WAKE_MAX_PLS(x) \
(((x) & BIT_MASK_WAKE_MAX_PLS) << BIT_SHIFT_WAKE_MAX_PLS)
#define BITS_WAKE_MAX_PLS (BIT_MASK_WAKE_MAX_PLS << BIT_SHIFT_WAKE_MAX_PLS)
#define BIT_CLEAR_WAKE_MAX_PLS(x) ((x) & (~BITS_WAKE_MAX_PLS))
#define BIT_GET_WAKE_MAX_PLS(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_PLS) & BIT_MASK_WAKE_MAX_PLS)
#define BIT_SET_WAKE_MAX_PLS(x, v) \
(BIT_CLEAR_WAKE_MAX_PLS(x) | BIT_WAKE_MAX_PLS(v))
#define BIT_SHIFT_WAKE_MIN_PLS 16
#define BIT_MASK_WAKE_MIN_PLS 0x7
#define BIT_WAKE_MIN_PLS(x) \
(((x) & BIT_MASK_WAKE_MIN_PLS) << BIT_SHIFT_WAKE_MIN_PLS)
#define BITS_WAKE_MIN_PLS (BIT_MASK_WAKE_MIN_PLS << BIT_SHIFT_WAKE_MIN_PLS)
#define BIT_CLEAR_WAKE_MIN_PLS(x) ((x) & (~BITS_WAKE_MIN_PLS))
#define BIT_GET_WAKE_MIN_PLS(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_PLS) & BIT_MASK_WAKE_MIN_PLS)
#define BIT_SET_WAKE_MIN_PLS(x, v) \
(BIT_CLEAR_WAKE_MIN_PLS(x) | BIT_WAKE_MIN_PLS(v))
#define BIT_SHIFT_WAKE_MAX_F2F 12
#define BIT_MASK_WAKE_MAX_F2F 0x7
#define BIT_WAKE_MAX_F2F(x) \
(((x) & BIT_MASK_WAKE_MAX_F2F) << BIT_SHIFT_WAKE_MAX_F2F)
#define BITS_WAKE_MAX_F2F (BIT_MASK_WAKE_MAX_F2F << BIT_SHIFT_WAKE_MAX_F2F)
#define BIT_CLEAR_WAKE_MAX_F2F(x) ((x) & (~BITS_WAKE_MAX_F2F))
#define BIT_GET_WAKE_MAX_F2F(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_F2F) & BIT_MASK_WAKE_MAX_F2F)
#define BIT_SET_WAKE_MAX_F2F(x, v) \
(BIT_CLEAR_WAKE_MAX_F2F(x) | BIT_WAKE_MAX_F2F(v))
#define BIT_SHIFT_WAKE_MIN_F2F 8
#define BIT_MASK_WAKE_MIN_F2F 0x7
#define BIT_WAKE_MIN_F2F(x) \
(((x) & BIT_MASK_WAKE_MIN_F2F) << BIT_SHIFT_WAKE_MIN_F2F)
#define BITS_WAKE_MIN_F2F (BIT_MASK_WAKE_MIN_F2F << BIT_SHIFT_WAKE_MIN_F2F)
#define BIT_CLEAR_WAKE_MIN_F2F(x) ((x) & (~BITS_WAKE_MIN_F2F))
#define BIT_GET_WAKE_MIN_F2F(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_F2F) & BIT_MASK_WAKE_MIN_F2F)
#define BIT_SET_WAKE_MIN_F2F(x, v) \
(BIT_CLEAR_WAKE_MIN_F2F(x) | BIT_WAKE_MIN_F2F(v))
#define BIT_APP_CPU_ACT_V1 BIT(3)
#define BIT_APP_OBFF_V1 BIT(2)
#define BIT_APP_IDLE_V1 BIT(1)
#define BIT_APP_INIT_V1 BIT(0)
/* 2 REG_OBFF_CTRL2_TIMER (Offset 0x079C) */
#define BIT_SHIFT_RX_HIGH_TIMER_IDX 24
#define BIT_MASK_RX_HIGH_TIMER_IDX 0x7
#define BIT_RX_HIGH_TIMER_IDX(x) \
(((x) & BIT_MASK_RX_HIGH_TIMER_IDX) << BIT_SHIFT_RX_HIGH_TIMER_IDX)
#define BITS_RX_HIGH_TIMER_IDX \
(BIT_MASK_RX_HIGH_TIMER_IDX << BIT_SHIFT_RX_HIGH_TIMER_IDX)
#define BIT_CLEAR_RX_HIGH_TIMER_IDX(x) ((x) & (~BITS_RX_HIGH_TIMER_IDX))
#define BIT_GET_RX_HIGH_TIMER_IDX(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TIMER_IDX) & BIT_MASK_RX_HIGH_TIMER_IDX)
#define BIT_SET_RX_HIGH_TIMER_IDX(x, v) \
(BIT_CLEAR_RX_HIGH_TIMER_IDX(x) | BIT_RX_HIGH_TIMER_IDX(v))
#define BIT_SHIFT_RX_MED_TIMER_IDX 16
#define BIT_MASK_RX_MED_TIMER_IDX 0x7
#define BIT_RX_MED_TIMER_IDX(x) \
(((x) & BIT_MASK_RX_MED_TIMER_IDX) << BIT_SHIFT_RX_MED_TIMER_IDX)
#define BITS_RX_MED_TIMER_IDX \
(BIT_MASK_RX_MED_TIMER_IDX << BIT_SHIFT_RX_MED_TIMER_IDX)
#define BIT_CLEAR_RX_MED_TIMER_IDX(x) ((x) & (~BITS_RX_MED_TIMER_IDX))
#define BIT_GET_RX_MED_TIMER_IDX(x) \
(((x) >> BIT_SHIFT_RX_MED_TIMER_IDX) & BIT_MASK_RX_MED_TIMER_IDX)
#define BIT_SET_RX_MED_TIMER_IDX(x, v) \
(BIT_CLEAR_RX_MED_TIMER_IDX(x) | BIT_RX_MED_TIMER_IDX(v))
#define BIT_SHIFT_RX_LOW_TIMER_IDX 8
#define BIT_MASK_RX_LOW_TIMER_IDX 0x7
#define BIT_RX_LOW_TIMER_IDX(x) \
(((x) & BIT_MASK_RX_LOW_TIMER_IDX) << BIT_SHIFT_RX_LOW_TIMER_IDX)
#define BITS_RX_LOW_TIMER_IDX \
(BIT_MASK_RX_LOW_TIMER_IDX << BIT_SHIFT_RX_LOW_TIMER_IDX)
#define BIT_CLEAR_RX_LOW_TIMER_IDX(x) ((x) & (~BITS_RX_LOW_TIMER_IDX))
#define BIT_GET_RX_LOW_TIMER_IDX(x) \
(((x) >> BIT_SHIFT_RX_LOW_TIMER_IDX) & BIT_MASK_RX_LOW_TIMER_IDX)
#define BIT_SET_RX_LOW_TIMER_IDX(x, v) \
(BIT_CLEAR_RX_LOW_TIMER_IDX(x) | BIT_RX_LOW_TIMER_IDX(v))
#define BIT_SHIFT_OBFF_INT_TIMER_IDX 0
#define BIT_MASK_OBFF_INT_TIMER_IDX 0x7
#define BIT_OBFF_INT_TIMER_IDX(x) \
(((x) & BIT_MASK_OBFF_INT_TIMER_IDX) << BIT_SHIFT_OBFF_INT_TIMER_IDX)
#define BITS_OBFF_INT_TIMER_IDX \
(BIT_MASK_OBFF_INT_TIMER_IDX << BIT_SHIFT_OBFF_INT_TIMER_IDX)
#define BIT_CLEAR_OBFF_INT_TIMER_IDX(x) ((x) & (~BITS_OBFF_INT_TIMER_IDX))
#define BIT_GET_OBFF_INT_TIMER_IDX(x) \
(((x) >> BIT_SHIFT_OBFF_INT_TIMER_IDX) & BIT_MASK_OBFF_INT_TIMER_IDX)
#define BIT_SET_OBFF_INT_TIMER_IDX(x, v) \
(BIT_CLEAR_OBFF_INT_TIMER_IDX(x) | BIT_OBFF_INT_TIMER_IDX(v))
/* 2 REG_LTR_CTRL_BASIC (Offset 0x07A0) */
#define BIT_LTR_EN_V1 BIT(31)
#define BIT_LTR_HW_EN_V1 BIT(30)
#define BIT_LRT_ACT_CTS_EN BIT(29)
#define BIT_LTR_ACT_RXPKT_EN BIT(28)
#define BIT_LTR_ACT_RXDMA_EN BIT(27)
#define BIT_LTR_IDLE_NO_SNOOP BIT(26)
#define BIT_SPDUP_MGTPKT BIT(25)
#define BIT_RX_AGG_EN BIT(24)
#define BIT_APP_LTR_ACT BIT(23)
#define BIT_APP_LTR_IDLE BIT(22)
#define BIT_SHIFT_HIGH_RATE_TRIG_SEL 20
#define BIT_MASK_HIGH_RATE_TRIG_SEL 0x3
#define BIT_HIGH_RATE_TRIG_SEL(x) \
(((x) & BIT_MASK_HIGH_RATE_TRIG_SEL) << BIT_SHIFT_HIGH_RATE_TRIG_SEL)
#define BITS_HIGH_RATE_TRIG_SEL \
(BIT_MASK_HIGH_RATE_TRIG_SEL << BIT_SHIFT_HIGH_RATE_TRIG_SEL)
#define BIT_CLEAR_HIGH_RATE_TRIG_SEL(x) ((x) & (~BITS_HIGH_RATE_TRIG_SEL))
#define BIT_GET_HIGH_RATE_TRIG_SEL(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_TRIG_SEL) & BIT_MASK_HIGH_RATE_TRIG_SEL)
#define BIT_SET_HIGH_RATE_TRIG_SEL(x, v) \
(BIT_CLEAR_HIGH_RATE_TRIG_SEL(x) | BIT_HIGH_RATE_TRIG_SEL(v))
#define BIT_SHIFT_MED_RATE_TRIG_SEL 18
#define BIT_MASK_MED_RATE_TRIG_SEL 0x3
#define BIT_MED_RATE_TRIG_SEL(x) \
(((x) & BIT_MASK_MED_RATE_TRIG_SEL) << BIT_SHIFT_MED_RATE_TRIG_SEL)
#define BITS_MED_RATE_TRIG_SEL \
(BIT_MASK_MED_RATE_TRIG_SEL << BIT_SHIFT_MED_RATE_TRIG_SEL)
#define BIT_CLEAR_MED_RATE_TRIG_SEL(x) ((x) & (~BITS_MED_RATE_TRIG_SEL))
#define BIT_GET_MED_RATE_TRIG_SEL(x) \
(((x) >> BIT_SHIFT_MED_RATE_TRIG_SEL) & BIT_MASK_MED_RATE_TRIG_SEL)
#define BIT_SET_MED_RATE_TRIG_SEL(x, v) \
(BIT_CLEAR_MED_RATE_TRIG_SEL(x) | BIT_MED_RATE_TRIG_SEL(v))
#define BIT_SHIFT_LOW_RATE_TRIG_SEL 16
#define BIT_MASK_LOW_RATE_TRIG_SEL 0x3
#define BIT_LOW_RATE_TRIG_SEL(x) \
(((x) & BIT_MASK_LOW_RATE_TRIG_SEL) << BIT_SHIFT_LOW_RATE_TRIG_SEL)
#define BITS_LOW_RATE_TRIG_SEL \
(BIT_MASK_LOW_RATE_TRIG_SEL << BIT_SHIFT_LOW_RATE_TRIG_SEL)
#define BIT_CLEAR_LOW_RATE_TRIG_SEL(x) ((x) & (~BITS_LOW_RATE_TRIG_SEL))
#define BIT_GET_LOW_RATE_TRIG_SEL(x) \
(((x) >> BIT_SHIFT_LOW_RATE_TRIG_SEL) & BIT_MASK_LOW_RATE_TRIG_SEL)
#define BIT_SET_LOW_RATE_TRIG_SEL(x, v) \
(BIT_CLEAR_LOW_RATE_TRIG_SEL(x) | BIT_LOW_RATE_TRIG_SEL(v))
#define BIT_SHIFT_HIGH_RATE_BD_IDX 8
#define BIT_MASK_HIGH_RATE_BD_IDX 0x7f
#define BIT_HIGH_RATE_BD_IDX(x) \
(((x) & BIT_MASK_HIGH_RATE_BD_IDX) << BIT_SHIFT_HIGH_RATE_BD_IDX)
#define BITS_HIGH_RATE_BD_IDX \
(BIT_MASK_HIGH_RATE_BD_IDX << BIT_SHIFT_HIGH_RATE_BD_IDX)
#define BIT_CLEAR_HIGH_RATE_BD_IDX(x) ((x) & (~BITS_HIGH_RATE_BD_IDX))
#define BIT_GET_HIGH_RATE_BD_IDX(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_BD_IDX) & BIT_MASK_HIGH_RATE_BD_IDX)
#define BIT_SET_HIGH_RATE_BD_IDX(x, v) \
(BIT_CLEAR_HIGH_RATE_BD_IDX(x) | BIT_HIGH_RATE_BD_IDX(v))
#define BIT_SHIFT_LOW_RATE_BD_IDX 0
#define BIT_MASK_LOW_RATE_BD_IDX 0x7f
#define BIT_LOW_RATE_BD_IDX(x) \
(((x) & BIT_MASK_LOW_RATE_BD_IDX) << BIT_SHIFT_LOW_RATE_BD_IDX)
#define BITS_LOW_RATE_BD_IDX \
(BIT_MASK_LOW_RATE_BD_IDX << BIT_SHIFT_LOW_RATE_BD_IDX)
#define BIT_CLEAR_LOW_RATE_BD_IDX(x) ((x) & (~BITS_LOW_RATE_BD_IDX))
#define BIT_GET_LOW_RATE_BD_IDX(x) \
(((x) >> BIT_SHIFT_LOW_RATE_BD_IDX) & BIT_MASK_LOW_RATE_BD_IDX)
#define BIT_SET_LOW_RATE_BD_IDX(x, v) \
(BIT_CLEAR_LOW_RATE_BD_IDX(x) | BIT_LOW_RATE_BD_IDX(v))
/* 2 REG_LTR_CTRL2_TIMER_THRESHOLD (Offset 0x07A4) */
#define BIT_SHIFT_RX_EMPTY_TIMER_IDX 24
#define BIT_MASK_RX_EMPTY_TIMER_IDX 0x7
#define BIT_RX_EMPTY_TIMER_IDX(x) \
(((x) & BIT_MASK_RX_EMPTY_TIMER_IDX) << BIT_SHIFT_RX_EMPTY_TIMER_IDX)
#define BITS_RX_EMPTY_TIMER_IDX \
(BIT_MASK_RX_EMPTY_TIMER_IDX << BIT_SHIFT_RX_EMPTY_TIMER_IDX)
#define BIT_CLEAR_RX_EMPTY_TIMER_IDX(x) ((x) & (~BITS_RX_EMPTY_TIMER_IDX))
#define BIT_GET_RX_EMPTY_TIMER_IDX(x) \
(((x) >> BIT_SHIFT_RX_EMPTY_TIMER_IDX) & BIT_MASK_RX_EMPTY_TIMER_IDX)
#define BIT_SET_RX_EMPTY_TIMER_IDX(x, v) \
(BIT_CLEAR_RX_EMPTY_TIMER_IDX(x) | BIT_RX_EMPTY_TIMER_IDX(v))
#define BIT_SHIFT_RX_AFULL_TH_IDX 20
#define BIT_MASK_RX_AFULL_TH_IDX 0x7
#define BIT_RX_AFULL_TH_IDX(x) \
(((x) & BIT_MASK_RX_AFULL_TH_IDX) << BIT_SHIFT_RX_AFULL_TH_IDX)
#define BITS_RX_AFULL_TH_IDX \
(BIT_MASK_RX_AFULL_TH_IDX << BIT_SHIFT_RX_AFULL_TH_IDX)
#define BIT_CLEAR_RX_AFULL_TH_IDX(x) ((x) & (~BITS_RX_AFULL_TH_IDX))
#define BIT_GET_RX_AFULL_TH_IDX(x) \
(((x) >> BIT_SHIFT_RX_AFULL_TH_IDX) & BIT_MASK_RX_AFULL_TH_IDX)
#define BIT_SET_RX_AFULL_TH_IDX(x, v) \
(BIT_CLEAR_RX_AFULL_TH_IDX(x) | BIT_RX_AFULL_TH_IDX(v))
#define BIT_SHIFT_RX_HIGH_TH_IDX 16
#define BIT_MASK_RX_HIGH_TH_IDX 0x7
#define BIT_RX_HIGH_TH_IDX(x) \
(((x) & BIT_MASK_RX_HIGH_TH_IDX) << BIT_SHIFT_RX_HIGH_TH_IDX)
#define BITS_RX_HIGH_TH_IDX \
(BIT_MASK_RX_HIGH_TH_IDX << BIT_SHIFT_RX_HIGH_TH_IDX)
#define BIT_CLEAR_RX_HIGH_TH_IDX(x) ((x) & (~BITS_RX_HIGH_TH_IDX))
#define BIT_GET_RX_HIGH_TH_IDX(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TH_IDX) & BIT_MASK_RX_HIGH_TH_IDX)
#define BIT_SET_RX_HIGH_TH_IDX(x, v) \
(BIT_CLEAR_RX_HIGH_TH_IDX(x) | BIT_RX_HIGH_TH_IDX(v))
#define BIT_SHIFT_RX_MED_TH_IDX 12
#define BIT_MASK_RX_MED_TH_IDX 0x7
#define BIT_RX_MED_TH_IDX(x) \
(((x) & BIT_MASK_RX_MED_TH_IDX) << BIT_SHIFT_RX_MED_TH_IDX)
#define BITS_RX_MED_TH_IDX (BIT_MASK_RX_MED_TH_IDX << BIT_SHIFT_RX_MED_TH_IDX)
#define BIT_CLEAR_RX_MED_TH_IDX(x) ((x) & (~BITS_RX_MED_TH_IDX))
#define BIT_GET_RX_MED_TH_IDX(x) \
(((x) >> BIT_SHIFT_RX_MED_TH_IDX) & BIT_MASK_RX_MED_TH_IDX)
#define BIT_SET_RX_MED_TH_IDX(x, v) \
(BIT_CLEAR_RX_MED_TH_IDX(x) | BIT_RX_MED_TH_IDX(v))
#define BIT_SHIFT_RX_LOW_TH_IDX 8
#define BIT_MASK_RX_LOW_TH_IDX 0x7
#define BIT_RX_LOW_TH_IDX(x) \
(((x) & BIT_MASK_RX_LOW_TH_IDX) << BIT_SHIFT_RX_LOW_TH_IDX)
#define BITS_RX_LOW_TH_IDX (BIT_MASK_RX_LOW_TH_IDX << BIT_SHIFT_RX_LOW_TH_IDX)
#define BIT_CLEAR_RX_LOW_TH_IDX(x) ((x) & (~BITS_RX_LOW_TH_IDX))
#define BIT_GET_RX_LOW_TH_IDX(x) \
(((x) >> BIT_SHIFT_RX_LOW_TH_IDX) & BIT_MASK_RX_LOW_TH_IDX)
#define BIT_SET_RX_LOW_TH_IDX(x, v) \
(BIT_CLEAR_RX_LOW_TH_IDX(x) | BIT_RX_LOW_TH_IDX(v))
#define BIT_SHIFT_LTR_SPACE_IDX 4
#define BIT_MASK_LTR_SPACE_IDX 0x3
#define BIT_LTR_SPACE_IDX(x) \
(((x) & BIT_MASK_LTR_SPACE_IDX) << BIT_SHIFT_LTR_SPACE_IDX)
#define BITS_LTR_SPACE_IDX (BIT_MASK_LTR_SPACE_IDX << BIT_SHIFT_LTR_SPACE_IDX)
#define BIT_CLEAR_LTR_SPACE_IDX(x) ((x) & (~BITS_LTR_SPACE_IDX))
#define BIT_GET_LTR_SPACE_IDX(x) \
(((x) >> BIT_SHIFT_LTR_SPACE_IDX) & BIT_MASK_LTR_SPACE_IDX)
#define BIT_SET_LTR_SPACE_IDX(x, v) \
(BIT_CLEAR_LTR_SPACE_IDX(x) | BIT_LTR_SPACE_IDX(v))
#define BIT_SHIFT_LTR_IDLE_TIMER_IDX 0
#define BIT_MASK_LTR_IDLE_TIMER_IDX 0x7
#define BIT_LTR_IDLE_TIMER_IDX(x) \
(((x) & BIT_MASK_LTR_IDLE_TIMER_IDX) << BIT_SHIFT_LTR_IDLE_TIMER_IDX)
#define BITS_LTR_IDLE_TIMER_IDX \
(BIT_MASK_LTR_IDLE_TIMER_IDX << BIT_SHIFT_LTR_IDLE_TIMER_IDX)
#define BIT_CLEAR_LTR_IDLE_TIMER_IDX(x) ((x) & (~BITS_LTR_IDLE_TIMER_IDX))
#define BIT_GET_LTR_IDLE_TIMER_IDX(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_TIMER_IDX) & BIT_MASK_LTR_IDLE_TIMER_IDX)
#define BIT_SET_LTR_IDLE_TIMER_IDX(x, v) \
(BIT_CLEAR_LTR_IDLE_TIMER_IDX(x) | BIT_LTR_IDLE_TIMER_IDX(v))
/* 2 REG_LTR_IDLE_LATENCY_V1 (Offset 0x07A8) */
#define BIT_SHIFT_LTR_IDLE_L 0
#define BIT_MASK_LTR_IDLE_L 0xffffffffL
#define BIT_LTR_IDLE_L(x) (((x) & BIT_MASK_LTR_IDLE_L) << BIT_SHIFT_LTR_IDLE_L)
#define BITS_LTR_IDLE_L (BIT_MASK_LTR_IDLE_L << BIT_SHIFT_LTR_IDLE_L)
#define BIT_CLEAR_LTR_IDLE_L(x) ((x) & (~BITS_LTR_IDLE_L))
#define BIT_GET_LTR_IDLE_L(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_L) & BIT_MASK_LTR_IDLE_L)
#define BIT_SET_LTR_IDLE_L(x, v) (BIT_CLEAR_LTR_IDLE_L(x) | BIT_LTR_IDLE_L(v))
/* 2 REG_LTR_ACTIVE_LATENCY_V1 (Offset 0x07AC) */
#define BIT_SHIFT_LTR_ACT_L 0
#define BIT_MASK_LTR_ACT_L 0xffffffffL
#define BIT_LTR_ACT_L(x) (((x) & BIT_MASK_LTR_ACT_L) << BIT_SHIFT_LTR_ACT_L)
#define BITS_LTR_ACT_L (BIT_MASK_LTR_ACT_L << BIT_SHIFT_LTR_ACT_L)
#define BIT_CLEAR_LTR_ACT_L(x) ((x) & (~BITS_LTR_ACT_L))
#define BIT_GET_LTR_ACT_L(x) (((x) >> BIT_SHIFT_LTR_ACT_L) & BIT_MASK_LTR_ACT_L)
#define BIT_SET_LTR_ACT_L(x, v) (BIT_CLEAR_LTR_ACT_L(x) | BIT_LTR_ACT_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_LTR_ACTIVE_LATENCY_V1 (Offset 0x07AC) */
#define BIT_SHIFT_ANT_ADDR2_1 0
#define BIT_MASK_ANT_ADDR2_1 0xffffffffL
#define BIT_ANT_ADDR2_1(x) \
(((x) & BIT_MASK_ANT_ADDR2_1) << BIT_SHIFT_ANT_ADDR2_1)
#define BITS_ANT_ADDR2_1 (BIT_MASK_ANT_ADDR2_1 << BIT_SHIFT_ANT_ADDR2_1)
#define BIT_CLEAR_ANT_ADDR2_1(x) ((x) & (~BITS_ANT_ADDR2_1))
#define BIT_GET_ANT_ADDR2_1(x) \
(((x) >> BIT_SHIFT_ANT_ADDR2_1) & BIT_MASK_ANT_ADDR2_1)
#define BIT_SET_ANT_ADDR2_1(x, v) \
(BIT_CLEAR_ANT_ADDR2_1(x) | BIT_ANT_ADDR2_1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER (Offset 0x07B0) */
#define BIT_APPEND_MACID_IN_RESP_EN BIT(50)
#define BIT_ADDR2_MATCH_EN BIT(49)
#define BIT_ANTTRN_EN BIT(48)
#define BIT_SHIFT_TRAIN_STA_ADDR 0
#define BIT_MASK_TRAIN_STA_ADDR 0xffffffffffffL
#define BIT_TRAIN_STA_ADDR(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR) << BIT_SHIFT_TRAIN_STA_ADDR)
#define BITS_TRAIN_STA_ADDR \
(BIT_MASK_TRAIN_STA_ADDR << BIT_SHIFT_TRAIN_STA_ADDR)
#define BIT_CLEAR_TRAIN_STA_ADDR(x) ((x) & (~BITS_TRAIN_STA_ADDR))
#define BIT_GET_TRAIN_STA_ADDR(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR) & BIT_MASK_TRAIN_STA_ADDR)
#define BIT_SET_TRAIN_STA_ADDR(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR(x) | BIT_TRAIN_STA_ADDR(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER (Offset 0x07B0) */
#define BIT_SHIFT_TRAIN_STA_ADDR_0 0
#define BIT_MASK_TRAIN_STA_ADDR_0 0xffffffffL
#define BIT_TRAIN_STA_ADDR_0(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_0) << BIT_SHIFT_TRAIN_STA_ADDR_0)
#define BITS_TRAIN_STA_ADDR_0 \
(BIT_MASK_TRAIN_STA_ADDR_0 << BIT_SHIFT_TRAIN_STA_ADDR_0)
#define BIT_CLEAR_TRAIN_STA_ADDR_0(x) ((x) & (~BITS_TRAIN_STA_ADDR_0))
#define BIT_GET_TRAIN_STA_ADDR_0(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_0) & BIT_MASK_TRAIN_STA_ADDR_0)
#define BIT_SET_TRAIN_STA_ADDR_0(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_0(x) | BIT_TRAIN_STA_ADDR_0(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_1 (Offset 0x07B4) */
#define BIT_SHIFT_TRAIN_STA_ADDR_1 0
#define BIT_MASK_TRAIN_STA_ADDR_1 0xffff
#define BIT_TRAIN_STA_ADDR_1(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_1) << BIT_SHIFT_TRAIN_STA_ADDR_1)
#define BITS_TRAIN_STA_ADDR_1 \
(BIT_MASK_TRAIN_STA_ADDR_1 << BIT_SHIFT_TRAIN_STA_ADDR_1)
#define BIT_CLEAR_TRAIN_STA_ADDR_1(x) ((x) & (~BITS_TRAIN_STA_ADDR_1))
#define BIT_GET_TRAIN_STA_ADDR_1(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_1) & BIT_MASK_TRAIN_STA_ADDR_1)
#define BIT_SET_TRAIN_STA_ADDR_1(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_1(x) | BIT_TRAIN_STA_ADDR_1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SMART_ANT_CTRL (Offset 0x07B4) */
#define BIT_SHIFT_ANT_ADDR2_2 0
#define BIT_MASK_ANT_ADDR2_2 0xffff
#define BIT_ANT_ADDR2_2(x) \
(((x) & BIT_MASK_ANT_ADDR2_2) << BIT_SHIFT_ANT_ADDR2_2)
#define BITS_ANT_ADDR2_2 (BIT_MASK_ANT_ADDR2_2 << BIT_SHIFT_ANT_ADDR2_2)
#define BIT_CLEAR_ANT_ADDR2_2(x) ((x) & (~BITS_ANT_ADDR2_2))
#define BIT_GET_ANT_ADDR2_2(x) \
(((x) >> BIT_SHIFT_ANT_ADDR2_2) & BIT_MASK_ANT_ADDR2_2)
#define BIT_SET_ANT_ADDR2_2(x, v) \
(BIT_CLEAR_ANT_ADDR2_2(x) | BIT_ANT_ADDR2_2(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_PKTCNT_RWD (Offset 0x07B8) */
#define BIT_SHIFT_PKTCNT_BSSIDMAP 4
#define BIT_MASK_PKTCNT_BSSIDMAP 0xf
#define BIT_PKTCNT_BSSIDMAP(x) \
(((x) & BIT_MASK_PKTCNT_BSSIDMAP) << BIT_SHIFT_PKTCNT_BSSIDMAP)
#define BITS_PKTCNT_BSSIDMAP \
(BIT_MASK_PKTCNT_BSSIDMAP << BIT_SHIFT_PKTCNT_BSSIDMAP)
#define BIT_CLEAR_PKTCNT_BSSIDMAP(x) ((x) & (~BITS_PKTCNT_BSSIDMAP))
#define BIT_GET_PKTCNT_BSSIDMAP(x) \
(((x) >> BIT_SHIFT_PKTCNT_BSSIDMAP) & BIT_MASK_PKTCNT_BSSIDMAP)
#define BIT_SET_PKTCNT_BSSIDMAP(x, v) \
(BIT_CLEAR_PKTCNT_BSSIDMAP(x) | BIT_PKTCNT_BSSIDMAP(v))
#define BIT_PKTCNT_CNTRST BIT(1)
#define BIT_PKTCNT_CNTEN BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CONTROL_FRAME_REPORT (Offset 0x07B8) */
#define BIT_SHIFT_CONTROL_FRAME_REPORT 0
#define BIT_MASK_CONTROL_FRAME_REPORT 0xffffffffL
#define BIT_CONTROL_FRAME_REPORT(x) \
(((x) & BIT_MASK_CONTROL_FRAME_REPORT) \
<< BIT_SHIFT_CONTROL_FRAME_REPORT)
#define BITS_CONTROL_FRAME_REPORT \
(BIT_MASK_CONTROL_FRAME_REPORT << BIT_SHIFT_CONTROL_FRAME_REPORT)
#define BIT_CLEAR_CONTROL_FRAME_REPORT(x) ((x) & (~BITS_CONTROL_FRAME_REPORT))
#define BIT_GET_CONTROL_FRAME_REPORT(x) \
(((x) >> BIT_SHIFT_CONTROL_FRAME_REPORT) & \
BIT_MASK_CONTROL_FRAME_REPORT)
#define BIT_SET_CONTROL_FRAME_REPORT(x, v) \
(BIT_CLEAR_CONTROL_FRAME_REPORT(x) | BIT_CONTROL_FRAME_REPORT(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_PKTCNT_CTRL (Offset 0x07BC) */
#define BIT_WMAC_PKTCNT_TRST BIT(9)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CONTROL_FRAME_CNT_CTRL (Offset 0x07BC) */
#define BIT_ALLCNTRST BIT(9)
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_PKTCNT_CTRL (Offset 0x07BC) */
#define BIT_WMAC_PKTCNT_FEN BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CONTROL_FRAME_CNT_CTRL (Offset 0x07BC) */
#define BIT__ALLCNTEN BIT(8)
#define BIT_SHIFT_ADDR 4
#define BIT_MASK_ADDR 0xf
#define BIT_ADDR(x) (((x) & BIT_MASK_ADDR) << BIT_SHIFT_ADDR)
#define BITS_ADDR (BIT_MASK_ADDR << BIT_SHIFT_ADDR)
#define BIT_CLEAR_ADDR(x) ((x) & (~BITS_ADDR))
#define BIT_GET_ADDR(x) (((x) >> BIT_SHIFT_ADDR) & BIT_MASK_ADDR)
#define BIT_SET_ADDR(x, v) (BIT_CLEAR_ADDR(x) | BIT_ADDR(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_WMAC_PKTCNT_CTRL (Offset 0x07BC) */
#define BIT_SHIFT_WMAC_PKTCNT_CFGAD 0
#define BIT_MASK_WMAC_PKTCNT_CFGAD 0xff
#define BIT_WMAC_PKTCNT_CFGAD(x) \
(((x) & BIT_MASK_WMAC_PKTCNT_CFGAD) << BIT_SHIFT_WMAC_PKTCNT_CFGAD)
#define BITS_WMAC_PKTCNT_CFGAD \
(BIT_MASK_WMAC_PKTCNT_CFGAD << BIT_SHIFT_WMAC_PKTCNT_CFGAD)
#define BIT_CLEAR_WMAC_PKTCNT_CFGAD(x) ((x) & (~BITS_WMAC_PKTCNT_CFGAD))
#define BIT_GET_WMAC_PKTCNT_CFGAD(x) \
(((x) >> BIT_SHIFT_WMAC_PKTCNT_CFGAD) & BIT_MASK_WMAC_PKTCNT_CFGAD)
#define BIT_SET_WMAC_PKTCNT_CFGAD(x, v) \
(BIT_CLEAR_WMAC_PKTCNT_CFGAD(x) | BIT_WMAC_PKTCNT_CFGAD(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CONTROL_FRAME_CNT_CTRL (Offset 0x07BC) */
#define BIT_SHIFT_CTRL_SEL 0
#define BIT_MASK_CTRL_SEL 0xf
#define BIT_CTRL_SEL(x) (((x) & BIT_MASK_CTRL_SEL) << BIT_SHIFT_CTRL_SEL)
#define BITS_CTRL_SEL (BIT_MASK_CTRL_SEL << BIT_SHIFT_CTRL_SEL)
#define BIT_CLEAR_CTRL_SEL(x) ((x) & (~BITS_CTRL_SEL))
#define BIT_GET_CTRL_SEL(x) (((x) >> BIT_SHIFT_CTRL_SEL) & BIT_MASK_CTRL_SEL)
#define BIT_SET_CTRL_SEL(x, v) (BIT_CLEAR_CTRL_SEL(x) | BIT_CTRL_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_IQ_DUMP (Offset 0x07C0) */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC (64 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_MATCH_REF_MAC 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC)
#define BITS_R_WMAC_MATCH_REF_MAC \
(BIT_MASK_R_WMAC_MATCH_REF_MAC << BIT_SHIFT_R_WMAC_MATCH_REF_MAC)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC(x) ((x) & (~BITS_R_WMAC_MATCH_REF_MAC))
#define BIT_GET_R_WMAC_MATCH_REF_MAC(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC)
#define BIT_SET_R_WMAC_MATCH_REF_MAC(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC(x) | BIT_R_WMAC_MATCH_REF_MAC(v))
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH (56 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH)
#define BITS_R_WMAC_RXFIFO_FULL_TH \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH << BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH(x) ((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH(x) | BIT_R_WMAC_RXFIFO_FULL_TH(v))
#define BIT_R_WMAC_SRCH_TXRPT_TYPE BIT(51)
#define BIT_R_WMAC_NDP_RST BIT(50)
#define BIT_R_WMAC_POWINT_EN BIT(49)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT BIT(48)
#define BIT_R_WMAC_SRCH_TXRPT_MID BIT(47)
#define BIT_R_WMAC_PFIN_TOEN BIT(46)
#define BIT_R_WMAC_FIL_SECERR BIT(45)
#define BIT_R_WMAC_FIL_CTLPKTLEN BIT(44)
#define BIT_R_WMAC_FIL_FCTYPE BIT(43)
#define BIT_R_WMAC_FIL_FCPROVER BIT(42)
#define BIT_R_WMAC_PHYSTS_SNIF BIT(41)
#define BIT_R_WMAC_PHYSTS_PLCP BIT(40)
#define BIT_R_MAC_TCR_VBONF_RD BIT(39)
#define BIT_R_WMAC_TCR_MPAR_NDP BIT(38)
#define BIT_R_WMAC_NDP_FILTER BIT(37)
#define BIT_R_WMAC_RXLEN_SEL BIT(36)
#define BIT_R_WMAC_RXLEN_SEL1 BIT(35)
#define BIT_R_OFDM_FILTER BIT(34)
#define BIT_R_WMAC_CHK_OFDM_LEN BIT(33)
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC (32 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_MASK_LA_MAC 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC) << BIT_SHIFT_R_WMAC_MASK_LA_MAC)
#define BITS_R_WMAC_MASK_LA_MAC \
(BIT_MASK_R_WMAC_MASK_LA_MAC << BIT_SHIFT_R_WMAC_MASK_LA_MAC)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC(x) ((x) & (~BITS_R_WMAC_MASK_LA_MAC))
#define BIT_GET_R_WMAC_MASK_LA_MAC(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC) & BIT_MASK_R_WMAC_MASK_LA_MAC)
#define BIT_SET_R_WMAC_MASK_LA_MAC(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC(x) | BIT_R_WMAC_MASK_LA_MAC(v))
#define BIT_R_WMAC_CHK_CCK_LEN BIT(32)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL (Offset 0x07C0) */
#define BIT_LTECOEX_ACCESS_START BIT(31)
#define BIT_LTECOEX_WRITE_MODE BIT(30)
#define BIT_LTECOEX_READY_BIT BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN 16
#define BIT_MASK_WRITE_BYTE_EN 0xf
#define BIT_WRITE_BYTE_EN(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN) << BIT_SHIFT_WRITE_BYTE_EN)
#define BITS_WRITE_BYTE_EN (BIT_MASK_WRITE_BYTE_EN << BIT_SHIFT_WRITE_BYTE_EN)
#define BIT_CLEAR_WRITE_BYTE_EN(x) ((x) & (~BITS_WRITE_BYTE_EN))
#define BIT_GET_WRITE_BYTE_EN(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN) & BIT_MASK_WRITE_BYTE_EN)
#define BIT_SET_WRITE_BYTE_EN(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN(x) | BIT_WRITE_BYTE_EN(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_IQ_DUMP (Offset 0x07C0) */
#define BIT_SHIFT_DUMP_OK_ADDR 16
#define BIT_MASK_DUMP_OK_ADDR 0xffff
#define BIT_DUMP_OK_ADDR(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR) << BIT_SHIFT_DUMP_OK_ADDR)
#define BITS_DUMP_OK_ADDR (BIT_MASK_DUMP_OK_ADDR << BIT_SHIFT_DUMP_OK_ADDR)
#define BIT_CLEAR_DUMP_OK_ADDR(x) ((x) & (~BITS_DUMP_OK_ADDR))
#define BIT_GET_DUMP_OK_ADDR(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR) & BIT_MASK_DUMP_OK_ADDR)
#define BIT_SET_DUMP_OK_ADDR(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR(x) | BIT_DUMP_OK_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_IQ_DUMP (Offset 0x07C0) */
#define BIT_SHIFT_DUMP_OK_ADDR_V1 15
#define BIT_MASK_DUMP_OK_ADDR_V1 0x1ffff
#define BIT_DUMP_OK_ADDR_V1(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR_V1) << BIT_SHIFT_DUMP_OK_ADDR_V1)
#define BITS_DUMP_OK_ADDR_V1 \
(BIT_MASK_DUMP_OK_ADDR_V1 << BIT_SHIFT_DUMP_OK_ADDR_V1)
#define BIT_CLEAR_DUMP_OK_ADDR_V1(x) ((x) & (~BITS_DUMP_OK_ADDR_V1))
#define BIT_GET_DUMP_OK_ADDR_V1(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR_V1) & BIT_MASK_DUMP_OK_ADDR_V1)
#define BIT_SET_DUMP_OK_ADDR_V1(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR_V1(x) | BIT_DUMP_OK_ADDR_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_IQ_DUMP (Offset 0x07C0) */
#define BIT_MACDBG_TRIG_IQDUMP BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_IQ_DUMP (Offset 0x07C0) */
#define BIT_SHIFT_R_TRIG_TIME_SEL 8
#define BIT_MASK_R_TRIG_TIME_SEL 0x7f
#define BIT_R_TRIG_TIME_SEL(x) \
(((x) & BIT_MASK_R_TRIG_TIME_SEL) << BIT_SHIFT_R_TRIG_TIME_SEL)
#define BITS_R_TRIG_TIME_SEL \
(BIT_MASK_R_TRIG_TIME_SEL << BIT_SHIFT_R_TRIG_TIME_SEL)
#define BIT_CLEAR_R_TRIG_TIME_SEL(x) ((x) & (~BITS_R_TRIG_TIME_SEL))
#define BIT_GET_R_TRIG_TIME_SEL(x) \
(((x) >> BIT_SHIFT_R_TRIG_TIME_SEL) & BIT_MASK_R_TRIG_TIME_SEL)
#define BIT_SET_R_TRIG_TIME_SEL(x, v) \
(BIT_CLEAR_R_TRIG_TIME_SEL(x) | BIT_R_TRIG_TIME_SEL(v))
#define BIT_SHIFT_R_MAC_TRIG_SEL 6
#define BIT_MASK_R_MAC_TRIG_SEL 0x3
#define BIT_R_MAC_TRIG_SEL(x) \
(((x) & BIT_MASK_R_MAC_TRIG_SEL) << BIT_SHIFT_R_MAC_TRIG_SEL)
#define BITS_R_MAC_TRIG_SEL \
(BIT_MASK_R_MAC_TRIG_SEL << BIT_SHIFT_R_MAC_TRIG_SEL)
#define BIT_CLEAR_R_MAC_TRIG_SEL(x) ((x) & (~BITS_R_MAC_TRIG_SEL))
#define BIT_GET_R_MAC_TRIG_SEL(x) \
(((x) >> BIT_SHIFT_R_MAC_TRIG_SEL) & BIT_MASK_R_MAC_TRIG_SEL)
#define BIT_SET_R_MAC_TRIG_SEL(x, v) \
(BIT_CLEAR_R_MAC_TRIG_SEL(x) | BIT_R_MAC_TRIG_SEL(v))
#define BIT_MAC_TRIG_REG BIT(5)
#define BIT_SHIFT_R_LEVEL_PULSE_SEL 3
#define BIT_MASK_R_LEVEL_PULSE_SEL 0x3
#define BIT_R_LEVEL_PULSE_SEL(x) \
(((x) & BIT_MASK_R_LEVEL_PULSE_SEL) << BIT_SHIFT_R_LEVEL_PULSE_SEL)
#define BITS_R_LEVEL_PULSE_SEL \
(BIT_MASK_R_LEVEL_PULSE_SEL << BIT_SHIFT_R_LEVEL_PULSE_SEL)
#define BIT_CLEAR_R_LEVEL_PULSE_SEL(x) ((x) & (~BITS_R_LEVEL_PULSE_SEL))
#define BIT_GET_R_LEVEL_PULSE_SEL(x) \
(((x) >> BIT_SHIFT_R_LEVEL_PULSE_SEL) & BIT_MASK_R_LEVEL_PULSE_SEL)
#define BIT_SET_R_LEVEL_PULSE_SEL(x, v) \
(BIT_CLEAR_R_LEVEL_PULSE_SEL(x) | BIT_R_LEVEL_PULSE_SEL(v))
#define BIT_EN_LA_MAC BIT(2)
#define BIT_R_EN_IQDUMP BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL (Offset 0x07C0) */
#define BIT_SHIFT_LTECOEX_REG_ADDR 0
#define BIT_MASK_LTECOEX_REG_ADDR 0xffff
#define BIT_LTECOEX_REG_ADDR(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR) << BIT_SHIFT_LTECOEX_REG_ADDR)
#define BITS_LTECOEX_REG_ADDR \
(BIT_MASK_LTECOEX_REG_ADDR << BIT_SHIFT_LTECOEX_REG_ADDR)
#define BIT_CLEAR_LTECOEX_REG_ADDR(x) ((x) & (~BITS_LTECOEX_REG_ADDR))
#define BIT_GET_LTECOEX_REG_ADDR(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR) & BIT_MASK_LTECOEX_REG_ADDR)
#define BIT_SET_LTECOEX_REG_ADDR(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR(x) | BIT_LTECOEX_REG_ADDR(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_IQ_DUMP (Offset 0x07C0) */
#define BIT_R_IQDATA_DUMP BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA (Offset 0x07C4) */
#define BIT_SHIFT_LTECOEX_W_DATA 0
#define BIT_MASK_LTECOEX_W_DATA 0xffffffffL
#define BIT_LTECOEX_W_DATA(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA) << BIT_SHIFT_LTECOEX_W_DATA)
#define BITS_LTECOEX_W_DATA \
(BIT_MASK_LTECOEX_W_DATA << BIT_SHIFT_LTECOEX_W_DATA)
#define BIT_CLEAR_LTECOEX_W_DATA(x) ((x) & (~BITS_LTECOEX_W_DATA))
#define BIT_GET_LTECOEX_W_DATA(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA) & BIT_MASK_LTECOEX_W_DATA)
#define BIT_SET_LTECOEX_W_DATA(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA(x) | BIT_LTECOEX_W_DATA(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_IQ_DUMP_1 (Offset 0x07C4) */
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC_1 0
#define BIT_MASK_R_WMAC_MASK_LA_MAC_1 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC_1(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC_1) \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1)
#define BITS_R_WMAC_MASK_LA_MAC_1 \
(BIT_MASK_R_WMAC_MASK_LA_MAC_1 << BIT_SHIFT_R_WMAC_MASK_LA_MAC_1)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC_1(x) ((x) & (~BITS_R_WMAC_MASK_LA_MAC_1))
#define BIT_GET_R_WMAC_MASK_LA_MAC_1(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC_1) & \
BIT_MASK_R_WMAC_MASK_LA_MAC_1)
#define BIT_SET_R_WMAC_MASK_LA_MAC_1(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC_1(x) | BIT_R_WMAC_MASK_LA_MAC_1(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA (Offset 0x07C8) */
#define BIT_SHIFT_LTECOEX_R_DATA 0
#define BIT_MASK_LTECOEX_R_DATA 0xffffffffL
#define BIT_LTECOEX_R_DATA(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA) << BIT_SHIFT_LTECOEX_R_DATA)
#define BITS_LTECOEX_R_DATA \
(BIT_MASK_LTECOEX_R_DATA << BIT_SHIFT_LTECOEX_R_DATA)
#define BIT_CLEAR_LTECOEX_R_DATA(x) ((x) & (~BITS_LTECOEX_R_DATA))
#define BIT_GET_LTECOEX_R_DATA(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA) & BIT_MASK_LTECOEX_R_DATA)
#define BIT_SET_LTECOEX_R_DATA(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA(x) | BIT_LTECOEX_R_DATA(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_IQ_DUMP_2 (Offset 0x07C8) */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2 0
#define BIT_MASK_R_WMAC_MATCH_REF_MAC_2 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC_2(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC_2) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2)
#define BITS_R_WMAC_MATCH_REF_MAC_2 \
(BIT_MASK_R_WMAC_MATCH_REF_MAC_2 << BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2(x) \
((x) & (~BITS_R_WMAC_MATCH_REF_MAC_2))
#define BIT_GET_R_WMAC_MATCH_REF_MAC_2(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC_2)
#define BIT_SET_R_WMAC_MATCH_REF_MAC_2(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2(x) | BIT_R_WMAC_MATCH_REF_MAC_2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_SHIFT_RX_STOPRXDMA_RXPOINT 16
#define BIT_MASK_RX_STOPRXDMA_RXPOINT 0xffff
#define BIT_RX_STOPRXDMA_RXPOINT(x) \
(((x) & BIT_MASK_RX_STOPRXDMA_RXPOINT) \
<< BIT_SHIFT_RX_STOPRXDMA_RXPOINT)
#define BITS_RX_STOPRXDMA_RXPOINT \
(BIT_MASK_RX_STOPRXDMA_RXPOINT << BIT_SHIFT_RX_STOPRXDMA_RXPOINT)
#define BIT_CLEAR_RX_STOPRXDMA_RXPOINT(x) ((x) & (~BITS_RX_STOPRXDMA_RXPOINT))
#define BIT_GET_RX_STOPRXDMA_RXPOINT(x) \
(((x) >> BIT_SHIFT_RX_STOPRXDMA_RXPOINT) & \
BIT_MASK_RX_STOPRXDMA_RXPOINT)
#define BIT_SET_RX_STOPRXDMA_RXPOINT(x, v) \
(BIT_CLEAR_RX_STOPRXDMA_RXPOINT(x) | BIT_RX_STOPRXDMA_RXPOINT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_RXFTM_TXACK_SC BIT(6)
#define BIT_RXFTM_TXACK_BW BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_RXFTM_STOPRXDMAEN BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_RXFTM_EN BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_RXFTMREQ_STOPRXDMAEN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_RXFTMREQ_BYDRV BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_FTM_CTL (Offset 0x07CC) */
#define BIT_RXFTMREQ_EN BIT(1)
#define BIT_FTM_EN BIT(0)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_IQ_DUMP_EXT (Offset 0x07CF) */
#define BIT_SHIFT_R_LA_MAC_TIMEOUT_UNIT_SEL 10
#define BIT_MASK_R_LA_MAC_TIMEOUT_UNIT_SEL 0x3
#define BIT_R_LA_MAC_TIMEOUT_UNIT_SEL(x) \
(((x) & BIT_MASK_R_LA_MAC_TIMEOUT_UNIT_SEL) \
<< BIT_SHIFT_R_LA_MAC_TIMEOUT_UNIT_SEL)
#define BITS_R_LA_MAC_TIMEOUT_UNIT_SEL \
(BIT_MASK_R_LA_MAC_TIMEOUT_UNIT_SEL \
<< BIT_SHIFT_R_LA_MAC_TIMEOUT_UNIT_SEL)
#define BIT_CLEAR_R_LA_MAC_TIMEOUT_UNIT_SEL(x) \
((x) & (~BITS_R_LA_MAC_TIMEOUT_UNIT_SEL))
#define BIT_GET_R_LA_MAC_TIMEOUT_UNIT_SEL(x) \
(((x) >> BIT_SHIFT_R_LA_MAC_TIMEOUT_UNIT_SEL) & \
BIT_MASK_R_LA_MAC_TIMEOUT_UNIT_SEL)
#define BIT_SET_R_LA_MAC_TIMEOUT_UNIT_SEL(x, v) \
(BIT_CLEAR_R_LA_MAC_TIMEOUT_UNIT_SEL(x) | \
BIT_R_LA_MAC_TIMEOUT_UNIT_SEL(v))
#define BIT_SHIFT_R_LA_MAC_TIMEOUT_VALUE 4
#define BIT_MASK_R_LA_MAC_TIMEOUT_VALUE 0x3f
#define BIT_R_LA_MAC_TIMEOUT_VALUE(x) \
(((x) & BIT_MASK_R_LA_MAC_TIMEOUT_VALUE) \
<< BIT_SHIFT_R_LA_MAC_TIMEOUT_VALUE)
#define BITS_R_LA_MAC_TIMEOUT_VALUE \
(BIT_MASK_R_LA_MAC_TIMEOUT_VALUE << BIT_SHIFT_R_LA_MAC_TIMEOUT_VALUE)
#define BIT_CLEAR_R_LA_MAC_TIMEOUT_VALUE(x) \
((x) & (~BITS_R_LA_MAC_TIMEOUT_VALUE))
#define BIT_GET_R_LA_MAC_TIMEOUT_VALUE(x) \
(((x) >> BIT_SHIFT_R_LA_MAC_TIMEOUT_VALUE) & \
BIT_MASK_R_LA_MAC_TIMEOUT_VALUE)
#define BIT_SET_R_LA_MAC_TIMEOUT_VALUE(x, v) \
(BIT_CLEAR_R_LA_MAC_TIMEOUT_VALUE(x) | BIT_R_LA_MAC_TIMEOUT_VALUE(v))
#define BIT_R_LEVEL_PULSE_SEL_EXTL BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_IQ_DUMP_EXT (Offset 0x07CF) */
#define BIT_SHIFT_R_TIME_UNIT_SEL 0
#define BIT_MASK_R_TIME_UNIT_SEL 0x7
#define BIT_R_TIME_UNIT_SEL(x) \
(((x) & BIT_MASK_R_TIME_UNIT_SEL) << BIT_SHIFT_R_TIME_UNIT_SEL)
#define BITS_R_TIME_UNIT_SEL \
(BIT_MASK_R_TIME_UNIT_SEL << BIT_SHIFT_R_TIME_UNIT_SEL)
#define BIT_CLEAR_R_TIME_UNIT_SEL(x) ((x) & (~BITS_R_TIME_UNIT_SEL))
#define BIT_GET_R_TIME_UNIT_SEL(x) \
(((x) >> BIT_SHIFT_R_TIME_UNIT_SEL) & BIT_MASK_R_TIME_UNIT_SEL)
#define BIT_SET_R_TIME_UNIT_SEL(x, v) \
(BIT_CLEAR_R_TIME_UNIT_SEL(x) | BIT_R_TIME_UNIT_SEL(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_OFDM_CCK_LEN_MASK (Offset 0x07D0) */
#define BIT_MICICV_CLR BIT(86)
#define BIT_MPDU_RDY_SET BIT(85)
#define BIT_CLR_SEC_TYPE BIT(84)
#define BIT_NEWPKT_IN BIT(83)
#define BIT_FCS_END BIT(82)
#define BIT_DEL_MESH_TYPE BIT(81)
#define BIT_MASK_MESH_TYPE BIT(80)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1 24
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH_1(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1)
#define BITS_R_WMAC_RXFIFO_FULL_TH_1 \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1 << BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1(x) \
((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH_1))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH_1(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH_1(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1(x) | BIT_R_WMAC_RXFIFO_FULL_TH_1(v))
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC_1 BIT(23)
#define BIT_R_WMAC_RXRST_DLY_1 BIT(22)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP_1 BIT(21)
#define BIT_R_WMAC_SRCH_TXRPT_UA1_1 BIT(20)
#define BIT_R_WMAC_SRCH_TXRPT_TYPE_1 BIT(19)
#define BIT_R_WMAC_NDP_RST_1 BIT(18)
#define BIT_R_WMAC_POWINT_EN_1 BIT(17)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT_1 BIT(16)
#define BIT_R_WMAC_SRCH_TXRPT_MID_1 BIT(15)
#define BIT_R_WMAC_PFIN_TOEN_1 BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_SECERR_V1 BIT(13)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_SECERR_1 BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_CTLPKTLEN_V1 BIT(12)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_CTLPKTLEN_1 BIT(12)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_FCTYPE_V1 BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_FCTYPE_1 BIT(11)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_FCPROVER_V1 BIT(10)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_R_WMAC_FIL_FCPROVER_1 BIT(10)
#define BIT_R_WMAC_PHYSTS_SNIF_1 BIT(9)
#define BIT_R_WMAC_PHYSTS_PLCP_1 BIT(8)
#define BIT_R_MAC_TCR_VBONF_RD_1 BIT(7)
#define BIT_R_WMAC_TCR_MPAR_NDP_1 BIT(6)
#define BIT_R_WMAC_NDP_FILTER_1 BIT(5)
#define BIT_R_WMAC_RXLEN_SEL_1 BIT(4)
#define BIT_R_WMAC_RXLEN_SEL1_1 BIT(3)
#define BIT_R_OFDM_FILTER_1 BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER1 (Offset 0x07D4) */
#define BIT_R_WMAC_CHK_OFDM_LEN_V1 BIT(1)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_R_WMAC_CHK_OFDM_LEN_1 BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER1 (Offset 0x07D4) */
#define BIT_R_WMAC_CHK_CCK_LEN_V1 BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_1 (Offset 0x07D4) */
#define BIT_R_WMAC_CHK_CCK_LEN_1 BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FA_FILTER2 (Offset 0x07D8) */
#define BIT_DEL_MESH_TYPE_V1 BIT(17)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_OPTION_FUNCTION_2 (Offset 0x07D8) */
#define BIT_SHIFT_R_WMAC_RX_FIL_LEN_2 0
#define BIT_MASK_R_WMAC_RX_FIL_LEN_2 0xffff
#define BIT_R_WMAC_RX_FIL_LEN_2(x) \
(((x) & BIT_MASK_R_WMAC_RX_FIL_LEN_2) << BIT_SHIFT_R_WMAC_RX_FIL_LEN_2)
#define BITS_R_WMAC_RX_FIL_LEN_2 \
(BIT_MASK_R_WMAC_RX_FIL_LEN_2 << BIT_SHIFT_R_WMAC_RX_FIL_LEN_2)
#define BIT_CLEAR_R_WMAC_RX_FIL_LEN_2(x) ((x) & (~BITS_R_WMAC_RX_FIL_LEN_2))
#define BIT_GET_R_WMAC_RX_FIL_LEN_2(x) \
(((x) >> BIT_SHIFT_R_WMAC_RX_FIL_LEN_2) & BIT_MASK_R_WMAC_RX_FIL_LEN_2)
#define BIT_SET_R_WMAC_RX_FIL_LEN_2(x, v) \
(BIT_CLEAR_R_WMAC_RX_FIL_LEN_2(x) | BIT_R_WMAC_RX_FIL_LEN_2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_WMAC_RXHANG_EN BIT(15)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_RXHANG_EN BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_WMAC_MHRDDY_LATCH BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_MHRDDY_CLR BIT(13)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_WMAC_MHRDDY_CLR BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY1 BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_WMAC_DIS_VHT_PLCP_CHK_MU BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_WMAC_DIS_VHT_PLCP_CHK_MU BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_RX_FILTER_FUNCTION (Offset 0x07DA) */
#define BIT_R_CHK_DELIMIT_LEN BIT(10)
#define BIT_R_REAPTER_ADDR_MATCH BIT(9)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY BIT(8)
#define BIT_R_LATCH_MACHRDY BIT(7)
#define BIT_R_WMAC_RXFIL_REND BIT(6)
#define BIT_R_WMAC_MPDURDY_CLR BIT(5)
#define BIT_R_WMAC_CLRRXSEC BIT(4)
#define BIT_R_WMAC_RXFIL_RDEL BIT(3)
#define BIT_R_WMAC_RXFIL_FCSE BIT(2)
#define BIT_R_WMAC_RXFIL_MESH_DEL BIT(1)
#define BIT_R_WMAC_RXFIL_MASKM BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_NDP_SIG (Offset 0x07E0) */
#define BIT_SHIFT_R_WMAC_TXNDP_SIGB 0
#define BIT_MASK_R_WMAC_TXNDP_SIGB 0x1fffff
#define BIT_R_WMAC_TXNDP_SIGB(x) \
(((x) & BIT_MASK_R_WMAC_TXNDP_SIGB) << BIT_SHIFT_R_WMAC_TXNDP_SIGB)
#define BITS_R_WMAC_TXNDP_SIGB \
(BIT_MASK_R_WMAC_TXNDP_SIGB << BIT_SHIFT_R_WMAC_TXNDP_SIGB)
#define BIT_CLEAR_R_WMAC_TXNDP_SIGB(x) ((x) & (~BITS_R_WMAC_TXNDP_SIGB))
#define BIT_GET_R_WMAC_TXNDP_SIGB(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXNDP_SIGB) & BIT_MASK_R_WMAC_TXNDP_SIGB)
#define BIT_SET_R_WMAC_TXNDP_SIGB(x, v) \
(BIT_CLEAR_R_WMAC_TXNDP_SIGB(x) | BIT_R_WMAC_TXNDP_SIGB(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT (Offset 0x07E4) */
#define BIT_SHIFT_R_MAC_DEBUG (32 & CPU_OPT_WIDTH)
#define BIT_MASK_R_MAC_DEBUG 0xffffffffL
#define BIT_R_MAC_DEBUG(x) \
(((x) & BIT_MASK_R_MAC_DEBUG) << BIT_SHIFT_R_MAC_DEBUG)
#define BITS_R_MAC_DEBUG (BIT_MASK_R_MAC_DEBUG << BIT_SHIFT_R_MAC_DEBUG)
#define BIT_CLEAR_R_MAC_DEBUG(x) ((x) & (~BITS_R_MAC_DEBUG))
#define BIT_GET_R_MAC_DEBUG(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG) & BIT_MASK_R_MAC_DEBUG)
#define BIT_SET_R_MAC_DEBUG(x, v) \
(BIT_CLEAR_R_MAC_DEBUG(x) | BIT_R_MAC_DEBUG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT (Offset 0x07E4) */
#define BIT_SHIFT_R_MAC_DBG_SHIFT 8
#define BIT_MASK_R_MAC_DBG_SHIFT 0x7
#define BIT_R_MAC_DBG_SHIFT(x) \
(((x) & BIT_MASK_R_MAC_DBG_SHIFT) << BIT_SHIFT_R_MAC_DBG_SHIFT)
#define BITS_R_MAC_DBG_SHIFT \
(BIT_MASK_R_MAC_DBG_SHIFT << BIT_SHIFT_R_MAC_DBG_SHIFT)
#define BIT_CLEAR_R_MAC_DBG_SHIFT(x) ((x) & (~BITS_R_MAC_DBG_SHIFT))
#define BIT_GET_R_MAC_DBG_SHIFT(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SHIFT) & BIT_MASK_R_MAC_DBG_SHIFT)
#define BIT_SET_R_MAC_DBG_SHIFT(x, v) \
(BIT_CLEAR_R_MAC_DBG_SHIFT(x) | BIT_R_MAC_DBG_SHIFT(v))
#define BIT_SHIFT_R_MAC_DBG_SEL 0
#define BIT_MASK_R_MAC_DBG_SEL 0x3
#define BIT_R_MAC_DBG_SEL(x) \
(((x) & BIT_MASK_R_MAC_DBG_SEL) << BIT_SHIFT_R_MAC_DBG_SEL)
#define BITS_R_MAC_DBG_SEL (BIT_MASK_R_MAC_DBG_SEL << BIT_SHIFT_R_MAC_DBG_SEL)
#define BIT_CLEAR_R_MAC_DBG_SEL(x) ((x) & (~BITS_R_MAC_DBG_SEL))
#define BIT_GET_R_MAC_DBG_SEL(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SEL) & BIT_MASK_R_MAC_DBG_SEL)
#define BIT_SET_R_MAC_DBG_SEL(x, v) \
(BIT_CLEAR_R_MAC_DBG_SEL(x) | BIT_R_MAC_DBG_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_1 (Offset 0x07E8) */
#define BIT_SHIFT_R_MAC_DEBUG_1 0
#define BIT_MASK_R_MAC_DEBUG_1 0xffffffffL
#define BIT_R_MAC_DEBUG_1(x) \
(((x) & BIT_MASK_R_MAC_DEBUG_1) << BIT_SHIFT_R_MAC_DEBUG_1)
#define BITS_R_MAC_DEBUG_1 (BIT_MASK_R_MAC_DEBUG_1 << BIT_SHIFT_R_MAC_DEBUG_1)
#define BIT_CLEAR_R_MAC_DEBUG_1(x) ((x) & (~BITS_R_MAC_DEBUG_1))
#define BIT_GET_R_MAC_DEBUG_1(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG_1) & BIT_MASK_R_MAC_DEBUG_1)
#define BIT_SET_R_MAC_DEBUG_1(x, v) \
(BIT_CLEAR_R_MAC_DEBUG_1(x) | BIT_R_MAC_DEBUG_1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WSEC_OPTION (Offset 0x07EC) */
#define BIT_RXDEC_BM_MGNT BIT(22)
#define BIT_TXENC_BM_MGNT BIT(21)
#define BIT_RXDEC_UNI_MGNT BIT(20)
#define BIT_TXENC_UNI_MGNT BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SEC_OPT_V2 (Offset 0x07EC) */
#define BIT_MASK_IV BIT(18)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WSEC_OPTION (Offset 0x07EC) */
#define BIT_WMAC_SEC_MASKIV BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SEC_OPT_V2 (Offset 0x07EC) */
#define BIT_EIVL_ENDIAN BIT(17)
#define BIT_EIVH_ENDIAN BIT(16)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WSEC_OPTION (Offset 0x07EC) */
#define BIT_SHIFT_WMAC_SEC_PN_SEL 16
#define BIT_MASK_WMAC_SEC_PN_SEL 0x3
#define BIT_WMAC_SEC_PN_SEL(x) \
(((x) & BIT_MASK_WMAC_SEC_PN_SEL) << BIT_SHIFT_WMAC_SEC_PN_SEL)
#define BITS_WMAC_SEC_PN_SEL \
(BIT_MASK_WMAC_SEC_PN_SEL << BIT_SHIFT_WMAC_SEC_PN_SEL)
#define BIT_CLEAR_WMAC_SEC_PN_SEL(x) ((x) & (~BITS_WMAC_SEC_PN_SEL))
#define BIT_GET_WMAC_SEC_PN_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_SEC_PN_SEL) & BIT_MASK_WMAC_SEC_PN_SEL)
#define BIT_SET_WMAC_SEC_PN_SEL(x, v) \
(BIT_CLEAR_WMAC_SEC_PN_SEL(x) | BIT_WMAC_SEC_PN_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WSEC_OPTION (Offset 0x07EC) */
#define BIT_SHIFT_BT_TIME_CNT 0
#define BIT_MASK_BT_TIME_CNT 0xff
#define BIT_BT_TIME_CNT(x) \
(((x) & BIT_MASK_BT_TIME_CNT) << BIT_SHIFT_BT_TIME_CNT)
#define BITS_BT_TIME_CNT (BIT_MASK_BT_TIME_CNT << BIT_SHIFT_BT_TIME_CNT)
#define BIT_CLEAR_BT_TIME_CNT(x) ((x) & (~BITS_BT_TIME_CNT))
#define BIT_GET_BT_TIME_CNT(x) \
(((x) >> BIT_SHIFT_BT_TIME_CNT) & BIT_MASK_BT_TIME_CNT)
#define BIT_SET_BT_TIME_CNT(x, v) \
(BIT_CLEAR_BT_TIME_CNT(x) | BIT_BT_TIME_CNT(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RTS_ADDRESS_0 (Offset 0x07F0) */
#define BIT_SHIFT_R_WMAC_RTS_ADDR0 0
#define BIT_MASK_R_WMAC_RTS_ADDR0 0xffffffffffffL
#define BIT_R_WMAC_RTS_ADDR0(x) \
(((x) & BIT_MASK_R_WMAC_RTS_ADDR0) << BIT_SHIFT_R_WMAC_RTS_ADDR0)
#define BITS_R_WMAC_RTS_ADDR0 \
(BIT_MASK_R_WMAC_RTS_ADDR0 << BIT_SHIFT_R_WMAC_RTS_ADDR0)
#define BIT_CLEAR_R_WMAC_RTS_ADDR0(x) ((x) & (~BITS_R_WMAC_RTS_ADDR0))
#define BIT_GET_R_WMAC_RTS_ADDR0(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTS_ADDR0) & BIT_MASK_R_WMAC_RTS_ADDR0)
#define BIT_SET_R_WMAC_RTS_ADDR0(x, v) \
(BIT_CLEAR_R_WMAC_RTS_ADDR0(x) | BIT_R_WMAC_RTS_ADDR0(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_RTS_ADDR0 (Offset 0x07F0) */
#define BIT_SHIFT_RTS_ADDR0 0
#define BIT_MASK_RTS_ADDR0 0xffffffffffffL
#define BIT_RTS_ADDR0(x) (((x) & BIT_MASK_RTS_ADDR0) << BIT_SHIFT_RTS_ADDR0)
#define BITS_RTS_ADDR0 (BIT_MASK_RTS_ADDR0 << BIT_SHIFT_RTS_ADDR0)
#define BIT_CLEAR_RTS_ADDR0(x) ((x) & (~BITS_RTS_ADDR0))
#define BIT_GET_RTS_ADDR0(x) (((x) >> BIT_SHIFT_RTS_ADDR0) & BIT_MASK_RTS_ADDR0)
#define BIT_SET_RTS_ADDR0(x, v) (BIT_CLEAR_RTS_ADDR0(x) | BIT_RTS_ADDR0(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_RTS_ADDRESS_1 (Offset 0x07F8) */
#define BIT_SHIFT_R_WMAC_RTS_ADDR1 0
#define BIT_MASK_R_WMAC_RTS_ADDR1 0xffffffffffffL
#define BIT_R_WMAC_RTS_ADDR1(x) \
(((x) & BIT_MASK_R_WMAC_RTS_ADDR1) << BIT_SHIFT_R_WMAC_RTS_ADDR1)
#define BITS_R_WMAC_RTS_ADDR1 \
(BIT_MASK_R_WMAC_RTS_ADDR1 << BIT_SHIFT_R_WMAC_RTS_ADDR1)
#define BIT_CLEAR_R_WMAC_RTS_ADDR1(x) ((x) & (~BITS_R_WMAC_RTS_ADDR1))
#define BIT_GET_R_WMAC_RTS_ADDR1(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTS_ADDR1) & BIT_MASK_R_WMAC_RTS_ADDR1)
#define BIT_SET_R_WMAC_RTS_ADDR1(x, v) \
(BIT_CLEAR_R_WMAC_RTS_ADDR1(x) | BIT_R_WMAC_RTS_ADDR1(v))
#endif
#if (HALMAC_8814AMP_SUPPORT)
/* 2 REG_RTS_ADDR1 (Offset 0x07F8) */
#define BIT_SHIFT_RTS_ADDR1 0
#define BIT_MASK_RTS_ADDR1 0xffffffffffffL
#define BIT_RTS_ADDR1(x) (((x) & BIT_MASK_RTS_ADDR1) << BIT_SHIFT_RTS_ADDR1)
#define BITS_RTS_ADDR1 (BIT_MASK_RTS_ADDR1 << BIT_SHIFT_RTS_ADDR1)
#define BIT_CLEAR_RTS_ADDR1(x) ((x) & (~BITS_RTS_ADDR1))
#define BIT_GET_RTS_ADDR1(x) (((x) >> BIT_SHIFT_RTS_ADDR1) & BIT_MASK_RTS_ADDR1)
#define BIT_SET_RTS_ADDR1(x, v) (BIT_CLEAR_RTS_ADDR1(x) | BIT_RTS_ADDR1(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG3 (Offset 0x1000) */
#define BIT_FEN_BB_GLB_RSTN_V1 BIT(17)
#define BIT_FEN_BBRSTB_V1 BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_CFG3 (Offset 0x1000) */
#define BIT_PWC_MA33V BIT(15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG3 (Offset 0x1000) */
#define BIT_PWC_EV25V_1 BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_SYS_CFG3 (Offset 0x1000) */
#define BIT_PWC_MA12V BIT(14)
#define BIT_PWC_MD12V BIT(13)
#define BIT_PWC_PD12V BIT(12)
#define BIT_PWC_UD12V BIT(11)
#define BIT_ISO_MA2MD BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_OCP_L BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_OCP_L_0 BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_POWOCP_L BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_CF_L_V2 28
#define BIT_MASK_CF_L_V2 0x3
#define BIT_CF_L_V2(x) (((x) & BIT_MASK_CF_L_V2) << BIT_SHIFT_CF_L_V2)
#define BITS_CF_L_V2 (BIT_MASK_CF_L_V2 << BIT_SHIFT_CF_L_V2)
#define BIT_CLEAR_CF_L_V2(x) ((x) & (~BITS_CF_L_V2))
#define BIT_GET_CF_L_V2(x) (((x) >> BIT_SHIFT_CF_L_V2) & BIT_MASK_CF_L_V2)
#define BIT_SET_CF_L_V2(x, v) (BIT_CLEAR_CF_L_V2(x) | BIT_CF_L_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_CF_L_1_0 28
#define BIT_MASK_CF_L_1_0 0x3
#define BIT_CF_L_1_0(x) (((x) & BIT_MASK_CF_L_1_0) << BIT_SHIFT_CF_L_1_0)
#define BITS_CF_L_1_0 (BIT_MASK_CF_L_1_0 << BIT_SHIFT_CF_L_1_0)
#define BIT_CLEAR_CF_L_1_0(x) ((x) & (~BITS_CF_L_1_0))
#define BIT_GET_CF_L_1_0(x) (((x) >> BIT_SHIFT_CF_L_1_0) & BIT_MASK_CF_L_1_0)
#define BIT_SET_CF_L_1_0(x, v) (BIT_CLEAR_CF_L_1_0(x) | BIT_CF_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_CFC_L_V2 26
#define BIT_MASK_CFC_L_V2 0x3
#define BIT_CFC_L_V2(x) (((x) & BIT_MASK_CFC_L_V2) << BIT_SHIFT_CFC_L_V2)
#define BITS_CFC_L_V2 (BIT_MASK_CFC_L_V2 << BIT_SHIFT_CFC_L_V2)
#define BIT_CLEAR_CFC_L_V2(x) ((x) & (~BITS_CFC_L_V2))
#define BIT_GET_CFC_L_V2(x) (((x) >> BIT_SHIFT_CFC_L_V2) & BIT_MASK_CFC_L_V2)
#define BIT_SET_CFC_L_V2(x, v) (BIT_CLEAR_CFC_L_V2(x) | BIT_CFC_L_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_CFC_L_1_0 26
#define BIT_MASK_CFC_L_1_0 0x3
#define BIT_CFC_L_1_0(x) (((x) & BIT_MASK_CFC_L_1_0) << BIT_SHIFT_CFC_L_1_0)
#define BITS_CFC_L_1_0 (BIT_MASK_CFC_L_1_0 << BIT_SHIFT_CFC_L_1_0)
#define BIT_CLEAR_CFC_L_1_0(x) ((x) & (~BITS_CFC_L_1_0))
#define BIT_GET_CFC_L_1_0(x) (((x) >> BIT_SHIFT_CFC_L_1_0) & BIT_MASK_CFC_L_1_0)
#define BIT_SET_CFC_L_1_0(x, v) (BIT_CLEAR_CFC_L_1_0(x) | BIT_CFC_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_R3_L_V2 24
#define BIT_MASK_R3_L_V2 0x3
#define BIT_R3_L_V2(x) (((x) & BIT_MASK_R3_L_V2) << BIT_SHIFT_R3_L_V2)
#define BITS_R3_L_V2 (BIT_MASK_R3_L_V2 << BIT_SHIFT_R3_L_V2)
#define BIT_CLEAR_R3_L_V2(x) ((x) & (~BITS_R3_L_V2))
#define BIT_GET_R3_L_V2(x) (((x) >> BIT_SHIFT_R3_L_V2) & BIT_MASK_R3_L_V2)
#define BIT_SET_R3_L_V2(x, v) (BIT_CLEAR_R3_L_V2(x) | BIT_R3_L_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_R3_L_1_0 24
#define BIT_MASK_R3_L_1_0 0x3
#define BIT_R3_L_1_0(x) (((x) & BIT_MASK_R3_L_1_0) << BIT_SHIFT_R3_L_1_0)
#define BITS_R3_L_1_0 (BIT_MASK_R3_L_1_0 << BIT_SHIFT_R3_L_1_0)
#define BIT_CLEAR_R3_L_1_0(x) ((x) & (~BITS_R3_L_1_0))
#define BIT_GET_R3_L_1_0(x) (((x) >> BIT_SHIFT_R3_L_1_0) & BIT_MASK_R3_L_1_0)
#define BIT_SET_R3_L_1_0(x, v) (BIT_CLEAR_R3_L_1_0(x) | BIT_R3_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_R2_L 22
#define BIT_MASK_R2_L 0x3
#define BIT_R2_L(x) (((x) & BIT_MASK_R2_L) << BIT_SHIFT_R2_L)
#define BITS_R2_L (BIT_MASK_R2_L << BIT_SHIFT_R2_L)
#define BIT_CLEAR_R2_L(x) ((x) & (~BITS_R2_L))
#define BIT_GET_R2_L(x) (((x) >> BIT_SHIFT_R2_L) & BIT_MASK_R2_L)
#define BIT_SET_R2_L(x, v) (BIT_CLEAR_R2_L(x) | BIT_R2_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_R2_L_1_0 22
#define BIT_MASK_R2_L_1_0 0x3
#define BIT_R2_L_1_0(x) (((x) & BIT_MASK_R2_L_1_0) << BIT_SHIFT_R2_L_1_0)
#define BITS_R2_L_1_0 (BIT_MASK_R2_L_1_0 << BIT_SHIFT_R2_L_1_0)
#define BIT_CLEAR_R2_L_1_0(x) ((x) & (~BITS_R2_L_1_0))
#define BIT_GET_R2_L_1_0(x) (((x) >> BIT_SHIFT_R2_L_1_0) & BIT_MASK_R2_L_1_0)
#define BIT_SET_R2_L_1_0(x, v) (BIT_CLEAR_R2_L_1_0(x) | BIT_R2_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_R1_L 20
#define BIT_MASK_R1_L 0x3
#define BIT_R1_L(x) (((x) & BIT_MASK_R1_L) << BIT_SHIFT_R1_L)
#define BITS_R1_L (BIT_MASK_R1_L << BIT_SHIFT_R1_L)
#define BIT_CLEAR_R1_L(x) ((x) & (~BITS_R1_L))
#define BIT_GET_R1_L(x) (((x) >> BIT_SHIFT_R1_L) & BIT_MASK_R1_L)
#define BIT_SET_R1_L(x, v) (BIT_CLEAR_R1_L(x) | BIT_R1_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_R1_L_1_0 20
#define BIT_MASK_R1_L_1_0 0x3
#define BIT_R1_L_1_0(x) (((x) & BIT_MASK_R1_L_1_0) << BIT_SHIFT_R1_L_1_0)
#define BITS_R1_L_1_0 (BIT_MASK_R1_L_1_0 << BIT_SHIFT_R1_L_1_0)
#define BIT_CLEAR_R1_L_1_0(x) ((x) & (~BITS_R1_L_1_0))
#define BIT_GET_R1_L_1_0(x) (((x) >> BIT_SHIFT_R1_L_1_0) & BIT_MASK_R1_L_1_0)
#define BIT_SET_R1_L_1_0(x, v) (BIT_CLEAR_R1_L_1_0(x) | BIT_R1_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_C3_L 18
#define BIT_MASK_C3_L 0x3
#define BIT_C3_L(x) (((x) & BIT_MASK_C3_L) << BIT_SHIFT_C3_L)
#define BITS_C3_L (BIT_MASK_C3_L << BIT_SHIFT_C3_L)
#define BIT_CLEAR_C3_L(x) ((x) & (~BITS_C3_L))
#define BIT_GET_C3_L(x) (((x) >> BIT_SHIFT_C3_L) & BIT_MASK_C3_L)
#define BIT_SET_C3_L(x, v) (BIT_CLEAR_C3_L(x) | BIT_C3_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_C3_L_1_0 18
#define BIT_MASK_C3_L_1_0 0x3
#define BIT_C3_L_1_0(x) (((x) & BIT_MASK_C3_L_1_0) << BIT_SHIFT_C3_L_1_0)
#define BITS_C3_L_1_0 (BIT_MASK_C3_L_1_0 << BIT_SHIFT_C3_L_1_0)
#define BIT_CLEAR_C3_L_1_0(x) ((x) & (~BITS_C3_L_1_0))
#define BIT_GET_C3_L_1_0(x) (((x) >> BIT_SHIFT_C3_L_1_0) & BIT_MASK_C3_L_1_0)
#define BIT_SET_C3_L_1_0(x, v) (BIT_CLEAR_C3_L_1_0(x) | BIT_C3_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_C2_L 16
#define BIT_MASK_C2_L 0x3
#define BIT_C2_L(x) (((x) & BIT_MASK_C2_L) << BIT_SHIFT_C2_L)
#define BITS_C2_L (BIT_MASK_C2_L << BIT_SHIFT_C2_L)
#define BIT_CLEAR_C2_L(x) ((x) & (~BITS_C2_L))
#define BIT_GET_C2_L(x) (((x) >> BIT_SHIFT_C2_L) & BIT_MASK_C2_L)
#define BIT_SET_C2_L(x, v) (BIT_CLEAR_C2_L(x) | BIT_C2_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_C2_L_1_0 16
#define BIT_MASK_C2_L_1_0 0x3
#define BIT_C2_L_1_0(x) (((x) & BIT_MASK_C2_L_1_0) << BIT_SHIFT_C2_L_1_0)
#define BITS_C2_L_1_0 (BIT_MASK_C2_L_1_0 << BIT_SHIFT_C2_L_1_0)
#define BIT_CLEAR_C2_L_1_0(x) ((x) & (~BITS_C2_L_1_0))
#define BIT_GET_C2_L_1_0(x) (((x) >> BIT_SHIFT_C2_L_1_0) & BIT_MASK_C2_L_1_0)
#define BIT_SET_C2_L_1_0(x, v) (BIT_CLEAR_C2_L_1_0(x) | BIT_C2_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_C1_L_V2 14
#define BIT_MASK_C1_L_V2 0x3
#define BIT_C1_L_V2(x) (((x) & BIT_MASK_C1_L_V2) << BIT_SHIFT_C1_L_V2)
#define BITS_C1_L_V2 (BIT_MASK_C1_L_V2 << BIT_SHIFT_C1_L_V2)
#define BIT_CLEAR_C1_L_V2(x) ((x) & (~BITS_C1_L_V2))
#define BIT_GET_C1_L_V2(x) (((x) >> BIT_SHIFT_C1_L_V2) & BIT_MASK_C1_L_V2)
#define BIT_SET_C1_L_V2(x, v) (BIT_CLEAR_C1_L_V2(x) | BIT_C1_L_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_C1_L_1_0 14
#define BIT_MASK_C1_L_1_0 0x3
#define BIT_C1_L_1_0(x) (((x) & BIT_MASK_C1_L_1_0) << BIT_SHIFT_C1_L_1_0)
#define BITS_C1_L_1_0 (BIT_MASK_C1_L_1_0 << BIT_SHIFT_C1_L_1_0)
#define BIT_CLEAR_C1_L_1_0(x) ((x) & (~BITS_C1_L_1_0))
#define BIT_GET_C1_L_1_0(x) (((x) >> BIT_SHIFT_C1_L_1_0) & BIT_MASK_C1_L_1_0)
#define BIT_SET_C1_L_1_0(x, v) (BIT_CLEAR_C1_L_1_0(x) | BIT_C1_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_REG_TYPE_L_V2 BIT(13)
#define BIT_REG_PWM_L BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_V15ADJ_L 9
#define BIT_MASK_V15ADJ_L 0x7
#define BIT_V15ADJ_L(x) (((x) & BIT_MASK_V15ADJ_L) << BIT_SHIFT_V15ADJ_L)
#define BITS_V15ADJ_L (BIT_MASK_V15ADJ_L << BIT_SHIFT_V15ADJ_L)
#define BIT_CLEAR_V15ADJ_L(x) ((x) & (~BITS_V15ADJ_L))
#define BIT_GET_V15ADJ_L(x) (((x) >> BIT_SHIFT_V15ADJ_L) & BIT_MASK_V15ADJ_L)
#define BIT_SET_V15ADJ_L(x, v) (BIT_CLEAR_V15ADJ_L(x) | BIT_V15ADJ_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_V15ADJ_L_2_0 9
#define BIT_MASK_V15ADJ_L_2_0 0x7
#define BIT_V15ADJ_L_2_0(x) \
(((x) & BIT_MASK_V15ADJ_L_2_0) << BIT_SHIFT_V15ADJ_L_2_0)
#define BITS_V15ADJ_L_2_0 (BIT_MASK_V15ADJ_L_2_0 << BIT_SHIFT_V15ADJ_L_2_0)
#define BIT_CLEAR_V15ADJ_L_2_0(x) ((x) & (~BITS_V15ADJ_L_2_0))
#define BIT_GET_V15ADJ_L_2_0(x) \
(((x) >> BIT_SHIFT_V15ADJ_L_2_0) & BIT_MASK_V15ADJ_L_2_0)
#define BIT_SET_V15ADJ_L_2_0(x, v) \
(BIT_CLEAR_V15ADJ_L_2_0(x) | BIT_V15ADJ_L_2_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_IN_L 6
#define BIT_MASK_IN_L 0x7
#define BIT_IN_L(x) (((x) & BIT_MASK_IN_L) << BIT_SHIFT_IN_L)
#define BITS_IN_L (BIT_MASK_IN_L << BIT_SHIFT_IN_L)
#define BIT_CLEAR_IN_L(x) ((x) & (~BITS_IN_L))
#define BIT_GET_IN_L(x) (((x) >> BIT_SHIFT_IN_L) & BIT_MASK_IN_L)
#define BIT_SET_IN_L(x, v) (BIT_CLEAR_IN_L(x) | BIT_IN_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_IN_L_2_0 6
#define BIT_MASK_IN_L_2_0 0x7
#define BIT_IN_L_2_0(x) (((x) & BIT_MASK_IN_L_2_0) << BIT_SHIFT_IN_L_2_0)
#define BITS_IN_L_2_0 (BIT_MASK_IN_L_2_0 << BIT_SHIFT_IN_L_2_0)
#define BIT_CLEAR_IN_L_2_0(x) ((x) & (~BITS_IN_L_2_0))
#define BIT_GET_IN_L_2_0(x) (((x) >> BIT_SHIFT_IN_L_2_0) & BIT_MASK_IN_L_2_0)
#define BIT_SET_IN_L_2_0(x, v) (BIT_CLEAR_IN_L_2_0(x) | BIT_IN_L_2_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_STD_L 4
#define BIT_MASK_STD_L 0x3
#define BIT_STD_L(x) (((x) & BIT_MASK_STD_L) << BIT_SHIFT_STD_L)
#define BITS_STD_L (BIT_MASK_STD_L << BIT_SHIFT_STD_L)
#define BIT_CLEAR_STD_L(x) ((x) & (~BITS_STD_L))
#define BIT_GET_STD_L(x) (((x) >> BIT_SHIFT_STD_L) & BIT_MASK_STD_L)
#define BIT_SET_STD_L(x, v) (BIT_CLEAR_STD_L(x) | BIT_STD_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_STD_L_1_0 4
#define BIT_MASK_STD_L_1_0 0x3
#define BIT_STD_L_1_0(x) (((x) & BIT_MASK_STD_L_1_0) << BIT_SHIFT_STD_L_1_0)
#define BITS_STD_L_1_0 (BIT_MASK_STD_L_1_0 << BIT_SHIFT_STD_L_1_0)
#define BIT_CLEAR_STD_L_1_0(x) ((x) & (~BITS_STD_L_1_0))
#define BIT_GET_STD_L_1_0(x) (((x) >> BIT_SHIFT_STD_L_1_0) & BIT_MASK_STD_L_1_0)
#define BIT_SET_STD_L_1_0(x, v) (BIT_CLEAR_STD_L_1_0(x) | BIT_STD_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_VOL_L 0
#define BIT_MASK_VOL_L 0xf
#define BIT_VOL_L(x) (((x) & BIT_MASK_VOL_L) << BIT_SHIFT_VOL_L)
#define BITS_VOL_L (BIT_MASK_VOL_L << BIT_SHIFT_VOL_L)
#define BIT_CLEAR_VOL_L(x) ((x) & (~BITS_VOL_L))
#define BIT_GET_VOL_L(x) (((x) >> BIT_SHIFT_VOL_L) & BIT_MASK_VOL_L)
#define BIT_SET_VOL_L(x, v) (BIT_CLEAR_VOL_L(x) | BIT_VOL_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_0 (Offset 0x1010) */
#define BIT_SHIFT_VOL_L_3_0 0
#define BIT_MASK_VOL_L_3_0 0xf
#define BIT_VOL_L_3_0(x) (((x) & BIT_MASK_VOL_L_3_0) << BIT_SHIFT_VOL_L_3_0)
#define BITS_VOL_L_3_0 (BIT_MASK_VOL_L_3_0 << BIT_SHIFT_VOL_L_3_0)
#define BIT_CLEAR_VOL_L_3_0(x) ((x) & (~BITS_VOL_L_3_0))
#define BIT_GET_VOL_L_3_0(x) (((x) >> BIT_SHIFT_VOL_L_3_0) & BIT_MASK_VOL_L_3_0)
#define BIT_SET_VOL_L_3_0(x, v) (BIT_CLEAR_VOL_L_3_0(x) | BIT_VOL_L_3_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_OCP_L_PFM 29
#define BIT_MASK_OCP_L_PFM 0x7
#define BIT_OCP_L_PFM(x) (((x) & BIT_MASK_OCP_L_PFM) << BIT_SHIFT_OCP_L_PFM)
#define BITS_OCP_L_PFM (BIT_MASK_OCP_L_PFM << BIT_SHIFT_OCP_L_PFM)
#define BIT_CLEAR_OCP_L_PFM(x) ((x) & (~BITS_OCP_L_PFM))
#define BIT_GET_OCP_L_PFM(x) (((x) >> BIT_SHIFT_OCP_L_PFM) & BIT_MASK_OCP_L_PFM)
#define BIT_SET_OCP_L_PFM(x, v) (BIT_CLEAR_OCP_L_PFM(x) | BIT_OCP_L_PFM(v))
#define BIT_SHIFT_CFC_L_PFM 27
#define BIT_MASK_CFC_L_PFM 0x3
#define BIT_CFC_L_PFM(x) (((x) & BIT_MASK_CFC_L_PFM) << BIT_SHIFT_CFC_L_PFM)
#define BITS_CFC_L_PFM (BIT_MASK_CFC_L_PFM << BIT_SHIFT_CFC_L_PFM)
#define BIT_CLEAR_CFC_L_PFM(x) ((x) & (~BITS_CFC_L_PFM))
#define BIT_GET_CFC_L_PFM(x) (((x) >> BIT_SHIFT_CFC_L_PFM) & BIT_MASK_CFC_L_PFM)
#define BIT_SET_CFC_L_PFM(x, v) (BIT_CLEAR_CFC_L_PFM(x) | BIT_CFC_L_PFM(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_REG_FREQ_L_V1 20
#define BIT_MASK_REG_FREQ_L_V1 0x7
#define BIT_REG_FREQ_L_V1(x) \
(((x) & BIT_MASK_REG_FREQ_L_V1) << BIT_SHIFT_REG_FREQ_L_V1)
#define BITS_REG_FREQ_L_V1 (BIT_MASK_REG_FREQ_L_V1 << BIT_SHIFT_REG_FREQ_L_V1)
#define BIT_CLEAR_REG_FREQ_L_V1(x) ((x) & (~BITS_REG_FREQ_L_V1))
#define BIT_GET_REG_FREQ_L_V1(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L_V1) & BIT_MASK_REG_FREQ_L_V1)
#define BIT_SET_REG_FREQ_L_V1(x, v) \
(BIT_CLEAR_REG_FREQ_L_V1(x) | BIT_REG_FREQ_L_V1(v))
#define BIT_EN_DUTY BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_REG_MODE_V2 17
#define BIT_MASK_REG_MODE_V2 0x3
#define BIT_REG_MODE_V2(x) \
(((x) & BIT_MASK_REG_MODE_V2) << BIT_SHIFT_REG_MODE_V2)
#define BITS_REG_MODE_V2 (BIT_MASK_REG_MODE_V2 << BIT_SHIFT_REG_MODE_V2)
#define BIT_CLEAR_REG_MODE_V2(x) ((x) & (~BITS_REG_MODE_V2))
#define BIT_GET_REG_MODE_V2(x) \
(((x) >> BIT_SHIFT_REG_MODE_V2) & BIT_MASK_REG_MODE_V2)
#define BIT_SET_REG_MODE_V2(x, v) \
(BIT_CLEAR_REG_MODE_V2(x) | BIT_REG_MODE_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_REG_MOS_HALF 17
#define BIT_MASK_REG_MOS_HALF 0x3
#define BIT_REG_MOS_HALF(x) \
(((x) & BIT_MASK_REG_MOS_HALF) << BIT_SHIFT_REG_MOS_HALF)
#define BITS_REG_MOS_HALF (BIT_MASK_REG_MOS_HALF << BIT_SHIFT_REG_MOS_HALF)
#define BIT_CLEAR_REG_MOS_HALF(x) ((x) & (~BITS_REG_MOS_HALF))
#define BIT_GET_REG_MOS_HALF(x) \
(((x) >> BIT_SHIFT_REG_MOS_HALF) & BIT_MASK_REG_MOS_HALF)
#define BIT_SET_REG_MOS_HALF(x, v) \
(BIT_CLEAR_REG_MOS_HALF(x) | BIT_REG_MOS_HALF(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_EN_SP BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_AUTO_L_V2 BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_AUTO_L_V1 BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_LDOF_L_V2 BIT(14)
#define BIT_REG_OCPS_L_V2 BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_VO15_V1P05_H BIT(12)
#define BIT_ARENB_L_V2 BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_ARENB_L_V1 BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_TBOX_L1_V2 9
#define BIT_MASK_TBOX_L1_V2 0x3
#define BIT_TBOX_L1_V2(x) (((x) & BIT_MASK_TBOX_L1_V2) << BIT_SHIFT_TBOX_L1_V2)
#define BITS_TBOX_L1_V2 (BIT_MASK_TBOX_L1_V2 << BIT_SHIFT_TBOX_L1_V2)
#define BIT_CLEAR_TBOX_L1_V2(x) ((x) & (~BITS_TBOX_L1_V2))
#define BIT_GET_TBOX_L1_V2(x) \
(((x) >> BIT_SHIFT_TBOX_L1_V2) & BIT_MASK_TBOX_L1_V2)
#define BIT_SET_TBOX_L1_V2(x, v) (BIT_CLEAR_TBOX_L1_V2(x) | BIT_TBOX_L1_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_TBOX_L1_1_0 9
#define BIT_MASK_TBOX_L1_1_0 0x3
#define BIT_TBOX_L1_1_0(x) \
(((x) & BIT_MASK_TBOX_L1_1_0) << BIT_SHIFT_TBOX_L1_1_0)
#define BITS_TBOX_L1_1_0 (BIT_MASK_TBOX_L1_1_0 << BIT_SHIFT_TBOX_L1_1_0)
#define BIT_CLEAR_TBOX_L1_1_0(x) ((x) & (~BITS_TBOX_L1_1_0))
#define BIT_GET_TBOX_L1_1_0(x) \
(((x) >> BIT_SHIFT_TBOX_L1_1_0) & BIT_MASK_TBOX_L1_1_0)
#define BIT_SET_TBOX_L1_1_0(x, v) \
(BIT_CLEAR_TBOX_L1_1_0(x) | BIT_TBOX_L1_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_REG_DELAY_L 7
#define BIT_MASK_REG_DELAY_L 0x3
#define BIT_REG_DELAY_L(x) \
(((x) & BIT_MASK_REG_DELAY_L) << BIT_SHIFT_REG_DELAY_L)
#define BITS_REG_DELAY_L (BIT_MASK_REG_DELAY_L << BIT_SHIFT_REG_DELAY_L)
#define BIT_CLEAR_REG_DELAY_L(x) ((x) & (~BITS_REG_DELAY_L))
#define BIT_GET_REG_DELAY_L(x) \
(((x) >> BIT_SHIFT_REG_DELAY_L) & BIT_MASK_REG_DELAY_L)
#define BIT_SET_REG_DELAY_L(x, v) \
(BIT_CLEAR_REG_DELAY_L(x) | BIT_REG_DELAY_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_REG_DELAY_L_1_0 7
#define BIT_MASK_REG_DELAY_L_1_0 0x3
#define BIT_REG_DELAY_L_1_0(x) \
(((x) & BIT_MASK_REG_DELAY_L_1_0) << BIT_SHIFT_REG_DELAY_L_1_0)
#define BITS_REG_DELAY_L_1_0 \
(BIT_MASK_REG_DELAY_L_1_0 << BIT_SHIFT_REG_DELAY_L_1_0)
#define BIT_CLEAR_REG_DELAY_L_1_0(x) ((x) & (~BITS_REG_DELAY_L_1_0))
#define BIT_GET_REG_DELAY_L_1_0(x) \
(((x) >> BIT_SHIFT_REG_DELAY_L_1_0) & BIT_MASK_REG_DELAY_L_1_0)
#define BIT_SET_REG_DELAY_L_1_0(x, v) \
(BIT_CLEAR_REG_DELAY_L_1_0(x) | BIT_REG_DELAY_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_CLAMP_D_L BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_BYPASS_L_V2 BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_BYPASS_L_V1 BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_AUTOZCD_L BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_POW_ZCD_L_V2 BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_POW_ZCD_L_V1 BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_REG_HALF_L BIT(2)
#define BIT_SHIFT_OCP_L_V2 0
#define BIT_MASK_OCP_L_V2 0x3
#define BIT_OCP_L_V2(x) (((x) & BIT_MASK_OCP_L_V2) << BIT_SHIFT_OCP_L_V2)
#define BITS_OCP_L_V2 (BIT_MASK_OCP_L_V2 << BIT_SHIFT_OCP_L_V2)
#define BIT_CLEAR_OCP_L_V2(x) ((x) & (~BITS_OCP_L_V2))
#define BIT_GET_OCP_L_V2(x) (((x) >> BIT_SHIFT_OCP_L_V2) & BIT_MASK_OCP_L_V2)
#define BIT_SET_OCP_L_V2(x, v) (BIT_CLEAR_OCP_L_V2(x) | BIT_OCP_L_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPARSW_MAC_1 (Offset 0x1014) */
#define BIT_SHIFT_OCP_L_2_1 0
#define BIT_MASK_OCP_L_2_1 0x3
#define BIT_OCP_L_2_1(x) (((x) & BIT_MASK_OCP_L_2_1) << BIT_SHIFT_OCP_L_2_1)
#define BITS_OCP_L_2_1 (BIT_MASK_OCP_L_2_1 << BIT_SHIFT_OCP_L_2_1)
#define BIT_CLEAR_OCP_L_2_1(x) ((x) & (~BITS_OCP_L_2_1))
#define BIT_GET_OCP_L_2_1(x) (((x) >> BIT_SHIFT_OCP_L_2_1) & BIT_MASK_OCP_L_2_1)
#define BIT_SET_OCP_L_2_1(x, v) (BIT_CLEAR_OCP_L_2_1(x) | BIT_OCP_L_2_1(v))
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_LPF_C2_1_0 30
#define BIT_MASK_LPF_C2_1_0 0x3
#define BIT_LPF_C2_1_0(x) (((x) & BIT_MASK_LPF_C2_1_0) << BIT_SHIFT_LPF_C2_1_0)
#define BITS_LPF_C2_1_0 (BIT_MASK_LPF_C2_1_0 << BIT_SHIFT_LPF_C2_1_0)
#define BIT_CLEAR_LPF_C2_1_0(x) ((x) & (~BITS_LPF_C2_1_0))
#define BIT_GET_LPF_C2_1_0(x) \
(((x) >> BIT_SHIFT_LPF_C2_1_0) & BIT_MASK_LPF_C2_1_0)
#define BIT_SET_LPF_C2_1_0(x, v) (BIT_CLEAR_LPF_C2_1_0(x) | BIT_LPF_C2_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_LPF_R3 29
#define BIT_MASK_REG_LPF_R3 0x7
#define BIT_REG_LPF_R3(x) (((x) & BIT_MASK_REG_LPF_R3) << BIT_SHIFT_REG_LPF_R3)
#define BITS_REG_LPF_R3 (BIT_MASK_REG_LPF_R3 << BIT_SHIFT_REG_LPF_R3)
#define BIT_CLEAR_REG_LPF_R3(x) ((x) & (~BITS_REG_LPF_R3))
#define BIT_GET_REG_LPF_R3(x) \
(((x) >> BIT_SHIFT_REG_LPF_R3) & BIT_MASK_REG_LPF_R3)
#define BIT_SET_REG_LPF_R3(x, v) (BIT_CLEAR_REG_LPF_R3(x) | BIT_REG_LPF_R3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_EN_XTAL_AAC_TRIG BIT(28)
#define BIT_EN_XTAL_AAC BIT(27)
#define BIT_EN_XTAL_AAC_DIGI BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_LPF_R2 24
#define BIT_MASK_REG_LPF_R2 0x1f
#define BIT_REG_LPF_R2(x) (((x) & BIT_MASK_REG_LPF_R2) << BIT_SHIFT_REG_LPF_R2)
#define BITS_REG_LPF_R2 (BIT_MASK_REG_LPF_R2 << BIT_SHIFT_REG_LPF_R2)
#define BIT_CLEAR_REG_LPF_R2(x) ((x) & (~BITS_REG_LPF_R2))
#define BIT_GET_REG_LPF_R2(x) \
(((x) >> BIT_SHIFT_REG_LPF_R2) & BIT_MASK_REG_LPF_R2)
#define BIT_SET_REG_LPF_R2(x, v) (BIT_CLEAR_REG_LPF_R2(x) | BIT_REG_LPF_R2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_LPF_C1_5_0 24
#define BIT_MASK_LPF_C1_5_0 0x3f
#define BIT_LPF_C1_5_0(x) (((x) & BIT_MASK_LPF_C1_5_0) << BIT_SHIFT_LPF_C1_5_0)
#define BITS_LPF_C1_5_0 (BIT_MASK_LPF_C1_5_0 << BIT_SHIFT_LPF_C1_5_0)
#define BIT_CLEAR_LPF_C1_5_0(x) ((x) & (~BITS_LPF_C1_5_0))
#define BIT_GET_LPF_C1_5_0(x) \
(((x) >> BIT_SHIFT_LPF_C1_5_0) & BIT_MASK_LPF_C1_5_0)
#define BIT_SET_LPF_C1_5_0(x, v) (BIT_CLEAR_LPF_C1_5_0(x) | BIT_LPF_C1_5_0(v))
#define BIT_LPF_TIEL BIT(23)
#define BIT_LPF_TIEH BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_LPF_C3 21
#define BIT_MASK_REG_LPF_C3 0x7
#define BIT_REG_LPF_C3(x) (((x) & BIT_MASK_REG_LPF_C3) << BIT_SHIFT_REG_LPF_C3)
#define BITS_REG_LPF_C3 (BIT_MASK_REG_LPF_C3 << BIT_SHIFT_REG_LPF_C3)
#define BIT_CLEAR_REG_LPF_C3(x) ((x) & (~BITS_REG_LPF_C3))
#define BIT_GET_REG_LPF_C3(x) \
(((x) >> BIT_SHIFT_REG_LPF_C3) & BIT_MASK_REG_LPF_C3)
#define BIT_SET_REG_LPF_C3(x, v) (BIT_CLEAR_REG_LPF_C3(x) | BIT_REG_LPF_C3(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_LOCKDET_VREF_L_1_0 20
#define BIT_MASK_LOCKDET_VREF_L_1_0 0x3
#define BIT_LOCKDET_VREF_L_1_0(x) \
(((x) & BIT_MASK_LOCKDET_VREF_L_1_0) << BIT_SHIFT_LOCKDET_VREF_L_1_0)
#define BITS_LOCKDET_VREF_L_1_0 \
(BIT_MASK_LOCKDET_VREF_L_1_0 << BIT_SHIFT_LOCKDET_VREF_L_1_0)
#define BIT_CLEAR_LOCKDET_VREF_L_1_0(x) ((x) & (~BITS_LOCKDET_VREF_L_1_0))
#define BIT_GET_LOCKDET_VREF_L_1_0(x) \
(((x) >> BIT_SHIFT_LOCKDET_VREF_L_1_0) & BIT_MASK_LOCKDET_VREF_L_1_0)
#define BIT_SET_LOCKDET_VREF_L_1_0(x, v) \
(BIT_CLEAR_LOCKDET_VREF_L_1_0(x) | BIT_LOCKDET_VREF_L_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_LPF_C2 18
#define BIT_MASK_REG_LPF_C2 0x7
#define BIT_REG_LPF_C2(x) (((x) & BIT_MASK_REG_LPF_C2) << BIT_SHIFT_REG_LPF_C2)
#define BITS_REG_LPF_C2 (BIT_MASK_REG_LPF_C2 << BIT_SHIFT_REG_LPF_C2)
#define BIT_CLEAR_REG_LPF_C2(x) ((x) & (~BITS_REG_LPF_C2))
#define BIT_GET_REG_LPF_C2(x) \
(((x) >> BIT_SHIFT_REG_LPF_C2) & BIT_MASK_REG_LPF_C2)
#define BIT_SET_REG_LPF_C2(x, v) (BIT_CLEAR_REG_LPF_C2(x) | BIT_REG_LPF_C2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_LOCKDET_VREF_H_1_0 18
#define BIT_MASK_LOCKDET_VREF_H_1_0 0x3
#define BIT_LOCKDET_VREF_H_1_0(x) \
(((x) & BIT_MASK_LOCKDET_VREF_H_1_0) << BIT_SHIFT_LOCKDET_VREF_H_1_0)
#define BITS_LOCKDET_VREF_H_1_0 \
(BIT_MASK_LOCKDET_VREF_H_1_0 << BIT_SHIFT_LOCKDET_VREF_H_1_0)
#define BIT_CLEAR_LOCKDET_VREF_H_1_0(x) ((x) & (~BITS_LOCKDET_VREF_H_1_0))
#define BIT_GET_LOCKDET_VREF_H_1_0(x) \
(((x) >> BIT_SHIFT_LOCKDET_VREF_H_1_0) & BIT_MASK_LOCKDET_VREF_H_1_0)
#define BIT_SET_LOCKDET_VREF_H_1_0(x, v) \
(BIT_CLEAR_LOCKDET_VREF_H_1_0(x) | BIT_LOCKDET_VREF_H_1_0(v))
#define BIT_SHIFT_LDO_SEL_1_0 16
#define BIT_MASK_LDO_SEL_1_0 0x3
#define BIT_LDO_SEL_1_0(x) \
(((x) & BIT_MASK_LDO_SEL_1_0) << BIT_SHIFT_LDO_SEL_1_0)
#define BITS_LDO_SEL_1_0 (BIT_MASK_LDO_SEL_1_0 << BIT_SHIFT_LDO_SEL_1_0)
#define BIT_CLEAR_LDO_SEL_1_0(x) ((x) & (~BITS_LDO_SEL_1_0))
#define BIT_GET_LDO_SEL_1_0(x) \
(((x) >> BIT_SHIFT_LDO_SEL_1_0) & BIT_MASK_LDO_SEL_1_0)
#define BIT_SET_LDO_SEL_1_0(x, v) \
(BIT_CLEAR_LDO_SEL_1_0(x) | BIT_LDO_SEL_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_LPF_C1 15
#define BIT_MASK_REG_LPF_C1 0x7
#define BIT_REG_LPF_C1(x) (((x) & BIT_MASK_REG_LPF_C1) << BIT_SHIFT_REG_LPF_C1)
#define BITS_REG_LPF_C1 (BIT_MASK_REG_LPF_C1 << BIT_SHIFT_REG_LPF_C1)
#define BIT_CLEAR_REG_LPF_C1(x) ((x) & (~BITS_REG_LPF_C1))
#define BIT_GET_REG_LPF_C1(x) \
(((x) >> BIT_SHIFT_REG_LPF_C1) & BIT_MASK_REG_LPF_C1)
#define BIT_SET_REG_LPF_C1(x, v) (BIT_CLEAR_REG_LPF_C1(x) | BIT_REG_LPF_C1(v))
#define BIT_SHIFT_REG_LDO_SEL_V1 13
#define BIT_MASK_REG_LDO_SEL_V1 0x3
#define BIT_REG_LDO_SEL_V1(x) \
(((x) & BIT_MASK_REG_LDO_SEL_V1) << BIT_SHIFT_REG_LDO_SEL_V1)
#define BITS_REG_LDO_SEL_V1 \
(BIT_MASK_REG_LDO_SEL_V1 << BIT_SHIFT_REG_LDO_SEL_V1)
#define BIT_CLEAR_REG_LDO_SEL_V1(x) ((x) & (~BITS_REG_LDO_SEL_V1))
#define BIT_GET_REG_LDO_SEL_V1(x) \
(((x) >> BIT_SHIFT_REG_LDO_SEL_V1) & BIT_MASK_REG_LDO_SEL_V1)
#define BIT_SET_REG_LDO_SEL_V1(x, v) \
(BIT_CLEAR_REG_LDO_SEL_V1(x) | BIT_REG_LDO_SEL_V1(v))
#define BIT_REG_CP_ICPX2 BIT(12)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_IOFFSET_5_0 10
#define BIT_MASK_IOFFSET_5_0 0x3f
#define BIT_IOFFSET_5_0(x) \
(((x) & BIT_MASK_IOFFSET_5_0) << BIT_SHIFT_IOFFSET_5_0)
#define BITS_IOFFSET_5_0 (BIT_MASK_IOFFSET_5_0 << BIT_SHIFT_IOFFSET_5_0)
#define BIT_CLEAR_IOFFSET_5_0(x) ((x) & (~BITS_IOFFSET_5_0))
#define BIT_GET_IOFFSET_5_0(x) \
(((x) >> BIT_SHIFT_IOFFSET_5_0) & BIT_MASK_IOFFSET_5_0)
#define BIT_SET_IOFFSET_5_0(x, v) \
(BIT_CLEAR_IOFFSET_5_0(x) | BIT_IOFFSET_5_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_CP_ICP_SEL_FAST 9
#define BIT_MASK_REG_CP_ICP_SEL_FAST 0x7
#define BIT_REG_CP_ICP_SEL_FAST(x) \
(((x) & BIT_MASK_REG_CP_ICP_SEL_FAST) << BIT_SHIFT_REG_CP_ICP_SEL_FAST)
#define BITS_REG_CP_ICP_SEL_FAST \
(BIT_MASK_REG_CP_ICP_SEL_FAST << BIT_SHIFT_REG_CP_ICP_SEL_FAST)
#define BIT_CLEAR_REG_CP_ICP_SEL_FAST(x) ((x) & (~BITS_REG_CP_ICP_SEL_FAST))
#define BIT_GET_REG_CP_ICP_SEL_FAST(x) \
(((x) >> BIT_SHIFT_REG_CP_ICP_SEL_FAST) & BIT_MASK_REG_CP_ICP_SEL_FAST)
#define BIT_SET_REG_CP_ICP_SEL_FAST(x, v) \
(BIT_CLEAR_REG_CP_ICP_SEL_FAST(x) | BIT_REG_CP_ICP_SEL_FAST(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_CP_ICPX2 BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_GM_STEP BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_REG_CP_ICP_SEL 6
#define BIT_MASK_REG_CP_ICP_SEL 0x7
#define BIT_REG_CP_ICP_SEL(x) \
(((x) & BIT_MASK_REG_CP_ICP_SEL) << BIT_SHIFT_REG_CP_ICP_SEL)
#define BITS_REG_CP_ICP_SEL \
(BIT_MASK_REG_CP_ICP_SEL << BIT_SHIFT_REG_CP_ICP_SEL)
#define BIT_CLEAR_REG_CP_ICP_SEL(x) ((x) & (~BITS_REG_CP_ICP_SEL))
#define BIT_GET_REG_CP_ICP_SEL(x) \
(((x) >> BIT_SHIFT_REG_CP_ICP_SEL) & BIT_MASK_REG_CP_ICP_SEL)
#define BIT_SET_REG_CP_ICP_SEL(x, v) \
(BIT_CLEAR_REG_CP_ICP_SEL(x) | BIT_REG_CP_ICP_SEL(v))
#define BIT_SHIFT_REG_IB_PI 4
#define BIT_MASK_REG_IB_PI 0x3
#define BIT_REG_IB_PI(x) (((x) & BIT_MASK_REG_IB_PI) << BIT_SHIFT_REG_IB_PI)
#define BITS_REG_IB_PI (BIT_MASK_REG_IB_PI << BIT_SHIFT_REG_IB_PI)
#define BIT_CLEAR_REG_IB_PI(x) ((x) & (~BITS_REG_IB_PI))
#define BIT_GET_REG_IB_PI(x) (((x) >> BIT_SHIFT_REG_IB_PI) & BIT_MASK_REG_IB_PI)
#define BIT_SET_REG_IB_PI(x, v) (BIT_CLEAR_REG_IB_PI(x) | BIT_REG_IB_PI(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_CP_ICP_SEL_4_0 4
#define BIT_MASK_CP_ICP_SEL_4_0 0x1f
#define BIT_CP_ICP_SEL_4_0(x) \
(((x) & BIT_MASK_CP_ICP_SEL_4_0) << BIT_SHIFT_CP_ICP_SEL_4_0)
#define BITS_CP_ICP_SEL_4_0 \
(BIT_MASK_CP_ICP_SEL_4_0 << BIT_SHIFT_CP_ICP_SEL_4_0)
#define BIT_CLEAR_CP_ICP_SEL_4_0(x) ((x) & (~BITS_CP_ICP_SEL_4_0))
#define BIT_GET_CP_ICP_SEL_4_0(x) \
(((x) >> BIT_SHIFT_CP_ICP_SEL_4_0) & BIT_MASK_CP_ICP_SEL_4_0)
#define BIT_SET_CP_ICP_SEL_4_0(x, v) \
(BIT_CLEAR_CP_ICP_SEL_4_0(x) | BIT_CP_ICP_SEL_4_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_LDO2PWRCUT BIT(3)
#define BIT_VPULSE_LDO BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_SHIFT_IB_PI_1_0 2
#define BIT_MASK_IB_PI_1_0 0x3
#define BIT_IB_PI_1_0(x) (((x) & BIT_MASK_IB_PI_1_0) << BIT_SHIFT_IB_PI_1_0)
#define BITS_IB_PI_1_0 (BIT_MASK_IB_PI_1_0 << BIT_SHIFT_IB_PI_1_0)
#define BIT_CLEAR_IB_PI_1_0(x) ((x) & (~BITS_IB_PI_1_0))
#define BIT_GET_IB_PI_1_0(x) (((x) >> BIT_SHIFT_IB_PI_1_0) & BIT_MASK_IB_PI_1_0)
#define BIT_SET_IB_PI_1_0(x, v) (BIT_CLEAR_IB_PI_1_0(x) | BIT_IB_PI_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_0 (Offset 0x1018) */
#define BIT_OFFSET_PLUS BIT(1)
#define BIT_SHIFT_LDO_VSEL 0
#define BIT_MASK_LDO_VSEL 0x3
#define BIT_LDO_VSEL(x) (((x) & BIT_MASK_LDO_VSEL) << BIT_SHIFT_LDO_VSEL)
#define BITS_LDO_VSEL (BIT_MASK_LDO_VSEL << BIT_SHIFT_LDO_VSEL)
#define BIT_CLEAR_LDO_VSEL(x) ((x) & (~BITS_LDO_VSEL))
#define BIT_GET_LDO_VSEL(x) (((x) >> BIT_SHIFT_LDO_VSEL) & BIT_MASK_LDO_VSEL)
#define BIT_SET_LDO_VSEL(x, v) (BIT_CLEAR_LDO_VSEL(x) | BIT_LDO_VSEL(v))
#define BIT_RESET_N BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_REG_CK_MON_SEL 29
#define BIT_MASK_REG_CK_MON_SEL 0x7
#define BIT_REG_CK_MON_SEL(x) \
(((x) & BIT_MASK_REG_CK_MON_SEL) << BIT_SHIFT_REG_CK_MON_SEL)
#define BITS_REG_CK_MON_SEL \
(BIT_MASK_REG_CK_MON_SEL << BIT_SHIFT_REG_CK_MON_SEL)
#define BIT_CLEAR_REG_CK_MON_SEL(x) ((x) & (~BITS_REG_CK_MON_SEL))
#define BIT_GET_REG_CK_MON_SEL(x) \
(((x) >> BIT_SHIFT_REG_CK_MON_SEL) & BIT_MASK_REG_CK_MON_SEL)
#define BIT_SET_REG_CK_MON_SEL(x, v) \
(BIT_CLEAR_REG_CK_MON_SEL(x) | BIT_REG_CK_MON_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_CKX_USB_IB_SEL 29
#define BIT_MASK_CKX_USB_IB_SEL 0x7
#define BIT_CKX_USB_IB_SEL(x) \
(((x) & BIT_MASK_CKX_USB_IB_SEL) << BIT_SHIFT_CKX_USB_IB_SEL)
#define BITS_CKX_USB_IB_SEL \
(BIT_MASK_CKX_USB_IB_SEL << BIT_SHIFT_CKX_USB_IB_SEL)
#define BIT_CLEAR_CKX_USB_IB_SEL(x) ((x) & (~BITS_CKX_USB_IB_SEL))
#define BIT_GET_CKX_USB_IB_SEL(x) \
(((x) >> BIT_SHIFT_CKX_USB_IB_SEL) & BIT_MASK_CKX_USB_IB_SEL)
#define BIT_SET_CKX_USB_IB_SEL(x, v) \
(BIT_CLEAR_CKX_USB_IB_SEL(x) | BIT_CKX_USB_IB_SEL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_REG_CK_MON_EN BIT(28)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_PFD_DN_GATED BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_REG_XTAL_FREQ_SEL BIT(27)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_PFD_UP_GATED BIT(27)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_REG_XTAL_EDGE_SEL BIT(26)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_PFD_RESET_GATED BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_REG_VCO_KVCO BIT(25)
#define BIT_REG_SDM_EDGE_SEL BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_PFD_OUT_DRV_1_0 24
#define BIT_MASK_PFD_OUT_DRV_1_0 0x3
#define BIT_PFD_OUT_DRV_1_0(x) \
(((x) & BIT_MASK_PFD_OUT_DRV_1_0) << BIT_SHIFT_PFD_OUT_DRV_1_0)
#define BITS_PFD_OUT_DRV_1_0 \
(BIT_MASK_PFD_OUT_DRV_1_0 << BIT_SHIFT_PFD_OUT_DRV_1_0)
#define BIT_CLEAR_PFD_OUT_DRV_1_0(x) ((x) & (~BITS_PFD_OUT_DRV_1_0))
#define BIT_GET_PFD_OUT_DRV_1_0(x) \
(((x) >> BIT_SHIFT_PFD_OUT_DRV_1_0) & BIT_MASK_PFD_OUT_DRV_1_0)
#define BIT_SET_PFD_OUT_DRV_1_0(x, v) \
(BIT_CLEAR_PFD_OUT_DRV_1_0(x) | BIT_PFD_OUT_DRV_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_REG_SDM_CK_SEL BIT(23)
#define BIT_REG_SDM_CK_GATED BIT(22)
#define BIT_REG_PFD_RESET_GATED BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_LPF_TIEMID_2_0 20
#define BIT_MASK_LPF_TIEMID_2_0 0x7
#define BIT_LPF_TIEMID_2_0(x) \
(((x) & BIT_MASK_LPF_TIEMID_2_0) << BIT_SHIFT_LPF_TIEMID_2_0)
#define BITS_LPF_TIEMID_2_0 \
(BIT_MASK_LPF_TIEMID_2_0 << BIT_SHIFT_LPF_TIEMID_2_0)
#define BIT_CLEAR_LPF_TIEMID_2_0(x) ((x) & (~BITS_LPF_TIEMID_2_0))
#define BIT_GET_LPF_TIEMID_2_0(x) \
(((x) >> BIT_SHIFT_LPF_TIEMID_2_0) & BIT_MASK_LPF_TIEMID_2_0)
#define BIT_SET_LPF_TIEMID_2_0(x, v) \
(BIT_CLEAR_LPF_TIEMID_2_0(x) | BIT_LPF_TIEMID_2_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_REG_LPF_R3_FAST 16
#define BIT_MASK_REG_LPF_R3_FAST 0x1f
#define BIT_REG_LPF_R3_FAST(x) \
(((x) & BIT_MASK_REG_LPF_R3_FAST) << BIT_SHIFT_REG_LPF_R3_FAST)
#define BITS_REG_LPF_R3_FAST \
(BIT_MASK_REG_LPF_R3_FAST << BIT_SHIFT_REG_LPF_R3_FAST)
#define BIT_CLEAR_REG_LPF_R3_FAST(x) ((x) & (~BITS_REG_LPF_R3_FAST))
#define BIT_GET_REG_LPF_R3_FAST(x) \
(((x) >> BIT_SHIFT_REG_LPF_R3_FAST) & BIT_MASK_REG_LPF_R3_FAST)
#define BIT_SET_REG_LPF_R3_FAST(x, v) \
(BIT_CLEAR_REG_LPF_R3_FAST(x) | BIT_REG_LPF_R3_FAST(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_LPF_R3_4_0 15
#define BIT_MASK_LPF_R3_4_0 0x1f
#define BIT_LPF_R3_4_0(x) (((x) & BIT_MASK_LPF_R3_4_0) << BIT_SHIFT_LPF_R3_4_0)
#define BITS_LPF_R3_4_0 (BIT_MASK_LPF_R3_4_0 << BIT_SHIFT_LPF_R3_4_0)
#define BIT_CLEAR_LPF_R3_4_0(x) ((x) & (~BITS_LPF_R3_4_0))
#define BIT_GET_LPF_R3_4_0(x) \
(((x) >> BIT_SHIFT_LPF_R3_4_0) & BIT_MASK_LPF_R3_4_0)
#define BIT_SET_LPF_R3_4_0(x, v) (BIT_CLEAR_LPF_R3_4_0(x) | BIT_LPF_R3_4_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_REG_LPF_R2_FAST 11
#define BIT_MASK_REG_LPF_R2_FAST 0x1f
#define BIT_REG_LPF_R2_FAST(x) \
(((x) & BIT_MASK_REG_LPF_R2_FAST) << BIT_SHIFT_REG_LPF_R2_FAST)
#define BITS_REG_LPF_R2_FAST \
(BIT_MASK_REG_LPF_R2_FAST << BIT_SHIFT_REG_LPF_R2_FAST)
#define BIT_CLEAR_REG_LPF_R2_FAST(x) ((x) & (~BITS_REG_LPF_R2_FAST))
#define BIT_GET_REG_LPF_R2_FAST(x) \
(((x) >> BIT_SHIFT_REG_LPF_R2_FAST) & BIT_MASK_REG_LPF_R2_FAST)
#define BIT_SET_REG_LPF_R2_FAST(x, v) \
(BIT_CLEAR_REG_LPF_R2_FAST(x) | BIT_REG_LPF_R2_FAST(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_LPF_R2_4_0 10
#define BIT_MASK_LPF_R2_4_0 0x1f
#define BIT_LPF_R2_4_0(x) (((x) & BIT_MASK_LPF_R2_4_0) << BIT_SHIFT_LPF_R2_4_0)
#define BITS_LPF_R2_4_0 (BIT_MASK_LPF_R2_4_0 << BIT_SHIFT_LPF_R2_4_0)
#define BIT_CLEAR_LPF_R2_4_0(x) ((x) & (~BITS_LPF_R2_4_0))
#define BIT_GET_LPF_R2_4_0(x) \
(((x) >> BIT_SHIFT_LPF_R2_4_0) & BIT_MASK_LPF_R2_4_0)
#define BIT_SET_LPF_R2_4_0(x, v) (BIT_CLEAR_LPF_R2_4_0(x) | BIT_LPF_R2_4_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_REG_LPF_C3_FAST 8
#define BIT_MASK_REG_LPF_C3_FAST 0x7
#define BIT_REG_LPF_C3_FAST(x) \
(((x) & BIT_MASK_REG_LPF_C3_FAST) << BIT_SHIFT_REG_LPF_C3_FAST)
#define BITS_REG_LPF_C3_FAST \
(BIT_MASK_REG_LPF_C3_FAST << BIT_SHIFT_REG_LPF_C3_FAST)
#define BIT_CLEAR_REG_LPF_C3_FAST(x) ((x) & (~BITS_REG_LPF_C3_FAST))
#define BIT_GET_REG_LPF_C3_FAST(x) \
(((x) >> BIT_SHIFT_REG_LPF_C3_FAST) & BIT_MASK_REG_LPF_C3_FAST)
#define BIT_SET_REG_LPF_C3_FAST(x, v) \
(BIT_CLEAR_REG_LPF_C3_FAST(x) | BIT_REG_LPF_C3_FAST(v))
#define BIT_SHIFT_REG_LPF_C2_FAST 5
#define BIT_MASK_REG_LPF_C2_FAST 0x7
#define BIT_REG_LPF_C2_FAST(x) \
(((x) & BIT_MASK_REG_LPF_C2_FAST) << BIT_SHIFT_REG_LPF_C2_FAST)
#define BITS_REG_LPF_C2_FAST \
(BIT_MASK_REG_LPF_C2_FAST << BIT_SHIFT_REG_LPF_C2_FAST)
#define BIT_CLEAR_REG_LPF_C2_FAST(x) ((x) & (~BITS_REG_LPF_C2_FAST))
#define BIT_GET_REG_LPF_C2_FAST(x) \
(((x) >> BIT_SHIFT_REG_LPF_C2_FAST) & BIT_MASK_REG_LPF_C2_FAST)
#define BIT_SET_REG_LPF_C2_FAST(x, v) \
(BIT_CLEAR_REG_LPF_C2_FAST(x) | BIT_REG_LPF_C2_FAST(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_LPF_C3_5_0 4
#define BIT_MASK_LPF_C3_5_0 0x3f
#define BIT_LPF_C3_5_0(x) (((x) & BIT_MASK_LPF_C3_5_0) << BIT_SHIFT_LPF_C3_5_0)
#define BITS_LPF_C3_5_0 (BIT_MASK_LPF_C3_5_0 << BIT_SHIFT_LPF_C3_5_0)
#define BIT_CLEAR_LPF_C3_5_0(x) ((x) & (~BITS_LPF_C3_5_0))
#define BIT_GET_LPF_C3_5_0(x) \
(((x) >> BIT_SHIFT_LPF_C3_5_0) & BIT_MASK_LPF_C3_5_0)
#define BIT_SET_LPF_C3_5_0(x, v) (BIT_CLEAR_LPF_C3_5_0(x) | BIT_LPF_C3_5_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_REG_LPF_C1_FAST 2
#define BIT_MASK_REG_LPF_C1_FAST 0x7
#define BIT_REG_LPF_C1_FAST(x) \
(((x) & BIT_MASK_REG_LPF_C1_FAST) << BIT_SHIFT_REG_LPF_C1_FAST)
#define BITS_REG_LPF_C1_FAST \
(BIT_MASK_REG_LPF_C1_FAST << BIT_SHIFT_REG_LPF_C1_FAST)
#define BIT_CLEAR_REG_LPF_C1_FAST(x) ((x) & (~BITS_REG_LPF_C1_FAST))
#define BIT_GET_REG_LPF_C1_FAST(x) \
(((x) >> BIT_SHIFT_REG_LPF_C1_FAST) & BIT_MASK_REG_LPF_C1_FAST)
#define BIT_SET_REG_LPF_C1_FAST(x, v) \
(BIT_CLEAR_REG_LPF_C1_FAST(x) | BIT_REG_LPF_C1_FAST(v))
#define BIT_SHIFT_REG_LPF_R3_V1 0
#define BIT_MASK_REG_LPF_R3_V1 0x3
#define BIT_REG_LPF_R3_V1(x) \
(((x) & BIT_MASK_REG_LPF_R3_V1) << BIT_SHIFT_REG_LPF_R3_V1)
#define BITS_REG_LPF_R3_V1 (BIT_MASK_REG_LPF_R3_V1 << BIT_SHIFT_REG_LPF_R3_V1)
#define BIT_CLEAR_REG_LPF_R3_V1(x) ((x) & (~BITS_REG_LPF_R3_V1))
#define BIT_GET_REG_LPF_R3_V1(x) \
(((x) >> BIT_SHIFT_REG_LPF_R3_V1) & BIT_MASK_REG_LPF_R3_V1)
#define BIT_SET_REG_LPF_R3_V1(x, v) \
(BIT_CLEAR_REG_LPF_R3_V1(x) | BIT_REG_LPF_R3_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_1 (Offset 0x101C) */
#define BIT_SHIFT_LPF_C2_5_2 0
#define BIT_MASK_LPF_C2_5_2 0xf
#define BIT_LPF_C2_5_2(x) (((x) & BIT_MASK_LPF_C2_5_2) << BIT_SHIFT_LPF_C2_5_2)
#define BITS_LPF_C2_5_2 (BIT_MASK_LPF_C2_5_2 << BIT_SHIFT_LPF_C2_5_2)
#define BIT_CLEAR_LPF_C2_5_2(x) ((x) & (~BITS_LPF_C2_5_2))
#define BIT_GET_LPF_C2_5_2(x) \
(((x) >> BIT_SHIFT_LPF_C2_5_2) & BIT_MASK_LPF_C2_5_2)
#define BIT_SET_LPF_C2_5_2(x, v) (BIT_CLEAR_LPF_C2_5_2(x) | BIT_LPF_C2_5_2(v))
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_CK_PHASE_SEL BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SHIFT_AGPIO_DRV_V1 30
#define BIT_MASK_AGPIO_DRV_V1 0x3
#define BIT_AGPIO_DRV_V1(x) \
(((x) & BIT_MASK_AGPIO_DRV_V1) << BIT_SHIFT_AGPIO_DRV_V1)
#define BITS_AGPIO_DRV_V1 (BIT_MASK_AGPIO_DRV_V1 << BIT_SHIFT_AGPIO_DRV_V1)
#define BIT_CLEAR_AGPIO_DRV_V1(x) ((x) & (~BITS_AGPIO_DRV_V1))
#define BIT_GET_AGPIO_DRV_V1(x) \
(((x) >> BIT_SHIFT_AGPIO_DRV_V1) & BIT_MASK_AGPIO_DRV_V1)
#define BIT_SET_AGPIO_DRV_V1(x, v) \
(BIT_CLEAR_AGPIO_DRV_V1(x) | BIT_AGPIO_DRV_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_CK960M_EN BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_AGPIO_GPO_V1 BIT(29)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_CK640M_EN BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_AGPIO_GPE_V1 BIT(28)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_CK240M_EN BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SEL_CLK BIT(27)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SHIFT_CK_MON_SEL_2_0 25
#define BIT_MASK_CK_MON_SEL_2_0 0x7
#define BIT_CK_MON_SEL_2_0(x) \
(((x) & BIT_MASK_CK_MON_SEL_2_0) << BIT_SHIFT_CK_MON_SEL_2_0)
#define BITS_CK_MON_SEL_2_0 \
(BIT_MASK_CK_MON_SEL_2_0 << BIT_SHIFT_CK_MON_SEL_2_0)
#define BIT_CLEAR_CK_MON_SEL_2_0(x) ((x) & (~BITS_CK_MON_SEL_2_0))
#define BIT_GET_CK_MON_SEL_2_0(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL_2_0) & BIT_MASK_CK_MON_SEL_2_0)
#define BIT_SET_CK_MON_SEL_2_0(x, v) \
(BIT_CLEAR_CK_MON_SEL_2_0(x) | BIT_CK_MON_SEL_2_0(v))
#define BIT_CK_MON_EN_V1 BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SHIFT_LS_XTAL_SEL 23
#define BIT_MASK_LS_XTAL_SEL 0xf
#define BIT_LS_XTAL_SEL(x) \
(((x) & BIT_MASK_LS_XTAL_SEL) << BIT_SHIFT_LS_XTAL_SEL)
#define BITS_LS_XTAL_SEL (BIT_MASK_LS_XTAL_SEL << BIT_SHIFT_LS_XTAL_SEL)
#define BIT_CLEAR_LS_XTAL_SEL(x) ((x) & (~BITS_LS_XTAL_SEL))
#define BIT_GET_LS_XTAL_SEL(x) \
(((x) >> BIT_SHIFT_LS_XTAL_SEL) & BIT_MASK_LS_XTAL_SEL)
#define BIT_SET_LS_XTAL_SEL(x, v) \
(BIT_CLEAR_LS_XTAL_SEL(x) | BIT_LS_XTAL_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_XTAL_SOURCE_SEL BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_LS_SDM_ORDER_V1 BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_XTAL_FREQ_SEL BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_LS_DELAY_PH BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_XTAL_EDGE_SEL BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_DIVIDER_SEL BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_XTAL_BUF_SEL BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SHIFT_PCODE 15
#define BIT_MASK_PCODE 0x1f
#define BIT_PCODE(x) (((x) & BIT_MASK_PCODE) << BIT_SHIFT_PCODE)
#define BITS_PCODE (BIT_MASK_PCODE << BIT_SHIFT_PCODE)
#define BIT_CLEAR_PCODE(x) ((x) & (~BITS_PCODE))
#define BIT_GET_PCODE(x) (((x) >> BIT_SHIFT_PCODE) & BIT_MASK_PCODE)
#define BIT_SET_PCODE(x, v) (BIT_CLEAR_PCODE(x) | BIT_PCODE(v))
#define BIT_SHIFT_NCODE 7
#define BIT_MASK_NCODE 0xff
#define BIT_NCODE(x) (((x) & BIT_MASK_NCODE) << BIT_SHIFT_NCODE)
#define BITS_NCODE (BIT_MASK_NCODE << BIT_SHIFT_NCODE)
#define BIT_CLEAR_NCODE(x) ((x) & (~BITS_NCODE))
#define BIT_GET_NCODE(x) (((x) >> BIT_SHIFT_NCODE) & BIT_MASK_NCODE)
#define BIT_SET_NCODE(x, v) (BIT_CLEAR_NCODE(x) | BIT_NCODE(v))
#define BIT_REG_BEACON BIT(6)
#define BIT_REG_MBIASE BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SHIFT_VCO_CV_7_0 4
#define BIT_MASK_VCO_CV_7_0 0xff
#define BIT_VCO_CV_7_0(x) (((x) & BIT_MASK_VCO_CV_7_0) << BIT_SHIFT_VCO_CV_7_0)
#define BITS_VCO_CV_7_0 (BIT_MASK_VCO_CV_7_0 << BIT_SHIFT_VCO_CV_7_0)
#define BIT_CLEAR_VCO_CV_7_0(x) ((x) & (~BITS_VCO_CV_7_0))
#define BIT_GET_VCO_CV_7_0(x) \
(((x) >> BIT_SHIFT_VCO_CV_7_0) & BIT_MASK_VCO_CV_7_0)
#define BIT_SET_VCO_CV_7_0(x, v) (BIT_CLEAR_VCO_CV_7_0(x) | BIT_VCO_CV_7_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SHIFT_REG_FAST_SEL 3
#define BIT_MASK_REG_FAST_SEL 0x3
#define BIT_REG_FAST_SEL(x) \
(((x) & BIT_MASK_REG_FAST_SEL) << BIT_SHIFT_REG_FAST_SEL)
#define BITS_REG_FAST_SEL (BIT_MASK_REG_FAST_SEL << BIT_SHIFT_REG_FAST_SEL)
#define BIT_CLEAR_REG_FAST_SEL(x) ((x) & (~BITS_REG_FAST_SEL))
#define BIT_GET_REG_FAST_SEL(x) \
(((x) >> BIT_SHIFT_REG_FAST_SEL) & BIT_MASK_REG_FAST_SEL)
#define BIT_SET_REG_FAST_SEL(x, v) \
(BIT_CLEAR_REG_FAST_SEL(x) | BIT_REG_FAST_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_VCO_KVCO BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_REG_CK960M_EN BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SDM_EDGE_SEL BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_REG_CK320M_EN BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SDM_CK_SEL BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_REG_CK_5M_EN BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_MAC_2 (Offset 0x1020) */
#define BIT_SDM_CK_GATED BIT(0)
/* 2 REG_ANAPAR_MAC_3 (Offset 0x1024) */
#define BIT_SHIFT_LCK_WAIT_CYCLE_2_0 28
#define BIT_MASK_LCK_WAIT_CYCLE_2_0 0x7
#define BIT_LCK_WAIT_CYCLE_2_0(x) \
(((x) & BIT_MASK_LCK_WAIT_CYCLE_2_0) << BIT_SHIFT_LCK_WAIT_CYCLE_2_0)
#define BITS_LCK_WAIT_CYCLE_2_0 \
(BIT_MASK_LCK_WAIT_CYCLE_2_0 << BIT_SHIFT_LCK_WAIT_CYCLE_2_0)
#define BIT_CLEAR_LCK_WAIT_CYCLE_2_0(x) ((x) & (~BITS_LCK_WAIT_CYCLE_2_0))
#define BIT_GET_LCK_WAIT_CYCLE_2_0(x) \
(((x) >> BIT_SHIFT_LCK_WAIT_CYCLE_2_0) & BIT_MASK_LCK_WAIT_CYCLE_2_0)
#define BIT_SET_LCK_WAIT_CYCLE_2_0(x, v) \
(BIT_CLEAR_LCK_WAIT_CYCLE_2_0(x) | BIT_LCK_WAIT_CYCLE_2_0(v))
#define BIT_SHIFT_LCK_VCO_DIVISOR_1_0 26
#define BIT_MASK_LCK_VCO_DIVISOR_1_0 0x3
#define BIT_LCK_VCO_DIVISOR_1_0(x) \
(((x) & BIT_MASK_LCK_VCO_DIVISOR_1_0) << BIT_SHIFT_LCK_VCO_DIVISOR_1_0)
#define BITS_LCK_VCO_DIVISOR_1_0 \
(BIT_MASK_LCK_VCO_DIVISOR_1_0 << BIT_SHIFT_LCK_VCO_DIVISOR_1_0)
#define BIT_CLEAR_LCK_VCO_DIVISOR_1_0(x) ((x) & (~BITS_LCK_VCO_DIVISOR_1_0))
#define BIT_GET_LCK_VCO_DIVISOR_1_0(x) \
(((x) >> BIT_SHIFT_LCK_VCO_DIVISOR_1_0) & BIT_MASK_LCK_VCO_DIVISOR_1_0)
#define BIT_SET_LCK_VCO_DIVISOR_1_0(x, v) \
(BIT_CLEAR_LCK_VCO_DIVISOR_1_0(x) | BIT_LCK_VCO_DIVISOR_1_0(v))
#define BIT_SHIFT_LCK_SEARCH_MODE_1_0 24
#define BIT_MASK_LCK_SEARCH_MODE_1_0 0x3
#define BIT_LCK_SEARCH_MODE_1_0(x) \
(((x) & BIT_MASK_LCK_SEARCH_MODE_1_0) << BIT_SHIFT_LCK_SEARCH_MODE_1_0)
#define BITS_LCK_SEARCH_MODE_1_0 \
(BIT_MASK_LCK_SEARCH_MODE_1_0 << BIT_SHIFT_LCK_SEARCH_MODE_1_0)
#define BIT_CLEAR_LCK_SEARCH_MODE_1_0(x) ((x) & (~BITS_LCK_SEARCH_MODE_1_0))
#define BIT_GET_LCK_SEARCH_MODE_1_0(x) \
(((x) >> BIT_SHIFT_LCK_SEARCH_MODE_1_0) & BIT_MASK_LCK_SEARCH_MODE_1_0)
#define BIT_SET_LCK_SEARCH_MODE_1_0(x, v) \
(BIT_CLEAR_LCK_SEARCH_MODE_1_0(x) | BIT_LCK_SEARCH_MODE_1_0(v))
#define BIT_SHIFT_LS_CV_OFFSET_3_0 12
#define BIT_MASK_LS_CV_OFFSET_3_0 0xf
#define BIT_LS_CV_OFFSET_3_0(x) \
(((x) & BIT_MASK_LS_CV_OFFSET_3_0) << BIT_SHIFT_LS_CV_OFFSET_3_0)
#define BITS_LS_CV_OFFSET_3_0 \
(BIT_MASK_LS_CV_OFFSET_3_0 << BIT_SHIFT_LS_CV_OFFSET_3_0)
#define BIT_CLEAR_LS_CV_OFFSET_3_0(x) ((x) & (~BITS_LS_CV_OFFSET_3_0))
#define BIT_GET_LS_CV_OFFSET_3_0(x) \
(((x) >> BIT_SHIFT_LS_CV_OFFSET_3_0) & BIT_MASK_LS_CV_OFFSET_3_0)
#define BIT_SET_LS_CV_OFFSET_3_0(x, v) \
(BIT_CLEAR_LS_CV_OFFSET_3_0(x) | BIT_LS_CV_OFFSET_3_0(v))
#define BIT_LS_EN_LC_CK40M BIT(11)
#define BIT_LS__CV_MANUAL BIT(10)
#define BIT_LS_PYPASS_PI BIT(9)
#define BIT_MBIASE BIT(4)
/* 2 REG_ANAPAR_MAC_4 (Offset 0x1028) */
#define BIT_LS_TIE_MID_MODE BIT(28)
#define BIT_SHIFT_LS_SYNC_CYCLE_1_0 26
#define BIT_MASK_LS_SYNC_CYCLE_1_0 0x3
#define BIT_LS_SYNC_CYCLE_1_0(x) \
(((x) & BIT_MASK_LS_SYNC_CYCLE_1_0) << BIT_SHIFT_LS_SYNC_CYCLE_1_0)
#define BITS_LS_SYNC_CYCLE_1_0 \
(BIT_MASK_LS_SYNC_CYCLE_1_0 << BIT_SHIFT_LS_SYNC_CYCLE_1_0)
#define BIT_CLEAR_LS_SYNC_CYCLE_1_0(x) ((x) & (~BITS_LS_SYNC_CYCLE_1_0))
#define BIT_GET_LS_SYNC_CYCLE_1_0(x) \
(((x) >> BIT_SHIFT_LS_SYNC_CYCLE_1_0) & BIT_MASK_LS_SYNC_CYCLE_1_0)
#define BIT_SET_LS_SYNC_CYCLE_1_0(x, v) \
(BIT_CLEAR_LS_SYNC_CYCLE_1_0(x) | BIT_LS_SYNC_CYCLE_1_0(v))
#define BIT_LS_SDM_ORDER BIT(25)
#define BIT_LS_RST_LC_CAL BIT(14)
#define BIT_LS_RSTB BIT(13)
#define BIT_LS_POW_LC_CAL_PREP BIT(11)
#define BIT_SHIFT_LCK_XTAL_DIVISOR_1_0 0
#define BIT_MASK_LCK_XTAL_DIVISOR_1_0 0x3
#define BIT_LCK_XTAL_DIVISOR_1_0(x) \
(((x) & BIT_MASK_LCK_XTAL_DIVISOR_1_0) \
<< BIT_SHIFT_LCK_XTAL_DIVISOR_1_0)
#define BITS_LCK_XTAL_DIVISOR_1_0 \
(BIT_MASK_LCK_XTAL_DIVISOR_1_0 << BIT_SHIFT_LCK_XTAL_DIVISOR_1_0)
#define BIT_CLEAR_LCK_XTAL_DIVISOR_1_0(x) ((x) & (~BITS_LCK_XTAL_DIVISOR_1_0))
#define BIT_GET_LCK_XTAL_DIVISOR_1_0(x) \
(((x) >> BIT_SHIFT_LCK_XTAL_DIVISOR_1_0) & \
BIT_MASK_LCK_XTAL_DIVISOR_1_0)
#define BIT_SET_LCK_XTAL_DIVISOR_1_0(x, v) \
(BIT_CLEAR_LCK_XTAL_DIVISOR_1_0(x) | BIT_LCK_XTAL_DIVISOR_1_0(v))
/* 2 REG_ANAPAR_MAC_5 (Offset 0x102C) */
#define BIT_SHIFT_LS_XTAL_SEL_3_0 0
#define BIT_MASK_LS_XTAL_SEL_3_0 0xf
#define BIT_LS_XTAL_SEL_3_0(x) \
(((x) & BIT_MASK_LS_XTAL_SEL_3_0) << BIT_SHIFT_LS_XTAL_SEL_3_0)
#define BITS_LS_XTAL_SEL_3_0 \
(BIT_MASK_LS_XTAL_SEL_3_0 << BIT_SHIFT_LS_XTAL_SEL_3_0)
#define BIT_CLEAR_LS_XTAL_SEL_3_0(x) ((x) & (~BITS_LS_XTAL_SEL_3_0))
#define BIT_GET_LS_XTAL_SEL_3_0(x) \
(((x) >> BIT_SHIFT_LS_XTAL_SEL_3_0) & BIT_MASK_LS_XTAL_SEL_3_0)
#define BIT_SET_LS_XTAL_SEL_3_0(x, v) \
(BIT_CLEAR_LS_XTAL_SEL_3_0(x) | BIT_LS_XTAL_SEL_3_0(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SYS_CFG4 (Offset 0x1034) */
#define BIT_EF_CSER_1 BIT(26)
#define BIT_SW_PG_EN_1 BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_XTAL_SC_LPS BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_XTAL_DRV_RF1_0 BIT(31)
#define BIT_XTAL_GATED_RF1N BIT(30)
#define BIT_XTAL_GATED_RF1P BIT(29)
#define BIT_XTAL_GM_SEP_V2 BIT(28)
#define BIT_SHIFT_XTAL_LDO_1_0 26
#define BIT_MASK_XTAL_LDO_1_0 0x3
#define BIT_XTAL_LDO_1_0(x) \
(((x) & BIT_MASK_XTAL_LDO_1_0) << BIT_SHIFT_XTAL_LDO_1_0)
#define BITS_XTAL_LDO_1_0 (BIT_MASK_XTAL_LDO_1_0 << BIT_SHIFT_XTAL_LDO_1_0)
#define BIT_CLEAR_XTAL_LDO_1_0(x) ((x) & (~BITS_XTAL_LDO_1_0))
#define BIT_GET_XTAL_LDO_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_1_0) & BIT_MASK_XTAL_LDO_1_0)
#define BIT_SET_XTAL_LDO_1_0(x, v) \
(BIT_CLEAR_XTAL_LDO_1_0(x) | BIT_XTAL_LDO_1_0(v))
#define BIT_XQSEL_V1 BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_SC_INIT 24
#define BIT_MASK_XTAL_SC_INIT 0x7f
#define BIT_XTAL_SC_INIT(x) \
(((x) & BIT_MASK_XTAL_SC_INIT) << BIT_SHIFT_XTAL_SC_INIT)
#define BITS_XTAL_SC_INIT (BIT_MASK_XTAL_SC_INIT << BIT_SHIFT_XTAL_SC_INIT)
#define BIT_CLEAR_XTAL_SC_INIT(x) ((x) & (~BITS_XTAL_SC_INIT))
#define BIT_GET_XTAL_SC_INIT(x) \
(((x) >> BIT_SHIFT_XTAL_SC_INIT) & BIT_MASK_XTAL_SC_INIT)
#define BIT_SET_XTAL_SC_INIT(x, v) \
(BIT_CLEAR_XTAL_SC_INIT(x) | BIT_XTAL_SC_INIT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_GATED_XTAL_OK0 BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_SC_XO 17
#define BIT_MASK_XTAL_SC_XO 0x7f
#define BIT_XTAL_SC_XO(x) (((x) & BIT_MASK_XTAL_SC_XO) << BIT_SHIFT_XTAL_SC_XO)
#define BITS_XTAL_SC_XO (BIT_MASK_XTAL_SC_XO << BIT_SHIFT_XTAL_SC_XO)
#define BIT_CLEAR_XTAL_SC_XO(x) ((x) & (~BITS_XTAL_SC_XO))
#define BIT_GET_XTAL_SC_XO(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XO) & BIT_MASK_XTAL_SC_XO)
#define BIT_SET_XTAL_SC_XO(x, v) (BIT_CLEAR_XTAL_SC_XO(x) | BIT_XTAL_SC_XO(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_SC_XO_6_0 17
#define BIT_MASK_XTAL_SC_XO_6_0 0x7f
#define BIT_XTAL_SC_XO_6_0(x) \
(((x) & BIT_MASK_XTAL_SC_XO_6_0) << BIT_SHIFT_XTAL_SC_XO_6_0)
#define BITS_XTAL_SC_XO_6_0 \
(BIT_MASK_XTAL_SC_XO_6_0 << BIT_SHIFT_XTAL_SC_XO_6_0)
#define BIT_CLEAR_XTAL_SC_XO_6_0(x) ((x) & (~BITS_XTAL_SC_XO_6_0))
#define BIT_GET_XTAL_SC_XO_6_0(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XO_6_0) & BIT_MASK_XTAL_SC_XO_6_0)
#define BIT_SET_XTAL_SC_XO_6_0(x, v) \
(BIT_CLEAR_XTAL_SC_XO_6_0(x) | BIT_XTAL_SC_XO_6_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_SC_XI 10
#define BIT_MASK_XTAL_SC_XI 0x7f
#define BIT_XTAL_SC_XI(x) (((x) & BIT_MASK_XTAL_SC_XI) << BIT_SHIFT_XTAL_SC_XI)
#define BITS_XTAL_SC_XI (BIT_MASK_XTAL_SC_XI << BIT_SHIFT_XTAL_SC_XI)
#define BIT_CLEAR_XTAL_SC_XI(x) ((x) & (~BITS_XTAL_SC_XI))
#define BIT_GET_XTAL_SC_XI(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XI) & BIT_MASK_XTAL_SC_XI)
#define BIT_SET_XTAL_SC_XI(x, v) (BIT_CLEAR_XTAL_SC_XI(x) | BIT_XTAL_SC_XI(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_SC_XI_6_0 10
#define BIT_MASK_XTAL_SC_XI_6_0 0x7f
#define BIT_XTAL_SC_XI_6_0(x) \
(((x) & BIT_MASK_XTAL_SC_XI_6_0) << BIT_SHIFT_XTAL_SC_XI_6_0)
#define BITS_XTAL_SC_XI_6_0 \
(BIT_MASK_XTAL_SC_XI_6_0 << BIT_SHIFT_XTAL_SC_XI_6_0)
#define BIT_CLEAR_XTAL_SC_XI_6_0(x) ((x) & (~BITS_XTAL_SC_XI_6_0))
#define BIT_GET_XTAL_SC_XI_6_0(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XI_6_0) & BIT_MASK_XTAL_SC_XI_6_0)
#define BIT_SET_XTAL_SC_XI_6_0(x, v) \
(BIT_CLEAR_XTAL_SC_XI_6_0(x) | BIT_XTAL_SC_XI_6_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_GMN_V3 5
#define BIT_MASK_XTAL_GMN_V3 0x1f
#define BIT_XTAL_GMN_V3(x) \
(((x) & BIT_MASK_XTAL_GMN_V3) << BIT_SHIFT_XTAL_GMN_V3)
#define BITS_XTAL_GMN_V3 (BIT_MASK_XTAL_GMN_V3 << BIT_SHIFT_XTAL_GMN_V3)
#define BIT_CLEAR_XTAL_GMN_V3(x) ((x) & (~BITS_XTAL_GMN_V3))
#define BIT_GET_XTAL_GMN_V3(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V3) & BIT_MASK_XTAL_GMN_V3)
#define BIT_SET_XTAL_GMN_V3(x, v) \
(BIT_CLEAR_XTAL_GMN_V3(x) | BIT_XTAL_GMN_V3(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_GMN_4_0 5
#define BIT_MASK_XTAL_GMN_4_0 0x1f
#define BIT_XTAL_GMN_4_0(x) \
(((x) & BIT_MASK_XTAL_GMN_4_0) << BIT_SHIFT_XTAL_GMN_4_0)
#define BITS_XTAL_GMN_4_0 (BIT_MASK_XTAL_GMN_4_0 << BIT_SHIFT_XTAL_GMN_4_0)
#define BIT_CLEAR_XTAL_GMN_4_0(x) ((x) & (~BITS_XTAL_GMN_4_0))
#define BIT_GET_XTAL_GMN_4_0(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_4_0) & BIT_MASK_XTAL_GMN_4_0)
#define BIT_SET_XTAL_GMN_4_0(x, v) \
(BIT_CLEAR_XTAL_GMN_4_0(x) | BIT_XTAL_GMN_4_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_GMP_V3 0
#define BIT_MASK_XTAL_GMP_V3 0x1f
#define BIT_XTAL_GMP_V3(x) \
(((x) & BIT_MASK_XTAL_GMP_V3) << BIT_SHIFT_XTAL_GMP_V3)
#define BITS_XTAL_GMP_V3 (BIT_MASK_XTAL_GMP_V3 << BIT_SHIFT_XTAL_GMP_V3)
#define BIT_CLEAR_XTAL_GMP_V3(x) ((x) & (~BITS_XTAL_GMP_V3))
#define BIT_GET_XTAL_GMP_V3(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V3) & BIT_MASK_XTAL_GMP_V3)
#define BIT_SET_XTAL_GMP_V3(x, v) \
(BIT_CLEAR_XTAL_GMP_V3(x) | BIT_XTAL_GMP_V3(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_0 (Offset 0x1040) */
#define BIT_SHIFT_XTAL_GMP_4_0 0
#define BIT_MASK_XTAL_GMP_4_0 0x1f
#define BIT_XTAL_GMP_4_0(x) \
(((x) & BIT_MASK_XTAL_GMP_4_0) << BIT_SHIFT_XTAL_GMP_4_0)
#define BITS_XTAL_GMP_4_0 (BIT_MASK_XTAL_GMP_4_0 << BIT_SHIFT_XTAL_GMP_4_0)
#define BIT_CLEAR_XTAL_GMP_4_0(x) ((x) & (~BITS_XTAL_GMP_4_0))
#define BIT_GET_XTAL_GMP_4_0(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_4_0) & BIT_MASK_XTAL_GMP_4_0)
#define BIT_SET_XTAL_GMP_4_0(x, v) \
(BIT_CLEAR_XTAL_GMP_4_0(x) | BIT_XTAL_GMP_4_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_SEL_TOK_V1 BIT(31)
#define BIT_XTAL_DELAY_DIGI_V2 BIT(30)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_LDO_OK_1_0 30
#define BIT_MASK_XTAL_LDO_OK_1_0 0x3
#define BIT_XTAL_LDO_OK_1_0(x) \
(((x) & BIT_MASK_XTAL_LDO_OK_1_0) << BIT_SHIFT_XTAL_LDO_OK_1_0)
#define BITS_XTAL_LDO_OK_1_0 \
(BIT_MASK_XTAL_LDO_OK_1_0 << BIT_SHIFT_XTAL_LDO_OK_1_0)
#define BIT_CLEAR_XTAL_LDO_OK_1_0(x) ((x) & (~BITS_XTAL_LDO_OK_1_0))
#define BIT_GET_XTAL_LDO_OK_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_OK_1_0) & BIT_MASK_XTAL_LDO_OK_1_0)
#define BIT_SET_XTAL_LDO_OK_1_0(x, v) \
(BIT_CLEAR_XTAL_LDO_OK_1_0(x) | BIT_XTAL_LDO_OK_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_DELAY_USB_V2 BIT(29)
#define BIT_XTAL_DELAY_AFE_V2 BIT(28)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_XORES_SEL_2_0 27
#define BIT_MASK_XTAL_XORES_SEL_2_0 0x7
#define BIT_XTAL_XORES_SEL_2_0(x) \
(((x) & BIT_MASK_XTAL_XORES_SEL_2_0) << BIT_SHIFT_XTAL_XORES_SEL_2_0)
#define BITS_XTAL_XORES_SEL_2_0 \
(BIT_MASK_XTAL_XORES_SEL_2_0 << BIT_SHIFT_XTAL_XORES_SEL_2_0)
#define BIT_CLEAR_XTAL_XORES_SEL_2_0(x) ((x) & (~BITS_XTAL_XORES_SEL_2_0))
#define BIT_GET_XTAL_XORES_SEL_2_0(x) \
(((x) >> BIT_SHIFT_XTAL_XORES_SEL_2_0) & BIT_MASK_XTAL_XORES_SEL_2_0)
#define BIT_SET_XTAL_XORES_SEL_2_0(x, v) \
(BIT_CLEAR_XTAL_XORES_SEL_2_0(x) | BIT_XTAL_XORES_SEL_2_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_DRV_DIGI_V2 26
#define BIT_MASK_XTAL_DRV_DIGI_V2 0x3
#define BIT_XTAL_DRV_DIGI_V2(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_V2) << BIT_SHIFT_XTAL_DRV_DIGI_V2)
#define BITS_XTAL_DRV_DIGI_V2 \
(BIT_MASK_XTAL_DRV_DIGI_V2 << BIT_SHIFT_XTAL_DRV_DIGI_V2)
#define BIT_CLEAR_XTAL_DRV_DIGI_V2(x) ((x) & (~BITS_XTAL_DRV_DIGI_V2))
#define BIT_GET_XTAL_DRV_DIGI_V2(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_V2) & BIT_MASK_XTAL_DRV_DIGI_V2)
#define BIT_SET_XTAL_DRV_DIGI_V2(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_V2(x) | BIT_XTAL_DRV_DIGI_V2(v))
#define BIT_EN_XTAL_DRV_LPS BIT(25)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_AAC_PK_SEL_1_0 25
#define BIT_MASK_XTAL_AAC_PK_SEL_1_0 0x3
#define BIT_XTAL_AAC_PK_SEL_1_0(x) \
(((x) & BIT_MASK_XTAL_AAC_PK_SEL_1_0) << BIT_SHIFT_XTAL_AAC_PK_SEL_1_0)
#define BITS_XTAL_AAC_PK_SEL_1_0 \
(BIT_MASK_XTAL_AAC_PK_SEL_1_0 << BIT_SHIFT_XTAL_AAC_PK_SEL_1_0)
#define BIT_CLEAR_XTAL_AAC_PK_SEL_1_0(x) ((x) & (~BITS_XTAL_AAC_PK_SEL_1_0))
#define BIT_GET_XTAL_AAC_PK_SEL_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_AAC_PK_SEL_1_0) & BIT_MASK_XTAL_AAC_PK_SEL_1_0)
#define BIT_SET_XTAL_AAC_PK_SEL_1_0(x, v) \
(BIT_CLEAR_XTAL_AAC_PK_SEL_1_0(x) | BIT_XTAL_AAC_PK_SEL_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_EN_XTAL_DRV_DIGI_V2 BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_EN_XTAL_AAC_PKDET BIT(24)
#define BIT_EN_XTAL_AAC_GM BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_DRV_USB 22
#define BIT_MASK_XTAL_DRV_USB 0x3
#define BIT_XTAL_DRV_USB(x) \
(((x) & BIT_MASK_XTAL_DRV_USB) << BIT_SHIFT_XTAL_DRV_USB)
#define BITS_XTAL_DRV_USB (BIT_MASK_XTAL_DRV_USB << BIT_SHIFT_XTAL_DRV_USB)
#define BIT_CLEAR_XTAL_DRV_USB(x) ((x) & (~BITS_XTAL_DRV_USB))
#define BIT_GET_XTAL_DRV_USB(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_USB) & BIT_MASK_XTAL_DRV_USB)
#define BIT_SET_XTAL_DRV_USB(x, v) \
(BIT_CLEAR_XTAL_DRV_USB(x) | BIT_XTAL_DRV_USB(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_LPMODE BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_EN_XTAL_DRV_USB BIT(21)
#define BIT_SHIFT_XTAL_DRV_AFE_V2 19
#define BIT_MASK_XTAL_DRV_AFE_V2 0x3
#define BIT_XTAL_DRV_AFE_V2(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_V2) << BIT_SHIFT_XTAL_DRV_AFE_V2)
#define BITS_XTAL_DRV_AFE_V2 \
(BIT_MASK_XTAL_DRV_AFE_V2 << BIT_SHIFT_XTAL_DRV_AFE_V2)
#define BIT_CLEAR_XTAL_DRV_AFE_V2(x) ((x) & (~BITS_XTAL_DRV_AFE_V2))
#define BIT_GET_XTAL_DRV_AFE_V2(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_V2) & BIT_MASK_XTAL_DRV_AFE_V2)
#define BIT_SET_XTAL_DRV_AFE_V2(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_V2(x) | BIT_XTAL_DRV_AFE_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_SEL_TOK_2_0 19
#define BIT_MASK_XTAL_SEL_TOK_2_0 0x7
#define BIT_XTAL_SEL_TOK_2_0(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_2_0) << BIT_SHIFT_XTAL_SEL_TOK_2_0)
#define BITS_XTAL_SEL_TOK_2_0 \
(BIT_MASK_XTAL_SEL_TOK_2_0 << BIT_SHIFT_XTAL_SEL_TOK_2_0)
#define BIT_CLEAR_XTAL_SEL_TOK_2_0(x) ((x) & (~BITS_XTAL_SEL_TOK_2_0))
#define BIT_GET_XTAL_SEL_TOK_2_0(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_2_0) & BIT_MASK_XTAL_SEL_TOK_2_0)
#define BIT_SET_XTAL_SEL_TOK_2_0(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_2_0(x) | BIT_XTAL_SEL_TOK_2_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_EN_XTAL_DRV_AFE BIT(18)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XQSEL_RF_AWAKE_V2 BIT(18)
#define BIT_XQSEL_RF_INITIAL_V2 BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_DRV_RF2_V2 16
#define BIT_MASK_XTAL_DRV_RF2_V2 0x3
#define BIT_XTAL_DRV_RF2_V2(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_V2) << BIT_SHIFT_XTAL_DRV_RF2_V2)
#define BITS_XTAL_DRV_RF2_V2 \
(BIT_MASK_XTAL_DRV_RF2_V2 << BIT_SHIFT_XTAL_DRV_RF2_V2)
#define BIT_CLEAR_XTAL_DRV_RF2_V2(x) ((x) & (~BITS_XTAL_DRV_RF2_V2))
#define BIT_GET_XTAL_DRV_RF2_V2(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_V2) & BIT_MASK_XTAL_DRV_RF2_V2)
#define BIT_SET_XTAL_DRV_RF2_V2(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_V2(x) | BIT_XTAL_DRV_RF2_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_DELAY_USB_V1 BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_EN_XTAL_DRV_RF2 BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_DELAY_DIGI_V1 BIT(15)
#define BIT_XTAL_DELAY_AFE_V1 BIT(14)
#define BIT_XTAL_DRV_RF_LATCH_V3 BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_EN_XTAL_DRV_RF1 BIT(12)
#define BIT_XTAL_DRV_RF_LATCH_V4 BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_DRV_DIGI_1_0 11
#define BIT_MASK_XTAL_DRV_DIGI_1_0 0x3
#define BIT_XTAL_DRV_DIGI_1_0(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_1_0) << BIT_SHIFT_XTAL_DRV_DIGI_1_0)
#define BITS_XTAL_DRV_DIGI_1_0 \
(BIT_MASK_XTAL_DRV_DIGI_1_0 << BIT_SHIFT_XTAL_DRV_DIGI_1_0)
#define BIT_CLEAR_XTAL_DRV_DIGI_1_0(x) ((x) & (~BITS_XTAL_DRV_DIGI_1_0))
#define BIT_GET_XTAL_DRV_DIGI_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_1_0) & BIT_MASK_XTAL_DRV_DIGI_1_0)
#define BIT_SET_XTAL_DRV_DIGI_1_0(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_1_0(x) | BIT_XTAL_DRV_DIGI_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_GM_SEP_V3 BIT(10)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_GATED_DIGIN BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XQSEL_RF_AWAKE_V3 BIT(9)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_GATED_DIGIP BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XQSEL_RF_INITIAL_V3 BIT(8)
#define BIT_XQSEL_V2 BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_DRV_USB_1_0 7
#define BIT_MASK_XTAL_DRV_USB_1_0 0x3
#define BIT_XTAL_DRV_USB_1_0(x) \
(((x) & BIT_MASK_XTAL_DRV_USB_1_0) << BIT_SHIFT_XTAL_DRV_USB_1_0)
#define BITS_XTAL_DRV_USB_1_0 \
(BIT_MASK_XTAL_DRV_USB_1_0 << BIT_SHIFT_XTAL_DRV_USB_1_0)
#define BIT_CLEAR_XTAL_DRV_USB_1_0(x) ((x) & (~BITS_XTAL_DRV_USB_1_0))
#define BIT_GET_XTAL_DRV_USB_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_USB_1_0) & BIT_MASK_XTAL_DRV_USB_1_0)
#define BIT_SET_XTAL_DRV_USB_1_0(x, v) \
(BIT_CLEAR_XTAL_DRV_USB_1_0(x) | BIT_XTAL_DRV_USB_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_GATED_XTAL_OK0_V2 BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_GATED_USBN BIT(6)
#define BIT_XTAL_GATED_USBP BIT(5)
#define BIT_SHIFT_XTAL_DRV_AFE_1_0 3
#define BIT_MASK_XTAL_DRV_AFE_1_0 0x3
#define BIT_XTAL_DRV_AFE_1_0(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_1_0) << BIT_SHIFT_XTAL_DRV_AFE_1_0)
#define BITS_XTAL_DRV_AFE_1_0 \
(BIT_MASK_XTAL_DRV_AFE_1_0 << BIT_SHIFT_XTAL_DRV_AFE_1_0)
#define BIT_CLEAR_XTAL_DRV_AFE_1_0(x) ((x) & (~BITS_XTAL_DRV_AFE_1_0))
#define BIT_GET_XTAL_DRV_AFE_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_1_0) & BIT_MASK_XTAL_DRV_AFE_1_0)
#define BIT_SET_XTAL_DRV_AFE_1_0(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_1_0(x) | BIT_XTAL_DRV_AFE_1_0(v))
#define BIT_XTAL_GATED_AFEN BIT(2)
#define BIT_XTAL_GATED_AFEP BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_SHIFT_XTAL_SC_LPS_V2 0
#define BIT_MASK_XTAL_SC_LPS_V2 0x3f
#define BIT_XTAL_SC_LPS_V2(x) \
(((x) & BIT_MASK_XTAL_SC_LPS_V2) << BIT_SHIFT_XTAL_SC_LPS_V2)
#define BITS_XTAL_SC_LPS_V2 \
(BIT_MASK_XTAL_SC_LPS_V2 << BIT_SHIFT_XTAL_SC_LPS_V2)
#define BIT_CLEAR_XTAL_SC_LPS_V2(x) ((x) & (~BITS_XTAL_SC_LPS_V2))
#define BIT_GET_XTAL_SC_LPS_V2(x) \
(((x) >> BIT_SHIFT_XTAL_SC_LPS_V2) & BIT_MASK_XTAL_SC_LPS_V2)
#define BIT_SET_XTAL_SC_LPS_V2(x, v) \
(BIT_CLEAR_XTAL_SC_LPS_V2(x) | BIT_XTAL_SC_LPS_V2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_1 (Offset 0x1044) */
#define BIT_XTAL_DRV_RF1_1 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_AAC_CAP BIT(31)
#define BIT_SHIFT_XTAL_PDSW 29
#define BIT_MASK_XTAL_PDSW 0x3
#define BIT_XTAL_PDSW(x) (((x) & BIT_MASK_XTAL_PDSW) << BIT_SHIFT_XTAL_PDSW)
#define BITS_XTAL_PDSW (BIT_MASK_XTAL_PDSW << BIT_SHIFT_XTAL_PDSW)
#define BIT_CLEAR_XTAL_PDSW(x) ((x) & (~BITS_XTAL_PDSW))
#define BIT_GET_XTAL_PDSW(x) (((x) >> BIT_SHIFT_XTAL_PDSW) & BIT_MASK_XTAL_PDSW)
#define BIT_SET_XTAL_PDSW(x, v) (BIT_CLEAR_XTAL_PDSW(x) | BIT_XTAL_PDSW(v))
#define BIT_SHIFT_XTAL_LPS_BUF_VB 27
#define BIT_MASK_XTAL_LPS_BUF_VB 0x3
#define BIT_XTAL_LPS_BUF_VB(x) \
(((x) & BIT_MASK_XTAL_LPS_BUF_VB) << BIT_SHIFT_XTAL_LPS_BUF_VB)
#define BITS_XTAL_LPS_BUF_VB \
(BIT_MASK_XTAL_LPS_BUF_VB << BIT_SHIFT_XTAL_LPS_BUF_VB)
#define BIT_CLEAR_XTAL_LPS_BUF_VB(x) ((x) & (~BITS_XTAL_LPS_BUF_VB))
#define BIT_GET_XTAL_LPS_BUF_VB(x) \
(((x) >> BIT_SHIFT_XTAL_LPS_BUF_VB) & BIT_MASK_XTAL_LPS_BUF_VB)
#define BIT_SET_XTAL_LPS_BUF_VB(x, v) \
(BIT_CLEAR_XTAL_LPS_BUF_VB(x) | BIT_XTAL_LPS_BUF_VB(v))
#define BIT_XTAL_PDCK_MANU BIT(26)
#define BIT_XTAL_PDCK_OK_MANU BIT(25)
#define BIT_SHIFT_XTAL_VREF_SEL 20
#define BIT_MASK_XTAL_VREF_SEL 0x1f
#define BIT_XTAL_VREF_SEL(x) \
(((x) & BIT_MASK_XTAL_VREF_SEL) << BIT_SHIFT_XTAL_VREF_SEL)
#define BITS_XTAL_VREF_SEL (BIT_MASK_XTAL_VREF_SEL << BIT_SHIFT_XTAL_VREF_SEL)
#define BIT_CLEAR_XTAL_VREF_SEL(x) ((x) & (~BITS_XTAL_VREF_SEL))
#define BIT_GET_XTAL_VREF_SEL(x) \
(((x) >> BIT_SHIFT_XTAL_VREF_SEL) & BIT_MASK_XTAL_VREF_SEL)
#define BIT_SET_XTAL_VREF_SEL(x, v) \
(BIT_CLEAR_XTAL_VREF_SEL(x) | BIT_XTAL_VREF_SEL(v))
#define BIT_EN_XTAL_PDCK_VREF BIT(19)
#define BIT_XTAL_SEL_PWR_V1 BIT(18)
#define BIT_XTAL_LPS_DIVISOR BIT(17)
#define BIT_XTAL_CKDIGI_SEL BIT(16)
#define BIT_EN_XTAL_LPS_CLK BIT(15)
#define BIT_EN_XTAL_SCHMITT BIT(14)
#define BIT_XTAL_PK_SEL_OFFSET BIT(13)
#define BIT_SHIFT_XTAL_MANU_PK_SEL 11
#define BIT_MASK_XTAL_MANU_PK_SEL 0x3
#define BIT_XTAL_MANU_PK_SEL(x) \
(((x) & BIT_MASK_XTAL_MANU_PK_SEL) << BIT_SHIFT_XTAL_MANU_PK_SEL)
#define BITS_XTAL_MANU_PK_SEL \
(BIT_MASK_XTAL_MANU_PK_SEL << BIT_SHIFT_XTAL_MANU_PK_SEL)
#define BIT_CLEAR_XTAL_MANU_PK_SEL(x) ((x) & (~BITS_XTAL_MANU_PK_SEL))
#define BIT_GET_XTAL_MANU_PK_SEL(x) \
(((x) >> BIT_SHIFT_XTAL_MANU_PK_SEL) & BIT_MASK_XTAL_MANU_PK_SEL)
#define BIT_SET_XTAL_MANU_PK_SEL(x, v) \
(BIT_CLEAR_XTAL_MANU_PK_SEL(x) | BIT_XTAL_MANU_PK_SEL(v))
#define BIT_XTAL_AACK_PK_MANU BIT(10)
#define BIT_EN_XTAL_AAC_PKDET_V1 BIT(9)
#define BIT_EN_XTAL_AAC_GM_V1 BIT(8)
#define BIT_XTAL_LDO_OPVB_SEL BIT(7)
#define BIT_SHIFT_XTAL_DUMMY_V1 7
#define BIT_MASK_XTAL_DUMMY_V1 0x3f
#define BIT_XTAL_DUMMY_V1(x) \
(((x) & BIT_MASK_XTAL_DUMMY_V1) << BIT_SHIFT_XTAL_DUMMY_V1)
#define BITS_XTAL_DUMMY_V1 (BIT_MASK_XTAL_DUMMY_V1 << BIT_SHIFT_XTAL_DUMMY_V1)
#define BIT_CLEAR_XTAL_DUMMY_V1(x) ((x) & (~BITS_XTAL_DUMMY_V1))
#define BIT_GET_XTAL_DUMMY_V1(x) \
(((x) >> BIT_SHIFT_XTAL_DUMMY_V1) & BIT_MASK_XTAL_DUMMY_V1)
#define BIT_SET_XTAL_DUMMY_V1(x, v) \
(BIT_CLEAR_XTAL_DUMMY_V1(x) | BIT_XTAL_DUMMY_V1(v))
#define BIT_XTAL_LDO_NC BIT(6)
#define BIT_XTAL_EN_LNBUF BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_DRV_RF2_LATCH BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL__AAC_TIE_MID BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_SHIFT_XTAL_DRV_RF2_1_0 4
#define BIT_MASK_XTAL_DRV_RF2_1_0 0x3
#define BIT_XTAL_DRV_RF2_1_0(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_1_0) << BIT_SHIFT_XTAL_DRV_RF2_1_0)
#define BITS_XTAL_DRV_RF2_1_0 \
(BIT_MASK_XTAL_DRV_RF2_1_0 << BIT_SHIFT_XTAL_DRV_RF2_1_0)
#define BIT_CLEAR_XTAL_DRV_RF2_1_0(x) ((x) & (~BITS_XTAL_DRV_RF2_1_0))
#define BIT_GET_XTAL_DRV_RF2_1_0(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_1_0) & BIT_MASK_XTAL_DRV_RF2_1_0)
#define BIT_SET_XTAL_DRV_RF2_1_0(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_1_0(x) | BIT_XTAL_DRV_RF2_1_0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_SHIFT_XTAL_LDO_VREF_V2 3
#define BIT_MASK_XTAL_LDO_VREF_V2 0x7
#define BIT_XTAL_LDO_VREF_V2(x) \
(((x) & BIT_MASK_XTAL_LDO_VREF_V2) << BIT_SHIFT_XTAL_LDO_VREF_V2)
#define BITS_XTAL_LDO_VREF_V2 \
(BIT_MASK_XTAL_LDO_VREF_V2 << BIT_SHIFT_XTAL_LDO_VREF_V2)
#define BIT_CLEAR_XTAL_LDO_VREF_V2(x) ((x) & (~BITS_XTAL_LDO_VREF_V2))
#define BIT_GET_XTAL_LDO_VREF_V2(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_VREF_V2) & BIT_MASK_XTAL_LDO_VREF_V2)
#define BIT_SET_XTAL_LDO_VREF_V2(x, v) \
(BIT_CLEAR_XTAL_LDO_VREF_V2(x) | BIT_XTAL_LDO_VREF_V2(v))
#define BIT_SHIFT_XTAL_AAC_OPCUR 3
#define BIT_MASK_XTAL_AAC_OPCUR 0x3
#define BIT_XTAL_AAC_OPCUR(x) \
(((x) & BIT_MASK_XTAL_AAC_OPCUR) << BIT_SHIFT_XTAL_AAC_OPCUR)
#define BITS_XTAL_AAC_OPCUR \
(BIT_MASK_XTAL_AAC_OPCUR << BIT_SHIFT_XTAL_AAC_OPCUR)
#define BIT_CLEAR_XTAL_AAC_OPCUR(x) ((x) & (~BITS_XTAL_AAC_OPCUR))
#define BIT_GET_XTAL_AAC_OPCUR(x) \
(((x) >> BIT_SHIFT_XTAL_AAC_OPCUR) & BIT_MASK_XTAL_AAC_OPCUR)
#define BIT_SET_XTAL_AAC_OPCUR(x, v) \
(BIT_CLEAR_XTAL_AAC_OPCUR(x) | BIT_XTAL_AAC_OPCUR(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_GATED_RF2N BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_LPMODE_V1 BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_GATED_RF2P BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_SHIFT_XTAL_AAC_IOFFSET 1
#define BIT_MASK_XTAL_AAC_IOFFSET 0x3
#define BIT_XTAL_AAC_IOFFSET(x) \
(((x) & BIT_MASK_XTAL_AAC_IOFFSET) << BIT_SHIFT_XTAL_AAC_IOFFSET)
#define BITS_XTAL_AAC_IOFFSET \
(BIT_MASK_XTAL_AAC_IOFFSET << BIT_SHIFT_XTAL_AAC_IOFFSET)
#define BIT_CLEAR_XTAL_AAC_IOFFSET(x) ((x) & (~BITS_XTAL_AAC_IOFFSET))
#define BIT_GET_XTAL_AAC_IOFFSET(x) \
(((x) >> BIT_SHIFT_XTAL_AAC_IOFFSET) & BIT_MASK_XTAL_AAC_IOFFSET)
#define BIT_SET_XTAL_AAC_IOFFSET(x, v) \
(BIT_CLEAR_XTAL_AAC_IOFFSET(x) | BIT_XTAL_AAC_IOFFSET(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_LDO_DI BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_SHIFT_XTAL_SEL_TOK_V3 0
#define BIT_MASK_XTAL_SEL_TOK_V3 0x3
#define BIT_XTAL_SEL_TOK_V3(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_V3) << BIT_SHIFT_XTAL_SEL_TOK_V3)
#define BITS_XTAL_SEL_TOK_V3 \
(BIT_MASK_XTAL_SEL_TOK_V3 << BIT_SHIFT_XTAL_SEL_TOK_V3)
#define BIT_CLEAR_XTAL_SEL_TOK_V3(x) ((x) & (~BITS_XTAL_SEL_TOK_V3))
#define BIT_GET_XTAL_SEL_TOK_V3(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_V3) & BIT_MASK_XTAL_SEL_TOK_V3)
#define BIT_SET_XTAL_SEL_TOK_V3(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_V3(x) | BIT_XTAL_SEL_TOK_V3(v))
#define BIT_XTAL_AAC_CAP_V1 BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ANAPAR_XTAL_2 (Offset 0x1048) */
#define BIT_XTAL_SEL_PWR BIT(0)
/* 2 REG_ANAPAR_XTAL_AAC (Offset 0x104C) */
#define BIT_SHIFT_GM_MANUAL_4_0 21
#define BIT_MASK_GM_MANUAL_4_0 0x1f
#define BIT_GM_MANUAL_4_0(x) \
(((x) & BIT_MASK_GM_MANUAL_4_0) << BIT_SHIFT_GM_MANUAL_4_0)
#define BITS_GM_MANUAL_4_0 (BIT_MASK_GM_MANUAL_4_0 << BIT_SHIFT_GM_MANUAL_4_0)
#define BIT_CLEAR_GM_MANUAL_4_0(x) ((x) & (~BITS_GM_MANUAL_4_0))
#define BIT_GET_GM_MANUAL_4_0(x) \
(((x) >> BIT_SHIFT_GM_MANUAL_4_0) & BIT_MASK_GM_MANUAL_4_0)
#define BIT_SET_GM_MANUAL_4_0(x, v) \
(BIT_CLEAR_GM_MANUAL_4_0(x) | BIT_GM_MANUAL_4_0(v))
#define BIT_SHIFT_GM_STUP_4_0 16
#define BIT_MASK_GM_STUP_4_0 0x1f
#define BIT_GM_STUP_4_0(x) \
(((x) & BIT_MASK_GM_STUP_4_0) << BIT_SHIFT_GM_STUP_4_0)
#define BITS_GM_STUP_4_0 (BIT_MASK_GM_STUP_4_0 << BIT_SHIFT_GM_STUP_4_0)
#define BIT_CLEAR_GM_STUP_4_0(x) ((x) & (~BITS_GM_STUP_4_0))
#define BIT_GET_GM_STUP_4_0(x) \
(((x) >> BIT_SHIFT_GM_STUP_4_0) & BIT_MASK_GM_STUP_4_0)
#define BIT_SET_GM_STUP_4_0(x, v) \
(BIT_CLEAR_GM_STUP_4_0(x) | BIT_GM_STUP_4_0(v))
#define BIT_SHIFT_XTAL_CK_SET_2_0 13
#define BIT_MASK_XTAL_CK_SET_2_0 0x7
#define BIT_XTAL_CK_SET_2_0(x) \
(((x) & BIT_MASK_XTAL_CK_SET_2_0) << BIT_SHIFT_XTAL_CK_SET_2_0)
#define BITS_XTAL_CK_SET_2_0 \
(BIT_MASK_XTAL_CK_SET_2_0 << BIT_SHIFT_XTAL_CK_SET_2_0)
#define BIT_CLEAR_XTAL_CK_SET_2_0(x) ((x) & (~BITS_XTAL_CK_SET_2_0))
#define BIT_GET_XTAL_CK_SET_2_0(x) \
(((x) >> BIT_SHIFT_XTAL_CK_SET_2_0) & BIT_MASK_XTAL_CK_SET_2_0)
#define BIT_SET_XTAL_CK_SET_2_0(x, v) \
(BIT_CLEAR_XTAL_CK_SET_2_0(x) | BIT_XTAL_CK_SET_2_0(v))
#define BIT_SHIFT_GM_INIT_4_0 8
#define BIT_MASK_GM_INIT_4_0 0x1f
#define BIT_GM_INIT_4_0(x) \
(((x) & BIT_MASK_GM_INIT_4_0) << BIT_SHIFT_GM_INIT_4_0)
#define BITS_GM_INIT_4_0 (BIT_MASK_GM_INIT_4_0 << BIT_SHIFT_GM_INIT_4_0)
#define BIT_CLEAR_GM_INIT_4_0(x) ((x) & (~BITS_GM_INIT_4_0))
#define BIT_GET_GM_INIT_4_0(x) \
(((x) >> BIT_SHIFT_GM_INIT_4_0) & BIT_MASK_GM_INIT_4_0)
#define BIT_SET_GM_INIT_4_0(x, v) \
(BIT_CLEAR_GM_INIT_4_0(x) | BIT_GM_INIT_4_0(v))
#define BIT_SHIFT_XAAC_GM_OFFSET_4_0 2
#define BIT_MASK_XAAC_GM_OFFSET_4_0 0x1f
#define BIT_XAAC_GM_OFFSET_4_0(x) \
(((x) & BIT_MASK_XAAC_GM_OFFSET_4_0) << BIT_SHIFT_XAAC_GM_OFFSET_4_0)
#define BITS_XAAC_GM_OFFSET_4_0 \
(BIT_MASK_XAAC_GM_OFFSET_4_0 << BIT_SHIFT_XAAC_GM_OFFSET_4_0)
#define BIT_CLEAR_XAAC_GM_OFFSET_4_0(x) ((x) & (~BITS_XAAC_GM_OFFSET_4_0))
#define BIT_GET_XAAC_GM_OFFSET_4_0(x) \
(((x) >> BIT_SHIFT_XAAC_GM_OFFSET_4_0) & BIT_MASK_XAAC_GM_OFFSET_4_0)
#define BIT_SET_XAAC_GM_OFFSET_4_0(x, v) \
(BIT_CLEAR_XAAC_GM_OFFSET_4_0(x) | BIT_XAAC_GM_OFFSET_4_0(v))
/* 2 REG_ANAPAR_XTAL_R_ONLY (Offset 0x1050) */
#define BIT_XTAL_PKDET_OUT BIT(6)
#define BIT_SHIFT_XTAL_GM_AAC_4_0 1
#define BIT_MASK_XTAL_GM_AAC_4_0 0x1f
#define BIT_XTAL_GM_AAC_4_0(x) \
(((x) & BIT_MASK_XTAL_GM_AAC_4_0) << BIT_SHIFT_XTAL_GM_AAC_4_0)
#define BITS_XTAL_GM_AAC_4_0 \
(BIT_MASK_XTAL_GM_AAC_4_0 << BIT_SHIFT_XTAL_GM_AAC_4_0)
#define BIT_CLEAR_XTAL_GM_AAC_4_0(x) ((x) & (~BITS_XTAL_GM_AAC_4_0))
#define BIT_GET_XTAL_GM_AAC_4_0(x) \
(((x) >> BIT_SHIFT_XTAL_GM_AAC_4_0) & BIT_MASK_XTAL_GM_AAC_4_0)
#define BIT_SET_XTAL_GM_AAC_4_0(x, v) \
(BIT_CLEAR_XTAL_GM_AAC_4_0(x) | BIT_XTAL_GM_AAC_4_0(v))
#define BIT_XAAC_READY BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_AACK_0 (Offset 0x1054) */
#define BIT_XAAC_LPOW BIT(31)
#define BIT_SHIFT_AAC_MODE 29
#define BIT_MASK_AAC_MODE 0x3
#define BIT_AAC_MODE(x) (((x) & BIT_MASK_AAC_MODE) << BIT_SHIFT_AAC_MODE)
#define BITS_AAC_MODE (BIT_MASK_AAC_MODE << BIT_SHIFT_AAC_MODE)
#define BIT_CLEAR_AAC_MODE(x) ((x) & (~BITS_AAC_MODE))
#define BIT_GET_AAC_MODE(x) (((x) >> BIT_SHIFT_AAC_MODE) & BIT_MASK_AAC_MODE)
#define BIT_SET_AAC_MODE(x, v) (BIT_CLEAR_AAC_MODE(x) | BIT_AAC_MODE(v))
#define BIT_SHIFT_GM_MANUAL 21
#define BIT_MASK_GM_MANUAL 0x1f
#define BIT_GM_MANUAL(x) (((x) & BIT_MASK_GM_MANUAL) << BIT_SHIFT_GM_MANUAL)
#define BITS_GM_MANUAL (BIT_MASK_GM_MANUAL << BIT_SHIFT_GM_MANUAL)
#define BIT_CLEAR_GM_MANUAL(x) ((x) & (~BITS_GM_MANUAL))
#define BIT_GET_GM_MANUAL(x) (((x) >> BIT_SHIFT_GM_MANUAL) & BIT_MASK_GM_MANUAL)
#define BIT_SET_GM_MANUAL(x, v) (BIT_CLEAR_GM_MANUAL(x) | BIT_GM_MANUAL(v))
#define BIT_SHIFT_XTAL_LDO_LPS 21
#define BIT_MASK_XTAL_LDO_LPS 0x7
#define BIT_XTAL_LDO_LPS(x) \
(((x) & BIT_MASK_XTAL_LDO_LPS) << BIT_SHIFT_XTAL_LDO_LPS)
#define BITS_XTAL_LDO_LPS (BIT_MASK_XTAL_LDO_LPS << BIT_SHIFT_XTAL_LDO_LPS)
#define BIT_CLEAR_XTAL_LDO_LPS(x) ((x) & (~BITS_XTAL_LDO_LPS))
#define BIT_GET_XTAL_LDO_LPS(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_LPS) & BIT_MASK_XTAL_LDO_LPS)
#define BIT_SET_XTAL_LDO_LPS(x, v) \
(BIT_CLEAR_XTAL_LDO_LPS(x) | BIT_XTAL_LDO_LPS(v))
#define BIT_SHIFT_GM_STUP 16
#define BIT_MASK_GM_STUP 0x1f
#define BIT_GM_STUP(x) (((x) & BIT_MASK_GM_STUP) << BIT_SHIFT_GM_STUP)
#define BITS_GM_STUP (BIT_MASK_GM_STUP << BIT_SHIFT_GM_STUP)
#define BIT_CLEAR_GM_STUP(x) ((x) & (~BITS_GM_STUP))
#define BIT_GET_GM_STUP(x) (((x) >> BIT_SHIFT_GM_STUP) & BIT_MASK_GM_STUP)
#define BIT_SET_GM_STUP(x, v) (BIT_CLEAR_GM_STUP(x) | BIT_GM_STUP(v))
#define BIT_SHIFT_XTAL_WAIT_CYC 15
#define BIT_MASK_XTAL_WAIT_CYC 0x3f
#define BIT_XTAL_WAIT_CYC(x) \
(((x) & BIT_MASK_XTAL_WAIT_CYC) << BIT_SHIFT_XTAL_WAIT_CYC)
#define BITS_XTAL_WAIT_CYC (BIT_MASK_XTAL_WAIT_CYC << BIT_SHIFT_XTAL_WAIT_CYC)
#define BIT_CLEAR_XTAL_WAIT_CYC(x) ((x) & (~BITS_XTAL_WAIT_CYC))
#define BIT_GET_XTAL_WAIT_CYC(x) \
(((x) >> BIT_SHIFT_XTAL_WAIT_CYC) & BIT_MASK_XTAL_WAIT_CYC)
#define BIT_SET_XTAL_WAIT_CYC(x, v) \
(BIT_CLEAR_XTAL_WAIT_CYC(x) | BIT_XTAL_WAIT_CYC(v))
#define BIT_SHIFT_XTAL_CK_SET 13
#define BIT_MASK_XTAL_CK_SET 0x7
#define BIT_XTAL_CK_SET(x) \
(((x) & BIT_MASK_XTAL_CK_SET) << BIT_SHIFT_XTAL_CK_SET)
#define BITS_XTAL_CK_SET (BIT_MASK_XTAL_CK_SET << BIT_SHIFT_XTAL_CK_SET)
#define BIT_CLEAR_XTAL_CK_SET(x) ((x) & (~BITS_XTAL_CK_SET))
#define BIT_GET_XTAL_CK_SET(x) \
(((x) >> BIT_SHIFT_XTAL_CK_SET) & BIT_MASK_XTAL_CK_SET)
#define BIT_SET_XTAL_CK_SET(x, v) \
(BIT_CLEAR_XTAL_CK_SET(x) | BIT_XTAL_CK_SET(v))
#define BIT_SHIFT_XTAL_LDO_OK 12
#define BIT_MASK_XTAL_LDO_OK 0x7
#define BIT_XTAL_LDO_OK(x) \
(((x) & BIT_MASK_XTAL_LDO_OK) << BIT_SHIFT_XTAL_LDO_OK)
#define BITS_XTAL_LDO_OK (BIT_MASK_XTAL_LDO_OK << BIT_SHIFT_XTAL_LDO_OK)
#define BIT_CLEAR_XTAL_LDO_OK(x) ((x) & (~BITS_XTAL_LDO_OK))
#define BIT_GET_XTAL_LDO_OK(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_OK) & BIT_MASK_XTAL_LDO_OK)
#define BIT_SET_XTAL_LDO_OK(x, v) \
(BIT_CLEAR_XTAL_LDO_OK(x) | BIT_XTAL_LDO_OK(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPHY_LDO (Offset 0x1054) */
#define BIT_SHIFT_CPHY_LDO_PD 12
#define BIT_MASK_CPHY_LDO_PD 0x3
#define BIT_CPHY_LDO_PD(x) \
(((x) & BIT_MASK_CPHY_LDO_PD) << BIT_SHIFT_CPHY_LDO_PD)
#define BITS_CPHY_LDO_PD (BIT_MASK_CPHY_LDO_PD << BIT_SHIFT_CPHY_LDO_PD)
#define BIT_CLEAR_CPHY_LDO_PD(x) ((x) & (~BITS_CPHY_LDO_PD))
#define BIT_GET_CPHY_LDO_PD(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_PD) & BIT_MASK_CPHY_LDO_PD)
#define BIT_SET_CPHY_LDO_PD(x, v) \
(BIT_CLEAR_CPHY_LDO_PD(x) | BIT_CPHY_LDO_PD(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_AACK_0 (Offset 0x1054) */
#define BIT_XTAL_MD_LPOW BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPHY_LDO (Offset 0x1054) */
#define BIT_SHIFT_CPHY_LDO_SR 10
#define BIT_MASK_CPHY_LDO_SR 0x3
#define BIT_CPHY_LDO_SR(x) \
(((x) & BIT_MASK_CPHY_LDO_SR) << BIT_SHIFT_CPHY_LDO_SR)
#define BITS_CPHY_LDO_SR (BIT_MASK_CPHY_LDO_SR << BIT_SHIFT_CPHY_LDO_SR)
#define BIT_CLEAR_CPHY_LDO_SR(x) ((x) & (~BITS_CPHY_LDO_SR))
#define BIT_GET_CPHY_LDO_SR(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_SR) & BIT_MASK_CPHY_LDO_SR)
#define BIT_SET_CPHY_LDO_SR(x, v) \
(BIT_CLEAR_CPHY_LDO_SR(x) | BIT_CPHY_LDO_SR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_AACK_0 (Offset 0x1054) */
#define BIT_SHIFT_XTAL_OV_RATIO 9
#define BIT_MASK_XTAL_OV_RATIO 0x3
#define BIT_XTAL_OV_RATIO(x) \
(((x) & BIT_MASK_XTAL_OV_RATIO) << BIT_SHIFT_XTAL_OV_RATIO)
#define BITS_XTAL_OV_RATIO (BIT_MASK_XTAL_OV_RATIO << BIT_SHIFT_XTAL_OV_RATIO)
#define BIT_CLEAR_XTAL_OV_RATIO(x) ((x) & (~BITS_XTAL_OV_RATIO))
#define BIT_GET_XTAL_OV_RATIO(x) \
(((x) >> BIT_SHIFT_XTAL_OV_RATIO) & BIT_MASK_XTAL_OV_RATIO)
#define BIT_SET_XTAL_OV_RATIO(x, v) \
(BIT_CLEAR_XTAL_OV_RATIO(x) | BIT_XTAL_OV_RATIO(v))
#define BIT_SHIFT_GM_INIT 8
#define BIT_MASK_GM_INIT 0x1f
#define BIT_GM_INIT(x) (((x) & BIT_MASK_GM_INIT) << BIT_SHIFT_GM_INIT)
#define BITS_GM_INIT (BIT_MASK_GM_INIT << BIT_SHIFT_GM_INIT)
#define BIT_CLEAR_GM_INIT(x) ((x) & (~BITS_GM_INIT))
#define BIT_GET_GM_INIT(x) (((x) >> BIT_SHIFT_GM_INIT) & BIT_MASK_GM_INIT)
#define BIT_SET_GM_INIT(x, v) (BIT_CLEAR_GM_INIT(x) | BIT_GM_INIT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPHY_LDO (Offset 0x1054) */
#define BIT_SHIFT_CPHY_LDO_TUNEREF 8
#define BIT_MASK_CPHY_LDO_TUNEREF 0x3
#define BIT_CPHY_LDO_TUNEREF(x) \
(((x) & BIT_MASK_CPHY_LDO_TUNEREF) << BIT_SHIFT_CPHY_LDO_TUNEREF)
#define BITS_CPHY_LDO_TUNEREF \
(BIT_MASK_CPHY_LDO_TUNEREF << BIT_SHIFT_CPHY_LDO_TUNEREF)
#define BIT_CLEAR_CPHY_LDO_TUNEREF(x) ((x) & (~BITS_CPHY_LDO_TUNEREF))
#define BIT_GET_CPHY_LDO_TUNEREF(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_TUNEREF) & BIT_MASK_CPHY_LDO_TUNEREF)
#define BIT_SET_CPHY_LDO_TUNEREF(x, v) \
(BIT_CLEAR_CPHY_LDO_TUNEREF(x) | BIT_CPHY_LDO_TUNEREF(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_AACK_0 (Offset 0x1054) */
#define BIT_SHIFT_XTAL_OV_UNIT 6
#define BIT_MASK_XTAL_OV_UNIT 0x7
#define BIT_XTAL_OV_UNIT(x) \
(((x) & BIT_MASK_XTAL_OV_UNIT) << BIT_SHIFT_XTAL_OV_UNIT)
#define BITS_XTAL_OV_UNIT (BIT_MASK_XTAL_OV_UNIT << BIT_SHIFT_XTAL_OV_UNIT)
#define BIT_CLEAR_XTAL_OV_UNIT(x) ((x) & (~BITS_XTAL_OV_UNIT))
#define BIT_GET_XTAL_OV_UNIT(x) \
(((x) >> BIT_SHIFT_XTAL_OV_UNIT) & BIT_MASK_XTAL_OV_UNIT)
#define BIT_SET_XTAL_OV_UNIT(x, v) \
(BIT_CLEAR_XTAL_OV_UNIT(x) | BIT_XTAL_OV_UNIT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPHY_LDO (Offset 0x1054) */
#define BIT_SHIFT_CPHY_LDO_TUNE_VO 5
#define BIT_MASK_CPHY_LDO_TUNE_VO 0x7
#define BIT_CPHY_LDO_TUNE_VO(x) \
(((x) & BIT_MASK_CPHY_LDO_TUNE_VO) << BIT_SHIFT_CPHY_LDO_TUNE_VO)
#define BITS_CPHY_LDO_TUNE_VO \
(BIT_MASK_CPHY_LDO_TUNE_VO << BIT_SHIFT_CPHY_LDO_TUNE_VO)
#define BIT_CLEAR_CPHY_LDO_TUNE_VO(x) ((x) & (~BITS_CPHY_LDO_TUNE_VO))
#define BIT_GET_CPHY_LDO_TUNE_VO(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_TUNE_VO) & BIT_MASK_CPHY_LDO_TUNE_VO)
#define BIT_SET_CPHY_LDO_TUNE_VO(x, v) \
(BIT_CLEAR_CPHY_LDO_TUNE_VO(x) | BIT_CPHY_LDO_TUNE_VO(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_AACK_0 (Offset 0x1054) */
#define BIT_SHIFT_XTAL_MODE_MANUAL 4
#define BIT_MASK_XTAL_MODE_MANUAL 0x3
#define BIT_XTAL_MODE_MANUAL(x) \
(((x) & BIT_MASK_XTAL_MODE_MANUAL) << BIT_SHIFT_XTAL_MODE_MANUAL)
#define BITS_XTAL_MODE_MANUAL \
(BIT_MASK_XTAL_MODE_MANUAL << BIT_SHIFT_XTAL_MODE_MANUAL)
#define BIT_CLEAR_XTAL_MODE_MANUAL(x) ((x) & (~BITS_XTAL_MODE_MANUAL))
#define BIT_GET_XTAL_MODE_MANUAL(x) \
(((x) >> BIT_SHIFT_XTAL_MODE_MANUAL) & BIT_MASK_XTAL_MODE_MANUAL)
#define BIT_SET_XTAL_MODE_MANUAL(x, v) \
(BIT_CLEAR_XTAL_MODE_MANUAL(x) | BIT_XTAL_MODE_MANUAL(v))
#define BIT_SHIFT_PK_END_AR 3
#define BIT_MASK_PK_END_AR 0x3
#define BIT_PK_END_AR(x) (((x) & BIT_MASK_PK_END_AR) << BIT_SHIFT_PK_END_AR)
#define BITS_PK_END_AR (BIT_MASK_PK_END_AR << BIT_SHIFT_PK_END_AR)
#define BIT_CLEAR_PK_END_AR(x) ((x) & (~BITS_PK_END_AR))
#define BIT_GET_PK_END_AR(x) (((x) >> BIT_SHIFT_PK_END_AR) & BIT_MASK_PK_END_AR)
#define BIT_SET_PK_END_AR(x, v) (BIT_CLEAR_PK_END_AR(x) | BIT_PK_END_AR(v))
#define BIT_XTAL_MANU_SEL BIT(3)
#define BIT_SHIFT_XAAC_GM_OFFSET 2
#define BIT_MASK_XAAC_GM_OFFSET 0x1f
#define BIT_XAAC_GM_OFFSET(x) \
(((x) & BIT_MASK_XAAC_GM_OFFSET) << BIT_SHIFT_XAAC_GM_OFFSET)
#define BITS_XAAC_GM_OFFSET \
(BIT_MASK_XAAC_GM_OFFSET << BIT_SHIFT_XAAC_GM_OFFSET)
#define BIT_CLEAR_XAAC_GM_OFFSET(x) ((x) & (~BITS_XAAC_GM_OFFSET))
#define BIT_GET_XAAC_GM_OFFSET(x) \
(((x) >> BIT_SHIFT_XAAC_GM_OFFSET) & BIT_MASK_XAAC_GM_OFFSET)
#define BIT_SET_XAAC_GM_OFFSET(x, v) \
(BIT_CLEAR_XAAC_GM_OFFSET(x) | BIT_XAAC_GM_OFFSET(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPHY_LDO (Offset 0x1054) */
#define BIT_SHIFT_CPHY_LDO_OCP_VTH 2
#define BIT_MASK_CPHY_LDO_OCP_VTH 0x7
#define BIT_CPHY_LDO_OCP_VTH(x) \
(((x) & BIT_MASK_CPHY_LDO_OCP_VTH) << BIT_SHIFT_CPHY_LDO_OCP_VTH)
#define BITS_CPHY_LDO_OCP_VTH \
(BIT_MASK_CPHY_LDO_OCP_VTH << BIT_SHIFT_CPHY_LDO_OCP_VTH)
#define BIT_CLEAR_CPHY_LDO_OCP_VTH(x) ((x) & (~BITS_CPHY_LDO_OCP_VTH))
#define BIT_GET_CPHY_LDO_OCP_VTH(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_OCP_VTH) & BIT_MASK_CPHY_LDO_OCP_VTH)
#define BIT_SET_CPHY_LDO_OCP_VTH(x, v) \
(BIT_CLEAR_CPHY_LDO_OCP_VTH(x) | BIT_CPHY_LDO_OCP_VTH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_ANAPAR_XTAL_AACK_0 (Offset 0x1054) */
#define BIT_SHIFT_PK_START_AR 1
#define BIT_MASK_PK_START_AR 0x3
#define BIT_PK_START_AR(x) \
(((x) & BIT_MASK_PK_START_AR) << BIT_SHIFT_PK_START_AR)
#define BITS_PK_START_AR (BIT_MASK_PK_START_AR << BIT_SHIFT_PK_START_AR)
#define BIT_CLEAR_PK_START_AR(x) ((x) & (~BITS_PK_START_AR))
#define BIT_GET_PK_START_AR(x) \
(((x) >> BIT_SHIFT_PK_START_AR) & BIT_MASK_PK_START_AR)
#define BIT_SET_PK_START_AR(x, v) \
(BIT_CLEAR_PK_START_AR(x) | BIT_PK_START_AR(v))
#define BIT_XTAL_MODE BIT(1)
#define BIT_XAAC_LUT_MANUAL_EN BIT(0)
#define BIT_RESET_N_DECODER BIT(0)
#endif
#if (HALMAC_8822C_SUPPORT)
/* 2 REG_WLRF1 (Offset 0x00EC) */
#define BIT_XAAC_READY_V1 BIT(7)
#define BIT_SHIFT_XAAC_PK_SEL 5
#define BIT_MASK_XAAC_PK_SEL 0x3
#define BIT_XAAC_PK_SEL(x) \
(((x) & BIT_MASK_XAAC_PK_SEL) << BIT_SHIFT_XAAC_PK_SEL)
#define BITS_XAAC_PK_SEL (BIT_MASK_XAAC_PK_SEL << BIT_SHIFT_XAAC_PK_SEL)
#define BIT_CLEAR_XAAC_PK_SEL(x) ((x) & (~BITS_XAAC_PK_SEL))
#define BIT_GET_XAAC_PK_SEL(x) \
(((x) >> BIT_SHIFT_XAAC_PK_SEL) & BIT_MASK_XAAC_PK_SEL)
#define BIT_SET_XAAC_PK_SEL(x, v) \
(BIT_CLEAR_XAAC_PK_SEL(x) | BIT_XAAC_PK_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CPHY_LDO (Offset 0x1054) */
#define BIT_SHIFT_VREF_LDO_OK 0
#define BIT_MASK_VREF_LDO_OK 0x3
#define BIT_VREF_LDO_OK(x) \
(((x) & BIT_MASK_VREF_LDO_OK) << BIT_SHIFT_VREF_LDO_OK)
#define BITS_VREF_LDO_OK (BIT_MASK_VREF_LDO_OK << BIT_SHIFT_VREF_LDO_OK)
#define BIT_CLEAR_VREF_LDO_OK(x) ((x) & (~BITS_VREF_LDO_OK))
#define BIT_GET_VREF_LDO_OK(x) \
(((x) >> BIT_SHIFT_VREF_LDO_OK) & BIT_MASK_VREF_LDO_OK)
#define BIT_SET_VREF_LDO_OK(x, v) \
(BIT_CLEAR_VREF_LDO_OK(x) | BIT_VREF_LDO_OK(v))
/* 2 REG_CPHY_BG (Offset 0x1058) */
#define BIT_TXBCN_OK_PORT4 BIT(31)
#define BIT_ATIMEND_PORT4 BIT(31)
#define BIT_TXBCN_OK_PORT3 BIT(30)
#define BIT_ATIMEND_PORT3 BIT(30)
#define BIT_TXBCN_OK_PORT2 BIT(29)
#define BIT_ATIMEND_PORT2 BIT(29)
#define BIT_TXBCN_OK_PORT1 BIT(28)
#define BIT_ATIMEND_PORT1 BIT(28)
#define BIT_TXBCN15OK BIT(23)
#define BIT_BCNDMAINT15 BIT(23)
#define BIT_ATIMEND15 BIT(23)
#define BIT_TXBCN14OK BIT(22)
#define BIT_BCNDMAINT14 BIT(22)
#define BIT_ATIMEND14 BIT(22)
#define BIT_TXBCN13OK BIT(21)
#define BIT_BCNDMAINT13 BIT(21)
#define BIT_ATIMEND13 BIT(21)
#define BIT_TXBCN12OK BIT(20)
#define BIT_BCNDMAINT12 BIT(20)
#define BIT_ATIMEND12 BIT(20)
#define BIT_TXBCN11OK BIT(19)
#define BIT_BCNDMAINT11 BIT(19)
#define BIT_ATIMEND11 BIT(19)
#define BIT_TXBCN10OK BIT(18)
#define BIT_BCNDMAINT10 BIT(18)
#define BIT_ATIMEND10 BIT(18)
#define BIT_TXBCN9OK BIT(17)
#define BIT_BCNDMAINT9 BIT(17)
#define BIT_ATIMEND9 BIT(17)
#define BIT_TXBCN8OK BIT(16)
#define BIT_BCNDMAINT8 BIT(16)
#define BIT_ATIMEND8 BIT(16)
#define BIT_BCNDERR_PORT4 BIT(15)
#define BIT_BCNDERR_PORT3 BIT(14)
#define BIT_BCNDERR_PORT2 BIT(13)
#define BIT_BCNDERR_PORT1 BIT(12)
#define BIT_TXBCN15ERR BIT(7)
#define BIT_BCNDERR15 BIT(7)
#define BIT_TXBCN14ERR BIT(6)
#define BIT_BCNDERR14 BIT(6)
#define BIT_TXBCN13ERR BIT(5)
#define BIT_BCNDERR13 BIT(5)
#define BIT_PS_TIMER_EARLY_INT_5 BIT(5)
#define BIT_TXBCN12ERR BIT(4)
#define BIT_BCNDERR12 BIT(4)
#define BIT_PS_TIMER_EARLY_INT_4 BIT(4)
#define BIT_TXBCN11ERR BIT(3)
#define BIT_BCNDERR11 BIT(3)
#define BIT_PS_TIMER_EARLY_INT_3 BIT(3)
#define BIT_TXBCN10ERR BIT(2)
#define BIT_BCNDERR10 BIT(2)
#define BIT_PS_TIMER_EARLY_INT_2 BIT(2)
#define BIT_TXBCN9ERR BIT(1)
#define BIT_BCNDERR9 BIT(1)
#define BIT_PS_TIMER_EARLY_INT_1 BIT(1)
#define BIT_SHIFT_BG 0
#define BIT_MASK_BG 0x7
#define BIT_BG(x) (((x) & BIT_MASK_BG) << BIT_SHIFT_BG)
#define BITS_BG (BIT_MASK_BG << BIT_SHIFT_BG)
#define BIT_CLEAR_BG(x) ((x) & (~BITS_BG))
#define BIT_GET_BG(x) (((x) >> BIT_SHIFT_BG) & BIT_MASK_BG)
#define BIT_SET_BG(x, v) (BIT_CLEAR_BG(x) | BIT_BG(v))
#define BIT_TXBCN8ERR BIT(0)
#define BIT_BCNDERR8 BIT(0)
#define BIT_PS_TIMER_EARLY_INT_0 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SYS_CFG5 (Offset 0x1070) */
#define BIT_LPS_STATUS BIT(3)
#define BIT_HCI_TXDMA_BUSY BIT(2)
#define BIT_HCI_TXDMA_ALLOW BIT(1)
#define BIT_FW_CTRL_HCI_TXDMA_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_REGU_32K_1 (Offset 0x1078) */
#define BIT_OUT_SEL BIT(26)
#define BIT_SHIFT_FREQ_SEL 24
#define BIT_MASK_FREQ_SEL 0x3
#define BIT_FREQ_SEL(x) (((x) & BIT_MASK_FREQ_SEL) << BIT_SHIFT_FREQ_SEL)
#define BITS_FREQ_SEL (BIT_MASK_FREQ_SEL << BIT_SHIFT_FREQ_SEL)
#define BIT_CLEAR_FREQ_SEL(x) ((x) & (~BITS_FREQ_SEL))
#define BIT_GET_FREQ_SEL(x) (((x) >> BIT_SHIFT_FREQ_SEL) & BIT_MASK_FREQ_SEL)
#define BIT_SET_FREQ_SEL(x, v) (BIT_CLEAR_FREQ_SEL(x) | BIT_FREQ_SEL(v))
#define BIT_SHIFT_CLKGEN0 16
#define BIT_MASK_CLKGEN0 0xff
#define BIT_CLKGEN0(x) (((x) & BIT_MASK_CLKGEN0) << BIT_SHIFT_CLKGEN0)
#define BITS_CLKGEN0 (BIT_MASK_CLKGEN0 << BIT_SHIFT_CLKGEN0)
#define BIT_CLEAR_CLKGEN0(x) ((x) & (~BITS_CLKGEN0))
#define BIT_GET_CLKGEN0(x) (((x) >> BIT_SHIFT_CLKGEN0) & BIT_MASK_CLKGEN0)
#define BIT_SET_CLKGEN0(x, v) (BIT_CLEAR_CLKGEN0(x) | BIT_CLKGEN0(v))
#define BIT_SHIFT_TEMP_COMP 12
#define BIT_MASK_TEMP_COMP 0xf
#define BIT_TEMP_COMP(x) (((x) & BIT_MASK_TEMP_COMP) << BIT_SHIFT_TEMP_COMP)
#define BITS_TEMP_COMP (BIT_MASK_TEMP_COMP << BIT_SHIFT_TEMP_COMP)
#define BIT_CLEAR_TEMP_COMP(x) ((x) & (~BITS_TEMP_COMP))
#define BIT_GET_TEMP_COMP(x) (((x) >> BIT_SHIFT_TEMP_COMP) & BIT_MASK_TEMP_COMP)
#define BIT_SET_TEMP_COMP(x, v) (BIT_CLEAR_TEMP_COMP(x) | BIT_TEMP_COMP(v))
#define BIT_SHIFT_LDO_V18ADJ 8
#define BIT_MASK_LDO_V18ADJ 0xf
#define BIT_LDO_V18ADJ(x) (((x) & BIT_MASK_LDO_V18ADJ) << BIT_SHIFT_LDO_V18ADJ)
#define BITS_LDO_V18ADJ (BIT_MASK_LDO_V18ADJ << BIT_SHIFT_LDO_V18ADJ)
#define BIT_CLEAR_LDO_V18ADJ(x) ((x) & (~BITS_LDO_V18ADJ))
#define BIT_GET_LDO_V18ADJ(x) \
(((x) >> BIT_SHIFT_LDO_V18ADJ) & BIT_MASK_LDO_V18ADJ)
#define BIT_SET_LDO_V18ADJ(x, v) (BIT_CLEAR_LDO_V18ADJ(x) | BIT_LDO_V18ADJ(v))
#define BIT_SHIFT_COMP_LOAD_CUR 5
#define BIT_MASK_COMP_LOAD_CUR 0x3
#define BIT_COMP_LOAD_CUR(x) \
(((x) & BIT_MASK_COMP_LOAD_CUR) << BIT_SHIFT_COMP_LOAD_CUR)
#define BITS_COMP_LOAD_CUR (BIT_MASK_COMP_LOAD_CUR << BIT_SHIFT_COMP_LOAD_CUR)
#define BIT_CLEAR_COMP_LOAD_CUR(x) ((x) & (~BITS_COMP_LOAD_CUR))
#define BIT_GET_COMP_LOAD_CUR(x) \
(((x) >> BIT_SHIFT_COMP_LOAD_CUR) & BIT_MASK_COMP_LOAD_CUR)
#define BIT_SET_COMP_LOAD_CUR(x, v) \
(BIT_CLEAR_COMP_LOAD_CUR(x) | BIT_COMP_LOAD_CUR(v))
#define BIT_SHIFT_COMP_LATCH_CUR 3
#define BIT_MASK_COMP_LATCH_CUR 0x3
#define BIT_COMP_LATCH_CUR(x) \
(((x) & BIT_MASK_COMP_LATCH_CUR) << BIT_SHIFT_COMP_LATCH_CUR)
#define BITS_COMP_LATCH_CUR \
(BIT_MASK_COMP_LATCH_CUR << BIT_SHIFT_COMP_LATCH_CUR)
#define BIT_CLEAR_COMP_LATCH_CUR(x) ((x) & (~BITS_COMP_LATCH_CUR))
#define BIT_GET_COMP_LATCH_CUR(x) \
(((x) >> BIT_SHIFT_COMP_LATCH_CUR) & BIT_MASK_COMP_LATCH_CUR)
#define BIT_SET_COMP_LATCH_CUR(x, v) \
(BIT_CLEAR_COMP_LATCH_CUR(x) | BIT_COMP_LATCH_CUR(v))
#define BIT_SHIFT_COMP_GM_CUR 1
#define BIT_MASK_COMP_GM_CUR 0x3
#define BIT_COMP_GM_CUR(x) \
(((x) & BIT_MASK_COMP_GM_CUR) << BIT_SHIFT_COMP_GM_CUR)
#define BITS_COMP_GM_CUR (BIT_MASK_COMP_GM_CUR << BIT_SHIFT_COMP_GM_CUR)
#define BIT_CLEAR_COMP_GM_CUR(x) ((x) & (~BITS_COMP_GM_CUR))
#define BIT_GET_COMP_GM_CUR(x) \
(((x) >> BIT_SHIFT_COMP_GM_CUR) & BIT_MASK_COMP_GM_CUR)
#define BIT_SET_COMP_GM_CUR(x, v) \
(BIT_CLEAR_COMP_GM_CUR(x) | BIT_COMP_GM_CUR(v))
/* 2 REG_REGU_32K_2 (Offset 0x107C) */
#define BIT_SEL_RCAL_SOURCE BIT(16)
#define BIT_SHIFT_RCAL 0
#define BIT_MASK_RCAL 0x3f
#define BIT_RCAL(x) (((x) & BIT_MASK_RCAL) << BIT_SHIFT_RCAL)
#define BITS_RCAL (BIT_MASK_RCAL << BIT_SHIFT_RCAL)
#define BIT_CLEAR_RCAL(x) ((x) & (~BITS_RCAL))
#define BIT_GET_RCAL(x) (((x) >> BIT_SHIFT_RCAL) & BIT_MASK_RCAL)
#define BIT_SET_RCAL(x, v) (BIT_CLEAR_RCAL(x) | BIT_RCAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_SCH_PHY_TXOP_SIFS_INT BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_WDT_AUTO_MODE BIT(22)
#define BIT_WDT_PLATFORM_EN BIT(21)
#define BIT_WDT_CPU_EN BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_WDT_OPT_IOWRAPPER BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_ANA_PORT_IDLE BIT(18)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_TEST_EPHY_BY_REG BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_MAC_PORT_IDLE BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_SYM_FEN_WLPLT BIT(16)
#define BIT_TEST_UPHY_BY_REG BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_WL_PLATFORM_RST BIT(16)
#define BIT_WL_SECURITY_CLK BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_DDMA_EN BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_UPHY_SLB_HW_PRD BIT(7)
#define BIT_UPHY_FS_SLB_OK BIT(6)
#define BIT_UPHY_HS_SLB_OK BIT(5)
#define BIT_UPHY_SLB_CMD BIT(4)
#define BIT_UPHY_SLB_FAIL BIT(3)
#define BIT_UPHY_SLB_DONE BIT(2)
#define BIT_UPHY_FORCE_SLB BIT(1)
#define BIT_SHIFT_SYM_CPU_DMEN_CON 0
#define BIT_MASK_SYM_CPU_DMEN_CON 0xff
#define BIT_SYM_CPU_DMEN_CON(x) \
(((x) & BIT_MASK_SYM_CPU_DMEN_CON) << BIT_SHIFT_SYM_CPU_DMEN_CON)
#define BITS_SYM_CPU_DMEN_CON \
(BIT_MASK_SYM_CPU_DMEN_CON << BIT_SHIFT_SYM_CPU_DMEN_CON)
#define BIT_CLEAR_SYM_CPU_DMEN_CON(x) ((x) & (~BITS_SYM_CPU_DMEN_CON))
#define BIT_GET_SYM_CPU_DMEN_CON(x) \
(((x) >> BIT_SHIFT_SYM_CPU_DMEN_CON) & BIT_MASK_SYM_CPU_DMEN_CON)
#define BIT_SET_SYM_CPU_DMEN_CON(x, v) \
(BIT_CLEAR_SYM_CPU_DMEN_CON(x) | BIT_SYM_CPU_DMEN_CON(v))
#define BIT_UPHY_SLB_HS BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CPU_DMEM_CON (Offset 0x1080) */
#define BIT_SHIFT_CPU_DMEM_CON 0
#define BIT_MASK_CPU_DMEM_CON 0xff
#define BIT_CPU_DMEM_CON(x) \
(((x) & BIT_MASK_CPU_DMEM_CON) << BIT_SHIFT_CPU_DMEM_CON)
#define BITS_CPU_DMEM_CON (BIT_MASK_CPU_DMEM_CON << BIT_SHIFT_CPU_DMEM_CON)
#define BIT_CLEAR_CPU_DMEM_CON(x) ((x) & (~BITS_CPU_DMEM_CON))
#define BIT_GET_CPU_DMEM_CON(x) \
(((x) >> BIT_SHIFT_CPU_DMEM_CON) & BIT_MASK_CPU_DMEM_CON)
#define BIT_SET_CPU_DMEM_CON(x, v) \
(BIT_CLEAR_CPU_DMEM_CON(x) | BIT_CPU_DMEM_CON(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BOOT_REASON (Offset 0x1088) */
#define BIT_SHIFT_BOOT_REASON_V1 0
#define BIT_MASK_BOOT_REASON_V1 0x7
#define BIT_BOOT_REASON_V1(x) \
(((x) & BIT_MASK_BOOT_REASON_V1) << BIT_SHIFT_BOOT_REASON_V1)
#define BITS_BOOT_REASON_V1 \
(BIT_MASK_BOOT_REASON_V1 << BIT_SHIFT_BOOT_REASON_V1)
#define BIT_CLEAR_BOOT_REASON_V1(x) ((x) & (~BITS_BOOT_REASON_V1))
#define BIT_GET_BOOT_REASON_V1(x) \
(((x) >> BIT_SHIFT_BOOT_REASON_V1) & BIT_MASK_BOOT_REASON_V1)
#define BIT_SET_BOOT_REASON_V1(x, v) \
(BIT_CLEAR_BOOT_REASON_V1(x) | BIT_BOOT_REASON_V1(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_ATIM_END_INT16_MSK BIT(32)
#define BIT_ATIM_END_INT15_MSK BIT(31)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_DATA_FW_READY BIT(31)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_ATIM_END_INT14_MSK BIT(30)
#define BIT_ATIM_END_INT13_MSK BIT(29)
#define BIT_ATIM_END_INT12_MSK BIT(28)
#define BIT_ATIM_END_INT11_MSK BIT(27)
#define BIT_ATIM_END_INT10_MSK BIT(26)
#define BIT_ATIM_END_INT9_MSK BIT(25)
#define BIT_ATIM_END_INT8_MSK BIT(24)
#define BIT_TX_BCN_ERR_INT15_MSK BIT(23)
#define BIT_TX_BCN_ERR_INT14_MSK BIT(22)
#define BIT_TX_BCN_ERR_INT13_MSK BIT(21)
#define BIT_TX_BCN_ERR_INT12_MSK BIT(20)
#define BIT_TX_BCN_ERR_INT11_MSK BIT(19)
#define BIT_TX_BCN_ERR_INT10_MSK BIT(18)
#define BIT_TX_BCN_ERR_INT9_MSK BIT(17)
#define BIT_TX_BCN_ERR_INT8_MSK BIT(16)
#define BIT_TX_BCN_OK_INT15_MSK BIT(15)
#define BIT_TX_BCN_OK_INT14_MSK BIT(14)
#define BIT_TX_BCN_OK_INT13_MSK BIT(13)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_WDT_SYS_RST BIT(13)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_TX_BCN_OK_INT12_MSK BIT(12)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_WDT_ENABLE BIT(12)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_TX_BCN_OK_INT11_MSK BIT(11)
#define BIT_TX_BCN_OK_INT10_MSK BIT(10)
#define BIT_TX_BCN_OK_INT9_MSK BIT(9)
#define BIT_TX_BCN_OK_INT8_MSK BIT(8)
#define BIT_BCN_DMA_INT15_MSK BIT(7)
#define BIT_BCN_DMA_INT14_MSK BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_SHIFT_BOOT_SEL 6
#define BIT_MASK_BOOT_SEL 0x3
#define BIT_BOOT_SEL(x) (((x) & BIT_MASK_BOOT_SEL) << BIT_SHIFT_BOOT_SEL)
#define BITS_BOOT_SEL (BIT_MASK_BOOT_SEL << BIT_SHIFT_BOOT_SEL)
#define BIT_CLEAR_BOOT_SEL(x) ((x) & (~BITS_BOOT_SEL))
#define BIT_GET_BOOT_SEL(x) (((x) >> BIT_SHIFT_BOOT_SEL) & BIT_MASK_BOOT_SEL)
#define BIT_SET_BOOT_SEL(x, v) (BIT_CLEAR_BOOT_SEL(x) | BIT_BOOT_SEL(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_BCN_DMA_INT13_MSK BIT(5)
#define BIT_BCN_DMA_INT12_MSK BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_CLK_SEL BIT(4)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_BCN_DMA_INT11_MSK BIT(3)
#define BIT_BCN_DMA_INT10_MSK BIT(2)
#define BIT_BCN_DMA_INT9_MSK BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_DATA_PLATFORM_RST BIT(1)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR4 (Offset 0x1090) */
#define BIT_BCN_DMA_INT8_MSK BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL0 (Offset 0x1090) */
#define BIT_DATA_CPU_RST BIT(0)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_TX_BCN_ERR_INT15 BIT(23)
#define BIT_TX_BCN_ERR_INT14 BIT(22)
#define BIT_TX_BCN_ERR_INT13 BIT(21)
#define BIT_TX_BCN_ERR_INT12 BIT(20)
#define BIT_TX_BCN_ERR_INT11 BIT(19)
#define BIT_TX_BCN_ERR_INT10 BIT(18)
#define BIT_TX_BCN_ERR_INT9 BIT(17)
#define BIT_TX_BCN_ERR_INT8 BIT(16)
#define BIT_TX_BCN_OK_INT15 BIT(15)
#define BIT_TX_BCN_OK_INT14 BIT(14)
#define BIT_TX_BCN_OK_INT13 BIT(13)
#define BIT_TX_BCN_OK_INT12 BIT(12)
#define BIT_TX_BCN_OK_INT11 BIT(11)
#define BIT_TX_BCN_OK_INT10 BIT(10)
#define BIT_TX_BCN_OK_INT9 BIT(9)
#define BIT_TX_BCN_OK_INT8 BIT(8)
#define BIT_BCN_DMA_INT15 BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_HOST_INTERFACE_IO_PATH BIT(7)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT14 BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_TXDMA_OFLD BIT(6)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT13 BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_RXDMA_OFLD BIT(5)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT12 BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_HCI_DMA_TX BIT(4)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT11 BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_HCI_DMA_RX BIT(3)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT10 BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_AXI_DMA_TX BIT(2)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT9 BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_AXI_DMA_RX BIT(1)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR4 (Offset 0x1094) */
#define BIT_BCN_DMA_INT8 BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DATA_CPU_CTL1 (Offset 0x1094) */
#define BIT_EN_PKT_ENG BIT(0)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HIMR5 (Offset 0x1098) */
#define BIT_BCN_QDMA_ERR_INT15_MSK BIT(7)
#define BIT_BCN_QDMA_ERR_INT14_MSK BIT(6)
#define BIT_BCN_QDMA_ERR_INT13_MSK BIT(5)
#define BIT_BCN_QDMA_ERR_INT12_MSK BIT(4)
#define BIT_BCN_QDMA_ERR_INT11_MSK BIT(3)
#define BIT_BCN_QDMA_ERR_INT10_MSK BIT(2)
#define BIT_BCN_QDMA_ERR_INT9_MSK BIT(1)
#define BIT_BCN_QDMA_ERR_INT8_MSK BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STOP_HIMR (Offset 0x1098) */
#define BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK 0
#define BIT_MASK_NTH_TXDMA_STOP_INT_MSK 0x1ffff
#define BIT_NTH_TXDMA_STOP_INT_MSK(x) \
(((x) & BIT_MASK_NTH_TXDMA_STOP_INT_MSK) \
<< BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK)
#define BITS_NTH_TXDMA_STOP_INT_MSK \
(BIT_MASK_NTH_TXDMA_STOP_INT_MSK << BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK)
#define BIT_CLEAR_NTH_TXDMA_STOP_INT_MSK(x) \
((x) & (~BITS_NTH_TXDMA_STOP_INT_MSK))
#define BIT_GET_NTH_TXDMA_STOP_INT_MSK(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK) & \
BIT_MASK_NTH_TXDMA_STOP_INT_MSK)
#define BIT_SET_NTH_TXDMA_STOP_INT_MSK(x, v) \
(BIT_CLEAR_NTH_TXDMA_STOP_INT_MSK(x) | BIT_NTH_TXDMA_STOP_INT_MSK(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HISR5 (Offset 0x109C) */
#define BIT_BCN_QDMA_ERR_INT15 BIT(7)
#define BIT_BCN_QDMA_ERR_INT14 BIT(6)
#define BIT_BCN_QDMA_ERR_INT13 BIT(5)
#define BIT_BCN_QDMA_ERR_INT12 BIT(4)
#define BIT_BCN_QDMA_ERR_INT11 BIT(3)
#define BIT_BCN_QDMA_ERR_INT10 BIT(2)
#define BIT_BCN_QDMA_ERR_INT9 BIT(1)
#define BIT_BCN_QDMA_ERR_INT8 BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXDMA_STOP_HISR (Offset 0x109C) */
#define BIT_SHIFT_NTH_TXDMA_STOP_INT 0
#define BIT_MASK_NTH_TXDMA_STOP_INT 0x1ffff
#define BIT_NTH_TXDMA_STOP_INT(x) \
(((x) & BIT_MASK_NTH_TXDMA_STOP_INT) << BIT_SHIFT_NTH_TXDMA_STOP_INT)
#define BITS_NTH_TXDMA_STOP_INT \
(BIT_MASK_NTH_TXDMA_STOP_INT << BIT_SHIFT_NTH_TXDMA_STOP_INT)
#define BIT_CLEAR_NTH_TXDMA_STOP_INT(x) ((x) & (~BITS_NTH_TXDMA_STOP_INT))
#define BIT_GET_NTH_TXDMA_STOP_INT(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_STOP_INT) & BIT_MASK_NTH_TXDMA_STOP_INT)
#define BIT_SET_NTH_TXDMA_STOP_INT(x, v) \
(BIT_CLEAR_NTH_TXDMA_STOP_INT(x) | BIT_NTH_TXDMA_STOP_INT(v))
/* 2 REG_TXDMA_START_HIMR (Offset 0x10A0) */
#define BIT_SHIFT_NTH_TXDMA_START_INT_MSK 0
#define BIT_MASK_NTH_TXDMA_START_INT_MSK 0x1ffff
#define BIT_NTH_TXDMA_START_INT_MSK(x) \
(((x) & BIT_MASK_NTH_TXDMA_START_INT_MSK) \
<< BIT_SHIFT_NTH_TXDMA_START_INT_MSK)
#define BITS_NTH_TXDMA_START_INT_MSK \
(BIT_MASK_NTH_TXDMA_START_INT_MSK << BIT_SHIFT_NTH_TXDMA_START_INT_MSK)
#define BIT_CLEAR_NTH_TXDMA_START_INT_MSK(x) \
((x) & (~BITS_NTH_TXDMA_START_INT_MSK))
#define BIT_GET_NTH_TXDMA_START_INT_MSK(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_START_INT_MSK) & \
BIT_MASK_NTH_TXDMA_START_INT_MSK)
#define BIT_SET_NTH_TXDMA_START_INT_MSK(x, v) \
(BIT_CLEAR_NTH_TXDMA_START_INT_MSK(x) | BIT_NTH_TXDMA_START_INT_MSK(v))
/* 2 REG_TXDMA_START_HISR (Offset 0x10A4) */
#define BIT_SHIFT_NTH_TXDMA_START_INT 0
#define BIT_MASK_NTH_TXDMA_START_INT 0x1ffff
#define BIT_NTH_TXDMA_START_INT(x) \
(((x) & BIT_MASK_NTH_TXDMA_START_INT) << BIT_SHIFT_NTH_TXDMA_START_INT)
#define BITS_NTH_TXDMA_START_INT \
(BIT_MASK_NTH_TXDMA_START_INT << BIT_SHIFT_NTH_TXDMA_START_INT)
#define BIT_CLEAR_NTH_TXDMA_START_INT(x) ((x) & (~BITS_NTH_TXDMA_START_INT))
#define BIT_GET_NTH_TXDMA_START_INT(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_START_INT) & BIT_MASK_NTH_TXDMA_START_INT)
#define BIT_SET_NTH_TXDMA_START_INT(x, v) \
(BIT_CLEAR_NTH_TXDMA_START_INT(x) | BIT_NTH_TXDMA_START_INT(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_PAD_SEL BIT(19)
#define BIT_SYM_NFC_PAD_SHDN BIT(18)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_PAD_SHUTDW BIT(18)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_PAD_E2 BIT(17)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_SYSON_NFC_PAD BIT(17)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_INTPL BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_NFC_INT_PAD_CTRL BIT(16)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_RFDIS_PULL BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_NFC_RFDIS_PAD_CTRL BIT(15)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_CLK_PULL BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_NFC_CLK_PAD_CTRL BIT(14)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_DATA_PULL BIT(13)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_NFC_DATA_PAD_CTRL BIT(13)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_PAD_PULL_EN BIT(12)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_NFC_PAD_PULL_CTRL BIT(12)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_INT_E BIT(11)
#define BIT_SYM_NFC_RFDIS_E BIT(10)
#define BIT_SYM_NFC_CLK_E BIT(9)
#define BIT_SYM_NFC_DATA_E BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_SHIFT_NFCPAD_IO_SEL 8
#define BIT_MASK_NFCPAD_IO_SEL 0xf
#define BIT_NFCPAD_IO_SEL(x) \
(((x) & BIT_MASK_NFCPAD_IO_SEL) << BIT_SHIFT_NFCPAD_IO_SEL)
#define BITS_NFCPAD_IO_SEL (BIT_MASK_NFCPAD_IO_SEL << BIT_SHIFT_NFCPAD_IO_SEL)
#define BIT_CLEAR_NFCPAD_IO_SEL(x) ((x) & (~BITS_NFCPAD_IO_SEL))
#define BIT_GET_NFCPAD_IO_SEL(x) \
(((x) >> BIT_SHIFT_NFCPAD_IO_SEL) & BIT_MASK_NFCPAD_IO_SEL)
#define BIT_SET_NFCPAD_IO_SEL(x, v) \
(BIT_CLEAR_NFCPAD_IO_SEL(x) | BIT_NFCPAD_IO_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_INT BIT(7)
#define BIT_SYM_NFC_RFDIS BIT(6)
#define BIT_SYM_NFC_CLK BIT(5)
#define BIT_SYM_NFC_DATA BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_SHIFT_NFCPAD_OUT 4
#define BIT_MASK_NFCPAD_OUT 0xf
#define BIT_NFCPAD_OUT(x) (((x) & BIT_MASK_NFCPAD_OUT) << BIT_SHIFT_NFCPAD_OUT)
#define BITS_NFCPAD_OUT (BIT_MASK_NFCPAD_OUT << BIT_SHIFT_NFCPAD_OUT)
#define BIT_CLEAR_NFCPAD_OUT(x) ((x) & (~BITS_NFCPAD_OUT))
#define BIT_GET_NFCPAD_OUT(x) \
(((x) >> BIT_SHIFT_NFCPAD_OUT) & BIT_MASK_NFCPAD_OUT)
#define BIT_SET_NFCPAD_OUT(x, v) (BIT_CLEAR_NFCPAD_OUT(x) | BIT_NFCPAD_OUT(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_NFC_PAD_CTRL (Offset 0x10A8) */
#define BIT_SYM_NFC_INT_I BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_NFCPAD_CTRL (Offset 0x10A8) */
#define BIT_SHIFT_NFCPAD_IN 0
#define BIT_MASK_NFCPAD_IN 0xf
#define BIT_NFCPAD_IN(x) (((x) & BIT_MASK_NFCPAD_IN) << BIT_SHIFT_NFCPAD_IN)
#define BITS_NFCPAD_IN (BIT_MASK_NFCPAD_IN << BIT_SHIFT_NFCPAD_IN)
#define BIT_CLEAR_NFCPAD_IN(x) ((x) & (~BITS_NFCPAD_IN))
#define BIT_GET_NFCPAD_IN(x) (((x) >> BIT_SHIFT_NFCPAD_IN) & BIT_MASK_NFCPAD_IN)
#define BIT_SET_NFCPAD_IN(x, v) (BIT_CLEAR_NFCPAD_IN(x) | BIT_NFCPAD_IN(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR2 (Offset 0x10B0) */
#define BIT_BCNDMAINT_P4_MSK BIT(31)
#define BIT_BCNDMAINT_P4 BIT(31)
#define BIT_BCNDMAINT_P3_MSK BIT(30)
#define BIT_BCNDMAINT_P3 BIT(30)
#define BIT_BCNDMAINT_P2_MSK BIT(29)
#define BIT_BCNDMAINT_P2 BIT(29)
#define BIT_BCNDMAINT_P1_MSK BIT(28)
#define BIT_BCNDMAINT_P1 BIT(28)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR2 (Offset 0x10B0) */
#define BIT_SCH_PHY_TXOP_SIFS_INT_MSK BIT(23)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR2 (Offset 0x10B0) */
#define BIT_ATIMEND7_MSK BIT(22)
#define BIT_ATIMEND7 BIT(22)
#define BIT_ATIMEND6_MSK BIT(21)
#define BIT_ATIMEND6 BIT(21)
#define BIT_ATIMEND5_MSK BIT(20)
#define BIT_ATIMEND5 BIT(20)
#define BIT_ATIMEND4_MSK BIT(19)
#define BIT_ATIMEND4 BIT(19)
#define BIT_ATIMEND3_MSK BIT(18)
#define BIT_ATIMEND3 BIT(18)
#define BIT_ATIMEND2_MSK BIT(17)
#define BIT_ATIMEND2 BIT(17)
#define BIT_ATIMEND1_MSK BIT(16)
#define BIT_ATIMEND1 BIT(16)
#define BIT_TXBCN7OK_MSK BIT(14)
#define BIT_TXBCN7OK BIT(14)
#define BIT_TXBCN6OK_MSK BIT(13)
#define BIT_TXBCN6OK BIT(13)
#define BIT_TXBCN5OK_MSK BIT(12)
#define BIT_TXBCN5OK BIT(12)
#define BIT_TXBCN4OK_MSK BIT(11)
#define BIT_TXBCN4OK BIT(11)
#define BIT_TXBCN3OK_MSK BIT(10)
#define BIT_TXBCN3OK BIT(10)
#define BIT_TXBCN2OK_MSK BIT(9)
#define BIT_TXBCN2OK BIT(9)
#define BIT_TXBCN1OK_MSK_V1 BIT(8)
#define BIT_TXBCN1OK BIT(8)
#define BIT_TXBCN7ERR_MSK BIT(6)
#define BIT_TXBCN7ERR BIT(6)
#define BIT_TXBCN6ERR_MSK BIT(5)
#define BIT_TXBCN6ERR BIT(5)
#define BIT_TXBCN5ERR_MSK BIT(4)
#define BIT_TXBCN5ERR BIT(4)
#define BIT_TXBCN4ERR_MSK BIT(3)
#define BIT_TXBCN4ERR BIT(3)
#define BIT_TXBCN3ERR_MSK BIT(2)
#define BIT_TXBCN3ERR BIT(2)
#define BIT_TXBCN2ERR_MSK BIT(1)
#define BIT_TXBCN2ERR BIT(1)
#define BIT_TXBCN1ERR_MSK_V1 BIT(0)
#define BIT_TXBCN1ERR BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT12 BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT12_MSK BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT11 BIT(23)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT11_MSK BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT10 BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT10_MSK BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT9 BIT(21)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_GTINT9_MSK BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_RX_DESC_BUF_FULL BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_RX_DESC_BUF_FULL_MSK BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_CPHY_LDO_OCP_DET_INT BIT(19)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_CPHY_LDO_OCP_DET_INT_MSK BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_WDT_PLATFORM_INT_MSK BIT(18)
#define BIT_WDT_PLATFORM_INT BIT(18)
#define BIT_WDT_CPU_INT_MSK BIT(17)
#define BIT_WDT_CPU_INT BIT(17)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_SETH2CDOK_MASK BIT(16)
#define BIT_SETH2CDOK BIT(16)
#define BIT_H2C_CMD_FULL_MASK BIT(15)
#define BIT_H2C_CMD_FULL BIT(15)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PWR_INT_127_MASK BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PKT_TRANS_ERR BIT(14)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PKT_TRANS_ERR_MASK BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_TXSHORTCUT_TXDESUPDATEOK_MASK BIT(13)
#define BIT_TXSHORTCUT_TXDESUPDATEOK BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_MASK BIT(12)
#define BIT_TXSHORTCUT_BKUPDATEOK BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_MASK BIT(11)
#define BIT_TXSHORTCUT_BEUPDATEOK BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_MAS BIT(10)
#define BIT_TXSHORTCUT_VIUPDATEOK BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_MASK BIT(9)
#define BIT_TXSHORTCUT_VOUPDATEOK BIT(9)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PWR_INT_127_MASK_V1 BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_SEARCH_FAIL BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_SEARCH_FAIL_MSK BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PWR_INT_126TO96_MASK BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PWR_INT_127TO96 BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PWR_INT_127TO96_MASK BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_PWR_INT_95TO64_MASK BIT(6)
#define BIT_PWR_INT_95TO64 BIT(6)
#define BIT_PWR_INT_63TO32_MASK BIT(5)
#define BIT_PWR_INT_63TO32 BIT(5)
#define BIT_PWR_INT_31TO0_MASK BIT(4)
#define BIT_PWR_INT_31TO0 BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_RX_DMA_STUCK_MSK BIT(3)
#define BIT_RX_DMA_STUCK BIT(3)
#define BIT_TX_DMA_STUCK_MSK BIT(2)
#define BIT_TX_DMA_STUCK BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HIMR3 (Offset 0x10B8) */
#define BIT_DDMA0_LP_INT_MSK BIT(1)
#define BIT_DDMA0_LP_INT BIT(1)
#define BIT_DDMA0_HP_INT_MSK BIT(0)
#define BIT_DDMA0_HP_INT BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_HISR3 (Offset 0x10BC) */
#define BIT_PWR_INT_127 BIT(14)
#define BIT_PWR_INT_127_V1 BIT(8)
#define BIT_PWR_INT_126TO96 BIT(7)
#define BIT_ECRC_EN_V1 BIT(7)
#define BIT_MDIO_RFLAG_V1 BIT(6)
#define BIT_MDIO_WFLAG_V1 BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_WLDSS_RST_N_0 BIT(27)
#define BIT_WLDSS_RST_N_1 BIT(27)
#define BIT_WLDSS_RST_N_2 BIT(27)
#define BIT_WLDSS_ENCLK_0 BIT(26)
#define BIT_WLDSS_ENCLK_1 BIT(26)
#define BIT_WLDSS_ENCLK_2 BIT(26)
#define BIT_WLDSS_SPEED_EN_0 BIT(25)
#define BIT_WLDSS_SPEED_EN_1 BIT(25)
#define BIT_WLDSS_SPEED_EN_2 BIT(25)
#define BIT_WLDSS_WIRE_SEL_0 BIT(24)
#define BIT_WLDSS_WIRE_SEL_1 BIT(24)
#define BIT_WLDSS_WIRE_SEL_2 BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_DIS_TIMEOUT_IO BIT(24)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_WLDSS_READY_0 BIT(21)
#define BIT_WLDSS_READY_1 BIT(21)
#define BIT_WLDSS_READY_2 BIT(21)
#define BIT_SHIFT_WLDSS_RO_SEL_0 20
#define BIT_MASK_WLDSS_RO_SEL_0 0x7
#define BIT_WLDSS_RO_SEL_0(x) \
(((x) & BIT_MASK_WLDSS_RO_SEL_0) << BIT_SHIFT_WLDSS_RO_SEL_0)
#define BITS_WLDSS_RO_SEL_0 \
(BIT_MASK_WLDSS_RO_SEL_0 << BIT_SHIFT_WLDSS_RO_SEL_0)
#define BIT_CLEAR_WLDSS_RO_SEL_0(x) ((x) & (~BITS_WLDSS_RO_SEL_0))
#define BIT_GET_WLDSS_RO_SEL_0(x) \
(((x) >> BIT_SHIFT_WLDSS_RO_SEL_0) & BIT_MASK_WLDSS_RO_SEL_0)
#define BIT_SET_WLDSS_RO_SEL_0(x, v) \
(BIT_CLEAR_WLDSS_RO_SEL_0(x) | BIT_WLDSS_RO_SEL_0(v))
#define BIT_WLDSS_WSORT_GO_0 BIT(20)
#define BIT_SHIFT_WLDSS_RO_SEL_1 20
#define BIT_MASK_WLDSS_RO_SEL_1 0x7
#define BIT_WLDSS_RO_SEL_1(x) \
(((x) & BIT_MASK_WLDSS_RO_SEL_1) << BIT_SHIFT_WLDSS_RO_SEL_1)
#define BITS_WLDSS_RO_SEL_1 \
(BIT_MASK_WLDSS_RO_SEL_1 << BIT_SHIFT_WLDSS_RO_SEL_1)
#define BIT_CLEAR_WLDSS_RO_SEL_1(x) ((x) & (~BITS_WLDSS_RO_SEL_1))
#define BIT_GET_WLDSS_RO_SEL_1(x) \
(((x) >> BIT_SHIFT_WLDSS_RO_SEL_1) & BIT_MASK_WLDSS_RO_SEL_1)
#define BIT_SET_WLDSS_RO_SEL_1(x, v) \
(BIT_CLEAR_WLDSS_RO_SEL_1(x) | BIT_WLDSS_RO_SEL_1(v))
#define BIT_WLDSS_WSORT_GO_1 BIT(20)
#define BIT_SHIFT_WLDSS_RO_SEL_2 20
#define BIT_MASK_WLDSS_RO_SEL_2 0x7
#define BIT_WLDSS_RO_SEL_2(x) \
(((x) & BIT_MASK_WLDSS_RO_SEL_2) << BIT_SHIFT_WLDSS_RO_SEL_2)
#define BITS_WLDSS_RO_SEL_2 \
(BIT_MASK_WLDSS_RO_SEL_2 << BIT_SHIFT_WLDSS_RO_SEL_2)
#define BIT_CLEAR_WLDSS_RO_SEL_2(x) ((x) & (~BITS_WLDSS_RO_SEL_2))
#define BIT_GET_WLDSS_RO_SEL_2(x) \
(((x) >> BIT_SHIFT_WLDSS_RO_SEL_2) & BIT_MASK_WLDSS_RO_SEL_2)
#define BIT_SET_WLDSS_RO_SEL_2(x, v) \
(BIT_CLEAR_WLDSS_RO_SEL_2(x) | BIT_WLDSS_RO_SEL_2(v))
#define BIT_WLDSS_WSORT_GO_2 BIT(20)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SUS_PL BIT(18)
#define BIT_SOP_ESUS BIT(17)
#define BIT_SOP_DLDO BIT(16)
#define BIT_R_OCP_ST_CLR BIT(8)
#define BIT_SW_USB3_MD_SEL BIT(5)
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SYM_SW_PCIE_MDSL_V1 BIT(4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SW_PCIE_MD_SEL BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SYM_SW_PCIE_MDSL BIT(3)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SYM_SW_PCIE_MDCK BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SW_MDCK BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SYM_SW_PCIE_MDI BIT(1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SW_MDI BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SYM_SW_PCIE_MDO BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_SHIFT_WLDSS_DATA_IN_0 0
#define BIT_MASK_WLDSS_DATA_IN_0 0xfffff
#define BIT_WLDSS_DATA_IN_0(x) \
(((x) & BIT_MASK_WLDSS_DATA_IN_0) << BIT_SHIFT_WLDSS_DATA_IN_0)
#define BITS_WLDSS_DATA_IN_0 \
(BIT_MASK_WLDSS_DATA_IN_0 << BIT_SHIFT_WLDSS_DATA_IN_0)
#define BIT_CLEAR_WLDSS_DATA_IN_0(x) ((x) & (~BITS_WLDSS_DATA_IN_0))
#define BIT_GET_WLDSS_DATA_IN_0(x) \
(((x) >> BIT_SHIFT_WLDSS_DATA_IN_0) & BIT_MASK_WLDSS_DATA_IN_0)
#define BIT_SET_WLDSS_DATA_IN_0(x, v) \
(BIT_CLEAR_WLDSS_DATA_IN_0(x) | BIT_WLDSS_DATA_IN_0(v))
#define BIT_SHIFT_WLDSS_COUNT_OUT_0 0
#define BIT_MASK_WLDSS_COUNT_OUT_0 0xfffff
#define BIT_WLDSS_COUNT_OUT_0(x) \
(((x) & BIT_MASK_WLDSS_COUNT_OUT_0) << BIT_SHIFT_WLDSS_COUNT_OUT_0)
#define BITS_WLDSS_COUNT_OUT_0 \
(BIT_MASK_WLDSS_COUNT_OUT_0 << BIT_SHIFT_WLDSS_COUNT_OUT_0)
#define BIT_CLEAR_WLDSS_COUNT_OUT_0(x) ((x) & (~BITS_WLDSS_COUNT_OUT_0))
#define BIT_GET_WLDSS_COUNT_OUT_0(x) \
(((x) >> BIT_SHIFT_WLDSS_COUNT_OUT_0) & BIT_MASK_WLDSS_COUNT_OUT_0)
#define BIT_SET_WLDSS_COUNT_OUT_0(x, v) \
(BIT_CLEAR_WLDSS_COUNT_OUT_0(x) | BIT_WLDSS_COUNT_OUT_0(v))
#define BIT_SHIFT_WLDSS_DATA_IN_1 0
#define BIT_MASK_WLDSS_DATA_IN_1 0xfffff
#define BIT_WLDSS_DATA_IN_1(x) \
(((x) & BIT_MASK_WLDSS_DATA_IN_1) << BIT_SHIFT_WLDSS_DATA_IN_1)
#define BITS_WLDSS_DATA_IN_1 \
(BIT_MASK_WLDSS_DATA_IN_1 << BIT_SHIFT_WLDSS_DATA_IN_1)
#define BIT_CLEAR_WLDSS_DATA_IN_1(x) ((x) & (~BITS_WLDSS_DATA_IN_1))
#define BIT_GET_WLDSS_DATA_IN_1(x) \
(((x) >> BIT_SHIFT_WLDSS_DATA_IN_1) & BIT_MASK_WLDSS_DATA_IN_1)
#define BIT_SET_WLDSS_DATA_IN_1(x, v) \
(BIT_CLEAR_WLDSS_DATA_IN_1(x) | BIT_WLDSS_DATA_IN_1(v))
#define BIT_SHIFT_WLDSS_COUNT_OUT_1 0
#define BIT_MASK_WLDSS_COUNT_OUT_1 0xfffff
#define BIT_WLDSS_COUNT_OUT_1(x) \
(((x) & BIT_MASK_WLDSS_COUNT_OUT_1) << BIT_SHIFT_WLDSS_COUNT_OUT_1)
#define BITS_WLDSS_COUNT_OUT_1 \
(BIT_MASK_WLDSS_COUNT_OUT_1 << BIT_SHIFT_WLDSS_COUNT_OUT_1)
#define BIT_CLEAR_WLDSS_COUNT_OUT_1(x) ((x) & (~BITS_WLDSS_COUNT_OUT_1))
#define BIT_GET_WLDSS_COUNT_OUT_1(x) \
(((x) >> BIT_SHIFT_WLDSS_COUNT_OUT_1) & BIT_MASK_WLDSS_COUNT_OUT_1)
#define BIT_SET_WLDSS_COUNT_OUT_1(x, v) \
(BIT_CLEAR_WLDSS_COUNT_OUT_1(x) | BIT_WLDSS_COUNT_OUT_1(v))
#define BIT_SHIFT_WLDSS_DATA_IN_2 0
#define BIT_MASK_WLDSS_DATA_IN_2 0xfffff
#define BIT_WLDSS_DATA_IN_2(x) \
(((x) & BIT_MASK_WLDSS_DATA_IN_2) << BIT_SHIFT_WLDSS_DATA_IN_2)
#define BITS_WLDSS_DATA_IN_2 \
(BIT_MASK_WLDSS_DATA_IN_2 << BIT_SHIFT_WLDSS_DATA_IN_2)
#define BIT_CLEAR_WLDSS_DATA_IN_2(x) ((x) & (~BITS_WLDSS_DATA_IN_2))
#define BIT_GET_WLDSS_DATA_IN_2(x) \
(((x) >> BIT_SHIFT_WLDSS_DATA_IN_2) & BIT_MASK_WLDSS_DATA_IN_2)
#define BIT_SET_WLDSS_DATA_IN_2(x, v) \
(BIT_CLEAR_WLDSS_DATA_IN_2(x) | BIT_WLDSS_DATA_IN_2(v))
#define BIT_SHIFT_WLDSS_COUNT_OUT_2 0
#define BIT_MASK_WLDSS_COUNT_OUT_2 0xfffff
#define BIT_WLDSS_COUNT_OUT_2(x) \
(((x) & BIT_MASK_WLDSS_COUNT_OUT_2) << BIT_SHIFT_WLDSS_COUNT_OUT_2)
#define BITS_WLDSS_COUNT_OUT_2 \
(BIT_MASK_WLDSS_COUNT_OUT_2 << BIT_SHIFT_WLDSS_COUNT_OUT_2)
#define BIT_CLEAR_WLDSS_COUNT_OUT_2(x) ((x) & (~BITS_WLDSS_COUNT_OUT_2))
#define BIT_GET_WLDSS_COUNT_OUT_2(x) \
(((x) >> BIT_SHIFT_WLDSS_COUNT_OUT_2) & BIT_MASK_WLDSS_COUNT_OUT_2)
#define BIT_SET_WLDSS_COUNT_OUT_2(x, v) \
(BIT_CLEAR_WLDSS_COUNT_OUT_2(x) | BIT_WLDSS_COUNT_OUT_2(v))
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_SW_MDIO (Offset 0x10C0) */
#define BIT_MDO BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_SW_FLUSH (Offset 0x10C4) */
#define BIT_FLUSH_HOLDN_EN BIT(25)
#define BIT_FLUSH_WR_EN BIT(24)
#define BIT_SW_FLASH_CONTROL BIT(23)
#define BIT_SW_FLASH_WEN_E BIT(19)
#define BIT_SW_FLASH_HOLDN_E BIT(18)
#define BIT_SW_FLASH_SO_E BIT(17)
#define BIT_SW_FLASH_SI_E BIT(16)
#define BIT_SW_FLASH_SK_O BIT(13)
#define BIT_SW_FLASH_CEN_O BIT(12)
#define BIT_SW_FLASH_WEN_O BIT(11)
#define BIT_SW_FLASH_HOLDN_O BIT(10)
#define BIT_SW_FLASH_SO_O BIT(9)
#define BIT_SW_FLASH_SI_O BIT(8)
#define BIT_SW_FLASH_WEN_I BIT(3)
#define BIT_SW_FLASH_HOLDN_I BIT(2)
#define BIT_SW_FLASH_SO_I BIT(1)
#define BIT_SW_FLASH_SI_I BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR_7 (Offset 0x10C8) */
#define BIT_DATA_CPU_WDT_INT_MSK BIT(31)
#define BIT_OFLD_TXDMA_ERR_MSK BIT(30)
#define BIT_OFLD_TXDMA_FULL_MSK BIT(29)
#define BIT_OFLD_RXDMA_OVR_MSK BIT(28)
#define BIT_OFLD_RXDMA_ERR_MSK BIT(27)
#define BIT_OFLD_RXDMA_DES_UA_MSK BIT(26)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_WL_DSS_CLKEN_BACKDOOR 24
#define BIT_MASK_WL_DSS_CLKEN_BACKDOOR 0x3
#define BIT_WL_DSS_CLKEN_BACKDOOR(x) \
(((x) & BIT_MASK_WL_DSS_CLKEN_BACKDOOR) \
<< BIT_SHIFT_WL_DSS_CLKEN_BACKDOOR)
#define BITS_WL_DSS_CLKEN_BACKDOOR \
(BIT_MASK_WL_DSS_CLKEN_BACKDOOR << BIT_SHIFT_WL_DSS_CLKEN_BACKDOOR)
#define BIT_CLEAR_WL_DSS_CLKEN_BACKDOOR(x) ((x) & (~BITS_WL_DSS_CLKEN_BACKDOOR))
#define BIT_GET_WL_DSS_CLKEN_BACKDOOR(x) \
(((x) >> BIT_SHIFT_WL_DSS_CLKEN_BACKDOOR) & \
BIT_MASK_WL_DSS_CLKEN_BACKDOOR)
#define BIT_SET_WL_DSS_CLKEN_BACKDOOR(x, v) \
(BIT_CLEAR_WL_DSS_CLKEN_BACKDOOR(x) | BIT_WL_DSS_CLKEN_BACKDOOR(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_DBG_GPIO_BMUX_7 21
#define BIT_MASK_DBG_GPIO_BMUX_7 0x7
#define BIT_DBG_GPIO_BMUX_7(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_7) << BIT_SHIFT_DBG_GPIO_BMUX_7)
#define BITS_DBG_GPIO_BMUX_7 \
(BIT_MASK_DBG_GPIO_BMUX_7 << BIT_SHIFT_DBG_GPIO_BMUX_7)
#define BIT_CLEAR_DBG_GPIO_BMUX_7(x) ((x) & (~BITS_DBG_GPIO_BMUX_7))
#define BIT_GET_DBG_GPIO_BMUX_7(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_7) & BIT_MASK_DBG_GPIO_BMUX_7)
#define BIT_SET_DBG_GPIO_BMUX_7(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_7(x) | BIT_DBG_GPIO_BMUX_7(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_6 18
#define BIT_MASK_DBG_GPIO_BMUX_6 0x7
#define BIT_DBG_GPIO_BMUX_6(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_6) << BIT_SHIFT_DBG_GPIO_BMUX_6)
#define BITS_DBG_GPIO_BMUX_6 \
(BIT_MASK_DBG_GPIO_BMUX_6 << BIT_SHIFT_DBG_GPIO_BMUX_6)
#define BIT_CLEAR_DBG_GPIO_BMUX_6(x) ((x) & (~BITS_DBG_GPIO_BMUX_6))
#define BIT_GET_DBG_GPIO_BMUX_6(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_6) & BIT_MASK_DBG_GPIO_BMUX_6)
#define BIT_SET_DBG_GPIO_BMUX_6(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_6(x) | BIT_DBG_GPIO_BMUX_6(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR_7 (Offset 0x10C8) */
#define BIT_TXDMAOK_CHANNEL_16_MSK BIT(16)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_DBG_GPIO_BMUX_5 15
#define BIT_MASK_DBG_GPIO_BMUX_5 0x7
#define BIT_DBG_GPIO_BMUX_5(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_5) << BIT_SHIFT_DBG_GPIO_BMUX_5)
#define BITS_DBG_GPIO_BMUX_5 \
(BIT_MASK_DBG_GPIO_BMUX_5 << BIT_SHIFT_DBG_GPIO_BMUX_5)
#define BIT_CLEAR_DBG_GPIO_BMUX_5(x) ((x) & (~BITS_DBG_GPIO_BMUX_5))
#define BIT_GET_DBG_GPIO_BMUX_5(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_5) & BIT_MASK_DBG_GPIO_BMUX_5)
#define BIT_SET_DBG_GPIO_BMUX_5(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_5(x) | BIT_DBG_GPIO_BMUX_5(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR_7 (Offset 0x10C8) */
#define BIT_TXDMAOK_CHANNEL_13_MSK BIT(13)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_DBG_GPIO_BMUX_4 12
#define BIT_MASK_DBG_GPIO_BMUX_4 0x7
#define BIT_DBG_GPIO_BMUX_4(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_4) << BIT_SHIFT_DBG_GPIO_BMUX_4)
#define BITS_DBG_GPIO_BMUX_4 \
(BIT_MASK_DBG_GPIO_BMUX_4 << BIT_SHIFT_DBG_GPIO_BMUX_4)
#define BIT_CLEAR_DBG_GPIO_BMUX_4(x) ((x) & (~BITS_DBG_GPIO_BMUX_4))
#define BIT_GET_DBG_GPIO_BMUX_4(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_4) & BIT_MASK_DBG_GPIO_BMUX_4)
#define BIT_SET_DBG_GPIO_BMUX_4(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_4(x) | BIT_DBG_GPIO_BMUX_4(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR_7 (Offset 0x10C8) */
#define BIT_TXDMAOK_CHANNEL_12_MSK BIT(12)
#define BIT_TXDMAOK_CHANNEL_11_MSK BIT(11)
#define BIT_TXDMAOK_CHANNEL_10_MSK BIT(10)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_DBG_GPIO_BMUX_3 9
#define BIT_MASK_DBG_GPIO_BMUX_3 0x7
#define BIT_DBG_GPIO_BMUX_3(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_3) << BIT_SHIFT_DBG_GPIO_BMUX_3)
#define BITS_DBG_GPIO_BMUX_3 \
(BIT_MASK_DBG_GPIO_BMUX_3 << BIT_SHIFT_DBG_GPIO_BMUX_3)
#define BIT_CLEAR_DBG_GPIO_BMUX_3(x) ((x) & (~BITS_DBG_GPIO_BMUX_3))
#define BIT_GET_DBG_GPIO_BMUX_3(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_3) & BIT_MASK_DBG_GPIO_BMUX_3)
#define BIT_SET_DBG_GPIO_BMUX_3(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_3(x) | BIT_DBG_GPIO_BMUX_3(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR_7 (Offset 0x10C8) */
#define BIT_TXDMAOK_CHANNEL_9_MSK BIT(9)
#define BIT_TXDMAOK_CHANNEL_8_MSK BIT(8)
#define BIT_TXDMAOK_CHANNEL_7_MSK BIT(7)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_DBG_GPIO_BMUX_2 6
#define BIT_MASK_DBG_GPIO_BMUX_2 0x7
#define BIT_DBG_GPIO_BMUX_2(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_2) << BIT_SHIFT_DBG_GPIO_BMUX_2)
#define BITS_DBG_GPIO_BMUX_2 \
(BIT_MASK_DBG_GPIO_BMUX_2 << BIT_SHIFT_DBG_GPIO_BMUX_2)
#define BIT_CLEAR_DBG_GPIO_BMUX_2(x) ((x) & (~BITS_DBG_GPIO_BMUX_2))
#define BIT_GET_DBG_GPIO_BMUX_2(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_2) & BIT_MASK_DBG_GPIO_BMUX_2)
#define BIT_SET_DBG_GPIO_BMUX_2(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_2(x) | BIT_DBG_GPIO_BMUX_2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIMR_7 (Offset 0x10C8) */
#define BIT_TXDMAOK_CHANNEL_6_MSK BIT(6)
#define BIT_TXDMAOK_CHANNEL_5_MSK BIT(5)
#define BIT_TXDMAOK_CHANNEL_4_MSK BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
/* 2 REG_DBG_GPIO_BMUX (Offset 0x10C8) */
#define BIT_SHIFT_DBG_GPIO_BMUX_1 3
#define BIT_MASK_DBG_GPIO_BMUX_1 0x7
#define BIT_DBG_GPIO_BMUX_1(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_1) << BIT_SHIFT_DBG_GPIO_BMUX_1)
#define BITS_DBG_GPIO_BMUX_1 \
(BIT_MASK_DBG_GPIO_BMUX_1 << BIT_SHIFT_DBG_GPIO_BMUX_1)
#define BIT_CLEAR_DBG_GPIO_BMUX_1(x) ((x) & (~BITS_DBG_GPIO_BMUX_1))
#define BIT_GET_DBG_GPIO_BMUX_1(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_1) & BIT_MASK_DBG_GPIO_BMUX_1)
#define BIT_SET_DBG_GPIO_BMUX_1(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_1(x) | BIT_DBG_GPIO_BMUX_1(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_0 0
#define BIT_MASK_DBG_GPIO_BMUX_0 0x7
#define BIT_DBG_GPIO_BMUX_0(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_0) << BIT_SHIFT_DBG_GPIO_BMUX_0)
#define BITS_DBG_GPIO_BMUX_0 \
(BIT_MASK_DBG_GPIO_BMUX_0 << BIT_SHIFT_DBG_GPIO_BMUX_0)
#define BIT_CLEAR_DBG_GPIO_BMUX_0(x) ((x) & (~BITS_DBG_GPIO_BMUX_0))
#define BIT_GET_DBG_GPIO_BMUX_0(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_0) & BIT_MASK_DBG_GPIO_BMUX_0)
#define BIT_SET_DBG_GPIO_BMUX_0(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_0(x) | BIT_DBG_GPIO_BMUX_0(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HISR_7 (Offset 0x10CC) */
#define BIT_DATA_CPU_WDT_INT BIT(31)
#define BIT_OFLD_TXDMA_ERR BIT(30)
#define BIT_OFLD_TXDMA_FULL BIT(29)
#define BIT_OFLD_RXDMA_OVR BIT(28)
#define BIT_OFLD_RXDMA_ERR BIT(27)
#define BIT_OFLD_RXDMA_DES_UA BIT(26)
#define BIT_TXDMAOK_CHANNEL_16 BIT(16)
#define BIT_TXDMAOK_CHANNEL_13 BIT(13)
#define BIT_TXDMAOK_CHANNEL_12 BIT(12)
#define BIT_TXDMAOK_CHANNEL_11 BIT(11)
#define BIT_TXDMAOK_CHANNEL_10 BIT(10)
#define BIT_TXDMAOK_CHANNEL_9 BIT(9)
#define BIT_TXDMAOK_CHANNEL_8 BIT(8)
#define BIT_TXDMAOK_CHANNEL_7 BIT(7)
#define BIT_TXDMAOK_CHANNEL_6 BIT(6)
#define BIT_TXDMAOK_CHANNEL_5 BIT(5)
#define BIT_TXDMAOK_CHANNEL_4 BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FPGA_TAG (Offset 0x10CC) */
#define BIT_SHIFT_FPGA_TAG 0
#define BIT_MASK_FPGA_TAG 0xffffffffL
#define BIT_FPGA_TAG(x) (((x) & BIT_MASK_FPGA_TAG) << BIT_SHIFT_FPGA_TAG)
#define BITS_FPGA_TAG (BIT_MASK_FPGA_TAG << BIT_SHIFT_FPGA_TAG)
#define BIT_CLEAR_FPGA_TAG(x) ((x) & (~BITS_FPGA_TAG))
#define BIT_GET_FPGA_TAG(x) (((x) >> BIT_SHIFT_FPGA_TAG) & BIT_MASK_FPGA_TAG)
#define BIT_SET_FPGA_TAG(x, v) (BIT_CLEAR_FPGA_TAG(x) | BIT_FPGA_TAG(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_CTRL0 (Offset 0x10D0) */
#define BIT_SHIFT_WL_DSS_DBG0_5_0 26
#define BIT_MASK_WL_DSS_DBG0_5_0 0x3f
#define BIT_WL_DSS_DBG0_5_0(x) \
(((x) & BIT_MASK_WL_DSS_DBG0_5_0) << BIT_SHIFT_WL_DSS_DBG0_5_0)
#define BITS_WL_DSS_DBG0_5_0 \
(BIT_MASK_WL_DSS_DBG0_5_0 << BIT_SHIFT_WL_DSS_DBG0_5_0)
#define BIT_CLEAR_WL_DSS_DBG0_5_0(x) ((x) & (~BITS_WL_DSS_DBG0_5_0))
#define BIT_GET_WL_DSS_DBG0_5_0(x) \
(((x) >> BIT_SHIFT_WL_DSS_DBG0_5_0) & BIT_MASK_WL_DSS_DBG0_5_0)
#define BIT_SET_WL_DSS_DBG0_5_0(x, v) \
(BIT_CLEAR_WL_DSS_DBG0_5_0(x) | BIT_WL_DSS_DBG0_5_0(v))
#define BIT_SHIFT_WL_DSS_DATA_IN_V1 5
#define BIT_MASK_WL_DSS_DATA_IN_V1 0xfffff
#define BIT_WL_DSS_DATA_IN_V1(x) \
(((x) & BIT_MASK_WL_DSS_DATA_IN_V1) << BIT_SHIFT_WL_DSS_DATA_IN_V1)
#define BITS_WL_DSS_DATA_IN_V1 \
(BIT_MASK_WL_DSS_DATA_IN_V1 << BIT_SHIFT_WL_DSS_DATA_IN_V1)
#define BIT_CLEAR_WL_DSS_DATA_IN_V1(x) ((x) & (~BITS_WL_DSS_DATA_IN_V1))
#define BIT_GET_WL_DSS_DATA_IN_V1(x) \
(((x) >> BIT_SHIFT_WL_DSS_DATA_IN_V1) & BIT_MASK_WL_DSS_DATA_IN_V1)
#define BIT_SET_WL_DSS_DATA_IN_V1(x, v) \
(BIT_CLEAR_WL_DSS_DATA_IN_V1(x) | BIT_WL_DSS_DATA_IN_V1(v))
#define BIT_WL_DSS_WIRE_SEL_V1 BIT(4)
#define BIT_SHIFT_WL_DSS_RO_SEL_V1 1
#define BIT_MASK_WL_DSS_RO_SEL_V1 0x7
#define BIT_WL_DSS_RO_SEL_V1(x) \
(((x) & BIT_MASK_WL_DSS_RO_SEL_V1) << BIT_SHIFT_WL_DSS_RO_SEL_V1)
#define BITS_WL_DSS_RO_SEL_V1 \
(BIT_MASK_WL_DSS_RO_SEL_V1 << BIT_SHIFT_WL_DSS_RO_SEL_V1)
#define BIT_CLEAR_WL_DSS_RO_SEL_V1(x) ((x) & (~BITS_WL_DSS_RO_SEL_V1))
#define BIT_GET_WL_DSS_RO_SEL_V1(x) \
(((x) >> BIT_SHIFT_WL_DSS_RO_SEL_V1) & BIT_MASK_WL_DSS_RO_SEL_V1)
#define BIT_SET_WL_DSS_RO_SEL_V1(x, v) \
(BIT_CLEAR_WL_DSS_RO_SEL_V1(x) | BIT_WL_DSS_RO_SEL_V1(v))
#define BIT_WL_DSS_RSTN_V1 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_PKT_READADDR (Offset 0x10D0) */
#define BIT_SHIFT_H2C_PKT_READADDR 0
#define BIT_MASK_H2C_PKT_READADDR 0x3ffff
#define BIT_H2C_PKT_READADDR(x) \
(((x) & BIT_MASK_H2C_PKT_READADDR) << BIT_SHIFT_H2C_PKT_READADDR)
#define BITS_H2C_PKT_READADDR \
(BIT_MASK_H2C_PKT_READADDR << BIT_SHIFT_H2C_PKT_READADDR)
#define BIT_CLEAR_H2C_PKT_READADDR(x) ((x) & (~BITS_H2C_PKT_READADDR))
#define BIT_GET_H2C_PKT_READADDR(x) \
(((x) >> BIT_SHIFT_H2C_PKT_READADDR) & BIT_MASK_H2C_PKT_READADDR)
#define BIT_SET_H2C_PKT_READADDR(x, v) \
(BIT_CLEAR_H2C_PKT_READADDR(x) | BIT_H2C_PKT_READADDR(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_STATUS0 (Offset 0x10D4) */
#define BIT_SHIFT_WL_DSS_DBG0_15_6 22
#define BIT_MASK_WL_DSS_DBG0_15_6 0x3ff
#define BIT_WL_DSS_DBG0_15_6(x) \
(((x) & BIT_MASK_WL_DSS_DBG0_15_6) << BIT_SHIFT_WL_DSS_DBG0_15_6)
#define BITS_WL_DSS_DBG0_15_6 \
(BIT_MASK_WL_DSS_DBG0_15_6 << BIT_SHIFT_WL_DSS_DBG0_15_6)
#define BIT_CLEAR_WL_DSS_DBG0_15_6(x) ((x) & (~BITS_WL_DSS_DBG0_15_6))
#define BIT_GET_WL_DSS_DBG0_15_6(x) \
(((x) >> BIT_SHIFT_WL_DSS_DBG0_15_6) & BIT_MASK_WL_DSS_DBG0_15_6)
#define BIT_SET_WL_DSS_DBG0_15_6(x, v) \
(BIT_CLEAR_WL_DSS_DBG0_15_6(x) | BIT_WL_DSS_DBG0_15_6(v))
#define BIT_WL_DSS_WSORT_GO_V1 BIT(21)
#define BIT_WL_DSS_READY_V1 BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2C_PKT_WRITEADDR (Offset 0x10D4) */
#define BIT_SHIFT_H2C_PKT_WRITEADDR 0
#define BIT_MASK_H2C_PKT_WRITEADDR 0x3ffff
#define BIT_H2C_PKT_WRITEADDR(x) \
(((x) & BIT_MASK_H2C_PKT_WRITEADDR) << BIT_SHIFT_H2C_PKT_WRITEADDR)
#define BITS_H2C_PKT_WRITEADDR \
(BIT_MASK_H2C_PKT_WRITEADDR << BIT_SHIFT_H2C_PKT_WRITEADDR)
#define BIT_CLEAR_H2C_PKT_WRITEADDR(x) ((x) & (~BITS_H2C_PKT_WRITEADDR))
#define BIT_GET_H2C_PKT_WRITEADDR(x) \
(((x) >> BIT_SHIFT_H2C_PKT_WRITEADDR) & BIT_MASK_H2C_PKT_WRITEADDR)
#define BIT_SET_H2C_PKT_WRITEADDR(x, v) \
(BIT_CLEAR_H2C_PKT_WRITEADDR(x) | BIT_H2C_PKT_WRITEADDR(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_SHIFT_WL_DSS_DBG1_5_0 26
#define BIT_MASK_WL_DSS_DBG1_5_0 0x3f
#define BIT_WL_DSS_DBG1_5_0(x) \
(((x) & BIT_MASK_WL_DSS_DBG1_5_0) << BIT_SHIFT_WL_DSS_DBG1_5_0)
#define BITS_WL_DSS_DBG1_5_0 \
(BIT_MASK_WL_DSS_DBG1_5_0 << BIT_SHIFT_WL_DSS_DBG1_5_0)
#define BIT_CLEAR_WL_DSS_DBG1_5_0(x) ((x) & (~BITS_WL_DSS_DBG1_5_0))
#define BIT_GET_WL_DSS_DBG1_5_0(x) \
(((x) >> BIT_SHIFT_WL_DSS_DBG1_5_0) & BIT_MASK_WL_DSS_DBG1_5_0)
#define BIT_SET_WL_DSS_DBG1_5_0(x, v) \
(BIT_CLEAR_WL_DSS_DBG1_5_0(x) | BIT_WL_DSS_DBG1_5_0(v))
#define BIT_WL_DSS_SPEED_EN1 BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_WL_DSS_WIRE_SEL BIT(24)
#define BIT_SHIFT_WL_DSS_RO_SEL 20
#define BIT_MASK_WL_DSS_RO_SEL 0x7
#define BIT_WL_DSS_RO_SEL(x) \
(((x) & BIT_MASK_WL_DSS_RO_SEL) << BIT_SHIFT_WL_DSS_RO_SEL)
#define BITS_WL_DSS_RO_SEL (BIT_MASK_WL_DSS_RO_SEL << BIT_SHIFT_WL_DSS_RO_SEL)
#define BIT_CLEAR_WL_DSS_RO_SEL(x) ((x) & (~BITS_WL_DSS_RO_SEL))
#define BIT_GET_WL_DSS_RO_SEL(x) \
(((x) >> BIT_SHIFT_WL_DSS_RO_SEL) & BIT_MASK_WL_DSS_RO_SEL)
#define BIT_SET_WL_DSS_RO_SEL(x, v) \
(BIT_CLEAR_WL_DSS_RO_SEL(x) | BIT_WL_DSS_RO_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_BB_SD BIT(17)
#define BIT_MEM_BB_DS BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_DENG_LS BIT(13)
#define BIT_MEM_DENG_DS BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_BT_DS BIT(10)
#define BIT_MEM_SDIO_LS BIT(9)
#define BIT_MEM_SDIO_DS BIT(8)
#define BIT_MEM_USB_LS BIT(7)
#define BIT_MEM_USB_DS BIT(6)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_SHIFT_WL_DSS_DATA_IN1 5
#define BIT_MASK_WL_DSS_DATA_IN1 0xfffff
#define BIT_WL_DSS_DATA_IN1(x) \
(((x) & BIT_MASK_WL_DSS_DATA_IN1) << BIT_SHIFT_WL_DSS_DATA_IN1)
#define BITS_WL_DSS_DATA_IN1 \
(BIT_MASK_WL_DSS_DATA_IN1 << BIT_SHIFT_WL_DSS_DATA_IN1)
#define BIT_CLEAR_WL_DSS_DATA_IN1(x) ((x) & (~BITS_WL_DSS_DATA_IN1))
#define BIT_GET_WL_DSS_DATA_IN1(x) \
(((x) >> BIT_SHIFT_WL_DSS_DATA_IN1) & BIT_MASK_WL_DSS_DATA_IN1)
#define BIT_SET_WL_DSS_DATA_IN1(x, v) \
(BIT_CLEAR_WL_DSS_DATA_IN1(x) | BIT_WL_DSS_DATA_IN1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_PCI_LS BIT(5)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_WL_DSS_WIRE_SEL1 BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_PCI_DS BIT(4)
#define BIT_MEM_WLMAC_LS BIT(3)
#define BIT_MEM_WLMAC_DS BIT(2)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_SHIFT_WL_DSS_RO_SEL1 1
#define BIT_MASK_WL_DSS_RO_SEL1 0x7
#define BIT_WL_DSS_RO_SEL1(x) \
(((x) & BIT_MASK_WL_DSS_RO_SEL1) << BIT_SHIFT_WL_DSS_RO_SEL1)
#define BITS_WL_DSS_RO_SEL1 \
(BIT_MASK_WL_DSS_RO_SEL1 << BIT_SHIFT_WL_DSS_RO_SEL1)
#define BIT_CLEAR_WL_DSS_RO_SEL1(x) ((x) & (~BITS_WL_DSS_RO_SEL1))
#define BIT_GET_WL_DSS_RO_SEL1(x) \
(((x) >> BIT_SHIFT_WL_DSS_RO_SEL1) & BIT_MASK_WL_DSS_RO_SEL1)
#define BIT_SET_WL_DSS_RO_SEL1(x, v) \
(BIT_CLEAR_WL_DSS_RO_SEL1(x) | BIT_WL_DSS_RO_SEL1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_WLMCU_LS BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_SHIFT_WL_DSS_DATA_IN 0
#define BIT_MASK_WL_DSS_DATA_IN 0xfffff
#define BIT_WL_DSS_DATA_IN(x) \
(((x) & BIT_MASK_WL_DSS_DATA_IN) << BIT_SHIFT_WL_DSS_DATA_IN)
#define BITS_WL_DSS_DATA_IN \
(BIT_MASK_WL_DSS_DATA_IN << BIT_SHIFT_WL_DSS_DATA_IN)
#define BIT_CLEAR_WL_DSS_DATA_IN(x) ((x) & (~BITS_WL_DSS_DATA_IN))
#define BIT_GET_WL_DSS_DATA_IN(x) \
(((x) >> BIT_SHIFT_WL_DSS_DATA_IN) & BIT_MASK_WL_DSS_DATA_IN)
#define BIT_SET_WL_DSS_DATA_IN(x, v) \
(BIT_CLEAR_WL_DSS_DATA_IN(x) | BIT_WL_DSS_DATA_IN(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_CTRL1 (Offset 0x10D8) */
#define BIT_WL_DSS_RSTN1 BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MEM_PWR_CRTL (Offset 0x10D8) */
#define BIT_MEM_WLMCU_DS BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WL_DSS_STATUS1 (Offset 0x10DC) */
#define BIT_SHIFT_WL_DSS_DBG1_15_6 22
#define BIT_MASK_WL_DSS_DBG1_15_6 0x3ff
#define BIT_WL_DSS_DBG1_15_6(x) \
(((x) & BIT_MASK_WL_DSS_DBG1_15_6) << BIT_SHIFT_WL_DSS_DBG1_15_6)
#define BITS_WL_DSS_DBG1_15_6 \
(BIT_MASK_WL_DSS_DBG1_15_6 << BIT_SHIFT_WL_DSS_DBG1_15_6)
#define BIT_CLEAR_WL_DSS_DBG1_15_6(x) ((x) & (~BITS_WL_DSS_DBG1_15_6))
#define BIT_GET_WL_DSS_DBG1_15_6(x) \
(((x) >> BIT_SHIFT_WL_DSS_DBG1_15_6) & BIT_MASK_WL_DSS_DBG1_15_6)
#define BIT_SET_WL_DSS_DBG1_15_6(x, v) \
(BIT_CLEAR_WL_DSS_DBG1_15_6(x) | BIT_WL_DSS_DBG1_15_6(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_WL_DSS_STATUS1 (Offset 0x10DC) */
#define BIT_WL_DSS_READY BIT(21)
#define BIT_WL_DSS_WSORT_GO BIT(20)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FW_DRV_HANDSHAKE (Offset 0x10DC) */
#define BIT_SHIFT_FW_DRV_HANDSHAKE 0
#define BIT_MASK_FW_DRV_HANDSHAKE 0xffffffffL
#define BIT_FW_DRV_HANDSHAKE(x) \
(((x) & BIT_MASK_FW_DRV_HANDSHAKE) << BIT_SHIFT_FW_DRV_HANDSHAKE)
#define BITS_FW_DRV_HANDSHAKE \
(BIT_MASK_FW_DRV_HANDSHAKE << BIT_SHIFT_FW_DRV_HANDSHAKE)
#define BIT_CLEAR_FW_DRV_HANDSHAKE(x) ((x) & (~BITS_FW_DRV_HANDSHAKE))
#define BIT_GET_FW_DRV_HANDSHAKE(x) \
(((x) >> BIT_SHIFT_FW_DRV_HANDSHAKE) & BIT_MASK_FW_DRV_HANDSHAKE)
#define BIT_SET_FW_DRV_HANDSHAKE(x, v) \
(BIT_CLEAR_FW_DRV_HANDSHAKE(x) | BIT_FW_DRV_HANDSHAKE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_FW_DBG0 (Offset 0x10E0) */
#define BIT_SHIFT_FW_DBG0 0
#define BIT_MASK_FW_DBG0 0xffffffffL
#define BIT_FW_DBG0(x) (((x) & BIT_MASK_FW_DBG0) << BIT_SHIFT_FW_DBG0)
#define BITS_FW_DBG0 (BIT_MASK_FW_DBG0 << BIT_SHIFT_FW_DBG0)
#define BIT_CLEAR_FW_DBG0(x) ((x) & (~BITS_FW_DBG0))
#define BIT_GET_FW_DBG0(x) (((x) >> BIT_SHIFT_FW_DBG0) & BIT_MASK_FW_DBG0)
#define BIT_SET_FW_DBG0(x, v) (BIT_CLEAR_FW_DBG0(x) | BIT_FW_DBG0(v))
/* 2 REG_FW_DBG1 (Offset 0x10E4) */
#define BIT_SHIFT_FW_DBG1 0
#define BIT_MASK_FW_DBG1 0xffffffffL
#define BIT_FW_DBG1(x) (((x) & BIT_MASK_FW_DBG1) << BIT_SHIFT_FW_DBG1)
#define BITS_FW_DBG1 (BIT_MASK_FW_DBG1 << BIT_SHIFT_FW_DBG1)
#define BIT_CLEAR_FW_DBG1(x) ((x) & (~BITS_FW_DBG1))
#define BIT_GET_FW_DBG1(x) (((x) >> BIT_SHIFT_FW_DBG1) & BIT_MASK_FW_DBG1)
#define BIT_SET_FW_DBG1(x, v) (BIT_CLEAR_FW_DBG1(x) | BIT_FW_DBG1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_FW_DBG2 (Offset 0x10E8) */
#define BIT_SHIFT_FW_DBG2 0
#define BIT_MASK_FW_DBG2 0xffffffffL
#define BIT_FW_DBG2(x) (((x) & BIT_MASK_FW_DBG2) << BIT_SHIFT_FW_DBG2)
#define BITS_FW_DBG2 (BIT_MASK_FW_DBG2 << BIT_SHIFT_FW_DBG2)
#define BIT_CLEAR_FW_DBG2(x) ((x) & (~BITS_FW_DBG2))
#define BIT_GET_FW_DBG2(x) (((x) >> BIT_SHIFT_FW_DBG2) & BIT_MASK_FW_DBG2)
#define BIT_SET_FW_DBG2(x, v) (BIT_CLEAR_FW_DBG2(x) | BIT_FW_DBG2(v))
/* 2 REG_FW_DBG3 (Offset 0x10EC) */
#define BIT_SHIFT_FW_DBG3 0
#define BIT_MASK_FW_DBG3 0xffffffffL
#define BIT_FW_DBG3(x) (((x) & BIT_MASK_FW_DBG3) << BIT_SHIFT_FW_DBG3)
#define BITS_FW_DBG3 (BIT_MASK_FW_DBG3 << BIT_SHIFT_FW_DBG3)
#define BIT_CLEAR_FW_DBG3(x) ((x) & (~BITS_FW_DBG3))
#define BIT_GET_FW_DBG3(x) (((x) >> BIT_SHIFT_FW_DBG3) & BIT_MASK_FW_DBG3)
#define BIT_SET_FW_DBG3(x, v) (BIT_CLEAR_FW_DBG3(x) | BIT_FW_DBG3(v))
/* 2 REG_FW_DBG4 (Offset 0x10F0) */
#define BIT_SHIFT_FW_DBG4 0
#define BIT_MASK_FW_DBG4 0xffffffffL
#define BIT_FW_DBG4(x) (((x) & BIT_MASK_FW_DBG4) << BIT_SHIFT_FW_DBG4)
#define BITS_FW_DBG4 (BIT_MASK_FW_DBG4 << BIT_SHIFT_FW_DBG4)
#define BIT_CLEAR_FW_DBG4(x) ((x) & (~BITS_FW_DBG4))
#define BIT_GET_FW_DBG4(x) (((x) >> BIT_SHIFT_FW_DBG4) & BIT_MASK_FW_DBG4)
#define BIT_SET_FW_DBG4(x, v) (BIT_CLEAR_FW_DBG4(x) | BIT_FW_DBG4(v))
/* 2 REG_FW_DBG5 (Offset 0x10F4) */
#define BIT_SHIFT_FW_DBG5 0
#define BIT_MASK_FW_DBG5 0xffffffffL
#define BIT_FW_DBG5(x) (((x) & BIT_MASK_FW_DBG5) << BIT_SHIFT_FW_DBG5)
#define BITS_FW_DBG5 (BIT_MASK_FW_DBG5 << BIT_SHIFT_FW_DBG5)
#define BIT_CLEAR_FW_DBG5(x) ((x) & (~BITS_FW_DBG5))
#define BIT_GET_FW_DBG5(x) (((x) >> BIT_SHIFT_FW_DBG5) & BIT_MASK_FW_DBG5)
#define BIT_SET_FW_DBG5(x, v) (BIT_CLEAR_FW_DBG5(x) | BIT_FW_DBG5(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FW_DBG6 (Offset 0x10F8) */
#define BIT_SHIFT_FW_DBG6 0
#define BIT_MASK_FW_DBG6 0xffffffffL
#define BIT_FW_DBG6(x) (((x) & BIT_MASK_FW_DBG6) << BIT_SHIFT_FW_DBG6)
#define BITS_FW_DBG6 (BIT_MASK_FW_DBG6 << BIT_SHIFT_FW_DBG6)
#define BIT_CLEAR_FW_DBG6(x) ((x) & (~BITS_FW_DBG6))
#define BIT_GET_FW_DBG6(x) (((x) >> BIT_SHIFT_FW_DBG6) & BIT_MASK_FW_DBG6)
#define BIT_SET_FW_DBG6(x, v) (BIT_CLEAR_FW_DBG6(x) | BIT_FW_DBG6(v))
/* 2 REG_FW_DBG7 (Offset 0x10FC) */
#define BIT_SHIFT_FW_DBG7 0
#define BIT_MASK_FW_DBG7 0xffffffffL
#define BIT_FW_DBG7(x) (((x) & BIT_MASK_FW_DBG7) << BIT_SHIFT_FW_DBG7)
#define BITS_FW_DBG7 (BIT_MASK_FW_DBG7 << BIT_SHIFT_FW_DBG7)
#define BIT_CLEAR_FW_DBG7(x) ((x) & (~BITS_FW_DBG7))
#define BIT_GET_FW_DBG7(x) (((x) >> BIT_SHIFT_FW_DBG7) & BIT_MASK_FW_DBG7)
#define BIT_SET_FW_DBG7(x, v) (BIT_CLEAR_FW_DBG7(x) | BIT_FW_DBG7(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CR_EXT (Offset 0x1100) */
#define BIT_SHIFT_PHY_REQ_DELAY 24
#define BIT_MASK_PHY_REQ_DELAY 0xf
#define BIT_PHY_REQ_DELAY(x) \
(((x) & BIT_MASK_PHY_REQ_DELAY) << BIT_SHIFT_PHY_REQ_DELAY)
#define BITS_PHY_REQ_DELAY (BIT_MASK_PHY_REQ_DELAY << BIT_SHIFT_PHY_REQ_DELAY)
#define BIT_CLEAR_PHY_REQ_DELAY(x) ((x) & (~BITS_PHY_REQ_DELAY))
#define BIT_GET_PHY_REQ_DELAY(x) \
(((x) >> BIT_SHIFT_PHY_REQ_DELAY) & BIT_MASK_PHY_REQ_DELAY)
#define BIT_SET_PHY_REQ_DELAY(x, v) \
(BIT_CLEAR_PHY_REQ_DELAY(x) | BIT_PHY_REQ_DELAY(v))
#define BIT_SPD_DOWN BIT(16)
#define BIT_SHIFT_NETYPE4 4
#define BIT_MASK_NETYPE4 0x3
#define BIT_NETYPE4(x) (((x) & BIT_MASK_NETYPE4) << BIT_SHIFT_NETYPE4)
#define BITS_NETYPE4 (BIT_MASK_NETYPE4 << BIT_SHIFT_NETYPE4)
#define BIT_CLEAR_NETYPE4(x) ((x) & (~BITS_NETYPE4))
#define BIT_GET_NETYPE4(x) (((x) >> BIT_SHIFT_NETYPE4) & BIT_MASK_NETYPE4)
#define BIT_SET_NETYPE4(x, v) (BIT_CLEAR_NETYPE4(x) | BIT_NETYPE4(v))
#define BIT_SHIFT_NETYPE3 2
#define BIT_MASK_NETYPE3 0x3
#define BIT_NETYPE3(x) (((x) & BIT_MASK_NETYPE3) << BIT_SHIFT_NETYPE3)
#define BITS_NETYPE3 (BIT_MASK_NETYPE3 << BIT_SHIFT_NETYPE3)
#define BIT_CLEAR_NETYPE3(x) ((x) & (~BITS_NETYPE3))
#define BIT_GET_NETYPE3(x) (((x) >> BIT_SHIFT_NETYPE3) & BIT_MASK_NETYPE3)
#define BIT_SET_NETYPE3(x, v) (BIT_CLEAR_NETYPE3(x) | BIT_NETYPE3(v))
#define BIT_SHIFT_NETYPE2 0
#define BIT_MASK_NETYPE2 0x3
#define BIT_NETYPE2(x) (((x) & BIT_MASK_NETYPE2) << BIT_SHIFT_NETYPE2)
#define BITS_NETYPE2 (BIT_MASK_NETYPE2 << BIT_SHIFT_NETYPE2)
#define BIT_CLEAR_NETYPE2(x) ((x) & (~BITS_NETYPE2))
#define BIT_GET_NETYPE2(x) (((x) >> BIT_SHIFT_NETYPE2) & BIT_MASK_NETYPE2)
#define BIT_SET_NETYPE2(x, v) (BIT_CLEAR_NETYPE2(x) | BIT_NETYPE2(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TC9_CTRL (Offset 0x1104) */
#define BIT_TC9INT_EN BIT(26)
#define BIT_TC9MODE BIT(25)
#define BIT_TC9EN BIT(24)
#define BIT_SHIFT_TC9DATA 0
#define BIT_MASK_TC9DATA 0xffffff
#define BIT_TC9DATA(x) (((x) & BIT_MASK_TC9DATA) << BIT_SHIFT_TC9DATA)
#define BITS_TC9DATA (BIT_MASK_TC9DATA << BIT_SHIFT_TC9DATA)
#define BIT_CLEAR_TC9DATA(x) ((x) & (~BITS_TC9DATA))
#define BIT_GET_TC9DATA(x) (((x) >> BIT_SHIFT_TC9DATA) & BIT_MASK_TC9DATA)
#define BIT_SET_TC9DATA(x, v) (BIT_CLEAR_TC9DATA(x) | BIT_TC9DATA(v))
/* 2 REG_TC10_CTRL (Offset 0x1108) */
#define BIT_TC10INT_EN BIT(26)
#define BIT_TC10MODE BIT(25)
#define BIT_TC10EN BIT(24)
#define BIT_SHIFT_TC10DATA 0
#define BIT_MASK_TC10DATA 0xffffff
#define BIT_TC10DATA(x) (((x) & BIT_MASK_TC10DATA) << BIT_SHIFT_TC10DATA)
#define BITS_TC10DATA (BIT_MASK_TC10DATA << BIT_SHIFT_TC10DATA)
#define BIT_CLEAR_TC10DATA(x) ((x) & (~BITS_TC10DATA))
#define BIT_GET_TC10DATA(x) (((x) >> BIT_SHIFT_TC10DATA) & BIT_MASK_TC10DATA)
#define BIT_SET_TC10DATA(x, v) (BIT_CLEAR_TC10DATA(x) | BIT_TC10DATA(v))
/* 2 REG_TC11_CTRL (Offset 0x110C) */
#define BIT_TC11INT_EN BIT(26)
#define BIT_TC11MODE BIT(25)
#define BIT_TC11EN BIT(24)
#define BIT_SHIFT_TC11DATA 0
#define BIT_MASK_TC11DATA 0xffffff
#define BIT_TC11DATA(x) (((x) & BIT_MASK_TC11DATA) << BIT_SHIFT_TC11DATA)
#define BITS_TC11DATA (BIT_MASK_TC11DATA << BIT_SHIFT_TC11DATA)
#define BIT_CLEAR_TC11DATA(x) ((x) & (~BITS_TC11DATA))
#define BIT_GET_TC11DATA(x) (((x) >> BIT_SHIFT_TC11DATA) & BIT_MASK_TC11DATA)
#define BIT_SET_TC11DATA(x, v) (BIT_CLEAR_TC11DATA(x) | BIT_TC11DATA(v))
/* 2 REG_TC12_CTRL (Offset 0x1110) */
#define BIT_TC12INT_EN BIT(26)
#define BIT_TC12MODE BIT(25)
#define BIT_TC12EN BIT(24)
#define BIT_P2P_PWROFF_NOA2_ERLY_INT BIT(22)
#define BIT_P2P_PWROFF_NOA1_ERLY_INT BIT(21)
#define BIT_P2P_PWROFF_NOA0_ERLY_INT BIT(20)
#define BIT_SHIFT_TC12DATA 0
#define BIT_MASK_TC12DATA 0xffffff
#define BIT_TC12DATA(x) (((x) & BIT_MASK_TC12DATA) << BIT_SHIFT_TC12DATA)
#define BITS_TC12DATA (BIT_MASK_TC12DATA << BIT_SHIFT_TC12DATA)
#define BIT_CLEAR_TC12DATA(x) ((x) & (~BITS_TC12DATA))
#define BIT_GET_TC12DATA(x) (((x) >> BIT_SHIFT_TC12DATA) & BIT_MASK_TC12DATA)
#define BIT_SET_TC12DATA(x, v) (BIT_CLEAR_TC12DATA(x) | BIT_TC12DATA(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FWFF (Offset 0x1114) */
#define BIT_SHIFT_PKTNUM_TH 24
#define BIT_MASK_PKTNUM_TH 0xff
#define BIT_PKTNUM_TH(x) (((x) & BIT_MASK_PKTNUM_TH) << BIT_SHIFT_PKTNUM_TH)
#define BITS_PKTNUM_TH (BIT_MASK_PKTNUM_TH << BIT_SHIFT_PKTNUM_TH)
#define BIT_CLEAR_PKTNUM_TH(x) ((x) & (~BITS_PKTNUM_TH))
#define BIT_GET_PKTNUM_TH(x) (((x) >> BIT_SHIFT_PKTNUM_TH) & BIT_MASK_PKTNUM_TH)
#define BIT_SET_PKTNUM_TH(x, v) (BIT_CLEAR_PKTNUM_TH(x) | BIT_PKTNUM_TH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FWFF (Offset 0x1114) */
#define BIT_SHIFT_PKTNUM_TH_V1 24
#define BIT_MASK_PKTNUM_TH_V1 0xff
#define BIT_PKTNUM_TH_V1(x) \
(((x) & BIT_MASK_PKTNUM_TH_V1) << BIT_SHIFT_PKTNUM_TH_V1)
#define BITS_PKTNUM_TH_V1 (BIT_MASK_PKTNUM_TH_V1 << BIT_SHIFT_PKTNUM_TH_V1)
#define BIT_CLEAR_PKTNUM_TH_V1(x) ((x) & (~BITS_PKTNUM_TH_V1))
#define BIT_GET_PKTNUM_TH_V1(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V1) & BIT_MASK_PKTNUM_TH_V1)
#define BIT_SET_PKTNUM_TH_V1(x, v) \
(BIT_CLEAR_PKTNUM_TH_V1(x) | BIT_PKTNUM_TH_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FWFF (Offset 0x1114) */
#define BIT_SHIFT_TIMER_TH 16
#define BIT_MASK_TIMER_TH 0xff
#define BIT_TIMER_TH(x) (((x) & BIT_MASK_TIMER_TH) << BIT_SHIFT_TIMER_TH)
#define BITS_TIMER_TH (BIT_MASK_TIMER_TH << BIT_SHIFT_TIMER_TH)
#define BIT_CLEAR_TIMER_TH(x) ((x) & (~BITS_TIMER_TH))
#define BIT_GET_TIMER_TH(x) (((x) >> BIT_SHIFT_TIMER_TH) & BIT_MASK_TIMER_TH)
#define BIT_SET_TIMER_TH(x, v) (BIT_CLEAR_TIMER_TH(x) | BIT_TIMER_TH(v))
#define BIT_SHIFT_RXPKT1ENADDR 0
#define BIT_MASK_RXPKT1ENADDR 0xffff
#define BIT_RXPKT1ENADDR(x) \
(((x) & BIT_MASK_RXPKT1ENADDR) << BIT_SHIFT_RXPKT1ENADDR)
#define BITS_RXPKT1ENADDR (BIT_MASK_RXPKT1ENADDR << BIT_SHIFT_RXPKT1ENADDR)
#define BIT_CLEAR_RXPKT1ENADDR(x) ((x) & (~BITS_RXPKT1ENADDR))
#define BIT_GET_RXPKT1ENADDR(x) \
(((x) >> BIT_SHIFT_RXPKT1ENADDR) & BIT_MASK_RXPKT1ENADDR)
#define BIT_SET_RXPKT1ENADDR(x, v) \
(BIT_CLEAR_RXPKT1ENADDR(x) | BIT_RXPKT1ENADDR(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE2IMR (Offset 0x1120) */
#define BIT__FE4ISR__IND_MSK BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE2IMR (Offset 0x1120) */
#define BIT_FS_TXSC_DESC_DONE_INT_EN BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_EN BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_EN BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_EN BIT(25)
#define BIT_FS_TXSC_VODONE_INT_EN BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE2IMR (Offset 0x1120) */
#define BIT_FS_ATIM_MB7_INT_EN BIT(23)
#define BIT_FS_ATIM_MB6_INT_EN BIT(22)
#define BIT_FS_ATIM_MB5_INT_EN BIT(21)
#define BIT_FS_ATIM_MB4_INT_EN BIT(20)
#define BIT_FS_ATIM_MB3_INT_EN BIT(19)
#define BIT_FS_ATIM_MB2_INT_EN BIT(18)
#define BIT_FS_ATIM_MB1_INT_EN BIT(17)
#define BIT_FS_ATIM_MB0_INT_EN BIT(16)
#define BIT_FS_TBTT4INT_EN BIT(11)
#define BIT_FS_TBTT3INT_EN BIT(10)
#define BIT_FS_TBTT2INT_EN BIT(9)
#define BIT_FS_TBTT1INT_EN BIT(8)
#define BIT_FS_TBTT0_MB7INT_EN BIT(7)
#define BIT_FS_TBTT0_MB6INT_EN BIT(6)
#define BIT_FS_TBTT0_MB5INT_EN BIT(5)
#define BIT_FS_TBTT0_MB4INT_EN BIT(4)
#define BIT_FS_TBTT0_MB3INT_EN BIT(3)
#define BIT_FS_TBTT0_MB2INT_EN BIT(2)
#define BIT_FS_TBTT0_MB1INT_EN BIT(1)
#define BIT_FS_TBTT0_INT_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE2ISR (Offset 0x1124) */
#define BIT__FE4ISR__IND_INT BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE2ISR (Offset 0x1124) */
#define BIT_FS_TXSC_DESC_DONE_INT BIT(28)
#define BIT_FS_TXSC_BKDONE_INT BIT(27)
#define BIT_FS_TXSC_BEDONE_INT BIT(26)
#define BIT_FS_TXSC_VIDONE_INT BIT(25)
#define BIT_FS_TXSC_VODONE_INT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE2ISR (Offset 0x1124) */
#define BIT_FS_ATIM_MB7_INT BIT(23)
#define BIT_FS_ATIM_MB6_INT BIT(22)
#define BIT_FS_ATIM_MB5_INT BIT(21)
#define BIT_FS_ATIM_MB4_INT BIT(20)
#define BIT_FS_ATIM_MB3_INT BIT(19)
#define BIT_FS_ATIM_MB2_INT BIT(18)
#define BIT_FS_ATIM_MB1_INT BIT(17)
#define BIT_FS_ATIM_MB0_INT BIT(16)
#define BIT_FS_TBTT4INT BIT(11)
#define BIT_FS_TBTT3INT BIT(10)
#define BIT_FS_TBTT2INT BIT(9)
#define BIT_FS_TBTT1INT BIT(8)
#define BIT_FS_TBTT0_MB7INT BIT(7)
#define BIT_FS_TBTT0_MB6INT BIT(6)
#define BIT_FS_TBTT0_MB5INT BIT(5)
#define BIT_FS_TBTT0_MB4INT BIT(4)
#define BIT_FS_TBTT0_MB3INT BIT(3)
#define BIT_FS_TBTT0_MB2INT BIT(2)
#define BIT_FS_TBTT0_MB1INT BIT(1)
#define BIT_FS_TBTT0_INT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_BCNELY4_AGGR_INT_EN BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT__EN BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_BCNELY3_AGGR_INT_EN BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT__EN BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_BCNELY2_AGGR_INT_EN BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT__EN BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_BCNELY1_AGGR_INT_EN BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT__EN BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE3IMR (Offset 0x1128) */
#define BIT_FS_BCNDMA4_INT_EN BIT(27)
#define BIT_FS_BCNDMA3_INT_EN BIT(26)
#define BIT_FS_BCNDMA2_INT_EN BIT(25)
#define BIT_FS_BCNDMA1_INT_EN BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_EN BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_EN BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_EN BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_EN BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_EN BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_EN BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_EN BIT(17)
#define BIT_FS_BCNDMA0_INT_EN BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT__EN BIT(15)
#define BIT_FS_BCNERLY4_INT_EN BIT(11)
#define BIT_FS_BCNERLY3_INT_EN BIT(10)
#define BIT_FS_BCNERLY2_INT_EN BIT(9)
#define BIT_FS_BCNERLY1_INT_EN BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_EN BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_EN BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_EN BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_EN BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_EN BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_EN BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_EN BIT(1)
#define BIT_FS_BCNERLY0_INT_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_BCNELY4_AGGR_INT BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_BCNELY3_AGGR_INT BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_BCNELY2_AGGR_INT BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_BCNELY1_AGGR_INT BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FE3ISR (Offset 0x112C) */
#define BIT_FS_BCNDMA4_INT BIT(27)
#define BIT_FS_BCNDMA3_INT BIT(26)
#define BIT_FS_BCNDMA2_INT BIT(25)
#define BIT_FS_BCNDMA1_INT BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT BIT(17)
#define BIT_FS_BCNDMA0_INT BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT BIT(15)
#define BIT_FS_BCNERLY4_INT BIT(11)
#define BIT_FS_BCNERLY3_INT BIT(10)
#define BIT_FS_BCNERLY2_INT BIT(9)
#define BIT_FS_BCNERLY1_INT BIT(8)
#define BIT_FS_BCNERLY0_MB7INT BIT(7)
#define BIT_FS_BCNERLY0_MB6INT BIT(6)
#define BIT_FS_BCNERLY0_MB5INT BIT(5)
#define BIT_FS_BCNERLY0_MB4INT BIT(4)
#define BIT_FS_BCNERLY0_MB3INT BIT(3)
#define BIT_FS_BCNERLY0_MB2INT BIT(2)
#define BIT_FS_BCNERLY0_MB1INT BIT(1)
#define BIT_FS_BCNERLY0_INT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT4_PKTIN_INT_EN BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI3_TXPKTIN_INT_EN BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT3_PKTIN_INT_EN BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI2_TXPKTIN_INT_EN BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT2_PKTIN_INT_EN BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI1_TXPKTIN_INT_EN BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT1_PKTIN_INT_EN BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI0_TXPKTIN_INT_EN BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT4_RXUCMD0_OK_INT_EN BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI3_RX_UMD0_INT_EN BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT4_RXUCMD1_OK_INT_EN BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI3_RX_UMD1_INT_EN BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT4_RXBCMD0_OK_INT_EN BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI3_RX_BMD0_INT_EN BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT4_RXBCMD1_OK_INT_EN BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI3_RX_BMD1_INT_EN BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT3_RXUCMD0_OK_INT_EN BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI2_RX_UMD0_INT_EN BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT3_RXUCMD1_OK_INT_EN BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI2_RX_UMD1_INT_EN BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT3_RXBCMD0_OK_INT_EN BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI2_RX_BMD0_INT_EN BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT3_RXBCMD1_OK_INT_EN BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI2_RX_BMD1_INT_EN BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT2_RXUCMD0_OK_INT_EN BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI1_RX_UMD0_INT_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT2_RXUCMD1_OK_INT_EN BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI1_RX_UMD1_INT_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT2_RXBCMD0_OK_INT_EN BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI1_RX_BMD0_INT_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT2_RXBCMD1_OK_INT_EN BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI1_RX_BMD1_INT_EN BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT1_RXUCMD0_OK_INT_EN BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI0_RX_UMD0_INT_EN BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT1_RXUCMD1_OK_INT_EN BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI0_RX_UMD1_INT_EN BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_DMEM1_WPTR_UPDATE_INT_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT1_RXBCMD0_OK_INT_EN BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI0_RX_BMD0_INT_EN BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_PORT1_RXBCMD1_OK_INT_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4IMR (Offset 0x1130) */
#define BIT_FS_CLI0_RX_BMD1_INT_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT4_PKTIN_INT BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI3_TXPKTIN_INT BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT3_PKTIN_INT BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI2_TXPKTIN_INT BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT2_PKTIN_INT BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI1_TXPKTIN_INT BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT1_PKTIN_INT BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI0_TXPKTIN_INT BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT4_RXUCMD0_OK_INT BIT(15)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI3_RX_UMD0_INT BIT(15)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT4_RXUCMD1_OK_INT BIT(14)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI3_RX_UMD1_INT BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT4_RXBCMD0_OK_INT BIT(13)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI3_RX_BMD0_INT BIT(13)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT4_RXBCMD1_OK_INT BIT(12)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI3_RX_BMD1_INT BIT(12)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT3_RXUCMD0_OK_INT BIT(11)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI2_RX_UMD0_INT BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT3_RXUCMD1_OK_INT BIT(10)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI2_RX_UMD1_INT BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT3_RXBCMD0_OK_INT BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI2_RX_BMD0_INT BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT3_RXBCMD1_OK_INT BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI2_RX_BMD1_INT BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT2_RXUCMD0_OK_INT BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI1_RX_UMD0_INT BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT2_RXUCMD1_OK_INT BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI1_RX_UMD1_INT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT2_RXBCMD0_OK_INT BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI1_RX_BMD0_INT BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT2_RXBCMD1_OK_INT BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI1_RX_BMD1_INT BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT1_RXUCMD0_OK_INT BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI0_RX_UMD0_INT BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT1_RXUCMD1_OK_INT BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI0_RX_UMD1_INT BIT(2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_DMEM1_WPTR_UPDATE_INT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT1_RXBCMD0_OK_INT BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI0_RX_BMD0_INT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_PORT1_RXBCMD1_OK_INT BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FE4ISR (Offset 0x1134) */
#define BIT_FS_CLI0_RX_BMD1_INT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT1IMR (Offset 0x1138) */
#define BIT__FT2ISR__IND_MSK BIT(30)
#define BIT_FTM_PTT_INT_EN BIT(29)
#define BIT_RXFTMREQ_INT_EN BIT(28)
#define BIT_RXFTM_INT_EN BIT(27)
#define BIT_TXFTM_INT_EN BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT1IMR (Offset 0x1138) */
#define BIT_FS_H2C_CMD_OK_INT_EN BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_EN BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT1IMR (Offset 0x1138) */
#define BIT_FS_MACID_PWRCHANGE5_INT_EN BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_EN BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1IMR (Offset 0x1138) */
#define BIT_FS_MACID_SEARCH_FAIL_INT_EN BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1IMR (Offset 0x1138) */
#define BIT_FS_MACID_PWRCHANGE3_INT_EN BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_EN BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_EN BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_EN BIT(18)
#define BIT_FS_CTWEND2_INT_EN BIT(17)
#define BIT_FS_CTWEND1_INT_EN BIT(16)
#define BIT_FS_CTWEND0_INT_EN BIT(15)
#define BIT_FS_TX_NULL1_INT_EN BIT(14)
#define BIT_FS_TX_NULL0_INT_EN BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_EN BIT(12)
#define BIT_FS_P2P_RFON2_INT_EN BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_EN BIT(10)
#define BIT_FS_P2P_RFON1_INT_EN BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_EN BIT(8)
#define BIT_FS_P2P_RFON0_INT_EN BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_EN BIT(6)
#define BIT_FS_RX_UAPSDMD1_EN BIT(5)
#define BIT_FS_RX_UAPSDMD0_EN BIT(4)
#define BIT_FS_TRIGGER_PKT_EN BIT(3)
#define BIT_FS_EOSP_INT_EN BIT(2)
#define BIT_FS_RPWM2_INT_EN BIT(1)
#define BIT_FS_RPWM_INT_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT__FT2ISR__IND_INT BIT(30)
#define BIT_FTM_PTT_INT BIT(29)
#define BIT_RXFTMREQ_INT BIT(28)
#define BIT_RXFTM_INT BIT(27)
#define BIT_TXFTM_INT BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_H2C_CMD_OK_INT BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_MACID_PWRCHANGE5_INT BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT BIT(22)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_MACID_SEARCH_FAIL_INT BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_MACID_PWRCHANGE3_INT BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT BIT(18)
#define BIT_FS_CTWEND2_INT BIT(17)
#define BIT_FS_CTWEND1_INT BIT(16)
#define BIT_FS_CTWEND0_INT BIT(15)
#define BIT_FS_TX_NULL1_INT BIT(14)
#define BIT_FS_TX_NULL0_INT BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_INT BIT(12)
#define BIT_FS_P2P_RFON2_INT BIT(11)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNOK_PORT4_INT_EN BIT(11)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_P2P_RFOFF2_INT BIT(10)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNOK_PORT3_INT_EN BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_P2P_RFON1_INT BIT(9)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNOK_PORT2_INT_EN BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_P2P_RFOFF1_INT BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNOK_PORT1_INT_EN BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_P2P_RFON0_INT BIT(7)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNERR_PORT4_INT_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_P2P_RFOFF0_INT BIT(6)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNERR_PORT3_INT_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_RX_UAPSDMD1_INT BIT(5)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNERR_PORT2_INT_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_RX_UAPSDMD0_INT BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TXBCNERR_PORT1_INT_EN BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_TRIGGER_PKT_INT BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_ATIM_PORT4_INT_EN BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_EOSP_INT BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_ATIM_PORT3_INT_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_RPWM2_INT BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_ATIM_PORT2_INT_EN BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_RPWM_INT BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FT1ISR (Offset 0x113C) */
#define BIT_FS_ATIM_PORT1_INT_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SPWR0 (Offset 0x1140) */
#define BIT_SHIFT_MID_31TO0 0
#define BIT_MASK_MID_31TO0 0xffffffffL
#define BIT_MID_31TO0(x) (((x) & BIT_MASK_MID_31TO0) << BIT_SHIFT_MID_31TO0)
#define BITS_MID_31TO0 (BIT_MASK_MID_31TO0 << BIT_SHIFT_MID_31TO0)
#define BIT_CLEAR_MID_31TO0(x) ((x) & (~BITS_MID_31TO0))
#define BIT_GET_MID_31TO0(x) (((x) >> BIT_SHIFT_MID_31TO0) & BIT_MASK_MID_31TO0)
#define BIT_SET_MID_31TO0(x, v) (BIT_CLEAR_MID_31TO0(x) | BIT_MID_31TO0(v))
/* 2 REG_SPWR1 (Offset 0x1144) */
#define BIT_SHIFT_MID_63TO32 0
#define BIT_MASK_MID_63TO32 0xffffffffL
#define BIT_MID_63TO32(x) (((x) & BIT_MASK_MID_63TO32) << BIT_SHIFT_MID_63TO32)
#define BITS_MID_63TO32 (BIT_MASK_MID_63TO32 << BIT_SHIFT_MID_63TO32)
#define BIT_CLEAR_MID_63TO32(x) ((x) & (~BITS_MID_63TO32))
#define BIT_GET_MID_63TO32(x) \
(((x) >> BIT_SHIFT_MID_63TO32) & BIT_MASK_MID_63TO32)
#define BIT_SET_MID_63TO32(x, v) (BIT_CLEAR_MID_63TO32(x) | BIT_MID_63TO32(v))
/* 2 REG_SPWR2 (Offset 0x1148) */
#define BIT_SHIFT_MID_95O64 0
#define BIT_MASK_MID_95O64 0xffffffffL
#define BIT_MID_95O64(x) (((x) & BIT_MASK_MID_95O64) << BIT_SHIFT_MID_95O64)
#define BITS_MID_95O64 (BIT_MASK_MID_95O64 << BIT_SHIFT_MID_95O64)
#define BIT_CLEAR_MID_95O64(x) ((x) & (~BITS_MID_95O64))
#define BIT_GET_MID_95O64(x) (((x) >> BIT_SHIFT_MID_95O64) & BIT_MASK_MID_95O64)
#define BIT_SET_MID_95O64(x, v) (BIT_CLEAR_MID_95O64(x) | BIT_MID_95O64(v))
/* 2 REG_SPWR3 (Offset 0x114C) */
#define BIT_SHIFT_MID_127TO96 0
#define BIT_MASK_MID_127TO96 0xffffffffL
#define BIT_MID_127TO96(x) \
(((x) & BIT_MASK_MID_127TO96) << BIT_SHIFT_MID_127TO96)
#define BITS_MID_127TO96 (BIT_MASK_MID_127TO96 << BIT_SHIFT_MID_127TO96)
#define BIT_CLEAR_MID_127TO96(x) ((x) & (~BITS_MID_127TO96))
#define BIT_GET_MID_127TO96(x) \
(((x) >> BIT_SHIFT_MID_127TO96) & BIT_MASK_MID_127TO96)
#define BIT_SET_MID_127TO96(x, v) \
(BIT_CLEAR_MID_127TO96(x) | BIT_MID_127TO96(v))
/* 2 REG_POWSEQ (Offset 0x1150) */
#define BIT_SHIFT_REF_MID 0
#define BIT_MASK_REF_MID 0x7f
#define BIT_REF_MID(x) (((x) & BIT_MASK_REF_MID) << BIT_SHIFT_REF_MID)
#define BITS_REF_MID (BIT_MASK_REF_MID << BIT_SHIFT_REF_MID)
#define BIT_CLEAR_REF_MID(x) ((x) & (~BITS_REF_MID))
#define BIT_GET_REF_MID(x) (((x) >> BIT_SHIFT_REF_MID) & BIT_MASK_REF_MID)
#define BIT_SET_REF_MID(x, v) (BIT_CLEAR_REF_MID(x) | BIT_REF_MID(v))
/* 2 REG_TC7_CTRL_V1 (Offset 0x1158) */
#define BIT_TC7INT_EN BIT(26)
#define BIT_TC7MODE BIT(25)
#define BIT_TC7EN BIT(24)
#define BIT_SHIFT_TC7DATA 0
#define BIT_MASK_TC7DATA 0xffffff
#define BIT_TC7DATA(x) (((x) & BIT_MASK_TC7DATA) << BIT_SHIFT_TC7DATA)
#define BITS_TC7DATA (BIT_MASK_TC7DATA << BIT_SHIFT_TC7DATA)
#define BIT_CLEAR_TC7DATA(x) ((x) & (~BITS_TC7DATA))
#define BIT_GET_TC7DATA(x) (((x) >> BIT_SHIFT_TC7DATA) & BIT_MASK_TC7DATA)
#define BIT_SET_TC7DATA(x, v) (BIT_CLEAR_TC7DATA(x) | BIT_TC7DATA(v))
/* 2 REG_TC8_CTRL_V1 (Offset 0x115C) */
#define BIT_TC8INT_EN BIT(26)
#define BIT_TC8MODE BIT(25)
#define BIT_TC8EN BIT(24)
#define BIT_SHIFT_TC8DATA 0
#define BIT_MASK_TC8DATA 0xffffff
#define BIT_TC8DATA(x) (((x) & BIT_MASK_TC8DATA) << BIT_SHIFT_TC8DATA)
#define BITS_TC8DATA (BIT_MASK_TC8DATA << BIT_SHIFT_TC8DATA)
#define BIT_CLEAR_TC8DATA(x) ((x) & (~BITS_TC8DATA))
#define BIT_GET_TC8DATA(x) (((x) >> BIT_SHIFT_TC8DATA) & BIT_MASK_TC8DATA)
#define BIT_SET_TC8DATA(x, v) (BIT_CLEAR_TC8DATA(x) | BIT_TC8DATA(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT0TO3 (Offset 0x1160) */
#define BIT_SHIFT_PORT3_RXBCN_TBTT_INTERVAL 24
#define BIT_MASK_PORT3_RXBCN_TBTT_INTERVAL 0xff
#define BIT_PORT3_RXBCN_TBTT_INTERVAL(x) \
(((x) & BIT_MASK_PORT3_RXBCN_TBTT_INTERVAL) \
<< BIT_SHIFT_PORT3_RXBCN_TBTT_INTERVAL)
#define BITS_PORT3_RXBCN_TBTT_INTERVAL \
(BIT_MASK_PORT3_RXBCN_TBTT_INTERVAL \
<< BIT_SHIFT_PORT3_RXBCN_TBTT_INTERVAL)
#define BIT_CLEAR_PORT3_RXBCN_TBTT_INTERVAL(x) \
((x) & (~BITS_PORT3_RXBCN_TBTT_INTERVAL))
#define BIT_GET_PORT3_RXBCN_TBTT_INTERVAL(x) \
(((x) >> BIT_SHIFT_PORT3_RXBCN_TBTT_INTERVAL) & \
BIT_MASK_PORT3_RXBCN_TBTT_INTERVAL)
#define BIT_SET_PORT3_RXBCN_TBTT_INTERVAL(x, v) \
(BIT_CLEAR_PORT3_RXBCN_TBTT_INTERVAL(x) | \
BIT_PORT3_RXBCN_TBTT_INTERVAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RX_BCN_TBTT_ITVL0 (Offset 0x1160) */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2 24
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT2(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT2 \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2 \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT2))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT2(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT2(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT0TO3 (Offset 0x1160) */
#define BIT_SHIFT_PORT2_RXBCN_TBTT_INTERVAL 16
#define BIT_MASK_PORT2_RXBCN_TBTT_INTERVAL 0xff
#define BIT_PORT2_RXBCN_TBTT_INTERVAL(x) \
(((x) & BIT_MASK_PORT2_RXBCN_TBTT_INTERVAL) \
<< BIT_SHIFT_PORT2_RXBCN_TBTT_INTERVAL)
#define BITS_PORT2_RXBCN_TBTT_INTERVAL \
(BIT_MASK_PORT2_RXBCN_TBTT_INTERVAL \
<< BIT_SHIFT_PORT2_RXBCN_TBTT_INTERVAL)
#define BIT_CLEAR_PORT2_RXBCN_TBTT_INTERVAL(x) \
((x) & (~BITS_PORT2_RXBCN_TBTT_INTERVAL))
#define BIT_GET_PORT2_RXBCN_TBTT_INTERVAL(x) \
(((x) >> BIT_SHIFT_PORT2_RXBCN_TBTT_INTERVAL) & \
BIT_MASK_PORT2_RXBCN_TBTT_INTERVAL)
#define BIT_SET_PORT2_RXBCN_TBTT_INTERVAL(x, v) \
(BIT_CLEAR_PORT2_RXBCN_TBTT_INTERVAL(x) | \
BIT_PORT2_RXBCN_TBTT_INTERVAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RX_BCN_TBTT_ITVL0 (Offset 0x1160) */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1 16
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT1(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT1 \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1 \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT1))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT1(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT1(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT0TO3 (Offset 0x1160) */
#define BIT_SHIFT_PORT1_RXBCN_TBTT_INTERVAL 8
#define BIT_MASK_PORT1_RXBCN_TBTT_INTERVAL 0xff
#define BIT_PORT1_RXBCN_TBTT_INTERVAL(x) \
(((x) & BIT_MASK_PORT1_RXBCN_TBTT_INTERVAL) \
<< BIT_SHIFT_PORT1_RXBCN_TBTT_INTERVAL)
#define BITS_PORT1_RXBCN_TBTT_INTERVAL \
(BIT_MASK_PORT1_RXBCN_TBTT_INTERVAL \
<< BIT_SHIFT_PORT1_RXBCN_TBTT_INTERVAL)
#define BIT_CLEAR_PORT1_RXBCN_TBTT_INTERVAL(x) \
((x) & (~BITS_PORT1_RXBCN_TBTT_INTERVAL))
#define BIT_GET_PORT1_RXBCN_TBTT_INTERVAL(x) \
(((x) >> BIT_SHIFT_PORT1_RXBCN_TBTT_INTERVAL) & \
BIT_MASK_PORT1_RXBCN_TBTT_INTERVAL)
#define BIT_SET_PORT1_RXBCN_TBTT_INTERVAL(x, v) \
(BIT_CLEAR_PORT1_RXBCN_TBTT_INTERVAL(x) | \
BIT_PORT1_RXBCN_TBTT_INTERVAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RX_BCN_TBTT_ITVL0 (Offset 0x1160) */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0 8
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT0(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT0 \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0 \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT0))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT0(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT0(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT0(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT0TO3 (Offset 0x1160) */
#define BIT_SHIFT_PORT0_RXBCN_TBTT_INTERVAL 0
#define BIT_MASK_PORT0_RXBCN_TBTT_INTERVAL 0xff
#define BIT_PORT0_RXBCN_TBTT_INTERVAL(x) \
(((x) & BIT_MASK_PORT0_RXBCN_TBTT_INTERVAL) \
<< BIT_SHIFT_PORT0_RXBCN_TBTT_INTERVAL)
#define BITS_PORT0_RXBCN_TBTT_INTERVAL \
(BIT_MASK_PORT0_RXBCN_TBTT_INTERVAL \
<< BIT_SHIFT_PORT0_RXBCN_TBTT_INTERVAL)
#define BIT_CLEAR_PORT0_RXBCN_TBTT_INTERVAL(x) \
((x) & (~BITS_PORT0_RXBCN_TBTT_INTERVAL))
#define BIT_GET_PORT0_RXBCN_TBTT_INTERVAL(x) \
(((x) >> BIT_SHIFT_PORT0_RXBCN_TBTT_INTERVAL) & \
BIT_MASK_PORT0_RXBCN_TBTT_INTERVAL)
#define BIT_SET_PORT0_RXBCN_TBTT_INTERVAL(x, v) \
(BIT_CLEAR_PORT0_RXBCN_TBTT_INTERVAL(x) | \
BIT_PORT0_RXBCN_TBTT_INTERVAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RX_BCN_TBTT_ITVL0 (Offset 0x1160) */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_PORT0 0xff
#define BIT_RX_BCN_TBTT_ITVL_PORT0(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_PORT0) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0)
#define BITS_RX_BCN_TBTT_ITVL_PORT0 \
(BIT_MASK_RX_BCN_TBTT_ITVL_PORT0 << BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_PORT0))
#define BIT_GET_RX_BCN_TBTT_ITVL_PORT0(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0) & \
BIT_MASK_RX_BCN_TBTT_ITVL_PORT0)
#define BIT_SET_RX_BCN_TBTT_ITVL_PORT0(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0(x) | BIT_RX_BCN_TBTT_ITVL_PORT0(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT4 (Offset 0x1164) */
#define BIT_SHIFT_PORT4_RXBCN_TBTT_INTERVAL 0
#define BIT_MASK_PORT4_RXBCN_TBTT_INTERVAL 0xff
#define BIT_PORT4_RXBCN_TBTT_INTERVAL(x) \
(((x) & BIT_MASK_PORT4_RXBCN_TBTT_INTERVAL) \
<< BIT_SHIFT_PORT4_RXBCN_TBTT_INTERVAL)
#define BITS_PORT4_RXBCN_TBTT_INTERVAL \
(BIT_MASK_PORT4_RXBCN_TBTT_INTERVAL \
<< BIT_SHIFT_PORT4_RXBCN_TBTT_INTERVAL)
#define BIT_CLEAR_PORT4_RXBCN_TBTT_INTERVAL(x) \
((x) & (~BITS_PORT4_RXBCN_TBTT_INTERVAL))
#define BIT_GET_PORT4_RXBCN_TBTT_INTERVAL(x) \
(((x) >> BIT_SHIFT_PORT4_RXBCN_TBTT_INTERVAL) & \
BIT_MASK_PORT4_RXBCN_TBTT_INTERVAL)
#define BIT_SET_PORT4_RXBCN_TBTT_INTERVAL(x, v) \
(BIT_CLEAR_PORT4_RXBCN_TBTT_INTERVAL(x) | \
BIT_PORT4_RXBCN_TBTT_INTERVAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RX_BCN_TBTT_ITVL1 (Offset 0x1164) */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT3(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT3 \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3 \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT3))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT3(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT3(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT3(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_FWIMR1 (Offset 0x1168) */
#define BIT_FS_ATIM_MB15_INT_EN BIT(31)
#define BIT_FS_ATIM_MB14_INT_EN BIT(30)
#define BIT_FS_ATIM_MB13_INT_EN BIT(29)
#define BIT_FS_ATIM_MB12_INT_EN BIT(28)
#define BIT_FS_ATIM_MB11_INT_EN BIT(27)
#define BIT_FS_ATIM_MB10_INT_EN BIT(26)
#define BIT_FS_ATIM_MB9_INT_EN BIT(25)
#define BIT_FS_ATIM_MB8_INT_EN BIT(24)
#define BIT_FS_TXBCNERR_MB15_INT_EN BIT(23)
#define BIT_FS_TXBCNERR_MB14_INT_EN BIT(22)
#define BIT_FS_TXBCNERR_MB13_INT_EN BIT(21)
#define BIT_FS_TXBCNERR_MB12_INT_EN BIT(20)
#define BIT_FS_TXBCNERR_MB11_INT_EN BIT(19)
#define BIT_FS_TXBCNERR_MB10_INT_EN BIT(18)
#define BIT_FS_TXBCNERR_MB9_INT_EN BIT(17)
#define BIT_FS_TXBCNERR_MB8_INT_EN BIT(16)
#define BIT_FS_TXBCNOK_MB15_INT_EN BIT(15)
#define BIT_FS_TXBCNOK_MB14_INT_EN BIT(14)
#define BIT_FS_TXBCNOK_MB13_INT_EN BIT(13)
#define BIT_FS_TXBCNOK_MB12_INT_EN BIT(12)
#define BIT_FS_TXBCNOK_MB11_INT_EN BIT(11)
#define BIT_FS_TXBCNOK_MB10_INT_EN BIT(10)
#define BIT_FS_TXBCNOK_MB9_INT_EN BIT(9)
#define BIT_FS_TXBCNOK_MB8_INT_EN BIT(8)
#define BIT_FS_BCNERLY0_MB15INT_EN BIT(7)
#define BIT_FS_BCNERLY0_MB14INT_EN BIT(6)
#define BIT_FS_BCNERLY0_MB13INT_EN BIT(5)
#define BIT_FS_BCNERLY0_MB12INT_EN BIT(4)
#define BIT_FS_BCNERLY0_MB11INT_EN BIT(3)
#define BIT_FS_BCNERLY0_MB10INT_EN BIT(2)
#define BIT_FS_BCNERLY0_MB9INT_EN BIT(1)
#define BIT_FS_BCNERLY0_MB8INT_EN BIT(0)
/* 2 REG_FWISR1 (Offset 0x116C) */
#define BIT_FS_ATIM_MB15_INT BIT(31)
#define BIT_FS_ATIM_MB14_INT BIT(30)
#define BIT_FS_ATIM_MB13_INT BIT(29)
#define BIT_FS_ATIM_MB12_INT BIT(28)
#define BIT_FS_ATIM_MB11_INT BIT(27)
#define BIT_FS_ATIM_MB10_INT BIT(26)
#define BIT_FS_ATIM_MB9_INT BIT(25)
#define BIT_FS_ATIM_MB8_INT BIT(24)
#define BIT_FS_TXBCNERR_MB15_INT BIT(23)
#define BIT_FS_TXBCNERR_MB14_INT BIT(22)
#define BIT_FS_TXBCNERR_MB13_INT BIT(21)
#define BIT_FS_TXBCNERR_MB12_INT BIT(20)
#define BIT_FS_TXBCNERR_MB11_INT BIT(19)
#define BIT_FS_TXBCNERR_MB10_INT BIT(18)
#define BIT_FS_TXBCNERR_MB9_INT BIT(17)
#define BIT_FS_TXBCNERR_MB8_INT BIT(16)
#define BIT_FS_TXBCNOK_MB15_INT BIT(15)
#define BIT_FS_TXBCNOK_MB14_INT BIT(14)
#define BIT_FS_TXBCNOK_MB13_INT BIT(13)
#define BIT_FS_TXBCNOK_MB12_INT BIT(12)
#define BIT_FS_TXBCNOK_MB11_INT BIT(11)
#define BIT_FS_TXBCNOK_MB10_INT BIT(10)
#define BIT_FS_TXBCNOK_MB9_INT BIT(9)
#define BIT_FS_TXBCNOK_MB8_INT BIT(8)
#define BIT_FS_BCNERLY0_MB15INT BIT(7)
#define BIT_FS_BCNERLY0_MB14INT BIT(6)
#define BIT_FS_BCNERLY0_MB13INT BIT(5)
#define BIT_FS_BCNERLY0_MB12INT BIT(4)
#define BIT_FS_BCNERLY0_MB11INT BIT(3)
#define BIT_FS_BCNERLY0_MB10INT BIT(2)
#define BIT_FS_BCNERLY0_MB9INT BIT(1)
#define BIT_FS_BCNERLY0_MB8INT BIT(0)
/* 2 REG_FWIMR2 (Offset 0x1170) */
#define BIT_FS_BCNDMA0_MB15_INT_EN BIT(15)
#define BIT_FS_BCNDMA0_MB14_INT_EN BIT(14)
#define BIT_FS_BCNDMA0_MB13_INT_EN BIT(13)
#define BIT_FS_BCNDMA0_MB12_INT_EN BIT(12)
#define BIT_FS_BCNDMA0_MB11_INT_EN BIT(11)
#define BIT_FS_BCNDMA0_MB10_INT_EN BIT(10)
#define BIT_FS_BCNDMA0_MB9_INT_EN BIT(9)
#define BIT_FS_BCNDMA0_MB8_INT_EN BIT(8)
#define BIT_FS_TBTT0_MB15INT_EN BIT(7)
#define BIT_FS_TBTT0_MB14INT_EN BIT(6)
#define BIT_FS_TBTT0_MB13INT_EN BIT(5)
#define BIT_FS_TBTT0_MB12INT_EN BIT(4)
#define BIT_FS_TBTT0_MB11INT_EN BIT(3)
#define BIT_FS_TBTT0_MB10INT_EN BIT(2)
#define BIT_FS_TBTT0_MB9INT_EN BIT(1)
#define BIT_FS_TBTT0_MB8INT_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_IO_WRAP_ERR_FLAG (Offset 0x1170) */
#define BIT_IO_WRAP_ERR BIT(0)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_FWISR2 (Offset 0x1174) */
#define BIT_FS_BCNDMA0_MB15_INT BIT(15)
#define BIT_FS_BCNDMA0_MB14_INT BIT(14)
#define BIT_FS_BCNDMA0_MB13_INT BIT(13)
#define BIT_FS_BCNDMA0_MB12_INT BIT(12)
#define BIT_FS_BCNDMA0_MB11_INT BIT(11)
#define BIT_FS_BCNDMA0_MB10_INT BIT(10)
#define BIT_FS_BCNDMA0_MB9_INT BIT(9)
#define BIT_FS_BCNDMA0_MB8_INT BIT(8)
#define BIT_FS_TBTT0_MB15INT BIT(7)
#define BIT_FS_TBTT0_MB14INT BIT(6)
#define BIT_FS_TBTT0_MB13INT BIT(5)
#define BIT_FS_TBTT0_MB12INT BIT(4)
#define BIT_FS_TBTT0_MB11INT BIT(3)
#define BIT_FS_TBTT0_MB10INT BIT(2)
#define BIT_FS_TBTT0_MB9INT BIT(1)
#define BIT_FS_TBTT0_MB8INT BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWISR3 (Offset 0x117C) */
#define BIT_FS_TXBCNOK_PORT4_INT BIT(11)
#define BIT_FS_TXBCNOK_PORT3_INT BIT(10)
#define BIT_FS_TXBCNOK_PORT2_INT BIT(9)
#define BIT_FS_TXBCNOK_PORT1_INT BIT(8)
#define BIT_FS_TXBCNERR_PORT4_INT BIT(7)
#define BIT_FS_TXBCNERR_PORT3_INT BIT(6)
#define BIT_FS_TXBCNERR_PORT2_INT BIT(5)
#define BIT_FS_TXBCNERR_PORT1_INT BIT(4)
#define BIT_FS_ATIM_PORT4_INT BIT(3)
#define BIT_FS_ATIM_PORT3_INT BIT(2)
#define BIT_FS_ATIM_PORT2_INT BIT(1)
#define BIT_FS_ATIM_PORT1_INT BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_SPEED_SENSOR (Offset 0x1180) */
#define BIT_DSS_1_RST_N BIT(31)
#define BIT_DSS_1_SPEED_EN BIT(30)
#define BIT_DSS_1_WIRE_SEL BIT(29)
#define BIT_DSS_ENCLK BIT(28)
#define BIT_SHIFT_DSS_1_RO_SEL 24
#define BIT_MASK_DSS_1_RO_SEL 0x7
#define BIT_DSS_1_RO_SEL(x) \
(((x) & BIT_MASK_DSS_1_RO_SEL) << BIT_SHIFT_DSS_1_RO_SEL)
#define BITS_DSS_1_RO_SEL (BIT_MASK_DSS_1_RO_SEL << BIT_SHIFT_DSS_1_RO_SEL)
#define BIT_CLEAR_DSS_1_RO_SEL(x) ((x) & (~BITS_DSS_1_RO_SEL))
#define BIT_GET_DSS_1_RO_SEL(x) \
(((x) >> BIT_SHIFT_DSS_1_RO_SEL) & BIT_MASK_DSS_1_RO_SEL)
#define BIT_SET_DSS_1_RO_SEL(x, v) \
(BIT_CLEAR_DSS_1_RO_SEL(x) | BIT_DSS_1_RO_SEL(v))
#define BIT_SHIFT_DSS_1_DATA_IN 0
#define BIT_MASK_DSS_1_DATA_IN 0xfffff
#define BIT_DSS_1_DATA_IN(x) \
(((x) & BIT_MASK_DSS_1_DATA_IN) << BIT_SHIFT_DSS_1_DATA_IN)
#define BITS_DSS_1_DATA_IN (BIT_MASK_DSS_1_DATA_IN << BIT_SHIFT_DSS_1_DATA_IN)
#define BIT_CLEAR_DSS_1_DATA_IN(x) ((x) & (~BITS_DSS_1_DATA_IN))
#define BIT_GET_DSS_1_DATA_IN(x) \
(((x) >> BIT_SHIFT_DSS_1_DATA_IN) & BIT_MASK_DSS_1_DATA_IN)
#define BIT_SET_DSS_1_DATA_IN(x, v) \
(BIT_CLEAR_DSS_1_DATA_IN(x) | BIT_DSS_1_DATA_IN(v))
/* 2 REG_SPEED_SENSOR1 (Offset 0x1184) */
#define BIT_DSS_1_READY BIT(31)
#define BIT_DSS_1_WSORT_GO BIT(30)
#define BIT_SHIFT_DSS_1_COUNT_OUT 0
#define BIT_MASK_DSS_1_COUNT_OUT 0xfffff
#define BIT_DSS_1_COUNT_OUT(x) \
(((x) & BIT_MASK_DSS_1_COUNT_OUT) << BIT_SHIFT_DSS_1_COUNT_OUT)
#define BITS_DSS_1_COUNT_OUT \
(BIT_MASK_DSS_1_COUNT_OUT << BIT_SHIFT_DSS_1_COUNT_OUT)
#define BIT_CLEAR_DSS_1_COUNT_OUT(x) ((x) & (~BITS_DSS_1_COUNT_OUT))
#define BIT_GET_DSS_1_COUNT_OUT(x) \
(((x) >> BIT_SHIFT_DSS_1_COUNT_OUT) & BIT_MASK_DSS_1_COUNT_OUT)
#define BIT_SET_DSS_1_COUNT_OUT(x, v) \
(BIT_CLEAR_DSS_1_COUNT_OUT(x) | BIT_DSS_1_COUNT_OUT(v))
/* 2 REG_SPEED_SENSOR2 (Offset 0x1188) */
#define BIT_DSS_2_RST_N BIT(31)
#define BIT_DSS_2_SPEED_EN BIT(30)
#define BIT_DSS_2_WIRE_SEL BIT(29)
#define BIT_SHIFT_DSS_2_RO_SEL 24
#define BIT_MASK_DSS_2_RO_SEL 0x7
#define BIT_DSS_2_RO_SEL(x) \
(((x) & BIT_MASK_DSS_2_RO_SEL) << BIT_SHIFT_DSS_2_RO_SEL)
#define BITS_DSS_2_RO_SEL (BIT_MASK_DSS_2_RO_SEL << BIT_SHIFT_DSS_2_RO_SEL)
#define BIT_CLEAR_DSS_2_RO_SEL(x) ((x) & (~BITS_DSS_2_RO_SEL))
#define BIT_GET_DSS_2_RO_SEL(x) \
(((x) >> BIT_SHIFT_DSS_2_RO_SEL) & BIT_MASK_DSS_2_RO_SEL)
#define BIT_SET_DSS_2_RO_SEL(x, v) \
(BIT_CLEAR_DSS_2_RO_SEL(x) | BIT_DSS_2_RO_SEL(v))
#define BIT_SHIFT_DSS_2_DATA_IN 0
#define BIT_MASK_DSS_2_DATA_IN 0xfffff
#define BIT_DSS_2_DATA_IN(x) \
(((x) & BIT_MASK_DSS_2_DATA_IN) << BIT_SHIFT_DSS_2_DATA_IN)
#define BITS_DSS_2_DATA_IN (BIT_MASK_DSS_2_DATA_IN << BIT_SHIFT_DSS_2_DATA_IN)
#define BIT_CLEAR_DSS_2_DATA_IN(x) ((x) & (~BITS_DSS_2_DATA_IN))
#define BIT_GET_DSS_2_DATA_IN(x) \
(((x) >> BIT_SHIFT_DSS_2_DATA_IN) & BIT_MASK_DSS_2_DATA_IN)
#define BIT_SET_DSS_2_DATA_IN(x, v) \
(BIT_CLEAR_DSS_2_DATA_IN(x) | BIT_DSS_2_DATA_IN(v))
/* 2 REG_SPEED_SENSOR3 (Offset 0x118C) */
#define BIT_DSS_2_READY BIT(31)
#define BIT_DSS_2_WSORT_GO BIT(30)
#define BIT_SHIFT_DSS_2_COUNT_OUT 0
#define BIT_MASK_DSS_2_COUNT_OUT 0xfffff
#define BIT_DSS_2_COUNT_OUT(x) \
(((x) & BIT_MASK_DSS_2_COUNT_OUT) << BIT_SHIFT_DSS_2_COUNT_OUT)
#define BITS_DSS_2_COUNT_OUT \
(BIT_MASK_DSS_2_COUNT_OUT << BIT_SHIFT_DSS_2_COUNT_OUT)
#define BIT_CLEAR_DSS_2_COUNT_OUT(x) ((x) & (~BITS_DSS_2_COUNT_OUT))
#define BIT_GET_DSS_2_COUNT_OUT(x) \
(((x) >> BIT_SHIFT_DSS_2_COUNT_OUT) & BIT_MASK_DSS_2_COUNT_OUT)
#define BIT_SET_DSS_2_COUNT_OUT(x, v) \
(BIT_CLEAR_DSS_2_COUNT_OUT(x) | BIT_DSS_2_COUNT_OUT(v))
/* 2 REG_SPEED_SENSOR4 (Offset 0x1190) */
#define BIT_DSS_3_RST_N BIT(31)
#define BIT_DSS_3_SPEED_EN BIT(30)
#define BIT_DSS_3_WIRE_SEL BIT(29)
#define BIT_SHIFT_DSS_3_RO_SEL 24
#define BIT_MASK_DSS_3_RO_SEL 0x7
#define BIT_DSS_3_RO_SEL(x) \
(((x) & BIT_MASK_DSS_3_RO_SEL) << BIT_SHIFT_DSS_3_RO_SEL)
#define BITS_DSS_3_RO_SEL (BIT_MASK_DSS_3_RO_SEL << BIT_SHIFT_DSS_3_RO_SEL)
#define BIT_CLEAR_DSS_3_RO_SEL(x) ((x) & (~BITS_DSS_3_RO_SEL))
#define BIT_GET_DSS_3_RO_SEL(x) \
(((x) >> BIT_SHIFT_DSS_3_RO_SEL) & BIT_MASK_DSS_3_RO_SEL)
#define BIT_SET_DSS_3_RO_SEL(x, v) \
(BIT_CLEAR_DSS_3_RO_SEL(x) | BIT_DSS_3_RO_SEL(v))
#define BIT_SHIFT_DSS_3_DATA_IN 0
#define BIT_MASK_DSS_3_DATA_IN 0xfffff
#define BIT_DSS_3_DATA_IN(x) \
(((x) & BIT_MASK_DSS_3_DATA_IN) << BIT_SHIFT_DSS_3_DATA_IN)
#define BITS_DSS_3_DATA_IN (BIT_MASK_DSS_3_DATA_IN << BIT_SHIFT_DSS_3_DATA_IN)
#define BIT_CLEAR_DSS_3_DATA_IN(x) ((x) & (~BITS_DSS_3_DATA_IN))
#define BIT_GET_DSS_3_DATA_IN(x) \
(((x) >> BIT_SHIFT_DSS_3_DATA_IN) & BIT_MASK_DSS_3_DATA_IN)
#define BIT_SET_DSS_3_DATA_IN(x, v) \
(BIT_CLEAR_DSS_3_DATA_IN(x) | BIT_DSS_3_DATA_IN(v))
/* 2 REG_SPEED_SENSOR5 (Offset 0x1194) */
#define BIT_DSS_3_READY BIT(31)
#define BIT_DSS_3_WSORT_GO BIT(30)
#define BIT_SHIFT_DSS_3_COUNT_OUT 0
#define BIT_MASK_DSS_3_COUNT_OUT 0xfffff
#define BIT_DSS_3_COUNT_OUT(x) \
(((x) & BIT_MASK_DSS_3_COUNT_OUT) << BIT_SHIFT_DSS_3_COUNT_OUT)
#define BITS_DSS_3_COUNT_OUT \
(BIT_MASK_DSS_3_COUNT_OUT << BIT_SHIFT_DSS_3_COUNT_OUT)
#define BIT_CLEAR_DSS_3_COUNT_OUT(x) ((x) & (~BITS_DSS_3_COUNT_OUT))
#define BIT_GET_DSS_3_COUNT_OUT(x) \
(((x) >> BIT_SHIFT_DSS_3_COUNT_OUT) & BIT_MASK_DSS_3_COUNT_OUT)
#define BIT_SET_DSS_3_COUNT_OUT(x, v) \
(BIT_CLEAR_DSS_3_COUNT_OUT(x) | BIT_DSS_3_COUNT_OUT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RXPKTBUF_1_MAX_ADDR (Offset 0x1198) */
#define BIT_SHIFT_RXPKTBUF_SIZE 30
#define BIT_MASK_RXPKTBUF_SIZE 0x3
#define BIT_RXPKTBUF_SIZE(x) \
(((x) & BIT_MASK_RXPKTBUF_SIZE) << BIT_SHIFT_RXPKTBUF_SIZE)
#define BITS_RXPKTBUF_SIZE (BIT_MASK_RXPKTBUF_SIZE << BIT_SHIFT_RXPKTBUF_SIZE)
#define BIT_CLEAR_RXPKTBUF_SIZE(x) ((x) & (~BITS_RXPKTBUF_SIZE))
#define BIT_GET_RXPKTBUF_SIZE(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_SIZE) & BIT_MASK_RXPKTBUF_SIZE)
#define BIT_SET_RXPKTBUF_SIZE(x, v) \
(BIT_CLEAR_RXPKTBUF_SIZE(x) | BIT_RXPKTBUF_SIZE(v))
#define BIT_RXPKTBUF_DBG_SEL BIT(29)
#define BIT_SHIFT_RXPKTBUF_1_MAX_ADDR 0
#define BIT_MASK_RXPKTBUF_1_MAX_ADDR 0x3ffff
#define BIT_RXPKTBUF_1_MAX_ADDR(x) \
(((x) & BIT_MASK_RXPKTBUF_1_MAX_ADDR) << BIT_SHIFT_RXPKTBUF_1_MAX_ADDR)
#define BITS_RXPKTBUF_1_MAX_ADDR \
(BIT_MASK_RXPKTBUF_1_MAX_ADDR << BIT_SHIFT_RXPKTBUF_1_MAX_ADDR)
#define BIT_CLEAR_RXPKTBUF_1_MAX_ADDR(x) ((x) & (~BITS_RXPKTBUF_1_MAX_ADDR))
#define BIT_GET_RXPKTBUF_1_MAX_ADDR(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_1_MAX_ADDR) & BIT_MASK_RXPKTBUF_1_MAX_ADDR)
#define BIT_SET_RXPKTBUF_1_MAX_ADDR(x, v) \
(BIT_CLEAR_RXPKTBUF_1_MAX_ADDR(x) | BIT_RXPKTBUF_1_MAX_ADDR(v))
/* 2 REG_RXFWBUF_1_MAX_ADDR (Offset 0x119C) */
#define BIT_SHIFT_RXFWBUF_1_MAX_ADDR 0
#define BIT_MASK_RXFWBUF_1_MAX_ADDR 0xffff
#define BIT_RXFWBUF_1_MAX_ADDR(x) \
(((x) & BIT_MASK_RXFWBUF_1_MAX_ADDR) << BIT_SHIFT_RXFWBUF_1_MAX_ADDR)
#define BITS_RXFWBUF_1_MAX_ADDR \
(BIT_MASK_RXFWBUF_1_MAX_ADDR << BIT_SHIFT_RXFWBUF_1_MAX_ADDR)
#define BIT_CLEAR_RXFWBUF_1_MAX_ADDR(x) ((x) & (~BITS_RXFWBUF_1_MAX_ADDR))
#define BIT_GET_RXFWBUF_1_MAX_ADDR(x) \
(((x) >> BIT_SHIFT_RXFWBUF_1_MAX_ADDR) & BIT_MASK_RXFWBUF_1_MAX_ADDR)
#define BIT_SET_RXFWBUF_1_MAX_ADDR(x, v) \
(BIT_CLEAR_RXFWBUF_1_MAX_ADDR(x) | BIT_RXFWBUF_1_MAX_ADDR(v))
/* 2 REG_RXPKTBUF_1_READ (Offset 0x11A4) */
#define BIT_SHIFT_RXPKTBUF_1_READ 0
#define BIT_MASK_RXPKTBUF_1_READ 0x3ffff
#define BIT_RXPKTBUF_1_READ(x) \
(((x) & BIT_MASK_RXPKTBUF_1_READ) << BIT_SHIFT_RXPKTBUF_1_READ)
#define BITS_RXPKTBUF_1_READ \
(BIT_MASK_RXPKTBUF_1_READ << BIT_SHIFT_RXPKTBUF_1_READ)
#define BIT_CLEAR_RXPKTBUF_1_READ(x) ((x) & (~BITS_RXPKTBUF_1_READ))
#define BIT_GET_RXPKTBUF_1_READ(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_1_READ) & BIT_MASK_RXPKTBUF_1_READ)
#define BIT_SET_RXPKTBUF_1_READ(x, v) \
(BIT_CLEAR_RXPKTBUF_1_READ(x) | BIT_RXPKTBUF_1_READ(v))
/* 2 REG_RXPKTBUF_1_WRITE (Offset 0x11A8) */
#define BIT_SHIFT_R_OQT_DBG_SEL 16
#define BIT_MASK_R_OQT_DBG_SEL 0xff
#define BIT_R_OQT_DBG_SEL(x) \
(((x) & BIT_MASK_R_OQT_DBG_SEL) << BIT_SHIFT_R_OQT_DBG_SEL)
#define BITS_R_OQT_DBG_SEL (BIT_MASK_R_OQT_DBG_SEL << BIT_SHIFT_R_OQT_DBG_SEL)
#define BIT_CLEAR_R_OQT_DBG_SEL(x) ((x) & (~BITS_R_OQT_DBG_SEL))
#define BIT_GET_R_OQT_DBG_SEL(x) \
(((x) >> BIT_SHIFT_R_OQT_DBG_SEL) & BIT_MASK_R_OQT_DBG_SEL)
#define BIT_SET_R_OQT_DBG_SEL(x, v) \
(BIT_CLEAR_R_OQT_DBG_SEL(x) | BIT_R_OQT_DBG_SEL(v))
#define BIT_SHIFT_R_TXPKTBF_DBG_SEL 8
#define BIT_MASK_R_TXPKTBF_DBG_SEL 0x7
#define BIT_R_TXPKTBF_DBG_SEL(x) \
(((x) & BIT_MASK_R_TXPKTBF_DBG_SEL) << BIT_SHIFT_R_TXPKTBF_DBG_SEL)
#define BITS_R_TXPKTBF_DBG_SEL \
(BIT_MASK_R_TXPKTBF_DBG_SEL << BIT_SHIFT_R_TXPKTBF_DBG_SEL)
#define BIT_CLEAR_R_TXPKTBF_DBG_SEL(x) ((x) & (~BITS_R_TXPKTBF_DBG_SEL))
#define BIT_GET_R_TXPKTBF_DBG_SEL(x) \
(((x) >> BIT_SHIFT_R_TXPKTBF_DBG_SEL) & BIT_MASK_R_TXPKTBF_DBG_SEL)
#define BIT_SET_R_TXPKTBF_DBG_SEL(x, v) \
(BIT_CLEAR_R_TXPKTBF_DBG_SEL(x) | BIT_R_TXPKTBF_DBG_SEL(v))
#define BIT_SHIFT_R_RXPKT_DBG_SEL 6
#define BIT_MASK_R_RXPKT_DBG_SEL 0x3
#define BIT_R_RXPKT_DBG_SEL(x) \
(((x) & BIT_MASK_R_RXPKT_DBG_SEL) << BIT_SHIFT_R_RXPKT_DBG_SEL)
#define BITS_R_RXPKT_DBG_SEL \
(BIT_MASK_R_RXPKT_DBG_SEL << BIT_SHIFT_R_RXPKT_DBG_SEL)
#define BIT_CLEAR_R_RXPKT_DBG_SEL(x) ((x) & (~BITS_R_RXPKT_DBG_SEL))
#define BIT_GET_R_RXPKT_DBG_SEL(x) \
(((x) >> BIT_SHIFT_R_RXPKT_DBG_SEL) & BIT_MASK_R_RXPKT_DBG_SEL)
#define BIT_SET_R_RXPKT_DBG_SEL(x, v) \
(BIT_CLEAR_R_RXPKT_DBG_SEL(x) | BIT_R_RXPKT_DBG_SEL(v))
#define BIT_SHIFT_RXPKTBUF_1_WRITE 0
#define BIT_MASK_RXPKTBUF_1_WRITE 0x3ffff
#define BIT_RXPKTBUF_1_WRITE(x) \
(((x) & BIT_MASK_RXPKTBUF_1_WRITE) << BIT_SHIFT_RXPKTBUF_1_WRITE)
#define BITS_RXPKTBUF_1_WRITE \
(BIT_MASK_RXPKTBUF_1_WRITE << BIT_SHIFT_RXPKTBUF_1_WRITE)
#define BIT_CLEAR_RXPKTBUF_1_WRITE(x) ((x) & (~BITS_RXPKTBUF_1_WRITE))
#define BIT_GET_RXPKTBUF_1_WRITE(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_1_WRITE) & BIT_MASK_RXPKTBUF_1_WRITE)
#define BIT_SET_RXPKTBUF_1_WRITE(x, v) \
(BIT_CLEAR_RXPKTBUF_1_WRITE(x) | BIT_RXPKTBUF_1_WRITE(v))
#define BIT_SHIFT_R_RXPKTBF_DBG_SEL 0
#define BIT_MASK_R_RXPKTBF_DBG_SEL 0x3
#define BIT_R_RXPKTBF_DBG_SEL(x) \
(((x) & BIT_MASK_R_RXPKTBF_DBG_SEL) << BIT_SHIFT_R_RXPKTBF_DBG_SEL)
#define BITS_R_RXPKTBF_DBG_SEL \
(BIT_MASK_R_RXPKTBF_DBG_SEL << BIT_SHIFT_R_RXPKTBF_DBG_SEL)
#define BIT_CLEAR_R_RXPKTBF_DBG_SEL(x) ((x) & (~BITS_R_RXPKTBF_DBG_SEL))
#define BIT_GET_R_RXPKTBF_DBG_SEL(x) \
(((x) >> BIT_SHIFT_R_RXPKTBF_DBG_SEL) & BIT_MASK_R_RXPKTBF_DBG_SEL)
#define BIT_SET_R_RXPKTBF_DBG_SEL(x, v) \
(BIT_CLEAR_R_RXPKTBF_DBG_SEL(x) | BIT_R_RXPKTBF_DBG_SEL(v))
/* 2 REG_RFE_CTRL_PAD_E2 (Offset 0x11B0) */
#define BIT_RFE_CTRL_ANTSW_E2 BIT(16)
#define BIT_RFE_CTRL_PIN15_E2 BIT(15)
#define BIT_RFE_CTRL_PIN14_E2 BIT(14)
#define BIT_RFE_CTRL_PIN13_E2 BIT(13)
#define BIT_RFE_CTRL_PIN12_E2 BIT(12)
#define BIT_RFE_CTRL_PIN11_E2 BIT(11)
#define BIT_RFE_CTRL_PIN10_E2 BIT(10)
#define BIT_RFE_CTRL_PIN9_E2 BIT(9)
#define BIT_RFE_CTRL_PIN8_E2 BIT(8)
#define BIT_RFE_CTRL_PIN7_E2 BIT(7)
#define BIT_RFE_CTRL_PIN6_E2 BIT(6)
#define BIT_RFE_CTRL_PIN5_E2 BIT(5)
#define BIT_RFE_CTRL_PIN4_E2 BIT(4)
#define BIT_RFE_CTRL_PIN3_E2 BIT(3)
#define BIT_RFE_CTRL_PIN2_E2 BIT(2)
#define BIT_RFE_CTRL_PIN1_E2 BIT(1)
#define BIT_RFE_CTRL_PIN0_E2 BIT(0)
/* 2 REG_RFE_CTRL_PAD_SR (Offset 0x11B4) */
#define BIT_RFE_CTRL_ANTSW_SR BIT(16)
#define BIT_RFE_CTRL_PIN15_SR BIT(15)
#define BIT_RFE_CTRL_PIN14_SR BIT(14)
#define BIT_RFE_CTRL_PIN13_SR BIT(13)
#define BIT_RFE_CTRL_PIN12_SR BIT(12)
#define BIT_RFE_CTRL_PIN11_SR BIT(11)
#define BIT_RFE_CTRL_PIN10_SR BIT(10)
#define BIT_RFE_CTRL_PIN9_SR BIT(9)
#define BIT_RFE_CTRL_PIN8_SR BIT(8)
#define BIT_RFE_CTRL_PIN7_SR BIT(7)
#define BIT_RFE_CTRL_PIN6_SR BIT(6)
#define BIT_RFE_CTRL_PIN5_SR BIT(5)
#define BIT_RFE_CTRL_PIN4_SR BIT(4)
#define BIT_RFE_CTRL_PIN3_SR BIT(3)
#define BIT_RFE_CTRL_PIN2_SR BIT(2)
#define BIT_RFE_CTRL_PIN1_SR BIT(1)
#define BIT_RFE_CTRL_PIN0_SR BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_EXT_QUEUE_REG (Offset 0x11C0) */
#define BIT_SHIFT_PCIE_PRIORITY_SEL 0
#define BIT_MASK_PCIE_PRIORITY_SEL 0x3
#define BIT_PCIE_PRIORITY_SEL(x) \
(((x) & BIT_MASK_PCIE_PRIORITY_SEL) << BIT_SHIFT_PCIE_PRIORITY_SEL)
#define BITS_PCIE_PRIORITY_SEL \
(BIT_MASK_PCIE_PRIORITY_SEL << BIT_SHIFT_PCIE_PRIORITY_SEL)
#define BIT_CLEAR_PCIE_PRIORITY_SEL(x) ((x) & (~BITS_PCIE_PRIORITY_SEL))
#define BIT_GET_PCIE_PRIORITY_SEL(x) \
(((x) >> BIT_SHIFT_PCIE_PRIORITY_SEL) & BIT_MASK_PCIE_PRIORITY_SEL)
#define BIT_SET_PCIE_PRIORITY_SEL(x, v) \
(BIT_CLEAR_PCIE_PRIORITY_SEL(x) | BIT_PCIE_PRIORITY_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_H2C_PRIORITY_SEL (Offset 0x11C0) */
#define BIT_SHIFT_H2C_PRIORITY_SEL 0
#define BIT_MASK_H2C_PRIORITY_SEL 0x3
#define BIT_H2C_PRIORITY_SEL(x) \
(((x) & BIT_MASK_H2C_PRIORITY_SEL) << BIT_SHIFT_H2C_PRIORITY_SEL)
#define BITS_H2C_PRIORITY_SEL \
(BIT_MASK_H2C_PRIORITY_SEL << BIT_SHIFT_H2C_PRIORITY_SEL)
#define BIT_CLEAR_H2C_PRIORITY_SEL(x) ((x) & (~BITS_H2C_PRIORITY_SEL))
#define BIT_GET_H2C_PRIORITY_SEL(x) \
(((x) >> BIT_SHIFT_H2C_PRIORITY_SEL) & BIT_MASK_H2C_PRIORITY_SEL)
#define BIT_SET_H2C_PRIORITY_SEL(x, v) \
(BIT_CLEAR_H2C_PRIORITY_SEL(x) | BIT_H2C_PRIORITY_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_CONTROL (Offset 0x11C4) */
#define BIT_EN_USB_CNT BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_CTRL (Offset 0x11C4) */
#define BIT_USB_COUNT_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_CONTROL (Offset 0x11C4) */
#define BIT_EN_PCIE_CNT BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_CTRL (Offset 0x11C4) */
#define BIT_PCIE_COUNT_EN BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_CONTROL (Offset 0x11C4) */
#define BIT_RQPN_CNT BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_CTRL (Offset 0x11C4) */
#define BIT_RQPN_COUNT_EN BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_CONTROL (Offset 0x11C4) */
#define BIT_RDE_CNT BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_CTRL (Offset 0x11C4) */
#define BIT_RDE_COUNT_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_CONTROL (Offset 0x11C4) */
#define BIT_TDE_CNT BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_CTRL (Offset 0x11C4) */
#define BIT_TDE_COUNT_EN BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_CONTROL (Offset 0x11C4) */
#define BIT_DIS_CNT BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_CTRL (Offset 0x11C4) */
#define BIT_DISABLE_COUNTER BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_TH (Offset 0x11C8) */
#define BIT_CNT_ALL_MACID BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_THRESHOLD (Offset 0x11C8) */
#define BIT_SEL_ALL_MACID BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_TH (Offset 0x11C8) */
#define BIT_SHIFT_CNT_MACID 24
#define BIT_MASK_CNT_MACID 0x7f
#define BIT_CNT_MACID(x) (((x) & BIT_MASK_CNT_MACID) << BIT_SHIFT_CNT_MACID)
#define BITS_CNT_MACID (BIT_MASK_CNT_MACID << BIT_SHIFT_CNT_MACID)
#define BIT_CLEAR_CNT_MACID(x) ((x) & (~BITS_CNT_MACID))
#define BIT_GET_CNT_MACID(x) (((x) >> BIT_SHIFT_CNT_MACID) & BIT_MASK_CNT_MACID)
#define BIT_SET_CNT_MACID(x, v) (BIT_CLEAR_CNT_MACID(x) | BIT_CNT_MACID(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_THRESHOLD (Offset 0x11C8) */
#define BIT_SHIFT_COUNTER_MACID 24
#define BIT_MASK_COUNTER_MACID 0x7f
#define BIT_COUNTER_MACID(x) \
(((x) & BIT_MASK_COUNTER_MACID) << BIT_SHIFT_COUNTER_MACID)
#define BITS_COUNTER_MACID (BIT_MASK_COUNTER_MACID << BIT_SHIFT_COUNTER_MACID)
#define BIT_CLEAR_COUNTER_MACID(x) ((x) & (~BITS_COUNTER_MACID))
#define BIT_GET_COUNTER_MACID(x) \
(((x) >> BIT_SHIFT_COUNTER_MACID) & BIT_MASK_COUNTER_MACID)
#define BIT_SET_COUNTER_MACID(x, v) \
(BIT_CLEAR_COUNTER_MACID(x) | BIT_COUNTER_MACID(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_SET (Offset 0x11CC) */
#define BIT_RTS_RST BIT(24)
#define BIT_PTCL_RST BIT(23)
#define BIT_SCH_RST BIT(22)
#define BIT_EDCA_RST BIT(21)
#define BIT_RQPN_RST BIT(20)
#define BIT_USB_RST BIT(19)
#define BIT_PCIE_RST BIT(18)
#define BIT_RXDMA_RST BIT(17)
#define BIT_TXDMA_RST BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_SET (Offset 0x11CC) */
#define BIT_SHIFT_REQUEST_RESET 16
#define BIT_MASK_REQUEST_RESET 0xffff
#define BIT_REQUEST_RESET(x) \
(((x) & BIT_MASK_REQUEST_RESET) << BIT_SHIFT_REQUEST_RESET)
#define BITS_REQUEST_RESET (BIT_MASK_REQUEST_RESET << BIT_SHIFT_REQUEST_RESET)
#define BIT_CLEAR_REQUEST_RESET(x) ((x) & (~BITS_REQUEST_RESET))
#define BIT_GET_REQUEST_RESET(x) \
(((x) >> BIT_SHIFT_REQUEST_RESET) & BIT_MASK_REQUEST_RESET)
#define BIT_SET_REQUEST_RESET(x, v) \
(BIT_CLEAR_REQUEST_RESET(x) | BIT_REQUEST_RESET(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_SET (Offset 0x11CC) */
#define BIT_EN_RTS_START BIT(8)
#define BIT_EN_PTCL_START BIT(7)
#define BIT_EN_SCH_START BIT(6)
#define BIT_EN_EDCA_START BIT(5)
#define BIT_EN_RQPN_START BIT(4)
#define BIT_EN_USB_START BIT(3)
#define BIT_EN_PCIE_START BIT(2)
#define BIT_EN_RXDMA_START BIT(1)
#define BIT_EN_TXDMA_START BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_SET (Offset 0x11CC) */
#define BIT_SHIFT_REQUEST_START 0
#define BIT_MASK_REQUEST_START 0xffff
#define BIT_REQUEST_START(x) \
(((x) & BIT_MASK_REQUEST_START) << BIT_SHIFT_REQUEST_START)
#define BITS_REQUEST_START (BIT_MASK_REQUEST_START << BIT_SHIFT_REQUEST_START)
#define BIT_CLEAR_REQUEST_START(x) ((x) & (~BITS_REQUEST_START))
#define BIT_GET_REQUEST_START(x) \
(((x) >> BIT_SHIFT_REQUEST_START) & BIT_MASK_REQUEST_START)
#define BIT_SET_REQUEST_START(x, v) \
(BIT_CLEAR_REQUEST_START(x) | BIT_REQUEST_START(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_COUNTER_OVERFLOW (Offset 0x11D0) */
#define BIT_RTS_OVF BIT(8)
#define BIT_PTCL_OVF BIT(7)
#define BIT_SCH_OVF BIT(6)
#define BIT_EDCA_OVF BIT(5)
#define BIT_RQPN_OVF BIT(4)
#define BIT_USB_OVF BIT(3)
#define BIT_PCIE_OVF BIT(2)
#define BIT_RXDMA_OVF BIT(1)
#define BIT_TXDMA_OVF BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_COUNTER_OVERFLOW (Offset 0x11D0) */
#define BIT_SHIFT_CNT_OVF_REG 0
#define BIT_MASK_CNT_OVF_REG 0xffff
#define BIT_CNT_OVF_REG(x) \
(((x) & BIT_MASK_CNT_OVF_REG) << BIT_SHIFT_CNT_OVF_REG)
#define BITS_CNT_OVF_REG (BIT_MASK_CNT_OVF_REG << BIT_SHIFT_CNT_OVF_REG)
#define BIT_CLEAR_CNT_OVF_REG(x) ((x) & (~BITS_CNT_OVF_REG))
#define BIT_GET_CNT_OVF_REG(x) \
(((x) >> BIT_SHIFT_CNT_OVF_REG) & BIT_MASK_CNT_OVF_REG)
#define BIT_SET_CNT_OVF_REG(x, v) \
(BIT_CLEAR_CNT_OVF_REG(x) | BIT_CNT_OVF_REG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_TDE_LEN_TH (Offset 0x11D4) */
#define BIT_SHIFT_TXDMA_LEN_TH0 16
#define BIT_MASK_TXDMA_LEN_TH0 0xffff
#define BIT_TXDMA_LEN_TH0(x) \
(((x) & BIT_MASK_TXDMA_LEN_TH0) << BIT_SHIFT_TXDMA_LEN_TH0)
#define BITS_TXDMA_LEN_TH0 (BIT_MASK_TXDMA_LEN_TH0 << BIT_SHIFT_TXDMA_LEN_TH0)
#define BIT_CLEAR_TXDMA_LEN_TH0(x) ((x) & (~BITS_TXDMA_LEN_TH0))
#define BIT_GET_TXDMA_LEN_TH0(x) \
(((x) >> BIT_SHIFT_TXDMA_LEN_TH0) & BIT_MASK_TXDMA_LEN_TH0)
#define BIT_SET_TXDMA_LEN_TH0(x, v) \
(BIT_CLEAR_TXDMA_LEN_TH0(x) | BIT_TXDMA_LEN_TH0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_LEN_THRESHOLD (Offset 0x11D4) */
#define BIT_SHIFT_TDE_LEN_TH1 16
#define BIT_MASK_TDE_LEN_TH1 0xffff
#define BIT_TDE_LEN_TH1(x) \
(((x) & BIT_MASK_TDE_LEN_TH1) << BIT_SHIFT_TDE_LEN_TH1)
#define BITS_TDE_LEN_TH1 (BIT_MASK_TDE_LEN_TH1 << BIT_SHIFT_TDE_LEN_TH1)
#define BIT_CLEAR_TDE_LEN_TH1(x) ((x) & (~BITS_TDE_LEN_TH1))
#define BIT_GET_TDE_LEN_TH1(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH1) & BIT_MASK_TDE_LEN_TH1)
#define BIT_SET_TDE_LEN_TH1(x, v) \
(BIT_CLEAR_TDE_LEN_TH1(x) | BIT_TDE_LEN_TH1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_TDE_LEN_TH (Offset 0x11D4) */
#define BIT_SHIFT_TXDMA_LEN_TH1 0
#define BIT_MASK_TXDMA_LEN_TH1 0xffff
#define BIT_TXDMA_LEN_TH1(x) \
(((x) & BIT_MASK_TXDMA_LEN_TH1) << BIT_SHIFT_TXDMA_LEN_TH1)
#define BITS_TXDMA_LEN_TH1 (BIT_MASK_TXDMA_LEN_TH1 << BIT_SHIFT_TXDMA_LEN_TH1)
#define BIT_CLEAR_TXDMA_LEN_TH1(x) ((x) & (~BITS_TXDMA_LEN_TH1))
#define BIT_GET_TXDMA_LEN_TH1(x) \
(((x) >> BIT_SHIFT_TXDMA_LEN_TH1) & BIT_MASK_TXDMA_LEN_TH1)
#define BIT_SET_TXDMA_LEN_TH1(x, v) \
(BIT_CLEAR_TXDMA_LEN_TH1(x) | BIT_TXDMA_LEN_TH1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_TXDMA_LEN_THRESHOLD (Offset 0x11D4) */
#define BIT_SHIFT_TDE_LEN_TH0 0
#define BIT_MASK_TDE_LEN_TH0 0xffff
#define BIT_TDE_LEN_TH0(x) \
(((x) & BIT_MASK_TDE_LEN_TH0) << BIT_SHIFT_TDE_LEN_TH0)
#define BITS_TDE_LEN_TH0 (BIT_MASK_TDE_LEN_TH0 << BIT_SHIFT_TDE_LEN_TH0)
#define BIT_CLEAR_TDE_LEN_TH0(x) ((x) & (~BITS_TDE_LEN_TH0))
#define BIT_GET_TDE_LEN_TH0(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH0) & BIT_MASK_TDE_LEN_TH0)
#define BIT_SET_TDE_LEN_TH0(x, v) \
(BIT_CLEAR_TDE_LEN_TH0(x) | BIT_TDE_LEN_TH0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_RDE_LEN_TH (Offset 0x11D8) */
#define BIT_SHIFT_RXDMA_LEN_TH0 16
#define BIT_MASK_RXDMA_LEN_TH0 0xffff
#define BIT_RXDMA_LEN_TH0(x) \
(((x) & BIT_MASK_RXDMA_LEN_TH0) << BIT_SHIFT_RXDMA_LEN_TH0)
#define BITS_RXDMA_LEN_TH0 (BIT_MASK_RXDMA_LEN_TH0 << BIT_SHIFT_RXDMA_LEN_TH0)
#define BIT_CLEAR_RXDMA_LEN_TH0(x) ((x) & (~BITS_RXDMA_LEN_TH0))
#define BIT_GET_RXDMA_LEN_TH0(x) \
(((x) >> BIT_SHIFT_RXDMA_LEN_TH0) & BIT_MASK_RXDMA_LEN_TH0)
#define BIT_SET_RXDMA_LEN_TH0(x, v) \
(BIT_CLEAR_RXDMA_LEN_TH0(x) | BIT_RXDMA_LEN_TH0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_LEN_THRESHOLD (Offset 0x11D8) */
#define BIT_SHIFT_RDE_LEN_TH1 16
#define BIT_MASK_RDE_LEN_TH1 0xffff
#define BIT_RDE_LEN_TH1(x) \
(((x) & BIT_MASK_RDE_LEN_TH1) << BIT_SHIFT_RDE_LEN_TH1)
#define BITS_RDE_LEN_TH1 (BIT_MASK_RDE_LEN_TH1 << BIT_SHIFT_RDE_LEN_TH1)
#define BIT_CLEAR_RDE_LEN_TH1(x) ((x) & (~BITS_RDE_LEN_TH1))
#define BIT_GET_RDE_LEN_TH1(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH1) & BIT_MASK_RDE_LEN_TH1)
#define BIT_SET_RDE_LEN_TH1(x, v) \
(BIT_CLEAR_RDE_LEN_TH1(x) | BIT_RDE_LEN_TH1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_RDE_LEN_TH (Offset 0x11D8) */
#define BIT_SHIFT_RXDMA_LEN_TH1 0
#define BIT_MASK_RXDMA_LEN_TH1 0xffff
#define BIT_RXDMA_LEN_TH1(x) \
(((x) & BIT_MASK_RXDMA_LEN_TH1) << BIT_SHIFT_RXDMA_LEN_TH1)
#define BITS_RXDMA_LEN_TH1 (BIT_MASK_RXDMA_LEN_TH1 << BIT_SHIFT_RXDMA_LEN_TH1)
#define BIT_CLEAR_RXDMA_LEN_TH1(x) ((x) & (~BITS_RXDMA_LEN_TH1))
#define BIT_GET_RXDMA_LEN_TH1(x) \
(((x) >> BIT_SHIFT_RXDMA_LEN_TH1) & BIT_MASK_RXDMA_LEN_TH1)
#define BIT_SET_RXDMA_LEN_TH1(x, v) \
(BIT_CLEAR_RXDMA_LEN_TH1(x) | BIT_RXDMA_LEN_TH1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RXDMA_LEN_THRESHOLD (Offset 0x11D8) */
#define BIT_SHIFT_RDE_LEN_TH0 0
#define BIT_MASK_RDE_LEN_TH0 0xffff
#define BIT_RDE_LEN_TH0(x) \
(((x) & BIT_MASK_RDE_LEN_TH0) << BIT_SHIFT_RDE_LEN_TH0)
#define BITS_RDE_LEN_TH0 (BIT_MASK_RDE_LEN_TH0 << BIT_SHIFT_RDE_LEN_TH0)
#define BIT_CLEAR_RDE_LEN_TH0(x) ((x) & (~BITS_RDE_LEN_TH0))
#define BIT_GET_RDE_LEN_TH0(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH0) & BIT_MASK_RDE_LEN_TH0)
#define BIT_SET_RDE_LEN_TH0(x, v) \
(BIT_CLEAR_RDE_LEN_TH0(x) | BIT_RDE_LEN_TH0(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_PCIE_EXEC_TIME (Offset 0x11DC) */
#define BIT_SHIFT_COUNTER_INTERVAL_SEL 16
#define BIT_MASK_COUNTER_INTERVAL_SEL 0x3
#define BIT_COUNTER_INTERVAL_SEL(x) \
(((x) & BIT_MASK_COUNTER_INTERVAL_SEL) \
<< BIT_SHIFT_COUNTER_INTERVAL_SEL)
#define BITS_COUNTER_INTERVAL_SEL \
(BIT_MASK_COUNTER_INTERVAL_SEL << BIT_SHIFT_COUNTER_INTERVAL_SEL)
#define BIT_CLEAR_COUNTER_INTERVAL_SEL(x) ((x) & (~BITS_COUNTER_INTERVAL_SEL))
#define BIT_GET_COUNTER_INTERVAL_SEL(x) \
(((x) >> BIT_SHIFT_COUNTER_INTERVAL_SEL) & \
BIT_MASK_COUNTER_INTERVAL_SEL)
#define BIT_SET_COUNTER_INTERVAL_SEL(x, v) \
(BIT_CLEAR_COUNTER_INTERVAL_SEL(x) | BIT_COUNTER_INTERVAL_SEL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_EXEC_TIME_THRESHOLD (Offset 0x11DC) */
#define BIT_SHIFT_COUNT_INT_SEL 16
#define BIT_MASK_COUNT_INT_SEL 0x3
#define BIT_COUNT_INT_SEL(x) \
(((x) & BIT_MASK_COUNT_INT_SEL) << BIT_SHIFT_COUNT_INT_SEL)
#define BITS_COUNT_INT_SEL (BIT_MASK_COUNT_INT_SEL << BIT_SHIFT_COUNT_INT_SEL)
#define BIT_CLEAR_COUNT_INT_SEL(x) ((x) & (~BITS_COUNT_INT_SEL))
#define BIT_GET_COUNT_INT_SEL(x) \
(((x) >> BIT_SHIFT_COUNT_INT_SEL) & BIT_MASK_COUNT_INT_SEL)
#define BIT_SET_COUNT_INT_SEL(x, v) \
(BIT_CLEAR_COUNT_INT_SEL(x) | BIT_COUNT_INT_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
/* 2 REG_PCIE_EXEC_TIME (Offset 0x11DC) */
#define BIT_SHIFT_PCIE_TRANS_DATA_TH1 0
#define BIT_MASK_PCIE_TRANS_DATA_TH1 0xffff
#define BIT_PCIE_TRANS_DATA_TH1(x) \
(((x) & BIT_MASK_PCIE_TRANS_DATA_TH1) << BIT_SHIFT_PCIE_TRANS_DATA_TH1)
#define BITS_PCIE_TRANS_DATA_TH1 \
(BIT_MASK_PCIE_TRANS_DATA_TH1 << BIT_SHIFT_PCIE_TRANS_DATA_TH1)
#define BIT_CLEAR_PCIE_TRANS_DATA_TH1(x) ((x) & (~BITS_PCIE_TRANS_DATA_TH1))
#define BIT_GET_PCIE_TRANS_DATA_TH1(x) \
(((x) >> BIT_SHIFT_PCIE_TRANS_DATA_TH1) & BIT_MASK_PCIE_TRANS_DATA_TH1)
#define BIT_SET_PCIE_TRANS_DATA_TH1(x, v) \
(BIT_CLEAR_PCIE_TRANS_DATA_TH1(x) | BIT_PCIE_TRANS_DATA_TH1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_EXEC_TIME_THRESHOLD (Offset 0x11DC) */
#define BIT_SHIFT_EXEC_TIME_TH 0
#define BIT_MASK_EXEC_TIME_TH 0xffff
#define BIT_EXEC_TIME_TH(x) \
(((x) & BIT_MASK_EXEC_TIME_TH) << BIT_SHIFT_EXEC_TIME_TH)
#define BITS_EXEC_TIME_TH (BIT_MASK_EXEC_TIME_TH << BIT_SHIFT_EXEC_TIME_TH)
#define BIT_CLEAR_EXEC_TIME_TH(x) ((x) & (~BITS_EXEC_TIME_TH))
#define BIT_GET_EXEC_TIME_TH(x) \
(((x) >> BIT_SHIFT_EXEC_TIME_TH) & BIT_MASK_EXEC_TIME_TH)
#define BIT_SET_EXEC_TIME_TH(x, v) \
(BIT_CLEAR_EXEC_TIME_TH(x) | BIT_EXEC_TIME_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT4_RX_UCMD1_UAPSD0_OK_INT_EN BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI3_RX_UAPSDMD1_EN BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT4_RX_UCMD0_UAPSD0_OK_INT_EN BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI3_RX_UAPSDMD0_EN BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT4_TRIPKT_OK_INT_EN BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI3_TRIGGER_PKT_EN BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT4_RX_EOSP_OK_INT_EN BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI3_EOSP_INT_EN BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT3_RX_UCMD1_UAPSD0_OK_INT_EN BIT(27)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI2_RX_UAPSDMD1_EN BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT3_RX_UCMD0_UAPSD0_OK_INT_EN BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI2_RX_UAPSDMD0_EN BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT3_TRIPKT_OK_INT_EN BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI2_TRIGGER_PKT_EN BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT3_RX_EOSP_OK_INT_EN BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI2_EOSP_INT_EN BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT2_RX_UCMD1_UAPSD0_OK_INT_EN BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI1_RX_UAPSDMD1_EN BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT2_RX_UCMD0_UAPSD0_OK_INT_EN BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI1_RX_UAPSDMD0_EN BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT2_TRIPKT_OK_INT_EN BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI1_TRIGGER_PKT_EN BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT2_RX_EOSP_OK_INT_EN BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI1_EOSP_INT_EN BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT1_RX_UCMD1_UAPSD0_OK_INT_EN BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI0_RX_UAPSDMD1_EN BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT1_RX_UCMD0_UAPSD0_OK_INT_EN BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI0_RX_UAPSDMD0_EN BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT1_TRIPKT_OK_INT_EN BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI0_TRIGGER_PKT_EN BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT1_RX_EOSP_OK_INT_EN BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI0_EOSP_INT_EN BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_NOA2_TSFT_BIT32_TOGGLE_INT_EN BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_EN BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_NOA1_TSFT_BIT32_TOGGLE_INT_EN BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_EN BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT4_TX_NULL1_DONE_INT_EN BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI3_TX_NULL1_INT_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT4_TX_NULL0_DONE_INT_EN BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI3_TX_NULL0_INT_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT3_TX_NULL1_DONE_INT_EN BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI2_TX_NULL1_INT_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT3_TX_NULL0_DONE_INT_EN BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI2_TX_NULL0_INT_EN BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT2_TX_NULL1_DONE_INT_EN BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI1_TX_NULL1_INT_EN BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT2_TX_NULL0_DONE_INT_EN BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI1_TX_NULL0_INT_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT1_TX_NULL1_DONE_INT_EN BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI0_TX_NULL1_INT_EN BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_PORT1_TX_NULL0_DONE_INT_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2IMR (Offset 0x11E0) */
#define BIT_FS_CLI0_TX_NULL0_INT_EN BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT4_RX_UCMD1_UAPSD0_OK_INT BIT(31)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI3_RX_UAPSDMD1_INT BIT(31)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT4_RX_UCMD0_UAPSD0_OK_INT BIT(30)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI3_RX_UAPSDMD0_INT BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT4_TRIPKT_OK_INT BIT(29)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI3_TRIGGER_PKT_INT BIT(29)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT4_RX_EOSP_OK_INT BIT(28)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI3_EOSP_INT BIT(28)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT3_RX_UCMD1_UAPSD0_OK_INT BIT(27)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI2_RX_UAPSDMD1_INT BIT(27)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT3_RX_UCMD0_UAPSD0_OK_INT BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI2_RX_UAPSDMD0_INT BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT3_TRIPKT_OK_INT BIT(25)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI2_TRIGGER_PKT_INT BIT(25)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT3_RX_EOSP_OK_INT BIT(24)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI2_EOSP_INT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT2_RX_UCMD1_UAPSD0_OK_INT BIT(23)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI1_RX_UAPSDMD1_INT BIT(23)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT2_RX_UCMD0_UAPSD0_OK_INT BIT(22)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI1_RX_UAPSDMD0_INT BIT(22)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT2_TRIPKT_OK_INT BIT(21)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI1_TRIGGER_PKT_INT BIT(21)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT2_RX_EOSP_OK_INT BIT(20)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI1_EOSP_INT BIT(20)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT1_RX_UCMD1_UAPSD0_OK_INT BIT(19)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI0_RX_UAPSDMD1_INT BIT(19)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT1_RX_UCMD0_UAPSD0_OK_INT BIT(18)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI0_RX_UAPSDMD0_INT BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT1_TRIPKT_OK_INT BIT(17)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI0_TRIGGER_PKT_INT BIT(17)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT1_RX_EOSP_OK_INT BIT(16)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI0_EOSP_INT BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_NOA2_TSFT_BIT32_TOGGLE_INT BIT(9)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_INT BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_NOA1_TSFT_BIT32_TOGGLE_INT BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_INT BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT4_TX_NULL1_DONE_INT BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI3_TX_NULL1_INT BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT4_TX_NULL0_DONE_INT BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI3_TX_NULL0_INT BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT3_TX_NULL1_DONE_INT BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI2_TX_NULL1_INT BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT3_TX_NULL0_DONE_INT BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI2_TX_NULL0_INT BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT2_TX_NULL1_DONE_INT BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI1_TX_NULL1_INT BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT2_TX_NULL0_DONE_INT BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI1_TX_NULL0_INT BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT1_TX_NULL1_DONE_INT BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI0_TX_NULL1_INT BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_PORT1_TX_NULL0_DONE_INT BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FT2ISR (Offset 0x11E4) */
#define BIT_FS_CLI0_TX_NULL0_INT BIT(0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MSG2 (Offset 0x11F0) */
#define BIT_SHIFT_FW_MSG2 0
#define BIT_MASK_FW_MSG2 0xffffffffL
#define BIT_FW_MSG2(x) (((x) & BIT_MASK_FW_MSG2) << BIT_SHIFT_FW_MSG2)
#define BITS_FW_MSG2 (BIT_MASK_FW_MSG2 << BIT_SHIFT_FW_MSG2)
#define BIT_CLEAR_FW_MSG2(x) ((x) & (~BITS_FW_MSG2))
#define BIT_GET_FW_MSG2(x) (((x) >> BIT_SHIFT_FW_MSG2) & BIT_MASK_FW_MSG2)
#define BIT_SET_FW_MSG2(x, v) (BIT_CLEAR_FW_MSG2(x) | BIT_FW_MSG2(v))
/* 2 REG_MSG3 (Offset 0x11F4) */
#define BIT_SHIFT_FW_MSG3 0
#define BIT_MASK_FW_MSG3 0xffffffffL
#define BIT_FW_MSG3(x) (((x) & BIT_MASK_FW_MSG3) << BIT_SHIFT_FW_MSG3)
#define BITS_FW_MSG3 (BIT_MASK_FW_MSG3 << BIT_SHIFT_FW_MSG3)
#define BIT_CLEAR_FW_MSG3(x) ((x) & (~BITS_FW_MSG3))
#define BIT_GET_FW_MSG3(x) (((x) >> BIT_SHIFT_FW_MSG3) & BIT_MASK_FW_MSG3)
#define BIT_SET_FW_MSG3(x, v) (BIT_CLEAR_FW_MSG3(x) | BIT_FW_MSG3(v))
/* 2 REG_MSG4 (Offset 0x11F8) */
#define BIT_SHIFT_FW_MSG4 0
#define BIT_MASK_FW_MSG4 0xffffffffL
#define BIT_FW_MSG4(x) (((x) & BIT_MASK_FW_MSG4) << BIT_SHIFT_FW_MSG4)
#define BITS_FW_MSG4 (BIT_MASK_FW_MSG4 << BIT_SHIFT_FW_MSG4)
#define BIT_CLEAR_FW_MSG4(x) ((x) & (~BITS_FW_MSG4))
#define BIT_GET_FW_MSG4(x) (((x) >> BIT_SHIFT_FW_MSG4) & BIT_MASK_FW_MSG4)
#define BIT_SET_FW_MSG4(x, v) (BIT_CLEAR_FW_MSG4(x) | BIT_FW_MSG4(v))
/* 2 REG_MSG5 (Offset 0x11FC) */
#define BIT_SHIFT_FW_MSG5 0
#define BIT_MASK_FW_MSG5 0xffffffffL
#define BIT_FW_MSG5(x) (((x) & BIT_MASK_FW_MSG5) << BIT_SHIFT_FW_MSG5)
#define BITS_FW_MSG5 (BIT_MASK_FW_MSG5 << BIT_SHIFT_FW_MSG5)
#define BIT_CLEAR_FW_MSG5(x) ((x) & (~BITS_FW_MSG5))
#define BIT_GET_FW_MSG5(x) (((x) >> BIT_SHIFT_FW_MSG5) & BIT_MASK_FW_MSG5)
#define BIT_SET_FW_MSG5(x, v) (BIT_CLEAR_FW_MSG5(x) | BIT_FW_MSG5(v))
/* 2 REG_DDMA_CH0SA (Offset 0x1200) */
#define BIT_SHIFT_DDMACH0_SA 0
#define BIT_MASK_DDMACH0_SA 0xffffffffL
#define BIT_DDMACH0_SA(x) (((x) & BIT_MASK_DDMACH0_SA) << BIT_SHIFT_DDMACH0_SA)
#define BITS_DDMACH0_SA (BIT_MASK_DDMACH0_SA << BIT_SHIFT_DDMACH0_SA)
#define BIT_CLEAR_DDMACH0_SA(x) ((x) & (~BITS_DDMACH0_SA))
#define BIT_GET_DDMACH0_SA(x) \
(((x) >> BIT_SHIFT_DDMACH0_SA) & BIT_MASK_DDMACH0_SA)
#define BIT_SET_DDMACH0_SA(x, v) (BIT_CLEAR_DDMACH0_SA(x) | BIT_DDMACH0_SA(v))
/* 2 REG_DDMA_CH0DA (Offset 0x1204) */
#define BIT_SHIFT_DDMACH0_DA 0
#define BIT_MASK_DDMACH0_DA 0xffffffffL
#define BIT_DDMACH0_DA(x) (((x) & BIT_MASK_DDMACH0_DA) << BIT_SHIFT_DDMACH0_DA)
#define BITS_DDMACH0_DA (BIT_MASK_DDMACH0_DA << BIT_SHIFT_DDMACH0_DA)
#define BIT_CLEAR_DDMACH0_DA(x) ((x) & (~BITS_DDMACH0_DA))
#define BIT_GET_DDMACH0_DA(x) \
(((x) >> BIT_SHIFT_DDMACH0_DA) & BIT_MASK_DDMACH0_DA)
#define BIT_SET_DDMACH0_DA(x, v) (BIT_CLEAR_DDMACH0_DA(x) | BIT_DDMACH0_DA(v))
/* 2 REG_DDMA_CH0CTRL (Offset 0x1208) */
#define BIT_DDMACH0_OWN BIT(31)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH0CTRL (Offset 0x1208) */
#define BIT_DDMACH0_IDMEM_ERR BIT(30)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_DDMA_CH0CTRL (Offset 0x1208) */
#define BIT_DDMACH0_ERR_MON BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH0CTRL (Offset 0x1208) */
#define BIT_DDMACH0_CHKSUM_EN BIT(29)
#define BIT_DDMACH0_DA_W_DISABLE BIT(28)
#define BIT_DDMACH0_CHKSUM_STS BIT(27)
#define BIT_DDMACH0_DDMA_MODE BIT(26)
#define BIT_DDMACH0_RESET_CHKSUM_STS BIT(25)
#define BIT_DDMACH0_CHKSUM_CONT BIT(24)
#define BIT_SHIFT_DDMACH0_DLEN 0
#define BIT_MASK_DDMACH0_DLEN 0x3ffff
#define BIT_DDMACH0_DLEN(x) \
(((x) & BIT_MASK_DDMACH0_DLEN) << BIT_SHIFT_DDMACH0_DLEN)
#define BITS_DDMACH0_DLEN (BIT_MASK_DDMACH0_DLEN << BIT_SHIFT_DDMACH0_DLEN)
#define BIT_CLEAR_DDMACH0_DLEN(x) ((x) & (~BITS_DDMACH0_DLEN))
#define BIT_GET_DDMACH0_DLEN(x) \
(((x) >> BIT_SHIFT_DDMACH0_DLEN) & BIT_MASK_DDMACH0_DLEN)
#define BIT_SET_DDMACH0_DLEN(x, v) \
(BIT_CLEAR_DDMACH0_DLEN(x) | BIT_DDMACH0_DLEN(v))
/* 2 REG_DDMA_CH1SA (Offset 0x1210) */
#define BIT_SHIFT_DDMACH1_SA 0
#define BIT_MASK_DDMACH1_SA 0xffffffffL
#define BIT_DDMACH1_SA(x) (((x) & BIT_MASK_DDMACH1_SA) << BIT_SHIFT_DDMACH1_SA)
#define BITS_DDMACH1_SA (BIT_MASK_DDMACH1_SA << BIT_SHIFT_DDMACH1_SA)
#define BIT_CLEAR_DDMACH1_SA(x) ((x) & (~BITS_DDMACH1_SA))
#define BIT_GET_DDMACH1_SA(x) \
(((x) >> BIT_SHIFT_DDMACH1_SA) & BIT_MASK_DDMACH1_SA)
#define BIT_SET_DDMACH1_SA(x, v) (BIT_CLEAR_DDMACH1_SA(x) | BIT_DDMACH1_SA(v))
/* 2 REG_DDMA_CH1DA (Offset 0x1214) */
#define BIT_SHIFT_DDMACH1_DA 0
#define BIT_MASK_DDMACH1_DA 0xffffffffL
#define BIT_DDMACH1_DA(x) (((x) & BIT_MASK_DDMACH1_DA) << BIT_SHIFT_DDMACH1_DA)
#define BITS_DDMACH1_DA (BIT_MASK_DDMACH1_DA << BIT_SHIFT_DDMACH1_DA)
#define BIT_CLEAR_DDMACH1_DA(x) ((x) & (~BITS_DDMACH1_DA))
#define BIT_GET_DDMACH1_DA(x) \
(((x) >> BIT_SHIFT_DDMACH1_DA) & BIT_MASK_DDMACH1_DA)
#define BIT_SET_DDMACH1_DA(x, v) (BIT_CLEAR_DDMACH1_DA(x) | BIT_DDMACH1_DA(v))
/* 2 REG_DDMA_CH1CTRL (Offset 0x1218) */
#define BIT_DDMACH1_OWN BIT(31)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH1CTRL (Offset 0x1218) */
#define BIT_DDMACH1_IDMEM_ERR BIT(30)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_DDMA_CH1CTRL (Offset 0x1218) */
#define BIT_DDMACH1_ERR_MON BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH1CTRL (Offset 0x1218) */
#define BIT_DDMACH1_CHKSUM_EN BIT(29)
#define BIT_DDMACH1_DA_W_DISABLE BIT(28)
#define BIT_DDMACH1_CHKSUM_STS BIT(27)
#define BIT_DDMACH1_DDMA_MODE BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_DDMA_CH1CTRL (Offset 0x1218) */
#define BIT_DDMACH1_RESET_CHKSUM_STS BIT(25)
#define BIT_DDMACH1_CHKSUM_CONT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH1CTRL (Offset 0x1218) */
#define BIT_SHIFT_DDMACH1_DLEN 0
#define BIT_MASK_DDMACH1_DLEN 0x3ffff
#define BIT_DDMACH1_DLEN(x) \
(((x) & BIT_MASK_DDMACH1_DLEN) << BIT_SHIFT_DDMACH1_DLEN)
#define BITS_DDMACH1_DLEN (BIT_MASK_DDMACH1_DLEN << BIT_SHIFT_DDMACH1_DLEN)
#define BIT_CLEAR_DDMACH1_DLEN(x) ((x) & (~BITS_DDMACH1_DLEN))
#define BIT_GET_DDMACH1_DLEN(x) \
(((x) >> BIT_SHIFT_DDMACH1_DLEN) & BIT_MASK_DDMACH1_DLEN)
#define BIT_SET_DDMACH1_DLEN(x, v) \
(BIT_CLEAR_DDMACH1_DLEN(x) | BIT_DDMACH1_DLEN(v))
/* 2 REG_DDMA_CH2SA (Offset 0x1220) */
#define BIT_SHIFT_DDMACH2_SA 0
#define BIT_MASK_DDMACH2_SA 0xffffffffL
#define BIT_DDMACH2_SA(x) (((x) & BIT_MASK_DDMACH2_SA) << BIT_SHIFT_DDMACH2_SA)
#define BITS_DDMACH2_SA (BIT_MASK_DDMACH2_SA << BIT_SHIFT_DDMACH2_SA)
#define BIT_CLEAR_DDMACH2_SA(x) ((x) & (~BITS_DDMACH2_SA))
#define BIT_GET_DDMACH2_SA(x) \
(((x) >> BIT_SHIFT_DDMACH2_SA) & BIT_MASK_DDMACH2_SA)
#define BIT_SET_DDMACH2_SA(x, v) (BIT_CLEAR_DDMACH2_SA(x) | BIT_DDMACH2_SA(v))
/* 2 REG_DDMA_CH2DA (Offset 0x1224) */
#define BIT_SHIFT_DDMACH2_DA 0
#define BIT_MASK_DDMACH2_DA 0xffffffffL
#define BIT_DDMACH2_DA(x) (((x) & BIT_MASK_DDMACH2_DA) << BIT_SHIFT_DDMACH2_DA)
#define BITS_DDMACH2_DA (BIT_MASK_DDMACH2_DA << BIT_SHIFT_DDMACH2_DA)
#define BIT_CLEAR_DDMACH2_DA(x) ((x) & (~BITS_DDMACH2_DA))
#define BIT_GET_DDMACH2_DA(x) \
(((x) >> BIT_SHIFT_DDMACH2_DA) & BIT_MASK_DDMACH2_DA)
#define BIT_SET_DDMACH2_DA(x, v) (BIT_CLEAR_DDMACH2_DA(x) | BIT_DDMACH2_DA(v))
/* 2 REG_DDMA_CH2CTRL (Offset 0x1228) */
#define BIT_DDMACH2_OWN BIT(31)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH2CTRL (Offset 0x1228) */
#define BIT_DDMACH2_IDMEM_ERR BIT(30)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_DDMA_CH2CTRL (Offset 0x1228) */
#define BIT_DDMACH2_ERR_MON BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH2CTRL (Offset 0x1228) */
#define BIT_DDMACH2_CHKSUM_EN BIT(29)
#define BIT_DDMACH2_DA_W_DISABLE BIT(28)
#define BIT_DDMACH2_CHKSUM_STS BIT(27)
#define BIT_DDMACH2_DDMA_MODE BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_DDMA_CH2CTRL (Offset 0x1228) */
#define BIT_DDMACH2_RESET_CHKSUM_STS BIT(25)
#define BIT_DDMACH2_CHKSUM_CONT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH2CTRL (Offset 0x1228) */
#define BIT_SHIFT_DDMACH2_DLEN 0
#define BIT_MASK_DDMACH2_DLEN 0x3ffff
#define BIT_DDMACH2_DLEN(x) \
(((x) & BIT_MASK_DDMACH2_DLEN) << BIT_SHIFT_DDMACH2_DLEN)
#define BITS_DDMACH2_DLEN (BIT_MASK_DDMACH2_DLEN << BIT_SHIFT_DDMACH2_DLEN)
#define BIT_CLEAR_DDMACH2_DLEN(x) ((x) & (~BITS_DDMACH2_DLEN))
#define BIT_GET_DDMACH2_DLEN(x) \
(((x) >> BIT_SHIFT_DDMACH2_DLEN) & BIT_MASK_DDMACH2_DLEN)
#define BIT_SET_DDMACH2_DLEN(x, v) \
(BIT_CLEAR_DDMACH2_DLEN(x) | BIT_DDMACH2_DLEN(v))
/* 2 REG_DDMA_CH3SA (Offset 0x1230) */
#define BIT_SHIFT_DDMACH3_SA 0
#define BIT_MASK_DDMACH3_SA 0xffffffffL
#define BIT_DDMACH3_SA(x) (((x) & BIT_MASK_DDMACH3_SA) << BIT_SHIFT_DDMACH3_SA)
#define BITS_DDMACH3_SA (BIT_MASK_DDMACH3_SA << BIT_SHIFT_DDMACH3_SA)
#define BIT_CLEAR_DDMACH3_SA(x) ((x) & (~BITS_DDMACH3_SA))
#define BIT_GET_DDMACH3_SA(x) \
(((x) >> BIT_SHIFT_DDMACH3_SA) & BIT_MASK_DDMACH3_SA)
#define BIT_SET_DDMACH3_SA(x, v) (BIT_CLEAR_DDMACH3_SA(x) | BIT_DDMACH3_SA(v))
/* 2 REG_DDMA_CH3DA (Offset 0x1234) */
#define BIT_SHIFT_DDMACH3_DA 0
#define BIT_MASK_DDMACH3_DA 0xffffffffL
#define BIT_DDMACH3_DA(x) (((x) & BIT_MASK_DDMACH3_DA) << BIT_SHIFT_DDMACH3_DA)
#define BITS_DDMACH3_DA (BIT_MASK_DDMACH3_DA << BIT_SHIFT_DDMACH3_DA)
#define BIT_CLEAR_DDMACH3_DA(x) ((x) & (~BITS_DDMACH3_DA))
#define BIT_GET_DDMACH3_DA(x) \
(((x) >> BIT_SHIFT_DDMACH3_DA) & BIT_MASK_DDMACH3_DA)
#define BIT_SET_DDMACH3_DA(x, v) (BIT_CLEAR_DDMACH3_DA(x) | BIT_DDMACH3_DA(v))
/* 2 REG_DDMA_CH3CTRL (Offset 0x1238) */
#define BIT_DDMACH3_OWN BIT(31)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH3CTRL (Offset 0x1238) */
#define BIT_DDMACH3_IDMEM_ERR BIT(30)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_DDMA_CH3CTRL (Offset 0x1238) */
#define BIT_DDMACH3_ERR_MON BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH3CTRL (Offset 0x1238) */
#define BIT_DDMACH3_CHKSUM_EN BIT(29)
#define BIT_DDMACH3_DA_W_DISABLE BIT(28)
#define BIT_DDMACH3_CHKSUM_STS BIT(27)
#define BIT_DDMACH3_DDMA_MODE BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_DDMA_CH3CTRL (Offset 0x1238) */
#define BIT_DDMACH3_RESET_CHKSUM_STS BIT(25)
#define BIT_DDMACH3_CHKSUM_CONT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH3CTRL (Offset 0x1238) */
#define BIT_SHIFT_DDMACH3_DLEN 0
#define BIT_MASK_DDMACH3_DLEN 0x3ffff
#define BIT_DDMACH3_DLEN(x) \
(((x) & BIT_MASK_DDMACH3_DLEN) << BIT_SHIFT_DDMACH3_DLEN)
#define BITS_DDMACH3_DLEN (BIT_MASK_DDMACH3_DLEN << BIT_SHIFT_DDMACH3_DLEN)
#define BIT_CLEAR_DDMACH3_DLEN(x) ((x) & (~BITS_DDMACH3_DLEN))
#define BIT_GET_DDMACH3_DLEN(x) \
(((x) >> BIT_SHIFT_DDMACH3_DLEN) & BIT_MASK_DDMACH3_DLEN)
#define BIT_SET_DDMACH3_DLEN(x, v) \
(BIT_CLEAR_DDMACH3_DLEN(x) | BIT_DDMACH3_DLEN(v))
/* 2 REG_DDMA_CH4SA (Offset 0x1240) */
#define BIT_SHIFT_DDMACH4_SA 0
#define BIT_MASK_DDMACH4_SA 0xffffffffL
#define BIT_DDMACH4_SA(x) (((x) & BIT_MASK_DDMACH4_SA) << BIT_SHIFT_DDMACH4_SA)
#define BITS_DDMACH4_SA (BIT_MASK_DDMACH4_SA << BIT_SHIFT_DDMACH4_SA)
#define BIT_CLEAR_DDMACH4_SA(x) ((x) & (~BITS_DDMACH4_SA))
#define BIT_GET_DDMACH4_SA(x) \
(((x) >> BIT_SHIFT_DDMACH4_SA) & BIT_MASK_DDMACH4_SA)
#define BIT_SET_DDMACH4_SA(x, v) (BIT_CLEAR_DDMACH4_SA(x) | BIT_DDMACH4_SA(v))
/* 2 REG_DDMA_CH4DA (Offset 0x1244) */
#define BIT_SHIFT_DDMACH4_DA 0
#define BIT_MASK_DDMACH4_DA 0xffffffffL
#define BIT_DDMACH4_DA(x) (((x) & BIT_MASK_DDMACH4_DA) << BIT_SHIFT_DDMACH4_DA)
#define BITS_DDMACH4_DA (BIT_MASK_DDMACH4_DA << BIT_SHIFT_DDMACH4_DA)
#define BIT_CLEAR_DDMACH4_DA(x) ((x) & (~BITS_DDMACH4_DA))
#define BIT_GET_DDMACH4_DA(x) \
(((x) >> BIT_SHIFT_DDMACH4_DA) & BIT_MASK_DDMACH4_DA)
#define BIT_SET_DDMACH4_DA(x, v) (BIT_CLEAR_DDMACH4_DA(x) | BIT_DDMACH4_DA(v))
/* 2 REG_DDMA_CH4CTRL (Offset 0x1248) */
#define BIT_DDMACH4_OWN BIT(31)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH4CTRL (Offset 0x1248) */
#define BIT_DDMACH4_IDMEM_ERR BIT(30)
#define BIT_DDMACH5_IDMEM_ERR BIT(30)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_DDMA_CH4CTRL (Offset 0x1248) */
#define BIT_DDMACH4_ERR_MON BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH4CTRL (Offset 0x1248) */
#define BIT_DDMACH4_CHKSUM_EN BIT(29)
#define BIT_DDMACH4_DA_W_DISABLE BIT(28)
#define BIT_DDMACH4_CHKSUM_STS BIT(27)
#define BIT_DDMACH4_DDMA_MODE BIT(26)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_DDMA_CH4CTRL (Offset 0x1248) */
#define BIT_DDMACH4_RESET_CHKSUM_STS BIT(25)
#define BIT_DDMACH5_RESET_CHKSUM_STS BIT(25)
#define BIT_DDMACH4_CHKSUM_CONT BIT(24)
#define BIT_DDMACH5_CHKSUM_CONT BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_CH4CTRL (Offset 0x1248) */
#define BIT_SHIFT_DDMACH4_DLEN 0
#define BIT_MASK_DDMACH4_DLEN 0x3ffff
#define BIT_DDMACH4_DLEN(x) \
(((x) & BIT_MASK_DDMACH4_DLEN) << BIT_SHIFT_DDMACH4_DLEN)
#define BITS_DDMACH4_DLEN (BIT_MASK_DDMACH4_DLEN << BIT_SHIFT_DDMACH4_DLEN)
#define BIT_CLEAR_DDMACH4_DLEN(x) ((x) & (~BITS_DDMACH4_DLEN))
#define BIT_GET_DDMACH4_DLEN(x) \
(((x) >> BIT_SHIFT_DDMACH4_DLEN) & BIT_MASK_DDMACH4_DLEN)
#define BIT_SET_DDMACH4_DLEN(x, v) \
(BIT_CLEAR_DDMACH4_DLEN(x) | BIT_DDMACH4_DLEN(v))
/* 2 REG_DDMA_CH5SA (Offset 0x1250) */
#define BIT_SHIFT_DDMACH5_SA 0
#define BIT_MASK_DDMACH5_SA 0xffffffffL
#define BIT_DDMACH5_SA(x) (((x) & BIT_MASK_DDMACH5_SA) << BIT_SHIFT_DDMACH5_SA)
#define BITS_DDMACH5_SA (BIT_MASK_DDMACH5_SA << BIT_SHIFT_DDMACH5_SA)
#define BIT_CLEAR_DDMACH5_SA(x) ((x) & (~BITS_DDMACH5_SA))
#define BIT_GET_DDMACH5_SA(x) \
(((x) >> BIT_SHIFT_DDMACH5_SA) & BIT_MASK_DDMACH5_SA)
#define BIT_SET_DDMACH5_SA(x, v) (BIT_CLEAR_DDMACH5_SA(x) | BIT_DDMACH5_SA(v))
/* 2 REG_DDMA_CH5DA (Offset 0x1254) */
#define BIT_DDMACH5_OWN BIT(31)
#define BIT_DDMACH5_CHKSUM_EN BIT(29)
#define BIT_DDMACH5_DA_W_DISABLE BIT(28)
#define BIT_DDMACH5_CHKSUM_STS BIT(27)
#define BIT_DDMACH5_DDMA_MODE BIT(26)
#define BIT_SHIFT_DDMACH5_DA 0
#define BIT_MASK_DDMACH5_DA 0xffffffffL
#define BIT_DDMACH5_DA(x) (((x) & BIT_MASK_DDMACH5_DA) << BIT_SHIFT_DDMACH5_DA)
#define BITS_DDMACH5_DA (BIT_MASK_DDMACH5_DA << BIT_SHIFT_DDMACH5_DA)
#define BIT_CLEAR_DDMACH5_DA(x) ((x) & (~BITS_DDMACH5_DA))
#define BIT_GET_DDMACH5_DA(x) \
(((x) >> BIT_SHIFT_DDMACH5_DA) & BIT_MASK_DDMACH5_DA)
#define BIT_SET_DDMACH5_DA(x, v) (BIT_CLEAR_DDMACH5_DA(x) | BIT_DDMACH5_DA(v))
#define BIT_SHIFT_DDMACH5_DLEN 0
#define BIT_MASK_DDMACH5_DLEN 0x3ffff
#define BIT_DDMACH5_DLEN(x) \
(((x) & BIT_MASK_DDMACH5_DLEN) << BIT_SHIFT_DDMACH5_DLEN)
#define BITS_DDMACH5_DLEN (BIT_MASK_DDMACH5_DLEN << BIT_SHIFT_DDMACH5_DLEN)
#define BIT_CLEAR_DDMACH5_DLEN(x) ((x) & (~BITS_DDMACH5_DLEN))
#define BIT_GET_DDMACH5_DLEN(x) \
(((x) >> BIT_SHIFT_DDMACH5_DLEN) & BIT_MASK_DDMACH5_DLEN)
#define BIT_SET_DDMACH5_DLEN(x, v) \
(BIT_CLEAR_DDMACH5_DLEN(x) | BIT_DDMACH5_DLEN(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_REG_DDMA_CH5CTRL (Offset 0x1258) */
#define BIT_DDMACH5_ERR_MON BIT(30)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_DDMA_INT_MSK (Offset 0x12E0) */
#define BIT_DDMACH5_MSK BIT(5)
#define BIT_DDMACH4_MSK BIT(4)
#define BIT_DDMACH3_MSK BIT(3)
#define BIT_DDMACH2_MSK BIT(2)
#define BIT_DDMACH1_MSK BIT(1)
#define BIT_DDMACH0_MSK BIT(0)
/* 2 REG_DDMA_CHSTATUS (Offset 0x12E8) */
#define BIT_DDMACH5_BUSY BIT(5)
#define BIT_DDMACH4_BUSY BIT(4)
#define BIT_DDMACH3_BUSY BIT(3)
#define BIT_DDMACH2_BUSY BIT(2)
#define BIT_DDMACH1_BUSY BIT(1)
#define BIT_DDMACH0_BUSY BIT(0)
/* 2 REG_DDMA_CHKSUM (Offset 0x12F0) */
#define BIT_SHIFT_IDDMA0_CHKSUM 0
#define BIT_MASK_IDDMA0_CHKSUM 0xffff
#define BIT_IDDMA0_CHKSUM(x) \
(((x) & BIT_MASK_IDDMA0_CHKSUM) << BIT_SHIFT_IDDMA0_CHKSUM)
#define BITS_IDDMA0_CHKSUM (BIT_MASK_IDDMA0_CHKSUM << BIT_SHIFT_IDDMA0_CHKSUM)
#define BIT_CLEAR_IDDMA0_CHKSUM(x) ((x) & (~BITS_IDDMA0_CHKSUM))
#define BIT_GET_IDDMA0_CHKSUM(x) \
(((x) >> BIT_SHIFT_IDDMA0_CHKSUM) & BIT_MASK_IDDMA0_CHKSUM)
#define BIT_SET_IDDMA0_CHKSUM(x, v) \
(BIT_CLEAR_IDDMA0_CHKSUM(x) | BIT_IDDMA0_CHKSUM(v))
/* 2 REG_DDMA_MONITOR (Offset 0x12FC) */
#define BIT_IDDMA0_PERMU_UNDERFLOW BIT(14)
#define BIT_IDDMA0_FIFO_UNDERFLOW BIT(13)
#define BIT_IDDMA0_FIFO_OVERFLOW BIT(12)
#define BIT_CH5_ERR BIT(5)
#define BIT_CH4_ERR BIT(4)
#define BIT_CH3_ERR BIT(3)
#define BIT_CH2_ERR BIT(2)
#define BIT_CH1_ERR BIT(1)
#define BIT_CH0_ERR BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_STC_INT_CS (Offset 0x1300) */
#define BIT_STC_INT_EN BIT(31)
#define BIT_STC_INT_GRP_EN BIT(31)
#define BIT_SHIFT_STC_INT_FLAG 16
#define BIT_MASK_STC_INT_FLAG 0xff
#define BIT_STC_INT_FLAG(x) \
(((x) & BIT_MASK_STC_INT_FLAG) << BIT_SHIFT_STC_INT_FLAG)
#define BITS_STC_INT_FLAG (BIT_MASK_STC_INT_FLAG << BIT_SHIFT_STC_INT_FLAG)
#define BIT_CLEAR_STC_INT_FLAG(x) ((x) & (~BITS_STC_INT_FLAG))
#define BIT_GET_STC_INT_FLAG(x) \
(((x) >> BIT_SHIFT_STC_INT_FLAG) & BIT_MASK_STC_INT_FLAG)
#define BIT_SET_STC_INT_FLAG(x, v) \
(BIT_CLEAR_STC_INT_FLAG(x) | BIT_STC_INT_FLAG(v))
#define BIT_SHIFT_STC_INT_IDX 8
#define BIT_MASK_STC_INT_IDX 0x7
#define BIT_STC_INT_IDX(x) \
(((x) & BIT_MASK_STC_INT_IDX) << BIT_SHIFT_STC_INT_IDX)
#define BITS_STC_INT_IDX (BIT_MASK_STC_INT_IDX << BIT_SHIFT_STC_INT_IDX)
#define BIT_CLEAR_STC_INT_IDX(x) ((x) & (~BITS_STC_INT_IDX))
#define BIT_GET_STC_INT_IDX(x) \
(((x) >> BIT_SHIFT_STC_INT_IDX) & BIT_MASK_STC_INT_IDX)
#define BIT_SET_STC_INT_IDX(x, v) \
(BIT_CLEAR_STC_INT_IDX(x) | BIT_STC_INT_IDX(v))
#define BIT_SHIFT_STC_INT_EXPECT_LS 8
#define BIT_MASK_STC_INT_EXPECT_LS 0x3f
#define BIT_STC_INT_EXPECT_LS(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_LS) << BIT_SHIFT_STC_INT_EXPECT_LS)
#define BITS_STC_INT_EXPECT_LS \
(BIT_MASK_STC_INT_EXPECT_LS << BIT_SHIFT_STC_INT_EXPECT_LS)
#define BIT_CLEAR_STC_INT_EXPECT_LS(x) ((x) & (~BITS_STC_INT_EXPECT_LS))
#define BIT_GET_STC_INT_EXPECT_LS(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_LS) & BIT_MASK_STC_INT_EXPECT_LS)
#define BIT_SET_STC_INT_EXPECT_LS(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_LS(x) | BIT_STC_INT_EXPECT_LS(v))
#define BIT_SHIFT_STC_INT_REALTIME_CS 0
#define BIT_MASK_STC_INT_REALTIME_CS 0x3f
#define BIT_STC_INT_REALTIME_CS(x) \
(((x) & BIT_MASK_STC_INT_REALTIME_CS) << BIT_SHIFT_STC_INT_REALTIME_CS)
#define BITS_STC_INT_REALTIME_CS \
(BIT_MASK_STC_INT_REALTIME_CS << BIT_SHIFT_STC_INT_REALTIME_CS)
#define BIT_CLEAR_STC_INT_REALTIME_CS(x) ((x) & (~BITS_STC_INT_REALTIME_CS))
#define BIT_GET_STC_INT_REALTIME_CS(x) \
(((x) >> BIT_SHIFT_STC_INT_REALTIME_CS) & BIT_MASK_STC_INT_REALTIME_CS)
#define BIT_SET_STC_INT_REALTIME_CS(x, v) \
(BIT_CLEAR_STC_INT_REALTIME_CS(x) | BIT_STC_INT_REALTIME_CS(v))
#define BIT_SHIFT_STC_INT_EXPECT_CS 0
#define BIT_MASK_STC_INT_EXPECT_CS 0x3f
#define BIT_STC_INT_EXPECT_CS(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_CS) << BIT_SHIFT_STC_INT_EXPECT_CS)
#define BITS_STC_INT_EXPECT_CS \
(BIT_MASK_STC_INT_EXPECT_CS << BIT_SHIFT_STC_INT_EXPECT_CS)
#define BIT_CLEAR_STC_INT_EXPECT_CS(x) ((x) & (~BITS_STC_INT_EXPECT_CS))
#define BIT_GET_STC_INT_EXPECT_CS(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_CS) & BIT_MASK_STC_INT_EXPECT_CS)
#define BIT_SET_STC_INT_EXPECT_CS(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_CS(x) | BIT_STC_INT_EXPECT_CS(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH4_ACH5_TXBD_NUM (Offset 0x130C) */
#define BIT_PCIE_ACH5_FLAG BIT(30)
#define BIT_SHIFT_ACH5_DESC_MODE 28
#define BIT_MASK_ACH5_DESC_MODE 0x3
#define BIT_ACH5_DESC_MODE(x) \
(((x) & BIT_MASK_ACH5_DESC_MODE) << BIT_SHIFT_ACH5_DESC_MODE)
#define BITS_ACH5_DESC_MODE \
(BIT_MASK_ACH5_DESC_MODE << BIT_SHIFT_ACH5_DESC_MODE)
#define BIT_CLEAR_ACH5_DESC_MODE(x) ((x) & (~BITS_ACH5_DESC_MODE))
#define BIT_GET_ACH5_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH5_DESC_MODE) & BIT_MASK_ACH5_DESC_MODE)
#define BIT_SET_ACH5_DESC_MODE(x, v) \
(BIT_CLEAR_ACH5_DESC_MODE(x) | BIT_ACH5_DESC_MODE(v))
#define BIT_SHIFT_ACH5_DESC_NUM 16
#define BIT_MASK_ACH5_DESC_NUM 0xfff
#define BIT_ACH5_DESC_NUM(x) \
(((x) & BIT_MASK_ACH5_DESC_NUM) << BIT_SHIFT_ACH5_DESC_NUM)
#define BITS_ACH5_DESC_NUM (BIT_MASK_ACH5_DESC_NUM << BIT_SHIFT_ACH5_DESC_NUM)
#define BIT_CLEAR_ACH5_DESC_NUM(x) ((x) & (~BITS_ACH5_DESC_NUM))
#define BIT_GET_ACH5_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH5_DESC_NUM) & BIT_MASK_ACH5_DESC_NUM)
#define BIT_SET_ACH5_DESC_NUM(x, v) \
(BIT_CLEAR_ACH5_DESC_NUM(x) | BIT_ACH5_DESC_NUM(v))
#define BIT_PCIE_ACH4_FLAG BIT(14)
#define BIT_SHIFT_ACH4_DESC_MODE 12
#define BIT_MASK_ACH4_DESC_MODE 0x3
#define BIT_ACH4_DESC_MODE(x) \
(((x) & BIT_MASK_ACH4_DESC_MODE) << BIT_SHIFT_ACH4_DESC_MODE)
#define BITS_ACH4_DESC_MODE \
(BIT_MASK_ACH4_DESC_MODE << BIT_SHIFT_ACH4_DESC_MODE)
#define BIT_CLEAR_ACH4_DESC_MODE(x) ((x) & (~BITS_ACH4_DESC_MODE))
#define BIT_GET_ACH4_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH4_DESC_MODE) & BIT_MASK_ACH4_DESC_MODE)
#define BIT_SET_ACH4_DESC_MODE(x, v) \
(BIT_CLEAR_ACH4_DESC_MODE(x) | BIT_ACH4_DESC_MODE(v))
#define BIT_SHIFT_ACH4_DESC_NUM 0
#define BIT_MASK_ACH4_DESC_NUM 0xfff
#define BIT_ACH4_DESC_NUM(x) \
(((x) & BIT_MASK_ACH4_DESC_NUM) << BIT_SHIFT_ACH4_DESC_NUM)
#define BITS_ACH4_DESC_NUM (BIT_MASK_ACH4_DESC_NUM << BIT_SHIFT_ACH4_DESC_NUM)
#define BIT_CLEAR_ACH4_DESC_NUM(x) ((x) & (~BITS_ACH4_DESC_NUM))
#define BIT_GET_ACH4_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH4_DESC_NUM) & BIT_MASK_ACH4_DESC_NUM)
#define BIT_SET_ACH4_DESC_NUM(x, v) \
(BIT_CLEAR_ACH4_DESC_NUM(x) | BIT_ACH4_DESC_NUM(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_CMU_DLY_CTRL (Offset 0x1310) */
#define BIT_CMU_DLY_EN BIT(31)
#define BIT_CMU_DLY_MODE BIT(30)
#define BIT_SHIFT_CMU_DLY_PRE_DIV 0
#define BIT_MASK_CMU_DLY_PRE_DIV 0xff
#define BIT_CMU_DLY_PRE_DIV(x) \
(((x) & BIT_MASK_CMU_DLY_PRE_DIV) << BIT_SHIFT_CMU_DLY_PRE_DIV)
#define BITS_CMU_DLY_PRE_DIV \
(BIT_MASK_CMU_DLY_PRE_DIV << BIT_SHIFT_CMU_DLY_PRE_DIV)
#define BIT_CLEAR_CMU_DLY_PRE_DIV(x) ((x) & (~BITS_CMU_DLY_PRE_DIV))
#define BIT_GET_CMU_DLY_PRE_DIV(x) \
(((x) >> BIT_SHIFT_CMU_DLY_PRE_DIV) & BIT_MASK_CMU_DLY_PRE_DIV)
#define BIT_SET_CMU_DLY_PRE_DIV(x, v) \
(BIT_CLEAR_CMU_DLY_PRE_DIV(x) | BIT_CMU_DLY_PRE_DIV(v))
/* 2 REG_CMU_DLY_CFG (Offset 0x1314) */
#define BIT_SHIFT_CMU_DLY_LTR_A2I 24
#define BIT_MASK_CMU_DLY_LTR_A2I 0xff
#define BIT_CMU_DLY_LTR_A2I(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_A2I) << BIT_SHIFT_CMU_DLY_LTR_A2I)
#define BITS_CMU_DLY_LTR_A2I \
(BIT_MASK_CMU_DLY_LTR_A2I << BIT_SHIFT_CMU_DLY_LTR_A2I)
#define BIT_CLEAR_CMU_DLY_LTR_A2I(x) ((x) & (~BITS_CMU_DLY_LTR_A2I))
#define BIT_GET_CMU_DLY_LTR_A2I(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_A2I) & BIT_MASK_CMU_DLY_LTR_A2I)
#define BIT_SET_CMU_DLY_LTR_A2I(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_A2I(x) | BIT_CMU_DLY_LTR_A2I(v))
#define BIT_SHIFT_CMU_DLY_LTR_I2A 16
#define BIT_MASK_CMU_DLY_LTR_I2A 0xff
#define BIT_CMU_DLY_LTR_I2A(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_I2A) << BIT_SHIFT_CMU_DLY_LTR_I2A)
#define BITS_CMU_DLY_LTR_I2A \
(BIT_MASK_CMU_DLY_LTR_I2A << BIT_SHIFT_CMU_DLY_LTR_I2A)
#define BIT_CLEAR_CMU_DLY_LTR_I2A(x) ((x) & (~BITS_CMU_DLY_LTR_I2A))
#define BIT_GET_CMU_DLY_LTR_I2A(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_I2A) & BIT_MASK_CMU_DLY_LTR_I2A)
#define BIT_SET_CMU_DLY_LTR_I2A(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_I2A(x) | BIT_CMU_DLY_LTR_I2A(v))
#define BIT_SHIFT_CMU_DLY_LTR_IDLE 8
#define BIT_MASK_CMU_DLY_LTR_IDLE 0xff
#define BIT_CMU_DLY_LTR_IDLE(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_IDLE) << BIT_SHIFT_CMU_DLY_LTR_IDLE)
#define BITS_CMU_DLY_LTR_IDLE \
(BIT_MASK_CMU_DLY_LTR_IDLE << BIT_SHIFT_CMU_DLY_LTR_IDLE)
#define BIT_CLEAR_CMU_DLY_LTR_IDLE(x) ((x) & (~BITS_CMU_DLY_LTR_IDLE))
#define BIT_GET_CMU_DLY_LTR_IDLE(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_IDLE) & BIT_MASK_CMU_DLY_LTR_IDLE)
#define BIT_SET_CMU_DLY_LTR_IDLE(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_IDLE(x) | BIT_CMU_DLY_LTR_IDLE(v))
#define BIT_SHIFT_CMU_DLY_LTR_ACT 0
#define BIT_MASK_CMU_DLY_LTR_ACT 0xff
#define BIT_CMU_DLY_LTR_ACT(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_ACT) << BIT_SHIFT_CMU_DLY_LTR_ACT)
#define BITS_CMU_DLY_LTR_ACT \
(BIT_MASK_CMU_DLY_LTR_ACT << BIT_SHIFT_CMU_DLY_LTR_ACT)
#define BIT_CLEAR_CMU_DLY_LTR_ACT(x) ((x) & (~BITS_CMU_DLY_LTR_ACT))
#define BIT_GET_CMU_DLY_LTR_ACT(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_ACT) & BIT_MASK_CMU_DLY_LTR_ACT)
#define BIT_SET_CMU_DLY_LTR_ACT(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_ACT(x) | BIT_CMU_DLY_LTR_ACT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWCMDQ_TXBD_IDX (Offset 0x1318) */
#define BIT_SHIFT_FWCMDQ_HW_IDX 16
#define BIT_MASK_FWCMDQ_HW_IDX 0xfff
#define BIT_FWCMDQ_HW_IDX(x) \
(((x) & BIT_MASK_FWCMDQ_HW_IDX) << BIT_SHIFT_FWCMDQ_HW_IDX)
#define BITS_FWCMDQ_HW_IDX (BIT_MASK_FWCMDQ_HW_IDX << BIT_SHIFT_FWCMDQ_HW_IDX)
#define BIT_CLEAR_FWCMDQ_HW_IDX(x) ((x) & (~BITS_FWCMDQ_HW_IDX))
#define BIT_GET_FWCMDQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_FWCMDQ_HW_IDX) & BIT_MASK_FWCMDQ_HW_IDX)
#define BIT_SET_FWCMDQ_HW_IDX(x, v) \
(BIT_CLEAR_FWCMDQ_HW_IDX(x) | BIT_FWCMDQ_HW_IDX(v))
#define BIT_SHIFT_FWCMDQ_HOST_IDX 0
#define BIT_MASK_FWCMDQ_HOST_IDX 0xfff
#define BIT_FWCMDQ_HOST_IDX(x) \
(((x) & BIT_MASK_FWCMDQ_HOST_IDX) << BIT_SHIFT_FWCMDQ_HOST_IDX)
#define BITS_FWCMDQ_HOST_IDX \
(BIT_MASK_FWCMDQ_HOST_IDX << BIT_SHIFT_FWCMDQ_HOST_IDX)
#define BIT_CLEAR_FWCMDQ_HOST_IDX(x) ((x) & (~BITS_FWCMDQ_HOST_IDX))
#define BIT_GET_FWCMDQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_FWCMDQ_HOST_IDX) & BIT_MASK_FWCMDQ_HOST_IDX)
#define BIT_SET_FWCMDQ_HOST_IDX(x, v) \
(BIT_CLEAR_FWCMDQ_HOST_IDX(x) | BIT_FWCMDQ_HOST_IDX(v))
/* 2 REG_P0HI8Q_TXBD_IDX (Offset 0x131C) */
#define BIT_SHIFT_P0HI8Q_HW_IDX 16
#define BIT_MASK_P0HI8Q_HW_IDX 0xfff
#define BIT_P0HI8Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI8Q_HW_IDX) << BIT_SHIFT_P0HI8Q_HW_IDX)
#define BITS_P0HI8Q_HW_IDX (BIT_MASK_P0HI8Q_HW_IDX << BIT_SHIFT_P0HI8Q_HW_IDX)
#define BIT_CLEAR_P0HI8Q_HW_IDX(x) ((x) & (~BITS_P0HI8Q_HW_IDX))
#define BIT_GET_P0HI8Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI8Q_HW_IDX) & BIT_MASK_P0HI8Q_HW_IDX)
#define BIT_SET_P0HI8Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI8Q_HW_IDX(x) | BIT_P0HI8Q_HW_IDX(v))
#define BIT_SHIFT_P0HI8Q_HOST_IDX 0
#define BIT_MASK_P0HI8Q_HOST_IDX 0xfff
#define BIT_P0HI8Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI8Q_HOST_IDX) << BIT_SHIFT_P0HI8Q_HOST_IDX)
#define BITS_P0HI8Q_HOST_IDX \
(BIT_MASK_P0HI8Q_HOST_IDX << BIT_SHIFT_P0HI8Q_HOST_IDX)
#define BIT_CLEAR_P0HI8Q_HOST_IDX(x) ((x) & (~BITS_P0HI8Q_HOST_IDX))
#define BIT_GET_P0HI8Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI8Q_HOST_IDX) & BIT_MASK_P0HI8Q_HOST_IDX)
#define BIT_SET_P0HI8Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI8Q_HOST_IDX(x) | BIT_P0HI8Q_HOST_IDX(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_H2CQ_TXBD_DESA (Offset 0x1320) */
#define BIT_SHIFT_H2CQ_TXBD_DESA 0
#define BIT_MASK_H2CQ_TXBD_DESA 0xffffffffffffffffL
#define BIT_H2CQ_TXBD_DESA(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA) << BIT_SHIFT_H2CQ_TXBD_DESA)
#define BITS_H2CQ_TXBD_DESA \
(BIT_MASK_H2CQ_TXBD_DESA << BIT_SHIFT_H2CQ_TXBD_DESA)
#define BIT_CLEAR_H2CQ_TXBD_DESA(x) ((x) & (~BITS_H2CQ_TXBD_DESA))
#define BIT_GET_H2CQ_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA) & BIT_MASK_H2CQ_TXBD_DESA)
#define BIT_SET_H2CQ_TXBD_DESA(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA(x) | BIT_H2CQ_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_H2CQ_TXBD_DESA_L (Offset 0x1320) */
#define BIT_SHIFT_H2CQ_TXBD_DESA_L 0
#define BIT_MASK_H2CQ_TXBD_DESA_L 0xffffffffL
#define BIT_H2CQ_TXBD_DESA_L(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_L) << BIT_SHIFT_H2CQ_TXBD_DESA_L)
#define BITS_H2CQ_TXBD_DESA_L \
(BIT_MASK_H2CQ_TXBD_DESA_L << BIT_SHIFT_H2CQ_TXBD_DESA_L)
#define BIT_CLEAR_H2CQ_TXBD_DESA_L(x) ((x) & (~BITS_H2CQ_TXBD_DESA_L))
#define BIT_GET_H2CQ_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_L) & BIT_MASK_H2CQ_TXBD_DESA_L)
#define BIT_SET_H2CQ_TXBD_DESA_L(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_L(x) | BIT_H2CQ_TXBD_DESA_L(v))
/* 2 REG_H2CQ_TXBD_DESA_H (Offset 0x1324) */
#define BIT_SHIFT_H2CQ_TXBD_DESA_H 0
#define BIT_MASK_H2CQ_TXBD_DESA_H 0xffffffffL
#define BIT_H2CQ_TXBD_DESA_H(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_H) << BIT_SHIFT_H2CQ_TXBD_DESA_H)
#define BITS_H2CQ_TXBD_DESA_H \
(BIT_MASK_H2CQ_TXBD_DESA_H << BIT_SHIFT_H2CQ_TXBD_DESA_H)
#define BIT_CLEAR_H2CQ_TXBD_DESA_H(x) ((x) & (~BITS_H2CQ_TXBD_DESA_H))
#define BIT_GET_H2CQ_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_H) & BIT_MASK_H2CQ_TXBD_DESA_H)
#define BIT_SET_H2CQ_TXBD_DESA_H(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_H(x) | BIT_H2CQ_TXBD_DESA_H(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_H2CQ_TXBD_NUM (Offset 0x1328) */
#define BIT_PCIE_H2CQ_FLAG BIT(14)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_H2CQ_TXBD_NUM (Offset 0x1328) */
#define BIT_HCI_H2CQ_FLAG BIT(14)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_H2CQ_TXBD_NUM (Offset 0x1328) */
#define BIT_SHIFT_H2CQ_DESC_MODE 12
#define BIT_MASK_H2CQ_DESC_MODE 0x3
#define BIT_H2CQ_DESC_MODE(x) \
(((x) & BIT_MASK_H2CQ_DESC_MODE) << BIT_SHIFT_H2CQ_DESC_MODE)
#define BITS_H2CQ_DESC_MODE \
(BIT_MASK_H2CQ_DESC_MODE << BIT_SHIFT_H2CQ_DESC_MODE)
#define BIT_CLEAR_H2CQ_DESC_MODE(x) ((x) & (~BITS_H2CQ_DESC_MODE))
#define BIT_GET_H2CQ_DESC_MODE(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_MODE) & BIT_MASK_H2CQ_DESC_MODE)
#define BIT_SET_H2CQ_DESC_MODE(x, v) \
(BIT_CLEAR_H2CQ_DESC_MODE(x) | BIT_H2CQ_DESC_MODE(v))
#define BIT_SHIFT_H2CQ_DESC_NUM 0
#define BIT_MASK_H2CQ_DESC_NUM 0xfff
#define BIT_H2CQ_DESC_NUM(x) \
(((x) & BIT_MASK_H2CQ_DESC_NUM) << BIT_SHIFT_H2CQ_DESC_NUM)
#define BITS_H2CQ_DESC_NUM (BIT_MASK_H2CQ_DESC_NUM << BIT_SHIFT_H2CQ_DESC_NUM)
#define BIT_CLEAR_H2CQ_DESC_NUM(x) ((x) & (~BITS_H2CQ_DESC_NUM))
#define BIT_GET_H2CQ_DESC_NUM(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_NUM) & BIT_MASK_H2CQ_DESC_NUM)
#define BIT_SET_H2CQ_DESC_NUM(x, v) \
(BIT_CLEAR_H2CQ_DESC_NUM(x) | BIT_H2CQ_DESC_NUM(v))
/* 2 REG_H2CQ_TXBD_IDX (Offset 0x132C) */
#define BIT_SHIFT_H2CQ_HW_IDX 16
#define BIT_MASK_H2CQ_HW_IDX 0xfff
#define BIT_H2CQ_HW_IDX(x) \
(((x) & BIT_MASK_H2CQ_HW_IDX) << BIT_SHIFT_H2CQ_HW_IDX)
#define BITS_H2CQ_HW_IDX (BIT_MASK_H2CQ_HW_IDX << BIT_SHIFT_H2CQ_HW_IDX)
#define BIT_CLEAR_H2CQ_HW_IDX(x) ((x) & (~BITS_H2CQ_HW_IDX))
#define BIT_GET_H2CQ_HW_IDX(x) \
(((x) >> BIT_SHIFT_H2CQ_HW_IDX) & BIT_MASK_H2CQ_HW_IDX)
#define BIT_SET_H2CQ_HW_IDX(x, v) \
(BIT_CLEAR_H2CQ_HW_IDX(x) | BIT_H2CQ_HW_IDX(v))
#define BIT_SHIFT_H2CQ_HOST_IDX 0
#define BIT_MASK_H2CQ_HOST_IDX 0xfff
#define BIT_H2CQ_HOST_IDX(x) \
(((x) & BIT_MASK_H2CQ_HOST_IDX) << BIT_SHIFT_H2CQ_HOST_IDX)
#define BITS_H2CQ_HOST_IDX (BIT_MASK_H2CQ_HOST_IDX << BIT_SHIFT_H2CQ_HOST_IDX)
#define BIT_CLEAR_H2CQ_HOST_IDX(x) ((x) & (~BITS_H2CQ_HOST_IDX))
#define BIT_GET_H2CQ_HOST_IDX(x) \
(((x) >> BIT_SHIFT_H2CQ_HOST_IDX) & BIT_MASK_H2CQ_HOST_IDX)
#define BIT_SET_H2CQ_HOST_IDX(x, v) \
(BIT_CLEAR_H2CQ_HOST_IDX(x) | BIT_H2CQ_HOST_IDX(v))
/* 2 REG_H2CQ_CSR (Offset 0x1330) */
#define BIT_H2CQ_FULL BIT(31)
#define BIT_CLR_H2CQ_HOST_IDX BIT(16)
#define BIT_CLR_H2CQ_HW_IDX BIT(8)
#define BIT_STOP_H2CQ BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI9Q_TXBD_IDX (Offset 0x1334) */
#define BIT_SHIFT_P0HI9Q_HW_IDX 16
#define BIT_MASK_P0HI9Q_HW_IDX 0xfff
#define BIT_P0HI9Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI9Q_HW_IDX) << BIT_SHIFT_P0HI9Q_HW_IDX)
#define BITS_P0HI9Q_HW_IDX (BIT_MASK_P0HI9Q_HW_IDX << BIT_SHIFT_P0HI9Q_HW_IDX)
#define BIT_CLEAR_P0HI9Q_HW_IDX(x) ((x) & (~BITS_P0HI9Q_HW_IDX))
#define BIT_GET_P0HI9Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI9Q_HW_IDX) & BIT_MASK_P0HI9Q_HW_IDX)
#define BIT_SET_P0HI9Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI9Q_HW_IDX(x) | BIT_P0HI9Q_HW_IDX(v))
#define BIT_SHIFT_P0HI9Q_HOST_IDX 0
#define BIT_MASK_P0HI9Q_HOST_IDX 0xfff
#define BIT_P0HI9Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI9Q_HOST_IDX) << BIT_SHIFT_P0HI9Q_HOST_IDX)
#define BITS_P0HI9Q_HOST_IDX \
(BIT_MASK_P0HI9Q_HOST_IDX << BIT_SHIFT_P0HI9Q_HOST_IDX)
#define BIT_CLEAR_P0HI9Q_HOST_IDX(x) ((x) & (~BITS_P0HI9Q_HOST_IDX))
#define BIT_GET_P0HI9Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI9Q_HOST_IDX) & BIT_MASK_P0HI9Q_HOST_IDX)
#define BIT_SET_P0HI9Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI9Q_HOST_IDX(x) | BIT_P0HI9Q_HOST_IDX(v))
/* 2 REG_P0HI10Q_TXBD_IDX (Offset 0x1338) */
#define BIT_SHIFT_P0HI10Q_HW_IDX 16
#define BIT_MASK_P0HI10Q_HW_IDX 0xfff
#define BIT_P0HI10Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI10Q_HW_IDX) << BIT_SHIFT_P0HI10Q_HW_IDX)
#define BITS_P0HI10Q_HW_IDX \
(BIT_MASK_P0HI10Q_HW_IDX << BIT_SHIFT_P0HI10Q_HW_IDX)
#define BIT_CLEAR_P0HI10Q_HW_IDX(x) ((x) & (~BITS_P0HI10Q_HW_IDX))
#define BIT_GET_P0HI10Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI10Q_HW_IDX) & BIT_MASK_P0HI10Q_HW_IDX)
#define BIT_SET_P0HI10Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI10Q_HW_IDX(x) | BIT_P0HI10Q_HW_IDX(v))
#define BIT_SHIFT_P0HI10Q_HOST_IDX 0
#define BIT_MASK_P0HI10Q_HOST_IDX 0xfff
#define BIT_P0HI10Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI10Q_HOST_IDX) << BIT_SHIFT_P0HI10Q_HOST_IDX)
#define BITS_P0HI10Q_HOST_IDX \
(BIT_MASK_P0HI10Q_HOST_IDX << BIT_SHIFT_P0HI10Q_HOST_IDX)
#define BIT_CLEAR_P0HI10Q_HOST_IDX(x) ((x) & (~BITS_P0HI10Q_HOST_IDX))
#define BIT_GET_P0HI10Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI10Q_HOST_IDX) & BIT_MASK_P0HI10Q_HOST_IDX)
#define BIT_SET_P0HI10Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI10Q_HOST_IDX(x) | BIT_P0HI10Q_HOST_IDX(v))
/* 2 REG_P0HI11Q_TXBD_IDX (Offset 0x133C) */
#define BIT_SHIFT_P0HI11Q_HW_IDX 16
#define BIT_MASK_P0HI11Q_HW_IDX 0xfff
#define BIT_P0HI11Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI11Q_HW_IDX) << BIT_SHIFT_P0HI11Q_HW_IDX)
#define BITS_P0HI11Q_HW_IDX \
(BIT_MASK_P0HI11Q_HW_IDX << BIT_SHIFT_P0HI11Q_HW_IDX)
#define BIT_CLEAR_P0HI11Q_HW_IDX(x) ((x) & (~BITS_P0HI11Q_HW_IDX))
#define BIT_GET_P0HI11Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI11Q_HW_IDX) & BIT_MASK_P0HI11Q_HW_IDX)
#define BIT_SET_P0HI11Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI11Q_HW_IDX(x) | BIT_P0HI11Q_HW_IDX(v))
#define BIT_SHIFT_P0HI11Q_HOST_IDX 0
#define BIT_MASK_P0HI11Q_HOST_IDX 0xfff
#define BIT_P0HI11Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI11Q_HOST_IDX) << BIT_SHIFT_P0HI11Q_HOST_IDX)
#define BITS_P0HI11Q_HOST_IDX \
(BIT_MASK_P0HI11Q_HOST_IDX << BIT_SHIFT_P0HI11Q_HOST_IDX)
#define BIT_CLEAR_P0HI11Q_HOST_IDX(x) ((x) & (~BITS_P0HI11Q_HOST_IDX))
#define BIT_GET_P0HI11Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI11Q_HOST_IDX) & BIT_MASK_P0HI11Q_HOST_IDX)
#define BIT_SET_P0HI11Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI11Q_HOST_IDX(x) | BIT_P0HI11Q_HOST_IDX(v))
/* 2 REG_P0HI12Q_TXBD_IDX (Offset 0x1340) */
#define BIT_SHIFT_P0HI12Q_HW_IDX 16
#define BIT_MASK_P0HI12Q_HW_IDX 0xfff
#define BIT_P0HI12Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI12Q_HW_IDX) << BIT_SHIFT_P0HI12Q_HW_IDX)
#define BITS_P0HI12Q_HW_IDX \
(BIT_MASK_P0HI12Q_HW_IDX << BIT_SHIFT_P0HI12Q_HW_IDX)
#define BIT_CLEAR_P0HI12Q_HW_IDX(x) ((x) & (~BITS_P0HI12Q_HW_IDX))
#define BIT_GET_P0HI12Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI12Q_HW_IDX) & BIT_MASK_P0HI12Q_HW_IDX)
#define BIT_SET_P0HI12Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI12Q_HW_IDX(x) | BIT_P0HI12Q_HW_IDX(v))
#define BIT_SHIFT_P0HI12Q_HOST_IDX 0
#define BIT_MASK_P0HI12Q_HOST_IDX 0xfff
#define BIT_P0HI12Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI12Q_HOST_IDX) << BIT_SHIFT_P0HI12Q_HOST_IDX)
#define BITS_P0HI12Q_HOST_IDX \
(BIT_MASK_P0HI12Q_HOST_IDX << BIT_SHIFT_P0HI12Q_HOST_IDX)
#define BIT_CLEAR_P0HI12Q_HOST_IDX(x) ((x) & (~BITS_P0HI12Q_HOST_IDX))
#define BIT_GET_P0HI12Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI12Q_HOST_IDX) & BIT_MASK_P0HI12Q_HOST_IDX)
#define BIT_SET_P0HI12Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI12Q_HOST_IDX(x) | BIT_P0HI12Q_HOST_IDX(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPL_BUFFER_MONITOR (Offset 0x1344) */
#define BIT_TXQFULL_FLAG BIT(19)
#define BIT_SHIFT_RELAX_ORDERING_ATTR 17
#define BIT_MASK_RELAX_ORDERING_ATTR 0x3
#define BIT_RELAX_ORDERING_ATTR(x) \
(((x) & BIT_MASK_RELAX_ORDERING_ATTR) << BIT_SHIFT_RELAX_ORDERING_ATTR)
#define BITS_RELAX_ORDERING_ATTR \
(BIT_MASK_RELAX_ORDERING_ATTR << BIT_SHIFT_RELAX_ORDERING_ATTR)
#define BIT_CLEAR_RELAX_ORDERING_ATTR(x) ((x) & (~BITS_RELAX_ORDERING_ATTR))
#define BIT_GET_RELAX_ORDERING_ATTR(x) \
(((x) >> BIT_SHIFT_RELAX_ORDERING_ATTR) & BIT_MASK_RELAX_ORDERING_ATTR)
#define BIT_SET_RELAX_ORDERING_ATTR(x, v) \
(BIT_CLEAR_RELAX_ORDERING_ATTR(x) | BIT_RELAX_ORDERING_ATTR(v))
#define BIT_CLR_QD_CPL_MIN_REMAIN BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI13Q_TXBD_IDX (Offset 0x1344) */
#define BIT_SHIFT_P0HI13Q_HW_IDX 16
#define BIT_MASK_P0HI13Q_HW_IDX 0xfff
#define BIT_P0HI13Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI13Q_HW_IDX) << BIT_SHIFT_P0HI13Q_HW_IDX)
#define BITS_P0HI13Q_HW_IDX \
(BIT_MASK_P0HI13Q_HW_IDX << BIT_SHIFT_P0HI13Q_HW_IDX)
#define BIT_CLEAR_P0HI13Q_HW_IDX(x) ((x) & (~BITS_P0HI13Q_HW_IDX))
#define BIT_GET_P0HI13Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI13Q_HW_IDX) & BIT_MASK_P0HI13Q_HW_IDX)
#define BIT_SET_P0HI13Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI13Q_HW_IDX(x) | BIT_P0HI13Q_HW_IDX(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_CPL_BUFFER_MONITOR (Offset 0x1344) */
#define BIT_SHIFT_QD_CPL_MIN_REMAIN_ADDR 8
#define BIT_MASK_QD_CPL_MIN_REMAIN_ADDR 0xff
#define BIT_QD_CPL_MIN_REMAIN_ADDR(x) \
(((x) & BIT_MASK_QD_CPL_MIN_REMAIN_ADDR) \
<< BIT_SHIFT_QD_CPL_MIN_REMAIN_ADDR)
#define BITS_QD_CPL_MIN_REMAIN_ADDR \
(BIT_MASK_QD_CPL_MIN_REMAIN_ADDR << BIT_SHIFT_QD_CPL_MIN_REMAIN_ADDR)
#define BIT_CLEAR_QD_CPL_MIN_REMAIN_ADDR(x) \
((x) & (~BITS_QD_CPL_MIN_REMAIN_ADDR))
#define BIT_GET_QD_CPL_MIN_REMAIN_ADDR(x) \
(((x) >> BIT_SHIFT_QD_CPL_MIN_REMAIN_ADDR) & \
BIT_MASK_QD_CPL_MIN_REMAIN_ADDR)
#define BIT_SET_QD_CPL_MIN_REMAIN_ADDR(x, v) \
(BIT_CLEAR_QD_CPL_MIN_REMAIN_ADDR(x) | BIT_QD_CPL_MIN_REMAIN_ADDR(v))
#define BIT_SHIFT_QD_CPL_CUR_REMAIN_ADDR 0
#define BIT_MASK_QD_CPL_CUR_REMAIN_ADDR 0xff
#define BIT_QD_CPL_CUR_REMAIN_ADDR(x) \
(((x) & BIT_MASK_QD_CPL_CUR_REMAIN_ADDR) \
<< BIT_SHIFT_QD_CPL_CUR_REMAIN_ADDR)
#define BITS_QD_CPL_CUR_REMAIN_ADDR \
(BIT_MASK_QD_CPL_CUR_REMAIN_ADDR << BIT_SHIFT_QD_CPL_CUR_REMAIN_ADDR)
#define BIT_CLEAR_QD_CPL_CUR_REMAIN_ADDR(x) \
((x) & (~BITS_QD_CPL_CUR_REMAIN_ADDR))
#define BIT_GET_QD_CPL_CUR_REMAIN_ADDR(x) \
(((x) >> BIT_SHIFT_QD_CPL_CUR_REMAIN_ADDR) & \
BIT_MASK_QD_CPL_CUR_REMAIN_ADDR)
#define BIT_SET_QD_CPL_CUR_REMAIN_ADDR(x, v) \
(BIT_CLEAR_QD_CPL_CUR_REMAIN_ADDR(x) | BIT_QD_CPL_CUR_REMAIN_ADDR(v))
#define BIT_SHIFT_PTM_LOCAL_CLOCK 0
#define BIT_MASK_PTM_LOCAL_CLOCK 0xffffffffL
#define BIT_PTM_LOCAL_CLOCK(x) \
(((x) & BIT_MASK_PTM_LOCAL_CLOCK) << BIT_SHIFT_PTM_LOCAL_CLOCK)
#define BITS_PTM_LOCAL_CLOCK \
(BIT_MASK_PTM_LOCAL_CLOCK << BIT_SHIFT_PTM_LOCAL_CLOCK)
#define BIT_CLEAR_PTM_LOCAL_CLOCK(x) ((x) & (~BITS_PTM_LOCAL_CLOCK))
#define BIT_GET_PTM_LOCAL_CLOCK(x) \
(((x) >> BIT_SHIFT_PTM_LOCAL_CLOCK) & BIT_MASK_PTM_LOCAL_CLOCK)
#define BIT_SET_PTM_LOCAL_CLOCK(x, v) \
(BIT_CLEAR_PTM_LOCAL_CLOCK(x) | BIT_PTM_LOCAL_CLOCK(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI13Q_TXBD_IDX (Offset 0x1344) */
#define BIT_SHIFT_P0HI13Q_HOST_IDX 0
#define BIT_MASK_P0HI13Q_HOST_IDX 0xfff
#define BIT_P0HI13Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI13Q_HOST_IDX) << BIT_SHIFT_P0HI13Q_HOST_IDX)
#define BITS_P0HI13Q_HOST_IDX \
(BIT_MASK_P0HI13Q_HOST_IDX << BIT_SHIFT_P0HI13Q_HOST_IDX)
#define BIT_CLEAR_P0HI13Q_HOST_IDX(x) ((x) & (~BITS_P0HI13Q_HOST_IDX))
#define BIT_GET_P0HI13Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI13Q_HOST_IDX) & BIT_MASK_P0HI13Q_HOST_IDX)
#define BIT_SET_P0HI13Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI13Q_HOST_IDX(x) | BIT_P0HI13Q_HOST_IDX(v))
/* 2 REG_P0HI14Q_TXBD_IDX (Offset 0x1348) */
#define BIT_SHIFT_P0HI14Q_HW_IDX 16
#define BIT_MASK_P0HI14Q_HW_IDX 0xfff
#define BIT_P0HI14Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI14Q_HW_IDX) << BIT_SHIFT_P0HI14Q_HW_IDX)
#define BITS_P0HI14Q_HW_IDX \
(BIT_MASK_P0HI14Q_HW_IDX << BIT_SHIFT_P0HI14Q_HW_IDX)
#define BIT_CLEAR_P0HI14Q_HW_IDX(x) ((x) & (~BITS_P0HI14Q_HW_IDX))
#define BIT_GET_P0HI14Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI14Q_HW_IDX) & BIT_MASK_P0HI14Q_HW_IDX)
#define BIT_SET_P0HI14Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI14Q_HW_IDX(x) | BIT_P0HI14Q_HW_IDX(v))
#define BIT_SHIFT_P0HI14Q_HOST_IDX 0
#define BIT_MASK_P0HI14Q_HOST_IDX 0xfff
#define BIT_P0HI14Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI14Q_HOST_IDX) << BIT_SHIFT_P0HI14Q_HOST_IDX)
#define BITS_P0HI14Q_HOST_IDX \
(BIT_MASK_P0HI14Q_HOST_IDX << BIT_SHIFT_P0HI14Q_HOST_IDX)
#define BIT_CLEAR_P0HI14Q_HOST_IDX(x) ((x) & (~BITS_P0HI14Q_HOST_IDX))
#define BIT_GET_P0HI14Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI14Q_HOST_IDX) & BIT_MASK_P0HI14Q_HOST_IDX)
#define BIT_SET_P0HI14Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI14Q_HOST_IDX(x) | BIT_P0HI14Q_HOST_IDX(v))
/* 2 REG_P0HI15Q_TXBD_IDX (Offset 0x134C) */
#define BIT_SHIFT_P0HI15Q_HW_IDX 16
#define BIT_MASK_P0HI15Q_HW_IDX 0xfff
#define BIT_P0HI15Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI15Q_HW_IDX) << BIT_SHIFT_P0HI15Q_HW_IDX)
#define BITS_P0HI15Q_HW_IDX \
(BIT_MASK_P0HI15Q_HW_IDX << BIT_SHIFT_P0HI15Q_HW_IDX)
#define BIT_CLEAR_P0HI15Q_HW_IDX(x) ((x) & (~BITS_P0HI15Q_HW_IDX))
#define BIT_GET_P0HI15Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI15Q_HW_IDX) & BIT_MASK_P0HI15Q_HW_IDX)
#define BIT_SET_P0HI15Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI15Q_HW_IDX(x) | BIT_P0HI15Q_HW_IDX(v))
#define BIT_SHIFT_P0HI15Q_HOST_IDX 0
#define BIT_MASK_P0HI15Q_HOST_IDX 0xfff
#define BIT_P0HI15Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI15Q_HOST_IDX) << BIT_SHIFT_P0HI15Q_HOST_IDX)
#define BITS_P0HI15Q_HOST_IDX \
(BIT_MASK_P0HI15Q_HOST_IDX << BIT_SHIFT_P0HI15Q_HOST_IDX)
#define BIT_CLEAR_P0HI15Q_HOST_IDX(x) ((x) & (~BITS_P0HI15Q_HOST_IDX))
#define BIT_GET_P0HI15Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI15Q_HOST_IDX) & BIT_MASK_P0HI15Q_HOST_IDX)
#define BIT_SET_P0HI15Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI15Q_HOST_IDX(x) | BIT_P0HI15Q_HOST_IDX(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_RXDMA_TIMEOUT_RE BIT(21)
#define BIT_AXI_TXDMA_TIMEOUT_RE BIT(20)
#define BIT_AXI_DECERR_W_RE BIT(19)
#define BIT_AXI_DECERR_R_RE BIT(18)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_CHANGE_PCIE_SPEED BIT(18)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_SLVERR_W_RE BIT(17)
#define BIT_AXI_SLVERR_R_RE BIT(16)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_SHIFT_GEN1_GEN2 16
#define BIT_MASK_GEN1_GEN2 0x3
#define BIT_GEN1_GEN2(x) (((x) & BIT_MASK_GEN1_GEN2) << BIT_SHIFT_GEN1_GEN2)
#define BITS_GEN1_GEN2 (BIT_MASK_GEN1_GEN2 << BIT_SHIFT_GEN1_GEN2)
#define BIT_CLEAR_GEN1_GEN2(x) ((x) & (~BITS_GEN1_GEN2))
#define BIT_GET_GEN1_GEN2(x) (((x) >> BIT_SHIFT_GEN1_GEN2) & BIT_MASK_GEN1_GEN2)
#define BIT_SET_GEN1_GEN2(x, v) (BIT_CLEAR_GEN1_GEN2(x) | BIT_GEN1_GEN2(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_RXDMA_TIMEOUT_IE BIT(13)
#define BIT_AXI_TXDMA_TIMEOUT_IE BIT(12)
#define BIT_AXI_DECERR_W_IE BIT(11)
#define BIT_AXI_DECERR_R_IE BIT(10)
#define BIT_AXI_SLVERR_W_IE BIT(9)
#define BIT_AXI_SLVERR_R_IE BIT(8)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_SHIFT_RXDMA_ERROR_COUNTER 8
#define BIT_MASK_RXDMA_ERROR_COUNTER 0xff
#define BIT_RXDMA_ERROR_COUNTER(x) \
(((x) & BIT_MASK_RXDMA_ERROR_COUNTER) << BIT_SHIFT_RXDMA_ERROR_COUNTER)
#define BITS_RXDMA_ERROR_COUNTER \
(BIT_MASK_RXDMA_ERROR_COUNTER << BIT_SHIFT_RXDMA_ERROR_COUNTER)
#define BIT_CLEAR_RXDMA_ERROR_COUNTER(x) ((x) & (~BITS_RXDMA_ERROR_COUNTER))
#define BIT_GET_RXDMA_ERROR_COUNTER(x) \
(((x) >> BIT_SHIFT_RXDMA_ERROR_COUNTER) & BIT_MASK_RXDMA_ERROR_COUNTER)
#define BIT_SET_RXDMA_ERROR_COUNTER(x, v) \
(BIT_CLEAR_RXDMA_ERROR_COUNTER(x) | BIT_RXDMA_ERROR_COUNTER(v))
#define BIT_TXDMA_ERROR_HANDLE_STATUS BIT(7)
#define BIT_TXDMA_ERROR_PULSE BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_RXDMA_TIMEOUT_FLAG BIT(5)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_TXDMA_STUCK_ERROR_HANDLE_ENABLE BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_TXDMA_TIMEOUT_FLAG BIT(4)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_TXDMA_RETURN_ERROR_ENABLE BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_DECERR_W_FLAG BIT(3)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_RXDMA_ERROR_HANDLE_STATUS BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_DECERR_R_FLAG BIT(2)
#define BIT_AXI_SLVERR_W_FLAG BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_TSFT_PTM_DIFF (Offset 0x1350) */
#define BIT_SHIFT_TSFT_PTM_DIFF 0
#define BIT_MASK_TSFT_PTM_DIFF 0xffffffffL
#define BIT_TSFT_PTM_DIFF(x) \
(((x) & BIT_MASK_TSFT_PTM_DIFF) << BIT_SHIFT_TSFT_PTM_DIFF)
#define BITS_TSFT_PTM_DIFF (BIT_MASK_TSFT_PTM_DIFF << BIT_SHIFT_TSFT_PTM_DIFF)
#define BIT_CLEAR_TSFT_PTM_DIFF(x) ((x) & (~BITS_TSFT_PTM_DIFF))
#define BIT_GET_TSFT_PTM_DIFF(x) \
(((x) >> BIT_SHIFT_TSFT_PTM_DIFF) & BIT_MASK_TSFT_PTM_DIFF)
#define BIT_SET_TSFT_PTM_DIFF(x, v) \
(BIT_CLEAR_TSFT_PTM_DIFF(x) | BIT_TSFT_PTM_DIFF(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_CS (Offset 0x1350) */
#define BIT_AXI_SLVERR_R_FLAG BIT(0)
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_CHANGE_PCIE_SPEED (Offset 0x1350) */
#define BIT_SHIFT_AUTO_HANG_RELEASE 0
#define BIT_MASK_AUTO_HANG_RELEASE 0x7
#define BIT_AUTO_HANG_RELEASE(x) \
(((x) & BIT_MASK_AUTO_HANG_RELEASE) << BIT_SHIFT_AUTO_HANG_RELEASE)
#define BITS_AUTO_HANG_RELEASE \
(BIT_MASK_AUTO_HANG_RELEASE << BIT_SHIFT_AUTO_HANG_RELEASE)
#define BIT_CLEAR_AUTO_HANG_RELEASE(x) ((x) & (~BITS_AUTO_HANG_RELEASE))
#define BIT_GET_AUTO_HANG_RELEASE(x) \
(((x) >> BIT_SHIFT_AUTO_HANG_RELEASE) & BIT_MASK_AUTO_HANG_RELEASE)
#define BIT_SET_AUTO_HANG_RELEASE(x, v) \
(BIT_CLEAR_AUTO_HANG_RELEASE(x) | BIT_AUTO_HANG_RELEASE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_TIME (Offset 0x1354) */
#define BIT_SHIFT_AXI_RECOVERY_TIME 24
#define BIT_MASK_AXI_RECOVERY_TIME 0xff
#define BIT_AXI_RECOVERY_TIME(x) \
(((x) & BIT_MASK_AXI_RECOVERY_TIME) << BIT_SHIFT_AXI_RECOVERY_TIME)
#define BITS_AXI_RECOVERY_TIME \
(BIT_MASK_AXI_RECOVERY_TIME << BIT_SHIFT_AXI_RECOVERY_TIME)
#define BIT_CLEAR_AXI_RECOVERY_TIME(x) ((x) & (~BITS_AXI_RECOVERY_TIME))
#define BIT_GET_AXI_RECOVERY_TIME(x) \
(((x) >> BIT_SHIFT_AXI_RECOVERY_TIME) & BIT_MASK_AXI_RECOVERY_TIME)
#define BIT_SET_AXI_RECOVERY_TIME(x, v) \
(BIT_CLEAR_AXI_RECOVERY_TIME(x) | BIT_AXI_RECOVERY_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PTM_CTRL_STATUS (Offset 0x1354) */
#define BIT_BCNQ2_EMPTY BIT(23)
#define BIT_BCNQ1_EMPTY BIT(22)
#define BIT_BCNQ0_EMPTY BIT(21)
#define BIT_EVTQ_EMPTY BIT(20)
#define BIT_MGQ_CPU_EMPTY_V2 BIT(19)
#define BIT_BCNQ_EMPTY_V2 BIT(18)
#define BIT_HQQ_EMPTY_V2 BIT(17)
#define BIT_SHIFT_TAIL_PKT_V1 16
#define BIT_MASK_TAIL_PKT_V1 0xff
#define BIT_TAIL_PKT_V1(x) \
(((x) & BIT_MASK_TAIL_PKT_V1) << BIT_SHIFT_TAIL_PKT_V1)
#define BITS_TAIL_PKT_V1 (BIT_MASK_TAIL_PKT_V1 << BIT_SHIFT_TAIL_PKT_V1)
#define BIT_CLEAR_TAIL_PKT_V1(x) ((x) & (~BITS_TAIL_PKT_V1))
#define BIT_GET_TAIL_PKT_V1(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_V1) & BIT_MASK_TAIL_PKT_V1)
#define BIT_SET_TAIL_PKT_V1(x, v) \
(BIT_CLEAR_TAIL_PKT_V1(x) | BIT_TAIL_PKT_V1(v))
#define BIT_MQQ_EMPTY_V3 BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_TIME (Offset 0x1354) */
#define BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL 12
#define BIT_MASK_AXI_RXDMA_TIMEOUT_VAL 0xfff
#define BIT_AXI_RXDMA_TIMEOUT_VAL(x) \
(((x) & BIT_MASK_AXI_RXDMA_TIMEOUT_VAL) \
<< BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL)
#define BITS_AXI_RXDMA_TIMEOUT_VAL \
(BIT_MASK_AXI_RXDMA_TIMEOUT_VAL << BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL)
#define BIT_CLEAR_AXI_RXDMA_TIMEOUT_VAL(x) ((x) & (~BITS_AXI_RXDMA_TIMEOUT_VAL))
#define BIT_GET_AXI_RXDMA_TIMEOUT_VAL(x) \
(((x) >> BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL) & \
BIT_MASK_AXI_RXDMA_TIMEOUT_VAL)
#define BIT_SET_AXI_RXDMA_TIMEOUT_VAL(x, v) \
(BIT_CLEAR_AXI_RXDMA_TIMEOUT_VAL(x) | BIT_AXI_RXDMA_TIMEOUT_VAL(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_PTM_CTRL_STATUS (Offset 0x1354) */
#define BIT_SHIFT_PKT_NUM_V1 8
#define BIT_MASK_PKT_NUM_V1 0xff
#define BIT_PKT_NUM_V1(x) (((x) & BIT_MASK_PKT_NUM_V1) << BIT_SHIFT_PKT_NUM_V1)
#define BITS_PKT_NUM_V1 (BIT_MASK_PKT_NUM_V1 << BIT_SHIFT_PKT_NUM_V1)
#define BIT_CLEAR_PKT_NUM_V1(x) ((x) & (~BITS_PKT_NUM_V1))
#define BIT_GET_PKT_NUM_V1(x) \
(((x) >> BIT_SHIFT_PKT_NUM_V1) & BIT_MASK_PKT_NUM_V1)
#define BIT_SET_PKT_NUM_V1(x, v) (BIT_CLEAR_PKT_NUM_V1(x) | BIT_PKT_NUM_V1(v))
#define BIT_SHIFT_QUEUEAC_V1 8
#define BIT_MASK_QUEUEAC_V1 0x3
#define BIT_QUEUEAC_V1(x) (((x) & BIT_MASK_QUEUEAC_V1) << BIT_SHIFT_QUEUEAC_V1)
#define BITS_QUEUEAC_V1 (BIT_MASK_QUEUEAC_V1 << BIT_SHIFT_QUEUEAC_V1)
#define BIT_CLEAR_QUEUEAC_V1(x) ((x) & (~BITS_QUEUEAC_V1))
#define BIT_GET_QUEUEAC_V1(x) \
(((x) >> BIT_SHIFT_QUEUEAC_V1) & BIT_MASK_QUEUEAC_V1)
#define BIT_SET_QUEUEAC_V1(x, v) (BIT_CLEAR_QUEUEAC_V1(x) | BIT_QUEUEAC_V1(v))
#define BIT_SHIFT_ACQ_STOP 5
#define BIT_MASK_ACQ_STOP 0xffff
#define BIT_ACQ_STOP(x) (((x) & BIT_MASK_ACQ_STOP) << BIT_SHIFT_ACQ_STOP)
#define BITS_ACQ_STOP (BIT_MASK_ACQ_STOP << BIT_SHIFT_ACQ_STOP)
#define BIT_CLEAR_ACQ_STOP(x) ((x) & (~BITS_ACQ_STOP))
#define BIT_GET_ACQ_STOP(x) (((x) >> BIT_SHIFT_ACQ_STOP) & BIT_MASK_ACQ_STOP)
#define BIT_SET_ACQ_STOP(x, v) (BIT_CLEAR_ACQ_STOP(x) | BIT_ACQ_STOP(v))
#define BIT_SHIFT_TSFT_PORT_SEL 3
#define BIT_MASK_TSFT_PORT_SEL 0x3
#define BIT_TSFT_PORT_SEL(x) \
(((x) & BIT_MASK_TSFT_PORT_SEL) << BIT_SHIFT_TSFT_PORT_SEL)
#define BITS_TSFT_PORT_SEL (BIT_MASK_TSFT_PORT_SEL << BIT_SHIFT_TSFT_PORT_SEL)
#define BIT_CLEAR_TSFT_PORT_SEL(x) ((x) & (~BITS_TSFT_PORT_SEL))
#define BIT_GET_TSFT_PORT_SEL(x) \
(((x) >> BIT_SHIFT_TSFT_PORT_SEL) & BIT_MASK_TSFT_PORT_SEL)
#define BIT_SET_TSFT_PORT_SEL(x, v) \
(BIT_CLEAR_TSFT_PORT_SEL(x) | BIT_TSFT_PORT_SEL(v))
#define BIT_PTM_CONTEXT_VALID BIT(2)
#define BIT_PTM_MANUL_UPDATE BIT(1)
#define BIT_PTM_AUTO_UPDATE BIT(0)
#define BIT_SHIFT_HEAD_PKT_V1 0
#define BIT_MASK_HEAD_PKT_V1 0xff
#define BIT_HEAD_PKT_V1(x) \
(((x) & BIT_MASK_HEAD_PKT_V1) << BIT_SHIFT_HEAD_PKT_V1)
#define BITS_HEAD_PKT_V1 (BIT_MASK_HEAD_PKT_V1 << BIT_SHIFT_HEAD_PKT_V1)
#define BIT_CLEAR_HEAD_PKT_V1(x) ((x) & (~BITS_HEAD_PKT_V1))
#define BIT_GET_HEAD_PKT_V1(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_V1) & BIT_MASK_HEAD_PKT_V1)
#define BIT_SET_HEAD_PKT_V1(x, v) \
(BIT_CLEAR_HEAD_PKT_V1(x) | BIT_HEAD_PKT_V1(v))
#define BIT_SHIFT_QUEUEMACID_V1 0
#define BIT_MASK_QUEUEMACID_V1 0x7f
#define BIT_QUEUEMACID_V1(x) \
(((x) & BIT_MASK_QUEUEMACID_V1) << BIT_SHIFT_QUEUEMACID_V1)
#define BITS_QUEUEMACID_V1 (BIT_MASK_QUEUEMACID_V1 << BIT_SHIFT_QUEUEMACID_V1)
#define BIT_CLEAR_QUEUEMACID_V1(x) ((x) & (~BITS_QUEUEMACID_V1))
#define BIT_GET_QUEUEMACID_V1(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_V1) & BIT_MASK_QUEUEMACID_V1)
#define BIT_SET_QUEUEMACID_V1(x, v) \
(BIT_CLEAR_QUEUEMACID_V1(x) | BIT_QUEUEMACID_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_AXI_EXCEPT_TIME (Offset 0x1354) */
#define BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL 0
#define BIT_MASK_AXI_TXDMA_TIMEOUT_VAL 0xfff
#define BIT_AXI_TXDMA_TIMEOUT_VAL(x) \
(((x) & BIT_MASK_AXI_TXDMA_TIMEOUT_VAL) \
<< BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL)
#define BITS_AXI_TXDMA_TIMEOUT_VAL \
(BIT_MASK_AXI_TXDMA_TIMEOUT_VAL << BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL)
#define BIT_CLEAR_AXI_TXDMA_TIMEOUT_VAL(x) ((x) & (~BITS_AXI_TXDMA_TIMEOUT_VAL))
#define BIT_GET_AXI_TXDMA_TIMEOUT_VAL(x) \
(((x) >> BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL) & \
BIT_MASK_AXI_TXDMA_TIMEOUT_VAL)
#define BIT_SET_AXI_TXDMA_TIMEOUT_VAL(x, v) \
(BIT_CLEAR_AXI_TXDMA_TIMEOUT_VAL(x) | BIT_AXI_TXDMA_TIMEOUT_VAL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DEBUG_STATE1 (Offset 0x1354) */
#define BIT_SHIFT_DEBUG_STATE1 0
#define BIT_MASK_DEBUG_STATE1 0xffffffffL
#define BIT_DEBUG_STATE1(x) \
(((x) & BIT_MASK_DEBUG_STATE1) << BIT_SHIFT_DEBUG_STATE1)
#define BITS_DEBUG_STATE1 (BIT_MASK_DEBUG_STATE1 << BIT_SHIFT_DEBUG_STATE1)
#define BIT_CLEAR_DEBUG_STATE1(x) ((x) & (~BITS_DEBUG_STATE1))
#define BIT_GET_DEBUG_STATE1(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE1) & BIT_MASK_DEBUG_STATE1)
#define BIT_SET_DEBUG_STATE1(x, v) \
(BIT_CLEAR_DEBUG_STATE1(x) | BIT_DEBUG_STATE1(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI8Q_TXBD_IDX (Offset 0x1358) */
#define BIT_SHIFT_HI8Q_HW_IDX 16
#define BIT_MASK_HI8Q_HW_IDX 0xfff
#define BIT_HI8Q_HW_IDX(x) \
(((x) & BIT_MASK_HI8Q_HW_IDX) << BIT_SHIFT_HI8Q_HW_IDX)
#define BITS_HI8Q_HW_IDX (BIT_MASK_HI8Q_HW_IDX << BIT_SHIFT_HI8Q_HW_IDX)
#define BIT_CLEAR_HI8Q_HW_IDX(x) ((x) & (~BITS_HI8Q_HW_IDX))
#define BIT_GET_HI8Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI8Q_HW_IDX) & BIT_MASK_HI8Q_HW_IDX)
#define BIT_SET_HI8Q_HW_IDX(x, v) \
(BIT_CLEAR_HI8Q_HW_IDX(x) | BIT_HI8Q_HW_IDX(v))
#define BIT_SHIFT_HI8Q_HOST_IDX 0
#define BIT_MASK_HI8Q_HOST_IDX 0xfff
#define BIT_HI8Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI8Q_HOST_IDX) << BIT_SHIFT_HI8Q_HOST_IDX)
#define BITS_HI8Q_HOST_IDX (BIT_MASK_HI8Q_HOST_IDX << BIT_SHIFT_HI8Q_HOST_IDX)
#define BIT_CLEAR_HI8Q_HOST_IDX(x) ((x) & (~BITS_HI8Q_HOST_IDX))
#define BIT_GET_HI8Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI8Q_HOST_IDX) & BIT_MASK_HI8Q_HOST_IDX)
#define BIT_SET_HI8Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI8Q_HOST_IDX(x) | BIT_HI8Q_HOST_IDX(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DEBUG_STATE2 (Offset 0x1358) */
#define BIT_SHIFT_DEBUG_STATE2 0
#define BIT_MASK_DEBUG_STATE2 0xffffffffL
#define BIT_DEBUG_STATE2(x) \
(((x) & BIT_MASK_DEBUG_STATE2) << BIT_SHIFT_DEBUG_STATE2)
#define BITS_DEBUG_STATE2 (BIT_MASK_DEBUG_STATE2 << BIT_SHIFT_DEBUG_STATE2)
#define BIT_CLEAR_DEBUG_STATE2(x) ((x) & (~BITS_DEBUG_STATE2))
#define BIT_GET_DEBUG_STATE2(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE2) & BIT_MASK_DEBUG_STATE2)
#define BIT_SET_DEBUG_STATE2(x, v) \
(BIT_CLEAR_DEBUG_STATE2(x) | BIT_DEBUG_STATE2(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI9Q_TXBD_IDX (Offset 0x135C) */
#define BIT_SHIFT_HI9Q_HW_IDX 16
#define BIT_MASK_HI9Q_HW_IDX 0xfff
#define BIT_HI9Q_HW_IDX(x) \
(((x) & BIT_MASK_HI9Q_HW_IDX) << BIT_SHIFT_HI9Q_HW_IDX)
#define BITS_HI9Q_HW_IDX (BIT_MASK_HI9Q_HW_IDX << BIT_SHIFT_HI9Q_HW_IDX)
#define BIT_CLEAR_HI9Q_HW_IDX(x) ((x) & (~BITS_HI9Q_HW_IDX))
#define BIT_GET_HI9Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI9Q_HW_IDX) & BIT_MASK_HI9Q_HW_IDX)
#define BIT_SET_HI9Q_HW_IDX(x, v) \
(BIT_CLEAR_HI9Q_HW_IDX(x) | BIT_HI9Q_HW_IDX(v))
#define BIT_SHIFT_HI9Q_HOST_IDX 0
#define BIT_MASK_HI9Q_HOST_IDX 0xfff
#define BIT_HI9Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI9Q_HOST_IDX) << BIT_SHIFT_HI9Q_HOST_IDX)
#define BITS_HI9Q_HOST_IDX (BIT_MASK_HI9Q_HOST_IDX << BIT_SHIFT_HI9Q_HOST_IDX)
#define BIT_CLEAR_HI9Q_HOST_IDX(x) ((x) & (~BITS_HI9Q_HOST_IDX))
#define BIT_GET_HI9Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI9Q_HOST_IDX) & BIT_MASK_HI9Q_HOST_IDX)
#define BIT_SET_HI9Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI9Q_HOST_IDX(x) | BIT_HI9Q_HOST_IDX(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_DEBUG_STATE3 (Offset 0x135C) */
#define BIT_SHIFT_DEBUG_STATE3 0
#define BIT_MASK_DEBUG_STATE3 0xffffffffL
#define BIT_DEBUG_STATE3(x) \
(((x) & BIT_MASK_DEBUG_STATE3) << BIT_SHIFT_DEBUG_STATE3)
#define BITS_DEBUG_STATE3 (BIT_MASK_DEBUG_STATE3 << BIT_SHIFT_DEBUG_STATE3)
#define BIT_CLEAR_DEBUG_STATE3(x) ((x) & (~BITS_DEBUG_STATE3))
#define BIT_GET_DEBUG_STATE3(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE3) & BIT_MASK_DEBUG_STATE3)
#define BIT_SET_DEBUG_STATE3(x, v) \
(BIT_CLEAR_DEBUG_STATE3(x) | BIT_DEBUG_STATE3(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI10Q_TXBD_IDX (Offset 0x1360) */
#define BIT_SHIFT_HI10Q_HW_IDX 16
#define BIT_MASK_HI10Q_HW_IDX 0xfff
#define BIT_HI10Q_HW_IDX(x) \
(((x) & BIT_MASK_HI10Q_HW_IDX) << BIT_SHIFT_HI10Q_HW_IDX)
#define BITS_HI10Q_HW_IDX (BIT_MASK_HI10Q_HW_IDX << BIT_SHIFT_HI10Q_HW_IDX)
#define BIT_CLEAR_HI10Q_HW_IDX(x) ((x) & (~BITS_HI10Q_HW_IDX))
#define BIT_GET_HI10Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI10Q_HW_IDX) & BIT_MASK_HI10Q_HW_IDX)
#define BIT_SET_HI10Q_HW_IDX(x, v) \
(BIT_CLEAR_HI10Q_HW_IDX(x) | BIT_HI10Q_HW_IDX(v))
#define BIT_SHIFT_HI10Q_HOST_IDX 0
#define BIT_MASK_HI10Q_HOST_IDX 0xfff
#define BIT_HI10Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI10Q_HOST_IDX) << BIT_SHIFT_HI10Q_HOST_IDX)
#define BITS_HI10Q_HOST_IDX \
(BIT_MASK_HI10Q_HOST_IDX << BIT_SHIFT_HI10Q_HOST_IDX)
#define BIT_CLEAR_HI10Q_HOST_IDX(x) ((x) & (~BITS_HI10Q_HOST_IDX))
#define BIT_GET_HI10Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI10Q_HOST_IDX) & BIT_MASK_HI10Q_HOST_IDX)
#define BIT_SET_HI10Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI10Q_HOST_IDX(x) | BIT_HI10Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH5_TXBD_DESA_L (Offset 0x1360) */
#define BIT_SHIFT_ACH5_TXBD_DESA_L 0
#define BIT_MASK_ACH5_TXBD_DESA_L 0xffffffffL
#define BIT_ACH5_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH5_TXBD_DESA_L) << BIT_SHIFT_ACH5_TXBD_DESA_L)
#define BITS_ACH5_TXBD_DESA_L \
(BIT_MASK_ACH5_TXBD_DESA_L << BIT_SHIFT_ACH5_TXBD_DESA_L)
#define BIT_CLEAR_ACH5_TXBD_DESA_L(x) ((x) & (~BITS_ACH5_TXBD_DESA_L))
#define BIT_GET_ACH5_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH5_TXBD_DESA_L) & BIT_MASK_ACH5_TXBD_DESA_L)
#define BIT_SET_ACH5_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH5_TXBD_DESA_L(x) | BIT_ACH5_TXBD_DESA_L(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI11Q_TXBD_IDX (Offset 0x1364) */
#define BIT_SHIFT_HI11Q_HW_IDX 16
#define BIT_MASK_HI11Q_HW_IDX 0xfff
#define BIT_HI11Q_HW_IDX(x) \
(((x) & BIT_MASK_HI11Q_HW_IDX) << BIT_SHIFT_HI11Q_HW_IDX)
#define BITS_HI11Q_HW_IDX (BIT_MASK_HI11Q_HW_IDX << BIT_SHIFT_HI11Q_HW_IDX)
#define BIT_CLEAR_HI11Q_HW_IDX(x) ((x) & (~BITS_HI11Q_HW_IDX))
#define BIT_GET_HI11Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI11Q_HW_IDX) & BIT_MASK_HI11Q_HW_IDX)
#define BIT_SET_HI11Q_HW_IDX(x, v) \
(BIT_CLEAR_HI11Q_HW_IDX(x) | BIT_HI11Q_HW_IDX(v))
#define BIT_SHIFT_HI11Q_HOST_IDX 0
#define BIT_MASK_HI11Q_HOST_IDX 0xfff
#define BIT_HI11Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI11Q_HOST_IDX) << BIT_SHIFT_HI11Q_HOST_IDX)
#define BITS_HI11Q_HOST_IDX \
(BIT_MASK_HI11Q_HOST_IDX << BIT_SHIFT_HI11Q_HOST_IDX)
#define BIT_CLEAR_HI11Q_HOST_IDX(x) ((x) & (~BITS_HI11Q_HOST_IDX))
#define BIT_GET_HI11Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI11Q_HOST_IDX) & BIT_MASK_HI11Q_HOST_IDX)
#define BIT_SET_HI11Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI11Q_HOST_IDX(x) | BIT_HI11Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH5_TXBD_DESA_H (Offset 0x1364) */
#define BIT_SHIFT_ACH5_TXBD_DESA_H 0
#define BIT_MASK_ACH5_TXBD_DESA_H 0xffffffffL
#define BIT_ACH5_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH5_TXBD_DESA_H) << BIT_SHIFT_ACH5_TXBD_DESA_H)
#define BITS_ACH5_TXBD_DESA_H \
(BIT_MASK_ACH5_TXBD_DESA_H << BIT_SHIFT_ACH5_TXBD_DESA_H)
#define BIT_CLEAR_ACH5_TXBD_DESA_H(x) ((x) & (~BITS_ACH5_TXBD_DESA_H))
#define BIT_GET_ACH5_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH5_TXBD_DESA_H) & BIT_MASK_ACH5_TXBD_DESA_H)
#define BIT_SET_ACH5_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH5_TXBD_DESA_H(x) | BIT_ACH5_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI12Q_TXBD_IDX (Offset 0x1368) */
#define BIT_SHIFT_HI12Q_HW_IDX 16
#define BIT_MASK_HI12Q_HW_IDX 0xfff
#define BIT_HI12Q_HW_IDX(x) \
(((x) & BIT_MASK_HI12Q_HW_IDX) << BIT_SHIFT_HI12Q_HW_IDX)
#define BITS_HI12Q_HW_IDX (BIT_MASK_HI12Q_HW_IDX << BIT_SHIFT_HI12Q_HW_IDX)
#define BIT_CLEAR_HI12Q_HW_IDX(x) ((x) & (~BITS_HI12Q_HW_IDX))
#define BIT_GET_HI12Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI12Q_HW_IDX) & BIT_MASK_HI12Q_HW_IDX)
#define BIT_SET_HI12Q_HW_IDX(x, v) \
(BIT_CLEAR_HI12Q_HW_IDX(x) | BIT_HI12Q_HW_IDX(v))
#define BIT_SHIFT_HI12Q_HOST_IDX 0
#define BIT_MASK_HI12Q_HOST_IDX 0xfff
#define BIT_HI12Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI12Q_HOST_IDX) << BIT_SHIFT_HI12Q_HOST_IDX)
#define BITS_HI12Q_HOST_IDX \
(BIT_MASK_HI12Q_HOST_IDX << BIT_SHIFT_HI12Q_HOST_IDX)
#define BIT_CLEAR_HI12Q_HOST_IDX(x) ((x) & (~BITS_HI12Q_HOST_IDX))
#define BIT_GET_HI12Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI12Q_HOST_IDX) & BIT_MASK_HI12Q_HOST_IDX)
#define BIT_SET_HI12Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI12Q_HOST_IDX(x) | BIT_HI12Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH6_TXBD_DESA_L (Offset 0x1368) */
#define BIT_SHIFT_ACH6_TXBD_DESA_L 0
#define BIT_MASK_ACH6_TXBD_DESA_L 0xffffffffL
#define BIT_ACH6_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH6_TXBD_DESA_L) << BIT_SHIFT_ACH6_TXBD_DESA_L)
#define BITS_ACH6_TXBD_DESA_L \
(BIT_MASK_ACH6_TXBD_DESA_L << BIT_SHIFT_ACH6_TXBD_DESA_L)
#define BIT_CLEAR_ACH6_TXBD_DESA_L(x) ((x) & (~BITS_ACH6_TXBD_DESA_L))
#define BIT_GET_ACH6_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH6_TXBD_DESA_L) & BIT_MASK_ACH6_TXBD_DESA_L)
#define BIT_SET_ACH6_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH6_TXBD_DESA_L(x) | BIT_ACH6_TXBD_DESA_L(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI13Q_TXBD_IDX (Offset 0x136C) */
#define BIT_SHIFT_HI13Q_HW_IDX 16
#define BIT_MASK_HI13Q_HW_IDX 0xfff
#define BIT_HI13Q_HW_IDX(x) \
(((x) & BIT_MASK_HI13Q_HW_IDX) << BIT_SHIFT_HI13Q_HW_IDX)
#define BITS_HI13Q_HW_IDX (BIT_MASK_HI13Q_HW_IDX << BIT_SHIFT_HI13Q_HW_IDX)
#define BIT_CLEAR_HI13Q_HW_IDX(x) ((x) & (~BITS_HI13Q_HW_IDX))
#define BIT_GET_HI13Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI13Q_HW_IDX) & BIT_MASK_HI13Q_HW_IDX)
#define BIT_SET_HI13Q_HW_IDX(x, v) \
(BIT_CLEAR_HI13Q_HW_IDX(x) | BIT_HI13Q_HW_IDX(v))
#define BIT_SHIFT_HI13Q_HOST_IDX 0
#define BIT_MASK_HI13Q_HOST_IDX 0xfff
#define BIT_HI13Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI13Q_HOST_IDX) << BIT_SHIFT_HI13Q_HOST_IDX)
#define BITS_HI13Q_HOST_IDX \
(BIT_MASK_HI13Q_HOST_IDX << BIT_SHIFT_HI13Q_HOST_IDX)
#define BIT_CLEAR_HI13Q_HOST_IDX(x) ((x) & (~BITS_HI13Q_HOST_IDX))
#define BIT_GET_HI13Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI13Q_HOST_IDX) & BIT_MASK_HI13Q_HOST_IDX)
#define BIT_SET_HI13Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI13Q_HOST_IDX(x) | BIT_HI13Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH6_TXBD_DESA_H (Offset 0x136C) */
#define BIT_SHIFT_ACH6_TXBD_DESA_H 0
#define BIT_MASK_ACH6_TXBD_DESA_H 0xffffffffL
#define BIT_ACH6_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH6_TXBD_DESA_H) << BIT_SHIFT_ACH6_TXBD_DESA_H)
#define BITS_ACH6_TXBD_DESA_H \
(BIT_MASK_ACH6_TXBD_DESA_H << BIT_SHIFT_ACH6_TXBD_DESA_H)
#define BIT_CLEAR_ACH6_TXBD_DESA_H(x) ((x) & (~BITS_ACH6_TXBD_DESA_H))
#define BIT_GET_ACH6_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH6_TXBD_DESA_H) & BIT_MASK_ACH6_TXBD_DESA_H)
#define BIT_SET_ACH6_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH6_TXBD_DESA_H(x) | BIT_ACH6_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI14Q_TXBD_IDX (Offset 0x1370) */
#define BIT_SHIFT_HI14Q_HW_IDX 16
#define BIT_MASK_HI14Q_HW_IDX 0xfff
#define BIT_HI14Q_HW_IDX(x) \
(((x) & BIT_MASK_HI14Q_HW_IDX) << BIT_SHIFT_HI14Q_HW_IDX)
#define BITS_HI14Q_HW_IDX (BIT_MASK_HI14Q_HW_IDX << BIT_SHIFT_HI14Q_HW_IDX)
#define BIT_CLEAR_HI14Q_HW_IDX(x) ((x) & (~BITS_HI14Q_HW_IDX))
#define BIT_GET_HI14Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI14Q_HW_IDX) & BIT_MASK_HI14Q_HW_IDX)
#define BIT_SET_HI14Q_HW_IDX(x, v) \
(BIT_CLEAR_HI14Q_HW_IDX(x) | BIT_HI14Q_HW_IDX(v))
#define BIT_SHIFT_HI14Q_HOST_IDX 0
#define BIT_MASK_HI14Q_HOST_IDX 0xfff
#define BIT_HI14Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI14Q_HOST_IDX) << BIT_SHIFT_HI14Q_HOST_IDX)
#define BITS_HI14Q_HOST_IDX \
(BIT_MASK_HI14Q_HOST_IDX << BIT_SHIFT_HI14Q_HOST_IDX)
#define BIT_CLEAR_HI14Q_HOST_IDX(x) ((x) & (~BITS_HI14Q_HOST_IDX))
#define BIT_GET_HI14Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI14Q_HOST_IDX) & BIT_MASK_HI14Q_HOST_IDX)
#define BIT_SET_HI14Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI14Q_HOST_IDX(x) | BIT_HI14Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH7_TXBD_DESA_L (Offset 0x1370) */
#define BIT_SHIFT_ACH7_TXBD_DESA_L 0
#define BIT_MASK_ACH7_TXBD_DESA_L 0xffffffffL
#define BIT_ACH7_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH7_TXBD_DESA_L) << BIT_SHIFT_ACH7_TXBD_DESA_L)
#define BITS_ACH7_TXBD_DESA_L \
(BIT_MASK_ACH7_TXBD_DESA_L << BIT_SHIFT_ACH7_TXBD_DESA_L)
#define BIT_CLEAR_ACH7_TXBD_DESA_L(x) ((x) & (~BITS_ACH7_TXBD_DESA_L))
#define BIT_GET_ACH7_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH7_TXBD_DESA_L) & BIT_MASK_ACH7_TXBD_DESA_L)
#define BIT_SET_ACH7_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH7_TXBD_DESA_L(x) | BIT_ACH7_TXBD_DESA_L(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI15Q_TXBD_IDX (Offset 0x1374) */
#define BIT_SHIFT_HI15Q_HW_IDX 16
#define BIT_MASK_HI15Q_HW_IDX 0xfff
#define BIT_HI15Q_HW_IDX(x) \
(((x) & BIT_MASK_HI15Q_HW_IDX) << BIT_SHIFT_HI15Q_HW_IDX)
#define BITS_HI15Q_HW_IDX (BIT_MASK_HI15Q_HW_IDX << BIT_SHIFT_HI15Q_HW_IDX)
#define BIT_CLEAR_HI15Q_HW_IDX(x) ((x) & (~BITS_HI15Q_HW_IDX))
#define BIT_GET_HI15Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_HI15Q_HW_IDX) & BIT_MASK_HI15Q_HW_IDX)
#define BIT_SET_HI15Q_HW_IDX(x, v) \
(BIT_CLEAR_HI15Q_HW_IDX(x) | BIT_HI15Q_HW_IDX(v))
#define BIT_SHIFT_HI15Q_HOST_IDX 0
#define BIT_MASK_HI15Q_HOST_IDX 0xfff
#define BIT_HI15Q_HOST_IDX(x) \
(((x) & BIT_MASK_HI15Q_HOST_IDX) << BIT_SHIFT_HI15Q_HOST_IDX)
#define BITS_HI15Q_HOST_IDX \
(BIT_MASK_HI15Q_HOST_IDX << BIT_SHIFT_HI15Q_HOST_IDX)
#define BIT_CLEAR_HI15Q_HOST_IDX(x) ((x) & (~BITS_HI15Q_HOST_IDX))
#define BIT_GET_HI15Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_HI15Q_HOST_IDX) & BIT_MASK_HI15Q_HOST_IDX)
#define BIT_SET_HI15Q_HOST_IDX(x, v) \
(BIT_CLEAR_HI15Q_HOST_IDX(x) | BIT_HI15Q_HOST_IDX(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH7_TXBD_DESA_H (Offset 0x1374) */
#define BIT_SHIFT_ACH7_TXBD_DESA_H 0
#define BIT_MASK_ACH7_TXBD_DESA_H 0xffffffffL
#define BIT_ACH7_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH7_TXBD_DESA_H) << BIT_SHIFT_ACH7_TXBD_DESA_H)
#define BITS_ACH7_TXBD_DESA_H \
(BIT_MASK_ACH7_TXBD_DESA_H << BIT_SHIFT_ACH7_TXBD_DESA_H)
#define BIT_CLEAR_ACH7_TXBD_DESA_H(x) ((x) & (~BITS_ACH7_TXBD_DESA_H))
#define BIT_GET_ACH7_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH7_TXBD_DESA_H) & BIT_MASK_ACH7_TXBD_DESA_H)
#define BIT_SET_ACH7_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH7_TXBD_DESA_H(x) | BIT_ACH7_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI8Q_TXBD_DESA (Offset 0x1378) */
#define BIT_SHIFT_HI8Q_TXBD_DESA 0
#define BIT_MASK_HI8Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI8Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI8Q_TXBD_DESA) << BIT_SHIFT_HI8Q_TXBD_DESA)
#define BITS_HI8Q_TXBD_DESA \
(BIT_MASK_HI8Q_TXBD_DESA << BIT_SHIFT_HI8Q_TXBD_DESA)
#define BIT_CLEAR_HI8Q_TXBD_DESA(x) ((x) & (~BITS_HI8Q_TXBD_DESA))
#define BIT_GET_HI8Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI8Q_TXBD_DESA) & BIT_MASK_HI8Q_TXBD_DESA)
#define BIT_SET_HI8Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI8Q_TXBD_DESA(x) | BIT_HI8Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH8_TXBD_DESA_L (Offset 0x1378) */
#define BIT_SHIFT_ACH8_TXBD_DESA_L 0
#define BIT_MASK_ACH8_TXBD_DESA_L 0xffffffffL
#define BIT_ACH8_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH8_TXBD_DESA_L) << BIT_SHIFT_ACH8_TXBD_DESA_L)
#define BITS_ACH8_TXBD_DESA_L \
(BIT_MASK_ACH8_TXBD_DESA_L << BIT_SHIFT_ACH8_TXBD_DESA_L)
#define BIT_CLEAR_ACH8_TXBD_DESA_L(x) ((x) & (~BITS_ACH8_TXBD_DESA_L))
#define BIT_GET_ACH8_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH8_TXBD_DESA_L) & BIT_MASK_ACH8_TXBD_DESA_L)
#define BIT_SET_ACH8_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH8_TXBD_DESA_L(x) | BIT_ACH8_TXBD_DESA_L(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_DMA_CFG_V1 (Offset 0x137C) */
#define BIT_TXHCI_EN_V1 BIT(26)
#define BIT_TXHCI_IDLE_V1 BIT(25)
#define BIT_DMA_PRI_EN_V1 BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH8_TXBD_DESA_H (Offset 0x137C) */
#define BIT_SHIFT_ACH8_TXBD_DESA_H 0
#define BIT_MASK_ACH8_TXBD_DESA_H 0xffffffffL
#define BIT_ACH8_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH8_TXBD_DESA_H) << BIT_SHIFT_ACH8_TXBD_DESA_H)
#define BITS_ACH8_TXBD_DESA_H \
(BIT_MASK_ACH8_TXBD_DESA_H << BIT_SHIFT_ACH8_TXBD_DESA_H)
#define BIT_CLEAR_ACH8_TXBD_DESA_H(x) ((x) & (~BITS_ACH8_TXBD_DESA_H))
#define BIT_GET_ACH8_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH8_TXBD_DESA_H) & BIT_MASK_ACH8_TXBD_DESA_H)
#define BIT_SET_ACH8_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH8_TXBD_DESA_H(x) | BIT_ACH8_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI9Q_TXBD_DESA (Offset 0x1380) */
#define BIT_SHIFT_HI9Q_TXBD_DESA 0
#define BIT_MASK_HI9Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI9Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI9Q_TXBD_DESA) << BIT_SHIFT_HI9Q_TXBD_DESA)
#define BITS_HI9Q_TXBD_DESA \
(BIT_MASK_HI9Q_TXBD_DESA << BIT_SHIFT_HI9Q_TXBD_DESA)
#define BIT_CLEAR_HI9Q_TXBD_DESA(x) ((x) & (~BITS_HI9Q_TXBD_DESA))
#define BIT_GET_HI9Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI9Q_TXBD_DESA) & BIT_MASK_HI9Q_TXBD_DESA)
#define BIT_SET_HI9Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI9Q_TXBD_DESA(x) | BIT_HI9Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH9_TXBD_DESA_L (Offset 0x1380) */
#define BIT_SHIFT_ACH9_TXBD_DESA_L 0
#define BIT_MASK_ACH9_TXBD_DESA_L 0xffffffffL
#define BIT_ACH9_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH9_TXBD_DESA_L) << BIT_SHIFT_ACH9_TXBD_DESA_L)
#define BITS_ACH9_TXBD_DESA_L \
(BIT_MASK_ACH9_TXBD_DESA_L << BIT_SHIFT_ACH9_TXBD_DESA_L)
#define BIT_CLEAR_ACH9_TXBD_DESA_L(x) ((x) & (~BITS_ACH9_TXBD_DESA_L))
#define BIT_GET_ACH9_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH9_TXBD_DESA_L) & BIT_MASK_ACH9_TXBD_DESA_L)
#define BIT_SET_ACH9_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH9_TXBD_DESA_L(x) | BIT_ACH9_TXBD_DESA_L(v))
/* 2 REG_ACH9_TXBD_DESA_H (Offset 0x1384) */
#define BIT_SHIFT_ACH9_TXBD_DESA_H 0
#define BIT_MASK_ACH9_TXBD_DESA_H 0xffffffffL
#define BIT_ACH9_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH9_TXBD_DESA_H) << BIT_SHIFT_ACH9_TXBD_DESA_H)
#define BITS_ACH9_TXBD_DESA_H \
(BIT_MASK_ACH9_TXBD_DESA_H << BIT_SHIFT_ACH9_TXBD_DESA_H)
#define BIT_CLEAR_ACH9_TXBD_DESA_H(x) ((x) & (~BITS_ACH9_TXBD_DESA_H))
#define BIT_GET_ACH9_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH9_TXBD_DESA_H) & BIT_MASK_ACH9_TXBD_DESA_H)
#define BIT_SET_ACH9_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH9_TXBD_DESA_H(x) | BIT_ACH9_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI10Q_TXBD_DESA (Offset 0x1388) */
#define BIT_SHIFT_HI10Q_TXBD_DESA 0
#define BIT_MASK_HI10Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI10Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI10Q_TXBD_DESA) << BIT_SHIFT_HI10Q_TXBD_DESA)
#define BITS_HI10Q_TXBD_DESA \
(BIT_MASK_HI10Q_TXBD_DESA << BIT_SHIFT_HI10Q_TXBD_DESA)
#define BIT_CLEAR_HI10Q_TXBD_DESA(x) ((x) & (~BITS_HI10Q_TXBD_DESA))
#define BIT_GET_HI10Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI10Q_TXBD_DESA) & BIT_MASK_HI10Q_TXBD_DESA)
#define BIT_SET_HI10Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI10Q_TXBD_DESA(x) | BIT_HI10Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH10_TXBD_DESA_L (Offset 0x1388) */
#define BIT_SHIFT_ACH10_TXBD_DESA_L 0
#define BIT_MASK_ACH10_TXBD_DESA_L 0xffffffffL
#define BIT_ACH10_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH10_TXBD_DESA_L) << BIT_SHIFT_ACH10_TXBD_DESA_L)
#define BITS_ACH10_TXBD_DESA_L \
(BIT_MASK_ACH10_TXBD_DESA_L << BIT_SHIFT_ACH10_TXBD_DESA_L)
#define BIT_CLEAR_ACH10_TXBD_DESA_L(x) ((x) & (~BITS_ACH10_TXBD_DESA_L))
#define BIT_GET_ACH10_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH10_TXBD_DESA_L) & BIT_MASK_ACH10_TXBD_DESA_L)
#define BIT_SET_ACH10_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH10_TXBD_DESA_L(x) | BIT_ACH10_TXBD_DESA_L(v))
/* 2 REG_ACH10_TXBD_DESA_H (Offset 0x138C) */
#define BIT_SHIFT_ACH10_TXBD_DESA_H 0
#define BIT_MASK_ACH10_TXBD_DESA_H 0xffffffffL
#define BIT_ACH10_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH10_TXBD_DESA_H) << BIT_SHIFT_ACH10_TXBD_DESA_H)
#define BITS_ACH10_TXBD_DESA_H \
(BIT_MASK_ACH10_TXBD_DESA_H << BIT_SHIFT_ACH10_TXBD_DESA_H)
#define BIT_CLEAR_ACH10_TXBD_DESA_H(x) ((x) & (~BITS_ACH10_TXBD_DESA_H))
#define BIT_GET_ACH10_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH10_TXBD_DESA_H) & BIT_MASK_ACH10_TXBD_DESA_H)
#define BIT_SET_ACH10_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH10_TXBD_DESA_H(x) | BIT_ACH10_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI11Q_TXBD_DESA (Offset 0x1390) */
#define BIT_SHIFT_HI11Q_TXBD_DESA 0
#define BIT_MASK_HI11Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI11Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI11Q_TXBD_DESA) << BIT_SHIFT_HI11Q_TXBD_DESA)
#define BITS_HI11Q_TXBD_DESA \
(BIT_MASK_HI11Q_TXBD_DESA << BIT_SHIFT_HI11Q_TXBD_DESA)
#define BIT_CLEAR_HI11Q_TXBD_DESA(x) ((x) & (~BITS_HI11Q_TXBD_DESA))
#define BIT_GET_HI11Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI11Q_TXBD_DESA) & BIT_MASK_HI11Q_TXBD_DESA)
#define BIT_SET_HI11Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI11Q_TXBD_DESA(x) | BIT_HI11Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH11_TXBD_DESA_L (Offset 0x1390) */
#define BIT_SHIFT_ACH11_TXBD_DESA_L 0
#define BIT_MASK_ACH11_TXBD_DESA_L 0xffffffffL
#define BIT_ACH11_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH11_TXBD_DESA_L) << BIT_SHIFT_ACH11_TXBD_DESA_L)
#define BITS_ACH11_TXBD_DESA_L \
(BIT_MASK_ACH11_TXBD_DESA_L << BIT_SHIFT_ACH11_TXBD_DESA_L)
#define BIT_CLEAR_ACH11_TXBD_DESA_L(x) ((x) & (~BITS_ACH11_TXBD_DESA_L))
#define BIT_GET_ACH11_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH11_TXBD_DESA_L) & BIT_MASK_ACH11_TXBD_DESA_L)
#define BIT_SET_ACH11_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH11_TXBD_DESA_L(x) | BIT_ACH11_TXBD_DESA_L(v))
/* 2 REG_ACH11_TXBD_DESA_H (Offset 0x1394) */
#define BIT_SHIFT_ACH11_TXBD_DESA_H 0
#define BIT_MASK_ACH11_TXBD_DESA_H 0xffffffffL
#define BIT_ACH11_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH11_TXBD_DESA_H) << BIT_SHIFT_ACH11_TXBD_DESA_H)
#define BITS_ACH11_TXBD_DESA_H \
(BIT_MASK_ACH11_TXBD_DESA_H << BIT_SHIFT_ACH11_TXBD_DESA_H)
#define BIT_CLEAR_ACH11_TXBD_DESA_H(x) ((x) & (~BITS_ACH11_TXBD_DESA_H))
#define BIT_GET_ACH11_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH11_TXBD_DESA_H) & BIT_MASK_ACH11_TXBD_DESA_H)
#define BIT_SET_ACH11_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH11_TXBD_DESA_H(x) | BIT_ACH11_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI12Q_TXBD_DESA (Offset 0x1398) */
#define BIT_SHIFT_HI12Q_TXBD_DESA 0
#define BIT_MASK_HI12Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI12Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI12Q_TXBD_DESA) << BIT_SHIFT_HI12Q_TXBD_DESA)
#define BITS_HI12Q_TXBD_DESA \
(BIT_MASK_HI12Q_TXBD_DESA << BIT_SHIFT_HI12Q_TXBD_DESA)
#define BIT_CLEAR_HI12Q_TXBD_DESA(x) ((x) & (~BITS_HI12Q_TXBD_DESA))
#define BIT_GET_HI12Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI12Q_TXBD_DESA) & BIT_MASK_HI12Q_TXBD_DESA)
#define BIT_SET_HI12Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI12Q_TXBD_DESA(x) | BIT_HI12Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH12_TXBD_DESA_L (Offset 0x1398) */
#define BIT_SHIFT_ACH12_TXBD_DESA_L 0
#define BIT_MASK_ACH12_TXBD_DESA_L 0xffffffffL
#define BIT_ACH12_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH12_TXBD_DESA_L) << BIT_SHIFT_ACH12_TXBD_DESA_L)
#define BITS_ACH12_TXBD_DESA_L \
(BIT_MASK_ACH12_TXBD_DESA_L << BIT_SHIFT_ACH12_TXBD_DESA_L)
#define BIT_CLEAR_ACH12_TXBD_DESA_L(x) ((x) & (~BITS_ACH12_TXBD_DESA_L))
#define BIT_GET_ACH12_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH12_TXBD_DESA_L) & BIT_MASK_ACH12_TXBD_DESA_L)
#define BIT_SET_ACH12_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH12_TXBD_DESA_L(x) | BIT_ACH12_TXBD_DESA_L(v))
/* 2 REG_ACH12_TXBD_DESA_H (Offset 0x139C) */
#define BIT_SHIFT_ACH12_TXBD_DESA_H 0
#define BIT_MASK_ACH12_TXBD_DESA_H 0xffffffffL
#define BIT_ACH12_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH12_TXBD_DESA_H) << BIT_SHIFT_ACH12_TXBD_DESA_H)
#define BITS_ACH12_TXBD_DESA_H \
(BIT_MASK_ACH12_TXBD_DESA_H << BIT_SHIFT_ACH12_TXBD_DESA_H)
#define BIT_CLEAR_ACH12_TXBD_DESA_H(x) ((x) & (~BITS_ACH12_TXBD_DESA_H))
#define BIT_GET_ACH12_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH12_TXBD_DESA_H) & BIT_MASK_ACH12_TXBD_DESA_H)
#define BIT_SET_ACH12_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH12_TXBD_DESA_H(x) | BIT_ACH12_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI13Q_TXBD_DESA (Offset 0x13A0) */
#define BIT_SHIFT_HI13Q_TXBD_DESA 0
#define BIT_MASK_HI13Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI13Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI13Q_TXBD_DESA) << BIT_SHIFT_HI13Q_TXBD_DESA)
#define BITS_HI13Q_TXBD_DESA \
(BIT_MASK_HI13Q_TXBD_DESA << BIT_SHIFT_HI13Q_TXBD_DESA)
#define BIT_CLEAR_HI13Q_TXBD_DESA(x) ((x) & (~BITS_HI13Q_TXBD_DESA))
#define BIT_GET_HI13Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI13Q_TXBD_DESA) & BIT_MASK_HI13Q_TXBD_DESA)
#define BIT_SET_HI13Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI13Q_TXBD_DESA(x) | BIT_HI13Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH13_TXBD_DESA_L (Offset 0x13A0) */
#define BIT_SHIFT_ACH13_TXBD_DESA_L 0
#define BIT_MASK_ACH13_TXBD_DESA_L 0xffffffffL
#define BIT_ACH13_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH13_TXBD_DESA_L) << BIT_SHIFT_ACH13_TXBD_DESA_L)
#define BITS_ACH13_TXBD_DESA_L \
(BIT_MASK_ACH13_TXBD_DESA_L << BIT_SHIFT_ACH13_TXBD_DESA_L)
#define BIT_CLEAR_ACH13_TXBD_DESA_L(x) ((x) & (~BITS_ACH13_TXBD_DESA_L))
#define BIT_GET_ACH13_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH13_TXBD_DESA_L) & BIT_MASK_ACH13_TXBD_DESA_L)
#define BIT_SET_ACH13_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH13_TXBD_DESA_L(x) | BIT_ACH13_TXBD_DESA_L(v))
/* 2 REG_ACH13_TXBD_DESA_H (Offset 0x13A4) */
#define BIT_SHIFT_ACH13_TXBD_DESA_H 0
#define BIT_MASK_ACH13_TXBD_DESA_H 0xffffffffL
#define BIT_ACH13_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH13_TXBD_DESA_H) << BIT_SHIFT_ACH13_TXBD_DESA_H)
#define BITS_ACH13_TXBD_DESA_H \
(BIT_MASK_ACH13_TXBD_DESA_H << BIT_SHIFT_ACH13_TXBD_DESA_H)
#define BIT_CLEAR_ACH13_TXBD_DESA_H(x) ((x) & (~BITS_ACH13_TXBD_DESA_H))
#define BIT_GET_ACH13_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH13_TXBD_DESA_H) & BIT_MASK_ACH13_TXBD_DESA_H)
#define BIT_SET_ACH13_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH13_TXBD_DESA_H(x) | BIT_ACH13_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI14Q_TXBD_DESA (Offset 0x13A8) */
#define BIT_SHIFT_HI14Q_TXBD_DESA 0
#define BIT_MASK_HI14Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI14Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI14Q_TXBD_DESA) << BIT_SHIFT_HI14Q_TXBD_DESA)
#define BITS_HI14Q_TXBD_DESA \
(BIT_MASK_HI14Q_TXBD_DESA << BIT_SHIFT_HI14Q_TXBD_DESA)
#define BIT_CLEAR_HI14Q_TXBD_DESA(x) ((x) & (~BITS_HI14Q_TXBD_DESA))
#define BIT_GET_HI14Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI14Q_TXBD_DESA) & BIT_MASK_HI14Q_TXBD_DESA)
#define BIT_SET_HI14Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI14Q_TXBD_DESA(x) | BIT_HI14Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI0Q_TXBD_DESA_L (Offset 0x13A8) */
#define BIT_SHIFT_HI0Q_TXBD_DESA_L 0
#define BIT_MASK_HI0Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI0Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_L) << BIT_SHIFT_HI0Q_TXBD_DESA_L)
#define BITS_HI0Q_TXBD_DESA_L \
(BIT_MASK_HI0Q_TXBD_DESA_L << BIT_SHIFT_HI0Q_TXBD_DESA_L)
#define BIT_CLEAR_HI0Q_TXBD_DESA_L(x) ((x) & (~BITS_HI0Q_TXBD_DESA_L))
#define BIT_GET_HI0Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_L) & BIT_MASK_HI0Q_TXBD_DESA_L)
#define BIT_SET_HI0Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_L(x) | BIT_HI0Q_TXBD_DESA_L(v))
/* 2 REG_HI0Q_TXBD_DESA_H (Offset 0x13AC) */
#define BIT_SHIFT_HI0Q_TXBD_DESA_H 0
#define BIT_MASK_HI0Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI0Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_H) << BIT_SHIFT_HI0Q_TXBD_DESA_H)
#define BITS_HI0Q_TXBD_DESA_H \
(BIT_MASK_HI0Q_TXBD_DESA_H << BIT_SHIFT_HI0Q_TXBD_DESA_H)
#define BIT_CLEAR_HI0Q_TXBD_DESA_H(x) ((x) & (~BITS_HI0Q_TXBD_DESA_H))
#define BIT_GET_HI0Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_H) & BIT_MASK_HI0Q_TXBD_DESA_H)
#define BIT_SET_HI0Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_H(x) | BIT_HI0Q_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI15Q_TXBD_DESA (Offset 0x13B0) */
#define BIT_SHIFT_HI15Q_TXBD_DESA 0
#define BIT_MASK_HI15Q_TXBD_DESA 0xffffffffffffffffL
#define BIT_HI15Q_TXBD_DESA(x) \
(((x) & BIT_MASK_HI15Q_TXBD_DESA) << BIT_SHIFT_HI15Q_TXBD_DESA)
#define BITS_HI15Q_TXBD_DESA \
(BIT_MASK_HI15Q_TXBD_DESA << BIT_SHIFT_HI15Q_TXBD_DESA)
#define BIT_CLEAR_HI15Q_TXBD_DESA(x) ((x) & (~BITS_HI15Q_TXBD_DESA))
#define BIT_GET_HI15Q_TXBD_DESA(x) \
(((x) >> BIT_SHIFT_HI15Q_TXBD_DESA) & BIT_MASK_HI15Q_TXBD_DESA)
#define BIT_SET_HI15Q_TXBD_DESA(x, v) \
(BIT_CLEAR_HI15Q_TXBD_DESA(x) | BIT_HI15Q_TXBD_DESA(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI1Q_TXBD_DESA_L (Offset 0x13B0) */
#define BIT_SHIFT_HI1Q_TXBD_DESA_L 0
#define BIT_MASK_HI1Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI1Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_L) << BIT_SHIFT_HI1Q_TXBD_DESA_L)
#define BITS_HI1Q_TXBD_DESA_L \
(BIT_MASK_HI1Q_TXBD_DESA_L << BIT_SHIFT_HI1Q_TXBD_DESA_L)
#define BIT_CLEAR_HI1Q_TXBD_DESA_L(x) ((x) & (~BITS_HI1Q_TXBD_DESA_L))
#define BIT_GET_HI1Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_L) & BIT_MASK_HI1Q_TXBD_DESA_L)
#define BIT_SET_HI1Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_L(x) | BIT_HI1Q_TXBD_DESA_L(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_HISR0_V1 (Offset 0x13B4) */
#define BIT_PRE_TX_ERR_INT BIT(31)
#define BIT_HISR1_IND BIT(11)
#define BIT_TXDMAOK_CHANNEL15 BIT(7)
#define BIT_TXDMAOK_CHANNEL14 BIT(6)
#define BIT_TXDMAOK_CHANNEL3 BIT(5)
#define BIT_TXDMAOK_CHANNEL2 BIT(4)
#define BIT_TXDMAOK_CHANNEL1 BIT(3)
#define BIT_TXDMAOK_CHANNEL0 BIT(2)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI1Q_TXBD_DESA_H (Offset 0x13B4) */
#define BIT_SHIFT_HI1Q_TXBD_DESA_H 0
#define BIT_MASK_HI1Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI1Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_H) << BIT_SHIFT_HI1Q_TXBD_DESA_H)
#define BITS_HI1Q_TXBD_DESA_H \
(BIT_MASK_HI1Q_TXBD_DESA_H << BIT_SHIFT_HI1Q_TXBD_DESA_H)
#define BIT_CLEAR_HI1Q_TXBD_DESA_H(x) ((x) & (~BITS_HI1Q_TXBD_DESA_H))
#define BIT_GET_HI1Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_H) & BIT_MASK_HI1Q_TXBD_DESA_H)
#define BIT_SET_HI1Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_H(x) | BIT_HI1Q_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI8Q_TXBD_NUM (Offset 0x13B8) */
#define BIT_HI8Q_FLAG BIT(14)
#define BIT_SHIFT_HI8Q_DESC_MODE 12
#define BIT_MASK_HI8Q_DESC_MODE 0x3
#define BIT_HI8Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI8Q_DESC_MODE) << BIT_SHIFT_HI8Q_DESC_MODE)
#define BITS_HI8Q_DESC_MODE \
(BIT_MASK_HI8Q_DESC_MODE << BIT_SHIFT_HI8Q_DESC_MODE)
#define BIT_CLEAR_HI8Q_DESC_MODE(x) ((x) & (~BITS_HI8Q_DESC_MODE))
#define BIT_GET_HI8Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI8Q_DESC_MODE) & BIT_MASK_HI8Q_DESC_MODE)
#define BIT_SET_HI8Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI8Q_DESC_MODE(x) | BIT_HI8Q_DESC_MODE(v))
#define BIT_SHIFT_HI8Q_DESC_NUM 0
#define BIT_MASK_HI8Q_DESC_NUM 0xfff
#define BIT_HI8Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI8Q_DESC_NUM) << BIT_SHIFT_HI8Q_DESC_NUM)
#define BITS_HI8Q_DESC_NUM (BIT_MASK_HI8Q_DESC_NUM << BIT_SHIFT_HI8Q_DESC_NUM)
#define BIT_CLEAR_HI8Q_DESC_NUM(x) ((x) & (~BITS_HI8Q_DESC_NUM))
#define BIT_GET_HI8Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI8Q_DESC_NUM) & BIT_MASK_HI8Q_DESC_NUM)
#define BIT_SET_HI8Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI8Q_DESC_NUM(x) | BIT_HI8Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI2Q_TXBD_DESA_L (Offset 0x13B8) */
#define BIT_SHIFT_HI2Q_TXBD_DESA_L 0
#define BIT_MASK_HI2Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI2Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_L) << BIT_SHIFT_HI2Q_TXBD_DESA_L)
#define BITS_HI2Q_TXBD_DESA_L \
(BIT_MASK_HI2Q_TXBD_DESA_L << BIT_SHIFT_HI2Q_TXBD_DESA_L)
#define BIT_CLEAR_HI2Q_TXBD_DESA_L(x) ((x) & (~BITS_HI2Q_TXBD_DESA_L))
#define BIT_GET_HI2Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_L) & BIT_MASK_HI2Q_TXBD_DESA_L)
#define BIT_SET_HI2Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_L(x) | BIT_HI2Q_TXBD_DESA_L(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI9Q_TXBD_NUM (Offset 0x13BA) */
#define BIT_HI9Q_FLAG BIT(14)
#define BIT_SHIFT_HI9Q_DESC_MODE 12
#define BIT_MASK_HI9Q_DESC_MODE 0x3
#define BIT_HI9Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI9Q_DESC_MODE) << BIT_SHIFT_HI9Q_DESC_MODE)
#define BITS_HI9Q_DESC_MODE \
(BIT_MASK_HI9Q_DESC_MODE << BIT_SHIFT_HI9Q_DESC_MODE)
#define BIT_CLEAR_HI9Q_DESC_MODE(x) ((x) & (~BITS_HI9Q_DESC_MODE))
#define BIT_GET_HI9Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI9Q_DESC_MODE) & BIT_MASK_HI9Q_DESC_MODE)
#define BIT_SET_HI9Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI9Q_DESC_MODE(x) | BIT_HI9Q_DESC_MODE(v))
#define BIT_SHIFT_HI9Q_DESC_NUM 0
#define BIT_MASK_HI9Q_DESC_NUM 0xfff
#define BIT_HI9Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI9Q_DESC_NUM) << BIT_SHIFT_HI9Q_DESC_NUM)
#define BITS_HI9Q_DESC_NUM (BIT_MASK_HI9Q_DESC_NUM << BIT_SHIFT_HI9Q_DESC_NUM)
#define BIT_CLEAR_HI9Q_DESC_NUM(x) ((x) & (~BITS_HI9Q_DESC_NUM))
#define BIT_GET_HI9Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI9Q_DESC_NUM) & BIT_MASK_HI9Q_DESC_NUM)
#define BIT_SET_HI9Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI9Q_DESC_NUM(x) | BIT_HI9Q_DESC_NUM(v))
/* 2 REG_HI10Q_TXBD_NUM (Offset 0x13BC) */
#define BIT_HI10Q_FLAG BIT(14)
#define BIT_SHIFT_HI10Q_DESC_MODE 12
#define BIT_MASK_HI10Q_DESC_MODE 0x3
#define BIT_HI10Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI10Q_DESC_MODE) << BIT_SHIFT_HI10Q_DESC_MODE)
#define BITS_HI10Q_DESC_MODE \
(BIT_MASK_HI10Q_DESC_MODE << BIT_SHIFT_HI10Q_DESC_MODE)
#define BIT_CLEAR_HI10Q_DESC_MODE(x) ((x) & (~BITS_HI10Q_DESC_MODE))
#define BIT_GET_HI10Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI10Q_DESC_MODE) & BIT_MASK_HI10Q_DESC_MODE)
#define BIT_SET_HI10Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI10Q_DESC_MODE(x) | BIT_HI10Q_DESC_MODE(v))
#define BIT_SHIFT_HI10Q_DESC_NUM 0
#define BIT_MASK_HI10Q_DESC_NUM 0xfff
#define BIT_HI10Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI10Q_DESC_NUM) << BIT_SHIFT_HI10Q_DESC_NUM)
#define BITS_HI10Q_DESC_NUM \
(BIT_MASK_HI10Q_DESC_NUM << BIT_SHIFT_HI10Q_DESC_NUM)
#define BIT_CLEAR_HI10Q_DESC_NUM(x) ((x) & (~BITS_HI10Q_DESC_NUM))
#define BIT_GET_HI10Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI10Q_DESC_NUM) & BIT_MASK_HI10Q_DESC_NUM)
#define BIT_SET_HI10Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI10Q_DESC_NUM(x) | BIT_HI10Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI2Q_TXBD_DESA_H (Offset 0x13BC) */
#define BIT_SHIFT_HI2Q_TXBD_DESA_H 0
#define BIT_MASK_HI2Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI2Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_H) << BIT_SHIFT_HI2Q_TXBD_DESA_H)
#define BITS_HI2Q_TXBD_DESA_H \
(BIT_MASK_HI2Q_TXBD_DESA_H << BIT_SHIFT_HI2Q_TXBD_DESA_H)
#define BIT_CLEAR_HI2Q_TXBD_DESA_H(x) ((x) & (~BITS_HI2Q_TXBD_DESA_H))
#define BIT_GET_HI2Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_H) & BIT_MASK_HI2Q_TXBD_DESA_H)
#define BIT_SET_HI2Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_H(x) | BIT_HI2Q_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI11Q_TXBD_NUM (Offset 0x13BE) */
#define BIT_HI11Q_FLAG BIT(14)
#define BIT_SHIFT_HI11Q_DESC_MODE 12
#define BIT_MASK_HI11Q_DESC_MODE 0x3
#define BIT_HI11Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI11Q_DESC_MODE) << BIT_SHIFT_HI11Q_DESC_MODE)
#define BITS_HI11Q_DESC_MODE \
(BIT_MASK_HI11Q_DESC_MODE << BIT_SHIFT_HI11Q_DESC_MODE)
#define BIT_CLEAR_HI11Q_DESC_MODE(x) ((x) & (~BITS_HI11Q_DESC_MODE))
#define BIT_GET_HI11Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI11Q_DESC_MODE) & BIT_MASK_HI11Q_DESC_MODE)
#define BIT_SET_HI11Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI11Q_DESC_MODE(x) | BIT_HI11Q_DESC_MODE(v))
#define BIT_SHIFT_HI11Q_DESC_NUM 0
#define BIT_MASK_HI11Q_DESC_NUM 0xfff
#define BIT_HI11Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI11Q_DESC_NUM) << BIT_SHIFT_HI11Q_DESC_NUM)
#define BITS_HI11Q_DESC_NUM \
(BIT_MASK_HI11Q_DESC_NUM << BIT_SHIFT_HI11Q_DESC_NUM)
#define BIT_CLEAR_HI11Q_DESC_NUM(x) ((x) & (~BITS_HI11Q_DESC_NUM))
#define BIT_GET_HI11Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI11Q_DESC_NUM) & BIT_MASK_HI11Q_DESC_NUM)
#define BIT_SET_HI11Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI11Q_DESC_NUM(x) | BIT_HI11Q_DESC_NUM(v))
/* 2 REG_HI12Q_TXBD_NUM (Offset 0x13C0) */
#define BIT_HI12Q_FLAG BIT(14)
#define BIT_SHIFT_HI12Q_DESC_MODE 12
#define BIT_MASK_HI12Q_DESC_MODE 0x3
#define BIT_HI12Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI12Q_DESC_MODE) << BIT_SHIFT_HI12Q_DESC_MODE)
#define BITS_HI12Q_DESC_MODE \
(BIT_MASK_HI12Q_DESC_MODE << BIT_SHIFT_HI12Q_DESC_MODE)
#define BIT_CLEAR_HI12Q_DESC_MODE(x) ((x) & (~BITS_HI12Q_DESC_MODE))
#define BIT_GET_HI12Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI12Q_DESC_MODE) & BIT_MASK_HI12Q_DESC_MODE)
#define BIT_SET_HI12Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI12Q_DESC_MODE(x) | BIT_HI12Q_DESC_MODE(v))
#define BIT_SHIFT_HI12Q_DESC_NUM 0
#define BIT_MASK_HI12Q_DESC_NUM 0xfff
#define BIT_HI12Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI12Q_DESC_NUM) << BIT_SHIFT_HI12Q_DESC_NUM)
#define BITS_HI12Q_DESC_NUM \
(BIT_MASK_HI12Q_DESC_NUM << BIT_SHIFT_HI12Q_DESC_NUM)
#define BIT_CLEAR_HI12Q_DESC_NUM(x) ((x) & (~BITS_HI12Q_DESC_NUM))
#define BIT_GET_HI12Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI12Q_DESC_NUM) & BIT_MASK_HI12Q_DESC_NUM)
#define BIT_SET_HI12Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI12Q_DESC_NUM(x) | BIT_HI12Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI3Q_TXBD_DESA_L (Offset 0x13C0) */
#define BIT_SHIFT_HI3Q_TXBD_DESA_L 0
#define BIT_MASK_HI3Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI3Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_L) << BIT_SHIFT_HI3Q_TXBD_DESA_L)
#define BITS_HI3Q_TXBD_DESA_L \
(BIT_MASK_HI3Q_TXBD_DESA_L << BIT_SHIFT_HI3Q_TXBD_DESA_L)
#define BIT_CLEAR_HI3Q_TXBD_DESA_L(x) ((x) & (~BITS_HI3Q_TXBD_DESA_L))
#define BIT_GET_HI3Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_L) & BIT_MASK_HI3Q_TXBD_DESA_L)
#define BIT_SET_HI3Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_L(x) | BIT_HI3Q_TXBD_DESA_L(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI13Q_TXBD_NUM (Offset 0x13C2) */
#define BIT_HI13Q_FLAG BIT(14)
#define BIT_SHIFT_HI13Q_DESC_MODE 12
#define BIT_MASK_HI13Q_DESC_MODE 0x3
#define BIT_HI13Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI13Q_DESC_MODE) << BIT_SHIFT_HI13Q_DESC_MODE)
#define BITS_HI13Q_DESC_MODE \
(BIT_MASK_HI13Q_DESC_MODE << BIT_SHIFT_HI13Q_DESC_MODE)
#define BIT_CLEAR_HI13Q_DESC_MODE(x) ((x) & (~BITS_HI13Q_DESC_MODE))
#define BIT_GET_HI13Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI13Q_DESC_MODE) & BIT_MASK_HI13Q_DESC_MODE)
#define BIT_SET_HI13Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI13Q_DESC_MODE(x) | BIT_HI13Q_DESC_MODE(v))
#define BIT_SHIFT_HI13Q_DESC_NUM 0
#define BIT_MASK_HI13Q_DESC_NUM 0xfff
#define BIT_HI13Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI13Q_DESC_NUM) << BIT_SHIFT_HI13Q_DESC_NUM)
#define BITS_HI13Q_DESC_NUM \
(BIT_MASK_HI13Q_DESC_NUM << BIT_SHIFT_HI13Q_DESC_NUM)
#define BIT_CLEAR_HI13Q_DESC_NUM(x) ((x) & (~BITS_HI13Q_DESC_NUM))
#define BIT_GET_HI13Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI13Q_DESC_NUM) & BIT_MASK_HI13Q_DESC_NUM)
#define BIT_SET_HI13Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI13Q_DESC_NUM(x) | BIT_HI13Q_DESC_NUM(v))
/* 2 REG_HI14Q_TXBD_NUM (Offset 0x13C4) */
#define BIT_HI14Q_FLAG BIT(14)
#define BIT_SHIFT_HI14Q_DESC_MODE 12
#define BIT_MASK_HI14Q_DESC_MODE 0x3
#define BIT_HI14Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI14Q_DESC_MODE) << BIT_SHIFT_HI14Q_DESC_MODE)
#define BITS_HI14Q_DESC_MODE \
(BIT_MASK_HI14Q_DESC_MODE << BIT_SHIFT_HI14Q_DESC_MODE)
#define BIT_CLEAR_HI14Q_DESC_MODE(x) ((x) & (~BITS_HI14Q_DESC_MODE))
#define BIT_GET_HI14Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI14Q_DESC_MODE) & BIT_MASK_HI14Q_DESC_MODE)
#define BIT_SET_HI14Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI14Q_DESC_MODE(x) | BIT_HI14Q_DESC_MODE(v))
#define BIT_SHIFT_HI14Q_DESC_NUM 0
#define BIT_MASK_HI14Q_DESC_NUM 0xfff
#define BIT_HI14Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI14Q_DESC_NUM) << BIT_SHIFT_HI14Q_DESC_NUM)
#define BITS_HI14Q_DESC_NUM \
(BIT_MASK_HI14Q_DESC_NUM << BIT_SHIFT_HI14Q_DESC_NUM)
#define BIT_CLEAR_HI14Q_DESC_NUM(x) ((x) & (~BITS_HI14Q_DESC_NUM))
#define BIT_GET_HI14Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI14Q_DESC_NUM) & BIT_MASK_HI14Q_DESC_NUM)
#define BIT_SET_HI14Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI14Q_DESC_NUM(x) | BIT_HI14Q_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI3Q_TXBD_DESA_H (Offset 0x13C4) */
#define BIT_SHIFT_HI3Q_TXBD_DESA_H 0
#define BIT_MASK_HI3Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI3Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_H) << BIT_SHIFT_HI3Q_TXBD_DESA_H)
#define BITS_HI3Q_TXBD_DESA_H \
(BIT_MASK_HI3Q_TXBD_DESA_H << BIT_SHIFT_HI3Q_TXBD_DESA_H)
#define BIT_CLEAR_HI3Q_TXBD_DESA_H(x) ((x) & (~BITS_HI3Q_TXBD_DESA_H))
#define BIT_GET_HI3Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_H) & BIT_MASK_HI3Q_TXBD_DESA_H)
#define BIT_SET_HI3Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_H(x) | BIT_HI3Q_TXBD_DESA_H(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_HI15Q_TXBD_NUM (Offset 0x13C6) */
#define BIT_HI15Q_FLAG BIT(14)
#define BIT_SHIFT_HI15Q_DESC_MODE 12
#define BIT_MASK_HI15Q_DESC_MODE 0x3
#define BIT_HI15Q_DESC_MODE(x) \
(((x) & BIT_MASK_HI15Q_DESC_MODE) << BIT_SHIFT_HI15Q_DESC_MODE)
#define BITS_HI15Q_DESC_MODE \
(BIT_MASK_HI15Q_DESC_MODE << BIT_SHIFT_HI15Q_DESC_MODE)
#define BIT_CLEAR_HI15Q_DESC_MODE(x) ((x) & (~BITS_HI15Q_DESC_MODE))
#define BIT_GET_HI15Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_HI15Q_DESC_MODE) & BIT_MASK_HI15Q_DESC_MODE)
#define BIT_SET_HI15Q_DESC_MODE(x, v) \
(BIT_CLEAR_HI15Q_DESC_MODE(x) | BIT_HI15Q_DESC_MODE(v))
#define BIT_SHIFT_HI15Q_DESC_NUM 0
#define BIT_MASK_HI15Q_DESC_NUM 0xfff
#define BIT_HI15Q_DESC_NUM(x) \
(((x) & BIT_MASK_HI15Q_DESC_NUM) << BIT_SHIFT_HI15Q_DESC_NUM)
#define BITS_HI15Q_DESC_NUM \
(BIT_MASK_HI15Q_DESC_NUM << BIT_SHIFT_HI15Q_DESC_NUM)
#define BIT_CLEAR_HI15Q_DESC_NUM(x) ((x) & (~BITS_HI15Q_DESC_NUM))
#define BIT_GET_HI15Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_HI15Q_DESC_NUM) & BIT_MASK_HI15Q_DESC_NUM)
#define BIT_SET_HI15Q_DESC_NUM(x, v) \
(BIT_CLEAR_HI15Q_DESC_NUM(x) | BIT_HI15Q_DESC_NUM(v))
/* 2 REG_HIQ_DMA_STOP (Offset 0x13C8) */
#define BIT_STOP_HI15Q BIT(7)
#define BIT_STOP_HI14Q BIT(6)
#define BIT_STOP_HI13Q BIT(5)
#define BIT_STOP_HI12Q BIT(4)
#define BIT_STOP_HI11Q BIT(3)
#define BIT_STOP_HI10Q BIT(2)
#define BIT_STOP_HI9Q BIT(1)
#define BIT_STOP_HI8Q BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HI4Q_TXBD_DESA_L (Offset 0x13C8) */
#define BIT_SHIFT_HI4Q_TXBD_DESA_L 0
#define BIT_MASK_HI4Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI4Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_L) << BIT_SHIFT_HI4Q_TXBD_DESA_L)
#define BITS_HI4Q_TXBD_DESA_L \
(BIT_MASK_HI4Q_TXBD_DESA_L << BIT_SHIFT_HI4Q_TXBD_DESA_L)
#define BIT_CLEAR_HI4Q_TXBD_DESA_L(x) ((x) & (~BITS_HI4Q_TXBD_DESA_L))
#define BIT_GET_HI4Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_L) & BIT_MASK_HI4Q_TXBD_DESA_L)
#define BIT_SET_HI4Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_L(x) | BIT_HI4Q_TXBD_DESA_L(v))
/* 2 REG_HI4Q_TXBD_DESA_H (Offset 0x13CC) */
#define BIT_SHIFT_HI4Q_TXBD_DESA_H 0
#define BIT_MASK_HI4Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI4Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_H) << BIT_SHIFT_HI4Q_TXBD_DESA_H)
#define BITS_HI4Q_TXBD_DESA_H \
(BIT_MASK_HI4Q_TXBD_DESA_H << BIT_SHIFT_HI4Q_TXBD_DESA_H)
#define BIT_CLEAR_HI4Q_TXBD_DESA_H(x) ((x) & (~BITS_HI4Q_TXBD_DESA_H))
#define BIT_GET_HI4Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_H) & BIT_MASK_HI4Q_TXBD_DESA_H)
#define BIT_SET_HI4Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_H(x) | BIT_HI4Q_TXBD_DESA_H(v))
/* 2 REG_HI5Q_TXBD_DESA_L (Offset 0x13D0) */
#define BIT_SHIFT_HI5Q_TXBD_DESA_L 0
#define BIT_MASK_HI5Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI5Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_L) << BIT_SHIFT_HI5Q_TXBD_DESA_L)
#define BITS_HI5Q_TXBD_DESA_L \
(BIT_MASK_HI5Q_TXBD_DESA_L << BIT_SHIFT_HI5Q_TXBD_DESA_L)
#define BIT_CLEAR_HI5Q_TXBD_DESA_L(x) ((x) & (~BITS_HI5Q_TXBD_DESA_L))
#define BIT_GET_HI5Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_L) & BIT_MASK_HI5Q_TXBD_DESA_L)
#define BIT_SET_HI5Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_L(x) | BIT_HI5Q_TXBD_DESA_L(v))
/* 2 REG_HI5Q_TXBD_DESA_H (Offset 0x13D4) */
#define BIT_SHIFT_HI5Q_TXBD_DESA_H 0
#define BIT_MASK_HI5Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI5Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_H) << BIT_SHIFT_HI5Q_TXBD_DESA_H)
#define BITS_HI5Q_TXBD_DESA_H \
(BIT_MASK_HI5Q_TXBD_DESA_H << BIT_SHIFT_HI5Q_TXBD_DESA_H)
#define BIT_CLEAR_HI5Q_TXBD_DESA_H(x) ((x) & (~BITS_HI5Q_TXBD_DESA_H))
#define BIT_GET_HI5Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_H) & BIT_MASK_HI5Q_TXBD_DESA_H)
#define BIT_SET_HI5Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_H(x) | BIT_HI5Q_TXBD_DESA_H(v))
/* 2 REG_HI6Q_TXBD_DESA_L (Offset 0x13D8) */
#define BIT_SHIFT_HI6Q_TXBD_DESA_L 0
#define BIT_MASK_HI6Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI6Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_L) << BIT_SHIFT_HI6Q_TXBD_DESA_L)
#define BITS_HI6Q_TXBD_DESA_L \
(BIT_MASK_HI6Q_TXBD_DESA_L << BIT_SHIFT_HI6Q_TXBD_DESA_L)
#define BIT_CLEAR_HI6Q_TXBD_DESA_L(x) ((x) & (~BITS_HI6Q_TXBD_DESA_L))
#define BIT_GET_HI6Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_L) & BIT_MASK_HI6Q_TXBD_DESA_L)
#define BIT_SET_HI6Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_L(x) | BIT_HI6Q_TXBD_DESA_L(v))
/* 2 REG_HI6Q_TXBD_DESA_H (Offset 0x13DC) */
#define BIT_SHIFT_HI6Q_TXBD_DESA_H 0
#define BIT_MASK_HI6Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI6Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_H) << BIT_SHIFT_HI6Q_TXBD_DESA_H)
#define BITS_HI6Q_TXBD_DESA_H \
(BIT_MASK_HI6Q_TXBD_DESA_H << BIT_SHIFT_HI6Q_TXBD_DESA_H)
#define BIT_CLEAR_HI6Q_TXBD_DESA_H(x) ((x) & (~BITS_HI6Q_TXBD_DESA_H))
#define BIT_GET_HI6Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_H) & BIT_MASK_HI6Q_TXBD_DESA_H)
#define BIT_SET_HI6Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_H(x) | BIT_HI6Q_TXBD_DESA_H(v))
/* 2 REG_HI7Q_TXBD_DESA_L (Offset 0x13E0) */
#define BIT_SHIFT_HI7Q_TXBD_DESA_L 0
#define BIT_MASK_HI7Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI7Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_L) << BIT_SHIFT_HI7Q_TXBD_DESA_L)
#define BITS_HI7Q_TXBD_DESA_L \
(BIT_MASK_HI7Q_TXBD_DESA_L << BIT_SHIFT_HI7Q_TXBD_DESA_L)
#define BIT_CLEAR_HI7Q_TXBD_DESA_L(x) ((x) & (~BITS_HI7Q_TXBD_DESA_L))
#define BIT_GET_HI7Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_L) & BIT_MASK_HI7Q_TXBD_DESA_L)
#define BIT_SET_HI7Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_L(x) | BIT_HI7Q_TXBD_DESA_L(v))
/* 2 REG_HI7Q_TXBD_DESA_H (Offset 0x13E4) */
#define BIT_SHIFT_HI7Q_TXBD_DESA_H 0
#define BIT_MASK_HI7Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI7Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_H) << BIT_SHIFT_HI7Q_TXBD_DESA_H)
#define BITS_HI7Q_TXBD_DESA_H \
(BIT_MASK_HI7Q_TXBD_DESA_H << BIT_SHIFT_HI7Q_TXBD_DESA_H)
#define BIT_CLEAR_HI7Q_TXBD_DESA_H(x) ((x) & (~BITS_HI7Q_TXBD_DESA_H))
#define BIT_GET_HI7Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_H) & BIT_MASK_HI7Q_TXBD_DESA_H)
#define BIT_SET_HI7Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_H(x) | BIT_HI7Q_TXBD_DESA_H(v))
/* 2 REG_ACH8_ACH9_TXBD_NUM (Offset 0x13E8) */
#define BIT_PCIE_ACH9_FLAG BIT(30)
#define BIT_SHIFT_ACH9_DESC_MODE 28
#define BIT_MASK_ACH9_DESC_MODE 0x3
#define BIT_ACH9_DESC_MODE(x) \
(((x) & BIT_MASK_ACH9_DESC_MODE) << BIT_SHIFT_ACH9_DESC_MODE)
#define BITS_ACH9_DESC_MODE \
(BIT_MASK_ACH9_DESC_MODE << BIT_SHIFT_ACH9_DESC_MODE)
#define BIT_CLEAR_ACH9_DESC_MODE(x) ((x) & (~BITS_ACH9_DESC_MODE))
#define BIT_GET_ACH9_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH9_DESC_MODE) & BIT_MASK_ACH9_DESC_MODE)
#define BIT_SET_ACH9_DESC_MODE(x, v) \
(BIT_CLEAR_ACH9_DESC_MODE(x) | BIT_ACH9_DESC_MODE(v))
#define BIT_SHIFT_ACH9_DESC_NUM 16
#define BIT_MASK_ACH9_DESC_NUM 0xfff
#define BIT_ACH9_DESC_NUM(x) \
(((x) & BIT_MASK_ACH9_DESC_NUM) << BIT_SHIFT_ACH9_DESC_NUM)
#define BITS_ACH9_DESC_NUM (BIT_MASK_ACH9_DESC_NUM << BIT_SHIFT_ACH9_DESC_NUM)
#define BIT_CLEAR_ACH9_DESC_NUM(x) ((x) & (~BITS_ACH9_DESC_NUM))
#define BIT_GET_ACH9_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH9_DESC_NUM) & BIT_MASK_ACH9_DESC_NUM)
#define BIT_SET_ACH9_DESC_NUM(x, v) \
(BIT_CLEAR_ACH9_DESC_NUM(x) | BIT_ACH9_DESC_NUM(v))
#define BIT_PCIE_ACH8_FLAG BIT(14)
#define BIT_SHIFT_ACH8_DESC_MODE 12
#define BIT_MASK_ACH8_DESC_MODE 0x3
#define BIT_ACH8_DESC_MODE(x) \
(((x) & BIT_MASK_ACH8_DESC_MODE) << BIT_SHIFT_ACH8_DESC_MODE)
#define BITS_ACH8_DESC_MODE \
(BIT_MASK_ACH8_DESC_MODE << BIT_SHIFT_ACH8_DESC_MODE)
#define BIT_CLEAR_ACH8_DESC_MODE(x) ((x) & (~BITS_ACH8_DESC_MODE))
#define BIT_GET_ACH8_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH8_DESC_MODE) & BIT_MASK_ACH8_DESC_MODE)
#define BIT_SET_ACH8_DESC_MODE(x, v) \
(BIT_CLEAR_ACH8_DESC_MODE(x) | BIT_ACH8_DESC_MODE(v))
#define BIT_SHIFT_ACH8_DESC_NUM 0
#define BIT_MASK_ACH8_DESC_NUM 0xfff
#define BIT_ACH8_DESC_NUM(x) \
(((x) & BIT_MASK_ACH8_DESC_NUM) << BIT_SHIFT_ACH8_DESC_NUM)
#define BITS_ACH8_DESC_NUM (BIT_MASK_ACH8_DESC_NUM << BIT_SHIFT_ACH8_DESC_NUM)
#define BIT_CLEAR_ACH8_DESC_NUM(x) ((x) & (~BITS_ACH8_DESC_NUM))
#define BIT_GET_ACH8_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH8_DESC_NUM) & BIT_MASK_ACH8_DESC_NUM)
#define BIT_SET_ACH8_DESC_NUM(x, v) \
(BIT_CLEAR_ACH8_DESC_NUM(x) | BIT_ACH8_DESC_NUM(v))
/* 2 REG_ACH10_ACH11_TXBD_NUM (Offset 0x13EC) */
#define BIT_PCIE_ACH11_FLAG BIT(30)
#define BIT_SHIFT_ACH11_DESC_MODE 28
#define BIT_MASK_ACH11_DESC_MODE 0x3
#define BIT_ACH11_DESC_MODE(x) \
(((x) & BIT_MASK_ACH11_DESC_MODE) << BIT_SHIFT_ACH11_DESC_MODE)
#define BITS_ACH11_DESC_MODE \
(BIT_MASK_ACH11_DESC_MODE << BIT_SHIFT_ACH11_DESC_MODE)
#define BIT_CLEAR_ACH11_DESC_MODE(x) ((x) & (~BITS_ACH11_DESC_MODE))
#define BIT_GET_ACH11_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH11_DESC_MODE) & BIT_MASK_ACH11_DESC_MODE)
#define BIT_SET_ACH11_DESC_MODE(x, v) \
(BIT_CLEAR_ACH11_DESC_MODE(x) | BIT_ACH11_DESC_MODE(v))
#define BIT_SHIFT_ACH11_DESC_NUM 16
#define BIT_MASK_ACH11_DESC_NUM 0xfff
#define BIT_ACH11_DESC_NUM(x) \
(((x) & BIT_MASK_ACH11_DESC_NUM) << BIT_SHIFT_ACH11_DESC_NUM)
#define BITS_ACH11_DESC_NUM \
(BIT_MASK_ACH11_DESC_NUM << BIT_SHIFT_ACH11_DESC_NUM)
#define BIT_CLEAR_ACH11_DESC_NUM(x) ((x) & (~BITS_ACH11_DESC_NUM))
#define BIT_GET_ACH11_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH11_DESC_NUM) & BIT_MASK_ACH11_DESC_NUM)
#define BIT_SET_ACH11_DESC_NUM(x, v) \
(BIT_CLEAR_ACH11_DESC_NUM(x) | BIT_ACH11_DESC_NUM(v))
#define BIT_PCIE_ACH10_FLAG BIT(14)
#define BIT_SHIFT_ACH10_DESC_MODE 12
#define BIT_MASK_ACH10_DESC_MODE 0x3
#define BIT_ACH10_DESC_MODE(x) \
(((x) & BIT_MASK_ACH10_DESC_MODE) << BIT_SHIFT_ACH10_DESC_MODE)
#define BITS_ACH10_DESC_MODE \
(BIT_MASK_ACH10_DESC_MODE << BIT_SHIFT_ACH10_DESC_MODE)
#define BIT_CLEAR_ACH10_DESC_MODE(x) ((x) & (~BITS_ACH10_DESC_MODE))
#define BIT_GET_ACH10_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH10_DESC_MODE) & BIT_MASK_ACH10_DESC_MODE)
#define BIT_SET_ACH10_DESC_MODE(x, v) \
(BIT_CLEAR_ACH10_DESC_MODE(x) | BIT_ACH10_DESC_MODE(v))
#define BIT_SHIFT_ACH10_DESC_NUM 0
#define BIT_MASK_ACH10_DESC_NUM 0xfff
#define BIT_ACH10_DESC_NUM(x) \
(((x) & BIT_MASK_ACH10_DESC_NUM) << BIT_SHIFT_ACH10_DESC_NUM)
#define BITS_ACH10_DESC_NUM \
(BIT_MASK_ACH10_DESC_NUM << BIT_SHIFT_ACH10_DESC_NUM)
#define BIT_CLEAR_ACH10_DESC_NUM(x) ((x) & (~BITS_ACH10_DESC_NUM))
#define BIT_GET_ACH10_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH10_DESC_NUM) & BIT_MASK_ACH10_DESC_NUM)
#define BIT_SET_ACH10_DESC_NUM(x, v) \
(BIT_CLEAR_ACH10_DESC_NUM(x) | BIT_ACH10_DESC_NUM(v))
/* 2 REG_ACH12_ACH13_TXBD_NUM (Offset 0x13F0) */
#define BIT_PCIE_ACH13_FLAG BIT(30)
#define BIT_SHIFT_ACH13_DESC_MODE 28
#define BIT_MASK_ACH13_DESC_MODE 0x3
#define BIT_ACH13_DESC_MODE(x) \
(((x) & BIT_MASK_ACH13_DESC_MODE) << BIT_SHIFT_ACH13_DESC_MODE)
#define BITS_ACH13_DESC_MODE \
(BIT_MASK_ACH13_DESC_MODE << BIT_SHIFT_ACH13_DESC_MODE)
#define BIT_CLEAR_ACH13_DESC_MODE(x) ((x) & (~BITS_ACH13_DESC_MODE))
#define BIT_GET_ACH13_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH13_DESC_MODE) & BIT_MASK_ACH13_DESC_MODE)
#define BIT_SET_ACH13_DESC_MODE(x, v) \
(BIT_CLEAR_ACH13_DESC_MODE(x) | BIT_ACH13_DESC_MODE(v))
#define BIT_SHIFT_ACH13_DESC_NUM 16
#define BIT_MASK_ACH13_DESC_NUM 0xfff
#define BIT_ACH13_DESC_NUM(x) \
(((x) & BIT_MASK_ACH13_DESC_NUM) << BIT_SHIFT_ACH13_DESC_NUM)
#define BITS_ACH13_DESC_NUM \
(BIT_MASK_ACH13_DESC_NUM << BIT_SHIFT_ACH13_DESC_NUM)
#define BIT_CLEAR_ACH13_DESC_NUM(x) ((x) & (~BITS_ACH13_DESC_NUM))
#define BIT_GET_ACH13_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH13_DESC_NUM) & BIT_MASK_ACH13_DESC_NUM)
#define BIT_SET_ACH13_DESC_NUM(x, v) \
(BIT_CLEAR_ACH13_DESC_NUM(x) | BIT_ACH13_DESC_NUM(v))
#define BIT_PCIE_ACH12_FLAG BIT(14)
#define BIT_SHIFT_ACH12_DESC_MODE 12
#define BIT_MASK_ACH12_DESC_MODE 0x3
#define BIT_ACH12_DESC_MODE(x) \
(((x) & BIT_MASK_ACH12_DESC_MODE) << BIT_SHIFT_ACH12_DESC_MODE)
#define BITS_ACH12_DESC_MODE \
(BIT_MASK_ACH12_DESC_MODE << BIT_SHIFT_ACH12_DESC_MODE)
#define BIT_CLEAR_ACH12_DESC_MODE(x) ((x) & (~BITS_ACH12_DESC_MODE))
#define BIT_GET_ACH12_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH12_DESC_MODE) & BIT_MASK_ACH12_DESC_MODE)
#define BIT_SET_ACH12_DESC_MODE(x, v) \
(BIT_CLEAR_ACH12_DESC_MODE(x) | BIT_ACH12_DESC_MODE(v))
#define BIT_SHIFT_ACH12_DESC_NUM 0
#define BIT_MASK_ACH12_DESC_NUM 0xfff
#define BIT_ACH12_DESC_NUM(x) \
(((x) & BIT_MASK_ACH12_DESC_NUM) << BIT_SHIFT_ACH12_DESC_NUM)
#define BITS_ACH12_DESC_NUM \
(BIT_MASK_ACH12_DESC_NUM << BIT_SHIFT_ACH12_DESC_NUM)
#define BIT_CLEAR_ACH12_DESC_NUM(x) ((x) & (~BITS_ACH12_DESC_NUM))
#define BIT_GET_ACH12_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH12_DESC_NUM) & BIT_MASK_ACH12_DESC_NUM)
#define BIT_SET_ACH12_DESC_NUM(x, v) \
(BIT_CLEAR_ACH12_DESC_NUM(x) | BIT_ACH12_DESC_NUM(v))
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_OLD_DEHANG (Offset 0x13F4) */
#define BIT_OLD_DEHANG BIT(1)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_ACH4_TXBD_DESA_L (Offset 0x13F8) */
#define BIT_SHIFT_ACH4_TXBD_DESA_L 0
#define BIT_MASK_ACH4_TXBD_DESA_L 0xffffffffL
#define BIT_ACH4_TXBD_DESA_L(x) \
(((x) & BIT_MASK_ACH4_TXBD_DESA_L) << BIT_SHIFT_ACH4_TXBD_DESA_L)
#define BITS_ACH4_TXBD_DESA_L \
(BIT_MASK_ACH4_TXBD_DESA_L << BIT_SHIFT_ACH4_TXBD_DESA_L)
#define BIT_CLEAR_ACH4_TXBD_DESA_L(x) ((x) & (~BITS_ACH4_TXBD_DESA_L))
#define BIT_GET_ACH4_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_ACH4_TXBD_DESA_L) & BIT_MASK_ACH4_TXBD_DESA_L)
#define BIT_SET_ACH4_TXBD_DESA_L(x, v) \
(BIT_CLEAR_ACH4_TXBD_DESA_L(x) | BIT_ACH4_TXBD_DESA_L(v))
/* 2 REG_ACH4_TXBD_DESA_H (Offset 0x13FC) */
#define BIT_SHIFT_ACH4_TXBD_DESA_H 0
#define BIT_MASK_ACH4_TXBD_DESA_H 0xffffffffL
#define BIT_ACH4_TXBD_DESA_H(x) \
(((x) & BIT_MASK_ACH4_TXBD_DESA_H) << BIT_SHIFT_ACH4_TXBD_DESA_H)
#define BITS_ACH4_TXBD_DESA_H \
(BIT_MASK_ACH4_TXBD_DESA_H << BIT_SHIFT_ACH4_TXBD_DESA_H)
#define BIT_CLEAR_ACH4_TXBD_DESA_H(x) ((x) & (~BITS_ACH4_TXBD_DESA_H))
#define BIT_GET_ACH4_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_ACH4_TXBD_DESA_H) & BIT_MASK_ACH4_TXBD_DESA_H)
#define BIT_SET_ACH4_TXBD_DESA_H(x, v) \
(BIT_CLEAR_ACH4_TXBD_DESA_H(x) | BIT_ACH4_TXBD_DESA_H(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q0_Q1_INFO (Offset 0x1400) */
#define BIT_SHIFT_AC1_PKT_INFO 16
#define BIT_MASK_AC1_PKT_INFO 0xfff
#define BIT_AC1_PKT_INFO(x) \
(((x) & BIT_MASK_AC1_PKT_INFO) << BIT_SHIFT_AC1_PKT_INFO)
#define BITS_AC1_PKT_INFO (BIT_MASK_AC1_PKT_INFO << BIT_SHIFT_AC1_PKT_INFO)
#define BIT_CLEAR_AC1_PKT_INFO(x) ((x) & (~BITS_AC1_PKT_INFO))
#define BIT_GET_AC1_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC1_PKT_INFO) & BIT_MASK_AC1_PKT_INFO)
#define BIT_SET_AC1_PKT_INFO(x, v) \
(BIT_CLEAR_AC1_PKT_INFO(x) | BIT_AC1_PKT_INFO(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_OFFSET (Offset 0x1400) */
#define BIT_SHIFT_MU_RATETABLE_OFFSET 16
#define BIT_MASK_MU_RATETABLE_OFFSET 0x1ff
#define BIT_MU_RATETABLE_OFFSET(x) \
(((x) & BIT_MASK_MU_RATETABLE_OFFSET) << BIT_SHIFT_MU_RATETABLE_OFFSET)
#define BITS_MU_RATETABLE_OFFSET \
(BIT_MASK_MU_RATETABLE_OFFSET << BIT_SHIFT_MU_RATETABLE_OFFSET)
#define BIT_CLEAR_MU_RATETABLE_OFFSET(x) ((x) & (~BITS_MU_RATETABLE_OFFSET))
#define BIT_GET_MU_RATETABLE_OFFSET(x) \
(((x) >> BIT_SHIFT_MU_RATETABLE_OFFSET) & BIT_MASK_MU_RATETABLE_OFFSET)
#define BIT_SET_MU_RATETABLE_OFFSET(x, v) \
(BIT_CLEAR_MU_RATETABLE_OFFSET(x) | BIT_MU_RATETABLE_OFFSET(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q0_Q1_INFO (Offset 0x1400) */
#define BIT_SHIFT_AC0_PKT_INFO 0
#define BIT_MASK_AC0_PKT_INFO 0xfff
#define BIT_AC0_PKT_INFO(x) \
(((x) & BIT_MASK_AC0_PKT_INFO) << BIT_SHIFT_AC0_PKT_INFO)
#define BITS_AC0_PKT_INFO (BIT_MASK_AC0_PKT_INFO << BIT_SHIFT_AC0_PKT_INFO)
#define BIT_CLEAR_AC0_PKT_INFO(x) ((x) & (~BITS_AC0_PKT_INFO))
#define BIT_GET_AC0_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC0_PKT_INFO) & BIT_MASK_AC0_PKT_INFO)
#define BIT_SET_AC0_PKT_INFO(x, v) \
(BIT_CLEAR_AC0_PKT_INFO(x) | BIT_AC0_PKT_INFO(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_ARFR6 (Offset 0x1400) */
#define BIT_SHIFT_ARFRL6 0
#define BIT_MASK_ARFRL6 0xffffffffL
#define BIT_ARFRL6(x) (((x) & BIT_MASK_ARFRL6) << BIT_SHIFT_ARFRL6)
#define BITS_ARFRL6 (BIT_MASK_ARFRL6 << BIT_SHIFT_ARFRL6)
#define BIT_CLEAR_ARFRL6(x) ((x) & (~BITS_ARFRL6))
#define BIT_GET_ARFRL6(x) (((x) >> BIT_SHIFT_ARFRL6) & BIT_MASK_ARFRL6)
#define BIT_SET_ARFRL6(x, v) (BIT_CLEAR_ARFRL6(x) | BIT_ARFRL6(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_ARFR6 (Offset 0x1400) */
#define BIT_SHIFT_ARFR6_V1 0
#define BIT_MASK_ARFR6_V1 0xffffffffffffffffL
#define BIT_ARFR6_V1(x) (((x) & BIT_MASK_ARFR6_V1) << BIT_SHIFT_ARFR6_V1)
#define BITS_ARFR6_V1 (BIT_MASK_ARFR6_V1 << BIT_SHIFT_ARFR6_V1)
#define BIT_CLEAR_ARFR6_V1(x) ((x) & (~BITS_ARFR6_V1))
#define BIT_GET_ARFR6_V1(x) (((x) >> BIT_SHIFT_ARFR6_V1) & BIT_MASK_ARFR6_V1)
#define BIT_SET_ARFR6_V1(x, v) (BIT_CLEAR_ARFR6_V1(x) | BIT_ARFR6_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_OFFSET (Offset 0x1400) */
#define BIT_SHIFT_MU_SCORETABLE_OFFSET 0
#define BIT_MASK_MU_SCORETABLE_OFFSET 0x1ff
#define BIT_MU_SCORETABLE_OFFSET(x) \
(((x) & BIT_MASK_MU_SCORETABLE_OFFSET) \
<< BIT_SHIFT_MU_SCORETABLE_OFFSET)
#define BITS_MU_SCORETABLE_OFFSET \
(BIT_MASK_MU_SCORETABLE_OFFSET << BIT_SHIFT_MU_SCORETABLE_OFFSET)
#define BIT_CLEAR_MU_SCORETABLE_OFFSET(x) ((x) & (~BITS_MU_SCORETABLE_OFFSET))
#define BIT_GET_MU_SCORETABLE_OFFSET(x) \
(((x) >> BIT_SHIFT_MU_SCORETABLE_OFFSET) & \
BIT_MASK_MU_SCORETABLE_OFFSET)
#define BIT_SET_MU_SCORETABLE_OFFSET(x, v) \
(BIT_CLEAR_MU_SCORETABLE_OFFSET(x) | BIT_MU_SCORETABLE_OFFSET(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q2_Q3_INFO (Offset 0x1404) */
#define BIT_SHIFT_AC3_PKT_INFO 16
#define BIT_MASK_AC3_PKT_INFO 0xfff
#define BIT_AC3_PKT_INFO(x) \
(((x) & BIT_MASK_AC3_PKT_INFO) << BIT_SHIFT_AC3_PKT_INFO)
#define BITS_AC3_PKT_INFO (BIT_MASK_AC3_PKT_INFO << BIT_SHIFT_AC3_PKT_INFO)
#define BIT_CLEAR_AC3_PKT_INFO(x) ((x) & (~BITS_AC3_PKT_INFO))
#define BIT_GET_AC3_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC3_PKT_INFO) & BIT_MASK_AC3_PKT_INFO)
#define BIT_SET_AC3_PKT_INFO(x, v) \
(BIT_CLEAR_AC3_PKT_INFO(x) | BIT_AC3_PKT_INFO(v))
#define BIT_SHIFT_AC2_PKT_INFO 0
#define BIT_MASK_AC2_PKT_INFO 0xfff
#define BIT_AC2_PKT_INFO(x) \
(((x) & BIT_MASK_AC2_PKT_INFO) << BIT_SHIFT_AC2_PKT_INFO)
#define BITS_AC2_PKT_INFO (BIT_MASK_AC2_PKT_INFO << BIT_SHIFT_AC2_PKT_INFO)
#define BIT_CLEAR_AC2_PKT_INFO(x) ((x) & (~BITS_AC2_PKT_INFO))
#define BIT_GET_AC2_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC2_PKT_INFO) & BIT_MASK_AC2_PKT_INFO)
#define BIT_SET_AC2_PKT_INFO(x, v) \
(BIT_CLEAR_AC2_PKT_INFO(x) | BIT_AC2_PKT_INFO(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_ARFRH6 (Offset 0x1404) */
#define BIT_SHIFT_ARFRH6 0
#define BIT_MASK_ARFRH6 0xffffffffL
#define BIT_ARFRH6(x) (((x) & BIT_MASK_ARFRH6) << BIT_SHIFT_ARFRH6)
#define BITS_ARFRH6 (BIT_MASK_ARFRH6 << BIT_SHIFT_ARFRH6)
#define BIT_CLEAR_ARFRH6(x) ((x) & (~BITS_ARFRH6))
#define BIT_GET_ARFRH6(x) (((x) >> BIT_SHIFT_ARFRH6) & BIT_MASK_ARFRH6)
#define BIT_SET_ARFRH6(x, v) (BIT_CLEAR_ARFRH6(x) | BIT_ARFRH6(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q4_Q5_INFO (Offset 0x1408) */
#define BIT_SHIFT_AC5_PKT_INFO 16
#define BIT_MASK_AC5_PKT_INFO 0xfff
#define BIT_AC5_PKT_INFO(x) \
(((x) & BIT_MASK_AC5_PKT_INFO) << BIT_SHIFT_AC5_PKT_INFO)
#define BITS_AC5_PKT_INFO (BIT_MASK_AC5_PKT_INFO << BIT_SHIFT_AC5_PKT_INFO)
#define BIT_CLEAR_AC5_PKT_INFO(x) ((x) & (~BITS_AC5_PKT_INFO))
#define BIT_GET_AC5_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC5_PKT_INFO) & BIT_MASK_AC5_PKT_INFO)
#define BIT_SET_AC5_PKT_INFO(x, v) \
(BIT_CLEAR_AC5_PKT_INFO(x) | BIT_AC5_PKT_INFO(v))
#define BIT_SHIFT_AC4_PKT_INFO 0
#define BIT_MASK_AC4_PKT_INFO 0xfff
#define BIT_AC4_PKT_INFO(x) \
(((x) & BIT_MASK_AC4_PKT_INFO) << BIT_SHIFT_AC4_PKT_INFO)
#define BITS_AC4_PKT_INFO (BIT_MASK_AC4_PKT_INFO << BIT_SHIFT_AC4_PKT_INFO)
#define BIT_CLEAR_AC4_PKT_INFO(x) ((x) & (~BITS_AC4_PKT_INFO))
#define BIT_GET_AC4_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC4_PKT_INFO) & BIT_MASK_AC4_PKT_INFO)
#define BIT_SET_AC4_PKT_INFO(x, v) \
(BIT_CLEAR_AC4_PKT_INFO(x) | BIT_AC4_PKT_INFO(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_ARFR7 (Offset 0x1408) */
#define BIT_SHIFT_ARFRL7 0
#define BIT_MASK_ARFRL7 0xffffffffL
#define BIT_ARFRL7(x) (((x) & BIT_MASK_ARFRL7) << BIT_SHIFT_ARFRL7)
#define BITS_ARFRL7 (BIT_MASK_ARFRL7 << BIT_SHIFT_ARFRL7)
#define BIT_CLEAR_ARFRL7(x) ((x) & (~BITS_ARFRL7))
#define BIT_GET_ARFRL7(x) (((x) >> BIT_SHIFT_ARFRL7) & BIT_MASK_ARFRL7)
#define BIT_SET_ARFRL7(x, v) (BIT_CLEAR_ARFRL7(x) | BIT_ARFRL7(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_ARFR7 (Offset 0x1408) */
#define BIT_SHIFT_ARFR7_V1 0
#define BIT_MASK_ARFR7_V1 0xffffffffffffffffL
#define BIT_ARFR7_V1(x) (((x) & BIT_MASK_ARFR7_V1) << BIT_SHIFT_ARFR7_V1)
#define BITS_ARFR7_V1 (BIT_MASK_ARFR7_V1 << BIT_SHIFT_ARFR7_V1)
#define BIT_CLEAR_ARFR7_V1(x) ((x) & (~BITS_ARFR7_V1))
#define BIT_GET_ARFR7_V1(x) (((x) >> BIT_SHIFT_ARFR7_V1) & BIT_MASK_ARFR7_V1)
#define BIT_SET_ARFR7_V1(x, v) (BIT_CLEAR_ARFR7_V1(x) | BIT_ARFR7_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_Q6_Q7_INFO (Offset 0x140C) */
#define BIT_SHIFT_AC7_PKT_INFO 16
#define BIT_MASK_AC7_PKT_INFO 0xfff
#define BIT_AC7_PKT_INFO(x) \
(((x) & BIT_MASK_AC7_PKT_INFO) << BIT_SHIFT_AC7_PKT_INFO)
#define BITS_AC7_PKT_INFO (BIT_MASK_AC7_PKT_INFO << BIT_SHIFT_AC7_PKT_INFO)
#define BIT_CLEAR_AC7_PKT_INFO(x) ((x) & (~BITS_AC7_PKT_INFO))
#define BIT_GET_AC7_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC7_PKT_INFO) & BIT_MASK_AC7_PKT_INFO)
#define BIT_SET_AC7_PKT_INFO(x, v) \
(BIT_CLEAR_AC7_PKT_INFO(x) | BIT_AC7_PKT_INFO(v))
#define BIT_SHIFT_AC6_PKT_INFO 0
#define BIT_MASK_AC6_PKT_INFO 0xfff
#define BIT_AC6_PKT_INFO(x) \
(((x) & BIT_MASK_AC6_PKT_INFO) << BIT_SHIFT_AC6_PKT_INFO)
#define BITS_AC6_PKT_INFO (BIT_MASK_AC6_PKT_INFO << BIT_SHIFT_AC6_PKT_INFO)
#define BIT_CLEAR_AC6_PKT_INFO(x) ((x) & (~BITS_AC6_PKT_INFO))
#define BIT_GET_AC6_PKT_INFO(x) \
(((x) >> BIT_SHIFT_AC6_PKT_INFO) & BIT_MASK_AC6_PKT_INFO)
#define BIT_SET_AC6_PKT_INFO(x, v) \
(BIT_CLEAR_AC6_PKT_INFO(x) | BIT_AC6_PKT_INFO(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_ARFRH7 (Offset 0x140C) */
#define BIT_SHIFT_ARFRH7 0
#define BIT_MASK_ARFRH7 0xffffffffL
#define BIT_ARFRH7(x) (((x) & BIT_MASK_ARFRH7) << BIT_SHIFT_ARFRH7)
#define BITS_ARFRH7 (BIT_MASK_ARFRH7 << BIT_SHIFT_ARFRH7)
#define BIT_CLEAR_ARFRH7(x) ((x) & (~BITS_ARFRH7))
#define BIT_GET_ARFRH7(x) (((x) >> BIT_SHIFT_ARFRH7) & BIT_MASK_ARFRH7)
#define BIT_SET_ARFRH7(x, v) (BIT_CLEAR_ARFRH7(x) | BIT_ARFRH7(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_HIQ_INFO (Offset 0x1410) */
#define BIT_SHIFT_HIQ_PKT_INFO 16
#define BIT_MASK_HIQ_PKT_INFO 0xfff
#define BIT_HIQ_PKT_INFO(x) \
(((x) & BIT_MASK_HIQ_PKT_INFO) << BIT_SHIFT_HIQ_PKT_INFO)
#define BITS_HIQ_PKT_INFO (BIT_MASK_HIQ_PKT_INFO << BIT_SHIFT_HIQ_PKT_INFO)
#define BIT_CLEAR_HIQ_PKT_INFO(x) ((x) & (~BITS_HIQ_PKT_INFO))
#define BIT_GET_HIQ_PKT_INFO(x) \
(((x) >> BIT_SHIFT_HIQ_PKT_INFO) & BIT_MASK_HIQ_PKT_INFO)
#define BIT_SET_HIQ_PKT_INFO(x, v) \
(BIT_CLEAR_HIQ_PKT_INFO(x) | BIT_HIQ_PKT_INFO(v))
#define BIT_SHIFT_MGQ_PKT_INFO 0
#define BIT_MASK_MGQ_PKT_INFO 0xfff
#define BIT_MGQ_PKT_INFO(x) \
(((x) & BIT_MASK_MGQ_PKT_INFO) << BIT_SHIFT_MGQ_PKT_INFO)
#define BITS_MGQ_PKT_INFO (BIT_MASK_MGQ_PKT_INFO << BIT_SHIFT_MGQ_PKT_INFO)
#define BIT_CLEAR_MGQ_PKT_INFO(x) ((x) & (~BITS_MGQ_PKT_INFO))
#define BIT_GET_MGQ_PKT_INFO(x) \
(((x) >> BIT_SHIFT_MGQ_PKT_INFO) & BIT_MASK_MGQ_PKT_INFO)
#define BIT_SET_MGQ_PKT_INFO(x, v) \
(BIT_CLEAR_MGQ_PKT_INFO(x) | BIT_MGQ_PKT_INFO(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_ARFR8 (Offset 0x1410) */
#define BIT_SHIFT_ARFRL8 0
#define BIT_MASK_ARFRL8 0xffffffffL
#define BIT_ARFRL8(x) (((x) & BIT_MASK_ARFRL8) << BIT_SHIFT_ARFRL8)
#define BITS_ARFRL8 (BIT_MASK_ARFRL8 << BIT_SHIFT_ARFRL8)
#define BIT_CLEAR_ARFRL8(x) ((x) & (~BITS_ARFRL8))
#define BIT_GET_ARFRL8(x) (((x) >> BIT_SHIFT_ARFRL8) & BIT_MASK_ARFRL8)
#define BIT_SET_ARFRL8(x, v) (BIT_CLEAR_ARFRL8(x) | BIT_ARFRL8(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_ARFR8 (Offset 0x1410) */
#define BIT_SHIFT_ARFR8_V1 0
#define BIT_MASK_ARFR8_V1 0xffffffffffffffffL
#define BIT_ARFR8_V1(x) (((x) & BIT_MASK_ARFR8_V1) << BIT_SHIFT_ARFR8_V1)
#define BITS_ARFR8_V1 (BIT_MASK_ARFR8_V1 << BIT_SHIFT_ARFR8_V1)
#define BIT_CLEAR_ARFR8_V1(x) ((x) & (~BITS_ARFR8_V1))
#define BIT_GET_ARFR8_V1(x) (((x) >> BIT_SHIFT_ARFR8_V1) & BIT_MASK_ARFR8_V1)
#define BIT_SET_ARFR8_V1(x, v) (BIT_CLEAR_ARFR8_V1(x) | BIT_ARFR8_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_CMDQ_BCNQ_INFO (Offset 0x1414) */
#define BIT_SHIFT_BCNQ_PKT_INFO_V1 16
#define BIT_MASK_BCNQ_PKT_INFO_V1 0xfff
#define BIT_BCNQ_PKT_INFO_V1(x) \
(((x) & BIT_MASK_BCNQ_PKT_INFO_V1) << BIT_SHIFT_BCNQ_PKT_INFO_V1)
#define BITS_BCNQ_PKT_INFO_V1 \
(BIT_MASK_BCNQ_PKT_INFO_V1 << BIT_SHIFT_BCNQ_PKT_INFO_V1)
#define BIT_CLEAR_BCNQ_PKT_INFO_V1(x) ((x) & (~BITS_BCNQ_PKT_INFO_V1))
#define BIT_GET_BCNQ_PKT_INFO_V1(x) \
(((x) >> BIT_SHIFT_BCNQ_PKT_INFO_V1) & BIT_MASK_BCNQ_PKT_INFO_V1)
#define BIT_SET_BCNQ_PKT_INFO_V1(x, v) \
(BIT_CLEAR_BCNQ_PKT_INFO_V1(x) | BIT_BCNQ_PKT_INFO_V1(v))
#define BIT_SHIFT_BCNERR_PORT_SEL 16
#define BIT_MASK_BCNERR_PORT_SEL 0x7
#define BIT_BCNERR_PORT_SEL(x) \
(((x) & BIT_MASK_BCNERR_PORT_SEL) << BIT_SHIFT_BCNERR_PORT_SEL)
#define BITS_BCNERR_PORT_SEL \
(BIT_MASK_BCNERR_PORT_SEL << BIT_SHIFT_BCNERR_PORT_SEL)
#define BIT_CLEAR_BCNERR_PORT_SEL(x) ((x) & (~BITS_BCNERR_PORT_SEL))
#define BIT_GET_BCNERR_PORT_SEL(x) \
(((x) >> BIT_SHIFT_BCNERR_PORT_SEL) & BIT_MASK_BCNERR_PORT_SEL)
#define BIT_SET_BCNERR_PORT_SEL(x, v) \
(BIT_CLEAR_BCNERR_PORT_SEL(x) | BIT_BCNERR_PORT_SEL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CMDQ_BCNQ_INFO (Offset 0x1414) */
#define BIT_SHIFT_CMDQ_PKT_INFO 16
#define BIT_MASK_CMDQ_PKT_INFO 0xfff
#define BIT_CMDQ_PKT_INFO(x) \
(((x) & BIT_MASK_CMDQ_PKT_INFO) << BIT_SHIFT_CMDQ_PKT_INFO)
#define BITS_CMDQ_PKT_INFO (BIT_MASK_CMDQ_PKT_INFO << BIT_SHIFT_CMDQ_PKT_INFO)
#define BIT_CLEAR_CMDQ_PKT_INFO(x) ((x) & (~BITS_CMDQ_PKT_INFO))
#define BIT_GET_CMDQ_PKT_INFO(x) \
(((x) >> BIT_SHIFT_CMDQ_PKT_INFO) & BIT_MASK_CMDQ_PKT_INFO)
#define BIT_SET_CMDQ_PKT_INFO(x, v) \
(BIT_CLEAR_CMDQ_PKT_INFO(x) | BIT_CMDQ_PKT_INFO(v))
#endif
#if (HALMAC_8197F_SUPPORT)
/* 2 REG_CMDQ_BCNQ_INFO (Offset 0x1414) */
#define BIT_SHIFT_CMDQ_PKT_INFO_V1 0
#define BIT_MASK_CMDQ_PKT_INFO_V1 0xfff
#define BIT_CMDQ_PKT_INFO_V1(x) \
(((x) & BIT_MASK_CMDQ_PKT_INFO_V1) << BIT_SHIFT_CMDQ_PKT_INFO_V1)
#define BITS_CMDQ_PKT_INFO_V1 \
(BIT_MASK_CMDQ_PKT_INFO_V1 << BIT_SHIFT_CMDQ_PKT_INFO_V1)
#define BIT_CLEAR_CMDQ_PKT_INFO_V1(x) ((x) & (~BITS_CMDQ_PKT_INFO_V1))
#define BIT_GET_CMDQ_PKT_INFO_V1(x) \
(((x) >> BIT_SHIFT_CMDQ_PKT_INFO_V1) & BIT_MASK_CMDQ_PKT_INFO_V1)
#define BIT_SET_CMDQ_PKT_INFO_V1(x, v) \
(BIT_CLEAR_CMDQ_PKT_INFO_V1(x) | BIT_CMDQ_PKT_INFO_V1(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_ARFRH8 (Offset 0x1414) */
#define BIT_SHIFT_ARFRH8 0
#define BIT_MASK_ARFRH8 0xffffffffL
#define BIT_ARFRH8(x) (((x) & BIT_MASK_ARFRH8) << BIT_SHIFT_ARFRH8)
#define BITS_ARFRH8 (BIT_MASK_ARFRH8 << BIT_SHIFT_ARFRH8)
#define BIT_CLEAR_ARFRH8(x) ((x) & (~BITS_ARFRH8))
#define BIT_GET_ARFRH8(x) (((x) >> BIT_SHIFT_ARFRH8) & BIT_MASK_ARFRH8)
#define BIT_SET_ARFRH8(x, v) (BIT_CLEAR_ARFRH8(x) | BIT_ARFRH8(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CMDQ_BCNQ_INFO (Offset 0x1414) */
#define BIT_SHIFT_BCNQ_PKT_INFO 0
#define BIT_MASK_BCNQ_PKT_INFO 0xfff
#define BIT_BCNQ_PKT_INFO(x) \
(((x) & BIT_MASK_BCNQ_PKT_INFO) << BIT_SHIFT_BCNQ_PKT_INFO)
#define BITS_BCNQ_PKT_INFO (BIT_MASK_BCNQ_PKT_INFO << BIT_SHIFT_BCNQ_PKT_INFO)
#define BIT_CLEAR_BCNQ_PKT_INFO(x) ((x) & (~BITS_BCNQ_PKT_INFO))
#define BIT_GET_BCNQ_PKT_INFO(x) \
(((x) >> BIT_SHIFT_BCNQ_PKT_INFO) & BIT_MASK_BCNQ_PKT_INFO)
#define BIT_SET_BCNQ_PKT_INFO(x, v) \
(BIT_CLEAR_BCNQ_PKT_INFO(x) | BIT_BCNQ_PKT_INFO(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_LOOPBACK_OPTION (Offset 0x1420) */
#define BIT_LOOPACK_FAST_EDCA_EN BIT(24)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_USEREG_SETTING (Offset 0x1420) */
#define BIT_NDPA_USEREG BIT(21)
#define BIT_SHIFT_RETRY_USEREG 19
#define BIT_MASK_RETRY_USEREG 0x3
#define BIT_RETRY_USEREG(x) \
(((x) & BIT_MASK_RETRY_USEREG) << BIT_SHIFT_RETRY_USEREG)
#define BITS_RETRY_USEREG (BIT_MASK_RETRY_USEREG << BIT_SHIFT_RETRY_USEREG)
#define BIT_CLEAR_RETRY_USEREG(x) ((x) & (~BITS_RETRY_USEREG))
#define BIT_GET_RETRY_USEREG(x) \
(((x) >> BIT_SHIFT_RETRY_USEREG) & BIT_MASK_RETRY_USEREG)
#define BIT_SET_RETRY_USEREG(x, v) \
(BIT_CLEAR_RETRY_USEREG(x) | BIT_RETRY_USEREG(v))
#define BIT_SHIFT_TRYPKT_USEREG 17
#define BIT_MASK_TRYPKT_USEREG 0x3
#define BIT_TRYPKT_USEREG(x) \
(((x) & BIT_MASK_TRYPKT_USEREG) << BIT_SHIFT_TRYPKT_USEREG)
#define BITS_TRYPKT_USEREG (BIT_MASK_TRYPKT_USEREG << BIT_SHIFT_TRYPKT_USEREG)
#define BIT_CLEAR_TRYPKT_USEREG(x) ((x) & (~BITS_TRYPKT_USEREG))
#define BIT_GET_TRYPKT_USEREG(x) \
(((x) >> BIT_SHIFT_TRYPKT_USEREG) & BIT_MASK_TRYPKT_USEREG)
#define BIT_SET_TRYPKT_USEREG(x, v) \
(BIT_CLEAR_TRYPKT_USEREG(x) | BIT_TRYPKT_USEREG(v))
#define BIT_CTLPKT_USEREG BIT(16)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_AESIV_SETTING (Offset 0x1424) */
#define BIT_SHIFT_AESIV_OFFSET 0
#define BIT_MASK_AESIV_OFFSET 0xfff
#define BIT_AESIV_OFFSET(x) \
(((x) & BIT_MASK_AESIV_OFFSET) << BIT_SHIFT_AESIV_OFFSET)
#define BITS_AESIV_OFFSET (BIT_MASK_AESIV_OFFSET << BIT_SHIFT_AESIV_OFFSET)
#define BIT_CLEAR_AESIV_OFFSET(x) ((x) & (~BITS_AESIV_OFFSET))
#define BIT_GET_AESIV_OFFSET(x) \
(((x) >> BIT_SHIFT_AESIV_OFFSET) & BIT_MASK_AESIV_OFFSET)
#define BIT_SET_AESIV_OFFSET(x, v) \
(BIT_CLEAR_AESIV_OFFSET(x) | BIT_AESIV_OFFSET(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BF0_TIME_SETTING (Offset 0x1428) */
#define BIT_BF0_TIMER_SET BIT(31)
#define BIT_BF0_TIMER_CLR BIT(30)
#define BIT_BF0_UPDATE_EN BIT(29)
#define BIT_BF0_TIMER_EN BIT(28)
#define BIT_SHIFT_BF0_PRETIME_OVER 16
#define BIT_MASK_BF0_PRETIME_OVER 0xfff
#define BIT_BF0_PRETIME_OVER(x) \
(((x) & BIT_MASK_BF0_PRETIME_OVER) << BIT_SHIFT_BF0_PRETIME_OVER)
#define BITS_BF0_PRETIME_OVER \
(BIT_MASK_BF0_PRETIME_OVER << BIT_SHIFT_BF0_PRETIME_OVER)
#define BIT_CLEAR_BF0_PRETIME_OVER(x) ((x) & (~BITS_BF0_PRETIME_OVER))
#define BIT_GET_BF0_PRETIME_OVER(x) \
(((x) >> BIT_SHIFT_BF0_PRETIME_OVER) & BIT_MASK_BF0_PRETIME_OVER)
#define BIT_SET_BF0_PRETIME_OVER(x, v) \
(BIT_CLEAR_BF0_PRETIME_OVER(x) | BIT_BF0_PRETIME_OVER(v))
#define BIT_SHIFT_BF0_LIFETIME 0
#define BIT_MASK_BF0_LIFETIME 0xffff
#define BIT_BF0_LIFETIME(x) \
(((x) & BIT_MASK_BF0_LIFETIME) << BIT_SHIFT_BF0_LIFETIME)
#define BITS_BF0_LIFETIME (BIT_MASK_BF0_LIFETIME << BIT_SHIFT_BF0_LIFETIME)
#define BIT_CLEAR_BF0_LIFETIME(x) ((x) & (~BITS_BF0_LIFETIME))
#define BIT_GET_BF0_LIFETIME(x) \
(((x) >> BIT_SHIFT_BF0_LIFETIME) & BIT_MASK_BF0_LIFETIME)
#define BIT_SET_BF0_LIFETIME(x, v) \
(BIT_CLEAR_BF0_LIFETIME(x) | BIT_BF0_LIFETIME(v))
/* 2 REG_BF1_TIME_SETTING (Offset 0x142C) */
#define BIT_BF1_TIMER_SET BIT(31)
#define BIT_BF1_TIMER_CLR BIT(30)
#define BIT_BF1_UPDATE_EN BIT(29)
#define BIT_BF1_TIMER_EN BIT(28)
#define BIT_SHIFT_BF1_PRETIME_OVER 16
#define BIT_MASK_BF1_PRETIME_OVER 0xfff
#define BIT_BF1_PRETIME_OVER(x) \
(((x) & BIT_MASK_BF1_PRETIME_OVER) << BIT_SHIFT_BF1_PRETIME_OVER)
#define BITS_BF1_PRETIME_OVER \
(BIT_MASK_BF1_PRETIME_OVER << BIT_SHIFT_BF1_PRETIME_OVER)
#define BIT_CLEAR_BF1_PRETIME_OVER(x) ((x) & (~BITS_BF1_PRETIME_OVER))
#define BIT_GET_BF1_PRETIME_OVER(x) \
(((x) >> BIT_SHIFT_BF1_PRETIME_OVER) & BIT_MASK_BF1_PRETIME_OVER)
#define BIT_SET_BF1_PRETIME_OVER(x, v) \
(BIT_CLEAR_BF1_PRETIME_OVER(x) | BIT_BF1_PRETIME_OVER(v))
#define BIT_SHIFT_BF1_LIFETIME 0
#define BIT_MASK_BF1_LIFETIME 0xffff
#define BIT_BF1_LIFETIME(x) \
(((x) & BIT_MASK_BF1_LIFETIME) << BIT_SHIFT_BF1_LIFETIME)
#define BITS_BF1_LIFETIME (BIT_MASK_BF1_LIFETIME << BIT_SHIFT_BF1_LIFETIME)
#define BIT_CLEAR_BF1_LIFETIME(x) ((x) & (~BITS_BF1_LIFETIME))
#define BIT_GET_BF1_LIFETIME(x) \
(((x) >> BIT_SHIFT_BF1_LIFETIME) & BIT_MASK_BF1_LIFETIME)
#define BIT_SET_BF1_LIFETIME(x, v) \
(BIT_CLEAR_BF1_LIFETIME(x) | BIT_BF1_LIFETIME(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BF_TIMEOUT_EN (Offset 0x1430) */
#define BIT_EN_VHT_LDPC BIT(9)
#define BIT_EN_HT_LDPC BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BF_TIMEOUT_EN (Offset 0x1430) */
#define BIT_BF1_TIMEOUT_EN BIT(1)
#define BIT_BF0_TIMEOUT_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_RELEASE0 (Offset 0x1434) */
#define BIT_SHIFT_MACID31_0_RELEASE 0
#define BIT_MASK_MACID31_0_RELEASE 0xffffffffL
#define BIT_MACID31_0_RELEASE(x) \
(((x) & BIT_MASK_MACID31_0_RELEASE) << BIT_SHIFT_MACID31_0_RELEASE)
#define BITS_MACID31_0_RELEASE \
(BIT_MASK_MACID31_0_RELEASE << BIT_SHIFT_MACID31_0_RELEASE)
#define BIT_CLEAR_MACID31_0_RELEASE(x) ((x) & (~BITS_MACID31_0_RELEASE))
#define BIT_GET_MACID31_0_RELEASE(x) \
(((x) >> BIT_SHIFT_MACID31_0_RELEASE) & BIT_MASK_MACID31_0_RELEASE)
#define BIT_SET_MACID31_0_RELEASE(x, v) \
(BIT_CLEAR_MACID31_0_RELEASE(x) | BIT_MACID31_0_RELEASE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_RELEASE_INFO (Offset 0x1434) */
#define BIT_SHIFT_MACID_RELEASE_INFO 0
#define BIT_MASK_MACID_RELEASE_INFO 0xffffffffL
#define BIT_MACID_RELEASE_INFO(x) \
(((x) & BIT_MASK_MACID_RELEASE_INFO) << BIT_SHIFT_MACID_RELEASE_INFO)
#define BITS_MACID_RELEASE_INFO \
(BIT_MASK_MACID_RELEASE_INFO << BIT_SHIFT_MACID_RELEASE_INFO)
#define BIT_CLEAR_MACID_RELEASE_INFO(x) ((x) & (~BITS_MACID_RELEASE_INFO))
#define BIT_GET_MACID_RELEASE_INFO(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_INFO) & BIT_MASK_MACID_RELEASE_INFO)
#define BIT_SET_MACID_RELEASE_INFO(x, v) \
(BIT_CLEAR_MACID_RELEASE_INFO(x) | BIT_MACID_RELEASE_INFO(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_RELEASE1 (Offset 0x1438) */
#define BIT_SHIFT_MACID63_32_RELEASE 0
#define BIT_MASK_MACID63_32_RELEASE 0xffffffffL
#define BIT_MACID63_32_RELEASE(x) \
(((x) & BIT_MASK_MACID63_32_RELEASE) << BIT_SHIFT_MACID63_32_RELEASE)
#define BITS_MACID63_32_RELEASE \
(BIT_MASK_MACID63_32_RELEASE << BIT_SHIFT_MACID63_32_RELEASE)
#define BIT_CLEAR_MACID63_32_RELEASE(x) ((x) & (~BITS_MACID63_32_RELEASE))
#define BIT_GET_MACID63_32_RELEASE(x) \
(((x) >> BIT_SHIFT_MACID63_32_RELEASE) & BIT_MASK_MACID63_32_RELEASE)
#define BIT_SET_MACID63_32_RELEASE(x, v) \
(BIT_CLEAR_MACID63_32_RELEASE(x) | BIT_MACID63_32_RELEASE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_RELEASE_SUCCESS_INFO (Offset 0x1438) */
#define BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO 0
#define BIT_MASK_MACID_RELEASE_SUCCESS_INFO 0xffffffffL
#define BIT_MACID_RELEASE_SUCCESS_INFO(x) \
(((x) & BIT_MASK_MACID_RELEASE_SUCCESS_INFO) \
<< BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO)
#define BITS_MACID_RELEASE_SUCCESS_INFO \
(BIT_MASK_MACID_RELEASE_SUCCESS_INFO \
<< BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO)
#define BIT_CLEAR_MACID_RELEASE_SUCCESS_INFO(x) \
((x) & (~BITS_MACID_RELEASE_SUCCESS_INFO))
#define BIT_GET_MACID_RELEASE_SUCCESS_INFO(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO) & \
BIT_MASK_MACID_RELEASE_SUCCESS_INFO)
#define BIT_SET_MACID_RELEASE_SUCCESS_INFO(x, v) \
(BIT_CLEAR_MACID_RELEASE_SUCCESS_INFO(x) | \
BIT_MACID_RELEASE_SUCCESS_INFO(v))
/* 2 REG_MACID_RELEASE_CTRL (Offset 0x143C) */
#define BIT_SHIFT_MACID_RELEASE_SEL 24
#define BIT_MASK_MACID_RELEASE_SEL 0x7
#define BIT_MACID_RELEASE_SEL(x) \
(((x) & BIT_MASK_MACID_RELEASE_SEL) << BIT_SHIFT_MACID_RELEASE_SEL)
#define BITS_MACID_RELEASE_SEL \
(BIT_MASK_MACID_RELEASE_SEL << BIT_SHIFT_MACID_RELEASE_SEL)
#define BIT_CLEAR_MACID_RELEASE_SEL(x) ((x) & (~BITS_MACID_RELEASE_SEL))
#define BIT_GET_MACID_RELEASE_SEL(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_SEL) & BIT_MASK_MACID_RELEASE_SEL)
#define BIT_SET_MACID_RELEASE_SEL(x, v) \
(BIT_CLEAR_MACID_RELEASE_SEL(x) | BIT_MACID_RELEASE_SEL(v))
#define BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET 16
#define BIT_MASK_MACID_RELEASE_CLEAR_OFFSET 0xff
#define BIT_MACID_RELEASE_CLEAR_OFFSET(x) \
(((x) & BIT_MASK_MACID_RELEASE_CLEAR_OFFSET) \
<< BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET)
#define BITS_MACID_RELEASE_CLEAR_OFFSET \
(BIT_MASK_MACID_RELEASE_CLEAR_OFFSET \
<< BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET)
#define BIT_CLEAR_MACID_RELEASE_CLEAR_OFFSET(x) \
((x) & (~BITS_MACID_RELEASE_CLEAR_OFFSET))
#define BIT_GET_MACID_RELEASE_CLEAR_OFFSET(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET) & \
BIT_MASK_MACID_RELEASE_CLEAR_OFFSET)
#define BIT_SET_MACID_RELEASE_CLEAR_OFFSET(x, v) \
(BIT_CLEAR_MACID_RELEASE_CLEAR_OFFSET(x) | \
BIT_MACID_RELEASE_CLEAR_OFFSET(v))
#define BIT_MACID_RELEASE_VALUE BIT(8)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_RELEASE2 (Offset 0x143C) */
#define BIT_SHIFT_MACID95_64_RELEASE 0
#define BIT_MASK_MACID95_64_RELEASE 0xffffffffL
#define BIT_MACID95_64_RELEASE(x) \
(((x) & BIT_MASK_MACID95_64_RELEASE) << BIT_SHIFT_MACID95_64_RELEASE)
#define BITS_MACID95_64_RELEASE \
(BIT_MASK_MACID95_64_RELEASE << BIT_SHIFT_MACID95_64_RELEASE)
#define BIT_CLEAR_MACID95_64_RELEASE(x) ((x) & (~BITS_MACID95_64_RELEASE))
#define BIT_GET_MACID95_64_RELEASE(x) \
(((x) >> BIT_SHIFT_MACID95_64_RELEASE) & BIT_MASK_MACID95_64_RELEASE)
#define BIT_SET_MACID95_64_RELEASE(x, v) \
(BIT_CLEAR_MACID95_64_RELEASE(x) | BIT_MACID95_64_RELEASE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_RELEASE_CTRL (Offset 0x143C) */
#define BIT_SHIFT_MACID_RELEASE_OFFSET 0
#define BIT_MASK_MACID_RELEASE_OFFSET 0xff
#define BIT_MACID_RELEASE_OFFSET(x) \
(((x) & BIT_MASK_MACID_RELEASE_OFFSET) \
<< BIT_SHIFT_MACID_RELEASE_OFFSET)
#define BITS_MACID_RELEASE_OFFSET \
(BIT_MASK_MACID_RELEASE_OFFSET << BIT_SHIFT_MACID_RELEASE_OFFSET)
#define BIT_CLEAR_MACID_RELEASE_OFFSET(x) ((x) & (~BITS_MACID_RELEASE_OFFSET))
#define BIT_GET_MACID_RELEASE_OFFSET(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_OFFSET) & \
BIT_MASK_MACID_RELEASE_OFFSET)
#define BIT_SET_MACID_RELEASE_OFFSET(x, v) \
(BIT_CLEAR_MACID_RELEASE_OFFSET(x) | BIT_MACID_RELEASE_OFFSET(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_RELEASE3 (Offset 0x1440) */
#define BIT_SHIFT_MACID127_96_RELEASE 0
#define BIT_MASK_MACID127_96_RELEASE 0xffffffffL
#define BIT_MACID127_96_RELEASE(x) \
(((x) & BIT_MASK_MACID127_96_RELEASE) << BIT_SHIFT_MACID127_96_RELEASE)
#define BITS_MACID127_96_RELEASE \
(BIT_MASK_MACID127_96_RELEASE << BIT_SHIFT_MACID127_96_RELEASE)
#define BIT_CLEAR_MACID127_96_RELEASE(x) ((x) & (~BITS_MACID127_96_RELEASE))
#define BIT_GET_MACID127_96_RELEASE(x) \
(((x) >> BIT_SHIFT_MACID127_96_RELEASE) & BIT_MASK_MACID127_96_RELEASE)
#define BIT_SET_MACID127_96_RELEASE(x, v) \
(BIT_CLEAR_MACID127_96_RELEASE(x) | BIT_MACID127_96_RELEASE(v))
/* 2 REG_MACID_RELEASE_SETTING (Offset 0x1444) */
#define BIT_MACID_VALUE BIT(7)
#define BIT_SHIFT_MACID_OFFSET 0
#define BIT_MASK_MACID_OFFSET 0x7f
#define BIT_MACID_OFFSET(x) \
(((x) & BIT_MASK_MACID_OFFSET) << BIT_SHIFT_MACID_OFFSET)
#define BITS_MACID_OFFSET (BIT_MASK_MACID_OFFSET << BIT_SHIFT_MACID_OFFSET)
#define BIT_CLEAR_MACID_OFFSET(x) ((x) & (~BITS_MACID_OFFSET))
#define BIT_GET_MACID_OFFSET(x) \
(((x) >> BIT_SHIFT_MACID_OFFSET) & BIT_MASK_MACID_OFFSET)
#define BIT_SET_MACID_OFFSET(x, v) \
(BIT_CLEAR_MACID_OFFSET(x) | BIT_MACID_OFFSET(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FAST_EDCA_VOVI_SETTING (Offset 0x1448) */
#define BIT_SHIFT_VI_FAST_EDCA_TO 24
#define BIT_MASK_VI_FAST_EDCA_TO 0xff
#define BIT_VI_FAST_EDCA_TO(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_TO) << BIT_SHIFT_VI_FAST_EDCA_TO)
#define BITS_VI_FAST_EDCA_TO \
(BIT_MASK_VI_FAST_EDCA_TO << BIT_SHIFT_VI_FAST_EDCA_TO)
#define BIT_CLEAR_VI_FAST_EDCA_TO(x) ((x) & (~BITS_VI_FAST_EDCA_TO))
#define BIT_GET_VI_FAST_EDCA_TO(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_TO) & BIT_MASK_VI_FAST_EDCA_TO)
#define BIT_SET_VI_FAST_EDCA_TO(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_TO(x) | BIT_VI_FAST_EDCA_TO(v))
#define BIT_VI_THRESHOLD_SEL BIT(23)
#define BIT_SHIFT_VI_FAST_EDCA_PKT_TH 16
#define BIT_MASK_VI_FAST_EDCA_PKT_TH 0x7f
#define BIT_VI_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_PKT_TH) << BIT_SHIFT_VI_FAST_EDCA_PKT_TH)
#define BITS_VI_FAST_EDCA_PKT_TH \
(BIT_MASK_VI_FAST_EDCA_PKT_TH << BIT_SHIFT_VI_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_VI_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_VI_FAST_EDCA_PKT_TH))
#define BIT_GET_VI_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_PKT_TH) & BIT_MASK_VI_FAST_EDCA_PKT_TH)
#define BIT_SET_VI_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_PKT_TH(x) | BIT_VI_FAST_EDCA_PKT_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FAST_EDCA_VOVI_SETTING (Offset 0x1448) */
#define BIT_SHIFT_VO_FAST_EDCA_TO 8
#define BIT_MASK_VO_FAST_EDCA_TO 0xff
#define BIT_VO_FAST_EDCA_TO(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO) << BIT_SHIFT_VO_FAST_EDCA_TO)
#define BITS_VO_FAST_EDCA_TO \
(BIT_MASK_VO_FAST_EDCA_TO << BIT_SHIFT_VO_FAST_EDCA_TO)
#define BIT_CLEAR_VO_FAST_EDCA_TO(x) ((x) & (~BITS_VO_FAST_EDCA_TO))
#define BIT_GET_VO_FAST_EDCA_TO(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO) & BIT_MASK_VO_FAST_EDCA_TO)
#define BIT_SET_VO_FAST_EDCA_TO(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO(x) | BIT_VO_FAST_EDCA_TO(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FAST_EDCA_VOVI_SETTING (Offset 0x1448) */
#define BIT_VO_THRESHOLD_SEL BIT(7)
#define BIT_SHIFT_VO_FAST_EDCA_PKT_TH 0
#define BIT_MASK_VO_FAST_EDCA_PKT_TH 0x7f
#define BIT_VO_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_PKT_TH) << BIT_SHIFT_VO_FAST_EDCA_PKT_TH)
#define BITS_VO_FAST_EDCA_PKT_TH \
(BIT_MASK_VO_FAST_EDCA_PKT_TH << BIT_SHIFT_VO_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_VO_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_VO_FAST_EDCA_PKT_TH))
#define BIT_GET_VO_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_PKT_TH) & BIT_MASK_VO_FAST_EDCA_PKT_TH)
#define BIT_SET_VO_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_PKT_TH(x) | BIT_VO_FAST_EDCA_PKT_TH(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING (Offset 0x144C) */
#define BIT_SHIFT_BK_FAST_EDCA_TO 24
#define BIT_MASK_BK_FAST_EDCA_TO 0xff
#define BIT_BK_FAST_EDCA_TO(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_TO) << BIT_SHIFT_BK_FAST_EDCA_TO)
#define BITS_BK_FAST_EDCA_TO \
(BIT_MASK_BK_FAST_EDCA_TO << BIT_SHIFT_BK_FAST_EDCA_TO)
#define BIT_CLEAR_BK_FAST_EDCA_TO(x) ((x) & (~BITS_BK_FAST_EDCA_TO))
#define BIT_GET_BK_FAST_EDCA_TO(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_TO) & BIT_MASK_BK_FAST_EDCA_TO)
#define BIT_SET_BK_FAST_EDCA_TO(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_TO(x) | BIT_BK_FAST_EDCA_TO(v))
#define BIT_BK_THRESHOLD_SEL BIT(23)
#define BIT_SHIFT_BK_FAST_EDCA_PKT_TH 16
#define BIT_MASK_BK_FAST_EDCA_PKT_TH 0x7f
#define BIT_BK_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_PKT_TH) << BIT_SHIFT_BK_FAST_EDCA_PKT_TH)
#define BITS_BK_FAST_EDCA_PKT_TH \
(BIT_MASK_BK_FAST_EDCA_PKT_TH << BIT_SHIFT_BK_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_BK_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_BK_FAST_EDCA_PKT_TH))
#define BIT_GET_BK_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_PKT_TH) & BIT_MASK_BK_FAST_EDCA_PKT_TH)
#define BIT_SET_BK_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_PKT_TH(x) | BIT_BK_FAST_EDCA_PKT_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_FAST_EDCA_BEBK_SETTING (Offset 0x144C) */
#define BIT_SHIFT_BE_FAST_EDCA_TO 8
#define BIT_MASK_BE_FAST_EDCA_TO 0xff
#define BIT_BE_FAST_EDCA_TO(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO) << BIT_SHIFT_BE_FAST_EDCA_TO)
#define BITS_BE_FAST_EDCA_TO \
(BIT_MASK_BE_FAST_EDCA_TO << BIT_SHIFT_BE_FAST_EDCA_TO)
#define BIT_CLEAR_BE_FAST_EDCA_TO(x) ((x) & (~BITS_BE_FAST_EDCA_TO))
#define BIT_GET_BE_FAST_EDCA_TO(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO) & BIT_MASK_BE_FAST_EDCA_TO)
#define BIT_SET_BE_FAST_EDCA_TO(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO(x) | BIT_BE_FAST_EDCA_TO(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_FAST_EDCA_BEBK_SETTING (Offset 0x144C) */
#define BIT_BE_THRESHOLD_SEL BIT(7)
#define BIT_SHIFT_BE_FAST_EDCA_PKT_TH 0
#define BIT_MASK_BE_FAST_EDCA_PKT_TH 0x7f
#define BIT_BE_FAST_EDCA_PKT_TH(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_PKT_TH) << BIT_SHIFT_BE_FAST_EDCA_PKT_TH)
#define BITS_BE_FAST_EDCA_PKT_TH \
(BIT_MASK_BE_FAST_EDCA_PKT_TH << BIT_SHIFT_BE_FAST_EDCA_PKT_TH)
#define BIT_CLEAR_BE_FAST_EDCA_PKT_TH(x) ((x) & (~BITS_BE_FAST_EDCA_PKT_TH))
#define BIT_GET_BE_FAST_EDCA_PKT_TH(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_PKT_TH) & BIT_MASK_BE_FAST_EDCA_PKT_TH)
#define BIT_SET_BE_FAST_EDCA_PKT_TH(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_PKT_TH(x) | BIT_BE_FAST_EDCA_PKT_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_DROP0 (Offset 0x1450) */
#define BIT_SHIFT_MACID31_0_DROP 0
#define BIT_MASK_MACID31_0_DROP 0xffffffffL
#define BIT_MACID31_0_DROP(x) \
(((x) & BIT_MASK_MACID31_0_DROP) << BIT_SHIFT_MACID31_0_DROP)
#define BITS_MACID31_0_DROP \
(BIT_MASK_MACID31_0_DROP << BIT_SHIFT_MACID31_0_DROP)
#define BIT_CLEAR_MACID31_0_DROP(x) ((x) & (~BITS_MACID31_0_DROP))
#define BIT_GET_MACID31_0_DROP(x) \
(((x) >> BIT_SHIFT_MACID31_0_DROP) & BIT_MASK_MACID31_0_DROP)
#define BIT_SET_MACID31_0_DROP(x, v) \
(BIT_CLEAR_MACID31_0_DROP(x) | BIT_MACID31_0_DROP(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_DROP_INFO (Offset 0x1450) */
#define BIT_SHIFT_MACID_DROP_INFO 0
#define BIT_MASK_MACID_DROP_INFO 0xffffffffL
#define BIT_MACID_DROP_INFO(x) \
(((x) & BIT_MASK_MACID_DROP_INFO) << BIT_SHIFT_MACID_DROP_INFO)
#define BITS_MACID_DROP_INFO \
(BIT_MASK_MACID_DROP_INFO << BIT_SHIFT_MACID_DROP_INFO)
#define BIT_CLEAR_MACID_DROP_INFO(x) ((x) & (~BITS_MACID_DROP_INFO))
#define BIT_GET_MACID_DROP_INFO(x) \
(((x) >> BIT_SHIFT_MACID_DROP_INFO) & BIT_MASK_MACID_DROP_INFO)
#define BIT_SET_MACID_DROP_INFO(x, v) \
(BIT_CLEAR_MACID_DROP_INFO(x) | BIT_MACID_DROP_INFO(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_DROP1 (Offset 0x1454) */
#define BIT_SHIFT_MACID63_32_DROP 0
#define BIT_MASK_MACID63_32_DROP 0xffffffffL
#define BIT_MACID63_32_DROP(x) \
(((x) & BIT_MASK_MACID63_32_DROP) << BIT_SHIFT_MACID63_32_DROP)
#define BITS_MACID63_32_DROP \
(BIT_MASK_MACID63_32_DROP << BIT_SHIFT_MACID63_32_DROP)
#define BIT_CLEAR_MACID63_32_DROP(x) ((x) & (~BITS_MACID63_32_DROP))
#define BIT_GET_MACID63_32_DROP(x) \
(((x) >> BIT_SHIFT_MACID63_32_DROP) & BIT_MASK_MACID63_32_DROP)
#define BIT_SET_MACID63_32_DROP(x, v) \
(BIT_CLEAR_MACID63_32_DROP(x) | BIT_MACID63_32_DROP(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_DROP_CTRL (Offset 0x1454) */
#define BIT_SHIFT_MACID_DROP_SEL 0
#define BIT_MASK_MACID_DROP_SEL 0x7
#define BIT_MACID_DROP_SEL(x) \
(((x) & BIT_MASK_MACID_DROP_SEL) << BIT_SHIFT_MACID_DROP_SEL)
#define BITS_MACID_DROP_SEL \
(BIT_MASK_MACID_DROP_SEL << BIT_SHIFT_MACID_DROP_SEL)
#define BIT_CLEAR_MACID_DROP_SEL(x) ((x) & (~BITS_MACID_DROP_SEL))
#define BIT_GET_MACID_DROP_SEL(x) \
(((x) >> BIT_SHIFT_MACID_DROP_SEL) & BIT_MASK_MACID_DROP_SEL)
#define BIT_SET_MACID_DROP_SEL(x, v) \
(BIT_CLEAR_MACID_DROP_SEL(x) | BIT_MACID_DROP_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID_DROP2 (Offset 0x1458) */
#define BIT_SHIFT_MACID95_64_DROP 0
#define BIT_MASK_MACID95_64_DROP 0xffffffffL
#define BIT_MACID95_64_DROP(x) \
(((x) & BIT_MASK_MACID95_64_DROP) << BIT_SHIFT_MACID95_64_DROP)
#define BITS_MACID95_64_DROP \
(BIT_MASK_MACID95_64_DROP << BIT_SHIFT_MACID95_64_DROP)
#define BIT_CLEAR_MACID95_64_DROP(x) ((x) & (~BITS_MACID95_64_DROP))
#define BIT_GET_MACID95_64_DROP(x) \
(((x) >> BIT_SHIFT_MACID95_64_DROP) & BIT_MASK_MACID95_64_DROP)
#define BIT_SET_MACID95_64_DROP(x, v) \
(BIT_CLEAR_MACID95_64_DROP(x) | BIT_MACID95_64_DROP(v))
/* 2 REG_MACID_DROP3 (Offset 0x145C) */
#define BIT_SHIFT_MACID127_96_DROP 0
#define BIT_MASK_MACID127_96_DROP 0xffffffffL
#define BIT_MACID127_96_DROP(x) \
(((x) & BIT_MASK_MACID127_96_DROP) << BIT_SHIFT_MACID127_96_DROP)
#define BITS_MACID127_96_DROP \
(BIT_MASK_MACID127_96_DROP << BIT_SHIFT_MACID127_96_DROP)
#define BIT_CLEAR_MACID127_96_DROP(x) ((x) & (~BITS_MACID127_96_DROP))
#define BIT_GET_MACID127_96_DROP(x) \
(((x) >> BIT_SHIFT_MACID127_96_DROP) & BIT_MASK_MACID127_96_DROP)
#define BIT_SET_MACID127_96_DROP(x, v) \
(BIT_CLEAR_MACID127_96_DROP(x) | BIT_MACID127_96_DROP(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_R_MACID_RELEASE_SUCCESS_1 (Offset 0x1464) */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_1 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_1(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_1) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1)
#define BITS_R_MACID_RELEASE_SUCCESS_1 \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_1 \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_1))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_1(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_1)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_1(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1(x) | \
BIT_R_MACID_RELEASE_SUCCESS_1(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_3 (Offset 0x146C) */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_3 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_3(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_3) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3)
#define BITS_R_MACID_RELEASE_SUCCESS_3 \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_3 \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_3))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_3(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_3)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_3(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3(x) | \
BIT_R_MACID_RELEASE_SUCCESS_3(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MGG_FIFO_CRTL (Offset 0x1470) */
#define BIT_R_MGG_FIFO_EN BIT(31)
#define BIT_SHIFT_R_MGG_FIFO_PG_SIZE 28
#define BIT_MASK_R_MGG_FIFO_PG_SIZE 0x7
#define BIT_R_MGG_FIFO_PG_SIZE(x) \
(((x) & BIT_MASK_R_MGG_FIFO_PG_SIZE) << BIT_SHIFT_R_MGG_FIFO_PG_SIZE)
#define BITS_R_MGG_FIFO_PG_SIZE \
(BIT_MASK_R_MGG_FIFO_PG_SIZE << BIT_SHIFT_R_MGG_FIFO_PG_SIZE)
#define BIT_CLEAR_R_MGG_FIFO_PG_SIZE(x) ((x) & (~BITS_R_MGG_FIFO_PG_SIZE))
#define BIT_GET_R_MGG_FIFO_PG_SIZE(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_PG_SIZE) & BIT_MASK_R_MGG_FIFO_PG_SIZE)
#define BIT_SET_R_MGG_FIFO_PG_SIZE(x, v) \
(BIT_CLEAR_R_MGG_FIFO_PG_SIZE(x) | BIT_R_MGG_FIFO_PG_SIZE(v))
#define BIT_SHIFT_R_MGG_FIFO_START_PG 16
#define BIT_MASK_R_MGG_FIFO_START_PG 0xfff
#define BIT_R_MGG_FIFO_START_PG(x) \
(((x) & BIT_MASK_R_MGG_FIFO_START_PG) << BIT_SHIFT_R_MGG_FIFO_START_PG)
#define BITS_R_MGG_FIFO_START_PG \
(BIT_MASK_R_MGG_FIFO_START_PG << BIT_SHIFT_R_MGG_FIFO_START_PG)
#define BIT_CLEAR_R_MGG_FIFO_START_PG(x) ((x) & (~BITS_R_MGG_FIFO_START_PG))
#define BIT_GET_R_MGG_FIFO_START_PG(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_START_PG) & BIT_MASK_R_MGG_FIFO_START_PG)
#define BIT_SET_R_MGG_FIFO_START_PG(x, v) \
(BIT_CLEAR_R_MGG_FIFO_START_PG(x) | BIT_R_MGG_FIFO_START_PG(v))
#define BIT_SHIFT_R_MGG_FIFO_SIZE 14
#define BIT_MASK_R_MGG_FIFO_SIZE 0x3
#define BIT_R_MGG_FIFO_SIZE(x) \
(((x) & BIT_MASK_R_MGG_FIFO_SIZE) << BIT_SHIFT_R_MGG_FIFO_SIZE)
#define BITS_R_MGG_FIFO_SIZE \
(BIT_MASK_R_MGG_FIFO_SIZE << BIT_SHIFT_R_MGG_FIFO_SIZE)
#define BIT_CLEAR_R_MGG_FIFO_SIZE(x) ((x) & (~BITS_R_MGG_FIFO_SIZE))
#define BIT_GET_R_MGG_FIFO_SIZE(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_SIZE) & BIT_MASK_R_MGG_FIFO_SIZE)
#define BIT_SET_R_MGG_FIFO_SIZE(x, v) \
(BIT_CLEAR_R_MGG_FIFO_SIZE(x) | BIT_R_MGG_FIFO_SIZE(v))
#define BIT_R_MGG_FIFO_PAUSE BIT(13)
#define BIT_SHIFT_R_MGG_FIFO_RPTR 8
#define BIT_MASK_R_MGG_FIFO_RPTR 0x1f
#define BIT_R_MGG_FIFO_RPTR(x) \
(((x) & BIT_MASK_R_MGG_FIFO_RPTR) << BIT_SHIFT_R_MGG_FIFO_RPTR)
#define BITS_R_MGG_FIFO_RPTR \
(BIT_MASK_R_MGG_FIFO_RPTR << BIT_SHIFT_R_MGG_FIFO_RPTR)
#define BIT_CLEAR_R_MGG_FIFO_RPTR(x) ((x) & (~BITS_R_MGG_FIFO_RPTR))
#define BIT_GET_R_MGG_FIFO_RPTR(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_RPTR) & BIT_MASK_R_MGG_FIFO_RPTR)
#define BIT_SET_R_MGG_FIFO_RPTR(x, v) \
(BIT_CLEAR_R_MGG_FIFO_RPTR(x) | BIT_R_MGG_FIFO_RPTR(v))
#define BIT_R_MGG_FIFO_OV BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_WRITE_POINTER (Offset 0x1470) */
#define BIT_MGQ_FIFO_OV BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MGG_FIFO_CRTL (Offset 0x1470) */
#define BIT_R_MGG_FIFO_WPTR_ERROR BIT(6)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_WRITE_POINTER (Offset 0x1470) */
#define BIT_MGQ_FIFO_WPTR_ERROR BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MGG_FIFO_CRTL (Offset 0x1470) */
#define BIT_R_EN_CPU_LIFETIME BIT(5)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_WRITE_POINTER (Offset 0x1470) */
#define BIT_EN_MGQ_FIFO_LIFETIME BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MGG_FIFO_CRTL (Offset 0x1470) */
#define BIT_SHIFT_R_MGG_FIFO_WPTR 0
#define BIT_MASK_R_MGG_FIFO_WPTR 0x1f
#define BIT_R_MGG_FIFO_WPTR(x) \
(((x) & BIT_MASK_R_MGG_FIFO_WPTR) << BIT_SHIFT_R_MGG_FIFO_WPTR)
#define BITS_R_MGG_FIFO_WPTR \
(BIT_MASK_R_MGG_FIFO_WPTR << BIT_SHIFT_R_MGG_FIFO_WPTR)
#define BIT_CLEAR_R_MGG_FIFO_WPTR(x) ((x) & (~BITS_R_MGG_FIFO_WPTR))
#define BIT_GET_R_MGG_FIFO_WPTR(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_WPTR) & BIT_MASK_R_MGG_FIFO_WPTR)
#define BIT_SET_R_MGG_FIFO_WPTR(x, v) \
(BIT_CLEAR_R_MGG_FIFO_WPTR(x) | BIT_R_MGG_FIFO_WPTR(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_WRITE_POINTER (Offset 0x1470) */
#define BIT_SHIFT_MGQ_FIFO_WPTR 0
#define BIT_MASK_MGQ_FIFO_WPTR 0x1f
#define BIT_MGQ_FIFO_WPTR(x) \
(((x) & BIT_MASK_MGQ_FIFO_WPTR) << BIT_SHIFT_MGQ_FIFO_WPTR)
#define BITS_MGQ_FIFO_WPTR (BIT_MASK_MGQ_FIFO_WPTR << BIT_SHIFT_MGQ_FIFO_WPTR)
#define BIT_CLEAR_MGQ_FIFO_WPTR(x) ((x) & (~BITS_MGQ_FIFO_WPTR))
#define BIT_GET_MGQ_FIFO_WPTR(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_WPTR) & BIT_MASK_MGQ_FIFO_WPTR)
#define BIT_SET_MGQ_FIFO_WPTR(x, v) \
(BIT_CLEAR_MGQ_FIFO_WPTR(x) | BIT_MGQ_FIFO_WPTR(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_ENABLE (Offset 0x1472) */
#define BIT_MGQ_FIFO_EN BIT(15)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MGQ_FIFO_ENABLE (Offset 0x1472) */
#define BIT_MGQ_FIFO_EN_V1 BIT(15)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_READ_POINTER (Offset 0x1472) */
#define BIT_SHIFT_MGQ_FIFO_SIZE 14
#define BIT_MASK_MGQ_FIFO_SIZE 0x3
#define BIT_MGQ_FIFO_SIZE(x) \
(((x) & BIT_MASK_MGQ_FIFO_SIZE) << BIT_SHIFT_MGQ_FIFO_SIZE)
#define BITS_MGQ_FIFO_SIZE (BIT_MASK_MGQ_FIFO_SIZE << BIT_SHIFT_MGQ_FIFO_SIZE)
#define BIT_CLEAR_MGQ_FIFO_SIZE(x) ((x) & (~BITS_MGQ_FIFO_SIZE))
#define BIT_GET_MGQ_FIFO_SIZE(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_SIZE) & BIT_MASK_MGQ_FIFO_SIZE)
#define BIT_SET_MGQ_FIFO_SIZE(x, v) \
(BIT_CLEAR_MGQ_FIFO_SIZE(x) | BIT_MGQ_FIFO_SIZE(v))
#define BIT_MGQ_FIFO_PAUSE BIT(13)
#define BIT_SHIFT_MGQ_FIFO_PG_SIZE 12
#define BIT_MASK_MGQ_FIFO_PG_SIZE 0x7
#define BIT_MGQ_FIFO_PG_SIZE(x) \
(((x) & BIT_MASK_MGQ_FIFO_PG_SIZE) << BIT_SHIFT_MGQ_FIFO_PG_SIZE)
#define BITS_MGQ_FIFO_PG_SIZE \
(BIT_MASK_MGQ_FIFO_PG_SIZE << BIT_SHIFT_MGQ_FIFO_PG_SIZE)
#define BIT_CLEAR_MGQ_FIFO_PG_SIZE(x) ((x) & (~BITS_MGQ_FIFO_PG_SIZE))
#define BIT_GET_MGQ_FIFO_PG_SIZE(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PG_SIZE) & BIT_MASK_MGQ_FIFO_PG_SIZE)
#define BIT_SET_MGQ_FIFO_PG_SIZE(x, v) \
(BIT_CLEAR_MGQ_FIFO_PG_SIZE(x) | BIT_MGQ_FIFO_PG_SIZE(v))
#define BIT_SHIFT_MGQ_FIFO_RPTR 8
#define BIT_MASK_MGQ_FIFO_RPTR 0x1f
#define BIT_MGQ_FIFO_RPTR(x) \
(((x) & BIT_MASK_MGQ_FIFO_RPTR) << BIT_SHIFT_MGQ_FIFO_RPTR)
#define BITS_MGQ_FIFO_RPTR (BIT_MASK_MGQ_FIFO_RPTR << BIT_SHIFT_MGQ_FIFO_RPTR)
#define BIT_CLEAR_MGQ_FIFO_RPTR(x) ((x) & (~BITS_MGQ_FIFO_RPTR))
#define BIT_GET_MGQ_FIFO_RPTR(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_RPTR) & BIT_MASK_MGQ_FIFO_RPTR)
#define BIT_SET_MGQ_FIFO_RPTR(x, v) \
(BIT_CLEAR_MGQ_FIFO_RPTR(x) | BIT_MGQ_FIFO_RPTR(v))
#define BIT_SHIFT_MGQ_FIFO_START_PG 0
#define BIT_MASK_MGQ_FIFO_START_PG 0xfff
#define BIT_MGQ_FIFO_START_PG(x) \
(((x) & BIT_MASK_MGQ_FIFO_START_PG) << BIT_SHIFT_MGQ_FIFO_START_PG)
#define BITS_MGQ_FIFO_START_PG \
(BIT_MASK_MGQ_FIFO_START_PG << BIT_SHIFT_MGQ_FIFO_START_PG)
#define BIT_CLEAR_MGQ_FIFO_START_PG(x) ((x) & (~BITS_MGQ_FIFO_START_PG))
#define BIT_GET_MGQ_FIFO_START_PG(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_START_PG) & BIT_MASK_MGQ_FIFO_START_PG)
#define BIT_SET_MGQ_FIFO_START_PG(x, v) \
(BIT_CLEAR_MGQ_FIFO_START_PG(x) | BIT_MGQ_FIFO_START_PG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MGG_FIFO_INT (Offset 0x1474) */
#define BIT_SHIFT_R_MGG_FIFO_INT_FLAG 16
#define BIT_MASK_R_MGG_FIFO_INT_FLAG 0xffff
#define BIT_R_MGG_FIFO_INT_FLAG(x) \
(((x) & BIT_MASK_R_MGG_FIFO_INT_FLAG) << BIT_SHIFT_R_MGG_FIFO_INT_FLAG)
#define BITS_R_MGG_FIFO_INT_FLAG \
(BIT_MASK_R_MGG_FIFO_INT_FLAG << BIT_SHIFT_R_MGG_FIFO_INT_FLAG)
#define BIT_CLEAR_R_MGG_FIFO_INT_FLAG(x) ((x) & (~BITS_R_MGG_FIFO_INT_FLAG))
#define BIT_GET_R_MGG_FIFO_INT_FLAG(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_INT_FLAG) & BIT_MASK_R_MGG_FIFO_INT_FLAG)
#define BIT_SET_R_MGG_FIFO_INT_FLAG(x, v) \
(BIT_CLEAR_R_MGG_FIFO_INT_FLAG(x) | BIT_R_MGG_FIFO_INT_FLAG(v))
#define BIT_SHIFT_R_MGG_FIFO_INT_MASK 0
#define BIT_MASK_R_MGG_FIFO_INT_MASK 0xffff
#define BIT_R_MGG_FIFO_INT_MASK(x) \
(((x) & BIT_MASK_R_MGG_FIFO_INT_MASK) << BIT_SHIFT_R_MGG_FIFO_INT_MASK)
#define BITS_R_MGG_FIFO_INT_MASK \
(BIT_MASK_R_MGG_FIFO_INT_MASK << BIT_SHIFT_R_MGG_FIFO_INT_MASK)
#define BIT_CLEAR_R_MGG_FIFO_INT_MASK(x) ((x) & (~BITS_R_MGG_FIFO_INT_MASK))
#define BIT_GET_R_MGG_FIFO_INT_MASK(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_INT_MASK) & BIT_MASK_R_MGG_FIFO_INT_MASK)
#define BIT_SET_R_MGG_FIFO_INT_MASK(x, v) \
(BIT_CLEAR_R_MGG_FIFO_INT_MASK(x) | BIT_R_MGG_FIFO_INT_MASK(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_RELEASE_INT_MASK (Offset 0x1474) */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_MASK 0
#define BIT_MASK_MGQ_FIFO_REL_INT_MASK 0xffff
#define BIT_MGQ_FIFO_REL_INT_MASK(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_MASK) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK)
#define BITS_MGQ_FIFO_REL_INT_MASK \
(BIT_MASK_MGQ_FIFO_REL_INT_MASK << BIT_SHIFT_MGQ_FIFO_REL_INT_MASK)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_MASK(x) ((x) & (~BITS_MGQ_FIFO_REL_INT_MASK))
#define BIT_GET_MGQ_FIFO_REL_INT_MASK(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_MASK) & \
BIT_MASK_MGQ_FIFO_REL_INT_MASK)
#define BIT_SET_MGQ_FIFO_REL_INT_MASK(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_MASK(x) | BIT_MGQ_FIFO_REL_INT_MASK(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_FLAG (Offset 0x1476) */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG 0
#define BIT_MASK_MGQ_FIFO_REL_INT_FLAG 0xffff
#define BIT_MGQ_FIFO_REL_INT_FLAG(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_FLAG) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG)
#define BITS_MGQ_FIFO_REL_INT_FLAG \
(BIT_MASK_MGQ_FIFO_REL_INT_FLAG << BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG(x) ((x) & (~BITS_MGQ_FIFO_REL_INT_FLAG))
#define BIT_GET_MGQ_FIFO_REL_INT_FLAG(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG) & \
BIT_MASK_MGQ_FIFO_REL_INT_FLAG)
#define BIT_SET_MGQ_FIFO_REL_INT_FLAG(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG(x) | BIT_MGQ_FIFO_REL_INT_FLAG(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MGG_FIFO_LIFETIME (Offset 0x1478) */
#define BIT_SHIFT_R_MGG_FIFO_LIFETIME 16
#define BIT_MASK_R_MGG_FIFO_LIFETIME 0xffff
#define BIT_R_MGG_FIFO_LIFETIME(x) \
(((x) & BIT_MASK_R_MGG_FIFO_LIFETIME) << BIT_SHIFT_R_MGG_FIFO_LIFETIME)
#define BITS_R_MGG_FIFO_LIFETIME \
(BIT_MASK_R_MGG_FIFO_LIFETIME << BIT_SHIFT_R_MGG_FIFO_LIFETIME)
#define BIT_CLEAR_R_MGG_FIFO_LIFETIME(x) ((x) & (~BITS_R_MGG_FIFO_LIFETIME))
#define BIT_GET_R_MGG_FIFO_LIFETIME(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_LIFETIME) & BIT_MASK_R_MGG_FIFO_LIFETIME)
#define BIT_SET_R_MGG_FIFO_LIFETIME(x, v) \
(BIT_CLEAR_R_MGG_FIFO_LIFETIME(x) | BIT_R_MGG_FIFO_LIFETIME(v))
#define BIT_SHIFT_R_MGG_FIFO_VALID_MAP 0
#define BIT_MASK_R_MGG_FIFO_VALID_MAP 0xffff
#define BIT_R_MGG_FIFO_VALID_MAP(x) \
(((x) & BIT_MASK_R_MGG_FIFO_VALID_MAP) \
<< BIT_SHIFT_R_MGG_FIFO_VALID_MAP)
#define BITS_R_MGG_FIFO_VALID_MAP \
(BIT_MASK_R_MGG_FIFO_VALID_MAP << BIT_SHIFT_R_MGG_FIFO_VALID_MAP)
#define BIT_CLEAR_R_MGG_FIFO_VALID_MAP(x) ((x) & (~BITS_R_MGG_FIFO_VALID_MAP))
#define BIT_GET_R_MGG_FIFO_VALID_MAP(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_VALID_MAP) & \
BIT_MASK_R_MGG_FIFO_VALID_MAP)
#define BIT_SET_R_MGG_FIFO_VALID_MAP(x, v) \
(BIT_CLEAR_R_MGG_FIFO_VALID_MAP(x) | BIT_R_MGG_FIFO_VALID_MAP(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MGQ_FIFO_VALID_MAP (Offset 0x1478) */
#define BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP 0
#define BIT_MASK_MGQ_FIFO_PKT_VALID_MAP 0xffff
#define BIT_MGQ_FIFO_PKT_VALID_MAP(x) \
(((x) & BIT_MASK_MGQ_FIFO_PKT_VALID_MAP) \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP)
#define BITS_MGQ_FIFO_PKT_VALID_MAP \
(BIT_MASK_MGQ_FIFO_PKT_VALID_MAP << BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP)
#define BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP(x) \
((x) & (~BITS_MGQ_FIFO_PKT_VALID_MAP))
#define BIT_GET_MGQ_FIFO_PKT_VALID_MAP(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP) & \
BIT_MASK_MGQ_FIFO_PKT_VALID_MAP)
#define BIT_SET_MGQ_FIFO_PKT_VALID_MAP(x, v) \
(BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP(x) | BIT_MGQ_FIFO_PKT_VALID_MAP(v))
/* 2 REG_MGQ_FIFO_LIFETIME (Offset 0x147A) */
#define BIT_RPT_VALID BIT(13)
#define BIT_SHIFT_MGQ_FIFO_LIFETIME 0
#define BIT_MASK_MGQ_FIFO_LIFETIME 0xffff
#define BIT_MGQ_FIFO_LIFETIME(x) \
(((x) & BIT_MASK_MGQ_FIFO_LIFETIME) << BIT_SHIFT_MGQ_FIFO_LIFETIME)
#define BITS_MGQ_FIFO_LIFETIME \
(BIT_MASK_MGQ_FIFO_LIFETIME << BIT_SHIFT_MGQ_FIFO_LIFETIME)
#define BIT_CLEAR_MGQ_FIFO_LIFETIME(x) ((x) & (~BITS_MGQ_FIFO_LIFETIME))
#define BIT_GET_MGQ_FIFO_LIFETIME(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_LIFETIME) & BIT_MASK_MGQ_FIFO_LIFETIME)
#define BIT_SET_MGQ_FIFO_LIFETIME(x, v) \
(BIT_CLEAR_MGQ_FIFO_LIFETIME(x) | BIT_MGQ_FIFO_LIFETIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET (Offset 0x147C) */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET 0x7f
#define BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET)
#define BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET(x) | \
BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PKT_TRANS (Offset 0x1480) */
#define BIT_SHIFT_IE_DESC_OFFSET 16
#define BIT_MASK_IE_DESC_OFFSET 0x1ff
#define BIT_IE_DESC_OFFSET(x) \
(((x) & BIT_MASK_IE_DESC_OFFSET) << BIT_SHIFT_IE_DESC_OFFSET)
#define BITS_IE_DESC_OFFSET \
(BIT_MASK_IE_DESC_OFFSET << BIT_SHIFT_IE_DESC_OFFSET)
#define BIT_CLEAR_IE_DESC_OFFSET(x) ((x) & (~BITS_IE_DESC_OFFSET))
#define BIT_GET_IE_DESC_OFFSET(x) \
(((x) >> BIT_SHIFT_IE_DESC_OFFSET) & BIT_MASK_IE_DESC_OFFSET)
#define BIT_SET_IE_DESC_OFFSET(x, v) \
(BIT_CLEAR_IE_DESC_OFFSET(x) | BIT_IE_DESC_OFFSET(v))
#define BIT_DIS_FWCMD_PATH_ERRCHK BIT(13)
#define BIT_MAC_HDR_CONVERT_EN BIT(12)
#define BIT_TXDESC_TRANS_EN BIT(8)
#define BIT_PKT_TRANS_ERRINT_EN BIT(7)
#define BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL 4
#define BIT_MASK_PKT_TRANS_ERR_MACID_SEL 0x3
#define BIT_PKT_TRANS_ERR_MACID_SEL(x) \
(((x) & BIT_MASK_PKT_TRANS_ERR_MACID_SEL) \
<< BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL)
#define BITS_PKT_TRANS_ERR_MACID_SEL \
(BIT_MASK_PKT_TRANS_ERR_MACID_SEL << BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL)
#define BIT_CLEAR_PKT_TRANS_ERR_MACID_SEL(x) \
((x) & (~BITS_PKT_TRANS_ERR_MACID_SEL))
#define BIT_GET_PKT_TRANS_ERR_MACID_SEL(x) \
(((x) >> BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL) & \
BIT_MASK_PKT_TRANS_ERR_MACID_SEL)
#define BIT_SET_PKT_TRANS_ERR_MACID_SEL(x, v) \
(BIT_CLEAR_PKT_TRANS_ERR_MACID_SEL(x) | BIT_PKT_TRANS_ERR_MACID_SEL(v))
#define BIT_PKT_TRANS_IEINIT_ERR BIT(3)
#define BIT_PKT_TRANS_IENUM_ERR BIT(2)
#define BIT_PKT_TRANS_IECNT_ERR1 BIT(1)
#define BIT_PKT_TRANS_IECNT_ERR0 BIT(0)
/* 2 REG_SHCUT_LLC_ETH_TYPE1 (Offset 0x1488) */
#define BIT_SHIFT_SHCUT_MHDR_OFFSET 16
#define BIT_MASK_SHCUT_MHDR_OFFSET 0x1ff
#define BIT_SHCUT_MHDR_OFFSET(x) \
(((x) & BIT_MASK_SHCUT_MHDR_OFFSET) << BIT_SHIFT_SHCUT_MHDR_OFFSET)
#define BITS_SHCUT_MHDR_OFFSET \
(BIT_MASK_SHCUT_MHDR_OFFSET << BIT_SHIFT_SHCUT_MHDR_OFFSET)
#define BIT_CLEAR_SHCUT_MHDR_OFFSET(x) ((x) & (~BITS_SHCUT_MHDR_OFFSET))
#define BIT_GET_SHCUT_MHDR_OFFSET(x) \
(((x) >> BIT_SHIFT_SHCUT_MHDR_OFFSET) & BIT_MASK_SHCUT_MHDR_OFFSET)
#define BIT_SET_SHCUT_MHDR_OFFSET(x, v) \
(BIT_CLEAR_SHCUT_MHDR_OFFSET(x) | BIT_SHCUT_MHDR_OFFSET(v))
#define BIT_SHIFT_PKT_TRANS_ERR_MACID 0
#define BIT_MASK_PKT_TRANS_ERR_MACID 0xffffffffL
#define BIT_PKT_TRANS_ERR_MACID(x) \
(((x) & BIT_MASK_PKT_TRANS_ERR_MACID) << BIT_SHIFT_PKT_TRANS_ERR_MACID)
#define BITS_PKT_TRANS_ERR_MACID \
(BIT_MASK_PKT_TRANS_ERR_MACID << BIT_SHIFT_PKT_TRANS_ERR_MACID)
#define BIT_CLEAR_PKT_TRANS_ERR_MACID(x) ((x) & (~BITS_PKT_TRANS_ERR_MACID))
#define BIT_GET_PKT_TRANS_ERR_MACID(x) \
(((x) >> BIT_SHIFT_PKT_TRANS_ERR_MACID) & BIT_MASK_PKT_TRANS_ERR_MACID)
#define BIT_SET_PKT_TRANS_ERR_MACID(x, v) \
(BIT_CLEAR_PKT_TRANS_ERR_MACID(x) | BIT_PKT_TRANS_ERR_MACID(v))
/* 2 REG_FWCMDQ_CTRL (Offset 0x14A0) */
#define BIT_FW_RELEASEPKT_POLLING BIT(31)
#define BIT_SHIFT_FWCMDQ_RELEASE_HEAD 16
#define BIT_MASK_FWCMDQ_RELEASE_HEAD 0xfff
#define BIT_FWCMDQ_RELEASE_HEAD(x) \
(((x) & BIT_MASK_FWCMDQ_RELEASE_HEAD) << BIT_SHIFT_FWCMDQ_RELEASE_HEAD)
#define BITS_FWCMDQ_RELEASE_HEAD \
(BIT_MASK_FWCMDQ_RELEASE_HEAD << BIT_SHIFT_FWCMDQ_RELEASE_HEAD)
#define BIT_CLEAR_FWCMDQ_RELEASE_HEAD(x) ((x) & (~BITS_FWCMDQ_RELEASE_HEAD))
#define BIT_GET_FWCMDQ_RELEASE_HEAD(x) \
(((x) >> BIT_SHIFT_FWCMDQ_RELEASE_HEAD) & BIT_MASK_FWCMDQ_RELEASE_HEAD)
#define BIT_SET_FWCMDQ_RELEASE_HEAD(x, v) \
(BIT_CLEAR_FWCMDQ_RELEASE_HEAD(x) | BIT_FWCMDQ_RELEASE_HEAD(v))
#define BIT_FW_GETPKTT_POLLING BIT(15)
#define BIT_SHIFT_FWCMDQ_H 0
#define BIT_MASK_FWCMDQ_H 0xfff
#define BIT_FWCMDQ_H(x) (((x) & BIT_MASK_FWCMDQ_H) << BIT_SHIFT_FWCMDQ_H)
#define BITS_FWCMDQ_H (BIT_MASK_FWCMDQ_H << BIT_SHIFT_FWCMDQ_H)
#define BIT_CLEAR_FWCMDQ_H(x) ((x) & (~BITS_FWCMDQ_H))
#define BIT_GET_FWCMDQ_H(x) (((x) >> BIT_SHIFT_FWCMDQ_H) & BIT_MASK_FWCMDQ_H)
#define BIT_SET_FWCMDQ_H(x, v) (BIT_CLEAR_FWCMDQ_H(x) | BIT_FWCMDQ_H(v))
/* 2 REG_FWCMDQ_PAGE (Offset 0x14A4) */
#define BIT_SHIFT_FWCMDQ_TOTAL_PAGE 16
#define BIT_MASK_FWCMDQ_TOTAL_PAGE 0xfff
#define BIT_FWCMDQ_TOTAL_PAGE(x) \
(((x) & BIT_MASK_FWCMDQ_TOTAL_PAGE) << BIT_SHIFT_FWCMDQ_TOTAL_PAGE)
#define BITS_FWCMDQ_TOTAL_PAGE \
(BIT_MASK_FWCMDQ_TOTAL_PAGE << BIT_SHIFT_FWCMDQ_TOTAL_PAGE)
#define BIT_CLEAR_FWCMDQ_TOTAL_PAGE(x) ((x) & (~BITS_FWCMDQ_TOTAL_PAGE))
#define BIT_GET_FWCMDQ_TOTAL_PAGE(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TOTAL_PAGE) & BIT_MASK_FWCMDQ_TOTAL_PAGE)
#define BIT_SET_FWCMDQ_TOTAL_PAGE(x, v) \
(BIT_CLEAR_FWCMDQ_TOTAL_PAGE(x) | BIT_FWCMDQ_TOTAL_PAGE(v))
#define BIT_SHIFT_FWCMDQ_QUEUE_PAGE 0
#define BIT_MASK_FWCMDQ_QUEUE_PAGE 0xfff
#define BIT_FWCMDQ_QUEUE_PAGE(x) \
(((x) & BIT_MASK_FWCMDQ_QUEUE_PAGE) << BIT_SHIFT_FWCMDQ_QUEUE_PAGE)
#define BITS_FWCMDQ_QUEUE_PAGE \
(BIT_MASK_FWCMDQ_QUEUE_PAGE << BIT_SHIFT_FWCMDQ_QUEUE_PAGE)
#define BIT_CLEAR_FWCMDQ_QUEUE_PAGE(x) ((x) & (~BITS_FWCMDQ_QUEUE_PAGE))
#define BIT_GET_FWCMDQ_QUEUE_PAGE(x) \
(((x) >> BIT_SHIFT_FWCMDQ_QUEUE_PAGE) & BIT_MASK_FWCMDQ_QUEUE_PAGE)
#define BIT_SET_FWCMDQ_QUEUE_PAGE(x, v) \
(BIT_CLEAR_FWCMDQ_QUEUE_PAGE(x) | BIT_FWCMDQ_QUEUE_PAGE(v))
/* 2 REG_FWCMDQ_INFO (Offset 0x14A8) */
#define BIT_FWCMD_READY BIT(31)
#define BIT_FWCMDQ_OVERFLOW BIT(30)
#define BIT_FWCMDQ_UNDERFLOW BIT(29)
#define BIT_FWCMDQ_RELEASE_MISS BIT(28)
#define BIT_SHIFT_FWCMDQ_TOTAL_PKT 16
#define BIT_MASK_FWCMDQ_TOTAL_PKT 0xfff
#define BIT_FWCMDQ_TOTAL_PKT(x) \
(((x) & BIT_MASK_FWCMDQ_TOTAL_PKT) << BIT_SHIFT_FWCMDQ_TOTAL_PKT)
#define BITS_FWCMDQ_TOTAL_PKT \
(BIT_MASK_FWCMDQ_TOTAL_PKT << BIT_SHIFT_FWCMDQ_TOTAL_PKT)
#define BIT_CLEAR_FWCMDQ_TOTAL_PKT(x) ((x) & (~BITS_FWCMDQ_TOTAL_PKT))
#define BIT_GET_FWCMDQ_TOTAL_PKT(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TOTAL_PKT) & BIT_MASK_FWCMDQ_TOTAL_PKT)
#define BIT_SET_FWCMDQ_TOTAL_PKT(x, v) \
(BIT_CLEAR_FWCMDQ_TOTAL_PKT(x) | BIT_FWCMDQ_TOTAL_PKT(v))
#define BIT_SHIFT_FWCMDQ_QUEUE_PKT 0
#define BIT_MASK_FWCMDQ_QUEUE_PKT 0xfff
#define BIT_FWCMDQ_QUEUE_PKT(x) \
(((x) & BIT_MASK_FWCMDQ_QUEUE_PKT) << BIT_SHIFT_FWCMDQ_QUEUE_PKT)
#define BITS_FWCMDQ_QUEUE_PKT \
(BIT_MASK_FWCMDQ_QUEUE_PKT << BIT_SHIFT_FWCMDQ_QUEUE_PKT)
#define BIT_CLEAR_FWCMDQ_QUEUE_PKT(x) ((x) & (~BITS_FWCMDQ_QUEUE_PKT))
#define BIT_GET_FWCMDQ_QUEUE_PKT(x) \
(((x) >> BIT_SHIFT_FWCMDQ_QUEUE_PKT) & BIT_MASK_FWCMDQ_QUEUE_PKT)
#define BIT_SET_FWCMDQ_QUEUE_PKT(x, v) \
(BIT_CLEAR_FWCMDQ_QUEUE_PKT(x) | BIT_FWCMDQ_QUEUE_PKT(v))
/* 2 REG_FWCMDQ_HOLD_PKTNUM (Offset 0x14AC) */
#define BIT_SHIFT_FWCMDQ_HOLD__PKTNUM 0
#define BIT_MASK_FWCMDQ_HOLD__PKTNUM 0xfff
#define BIT_FWCMDQ_HOLD__PKTNUM(x) \
(((x) & BIT_MASK_FWCMDQ_HOLD__PKTNUM) << BIT_SHIFT_FWCMDQ_HOLD__PKTNUM)
#define BITS_FWCMDQ_HOLD__PKTNUM \
(BIT_MASK_FWCMDQ_HOLD__PKTNUM << BIT_SHIFT_FWCMDQ_HOLD__PKTNUM)
#define BIT_CLEAR_FWCMDQ_HOLD__PKTNUM(x) ((x) & (~BITS_FWCMDQ_HOLD__PKTNUM))
#define BIT_GET_FWCMDQ_HOLD__PKTNUM(x) \
(((x) >> BIT_SHIFT_FWCMDQ_HOLD__PKTNUM) & BIT_MASK_FWCMDQ_HOLD__PKTNUM)
#define BIT_SET_FWCMDQ_HOLD__PKTNUM(x, v) \
(BIT_CLEAR_FWCMDQ_HOLD__PKTNUM(x) | BIT_FWCMDQ_HOLD__PKTNUM(v))
/* 2 REG_MU_TX_CTRL (Offset 0x14C0) */
#define BIT_SEARCH_DONE_RDY BIT(31)
#define BIT_MU_EN BIT(30)
#define BIT_MU_SECONDARY_WAITMODE_EN BIT(29)
#define BIT_MU_BB_SCORE_EN BIT(28)
#define BIT_MU_SECONDARY_ANT_COUNT_EN BIT(27)
#define BIT_MUARB_SEARCH_ERR_EN BIT(26)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TX_CTL (Offset 0x14C0) */
#define BIT_R_MU_P1_WAIT_STATE_EN BIT(16)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_TX_CTRL (Offset 0x14C0) */
#define BIT_SHIFT_DIS_SU_TXBF 16
#define BIT_MASK_DIS_SU_TXBF 0x3f
#define BIT_DIS_SU_TXBF(x) \
(((x) & BIT_MASK_DIS_SU_TXBF) << BIT_SHIFT_DIS_SU_TXBF)
#define BITS_DIS_SU_TXBF (BIT_MASK_DIS_SU_TXBF << BIT_SHIFT_DIS_SU_TXBF)
#define BIT_CLEAR_DIS_SU_TXBF(x) ((x) & (~BITS_DIS_SU_TXBF))
#define BIT_GET_DIS_SU_TXBF(x) \
(((x) >> BIT_SHIFT_DIS_SU_TXBF) & BIT_MASK_DIS_SU_TXBF)
#define BIT_SET_DIS_SU_TXBF(x, v) \
(BIT_CLEAR_DIS_SU_TXBF(x) | BIT_DIS_SU_TXBF(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TX_CTL (Offset 0x14C0) */
#define BIT_SHIFT_R_MU_RL 12
#define BIT_MASK_R_MU_RL 0xf
#define BIT_R_MU_RL(x) (((x) & BIT_MASK_R_MU_RL) << BIT_SHIFT_R_MU_RL)
#define BITS_R_MU_RL (BIT_MASK_R_MU_RL << BIT_SHIFT_R_MU_RL)
#define BIT_CLEAR_R_MU_RL(x) ((x) & (~BITS_R_MU_RL))
#define BIT_GET_R_MU_RL(x) (((x) >> BIT_SHIFT_R_MU_RL) & BIT_MASK_R_MU_RL)
#define BIT_SET_R_MU_RL(x, v) (BIT_CLEAR_R_MU_RL(x) | BIT_R_MU_RL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_TX_CTRL (Offset 0x14C0) */
#define BIT_SHIFT_MU_RL 12
#define BIT_MASK_MU_RL 0xf
#define BIT_MU_RL(x) (((x) & BIT_MASK_MU_RL) << BIT_SHIFT_MU_RL)
#define BITS_MU_RL (BIT_MASK_MU_RL << BIT_SHIFT_MU_RL)
#define BIT_CLEAR_MU_RL(x) ((x) & (~BITS_MU_RL))
#define BIT_GET_MU_RL(x) (((x) >> BIT_SHIFT_MU_RL) & BIT_MASK_MU_RL)
#define BIT_SET_MU_RL(x, v) (BIT_CLEAR_MU_RL(x) | BIT_MU_RL(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TX_CTL (Offset 0x14C0) */
#define BIT_R_FORCE_P1_RATEDOWN BIT(11)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TX_CTL (Offset 0x14C0) */
#define BIT_SHIFT_R_MU_TAB_SEL 8
#define BIT_MASK_R_MU_TAB_SEL 0x7
#define BIT_R_MU_TAB_SEL(x) \
(((x) & BIT_MASK_R_MU_TAB_SEL) << BIT_SHIFT_R_MU_TAB_SEL)
#define BITS_R_MU_TAB_SEL (BIT_MASK_R_MU_TAB_SEL << BIT_SHIFT_R_MU_TAB_SEL)
#define BIT_CLEAR_R_MU_TAB_SEL(x) ((x) & (~BITS_R_MU_TAB_SEL))
#define BIT_GET_R_MU_TAB_SEL(x) \
(((x) >> BIT_SHIFT_R_MU_TAB_SEL) & BIT_MASK_R_MU_TAB_SEL)
#define BIT_SET_R_MU_TAB_SEL(x, v) \
(BIT_CLEAR_R_MU_TAB_SEL(x) | BIT_R_MU_TAB_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_TX_CTRL (Offset 0x14C0) */
#define BIT_SHIFT_MU_TAB_SEL 8
#define BIT_MASK_MU_TAB_SEL 0xf
#define BIT_MU_TAB_SEL(x) (((x) & BIT_MASK_MU_TAB_SEL) << BIT_SHIFT_MU_TAB_SEL)
#define BITS_MU_TAB_SEL (BIT_MASK_MU_TAB_SEL << BIT_SHIFT_MU_TAB_SEL)
#define BIT_CLEAR_MU_TAB_SEL(x) ((x) & (~BITS_MU_TAB_SEL))
#define BIT_GET_MU_TAB_SEL(x) \
(((x) >> BIT_SHIFT_MU_TAB_SEL) & BIT_MASK_MU_TAB_SEL)
#define BIT_SET_MU_TAB_SEL(x, v) (BIT_CLEAR_MU_TAB_SEL(x) | BIT_MU_TAB_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TX_CTL (Offset 0x14C0) */
#define BIT_R_EN_MU_MIMO BIT(7)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TX_CTL (Offset 0x14C0) */
#define BIT_R_EN_REVERS_GTAB BIT(6)
#define BIT_SHIFT_R_MU_TABLE_VALID 0
#define BIT_MASK_R_MU_TABLE_VALID 0x3f
#define BIT_R_MU_TABLE_VALID(x) \
(((x) & BIT_MASK_R_MU_TABLE_VALID) << BIT_SHIFT_R_MU_TABLE_VALID)
#define BITS_R_MU_TABLE_VALID \
(BIT_MASK_R_MU_TABLE_VALID << BIT_SHIFT_R_MU_TABLE_VALID)
#define BIT_CLEAR_R_MU_TABLE_VALID(x) ((x) & (~BITS_R_MU_TABLE_VALID))
#define BIT_GET_R_MU_TABLE_VALID(x) \
(((x) >> BIT_SHIFT_R_MU_TABLE_VALID) & BIT_MASK_R_MU_TABLE_VALID)
#define BIT_SET_R_MU_TABLE_VALID(x, v) \
(BIT_CLEAR_R_MU_TABLE_VALID(x) | BIT_R_MU_TABLE_VALID(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_TX_CTRL (Offset 0x14C0) */
#define BIT_SHIFT_MU_TAB_VALID 0
#define BIT_MASK_MU_TAB_VALID 0x3f
#define BIT_MU_TAB_VALID(x) \
(((x) & BIT_MASK_MU_TAB_VALID) << BIT_SHIFT_MU_TAB_VALID)
#define BITS_MU_TAB_VALID (BIT_MASK_MU_TAB_VALID << BIT_SHIFT_MU_TAB_VALID)
#define BIT_CLEAR_MU_TAB_VALID(x) ((x) & (~BITS_MU_TAB_VALID))
#define BIT_GET_MU_TAB_VALID(x) \
(((x) >> BIT_SHIFT_MU_TAB_VALID) & BIT_MASK_MU_TAB_VALID)
#define BIT_SET_MU_TAB_VALID(x, v) \
(BIT_CLEAR_MU_TAB_VALID(x) | BIT_MU_TAB_VALID(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_STA_GID_VLD (Offset 0x14C4) */
#define BIT_SHIFT_R_MU_STA_GTAB_VALID 0
#define BIT_MASK_R_MU_STA_GTAB_VALID 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID) << BIT_SHIFT_R_MU_STA_GTAB_VALID)
#define BITS_R_MU_STA_GTAB_VALID \
(BIT_MASK_R_MU_STA_GTAB_VALID << BIT_SHIFT_R_MU_STA_GTAB_VALID)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID(x) ((x) & (~BITS_R_MU_STA_GTAB_VALID))
#define BIT_GET_R_MU_STA_GTAB_VALID(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID) & BIT_MASK_R_MU_STA_GTAB_VALID)
#define BIT_SET_R_MU_STA_GTAB_VALID(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID(x) | BIT_R_MU_STA_GTAB_VALID(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_STA_GID_VLD (Offset 0x14C4) */
#define BIT_SHIFT_MU_STA_GTAB_VALID 0
#define BIT_MASK_MU_STA_GTAB_VALID 0xffffffffL
#define BIT_MU_STA_GTAB_VALID(x) \
(((x) & BIT_MASK_MU_STA_GTAB_VALID) << BIT_SHIFT_MU_STA_GTAB_VALID)
#define BITS_MU_STA_GTAB_VALID \
(BIT_MASK_MU_STA_GTAB_VALID << BIT_SHIFT_MU_STA_GTAB_VALID)
#define BIT_CLEAR_MU_STA_GTAB_VALID(x) ((x) & (~BITS_MU_STA_GTAB_VALID))
#define BIT_GET_MU_STA_GTAB_VALID(x) \
(((x) >> BIT_SHIFT_MU_STA_GTAB_VALID) & BIT_MASK_MU_STA_GTAB_VALID)
#define BIT_SET_MU_STA_GTAB_VALID(x, v) \
(BIT_CLEAR_MU_STA_GTAB_VALID(x) | BIT_MU_STA_GTAB_VALID(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MU_STA_USER_POS_INFO (Offset 0x14C8) */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_L 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_L 0xffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_L(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_L) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_L)
#define BITS_R_MU_STA_GTAB_POSITION_L \
(BIT_MASK_R_MU_STA_GTAB_POSITION_L \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_L)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_L(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_L))
#define BIT_GET_R_MU_STA_GTAB_POSITION_L(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_L) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_L)
#define BIT_SET_R_MU_STA_GTAB_POSITION_L(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_L(x) | \
BIT_R_MU_STA_GTAB_POSITION_L(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_STA_USER_POS_INFO (Offset 0x14C8) */
#define BIT_SHIFT_MU_STA_GTAB_POSITION_L 0
#define BIT_MASK_MU_STA_GTAB_POSITION_L 0xffffffffL
#define BIT_MU_STA_GTAB_POSITION_L(x) \
(((x) & BIT_MASK_MU_STA_GTAB_POSITION_L) \
<< BIT_SHIFT_MU_STA_GTAB_POSITION_L)
#define BITS_MU_STA_GTAB_POSITION_L \
(BIT_MASK_MU_STA_GTAB_POSITION_L << BIT_SHIFT_MU_STA_GTAB_POSITION_L)
#define BIT_CLEAR_MU_STA_GTAB_POSITION_L(x) \
((x) & (~BITS_MU_STA_GTAB_POSITION_L))
#define BIT_GET_MU_STA_GTAB_POSITION_L(x) \
(((x) >> BIT_SHIFT_MU_STA_GTAB_POSITION_L) & \
BIT_MASK_MU_STA_GTAB_POSITION_L)
#define BIT_SET_MU_STA_GTAB_POSITION_L(x, v) \
(BIT_CLEAR_MU_STA_GTAB_POSITION_L(x) | BIT_MU_STA_GTAB_POSITION_L(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_MU_STA_USER_POS_INFO_H (Offset 0x14CC) */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_H 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_H 0xffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_H(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_H) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_H)
#define BITS_R_MU_STA_GTAB_POSITION_H \
(BIT_MASK_R_MU_STA_GTAB_POSITION_H \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_H)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_H(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_H))
#define BIT_GET_R_MU_STA_GTAB_POSITION_H(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_H) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_H)
#define BIT_SET_R_MU_STA_GTAB_POSITION_H(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_H(x) | \
BIT_R_MU_STA_GTAB_POSITION_H(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_STA_USER_POS_INFO_H (Offset 0x14CC) */
#define BIT_SHIFT_MU_STA_GTAB_POSITION_H 0
#define BIT_MASK_MU_STA_GTAB_POSITION_H 0xffffffffL
#define BIT_MU_STA_GTAB_POSITION_H(x) \
(((x) & BIT_MASK_MU_STA_GTAB_POSITION_H) \
<< BIT_SHIFT_MU_STA_GTAB_POSITION_H)
#define BITS_MU_STA_GTAB_POSITION_H \
(BIT_MASK_MU_STA_GTAB_POSITION_H << BIT_SHIFT_MU_STA_GTAB_POSITION_H)
#define BIT_CLEAR_MU_STA_GTAB_POSITION_H(x) \
((x) & (~BITS_MU_STA_GTAB_POSITION_H))
#define BIT_GET_MU_STA_GTAB_POSITION_H(x) \
(((x) >> BIT_SHIFT_MU_STA_GTAB_POSITION_H) & \
BIT_MASK_MU_STA_GTAB_POSITION_H)
#define BIT_SET_MU_STA_GTAB_POSITION_H(x, v) \
(BIT_CLEAR_MU_STA_GTAB_POSITION_H(x) | BIT_MU_STA_GTAB_POSITION_H(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TRX_DBG_CNT (Offset 0x14D0) */
#define BIT_MU_DNGCNT_RST BIT(20)
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MU_TRX_DBG_CNT (Offset 0x14D0) */
#define BIT_SHIFT_MU_DBGCNT_SEL 16
#define BIT_MASK_MU_DBGCNT_SEL 0xf
#define BIT_MU_DBGCNT_SEL(x) \
(((x) & BIT_MASK_MU_DBGCNT_SEL) << BIT_SHIFT_MU_DBGCNT_SEL)
#define BITS_MU_DBGCNT_SEL (BIT_MASK_MU_DBGCNT_SEL << BIT_SHIFT_MU_DBGCNT_SEL)
#define BIT_CLEAR_MU_DBGCNT_SEL(x) ((x) & (~BITS_MU_DBGCNT_SEL))
#define BIT_GET_MU_DBGCNT_SEL(x) \
(((x) >> BIT_SHIFT_MU_DBGCNT_SEL) & BIT_MASK_MU_DBGCNT_SEL)
#define BIT_SET_MU_DBGCNT_SEL(x, v) \
(BIT_CLEAR_MU_DBGCNT_SEL(x) | BIT_MU_DBGCNT_SEL(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_CHNL_REF_RXNAV BIT(7)
#define BIT_CHNL_REF_VBON BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_CHNL_REF_EDCCA BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_CHNL_REF_CCA BIT(4)
#define BIT_MACTX_ERR_4 BIT(4)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_RST_CHNL_BUSY BIT(3)
#define BIT_RST_CHNL_IDLE BIT(2)
#define BIT_CHNL_INFO_RST BIT(1)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD 1
#define BIT_MASK_VHTHT_MIMO_CTRL_FIELD 0xffffff
#define BIT_VHTHT_MIMO_CTRL_FIELD(x) \
(((x) & BIT_MASK_VHTHT_MIMO_CTRL_FIELD) \
<< BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD)
#define BITS_VHTHT_MIMO_CTRL_FIELD \
(BIT_MASK_VHTHT_MIMO_CTRL_FIELD << BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD)
#define BIT_CLEAR_VHTHT_MIMO_CTRL_FIELD(x) ((x) & (~BITS_VHTHT_MIMO_CTRL_FIELD))
#define BIT_GET_VHTHT_MIMO_CTRL_FIELD(x) \
(((x) >> BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD) & \
BIT_MASK_VHTHT_MIMO_CTRL_FIELD)
#define BIT_SET_VHTHT_MIMO_CTRL_FIELD(x, v) \
(BIT_CLEAR_VHTHT_MIMO_CTRL_FIELD(x) | BIT_VHTHT_MIMO_CTRL_FIELD(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_ATM_AIRTIME_EN BIT(0)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL (Offset 0x14D0) */
#define BIT_CSI_INTERRUPT_STATUS BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TRX_DBG_CNT (Offset 0x14D0) */
#define BIT_SHIFT_MU_DNGCNT 0
#define BIT_MASK_MU_DNGCNT 0xffff
#define BIT_MU_DNGCNT(x) (((x) & BIT_MASK_MU_DNGCNT) << BIT_SHIFT_MU_DNGCNT)
#define BITS_MU_DNGCNT (BIT_MASK_MU_DNGCNT << BIT_SHIFT_MU_DNGCNT)
#define BIT_CLEAR_MU_DNGCNT(x) ((x) & (~BITS_MU_DNGCNT))
#define BIT_GET_MU_DNGCNT(x) (((x) >> BIT_SHIFT_MU_DNGCNT) & BIT_MASK_MU_DNGCNT)
#define BIT_SET_MU_DNGCNT(x, v) (BIT_CLEAR_MU_DNGCNT(x) | BIT_MU_DNGCNT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_BUSY_TIME (Offset 0x14D8) */
#define BIT_SHIFT_CHNL_BUSY_TIME 0
#define BIT_MASK_CHNL_BUSY_TIME 0xffffffffL
#define BIT_CHNL_BUSY_TIME(x) \
(((x) & BIT_MASK_CHNL_BUSY_TIME) << BIT_SHIFT_CHNL_BUSY_TIME)
#define BITS_CHNL_BUSY_TIME \
(BIT_MASK_CHNL_BUSY_TIME << BIT_SHIFT_CHNL_BUSY_TIME)
#define BIT_CLEAR_CHNL_BUSY_TIME(x) ((x) & (~BITS_CHNL_BUSY_TIME))
#define BIT_GET_CHNL_BUSY_TIME(x) \
(((x) >> BIT_SHIFT_CHNL_BUSY_TIME) & BIT_MASK_CHNL_BUSY_TIME)
#define BIT_SET_CHNL_BUSY_TIME(x, v) \
(BIT_CLEAR_CHNL_BUSY_TIME(x) | BIT_CHNL_BUSY_TIME(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_MU_TRX_DBG_CNT_V1 (Offset 0x14DC) */
#define BIT_FORCE_SND_STS_EN BIT(31)
#define BIT_SHIFT_SND_STS_VALUE 24
#define BIT_MASK_SND_STS_VALUE 0x3f
#define BIT_SND_STS_VALUE(x) \
(((x) & BIT_MASK_SND_STS_VALUE) << BIT_SHIFT_SND_STS_VALUE)
#define BITS_SND_STS_VALUE (BIT_MASK_SND_STS_VALUE << BIT_SHIFT_SND_STS_VALUE)
#define BIT_CLEAR_SND_STS_VALUE(x) ((x) & (~BITS_SND_STS_VALUE))
#define BIT_GET_SND_STS_VALUE(x) \
(((x) >> BIT_SHIFT_SND_STS_VALUE) & BIT_MASK_SND_STS_VALUE)
#define BIT_SET_SND_STS_VALUE(x, v) \
(BIT_CLEAR_SND_STS_VALUE(x) | BIT_SND_STS_VALUE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_TRX_DBG_CNT_V1 (Offset 0x14DC) */
#define BIT_SHIFT_MU_DNGCNT_SEL 16
#define BIT_MASK_MU_DNGCNT_SEL 0xf
#define BIT_MU_DNGCNT_SEL(x) \
(((x) & BIT_MASK_MU_DNGCNT_SEL) << BIT_SHIFT_MU_DNGCNT_SEL)
#define BITS_MU_DNGCNT_SEL (BIT_MASK_MU_DNGCNT_SEL << BIT_SHIFT_MU_DNGCNT_SEL)
#define BIT_CLEAR_MU_DNGCNT_SEL(x) ((x) & (~BITS_MU_DNGCNT_SEL))
#define BIT_GET_MU_DNGCNT_SEL(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_SEL) & BIT_MASK_MU_DNGCNT_SEL)
#define BIT_SET_MU_DNGCNT_SEL(x, v) \
(BIT_CLEAR_MU_DNGCNT_SEL(x) | BIT_MU_DNGCNT_SEL(v))
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_SU_DURATION (Offset 0x14F0) */
#define BIT_SHIFT_SU_DURATION 0
#define BIT_MASK_SU_DURATION 0xffff
#define BIT_SU_DURATION(x) \
(((x) & BIT_MASK_SU_DURATION) << BIT_SHIFT_SU_DURATION)
#define BITS_SU_DURATION (BIT_MASK_SU_DURATION << BIT_SHIFT_SU_DURATION)
#define BIT_CLEAR_SU_DURATION(x) ((x) & (~BITS_SU_DURATION))
#define BIT_GET_SU_DURATION(x) \
(((x) >> BIT_SHIFT_SU_DURATION) & BIT_MASK_SU_DURATION)
#define BIT_SET_SU_DURATION(x, v) \
(BIT_CLEAR_SU_DURATION(x) | BIT_SU_DURATION(v))
/* 2 REG_MU_DURATION (Offset 0x14F2) */
#define BIT_SHIFT_MU_DURATION 0
#define BIT_MASK_MU_DURATION 0xffff
#define BIT_MU_DURATION(x) \
(((x) & BIT_MASK_MU_DURATION) << BIT_SHIFT_MU_DURATION)
#define BITS_MU_DURATION (BIT_MASK_MU_DURATION << BIT_SHIFT_MU_DURATION)
#define BIT_CLEAR_MU_DURATION(x) ((x) & (~BITS_MU_DURATION))
#define BIT_GET_MU_DURATION(x) \
(((x) >> BIT_SHIFT_MU_DURATION) & BIT_MASK_MU_DURATION)
#define BIT_SET_MU_DURATION(x, v) \
(BIT_CLEAR_MU_DURATION(x) | BIT_MU_DURATION(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_SWPS_CTRL (Offset 0x14F4) */
#define BIT_SHIFT_SWPS_PKT_TH_V1 16
#define BIT_MASK_SWPS_PKT_TH_V1 0xffff
#define BIT_SWPS_PKT_TH_V1(x) \
(((x) & BIT_MASK_SWPS_PKT_TH_V1) << BIT_SHIFT_SWPS_PKT_TH_V1)
#define BITS_SWPS_PKT_TH_V1 \
(BIT_MASK_SWPS_PKT_TH_V1 << BIT_SHIFT_SWPS_PKT_TH_V1)
#define BIT_CLEAR_SWPS_PKT_TH_V1(x) ((x) & (~BITS_SWPS_PKT_TH_V1))
#define BIT_GET_SWPS_PKT_TH_V1(x) \
(((x) >> BIT_SHIFT_SWPS_PKT_TH_V1) & BIT_MASK_SWPS_PKT_TH_V1)
#define BIT_SET_SWPS_PKT_TH_V1(x, v) \
(BIT_CLEAR_SWPS_PKT_TH_V1(x) | BIT_SWPS_PKT_TH_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_SWPS_CTRL (Offset 0x14F4) */
#define BIT_SHIFT_SWPS_RPT_LENGTH 8
#define BIT_MASK_SWPS_RPT_LENGTH 0x7f
#define BIT_SWPS_RPT_LENGTH(x) \
(((x) & BIT_MASK_SWPS_RPT_LENGTH) << BIT_SHIFT_SWPS_RPT_LENGTH)
#define BITS_SWPS_RPT_LENGTH \
(BIT_MASK_SWPS_RPT_LENGTH << BIT_SHIFT_SWPS_RPT_LENGTH)
#define BIT_CLEAR_SWPS_RPT_LENGTH(x) ((x) & (~BITS_SWPS_RPT_LENGTH))
#define BIT_GET_SWPS_RPT_LENGTH(x) \
(((x) >> BIT_SHIFT_SWPS_RPT_LENGTH) & BIT_MASK_SWPS_RPT_LENGTH)
#define BIT_SET_SWPS_RPT_LENGTH(x, v) \
(BIT_CLEAR_SWPS_RPT_LENGTH(x) | BIT_SWPS_RPT_LENGTH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_SWPS_CTRL (Offset 0x14F4) */
#define BIT_SHIFT_MACID_SWPS_EN_SEL 2
#define BIT_MASK_MACID_SWPS_EN_SEL 0x3
#define BIT_MACID_SWPS_EN_SEL(x) \
(((x) & BIT_MASK_MACID_SWPS_EN_SEL) << BIT_SHIFT_MACID_SWPS_EN_SEL)
#define BITS_MACID_SWPS_EN_SEL \
(BIT_MASK_MACID_SWPS_EN_SEL << BIT_SHIFT_MACID_SWPS_EN_SEL)
#define BIT_CLEAR_MACID_SWPS_EN_SEL(x) ((x) & (~BITS_MACID_SWPS_EN_SEL))
#define BIT_GET_MACID_SWPS_EN_SEL(x) \
(((x) >> BIT_SHIFT_MACID_SWPS_EN_SEL) & BIT_MASK_MACID_SWPS_EN_SEL)
#define BIT_SET_MACID_SWPS_EN_SEL(x, v) \
(BIT_CLEAR_MACID_SWPS_EN_SEL(x) | BIT_MACID_SWPS_EN_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_SWPS_CTRL (Offset 0x14F4) */
#define BIT_MACID_SWPS_EN_SEL_V1 BIT(2)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_SWPS_CTRL (Offset 0x14F4) */
#define BIT_SWPS_MANUALL_POLLING BIT(1)
#define BIT_SWPS_EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_HW_NDPA_RTY_LIMIT (Offset 0x14F4) */
#define BIT_SHIFT_HW_NDPA_RTY_LIMIT 0
#define BIT_MASK_HW_NDPA_RTY_LIMIT 0xf
#define BIT_HW_NDPA_RTY_LIMIT(x) \
(((x) & BIT_MASK_HW_NDPA_RTY_LIMIT) << BIT_SHIFT_HW_NDPA_RTY_LIMIT)
#define BITS_HW_NDPA_RTY_LIMIT \
(BIT_MASK_HW_NDPA_RTY_LIMIT << BIT_SHIFT_HW_NDPA_RTY_LIMIT)
#define BIT_CLEAR_HW_NDPA_RTY_LIMIT(x) ((x) & (~BITS_HW_NDPA_RTY_LIMIT))
#define BIT_GET_HW_NDPA_RTY_LIMIT(x) \
(((x) >> BIT_SHIFT_HW_NDPA_RTY_LIMIT) & BIT_MASK_HW_NDPA_RTY_LIMIT)
#define BIT_SET_HW_NDPA_RTY_LIMIT(x, v) \
(BIT_CLEAR_HW_NDPA_RTY_LIMIT(x) | BIT_HW_NDPA_RTY_LIMIT(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_MACID_SWPS_EN (Offset 0x14FC) */
#define BIT_SHIFT_MACID_SWPS_EN 0
#define BIT_MASK_MACID_SWPS_EN 0xffffffffL
#define BIT_MACID_SWPS_EN(x) \
(((x) & BIT_MASK_MACID_SWPS_EN) << BIT_SHIFT_MACID_SWPS_EN)
#define BITS_MACID_SWPS_EN (BIT_MASK_MACID_SWPS_EN << BIT_SHIFT_MACID_SWPS_EN)
#define BIT_CLEAR_MACID_SWPS_EN(x) ((x) & (~BITS_MACID_SWPS_EN))
#define BIT_GET_MACID_SWPS_EN(x) \
(((x) >> BIT_SHIFT_MACID_SWPS_EN) & BIT_MASK_MACID_SWPS_EN)
#define BIT_SET_MACID_SWPS_EN(x, v) \
(BIT_CLEAR_MACID_SWPS_EN(x) | BIT_MACID_SWPS_EN(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PORT_CTRL_SEL (Offset 0x1500) */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1 4
#define BIT_MASK_BCN_TIMER_SEL_FWRD_V1 0x7
#define BIT_BCN_TIMER_SEL_FWRD_V1(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD_V1) \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1)
#define BITS_BCN_TIMER_SEL_FWRD_V1 \
(BIT_MASK_BCN_TIMER_SEL_FWRD_V1 << BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD_V1(x) ((x) & (~BITS_BCN_TIMER_SEL_FWRD_V1))
#define BIT_GET_BCN_TIMER_SEL_FWRD_V1(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1) & \
BIT_MASK_BCN_TIMER_SEL_FWRD_V1)
#define BIT_SET_BCN_TIMER_SEL_FWRD_V1(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD_V1(x) | BIT_BCN_TIMER_SEL_FWRD_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CPUMGQ_TX_TIMER (Offset 0x1500) */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_V1 0
#define BIT_MASK_CPUMGQ_TX_TIMER_V1 0xffffffffL
#define BIT_CPUMGQ_TX_TIMER_V1(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_V1) << BIT_SHIFT_CPUMGQ_TX_TIMER_V1)
#define BITS_CPUMGQ_TX_TIMER_V1 \
(BIT_MASK_CPUMGQ_TX_TIMER_V1 << BIT_SHIFT_CPUMGQ_TX_TIMER_V1)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_V1(x) ((x) & (~BITS_CPUMGQ_TX_TIMER_V1))
#define BIT_GET_CPUMGQ_TX_TIMER_V1(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_V1) & BIT_MASK_CPUMGQ_TX_TIMER_V1)
#define BIT_SET_CPUMGQ_TX_TIMER_V1(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_V1(x) | BIT_CPUMGQ_TX_TIMER_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_PORT_CTRL_SEL (Offset 0x1500) */
#define BIT_SHIFT_PORT_CTRL_SEL 0
#define BIT_MASK_PORT_CTRL_SEL 0x7
#define BIT_PORT_CTRL_SEL(x) \
(((x) & BIT_MASK_PORT_CTRL_SEL) << BIT_SHIFT_PORT_CTRL_SEL)
#define BITS_PORT_CTRL_SEL (BIT_MASK_PORT_CTRL_SEL << BIT_SHIFT_PORT_CTRL_SEL)
#define BIT_CLEAR_PORT_CTRL_SEL(x) ((x) & (~BITS_PORT_CTRL_SEL))
#define BIT_GET_PORT_CTRL_SEL(x) \
(((x) >> BIT_SHIFT_PORT_CTRL_SEL) & BIT_MASK_PORT_CTRL_SEL)
#define BIT_SET_PORT_CTRL_SEL(x, v) \
(BIT_CLEAR_PORT_CTRL_SEL(x) | BIT_PORT_CTRL_SEL(v))
/* 2 REG_PORT_CTRL_CFG (Offset 0x1501) */
#define BIT_BCNERR_CNT_EN_V1 BIT(11)
#define BIT_DIS_TRX_CAL_BCN_V1 BIT(10)
#define BIT_DIS_TX_CAL_TBTT_V1 BIT(9)
#define BIT_BCN_AGGRESSION_V1 BIT(8)
#define BIT_TSFTR_RST_V1 BIT(7)
#define BIT_EN_TXBCN_RPT_V1 BIT(5)
#define BIT_EN_PORT_FUNCTION BIT(3)
#define BIT_EN_RXBCN_RPT BIT(2)
/* 2 REG_TBTT_PROHIBIT_CFG (Offset 0x1504) */
#define BIT_MASK_PROHIBIT BIT(23)
#define BIT_SHIFT_TBTT_HOLD_TIME 8
#define BIT_MASK_TBTT_HOLD_TIME 0xfff
#define BIT_TBTT_HOLD_TIME(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME) << BIT_SHIFT_TBTT_HOLD_TIME)
#define BITS_TBTT_HOLD_TIME \
(BIT_MASK_TBTT_HOLD_TIME << BIT_SHIFT_TBTT_HOLD_TIME)
#define BIT_CLEAR_TBTT_HOLD_TIME(x) ((x) & (~BITS_TBTT_HOLD_TIME))
#define BIT_GET_TBTT_HOLD_TIME(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME) & BIT_MASK_TBTT_HOLD_TIME)
#define BIT_SET_TBTT_HOLD_TIME(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME(x) | BIT_TBTT_HOLD_TIME(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PS_TIMER_A (Offset 0x1504) */
#define BIT_SHIFT_PS_TIMER_A_V1 0
#define BIT_MASK_PS_TIMER_A_V1 0xffffffffL
#define BIT_PS_TIMER_A_V1(x) \
(((x) & BIT_MASK_PS_TIMER_A_V1) << BIT_SHIFT_PS_TIMER_A_V1)
#define BITS_PS_TIMER_A_V1 (BIT_MASK_PS_TIMER_A_V1 << BIT_SHIFT_PS_TIMER_A_V1)
#define BIT_CLEAR_PS_TIMER_A_V1(x) ((x) & (~BITS_PS_TIMER_A_V1))
#define BIT_GET_PS_TIMER_A_V1(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_V1) & BIT_MASK_PS_TIMER_A_V1)
#define BIT_SET_PS_TIMER_A_V1(x, v) \
(BIT_CLEAR_PS_TIMER_A_V1(x) | BIT_PS_TIMER_A_V1(v))
/* 2 REG_PS_TIMER_B (Offset 0x1508) */
#define BIT_SHIFT_PS_TIMER_B_V1 0
#define BIT_MASK_PS_TIMER_B_V1 0xffffffffL
#define BIT_PS_TIMER_B_V1(x) \
(((x) & BIT_MASK_PS_TIMER_B_V1) << BIT_SHIFT_PS_TIMER_B_V1)
#define BITS_PS_TIMER_B_V1 (BIT_MASK_PS_TIMER_B_V1 << BIT_SHIFT_PS_TIMER_B_V1)
#define BIT_CLEAR_PS_TIMER_B_V1(x) ((x) & (~BITS_PS_TIMER_B_V1))
#define BIT_GET_PS_TIMER_B_V1(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_V1) & BIT_MASK_PS_TIMER_B_V1)
#define BIT_SET_PS_TIMER_B_V1(x, v) \
(BIT_CLEAR_PS_TIMER_B_V1(x) | BIT_PS_TIMER_B_V1(v))
/* 2 REG_PS_TIMER_C (Offset 0x150C) */
#define BIT_SHIFT_PS_TIMER_C_V1 0
#define BIT_MASK_PS_TIMER_C_V1 0xffffffffL
#define BIT_PS_TIMER_C_V1(x) \
(((x) & BIT_MASK_PS_TIMER_C_V1) << BIT_SHIFT_PS_TIMER_C_V1)
#define BITS_PS_TIMER_C_V1 (BIT_MASK_PS_TIMER_C_V1 << BIT_SHIFT_PS_TIMER_C_V1)
#define BIT_CLEAR_PS_TIMER_C_V1(x) ((x) & (~BITS_PS_TIMER_C_V1))
#define BIT_GET_PS_TIMER_C_V1(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_V1) & BIT_MASK_PS_TIMER_C_V1)
#define BIT_SET_PS_TIMER_C_V1(x, v) \
(BIT_CLEAR_PS_TIMER_C_V1(x) | BIT_PS_TIMER_C_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TSFTR_SYNC_OFFSET_CFG (Offset 0x150C) */
#define BIT_SHIFT_TSFTR_SNC_OFFSET_V1 0
#define BIT_MASK_TSFTR_SNC_OFFSET_V1 0xffffff
#define BIT_TSFTR_SNC_OFFSET_V1(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET_V1) << BIT_SHIFT_TSFTR_SNC_OFFSET_V1)
#define BITS_TSFTR_SNC_OFFSET_V1 \
(BIT_MASK_TSFTR_SNC_OFFSET_V1 << BIT_SHIFT_TSFTR_SNC_OFFSET_V1)
#define BIT_CLEAR_TSFTR_SNC_OFFSET_V1(x) ((x) & (~BITS_TSFTR_SNC_OFFSET_V1))
#define BIT_GET_TSFTR_SNC_OFFSET_V1(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET_V1) & BIT_MASK_TSFTR_SNC_OFFSET_V1)
#define BIT_SET_TSFTR_SNC_OFFSET_V1(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET_V1(x) | BIT_TSFTR_SNC_OFFSET_V1(v))
/* 2 REG_TSFTR_SYNC_CTRL_CFG (Offset 0x150F) */
#define BIT_SYNC_TSF_NOW_V1 BIT(5)
#define BIT_SYNC_TSF_ONCE BIT(4)
#define BIT_SYNC_TSF_AUTO BIT(3)
#define BIT_SHIFT_SYNC_PORT_SEL 0
#define BIT_MASK_SYNC_PORT_SEL 0x7
#define BIT_SYNC_PORT_SEL(x) \
(((x) & BIT_MASK_SYNC_PORT_SEL) << BIT_SHIFT_SYNC_PORT_SEL)
#define BITS_SYNC_PORT_SEL (BIT_MASK_SYNC_PORT_SEL << BIT_SHIFT_SYNC_PORT_SEL)
#define BIT_CLEAR_SYNC_PORT_SEL(x) ((x) & (~BITS_SYNC_PORT_SEL))
#define BIT_GET_SYNC_PORT_SEL(x) \
(((x) >> BIT_SHIFT_SYNC_PORT_SEL) & BIT_MASK_SYNC_PORT_SEL)
#define BIT_SET_SYNC_PORT_SEL(x, v) \
(BIT_CLEAR_SYNC_PORT_SEL(x) | BIT_SYNC_PORT_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL (Offset 0x1510) */
#define BIT_CPUMGQ_TIMER_EN BIT(31)
#define BIT_CPUMGQ_TX_EN BIT(28)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL 24
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL)
#define BITS_CPUMGQ_TIMER_TSF_SEL \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL << BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL(x) ((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL(x) | BIT_CPUMGQ_TIMER_TSF_SEL(v))
#define BIT_PS_TIMER_C_EN BIT(23)
#define BIT_SHIFT_PS_TIMER_C_TSF_SEL 16
#define BIT_MASK_PS_TIMER_C_TSF_SEL 0x7
#define BIT_PS_TIMER_C_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_C_TSF_SEL) << BIT_SHIFT_PS_TIMER_C_TSF_SEL)
#define BITS_PS_TIMER_C_TSF_SEL \
(BIT_MASK_PS_TIMER_C_TSF_SEL << BIT_SHIFT_PS_TIMER_C_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_C_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_C_TSF_SEL))
#define BIT_GET_PS_TIMER_C_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_TSF_SEL) & BIT_MASK_PS_TIMER_C_TSF_SEL)
#define BIT_SET_PS_TIMER_C_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_C_TSF_SEL(x) | BIT_PS_TIMER_C_TSF_SEL(v))
#define BIT_PS_TIMER_B_EN BIT(15)
#define BIT_SHIFT_PS_TIMER_B_TSF_SEL 8
#define BIT_MASK_PS_TIMER_B_TSF_SEL 0x7
#define BIT_PS_TIMER_B_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_B_TSF_SEL) << BIT_SHIFT_PS_TIMER_B_TSF_SEL)
#define BITS_PS_TIMER_B_TSF_SEL \
(BIT_MASK_PS_TIMER_B_TSF_SEL << BIT_SHIFT_PS_TIMER_B_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_B_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_B_TSF_SEL))
#define BIT_GET_PS_TIMER_B_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_TSF_SEL) & BIT_MASK_PS_TIMER_B_TSF_SEL)
#define BIT_SET_PS_TIMER_B_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_B_TSF_SEL(x) | BIT_PS_TIMER_B_TSF_SEL(v))
#define BIT_PS_TIMER_A_EN BIT(7)
#define BIT_SHIFT_PS_TIMER_A_TSF_SEL 0
#define BIT_MASK_PS_TIMER_A_TSF_SEL 0x7
#define BIT_PS_TIMER_A_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_A_TSF_SEL) << BIT_SHIFT_PS_TIMER_A_TSF_SEL)
#define BITS_PS_TIMER_A_TSF_SEL \
(BIT_MASK_PS_TIMER_A_TSF_SEL << BIT_SHIFT_PS_TIMER_A_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_A_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_A_TSF_SEL))
#define BIT_GET_PS_TIMER_A_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_TSF_SEL) & BIT_MASK_PS_TIMER_A_TSF_SEL)
#define BIT_SET_PS_TIMER_A_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_A_TSF_SEL(x) | BIT_PS_TIMER_A_TSF_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_SPACE_CFG (Offset 0x1510) */
#define BIT_SHIFT_BCN_SPACE 0
#define BIT_MASK_BCN_SPACE 0xffff
#define BIT_BCN_SPACE(x) (((x) & BIT_MASK_BCN_SPACE) << BIT_SHIFT_BCN_SPACE)
#define BITS_BCN_SPACE (BIT_MASK_BCN_SPACE << BIT_SHIFT_BCN_SPACE)
#define BIT_CLEAR_BCN_SPACE(x) ((x) & (~BITS_BCN_SPACE))
#define BIT_GET_BCN_SPACE(x) (((x) >> BIT_SHIFT_BCN_SPACE) & BIT_MASK_BCN_SPACE)
#define BIT_SET_BCN_SPACE(x, v) (BIT_CLEAR_BCN_SPACE(x) | BIT_BCN_SPACE(v))
/* 2 REG_EARLY_INT_ADJUST_CFG (Offset 0x1512) */
#define BIT_SHIFT_EARLY_INT_ADJUST 0
#define BIT_MASK_EARLY_INT_ADJUST 0xffff
#define BIT_EARLY_INT_ADJUST(x) \
(((x) & BIT_MASK_EARLY_INT_ADJUST) << BIT_SHIFT_EARLY_INT_ADJUST)
#define BITS_EARLY_INT_ADJUST \
(BIT_MASK_EARLY_INT_ADJUST << BIT_SHIFT_EARLY_INT_ADJUST)
#define BIT_CLEAR_EARLY_INT_ADJUST(x) ((x) & (~BITS_EARLY_INT_ADJUST))
#define BIT_GET_EARLY_INT_ADJUST(x) \
(((x) >> BIT_SHIFT_EARLY_INT_ADJUST) & BIT_MASK_EARLY_INT_ADJUST)
#define BIT_SET_EARLY_INT_ADJUST(x, v) \
(BIT_CLEAR_EARLY_INT_ADJUST(x) | BIT_EARLY_INT_ADJUST(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CPUMGQ_TX_TIMER_EARLY (Offset 0x1514) */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY 0
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY)
#define BITS_CPUMGQ_TX_TIMER_EARLY \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY << BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY(x) ((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY(x) | BIT_CPUMGQ_TX_TIMER_EARLY(v))
/* 2 REG_PS_TIMER_A_EARLY (Offset 0x1515) */
#define BIT_SHIFT_PS_TIMER_A_EARLY 0
#define BIT_MASK_PS_TIMER_A_EARLY 0xff
#define BIT_PS_TIMER_A_EARLY(x) \
(((x) & BIT_MASK_PS_TIMER_A_EARLY) << BIT_SHIFT_PS_TIMER_A_EARLY)
#define BITS_PS_TIMER_A_EARLY \
(BIT_MASK_PS_TIMER_A_EARLY << BIT_SHIFT_PS_TIMER_A_EARLY)
#define BIT_CLEAR_PS_TIMER_A_EARLY(x) ((x) & (~BITS_PS_TIMER_A_EARLY))
#define BIT_GET_PS_TIMER_A_EARLY(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_EARLY) & BIT_MASK_PS_TIMER_A_EARLY)
#define BIT_SET_PS_TIMER_A_EARLY(x, v) \
(BIT_CLEAR_PS_TIMER_A_EARLY(x) | BIT_PS_TIMER_A_EARLY(v))
/* 2 REG_PS_TIMER_B_EARLY (Offset 0x1516) */
#define BIT_SHIFT_PS_TIMER_B_EARLY 0
#define BIT_MASK_PS_TIMER_B_EARLY 0xff
#define BIT_PS_TIMER_B_EARLY(x) \
(((x) & BIT_MASK_PS_TIMER_B_EARLY) << BIT_SHIFT_PS_TIMER_B_EARLY)
#define BITS_PS_TIMER_B_EARLY \
(BIT_MASK_PS_TIMER_B_EARLY << BIT_SHIFT_PS_TIMER_B_EARLY)
#define BIT_CLEAR_PS_TIMER_B_EARLY(x) ((x) & (~BITS_PS_TIMER_B_EARLY))
#define BIT_GET_PS_TIMER_B_EARLY(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_EARLY) & BIT_MASK_PS_TIMER_B_EARLY)
#define BIT_SET_PS_TIMER_B_EARLY(x, v) \
(BIT_CLEAR_PS_TIMER_B_EARLY(x) | BIT_PS_TIMER_B_EARLY(v))
/* 2 REG_PS_TIMER_C_EARLY (Offset 0x1517) */
#define BIT_SHIFT_PS_TIMER_C_EARLY 0
#define BIT_MASK_PS_TIMER_C_EARLY 0xff
#define BIT_PS_TIMER_C_EARLY(x) \
(((x) & BIT_MASK_PS_TIMER_C_EARLY) << BIT_SHIFT_PS_TIMER_C_EARLY)
#define BITS_PS_TIMER_C_EARLY \
(BIT_MASK_PS_TIMER_C_EARLY << BIT_SHIFT_PS_TIMER_C_EARLY)
#define BIT_CLEAR_PS_TIMER_C_EARLY(x) ((x) & (~BITS_PS_TIMER_C_EARLY))
#define BIT_GET_PS_TIMER_C_EARLY(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_EARLY) & BIT_MASK_PS_TIMER_C_EARLY)
#define BIT_SET_PS_TIMER_C_EARLY(x, v) \
(BIT_CLEAR_PS_TIMER_C_EARLY(x) | BIT_PS_TIMER_C_EARLY(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_CPUMGQ_PARAMETER (Offset 0x1518) */
#define BIT_STOP_CPUMGQ BIT(16)
#define BIT_SHIFT_CPUMGQ_PARAMETER 0
#define BIT_MASK_CPUMGQ_PARAMETER 0xffff
#define BIT_CPUMGQ_PARAMETER(x) \
(((x) & BIT_MASK_CPUMGQ_PARAMETER) << BIT_SHIFT_CPUMGQ_PARAMETER)
#define BITS_CPUMGQ_PARAMETER \
(BIT_MASK_CPUMGQ_PARAMETER << BIT_SHIFT_CPUMGQ_PARAMETER)
#define BIT_CLEAR_CPUMGQ_PARAMETER(x) ((x) & (~BITS_CPUMGQ_PARAMETER))
#define BIT_GET_CPUMGQ_PARAMETER(x) \
(((x) >> BIT_SHIFT_CPUMGQ_PARAMETER) & BIT_MASK_CPUMGQ_PARAMETER)
#define BIT_SET_CPUMGQ_PARAMETER(x, v) \
(BIT_CLEAR_CPUMGQ_PARAMETER(x) | BIT_CPUMGQ_PARAMETER(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SW_TBTT_TSF_INFO (Offset 0x151C) */
#define BIT_SHIFT_SW_TBTT_TSF_INFO 0
#define BIT_MASK_SW_TBTT_TSF_INFO 0xffffffffL
#define BIT_SW_TBTT_TSF_INFO(x) \
(((x) & BIT_MASK_SW_TBTT_TSF_INFO) << BIT_SHIFT_SW_TBTT_TSF_INFO)
#define BITS_SW_TBTT_TSF_INFO \
(BIT_MASK_SW_TBTT_TSF_INFO << BIT_SHIFT_SW_TBTT_TSF_INFO)
#define BIT_CLEAR_SW_TBTT_TSF_INFO(x) ((x) & (~BITS_SW_TBTT_TSF_INFO))
#define BIT_GET_SW_TBTT_TSF_INFO(x) \
(((x) >> BIT_SHIFT_SW_TBTT_TSF_INFO) & BIT_MASK_SW_TBTT_TSF_INFO)
#define BIT_SET_SW_TBTT_TSF_INFO(x, v) \
(BIT_CLEAR_SW_TBTT_TSF_INFO(x) | BIT_SW_TBTT_TSF_INFO(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TSF_SYN_CTRL0 (Offset 0x1520) */
#define BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0_V1 16
#define BIT_MASK_TSF_SYNC_INTERVAL_PORT0_V1 0xffff
#define BIT_TSF_SYNC_INTERVAL_PORT0_V1(x) \
(((x) & BIT_MASK_TSF_SYNC_INTERVAL_PORT0_V1) \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0_V1)
#define BITS_TSF_SYNC_INTERVAL_PORT0_V1 \
(BIT_MASK_TSF_SYNC_INTERVAL_PORT0_V1 \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0_V1)
#define BIT_CLEAR_TSF_SYNC_INTERVAL_PORT0_V1(x) \
((x) & (~BITS_TSF_SYNC_INTERVAL_PORT0_V1))
#define BIT_GET_TSF_SYNC_INTERVAL_PORT0_V1(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0_V1) & \
BIT_MASK_TSF_SYNC_INTERVAL_PORT0_V1)
#define BIT_SET_TSF_SYNC_INTERVAL_PORT0_V1(x, v) \
(BIT_CLEAR_TSF_SYNC_INTERVAL_PORT0_V1(x) | \
BIT_TSF_SYNC_INTERVAL_PORT0_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_SYNC_ADJ (Offset 0x1520) */
#define BIT_SHIFT_R_P0_TSFT_ADJ_VAL 16
#define BIT_MASK_R_P0_TSFT_ADJ_VAL 0xffff
#define BIT_R_P0_TSFT_ADJ_VAL(x) \
(((x) & BIT_MASK_R_P0_TSFT_ADJ_VAL) << BIT_SHIFT_R_P0_TSFT_ADJ_VAL)
#define BITS_R_P0_TSFT_ADJ_VAL \
(BIT_MASK_R_P0_TSFT_ADJ_VAL << BIT_SHIFT_R_P0_TSFT_ADJ_VAL)
#define BIT_CLEAR_R_P0_TSFT_ADJ_VAL(x) ((x) & (~BITS_R_P0_TSFT_ADJ_VAL))
#define BIT_GET_R_P0_TSFT_ADJ_VAL(x) \
(((x) >> BIT_SHIFT_R_P0_TSFT_ADJ_VAL) & BIT_MASK_R_P0_TSFT_ADJ_VAL)
#define BIT_SET_R_P0_TSFT_ADJ_VAL(x, v) \
(BIT_CLEAR_R_P0_TSFT_ADJ_VAL(x) | BIT_R_P0_TSFT_ADJ_VAL(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TSF_SYN_CTRL0 (Offset 0x1520) */
#define BIT_TSF_SYNC_SIGNAL_V1 BIT(8)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_SYNC_ADJ (Offset 0x1520) */
#define BIT_R_X_COMP_Y_OVER BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_CTRL0 (Offset 0x1520) */
#define BIT_TSF_SYNC_COMPARE_POLLING BIT(7)
#define BIT_TSF_SYNC_POLLING BIT(6)
#define BIT_SHIFT_TSF_SYNC_DUT 3
#define BIT_MASK_TSF_SYNC_DUT 0x7
#define BIT_TSF_SYNC_DUT(x) \
(((x) & BIT_MASK_TSF_SYNC_DUT) << BIT_SHIFT_TSF_SYNC_DUT)
#define BITS_TSF_SYNC_DUT (BIT_MASK_TSF_SYNC_DUT << BIT_SHIFT_TSF_SYNC_DUT)
#define BIT_CLEAR_TSF_SYNC_DUT(x) ((x) & (~BITS_TSF_SYNC_DUT))
#define BIT_GET_TSF_SYNC_DUT(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_DUT) & BIT_MASK_TSF_SYNC_DUT)
#define BIT_SET_TSF_SYNC_DUT(x, v) \
(BIT_CLEAR_TSF_SYNC_DUT(x) | BIT_TSF_SYNC_DUT(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_SYNC_ADJ (Offset 0x1520) */
#define BIT_SHIFT_R_X_SYNC_SEL 3
#define BIT_MASK_R_X_SYNC_SEL 0x7
#define BIT_R_X_SYNC_SEL(x) \
(((x) & BIT_MASK_R_X_SYNC_SEL) << BIT_SHIFT_R_X_SYNC_SEL)
#define BITS_R_X_SYNC_SEL (BIT_MASK_R_X_SYNC_SEL << BIT_SHIFT_R_X_SYNC_SEL)
#define BIT_CLEAR_R_X_SYNC_SEL(x) ((x) & (~BITS_R_X_SYNC_SEL))
#define BIT_GET_R_X_SYNC_SEL(x) \
(((x) >> BIT_SHIFT_R_X_SYNC_SEL) & BIT_MASK_R_X_SYNC_SEL)
#define BIT_SET_R_X_SYNC_SEL(x, v) \
(BIT_CLEAR_R_X_SYNC_SEL(x) | BIT_R_X_SYNC_SEL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_CTRL0 (Offset 0x1520) */
#define BIT_SHIFT_TSF_SYNC_SOURCE 0
#define BIT_MASK_TSF_SYNC_SOURCE 0x7
#define BIT_TSF_SYNC_SOURCE(x) \
(((x) & BIT_MASK_TSF_SYNC_SOURCE) << BIT_SHIFT_TSF_SYNC_SOURCE)
#define BITS_TSF_SYNC_SOURCE \
(BIT_MASK_TSF_SYNC_SOURCE << BIT_SHIFT_TSF_SYNC_SOURCE)
#define BIT_CLEAR_TSF_SYNC_SOURCE(x) ((x) & (~BITS_TSF_SYNC_SOURCE))
#define BIT_GET_TSF_SYNC_SOURCE(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_SOURCE) & BIT_MASK_TSF_SYNC_SOURCE)
#define BIT_SET_TSF_SYNC_SOURCE(x, v) \
(BIT_CLEAR_TSF_SYNC_SOURCE(x) | BIT_TSF_SYNC_SOURCE(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_SYNC_ADJ (Offset 0x1520) */
#define BIT_SHIFT_R_SYNC_Y_SEL 0
#define BIT_MASK_R_SYNC_Y_SEL 0x7
#define BIT_R_SYNC_Y_SEL(x) \
(((x) & BIT_MASK_R_SYNC_Y_SEL) << BIT_SHIFT_R_SYNC_Y_SEL)
#define BITS_R_SYNC_Y_SEL (BIT_MASK_R_SYNC_Y_SEL << BIT_SHIFT_R_SYNC_Y_SEL)
#define BIT_CLEAR_R_SYNC_Y_SEL(x) ((x) & (~BITS_R_SYNC_Y_SEL))
#define BIT_GET_R_SYNC_Y_SEL(x) \
(((x) >> BIT_SHIFT_R_SYNC_Y_SEL) & BIT_MASK_R_SYNC_Y_SEL)
#define BIT_SET_R_SYNC_Y_SEL(x, v) \
(BIT_CLEAR_R_SYNC_Y_SEL(x) | BIT_R_SYNC_Y_SEL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TSFTR_LOW (Offset 0x1520) */
#define BIT_SHIFT_TSF_TIMER_LOW 0
#define BIT_MASK_TSF_TIMER_LOW 0xffffffffL
#define BIT_TSF_TIMER_LOW(x) \
(((x) & BIT_MASK_TSF_TIMER_LOW) << BIT_SHIFT_TSF_TIMER_LOW)
#define BITS_TSF_TIMER_LOW (BIT_MASK_TSF_TIMER_LOW << BIT_SHIFT_TSF_TIMER_LOW)
#define BIT_CLEAR_TSF_TIMER_LOW(x) ((x) & (~BITS_TSF_TIMER_LOW))
#define BIT_GET_TSF_TIMER_LOW(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_LOW) & BIT_MASK_TSF_TIMER_LOW)
#define BIT_SET_TSF_TIMER_LOW(x, v) \
(BIT_CLEAR_TSF_TIMER_LOW(x) | BIT_TSF_TIMER_LOW(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_OFFSET0 (Offset 0x1522) */
#define BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0 0
#define BIT_MASK_TSF_SYNC_INTERVAL_PORT0 0xffff
#define BIT_TSF_SYNC_INTERVAL_PORT0(x) \
(((x) & BIT_MASK_TSF_SYNC_INTERVAL_PORT0) \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0)
#define BITS_TSF_SYNC_INTERVAL_PORT0 \
(BIT_MASK_TSF_SYNC_INTERVAL_PORT0 << BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0)
#define BIT_CLEAR_TSF_SYNC_INTERVAL_PORT0(x) \
((x) & (~BITS_TSF_SYNC_INTERVAL_PORT0))
#define BIT_GET_TSF_SYNC_INTERVAL_PORT0(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_INTERVAL_PORT0) & \
BIT_MASK_TSF_SYNC_INTERVAL_PORT0)
#define BIT_SET_TSF_SYNC_INTERVAL_PORT0(x, v) \
(BIT_CLEAR_TSF_SYNC_INTERVAL_PORT0(x) | BIT_TSF_SYNC_INTERVAL_PORT0(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_OFFSET1 (Offset 0x1524) */
#define BIT_SHIFT_TSF_SYNC_INTERVAL_CLI1 16
#define BIT_MASK_TSF_SYNC_INTERVAL_CLI1 0xffff
#define BIT_TSF_SYNC_INTERVAL_CLI1(x) \
(((x) & BIT_MASK_TSF_SYNC_INTERVAL_CLI1) \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_CLI1)
#define BITS_TSF_SYNC_INTERVAL_CLI1 \
(BIT_MASK_TSF_SYNC_INTERVAL_CLI1 << BIT_SHIFT_TSF_SYNC_INTERVAL_CLI1)
#define BIT_CLEAR_TSF_SYNC_INTERVAL_CLI1(x) \
((x) & (~BITS_TSF_SYNC_INTERVAL_CLI1))
#define BIT_GET_TSF_SYNC_INTERVAL_CLI1(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_INTERVAL_CLI1) & \
BIT_MASK_TSF_SYNC_INTERVAL_CLI1)
#define BIT_SET_TSF_SYNC_INTERVAL_CLI1(x, v) \
(BIT_CLEAR_TSF_SYNC_INTERVAL_CLI1(x) | BIT_TSF_SYNC_INTERVAL_CLI1(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_ADJ_VLAUE (Offset 0x1524) */
#define BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL 16
#define BIT_MASK_R_CLI1_TSFT_ADJ_VAL 0xffff
#define BIT_R_CLI1_TSFT_ADJ_VAL(x) \
(((x) & BIT_MASK_R_CLI1_TSFT_ADJ_VAL) << BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL)
#define BITS_R_CLI1_TSFT_ADJ_VAL \
(BIT_MASK_R_CLI1_TSFT_ADJ_VAL << BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL)
#define BIT_CLEAR_R_CLI1_TSFT_ADJ_VAL(x) ((x) & (~BITS_R_CLI1_TSFT_ADJ_VAL))
#define BIT_GET_R_CLI1_TSFT_ADJ_VAL(x) \
(((x) >> BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL) & BIT_MASK_R_CLI1_TSFT_ADJ_VAL)
#define BIT_SET_R_CLI1_TSFT_ADJ_VAL(x, v) \
(BIT_CLEAR_R_CLI1_TSFT_ADJ_VAL(x) | BIT_R_CLI1_TSFT_ADJ_VAL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_OFFSET1 (Offset 0x1524) */
#define BIT_SHIFT_TSF_SYNC_INTERVAL_CLI0 0
#define BIT_MASK_TSF_SYNC_INTERVAL_CLI0 0xffff
#define BIT_TSF_SYNC_INTERVAL_CLI0(x) \
(((x) & BIT_MASK_TSF_SYNC_INTERVAL_CLI0) \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_CLI0)
#define BITS_TSF_SYNC_INTERVAL_CLI0 \
(BIT_MASK_TSF_SYNC_INTERVAL_CLI0 << BIT_SHIFT_TSF_SYNC_INTERVAL_CLI0)
#define BIT_CLEAR_TSF_SYNC_INTERVAL_CLI0(x) \
((x) & (~BITS_TSF_SYNC_INTERVAL_CLI0))
#define BIT_GET_TSF_SYNC_INTERVAL_CLI0(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_INTERVAL_CLI0) & \
BIT_MASK_TSF_SYNC_INTERVAL_CLI0)
#define BIT_SET_TSF_SYNC_INTERVAL_CLI0(x, v) \
(BIT_CLEAR_TSF_SYNC_INTERVAL_CLI0(x) | BIT_TSF_SYNC_INTERVAL_CLI0(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_ADJ_VLAUE (Offset 0x1524) */
#define BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL 0
#define BIT_MASK_R_CLI0_TSFT_ADJ_VAL 0xffff
#define BIT_R_CLI0_TSFT_ADJ_VAL(x) \
(((x) & BIT_MASK_R_CLI0_TSFT_ADJ_VAL) << BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL)
#define BITS_R_CLI0_TSFT_ADJ_VAL \
(BIT_MASK_R_CLI0_TSFT_ADJ_VAL << BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL)
#define BIT_CLEAR_R_CLI0_TSFT_ADJ_VAL(x) ((x) & (~BITS_R_CLI0_TSFT_ADJ_VAL))
#define BIT_GET_R_CLI0_TSFT_ADJ_VAL(x) \
(((x) >> BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL) & BIT_MASK_R_CLI0_TSFT_ADJ_VAL)
#define BIT_SET_R_CLI0_TSFT_ADJ_VAL(x, v) \
(BIT_CLEAR_R_CLI0_TSFT_ADJ_VAL(x) | BIT_R_CLI0_TSFT_ADJ_VAL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TSFTR_HIGH (Offset 0x1524) */
#define BIT_SHIFT_TSF_TIMER_HIGH 0
#define BIT_MASK_TSF_TIMER_HIGH 0xffffffffL
#define BIT_TSF_TIMER_HIGH(x) \
(((x) & BIT_MASK_TSF_TIMER_HIGH) << BIT_SHIFT_TSF_TIMER_HIGH)
#define BITS_TSF_TIMER_HIGH \
(BIT_MASK_TSF_TIMER_HIGH << BIT_SHIFT_TSF_TIMER_HIGH)
#define BIT_CLEAR_TSF_TIMER_HIGH(x) ((x) & (~BITS_TSF_TIMER_HIGH))
#define BIT_GET_TSF_TIMER_HIGH(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_HIGH) & BIT_MASK_TSF_TIMER_HIGH)
#define BIT_SET_TSF_TIMER_HIGH(x, v) \
(BIT_CLEAR_TSF_TIMER_HIGH(x) | BIT_TSF_TIMER_HIGH(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_OFFSET2 (Offset 0x1528) */
#define BIT_SHIFT_TSF_SYNC_INTERVAL_CLI3 16
#define BIT_MASK_TSF_SYNC_INTERVAL_CLI3 0xffff
#define BIT_TSF_SYNC_INTERVAL_CLI3(x) \
(((x) & BIT_MASK_TSF_SYNC_INTERVAL_CLI3) \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_CLI3)
#define BITS_TSF_SYNC_INTERVAL_CLI3 \
(BIT_MASK_TSF_SYNC_INTERVAL_CLI3 << BIT_SHIFT_TSF_SYNC_INTERVAL_CLI3)
#define BIT_CLEAR_TSF_SYNC_INTERVAL_CLI3(x) \
((x) & (~BITS_TSF_SYNC_INTERVAL_CLI3))
#define BIT_GET_TSF_SYNC_INTERVAL_CLI3(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_INTERVAL_CLI3) & \
BIT_MASK_TSF_SYNC_INTERVAL_CLI3)
#define BIT_SET_TSF_SYNC_INTERVAL_CLI3(x, v) \
(BIT_CLEAR_TSF_SYNC_INTERVAL_CLI3(x) | BIT_TSF_SYNC_INTERVAL_CLI3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_ADJ_VLAUE_2 (Offset 0x1528) */
#define BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL 16
#define BIT_MASK_R_CLI3_TSFT_ADJ_VAL 0xffff
#define BIT_R_CLI3_TSFT_ADJ_VAL(x) \
(((x) & BIT_MASK_R_CLI3_TSFT_ADJ_VAL) << BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL)
#define BITS_R_CLI3_TSFT_ADJ_VAL \
(BIT_MASK_R_CLI3_TSFT_ADJ_VAL << BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL)
#define BIT_CLEAR_R_CLI3_TSFT_ADJ_VAL(x) ((x) & (~BITS_R_CLI3_TSFT_ADJ_VAL))
#define BIT_GET_R_CLI3_TSFT_ADJ_VAL(x) \
(((x) >> BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL) & BIT_MASK_R_CLI3_TSFT_ADJ_VAL)
#define BIT_SET_R_CLI3_TSFT_ADJ_VAL(x, v) \
(BIT_CLEAR_R_CLI3_TSFT_ADJ_VAL(x) | BIT_R_CLI3_TSFT_ADJ_VAL(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_OFFSET2 (Offset 0x1528) */
#define BIT_WMAC_20MHZBW BIT(2)
#define BIT_SHIFT_TSF_SYNC_INTERVAL_CLI2 0
#define BIT_MASK_TSF_SYNC_INTERVAL_CLI2 0xffff
#define BIT_TSF_SYNC_INTERVAL_CLI2(x) \
(((x) & BIT_MASK_TSF_SYNC_INTERVAL_CLI2) \
<< BIT_SHIFT_TSF_SYNC_INTERVAL_CLI2)
#define BITS_TSF_SYNC_INTERVAL_CLI2 \
(BIT_MASK_TSF_SYNC_INTERVAL_CLI2 << BIT_SHIFT_TSF_SYNC_INTERVAL_CLI2)
#define BIT_CLEAR_TSF_SYNC_INTERVAL_CLI2(x) \
((x) & (~BITS_TSF_SYNC_INTERVAL_CLI2))
#define BIT_GET_TSF_SYNC_INTERVAL_CLI2(x) \
(((x) >> BIT_SHIFT_TSF_SYNC_INTERVAL_CLI2) & \
BIT_MASK_TSF_SYNC_INTERVAL_CLI2)
#define BIT_SET_TSF_SYNC_INTERVAL_CLI2(x, v) \
(BIT_CLEAR_TSF_SYNC_INTERVAL_CLI2(x) | BIT_TSF_SYNC_INTERVAL_CLI2(v))
#define BIT_WMAC_M11J BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TSF_ADJ_VLAUE_2 (Offset 0x1528) */
#define BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL 0
#define BIT_MASK_R_CLI2_TSFT_ADJ_VAL 0xffff
#define BIT_R_CLI2_TSFT_ADJ_VAL(x) \
(((x) & BIT_MASK_R_CLI2_TSFT_ADJ_VAL) << BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL)
#define BITS_R_CLI2_TSFT_ADJ_VAL \
(BIT_MASK_R_CLI2_TSFT_ADJ_VAL << BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL)
#define BIT_CLEAR_R_CLI2_TSFT_ADJ_VAL(x) ((x) & (~BITS_R_CLI2_TSFT_ADJ_VAL))
#define BIT_GET_R_CLI2_TSFT_ADJ_VAL(x) \
(((x) >> BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL) & BIT_MASK_R_CLI2_TSFT_ADJ_VAL)
#define BIT_SET_R_CLI2_TSFT_ADJ_VAL(x, v) \
(BIT_CLEAR_R_CLI2_TSFT_ADJ_VAL(x) | BIT_R_CLI2_TSFT_ADJ_VAL(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_BCN_ERR_CNT_MAC (Offset 0x1528) */
#define BIT_SHIFT_BCN_ERR_CNT_MAC 0
#define BIT_MASK_BCN_ERR_CNT_MAC 0xff
#define BIT_BCN_ERR_CNT_MAC(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_MAC) << BIT_SHIFT_BCN_ERR_CNT_MAC)
#define BITS_BCN_ERR_CNT_MAC \
(BIT_MASK_BCN_ERR_CNT_MAC << BIT_SHIFT_BCN_ERR_CNT_MAC)
#define BIT_CLEAR_BCN_ERR_CNT_MAC(x) ((x) & (~BITS_BCN_ERR_CNT_MAC))
#define BIT_GET_BCN_ERR_CNT_MAC(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_MAC) & BIT_MASK_BCN_ERR_CNT_MAC)
#define BIT_SET_BCN_ERR_CNT_MAC(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_MAC(x) | BIT_BCN_ERR_CNT_MAC(v))
/* 2 REG_BCN_ERR_CNT_EDCCA (Offset 0x1529) */
#define BIT_SHIFT_BCN_ERR_CNT_EDCCA 0
#define BIT_MASK_BCN_ERR_CNT_EDCCA 0xff
#define BIT_BCN_ERR_CNT_EDCCA(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_EDCCA) << BIT_SHIFT_BCN_ERR_CNT_EDCCA)
#define BITS_BCN_ERR_CNT_EDCCA \
(BIT_MASK_BCN_ERR_CNT_EDCCA << BIT_SHIFT_BCN_ERR_CNT_EDCCA)
#define BIT_CLEAR_BCN_ERR_CNT_EDCCA(x) ((x) & (~BITS_BCN_ERR_CNT_EDCCA))
#define BIT_GET_BCN_ERR_CNT_EDCCA(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_EDCCA) & BIT_MASK_BCN_ERR_CNT_EDCCA)
#define BIT_SET_BCN_ERR_CNT_EDCCA(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_EDCCA(x) | BIT_BCN_ERR_CNT_EDCCA(v))
/* 2 REG_BCN_ERR_CNT_CCA (Offset 0x152A) */
#define BIT_SHIFT_BCN_ERR_CNT_CCA 0
#define BIT_MASK_BCN_ERR_CNT_CCA 0xff
#define BIT_BCN_ERR_CNT_CCA(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_CCA) << BIT_SHIFT_BCN_ERR_CNT_CCA)
#define BITS_BCN_ERR_CNT_CCA \
(BIT_MASK_BCN_ERR_CNT_CCA << BIT_SHIFT_BCN_ERR_CNT_CCA)
#define BIT_CLEAR_BCN_ERR_CNT_CCA(x) ((x) & (~BITS_BCN_ERR_CNT_CCA))
#define BIT_GET_BCN_ERR_CNT_CCA(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_CCA) & BIT_MASK_BCN_ERR_CNT_CCA)
#define BIT_SET_BCN_ERR_CNT_CCA(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_CCA(x) | BIT_BCN_ERR_CNT_CCA(v))
/* 2 REG_BCN_ERR_CNT_INVALID (Offset 0x152B) */
#define BIT_SHIFT_BCN_ERR_CNT_INVALID 0
#define BIT_MASK_BCN_ERR_CNT_INVALID 0xff
#define BIT_BCN_ERR_CNT_INVALID(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_INVALID) << BIT_SHIFT_BCN_ERR_CNT_INVALID)
#define BITS_BCN_ERR_CNT_INVALID \
(BIT_MASK_BCN_ERR_CNT_INVALID << BIT_SHIFT_BCN_ERR_CNT_INVALID)
#define BIT_CLEAR_BCN_ERR_CNT_INVALID(x) ((x) & (~BITS_BCN_ERR_CNT_INVALID))
#define BIT_GET_BCN_ERR_CNT_INVALID(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_INVALID) & BIT_MASK_BCN_ERR_CNT_INVALID)
#define BIT_SET_BCN_ERR_CNT_INVALID(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_INVALID(x) | BIT_BCN_ERR_CNT_INVALID(v))
/* 2 REG_BCN_ERR_CNT_OTHERS (Offset 0x152C) */
#define BIT_SHIFT_BCN_ERR_CNT_OTHERS 0
#define BIT_MASK_BCN_ERR_CNT_OTHERS 0xff
#define BIT_BCN_ERR_CNT_OTHERS(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_OTHERS) << BIT_SHIFT_BCN_ERR_CNT_OTHERS)
#define BITS_BCN_ERR_CNT_OTHERS \
(BIT_MASK_BCN_ERR_CNT_OTHERS << BIT_SHIFT_BCN_ERR_CNT_OTHERS)
#define BIT_CLEAR_BCN_ERR_CNT_OTHERS(x) ((x) & (~BITS_BCN_ERR_CNT_OTHERS))
#define BIT_GET_BCN_ERR_CNT_OTHERS(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_OTHERS) & BIT_MASK_BCN_ERR_CNT_OTHERS)
#define BIT_SET_BCN_ERR_CNT_OTHERS(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_OTHERS(x) | BIT_BCN_ERR_CNT_OTHERS(v))
/* 2 REG_RX_BCN_TIMER (Offset 0x152D) */
#define BIT_SHIFT_RX_BCN_TIMER 0
#define BIT_MASK_RX_BCN_TIMER 0xffff
#define BIT_RX_BCN_TIMER(x) \
(((x) & BIT_MASK_RX_BCN_TIMER) << BIT_SHIFT_RX_BCN_TIMER)
#define BITS_RX_BCN_TIMER (BIT_MASK_RX_BCN_TIMER << BIT_SHIFT_RX_BCN_TIMER)
#define BIT_CLEAR_RX_BCN_TIMER(x) ((x) & (~BITS_RX_BCN_TIMER))
#define BIT_GET_RX_BCN_TIMER(x) \
(((x) >> BIT_SHIFT_RX_BCN_TIMER) & BIT_MASK_RX_BCN_TIMER)
#define BIT_SET_RX_BCN_TIMER(x, v) \
(BIT_CLEAR_RX_BCN_TIMER(x) | BIT_RX_BCN_TIMER(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TSF_SYN_COMPARE_VALUE_L (Offset 0x1530) */
#define BIT_SHIFT_TSF_SYN_COMPARE_VALUE_L 0
#define BIT_MASK_TSF_SYN_COMPARE_VALUE_L 0xffffffffL
#define BIT_TSF_SYN_COMPARE_VALUE_L(x) \
(((x) & BIT_MASK_TSF_SYN_COMPARE_VALUE_L) \
<< BIT_SHIFT_TSF_SYN_COMPARE_VALUE_L)
#define BITS_TSF_SYN_COMPARE_VALUE_L \
(BIT_MASK_TSF_SYN_COMPARE_VALUE_L << BIT_SHIFT_TSF_SYN_COMPARE_VALUE_L)
#define BIT_CLEAR_TSF_SYN_COMPARE_VALUE_L(x) \
((x) & (~BITS_TSF_SYN_COMPARE_VALUE_L))
#define BIT_GET_TSF_SYN_COMPARE_VALUE_L(x) \
(((x) >> BIT_SHIFT_TSF_SYN_COMPARE_VALUE_L) & \
BIT_MASK_TSF_SYN_COMPARE_VALUE_L)
#define BIT_SET_TSF_SYN_COMPARE_VALUE_L(x, v) \
(BIT_CLEAR_TSF_SYN_COMPARE_VALUE_L(x) | BIT_TSF_SYN_COMPARE_VALUE_L(v))
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_TSF_SYN_COMPARE_VALUE (Offset 0x1530) */
#define BIT_SHIFT_TSF_SYN_COMPARE_VALUE 0
#define BIT_MASK_TSF_SYN_COMPARE_VALUE 0xffffffffffffffffL
#define BIT_TSF_SYN_COMPARE_VALUE(x) \
(((x) & BIT_MASK_TSF_SYN_COMPARE_VALUE) \
<< BIT_SHIFT_TSF_SYN_COMPARE_VALUE)
#define BITS_TSF_SYN_COMPARE_VALUE \
(BIT_MASK_TSF_SYN_COMPARE_VALUE << BIT_SHIFT_TSF_SYN_COMPARE_VALUE)
#define BIT_CLEAR_TSF_SYN_COMPARE_VALUE(x) ((x) & (~BITS_TSF_SYN_COMPARE_VALUE))
#define BIT_GET_TSF_SYN_COMPARE_VALUE(x) \
(((x) >> BIT_SHIFT_TSF_SYN_COMPARE_VALUE) & \
BIT_MASK_TSF_SYN_COMPARE_VALUE)
#define BIT_SET_TSF_SYN_COMPARE_VALUE(x, v) \
(BIT_CLEAR_TSF_SYN_COMPARE_VALUE(x) | BIT_TSF_SYN_COMPARE_VALUE(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_TSF_SYN_COMPARE_VALUE_H (Offset 0x1534) */
#define BIT_SHIFT_TSF_SYN_COMPARE_VALUE_H 0
#define BIT_MASK_TSF_SYN_COMPARE_VALUE_H 0xffffffffL
#define BIT_TSF_SYN_COMPARE_VALUE_H(x) \
(((x) & BIT_MASK_TSF_SYN_COMPARE_VALUE_H) \
<< BIT_SHIFT_TSF_SYN_COMPARE_VALUE_H)
#define BITS_TSF_SYN_COMPARE_VALUE_H \
(BIT_MASK_TSF_SYN_COMPARE_VALUE_H << BIT_SHIFT_TSF_SYN_COMPARE_VALUE_H)
#define BIT_CLEAR_TSF_SYN_COMPARE_VALUE_H(x) \
((x) & (~BITS_TSF_SYN_COMPARE_VALUE_H))
#define BIT_GET_TSF_SYN_COMPARE_VALUE_H(x) \
(((x) >> BIT_SHIFT_TSF_SYN_COMPARE_VALUE_H) & \
BIT_MASK_TSF_SYN_COMPARE_VALUE_H)
#define BIT_SET_TSF_SYN_COMPARE_VALUE_H(x, v) \
(BIT_CLEAR_TSF_SYN_COMPARE_VALUE_H(x) | BIT_TSF_SYN_COMPARE_VALUE_H(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_SUB_BCN_SPACE (Offset 0x1534) */
#define BIT_SHIFT_SUB_BCN_SPACE_V2 0
#define BIT_MASK_SUB_BCN_SPACE_V2 0xff
#define BIT_SUB_BCN_SPACE_V2(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE_V2) << BIT_SHIFT_SUB_BCN_SPACE_V2)
#define BITS_SUB_BCN_SPACE_V2 \
(BIT_MASK_SUB_BCN_SPACE_V2 << BIT_SHIFT_SUB_BCN_SPACE_V2)
#define BIT_CLEAR_SUB_BCN_SPACE_V2(x) ((x) & (~BITS_SUB_BCN_SPACE_V2))
#define BIT_GET_SUB_BCN_SPACE_V2(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE_V2) & BIT_MASK_SUB_BCN_SPACE_V2)
#define BIT_SET_SUB_BCN_SPACE_V2(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE_V2(x) | BIT_SUB_BCN_SPACE_V2(v))
/* 2 REG_MBID_NUM_V1 (Offset 0x1535) */
#define BIT_SHIFT_BCN_ERR_PORT_SEL 4
#define BIT_MASK_BCN_ERR_PORT_SEL 0xf
#define BIT_BCN_ERR_PORT_SEL(x) \
(((x) & BIT_MASK_BCN_ERR_PORT_SEL) << BIT_SHIFT_BCN_ERR_PORT_SEL)
#define BITS_BCN_ERR_PORT_SEL \
(BIT_MASK_BCN_ERR_PORT_SEL << BIT_SHIFT_BCN_ERR_PORT_SEL)
#define BIT_CLEAR_BCN_ERR_PORT_SEL(x) ((x) & (~BITS_BCN_ERR_PORT_SEL))
#define BIT_GET_BCN_ERR_PORT_SEL(x) \
(((x) >> BIT_SHIFT_BCN_ERR_PORT_SEL) & BIT_MASK_BCN_ERR_PORT_SEL)
#define BIT_SET_BCN_ERR_PORT_SEL(x, v) \
(BIT_CLEAR_BCN_ERR_PORT_SEL(x) | BIT_BCN_ERR_PORT_SEL(v))
#define BIT_SHIFT_MBID_BCN_NUM_V1 0
#define BIT_MASK_MBID_BCN_NUM_V1 0xf
#define BIT_MBID_BCN_NUM_V1(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_V1) << BIT_SHIFT_MBID_BCN_NUM_V1)
#define BITS_MBID_BCN_NUM_V1 \
(BIT_MASK_MBID_BCN_NUM_V1 << BIT_SHIFT_MBID_BCN_NUM_V1)
#define BIT_CLEAR_MBID_BCN_NUM_V1(x) ((x) & (~BITS_MBID_BCN_NUM_V1))
#define BIT_GET_MBID_BCN_NUM_V1(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_V1) & BIT_MASK_MBID_BCN_NUM_V1)
#define BIT_SET_MBID_BCN_NUM_V1(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_V1(x) | BIT_MBID_BCN_NUM_V1(v))
/* 2 REG_MBSSID_CTRL_V1 (Offset 0x1536) */
#define BIT_MBID_BCNQ15_EN BIT(15)
#define BIT_MBID_BCNQ14_EN BIT(14)
#define BIT_MBID_BCNQ13_EN BIT(13)
#define BIT_MBID_BCNQ12_EN BIT(12)
#define BIT_MBID_BCNQ11_EN BIT(11)
#define BIT_MBID_BCNQ10_EN BIT(10)
#define BIT_MBID_BCNQ9_EN BIT(9)
#define BIT_MBID_BCNQ8_EN BIT(8)
/* 2 REG_BW_CFG (Offset 0x1539) */
#define BIT_SLEEP_32K_EN BIT(3)
#define BIT_DIS_MARK_TSF_US_V1 BIT(2)
/* 2 REG_ATIMWND_CFG (Offset 0x153A) */
#define BIT_SHIFT_ATIMWND_V1 0
#define BIT_MASK_ATIMWND_V1 0xff
#define BIT_ATIMWND_V1(x) (((x) & BIT_MASK_ATIMWND_V1) << BIT_SHIFT_ATIMWND_V1)
#define BITS_ATIMWND_V1 (BIT_MASK_ATIMWND_V1 << BIT_SHIFT_ATIMWND_V1)
#define BIT_CLEAR_ATIMWND_V1(x) ((x) & (~BITS_ATIMWND_V1))
#define BIT_GET_ATIMWND_V1(x) \
(((x) >> BIT_SHIFT_ATIMWND_V1) & BIT_MASK_ATIMWND_V1)
#define BIT_SET_ATIMWND_V1(x, v) (BIT_CLEAR_ATIMWND_V1(x) | BIT_ATIMWND_V1(v))
/* 2 REG_DTIM_COUNTER_CFG (Offset 0x153B) */
#define BIT_SHIFT_DTIM_COUNT 0
#define BIT_MASK_DTIM_COUNT 0xff
#define BIT_DTIM_COUNT(x) (((x) & BIT_MASK_DTIM_COUNT) << BIT_SHIFT_DTIM_COUNT)
#define BITS_DTIM_COUNT (BIT_MASK_DTIM_COUNT << BIT_SHIFT_DTIM_COUNT)
#define BIT_CLEAR_DTIM_COUNT(x) ((x) & (~BITS_DTIM_COUNT))
#define BIT_GET_DTIM_COUNT(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT) & BIT_MASK_DTIM_COUNT)
#define BIT_SET_DTIM_COUNT(x, v) (BIT_CLEAR_DTIM_COUNT(x) | BIT_DTIM_COUNT(v))
/* 2 REG_ATIM_DTIM_CTRL_SEL (Offset 0x153C) */
#define BIT_DTIM_BYPASS_V1 BIT(7)
#define BIT_SHIFT_ATIM_DTIM_SEL 0
#define BIT_MASK_ATIM_DTIM_SEL 0x1f
#define BIT_ATIM_DTIM_SEL(x) \
(((x) & BIT_MASK_ATIM_DTIM_SEL) << BIT_SHIFT_ATIM_DTIM_SEL)
#define BITS_ATIM_DTIM_SEL (BIT_MASK_ATIM_DTIM_SEL << BIT_SHIFT_ATIM_DTIM_SEL)
#define BIT_CLEAR_ATIM_DTIM_SEL(x) ((x) & (~BITS_ATIM_DTIM_SEL))
#define BIT_GET_ATIM_DTIM_SEL(x) \
(((x) >> BIT_SHIFT_ATIM_DTIM_SEL) & BIT_MASK_ATIM_DTIM_SEL)
#define BIT_SET_ATIM_DTIM_SEL(x, v) \
(BIT_CLEAR_ATIM_DTIM_SEL(x) | BIT_ATIM_DTIM_SEL(v))
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
/* 2 REG_ATIMUGT_V1 (Offset 0x153D) */
#define BIT_SHIFT_ATIM_URGENT 0
#define BIT_MASK_ATIM_URGENT 0xff
#define BIT_ATIM_URGENT(x) \
(((x) & BIT_MASK_ATIM_URGENT) << BIT_SHIFT_ATIM_URGENT)
#define BITS_ATIM_URGENT (BIT_MASK_ATIM_URGENT << BIT_SHIFT_ATIM_URGENT)
#define BIT_CLEAR_ATIM_URGENT(x) ((x) & (~BITS_ATIM_URGENT))
#define BIT_GET_ATIM_URGENT(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT) & BIT_MASK_ATIM_URGENT)
#define BIT_SET_ATIM_URGENT(x, v) \
(BIT_CLEAR_ATIM_URGENT(x) | BIT_ATIM_URGENT(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DIS_ATIM_V1 (Offset 0x1540) */
#define BIT_DIS_ATIM_P4 BIT(19)
#define BIT_DIS_ATIM_P3 BIT(18)
#define BIT_DIS_ATIM_P2 BIT(17)
#define BIT_DIS_ATIM_P1 BIT(16)
#define BIT_DIS_ATIM_VAP15 BIT(15)
#define BIT_DIS_ATIM_VAP14 BIT(14)
#define BIT_DIS_ATIM_VAP13 BIT(13)
#define BIT_DIS_ATIM_VAP12 BIT(12)
#define BIT_DIS_ATIM_VAP11 BIT(11)
#define BIT_DIS_ATIM_VAP10 BIT(10)
#define BIT_DIS_ATIM_VAP9 BIT(9)
#define BIT_DIS_ATIM_VAP8 BIT(8)
#define BIT_DIS_ATIM_ROOT_P0 BIT(0)
/* 2 REG_HIQ_NO_LMT_EN_V1 (Offset 0x1544) */
#define BIT_HIQ_NO_LMT_EN_P4 BIT(19)
#define BIT_HIQ_NO_LMT_EN_P3 BIT(18)
#define BIT_HIQ_NO_LMT_EN_P2 BIT(17)
#define BIT_HIQ_NO_LMT_EN_P1 BIT(16)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_HIQ_NO_LMT_EN_V1 (Offset 0x1544) */
#define BIT_HIQ_NO_LMT_EN_VAP15 BIT(15)
#define BIT_HIQ_NO_LMT_EN_VAP14 BIT(14)
#define BIT_HIQ_NO_LMT_EN_VAP13 BIT(13)
#define BIT_HIQ_NO_LMT_EN_VAP12 BIT(12)
#define BIT_HIQ_NO_LMT_EN_VAP11 BIT(11)
#define BIT_HIQ_NO_LMT_EN_VAP10 BIT(10)
#define BIT_HIQ_NO_LMT_EN_VAP9 BIT(9)
#define BIT_HIQ_NO_LMT_EN_VAP8 BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_HIQ_NO_LMT_EN_V1 (Offset 0x1544) */
#define BIT_HIQ_NO_LMT_EN_ROOT_P0 BIT(0)
/* 2 REG_P2PPS_CTRL_V1 (Offset 0x1548) */
#define BIT_P2P_PWR_RST1_V2 BIT(15)
#define BIT_P2P_PWR_RST0_V2 BIT(14)
#define BIT_EN_TSFBIT32_RST_P2P_V1 BIT(13)
#define BIT_SHIFT_NOA_UNIT0_SEL_V1 8
#define BIT_MASK_NOA_UNIT0_SEL_V1 0x7
#define BIT_NOA_UNIT0_SEL_V1(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL_V1) << BIT_SHIFT_NOA_UNIT0_SEL_V1)
#define BITS_NOA_UNIT0_SEL_V1 \
(BIT_MASK_NOA_UNIT0_SEL_V1 << BIT_SHIFT_NOA_UNIT0_SEL_V1)
#define BIT_CLEAR_NOA_UNIT0_SEL_V1(x) ((x) & (~BITS_NOA_UNIT0_SEL_V1))
#define BIT_GET_NOA_UNIT0_SEL_V1(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL_V1) & BIT_MASK_NOA_UNIT0_SEL_V1)
#define BIT_SET_NOA_UNIT0_SEL_V1(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL_V1(x) | BIT_NOA_UNIT0_SEL_V1(v))
#define BIT_P2P_CTW_ALLSTASLEEP_V1 BIT(7)
#define BIT_P2P_OFF_DISTX_EN_V1 BIT(6)
#define BIT_PWR_MGT_EN_V1 BIT(5)
#define BIT_P2P_NOA1_EN_V1 BIT(2)
#define BIT_P2P_NOA0_EN_V1 BIT(1)
/* 2 REG_P2PPS1_CTRL_V1 (Offset 0x154C) */
#define BIT_P2P1_PWR_RST1_V2 BIT(15)
#define BIT_P2P1_PWR_RST0_V2 BIT(14)
#define BIT_EN_TSFBIT32_RST_P2P1_V1 BIT(13)
#define BIT_SHIFT_NOA_UNIT1_SEL_V1 8
#define BIT_MASK_NOA_UNIT1_SEL_V1 0x7
#define BIT_NOA_UNIT1_SEL_V1(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL_V1) << BIT_SHIFT_NOA_UNIT1_SEL_V1)
#define BITS_NOA_UNIT1_SEL_V1 \
(BIT_MASK_NOA_UNIT1_SEL_V1 << BIT_SHIFT_NOA_UNIT1_SEL_V1)
#define BIT_CLEAR_NOA_UNIT1_SEL_V1(x) ((x) & (~BITS_NOA_UNIT1_SEL_V1))
#define BIT_GET_NOA_UNIT1_SEL_V1(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL_V1) & BIT_MASK_NOA_UNIT1_SEL_V1)
#define BIT_SET_NOA_UNIT1_SEL_V1(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL_V1(x) | BIT_NOA_UNIT1_SEL_V1(v))
#define BIT_P2P1_CTW_ALLSTASLEEP_V1 BIT(7)
#define BIT_P2P1_PWR_MGT_EN_V1 BIT(5)
#define BIT_P2P1_NOA1_EN_V1 BIT(2)
#define BIT_P2P1_NOA0_EN_V1 BIT(1)
/* 2 REG_P2PPS1_SPEC_STATE_V1 (Offset 0x154E) */
#define BIT_P2P1_SPEC_POWER_STATEP BIT(7)
#define BIT_P2P1_SPEC_BEACON_AREA_ON BIT(5)
/* 2 REG_P2PPS2_CTRL_V1 (Offset 0x1550) */
#define BIT_P2P2_PWR_RST1_V2 BIT(15)
#define BIT_P2P2_PWR_RST0_V2 BIT(14)
#define BIT_EN_TSFBIT32_RST_P2P2_V1 BIT(13)
#define BIT_SHIFT_NOA_UNIT2_SEL_V1 8
#define BIT_MASK_NOA_UNIT2_SEL_V1 0x7
#define BIT_NOA_UNIT2_SEL_V1(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL_V1) << BIT_SHIFT_NOA_UNIT2_SEL_V1)
#define BITS_NOA_UNIT2_SEL_V1 \
(BIT_MASK_NOA_UNIT2_SEL_V1 << BIT_SHIFT_NOA_UNIT2_SEL_V1)
#define BIT_CLEAR_NOA_UNIT2_SEL_V1(x) ((x) & (~BITS_NOA_UNIT2_SEL_V1))
#define BIT_GET_NOA_UNIT2_SEL_V1(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL_V1) & BIT_MASK_NOA_UNIT2_SEL_V1)
#define BIT_SET_NOA_UNIT2_SEL_V1(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL_V1(x) | BIT_NOA_UNIT2_SEL_V1(v))
#define BIT_P2P2_CTW_ALLSTASLEEP_V1 BIT(7)
#define BIT_P2P2_OFF_DISTX_EN_V1 BIT(6)
#define BIT_P2P2_PWR_MGT_EN_V1 BIT(5)
#define BIT_P2P2_NOA1_EN_V1 BIT(2)
#define BIT_P2P2_NOA0_EN_V1 BIT(1)
/* 2 REG_P2PPS2_SPEC_STATE_V1 (Offset 0x1552) */
#define BIT_P2P2_SPEC_POWER_STATEP BIT(7)
#define BIT_P2P2_SPEC_BEACON_AREA_ON BIT(5)
/* 2 REG_CHG_POWER_BCN_AREA (Offset 0x1556) */
#define BIT_CHG_POWER_BCN_AREA BIT(0)
/* 2 REG_NOA_SEL (Offset 0x1557) */
#define BIT_SHIFT_NOA_SEL_V1 0
#define BIT_MASK_NOA_SEL_V1 0x7
#define BIT_NOA_SEL_V1(x) (((x) & BIT_MASK_NOA_SEL_V1) << BIT_SHIFT_NOA_SEL_V1)
#define BITS_NOA_SEL_V1 (BIT_MASK_NOA_SEL_V1 << BIT_SHIFT_NOA_SEL_V1)
#define BIT_CLEAR_NOA_SEL_V1(x) ((x) & (~BITS_NOA_SEL_V1))
#define BIT_GET_NOA_SEL_V1(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V1) & BIT_MASK_NOA_SEL_V1)
#define BIT_SET_NOA_SEL_V1(x, v) (BIT_CLEAR_NOA_SEL_V1(x) | BIT_NOA_SEL_V1(v))
/* 2 REG_NOA_PARAM_3_V1 (Offset 0x1564) */
#define BIT_SHIFT_NOA_COUNT_V2 0
#define BIT_MASK_NOA_COUNT_V2 0xffffffffL
#define BIT_NOA_COUNT_V2(x) \
(((x) & BIT_MASK_NOA_COUNT_V2) << BIT_SHIFT_NOA_COUNT_V2)
#define BITS_NOA_COUNT_V2 (BIT_MASK_NOA_COUNT_V2 << BIT_SHIFT_NOA_COUNT_V2)
#define BIT_CLEAR_NOA_COUNT_V2(x) ((x) & (~BITS_NOA_COUNT_V2))
#define BIT_GET_NOA_COUNT_V2(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_V2) & BIT_MASK_NOA_COUNT_V2)
#define BIT_SET_NOA_COUNT_V2(x, v) \
(BIT_CLEAR_NOA_COUNT_V2(x) | BIT_NOA_COUNT_V2(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_P2PPS_HW_AUTO_PAUSE_CTRL (Offset 0x156C) */
#define BIT_P2PPS_NOA_STOP_TX_HANG BIT(31)
#define BIT_P2PPS_MACID_PAUSE_EN BIT(11)
#define BIT_P2PPS__MGQ_PAUSE BIT(10)
#define BIT_P2PPS__HIQ_PAUSE BIT(9)
#define BIT_P2PPS__BCNQ_PAUSE BIT(8)
#define BIT_SHIFT_P2PPS_MACID_PAUSE 0
#define BIT_MASK_P2PPS_MACID_PAUSE 0xff
#define BIT_P2PPS_MACID_PAUSE(x) \
(((x) & BIT_MASK_P2PPS_MACID_PAUSE) << BIT_SHIFT_P2PPS_MACID_PAUSE)
#define BITS_P2PPS_MACID_PAUSE \
(BIT_MASK_P2PPS_MACID_PAUSE << BIT_SHIFT_P2PPS_MACID_PAUSE)
#define BIT_CLEAR_P2PPS_MACID_PAUSE(x) ((x) & (~BITS_P2PPS_MACID_PAUSE))
#define BIT_GET_P2PPS_MACID_PAUSE(x) \
(((x) >> BIT_SHIFT_P2PPS_MACID_PAUSE) & BIT_MASK_P2PPS_MACID_PAUSE)
#define BIT_SET_P2PPS_MACID_PAUSE(x, v) \
(BIT_CLEAR_P2PPS_MACID_PAUSE(x) | BIT_P2PPS_MACID_PAUSE(v))
/* 2 REG_P2PPS1_HW_AUTO_PAUSE_CTRL (Offset 0x1570) */
#define BIT_P2PPS1_NOA_STOP_TX_HANG BIT(31)
#define BIT_P2PPS1_MACID_PAUSE_EN BIT(11)
#define BIT_P2PPS1__MGQ_PAUSE BIT(10)
#define BIT_P2PPS1__HIQ_PAUSE BIT(9)
#define BIT_P2PPS1__BCNQ_PAUSE BIT(8)
#define BIT_SHIFT_P2PPS1_MACID_PAUSE 0
#define BIT_MASK_P2PPS1_MACID_PAUSE 0xff
#define BIT_P2PPS1_MACID_PAUSE(x) \
(((x) & BIT_MASK_P2PPS1_MACID_PAUSE) << BIT_SHIFT_P2PPS1_MACID_PAUSE)
#define BITS_P2PPS1_MACID_PAUSE \
(BIT_MASK_P2PPS1_MACID_PAUSE << BIT_SHIFT_P2PPS1_MACID_PAUSE)
#define BIT_CLEAR_P2PPS1_MACID_PAUSE(x) ((x) & (~BITS_P2PPS1_MACID_PAUSE))
#define BIT_GET_P2PPS1_MACID_PAUSE(x) \
(((x) >> BIT_SHIFT_P2PPS1_MACID_PAUSE) & BIT_MASK_P2PPS1_MACID_PAUSE)
#define BIT_SET_P2PPS1_MACID_PAUSE(x, v) \
(BIT_CLEAR_P2PPS1_MACID_PAUSE(x) | BIT_P2PPS1_MACID_PAUSE(v))
/* 2 REG_P2PPS2_HW_AUTO_PAUSE_CTRL (Offset 0x1574) */
#define BIT_P2PPS2_NOA_STOP_TX_HANG BIT(31)
#define BIT_P2PPS2_MACID_PAUSE_EN BIT(11)
#define BIT_P2PPS2__MGQ_PAUSE BIT(10)
#define BIT_P2PPS2__HIQ_PAUSE BIT(9)
#define BIT_P2PPS2__BCNQ_PAUSE BIT(8)
#define BIT_SHIFT_P2PPS2_MACID_PAUSE 0
#define BIT_MASK_P2PPS2_MACID_PAUSE 0xff
#define BIT_P2PPS2_MACID_PAUSE(x) \
(((x) & BIT_MASK_P2PPS2_MACID_PAUSE) << BIT_SHIFT_P2PPS2_MACID_PAUSE)
#define BITS_P2PPS2_MACID_PAUSE \
(BIT_MASK_P2PPS2_MACID_PAUSE << BIT_SHIFT_P2PPS2_MACID_PAUSE)
#define BIT_CLEAR_P2PPS2_MACID_PAUSE(x) ((x) & (~BITS_P2PPS2_MACID_PAUSE))
#define BIT_GET_P2PPS2_MACID_PAUSE(x) \
(((x) >> BIT_SHIFT_P2PPS2_MACID_PAUSE) & BIT_MASK_P2PPS2_MACID_PAUSE)
#define BIT_SET_P2PPS2_MACID_PAUSE(x, v) \
(BIT_CLEAR_P2PPS2_MACID_PAUSE(x) | BIT_P2PPS2_MACID_PAUSE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_RX_TBTT_SHIFT (Offset 0x1578) */
#define BIT_SHIFT_RX_TBTT_SHIFT_SEL 24
#define BIT_MASK_RX_TBTT_SHIFT_SEL 0x7
#define BIT_RX_TBTT_SHIFT_SEL(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_SEL) << BIT_SHIFT_RX_TBTT_SHIFT_SEL)
#define BITS_RX_TBTT_SHIFT_SEL \
(BIT_MASK_RX_TBTT_SHIFT_SEL << BIT_SHIFT_RX_TBTT_SHIFT_SEL)
#define BIT_CLEAR_RX_TBTT_SHIFT_SEL(x) ((x) & (~BITS_RX_TBTT_SHIFT_SEL))
#define BIT_GET_RX_TBTT_SHIFT_SEL(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_SEL) & BIT_MASK_RX_TBTT_SHIFT_SEL)
#define BIT_SET_RX_TBTT_SHIFT_SEL(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_SEL(x) | BIT_RX_TBTT_SHIFT_SEL(v))
#define BIT_RX_TBTT_SHIFT_RW_FLAG BIT(15)
#define BIT_SHIFT_RX_TBTT_SHIFT_OFFSET 0
#define BIT_MASK_RX_TBTT_SHIFT_OFFSET 0xfff
#define BIT_RX_TBTT_SHIFT_OFFSET(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_OFFSET) \
<< BIT_SHIFT_RX_TBTT_SHIFT_OFFSET)
#define BITS_RX_TBTT_SHIFT_OFFSET \
(BIT_MASK_RX_TBTT_SHIFT_OFFSET << BIT_SHIFT_RX_TBTT_SHIFT_OFFSET)
#define BIT_CLEAR_RX_TBTT_SHIFT_OFFSET(x) ((x) & (~BITS_RX_TBTT_SHIFT_OFFSET))
#define BIT_GET_RX_TBTT_SHIFT_OFFSET(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_OFFSET) & \
BIT_MASK_RX_TBTT_SHIFT_OFFSET)
#define BIT_SET_RX_TBTT_SHIFT_OFFSET(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_OFFSET(x) | BIT_RX_TBTT_SHIFT_OFFSET(v))
/* 2 REG_FREERUN_CNT_LOW (Offset 0x1580) */
#define BIT_SHIFT_FREERUN_CNT_LOW 0
#define BIT_MASK_FREERUN_CNT_LOW 0xffffffffL
#define BIT_FREERUN_CNT_LOW(x) \
(((x) & BIT_MASK_FREERUN_CNT_LOW) << BIT_SHIFT_FREERUN_CNT_LOW)
#define BITS_FREERUN_CNT_LOW \
(BIT_MASK_FREERUN_CNT_LOW << BIT_SHIFT_FREERUN_CNT_LOW)
#define BIT_CLEAR_FREERUN_CNT_LOW(x) ((x) & (~BITS_FREERUN_CNT_LOW))
#define BIT_GET_FREERUN_CNT_LOW(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_LOW) & BIT_MASK_FREERUN_CNT_LOW)
#define BIT_SET_FREERUN_CNT_LOW(x, v) \
(BIT_CLEAR_FREERUN_CNT_LOW(x) | BIT_FREERUN_CNT_LOW(v))
/* 2 REG_FREERUN_CNT_HIGH (Offset 0x1584) */
#define BIT_SHIFT_FREERUN_CNT_HIGH 0
#define BIT_MASK_FREERUN_CNT_HIGH 0xffffffffL
#define BIT_FREERUN_CNT_HIGH(x) \
(((x) & BIT_MASK_FREERUN_CNT_HIGH) << BIT_SHIFT_FREERUN_CNT_HIGH)
#define BITS_FREERUN_CNT_HIGH \
(BIT_MASK_FREERUN_CNT_HIGH << BIT_SHIFT_FREERUN_CNT_HIGH)
#define BIT_CLEAR_FREERUN_CNT_HIGH(x) ((x) & (~BITS_FREERUN_CNT_HIGH))
#define BIT_GET_FREERUN_CNT_HIGH(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_HIGH) & BIT_MASK_FREERUN_CNT_HIGH)
#define BIT_SET_FREERUN_CNT_HIGH(x, v) \
(BIT_CLEAR_FREERUN_CNT_HIGH(x) | BIT_FREERUN_CNT_HIGH(v))
/* 2 REG_PS_TIMER_0 (Offset 0x158C) */
#define BIT_SHIFT_PS_TIMER_0 0
#define BIT_MASK_PS_TIMER_0 0xffffffffL
#define BIT_PS_TIMER_0(x) (((x) & BIT_MASK_PS_TIMER_0) << BIT_SHIFT_PS_TIMER_0)
#define BITS_PS_TIMER_0 (BIT_MASK_PS_TIMER_0 << BIT_SHIFT_PS_TIMER_0)
#define BIT_CLEAR_PS_TIMER_0(x) ((x) & (~BITS_PS_TIMER_0))
#define BIT_GET_PS_TIMER_0(x) \
(((x) >> BIT_SHIFT_PS_TIMER_0) & BIT_MASK_PS_TIMER_0)
#define BIT_SET_PS_TIMER_0(x, v) (BIT_CLEAR_PS_TIMER_0(x) | BIT_PS_TIMER_0(v))
/* 2 REG_PS_TIMER_1 (Offset 0x1590) */
#define BIT_SHIFT_PS_TIMER_1 0
#define BIT_MASK_PS_TIMER_1 0xffffffffL
#define BIT_PS_TIMER_1(x) (((x) & BIT_MASK_PS_TIMER_1) << BIT_SHIFT_PS_TIMER_1)
#define BITS_PS_TIMER_1 (BIT_MASK_PS_TIMER_1 << BIT_SHIFT_PS_TIMER_1)
#define BIT_CLEAR_PS_TIMER_1(x) ((x) & (~BITS_PS_TIMER_1))
#define BIT_GET_PS_TIMER_1(x) \
(((x) >> BIT_SHIFT_PS_TIMER_1) & BIT_MASK_PS_TIMER_1)
#define BIT_SET_PS_TIMER_1(x, v) (BIT_CLEAR_PS_TIMER_1(x) | BIT_PS_TIMER_1(v))
/* 2 REG_PS_TIMER_2 (Offset 0x1594) */
#define BIT_SHIFT_PS_TIMER_2 0
#define BIT_MASK_PS_TIMER_2 0xffffffffL
#define BIT_PS_TIMER_2(x) (((x) & BIT_MASK_PS_TIMER_2) << BIT_SHIFT_PS_TIMER_2)
#define BITS_PS_TIMER_2 (BIT_MASK_PS_TIMER_2 << BIT_SHIFT_PS_TIMER_2)
#define BIT_CLEAR_PS_TIMER_2(x) ((x) & (~BITS_PS_TIMER_2))
#define BIT_GET_PS_TIMER_2(x) \
(((x) >> BIT_SHIFT_PS_TIMER_2) & BIT_MASK_PS_TIMER_2)
#define BIT_SET_PS_TIMER_2(x, v) (BIT_CLEAR_PS_TIMER_2(x) | BIT_PS_TIMER_2(v))
/* 2 REG_PS_TIMER_3 (Offset 0x1598) */
#define BIT_SHIFT_PS_TIMER_3 0
#define BIT_MASK_PS_TIMER_3 0xffffffffL
#define BIT_PS_TIMER_3(x) (((x) & BIT_MASK_PS_TIMER_3) << BIT_SHIFT_PS_TIMER_3)
#define BITS_PS_TIMER_3 (BIT_MASK_PS_TIMER_3 << BIT_SHIFT_PS_TIMER_3)
#define BIT_CLEAR_PS_TIMER_3(x) ((x) & (~BITS_PS_TIMER_3))
#define BIT_GET_PS_TIMER_3(x) \
(((x) >> BIT_SHIFT_PS_TIMER_3) & BIT_MASK_PS_TIMER_3)
#define BIT_SET_PS_TIMER_3(x, v) (BIT_CLEAR_PS_TIMER_3(x) | BIT_PS_TIMER_3(v))
/* 2 REG_PS_TIMER_4 (Offset 0x159C) */
#define BIT_SHIFT_PS_TIMER_4 0
#define BIT_MASK_PS_TIMER_4 0xffffffffL
#define BIT_PS_TIMER_4(x) (((x) & BIT_MASK_PS_TIMER_4) << BIT_SHIFT_PS_TIMER_4)
#define BITS_PS_TIMER_4 (BIT_MASK_PS_TIMER_4 << BIT_SHIFT_PS_TIMER_4)
#define BIT_CLEAR_PS_TIMER_4(x) ((x) & (~BITS_PS_TIMER_4))
#define BIT_GET_PS_TIMER_4(x) \
(((x) >> BIT_SHIFT_PS_TIMER_4) & BIT_MASK_PS_TIMER_4)
#define BIT_SET_PS_TIMER_4(x, v) (BIT_CLEAR_PS_TIMER_4(x) | BIT_PS_TIMER_4(v))
/* 2 REG_PS_TIMER_5 (Offset 0x15A0) */
#define BIT_SHIFT_PS_TIMER_5 0
#define BIT_MASK_PS_TIMER_5 0xffffffffL
#define BIT_PS_TIMER_5(x) (((x) & BIT_MASK_PS_TIMER_5) << BIT_SHIFT_PS_TIMER_5)
#define BITS_PS_TIMER_5 (BIT_MASK_PS_TIMER_5 << BIT_SHIFT_PS_TIMER_5)
#define BIT_CLEAR_PS_TIMER_5(x) ((x) & (~BITS_PS_TIMER_5))
#define BIT_GET_PS_TIMER_5(x) \
(((x) >> BIT_SHIFT_PS_TIMER_5) & BIT_MASK_PS_TIMER_5)
#define BIT_SET_PS_TIMER_5(x, v) (BIT_CLEAR_PS_TIMER_5(x) | BIT_PS_TIMER_5(v))
/* 2 REG_PS_TIMER_01_CTRL (Offset 0x15A4) */
#define BIT_SHIFT_PS_TIMER_1_EARLY_TIME 24
#define BIT_MASK_PS_TIMER_1_EARLY_TIME 0xff
#define BIT_PS_TIMER_1_EARLY_TIME(x) \
(((x) & BIT_MASK_PS_TIMER_1_EARLY_TIME) \
<< BIT_SHIFT_PS_TIMER_1_EARLY_TIME)
#define BITS_PS_TIMER_1_EARLY_TIME \
(BIT_MASK_PS_TIMER_1_EARLY_TIME << BIT_SHIFT_PS_TIMER_1_EARLY_TIME)
#define BIT_CLEAR_PS_TIMER_1_EARLY_TIME(x) ((x) & (~BITS_PS_TIMER_1_EARLY_TIME))
#define BIT_GET_PS_TIMER_1_EARLY_TIME(x) \
(((x) >> BIT_SHIFT_PS_TIMER_1_EARLY_TIME) & \
BIT_MASK_PS_TIMER_1_EARLY_TIME)
#define BIT_SET_PS_TIMER_1_EARLY_TIME(x, v) \
(BIT_CLEAR_PS_TIMER_1_EARLY_TIME(x) | BIT_PS_TIMER_1_EARLY_TIME(v))
#define BIT_PS_TIMER_1_EN BIT(23)
#define BIT_SHIFT_PS_TIMER_1_TSF_SEL 16
#define BIT_MASK_PS_TIMER_1_TSF_SEL 0x7
#define BIT_PS_TIMER_1_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_1_TSF_SEL) << BIT_SHIFT_PS_TIMER_1_TSF_SEL)
#define BITS_PS_TIMER_1_TSF_SEL \
(BIT_MASK_PS_TIMER_1_TSF_SEL << BIT_SHIFT_PS_TIMER_1_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_1_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_1_TSF_SEL))
#define BIT_GET_PS_TIMER_1_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_1_TSF_SEL) & BIT_MASK_PS_TIMER_1_TSF_SEL)
#define BIT_SET_PS_TIMER_1_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_1_TSF_SEL(x) | BIT_PS_TIMER_1_TSF_SEL(v))
#define BIT_SHIFT_PS_TIMER_0_EARLY_TIME 8
#define BIT_MASK_PS_TIMER_0_EARLY_TIME 0xff
#define BIT_PS_TIMER_0_EARLY_TIME(x) \
(((x) & BIT_MASK_PS_TIMER_0_EARLY_TIME) \
<< BIT_SHIFT_PS_TIMER_0_EARLY_TIME)
#define BITS_PS_TIMER_0_EARLY_TIME \
(BIT_MASK_PS_TIMER_0_EARLY_TIME << BIT_SHIFT_PS_TIMER_0_EARLY_TIME)
#define BIT_CLEAR_PS_TIMER_0_EARLY_TIME(x) ((x) & (~BITS_PS_TIMER_0_EARLY_TIME))
#define BIT_GET_PS_TIMER_0_EARLY_TIME(x) \
(((x) >> BIT_SHIFT_PS_TIMER_0_EARLY_TIME) & \
BIT_MASK_PS_TIMER_0_EARLY_TIME)
#define BIT_SET_PS_TIMER_0_EARLY_TIME(x, v) \
(BIT_CLEAR_PS_TIMER_0_EARLY_TIME(x) | BIT_PS_TIMER_0_EARLY_TIME(v))
#define BIT_PS_TIMER_0_EN BIT(7)
#define BIT_SHIFT_PS_TIMER_0_TSF_SEL 0
#define BIT_MASK_PS_TIMER_0_TSF_SEL 0x7
#define BIT_PS_TIMER_0_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_0_TSF_SEL) << BIT_SHIFT_PS_TIMER_0_TSF_SEL)
#define BITS_PS_TIMER_0_TSF_SEL \
(BIT_MASK_PS_TIMER_0_TSF_SEL << BIT_SHIFT_PS_TIMER_0_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_0_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_0_TSF_SEL))
#define BIT_GET_PS_TIMER_0_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_0_TSF_SEL) & BIT_MASK_PS_TIMER_0_TSF_SEL)
#define BIT_SET_PS_TIMER_0_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_0_TSF_SEL(x) | BIT_PS_TIMER_0_TSF_SEL(v))
/* 2 REG_PS_TIMER_23_CTRL (Offset 0x15A8) */
#define BIT_SHIFT_PS_TIMER_3_EARLY_TIME 24
#define BIT_MASK_PS_TIMER_3_EARLY_TIME 0xff
#define BIT_PS_TIMER_3_EARLY_TIME(x) \
(((x) & BIT_MASK_PS_TIMER_3_EARLY_TIME) \
<< BIT_SHIFT_PS_TIMER_3_EARLY_TIME)
#define BITS_PS_TIMER_3_EARLY_TIME \
(BIT_MASK_PS_TIMER_3_EARLY_TIME << BIT_SHIFT_PS_TIMER_3_EARLY_TIME)
#define BIT_CLEAR_PS_TIMER_3_EARLY_TIME(x) ((x) & (~BITS_PS_TIMER_3_EARLY_TIME))
#define BIT_GET_PS_TIMER_3_EARLY_TIME(x) \
(((x) >> BIT_SHIFT_PS_TIMER_3_EARLY_TIME) & \
BIT_MASK_PS_TIMER_3_EARLY_TIME)
#define BIT_SET_PS_TIMER_3_EARLY_TIME(x, v) \
(BIT_CLEAR_PS_TIMER_3_EARLY_TIME(x) | BIT_PS_TIMER_3_EARLY_TIME(v))
#define BIT_PS_TIMER_3_EN BIT(23)
#define BIT_SHIFT_PS_TIMER_3_TSF_SEL 16
#define BIT_MASK_PS_TIMER_3_TSF_SEL 0x7
#define BIT_PS_TIMER_3_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_3_TSF_SEL) << BIT_SHIFT_PS_TIMER_3_TSF_SEL)
#define BITS_PS_TIMER_3_TSF_SEL \
(BIT_MASK_PS_TIMER_3_TSF_SEL << BIT_SHIFT_PS_TIMER_3_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_3_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_3_TSF_SEL))
#define BIT_GET_PS_TIMER_3_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_3_TSF_SEL) & BIT_MASK_PS_TIMER_3_TSF_SEL)
#define BIT_SET_PS_TIMER_3_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_3_TSF_SEL(x) | BIT_PS_TIMER_3_TSF_SEL(v))
#define BIT_SHIFT_PS_TIMER_2_EARLY_TIME 8
#define BIT_MASK_PS_TIMER_2_EARLY_TIME 0xff
#define BIT_PS_TIMER_2_EARLY_TIME(x) \
(((x) & BIT_MASK_PS_TIMER_2_EARLY_TIME) \
<< BIT_SHIFT_PS_TIMER_2_EARLY_TIME)
#define BITS_PS_TIMER_2_EARLY_TIME \
(BIT_MASK_PS_TIMER_2_EARLY_TIME << BIT_SHIFT_PS_TIMER_2_EARLY_TIME)
#define BIT_CLEAR_PS_TIMER_2_EARLY_TIME(x) ((x) & (~BITS_PS_TIMER_2_EARLY_TIME))
#define BIT_GET_PS_TIMER_2_EARLY_TIME(x) \
(((x) >> BIT_SHIFT_PS_TIMER_2_EARLY_TIME) & \
BIT_MASK_PS_TIMER_2_EARLY_TIME)
#define BIT_SET_PS_TIMER_2_EARLY_TIME(x, v) \
(BIT_CLEAR_PS_TIMER_2_EARLY_TIME(x) | BIT_PS_TIMER_2_EARLY_TIME(v))
#define BIT_PS_TIMER_2_EN BIT(7)
#define BIT_SHIFT_PS_TIMER_2_TSF_SEL 0
#define BIT_MASK_PS_TIMER_2_TSF_SEL 0x7
#define BIT_PS_TIMER_2_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_2_TSF_SEL) << BIT_SHIFT_PS_TIMER_2_TSF_SEL)
#define BITS_PS_TIMER_2_TSF_SEL \
(BIT_MASK_PS_TIMER_2_TSF_SEL << BIT_SHIFT_PS_TIMER_2_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_2_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_2_TSF_SEL))
#define BIT_GET_PS_TIMER_2_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_2_TSF_SEL) & BIT_MASK_PS_TIMER_2_TSF_SEL)
#define BIT_SET_PS_TIMER_2_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_2_TSF_SEL(x) | BIT_PS_TIMER_2_TSF_SEL(v))
/* 2 REG_PS_TIMER_45_CTRL (Offset 0x15AC) */
#define BIT_SHIFT_PS_TIMER_5_EARLY_TIME 24
#define BIT_MASK_PS_TIMER_5_EARLY_TIME 0xff
#define BIT_PS_TIMER_5_EARLY_TIME(x) \
(((x) & BIT_MASK_PS_TIMER_5_EARLY_TIME) \
<< BIT_SHIFT_PS_TIMER_5_EARLY_TIME)
#define BITS_PS_TIMER_5_EARLY_TIME \
(BIT_MASK_PS_TIMER_5_EARLY_TIME << BIT_SHIFT_PS_TIMER_5_EARLY_TIME)
#define BIT_CLEAR_PS_TIMER_5_EARLY_TIME(x) ((x) & (~BITS_PS_TIMER_5_EARLY_TIME))
#define BIT_GET_PS_TIMER_5_EARLY_TIME(x) \
(((x) >> BIT_SHIFT_PS_TIMER_5_EARLY_TIME) & \
BIT_MASK_PS_TIMER_5_EARLY_TIME)
#define BIT_SET_PS_TIMER_5_EARLY_TIME(x, v) \
(BIT_CLEAR_PS_TIMER_5_EARLY_TIME(x) | BIT_PS_TIMER_5_EARLY_TIME(v))
#define BIT_PS_TIMER_5_EN BIT(23)
#define BIT_SHIFT_PS_TIMER_5_TSF_SEL 16
#define BIT_MASK_PS_TIMER_5_TSF_SEL 0x7
#define BIT_PS_TIMER_5_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_5_TSF_SEL) << BIT_SHIFT_PS_TIMER_5_TSF_SEL)
#define BITS_PS_TIMER_5_TSF_SEL \
(BIT_MASK_PS_TIMER_5_TSF_SEL << BIT_SHIFT_PS_TIMER_5_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_5_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_5_TSF_SEL))
#define BIT_GET_PS_TIMER_5_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_5_TSF_SEL) & BIT_MASK_PS_TIMER_5_TSF_SEL)
#define BIT_SET_PS_TIMER_5_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_5_TSF_SEL(x) | BIT_PS_TIMER_5_TSF_SEL(v))
#define BIT_SHIFT_PS_TIMER_4_EARLY_TIME 8
#define BIT_MASK_PS_TIMER_4_EARLY_TIME 0xff
#define BIT_PS_TIMER_4_EARLY_TIME(x) \
(((x) & BIT_MASK_PS_TIMER_4_EARLY_TIME) \
<< BIT_SHIFT_PS_TIMER_4_EARLY_TIME)
#define BITS_PS_TIMER_4_EARLY_TIME \
(BIT_MASK_PS_TIMER_4_EARLY_TIME << BIT_SHIFT_PS_TIMER_4_EARLY_TIME)
#define BIT_CLEAR_PS_TIMER_4_EARLY_TIME(x) ((x) & (~BITS_PS_TIMER_4_EARLY_TIME))
#define BIT_GET_PS_TIMER_4_EARLY_TIME(x) \
(((x) >> BIT_SHIFT_PS_TIMER_4_EARLY_TIME) & \
BIT_MASK_PS_TIMER_4_EARLY_TIME)
#define BIT_SET_PS_TIMER_4_EARLY_TIME(x, v) \
(BIT_CLEAR_PS_TIMER_4_EARLY_TIME(x) | BIT_PS_TIMER_4_EARLY_TIME(v))
#define BIT_PS_TIMER_4_EN BIT(7)
#define BIT_SHIFT_PS_TIMER_4_TSF_SEL 0
#define BIT_MASK_PS_TIMER_4_TSF_SEL 0x7
#define BIT_PS_TIMER_4_TSF_SEL(x) \
(((x) & BIT_MASK_PS_TIMER_4_TSF_SEL) << BIT_SHIFT_PS_TIMER_4_TSF_SEL)
#define BITS_PS_TIMER_4_TSF_SEL \
(BIT_MASK_PS_TIMER_4_TSF_SEL << BIT_SHIFT_PS_TIMER_4_TSF_SEL)
#define BIT_CLEAR_PS_TIMER_4_TSF_SEL(x) ((x) & (~BITS_PS_TIMER_4_TSF_SEL))
#define BIT_GET_PS_TIMER_4_TSF_SEL(x) \
(((x) >> BIT_SHIFT_PS_TIMER_4_TSF_SEL) & BIT_MASK_PS_TIMER_4_TSF_SEL)
#define BIT_SET_PS_TIMER_4_TSF_SEL(x, v) \
(BIT_CLEAR_PS_TIMER_4_TSF_SEL(x) | BIT_PS_TIMER_4_TSF_SEL(v))
/* 2 REG_CPUMGQ_FREERUN_TIMER_CTRL (Offset 0x15B0) */
#define BIT_FREECNT_RST_V1 BIT(23)
#define BIT_EN_FREECNT_V1 BIT(16)
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1 8
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY_V1(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1)
#define BITS_CPUMGQ_TX_TIMER_EARLY_V1 \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1 \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_V1(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY_V1))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY_V1(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY_V1(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_V1(x) | \
BIT_CPUMGQ_TX_TIMER_EARLY_V1(v))
#define BIT_CPUMGQ_TIMER_EN_V1 BIT(7)
#define BIT_CPUMGQ_DROP_BY_HOLDTIME BIT(5)
#define BIT_CPUMGQ_TX_EN_V1 BIT(4)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1 0
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL_V1(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1)
#define BITS_CPUMGQ_TIMER_TSF_SEL_V1 \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1 << BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_V1(x) \
((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL_V1))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL_V1(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL_V1(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_V1(x) | BIT_CPUMGQ_TIMER_TSF_SEL_V1(v))
/* 2 REG_CPUMGQ_PROHIBIT (Offset 0x15B4) */
#define BIT_SHIFT_CPUMGQ_HOLD_TIME 8
#define BIT_MASK_CPUMGQ_HOLD_TIME 0xfff
#define BIT_CPUMGQ_HOLD_TIME(x) \
(((x) & BIT_MASK_CPUMGQ_HOLD_TIME) << BIT_SHIFT_CPUMGQ_HOLD_TIME)
#define BITS_CPUMGQ_HOLD_TIME \
(BIT_MASK_CPUMGQ_HOLD_TIME << BIT_SHIFT_CPUMGQ_HOLD_TIME)
#define BIT_CLEAR_CPUMGQ_HOLD_TIME(x) ((x) & (~BITS_CPUMGQ_HOLD_TIME))
#define BIT_GET_CPUMGQ_HOLD_TIME(x) \
(((x) >> BIT_SHIFT_CPUMGQ_HOLD_TIME) & BIT_MASK_CPUMGQ_HOLD_TIME)
#define BIT_SET_CPUMGQ_HOLD_TIME(x, v) \
(BIT_CLEAR_CPUMGQ_HOLD_TIME(x) | BIT_CPUMGQ_HOLD_TIME(v))
#define BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP 0
#define BIT_MASK_CPUMGQ_PROHIBIT_SETUP 0xf
#define BIT_CPUMGQ_PROHIBIT_SETUP(x) \
(((x) & BIT_MASK_CPUMGQ_PROHIBIT_SETUP) \
<< BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP)
#define BITS_CPUMGQ_PROHIBIT_SETUP \
(BIT_MASK_CPUMGQ_PROHIBIT_SETUP << BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP)
#define BIT_CLEAR_CPUMGQ_PROHIBIT_SETUP(x) ((x) & (~BITS_CPUMGQ_PROHIBIT_SETUP))
#define BIT_GET_CPUMGQ_PROHIBIT_SETUP(x) \
(((x) >> BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP) & \
BIT_MASK_CPUMGQ_PROHIBIT_SETUP)
#define BIT_SET_CPUMGQ_PROHIBIT_SETUP(x, v) \
(BIT_CLEAR_CPUMGQ_PROHIBIT_SETUP(x) | BIT_CPUMGQ_PROHIBIT_SETUP(v))
/* 2 REG_TIMER_COMPARE (Offset 0x15C0) */
#define BIT_COMP_TRIGGER BIT(7)
#define BIT_SHIFT_Y_COMP 4
#define BIT_MASK_Y_COMP 0x7
#define BIT_Y_COMP(x) (((x) & BIT_MASK_Y_COMP) << BIT_SHIFT_Y_COMP)
#define BITS_Y_COMP (BIT_MASK_Y_COMP << BIT_SHIFT_Y_COMP)
#define BIT_CLEAR_Y_COMP(x) ((x) & (~BITS_Y_COMP))
#define BIT_GET_Y_COMP(x) (((x) >> BIT_SHIFT_Y_COMP) & BIT_MASK_Y_COMP)
#define BIT_SET_Y_COMP(x, v) (BIT_CLEAR_Y_COMP(x) | BIT_Y_COMP(v))
#define BIT_X_COMP_Y_OVERFLOW BIT(3)
#define BIT_SHIFT_X_COMP 0
#define BIT_MASK_X_COMP 0x7
#define BIT_X_COMP(x) (((x) & BIT_MASK_X_COMP) << BIT_SHIFT_X_COMP)
#define BITS_X_COMP (BIT_MASK_X_COMP << BIT_SHIFT_X_COMP)
#define BIT_CLEAR_X_COMP(x) ((x) & (~BITS_X_COMP))
#define BIT_GET_X_COMP(x) (((x) >> BIT_SHIFT_X_COMP) & BIT_MASK_X_COMP)
#define BIT_SET_X_COMP(x, v) (BIT_CLEAR_X_COMP(x) | BIT_X_COMP(v))
/* 2 REG_TIMER_COMPARE_VALUE_LOW (Offset 0x15C4) */
#define BIT_SHIFT_COMP_VALUE_LOW 0
#define BIT_MASK_COMP_VALUE_LOW 0xffffffffL
#define BIT_COMP_VALUE_LOW(x) \
(((x) & BIT_MASK_COMP_VALUE_LOW) << BIT_SHIFT_COMP_VALUE_LOW)
#define BITS_COMP_VALUE_LOW \
(BIT_MASK_COMP_VALUE_LOW << BIT_SHIFT_COMP_VALUE_LOW)
#define BIT_CLEAR_COMP_VALUE_LOW(x) ((x) & (~BITS_COMP_VALUE_LOW))
#define BIT_GET_COMP_VALUE_LOW(x) \
(((x) >> BIT_SHIFT_COMP_VALUE_LOW) & BIT_MASK_COMP_VALUE_LOW)
#define BIT_SET_COMP_VALUE_LOW(x, v) \
(BIT_CLEAR_COMP_VALUE_LOW(x) | BIT_COMP_VALUE_LOW(v))
/* 2 REG_TIMER_COMPARE_VALUE_HIGH (Offset 0x15C8) */
#define BIT_SHIFT_COMP_VALUE_HIGH 0
#define BIT_MASK_COMP_VALUE_HIGH 0xffffffffL
#define BIT_COMP_VALUE_HIGH(x) \
(((x) & BIT_MASK_COMP_VALUE_HIGH) << BIT_SHIFT_COMP_VALUE_HIGH)
#define BITS_COMP_VALUE_HIGH \
(BIT_MASK_COMP_VALUE_HIGH << BIT_SHIFT_COMP_VALUE_HIGH)
#define BIT_CLEAR_COMP_VALUE_HIGH(x) ((x) & (~BITS_COMP_VALUE_HIGH))
#define BIT_GET_COMP_VALUE_HIGH(x) \
(((x) >> BIT_SHIFT_COMP_VALUE_HIGH) & BIT_MASK_COMP_VALUE_HIGH)
#define BIT_SET_COMP_VALUE_HIGH(x, v) \
(BIT_CLEAR_COMP_VALUE_HIGH(x) | BIT_COMP_VALUE_HIGH(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_SCHEDULER_COUNTER (Offset 0x15D0) */
#define BIT_SHIFT_SCHEDULER_COUNTER 16
#define BIT_MASK_SCHEDULER_COUNTER 0xffff
#define BIT_SCHEDULER_COUNTER(x) \
(((x) & BIT_MASK_SCHEDULER_COUNTER) << BIT_SHIFT_SCHEDULER_COUNTER)
#define BITS_SCHEDULER_COUNTER \
(BIT_MASK_SCHEDULER_COUNTER << BIT_SHIFT_SCHEDULER_COUNTER)
#define BIT_CLEAR_SCHEDULER_COUNTER(x) ((x) & (~BITS_SCHEDULER_COUNTER))
#define BIT_GET_SCHEDULER_COUNTER(x) \
(((x) >> BIT_SHIFT_SCHEDULER_COUNTER) & BIT_MASK_SCHEDULER_COUNTER)
#define BIT_SET_SCHEDULER_COUNTER(x, v) \
(BIT_CLEAR_SCHEDULER_COUNTER(x) | BIT_SCHEDULER_COUNTER(v))
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_COUNTER (Offset 0x15D0) */
#define BIT_SHIFT__SCHEDULER_COUNTER 16
#define BIT_MASK__SCHEDULER_COUNTER 0xffff
#define BIT__SCHEDULER_COUNTER(x) \
(((x) & BIT_MASK__SCHEDULER_COUNTER) << BIT_SHIFT__SCHEDULER_COUNTER)
#define BITS__SCHEDULER_COUNTER \
(BIT_MASK__SCHEDULER_COUNTER << BIT_SHIFT__SCHEDULER_COUNTER)
#define BIT_CLEAR__SCHEDULER_COUNTER(x) ((x) & (~BITS__SCHEDULER_COUNTER))
#define BIT_GET__SCHEDULER_COUNTER(x) \
(((x) >> BIT_SHIFT__SCHEDULER_COUNTER) & BIT_MASK__SCHEDULER_COUNTER)
#define BIT_SET__SCHEDULER_COUNTER(x, v) \
(BIT_CLEAR__SCHEDULER_COUNTER(x) | BIT__SCHEDULER_COUNTER(v))
#endif
#if (HALMAC_8197G_SUPPORT)
/* 2 REG_SCHEDULER_COUNTER (Offset 0x15D0) */
#define BIT_SCHEDULER_COUNTER_RST BIT(8)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_COUNTER (Offset 0x15D0) */
#define BIT__SCHEDULER_COUNTER_RST BIT(8)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_SCHEDULER_COUNTER (Offset 0x15D0) */
#define BIT_SHIFT_SCHEDULER_COUNTER_SEL 0
#define BIT_MASK_SCHEDULER_COUNTER_SEL 0xff
#define BIT_SCHEDULER_COUNTER_SEL(x) \
(((x) & BIT_MASK_SCHEDULER_COUNTER_SEL) \
<< BIT_SHIFT_SCHEDULER_COUNTER_SEL)
#define BITS_SCHEDULER_COUNTER_SEL \
(BIT_MASK_SCHEDULER_COUNTER_SEL << BIT_SHIFT_SCHEDULER_COUNTER_SEL)
#define BIT_CLEAR_SCHEDULER_COUNTER_SEL(x) ((x) & (~BITS_SCHEDULER_COUNTER_SEL))
#define BIT_GET_SCHEDULER_COUNTER_SEL(x) \
(((x) >> BIT_SHIFT_SCHEDULER_COUNTER_SEL) & \
BIT_MASK_SCHEDULER_COUNTER_SEL)
#define BIT_SET_SCHEDULER_COUNTER_SEL(x, v) \
(BIT_CLEAR_SCHEDULER_COUNTER_SEL(x) | BIT_SCHEDULER_COUNTER_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_BCN_PSR_RPT2 (Offset 0x1600) */
#define BIT_SHIFT_DTIM_CNT2 24
#define BIT_MASK_DTIM_CNT2 0xff
#define BIT_DTIM_CNT2(x) (((x) & BIT_MASK_DTIM_CNT2) << BIT_SHIFT_DTIM_CNT2)
#define BITS_DTIM_CNT2 (BIT_MASK_DTIM_CNT2 << BIT_SHIFT_DTIM_CNT2)
#define BIT_CLEAR_DTIM_CNT2(x) ((x) & (~BITS_DTIM_CNT2))
#define BIT_GET_DTIM_CNT2(x) (((x) >> BIT_SHIFT_DTIM_CNT2) & BIT_MASK_DTIM_CNT2)
#define BIT_SET_DTIM_CNT2(x, v) (BIT_CLEAR_DTIM_CNT2(x) | BIT_DTIM_CNT2(v))
#define BIT_SHIFT_DTIM_PERIOD2 16
#define BIT_MASK_DTIM_PERIOD2 0xff
#define BIT_DTIM_PERIOD2(x) \
(((x) & BIT_MASK_DTIM_PERIOD2) << BIT_SHIFT_DTIM_PERIOD2)
#define BITS_DTIM_PERIOD2 (BIT_MASK_DTIM_PERIOD2 << BIT_SHIFT_DTIM_PERIOD2)
#define BIT_CLEAR_DTIM_PERIOD2(x) ((x) & (~BITS_DTIM_PERIOD2))
#define BIT_GET_DTIM_PERIOD2(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD2) & BIT_MASK_DTIM_PERIOD2)
#define BIT_SET_DTIM_PERIOD2(x, v) \
(BIT_CLEAR_DTIM_PERIOD2(x) | BIT_DTIM_PERIOD2(v))
#define BIT_DTIM2 BIT(15)
#define BIT_TIM2 BIT(14)
#define BIT_SHIFT_PS_AID_2 0
#define BIT_MASK_PS_AID_2 0x7ff
#define BIT_PS_AID_2(x) (((x) & BIT_MASK_PS_AID_2) << BIT_SHIFT_PS_AID_2)
#define BITS_PS_AID_2 (BIT_MASK_PS_AID_2 << BIT_SHIFT_PS_AID_2)
#define BIT_CLEAR_PS_AID_2(x) ((x) & (~BITS_PS_AID_2))
#define BIT_GET_PS_AID_2(x) (((x) >> BIT_SHIFT_PS_AID_2) & BIT_MASK_PS_AID_2)
#define BIT_SET_PS_AID_2(x, v) (BIT_CLEAR_PS_AID_2(x) | BIT_PS_AID_2(v))
/* 2 REG_BCN_PSR_RPT3 (Offset 0x1604) */
#define BIT_SHIFT_DTIM_CNT3 24
#define BIT_MASK_DTIM_CNT3 0xff
#define BIT_DTIM_CNT3(x) (((x) & BIT_MASK_DTIM_CNT3) << BIT_SHIFT_DTIM_CNT3)
#define BITS_DTIM_CNT3 (BIT_MASK_DTIM_CNT3 << BIT_SHIFT_DTIM_CNT3)
#define BIT_CLEAR_DTIM_CNT3(x) ((x) & (~BITS_DTIM_CNT3))
#define BIT_GET_DTIM_CNT3(x) (((x) >> BIT_SHIFT_DTIM_CNT3) & BIT_MASK_DTIM_CNT3)
#define BIT_SET_DTIM_CNT3(x, v) (BIT_CLEAR_DTIM_CNT3(x) | BIT_DTIM_CNT3(v))
#define BIT_SHIFT_DTIM_PERIOD3 16
#define BIT_MASK_DTIM_PERIOD3 0xff
#define BIT_DTIM_PERIOD3(x) \
(((x) & BIT_MASK_DTIM_PERIOD3) << BIT_SHIFT_DTIM_PERIOD3)
#define BITS_DTIM_PERIOD3 (BIT_MASK_DTIM_PERIOD3 << BIT_SHIFT_DTIM_PERIOD3)
#define BIT_CLEAR_DTIM_PERIOD3(x) ((x) & (~BITS_DTIM_PERIOD3))
#define BIT_GET_DTIM_PERIOD3(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD3) & BIT_MASK_DTIM_PERIOD3)
#define BIT_SET_DTIM_PERIOD3(x, v) \
(BIT_CLEAR_DTIM_PERIOD3(x) | BIT_DTIM_PERIOD3(v))
#define BIT_DTIM3 BIT(15)
#define BIT_TIM3 BIT(14)
#define BIT_SHIFT_PS_AID_3 0
#define BIT_MASK_PS_AID_3 0x7ff
#define BIT_PS_AID_3(x) (((x) & BIT_MASK_PS_AID_3) << BIT_SHIFT_PS_AID_3)
#define BITS_PS_AID_3 (BIT_MASK_PS_AID_3 << BIT_SHIFT_PS_AID_3)
#define BIT_CLEAR_PS_AID_3(x) ((x) & (~BITS_PS_AID_3))
#define BIT_GET_PS_AID_3(x) (((x) >> BIT_SHIFT_PS_AID_3) & BIT_MASK_PS_AID_3)
#define BIT_SET_PS_AID_3(x, v) (BIT_CLEAR_PS_AID_3(x) | BIT_PS_AID_3(v))
/* 2 REG_BCN_PSR_RPT4 (Offset 0x1608) */
#define BIT_SHIFT_DTIM_CNT4 24
#define BIT_MASK_DTIM_CNT4 0xff
#define BIT_DTIM_CNT4(x) (((x) & BIT_MASK_DTIM_CNT4) << BIT_SHIFT_DTIM_CNT4)
#define BITS_DTIM_CNT4 (BIT_MASK_DTIM_CNT4 << BIT_SHIFT_DTIM_CNT4)
#define BIT_CLEAR_DTIM_CNT4(x) ((x) & (~BITS_DTIM_CNT4))
#define BIT_GET_DTIM_CNT4(x) (((x) >> BIT_SHIFT_DTIM_CNT4) & BIT_MASK_DTIM_CNT4)
#define BIT_SET_DTIM_CNT4(x, v) (BIT_CLEAR_DTIM_CNT4(x) | BIT_DTIM_CNT4(v))
#define BIT_SHIFT_DTIM_PERIOD4 16
#define BIT_MASK_DTIM_PERIOD4 0xff
#define BIT_DTIM_PERIOD4(x) \
(((x) & BIT_MASK_DTIM_PERIOD4) << BIT_SHIFT_DTIM_PERIOD4)
#define BITS_DTIM_PERIOD4 (BIT_MASK_DTIM_PERIOD4 << BIT_SHIFT_DTIM_PERIOD4)
#define BIT_CLEAR_DTIM_PERIOD4(x) ((x) & (~BITS_DTIM_PERIOD4))
#define BIT_GET_DTIM_PERIOD4(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD4) & BIT_MASK_DTIM_PERIOD4)
#define BIT_SET_DTIM_PERIOD4(x, v) \
(BIT_CLEAR_DTIM_PERIOD4(x) | BIT_DTIM_PERIOD4(v))
#define BIT_DTIM4 BIT(15)
#define BIT_TIM4 BIT(14)
#define BIT_SHIFT_PS_AID_4 0
#define BIT_MASK_PS_AID_4 0x7ff
#define BIT_PS_AID_4(x) (((x) & BIT_MASK_PS_AID_4) << BIT_SHIFT_PS_AID_4)
#define BITS_PS_AID_4 (BIT_MASK_PS_AID_4 << BIT_SHIFT_PS_AID_4)
#define BIT_CLEAR_PS_AID_4(x) ((x) & (~BITS_PS_AID_4))
#define BIT_GET_PS_AID_4(x) (((x) >> BIT_SHIFT_PS_AID_4) & BIT_MASK_PS_AID_4)
#define BIT_SET_PS_AID_4(x, v) (BIT_CLEAR_PS_AID_4(x) | BIT_PS_AID_4(v))
/* 2 REG_A1_ADDR_MASK (Offset 0x160C) */
#define BIT_SHIFT_A1_ADDR_MASK 0
#define BIT_MASK_A1_ADDR_MASK 0xffffffffL
#define BIT_A1_ADDR_MASK(x) \
(((x) & BIT_MASK_A1_ADDR_MASK) << BIT_SHIFT_A1_ADDR_MASK)
#define BITS_A1_ADDR_MASK (BIT_MASK_A1_ADDR_MASK << BIT_SHIFT_A1_ADDR_MASK)
#define BIT_CLEAR_A1_ADDR_MASK(x) ((x) & (~BITS_A1_ADDR_MASK))
#define BIT_GET_A1_ADDR_MASK(x) \
(((x) >> BIT_SHIFT_A1_ADDR_MASK) & BIT_MASK_A1_ADDR_MASK)
#define BIT_SET_A1_ADDR_MASK(x, v) \
(BIT_CLEAR_A1_ADDR_MASK(x) | BIT_A1_ADDR_MASK(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_RXPSF_CTRL (Offset 0x1610) */
#define BIT_RXGCK_FIFOTHR_EN BIT(28)
#define BIT_SHIFT_RXGCK_VHT_FIFOTHR 26
#define BIT_MASK_RXGCK_VHT_FIFOTHR 0x3
#define BIT_RXGCK_VHT_FIFOTHR(x) \
(((x) & BIT_MASK_RXGCK_VHT_FIFOTHR) << BIT_SHIFT_RXGCK_VHT_FIFOTHR)
#define BITS_RXGCK_VHT_FIFOTHR \
(BIT_MASK_RXGCK_VHT_FIFOTHR << BIT_SHIFT_RXGCK_VHT_FIFOTHR)
#define BIT_CLEAR_RXGCK_VHT_FIFOTHR(x) ((x) & (~BITS_RXGCK_VHT_FIFOTHR))
#define BIT_GET_RXGCK_VHT_FIFOTHR(x) \
(((x) >> BIT_SHIFT_RXGCK_VHT_FIFOTHR) & BIT_MASK_RXGCK_VHT_FIFOTHR)
#define BIT_SET_RXGCK_VHT_FIFOTHR(x, v) \
(BIT_CLEAR_RXGCK_VHT_FIFOTHR(x) | BIT_RXGCK_VHT_FIFOTHR(v))
#define BIT_SHIFT_RXGCK_HT_FIFOTHR 24
#define BIT_MASK_RXGCK_HT_FIFOTHR 0x3
#define BIT_RXGCK_HT_FIFOTHR(x) \
(((x) & BIT_MASK_RXGCK_HT_FIFOTHR) << BIT_SHIFT_RXGCK_HT_FIFOTHR)
#define BITS_RXGCK_HT_FIFOTHR \
(BIT_MASK_RXGCK_HT_FIFOTHR << BIT_SHIFT_RXGCK_HT_FIFOTHR)
#define BIT_CLEAR_RXGCK_HT_FIFOTHR(x) ((x) & (~BITS_RXGCK_HT_FIFOTHR))
#define BIT_GET_RXGCK_HT_FIFOTHR(x) \
(((x) >> BIT_SHIFT_RXGCK_HT_FIFOTHR) & BIT_MASK_RXGCK_HT_FIFOTHR)
#define BIT_SET_RXGCK_HT_FIFOTHR(x, v) \
(BIT_CLEAR_RXGCK_HT_FIFOTHR(x) | BIT_RXGCK_HT_FIFOTHR(v))
#define BIT_SHIFT_RXGCK_OFDM_FIFOTHR 22
#define BIT_MASK_RXGCK_OFDM_FIFOTHR 0x3
#define BIT_RXGCK_OFDM_FIFOTHR(x) \
(((x) & BIT_MASK_RXGCK_OFDM_FIFOTHR) << BIT_SHIFT_RXGCK_OFDM_FIFOTHR)
#define BITS_RXGCK_OFDM_FIFOTHR \
(BIT_MASK_RXGCK_OFDM_FIFOTHR << BIT_SHIFT_RXGCK_OFDM_FIFOTHR)
#define BIT_CLEAR_RXGCK_OFDM_FIFOTHR(x) ((x) & (~BITS_RXGCK_OFDM_FIFOTHR))
#define BIT_GET_RXGCK_OFDM_FIFOTHR(x) \
(((x) >> BIT_SHIFT_RXGCK_OFDM_FIFOTHR) & BIT_MASK_RXGCK_OFDM_FIFOTHR)
#define BIT_SET_RXGCK_OFDM_FIFOTHR(x, v) \
(BIT_CLEAR_RXGCK_OFDM_FIFOTHR(x) | BIT_RXGCK_OFDM_FIFOTHR(v))
#define BIT_SHIFT_RXGCK_CCK_FIFOTHR 20
#define BIT_MASK_RXGCK_CCK_FIFOTHR 0x3
#define BIT_RXGCK_CCK_FIFOTHR(x) \
(((x) & BIT_MASK_RXGCK_CCK_FIFOTHR) << BIT_SHIFT_RXGCK_CCK_FIFOTHR)
#define BITS_RXGCK_CCK_FIFOTHR \
(BIT_MASK_RXGCK_CCK_FIFOTHR << BIT_SHIFT_RXGCK_CCK_FIFOTHR)
#define BIT_CLEAR_RXGCK_CCK_FIFOTHR(x) ((x) & (~BITS_RXGCK_CCK_FIFOTHR))
#define BIT_GET_RXGCK_CCK_FIFOTHR(x) \
(((x) >> BIT_SHIFT_RXGCK_CCK_FIFOTHR) & BIT_MASK_RXGCK_CCK_FIFOTHR)
#define BIT_SET_RXGCK_CCK_FIFOTHR(x, v) \
(BIT_CLEAR_RXGCK_CCK_FIFOTHR(x) | BIT_RXGCK_CCK_FIFOTHR(v))
#define BIT_SHIFT_RXGCK_ENTRY_DELAY 17
#define BIT_MASK_RXGCK_ENTRY_DELAY 0x7
#define BIT_RXGCK_ENTRY_DELAY(x) \
(((x) & BIT_MASK_RXGCK_ENTRY_DELAY) << BIT_SHIFT_RXGCK_ENTRY_DELAY)
#define BITS_RXGCK_ENTRY_DELAY \
(BIT_MASK_RXGCK_ENTRY_DELAY << BIT_SHIFT_RXGCK_ENTRY_DELAY)
#define BIT_CLEAR_RXGCK_ENTRY_DELAY(x) ((x) & (~BITS_RXGCK_ENTRY_DELAY))
#define BIT_GET_RXGCK_ENTRY_DELAY(x) \
(((x) >> BIT_SHIFT_RXGCK_ENTRY_DELAY) & BIT_MASK_RXGCK_ENTRY_DELAY)
#define BIT_SET_RXGCK_ENTRY_DELAY(x, v) \
(BIT_CLEAR_RXGCK_ENTRY_DELAY(x) | BIT_RXGCK_ENTRY_DELAY(v))
#define BIT_RXGCK_OFDMCCA_EN BIT(16)
#define BIT_SHIFT_RXPSF_PKTLENTHR 13
#define BIT_MASK_RXPSF_PKTLENTHR 0x7
#define BIT_RXPSF_PKTLENTHR(x) \
(((x) & BIT_MASK_RXPSF_PKTLENTHR) << BIT_SHIFT_RXPSF_PKTLENTHR)
#define BITS_RXPSF_PKTLENTHR \
(BIT_MASK_RXPSF_PKTLENTHR << BIT_SHIFT_RXPSF_PKTLENTHR)
#define BIT_CLEAR_RXPSF_PKTLENTHR(x) ((x) & (~BITS_RXPSF_PKTLENTHR))
#define BIT_GET_RXPSF_PKTLENTHR(x) \
(((x) >> BIT_SHIFT_RXPSF_PKTLENTHR) & BIT_MASK_RXPSF_PKTLENTHR)
#define BIT_SET_RXPSF_PKTLENTHR(x, v) \
(BIT_CLEAR_RXPSF_PKTLENTHR(x) | BIT_RXPSF_PKTLENTHR(v))
#define BIT_RXPSF_CTRLEN BIT(12)
#define BIT_RXPSF_VHTCHKEN BIT(11)
#define BIT_RXPSF_HTCHKEN BIT(10)
#define BIT_RXPSF_OFDMCHKEN BIT(9)
#define BIT_RXPSF_CCKCHKEN BIT(8)
#define BIT_RXPSF_OFDMRST BIT(7)
#define BIT_RXPSF_CCKRST BIT(6)
#define BIT_RXPSF_MHCHKEN BIT(5)
#define BIT_RXPSF_CONT_ERRCHKEN BIT(4)
#define BIT_RXPSF_ALL_ERRCHKEN BIT(3)
#define BIT_SHIFT_RXPSF_ERRTHR 0
#define BIT_MASK_RXPSF_ERRTHR 0x7
#define BIT_RXPSF_ERRTHR(x) \
(((x) & BIT_MASK_RXPSF_ERRTHR) << BIT_SHIFT_RXPSF_ERRTHR)
#define BITS_RXPSF_ERRTHR (BIT_MASK_RXPSF_ERRTHR << BIT_SHIFT_RXPSF_ERRTHR)
#define BIT_CLEAR_RXPSF_ERRTHR(x) ((x) & (~BITS_RXPSF_ERRTHR))
#define BIT_GET_RXPSF_ERRTHR(x) \
(((x) >> BIT_SHIFT_RXPSF_ERRTHR) & BIT_MASK_RXPSF_ERRTHR)
#define BIT_SET_RXPSF_ERRTHR(x, v) \
(BIT_CLEAR_RXPSF_ERRTHR(x) | BIT_RXPSF_ERRTHR(v))
/* 2 REG_RXPSF_TYPE_CTRL (Offset 0x1614) */
#define BIT_RXPSF_DATA15EN BIT(31)
#define BIT_RXPSF_DATA14EN BIT(30)
#define BIT_RXPSF_DATA13EN BIT(29)
#define BIT_RXPSF_DATA12EN BIT(28)
#define BIT_RXPSF_DATA11EN BIT(27)
#define BIT_RXPSF_DATA10EN BIT(26)
#define BIT_RXPSF_DATA9EN BIT(25)
#define BIT_RXPSF_DATA8EN BIT(24)
#define BIT_RXPSF_DATA7EN BIT(23)
#define BIT_RXPSF_DATA6EN BIT(22)
#define BIT_RXPSF_DATA5EN BIT(21)
#define BIT_RXPSF_DATA4EN BIT(20)
#define BIT_RXPSF_DATA3EN BIT(19)
#define BIT_RXPSF_DATA2EN BIT(18)
#define BIT_RXPSF_DATA1EN BIT(17)
#define BIT_RXPSF_DATA0EN BIT(16)
#define BIT_RXPSF_MGT15EN BIT(15)
#define BIT_RXPSF_MGT14EN BIT(14)
#define BIT_RXPSF_MGT13EN BIT(13)
#define BIT_RXPSF_MGT12EN BIT(12)
#define BIT_RXPSF_MGT11EN BIT(11)
#define BIT_RXPSF_MGT10EN BIT(10)
#define BIT_RXPSF_MGT9EN BIT(9)
#define BIT_RXPSF_MGT8EN BIT(8)
#define BIT_RXPSF_MGT7EN BIT(7)
#define BIT_RXPSF_MGT6EN BIT(6)
#define BIT_RXPSF_MGT5EN BIT(5)
#define BIT_RXPSF_MGT4EN BIT(4)
#define BIT_RXPSF_MGT3EN BIT(3)
#define BIT_RXPSF_MGT2EN BIT(2)
#define BIT_RXPSF_MGT1EN BIT(1)
#define BIT_RXPSF_MGT0EN BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CAM_ACCESS_CTRL (Offset 0x1618) */
#define BIT_INDIRECT_ERR BIT(6)
#define BIT_DIRECT_ERR BIT(5)
#define BIT_DIR_ACCESS_EN_RX_BA BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CAM_ACCESS_CTRL (Offset 0x1618) */
#define BIT_DIR_ACCESS_EN_MBSSIDCAM BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CAM_ACCESS_CTRL (Offset 0x1618) */
#define BIT_DIR_ACCESS_EN_ADDRCAM BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_CAM_ACCESS_CTRL (Offset 0x1618) */
#define BIT_DIR_ACCESS_EN_KEY BIT(2)
#define BIT_DIR_ACCESS_EN_WOWLAN BIT(1)
#define BIT_DIR_ACCESS_EN_FW_FILTER BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CUT_AMSDU_CTRL (Offset 0x161C) */
#define BIT__CUT_AMSDU_CHKLEN_EN BIT(31)
#define BIT_EN_CUT_AMSDU BIT(30)
#define BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH 16
#define BIT_MASK_CUT_AMSDU_CHKLEN_L_TH 0xff
#define BIT_CUT_AMSDU_CHKLEN_L_TH(x) \
(((x) & BIT_MASK_CUT_AMSDU_CHKLEN_L_TH) \
<< BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH)
#define BITS_CUT_AMSDU_CHKLEN_L_TH \
(BIT_MASK_CUT_AMSDU_CHKLEN_L_TH << BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH)
#define BIT_CLEAR_CUT_AMSDU_CHKLEN_L_TH(x) ((x) & (~BITS_CUT_AMSDU_CHKLEN_L_TH))
#define BIT_GET_CUT_AMSDU_CHKLEN_L_TH(x) \
(((x) >> BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH) & \
BIT_MASK_CUT_AMSDU_CHKLEN_L_TH)
#define BIT_SET_CUT_AMSDU_CHKLEN_L_TH(x, v) \
(BIT_CLEAR_CUT_AMSDU_CHKLEN_L_TH(x) | BIT_CUT_AMSDU_CHKLEN_L_TH(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_HT_SND_REF_RATE (Offset 0x161C) */
#define BIT_SHIFT_WMAC_HT_CSI_RATE 0
#define BIT_MASK_WMAC_HT_CSI_RATE 0x3f
#define BIT_WMAC_HT_CSI_RATE(x) \
(((x) & BIT_MASK_WMAC_HT_CSI_RATE) << BIT_SHIFT_WMAC_HT_CSI_RATE)
#define BITS_WMAC_HT_CSI_RATE \
(BIT_MASK_WMAC_HT_CSI_RATE << BIT_SHIFT_WMAC_HT_CSI_RATE)
#define BIT_CLEAR_WMAC_HT_CSI_RATE(x) ((x) & (~BITS_WMAC_HT_CSI_RATE))
#define BIT_GET_WMAC_HT_CSI_RATE(x) \
(((x) >> BIT_SHIFT_WMAC_HT_CSI_RATE) & BIT_MASK_WMAC_HT_CSI_RATE)
#define BIT_SET_WMAC_HT_CSI_RATE(x, v) \
(BIT_CLEAR_WMAC_HT_CSI_RATE(x) | BIT_WMAC_HT_CSI_RATE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_CUT_AMSDU_CTRL (Offset 0x161C) */
#define BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH 0
#define BIT_MASK_CUT_AMSDU_CHKLEN_H_TH 0xffff
#define BIT_CUT_AMSDU_CHKLEN_H_TH(x) \
(((x) & BIT_MASK_CUT_AMSDU_CHKLEN_H_TH) \
<< BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH)
#define BITS_CUT_AMSDU_CHKLEN_H_TH \
(BIT_MASK_CUT_AMSDU_CHKLEN_H_TH << BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH)
#define BIT_CLEAR_CUT_AMSDU_CHKLEN_H_TH(x) ((x) & (~BITS_CUT_AMSDU_CHKLEN_H_TH))
#define BIT_GET_CUT_AMSDU_CHKLEN_H_TH(x) \
(((x) >> BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH) & \
BIT_MASK_CUT_AMSDU_CHKLEN_H_TH)
#define BIT_SET_CUT_AMSDU_CHKLEN_H_TH(x, v) \
(BIT_CLEAR_CUT_AMSDU_CHKLEN_H_TH(x) | BIT_CUT_AMSDU_CHKLEN_H_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MACID2 (Offset 0x1620) */
#define BIT_SHIFT_MACID2 0
#define BIT_MASK_MACID2 0xffffffffffffL
#define BIT_MACID2(x) (((x) & BIT_MASK_MACID2) << BIT_SHIFT_MACID2)
#define BITS_MACID2 (BIT_MASK_MACID2 << BIT_SHIFT_MACID2)
#define BIT_CLEAR_MACID2(x) ((x) & (~BITS_MACID2))
#define BIT_GET_MACID2(x) (((x) >> BIT_SHIFT_MACID2) & BIT_MASK_MACID2)
#define BIT_SET_MACID2(x, v) (BIT_CLEAR_MACID2(x) | BIT_MACID2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID2 (Offset 0x1620) */
#define BIT_SHIFT_MACID2_V1 0
#define BIT_MASK_MACID2_V1 0xffffffffL
#define BIT_MACID2_V1(x) (((x) & BIT_MASK_MACID2_V1) << BIT_SHIFT_MACID2_V1)
#define BITS_MACID2_V1 (BIT_MASK_MACID2_V1 << BIT_SHIFT_MACID2_V1)
#define BIT_CLEAR_MACID2_V1(x) ((x) & (~BITS_MACID2_V1))
#define BIT_GET_MACID2_V1(x) (((x) >> BIT_SHIFT_MACID2_V1) & BIT_MASK_MACID2_V1)
#define BIT_SET_MACID2_V1(x, v) (BIT_CLEAR_MACID2_V1(x) | BIT_MACID2_V1(v))
/* 2 REG_MACID2_H (Offset 0x1624) */
#define BIT_SHIFT_MACID2_H_V1 0
#define BIT_MASK_MACID2_H_V1 0xffff
#define BIT_MACID2_H_V1(x) \
(((x) & BIT_MASK_MACID2_H_V1) << BIT_SHIFT_MACID2_H_V1)
#define BITS_MACID2_H_V1 (BIT_MASK_MACID2_H_V1 << BIT_SHIFT_MACID2_H_V1)
#define BIT_CLEAR_MACID2_H_V1(x) ((x) & (~BITS_MACID2_H_V1))
#define BIT_GET_MACID2_H_V1(x) \
(((x) >> BIT_SHIFT_MACID2_H_V1) & BIT_MASK_MACID2_H_V1)
#define BIT_SET_MACID2_H_V1(x, v) \
(BIT_CLEAR_MACID2_H_V1(x) | BIT_MACID2_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BSSID2 (Offset 0x1628) */
#define BIT_SHIFT_BSSID2 0
#define BIT_MASK_BSSID2 0xffffffffffffL
#define BIT_BSSID2(x) (((x) & BIT_MASK_BSSID2) << BIT_SHIFT_BSSID2)
#define BITS_BSSID2 (BIT_MASK_BSSID2 << BIT_SHIFT_BSSID2)
#define BIT_CLEAR_BSSID2(x) ((x) & (~BITS_BSSID2))
#define BIT_GET_BSSID2(x) (((x) >> BIT_SHIFT_BSSID2) & BIT_MASK_BSSID2)
#define BIT_SET_BSSID2(x, v) (BIT_CLEAR_BSSID2(x) | BIT_BSSID2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BSSID2 (Offset 0x1628) */
#define BIT_SHIFT_BSSID2_V1 0
#define BIT_MASK_BSSID2_V1 0xffffffffL
#define BIT_BSSID2_V1(x) (((x) & BIT_MASK_BSSID2_V1) << BIT_SHIFT_BSSID2_V1)
#define BITS_BSSID2_V1 (BIT_MASK_BSSID2_V1 << BIT_SHIFT_BSSID2_V1)
#define BIT_CLEAR_BSSID2_V1(x) ((x) & (~BITS_BSSID2_V1))
#define BIT_GET_BSSID2_V1(x) (((x) >> BIT_SHIFT_BSSID2_V1) & BIT_MASK_BSSID2_V1)
#define BIT_SET_BSSID2_V1(x, v) (BIT_CLEAR_BSSID2_V1(x) | BIT_BSSID2_V1(v))
/* 2 REG_BSSID2_H (Offset 0x162C) */
#define BIT_SHIFT_BSSID2_H_V1 0
#define BIT_MASK_BSSID2_H_V1 0xffff
#define BIT_BSSID2_H_V1(x) \
(((x) & BIT_MASK_BSSID2_H_V1) << BIT_SHIFT_BSSID2_H_V1)
#define BITS_BSSID2_H_V1 (BIT_MASK_BSSID2_H_V1 << BIT_SHIFT_BSSID2_H_V1)
#define BIT_CLEAR_BSSID2_H_V1(x) ((x) & (~BITS_BSSID2_H_V1))
#define BIT_GET_BSSID2_H_V1(x) \
(((x) >> BIT_SHIFT_BSSID2_H_V1) & BIT_MASK_BSSID2_H_V1)
#define BIT_SET_BSSID2_H_V1(x, v) \
(BIT_CLEAR_BSSID2_H_V1(x) | BIT_BSSID2_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MACID3 (Offset 0x1630) */
#define BIT_SHIFT_MACID3 0
#define BIT_MASK_MACID3 0xffffffffffffL
#define BIT_MACID3(x) (((x) & BIT_MASK_MACID3) << BIT_SHIFT_MACID3)
#define BITS_MACID3 (BIT_MASK_MACID3 << BIT_SHIFT_MACID3)
#define BIT_CLEAR_MACID3(x) ((x) & (~BITS_MACID3))
#define BIT_GET_MACID3(x) (((x) >> BIT_SHIFT_MACID3) & BIT_MASK_MACID3)
#define BIT_SET_MACID3(x, v) (BIT_CLEAR_MACID3(x) | BIT_MACID3(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID3 (Offset 0x1630) */
#define BIT_SHIFT_MACID3_V1 0
#define BIT_MASK_MACID3_V1 0xffffffffL
#define BIT_MACID3_V1(x) (((x) & BIT_MASK_MACID3_V1) << BIT_SHIFT_MACID3_V1)
#define BITS_MACID3_V1 (BIT_MASK_MACID3_V1 << BIT_SHIFT_MACID3_V1)
#define BIT_CLEAR_MACID3_V1(x) ((x) & (~BITS_MACID3_V1))
#define BIT_GET_MACID3_V1(x) (((x) >> BIT_SHIFT_MACID3_V1) & BIT_MASK_MACID3_V1)
#define BIT_SET_MACID3_V1(x, v) (BIT_CLEAR_MACID3_V1(x) | BIT_MACID3_V1(v))
/* 2 REG_MACID3_H (Offset 0x1634) */
#define BIT_SHIFT_MACID3_H_V1 0
#define BIT_MASK_MACID3_H_V1 0xffff
#define BIT_MACID3_H_V1(x) \
(((x) & BIT_MASK_MACID3_H_V1) << BIT_SHIFT_MACID3_H_V1)
#define BITS_MACID3_H_V1 (BIT_MASK_MACID3_H_V1 << BIT_SHIFT_MACID3_H_V1)
#define BIT_CLEAR_MACID3_H_V1(x) ((x) & (~BITS_MACID3_H_V1))
#define BIT_GET_MACID3_H_V1(x) \
(((x) >> BIT_SHIFT_MACID3_H_V1) & BIT_MASK_MACID3_H_V1)
#define BIT_SET_MACID3_H_V1(x, v) \
(BIT_CLEAR_MACID3_H_V1(x) | BIT_MACID3_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BSSID3 (Offset 0x1638) */
#define BIT_SHIFT_BSSID3 0
#define BIT_MASK_BSSID3 0xffffffffffffL
#define BIT_BSSID3(x) (((x) & BIT_MASK_BSSID3) << BIT_SHIFT_BSSID3)
#define BITS_BSSID3 (BIT_MASK_BSSID3 << BIT_SHIFT_BSSID3)
#define BIT_CLEAR_BSSID3(x) ((x) & (~BITS_BSSID3))
#define BIT_GET_BSSID3(x) (((x) >> BIT_SHIFT_BSSID3) & BIT_MASK_BSSID3)
#define BIT_SET_BSSID3(x, v) (BIT_CLEAR_BSSID3(x) | BIT_BSSID3(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BSSID3 (Offset 0x1638) */
#define BIT_SHIFT_BSSID3_V1 0
#define BIT_MASK_BSSID3_V1 0xffffffffL
#define BIT_BSSID3_V1(x) (((x) & BIT_MASK_BSSID3_V1) << BIT_SHIFT_BSSID3_V1)
#define BITS_BSSID3_V1 (BIT_MASK_BSSID3_V1 << BIT_SHIFT_BSSID3_V1)
#define BIT_CLEAR_BSSID3_V1(x) ((x) & (~BITS_BSSID3_V1))
#define BIT_GET_BSSID3_V1(x) (((x) >> BIT_SHIFT_BSSID3_V1) & BIT_MASK_BSSID3_V1)
#define BIT_SET_BSSID3_V1(x, v) (BIT_CLEAR_BSSID3_V1(x) | BIT_BSSID3_V1(v))
/* 2 REG_BSSID3_H (Offset 0x163C) */
#define BIT_SHIFT_BSSID3_H_V1 0
#define BIT_MASK_BSSID3_H_V1 0xffff
#define BIT_BSSID3_H_V1(x) \
(((x) & BIT_MASK_BSSID3_H_V1) << BIT_SHIFT_BSSID3_H_V1)
#define BITS_BSSID3_H_V1 (BIT_MASK_BSSID3_H_V1 << BIT_SHIFT_BSSID3_H_V1)
#define BIT_CLEAR_BSSID3_H_V1(x) ((x) & (~BITS_BSSID3_H_V1))
#define BIT_GET_BSSID3_H_V1(x) \
(((x) >> BIT_SHIFT_BSSID3_H_V1) & BIT_MASK_BSSID3_H_V1)
#define BIT_SET_BSSID3_H_V1(x, v) \
(BIT_CLEAR_BSSID3_H_V1(x) | BIT_BSSID3_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_MACID4 (Offset 0x1640) */
#define BIT_SHIFT_MACID4 0
#define BIT_MASK_MACID4 0xffffffffffffL
#define BIT_MACID4(x) (((x) & BIT_MASK_MACID4) << BIT_SHIFT_MACID4)
#define BITS_MACID4 (BIT_MASK_MACID4 << BIT_SHIFT_MACID4)
#define BIT_CLEAR_MACID4(x) ((x) & (~BITS_MACID4))
#define BIT_GET_MACID4(x) (((x) >> BIT_SHIFT_MACID4) & BIT_MASK_MACID4)
#define BIT_SET_MACID4(x, v) (BIT_CLEAR_MACID4(x) | BIT_MACID4(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MACID4 (Offset 0x1640) */
#define BIT_SHIFT_MACID4_V1 0
#define BIT_MASK_MACID4_V1 0xffffffffL
#define BIT_MACID4_V1(x) (((x) & BIT_MASK_MACID4_V1) << BIT_SHIFT_MACID4_V1)
#define BITS_MACID4_V1 (BIT_MASK_MACID4_V1 << BIT_SHIFT_MACID4_V1)
#define BIT_CLEAR_MACID4_V1(x) ((x) & (~BITS_MACID4_V1))
#define BIT_GET_MACID4_V1(x) (((x) >> BIT_SHIFT_MACID4_V1) & BIT_MASK_MACID4_V1)
#define BIT_SET_MACID4_V1(x, v) (BIT_CLEAR_MACID4_V1(x) | BIT_MACID4_V1(v))
/* 2 REG_MACID4_H (Offset 0x1644) */
#define BIT_SHIFT_MACID4_H_V1 0
#define BIT_MASK_MACID4_H_V1 0xffff
#define BIT_MACID4_H_V1(x) \
(((x) & BIT_MASK_MACID4_H_V1) << BIT_SHIFT_MACID4_H_V1)
#define BITS_MACID4_H_V1 (BIT_MASK_MACID4_H_V1 << BIT_SHIFT_MACID4_H_V1)
#define BIT_CLEAR_MACID4_H_V1(x) ((x) & (~BITS_MACID4_H_V1))
#define BIT_GET_MACID4_H_V1(x) \
(((x) >> BIT_SHIFT_MACID4_H_V1) & BIT_MASK_MACID4_H_V1)
#define BIT_SET_MACID4_H_V1(x, v) \
(BIT_CLEAR_MACID4_H_V1(x) | BIT_MACID4_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_BSSID4 (Offset 0x1648) */
#define BIT_SHIFT_BSSID4 0
#define BIT_MASK_BSSID4 0xffffffffffffL
#define BIT_BSSID4(x) (((x) & BIT_MASK_BSSID4) << BIT_SHIFT_BSSID4)
#define BITS_BSSID4 (BIT_MASK_BSSID4 << BIT_SHIFT_BSSID4)
#define BIT_CLEAR_BSSID4(x) ((x) & (~BITS_BSSID4))
#define BIT_GET_BSSID4(x) (((x) >> BIT_SHIFT_BSSID4) & BIT_MASK_BSSID4)
#define BIT_SET_BSSID4(x, v) (BIT_CLEAR_BSSID4(x) | BIT_BSSID4(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_BSSID4 (Offset 0x1648) */
#define BIT_SHIFT_BSSID4_V1 0
#define BIT_MASK_BSSID4_V1 0xffffffffL
#define BIT_BSSID4_V1(x) (((x) & BIT_MASK_BSSID4_V1) << BIT_SHIFT_BSSID4_V1)
#define BITS_BSSID4_V1 (BIT_MASK_BSSID4_V1 << BIT_SHIFT_BSSID4_V1)
#define BIT_CLEAR_BSSID4_V1(x) ((x) & (~BITS_BSSID4_V1))
#define BIT_GET_BSSID4_V1(x) (((x) >> BIT_SHIFT_BSSID4_V1) & BIT_MASK_BSSID4_V1)
#define BIT_SET_BSSID4_V1(x, v) (BIT_CLEAR_BSSID4_V1(x) | BIT_BSSID4_V1(v))
/* 2 REG_BSSID4_H (Offset 0x164C) */
#define BIT_SHIFT_BSSID4_H_V1 0
#define BIT_MASK_BSSID4_H_V1 0xffff
#define BIT_BSSID4_H_V1(x) \
(((x) & BIT_MASK_BSSID4_H_V1) << BIT_SHIFT_BSSID4_H_V1)
#define BITS_BSSID4_H_V1 (BIT_MASK_BSSID4_H_V1 << BIT_SHIFT_BSSID4_H_V1)
#define BIT_CLEAR_BSSID4_H_V1(x) ((x) & (~BITS_BSSID4_H_V1))
#define BIT_GET_BSSID4_H_V1(x) \
(((x) >> BIT_SHIFT_BSSID4_H_V1) & BIT_MASK_BSSID4_H_V1)
#define BIT_SET_BSSID4_H_V1(x, v) \
(BIT_CLEAR_BSSID4_H_V1(x) | BIT_BSSID4_H_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_NOA_REPORT (Offset 0x1650) */
#define BIT_SHIFT_NOA_RPT 0
#define BIT_MASK_NOA_RPT 0xffffffffL
#define BIT_NOA_RPT(x) (((x) & BIT_MASK_NOA_RPT) << BIT_SHIFT_NOA_RPT)
#define BITS_NOA_RPT (BIT_MASK_NOA_RPT << BIT_SHIFT_NOA_RPT)
#define BIT_CLEAR_NOA_RPT(x) ((x) & (~BITS_NOA_RPT))
#define BIT_GET_NOA_RPT(x) (((x) >> BIT_SHIFT_NOA_RPT) & BIT_MASK_NOA_RPT)
#define BIT_SET_NOA_RPT(x, v) (BIT_CLEAR_NOA_RPT(x) | BIT_NOA_RPT(v))
/* 2 REG_NOA_REPORT_1 (Offset 0x1654) */
#define BIT_SHIFT_NOA_RPT_1 0
#define BIT_MASK_NOA_RPT_1 0xffffffffL
#define BIT_NOA_RPT_1(x) (((x) & BIT_MASK_NOA_RPT_1) << BIT_SHIFT_NOA_RPT_1)
#define BITS_NOA_RPT_1 (BIT_MASK_NOA_RPT_1 << BIT_SHIFT_NOA_RPT_1)
#define BIT_CLEAR_NOA_RPT_1(x) ((x) & (~BITS_NOA_RPT_1))
#define BIT_GET_NOA_RPT_1(x) (((x) >> BIT_SHIFT_NOA_RPT_1) & BIT_MASK_NOA_RPT_1)
#define BIT_SET_NOA_RPT_1(x, v) (BIT_CLEAR_NOA_RPT_1(x) | BIT_NOA_RPT_1(v))
/* 2 REG_NOA_REPORT_2 (Offset 0x1658) */
#define BIT_SHIFT_NOA_RPT_2 0
#define BIT_MASK_NOA_RPT_2 0xffffffffL
#define BIT_NOA_RPT_2(x) (((x) & BIT_MASK_NOA_RPT_2) << BIT_SHIFT_NOA_RPT_2)
#define BITS_NOA_RPT_2 (BIT_MASK_NOA_RPT_2 << BIT_SHIFT_NOA_RPT_2)
#define BIT_CLEAR_NOA_RPT_2(x) ((x) & (~BITS_NOA_RPT_2))
#define BIT_GET_NOA_RPT_2(x) (((x) >> BIT_SHIFT_NOA_RPT_2) & BIT_MASK_NOA_RPT_2)
#define BIT_SET_NOA_RPT_2(x, v) (BIT_CLEAR_NOA_RPT_2(x) | BIT_NOA_RPT_2(v))
/* 2 REG_NOA_REPORT_3 (Offset 0x165C) */
#define BIT_SHIFT_NOA_RPT_3 0
#define BIT_MASK_NOA_RPT_3 0xff
#define BIT_NOA_RPT_3(x) (((x) & BIT_MASK_NOA_RPT_3) << BIT_SHIFT_NOA_RPT_3)
#define BITS_NOA_RPT_3 (BIT_MASK_NOA_RPT_3 << BIT_SHIFT_NOA_RPT_3)
#define BIT_CLEAR_NOA_RPT_3(x) ((x) & (~BITS_NOA_RPT_3))
#define BIT_GET_NOA_RPT_3(x) (((x) >> BIT_SHIFT_NOA_RPT_3) & BIT_MASK_NOA_RPT_3)
#define BIT_SET_NOA_RPT_3(x, v) (BIT_CLEAR_NOA_RPT_3(x) | BIT_NOA_RPT_3(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI3_WMAC_TCRPWRMGT_HWCTL_EN BIT(15)
#define BIT_CLI3_WMAC_TCRPWRMGT_HWDATA_EN BIT(14)
#define BIT_CLI3_WMAC_TCRPWRMGT_HWACT_EN BIT(13)
#define BIT_CLI3_PWR_ST_V1 BIT(12)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWCTL_EN BIT(11)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWDATA_EN BIT(10)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWACT_EN BIT(9)
#define BIT_CLI2_PWR_ST_V1 BIT(8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI3_PWRBIT_OW_EN BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI1_WMAC_TCRPWRMGT_HWCTL_EN BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI3_PWR_ST BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI1_WMAC_TCRPWRMGT_HWDATA_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI2_PWRBIT_OW_EN BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI1_WMAC_TCRPWRMGT_HWACT_EN BIT(5)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI2_PWR_ST BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI1_PWR_ST_V1 BIT(4)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI1_PWRBIT_OW_EN BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI0_WMAC_TCRPWRMGT_HWCTL_EN BIT(3)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI1_PWR_ST BIT(2)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI0_WMAC_TCRPWRMGT_HWDATA_EN BIT(2)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI0_PWRBIT_OW_EN BIT(1)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI0_WMAC_TCRPWRMGT_HWACT_EN BIT(1)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI0_PWR_ST BIT(0)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PWRBIT_SETTING (Offset 0x1660) */
#define BIT_CLI0_PWR_ST_V1 BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_FIX_MSDU_TAIL_WR BIT(12)
#define BIT_FIX_MSDU_SHIFT BIT(11)
#endif
#if (HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_WMAC_RXRST_NDP_TIMEOUT BIT(11)
#define BIT_WMAC_NDP_STANDBY_WAIT_RXEND BIT(10)
#define BIT_DUMMY_FCS_READY_MASK_EN BIT(9)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_RXFIFO_GNT_CUT BIT(8)
#endif
#if (HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_DUMMY_RXD_FCS_ERROR_MASK_EN_V1 BIT(7)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_WMAC_EXT_DBG_SEL_V1 BIT(6)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_WMAC_FIX_FIRST_MPDU_WITH_PHYSTS BIT(5)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_RX_DMA_BYPASS_CHECK_DATABYPASS_CHECK_DATA BIT(4)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_DUMMY_RXD_FCS_ERROR_MASK_EN BIT(4)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_RX_DMA_BYPASS_CHECK_MGTBIT_RX_DMA_BYPASS_CHECK_MGT BIT(3)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_PATTERN_MATCH_FIX_EN BIT(3)
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_GENERAL_OPTION (Offset 0x1664) */
#define BIT_TXSERV_FIELD_SEL BIT(2)
#define BIT_RXVHT_LEN_SEL BIT(1)
#define BIT_RXMIC_PROTECT_EN BIT(0)
#define BIT_SHIFT_WMAC_MULBK_PAGE_SIZE 0
#define BIT_MASK_WMAC_MULBK_PAGE_SIZE 0xff
#define BIT_WMAC_MULBK_PAGE_SIZE(x) \
(((x) & BIT_MASK_WMAC_MULBK_PAGE_SIZE) \
<< BIT_SHIFT_WMAC_MULBK_PAGE_SIZE)
#define BITS_WMAC_MULBK_PAGE_SIZE \
(BIT_MASK_WMAC_MULBK_PAGE_SIZE << BIT_SHIFT_WMAC_MULBK_PAGE_SIZE)
#define BIT_CLEAR_WMAC_MULBK_PAGE_SIZE(x) ((x) & (~BITS_WMAC_MULBK_PAGE_SIZE))
#define BIT_GET_WMAC_MULBK_PAGE_SIZE(x) \
(((x) >> BIT_SHIFT_WMAC_MULBK_PAGE_SIZE) & \
BIT_MASK_WMAC_MULBK_PAGE_SIZE)
#define BIT_SET_WMAC_MULBK_PAGE_SIZE(x, v) \
(BIT_CLEAR_WMAC_MULBK_PAGE_SIZE(x) | BIT_WMAC_MULBK_PAGE_SIZE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_FWPHYFF_RCR (Offset 0x1668) */
#define BIT_RCR2_AAMSDU BIT(25)
#define BIT_RCR2_CBSSID_BCN BIT(24)
#define BIT_RCR2_ACRC32 BIT(23)
#define BIT_RCR2_TA_BCN BIT(22)
#define BIT_RCR2_CBSSID_DATA BIT(21)
#define BIT_RCR2_ADD3 BIT(20)
#define BIT_RCR2_AB BIT(19)
#define BIT_RCR2_AM BIT(18)
#define BIT_RCR2_APM BIT(17)
#define BIT_RCR2_AAP BIT(16)
#define BIT_RCR1_AAMSDU BIT(9)
#define BIT_RCR1_CBSSID_BCN BIT(8)
#define BIT_RCR1_ACRC32 BIT(7)
#define BIT_RCR1_TA_BCN BIT(6)
#define BIT_RCR1_CBSSID_DATA BIT(5)
#define BIT_RCR1_ADD3 BIT(4)
#define BIT_RCR1_AB BIT(3)
#define BIT_RCR1_AM BIT(2)
#define BIT_RCR1_APM BIT(1)
#define BIT_RCR1_AAP BIT(0)
/* 2 REG_ADDRCAM_WRITE_CONTENT (Offset 0x166C) */
#define BIT_SHIFT_ADDRCAM_WDATA 0
#define BIT_MASK_ADDRCAM_WDATA 0xffffffffL
#define BIT_ADDRCAM_WDATA(x) \
(((x) & BIT_MASK_ADDRCAM_WDATA) << BIT_SHIFT_ADDRCAM_WDATA)
#define BITS_ADDRCAM_WDATA (BIT_MASK_ADDRCAM_WDATA << BIT_SHIFT_ADDRCAM_WDATA)
#define BIT_CLEAR_ADDRCAM_WDATA(x) ((x) & (~BITS_ADDRCAM_WDATA))
#define BIT_GET_ADDRCAM_WDATA(x) \
(((x) >> BIT_SHIFT_ADDRCAM_WDATA) & BIT_MASK_ADDRCAM_WDATA)
#define BIT_SET_ADDRCAM_WDATA(x, v) \
(BIT_CLEAR_ADDRCAM_WDATA(x) | BIT_ADDRCAM_WDATA(v))
/* 2 REG_ADDRCAM_READ_CONTENT (Offset 0x1670) */
#define BIT_SHIFT_ADDRCAM_RDATA 0
#define BIT_MASK_ADDRCAM_RDATA 0xffffffffL
#define BIT_ADDRCAM_RDATA(x) \
(((x) & BIT_MASK_ADDRCAM_RDATA) << BIT_SHIFT_ADDRCAM_RDATA)
#define BITS_ADDRCAM_RDATA (BIT_MASK_ADDRCAM_RDATA << BIT_SHIFT_ADDRCAM_RDATA)
#define BIT_CLEAR_ADDRCAM_RDATA(x) ((x) & (~BITS_ADDRCAM_RDATA))
#define BIT_GET_ADDRCAM_RDATA(x) \
(((x) >> BIT_SHIFT_ADDRCAM_RDATA) & BIT_MASK_ADDRCAM_RDATA)
#define BIT_SET_ADDRCAM_RDATA(x, v) \
(BIT_CLEAR_ADDRCAM_RDATA(x) | BIT_ADDRCAM_RDATA(v))
/* 2 REG_ADDRCAM_CFG (Offset 0x1674) */
#define BIT_ADDRCAM_POLL BIT(31)
#define BIT__ADDRCAM_WT_EN BIT(30)
#define BIT_CLRADDRCAM BIT(29)
#define BIT_SHIFT__ADDRCAM_ADDR 8
#define BIT_MASK__ADDRCAM_ADDR 0x3ff
#define BIT__ADDRCAM_ADDR(x) \
(((x) & BIT_MASK__ADDRCAM_ADDR) << BIT_SHIFT__ADDRCAM_ADDR)
#define BITS__ADDRCAM_ADDR (BIT_MASK__ADDRCAM_ADDR << BIT_SHIFT__ADDRCAM_ADDR)
#define BIT_CLEAR__ADDRCAM_ADDR(x) ((x) & (~BITS__ADDRCAM_ADDR))
#define BIT_GET__ADDRCAM_ADDR(x) \
(((x) >> BIT_SHIFT__ADDRCAM_ADDR) & BIT_MASK__ADDRCAM_ADDR)
#define BIT_SET__ADDRCAM_ADDR(x, v) \
(BIT_CLEAR__ADDRCAM_ADDR(x) | BIT__ADDRCAM_ADDR(v))
#define BIT_SHIFT_ADDRCAM_RANGE 0
#define BIT_MASK_ADDRCAM_RANGE 0x7f
#define BIT_ADDRCAM_RANGE(x) \
(((x) & BIT_MASK_ADDRCAM_RANGE) << BIT_SHIFT_ADDRCAM_RANGE)
#define BITS_ADDRCAM_RANGE (BIT_MASK_ADDRCAM_RANGE << BIT_SHIFT_ADDRCAM_RANGE)
#define BIT_CLEAR_ADDRCAM_RANGE(x) ((x) & (~BITS_ADDRCAM_RANGE))
#define BIT_GET_ADDRCAM_RANGE(x) \
(((x) >> BIT_SHIFT_ADDRCAM_RANGE) & BIT_MASK_ADDRCAM_RANGE)
#define BIT_SET_ADDRCAM_RANGE(x, v) \
(BIT_CLEAR_ADDRCAM_RANGE(x) | BIT_ADDRCAM_RANGE(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CSI_RRSR (Offset 0x1678) */
#define BIT_CSI_LDPC_EN BIT(29)
#define BIT_CSI_STBC_EN BIT(28)
#define BIT_SHIFT_CSI_RRSC_BITMAP 4
#define BIT_MASK_CSI_RRSC_BITMAP 0xffffff
#define BIT_CSI_RRSC_BITMAP(x) \
(((x) & BIT_MASK_CSI_RRSC_BITMAP) << BIT_SHIFT_CSI_RRSC_BITMAP)
#define BITS_CSI_RRSC_BITMAP \
(BIT_MASK_CSI_RRSC_BITMAP << BIT_SHIFT_CSI_RRSC_BITMAP)
#define BIT_CLEAR_CSI_RRSC_BITMAP(x) ((x) & (~BITS_CSI_RRSC_BITMAP))
#define BIT_GET_CSI_RRSC_BITMAP(x) \
(((x) >> BIT_SHIFT_CSI_RRSC_BITMAP) & BIT_MASK_CSI_RRSC_BITMAP)
#define BIT_SET_CSI_RRSC_BITMAP(x, v) \
(BIT_CLEAR_CSI_RRSC_BITMAP(x) | BIT_CSI_RRSC_BITMAP(v))
#define BIT_SHIFT_OFDM_LEN_TH 0
#define BIT_MASK_OFDM_LEN_TH 0xf
#define BIT_OFDM_LEN_TH(x) \
(((x) & BIT_MASK_OFDM_LEN_TH) << BIT_SHIFT_OFDM_LEN_TH)
#define BITS_OFDM_LEN_TH (BIT_MASK_OFDM_LEN_TH << BIT_SHIFT_OFDM_LEN_TH)
#define BIT_CLEAR_OFDM_LEN_TH(x) ((x) & (~BITS_OFDM_LEN_TH))
#define BIT_GET_OFDM_LEN_TH(x) \
(((x) >> BIT_SHIFT_OFDM_LEN_TH) & BIT_MASK_OFDM_LEN_TH)
#define BIT_SET_OFDM_LEN_TH(x, v) \
(BIT_CLEAR_OFDM_LEN_TH(x) | BIT_OFDM_LEN_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_MU_BF_OPTION (Offset 0x167C) */
#define BIT_BIT_WMAC_TXMU_ACKPOLICY_EN BIT(6)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_MU_BF_OPTION (Offset 0x167C) */
#define BIT_WMAC_TXMU_ACKPOLICY_EN BIT(6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_PAUSE_BB_CLR_TH (Offset 0x167D) */
#define BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH 0
#define BIT_MASK_WMAC_PAUSE_BB_CLR_TH 0xff
#define BIT_WMAC_PAUSE_BB_CLR_TH(x) \
(((x) & BIT_MASK_WMAC_PAUSE_BB_CLR_TH) \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH)
#define BITS_WMAC_PAUSE_BB_CLR_TH \
(BIT_MASK_WMAC_PAUSE_BB_CLR_TH << BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH)
#define BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH(x) ((x) & (~BITS_WMAC_PAUSE_BB_CLR_TH))
#define BIT_GET_WMAC_PAUSE_BB_CLR_TH(x) \
(((x) >> BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH) & \
BIT_MASK_WMAC_PAUSE_BB_CLR_TH)
#define BIT_SET_WMAC_PAUSE_BB_CLR_TH(x, v) \
(BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH(x) | BIT_WMAC_PAUSE_BB_CLR_TH(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_MU_ARB (Offset 0x167E) */
#define BIT_WMAC_ARB_HW_ADAPT_EN BIT(7)
#define BIT_WMAC_ARB_SW_EN BIT(6)
#define BIT_SHIFT_WMAC_ARB_SW_STATE 0
#define BIT_MASK_WMAC_ARB_SW_STATE 0x3f
#define BIT_WMAC_ARB_SW_STATE(x) \
(((x) & BIT_MASK_WMAC_ARB_SW_STATE) << BIT_SHIFT_WMAC_ARB_SW_STATE)
#define BITS_WMAC_ARB_SW_STATE \
(BIT_MASK_WMAC_ARB_SW_STATE << BIT_SHIFT_WMAC_ARB_SW_STATE)
#define BIT_CLEAR_WMAC_ARB_SW_STATE(x) ((x) & (~BITS_WMAC_ARB_SW_STATE))
#define BIT_GET_WMAC_ARB_SW_STATE(x) \
(((x) >> BIT_SHIFT_WMAC_ARB_SW_STATE) & BIT_MASK_WMAC_ARB_SW_STATE)
#define BIT_SET_WMAC_ARB_SW_STATE(x, v) \
(BIT_CLEAR_WMAC_ARB_SW_STATE(x) | BIT_WMAC_ARB_SW_STATE(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WMAC_MU_OPTION (Offset 0x167F) */
#define BIT_NOCHK_BFPOLL_BMP BIT(7)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_MU_OPTION (Offset 0x167F) */
#define BIT_SHIFT_WMAC_MU_DBGSEL 5
#define BIT_MASK_WMAC_MU_DBGSEL 0x3
#define BIT_WMAC_MU_DBGSEL(x) \
(((x) & BIT_MASK_WMAC_MU_DBGSEL) << BIT_SHIFT_WMAC_MU_DBGSEL)
#define BITS_WMAC_MU_DBGSEL \
(BIT_MASK_WMAC_MU_DBGSEL << BIT_SHIFT_WMAC_MU_DBGSEL)
#define BIT_CLEAR_WMAC_MU_DBGSEL(x) ((x) & (~BITS_WMAC_MU_DBGSEL))
#define BIT_GET_WMAC_MU_DBGSEL(x) \
(((x) >> BIT_SHIFT_WMAC_MU_DBGSEL) & BIT_MASK_WMAC_MU_DBGSEL)
#define BIT_SET_WMAC_MU_DBGSEL(x, v) \
(BIT_CLEAR_WMAC_MU_DBGSEL(x) | BIT_WMAC_MU_DBGSEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_MU_OPTION (Offset 0x167F) */
#define BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT 0
#define BIT_MASK_WMAC_MU_CPRD_TIMEOUT 0x1f
#define BIT_WMAC_MU_CPRD_TIMEOUT(x) \
(((x) & BIT_MASK_WMAC_MU_CPRD_TIMEOUT) \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT)
#define BITS_WMAC_MU_CPRD_TIMEOUT \
(BIT_MASK_WMAC_MU_CPRD_TIMEOUT << BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT)
#define BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT(x) ((x) & (~BITS_WMAC_MU_CPRD_TIMEOUT))
#define BIT_GET_WMAC_MU_CPRD_TIMEOUT(x) \
(((x) >> BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT) & \
BIT_MASK_WMAC_MU_CPRD_TIMEOUT)
#define BIT_SET_WMAC_MU_CPRD_TIMEOUT(x, v) \
(BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT(x) | BIT_WMAC_MU_CPRD_TIMEOUT(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_MU_BF_CTL (Offset 0x1680) */
#define BIT_WMAC_INVLD_BFPRT_CHK BIT(15)
#define BIT_WMAC_RETXBFRPTSEQ_UPD BIT(14)
#define BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL 12
#define BIT_MASK_WMAC_MU_BFRPTSEG_SEL 0x3
#define BIT_WMAC_MU_BFRPTSEG_SEL(x) \
(((x) & BIT_MASK_WMAC_MU_BFRPTSEG_SEL) \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL)
#define BITS_WMAC_MU_BFRPTSEG_SEL \
(BIT_MASK_WMAC_MU_BFRPTSEG_SEL << BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL)
#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL(x) ((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL))
#define BIT_GET_WMAC_MU_BFRPTSEG_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL) & \
BIT_MASK_WMAC_MU_BFRPTSEG_SEL)
#define BIT_SET_WMAC_MU_BFRPTSEG_SEL(x, v) \
(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL(x) | BIT_WMAC_MU_BFRPTSEG_SEL(v))
#define BIT_SHIFT_WMAC_MU_BF_MYAID 0
#define BIT_MASK_WMAC_MU_BF_MYAID 0xfff
#define BIT_WMAC_MU_BF_MYAID(x) \
(((x) & BIT_MASK_WMAC_MU_BF_MYAID) << BIT_SHIFT_WMAC_MU_BF_MYAID)
#define BITS_WMAC_MU_BF_MYAID \
(BIT_MASK_WMAC_MU_BF_MYAID << BIT_SHIFT_WMAC_MU_BF_MYAID)
#define BIT_CLEAR_WMAC_MU_BF_MYAID(x) ((x) & (~BITS_WMAC_MU_BF_MYAID))
#define BIT_GET_WMAC_MU_BF_MYAID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BF_MYAID) & BIT_MASK_WMAC_MU_BF_MYAID)
#define BIT_SET_WMAC_MU_BF_MYAID(x, v) \
(BIT_CLEAR_WMAC_MU_BF_MYAID(x) | BIT_WMAC_MU_BF_MYAID(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_MU_BFRPT_PARA (Offset 0x1682) */
#define BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1 13
#define BIT_MASK_BFRPT_PARA_USERID_SEL_V1 0x7
#define BIT_BFRPT_PARA_USERID_SEL_V1(x) \
(((x) & BIT_MASK_BFRPT_PARA_USERID_SEL_V1) \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1)
#define BITS_BFRPT_PARA_USERID_SEL_V1 \
(BIT_MASK_BFRPT_PARA_USERID_SEL_V1 \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1)
#define BIT_CLEAR_BFRPT_PARA_USERID_SEL_V1(x) \
((x) & (~BITS_BFRPT_PARA_USERID_SEL_V1))
#define BIT_GET_BFRPT_PARA_USERID_SEL_V1(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1) & \
BIT_MASK_BFRPT_PARA_USERID_SEL_V1)
#define BIT_SET_BFRPT_PARA_USERID_SEL_V1(x, v) \
(BIT_CLEAR_BFRPT_PARA_USERID_SEL_V1(x) | \
BIT_BFRPT_PARA_USERID_SEL_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT)
/* 2 REG_WMAC_MU_BFRPT_PARA (Offset 0x1682) */
#define BIT_SHIFT_BFRPT_PARA_USERID_SEL 12
#define BIT_MASK_BFRPT_PARA_USERID_SEL 0x7
#define BIT_BFRPT_PARA_USERID_SEL(x) \
(((x) & BIT_MASK_BFRPT_PARA_USERID_SEL) \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL)
#define BITS_BFRPT_PARA_USERID_SEL \
(BIT_MASK_BFRPT_PARA_USERID_SEL << BIT_SHIFT_BFRPT_PARA_USERID_SEL)
#define BIT_CLEAR_BFRPT_PARA_USERID_SEL(x) ((x) & (~BITS_BFRPT_PARA_USERID_SEL))
#define BIT_GET_BFRPT_PARA_USERID_SEL(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_USERID_SEL) & \
BIT_MASK_BFRPT_PARA_USERID_SEL)
#define BIT_SET_BFRPT_PARA_USERID_SEL(x, v) \
(BIT_CLEAR_BFRPT_PARA_USERID_SEL(x) | BIT_BFRPT_PARA_USERID_SEL(v))
#endif
#if (HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_MU_BFRPT_PARA (Offset 0x1682) */
#define BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL 12
#define BIT_MASK_BIT_BFRPT_PARA_USERID_SEL 0x7
#define BIT_BIT_BFRPT_PARA_USERID_SEL(x) \
(((x) & BIT_MASK_BIT_BFRPT_PARA_USERID_SEL) \
<< BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL)
#define BITS_BIT_BFRPT_PARA_USERID_SEL \
(BIT_MASK_BIT_BFRPT_PARA_USERID_SEL \
<< BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL)
#define BIT_CLEAR_BIT_BFRPT_PARA_USERID_SEL(x) \
((x) & (~BITS_BIT_BFRPT_PARA_USERID_SEL))
#define BIT_GET_BIT_BFRPT_PARA_USERID_SEL(x) \
(((x) >> BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL) & \
BIT_MASK_BIT_BFRPT_PARA_USERID_SEL)
#define BIT_SET_BIT_BFRPT_PARA_USERID_SEL(x, v) \
(BIT_CLEAR_BIT_BFRPT_PARA_USERID_SEL(x) | \
BIT_BIT_BFRPT_PARA_USERID_SEL(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_MU_BFRPT_PARA (Offset 0x1682) */
#define BIT_SHIFT_BFRPT_PARA 0
#define BIT_MASK_BFRPT_PARA 0xfff
#define BIT_BFRPT_PARA(x) (((x) & BIT_MASK_BFRPT_PARA) << BIT_SHIFT_BFRPT_PARA)
#define BITS_BFRPT_PARA (BIT_MASK_BFRPT_PARA << BIT_SHIFT_BFRPT_PARA)
#define BIT_CLEAR_BFRPT_PARA(x) ((x) & (~BITS_BFRPT_PARA))
#define BIT_GET_BFRPT_PARA(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA) & BIT_MASK_BFRPT_PARA)
#define BIT_SET_BFRPT_PARA(x, v) (BIT_CLEAR_BFRPT_PARA(x) | BIT_BFRPT_PARA(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_MU_BFRPT_PARA (Offset 0x1682) */
#define BIT_SHIFT_BFRPT_PARA_V1 0
#define BIT_MASK_BFRPT_PARA_V1 0x1fff
#define BIT_BFRPT_PARA_V1(x) \
(((x) & BIT_MASK_BFRPT_PARA_V1) << BIT_SHIFT_BFRPT_PARA_V1)
#define BITS_BFRPT_PARA_V1 (BIT_MASK_BFRPT_PARA_V1 << BIT_SHIFT_BFRPT_PARA_V1)
#define BIT_CLEAR_BFRPT_PARA_V1(x) ((x) & (~BITS_BFRPT_PARA_V1))
#define BIT_GET_BFRPT_PARA_V1(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_V1) & BIT_MASK_BFRPT_PARA_V1)
#define BIT_SET_BFRPT_PARA_V1(x, v) \
(BIT_CLEAR_BFRPT_PARA_V1(x) | BIT_BFRPT_PARA_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2 (Offset 0x1684) */
#define BIT_STATUS_BFEE2 BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2 (Offset 0x1684) */
#define BIT_WMAC_MU_BFEE2_EN BIT(9)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2 (Offset 0x1684) */
#define BIT_WMAC_MU_BFEE2_USER_EN BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2 (Offset 0x1684) */
#define BIT_SHIFT_WMAC_MU_BFEE2_AID 0
#define BIT_MASK_WMAC_MU_BFEE2_AID 0x1ff
#define BIT_WMAC_MU_BFEE2_AID(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE2_AID) << BIT_SHIFT_WMAC_MU_BFEE2_AID)
#define BITS_WMAC_MU_BFEE2_AID \
(BIT_MASK_WMAC_MU_BFEE2_AID << BIT_SHIFT_WMAC_MU_BFEE2_AID)
#define BIT_CLEAR_WMAC_MU_BFEE2_AID(x) ((x) & (~BITS_WMAC_MU_BFEE2_AID))
#define BIT_GET_WMAC_MU_BFEE2_AID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE2_AID) & BIT_MASK_WMAC_MU_BFEE2_AID)
#define BIT_SET_WMAC_MU_BFEE2_AID(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE2_AID(x) | BIT_WMAC_MU_BFEE2_AID(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3 (Offset 0x1686) */
#define BIT_STATUS_BFEE3 BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3 (Offset 0x1686) */
#define BIT_WMAC_MU_BFEE3_EN BIT(9)
#endif
#if (HALMAC_8198F_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3 (Offset 0x1686) */
#define BIT_WMAC_MU_BFEE3_USER_EN BIT(9)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3 (Offset 0x1686) */
#define BIT_SHIFT_WMAC_MU_BFEE3_AID 0
#define BIT_MASK_WMAC_MU_BFEE3_AID 0x1ff
#define BIT_WMAC_MU_BFEE3_AID(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE3_AID) << BIT_SHIFT_WMAC_MU_BFEE3_AID)
#define BITS_WMAC_MU_BFEE3_AID \
(BIT_MASK_WMAC_MU_BFEE3_AID << BIT_SHIFT_WMAC_MU_BFEE3_AID)
#define BIT_CLEAR_WMAC_MU_BFEE3_AID(x) ((x) & (~BITS_WMAC_MU_BFEE3_AID))
#define BIT_GET_WMAC_MU_BFEE3_AID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE3_AID) & BIT_MASK_WMAC_MU_BFEE3_AID)
#define BIT_SET_WMAC_MU_BFEE3_AID(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE3_AID(x) | BIT_WMAC_MU_BFEE3_AID(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE4 (Offset 0x1688) */
#define BIT_STATUS_BFEE4 BIT(10)
#define BIT_WMAC_MU_BFEE4_EN BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE4_AID 0
#define BIT_MASK_WMAC_MU_BFEE4_AID 0x1ff
#define BIT_WMAC_MU_BFEE4_AID(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE4_AID) << BIT_SHIFT_WMAC_MU_BFEE4_AID)
#define BITS_WMAC_MU_BFEE4_AID \
(BIT_MASK_WMAC_MU_BFEE4_AID << BIT_SHIFT_WMAC_MU_BFEE4_AID)
#define BIT_CLEAR_WMAC_MU_BFEE4_AID(x) ((x) & (~BITS_WMAC_MU_BFEE4_AID))
#define BIT_GET_WMAC_MU_BFEE4_AID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE4_AID) & BIT_MASK_WMAC_MU_BFEE4_AID)
#define BIT_SET_WMAC_MU_BFEE4_AID(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE4_AID(x) | BIT_WMAC_MU_BFEE4_AID(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5 (Offset 0x168A) */
#define BIT_STATUS_BFEE5 BIT(10)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5 (Offset 0x168A) */
#define BIT_BIT_STATUS_BFEE5 BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5 (Offset 0x168A) */
#define BIT_WMAC_MU_BFEE5_EN BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE5_AID 0
#define BIT_MASK_WMAC_MU_BFEE5_AID 0x1ff
#define BIT_WMAC_MU_BFEE5_AID(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE5_AID) << BIT_SHIFT_WMAC_MU_BFEE5_AID)
#define BITS_WMAC_MU_BFEE5_AID \
(BIT_MASK_WMAC_MU_BFEE5_AID << BIT_SHIFT_WMAC_MU_BFEE5_AID)
#define BIT_CLEAR_WMAC_MU_BFEE5_AID(x) ((x) & (~BITS_WMAC_MU_BFEE5_AID))
#define BIT_GET_WMAC_MU_BFEE5_AID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE5_AID) & BIT_MASK_WMAC_MU_BFEE5_AID)
#define BIT_SET_WMAC_MU_BFEE5_AID(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE5_AID(x) | BIT_WMAC_MU_BFEE5_AID(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE6 (Offset 0x168C) */
#define BIT_STATUS_BFEE6 BIT(10)
#define BIT_WMAC_MU_BFEE6_EN BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE6_AID 0
#define BIT_MASK_WMAC_MU_BFEE6_AID 0x1ff
#define BIT_WMAC_MU_BFEE6_AID(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE6_AID) << BIT_SHIFT_WMAC_MU_BFEE6_AID)
#define BITS_WMAC_MU_BFEE6_AID \
(BIT_MASK_WMAC_MU_BFEE6_AID << BIT_SHIFT_WMAC_MU_BFEE6_AID)
#define BIT_CLEAR_WMAC_MU_BFEE6_AID(x) ((x) & (~BITS_WMAC_MU_BFEE6_AID))
#define BIT_GET_WMAC_MU_BFEE6_AID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE6_AID) & BIT_MASK_WMAC_MU_BFEE6_AID)
#define BIT_SET_WMAC_MU_BFEE6_AID(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE6_AID(x) | BIT_WMAC_MU_BFEE6_AID(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7 (Offset 0x168E) */
#define BIT_BIT_STATUS_BFEE4 BIT(10)
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7 (Offset 0x168E) */
#define BIT_STATUS_BFEE7 BIT(10)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7 (Offset 0x168E) */
#define BIT_WMAC_MU_BFEE7_EN BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE7_AID 0
#define BIT_MASK_WMAC_MU_BFEE7_AID 0x1ff
#define BIT_WMAC_MU_BFEE7_AID(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE7_AID) << BIT_SHIFT_WMAC_MU_BFEE7_AID)
#define BITS_WMAC_MU_BFEE7_AID \
(BIT_MASK_WMAC_MU_BFEE7_AID << BIT_SHIFT_WMAC_MU_BFEE7_AID)
#define BIT_CLEAR_WMAC_MU_BFEE7_AID(x) ((x) & (~BITS_WMAC_MU_BFEE7_AID))
#define BIT_GET_WMAC_MU_BFEE7_AID(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE7_AID) & BIT_MASK_WMAC_MU_BFEE7_AID)
#define BIT_SET_WMAC_MU_BFEE7_AID(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE7_AID(x) | BIT_WMAC_MU_BFEE7_AID(v))
/* 2 REG_WMAC_BB_STOP_RX_COUNTER (Offset 0x1690) */
#define BIT_RST_ALL_COUNTER BIT(31)
#define BIT_SHIFT_ABORT_RX_VBON_COUNTER 16
#define BIT_MASK_ABORT_RX_VBON_COUNTER 0xff
#define BIT_ABORT_RX_VBON_COUNTER(x) \
(((x) & BIT_MASK_ABORT_RX_VBON_COUNTER) \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER)
#define BITS_ABORT_RX_VBON_COUNTER \
(BIT_MASK_ABORT_RX_VBON_COUNTER << BIT_SHIFT_ABORT_RX_VBON_COUNTER)
#define BIT_CLEAR_ABORT_RX_VBON_COUNTER(x) ((x) & (~BITS_ABORT_RX_VBON_COUNTER))
#define BIT_GET_ABORT_RX_VBON_COUNTER(x) \
(((x) >> BIT_SHIFT_ABORT_RX_VBON_COUNTER) & \
BIT_MASK_ABORT_RX_VBON_COUNTER)
#define BIT_SET_ABORT_RX_VBON_COUNTER(x, v) \
(BIT_CLEAR_ABORT_RX_VBON_COUNTER(x) | BIT_ABORT_RX_VBON_COUNTER(v))
#define BIT_SHIFT_ABORT_RX_RDRDY_COUNTER 8
#define BIT_MASK_ABORT_RX_RDRDY_COUNTER 0xff
#define BIT_ABORT_RX_RDRDY_COUNTER(x) \
(((x) & BIT_MASK_ABORT_RX_RDRDY_COUNTER) \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER)
#define BITS_ABORT_RX_RDRDY_COUNTER \
(BIT_MASK_ABORT_RX_RDRDY_COUNTER << BIT_SHIFT_ABORT_RX_RDRDY_COUNTER)
#define BIT_CLEAR_ABORT_RX_RDRDY_COUNTER(x) \
((x) & (~BITS_ABORT_RX_RDRDY_COUNTER))
#define BIT_GET_ABORT_RX_RDRDY_COUNTER(x) \
(((x) >> BIT_SHIFT_ABORT_RX_RDRDY_COUNTER) & \
BIT_MASK_ABORT_RX_RDRDY_COUNTER)
#define BIT_SET_ABORT_RX_RDRDY_COUNTER(x, v) \
(BIT_CLEAR_ABORT_RX_RDRDY_COUNTER(x) | BIT_ABORT_RX_RDRDY_COUNTER(v))
#define BIT_SHIFT_VBON_EARLY_FALLING_COUNTER 0
#define BIT_MASK_VBON_EARLY_FALLING_COUNTER 0xff
#define BIT_VBON_EARLY_FALLING_COUNTER(x) \
(((x) & BIT_MASK_VBON_EARLY_FALLING_COUNTER) \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER)
#define BITS_VBON_EARLY_FALLING_COUNTER \
(BIT_MASK_VBON_EARLY_FALLING_COUNTER \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER)
#define BIT_CLEAR_VBON_EARLY_FALLING_COUNTER(x) \
((x) & (~BITS_VBON_EARLY_FALLING_COUNTER))
#define BIT_GET_VBON_EARLY_FALLING_COUNTER(x) \
(((x) >> BIT_SHIFT_VBON_EARLY_FALLING_COUNTER) & \
BIT_MASK_VBON_EARLY_FALLING_COUNTER)
#define BIT_SET_VBON_EARLY_FALLING_COUNTER(x, v) \
(BIT_CLEAR_VBON_EARLY_FALLING_COUNTER(x) | \
BIT_VBON_EARLY_FALLING_COUNTER(v))
/* 2 REG_WMAC_PLCP_MONITOR (Offset 0x1694) */
#define BIT_WMAC_PLCP_TRX_SEL BIT(31)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_SEL 28
#define BIT_MASK_WMAC_PLCP_RDSIG_SEL 0x7
#define BIT_WMAC_PLCP_RDSIG_SEL(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_SEL) << BIT_SHIFT_WMAC_PLCP_RDSIG_SEL)
#define BITS_WMAC_PLCP_RDSIG_SEL \
(BIT_MASK_WMAC_PLCP_RDSIG_SEL << BIT_SHIFT_WMAC_PLCP_RDSIG_SEL)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_SEL(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_SEL))
#define BIT_GET_WMAC_PLCP_RDSIG_SEL(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_SEL) & BIT_MASK_WMAC_PLCP_RDSIG_SEL)
#define BIT_SET_WMAC_PLCP_RDSIG_SEL(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_SEL(x) | BIT_WMAC_PLCP_RDSIG_SEL(v))
#define BIT_SHIFT_WMAC_RATE_IDX 24
#define BIT_MASK_WMAC_RATE_IDX 0xf
#define BIT_WMAC_RATE_IDX(x) \
(((x) & BIT_MASK_WMAC_RATE_IDX) << BIT_SHIFT_WMAC_RATE_IDX)
#define BITS_WMAC_RATE_IDX (BIT_MASK_WMAC_RATE_IDX << BIT_SHIFT_WMAC_RATE_IDX)
#define BIT_CLEAR_WMAC_RATE_IDX(x) ((x) & (~BITS_WMAC_RATE_IDX))
#define BIT_GET_WMAC_RATE_IDX(x) \
(((x) >> BIT_SHIFT_WMAC_RATE_IDX) & BIT_MASK_WMAC_RATE_IDX)
#define BIT_SET_WMAC_RATE_IDX(x, v) \
(BIT_CLEAR_WMAC_RATE_IDX(x) | BIT_WMAC_RATE_IDX(v))
#define BIT_SHIFT_WMAC_PLCP_RDSIG 0
#define BIT_MASK_WMAC_PLCP_RDSIG 0xffffff
#define BIT_WMAC_PLCP_RDSIG(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG) << BIT_SHIFT_WMAC_PLCP_RDSIG)
#define BITS_WMAC_PLCP_RDSIG \
(BIT_MASK_WMAC_PLCP_RDSIG << BIT_SHIFT_WMAC_PLCP_RDSIG)
#define BIT_CLEAR_WMAC_PLCP_RDSIG(x) ((x) & (~BITS_WMAC_PLCP_RDSIG))
#define BIT_GET_WMAC_PLCP_RDSIG(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG) & BIT_MASK_WMAC_PLCP_RDSIG)
#define BIT_SET_WMAC_PLCP_RDSIG(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG(x) | BIT_WMAC_PLCP_RDSIG(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_PLCP_MONITOR_MUTX (Offset 0x1698) */
#define BIT_WMAC_MUTX_IDX BIT(24)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_WMAC_DEBUG_PORT (Offset 0x1698) */
#define BIT_SHIFT_WMAC_DEBUG_PORT 0
#define BIT_MASK_WMAC_DEBUG_PORT 0xffffffffL
#define BIT_WMAC_DEBUG_PORT(x) \
(((x) & BIT_MASK_WMAC_DEBUG_PORT) << BIT_SHIFT_WMAC_DEBUG_PORT)
#define BITS_WMAC_DEBUG_PORT \
(BIT_MASK_WMAC_DEBUG_PORT << BIT_SHIFT_WMAC_DEBUG_PORT)
#define BIT_CLEAR_WMAC_DEBUG_PORT(x) ((x) & (~BITS_WMAC_DEBUG_PORT))
#define BIT_GET_WMAC_DEBUG_PORT(x) \
(((x) >> BIT_SHIFT_WMAC_DEBUG_PORT) & BIT_MASK_WMAC_DEBUG_PORT)
#define BIT_SET_WMAC_DEBUG_PORT(x, v) \
(BIT_CLEAR_WMAC_DEBUG_PORT(x) | BIT_WMAC_DEBUG_PORT(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WMAC_CSIDMA_CFG (Offset 0x169C) */
#define BIT_SHIFT_CSI_SEG_SIZE 16
#define BIT_MASK_CSI_SEG_SIZE 0xfff
#define BIT_CSI_SEG_SIZE(x) \
(((x) & BIT_MASK_CSI_SEG_SIZE) << BIT_SHIFT_CSI_SEG_SIZE)
#define BITS_CSI_SEG_SIZE (BIT_MASK_CSI_SEG_SIZE << BIT_SHIFT_CSI_SEG_SIZE)
#define BIT_CLEAR_CSI_SEG_SIZE(x) ((x) & (~BITS_CSI_SEG_SIZE))
#define BIT_GET_CSI_SEG_SIZE(x) \
(((x) >> BIT_SHIFT_CSI_SEG_SIZE) & BIT_MASK_CSI_SEG_SIZE)
#define BIT_SET_CSI_SEG_SIZE(x, v) \
(BIT_CLEAR_CSI_SEG_SIZE(x) | BIT_CSI_SEG_SIZE(v))
#define BIT_SHIFT_CSI_START_PAGE 0
#define BIT_MASK_CSI_START_PAGE 0xfff
#define BIT_CSI_START_PAGE(x) \
(((x) & BIT_MASK_CSI_START_PAGE) << BIT_SHIFT_CSI_START_PAGE)
#define BITS_CSI_START_PAGE \
(BIT_MASK_CSI_START_PAGE << BIT_SHIFT_CSI_START_PAGE)
#define BIT_CLEAR_CSI_START_PAGE(x) ((x) & (~BITS_CSI_START_PAGE))
#define BIT_GET_CSI_START_PAGE(x) \
(((x) >> BIT_SHIFT_CSI_START_PAGE) & BIT_MASK_CSI_START_PAGE)
#define BIT_SET_CSI_START_PAGE(x, v) \
(BIT_CLEAR_CSI_START_PAGE(x) | BIT_CSI_START_PAGE(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_0 (Offset 0x16A0) */
#define BIT_SHIFT_TA0 0
#define BIT_MASK_TA0 0xffffffffffffL
#define BIT_TA0(x) (((x) & BIT_MASK_TA0) << BIT_SHIFT_TA0)
#define BITS_TA0 (BIT_MASK_TA0 << BIT_SHIFT_TA0)
#define BIT_CLEAR_TA0(x) ((x) & (~BITS_TA0))
#define BIT_GET_TA0(x) (((x) >> BIT_SHIFT_TA0) & BIT_MASK_TA0)
#define BIT_SET_TA0(x, v) (BIT_CLEAR_TA0(x) | BIT_TA0(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_0 (Offset 0x16A0) */
#define BIT_SHIFT_TA0_V1 0
#define BIT_MASK_TA0_V1 0xffffffffL
#define BIT_TA0_V1(x) (((x) & BIT_MASK_TA0_V1) << BIT_SHIFT_TA0_V1)
#define BITS_TA0_V1 (BIT_MASK_TA0_V1 << BIT_SHIFT_TA0_V1)
#define BIT_CLEAR_TA0_V1(x) ((x) & (~BITS_TA0_V1))
#define BIT_GET_TA0_V1(x) (((x) >> BIT_SHIFT_TA0_V1) & BIT_MASK_TA0_V1)
#define BIT_SET_TA0_V1(x, v) (BIT_CLEAR_TA0_V1(x) | BIT_TA0_V1(v))
/* 2 REG_TRANSMIT_ADDRSS_0_H (Offset 0x16A4) */
#define BIT_SHIFT_TA0_H_V1 0
#define BIT_MASK_TA0_H_V1 0xffff
#define BIT_TA0_H_V1(x) (((x) & BIT_MASK_TA0_H_V1) << BIT_SHIFT_TA0_H_V1)
#define BITS_TA0_H_V1 (BIT_MASK_TA0_H_V1 << BIT_SHIFT_TA0_H_V1)
#define BIT_CLEAR_TA0_H_V1(x) ((x) & (~BITS_TA0_H_V1))
#define BIT_GET_TA0_H_V1(x) (((x) >> BIT_SHIFT_TA0_H_V1) & BIT_MASK_TA0_H_V1)
#define BIT_SET_TA0_H_V1(x, v) (BIT_CLEAR_TA0_H_V1(x) | BIT_TA0_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_1 (Offset 0x16A8) */
#define BIT_SHIFT_TA1 0
#define BIT_MASK_TA1 0xffffffffffffL
#define BIT_TA1(x) (((x) & BIT_MASK_TA1) << BIT_SHIFT_TA1)
#define BITS_TA1 (BIT_MASK_TA1 << BIT_SHIFT_TA1)
#define BIT_CLEAR_TA1(x) ((x) & (~BITS_TA1))
#define BIT_GET_TA1(x) (((x) >> BIT_SHIFT_TA1) & BIT_MASK_TA1)
#define BIT_SET_TA1(x, v) (BIT_CLEAR_TA1(x) | BIT_TA1(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_1 (Offset 0x16A8) */
#define BIT_SHIFT_TA1_V1 0
#define BIT_MASK_TA1_V1 0xffffffffL
#define BIT_TA1_V1(x) (((x) & BIT_MASK_TA1_V1) << BIT_SHIFT_TA1_V1)
#define BITS_TA1_V1 (BIT_MASK_TA1_V1 << BIT_SHIFT_TA1_V1)
#define BIT_CLEAR_TA1_V1(x) ((x) & (~BITS_TA1_V1))
#define BIT_GET_TA1_V1(x) (((x) >> BIT_SHIFT_TA1_V1) & BIT_MASK_TA1_V1)
#define BIT_SET_TA1_V1(x, v) (BIT_CLEAR_TA1_V1(x) | BIT_TA1_V1(v))
/* 2 REG_TRANSMIT_ADDRSS_1_H (Offset 0x16AC) */
#define BIT_SHIFT_TA1_H_V1 0
#define BIT_MASK_TA1_H_V1 0xffff
#define BIT_TA1_H_V1(x) (((x) & BIT_MASK_TA1_H_V1) << BIT_SHIFT_TA1_H_V1)
#define BITS_TA1_H_V1 (BIT_MASK_TA1_H_V1 << BIT_SHIFT_TA1_H_V1)
#define BIT_CLEAR_TA1_H_V1(x) ((x) & (~BITS_TA1_H_V1))
#define BIT_GET_TA1_H_V1(x) (((x) >> BIT_SHIFT_TA1_H_V1) & BIT_MASK_TA1_H_V1)
#define BIT_SET_TA1_H_V1(x, v) (BIT_CLEAR_TA1_H_V1(x) | BIT_TA1_H_V1(v))
#define BIT_SHIFT_TA2_V1 0
#define BIT_MASK_TA2_V1 0xffffffffL
#define BIT_TA2_V1(x) (((x) & BIT_MASK_TA2_V1) << BIT_SHIFT_TA2_V1)
#define BITS_TA2_V1 (BIT_MASK_TA2_V1 << BIT_SHIFT_TA2_V1)
#define BIT_CLEAR_TA2_V1(x) ((x) & (~BITS_TA2_V1))
#define BIT_GET_TA2_V1(x) (((x) >> BIT_SHIFT_TA2_V1) & BIT_MASK_TA2_V1)
#define BIT_SET_TA2_V1(x, v) (BIT_CLEAR_TA2_V1(x) | BIT_TA2_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_2 (Offset 0x16B0) */
#define BIT_SHIFT_TA2 0
#define BIT_MASK_TA2 0xffffffffffffL
#define BIT_TA2(x) (((x) & BIT_MASK_TA2) << BIT_SHIFT_TA2)
#define BITS_TA2 (BIT_MASK_TA2 << BIT_SHIFT_TA2)
#define BIT_CLEAR_TA2(x) ((x) & (~BITS_TA2))
#define BIT_GET_TA2(x) (((x) >> BIT_SHIFT_TA2) & BIT_MASK_TA2)
#define BIT_SET_TA2(x, v) (BIT_CLEAR_TA2(x) | BIT_TA2(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_2_H (Offset 0x16B4) */
#define BIT_SHIFT_TA2_H_V1 0
#define BIT_MASK_TA2_H_V1 0xffff
#define BIT_TA2_H_V1(x) (((x) & BIT_MASK_TA2_H_V1) << BIT_SHIFT_TA2_H_V1)
#define BITS_TA2_H_V1 (BIT_MASK_TA2_H_V1 << BIT_SHIFT_TA2_H_V1)
#define BIT_CLEAR_TA2_H_V1(x) ((x) & (~BITS_TA2_H_V1))
#define BIT_GET_TA2_H_V1(x) (((x) >> BIT_SHIFT_TA2_H_V1) & BIT_MASK_TA2_H_V1)
#define BIT_SET_TA2_H_V1(x, v) (BIT_CLEAR_TA2_H_V1(x) | BIT_TA2_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_3 (Offset 0x16B8) */
#define BIT_SHIFT_TA3 0
#define BIT_MASK_TA3 0xffffffffffffL
#define BIT_TA3(x) (((x) & BIT_MASK_TA3) << BIT_SHIFT_TA3)
#define BITS_TA3 (BIT_MASK_TA3 << BIT_SHIFT_TA3)
#define BIT_CLEAR_TA3(x) ((x) & (~BITS_TA3))
#define BIT_GET_TA3(x) (((x) >> BIT_SHIFT_TA3) & BIT_MASK_TA3)
#define BIT_SET_TA3(x, v) (BIT_CLEAR_TA3(x) | BIT_TA3(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_3_H (Offset 0x16BC) */
#define BIT_SHIFT_TA3_H_V1 0
#define BIT_MASK_TA3_H_V1 0xffff
#define BIT_TA3_H_V1(x) (((x) & BIT_MASK_TA3_H_V1) << BIT_SHIFT_TA3_H_V1)
#define BITS_TA3_H_V1 (BIT_MASK_TA3_H_V1 << BIT_SHIFT_TA3_H_V1)
#define BIT_CLEAR_TA3_H_V1(x) ((x) & (~BITS_TA3_H_V1))
#define BIT_GET_TA3_H_V1(x) (((x) >> BIT_SHIFT_TA3_H_V1) & BIT_MASK_TA3_H_V1)
#define BIT_SET_TA3_H_V1(x, v) (BIT_CLEAR_TA3_H_V1(x) | BIT_TA3_H_V1(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_4 (Offset 0x16C0) */
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC BIT(55)
#define BIT_R_WMAC_RXRST_DLY BIT(54)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP BIT(53)
#define BIT_R_WMAC_SRCH_TXRPT_UA1 BIT(52)
#define BIT_SHIFT_TA4 0
#define BIT_MASK_TA4 0xffffffffffffL
#define BIT_TA4(x) (((x) & BIT_MASK_TA4) << BIT_SHIFT_TA4)
#define BITS_TA4 (BIT_MASK_TA4 << BIT_SHIFT_TA4)
#define BIT_CLEAR_TA4(x) ((x) & (~BITS_TA4))
#define BIT_GET_TA4(x) (((x) >> BIT_SHIFT_TA4) & BIT_MASK_TA4)
#define BIT_SET_TA4(x, v) (BIT_CLEAR_TA4(x) | BIT_TA4(v))
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_TRANSMIT_ADDRSS_4 (Offset 0x16C0) */
#define BIT_SHIFT_TA4_V1 0
#define BIT_MASK_TA4_V1 0xffffffffL
#define BIT_TA4_V1(x) (((x) & BIT_MASK_TA4_V1) << BIT_SHIFT_TA4_V1)
#define BITS_TA4_V1 (BIT_MASK_TA4_V1 << BIT_SHIFT_TA4_V1)
#define BIT_CLEAR_TA4_V1(x) ((x) & (~BITS_TA4_V1))
#define BIT_GET_TA4_V1(x) (((x) >> BIT_SHIFT_TA4_V1) & BIT_MASK_TA4_V1)
#define BIT_SET_TA4_V1(x, v) (BIT_CLEAR_TA4_V1(x) | BIT_TA4_V1(v))
/* 2 REG_TRANSMIT_ADDRSS_4_H (Offset 0x16C4) */
#define BIT_SHIFT_TA4_H_V1 0
#define BIT_MASK_TA4_H_V1 0xffff
#define BIT_TA4_H_V1(x) (((x) & BIT_MASK_TA4_H_V1) << BIT_SHIFT_TA4_H_V1)
#define BITS_TA4_H_V1 (BIT_MASK_TA4_H_V1 << BIT_SHIFT_TA4_H_V1)
#define BIT_CLEAR_TA4_H_V1(x) ((x) & (~BITS_TA4_H_V1))
#define BIT_GET_TA4_H_V1(x) (((x) >> BIT_SHIFT_TA4_H_V1) & BIT_MASK_TA4_H_V1)
#define BIT_SET_TA4_H_V1(x, v) (BIT_CLEAR_TA4_H_V1(x) | BIT_TA4_H_V1(v))
#endif
#if (HALMAC_8812F_SUPPORT)
/* 2 REG_SND_AID12 (Offset 0x16D0) */
#define BIT_SHIFT_USERID_SEL 12
#define BIT_MASK_USERID_SEL 0x7
#define BIT_USERID_SEL(x) (((x) & BIT_MASK_USERID_SEL) << BIT_SHIFT_USERID_SEL)
#define BITS_USERID_SEL (BIT_MASK_USERID_SEL << BIT_SHIFT_USERID_SEL)
#define BIT_CLEAR_USERID_SEL(x) ((x) & (~BITS_USERID_SEL))
#define BIT_GET_USERID_SEL(x) \
(((x) >> BIT_SHIFT_USERID_SEL) & BIT_MASK_USERID_SEL)
#define BIT_SET_USERID_SEL(x, v) (BIT_CLEAR_USERID_SEL(x) | BIT_USERID_SEL(v))
#define BIT_SHIFT_USERID_AID12 0
#define BIT_MASK_USERID_AID12 0xfff
#define BIT_USERID_AID12(x) \
(((x) & BIT_MASK_USERID_AID12) << BIT_SHIFT_USERID_AID12)
#define BITS_USERID_AID12 (BIT_MASK_USERID_AID12 << BIT_SHIFT_USERID_AID12)
#define BIT_CLEAR_USERID_AID12(x) ((x) & (~BITS_USERID_AID12))
#define BIT_GET_USERID_AID12(x) \
(((x) >> BIT_SHIFT_USERID_AID12) & BIT_MASK_USERID_AID12)
#define BIT_SET_USERID_AID12(x, v) \
(BIT_CLEAR_USERID_AID12(x) | BIT_USERID_AID12(v))
/* 2 REG_SND_PKT_INFO (Offset 0x16D2) */
#define BIT_SND_FROM_DS BIT(7)
#define BIT_SND_TO_DS BIT(6)
#define BIT_SHIFT_SND_TOKEN 0
#define BIT_MASK_SND_TOKEN 0x3f
#define BIT_SND_TOKEN(x) (((x) & BIT_MASK_SND_TOKEN) << BIT_SHIFT_SND_TOKEN)
#define BITS_SND_TOKEN (BIT_MASK_SND_TOKEN << BIT_SHIFT_SND_TOKEN)
#define BIT_CLEAR_SND_TOKEN(x) ((x) & (~BITS_SND_TOKEN))
#define BIT_GET_SND_TOKEN(x) (((x) >> BIT_SHIFT_SND_TOKEN) & BIT_MASK_SND_TOKEN)
#define BIT_SET_SND_TOKEN(x, v) (BIT_CLEAR_SND_TOKEN(x) | BIT_SND_TOKEN(v))
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1 (Offset 0x1700) */
#define BIT_LTECOEX_ACCESS_START_V1 BIT(31)
#define BIT_LTECOEX_WRITE_MODE_V1 BIT(30)
#define BIT_LTECOEX_READY_BIT_V1 BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN_V1 16
#define BIT_MASK_WRITE_BYTE_EN_V1 0xf
#define BIT_WRITE_BYTE_EN_V1(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN_V1) << BIT_SHIFT_WRITE_BYTE_EN_V1)
#define BITS_WRITE_BYTE_EN_V1 \
(BIT_MASK_WRITE_BYTE_EN_V1 << BIT_SHIFT_WRITE_BYTE_EN_V1)
#define BIT_CLEAR_WRITE_BYTE_EN_V1(x) ((x) & (~BITS_WRITE_BYTE_EN_V1))
#define BIT_GET_WRITE_BYTE_EN_V1(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN_V1) & BIT_MASK_WRITE_BYTE_EN_V1)
#define BIT_SET_WRITE_BYTE_EN_V1(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN_V1(x) | BIT_WRITE_BYTE_EN_V1(v))
#define BIT_SHIFT_LTECOEX_REG_ADDR_V1 0
#define BIT_MASK_LTECOEX_REG_ADDR_V1 0xffff
#define BIT_LTECOEX_REG_ADDR_V1(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR_V1) << BIT_SHIFT_LTECOEX_REG_ADDR_V1)
#define BITS_LTECOEX_REG_ADDR_V1 \
(BIT_MASK_LTECOEX_REG_ADDR_V1 << BIT_SHIFT_LTECOEX_REG_ADDR_V1)
#define BIT_CLEAR_LTECOEX_REG_ADDR_V1(x) ((x) & (~BITS_LTECOEX_REG_ADDR_V1))
#define BIT_GET_LTECOEX_REG_ADDR_V1(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR_V1) & BIT_MASK_LTECOEX_REG_ADDR_V1)
#define BIT_SET_LTECOEX_REG_ADDR_V1(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR_V1(x) | BIT_LTECOEX_REG_ADDR_V1(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1 (Offset 0x1704) */
#define BIT_SHIFT_LTECOEX_W_DATA_V1 0
#define BIT_MASK_LTECOEX_W_DATA_V1 0xffffffffL
#define BIT_LTECOEX_W_DATA_V1(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA_V1) << BIT_SHIFT_LTECOEX_W_DATA_V1)
#define BITS_LTECOEX_W_DATA_V1 \
(BIT_MASK_LTECOEX_W_DATA_V1 << BIT_SHIFT_LTECOEX_W_DATA_V1)
#define BIT_CLEAR_LTECOEX_W_DATA_V1(x) ((x) & (~BITS_LTECOEX_W_DATA_V1))
#define BIT_GET_LTECOEX_W_DATA_V1(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA_V1) & BIT_MASK_LTECOEX_W_DATA_V1)
#define BIT_SET_LTECOEX_W_DATA_V1(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA_V1(x) | BIT_LTECOEX_W_DATA_V1(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1 (Offset 0x1708) */
#define BIT_SHIFT_LTECOEX_R_DATA_V1 0
#define BIT_MASK_LTECOEX_R_DATA_V1 0xffffffffL
#define BIT_LTECOEX_R_DATA_V1(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA_V1) << BIT_SHIFT_LTECOEX_R_DATA_V1)
#define BITS_LTECOEX_R_DATA_V1 \
(BIT_MASK_LTECOEX_R_DATA_V1 << BIT_SHIFT_LTECOEX_R_DATA_V1)
#define BIT_CLEAR_LTECOEX_R_DATA_V1(x) ((x) & (~BITS_LTECOEX_R_DATA_V1))
#define BIT_GET_LTECOEX_R_DATA_V1(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA_V1) & BIT_MASK_LTECOEX_R_DATA_V1)
#define BIT_SET_LTECOEX_R_DATA_V1(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA_V1(x) | BIT_LTECOEX_R_DATA_V1(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_DMA_RQPN_INFO_0 (Offset 0x2200) */
#define BIT_SHIFT_CH0_AVAL_PG 16
#define BIT_MASK_CH0_AVAL_PG 0xfff
#define BIT_CH0_AVAL_PG(x) \
(((x) & BIT_MASK_CH0_AVAL_PG) << BIT_SHIFT_CH0_AVAL_PG)
#define BITS_CH0_AVAL_PG (BIT_MASK_CH0_AVAL_PG << BIT_SHIFT_CH0_AVAL_PG)
#define BIT_CLEAR_CH0_AVAL_PG(x) ((x) & (~BITS_CH0_AVAL_PG))
#define BIT_GET_CH0_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH0_AVAL_PG) & BIT_MASK_CH0_AVAL_PG)
#define BIT_SET_CH0_AVAL_PG(x, v) \
(BIT_CLEAR_CH0_AVAL_PG(x) | BIT_CH0_AVAL_PG(v))
#define BIT_SHIFT_CH0_RSVD_PG 0
#define BIT_MASK_CH0_RSVD_PG 0xfff
#define BIT_CH0_RSVD_PG(x) \
(((x) & BIT_MASK_CH0_RSVD_PG) << BIT_SHIFT_CH0_RSVD_PG)
#define BITS_CH0_RSVD_PG (BIT_MASK_CH0_RSVD_PG << BIT_SHIFT_CH0_RSVD_PG)
#define BIT_CLEAR_CH0_RSVD_PG(x) ((x) & (~BITS_CH0_RSVD_PG))
#define BIT_GET_CH0_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH0_RSVD_PG) & BIT_MASK_CH0_RSVD_PG)
#define BIT_SET_CH0_RSVD_PG(x, v) \
(BIT_CLEAR_CH0_RSVD_PG(x) | BIT_CH0_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_1 (Offset 0x2204) */
#define BIT_SHIFT_CH1_AVAL_PG 16
#define BIT_MASK_CH1_AVAL_PG 0xfff
#define BIT_CH1_AVAL_PG(x) \
(((x) & BIT_MASK_CH1_AVAL_PG) << BIT_SHIFT_CH1_AVAL_PG)
#define BITS_CH1_AVAL_PG (BIT_MASK_CH1_AVAL_PG << BIT_SHIFT_CH1_AVAL_PG)
#define BIT_CLEAR_CH1_AVAL_PG(x) ((x) & (~BITS_CH1_AVAL_PG))
#define BIT_GET_CH1_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH1_AVAL_PG) & BIT_MASK_CH1_AVAL_PG)
#define BIT_SET_CH1_AVAL_PG(x, v) \
(BIT_CLEAR_CH1_AVAL_PG(x) | BIT_CH1_AVAL_PG(v))
#define BIT_SHIFT_CH1_RSVD_PG 0
#define BIT_MASK_CH1_RSVD_PG 0xfff
#define BIT_CH1_RSVD_PG(x) \
(((x) & BIT_MASK_CH1_RSVD_PG) << BIT_SHIFT_CH1_RSVD_PG)
#define BITS_CH1_RSVD_PG (BIT_MASK_CH1_RSVD_PG << BIT_SHIFT_CH1_RSVD_PG)
#define BIT_CLEAR_CH1_RSVD_PG(x) ((x) & (~BITS_CH1_RSVD_PG))
#define BIT_GET_CH1_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH1_RSVD_PG) & BIT_MASK_CH1_RSVD_PG)
#define BIT_SET_CH1_RSVD_PG(x, v) \
(BIT_CLEAR_CH1_RSVD_PG(x) | BIT_CH1_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_2 (Offset 0x2208) */
#define BIT_SHIFT_CH2_AVAL_PG 16
#define BIT_MASK_CH2_AVAL_PG 0xfff
#define BIT_CH2_AVAL_PG(x) \
(((x) & BIT_MASK_CH2_AVAL_PG) << BIT_SHIFT_CH2_AVAL_PG)
#define BITS_CH2_AVAL_PG (BIT_MASK_CH2_AVAL_PG << BIT_SHIFT_CH2_AVAL_PG)
#define BIT_CLEAR_CH2_AVAL_PG(x) ((x) & (~BITS_CH2_AVAL_PG))
#define BIT_GET_CH2_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH2_AVAL_PG) & BIT_MASK_CH2_AVAL_PG)
#define BIT_SET_CH2_AVAL_PG(x, v) \
(BIT_CLEAR_CH2_AVAL_PG(x) | BIT_CH2_AVAL_PG(v))
#define BIT_SHIFT_CH2_RSVD_PG 0
#define BIT_MASK_CH2_RSVD_PG 0xfff
#define BIT_CH2_RSVD_PG(x) \
(((x) & BIT_MASK_CH2_RSVD_PG) << BIT_SHIFT_CH2_RSVD_PG)
#define BITS_CH2_RSVD_PG (BIT_MASK_CH2_RSVD_PG << BIT_SHIFT_CH2_RSVD_PG)
#define BIT_CLEAR_CH2_RSVD_PG(x) ((x) & (~BITS_CH2_RSVD_PG))
#define BIT_GET_CH2_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH2_RSVD_PG) & BIT_MASK_CH2_RSVD_PG)
#define BIT_SET_CH2_RSVD_PG(x, v) \
(BIT_CLEAR_CH2_RSVD_PG(x) | BIT_CH2_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_3 (Offset 0x220C) */
#define BIT_SHIFT_CH3_AVAL_PG 16
#define BIT_MASK_CH3_AVAL_PG 0xfff
#define BIT_CH3_AVAL_PG(x) \
(((x) & BIT_MASK_CH3_AVAL_PG) << BIT_SHIFT_CH3_AVAL_PG)
#define BITS_CH3_AVAL_PG (BIT_MASK_CH3_AVAL_PG << BIT_SHIFT_CH3_AVAL_PG)
#define BIT_CLEAR_CH3_AVAL_PG(x) ((x) & (~BITS_CH3_AVAL_PG))
#define BIT_GET_CH3_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH3_AVAL_PG) & BIT_MASK_CH3_AVAL_PG)
#define BIT_SET_CH3_AVAL_PG(x, v) \
(BIT_CLEAR_CH3_AVAL_PG(x) | BIT_CH3_AVAL_PG(v))
#define BIT_SHIFT_CH3_RSVD_PG 0
#define BIT_MASK_CH3_RSVD_PG 0xfff
#define BIT_CH3_RSVD_PG(x) \
(((x) & BIT_MASK_CH3_RSVD_PG) << BIT_SHIFT_CH3_RSVD_PG)
#define BITS_CH3_RSVD_PG (BIT_MASK_CH3_RSVD_PG << BIT_SHIFT_CH3_RSVD_PG)
#define BIT_CLEAR_CH3_RSVD_PG(x) ((x) & (~BITS_CH3_RSVD_PG))
#define BIT_GET_CH3_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH3_RSVD_PG) & BIT_MASK_CH3_RSVD_PG)
#define BIT_SET_CH3_RSVD_PG(x, v) \
(BIT_CLEAR_CH3_RSVD_PG(x) | BIT_CH3_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_4 (Offset 0x2210) */
#define BIT_SHIFT_CH4_AVAL_PG 16
#define BIT_MASK_CH4_AVAL_PG 0xfff
#define BIT_CH4_AVAL_PG(x) \
(((x) & BIT_MASK_CH4_AVAL_PG) << BIT_SHIFT_CH4_AVAL_PG)
#define BITS_CH4_AVAL_PG (BIT_MASK_CH4_AVAL_PG << BIT_SHIFT_CH4_AVAL_PG)
#define BIT_CLEAR_CH4_AVAL_PG(x) ((x) & (~BITS_CH4_AVAL_PG))
#define BIT_GET_CH4_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH4_AVAL_PG) & BIT_MASK_CH4_AVAL_PG)
#define BIT_SET_CH4_AVAL_PG(x, v) \
(BIT_CLEAR_CH4_AVAL_PG(x) | BIT_CH4_AVAL_PG(v))
#define BIT_SHIFT_CH4_RSVD_PG 0
#define BIT_MASK_CH4_RSVD_PG 0xfff
#define BIT_CH4_RSVD_PG(x) \
(((x) & BIT_MASK_CH4_RSVD_PG) << BIT_SHIFT_CH4_RSVD_PG)
#define BITS_CH4_RSVD_PG (BIT_MASK_CH4_RSVD_PG << BIT_SHIFT_CH4_RSVD_PG)
#define BIT_CLEAR_CH4_RSVD_PG(x) ((x) & (~BITS_CH4_RSVD_PG))
#define BIT_GET_CH4_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH4_RSVD_PG) & BIT_MASK_CH4_RSVD_PG)
#define BIT_SET_CH4_RSVD_PG(x, v) \
(BIT_CLEAR_CH4_RSVD_PG(x) | BIT_CH4_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_5 (Offset 0x2214) */
#define BIT_SHIFT_CH5_AVAL_PG 16
#define BIT_MASK_CH5_AVAL_PG 0xfff
#define BIT_CH5_AVAL_PG(x) \
(((x) & BIT_MASK_CH5_AVAL_PG) << BIT_SHIFT_CH5_AVAL_PG)
#define BITS_CH5_AVAL_PG (BIT_MASK_CH5_AVAL_PG << BIT_SHIFT_CH5_AVAL_PG)
#define BIT_CLEAR_CH5_AVAL_PG(x) ((x) & (~BITS_CH5_AVAL_PG))
#define BIT_GET_CH5_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH5_AVAL_PG) & BIT_MASK_CH5_AVAL_PG)
#define BIT_SET_CH5_AVAL_PG(x, v) \
(BIT_CLEAR_CH5_AVAL_PG(x) | BIT_CH5_AVAL_PG(v))
#define BIT_SHIFT_CH5_RSVD_PG 0
#define BIT_MASK_CH5_RSVD_PG 0xfff
#define BIT_CH5_RSVD_PG(x) \
(((x) & BIT_MASK_CH5_RSVD_PG) << BIT_SHIFT_CH5_RSVD_PG)
#define BITS_CH5_RSVD_PG (BIT_MASK_CH5_RSVD_PG << BIT_SHIFT_CH5_RSVD_PG)
#define BIT_CLEAR_CH5_RSVD_PG(x) ((x) & (~BITS_CH5_RSVD_PG))
#define BIT_GET_CH5_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH5_RSVD_PG) & BIT_MASK_CH5_RSVD_PG)
#define BIT_SET_CH5_RSVD_PG(x, v) \
(BIT_CLEAR_CH5_RSVD_PG(x) | BIT_CH5_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_6 (Offset 0x2218) */
#define BIT_SHIFT_CH6_AVAL_PG 16
#define BIT_MASK_CH6_AVAL_PG 0xfff
#define BIT_CH6_AVAL_PG(x) \
(((x) & BIT_MASK_CH6_AVAL_PG) << BIT_SHIFT_CH6_AVAL_PG)
#define BITS_CH6_AVAL_PG (BIT_MASK_CH6_AVAL_PG << BIT_SHIFT_CH6_AVAL_PG)
#define BIT_CLEAR_CH6_AVAL_PG(x) ((x) & (~BITS_CH6_AVAL_PG))
#define BIT_GET_CH6_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH6_AVAL_PG) & BIT_MASK_CH6_AVAL_PG)
#define BIT_SET_CH6_AVAL_PG(x, v) \
(BIT_CLEAR_CH6_AVAL_PG(x) | BIT_CH6_AVAL_PG(v))
#define BIT_SHIFT_CH6_RSVD_PG 0
#define BIT_MASK_CH6_RSVD_PG 0xfff
#define BIT_CH6_RSVD_PG(x) \
(((x) & BIT_MASK_CH6_RSVD_PG) << BIT_SHIFT_CH6_RSVD_PG)
#define BITS_CH6_RSVD_PG (BIT_MASK_CH6_RSVD_PG << BIT_SHIFT_CH6_RSVD_PG)
#define BIT_CLEAR_CH6_RSVD_PG(x) ((x) & (~BITS_CH6_RSVD_PG))
#define BIT_GET_CH6_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH6_RSVD_PG) & BIT_MASK_CH6_RSVD_PG)
#define BIT_SET_CH6_RSVD_PG(x, v) \
(BIT_CLEAR_CH6_RSVD_PG(x) | BIT_CH6_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_7 (Offset 0x221C) */
#define BIT_SHIFT_CH7_AVAL_PG 16
#define BIT_MASK_CH7_AVAL_PG 0xfff
#define BIT_CH7_AVAL_PG(x) \
(((x) & BIT_MASK_CH7_AVAL_PG) << BIT_SHIFT_CH7_AVAL_PG)
#define BITS_CH7_AVAL_PG (BIT_MASK_CH7_AVAL_PG << BIT_SHIFT_CH7_AVAL_PG)
#define BIT_CLEAR_CH7_AVAL_PG(x) ((x) & (~BITS_CH7_AVAL_PG))
#define BIT_GET_CH7_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH7_AVAL_PG) & BIT_MASK_CH7_AVAL_PG)
#define BIT_SET_CH7_AVAL_PG(x, v) \
(BIT_CLEAR_CH7_AVAL_PG(x) | BIT_CH7_AVAL_PG(v))
#define BIT_SHIFT_CH7_RSVD_PG 0
#define BIT_MASK_CH7_RSVD_PG 0xfff
#define BIT_CH7_RSVD_PG(x) \
(((x) & BIT_MASK_CH7_RSVD_PG) << BIT_SHIFT_CH7_RSVD_PG)
#define BITS_CH7_RSVD_PG (BIT_MASK_CH7_RSVD_PG << BIT_SHIFT_CH7_RSVD_PG)
#define BIT_CLEAR_CH7_RSVD_PG(x) ((x) & (~BITS_CH7_RSVD_PG))
#define BIT_GET_CH7_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH7_RSVD_PG) & BIT_MASK_CH7_RSVD_PG)
#define BIT_SET_CH7_RSVD_PG(x, v) \
(BIT_CLEAR_CH7_RSVD_PG(x) | BIT_CH7_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_8 (Offset 0x2220) */
#define BIT_SHIFT_CH8_AVAL_PG 16
#define BIT_MASK_CH8_AVAL_PG 0xfff
#define BIT_CH8_AVAL_PG(x) \
(((x) & BIT_MASK_CH8_AVAL_PG) << BIT_SHIFT_CH8_AVAL_PG)
#define BITS_CH8_AVAL_PG (BIT_MASK_CH8_AVAL_PG << BIT_SHIFT_CH8_AVAL_PG)
#define BIT_CLEAR_CH8_AVAL_PG(x) ((x) & (~BITS_CH8_AVAL_PG))
#define BIT_GET_CH8_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH8_AVAL_PG) & BIT_MASK_CH8_AVAL_PG)
#define BIT_SET_CH8_AVAL_PG(x, v) \
(BIT_CLEAR_CH8_AVAL_PG(x) | BIT_CH8_AVAL_PG(v))
#define BIT_SHIFT_CH8_RSVD_PG 0
#define BIT_MASK_CH8_RSVD_PG 0xfff
#define BIT_CH8_RSVD_PG(x) \
(((x) & BIT_MASK_CH8_RSVD_PG) << BIT_SHIFT_CH8_RSVD_PG)
#define BITS_CH8_RSVD_PG (BIT_MASK_CH8_RSVD_PG << BIT_SHIFT_CH8_RSVD_PG)
#define BIT_CLEAR_CH8_RSVD_PG(x) ((x) & (~BITS_CH8_RSVD_PG))
#define BIT_GET_CH8_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH8_RSVD_PG) & BIT_MASK_CH8_RSVD_PG)
#define BIT_SET_CH8_RSVD_PG(x, v) \
(BIT_CLEAR_CH8_RSVD_PG(x) | BIT_CH8_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_9 (Offset 0x2224) */
#define BIT_SHIFT_CH9_AVAL_PG 16
#define BIT_MASK_CH9_AVAL_PG 0xfff
#define BIT_CH9_AVAL_PG(x) \
(((x) & BIT_MASK_CH9_AVAL_PG) << BIT_SHIFT_CH9_AVAL_PG)
#define BITS_CH9_AVAL_PG (BIT_MASK_CH9_AVAL_PG << BIT_SHIFT_CH9_AVAL_PG)
#define BIT_CLEAR_CH9_AVAL_PG(x) ((x) & (~BITS_CH9_AVAL_PG))
#define BIT_GET_CH9_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH9_AVAL_PG) & BIT_MASK_CH9_AVAL_PG)
#define BIT_SET_CH9_AVAL_PG(x, v) \
(BIT_CLEAR_CH9_AVAL_PG(x) | BIT_CH9_AVAL_PG(v))
#define BIT_SHIFT_CH9_RSVD_PG 0
#define BIT_MASK_CH9_RSVD_PG 0xfff
#define BIT_CH9_RSVD_PG(x) \
(((x) & BIT_MASK_CH9_RSVD_PG) << BIT_SHIFT_CH9_RSVD_PG)
#define BITS_CH9_RSVD_PG (BIT_MASK_CH9_RSVD_PG << BIT_SHIFT_CH9_RSVD_PG)
#define BIT_CLEAR_CH9_RSVD_PG(x) ((x) & (~BITS_CH9_RSVD_PG))
#define BIT_GET_CH9_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH9_RSVD_PG) & BIT_MASK_CH9_RSVD_PG)
#define BIT_SET_CH9_RSVD_PG(x, v) \
(BIT_CLEAR_CH9_RSVD_PG(x) | BIT_CH9_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_10 (Offset 0x2228) */
#define BIT_SHIFT_CH10_AVAL_PG 16
#define BIT_MASK_CH10_AVAL_PG 0xfff
#define BIT_CH10_AVAL_PG(x) \
(((x) & BIT_MASK_CH10_AVAL_PG) << BIT_SHIFT_CH10_AVAL_PG)
#define BITS_CH10_AVAL_PG (BIT_MASK_CH10_AVAL_PG << BIT_SHIFT_CH10_AVAL_PG)
#define BIT_CLEAR_CH10_AVAL_PG(x) ((x) & (~BITS_CH10_AVAL_PG))
#define BIT_GET_CH10_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH10_AVAL_PG) & BIT_MASK_CH10_AVAL_PG)
#define BIT_SET_CH10_AVAL_PG(x, v) \
(BIT_CLEAR_CH10_AVAL_PG(x) | BIT_CH10_AVAL_PG(v))
#define BIT_SHIFT_CH10_RSVD_PG 0
#define BIT_MASK_CH10_RSVD_PG 0xfff
#define BIT_CH10_RSVD_PG(x) \
(((x) & BIT_MASK_CH10_RSVD_PG) << BIT_SHIFT_CH10_RSVD_PG)
#define BITS_CH10_RSVD_PG (BIT_MASK_CH10_RSVD_PG << BIT_SHIFT_CH10_RSVD_PG)
#define BIT_CLEAR_CH10_RSVD_PG(x) ((x) & (~BITS_CH10_RSVD_PG))
#define BIT_GET_CH10_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH10_RSVD_PG) & BIT_MASK_CH10_RSVD_PG)
#define BIT_SET_CH10_RSVD_PG(x, v) \
(BIT_CLEAR_CH10_RSVD_PG(x) | BIT_CH10_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_11 (Offset 0x222C) */
#define BIT_SHIFT_CH11_AVAL_PG 16
#define BIT_MASK_CH11_AVAL_PG 0xfff
#define BIT_CH11_AVAL_PG(x) \
(((x) & BIT_MASK_CH11_AVAL_PG) << BIT_SHIFT_CH11_AVAL_PG)
#define BITS_CH11_AVAL_PG (BIT_MASK_CH11_AVAL_PG << BIT_SHIFT_CH11_AVAL_PG)
#define BIT_CLEAR_CH11_AVAL_PG(x) ((x) & (~BITS_CH11_AVAL_PG))
#define BIT_GET_CH11_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH11_AVAL_PG) & BIT_MASK_CH11_AVAL_PG)
#define BIT_SET_CH11_AVAL_PG(x, v) \
(BIT_CLEAR_CH11_AVAL_PG(x) | BIT_CH11_AVAL_PG(v))
#define BIT_SHIFT_CH11_RSVD_PG 0
#define BIT_MASK_CH11_RSVD_PG 0xfff
#define BIT_CH11_RSVD_PG(x) \
(((x) & BIT_MASK_CH11_RSVD_PG) << BIT_SHIFT_CH11_RSVD_PG)
#define BITS_CH11_RSVD_PG (BIT_MASK_CH11_RSVD_PG << BIT_SHIFT_CH11_RSVD_PG)
#define BIT_CLEAR_CH11_RSVD_PG(x) ((x) & (~BITS_CH11_RSVD_PG))
#define BIT_GET_CH11_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH11_RSVD_PG) & BIT_MASK_CH11_RSVD_PG)
#define BIT_SET_CH11_RSVD_PG(x, v) \
(BIT_CLEAR_CH11_RSVD_PG(x) | BIT_CH11_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_12 (Offset 0x2230) */
#define BIT_SHIFT_CH12_AVAL_PG 16
#define BIT_MASK_CH12_AVAL_PG 0xfff
#define BIT_CH12_AVAL_PG(x) \
(((x) & BIT_MASK_CH12_AVAL_PG) << BIT_SHIFT_CH12_AVAL_PG)
#define BITS_CH12_AVAL_PG (BIT_MASK_CH12_AVAL_PG << BIT_SHIFT_CH12_AVAL_PG)
#define BIT_CLEAR_CH12_AVAL_PG(x) ((x) & (~BITS_CH12_AVAL_PG))
#define BIT_GET_CH12_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH12_AVAL_PG) & BIT_MASK_CH12_AVAL_PG)
#define BIT_SET_CH12_AVAL_PG(x, v) \
(BIT_CLEAR_CH12_AVAL_PG(x) | BIT_CH12_AVAL_PG(v))
#define BIT_SHIFT_CH12_RSVD_PG 0
#define BIT_MASK_CH12_RSVD_PG 0xfff
#define BIT_CH12_RSVD_PG(x) \
(((x) & BIT_MASK_CH12_RSVD_PG) << BIT_SHIFT_CH12_RSVD_PG)
#define BITS_CH12_RSVD_PG (BIT_MASK_CH12_RSVD_PG << BIT_SHIFT_CH12_RSVD_PG)
#define BIT_CLEAR_CH12_RSVD_PG(x) ((x) & (~BITS_CH12_RSVD_PG))
#define BIT_GET_CH12_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH12_RSVD_PG) & BIT_MASK_CH12_RSVD_PG)
#define BIT_SET_CH12_RSVD_PG(x, v) \
(BIT_CLEAR_CH12_RSVD_PG(x) | BIT_CH12_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_13 (Offset 0x2234) */
#define BIT_SHIFT_CH13_AVAL_PG 16
#define BIT_MASK_CH13_AVAL_PG 0xfff
#define BIT_CH13_AVAL_PG(x) \
(((x) & BIT_MASK_CH13_AVAL_PG) << BIT_SHIFT_CH13_AVAL_PG)
#define BITS_CH13_AVAL_PG (BIT_MASK_CH13_AVAL_PG << BIT_SHIFT_CH13_AVAL_PG)
#define BIT_CLEAR_CH13_AVAL_PG(x) ((x) & (~BITS_CH13_AVAL_PG))
#define BIT_GET_CH13_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH13_AVAL_PG) & BIT_MASK_CH13_AVAL_PG)
#define BIT_SET_CH13_AVAL_PG(x, v) \
(BIT_CLEAR_CH13_AVAL_PG(x) | BIT_CH13_AVAL_PG(v))
#define BIT_SHIFT_CH13_RSVD_PG 0
#define BIT_MASK_CH13_RSVD_PG 0xfff
#define BIT_CH13_RSVD_PG(x) \
(((x) & BIT_MASK_CH13_RSVD_PG) << BIT_SHIFT_CH13_RSVD_PG)
#define BITS_CH13_RSVD_PG (BIT_MASK_CH13_RSVD_PG << BIT_SHIFT_CH13_RSVD_PG)
#define BIT_CLEAR_CH13_RSVD_PG(x) ((x) & (~BITS_CH13_RSVD_PG))
#define BIT_GET_CH13_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH13_RSVD_PG) & BIT_MASK_CH13_RSVD_PG)
#define BIT_SET_CH13_RSVD_PG(x, v) \
(BIT_CLEAR_CH13_RSVD_PG(x) | BIT_CH13_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_14 (Offset 0x2238) */
#define BIT_SHIFT_CH14_AVAL_PG 16
#define BIT_MASK_CH14_AVAL_PG 0xfff
#define BIT_CH14_AVAL_PG(x) \
(((x) & BIT_MASK_CH14_AVAL_PG) << BIT_SHIFT_CH14_AVAL_PG)
#define BITS_CH14_AVAL_PG (BIT_MASK_CH14_AVAL_PG << BIT_SHIFT_CH14_AVAL_PG)
#define BIT_CLEAR_CH14_AVAL_PG(x) ((x) & (~BITS_CH14_AVAL_PG))
#define BIT_GET_CH14_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH14_AVAL_PG) & BIT_MASK_CH14_AVAL_PG)
#define BIT_SET_CH14_AVAL_PG(x, v) \
(BIT_CLEAR_CH14_AVAL_PG(x) | BIT_CH14_AVAL_PG(v))
#define BIT_SHIFT_CH14_RSVD_PG 0
#define BIT_MASK_CH14_RSVD_PG 0xfff
#define BIT_CH14_RSVD_PG(x) \
(((x) & BIT_MASK_CH14_RSVD_PG) << BIT_SHIFT_CH14_RSVD_PG)
#define BITS_CH14_RSVD_PG (BIT_MASK_CH14_RSVD_PG << BIT_SHIFT_CH14_RSVD_PG)
#define BIT_CLEAR_CH14_RSVD_PG(x) ((x) & (~BITS_CH14_RSVD_PG))
#define BIT_GET_CH14_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH14_RSVD_PG) & BIT_MASK_CH14_RSVD_PG)
#define BIT_SET_CH14_RSVD_PG(x, v) \
(BIT_CLEAR_CH14_RSVD_PG(x) | BIT_CH14_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_15 (Offset 0x223C) */
#define BIT_SHIFT_CH15_AVAL_PG 16
#define BIT_MASK_CH15_AVAL_PG 0xfff
#define BIT_CH15_AVAL_PG(x) \
(((x) & BIT_MASK_CH15_AVAL_PG) << BIT_SHIFT_CH15_AVAL_PG)
#define BITS_CH15_AVAL_PG (BIT_MASK_CH15_AVAL_PG << BIT_SHIFT_CH15_AVAL_PG)
#define BIT_CLEAR_CH15_AVAL_PG(x) ((x) & (~BITS_CH15_AVAL_PG))
#define BIT_GET_CH15_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH15_AVAL_PG) & BIT_MASK_CH15_AVAL_PG)
#define BIT_SET_CH15_AVAL_PG(x, v) \
(BIT_CLEAR_CH15_AVAL_PG(x) | BIT_CH15_AVAL_PG(v))
#define BIT_SHIFT_CH15_RSVD_PG 0
#define BIT_MASK_CH15_RSVD_PG 0xfff
#define BIT_CH15_RSVD_PG(x) \
(((x) & BIT_MASK_CH15_RSVD_PG) << BIT_SHIFT_CH15_RSVD_PG)
#define BITS_CH15_RSVD_PG (BIT_MASK_CH15_RSVD_PG << BIT_SHIFT_CH15_RSVD_PG)
#define BIT_CLEAR_CH15_RSVD_PG(x) ((x) & (~BITS_CH15_RSVD_PG))
#define BIT_GET_CH15_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH15_RSVD_PG) & BIT_MASK_CH15_RSVD_PG)
#define BIT_SET_CH15_RSVD_PG(x, v) \
(BIT_CLEAR_CH15_RSVD_PG(x) | BIT_CH15_RSVD_PG(v))
/* 2 REG_DMA_RQPN_INFO_16 (Offset 0x2240) */
#define BIT_SHIFT_CH16_AVAL_PG 16
#define BIT_MASK_CH16_AVAL_PG 0xfff
#define BIT_CH16_AVAL_PG(x) \
(((x) & BIT_MASK_CH16_AVAL_PG) << BIT_SHIFT_CH16_AVAL_PG)
#define BITS_CH16_AVAL_PG (BIT_MASK_CH16_AVAL_PG << BIT_SHIFT_CH16_AVAL_PG)
#define BIT_CLEAR_CH16_AVAL_PG(x) ((x) & (~BITS_CH16_AVAL_PG))
#define BIT_GET_CH16_AVAL_PG(x) \
(((x) >> BIT_SHIFT_CH16_AVAL_PG) & BIT_MASK_CH16_AVAL_PG)
#define BIT_SET_CH16_AVAL_PG(x, v) \
(BIT_CLEAR_CH16_AVAL_PG(x) | BIT_CH16_AVAL_PG(v))
#define BIT_SHIFT_CH16_RSVD_PG 0
#define BIT_MASK_CH16_RSVD_PG 0xfff
#define BIT_CH16_RSVD_PG(x) \
(((x) & BIT_MASK_CH16_RSVD_PG) << BIT_SHIFT_CH16_RSVD_PG)
#define BITS_CH16_RSVD_PG (BIT_MASK_CH16_RSVD_PG << BIT_SHIFT_CH16_RSVD_PG)
#define BIT_CLEAR_CH16_RSVD_PG(x) ((x) & (~BITS_CH16_RSVD_PG))
#define BIT_GET_CH16_RSVD_PG(x) \
(((x) >> BIT_SHIFT_CH16_RSVD_PG) & BIT_MASK_CH16_RSVD_PG)
#define BIT_SET_CH16_RSVD_PG(x, v) \
(BIT_CLEAR_CH16_RSVD_PG(x) | BIT_CH16_RSVD_PG(v))
/* 2 REG_HWAMSDU_CTL1 (Offset 0x2250) */
#define BIT_SHIFT_HWAMSDU_PKTNUM 8
#define BIT_MASK_HWAMSDU_PKTNUM 0x3f
#define BIT_HWAMSDU_PKTNUM(x) \
(((x) & BIT_MASK_HWAMSDU_PKTNUM) << BIT_SHIFT_HWAMSDU_PKTNUM)
#define BITS_HWAMSDU_PKTNUM \
(BIT_MASK_HWAMSDU_PKTNUM << BIT_SHIFT_HWAMSDU_PKTNUM)
#define BIT_CLEAR_HWAMSDU_PKTNUM(x) ((x) & (~BITS_HWAMSDU_PKTNUM))
#define BIT_GET_HWAMSDU_PKTNUM(x) \
(((x) >> BIT_SHIFT_HWAMSDU_PKTNUM) & BIT_MASK_HWAMSDU_PKTNUM)
#define BIT_SET_HWAMSDU_PKTNUM(x, v) \
(BIT_CLEAR_HWAMSDU_PKTNUM(x) | BIT_HWAMSDU_PKTNUM(v))
#define BIT_HWAMSDU_BUSY BIT(7)
#define BIT_SINGLE_AMSDU BIT(2)
#define BIT_HWAMSDU_PADDING_MODE BIT(1)
#define BIT_HWAMSDU_EN BIT(0)
/* 2 REG_HWAMSDU_CTL2 (Offset 0x2254) */
#define BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT 16
#define BIT_MASK_HWAMSDU_AMSDU_TIMEOUT 0xffff
#define BIT_HWAMSDU_AMSDU_TIMEOUT(x) \
(((x) & BIT_MASK_HWAMSDU_AMSDU_TIMEOUT) \
<< BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT)
#define BITS_HWAMSDU_AMSDU_TIMEOUT \
(BIT_MASK_HWAMSDU_AMSDU_TIMEOUT << BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT)
#define BIT_CLEAR_HWAMSDU_AMSDU_TIMEOUT(x) ((x) & (~BITS_HWAMSDU_AMSDU_TIMEOUT))
#define BIT_GET_HWAMSDU_AMSDU_TIMEOUT(x) \
(((x) >> BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT) & \
BIT_MASK_HWAMSDU_AMSDU_TIMEOUT)
#define BIT_SET_HWAMSDU_AMSDU_TIMEOUT(x, v) \
(BIT_CLEAR_HWAMSDU_AMSDU_TIMEOUT(x) | BIT_HWAMSDU_AMSDU_TIMEOUT(v))
#define BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT 0
#define BIT_MASK_HWAMSDU_MSDU_TIMEOUT 0xffff
#define BIT_HWAMSDU_MSDU_TIMEOUT(x) \
(((x) & BIT_MASK_HWAMSDU_MSDU_TIMEOUT) \
<< BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT)
#define BITS_HWAMSDU_MSDU_TIMEOUT \
(BIT_MASK_HWAMSDU_MSDU_TIMEOUT << BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT)
#define BIT_CLEAR_HWAMSDU_MSDU_TIMEOUT(x) ((x) & (~BITS_HWAMSDU_MSDU_TIMEOUT))
#define BIT_GET_HWAMSDU_MSDU_TIMEOUT(x) \
(((x) >> BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT) & \
BIT_MASK_HWAMSDU_MSDU_TIMEOUT)
#define BIT_SET_HWAMSDU_MSDU_TIMEOUT(x, v) \
(BIT_CLEAR_HWAMSDU_MSDU_TIMEOUT(x) | BIT_HWAMSDU_MSDU_TIMEOUT(v))
/* 2 REG_HI8Q_TXBD_DESA_L (Offset 0x2300) */
#define BIT_SHIFT_HI8Q_TXBD_DESA_L 0
#define BIT_MASK_HI8Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI8Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI8Q_TXBD_DESA_L) << BIT_SHIFT_HI8Q_TXBD_DESA_L)
#define BITS_HI8Q_TXBD_DESA_L \
(BIT_MASK_HI8Q_TXBD_DESA_L << BIT_SHIFT_HI8Q_TXBD_DESA_L)
#define BIT_CLEAR_HI8Q_TXBD_DESA_L(x) ((x) & (~BITS_HI8Q_TXBD_DESA_L))
#define BIT_GET_HI8Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI8Q_TXBD_DESA_L) & BIT_MASK_HI8Q_TXBD_DESA_L)
#define BIT_SET_HI8Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI8Q_TXBD_DESA_L(x) | BIT_HI8Q_TXBD_DESA_L(v))
/* 2 REG_HI8Q_TXBD_DESA_H (Offset 0x2304) */
#define BIT_SHIFT_HI8Q_TXBD_DESA_H 0
#define BIT_MASK_HI8Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI8Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI8Q_TXBD_DESA_H) << BIT_SHIFT_HI8Q_TXBD_DESA_H)
#define BITS_HI8Q_TXBD_DESA_H \
(BIT_MASK_HI8Q_TXBD_DESA_H << BIT_SHIFT_HI8Q_TXBD_DESA_H)
#define BIT_CLEAR_HI8Q_TXBD_DESA_H(x) ((x) & (~BITS_HI8Q_TXBD_DESA_H))
#define BIT_GET_HI8Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI8Q_TXBD_DESA_H) & BIT_MASK_HI8Q_TXBD_DESA_H)
#define BIT_SET_HI8Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI8Q_TXBD_DESA_H(x) | BIT_HI8Q_TXBD_DESA_H(v))
/* 2 REG_HI9Q_TXBD_DESA_L (Offset 0x2308) */
#define BIT_SHIFT_HI9Q_TXBD_DESA_L 0
#define BIT_MASK_HI9Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI9Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI9Q_TXBD_DESA_L) << BIT_SHIFT_HI9Q_TXBD_DESA_L)
#define BITS_HI9Q_TXBD_DESA_L \
(BIT_MASK_HI9Q_TXBD_DESA_L << BIT_SHIFT_HI9Q_TXBD_DESA_L)
#define BIT_CLEAR_HI9Q_TXBD_DESA_L(x) ((x) & (~BITS_HI9Q_TXBD_DESA_L))
#define BIT_GET_HI9Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI9Q_TXBD_DESA_L) & BIT_MASK_HI9Q_TXBD_DESA_L)
#define BIT_SET_HI9Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI9Q_TXBD_DESA_L(x) | BIT_HI9Q_TXBD_DESA_L(v))
/* 2 REG_HI9Q_TXBD_DESA_H (Offset 0x230C) */
#define BIT_SHIFT_HI9Q_TXBD_DESA_H 0
#define BIT_MASK_HI9Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI9Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI9Q_TXBD_DESA_H) << BIT_SHIFT_HI9Q_TXBD_DESA_H)
#define BITS_HI9Q_TXBD_DESA_H \
(BIT_MASK_HI9Q_TXBD_DESA_H << BIT_SHIFT_HI9Q_TXBD_DESA_H)
#define BIT_CLEAR_HI9Q_TXBD_DESA_H(x) ((x) & (~BITS_HI9Q_TXBD_DESA_H))
#define BIT_GET_HI9Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI9Q_TXBD_DESA_H) & BIT_MASK_HI9Q_TXBD_DESA_H)
#define BIT_SET_HI9Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI9Q_TXBD_DESA_H(x) | BIT_HI9Q_TXBD_DESA_H(v))
/* 2 REG_HI10Q_TXBD_DESA_L (Offset 0x2310) */
#define BIT_SHIFT_HI10Q_TXBD_DESA_L 0
#define BIT_MASK_HI10Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI10Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI10Q_TXBD_DESA_L) << BIT_SHIFT_HI10Q_TXBD_DESA_L)
#define BITS_HI10Q_TXBD_DESA_L \
(BIT_MASK_HI10Q_TXBD_DESA_L << BIT_SHIFT_HI10Q_TXBD_DESA_L)
#define BIT_CLEAR_HI10Q_TXBD_DESA_L(x) ((x) & (~BITS_HI10Q_TXBD_DESA_L))
#define BIT_GET_HI10Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI10Q_TXBD_DESA_L) & BIT_MASK_HI10Q_TXBD_DESA_L)
#define BIT_SET_HI10Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI10Q_TXBD_DESA_L(x) | BIT_HI10Q_TXBD_DESA_L(v))
/* 2 REG_HI10Q_TXBD_DESA_H (Offset 0x2314) */
#define BIT_SHIFT_HI10Q_TXBD_DESA_H 0
#define BIT_MASK_HI10Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI10Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI10Q_TXBD_DESA_H) << BIT_SHIFT_HI10Q_TXBD_DESA_H)
#define BITS_HI10Q_TXBD_DESA_H \
(BIT_MASK_HI10Q_TXBD_DESA_H << BIT_SHIFT_HI10Q_TXBD_DESA_H)
#define BIT_CLEAR_HI10Q_TXBD_DESA_H(x) ((x) & (~BITS_HI10Q_TXBD_DESA_H))
#define BIT_GET_HI10Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI10Q_TXBD_DESA_H) & BIT_MASK_HI10Q_TXBD_DESA_H)
#define BIT_SET_HI10Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI10Q_TXBD_DESA_H(x) | BIT_HI10Q_TXBD_DESA_H(v))
/* 2 REG_HI11Q_TXBD_DESA_L (Offset 0x2318) */
#define BIT_SHIFT_HI11Q_TXBD_DESA_L 0
#define BIT_MASK_HI11Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI11Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI11Q_TXBD_DESA_L) << BIT_SHIFT_HI11Q_TXBD_DESA_L)
#define BITS_HI11Q_TXBD_DESA_L \
(BIT_MASK_HI11Q_TXBD_DESA_L << BIT_SHIFT_HI11Q_TXBD_DESA_L)
#define BIT_CLEAR_HI11Q_TXBD_DESA_L(x) ((x) & (~BITS_HI11Q_TXBD_DESA_L))
#define BIT_GET_HI11Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI11Q_TXBD_DESA_L) & BIT_MASK_HI11Q_TXBD_DESA_L)
#define BIT_SET_HI11Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI11Q_TXBD_DESA_L(x) | BIT_HI11Q_TXBD_DESA_L(v))
/* 2 REG_HI11Q_TXBD_DESA_H (Offset 0x231C) */
#define BIT_SHIFT_HI11Q_TXBD_DESA_H 0
#define BIT_MASK_HI11Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI11Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI11Q_TXBD_DESA_H) << BIT_SHIFT_HI11Q_TXBD_DESA_H)
#define BITS_HI11Q_TXBD_DESA_H \
(BIT_MASK_HI11Q_TXBD_DESA_H << BIT_SHIFT_HI11Q_TXBD_DESA_H)
#define BIT_CLEAR_HI11Q_TXBD_DESA_H(x) ((x) & (~BITS_HI11Q_TXBD_DESA_H))
#define BIT_GET_HI11Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI11Q_TXBD_DESA_H) & BIT_MASK_HI11Q_TXBD_DESA_H)
#define BIT_SET_HI11Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI11Q_TXBD_DESA_H(x) | BIT_HI11Q_TXBD_DESA_H(v))
/* 2 REG_HI12Q_TXBD_DESA_L (Offset 0x2320) */
#define BIT_SHIFT_HI12Q_TXBD_DESA_L 0
#define BIT_MASK_HI12Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI12Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI12Q_TXBD_DESA_L) << BIT_SHIFT_HI12Q_TXBD_DESA_L)
#define BITS_HI12Q_TXBD_DESA_L \
(BIT_MASK_HI12Q_TXBD_DESA_L << BIT_SHIFT_HI12Q_TXBD_DESA_L)
#define BIT_CLEAR_HI12Q_TXBD_DESA_L(x) ((x) & (~BITS_HI12Q_TXBD_DESA_L))
#define BIT_GET_HI12Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI12Q_TXBD_DESA_L) & BIT_MASK_HI12Q_TXBD_DESA_L)
#define BIT_SET_HI12Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI12Q_TXBD_DESA_L(x) | BIT_HI12Q_TXBD_DESA_L(v))
/* 2 REG_HI12Q_TXBD_DESA_H (Offset 0x2324) */
#define BIT_SHIFT_HI12Q_TXBD_DESA_H 0
#define BIT_MASK_HI12Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI12Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI12Q_TXBD_DESA_H) << BIT_SHIFT_HI12Q_TXBD_DESA_H)
#define BITS_HI12Q_TXBD_DESA_H \
(BIT_MASK_HI12Q_TXBD_DESA_H << BIT_SHIFT_HI12Q_TXBD_DESA_H)
#define BIT_CLEAR_HI12Q_TXBD_DESA_H(x) ((x) & (~BITS_HI12Q_TXBD_DESA_H))
#define BIT_GET_HI12Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI12Q_TXBD_DESA_H) & BIT_MASK_HI12Q_TXBD_DESA_H)
#define BIT_SET_HI12Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI12Q_TXBD_DESA_H(x) | BIT_HI12Q_TXBD_DESA_H(v))
/* 2 REG_HI13Q_TXBD_DESA_L (Offset 0x2328) */
#define BIT_SHIFT_HI13Q_TXBD_DESA_L 0
#define BIT_MASK_HI13Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI13Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI13Q_TXBD_DESA_L) << BIT_SHIFT_HI13Q_TXBD_DESA_L)
#define BITS_HI13Q_TXBD_DESA_L \
(BIT_MASK_HI13Q_TXBD_DESA_L << BIT_SHIFT_HI13Q_TXBD_DESA_L)
#define BIT_CLEAR_HI13Q_TXBD_DESA_L(x) ((x) & (~BITS_HI13Q_TXBD_DESA_L))
#define BIT_GET_HI13Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI13Q_TXBD_DESA_L) & BIT_MASK_HI13Q_TXBD_DESA_L)
#define BIT_SET_HI13Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI13Q_TXBD_DESA_L(x) | BIT_HI13Q_TXBD_DESA_L(v))
/* 2 REG_HI13Q_TXBD_DESA_H (Offset 0x232C) */
#define BIT_SHIFT_HI13Q_TXBD_DESA_H 0
#define BIT_MASK_HI13Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI13Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI13Q_TXBD_DESA_H) << BIT_SHIFT_HI13Q_TXBD_DESA_H)
#define BITS_HI13Q_TXBD_DESA_H \
(BIT_MASK_HI13Q_TXBD_DESA_H << BIT_SHIFT_HI13Q_TXBD_DESA_H)
#define BIT_CLEAR_HI13Q_TXBD_DESA_H(x) ((x) & (~BITS_HI13Q_TXBD_DESA_H))
#define BIT_GET_HI13Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI13Q_TXBD_DESA_H) & BIT_MASK_HI13Q_TXBD_DESA_H)
#define BIT_SET_HI13Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI13Q_TXBD_DESA_H(x) | BIT_HI13Q_TXBD_DESA_H(v))
/* 2 REG_HI14Q_TXBD_DESA_L (Offset 0x2330) */
#define BIT_SHIFT_HI14Q_TXBD_DESA_L 0
#define BIT_MASK_HI14Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI14Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI14Q_TXBD_DESA_L) << BIT_SHIFT_HI14Q_TXBD_DESA_L)
#define BITS_HI14Q_TXBD_DESA_L \
(BIT_MASK_HI14Q_TXBD_DESA_L << BIT_SHIFT_HI14Q_TXBD_DESA_L)
#define BIT_CLEAR_HI14Q_TXBD_DESA_L(x) ((x) & (~BITS_HI14Q_TXBD_DESA_L))
#define BIT_GET_HI14Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI14Q_TXBD_DESA_L) & BIT_MASK_HI14Q_TXBD_DESA_L)
#define BIT_SET_HI14Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI14Q_TXBD_DESA_L(x) | BIT_HI14Q_TXBD_DESA_L(v))
/* 2 REG_HI14Q_TXBD_DESA_H (Offset 0x2334) */
#define BIT_SHIFT_HI14Q_TXBD_DESA_H 0
#define BIT_MASK_HI14Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI14Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI14Q_TXBD_DESA_H) << BIT_SHIFT_HI14Q_TXBD_DESA_H)
#define BITS_HI14Q_TXBD_DESA_H \
(BIT_MASK_HI14Q_TXBD_DESA_H << BIT_SHIFT_HI14Q_TXBD_DESA_H)
#define BIT_CLEAR_HI14Q_TXBD_DESA_H(x) ((x) & (~BITS_HI14Q_TXBD_DESA_H))
#define BIT_GET_HI14Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI14Q_TXBD_DESA_H) & BIT_MASK_HI14Q_TXBD_DESA_H)
#define BIT_SET_HI14Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI14Q_TXBD_DESA_H(x) | BIT_HI14Q_TXBD_DESA_H(v))
/* 2 REG_HI15Q_TXBD_DESA_L (Offset 0x2338) */
#define BIT_SHIFT_HI15Q_TXBD_DESA_L 0
#define BIT_MASK_HI15Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI15Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI15Q_TXBD_DESA_L) << BIT_SHIFT_HI15Q_TXBD_DESA_L)
#define BITS_HI15Q_TXBD_DESA_L \
(BIT_MASK_HI15Q_TXBD_DESA_L << BIT_SHIFT_HI15Q_TXBD_DESA_L)
#define BIT_CLEAR_HI15Q_TXBD_DESA_L(x) ((x) & (~BITS_HI15Q_TXBD_DESA_L))
#define BIT_GET_HI15Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI15Q_TXBD_DESA_L) & BIT_MASK_HI15Q_TXBD_DESA_L)
#define BIT_SET_HI15Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI15Q_TXBD_DESA_L(x) | BIT_HI15Q_TXBD_DESA_L(v))
/* 2 REG_HI15Q_TXBD_DESA_H (Offset 0x233C) */
#define BIT_SHIFT_HI15Q_TXBD_DESA_H 0
#define BIT_MASK_HI15Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI15Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI15Q_TXBD_DESA_H) << BIT_SHIFT_HI15Q_TXBD_DESA_H)
#define BITS_HI15Q_TXBD_DESA_H \
(BIT_MASK_HI15Q_TXBD_DESA_H << BIT_SHIFT_HI15Q_TXBD_DESA_H)
#define BIT_CLEAR_HI15Q_TXBD_DESA_H(x) ((x) & (~BITS_HI15Q_TXBD_DESA_H))
#define BIT_GET_HI15Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI15Q_TXBD_DESA_H) & BIT_MASK_HI15Q_TXBD_DESA_H)
#define BIT_SET_HI15Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI15Q_TXBD_DESA_H(x) | BIT_HI15Q_TXBD_DESA_H(v))
/* 2 REG_HI16Q_TXBD_DESA_L (Offset 0x2340) */
#define BIT_SHIFT_HI16Q_TXBD_DESA_L 0
#define BIT_MASK_HI16Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI16Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI16Q_TXBD_DESA_L) << BIT_SHIFT_HI16Q_TXBD_DESA_L)
#define BITS_HI16Q_TXBD_DESA_L \
(BIT_MASK_HI16Q_TXBD_DESA_L << BIT_SHIFT_HI16Q_TXBD_DESA_L)
#define BIT_CLEAR_HI16Q_TXBD_DESA_L(x) ((x) & (~BITS_HI16Q_TXBD_DESA_L))
#define BIT_GET_HI16Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI16Q_TXBD_DESA_L) & BIT_MASK_HI16Q_TXBD_DESA_L)
#define BIT_SET_HI16Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI16Q_TXBD_DESA_L(x) | BIT_HI16Q_TXBD_DESA_L(v))
/* 2 REG_HI16Q_TXBD_DESA_H (Offset 0x2344) */
#define BIT_SHIFT_HI16Q_TXBD_DESA_H 0
#define BIT_MASK_HI16Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI16Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI16Q_TXBD_DESA_H) << BIT_SHIFT_HI16Q_TXBD_DESA_H)
#define BITS_HI16Q_TXBD_DESA_H \
(BIT_MASK_HI16Q_TXBD_DESA_H << BIT_SHIFT_HI16Q_TXBD_DESA_H)
#define BIT_CLEAR_HI16Q_TXBD_DESA_H(x) ((x) & (~BITS_HI16Q_TXBD_DESA_H))
#define BIT_GET_HI16Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI16Q_TXBD_DESA_H) & BIT_MASK_HI16Q_TXBD_DESA_H)
#define BIT_SET_HI16Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI16Q_TXBD_DESA_H(x) | BIT_HI16Q_TXBD_DESA_H(v))
/* 2 REG_HI17Q_TXBD_DESA_L (Offset 0x2348) */
#define BIT_SHIFT_HI17Q_TXBD_DESA_L 0
#define BIT_MASK_HI17Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI17Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI17Q_TXBD_DESA_L) << BIT_SHIFT_HI17Q_TXBD_DESA_L)
#define BITS_HI17Q_TXBD_DESA_L \
(BIT_MASK_HI17Q_TXBD_DESA_L << BIT_SHIFT_HI17Q_TXBD_DESA_L)
#define BIT_CLEAR_HI17Q_TXBD_DESA_L(x) ((x) & (~BITS_HI17Q_TXBD_DESA_L))
#define BIT_GET_HI17Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI17Q_TXBD_DESA_L) & BIT_MASK_HI17Q_TXBD_DESA_L)
#define BIT_SET_HI17Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI17Q_TXBD_DESA_L(x) | BIT_HI17Q_TXBD_DESA_L(v))
/* 2 REG_HI17Q_TXBD_DESA_H (Offset 0x234C) */
#define BIT_SHIFT_HI17Q_TXBD_DESA_H 0
#define BIT_MASK_HI17Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI17Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI17Q_TXBD_DESA_H) << BIT_SHIFT_HI17Q_TXBD_DESA_H)
#define BITS_HI17Q_TXBD_DESA_H \
(BIT_MASK_HI17Q_TXBD_DESA_H << BIT_SHIFT_HI17Q_TXBD_DESA_H)
#define BIT_CLEAR_HI17Q_TXBD_DESA_H(x) ((x) & (~BITS_HI17Q_TXBD_DESA_H))
#define BIT_GET_HI17Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI17Q_TXBD_DESA_H) & BIT_MASK_HI17Q_TXBD_DESA_H)
#define BIT_SET_HI17Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI17Q_TXBD_DESA_H(x) | BIT_HI17Q_TXBD_DESA_H(v))
/* 2 REG_HI18Q_TXBD_DESA_L (Offset 0x2350) */
#define BIT_SHIFT_HI18Q_TXBD_DESA_L 0
#define BIT_MASK_HI18Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI18Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI18Q_TXBD_DESA_L) << BIT_SHIFT_HI18Q_TXBD_DESA_L)
#define BITS_HI18Q_TXBD_DESA_L \
(BIT_MASK_HI18Q_TXBD_DESA_L << BIT_SHIFT_HI18Q_TXBD_DESA_L)
#define BIT_CLEAR_HI18Q_TXBD_DESA_L(x) ((x) & (~BITS_HI18Q_TXBD_DESA_L))
#define BIT_GET_HI18Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI18Q_TXBD_DESA_L) & BIT_MASK_HI18Q_TXBD_DESA_L)
#define BIT_SET_HI18Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI18Q_TXBD_DESA_L(x) | BIT_HI18Q_TXBD_DESA_L(v))
/* 2 REG_HI18Q_TXBD_DESA_H (Offset 0x2354) */
#define BIT_SHIFT_HI18Q_TXBD_DESA_H 0
#define BIT_MASK_HI18Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI18Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI18Q_TXBD_DESA_H) << BIT_SHIFT_HI18Q_TXBD_DESA_H)
#define BITS_HI18Q_TXBD_DESA_H \
(BIT_MASK_HI18Q_TXBD_DESA_H << BIT_SHIFT_HI18Q_TXBD_DESA_H)
#define BIT_CLEAR_HI18Q_TXBD_DESA_H(x) ((x) & (~BITS_HI18Q_TXBD_DESA_H))
#define BIT_GET_HI18Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI18Q_TXBD_DESA_H) & BIT_MASK_HI18Q_TXBD_DESA_H)
#define BIT_SET_HI18Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI18Q_TXBD_DESA_H(x) | BIT_HI18Q_TXBD_DESA_H(v))
/* 2 REG_HI19Q_TXBD_DESA_L (Offset 0x2358) */
#define BIT_SHIFT_HI19Q_TXBD_DESA_L 0
#define BIT_MASK_HI19Q_TXBD_DESA_L 0xffffffffL
#define BIT_HI19Q_TXBD_DESA_L(x) \
(((x) & BIT_MASK_HI19Q_TXBD_DESA_L) << BIT_SHIFT_HI19Q_TXBD_DESA_L)
#define BITS_HI19Q_TXBD_DESA_L \
(BIT_MASK_HI19Q_TXBD_DESA_L << BIT_SHIFT_HI19Q_TXBD_DESA_L)
#define BIT_CLEAR_HI19Q_TXBD_DESA_L(x) ((x) & (~BITS_HI19Q_TXBD_DESA_L))
#define BIT_GET_HI19Q_TXBD_DESA_L(x) \
(((x) >> BIT_SHIFT_HI19Q_TXBD_DESA_L) & BIT_MASK_HI19Q_TXBD_DESA_L)
#define BIT_SET_HI19Q_TXBD_DESA_L(x, v) \
(BIT_CLEAR_HI19Q_TXBD_DESA_L(x) | BIT_HI19Q_TXBD_DESA_L(v))
/* 2 REG_HI19Q_TXBD_DESA_H (Offset 0x235C) */
#define BIT_CLR_P0HI19Q_HW_IDX BIT(25)
#define BIT_CLR_P0HI18Q_HW_IDX BIT(24)
#define BIT_CLR_P0HI17Q_HW_IDX BIT(23)
#define BIT_CLR_P0HI16Q_HW_IDX BIT(22)
#define BIT_CLR_P0HI19Q_HOST_IDX BIT(9)
#define BIT_CLR_P0HI18Q_HOST_IDX BIT(8)
#define BIT_CLR_P0HI17Q_HOST_IDX BIT(7)
#define BIT_CLR_P0HI16Q_HOST_IDX BIT(6)
#define BIT_SHIFT_HI19Q_TXBD_DESA_H 0
#define BIT_MASK_HI19Q_TXBD_DESA_H 0xffffffffL
#define BIT_HI19Q_TXBD_DESA_H(x) \
(((x) & BIT_MASK_HI19Q_TXBD_DESA_H) << BIT_SHIFT_HI19Q_TXBD_DESA_H)
#define BITS_HI19Q_TXBD_DESA_H \
(BIT_MASK_HI19Q_TXBD_DESA_H << BIT_SHIFT_HI19Q_TXBD_DESA_H)
#define BIT_CLEAR_HI19Q_TXBD_DESA_H(x) ((x) & (~BITS_HI19Q_TXBD_DESA_H))
#define BIT_GET_HI19Q_TXBD_DESA_H(x) \
(((x) >> BIT_SHIFT_HI19Q_TXBD_DESA_H) & BIT_MASK_HI19Q_TXBD_DESA_H)
#define BIT_SET_HI19Q_TXBD_DESA_H(x, v) \
(BIT_CLEAR_HI19Q_TXBD_DESA_H(x) | BIT_HI19Q_TXBD_DESA_H(v))
/* 2 REG_P0HI16Q_TXBD_IDX (Offset 0x2370) */
#define BIT_SHIFT_P0HI16Q_HW_IDX 16
#define BIT_MASK_P0HI16Q_HW_IDX 0xfff
#define BIT_P0HI16Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI16Q_HW_IDX) << BIT_SHIFT_P0HI16Q_HW_IDX)
#define BITS_P0HI16Q_HW_IDX \
(BIT_MASK_P0HI16Q_HW_IDX << BIT_SHIFT_P0HI16Q_HW_IDX)
#define BIT_CLEAR_P0HI16Q_HW_IDX(x) ((x) & (~BITS_P0HI16Q_HW_IDX))
#define BIT_GET_P0HI16Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI16Q_HW_IDX) & BIT_MASK_P0HI16Q_HW_IDX)
#define BIT_SET_P0HI16Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI16Q_HW_IDX(x) | BIT_P0HI16Q_HW_IDX(v))
#define BIT_SHIFT_P0HI16Q_HOST_IDX 0
#define BIT_MASK_P0HI16Q_HOST_IDX 0xfff
#define BIT_P0HI16Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI16Q_HOST_IDX) << BIT_SHIFT_P0HI16Q_HOST_IDX)
#define BITS_P0HI16Q_HOST_IDX \
(BIT_MASK_P0HI16Q_HOST_IDX << BIT_SHIFT_P0HI16Q_HOST_IDX)
#define BIT_CLEAR_P0HI16Q_HOST_IDX(x) ((x) & (~BITS_P0HI16Q_HOST_IDX))
#define BIT_GET_P0HI16Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI16Q_HOST_IDX) & BIT_MASK_P0HI16Q_HOST_IDX)
#define BIT_SET_P0HI16Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI16Q_HOST_IDX(x) | BIT_P0HI16Q_HOST_IDX(v))
/* 2 REG_P0HI17Q_TXBD_IDX (Offset 0x2374) */
#define BIT_SHIFT_P0HI17Q_HW_IDX 16
#define BIT_MASK_P0HI17Q_HW_IDX 0xfff
#define BIT_P0HI17Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI17Q_HW_IDX) << BIT_SHIFT_P0HI17Q_HW_IDX)
#define BITS_P0HI17Q_HW_IDX \
(BIT_MASK_P0HI17Q_HW_IDX << BIT_SHIFT_P0HI17Q_HW_IDX)
#define BIT_CLEAR_P0HI17Q_HW_IDX(x) ((x) & (~BITS_P0HI17Q_HW_IDX))
#define BIT_GET_P0HI17Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI17Q_HW_IDX) & BIT_MASK_P0HI17Q_HW_IDX)
#define BIT_SET_P0HI17Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI17Q_HW_IDX(x) | BIT_P0HI17Q_HW_IDX(v))
#define BIT_SHIFT_P0HI17Q_HOST_IDX 0
#define BIT_MASK_P0HI17Q_HOST_IDX 0xfff
#define BIT_P0HI17Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI17Q_HOST_IDX) << BIT_SHIFT_P0HI17Q_HOST_IDX)
#define BITS_P0HI17Q_HOST_IDX \
(BIT_MASK_P0HI17Q_HOST_IDX << BIT_SHIFT_P0HI17Q_HOST_IDX)
#define BIT_CLEAR_P0HI17Q_HOST_IDX(x) ((x) & (~BITS_P0HI17Q_HOST_IDX))
#define BIT_GET_P0HI17Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI17Q_HOST_IDX) & BIT_MASK_P0HI17Q_HOST_IDX)
#define BIT_SET_P0HI17Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI17Q_HOST_IDX(x) | BIT_P0HI17Q_HOST_IDX(v))
/* 2 REG_P0HI18Q_TXBD_IDX (Offset 0x2378) */
#define BIT_SHIFT_P0HI18Q_HW_IDX 16
#define BIT_MASK_P0HI18Q_HW_IDX 0xfff
#define BIT_P0HI18Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI18Q_HW_IDX) << BIT_SHIFT_P0HI18Q_HW_IDX)
#define BITS_P0HI18Q_HW_IDX \
(BIT_MASK_P0HI18Q_HW_IDX << BIT_SHIFT_P0HI18Q_HW_IDX)
#define BIT_CLEAR_P0HI18Q_HW_IDX(x) ((x) & (~BITS_P0HI18Q_HW_IDX))
#define BIT_GET_P0HI18Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI18Q_HW_IDX) & BIT_MASK_P0HI18Q_HW_IDX)
#define BIT_SET_P0HI18Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI18Q_HW_IDX(x) | BIT_P0HI18Q_HW_IDX(v))
#define BIT_SHIFT_P0HI18Q_HOST_IDX 0
#define BIT_MASK_P0HI18Q_HOST_IDX 0xfff
#define BIT_P0HI18Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI18Q_HOST_IDX) << BIT_SHIFT_P0HI18Q_HOST_IDX)
#define BITS_P0HI18Q_HOST_IDX \
(BIT_MASK_P0HI18Q_HOST_IDX << BIT_SHIFT_P0HI18Q_HOST_IDX)
#define BIT_CLEAR_P0HI18Q_HOST_IDX(x) ((x) & (~BITS_P0HI18Q_HOST_IDX))
#define BIT_GET_P0HI18Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI18Q_HOST_IDX) & BIT_MASK_P0HI18Q_HOST_IDX)
#define BIT_SET_P0HI18Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI18Q_HOST_IDX(x) | BIT_P0HI18Q_HOST_IDX(v))
/* 2 REG_P0HI19Q_TXBD_IDX (Offset 0x237C) */
#define BIT_SHIFT_P0HI19Q_HW_IDX 16
#define BIT_MASK_P0HI19Q_HW_IDX 0xfff
#define BIT_P0HI19Q_HW_IDX(x) \
(((x) & BIT_MASK_P0HI19Q_HW_IDX) << BIT_SHIFT_P0HI19Q_HW_IDX)
#define BITS_P0HI19Q_HW_IDX \
(BIT_MASK_P0HI19Q_HW_IDX << BIT_SHIFT_P0HI19Q_HW_IDX)
#define BIT_CLEAR_P0HI19Q_HW_IDX(x) ((x) & (~BITS_P0HI19Q_HW_IDX))
#define BIT_GET_P0HI19Q_HW_IDX(x) \
(((x) >> BIT_SHIFT_P0HI19Q_HW_IDX) & BIT_MASK_P0HI19Q_HW_IDX)
#define BIT_SET_P0HI19Q_HW_IDX(x, v) \
(BIT_CLEAR_P0HI19Q_HW_IDX(x) | BIT_P0HI19Q_HW_IDX(v))
#define BIT_SHIFT_P0HI19Q_HOST_IDX 0
#define BIT_MASK_P0HI19Q_HOST_IDX 0xfff
#define BIT_P0HI19Q_HOST_IDX(x) \
(((x) & BIT_MASK_P0HI19Q_HOST_IDX) << BIT_SHIFT_P0HI19Q_HOST_IDX)
#define BITS_P0HI19Q_HOST_IDX \
(BIT_MASK_P0HI19Q_HOST_IDX << BIT_SHIFT_P0HI19Q_HOST_IDX)
#define BIT_CLEAR_P0HI19Q_HOST_IDX(x) ((x) & (~BITS_P0HI19Q_HOST_IDX))
#define BIT_GET_P0HI19Q_HOST_IDX(x) \
(((x) >> BIT_SHIFT_P0HI19Q_HOST_IDX) & BIT_MASK_P0HI19Q_HOST_IDX)
#define BIT_SET_P0HI19Q_HOST_IDX(x, v) \
(BIT_CLEAR_P0HI19Q_HOST_IDX(x) | BIT_P0HI19Q_HOST_IDX(v))
/* 2 REG_P0HI16Q_HI17Q_TXBD_NUM (Offset 0x2380) */
#define BIT_P0HI17Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI17Q_DESC_MODE 28
#define BIT_MASK_P0HI17Q_DESC_MODE 0x3
#define BIT_P0HI17Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI17Q_DESC_MODE) << BIT_SHIFT_P0HI17Q_DESC_MODE)
#define BITS_P0HI17Q_DESC_MODE \
(BIT_MASK_P0HI17Q_DESC_MODE << BIT_SHIFT_P0HI17Q_DESC_MODE)
#define BIT_CLEAR_P0HI17Q_DESC_MODE(x) ((x) & (~BITS_P0HI17Q_DESC_MODE))
#define BIT_GET_P0HI17Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI17Q_DESC_MODE) & BIT_MASK_P0HI17Q_DESC_MODE)
#define BIT_SET_P0HI17Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI17Q_DESC_MODE(x) | BIT_P0HI17Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI17Q_DESC_NUM 16
#define BIT_MASK_P0HI17Q_DESC_NUM 0xfff
#define BIT_P0HI17Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI17Q_DESC_NUM) << BIT_SHIFT_P0HI17Q_DESC_NUM)
#define BITS_P0HI17Q_DESC_NUM \
(BIT_MASK_P0HI17Q_DESC_NUM << BIT_SHIFT_P0HI17Q_DESC_NUM)
#define BIT_CLEAR_P0HI17Q_DESC_NUM(x) ((x) & (~BITS_P0HI17Q_DESC_NUM))
#define BIT_GET_P0HI17Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI17Q_DESC_NUM) & BIT_MASK_P0HI17Q_DESC_NUM)
#define BIT_SET_P0HI17Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI17Q_DESC_NUM(x) | BIT_P0HI17Q_DESC_NUM(v))
#define BIT_P0HI16Q_FLAG BIT(14)
#define BIT_SHIFT_P0HI16Q_DESC_MODE 12
#define BIT_MASK_P0HI16Q_DESC_MODE 0x3
#define BIT_P0HI16Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI16Q_DESC_MODE) << BIT_SHIFT_P0HI16Q_DESC_MODE)
#define BITS_P0HI16Q_DESC_MODE \
(BIT_MASK_P0HI16Q_DESC_MODE << BIT_SHIFT_P0HI16Q_DESC_MODE)
#define BIT_CLEAR_P0HI16Q_DESC_MODE(x) ((x) & (~BITS_P0HI16Q_DESC_MODE))
#define BIT_GET_P0HI16Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI16Q_DESC_MODE) & BIT_MASK_P0HI16Q_DESC_MODE)
#define BIT_SET_P0HI16Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI16Q_DESC_MODE(x) | BIT_P0HI16Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI16Q_DESC_NUM 0
#define BIT_MASK_P0HI16Q_DESC_NUM 0xfff
#define BIT_P0HI16Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI16Q_DESC_NUM) << BIT_SHIFT_P0HI16Q_DESC_NUM)
#define BITS_P0HI16Q_DESC_NUM \
(BIT_MASK_P0HI16Q_DESC_NUM << BIT_SHIFT_P0HI16Q_DESC_NUM)
#define BIT_CLEAR_P0HI16Q_DESC_NUM(x) ((x) & (~BITS_P0HI16Q_DESC_NUM))
#define BIT_GET_P0HI16Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI16Q_DESC_NUM) & BIT_MASK_P0HI16Q_DESC_NUM)
#define BIT_SET_P0HI16Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI16Q_DESC_NUM(x) | BIT_P0HI16Q_DESC_NUM(v))
/* 2 REG_P0HI18Q_HI19Q_TXBD_NUM (Offset 0x2384) */
#define BIT_P0HI19Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI19Q_DESC_MODE 28
#define BIT_MASK_P0HI19Q_DESC_MODE 0x3
#define BIT_P0HI19Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI19Q_DESC_MODE) << BIT_SHIFT_P0HI19Q_DESC_MODE)
#define BITS_P0HI19Q_DESC_MODE \
(BIT_MASK_P0HI19Q_DESC_MODE << BIT_SHIFT_P0HI19Q_DESC_MODE)
#define BIT_CLEAR_P0HI19Q_DESC_MODE(x) ((x) & (~BITS_P0HI19Q_DESC_MODE))
#define BIT_GET_P0HI19Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI19Q_DESC_MODE) & BIT_MASK_P0HI19Q_DESC_MODE)
#define BIT_SET_P0HI19Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI19Q_DESC_MODE(x) | BIT_P0HI19Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI19Q_DESC_NUM 16
#define BIT_MASK_P0HI19Q_DESC_NUM 0xfff
#define BIT_P0HI19Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI19Q_DESC_NUM) << BIT_SHIFT_P0HI19Q_DESC_NUM)
#define BITS_P0HI19Q_DESC_NUM \
(BIT_MASK_P0HI19Q_DESC_NUM << BIT_SHIFT_P0HI19Q_DESC_NUM)
#define BIT_CLEAR_P0HI19Q_DESC_NUM(x) ((x) & (~BITS_P0HI19Q_DESC_NUM))
#define BIT_GET_P0HI19Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI19Q_DESC_NUM) & BIT_MASK_P0HI19Q_DESC_NUM)
#define BIT_SET_P0HI19Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI19Q_DESC_NUM(x) | BIT_P0HI19Q_DESC_NUM(v))
#define BIT_P0HI18Q_FLAG BIT(14)
#define BIT_SHIFT_P0HI18Q_DESC_MODE 12
#define BIT_MASK_P0HI18Q_DESC_MODE 0x3
#define BIT_P0HI18Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI18Q_DESC_MODE) << BIT_SHIFT_P0HI18Q_DESC_MODE)
#define BITS_P0HI18Q_DESC_MODE \
(BIT_MASK_P0HI18Q_DESC_MODE << BIT_SHIFT_P0HI18Q_DESC_MODE)
#define BIT_CLEAR_P0HI18Q_DESC_MODE(x) ((x) & (~BITS_P0HI18Q_DESC_MODE))
#define BIT_GET_P0HI18Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI18Q_DESC_MODE) & BIT_MASK_P0HI18Q_DESC_MODE)
#define BIT_SET_P0HI18Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI18Q_DESC_MODE(x) | BIT_P0HI18Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI18Q_DESC_NUM 0
#define BIT_MASK_P0HI18Q_DESC_NUM 0xfff
#define BIT_P0HI18Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI18Q_DESC_NUM) << BIT_SHIFT_P0HI18Q_DESC_NUM)
#define BITS_P0HI18Q_DESC_NUM \
(BIT_MASK_P0HI18Q_DESC_NUM << BIT_SHIFT_P0HI18Q_DESC_NUM)
#define BIT_CLEAR_P0HI18Q_DESC_NUM(x) ((x) & (~BITS_P0HI18Q_DESC_NUM))
#define BIT_GET_P0HI18Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI18Q_DESC_NUM) & BIT_MASK_P0HI18Q_DESC_NUM)
#define BIT_SET_P0HI18Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI18Q_DESC_NUM(x) | BIT_P0HI18Q_DESC_NUM(v))
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_PCIE_HISR1 (Offset 0x23BC) */
#define BIT_CPU_MGQ_EARLY_INT BIT(6)
#define BIT_PSTIMER_5 BIT(4)
#define BIT_PSTIMER_4 BIT(3)
#define BIT_PSTIMER_3 BIT(2)
#define BIT_BB_STOPRX_INT BIT(0)
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_P0HI8Q_HI9Q_TXBD_NUM (Offset 0x23C0) */
#define BIT_P0HI9Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI9Q_DESC_MODE 28
#define BIT_MASK_P0HI9Q_DESC_MODE 0x3
#define BIT_P0HI9Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI9Q_DESC_MODE) << BIT_SHIFT_P0HI9Q_DESC_MODE)
#define BITS_P0HI9Q_DESC_MODE \
(BIT_MASK_P0HI9Q_DESC_MODE << BIT_SHIFT_P0HI9Q_DESC_MODE)
#define BIT_CLEAR_P0HI9Q_DESC_MODE(x) ((x) & (~BITS_P0HI9Q_DESC_MODE))
#define BIT_GET_P0HI9Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI9Q_DESC_MODE) & BIT_MASK_P0HI9Q_DESC_MODE)
#define BIT_SET_P0HI9Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI9Q_DESC_MODE(x) | BIT_P0HI9Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI9Q_DESC_NUM 16
#define BIT_MASK_P0HI9Q_DESC_NUM 0xfff
#define BIT_P0HI9Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI9Q_DESC_NUM) << BIT_SHIFT_P0HI9Q_DESC_NUM)
#define BITS_P0HI9Q_DESC_NUM \
(BIT_MASK_P0HI9Q_DESC_NUM << BIT_SHIFT_P0HI9Q_DESC_NUM)
#define BIT_CLEAR_P0HI9Q_DESC_NUM(x) ((x) & (~BITS_P0HI9Q_DESC_NUM))
#define BIT_GET_P0HI9Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI9Q_DESC_NUM) & BIT_MASK_P0HI9Q_DESC_NUM)
#define BIT_SET_P0HI9Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI9Q_DESC_NUM(x) | BIT_P0HI9Q_DESC_NUM(v))
#define BIT_P0HI8Q_FLAG BIT(14)
#define BIT_SHIFT_P0HI8Q_DESC_MODE 12
#define BIT_MASK_P0HI8Q_DESC_MODE 0x3
#define BIT_P0HI8Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI8Q_DESC_MODE) << BIT_SHIFT_P0HI8Q_DESC_MODE)
#define BITS_P0HI8Q_DESC_MODE \
(BIT_MASK_P0HI8Q_DESC_MODE << BIT_SHIFT_P0HI8Q_DESC_MODE)
#define BIT_CLEAR_P0HI8Q_DESC_MODE(x) ((x) & (~BITS_P0HI8Q_DESC_MODE))
#define BIT_GET_P0HI8Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI8Q_DESC_MODE) & BIT_MASK_P0HI8Q_DESC_MODE)
#define BIT_SET_P0HI8Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI8Q_DESC_MODE(x) | BIT_P0HI8Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI8Q_DESC_NUM 0
#define BIT_MASK_P0HI8Q_DESC_NUM 0xfff
#define BIT_P0HI8Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI8Q_DESC_NUM) << BIT_SHIFT_P0HI8Q_DESC_NUM)
#define BITS_P0HI8Q_DESC_NUM \
(BIT_MASK_P0HI8Q_DESC_NUM << BIT_SHIFT_P0HI8Q_DESC_NUM)
#define BIT_CLEAR_P0HI8Q_DESC_NUM(x) ((x) & (~BITS_P0HI8Q_DESC_NUM))
#define BIT_GET_P0HI8Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI8Q_DESC_NUM) & BIT_MASK_P0HI8Q_DESC_NUM)
#define BIT_SET_P0HI8Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI8Q_DESC_NUM(x) | BIT_P0HI8Q_DESC_NUM(v))
/* 2 REG_P0HI10Q_HI11Q_TXBD_NUM (Offset 0x23C4) */
#define BIT_P0HI11Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI11Q_DESC_MODE 28
#define BIT_MASK_P0HI11Q_DESC_MODE 0x3
#define BIT_P0HI11Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI11Q_DESC_MODE) << BIT_SHIFT_P0HI11Q_DESC_MODE)
#define BITS_P0HI11Q_DESC_MODE \
(BIT_MASK_P0HI11Q_DESC_MODE << BIT_SHIFT_P0HI11Q_DESC_MODE)
#define BIT_CLEAR_P0HI11Q_DESC_MODE(x) ((x) & (~BITS_P0HI11Q_DESC_MODE))
#define BIT_GET_P0HI11Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI11Q_DESC_MODE) & BIT_MASK_P0HI11Q_DESC_MODE)
#define BIT_SET_P0HI11Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI11Q_DESC_MODE(x) | BIT_P0HI11Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI11Q_DESC_NUM 16
#define BIT_MASK_P0HI11Q_DESC_NUM 0xfff
#define BIT_P0HI11Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI11Q_DESC_NUM) << BIT_SHIFT_P0HI11Q_DESC_NUM)
#define BITS_P0HI11Q_DESC_NUM \
(BIT_MASK_P0HI11Q_DESC_NUM << BIT_SHIFT_P0HI11Q_DESC_NUM)
#define BIT_CLEAR_P0HI11Q_DESC_NUM(x) ((x) & (~BITS_P0HI11Q_DESC_NUM))
#define BIT_GET_P0HI11Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI11Q_DESC_NUM) & BIT_MASK_P0HI11Q_DESC_NUM)
#define BIT_SET_P0HI11Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI11Q_DESC_NUM(x) | BIT_P0HI11Q_DESC_NUM(v))
#define BIT_P0HI10Q_FLAG BIT(14)
#define BIT_SHIFT_P0HI10Q_DESC_MODE 12
#define BIT_MASK_P0HI10Q_DESC_MODE 0x3
#define BIT_P0HI10Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI10Q_DESC_MODE) << BIT_SHIFT_P0HI10Q_DESC_MODE)
#define BITS_P0HI10Q_DESC_MODE \
(BIT_MASK_P0HI10Q_DESC_MODE << BIT_SHIFT_P0HI10Q_DESC_MODE)
#define BIT_CLEAR_P0HI10Q_DESC_MODE(x) ((x) & (~BITS_P0HI10Q_DESC_MODE))
#define BIT_GET_P0HI10Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI10Q_DESC_MODE) & BIT_MASK_P0HI10Q_DESC_MODE)
#define BIT_SET_P0HI10Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI10Q_DESC_MODE(x) | BIT_P0HI10Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI10Q_DESC_NUM 0
#define BIT_MASK_P0HI10Q_DESC_NUM 0xfff
#define BIT_P0HI10Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI10Q_DESC_NUM) << BIT_SHIFT_P0HI10Q_DESC_NUM)
#define BITS_P0HI10Q_DESC_NUM \
(BIT_MASK_P0HI10Q_DESC_NUM << BIT_SHIFT_P0HI10Q_DESC_NUM)
#define BIT_CLEAR_P0HI10Q_DESC_NUM(x) ((x) & (~BITS_P0HI10Q_DESC_NUM))
#define BIT_GET_P0HI10Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI10Q_DESC_NUM) & BIT_MASK_P0HI10Q_DESC_NUM)
#define BIT_SET_P0HI10Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI10Q_DESC_NUM(x) | BIT_P0HI10Q_DESC_NUM(v))
/* 2 REG_P0HI12Q_HI13Q_TXBD_NUM (Offset 0x23C8) */
#define BIT_P0HI13Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI13Q_DESC_MODE 28
#define BIT_MASK_P0HI13Q_DESC_MODE 0x3
#define BIT_P0HI13Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI13Q_DESC_MODE) << BIT_SHIFT_P0HI13Q_DESC_MODE)
#define BITS_P0HI13Q_DESC_MODE \
(BIT_MASK_P0HI13Q_DESC_MODE << BIT_SHIFT_P0HI13Q_DESC_MODE)
#define BIT_CLEAR_P0HI13Q_DESC_MODE(x) ((x) & (~BITS_P0HI13Q_DESC_MODE))
#define BIT_GET_P0HI13Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI13Q_DESC_MODE) & BIT_MASK_P0HI13Q_DESC_MODE)
#define BIT_SET_P0HI13Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI13Q_DESC_MODE(x) | BIT_P0HI13Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI13Q_DESC_NUM 16
#define BIT_MASK_P0HI13Q_DESC_NUM 0xfff
#define BIT_P0HI13Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI13Q_DESC_NUM) << BIT_SHIFT_P0HI13Q_DESC_NUM)
#define BITS_P0HI13Q_DESC_NUM \
(BIT_MASK_P0HI13Q_DESC_NUM << BIT_SHIFT_P0HI13Q_DESC_NUM)
#define BIT_CLEAR_P0HI13Q_DESC_NUM(x) ((x) & (~BITS_P0HI13Q_DESC_NUM))
#define BIT_GET_P0HI13Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI13Q_DESC_NUM) & BIT_MASK_P0HI13Q_DESC_NUM)
#define BIT_SET_P0HI13Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI13Q_DESC_NUM(x) | BIT_P0HI13Q_DESC_NUM(v))
#define BIT_P0HI12Q_FLAG BIT(14)
#define BIT_SHIFT_P0HI12Q_DESC_MODE 12
#define BIT_MASK_P0HI12Q_DESC_MODE 0x3
#define BIT_P0HI12Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI12Q_DESC_MODE) << BIT_SHIFT_P0HI12Q_DESC_MODE)
#define BITS_P0HI12Q_DESC_MODE \
(BIT_MASK_P0HI12Q_DESC_MODE << BIT_SHIFT_P0HI12Q_DESC_MODE)
#define BIT_CLEAR_P0HI12Q_DESC_MODE(x) ((x) & (~BITS_P0HI12Q_DESC_MODE))
#define BIT_GET_P0HI12Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI12Q_DESC_MODE) & BIT_MASK_P0HI12Q_DESC_MODE)
#define BIT_SET_P0HI12Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI12Q_DESC_MODE(x) | BIT_P0HI12Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI12Q_DESC_NUM 0
#define BIT_MASK_P0HI12Q_DESC_NUM 0xfff
#define BIT_P0HI12Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI12Q_DESC_NUM) << BIT_SHIFT_P0HI12Q_DESC_NUM)
#define BITS_P0HI12Q_DESC_NUM \
(BIT_MASK_P0HI12Q_DESC_NUM << BIT_SHIFT_P0HI12Q_DESC_NUM)
#define BIT_CLEAR_P0HI12Q_DESC_NUM(x) ((x) & (~BITS_P0HI12Q_DESC_NUM))
#define BIT_GET_P0HI12Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI12Q_DESC_NUM) & BIT_MASK_P0HI12Q_DESC_NUM)
#define BIT_SET_P0HI12Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI12Q_DESC_NUM(x) | BIT_P0HI12Q_DESC_NUM(v))
/* 2 REG_P0HI14Q_HI15Q_TXBD_NUM (Offset 0x23CC) */
#define BIT_P0HI15Q_FLAG BIT(30)
#define BIT_SHIFT_P0HI15Q_DESC_MODE 28
#define BIT_MASK_P0HI15Q_DESC_MODE 0x3
#define BIT_P0HI15Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI15Q_DESC_MODE) << BIT_SHIFT_P0HI15Q_DESC_MODE)
#define BITS_P0HI15Q_DESC_MODE \
(BIT_MASK_P0HI15Q_DESC_MODE << BIT_SHIFT_P0HI15Q_DESC_MODE)
#define BIT_CLEAR_P0HI15Q_DESC_MODE(x) ((x) & (~BITS_P0HI15Q_DESC_MODE))
#define BIT_GET_P0HI15Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI15Q_DESC_MODE) & BIT_MASK_P0HI15Q_DESC_MODE)
#define BIT_SET_P0HI15Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI15Q_DESC_MODE(x) | BIT_P0HI15Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI15Q_DESC_NUM 16
#define BIT_MASK_P0HI15Q_DESC_NUM 0xfff
#define BIT_P0HI15Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI15Q_DESC_NUM) << BIT_SHIFT_P0HI15Q_DESC_NUM)
#define BITS_P0HI15Q_DESC_NUM \
(BIT_MASK_P0HI15Q_DESC_NUM << BIT_SHIFT_P0HI15Q_DESC_NUM)
#define BIT_CLEAR_P0HI15Q_DESC_NUM(x) ((x) & (~BITS_P0HI15Q_DESC_NUM))
#define BIT_GET_P0HI15Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI15Q_DESC_NUM) & BIT_MASK_P0HI15Q_DESC_NUM)
#define BIT_SET_P0HI15Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI15Q_DESC_NUM(x) | BIT_P0HI15Q_DESC_NUM(v))
#define BIT_P0HI14Q_FLAG BIT(14)
#define BIT_SHIFT_P0HI14Q_DESC_MODE 12
#define BIT_MASK_P0HI14Q_DESC_MODE 0x3
#define BIT_P0HI14Q_DESC_MODE(x) \
(((x) & BIT_MASK_P0HI14Q_DESC_MODE) << BIT_SHIFT_P0HI14Q_DESC_MODE)
#define BITS_P0HI14Q_DESC_MODE \
(BIT_MASK_P0HI14Q_DESC_MODE << BIT_SHIFT_P0HI14Q_DESC_MODE)
#define BIT_CLEAR_P0HI14Q_DESC_MODE(x) ((x) & (~BITS_P0HI14Q_DESC_MODE))
#define BIT_GET_P0HI14Q_DESC_MODE(x) \
(((x) >> BIT_SHIFT_P0HI14Q_DESC_MODE) & BIT_MASK_P0HI14Q_DESC_MODE)
#define BIT_SET_P0HI14Q_DESC_MODE(x, v) \
(BIT_CLEAR_P0HI14Q_DESC_MODE(x) | BIT_P0HI14Q_DESC_MODE(v))
#define BIT_SHIFT_P0HI14Q_DESC_NUM 0
#define BIT_MASK_P0HI14Q_DESC_NUM 0xfff
#define BIT_P0HI14Q_DESC_NUM(x) \
(((x) & BIT_MASK_P0HI14Q_DESC_NUM) << BIT_SHIFT_P0HI14Q_DESC_NUM)
#define BITS_P0HI14Q_DESC_NUM \
(BIT_MASK_P0HI14Q_DESC_NUM << BIT_SHIFT_P0HI14Q_DESC_NUM)
#define BIT_CLEAR_P0HI14Q_DESC_NUM(x) ((x) & (~BITS_P0HI14Q_DESC_NUM))
#define BIT_GET_P0HI14Q_DESC_NUM(x) \
(((x) >> BIT_SHIFT_P0HI14Q_DESC_NUM) & BIT_MASK_P0HI14Q_DESC_NUM)
#define BIT_SET_P0HI14Q_DESC_NUM(x, v) \
(BIT_CLEAR_P0HI14Q_DESC_NUM(x) | BIT_P0HI14Q_DESC_NUM(v))
/* 2 REG_ACH6_ACH7_TXBD_NUM (Offset 0x23F0) */
#define BIT_PCIE_ACH7_FLAG BIT(30)
#define BIT_SHIFT_ACH7_DESC_MODE 28
#define BIT_MASK_ACH7_DESC_MODE 0x3
#define BIT_ACH7_DESC_MODE(x) \
(((x) & BIT_MASK_ACH7_DESC_MODE) << BIT_SHIFT_ACH7_DESC_MODE)
#define BITS_ACH7_DESC_MODE \
(BIT_MASK_ACH7_DESC_MODE << BIT_SHIFT_ACH7_DESC_MODE)
#define BIT_CLEAR_ACH7_DESC_MODE(x) ((x) & (~BITS_ACH7_DESC_MODE))
#define BIT_GET_ACH7_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH7_DESC_MODE) & BIT_MASK_ACH7_DESC_MODE)
#define BIT_SET_ACH7_DESC_MODE(x, v) \
(BIT_CLEAR_ACH7_DESC_MODE(x) | BIT_ACH7_DESC_MODE(v))
#define BIT_SHIFT_ACH7_DESC_NUM 16
#define BIT_MASK_ACH7_DESC_NUM 0xfff
#define BIT_ACH7_DESC_NUM(x) \
(((x) & BIT_MASK_ACH7_DESC_NUM) << BIT_SHIFT_ACH7_DESC_NUM)
#define BITS_ACH7_DESC_NUM (BIT_MASK_ACH7_DESC_NUM << BIT_SHIFT_ACH7_DESC_NUM)
#define BIT_CLEAR_ACH7_DESC_NUM(x) ((x) & (~BITS_ACH7_DESC_NUM))
#define BIT_GET_ACH7_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH7_DESC_NUM) & BIT_MASK_ACH7_DESC_NUM)
#define BIT_SET_ACH7_DESC_NUM(x, v) \
(BIT_CLEAR_ACH7_DESC_NUM(x) | BIT_ACH7_DESC_NUM(v))
#define BIT_PCIE_ACH6_FLAG BIT(14)
#define BIT_SHIFT_ACH6_DESC_MODE 12
#define BIT_MASK_ACH6_DESC_MODE 0x3
#define BIT_ACH6_DESC_MODE(x) \
(((x) & BIT_MASK_ACH6_DESC_MODE) << BIT_SHIFT_ACH6_DESC_MODE)
#define BITS_ACH6_DESC_MODE \
(BIT_MASK_ACH6_DESC_MODE << BIT_SHIFT_ACH6_DESC_MODE)
#define BIT_CLEAR_ACH6_DESC_MODE(x) ((x) & (~BITS_ACH6_DESC_MODE))
#define BIT_GET_ACH6_DESC_MODE(x) \
(((x) >> BIT_SHIFT_ACH6_DESC_MODE) & BIT_MASK_ACH6_DESC_MODE)
#define BIT_SET_ACH6_DESC_MODE(x, v) \
(BIT_CLEAR_ACH6_DESC_MODE(x) | BIT_ACH6_DESC_MODE(v))
#define BIT_SHIFT_ACH6_DESC_NUM 0
#define BIT_MASK_ACH6_DESC_NUM 0xfff
#define BIT_ACH6_DESC_NUM(x) \
(((x) & BIT_MASK_ACH6_DESC_NUM) << BIT_SHIFT_ACH6_DESC_NUM)
#define BITS_ACH6_DESC_NUM (BIT_MASK_ACH6_DESC_NUM << BIT_SHIFT_ACH6_DESC_NUM)
#define BIT_CLEAR_ACH6_DESC_NUM(x) ((x) & (~BITS_ACH6_DESC_NUM))
#define BIT_GET_ACH6_DESC_NUM(x) \
(((x) >> BIT_SHIFT_ACH6_DESC_NUM) & BIT_MASK_ACH6_DESC_NUM)
#define BIT_SET_ACH6_DESC_NUM(x, v) \
(BIT_CLEAR_ACH6_DESC_NUM(x) | BIT_ACH6_DESC_NUM(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_FAST_EDCA_VOVI_SETTING_V1 (Offset 0x2448) */
#define BIT_SHIFT_VO_FAST_EDCA_TO_V1 0
#define BIT_MASK_VO_FAST_EDCA_TO_V1 0xffff
#define BIT_VO_FAST_EDCA_TO_V1(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO_V1) << BIT_SHIFT_VO_FAST_EDCA_TO_V1)
#define BITS_VO_FAST_EDCA_TO_V1 \
(BIT_MASK_VO_FAST_EDCA_TO_V1 << BIT_SHIFT_VO_FAST_EDCA_TO_V1)
#define BIT_CLEAR_VO_FAST_EDCA_TO_V1(x) ((x) & (~BITS_VO_FAST_EDCA_TO_V1))
#define BIT_GET_VO_FAST_EDCA_TO_V1(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO_V1) & BIT_MASK_VO_FAST_EDCA_TO_V1)
#define BIT_SET_VO_FAST_EDCA_TO_V1(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO_V1(x) | BIT_VO_FAST_EDCA_TO_V1(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING_V1 (Offset 0x244C) */
#define BIT_SHIFT_BE_FAST_EDCA_TO_V1 0
#define BIT_MASK_BE_FAST_EDCA_TO_V1 0xffff
#define BIT_BE_FAST_EDCA_TO_V1(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO_V1) << BIT_SHIFT_BE_FAST_EDCA_TO_V1)
#define BITS_BE_FAST_EDCA_TO_V1 \
(BIT_MASK_BE_FAST_EDCA_TO_V1 << BIT_SHIFT_BE_FAST_EDCA_TO_V1)
#define BIT_CLEAR_BE_FAST_EDCA_TO_V1(x) ((x) & (~BITS_BE_FAST_EDCA_TO_V1))
#define BIT_GET_BE_FAST_EDCA_TO_V1(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO_V1) & BIT_MASK_BE_FAST_EDCA_TO_V1)
#define BIT_SET_BE_FAST_EDCA_TO_V1(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO_V1(x) | BIT_BE_FAST_EDCA_TO_V1(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
/* 2 REG_R_MACID_RELEASE_SUCCESS_0_V1 (Offset 0x2460) */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_0 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_0(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_0) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0)
#define BITS_R_MACID_RELEASE_SUCCESS_0 \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_0 \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_0))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_0(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_0)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_0(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0(x) | \
BIT_R_MACID_RELEASE_SUCCESS_0(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_2_V1 (Offset 0x2468) */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_2 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_2(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_2) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2)
#define BITS_R_MACID_RELEASE_SUCCESS_2 \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_2 \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_2))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_2(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_2)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_2(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2(x) | \
BIT_R_MACID_RELEASE_SUCCESS_2(v))
#endif
#if (HALMAC_8192F_SUPPORT)
/* 2 REG_NAN_INFO0 (Offset 0x2480) */
#define BIT_SHIFT_NAN_INFO0 0
#define BIT_MASK_NAN_INFO0 0xffffffffL
#define BIT_NAN_INFO0(x) (((x) & BIT_MASK_NAN_INFO0) << BIT_SHIFT_NAN_INFO0)
#define BITS_NAN_INFO0 (BIT_MASK_NAN_INFO0 << BIT_SHIFT_NAN_INFO0)
#define BIT_CLEAR_NAN_INFO0(x) ((x) & (~BITS_NAN_INFO0))
#define BIT_GET_NAN_INFO0(x) (((x) >> BIT_SHIFT_NAN_INFO0) & BIT_MASK_NAN_INFO0)
#define BIT_SET_NAN_INFO0(x, v) (BIT_CLEAR_NAN_INFO0(x) | BIT_NAN_INFO0(v))
/* 2 REG_NAN_INFO1 (Offset 0x2484) */
#define BIT_SHIFT_NAN_INFO1 0
#define BIT_MASK_NAN_INFO1 0xffffffffL
#define BIT_NAN_INFO1(x) (((x) & BIT_MASK_NAN_INFO1) << BIT_SHIFT_NAN_INFO1)
#define BITS_NAN_INFO1 (BIT_MASK_NAN_INFO1 << BIT_SHIFT_NAN_INFO1)
#define BIT_CLEAR_NAN_INFO1(x) ((x) & (~BITS_NAN_INFO1))
#define BIT_GET_NAN_INFO1(x) (((x) >> BIT_SHIFT_NAN_INFO1) & BIT_MASK_NAN_INFO1)
#define BIT_SET_NAN_INFO1(x, v) (BIT_CLEAR_NAN_INFO1(x) | BIT_NAN_INFO1(v))
/* 2 REG_NAN_INFO2 (Offset 0x2488) */
#define BIT_SHIFT_NAN_INFO2 0
#define BIT_MASK_NAN_INFO2 0xffffffffL
#define BIT_NAN_INFO2(x) (((x) & BIT_MASK_NAN_INFO2) << BIT_SHIFT_NAN_INFO2)
#define BITS_NAN_INFO2 (BIT_MASK_NAN_INFO2 << BIT_SHIFT_NAN_INFO2)
#define BIT_CLEAR_NAN_INFO2(x) ((x) & (~BITS_NAN_INFO2))
#define BIT_GET_NAN_INFO2(x) (((x) >> BIT_SHIFT_NAN_INFO2) & BIT_MASK_NAN_INFO2)
#define BIT_SET_NAN_INFO2(x, v) (BIT_CLEAR_NAN_INFO2(x) | BIT_NAN_INFO2(v))
/* 2 REG_NAN_INFO3 (Offset 0x248C) */
#define BIT_SHIFT_NAN_INFO3 0
#define BIT_MASK_NAN_INFO3 0xffffffffL
#define BIT_NAN_INFO3(x) (((x) & BIT_MASK_NAN_INFO3) << BIT_SHIFT_NAN_INFO3)
#define BITS_NAN_INFO3 (BIT_MASK_NAN_INFO3 << BIT_SHIFT_NAN_INFO3)
#define BIT_CLEAR_NAN_INFO3(x) ((x) & (~BITS_NAN_INFO3))
#define BIT_GET_NAN_INFO3(x) (((x) >> BIT_SHIFT_NAN_INFO3) & BIT_MASK_NAN_INFO3)
#define BIT_SET_NAN_INFO3(x, v) (BIT_CLEAR_NAN_INFO3(x) | BIT_NAN_INFO3(v))
/* 2 REG_NAN_INFO4 (Offset 0x2490) */
#define BIT_SHIFT_NAN_INFO4 0
#define BIT_MASK_NAN_INFO4 0xffffffffL
#define BIT_NAN_INFO4(x) (((x) & BIT_MASK_NAN_INFO4) << BIT_SHIFT_NAN_INFO4)
#define BITS_NAN_INFO4 (BIT_MASK_NAN_INFO4 << BIT_SHIFT_NAN_INFO4)
#define BIT_CLEAR_NAN_INFO4(x) ((x) & (~BITS_NAN_INFO4))
#define BIT_GET_NAN_INFO4(x) (((x) >> BIT_SHIFT_NAN_INFO4) & BIT_MASK_NAN_INFO4)
#define BIT_SET_NAN_INFO4(x, v) (BIT_CLEAR_NAN_INFO4(x) | BIT_NAN_INFO4(v))
/* 2 REG_NAN_INFO5 (Offset 0x2494) */
#define BIT_SHIFT_NAN_INFO5 0
#define BIT_MASK_NAN_INFO5 0xffffffffL
#define BIT_NAN_INFO5(x) (((x) & BIT_MASK_NAN_INFO5) << BIT_SHIFT_NAN_INFO5)
#define BITS_NAN_INFO5 (BIT_MASK_NAN_INFO5 << BIT_SHIFT_NAN_INFO5)
#define BIT_CLEAR_NAN_INFO5(x) ((x) & (~BITS_NAN_INFO5))
#define BIT_GET_NAN_INFO5(x) (((x) >> BIT_SHIFT_NAN_INFO5) & BIT_MASK_NAN_INFO5)
#define BIT_SET_NAN_INFO5(x, v) (BIT_CLEAR_NAN_INFO5(x) | BIT_NAN_INFO5(v))
/* 2 REG_NAN_INFO6 (Offset 0x2498) */
#define BIT_SHIFT_NAN_INFO6 0
#define BIT_MASK_NAN_INFO6 0xffffffffL
#define BIT_NAN_INFO6(x) (((x) & BIT_MASK_NAN_INFO6) << BIT_SHIFT_NAN_INFO6)
#define BITS_NAN_INFO6 (BIT_MASK_NAN_INFO6 << BIT_SHIFT_NAN_INFO6)
#define BIT_CLEAR_NAN_INFO6(x) ((x) & (~BITS_NAN_INFO6))
#define BIT_GET_NAN_INFO6(x) (((x) >> BIT_SHIFT_NAN_INFO6) & BIT_MASK_NAN_INFO6)
#define BIT_SET_NAN_INFO6(x, v) (BIT_CLEAR_NAN_INFO6(x) | BIT_NAN_INFO6(v))
/* 2 REG_NAN_INFO7 (Offset 0x249C) */
#define BIT_SHIFT_NAN_INFO7 0
#define BIT_MASK_NAN_INFO7 0xffffffffL
#define BIT_NAN_INFO7(x) (((x) & BIT_MASK_NAN_INFO7) << BIT_SHIFT_NAN_INFO7)
#define BITS_NAN_INFO7 (BIT_MASK_NAN_INFO7 << BIT_SHIFT_NAN_INFO7)
#define BIT_CLEAR_NAN_INFO7(x) ((x) & (~BITS_NAN_INFO7))
#define BIT_GET_NAN_INFO7(x) (((x) >> BIT_SHIFT_NAN_INFO7) & BIT_MASK_NAN_INFO7)
#define BIT_SET_NAN_INFO7(x, v) (BIT_CLEAR_NAN_INFO7(x) | BIT_NAN_INFO7(v))
/* 2 REG_NAN_INFO8 (Offset 0x24A0) */
#define BIT_SHIFT_NAN_INFO8 0
#define BIT_MASK_NAN_INFO8 0xffffffffL
#define BIT_NAN_INFO8(x) (((x) & BIT_MASK_NAN_INFO8) << BIT_SHIFT_NAN_INFO8)
#define BITS_NAN_INFO8 (BIT_MASK_NAN_INFO8 << BIT_SHIFT_NAN_INFO8)
#define BIT_CLEAR_NAN_INFO8(x) ((x) & (~BITS_NAN_INFO8))
#define BIT_GET_NAN_INFO8(x) (((x) >> BIT_SHIFT_NAN_INFO8) & BIT_MASK_NAN_INFO8)
#define BIT_SET_NAN_INFO8(x, v) (BIT_CLEAR_NAN_INFO8(x) | BIT_NAN_INFO8(v))
/* 2 REG_NAN_INFO9 (Offset 0x24A4) */
#define BIT_SHIFT_NAN_INFO9 0
#define BIT_MASK_NAN_INFO9 0xffffffffL
#define BIT_NAN_INFO9(x) (((x) & BIT_MASK_NAN_INFO9) << BIT_SHIFT_NAN_INFO9)
#define BITS_NAN_INFO9 (BIT_MASK_NAN_INFO9 << BIT_SHIFT_NAN_INFO9)
#define BIT_CLEAR_NAN_INFO9(x) ((x) & (~BITS_NAN_INFO9))
#define BIT_GET_NAN_INFO9(x) (((x) >> BIT_SHIFT_NAN_INFO9) & BIT_MASK_NAN_INFO9)
#define BIT_SET_NAN_INFO9(x, v) (BIT_CLEAR_NAN_INFO9(x) | BIT_NAN_INFO9(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_INFO_CTRL_V1 (Offset 0x24D0) */
#define BIT_CHNL_REF_EDCA BIT(5)
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
/* 2 REG_CHNL_IDLE_TIME_V1 (Offset 0x24D4) */
#define BIT_SHIFT_CHNL_IDLE_TIME 0
#define BIT_MASK_CHNL_IDLE_TIME 0xffffffffL
#define BIT_CHNL_IDLE_TIME(x) \
(((x) & BIT_MASK_CHNL_IDLE_TIME) << BIT_SHIFT_CHNL_IDLE_TIME)
#define BITS_CHNL_IDLE_TIME \
(BIT_MASK_CHNL_IDLE_TIME << BIT_SHIFT_CHNL_IDLE_TIME)
#define BIT_CLEAR_CHNL_IDLE_TIME(x) ((x) & (~BITS_CHNL_IDLE_TIME))
#define BIT_GET_CHNL_IDLE_TIME(x) \
(((x) >> BIT_SHIFT_CHNL_IDLE_TIME) & BIT_MASK_CHNL_IDLE_TIME)
#define BIT_SET_CHNL_IDLE_TIME(x, v) \
(BIT_CLEAR_CHNL_IDLE_TIME(x) | BIT_CHNL_IDLE_TIME(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
/* 2 REG_SWPS_PKT_TH_V1 (Offset 0x24F6) */
#define BIT_SHIFT_SWPS_PKT_TH 0
#define BIT_MASK_SWPS_PKT_TH 0xffff
#define BIT_SWPS_PKT_TH(x) \
(((x) & BIT_MASK_SWPS_PKT_TH) << BIT_SHIFT_SWPS_PKT_TH)
#define BITS_SWPS_PKT_TH (BIT_MASK_SWPS_PKT_TH << BIT_SHIFT_SWPS_PKT_TH)
#define BIT_CLEAR_SWPS_PKT_TH(x) ((x) & (~BITS_SWPS_PKT_TH))
#define BIT_GET_SWPS_PKT_TH(x) \
(((x) >> BIT_SHIFT_SWPS_PKT_TH) & BIT_MASK_SWPS_PKT_TH)
#define BIT_SET_SWPS_PKT_TH(x, v) \
(BIT_CLEAR_SWPS_PKT_TH(x) | BIT_SWPS_PKT_TH(v))
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814B_SUPPORT)
/* 2 REG_SWPS_TIME_TH_V1 (Offset 0x24F8) */
#define BIT_SHIFT_SWPS_PSTIME_TH 16
#define BIT_MASK_SWPS_PSTIME_TH 0xffff
#define BIT_SWPS_PSTIME_TH(x) \
(((x) & BIT_MASK_SWPS_PSTIME_TH) << BIT_SHIFT_SWPS_PSTIME_TH)
#define BITS_SWPS_PSTIME_TH \
(BIT_MASK_SWPS_PSTIME_TH << BIT_SHIFT_SWPS_PSTIME_TH)
#define BIT_CLEAR_SWPS_PSTIME_TH(x) ((x) & (~BITS_SWPS_PSTIME_TH))
#define BIT_GET_SWPS_PSTIME_TH(x) \
(((x) >> BIT_SHIFT_SWPS_PSTIME_TH) & BIT_MASK_SWPS_PSTIME_TH)
#define BIT_SET_SWPS_PSTIME_TH(x, v) \
(BIT_CLEAR_SWPS_PSTIME_TH(x) | BIT_SWPS_PSTIME_TH(v))
#define BIT_SHIFT_SWPS_TIME_TH 0
#define BIT_MASK_SWPS_TIME_TH 0xffff
#define BIT_SWPS_TIME_TH(x) \
(((x) & BIT_MASK_SWPS_TIME_TH) << BIT_SHIFT_SWPS_TIME_TH)
#define BITS_SWPS_TIME_TH (BIT_MASK_SWPS_TIME_TH << BIT_SHIFT_SWPS_TIME_TH)
#define BIT_CLEAR_SWPS_TIME_TH(x) ((x) & (~BITS_SWPS_TIME_TH))
#define BIT_GET_SWPS_TIME_TH(x) \
(((x) >> BIT_SHIFT_SWPS_TIME_TH) & BIT_MASK_SWPS_TIME_TH)
#define BIT_SET_SWPS_TIME_TH(x, v) \
(BIT_CLEAR_SWPS_TIME_TH(x) | BIT_SWPS_TIME_TH(v))
#endif
#if (HALMAC_8814B_SUPPORT)
/* 2 REG_TXPAGE_INT_CTRL_0 (Offset 0x3200) */
#define BIT_CH0_INT_EN BIT(31)
#define BIT_SHIFT_CH0_HIGH_TH 16
#define BIT_MASK_CH0_HIGH_TH 0xfff
#define BIT_CH0_HIGH_TH(x) \
(((x) & BIT_MASK_CH0_HIGH_TH) << BIT_SHIFT_CH0_HIGH_TH)
#define BITS_CH0_HIGH_TH (BIT_MASK_CH0_HIGH_TH << BIT_SHIFT_CH0_HIGH_TH)
#define BIT_CLEAR_CH0_HIGH_TH(x) ((x) & (~BITS_CH0_HIGH_TH))
#define BIT_GET_CH0_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH0_HIGH_TH) & BIT_MASK_CH0_HIGH_TH)
#define BIT_SET_CH0_HIGH_TH(x, v) \
(BIT_CLEAR_CH0_HIGH_TH(x) | BIT_CH0_HIGH_TH(v))
#define BIT_SHIFT_CH0_LOW_TH 0
#define BIT_MASK_CH0_LOW_TH 0xfff
#define BIT_CH0_LOW_TH(x) (((x) & BIT_MASK_CH0_LOW_TH) << BIT_SHIFT_CH0_LOW_TH)
#define BITS_CH0_LOW_TH (BIT_MASK_CH0_LOW_TH << BIT_SHIFT_CH0_LOW_TH)
#define BIT_CLEAR_CH0_LOW_TH(x) ((x) & (~BITS_CH0_LOW_TH))
#define BIT_GET_CH0_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH0_LOW_TH) & BIT_MASK_CH0_LOW_TH)
#define BIT_SET_CH0_LOW_TH(x, v) (BIT_CLEAR_CH0_LOW_TH(x) | BIT_CH0_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_1 (Offset 0x3204) */
#define BIT_CH1_INT_EN BIT(31)
#define BIT_SHIFT_CH1_HIGH_TH 16
#define BIT_MASK_CH1_HIGH_TH 0xfff
#define BIT_CH1_HIGH_TH(x) \
(((x) & BIT_MASK_CH1_HIGH_TH) << BIT_SHIFT_CH1_HIGH_TH)
#define BITS_CH1_HIGH_TH (BIT_MASK_CH1_HIGH_TH << BIT_SHIFT_CH1_HIGH_TH)
#define BIT_CLEAR_CH1_HIGH_TH(x) ((x) & (~BITS_CH1_HIGH_TH))
#define BIT_GET_CH1_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH1_HIGH_TH) & BIT_MASK_CH1_HIGH_TH)
#define BIT_SET_CH1_HIGH_TH(x, v) \
(BIT_CLEAR_CH1_HIGH_TH(x) | BIT_CH1_HIGH_TH(v))
#define BIT_SHIFT_CH1_LOW_TH 0
#define BIT_MASK_CH1_LOW_TH 0xfff
#define BIT_CH1_LOW_TH(x) (((x) & BIT_MASK_CH1_LOW_TH) << BIT_SHIFT_CH1_LOW_TH)
#define BITS_CH1_LOW_TH (BIT_MASK_CH1_LOW_TH << BIT_SHIFT_CH1_LOW_TH)
#define BIT_CLEAR_CH1_LOW_TH(x) ((x) & (~BITS_CH1_LOW_TH))
#define BIT_GET_CH1_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH1_LOW_TH) & BIT_MASK_CH1_LOW_TH)
#define BIT_SET_CH1_LOW_TH(x, v) (BIT_CLEAR_CH1_LOW_TH(x) | BIT_CH1_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_2 (Offset 0x3208) */
#define BIT_CH2_INT_EN BIT(31)
#define BIT_SHIFT_CH2_HIGH_TH 16
#define BIT_MASK_CH2_HIGH_TH 0xfff
#define BIT_CH2_HIGH_TH(x) \
(((x) & BIT_MASK_CH2_HIGH_TH) << BIT_SHIFT_CH2_HIGH_TH)
#define BITS_CH2_HIGH_TH (BIT_MASK_CH2_HIGH_TH << BIT_SHIFT_CH2_HIGH_TH)
#define BIT_CLEAR_CH2_HIGH_TH(x) ((x) & (~BITS_CH2_HIGH_TH))
#define BIT_GET_CH2_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH2_HIGH_TH) & BIT_MASK_CH2_HIGH_TH)
#define BIT_SET_CH2_HIGH_TH(x, v) \
(BIT_CLEAR_CH2_HIGH_TH(x) | BIT_CH2_HIGH_TH(v))
#define BIT_SHIFT_CH2_LOW_TH 0
#define BIT_MASK_CH2_LOW_TH 0xfff
#define BIT_CH2_LOW_TH(x) (((x) & BIT_MASK_CH2_LOW_TH) << BIT_SHIFT_CH2_LOW_TH)
#define BITS_CH2_LOW_TH (BIT_MASK_CH2_LOW_TH << BIT_SHIFT_CH2_LOW_TH)
#define BIT_CLEAR_CH2_LOW_TH(x) ((x) & (~BITS_CH2_LOW_TH))
#define BIT_GET_CH2_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH2_LOW_TH) & BIT_MASK_CH2_LOW_TH)
#define BIT_SET_CH2_LOW_TH(x, v) (BIT_CLEAR_CH2_LOW_TH(x) | BIT_CH2_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_3 (Offset 0x320C) */
#define BIT_CH3_INT_EN BIT(31)
#define BIT_SHIFT_CH3_HIGH_TH 16
#define BIT_MASK_CH3_HIGH_TH 0xfff
#define BIT_CH3_HIGH_TH(x) \
(((x) & BIT_MASK_CH3_HIGH_TH) << BIT_SHIFT_CH3_HIGH_TH)
#define BITS_CH3_HIGH_TH (BIT_MASK_CH3_HIGH_TH << BIT_SHIFT_CH3_HIGH_TH)
#define BIT_CLEAR_CH3_HIGH_TH(x) ((x) & (~BITS_CH3_HIGH_TH))
#define BIT_GET_CH3_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH3_HIGH_TH) & BIT_MASK_CH3_HIGH_TH)
#define BIT_SET_CH3_HIGH_TH(x, v) \
(BIT_CLEAR_CH3_HIGH_TH(x) | BIT_CH3_HIGH_TH(v))
#define BIT_SHIFT_CH3_LOW_TH 0
#define BIT_MASK_CH3_LOW_TH 0xfff
#define BIT_CH3_LOW_TH(x) (((x) & BIT_MASK_CH3_LOW_TH) << BIT_SHIFT_CH3_LOW_TH)
#define BITS_CH3_LOW_TH (BIT_MASK_CH3_LOW_TH << BIT_SHIFT_CH3_LOW_TH)
#define BIT_CLEAR_CH3_LOW_TH(x) ((x) & (~BITS_CH3_LOW_TH))
#define BIT_GET_CH3_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH3_LOW_TH) & BIT_MASK_CH3_LOW_TH)
#define BIT_SET_CH3_LOW_TH(x, v) (BIT_CLEAR_CH3_LOW_TH(x) | BIT_CH3_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_4 (Offset 0x3210) */
#define BIT_CH4_INT_EN BIT(31)
#define BIT_SHIFT_CH4_HIGH_TH 16
#define BIT_MASK_CH4_HIGH_TH 0xfff
#define BIT_CH4_HIGH_TH(x) \
(((x) & BIT_MASK_CH4_HIGH_TH) << BIT_SHIFT_CH4_HIGH_TH)
#define BITS_CH4_HIGH_TH (BIT_MASK_CH4_HIGH_TH << BIT_SHIFT_CH4_HIGH_TH)
#define BIT_CLEAR_CH4_HIGH_TH(x) ((x) & (~BITS_CH4_HIGH_TH))
#define BIT_GET_CH4_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH4_HIGH_TH) & BIT_MASK_CH4_HIGH_TH)
#define BIT_SET_CH4_HIGH_TH(x, v) \
(BIT_CLEAR_CH4_HIGH_TH(x) | BIT_CH4_HIGH_TH(v))
#define BIT_SHIFT_CH4_LOW_TH 0
#define BIT_MASK_CH4_LOW_TH 0xfff
#define BIT_CH4_LOW_TH(x) (((x) & BIT_MASK_CH4_LOW_TH) << BIT_SHIFT_CH4_LOW_TH)
#define BITS_CH4_LOW_TH (BIT_MASK_CH4_LOW_TH << BIT_SHIFT_CH4_LOW_TH)
#define BIT_CLEAR_CH4_LOW_TH(x) ((x) & (~BITS_CH4_LOW_TH))
#define BIT_GET_CH4_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH4_LOW_TH) & BIT_MASK_CH4_LOW_TH)
#define BIT_SET_CH4_LOW_TH(x, v) (BIT_CLEAR_CH4_LOW_TH(x) | BIT_CH4_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_5 (Offset 0x3214) */
#define BIT_CH5_INT_EN BIT(31)
#define BIT_SHIFT_CH5_HIGH_TH 16
#define BIT_MASK_CH5_HIGH_TH 0xfff
#define BIT_CH5_HIGH_TH(x) \
(((x) & BIT_MASK_CH5_HIGH_TH) << BIT_SHIFT_CH5_HIGH_TH)
#define BITS_CH5_HIGH_TH (BIT_MASK_CH5_HIGH_TH << BIT_SHIFT_CH5_HIGH_TH)
#define BIT_CLEAR_CH5_HIGH_TH(x) ((x) & (~BITS_CH5_HIGH_TH))
#define BIT_GET_CH5_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH5_HIGH_TH) & BIT_MASK_CH5_HIGH_TH)
#define BIT_SET_CH5_HIGH_TH(x, v) \
(BIT_CLEAR_CH5_HIGH_TH(x) | BIT_CH5_HIGH_TH(v))
#define BIT_SHIFT_CH5_LOW_TH 0
#define BIT_MASK_CH5_LOW_TH 0xfff
#define BIT_CH5_LOW_TH(x) (((x) & BIT_MASK_CH5_LOW_TH) << BIT_SHIFT_CH5_LOW_TH)
#define BITS_CH5_LOW_TH (BIT_MASK_CH5_LOW_TH << BIT_SHIFT_CH5_LOW_TH)
#define BIT_CLEAR_CH5_LOW_TH(x) ((x) & (~BITS_CH5_LOW_TH))
#define BIT_GET_CH5_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH5_LOW_TH) & BIT_MASK_CH5_LOW_TH)
#define BIT_SET_CH5_LOW_TH(x, v) (BIT_CLEAR_CH5_LOW_TH(x) | BIT_CH5_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_6 (Offset 0x3218) */
#define BIT_CH6_INT_EN BIT(31)
#define BIT_SHIFT_CH6_HIGH_TH 16
#define BIT_MASK_CH6_HIGH_TH 0xfff
#define BIT_CH6_HIGH_TH(x) \
(((x) & BIT_MASK_CH6_HIGH_TH) << BIT_SHIFT_CH6_HIGH_TH)
#define BITS_CH6_HIGH_TH (BIT_MASK_CH6_HIGH_TH << BIT_SHIFT_CH6_HIGH_TH)
#define BIT_CLEAR_CH6_HIGH_TH(x) ((x) & (~BITS_CH6_HIGH_TH))
#define BIT_GET_CH6_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH6_HIGH_TH) & BIT_MASK_CH6_HIGH_TH)
#define BIT_SET_CH6_HIGH_TH(x, v) \
(BIT_CLEAR_CH6_HIGH_TH(x) | BIT_CH6_HIGH_TH(v))
#define BIT_SHIFT_CH6_LOW_TH 0
#define BIT_MASK_CH6_LOW_TH 0xfff
#define BIT_CH6_LOW_TH(x) (((x) & BIT_MASK_CH6_LOW_TH) << BIT_SHIFT_CH6_LOW_TH)
#define BITS_CH6_LOW_TH (BIT_MASK_CH6_LOW_TH << BIT_SHIFT_CH6_LOW_TH)
#define BIT_CLEAR_CH6_LOW_TH(x) ((x) & (~BITS_CH6_LOW_TH))
#define BIT_GET_CH6_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH6_LOW_TH) & BIT_MASK_CH6_LOW_TH)
#define BIT_SET_CH6_LOW_TH(x, v) (BIT_CLEAR_CH6_LOW_TH(x) | BIT_CH6_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_7 (Offset 0x321C) */
#define BIT_CH7_INT_EN BIT(31)
#define BIT_SHIFT_CH7_HIGH_TH 16
#define BIT_MASK_CH7_HIGH_TH 0xfff
#define BIT_CH7_HIGH_TH(x) \
(((x) & BIT_MASK_CH7_HIGH_TH) << BIT_SHIFT_CH7_HIGH_TH)
#define BITS_CH7_HIGH_TH (BIT_MASK_CH7_HIGH_TH << BIT_SHIFT_CH7_HIGH_TH)
#define BIT_CLEAR_CH7_HIGH_TH(x) ((x) & (~BITS_CH7_HIGH_TH))
#define BIT_GET_CH7_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH7_HIGH_TH) & BIT_MASK_CH7_HIGH_TH)
#define BIT_SET_CH7_HIGH_TH(x, v) \
(BIT_CLEAR_CH7_HIGH_TH(x) | BIT_CH7_HIGH_TH(v))
#define BIT_SHIFT_CH7_LOW_TH 0
#define BIT_MASK_CH7_LOW_TH 0xfff
#define BIT_CH7_LOW_TH(x) (((x) & BIT_MASK_CH7_LOW_TH) << BIT_SHIFT_CH7_LOW_TH)
#define BITS_CH7_LOW_TH (BIT_MASK_CH7_LOW_TH << BIT_SHIFT_CH7_LOW_TH)
#define BIT_CLEAR_CH7_LOW_TH(x) ((x) & (~BITS_CH7_LOW_TH))
#define BIT_GET_CH7_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH7_LOW_TH) & BIT_MASK_CH7_LOW_TH)
#define BIT_SET_CH7_LOW_TH(x, v) (BIT_CLEAR_CH7_LOW_TH(x) | BIT_CH7_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_8 (Offset 0x3220) */
#define BIT_CH8_INT_EN BIT(31)
#define BIT_SHIFT_CH8_HIGH_TH 16
#define BIT_MASK_CH8_HIGH_TH 0xfff
#define BIT_CH8_HIGH_TH(x) \
(((x) & BIT_MASK_CH8_HIGH_TH) << BIT_SHIFT_CH8_HIGH_TH)
#define BITS_CH8_HIGH_TH (BIT_MASK_CH8_HIGH_TH << BIT_SHIFT_CH8_HIGH_TH)
#define BIT_CLEAR_CH8_HIGH_TH(x) ((x) & (~BITS_CH8_HIGH_TH))
#define BIT_GET_CH8_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH8_HIGH_TH) & BIT_MASK_CH8_HIGH_TH)
#define BIT_SET_CH8_HIGH_TH(x, v) \
(BIT_CLEAR_CH8_HIGH_TH(x) | BIT_CH8_HIGH_TH(v))
#define BIT_SHIFT_CH8_LOW_TH 0
#define BIT_MASK_CH8_LOW_TH 0xfff
#define BIT_CH8_LOW_TH(x) (((x) & BIT_MASK_CH8_LOW_TH) << BIT_SHIFT_CH8_LOW_TH)
#define BITS_CH8_LOW_TH (BIT_MASK_CH8_LOW_TH << BIT_SHIFT_CH8_LOW_TH)
#define BIT_CLEAR_CH8_LOW_TH(x) ((x) & (~BITS_CH8_LOW_TH))
#define BIT_GET_CH8_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH8_LOW_TH) & BIT_MASK_CH8_LOW_TH)
#define BIT_SET_CH8_LOW_TH(x, v) (BIT_CLEAR_CH8_LOW_TH(x) | BIT_CH8_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_9 (Offset 0x3224) */
#define BIT_CH9_INT_EN BIT(31)
#define BIT_SHIFT_CH9_HIGH_TH 16
#define BIT_MASK_CH9_HIGH_TH 0xfff
#define BIT_CH9_HIGH_TH(x) \
(((x) & BIT_MASK_CH9_HIGH_TH) << BIT_SHIFT_CH9_HIGH_TH)
#define BITS_CH9_HIGH_TH (BIT_MASK_CH9_HIGH_TH << BIT_SHIFT_CH9_HIGH_TH)
#define BIT_CLEAR_CH9_HIGH_TH(x) ((x) & (~BITS_CH9_HIGH_TH))
#define BIT_GET_CH9_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH9_HIGH_TH) & BIT_MASK_CH9_HIGH_TH)
#define BIT_SET_CH9_HIGH_TH(x, v) \
(BIT_CLEAR_CH9_HIGH_TH(x) | BIT_CH9_HIGH_TH(v))
#define BIT_SHIFT_CH9_LOW_TH 0
#define BIT_MASK_CH9_LOW_TH 0xfff
#define BIT_CH9_LOW_TH(x) (((x) & BIT_MASK_CH9_LOW_TH) << BIT_SHIFT_CH9_LOW_TH)
#define BITS_CH9_LOW_TH (BIT_MASK_CH9_LOW_TH << BIT_SHIFT_CH9_LOW_TH)
#define BIT_CLEAR_CH9_LOW_TH(x) ((x) & (~BITS_CH9_LOW_TH))
#define BIT_GET_CH9_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH9_LOW_TH) & BIT_MASK_CH9_LOW_TH)
#define BIT_SET_CH9_LOW_TH(x, v) (BIT_CLEAR_CH9_LOW_TH(x) | BIT_CH9_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_10 (Offset 0x3228) */
#define BIT_CH10_INT_EN BIT(31)
#define BIT_SHIFT_CH10_HIGH_TH 16
#define BIT_MASK_CH10_HIGH_TH 0xfff
#define BIT_CH10_HIGH_TH(x) \
(((x) & BIT_MASK_CH10_HIGH_TH) << BIT_SHIFT_CH10_HIGH_TH)
#define BITS_CH10_HIGH_TH (BIT_MASK_CH10_HIGH_TH << BIT_SHIFT_CH10_HIGH_TH)
#define BIT_CLEAR_CH10_HIGH_TH(x) ((x) & (~BITS_CH10_HIGH_TH))
#define BIT_GET_CH10_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH10_HIGH_TH) & BIT_MASK_CH10_HIGH_TH)
#define BIT_SET_CH10_HIGH_TH(x, v) \
(BIT_CLEAR_CH10_HIGH_TH(x) | BIT_CH10_HIGH_TH(v))
#define BIT_SHIFT_CH10_LOW_TH 0
#define BIT_MASK_CH10_LOW_TH 0xfff
#define BIT_CH10_LOW_TH(x) \
(((x) & BIT_MASK_CH10_LOW_TH) << BIT_SHIFT_CH10_LOW_TH)
#define BITS_CH10_LOW_TH (BIT_MASK_CH10_LOW_TH << BIT_SHIFT_CH10_LOW_TH)
#define BIT_CLEAR_CH10_LOW_TH(x) ((x) & (~BITS_CH10_LOW_TH))
#define BIT_GET_CH10_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH10_LOW_TH) & BIT_MASK_CH10_LOW_TH)
#define BIT_SET_CH10_LOW_TH(x, v) \
(BIT_CLEAR_CH10_LOW_TH(x) | BIT_CH10_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_11 (Offset 0x322C) */
#define BIT_CH11_INT_EN BIT(31)
#define BIT_SHIFT_CH11_HIGH_TH 16
#define BIT_MASK_CH11_HIGH_TH 0xfff
#define BIT_CH11_HIGH_TH(x) \
(((x) & BIT_MASK_CH11_HIGH_TH) << BIT_SHIFT_CH11_HIGH_TH)
#define BITS_CH11_HIGH_TH (BIT_MASK_CH11_HIGH_TH << BIT_SHIFT_CH11_HIGH_TH)
#define BIT_CLEAR_CH11_HIGH_TH(x) ((x) & (~BITS_CH11_HIGH_TH))
#define BIT_GET_CH11_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH11_HIGH_TH) & BIT_MASK_CH11_HIGH_TH)
#define BIT_SET_CH11_HIGH_TH(x, v) \
(BIT_CLEAR_CH11_HIGH_TH(x) | BIT_CH11_HIGH_TH(v))
#define BIT_SHIFT_CH11_LOW_TH 0
#define BIT_MASK_CH11_LOW_TH 0xfff
#define BIT_CH11_LOW_TH(x) \
(((x) & BIT_MASK_CH11_LOW_TH) << BIT_SHIFT_CH11_LOW_TH)
#define BITS_CH11_LOW_TH (BIT_MASK_CH11_LOW_TH << BIT_SHIFT_CH11_LOW_TH)
#define BIT_CLEAR_CH11_LOW_TH(x) ((x) & (~BITS_CH11_LOW_TH))
#define BIT_GET_CH11_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH11_LOW_TH) & BIT_MASK_CH11_LOW_TH)
#define BIT_SET_CH11_LOW_TH(x, v) \
(BIT_CLEAR_CH11_LOW_TH(x) | BIT_CH11_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_12 (Offset 0x3230) */
#define BIT_CH12_INT_EN BIT(31)
#define BIT_SHIFT_CH12_HIGH_TH 16
#define BIT_MASK_CH12_HIGH_TH 0xfff
#define BIT_CH12_HIGH_TH(x) \
(((x) & BIT_MASK_CH12_HIGH_TH) << BIT_SHIFT_CH12_HIGH_TH)
#define BITS_CH12_HIGH_TH (BIT_MASK_CH12_HIGH_TH << BIT_SHIFT_CH12_HIGH_TH)
#define BIT_CLEAR_CH12_HIGH_TH(x) ((x) & (~BITS_CH12_HIGH_TH))
#define BIT_GET_CH12_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH12_HIGH_TH) & BIT_MASK_CH12_HIGH_TH)
#define BIT_SET_CH12_HIGH_TH(x, v) \
(BIT_CLEAR_CH12_HIGH_TH(x) | BIT_CH12_HIGH_TH(v))
#define BIT_SHIFT_CH12_LOW_TH 0
#define BIT_MASK_CH12_LOW_TH 0xfff
#define BIT_CH12_LOW_TH(x) \
(((x) & BIT_MASK_CH12_LOW_TH) << BIT_SHIFT_CH12_LOW_TH)
#define BITS_CH12_LOW_TH (BIT_MASK_CH12_LOW_TH << BIT_SHIFT_CH12_LOW_TH)
#define BIT_CLEAR_CH12_LOW_TH(x) ((x) & (~BITS_CH12_LOW_TH))
#define BIT_GET_CH12_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH12_LOW_TH) & BIT_MASK_CH12_LOW_TH)
#define BIT_SET_CH12_LOW_TH(x, v) \
(BIT_CLEAR_CH12_LOW_TH(x) | BIT_CH12_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_13 (Offset 0x3234) */
#define BIT_CH13_INT_EN BIT(31)
#define BIT_SHIFT_CH13_HIGH_TH 16
#define BIT_MASK_CH13_HIGH_TH 0xfff
#define BIT_CH13_HIGH_TH(x) \
(((x) & BIT_MASK_CH13_HIGH_TH) << BIT_SHIFT_CH13_HIGH_TH)
#define BITS_CH13_HIGH_TH (BIT_MASK_CH13_HIGH_TH << BIT_SHIFT_CH13_HIGH_TH)
#define BIT_CLEAR_CH13_HIGH_TH(x) ((x) & (~BITS_CH13_HIGH_TH))
#define BIT_GET_CH13_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH13_HIGH_TH) & BIT_MASK_CH13_HIGH_TH)
#define BIT_SET_CH13_HIGH_TH(x, v) \
(BIT_CLEAR_CH13_HIGH_TH(x) | BIT_CH13_HIGH_TH(v))
#define BIT_SHIFT_CH13_LOW_TH 0
#define BIT_MASK_CH13_LOW_TH 0xfff
#define BIT_CH13_LOW_TH(x) \
(((x) & BIT_MASK_CH13_LOW_TH) << BIT_SHIFT_CH13_LOW_TH)
#define BITS_CH13_LOW_TH (BIT_MASK_CH13_LOW_TH << BIT_SHIFT_CH13_LOW_TH)
#define BIT_CLEAR_CH13_LOW_TH(x) ((x) & (~BITS_CH13_LOW_TH))
#define BIT_GET_CH13_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH13_LOW_TH) & BIT_MASK_CH13_LOW_TH)
#define BIT_SET_CH13_LOW_TH(x, v) \
(BIT_CLEAR_CH13_LOW_TH(x) | BIT_CH13_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_14 (Offset 0x3238) */
#define BIT_CH14_INT_EN BIT(31)
#define BIT_SHIFT_CH14_HIGH_TH 16
#define BIT_MASK_CH14_HIGH_TH 0xfff
#define BIT_CH14_HIGH_TH(x) \
(((x) & BIT_MASK_CH14_HIGH_TH) << BIT_SHIFT_CH14_HIGH_TH)
#define BITS_CH14_HIGH_TH (BIT_MASK_CH14_HIGH_TH << BIT_SHIFT_CH14_HIGH_TH)
#define BIT_CLEAR_CH14_HIGH_TH(x) ((x) & (~BITS_CH14_HIGH_TH))
#define BIT_GET_CH14_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH14_HIGH_TH) & BIT_MASK_CH14_HIGH_TH)
#define BIT_SET_CH14_HIGH_TH(x, v) \
(BIT_CLEAR_CH14_HIGH_TH(x) | BIT_CH14_HIGH_TH(v))
#define BIT_SHIFT_CH14_LOW_TH 0
#define BIT_MASK_CH14_LOW_TH 0xfff
#define BIT_CH14_LOW_TH(x) \
(((x) & BIT_MASK_CH14_LOW_TH) << BIT_SHIFT_CH14_LOW_TH)
#define BITS_CH14_LOW_TH (BIT_MASK_CH14_LOW_TH << BIT_SHIFT_CH14_LOW_TH)
#define BIT_CLEAR_CH14_LOW_TH(x) ((x) & (~BITS_CH14_LOW_TH))
#define BIT_GET_CH14_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH14_LOW_TH) & BIT_MASK_CH14_LOW_TH)
#define BIT_SET_CH14_LOW_TH(x, v) \
(BIT_CLEAR_CH14_LOW_TH(x) | BIT_CH14_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_15 (Offset 0x323C) */
#define BIT_CH15_INT_EN BIT(31)
#define BIT_SHIFT_CH15_HIGH_TH 16
#define BIT_MASK_CH15_HIGH_TH 0xfff
#define BIT_CH15_HIGH_TH(x) \
(((x) & BIT_MASK_CH15_HIGH_TH) << BIT_SHIFT_CH15_HIGH_TH)
#define BITS_CH15_HIGH_TH (BIT_MASK_CH15_HIGH_TH << BIT_SHIFT_CH15_HIGH_TH)
#define BIT_CLEAR_CH15_HIGH_TH(x) ((x) & (~BITS_CH15_HIGH_TH))
#define BIT_GET_CH15_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH15_HIGH_TH) & BIT_MASK_CH15_HIGH_TH)
#define BIT_SET_CH15_HIGH_TH(x, v) \
(BIT_CLEAR_CH15_HIGH_TH(x) | BIT_CH15_HIGH_TH(v))
#define BIT_SHIFT_CH15_LOW_TH 0
#define BIT_MASK_CH15_LOW_TH 0xfff
#define BIT_CH15_LOW_TH(x) \
(((x) & BIT_MASK_CH15_LOW_TH) << BIT_SHIFT_CH15_LOW_TH)
#define BITS_CH15_LOW_TH (BIT_MASK_CH15_LOW_TH << BIT_SHIFT_CH15_LOW_TH)
#define BIT_CLEAR_CH15_LOW_TH(x) ((x) & (~BITS_CH15_LOW_TH))
#define BIT_GET_CH15_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH15_LOW_TH) & BIT_MASK_CH15_LOW_TH)
#define BIT_SET_CH15_LOW_TH(x, v) \
(BIT_CLEAR_CH15_LOW_TH(x) | BIT_CH15_LOW_TH(v))
/* 2 REG_TXPAGE_INT_CTRL_16 (Offset 0x3240) */
#define BIT_CH16_INT_EN BIT(31)
#define BIT_SHIFT_CH16_HIGH_TH 16
#define BIT_MASK_CH16_HIGH_TH 0xfff
#define BIT_CH16_HIGH_TH(x) \
(((x) & BIT_MASK_CH16_HIGH_TH) << BIT_SHIFT_CH16_HIGH_TH)
#define BITS_CH16_HIGH_TH (BIT_MASK_CH16_HIGH_TH << BIT_SHIFT_CH16_HIGH_TH)
#define BIT_CLEAR_CH16_HIGH_TH(x) ((x) & (~BITS_CH16_HIGH_TH))
#define BIT_GET_CH16_HIGH_TH(x) \
(((x) >> BIT_SHIFT_CH16_HIGH_TH) & BIT_MASK_CH16_HIGH_TH)
#define BIT_SET_CH16_HIGH_TH(x, v) \
(BIT_CLEAR_CH16_HIGH_TH(x) | BIT_CH16_HIGH_TH(v))
#define BIT_SHIFT_CH16_LOW_TH 0
#define BIT_MASK_CH16_LOW_TH 0xfff
#define BIT_CH16_LOW_TH(x) \
(((x) & BIT_MASK_CH16_LOW_TH) << BIT_SHIFT_CH16_LOW_TH)
#define BITS_CH16_LOW_TH (BIT_MASK_CH16_LOW_TH << BIT_SHIFT_CH16_LOW_TH)
#define BIT_CLEAR_CH16_LOW_TH(x) ((x) & (~BITS_CH16_LOW_TH))
#define BIT_GET_CH16_LOW_TH(x) \
(((x) >> BIT_SHIFT_CH16_LOW_TH) & BIT_MASK_CH16_LOW_TH)
#define BIT_SET_CH16_LOW_TH(x, v) \
(BIT_CLEAR_CH16_LOW_TH(x) | BIT_CH16_LOW_TH(v))
/* 2 REG_ACH4_TXBD_IDX (Offset 0x3340) */
#define BIT_SHIFT_ACH4_HW_IDX 16
#define BIT_MASK_ACH4_HW_IDX 0xfff
#define BIT_ACH4_HW_IDX(x) \
(((x) & BIT_MASK_ACH4_HW_IDX) << BIT_SHIFT_ACH4_HW_IDX)
#define BITS_ACH4_HW_IDX (BIT_MASK_ACH4_HW_IDX << BIT_SHIFT_ACH4_HW_IDX)
#define BIT_CLEAR_ACH4_HW_IDX(x) ((x) & (~BITS_ACH4_HW_IDX))
#define BIT_GET_ACH4_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH4_HW_IDX) & BIT_MASK_ACH4_HW_IDX)
#define BIT_SET_ACH4_HW_IDX(x, v) \
(BIT_CLEAR_ACH4_HW_IDX(x) | BIT_ACH4_HW_IDX(v))
#define BIT_SHIFT_ACH4_HOST_IDX 0
#define BIT_MASK_ACH4_HOST_IDX 0xfff
#define BIT_ACH4_HOST_IDX(x) \
(((x) & BIT_MASK_ACH4_HOST_IDX) << BIT_SHIFT_ACH4_HOST_IDX)
#define BITS_ACH4_HOST_IDX (BIT_MASK_ACH4_HOST_IDX << BIT_SHIFT_ACH4_HOST_IDX)
#define BIT_CLEAR_ACH4_HOST_IDX(x) ((x) & (~BITS_ACH4_HOST_IDX))
#define BIT_GET_ACH4_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH4_HOST_IDX) & BIT_MASK_ACH4_HOST_IDX)
#define BIT_SET_ACH4_HOST_IDX(x, v) \
(BIT_CLEAR_ACH4_HOST_IDX(x) | BIT_ACH4_HOST_IDX(v))
/* 2 REG_ACH5_TXBD_IDX (Offset 0x3344) */
#define BIT_SHIFT_ACH5_HW_IDX 16
#define BIT_MASK_ACH5_HW_IDX 0xfff
#define BIT_ACH5_HW_IDX(x) \
(((x) & BIT_MASK_ACH5_HW_IDX) << BIT_SHIFT_ACH5_HW_IDX)
#define BITS_ACH5_HW_IDX (BIT_MASK_ACH5_HW_IDX << BIT_SHIFT_ACH5_HW_IDX)
#define BIT_CLEAR_ACH5_HW_IDX(x) ((x) & (~BITS_ACH5_HW_IDX))
#define BIT_GET_ACH5_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH5_HW_IDX) & BIT_MASK_ACH5_HW_IDX)
#define BIT_SET_ACH5_HW_IDX(x, v) \
(BIT_CLEAR_ACH5_HW_IDX(x) | BIT_ACH5_HW_IDX(v))
#define BIT_SHIFT_ACH5_HOST_IDX 0
#define BIT_MASK_ACH5_HOST_IDX 0xfff
#define BIT_ACH5_HOST_IDX(x) \
(((x) & BIT_MASK_ACH5_HOST_IDX) << BIT_SHIFT_ACH5_HOST_IDX)
#define BITS_ACH5_HOST_IDX (BIT_MASK_ACH5_HOST_IDX << BIT_SHIFT_ACH5_HOST_IDX)
#define BIT_CLEAR_ACH5_HOST_IDX(x) ((x) & (~BITS_ACH5_HOST_IDX))
#define BIT_GET_ACH5_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH5_HOST_IDX) & BIT_MASK_ACH5_HOST_IDX)
#define BIT_SET_ACH5_HOST_IDX(x, v) \
(BIT_CLEAR_ACH5_HOST_IDX(x) | BIT_ACH5_HOST_IDX(v))
/* 2 REG_ACH6_TXBD_IDX (Offset 0x3348) */
#define BIT_SHIFT_ACH6_HW_IDX 16
#define BIT_MASK_ACH6_HW_IDX 0xfff
#define BIT_ACH6_HW_IDX(x) \
(((x) & BIT_MASK_ACH6_HW_IDX) << BIT_SHIFT_ACH6_HW_IDX)
#define BITS_ACH6_HW_IDX (BIT_MASK_ACH6_HW_IDX << BIT_SHIFT_ACH6_HW_IDX)
#define BIT_CLEAR_ACH6_HW_IDX(x) ((x) & (~BITS_ACH6_HW_IDX))
#define BIT_GET_ACH6_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH6_HW_IDX) & BIT_MASK_ACH6_HW_IDX)
#define BIT_SET_ACH6_HW_IDX(x, v) \
(BIT_CLEAR_ACH6_HW_IDX(x) | BIT_ACH6_HW_IDX(v))
#define BIT_SHIFT_ACH6_HOST_IDX 0
#define BIT_MASK_ACH6_HOST_IDX 0xfff
#define BIT_ACH6_HOST_IDX(x) \
(((x) & BIT_MASK_ACH6_HOST_IDX) << BIT_SHIFT_ACH6_HOST_IDX)
#define BITS_ACH6_HOST_IDX (BIT_MASK_ACH6_HOST_IDX << BIT_SHIFT_ACH6_HOST_IDX)
#define BIT_CLEAR_ACH6_HOST_IDX(x) ((x) & (~BITS_ACH6_HOST_IDX))
#define BIT_GET_ACH6_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH6_HOST_IDX) & BIT_MASK_ACH6_HOST_IDX)
#define BIT_SET_ACH6_HOST_IDX(x, v) \
(BIT_CLEAR_ACH6_HOST_IDX(x) | BIT_ACH6_HOST_IDX(v))
/* 2 REG_ACH7_TXBD_IDX (Offset 0x334C) */
#define BIT_SHIFT_ACH7_HW_IDX 16
#define BIT_MASK_ACH7_HW_IDX 0xfff
#define BIT_ACH7_HW_IDX(x) \
(((x) & BIT_MASK_ACH7_HW_IDX) << BIT_SHIFT_ACH7_HW_IDX)
#define BITS_ACH7_HW_IDX (BIT_MASK_ACH7_HW_IDX << BIT_SHIFT_ACH7_HW_IDX)
#define BIT_CLEAR_ACH7_HW_IDX(x) ((x) & (~BITS_ACH7_HW_IDX))
#define BIT_GET_ACH7_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH7_HW_IDX) & BIT_MASK_ACH7_HW_IDX)
#define BIT_SET_ACH7_HW_IDX(x, v) \
(BIT_CLEAR_ACH7_HW_IDX(x) | BIT_ACH7_HW_IDX(v))
#define BIT_SHIFT_ACH7_HOST_IDX 0
#define BIT_MASK_ACH7_HOST_IDX 0xfff
#define BIT_ACH7_HOST_IDX(x) \
(((x) & BIT_MASK_ACH7_HOST_IDX) << BIT_SHIFT_ACH7_HOST_IDX)
#define BITS_ACH7_HOST_IDX (BIT_MASK_ACH7_HOST_IDX << BIT_SHIFT_ACH7_HOST_IDX)
#define BIT_CLEAR_ACH7_HOST_IDX(x) ((x) & (~BITS_ACH7_HOST_IDX))
#define BIT_GET_ACH7_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH7_HOST_IDX) & BIT_MASK_ACH7_HOST_IDX)
#define BIT_SET_ACH7_HOST_IDX(x, v) \
(BIT_CLEAR_ACH7_HOST_IDX(x) | BIT_ACH7_HOST_IDX(v))
/* 2 REG_ACH8_TXBD_IDX (Offset 0x3350) */
#define BIT_SHIFT_ACH8_HW_IDX 16
#define BIT_MASK_ACH8_HW_IDX 0xfff
#define BIT_ACH8_HW_IDX(x) \
(((x) & BIT_MASK_ACH8_HW_IDX) << BIT_SHIFT_ACH8_HW_IDX)
#define BITS_ACH8_HW_IDX (BIT_MASK_ACH8_HW_IDX << BIT_SHIFT_ACH8_HW_IDX)
#define BIT_CLEAR_ACH8_HW_IDX(x) ((x) & (~BITS_ACH8_HW_IDX))
#define BIT_GET_ACH8_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH8_HW_IDX) & BIT_MASK_ACH8_HW_IDX)
#define BIT_SET_ACH8_HW_IDX(x, v) \
(BIT_CLEAR_ACH8_HW_IDX(x) | BIT_ACH8_HW_IDX(v))
#define BIT_SHIFT_ACH8_HOST_IDX 0
#define BIT_MASK_ACH8_HOST_IDX 0xfff
#define BIT_ACH8_HOST_IDX(x) \
(((x) & BIT_MASK_ACH8_HOST_IDX) << BIT_SHIFT_ACH8_HOST_IDX)
#define BITS_ACH8_HOST_IDX (BIT_MASK_ACH8_HOST_IDX << BIT_SHIFT_ACH8_HOST_IDX)
#define BIT_CLEAR_ACH8_HOST_IDX(x) ((x) & (~BITS_ACH8_HOST_IDX))
#define BIT_GET_ACH8_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH8_HOST_IDX) & BIT_MASK_ACH8_HOST_IDX)
#define BIT_SET_ACH8_HOST_IDX(x, v) \
(BIT_CLEAR_ACH8_HOST_IDX(x) | BIT_ACH8_HOST_IDX(v))
/* 2 REG_ACH9_TXBD_IDX (Offset 0x3354) */
#define BIT_SHIFT_ACH9_HW_IDX 16
#define BIT_MASK_ACH9_HW_IDX 0xfff
#define BIT_ACH9_HW_IDX(x) \
(((x) & BIT_MASK_ACH9_HW_IDX) << BIT_SHIFT_ACH9_HW_IDX)
#define BITS_ACH9_HW_IDX (BIT_MASK_ACH9_HW_IDX << BIT_SHIFT_ACH9_HW_IDX)
#define BIT_CLEAR_ACH9_HW_IDX(x) ((x) & (~BITS_ACH9_HW_IDX))
#define BIT_GET_ACH9_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH9_HW_IDX) & BIT_MASK_ACH9_HW_IDX)
#define BIT_SET_ACH9_HW_IDX(x, v) \
(BIT_CLEAR_ACH9_HW_IDX(x) | BIT_ACH9_HW_IDX(v))
#define BIT_SHIFT_ACH9_HOST_IDX 0
#define BIT_MASK_ACH9_HOST_IDX 0xfff
#define BIT_ACH9_HOST_IDX(x) \
(((x) & BIT_MASK_ACH9_HOST_IDX) << BIT_SHIFT_ACH9_HOST_IDX)
#define BITS_ACH9_HOST_IDX (BIT_MASK_ACH9_HOST_IDX << BIT_SHIFT_ACH9_HOST_IDX)
#define BIT_CLEAR_ACH9_HOST_IDX(x) ((x) & (~BITS_ACH9_HOST_IDX))
#define BIT_GET_ACH9_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH9_HOST_IDX) & BIT_MASK_ACH9_HOST_IDX)
#define BIT_SET_ACH9_HOST_IDX(x, v) \
(BIT_CLEAR_ACH9_HOST_IDX(x) | BIT_ACH9_HOST_IDX(v))
/* 2 REG_ACH10_TXBD_IDX (Offset 0x3358) */
#define BIT_SHIFT_ACH10_HW_IDX 16
#define BIT_MASK_ACH10_HW_IDX 0xfff
#define BIT_ACH10_HW_IDX(x) \
(((x) & BIT_MASK_ACH10_HW_IDX) << BIT_SHIFT_ACH10_HW_IDX)
#define BITS_ACH10_HW_IDX (BIT_MASK_ACH10_HW_IDX << BIT_SHIFT_ACH10_HW_IDX)
#define BIT_CLEAR_ACH10_HW_IDX(x) ((x) & (~BITS_ACH10_HW_IDX))
#define BIT_GET_ACH10_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH10_HW_IDX) & BIT_MASK_ACH10_HW_IDX)
#define BIT_SET_ACH10_HW_IDX(x, v) \
(BIT_CLEAR_ACH10_HW_IDX(x) | BIT_ACH10_HW_IDX(v))
#define BIT_SHIFT_ACH10_HOST_IDX 0
#define BIT_MASK_ACH10_HOST_IDX 0xfff
#define BIT_ACH10_HOST_IDX(x) \
(((x) & BIT_MASK_ACH10_HOST_IDX) << BIT_SHIFT_ACH10_HOST_IDX)
#define BITS_ACH10_HOST_IDX \
(BIT_MASK_ACH10_HOST_IDX << BIT_SHIFT_ACH10_HOST_IDX)
#define BIT_CLEAR_ACH10_HOST_IDX(x) ((x) & (~BITS_ACH10_HOST_IDX))
#define BIT_GET_ACH10_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH10_HOST_IDX) & BIT_MASK_ACH10_HOST_IDX)
#define BIT_SET_ACH10_HOST_IDX(x, v) \
(BIT_CLEAR_ACH10_HOST_IDX(x) | BIT_ACH10_HOST_IDX(v))
/* 2 REG_ACH11_TXBD_IDX (Offset 0x335C) */
#define BIT_SHIFT_ACH11_HW_IDX 16
#define BIT_MASK_ACH11_HW_IDX 0xfff
#define BIT_ACH11_HW_IDX(x) \
(((x) & BIT_MASK_ACH11_HW_IDX) << BIT_SHIFT_ACH11_HW_IDX)
#define BITS_ACH11_HW_IDX (BIT_MASK_ACH11_HW_IDX << BIT_SHIFT_ACH11_HW_IDX)
#define BIT_CLEAR_ACH11_HW_IDX(x) ((x) & (~BITS_ACH11_HW_IDX))
#define BIT_GET_ACH11_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH11_HW_IDX) & BIT_MASK_ACH11_HW_IDX)
#define BIT_SET_ACH11_HW_IDX(x, v) \
(BIT_CLEAR_ACH11_HW_IDX(x) | BIT_ACH11_HW_IDX(v))
#define BIT_SHIFT_ACH11_HOST_IDX 0
#define BIT_MASK_ACH11_HOST_IDX 0xfff
#define BIT_ACH11_HOST_IDX(x) \
(((x) & BIT_MASK_ACH11_HOST_IDX) << BIT_SHIFT_ACH11_HOST_IDX)
#define BITS_ACH11_HOST_IDX \
(BIT_MASK_ACH11_HOST_IDX << BIT_SHIFT_ACH11_HOST_IDX)
#define BIT_CLEAR_ACH11_HOST_IDX(x) ((x) & (~BITS_ACH11_HOST_IDX))
#define BIT_GET_ACH11_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH11_HOST_IDX) & BIT_MASK_ACH11_HOST_IDX)
#define BIT_SET_ACH11_HOST_IDX(x, v) \
(BIT_CLEAR_ACH11_HOST_IDX(x) | BIT_ACH11_HOST_IDX(v))
/* 2 REG_ACH12_TXBD_IDX (Offset 0x3360) */
#define BIT_SHIFT_ACH12_HW_IDX 16
#define BIT_MASK_ACH12_HW_IDX 0xfff
#define BIT_ACH12_HW_IDX(x) \
(((x) & BIT_MASK_ACH12_HW_IDX) << BIT_SHIFT_ACH12_HW_IDX)
#define BITS_ACH12_HW_IDX (BIT_MASK_ACH12_HW_IDX << BIT_SHIFT_ACH12_HW_IDX)
#define BIT_CLEAR_ACH12_HW_IDX(x) ((x) & (~BITS_ACH12_HW_IDX))
#define BIT_GET_ACH12_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH12_HW_IDX) & BIT_MASK_ACH12_HW_IDX)
#define BIT_SET_ACH12_HW_IDX(x, v) \
(BIT_CLEAR_ACH12_HW_IDX(x) | BIT_ACH12_HW_IDX(v))
#define BIT_SHIFT_ACH12_HOST_IDX 0
#define BIT_MASK_ACH12_HOST_IDX 0xfff
#define BIT_ACH12_HOST_IDX(x) \
(((x) & BIT_MASK_ACH12_HOST_IDX) << BIT_SHIFT_ACH12_HOST_IDX)
#define BITS_ACH12_HOST_IDX \
(BIT_MASK_ACH12_HOST_IDX << BIT_SHIFT_ACH12_HOST_IDX)
#define BIT_CLEAR_ACH12_HOST_IDX(x) ((x) & (~BITS_ACH12_HOST_IDX))
#define BIT_GET_ACH12_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH12_HOST_IDX) & BIT_MASK_ACH12_HOST_IDX)
#define BIT_SET_ACH12_HOST_IDX(x, v) \
(BIT_CLEAR_ACH12_HOST_IDX(x) | BIT_ACH12_HOST_IDX(v))
/* 2 REG_ACH13_TXBD_IDX (Offset 0x3364) */
#define BIT_SHIFT_ACH13_HW_IDX 16
#define BIT_MASK_ACH13_HW_IDX 0xfff
#define BIT_ACH13_HW_IDX(x) \
(((x) & BIT_MASK_ACH13_HW_IDX) << BIT_SHIFT_ACH13_HW_IDX)
#define BITS_ACH13_HW_IDX (BIT_MASK_ACH13_HW_IDX << BIT_SHIFT_ACH13_HW_IDX)
#define BIT_CLEAR_ACH13_HW_IDX(x) ((x) & (~BITS_ACH13_HW_IDX))
#define BIT_GET_ACH13_HW_IDX(x) \
(((x) >> BIT_SHIFT_ACH13_HW_IDX) & BIT_MASK_ACH13_HW_IDX)
#define BIT_SET_ACH13_HW_IDX(x, v) \
(BIT_CLEAR_ACH13_HW_IDX(x) | BIT_ACH13_HW_IDX(v))
#define BIT_SHIFT_ACH13_HOST_IDX 0
#define BIT_MASK_ACH13_HOST_IDX 0xfff
#define BIT_ACH13_HOST_IDX(x) \
(((x) & BIT_MASK_ACH13_HOST_IDX) << BIT_SHIFT_ACH13_HOST_IDX)
#define BITS_ACH13_HOST_IDX \
(BIT_MASK_ACH13_HOST_IDX << BIT_SHIFT_ACH13_HOST_IDX)
#define BIT_CLEAR_ACH13_HOST_IDX(x) ((x) & (~BITS_ACH13_HOST_IDX))
#define BIT_GET_ACH13_HOST_IDX(x) \
(((x) >> BIT_SHIFT_ACH13_HOST_IDX) & BIT_MASK_ACH13_HOST_IDX)
#define BIT_SET_ACH13_HOST_IDX(x, v) \
(BIT_CLEAR_ACH13_HOST_IDX(x) | BIT_ACH13_HOST_IDX(v))
/* 2 REG_AC_CHANNEL0_WEIGHT (Offset 0x3368) */
#define BIT_SHIFT_AC_CHANNEL0_WEIGHT 0
#define BIT_MASK_AC_CHANNEL0_WEIGHT 0xff
#define BIT_AC_CHANNEL0_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL0_WEIGHT) << BIT_SHIFT_AC_CHANNEL0_WEIGHT)
#define BITS_AC_CHANNEL0_WEIGHT \
(BIT_MASK_AC_CHANNEL0_WEIGHT << BIT_SHIFT_AC_CHANNEL0_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL0_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL0_WEIGHT))
#define BIT_GET_AC_CHANNEL0_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL0_WEIGHT) & BIT_MASK_AC_CHANNEL0_WEIGHT)
#define BIT_SET_AC_CHANNEL0_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL0_WEIGHT(x) | BIT_AC_CHANNEL0_WEIGHT(v))
/* 2 REG_AC_CHANNEL1_WEIGHT (Offset 0x3369) */
#define BIT_SHIFT_AC_CHANNEL1_WEIGHT 0
#define BIT_MASK_AC_CHANNEL1_WEIGHT 0xff
#define BIT_AC_CHANNEL1_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL1_WEIGHT) << BIT_SHIFT_AC_CHANNEL1_WEIGHT)
#define BITS_AC_CHANNEL1_WEIGHT \
(BIT_MASK_AC_CHANNEL1_WEIGHT << BIT_SHIFT_AC_CHANNEL1_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL1_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL1_WEIGHT))
#define BIT_GET_AC_CHANNEL1_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL1_WEIGHT) & BIT_MASK_AC_CHANNEL1_WEIGHT)
#define BIT_SET_AC_CHANNEL1_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL1_WEIGHT(x) | BIT_AC_CHANNEL1_WEIGHT(v))
/* 2 REG_AC_CHANNEL2_WEIGHT (Offset 0x336A) */
#define BIT_SHIFT_AC_CHANNEL2_WEIGHT 0
#define BIT_MASK_AC_CHANNEL2_WEIGHT 0xff
#define BIT_AC_CHANNEL2_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL2_WEIGHT) << BIT_SHIFT_AC_CHANNEL2_WEIGHT)
#define BITS_AC_CHANNEL2_WEIGHT \
(BIT_MASK_AC_CHANNEL2_WEIGHT << BIT_SHIFT_AC_CHANNEL2_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL2_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL2_WEIGHT))
#define BIT_GET_AC_CHANNEL2_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL2_WEIGHT) & BIT_MASK_AC_CHANNEL2_WEIGHT)
#define BIT_SET_AC_CHANNEL2_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL2_WEIGHT(x) | BIT_AC_CHANNEL2_WEIGHT(v))
/* 2 REG_AC_CHANNEL3_WEIGHT (Offset 0x336B) */
#define BIT_SHIFT_AC_CHANNEL3_WEIGHT 0
#define BIT_MASK_AC_CHANNEL3_WEIGHT 0xff
#define BIT_AC_CHANNEL3_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL3_WEIGHT) << BIT_SHIFT_AC_CHANNEL3_WEIGHT)
#define BITS_AC_CHANNEL3_WEIGHT \
(BIT_MASK_AC_CHANNEL3_WEIGHT << BIT_SHIFT_AC_CHANNEL3_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL3_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL3_WEIGHT))
#define BIT_GET_AC_CHANNEL3_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL3_WEIGHT) & BIT_MASK_AC_CHANNEL3_WEIGHT)
#define BIT_SET_AC_CHANNEL3_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL3_WEIGHT(x) | BIT_AC_CHANNEL3_WEIGHT(v))
/* 2 REG_AC_CHANNEL4_WEIGHT (Offset 0x336C) */
#define BIT_SHIFT_AC_CHANNEL4_WEIGHT 0
#define BIT_MASK_AC_CHANNEL4_WEIGHT 0xff
#define BIT_AC_CHANNEL4_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL4_WEIGHT) << BIT_SHIFT_AC_CHANNEL4_WEIGHT)
#define BITS_AC_CHANNEL4_WEIGHT \
(BIT_MASK_AC_CHANNEL4_WEIGHT << BIT_SHIFT_AC_CHANNEL4_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL4_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL4_WEIGHT))
#define BIT_GET_AC_CHANNEL4_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL4_WEIGHT) & BIT_MASK_AC_CHANNEL4_WEIGHT)
#define BIT_SET_AC_CHANNEL4_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL4_WEIGHT(x) | BIT_AC_CHANNEL4_WEIGHT(v))
/* 2 REG_AC_CHANNEL5_WEIGHT (Offset 0x336D) */
#define BIT_SHIFT_AC_CHANNEL5_WEIGHT 0
#define BIT_MASK_AC_CHANNEL5_WEIGHT 0xff
#define BIT_AC_CHANNEL5_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL5_WEIGHT) << BIT_SHIFT_AC_CHANNEL5_WEIGHT)
#define BITS_AC_CHANNEL5_WEIGHT \
(BIT_MASK_AC_CHANNEL5_WEIGHT << BIT_SHIFT_AC_CHANNEL5_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL5_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL5_WEIGHT))
#define BIT_GET_AC_CHANNEL5_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL5_WEIGHT) & BIT_MASK_AC_CHANNEL5_WEIGHT)
#define BIT_SET_AC_CHANNEL5_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL5_WEIGHT(x) | BIT_AC_CHANNEL5_WEIGHT(v))
/* 2 REG_AC_CHANNEL6_WEIGHT (Offset 0x336E) */
#define BIT_SHIFT_AC_CHANNEL6_WEIGHT 0
#define BIT_MASK_AC_CHANNEL6_WEIGHT 0xff
#define BIT_AC_CHANNEL6_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL6_WEIGHT) << BIT_SHIFT_AC_CHANNEL6_WEIGHT)
#define BITS_AC_CHANNEL6_WEIGHT \
(BIT_MASK_AC_CHANNEL6_WEIGHT << BIT_SHIFT_AC_CHANNEL6_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL6_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL6_WEIGHT))
#define BIT_GET_AC_CHANNEL6_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL6_WEIGHT) & BIT_MASK_AC_CHANNEL6_WEIGHT)
#define BIT_SET_AC_CHANNEL6_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL6_WEIGHT(x) | BIT_AC_CHANNEL6_WEIGHT(v))
/* 2 REG_AC_CHANNEL7_WEIGHT (Offset 0x336F) */
#define BIT_SHIFT_AC_CHANNEL7_WEIGHT 0
#define BIT_MASK_AC_CHANNEL7_WEIGHT 0xff
#define BIT_AC_CHANNEL7_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL7_WEIGHT) << BIT_SHIFT_AC_CHANNEL7_WEIGHT)
#define BITS_AC_CHANNEL7_WEIGHT \
(BIT_MASK_AC_CHANNEL7_WEIGHT << BIT_SHIFT_AC_CHANNEL7_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL7_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL7_WEIGHT))
#define BIT_GET_AC_CHANNEL7_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL7_WEIGHT) & BIT_MASK_AC_CHANNEL7_WEIGHT)
#define BIT_SET_AC_CHANNEL7_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL7_WEIGHT(x) | BIT_AC_CHANNEL7_WEIGHT(v))
/* 2 REG_AC_CHANNEL8_WEIGHT (Offset 0x3370) */
#define BIT_SHIFT_AC_CHANNEL8_WEIGHT 0
#define BIT_MASK_AC_CHANNEL8_WEIGHT 0xff
#define BIT_AC_CHANNEL8_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL8_WEIGHT) << BIT_SHIFT_AC_CHANNEL8_WEIGHT)
#define BITS_AC_CHANNEL8_WEIGHT \
(BIT_MASK_AC_CHANNEL8_WEIGHT << BIT_SHIFT_AC_CHANNEL8_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL8_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL8_WEIGHT))
#define BIT_GET_AC_CHANNEL8_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL8_WEIGHT) & BIT_MASK_AC_CHANNEL8_WEIGHT)
#define BIT_SET_AC_CHANNEL8_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL8_WEIGHT(x) | BIT_AC_CHANNEL8_WEIGHT(v))
/* 2 REG_AC_CHANNEL9_WEIGHT (Offset 0x3371) */
#define BIT_SHIFT_AC_CHANNEL9_WEIGHT 0
#define BIT_MASK_AC_CHANNEL9_WEIGHT 0xff
#define BIT_AC_CHANNEL9_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL9_WEIGHT) << BIT_SHIFT_AC_CHANNEL9_WEIGHT)
#define BITS_AC_CHANNEL9_WEIGHT \
(BIT_MASK_AC_CHANNEL9_WEIGHT << BIT_SHIFT_AC_CHANNEL9_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL9_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL9_WEIGHT))
#define BIT_GET_AC_CHANNEL9_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL9_WEIGHT) & BIT_MASK_AC_CHANNEL9_WEIGHT)
#define BIT_SET_AC_CHANNEL9_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL9_WEIGHT(x) | BIT_AC_CHANNEL9_WEIGHT(v))
/* 2 REG_AC_CHANNEL10_WEIGHT (Offset 0x3372) */
#define BIT_SHIFT_AC_CHANNEL10_WEIGHT 0
#define BIT_MASK_AC_CHANNEL10_WEIGHT 0xff
#define BIT_AC_CHANNEL10_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL10_WEIGHT) << BIT_SHIFT_AC_CHANNEL10_WEIGHT)
#define BITS_AC_CHANNEL10_WEIGHT \
(BIT_MASK_AC_CHANNEL10_WEIGHT << BIT_SHIFT_AC_CHANNEL10_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL10_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL10_WEIGHT))
#define BIT_GET_AC_CHANNEL10_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL10_WEIGHT) & BIT_MASK_AC_CHANNEL10_WEIGHT)
#define BIT_SET_AC_CHANNEL10_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL10_WEIGHT(x) | BIT_AC_CHANNEL10_WEIGHT(v))
/* 2 REG_AC_CHANNEL11_WEIGHT (Offset 0x3373) */
#define BIT_SHIFT_AC_CHANNEL11_WEIGHT 0
#define BIT_MASK_AC_CHANNEL11_WEIGHT 0xff
#define BIT_AC_CHANNEL11_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL11_WEIGHT) << BIT_SHIFT_AC_CHANNEL11_WEIGHT)
#define BITS_AC_CHANNEL11_WEIGHT \
(BIT_MASK_AC_CHANNEL11_WEIGHT << BIT_SHIFT_AC_CHANNEL11_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL11_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL11_WEIGHT))
#define BIT_GET_AC_CHANNEL11_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL11_WEIGHT) & BIT_MASK_AC_CHANNEL11_WEIGHT)
#define BIT_SET_AC_CHANNEL11_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL11_WEIGHT(x) | BIT_AC_CHANNEL11_WEIGHT(v))
/* 2 REG_AC_CHANNEL12_WEIGHT (Offset 0x3374) */
#define BIT_SHIFT_AC_CHANNEL12_WEIGHT 0
#define BIT_MASK_AC_CHANNEL12_WEIGHT 0xff
#define BIT_AC_CHANNEL12_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL12_WEIGHT) << BIT_SHIFT_AC_CHANNEL12_WEIGHT)
#define BITS_AC_CHANNEL12_WEIGHT \
(BIT_MASK_AC_CHANNEL12_WEIGHT << BIT_SHIFT_AC_CHANNEL12_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL12_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL12_WEIGHT))
#define BIT_GET_AC_CHANNEL12_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL12_WEIGHT) & BIT_MASK_AC_CHANNEL12_WEIGHT)
#define BIT_SET_AC_CHANNEL12_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL12_WEIGHT(x) | BIT_AC_CHANNEL12_WEIGHT(v))
/* 2 REG_AC_CHANNEL13_WEIGHT (Offset 0x3375) */
#define BIT_SHIFT_AC_CHANNEL13_WEIGHT 0
#define BIT_MASK_AC_CHANNEL13_WEIGHT 0xff
#define BIT_AC_CHANNEL13_WEIGHT(x) \
(((x) & BIT_MASK_AC_CHANNEL13_WEIGHT) << BIT_SHIFT_AC_CHANNEL13_WEIGHT)
#define BITS_AC_CHANNEL13_WEIGHT \
(BIT_MASK_AC_CHANNEL13_WEIGHT << BIT_SHIFT_AC_CHANNEL13_WEIGHT)
#define BIT_CLEAR_AC_CHANNEL13_WEIGHT(x) ((x) & (~BITS_AC_CHANNEL13_WEIGHT))
#define BIT_GET_AC_CHANNEL13_WEIGHT(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL13_WEIGHT) & BIT_MASK_AC_CHANNEL13_WEIGHT)
#define BIT_SET_AC_CHANNEL13_WEIGHT(x, v) \
(BIT_CLEAR_AC_CHANNEL13_WEIGHT(x) | BIT_AC_CHANNEL13_WEIGHT(v))
#endif
#endif /* __RTL_WLAN_BITDEF_H__ */
================================================
FILE: hal/halmac/halmac_bit_8197f.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_BIT_8197F_H
#define __INC_HALMAC_BIT_8197F_H
#define CPU_OPT_WIDTH 0x1F
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SYS_ISO_CTRL_8197F */
#define BIT_PWC_EV12V_8197F BIT(15)
#define BIT_PWC_EV25V_8197F BIT(14)
#define BIT_PA33V_EN_8197F BIT(13)
#define BIT_PA12V_EN_8197F BIT(12)
#define BIT_UA33V_EN_8197F BIT(11)
#define BIT_UA12V_EN_8197F BIT(10)
#define BIT_ISO_RFDIO_8197F BIT(9)
#define BIT_ISO_EB2CORE_8197F BIT(8)
#define BIT_ISO_DIOE_8197F BIT(7)
#define BIT_ISO_WLPON2PP_8197F BIT(6)
#define BIT_ISO_IP2MAC_WA2PP_8197F BIT(5)
#define BIT_ISO_PD2CORE_8197F BIT(4)
#define BIT_ISO_PA2PCIE_8197F BIT(3)
#define BIT_ISO_UD2CORE_8197F BIT(2)
#define BIT_ISO_UA2USB_8197F BIT(1)
#define BIT_ISO_WD2PP_8197F BIT(0)
/* 2 REG_SYS_FUNC_EN_8197F */
#define BIT_FEN_MREGEN_8197F BIT(15)
#define BIT_FEN_HWPDN_8197F BIT(14)
#define BIT_EN_25_1_8197F BIT(13)
#define BIT_FEN_ELDR_8197F BIT(12)
#define BIT_FEN_DCORE_8197F BIT(11)
#define BIT_FEN_CPUEN_8197F BIT(10)
#define BIT_FEN_DIOE_8197F BIT(9)
#define BIT_FEN_PCIED_8197F BIT(8)
#define BIT_FEN_PPLL_8197F BIT(7)
#define BIT_FEN_PCIEA_8197F BIT(6)
#define BIT_FEN_DIO_PCIE_8197F BIT(5)
#define BIT_FEN_USBD_8197F BIT(4)
#define BIT_FEN_UPLL_8197F BIT(3)
#define BIT_FEN_USBA_8197F BIT(2)
#define BIT_FEN_BB_GLB_RSTN_8197F BIT(1)
#define BIT_FEN_BBRSTB_8197F BIT(0)
/* 2 REG_SYS_PW_CTRL_8197F */
#define BIT_SOP_EABM_8197F BIT(31)
#define BIT_SOP_ACKF_8197F BIT(30)
#define BIT_SOP_ERCK_8197F BIT(29)
#define BIT_SOP_ESWR_8197F BIT(28)
#define BIT_SOP_PWMM_8197F BIT(27)
#define BIT_SOP_EECK_8197F BIT(26)
#define BIT_SOP_EXTL_8197F BIT(24)
#define BIT_SYM_OP_RING_12M_8197F BIT(22)
#define BIT_ROP_SWPR_8197F BIT(21)
#define BIT_DIS_HW_LPLDM_8197F BIT(20)
#define BIT_OPT_SWRST_WLMCU_8197F BIT(19)
#define BIT_RDY_SYSPWR_8197F BIT(17)
#define BIT_EN_WLON_8197F BIT(16)
#define BIT_APDM_HPDN_8197F BIT(15)
#define BIT_AFSM_PCIE_SUS_EN_8197F BIT(12)
#define BIT_AFSM_WLSUS_EN_8197F BIT(11)
#define BIT_APFM_SWLPS_8197F BIT(10)
#define BIT_APFM_OFFMAC_8197F BIT(9)
#define BIT_APFN_ONMAC_8197F BIT(8)
#define BIT_CHIP_PDN_EN_8197F BIT(7)
#define BIT_RDY_MACDIS_8197F BIT(6)
#define BIT_RING_CLK_12M_EN_8197F BIT(4)
#define BIT_PFM_WOWL_8197F BIT(3)
#define BIT_PFM_LDKP_8197F BIT(2)
#define BIT_WL_HCI_ALD_8197F BIT(1)
#define BIT_PFM_LDALL_8197F BIT(0)
/* 2 REG_SYS_CLK_CTRL_8197F */
#define BIT_LDO_DUMMY_8197F BIT(15)
#define BIT_CPU_CLK_EN_8197F BIT(14)
#define BIT_SYMREG_CLK_EN_8197F BIT(13)
#define BIT_HCI_CLK_EN_8197F BIT(12)
#define BIT_MAC_CLK_EN_8197F BIT(11)
#define BIT_SEC_CLK_EN_8197F BIT(10)
#define BIT_PHY_SSC_RSTB_8197F BIT(9)
#define BIT_EXT_32K_EN_8197F BIT(8)
#define BIT_WL_CLK_TEST_8197F BIT(7)
#define BIT_OP_SPS_PWM_EN_8197F BIT(6)
#define BIT_LOADER_CLK_EN_8197F BIT(5)
#define BIT_MACSLP_8197F BIT(4)
#define BIT_WAKEPAD_EN_8197F BIT(3)
#define BIT_ROMD16V_EN_8197F BIT(2)
#define BIT_CKANA12M_EN_8197F BIT(1)
#define BIT_CNTD16V_EN_8197F BIT(0)
/* 2 REG_SYS_EEPROM_CTRL_8197F */
#define BIT_SHIFT_VPDIDX_8197F 8
#define BIT_MASK_VPDIDX_8197F 0xff
#define BIT_VPDIDX_8197F(x) \
(((x) & BIT_MASK_VPDIDX_8197F) << BIT_SHIFT_VPDIDX_8197F)
#define BITS_VPDIDX_8197F (BIT_MASK_VPDIDX_8197F << BIT_SHIFT_VPDIDX_8197F)
#define BIT_CLEAR_VPDIDX_8197F(x) ((x) & (~BITS_VPDIDX_8197F))
#define BIT_GET_VPDIDX_8197F(x) \
(((x) >> BIT_SHIFT_VPDIDX_8197F) & BIT_MASK_VPDIDX_8197F)
#define BIT_SET_VPDIDX_8197F(x, v) \
(BIT_CLEAR_VPDIDX_8197F(x) | BIT_VPDIDX_8197F(v))
#define BIT_SHIFT_EEM1_0_8197F 6
#define BIT_MASK_EEM1_0_8197F 0x3
#define BIT_EEM1_0_8197F(x) \
(((x) & BIT_MASK_EEM1_0_8197F) << BIT_SHIFT_EEM1_0_8197F)
#define BITS_EEM1_0_8197F (BIT_MASK_EEM1_0_8197F << BIT_SHIFT_EEM1_0_8197F)
#define BIT_CLEAR_EEM1_0_8197F(x) ((x) & (~BITS_EEM1_0_8197F))
#define BIT_GET_EEM1_0_8197F(x) \
(((x) >> BIT_SHIFT_EEM1_0_8197F) & BIT_MASK_EEM1_0_8197F)
#define BIT_SET_EEM1_0_8197F(x, v) \
(BIT_CLEAR_EEM1_0_8197F(x) | BIT_EEM1_0_8197F(v))
#define BIT_AUTOLOAD_SUS_8197F BIT(5)
#define BIT_EERPOMSEL_8197F BIT(4)
#define BIT_EECS_V1_8197F BIT(3)
#define BIT_EESK_V1_8197F BIT(2)
#define BIT_EEDI_V1_8197F BIT(1)
#define BIT_EEDO_V1_8197F BIT(0)
/* 2 REG_EE_VPD_8197F */
#define BIT_SHIFT_VPD_DATA_8197F 0
#define BIT_MASK_VPD_DATA_8197F 0xffffffffL
#define BIT_VPD_DATA_8197F(x) \
(((x) & BIT_MASK_VPD_DATA_8197F) << BIT_SHIFT_VPD_DATA_8197F)
#define BITS_VPD_DATA_8197F \
(BIT_MASK_VPD_DATA_8197F << BIT_SHIFT_VPD_DATA_8197F)
#define BIT_CLEAR_VPD_DATA_8197F(x) ((x) & (~BITS_VPD_DATA_8197F))
#define BIT_GET_VPD_DATA_8197F(x) \
(((x) >> BIT_SHIFT_VPD_DATA_8197F) & BIT_MASK_VPD_DATA_8197F)
#define BIT_SET_VPD_DATA_8197F(x, v) \
(BIT_CLEAR_VPD_DATA_8197F(x) | BIT_VPD_DATA_8197F(v))
/* 2 REG_SYS_SWR_CTRL1_8197F */
#define BIT_SW18_C2_BIT0_8197F BIT(31)
#define BIT_SHIFT_SW18_C1_8197F 29
#define BIT_MASK_SW18_C1_8197F 0x3
#define BIT_SW18_C1_8197F(x) \
(((x) & BIT_MASK_SW18_C1_8197F) << BIT_SHIFT_SW18_C1_8197F)
#define BITS_SW18_C1_8197F (BIT_MASK_SW18_C1_8197F << BIT_SHIFT_SW18_C1_8197F)
#define BIT_CLEAR_SW18_C1_8197F(x) ((x) & (~BITS_SW18_C1_8197F))
#define BIT_GET_SW18_C1_8197F(x) \
(((x) >> BIT_SHIFT_SW18_C1_8197F) & BIT_MASK_SW18_C1_8197F)
#define BIT_SET_SW18_C1_8197F(x, v) \
(BIT_CLEAR_SW18_C1_8197F(x) | BIT_SW18_C1_8197F(v))
#define BIT_SHIFT_REG_FREQ_L_8197F 25
#define BIT_MASK_REG_FREQ_L_8197F 0x7
#define BIT_REG_FREQ_L_8197F(x) \
(((x) & BIT_MASK_REG_FREQ_L_8197F) << BIT_SHIFT_REG_FREQ_L_8197F)
#define BITS_REG_FREQ_L_8197F \
(BIT_MASK_REG_FREQ_L_8197F << BIT_SHIFT_REG_FREQ_L_8197F)
#define BIT_CLEAR_REG_FREQ_L_8197F(x) ((x) & (~BITS_REG_FREQ_L_8197F))
#define BIT_GET_REG_FREQ_L_8197F(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L_8197F) & BIT_MASK_REG_FREQ_L_8197F)
#define BIT_SET_REG_FREQ_L_8197F(x, v) \
(BIT_CLEAR_REG_FREQ_L_8197F(x) | BIT_REG_FREQ_L_8197F(v))
#define BIT_REG_EN_DUTY_8197F BIT(24)
#define BIT_SHIFT_REG_MODE_8197F 22
#define BIT_MASK_REG_MODE_8197F 0x3
#define BIT_REG_MODE_8197F(x) \
(((x) & BIT_MASK_REG_MODE_8197F) << BIT_SHIFT_REG_MODE_8197F)
#define BITS_REG_MODE_8197F \
(BIT_MASK_REG_MODE_8197F << BIT_SHIFT_REG_MODE_8197F)
#define BIT_CLEAR_REG_MODE_8197F(x) ((x) & (~BITS_REG_MODE_8197F))
#define BIT_GET_REG_MODE_8197F(x) \
(((x) >> BIT_SHIFT_REG_MODE_8197F) & BIT_MASK_REG_MODE_8197F)
#define BIT_SET_REG_MODE_8197F(x, v) \
(BIT_CLEAR_REG_MODE_8197F(x) | BIT_REG_MODE_8197F(v))
#define BIT_REG_EN_SP_8197F BIT(21)
#define BIT_REG_AUTO_L_8197F BIT(20)
#define BIT_SW18_SELD_BIT0_8197F BIT(19)
#define BIT_SW18_POWOCP_8197F BIT(18)
#define BIT_SHIFT_SW18_OCP_8197F 15
#define BIT_MASK_SW18_OCP_8197F 0x7
#define BIT_SW18_OCP_8197F(x) \
(((x) & BIT_MASK_SW18_OCP_8197F) << BIT_SHIFT_SW18_OCP_8197F)
#define BITS_SW18_OCP_8197F \
(BIT_MASK_SW18_OCP_8197F << BIT_SHIFT_SW18_OCP_8197F)
#define BIT_CLEAR_SW18_OCP_8197F(x) ((x) & (~BITS_SW18_OCP_8197F))
#define BIT_GET_SW18_OCP_8197F(x) \
(((x) >> BIT_SHIFT_SW18_OCP_8197F) & BIT_MASK_SW18_OCP_8197F)
#define BIT_SET_SW18_OCP_8197F(x, v) \
(BIT_CLEAR_SW18_OCP_8197F(x) | BIT_SW18_OCP_8197F(v))
#define BIT_SHIFT_CF_L_BIT0_TO_1_8197F 13
#define BIT_MASK_CF_L_BIT0_TO_1_8197F 0x3
#define BIT_CF_L_BIT0_TO_1_8197F(x) \
(((x) & BIT_MASK_CF_L_BIT0_TO_1_8197F) \
<< BIT_SHIFT_CF_L_BIT0_TO_1_8197F)
#define BITS_CF_L_BIT0_TO_1_8197F \
(BIT_MASK_CF_L_BIT0_TO_1_8197F << BIT_SHIFT_CF_L_BIT0_TO_1_8197F)
#define BIT_CLEAR_CF_L_BIT0_TO_1_8197F(x) ((x) & (~BITS_CF_L_BIT0_TO_1_8197F))
#define BIT_GET_CF_L_BIT0_TO_1_8197F(x) \
(((x) >> BIT_SHIFT_CF_L_BIT0_TO_1_8197F) & \
BIT_MASK_CF_L_BIT0_TO_1_8197F)
#define BIT_SET_CF_L_BIT0_TO_1_8197F(x, v) \
(BIT_CLEAR_CF_L_BIT0_TO_1_8197F(x) | BIT_CF_L_BIT0_TO_1_8197F(v))
#define BIT_SW18_FPWM_8197F BIT(11)
#define BIT_SW18_SWEN_8197F BIT(9)
#define BIT_SW18_LDEN_8197F BIT(8)
#define BIT_MAC_ID_EN_8197F BIT(7)
#define BIT_WL_CTRL_XTAL_CADJ_8197F BIT(6)
#define BIT_AFE_BGEN_8197F BIT(0)
/* 2 REG_SYS_SWR_CTRL2_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SYS_SWR_CTRL3_8197F */
#define BIT_SPS18_OCP_DIS_8197F BIT(31)
#define BIT_SHIFT_SPS18_OCP_TH_8197F 16
#define BIT_MASK_SPS18_OCP_TH_8197F 0x7fff
#define BIT_SPS18_OCP_TH_8197F(x) \
(((x) & BIT_MASK_SPS18_OCP_TH_8197F) << BIT_SHIFT_SPS18_OCP_TH_8197F)
#define BITS_SPS18_OCP_TH_8197F \
(BIT_MASK_SPS18_OCP_TH_8197F << BIT_SHIFT_SPS18_OCP_TH_8197F)
#define BIT_CLEAR_SPS18_OCP_TH_8197F(x) ((x) & (~BITS_SPS18_OCP_TH_8197F))
#define BIT_GET_SPS18_OCP_TH_8197F(x) \
(((x) >> BIT_SHIFT_SPS18_OCP_TH_8197F) & BIT_MASK_SPS18_OCP_TH_8197F)
#define BIT_SET_SPS18_OCP_TH_8197F(x, v) \
(BIT_CLEAR_SPS18_OCP_TH_8197F(x) | BIT_SPS18_OCP_TH_8197F(v))
#define BIT_SHIFT_OCP_WINDOW_8197F 0
#define BIT_MASK_OCP_WINDOW_8197F 0xffff
#define BIT_OCP_WINDOW_8197F(x) \
(((x) & BIT_MASK_OCP_WINDOW_8197F) << BIT_SHIFT_OCP_WINDOW_8197F)
#define BITS_OCP_WINDOW_8197F \
(BIT_MASK_OCP_WINDOW_8197F << BIT_SHIFT_OCP_WINDOW_8197F)
#define BIT_CLEAR_OCP_WINDOW_8197F(x) ((x) & (~BITS_OCP_WINDOW_8197F))
#define BIT_GET_OCP_WINDOW_8197F(x) \
(((x) >> BIT_SHIFT_OCP_WINDOW_8197F) & BIT_MASK_OCP_WINDOW_8197F)
#define BIT_SET_OCP_WINDOW_8197F(x, v) \
(BIT_CLEAR_OCP_WINDOW_8197F(x) | BIT_OCP_WINDOW_8197F(v))
/* 2 REG_RSV_CTRL_8197F */
#define BIT_HREG_DBG_8197F BIT(23)
#define BIT_WLMCUIOIF_8197F BIT(8)
#define BIT_LOCK_ALL_EN_8197F BIT(7)
#define BIT_R_DIS_PRST_8197F BIT(6)
#define BIT_WLOCK_1C_B6_8197F BIT(5)
#define BIT_WLOCK_40_8197F BIT(4)
#define BIT_WLOCK_08_8197F BIT(3)
#define BIT_WLOCK_04_8197F BIT(2)
#define BIT_WLOCK_00_8197F BIT(1)
#define BIT_WLOCK_ALL_8197F BIT(0)
/* 2 REG_RF0_CTRL_8197F */
#define BIT_RF0_SDMRSTB_8197F BIT(2)
#define BIT_RF0_RSTB_8197F BIT(1)
#define BIT_RF0_EN_8197F BIT(0)
/* 2 REG_AFE_LDO_CTRL_8197F */
#define BIT_SHIFT_LPLDH12_RSV_8197F 29
#define BIT_MASK_LPLDH12_RSV_8197F 0x7
#define BIT_LPLDH12_RSV_8197F(x) \
(((x) & BIT_MASK_LPLDH12_RSV_8197F) << BIT_SHIFT_LPLDH12_RSV_8197F)
#define BITS_LPLDH12_RSV_8197F \
(BIT_MASK_LPLDH12_RSV_8197F << BIT_SHIFT_LPLDH12_RSV_8197F)
#define BIT_CLEAR_LPLDH12_RSV_8197F(x) ((x) & (~BITS_LPLDH12_RSV_8197F))
#define BIT_GET_LPLDH12_RSV_8197F(x) \
(((x) >> BIT_SHIFT_LPLDH12_RSV_8197F) & BIT_MASK_LPLDH12_RSV_8197F)
#define BIT_SET_LPLDH12_RSV_8197F(x, v) \
(BIT_CLEAR_LPLDH12_RSV_8197F(x) | BIT_LPLDH12_RSV_8197F(v))
#define BIT_LPLDH12_SLP_8197F BIT(28)
#define BIT_SHIFT_LPLDH12_VADJ_8197F 24
#define BIT_MASK_LPLDH12_VADJ_8197F 0xf
#define BIT_LPLDH12_VADJ_8197F(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_8197F) << BIT_SHIFT_LPLDH12_VADJ_8197F)
#define BITS_LPLDH12_VADJ_8197F \
(BIT_MASK_LPLDH12_VADJ_8197F << BIT_SHIFT_LPLDH12_VADJ_8197F)
#define BIT_CLEAR_LPLDH12_VADJ_8197F(x) ((x) & (~BITS_LPLDH12_VADJ_8197F))
#define BIT_GET_LPLDH12_VADJ_8197F(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_8197F) & BIT_MASK_LPLDH12_VADJ_8197F)
#define BIT_SET_LPLDH12_VADJ_8197F(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_8197F(x) | BIT_LPLDH12_VADJ_8197F(v))
#define BIT_LDH12_EN_8197F BIT(16)
#define BIT_POW_REGU_P1_8197F BIT(10)
#define BIT_LDOV12W_EN_8197F BIT(8)
#define BIT_EX_XTAL_DRV_DIGI_8197F BIT(7)
#define BIT_EX_XTAL_DRV_USB_8197F BIT(6)
#define BIT_EX_XTAL_DRV_AFE_8197F BIT(5)
#define BIT_EX_XTAL_DRV_RF2_8197F BIT(4)
#define BIT_EX_XTAL_DRV_RF1_8197F BIT(3)
#define BIT_POW_REGU_P0_8197F BIT(2)
/* 2 REG_NOT_VALID_8197F */
#define BIT_POW_PLL_LDO_8197F BIT(0)
/* 2 REG_AFE_CTRL1_8197F */
#define BIT_AGPIO_GPE_8197F BIT(31)
#define BIT_SHIFT_XTAL_CAP_XI_8197F 25
#define BIT_MASK_XTAL_CAP_XI_8197F 0x3f
#define BIT_XTAL_CAP_XI_8197F(x) \
(((x) & BIT_MASK_XTAL_CAP_XI_8197F) << BIT_SHIFT_XTAL_CAP_XI_8197F)
#define BITS_XTAL_CAP_XI_8197F \
(BIT_MASK_XTAL_CAP_XI_8197F << BIT_SHIFT_XTAL_CAP_XI_8197F)
#define BIT_CLEAR_XTAL_CAP_XI_8197F(x) ((x) & (~BITS_XTAL_CAP_XI_8197F))
#define BIT_GET_XTAL_CAP_XI_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XI_8197F) & BIT_MASK_XTAL_CAP_XI_8197F)
#define BIT_SET_XTAL_CAP_XI_8197F(x, v) \
(BIT_CLEAR_XTAL_CAP_XI_8197F(x) | BIT_XTAL_CAP_XI_8197F(v))
#define BIT_SHIFT_XTAL_DRV_DIGI_8197F 23
#define BIT_MASK_XTAL_DRV_DIGI_8197F 0x3
#define BIT_XTAL_DRV_DIGI_8197F(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_8197F) << BIT_SHIFT_XTAL_DRV_DIGI_8197F)
#define BITS_XTAL_DRV_DIGI_8197F \
(BIT_MASK_XTAL_DRV_DIGI_8197F << BIT_SHIFT_XTAL_DRV_DIGI_8197F)
#define BIT_CLEAR_XTAL_DRV_DIGI_8197F(x) ((x) & (~BITS_XTAL_DRV_DIGI_8197F))
#define BIT_GET_XTAL_DRV_DIGI_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_8197F) & BIT_MASK_XTAL_DRV_DIGI_8197F)
#define BIT_SET_XTAL_DRV_DIGI_8197F(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_8197F(x) | BIT_XTAL_DRV_DIGI_8197F(v))
#define BIT_XTAL_DRV_USB_BIT1_8197F BIT(22)
#define BIT_SHIFT_MAC_CLK_SEL_8197F 20
#define BIT_MASK_MAC_CLK_SEL_8197F 0x3
#define BIT_MAC_CLK_SEL_8197F(x) \
(((x) & BIT_MASK_MAC_CLK_SEL_8197F) << BIT_SHIFT_MAC_CLK_SEL_8197F)
#define BITS_MAC_CLK_SEL_8197F \
(BIT_MASK_MAC_CLK_SEL_8197F << BIT_SHIFT_MAC_CLK_SEL_8197F)
#define BIT_CLEAR_MAC_CLK_SEL_8197F(x) ((x) & (~BITS_MAC_CLK_SEL_8197F))
#define BIT_GET_MAC_CLK_SEL_8197F(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL_8197F) & BIT_MASK_MAC_CLK_SEL_8197F)
#define BIT_SET_MAC_CLK_SEL_8197F(x, v) \
(BIT_CLEAR_MAC_CLK_SEL_8197F(x) | BIT_MAC_CLK_SEL_8197F(v))
#define BIT_XTAL_DRV_USB_BIT0_8197F BIT(19)
#define BIT_SHIFT_XTAL_DRV_AFE_8197F 17
#define BIT_MASK_XTAL_DRV_AFE_8197F 0x3
#define BIT_XTAL_DRV_AFE_8197F(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_8197F) << BIT_SHIFT_XTAL_DRV_AFE_8197F)
#define BITS_XTAL_DRV_AFE_8197F \
(BIT_MASK_XTAL_DRV_AFE_8197F << BIT_SHIFT_XTAL_DRV_AFE_8197F)
#define BIT_CLEAR_XTAL_DRV_AFE_8197F(x) ((x) & (~BITS_XTAL_DRV_AFE_8197F))
#define BIT_GET_XTAL_DRV_AFE_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_8197F) & BIT_MASK_XTAL_DRV_AFE_8197F)
#define BIT_SET_XTAL_DRV_AFE_8197F(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_8197F(x) | BIT_XTAL_DRV_AFE_8197F(v))
#define BIT_SHIFT_XTAL_DRV_RF2_8197F 15
#define BIT_MASK_XTAL_DRV_RF2_8197F 0x3
#define BIT_XTAL_DRV_RF2_8197F(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_8197F) << BIT_SHIFT_XTAL_DRV_RF2_8197F)
#define BITS_XTAL_DRV_RF2_8197F \
(BIT_MASK_XTAL_DRV_RF2_8197F << BIT_SHIFT_XTAL_DRV_RF2_8197F)
#define BIT_CLEAR_XTAL_DRV_RF2_8197F(x) ((x) & (~BITS_XTAL_DRV_RF2_8197F))
#define BIT_GET_XTAL_DRV_RF2_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_8197F) & BIT_MASK_XTAL_DRV_RF2_8197F)
#define BIT_SET_XTAL_DRV_RF2_8197F(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_8197F(x) | BIT_XTAL_DRV_RF2_8197F(v))
#define BIT_SHIFT_XTAL_DRV_RF1_8197F 13
#define BIT_MASK_XTAL_DRV_RF1_8197F 0x3
#define BIT_XTAL_DRV_RF1_8197F(x) \
(((x) & BIT_MASK_XTAL_DRV_RF1_8197F) << BIT_SHIFT_XTAL_DRV_RF1_8197F)
#define BITS_XTAL_DRV_RF1_8197F \
(BIT_MASK_XTAL_DRV_RF1_8197F << BIT_SHIFT_XTAL_DRV_RF1_8197F)
#define BIT_CLEAR_XTAL_DRV_RF1_8197F(x) ((x) & (~BITS_XTAL_DRV_RF1_8197F))
#define BIT_GET_XTAL_DRV_RF1_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF1_8197F) & BIT_MASK_XTAL_DRV_RF1_8197F)
#define BIT_SET_XTAL_DRV_RF1_8197F(x, v) \
(BIT_CLEAR_XTAL_DRV_RF1_8197F(x) | BIT_XTAL_DRV_RF1_8197F(v))
#define BIT_XTAL_DELAY_DIGI_8197F BIT(12)
#define BIT_XTAL_DELAY_USB_8197F BIT(11)
#define BIT_XTAL_DELAY_AFE_8197F BIT(10)
#define BIT_XTAL_LP_V1_8197F BIT(9)
#define BIT_XTAL_GM_SEP_V1_8197F BIT(8)
#define BIT_XTAL_LDO_VREF_V1_8197F BIT(7)
#define BIT_XTAL_XQSEL_RF_8197F BIT(6)
#define BIT_XTAL_XQSEL_8197F BIT(5)
#define BIT_SHIFT_XTAL_GMN_V1_8197F 3
#define BIT_MASK_XTAL_GMN_V1_8197F 0x3
#define BIT_XTAL_GMN_V1_8197F(x) \
(((x) & BIT_MASK_XTAL_GMN_V1_8197F) << BIT_SHIFT_XTAL_GMN_V1_8197F)
#define BITS_XTAL_GMN_V1_8197F \
(BIT_MASK_XTAL_GMN_V1_8197F << BIT_SHIFT_XTAL_GMN_V1_8197F)
#define BIT_CLEAR_XTAL_GMN_V1_8197F(x) ((x) & (~BITS_XTAL_GMN_V1_8197F))
#define BIT_GET_XTAL_GMN_V1_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V1_8197F) & BIT_MASK_XTAL_GMN_V1_8197F)
#define BIT_SET_XTAL_GMN_V1_8197F(x, v) \
(BIT_CLEAR_XTAL_GMN_V1_8197F(x) | BIT_XTAL_GMN_V1_8197F(v))
#define BIT_SHIFT_XTAL_GMP_V1_8197F 1
#define BIT_MASK_XTAL_GMP_V1_8197F 0x3
#define BIT_XTAL_GMP_V1_8197F(x) \
(((x) & BIT_MASK_XTAL_GMP_V1_8197F) << BIT_SHIFT_XTAL_GMP_V1_8197F)
#define BITS_XTAL_GMP_V1_8197F \
(BIT_MASK_XTAL_GMP_V1_8197F << BIT_SHIFT_XTAL_GMP_V1_8197F)
#define BIT_CLEAR_XTAL_GMP_V1_8197F(x) ((x) & (~BITS_XTAL_GMP_V1_8197F))
#define BIT_GET_XTAL_GMP_V1_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V1_8197F) & BIT_MASK_XTAL_GMP_V1_8197F)
#define BIT_SET_XTAL_GMP_V1_8197F(x, v) \
(BIT_CLEAR_XTAL_GMP_V1_8197F(x) | BIT_XTAL_GMP_V1_8197F(v))
#define BIT_XTAL_EN_8197F BIT(0)
/* 2 REG_AFE_CTRL2_8197F */
#define BIT_SHIFT_RS_SET_V2_8197F 26
#define BIT_MASK_RS_SET_V2_8197F 0x7
#define BIT_RS_SET_V2_8197F(x) \
(((x) & BIT_MASK_RS_SET_V2_8197F) << BIT_SHIFT_RS_SET_V2_8197F)
#define BITS_RS_SET_V2_8197F \
(BIT_MASK_RS_SET_V2_8197F << BIT_SHIFT_RS_SET_V2_8197F)
#define BIT_CLEAR_RS_SET_V2_8197F(x) ((x) & (~BITS_RS_SET_V2_8197F))
#define BIT_GET_RS_SET_V2_8197F(x) \
(((x) >> BIT_SHIFT_RS_SET_V2_8197F) & BIT_MASK_RS_SET_V2_8197F)
#define BIT_SET_RS_SET_V2_8197F(x, v) \
(BIT_CLEAR_RS_SET_V2_8197F(x) | BIT_RS_SET_V2_8197F(v))
#define BIT_SHIFT_CP_BIAS_V2_8197F 18
#define BIT_MASK_CP_BIAS_V2_8197F 0x7
#define BIT_CP_BIAS_V2_8197F(x) \
(((x) & BIT_MASK_CP_BIAS_V2_8197F) << BIT_SHIFT_CP_BIAS_V2_8197F)
#define BITS_CP_BIAS_V2_8197F \
(BIT_MASK_CP_BIAS_V2_8197F << BIT_SHIFT_CP_BIAS_V2_8197F)
#define BIT_CLEAR_CP_BIAS_V2_8197F(x) ((x) & (~BITS_CP_BIAS_V2_8197F))
#define BIT_GET_CP_BIAS_V2_8197F(x) \
(((x) >> BIT_SHIFT_CP_BIAS_V2_8197F) & BIT_MASK_CP_BIAS_V2_8197F)
#define BIT_SET_CP_BIAS_V2_8197F(x, v) \
(BIT_CLEAR_CP_BIAS_V2_8197F(x) | BIT_CP_BIAS_V2_8197F(v))
#define BIT_FREF_SEL_8197F BIT(16)
#define BIT_SHIFT_MCCO_V2_8197F 14
#define BIT_MASK_MCCO_V2_8197F 0x3
#define BIT_MCCO_V2_8197F(x) \
(((x) & BIT_MASK_MCCO_V2_8197F) << BIT_SHIFT_MCCO_V2_8197F)
#define BITS_MCCO_V2_8197F (BIT_MASK_MCCO_V2_8197F << BIT_SHIFT_MCCO_V2_8197F)
#define BIT_CLEAR_MCCO_V2_8197F(x) ((x) & (~BITS_MCCO_V2_8197F))
#define BIT_GET_MCCO_V2_8197F(x) \
(((x) >> BIT_SHIFT_MCCO_V2_8197F) & BIT_MASK_MCCO_V2_8197F)
#define BIT_SET_MCCO_V2_8197F(x, v) \
(BIT_CLEAR_MCCO_V2_8197F(x) | BIT_MCCO_V2_8197F(v))
#define BIT_SHIFT_CK320_EN_8197F 12
#define BIT_MASK_CK320_EN_8197F 0x3
#define BIT_CK320_EN_8197F(x) \
(((x) & BIT_MASK_CK320_EN_8197F) << BIT_SHIFT_CK320_EN_8197F)
#define BITS_CK320_EN_8197F \
(BIT_MASK_CK320_EN_8197F << BIT_SHIFT_CK320_EN_8197F)
#define BIT_CLEAR_CK320_EN_8197F(x) ((x) & (~BITS_CK320_EN_8197F))
#define BIT_GET_CK320_EN_8197F(x) \
(((x) >> BIT_SHIFT_CK320_EN_8197F) & BIT_MASK_CK320_EN_8197F)
#define BIT_SET_CK320_EN_8197F(x, v) \
(BIT_CLEAR_CK320_EN_8197F(x) | BIT_CK320_EN_8197F(v))
#define BIT_AGPIO_GPO_8197F BIT(9)
#define BIT_SHIFT_AGPIO_DRV_8197F 7
#define BIT_MASK_AGPIO_DRV_8197F 0x3
#define BIT_AGPIO_DRV_8197F(x) \
(((x) & BIT_MASK_AGPIO_DRV_8197F) << BIT_SHIFT_AGPIO_DRV_8197F)
#define BITS_AGPIO_DRV_8197F \
(BIT_MASK_AGPIO_DRV_8197F << BIT_SHIFT_AGPIO_DRV_8197F)
#define BIT_CLEAR_AGPIO_DRV_8197F(x) ((x) & (~BITS_AGPIO_DRV_8197F))
#define BIT_GET_AGPIO_DRV_8197F(x) \
(((x) >> BIT_SHIFT_AGPIO_DRV_8197F) & BIT_MASK_AGPIO_DRV_8197F)
#define BIT_SET_AGPIO_DRV_8197F(x, v) \
(BIT_CLEAR_AGPIO_DRV_8197F(x) | BIT_AGPIO_DRV_8197F(v))
#define BIT_SHIFT_XTAL_CAP_XO_8197F 1
#define BIT_MASK_XTAL_CAP_XO_8197F 0x3f
#define BIT_XTAL_CAP_XO_8197F(x) \
(((x) & BIT_MASK_XTAL_CAP_XO_8197F) << BIT_SHIFT_XTAL_CAP_XO_8197F)
#define BITS_XTAL_CAP_XO_8197F \
(BIT_MASK_XTAL_CAP_XO_8197F << BIT_SHIFT_XTAL_CAP_XO_8197F)
#define BIT_CLEAR_XTAL_CAP_XO_8197F(x) ((x) & (~BITS_XTAL_CAP_XO_8197F))
#define BIT_GET_XTAL_CAP_XO_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XO_8197F) & BIT_MASK_XTAL_CAP_XO_8197F)
#define BIT_SET_XTAL_CAP_XO_8197F(x, v) \
(BIT_CLEAR_XTAL_CAP_XO_8197F(x) | BIT_XTAL_CAP_XO_8197F(v))
#define BIT_POW_PLL_8197F BIT(0)
/* 2 REG_AFE_CTRL3_8197F */
#define BIT_SHIFT_PS_V2_8197F 7
#define BIT_MASK_PS_V2_8197F 0x7
#define BIT_PS_V2_8197F(x) \
(((x) & BIT_MASK_PS_V2_8197F) << BIT_SHIFT_PS_V2_8197F)
#define BITS_PS_V2_8197F (BIT_MASK_PS_V2_8197F << BIT_SHIFT_PS_V2_8197F)
#define BIT_CLEAR_PS_V2_8197F(x) ((x) & (~BITS_PS_V2_8197F))
#define BIT_GET_PS_V2_8197F(x) \
(((x) >> BIT_SHIFT_PS_V2_8197F) & BIT_MASK_PS_V2_8197F)
#define BIT_SET_PS_V2_8197F(x, v) \
(BIT_CLEAR_PS_V2_8197F(x) | BIT_PS_V2_8197F(v))
#define BIT_PSEN_8197F BIT(6)
#define BIT_DOGENB_8197F BIT(5)
/* 2 REG_EFUSE_CTRL_8197F */
#define BIT_EF_FLAG_8197F BIT(31)
#define BIT_SHIFT_EF_PGPD_8197F 28
#define BIT_MASK_EF_PGPD_8197F 0x7
#define BIT_EF_PGPD_8197F(x) \
(((x) & BIT_MASK_EF_PGPD_8197F) << BIT_SHIFT_EF_PGPD_8197F)
#define BITS_EF_PGPD_8197F (BIT_MASK_EF_PGPD_8197F << BIT_SHIFT_EF_PGPD_8197F)
#define BIT_CLEAR_EF_PGPD_8197F(x) ((x) & (~BITS_EF_PGPD_8197F))
#define BIT_GET_EF_PGPD_8197F(x) \
(((x) >> BIT_SHIFT_EF_PGPD_8197F) & BIT_MASK_EF_PGPD_8197F)
#define BIT_SET_EF_PGPD_8197F(x, v) \
(BIT_CLEAR_EF_PGPD_8197F(x) | BIT_EF_PGPD_8197F(v))
#define BIT_SHIFT_EF_RDT_8197F 24
#define BIT_MASK_EF_RDT_8197F 0xf
#define BIT_EF_RDT_8197F(x) \
(((x) & BIT_MASK_EF_RDT_8197F) << BIT_SHIFT_EF_RDT_8197F)
#define BITS_EF_RDT_8197F (BIT_MASK_EF_RDT_8197F << BIT_SHIFT_EF_RDT_8197F)
#define BIT_CLEAR_EF_RDT_8197F(x) ((x) & (~BITS_EF_RDT_8197F))
#define BIT_GET_EF_RDT_8197F(x) \
(((x) >> BIT_SHIFT_EF_RDT_8197F) & BIT_MASK_EF_RDT_8197F)
#define BIT_SET_EF_RDT_8197F(x, v) \
(BIT_CLEAR_EF_RDT_8197F(x) | BIT_EF_RDT_8197F(v))
#define BIT_SHIFT_EF_PGTS_8197F 20
#define BIT_MASK_EF_PGTS_8197F 0xf
#define BIT_EF_PGTS_8197F(x) \
(((x) & BIT_MASK_EF_PGTS_8197F) << BIT_SHIFT_EF_PGTS_8197F)
#define BITS_EF_PGTS_8197F (BIT_MASK_EF_PGTS_8197F << BIT_SHIFT_EF_PGTS_8197F)
#define BIT_CLEAR_EF_PGTS_8197F(x) ((x) & (~BITS_EF_PGTS_8197F))
#define BIT_GET_EF_PGTS_8197F(x) \
(((x) >> BIT_SHIFT_EF_PGTS_8197F) & BIT_MASK_EF_PGTS_8197F)
#define BIT_SET_EF_PGTS_8197F(x, v) \
(BIT_CLEAR_EF_PGTS_8197F(x) | BIT_EF_PGTS_8197F(v))
#define BIT_EF_PDWN_8197F BIT(19)
#define BIT_EF_ALDEN_8197F BIT(18)
#define BIT_SHIFT_EF_ADDR_8197F 8
#define BIT_MASK_EF_ADDR_8197F 0x3ff
#define BIT_EF_ADDR_8197F(x) \
(((x) & BIT_MASK_EF_ADDR_8197F) << BIT_SHIFT_EF_ADDR_8197F)
#define BITS_EF_ADDR_8197F (BIT_MASK_EF_ADDR_8197F << BIT_SHIFT_EF_ADDR_8197F)
#define BIT_CLEAR_EF_ADDR_8197F(x) ((x) & (~BITS_EF_ADDR_8197F))
#define BIT_GET_EF_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_EF_ADDR_8197F) & BIT_MASK_EF_ADDR_8197F)
#define BIT_SET_EF_ADDR_8197F(x, v) \
(BIT_CLEAR_EF_ADDR_8197F(x) | BIT_EF_ADDR_8197F(v))
#define BIT_SHIFT_EF_DATA_8197F 0
#define BIT_MASK_EF_DATA_8197F 0xff
#define BIT_EF_DATA_8197F(x) \
(((x) & BIT_MASK_EF_DATA_8197F) << BIT_SHIFT_EF_DATA_8197F)
#define BITS_EF_DATA_8197F (BIT_MASK_EF_DATA_8197F << BIT_SHIFT_EF_DATA_8197F)
#define BIT_CLEAR_EF_DATA_8197F(x) ((x) & (~BITS_EF_DATA_8197F))
#define BIT_GET_EF_DATA_8197F(x) \
(((x) >> BIT_SHIFT_EF_DATA_8197F) & BIT_MASK_EF_DATA_8197F)
#define BIT_SET_EF_DATA_8197F(x, v) \
(BIT_CLEAR_EF_DATA_8197F(x) | BIT_EF_DATA_8197F(v))
/* 2 REG_LDO_EFUSE_CTRL_8197F */
#define BIT_LDOE25_EN_8197F BIT(31)
#define BIT_SHIFT_LDOE25_V12ADJ_L_8197F 27
#define BIT_MASK_LDOE25_V12ADJ_L_8197F 0xf
#define BIT_LDOE25_V12ADJ_L_8197F(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L_8197F) \
<< BIT_SHIFT_LDOE25_V12ADJ_L_8197F)
#define BITS_LDOE25_V12ADJ_L_8197F \
(BIT_MASK_LDOE25_V12ADJ_L_8197F << BIT_SHIFT_LDOE25_V12ADJ_L_8197F)
#define BIT_CLEAR_LDOE25_V12ADJ_L_8197F(x) ((x) & (~BITS_LDOE25_V12ADJ_L_8197F))
#define BIT_GET_LDOE25_V12ADJ_L_8197F(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L_8197F) & \
BIT_MASK_LDOE25_V12ADJ_L_8197F)
#define BIT_SET_LDOE25_V12ADJ_L_8197F(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L_8197F(x) | BIT_LDOE25_V12ADJ_L_8197F(v))
#define BIT_SHIFT_EF_SCAN_START_V1_8197F 16
#define BIT_MASK_EF_SCAN_START_V1_8197F 0x3ff
#define BIT_EF_SCAN_START_V1_8197F(x) \
(((x) & BIT_MASK_EF_SCAN_START_V1_8197F) \
<< BIT_SHIFT_EF_SCAN_START_V1_8197F)
#define BITS_EF_SCAN_START_V1_8197F \
(BIT_MASK_EF_SCAN_START_V1_8197F << BIT_SHIFT_EF_SCAN_START_V1_8197F)
#define BIT_CLEAR_EF_SCAN_START_V1_8197F(x) \
((x) & (~BITS_EF_SCAN_START_V1_8197F))
#define BIT_GET_EF_SCAN_START_V1_8197F(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START_V1_8197F) & \
BIT_MASK_EF_SCAN_START_V1_8197F)
#define BIT_SET_EF_SCAN_START_V1_8197F(x, v) \
(BIT_CLEAR_EF_SCAN_START_V1_8197F(x) | BIT_EF_SCAN_START_V1_8197F(v))
#define BIT_SHIFT_EF_SCAN_END_8197F 12
#define BIT_MASK_EF_SCAN_END_8197F 0xf
#define BIT_EF_SCAN_END_8197F(x) \
(((x) & BIT_MASK_EF_SCAN_END_8197F) << BIT_SHIFT_EF_SCAN_END_8197F)
#define BITS_EF_SCAN_END_8197F \
(BIT_MASK_EF_SCAN_END_8197F << BIT_SHIFT_EF_SCAN_END_8197F)
#define BIT_CLEAR_EF_SCAN_END_8197F(x) ((x) & (~BITS_EF_SCAN_END_8197F))
#define BIT_GET_EF_SCAN_END_8197F(x) \
(((x) >> BIT_SHIFT_EF_SCAN_END_8197F) & BIT_MASK_EF_SCAN_END_8197F)
#define BIT_SET_EF_SCAN_END_8197F(x, v) \
(BIT_CLEAR_EF_SCAN_END_8197F(x) | BIT_EF_SCAN_END_8197F(v))
#define BIT_SHIFT_EF_CELL_SEL_8197F 8
#define BIT_MASK_EF_CELL_SEL_8197F 0x3
#define BIT_EF_CELL_SEL_8197F(x) \
(((x) & BIT_MASK_EF_CELL_SEL_8197F) << BIT_SHIFT_EF_CELL_SEL_8197F)
#define BITS_EF_CELL_SEL_8197F \
(BIT_MASK_EF_CELL_SEL_8197F << BIT_SHIFT_EF_CELL_SEL_8197F)
#define BIT_CLEAR_EF_CELL_SEL_8197F(x) ((x) & (~BITS_EF_CELL_SEL_8197F))
#define BIT_GET_EF_CELL_SEL_8197F(x) \
(((x) >> BIT_SHIFT_EF_CELL_SEL_8197F) & BIT_MASK_EF_CELL_SEL_8197F)
#define BIT_SET_EF_CELL_SEL_8197F(x, v) \
(BIT_CLEAR_EF_CELL_SEL_8197F(x) | BIT_EF_CELL_SEL_8197F(v))
#define BIT_EF_TRPT_8197F BIT(7)
#define BIT_SHIFT_EF_TTHD_8197F 0
#define BIT_MASK_EF_TTHD_8197F 0x7f
#define BIT_EF_TTHD_8197F(x) \
(((x) & BIT_MASK_EF_TTHD_8197F) << BIT_SHIFT_EF_TTHD_8197F)
#define BITS_EF_TTHD_8197F (BIT_MASK_EF_TTHD_8197F << BIT_SHIFT_EF_TTHD_8197F)
#define BIT_CLEAR_EF_TTHD_8197F(x) ((x) & (~BITS_EF_TTHD_8197F))
#define BIT_GET_EF_TTHD_8197F(x) \
(((x) >> BIT_SHIFT_EF_TTHD_8197F) & BIT_MASK_EF_TTHD_8197F)
#define BIT_SET_EF_TTHD_8197F(x, v) \
(BIT_CLEAR_EF_TTHD_8197F(x) | BIT_EF_TTHD_8197F(v))
/* 2 REG_PWR_OPTION_CTRL_8197F */
#define BIT_SHIFT_DBG_SEL_V1_8197F 16
#define BIT_MASK_DBG_SEL_V1_8197F 0xff
#define BIT_DBG_SEL_V1_8197F(x) \
(((x) & BIT_MASK_DBG_SEL_V1_8197F) << BIT_SHIFT_DBG_SEL_V1_8197F)
#define BITS_DBG_SEL_V1_8197F \
(BIT_MASK_DBG_SEL_V1_8197F << BIT_SHIFT_DBG_SEL_V1_8197F)
#define BIT_CLEAR_DBG_SEL_V1_8197F(x) ((x) & (~BITS_DBG_SEL_V1_8197F))
#define BIT_GET_DBG_SEL_V1_8197F(x) \
(((x) >> BIT_SHIFT_DBG_SEL_V1_8197F) & BIT_MASK_DBG_SEL_V1_8197F)
#define BIT_SET_DBG_SEL_V1_8197F(x, v) \
(BIT_CLEAR_DBG_SEL_V1_8197F(x) | BIT_DBG_SEL_V1_8197F(v))
#define BIT_SHIFT_DBG_SEL_BYTE_8197F 14
#define BIT_MASK_DBG_SEL_BYTE_8197F 0x3
#define BIT_DBG_SEL_BYTE_8197F(x) \
(((x) & BIT_MASK_DBG_SEL_BYTE_8197F) << BIT_SHIFT_DBG_SEL_BYTE_8197F)
#define BITS_DBG_SEL_BYTE_8197F \
(BIT_MASK_DBG_SEL_BYTE_8197F << BIT_SHIFT_DBG_SEL_BYTE_8197F)
#define BIT_CLEAR_DBG_SEL_BYTE_8197F(x) ((x) & (~BITS_DBG_SEL_BYTE_8197F))
#define BIT_GET_DBG_SEL_BYTE_8197F(x) \
(((x) >> BIT_SHIFT_DBG_SEL_BYTE_8197F) & BIT_MASK_DBG_SEL_BYTE_8197F)
#define BIT_SET_DBG_SEL_BYTE_8197F(x, v) \
(BIT_CLEAR_DBG_SEL_BYTE_8197F(x) | BIT_DBG_SEL_BYTE_8197F(v))
#define BIT_SHIFT_STD_L1_V1_8197F 12
#define BIT_MASK_STD_L1_V1_8197F 0x3
#define BIT_STD_L1_V1_8197F(x) \
(((x) & BIT_MASK_STD_L1_V1_8197F) << BIT_SHIFT_STD_L1_V1_8197F)
#define BITS_STD_L1_V1_8197F \
(BIT_MASK_STD_L1_V1_8197F << BIT_SHIFT_STD_L1_V1_8197F)
#define BIT_CLEAR_STD_L1_V1_8197F(x) ((x) & (~BITS_STD_L1_V1_8197F))
#define BIT_GET_STD_L1_V1_8197F(x) \
(((x) >> BIT_SHIFT_STD_L1_V1_8197F) & BIT_MASK_STD_L1_V1_8197F)
#define BIT_SET_STD_L1_V1_8197F(x, v) \
(BIT_CLEAR_STD_L1_V1_8197F(x) | BIT_STD_L1_V1_8197F(v))
#define BIT_SYSON_DBG_PAD_E2_8197F BIT(11)
#define BIT_SYSON_LED_PAD_E2_8197F BIT(10)
#define BIT_SYSON_GPEE_PAD_E2_8197F BIT(9)
#define BIT_SYSON_PCI_PAD_E2_8197F BIT(8)
#define BIT_AUTO_SW_LDO_VOL_EN_8197F BIT(7)
#define BIT_SHIFT_SYSON_SPS0WWV_WT_8197F 4
#define BIT_MASK_SYSON_SPS0WWV_WT_8197F 0x3
#define BIT_SYSON_SPS0WWV_WT_8197F(x) \
(((x) & BIT_MASK_SYSON_SPS0WWV_WT_8197F) \
<< BIT_SHIFT_SYSON_SPS0WWV_WT_8197F)
#define BITS_SYSON_SPS0WWV_WT_8197F \
(BIT_MASK_SYSON_SPS0WWV_WT_8197F << BIT_SHIFT_SYSON_SPS0WWV_WT_8197F)
#define BIT_CLEAR_SYSON_SPS0WWV_WT_8197F(x) \
((x) & (~BITS_SYSON_SPS0WWV_WT_8197F))
#define BIT_GET_SYSON_SPS0WWV_WT_8197F(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0WWV_WT_8197F) & \
BIT_MASK_SYSON_SPS0WWV_WT_8197F)
#define BIT_SET_SYSON_SPS0WWV_WT_8197F(x, v) \
(BIT_CLEAR_SYSON_SPS0WWV_WT_8197F(x) | BIT_SYSON_SPS0WWV_WT_8197F(v))
#define BIT_SHIFT_SYSON_SPS0LDO_WT_8197F 2
#define BIT_MASK_SYSON_SPS0LDO_WT_8197F 0x3
#define BIT_SYSON_SPS0LDO_WT_8197F(x) \
(((x) & BIT_MASK_SYSON_SPS0LDO_WT_8197F) \
<< BIT_SHIFT_SYSON_SPS0LDO_WT_8197F)
#define BITS_SYSON_SPS0LDO_WT_8197F \
(BIT_MASK_SYSON_SPS0LDO_WT_8197F << BIT_SHIFT_SYSON_SPS0LDO_WT_8197F)
#define BIT_CLEAR_SYSON_SPS0LDO_WT_8197F(x) \
((x) & (~BITS_SYSON_SPS0LDO_WT_8197F))
#define BIT_GET_SYSON_SPS0LDO_WT_8197F(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0LDO_WT_8197F) & \
BIT_MASK_SYSON_SPS0LDO_WT_8197F)
#define BIT_SET_SYSON_SPS0LDO_WT_8197F(x, v) \
(BIT_CLEAR_SYSON_SPS0LDO_WT_8197F(x) | BIT_SYSON_SPS0LDO_WT_8197F(v))
#define BIT_SHIFT_SYSON_RCLK_SCALE_8197F 0
#define BIT_MASK_SYSON_RCLK_SCALE_8197F 0x3
#define BIT_SYSON_RCLK_SCALE_8197F(x) \
(((x) & BIT_MASK_SYSON_RCLK_SCALE_8197F) \
<< BIT_SHIFT_SYSON_RCLK_SCALE_8197F)
#define BITS_SYSON_RCLK_SCALE_8197F \
(BIT_MASK_SYSON_RCLK_SCALE_8197F << BIT_SHIFT_SYSON_RCLK_SCALE_8197F)
#define BIT_CLEAR_SYSON_RCLK_SCALE_8197F(x) \
((x) & (~BITS_SYSON_RCLK_SCALE_8197F))
#define BIT_GET_SYSON_RCLK_SCALE_8197F(x) \
(((x) >> BIT_SHIFT_SYSON_RCLK_SCALE_8197F) & \
BIT_MASK_SYSON_RCLK_SCALE_8197F)
#define BIT_SET_SYSON_RCLK_SCALE_8197F(x, v) \
(BIT_CLEAR_SYSON_RCLK_SCALE_8197F(x) | BIT_SYSON_RCLK_SCALE_8197F(v))
/* 2 REG_CAL_TIMER_8197F */
#define BIT_SHIFT_MATCH_CNT_8197F 8
#define BIT_MASK_MATCH_CNT_8197F 0xff
#define BIT_MATCH_CNT_8197F(x) \
(((x) & BIT_MASK_MATCH_CNT_8197F) << BIT_SHIFT_MATCH_CNT_8197F)
#define BITS_MATCH_CNT_8197F \
(BIT_MASK_MATCH_CNT_8197F << BIT_SHIFT_MATCH_CNT_8197F)
#define BIT_CLEAR_MATCH_CNT_8197F(x) ((x) & (~BITS_MATCH_CNT_8197F))
#define BIT_GET_MATCH_CNT_8197F(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8197F) & BIT_MASK_MATCH_CNT_8197F)
#define BIT_SET_MATCH_CNT_8197F(x, v) \
(BIT_CLEAR_MATCH_CNT_8197F(x) | BIT_MATCH_CNT_8197F(v))
#define BIT_SHIFT_CAL_SCAL_8197F 0
#define BIT_MASK_CAL_SCAL_8197F 0xff
#define BIT_CAL_SCAL_8197F(x) \
(((x) & BIT_MASK_CAL_SCAL_8197F) << BIT_SHIFT_CAL_SCAL_8197F)
#define BITS_CAL_SCAL_8197F \
(BIT_MASK_CAL_SCAL_8197F << BIT_SHIFT_CAL_SCAL_8197F)
#define BIT_CLEAR_CAL_SCAL_8197F(x) ((x) & (~BITS_CAL_SCAL_8197F))
#define BIT_GET_CAL_SCAL_8197F(x) \
(((x) >> BIT_SHIFT_CAL_SCAL_8197F) & BIT_MASK_CAL_SCAL_8197F)
#define BIT_SET_CAL_SCAL_8197F(x, v) \
(BIT_CLEAR_CAL_SCAL_8197F(x) | BIT_CAL_SCAL_8197F(v))
/* 2 REG_ACLK_MON_8197F */
#define BIT_SHIFT_RCLK_MON_8197F 5
#define BIT_MASK_RCLK_MON_8197F 0x7ff
#define BIT_RCLK_MON_8197F(x) \
(((x) & BIT_MASK_RCLK_MON_8197F) << BIT_SHIFT_RCLK_MON_8197F)
#define BITS_RCLK_MON_8197F \
(BIT_MASK_RCLK_MON_8197F << BIT_SHIFT_RCLK_MON_8197F)
#define BIT_CLEAR_RCLK_MON_8197F(x) ((x) & (~BITS_RCLK_MON_8197F))
#define BIT_GET_RCLK_MON_8197F(x) \
(((x) >> BIT_SHIFT_RCLK_MON_8197F) & BIT_MASK_RCLK_MON_8197F)
#define BIT_SET_RCLK_MON_8197F(x, v) \
(BIT_CLEAR_RCLK_MON_8197F(x) | BIT_RCLK_MON_8197F(v))
#define BIT_CAL_EN_8197F BIT(4)
#define BIT_SHIFT_DPSTU_8197F 2
#define BIT_MASK_DPSTU_8197F 0x3
#define BIT_DPSTU_8197F(x) \
(((x) & BIT_MASK_DPSTU_8197F) << BIT_SHIFT_DPSTU_8197F)
#define BITS_DPSTU_8197F (BIT_MASK_DPSTU_8197F << BIT_SHIFT_DPSTU_8197F)
#define BIT_CLEAR_DPSTU_8197F(x) ((x) & (~BITS_DPSTU_8197F))
#define BIT_GET_DPSTU_8197F(x) \
(((x) >> BIT_SHIFT_DPSTU_8197F) & BIT_MASK_DPSTU_8197F)
#define BIT_SET_DPSTU_8197F(x, v) \
(BIT_CLEAR_DPSTU_8197F(x) | BIT_DPSTU_8197F(v))
#define BIT_SUS_16X_8197F BIT(1)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_GPIO_MUXCFG_8197F */
#define BIT_SIC_LOWEST_PRIORITY_8197F BIT(28)
#define BIT_SHIFT_PIN_USECASE_8197F 24
#define BIT_MASK_PIN_USECASE_8197F 0xf
#define BIT_PIN_USECASE_8197F(x) \
(((x) & BIT_MASK_PIN_USECASE_8197F) << BIT_SHIFT_PIN_USECASE_8197F)
#define BITS_PIN_USECASE_8197F \
(BIT_MASK_PIN_USECASE_8197F << BIT_SHIFT_PIN_USECASE_8197F)
#define BIT_CLEAR_PIN_USECASE_8197F(x) ((x) & (~BITS_PIN_USECASE_8197F))
#define BIT_GET_PIN_USECASE_8197F(x) \
(((x) >> BIT_SHIFT_PIN_USECASE_8197F) & BIT_MASK_PIN_USECASE_8197F)
#define BIT_SET_PIN_USECASE_8197F(x, v) \
(BIT_CLEAR_PIN_USECASE_8197F(x) | BIT_PIN_USECASE_8197F(v))
#define BIT_FSPI_EN_8197F BIT(19)
#define BIT_WL_RTS_EXT_32K_SEL_8197F BIT(18)
#define BIT_WLGP_SPI_EN_8197F BIT(16)
#define BIT_SIC_LBK_8197F BIT(15)
#define BIT_ENHTP_8197F BIT(14)
#define BIT_WLPHY_DBG_EN_8197F BIT(13)
#define BIT_ENSIC_8197F BIT(12)
#define BIT_SIC_SWRST_8197F BIT(11)
#define BIT_PO_WIFI_PTA_PINS_8197F BIT(10)
#define BIT_BTCOEX_MBOX_EN_8197F BIT(9)
#define BIT_ENUART_8197F BIT(8)
#define BIT_SHIFT_BTMODE_8197F 6
#define BIT_MASK_BTMODE_8197F 0x3
#define BIT_BTMODE_8197F(x) \
(((x) & BIT_MASK_BTMODE_8197F) << BIT_SHIFT_BTMODE_8197F)
#define BITS_BTMODE_8197F (BIT_MASK_BTMODE_8197F << BIT_SHIFT_BTMODE_8197F)
#define BIT_CLEAR_BTMODE_8197F(x) ((x) & (~BITS_BTMODE_8197F))
#define BIT_GET_BTMODE_8197F(x) \
(((x) >> BIT_SHIFT_BTMODE_8197F) & BIT_MASK_BTMODE_8197F)
#define BIT_SET_BTMODE_8197F(x, v) \
(BIT_CLEAR_BTMODE_8197F(x) | BIT_BTMODE_8197F(v))
#define BIT_ENBT_8197F BIT(5)
#define BIT_EROM_EN_8197F BIT(4)
#define BIT_WLRFE_6_7_EN_8197F BIT(3)
#define BIT_WLRFE_4_5_EN_8197F BIT(2)
#define BIT_SHIFT_GPIOSEL_8197F 0
#define BIT_MASK_GPIOSEL_8197F 0x3
#define BIT_GPIOSEL_8197F(x) \
(((x) & BIT_MASK_GPIOSEL_8197F) << BIT_SHIFT_GPIOSEL_8197F)
#define BITS_GPIOSEL_8197F (BIT_MASK_GPIOSEL_8197F << BIT_SHIFT_GPIOSEL_8197F)
#define BIT_CLEAR_GPIOSEL_8197F(x) ((x) & (~BITS_GPIOSEL_8197F))
#define BIT_GET_GPIOSEL_8197F(x) \
(((x) >> BIT_SHIFT_GPIOSEL_8197F) & BIT_MASK_GPIOSEL_8197F)
#define BIT_SET_GPIOSEL_8197F(x, v) \
(BIT_CLEAR_GPIOSEL_8197F(x) | BIT_GPIOSEL_8197F(v))
/* 2 REG_GPIO_PIN_CTRL_8197F */
#define BIT_SHIFT_GPIO_MOD_7_TO_0_8197F 24
#define BIT_MASK_GPIO_MOD_7_TO_0_8197F 0xff
#define BIT_GPIO_MOD_7_TO_0_8197F(x) \
(((x) & BIT_MASK_GPIO_MOD_7_TO_0_8197F) \
<< BIT_SHIFT_GPIO_MOD_7_TO_0_8197F)
#define BITS_GPIO_MOD_7_TO_0_8197F \
(BIT_MASK_GPIO_MOD_7_TO_0_8197F << BIT_SHIFT_GPIO_MOD_7_TO_0_8197F)
#define BIT_CLEAR_GPIO_MOD_7_TO_0_8197F(x) ((x) & (~BITS_GPIO_MOD_7_TO_0_8197F))
#define BIT_GET_GPIO_MOD_7_TO_0_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_7_TO_0_8197F) & \
BIT_MASK_GPIO_MOD_7_TO_0_8197F)
#define BIT_SET_GPIO_MOD_7_TO_0_8197F(x, v) \
(BIT_CLEAR_GPIO_MOD_7_TO_0_8197F(x) | BIT_GPIO_MOD_7_TO_0_8197F(v))
#define BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8197F 16
#define BIT_MASK_GPIO_IO_SEL_7_TO_0_8197F 0xff
#define BIT_GPIO_IO_SEL_7_TO_0_8197F(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_7_TO_0_8197F) \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8197F)
#define BITS_GPIO_IO_SEL_7_TO_0_8197F \
(BIT_MASK_GPIO_IO_SEL_7_TO_0_8197F \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8197F)
#define BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8197F(x) \
((x) & (~BITS_GPIO_IO_SEL_7_TO_0_8197F))
#define BIT_GET_GPIO_IO_SEL_7_TO_0_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8197F) & \
BIT_MASK_GPIO_IO_SEL_7_TO_0_8197F)
#define BIT_SET_GPIO_IO_SEL_7_TO_0_8197F(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8197F(x) | \
BIT_GPIO_IO_SEL_7_TO_0_8197F(v))
#define BIT_SHIFT_GPIO_OUT_7_TO_0_8197F 8
#define BIT_MASK_GPIO_OUT_7_TO_0_8197F 0xff
#define BIT_GPIO_OUT_7_TO_0_8197F(x) \
(((x) & BIT_MASK_GPIO_OUT_7_TO_0_8197F) \
<< BIT_SHIFT_GPIO_OUT_7_TO_0_8197F)
#define BITS_GPIO_OUT_7_TO_0_8197F \
(BIT_MASK_GPIO_OUT_7_TO_0_8197F << BIT_SHIFT_GPIO_OUT_7_TO_0_8197F)
#define BIT_CLEAR_GPIO_OUT_7_TO_0_8197F(x) ((x) & (~BITS_GPIO_OUT_7_TO_0_8197F))
#define BIT_GET_GPIO_OUT_7_TO_0_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_7_TO_0_8197F) & \
BIT_MASK_GPIO_OUT_7_TO_0_8197F)
#define BIT_SET_GPIO_OUT_7_TO_0_8197F(x, v) \
(BIT_CLEAR_GPIO_OUT_7_TO_0_8197F(x) | BIT_GPIO_OUT_7_TO_0_8197F(v))
#define BIT_SHIFT_GPIO_IN_7_TO_0_8197F 0
#define BIT_MASK_GPIO_IN_7_TO_0_8197F 0xff
#define BIT_GPIO_IN_7_TO_0_8197F(x) \
(((x) & BIT_MASK_GPIO_IN_7_TO_0_8197F) \
<< BIT_SHIFT_GPIO_IN_7_TO_0_8197F)
#define BITS_GPIO_IN_7_TO_0_8197F \
(BIT_MASK_GPIO_IN_7_TO_0_8197F << BIT_SHIFT_GPIO_IN_7_TO_0_8197F)
#define BIT_CLEAR_GPIO_IN_7_TO_0_8197F(x) ((x) & (~BITS_GPIO_IN_7_TO_0_8197F))
#define BIT_GET_GPIO_IN_7_TO_0_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_IN_7_TO_0_8197F) & \
BIT_MASK_GPIO_IN_7_TO_0_8197F)
#define BIT_SET_GPIO_IN_7_TO_0_8197F(x, v) \
(BIT_CLEAR_GPIO_IN_7_TO_0_8197F(x) | BIT_GPIO_IN_7_TO_0_8197F(v))
/* 2 REG_GPIO_INTM_8197F */
#define BIT_SHIFT_MUXDBG_SEL_8197F 30
#define BIT_MASK_MUXDBG_SEL_8197F 0x3
#define BIT_MUXDBG_SEL_8197F(x) \
(((x) & BIT_MASK_MUXDBG_SEL_8197F) << BIT_SHIFT_MUXDBG_SEL_8197F)
#define BITS_MUXDBG_SEL_8197F \
(BIT_MASK_MUXDBG_SEL_8197F << BIT_SHIFT_MUXDBG_SEL_8197F)
#define BIT_CLEAR_MUXDBG_SEL_8197F(x) ((x) & (~BITS_MUXDBG_SEL_8197F))
#define BIT_GET_MUXDBG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL_8197F) & BIT_MASK_MUXDBG_SEL_8197F)
#define BIT_SET_MUXDBG_SEL_8197F(x, v) \
(BIT_CLEAR_MUXDBG_SEL_8197F(x) | BIT_MUXDBG_SEL_8197F(v))
#define BIT_EXTWOL_SEL_8197F BIT(17)
#define BIT_EXTWOL_EN_8197F BIT(16)
#define BIT_GPIOF_INT_MD_8197F BIT(15)
#define BIT_GPIOE_INT_MD_8197F BIT(14)
#define BIT_GPIOD_INT_MD_8197F BIT(13)
#define BIT_GPIOC_INT_MD_8197F BIT(12)
#define BIT_GPIOB_INT_MD_8197F BIT(11)
#define BIT_GPIOA_INT_MD_8197F BIT(10)
#define BIT_GPIO9_INT_MD_8197F BIT(9)
#define BIT_GPIO8_INT_MD_8197F BIT(8)
#define BIT_GPIO7_INT_MD_8197F BIT(7)
#define BIT_GPIO6_INT_MD_8197F BIT(6)
#define BIT_GPIO5_INT_MD_8197F BIT(5)
#define BIT_GPIO4_INT_MD_8197F BIT(4)
#define BIT_GPIO3_INT_MD_8197F BIT(3)
#define BIT_GPIO2_INT_MD_8197F BIT(2)
#define BIT_GPIO1_INT_MD_8197F BIT(1)
#define BIT_GPIO0_INT_MD_8197F BIT(0)
/* 2 REG_LED_CFG_8197F */
#define BIT_LNAON_SEL_EN_8197F BIT(26)
#define BIT_PAPE_SEL_EN_8197F BIT(25)
#define BIT_DPDT_WLBT_SEL_8197F BIT(24)
#define BIT_DPDT_SEL_EN_8197F BIT(23)
#define BIT_LED2DIS_V1_8197F BIT(22)
#define BIT_LED2EN_8197F BIT(21)
#define BIT_LED2PL_8197F BIT(20)
#define BIT_LED2SV_8197F BIT(19)
#define BIT_SHIFT_LED2CM_8197F 16
#define BIT_MASK_LED2CM_8197F 0x7
#define BIT_LED2CM_8197F(x) \
(((x) & BIT_MASK_LED2CM_8197F) << BIT_SHIFT_LED2CM_8197F)
#define BITS_LED2CM_8197F (BIT_MASK_LED2CM_8197F << BIT_SHIFT_LED2CM_8197F)
#define BIT_CLEAR_LED2CM_8197F(x) ((x) & (~BITS_LED2CM_8197F))
#define BIT_GET_LED2CM_8197F(x) \
(((x) >> BIT_SHIFT_LED2CM_8197F) & BIT_MASK_LED2CM_8197F)
#define BIT_SET_LED2CM_8197F(x, v) \
(BIT_CLEAR_LED2CM_8197F(x) | BIT_LED2CM_8197F(v))
#define BIT_LED1DIS_8197F BIT(15)
#define BIT_LED1PL_8197F BIT(12)
#define BIT_LED1SV_8197F BIT(11)
#define BIT_SHIFT_LED1CM_8197F 8
#define BIT_MASK_LED1CM_8197F 0x7
#define BIT_LED1CM_8197F(x) \
(((x) & BIT_MASK_LED1CM_8197F) << BIT_SHIFT_LED1CM_8197F)
#define BITS_LED1CM_8197F (BIT_MASK_LED1CM_8197F << BIT_SHIFT_LED1CM_8197F)
#define BIT_CLEAR_LED1CM_8197F(x) ((x) & (~BITS_LED1CM_8197F))
#define BIT_GET_LED1CM_8197F(x) \
(((x) >> BIT_SHIFT_LED1CM_8197F) & BIT_MASK_LED1CM_8197F)
#define BIT_SET_LED1CM_8197F(x, v) \
(BIT_CLEAR_LED1CM_8197F(x) | BIT_LED1CM_8197F(v))
#define BIT_LED0DIS_8197F BIT(7)
#define BIT_SHIFT_AFE_LDO_SWR_CHECK_8197F 5
#define BIT_MASK_AFE_LDO_SWR_CHECK_8197F 0x3
#define BIT_AFE_LDO_SWR_CHECK_8197F(x) \
(((x) & BIT_MASK_AFE_LDO_SWR_CHECK_8197F) \
<< BIT_SHIFT_AFE_LDO_SWR_CHECK_8197F)
#define BITS_AFE_LDO_SWR_CHECK_8197F \
(BIT_MASK_AFE_LDO_SWR_CHECK_8197F << BIT_SHIFT_AFE_LDO_SWR_CHECK_8197F)
#define BIT_CLEAR_AFE_LDO_SWR_CHECK_8197F(x) \
((x) & (~BITS_AFE_LDO_SWR_CHECK_8197F))
#define BIT_GET_AFE_LDO_SWR_CHECK_8197F(x) \
(((x) >> BIT_SHIFT_AFE_LDO_SWR_CHECK_8197F) & \
BIT_MASK_AFE_LDO_SWR_CHECK_8197F)
#define BIT_SET_AFE_LDO_SWR_CHECK_8197F(x, v) \
(BIT_CLEAR_AFE_LDO_SWR_CHECK_8197F(x) | BIT_AFE_LDO_SWR_CHECK_8197F(v))
#define BIT_LED0PL_8197F BIT(4)
#define BIT_LED0SV_8197F BIT(3)
#define BIT_SHIFT_LED0CM_8197F 0
#define BIT_MASK_LED0CM_8197F 0x7
#define BIT_LED0CM_8197F(x) \
(((x) & BIT_MASK_LED0CM_8197F) << BIT_SHIFT_LED0CM_8197F)
#define BITS_LED0CM_8197F (BIT_MASK_LED0CM_8197F << BIT_SHIFT_LED0CM_8197F)
#define BIT_CLEAR_LED0CM_8197F(x) ((x) & (~BITS_LED0CM_8197F))
#define BIT_GET_LED0CM_8197F(x) \
(((x) >> BIT_SHIFT_LED0CM_8197F) & BIT_MASK_LED0CM_8197F)
#define BIT_SET_LED0CM_8197F(x, v) \
(BIT_CLEAR_LED0CM_8197F(x) | BIT_LED0CM_8197F(v))
/* 2 REG_FSIMR_8197F */
#define BIT_FS_PDNINT_EN_8197F BIT(31)
#define BIT_FS_SPS_OCP_INT_EN_8197F BIT(29)
#define BIT_FS_PWMERR_INT_EN_8197F BIT(28)
#define BIT_FS_GPIOF_INT_EN_8197F BIT(27)
#define BIT_FS_GPIOE_INT_EN_8197F BIT(26)
#define BIT_FS_GPIOD_INT_EN_8197F BIT(25)
#define BIT_FS_GPIOC_INT_EN_8197F BIT(24)
#define BIT_FS_GPIOB_INT_EN_8197F BIT(23)
#define BIT_FS_GPIOA_INT_EN_8197F BIT(22)
#define BIT_FS_GPIO9_INT_EN_8197F BIT(21)
#define BIT_FS_GPIO8_INT_EN_8197F BIT(20)
#define BIT_FS_GPIO7_INT_EN_8197F BIT(19)
#define BIT_FS_GPIO6_INT_EN_8197F BIT(18)
#define BIT_FS_GPIO5_INT_EN_8197F BIT(17)
#define BIT_FS_GPIO4_INT_EN_8197F BIT(16)
#define BIT_FS_GPIO3_INT_EN_8197F BIT(15)
#define BIT_FS_GPIO2_INT_EN_8197F BIT(14)
#define BIT_FS_GPIO1_INT_EN_8197F BIT(13)
#define BIT_FS_GPIO0_INT_EN_8197F BIT(12)
#define BIT_FS_HCI_SUS_EN_8197F BIT(11)
#define BIT_FS_HCI_RES_EN_8197F BIT(10)
#define BIT_FS_HCI_RESET_EN_8197F BIT(9)
#define BIT_AXI_EXCEPT_FINT_EN_8197F BIT(8)
#define BIT_FS_BTON_STS_UPDATE_MSK_EN_8197F BIT(7)
#define BIT_ACT2RECOVERY_INT_EN_V1_8197F BIT(6)
#define BIT_FS_TRPC_TO_INT_EN_8197F BIT(5)
#define BIT_FS_RPC_O_T_INT_EN_8197F BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_MAK_8197F BIT(3)
#define BIT_FS_32K_ENTER_SETTING_MAK_8197F BIT(2)
#define BIT_FS_USB_LPMRSM_MSK_8197F BIT(1)
#define BIT_FS_USB_LPMINT_MSK_8197F BIT(0)
/* 2 REG_FSISR_8197F */
#define BIT_FS_PDNINT_8197F BIT(31)
#define BIT_FS_SPS_OCP_INT_8197F BIT(29)
#define BIT_FS_PWMERR_INT_8197F BIT(28)
#define BIT_FS_GPIOF_INT_8197F BIT(27)
#define BIT_FS_GPIOE_INT_8197F BIT(26)
#define BIT_FS_GPIOD_INT_8197F BIT(25)
#define BIT_FS_GPIOC_INT_8197F BIT(24)
#define BIT_FS_GPIOB_INT_8197F BIT(23)
#define BIT_FS_GPIOA_INT_8197F BIT(22)
#define BIT_FS_GPIO9_INT_8197F BIT(21)
#define BIT_FS_GPIO8_INT_8197F BIT(20)
#define BIT_FS_GPIO7_INT_8197F BIT(19)
#define BIT_FS_GPIO6_INT_8197F BIT(18)
#define BIT_FS_GPIO5_INT_8197F BIT(17)
#define BIT_FS_GPIO4_INT_8197F BIT(16)
#define BIT_FS_GPIO3_INT_8197F BIT(15)
#define BIT_FS_GPIO2_INT_8197F BIT(14)
#define BIT_FS_GPIO1_INT_8197F BIT(13)
#define BIT_FS_GPIO0_INT_8197F BIT(12)
#define BIT_FS_HCI_SUS_INT_8197F BIT(11)
#define BIT_FS_HCI_RES_INT_8197F BIT(10)
#define BIT_FS_HCI_RESET_INT_8197F BIT(9)
#define BIT_AXI_EXCEPT_FINT_8197F BIT(8)
#define BIT_FS_BTON_STS_UPDATE_INT_8197F BIT(7)
#define BIT_ACT2RECOVERY_INT_V1_8197F BIT(6)
#define BIT_FS_TRPC_TO_INT_INT_8197F BIT(5)
#define BIT_FS_RPC_O_T_INT_INT_8197F BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_INT_8197F BIT(3)
#define BIT_FS_32K_ENTER_SETTING_INT_8197F BIT(2)
#define BIT_FS_USB_LPMRSM_INT_8197F BIT(1)
#define BIT_FS_USB_LPMINT_INT_8197F BIT(0)
/* 2 REG_HSIMR_8197F */
#define BIT_GPIOF_INT_EN_8197F BIT(31)
#define BIT_GPIOE_INT_EN_8197F BIT(30)
#define BIT_GPIOD_INT_EN_8197F BIT(29)
#define BIT_GPIOC_INT_EN_8197F BIT(28)
#define BIT_GPIOB_INT_EN_8197F BIT(27)
#define BIT_GPIOA_INT_EN_8197F BIT(26)
#define BIT_GPIO9_INT_EN_8197F BIT(25)
#define BIT_GPIO8_INT_EN_8197F BIT(24)
#define BIT_GPIO7_INT_EN_8197F BIT(23)
#define BIT_GPIO6_INT_EN_8197F BIT(22)
#define BIT_GPIO5_INT_EN_8197F BIT(21)
#define BIT_GPIO4_INT_EN_8197F BIT(20)
#define BIT_GPIO3_INT_EN_8197F BIT(19)
#define BIT_GPIO2_INT_EN_8197F BIT(18)
#define BIT_GPIO1_INT_EN_8197F BIT(17)
#define BIT_GPIO0_INT_EN_8197F BIT(16)
#define BIT_AXI_EXCEPT_HINT_EN_8197F BIT(9)
#define BIT_PDNINT_EN_V2_8197F BIT(8)
#define BIT_PDNINT_EN_V1_8197F BIT(7)
#define BIT_RON_INT_EN_V1_8197F BIT(6)
#define BIT_SPS_OCP_INT_EN_V1_8197F BIT(5)
#define BIT_GPIO15_0_INT_EN_V1_8197F BIT(0)
/* 2 REG_HSISR_8197F */
#define BIT_GPIOF_INT_8197F BIT(31)
#define BIT_GPIOE_INT_8197F BIT(30)
#define BIT_GPIOD_INT_8197F BIT(29)
#define BIT_GPIOC_INT_8197F BIT(28)
#define BIT_GPIOB_INT_8197F BIT(27)
#define BIT_GPIOA_INT_8197F BIT(26)
#define BIT_GPIO9_INT_8197F BIT(25)
#define BIT_GPIO8_INT_8197F BIT(24)
#define BIT_GPIO7_INT_8197F BIT(23)
#define BIT_GPIO6_INT_8197F BIT(22)
#define BIT_GPIO5_INT_8197F BIT(21)
#define BIT_GPIO4_INT_8197F BIT(20)
#define BIT_GPIO3_INT_8197F BIT(19)
#define BIT_GPIO2_INT_8197F BIT(18)
#define BIT_GPIO1_INT_8197F BIT(17)
#define BIT_GPIO0_INT_8197F BIT(16)
#define BIT_AXI_EXCEPT_HINT_8197F BIT(8)
#define BIT_PDNINT_V1_8197F BIT(7)
#define BIT_RON_INT_V1_8197F BIT(6)
#define BIT_SPS_OCP_INT_V1_8197F BIT(5)
#define BIT_GPIO15_0_INT_V1_8197F BIT(0)
/* 2 REG_GPIO_EXT_CTRL_8197F */
#define BIT_SHIFT_GPIO_MOD_15_TO_8_8197F 24
#define BIT_MASK_GPIO_MOD_15_TO_8_8197F 0xff
#define BIT_GPIO_MOD_15_TO_8_8197F(x) \
(((x) & BIT_MASK_GPIO_MOD_15_TO_8_8197F) \
<< BIT_SHIFT_GPIO_MOD_15_TO_8_8197F)
#define BITS_GPIO_MOD_15_TO_8_8197F \
(BIT_MASK_GPIO_MOD_15_TO_8_8197F << BIT_SHIFT_GPIO_MOD_15_TO_8_8197F)
#define BIT_CLEAR_GPIO_MOD_15_TO_8_8197F(x) \
((x) & (~BITS_GPIO_MOD_15_TO_8_8197F))
#define BIT_GET_GPIO_MOD_15_TO_8_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_15_TO_8_8197F) & \
BIT_MASK_GPIO_MOD_15_TO_8_8197F)
#define BIT_SET_GPIO_MOD_15_TO_8_8197F(x, v) \
(BIT_CLEAR_GPIO_MOD_15_TO_8_8197F(x) | BIT_GPIO_MOD_15_TO_8_8197F(v))
#define BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8197F 16
#define BIT_MASK_GPIO_IO_SEL_15_TO_8_8197F 0xff
#define BIT_GPIO_IO_SEL_15_TO_8_8197F(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_15_TO_8_8197F) \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8197F)
#define BITS_GPIO_IO_SEL_15_TO_8_8197F \
(BIT_MASK_GPIO_IO_SEL_15_TO_8_8197F \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8197F)
#define BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8197F(x) \
((x) & (~BITS_GPIO_IO_SEL_15_TO_8_8197F))
#define BIT_GET_GPIO_IO_SEL_15_TO_8_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8197F) & \
BIT_MASK_GPIO_IO_SEL_15_TO_8_8197F)
#define BIT_SET_GPIO_IO_SEL_15_TO_8_8197F(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8197F(x) | \
BIT_GPIO_IO_SEL_15_TO_8_8197F(v))
#define BIT_SHIFT_GPIO_OUT_15_TO_8_8197F 8
#define BIT_MASK_GPIO_OUT_15_TO_8_8197F 0xff
#define BIT_GPIO_OUT_15_TO_8_8197F(x) \
(((x) & BIT_MASK_GPIO_OUT_15_TO_8_8197F) \
<< BIT_SHIFT_GPIO_OUT_15_TO_8_8197F)
#define BITS_GPIO_OUT_15_TO_8_8197F \
(BIT_MASK_GPIO_OUT_15_TO_8_8197F << BIT_SHIFT_GPIO_OUT_15_TO_8_8197F)
#define BIT_CLEAR_GPIO_OUT_15_TO_8_8197F(x) \
((x) & (~BITS_GPIO_OUT_15_TO_8_8197F))
#define BIT_GET_GPIO_OUT_15_TO_8_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_15_TO_8_8197F) & \
BIT_MASK_GPIO_OUT_15_TO_8_8197F)
#define BIT_SET_GPIO_OUT_15_TO_8_8197F(x, v) \
(BIT_CLEAR_GPIO_OUT_15_TO_8_8197F(x) | BIT_GPIO_OUT_15_TO_8_8197F(v))
#define BIT_SHIFT_GPIO_IN_15_TO_8_8197F 0
#define BIT_MASK_GPIO_IN_15_TO_8_8197F 0xff
#define BIT_GPIO_IN_15_TO_8_8197F(x) \
(((x) & BIT_MASK_GPIO_IN_15_TO_8_8197F) \
<< BIT_SHIFT_GPIO_IN_15_TO_8_8197F)
#define BITS_GPIO_IN_15_TO_8_8197F \
(BIT_MASK_GPIO_IN_15_TO_8_8197F << BIT_SHIFT_GPIO_IN_15_TO_8_8197F)
#define BIT_CLEAR_GPIO_IN_15_TO_8_8197F(x) ((x) & (~BITS_GPIO_IN_15_TO_8_8197F))
#define BIT_GET_GPIO_IN_15_TO_8_8197F(x) \
(((x) >> BIT_SHIFT_GPIO_IN_15_TO_8_8197F) & \
BIT_MASK_GPIO_IN_15_TO_8_8197F)
#define BIT_SET_GPIO_IN_15_TO_8_8197F(x, v) \
(BIT_CLEAR_GPIO_IN_15_TO_8_8197F(x) | BIT_GPIO_IN_15_TO_8_8197F(v))
/* 2 REG_PAD_CTRL1_8197F */
#define BIT_PAPE_WLBT_SEL_8197F BIT(29)
#define BIT_LNAON_WLBT_SEL_8197F BIT(28)
#define BIT_BTGP_GPG3_FEN_8197F BIT(26)
#define BIT_BTGP_GPG2_FEN_8197F BIT(25)
#define BIT_BTGP_JTAG_EN_8197F BIT(24)
#define BIT_XTAL_CLK_EXTARNAL_EN_8197F BIT(23)
#define BIT_BTGP_UART0_EN_8197F BIT(22)
#define BIT_BTGP_UART1_EN_8197F BIT(21)
#define BIT_BTGP_SPI_EN_8197F BIT(20)
#define BIT_BTGP_GPIO_E2_8197F BIT(19)
#define BIT_BTGP_GPIO_EN_8197F BIT(18)
#define BIT_SHIFT_BTGP_GPIO_SL_8197F 16
#define BIT_MASK_BTGP_GPIO_SL_8197F 0x3
#define BIT_BTGP_GPIO_SL_8197F(x) \
(((x) & BIT_MASK_BTGP_GPIO_SL_8197F) << BIT_SHIFT_BTGP_GPIO_SL_8197F)
#define BITS_BTGP_GPIO_SL_8197F \
(BIT_MASK_BTGP_GPIO_SL_8197F << BIT_SHIFT_BTGP_GPIO_SL_8197F)
#define BIT_CLEAR_BTGP_GPIO_SL_8197F(x) ((x) & (~BITS_BTGP_GPIO_SL_8197F))
#define BIT_GET_BTGP_GPIO_SL_8197F(x) \
(((x) >> BIT_SHIFT_BTGP_GPIO_SL_8197F) & BIT_MASK_BTGP_GPIO_SL_8197F)
#define BIT_SET_BTGP_GPIO_SL_8197F(x, v) \
(BIT_CLEAR_BTGP_GPIO_SL_8197F(x) | BIT_BTGP_GPIO_SL_8197F(v))
#define BIT_PAD_SDIO_SR_8197F BIT(14)
#define BIT_GPIO14_OUTPUT_PL_8197F BIT(13)
#define BIT_HOST_WAKE_PAD_PULL_EN_8197F BIT(12)
#define BIT_HOST_WAKE_PAD_SL_8197F BIT(11)
#define BIT_PAD_LNAON_SR_8197F BIT(10)
#define BIT_PAD_LNAON_E2_8197F BIT(9)
#define BIT_SW_LNAON_G_SEL_DATA_8197F BIT(8)
#define BIT_SW_LNAON_A_SEL_DATA_8197F BIT(7)
#define BIT_PAD_PAPE_SR_8197F BIT(6)
#define BIT_PAD_PAPE_E2_8197F BIT(5)
#define BIT_SW_PAPE_G_SEL_DATA_8197F BIT(4)
#define BIT_SW_PAPE_A_SEL_DATA_8197F BIT(3)
#define BIT_PAD_DPDT_SR_8197F BIT(2)
#define BIT_PAD_DPDT_PAD_E2_8197F BIT(1)
#define BIT_SW_DPDT_SEL_DATA_8197F BIT(0)
/* 2 REG_WL_BT_PWR_CTRL_8197F */
#define BIT_ISO_BD2PP_8197F BIT(31)
#define BIT_LDOV12B_EN_8197F BIT(30)
#define BIT_CKEN_BTGPS_8197F BIT(29)
#define BIT_FEN_BTGPS_8197F BIT(28)
#define BIT_BTCPU_BOOTSEL_8197F BIT(27)
#define BIT_SPI_SPEEDUP_8197F BIT(26)
#define BIT_DEVWAKE_PAD_TYPE_SEL_8197F BIT(24)
#define BIT_CLKREQ_PAD_TYPE_SEL_8197F BIT(23)
#define BIT_ISO_BTPON2PP_8197F BIT(22)
#define BIT_BT_HWROF_EN_8197F BIT(19)
#define BIT_BT_FUNC_EN_8197F BIT(18)
#define BIT_BT_HWPDN_SL_8197F BIT(17)
#define BIT_BT_DISN_EN_8197F BIT(16)
#define BIT_BT_PDN_PULL_EN_8197F BIT(15)
#define BIT_WL_PDN_PULL_EN_8197F BIT(14)
#define BIT_EXTERNAL_REQUEST_PL_8197F BIT(13)
#define BIT_GPIO0_2_3_PULL_LOW_EN_8197F BIT(12)
#define BIT_ISO_BA2PP_8197F BIT(11)
#define BIT_BT_AFE_LDO_EN_8197F BIT(10)
#define BIT_BT_AFE_PLL_EN_8197F BIT(9)
#define BIT_BT_DIG_CLK_EN_8197F BIT(8)
#define BIT_WL_DRV_EXIST_IDX_8197F BIT(5)
#define BIT_DOP_EHPAD_8197F BIT(4)
#define BIT_WL_HWROF_EN_8197F BIT(3)
#define BIT_WL_FUNC_EN_8197F BIT(2)
#define BIT_WL_HWPDN_SL_8197F BIT(1)
#define BIT_WL_HWPDN_EN_8197F BIT(0)
/* 2 REG_SDM_DEBUG_8197F */
#define BIT_SHIFT_WLCLK_PHASE_8197F 0
#define BIT_MASK_WLCLK_PHASE_8197F 0x1f
#define BIT_WLCLK_PHASE_8197F(x) \
(((x) & BIT_MASK_WLCLK_PHASE_8197F) << BIT_SHIFT_WLCLK_PHASE_8197F)
#define BITS_WLCLK_PHASE_8197F \
(BIT_MASK_WLCLK_PHASE_8197F << BIT_SHIFT_WLCLK_PHASE_8197F)
#define BIT_CLEAR_WLCLK_PHASE_8197F(x) ((x) & (~BITS_WLCLK_PHASE_8197F))
#define BIT_GET_WLCLK_PHASE_8197F(x) \
(((x) >> BIT_SHIFT_WLCLK_PHASE_8197F) & BIT_MASK_WLCLK_PHASE_8197F)
#define BIT_SET_WLCLK_PHASE_8197F(x, v) \
(BIT_CLEAR_WLCLK_PHASE_8197F(x) | BIT_WLCLK_PHASE_8197F(v))
/* 2 REG_SYS_SDIO_CTRL_8197F */
#define BIT_DBG_GNT_WL_BT_8197F BIT(27)
#define BIT_LTE_MUX_CTRL_PATH_8197F BIT(26)
#define BIT_SDIO_INT_POLARITY_8197F BIT(19)
#define BIT_SDIO_INT_8197F BIT(18)
#define BIT_SDIO_OFF_EN_8197F BIT(17)
#define BIT_SDIO_ON_EN_8197F BIT(16)
/* 2 REG_HCI_OPT_CTRL_8197F */
#define BIT_USB_HOST_PWR_OFF_EN_8197F BIT(12)
#define BIT_SYM_LPS_BLOCK_EN_8197F BIT(11)
#define BIT_USB_LPM_ACT_EN_8197F BIT(10)
#define BIT_USB_LPM_NY_8197F BIT(9)
#define BIT_USB_SUS_DIS_8197F BIT(8)
#define BIT_SHIFT_SDIO_PAD_E_8197F 5
#define BIT_MASK_SDIO_PAD_E_8197F 0x7
#define BIT_SDIO_PAD_E_8197F(x) \
(((x) & BIT_MASK_SDIO_PAD_E_8197F) << BIT_SHIFT_SDIO_PAD_E_8197F)
#define BITS_SDIO_PAD_E_8197F \
(BIT_MASK_SDIO_PAD_E_8197F << BIT_SHIFT_SDIO_PAD_E_8197F)
#define BIT_CLEAR_SDIO_PAD_E_8197F(x) ((x) & (~BITS_SDIO_PAD_E_8197F))
#define BIT_GET_SDIO_PAD_E_8197F(x) \
(((x) >> BIT_SHIFT_SDIO_PAD_E_8197F) & BIT_MASK_SDIO_PAD_E_8197F)
#define BIT_SET_SDIO_PAD_E_8197F(x, v) \
(BIT_CLEAR_SDIO_PAD_E_8197F(x) | BIT_SDIO_PAD_E_8197F(v))
#define BIT_USB_LPPLL_EN_8197F BIT(4)
#define BIT_ROP_SW15_8197F BIT(2)
#define BIT_PCI_CKRDY_OPT_8197F BIT(1)
#define BIT_PCI_VAUX_EN_8197F BIT(0)
/* 2 REG_AFE_CTRL4_8197F */
#define BIT_RF1_SDMRSTB_8197F BIT(26)
#define BIT_RF1_RSTB_8197F BIT(25)
#define BIT_RF1_EN_8197F BIT(24)
#define BIT_SHIFT_XTAL_LDO_8197F 20
#define BIT_MASK_XTAL_LDO_8197F 0x7
#define BIT_XTAL_LDO_8197F(x) \
(((x) & BIT_MASK_XTAL_LDO_8197F) << BIT_SHIFT_XTAL_LDO_8197F)
#define BITS_XTAL_LDO_8197F \
(BIT_MASK_XTAL_LDO_8197F << BIT_SHIFT_XTAL_LDO_8197F)
#define BIT_CLEAR_XTAL_LDO_8197F(x) ((x) & (~BITS_XTAL_LDO_8197F))
#define BIT_GET_XTAL_LDO_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_8197F) & BIT_MASK_XTAL_LDO_8197F)
#define BIT_SET_XTAL_LDO_8197F(x, v) \
(BIT_CLEAR_XTAL_LDO_8197F(x) | BIT_XTAL_LDO_8197F(v))
#define BIT_ADC_CK_SYNC_EN_8197F BIT(16)
/* 2 REG_LDO_SWR_CTRL_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_MCUFW_CTRL_8197F */
#define BIT_SHIFT_RPWM_8197F 24
#define BIT_MASK_RPWM_8197F 0xff
#define BIT_RPWM_8197F(x) (((x) & BIT_MASK_RPWM_8197F) << BIT_SHIFT_RPWM_8197F)
#define BITS_RPWM_8197F (BIT_MASK_RPWM_8197F << BIT_SHIFT_RPWM_8197F)
#define BIT_CLEAR_RPWM_8197F(x) ((x) & (~BITS_RPWM_8197F))
#define BIT_GET_RPWM_8197F(x) \
(((x) >> BIT_SHIFT_RPWM_8197F) & BIT_MASK_RPWM_8197F)
#define BIT_SET_RPWM_8197F(x, v) (BIT_CLEAR_RPWM_8197F(x) | BIT_RPWM_8197F(v))
#define BIT_CPRST_8197F BIT(23)
#define BIT_ANA_PORT_EN_8197F BIT(22)
#define BIT_MAC_PORT_EN_8197F BIT(21)
#define BIT_BOOT_FSPI_EN_8197F BIT(20)
#define BIT_ROM_DLEN_8197F BIT(19)
#define BIT_SHIFT_ROM_PGE_8197F 16
#define BIT_MASK_ROM_PGE_8197F 0x7
#define BIT_ROM_PGE_8197F(x) \
(((x) & BIT_MASK_ROM_PGE_8197F) << BIT_SHIFT_ROM_PGE_8197F)
#define BITS_ROM_PGE_8197F (BIT_MASK_ROM_PGE_8197F << BIT_SHIFT_ROM_PGE_8197F)
#define BIT_CLEAR_ROM_PGE_8197F(x) ((x) & (~BITS_ROM_PGE_8197F))
#define BIT_GET_ROM_PGE_8197F(x) \
(((x) >> BIT_SHIFT_ROM_PGE_8197F) & BIT_MASK_ROM_PGE_8197F)
#define BIT_SET_ROM_PGE_8197F(x, v) \
(BIT_CLEAR_ROM_PGE_8197F(x) | BIT_ROM_PGE_8197F(v))
#define BIT_FW_INIT_RDY_8197F BIT(15)
#define BIT_FW_DW_RDY_8197F BIT(14)
#define BIT_SHIFT_CPU_CLK_SEL_8197F 12
#define BIT_MASK_CPU_CLK_SEL_8197F 0x3
#define BIT_CPU_CLK_SEL_8197F(x) \
(((x) & BIT_MASK_CPU_CLK_SEL_8197F) << BIT_SHIFT_CPU_CLK_SEL_8197F)
#define BITS_CPU_CLK_SEL_8197F \
(BIT_MASK_CPU_CLK_SEL_8197F << BIT_SHIFT_CPU_CLK_SEL_8197F)
#define BIT_CLEAR_CPU_CLK_SEL_8197F(x) ((x) & (~BITS_CPU_CLK_SEL_8197F))
#define BIT_GET_CPU_CLK_SEL_8197F(x) \
(((x) >> BIT_SHIFT_CPU_CLK_SEL_8197F) & BIT_MASK_CPU_CLK_SEL_8197F)
#define BIT_SET_CPU_CLK_SEL_8197F(x, v) \
(BIT_CLEAR_CPU_CLK_SEL_8197F(x) | BIT_CPU_CLK_SEL_8197F(v))
#define BIT_CCLK_CHG_MASK_8197F BIT(11)
#define BIT_FW_INIT_RDY_V1_8197F BIT(10)
#define BIT_R_8051_SPD_8197F BIT(9)
#define BIT_MCU_CLK_EN_8197F BIT(8)
#define BIT_RAM_DL_SEL_8197F BIT(7)
#define BIT_WINTINI_RDY_8197F BIT(6)
#define BIT_RF_INIT_RDY_8197F BIT(5)
#define BIT_BB_INIT_RDY_8197F BIT(4)
#define BIT_MAC_INIT_RDY_8197F BIT(3)
#define BIT_MCU_FWDL_RDY_8197F BIT(1)
#define BIT_MCU_FWDL_EN_8197F BIT(0)
/* 2 REG_MCU_TST_CFG_8197F */
#define BIT_SHIFT_LBKTST_8197F 0
#define BIT_MASK_LBKTST_8197F 0xffff
#define BIT_LBKTST_8197F(x) \
(((x) & BIT_MASK_LBKTST_8197F) << BIT_SHIFT_LBKTST_8197F)
#define BITS_LBKTST_8197F (BIT_MASK_LBKTST_8197F << BIT_SHIFT_LBKTST_8197F)
#define BIT_CLEAR_LBKTST_8197F(x) ((x) & (~BITS_LBKTST_8197F))
#define BIT_GET_LBKTST_8197F(x) \
(((x) >> BIT_SHIFT_LBKTST_8197F) & BIT_MASK_LBKTST_8197F)
#define BIT_SET_LBKTST_8197F(x, v) \
(BIT_CLEAR_LBKTST_8197F(x) | BIT_LBKTST_8197F(v))
/* 2 REG_HMEBOX_E0_E1_8197F */
#define BIT_SHIFT_HOST_MSG_E1_8197F 16
#define BIT_MASK_HOST_MSG_E1_8197F 0xffff
#define BIT_HOST_MSG_E1_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_E1_8197F) << BIT_SHIFT_HOST_MSG_E1_8197F)
#define BITS_HOST_MSG_E1_8197F \
(BIT_MASK_HOST_MSG_E1_8197F << BIT_SHIFT_HOST_MSG_E1_8197F)
#define BIT_CLEAR_HOST_MSG_E1_8197F(x) ((x) & (~BITS_HOST_MSG_E1_8197F))
#define BIT_GET_HOST_MSG_E1_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E1_8197F) & BIT_MASK_HOST_MSG_E1_8197F)
#define BIT_SET_HOST_MSG_E1_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_E1_8197F(x) | BIT_HOST_MSG_E1_8197F(v))
#define BIT_SHIFT_HOST_MSG_E0_8197F 0
#define BIT_MASK_HOST_MSG_E0_8197F 0xffff
#define BIT_HOST_MSG_E0_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_E0_8197F) << BIT_SHIFT_HOST_MSG_E0_8197F)
#define BITS_HOST_MSG_E0_8197F \
(BIT_MASK_HOST_MSG_E0_8197F << BIT_SHIFT_HOST_MSG_E0_8197F)
#define BIT_CLEAR_HOST_MSG_E0_8197F(x) ((x) & (~BITS_HOST_MSG_E0_8197F))
#define BIT_GET_HOST_MSG_E0_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E0_8197F) & BIT_MASK_HOST_MSG_E0_8197F)
#define BIT_SET_HOST_MSG_E0_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_E0_8197F(x) | BIT_HOST_MSG_E0_8197F(v))
/* 2 REG_HMEBOX_E2_E3_8197F */
#define BIT_SHIFT_HOST_MSG_E3_8197F 16
#define BIT_MASK_HOST_MSG_E3_8197F 0xffff
#define BIT_HOST_MSG_E3_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_E3_8197F) << BIT_SHIFT_HOST_MSG_E3_8197F)
#define BITS_HOST_MSG_E3_8197F \
(BIT_MASK_HOST_MSG_E3_8197F << BIT_SHIFT_HOST_MSG_E3_8197F)
#define BIT_CLEAR_HOST_MSG_E3_8197F(x) ((x) & (~BITS_HOST_MSG_E3_8197F))
#define BIT_GET_HOST_MSG_E3_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E3_8197F) & BIT_MASK_HOST_MSG_E3_8197F)
#define BIT_SET_HOST_MSG_E3_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_E3_8197F(x) | BIT_HOST_MSG_E3_8197F(v))
#define BIT_SHIFT_HOST_MSG_E2_8197F 0
#define BIT_MASK_HOST_MSG_E2_8197F 0xffff
#define BIT_HOST_MSG_E2_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_E2_8197F) << BIT_SHIFT_HOST_MSG_E2_8197F)
#define BITS_HOST_MSG_E2_8197F \
(BIT_MASK_HOST_MSG_E2_8197F << BIT_SHIFT_HOST_MSG_E2_8197F)
#define BIT_CLEAR_HOST_MSG_E2_8197F(x) ((x) & (~BITS_HOST_MSG_E2_8197F))
#define BIT_GET_HOST_MSG_E2_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E2_8197F) & BIT_MASK_HOST_MSG_E2_8197F)
#define BIT_SET_HOST_MSG_E2_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_E2_8197F(x) | BIT_HOST_MSG_E2_8197F(v))
/* 2 REG_WLLPS_CTRL_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_AFE_CTRL5_8197F */
#define BIT_BB_DBG_SEL_AFE_SDM_V3_8197F BIT(31)
#define BIT_ORDER_SDM_8197F BIT(30)
#define BIT_RFE_SEL_SDM_8197F BIT(29)
#define BIT_SHIFT_REF_SEL_8197F 25
#define BIT_MASK_REF_SEL_8197F 0xf
#define BIT_REF_SEL_8197F(x) \
(((x) & BIT_MASK_REF_SEL_8197F) << BIT_SHIFT_REF_SEL_8197F)
#define BITS_REF_SEL_8197F (BIT_MASK_REF_SEL_8197F << BIT_SHIFT_REF_SEL_8197F)
#define BIT_CLEAR_REF_SEL_8197F(x) ((x) & (~BITS_REF_SEL_8197F))
#define BIT_GET_REF_SEL_8197F(x) \
(((x) >> BIT_SHIFT_REF_SEL_8197F) & BIT_MASK_REF_SEL_8197F)
#define BIT_SET_REF_SEL_8197F(x, v) \
(BIT_CLEAR_REF_SEL_8197F(x) | BIT_REF_SEL_8197F(v))
#define BIT_SHIFT_F0F_SDM_V2_8197F 12
#define BIT_MASK_F0F_SDM_V2_8197F 0x1fff
#define BIT_F0F_SDM_V2_8197F(x) \
(((x) & BIT_MASK_F0F_SDM_V2_8197F) << BIT_SHIFT_F0F_SDM_V2_8197F)
#define BITS_F0F_SDM_V2_8197F \
(BIT_MASK_F0F_SDM_V2_8197F << BIT_SHIFT_F0F_SDM_V2_8197F)
#define BIT_CLEAR_F0F_SDM_V2_8197F(x) ((x) & (~BITS_F0F_SDM_V2_8197F))
#define BIT_GET_F0F_SDM_V2_8197F(x) \
(((x) >> BIT_SHIFT_F0F_SDM_V2_8197F) & BIT_MASK_F0F_SDM_V2_8197F)
#define BIT_SET_F0F_SDM_V2_8197F(x, v) \
(BIT_CLEAR_F0F_SDM_V2_8197F(x) | BIT_F0F_SDM_V2_8197F(v))
#define BIT_SHIFT_F0N_SDM_V2_8197F 9
#define BIT_MASK_F0N_SDM_V2_8197F 0x7
#define BIT_F0N_SDM_V2_8197F(x) \
(((x) & BIT_MASK_F0N_SDM_V2_8197F) << BIT_SHIFT_F0N_SDM_V2_8197F)
#define BITS_F0N_SDM_V2_8197F \
(BIT_MASK_F0N_SDM_V2_8197F << BIT_SHIFT_F0N_SDM_V2_8197F)
#define BIT_CLEAR_F0N_SDM_V2_8197F(x) ((x) & (~BITS_F0N_SDM_V2_8197F))
#define BIT_GET_F0N_SDM_V2_8197F(x) \
(((x) >> BIT_SHIFT_F0N_SDM_V2_8197F) & BIT_MASK_F0N_SDM_V2_8197F)
#define BIT_SET_F0N_SDM_V2_8197F(x, v) \
(BIT_CLEAR_F0N_SDM_V2_8197F(x) | BIT_F0N_SDM_V2_8197F(v))
#define BIT_SHIFT_DIVN_SDM_V2_8197F 3
#define BIT_MASK_DIVN_SDM_V2_8197F 0x3f
#define BIT_DIVN_SDM_V2_8197F(x) \
(((x) & BIT_MASK_DIVN_SDM_V2_8197F) << BIT_SHIFT_DIVN_SDM_V2_8197F)
#define BITS_DIVN_SDM_V2_8197F \
(BIT_MASK_DIVN_SDM_V2_8197F << BIT_SHIFT_DIVN_SDM_V2_8197F)
#define BIT_CLEAR_DIVN_SDM_V2_8197F(x) ((x) & (~BITS_DIVN_SDM_V2_8197F))
#define BIT_GET_DIVN_SDM_V2_8197F(x) \
(((x) >> BIT_SHIFT_DIVN_SDM_V2_8197F) & BIT_MASK_DIVN_SDM_V2_8197F)
#define BIT_SET_DIVN_SDM_V2_8197F(x, v) \
(BIT_CLEAR_DIVN_SDM_V2_8197F(x) | BIT_DIVN_SDM_V2_8197F(v))
#define BIT_SHIFT_DITHER_SDM_V2_8197F 0
#define BIT_MASK_DITHER_SDM_V2_8197F 0x7
#define BIT_DITHER_SDM_V2_8197F(x) \
(((x) & BIT_MASK_DITHER_SDM_V2_8197F) << BIT_SHIFT_DITHER_SDM_V2_8197F)
#define BITS_DITHER_SDM_V2_8197F \
(BIT_MASK_DITHER_SDM_V2_8197F << BIT_SHIFT_DITHER_SDM_V2_8197F)
#define BIT_CLEAR_DITHER_SDM_V2_8197F(x) ((x) & (~BITS_DITHER_SDM_V2_8197F))
#define BIT_GET_DITHER_SDM_V2_8197F(x) \
(((x) >> BIT_SHIFT_DITHER_SDM_V2_8197F) & BIT_MASK_DITHER_SDM_V2_8197F)
#define BIT_SET_DITHER_SDM_V2_8197F(x, v) \
(BIT_CLEAR_DITHER_SDM_V2_8197F(x) | BIT_DITHER_SDM_V2_8197F(v))
/* 2 REG_GPIO_DEBOUNCE_CTRL_8197F */
#define BIT_WLGP_DBC1EN_8197F BIT(15)
#define BIT_SHIFT_WLGP_DBC1_8197F 8
#define BIT_MASK_WLGP_DBC1_8197F 0xf
#define BIT_WLGP_DBC1_8197F(x) \
(((x) & BIT_MASK_WLGP_DBC1_8197F) << BIT_SHIFT_WLGP_DBC1_8197F)
#define BITS_WLGP_DBC1_8197F \
(BIT_MASK_WLGP_DBC1_8197F << BIT_SHIFT_WLGP_DBC1_8197F)
#define BIT_CLEAR_WLGP_DBC1_8197F(x) ((x) & (~BITS_WLGP_DBC1_8197F))
#define BIT_GET_WLGP_DBC1_8197F(x) \
(((x) >> BIT_SHIFT_WLGP_DBC1_8197F) & BIT_MASK_WLGP_DBC1_8197F)
#define BIT_SET_WLGP_DBC1_8197F(x, v) \
(BIT_CLEAR_WLGP_DBC1_8197F(x) | BIT_WLGP_DBC1_8197F(v))
#define BIT_WLGP_DBC0EN_8197F BIT(7)
#define BIT_SHIFT_WLGP_DBC0_8197F 0
#define BIT_MASK_WLGP_DBC0_8197F 0xf
#define BIT_WLGP_DBC0_8197F(x) \
(((x) & BIT_MASK_WLGP_DBC0_8197F) << BIT_SHIFT_WLGP_DBC0_8197F)
#define BITS_WLGP_DBC0_8197F \
(BIT_MASK_WLGP_DBC0_8197F << BIT_SHIFT_WLGP_DBC0_8197F)
#define BIT_CLEAR_WLGP_DBC0_8197F(x) ((x) & (~BITS_WLGP_DBC0_8197F))
#define BIT_GET_WLGP_DBC0_8197F(x) \
(((x) >> BIT_SHIFT_WLGP_DBC0_8197F) & BIT_MASK_WLGP_DBC0_8197F)
#define BIT_SET_WLGP_DBC0_8197F(x, v) \
(BIT_CLEAR_WLGP_DBC0_8197F(x) | BIT_WLGP_DBC0_8197F(v))
/* 2 REG_RPWM2_8197F */
#define BIT_SHIFT_RPWM2_8197F 16
#define BIT_MASK_RPWM2_8197F 0xffff
#define BIT_RPWM2_8197F(x) \
(((x) & BIT_MASK_RPWM2_8197F) << BIT_SHIFT_RPWM2_8197F)
#define BITS_RPWM2_8197F (BIT_MASK_RPWM2_8197F << BIT_SHIFT_RPWM2_8197F)
#define BIT_CLEAR_RPWM2_8197F(x) ((x) & (~BITS_RPWM2_8197F))
#define BIT_GET_RPWM2_8197F(x) \
(((x) >> BIT_SHIFT_RPWM2_8197F) & BIT_MASK_RPWM2_8197F)
#define BIT_SET_RPWM2_8197F(x, v) \
(BIT_CLEAR_RPWM2_8197F(x) | BIT_RPWM2_8197F(v))
/* 2 REG_SYSON_FSM_MON_8197F */
#define BIT_SHIFT_FSM_MON_SEL_8197F 24
#define BIT_MASK_FSM_MON_SEL_8197F 0x7
#define BIT_FSM_MON_SEL_8197F(x) \
(((x) & BIT_MASK_FSM_MON_SEL_8197F) << BIT_SHIFT_FSM_MON_SEL_8197F)
#define BITS_FSM_MON_SEL_8197F \
(BIT_MASK_FSM_MON_SEL_8197F << BIT_SHIFT_FSM_MON_SEL_8197F)
#define BIT_CLEAR_FSM_MON_SEL_8197F(x) ((x) & (~BITS_FSM_MON_SEL_8197F))
#define BIT_GET_FSM_MON_SEL_8197F(x) \
(((x) >> BIT_SHIFT_FSM_MON_SEL_8197F) & BIT_MASK_FSM_MON_SEL_8197F)
#define BIT_SET_FSM_MON_SEL_8197F(x, v) \
(BIT_CLEAR_FSM_MON_SEL_8197F(x) | BIT_FSM_MON_SEL_8197F(v))
#define BIT_DOP_ELDO_8197F BIT(23)
#define BIT_FSM_MON_UPD_8197F BIT(15)
#define BIT_SHIFT_FSM_PAR_8197F 0
#define BIT_MASK_FSM_PAR_8197F 0x7fff
#define BIT_FSM_PAR_8197F(x) \
(((x) & BIT_MASK_FSM_PAR_8197F) << BIT_SHIFT_FSM_PAR_8197F)
#define BITS_FSM_PAR_8197F (BIT_MASK_FSM_PAR_8197F << BIT_SHIFT_FSM_PAR_8197F)
#define BIT_CLEAR_FSM_PAR_8197F(x) ((x) & (~BITS_FSM_PAR_8197F))
#define BIT_GET_FSM_PAR_8197F(x) \
(((x) >> BIT_SHIFT_FSM_PAR_8197F) & BIT_MASK_FSM_PAR_8197F)
#define BIT_SET_FSM_PAR_8197F(x, v) \
(BIT_CLEAR_FSM_PAR_8197F(x) | BIT_FSM_PAR_8197F(v))
/* 2 REG_AFE_CTRL6_8197F */
#define BIT_SHIFT_TSFT_SEL_V1_8197F 0
#define BIT_MASK_TSFT_SEL_V1_8197F 0x7
#define BIT_TSFT_SEL_V1_8197F(x) \
(((x) & BIT_MASK_TSFT_SEL_V1_8197F) << BIT_SHIFT_TSFT_SEL_V1_8197F)
#define BITS_TSFT_SEL_V1_8197F \
(BIT_MASK_TSFT_SEL_V1_8197F << BIT_SHIFT_TSFT_SEL_V1_8197F)
#define BIT_CLEAR_TSFT_SEL_V1_8197F(x) ((x) & (~BITS_TSFT_SEL_V1_8197F))
#define BIT_GET_TSFT_SEL_V1_8197F(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_V1_8197F) & BIT_MASK_TSFT_SEL_V1_8197F)
#define BIT_SET_TSFT_SEL_V1_8197F(x, v) \
(BIT_CLEAR_TSFT_SEL_V1_8197F(x) | BIT_TSFT_SEL_V1_8197F(v))
/* 2 REG_PMC_DBG_CTRL1_8197F */
#define BIT_BT_INT_EN_8197F BIT(31)
#define BIT_SHIFT_RD_WR_WIFI_BT_INFO_8197F 16
#define BIT_MASK_RD_WR_WIFI_BT_INFO_8197F 0x7fff
#define BIT_RD_WR_WIFI_BT_INFO_8197F(x) \
(((x) & BIT_MASK_RD_WR_WIFI_BT_INFO_8197F) \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8197F)
#define BITS_RD_WR_WIFI_BT_INFO_8197F \
(BIT_MASK_RD_WR_WIFI_BT_INFO_8197F \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8197F)
#define BIT_CLEAR_RD_WR_WIFI_BT_INFO_8197F(x) \
((x) & (~BITS_RD_WR_WIFI_BT_INFO_8197F))
#define BIT_GET_RD_WR_WIFI_BT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_RD_WR_WIFI_BT_INFO_8197F) & \
BIT_MASK_RD_WR_WIFI_BT_INFO_8197F)
#define BIT_SET_RD_WR_WIFI_BT_INFO_8197F(x, v) \
(BIT_CLEAR_RD_WR_WIFI_BT_INFO_8197F(x) | \
BIT_RD_WR_WIFI_BT_INFO_8197F(v))
#define BIT_PMC_WR_OVF_8197F BIT(8)
#define BIT_SHIFT_WLPMC_ERRINT_8197F 0
#define BIT_MASK_WLPMC_ERRINT_8197F 0xff
#define BIT_WLPMC_ERRINT_8197F(x) \
(((x) & BIT_MASK_WLPMC_ERRINT_8197F) << BIT_SHIFT_WLPMC_ERRINT_8197F)
#define BITS_WLPMC_ERRINT_8197F \
(BIT_MASK_WLPMC_ERRINT_8197F << BIT_SHIFT_WLPMC_ERRINT_8197F)
#define BIT_CLEAR_WLPMC_ERRINT_8197F(x) ((x) & (~BITS_WLPMC_ERRINT_8197F))
#define BIT_GET_WLPMC_ERRINT_8197F(x) \
(((x) >> BIT_SHIFT_WLPMC_ERRINT_8197F) & BIT_MASK_WLPMC_ERRINT_8197F)
#define BIT_SET_WLPMC_ERRINT_8197F(x, v) \
(BIT_CLEAR_WLPMC_ERRINT_8197F(x) | BIT_WLPMC_ERRINT_8197F(v))
/* 2 REG_AFE_CTRL7_8197F */
#define BIT_SHIFT_SEL_V_8197F 30
#define BIT_MASK_SEL_V_8197F 0x3
#define BIT_SEL_V_8197F(x) \
(((x) & BIT_MASK_SEL_V_8197F) << BIT_SHIFT_SEL_V_8197F)
#define BITS_SEL_V_8197F (BIT_MASK_SEL_V_8197F << BIT_SHIFT_SEL_V_8197F)
#define BIT_CLEAR_SEL_V_8197F(x) ((x) & (~BITS_SEL_V_8197F))
#define BIT_GET_SEL_V_8197F(x) \
(((x) >> BIT_SHIFT_SEL_V_8197F) & BIT_MASK_SEL_V_8197F)
#define BIT_SET_SEL_V_8197F(x, v) \
(BIT_CLEAR_SEL_V_8197F(x) | BIT_SEL_V_8197F(v))
#define BIT_SEL_LDO_PC_8197F BIT(29)
#define BIT_SHIFT_CK_MON_SEL_V2_8197F 26
#define BIT_MASK_CK_MON_SEL_V2_8197F 0x7
#define BIT_CK_MON_SEL_V2_8197F(x) \
(((x) & BIT_MASK_CK_MON_SEL_V2_8197F) << BIT_SHIFT_CK_MON_SEL_V2_8197F)
#define BITS_CK_MON_SEL_V2_8197F \
(BIT_MASK_CK_MON_SEL_V2_8197F << BIT_SHIFT_CK_MON_SEL_V2_8197F)
#define BIT_CLEAR_CK_MON_SEL_V2_8197F(x) ((x) & (~BITS_CK_MON_SEL_V2_8197F))
#define BIT_GET_CK_MON_SEL_V2_8197F(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL_V2_8197F) & BIT_MASK_CK_MON_SEL_V2_8197F)
#define BIT_SET_CK_MON_SEL_V2_8197F(x, v) \
(BIT_CLEAR_CK_MON_SEL_V2_8197F(x) | BIT_CK_MON_SEL_V2_8197F(v))
#define BIT_CK_MON_EN_8197F BIT(25)
#define BIT_FREF_EDGE_8197F BIT(24)
#define BIT_CK320M_EN_8197F BIT(23)
#define BIT_CK_5M_EN_8197F BIT(22)
#define BIT_TESTEN_8197F BIT(21)
/* 2 REG_HIMR0_8197F */
#define BIT_TIMEOUT_INTERRUPT2_MASK_8197F BIT(31)
#define BIT_TIMEOUT_INTERRUTP1_MASK_8197F BIT(30)
#define BIT_PSTIMEOUT_MSK_8197F BIT(29)
#define BIT_GTINT4_MSK_8197F BIT(28)
#define BIT_GTINT3_MSK_8197F BIT(27)
#define BIT_TXBCN0ERR_MSK_8197F BIT(26)
#define BIT_TXBCN0OK_MSK_8197F BIT(25)
#define BIT_TSF_BIT32_TOGGLE_MSK_8197F BIT(24)
#define BIT_BCNDMAINT0_MSK_8197F BIT(20)
#define BIT_BCNDERR0_MSK_8197F BIT(16)
#define BIT_HSISR_IND_ON_INT_MSK_8197F BIT(15)
#define BIT_HISR3_IND_INT_MSK_8197F BIT(14)
#define BIT_HISR2_IND_INT_MSK_8197F BIT(13)
#define BIT_CTWEND_MSK_8197F BIT(12)
#define BIT_HISR1_IND_MSK_8197F BIT(11)
#define BIT_C2HCMD_MSK_8197F BIT(10)
#define BIT_CPWM2_MSK_8197F BIT(9)
#define BIT_CPWM_MSK_8197F BIT(8)
#define BIT_HIGHDOK_MSK_8197F BIT(7)
#define BIT_MGTDOK_MSK_8197F BIT(6)
#define BIT_BKDOK_MSK_8197F BIT(5)
#define BIT_BEDOK_MSK_8197F BIT(4)
#define BIT_VIDOK_MSK_8197F BIT(3)
#define BIT_VODOK_MSK_8197F BIT(2)
#define BIT_RDU_MSK_8197F BIT(1)
#define BIT_RXOK_MSK_8197F BIT(0)
/* 2 REG_HISR0_8197F */
#define BIT_PSTIMEOUT2_8197F BIT(31)
#define BIT_PSTIMEOUT1_8197F BIT(30)
#define BIT_PSTIMEOUT_8197F BIT(29)
#define BIT_GTINT4_8197F BIT(28)
#define BIT_GTINT3_8197F BIT(27)
#define BIT_TXBCN0ERR_8197F BIT(26)
#define BIT_TXBCN0OK_8197F BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8197F BIT(24)
#define BIT_BCNDMAINT0_8197F BIT(20)
#define BIT_BCNDERR0_8197F BIT(16)
#define BIT_HSISR_IND_ON_INT_8197F BIT(15)
#define BIT_HISR3_IND_INT_8197F BIT(14)
#define BIT_HISR2_IND_INT_8197F BIT(13)
#define BIT_CTWEND_8197F BIT(12)
#define BIT_HISR1_IND_INT_8197F BIT(11)
#define BIT_C2HCMD_8197F BIT(10)
#define BIT_CPWM2_8197F BIT(9)
#define BIT_CPWM_8197F BIT(8)
#define BIT_HIGHDOK_8197F BIT(7)
#define BIT_MGTDOK_8197F BIT(6)
#define BIT_BKDOK_8197F BIT(5)
#define BIT_BEDOK_8197F BIT(4)
#define BIT_VIDOK_8197F BIT(3)
#define BIT_VODOK_8197F BIT(2)
#define BIT_RDU_8197F BIT(1)
#define BIT_RXOK_8197F BIT(0)
/* 2 REG_HIMR1_8197F */
#define BIT_BTON_STS_UPDATE_MSK_8197F BIT(29)
#define BIT_MCU_ERR_MASK_8197F BIT(28)
#define BIT_BCNDMAINT7__MSK_8197F BIT(27)
#define BIT_BCNDMAINT6__MSK_8197F BIT(26)
#define BIT_BCNDMAINT5__MSK_8197F BIT(25)
#define BIT_BCNDMAINT4__MSK_8197F BIT(24)
#define BIT_BCNDMAINT3_MSK_8197F BIT(23)
#define BIT_BCNDMAINT2_MSK_8197F BIT(22)
#define BIT_BCNDMAINT1_MSK_8197F BIT(21)
#define BIT_BCNDERR7_MSK_8197F BIT(20)
#define BIT_BCNDERR6_MSK_8197F BIT(19)
#define BIT_BCNDERR5_MSK_8197F BIT(18)
#define BIT_BCNDERR4_MSK_8197F BIT(17)
#define BIT_BCNDERR3_MSK_8197F BIT(16)
#define BIT_BCNDERR2_MSK_8197F BIT(15)
#define BIT_BCNDERR1_MSK_8197F BIT(14)
#define BIT_ATIMEND_E_MSK_8197F BIT(13)
#define BIT_ATIMEND__MSK_8197F BIT(12)
#define BIT_TXERR_MSK_8197F BIT(11)
#define BIT_RXERR_MSK_8197F BIT(10)
#define BIT_TXFOVW_MSK_8197F BIT(9)
#define BIT_FOVW_MSK_8197F BIT(8)
/* 2 REG_HISR1_8197F */
#define BIT_BTON_STS_UPDATE_INT_8197F BIT(29)
#define BIT_MCU_ERR_8197F BIT(28)
#define BIT_BCNDMAINT7_8197F BIT(27)
#define BIT_BCNDMAINT6_8197F BIT(26)
#define BIT_BCNDMAINT5_8197F BIT(25)
#define BIT_BCNDMAINT4_8197F BIT(24)
#define BIT_BCNDMAINT3_8197F BIT(23)
#define BIT_BCNDMAINT2_8197F BIT(22)
#define BIT_BCNDMAINT1_8197F BIT(21)
#define BIT_BCNDERR7_8197F BIT(20)
#define BIT_BCNDERR6_8197F BIT(19)
#define BIT_BCNDERR5_8197F BIT(18)
#define BIT_BCNDERR4_8197F BIT(17)
#define BIT_BCNDERR3_8197F BIT(16)
#define BIT_BCNDERR2_8197F BIT(15)
#define BIT_BCNDERR1_8197F BIT(14)
#define BIT_ATIMEND_E_8197F BIT(13)
#define BIT_ATIMEND_8197F BIT(12)
#define BIT_TXERR_INT_8197F BIT(11)
#define BIT_RXERR_INT_8197F BIT(10)
#define BIT_TXFOVW_8197F BIT(9)
#define BIT_FOVW_8197F BIT(8)
/* 2 REG_DBG_PORT_SEL_8197F */
#define BIT_SHIFT_DEBUG_ST_8197F 0
#define BIT_MASK_DEBUG_ST_8197F 0xffffffffL
#define BIT_DEBUG_ST_8197F(x) \
(((x) & BIT_MASK_DEBUG_ST_8197F) << BIT_SHIFT_DEBUG_ST_8197F)
#define BITS_DEBUG_ST_8197F \
(BIT_MASK_DEBUG_ST_8197F << BIT_SHIFT_DEBUG_ST_8197F)
#define BIT_CLEAR_DEBUG_ST_8197F(x) ((x) & (~BITS_DEBUG_ST_8197F))
#define BIT_GET_DEBUG_ST_8197F(x) \
(((x) >> BIT_SHIFT_DEBUG_ST_8197F) & BIT_MASK_DEBUG_ST_8197F)
#define BIT_SET_DEBUG_ST_8197F(x, v) \
(BIT_CLEAR_DEBUG_ST_8197F(x) | BIT_DEBUG_ST_8197F(v))
/* 2 REG_PAD_CTRL2_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_LD_B12V_EN_V1_8197F BIT(7)
#define BIT_EECS_IOSEL_V1_8197F BIT(6)
#define BIT_EECS_DATA_O_V1_8197F BIT(5)
#define BIT_EECS_DATA_I_V1_8197F BIT(4)
#define BIT_EESK_IOSEL_V1_8197F BIT(2)
#define BIT_EESK_DATA_O_V1_8197F BIT(1)
#define BIT_EESK_DATA_I_V1_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_PMC_DBG_CTRL2_8197F */
#define BIT_SHIFT_EFUSE_BURN_GNT_8197F 24
#define BIT_MASK_EFUSE_BURN_GNT_8197F 0xff
#define BIT_EFUSE_BURN_GNT_8197F(x) \
(((x) & BIT_MASK_EFUSE_BURN_GNT_8197F) \
<< BIT_SHIFT_EFUSE_BURN_GNT_8197F)
#define BITS_EFUSE_BURN_GNT_8197F \
(BIT_MASK_EFUSE_BURN_GNT_8197F << BIT_SHIFT_EFUSE_BURN_GNT_8197F)
#define BIT_CLEAR_EFUSE_BURN_GNT_8197F(x) ((x) & (~BITS_EFUSE_BURN_GNT_8197F))
#define BIT_GET_EFUSE_BURN_GNT_8197F(x) \
(((x) >> BIT_SHIFT_EFUSE_BURN_GNT_8197F) & \
BIT_MASK_EFUSE_BURN_GNT_8197F)
#define BIT_SET_EFUSE_BURN_GNT_8197F(x, v) \
(BIT_CLEAR_EFUSE_BURN_GNT_8197F(x) | BIT_EFUSE_BURN_GNT_8197F(v))
#define BIT_STOP_WL_PMC_8197F BIT(9)
#define BIT_STOP_SYM_PMC_8197F BIT(8)
#define BIT_REG_RST_WLPMC_8197F BIT(5)
#define BIT_REG_RST_PD12N_8197F BIT(4)
#define BIT_SYSON_DIS_WLREG_WRMSK_8197F BIT(3)
#define BIT_SYSON_DIS_PMCREG_WRMSK_8197F BIT(2)
#define BIT_SHIFT_SYSON_REG_ARB_8197F 0
#define BIT_MASK_SYSON_REG_ARB_8197F 0x3
#define BIT_SYSON_REG_ARB_8197F(x) \
(((x) & BIT_MASK_SYSON_REG_ARB_8197F) << BIT_SHIFT_SYSON_REG_ARB_8197F)
#define BITS_SYSON_REG_ARB_8197F \
(BIT_MASK_SYSON_REG_ARB_8197F << BIT_SHIFT_SYSON_REG_ARB_8197F)
#define BIT_CLEAR_SYSON_REG_ARB_8197F(x) ((x) & (~BITS_SYSON_REG_ARB_8197F))
#define BIT_GET_SYSON_REG_ARB_8197F(x) \
(((x) >> BIT_SHIFT_SYSON_REG_ARB_8197F) & BIT_MASK_SYSON_REG_ARB_8197F)
#define BIT_SET_SYSON_REG_ARB_8197F(x, v) \
(BIT_CLEAR_SYSON_REG_ARB_8197F(x) | BIT_SYSON_REG_ARB_8197F(v))
/* 2 REG_BIST_CTRL_8197F */
#define BIT_BIST_USB_DIS_8197F BIT(27)
#define BIT_BIST_PCI_DIS_8197F BIT(26)
#define BIT_BIST_BT_DIS_8197F BIT(25)
#define BIT_BIST_WL_DIS_8197F BIT(24)
#define BIT_SHIFT_BIST_RPT_SEL_8197F 16
#define BIT_MASK_BIST_RPT_SEL_8197F 0xf
#define BIT_BIST_RPT_SEL_8197F(x) \
(((x) & BIT_MASK_BIST_RPT_SEL_8197F) << BIT_SHIFT_BIST_RPT_SEL_8197F)
#define BITS_BIST_RPT_SEL_8197F \
(BIT_MASK_BIST_RPT_SEL_8197F << BIT_SHIFT_BIST_RPT_SEL_8197F)
#define BIT_CLEAR_BIST_RPT_SEL_8197F(x) ((x) & (~BITS_BIST_RPT_SEL_8197F))
#define BIT_GET_BIST_RPT_SEL_8197F(x) \
(((x) >> BIT_SHIFT_BIST_RPT_SEL_8197F) & BIT_MASK_BIST_RPT_SEL_8197F)
#define BIT_SET_BIST_RPT_SEL_8197F(x, v) \
(BIT_CLEAR_BIST_RPT_SEL_8197F(x) | BIT_BIST_RPT_SEL_8197F(v))
#define BIT_BIST_RESUME_PS_8197F BIT(4)
#define BIT_BIST_RESUME_8197F BIT(3)
#define BIT_BIST_NORMAL_8197F BIT(2)
#define BIT_BIST_RSTN_8197F BIT(1)
#define BIT_BIST_CLK_EN_8197F BIT(0)
/* 2 REG_BIST_RPT_8197F */
#define BIT_SHIFT_MBIST_REPORT_8197F 0
#define BIT_MASK_MBIST_REPORT_8197F 0xffffffffL
#define BIT_MBIST_REPORT_8197F(x) \
(((x) & BIT_MASK_MBIST_REPORT_8197F) << BIT_SHIFT_MBIST_REPORT_8197F)
#define BITS_MBIST_REPORT_8197F \
(BIT_MASK_MBIST_REPORT_8197F << BIT_SHIFT_MBIST_REPORT_8197F)
#define BIT_CLEAR_MBIST_REPORT_8197F(x) ((x) & (~BITS_MBIST_REPORT_8197F))
#define BIT_GET_MBIST_REPORT_8197F(x) \
(((x) >> BIT_SHIFT_MBIST_REPORT_8197F) & BIT_MASK_MBIST_REPORT_8197F)
#define BIT_SET_MBIST_REPORT_8197F(x, v) \
(BIT_CLEAR_MBIST_REPORT_8197F(x) | BIT_MBIST_REPORT_8197F(v))
/* 2 REG_MEM_CTRL_8197F */
#define BIT_UMEM_RME_8197F BIT(31)
#define BIT_SHIFT_BT_SPRAM_8197F 28
#define BIT_MASK_BT_SPRAM_8197F 0x3
#define BIT_BT_SPRAM_8197F(x) \
(((x) & BIT_MASK_BT_SPRAM_8197F) << BIT_SHIFT_BT_SPRAM_8197F)
#define BITS_BT_SPRAM_8197F \
(BIT_MASK_BT_SPRAM_8197F << BIT_SHIFT_BT_SPRAM_8197F)
#define BIT_CLEAR_BT_SPRAM_8197F(x) ((x) & (~BITS_BT_SPRAM_8197F))
#define BIT_GET_BT_SPRAM_8197F(x) \
(((x) >> BIT_SHIFT_BT_SPRAM_8197F) & BIT_MASK_BT_SPRAM_8197F)
#define BIT_SET_BT_SPRAM_8197F(x, v) \
(BIT_CLEAR_BT_SPRAM_8197F(x) | BIT_BT_SPRAM_8197F(v))
#define BIT_SHIFT_BT_ROM_8197F 24
#define BIT_MASK_BT_ROM_8197F 0xf
#define BIT_BT_ROM_8197F(x) \
(((x) & BIT_MASK_BT_ROM_8197F) << BIT_SHIFT_BT_ROM_8197F)
#define BITS_BT_ROM_8197F (BIT_MASK_BT_ROM_8197F << BIT_SHIFT_BT_ROM_8197F)
#define BIT_CLEAR_BT_ROM_8197F(x) ((x) & (~BITS_BT_ROM_8197F))
#define BIT_GET_BT_ROM_8197F(x) \
(((x) >> BIT_SHIFT_BT_ROM_8197F) & BIT_MASK_BT_ROM_8197F)
#define BIT_SET_BT_ROM_8197F(x, v) \
(BIT_CLEAR_BT_ROM_8197F(x) | BIT_BT_ROM_8197F(v))
#define BIT_SHIFT_PCI_DPRAM_8197F 10
#define BIT_MASK_PCI_DPRAM_8197F 0x3
#define BIT_PCI_DPRAM_8197F(x) \
(((x) & BIT_MASK_PCI_DPRAM_8197F) << BIT_SHIFT_PCI_DPRAM_8197F)
#define BITS_PCI_DPRAM_8197F \
(BIT_MASK_PCI_DPRAM_8197F << BIT_SHIFT_PCI_DPRAM_8197F)
#define BIT_CLEAR_PCI_DPRAM_8197F(x) ((x) & (~BITS_PCI_DPRAM_8197F))
#define BIT_GET_PCI_DPRAM_8197F(x) \
(((x) >> BIT_SHIFT_PCI_DPRAM_8197F) & BIT_MASK_PCI_DPRAM_8197F)
#define BIT_SET_PCI_DPRAM_8197F(x, v) \
(BIT_CLEAR_PCI_DPRAM_8197F(x) | BIT_PCI_DPRAM_8197F(v))
#define BIT_SHIFT_PCI_SPRAM_8197F 8
#define BIT_MASK_PCI_SPRAM_8197F 0x3
#define BIT_PCI_SPRAM_8197F(x) \
(((x) & BIT_MASK_PCI_SPRAM_8197F) << BIT_SHIFT_PCI_SPRAM_8197F)
#define BITS_PCI_SPRAM_8197F \
(BIT_MASK_PCI_SPRAM_8197F << BIT_SHIFT_PCI_SPRAM_8197F)
#define BIT_CLEAR_PCI_SPRAM_8197F(x) ((x) & (~BITS_PCI_SPRAM_8197F))
#define BIT_GET_PCI_SPRAM_8197F(x) \
(((x) >> BIT_SHIFT_PCI_SPRAM_8197F) & BIT_MASK_PCI_SPRAM_8197F)
#define BIT_SET_PCI_SPRAM_8197F(x, v) \
(BIT_CLEAR_PCI_SPRAM_8197F(x) | BIT_PCI_SPRAM_8197F(v))
#define BIT_SHIFT_USB_SPRAM_8197F 6
#define BIT_MASK_USB_SPRAM_8197F 0x3
#define BIT_USB_SPRAM_8197F(x) \
(((x) & BIT_MASK_USB_SPRAM_8197F) << BIT_SHIFT_USB_SPRAM_8197F)
#define BITS_USB_SPRAM_8197F \
(BIT_MASK_USB_SPRAM_8197F << BIT_SHIFT_USB_SPRAM_8197F)
#define BIT_CLEAR_USB_SPRAM_8197F(x) ((x) & (~BITS_USB_SPRAM_8197F))
#define BIT_GET_USB_SPRAM_8197F(x) \
(((x) >> BIT_SHIFT_USB_SPRAM_8197F) & BIT_MASK_USB_SPRAM_8197F)
#define BIT_SET_USB_SPRAM_8197F(x, v) \
(BIT_CLEAR_USB_SPRAM_8197F(x) | BIT_USB_SPRAM_8197F(v))
#define BIT_SHIFT_USB_SPRF_8197F 4
#define BIT_MASK_USB_SPRF_8197F 0x3
#define BIT_USB_SPRF_8197F(x) \
(((x) & BIT_MASK_USB_SPRF_8197F) << BIT_SHIFT_USB_SPRF_8197F)
#define BITS_USB_SPRF_8197F \
(BIT_MASK_USB_SPRF_8197F << BIT_SHIFT_USB_SPRF_8197F)
#define BIT_CLEAR_USB_SPRF_8197F(x) ((x) & (~BITS_USB_SPRF_8197F))
#define BIT_GET_USB_SPRF_8197F(x) \
(((x) >> BIT_SHIFT_USB_SPRF_8197F) & BIT_MASK_USB_SPRF_8197F)
#define BIT_SET_USB_SPRF_8197F(x, v) \
(BIT_CLEAR_USB_SPRF_8197F(x) | BIT_USB_SPRF_8197F(v))
#define BIT_SHIFT_MCU_ROM_8197F 0
#define BIT_MASK_MCU_ROM_8197F 0xf
#define BIT_MCU_ROM_8197F(x) \
(((x) & BIT_MASK_MCU_ROM_8197F) << BIT_SHIFT_MCU_ROM_8197F)
#define BITS_MCU_ROM_8197F (BIT_MASK_MCU_ROM_8197F << BIT_SHIFT_MCU_ROM_8197F)
#define BIT_CLEAR_MCU_ROM_8197F(x) ((x) & (~BITS_MCU_ROM_8197F))
#define BIT_GET_MCU_ROM_8197F(x) \
(((x) >> BIT_SHIFT_MCU_ROM_8197F) & BIT_MASK_MCU_ROM_8197F)
#define BIT_SET_MCU_ROM_8197F(x, v) \
(BIT_CLEAR_MCU_ROM_8197F(x) | BIT_MCU_ROM_8197F(v))
/* 2 REG_AFE_CTRL8_8197F */
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4_8197F 26
#define BIT_MASK_BB_DBG_SEL_AFE_SDM_V4_8197F 0x7
#define BIT_BB_DBG_SEL_AFE_SDM_V4_8197F(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM_V4_8197F) \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4_8197F)
#define BITS_BB_DBG_SEL_AFE_SDM_V4_8197F \
(BIT_MASK_BB_DBG_SEL_AFE_SDM_V4_8197F \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4_8197F)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM_V4_8197F(x) \
((x) & (~BITS_BB_DBG_SEL_AFE_SDM_V4_8197F))
#define BIT_GET_BB_DBG_SEL_AFE_SDM_V4_8197F(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM_V4_8197F) & \
BIT_MASK_BB_DBG_SEL_AFE_SDM_V4_8197F)
#define BIT_SET_BB_DBG_SEL_AFE_SDM_V4_8197F(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM_V4_8197F(x) | \
BIT_BB_DBG_SEL_AFE_SDM_V4_8197F(v))
#define BIT_SYN_AGPIO_8197F BIT(20)
#define BIT_SHIFT_XTAL_SEL_TOK_V2_8197F 0
#define BIT_MASK_XTAL_SEL_TOK_V2_8197F 0x7
#define BIT_XTAL_SEL_TOK_V2_8197F(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_V2_8197F) \
<< BIT_SHIFT_XTAL_SEL_TOK_V2_8197F)
#define BITS_XTAL_SEL_TOK_V2_8197F \
(BIT_MASK_XTAL_SEL_TOK_V2_8197F << BIT_SHIFT_XTAL_SEL_TOK_V2_8197F)
#define BIT_CLEAR_XTAL_SEL_TOK_V2_8197F(x) ((x) & (~BITS_XTAL_SEL_TOK_V2_8197F))
#define BIT_GET_XTAL_SEL_TOK_V2_8197F(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_V2_8197F) & \
BIT_MASK_XTAL_SEL_TOK_V2_8197F)
#define BIT_SET_XTAL_SEL_TOK_V2_8197F(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_V2_8197F(x) | BIT_XTAL_SEL_TOK_V2_8197F(v))
/* 2 REG_USB_SIE_INTF_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_PCIE_MIO_INTF_8197F */
#define BIT_PCIE_MIO_BYIOREG_8197F BIT(13)
#define BIT_PCIE_MIO_RE_8197F BIT(12)
#define BIT_SHIFT_PCIE_MIO_WE_8197F 8
#define BIT_MASK_PCIE_MIO_WE_8197F 0xf
#define BIT_PCIE_MIO_WE_8197F(x) \
(((x) & BIT_MASK_PCIE_MIO_WE_8197F) << BIT_SHIFT_PCIE_MIO_WE_8197F)
#define BITS_PCIE_MIO_WE_8197F \
(BIT_MASK_PCIE_MIO_WE_8197F << BIT_SHIFT_PCIE_MIO_WE_8197F)
#define BIT_CLEAR_PCIE_MIO_WE_8197F(x) ((x) & (~BITS_PCIE_MIO_WE_8197F))
#define BIT_GET_PCIE_MIO_WE_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_WE_8197F) & BIT_MASK_PCIE_MIO_WE_8197F)
#define BIT_SET_PCIE_MIO_WE_8197F(x, v) \
(BIT_CLEAR_PCIE_MIO_WE_8197F(x) | BIT_PCIE_MIO_WE_8197F(v))
#define BIT_SHIFT_PCIE_MIO_ADDR_8197F 0
#define BIT_MASK_PCIE_MIO_ADDR_8197F 0xff
#define BIT_PCIE_MIO_ADDR_8197F(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_8197F) << BIT_SHIFT_PCIE_MIO_ADDR_8197F)
#define BITS_PCIE_MIO_ADDR_8197F \
(BIT_MASK_PCIE_MIO_ADDR_8197F << BIT_SHIFT_PCIE_MIO_ADDR_8197F)
#define BIT_CLEAR_PCIE_MIO_ADDR_8197F(x) ((x) & (~BITS_PCIE_MIO_ADDR_8197F))
#define BIT_GET_PCIE_MIO_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_8197F) & BIT_MASK_PCIE_MIO_ADDR_8197F)
#define BIT_SET_PCIE_MIO_ADDR_8197F(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_8197F(x) | BIT_PCIE_MIO_ADDR_8197F(v))
/* 2 REG_PCIE_MIO_INTD_8197F */
#define BIT_SHIFT_PCIE_MIO_DATA_8197F 0
#define BIT_MASK_PCIE_MIO_DATA_8197F 0xffffffffL
#define BIT_PCIE_MIO_DATA_8197F(x) \
(((x) & BIT_MASK_PCIE_MIO_DATA_8197F) << BIT_SHIFT_PCIE_MIO_DATA_8197F)
#define BITS_PCIE_MIO_DATA_8197F \
(BIT_MASK_PCIE_MIO_DATA_8197F << BIT_SHIFT_PCIE_MIO_DATA_8197F)
#define BIT_CLEAR_PCIE_MIO_DATA_8197F(x) ((x) & (~BITS_PCIE_MIO_DATA_8197F))
#define BIT_GET_PCIE_MIO_DATA_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_DATA_8197F) & BIT_MASK_PCIE_MIO_DATA_8197F)
#define BIT_SET_PCIE_MIO_DATA_8197F(x, v) \
(BIT_CLEAR_PCIE_MIO_DATA_8197F(x) | BIT_PCIE_MIO_DATA_8197F(v))
/* 2 REG_WLRF1_8197F */
/* 2 REG_SYS_CFG1_8197F */
#define BIT_SHIFT_TRP_ICFG_8197F 28
#define BIT_MASK_TRP_ICFG_8197F 0xf
#define BIT_TRP_ICFG_8197F(x) \
(((x) & BIT_MASK_TRP_ICFG_8197F) << BIT_SHIFT_TRP_ICFG_8197F)
#define BITS_TRP_ICFG_8197F \
(BIT_MASK_TRP_ICFG_8197F << BIT_SHIFT_TRP_ICFG_8197F)
#define BIT_CLEAR_TRP_ICFG_8197F(x) ((x) & (~BITS_TRP_ICFG_8197F))
#define BIT_GET_TRP_ICFG_8197F(x) \
(((x) >> BIT_SHIFT_TRP_ICFG_8197F) & BIT_MASK_TRP_ICFG_8197F)
#define BIT_SET_TRP_ICFG_8197F(x, v) \
(BIT_CLEAR_TRP_ICFG_8197F(x) | BIT_TRP_ICFG_8197F(v))
#define BIT_RF_TYPE_ID_8197F BIT(27)
#define BIT_BD_HCI_SEL_8197F BIT(26)
#define BIT_BD_PKG_SEL_8197F BIT(25)
#define BIT_SPSLDO_SEL_8197F BIT(24)
#define BIT_RTL_ID_8197F BIT(23)
#define BIT_PAD_HWPD_IDN_8197F BIT(22)
#define BIT_TESTMODE_8197F BIT(20)
#define BIT_SHIFT_VENDOR_ID_8197F 16
#define BIT_MASK_VENDOR_ID_8197F 0xf
#define BIT_VENDOR_ID_8197F(x) \
(((x) & BIT_MASK_VENDOR_ID_8197F) << BIT_SHIFT_VENDOR_ID_8197F)
#define BITS_VENDOR_ID_8197F \
(BIT_MASK_VENDOR_ID_8197F << BIT_SHIFT_VENDOR_ID_8197F)
#define BIT_CLEAR_VENDOR_ID_8197F(x) ((x) & (~BITS_VENDOR_ID_8197F))
#define BIT_GET_VENDOR_ID_8197F(x) \
(((x) >> BIT_SHIFT_VENDOR_ID_8197F) & BIT_MASK_VENDOR_ID_8197F)
#define BIT_SET_VENDOR_ID_8197F(x, v) \
(BIT_CLEAR_VENDOR_ID_8197F(x) | BIT_VENDOR_ID_8197F(v))
#define BIT_SHIFT_CHIP_VER_8197F 12
#define BIT_MASK_CHIP_VER_8197F 0xf
#define BIT_CHIP_VER_8197F(x) \
(((x) & BIT_MASK_CHIP_VER_8197F) << BIT_SHIFT_CHIP_VER_8197F)
#define BITS_CHIP_VER_8197F \
(BIT_MASK_CHIP_VER_8197F << BIT_SHIFT_CHIP_VER_8197F)
#define BIT_CLEAR_CHIP_VER_8197F(x) ((x) & (~BITS_CHIP_VER_8197F))
#define BIT_GET_CHIP_VER_8197F(x) \
(((x) >> BIT_SHIFT_CHIP_VER_8197F) & BIT_MASK_CHIP_VER_8197F)
#define BIT_SET_CHIP_VER_8197F(x, v) \
(BIT_CLEAR_CHIP_VER_8197F(x) | BIT_CHIP_VER_8197F(v))
#define BIT_BD_MAC1_8197F BIT(10)
#define BIT_BD_MAC2_8197F BIT(9)
#define BIT_SIC_IDLE_8197F BIT(8)
#define BIT_SW_OFFLOAD_EN_8197F BIT(7)
#define BIT_OCP_SHUTDN_8197F BIT(6)
#define BIT_V15_VLD_8197F BIT(5)
#define BIT_PCIRSTB_8197F BIT(4)
#define BIT_PCLK_VLD_8197F BIT(3)
#define BIT_UCLK_VLD_8197F BIT(2)
#define BIT_ACLK_VLD_8197F BIT(1)
#define BIT_XCLK_VLD_8197F BIT(0)
/* 2 REG_SYS_STATUS1_8197F */
#define BIT_SHIFT_RF_RL_ID_8197F 28
#define BIT_MASK_RF_RL_ID_8197F 0xf
#define BIT_RF_RL_ID_8197F(x) \
(((x) & BIT_MASK_RF_RL_ID_8197F) << BIT_SHIFT_RF_RL_ID_8197F)
#define BITS_RF_RL_ID_8197F \
(BIT_MASK_RF_RL_ID_8197F << BIT_SHIFT_RF_RL_ID_8197F)
#define BIT_CLEAR_RF_RL_ID_8197F(x) ((x) & (~BITS_RF_RL_ID_8197F))
#define BIT_GET_RF_RL_ID_8197F(x) \
(((x) >> BIT_SHIFT_RF_RL_ID_8197F) & BIT_MASK_RF_RL_ID_8197F)
#define BIT_SET_RF_RL_ID_8197F(x, v) \
(BIT_CLEAR_RF_RL_ID_8197F(x) | BIT_RF_RL_ID_8197F(v))
#define BIT_HPHY_ICFG_8197F BIT(19)
#define BIT_SHIFT_SEL_0XC0_8197F 16
#define BIT_MASK_SEL_0XC0_8197F 0x3
#define BIT_SEL_0XC0_8197F(x) \
(((x) & BIT_MASK_SEL_0XC0_8197F) << BIT_SHIFT_SEL_0XC0_8197F)
#define BITS_SEL_0XC0_8197F \
(BIT_MASK_SEL_0XC0_8197F << BIT_SHIFT_SEL_0XC0_8197F)
#define BIT_CLEAR_SEL_0XC0_8197F(x) ((x) & (~BITS_SEL_0XC0_8197F))
#define BIT_GET_SEL_0XC0_8197F(x) \
(((x) >> BIT_SHIFT_SEL_0XC0_8197F) & BIT_MASK_SEL_0XC0_8197F)
#define BIT_SET_SEL_0XC0_8197F(x, v) \
(BIT_CLEAR_SEL_0XC0_8197F(x) | BIT_SEL_0XC0_8197F(v))
#define BIT_USB_OPERATION_MODE_8197F BIT(10)
#define BIT_BT_PDN_8197F BIT(9)
#define BIT_AUTO_WLPON_8197F BIT(8)
#define BIT_WL_MODE_8197F BIT(7)
#define BIT_PKG_SEL_HCI_8197F BIT(6)
#define BIT_SHIFT_HCI_SEL_8197F 4
#define BIT_MASK_HCI_SEL_8197F 0x3
#define BIT_HCI_SEL_8197F(x) \
(((x) & BIT_MASK_HCI_SEL_8197F) << BIT_SHIFT_HCI_SEL_8197F)
#define BITS_HCI_SEL_8197F (BIT_MASK_HCI_SEL_8197F << BIT_SHIFT_HCI_SEL_8197F)
#define BIT_CLEAR_HCI_SEL_8197F(x) ((x) & (~BITS_HCI_SEL_8197F))
#define BIT_GET_HCI_SEL_8197F(x) \
(((x) >> BIT_SHIFT_HCI_SEL_8197F) & BIT_MASK_HCI_SEL_8197F)
#define BIT_SET_HCI_SEL_8197F(x, v) \
(BIT_CLEAR_HCI_SEL_8197F(x) | BIT_HCI_SEL_8197F(v))
#define BIT_SHIFT_PAD_HCI_SEL_8197F 2
#define BIT_MASK_PAD_HCI_SEL_8197F 0x3
#define BIT_PAD_HCI_SEL_8197F(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_8197F) << BIT_SHIFT_PAD_HCI_SEL_8197F)
#define BITS_PAD_HCI_SEL_8197F \
(BIT_MASK_PAD_HCI_SEL_8197F << BIT_SHIFT_PAD_HCI_SEL_8197F)
#define BIT_CLEAR_PAD_HCI_SEL_8197F(x) ((x) & (~BITS_PAD_HCI_SEL_8197F))
#define BIT_GET_PAD_HCI_SEL_8197F(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_8197F) & BIT_MASK_PAD_HCI_SEL_8197F)
#define BIT_SET_PAD_HCI_SEL_8197F(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_8197F(x) | BIT_PAD_HCI_SEL_8197F(v))
#define BIT_SHIFT_EFS_HCI_SEL_8197F 0
#define BIT_MASK_EFS_HCI_SEL_8197F 0x3
#define BIT_EFS_HCI_SEL_8197F(x) \
(((x) & BIT_MASK_EFS_HCI_SEL_8197F) << BIT_SHIFT_EFS_HCI_SEL_8197F)
#define BITS_EFS_HCI_SEL_8197F \
(BIT_MASK_EFS_HCI_SEL_8197F << BIT_SHIFT_EFS_HCI_SEL_8197F)
#define BIT_CLEAR_EFS_HCI_SEL_8197F(x) ((x) & (~BITS_EFS_HCI_SEL_8197F))
#define BIT_GET_EFS_HCI_SEL_8197F(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL_8197F) & BIT_MASK_EFS_HCI_SEL_8197F)
#define BIT_SET_EFS_HCI_SEL_8197F(x, v) \
(BIT_CLEAR_EFS_HCI_SEL_8197F(x) | BIT_EFS_HCI_SEL_8197F(v))
/* 2 REG_SYS_STATUS2_8197F */
#define BIT_SIO_ALDN_8197F BIT(19)
#define BIT_USB_ALDN_8197F BIT(18)
#define BIT_PCI_ALDN_8197F BIT(17)
#define BIT_SYS_ALDN_8197F BIT(16)
#define BIT_SHIFT_EPVID1_8197F 8
#define BIT_MASK_EPVID1_8197F 0xff
#define BIT_EPVID1_8197F(x) \
(((x) & BIT_MASK_EPVID1_8197F) << BIT_SHIFT_EPVID1_8197F)
#define BITS_EPVID1_8197F (BIT_MASK_EPVID1_8197F << BIT_SHIFT_EPVID1_8197F)
#define BIT_CLEAR_EPVID1_8197F(x) ((x) & (~BITS_EPVID1_8197F))
#define BIT_GET_EPVID1_8197F(x) \
(((x) >> BIT_SHIFT_EPVID1_8197F) & BIT_MASK_EPVID1_8197F)
#define BIT_SET_EPVID1_8197F(x, v) \
(BIT_CLEAR_EPVID1_8197F(x) | BIT_EPVID1_8197F(v))
#define BIT_SHIFT_EPVID0_8197F 0
#define BIT_MASK_EPVID0_8197F 0xff
#define BIT_EPVID0_8197F(x) \
(((x) & BIT_MASK_EPVID0_8197F) << BIT_SHIFT_EPVID0_8197F)
#define BITS_EPVID0_8197F (BIT_MASK_EPVID0_8197F << BIT_SHIFT_EPVID0_8197F)
#define BIT_CLEAR_EPVID0_8197F(x) ((x) & (~BITS_EPVID0_8197F))
#define BIT_GET_EPVID0_8197F(x) \
(((x) >> BIT_SHIFT_EPVID0_8197F) & BIT_MASK_EPVID0_8197F)
#define BIT_SET_EPVID0_8197F(x, v) \
(BIT_CLEAR_EPVID0_8197F(x) | BIT_EPVID0_8197F(v))
/* 2 REG_SYS_CFG2_8197F */
#define BIT_SHIFT_HW_ID_8197F 0
#define BIT_MASK_HW_ID_8197F 0xff
#define BIT_HW_ID_8197F(x) \
(((x) & BIT_MASK_HW_ID_8197F) << BIT_SHIFT_HW_ID_8197F)
#define BITS_HW_ID_8197F (BIT_MASK_HW_ID_8197F << BIT_SHIFT_HW_ID_8197F)
#define BIT_CLEAR_HW_ID_8197F(x) ((x) & (~BITS_HW_ID_8197F))
#define BIT_GET_HW_ID_8197F(x) \
(((x) >> BIT_SHIFT_HW_ID_8197F) & BIT_MASK_HW_ID_8197F)
#define BIT_SET_HW_ID_8197F(x, v) \
(BIT_CLEAR_HW_ID_8197F(x) | BIT_HW_ID_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SYS_CFG3_8197F */
/* 2 REG_SYS_CFG4_8197F */
/* 2 REG_CPU_DMEM_CON_8197F */
#define BIT_ANA_PORT_IDLE_8197F BIT(18)
#define BIT_MAC_PORT_IDLE_8197F BIT(17)
#define BIT_WL_PLATFORM_RST_8197F BIT(16)
#define BIT_WL_SECURITY_CLK_8197F BIT(15)
#define BIT_SHIFT_CPU_DMEM_CON_8197F 0
#define BIT_MASK_CPU_DMEM_CON_8197F 0xff
#define BIT_CPU_DMEM_CON_8197F(x) \
(((x) & BIT_MASK_CPU_DMEM_CON_8197F) << BIT_SHIFT_CPU_DMEM_CON_8197F)
#define BITS_CPU_DMEM_CON_8197F \
(BIT_MASK_CPU_DMEM_CON_8197F << BIT_SHIFT_CPU_DMEM_CON_8197F)
#define BIT_CLEAR_CPU_DMEM_CON_8197F(x) ((x) & (~BITS_CPU_DMEM_CON_8197F))
#define BIT_GET_CPU_DMEM_CON_8197F(x) \
(((x) >> BIT_SHIFT_CPU_DMEM_CON_8197F) & BIT_MASK_CPU_DMEM_CON_8197F)
#define BIT_SET_CPU_DMEM_CON_8197F(x, v) \
(BIT_CLEAR_CPU_DMEM_CON_8197F(x) | BIT_CPU_DMEM_CON_8197F(v))
/* 2 REG_HIMR2_8197F */
#define BIT_BCNDMAINT_P4_MSK_8197F BIT(31)
#define BIT_BCNDMAINT_P3_MSK_8197F BIT(30)
#define BIT_BCNDMAINT_P2_MSK_8197F BIT(29)
#define BIT_BCNDMAINT_P1_MSK_8197F BIT(28)
#define BIT_ATIMEND7_MSK_8197F BIT(22)
#define BIT_ATIMEND6_MSK_8197F BIT(21)
#define BIT_ATIMEND5_MSK_8197F BIT(20)
#define BIT_ATIMEND4_MSK_8197F BIT(19)
#define BIT_ATIMEND3_MSK_8197F BIT(18)
#define BIT_ATIMEND2_MSK_8197F BIT(17)
#define BIT_ATIMEND1_MSK_8197F BIT(16)
#define BIT_TXBCN7OK_MSK_8197F BIT(14)
#define BIT_TXBCN6OK_MSK_8197F BIT(13)
#define BIT_TXBCN5OK_MSK_8197F BIT(12)
#define BIT_TXBCN4OK_MSK_8197F BIT(11)
#define BIT_TXBCN3OK_MSK_8197F BIT(10)
#define BIT_TXBCN2OK_MSK_8197F BIT(9)
#define BIT_TXBCN1OK_MSK_V1_8197F BIT(8)
#define BIT_TXBCN7ERR_MSK_8197F BIT(6)
#define BIT_TXBCN6ERR_MSK_8197F BIT(5)
#define BIT_TXBCN5ERR_MSK_8197F BIT(4)
#define BIT_TXBCN4ERR_MSK_8197F BIT(3)
#define BIT_TXBCN3ERR_MSK_8197F BIT(2)
#define BIT_TXBCN2ERR_MSK_8197F BIT(1)
#define BIT_TXBCN1ERR_MSK_V1_8197F BIT(0)
/* 2 REG_HISR2_8197F */
#define BIT_BCNDMAINT_P4_8197F BIT(31)
#define BIT_BCNDMAINT_P3_8197F BIT(30)
#define BIT_BCNDMAINT_P2_8197F BIT(29)
#define BIT_BCNDMAINT_P1_8197F BIT(28)
#define BIT_ATIMEND7_8197F BIT(22)
#define BIT_ATIMEND6_8197F BIT(21)
#define BIT_ATIMEND5_8197F BIT(20)
#define BIT_ATIMEND4_8197F BIT(19)
#define BIT_ATIMEND3_8197F BIT(18)
#define BIT_ATIMEND2_8197F BIT(17)
#define BIT_ATIMEND1_8197F BIT(16)
#define BIT_TXBCN7OK_8197F BIT(14)
#define BIT_TXBCN6OK_8197F BIT(13)
#define BIT_TXBCN5OK_8197F BIT(12)
#define BIT_TXBCN4OK_8197F BIT(11)
#define BIT_TXBCN3OK_8197F BIT(10)
#define BIT_TXBCN2OK_8197F BIT(9)
#define BIT_TXBCN1OK_8197F BIT(8)
#define BIT_TXBCN7ERR_8197F BIT(6)
#define BIT_TXBCN6ERR_8197F BIT(5)
#define BIT_TXBCN5ERR_8197F BIT(4)
#define BIT_TXBCN4ERR_8197F BIT(3)
#define BIT_TXBCN3ERR_8197F BIT(2)
#define BIT_TXBCN2ERR_8197F BIT(1)
#define BIT_TXBCN1ERR_8197F BIT(0)
/* 2 REG_HIMR3_8197F */
#define BIT_SETH2CDOK_MASK_8197F BIT(16)
#define BIT_H2C_CMD_FULL_MASK_8197F BIT(15)
#define BIT_PWR_INT_127_MASK_8197F BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_MASK_8197F BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_MASK_8197F BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_MASK_8197F BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_MAS_8197F BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_MASK_8197F BIT(9)
#define BIT_PWR_INT_127_MASK_V1_8197F BIT(8)
#define BIT_PWR_INT_126TO96_MASK_8197F BIT(7)
#define BIT_PWR_INT_95TO64_MASK_8197F BIT(6)
#define BIT_PWR_INT_63TO32_MASK_8197F BIT(5)
#define BIT_PWR_INT_31TO0_MASK_8197F BIT(4)
#define BIT_DDMA0_LP_INT_MSK_8197F BIT(1)
#define BIT_DDMA0_HP_INT_MSK_8197F BIT(0)
/* 2 REG_HISR3_8197F */
#define BIT_SETH2CDOK_8197F BIT(16)
#define BIT_H2C_CMD_FULL_8197F BIT(15)
#define BIT_PWR_INT_127_8197F BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8197F BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8197F BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8197F BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8197F BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8197F BIT(9)
#define BIT_PWR_INT_127_V1_8197F BIT(8)
#define BIT_PWR_INT_126TO96_8197F BIT(7)
#define BIT_PWR_INT_95TO64_8197F BIT(6)
#define BIT_PWR_INT_63TO32_8197F BIT(5)
#define BIT_PWR_INT_31TO0_8197F BIT(4)
#define BIT_DDMA0_LP_INT_8197F BIT(1)
#define BIT_DDMA0_HP_INT_8197F BIT(0)
/* 2 REG_SW_MDIO_8197F */
/* 2 REG_SW_FLUSH_8197F */
#define BIT_FLUSH_HOLDN_EN_8197F BIT(25)
#define BIT_FLUSH_WR_EN_8197F BIT(24)
#define BIT_SW_FLASH_CONTROL_8197F BIT(23)
#define BIT_SW_FLASH_WEN_E_8197F BIT(19)
#define BIT_SW_FLASH_HOLDN_E_8197F BIT(18)
#define BIT_SW_FLASH_SO_E_8197F BIT(17)
#define BIT_SW_FLASH_SI_E_8197F BIT(16)
#define BIT_SW_FLASH_SK_O_8197F BIT(13)
#define BIT_SW_FLASH_CEN_O_8197F BIT(12)
#define BIT_SW_FLASH_WEN_O_8197F BIT(11)
#define BIT_SW_FLASH_HOLDN_O_8197F BIT(10)
#define BIT_SW_FLASH_SO_O_8197F BIT(9)
#define BIT_SW_FLASH_SI_O_8197F BIT(8)
#define BIT_SW_FLASH_WEN_I_8197F BIT(3)
#define BIT_SW_FLASH_HOLDN_I_8197F BIT(2)
#define BIT_SW_FLASH_SO_I_8197F BIT(1)
#define BIT_SW_FLASH_SI_I_8197F BIT(0)
/* 2 REG_DBG_GPIO_BMUX_8197F */
#define BIT_SHIFT_DBG_GPIO_BMUX_7_8197F 21
#define BIT_MASK_DBG_GPIO_BMUX_7_8197F 0x7
#define BIT_DBG_GPIO_BMUX_7_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_7_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_7_8197F)
#define BITS_DBG_GPIO_BMUX_7_8197F \
(BIT_MASK_DBG_GPIO_BMUX_7_8197F << BIT_SHIFT_DBG_GPIO_BMUX_7_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_7_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_7_8197F))
#define BIT_GET_DBG_GPIO_BMUX_7_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_7_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_7_8197F)
#define BIT_SET_DBG_GPIO_BMUX_7_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_7_8197F(x) | BIT_DBG_GPIO_BMUX_7_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_6_8197F 18
#define BIT_MASK_DBG_GPIO_BMUX_6_8197F 0x7
#define BIT_DBG_GPIO_BMUX_6_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_6_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_6_8197F)
#define BITS_DBG_GPIO_BMUX_6_8197F \
(BIT_MASK_DBG_GPIO_BMUX_6_8197F << BIT_SHIFT_DBG_GPIO_BMUX_6_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_6_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_6_8197F))
#define BIT_GET_DBG_GPIO_BMUX_6_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_6_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_6_8197F)
#define BIT_SET_DBG_GPIO_BMUX_6_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_6_8197F(x) | BIT_DBG_GPIO_BMUX_6_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_5_8197F 15
#define BIT_MASK_DBG_GPIO_BMUX_5_8197F 0x7
#define BIT_DBG_GPIO_BMUX_5_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_5_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_5_8197F)
#define BITS_DBG_GPIO_BMUX_5_8197F \
(BIT_MASK_DBG_GPIO_BMUX_5_8197F << BIT_SHIFT_DBG_GPIO_BMUX_5_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_5_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_5_8197F))
#define BIT_GET_DBG_GPIO_BMUX_5_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_5_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_5_8197F)
#define BIT_SET_DBG_GPIO_BMUX_5_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_5_8197F(x) | BIT_DBG_GPIO_BMUX_5_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_4_8197F 12
#define BIT_MASK_DBG_GPIO_BMUX_4_8197F 0x7
#define BIT_DBG_GPIO_BMUX_4_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_4_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_4_8197F)
#define BITS_DBG_GPIO_BMUX_4_8197F \
(BIT_MASK_DBG_GPIO_BMUX_4_8197F << BIT_SHIFT_DBG_GPIO_BMUX_4_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_4_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_4_8197F))
#define BIT_GET_DBG_GPIO_BMUX_4_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_4_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_4_8197F)
#define BIT_SET_DBG_GPIO_BMUX_4_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_4_8197F(x) | BIT_DBG_GPIO_BMUX_4_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_3_8197F 9
#define BIT_MASK_DBG_GPIO_BMUX_3_8197F 0x7
#define BIT_DBG_GPIO_BMUX_3_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_3_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_3_8197F)
#define BITS_DBG_GPIO_BMUX_3_8197F \
(BIT_MASK_DBG_GPIO_BMUX_3_8197F << BIT_SHIFT_DBG_GPIO_BMUX_3_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_3_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_3_8197F))
#define BIT_GET_DBG_GPIO_BMUX_3_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_3_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_3_8197F)
#define BIT_SET_DBG_GPIO_BMUX_3_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_3_8197F(x) | BIT_DBG_GPIO_BMUX_3_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_2_8197F 6
#define BIT_MASK_DBG_GPIO_BMUX_2_8197F 0x7
#define BIT_DBG_GPIO_BMUX_2_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_2_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_2_8197F)
#define BITS_DBG_GPIO_BMUX_2_8197F \
(BIT_MASK_DBG_GPIO_BMUX_2_8197F << BIT_SHIFT_DBG_GPIO_BMUX_2_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_2_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_2_8197F))
#define BIT_GET_DBG_GPIO_BMUX_2_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_2_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_2_8197F)
#define BIT_SET_DBG_GPIO_BMUX_2_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_2_8197F(x) | BIT_DBG_GPIO_BMUX_2_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_1_8197F 3
#define BIT_MASK_DBG_GPIO_BMUX_1_8197F 0x7
#define BIT_DBG_GPIO_BMUX_1_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_1_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_1_8197F)
#define BITS_DBG_GPIO_BMUX_1_8197F \
(BIT_MASK_DBG_GPIO_BMUX_1_8197F << BIT_SHIFT_DBG_GPIO_BMUX_1_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_1_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_1_8197F))
#define BIT_GET_DBG_GPIO_BMUX_1_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_1_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_1_8197F)
#define BIT_SET_DBG_GPIO_BMUX_1_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_1_8197F(x) | BIT_DBG_GPIO_BMUX_1_8197F(v))
#define BIT_SHIFT_DBG_GPIO_BMUX_0_8197F 0
#define BIT_MASK_DBG_GPIO_BMUX_0_8197F 0x7
#define BIT_DBG_GPIO_BMUX_0_8197F(x) \
(((x) & BIT_MASK_DBG_GPIO_BMUX_0_8197F) \
<< BIT_SHIFT_DBG_GPIO_BMUX_0_8197F)
#define BITS_DBG_GPIO_BMUX_0_8197F \
(BIT_MASK_DBG_GPIO_BMUX_0_8197F << BIT_SHIFT_DBG_GPIO_BMUX_0_8197F)
#define BIT_CLEAR_DBG_GPIO_BMUX_0_8197F(x) ((x) & (~BITS_DBG_GPIO_BMUX_0_8197F))
#define BIT_GET_DBG_GPIO_BMUX_0_8197F(x) \
(((x) >> BIT_SHIFT_DBG_GPIO_BMUX_0_8197F) & \
BIT_MASK_DBG_GPIO_BMUX_0_8197F)
#define BIT_SET_DBG_GPIO_BMUX_0_8197F(x, v) \
(BIT_CLEAR_DBG_GPIO_BMUX_0_8197F(x) | BIT_DBG_GPIO_BMUX_0_8197F(v))
/* 2 REG_FPGA_TAG_8197F (NO USE IN ASIC) */
#define BIT_SHIFT_FPGA_TAG_8197F 0
#define BIT_MASK_FPGA_TAG_8197F 0xffffffffL
#define BIT_FPGA_TAG_8197F(x) \
(((x) & BIT_MASK_FPGA_TAG_8197F) << BIT_SHIFT_FPGA_TAG_8197F)
#define BITS_FPGA_TAG_8197F \
(BIT_MASK_FPGA_TAG_8197F << BIT_SHIFT_FPGA_TAG_8197F)
#define BIT_CLEAR_FPGA_TAG_8197F(x) ((x) & (~BITS_FPGA_TAG_8197F))
#define BIT_GET_FPGA_TAG_8197F(x) \
(((x) >> BIT_SHIFT_FPGA_TAG_8197F) & BIT_MASK_FPGA_TAG_8197F)
#define BIT_SET_FPGA_TAG_8197F(x, v) \
(BIT_CLEAR_FPGA_TAG_8197F(x) | BIT_FPGA_TAG_8197F(v))
/* 2 REG_WL_DSS_CTRL0_8197F */
#define BIT_WL_DSS_RSTN_8197F BIT(27)
#define BIT_WL_DSS_EN_CLK_8197F BIT(26)
#define BIT_WL_DSS_SPEED_EN_8197F BIT(25)
#define BIT_SHIFT_WL_DSS_COUNT_OUT_8197F 0
#define BIT_MASK_WL_DSS_COUNT_OUT_8197F 0xfffff
#define BIT_WL_DSS_COUNT_OUT_8197F(x) \
(((x) & BIT_MASK_WL_DSS_COUNT_OUT_8197F) \
<< BIT_SHIFT_WL_DSS_COUNT_OUT_8197F)
#define BITS_WL_DSS_COUNT_OUT_8197F \
(BIT_MASK_WL_DSS_COUNT_OUT_8197F << BIT_SHIFT_WL_DSS_COUNT_OUT_8197F)
#define BIT_CLEAR_WL_DSS_COUNT_OUT_8197F(x) \
((x) & (~BITS_WL_DSS_COUNT_OUT_8197F))
#define BIT_GET_WL_DSS_COUNT_OUT_8197F(x) \
(((x) >> BIT_SHIFT_WL_DSS_COUNT_OUT_8197F) & \
BIT_MASK_WL_DSS_COUNT_OUT_8197F)
#define BIT_SET_WL_DSS_COUNT_OUT_8197F(x, v) \
(BIT_CLEAR_WL_DSS_COUNT_OUT_8197F(x) | BIT_WL_DSS_COUNT_OUT_8197F(v))
/* 2 REG_WL_DSS_CTRL1_8197F */
#define BIT_WL_DSS_RSTN_8197F BIT(27)
#define BIT_WL_DSS_EN_CLK_8197F BIT(26)
#define BIT_WL_DSS_SPEED_EN_8197F BIT(25)
#define BIT_WL_DSS_WIRE_SEL_8197F BIT(24)
#define BIT_SHIFT_WL_DSS_RO_SEL_8197F 20
#define BIT_MASK_WL_DSS_RO_SEL_8197F 0x7
#define BIT_WL_DSS_RO_SEL_8197F(x) \
(((x) & BIT_MASK_WL_DSS_RO_SEL_8197F) << BIT_SHIFT_WL_DSS_RO_SEL_8197F)
#define BITS_WL_DSS_RO_SEL_8197F \
(BIT_MASK_WL_DSS_RO_SEL_8197F << BIT_SHIFT_WL_DSS_RO_SEL_8197F)
#define BIT_CLEAR_WL_DSS_RO_SEL_8197F(x) ((x) & (~BITS_WL_DSS_RO_SEL_8197F))
#define BIT_GET_WL_DSS_RO_SEL_8197F(x) \
(((x) >> BIT_SHIFT_WL_DSS_RO_SEL_8197F) & BIT_MASK_WL_DSS_RO_SEL_8197F)
#define BIT_SET_WL_DSS_RO_SEL_8197F(x, v) \
(BIT_CLEAR_WL_DSS_RO_SEL_8197F(x) | BIT_WL_DSS_RO_SEL_8197F(v))
#define BIT_SHIFT_WL_DSS_DATA_IN_8197F 0
#define BIT_MASK_WL_DSS_DATA_IN_8197F 0xfffff
#define BIT_WL_DSS_DATA_IN_8197F(x) \
(((x) & BIT_MASK_WL_DSS_DATA_IN_8197F) \
<< BIT_SHIFT_WL_DSS_DATA_IN_8197F)
#define BITS_WL_DSS_DATA_IN_8197F \
(BIT_MASK_WL_DSS_DATA_IN_8197F << BIT_SHIFT_WL_DSS_DATA_IN_8197F)
#define BIT_CLEAR_WL_DSS_DATA_IN_8197F(x) ((x) & (~BITS_WL_DSS_DATA_IN_8197F))
#define BIT_GET_WL_DSS_DATA_IN_8197F(x) \
(((x) >> BIT_SHIFT_WL_DSS_DATA_IN_8197F) & \
BIT_MASK_WL_DSS_DATA_IN_8197F)
#define BIT_SET_WL_DSS_DATA_IN_8197F(x, v) \
(BIT_CLEAR_WL_DSS_DATA_IN_8197F(x) | BIT_WL_DSS_DATA_IN_8197F(v))
/* 2 REG_WL_DSS_STATUS1_8197F */
#define BIT_WL_DSS_READY_8197F BIT(21)
#define BIT_WL_DSS_WSORT_GO_8197F BIT(20)
#define BIT_SHIFT_WL_DSS_COUNT_OUT_8197F 0
#define BIT_MASK_WL_DSS_COUNT_OUT_8197F 0xfffff
#define BIT_WL_DSS_COUNT_OUT_8197F(x) \
(((x) & BIT_MASK_WL_DSS_COUNT_OUT_8197F) \
<< BIT_SHIFT_WL_DSS_COUNT_OUT_8197F)
#define BITS_WL_DSS_COUNT_OUT_8197F \
(BIT_MASK_WL_DSS_COUNT_OUT_8197F << BIT_SHIFT_WL_DSS_COUNT_OUT_8197F)
#define BIT_CLEAR_WL_DSS_COUNT_OUT_8197F(x) \
((x) & (~BITS_WL_DSS_COUNT_OUT_8197F))
#define BIT_GET_WL_DSS_COUNT_OUT_8197F(x) \
(((x) >> BIT_SHIFT_WL_DSS_COUNT_OUT_8197F) & \
BIT_MASK_WL_DSS_COUNT_OUT_8197F)
#define BIT_SET_WL_DSS_COUNT_OUT_8197F(x, v) \
(BIT_CLEAR_WL_DSS_COUNT_OUT_8197F(x) | BIT_WL_DSS_COUNT_OUT_8197F(v))
/* 2 REG_FW_DBG0_8197F */
#define BIT_SHIFT_FW_DBG0_8197F 0
#define BIT_MASK_FW_DBG0_8197F 0xffffffffL
#define BIT_FW_DBG0_8197F(x) \
(((x) & BIT_MASK_FW_DBG0_8197F) << BIT_SHIFT_FW_DBG0_8197F)
#define BITS_FW_DBG0_8197F (BIT_MASK_FW_DBG0_8197F << BIT_SHIFT_FW_DBG0_8197F)
#define BIT_CLEAR_FW_DBG0_8197F(x) ((x) & (~BITS_FW_DBG0_8197F))
#define BIT_GET_FW_DBG0_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG0_8197F) & BIT_MASK_FW_DBG0_8197F)
#define BIT_SET_FW_DBG0_8197F(x, v) \
(BIT_CLEAR_FW_DBG0_8197F(x) | BIT_FW_DBG0_8197F(v))
/* 2 REG_FW_DBG1_8197F */
#define BIT_SHIFT_FW_DBG1_8197F 0
#define BIT_MASK_FW_DBG1_8197F 0xffffffffL
#define BIT_FW_DBG1_8197F(x) \
(((x) & BIT_MASK_FW_DBG1_8197F) << BIT_SHIFT_FW_DBG1_8197F)
#define BITS_FW_DBG1_8197F (BIT_MASK_FW_DBG1_8197F << BIT_SHIFT_FW_DBG1_8197F)
#define BIT_CLEAR_FW_DBG1_8197F(x) ((x) & (~BITS_FW_DBG1_8197F))
#define BIT_GET_FW_DBG1_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG1_8197F) & BIT_MASK_FW_DBG1_8197F)
#define BIT_SET_FW_DBG1_8197F(x, v) \
(BIT_CLEAR_FW_DBG1_8197F(x) | BIT_FW_DBG1_8197F(v))
/* 2 REG_FW_DBG2_8197F */
#define BIT_SHIFT_FW_DBG2_8197F 0
#define BIT_MASK_FW_DBG2_8197F 0xffffffffL
#define BIT_FW_DBG2_8197F(x) \
(((x) & BIT_MASK_FW_DBG2_8197F) << BIT_SHIFT_FW_DBG2_8197F)
#define BITS_FW_DBG2_8197F (BIT_MASK_FW_DBG2_8197F << BIT_SHIFT_FW_DBG2_8197F)
#define BIT_CLEAR_FW_DBG2_8197F(x) ((x) & (~BITS_FW_DBG2_8197F))
#define BIT_GET_FW_DBG2_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG2_8197F) & BIT_MASK_FW_DBG2_8197F)
#define BIT_SET_FW_DBG2_8197F(x, v) \
(BIT_CLEAR_FW_DBG2_8197F(x) | BIT_FW_DBG2_8197F(v))
/* 2 REG_FW_DBG3_8197F */
#define BIT_SHIFT_FW_DBG3_8197F 0
#define BIT_MASK_FW_DBG3_8197F 0xffffffffL
#define BIT_FW_DBG3_8197F(x) \
(((x) & BIT_MASK_FW_DBG3_8197F) << BIT_SHIFT_FW_DBG3_8197F)
#define BITS_FW_DBG3_8197F (BIT_MASK_FW_DBG3_8197F << BIT_SHIFT_FW_DBG3_8197F)
#define BIT_CLEAR_FW_DBG3_8197F(x) ((x) & (~BITS_FW_DBG3_8197F))
#define BIT_GET_FW_DBG3_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG3_8197F) & BIT_MASK_FW_DBG3_8197F)
#define BIT_SET_FW_DBG3_8197F(x, v) \
(BIT_CLEAR_FW_DBG3_8197F(x) | BIT_FW_DBG3_8197F(v))
/* 2 REG_FW_DBG4_8197F */
#define BIT_SHIFT_FW_DBG4_8197F 0
#define BIT_MASK_FW_DBG4_8197F 0xffffffffL
#define BIT_FW_DBG4_8197F(x) \
(((x) & BIT_MASK_FW_DBG4_8197F) << BIT_SHIFT_FW_DBG4_8197F)
#define BITS_FW_DBG4_8197F (BIT_MASK_FW_DBG4_8197F << BIT_SHIFT_FW_DBG4_8197F)
#define BIT_CLEAR_FW_DBG4_8197F(x) ((x) & (~BITS_FW_DBG4_8197F))
#define BIT_GET_FW_DBG4_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG4_8197F) & BIT_MASK_FW_DBG4_8197F)
#define BIT_SET_FW_DBG4_8197F(x, v) \
(BIT_CLEAR_FW_DBG4_8197F(x) | BIT_FW_DBG4_8197F(v))
/* 2 REG_FW_DBG5_8197F */
#define BIT_SHIFT_FW_DBG5_8197F 0
#define BIT_MASK_FW_DBG5_8197F 0xffffffffL
#define BIT_FW_DBG5_8197F(x) \
(((x) & BIT_MASK_FW_DBG5_8197F) << BIT_SHIFT_FW_DBG5_8197F)
#define BITS_FW_DBG5_8197F (BIT_MASK_FW_DBG5_8197F << BIT_SHIFT_FW_DBG5_8197F)
#define BIT_CLEAR_FW_DBG5_8197F(x) ((x) & (~BITS_FW_DBG5_8197F))
#define BIT_GET_FW_DBG5_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG5_8197F) & BIT_MASK_FW_DBG5_8197F)
#define BIT_SET_FW_DBG5_8197F(x, v) \
(BIT_CLEAR_FW_DBG5_8197F(x) | BIT_FW_DBG5_8197F(v))
/* 2 REG_FW_DBG6_8197F */
#define BIT_SHIFT_FW_DBG6_8197F 0
#define BIT_MASK_FW_DBG6_8197F 0xffffffffL
#define BIT_FW_DBG6_8197F(x) \
(((x) & BIT_MASK_FW_DBG6_8197F) << BIT_SHIFT_FW_DBG6_8197F)
#define BITS_FW_DBG6_8197F (BIT_MASK_FW_DBG6_8197F << BIT_SHIFT_FW_DBG6_8197F)
#define BIT_CLEAR_FW_DBG6_8197F(x) ((x) & (~BITS_FW_DBG6_8197F))
#define BIT_GET_FW_DBG6_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG6_8197F) & BIT_MASK_FW_DBG6_8197F)
#define BIT_SET_FW_DBG6_8197F(x, v) \
(BIT_CLEAR_FW_DBG6_8197F(x) | BIT_FW_DBG6_8197F(v))
/* 2 REG_FW_DBG7_8197F */
#define BIT_SHIFT_FW_DBG7_8197F 0
#define BIT_MASK_FW_DBG7_8197F 0xffffffffL
#define BIT_FW_DBG7_8197F(x) \
(((x) & BIT_MASK_FW_DBG7_8197F) << BIT_SHIFT_FW_DBG7_8197F)
#define BITS_FW_DBG7_8197F (BIT_MASK_FW_DBG7_8197F << BIT_SHIFT_FW_DBG7_8197F)
#define BIT_CLEAR_FW_DBG7_8197F(x) ((x) & (~BITS_FW_DBG7_8197F))
#define BIT_GET_FW_DBG7_8197F(x) \
(((x) >> BIT_SHIFT_FW_DBG7_8197F) & BIT_MASK_FW_DBG7_8197F)
#define BIT_SET_FW_DBG7_8197F(x, v) \
(BIT_CLEAR_FW_DBG7_8197F(x) | BIT_FW_DBG7_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_CR_8197F (ENABLE FUNCTION REGISTER) */
#define BIT_MACIO_TIMEOUT_EN_8197F BIT(29)
#define BIT_SHIFT_LBMODE_8197F 24
#define BIT_MASK_LBMODE_8197F 0x1f
#define BIT_LBMODE_8197F(x) \
(((x) & BIT_MASK_LBMODE_8197F) << BIT_SHIFT_LBMODE_8197F)
#define BITS_LBMODE_8197F (BIT_MASK_LBMODE_8197F << BIT_SHIFT_LBMODE_8197F)
#define BIT_CLEAR_LBMODE_8197F(x) ((x) & (~BITS_LBMODE_8197F))
#define BIT_GET_LBMODE_8197F(x) \
(((x) >> BIT_SHIFT_LBMODE_8197F) & BIT_MASK_LBMODE_8197F)
#define BIT_SET_LBMODE_8197F(x, v) \
(BIT_CLEAR_LBMODE_8197F(x) | BIT_LBMODE_8197F(v))
#define BIT_SHIFT_NETYPE1_8197F 18
#define BIT_MASK_NETYPE1_8197F 0x3
#define BIT_NETYPE1_8197F(x) \
(((x) & BIT_MASK_NETYPE1_8197F) << BIT_SHIFT_NETYPE1_8197F)
#define BITS_NETYPE1_8197F (BIT_MASK_NETYPE1_8197F << BIT_SHIFT_NETYPE1_8197F)
#define BIT_CLEAR_NETYPE1_8197F(x) ((x) & (~BITS_NETYPE1_8197F))
#define BIT_GET_NETYPE1_8197F(x) \
(((x) >> BIT_SHIFT_NETYPE1_8197F) & BIT_MASK_NETYPE1_8197F)
#define BIT_SET_NETYPE1_8197F(x, v) \
(BIT_CLEAR_NETYPE1_8197F(x) | BIT_NETYPE1_8197F(v))
#define BIT_SHIFT_NETYPE0_8197F 16
#define BIT_MASK_NETYPE0_8197F 0x3
#define BIT_NETYPE0_8197F(x) \
(((x) & BIT_MASK_NETYPE0_8197F) << BIT_SHIFT_NETYPE0_8197F)
#define BITS_NETYPE0_8197F (BIT_MASK_NETYPE0_8197F << BIT_SHIFT_NETYPE0_8197F)
#define BIT_CLEAR_NETYPE0_8197F(x) ((x) & (~BITS_NETYPE0_8197F))
#define BIT_GET_NETYPE0_8197F(x) \
(((x) >> BIT_SHIFT_NETYPE0_8197F) & BIT_MASK_NETYPE0_8197F)
#define BIT_SET_NETYPE0_8197F(x, v) \
(BIT_CLEAR_NETYPE0_8197F(x) | BIT_NETYPE0_8197F(v))
#define BIT_STAT_FUNC_RST_8197F BIT(13)
#define BIT_I2C_MAILBOX_EN_8197F BIT(12)
#define BIT_SHCUT_EN_8197F BIT(11)
#define BIT_32K_CAL_TMR_EN_8197F BIT(10)
#define BIT_MAC_SEC_EN_8197F BIT(9)
#define BIT_ENSWBCN_8197F BIT(8)
#define BIT_MACRXEN_8197F BIT(7)
#define BIT_MACTXEN_8197F BIT(6)
#define BIT_SCHEDULE_EN_8197F BIT(5)
#define BIT_PROTOCOL_EN_8197F BIT(4)
#define BIT_RXDMA_EN_8197F BIT(3)
#define BIT_TXDMA_EN_8197F BIT(2)
#define BIT_HCI_RXDMA_EN_8197F BIT(1)
#define BIT_HCI_TXDMA_EN_8197F BIT(0)
/* 2 REG_TSF_CLK_STATE_8197F */
#define BIT_TSF_CLK_STABLE_8197F BIT(15)
/* 2 REG_TXDMA_PQ_MAP_8197F */
#define BIT_SHIFT_TXDMA_HIQ_MAP_8197F 14
#define BIT_MASK_TXDMA_HIQ_MAP_8197F 0x3
#define BIT_TXDMA_HIQ_MAP_8197F(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP_8197F) << BIT_SHIFT_TXDMA_HIQ_MAP_8197F)
#define BITS_TXDMA_HIQ_MAP_8197F \
(BIT_MASK_TXDMA_HIQ_MAP_8197F << BIT_SHIFT_TXDMA_HIQ_MAP_8197F)
#define BIT_CLEAR_TXDMA_HIQ_MAP_8197F(x) ((x) & (~BITS_TXDMA_HIQ_MAP_8197F))
#define BIT_GET_TXDMA_HIQ_MAP_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP_8197F) & BIT_MASK_TXDMA_HIQ_MAP_8197F)
#define BIT_SET_TXDMA_HIQ_MAP_8197F(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP_8197F(x) | BIT_TXDMA_HIQ_MAP_8197F(v))
#define BIT_SHIFT_TXDMA_MGQ_MAP_8197F 12
#define BIT_MASK_TXDMA_MGQ_MAP_8197F 0x3
#define BIT_TXDMA_MGQ_MAP_8197F(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP_8197F) << BIT_SHIFT_TXDMA_MGQ_MAP_8197F)
#define BITS_TXDMA_MGQ_MAP_8197F \
(BIT_MASK_TXDMA_MGQ_MAP_8197F << BIT_SHIFT_TXDMA_MGQ_MAP_8197F)
#define BIT_CLEAR_TXDMA_MGQ_MAP_8197F(x) ((x) & (~BITS_TXDMA_MGQ_MAP_8197F))
#define BIT_GET_TXDMA_MGQ_MAP_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP_8197F) & BIT_MASK_TXDMA_MGQ_MAP_8197F)
#define BIT_SET_TXDMA_MGQ_MAP_8197F(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP_8197F(x) | BIT_TXDMA_MGQ_MAP_8197F(v))
#define BIT_SHIFT_TXDMA_BKQ_MAP_8197F 10
#define BIT_MASK_TXDMA_BKQ_MAP_8197F 0x3
#define BIT_TXDMA_BKQ_MAP_8197F(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP_8197F) << BIT_SHIFT_TXDMA_BKQ_MAP_8197F)
#define BITS_TXDMA_BKQ_MAP_8197F \
(BIT_MASK_TXDMA_BKQ_MAP_8197F << BIT_SHIFT_TXDMA_BKQ_MAP_8197F)
#define BIT_CLEAR_TXDMA_BKQ_MAP_8197F(x) ((x) & (~BITS_TXDMA_BKQ_MAP_8197F))
#define BIT_GET_TXDMA_BKQ_MAP_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP_8197F) & BIT_MASK_TXDMA_BKQ_MAP_8197F)
#define BIT_SET_TXDMA_BKQ_MAP_8197F(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP_8197F(x) | BIT_TXDMA_BKQ_MAP_8197F(v))
#define BIT_SHIFT_TXDMA_BEQ_MAP_8197F 8
#define BIT_MASK_TXDMA_BEQ_MAP_8197F 0x3
#define BIT_TXDMA_BEQ_MAP_8197F(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP_8197F) << BIT_SHIFT_TXDMA_BEQ_MAP_8197F)
#define BITS_TXDMA_BEQ_MAP_8197F \
(BIT_MASK_TXDMA_BEQ_MAP_8197F << BIT_SHIFT_TXDMA_BEQ_MAP_8197F)
#define BIT_CLEAR_TXDMA_BEQ_MAP_8197F(x) ((x) & (~BITS_TXDMA_BEQ_MAP_8197F))
#define BIT_GET_TXDMA_BEQ_MAP_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP_8197F) & BIT_MASK_TXDMA_BEQ_MAP_8197F)
#define BIT_SET_TXDMA_BEQ_MAP_8197F(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP_8197F(x) | BIT_TXDMA_BEQ_MAP_8197F(v))
#define BIT_SHIFT_TXDMA_VIQ_MAP_8197F 6
#define BIT_MASK_TXDMA_VIQ_MAP_8197F 0x3
#define BIT_TXDMA_VIQ_MAP_8197F(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP_8197F) << BIT_SHIFT_TXDMA_VIQ_MAP_8197F)
#define BITS_TXDMA_VIQ_MAP_8197F \
(BIT_MASK_TXDMA_VIQ_MAP_8197F << BIT_SHIFT_TXDMA_VIQ_MAP_8197F)
#define BIT_CLEAR_TXDMA_VIQ_MAP_8197F(x) ((x) & (~BITS_TXDMA_VIQ_MAP_8197F))
#define BIT_GET_TXDMA_VIQ_MAP_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP_8197F) & BIT_MASK_TXDMA_VIQ_MAP_8197F)
#define BIT_SET_TXDMA_VIQ_MAP_8197F(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP_8197F(x) | BIT_TXDMA_VIQ_MAP_8197F(v))
#define BIT_SHIFT_TXDMA_VOQ_MAP_8197F 4
#define BIT_MASK_TXDMA_VOQ_MAP_8197F 0x3
#define BIT_TXDMA_VOQ_MAP_8197F(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP_8197F) << BIT_SHIFT_TXDMA_VOQ_MAP_8197F)
#define BITS_TXDMA_VOQ_MAP_8197F \
(BIT_MASK_TXDMA_VOQ_MAP_8197F << BIT_SHIFT_TXDMA_VOQ_MAP_8197F)
#define BIT_CLEAR_TXDMA_VOQ_MAP_8197F(x) ((x) & (~BITS_TXDMA_VOQ_MAP_8197F))
#define BIT_GET_TXDMA_VOQ_MAP_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP_8197F) & BIT_MASK_TXDMA_VOQ_MAP_8197F)
#define BIT_SET_TXDMA_VOQ_MAP_8197F(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP_8197F(x) | BIT_TXDMA_VOQ_MAP_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_RXDMA_AGG_EN_8197F BIT(2)
#define BIT_RXSHFT_EN_8197F BIT(1)
#define BIT_RXDMA_ARBBW_EN_8197F BIT(0)
/* 2 REG_TRXFF_BNDY_8197F */
#define BIT_SHIFT_RXFFOVFL_RSV_V2_8197F 8
#define BIT_MASK_RXFFOVFL_RSV_V2_8197F 0xf
#define BIT_RXFFOVFL_RSV_V2_8197F(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V2_8197F) \
<< BIT_SHIFT_RXFFOVFL_RSV_V2_8197F)
#define BITS_RXFFOVFL_RSV_V2_8197F \
(BIT_MASK_RXFFOVFL_RSV_V2_8197F << BIT_SHIFT_RXFFOVFL_RSV_V2_8197F)
#define BIT_CLEAR_RXFFOVFL_RSV_V2_8197F(x) ((x) & (~BITS_RXFFOVFL_RSV_V2_8197F))
#define BIT_GET_RXFFOVFL_RSV_V2_8197F(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V2_8197F) & \
BIT_MASK_RXFFOVFL_RSV_V2_8197F)
#define BIT_SET_RXFFOVFL_RSV_V2_8197F(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V2_8197F(x) | BIT_RXFFOVFL_RSV_V2_8197F(v))
#define BIT_SHIFT_TXPKTBUF_PGBNDY_8197F 0
#define BIT_MASK_TXPKTBUF_PGBNDY_8197F 0xff
#define BIT_TXPKTBUF_PGBNDY_8197F(x) \
(((x) & BIT_MASK_TXPKTBUF_PGBNDY_8197F) \
<< BIT_SHIFT_TXPKTBUF_PGBNDY_8197F)
#define BITS_TXPKTBUF_PGBNDY_8197F \
(BIT_MASK_TXPKTBUF_PGBNDY_8197F << BIT_SHIFT_TXPKTBUF_PGBNDY_8197F)
#define BIT_CLEAR_TXPKTBUF_PGBNDY_8197F(x) ((x) & (~BITS_TXPKTBUF_PGBNDY_8197F))
#define BIT_GET_TXPKTBUF_PGBNDY_8197F(x) \
(((x) >> BIT_SHIFT_TXPKTBUF_PGBNDY_8197F) & \
BIT_MASK_TXPKTBUF_PGBNDY_8197F)
#define BIT_SET_TXPKTBUF_PGBNDY_8197F(x, v) \
(BIT_CLEAR_TXPKTBUF_PGBNDY_8197F(x) | BIT_TXPKTBUF_PGBNDY_8197F(v))
/* 2 REG_PTA_I2C_MBOX_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_I2C_M_STATUS_8197F 8
#define BIT_MASK_I2C_M_STATUS_8197F 0xf
#define BIT_I2C_M_STATUS_8197F(x) \
(((x) & BIT_MASK_I2C_M_STATUS_8197F) << BIT_SHIFT_I2C_M_STATUS_8197F)
#define BITS_I2C_M_STATUS_8197F \
(BIT_MASK_I2C_M_STATUS_8197F << BIT_SHIFT_I2C_M_STATUS_8197F)
#define BIT_CLEAR_I2C_M_STATUS_8197F(x) ((x) & (~BITS_I2C_M_STATUS_8197F))
#define BIT_GET_I2C_M_STATUS_8197F(x) \
(((x) >> BIT_SHIFT_I2C_M_STATUS_8197F) & BIT_MASK_I2C_M_STATUS_8197F)
#define BIT_SET_I2C_M_STATUS_8197F(x, v) \
(BIT_CLEAR_I2C_M_STATUS_8197F(x) | BIT_I2C_M_STATUS_8197F(v))
#define BIT_SHIFT_I2C_M_BUS_GNT_FW_8197F 4
#define BIT_MASK_I2C_M_BUS_GNT_FW_8197F 0x7
#define BIT_I2C_M_BUS_GNT_FW_8197F(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT_FW_8197F) \
<< BIT_SHIFT_I2C_M_BUS_GNT_FW_8197F)
#define BITS_I2C_M_BUS_GNT_FW_8197F \
(BIT_MASK_I2C_M_BUS_GNT_FW_8197F << BIT_SHIFT_I2C_M_BUS_GNT_FW_8197F)
#define BIT_CLEAR_I2C_M_BUS_GNT_FW_8197F(x) \
((x) & (~BITS_I2C_M_BUS_GNT_FW_8197F))
#define BIT_GET_I2C_M_BUS_GNT_FW_8197F(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT_FW_8197F) & \
BIT_MASK_I2C_M_BUS_GNT_FW_8197F)
#define BIT_SET_I2C_M_BUS_GNT_FW_8197F(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT_FW_8197F(x) | BIT_I2C_M_BUS_GNT_FW_8197F(v))
#define BIT_I2C_M_GNT_FW_8197F BIT(3)
#define BIT_SHIFT_I2C_M_SPEED_8197F 1
#define BIT_MASK_I2C_M_SPEED_8197F 0x3
#define BIT_I2C_M_SPEED_8197F(x) \
(((x) & BIT_MASK_I2C_M_SPEED_8197F) << BIT_SHIFT_I2C_M_SPEED_8197F)
#define BITS_I2C_M_SPEED_8197F \
(BIT_MASK_I2C_M_SPEED_8197F << BIT_SHIFT_I2C_M_SPEED_8197F)
#define BIT_CLEAR_I2C_M_SPEED_8197F(x) ((x) & (~BITS_I2C_M_SPEED_8197F))
#define BIT_GET_I2C_M_SPEED_8197F(x) \
(((x) >> BIT_SHIFT_I2C_M_SPEED_8197F) & BIT_MASK_I2C_M_SPEED_8197F)
#define BIT_SET_I2C_M_SPEED_8197F(x, v) \
(BIT_CLEAR_I2C_M_SPEED_8197F(x) | BIT_I2C_M_SPEED_8197F(v))
#define BIT_I2C_M_UNLOCK_8197F BIT(0)
/* 2 REG_RXFF_BNDY_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_RXFF0_BNDY_V2_8197F 0
#define BIT_MASK_RXFF0_BNDY_V2_8197F 0x3ffff
#define BIT_RXFF0_BNDY_V2_8197F(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V2_8197F) << BIT_SHIFT_RXFF0_BNDY_V2_8197F)
#define BITS_RXFF0_BNDY_V2_8197F \
(BIT_MASK_RXFF0_BNDY_V2_8197F << BIT_SHIFT_RXFF0_BNDY_V2_8197F)
#define BIT_CLEAR_RXFF0_BNDY_V2_8197F(x) ((x) & (~BITS_RXFF0_BNDY_V2_8197F))
#define BIT_GET_RXFF0_BNDY_V2_8197F(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V2_8197F) & BIT_MASK_RXFF0_BNDY_V2_8197F)
#define BIT_SET_RXFF0_BNDY_V2_8197F(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V2_8197F(x) | BIT_RXFF0_BNDY_V2_8197F(v))
/* 2 REG_FE1IMR_8197F */
#define BIT_BB_STOP_RX_INT_EN_8197F BIT(29)
#define BIT_FS_RXDMA2_DONE_INT_EN_8197F BIT(28)
#define BIT_FS_RXDONE3_INT_EN_8197F BIT(27)
#define BIT_FS_RXDONE2_INT_EN_8197F BIT(26)
#define BIT_FS_RX_BCN_P4_INT_EN_8197F BIT(25)
#define BIT_FS_RX_BCN_P3_INT_EN_8197F BIT(24)
#define BIT_FS_RX_BCN_P2_INT_EN_8197F BIT(23)
#define BIT_FS_RX_BCN_P1_INT_EN_8197F BIT(22)
#define BIT_FS_RX_BCN_P0_INT_EN_8197F BIT(21)
#define BIT_FS_RX_UMD0_INT_EN_8197F BIT(20)
#define BIT_FS_RX_UMD1_INT_EN_8197F BIT(19)
#define BIT_FS_RX_BMD0_INT_EN_8197F BIT(18)
#define BIT_FS_RX_BMD1_INT_EN_8197F BIT(17)
#define BIT_FS_RXDONE_INT_EN_8197F BIT(16)
#define BIT_FS_WWLAN_INT_EN_8197F BIT(15)
#define BIT_FS_SOUND_DONE_INT_EN_8197F BIT(14)
#define BIT_FS_LP_STBY_INT_EN_8197F BIT(13)
#define BIT_FS_TRL_MTR_INT_EN_8197F BIT(12)
#define BIT_FS_BF1_PRETO_INT_EN_8197F BIT(11)
#define BIT_FS_BF0_PRETO_INT_EN_8197F BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_EN_8197F BIT(9)
#define BIT_FS_LTE_COEX_EN_8197F BIT(6)
#define BIT_FS_WLACTOFF_INT_EN_8197F BIT(5)
#define BIT_FS_WLACTON_INT_EN_8197F BIT(4)
#define BIT_FS_BTCMD_INT_EN_8197F BIT(3)
#define BIT_FS_REG_MAILBOX_TO_I2C_INT_EN_8197F BIT(2)
#define BIT_FS_TRPC_TO_INT_EN_V1_8197F BIT(1)
#define BIT_FS_RPC_O_T_INT_EN_V1_8197F BIT(0)
/* 2 REG_FE1ISR_8197F */
#define BIT_BB_STOP_RX_INT_8197F BIT(29)
#define BIT_FS_RXDMA2_DONE_INT_8197F BIT(28)
#define BIT_FS_RXDONE3_INT_8197F BIT(27)
#define BIT_FS_RXDONE2_INT_8197F BIT(26)
#define BIT_FS_RX_BCN_P4_INT_8197F BIT(25)
#define BIT_FS_RX_BCN_P3_INT_8197F BIT(24)
#define BIT_FS_RX_BCN_P2_INT_8197F BIT(23)
#define BIT_FS_RX_BCN_P1_INT_8197F BIT(22)
#define BIT_FS_RX_BCN_P0_INT_8197F BIT(21)
#define BIT_FS_RX_UMD0_INT_8197F BIT(20)
#define BIT_FS_RX_UMD1_INT_8197F BIT(19)
#define BIT_FS_RX_BMD0_INT_8197F BIT(18)
#define BIT_FS_RX_BMD1_INT_8197F BIT(17)
#define BIT_FS_RXDONE_INT_8197F BIT(16)
#define BIT_FS_WWLAN_INT_8197F BIT(15)
#define BIT_FS_SOUND_DONE_INT_8197F BIT(14)
#define BIT_FS_LP_STBY_INT_8197F BIT(13)
#define BIT_FS_TRL_MTR_INT_8197F BIT(12)
#define BIT_FS_BF1_PRETO_INT_8197F BIT(11)
#define BIT_FS_BF0_PRETO_INT_8197F BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_8197F BIT(9)
#define BIT_FS_LTE_COEX_INT_8197F BIT(6)
#define BIT_FS_WLACTOFF_INT_8197F BIT(5)
#define BIT_FS_WLACTON_INT_8197F BIT(4)
#define BIT_FS_BCN_RX_INT_INT_8197F BIT(3)
#define BIT_FS_MAILBOX_TO_I2C_INT_8197F BIT(2)
#define BIT_FS_TRPC_TO_INT_8197F BIT(1)
#define BIT_FS_RPC_O_T_INT_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_CPWM_8197F */
#define BIT_CPWM_TOGGLING_8197F BIT(31)
#define BIT_SHIFT_CPWM_MOD_8197F 24
#define BIT_MASK_CPWM_MOD_8197F 0x7f
#define BIT_CPWM_MOD_8197F(x) \
(((x) & BIT_MASK_CPWM_MOD_8197F) << BIT_SHIFT_CPWM_MOD_8197F)
#define BITS_CPWM_MOD_8197F \
(BIT_MASK_CPWM_MOD_8197F << BIT_SHIFT_CPWM_MOD_8197F)
#define BIT_CLEAR_CPWM_MOD_8197F(x) ((x) & (~BITS_CPWM_MOD_8197F))
#define BIT_GET_CPWM_MOD_8197F(x) \
(((x) >> BIT_SHIFT_CPWM_MOD_8197F) & BIT_MASK_CPWM_MOD_8197F)
#define BIT_SET_CPWM_MOD_8197F(x, v) \
(BIT_CLEAR_CPWM_MOD_8197F(x) | BIT_CPWM_MOD_8197F(v))
/* 2 REG_FWIMR_8197F */
#define BIT_FS_TXBCNOK_MB7_INT_EN_8197F BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_EN_8197F BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_EN_8197F BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_EN_8197F BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_EN_8197F BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_EN_8197F BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_EN_8197F BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_EN_8197F BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_EN_8197F BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_EN_8197F BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_EN_8197F BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_EN_8197F BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_EN_8197F BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_EN_8197F BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_EN_8197F BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_EN_8197F BIT(16)
#define BIT_CPUMGN_POLLED_PKT_DONE_INT_EN_8197F BIT(15)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_EN_8197F BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_EN_8197F BIT(12)
#define BIT_FS_DDMA1_LP_INT_ENBIT_CPUMGN_POLLED_PKT_BUSY_ERR_INT_EN_8197F \
BIT(11)
#define BIT_FS_DDMA1_HP_INT_EN_8197F BIT(10)
#define BIT_FS_DDMA0_LP_INT_EN_8197F BIT(9)
#define BIT_FS_DDMA0_HP_INT_EN_8197F BIT(8)
#define BIT_FS_TRXRPT_INT_EN_8197F BIT(7)
#define BIT_FS_C2H_W_READY_INT_EN_8197F BIT(6)
#define BIT_FS_HRCV_INT_EN_8197F BIT(5)
#define BIT_FS_H2CCMD_INT_EN_8197F BIT(4)
#define BIT_FS_TXPKTIN_INT_EN_8197F BIT(3)
#define BIT_FS_ERRORHDL_INT_EN_8197F BIT(2)
#define BIT_FS_TXCCX_INT_EN_8197F BIT(1)
#define BIT_FS_TXCLOSE_INT_EN_8197F BIT(0)
/* 2 REG_FWISR_8197F */
#define BIT_FS_TXBCNOK_MB7_INT_8197F BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_8197F BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_8197F BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_8197F BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_8197F BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_8197F BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_8197F BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_8197F BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_8197F BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_8197F BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_8197F BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_8197F BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_8197F BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_8197F BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_8197F BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_8197F BIT(16)
#define BIT_CPUMGN_POLLED_PKT_DONE_INT_8197F BIT(15)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_8197F BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_8197F BIT(12)
#define BIT_FS_DDMA1_LP_INTBIT_CPUMGN_POLLED_PKT_BUSY_ERR_INT_8197F BIT(11)
#define BIT_FS_DDMA1_HP_INT_8197F BIT(10)
#define BIT_FS_DDMA0_LP_INT_8197F BIT(9)
#define BIT_FS_DDMA0_HP_INT_8197F BIT(8)
#define BIT_FS_TRXRPT_INT_8197F BIT(7)
#define BIT_FS_C2H_W_READY_INT_8197F BIT(6)
#define BIT_FS_HRCV_INT_8197F BIT(5)
#define BIT_FS_H2CCMD_INT_8197F BIT(4)
#define BIT_FS_TXPKTIN_INT_8197F BIT(3)
#define BIT_FS_ERRORHDL_INT_8197F BIT(2)
#define BIT_FS_TXCCX_INT_8197F BIT(1)
#define BIT_FS_TXCLOSE_INT_8197F BIT(0)
/* 2 REG_FTIMR_8197F */
#define BIT_PS_TIMER_C_EARLY_INT_EN_8197F BIT(23)
#define BIT_PS_TIMER_B_EARLY_INT_EN_8197F BIT(22)
#define BIT_PS_TIMER_A_EARLY_INT_EN_8197F BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_EN_8197F BIT(20)
#define BIT_PS_TIMER_C_INT_EN_8197F BIT(19)
#define BIT_PS_TIMER_B_INT_EN_8197F BIT(18)
#define BIT_PS_TIMER_A_INT_EN_8197F BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_EN_8197F BIT(16)
#define BIT_FS_PS_TIMEOUT2_EN_8197F BIT(15)
#define BIT_FS_PS_TIMEOUT1_EN_8197F BIT(14)
#define BIT_FS_PS_TIMEOUT0_EN_8197F BIT(13)
#define BIT_FS_GTINT8_EN_8197F BIT(8)
#define BIT_FS_GTINT7_EN_8197F BIT(7)
#define BIT_FS_GTINT6_EN_8197F BIT(6)
#define BIT_FS_GTINT5_EN_8197F BIT(5)
#define BIT_FS_GTINT4_EN_8197F BIT(4)
#define BIT_FS_GTINT3_EN_8197F BIT(3)
#define BIT_FS_GTINT2_EN_8197F BIT(2)
#define BIT_FS_GTINT1_EN_8197F BIT(1)
#define BIT_FS_GTINT0_EN_8197F BIT(0)
/* 2 REG_FTISR_8197F */
#define BIT_PS_TIMER_C_EARLY__INT_8197F BIT(23)
#define BIT_PS_TIMER_B_EARLY__INT_8197F BIT(22)
#define BIT_PS_TIMER_A_EARLY__INT_8197F BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_8197F BIT(20)
#define BIT_PS_TIMER_C_INT_8197F BIT(19)
#define BIT_PS_TIMER_B_INT_8197F BIT(18)
#define BIT_PS_TIMER_A_INT_8197F BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_8197F BIT(16)
#define BIT_FS_PS_TIMEOUT2_INT_8197F BIT(15)
#define BIT_FS_PS_TIMEOUT1_INT_8197F BIT(14)
#define BIT_FS_PS_TIMEOUT0_INT_8197F BIT(13)
#define BIT_FS_GTINT8_INT_8197F BIT(8)
#define BIT_FS_GTINT7_INT_8197F BIT(7)
#define BIT_FS_GTINT6_INT_8197F BIT(6)
#define BIT_FS_GTINT5_INT_8197F BIT(5)
#define BIT_FS_GTINT4_INT_8197F BIT(4)
#define BIT_FS_GTINT3_INT_8197F BIT(3)
#define BIT_FS_GTINT2_INT_8197F BIT(2)
#define BIT_FS_GTINT1_INT_8197F BIT(1)
#define BIT_FS_GTINT0_INT_8197F BIT(0)
/* 2 REG_PKTBUF_DBG_CTRL_8197F */
#define BIT_SHIFT_PKTBUF_WRITE_EN_8197F 24
#define BIT_MASK_PKTBUF_WRITE_EN_8197F 0xff
#define BIT_PKTBUF_WRITE_EN_8197F(x) \
(((x) & BIT_MASK_PKTBUF_WRITE_EN_8197F) \
<< BIT_SHIFT_PKTBUF_WRITE_EN_8197F)
#define BITS_PKTBUF_WRITE_EN_8197F \
(BIT_MASK_PKTBUF_WRITE_EN_8197F << BIT_SHIFT_PKTBUF_WRITE_EN_8197F)
#define BIT_CLEAR_PKTBUF_WRITE_EN_8197F(x) ((x) & (~BITS_PKTBUF_WRITE_EN_8197F))
#define BIT_GET_PKTBUF_WRITE_EN_8197F(x) \
(((x) >> BIT_SHIFT_PKTBUF_WRITE_EN_8197F) & \
BIT_MASK_PKTBUF_WRITE_EN_8197F)
#define BIT_SET_PKTBUF_WRITE_EN_8197F(x, v) \
(BIT_CLEAR_PKTBUF_WRITE_EN_8197F(x) | BIT_PKTBUF_WRITE_EN_8197F(v))
#define BIT_TXRPTBUF_DBG_8197F BIT(23)
/* 2 REG_NOT_VALID_8197F */
#define BIT_TXPKTBUF_DBG_V2_8197F BIT(20)
#define BIT_RXPKTBUF_DBG_8197F BIT(16)
#define BIT_SHIFT_PKTBUF_DBG_ADDR_8197F 0
#define BIT_MASK_PKTBUF_DBG_ADDR_8197F 0x1fff
#define BIT_PKTBUF_DBG_ADDR_8197F(x) \
(((x) & BIT_MASK_PKTBUF_DBG_ADDR_8197F) \
<< BIT_SHIFT_PKTBUF_DBG_ADDR_8197F)
#define BITS_PKTBUF_DBG_ADDR_8197F \
(BIT_MASK_PKTBUF_DBG_ADDR_8197F << BIT_SHIFT_PKTBUF_DBG_ADDR_8197F)
#define BIT_CLEAR_PKTBUF_DBG_ADDR_8197F(x) ((x) & (~BITS_PKTBUF_DBG_ADDR_8197F))
#define BIT_GET_PKTBUF_DBG_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_ADDR_8197F) & \
BIT_MASK_PKTBUF_DBG_ADDR_8197F)
#define BIT_SET_PKTBUF_DBG_ADDR_8197F(x, v) \
(BIT_CLEAR_PKTBUF_DBG_ADDR_8197F(x) | BIT_PKTBUF_DBG_ADDR_8197F(v))
/* 2 REG_PKTBUF_DBG_DATA_L_8197F */
#define BIT_SHIFT_PKTBUF_DBG_DATA_L_8197F 0
#define BIT_MASK_PKTBUF_DBG_DATA_L_8197F 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_L_8197F(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_L_8197F) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_L_8197F)
#define BITS_PKTBUF_DBG_DATA_L_8197F \
(BIT_MASK_PKTBUF_DBG_DATA_L_8197F << BIT_SHIFT_PKTBUF_DBG_DATA_L_8197F)
#define BIT_CLEAR_PKTBUF_DBG_DATA_L_8197F(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_L_8197F))
#define BIT_GET_PKTBUF_DBG_DATA_L_8197F(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_L_8197F) & \
BIT_MASK_PKTBUF_DBG_DATA_L_8197F)
#define BIT_SET_PKTBUF_DBG_DATA_L_8197F(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_L_8197F(x) | BIT_PKTBUF_DBG_DATA_L_8197F(v))
/* 2 REG_PKTBUF_DBG_DATA_H_8197F */
#define BIT_SHIFT_PKTBUF_DBG_DATA_H_8197F 0
#define BIT_MASK_PKTBUF_DBG_DATA_H_8197F 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_H_8197F(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_H_8197F) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_H_8197F)
#define BITS_PKTBUF_DBG_DATA_H_8197F \
(BIT_MASK_PKTBUF_DBG_DATA_H_8197F << BIT_SHIFT_PKTBUF_DBG_DATA_H_8197F)
#define BIT_CLEAR_PKTBUF_DBG_DATA_H_8197F(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_H_8197F))
#define BIT_GET_PKTBUF_DBG_DATA_H_8197F(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_H_8197F) & \
BIT_MASK_PKTBUF_DBG_DATA_H_8197F)
#define BIT_SET_PKTBUF_DBG_DATA_H_8197F(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_H_8197F(x) | BIT_PKTBUF_DBG_DATA_H_8197F(v))
/* 2 REG_CPWM2_8197F */
#define BIT_SHIFT_L0S_TO_RCVY_NUM_8197F 16
#define BIT_MASK_L0S_TO_RCVY_NUM_8197F 0xff
#define BIT_L0S_TO_RCVY_NUM_8197F(x) \
(((x) & BIT_MASK_L0S_TO_RCVY_NUM_8197F) \
<< BIT_SHIFT_L0S_TO_RCVY_NUM_8197F)
#define BITS_L0S_TO_RCVY_NUM_8197F \
(BIT_MASK_L0S_TO_RCVY_NUM_8197F << BIT_SHIFT_L0S_TO_RCVY_NUM_8197F)
#define BIT_CLEAR_L0S_TO_RCVY_NUM_8197F(x) ((x) & (~BITS_L0S_TO_RCVY_NUM_8197F))
#define BIT_GET_L0S_TO_RCVY_NUM_8197F(x) \
(((x) >> BIT_SHIFT_L0S_TO_RCVY_NUM_8197F) & \
BIT_MASK_L0S_TO_RCVY_NUM_8197F)
#define BIT_SET_L0S_TO_RCVY_NUM_8197F(x, v) \
(BIT_CLEAR_L0S_TO_RCVY_NUM_8197F(x) | BIT_L0S_TO_RCVY_NUM_8197F(v))
#define BIT_CPWM2_TOGGLING_8197F BIT(15)
#define BIT_SHIFT_CPWM2_MOD_8197F 0
#define BIT_MASK_CPWM2_MOD_8197F 0x7fff
#define BIT_CPWM2_MOD_8197F(x) \
(((x) & BIT_MASK_CPWM2_MOD_8197F) << BIT_SHIFT_CPWM2_MOD_8197F)
#define BITS_CPWM2_MOD_8197F \
(BIT_MASK_CPWM2_MOD_8197F << BIT_SHIFT_CPWM2_MOD_8197F)
#define BIT_CLEAR_CPWM2_MOD_8197F(x) ((x) & (~BITS_CPWM2_MOD_8197F))
#define BIT_GET_CPWM2_MOD_8197F(x) \
(((x) >> BIT_SHIFT_CPWM2_MOD_8197F) & BIT_MASK_CPWM2_MOD_8197F)
#define BIT_SET_CPWM2_MOD_8197F(x, v) \
(BIT_CLEAR_CPWM2_MOD_8197F(x) | BIT_CPWM2_MOD_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_TC0_CTRL_8197F */
#define BIT_TC0INT_EN_8197F BIT(26)
#define BIT_TC0MODE_8197F BIT(25)
#define BIT_TC0EN_8197F BIT(24)
#define BIT_SHIFT_TC0DATA_8197F 0
#define BIT_MASK_TC0DATA_8197F 0xffffff
#define BIT_TC0DATA_8197F(x) \
(((x) & BIT_MASK_TC0DATA_8197F) << BIT_SHIFT_TC0DATA_8197F)
#define BITS_TC0DATA_8197F (BIT_MASK_TC0DATA_8197F << BIT_SHIFT_TC0DATA_8197F)
#define BIT_CLEAR_TC0DATA_8197F(x) ((x) & (~BITS_TC0DATA_8197F))
#define BIT_GET_TC0DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC0DATA_8197F) & BIT_MASK_TC0DATA_8197F)
#define BIT_SET_TC0DATA_8197F(x, v) \
(BIT_CLEAR_TC0DATA_8197F(x) | BIT_TC0DATA_8197F(v))
/* 2 REG_TC1_CTRL_8197F */
#define BIT_TC1INT_EN_8197F BIT(26)
#define BIT_TC1MODE_8197F BIT(25)
#define BIT_TC1EN_8197F BIT(24)
#define BIT_SHIFT_TC1DATA_8197F 0
#define BIT_MASK_TC1DATA_8197F 0xffffff
#define BIT_TC1DATA_8197F(x) \
(((x) & BIT_MASK_TC1DATA_8197F) << BIT_SHIFT_TC1DATA_8197F)
#define BITS_TC1DATA_8197F (BIT_MASK_TC1DATA_8197F << BIT_SHIFT_TC1DATA_8197F)
#define BIT_CLEAR_TC1DATA_8197F(x) ((x) & (~BITS_TC1DATA_8197F))
#define BIT_GET_TC1DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC1DATA_8197F) & BIT_MASK_TC1DATA_8197F)
#define BIT_SET_TC1DATA_8197F(x, v) \
(BIT_CLEAR_TC1DATA_8197F(x) | BIT_TC1DATA_8197F(v))
/* 2 REG_TC2_CTRL_8197F */
#define BIT_TC2INT_EN_8197F BIT(26)
#define BIT_TC2MODE_8197F BIT(25)
#define BIT_TC2EN_8197F BIT(24)
#define BIT_SHIFT_TC2DATA_8197F 0
#define BIT_MASK_TC2DATA_8197F 0xffffff
#define BIT_TC2DATA_8197F(x) \
(((x) & BIT_MASK_TC2DATA_8197F) << BIT_SHIFT_TC2DATA_8197F)
#define BITS_TC2DATA_8197F (BIT_MASK_TC2DATA_8197F << BIT_SHIFT_TC2DATA_8197F)
#define BIT_CLEAR_TC2DATA_8197F(x) ((x) & (~BITS_TC2DATA_8197F))
#define BIT_GET_TC2DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC2DATA_8197F) & BIT_MASK_TC2DATA_8197F)
#define BIT_SET_TC2DATA_8197F(x, v) \
(BIT_CLEAR_TC2DATA_8197F(x) | BIT_TC2DATA_8197F(v))
/* 2 REG_TC3_CTRL_8197F */
#define BIT_TC3INT_EN_8197F BIT(26)
#define BIT_TC3MODE_8197F BIT(25)
#define BIT_TC3EN_8197F BIT(24)
#define BIT_SHIFT_TC3DATA_8197F 0
#define BIT_MASK_TC3DATA_8197F 0xffffff
#define BIT_TC3DATA_8197F(x) \
(((x) & BIT_MASK_TC3DATA_8197F) << BIT_SHIFT_TC3DATA_8197F)
#define BITS_TC3DATA_8197F (BIT_MASK_TC3DATA_8197F << BIT_SHIFT_TC3DATA_8197F)
#define BIT_CLEAR_TC3DATA_8197F(x) ((x) & (~BITS_TC3DATA_8197F))
#define BIT_GET_TC3DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC3DATA_8197F) & BIT_MASK_TC3DATA_8197F)
#define BIT_SET_TC3DATA_8197F(x, v) \
(BIT_CLEAR_TC3DATA_8197F(x) | BIT_TC3DATA_8197F(v))
/* 2 REG_TC4_CTRL_8197F */
#define BIT_TC4INT_EN_8197F BIT(26)
#define BIT_TC4MODE_8197F BIT(25)
#define BIT_TC4EN_8197F BIT(24)
#define BIT_SHIFT_TC4DATA_8197F 0
#define BIT_MASK_TC4DATA_8197F 0xffffff
#define BIT_TC4DATA_8197F(x) \
(((x) & BIT_MASK_TC4DATA_8197F) << BIT_SHIFT_TC4DATA_8197F)
#define BITS_TC4DATA_8197F (BIT_MASK_TC4DATA_8197F << BIT_SHIFT_TC4DATA_8197F)
#define BIT_CLEAR_TC4DATA_8197F(x) ((x) & (~BITS_TC4DATA_8197F))
#define BIT_GET_TC4DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC4DATA_8197F) & BIT_MASK_TC4DATA_8197F)
#define BIT_SET_TC4DATA_8197F(x, v) \
(BIT_CLEAR_TC4DATA_8197F(x) | BIT_TC4DATA_8197F(v))
/* 2 REG_TCUNIT_BASE_8197F */
#define BIT_SHIFT_TCUNIT_BASE_8197F 0
#define BIT_MASK_TCUNIT_BASE_8197F 0x3fff
#define BIT_TCUNIT_BASE_8197F(x) \
(((x) & BIT_MASK_TCUNIT_BASE_8197F) << BIT_SHIFT_TCUNIT_BASE_8197F)
#define BITS_TCUNIT_BASE_8197F \
(BIT_MASK_TCUNIT_BASE_8197F << BIT_SHIFT_TCUNIT_BASE_8197F)
#define BIT_CLEAR_TCUNIT_BASE_8197F(x) ((x) & (~BITS_TCUNIT_BASE_8197F))
#define BIT_GET_TCUNIT_BASE_8197F(x) \
(((x) >> BIT_SHIFT_TCUNIT_BASE_8197F) & BIT_MASK_TCUNIT_BASE_8197F)
#define BIT_SET_TCUNIT_BASE_8197F(x, v) \
(BIT_CLEAR_TCUNIT_BASE_8197F(x) | BIT_TCUNIT_BASE_8197F(v))
/* 2 REG_TC5_CTRL_8197F */
#define BIT_TC5INT_EN_8197F BIT(26)
#define BIT_TC5MODE_8197F BIT(25)
#define BIT_TC5EN_8197F BIT(24)
#define BIT_SHIFT_TC5DATA_8197F 0
#define BIT_MASK_TC5DATA_8197F 0xffffff
#define BIT_TC5DATA_8197F(x) \
(((x) & BIT_MASK_TC5DATA_8197F) << BIT_SHIFT_TC5DATA_8197F)
#define BITS_TC5DATA_8197F (BIT_MASK_TC5DATA_8197F << BIT_SHIFT_TC5DATA_8197F)
#define BIT_CLEAR_TC5DATA_8197F(x) ((x) & (~BITS_TC5DATA_8197F))
#define BIT_GET_TC5DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC5DATA_8197F) & BIT_MASK_TC5DATA_8197F)
#define BIT_SET_TC5DATA_8197F(x, v) \
(BIT_CLEAR_TC5DATA_8197F(x) | BIT_TC5DATA_8197F(v))
/* 2 REG_TC6_CTRL_8197F */
#define BIT_TC6INT_EN_8197F BIT(26)
#define BIT_TC6MODE_8197F BIT(25)
#define BIT_TC6EN_8197F BIT(24)
#define BIT_SHIFT_TC6DATA_8197F 0
#define BIT_MASK_TC6DATA_8197F 0xffffff
#define BIT_TC6DATA_8197F(x) \
(((x) & BIT_MASK_TC6DATA_8197F) << BIT_SHIFT_TC6DATA_8197F)
#define BITS_TC6DATA_8197F (BIT_MASK_TC6DATA_8197F << BIT_SHIFT_TC6DATA_8197F)
#define BIT_CLEAR_TC6DATA_8197F(x) ((x) & (~BITS_TC6DATA_8197F))
#define BIT_GET_TC6DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC6DATA_8197F) & BIT_MASK_TC6DATA_8197F)
#define BIT_SET_TC6DATA_8197F(x, v) \
(BIT_CLEAR_TC6DATA_8197F(x) | BIT_TC6DATA_8197F(v))
/* 2 REG_MBIST_FAIL_8197F */
#define BIT_SHIFT_8051_MBIST_FAIL_8197F 26
#define BIT_MASK_8051_MBIST_FAIL_8197F 0x7
#define BIT_8051_MBIST_FAIL_8197F(x) \
(((x) & BIT_MASK_8051_MBIST_FAIL_8197F) \
<< BIT_SHIFT_8051_MBIST_FAIL_8197F)
#define BITS_8051_MBIST_FAIL_8197F \
(BIT_MASK_8051_MBIST_FAIL_8197F << BIT_SHIFT_8051_MBIST_FAIL_8197F)
#define BIT_CLEAR_8051_MBIST_FAIL_8197F(x) ((x) & (~BITS_8051_MBIST_FAIL_8197F))
#define BIT_GET_8051_MBIST_FAIL_8197F(x) \
(((x) >> BIT_SHIFT_8051_MBIST_FAIL_8197F) & \
BIT_MASK_8051_MBIST_FAIL_8197F)
#define BIT_SET_8051_MBIST_FAIL_8197F(x, v) \
(BIT_CLEAR_8051_MBIST_FAIL_8197F(x) | BIT_8051_MBIST_FAIL_8197F(v))
#define BIT_SHIFT_USB_MBIST_FAIL_8197F 24
#define BIT_MASK_USB_MBIST_FAIL_8197F 0x3
#define BIT_USB_MBIST_FAIL_8197F(x) \
(((x) & BIT_MASK_USB_MBIST_FAIL_8197F) \
<< BIT_SHIFT_USB_MBIST_FAIL_8197F)
#define BITS_USB_MBIST_FAIL_8197F \
(BIT_MASK_USB_MBIST_FAIL_8197F << BIT_SHIFT_USB_MBIST_FAIL_8197F)
#define BIT_CLEAR_USB_MBIST_FAIL_8197F(x) ((x) & (~BITS_USB_MBIST_FAIL_8197F))
#define BIT_GET_USB_MBIST_FAIL_8197F(x) \
(((x) >> BIT_SHIFT_USB_MBIST_FAIL_8197F) & \
BIT_MASK_USB_MBIST_FAIL_8197F)
#define BIT_SET_USB_MBIST_FAIL_8197F(x, v) \
(BIT_CLEAR_USB_MBIST_FAIL_8197F(x) | BIT_USB_MBIST_FAIL_8197F(v))
#define BIT_SHIFT_PCIE_MBIST_FAIL_8197F 16
#define BIT_MASK_PCIE_MBIST_FAIL_8197F 0x3f
#define BIT_PCIE_MBIST_FAIL_8197F(x) \
(((x) & BIT_MASK_PCIE_MBIST_FAIL_8197F) \
<< BIT_SHIFT_PCIE_MBIST_FAIL_8197F)
#define BITS_PCIE_MBIST_FAIL_8197F \
(BIT_MASK_PCIE_MBIST_FAIL_8197F << BIT_SHIFT_PCIE_MBIST_FAIL_8197F)
#define BIT_CLEAR_PCIE_MBIST_FAIL_8197F(x) ((x) & (~BITS_PCIE_MBIST_FAIL_8197F))
#define BIT_GET_PCIE_MBIST_FAIL_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_FAIL_8197F) & \
BIT_MASK_PCIE_MBIST_FAIL_8197F)
#define BIT_SET_PCIE_MBIST_FAIL_8197F(x, v) \
(BIT_CLEAR_PCIE_MBIST_FAIL_8197F(x) | BIT_PCIE_MBIST_FAIL_8197F(v))
#define BIT_SHIFT_MAC_MBIST_FAIL_DRF_8197F 0
#define BIT_MASK_MAC_MBIST_FAIL_DRF_8197F 0x3ffff
#define BIT_MAC_MBIST_FAIL_DRF_8197F(x) \
(((x) & BIT_MASK_MAC_MBIST_FAIL_DRF_8197F) \
<< BIT_SHIFT_MAC_MBIST_FAIL_DRF_8197F)
#define BITS_MAC_MBIST_FAIL_DRF_8197F \
(BIT_MASK_MAC_MBIST_FAIL_DRF_8197F \
<< BIT_SHIFT_MAC_MBIST_FAIL_DRF_8197F)
#define BIT_CLEAR_MAC_MBIST_FAIL_DRF_8197F(x) \
((x) & (~BITS_MAC_MBIST_FAIL_DRF_8197F))
#define BIT_GET_MAC_MBIST_FAIL_DRF_8197F(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_FAIL_DRF_8197F) & \
BIT_MASK_MAC_MBIST_FAIL_DRF_8197F)
#define BIT_SET_MAC_MBIST_FAIL_DRF_8197F(x, v) \
(BIT_CLEAR_MAC_MBIST_FAIL_DRF_8197F(x) | \
BIT_MAC_MBIST_FAIL_DRF_8197F(v))
/* 2 REG_MBIST_START_PAUSE_8197F */
#define BIT_SHIFT_8051_MBIST_START_PAUSE_8197F 26
#define BIT_MASK_8051_MBIST_START_PAUSE_8197F 0x7
#define BIT_8051_MBIST_START_PAUSE_8197F(x) \
(((x) & BIT_MASK_8051_MBIST_START_PAUSE_8197F) \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_8197F)
#define BITS_8051_MBIST_START_PAUSE_8197F \
(BIT_MASK_8051_MBIST_START_PAUSE_8197F \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_8197F)
#define BIT_CLEAR_8051_MBIST_START_PAUSE_8197F(x) \
((x) & (~BITS_8051_MBIST_START_PAUSE_8197F))
#define BIT_GET_8051_MBIST_START_PAUSE_8197F(x) \
(((x) >> BIT_SHIFT_8051_MBIST_START_PAUSE_8197F) & \
BIT_MASK_8051_MBIST_START_PAUSE_8197F)
#define BIT_SET_8051_MBIST_START_PAUSE_8197F(x, v) \
(BIT_CLEAR_8051_MBIST_START_PAUSE_8197F(x) | \
BIT_8051_MBIST_START_PAUSE_8197F(v))
#define BIT_SHIFT_USB_MBIST_START_PAUSE_8197F 24
#define BIT_MASK_USB_MBIST_START_PAUSE_8197F 0x3
#define BIT_USB_MBIST_START_PAUSE_8197F(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE_8197F) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_8197F)
#define BITS_USB_MBIST_START_PAUSE_8197F \
(BIT_MASK_USB_MBIST_START_PAUSE_8197F \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_8197F)
#define BIT_CLEAR_USB_MBIST_START_PAUSE_8197F(x) \
((x) & (~BITS_USB_MBIST_START_PAUSE_8197F))
#define BIT_GET_USB_MBIST_START_PAUSE_8197F(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE_8197F) & \
BIT_MASK_USB_MBIST_START_PAUSE_8197F)
#define BIT_SET_USB_MBIST_START_PAUSE_8197F(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE_8197F(x) | \
BIT_USB_MBIST_START_PAUSE_8197F(v))
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE_8197F 16
#define BIT_MASK_PCIE_MBIST_START_PAUSE_8197F 0x3f
#define BIT_PCIE_MBIST_START_PAUSE_8197F(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE_8197F) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_8197F)
#define BITS_PCIE_MBIST_START_PAUSE_8197F \
(BIT_MASK_PCIE_MBIST_START_PAUSE_8197F \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_8197F)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE_8197F(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE_8197F))
#define BIT_GET_PCIE_MBIST_START_PAUSE_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE_8197F) & \
BIT_MASK_PCIE_MBIST_START_PAUSE_8197F)
#define BIT_SET_PCIE_MBIST_START_PAUSE_8197F(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE_8197F(x) | \
BIT_PCIE_MBIST_START_PAUSE_8197F(v))
#define BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8197F 0
#define BIT_MASK_MAC_MBIST_START_PAUSE_V1_8197F 0x3ffff
#define BIT_MAC_MBIST_START_PAUSE_V1_8197F(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE_V1_8197F) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8197F)
#define BITS_MAC_MBIST_START_PAUSE_V1_8197F \
(BIT_MASK_MAC_MBIST_START_PAUSE_V1_8197F \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8197F)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE_V1_8197F(x) \
((x) & (~BITS_MAC_MBIST_START_PAUSE_V1_8197F))
#define BIT_GET_MAC_MBIST_START_PAUSE_V1_8197F(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8197F) & \
BIT_MASK_MAC_MBIST_START_PAUSE_V1_8197F)
#define BIT_SET_MAC_MBIST_START_PAUSE_V1_8197F(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE_V1_8197F(x) | \
BIT_MAC_MBIST_START_PAUSE_V1_8197F(v))
/* 2 REG_MBIST_DONE_8197F */
#define BIT_SHIFT_8051_MBIST_DONE_8197F 26
#define BIT_MASK_8051_MBIST_DONE_8197F 0x7
#define BIT_8051_MBIST_DONE_8197F(x) \
(((x) & BIT_MASK_8051_MBIST_DONE_8197F) \
<< BIT_SHIFT_8051_MBIST_DONE_8197F)
#define BITS_8051_MBIST_DONE_8197F \
(BIT_MASK_8051_MBIST_DONE_8197F << BIT_SHIFT_8051_MBIST_DONE_8197F)
#define BIT_CLEAR_8051_MBIST_DONE_8197F(x) ((x) & (~BITS_8051_MBIST_DONE_8197F))
#define BIT_GET_8051_MBIST_DONE_8197F(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DONE_8197F) & \
BIT_MASK_8051_MBIST_DONE_8197F)
#define BIT_SET_8051_MBIST_DONE_8197F(x, v) \
(BIT_CLEAR_8051_MBIST_DONE_8197F(x) | BIT_8051_MBIST_DONE_8197F(v))
#define BIT_SHIFT_USB_MBIST_DONE_8197F 24
#define BIT_MASK_USB_MBIST_DONE_8197F 0x3
#define BIT_USB_MBIST_DONE_8197F(x) \
(((x) & BIT_MASK_USB_MBIST_DONE_8197F) \
<< BIT_SHIFT_USB_MBIST_DONE_8197F)
#define BITS_USB_MBIST_DONE_8197F \
(BIT_MASK_USB_MBIST_DONE_8197F << BIT_SHIFT_USB_MBIST_DONE_8197F)
#define BIT_CLEAR_USB_MBIST_DONE_8197F(x) ((x) & (~BITS_USB_MBIST_DONE_8197F))
#define BIT_GET_USB_MBIST_DONE_8197F(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE_8197F) & \
BIT_MASK_USB_MBIST_DONE_8197F)
#define BIT_SET_USB_MBIST_DONE_8197F(x, v) \
(BIT_CLEAR_USB_MBIST_DONE_8197F(x) | BIT_USB_MBIST_DONE_8197F(v))
#define BIT_SHIFT_PCIE_MBIST_DONE_8197F 16
#define BIT_MASK_PCIE_MBIST_DONE_8197F 0x3f
#define BIT_PCIE_MBIST_DONE_8197F(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE_8197F) \
<< BIT_SHIFT_PCIE_MBIST_DONE_8197F)
#define BITS_PCIE_MBIST_DONE_8197F \
(BIT_MASK_PCIE_MBIST_DONE_8197F << BIT_SHIFT_PCIE_MBIST_DONE_8197F)
#define BIT_CLEAR_PCIE_MBIST_DONE_8197F(x) ((x) & (~BITS_PCIE_MBIST_DONE_8197F))
#define BIT_GET_PCIE_MBIST_DONE_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE_8197F) & \
BIT_MASK_PCIE_MBIST_DONE_8197F)
#define BIT_SET_PCIE_MBIST_DONE_8197F(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE_8197F(x) | BIT_PCIE_MBIST_DONE_8197F(v))
#define BIT_SHIFT_MAC_MBIST_DONE_V1_8197F 0
#define BIT_MASK_MAC_MBIST_DONE_V1_8197F 0x3ffff
#define BIT_MAC_MBIST_DONE_V1_8197F(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE_V1_8197F) \
<< BIT_SHIFT_MAC_MBIST_DONE_V1_8197F)
#define BITS_MAC_MBIST_DONE_V1_8197F \
(BIT_MASK_MAC_MBIST_DONE_V1_8197F << BIT_SHIFT_MAC_MBIST_DONE_V1_8197F)
#define BIT_CLEAR_MAC_MBIST_DONE_V1_8197F(x) \
((x) & (~BITS_MAC_MBIST_DONE_V1_8197F))
#define BIT_GET_MAC_MBIST_DONE_V1_8197F(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE_V1_8197F) & \
BIT_MASK_MAC_MBIST_DONE_V1_8197F)
#define BIT_SET_MAC_MBIST_DONE_V1_8197F(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE_V1_8197F(x) | BIT_MAC_MBIST_DONE_V1_8197F(v))
/* 2 REG_MBIST_FAIL_NRML_8197F */
#define BIT_SHIFT_MBIST_FAIL_NRML_V1_8197F 0
#define BIT_MASK_MBIST_FAIL_NRML_V1_8197F 0x3ffff
#define BIT_MBIST_FAIL_NRML_V1_8197F(x) \
(((x) & BIT_MASK_MBIST_FAIL_NRML_V1_8197F) \
<< BIT_SHIFT_MBIST_FAIL_NRML_V1_8197F)
#define BITS_MBIST_FAIL_NRML_V1_8197F \
(BIT_MASK_MBIST_FAIL_NRML_V1_8197F \
<< BIT_SHIFT_MBIST_FAIL_NRML_V1_8197F)
#define BIT_CLEAR_MBIST_FAIL_NRML_V1_8197F(x) \
((x) & (~BITS_MBIST_FAIL_NRML_V1_8197F))
#define BIT_GET_MBIST_FAIL_NRML_V1_8197F(x) \
(((x) >> BIT_SHIFT_MBIST_FAIL_NRML_V1_8197F) & \
BIT_MASK_MBIST_FAIL_NRML_V1_8197F)
#define BIT_SET_MBIST_FAIL_NRML_V1_8197F(x, v) \
(BIT_CLEAR_MBIST_FAIL_NRML_V1_8197F(x) | \
BIT_MBIST_FAIL_NRML_V1_8197F(v))
/* 2 REG_AES_DECRPT_DATA_8197F */
#define BIT_SHIFT_IPS_CFG_ADDR_8197F 0
#define BIT_MASK_IPS_CFG_ADDR_8197F 0xff
#define BIT_IPS_CFG_ADDR_8197F(x) \
(((x) & BIT_MASK_IPS_CFG_ADDR_8197F) << BIT_SHIFT_IPS_CFG_ADDR_8197F)
#define BITS_IPS_CFG_ADDR_8197F \
(BIT_MASK_IPS_CFG_ADDR_8197F << BIT_SHIFT_IPS_CFG_ADDR_8197F)
#define BIT_CLEAR_IPS_CFG_ADDR_8197F(x) ((x) & (~BITS_IPS_CFG_ADDR_8197F))
#define BIT_GET_IPS_CFG_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_IPS_CFG_ADDR_8197F) & BIT_MASK_IPS_CFG_ADDR_8197F)
#define BIT_SET_IPS_CFG_ADDR_8197F(x, v) \
(BIT_CLEAR_IPS_CFG_ADDR_8197F(x) | BIT_IPS_CFG_ADDR_8197F(v))
/* 2 REG_AES_DECRPT_CFG_8197F */
#define BIT_SHIFT_IPS_CFG_DATA_8197F 0
#define BIT_MASK_IPS_CFG_DATA_8197F 0xffffffffL
#define BIT_IPS_CFG_DATA_8197F(x) \
(((x) & BIT_MASK_IPS_CFG_DATA_8197F) << BIT_SHIFT_IPS_CFG_DATA_8197F)
#define BITS_IPS_CFG_DATA_8197F \
(BIT_MASK_IPS_CFG_DATA_8197F << BIT_SHIFT_IPS_CFG_DATA_8197F)
#define BIT_CLEAR_IPS_CFG_DATA_8197F(x) ((x) & (~BITS_IPS_CFG_DATA_8197F))
#define BIT_GET_IPS_CFG_DATA_8197F(x) \
(((x) >> BIT_SHIFT_IPS_CFG_DATA_8197F) & BIT_MASK_IPS_CFG_DATA_8197F)
#define BIT_SET_IPS_CFG_DATA_8197F(x, v) \
(BIT_CLEAR_IPS_CFG_DATA_8197F(x) | BIT_IPS_CFG_DATA_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_MACCLKFRQ_8197F */
#define BIT_SHIFT_MACCLK_FREQ_LOW32_8197F 0
#define BIT_MASK_MACCLK_FREQ_LOW32_8197F 0xffffffffL
#define BIT_MACCLK_FREQ_LOW32_8197F(x) \
(((x) & BIT_MASK_MACCLK_FREQ_LOW32_8197F) \
<< BIT_SHIFT_MACCLK_FREQ_LOW32_8197F)
#define BITS_MACCLK_FREQ_LOW32_8197F \
(BIT_MASK_MACCLK_FREQ_LOW32_8197F << BIT_SHIFT_MACCLK_FREQ_LOW32_8197F)
#define BIT_CLEAR_MACCLK_FREQ_LOW32_8197F(x) \
((x) & (~BITS_MACCLK_FREQ_LOW32_8197F))
#define BIT_GET_MACCLK_FREQ_LOW32_8197F(x) \
(((x) >> BIT_SHIFT_MACCLK_FREQ_LOW32_8197F) & \
BIT_MASK_MACCLK_FREQ_LOW32_8197F)
#define BIT_SET_MACCLK_FREQ_LOW32_8197F(x, v) \
(BIT_CLEAR_MACCLK_FREQ_LOW32_8197F(x) | BIT_MACCLK_FREQ_LOW32_8197F(v))
/* 2 REG_TMETER_8197F */
#define BIT_SHIFT_MACCLK_FREQ_HIGH10_8197F 0
#define BIT_MASK_MACCLK_FREQ_HIGH10_8197F 0x3ff
#define BIT_MACCLK_FREQ_HIGH10_8197F(x) \
(((x) & BIT_MASK_MACCLK_FREQ_HIGH10_8197F) \
<< BIT_SHIFT_MACCLK_FREQ_HIGH10_8197F)
#define BITS_MACCLK_FREQ_HIGH10_8197F \
(BIT_MASK_MACCLK_FREQ_HIGH10_8197F \
<< BIT_SHIFT_MACCLK_FREQ_HIGH10_8197F)
#define BIT_CLEAR_MACCLK_FREQ_HIGH10_8197F(x) \
((x) & (~BITS_MACCLK_FREQ_HIGH10_8197F))
#define BIT_GET_MACCLK_FREQ_HIGH10_8197F(x) \
(((x) >> BIT_SHIFT_MACCLK_FREQ_HIGH10_8197F) & \
BIT_MASK_MACCLK_FREQ_HIGH10_8197F)
#define BIT_SET_MACCLK_FREQ_HIGH10_8197F(x, v) \
(BIT_CLEAR_MACCLK_FREQ_HIGH10_8197F(x) | \
BIT_MACCLK_FREQ_HIGH10_8197F(v))
/* 2 REG_OSC_32K_CTRL_8197F */
#define BIT_32K_CLK_OUT_RDY_8197F BIT(12)
#define BIT_SHIFT_MONITOR_CYCLE_LOG2_8197F 8
#define BIT_MASK_MONITOR_CYCLE_LOG2_8197F 0xf
#define BIT_MONITOR_CYCLE_LOG2_8197F(x) \
(((x) & BIT_MASK_MONITOR_CYCLE_LOG2_8197F) \
<< BIT_SHIFT_MONITOR_CYCLE_LOG2_8197F)
#define BITS_MONITOR_CYCLE_LOG2_8197F \
(BIT_MASK_MONITOR_CYCLE_LOG2_8197F \
<< BIT_SHIFT_MONITOR_CYCLE_LOG2_8197F)
#define BIT_CLEAR_MONITOR_CYCLE_LOG2_8197F(x) \
((x) & (~BITS_MONITOR_CYCLE_LOG2_8197F))
#define BIT_GET_MONITOR_CYCLE_LOG2_8197F(x) \
(((x) >> BIT_SHIFT_MONITOR_CYCLE_LOG2_8197F) & \
BIT_MASK_MONITOR_CYCLE_LOG2_8197F)
#define BIT_SET_MONITOR_CYCLE_LOG2_8197F(x, v) \
(BIT_CLEAR_MONITOR_CYCLE_LOG2_8197F(x) | \
BIT_MONITOR_CYCLE_LOG2_8197F(v))
/* 2 REG_32K_CAL_REG1_8197F */
#define BIT_SHIFT_FREQVALUE_UNREGCLK_8197F 8
#define BIT_MASK_FREQVALUE_UNREGCLK_8197F 0xffffff
#define BIT_FREQVALUE_UNREGCLK_8197F(x) \
(((x) & BIT_MASK_FREQVALUE_UNREGCLK_8197F) \
<< BIT_SHIFT_FREQVALUE_UNREGCLK_8197F)
#define BITS_FREQVALUE_UNREGCLK_8197F \
(BIT_MASK_FREQVALUE_UNREGCLK_8197F \
<< BIT_SHIFT_FREQVALUE_UNREGCLK_8197F)
#define BIT_CLEAR_FREQVALUE_UNREGCLK_8197F(x) \
((x) & (~BITS_FREQVALUE_UNREGCLK_8197F))
#define BIT_GET_FREQVALUE_UNREGCLK_8197F(x) \
(((x) >> BIT_SHIFT_FREQVALUE_UNREGCLK_8197F) & \
BIT_MASK_FREQVALUE_UNREGCLK_8197F)
#define BIT_SET_FREQVALUE_UNREGCLK_8197F(x, v) \
(BIT_CLEAR_FREQVALUE_UNREGCLK_8197F(x) | \
BIT_FREQVALUE_UNREGCLK_8197F(v))
#define BIT_CAL32K_DBGMOD_8197F BIT(7)
#define BIT_SHIFT_NCO_THRS_8197F 0
#define BIT_MASK_NCO_THRS_8197F 0x7f
#define BIT_NCO_THRS_8197F(x) \
(((x) & BIT_MASK_NCO_THRS_8197F) << BIT_SHIFT_NCO_THRS_8197F)
#define BITS_NCO_THRS_8197F \
(BIT_MASK_NCO_THRS_8197F << BIT_SHIFT_NCO_THRS_8197F)
#define BIT_CLEAR_NCO_THRS_8197F(x) ((x) & (~BITS_NCO_THRS_8197F))
#define BIT_GET_NCO_THRS_8197F(x) \
(((x) >> BIT_SHIFT_NCO_THRS_8197F) & BIT_MASK_NCO_THRS_8197F)
#define BIT_SET_NCO_THRS_8197F(x, v) \
(BIT_CLEAR_NCO_THRS_8197F(x) | BIT_NCO_THRS_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_C2HEVT_8197F */
#define BIT_SHIFT_C2HEVT_MSG_8197F 0
#define BIT_MASK_C2HEVT_MSG_8197F 0xffffffffffffffffffffffffffffffffL
#define BIT_C2HEVT_MSG_8197F(x) \
(((x) & BIT_MASK_C2HEVT_MSG_8197F) << BIT_SHIFT_C2HEVT_MSG_8197F)
#define BITS_C2HEVT_MSG_8197F \
(BIT_MASK_C2HEVT_MSG_8197F << BIT_SHIFT_C2HEVT_MSG_8197F)
#define BIT_CLEAR_C2HEVT_MSG_8197F(x) ((x) & (~BITS_C2HEVT_MSG_8197F))
#define BIT_GET_C2HEVT_MSG_8197F(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_8197F) & BIT_MASK_C2HEVT_MSG_8197F)
#define BIT_SET_C2HEVT_MSG_8197F(x, v) \
(BIT_CLEAR_C2HEVT_MSG_8197F(x) | BIT_C2HEVT_MSG_8197F(v))
/* 2 REG_SW_DEFINED_PAGE1_8197F */
#define BIT_SHIFT_SW_DEFINED_PAGE1_8197F 0
#define BIT_MASK_SW_DEFINED_PAGE1_8197F 0xffffffffffffffffL
#define BIT_SW_DEFINED_PAGE1_8197F(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1_8197F) \
<< BIT_SHIFT_SW_DEFINED_PAGE1_8197F)
#define BITS_SW_DEFINED_PAGE1_8197F \
(BIT_MASK_SW_DEFINED_PAGE1_8197F << BIT_SHIFT_SW_DEFINED_PAGE1_8197F)
#define BIT_CLEAR_SW_DEFINED_PAGE1_8197F(x) \
((x) & (~BITS_SW_DEFINED_PAGE1_8197F))
#define BIT_GET_SW_DEFINED_PAGE1_8197F(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1_8197F) & \
BIT_MASK_SW_DEFINED_PAGE1_8197F)
#define BIT_SET_SW_DEFINED_PAGE1_8197F(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1_8197F(x) | BIT_SW_DEFINED_PAGE1_8197F(v))
/* 2 REG_MCUTST_I_8197F */
#define BIT_SHIFT_MCUDMSG_I_8197F 0
#define BIT_MASK_MCUDMSG_I_8197F 0xffffffffL
#define BIT_MCUDMSG_I_8197F(x) \
(((x) & BIT_MASK_MCUDMSG_I_8197F) << BIT_SHIFT_MCUDMSG_I_8197F)
#define BITS_MCUDMSG_I_8197F \
(BIT_MASK_MCUDMSG_I_8197F << BIT_SHIFT_MCUDMSG_I_8197F)
#define BIT_CLEAR_MCUDMSG_I_8197F(x) ((x) & (~BITS_MCUDMSG_I_8197F))
#define BIT_GET_MCUDMSG_I_8197F(x) \
(((x) >> BIT_SHIFT_MCUDMSG_I_8197F) & BIT_MASK_MCUDMSG_I_8197F)
#define BIT_SET_MCUDMSG_I_8197F(x, v) \
(BIT_CLEAR_MCUDMSG_I_8197F(x) | BIT_MCUDMSG_I_8197F(v))
/* 2 REG_MCUTST_II_8197F */
#define BIT_SHIFT_MCUDMSG_II_8197F 0
#define BIT_MASK_MCUDMSG_II_8197F 0xffffffffL
#define BIT_MCUDMSG_II_8197F(x) \
(((x) & BIT_MASK_MCUDMSG_II_8197F) << BIT_SHIFT_MCUDMSG_II_8197F)
#define BITS_MCUDMSG_II_8197F \
(BIT_MASK_MCUDMSG_II_8197F << BIT_SHIFT_MCUDMSG_II_8197F)
#define BIT_CLEAR_MCUDMSG_II_8197F(x) ((x) & (~BITS_MCUDMSG_II_8197F))
#define BIT_GET_MCUDMSG_II_8197F(x) \
(((x) >> BIT_SHIFT_MCUDMSG_II_8197F) & BIT_MASK_MCUDMSG_II_8197F)
#define BIT_SET_MCUDMSG_II_8197F(x, v) \
(BIT_CLEAR_MCUDMSG_II_8197F(x) | BIT_MCUDMSG_II_8197F(v))
/* 2 REG_FMETHR_8197F */
#define BIT_FMSG_INT_8197F BIT(31)
#define BIT_SHIFT_FW_MSG_8197F 0
#define BIT_MASK_FW_MSG_8197F 0xffffffffL
#define BIT_FW_MSG_8197F(x) \
(((x) & BIT_MASK_FW_MSG_8197F) << BIT_SHIFT_FW_MSG_8197F)
#define BITS_FW_MSG_8197F (BIT_MASK_FW_MSG_8197F << BIT_SHIFT_FW_MSG_8197F)
#define BIT_CLEAR_FW_MSG_8197F(x) ((x) & (~BITS_FW_MSG_8197F))
#define BIT_GET_FW_MSG_8197F(x) \
(((x) >> BIT_SHIFT_FW_MSG_8197F) & BIT_MASK_FW_MSG_8197F)
#define BIT_SET_FW_MSG_8197F(x, v) \
(BIT_CLEAR_FW_MSG_8197F(x) | BIT_FW_MSG_8197F(v))
/* 2 REG_HMETFR_8197F */
#define BIT_SHIFT_HRCV_MSG_8197F 24
#define BIT_MASK_HRCV_MSG_8197F 0xff
#define BIT_HRCV_MSG_8197F(x) \
(((x) & BIT_MASK_HRCV_MSG_8197F) << BIT_SHIFT_HRCV_MSG_8197F)
#define BITS_HRCV_MSG_8197F \
(BIT_MASK_HRCV_MSG_8197F << BIT_SHIFT_HRCV_MSG_8197F)
#define BIT_CLEAR_HRCV_MSG_8197F(x) ((x) & (~BITS_HRCV_MSG_8197F))
#define BIT_GET_HRCV_MSG_8197F(x) \
(((x) >> BIT_SHIFT_HRCV_MSG_8197F) & BIT_MASK_HRCV_MSG_8197F)
#define BIT_SET_HRCV_MSG_8197F(x, v) \
(BIT_CLEAR_HRCV_MSG_8197F(x) | BIT_HRCV_MSG_8197F(v))
#define BIT_INT_BOX3_8197F BIT(3)
#define BIT_INT_BOX2_8197F BIT(2)
#define BIT_INT_BOX1_8197F BIT(1)
#define BIT_INT_BOX0_8197F BIT(0)
/* 2 REG_HMEBOX0_8197F */
#define BIT_SHIFT_HOST_MSG_0_8197F 0
#define BIT_MASK_HOST_MSG_0_8197F 0xffffffffL
#define BIT_HOST_MSG_0_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_0_8197F) << BIT_SHIFT_HOST_MSG_0_8197F)
#define BITS_HOST_MSG_0_8197F \
(BIT_MASK_HOST_MSG_0_8197F << BIT_SHIFT_HOST_MSG_0_8197F)
#define BIT_CLEAR_HOST_MSG_0_8197F(x) ((x) & (~BITS_HOST_MSG_0_8197F))
#define BIT_GET_HOST_MSG_0_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_0_8197F) & BIT_MASK_HOST_MSG_0_8197F)
#define BIT_SET_HOST_MSG_0_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_0_8197F(x) | BIT_HOST_MSG_0_8197F(v))
/* 2 REG_HMEBOX1_8197F */
#define BIT_SHIFT_HOST_MSG_1_8197F 0
#define BIT_MASK_HOST_MSG_1_8197F 0xffffffffL
#define BIT_HOST_MSG_1_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_1_8197F) << BIT_SHIFT_HOST_MSG_1_8197F)
#define BITS_HOST_MSG_1_8197F \
(BIT_MASK_HOST_MSG_1_8197F << BIT_SHIFT_HOST_MSG_1_8197F)
#define BIT_CLEAR_HOST_MSG_1_8197F(x) ((x) & (~BITS_HOST_MSG_1_8197F))
#define BIT_GET_HOST_MSG_1_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_1_8197F) & BIT_MASK_HOST_MSG_1_8197F)
#define BIT_SET_HOST_MSG_1_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_1_8197F(x) | BIT_HOST_MSG_1_8197F(v))
/* 2 REG_HMEBOX2_8197F */
#define BIT_SHIFT_HOST_MSG_2_8197F 0
#define BIT_MASK_HOST_MSG_2_8197F 0xffffffffL
#define BIT_HOST_MSG_2_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_2_8197F) << BIT_SHIFT_HOST_MSG_2_8197F)
#define BITS_HOST_MSG_2_8197F \
(BIT_MASK_HOST_MSG_2_8197F << BIT_SHIFT_HOST_MSG_2_8197F)
#define BIT_CLEAR_HOST_MSG_2_8197F(x) ((x) & (~BITS_HOST_MSG_2_8197F))
#define BIT_GET_HOST_MSG_2_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_2_8197F) & BIT_MASK_HOST_MSG_2_8197F)
#define BIT_SET_HOST_MSG_2_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_2_8197F(x) | BIT_HOST_MSG_2_8197F(v))
/* 2 REG_HMEBOX3_8197F */
#define BIT_SHIFT_HOST_MSG_3_8197F 0
#define BIT_MASK_HOST_MSG_3_8197F 0xffffffffL
#define BIT_HOST_MSG_3_8197F(x) \
(((x) & BIT_MASK_HOST_MSG_3_8197F) << BIT_SHIFT_HOST_MSG_3_8197F)
#define BITS_HOST_MSG_3_8197F \
(BIT_MASK_HOST_MSG_3_8197F << BIT_SHIFT_HOST_MSG_3_8197F)
#define BIT_CLEAR_HOST_MSG_3_8197F(x) ((x) & (~BITS_HOST_MSG_3_8197F))
#define BIT_GET_HOST_MSG_3_8197F(x) \
(((x) >> BIT_SHIFT_HOST_MSG_3_8197F) & BIT_MASK_HOST_MSG_3_8197F)
#define BIT_SET_HOST_MSG_3_8197F(x, v) \
(BIT_CLEAR_HOST_MSG_3_8197F(x) | BIT_HOST_MSG_3_8197F(v))
/* 2 REG_LLT_INIT_8197F */
#define BIT_SHIFT_LLTE_RWM_8197F 30
#define BIT_MASK_LLTE_RWM_8197F 0x3
#define BIT_LLTE_RWM_8197F(x) \
(((x) & BIT_MASK_LLTE_RWM_8197F) << BIT_SHIFT_LLTE_RWM_8197F)
#define BITS_LLTE_RWM_8197F \
(BIT_MASK_LLTE_RWM_8197F << BIT_SHIFT_LLTE_RWM_8197F)
#define BIT_CLEAR_LLTE_RWM_8197F(x) ((x) & (~BITS_LLTE_RWM_8197F))
#define BIT_GET_LLTE_RWM_8197F(x) \
(((x) >> BIT_SHIFT_LLTE_RWM_8197F) & BIT_MASK_LLTE_RWM_8197F)
#define BIT_SET_LLTE_RWM_8197F(x, v) \
(BIT_CLEAR_LLTE_RWM_8197F(x) | BIT_LLTE_RWM_8197F(v))
#define BIT_SHIFT_LLTINI_PDATA_V1_8197F 16
#define BIT_MASK_LLTINI_PDATA_V1_8197F 0xfff
#define BIT_LLTINI_PDATA_V1_8197F(x) \
(((x) & BIT_MASK_LLTINI_PDATA_V1_8197F) \
<< BIT_SHIFT_LLTINI_PDATA_V1_8197F)
#define BITS_LLTINI_PDATA_V1_8197F \
(BIT_MASK_LLTINI_PDATA_V1_8197F << BIT_SHIFT_LLTINI_PDATA_V1_8197F)
#define BIT_CLEAR_LLTINI_PDATA_V1_8197F(x) ((x) & (~BITS_LLTINI_PDATA_V1_8197F))
#define BIT_GET_LLTINI_PDATA_V1_8197F(x) \
(((x) >> BIT_SHIFT_LLTINI_PDATA_V1_8197F) & \
BIT_MASK_LLTINI_PDATA_V1_8197F)
#define BIT_SET_LLTINI_PDATA_V1_8197F(x, v) \
(BIT_CLEAR_LLTINI_PDATA_V1_8197F(x) | BIT_LLTINI_PDATA_V1_8197F(v))
#define BIT_SHIFT_LLTINI_HDATA_V1_8197F 0
#define BIT_MASK_LLTINI_HDATA_V1_8197F 0xfff
#define BIT_LLTINI_HDATA_V1_8197F(x) \
(((x) & BIT_MASK_LLTINI_HDATA_V1_8197F) \
<< BIT_SHIFT_LLTINI_HDATA_V1_8197F)
#define BITS_LLTINI_HDATA_V1_8197F \
(BIT_MASK_LLTINI_HDATA_V1_8197F << BIT_SHIFT_LLTINI_HDATA_V1_8197F)
#define BIT_CLEAR_LLTINI_HDATA_V1_8197F(x) ((x) & (~BITS_LLTINI_HDATA_V1_8197F))
#define BIT_GET_LLTINI_HDATA_V1_8197F(x) \
(((x) >> BIT_SHIFT_LLTINI_HDATA_V1_8197F) & \
BIT_MASK_LLTINI_HDATA_V1_8197F)
#define BIT_SET_LLTINI_HDATA_V1_8197F(x, v) \
(BIT_CLEAR_LLTINI_HDATA_V1_8197F(x) | BIT_LLTINI_HDATA_V1_8197F(v))
/* 2 REG_LLT_INIT_ADDR_8197F */
#define BIT_SHIFT_LLTINI_ADDR_V1_8197F 0
#define BIT_MASK_LLTINI_ADDR_V1_8197F 0xfff
#define BIT_LLTINI_ADDR_V1_8197F(x) \
(((x) & BIT_MASK_LLTINI_ADDR_V1_8197F) \
<< BIT_SHIFT_LLTINI_ADDR_V1_8197F)
#define BITS_LLTINI_ADDR_V1_8197F \
(BIT_MASK_LLTINI_ADDR_V1_8197F << BIT_SHIFT_LLTINI_ADDR_V1_8197F)
#define BIT_CLEAR_LLTINI_ADDR_V1_8197F(x) ((x) & (~BITS_LLTINI_ADDR_V1_8197F))
#define BIT_GET_LLTINI_ADDR_V1_8197F(x) \
(((x) >> BIT_SHIFT_LLTINI_ADDR_V1_8197F) & \
BIT_MASK_LLTINI_ADDR_V1_8197F)
#define BIT_SET_LLTINI_ADDR_V1_8197F(x, v) \
(BIT_CLEAR_LLTINI_ADDR_V1_8197F(x) | BIT_LLTINI_ADDR_V1_8197F(v))
/* 2 REG_BB_ACCESS_CTRL_8197F */
#define BIT_SHIFT_BB_WRITE_READ_8197F 30
#define BIT_MASK_BB_WRITE_READ_8197F 0x3
#define BIT_BB_WRITE_READ_8197F(x) \
(((x) & BIT_MASK_BB_WRITE_READ_8197F) << BIT_SHIFT_BB_WRITE_READ_8197F)
#define BITS_BB_WRITE_READ_8197F \
(BIT_MASK_BB_WRITE_READ_8197F << BIT_SHIFT_BB_WRITE_READ_8197F)
#define BIT_CLEAR_BB_WRITE_READ_8197F(x) ((x) & (~BITS_BB_WRITE_READ_8197F))
#define BIT_GET_BB_WRITE_READ_8197F(x) \
(((x) >> BIT_SHIFT_BB_WRITE_READ_8197F) & BIT_MASK_BB_WRITE_READ_8197F)
#define BIT_SET_BB_WRITE_READ_8197F(x, v) \
(BIT_CLEAR_BB_WRITE_READ_8197F(x) | BIT_BB_WRITE_READ_8197F(v))
#define BIT_SHIFT_BB_WRITE_EN_V1_8197F 16
#define BIT_MASK_BB_WRITE_EN_V1_8197F 0xf
#define BIT_BB_WRITE_EN_V1_8197F(x) \
(((x) & BIT_MASK_BB_WRITE_EN_V1_8197F) \
<< BIT_SHIFT_BB_WRITE_EN_V1_8197F)
#define BITS_BB_WRITE_EN_V1_8197F \
(BIT_MASK_BB_WRITE_EN_V1_8197F << BIT_SHIFT_BB_WRITE_EN_V1_8197F)
#define BIT_CLEAR_BB_WRITE_EN_V1_8197F(x) ((x) & (~BITS_BB_WRITE_EN_V1_8197F))
#define BIT_GET_BB_WRITE_EN_V1_8197F(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN_V1_8197F) & \
BIT_MASK_BB_WRITE_EN_V1_8197F)
#define BIT_SET_BB_WRITE_EN_V1_8197F(x, v) \
(BIT_CLEAR_BB_WRITE_EN_V1_8197F(x) | BIT_BB_WRITE_EN_V1_8197F(v))
#define BIT_SHIFT_BB_ADDR_V1_8197F 2
#define BIT_MASK_BB_ADDR_V1_8197F 0xfff
#define BIT_BB_ADDR_V1_8197F(x) \
(((x) & BIT_MASK_BB_ADDR_V1_8197F) << BIT_SHIFT_BB_ADDR_V1_8197F)
#define BITS_BB_ADDR_V1_8197F \
(BIT_MASK_BB_ADDR_V1_8197F << BIT_SHIFT_BB_ADDR_V1_8197F)
#define BIT_CLEAR_BB_ADDR_V1_8197F(x) ((x) & (~BITS_BB_ADDR_V1_8197F))
#define BIT_GET_BB_ADDR_V1_8197F(x) \
(((x) >> BIT_SHIFT_BB_ADDR_V1_8197F) & BIT_MASK_BB_ADDR_V1_8197F)
#define BIT_SET_BB_ADDR_V1_8197F(x, v) \
(BIT_CLEAR_BB_ADDR_V1_8197F(x) | BIT_BB_ADDR_V1_8197F(v))
#define BIT_BB_ERRACC_8197F BIT(0)
/* 2 REG_BB_ACCESS_DATA_8197F */
#define BIT_SHIFT_BB_DATA_8197F 0
#define BIT_MASK_BB_DATA_8197F 0xffffffffL
#define BIT_BB_DATA_8197F(x) \
(((x) & BIT_MASK_BB_DATA_8197F) << BIT_SHIFT_BB_DATA_8197F)
#define BITS_BB_DATA_8197F (BIT_MASK_BB_DATA_8197F << BIT_SHIFT_BB_DATA_8197F)
#define BIT_CLEAR_BB_DATA_8197F(x) ((x) & (~BITS_BB_DATA_8197F))
#define BIT_GET_BB_DATA_8197F(x) \
(((x) >> BIT_SHIFT_BB_DATA_8197F) & BIT_MASK_BB_DATA_8197F)
#define BIT_SET_BB_DATA_8197F(x, v) \
(BIT_CLEAR_BB_DATA_8197F(x) | BIT_BB_DATA_8197F(v))
/* 2 REG_HMEBOX_E0_8197F */
#define BIT_SHIFT_HMEBOX_E0_8197F 0
#define BIT_MASK_HMEBOX_E0_8197F 0xffffffffL
#define BIT_HMEBOX_E0_8197F(x) \
(((x) & BIT_MASK_HMEBOX_E0_8197F) << BIT_SHIFT_HMEBOX_E0_8197F)
#define BITS_HMEBOX_E0_8197F \
(BIT_MASK_HMEBOX_E0_8197F << BIT_SHIFT_HMEBOX_E0_8197F)
#define BIT_CLEAR_HMEBOX_E0_8197F(x) ((x) & (~BITS_HMEBOX_E0_8197F))
#define BIT_GET_HMEBOX_E0_8197F(x) \
(((x) >> BIT_SHIFT_HMEBOX_E0_8197F) & BIT_MASK_HMEBOX_E0_8197F)
#define BIT_SET_HMEBOX_E0_8197F(x, v) \
(BIT_CLEAR_HMEBOX_E0_8197F(x) | BIT_HMEBOX_E0_8197F(v))
/* 2 REG_HMEBOX_E1_8197F */
#define BIT_SHIFT_HMEBOX_E1_8197F 0
#define BIT_MASK_HMEBOX_E1_8197F 0xffffffffL
#define BIT_HMEBOX_E1_8197F(x) \
(((x) & BIT_MASK_HMEBOX_E1_8197F) << BIT_SHIFT_HMEBOX_E1_8197F)
#define BITS_HMEBOX_E1_8197F \
(BIT_MASK_HMEBOX_E1_8197F << BIT_SHIFT_HMEBOX_E1_8197F)
#define BIT_CLEAR_HMEBOX_E1_8197F(x) ((x) & (~BITS_HMEBOX_E1_8197F))
#define BIT_GET_HMEBOX_E1_8197F(x) \
(((x) >> BIT_SHIFT_HMEBOX_E1_8197F) & BIT_MASK_HMEBOX_E1_8197F)
#define BIT_SET_HMEBOX_E1_8197F(x, v) \
(BIT_CLEAR_HMEBOX_E1_8197F(x) | BIT_HMEBOX_E1_8197F(v))
/* 2 REG_HMEBOX_E2_8197F */
#define BIT_SHIFT_HMEBOX_E2_8197F 0
#define BIT_MASK_HMEBOX_E2_8197F 0xffffffffL
#define BIT_HMEBOX_E2_8197F(x) \
(((x) & BIT_MASK_HMEBOX_E2_8197F) << BIT_SHIFT_HMEBOX_E2_8197F)
#define BITS_HMEBOX_E2_8197F \
(BIT_MASK_HMEBOX_E2_8197F << BIT_SHIFT_HMEBOX_E2_8197F)
#define BIT_CLEAR_HMEBOX_E2_8197F(x) ((x) & (~BITS_HMEBOX_E2_8197F))
#define BIT_GET_HMEBOX_E2_8197F(x) \
(((x) >> BIT_SHIFT_HMEBOX_E2_8197F) & BIT_MASK_HMEBOX_E2_8197F)
#define BIT_SET_HMEBOX_E2_8197F(x, v) \
(BIT_CLEAR_HMEBOX_E2_8197F(x) | BIT_HMEBOX_E2_8197F(v))
/* 2 REG_HMEBOX_E3_8197F */
#define BIT_SHIFT_HMEBOX_E3_8197F 0
#define BIT_MASK_HMEBOX_E3_8197F 0xffffffffL
#define BIT_HMEBOX_E3_8197F(x) \
(((x) & BIT_MASK_HMEBOX_E3_8197F) << BIT_SHIFT_HMEBOX_E3_8197F)
#define BITS_HMEBOX_E3_8197F \
(BIT_MASK_HMEBOX_E3_8197F << BIT_SHIFT_HMEBOX_E3_8197F)
#define BIT_CLEAR_HMEBOX_E3_8197F(x) ((x) & (~BITS_HMEBOX_E3_8197F))
#define BIT_GET_HMEBOX_E3_8197F(x) \
(((x) >> BIT_SHIFT_HMEBOX_E3_8197F) & BIT_MASK_HMEBOX_E3_8197F)
#define BIT_SET_HMEBOX_E3_8197F(x, v) \
(BIT_CLEAR_HMEBOX_E3_8197F(x) | BIT_HMEBOX_E3_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_CR_EXT_8197F */
#define BIT_SHIFT_PHY_REQ_DELAY_8197F 24
#define BIT_MASK_PHY_REQ_DELAY_8197F 0xf
#define BIT_PHY_REQ_DELAY_8197F(x) \
(((x) & BIT_MASK_PHY_REQ_DELAY_8197F) << BIT_SHIFT_PHY_REQ_DELAY_8197F)
#define BITS_PHY_REQ_DELAY_8197F \
(BIT_MASK_PHY_REQ_DELAY_8197F << BIT_SHIFT_PHY_REQ_DELAY_8197F)
#define BIT_CLEAR_PHY_REQ_DELAY_8197F(x) ((x) & (~BITS_PHY_REQ_DELAY_8197F))
#define BIT_GET_PHY_REQ_DELAY_8197F(x) \
(((x) >> BIT_SHIFT_PHY_REQ_DELAY_8197F) & BIT_MASK_PHY_REQ_DELAY_8197F)
#define BIT_SET_PHY_REQ_DELAY_8197F(x, v) \
(BIT_CLEAR_PHY_REQ_DELAY_8197F(x) | BIT_PHY_REQ_DELAY_8197F(v))
#define BIT_SPD_DOWN_8197F BIT(16)
#define BIT_SHIFT_NETYPE4_8197F 4
#define BIT_MASK_NETYPE4_8197F 0x3
#define BIT_NETYPE4_8197F(x) \
(((x) & BIT_MASK_NETYPE4_8197F) << BIT_SHIFT_NETYPE4_8197F)
#define BITS_NETYPE4_8197F (BIT_MASK_NETYPE4_8197F << BIT_SHIFT_NETYPE4_8197F)
#define BIT_CLEAR_NETYPE4_8197F(x) ((x) & (~BITS_NETYPE4_8197F))
#define BIT_GET_NETYPE4_8197F(x) \
(((x) >> BIT_SHIFT_NETYPE4_8197F) & BIT_MASK_NETYPE4_8197F)
#define BIT_SET_NETYPE4_8197F(x, v) \
(BIT_CLEAR_NETYPE4_8197F(x) | BIT_NETYPE4_8197F(v))
#define BIT_SHIFT_NETYPE3_8197F 2
#define BIT_MASK_NETYPE3_8197F 0x3
#define BIT_NETYPE3_8197F(x) \
(((x) & BIT_MASK_NETYPE3_8197F) << BIT_SHIFT_NETYPE3_8197F)
#define BITS_NETYPE3_8197F (BIT_MASK_NETYPE3_8197F << BIT_SHIFT_NETYPE3_8197F)
#define BIT_CLEAR_NETYPE3_8197F(x) ((x) & (~BITS_NETYPE3_8197F))
#define BIT_GET_NETYPE3_8197F(x) \
(((x) >> BIT_SHIFT_NETYPE3_8197F) & BIT_MASK_NETYPE3_8197F)
#define BIT_SET_NETYPE3_8197F(x, v) \
(BIT_CLEAR_NETYPE3_8197F(x) | BIT_NETYPE3_8197F(v))
#define BIT_SHIFT_NETYPE2_8197F 0
#define BIT_MASK_NETYPE2_8197F 0x3
#define BIT_NETYPE2_8197F(x) \
(((x) & BIT_MASK_NETYPE2_8197F) << BIT_SHIFT_NETYPE2_8197F)
#define BITS_NETYPE2_8197F (BIT_MASK_NETYPE2_8197F << BIT_SHIFT_NETYPE2_8197F)
#define BIT_CLEAR_NETYPE2_8197F(x) ((x) & (~BITS_NETYPE2_8197F))
#define BIT_GET_NETYPE2_8197F(x) \
(((x) >> BIT_SHIFT_NETYPE2_8197F) & BIT_MASK_NETYPE2_8197F)
#define BIT_SET_NETYPE2_8197F(x, v) \
(BIT_CLEAR_NETYPE2_8197F(x) | BIT_NETYPE2_8197F(v))
/* 2 REG_FWFF_8197F */
#define BIT_SHIFT_PKTNUM_TH_8197F 24
#define BIT_MASK_PKTNUM_TH_8197F 0xff
#define BIT_PKTNUM_TH_8197F(x) \
(((x) & BIT_MASK_PKTNUM_TH_8197F) << BIT_SHIFT_PKTNUM_TH_8197F)
#define BITS_PKTNUM_TH_8197F \
(BIT_MASK_PKTNUM_TH_8197F << BIT_SHIFT_PKTNUM_TH_8197F)
#define BIT_CLEAR_PKTNUM_TH_8197F(x) ((x) & (~BITS_PKTNUM_TH_8197F))
#define BIT_GET_PKTNUM_TH_8197F(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_8197F) & BIT_MASK_PKTNUM_TH_8197F)
#define BIT_SET_PKTNUM_TH_8197F(x, v) \
(BIT_CLEAR_PKTNUM_TH_8197F(x) | BIT_PKTNUM_TH_8197F(v))
#define BIT_SHIFT_TIMER_TH_8197F 16
#define BIT_MASK_TIMER_TH_8197F 0xff
#define BIT_TIMER_TH_8197F(x) \
(((x) & BIT_MASK_TIMER_TH_8197F) << BIT_SHIFT_TIMER_TH_8197F)
#define BITS_TIMER_TH_8197F \
(BIT_MASK_TIMER_TH_8197F << BIT_SHIFT_TIMER_TH_8197F)
#define BIT_CLEAR_TIMER_TH_8197F(x) ((x) & (~BITS_TIMER_TH_8197F))
#define BIT_GET_TIMER_TH_8197F(x) \
(((x) >> BIT_SHIFT_TIMER_TH_8197F) & BIT_MASK_TIMER_TH_8197F)
#define BIT_SET_TIMER_TH_8197F(x, v) \
(BIT_CLEAR_TIMER_TH_8197F(x) | BIT_TIMER_TH_8197F(v))
#define BIT_SHIFT_RXPKT1ENADDR_8197F 0
#define BIT_MASK_RXPKT1ENADDR_8197F 0xffff
#define BIT_RXPKT1ENADDR_8197F(x) \
(((x) & BIT_MASK_RXPKT1ENADDR_8197F) << BIT_SHIFT_RXPKT1ENADDR_8197F)
#define BITS_RXPKT1ENADDR_8197F \
(BIT_MASK_RXPKT1ENADDR_8197F << BIT_SHIFT_RXPKT1ENADDR_8197F)
#define BIT_CLEAR_RXPKT1ENADDR_8197F(x) ((x) & (~BITS_RXPKT1ENADDR_8197F))
#define BIT_GET_RXPKT1ENADDR_8197F(x) \
(((x) >> BIT_SHIFT_RXPKT1ENADDR_8197F) & BIT_MASK_RXPKT1ENADDR_8197F)
#define BIT_SET_RXPKT1ENADDR_8197F(x, v) \
(BIT_CLEAR_RXPKT1ENADDR_8197F(x) | BIT_RXPKT1ENADDR_8197F(v))
/* 2 REG_RXFF_PTR_V1_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_RXFF0_RDPTR_V2_8197F 0
#define BIT_MASK_RXFF0_RDPTR_V2_8197F 0x3ffff
#define BIT_RXFF0_RDPTR_V2_8197F(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V2_8197F) \
<< BIT_SHIFT_RXFF0_RDPTR_V2_8197F)
#define BITS_RXFF0_RDPTR_V2_8197F \
(BIT_MASK_RXFF0_RDPTR_V2_8197F << BIT_SHIFT_RXFF0_RDPTR_V2_8197F)
#define BIT_CLEAR_RXFF0_RDPTR_V2_8197F(x) ((x) & (~BITS_RXFF0_RDPTR_V2_8197F))
#define BIT_GET_RXFF0_RDPTR_V2_8197F(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V2_8197F) & \
BIT_MASK_RXFF0_RDPTR_V2_8197F)
#define BIT_SET_RXFF0_RDPTR_V2_8197F(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V2_8197F(x) | BIT_RXFF0_RDPTR_V2_8197F(v))
/* 2 REG_RXFF_WTR_V1_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_RXFF0_WTPTR_V2_8197F 0
#define BIT_MASK_RXFF0_WTPTR_V2_8197F 0x3ffff
#define BIT_RXFF0_WTPTR_V2_8197F(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V2_8197F) \
<< BIT_SHIFT_RXFF0_WTPTR_V2_8197F)
#define BITS_RXFF0_WTPTR_V2_8197F \
(BIT_MASK_RXFF0_WTPTR_V2_8197F << BIT_SHIFT_RXFF0_WTPTR_V2_8197F)
#define BIT_CLEAR_RXFF0_WTPTR_V2_8197F(x) ((x) & (~BITS_RXFF0_WTPTR_V2_8197F))
#define BIT_GET_RXFF0_WTPTR_V2_8197F(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V2_8197F) & \
BIT_MASK_RXFF0_WTPTR_V2_8197F)
#define BIT_SET_RXFF0_WTPTR_V2_8197F(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V2_8197F(x) | BIT_RXFF0_WTPTR_V2_8197F(v))
/* 2 REG_FE2IMR_8197F */
#define BIT_FS_TXSC_DESC_DONE_INT_EN_8197F BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_EN_8197F BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_EN_8197F BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_EN_8197F BIT(25)
#define BIT_FS_TXSC_VODONE_INT_EN_8197F BIT(24)
#define BIT_FS_ATIM_MB7_INT_EN_8197F BIT(23)
#define BIT_FS_ATIM_MB6_INT_EN_8197F BIT(22)
#define BIT_FS_ATIM_MB5_INT_EN_8197F BIT(21)
#define BIT_FS_ATIM_MB4_INT_EN_8197F BIT(20)
#define BIT_FS_ATIM_MB3_INT_EN_8197F BIT(19)
#define BIT_FS_ATIM_MB2_INT_EN_8197F BIT(18)
#define BIT_FS_ATIM_MB1_INT_EN_8197F BIT(17)
#define BIT_FS_ATIM_MB0_INT_EN_8197F BIT(16)
#define BIT_FS_TBTT4INT_EN_8197F BIT(11)
#define BIT_FS_TBTT3INT_EN_8197F BIT(10)
#define BIT_FS_TBTT2INT_EN_8197F BIT(9)
#define BIT_FS_TBTT1INT_EN_8197F BIT(8)
#define BIT_FS_TBTT0_MB7INT_EN_8197F BIT(7)
#define BIT_FS_TBTT0_MB6INT_EN_8197F BIT(6)
#define BIT_FS_TBTT0_MB5INT_EN_8197F BIT(5)
#define BIT_FS_TBTT0_MB4INT_EN_8197F BIT(4)
#define BIT_FS_TBTT0_MB3INT_EN_8197F BIT(3)
#define BIT_FS_TBTT0_MB2INT_EN_8197F BIT(2)
#define BIT_FS_TBTT0_MB1INT_EN_8197F BIT(1)
#define BIT_FS_TBTT0_INT_EN_8197F BIT(0)
/* 2 REG_FE2ISR_8197F */
#define BIT_FS_TXSC_DESC_DONE_INT_8197F BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_8197F BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_8197F BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_8197F BIT(25)
#define BIT_FS_TXSC_VODONE_INT_8197F BIT(24)
#define BIT_FS_ATIM_MB7_INT_8197F BIT(23)
#define BIT_FS_ATIM_MB6_INT_8197F BIT(22)
#define BIT_FS_ATIM_MB5_INT_8197F BIT(21)
#define BIT_FS_ATIM_MB4_INT_8197F BIT(20)
#define BIT_FS_ATIM_MB3_INT_8197F BIT(19)
#define BIT_FS_ATIM_MB2_INT_8197F BIT(18)
#define BIT_FS_ATIM_MB1_INT_8197F BIT(17)
#define BIT_FS_ATIM_MB0_INT_8197F BIT(16)
#define BIT_FS_TBTT4INT_8197F BIT(11)
#define BIT_FS_TBTT3INT_8197F BIT(10)
#define BIT_FS_TBTT2INT_8197F BIT(9)
#define BIT_FS_TBTT1INT_8197F BIT(8)
#define BIT_FS_TBTT0_MB7INT_8197F BIT(7)
#define BIT_FS_TBTT0_MB6INT_8197F BIT(6)
#define BIT_FS_TBTT0_MB5INT_8197F BIT(5)
#define BIT_FS_TBTT0_MB4INT_8197F BIT(4)
#define BIT_FS_TBTT0_MB3INT_8197F BIT(3)
#define BIT_FS_TBTT0_MB2INT_8197F BIT(2)
#define BIT_FS_TBTT0_MB1INT_8197F BIT(1)
#define BIT_FS_TBTT0_INT_8197F BIT(0)
/* 2 REG_FE3IMR_8197F */
#define BIT_FS_BCNELY4_AGGR_INT_EN_8197F BIT(31)
#define BIT_FS_BCNELY3_AGGR_INT_EN_8197F BIT(30)
#define BIT_FS_BCNELY2_AGGR_INT_EN_8197F BIT(29)
#define BIT_FS_BCNELY1_AGGR_INT_EN_8197F BIT(28)
#define BIT_FS_BCNDMA4_INT_EN_8197F BIT(27)
#define BIT_FS_BCNDMA3_INT_EN_8197F BIT(26)
#define BIT_FS_BCNDMA2_INT_EN_8197F BIT(25)
#define BIT_FS_BCNDMA1_INT_EN_8197F BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_EN_8197F BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_EN_8197F BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_EN_8197F BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_EN_8197F BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_EN_8197F BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_EN_8197F BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_EN_8197F BIT(17)
#define BIT_FS_BCNDMA0_INT_EN_8197F BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT__EN_8197F BIT(15)
#define BIT_FS_BCNERLY4_INT_EN_8197F BIT(11)
#define BIT_FS_BCNERLY3_INT_EN_8197F BIT(10)
#define BIT_FS_BCNERLY2_INT_EN_8197F BIT(9)
#define BIT_FS_BCNERLY1_INT_EN_8197F BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_EN_8197F BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_EN_8197F BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_EN_8197F BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_EN_8197F BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_EN_8197F BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_EN_8197F BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_EN_8197F BIT(1)
#define BIT_FS_BCNERLY0_INT_EN_8197F BIT(0)
/* 2 REG_FE3ISR_8197F */
#define BIT_FS_BCNELY4_AGGR_INT_8197F BIT(31)
#define BIT_FS_BCNELY3_AGGR_INT_8197F BIT(30)
#define BIT_FS_BCNELY2_AGGR_INT_8197F BIT(29)
#define BIT_FS_BCNELY1_AGGR_INT_8197F BIT(28)
#define BIT_FS_BCNDMA4_INT_8197F BIT(27)
#define BIT_FS_BCNDMA3_INT_8197F BIT(26)
#define BIT_FS_BCNDMA2_INT_8197F BIT(25)
#define BIT_FS_BCNDMA1_INT_8197F BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_8197F BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_8197F BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_8197F BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_8197F BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_8197F BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_8197F BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_8197F BIT(17)
#define BIT_FS_BCNDMA0_INT_8197F BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT_8197F BIT(15)
#define BIT_FS_BCNERLY4_INT_8197F BIT(11)
#define BIT_FS_BCNERLY3_INT_8197F BIT(10)
#define BIT_FS_BCNERLY2_INT_8197F BIT(9)
#define BIT_FS_BCNERLY1_INT_8197F BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_8197F BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_8197F BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_8197F BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_8197F BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_8197F BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_8197F BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_8197F BIT(1)
#define BIT_FS_BCNERLY0_INT_8197F BIT(0)
/* 2 REG_FE4IMR_8197F */
#define BIT_PORT4_PKTIN_INT_EN_8197F BIT(19)
#define BIT_PORT3_PKTIN_INT_EN_8197F BIT(18)
#define BIT_PORT2_PKTIN_INT_EN_8197F BIT(17)
#define BIT_PORT1_PKTIN_INT_EN_8197F BIT(16)
#define BIT_PORT4_RXUCMD0_OK_INT_EN_8197F BIT(15)
#define BIT_PORT4_RXUCMD1_OK_INT_EN_8197F BIT(14)
#define BIT_PORT4_RXBCMD0_OK_INT_EN_8197F BIT(13)
#define BIT_PORT4_RXBCMD1_OK_INT_EN_8197F BIT(12)
#define BIT_PORT3_RXUCMD0_OK_INT_EN_8197F BIT(11)
#define BIT_PORT3_RXUCMD1_OK_INT_EN_8197F BIT(10)
#define BIT_PORT3_RXBCMD0_OK_INT_EN_8197F BIT(9)
#define BIT_PORT3_RXBCMD1_OK_INT_EN_8197F BIT(8)
#define BIT_PORT2_RXUCMD0_OK_INT_EN_8197F BIT(7)
#define BIT_PORT2_RXUCMD1_OK_INT_EN_8197F BIT(6)
#define BIT_PORT2_RXBCMD0_OK_INT_EN_8197F BIT(5)
#define BIT_PORT2_RXBCMD1_OK_INT_EN_8197F BIT(4)
#define BIT_PORT1_RXUCMD0_OK_INT_EN_8197F BIT(3)
#define BIT_PORT1_RXUCMD1_OK_INT_EN_8197F BIT(2)
#define BIT_PORT1_RXBCMD0_OK_INT_EN_8197F BIT(1)
#define BIT_PORT1_RXBCMD1_OK_INT_EN_8197F BIT(0)
/* 2 REG_FE4ISR_8197F */
#define BIT_PORT4_PKTIN_INT_8197F BIT(19)
#define BIT_PORT3_PKTIN_INT_8197F BIT(18)
#define BIT_PORT2_PKTIN_INT_8197F BIT(17)
#define BIT_PORT1_PKTIN_INT_8197F BIT(16)
#define BIT_PORT4_RXUCMD0_OK_INT_8197F BIT(15)
#define BIT_PORT4_RXUCMD1_OK_INT_8197F BIT(14)
#define BIT_PORT4_RXBCMD0_OK_INT_8197F BIT(13)
#define BIT_PORT4_RXBCMD1_OK_INT_8197F BIT(12)
#define BIT_PORT3_RXUCMD0_OK_INT_8197F BIT(11)
#define BIT_PORT3_RXUCMD1_OK_INT_8197F BIT(10)
#define BIT_PORT3_RXBCMD0_OK_INT_8197F BIT(9)
#define BIT_PORT3_RXBCMD1_OK_INT_8197F BIT(8)
#define BIT_PORT2_RXUCMD0_OK_INT_8197F BIT(7)
#define BIT_PORT2_RXUCMD1_OK_INT_8197F BIT(6)
#define BIT_PORT2_RXBCMD0_OK_INT_8197F BIT(5)
#define BIT_PORT2_RXBCMD1_OK_INT_8197F BIT(4)
#define BIT_PORT1_RXUCMD0_OK_INT_8197F BIT(3)
#define BIT_PORT1_RXUCMD1_OK_INT_8197F BIT(2)
#define BIT_PORT1_RXBCMD0_OK_INT_8197F BIT(1)
#define BIT_PORT1_RXBCMD1_OK_INT_8197F BIT(0)
/* 2 REG_FT1IMR_8197F */
#define BIT__FT2ISR__IND_MSK_8197F BIT(30)
#define BIT_FTM_PTT_INT_EN_8197F BIT(29)
#define BIT_RXFTMREQ_INT_EN_8197F BIT(28)
#define BIT_RXFTM_INT_EN_8197F BIT(27)
#define BIT_TXFTM_INT_EN_8197F BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_EN_8197F BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_EN_8197F BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_EN_8197F BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_EN_8197F BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_EN_8197F BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_EN_8197F BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_EN_8197F BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_EN_8197F BIT(18)
#define BIT_FS_CTWEND2_INT_EN_8197F BIT(17)
#define BIT_FS_CTWEND1_INT_EN_8197F BIT(16)
#define BIT_FS_CTWEND0_INT_EN_8197F BIT(15)
#define BIT_FS_TX_NULL1_INT_EN_8197F BIT(14)
#define BIT_FS_TX_NULL0_INT_EN_8197F BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_EN_8197F BIT(12)
#define BIT_FS_P2P_RFON2_INT_EN_8197F BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_EN_8197F BIT(10)
#define BIT_FS_P2P_RFON1_INT_EN_8197F BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_EN_8197F BIT(8)
#define BIT_FS_P2P_RFON0_INT_EN_8197F BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_EN_8197F BIT(6)
#define BIT_FS_RX_UAPSDMD1_EN_8197F BIT(5)
#define BIT_FS_RX_UAPSDMD0_EN_8197F BIT(4)
#define BIT_FS_TRIGGER_PKT_EN_8197F BIT(3)
#define BIT_FS_EOSP_INT_EN_8197F BIT(2)
#define BIT_FS_RPWM2_INT_EN_8197F BIT(1)
#define BIT_FS_RPWM_INT_EN_8197F BIT(0)
/* 2 REG_FT1ISR_8197F */
#define BIT__FT2ISR__IND_INT_8197F BIT(30)
#define BIT_FTM_PTT_INT_8197F BIT(29)
#define BIT_RXFTMREQ_INT_8197F BIT(28)
#define BIT_RXFTM_INT_8197F BIT(27)
#define BIT_TXFTM_INT_8197F BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_8197F BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_8197F BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_8197F BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_8197F BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_8197F BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_8197F BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_8197F BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_8197F BIT(18)
#define BIT_FS_CTWEND2_INT_8197F BIT(17)
#define BIT_FS_CTWEND1_INT_8197F BIT(16)
#define BIT_FS_CTWEND0_INT_8197F BIT(15)
#define BIT_FS_TX_NULL1_INT_8197F BIT(14)
#define BIT_FS_TX_NULL0_INT_8197F BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_INT_8197F BIT(12)
#define BIT_FS_P2P_RFON2_INT_8197F BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_8197F BIT(10)
#define BIT_FS_P2P_RFON1_INT_8197F BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_8197F BIT(8)
#define BIT_FS_P2P_RFON0_INT_8197F BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_8197F BIT(6)
#define BIT_FS_RX_UAPSDMD1_INT_8197F BIT(5)
#define BIT_FS_RX_UAPSDMD0_INT_8197F BIT(4)
#define BIT_FS_TRIGGER_PKT_INT_8197F BIT(3)
#define BIT_FS_EOSP_INT_8197F BIT(2)
#define BIT_FS_RPWM2_INT_8197F BIT(1)
#define BIT_FS_RPWM_INT_8197F BIT(0)
/* 2 REG_SPWR0_8197F */
#define BIT_SHIFT_MID_31TO0_8197F 0
#define BIT_MASK_MID_31TO0_8197F 0xffffffffL
#define BIT_MID_31TO0_8197F(x) \
(((x) & BIT_MASK_MID_31TO0_8197F) << BIT_SHIFT_MID_31TO0_8197F)
#define BITS_MID_31TO0_8197F \
(BIT_MASK_MID_31TO0_8197F << BIT_SHIFT_MID_31TO0_8197F)
#define BIT_CLEAR_MID_31TO0_8197F(x) ((x) & (~BITS_MID_31TO0_8197F))
#define BIT_GET_MID_31TO0_8197F(x) \
(((x) >> BIT_SHIFT_MID_31TO0_8197F) & BIT_MASK_MID_31TO0_8197F)
#define BIT_SET_MID_31TO0_8197F(x, v) \
(BIT_CLEAR_MID_31TO0_8197F(x) | BIT_MID_31TO0_8197F(v))
/* 2 REG_SPWR1_8197F */
#define BIT_SHIFT_MID_63TO32_8197F 0
#define BIT_MASK_MID_63TO32_8197F 0xffffffffL
#define BIT_MID_63TO32_8197F(x) \
(((x) & BIT_MASK_MID_63TO32_8197F) << BIT_SHIFT_MID_63TO32_8197F)
#define BITS_MID_63TO32_8197F \
(BIT_MASK_MID_63TO32_8197F << BIT_SHIFT_MID_63TO32_8197F)
#define BIT_CLEAR_MID_63TO32_8197F(x) ((x) & (~BITS_MID_63TO32_8197F))
#define BIT_GET_MID_63TO32_8197F(x) \
(((x) >> BIT_SHIFT_MID_63TO32_8197F) & BIT_MASK_MID_63TO32_8197F)
#define BIT_SET_MID_63TO32_8197F(x, v) \
(BIT_CLEAR_MID_63TO32_8197F(x) | BIT_MID_63TO32_8197F(v))
/* 2 REG_SPWR2_8197F */
#define BIT_SHIFT_MID_95O64_8197F 0
#define BIT_MASK_MID_95O64_8197F 0xffffffffL
#define BIT_MID_95O64_8197F(x) \
(((x) & BIT_MASK_MID_95O64_8197F) << BIT_SHIFT_MID_95O64_8197F)
#define BITS_MID_95O64_8197F \
(BIT_MASK_MID_95O64_8197F << BIT_SHIFT_MID_95O64_8197F)
#define BIT_CLEAR_MID_95O64_8197F(x) ((x) & (~BITS_MID_95O64_8197F))
#define BIT_GET_MID_95O64_8197F(x) \
(((x) >> BIT_SHIFT_MID_95O64_8197F) & BIT_MASK_MID_95O64_8197F)
#define BIT_SET_MID_95O64_8197F(x, v) \
(BIT_CLEAR_MID_95O64_8197F(x) | BIT_MID_95O64_8197F(v))
/* 2 REG_SPWR3_8197F */
#define BIT_SHIFT_MID_127TO96_8197F 0
#define BIT_MASK_MID_127TO96_8197F 0xffffffffL
#define BIT_MID_127TO96_8197F(x) \
(((x) & BIT_MASK_MID_127TO96_8197F) << BIT_SHIFT_MID_127TO96_8197F)
#define BITS_MID_127TO96_8197F \
(BIT_MASK_MID_127TO96_8197F << BIT_SHIFT_MID_127TO96_8197F)
#define BIT_CLEAR_MID_127TO96_8197F(x) ((x) & (~BITS_MID_127TO96_8197F))
#define BIT_GET_MID_127TO96_8197F(x) \
(((x) >> BIT_SHIFT_MID_127TO96_8197F) & BIT_MASK_MID_127TO96_8197F)
#define BIT_SET_MID_127TO96_8197F(x, v) \
(BIT_CLEAR_MID_127TO96_8197F(x) | BIT_MID_127TO96_8197F(v))
/* 2 REG_POWSEQ_8197F */
#define BIT_SHIFT_SEQNUM_MID_8197F 16
#define BIT_MASK_SEQNUM_MID_8197F 0xffff
#define BIT_SEQNUM_MID_8197F(x) \
(((x) & BIT_MASK_SEQNUM_MID_8197F) << BIT_SHIFT_SEQNUM_MID_8197F)
#define BITS_SEQNUM_MID_8197F \
(BIT_MASK_SEQNUM_MID_8197F << BIT_SHIFT_SEQNUM_MID_8197F)
#define BIT_CLEAR_SEQNUM_MID_8197F(x) ((x) & (~BITS_SEQNUM_MID_8197F))
#define BIT_GET_SEQNUM_MID_8197F(x) \
(((x) >> BIT_SHIFT_SEQNUM_MID_8197F) & BIT_MASK_SEQNUM_MID_8197F)
#define BIT_SET_SEQNUM_MID_8197F(x, v) \
(BIT_CLEAR_SEQNUM_MID_8197F(x) | BIT_SEQNUM_MID_8197F(v))
#define BIT_SHIFT_REF_MID_8197F 0
#define BIT_MASK_REF_MID_8197F 0x7f
#define BIT_REF_MID_8197F(x) \
(((x) & BIT_MASK_REF_MID_8197F) << BIT_SHIFT_REF_MID_8197F)
#define BITS_REF_MID_8197F (BIT_MASK_REF_MID_8197F << BIT_SHIFT_REF_MID_8197F)
#define BIT_CLEAR_REF_MID_8197F(x) ((x) & (~BITS_REF_MID_8197F))
#define BIT_GET_REF_MID_8197F(x) \
(((x) >> BIT_SHIFT_REF_MID_8197F) & BIT_MASK_REF_MID_8197F)
#define BIT_SET_REF_MID_8197F(x, v) \
(BIT_CLEAR_REF_MID_8197F(x) | BIT_REF_MID_8197F(v))
/* 2 REG_TC7_CTRL_V1_8197F */
#define BIT_TC7INT_EN_8197F BIT(26)
#define BIT_TC7MODE_8197F BIT(25)
#define BIT_TC7EN_8197F BIT(24)
#define BIT_SHIFT_TC7DATA_8197F 0
#define BIT_MASK_TC7DATA_8197F 0xffffff
#define BIT_TC7DATA_8197F(x) \
(((x) & BIT_MASK_TC7DATA_8197F) << BIT_SHIFT_TC7DATA_8197F)
#define BITS_TC7DATA_8197F (BIT_MASK_TC7DATA_8197F << BIT_SHIFT_TC7DATA_8197F)
#define BIT_CLEAR_TC7DATA_8197F(x) ((x) & (~BITS_TC7DATA_8197F))
#define BIT_GET_TC7DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC7DATA_8197F) & BIT_MASK_TC7DATA_8197F)
#define BIT_SET_TC7DATA_8197F(x, v) \
(BIT_CLEAR_TC7DATA_8197F(x) | BIT_TC7DATA_8197F(v))
/* 2 REG_TC8_CTRL_V1_8197F */
#define BIT_TC8INT_EN_8197F BIT(26)
#define BIT_TC8MODE_8197F BIT(25)
#define BIT_TC8EN_8197F BIT(24)
#define BIT_SHIFT_TC8DATA_8197F 0
#define BIT_MASK_TC8DATA_8197F 0xffffff
#define BIT_TC8DATA_8197F(x) \
(((x) & BIT_MASK_TC8DATA_8197F) << BIT_SHIFT_TC8DATA_8197F)
#define BITS_TC8DATA_8197F (BIT_MASK_TC8DATA_8197F << BIT_SHIFT_TC8DATA_8197F)
#define BIT_CLEAR_TC8DATA_8197F(x) ((x) & (~BITS_TC8DATA_8197F))
#define BIT_GET_TC8DATA_8197F(x) \
(((x) >> BIT_SHIFT_TC8DATA_8197F) & BIT_MASK_TC8DATA_8197F)
#define BIT_SET_TC8DATA_8197F(x, v) \
(BIT_CLEAR_TC8DATA_8197F(x) | BIT_TC8DATA_8197F(v))
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT0TO3_8197F */
/* 2 REG_RXBCN_TBTT_INTERVAL_PORT4_8197F */
/* 2 REG_EXT_QUEUE_REG_8197F */
#define BIT_SHIFT_PCIE_PRIORITY_SEL_8197F 0
#define BIT_MASK_PCIE_PRIORITY_SEL_8197F 0x3
#define BIT_PCIE_PRIORITY_SEL_8197F(x) \
(((x) & BIT_MASK_PCIE_PRIORITY_SEL_8197F) \
<< BIT_SHIFT_PCIE_PRIORITY_SEL_8197F)
#define BITS_PCIE_PRIORITY_SEL_8197F \
(BIT_MASK_PCIE_PRIORITY_SEL_8197F << BIT_SHIFT_PCIE_PRIORITY_SEL_8197F)
#define BIT_CLEAR_PCIE_PRIORITY_SEL_8197F(x) \
((x) & (~BITS_PCIE_PRIORITY_SEL_8197F))
#define BIT_GET_PCIE_PRIORITY_SEL_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_PRIORITY_SEL_8197F) & \
BIT_MASK_PCIE_PRIORITY_SEL_8197F)
#define BIT_SET_PCIE_PRIORITY_SEL_8197F(x, v) \
(BIT_CLEAR_PCIE_PRIORITY_SEL_8197F(x) | BIT_PCIE_PRIORITY_SEL_8197F(v))
/* 2 REG_COUNTER_CONTROL_8197F */
#define BIT_SHIFT_COUNTER_BASE_8197F 16
#define BIT_MASK_COUNTER_BASE_8197F 0x1fff
#define BIT_COUNTER_BASE_8197F(x) \
(((x) & BIT_MASK_COUNTER_BASE_8197F) << BIT_SHIFT_COUNTER_BASE_8197F)
#define BITS_COUNTER_BASE_8197F \
(BIT_MASK_COUNTER_BASE_8197F << BIT_SHIFT_COUNTER_BASE_8197F)
#define BIT_CLEAR_COUNTER_BASE_8197F(x) ((x) & (~BITS_COUNTER_BASE_8197F))
#define BIT_GET_COUNTER_BASE_8197F(x) \
(((x) >> BIT_SHIFT_COUNTER_BASE_8197F) & BIT_MASK_COUNTER_BASE_8197F)
#define BIT_SET_COUNTER_BASE_8197F(x, v) \
(BIT_CLEAR_COUNTER_BASE_8197F(x) | BIT_COUNTER_BASE_8197F(v))
#define BIT_EN_RTS_REQ_8197F BIT(9)
#define BIT_EN_EDCA_REQ_8197F BIT(8)
#define BIT_EN_PTCL_REQ_8197F BIT(7)
#define BIT_EN_SCH_REQ_8197F BIT(6)
#define BIT_EN_USB_CNT_8197F BIT(5)
#define BIT_EN_PCIE_CNT_8197F BIT(4)
#define BIT_RQPN_CNT_8197F BIT(3)
#define BIT_RDE_CNT_8197F BIT(2)
#define BIT_TDE_CNT_8197F BIT(1)
#define BIT_DIS_CNT_8197F BIT(0)
/* 2 REG_COUNTER_TH_8197F */
#define BIT_CNT_ALL_MACID_8197F BIT(31)
#define BIT_SHIFT_CNT_MACID_8197F 24
#define BIT_MASK_CNT_MACID_8197F 0x7f
#define BIT_CNT_MACID_8197F(x) \
(((x) & BIT_MASK_CNT_MACID_8197F) << BIT_SHIFT_CNT_MACID_8197F)
#define BITS_CNT_MACID_8197F \
(BIT_MASK_CNT_MACID_8197F << BIT_SHIFT_CNT_MACID_8197F)
#define BIT_CLEAR_CNT_MACID_8197F(x) ((x) & (~BITS_CNT_MACID_8197F))
#define BIT_GET_CNT_MACID_8197F(x) \
(((x) >> BIT_SHIFT_CNT_MACID_8197F) & BIT_MASK_CNT_MACID_8197F)
#define BIT_SET_CNT_MACID_8197F(x, v) \
(BIT_CLEAR_CNT_MACID_8197F(x) | BIT_CNT_MACID_8197F(v))
#define BIT_SHIFT_AGG_VALUE2_8197F 16
#define BIT_MASK_AGG_VALUE2_8197F 0x7f
#define BIT_AGG_VALUE2_8197F(x) \
(((x) & BIT_MASK_AGG_VALUE2_8197F) << BIT_SHIFT_AGG_VALUE2_8197F)
#define BITS_AGG_VALUE2_8197F \
(BIT_MASK_AGG_VALUE2_8197F << BIT_SHIFT_AGG_VALUE2_8197F)
#define BIT_CLEAR_AGG_VALUE2_8197F(x) ((x) & (~BITS_AGG_VALUE2_8197F))
#define BIT_GET_AGG_VALUE2_8197F(x) \
(((x) >> BIT_SHIFT_AGG_VALUE2_8197F) & BIT_MASK_AGG_VALUE2_8197F)
#define BIT_SET_AGG_VALUE2_8197F(x, v) \
(BIT_CLEAR_AGG_VALUE2_8197F(x) | BIT_AGG_VALUE2_8197F(v))
#define BIT_SHIFT_AGG_VALUE1_8197F 8
#define BIT_MASK_AGG_VALUE1_8197F 0x7f
#define BIT_AGG_VALUE1_8197F(x) \
(((x) & BIT_MASK_AGG_VALUE1_8197F) << BIT_SHIFT_AGG_VALUE1_8197F)
#define BITS_AGG_VALUE1_8197F \
(BIT_MASK_AGG_VALUE1_8197F << BIT_SHIFT_AGG_VALUE1_8197F)
#define BIT_CLEAR_AGG_VALUE1_8197F(x) ((x) & (~BITS_AGG_VALUE1_8197F))
#define BIT_GET_AGG_VALUE1_8197F(x) \
(((x) >> BIT_SHIFT_AGG_VALUE1_8197F) & BIT_MASK_AGG_VALUE1_8197F)
#define BIT_SET_AGG_VALUE1_8197F(x, v) \
(BIT_CLEAR_AGG_VALUE1_8197F(x) | BIT_AGG_VALUE1_8197F(v))
#define BIT_SHIFT_AGG_VALUE0_8197F 0
#define BIT_MASK_AGG_VALUE0_8197F 0x7f
#define BIT_AGG_VALUE0_8197F(x) \
(((x) & BIT_MASK_AGG_VALUE0_8197F) << BIT_SHIFT_AGG_VALUE0_8197F)
#define BITS_AGG_VALUE0_8197F \
(BIT_MASK_AGG_VALUE0_8197F << BIT_SHIFT_AGG_VALUE0_8197F)
#define BIT_CLEAR_AGG_VALUE0_8197F(x) ((x) & (~BITS_AGG_VALUE0_8197F))
#define BIT_GET_AGG_VALUE0_8197F(x) \
(((x) >> BIT_SHIFT_AGG_VALUE0_8197F) & BIT_MASK_AGG_VALUE0_8197F)
#define BIT_SET_AGG_VALUE0_8197F(x, v) \
(BIT_CLEAR_AGG_VALUE0_8197F(x) | BIT_AGG_VALUE0_8197F(v))
/* 2 REG_COUNTER_SET_8197F */
#define BIT_RTS_RST_8197F BIT(24)
#define BIT_PTCL_RST_8197F BIT(23)
#define BIT_SCH_RST_8197F BIT(22)
#define BIT_EDCA_RST_8197F BIT(21)
#define BIT_RQPN_RST_8197F BIT(20)
#define BIT_USB_RST_8197F BIT(19)
#define BIT_PCIE_RST_8197F BIT(18)
#define BIT_RXDMA_RST_8197F BIT(17)
#define BIT_TXDMA_RST_8197F BIT(16)
#define BIT_EN_RTS_START_8197F BIT(8)
#define BIT_EN_PTCL_START_8197F BIT(7)
#define BIT_EN_SCH_START_8197F BIT(6)
#define BIT_EN_EDCA_START_8197F BIT(5)
#define BIT_EN_RQPN_START_8197F BIT(4)
#define BIT_EN_USB_START_8197F BIT(3)
#define BIT_EN_PCIE_START_8197F BIT(2)
#define BIT_EN_RXDMA_START_8197F BIT(1)
#define BIT_EN_TXDMA_START_8197F BIT(0)
/* 2 REG_COUNTER_OVERFLOW_8197F */
#define BIT_RTS_OVF_8197F BIT(8)
#define BIT_PTCL_OVF_8197F BIT(7)
#define BIT_SCH_OVF_8197F BIT(6)
#define BIT_EDCA_OVF_8197F BIT(5)
#define BIT_RQPN_OVF_8197F BIT(4)
#define BIT_USB_OVF_8197F BIT(3)
#define BIT_PCIE_OVF_8197F BIT(2)
#define BIT_RXDMA_OVF_8197F BIT(1)
#define BIT_TXDMA_OVF_8197F BIT(0)
/* 2 REG_TDE_LEN_TH_8197F */
#define BIT_SHIFT_TXDMA_LEN_TH0_8197F 16
#define BIT_MASK_TXDMA_LEN_TH0_8197F 0xffff
#define BIT_TXDMA_LEN_TH0_8197F(x) \
(((x) & BIT_MASK_TXDMA_LEN_TH0_8197F) << BIT_SHIFT_TXDMA_LEN_TH0_8197F)
#define BITS_TXDMA_LEN_TH0_8197F \
(BIT_MASK_TXDMA_LEN_TH0_8197F << BIT_SHIFT_TXDMA_LEN_TH0_8197F)
#define BIT_CLEAR_TXDMA_LEN_TH0_8197F(x) ((x) & (~BITS_TXDMA_LEN_TH0_8197F))
#define BIT_GET_TXDMA_LEN_TH0_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_LEN_TH0_8197F) & BIT_MASK_TXDMA_LEN_TH0_8197F)
#define BIT_SET_TXDMA_LEN_TH0_8197F(x, v) \
(BIT_CLEAR_TXDMA_LEN_TH0_8197F(x) | BIT_TXDMA_LEN_TH0_8197F(v))
#define BIT_SHIFT_TXDMA_LEN_TH1_8197F 0
#define BIT_MASK_TXDMA_LEN_TH1_8197F 0xffff
#define BIT_TXDMA_LEN_TH1_8197F(x) \
(((x) & BIT_MASK_TXDMA_LEN_TH1_8197F) << BIT_SHIFT_TXDMA_LEN_TH1_8197F)
#define BITS_TXDMA_LEN_TH1_8197F \
(BIT_MASK_TXDMA_LEN_TH1_8197F << BIT_SHIFT_TXDMA_LEN_TH1_8197F)
#define BIT_CLEAR_TXDMA_LEN_TH1_8197F(x) ((x) & (~BITS_TXDMA_LEN_TH1_8197F))
#define BIT_GET_TXDMA_LEN_TH1_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_LEN_TH1_8197F) & BIT_MASK_TXDMA_LEN_TH1_8197F)
#define BIT_SET_TXDMA_LEN_TH1_8197F(x, v) \
(BIT_CLEAR_TXDMA_LEN_TH1_8197F(x) | BIT_TXDMA_LEN_TH1_8197F(v))
/* 2 REG_RDE_LEN_TH_8197F */
#define BIT_SHIFT_RXDMA_LEN_TH0_8197F 16
#define BIT_MASK_RXDMA_LEN_TH0_8197F 0xffff
#define BIT_RXDMA_LEN_TH0_8197F(x) \
(((x) & BIT_MASK_RXDMA_LEN_TH0_8197F) << BIT_SHIFT_RXDMA_LEN_TH0_8197F)
#define BITS_RXDMA_LEN_TH0_8197F \
(BIT_MASK_RXDMA_LEN_TH0_8197F << BIT_SHIFT_RXDMA_LEN_TH0_8197F)
#define BIT_CLEAR_RXDMA_LEN_TH0_8197F(x) ((x) & (~BITS_RXDMA_LEN_TH0_8197F))
#define BIT_GET_RXDMA_LEN_TH0_8197F(x) \
(((x) >> BIT_SHIFT_RXDMA_LEN_TH0_8197F) & BIT_MASK_RXDMA_LEN_TH0_8197F)
#define BIT_SET_RXDMA_LEN_TH0_8197F(x, v) \
(BIT_CLEAR_RXDMA_LEN_TH0_8197F(x) | BIT_RXDMA_LEN_TH0_8197F(v))
#define BIT_SHIFT_RXDMA_LEN_TH1_8197F 0
#define BIT_MASK_RXDMA_LEN_TH1_8197F 0xffff
#define BIT_RXDMA_LEN_TH1_8197F(x) \
(((x) & BIT_MASK_RXDMA_LEN_TH1_8197F) << BIT_SHIFT_RXDMA_LEN_TH1_8197F)
#define BITS_RXDMA_LEN_TH1_8197F \
(BIT_MASK_RXDMA_LEN_TH1_8197F << BIT_SHIFT_RXDMA_LEN_TH1_8197F)
#define BIT_CLEAR_RXDMA_LEN_TH1_8197F(x) ((x) & (~BITS_RXDMA_LEN_TH1_8197F))
#define BIT_GET_RXDMA_LEN_TH1_8197F(x) \
(((x) >> BIT_SHIFT_RXDMA_LEN_TH1_8197F) & BIT_MASK_RXDMA_LEN_TH1_8197F)
#define BIT_SET_RXDMA_LEN_TH1_8197F(x, v) \
(BIT_CLEAR_RXDMA_LEN_TH1_8197F(x) | BIT_RXDMA_LEN_TH1_8197F(v))
/* 2 REG_PCIE_EXEC_TIME_8197F */
#define BIT_SHIFT_COUNTER_INTERVAL_SEL_8197F 16
#define BIT_MASK_COUNTER_INTERVAL_SEL_8197F 0x3
#define BIT_COUNTER_INTERVAL_SEL_8197F(x) \
(((x) & BIT_MASK_COUNTER_INTERVAL_SEL_8197F) \
<< BIT_SHIFT_COUNTER_INTERVAL_SEL_8197F)
#define BITS_COUNTER_INTERVAL_SEL_8197F \
(BIT_MASK_COUNTER_INTERVAL_SEL_8197F \
<< BIT_SHIFT_COUNTER_INTERVAL_SEL_8197F)
#define BIT_CLEAR_COUNTER_INTERVAL_SEL_8197F(x) \
((x) & (~BITS_COUNTER_INTERVAL_SEL_8197F))
#define BIT_GET_COUNTER_INTERVAL_SEL_8197F(x) \
(((x) >> BIT_SHIFT_COUNTER_INTERVAL_SEL_8197F) & \
BIT_MASK_COUNTER_INTERVAL_SEL_8197F)
#define BIT_SET_COUNTER_INTERVAL_SEL_8197F(x, v) \
(BIT_CLEAR_COUNTER_INTERVAL_SEL_8197F(x) | \
BIT_COUNTER_INTERVAL_SEL_8197F(v))
#define BIT_SHIFT_PCIE_TRANS_DATA_TH1_8197F 0
#define BIT_MASK_PCIE_TRANS_DATA_TH1_8197F 0xffff
#define BIT_PCIE_TRANS_DATA_TH1_8197F(x) \
(((x) & BIT_MASK_PCIE_TRANS_DATA_TH1_8197F) \
<< BIT_SHIFT_PCIE_TRANS_DATA_TH1_8197F)
#define BITS_PCIE_TRANS_DATA_TH1_8197F \
(BIT_MASK_PCIE_TRANS_DATA_TH1_8197F \
<< BIT_SHIFT_PCIE_TRANS_DATA_TH1_8197F)
#define BIT_CLEAR_PCIE_TRANS_DATA_TH1_8197F(x) \
((x) & (~BITS_PCIE_TRANS_DATA_TH1_8197F))
#define BIT_GET_PCIE_TRANS_DATA_TH1_8197F(x) \
(((x) >> BIT_SHIFT_PCIE_TRANS_DATA_TH1_8197F) & \
BIT_MASK_PCIE_TRANS_DATA_TH1_8197F)
#define BIT_SET_PCIE_TRANS_DATA_TH1_8197F(x, v) \
(BIT_CLEAR_PCIE_TRANS_DATA_TH1_8197F(x) | \
BIT_PCIE_TRANS_DATA_TH1_8197F(v))
/* 2 REG_FT2IMR_8197F */
#define BIT_PORT4_RX_UCMD1_UAPSD0_OK_INT_EN_8197F BIT(31)
#define BIT_PORT4_RX_UCMD0_UAPSD0_OK_INT_EN_8197F BIT(30)
#define BIT_PORT4_TRIPKT_OK_INT_EN_8197F BIT(29)
#define BIT_PORT4_RX_EOSP_OK_INT_EN_8197F BIT(28)
#define BIT_PORT3_RX_UCMD1_UAPSD0_OK_INT_EN_8197F BIT(27)
#define BIT_PORT3_RX_UCMD0_UAPSD0_OK_INT_EN_8197F BIT(26)
#define BIT_PORT3_TRIPKT_OK_INT_EN_8197F BIT(25)
#define BIT_PORT3_RX_EOSP_OK_INT_EN_8197F BIT(24)
#define BIT_PORT2_RX_UCMD1_UAPSD0_OK_INT_EN_8197F BIT(23)
#define BIT_PORT2_RX_UCMD0_UAPSD0_OK_INT_EN_8197F BIT(22)
#define BIT_PORT2_TRIPKT_OK_INT_EN_8197F BIT(21)
#define BIT_PORT2_RX_EOSP_OK_INT_EN_8197F BIT(20)
#define BIT_PORT1_RX_UCMD1_UAPSD0_OK_INT_EN_8197F BIT(19)
#define BIT_PORT1_RX_UCMD0_UAPSD0_OK_INT_EN_8197F BIT(18)
#define BIT_PORT1_TRIPKT_OK_INT_EN_8197F BIT(17)
#define BIT_PORT1_RX_EOSP_OK_INT_EN_8197F BIT(16)
#define BIT_NOA2_TSFT_BIT32_TOGGLE_INT_EN_8197F BIT(9)
#define BIT_NOA1_TSFT_BIT32_TOGGLE_INT_EN_8197F BIT(8)
#define BIT_PORT4_TX_NULL1_DONE_INT_EN_8197F BIT(7)
#define BIT_PORT4_TX_NULL0_DONE_INT_EN_8197F BIT(6)
#define BIT_PORT3_TX_NULL1_DONE_INT_EN_8197F BIT(5)
#define BIT_PORT3_TX_NULL0_DONE_INT_EN_8197F BIT(4)
#define BIT_PORT2_TX_NULL1_DONE_INT_EN_8197F BIT(3)
#define BIT_PORT2_TX_NULL0_DONE_INT_EN_8197F BIT(2)
#define BIT_PORT1_TX_NULL1_DONE_INT_EN_8197F BIT(1)
#define BIT_PORT1_TX_NULL0_DONE_INT_EN_8197F BIT(0)
/* 2 REG_FT2ISR_8197F */
#define BIT_PORT4_RX_UCMD1_UAPSD0_OK_INT_8197F BIT(31)
#define BIT_PORT4_RX_UCMD0_UAPSD0_OK_INT_8197F BIT(30)
#define BIT_PORT4_TRIPKT_OK_INT_8197F BIT(29)
#define BIT_PORT4_RX_EOSP_OK_INT_8197F BIT(28)
#define BIT_PORT3_RX_UCMD1_UAPSD0_OK_INT_8197F BIT(27)
#define BIT_PORT3_RX_UCMD0_UAPSD0_OK_INT_8197F BIT(26)
#define BIT_PORT3_TRIPKT_OK_INT_8197F BIT(25)
#define BIT_PORT3_RX_EOSP_OK_INT_8197F BIT(24)
#define BIT_PORT2_RX_UCMD1_UAPSD0_OK_INT_8197F BIT(23)
#define BIT_PORT2_RX_UCMD0_UAPSD0_OK_INT_8197F BIT(22)
#define BIT_PORT2_TRIPKT_OK_INT_8197F BIT(21)
#define BIT_PORT2_RX_EOSP_OK_INT_8197F BIT(20)
#define BIT_PORT1_RX_UCMD1_UAPSD0_OK_INT_8197F BIT(19)
#define BIT_PORT1_RX_UCMD0_UAPSD0_OK_INT_8197F BIT(18)
#define BIT_PORT1_TRIPKT_OK_INT_8197F BIT(17)
#define BIT_PORT1_RX_EOSP_OK_INT_8197F BIT(16)
#define BIT_NOA2_TSFT_BIT32_TOGGLE_INT_8197F BIT(9)
#define BIT_NOA1_TSFT_BIT32_TOGGLE_INT_8197F BIT(8)
#define BIT_PORT4_TX_NULL1_DONE_INT_8197F BIT(7)
#define BIT_PORT4_TX_NULL0_DONE_INT_8197F BIT(6)
#define BIT_PORT3_TX_NULL1_DONE_INT_8197F BIT(5)
#define BIT_PORT3_TX_NULL0_DONE_INT_8197F BIT(4)
#define BIT_PORT2_TX_NULL1_DONE_INT_8197F BIT(3)
#define BIT_PORT2_TX_NULL0_DONE_INT_8197F BIT(2)
#define BIT_PORT1_TX_NULL1_DONE_INT_8197F BIT(1)
#define BIT_PORT1_TX_NULL0_DONE_INT_8197F BIT(0)
/* 2 REG_MSG2_8197F */
#define BIT_SHIFT_FW_MSG2_8197F 0
#define BIT_MASK_FW_MSG2_8197F 0xffffffffL
#define BIT_FW_MSG2_8197F(x) \
(((x) & BIT_MASK_FW_MSG2_8197F) << BIT_SHIFT_FW_MSG2_8197F)
#define BITS_FW_MSG2_8197F (BIT_MASK_FW_MSG2_8197F << BIT_SHIFT_FW_MSG2_8197F)
#define BIT_CLEAR_FW_MSG2_8197F(x) ((x) & (~BITS_FW_MSG2_8197F))
#define BIT_GET_FW_MSG2_8197F(x) \
(((x) >> BIT_SHIFT_FW_MSG2_8197F) & BIT_MASK_FW_MSG2_8197F)
#define BIT_SET_FW_MSG2_8197F(x, v) \
(BIT_CLEAR_FW_MSG2_8197F(x) | BIT_FW_MSG2_8197F(v))
/* 2 REG_MSG3_8197F */
#define BIT_SHIFT_FW_MSG3_8197F 0
#define BIT_MASK_FW_MSG3_8197F 0xffffffffL
#define BIT_FW_MSG3_8197F(x) \
(((x) & BIT_MASK_FW_MSG3_8197F) << BIT_SHIFT_FW_MSG3_8197F)
#define BITS_FW_MSG3_8197F (BIT_MASK_FW_MSG3_8197F << BIT_SHIFT_FW_MSG3_8197F)
#define BIT_CLEAR_FW_MSG3_8197F(x) ((x) & (~BITS_FW_MSG3_8197F))
#define BIT_GET_FW_MSG3_8197F(x) \
(((x) >> BIT_SHIFT_FW_MSG3_8197F) & BIT_MASK_FW_MSG3_8197F)
#define BIT_SET_FW_MSG3_8197F(x, v) \
(BIT_CLEAR_FW_MSG3_8197F(x) | BIT_FW_MSG3_8197F(v))
/* 2 REG_MSG4_8197F */
#define BIT_SHIFT_FW_MSG4_8197F 0
#define BIT_MASK_FW_MSG4_8197F 0xffffffffL
#define BIT_FW_MSG4_8197F(x) \
(((x) & BIT_MASK_FW_MSG4_8197F) << BIT_SHIFT_FW_MSG4_8197F)
#define BITS_FW_MSG4_8197F (BIT_MASK_FW_MSG4_8197F << BIT_SHIFT_FW_MSG4_8197F)
#define BIT_CLEAR_FW_MSG4_8197F(x) ((x) & (~BITS_FW_MSG4_8197F))
#define BIT_GET_FW_MSG4_8197F(x) \
(((x) >> BIT_SHIFT_FW_MSG4_8197F) & BIT_MASK_FW_MSG4_8197F)
#define BIT_SET_FW_MSG4_8197F(x, v) \
(BIT_CLEAR_FW_MSG4_8197F(x) | BIT_FW_MSG4_8197F(v))
/* 2 REG_MSG5_8197F */
#define BIT_SHIFT_FW_MSG5_8197F 0
#define BIT_MASK_FW_MSG5_8197F 0xffffffffL
#define BIT_FW_MSG5_8197F(x) \
(((x) & BIT_MASK_FW_MSG5_8197F) << BIT_SHIFT_FW_MSG5_8197F)
#define BITS_FW_MSG5_8197F (BIT_MASK_FW_MSG5_8197F << BIT_SHIFT_FW_MSG5_8197F)
#define BIT_CLEAR_FW_MSG5_8197F(x) ((x) & (~BITS_FW_MSG5_8197F))
#define BIT_GET_FW_MSG5_8197F(x) \
(((x) >> BIT_SHIFT_FW_MSG5_8197F) & BIT_MASK_FW_MSG5_8197F)
#define BIT_SET_FW_MSG5_8197F(x, v) \
(BIT_CLEAR_FW_MSG5_8197F(x) | BIT_FW_MSG5_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_FIFOPAGE_CTRL_1_8197F */
#define BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8197F 16
#define BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8197F 0xff
#define BIT_TX_OQT_HE_FREE_SPACE_V1_8197F(x) \
(((x) & BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8197F) \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8197F)
#define BITS_TX_OQT_HE_FREE_SPACE_V1_8197F \
(BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8197F \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8197F)
#define BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8197F(x) \
((x) & (~BITS_TX_OQT_HE_FREE_SPACE_V1_8197F))
#define BIT_GET_TX_OQT_HE_FREE_SPACE_V1_8197F(x) \
(((x) >> BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8197F) & \
BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8197F)
#define BIT_SET_TX_OQT_HE_FREE_SPACE_V1_8197F(x, v) \
(BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8197F(x) | \
BIT_TX_OQT_HE_FREE_SPACE_V1_8197F(v))
#define BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8197F 0
#define BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8197F 0xff
#define BIT_TX_OQT_NL_FREE_SPACE_V1_8197F(x) \
(((x) & BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8197F) \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8197F)
#define BITS_TX_OQT_NL_FREE_SPACE_V1_8197F \
(BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8197F \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8197F)
#define BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8197F(x) \
((x) & (~BITS_TX_OQT_NL_FREE_SPACE_V1_8197F))
#define BIT_GET_TX_OQT_NL_FREE_SPACE_V1_8197F(x) \
(((x) >> BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8197F) & \
BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8197F)
#define BIT_SET_TX_OQT_NL_FREE_SPACE_V1_8197F(x, v) \
(BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8197F(x) | \
BIT_TX_OQT_NL_FREE_SPACE_V1_8197F(v))
/* 2 REG_FIFOPAGE_CTRL_2_8197F */
#define BIT_BCN_VALID_1_V1_8197F BIT(31)
#define BIT_SHIFT_BCN_HEAD_1_V1_8197F 16
#define BIT_MASK_BCN_HEAD_1_V1_8197F 0xfff
#define BIT_BCN_HEAD_1_V1_8197F(x) \
(((x) & BIT_MASK_BCN_HEAD_1_V1_8197F) << BIT_SHIFT_BCN_HEAD_1_V1_8197F)
#define BITS_BCN_HEAD_1_V1_8197F \
(BIT_MASK_BCN_HEAD_1_V1_8197F << BIT_SHIFT_BCN_HEAD_1_V1_8197F)
#define BIT_CLEAR_BCN_HEAD_1_V1_8197F(x) ((x) & (~BITS_BCN_HEAD_1_V1_8197F))
#define BIT_GET_BCN_HEAD_1_V1_8197F(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_1_V1_8197F) & BIT_MASK_BCN_HEAD_1_V1_8197F)
#define BIT_SET_BCN_HEAD_1_V1_8197F(x, v) \
(BIT_CLEAR_BCN_HEAD_1_V1_8197F(x) | BIT_BCN_HEAD_1_V1_8197F(v))
#define BIT_BCN_VALID_V1_8197F BIT(15)
#define BIT_SHIFT_BCN_HEAD_V1_8197F 0
#define BIT_MASK_BCN_HEAD_V1_8197F 0xfff
#define BIT_BCN_HEAD_V1_8197F(x) \
(((x) & BIT_MASK_BCN_HEAD_V1_8197F) << BIT_SHIFT_BCN_HEAD_V1_8197F)
#define BITS_BCN_HEAD_V1_8197F \
(BIT_MASK_BCN_HEAD_V1_8197F << BIT_SHIFT_BCN_HEAD_V1_8197F)
#define BIT_CLEAR_BCN_HEAD_V1_8197F(x) ((x) & (~BITS_BCN_HEAD_V1_8197F))
#define BIT_GET_BCN_HEAD_V1_8197F(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_V1_8197F) & BIT_MASK_BCN_HEAD_V1_8197F)
#define BIT_SET_BCN_HEAD_V1_8197F(x, v) \
(BIT_CLEAR_BCN_HEAD_V1_8197F(x) | BIT_BCN_HEAD_V1_8197F(v))
/* 2 REG_AUTO_LLT_V1_8197F */
#define BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F 24
#define BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F 0xff
#define BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F(x) \
(((x) & BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F) \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F)
#define BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F \
(BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F)
#define BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F(x) \
((x) & (~BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F))
#define BIT_GET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F) & \
BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F)
#define BIT_SET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F(x, v) \
(BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F(x) | \
BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8197F(v))
#define BIT_SHIFT_LLT_FREE_PAGE_V1_8197F 8
#define BIT_MASK_LLT_FREE_PAGE_V1_8197F 0xffff
#define BIT_LLT_FREE_PAGE_V1_8197F(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V1_8197F) \
<< BIT_SHIFT_LLT_FREE_PAGE_V1_8197F)
#define BITS_LLT_FREE_PAGE_V1_8197F \
(BIT_MASK_LLT_FREE_PAGE_V1_8197F << BIT_SHIFT_LLT_FREE_PAGE_V1_8197F)
#define BIT_CLEAR_LLT_FREE_PAGE_V1_8197F(x) \
((x) & (~BITS_LLT_FREE_PAGE_V1_8197F))
#define BIT_GET_LLT_FREE_PAGE_V1_8197F(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V1_8197F) & \
BIT_MASK_LLT_FREE_PAGE_V1_8197F)
#define BIT_SET_LLT_FREE_PAGE_V1_8197F(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V1_8197F(x) | BIT_LLT_FREE_PAGE_V1_8197F(v))
#define BIT_SHIFT_BLK_DESC_NUM_8197F 4
#define BIT_MASK_BLK_DESC_NUM_8197F 0xf
#define BIT_BLK_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_BLK_DESC_NUM_8197F) << BIT_SHIFT_BLK_DESC_NUM_8197F)
#define BITS_BLK_DESC_NUM_8197F \
(BIT_MASK_BLK_DESC_NUM_8197F << BIT_SHIFT_BLK_DESC_NUM_8197F)
#define BIT_CLEAR_BLK_DESC_NUM_8197F(x) ((x) & (~BITS_BLK_DESC_NUM_8197F))
#define BIT_GET_BLK_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_BLK_DESC_NUM_8197F) & BIT_MASK_BLK_DESC_NUM_8197F)
#define BIT_SET_BLK_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_BLK_DESC_NUM_8197F(x) | BIT_BLK_DESC_NUM_8197F(v))
#define BIT_R_BCN_HEAD_SEL_8197F BIT(3)
#define BIT_R_EN_BCN_SW_HEAD_SEL_8197F BIT(2)
#define BIT_LLT_DBG_SEL_8197F BIT(1)
#define BIT_AUTO_INIT_LLT_V1_8197F BIT(0)
/* 2 REG_TXDMA_OFFSET_CHK_8197F */
#define BIT_EM_CHKSUM_FIN_8197F BIT(31)
#define BIT_EMN_PCIE_DMA_MOD_8197F BIT(30)
#define BIT_EN_TXQUE_CLR_8197F BIT(29)
#define BIT_EN_PCIE_FIFO_MODE_8197F BIT(28)
#define BIT_SHIFT_PG_UNDER_TH_V1_8197F 16
#define BIT_MASK_PG_UNDER_TH_V1_8197F 0xfff
#define BIT_PG_UNDER_TH_V1_8197F(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V1_8197F) \
<< BIT_SHIFT_PG_UNDER_TH_V1_8197F)
#define BITS_PG_UNDER_TH_V1_8197F \
(BIT_MASK_PG_UNDER_TH_V1_8197F << BIT_SHIFT_PG_UNDER_TH_V1_8197F)
#define BIT_CLEAR_PG_UNDER_TH_V1_8197F(x) ((x) & (~BITS_PG_UNDER_TH_V1_8197F))
#define BIT_GET_PG_UNDER_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V1_8197F) & \
BIT_MASK_PG_UNDER_TH_V1_8197F)
#define BIT_SET_PG_UNDER_TH_V1_8197F(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V1_8197F(x) | BIT_PG_UNDER_TH_V1_8197F(v))
#define BIT_EN_RESET_RESTORE_H2C_8197F BIT(15)
#define BIT_SDIO_TDE_FINISH_8197F BIT(14)
#define BIT_SDIO_TXDESC_CHKSUM_EN_8197F BIT(13)
#define BIT_RST_RDPTR_8197F BIT(12)
#define BIT_RST_WRPTR_8197F BIT(11)
#define BIT_CHK_PG_TH_EN_8197F BIT(10)
#define BIT_DROP_DATA_EN_8197F BIT(9)
#define BIT_CHECK_OFFSET_EN_8197F BIT(8)
#define BIT_SHIFT_CHECK_OFFSET_8197F 0
#define BIT_MASK_CHECK_OFFSET_8197F 0xff
#define BIT_CHECK_OFFSET_8197F(x) \
(((x) & BIT_MASK_CHECK_OFFSET_8197F) << BIT_SHIFT_CHECK_OFFSET_8197F)
#define BITS_CHECK_OFFSET_8197F \
(BIT_MASK_CHECK_OFFSET_8197F << BIT_SHIFT_CHECK_OFFSET_8197F)
#define BIT_CLEAR_CHECK_OFFSET_8197F(x) ((x) & (~BITS_CHECK_OFFSET_8197F))
#define BIT_GET_CHECK_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_CHECK_OFFSET_8197F) & BIT_MASK_CHECK_OFFSET_8197F)
#define BIT_SET_CHECK_OFFSET_8197F(x, v) \
(BIT_CLEAR_CHECK_OFFSET_8197F(x) | BIT_CHECK_OFFSET_8197F(v))
/* 2 REG_TXDMA_STATUS_8197F */
#define BIT_HI_OQT_UDN_8197F BIT(17)
#define BIT_HI_OQT_OVF_8197F BIT(16)
#define BIT_PAYLOAD_CHKSUM_ERR_8197F BIT(15)
#define BIT_PAYLOAD_UDN_8197F BIT(14)
#define BIT_PAYLOAD_OVF_8197F BIT(13)
#define BIT_DSC_CHKSUM_FAIL_8197F BIT(12)
#define BIT_UNKNOWN_QSEL_8197F BIT(11)
#define BIT_EP_QSEL_DIFF_8197F BIT(10)
#define BIT_TX_OFFS_UNMATCH_8197F BIT(9)
#define BIT_TXOQT_UDN_8197F BIT(8)
#define BIT_TXOQT_OVF_8197F BIT(7)
#define BIT_TXDMA_SFF_UDN_8197F BIT(6)
#define BIT_TXDMA_SFF_OVF_8197F BIT(5)
#define BIT_LLT_NULL_PG_8197F BIT(4)
#define BIT_PAGE_UDN_8197F BIT(3)
#define BIT_PAGE_OVF_8197F BIT(2)
#define BIT_TXFF_PG_UDN_8197F BIT(1)
#define BIT_TXFF_PG_OVF_8197F BIT(0)
/* 2 REG_TX_DMA_DBG_8197F */
/* 2 REG_TQPNT1_8197F */
#define BIT_SHIFT_HPQ_HIGH_TH_V1_8197F 16
#define BIT_MASK_HPQ_HIGH_TH_V1_8197F 0xfff
#define BIT_HPQ_HIGH_TH_V1_8197F(x) \
(((x) & BIT_MASK_HPQ_HIGH_TH_V1_8197F) \
<< BIT_SHIFT_HPQ_HIGH_TH_V1_8197F)
#define BITS_HPQ_HIGH_TH_V1_8197F \
(BIT_MASK_HPQ_HIGH_TH_V1_8197F << BIT_SHIFT_HPQ_HIGH_TH_V1_8197F)
#define BIT_CLEAR_HPQ_HIGH_TH_V1_8197F(x) ((x) & (~BITS_HPQ_HIGH_TH_V1_8197F))
#define BIT_GET_HPQ_HIGH_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_HPQ_HIGH_TH_V1_8197F) & \
BIT_MASK_HPQ_HIGH_TH_V1_8197F)
#define BIT_SET_HPQ_HIGH_TH_V1_8197F(x, v) \
(BIT_CLEAR_HPQ_HIGH_TH_V1_8197F(x) | BIT_HPQ_HIGH_TH_V1_8197F(v))
#define BIT_SHIFT_HPQ_LOW_TH_V1_8197F 0
#define BIT_MASK_HPQ_LOW_TH_V1_8197F 0xfff
#define BIT_HPQ_LOW_TH_V1_8197F(x) \
(((x) & BIT_MASK_HPQ_LOW_TH_V1_8197F) << BIT_SHIFT_HPQ_LOW_TH_V1_8197F)
#define BITS_HPQ_LOW_TH_V1_8197F \
(BIT_MASK_HPQ_LOW_TH_V1_8197F << BIT_SHIFT_HPQ_LOW_TH_V1_8197F)
#define BIT_CLEAR_HPQ_LOW_TH_V1_8197F(x) ((x) & (~BITS_HPQ_LOW_TH_V1_8197F))
#define BIT_GET_HPQ_LOW_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_HPQ_LOW_TH_V1_8197F) & BIT_MASK_HPQ_LOW_TH_V1_8197F)
#define BIT_SET_HPQ_LOW_TH_V1_8197F(x, v) \
(BIT_CLEAR_HPQ_LOW_TH_V1_8197F(x) | BIT_HPQ_LOW_TH_V1_8197F(v))
/* 2 REG_TQPNT2_8197F */
#define BIT_SHIFT_NPQ_HIGH_TH_V1_8197F 16
#define BIT_MASK_NPQ_HIGH_TH_V1_8197F 0xfff
#define BIT_NPQ_HIGH_TH_V1_8197F(x) \
(((x) & BIT_MASK_NPQ_HIGH_TH_V1_8197F) \
<< BIT_SHIFT_NPQ_HIGH_TH_V1_8197F)
#define BITS_NPQ_HIGH_TH_V1_8197F \
(BIT_MASK_NPQ_HIGH_TH_V1_8197F << BIT_SHIFT_NPQ_HIGH_TH_V1_8197F)
#define BIT_CLEAR_NPQ_HIGH_TH_V1_8197F(x) ((x) & (~BITS_NPQ_HIGH_TH_V1_8197F))
#define BIT_GET_NPQ_HIGH_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_NPQ_HIGH_TH_V1_8197F) & \
BIT_MASK_NPQ_HIGH_TH_V1_8197F)
#define BIT_SET_NPQ_HIGH_TH_V1_8197F(x, v) \
(BIT_CLEAR_NPQ_HIGH_TH_V1_8197F(x) | BIT_NPQ_HIGH_TH_V1_8197F(v))
#define BIT_SHIFT_NPQ_LOW_TH_V1_8197F 0
#define BIT_MASK_NPQ_LOW_TH_V1_8197F 0xfff
#define BIT_NPQ_LOW_TH_V1_8197F(x) \
(((x) & BIT_MASK_NPQ_LOW_TH_V1_8197F) << BIT_SHIFT_NPQ_LOW_TH_V1_8197F)
#define BITS_NPQ_LOW_TH_V1_8197F \
(BIT_MASK_NPQ_LOW_TH_V1_8197F << BIT_SHIFT_NPQ_LOW_TH_V1_8197F)
#define BIT_CLEAR_NPQ_LOW_TH_V1_8197F(x) ((x) & (~BITS_NPQ_LOW_TH_V1_8197F))
#define BIT_GET_NPQ_LOW_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_NPQ_LOW_TH_V1_8197F) & BIT_MASK_NPQ_LOW_TH_V1_8197F)
#define BIT_SET_NPQ_LOW_TH_V1_8197F(x, v) \
(BIT_CLEAR_NPQ_LOW_TH_V1_8197F(x) | BIT_NPQ_LOW_TH_V1_8197F(v))
/* 2 REG_TQPNT3_8197F */
#define BIT_SHIFT_LPQ_HIGH_TH_V1_8197F 16
#define BIT_MASK_LPQ_HIGH_TH_V1_8197F 0xfff
#define BIT_LPQ_HIGH_TH_V1_8197F(x) \
(((x) & BIT_MASK_LPQ_HIGH_TH_V1_8197F) \
<< BIT_SHIFT_LPQ_HIGH_TH_V1_8197F)
#define BITS_LPQ_HIGH_TH_V1_8197F \
(BIT_MASK_LPQ_HIGH_TH_V1_8197F << BIT_SHIFT_LPQ_HIGH_TH_V1_8197F)
#define BIT_CLEAR_LPQ_HIGH_TH_V1_8197F(x) ((x) & (~BITS_LPQ_HIGH_TH_V1_8197F))
#define BIT_GET_LPQ_HIGH_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_LPQ_HIGH_TH_V1_8197F) & \
BIT_MASK_LPQ_HIGH_TH_V1_8197F)
#define BIT_SET_LPQ_HIGH_TH_V1_8197F(x, v) \
(BIT_CLEAR_LPQ_HIGH_TH_V1_8197F(x) | BIT_LPQ_HIGH_TH_V1_8197F(v))
#define BIT_SHIFT_LPQ_LOW_TH_V1_8197F 0
#define BIT_MASK_LPQ_LOW_TH_V1_8197F 0xfff
#define BIT_LPQ_LOW_TH_V1_8197F(x) \
(((x) & BIT_MASK_LPQ_LOW_TH_V1_8197F) << BIT_SHIFT_LPQ_LOW_TH_V1_8197F)
#define BITS_LPQ_LOW_TH_V1_8197F \
(BIT_MASK_LPQ_LOW_TH_V1_8197F << BIT_SHIFT_LPQ_LOW_TH_V1_8197F)
#define BIT_CLEAR_LPQ_LOW_TH_V1_8197F(x) ((x) & (~BITS_LPQ_LOW_TH_V1_8197F))
#define BIT_GET_LPQ_LOW_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_LPQ_LOW_TH_V1_8197F) & BIT_MASK_LPQ_LOW_TH_V1_8197F)
#define BIT_SET_LPQ_LOW_TH_V1_8197F(x, v) \
(BIT_CLEAR_LPQ_LOW_TH_V1_8197F(x) | BIT_LPQ_LOW_TH_V1_8197F(v))
/* 2 REG_TQPNT4_8197F */
#define BIT_SHIFT_EXQ_HIGH_TH_V1_8197F 16
#define BIT_MASK_EXQ_HIGH_TH_V1_8197F 0xfff
#define BIT_EXQ_HIGH_TH_V1_8197F(x) \
(((x) & BIT_MASK_EXQ_HIGH_TH_V1_8197F) \
<< BIT_SHIFT_EXQ_HIGH_TH_V1_8197F)
#define BITS_EXQ_HIGH_TH_V1_8197F \
(BIT_MASK_EXQ_HIGH_TH_V1_8197F << BIT_SHIFT_EXQ_HIGH_TH_V1_8197F)
#define BIT_CLEAR_EXQ_HIGH_TH_V1_8197F(x) ((x) & (~BITS_EXQ_HIGH_TH_V1_8197F))
#define BIT_GET_EXQ_HIGH_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_EXQ_HIGH_TH_V1_8197F) & \
BIT_MASK_EXQ_HIGH_TH_V1_8197F)
#define BIT_SET_EXQ_HIGH_TH_V1_8197F(x, v) \
(BIT_CLEAR_EXQ_HIGH_TH_V1_8197F(x) | BIT_EXQ_HIGH_TH_V1_8197F(v))
#define BIT_SHIFT_EXQ_LOW_TH_V1_8197F 0
#define BIT_MASK_EXQ_LOW_TH_V1_8197F 0xfff
#define BIT_EXQ_LOW_TH_V1_8197F(x) \
(((x) & BIT_MASK_EXQ_LOW_TH_V1_8197F) << BIT_SHIFT_EXQ_LOW_TH_V1_8197F)
#define BITS_EXQ_LOW_TH_V1_8197F \
(BIT_MASK_EXQ_LOW_TH_V1_8197F << BIT_SHIFT_EXQ_LOW_TH_V1_8197F)
#define BIT_CLEAR_EXQ_LOW_TH_V1_8197F(x) ((x) & (~BITS_EXQ_LOW_TH_V1_8197F))
#define BIT_GET_EXQ_LOW_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_EXQ_LOW_TH_V1_8197F) & BIT_MASK_EXQ_LOW_TH_V1_8197F)
#define BIT_SET_EXQ_LOW_TH_V1_8197F(x, v) \
(BIT_CLEAR_EXQ_LOW_TH_V1_8197F(x) | BIT_EXQ_LOW_TH_V1_8197F(v))
/* 2 REG_RQPN_CTRL_1_8197F */
#define BIT_SHIFT_TXPKTNUM_H_8197F 16
#define BIT_MASK_TXPKTNUM_H_8197F 0xffff
#define BIT_TXPKTNUM_H_8197F(x) \
(((x) & BIT_MASK_TXPKTNUM_H_8197F) << BIT_SHIFT_TXPKTNUM_H_8197F)
#define BITS_TXPKTNUM_H_8197F \
(BIT_MASK_TXPKTNUM_H_8197F << BIT_SHIFT_TXPKTNUM_H_8197F)
#define BIT_CLEAR_TXPKTNUM_H_8197F(x) ((x) & (~BITS_TXPKTNUM_H_8197F))
#define BIT_GET_TXPKTNUM_H_8197F(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_8197F) & BIT_MASK_TXPKTNUM_H_8197F)
#define BIT_SET_TXPKTNUM_H_8197F(x, v) \
(BIT_CLEAR_TXPKTNUM_H_8197F(x) | BIT_TXPKTNUM_H_8197F(v))
#define BIT_SHIFT_TXPKTNUM_H_V1_8197F 0
#define BIT_MASK_TXPKTNUM_H_V1_8197F 0xffff
#define BIT_TXPKTNUM_H_V1_8197F(x) \
(((x) & BIT_MASK_TXPKTNUM_H_V1_8197F) << BIT_SHIFT_TXPKTNUM_H_V1_8197F)
#define BITS_TXPKTNUM_H_V1_8197F \
(BIT_MASK_TXPKTNUM_H_V1_8197F << BIT_SHIFT_TXPKTNUM_H_V1_8197F)
#define BIT_CLEAR_TXPKTNUM_H_V1_8197F(x) ((x) & (~BITS_TXPKTNUM_H_V1_8197F))
#define BIT_GET_TXPKTNUM_H_V1_8197F(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_V1_8197F) & BIT_MASK_TXPKTNUM_H_V1_8197F)
#define BIT_SET_TXPKTNUM_H_V1_8197F(x, v) \
(BIT_CLEAR_TXPKTNUM_H_V1_8197F(x) | BIT_TXPKTNUM_H_V1_8197F(v))
/* 2 REG_RQPN_CTRL_2_8197F */
#define BIT_LD_RQPN_8197F BIT(31)
#define BIT_EXQ_PUBLIC_DIS_V1_8197F BIT(19)
#define BIT_NPQ_PUBLIC_DIS_V1_8197F BIT(18)
#define BIT_LPQ_PUBLIC_DIS_V1_8197F BIT(17)
#define BIT_HPQ_PUBLIC_DIS_V1_8197F BIT(16)
/* 2 REG_FIFOPAGE_INFO_1_8197F */
#define BIT_SHIFT_HPQ_AVAL_PG_V1_8197F 16
#define BIT_MASK_HPQ_AVAL_PG_V1_8197F 0xfff
#define BIT_HPQ_AVAL_PG_V1_8197F(x) \
(((x) & BIT_MASK_HPQ_AVAL_PG_V1_8197F) \
<< BIT_SHIFT_HPQ_AVAL_PG_V1_8197F)
#define BITS_HPQ_AVAL_PG_V1_8197F \
(BIT_MASK_HPQ_AVAL_PG_V1_8197F << BIT_SHIFT_HPQ_AVAL_PG_V1_8197F)
#define BIT_CLEAR_HPQ_AVAL_PG_V1_8197F(x) ((x) & (~BITS_HPQ_AVAL_PG_V1_8197F))
#define BIT_GET_HPQ_AVAL_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_HPQ_AVAL_PG_V1_8197F) & \
BIT_MASK_HPQ_AVAL_PG_V1_8197F)
#define BIT_SET_HPQ_AVAL_PG_V1_8197F(x, v) \
(BIT_CLEAR_HPQ_AVAL_PG_V1_8197F(x) | BIT_HPQ_AVAL_PG_V1_8197F(v))
#define BIT_SHIFT_HPQ_V1_8197F 0
#define BIT_MASK_HPQ_V1_8197F 0xfff
#define BIT_HPQ_V1_8197F(x) \
(((x) & BIT_MASK_HPQ_V1_8197F) << BIT_SHIFT_HPQ_V1_8197F)
#define BITS_HPQ_V1_8197F (BIT_MASK_HPQ_V1_8197F << BIT_SHIFT_HPQ_V1_8197F)
#define BIT_CLEAR_HPQ_V1_8197F(x) ((x) & (~BITS_HPQ_V1_8197F))
#define BIT_GET_HPQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_HPQ_V1_8197F) & BIT_MASK_HPQ_V1_8197F)
#define BIT_SET_HPQ_V1_8197F(x, v) \
(BIT_CLEAR_HPQ_V1_8197F(x) | BIT_HPQ_V1_8197F(v))
/* 2 REG_FIFOPAGE_INFO_2_8197F */
#define BIT_SHIFT_LPQ_AVAL_PG_V1_8197F 16
#define BIT_MASK_LPQ_AVAL_PG_V1_8197F 0xfff
#define BIT_LPQ_AVAL_PG_V1_8197F(x) \
(((x) & BIT_MASK_LPQ_AVAL_PG_V1_8197F) \
<< BIT_SHIFT_LPQ_AVAL_PG_V1_8197F)
#define BITS_LPQ_AVAL_PG_V1_8197F \
(BIT_MASK_LPQ_AVAL_PG_V1_8197F << BIT_SHIFT_LPQ_AVAL_PG_V1_8197F)
#define BIT_CLEAR_LPQ_AVAL_PG_V1_8197F(x) ((x) & (~BITS_LPQ_AVAL_PG_V1_8197F))
#define BIT_GET_LPQ_AVAL_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_LPQ_AVAL_PG_V1_8197F) & \
BIT_MASK_LPQ_AVAL_PG_V1_8197F)
#define BIT_SET_LPQ_AVAL_PG_V1_8197F(x, v) \
(BIT_CLEAR_LPQ_AVAL_PG_V1_8197F(x) | BIT_LPQ_AVAL_PG_V1_8197F(v))
#define BIT_SHIFT_LPQ_V1_8197F 0
#define BIT_MASK_LPQ_V1_8197F 0xfff
#define BIT_LPQ_V1_8197F(x) \
(((x) & BIT_MASK_LPQ_V1_8197F) << BIT_SHIFT_LPQ_V1_8197F)
#define BITS_LPQ_V1_8197F (BIT_MASK_LPQ_V1_8197F << BIT_SHIFT_LPQ_V1_8197F)
#define BIT_CLEAR_LPQ_V1_8197F(x) ((x) & (~BITS_LPQ_V1_8197F))
#define BIT_GET_LPQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_LPQ_V1_8197F) & BIT_MASK_LPQ_V1_8197F)
#define BIT_SET_LPQ_V1_8197F(x, v) \
(BIT_CLEAR_LPQ_V1_8197F(x) | BIT_LPQ_V1_8197F(v))
/* 2 REG_FIFOPAGE_INFO_3_8197F */
#define BIT_SHIFT_NPQ_AVAL_PG_V1_8197F 16
#define BIT_MASK_NPQ_AVAL_PG_V1_8197F 0xfff
#define BIT_NPQ_AVAL_PG_V1_8197F(x) \
(((x) & BIT_MASK_NPQ_AVAL_PG_V1_8197F) \
<< BIT_SHIFT_NPQ_AVAL_PG_V1_8197F)
#define BITS_NPQ_AVAL_PG_V1_8197F \
(BIT_MASK_NPQ_AVAL_PG_V1_8197F << BIT_SHIFT_NPQ_AVAL_PG_V1_8197F)
#define BIT_CLEAR_NPQ_AVAL_PG_V1_8197F(x) ((x) & (~BITS_NPQ_AVAL_PG_V1_8197F))
#define BIT_GET_NPQ_AVAL_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_NPQ_AVAL_PG_V1_8197F) & \
BIT_MASK_NPQ_AVAL_PG_V1_8197F)
#define BIT_SET_NPQ_AVAL_PG_V1_8197F(x, v) \
(BIT_CLEAR_NPQ_AVAL_PG_V1_8197F(x) | BIT_NPQ_AVAL_PG_V1_8197F(v))
#define BIT_SHIFT_NPQ_V1_8197F 0
#define BIT_MASK_NPQ_V1_8197F 0xfff
#define BIT_NPQ_V1_8197F(x) \
(((x) & BIT_MASK_NPQ_V1_8197F) << BIT_SHIFT_NPQ_V1_8197F)
#define BITS_NPQ_V1_8197F (BIT_MASK_NPQ_V1_8197F << BIT_SHIFT_NPQ_V1_8197F)
#define BIT_CLEAR_NPQ_V1_8197F(x) ((x) & (~BITS_NPQ_V1_8197F))
#define BIT_GET_NPQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_NPQ_V1_8197F) & BIT_MASK_NPQ_V1_8197F)
#define BIT_SET_NPQ_V1_8197F(x, v) \
(BIT_CLEAR_NPQ_V1_8197F(x) | BIT_NPQ_V1_8197F(v))
/* 2 REG_FIFOPAGE_INFO_4_8197F */
#define BIT_SHIFT_EXQ_AVAL_PG_V1_8197F 16
#define BIT_MASK_EXQ_AVAL_PG_V1_8197F 0xfff
#define BIT_EXQ_AVAL_PG_V1_8197F(x) \
(((x) & BIT_MASK_EXQ_AVAL_PG_V1_8197F) \
<< BIT_SHIFT_EXQ_AVAL_PG_V1_8197F)
#define BITS_EXQ_AVAL_PG_V1_8197F \
(BIT_MASK_EXQ_AVAL_PG_V1_8197F << BIT_SHIFT_EXQ_AVAL_PG_V1_8197F)
#define BIT_CLEAR_EXQ_AVAL_PG_V1_8197F(x) ((x) & (~BITS_EXQ_AVAL_PG_V1_8197F))
#define BIT_GET_EXQ_AVAL_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_EXQ_AVAL_PG_V1_8197F) & \
BIT_MASK_EXQ_AVAL_PG_V1_8197F)
#define BIT_SET_EXQ_AVAL_PG_V1_8197F(x, v) \
(BIT_CLEAR_EXQ_AVAL_PG_V1_8197F(x) | BIT_EXQ_AVAL_PG_V1_8197F(v))
#define BIT_SHIFT_EXQ_V1_8197F 0
#define BIT_MASK_EXQ_V1_8197F 0xfff
#define BIT_EXQ_V1_8197F(x) \
(((x) & BIT_MASK_EXQ_V1_8197F) << BIT_SHIFT_EXQ_V1_8197F)
#define BITS_EXQ_V1_8197F (BIT_MASK_EXQ_V1_8197F << BIT_SHIFT_EXQ_V1_8197F)
#define BIT_CLEAR_EXQ_V1_8197F(x) ((x) & (~BITS_EXQ_V1_8197F))
#define BIT_GET_EXQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_EXQ_V1_8197F) & BIT_MASK_EXQ_V1_8197F)
#define BIT_SET_EXQ_V1_8197F(x, v) \
(BIT_CLEAR_EXQ_V1_8197F(x) | BIT_EXQ_V1_8197F(v))
/* 2 REG_FIFOPAGE_INFO_5_8197F */
#define BIT_SHIFT_PUBQ_AVAL_PG_V1_8197F 16
#define BIT_MASK_PUBQ_AVAL_PG_V1_8197F 0xfff
#define BIT_PUBQ_AVAL_PG_V1_8197F(x) \
(((x) & BIT_MASK_PUBQ_AVAL_PG_V1_8197F) \
<< BIT_SHIFT_PUBQ_AVAL_PG_V1_8197F)
#define BITS_PUBQ_AVAL_PG_V1_8197F \
(BIT_MASK_PUBQ_AVAL_PG_V1_8197F << BIT_SHIFT_PUBQ_AVAL_PG_V1_8197F)
#define BIT_CLEAR_PUBQ_AVAL_PG_V1_8197F(x) ((x) & (~BITS_PUBQ_AVAL_PG_V1_8197F))
#define BIT_GET_PUBQ_AVAL_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_PUBQ_AVAL_PG_V1_8197F) & \
BIT_MASK_PUBQ_AVAL_PG_V1_8197F)
#define BIT_SET_PUBQ_AVAL_PG_V1_8197F(x, v) \
(BIT_CLEAR_PUBQ_AVAL_PG_V1_8197F(x) | BIT_PUBQ_AVAL_PG_V1_8197F(v))
#define BIT_SHIFT_PUBQ_V1_8197F 0
#define BIT_MASK_PUBQ_V1_8197F 0xfff
#define BIT_PUBQ_V1_8197F(x) \
(((x) & BIT_MASK_PUBQ_V1_8197F) << BIT_SHIFT_PUBQ_V1_8197F)
#define BITS_PUBQ_V1_8197F (BIT_MASK_PUBQ_V1_8197F << BIT_SHIFT_PUBQ_V1_8197F)
#define BIT_CLEAR_PUBQ_V1_8197F(x) ((x) & (~BITS_PUBQ_V1_8197F))
#define BIT_GET_PUBQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_PUBQ_V1_8197F) & BIT_MASK_PUBQ_V1_8197F)
#define BIT_SET_PUBQ_V1_8197F(x, v) \
(BIT_CLEAR_PUBQ_V1_8197F(x) | BIT_PUBQ_V1_8197F(v))
/* 2 REG_H2C_HEAD_8197F */
#define BIT_SHIFT_H2C_HEAD_8197F 0
#define BIT_MASK_H2C_HEAD_8197F 0x3ffff
#define BIT_H2C_HEAD_8197F(x) \
(((x) & BIT_MASK_H2C_HEAD_8197F) << BIT_SHIFT_H2C_HEAD_8197F)
#define BITS_H2C_HEAD_8197F \
(BIT_MASK_H2C_HEAD_8197F << BIT_SHIFT_H2C_HEAD_8197F)
#define BIT_CLEAR_H2C_HEAD_8197F(x) ((x) & (~BITS_H2C_HEAD_8197F))
#define BIT_GET_H2C_HEAD_8197F(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_8197F) & BIT_MASK_H2C_HEAD_8197F)
#define BIT_SET_H2C_HEAD_8197F(x, v) \
(BIT_CLEAR_H2C_HEAD_8197F(x) | BIT_H2C_HEAD_8197F(v))
/* 2 REG_H2C_TAIL_8197F */
#define BIT_SHIFT_H2C_TAIL_8197F 0
#define BIT_MASK_H2C_TAIL_8197F 0x3ffff
#define BIT_H2C_TAIL_8197F(x) \
(((x) & BIT_MASK_H2C_TAIL_8197F) << BIT_SHIFT_H2C_TAIL_8197F)
#define BITS_H2C_TAIL_8197F \
(BIT_MASK_H2C_TAIL_8197F << BIT_SHIFT_H2C_TAIL_8197F)
#define BIT_CLEAR_H2C_TAIL_8197F(x) ((x) & (~BITS_H2C_TAIL_8197F))
#define BIT_GET_H2C_TAIL_8197F(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_8197F) & BIT_MASK_H2C_TAIL_8197F)
#define BIT_SET_H2C_TAIL_8197F(x, v) \
(BIT_CLEAR_H2C_TAIL_8197F(x) | BIT_H2C_TAIL_8197F(v))
/* 2 REG_H2C_READ_ADDR_8197F */
#define BIT_SHIFT_H2C_READ_ADDR_8197F 0
#define BIT_MASK_H2C_READ_ADDR_8197F 0x3ffff
#define BIT_H2C_READ_ADDR_8197F(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_8197F) << BIT_SHIFT_H2C_READ_ADDR_8197F)
#define BITS_H2C_READ_ADDR_8197F \
(BIT_MASK_H2C_READ_ADDR_8197F << BIT_SHIFT_H2C_READ_ADDR_8197F)
#define BIT_CLEAR_H2C_READ_ADDR_8197F(x) ((x) & (~BITS_H2C_READ_ADDR_8197F))
#define BIT_GET_H2C_READ_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_8197F) & BIT_MASK_H2C_READ_ADDR_8197F)
#define BIT_SET_H2C_READ_ADDR_8197F(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_8197F(x) | BIT_H2C_READ_ADDR_8197F(v))
/* 2 REG_H2C_WR_ADDR_8197F */
#define BIT_SHIFT_H2C_WR_ADDR_8197F 0
#define BIT_MASK_H2C_WR_ADDR_8197F 0x3ffff
#define BIT_H2C_WR_ADDR_8197F(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_8197F) << BIT_SHIFT_H2C_WR_ADDR_8197F)
#define BITS_H2C_WR_ADDR_8197F \
(BIT_MASK_H2C_WR_ADDR_8197F << BIT_SHIFT_H2C_WR_ADDR_8197F)
#define BIT_CLEAR_H2C_WR_ADDR_8197F(x) ((x) & (~BITS_H2C_WR_ADDR_8197F))
#define BIT_GET_H2C_WR_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_8197F) & BIT_MASK_H2C_WR_ADDR_8197F)
#define BIT_SET_H2C_WR_ADDR_8197F(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_8197F(x) | BIT_H2C_WR_ADDR_8197F(v))
/* 2 REG_H2C_INFO_8197F */
#define BIT_EXQ_EN_PUBLIC_LIMIT_8197F BIT(11)
#define BIT_NPQ_EN_PUBLIC_LIMIT_8197F BIT(10)
#define BIT_LPQ_EN_PUBLIC_LIMIT_8197F BIT(9)
#define BIT_HPQ_EN_PUBLIC_LIMIT_8197F BIT(8)
#define BIT_H2C_SPACE_VLD_8197F BIT(3)
#define BIT_H2C_WR_ADDR_RST_8197F BIT(2)
#define BIT_SHIFT_H2C_LEN_SEL_8197F 0
#define BIT_MASK_H2C_LEN_SEL_8197F 0x3
#define BIT_H2C_LEN_SEL_8197F(x) \
(((x) & BIT_MASK_H2C_LEN_SEL_8197F) << BIT_SHIFT_H2C_LEN_SEL_8197F)
#define BITS_H2C_LEN_SEL_8197F \
(BIT_MASK_H2C_LEN_SEL_8197F << BIT_SHIFT_H2C_LEN_SEL_8197F)
#define BIT_CLEAR_H2C_LEN_SEL_8197F(x) ((x) & (~BITS_H2C_LEN_SEL_8197F))
#define BIT_GET_H2C_LEN_SEL_8197F(x) \
(((x) >> BIT_SHIFT_H2C_LEN_SEL_8197F) & BIT_MASK_H2C_LEN_SEL_8197F)
#define BIT_SET_H2C_LEN_SEL_8197F(x, v) \
(BIT_CLEAR_H2C_LEN_SEL_8197F(x) | BIT_H2C_LEN_SEL_8197F(v))
#define BIT_SHIFT_VI_PUB_LIMIT_8197F 16
#define BIT_MASK_VI_PUB_LIMIT_8197F 0xfff
#define BIT_VI_PUB_LIMIT_8197F(x) \
(((x) & BIT_MASK_VI_PUB_LIMIT_8197F) << BIT_SHIFT_VI_PUB_LIMIT_8197F)
#define BITS_VI_PUB_LIMIT_8197F \
(BIT_MASK_VI_PUB_LIMIT_8197F << BIT_SHIFT_VI_PUB_LIMIT_8197F)
#define BIT_CLEAR_VI_PUB_LIMIT_8197F(x) ((x) & (~BITS_VI_PUB_LIMIT_8197F))
#define BIT_GET_VI_PUB_LIMIT_8197F(x) \
(((x) >> BIT_SHIFT_VI_PUB_LIMIT_8197F) & BIT_MASK_VI_PUB_LIMIT_8197F)
#define BIT_SET_VI_PUB_LIMIT_8197F(x, v) \
(BIT_CLEAR_VI_PUB_LIMIT_8197F(x) | BIT_VI_PUB_LIMIT_8197F(v))
#define BIT_SHIFT_VO_PUB_LIMIT_8197F 0
#define BIT_MASK_VO_PUB_LIMIT_8197F 0xfff
#define BIT_VO_PUB_LIMIT_8197F(x) \
(((x) & BIT_MASK_VO_PUB_LIMIT_8197F) << BIT_SHIFT_VO_PUB_LIMIT_8197F)
#define BITS_VO_PUB_LIMIT_8197F \
(BIT_MASK_VO_PUB_LIMIT_8197F << BIT_SHIFT_VO_PUB_LIMIT_8197F)
#define BIT_CLEAR_VO_PUB_LIMIT_8197F(x) ((x) & (~BITS_VO_PUB_LIMIT_8197F))
#define BIT_GET_VO_PUB_LIMIT_8197F(x) \
(((x) >> BIT_SHIFT_VO_PUB_LIMIT_8197F) & BIT_MASK_VO_PUB_LIMIT_8197F)
#define BIT_SET_VO_PUB_LIMIT_8197F(x, v) \
(BIT_CLEAR_VO_PUB_LIMIT_8197F(x) | BIT_VO_PUB_LIMIT_8197F(v))
#define BIT_SHIFT_BK_PUB_LIMIT_8197F 16
#define BIT_MASK_BK_PUB_LIMIT_8197F 0xfff
#define BIT_BK_PUB_LIMIT_8197F(x) \
(((x) & BIT_MASK_BK_PUB_LIMIT_8197F) << BIT_SHIFT_BK_PUB_LIMIT_8197F)
#define BITS_BK_PUB_LIMIT_8197F \
(BIT_MASK_BK_PUB_LIMIT_8197F << BIT_SHIFT_BK_PUB_LIMIT_8197F)
#define BIT_CLEAR_BK_PUB_LIMIT_8197F(x) ((x) & (~BITS_BK_PUB_LIMIT_8197F))
#define BIT_GET_BK_PUB_LIMIT_8197F(x) \
(((x) >> BIT_SHIFT_BK_PUB_LIMIT_8197F) & BIT_MASK_BK_PUB_LIMIT_8197F)
#define BIT_SET_BK_PUB_LIMIT_8197F(x, v) \
(BIT_CLEAR_BK_PUB_LIMIT_8197F(x) | BIT_BK_PUB_LIMIT_8197F(v))
#define BIT_SHIFT_BE_PUB_LIMIT_8197F 0
#define BIT_MASK_BE_PUB_LIMIT_8197F 0xfff
#define BIT_BE_PUB_LIMIT_8197F(x) \
(((x) & BIT_MASK_BE_PUB_LIMIT_8197F) << BIT_SHIFT_BE_PUB_LIMIT_8197F)
#define BITS_BE_PUB_LIMIT_8197F \
(BIT_MASK_BE_PUB_LIMIT_8197F << BIT_SHIFT_BE_PUB_LIMIT_8197F)
#define BIT_CLEAR_BE_PUB_LIMIT_8197F(x) ((x) & (~BITS_BE_PUB_LIMIT_8197F))
#define BIT_GET_BE_PUB_LIMIT_8197F(x) \
(((x) >> BIT_SHIFT_BE_PUB_LIMIT_8197F) & BIT_MASK_BE_PUB_LIMIT_8197F)
#define BIT_SET_BE_PUB_LIMIT_8197F(x, v) \
(BIT_CLEAR_BE_PUB_LIMIT_8197F(x) | BIT_BE_PUB_LIMIT_8197F(v))
/* 2 REG_RXDMA_AGG_PG_TH_8197F */
#define BIT_DMA_STORE_MODE_8197F BIT(31)
#define BIT_EN_FW_ADD_8197F BIT(30)
#define BIT_EN_PRE_CALC_8197F BIT(29)
#define BIT_RXAGG_SW_EN_8197F BIT(28)
#define BIT_SHIFT_PKT_NUM_WOL_8197F 16
#define BIT_MASK_PKT_NUM_WOL_8197F 0xff
#define BIT_PKT_NUM_WOL_8197F(x) \
(((x) & BIT_MASK_PKT_NUM_WOL_8197F) << BIT_SHIFT_PKT_NUM_WOL_8197F)
#define BITS_PKT_NUM_WOL_8197F \
(BIT_MASK_PKT_NUM_WOL_8197F << BIT_SHIFT_PKT_NUM_WOL_8197F)
#define BIT_CLEAR_PKT_NUM_WOL_8197F(x) ((x) & (~BITS_PKT_NUM_WOL_8197F))
#define BIT_GET_PKT_NUM_WOL_8197F(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL_8197F) & BIT_MASK_PKT_NUM_WOL_8197F)
#define BIT_SET_PKT_NUM_WOL_8197F(x, v) \
(BIT_CLEAR_PKT_NUM_WOL_8197F(x) | BIT_PKT_NUM_WOL_8197F(v))
#define BIT_SHIFT_DMA_AGG_TO_V1_8197F 8
#define BIT_MASK_DMA_AGG_TO_V1_8197F 0xff
#define BIT_DMA_AGG_TO_V1_8197F(x) \
(((x) & BIT_MASK_DMA_AGG_TO_V1_8197F) << BIT_SHIFT_DMA_AGG_TO_V1_8197F)
#define BITS_DMA_AGG_TO_V1_8197F \
(BIT_MASK_DMA_AGG_TO_V1_8197F << BIT_SHIFT_DMA_AGG_TO_V1_8197F)
#define BIT_CLEAR_DMA_AGG_TO_V1_8197F(x) ((x) & (~BITS_DMA_AGG_TO_V1_8197F))
#define BIT_GET_DMA_AGG_TO_V1_8197F(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO_V1_8197F) & BIT_MASK_DMA_AGG_TO_V1_8197F)
#define BIT_SET_DMA_AGG_TO_V1_8197F(x, v) \
(BIT_CLEAR_DMA_AGG_TO_V1_8197F(x) | BIT_DMA_AGG_TO_V1_8197F(v))
#define BIT_SHIFT_RXDMA_AGG_PG_TH_8197F 0
#define BIT_MASK_RXDMA_AGG_PG_TH_8197F 0xff
#define BIT_RXDMA_AGG_PG_TH_8197F(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_8197F) \
<< BIT_SHIFT_RXDMA_AGG_PG_TH_8197F)
#define BITS_RXDMA_AGG_PG_TH_8197F \
(BIT_MASK_RXDMA_AGG_PG_TH_8197F << BIT_SHIFT_RXDMA_AGG_PG_TH_8197F)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_8197F(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_8197F))
#define BIT_GET_RXDMA_AGG_PG_TH_8197F(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_8197F) & \
BIT_MASK_RXDMA_AGG_PG_TH_8197F)
#define BIT_SET_RXDMA_AGG_PG_TH_8197F(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_8197F(x) | BIT_RXDMA_AGG_PG_TH_8197F(v))
/* 2 REG_RXPKT_NUM_8197F */
#define BIT_SHIFT_RXPKT_NUM_8197F 24
#define BIT_MASK_RXPKT_NUM_8197F 0xff
#define BIT_RXPKT_NUM_8197F(x) \
(((x) & BIT_MASK_RXPKT_NUM_8197F) << BIT_SHIFT_RXPKT_NUM_8197F)
#define BITS_RXPKT_NUM_8197F \
(BIT_MASK_RXPKT_NUM_8197F << BIT_SHIFT_RXPKT_NUM_8197F)
#define BIT_CLEAR_RXPKT_NUM_8197F(x) ((x) & (~BITS_RXPKT_NUM_8197F))
#define BIT_GET_RXPKT_NUM_8197F(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_8197F) & BIT_MASK_RXPKT_NUM_8197F)
#define BIT_SET_RXPKT_NUM_8197F(x, v) \
(BIT_CLEAR_RXPKT_NUM_8197F(x) | BIT_RXPKT_NUM_8197F(v))
#define BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8197F 20
#define BIT_MASK_FW_UPD_RDPTR19_TO_16_8197F 0xf
#define BIT_FW_UPD_RDPTR19_TO_16_8197F(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR19_TO_16_8197F) \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8197F)
#define BITS_FW_UPD_RDPTR19_TO_16_8197F \
(BIT_MASK_FW_UPD_RDPTR19_TO_16_8197F \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8197F)
#define BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8197F(x) \
((x) & (~BITS_FW_UPD_RDPTR19_TO_16_8197F))
#define BIT_GET_FW_UPD_RDPTR19_TO_16_8197F(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8197F) & \
BIT_MASK_FW_UPD_RDPTR19_TO_16_8197F)
#define BIT_SET_FW_UPD_RDPTR19_TO_16_8197F(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8197F(x) | \
BIT_FW_UPD_RDPTR19_TO_16_8197F(v))
#define BIT_RXDMA_REQ_8197F BIT(19)
#define BIT_RW_RELEASE_EN_8197F BIT(18)
#define BIT_RXDMA_IDLE_8197F BIT(17)
#define BIT_RXPKT_RELEASE_POLL_8197F BIT(16)
#define BIT_SHIFT_FW_UPD_RDPTR_8197F 0
#define BIT_MASK_FW_UPD_RDPTR_8197F 0xffff
#define BIT_FW_UPD_RDPTR_8197F(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR_8197F) << BIT_SHIFT_FW_UPD_RDPTR_8197F)
#define BITS_FW_UPD_RDPTR_8197F \
(BIT_MASK_FW_UPD_RDPTR_8197F << BIT_SHIFT_FW_UPD_RDPTR_8197F)
#define BIT_CLEAR_FW_UPD_RDPTR_8197F(x) ((x) & (~BITS_FW_UPD_RDPTR_8197F))
#define BIT_GET_FW_UPD_RDPTR_8197F(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR_8197F) & BIT_MASK_FW_UPD_RDPTR_8197F)
#define BIT_SET_FW_UPD_RDPTR_8197F(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR_8197F(x) | BIT_FW_UPD_RDPTR_8197F(v))
/* 2 REG_RXDMA_STATUS_8197F */
#define BIT_FC2H_PKT_OVERFLOW_8197F BIT(8)
#define BIT_C2H_PKT_OVF_8197F BIT(7)
#define BIT_AGG_CONFGI_ISSUE_8197F BIT(6)
#define BIT_FW_POLL_ISSUE_8197F BIT(5)
#define BIT_RX_DATA_UDN_8197F BIT(4)
#define BIT_RX_SFF_UDN_8197F BIT(3)
#define BIT_RX_SFF_OVF_8197F BIT(2)
#define BIT_RXPKT_OVF_8197F BIT(0)
/* 2 REG_RXDMA_DPR_8197F */
#define BIT_SHIFT_RDE_DEBUG_8197F 0
#define BIT_MASK_RDE_DEBUG_8197F 0xffffffffL
#define BIT_RDE_DEBUG_8197F(x) \
(((x) & BIT_MASK_RDE_DEBUG_8197F) << BIT_SHIFT_RDE_DEBUG_8197F)
#define BITS_RDE_DEBUG_8197F \
(BIT_MASK_RDE_DEBUG_8197F << BIT_SHIFT_RDE_DEBUG_8197F)
#define BIT_CLEAR_RDE_DEBUG_8197F(x) ((x) & (~BITS_RDE_DEBUG_8197F))
#define BIT_GET_RDE_DEBUG_8197F(x) \
(((x) >> BIT_SHIFT_RDE_DEBUG_8197F) & BIT_MASK_RDE_DEBUG_8197F)
#define BIT_SET_RDE_DEBUG_8197F(x, v) \
(BIT_CLEAR_RDE_DEBUG_8197F(x) | BIT_RDE_DEBUG_8197F(v))
/* 2 REG_RXDMA_MODE_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_EN_SPD_8197F BIT(6)
#define BIT_SHIFT_BURST_SIZE_8197F 4
#define BIT_MASK_BURST_SIZE_8197F 0x3
#define BIT_BURST_SIZE_8197F(x) \
(((x) & BIT_MASK_BURST_SIZE_8197F) << BIT_SHIFT_BURST_SIZE_8197F)
#define BITS_BURST_SIZE_8197F \
(BIT_MASK_BURST_SIZE_8197F << BIT_SHIFT_BURST_SIZE_8197F)
#define BIT_CLEAR_BURST_SIZE_8197F(x) ((x) & (~BITS_BURST_SIZE_8197F))
#define BIT_GET_BURST_SIZE_8197F(x) \
(((x) >> BIT_SHIFT_BURST_SIZE_8197F) & BIT_MASK_BURST_SIZE_8197F)
#define BIT_SET_BURST_SIZE_8197F(x, v) \
(BIT_CLEAR_BURST_SIZE_8197F(x) | BIT_BURST_SIZE_8197F(v))
#define BIT_SHIFT_BURST_CNT_8197F 2
#define BIT_MASK_BURST_CNT_8197F 0x3
#define BIT_BURST_CNT_8197F(x) \
(((x) & BIT_MASK_BURST_CNT_8197F) << BIT_SHIFT_BURST_CNT_8197F)
#define BITS_BURST_CNT_8197F \
(BIT_MASK_BURST_CNT_8197F << BIT_SHIFT_BURST_CNT_8197F)
#define BIT_CLEAR_BURST_CNT_8197F(x) ((x) & (~BITS_BURST_CNT_8197F))
#define BIT_GET_BURST_CNT_8197F(x) \
(((x) >> BIT_SHIFT_BURST_CNT_8197F) & BIT_MASK_BURST_CNT_8197F)
#define BIT_SET_BURST_CNT_8197F(x, v) \
(BIT_CLEAR_BURST_CNT_8197F(x) | BIT_BURST_CNT_8197F(v))
#define BIT_DMA_MODE_8197F BIT(1)
/* 2 REG_C2H_PKT_8197F */
#define BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8197F 24
#define BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8197F 0xf
#define BIT_R_C2H_STR_ADDR_16_TO_19_8197F(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8197F) \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8197F)
#define BITS_R_C2H_STR_ADDR_16_TO_19_8197F \
(BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8197F \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8197F)
#define BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8197F(x) \
((x) & (~BITS_R_C2H_STR_ADDR_16_TO_19_8197F))
#define BIT_GET_R_C2H_STR_ADDR_16_TO_19_8197F(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8197F) & \
BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8197F)
#define BIT_SET_R_C2H_STR_ADDR_16_TO_19_8197F(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8197F(x) | \
BIT_R_C2H_STR_ADDR_16_TO_19_8197F(v))
#define BIT_R_C2H_PKT_REQ_8197F BIT(16)
#define BIT_SHIFT_R_C2H_STR_ADDR_8197F 0
#define BIT_MASK_R_C2H_STR_ADDR_8197F 0xffff
#define BIT_R_C2H_STR_ADDR_8197F(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_8197F) \
<< BIT_SHIFT_R_C2H_STR_ADDR_8197F)
#define BITS_R_C2H_STR_ADDR_8197F \
(BIT_MASK_R_C2H_STR_ADDR_8197F << BIT_SHIFT_R_C2H_STR_ADDR_8197F)
#define BIT_CLEAR_R_C2H_STR_ADDR_8197F(x) ((x) & (~BITS_R_C2H_STR_ADDR_8197F))
#define BIT_GET_R_C2H_STR_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_8197F) & \
BIT_MASK_R_C2H_STR_ADDR_8197F)
#define BIT_SET_R_C2H_STR_ADDR_8197F(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_8197F(x) | BIT_R_C2H_STR_ADDR_8197F(v))
/* 2 REG_FWFF_C2H_8197F */
#define BIT_SHIFT_C2H_DMA_ADDR_8197F 0
#define BIT_MASK_C2H_DMA_ADDR_8197F 0x3ffff
#define BIT_C2H_DMA_ADDR_8197F(x) \
(((x) & BIT_MASK_C2H_DMA_ADDR_8197F) << BIT_SHIFT_C2H_DMA_ADDR_8197F)
#define BITS_C2H_DMA_ADDR_8197F \
(BIT_MASK_C2H_DMA_ADDR_8197F << BIT_SHIFT_C2H_DMA_ADDR_8197F)
#define BIT_CLEAR_C2H_DMA_ADDR_8197F(x) ((x) & (~BITS_C2H_DMA_ADDR_8197F))
#define BIT_GET_C2H_DMA_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_C2H_DMA_ADDR_8197F) & BIT_MASK_C2H_DMA_ADDR_8197F)
#define BIT_SET_C2H_DMA_ADDR_8197F(x, v) \
(BIT_CLEAR_C2H_DMA_ADDR_8197F(x) | BIT_C2H_DMA_ADDR_8197F(v))
/* 2 REG_FWFF_CTRL_8197F */
#define BIT_FWFF_DMAPKT_REQ_8197F BIT(31)
#define BIT_SHIFT_FWFF_DMA_PKT_NUM_8197F 16
#define BIT_MASK_FWFF_DMA_PKT_NUM_8197F 0xff
#define BIT_FWFF_DMA_PKT_NUM_8197F(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM_8197F) \
<< BIT_SHIFT_FWFF_DMA_PKT_NUM_8197F)
#define BITS_FWFF_DMA_PKT_NUM_8197F \
(BIT_MASK_FWFF_DMA_PKT_NUM_8197F << BIT_SHIFT_FWFF_DMA_PKT_NUM_8197F)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM_8197F(x) \
((x) & (~BITS_FWFF_DMA_PKT_NUM_8197F))
#define BIT_GET_FWFF_DMA_PKT_NUM_8197F(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM_8197F) & \
BIT_MASK_FWFF_DMA_PKT_NUM_8197F)
#define BIT_SET_FWFF_DMA_PKT_NUM_8197F(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM_8197F(x) | BIT_FWFF_DMA_PKT_NUM_8197F(v))
#define BIT_SHIFT_FWFF_STR_ADDR_8197F 0
#define BIT_MASK_FWFF_STR_ADDR_8197F 0xffff
#define BIT_FWFF_STR_ADDR_8197F(x) \
(((x) & BIT_MASK_FWFF_STR_ADDR_8197F) << BIT_SHIFT_FWFF_STR_ADDR_8197F)
#define BITS_FWFF_STR_ADDR_8197F \
(BIT_MASK_FWFF_STR_ADDR_8197F << BIT_SHIFT_FWFF_STR_ADDR_8197F)
#define BIT_CLEAR_FWFF_STR_ADDR_8197F(x) ((x) & (~BITS_FWFF_STR_ADDR_8197F))
#define BIT_GET_FWFF_STR_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_FWFF_STR_ADDR_8197F) & BIT_MASK_FWFF_STR_ADDR_8197F)
#define BIT_SET_FWFF_STR_ADDR_8197F(x, v) \
(BIT_CLEAR_FWFF_STR_ADDR_8197F(x) | BIT_FWFF_STR_ADDR_8197F(v))
/* 2 REG_FWFF_PKT_INFO_8197F */
#define BIT_SHIFT_FWFF_PKT_QUEUED_8197F 16
#define BIT_MASK_FWFF_PKT_QUEUED_8197F 0xff
#define BIT_FWFF_PKT_QUEUED_8197F(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED_8197F) \
<< BIT_SHIFT_FWFF_PKT_QUEUED_8197F)
#define BITS_FWFF_PKT_QUEUED_8197F \
(BIT_MASK_FWFF_PKT_QUEUED_8197F << BIT_SHIFT_FWFF_PKT_QUEUED_8197F)
#define BIT_CLEAR_FWFF_PKT_QUEUED_8197F(x) ((x) & (~BITS_FWFF_PKT_QUEUED_8197F))
#define BIT_GET_FWFF_PKT_QUEUED_8197F(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED_8197F) & \
BIT_MASK_FWFF_PKT_QUEUED_8197F)
#define BIT_SET_FWFF_PKT_QUEUED_8197F(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED_8197F(x) | BIT_FWFF_PKT_QUEUED_8197F(v))
#define BIT_SHIFT_FWFF_PKT_STR_ADDR_8197F 0
#define BIT_MASK_FWFF_PKT_STR_ADDR_8197F 0xffff
#define BIT_FWFF_PKT_STR_ADDR_8197F(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR_8197F) \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_8197F)
#define BITS_FWFF_PKT_STR_ADDR_8197F \
(BIT_MASK_FWFF_PKT_STR_ADDR_8197F << BIT_SHIFT_FWFF_PKT_STR_ADDR_8197F)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR_8197F(x) \
((x) & (~BITS_FWFF_PKT_STR_ADDR_8197F))
#define BIT_GET_FWFF_PKT_STR_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR_8197F) & \
BIT_MASK_FWFF_PKT_STR_ADDR_8197F)
#define BIT_SET_FWFF_PKT_STR_ADDR_8197F(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR_8197F(x) | BIT_FWFF_PKT_STR_ADDR_8197F(v))
/* 2 REG_FC2H_INFO_8197F */
#define BIT_FC2H_PKT_REQ_8197F BIT(16)
#define BIT_SHIFT_FC2H_STR_ADDR_8197F 0
#define BIT_MASK_FC2H_STR_ADDR_8197F 0xffff
#define BIT_FC2H_STR_ADDR_8197F(x) \
(((x) & BIT_MASK_FC2H_STR_ADDR_8197F) << BIT_SHIFT_FC2H_STR_ADDR_8197F)
#define BITS_FC2H_STR_ADDR_8197F \
(BIT_MASK_FC2H_STR_ADDR_8197F << BIT_SHIFT_FC2H_STR_ADDR_8197F)
#define BIT_CLEAR_FC2H_STR_ADDR_8197F(x) ((x) & (~BITS_FC2H_STR_ADDR_8197F))
#define BIT_GET_FC2H_STR_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_FC2H_STR_ADDR_8197F) & BIT_MASK_FC2H_STR_ADDR_8197F)
#define BIT_SET_FC2H_STR_ADDR_8197F(x, v) \
(BIT_CLEAR_FC2H_STR_ADDR_8197F(x) | BIT_FC2H_STR_ADDR_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_DDMA_CH0SA_8197F */
#define BIT_SHIFT_DDMACH0_SA_8197F 0
#define BIT_MASK_DDMACH0_SA_8197F 0xffffffffL
#define BIT_DDMACH0_SA_8197F(x) \
(((x) & BIT_MASK_DDMACH0_SA_8197F) << BIT_SHIFT_DDMACH0_SA_8197F)
#define BITS_DDMACH0_SA_8197F \
(BIT_MASK_DDMACH0_SA_8197F << BIT_SHIFT_DDMACH0_SA_8197F)
#define BIT_CLEAR_DDMACH0_SA_8197F(x) ((x) & (~BITS_DDMACH0_SA_8197F))
#define BIT_GET_DDMACH0_SA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH0_SA_8197F) & BIT_MASK_DDMACH0_SA_8197F)
#define BIT_SET_DDMACH0_SA_8197F(x, v) \
(BIT_CLEAR_DDMACH0_SA_8197F(x) | BIT_DDMACH0_SA_8197F(v))
/* 2 REG_DDMA_CH0DA_8197F */
#define BIT_SHIFT_DDMACH0_DA_8197F 0
#define BIT_MASK_DDMACH0_DA_8197F 0xffffffffL
#define BIT_DDMACH0_DA_8197F(x) \
(((x) & BIT_MASK_DDMACH0_DA_8197F) << BIT_SHIFT_DDMACH0_DA_8197F)
#define BITS_DDMACH0_DA_8197F \
(BIT_MASK_DDMACH0_DA_8197F << BIT_SHIFT_DDMACH0_DA_8197F)
#define BIT_CLEAR_DDMACH0_DA_8197F(x) ((x) & (~BITS_DDMACH0_DA_8197F))
#define BIT_GET_DDMACH0_DA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH0_DA_8197F) & BIT_MASK_DDMACH0_DA_8197F)
#define BIT_SET_DDMACH0_DA_8197F(x, v) \
(BIT_CLEAR_DDMACH0_DA_8197F(x) | BIT_DDMACH0_DA_8197F(v))
/* 2 REG_DDMA_CH0CTRL_8197F */
#define BIT_DDMACH0_OWN_8197F BIT(31)
#define BIT_DDMACH0_CHKSUM_EN_8197F BIT(29)
#define BIT_DDMACH0_DA_W_DISABLE_8197F BIT(28)
#define BIT_DDMACH0_CHKSUM_STS_8197F BIT(27)
#define BIT_DDMACH0_DDMA_MODE_8197F BIT(26)
#define BIT_DDMACH0_RESET_CHKSUM_STS_8197F BIT(25)
#define BIT_DDMACH0_CHKSUM_CONT_8197F BIT(24)
#define BIT_SHIFT_DDMACH0_DLEN_8197F 0
#define BIT_MASK_DDMACH0_DLEN_8197F 0x3ffff
#define BIT_DDMACH0_DLEN_8197F(x) \
(((x) & BIT_MASK_DDMACH0_DLEN_8197F) << BIT_SHIFT_DDMACH0_DLEN_8197F)
#define BITS_DDMACH0_DLEN_8197F \
(BIT_MASK_DDMACH0_DLEN_8197F << BIT_SHIFT_DDMACH0_DLEN_8197F)
#define BIT_CLEAR_DDMACH0_DLEN_8197F(x) ((x) & (~BITS_DDMACH0_DLEN_8197F))
#define BIT_GET_DDMACH0_DLEN_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH0_DLEN_8197F) & BIT_MASK_DDMACH0_DLEN_8197F)
#define BIT_SET_DDMACH0_DLEN_8197F(x, v) \
(BIT_CLEAR_DDMACH0_DLEN_8197F(x) | BIT_DDMACH0_DLEN_8197F(v))
/* 2 REG_DDMA_CH1SA_8197F */
#define BIT_SHIFT_DDMACH1_SA_8197F 0
#define BIT_MASK_DDMACH1_SA_8197F 0xffffffffL
#define BIT_DDMACH1_SA_8197F(x) \
(((x) & BIT_MASK_DDMACH1_SA_8197F) << BIT_SHIFT_DDMACH1_SA_8197F)
#define BITS_DDMACH1_SA_8197F \
(BIT_MASK_DDMACH1_SA_8197F << BIT_SHIFT_DDMACH1_SA_8197F)
#define BIT_CLEAR_DDMACH1_SA_8197F(x) ((x) & (~BITS_DDMACH1_SA_8197F))
#define BIT_GET_DDMACH1_SA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH1_SA_8197F) & BIT_MASK_DDMACH1_SA_8197F)
#define BIT_SET_DDMACH1_SA_8197F(x, v) \
(BIT_CLEAR_DDMACH1_SA_8197F(x) | BIT_DDMACH1_SA_8197F(v))
/* 2 REG_DDMA_CH1DA_8197F */
#define BIT_SHIFT_DDMACH1_DA_8197F 0
#define BIT_MASK_DDMACH1_DA_8197F 0xffffffffL
#define BIT_DDMACH1_DA_8197F(x) \
(((x) & BIT_MASK_DDMACH1_DA_8197F) << BIT_SHIFT_DDMACH1_DA_8197F)
#define BITS_DDMACH1_DA_8197F \
(BIT_MASK_DDMACH1_DA_8197F << BIT_SHIFT_DDMACH1_DA_8197F)
#define BIT_CLEAR_DDMACH1_DA_8197F(x) ((x) & (~BITS_DDMACH1_DA_8197F))
#define BIT_GET_DDMACH1_DA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH1_DA_8197F) & BIT_MASK_DDMACH1_DA_8197F)
#define BIT_SET_DDMACH1_DA_8197F(x, v) \
(BIT_CLEAR_DDMACH1_DA_8197F(x) | BIT_DDMACH1_DA_8197F(v))
/* 2 REG_DDMA_CH1CTRL_8197F */
#define BIT_DDMACH1_OWN_8197F BIT(31)
#define BIT_DDMACH1_CHKSUM_EN_8197F BIT(29)
#define BIT_DDMACH1_DA_W_DISABLE_8197F BIT(28)
#define BIT_DDMACH1_CHKSUM_STS_8197F BIT(27)
#define BIT_DDMACH1_DDMA_MODE_8197F BIT(26)
#define BIT_DDMACH1_RESET_CHKSUM_STS_8197F BIT(25)
#define BIT_DDMACH1_CHKSUM_CONT_8197F BIT(24)
#define BIT_SHIFT_DDMACH1_DLEN_8197F 0
#define BIT_MASK_DDMACH1_DLEN_8197F 0x3ffff
#define BIT_DDMACH1_DLEN_8197F(x) \
(((x) & BIT_MASK_DDMACH1_DLEN_8197F) << BIT_SHIFT_DDMACH1_DLEN_8197F)
#define BITS_DDMACH1_DLEN_8197F \
(BIT_MASK_DDMACH1_DLEN_8197F << BIT_SHIFT_DDMACH1_DLEN_8197F)
#define BIT_CLEAR_DDMACH1_DLEN_8197F(x) ((x) & (~BITS_DDMACH1_DLEN_8197F))
#define BIT_GET_DDMACH1_DLEN_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH1_DLEN_8197F) & BIT_MASK_DDMACH1_DLEN_8197F)
#define BIT_SET_DDMACH1_DLEN_8197F(x, v) \
(BIT_CLEAR_DDMACH1_DLEN_8197F(x) | BIT_DDMACH1_DLEN_8197F(v))
/* 2 REG_DDMA_CH2SA_8197F */
#define BIT_SHIFT_DDMACH2_SA_8197F 0
#define BIT_MASK_DDMACH2_SA_8197F 0xffffffffL
#define BIT_DDMACH2_SA_8197F(x) \
(((x) & BIT_MASK_DDMACH2_SA_8197F) << BIT_SHIFT_DDMACH2_SA_8197F)
#define BITS_DDMACH2_SA_8197F \
(BIT_MASK_DDMACH2_SA_8197F << BIT_SHIFT_DDMACH2_SA_8197F)
#define BIT_CLEAR_DDMACH2_SA_8197F(x) ((x) & (~BITS_DDMACH2_SA_8197F))
#define BIT_GET_DDMACH2_SA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH2_SA_8197F) & BIT_MASK_DDMACH2_SA_8197F)
#define BIT_SET_DDMACH2_SA_8197F(x, v) \
(BIT_CLEAR_DDMACH2_SA_8197F(x) | BIT_DDMACH2_SA_8197F(v))
/* 2 REG_DDMA_CH2DA_8197F */
#define BIT_SHIFT_DDMACH2_DA_8197F 0
#define BIT_MASK_DDMACH2_DA_8197F 0xffffffffL
#define BIT_DDMACH2_DA_8197F(x) \
(((x) & BIT_MASK_DDMACH2_DA_8197F) << BIT_SHIFT_DDMACH2_DA_8197F)
#define BITS_DDMACH2_DA_8197F \
(BIT_MASK_DDMACH2_DA_8197F << BIT_SHIFT_DDMACH2_DA_8197F)
#define BIT_CLEAR_DDMACH2_DA_8197F(x) ((x) & (~BITS_DDMACH2_DA_8197F))
#define BIT_GET_DDMACH2_DA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH2_DA_8197F) & BIT_MASK_DDMACH2_DA_8197F)
#define BIT_SET_DDMACH2_DA_8197F(x, v) \
(BIT_CLEAR_DDMACH2_DA_8197F(x) | BIT_DDMACH2_DA_8197F(v))
/* 2 REG_DDMA_CH2CTRL_8197F */
#define BIT_DDMACH2_OWN_8197F BIT(31)
#define BIT_DDMACH2_CHKSUM_EN_8197F BIT(29)
#define BIT_DDMACH2_DA_W_DISABLE_8197F BIT(28)
#define BIT_DDMACH2_CHKSUM_STS_8197F BIT(27)
#define BIT_DDMACH2_DDMA_MODE_8197F BIT(26)
#define BIT_DDMACH2_RESET_CHKSUM_STS_8197F BIT(25)
#define BIT_DDMACH2_CHKSUM_CONT_8197F BIT(24)
#define BIT_SHIFT_DDMACH2_DLEN_8197F 0
#define BIT_MASK_DDMACH2_DLEN_8197F 0x3ffff
#define BIT_DDMACH2_DLEN_8197F(x) \
(((x) & BIT_MASK_DDMACH2_DLEN_8197F) << BIT_SHIFT_DDMACH2_DLEN_8197F)
#define BITS_DDMACH2_DLEN_8197F \
(BIT_MASK_DDMACH2_DLEN_8197F << BIT_SHIFT_DDMACH2_DLEN_8197F)
#define BIT_CLEAR_DDMACH2_DLEN_8197F(x) ((x) & (~BITS_DDMACH2_DLEN_8197F))
#define BIT_GET_DDMACH2_DLEN_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH2_DLEN_8197F) & BIT_MASK_DDMACH2_DLEN_8197F)
#define BIT_SET_DDMACH2_DLEN_8197F(x, v) \
(BIT_CLEAR_DDMACH2_DLEN_8197F(x) | BIT_DDMACH2_DLEN_8197F(v))
/* 2 REG_DDMA_CH3SA_8197F */
#define BIT_SHIFT_DDMACH3_SA_8197F 0
#define BIT_MASK_DDMACH3_SA_8197F 0xffffffffL
#define BIT_DDMACH3_SA_8197F(x) \
(((x) & BIT_MASK_DDMACH3_SA_8197F) << BIT_SHIFT_DDMACH3_SA_8197F)
#define BITS_DDMACH3_SA_8197F \
(BIT_MASK_DDMACH3_SA_8197F << BIT_SHIFT_DDMACH3_SA_8197F)
#define BIT_CLEAR_DDMACH3_SA_8197F(x) ((x) & (~BITS_DDMACH3_SA_8197F))
#define BIT_GET_DDMACH3_SA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH3_SA_8197F) & BIT_MASK_DDMACH3_SA_8197F)
#define BIT_SET_DDMACH3_SA_8197F(x, v) \
(BIT_CLEAR_DDMACH3_SA_8197F(x) | BIT_DDMACH3_SA_8197F(v))
/* 2 REG_DDMA_CH3DA_8197F */
#define BIT_SHIFT_DDMACH3_DA_8197F 0
#define BIT_MASK_DDMACH3_DA_8197F 0xffffffffL
#define BIT_DDMACH3_DA_8197F(x) \
(((x) & BIT_MASK_DDMACH3_DA_8197F) << BIT_SHIFT_DDMACH3_DA_8197F)
#define BITS_DDMACH3_DA_8197F \
(BIT_MASK_DDMACH3_DA_8197F << BIT_SHIFT_DDMACH3_DA_8197F)
#define BIT_CLEAR_DDMACH3_DA_8197F(x) ((x) & (~BITS_DDMACH3_DA_8197F))
#define BIT_GET_DDMACH3_DA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH3_DA_8197F) & BIT_MASK_DDMACH3_DA_8197F)
#define BIT_SET_DDMACH3_DA_8197F(x, v) \
(BIT_CLEAR_DDMACH3_DA_8197F(x) | BIT_DDMACH3_DA_8197F(v))
/* 2 REG_DDMA_CH3CTRL_8197F */
#define BIT_DDMACH3_OWN_8197F BIT(31)
#define BIT_DDMACH3_CHKSUM_EN_8197F BIT(29)
#define BIT_DDMACH3_DA_W_DISABLE_8197F BIT(28)
#define BIT_DDMACH3_CHKSUM_STS_8197F BIT(27)
#define BIT_DDMACH3_DDMA_MODE_8197F BIT(26)
#define BIT_DDMACH3_RESET_CHKSUM_STS_8197F BIT(25)
#define BIT_DDMACH3_CHKSUM_CONT_8197F BIT(24)
#define BIT_SHIFT_DDMACH3_DLEN_8197F 0
#define BIT_MASK_DDMACH3_DLEN_8197F 0x3ffff
#define BIT_DDMACH3_DLEN_8197F(x) \
(((x) & BIT_MASK_DDMACH3_DLEN_8197F) << BIT_SHIFT_DDMACH3_DLEN_8197F)
#define BITS_DDMACH3_DLEN_8197F \
(BIT_MASK_DDMACH3_DLEN_8197F << BIT_SHIFT_DDMACH3_DLEN_8197F)
#define BIT_CLEAR_DDMACH3_DLEN_8197F(x) ((x) & (~BITS_DDMACH3_DLEN_8197F))
#define BIT_GET_DDMACH3_DLEN_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH3_DLEN_8197F) & BIT_MASK_DDMACH3_DLEN_8197F)
#define BIT_SET_DDMACH3_DLEN_8197F(x, v) \
(BIT_CLEAR_DDMACH3_DLEN_8197F(x) | BIT_DDMACH3_DLEN_8197F(v))
/* 2 REG_DDMA_CH4SA_8197F */
#define BIT_SHIFT_DDMACH4_SA_8197F 0
#define BIT_MASK_DDMACH4_SA_8197F 0xffffffffL
#define BIT_DDMACH4_SA_8197F(x) \
(((x) & BIT_MASK_DDMACH4_SA_8197F) << BIT_SHIFT_DDMACH4_SA_8197F)
#define BITS_DDMACH4_SA_8197F \
(BIT_MASK_DDMACH4_SA_8197F << BIT_SHIFT_DDMACH4_SA_8197F)
#define BIT_CLEAR_DDMACH4_SA_8197F(x) ((x) & (~BITS_DDMACH4_SA_8197F))
#define BIT_GET_DDMACH4_SA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH4_SA_8197F) & BIT_MASK_DDMACH4_SA_8197F)
#define BIT_SET_DDMACH4_SA_8197F(x, v) \
(BIT_CLEAR_DDMACH4_SA_8197F(x) | BIT_DDMACH4_SA_8197F(v))
/* 2 REG_DDMA_CH4DA_8197F */
#define BIT_SHIFT_DDMACH4_DA_8197F 0
#define BIT_MASK_DDMACH4_DA_8197F 0xffffffffL
#define BIT_DDMACH4_DA_8197F(x) \
(((x) & BIT_MASK_DDMACH4_DA_8197F) << BIT_SHIFT_DDMACH4_DA_8197F)
#define BITS_DDMACH4_DA_8197F \
(BIT_MASK_DDMACH4_DA_8197F << BIT_SHIFT_DDMACH4_DA_8197F)
#define BIT_CLEAR_DDMACH4_DA_8197F(x) ((x) & (~BITS_DDMACH4_DA_8197F))
#define BIT_GET_DDMACH4_DA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH4_DA_8197F) & BIT_MASK_DDMACH4_DA_8197F)
#define BIT_SET_DDMACH4_DA_8197F(x, v) \
(BIT_CLEAR_DDMACH4_DA_8197F(x) | BIT_DDMACH4_DA_8197F(v))
/* 2 REG_DDMA_CH4CTRL_8197F */
#define BIT_DDMACH4_OWN_8197F BIT(31)
#define BIT_DDMACH4_CHKSUM_EN_8197F BIT(29)
#define BIT_DDMACH4_DA_W_DISABLE_8197F BIT(28)
#define BIT_DDMACH4_CHKSUM_STS_8197F BIT(27)
#define BIT_DDMACH4_DDMA_MODE_8197F BIT(26)
#define BIT_DDMACH4_RESET_CHKSUM_STS_8197F BIT(25)
#define BIT_DDMACH4_CHKSUM_CONT_8197F BIT(24)
#define BIT_SHIFT_DDMACH4_DLEN_8197F 0
#define BIT_MASK_DDMACH4_DLEN_8197F 0x3ffff
#define BIT_DDMACH4_DLEN_8197F(x) \
(((x) & BIT_MASK_DDMACH4_DLEN_8197F) << BIT_SHIFT_DDMACH4_DLEN_8197F)
#define BITS_DDMACH4_DLEN_8197F \
(BIT_MASK_DDMACH4_DLEN_8197F << BIT_SHIFT_DDMACH4_DLEN_8197F)
#define BIT_CLEAR_DDMACH4_DLEN_8197F(x) ((x) & (~BITS_DDMACH4_DLEN_8197F))
#define BIT_GET_DDMACH4_DLEN_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH4_DLEN_8197F) & BIT_MASK_DDMACH4_DLEN_8197F)
#define BIT_SET_DDMACH4_DLEN_8197F(x, v) \
(BIT_CLEAR_DDMACH4_DLEN_8197F(x) | BIT_DDMACH4_DLEN_8197F(v))
/* 2 REG_DDMA_CH5SA_8197F */
#define BIT_SHIFT_DDMACH5_SA_8197F 0
#define BIT_MASK_DDMACH5_SA_8197F 0xffffffffL
#define BIT_DDMACH5_SA_8197F(x) \
(((x) & BIT_MASK_DDMACH5_SA_8197F) << BIT_SHIFT_DDMACH5_SA_8197F)
#define BITS_DDMACH5_SA_8197F \
(BIT_MASK_DDMACH5_SA_8197F << BIT_SHIFT_DDMACH5_SA_8197F)
#define BIT_CLEAR_DDMACH5_SA_8197F(x) ((x) & (~BITS_DDMACH5_SA_8197F))
#define BIT_GET_DDMACH5_SA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH5_SA_8197F) & BIT_MASK_DDMACH5_SA_8197F)
#define BIT_SET_DDMACH5_SA_8197F(x, v) \
(BIT_CLEAR_DDMACH5_SA_8197F(x) | BIT_DDMACH5_SA_8197F(v))
/* 2 REG_DDMA_CH5DA_8197F */
#define BIT_SHIFT_DDMACH5_DA_8197F 0
#define BIT_MASK_DDMACH5_DA_8197F 0xffffffffL
#define BIT_DDMACH5_DA_8197F(x) \
(((x) & BIT_MASK_DDMACH5_DA_8197F) << BIT_SHIFT_DDMACH5_DA_8197F)
#define BITS_DDMACH5_DA_8197F \
(BIT_MASK_DDMACH5_DA_8197F << BIT_SHIFT_DDMACH5_DA_8197F)
#define BIT_CLEAR_DDMACH5_DA_8197F(x) ((x) & (~BITS_DDMACH5_DA_8197F))
#define BIT_GET_DDMACH5_DA_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH5_DA_8197F) & BIT_MASK_DDMACH5_DA_8197F)
#define BIT_SET_DDMACH5_DA_8197F(x, v) \
(BIT_CLEAR_DDMACH5_DA_8197F(x) | BIT_DDMACH5_DA_8197F(v))
/* 2 REG_REG_DDMA_CH5CTRL_8197F */
#define BIT_DDMACH5_OWN_8197F BIT(31)
#define BIT_DDMACH5_CHKSUM_EN_8197F BIT(29)
#define BIT_DDMACH5_DA_W_DISABLE_8197F BIT(28)
#define BIT_DDMACH5_CHKSUM_STS_8197F BIT(27)
#define BIT_DDMACH5_DDMA_MODE_8197F BIT(26)
#define BIT_DDMACH5_RESET_CHKSUM_STS_8197F BIT(25)
#define BIT_DDMACH5_CHKSUM_CONT_8197F BIT(24)
#define BIT_SHIFT_DDMACH5_DLEN_8197F 0
#define BIT_MASK_DDMACH5_DLEN_8197F 0x3ffff
#define BIT_DDMACH5_DLEN_8197F(x) \
(((x) & BIT_MASK_DDMACH5_DLEN_8197F) << BIT_SHIFT_DDMACH5_DLEN_8197F)
#define BITS_DDMACH5_DLEN_8197F \
(BIT_MASK_DDMACH5_DLEN_8197F << BIT_SHIFT_DDMACH5_DLEN_8197F)
#define BIT_CLEAR_DDMACH5_DLEN_8197F(x) ((x) & (~BITS_DDMACH5_DLEN_8197F))
#define BIT_GET_DDMACH5_DLEN_8197F(x) \
(((x) >> BIT_SHIFT_DDMACH5_DLEN_8197F) & BIT_MASK_DDMACH5_DLEN_8197F)
#define BIT_SET_DDMACH5_DLEN_8197F(x, v) \
(BIT_CLEAR_DDMACH5_DLEN_8197F(x) | BIT_DDMACH5_DLEN_8197F(v))
/* 2 REG_DDMA_INT_MSK_8197F */
#define BIT_DDMACH5_MSK_8197F BIT(5)
#define BIT_DDMACH4_MSK_8197F BIT(4)
#define BIT_DDMACH3_MSK_8197F BIT(3)
#define BIT_DDMACH2_MSK_8197F BIT(2)
#define BIT_DDMACH1_MSK_8197F BIT(1)
#define BIT_DDMACH0_MSK_8197F BIT(0)
/* 2 REG_DDMA_CHSTATUS_8197F */
#define BIT_DDMACH5_BUSY_8197F BIT(5)
#define BIT_DDMACH4_BUSY_8197F BIT(4)
#define BIT_DDMACH3_BUSY_8197F BIT(3)
#define BIT_DDMACH2_BUSY_8197F BIT(2)
#define BIT_DDMACH1_BUSY_8197F BIT(1)
#define BIT_DDMACH0_BUSY_8197F BIT(0)
/* 2 REG_DDMA_CHKSUM_8197F */
#define BIT_SHIFT_IDDMA0_CHKSUM_8197F 0
#define BIT_MASK_IDDMA0_CHKSUM_8197F 0xffff
#define BIT_IDDMA0_CHKSUM_8197F(x) \
(((x) & BIT_MASK_IDDMA0_CHKSUM_8197F) << BIT_SHIFT_IDDMA0_CHKSUM_8197F)
#define BITS_IDDMA0_CHKSUM_8197F \
(BIT_MASK_IDDMA0_CHKSUM_8197F << BIT_SHIFT_IDDMA0_CHKSUM_8197F)
#define BIT_CLEAR_IDDMA0_CHKSUM_8197F(x) ((x) & (~BITS_IDDMA0_CHKSUM_8197F))
#define BIT_GET_IDDMA0_CHKSUM_8197F(x) \
(((x) >> BIT_SHIFT_IDDMA0_CHKSUM_8197F) & BIT_MASK_IDDMA0_CHKSUM_8197F)
#define BIT_SET_IDDMA0_CHKSUM_8197F(x, v) \
(BIT_CLEAR_IDDMA0_CHKSUM_8197F(x) | BIT_IDDMA0_CHKSUM_8197F(v))
/* 2 REG_DDMA_MONITOR_8197F */
#define BIT_IDDMA0_PERMU_UNDERFLOW_8197F BIT(14)
#define BIT_IDDMA0_FIFO_UNDERFLOW_8197F BIT(13)
#define BIT_IDDMA0_FIFO_OVERFLOW_8197F BIT(12)
#define BIT_CH5_ERR_8197F BIT(5)
#define BIT_CH4_ERR_8197F BIT(4)
#define BIT_CH3_ERR_8197F BIT(3)
#define BIT_CH2_ERR_8197F BIT(2)
#define BIT_CH1_ERR_8197F BIT(1)
#define BIT_CH0_ERR_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_HCI_CTRL_8197F */
#define BIT_HCIIO_PERSTB_SEL_8197F BIT(31)
#define BIT_SHIFT_HCI_MAX_RXDMA_8197F 28
#define BIT_MASK_HCI_MAX_RXDMA_8197F 0x7
#define BIT_HCI_MAX_RXDMA_8197F(x) \
(((x) & BIT_MASK_HCI_MAX_RXDMA_8197F) << BIT_SHIFT_HCI_MAX_RXDMA_8197F)
#define BITS_HCI_MAX_RXDMA_8197F \
(BIT_MASK_HCI_MAX_RXDMA_8197F << BIT_SHIFT_HCI_MAX_RXDMA_8197F)
#define BIT_CLEAR_HCI_MAX_RXDMA_8197F(x) ((x) & (~BITS_HCI_MAX_RXDMA_8197F))
#define BIT_GET_HCI_MAX_RXDMA_8197F(x) \
(((x) >> BIT_SHIFT_HCI_MAX_RXDMA_8197F) & BIT_MASK_HCI_MAX_RXDMA_8197F)
#define BIT_SET_HCI_MAX_RXDMA_8197F(x, v) \
(BIT_CLEAR_HCI_MAX_RXDMA_8197F(x) | BIT_HCI_MAX_RXDMA_8197F(v))
#define BIT_MULRW_8197F BIT(27)
#define BIT_SHIFT_HCI_MAX_TXDMA_8197F 24
#define BIT_MASK_HCI_MAX_TXDMA_8197F 0x7
#define BIT_HCI_MAX_TXDMA_8197F(x) \
(((x) & BIT_MASK_HCI_MAX_TXDMA_8197F) << BIT_SHIFT_HCI_MAX_TXDMA_8197F)
#define BITS_HCI_MAX_TXDMA_8197F \
(BIT_MASK_HCI_MAX_TXDMA_8197F << BIT_SHIFT_HCI_MAX_TXDMA_8197F)
#define BIT_CLEAR_HCI_MAX_TXDMA_8197F(x) ((x) & (~BITS_HCI_MAX_TXDMA_8197F))
#define BIT_GET_HCI_MAX_TXDMA_8197F(x) \
(((x) >> BIT_SHIFT_HCI_MAX_TXDMA_8197F) & BIT_MASK_HCI_MAX_TXDMA_8197F)
#define BIT_SET_HCI_MAX_TXDMA_8197F(x, v) \
(BIT_CLEAR_HCI_MAX_TXDMA_8197F(x) | BIT_HCI_MAX_TXDMA_8197F(v))
#define BIT_EN_CPL_TIMEOUT_PS_8197F BIT(22)
#define BIT_REG_TXDMA_FAIL_PS_8197F BIT(21)
#define BIT_HCI_RST_TRXDMA_INTF_8197F BIT(20)
#define BIT_EN_HWENTR_L1_8197F BIT(19)
#define BIT_EN_ADV_CLKGATE_8197F BIT(18)
#define BIT_HCI_EN_SWENT_L23_8197F BIT(17)
#define BIT_HCI_EN_HWEXT_L1_8197F BIT(16)
#define BIT_RX_CLOSE_EN_8197F BIT(15)
#define BIT_STOP_BCNQ_8197F BIT(14)
#define BIT_STOP_MGQ_8197F BIT(13)
#define BIT_STOP_VOQ_8197F BIT(12)
#define BIT_STOP_VIQ_8197F BIT(11)
#define BIT_STOP_BEQ_8197F BIT(10)
#define BIT_STOP_BKQ_8197F BIT(9)
#define BIT_STOP_RXQ_8197F BIT(8)
#define BIT_STOP_HI7Q_8197F BIT(7)
#define BIT_STOP_HI6Q_8197F BIT(6)
#define BIT_STOP_HI5Q_8197F BIT(5)
#define BIT_STOP_HI4Q_8197F BIT(4)
#define BIT_STOP_HI3Q_8197F BIT(3)
#define BIT_STOP_HI2Q_8197F BIT(2)
#define BIT_STOP_HI1Q_8197F BIT(1)
#define BIT_STOP_HI0Q_8197F BIT(0)
/* 2 REG_INT_MIG_8197F */
#define BIT_SHIFT_TXTTIMER_MATCH_NUM_8197F 28
#define BIT_MASK_TXTTIMER_MATCH_NUM_8197F 0xf
#define BIT_TXTTIMER_MATCH_NUM_8197F(x) \
(((x) & BIT_MASK_TXTTIMER_MATCH_NUM_8197F) \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8197F)
#define BITS_TXTTIMER_MATCH_NUM_8197F \
(BIT_MASK_TXTTIMER_MATCH_NUM_8197F \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8197F)
#define BIT_CLEAR_TXTTIMER_MATCH_NUM_8197F(x) \
((x) & (~BITS_TXTTIMER_MATCH_NUM_8197F))
#define BIT_GET_TXTTIMER_MATCH_NUM_8197F(x) \
(((x) >> BIT_SHIFT_TXTTIMER_MATCH_NUM_8197F) & \
BIT_MASK_TXTTIMER_MATCH_NUM_8197F)
#define BIT_SET_TXTTIMER_MATCH_NUM_8197F(x, v) \
(BIT_CLEAR_TXTTIMER_MATCH_NUM_8197F(x) | \
BIT_TXTTIMER_MATCH_NUM_8197F(v))
#define BIT_SHIFT_TXPKT_NUM_MATCH_8197F 24
#define BIT_MASK_TXPKT_NUM_MATCH_8197F 0xf
#define BIT_TXPKT_NUM_MATCH_8197F(x) \
(((x) & BIT_MASK_TXPKT_NUM_MATCH_8197F) \
<< BIT_SHIFT_TXPKT_NUM_MATCH_8197F)
#define BITS_TXPKT_NUM_MATCH_8197F \
(BIT_MASK_TXPKT_NUM_MATCH_8197F << BIT_SHIFT_TXPKT_NUM_MATCH_8197F)
#define BIT_CLEAR_TXPKT_NUM_MATCH_8197F(x) ((x) & (~BITS_TXPKT_NUM_MATCH_8197F))
#define BIT_GET_TXPKT_NUM_MATCH_8197F(x) \
(((x) >> BIT_SHIFT_TXPKT_NUM_MATCH_8197F) & \
BIT_MASK_TXPKT_NUM_MATCH_8197F)
#define BIT_SET_TXPKT_NUM_MATCH_8197F(x, v) \
(BIT_CLEAR_TXPKT_NUM_MATCH_8197F(x) | BIT_TXPKT_NUM_MATCH_8197F(v))
#define BIT_SHIFT_RXTTIMER_MATCH_NUM_8197F 20
#define BIT_MASK_RXTTIMER_MATCH_NUM_8197F 0xf
#define BIT_RXTTIMER_MATCH_NUM_8197F(x) \
(((x) & BIT_MASK_RXTTIMER_MATCH_NUM_8197F) \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8197F)
#define BITS_RXTTIMER_MATCH_NUM_8197F \
(BIT_MASK_RXTTIMER_MATCH_NUM_8197F \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8197F)
#define BIT_CLEAR_RXTTIMER_MATCH_NUM_8197F(x) \
((x) & (~BITS_RXTTIMER_MATCH_NUM_8197F))
#define BIT_GET_RXTTIMER_MATCH_NUM_8197F(x) \
(((x) >> BIT_SHIFT_RXTTIMER_MATCH_NUM_8197F) & \
BIT_MASK_RXTTIMER_MATCH_NUM_8197F)
#define BIT_SET_RXTTIMER_MATCH_NUM_8197F(x, v) \
(BIT_CLEAR_RXTTIMER_MATCH_NUM_8197F(x) | \
BIT_RXTTIMER_MATCH_NUM_8197F(v))
#define BIT_SHIFT_RXPKT_NUM_MATCH_8197F 16
#define BIT_MASK_RXPKT_NUM_MATCH_8197F 0xf
#define BIT_RXPKT_NUM_MATCH_8197F(x) \
(((x) & BIT_MASK_RXPKT_NUM_MATCH_8197F) \
<< BIT_SHIFT_RXPKT_NUM_MATCH_8197F)
#define BITS_RXPKT_NUM_MATCH_8197F \
(BIT_MASK_RXPKT_NUM_MATCH_8197F << BIT_SHIFT_RXPKT_NUM_MATCH_8197F)
#define BIT_CLEAR_RXPKT_NUM_MATCH_8197F(x) ((x) & (~BITS_RXPKT_NUM_MATCH_8197F))
#define BIT_GET_RXPKT_NUM_MATCH_8197F(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_MATCH_8197F) & \
BIT_MASK_RXPKT_NUM_MATCH_8197F)
#define BIT_SET_RXPKT_NUM_MATCH_8197F(x, v) \
(BIT_CLEAR_RXPKT_NUM_MATCH_8197F(x) | BIT_RXPKT_NUM_MATCH_8197F(v))
#define BIT_SHIFT_MIGRATE_TIMER_8197F 0
#define BIT_MASK_MIGRATE_TIMER_8197F 0xffff
#define BIT_MIGRATE_TIMER_8197F(x) \
(((x) & BIT_MASK_MIGRATE_TIMER_8197F) << BIT_SHIFT_MIGRATE_TIMER_8197F)
#define BITS_MIGRATE_TIMER_8197F \
(BIT_MASK_MIGRATE_TIMER_8197F << BIT_SHIFT_MIGRATE_TIMER_8197F)
#define BIT_CLEAR_MIGRATE_TIMER_8197F(x) ((x) & (~BITS_MIGRATE_TIMER_8197F))
#define BIT_GET_MIGRATE_TIMER_8197F(x) \
(((x) >> BIT_SHIFT_MIGRATE_TIMER_8197F) & BIT_MASK_MIGRATE_TIMER_8197F)
#define BIT_SET_MIGRATE_TIMER_8197F(x, v) \
(BIT_CLEAR_MIGRATE_TIMER_8197F(x) | BIT_MIGRATE_TIMER_8197F(v))
/* 2 REG_BCNQ_TXBD_DESA_8197F */
#define BIT_SHIFT_BCNQ_TXBD_DESA_8197F 0
#define BIT_MASK_BCNQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_BCNQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_BCNQ_TXBD_DESA_8197F) \
<< BIT_SHIFT_BCNQ_TXBD_DESA_8197F)
#define BITS_BCNQ_TXBD_DESA_8197F \
(BIT_MASK_BCNQ_TXBD_DESA_8197F << BIT_SHIFT_BCNQ_TXBD_DESA_8197F)
#define BIT_CLEAR_BCNQ_TXBD_DESA_8197F(x) ((x) & (~BITS_BCNQ_TXBD_DESA_8197F))
#define BIT_GET_BCNQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_BCNQ_TXBD_DESA_8197F) & \
BIT_MASK_BCNQ_TXBD_DESA_8197F)
#define BIT_SET_BCNQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_BCNQ_TXBD_DESA_8197F(x) | BIT_BCNQ_TXBD_DESA_8197F(v))
/* 2 REG_MGQ_TXBD_DESA_8197F */
#define BIT_SHIFT_MGQ_TXBD_DESA_8197F 0
#define BIT_MASK_MGQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_MGQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_MGQ_TXBD_DESA_8197F) << BIT_SHIFT_MGQ_TXBD_DESA_8197F)
#define BITS_MGQ_TXBD_DESA_8197F \
(BIT_MASK_MGQ_TXBD_DESA_8197F << BIT_SHIFT_MGQ_TXBD_DESA_8197F)
#define BIT_CLEAR_MGQ_TXBD_DESA_8197F(x) ((x) & (~BITS_MGQ_TXBD_DESA_8197F))
#define BIT_GET_MGQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_TXBD_DESA_8197F) & BIT_MASK_MGQ_TXBD_DESA_8197F)
#define BIT_SET_MGQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_MGQ_TXBD_DESA_8197F(x) | BIT_MGQ_TXBD_DESA_8197F(v))
/* 2 REG_VOQ_TXBD_DESA_8197F */
#define BIT_SHIFT_VOQ_TXBD_DESA_8197F 0
#define BIT_MASK_VOQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_VOQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_VOQ_TXBD_DESA_8197F) << BIT_SHIFT_VOQ_TXBD_DESA_8197F)
#define BITS_VOQ_TXBD_DESA_8197F \
(BIT_MASK_VOQ_TXBD_DESA_8197F << BIT_SHIFT_VOQ_TXBD_DESA_8197F)
#define BIT_CLEAR_VOQ_TXBD_DESA_8197F(x) ((x) & (~BITS_VOQ_TXBD_DESA_8197F))
#define BIT_GET_VOQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_VOQ_TXBD_DESA_8197F) & BIT_MASK_VOQ_TXBD_DESA_8197F)
#define BIT_SET_VOQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_VOQ_TXBD_DESA_8197F(x) | BIT_VOQ_TXBD_DESA_8197F(v))
/* 2 REG_VIQ_TXBD_DESA_8197F */
#define BIT_SHIFT_VIQ_TXBD_DESA_8197F 0
#define BIT_MASK_VIQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_VIQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_VIQ_TXBD_DESA_8197F) << BIT_SHIFT_VIQ_TXBD_DESA_8197F)
#define BITS_VIQ_TXBD_DESA_8197F \
(BIT_MASK_VIQ_TXBD_DESA_8197F << BIT_SHIFT_VIQ_TXBD_DESA_8197F)
#define BIT_CLEAR_VIQ_TXBD_DESA_8197F(x) ((x) & (~BITS_VIQ_TXBD_DESA_8197F))
#define BIT_GET_VIQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_VIQ_TXBD_DESA_8197F) & BIT_MASK_VIQ_TXBD_DESA_8197F)
#define BIT_SET_VIQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_VIQ_TXBD_DESA_8197F(x) | BIT_VIQ_TXBD_DESA_8197F(v))
/* 2 REG_BEQ_TXBD_DESA_8197F */
#define BIT_SHIFT_BEQ_TXBD_DESA_8197F 0
#define BIT_MASK_BEQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_BEQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_BEQ_TXBD_DESA_8197F) << BIT_SHIFT_BEQ_TXBD_DESA_8197F)
#define BITS_BEQ_TXBD_DESA_8197F \
(BIT_MASK_BEQ_TXBD_DESA_8197F << BIT_SHIFT_BEQ_TXBD_DESA_8197F)
#define BIT_CLEAR_BEQ_TXBD_DESA_8197F(x) ((x) & (~BITS_BEQ_TXBD_DESA_8197F))
#define BIT_GET_BEQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_BEQ_TXBD_DESA_8197F) & BIT_MASK_BEQ_TXBD_DESA_8197F)
#define BIT_SET_BEQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_BEQ_TXBD_DESA_8197F(x) | BIT_BEQ_TXBD_DESA_8197F(v))
/* 2 REG_BKQ_TXBD_DESA_8197F */
#define BIT_SHIFT_BKQ_TXBD_DESA_8197F 0
#define BIT_MASK_BKQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_BKQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_BKQ_TXBD_DESA_8197F) << BIT_SHIFT_BKQ_TXBD_DESA_8197F)
#define BITS_BKQ_TXBD_DESA_8197F \
(BIT_MASK_BKQ_TXBD_DESA_8197F << BIT_SHIFT_BKQ_TXBD_DESA_8197F)
#define BIT_CLEAR_BKQ_TXBD_DESA_8197F(x) ((x) & (~BITS_BKQ_TXBD_DESA_8197F))
#define BIT_GET_BKQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_BKQ_TXBD_DESA_8197F) & BIT_MASK_BKQ_TXBD_DESA_8197F)
#define BIT_SET_BKQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_BKQ_TXBD_DESA_8197F(x) | BIT_BKQ_TXBD_DESA_8197F(v))
/* 2 REG_RXQ_RXBD_DESA_8197F */
#define BIT_SHIFT_RXQ_RXBD_DESA_8197F 0
#define BIT_MASK_RXQ_RXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_RXQ_RXBD_DESA_8197F(x) \
(((x) & BIT_MASK_RXQ_RXBD_DESA_8197F) << BIT_SHIFT_RXQ_RXBD_DESA_8197F)
#define BITS_RXQ_RXBD_DESA_8197F \
(BIT_MASK_RXQ_RXBD_DESA_8197F << BIT_SHIFT_RXQ_RXBD_DESA_8197F)
#define BIT_CLEAR_RXQ_RXBD_DESA_8197F(x) ((x) & (~BITS_RXQ_RXBD_DESA_8197F))
#define BIT_GET_RXQ_RXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_RXQ_RXBD_DESA_8197F) & BIT_MASK_RXQ_RXBD_DESA_8197F)
#define BIT_SET_RXQ_RXBD_DESA_8197F(x, v) \
(BIT_CLEAR_RXQ_RXBD_DESA_8197F(x) | BIT_RXQ_RXBD_DESA_8197F(v))
/* 2 REG_HI0Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI0Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI0Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI0Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI0Q_TXBD_DESA_8197F)
#define BITS_HI0Q_TXBD_DESA_8197F \
(BIT_MASK_HI0Q_TXBD_DESA_8197F << BIT_SHIFT_HI0Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI0Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI0Q_TXBD_DESA_8197F))
#define BIT_GET_HI0Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_8197F) & \
BIT_MASK_HI0Q_TXBD_DESA_8197F)
#define BIT_SET_HI0Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_8197F(x) | BIT_HI0Q_TXBD_DESA_8197F(v))
/* 2 REG_HI1Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI1Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI1Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI1Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI1Q_TXBD_DESA_8197F)
#define BITS_HI1Q_TXBD_DESA_8197F \
(BIT_MASK_HI1Q_TXBD_DESA_8197F << BIT_SHIFT_HI1Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI1Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI1Q_TXBD_DESA_8197F))
#define BIT_GET_HI1Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_8197F) & \
BIT_MASK_HI1Q_TXBD_DESA_8197F)
#define BIT_SET_HI1Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_8197F(x) | BIT_HI1Q_TXBD_DESA_8197F(v))
/* 2 REG_HI2Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI2Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI2Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI2Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI2Q_TXBD_DESA_8197F)
#define BITS_HI2Q_TXBD_DESA_8197F \
(BIT_MASK_HI2Q_TXBD_DESA_8197F << BIT_SHIFT_HI2Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI2Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI2Q_TXBD_DESA_8197F))
#define BIT_GET_HI2Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_8197F) & \
BIT_MASK_HI2Q_TXBD_DESA_8197F)
#define BIT_SET_HI2Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_8197F(x) | BIT_HI2Q_TXBD_DESA_8197F(v))
/* 2 REG_HI3Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI3Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI3Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI3Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI3Q_TXBD_DESA_8197F)
#define BITS_HI3Q_TXBD_DESA_8197F \
(BIT_MASK_HI3Q_TXBD_DESA_8197F << BIT_SHIFT_HI3Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI3Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI3Q_TXBD_DESA_8197F))
#define BIT_GET_HI3Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_8197F) & \
BIT_MASK_HI3Q_TXBD_DESA_8197F)
#define BIT_SET_HI3Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_8197F(x) | BIT_HI3Q_TXBD_DESA_8197F(v))
/* 2 REG_HI4Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI4Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI4Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI4Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI4Q_TXBD_DESA_8197F)
#define BITS_HI4Q_TXBD_DESA_8197F \
(BIT_MASK_HI4Q_TXBD_DESA_8197F << BIT_SHIFT_HI4Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI4Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI4Q_TXBD_DESA_8197F))
#define BIT_GET_HI4Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_8197F) & \
BIT_MASK_HI4Q_TXBD_DESA_8197F)
#define BIT_SET_HI4Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_8197F(x) | BIT_HI4Q_TXBD_DESA_8197F(v))
/* 2 REG_HI5Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI5Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI5Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI5Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI5Q_TXBD_DESA_8197F)
#define BITS_HI5Q_TXBD_DESA_8197F \
(BIT_MASK_HI5Q_TXBD_DESA_8197F << BIT_SHIFT_HI5Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI5Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI5Q_TXBD_DESA_8197F))
#define BIT_GET_HI5Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_8197F) & \
BIT_MASK_HI5Q_TXBD_DESA_8197F)
#define BIT_SET_HI5Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_8197F(x) | BIT_HI5Q_TXBD_DESA_8197F(v))
/* 2 REG_HI6Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI6Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI6Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI6Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI6Q_TXBD_DESA_8197F)
#define BITS_HI6Q_TXBD_DESA_8197F \
(BIT_MASK_HI6Q_TXBD_DESA_8197F << BIT_SHIFT_HI6Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI6Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI6Q_TXBD_DESA_8197F))
#define BIT_GET_HI6Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_8197F) & \
BIT_MASK_HI6Q_TXBD_DESA_8197F)
#define BIT_SET_HI6Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_8197F(x) | BIT_HI6Q_TXBD_DESA_8197F(v))
/* 2 REG_HI7Q_TXBD_DESA_8197F */
#define BIT_SHIFT_HI7Q_TXBD_DESA_8197F 0
#define BIT_MASK_HI7Q_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_HI7Q_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_8197F) \
<< BIT_SHIFT_HI7Q_TXBD_DESA_8197F)
#define BITS_HI7Q_TXBD_DESA_8197F \
(BIT_MASK_HI7Q_TXBD_DESA_8197F << BIT_SHIFT_HI7Q_TXBD_DESA_8197F)
#define BIT_CLEAR_HI7Q_TXBD_DESA_8197F(x) ((x) & (~BITS_HI7Q_TXBD_DESA_8197F))
#define BIT_GET_HI7Q_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_8197F) & \
BIT_MASK_HI7Q_TXBD_DESA_8197F)
#define BIT_SET_HI7Q_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_8197F(x) | BIT_HI7Q_TXBD_DESA_8197F(v))
/* 2 REG_MGQ_TXBD_NUM_8197F */
#define BIT_HCI_MGQ_FLAG_8197F BIT(14)
#define BIT_SHIFT_MGQ_DESC_MODE_8197F 12
#define BIT_MASK_MGQ_DESC_MODE_8197F 0x3
#define BIT_MGQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_MGQ_DESC_MODE_8197F) << BIT_SHIFT_MGQ_DESC_MODE_8197F)
#define BITS_MGQ_DESC_MODE_8197F \
(BIT_MASK_MGQ_DESC_MODE_8197F << BIT_SHIFT_MGQ_DESC_MODE_8197F)
#define BIT_CLEAR_MGQ_DESC_MODE_8197F(x) ((x) & (~BITS_MGQ_DESC_MODE_8197F))
#define BIT_GET_MGQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_MODE_8197F) & BIT_MASK_MGQ_DESC_MODE_8197F)
#define BIT_SET_MGQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_MGQ_DESC_MODE_8197F(x) | BIT_MGQ_DESC_MODE_8197F(v))
#define BIT_SHIFT_MGQ_DESC_NUM_8197F 0
#define BIT_MASK_MGQ_DESC_NUM_8197F 0xfff
#define BIT_MGQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_MGQ_DESC_NUM_8197F) << BIT_SHIFT_MGQ_DESC_NUM_8197F)
#define BITS_MGQ_DESC_NUM_8197F \
(BIT_MASK_MGQ_DESC_NUM_8197F << BIT_SHIFT_MGQ_DESC_NUM_8197F)
#define BIT_CLEAR_MGQ_DESC_NUM_8197F(x) ((x) & (~BITS_MGQ_DESC_NUM_8197F))
#define BIT_GET_MGQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_NUM_8197F) & BIT_MASK_MGQ_DESC_NUM_8197F)
#define BIT_SET_MGQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_MGQ_DESC_NUM_8197F(x) | BIT_MGQ_DESC_NUM_8197F(v))
/* 2 REG_RX_RXBD_NUM_8197F */
#define BIT_SYS_32_64_8197F BIT(15)
#define BIT_SHIFT_BCNQ_DESC_MODE_8197F 13
#define BIT_MASK_BCNQ_DESC_MODE_8197F 0x3
#define BIT_BCNQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_BCNQ_DESC_MODE_8197F) \
<< BIT_SHIFT_BCNQ_DESC_MODE_8197F)
#define BITS_BCNQ_DESC_MODE_8197F \
(BIT_MASK_BCNQ_DESC_MODE_8197F << BIT_SHIFT_BCNQ_DESC_MODE_8197F)
#define BIT_CLEAR_BCNQ_DESC_MODE_8197F(x) ((x) & (~BITS_BCNQ_DESC_MODE_8197F))
#define BIT_GET_BCNQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_BCNQ_DESC_MODE_8197F) & \
BIT_MASK_BCNQ_DESC_MODE_8197F)
#define BIT_SET_BCNQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_BCNQ_DESC_MODE_8197F(x) | BIT_BCNQ_DESC_MODE_8197F(v))
#define BIT_HCI_BCNQ_FLAG_8197F BIT(12)
#define BIT_SHIFT_RXQ_DESC_NUM_8197F 0
#define BIT_MASK_RXQ_DESC_NUM_8197F 0xfff
#define BIT_RXQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_RXQ_DESC_NUM_8197F) << BIT_SHIFT_RXQ_DESC_NUM_8197F)
#define BITS_RXQ_DESC_NUM_8197F \
(BIT_MASK_RXQ_DESC_NUM_8197F << BIT_SHIFT_RXQ_DESC_NUM_8197F)
#define BIT_CLEAR_RXQ_DESC_NUM_8197F(x) ((x) & (~BITS_RXQ_DESC_NUM_8197F))
#define BIT_GET_RXQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_RXQ_DESC_NUM_8197F) & BIT_MASK_RXQ_DESC_NUM_8197F)
#define BIT_SET_RXQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_RXQ_DESC_NUM_8197F(x) | BIT_RXQ_DESC_NUM_8197F(v))
/* 2 REG_VOQ_TXBD_NUM_8197F */
#define BIT_HCI_VOQ_FLAG_8197F BIT(14)
#define BIT_SHIFT_VOQ_DESC_MODE_8197F 12
#define BIT_MASK_VOQ_DESC_MODE_8197F 0x3
#define BIT_VOQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_VOQ_DESC_MODE_8197F) << BIT_SHIFT_VOQ_DESC_MODE_8197F)
#define BITS_VOQ_DESC_MODE_8197F \
(BIT_MASK_VOQ_DESC_MODE_8197F << BIT_SHIFT_VOQ_DESC_MODE_8197F)
#define BIT_CLEAR_VOQ_DESC_MODE_8197F(x) ((x) & (~BITS_VOQ_DESC_MODE_8197F))
#define BIT_GET_VOQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_MODE_8197F) & BIT_MASK_VOQ_DESC_MODE_8197F)
#define BIT_SET_VOQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_VOQ_DESC_MODE_8197F(x) | BIT_VOQ_DESC_MODE_8197F(v))
#define BIT_SHIFT_VOQ_DESC_NUM_8197F 0
#define BIT_MASK_VOQ_DESC_NUM_8197F 0xfff
#define BIT_VOQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_VOQ_DESC_NUM_8197F) << BIT_SHIFT_VOQ_DESC_NUM_8197F)
#define BITS_VOQ_DESC_NUM_8197F \
(BIT_MASK_VOQ_DESC_NUM_8197F << BIT_SHIFT_VOQ_DESC_NUM_8197F)
#define BIT_CLEAR_VOQ_DESC_NUM_8197F(x) ((x) & (~BITS_VOQ_DESC_NUM_8197F))
#define BIT_GET_VOQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_NUM_8197F) & BIT_MASK_VOQ_DESC_NUM_8197F)
#define BIT_SET_VOQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_VOQ_DESC_NUM_8197F(x) | BIT_VOQ_DESC_NUM_8197F(v))
/* 2 REG_VIQ_TXBD_NUM_8197F */
#define BIT_HCI_VIQ_FLAG_8197F BIT(14)
#define BIT_SHIFT_VIQ_DESC_MODE_8197F 12
#define BIT_MASK_VIQ_DESC_MODE_8197F 0x3
#define BIT_VIQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_VIQ_DESC_MODE_8197F) << BIT_SHIFT_VIQ_DESC_MODE_8197F)
#define BITS_VIQ_DESC_MODE_8197F \
(BIT_MASK_VIQ_DESC_MODE_8197F << BIT_SHIFT_VIQ_DESC_MODE_8197F)
#define BIT_CLEAR_VIQ_DESC_MODE_8197F(x) ((x) & (~BITS_VIQ_DESC_MODE_8197F))
#define BIT_GET_VIQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_MODE_8197F) & BIT_MASK_VIQ_DESC_MODE_8197F)
#define BIT_SET_VIQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_VIQ_DESC_MODE_8197F(x) | BIT_VIQ_DESC_MODE_8197F(v))
#define BIT_SHIFT_VIQ_DESC_NUM_8197F 0
#define BIT_MASK_VIQ_DESC_NUM_8197F 0xfff
#define BIT_VIQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_VIQ_DESC_NUM_8197F) << BIT_SHIFT_VIQ_DESC_NUM_8197F)
#define BITS_VIQ_DESC_NUM_8197F \
(BIT_MASK_VIQ_DESC_NUM_8197F << BIT_SHIFT_VIQ_DESC_NUM_8197F)
#define BIT_CLEAR_VIQ_DESC_NUM_8197F(x) ((x) & (~BITS_VIQ_DESC_NUM_8197F))
#define BIT_GET_VIQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_NUM_8197F) & BIT_MASK_VIQ_DESC_NUM_8197F)
#define BIT_SET_VIQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_VIQ_DESC_NUM_8197F(x) | BIT_VIQ_DESC_NUM_8197F(v))
/* 2 REG_BEQ_TXBD_NUM_8197F */
#define BIT_HCI_BEQ_FLAG_8197F BIT(14)
#define BIT_SHIFT_BEQ_DESC_MODE_8197F 12
#define BIT_MASK_BEQ_DESC_MODE_8197F 0x3
#define BIT_BEQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_BEQ_DESC_MODE_8197F) << BIT_SHIFT_BEQ_DESC_MODE_8197F)
#define BITS_BEQ_DESC_MODE_8197F \
(BIT_MASK_BEQ_DESC_MODE_8197F << BIT_SHIFT_BEQ_DESC_MODE_8197F)
#define BIT_CLEAR_BEQ_DESC_MODE_8197F(x) ((x) & (~BITS_BEQ_DESC_MODE_8197F))
#define BIT_GET_BEQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_MODE_8197F) & BIT_MASK_BEQ_DESC_MODE_8197F)
#define BIT_SET_BEQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_BEQ_DESC_MODE_8197F(x) | BIT_BEQ_DESC_MODE_8197F(v))
#define BIT_SHIFT_BEQ_DESC_NUM_8197F 0
#define BIT_MASK_BEQ_DESC_NUM_8197F 0xfff
#define BIT_BEQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_BEQ_DESC_NUM_8197F) << BIT_SHIFT_BEQ_DESC_NUM_8197F)
#define BITS_BEQ_DESC_NUM_8197F \
(BIT_MASK_BEQ_DESC_NUM_8197F << BIT_SHIFT_BEQ_DESC_NUM_8197F)
#define BIT_CLEAR_BEQ_DESC_NUM_8197F(x) ((x) & (~BITS_BEQ_DESC_NUM_8197F))
#define BIT_GET_BEQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_NUM_8197F) & BIT_MASK_BEQ_DESC_NUM_8197F)
#define BIT_SET_BEQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_BEQ_DESC_NUM_8197F(x) | BIT_BEQ_DESC_NUM_8197F(v))
/* 2 REG_BKQ_TXBD_NUM_8197F */
#define BIT_HCI_BKQ_FLAG_8197F BIT(14)
#define BIT_SHIFT_BKQ_DESC_MODE_8197F 12
#define BIT_MASK_BKQ_DESC_MODE_8197F 0x3
#define BIT_BKQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_BKQ_DESC_MODE_8197F) << BIT_SHIFT_BKQ_DESC_MODE_8197F)
#define BITS_BKQ_DESC_MODE_8197F \
(BIT_MASK_BKQ_DESC_MODE_8197F << BIT_SHIFT_BKQ_DESC_MODE_8197F)
#define BIT_CLEAR_BKQ_DESC_MODE_8197F(x) ((x) & (~BITS_BKQ_DESC_MODE_8197F))
#define BIT_GET_BKQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_MODE_8197F) & BIT_MASK_BKQ_DESC_MODE_8197F)
#define BIT_SET_BKQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_BKQ_DESC_MODE_8197F(x) | BIT_BKQ_DESC_MODE_8197F(v))
#define BIT_SHIFT_BKQ_DESC_NUM_8197F 0
#define BIT_MASK_BKQ_DESC_NUM_8197F 0xfff
#define BIT_BKQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_BKQ_DESC_NUM_8197F) << BIT_SHIFT_BKQ_DESC_NUM_8197F)
#define BITS_BKQ_DESC_NUM_8197F \
(BIT_MASK_BKQ_DESC_NUM_8197F << BIT_SHIFT_BKQ_DESC_NUM_8197F)
#define BIT_CLEAR_BKQ_DESC_NUM_8197F(x) ((x) & (~BITS_BKQ_DESC_NUM_8197F))
#define BIT_GET_BKQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_NUM_8197F) & BIT_MASK_BKQ_DESC_NUM_8197F)
#define BIT_SET_BKQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_BKQ_DESC_NUM_8197F(x) | BIT_BKQ_DESC_NUM_8197F(v))
/* 2 REG_HI0Q_TXBD_NUM_8197F */
#define BIT_HI0Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI0Q_DESC_MODE_8197F 12
#define BIT_MASK_HI0Q_DESC_MODE_8197F 0x3
#define BIT_HI0Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI0Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI0Q_DESC_MODE_8197F)
#define BITS_HI0Q_DESC_MODE_8197F \
(BIT_MASK_HI0Q_DESC_MODE_8197F << BIT_SHIFT_HI0Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI0Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI0Q_DESC_MODE_8197F))
#define BIT_GET_HI0Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_MODE_8197F) & \
BIT_MASK_HI0Q_DESC_MODE_8197F)
#define BIT_SET_HI0Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI0Q_DESC_MODE_8197F(x) | BIT_HI0Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI0Q_DESC_NUM_8197F 0
#define BIT_MASK_HI0Q_DESC_NUM_8197F 0xfff
#define BIT_HI0Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI0Q_DESC_NUM_8197F) << BIT_SHIFT_HI0Q_DESC_NUM_8197F)
#define BITS_HI0Q_DESC_NUM_8197F \
(BIT_MASK_HI0Q_DESC_NUM_8197F << BIT_SHIFT_HI0Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI0Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI0Q_DESC_NUM_8197F))
#define BIT_GET_HI0Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_NUM_8197F) & BIT_MASK_HI0Q_DESC_NUM_8197F)
#define BIT_SET_HI0Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI0Q_DESC_NUM_8197F(x) | BIT_HI0Q_DESC_NUM_8197F(v))
/* 2 REG_HI1Q_TXBD_NUM_8197F */
#define BIT_HI1Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI1Q_DESC_MODE_8197F 12
#define BIT_MASK_HI1Q_DESC_MODE_8197F 0x3
#define BIT_HI1Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI1Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI1Q_DESC_MODE_8197F)
#define BITS_HI1Q_DESC_MODE_8197F \
(BIT_MASK_HI1Q_DESC_MODE_8197F << BIT_SHIFT_HI1Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI1Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI1Q_DESC_MODE_8197F))
#define BIT_GET_HI1Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_MODE_8197F) & \
BIT_MASK_HI1Q_DESC_MODE_8197F)
#define BIT_SET_HI1Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI1Q_DESC_MODE_8197F(x) | BIT_HI1Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI1Q_DESC_NUM_8197F 0
#define BIT_MASK_HI1Q_DESC_NUM_8197F 0xfff
#define BIT_HI1Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI1Q_DESC_NUM_8197F) << BIT_SHIFT_HI1Q_DESC_NUM_8197F)
#define BITS_HI1Q_DESC_NUM_8197F \
(BIT_MASK_HI1Q_DESC_NUM_8197F << BIT_SHIFT_HI1Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI1Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI1Q_DESC_NUM_8197F))
#define BIT_GET_HI1Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_NUM_8197F) & BIT_MASK_HI1Q_DESC_NUM_8197F)
#define BIT_SET_HI1Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI1Q_DESC_NUM_8197F(x) | BIT_HI1Q_DESC_NUM_8197F(v))
/* 2 REG_HI2Q_TXBD_NUM_8197F */
#define BIT_HI2Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI2Q_DESC_MODE_8197F 12
#define BIT_MASK_HI2Q_DESC_MODE_8197F 0x3
#define BIT_HI2Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI2Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI2Q_DESC_MODE_8197F)
#define BITS_HI2Q_DESC_MODE_8197F \
(BIT_MASK_HI2Q_DESC_MODE_8197F << BIT_SHIFT_HI2Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI2Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI2Q_DESC_MODE_8197F))
#define BIT_GET_HI2Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_MODE_8197F) & \
BIT_MASK_HI2Q_DESC_MODE_8197F)
#define BIT_SET_HI2Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI2Q_DESC_MODE_8197F(x) | BIT_HI2Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI2Q_DESC_NUM_8197F 0
#define BIT_MASK_HI2Q_DESC_NUM_8197F 0xfff
#define BIT_HI2Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI2Q_DESC_NUM_8197F) << BIT_SHIFT_HI2Q_DESC_NUM_8197F)
#define BITS_HI2Q_DESC_NUM_8197F \
(BIT_MASK_HI2Q_DESC_NUM_8197F << BIT_SHIFT_HI2Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI2Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI2Q_DESC_NUM_8197F))
#define BIT_GET_HI2Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_NUM_8197F) & BIT_MASK_HI2Q_DESC_NUM_8197F)
#define BIT_SET_HI2Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI2Q_DESC_NUM_8197F(x) | BIT_HI2Q_DESC_NUM_8197F(v))
/* 2 REG_HI3Q_TXBD_NUM_8197F */
#define BIT_HI3Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI3Q_DESC_MODE_8197F 12
#define BIT_MASK_HI3Q_DESC_MODE_8197F 0x3
#define BIT_HI3Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI3Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI3Q_DESC_MODE_8197F)
#define BITS_HI3Q_DESC_MODE_8197F \
(BIT_MASK_HI3Q_DESC_MODE_8197F << BIT_SHIFT_HI3Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI3Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI3Q_DESC_MODE_8197F))
#define BIT_GET_HI3Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_MODE_8197F) & \
BIT_MASK_HI3Q_DESC_MODE_8197F)
#define BIT_SET_HI3Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI3Q_DESC_MODE_8197F(x) | BIT_HI3Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI3Q_DESC_NUM_8197F 0
#define BIT_MASK_HI3Q_DESC_NUM_8197F 0xfff
#define BIT_HI3Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI3Q_DESC_NUM_8197F) << BIT_SHIFT_HI3Q_DESC_NUM_8197F)
#define BITS_HI3Q_DESC_NUM_8197F \
(BIT_MASK_HI3Q_DESC_NUM_8197F << BIT_SHIFT_HI3Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI3Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI3Q_DESC_NUM_8197F))
#define BIT_GET_HI3Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_NUM_8197F) & BIT_MASK_HI3Q_DESC_NUM_8197F)
#define BIT_SET_HI3Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI3Q_DESC_NUM_8197F(x) | BIT_HI3Q_DESC_NUM_8197F(v))
/* 2 REG_HI4Q_TXBD_NUM_8197F */
#define BIT_HI4Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI4Q_DESC_MODE_8197F 12
#define BIT_MASK_HI4Q_DESC_MODE_8197F 0x3
#define BIT_HI4Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI4Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI4Q_DESC_MODE_8197F)
#define BITS_HI4Q_DESC_MODE_8197F \
(BIT_MASK_HI4Q_DESC_MODE_8197F << BIT_SHIFT_HI4Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI4Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI4Q_DESC_MODE_8197F))
#define BIT_GET_HI4Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_MODE_8197F) & \
BIT_MASK_HI4Q_DESC_MODE_8197F)
#define BIT_SET_HI4Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI4Q_DESC_MODE_8197F(x) | BIT_HI4Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI4Q_DESC_NUM_8197F 0
#define BIT_MASK_HI4Q_DESC_NUM_8197F 0xfff
#define BIT_HI4Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI4Q_DESC_NUM_8197F) << BIT_SHIFT_HI4Q_DESC_NUM_8197F)
#define BITS_HI4Q_DESC_NUM_8197F \
(BIT_MASK_HI4Q_DESC_NUM_8197F << BIT_SHIFT_HI4Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI4Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI4Q_DESC_NUM_8197F))
#define BIT_GET_HI4Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_NUM_8197F) & BIT_MASK_HI4Q_DESC_NUM_8197F)
#define BIT_SET_HI4Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI4Q_DESC_NUM_8197F(x) | BIT_HI4Q_DESC_NUM_8197F(v))
/* 2 REG_HI5Q_TXBD_NUM_8197F */
#define BIT_HI5Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI5Q_DESC_MODE_8197F 12
#define BIT_MASK_HI5Q_DESC_MODE_8197F 0x3
#define BIT_HI5Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI5Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI5Q_DESC_MODE_8197F)
#define BITS_HI5Q_DESC_MODE_8197F \
(BIT_MASK_HI5Q_DESC_MODE_8197F << BIT_SHIFT_HI5Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI5Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI5Q_DESC_MODE_8197F))
#define BIT_GET_HI5Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_MODE_8197F) & \
BIT_MASK_HI5Q_DESC_MODE_8197F)
#define BIT_SET_HI5Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI5Q_DESC_MODE_8197F(x) | BIT_HI5Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI5Q_DESC_NUM_8197F 0
#define BIT_MASK_HI5Q_DESC_NUM_8197F 0xfff
#define BIT_HI5Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI5Q_DESC_NUM_8197F) << BIT_SHIFT_HI5Q_DESC_NUM_8197F)
#define BITS_HI5Q_DESC_NUM_8197F \
(BIT_MASK_HI5Q_DESC_NUM_8197F << BIT_SHIFT_HI5Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI5Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI5Q_DESC_NUM_8197F))
#define BIT_GET_HI5Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_NUM_8197F) & BIT_MASK_HI5Q_DESC_NUM_8197F)
#define BIT_SET_HI5Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI5Q_DESC_NUM_8197F(x) | BIT_HI5Q_DESC_NUM_8197F(v))
/* 2 REG_HI6Q_TXBD_NUM_8197F */
#define BIT_HI6Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI6Q_DESC_MODE_8197F 12
#define BIT_MASK_HI6Q_DESC_MODE_8197F 0x3
#define BIT_HI6Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI6Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI6Q_DESC_MODE_8197F)
#define BITS_HI6Q_DESC_MODE_8197F \
(BIT_MASK_HI6Q_DESC_MODE_8197F << BIT_SHIFT_HI6Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI6Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI6Q_DESC_MODE_8197F))
#define BIT_GET_HI6Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_MODE_8197F) & \
BIT_MASK_HI6Q_DESC_MODE_8197F)
#define BIT_SET_HI6Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI6Q_DESC_MODE_8197F(x) | BIT_HI6Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI6Q_DESC_NUM_8197F 0
#define BIT_MASK_HI6Q_DESC_NUM_8197F 0xfff
#define BIT_HI6Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI6Q_DESC_NUM_8197F) << BIT_SHIFT_HI6Q_DESC_NUM_8197F)
#define BITS_HI6Q_DESC_NUM_8197F \
(BIT_MASK_HI6Q_DESC_NUM_8197F << BIT_SHIFT_HI6Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI6Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI6Q_DESC_NUM_8197F))
#define BIT_GET_HI6Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_NUM_8197F) & BIT_MASK_HI6Q_DESC_NUM_8197F)
#define BIT_SET_HI6Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI6Q_DESC_NUM_8197F(x) | BIT_HI6Q_DESC_NUM_8197F(v))
/* 2 REG_HI7Q_TXBD_NUM_8197F */
#define BIT_HI7Q_FLAG_8197F BIT(14)
#define BIT_SHIFT_HI7Q_DESC_MODE_8197F 12
#define BIT_MASK_HI7Q_DESC_MODE_8197F 0x3
#define BIT_HI7Q_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_HI7Q_DESC_MODE_8197F) \
<< BIT_SHIFT_HI7Q_DESC_MODE_8197F)
#define BITS_HI7Q_DESC_MODE_8197F \
(BIT_MASK_HI7Q_DESC_MODE_8197F << BIT_SHIFT_HI7Q_DESC_MODE_8197F)
#define BIT_CLEAR_HI7Q_DESC_MODE_8197F(x) ((x) & (~BITS_HI7Q_DESC_MODE_8197F))
#define BIT_GET_HI7Q_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_MODE_8197F) & \
BIT_MASK_HI7Q_DESC_MODE_8197F)
#define BIT_SET_HI7Q_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_HI7Q_DESC_MODE_8197F(x) | BIT_HI7Q_DESC_MODE_8197F(v))
#define BIT_SHIFT_HI7Q_DESC_NUM_8197F 0
#define BIT_MASK_HI7Q_DESC_NUM_8197F 0xfff
#define BIT_HI7Q_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_HI7Q_DESC_NUM_8197F) << BIT_SHIFT_HI7Q_DESC_NUM_8197F)
#define BITS_HI7Q_DESC_NUM_8197F \
(BIT_MASK_HI7Q_DESC_NUM_8197F << BIT_SHIFT_HI7Q_DESC_NUM_8197F)
#define BIT_CLEAR_HI7Q_DESC_NUM_8197F(x) ((x) & (~BITS_HI7Q_DESC_NUM_8197F))
#define BIT_GET_HI7Q_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_NUM_8197F) & BIT_MASK_HI7Q_DESC_NUM_8197F)
#define BIT_SET_HI7Q_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_HI7Q_DESC_NUM_8197F(x) | BIT_HI7Q_DESC_NUM_8197F(v))
/* 2 REG_TSFTIMER_HCI_8197F */
#define BIT_SHIFT_TSFT2_HCI_8197F 16
#define BIT_MASK_TSFT2_HCI_8197F 0xffff
#define BIT_TSFT2_HCI_8197F(x) \
(((x) & BIT_MASK_TSFT2_HCI_8197F) << BIT_SHIFT_TSFT2_HCI_8197F)
#define BITS_TSFT2_HCI_8197F \
(BIT_MASK_TSFT2_HCI_8197F << BIT_SHIFT_TSFT2_HCI_8197F)
#define BIT_CLEAR_TSFT2_HCI_8197F(x) ((x) & (~BITS_TSFT2_HCI_8197F))
#define BIT_GET_TSFT2_HCI_8197F(x) \
(((x) >> BIT_SHIFT_TSFT2_HCI_8197F) & BIT_MASK_TSFT2_HCI_8197F)
#define BIT_SET_TSFT2_HCI_8197F(x, v) \
(BIT_CLEAR_TSFT2_HCI_8197F(x) | BIT_TSFT2_HCI_8197F(v))
#define BIT_SHIFT_TSFT1_HCI_8197F 0
#define BIT_MASK_TSFT1_HCI_8197F 0xffff
#define BIT_TSFT1_HCI_8197F(x) \
(((x) & BIT_MASK_TSFT1_HCI_8197F) << BIT_SHIFT_TSFT1_HCI_8197F)
#define BITS_TSFT1_HCI_8197F \
(BIT_MASK_TSFT1_HCI_8197F << BIT_SHIFT_TSFT1_HCI_8197F)
#define BIT_CLEAR_TSFT1_HCI_8197F(x) ((x) & (~BITS_TSFT1_HCI_8197F))
#define BIT_GET_TSFT1_HCI_8197F(x) \
(((x) >> BIT_SHIFT_TSFT1_HCI_8197F) & BIT_MASK_TSFT1_HCI_8197F)
#define BIT_SET_TSFT1_HCI_8197F(x, v) \
(BIT_CLEAR_TSFT1_HCI_8197F(x) | BIT_TSFT1_HCI_8197F(v))
/* 2 REG_BD_RWPTR_CLR_8197F */
#define BIT_CLR_HI7Q_HW_IDX_8197F BIT(29)
#define BIT_CLR_HI6Q_HW_IDX_8197F BIT(28)
#define BIT_CLR_HI5Q_HW_IDX_8197F BIT(27)
#define BIT_CLR_HI4Q_HW_IDX_8197F BIT(26)
#define BIT_CLR_HI3Q_HW_IDX_8197F BIT(25)
#define BIT_CLR_HI2Q_HW_IDX_8197F BIT(24)
#define BIT_CLR_HI1Q_HW_IDX_8197F BIT(23)
#define BIT_CLR_HI0Q_HW_IDX_8197F BIT(22)
#define BIT_CLR_BKQ_HW_IDX_8197F BIT(21)
#define BIT_CLR_BEQ_HW_IDX_8197F BIT(20)
#define BIT_CLR_VIQ_HW_IDX_8197F BIT(19)
#define BIT_CLR_VOQ_HW_IDX_8197F BIT(18)
#define BIT_CLR_MGQ_HW_IDX_8197F BIT(17)
#define BIT_CLR_RXQ_HW_IDX_8197F BIT(16)
#define BIT_CLR_HI7Q_HOST_IDX_8197F BIT(13)
#define BIT_CLR_HI6Q_HOST_IDX_8197F BIT(12)
#define BIT_CLR_HI5Q_HOST_IDX_8197F BIT(11)
#define BIT_CLR_HI4Q_HOST_IDX_8197F BIT(10)
#define BIT_CLR_HI3Q_HOST_IDX_8197F BIT(9)
#define BIT_CLR_HI2Q_HOST_IDX_8197F BIT(8)
#define BIT_CLR_HI1Q_HOST_IDX_8197F BIT(7)
#define BIT_CLR_HI0Q_HOST_IDX_8197F BIT(6)
#define BIT_CLR_BKQ_HOST_IDX_8197F BIT(5)
#define BIT_CLR_BEQ_HOST_IDX_8197F BIT(4)
#define BIT_CLR_VIQ_HOST_IDX_8197F BIT(3)
#define BIT_CLR_VOQ_HOST_IDX_8197F BIT(2)
#define BIT_CLR_MGQ_HOST_IDX_8197F BIT(1)
#define BIT_CLR_RXQ_HOST_IDX_8197F BIT(0)
/* 2 REG_VOQ_TXBD_IDX_8197F */
#define BIT_SHIFT_VOQ_HW_IDX_8197F 16
#define BIT_MASK_VOQ_HW_IDX_8197F 0xfff
#define BIT_VOQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_VOQ_HW_IDX_8197F) << BIT_SHIFT_VOQ_HW_IDX_8197F)
#define BITS_VOQ_HW_IDX_8197F \
(BIT_MASK_VOQ_HW_IDX_8197F << BIT_SHIFT_VOQ_HW_IDX_8197F)
#define BIT_CLEAR_VOQ_HW_IDX_8197F(x) ((x) & (~BITS_VOQ_HW_IDX_8197F))
#define BIT_GET_VOQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_VOQ_HW_IDX_8197F) & BIT_MASK_VOQ_HW_IDX_8197F)
#define BIT_SET_VOQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_VOQ_HW_IDX_8197F(x) | BIT_VOQ_HW_IDX_8197F(v))
#define BIT_SHIFT_VOQ_HOST_IDX_8197F 0
#define BIT_MASK_VOQ_HOST_IDX_8197F 0xfff
#define BIT_VOQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_VOQ_HOST_IDX_8197F) << BIT_SHIFT_VOQ_HOST_IDX_8197F)
#define BITS_VOQ_HOST_IDX_8197F \
(BIT_MASK_VOQ_HOST_IDX_8197F << BIT_SHIFT_VOQ_HOST_IDX_8197F)
#define BIT_CLEAR_VOQ_HOST_IDX_8197F(x) ((x) & (~BITS_VOQ_HOST_IDX_8197F))
#define BIT_GET_VOQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_VOQ_HOST_IDX_8197F) & BIT_MASK_VOQ_HOST_IDX_8197F)
#define BIT_SET_VOQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_VOQ_HOST_IDX_8197F(x) | BIT_VOQ_HOST_IDX_8197F(v))
/* 2 REG_VIQ_TXBD_IDX_8197F */
#define BIT_SHIFT_VIQ_HW_IDX_8197F 16
#define BIT_MASK_VIQ_HW_IDX_8197F 0xfff
#define BIT_VIQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_VIQ_HW_IDX_8197F) << BIT_SHIFT_VIQ_HW_IDX_8197F)
#define BITS_VIQ_HW_IDX_8197F \
(BIT_MASK_VIQ_HW_IDX_8197F << BIT_SHIFT_VIQ_HW_IDX_8197F)
#define BIT_CLEAR_VIQ_HW_IDX_8197F(x) ((x) & (~BITS_VIQ_HW_IDX_8197F))
#define BIT_GET_VIQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_VIQ_HW_IDX_8197F) & BIT_MASK_VIQ_HW_IDX_8197F)
#define BIT_SET_VIQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_VIQ_HW_IDX_8197F(x) | BIT_VIQ_HW_IDX_8197F(v))
#define BIT_SHIFT_VIQ_HOST_IDX_8197F 0
#define BIT_MASK_VIQ_HOST_IDX_8197F 0xfff
#define BIT_VIQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_VIQ_HOST_IDX_8197F) << BIT_SHIFT_VIQ_HOST_IDX_8197F)
#define BITS_VIQ_HOST_IDX_8197F \
(BIT_MASK_VIQ_HOST_IDX_8197F << BIT_SHIFT_VIQ_HOST_IDX_8197F)
#define BIT_CLEAR_VIQ_HOST_IDX_8197F(x) ((x) & (~BITS_VIQ_HOST_IDX_8197F))
#define BIT_GET_VIQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_VIQ_HOST_IDX_8197F) & BIT_MASK_VIQ_HOST_IDX_8197F)
#define BIT_SET_VIQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_VIQ_HOST_IDX_8197F(x) | BIT_VIQ_HOST_IDX_8197F(v))
/* 2 REG_BEQ_TXBD_IDX_8197F */
#define BIT_SHIFT_BEQ_HW_IDX_8197F 16
#define BIT_MASK_BEQ_HW_IDX_8197F 0xfff
#define BIT_BEQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_BEQ_HW_IDX_8197F) << BIT_SHIFT_BEQ_HW_IDX_8197F)
#define BITS_BEQ_HW_IDX_8197F \
(BIT_MASK_BEQ_HW_IDX_8197F << BIT_SHIFT_BEQ_HW_IDX_8197F)
#define BIT_CLEAR_BEQ_HW_IDX_8197F(x) ((x) & (~BITS_BEQ_HW_IDX_8197F))
#define BIT_GET_BEQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_BEQ_HW_IDX_8197F) & BIT_MASK_BEQ_HW_IDX_8197F)
#define BIT_SET_BEQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_BEQ_HW_IDX_8197F(x) | BIT_BEQ_HW_IDX_8197F(v))
#define BIT_SHIFT_BEQ_HOST_IDX_8197F 0
#define BIT_MASK_BEQ_HOST_IDX_8197F 0xfff
#define BIT_BEQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_BEQ_HOST_IDX_8197F) << BIT_SHIFT_BEQ_HOST_IDX_8197F)
#define BITS_BEQ_HOST_IDX_8197F \
(BIT_MASK_BEQ_HOST_IDX_8197F << BIT_SHIFT_BEQ_HOST_IDX_8197F)
#define BIT_CLEAR_BEQ_HOST_IDX_8197F(x) ((x) & (~BITS_BEQ_HOST_IDX_8197F))
#define BIT_GET_BEQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_BEQ_HOST_IDX_8197F) & BIT_MASK_BEQ_HOST_IDX_8197F)
#define BIT_SET_BEQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_BEQ_HOST_IDX_8197F(x) | BIT_BEQ_HOST_IDX_8197F(v))
/* 2 REG_BKQ_TXBD_IDX_8197F */
#define BIT_SHIFT_BKQ_HW_IDX_8197F 16
#define BIT_MASK_BKQ_HW_IDX_8197F 0xfff
#define BIT_BKQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_BKQ_HW_IDX_8197F) << BIT_SHIFT_BKQ_HW_IDX_8197F)
#define BITS_BKQ_HW_IDX_8197F \
(BIT_MASK_BKQ_HW_IDX_8197F << BIT_SHIFT_BKQ_HW_IDX_8197F)
#define BIT_CLEAR_BKQ_HW_IDX_8197F(x) ((x) & (~BITS_BKQ_HW_IDX_8197F))
#define BIT_GET_BKQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_BKQ_HW_IDX_8197F) & BIT_MASK_BKQ_HW_IDX_8197F)
#define BIT_SET_BKQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_BKQ_HW_IDX_8197F(x) | BIT_BKQ_HW_IDX_8197F(v))
#define BIT_SHIFT_BKQ_HOST_IDX_8197F 0
#define BIT_MASK_BKQ_HOST_IDX_8197F 0xfff
#define BIT_BKQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_BKQ_HOST_IDX_8197F) << BIT_SHIFT_BKQ_HOST_IDX_8197F)
#define BITS_BKQ_HOST_IDX_8197F \
(BIT_MASK_BKQ_HOST_IDX_8197F << BIT_SHIFT_BKQ_HOST_IDX_8197F)
#define BIT_CLEAR_BKQ_HOST_IDX_8197F(x) ((x) & (~BITS_BKQ_HOST_IDX_8197F))
#define BIT_GET_BKQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_BKQ_HOST_IDX_8197F) & BIT_MASK_BKQ_HOST_IDX_8197F)
#define BIT_SET_BKQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_BKQ_HOST_IDX_8197F(x) | BIT_BKQ_HOST_IDX_8197F(v))
/* 2 REG_MGQ_TXBD_IDX_8197F */
#define BIT_SHIFT_MGQ_HW_IDX_8197F 16
#define BIT_MASK_MGQ_HW_IDX_8197F 0xfff
#define BIT_MGQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_MGQ_HW_IDX_8197F) << BIT_SHIFT_MGQ_HW_IDX_8197F)
#define BITS_MGQ_HW_IDX_8197F \
(BIT_MASK_MGQ_HW_IDX_8197F << BIT_SHIFT_MGQ_HW_IDX_8197F)
#define BIT_CLEAR_MGQ_HW_IDX_8197F(x) ((x) & (~BITS_MGQ_HW_IDX_8197F))
#define BIT_GET_MGQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_HW_IDX_8197F) & BIT_MASK_MGQ_HW_IDX_8197F)
#define BIT_SET_MGQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_MGQ_HW_IDX_8197F(x) | BIT_MGQ_HW_IDX_8197F(v))
#define BIT_SHIFT_MGQ_HOST_IDX_8197F 0
#define BIT_MASK_MGQ_HOST_IDX_8197F 0xfff
#define BIT_MGQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_MGQ_HOST_IDX_8197F) << BIT_SHIFT_MGQ_HOST_IDX_8197F)
#define BITS_MGQ_HOST_IDX_8197F \
(BIT_MASK_MGQ_HOST_IDX_8197F << BIT_SHIFT_MGQ_HOST_IDX_8197F)
#define BIT_CLEAR_MGQ_HOST_IDX_8197F(x) ((x) & (~BITS_MGQ_HOST_IDX_8197F))
#define BIT_GET_MGQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_HOST_IDX_8197F) & BIT_MASK_MGQ_HOST_IDX_8197F)
#define BIT_SET_MGQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_MGQ_HOST_IDX_8197F(x) | BIT_MGQ_HOST_IDX_8197F(v))
/* 2 REG_RXQ_RXBD_IDX_8197F */
#define BIT_SHIFT_RXQ_HW_IDX_8197F 16
#define BIT_MASK_RXQ_HW_IDX_8197F 0xfff
#define BIT_RXQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_RXQ_HW_IDX_8197F) << BIT_SHIFT_RXQ_HW_IDX_8197F)
#define BITS_RXQ_HW_IDX_8197F \
(BIT_MASK_RXQ_HW_IDX_8197F << BIT_SHIFT_RXQ_HW_IDX_8197F)
#define BIT_CLEAR_RXQ_HW_IDX_8197F(x) ((x) & (~BITS_RXQ_HW_IDX_8197F))
#define BIT_GET_RXQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RXQ_HW_IDX_8197F) & BIT_MASK_RXQ_HW_IDX_8197F)
#define BIT_SET_RXQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_RXQ_HW_IDX_8197F(x) | BIT_RXQ_HW_IDX_8197F(v))
#define BIT_SHIFT_RXQ_HOST_IDX_8197F 0
#define BIT_MASK_RXQ_HOST_IDX_8197F 0xfff
#define BIT_RXQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_RXQ_HOST_IDX_8197F) << BIT_SHIFT_RXQ_HOST_IDX_8197F)
#define BITS_RXQ_HOST_IDX_8197F \
(BIT_MASK_RXQ_HOST_IDX_8197F << BIT_SHIFT_RXQ_HOST_IDX_8197F)
#define BIT_CLEAR_RXQ_HOST_IDX_8197F(x) ((x) & (~BITS_RXQ_HOST_IDX_8197F))
#define BIT_GET_RXQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RXQ_HOST_IDX_8197F) & BIT_MASK_RXQ_HOST_IDX_8197F)
#define BIT_SET_RXQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_RXQ_HOST_IDX_8197F(x) | BIT_RXQ_HOST_IDX_8197F(v))
/* 2 REG_HI0Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI0Q_HW_IDX_8197F 16
#define BIT_MASK_HI0Q_HW_IDX_8197F 0xfff
#define BIT_HI0Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI0Q_HW_IDX_8197F) << BIT_SHIFT_HI0Q_HW_IDX_8197F)
#define BITS_HI0Q_HW_IDX_8197F \
(BIT_MASK_HI0Q_HW_IDX_8197F << BIT_SHIFT_HI0Q_HW_IDX_8197F)
#define BIT_CLEAR_HI0Q_HW_IDX_8197F(x) ((x) & (~BITS_HI0Q_HW_IDX_8197F))
#define BIT_GET_HI0Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI0Q_HW_IDX_8197F) & BIT_MASK_HI0Q_HW_IDX_8197F)
#define BIT_SET_HI0Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI0Q_HW_IDX_8197F(x) | BIT_HI0Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI0Q_HOST_IDX_8197F 0
#define BIT_MASK_HI0Q_HOST_IDX_8197F 0xfff
#define BIT_HI0Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI0Q_HOST_IDX_8197F) << BIT_SHIFT_HI0Q_HOST_IDX_8197F)
#define BITS_HI0Q_HOST_IDX_8197F \
(BIT_MASK_HI0Q_HOST_IDX_8197F << BIT_SHIFT_HI0Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI0Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI0Q_HOST_IDX_8197F))
#define BIT_GET_HI0Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI0Q_HOST_IDX_8197F) & BIT_MASK_HI0Q_HOST_IDX_8197F)
#define BIT_SET_HI0Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI0Q_HOST_IDX_8197F(x) | BIT_HI0Q_HOST_IDX_8197F(v))
/* 2 REG_HI1Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI1Q_HW_IDX_8197F 16
#define BIT_MASK_HI1Q_HW_IDX_8197F 0xfff
#define BIT_HI1Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI1Q_HW_IDX_8197F) << BIT_SHIFT_HI1Q_HW_IDX_8197F)
#define BITS_HI1Q_HW_IDX_8197F \
(BIT_MASK_HI1Q_HW_IDX_8197F << BIT_SHIFT_HI1Q_HW_IDX_8197F)
#define BIT_CLEAR_HI1Q_HW_IDX_8197F(x) ((x) & (~BITS_HI1Q_HW_IDX_8197F))
#define BIT_GET_HI1Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI1Q_HW_IDX_8197F) & BIT_MASK_HI1Q_HW_IDX_8197F)
#define BIT_SET_HI1Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI1Q_HW_IDX_8197F(x) | BIT_HI1Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI1Q_HOST_IDX_8197F 0
#define BIT_MASK_HI1Q_HOST_IDX_8197F 0xfff
#define BIT_HI1Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI1Q_HOST_IDX_8197F) << BIT_SHIFT_HI1Q_HOST_IDX_8197F)
#define BITS_HI1Q_HOST_IDX_8197F \
(BIT_MASK_HI1Q_HOST_IDX_8197F << BIT_SHIFT_HI1Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI1Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI1Q_HOST_IDX_8197F))
#define BIT_GET_HI1Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI1Q_HOST_IDX_8197F) & BIT_MASK_HI1Q_HOST_IDX_8197F)
#define BIT_SET_HI1Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI1Q_HOST_IDX_8197F(x) | BIT_HI1Q_HOST_IDX_8197F(v))
/* 2 REG_HI2Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI2Q_HW_IDX_8197F 16
#define BIT_MASK_HI2Q_HW_IDX_8197F 0xfff
#define BIT_HI2Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI2Q_HW_IDX_8197F) << BIT_SHIFT_HI2Q_HW_IDX_8197F)
#define BITS_HI2Q_HW_IDX_8197F \
(BIT_MASK_HI2Q_HW_IDX_8197F << BIT_SHIFT_HI2Q_HW_IDX_8197F)
#define BIT_CLEAR_HI2Q_HW_IDX_8197F(x) ((x) & (~BITS_HI2Q_HW_IDX_8197F))
#define BIT_GET_HI2Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI2Q_HW_IDX_8197F) & BIT_MASK_HI2Q_HW_IDX_8197F)
#define BIT_SET_HI2Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI2Q_HW_IDX_8197F(x) | BIT_HI2Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI2Q_HOST_IDX_8197F 0
#define BIT_MASK_HI2Q_HOST_IDX_8197F 0xfff
#define BIT_HI2Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI2Q_HOST_IDX_8197F) << BIT_SHIFT_HI2Q_HOST_IDX_8197F)
#define BITS_HI2Q_HOST_IDX_8197F \
(BIT_MASK_HI2Q_HOST_IDX_8197F << BIT_SHIFT_HI2Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI2Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI2Q_HOST_IDX_8197F))
#define BIT_GET_HI2Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI2Q_HOST_IDX_8197F) & BIT_MASK_HI2Q_HOST_IDX_8197F)
#define BIT_SET_HI2Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI2Q_HOST_IDX_8197F(x) | BIT_HI2Q_HOST_IDX_8197F(v))
/* 2 REG_HI3Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI3Q_HW_IDX_8197F 16
#define BIT_MASK_HI3Q_HW_IDX_8197F 0xfff
#define BIT_HI3Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI3Q_HW_IDX_8197F) << BIT_SHIFT_HI3Q_HW_IDX_8197F)
#define BITS_HI3Q_HW_IDX_8197F \
(BIT_MASK_HI3Q_HW_IDX_8197F << BIT_SHIFT_HI3Q_HW_IDX_8197F)
#define BIT_CLEAR_HI3Q_HW_IDX_8197F(x) ((x) & (~BITS_HI3Q_HW_IDX_8197F))
#define BIT_GET_HI3Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI3Q_HW_IDX_8197F) & BIT_MASK_HI3Q_HW_IDX_8197F)
#define BIT_SET_HI3Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI3Q_HW_IDX_8197F(x) | BIT_HI3Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI3Q_HOST_IDX_8197F 0
#define BIT_MASK_HI3Q_HOST_IDX_8197F 0xfff
#define BIT_HI3Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI3Q_HOST_IDX_8197F) << BIT_SHIFT_HI3Q_HOST_IDX_8197F)
#define BITS_HI3Q_HOST_IDX_8197F \
(BIT_MASK_HI3Q_HOST_IDX_8197F << BIT_SHIFT_HI3Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI3Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI3Q_HOST_IDX_8197F))
#define BIT_GET_HI3Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI3Q_HOST_IDX_8197F) & BIT_MASK_HI3Q_HOST_IDX_8197F)
#define BIT_SET_HI3Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI3Q_HOST_IDX_8197F(x) | BIT_HI3Q_HOST_IDX_8197F(v))
/* 2 REG_HI4Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI4Q_HW_IDX_8197F 16
#define BIT_MASK_HI4Q_HW_IDX_8197F 0xfff
#define BIT_HI4Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI4Q_HW_IDX_8197F) << BIT_SHIFT_HI4Q_HW_IDX_8197F)
#define BITS_HI4Q_HW_IDX_8197F \
(BIT_MASK_HI4Q_HW_IDX_8197F << BIT_SHIFT_HI4Q_HW_IDX_8197F)
#define BIT_CLEAR_HI4Q_HW_IDX_8197F(x) ((x) & (~BITS_HI4Q_HW_IDX_8197F))
#define BIT_GET_HI4Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI4Q_HW_IDX_8197F) & BIT_MASK_HI4Q_HW_IDX_8197F)
#define BIT_SET_HI4Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI4Q_HW_IDX_8197F(x) | BIT_HI4Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI4Q_HOST_IDX_8197F 0
#define BIT_MASK_HI4Q_HOST_IDX_8197F 0xfff
#define BIT_HI4Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI4Q_HOST_IDX_8197F) << BIT_SHIFT_HI4Q_HOST_IDX_8197F)
#define BITS_HI4Q_HOST_IDX_8197F \
(BIT_MASK_HI4Q_HOST_IDX_8197F << BIT_SHIFT_HI4Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI4Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI4Q_HOST_IDX_8197F))
#define BIT_GET_HI4Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI4Q_HOST_IDX_8197F) & BIT_MASK_HI4Q_HOST_IDX_8197F)
#define BIT_SET_HI4Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI4Q_HOST_IDX_8197F(x) | BIT_HI4Q_HOST_IDX_8197F(v))
/* 2 REG_HI5Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI5Q_HW_IDX_8197F 16
#define BIT_MASK_HI5Q_HW_IDX_8197F 0xfff
#define BIT_HI5Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI5Q_HW_IDX_8197F) << BIT_SHIFT_HI5Q_HW_IDX_8197F)
#define BITS_HI5Q_HW_IDX_8197F \
(BIT_MASK_HI5Q_HW_IDX_8197F << BIT_SHIFT_HI5Q_HW_IDX_8197F)
#define BIT_CLEAR_HI5Q_HW_IDX_8197F(x) ((x) & (~BITS_HI5Q_HW_IDX_8197F))
#define BIT_GET_HI5Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI5Q_HW_IDX_8197F) & BIT_MASK_HI5Q_HW_IDX_8197F)
#define BIT_SET_HI5Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI5Q_HW_IDX_8197F(x) | BIT_HI5Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI5Q_HOST_IDX_8197F 0
#define BIT_MASK_HI5Q_HOST_IDX_8197F 0xfff
#define BIT_HI5Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI5Q_HOST_IDX_8197F) << BIT_SHIFT_HI5Q_HOST_IDX_8197F)
#define BITS_HI5Q_HOST_IDX_8197F \
(BIT_MASK_HI5Q_HOST_IDX_8197F << BIT_SHIFT_HI5Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI5Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI5Q_HOST_IDX_8197F))
#define BIT_GET_HI5Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI5Q_HOST_IDX_8197F) & BIT_MASK_HI5Q_HOST_IDX_8197F)
#define BIT_SET_HI5Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI5Q_HOST_IDX_8197F(x) | BIT_HI5Q_HOST_IDX_8197F(v))
/* 2 REG_HI6Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI6Q_HW_IDX_8197F 16
#define BIT_MASK_HI6Q_HW_IDX_8197F 0xfff
#define BIT_HI6Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI6Q_HW_IDX_8197F) << BIT_SHIFT_HI6Q_HW_IDX_8197F)
#define BITS_HI6Q_HW_IDX_8197F \
(BIT_MASK_HI6Q_HW_IDX_8197F << BIT_SHIFT_HI6Q_HW_IDX_8197F)
#define BIT_CLEAR_HI6Q_HW_IDX_8197F(x) ((x) & (~BITS_HI6Q_HW_IDX_8197F))
#define BIT_GET_HI6Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI6Q_HW_IDX_8197F) & BIT_MASK_HI6Q_HW_IDX_8197F)
#define BIT_SET_HI6Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI6Q_HW_IDX_8197F(x) | BIT_HI6Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI6Q_HOST_IDX_8197F 0
#define BIT_MASK_HI6Q_HOST_IDX_8197F 0xfff
#define BIT_HI6Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI6Q_HOST_IDX_8197F) << BIT_SHIFT_HI6Q_HOST_IDX_8197F)
#define BITS_HI6Q_HOST_IDX_8197F \
(BIT_MASK_HI6Q_HOST_IDX_8197F << BIT_SHIFT_HI6Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI6Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI6Q_HOST_IDX_8197F))
#define BIT_GET_HI6Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI6Q_HOST_IDX_8197F) & BIT_MASK_HI6Q_HOST_IDX_8197F)
#define BIT_SET_HI6Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI6Q_HOST_IDX_8197F(x) | BIT_HI6Q_HOST_IDX_8197F(v))
/* 2 REG_HI7Q_TXBD_IDX_8197F */
#define BIT_SHIFT_HI7Q_HW_IDX_8197F 16
#define BIT_MASK_HI7Q_HW_IDX_8197F 0xfff
#define BIT_HI7Q_HW_IDX_8197F(x) \
(((x) & BIT_MASK_HI7Q_HW_IDX_8197F) << BIT_SHIFT_HI7Q_HW_IDX_8197F)
#define BITS_HI7Q_HW_IDX_8197F \
(BIT_MASK_HI7Q_HW_IDX_8197F << BIT_SHIFT_HI7Q_HW_IDX_8197F)
#define BIT_CLEAR_HI7Q_HW_IDX_8197F(x) ((x) & (~BITS_HI7Q_HW_IDX_8197F))
#define BIT_GET_HI7Q_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI7Q_HW_IDX_8197F) & BIT_MASK_HI7Q_HW_IDX_8197F)
#define BIT_SET_HI7Q_HW_IDX_8197F(x, v) \
(BIT_CLEAR_HI7Q_HW_IDX_8197F(x) | BIT_HI7Q_HW_IDX_8197F(v))
#define BIT_SHIFT_HI7Q_HOST_IDX_8197F 0
#define BIT_MASK_HI7Q_HOST_IDX_8197F 0xfff
#define BIT_HI7Q_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_HI7Q_HOST_IDX_8197F) << BIT_SHIFT_HI7Q_HOST_IDX_8197F)
#define BITS_HI7Q_HOST_IDX_8197F \
(BIT_MASK_HI7Q_HOST_IDX_8197F << BIT_SHIFT_HI7Q_HOST_IDX_8197F)
#define BIT_CLEAR_HI7Q_HOST_IDX_8197F(x) ((x) & (~BITS_HI7Q_HOST_IDX_8197F))
#define BIT_GET_HI7Q_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HI7Q_HOST_IDX_8197F) & BIT_MASK_HI7Q_HOST_IDX_8197F)
#define BIT_SET_HI7Q_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_HI7Q_HOST_IDX_8197F(x) | BIT_HI7Q_HOST_IDX_8197F(v))
/* 2 REG_DBG_SEL_V1_8197F */
#define BIT_SHIFT_DBG_SEL_8197F 0
#define BIT_MASK_DBG_SEL_8197F 0xff
#define BIT_DBG_SEL_8197F(x) \
(((x) & BIT_MASK_DBG_SEL_8197F) << BIT_SHIFT_DBG_SEL_8197F)
#define BITS_DBG_SEL_8197F (BIT_MASK_DBG_SEL_8197F << BIT_SHIFT_DBG_SEL_8197F)
#define BIT_CLEAR_DBG_SEL_8197F(x) ((x) & (~BITS_DBG_SEL_8197F))
#define BIT_GET_DBG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_DBG_SEL_8197F) & BIT_MASK_DBG_SEL_8197F)
#define BIT_SET_DBG_SEL_8197F(x, v) \
(BIT_CLEAR_DBG_SEL_8197F(x) | BIT_DBG_SEL_8197F(v))
/* 2 REG_HCI_HRPWM1_V1_8197F */
#define BIT_SHIFT_HCI_HRPWM_8197F 0
#define BIT_MASK_HCI_HRPWM_8197F 0xff
#define BIT_HCI_HRPWM_8197F(x) \
(((x) & BIT_MASK_HCI_HRPWM_8197F) << BIT_SHIFT_HCI_HRPWM_8197F)
#define BITS_HCI_HRPWM_8197F \
(BIT_MASK_HCI_HRPWM_8197F << BIT_SHIFT_HCI_HRPWM_8197F)
#define BIT_CLEAR_HCI_HRPWM_8197F(x) ((x) & (~BITS_HCI_HRPWM_8197F))
#define BIT_GET_HCI_HRPWM_8197F(x) \
(((x) >> BIT_SHIFT_HCI_HRPWM_8197F) & BIT_MASK_HCI_HRPWM_8197F)
#define BIT_SET_HCI_HRPWM_8197F(x, v) \
(BIT_CLEAR_HCI_HRPWM_8197F(x) | BIT_HCI_HRPWM_8197F(v))
/* 2 REG_HCI_HCPWM1_V1_8197F */
#define BIT_SHIFT_HCI_HCPWM_8197F 0
#define BIT_MASK_HCI_HCPWM_8197F 0xff
#define BIT_HCI_HCPWM_8197F(x) \
(((x) & BIT_MASK_HCI_HCPWM_8197F) << BIT_SHIFT_HCI_HCPWM_8197F)
#define BITS_HCI_HCPWM_8197F \
(BIT_MASK_HCI_HCPWM_8197F << BIT_SHIFT_HCI_HCPWM_8197F)
#define BIT_CLEAR_HCI_HCPWM_8197F(x) ((x) & (~BITS_HCI_HCPWM_8197F))
#define BIT_GET_HCI_HCPWM_8197F(x) \
(((x) >> BIT_SHIFT_HCI_HCPWM_8197F) & BIT_MASK_HCI_HCPWM_8197F)
#define BIT_SET_HCI_HCPWM_8197F(x, v) \
(BIT_CLEAR_HCI_HCPWM_8197F(x) | BIT_HCI_HCPWM_8197F(v))
/* 2 REG_HCI_CTRL2_8197F */
#define BIT_DIS_TXDMA_PRE_8197F BIT(7)
#define BIT_DIS_RXDMA_PRE_8197F BIT(6)
#define BIT_SHIFT_HPS_CLKR_HCI_8197F 4
#define BIT_MASK_HPS_CLKR_HCI_8197F 0x3
#define BIT_HPS_CLKR_HCI_8197F(x) \
(((x) & BIT_MASK_HPS_CLKR_HCI_8197F) << BIT_SHIFT_HPS_CLKR_HCI_8197F)
#define BITS_HPS_CLKR_HCI_8197F \
(BIT_MASK_HPS_CLKR_HCI_8197F << BIT_SHIFT_HPS_CLKR_HCI_8197F)
#define BIT_CLEAR_HPS_CLKR_HCI_8197F(x) ((x) & (~BITS_HPS_CLKR_HCI_8197F))
#define BIT_GET_HPS_CLKR_HCI_8197F(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_HCI_8197F) & BIT_MASK_HPS_CLKR_HCI_8197F)
#define BIT_SET_HPS_CLKR_HCI_8197F(x, v) \
(BIT_CLEAR_HPS_CLKR_HCI_8197F(x) | BIT_HPS_CLKR_HCI_8197F(v))
#define BIT_HCI_INT_8197F BIT(3)
#define BIT_TXFLAG_EXIT_L1_EN_8197F BIT(2)
#define BIT_EN_RXDMA_ALIGN_V1_8197F BIT(1)
#define BIT_EN_TXDMA_ALIGN_V1_8197F BIT(0)
/* 2 REG_HCI_HRPWM2_V1_8197F */
#define BIT_SHIFT_HCI_HRPWM2_8197F 0
#define BIT_MASK_HCI_HRPWM2_8197F 0xffff
#define BIT_HCI_HRPWM2_8197F(x) \
(((x) & BIT_MASK_HCI_HRPWM2_8197F) << BIT_SHIFT_HCI_HRPWM2_8197F)
#define BITS_HCI_HRPWM2_8197F \
(BIT_MASK_HCI_HRPWM2_8197F << BIT_SHIFT_HCI_HRPWM2_8197F)
#define BIT_CLEAR_HCI_HRPWM2_8197F(x) ((x) & (~BITS_HCI_HRPWM2_8197F))
#define BIT_GET_HCI_HRPWM2_8197F(x) \
(((x) >> BIT_SHIFT_HCI_HRPWM2_8197F) & BIT_MASK_HCI_HRPWM2_8197F)
#define BIT_SET_HCI_HRPWM2_8197F(x, v) \
(BIT_CLEAR_HCI_HRPWM2_8197F(x) | BIT_HCI_HRPWM2_8197F(v))
/* 2 REG_HCI_HCPWM2_V1_8197F */
#define BIT_SHIFT_HCI_HCPWM2_8197F 0
#define BIT_MASK_HCI_HCPWM2_8197F 0xffff
#define BIT_HCI_HCPWM2_8197F(x) \
(((x) & BIT_MASK_HCI_HCPWM2_8197F) << BIT_SHIFT_HCI_HCPWM2_8197F)
#define BITS_HCI_HCPWM2_8197F \
(BIT_MASK_HCI_HCPWM2_8197F << BIT_SHIFT_HCI_HCPWM2_8197F)
#define BIT_CLEAR_HCI_HCPWM2_8197F(x) ((x) & (~BITS_HCI_HCPWM2_8197F))
#define BIT_GET_HCI_HCPWM2_8197F(x) \
(((x) >> BIT_SHIFT_HCI_HCPWM2_8197F) & BIT_MASK_HCI_HCPWM2_8197F)
#define BIT_SET_HCI_HCPWM2_8197F(x, v) \
(BIT_CLEAR_HCI_HCPWM2_8197F(x) | BIT_HCI_HCPWM2_8197F(v))
/* 2 REG_HCI_H2C_MSG_V1_8197F */
#define BIT_SHIFT_DRV2FW_INFO_8197F 0
#define BIT_MASK_DRV2FW_INFO_8197F 0xffffffffL
#define BIT_DRV2FW_INFO_8197F(x) \
(((x) & BIT_MASK_DRV2FW_INFO_8197F) << BIT_SHIFT_DRV2FW_INFO_8197F)
#define BITS_DRV2FW_INFO_8197F \
(BIT_MASK_DRV2FW_INFO_8197F << BIT_SHIFT_DRV2FW_INFO_8197F)
#define BIT_CLEAR_DRV2FW_INFO_8197F(x) ((x) & (~BITS_DRV2FW_INFO_8197F))
#define BIT_GET_DRV2FW_INFO_8197F(x) \
(((x) >> BIT_SHIFT_DRV2FW_INFO_8197F) & BIT_MASK_DRV2FW_INFO_8197F)
#define BIT_SET_DRV2FW_INFO_8197F(x, v) \
(BIT_CLEAR_DRV2FW_INFO_8197F(x) | BIT_DRV2FW_INFO_8197F(v))
/* 2 REG_HCI_C2H_MSG_V1_8197F */
#define BIT_SHIFT_HCI_C2H_MSG_8197F 0
#define BIT_MASK_HCI_C2H_MSG_8197F 0xffffffffL
#define BIT_HCI_C2H_MSG_8197F(x) \
(((x) & BIT_MASK_HCI_C2H_MSG_8197F) << BIT_SHIFT_HCI_C2H_MSG_8197F)
#define BITS_HCI_C2H_MSG_8197F \
(BIT_MASK_HCI_C2H_MSG_8197F << BIT_SHIFT_HCI_C2H_MSG_8197F)
#define BIT_CLEAR_HCI_C2H_MSG_8197F(x) ((x) & (~BITS_HCI_C2H_MSG_8197F))
#define BIT_GET_HCI_C2H_MSG_8197F(x) \
(((x) >> BIT_SHIFT_HCI_C2H_MSG_8197F) & BIT_MASK_HCI_C2H_MSG_8197F)
#define BIT_SET_HCI_C2H_MSG_8197F(x, v) \
(BIT_CLEAR_HCI_C2H_MSG_8197F(x) | BIT_HCI_C2H_MSG_8197F(v))
/* 2 REG_DBI_WDATA_V1_8197F */
#define BIT_SHIFT_DBI_WDATA_8197F 0
#define BIT_MASK_DBI_WDATA_8197F 0xffffffffL
#define BIT_DBI_WDATA_8197F(x) \
(((x) & BIT_MASK_DBI_WDATA_8197F) << BIT_SHIFT_DBI_WDATA_8197F)
#define BITS_DBI_WDATA_8197F \
(BIT_MASK_DBI_WDATA_8197F << BIT_SHIFT_DBI_WDATA_8197F)
#define BIT_CLEAR_DBI_WDATA_8197F(x) ((x) & (~BITS_DBI_WDATA_8197F))
#define BIT_GET_DBI_WDATA_8197F(x) \
(((x) >> BIT_SHIFT_DBI_WDATA_8197F) & BIT_MASK_DBI_WDATA_8197F)
#define BIT_SET_DBI_WDATA_8197F(x, v) \
(BIT_CLEAR_DBI_WDATA_8197F(x) | BIT_DBI_WDATA_8197F(v))
/* 2 REG_DBI_RDATA_V1_8197F */
#define BIT_SHIFT_DBI_RDATA_8197F 0
#define BIT_MASK_DBI_RDATA_8197F 0xffffffffL
#define BIT_DBI_RDATA_8197F(x) \
(((x) & BIT_MASK_DBI_RDATA_8197F) << BIT_SHIFT_DBI_RDATA_8197F)
#define BITS_DBI_RDATA_8197F \
(BIT_MASK_DBI_RDATA_8197F << BIT_SHIFT_DBI_RDATA_8197F)
#define BIT_CLEAR_DBI_RDATA_8197F(x) ((x) & (~BITS_DBI_RDATA_8197F))
#define BIT_GET_DBI_RDATA_8197F(x) \
(((x) >> BIT_SHIFT_DBI_RDATA_8197F) & BIT_MASK_DBI_RDATA_8197F)
#define BIT_SET_DBI_RDATA_8197F(x, v) \
(BIT_CLEAR_DBI_RDATA_8197F(x) | BIT_DBI_RDATA_8197F(v))
/* 2 REG_STUCK_FLAG_V1_8197F */
#define BIT_EN_STUCK_DBG_8197F BIT(26)
#define BIT_RX_STUCK_8197F BIT(25)
#define BIT_TX_STUCK_8197F BIT(24)
#define BIT_DBI_RFLAG_8197F BIT(17)
#define BIT_DBI_WFLAG_8197F BIT(16)
#define BIT_SHIFT_DBI_WREN_8197F 12
#define BIT_MASK_DBI_WREN_8197F 0xf
#define BIT_DBI_WREN_8197F(x) \
(((x) & BIT_MASK_DBI_WREN_8197F) << BIT_SHIFT_DBI_WREN_8197F)
#define BITS_DBI_WREN_8197F \
(BIT_MASK_DBI_WREN_8197F << BIT_SHIFT_DBI_WREN_8197F)
#define BIT_CLEAR_DBI_WREN_8197F(x) ((x) & (~BITS_DBI_WREN_8197F))
#define BIT_GET_DBI_WREN_8197F(x) \
(((x) >> BIT_SHIFT_DBI_WREN_8197F) & BIT_MASK_DBI_WREN_8197F)
#define BIT_SET_DBI_WREN_8197F(x, v) \
(BIT_CLEAR_DBI_WREN_8197F(x) | BIT_DBI_WREN_8197F(v))
#define BIT_SHIFT_DBI_ADDR_8197F 0
#define BIT_MASK_DBI_ADDR_8197F 0xfff
#define BIT_DBI_ADDR_8197F(x) \
(((x) & BIT_MASK_DBI_ADDR_8197F) << BIT_SHIFT_DBI_ADDR_8197F)
#define BITS_DBI_ADDR_8197F \
(BIT_MASK_DBI_ADDR_8197F << BIT_SHIFT_DBI_ADDR_8197F)
#define BIT_CLEAR_DBI_ADDR_8197F(x) ((x) & (~BITS_DBI_ADDR_8197F))
#define BIT_GET_DBI_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_DBI_ADDR_8197F) & BIT_MASK_DBI_ADDR_8197F)
#define BIT_SET_DBI_ADDR_8197F(x, v) \
(BIT_CLEAR_DBI_ADDR_8197F(x) | BIT_DBI_ADDR_8197F(v))
/* 2 REG_MDIO_V1_8197F */
#define BIT_SHIFT_MDIO_RDATA_8197F 16
#define BIT_MASK_MDIO_RDATA_8197F 0xffff
#define BIT_MDIO_RDATA_8197F(x) \
(((x) & BIT_MASK_MDIO_RDATA_8197F) << BIT_SHIFT_MDIO_RDATA_8197F)
#define BITS_MDIO_RDATA_8197F \
(BIT_MASK_MDIO_RDATA_8197F << BIT_SHIFT_MDIO_RDATA_8197F)
#define BIT_CLEAR_MDIO_RDATA_8197F(x) ((x) & (~BITS_MDIO_RDATA_8197F))
#define BIT_GET_MDIO_RDATA_8197F(x) \
(((x) >> BIT_SHIFT_MDIO_RDATA_8197F) & BIT_MASK_MDIO_RDATA_8197F)
#define BIT_SET_MDIO_RDATA_8197F(x, v) \
(BIT_CLEAR_MDIO_RDATA_8197F(x) | BIT_MDIO_RDATA_8197F(v))
#define BIT_SHIFT_MDIO_WDATA_8197F 0
#define BIT_MASK_MDIO_WDATA_8197F 0xffff
#define BIT_MDIO_WDATA_8197F(x) \
(((x) & BIT_MASK_MDIO_WDATA_8197F) << BIT_SHIFT_MDIO_WDATA_8197F)
#define BITS_MDIO_WDATA_8197F \
(BIT_MASK_MDIO_WDATA_8197F << BIT_SHIFT_MDIO_WDATA_8197F)
#define BIT_CLEAR_MDIO_WDATA_8197F(x) ((x) & (~BITS_MDIO_WDATA_8197F))
#define BIT_GET_MDIO_WDATA_8197F(x) \
(((x) >> BIT_SHIFT_MDIO_WDATA_8197F) & BIT_MASK_MDIO_WDATA_8197F)
#define BIT_SET_MDIO_WDATA_8197F(x, v) \
(BIT_CLEAR_MDIO_WDATA_8197F(x) | BIT_MDIO_WDATA_8197F(v))
/* 2 REG_WDT_CFG_8197F */
#define BIT_SHIFT_MDIO_PHY_ADDR_8197F 24
#define BIT_MASK_MDIO_PHY_ADDR_8197F 0x1f
#define BIT_MDIO_PHY_ADDR_8197F(x) \
(((x) & BIT_MASK_MDIO_PHY_ADDR_8197F) << BIT_SHIFT_MDIO_PHY_ADDR_8197F)
#define BITS_MDIO_PHY_ADDR_8197F \
(BIT_MASK_MDIO_PHY_ADDR_8197F << BIT_SHIFT_MDIO_PHY_ADDR_8197F)
#define BIT_CLEAR_MDIO_PHY_ADDR_8197F(x) ((x) & (~BITS_MDIO_PHY_ADDR_8197F))
#define BIT_GET_MDIO_PHY_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_MDIO_PHY_ADDR_8197F) & BIT_MASK_MDIO_PHY_ADDR_8197F)
#define BIT_SET_MDIO_PHY_ADDR_8197F(x, v) \
(BIT_CLEAR_MDIO_PHY_ADDR_8197F(x) | BIT_MDIO_PHY_ADDR_8197F(v))
#define BIT_SHIFT_WATCH_DOG_RECORD_V1_8197F 10
#define BIT_MASK_WATCH_DOG_RECORD_V1_8197F 0x3fff
#define BIT_WATCH_DOG_RECORD_V1_8197F(x) \
(((x) & BIT_MASK_WATCH_DOG_RECORD_V1_8197F) \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8197F)
#define BITS_WATCH_DOG_RECORD_V1_8197F \
(BIT_MASK_WATCH_DOG_RECORD_V1_8197F \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8197F)
#define BIT_CLEAR_WATCH_DOG_RECORD_V1_8197F(x) \
((x) & (~BITS_WATCH_DOG_RECORD_V1_8197F))
#define BIT_GET_WATCH_DOG_RECORD_V1_8197F(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_RECORD_V1_8197F) & \
BIT_MASK_WATCH_DOG_RECORD_V1_8197F)
#define BIT_SET_WATCH_DOG_RECORD_V1_8197F(x, v) \
(BIT_CLEAR_WATCH_DOG_RECORD_V1_8197F(x) | \
BIT_WATCH_DOG_RECORD_V1_8197F(v))
#define BIT_R_IO_TIMEOUT_FLAG_V1_8197F BIT(9)
#define BIT_EN_WATCH_DOG_V1_8197F BIT(8)
#define BIT_ECRC_EN_V1_8197F BIT(7)
#define BIT_MDIO_RFLAG_V1_8197F BIT(6)
#define BIT_MDIO_WFLAG_V1_8197F BIT(5)
#define BIT_SHIFT_MDIO_REG_ADDR_8197F 0
#define BIT_MASK_MDIO_REG_ADDR_8197F 0x1f
#define BIT_MDIO_REG_ADDR_8197F(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR_8197F) << BIT_SHIFT_MDIO_REG_ADDR_8197F)
#define BITS_MDIO_REG_ADDR_8197F \
(BIT_MASK_MDIO_REG_ADDR_8197F << BIT_SHIFT_MDIO_REG_ADDR_8197F)
#define BIT_CLEAR_MDIO_REG_ADDR_8197F(x) ((x) & (~BITS_MDIO_REG_ADDR_8197F))
#define BIT_GET_MDIO_REG_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR_8197F) & BIT_MASK_MDIO_REG_ADDR_8197F)
#define BIT_SET_MDIO_REG_ADDR_8197F(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR_8197F(x) | BIT_MDIO_REG_ADDR_8197F(v))
/* 2 REG_HCI_MIX_CFG_8197F */
#define BIT_RXRST_BACKDOOR_8197F BIT(31)
#define BIT_TXRST_BACKDOOR_8197F BIT(30)
#define BIT_RXIDX_RSTB_8197F BIT(29)
#define BIT_TXIDX_RSTB_8197F BIT(28)
#define BIT_DROP_NEXT_RXPKT_8197F BIT(27)
#define BIT_SHORT_CORE_RST_SEL_8197F BIT(26)
#define BIT_EXCEPT_RESUME_EN_8197F BIT(25)
#define BIT_EXCEPT_RESUME_FLAG_8197F BIT(24)
#define BIT_ALIGN_MTU_8197F BIT(23)
#define BIT_HOST_GEN2_SUPPORT_8197F BIT(20)
#define BIT_SHIFT_TXDMA_ERR_FLAG_8197F 16
#define BIT_MASK_TXDMA_ERR_FLAG_8197F 0xf
#define BIT_TXDMA_ERR_FLAG_8197F(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG_8197F) \
<< BIT_SHIFT_TXDMA_ERR_FLAG_8197F)
#define BITS_TXDMA_ERR_FLAG_8197F \
(BIT_MASK_TXDMA_ERR_FLAG_8197F << BIT_SHIFT_TXDMA_ERR_FLAG_8197F)
#define BIT_CLEAR_TXDMA_ERR_FLAG_8197F(x) ((x) & (~BITS_TXDMA_ERR_FLAG_8197F))
#define BIT_GET_TXDMA_ERR_FLAG_8197F(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG_8197F) & \
BIT_MASK_TXDMA_ERR_FLAG_8197F)
#define BIT_SET_TXDMA_ERR_FLAG_8197F(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG_8197F(x) | BIT_TXDMA_ERR_FLAG_8197F(v))
#define BIT_SHIFT_EARLY_MODE_SEL_8197F 12
#define BIT_MASK_EARLY_MODE_SEL_8197F 0xf
#define BIT_EARLY_MODE_SEL_8197F(x) \
(((x) & BIT_MASK_EARLY_MODE_SEL_8197F) \
<< BIT_SHIFT_EARLY_MODE_SEL_8197F)
#define BITS_EARLY_MODE_SEL_8197F \
(BIT_MASK_EARLY_MODE_SEL_8197F << BIT_SHIFT_EARLY_MODE_SEL_8197F)
#define BIT_CLEAR_EARLY_MODE_SEL_8197F(x) ((x) & (~BITS_EARLY_MODE_SEL_8197F))
#define BIT_GET_EARLY_MODE_SEL_8197F(x) \
(((x) >> BIT_SHIFT_EARLY_MODE_SEL_8197F) & \
BIT_MASK_EARLY_MODE_SEL_8197F)
#define BIT_SET_EARLY_MODE_SEL_8197F(x, v) \
(BIT_CLEAR_EARLY_MODE_SEL_8197F(x) | BIT_EARLY_MODE_SEL_8197F(v))
#define BIT_EPHY_RX50_EN_8197F BIT(11)
#define BIT_SHIFT_MSI_TIMEOUT_ID_V1_8197F 8
#define BIT_MASK_MSI_TIMEOUT_ID_V1_8197F 0x7
#define BIT_MSI_TIMEOUT_ID_V1_8197F(x) \
(((x) & BIT_MASK_MSI_TIMEOUT_ID_V1_8197F) \
<< BIT_SHIFT_MSI_TIMEOUT_ID_V1_8197F)
#define BITS_MSI_TIMEOUT_ID_V1_8197F \
(BIT_MASK_MSI_TIMEOUT_ID_V1_8197F << BIT_SHIFT_MSI_TIMEOUT_ID_V1_8197F)
#define BIT_CLEAR_MSI_TIMEOUT_ID_V1_8197F(x) \
((x) & (~BITS_MSI_TIMEOUT_ID_V1_8197F))
#define BIT_GET_MSI_TIMEOUT_ID_V1_8197F(x) \
(((x) >> BIT_SHIFT_MSI_TIMEOUT_ID_V1_8197F) & \
BIT_MASK_MSI_TIMEOUT_ID_V1_8197F)
#define BIT_SET_MSI_TIMEOUT_ID_V1_8197F(x, v) \
(BIT_CLEAR_MSI_TIMEOUT_ID_V1_8197F(x) | BIT_MSI_TIMEOUT_ID_V1_8197F(v))
#define BIT_RADDR_RD_8197F BIT(7)
#define BIT_EN_MUL_TAG_8197F BIT(6)
#define BIT_EN_EARLY_MODE_8197F BIT(5)
#define BIT_L0S_LINK_OFF_8197F BIT(4)
#define BIT_ACT_LINK_OFF_8197F BIT(3)
/* 2 REG_STC_INT_CS_8197F(HCI STATE CHANGE INTERRUPT CONTROL AND STATUS) */
#define BIT_STC_INT_EN_8197F BIT(31)
#define BIT_SHIFT_STC_INT_FLAG_8197F 16
#define BIT_MASK_STC_INT_FLAG_8197F 0xff
#define BIT_STC_INT_FLAG_8197F(x) \
(((x) & BIT_MASK_STC_INT_FLAG_8197F) << BIT_SHIFT_STC_INT_FLAG_8197F)
#define BITS_STC_INT_FLAG_8197F \
(BIT_MASK_STC_INT_FLAG_8197F << BIT_SHIFT_STC_INT_FLAG_8197F)
#define BIT_CLEAR_STC_INT_FLAG_8197F(x) ((x) & (~BITS_STC_INT_FLAG_8197F))
#define BIT_GET_STC_INT_FLAG_8197F(x) \
(((x) >> BIT_SHIFT_STC_INT_FLAG_8197F) & BIT_MASK_STC_INT_FLAG_8197F)
#define BIT_SET_STC_INT_FLAG_8197F(x, v) \
(BIT_CLEAR_STC_INT_FLAG_8197F(x) | BIT_STC_INT_FLAG_8197F(v))
#define BIT_SHIFT_STC_INT_IDX_8197F 8
#define BIT_MASK_STC_INT_IDX_8197F 0x7
#define BIT_STC_INT_IDX_8197F(x) \
(((x) & BIT_MASK_STC_INT_IDX_8197F) << BIT_SHIFT_STC_INT_IDX_8197F)
#define BITS_STC_INT_IDX_8197F \
(BIT_MASK_STC_INT_IDX_8197F << BIT_SHIFT_STC_INT_IDX_8197F)
#define BIT_CLEAR_STC_INT_IDX_8197F(x) ((x) & (~BITS_STC_INT_IDX_8197F))
#define BIT_GET_STC_INT_IDX_8197F(x) \
(((x) >> BIT_SHIFT_STC_INT_IDX_8197F) & BIT_MASK_STC_INT_IDX_8197F)
#define BIT_SET_STC_INT_IDX_8197F(x, v) \
(BIT_CLEAR_STC_INT_IDX_8197F(x) | BIT_STC_INT_IDX_8197F(v))
#define BIT_SHIFT_STC_INT_REALTIME_CS_8197F 0
#define BIT_MASK_STC_INT_REALTIME_CS_8197F 0x3f
#define BIT_STC_INT_REALTIME_CS_8197F(x) \
(((x) & BIT_MASK_STC_INT_REALTIME_CS_8197F) \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8197F)
#define BITS_STC_INT_REALTIME_CS_8197F \
(BIT_MASK_STC_INT_REALTIME_CS_8197F \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8197F)
#define BIT_CLEAR_STC_INT_REALTIME_CS_8197F(x) \
((x) & (~BITS_STC_INT_REALTIME_CS_8197F))
#define BIT_GET_STC_INT_REALTIME_CS_8197F(x) \
(((x) >> BIT_SHIFT_STC_INT_REALTIME_CS_8197F) & \
BIT_MASK_STC_INT_REALTIME_CS_8197F)
#define BIT_SET_STC_INT_REALTIME_CS_8197F(x, v) \
(BIT_CLEAR_STC_INT_REALTIME_CS_8197F(x) | \
BIT_STC_INT_REALTIME_CS_8197F(v))
/* 2 REG_ST_INT_CFG_8197F(HCI STATE CHANGE INTERRUPT CONFIGURATION) */
#define BIT_STC_INT_GRP_EN_8197F BIT(31)
#define BIT_SHIFT_STC_INT_EXPECT_LS_8197F 8
#define BIT_MASK_STC_INT_EXPECT_LS_8197F 0x3f
#define BIT_STC_INT_EXPECT_LS_8197F(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_LS_8197F) \
<< BIT_SHIFT_STC_INT_EXPECT_LS_8197F)
#define BITS_STC_INT_EXPECT_LS_8197F \
(BIT_MASK_STC_INT_EXPECT_LS_8197F << BIT_SHIFT_STC_INT_EXPECT_LS_8197F)
#define BIT_CLEAR_STC_INT_EXPECT_LS_8197F(x) \
((x) & (~BITS_STC_INT_EXPECT_LS_8197F))
#define BIT_GET_STC_INT_EXPECT_LS_8197F(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_LS_8197F) & \
BIT_MASK_STC_INT_EXPECT_LS_8197F)
#define BIT_SET_STC_INT_EXPECT_LS_8197F(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_LS_8197F(x) | BIT_STC_INT_EXPECT_LS_8197F(v))
#define BIT_SHIFT_STC_INT_EXPECT_CS_8197F 0
#define BIT_MASK_STC_INT_EXPECT_CS_8197F 0x3f
#define BIT_STC_INT_EXPECT_CS_8197F(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_CS_8197F) \
<< BIT_SHIFT_STC_INT_EXPECT_CS_8197F)
#define BITS_STC_INT_EXPECT_CS_8197F \
(BIT_MASK_STC_INT_EXPECT_CS_8197F << BIT_SHIFT_STC_INT_EXPECT_CS_8197F)
#define BIT_CLEAR_STC_INT_EXPECT_CS_8197F(x) \
((x) & (~BITS_STC_INT_EXPECT_CS_8197F))
#define BIT_GET_STC_INT_EXPECT_CS_8197F(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_CS_8197F) & \
BIT_MASK_STC_INT_EXPECT_CS_8197F)
#define BIT_SET_STC_INT_EXPECT_CS_8197F(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_CS_8197F(x) | BIT_STC_INT_EXPECT_CS_8197F(v))
/* 2 REG_CMU_DLY_CTRL_8197F(HCI PHY CLOCK MGT UNIT DELAY CONTROL ) */
#define BIT_CMU_DLY_EN_8197F BIT(31)
#define BIT_CMU_DLY_MODE_8197F BIT(30)
#define BIT_SHIFT_CMU_DLY_PRE_DIV_8197F 0
#define BIT_MASK_CMU_DLY_PRE_DIV_8197F 0xff
#define BIT_CMU_DLY_PRE_DIV_8197F(x) \
(((x) & BIT_MASK_CMU_DLY_PRE_DIV_8197F) \
<< BIT_SHIFT_CMU_DLY_PRE_DIV_8197F)
#define BITS_CMU_DLY_PRE_DIV_8197F \
(BIT_MASK_CMU_DLY_PRE_DIV_8197F << BIT_SHIFT_CMU_DLY_PRE_DIV_8197F)
#define BIT_CLEAR_CMU_DLY_PRE_DIV_8197F(x) ((x) & (~BITS_CMU_DLY_PRE_DIV_8197F))
#define BIT_GET_CMU_DLY_PRE_DIV_8197F(x) \
(((x) >> BIT_SHIFT_CMU_DLY_PRE_DIV_8197F) & \
BIT_MASK_CMU_DLY_PRE_DIV_8197F)
#define BIT_SET_CMU_DLY_PRE_DIV_8197F(x, v) \
(BIT_CLEAR_CMU_DLY_PRE_DIV_8197F(x) | BIT_CMU_DLY_PRE_DIV_8197F(v))
/* 2 REG_CMU_DLY_CFG_8197F(HCI PHY CLOCK MGT UNIT DELAY CONFIGURATION ) */
#define BIT_SHIFT_CMU_DLY_LTR_A2I_8197F 24
#define BIT_MASK_CMU_DLY_LTR_A2I_8197F 0xff
#define BIT_CMU_DLY_LTR_A2I_8197F(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_A2I_8197F) \
<< BIT_SHIFT_CMU_DLY_LTR_A2I_8197F)
#define BITS_CMU_DLY_LTR_A2I_8197F \
(BIT_MASK_CMU_DLY_LTR_A2I_8197F << BIT_SHIFT_CMU_DLY_LTR_A2I_8197F)
#define BIT_CLEAR_CMU_DLY_LTR_A2I_8197F(x) ((x) & (~BITS_CMU_DLY_LTR_A2I_8197F))
#define BIT_GET_CMU_DLY_LTR_A2I_8197F(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_A2I_8197F) & \
BIT_MASK_CMU_DLY_LTR_A2I_8197F)
#define BIT_SET_CMU_DLY_LTR_A2I_8197F(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_A2I_8197F(x) | BIT_CMU_DLY_LTR_A2I_8197F(v))
#define BIT_SHIFT_CMU_DLY_LTR_I2A_8197F 16
#define BIT_MASK_CMU_DLY_LTR_I2A_8197F 0xff
#define BIT_CMU_DLY_LTR_I2A_8197F(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_I2A_8197F) \
<< BIT_SHIFT_CMU_DLY_LTR_I2A_8197F)
#define BITS_CMU_DLY_LTR_I2A_8197F \
(BIT_MASK_CMU_DLY_LTR_I2A_8197F << BIT_SHIFT_CMU_DLY_LTR_I2A_8197F)
#define BIT_CLEAR_CMU_DLY_LTR_I2A_8197F(x) ((x) & (~BITS_CMU_DLY_LTR_I2A_8197F))
#define BIT_GET_CMU_DLY_LTR_I2A_8197F(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_I2A_8197F) & \
BIT_MASK_CMU_DLY_LTR_I2A_8197F)
#define BIT_SET_CMU_DLY_LTR_I2A_8197F(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_I2A_8197F(x) | BIT_CMU_DLY_LTR_I2A_8197F(v))
#define BIT_SHIFT_CMU_DLY_LTR_IDLE_8197F 8
#define BIT_MASK_CMU_DLY_LTR_IDLE_8197F 0xff
#define BIT_CMU_DLY_LTR_IDLE_8197F(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_IDLE_8197F) \
<< BIT_SHIFT_CMU_DLY_LTR_IDLE_8197F)
#define BITS_CMU_DLY_LTR_IDLE_8197F \
(BIT_MASK_CMU_DLY_LTR_IDLE_8197F << BIT_SHIFT_CMU_DLY_LTR_IDLE_8197F)
#define BIT_CLEAR_CMU_DLY_LTR_IDLE_8197F(x) \
((x) & (~BITS_CMU_DLY_LTR_IDLE_8197F))
#define BIT_GET_CMU_DLY_LTR_IDLE_8197F(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_IDLE_8197F) & \
BIT_MASK_CMU_DLY_LTR_IDLE_8197F)
#define BIT_SET_CMU_DLY_LTR_IDLE_8197F(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_IDLE_8197F(x) | BIT_CMU_DLY_LTR_IDLE_8197F(v))
#define BIT_SHIFT_CMU_DLY_LTR_ACT_8197F 0
#define BIT_MASK_CMU_DLY_LTR_ACT_8197F 0xff
#define BIT_CMU_DLY_LTR_ACT_8197F(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_ACT_8197F) \
<< BIT_SHIFT_CMU_DLY_LTR_ACT_8197F)
#define BITS_CMU_DLY_LTR_ACT_8197F \
(BIT_MASK_CMU_DLY_LTR_ACT_8197F << BIT_SHIFT_CMU_DLY_LTR_ACT_8197F)
#define BIT_CLEAR_CMU_DLY_LTR_ACT_8197F(x) ((x) & (~BITS_CMU_DLY_LTR_ACT_8197F))
#define BIT_GET_CMU_DLY_LTR_ACT_8197F(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_ACT_8197F) & \
BIT_MASK_CMU_DLY_LTR_ACT_8197F)
#define BIT_SET_CMU_DLY_LTR_ACT_8197F(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_ACT_8197F(x) | BIT_CMU_DLY_LTR_ACT_8197F(v))
/* 2 REG_H2CQ_TXBD_DESA_8197F */
#define BIT_SHIFT_H2CQ_TXBD_DESA_8197F 0
#define BIT_MASK_H2CQ_TXBD_DESA_8197F 0xffffffffffffffffL
#define BIT_H2CQ_TXBD_DESA_8197F(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_8197F) \
<< BIT_SHIFT_H2CQ_TXBD_DESA_8197F)
#define BITS_H2CQ_TXBD_DESA_8197F \
(BIT_MASK_H2CQ_TXBD_DESA_8197F << BIT_SHIFT_H2CQ_TXBD_DESA_8197F)
#define BIT_CLEAR_H2CQ_TXBD_DESA_8197F(x) ((x) & (~BITS_H2CQ_TXBD_DESA_8197F))
#define BIT_GET_H2CQ_TXBD_DESA_8197F(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_8197F) & \
BIT_MASK_H2CQ_TXBD_DESA_8197F)
#define BIT_SET_H2CQ_TXBD_DESA_8197F(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_8197F(x) | BIT_H2CQ_TXBD_DESA_8197F(v))
/* 2 REG_H2CQ_TXBD_NUM_8197F */
#define BIT_HCI_H2CQ_FLAG_8197F BIT(14)
#define BIT_SHIFT_H2CQ_DESC_MODE_8197F 12
#define BIT_MASK_H2CQ_DESC_MODE_8197F 0x3
#define BIT_H2CQ_DESC_MODE_8197F(x) \
(((x) & BIT_MASK_H2CQ_DESC_MODE_8197F) \
<< BIT_SHIFT_H2CQ_DESC_MODE_8197F)
#define BITS_H2CQ_DESC_MODE_8197F \
(BIT_MASK_H2CQ_DESC_MODE_8197F << BIT_SHIFT_H2CQ_DESC_MODE_8197F)
#define BIT_CLEAR_H2CQ_DESC_MODE_8197F(x) ((x) & (~BITS_H2CQ_DESC_MODE_8197F))
#define BIT_GET_H2CQ_DESC_MODE_8197F(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_MODE_8197F) & \
BIT_MASK_H2CQ_DESC_MODE_8197F)
#define BIT_SET_H2CQ_DESC_MODE_8197F(x, v) \
(BIT_CLEAR_H2CQ_DESC_MODE_8197F(x) | BIT_H2CQ_DESC_MODE_8197F(v))
#define BIT_SHIFT_H2CQ_DESC_NUM_8197F 0
#define BIT_MASK_H2CQ_DESC_NUM_8197F 0xfff
#define BIT_H2CQ_DESC_NUM_8197F(x) \
(((x) & BIT_MASK_H2CQ_DESC_NUM_8197F) << BIT_SHIFT_H2CQ_DESC_NUM_8197F)
#define BITS_H2CQ_DESC_NUM_8197F \
(BIT_MASK_H2CQ_DESC_NUM_8197F << BIT_SHIFT_H2CQ_DESC_NUM_8197F)
#define BIT_CLEAR_H2CQ_DESC_NUM_8197F(x) ((x) & (~BITS_H2CQ_DESC_NUM_8197F))
#define BIT_GET_H2CQ_DESC_NUM_8197F(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_NUM_8197F) & BIT_MASK_H2CQ_DESC_NUM_8197F)
#define BIT_SET_H2CQ_DESC_NUM_8197F(x, v) \
(BIT_CLEAR_H2CQ_DESC_NUM_8197F(x) | BIT_H2CQ_DESC_NUM_8197F(v))
/* 2 REG_H2CQ_TXBD_IDX_8197F */
#define BIT_SHIFT_H2CQ_HW_IDX_8197F 16
#define BIT_MASK_H2CQ_HW_IDX_8197F 0xfff
#define BIT_H2CQ_HW_IDX_8197F(x) \
(((x) & BIT_MASK_H2CQ_HW_IDX_8197F) << BIT_SHIFT_H2CQ_HW_IDX_8197F)
#define BITS_H2CQ_HW_IDX_8197F \
(BIT_MASK_H2CQ_HW_IDX_8197F << BIT_SHIFT_H2CQ_HW_IDX_8197F)
#define BIT_CLEAR_H2CQ_HW_IDX_8197F(x) ((x) & (~BITS_H2CQ_HW_IDX_8197F))
#define BIT_GET_H2CQ_HW_IDX_8197F(x) \
(((x) >> BIT_SHIFT_H2CQ_HW_IDX_8197F) & BIT_MASK_H2CQ_HW_IDX_8197F)
#define BIT_SET_H2CQ_HW_IDX_8197F(x, v) \
(BIT_CLEAR_H2CQ_HW_IDX_8197F(x) | BIT_H2CQ_HW_IDX_8197F(v))
#define BIT_SHIFT_H2CQ_HOST_IDX_8197F 0
#define BIT_MASK_H2CQ_HOST_IDX_8197F 0xfff
#define BIT_H2CQ_HOST_IDX_8197F(x) \
(((x) & BIT_MASK_H2CQ_HOST_IDX_8197F) << BIT_SHIFT_H2CQ_HOST_IDX_8197F)
#define BITS_H2CQ_HOST_IDX_8197F \
(BIT_MASK_H2CQ_HOST_IDX_8197F << BIT_SHIFT_H2CQ_HOST_IDX_8197F)
#define BIT_CLEAR_H2CQ_HOST_IDX_8197F(x) ((x) & (~BITS_H2CQ_HOST_IDX_8197F))
#define BIT_GET_H2CQ_HOST_IDX_8197F(x) \
(((x) >> BIT_SHIFT_H2CQ_HOST_IDX_8197F) & BIT_MASK_H2CQ_HOST_IDX_8197F)
#define BIT_SET_H2CQ_HOST_IDX_8197F(x, v) \
(BIT_CLEAR_H2CQ_HOST_IDX_8197F(x) | BIT_H2CQ_HOST_IDX_8197F(v))
/* 2 REG_H2CQ_CSR_8197F[31:0] (H2CQ CONTROL AND STATUS) */
#define BIT_H2CQ_FULL_8197F BIT(31)
#define BIT_CLR_H2CQ_HOST_IDX_8197F BIT(16)
#define BIT_CLR_H2CQ_HW_IDX_8197F BIT(8)
#define BIT_STOP_H2CQ_8197F BIT(0)
/* 2 REG_AXI_EXCEPT_CS_8197F[31:0] (AXI EXCEPTION CONTROL AND STATUS) */
#define BIT_AXI_RXDMA_TIMEOUT_RE_8197F BIT(21)
#define BIT_AXI_TXDMA_TIMEOUT_RE_8197F BIT(20)
#define BIT_AXI_DECERR_W_RE_8197F BIT(19)
#define BIT_AXI_DECERR_R_RE_8197F BIT(18)
#define BIT_AXI_SLVERR_W_RE_8197F BIT(17)
#define BIT_AXI_SLVERR_R_RE_8197F BIT(16)
#define BIT_AXI_RXDMA_TIMEOUT_IE_8197F BIT(13)
#define BIT_AXI_TXDMA_TIMEOUT_IE_8197F BIT(12)
#define BIT_AXI_DECERR_W_IE_8197F BIT(11)
#define BIT_AXI_DECERR_R_IE_8197F BIT(10)
#define BIT_AXI_SLVERR_W_IE_8197F BIT(9)
#define BIT_AXI_SLVERR_R_IE_8197F BIT(8)
#define BIT_AXI_RXDMA_TIMEOUT_FLAG_8197F BIT(5)
#define BIT_AXI_TXDMA_TIMEOUT_FLAG_8197F BIT(4)
#define BIT_AXI_DECERR_W_FLAG_8197F BIT(3)
#define BIT_AXI_DECERR_R_FLAG_8197F BIT(2)
#define BIT_AXI_SLVERR_W_FLAG_8197F BIT(1)
#define BIT_AXI_SLVERR_R_FLAG_8197F BIT(0)
/* 2 REG_AXI_EXCEPT_TIME_8197F[31:0] (AXI EXCEPTION TIME CONTROL) */
#define BIT_SHIFT_AXI_RECOVERY_TIME_8197F 24
#define BIT_MASK_AXI_RECOVERY_TIME_8197F 0xff
#define BIT_AXI_RECOVERY_TIME_8197F(x) \
(((x) & BIT_MASK_AXI_RECOVERY_TIME_8197F) \
<< BIT_SHIFT_AXI_RECOVERY_TIME_8197F)
#define BITS_AXI_RECOVERY_TIME_8197F \
(BIT_MASK_AXI_RECOVERY_TIME_8197F << BIT_SHIFT_AXI_RECOVERY_TIME_8197F)
#define BIT_CLEAR_AXI_RECOVERY_TIME_8197F(x) \
((x) & (~BITS_AXI_RECOVERY_TIME_8197F))
#define BIT_GET_AXI_RECOVERY_TIME_8197F(x) \
(((x) >> BIT_SHIFT_AXI_RECOVERY_TIME_8197F) & \
BIT_MASK_AXI_RECOVERY_TIME_8197F)
#define BIT_SET_AXI_RECOVERY_TIME_8197F(x, v) \
(BIT_CLEAR_AXI_RECOVERY_TIME_8197F(x) | BIT_AXI_RECOVERY_TIME_8197F(v))
#define BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL_8197F 12
#define BIT_MASK_AXI_RXDMA_TIMEOUT_VAL_8197F 0xfff
#define BIT_AXI_RXDMA_TIMEOUT_VAL_8197F(x) \
(((x) & BIT_MASK_AXI_RXDMA_TIMEOUT_VAL_8197F) \
<< BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL_8197F)
#define BITS_AXI_RXDMA_TIMEOUT_VAL_8197F \
(BIT_MASK_AXI_RXDMA_TIMEOUT_VAL_8197F \
<< BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL_8197F)
#define BIT_CLEAR_AXI_RXDMA_TIMEOUT_VAL_8197F(x) \
((x) & (~BITS_AXI_RXDMA_TIMEOUT_VAL_8197F))
#define BIT_GET_AXI_RXDMA_TIMEOUT_VAL_8197F(x) \
(((x) >> BIT_SHIFT_AXI_RXDMA_TIMEOUT_VAL_8197F) & \
BIT_MASK_AXI_RXDMA_TIMEOUT_VAL_8197F)
#define BIT_SET_AXI_RXDMA_TIMEOUT_VAL_8197F(x, v) \
(BIT_CLEAR_AXI_RXDMA_TIMEOUT_VAL_8197F(x) | \
BIT_AXI_RXDMA_TIMEOUT_VAL_8197F(v))
#define BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL_8197F 0
#define BIT_MASK_AXI_TXDMA_TIMEOUT_VAL_8197F 0xfff
#define BIT_AXI_TXDMA_TIMEOUT_VAL_8197F(x) \
(((x) & BIT_MASK_AXI_TXDMA_TIMEOUT_VAL_8197F) \
<< BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL_8197F)
#define BITS_AXI_TXDMA_TIMEOUT_VAL_8197F \
(BIT_MASK_AXI_TXDMA_TIMEOUT_VAL_8197F \
<< BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL_8197F)
#define BIT_CLEAR_AXI_TXDMA_TIMEOUT_VAL_8197F(x) \
((x) & (~BITS_AXI_TXDMA_TIMEOUT_VAL_8197F))
#define BIT_GET_AXI_TXDMA_TIMEOUT_VAL_8197F(x) \
(((x) >> BIT_SHIFT_AXI_TXDMA_TIMEOUT_VAL_8197F) & \
BIT_MASK_AXI_TXDMA_TIMEOUT_VAL_8197F)
#define BIT_SET_AXI_TXDMA_TIMEOUT_VAL_8197F(x, v) \
(BIT_CLEAR_AXI_TXDMA_TIMEOUT_VAL_8197F(x) | \
BIT_AXI_TXDMA_TIMEOUT_VAL_8197F(v))
/* 2 REG_Q0_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q0_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q0_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q0_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q0_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q0_V1_8197F)
#define BITS_QUEUEMACID_Q0_V1_8197F \
(BIT_MASK_QUEUEMACID_Q0_V1_8197F << BIT_SHIFT_QUEUEMACID_Q0_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q0_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q0_V1_8197F))
#define BIT_GET_QUEUEMACID_Q0_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q0_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q0_V1_8197F)
#define BIT_SET_QUEUEMACID_Q0_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q0_V1_8197F(x) | BIT_QUEUEMACID_Q0_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q0_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q0_V1_8197F 0x3
#define BIT_QUEUEAC_Q0_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q0_V1_8197F) << BIT_SHIFT_QUEUEAC_Q0_V1_8197F)
#define BITS_QUEUEAC_Q0_V1_8197F \
(BIT_MASK_QUEUEAC_Q0_V1_8197F << BIT_SHIFT_QUEUEAC_Q0_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q0_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q0_V1_8197F))
#define BIT_GET_QUEUEAC_Q0_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q0_V1_8197F) & BIT_MASK_QUEUEAC_Q0_V1_8197F)
#define BIT_SET_QUEUEAC_Q0_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q0_V1_8197F(x) | BIT_QUEUEAC_Q0_V1_8197F(v))
#define BIT_TIDEMPTY_Q0_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q0_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q0_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q0_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q0_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q0_V2_8197F)
#define BITS_TAIL_PKT_Q0_V2_8197F \
(BIT_MASK_TAIL_PKT_Q0_V2_8197F << BIT_SHIFT_TAIL_PKT_Q0_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q0_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q0_V2_8197F))
#define BIT_GET_TAIL_PKT_Q0_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q0_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q0_V2_8197F)
#define BIT_SET_TAIL_PKT_Q0_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q0_V2_8197F(x) | BIT_TAIL_PKT_Q0_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q0_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q0_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q0_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q0_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q0_V1_8197F)
#define BITS_HEAD_PKT_Q0_V1_8197F \
(BIT_MASK_HEAD_PKT_Q0_V1_8197F << BIT_SHIFT_HEAD_PKT_Q0_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q0_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q0_V1_8197F))
#define BIT_GET_HEAD_PKT_Q0_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q0_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q0_V1_8197F)
#define BIT_SET_HEAD_PKT_Q0_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q0_V1_8197F(x) | BIT_HEAD_PKT_Q0_V1_8197F(v))
/* 2 REG_Q1_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q1_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q1_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q1_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q1_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q1_V1_8197F)
#define BITS_QUEUEMACID_Q1_V1_8197F \
(BIT_MASK_QUEUEMACID_Q1_V1_8197F << BIT_SHIFT_QUEUEMACID_Q1_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q1_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q1_V1_8197F))
#define BIT_GET_QUEUEMACID_Q1_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q1_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q1_V1_8197F)
#define BIT_SET_QUEUEMACID_Q1_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q1_V1_8197F(x) | BIT_QUEUEMACID_Q1_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q1_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q1_V1_8197F 0x3
#define BIT_QUEUEAC_Q1_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q1_V1_8197F) << BIT_SHIFT_QUEUEAC_Q1_V1_8197F)
#define BITS_QUEUEAC_Q1_V1_8197F \
(BIT_MASK_QUEUEAC_Q1_V1_8197F << BIT_SHIFT_QUEUEAC_Q1_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q1_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q1_V1_8197F))
#define BIT_GET_QUEUEAC_Q1_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q1_V1_8197F) & BIT_MASK_QUEUEAC_Q1_V1_8197F)
#define BIT_SET_QUEUEAC_Q1_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q1_V1_8197F(x) | BIT_QUEUEAC_Q1_V1_8197F(v))
#define BIT_TIDEMPTY_Q1_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q1_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q1_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q1_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q1_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q1_V2_8197F)
#define BITS_TAIL_PKT_Q1_V2_8197F \
(BIT_MASK_TAIL_PKT_Q1_V2_8197F << BIT_SHIFT_TAIL_PKT_Q1_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q1_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q1_V2_8197F))
#define BIT_GET_TAIL_PKT_Q1_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q1_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q1_V2_8197F)
#define BIT_SET_TAIL_PKT_Q1_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q1_V2_8197F(x) | BIT_TAIL_PKT_Q1_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q1_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q1_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q1_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q1_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q1_V1_8197F)
#define BITS_HEAD_PKT_Q1_V1_8197F \
(BIT_MASK_HEAD_PKT_Q1_V1_8197F << BIT_SHIFT_HEAD_PKT_Q1_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q1_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q1_V1_8197F))
#define BIT_GET_HEAD_PKT_Q1_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q1_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q1_V1_8197F)
#define BIT_SET_HEAD_PKT_Q1_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q1_V1_8197F(x) | BIT_HEAD_PKT_Q1_V1_8197F(v))
/* 2 REG_Q2_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q2_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q2_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q2_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q2_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q2_V1_8197F)
#define BITS_QUEUEMACID_Q2_V1_8197F \
(BIT_MASK_QUEUEMACID_Q2_V1_8197F << BIT_SHIFT_QUEUEMACID_Q2_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q2_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q2_V1_8197F))
#define BIT_GET_QUEUEMACID_Q2_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q2_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q2_V1_8197F)
#define BIT_SET_QUEUEMACID_Q2_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q2_V1_8197F(x) | BIT_QUEUEMACID_Q2_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q2_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q2_V1_8197F 0x3
#define BIT_QUEUEAC_Q2_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q2_V1_8197F) << BIT_SHIFT_QUEUEAC_Q2_V1_8197F)
#define BITS_QUEUEAC_Q2_V1_8197F \
(BIT_MASK_QUEUEAC_Q2_V1_8197F << BIT_SHIFT_QUEUEAC_Q2_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q2_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q2_V1_8197F))
#define BIT_GET_QUEUEAC_Q2_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q2_V1_8197F) & BIT_MASK_QUEUEAC_Q2_V1_8197F)
#define BIT_SET_QUEUEAC_Q2_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q2_V1_8197F(x) | BIT_QUEUEAC_Q2_V1_8197F(v))
#define BIT_TIDEMPTY_Q2_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q2_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q2_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q2_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q2_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q2_V2_8197F)
#define BITS_TAIL_PKT_Q2_V2_8197F \
(BIT_MASK_TAIL_PKT_Q2_V2_8197F << BIT_SHIFT_TAIL_PKT_Q2_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q2_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q2_V2_8197F))
#define BIT_GET_TAIL_PKT_Q2_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q2_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q2_V2_8197F)
#define BIT_SET_TAIL_PKT_Q2_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q2_V2_8197F(x) | BIT_TAIL_PKT_Q2_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q2_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q2_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q2_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q2_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q2_V1_8197F)
#define BITS_HEAD_PKT_Q2_V1_8197F \
(BIT_MASK_HEAD_PKT_Q2_V1_8197F << BIT_SHIFT_HEAD_PKT_Q2_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q2_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q2_V1_8197F))
#define BIT_GET_HEAD_PKT_Q2_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q2_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q2_V1_8197F)
#define BIT_SET_HEAD_PKT_Q2_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q2_V1_8197F(x) | BIT_HEAD_PKT_Q2_V1_8197F(v))
/* 2 REG_Q3_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q3_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q3_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q3_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q3_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q3_V1_8197F)
#define BITS_QUEUEMACID_Q3_V1_8197F \
(BIT_MASK_QUEUEMACID_Q3_V1_8197F << BIT_SHIFT_QUEUEMACID_Q3_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q3_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q3_V1_8197F))
#define BIT_GET_QUEUEMACID_Q3_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q3_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q3_V1_8197F)
#define BIT_SET_QUEUEMACID_Q3_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q3_V1_8197F(x) | BIT_QUEUEMACID_Q3_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q3_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q3_V1_8197F 0x3
#define BIT_QUEUEAC_Q3_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q3_V1_8197F) << BIT_SHIFT_QUEUEAC_Q3_V1_8197F)
#define BITS_QUEUEAC_Q3_V1_8197F \
(BIT_MASK_QUEUEAC_Q3_V1_8197F << BIT_SHIFT_QUEUEAC_Q3_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q3_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q3_V1_8197F))
#define BIT_GET_QUEUEAC_Q3_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q3_V1_8197F) & BIT_MASK_QUEUEAC_Q3_V1_8197F)
#define BIT_SET_QUEUEAC_Q3_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q3_V1_8197F(x) | BIT_QUEUEAC_Q3_V1_8197F(v))
#define BIT_TIDEMPTY_Q3_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q3_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q3_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q3_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q3_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q3_V2_8197F)
#define BITS_TAIL_PKT_Q3_V2_8197F \
(BIT_MASK_TAIL_PKT_Q3_V2_8197F << BIT_SHIFT_TAIL_PKT_Q3_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q3_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q3_V2_8197F))
#define BIT_GET_TAIL_PKT_Q3_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q3_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q3_V2_8197F)
#define BIT_SET_TAIL_PKT_Q3_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q3_V2_8197F(x) | BIT_TAIL_PKT_Q3_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q3_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q3_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q3_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q3_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q3_V1_8197F)
#define BITS_HEAD_PKT_Q3_V1_8197F \
(BIT_MASK_HEAD_PKT_Q3_V1_8197F << BIT_SHIFT_HEAD_PKT_Q3_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q3_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q3_V1_8197F))
#define BIT_GET_HEAD_PKT_Q3_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q3_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q3_V1_8197F)
#define BIT_SET_HEAD_PKT_Q3_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q3_V1_8197F(x) | BIT_HEAD_PKT_Q3_V1_8197F(v))
/* 2 REG_MGQ_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_MGQ_V1_8197F 25
#define BIT_MASK_QUEUEMACID_MGQ_V1_8197F 0x7f
#define BIT_QUEUEMACID_MGQ_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_MGQ_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_MGQ_V1_8197F)
#define BITS_QUEUEMACID_MGQ_V1_8197F \
(BIT_MASK_QUEUEMACID_MGQ_V1_8197F << BIT_SHIFT_QUEUEMACID_MGQ_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_MGQ_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_MGQ_V1_8197F))
#define BIT_GET_QUEUEMACID_MGQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_MGQ_V1_8197F) & \
BIT_MASK_QUEUEMACID_MGQ_V1_8197F)
#define BIT_SET_QUEUEMACID_MGQ_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_MGQ_V1_8197F(x) | BIT_QUEUEMACID_MGQ_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_MGQ_V1_8197F 23
#define BIT_MASK_QUEUEAC_MGQ_V1_8197F 0x3
#define BIT_QUEUEAC_MGQ_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_MGQ_V1_8197F) \
<< BIT_SHIFT_QUEUEAC_MGQ_V1_8197F)
#define BITS_QUEUEAC_MGQ_V1_8197F \
(BIT_MASK_QUEUEAC_MGQ_V1_8197F << BIT_SHIFT_QUEUEAC_MGQ_V1_8197F)
#define BIT_CLEAR_QUEUEAC_MGQ_V1_8197F(x) ((x) & (~BITS_QUEUEAC_MGQ_V1_8197F))
#define BIT_GET_QUEUEAC_MGQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_MGQ_V1_8197F) & \
BIT_MASK_QUEUEAC_MGQ_V1_8197F)
#define BIT_SET_QUEUEAC_MGQ_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_MGQ_V1_8197F(x) | BIT_QUEUEAC_MGQ_V1_8197F(v))
#define BIT_TIDEMPTY_MGQ_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_MGQ_V2_8197F 11
#define BIT_MASK_TAIL_PKT_MGQ_V2_8197F 0x7ff
#define BIT_TAIL_PKT_MGQ_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_MGQ_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_MGQ_V2_8197F)
#define BITS_TAIL_PKT_MGQ_V2_8197F \
(BIT_MASK_TAIL_PKT_MGQ_V2_8197F << BIT_SHIFT_TAIL_PKT_MGQ_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_MGQ_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_MGQ_V2_8197F))
#define BIT_GET_TAIL_PKT_MGQ_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_MGQ_V2_8197F) & \
BIT_MASK_TAIL_PKT_MGQ_V2_8197F)
#define BIT_SET_TAIL_PKT_MGQ_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_MGQ_V2_8197F(x) | BIT_TAIL_PKT_MGQ_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_MGQ_V1_8197F 0
#define BIT_MASK_HEAD_PKT_MGQ_V1_8197F 0x7ff
#define BIT_HEAD_PKT_MGQ_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_MGQ_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_MGQ_V1_8197F)
#define BITS_HEAD_PKT_MGQ_V1_8197F \
(BIT_MASK_HEAD_PKT_MGQ_V1_8197F << BIT_SHIFT_HEAD_PKT_MGQ_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_MGQ_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_MGQ_V1_8197F))
#define BIT_GET_HEAD_PKT_MGQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_MGQ_V1_8197F) & \
BIT_MASK_HEAD_PKT_MGQ_V1_8197F)
#define BIT_SET_HEAD_PKT_MGQ_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_MGQ_V1_8197F(x) | BIT_HEAD_PKT_MGQ_V1_8197F(v))
/* 2 REG_HIQ_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_HIQ_V1_8197F 25
#define BIT_MASK_QUEUEMACID_HIQ_V1_8197F 0x7f
#define BIT_QUEUEMACID_HIQ_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_HIQ_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_HIQ_V1_8197F)
#define BITS_QUEUEMACID_HIQ_V1_8197F \
(BIT_MASK_QUEUEMACID_HIQ_V1_8197F << BIT_SHIFT_QUEUEMACID_HIQ_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_HIQ_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_HIQ_V1_8197F))
#define BIT_GET_QUEUEMACID_HIQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_HIQ_V1_8197F) & \
BIT_MASK_QUEUEMACID_HIQ_V1_8197F)
#define BIT_SET_QUEUEMACID_HIQ_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_HIQ_V1_8197F(x) | BIT_QUEUEMACID_HIQ_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_HIQ_V1_8197F 23
#define BIT_MASK_QUEUEAC_HIQ_V1_8197F 0x3
#define BIT_QUEUEAC_HIQ_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_HIQ_V1_8197F) \
<< BIT_SHIFT_QUEUEAC_HIQ_V1_8197F)
#define BITS_QUEUEAC_HIQ_V1_8197F \
(BIT_MASK_QUEUEAC_HIQ_V1_8197F << BIT_SHIFT_QUEUEAC_HIQ_V1_8197F)
#define BIT_CLEAR_QUEUEAC_HIQ_V1_8197F(x) ((x) & (~BITS_QUEUEAC_HIQ_V1_8197F))
#define BIT_GET_QUEUEAC_HIQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_HIQ_V1_8197F) & \
BIT_MASK_QUEUEAC_HIQ_V1_8197F)
#define BIT_SET_QUEUEAC_HIQ_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_HIQ_V1_8197F(x) | BIT_QUEUEAC_HIQ_V1_8197F(v))
#define BIT_TIDEMPTY_HIQ_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_HIQ_V2_8197F 11
#define BIT_MASK_TAIL_PKT_HIQ_V2_8197F 0x7ff
#define BIT_TAIL_PKT_HIQ_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_HIQ_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_HIQ_V2_8197F)
#define BITS_TAIL_PKT_HIQ_V2_8197F \
(BIT_MASK_TAIL_PKT_HIQ_V2_8197F << BIT_SHIFT_TAIL_PKT_HIQ_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_HIQ_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_HIQ_V2_8197F))
#define BIT_GET_TAIL_PKT_HIQ_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_HIQ_V2_8197F) & \
BIT_MASK_TAIL_PKT_HIQ_V2_8197F)
#define BIT_SET_TAIL_PKT_HIQ_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_HIQ_V2_8197F(x) | BIT_TAIL_PKT_HIQ_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_HIQ_V1_8197F 0
#define BIT_MASK_HEAD_PKT_HIQ_V1_8197F 0x7ff
#define BIT_HEAD_PKT_HIQ_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_HIQ_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_HIQ_V1_8197F)
#define BITS_HEAD_PKT_HIQ_V1_8197F \
(BIT_MASK_HEAD_PKT_HIQ_V1_8197F << BIT_SHIFT_HEAD_PKT_HIQ_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_HIQ_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_HIQ_V1_8197F))
#define BIT_GET_HEAD_PKT_HIQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_HIQ_V1_8197F) & \
BIT_MASK_HEAD_PKT_HIQ_V1_8197F)
#define BIT_SET_HEAD_PKT_HIQ_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_HIQ_V1_8197F(x) | BIT_HEAD_PKT_HIQ_V1_8197F(v))
/* 2 REG_BCNQ_INFO_8197F */
#define BIT_SHIFT_BCNQ_HEAD_PG_V1_8197F 0
#define BIT_MASK_BCNQ_HEAD_PG_V1_8197F 0xfff
#define BIT_BCNQ_HEAD_PG_V1_8197F(x) \
(((x) & BIT_MASK_BCNQ_HEAD_PG_V1_8197F) \
<< BIT_SHIFT_BCNQ_HEAD_PG_V1_8197F)
#define BITS_BCNQ_HEAD_PG_V1_8197F \
(BIT_MASK_BCNQ_HEAD_PG_V1_8197F << BIT_SHIFT_BCNQ_HEAD_PG_V1_8197F)
#define BIT_CLEAR_BCNQ_HEAD_PG_V1_8197F(x) ((x) & (~BITS_BCNQ_HEAD_PG_V1_8197F))
#define BIT_GET_BCNQ_HEAD_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_BCNQ_HEAD_PG_V1_8197F) & \
BIT_MASK_BCNQ_HEAD_PG_V1_8197F)
#define BIT_SET_BCNQ_HEAD_PG_V1_8197F(x, v) \
(BIT_CLEAR_BCNQ_HEAD_PG_V1_8197F(x) | BIT_BCNQ_HEAD_PG_V1_8197F(v))
/* 2 REG_TXPKT_EMPTY_8197F */
#define BIT_BCNQ_EMPTY_8197F BIT(11)
#define BIT_HQQ_EMPTY_8197F BIT(10)
#define BIT_MQQ_EMPTY_8197F BIT(9)
#define BIT_MGQ_CPU_EMPTY_8197F BIT(8)
#define BIT_AC7Q_EMPTY_8197F BIT(7)
#define BIT_AC6Q_EMPTY_8197F BIT(6)
#define BIT_AC5Q_EMPTY_8197F BIT(5)
#define BIT_AC4Q_EMPTY_8197F BIT(4)
#define BIT_AC3Q_EMPTY_8197F BIT(3)
#define BIT_AC2Q_EMPTY_8197F BIT(2)
#define BIT_AC1Q_EMPTY_8197F BIT(1)
#define BIT_AC0Q_EMPTY_8197F BIT(0)
/* 2 REG_CPU_MGQ_INFO_8197F */
#define BIT_BCN1_POLL_8197F BIT(30)
#define BIT_CPUMGT_POLL_8197F BIT(29)
#define BIT_BCN_POLL_8197F BIT(28)
#define BIT_CPUMGQ_FW_NUM_V1_8197F BIT(12)
#define BIT_SHIFT_FW_FREE_TAIL_V1_8197F 0
#define BIT_MASK_FW_FREE_TAIL_V1_8197F 0xfff
#define BIT_FW_FREE_TAIL_V1_8197F(x) \
(((x) & BIT_MASK_FW_FREE_TAIL_V1_8197F) \
<< BIT_SHIFT_FW_FREE_TAIL_V1_8197F)
#define BITS_FW_FREE_TAIL_V1_8197F \
(BIT_MASK_FW_FREE_TAIL_V1_8197F << BIT_SHIFT_FW_FREE_TAIL_V1_8197F)
#define BIT_CLEAR_FW_FREE_TAIL_V1_8197F(x) ((x) & (~BITS_FW_FREE_TAIL_V1_8197F))
#define BIT_GET_FW_FREE_TAIL_V1_8197F(x) \
(((x) >> BIT_SHIFT_FW_FREE_TAIL_V1_8197F) & \
BIT_MASK_FW_FREE_TAIL_V1_8197F)
#define BIT_SET_FW_FREE_TAIL_V1_8197F(x, v) \
(BIT_CLEAR_FW_FREE_TAIL_V1_8197F(x) | BIT_FW_FREE_TAIL_V1_8197F(v))
/* 2 REG_FWHW_TXQ_CTRL_8197F */
#define BIT_RTS_LIMIT_IN_OFDM_8197F BIT(23)
#define BIT_EN_BCNQ_DL_8197F BIT(22)
#define BIT_EN_RD_RESP_NAV_BK_8197F BIT(21)
#define BIT_EN_WR_FREE_TAIL_8197F BIT(20)
#define BIT_SHIFT_EN_QUEUE_RPT_8197F 8
#define BIT_MASK_EN_QUEUE_RPT_8197F 0xff
#define BIT_EN_QUEUE_RPT_8197F(x) \
(((x) & BIT_MASK_EN_QUEUE_RPT_8197F) << BIT_SHIFT_EN_QUEUE_RPT_8197F)
#define BITS_EN_QUEUE_RPT_8197F \
(BIT_MASK_EN_QUEUE_RPT_8197F << BIT_SHIFT_EN_QUEUE_RPT_8197F)
#define BIT_CLEAR_EN_QUEUE_RPT_8197F(x) ((x) & (~BITS_EN_QUEUE_RPT_8197F))
#define BIT_GET_EN_QUEUE_RPT_8197F(x) \
(((x) >> BIT_SHIFT_EN_QUEUE_RPT_8197F) & BIT_MASK_EN_QUEUE_RPT_8197F)
#define BIT_SET_EN_QUEUE_RPT_8197F(x, v) \
(BIT_CLEAR_EN_QUEUE_RPT_8197F(x) | BIT_EN_QUEUE_RPT_8197F(v))
#define BIT_EN_RTY_BK_8197F BIT(7)
#define BIT_EN_USE_INI_RAT_8197F BIT(6)
#define BIT_EN_RTS_NAV_BK_8197F BIT(5)
#define BIT_DIS_SSN_CHECK_8197F BIT(4)
#define BIT_MACID_MATCH_RTS_8197F BIT(3)
#define BIT_EN_BCN_TRXRPT_V1_8197F BIT(2)
#define BIT_R_EN_FTMRPT_8197F BIT(1)
#define BIT_R_BMC_NAV_PROTECT_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
#define BIT__R_EN_RTY_BK_COD_8197F BIT(2)
#define BIT_SHIFT__R_DATA_FALLBACK_SEL_8197F 0
#define BIT_MASK__R_DATA_FALLBACK_SEL_8197F 0x3
#define BIT__R_DATA_FALLBACK_SEL_8197F(x) \
(((x) & BIT_MASK__R_DATA_FALLBACK_SEL_8197F) \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8197F)
#define BITS__R_DATA_FALLBACK_SEL_8197F \
(BIT_MASK__R_DATA_FALLBACK_SEL_8197F \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8197F)
#define BIT_CLEAR__R_DATA_FALLBACK_SEL_8197F(x) \
((x) & (~BITS__R_DATA_FALLBACK_SEL_8197F))
#define BIT_GET__R_DATA_FALLBACK_SEL_8197F(x) \
(((x) >> BIT_SHIFT__R_DATA_FALLBACK_SEL_8197F) & \
BIT_MASK__R_DATA_FALLBACK_SEL_8197F)
#define BIT_SET__R_DATA_FALLBACK_SEL_8197F(x, v) \
(BIT_CLEAR__R_DATA_FALLBACK_SEL_8197F(x) | \
BIT__R_DATA_FALLBACK_SEL_8197F(v))
/* 2 REG_BCNQ_BDNY_V1_8197F */
#define BIT_SHIFT_BCNQ_PGBNDY_V1_8197F 0
#define BIT_MASK_BCNQ_PGBNDY_V1_8197F 0xfff
#define BIT_BCNQ_PGBNDY_V1_8197F(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_V1_8197F) \
<< BIT_SHIFT_BCNQ_PGBNDY_V1_8197F)
#define BITS_BCNQ_PGBNDY_V1_8197F \
(BIT_MASK_BCNQ_PGBNDY_V1_8197F << BIT_SHIFT_BCNQ_PGBNDY_V1_8197F)
#define BIT_CLEAR_BCNQ_PGBNDY_V1_8197F(x) ((x) & (~BITS_BCNQ_PGBNDY_V1_8197F))
#define BIT_GET_BCNQ_PGBNDY_V1_8197F(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_V1_8197F) & \
BIT_MASK_BCNQ_PGBNDY_V1_8197F)
#define BIT_SET_BCNQ_PGBNDY_V1_8197F(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_V1_8197F(x) | BIT_BCNQ_PGBNDY_V1_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_LIFETIME_EN_8197F */
#define BIT_BT_INT_CPU_8197F BIT(7)
#define BIT_BT_INT_PTA_8197F BIT(6)
#define BIT_EN_CTRL_RTYBIT_8197F BIT(4)
#define BIT_LIFETIME_BK_EN_8197F BIT(3)
#define BIT_LIFETIME_BE_EN_8197F BIT(2)
#define BIT_LIFETIME_VI_EN_8197F BIT(1)
#define BIT_LIFETIME_VO_EN_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SPEC_SIFS_8197F */
#define BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8197F 8
#define BIT_MASK_SPEC_SIFS_OFDM_PTCL_8197F 0xff
#define BIT_SPEC_SIFS_OFDM_PTCL_8197F(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_PTCL_8197F) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8197F)
#define BITS_SPEC_SIFS_OFDM_PTCL_8197F \
(BIT_MASK_SPEC_SIFS_OFDM_PTCL_8197F \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8197F)
#define BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8197F(x) \
((x) & (~BITS_SPEC_SIFS_OFDM_PTCL_8197F))
#define BIT_GET_SPEC_SIFS_OFDM_PTCL_8197F(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8197F) & \
BIT_MASK_SPEC_SIFS_OFDM_PTCL_8197F)
#define BIT_SET_SPEC_SIFS_OFDM_PTCL_8197F(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8197F(x) | \
BIT_SPEC_SIFS_OFDM_PTCL_8197F(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8197F 0
#define BIT_MASK_SPEC_SIFS_CCK_PTCL_8197F 0xff
#define BIT_SPEC_SIFS_CCK_PTCL_8197F(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_PTCL_8197F) \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8197F)
#define BITS_SPEC_SIFS_CCK_PTCL_8197F \
(BIT_MASK_SPEC_SIFS_CCK_PTCL_8197F \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8197F)
#define BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8197F(x) \
((x) & (~BITS_SPEC_SIFS_CCK_PTCL_8197F))
#define BIT_GET_SPEC_SIFS_CCK_PTCL_8197F(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8197F) & \
BIT_MASK_SPEC_SIFS_CCK_PTCL_8197F)
#define BIT_SET_SPEC_SIFS_CCK_PTCL_8197F(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8197F(x) | \
BIT_SPEC_SIFS_CCK_PTCL_8197F(v))
/* 2 REG_RETRY_LIMIT_8197F */
#define BIT_SHIFT_SRL_8197F 8
#define BIT_MASK_SRL_8197F 0x3f
#define BIT_SRL_8197F(x) (((x) & BIT_MASK_SRL_8197F) << BIT_SHIFT_SRL_8197F)
#define BITS_SRL_8197F (BIT_MASK_SRL_8197F << BIT_SHIFT_SRL_8197F)
#define BIT_CLEAR_SRL_8197F(x) ((x) & (~BITS_SRL_8197F))
#define BIT_GET_SRL_8197F(x) (((x) >> BIT_SHIFT_SRL_8197F) & BIT_MASK_SRL_8197F)
#define BIT_SET_SRL_8197F(x, v) (BIT_CLEAR_SRL_8197F(x) | BIT_SRL_8197F(v))
#define BIT_SHIFT_LRL_8197F 0
#define BIT_MASK_LRL_8197F 0x3f
#define BIT_LRL_8197F(x) (((x) & BIT_MASK_LRL_8197F) << BIT_SHIFT_LRL_8197F)
#define BITS_LRL_8197F (BIT_MASK_LRL_8197F << BIT_SHIFT_LRL_8197F)
#define BIT_CLEAR_LRL_8197F(x) ((x) & (~BITS_LRL_8197F))
#define BIT_GET_LRL_8197F(x) (((x) >> BIT_SHIFT_LRL_8197F) & BIT_MASK_LRL_8197F)
#define BIT_SET_LRL_8197F(x, v) (BIT_CLEAR_LRL_8197F(x) | BIT_LRL_8197F(v))
/* 2 REG_TXBF_CTRL_8197F */
#define BIT_R_ENABLE_NDPA_8197F BIT(31)
#define BIT_USE_NDPA_PARAMETER_8197F BIT(30)
#define BIT_R_PROP_TXBF_8197F BIT(29)
#define BIT_R_EN_NDPA_INT_8197F BIT(28)
#define BIT_R_TXBF1_80M_8197F BIT(27)
#define BIT_R_TXBF1_40M_8197F BIT(26)
#define BIT_R_TXBF1_20M_8197F BIT(25)
#define BIT_SHIFT_R_TXBF1_AID_8197F 16
#define BIT_MASK_R_TXBF1_AID_8197F 0x1ff
#define BIT_R_TXBF1_AID_8197F(x) \
(((x) & BIT_MASK_R_TXBF1_AID_8197F) << BIT_SHIFT_R_TXBF1_AID_8197F)
#define BITS_R_TXBF1_AID_8197F \
(BIT_MASK_R_TXBF1_AID_8197F << BIT_SHIFT_R_TXBF1_AID_8197F)
#define BIT_CLEAR_R_TXBF1_AID_8197F(x) ((x) & (~BITS_R_TXBF1_AID_8197F))
#define BIT_GET_R_TXBF1_AID_8197F(x) \
(((x) >> BIT_SHIFT_R_TXBF1_AID_8197F) & BIT_MASK_R_TXBF1_AID_8197F)
#define BIT_SET_R_TXBF1_AID_8197F(x, v) \
(BIT_CLEAR_R_TXBF1_AID_8197F(x) | BIT_R_TXBF1_AID_8197F(v))
#define BIT_DIS_NDP_BFEN_8197F BIT(15)
#define BIT_R_TXBCN_NOBLOCK_NDP_8197F BIT(14)
#define BIT_R_TXBF0_80M_8197F BIT(11)
#define BIT_R_TXBF0_40M_8197F BIT(10)
#define BIT_R_TXBF0_20M_8197F BIT(9)
#define BIT_SHIFT_R_TXBF0_AID_8197F 0
#define BIT_MASK_R_TXBF0_AID_8197F 0x1ff
#define BIT_R_TXBF0_AID_8197F(x) \
(((x) & BIT_MASK_R_TXBF0_AID_8197F) << BIT_SHIFT_R_TXBF0_AID_8197F)
#define BITS_R_TXBF0_AID_8197F \
(BIT_MASK_R_TXBF0_AID_8197F << BIT_SHIFT_R_TXBF0_AID_8197F)
#define BIT_CLEAR_R_TXBF0_AID_8197F(x) ((x) & (~BITS_R_TXBF0_AID_8197F))
#define BIT_GET_R_TXBF0_AID_8197F(x) \
(((x) >> BIT_SHIFT_R_TXBF0_AID_8197F) & BIT_MASK_R_TXBF0_AID_8197F)
#define BIT_SET_R_TXBF0_AID_8197F(x, v) \
(BIT_CLEAR_R_TXBF0_AID_8197F(x) | BIT_R_TXBF0_AID_8197F(v))
/* 2 REG_DARFRC_8197F */
#define BIT_SHIFT_DARF_RC8_V2_8197F (56 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC8_V2_8197F 0x3f
#define BIT_DARF_RC8_V2_8197F(x) \
(((x) & BIT_MASK_DARF_RC8_V2_8197F) << BIT_SHIFT_DARF_RC8_V2_8197F)
#define BITS_DARF_RC8_V2_8197F \
(BIT_MASK_DARF_RC8_V2_8197F << BIT_SHIFT_DARF_RC8_V2_8197F)
#define BIT_CLEAR_DARF_RC8_V2_8197F(x) ((x) & (~BITS_DARF_RC8_V2_8197F))
#define BIT_GET_DARF_RC8_V2_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC8_V2_8197F) & BIT_MASK_DARF_RC8_V2_8197F)
#define BIT_SET_DARF_RC8_V2_8197F(x, v) \
(BIT_CLEAR_DARF_RC8_V2_8197F(x) | BIT_DARF_RC8_V2_8197F(v))
#define BIT_SHIFT_DARF_RC7_V2_8197F (48 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC7_V2_8197F 0x3f
#define BIT_DARF_RC7_V2_8197F(x) \
(((x) & BIT_MASK_DARF_RC7_V2_8197F) << BIT_SHIFT_DARF_RC7_V2_8197F)
#define BITS_DARF_RC7_V2_8197F \
(BIT_MASK_DARF_RC7_V2_8197F << BIT_SHIFT_DARF_RC7_V2_8197F)
#define BIT_CLEAR_DARF_RC7_V2_8197F(x) ((x) & (~BITS_DARF_RC7_V2_8197F))
#define BIT_GET_DARF_RC7_V2_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC7_V2_8197F) & BIT_MASK_DARF_RC7_V2_8197F)
#define BIT_SET_DARF_RC7_V2_8197F(x, v) \
(BIT_CLEAR_DARF_RC7_V2_8197F(x) | BIT_DARF_RC7_V2_8197F(v))
#define BIT_SHIFT_DARF_RC6_V2_8197F (40 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC6_V2_8197F 0x3f
#define BIT_DARF_RC6_V2_8197F(x) \
(((x) & BIT_MASK_DARF_RC6_V2_8197F) << BIT_SHIFT_DARF_RC6_V2_8197F)
#define BITS_DARF_RC6_V2_8197F \
(BIT_MASK_DARF_RC6_V2_8197F << BIT_SHIFT_DARF_RC6_V2_8197F)
#define BIT_CLEAR_DARF_RC6_V2_8197F(x) ((x) & (~BITS_DARF_RC6_V2_8197F))
#define BIT_GET_DARF_RC6_V2_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC6_V2_8197F) & BIT_MASK_DARF_RC6_V2_8197F)
#define BIT_SET_DARF_RC6_V2_8197F(x, v) \
(BIT_CLEAR_DARF_RC6_V2_8197F(x) | BIT_DARF_RC6_V2_8197F(v))
#define BIT_SHIFT_DARF_RC5_V2_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC5_V2_8197F 0x3f
#define BIT_DARF_RC5_V2_8197F(x) \
(((x) & BIT_MASK_DARF_RC5_V2_8197F) << BIT_SHIFT_DARF_RC5_V2_8197F)
#define BITS_DARF_RC5_V2_8197F \
(BIT_MASK_DARF_RC5_V2_8197F << BIT_SHIFT_DARF_RC5_V2_8197F)
#define BIT_CLEAR_DARF_RC5_V2_8197F(x) ((x) & (~BITS_DARF_RC5_V2_8197F))
#define BIT_GET_DARF_RC5_V2_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC5_V2_8197F) & BIT_MASK_DARF_RC5_V2_8197F)
#define BIT_SET_DARF_RC5_V2_8197F(x, v) \
(BIT_CLEAR_DARF_RC5_V2_8197F(x) | BIT_DARF_RC5_V2_8197F(v))
#define BIT_SHIFT_DARF_RC4_V1_8197F 24
#define BIT_MASK_DARF_RC4_V1_8197F 0x3f
#define BIT_DARF_RC4_V1_8197F(x) \
(((x) & BIT_MASK_DARF_RC4_V1_8197F) << BIT_SHIFT_DARF_RC4_V1_8197F)
#define BITS_DARF_RC4_V1_8197F \
(BIT_MASK_DARF_RC4_V1_8197F << BIT_SHIFT_DARF_RC4_V1_8197F)
#define BIT_CLEAR_DARF_RC4_V1_8197F(x) ((x) & (~BITS_DARF_RC4_V1_8197F))
#define BIT_GET_DARF_RC4_V1_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC4_V1_8197F) & BIT_MASK_DARF_RC4_V1_8197F)
#define BIT_SET_DARF_RC4_V1_8197F(x, v) \
(BIT_CLEAR_DARF_RC4_V1_8197F(x) | BIT_DARF_RC4_V1_8197F(v))
#define BIT_SHIFT_DARF_RC3_V1_8197F 16
#define BIT_MASK_DARF_RC3_V1_8197F 0x3f
#define BIT_DARF_RC3_V1_8197F(x) \
(((x) & BIT_MASK_DARF_RC3_V1_8197F) << BIT_SHIFT_DARF_RC3_V1_8197F)
#define BITS_DARF_RC3_V1_8197F \
(BIT_MASK_DARF_RC3_V1_8197F << BIT_SHIFT_DARF_RC3_V1_8197F)
#define BIT_CLEAR_DARF_RC3_V1_8197F(x) ((x) & (~BITS_DARF_RC3_V1_8197F))
#define BIT_GET_DARF_RC3_V1_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC3_V1_8197F) & BIT_MASK_DARF_RC3_V1_8197F)
#define BIT_SET_DARF_RC3_V1_8197F(x, v) \
(BIT_CLEAR_DARF_RC3_V1_8197F(x) | BIT_DARF_RC3_V1_8197F(v))
#define BIT_SHIFT_DARF_RC2_V1_8197F 8
#define BIT_MASK_DARF_RC2_V1_8197F 0x3f
#define BIT_DARF_RC2_V1_8197F(x) \
(((x) & BIT_MASK_DARF_RC2_V1_8197F) << BIT_SHIFT_DARF_RC2_V1_8197F)
#define BITS_DARF_RC2_V1_8197F \
(BIT_MASK_DARF_RC2_V1_8197F << BIT_SHIFT_DARF_RC2_V1_8197F)
#define BIT_CLEAR_DARF_RC2_V1_8197F(x) ((x) & (~BITS_DARF_RC2_V1_8197F))
#define BIT_GET_DARF_RC2_V1_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC2_V1_8197F) & BIT_MASK_DARF_RC2_V1_8197F)
#define BIT_SET_DARF_RC2_V1_8197F(x, v) \
(BIT_CLEAR_DARF_RC2_V1_8197F(x) | BIT_DARF_RC2_V1_8197F(v))
#define BIT_SHIFT_DARF_RC1_V1_8197F 0
#define BIT_MASK_DARF_RC1_V1_8197F 0x3f
#define BIT_DARF_RC1_V1_8197F(x) \
(((x) & BIT_MASK_DARF_RC1_V1_8197F) << BIT_SHIFT_DARF_RC1_V1_8197F)
#define BITS_DARF_RC1_V1_8197F \
(BIT_MASK_DARF_RC1_V1_8197F << BIT_SHIFT_DARF_RC1_V1_8197F)
#define BIT_CLEAR_DARF_RC1_V1_8197F(x) ((x) & (~BITS_DARF_RC1_V1_8197F))
#define BIT_GET_DARF_RC1_V1_8197F(x) \
(((x) >> BIT_SHIFT_DARF_RC1_V1_8197F) & BIT_MASK_DARF_RC1_V1_8197F)
#define BIT_SET_DARF_RC1_V1_8197F(x, v) \
(BIT_CLEAR_DARF_RC1_V1_8197F(x) | BIT_DARF_RC1_V1_8197F(v))
/* 2 REG_RARFRC_8197F */
#define BIT_SHIFT_RARF_RC8_8197F (56 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC8_8197F 0x1f
#define BIT_RARF_RC8_8197F(x) \
(((x) & BIT_MASK_RARF_RC8_8197F) << BIT_SHIFT_RARF_RC8_8197F)
#define BITS_RARF_RC8_8197F \
(BIT_MASK_RARF_RC8_8197F << BIT_SHIFT_RARF_RC8_8197F)
#define BIT_CLEAR_RARF_RC8_8197F(x) ((x) & (~BITS_RARF_RC8_8197F))
#define BIT_GET_RARF_RC8_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC8_8197F) & BIT_MASK_RARF_RC8_8197F)
#define BIT_SET_RARF_RC8_8197F(x, v) \
(BIT_CLEAR_RARF_RC8_8197F(x) | BIT_RARF_RC8_8197F(v))
#define BIT_SHIFT_RARF_RC7_8197F (48 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC7_8197F 0x1f
#define BIT_RARF_RC7_8197F(x) \
(((x) & BIT_MASK_RARF_RC7_8197F) << BIT_SHIFT_RARF_RC7_8197F)
#define BITS_RARF_RC7_8197F \
(BIT_MASK_RARF_RC7_8197F << BIT_SHIFT_RARF_RC7_8197F)
#define BIT_CLEAR_RARF_RC7_8197F(x) ((x) & (~BITS_RARF_RC7_8197F))
#define BIT_GET_RARF_RC7_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC7_8197F) & BIT_MASK_RARF_RC7_8197F)
#define BIT_SET_RARF_RC7_8197F(x, v) \
(BIT_CLEAR_RARF_RC7_8197F(x) | BIT_RARF_RC7_8197F(v))
#define BIT_SHIFT_RARF_RC6_8197F (40 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC6_8197F 0x1f
#define BIT_RARF_RC6_8197F(x) \
(((x) & BIT_MASK_RARF_RC6_8197F) << BIT_SHIFT_RARF_RC6_8197F)
#define BITS_RARF_RC6_8197F \
(BIT_MASK_RARF_RC6_8197F << BIT_SHIFT_RARF_RC6_8197F)
#define BIT_CLEAR_RARF_RC6_8197F(x) ((x) & (~BITS_RARF_RC6_8197F))
#define BIT_GET_RARF_RC6_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC6_8197F) & BIT_MASK_RARF_RC6_8197F)
#define BIT_SET_RARF_RC6_8197F(x, v) \
(BIT_CLEAR_RARF_RC6_8197F(x) | BIT_RARF_RC6_8197F(v))
#define BIT_SHIFT_RARF_RC5_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC5_8197F 0x1f
#define BIT_RARF_RC5_8197F(x) \
(((x) & BIT_MASK_RARF_RC5_8197F) << BIT_SHIFT_RARF_RC5_8197F)
#define BITS_RARF_RC5_8197F \
(BIT_MASK_RARF_RC5_8197F << BIT_SHIFT_RARF_RC5_8197F)
#define BIT_CLEAR_RARF_RC5_8197F(x) ((x) & (~BITS_RARF_RC5_8197F))
#define BIT_GET_RARF_RC5_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC5_8197F) & BIT_MASK_RARF_RC5_8197F)
#define BIT_SET_RARF_RC5_8197F(x, v) \
(BIT_CLEAR_RARF_RC5_8197F(x) | BIT_RARF_RC5_8197F(v))
#define BIT_SHIFT_RARF_RC4_8197F 24
#define BIT_MASK_RARF_RC4_8197F 0x1f
#define BIT_RARF_RC4_8197F(x) \
(((x) & BIT_MASK_RARF_RC4_8197F) << BIT_SHIFT_RARF_RC4_8197F)
#define BITS_RARF_RC4_8197F \
(BIT_MASK_RARF_RC4_8197F << BIT_SHIFT_RARF_RC4_8197F)
#define BIT_CLEAR_RARF_RC4_8197F(x) ((x) & (~BITS_RARF_RC4_8197F))
#define BIT_GET_RARF_RC4_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC4_8197F) & BIT_MASK_RARF_RC4_8197F)
#define BIT_SET_RARF_RC4_8197F(x, v) \
(BIT_CLEAR_RARF_RC4_8197F(x) | BIT_RARF_RC4_8197F(v))
#define BIT_SHIFT_RARF_RC3_8197F 16
#define BIT_MASK_RARF_RC3_8197F 0x1f
#define BIT_RARF_RC3_8197F(x) \
(((x) & BIT_MASK_RARF_RC3_8197F) << BIT_SHIFT_RARF_RC3_8197F)
#define BITS_RARF_RC3_8197F \
(BIT_MASK_RARF_RC3_8197F << BIT_SHIFT_RARF_RC3_8197F)
#define BIT_CLEAR_RARF_RC3_8197F(x) ((x) & (~BITS_RARF_RC3_8197F))
#define BIT_GET_RARF_RC3_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC3_8197F) & BIT_MASK_RARF_RC3_8197F)
#define BIT_SET_RARF_RC3_8197F(x, v) \
(BIT_CLEAR_RARF_RC3_8197F(x) | BIT_RARF_RC3_8197F(v))
#define BIT_SHIFT_RARF_RC2_8197F 8
#define BIT_MASK_RARF_RC2_8197F 0x1f
#define BIT_RARF_RC2_8197F(x) \
(((x) & BIT_MASK_RARF_RC2_8197F) << BIT_SHIFT_RARF_RC2_8197F)
#define BITS_RARF_RC2_8197F \
(BIT_MASK_RARF_RC2_8197F << BIT_SHIFT_RARF_RC2_8197F)
#define BIT_CLEAR_RARF_RC2_8197F(x) ((x) & (~BITS_RARF_RC2_8197F))
#define BIT_GET_RARF_RC2_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC2_8197F) & BIT_MASK_RARF_RC2_8197F)
#define BIT_SET_RARF_RC2_8197F(x, v) \
(BIT_CLEAR_RARF_RC2_8197F(x) | BIT_RARF_RC2_8197F(v))
#define BIT_SHIFT_RARF_RC1_8197F 0
#define BIT_MASK_RARF_RC1_8197F 0x1f
#define BIT_RARF_RC1_8197F(x) \
(((x) & BIT_MASK_RARF_RC1_8197F) << BIT_SHIFT_RARF_RC1_8197F)
#define BITS_RARF_RC1_8197F \
(BIT_MASK_RARF_RC1_8197F << BIT_SHIFT_RARF_RC1_8197F)
#define BIT_CLEAR_RARF_RC1_8197F(x) ((x) & (~BITS_RARF_RC1_8197F))
#define BIT_GET_RARF_RC1_8197F(x) \
(((x) >> BIT_SHIFT_RARF_RC1_8197F) & BIT_MASK_RARF_RC1_8197F)
#define BIT_SET_RARF_RC1_8197F(x, v) \
(BIT_CLEAR_RARF_RC1_8197F(x) | BIT_RARF_RC1_8197F(v))
/* 2 REG_RRSR_8197F */
#define BIT_EN_VHTBW_FALL_8197F BIT(31)
#define BIT_EN_HTBW_FALL_8197F BIT(30)
#define BIT_SHIFT_RRSR_RSC_8197F 21
#define BIT_MASK_RRSR_RSC_8197F 0x3
#define BIT_RRSR_RSC_8197F(x) \
(((x) & BIT_MASK_RRSR_RSC_8197F) << BIT_SHIFT_RRSR_RSC_8197F)
#define BITS_RRSR_RSC_8197F \
(BIT_MASK_RRSR_RSC_8197F << BIT_SHIFT_RRSR_RSC_8197F)
#define BIT_CLEAR_RRSR_RSC_8197F(x) ((x) & (~BITS_RRSR_RSC_8197F))
#define BIT_GET_RRSR_RSC_8197F(x) \
(((x) >> BIT_SHIFT_RRSR_RSC_8197F) & BIT_MASK_RRSR_RSC_8197F)
#define BIT_SET_RRSR_RSC_8197F(x, v) \
(BIT_CLEAR_RRSR_RSC_8197F(x) | BIT_RRSR_RSC_8197F(v))
#define BIT_RRSR_BW_8197F BIT(20)
#define BIT_SHIFT_RRSC_BITMAP_8197F 0
#define BIT_MASK_RRSC_BITMAP_8197F 0xfffff
#define BIT_RRSC_BITMAP_8197F(x) \
(((x) & BIT_MASK_RRSC_BITMAP_8197F) << BIT_SHIFT_RRSC_BITMAP_8197F)
#define BITS_RRSC_BITMAP_8197F \
(BIT_MASK_RRSC_BITMAP_8197F << BIT_SHIFT_RRSC_BITMAP_8197F)
#define BIT_CLEAR_RRSC_BITMAP_8197F(x) ((x) & (~BITS_RRSC_BITMAP_8197F))
#define BIT_GET_RRSC_BITMAP_8197F(x) \
(((x) >> BIT_SHIFT_RRSC_BITMAP_8197F) & BIT_MASK_RRSC_BITMAP_8197F)
#define BIT_SET_RRSC_BITMAP_8197F(x, v) \
(BIT_CLEAR_RRSC_BITMAP_8197F(x) | BIT_RRSC_BITMAP_8197F(v))
/* 2 REG_ARFR0_8197F */
#define BIT_SHIFT_ARFR0_V1_8197F 0
#define BIT_MASK_ARFR0_V1_8197F 0xffffffffffffffffL
#define BIT_ARFR0_V1_8197F(x) \
(((x) & BIT_MASK_ARFR0_V1_8197F) << BIT_SHIFT_ARFR0_V1_8197F)
#define BITS_ARFR0_V1_8197F \
(BIT_MASK_ARFR0_V1_8197F << BIT_SHIFT_ARFR0_V1_8197F)
#define BIT_CLEAR_ARFR0_V1_8197F(x) ((x) & (~BITS_ARFR0_V1_8197F))
#define BIT_GET_ARFR0_V1_8197F(x) \
(((x) >> BIT_SHIFT_ARFR0_V1_8197F) & BIT_MASK_ARFR0_V1_8197F)
#define BIT_SET_ARFR0_V1_8197F(x, v) \
(BIT_CLEAR_ARFR0_V1_8197F(x) | BIT_ARFR0_V1_8197F(v))
/* 2 REG_ARFR1_V1_8197F */
#define BIT_SHIFT_ARFR1_V1_8197F 0
#define BIT_MASK_ARFR1_V1_8197F 0xffffffffffffffffL
#define BIT_ARFR1_V1_8197F(x) \
(((x) & BIT_MASK_ARFR1_V1_8197F) << BIT_SHIFT_ARFR1_V1_8197F)
#define BITS_ARFR1_V1_8197F \
(BIT_MASK_ARFR1_V1_8197F << BIT_SHIFT_ARFR1_V1_8197F)
#define BIT_CLEAR_ARFR1_V1_8197F(x) ((x) & (~BITS_ARFR1_V1_8197F))
#define BIT_GET_ARFR1_V1_8197F(x) \
(((x) >> BIT_SHIFT_ARFR1_V1_8197F) & BIT_MASK_ARFR1_V1_8197F)
#define BIT_SET_ARFR1_V1_8197F(x, v) \
(BIT_CLEAR_ARFR1_V1_8197F(x) | BIT_ARFR1_V1_8197F(v))
/* 2 REG_CCK_CHECK_8197F */
#define BIT_CHECK_CCK_EN_8197F BIT(7)
#define BIT_EN_BCN_PKT_REL_8197F BIT(6)
#define BIT_BCN_PORT_SEL_8197F BIT(5)
#define BIT_MOREDATA_BYPASS_8197F BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_8197F BIT(3)
#define BIT_R_EN_SET_MOREDATA_8197F BIT(2)
#define BIT__R_DIS_CLEAR_MACID_RELEASE_8197F BIT(1)
#define BIT__R_MACID_RELEASE_EN_8197F BIT(0)
/* 2 REG_AMPDU_MAX_TIME_V1_8197F */
#define BIT_SHIFT_AMPDU_MAX_TIME_8197F 0
#define BIT_MASK_AMPDU_MAX_TIME_8197F 0xff
#define BIT_AMPDU_MAX_TIME_8197F(x) \
(((x) & BIT_MASK_AMPDU_MAX_TIME_8197F) \
<< BIT_SHIFT_AMPDU_MAX_TIME_8197F)
#define BITS_AMPDU_MAX_TIME_8197F \
(BIT_MASK_AMPDU_MAX_TIME_8197F << BIT_SHIFT_AMPDU_MAX_TIME_8197F)
#define BIT_CLEAR_AMPDU_MAX_TIME_8197F(x) ((x) & (~BITS_AMPDU_MAX_TIME_8197F))
#define BIT_GET_AMPDU_MAX_TIME_8197F(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_TIME_8197F) & \
BIT_MASK_AMPDU_MAX_TIME_8197F)
#define BIT_SET_AMPDU_MAX_TIME_8197F(x, v) \
(BIT_CLEAR_AMPDU_MAX_TIME_8197F(x) | BIT_AMPDU_MAX_TIME_8197F(v))
/* 2 REG_BCNQ1_BDNY_V1_8197F */
#define BIT_SHIFT_BCNQ1_PGBNDY_V1_8197F 0
#define BIT_MASK_BCNQ1_PGBNDY_V1_8197F 0xfff
#define BIT_BCNQ1_PGBNDY_V1_8197F(x) \
(((x) & BIT_MASK_BCNQ1_PGBNDY_V1_8197F) \
<< BIT_SHIFT_BCNQ1_PGBNDY_V1_8197F)
#define BITS_BCNQ1_PGBNDY_V1_8197F \
(BIT_MASK_BCNQ1_PGBNDY_V1_8197F << BIT_SHIFT_BCNQ1_PGBNDY_V1_8197F)
#define BIT_CLEAR_BCNQ1_PGBNDY_V1_8197F(x) ((x) & (~BITS_BCNQ1_PGBNDY_V1_8197F))
#define BIT_GET_BCNQ1_PGBNDY_V1_8197F(x) \
(((x) >> BIT_SHIFT_BCNQ1_PGBNDY_V1_8197F) & \
BIT_MASK_BCNQ1_PGBNDY_V1_8197F)
#define BIT_SET_BCNQ1_PGBNDY_V1_8197F(x, v) \
(BIT_CLEAR_BCNQ1_PGBNDY_V1_8197F(x) | BIT_BCNQ1_PGBNDY_V1_8197F(v))
/* 2 REG_AMPDU_MAX_LENGTH_8197F */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_8197F 0
#define BIT_MASK_AMPDU_MAX_LENGTH_8197F 0xffffffffL
#define BIT_AMPDU_MAX_LENGTH_8197F(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_8197F) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_8197F)
#define BITS_AMPDU_MAX_LENGTH_8197F \
(BIT_MASK_AMPDU_MAX_LENGTH_8197F << BIT_SHIFT_AMPDU_MAX_LENGTH_8197F)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_8197F(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_8197F))
#define BIT_GET_AMPDU_MAX_LENGTH_8197F(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_8197F) & \
BIT_MASK_AMPDU_MAX_LENGTH_8197F)
#define BIT_SET_AMPDU_MAX_LENGTH_8197F(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_8197F(x) | BIT_AMPDU_MAX_LENGTH_8197F(v))
/* 2 REG_ACQ_STOP_8197F */
#define BIT_AC7Q_STOP_8197F BIT(7)
#define BIT_AC6Q_STOP_8197F BIT(6)
#define BIT_AC5Q_STOP_8197F BIT(5)
#define BIT_AC4Q_STOP_8197F BIT(4)
#define BIT_AC3Q_STOP_8197F BIT(3)
#define BIT_AC2Q_STOP_8197F BIT(2)
#define BIT_AC1Q_STOP_8197F BIT(1)
#define BIT_AC0Q_STOP_8197F BIT(0)
/* 2 REG_NDPA_RATE_8197F */
#define BIT_SHIFT_R_NDPA_RATE_V1_8197F 0
#define BIT_MASK_R_NDPA_RATE_V1_8197F 0xff
#define BIT_R_NDPA_RATE_V1_8197F(x) \
(((x) & BIT_MASK_R_NDPA_RATE_V1_8197F) \
<< BIT_SHIFT_R_NDPA_RATE_V1_8197F)
#define BITS_R_NDPA_RATE_V1_8197F \
(BIT_MASK_R_NDPA_RATE_V1_8197F << BIT_SHIFT_R_NDPA_RATE_V1_8197F)
#define BIT_CLEAR_R_NDPA_RATE_V1_8197F(x) ((x) & (~BITS_R_NDPA_RATE_V1_8197F))
#define BIT_GET_R_NDPA_RATE_V1_8197F(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE_V1_8197F) & \
BIT_MASK_R_NDPA_RATE_V1_8197F)
#define BIT_SET_R_NDPA_RATE_V1_8197F(x, v) \
(BIT_CLEAR_R_NDPA_RATE_V1_8197F(x) | BIT_R_NDPA_RATE_V1_8197F(v))
/* 2 REG_TX_HANG_CTRL_8197F */
#define BIT_R_EN_GNT_BT_AWAKE_8197F BIT(3)
#define BIT_EN_EOF_V1_8197F BIT(2)
#define BIT_DIS_OQT_BLOCK_8197F BIT(1)
#define BIT_SEARCH_QUEUE_EN_8197F BIT(0)
/* 2 REG_NDPA_OPT_CTRL_8197F */
#define BIT_R_DIS_MACID_RELEASE_RTY_8197F BIT(5)
#define BIT_SHIFT_BW_SIGTA_8197F 3
#define BIT_MASK_BW_SIGTA_8197F 0x3
#define BIT_BW_SIGTA_8197F(x) \
(((x) & BIT_MASK_BW_SIGTA_8197F) << BIT_SHIFT_BW_SIGTA_8197F)
#define BITS_BW_SIGTA_8197F \
(BIT_MASK_BW_SIGTA_8197F << BIT_SHIFT_BW_SIGTA_8197F)
#define BIT_CLEAR_BW_SIGTA_8197F(x) ((x) & (~BITS_BW_SIGTA_8197F))
#define BIT_GET_BW_SIGTA_8197F(x) \
(((x) >> BIT_SHIFT_BW_SIGTA_8197F) & BIT_MASK_BW_SIGTA_8197F)
#define BIT_SET_BW_SIGTA_8197F(x, v) \
(BIT_CLEAR_BW_SIGTA_8197F(x) | BIT_BW_SIGTA_8197F(v))
#define BIT_EN_BAR_SIGTA_8197F BIT(2)
#define BIT_SHIFT_R_NDPA_BW_8197F 0
#define BIT_MASK_R_NDPA_BW_8197F 0x3
#define BIT_R_NDPA_BW_8197F(x) \
(((x) & BIT_MASK_R_NDPA_BW_8197F) << BIT_SHIFT_R_NDPA_BW_8197F)
#define BITS_R_NDPA_BW_8197F \
(BIT_MASK_R_NDPA_BW_8197F << BIT_SHIFT_R_NDPA_BW_8197F)
#define BIT_CLEAR_R_NDPA_BW_8197F(x) ((x) & (~BITS_R_NDPA_BW_8197F))
#define BIT_GET_R_NDPA_BW_8197F(x) \
(((x) >> BIT_SHIFT_R_NDPA_BW_8197F) & BIT_MASK_R_NDPA_BW_8197F)
#define BIT_SET_R_NDPA_BW_8197F(x, v) \
(BIT_CLEAR_R_NDPA_BW_8197F(x) | BIT_R_NDPA_BW_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_RD_RESP_PKT_TH_8197F */
#define BIT_SHIFT_RD_RESP_PKT_TH_V1_8197F 0
#define BIT_MASK_RD_RESP_PKT_TH_V1_8197F 0x3f
#define BIT_RD_RESP_PKT_TH_V1_8197F(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH_V1_8197F) \
<< BIT_SHIFT_RD_RESP_PKT_TH_V1_8197F)
#define BITS_RD_RESP_PKT_TH_V1_8197F \
(BIT_MASK_RD_RESP_PKT_TH_V1_8197F << BIT_SHIFT_RD_RESP_PKT_TH_V1_8197F)
#define BIT_CLEAR_RD_RESP_PKT_TH_V1_8197F(x) \
((x) & (~BITS_RD_RESP_PKT_TH_V1_8197F))
#define BIT_GET_RD_RESP_PKT_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH_V1_8197F) & \
BIT_MASK_RD_RESP_PKT_TH_V1_8197F)
#define BIT_SET_RD_RESP_PKT_TH_V1_8197F(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH_V1_8197F(x) | BIT_RD_RESP_PKT_TH_V1_8197F(v))
/* 2 REG_CMDQ_INFO_8197F */
#define BIT_SHIFT_PKT_NUM_8197F 23
#define BIT_MASK_PKT_NUM_8197F 0x1ff
#define BIT_PKT_NUM_8197F(x) \
(((x) & BIT_MASK_PKT_NUM_8197F) << BIT_SHIFT_PKT_NUM_8197F)
#define BITS_PKT_NUM_8197F (BIT_MASK_PKT_NUM_8197F << BIT_SHIFT_PKT_NUM_8197F)
#define BIT_CLEAR_PKT_NUM_8197F(x) ((x) & (~BITS_PKT_NUM_8197F))
#define BIT_GET_PKT_NUM_8197F(x) \
(((x) >> BIT_SHIFT_PKT_NUM_8197F) & BIT_MASK_PKT_NUM_8197F)
#define BIT_SET_PKT_NUM_8197F(x, v) \
(BIT_CLEAR_PKT_NUM_8197F(x) | BIT_PKT_NUM_8197F(v))
#define BIT_TIDEMPTY_CMDQ_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_CMDQ_V2_8197F 11
#define BIT_MASK_TAIL_PKT_CMDQ_V2_8197F 0x7ff
#define BIT_TAIL_PKT_CMDQ_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_CMDQ_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_CMDQ_V2_8197F)
#define BITS_TAIL_PKT_CMDQ_V2_8197F \
(BIT_MASK_TAIL_PKT_CMDQ_V2_8197F << BIT_SHIFT_TAIL_PKT_CMDQ_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_CMDQ_V2_8197F(x) \
((x) & (~BITS_TAIL_PKT_CMDQ_V2_8197F))
#define BIT_GET_TAIL_PKT_CMDQ_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_CMDQ_V2_8197F) & \
BIT_MASK_TAIL_PKT_CMDQ_V2_8197F)
#define BIT_SET_TAIL_PKT_CMDQ_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_CMDQ_V2_8197F(x) | BIT_TAIL_PKT_CMDQ_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_CMDQ_V1_8197F 0
#define BIT_MASK_HEAD_PKT_CMDQ_V1_8197F 0x7ff
#define BIT_HEAD_PKT_CMDQ_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_CMDQ_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_CMDQ_V1_8197F)
#define BITS_HEAD_PKT_CMDQ_V1_8197F \
(BIT_MASK_HEAD_PKT_CMDQ_V1_8197F << BIT_SHIFT_HEAD_PKT_CMDQ_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_CMDQ_V1_8197F(x) \
((x) & (~BITS_HEAD_PKT_CMDQ_V1_8197F))
#define BIT_GET_HEAD_PKT_CMDQ_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_CMDQ_V1_8197F) & \
BIT_MASK_HEAD_PKT_CMDQ_V1_8197F)
#define BIT_SET_HEAD_PKT_CMDQ_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_CMDQ_V1_8197F(x) | BIT_HEAD_PKT_CMDQ_V1_8197F(v))
/* 2 REG_Q4_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q4_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q4_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q4_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q4_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q4_V1_8197F)
#define BITS_QUEUEMACID_Q4_V1_8197F \
(BIT_MASK_QUEUEMACID_Q4_V1_8197F << BIT_SHIFT_QUEUEMACID_Q4_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q4_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q4_V1_8197F))
#define BIT_GET_QUEUEMACID_Q4_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q4_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q4_V1_8197F)
#define BIT_SET_QUEUEMACID_Q4_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q4_V1_8197F(x) | BIT_QUEUEMACID_Q4_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q4_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q4_V1_8197F 0x3
#define BIT_QUEUEAC_Q4_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q4_V1_8197F) << BIT_SHIFT_QUEUEAC_Q4_V1_8197F)
#define BITS_QUEUEAC_Q4_V1_8197F \
(BIT_MASK_QUEUEAC_Q4_V1_8197F << BIT_SHIFT_QUEUEAC_Q4_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q4_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q4_V1_8197F))
#define BIT_GET_QUEUEAC_Q4_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q4_V1_8197F) & BIT_MASK_QUEUEAC_Q4_V1_8197F)
#define BIT_SET_QUEUEAC_Q4_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q4_V1_8197F(x) | BIT_QUEUEAC_Q4_V1_8197F(v))
#define BIT_TIDEMPTY_Q4_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q4_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q4_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q4_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q4_V2_8197F)
#define BITS_TAIL_PKT_Q4_V2_8197F \
(BIT_MASK_TAIL_PKT_Q4_V2_8197F << BIT_SHIFT_TAIL_PKT_Q4_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q4_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q4_V2_8197F))
#define BIT_GET_TAIL_PKT_Q4_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q4_V2_8197F)
#define BIT_SET_TAIL_PKT_Q4_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2_8197F(x) | BIT_TAIL_PKT_Q4_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q4_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q4_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q4_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q4_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q4_V1_8197F)
#define BITS_HEAD_PKT_Q4_V1_8197F \
(BIT_MASK_HEAD_PKT_Q4_V1_8197F << BIT_SHIFT_HEAD_PKT_Q4_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q4_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q4_V1_8197F))
#define BIT_GET_HEAD_PKT_Q4_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q4_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q4_V1_8197F)
#define BIT_SET_HEAD_PKT_Q4_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q4_V1_8197F(x) | BIT_HEAD_PKT_Q4_V1_8197F(v))
/* 2 REG_Q5_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q5_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q5_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q5_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q5_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q5_V1_8197F)
#define BITS_QUEUEMACID_Q5_V1_8197F \
(BIT_MASK_QUEUEMACID_Q5_V1_8197F << BIT_SHIFT_QUEUEMACID_Q5_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q5_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q5_V1_8197F))
#define BIT_GET_QUEUEMACID_Q5_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q5_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q5_V1_8197F)
#define BIT_SET_QUEUEMACID_Q5_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q5_V1_8197F(x) | BIT_QUEUEMACID_Q5_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q5_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q5_V1_8197F 0x3
#define BIT_QUEUEAC_Q5_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q5_V1_8197F) << BIT_SHIFT_QUEUEAC_Q5_V1_8197F)
#define BITS_QUEUEAC_Q5_V1_8197F \
(BIT_MASK_QUEUEAC_Q5_V1_8197F << BIT_SHIFT_QUEUEAC_Q5_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q5_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q5_V1_8197F))
#define BIT_GET_QUEUEAC_Q5_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q5_V1_8197F) & BIT_MASK_QUEUEAC_Q5_V1_8197F)
#define BIT_SET_QUEUEAC_Q5_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q5_V1_8197F(x) | BIT_QUEUEAC_Q5_V1_8197F(v))
#define BIT_TIDEMPTY_Q5_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q5_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q5_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q5_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q5_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q5_V2_8197F)
#define BITS_TAIL_PKT_Q5_V2_8197F \
(BIT_MASK_TAIL_PKT_Q5_V2_8197F << BIT_SHIFT_TAIL_PKT_Q5_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q5_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q5_V2_8197F))
#define BIT_GET_TAIL_PKT_Q5_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q5_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q5_V2_8197F)
#define BIT_SET_TAIL_PKT_Q5_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q5_V2_8197F(x) | BIT_TAIL_PKT_Q5_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q5_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q5_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q5_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q5_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q5_V1_8197F)
#define BITS_HEAD_PKT_Q5_V1_8197F \
(BIT_MASK_HEAD_PKT_Q5_V1_8197F << BIT_SHIFT_HEAD_PKT_Q5_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q5_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q5_V1_8197F))
#define BIT_GET_HEAD_PKT_Q5_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q5_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q5_V1_8197F)
#define BIT_SET_HEAD_PKT_Q5_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q5_V1_8197F(x) | BIT_HEAD_PKT_Q5_V1_8197F(v))
/* 2 REG_Q6_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q6_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q6_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q6_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q6_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q6_V1_8197F)
#define BITS_QUEUEMACID_Q6_V1_8197F \
(BIT_MASK_QUEUEMACID_Q6_V1_8197F << BIT_SHIFT_QUEUEMACID_Q6_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q6_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q6_V1_8197F))
#define BIT_GET_QUEUEMACID_Q6_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q6_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q6_V1_8197F)
#define BIT_SET_QUEUEMACID_Q6_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q6_V1_8197F(x) | BIT_QUEUEMACID_Q6_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q6_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q6_V1_8197F 0x3
#define BIT_QUEUEAC_Q6_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q6_V1_8197F) << BIT_SHIFT_QUEUEAC_Q6_V1_8197F)
#define BITS_QUEUEAC_Q6_V1_8197F \
(BIT_MASK_QUEUEAC_Q6_V1_8197F << BIT_SHIFT_QUEUEAC_Q6_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q6_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q6_V1_8197F))
#define BIT_GET_QUEUEAC_Q6_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q6_V1_8197F) & BIT_MASK_QUEUEAC_Q6_V1_8197F)
#define BIT_SET_QUEUEAC_Q6_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q6_V1_8197F(x) | BIT_QUEUEAC_Q6_V1_8197F(v))
#define BIT_TIDEMPTY_Q6_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q6_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q6_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q6_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q6_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q6_V2_8197F)
#define BITS_TAIL_PKT_Q6_V2_8197F \
(BIT_MASK_TAIL_PKT_Q6_V2_8197F << BIT_SHIFT_TAIL_PKT_Q6_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q6_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q6_V2_8197F))
#define BIT_GET_TAIL_PKT_Q6_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q6_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q6_V2_8197F)
#define BIT_SET_TAIL_PKT_Q6_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q6_V2_8197F(x) | BIT_TAIL_PKT_Q6_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q6_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q6_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q6_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q6_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q6_V1_8197F)
#define BITS_HEAD_PKT_Q6_V1_8197F \
(BIT_MASK_HEAD_PKT_Q6_V1_8197F << BIT_SHIFT_HEAD_PKT_Q6_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q6_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q6_V1_8197F))
#define BIT_GET_HEAD_PKT_Q6_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q6_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q6_V1_8197F)
#define BIT_SET_HEAD_PKT_Q6_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q6_V1_8197F(x) | BIT_HEAD_PKT_Q6_V1_8197F(v))
/* 2 REG_Q7_INFO_8197F */
#define BIT_SHIFT_QUEUEMACID_Q7_V1_8197F 25
#define BIT_MASK_QUEUEMACID_Q7_V1_8197F 0x7f
#define BIT_QUEUEMACID_Q7_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEMACID_Q7_V1_8197F) \
<< BIT_SHIFT_QUEUEMACID_Q7_V1_8197F)
#define BITS_QUEUEMACID_Q7_V1_8197F \
(BIT_MASK_QUEUEMACID_Q7_V1_8197F << BIT_SHIFT_QUEUEMACID_Q7_V1_8197F)
#define BIT_CLEAR_QUEUEMACID_Q7_V1_8197F(x) \
((x) & (~BITS_QUEUEMACID_Q7_V1_8197F))
#define BIT_GET_QUEUEMACID_Q7_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q7_V1_8197F) & \
BIT_MASK_QUEUEMACID_Q7_V1_8197F)
#define BIT_SET_QUEUEMACID_Q7_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEMACID_Q7_V1_8197F(x) | BIT_QUEUEMACID_Q7_V1_8197F(v))
#define BIT_SHIFT_QUEUEAC_Q7_V1_8197F 23
#define BIT_MASK_QUEUEAC_Q7_V1_8197F 0x3
#define BIT_QUEUEAC_Q7_V1_8197F(x) \
(((x) & BIT_MASK_QUEUEAC_Q7_V1_8197F) << BIT_SHIFT_QUEUEAC_Q7_V1_8197F)
#define BITS_QUEUEAC_Q7_V1_8197F \
(BIT_MASK_QUEUEAC_Q7_V1_8197F << BIT_SHIFT_QUEUEAC_Q7_V1_8197F)
#define BIT_CLEAR_QUEUEAC_Q7_V1_8197F(x) ((x) & (~BITS_QUEUEAC_Q7_V1_8197F))
#define BIT_GET_QUEUEAC_Q7_V1_8197F(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q7_V1_8197F) & BIT_MASK_QUEUEAC_Q7_V1_8197F)
#define BIT_SET_QUEUEAC_Q7_V1_8197F(x, v) \
(BIT_CLEAR_QUEUEAC_Q7_V1_8197F(x) | BIT_QUEUEAC_Q7_V1_8197F(v))
#define BIT_TIDEMPTY_Q7_V1_8197F BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q7_V2_8197F 11
#define BIT_MASK_TAIL_PKT_Q7_V2_8197F 0x7ff
#define BIT_TAIL_PKT_Q7_V2_8197F(x) \
(((x) & BIT_MASK_TAIL_PKT_Q7_V2_8197F) \
<< BIT_SHIFT_TAIL_PKT_Q7_V2_8197F)
#define BITS_TAIL_PKT_Q7_V2_8197F \
(BIT_MASK_TAIL_PKT_Q7_V2_8197F << BIT_SHIFT_TAIL_PKT_Q7_V2_8197F)
#define BIT_CLEAR_TAIL_PKT_Q7_V2_8197F(x) ((x) & (~BITS_TAIL_PKT_Q7_V2_8197F))
#define BIT_GET_TAIL_PKT_Q7_V2_8197F(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q7_V2_8197F) & \
BIT_MASK_TAIL_PKT_Q7_V2_8197F)
#define BIT_SET_TAIL_PKT_Q7_V2_8197F(x, v) \
(BIT_CLEAR_TAIL_PKT_Q7_V2_8197F(x) | BIT_TAIL_PKT_Q7_V2_8197F(v))
#define BIT_SHIFT_HEAD_PKT_Q7_V1_8197F 0
#define BIT_MASK_HEAD_PKT_Q7_V1_8197F 0x7ff
#define BIT_HEAD_PKT_Q7_V1_8197F(x) \
(((x) & BIT_MASK_HEAD_PKT_Q7_V1_8197F) \
<< BIT_SHIFT_HEAD_PKT_Q7_V1_8197F)
#define BITS_HEAD_PKT_Q7_V1_8197F \
(BIT_MASK_HEAD_PKT_Q7_V1_8197F << BIT_SHIFT_HEAD_PKT_Q7_V1_8197F)
#define BIT_CLEAR_HEAD_PKT_Q7_V1_8197F(x) ((x) & (~BITS_HEAD_PKT_Q7_V1_8197F))
#define BIT_GET_HEAD_PKT_Q7_V1_8197F(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q7_V1_8197F) & \
BIT_MASK_HEAD_PKT_Q7_V1_8197F)
#define BIT_SET_HEAD_PKT_Q7_V1_8197F(x, v) \
(BIT_CLEAR_HEAD_PKT_Q7_V1_8197F(x) | BIT_HEAD_PKT_Q7_V1_8197F(v))
/* 2 REG_WMAC_LBK_BUF_HD_V1_8197F */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8197F 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8197F 0xfff
#define BIT_WMAC_LBK_BUF_HEAD_V1_8197F(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8197F) \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8197F)
#define BITS_WMAC_LBK_BUF_HEAD_V1_8197F \
(BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8197F \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8197F)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8197F(x) \
((x) & (~BITS_WMAC_LBK_BUF_HEAD_V1_8197F))
#define BIT_GET_WMAC_LBK_BUF_HEAD_V1_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8197F) & \
BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8197F)
#define BIT_SET_WMAC_LBK_BUF_HEAD_V1_8197F(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8197F(x) | \
BIT_WMAC_LBK_BUF_HEAD_V1_8197F(v))
/* 2 REG_MGQ_BDNY_V1_8197F */
#define BIT_SHIFT_MGQ_PGBNDY_V1_8197F 0
#define BIT_MASK_MGQ_PGBNDY_V1_8197F 0xfff
#define BIT_MGQ_PGBNDY_V1_8197F(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V1_8197F) << BIT_SHIFT_MGQ_PGBNDY_V1_8197F)
#define BITS_MGQ_PGBNDY_V1_8197F \
(BIT_MASK_MGQ_PGBNDY_V1_8197F << BIT_SHIFT_MGQ_PGBNDY_V1_8197F)
#define BIT_CLEAR_MGQ_PGBNDY_V1_8197F(x) ((x) & (~BITS_MGQ_PGBNDY_V1_8197F))
#define BIT_GET_MGQ_PGBNDY_V1_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V1_8197F) & BIT_MASK_MGQ_PGBNDY_V1_8197F)
#define BIT_SET_MGQ_PGBNDY_V1_8197F(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V1_8197F(x) | BIT_MGQ_PGBNDY_V1_8197F(v))
/* 2 REG_TXRPT_CTRL_8197F */
#define BIT_SHIFT_TRXRPT_TIMER_TH_8197F 24
#define BIT_MASK_TRXRPT_TIMER_TH_8197F 0xff
#define BIT_TRXRPT_TIMER_TH_8197F(x) \
(((x) & BIT_MASK_TRXRPT_TIMER_TH_8197F) \
<< BIT_SHIFT_TRXRPT_TIMER_TH_8197F)
#define BITS_TRXRPT_TIMER_TH_8197F \
(BIT_MASK_TRXRPT_TIMER_TH_8197F << BIT_SHIFT_TRXRPT_TIMER_TH_8197F)
#define BIT_CLEAR_TRXRPT_TIMER_TH_8197F(x) ((x) & (~BITS_TRXRPT_TIMER_TH_8197F))
#define BIT_GET_TRXRPT_TIMER_TH_8197F(x) \
(((x) >> BIT_SHIFT_TRXRPT_TIMER_TH_8197F) & \
BIT_MASK_TRXRPT_TIMER_TH_8197F)
#define BIT_SET_TRXRPT_TIMER_TH_8197F(x, v) \
(BIT_CLEAR_TRXRPT_TIMER_TH_8197F(x) | BIT_TRXRPT_TIMER_TH_8197F(v))
#define BIT_SHIFT_TRXRPT_LEN_TH_8197F 16
#define BIT_MASK_TRXRPT_LEN_TH_8197F 0xff
#define BIT_TRXRPT_LEN_TH_8197F(x) \
(((x) & BIT_MASK_TRXRPT_LEN_TH_8197F) << BIT_SHIFT_TRXRPT_LEN_TH_8197F)
#define BITS_TRXRPT_LEN_TH_8197F \
(BIT_MASK_TRXRPT_LEN_TH_8197F << BIT_SHIFT_TRXRPT_LEN_TH_8197F)
#define BIT_CLEAR_TRXRPT_LEN_TH_8197F(x) ((x) & (~BITS_TRXRPT_LEN_TH_8197F))
#define BIT_GET_TRXRPT_LEN_TH_8197F(x) \
(((x) >> BIT_SHIFT_TRXRPT_LEN_TH_8197F) & BIT_MASK_TRXRPT_LEN_TH_8197F)
#define BIT_SET_TRXRPT_LEN_TH_8197F(x, v) \
(BIT_CLEAR_TRXRPT_LEN_TH_8197F(x) | BIT_TRXRPT_LEN_TH_8197F(v))
#define BIT_SHIFT_TRXRPT_READ_PTR_8197F 8
#define BIT_MASK_TRXRPT_READ_PTR_8197F 0xff
#define BIT_TRXRPT_READ_PTR_8197F(x) \
(((x) & BIT_MASK_TRXRPT_READ_PTR_8197F) \
<< BIT_SHIFT_TRXRPT_READ_PTR_8197F)
#define BITS_TRXRPT_READ_PTR_8197F \
(BIT_MASK_TRXRPT_READ_PTR_8197F << BIT_SHIFT_TRXRPT_READ_PTR_8197F)
#define BIT_CLEAR_TRXRPT_READ_PTR_8197F(x) ((x) & (~BITS_TRXRPT_READ_PTR_8197F))
#define BIT_GET_TRXRPT_READ_PTR_8197F(x) \
(((x) >> BIT_SHIFT_TRXRPT_READ_PTR_8197F) & \
BIT_MASK_TRXRPT_READ_PTR_8197F)
#define BIT_SET_TRXRPT_READ_PTR_8197F(x, v) \
(BIT_CLEAR_TRXRPT_READ_PTR_8197F(x) | BIT_TRXRPT_READ_PTR_8197F(v))
#define BIT_SHIFT_TRXRPT_WRITE_PTR_8197F 0
#define BIT_MASK_TRXRPT_WRITE_PTR_8197F 0xff
#define BIT_TRXRPT_WRITE_PTR_8197F(x) \
(((x) & BIT_MASK_TRXRPT_WRITE_PTR_8197F) \
<< BIT_SHIFT_TRXRPT_WRITE_PTR_8197F)
#define BITS_TRXRPT_WRITE_PTR_8197F \
(BIT_MASK_TRXRPT_WRITE_PTR_8197F << BIT_SHIFT_TRXRPT_WRITE_PTR_8197F)
#define BIT_CLEAR_TRXRPT_WRITE_PTR_8197F(x) \
((x) & (~BITS_TRXRPT_WRITE_PTR_8197F))
#define BIT_GET_TRXRPT_WRITE_PTR_8197F(x) \
(((x) >> BIT_SHIFT_TRXRPT_WRITE_PTR_8197F) & \
BIT_MASK_TRXRPT_WRITE_PTR_8197F)
#define BIT_SET_TRXRPT_WRITE_PTR_8197F(x, v) \
(BIT_CLEAR_TRXRPT_WRITE_PTR_8197F(x) | BIT_TRXRPT_WRITE_PTR_8197F(v))
/* 2 REG_INIRTS_RATE_SEL_8197F */
#define BIT_LEAG_RTS_BW_DUP_8197F BIT(5)
/* 2 REG_BASIC_CFEND_RATE_8197F */
#define BIT_SHIFT_BASIC_CFEND_RATE_8197F 0
#define BIT_MASK_BASIC_CFEND_RATE_8197F 0x1f
#define BIT_BASIC_CFEND_RATE_8197F(x) \
(((x) & BIT_MASK_BASIC_CFEND_RATE_8197F) \
<< BIT_SHIFT_BASIC_CFEND_RATE_8197F)
#define BITS_BASIC_CFEND_RATE_8197F \
(BIT_MASK_BASIC_CFEND_RATE_8197F << BIT_SHIFT_BASIC_CFEND_RATE_8197F)
#define BIT_CLEAR_BASIC_CFEND_RATE_8197F(x) \
((x) & (~BITS_BASIC_CFEND_RATE_8197F))
#define BIT_GET_BASIC_CFEND_RATE_8197F(x) \
(((x) >> BIT_SHIFT_BASIC_CFEND_RATE_8197F) & \
BIT_MASK_BASIC_CFEND_RATE_8197F)
#define BIT_SET_BASIC_CFEND_RATE_8197F(x, v) \
(BIT_CLEAR_BASIC_CFEND_RATE_8197F(x) | BIT_BASIC_CFEND_RATE_8197F(v))
/* 2 REG_STBC_CFEND_RATE_8197F */
#define BIT_SHIFT_STBC_CFEND_RATE_8197F 0
#define BIT_MASK_STBC_CFEND_RATE_8197F 0x1f
#define BIT_STBC_CFEND_RATE_8197F(x) \
(((x) & BIT_MASK_STBC_CFEND_RATE_8197F) \
<< BIT_SHIFT_STBC_CFEND_RATE_8197F)
#define BITS_STBC_CFEND_RATE_8197F \
(BIT_MASK_STBC_CFEND_RATE_8197F << BIT_SHIFT_STBC_CFEND_RATE_8197F)
#define BIT_CLEAR_STBC_CFEND_RATE_8197F(x) ((x) & (~BITS_STBC_CFEND_RATE_8197F))
#define BIT_GET_STBC_CFEND_RATE_8197F(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_RATE_8197F) & \
BIT_MASK_STBC_CFEND_RATE_8197F)
#define BIT_SET_STBC_CFEND_RATE_8197F(x, v) \
(BIT_CLEAR_STBC_CFEND_RATE_8197F(x) | BIT_STBC_CFEND_RATE_8197F(v))
/* 2 REG_DATA_SC_8197F */
#define BIT_SHIFT_TXSC_40M_8197F 4
#define BIT_MASK_TXSC_40M_8197F 0xf
#define BIT_TXSC_40M_8197F(x) \
(((x) & BIT_MASK_TXSC_40M_8197F) << BIT_SHIFT_TXSC_40M_8197F)
#define BITS_TXSC_40M_8197F \
(BIT_MASK_TXSC_40M_8197F << BIT_SHIFT_TXSC_40M_8197F)
#define BIT_CLEAR_TXSC_40M_8197F(x) ((x) & (~BITS_TXSC_40M_8197F))
#define BIT_GET_TXSC_40M_8197F(x) \
(((x) >> BIT_SHIFT_TXSC_40M_8197F) & BIT_MASK_TXSC_40M_8197F)
#define BIT_SET_TXSC_40M_8197F(x, v) \
(BIT_CLEAR_TXSC_40M_8197F(x) | BIT_TXSC_40M_8197F(v))
#define BIT_SHIFT_TXSC_20M_8197F 0
#define BIT_MASK_TXSC_20M_8197F 0xf
#define BIT_TXSC_20M_8197F(x) \
(((x) & BIT_MASK_TXSC_20M_8197F) << BIT_SHIFT_TXSC_20M_8197F)
#define BITS_TXSC_20M_8197F \
(BIT_MASK_TXSC_20M_8197F << BIT_SHIFT_TXSC_20M_8197F)
#define BIT_CLEAR_TXSC_20M_8197F(x) ((x) & (~BITS_TXSC_20M_8197F))
#define BIT_GET_TXSC_20M_8197F(x) \
(((x) >> BIT_SHIFT_TXSC_20M_8197F) & BIT_MASK_TXSC_20M_8197F)
#define BIT_SET_TXSC_20M_8197F(x, v) \
(BIT_CLEAR_TXSC_20M_8197F(x) | BIT_TXSC_20M_8197F(v))
/* 2 REG_MACID_SLEEP3_8197F */
#define BIT_SHIFT_MACID127_96_PKTSLEEP_8197F 0
#define BIT_MASK_MACID127_96_PKTSLEEP_8197F 0xffffffffL
#define BIT_MACID127_96_PKTSLEEP_8197F(x) \
(((x) & BIT_MASK_MACID127_96_PKTSLEEP_8197F) \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8197F)
#define BITS_MACID127_96_PKTSLEEP_8197F \
(BIT_MASK_MACID127_96_PKTSLEEP_8197F \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8197F)
#define BIT_CLEAR_MACID127_96_PKTSLEEP_8197F(x) \
((x) & (~BITS_MACID127_96_PKTSLEEP_8197F))
#define BIT_GET_MACID127_96_PKTSLEEP_8197F(x) \
(((x) >> BIT_SHIFT_MACID127_96_PKTSLEEP_8197F) & \
BIT_MASK_MACID127_96_PKTSLEEP_8197F)
#define BIT_SET_MACID127_96_PKTSLEEP_8197F(x, v) \
(BIT_CLEAR_MACID127_96_PKTSLEEP_8197F(x) | \
BIT_MACID127_96_PKTSLEEP_8197F(v))
/* 2 REG_MACID_SLEEP1_8197F */
#define BIT_SHIFT_MACID63_32_PKTSLEEP_8197F 0
#define BIT_MASK_MACID63_32_PKTSLEEP_8197F 0xffffffffL
#define BIT_MACID63_32_PKTSLEEP_8197F(x) \
(((x) & BIT_MASK_MACID63_32_PKTSLEEP_8197F) \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8197F)
#define BITS_MACID63_32_PKTSLEEP_8197F \
(BIT_MASK_MACID63_32_PKTSLEEP_8197F \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8197F)
#define BIT_CLEAR_MACID63_32_PKTSLEEP_8197F(x) \
((x) & (~BITS_MACID63_32_PKTSLEEP_8197F))
#define BIT_GET_MACID63_32_PKTSLEEP_8197F(x) \
(((x) >> BIT_SHIFT_MACID63_32_PKTSLEEP_8197F) & \
BIT_MASK_MACID63_32_PKTSLEEP_8197F)
#define BIT_SET_MACID63_32_PKTSLEEP_8197F(x, v) \
(BIT_CLEAR_MACID63_32_PKTSLEEP_8197F(x) | \
BIT_MACID63_32_PKTSLEEP_8197F(v))
/* 2 REG_ARFR2_V1_8197F */
#define BIT_SHIFT_ARFR2_V1_8197F 0
#define BIT_MASK_ARFR2_V1_8197F 0xffffffffffffffffL
#define BIT_ARFR2_V1_8197F(x) \
(((x) & BIT_MASK_ARFR2_V1_8197F) << BIT_SHIFT_ARFR2_V1_8197F)
#define BITS_ARFR2_V1_8197F \
(BIT_MASK_ARFR2_V1_8197F << BIT_SHIFT_ARFR2_V1_8197F)
#define BIT_CLEAR_ARFR2_V1_8197F(x) ((x) & (~BITS_ARFR2_V1_8197F))
#define BIT_GET_ARFR2_V1_8197F(x) \
(((x) >> BIT_SHIFT_ARFR2_V1_8197F) & BIT_MASK_ARFR2_V1_8197F)
#define BIT_SET_ARFR2_V1_8197F(x, v) \
(BIT_CLEAR_ARFR2_V1_8197F(x) | BIT_ARFR2_V1_8197F(v))
/* 2 REG_ARFR3_V1_8197F */
#define BIT_SHIFT_ARFR3_V1_8197F 0
#define BIT_MASK_ARFR3_V1_8197F 0xffffffffffffffffL
#define BIT_ARFR3_V1_8197F(x) \
(((x) & BIT_MASK_ARFR3_V1_8197F) << BIT_SHIFT_ARFR3_V1_8197F)
#define BITS_ARFR3_V1_8197F \
(BIT_MASK_ARFR3_V1_8197F << BIT_SHIFT_ARFR3_V1_8197F)
#define BIT_CLEAR_ARFR3_V1_8197F(x) ((x) & (~BITS_ARFR3_V1_8197F))
#define BIT_GET_ARFR3_V1_8197F(x) \
(((x) >> BIT_SHIFT_ARFR3_V1_8197F) & BIT_MASK_ARFR3_V1_8197F)
#define BIT_SET_ARFR3_V1_8197F(x, v) \
(BIT_CLEAR_ARFR3_V1_8197F(x) | BIT_ARFR3_V1_8197F(v))
/* 2 REG_ARFR4_8197F */
#define BIT_SHIFT_ARFR4_8197F 0
#define BIT_MASK_ARFR4_8197F 0xffffffffffffffffL
#define BIT_ARFR4_8197F(x) \
(((x) & BIT_MASK_ARFR4_8197F) << BIT_SHIFT_ARFR4_8197F)
#define BITS_ARFR4_8197F (BIT_MASK_ARFR4_8197F << BIT_SHIFT_ARFR4_8197F)
#define BIT_CLEAR_ARFR4_8197F(x) ((x) & (~BITS_ARFR4_8197F))
#define BIT_GET_ARFR4_8197F(x) \
(((x) >> BIT_SHIFT_ARFR4_8197F) & BIT_MASK_ARFR4_8197F)
#define BIT_SET_ARFR4_8197F(x, v) \
(BIT_CLEAR_ARFR4_8197F(x) | BIT_ARFR4_8197F(v))
/* 2 REG_ARFR5_8197F */
#define BIT_SHIFT_ARFR5_8197F 0
#define BIT_MASK_ARFR5_8197F 0xffffffffffffffffL
#define BIT_ARFR5_8197F(x) \
(((x) & BIT_MASK_ARFR5_8197F) << BIT_SHIFT_ARFR5_8197F)
#define BITS_ARFR5_8197F (BIT_MASK_ARFR5_8197F << BIT_SHIFT_ARFR5_8197F)
#define BIT_CLEAR_ARFR5_8197F(x) ((x) & (~BITS_ARFR5_8197F))
#define BIT_GET_ARFR5_8197F(x) \
(((x) >> BIT_SHIFT_ARFR5_8197F) & BIT_MASK_ARFR5_8197F)
#define BIT_SET_ARFR5_8197F(x, v) \
(BIT_CLEAR_ARFR5_8197F(x) | BIT_ARFR5_8197F(v))
/* 2 REG_TXRPT_START_OFFSET_8197F */
#define BIT_SHCUT_PARSE_DASA_8197F BIT(25)
#define BIT_SHCUT_BYPASS_8197F BIT(24)
#define BIT__R_RPTFIFO_1K_8197F BIT(16)
#define BIT_SHIFT_MACID_CTRL_OFFSET_8197F 8
#define BIT_MASK_MACID_CTRL_OFFSET_8197F 0xff
#define BIT_MACID_CTRL_OFFSET_8197F(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET_8197F) \
<< BIT_SHIFT_MACID_CTRL_OFFSET_8197F)
#define BITS_MACID_CTRL_OFFSET_8197F \
(BIT_MASK_MACID_CTRL_OFFSET_8197F << BIT_SHIFT_MACID_CTRL_OFFSET_8197F)
#define BIT_CLEAR_MACID_CTRL_OFFSET_8197F(x) \
((x) & (~BITS_MACID_CTRL_OFFSET_8197F))
#define BIT_GET_MACID_CTRL_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET_8197F) & \
BIT_MASK_MACID_CTRL_OFFSET_8197F)
#define BIT_SET_MACID_CTRL_OFFSET_8197F(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET_8197F(x) | BIT_MACID_CTRL_OFFSET_8197F(v))
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET_8197F 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET_8197F 0xff
#define BIT_AMPDU_TXRPT_OFFSET_8197F(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET_8197F) \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8197F)
#define BITS_AMPDU_TXRPT_OFFSET_8197F \
(BIT_MASK_AMPDU_TXRPT_OFFSET_8197F \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8197F)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET_8197F(x) \
((x) & (~BITS_AMPDU_TXRPT_OFFSET_8197F))
#define BIT_GET_AMPDU_TXRPT_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET_8197F) & \
BIT_MASK_AMPDU_TXRPT_OFFSET_8197F)
#define BIT_SET_AMPDU_TXRPT_OFFSET_8197F(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET_8197F(x) | \
BIT_AMPDU_TXRPT_OFFSET_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_POWER_STAGE1_8197F */
#define BIT_PTA_WL_PRI_MASK_CPU_MGQ_8197F BIT(31)
#define BIT_PTA_WL_PRI_MASK_BCNQ_8197F BIT(30)
#define BIT_PTA_WL_PRI_MASK_HIQ_8197F BIT(29)
#define BIT_PTA_WL_PRI_MASK_MGQ_8197F BIT(28)
#define BIT_PTA_WL_PRI_MASK_BK_8197F BIT(27)
#define BIT_PTA_WL_PRI_MASK_BE_8197F BIT(26)
#define BIT_PTA_WL_PRI_MASK_VI_8197F BIT(25)
#define BIT_PTA_WL_PRI_MASK_VO_8197F BIT(24)
#define BIT_SHIFT_POWER_STAGE1_8197F 0
#define BIT_MASK_POWER_STAGE1_8197F 0xffffff
#define BIT_POWER_STAGE1_8197F(x) \
(((x) & BIT_MASK_POWER_STAGE1_8197F) << BIT_SHIFT_POWER_STAGE1_8197F)
#define BITS_POWER_STAGE1_8197F \
(BIT_MASK_POWER_STAGE1_8197F << BIT_SHIFT_POWER_STAGE1_8197F)
#define BIT_CLEAR_POWER_STAGE1_8197F(x) ((x) & (~BITS_POWER_STAGE1_8197F))
#define BIT_GET_POWER_STAGE1_8197F(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1_8197F) & BIT_MASK_POWER_STAGE1_8197F)
#define BIT_SET_POWER_STAGE1_8197F(x, v) \
(BIT_CLEAR_POWER_STAGE1_8197F(x) | BIT_POWER_STAGE1_8197F(v))
/* 2 REG_POWER_STAGE2_8197F */
#define BIT__R_CTRL_PKT_POW_ADJ_8197F BIT(24)
#define BIT_SHIFT_POWER_STAGE2_8197F 0
#define BIT_MASK_POWER_STAGE2_8197F 0xffffff
#define BIT_POWER_STAGE2_8197F(x) \
(((x) & BIT_MASK_POWER_STAGE2_8197F) << BIT_SHIFT_POWER_STAGE2_8197F)
#define BITS_POWER_STAGE2_8197F \
(BIT_MASK_POWER_STAGE2_8197F << BIT_SHIFT_POWER_STAGE2_8197F)
#define BIT_CLEAR_POWER_STAGE2_8197F(x) ((x) & (~BITS_POWER_STAGE2_8197F))
#define BIT_GET_POWER_STAGE2_8197F(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2_8197F) & BIT_MASK_POWER_STAGE2_8197F)
#define BIT_SET_POWER_STAGE2_8197F(x, v) \
(BIT_CLEAR_POWER_STAGE2_8197F(x) | BIT_POWER_STAGE2_8197F(v))
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL_8197F */
#define BIT_SHIFT_PAD_NUM_THRES_8197F 24
#define BIT_MASK_PAD_NUM_THRES_8197F 0x3f
#define BIT_PAD_NUM_THRES_8197F(x) \
(((x) & BIT_MASK_PAD_NUM_THRES_8197F) << BIT_SHIFT_PAD_NUM_THRES_8197F)
#define BITS_PAD_NUM_THRES_8197F \
(BIT_MASK_PAD_NUM_THRES_8197F << BIT_SHIFT_PAD_NUM_THRES_8197F)
#define BIT_CLEAR_PAD_NUM_THRES_8197F(x) ((x) & (~BITS_PAD_NUM_THRES_8197F))
#define BIT_GET_PAD_NUM_THRES_8197F(x) \
(((x) >> BIT_SHIFT_PAD_NUM_THRES_8197F) & BIT_MASK_PAD_NUM_THRES_8197F)
#define BIT_SET_PAD_NUM_THRES_8197F(x, v) \
(BIT_CLEAR_PAD_NUM_THRES_8197F(x) | BIT_PAD_NUM_THRES_8197F(v))
#define BIT_R_DMA_THIS_QUEUE_BK_8197F BIT(23)
#define BIT_R_DMA_THIS_QUEUE_BE_8197F BIT(22)
#define BIT_R_DMA_THIS_QUEUE_VI_8197F BIT(21)
#define BIT_R_DMA_THIS_QUEUE_VO_8197F BIT(20)
#define BIT_SHIFT_R_TOTAL_LEN_TH_8197F 8
#define BIT_MASK_R_TOTAL_LEN_TH_8197F 0xfff
#define BIT_R_TOTAL_LEN_TH_8197F(x) \
(((x) & BIT_MASK_R_TOTAL_LEN_TH_8197F) \
<< BIT_SHIFT_R_TOTAL_LEN_TH_8197F)
#define BITS_R_TOTAL_LEN_TH_8197F \
(BIT_MASK_R_TOTAL_LEN_TH_8197F << BIT_SHIFT_R_TOTAL_LEN_TH_8197F)
#define BIT_CLEAR_R_TOTAL_LEN_TH_8197F(x) ((x) & (~BITS_R_TOTAL_LEN_TH_8197F))
#define BIT_GET_R_TOTAL_LEN_TH_8197F(x) \
(((x) >> BIT_SHIFT_R_TOTAL_LEN_TH_8197F) & \
BIT_MASK_R_TOTAL_LEN_TH_8197F)
#define BIT_SET_R_TOTAL_LEN_TH_8197F(x, v) \
(BIT_CLEAR_R_TOTAL_LEN_TH_8197F(x) | BIT_R_TOTAL_LEN_TH_8197F(v))
#define BIT_EN_NEW_EARLY_8197F BIT(7)
#define BIT_PRE_TX_CMD_8197F BIT(6)
#define BIT_SHIFT_NUM_SCL_EN_8197F 4
#define BIT_MASK_NUM_SCL_EN_8197F 0x3
#define BIT_NUM_SCL_EN_8197F(x) \
(((x) & BIT_MASK_NUM_SCL_EN_8197F) << BIT_SHIFT_NUM_SCL_EN_8197F)
#define BITS_NUM_SCL_EN_8197F \
(BIT_MASK_NUM_SCL_EN_8197F << BIT_SHIFT_NUM_SCL_EN_8197F)
#define BIT_CLEAR_NUM_SCL_EN_8197F(x) ((x) & (~BITS_NUM_SCL_EN_8197F))
#define BIT_GET_NUM_SCL_EN_8197F(x) \
(((x) >> BIT_SHIFT_NUM_SCL_EN_8197F) & BIT_MASK_NUM_SCL_EN_8197F)
#define BIT_SET_NUM_SCL_EN_8197F(x, v) \
(BIT_CLEAR_NUM_SCL_EN_8197F(x) | BIT_NUM_SCL_EN_8197F(v))
#define BIT_BK_EN_8197F BIT(3)
#define BIT_BE_EN_8197F BIT(2)
#define BIT_VI_EN_8197F BIT(1)
#define BIT_VO_EN_8197F BIT(0)
/* 2 REG_PKT_LIFE_TIME_8197F */
#define BIT_SHIFT_PKT_LIFTIME_BEBK_8197F 16
#define BIT_MASK_PKT_LIFTIME_BEBK_8197F 0xffff
#define BIT_PKT_LIFTIME_BEBK_8197F(x) \
(((x) & BIT_MASK_PKT_LIFTIME_BEBK_8197F) \
<< BIT_SHIFT_PKT_LIFTIME_BEBK_8197F)
#define BITS_PKT_LIFTIME_BEBK_8197F \
(BIT_MASK_PKT_LIFTIME_BEBK_8197F << BIT_SHIFT_PKT_LIFTIME_BEBK_8197F)
#define BIT_CLEAR_PKT_LIFTIME_BEBK_8197F(x) \
((x) & (~BITS_PKT_LIFTIME_BEBK_8197F))
#define BIT_GET_PKT_LIFTIME_BEBK_8197F(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_BEBK_8197F) & \
BIT_MASK_PKT_LIFTIME_BEBK_8197F)
#define BIT_SET_PKT_LIFTIME_BEBK_8197F(x, v) \
(BIT_CLEAR_PKT_LIFTIME_BEBK_8197F(x) | BIT_PKT_LIFTIME_BEBK_8197F(v))
#define BIT_SHIFT_PKT_LIFTIME_VOVI_8197F 0
#define BIT_MASK_PKT_LIFTIME_VOVI_8197F 0xffff
#define BIT_PKT_LIFTIME_VOVI_8197F(x) \
(((x) & BIT_MASK_PKT_LIFTIME_VOVI_8197F) \
<< BIT_SHIFT_PKT_LIFTIME_VOVI_8197F)
#define BITS_PKT_LIFTIME_VOVI_8197F \
(BIT_MASK_PKT_LIFTIME_VOVI_8197F << BIT_SHIFT_PKT_LIFTIME_VOVI_8197F)
#define BIT_CLEAR_PKT_LIFTIME_VOVI_8197F(x) \
((x) & (~BITS_PKT_LIFTIME_VOVI_8197F))
#define BIT_GET_PKT_LIFTIME_VOVI_8197F(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_VOVI_8197F) & \
BIT_MASK_PKT_LIFTIME_VOVI_8197F)
#define BIT_SET_PKT_LIFTIME_VOVI_8197F(x, v) \
(BIT_CLEAR_PKT_LIFTIME_VOVI_8197F(x) | BIT_PKT_LIFTIME_VOVI_8197F(v))
/* 2 REG_STBC_SETTING_8197F */
#define BIT_SHIFT_CDEND_TXTIME_L_8197F 4
#define BIT_MASK_CDEND_TXTIME_L_8197F 0xf
#define BIT_CDEND_TXTIME_L_8197F(x) \
(((x) & BIT_MASK_CDEND_TXTIME_L_8197F) \
<< BIT_SHIFT_CDEND_TXTIME_L_8197F)
#define BITS_CDEND_TXTIME_L_8197F \
(BIT_MASK_CDEND_TXTIME_L_8197F << BIT_SHIFT_CDEND_TXTIME_L_8197F)
#define BIT_CLEAR_CDEND_TXTIME_L_8197F(x) ((x) & (~BITS_CDEND_TXTIME_L_8197F))
#define BIT_GET_CDEND_TXTIME_L_8197F(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_L_8197F) & \
BIT_MASK_CDEND_TXTIME_L_8197F)
#define BIT_SET_CDEND_TXTIME_L_8197F(x, v) \
(BIT_CLEAR_CDEND_TXTIME_L_8197F(x) | BIT_CDEND_TXTIME_L_8197F(v))
#define BIT_SHIFT_NESS_8197F 2
#define BIT_MASK_NESS_8197F 0x3
#define BIT_NESS_8197F(x) (((x) & BIT_MASK_NESS_8197F) << BIT_SHIFT_NESS_8197F)
#define BITS_NESS_8197F (BIT_MASK_NESS_8197F << BIT_SHIFT_NESS_8197F)
#define BIT_CLEAR_NESS_8197F(x) ((x) & (~BITS_NESS_8197F))
#define BIT_GET_NESS_8197F(x) \
(((x) >> BIT_SHIFT_NESS_8197F) & BIT_MASK_NESS_8197F)
#define BIT_SET_NESS_8197F(x, v) (BIT_CLEAR_NESS_8197F(x) | BIT_NESS_8197F(v))
#define BIT_SHIFT_STBC_CFEND_8197F 0
#define BIT_MASK_STBC_CFEND_8197F 0x3
#define BIT_STBC_CFEND_8197F(x) \
(((x) & BIT_MASK_STBC_CFEND_8197F) << BIT_SHIFT_STBC_CFEND_8197F)
#define BITS_STBC_CFEND_8197F \
(BIT_MASK_STBC_CFEND_8197F << BIT_SHIFT_STBC_CFEND_8197F)
#define BIT_CLEAR_STBC_CFEND_8197F(x) ((x) & (~BITS_STBC_CFEND_8197F))
#define BIT_GET_STBC_CFEND_8197F(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_8197F) & BIT_MASK_STBC_CFEND_8197F)
#define BIT_SET_STBC_CFEND_8197F(x, v) \
(BIT_CLEAR_STBC_CFEND_8197F(x) | BIT_STBC_CFEND_8197F(v))
/* 2 REG_STBC_SETTING2_8197F */
#define BIT_SHIFT_CDEND_TXTIME_H_8197F 0
#define BIT_MASK_CDEND_TXTIME_H_8197F 0x1f
#define BIT_CDEND_TXTIME_H_8197F(x) \
(((x) & BIT_MASK_CDEND_TXTIME_H_8197F) \
<< BIT_SHIFT_CDEND_TXTIME_H_8197F)
#define BITS_CDEND_TXTIME_H_8197F \
(BIT_MASK_CDEND_TXTIME_H_8197F << BIT_SHIFT_CDEND_TXTIME_H_8197F)
#define BIT_CLEAR_CDEND_TXTIME_H_8197F(x) ((x) & (~BITS_CDEND_TXTIME_H_8197F))
#define BIT_GET_CDEND_TXTIME_H_8197F(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_H_8197F) & \
BIT_MASK_CDEND_TXTIME_H_8197F)
#define BIT_SET_CDEND_TXTIME_H_8197F(x, v) \
(BIT_CLEAR_CDEND_TXTIME_H_8197F(x) | BIT_CDEND_TXTIME_H_8197F(v))
/* 2 REG_QUEUE_CTRL_8197F */
#define BIT_PTA_EDCCA_EN_8197F BIT(5)
#define BIT_PTA_WL_TX_EN_8197F BIT(4)
#define BIT_R_USE_DATA_BW_8197F BIT(3)
#define BIT_TRI_PKT_INT_MODE1_8197F BIT(2)
#define BIT_TRI_PKT_INT_MODE0_8197F BIT(1)
#define BIT_ACQ_MODE_SEL_8197F BIT(0)
/* 2 REG_SINGLE_AMPDU_CTRL_8197F */
#define BIT_EN_SINGLE_APMDU_8197F BIT(7)
/* 2 REG_PROT_MODE_CTRL_8197F */
#define BIT_SHIFT_RTS_MAX_AGG_NUM_8197F 24
#define BIT_MASK_RTS_MAX_AGG_NUM_8197F 0x3f
#define BIT_RTS_MAX_AGG_NUM_8197F(x) \
(((x) & BIT_MASK_RTS_MAX_AGG_NUM_8197F) \
<< BIT_SHIFT_RTS_MAX_AGG_NUM_8197F)
#define BITS_RTS_MAX_AGG_NUM_8197F \
(BIT_MASK_RTS_MAX_AGG_NUM_8197F << BIT_SHIFT_RTS_MAX_AGG_NUM_8197F)
#define BIT_CLEAR_RTS_MAX_AGG_NUM_8197F(x) ((x) & (~BITS_RTS_MAX_AGG_NUM_8197F))
#define BIT_GET_RTS_MAX_AGG_NUM_8197F(x) \
(((x) >> BIT_SHIFT_RTS_MAX_AGG_NUM_8197F) & \
BIT_MASK_RTS_MAX_AGG_NUM_8197F)
#define BIT_SET_RTS_MAX_AGG_NUM_8197F(x, v) \
(BIT_CLEAR_RTS_MAX_AGG_NUM_8197F(x) | BIT_RTS_MAX_AGG_NUM_8197F(v))
#define BIT_SHIFT_MAX_AGG_NUM_8197F 16
#define BIT_MASK_MAX_AGG_NUM_8197F 0x3f
#define BIT_MAX_AGG_NUM_8197F(x) \
(((x) & BIT_MASK_MAX_AGG_NUM_8197F) << BIT_SHIFT_MAX_AGG_NUM_8197F)
#define BITS_MAX_AGG_NUM_8197F \
(BIT_MASK_MAX_AGG_NUM_8197F << BIT_SHIFT_MAX_AGG_NUM_8197F)
#define BIT_CLEAR_MAX_AGG_NUM_8197F(x) ((x) & (~BITS_MAX_AGG_NUM_8197F))
#define BIT_GET_MAX_AGG_NUM_8197F(x) \
(((x) >> BIT_SHIFT_MAX_AGG_NUM_8197F) & BIT_MASK_MAX_AGG_NUM_8197F)
#define BIT_SET_MAX_AGG_NUM_8197F(x, v) \
(BIT_CLEAR_MAX_AGG_NUM_8197F(x) | BIT_MAX_AGG_NUM_8197F(v))
#define BIT_SHIFT_RTS_TXTIME_TH_8197F 8
#define BIT_MASK_RTS_TXTIME_TH_8197F 0xff
#define BIT_RTS_TXTIME_TH_8197F(x) \
(((x) & BIT_MASK_RTS_TXTIME_TH_8197F) << BIT_SHIFT_RTS_TXTIME_TH_8197F)
#define BITS_RTS_TXTIME_TH_8197F \
(BIT_MASK_RTS_TXTIME_TH_8197F << BIT_SHIFT_RTS_TXTIME_TH_8197F)
#define BIT_CLEAR_RTS_TXTIME_TH_8197F(x) ((x) & (~BITS_RTS_TXTIME_TH_8197F))
#define BIT_GET_RTS_TXTIME_TH_8197F(x) \
(((x) >> BIT_SHIFT_RTS_TXTIME_TH_8197F) & BIT_MASK_RTS_TXTIME_TH_8197F)
#define BIT_SET_RTS_TXTIME_TH_8197F(x, v) \
(BIT_CLEAR_RTS_TXTIME_TH_8197F(x) | BIT_RTS_TXTIME_TH_8197F(v))
#define BIT_SHIFT_RTS_LEN_TH_8197F 0
#define BIT_MASK_RTS_LEN_TH_8197F 0xff
#define BIT_RTS_LEN_TH_8197F(x) \
(((x) & BIT_MASK_RTS_LEN_TH_8197F) << BIT_SHIFT_RTS_LEN_TH_8197F)
#define BITS_RTS_LEN_TH_8197F \
(BIT_MASK_RTS_LEN_TH_8197F << BIT_SHIFT_RTS_LEN_TH_8197F)
#define BIT_CLEAR_RTS_LEN_TH_8197F(x) ((x) & (~BITS_RTS_LEN_TH_8197F))
#define BIT_GET_RTS_LEN_TH_8197F(x) \
(((x) >> BIT_SHIFT_RTS_LEN_TH_8197F) & BIT_MASK_RTS_LEN_TH_8197F)
#define BIT_SET_RTS_LEN_TH_8197F(x, v) \
(BIT_CLEAR_RTS_LEN_TH_8197F(x) | BIT_RTS_LEN_TH_8197F(v))
/* 2 REG_BAR_MODE_CTRL_8197F */
#define BIT_SHIFT_BAR_RTY_LMT_8197F 16
#define BIT_MASK_BAR_RTY_LMT_8197F 0x3
#define BIT_BAR_RTY_LMT_8197F(x) \
(((x) & BIT_MASK_BAR_RTY_LMT_8197F) << BIT_SHIFT_BAR_RTY_LMT_8197F)
#define BITS_BAR_RTY_LMT_8197F \
(BIT_MASK_BAR_RTY_LMT_8197F << BIT_SHIFT_BAR_RTY_LMT_8197F)
#define BIT_CLEAR_BAR_RTY_LMT_8197F(x) ((x) & (~BITS_BAR_RTY_LMT_8197F))
#define BIT_GET_BAR_RTY_LMT_8197F(x) \
(((x) >> BIT_SHIFT_BAR_RTY_LMT_8197F) & BIT_MASK_BAR_RTY_LMT_8197F)
#define BIT_SET_BAR_RTY_LMT_8197F(x, v) \
(BIT_CLEAR_BAR_RTY_LMT_8197F(x) | BIT_BAR_RTY_LMT_8197F(v))
#define BIT_SHIFT_BAR_PKT_TXTIME_TH_8197F 8
#define BIT_MASK_BAR_PKT_TXTIME_TH_8197F 0xff
#define BIT_BAR_PKT_TXTIME_TH_8197F(x) \
(((x) & BIT_MASK_BAR_PKT_TXTIME_TH_8197F) \
<< BIT_SHIFT_BAR_PKT_TXTIME_TH_8197F)
#define BITS_BAR_PKT_TXTIME_TH_8197F \
(BIT_MASK_BAR_PKT_TXTIME_TH_8197F << BIT_SHIFT_BAR_PKT_TXTIME_TH_8197F)
#define BIT_CLEAR_BAR_PKT_TXTIME_TH_8197F(x) \
((x) & (~BITS_BAR_PKT_TXTIME_TH_8197F))
#define BIT_GET_BAR_PKT_TXTIME_TH_8197F(x) \
(((x) >> BIT_SHIFT_BAR_PKT_TXTIME_TH_8197F) & \
BIT_MASK_BAR_PKT_TXTIME_TH_8197F)
#define BIT_SET_BAR_PKT_TXTIME_TH_8197F(x, v) \
(BIT_CLEAR_BAR_PKT_TXTIME_TH_8197F(x) | BIT_BAR_PKT_TXTIME_TH_8197F(v))
#define BIT_BAR_EN_V1_8197F BIT(6)
#define BIT_SHIFT_BAR_PKTNUM_TH_V1_8197F 0
#define BIT_MASK_BAR_PKTNUM_TH_V1_8197F 0x3f
#define BIT_BAR_PKTNUM_TH_V1_8197F(x) \
(((x) & BIT_MASK_BAR_PKTNUM_TH_V1_8197F) \
<< BIT_SHIFT_BAR_PKTNUM_TH_V1_8197F)
#define BITS_BAR_PKTNUM_TH_V1_8197F \
(BIT_MASK_BAR_PKTNUM_TH_V1_8197F << BIT_SHIFT_BAR_PKTNUM_TH_V1_8197F)
#define BIT_CLEAR_BAR_PKTNUM_TH_V1_8197F(x) \
((x) & (~BITS_BAR_PKTNUM_TH_V1_8197F))
#define BIT_GET_BAR_PKTNUM_TH_V1_8197F(x) \
(((x) >> BIT_SHIFT_BAR_PKTNUM_TH_V1_8197F) & \
BIT_MASK_BAR_PKTNUM_TH_V1_8197F)
#define BIT_SET_BAR_PKTNUM_TH_V1_8197F(x, v) \
(BIT_CLEAR_BAR_PKTNUM_TH_V1_8197F(x) | BIT_BAR_PKTNUM_TH_V1_8197F(v))
/* 2 REG_RA_TRY_RATE_AGG_LMT_8197F */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8197F 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8197F 0x3f
#define BIT_RA_TRY_RATE_AGG_LMT_V1_8197F(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8197F) \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8197F)
#define BITS_RA_TRY_RATE_AGG_LMT_V1_8197F \
(BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8197F \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8197F)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8197F(x) \
((x) & (~BITS_RA_TRY_RATE_AGG_LMT_V1_8197F))
#define BIT_GET_RA_TRY_RATE_AGG_LMT_V1_8197F(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8197F) & \
BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8197F)
#define BIT_SET_RA_TRY_RATE_AGG_LMT_V1_8197F(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8197F(x) | \
BIT_RA_TRY_RATE_AGG_LMT_V1_8197F(v))
/* 2 REG_MACID_SLEEP2_8197F */
#define BIT_SHIFT_MACID95_64PKTSLEEP_8197F 0
#define BIT_MASK_MACID95_64PKTSLEEP_8197F 0xffffffffL
#define BIT_MACID95_64PKTSLEEP_8197F(x) \
(((x) & BIT_MASK_MACID95_64PKTSLEEP_8197F) \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8197F)
#define BITS_MACID95_64PKTSLEEP_8197F \
(BIT_MASK_MACID95_64PKTSLEEP_8197F \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8197F)
#define BIT_CLEAR_MACID95_64PKTSLEEP_8197F(x) \
((x) & (~BITS_MACID95_64PKTSLEEP_8197F))
#define BIT_GET_MACID95_64PKTSLEEP_8197F(x) \
(((x) >> BIT_SHIFT_MACID95_64PKTSLEEP_8197F) & \
BIT_MASK_MACID95_64PKTSLEEP_8197F)
#define BIT_SET_MACID95_64PKTSLEEP_8197F(x, v) \
(BIT_CLEAR_MACID95_64PKTSLEEP_8197F(x) | \
BIT_MACID95_64PKTSLEEP_8197F(v))
/* 2 REG_MACID_SLEEP_8197F */
#define BIT_SHIFT_MACID31_0_PKTSLEEP_8197F 0
#define BIT_MASK_MACID31_0_PKTSLEEP_8197F 0xffffffffL
#define BIT_MACID31_0_PKTSLEEP_8197F(x) \
(((x) & BIT_MASK_MACID31_0_PKTSLEEP_8197F) \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8197F)
#define BITS_MACID31_0_PKTSLEEP_8197F \
(BIT_MASK_MACID31_0_PKTSLEEP_8197F \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8197F)
#define BIT_CLEAR_MACID31_0_PKTSLEEP_8197F(x) \
((x) & (~BITS_MACID31_0_PKTSLEEP_8197F))
#define BIT_GET_MACID31_0_PKTSLEEP_8197F(x) \
(((x) >> BIT_SHIFT_MACID31_0_PKTSLEEP_8197F) & \
BIT_MASK_MACID31_0_PKTSLEEP_8197F)
#define BIT_SET_MACID31_0_PKTSLEEP_8197F(x, v) \
(BIT_CLEAR_MACID31_0_PKTSLEEP_8197F(x) | \
BIT_MACID31_0_PKTSLEEP_8197F(v))
/* 2 REG_HW_SEQ0_8197F */
#define BIT_SHIFT_HW_SSN_SEQ0_8197F 0
#define BIT_MASK_HW_SSN_SEQ0_8197F 0xfff
#define BIT_HW_SSN_SEQ0_8197F(x) \
(((x) & BIT_MASK_HW_SSN_SEQ0_8197F) << BIT_SHIFT_HW_SSN_SEQ0_8197F)
#define BITS_HW_SSN_SEQ0_8197F \
(BIT_MASK_HW_SSN_SEQ0_8197F << BIT_SHIFT_HW_SSN_SEQ0_8197F)
#define BIT_CLEAR_HW_SSN_SEQ0_8197F(x) ((x) & (~BITS_HW_SSN_SEQ0_8197F))
#define BIT_GET_HW_SSN_SEQ0_8197F(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ0_8197F) & BIT_MASK_HW_SSN_SEQ0_8197F)
#define BIT_SET_HW_SSN_SEQ0_8197F(x, v) \
(BIT_CLEAR_HW_SSN_SEQ0_8197F(x) | BIT_HW_SSN_SEQ0_8197F(v))
/* 2 REG_HW_SEQ1_8197F */
#define BIT_SHIFT_HW_SSN_SEQ1_8197F 0
#define BIT_MASK_HW_SSN_SEQ1_8197F 0xfff
#define BIT_HW_SSN_SEQ1_8197F(x) \
(((x) & BIT_MASK_HW_SSN_SEQ1_8197F) << BIT_SHIFT_HW_SSN_SEQ1_8197F)
#define BITS_HW_SSN_SEQ1_8197F \
(BIT_MASK_HW_SSN_SEQ1_8197F << BIT_SHIFT_HW_SSN_SEQ1_8197F)
#define BIT_CLEAR_HW_SSN_SEQ1_8197F(x) ((x) & (~BITS_HW_SSN_SEQ1_8197F))
#define BIT_GET_HW_SSN_SEQ1_8197F(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ1_8197F) & BIT_MASK_HW_SSN_SEQ1_8197F)
#define BIT_SET_HW_SSN_SEQ1_8197F(x, v) \
(BIT_CLEAR_HW_SSN_SEQ1_8197F(x) | BIT_HW_SSN_SEQ1_8197F(v))
/* 2 REG_HW_SEQ2_8197F */
#define BIT_SHIFT_HW_SSN_SEQ2_8197F 0
#define BIT_MASK_HW_SSN_SEQ2_8197F 0xfff
#define BIT_HW_SSN_SEQ2_8197F(x) \
(((x) & BIT_MASK_HW_SSN_SEQ2_8197F) << BIT_SHIFT_HW_SSN_SEQ2_8197F)
#define BITS_HW_SSN_SEQ2_8197F \
(BIT_MASK_HW_SSN_SEQ2_8197F << BIT_SHIFT_HW_SSN_SEQ2_8197F)
#define BIT_CLEAR_HW_SSN_SEQ2_8197F(x) ((x) & (~BITS_HW_SSN_SEQ2_8197F))
#define BIT_GET_HW_SSN_SEQ2_8197F(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ2_8197F) & BIT_MASK_HW_SSN_SEQ2_8197F)
#define BIT_SET_HW_SSN_SEQ2_8197F(x, v) \
(BIT_CLEAR_HW_SSN_SEQ2_8197F(x) | BIT_HW_SSN_SEQ2_8197F(v))
/* 2 REG_HW_SEQ3_8197F */
#define BIT_SHIFT_CSI_HWSSN_SEL_8197F 12
#define BIT_MASK_CSI_HWSSN_SEL_8197F 0x3
#define BIT_CSI_HWSSN_SEL_8197F(x) \
(((x) & BIT_MASK_CSI_HWSSN_SEL_8197F) << BIT_SHIFT_CSI_HWSSN_SEL_8197F)
#define BITS_CSI_HWSSN_SEL_8197F \
(BIT_MASK_CSI_HWSSN_SEL_8197F << BIT_SHIFT_CSI_HWSSN_SEL_8197F)
#define BIT_CLEAR_CSI_HWSSN_SEL_8197F(x) ((x) & (~BITS_CSI_HWSSN_SEL_8197F))
#define BIT_GET_CSI_HWSSN_SEL_8197F(x) \
(((x) >> BIT_SHIFT_CSI_HWSSN_SEL_8197F) & BIT_MASK_CSI_HWSSN_SEL_8197F)
#define BIT_SET_CSI_HWSSN_SEL_8197F(x, v) \
(BIT_CLEAR_CSI_HWSSN_SEL_8197F(x) | BIT_CSI_HWSSN_SEL_8197F(v))
#define BIT_SHIFT_HW_SSN_SEQ3_8197F 0
#define BIT_MASK_HW_SSN_SEQ3_8197F 0xfff
#define BIT_HW_SSN_SEQ3_8197F(x) \
(((x) & BIT_MASK_HW_SSN_SEQ3_8197F) << BIT_SHIFT_HW_SSN_SEQ3_8197F)
#define BITS_HW_SSN_SEQ3_8197F \
(BIT_MASK_HW_SSN_SEQ3_8197F << BIT_SHIFT_HW_SSN_SEQ3_8197F)
#define BIT_CLEAR_HW_SSN_SEQ3_8197F(x) ((x) & (~BITS_HW_SSN_SEQ3_8197F))
#define BIT_GET_HW_SSN_SEQ3_8197F(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ3_8197F) & BIT_MASK_HW_SSN_SEQ3_8197F)
#define BIT_SET_HW_SSN_SEQ3_8197F(x, v) \
(BIT_CLEAR_HW_SSN_SEQ3_8197F(x) | BIT_HW_SSN_SEQ3_8197F(v))
/* 2 REG_NULL_PKT_STATUS_V1_8197F */
#define BIT_SHIFT_PTCL_TOTAL_PG_V1_8197F 2
#define BIT_MASK_PTCL_TOTAL_PG_V1_8197F 0x1fff
#define BIT_PTCL_TOTAL_PG_V1_8197F(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V1_8197F) \
<< BIT_SHIFT_PTCL_TOTAL_PG_V1_8197F)
#define BITS_PTCL_TOTAL_PG_V1_8197F \
(BIT_MASK_PTCL_TOTAL_PG_V1_8197F << BIT_SHIFT_PTCL_TOTAL_PG_V1_8197F)
#define BIT_CLEAR_PTCL_TOTAL_PG_V1_8197F(x) \
((x) & (~BITS_PTCL_TOTAL_PG_V1_8197F))
#define BIT_GET_PTCL_TOTAL_PG_V1_8197F(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V1_8197F) & \
BIT_MASK_PTCL_TOTAL_PG_V1_8197F)
#define BIT_SET_PTCL_TOTAL_PG_V1_8197F(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V1_8197F(x) | BIT_PTCL_TOTAL_PG_V1_8197F(v))
#define BIT_TX_NULL_1_8197F BIT(1)
#define BIT_TX_NULL_0_8197F BIT(0)
/* 2 REG_PTCL_ERR_STATUS_8197F */
#define BIT_PTCL_RATE_TABLE_INVALID_8197F BIT(7)
#define BIT_FTM_T2R_ERROR_8197F BIT(6)
#define BIT_PTCL_ERR0_8197F BIT(5)
#define BIT_PTCL_ERR1_8197F BIT(4)
#define BIT_PTCL_ERR2_8197F BIT(3)
#define BIT_PTCL_ERR3_8197F BIT(2)
#define BIT_PTCL_ERR4_8197F BIT(1)
#define BIT_PTCL_ERR5_8197F BIT(0)
/* 2 REG_NULL_PKT_STATUS_EXTEND_8197F */
#define BIT_CLI3_TX_NULL_1_8197F BIT(7)
#define BIT_CLI3_TX_NULL_0_8197F BIT(6)
#define BIT_CLI2_TX_NULL_1_8197F BIT(5)
#define BIT_CLI2_TX_NULL_0_8197F BIT(4)
#define BIT_CLI1_TX_NULL_1_8197F BIT(3)
#define BIT_CLI1_TX_NULL_0_8197F BIT(2)
#define BIT_CLI0_TX_NULL_1_8197F BIT(1)
#define BIT_CLI0_TX_NULL_0_8197F BIT(0)
/* 2 REG_VIDEO_ENHANCEMENT_FUN_8197F */
#define BIT_VIDEO_JUST_DROP_8197F BIT(1)
#define BIT_VIDEO_ENHANCEMENT_FUN_EN_8197F BIT(0)
/* 2 REG_BT_POLLUTE_PKT_CNT_8197F */
#define BIT_SHIFT_BT_POLLUTE_PKT_CNT_8197F 0
#define BIT_MASK_BT_POLLUTE_PKT_CNT_8197F 0xffff
#define BIT_BT_POLLUTE_PKT_CNT_8197F(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKT_CNT_8197F) \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8197F)
#define BITS_BT_POLLUTE_PKT_CNT_8197F \
(BIT_MASK_BT_POLLUTE_PKT_CNT_8197F \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8197F)
#define BIT_CLEAR_BT_POLLUTE_PKT_CNT_8197F(x) \
((x) & (~BITS_BT_POLLUTE_PKT_CNT_8197F))
#define BIT_GET_BT_POLLUTE_PKT_CNT_8197F(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKT_CNT_8197F) & \
BIT_MASK_BT_POLLUTE_PKT_CNT_8197F)
#define BIT_SET_BT_POLLUTE_PKT_CNT_8197F(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKT_CNT_8197F(x) | \
BIT_BT_POLLUTE_PKT_CNT_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_PTCL_DBG_8197F */
#define BIT_SHIFT_PTCL_DBG_8197F 0
#define BIT_MASK_PTCL_DBG_8197F 0xffffffffL
#define BIT_PTCL_DBG_8197F(x) \
(((x) & BIT_MASK_PTCL_DBG_8197F) << BIT_SHIFT_PTCL_DBG_8197F)
#define BITS_PTCL_DBG_8197F \
(BIT_MASK_PTCL_DBG_8197F << BIT_SHIFT_PTCL_DBG_8197F)
#define BIT_CLEAR_PTCL_DBG_8197F(x) ((x) & (~BITS_PTCL_DBG_8197F))
#define BIT_GET_PTCL_DBG_8197F(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_8197F) & BIT_MASK_PTCL_DBG_8197F)
#define BIT_SET_PTCL_DBG_8197F(x, v) \
(BIT_CLEAR_PTCL_DBG_8197F(x) | BIT_PTCL_DBG_8197F(v))
/* 2 REG_TXOP_EXTRA_CTRL_8197F */
#define BIT_TXOP_EFFICIENCY_EN_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_CPUMGQ_TIMER_CTRL2_8197F */
#define BIT_SHIFT_TRI_HEAD_ADDR_8197F 16
#define BIT_MASK_TRI_HEAD_ADDR_8197F 0xfff
#define BIT_TRI_HEAD_ADDR_8197F(x) \
(((x) & BIT_MASK_TRI_HEAD_ADDR_8197F) << BIT_SHIFT_TRI_HEAD_ADDR_8197F)
#define BITS_TRI_HEAD_ADDR_8197F \
(BIT_MASK_TRI_HEAD_ADDR_8197F << BIT_SHIFT_TRI_HEAD_ADDR_8197F)
#define BIT_CLEAR_TRI_HEAD_ADDR_8197F(x) ((x) & (~BITS_TRI_HEAD_ADDR_8197F))
#define BIT_GET_TRI_HEAD_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_TRI_HEAD_ADDR_8197F) & BIT_MASK_TRI_HEAD_ADDR_8197F)
#define BIT_SET_TRI_HEAD_ADDR_8197F(x, v) \
(BIT_CLEAR_TRI_HEAD_ADDR_8197F(x) | BIT_TRI_HEAD_ADDR_8197F(v))
#define BIT_DROP_TH_EN_8197F BIT(8)
#define BIT_SHIFT_DROP_TH_8197F 0
#define BIT_MASK_DROP_TH_8197F 0xff
#define BIT_DROP_TH_8197F(x) \
(((x) & BIT_MASK_DROP_TH_8197F) << BIT_SHIFT_DROP_TH_8197F)
#define BITS_DROP_TH_8197F (BIT_MASK_DROP_TH_8197F << BIT_SHIFT_DROP_TH_8197F)
#define BIT_CLEAR_DROP_TH_8197F(x) ((x) & (~BITS_DROP_TH_8197F))
#define BIT_GET_DROP_TH_8197F(x) \
(((x) >> BIT_SHIFT_DROP_TH_8197F) & BIT_MASK_DROP_TH_8197F)
#define BIT_SET_DROP_TH_8197F(x, v) \
(BIT_CLEAR_DROP_TH_8197F(x) | BIT_DROP_TH_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_DUMMY_PAGE4_8197F */
#define BIT_MOREDATA_CTRL2_EN_V2_8197F BIT(19)
#define BIT_MOREDATA_CTRL1_EN_V2_8197F BIT(18)
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE_8197F BIT(16)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_Q0_Q1_INFO_8197F */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8197F BIT(31)
#define BIT_SHIFT_GTAB_ID_8197F 28
#define BIT_MASK_GTAB_ID_8197F 0x7
#define BIT_GTAB_ID_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_8197F) << BIT_SHIFT_GTAB_ID_8197F)
#define BITS_GTAB_ID_8197F (BIT_MASK_GTAB_ID_8197F << BIT_SHIFT_GTAB_ID_8197F)
#define BIT_CLEAR_GTAB_ID_8197F(x) ((x) & (~BITS_GTAB_ID_8197F))
#define BIT_GET_GTAB_ID_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8197F) & BIT_MASK_GTAB_ID_8197F)
#define BIT_SET_GTAB_ID_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_8197F(x) | BIT_GTAB_ID_8197F(v))
#define BIT_SHIFT_AC1_PKT_INFO_8197F 16
#define BIT_MASK_AC1_PKT_INFO_8197F 0xfff
#define BIT_AC1_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC1_PKT_INFO_8197F) << BIT_SHIFT_AC1_PKT_INFO_8197F)
#define BITS_AC1_PKT_INFO_8197F \
(BIT_MASK_AC1_PKT_INFO_8197F << BIT_SHIFT_AC1_PKT_INFO_8197F)
#define BIT_CLEAR_AC1_PKT_INFO_8197F(x) ((x) & (~BITS_AC1_PKT_INFO_8197F))
#define BIT_GET_AC1_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC1_PKT_INFO_8197F) & BIT_MASK_AC1_PKT_INFO_8197F)
#define BIT_SET_AC1_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC1_PKT_INFO_8197F(x) | BIT_AC1_PKT_INFO_8197F(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8197F BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8197F 12
#define BIT_MASK_GTAB_ID_V1_8197F 0x7
#define BIT_GTAB_ID_V1_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8197F) << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BITS_GTAB_ID_V1_8197F \
(BIT_MASK_GTAB_ID_V1_8197F << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BIT_CLEAR_GTAB_ID_V1_8197F(x) ((x) & (~BITS_GTAB_ID_V1_8197F))
#define BIT_GET_GTAB_ID_V1_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8197F) & BIT_MASK_GTAB_ID_V1_8197F)
#define BIT_SET_GTAB_ID_V1_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8197F(x) | BIT_GTAB_ID_V1_8197F(v))
#define BIT_SHIFT_AC0_PKT_INFO_8197F 0
#define BIT_MASK_AC0_PKT_INFO_8197F 0xfff
#define BIT_AC0_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC0_PKT_INFO_8197F) << BIT_SHIFT_AC0_PKT_INFO_8197F)
#define BITS_AC0_PKT_INFO_8197F \
(BIT_MASK_AC0_PKT_INFO_8197F << BIT_SHIFT_AC0_PKT_INFO_8197F)
#define BIT_CLEAR_AC0_PKT_INFO_8197F(x) ((x) & (~BITS_AC0_PKT_INFO_8197F))
#define BIT_GET_AC0_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC0_PKT_INFO_8197F) & BIT_MASK_AC0_PKT_INFO_8197F)
#define BIT_SET_AC0_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC0_PKT_INFO_8197F(x) | BIT_AC0_PKT_INFO_8197F(v))
/* 2 REG_Q2_Q3_INFO_8197F */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8197F BIT(31)
#define BIT_SHIFT_GTAB_ID_8197F 28
#define BIT_MASK_GTAB_ID_8197F 0x7
#define BIT_GTAB_ID_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_8197F) << BIT_SHIFT_GTAB_ID_8197F)
#define BITS_GTAB_ID_8197F (BIT_MASK_GTAB_ID_8197F << BIT_SHIFT_GTAB_ID_8197F)
#define BIT_CLEAR_GTAB_ID_8197F(x) ((x) & (~BITS_GTAB_ID_8197F))
#define BIT_GET_GTAB_ID_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8197F) & BIT_MASK_GTAB_ID_8197F)
#define BIT_SET_GTAB_ID_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_8197F(x) | BIT_GTAB_ID_8197F(v))
#define BIT_SHIFT_AC3_PKT_INFO_8197F 16
#define BIT_MASK_AC3_PKT_INFO_8197F 0xfff
#define BIT_AC3_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC3_PKT_INFO_8197F) << BIT_SHIFT_AC3_PKT_INFO_8197F)
#define BITS_AC3_PKT_INFO_8197F \
(BIT_MASK_AC3_PKT_INFO_8197F << BIT_SHIFT_AC3_PKT_INFO_8197F)
#define BIT_CLEAR_AC3_PKT_INFO_8197F(x) ((x) & (~BITS_AC3_PKT_INFO_8197F))
#define BIT_GET_AC3_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC3_PKT_INFO_8197F) & BIT_MASK_AC3_PKT_INFO_8197F)
#define BIT_SET_AC3_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC3_PKT_INFO_8197F(x) | BIT_AC3_PKT_INFO_8197F(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8197F BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8197F 12
#define BIT_MASK_GTAB_ID_V1_8197F 0x7
#define BIT_GTAB_ID_V1_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8197F) << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BITS_GTAB_ID_V1_8197F \
(BIT_MASK_GTAB_ID_V1_8197F << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BIT_CLEAR_GTAB_ID_V1_8197F(x) ((x) & (~BITS_GTAB_ID_V1_8197F))
#define BIT_GET_GTAB_ID_V1_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8197F) & BIT_MASK_GTAB_ID_V1_8197F)
#define BIT_SET_GTAB_ID_V1_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8197F(x) | BIT_GTAB_ID_V1_8197F(v))
#define BIT_SHIFT_AC2_PKT_INFO_8197F 0
#define BIT_MASK_AC2_PKT_INFO_8197F 0xfff
#define BIT_AC2_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC2_PKT_INFO_8197F) << BIT_SHIFT_AC2_PKT_INFO_8197F)
#define BITS_AC2_PKT_INFO_8197F \
(BIT_MASK_AC2_PKT_INFO_8197F << BIT_SHIFT_AC2_PKT_INFO_8197F)
#define BIT_CLEAR_AC2_PKT_INFO_8197F(x) ((x) & (~BITS_AC2_PKT_INFO_8197F))
#define BIT_GET_AC2_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC2_PKT_INFO_8197F) & BIT_MASK_AC2_PKT_INFO_8197F)
#define BIT_SET_AC2_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC2_PKT_INFO_8197F(x) | BIT_AC2_PKT_INFO_8197F(v))
/* 2 REG_Q4_Q5_INFO_8197F */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8197F BIT(31)
#define BIT_SHIFT_GTAB_ID_8197F 28
#define BIT_MASK_GTAB_ID_8197F 0x7
#define BIT_GTAB_ID_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_8197F) << BIT_SHIFT_GTAB_ID_8197F)
#define BITS_GTAB_ID_8197F (BIT_MASK_GTAB_ID_8197F << BIT_SHIFT_GTAB_ID_8197F)
#define BIT_CLEAR_GTAB_ID_8197F(x) ((x) & (~BITS_GTAB_ID_8197F))
#define BIT_GET_GTAB_ID_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8197F) & BIT_MASK_GTAB_ID_8197F)
#define BIT_SET_GTAB_ID_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_8197F(x) | BIT_GTAB_ID_8197F(v))
#define BIT_SHIFT_AC5_PKT_INFO_8197F 16
#define BIT_MASK_AC5_PKT_INFO_8197F 0xfff
#define BIT_AC5_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC5_PKT_INFO_8197F) << BIT_SHIFT_AC5_PKT_INFO_8197F)
#define BITS_AC5_PKT_INFO_8197F \
(BIT_MASK_AC5_PKT_INFO_8197F << BIT_SHIFT_AC5_PKT_INFO_8197F)
#define BIT_CLEAR_AC5_PKT_INFO_8197F(x) ((x) & (~BITS_AC5_PKT_INFO_8197F))
#define BIT_GET_AC5_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC5_PKT_INFO_8197F) & BIT_MASK_AC5_PKT_INFO_8197F)
#define BIT_SET_AC5_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC5_PKT_INFO_8197F(x) | BIT_AC5_PKT_INFO_8197F(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8197F BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8197F 12
#define BIT_MASK_GTAB_ID_V1_8197F 0x7
#define BIT_GTAB_ID_V1_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8197F) << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BITS_GTAB_ID_V1_8197F \
(BIT_MASK_GTAB_ID_V1_8197F << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BIT_CLEAR_GTAB_ID_V1_8197F(x) ((x) & (~BITS_GTAB_ID_V1_8197F))
#define BIT_GET_GTAB_ID_V1_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8197F) & BIT_MASK_GTAB_ID_V1_8197F)
#define BIT_SET_GTAB_ID_V1_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8197F(x) | BIT_GTAB_ID_V1_8197F(v))
#define BIT_SHIFT_AC4_PKT_INFO_8197F 0
#define BIT_MASK_AC4_PKT_INFO_8197F 0xfff
#define BIT_AC4_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC4_PKT_INFO_8197F) << BIT_SHIFT_AC4_PKT_INFO_8197F)
#define BITS_AC4_PKT_INFO_8197F \
(BIT_MASK_AC4_PKT_INFO_8197F << BIT_SHIFT_AC4_PKT_INFO_8197F)
#define BIT_CLEAR_AC4_PKT_INFO_8197F(x) ((x) & (~BITS_AC4_PKT_INFO_8197F))
#define BIT_GET_AC4_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC4_PKT_INFO_8197F) & BIT_MASK_AC4_PKT_INFO_8197F)
#define BIT_SET_AC4_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC4_PKT_INFO_8197F(x) | BIT_AC4_PKT_INFO_8197F(v))
/* 2 REG_Q6_Q7_INFO_8197F */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8197F BIT(31)
#define BIT_SHIFT_GTAB_ID_8197F 28
#define BIT_MASK_GTAB_ID_8197F 0x7
#define BIT_GTAB_ID_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_8197F) << BIT_SHIFT_GTAB_ID_8197F)
#define BITS_GTAB_ID_8197F (BIT_MASK_GTAB_ID_8197F << BIT_SHIFT_GTAB_ID_8197F)
#define BIT_CLEAR_GTAB_ID_8197F(x) ((x) & (~BITS_GTAB_ID_8197F))
#define BIT_GET_GTAB_ID_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8197F) & BIT_MASK_GTAB_ID_8197F)
#define BIT_SET_GTAB_ID_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_8197F(x) | BIT_GTAB_ID_8197F(v))
#define BIT_SHIFT_AC7_PKT_INFO_8197F 16
#define BIT_MASK_AC7_PKT_INFO_8197F 0xfff
#define BIT_AC7_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC7_PKT_INFO_8197F) << BIT_SHIFT_AC7_PKT_INFO_8197F)
#define BITS_AC7_PKT_INFO_8197F \
(BIT_MASK_AC7_PKT_INFO_8197F << BIT_SHIFT_AC7_PKT_INFO_8197F)
#define BIT_CLEAR_AC7_PKT_INFO_8197F(x) ((x) & (~BITS_AC7_PKT_INFO_8197F))
#define BIT_GET_AC7_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC7_PKT_INFO_8197F) & BIT_MASK_AC7_PKT_INFO_8197F)
#define BIT_SET_AC7_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC7_PKT_INFO_8197F(x) | BIT_AC7_PKT_INFO_8197F(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8197F BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8197F 12
#define BIT_MASK_GTAB_ID_V1_8197F 0x7
#define BIT_GTAB_ID_V1_8197F(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8197F) << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BITS_GTAB_ID_V1_8197F \
(BIT_MASK_GTAB_ID_V1_8197F << BIT_SHIFT_GTAB_ID_V1_8197F)
#define BIT_CLEAR_GTAB_ID_V1_8197F(x) ((x) & (~BITS_GTAB_ID_V1_8197F))
#define BIT_GET_GTAB_ID_V1_8197F(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8197F) & BIT_MASK_GTAB_ID_V1_8197F)
#define BIT_SET_GTAB_ID_V1_8197F(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8197F(x) | BIT_GTAB_ID_V1_8197F(v))
#define BIT_SHIFT_AC6_PKT_INFO_8197F 0
#define BIT_MASK_AC6_PKT_INFO_8197F 0xfff
#define BIT_AC6_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_AC6_PKT_INFO_8197F) << BIT_SHIFT_AC6_PKT_INFO_8197F)
#define BITS_AC6_PKT_INFO_8197F \
(BIT_MASK_AC6_PKT_INFO_8197F << BIT_SHIFT_AC6_PKT_INFO_8197F)
#define BIT_CLEAR_AC6_PKT_INFO_8197F(x) ((x) & (~BITS_AC6_PKT_INFO_8197F))
#define BIT_GET_AC6_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_AC6_PKT_INFO_8197F) & BIT_MASK_AC6_PKT_INFO_8197F)
#define BIT_SET_AC6_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_AC6_PKT_INFO_8197F(x) | BIT_AC6_PKT_INFO_8197F(v))
/* 2 REG_MGQ_HIQ_INFO_8197F */
#define BIT_SHIFT_HIQ_PKT_INFO_8197F 16
#define BIT_MASK_HIQ_PKT_INFO_8197F 0xfff
#define BIT_HIQ_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_HIQ_PKT_INFO_8197F) << BIT_SHIFT_HIQ_PKT_INFO_8197F)
#define BITS_HIQ_PKT_INFO_8197F \
(BIT_MASK_HIQ_PKT_INFO_8197F << BIT_SHIFT_HIQ_PKT_INFO_8197F)
#define BIT_CLEAR_HIQ_PKT_INFO_8197F(x) ((x) & (~BITS_HIQ_PKT_INFO_8197F))
#define BIT_GET_HIQ_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_HIQ_PKT_INFO_8197F) & BIT_MASK_HIQ_PKT_INFO_8197F)
#define BIT_SET_HIQ_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_HIQ_PKT_INFO_8197F(x) | BIT_HIQ_PKT_INFO_8197F(v))
#define BIT_SHIFT_MGQ_PKT_INFO_8197F 0
#define BIT_MASK_MGQ_PKT_INFO_8197F 0xfff
#define BIT_MGQ_PKT_INFO_8197F(x) \
(((x) & BIT_MASK_MGQ_PKT_INFO_8197F) << BIT_SHIFT_MGQ_PKT_INFO_8197F)
#define BITS_MGQ_PKT_INFO_8197F \
(BIT_MASK_MGQ_PKT_INFO_8197F << BIT_SHIFT_MGQ_PKT_INFO_8197F)
#define BIT_CLEAR_MGQ_PKT_INFO_8197F(x) ((x) & (~BITS_MGQ_PKT_INFO_8197F))
#define BIT_GET_MGQ_PKT_INFO_8197F(x) \
(((x) >> BIT_SHIFT_MGQ_PKT_INFO_8197F) & BIT_MASK_MGQ_PKT_INFO_8197F)
#define BIT_SET_MGQ_PKT_INFO_8197F(x, v) \
(BIT_CLEAR_MGQ_PKT_INFO_8197F(x) | BIT_MGQ_PKT_INFO_8197F(v))
/* 2 REG_CMDQ_BCNQ_INFO_8197F */
#define BIT_SHIFT_BCNQ_PKT_INFO_V1_8197F 16
#define BIT_MASK_BCNQ_PKT_INFO_V1_8197F 0xfff
#define BIT_BCNQ_PKT_INFO_V1_8197F(x) \
(((x) & BIT_MASK_BCNQ_PKT_INFO_V1_8197F) \
<< BIT_SHIFT_BCNQ_PKT_INFO_V1_8197F)
#define BITS_BCNQ_PKT_INFO_V1_8197F \
(BIT_MASK_BCNQ_PKT_INFO_V1_8197F << BIT_SHIFT_BCNQ_PKT_INFO_V1_8197F)
#define BIT_CLEAR_BCNQ_PKT_INFO_V1_8197F(x) \
((x) & (~BITS_BCNQ_PKT_INFO_V1_8197F))
#define BIT_GET_BCNQ_PKT_INFO_V1_8197F(x) \
(((x) >> BIT_SHIFT_BCNQ_PKT_INFO_V1_8197F) & \
BIT_MASK_BCNQ_PKT_INFO_V1_8197F)
#define BIT_SET_BCNQ_PKT_INFO_V1_8197F(x, v) \
(BIT_CLEAR_BCNQ_PKT_INFO_V1_8197F(x) | BIT_BCNQ_PKT_INFO_V1_8197F(v))
#define BIT_SHIFT_CMDQ_PKT_INFO_V1_8197F 0
#define BIT_MASK_CMDQ_PKT_INFO_V1_8197F 0xfff
#define BIT_CMDQ_PKT_INFO_V1_8197F(x) \
(((x) & BIT_MASK_CMDQ_PKT_INFO_V1_8197F) \
<< BIT_SHIFT_CMDQ_PKT_INFO_V1_8197F)
#define BITS_CMDQ_PKT_INFO_V1_8197F \
(BIT_MASK_CMDQ_PKT_INFO_V1_8197F << BIT_SHIFT_CMDQ_PKT_INFO_V1_8197F)
#define BIT_CLEAR_CMDQ_PKT_INFO_V1_8197F(x) \
((x) & (~BITS_CMDQ_PKT_INFO_V1_8197F))
#define BIT_GET_CMDQ_PKT_INFO_V1_8197F(x) \
(((x) >> BIT_SHIFT_CMDQ_PKT_INFO_V1_8197F) & \
BIT_MASK_CMDQ_PKT_INFO_V1_8197F)
#define BIT_SET_CMDQ_PKT_INFO_V1_8197F(x, v) \
(BIT_CLEAR_CMDQ_PKT_INFO_V1_8197F(x) | BIT_CMDQ_PKT_INFO_V1_8197F(v))
/* 2 REG_USEREG_SETTING_8197F */
#define BIT_NDPA_USEREG_8197F BIT(21)
#define BIT_SHIFT_RETRY_USEREG_8197F 19
#define BIT_MASK_RETRY_USEREG_8197F 0x3
#define BIT_RETRY_USEREG_8197F(x) \
(((x) & BIT_MASK_RETRY_USEREG_8197F) << BIT_SHIFT_RETRY_USEREG_8197F)
#define BITS_RETRY_USEREG_8197F \
(BIT_MASK_RETRY_USEREG_8197F << BIT_SHIFT_RETRY_USEREG_8197F)
#define BIT_CLEAR_RETRY_USEREG_8197F(x) ((x) & (~BITS_RETRY_USEREG_8197F))
#define BIT_GET_RETRY_USEREG_8197F(x) \
(((x) >> BIT_SHIFT_RETRY_USEREG_8197F) & BIT_MASK_RETRY_USEREG_8197F)
#define BIT_SET_RETRY_USEREG_8197F(x, v) \
(BIT_CLEAR_RETRY_USEREG_8197F(x) | BIT_RETRY_USEREG_8197F(v))
#define BIT_SHIFT_TRYPKT_USEREG_8197F 17
#define BIT_MASK_TRYPKT_USEREG_8197F 0x3
#define BIT_TRYPKT_USEREG_8197F(x) \
(((x) & BIT_MASK_TRYPKT_USEREG_8197F) << BIT_SHIFT_TRYPKT_USEREG_8197F)
#define BITS_TRYPKT_USEREG_8197F \
(BIT_MASK_TRYPKT_USEREG_8197F << BIT_SHIFT_TRYPKT_USEREG_8197F)
#define BIT_CLEAR_TRYPKT_USEREG_8197F(x) ((x) & (~BITS_TRYPKT_USEREG_8197F))
#define BIT_GET_TRYPKT_USEREG_8197F(x) \
(((x) >> BIT_SHIFT_TRYPKT_USEREG_8197F) & BIT_MASK_TRYPKT_USEREG_8197F)
#define BIT_SET_TRYPKT_USEREG_8197F(x, v) \
(BIT_CLEAR_TRYPKT_USEREG_8197F(x) | BIT_TRYPKT_USEREG_8197F(v))
#define BIT_CTLPKT_USEREG_8197F BIT(16)
/* 2 REG_AESIV_SETTING_8197F */
#define BIT_SHIFT_AESIV_OFFSET_8197F 0
#define BIT_MASK_AESIV_OFFSET_8197F 0xfff
#define BIT_AESIV_OFFSET_8197F(x) \
(((x) & BIT_MASK_AESIV_OFFSET_8197F) << BIT_SHIFT_AESIV_OFFSET_8197F)
#define BITS_AESIV_OFFSET_8197F \
(BIT_MASK_AESIV_OFFSET_8197F << BIT_SHIFT_AESIV_OFFSET_8197F)
#define BIT_CLEAR_AESIV_OFFSET_8197F(x) ((x) & (~BITS_AESIV_OFFSET_8197F))
#define BIT_GET_AESIV_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_AESIV_OFFSET_8197F) & BIT_MASK_AESIV_OFFSET_8197F)
#define BIT_SET_AESIV_OFFSET_8197F(x, v) \
(BIT_CLEAR_AESIV_OFFSET_8197F(x) | BIT_AESIV_OFFSET_8197F(v))
/* 2 REG_BF0_TIME_SETTING_8197F */
#define BIT_BF0_TIMER_SET_8197F BIT(31)
#define BIT_BF0_TIMER_CLR_8197F BIT(30)
#define BIT_BF0_UPDATE_EN_8197F BIT(29)
#define BIT_BF0_TIMER_EN_8197F BIT(28)
#define BIT_SHIFT_BF0_PRETIME_OVER_8197F 16
#define BIT_MASK_BF0_PRETIME_OVER_8197F 0xfff
#define BIT_BF0_PRETIME_OVER_8197F(x) \
(((x) & BIT_MASK_BF0_PRETIME_OVER_8197F) \
<< BIT_SHIFT_BF0_PRETIME_OVER_8197F)
#define BITS_BF0_PRETIME_OVER_8197F \
(BIT_MASK_BF0_PRETIME_OVER_8197F << BIT_SHIFT_BF0_PRETIME_OVER_8197F)
#define BIT_CLEAR_BF0_PRETIME_OVER_8197F(x) \
((x) & (~BITS_BF0_PRETIME_OVER_8197F))
#define BIT_GET_BF0_PRETIME_OVER_8197F(x) \
(((x) >> BIT_SHIFT_BF0_PRETIME_OVER_8197F) & \
BIT_MASK_BF0_PRETIME_OVER_8197F)
#define BIT_SET_BF0_PRETIME_OVER_8197F(x, v) \
(BIT_CLEAR_BF0_PRETIME_OVER_8197F(x) | BIT_BF0_PRETIME_OVER_8197F(v))
#define BIT_SHIFT_BF0_LIFETIME_8197F 0
#define BIT_MASK_BF0_LIFETIME_8197F 0xffff
#define BIT_BF0_LIFETIME_8197F(x) \
(((x) & BIT_MASK_BF0_LIFETIME_8197F) << BIT_SHIFT_BF0_LIFETIME_8197F)
#define BITS_BF0_LIFETIME_8197F \
(BIT_MASK_BF0_LIFETIME_8197F << BIT_SHIFT_BF0_LIFETIME_8197F)
#define BIT_CLEAR_BF0_LIFETIME_8197F(x) ((x) & (~BITS_BF0_LIFETIME_8197F))
#define BIT_GET_BF0_LIFETIME_8197F(x) \
(((x) >> BIT_SHIFT_BF0_LIFETIME_8197F) & BIT_MASK_BF0_LIFETIME_8197F)
#define BIT_SET_BF0_LIFETIME_8197F(x, v) \
(BIT_CLEAR_BF0_LIFETIME_8197F(x) | BIT_BF0_LIFETIME_8197F(v))
/* 2 REG_BF1_TIME_SETTING_8197F */
#define BIT_BF1_TIMER_SET_8197F BIT(31)
#define BIT_BF1_TIMER_CLR_8197F BIT(30)
#define BIT_BF1_UPDATE_EN_8197F BIT(29)
#define BIT_BF1_TIMER_EN_8197F BIT(28)
#define BIT_SHIFT_BF1_PRETIME_OVER_8197F 16
#define BIT_MASK_BF1_PRETIME_OVER_8197F 0xfff
#define BIT_BF1_PRETIME_OVER_8197F(x) \
(((x) & BIT_MASK_BF1_PRETIME_OVER_8197F) \
<< BIT_SHIFT_BF1_PRETIME_OVER_8197F)
#define BITS_BF1_PRETIME_OVER_8197F \
(BIT_MASK_BF1_PRETIME_OVER_8197F << BIT_SHIFT_BF1_PRETIME_OVER_8197F)
#define BIT_CLEAR_BF1_PRETIME_OVER_8197F(x) \
((x) & (~BITS_BF1_PRETIME_OVER_8197F))
#define BIT_GET_BF1_PRETIME_OVER_8197F(x) \
(((x) >> BIT_SHIFT_BF1_PRETIME_OVER_8197F) & \
BIT_MASK_BF1_PRETIME_OVER_8197F)
#define BIT_SET_BF1_PRETIME_OVER_8197F(x, v) \
(BIT_CLEAR_BF1_PRETIME_OVER_8197F(x) | BIT_BF1_PRETIME_OVER_8197F(v))
#define BIT_SHIFT_BF1_LIFETIME_8197F 0
#define BIT_MASK_BF1_LIFETIME_8197F 0xffff
#define BIT_BF1_LIFETIME_8197F(x) \
(((x) & BIT_MASK_BF1_LIFETIME_8197F) << BIT_SHIFT_BF1_LIFETIME_8197F)
#define BITS_BF1_LIFETIME_8197F \
(BIT_MASK_BF1_LIFETIME_8197F << BIT_SHIFT_BF1_LIFETIME_8197F)
#define BIT_CLEAR_BF1_LIFETIME_8197F(x) ((x) & (~BITS_BF1_LIFETIME_8197F))
#define BIT_GET_BF1_LIFETIME_8197F(x) \
(((x) >> BIT_SHIFT_BF1_LIFETIME_8197F) & BIT_MASK_BF1_LIFETIME_8197F)
#define BIT_SET_BF1_LIFETIME_8197F(x, v) \
(BIT_CLEAR_BF1_LIFETIME_8197F(x) | BIT_BF1_LIFETIME_8197F(v))
/* 2 REG_BF_TIMEOUT_EN_8197F */
#define BIT_EN_VHT_LDPC_8197F BIT(9)
#define BIT_EN_HT_LDPC_8197F BIT(8)
#define BIT_BF1_TIMEOUT_EN_8197F BIT(1)
#define BIT_BF0_TIMEOUT_EN_8197F BIT(0)
/* 2 REG_MACID_RELEASE0_8197F */
#define BIT_SHIFT_MACID31_0_RELEASE_8197F 0
#define BIT_MASK_MACID31_0_RELEASE_8197F 0xffffffffL
#define BIT_MACID31_0_RELEASE_8197F(x) \
(((x) & BIT_MASK_MACID31_0_RELEASE_8197F) \
<< BIT_SHIFT_MACID31_0_RELEASE_8197F)
#define BITS_MACID31_0_RELEASE_8197F \
(BIT_MASK_MACID31_0_RELEASE_8197F << BIT_SHIFT_MACID31_0_RELEASE_8197F)
#define BIT_CLEAR_MACID31_0_RELEASE_8197F(x) \
((x) & (~BITS_MACID31_0_RELEASE_8197F))
#define BIT_GET_MACID31_0_RELEASE_8197F(x) \
(((x) >> BIT_SHIFT_MACID31_0_RELEASE_8197F) & \
BIT_MASK_MACID31_0_RELEASE_8197F)
#define BIT_SET_MACID31_0_RELEASE_8197F(x, v) \
(BIT_CLEAR_MACID31_0_RELEASE_8197F(x) | BIT_MACID31_0_RELEASE_8197F(v))
/* 2 REG_MACID_RELEASE1_8197F */
#define BIT_SHIFT_MACID63_32_RELEASE_8197F 0
#define BIT_MASK_MACID63_32_RELEASE_8197F 0xffffffffL
#define BIT_MACID63_32_RELEASE_8197F(x) \
(((x) & BIT_MASK_MACID63_32_RELEASE_8197F) \
<< BIT_SHIFT_MACID63_32_RELEASE_8197F)
#define BITS_MACID63_32_RELEASE_8197F \
(BIT_MASK_MACID63_32_RELEASE_8197F \
<< BIT_SHIFT_MACID63_32_RELEASE_8197F)
#define BIT_CLEAR_MACID63_32_RELEASE_8197F(x) \
((x) & (~BITS_MACID63_32_RELEASE_8197F))
#define BIT_GET_MACID63_32_RELEASE_8197F(x) \
(((x) >> BIT_SHIFT_MACID63_32_RELEASE_8197F) & \
BIT_MASK_MACID63_32_RELEASE_8197F)
#define BIT_SET_MACID63_32_RELEASE_8197F(x, v) \
(BIT_CLEAR_MACID63_32_RELEASE_8197F(x) | \
BIT_MACID63_32_RELEASE_8197F(v))
/* 2 REG_MACID_RELEASE2_8197F */
#define BIT_SHIFT_MACID95_64_RELEASE_8197F 0
#define BIT_MASK_MACID95_64_RELEASE_8197F 0xffffffffL
#define BIT_MACID95_64_RELEASE_8197F(x) \
(((x) & BIT_MASK_MACID95_64_RELEASE_8197F) \
<< BIT_SHIFT_MACID95_64_RELEASE_8197F)
#define BITS_MACID95_64_RELEASE_8197F \
(BIT_MASK_MACID95_64_RELEASE_8197F \
<< BIT_SHIFT_MACID95_64_RELEASE_8197F)
#define BIT_CLEAR_MACID95_64_RELEASE_8197F(x) \
((x) & (~BITS_MACID95_64_RELEASE_8197F))
#define BIT_GET_MACID95_64_RELEASE_8197F(x) \
(((x) >> BIT_SHIFT_MACID95_64_RELEASE_8197F) & \
BIT_MASK_MACID95_64_RELEASE_8197F)
#define BIT_SET_MACID95_64_RELEASE_8197F(x, v) \
(BIT_CLEAR_MACID95_64_RELEASE_8197F(x) | \
BIT_MACID95_64_RELEASE_8197F(v))
/* 2 REG_MACID_RELEASE3_8197F */
#define BIT_SHIFT_MACID127_96_RELEASE_8197F 0
#define BIT_MASK_MACID127_96_RELEASE_8197F 0xffffffffL
#define BIT_MACID127_96_RELEASE_8197F(x) \
(((x) & BIT_MASK_MACID127_96_RELEASE_8197F) \
<< BIT_SHIFT_MACID127_96_RELEASE_8197F)
#define BITS_MACID127_96_RELEASE_8197F \
(BIT_MASK_MACID127_96_RELEASE_8197F \
<< BIT_SHIFT_MACID127_96_RELEASE_8197F)
#define BIT_CLEAR_MACID127_96_RELEASE_8197F(x) \
((x) & (~BITS_MACID127_96_RELEASE_8197F))
#define BIT_GET_MACID127_96_RELEASE_8197F(x) \
(((x) >> BIT_SHIFT_MACID127_96_RELEASE_8197F) & \
BIT_MASK_MACID127_96_RELEASE_8197F)
#define BIT_SET_MACID127_96_RELEASE_8197F(x, v) \
(BIT_CLEAR_MACID127_96_RELEASE_8197F(x) | \
BIT_MACID127_96_RELEASE_8197F(v))
/* 2 REG_MACID_RELEASE_SETTING_8197F */
#define BIT_MACID_VALUE_8197F BIT(7)
#define BIT_SHIFT_MACID_OFFSET_8197F 0
#define BIT_MASK_MACID_OFFSET_8197F 0x7f
#define BIT_MACID_OFFSET_8197F(x) \
(((x) & BIT_MASK_MACID_OFFSET_8197F) << BIT_SHIFT_MACID_OFFSET_8197F)
#define BITS_MACID_OFFSET_8197F \
(BIT_MASK_MACID_OFFSET_8197F << BIT_SHIFT_MACID_OFFSET_8197F)
#define BIT_CLEAR_MACID_OFFSET_8197F(x) ((x) & (~BITS_MACID_OFFSET_8197F))
#define BIT_GET_MACID_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_MACID_OFFSET_8197F) & BIT_MASK_MACID_OFFSET_8197F)
#define BIT_SET_MACID_OFFSET_8197F(x, v) \
(BIT_CLEAR_MACID_OFFSET_8197F(x) | BIT_MACID_OFFSET_8197F(v))
/* 2 REG_FAST_EDCA_VOVI_SETTING_8197F */
#define BIT_SHIFT_VI_FAST_EDCA_TO_8197F 24
#define BIT_MASK_VI_FAST_EDCA_TO_8197F 0xff
#define BIT_VI_FAST_EDCA_TO_8197F(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_TO_8197F) \
<< BIT_SHIFT_VI_FAST_EDCA_TO_8197F)
#define BITS_VI_FAST_EDCA_TO_8197F \
(BIT_MASK_VI_FAST_EDCA_TO_8197F << BIT_SHIFT_VI_FAST_EDCA_TO_8197F)
#define BIT_CLEAR_VI_FAST_EDCA_TO_8197F(x) ((x) & (~BITS_VI_FAST_EDCA_TO_8197F))
#define BIT_GET_VI_FAST_EDCA_TO_8197F(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_TO_8197F) & \
BIT_MASK_VI_FAST_EDCA_TO_8197F)
#define BIT_SET_VI_FAST_EDCA_TO_8197F(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_TO_8197F(x) | BIT_VI_FAST_EDCA_TO_8197F(v))
#define BIT_VI_THRESHOLD_SEL_8197F BIT(23)
#define BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8197F 16
#define BIT_MASK_VI_FAST_EDCA_PKT_TH_8197F 0x7f
#define BIT_VI_FAST_EDCA_PKT_TH_8197F(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_PKT_TH_8197F) \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8197F)
#define BITS_VI_FAST_EDCA_PKT_TH_8197F \
(BIT_MASK_VI_FAST_EDCA_PKT_TH_8197F \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8197F)
#define BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8197F(x) \
((x) & (~BITS_VI_FAST_EDCA_PKT_TH_8197F))
#define BIT_GET_VI_FAST_EDCA_PKT_TH_8197F(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8197F) & \
BIT_MASK_VI_FAST_EDCA_PKT_TH_8197F)
#define BIT_SET_VI_FAST_EDCA_PKT_TH_8197F(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8197F(x) | \
BIT_VI_FAST_EDCA_PKT_TH_8197F(v))
#define BIT_SHIFT_VO_FAST_EDCA_TO_8197F 8
#define BIT_MASK_VO_FAST_EDCA_TO_8197F 0xff
#define BIT_VO_FAST_EDCA_TO_8197F(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO_8197F) \
<< BIT_SHIFT_VO_FAST_EDCA_TO_8197F)
#define BITS_VO_FAST_EDCA_TO_8197F \
(BIT_MASK_VO_FAST_EDCA_TO_8197F << BIT_SHIFT_VO_FAST_EDCA_TO_8197F)
#define BIT_CLEAR_VO_FAST_EDCA_TO_8197F(x) ((x) & (~BITS_VO_FAST_EDCA_TO_8197F))
#define BIT_GET_VO_FAST_EDCA_TO_8197F(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO_8197F) & \
BIT_MASK_VO_FAST_EDCA_TO_8197F)
#define BIT_SET_VO_FAST_EDCA_TO_8197F(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO_8197F(x) | BIT_VO_FAST_EDCA_TO_8197F(v))
#define BIT_VO_THRESHOLD_SEL_8197F BIT(7)
#define BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8197F 0
#define BIT_MASK_VO_FAST_EDCA_PKT_TH_8197F 0x7f
#define BIT_VO_FAST_EDCA_PKT_TH_8197F(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_PKT_TH_8197F) \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8197F)
#define BITS_VO_FAST_EDCA_PKT_TH_8197F \
(BIT_MASK_VO_FAST_EDCA_PKT_TH_8197F \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8197F)
#define BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8197F(x) \
((x) & (~BITS_VO_FAST_EDCA_PKT_TH_8197F))
#define BIT_GET_VO_FAST_EDCA_PKT_TH_8197F(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8197F) & \
BIT_MASK_VO_FAST_EDCA_PKT_TH_8197F)
#define BIT_SET_VO_FAST_EDCA_PKT_TH_8197F(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8197F(x) | \
BIT_VO_FAST_EDCA_PKT_TH_8197F(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING_8197F */
#define BIT_SHIFT_BK_FAST_EDCA_TO_8197F 24
#define BIT_MASK_BK_FAST_EDCA_TO_8197F 0xff
#define BIT_BK_FAST_EDCA_TO_8197F(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_TO_8197F) \
<< BIT_SHIFT_BK_FAST_EDCA_TO_8197F)
#define BITS_BK_FAST_EDCA_TO_8197F \
(BIT_MASK_BK_FAST_EDCA_TO_8197F << BIT_SHIFT_BK_FAST_EDCA_TO_8197F)
#define BIT_CLEAR_BK_FAST_EDCA_TO_8197F(x) ((x) & (~BITS_BK_FAST_EDCA_TO_8197F))
#define BIT_GET_BK_FAST_EDCA_TO_8197F(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_TO_8197F) & \
BIT_MASK_BK_FAST_EDCA_TO_8197F)
#define BIT_SET_BK_FAST_EDCA_TO_8197F(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_TO_8197F(x) | BIT_BK_FAST_EDCA_TO_8197F(v))
#define BIT_BK_THRESHOLD_SEL_8197F BIT(23)
#define BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8197F 16
#define BIT_MASK_BK_FAST_EDCA_PKT_TH_8197F 0x7f
#define BIT_BK_FAST_EDCA_PKT_TH_8197F(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_PKT_TH_8197F) \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8197F)
#define BITS_BK_FAST_EDCA_PKT_TH_8197F \
(BIT_MASK_BK_FAST_EDCA_PKT_TH_8197F \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8197F)
#define BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8197F(x) \
((x) & (~BITS_BK_FAST_EDCA_PKT_TH_8197F))
#define BIT_GET_BK_FAST_EDCA_PKT_TH_8197F(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8197F) & \
BIT_MASK_BK_FAST_EDCA_PKT_TH_8197F)
#define BIT_SET_BK_FAST_EDCA_PKT_TH_8197F(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8197F(x) | \
BIT_BK_FAST_EDCA_PKT_TH_8197F(v))
#define BIT_SHIFT_BE_FAST_EDCA_TO_8197F 8
#define BIT_MASK_BE_FAST_EDCA_TO_8197F 0xff
#define BIT_BE_FAST_EDCA_TO_8197F(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO_8197F) \
<< BIT_SHIFT_BE_FAST_EDCA_TO_8197F)
#define BITS_BE_FAST_EDCA_TO_8197F \
(BIT_MASK_BE_FAST_EDCA_TO_8197F << BIT_SHIFT_BE_FAST_EDCA_TO_8197F)
#define BIT_CLEAR_BE_FAST_EDCA_TO_8197F(x) ((x) & (~BITS_BE_FAST_EDCA_TO_8197F))
#define BIT_GET_BE_FAST_EDCA_TO_8197F(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO_8197F) & \
BIT_MASK_BE_FAST_EDCA_TO_8197F)
#define BIT_SET_BE_FAST_EDCA_TO_8197F(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO_8197F(x) | BIT_BE_FAST_EDCA_TO_8197F(v))
#define BIT_BE_THRESHOLD_SEL_8197F BIT(7)
#define BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8197F 0
#define BIT_MASK_BE_FAST_EDCA_PKT_TH_8197F 0x7f
#define BIT_BE_FAST_EDCA_PKT_TH_8197F(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_PKT_TH_8197F) \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8197F)
#define BITS_BE_FAST_EDCA_PKT_TH_8197F \
(BIT_MASK_BE_FAST_EDCA_PKT_TH_8197F \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8197F)
#define BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8197F(x) \
((x) & (~BITS_BE_FAST_EDCA_PKT_TH_8197F))
#define BIT_GET_BE_FAST_EDCA_PKT_TH_8197F(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8197F) & \
BIT_MASK_BE_FAST_EDCA_PKT_TH_8197F)
#define BIT_SET_BE_FAST_EDCA_PKT_TH_8197F(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8197F(x) | \
BIT_BE_FAST_EDCA_PKT_TH_8197F(v))
/* 2 REG_MACID_DROP0_8197F */
#define BIT_SHIFT_MACID31_0_DROP_8197F 0
#define BIT_MASK_MACID31_0_DROP_8197F 0xffffffffL
#define BIT_MACID31_0_DROP_8197F(x) \
(((x) & BIT_MASK_MACID31_0_DROP_8197F) \
<< BIT_SHIFT_MACID31_0_DROP_8197F)
#define BITS_MACID31_0_DROP_8197F \
(BIT_MASK_MACID31_0_DROP_8197F << BIT_SHIFT_MACID31_0_DROP_8197F)
#define BIT_CLEAR_MACID31_0_DROP_8197F(x) ((x) & (~BITS_MACID31_0_DROP_8197F))
#define BIT_GET_MACID31_0_DROP_8197F(x) \
(((x) >> BIT_SHIFT_MACID31_0_DROP_8197F) & \
BIT_MASK_MACID31_0_DROP_8197F)
#define BIT_SET_MACID31_0_DROP_8197F(x, v) \
(BIT_CLEAR_MACID31_0_DROP_8197F(x) | BIT_MACID31_0_DROP_8197F(v))
/* 2 REG_MACID_DROP1_8197F */
#define BIT_SHIFT_MACID63_32_DROP_8197F 0
#define BIT_MASK_MACID63_32_DROP_8197F 0xffffffffL
#define BIT_MACID63_32_DROP_8197F(x) \
(((x) & BIT_MASK_MACID63_32_DROP_8197F) \
<< BIT_SHIFT_MACID63_32_DROP_8197F)
#define BITS_MACID63_32_DROP_8197F \
(BIT_MASK_MACID63_32_DROP_8197F << BIT_SHIFT_MACID63_32_DROP_8197F)
#define BIT_CLEAR_MACID63_32_DROP_8197F(x) ((x) & (~BITS_MACID63_32_DROP_8197F))
#define BIT_GET_MACID63_32_DROP_8197F(x) \
(((x) >> BIT_SHIFT_MACID63_32_DROP_8197F) & \
BIT_MASK_MACID63_32_DROP_8197F)
#define BIT_SET_MACID63_32_DROP_8197F(x, v) \
(BIT_CLEAR_MACID63_32_DROP_8197F(x) | BIT_MACID63_32_DROP_8197F(v))
/* 2 REG_MACID_DROP2_8197F */
#define BIT_SHIFT_MACID95_64_DROP_8197F 0
#define BIT_MASK_MACID95_64_DROP_8197F 0xffffffffL
#define BIT_MACID95_64_DROP_8197F(x) \
(((x) & BIT_MASK_MACID95_64_DROP_8197F) \
<< BIT_SHIFT_MACID95_64_DROP_8197F)
#define BITS_MACID95_64_DROP_8197F \
(BIT_MASK_MACID95_64_DROP_8197F << BIT_SHIFT_MACID95_64_DROP_8197F)
#define BIT_CLEAR_MACID95_64_DROP_8197F(x) ((x) & (~BITS_MACID95_64_DROP_8197F))
#define BIT_GET_MACID95_64_DROP_8197F(x) \
(((x) >> BIT_SHIFT_MACID95_64_DROP_8197F) & \
BIT_MASK_MACID95_64_DROP_8197F)
#define BIT_SET_MACID95_64_DROP_8197F(x, v) \
(BIT_CLEAR_MACID95_64_DROP_8197F(x) | BIT_MACID95_64_DROP_8197F(v))
/* 2 REG_MACID_DROP3_8197F */
#define BIT_SHIFT_MACID127_96_DROP_8197F 0
#define BIT_MASK_MACID127_96_DROP_8197F 0xffffffffL
#define BIT_MACID127_96_DROP_8197F(x) \
(((x) & BIT_MASK_MACID127_96_DROP_8197F) \
<< BIT_SHIFT_MACID127_96_DROP_8197F)
#define BITS_MACID127_96_DROP_8197F \
(BIT_MASK_MACID127_96_DROP_8197F << BIT_SHIFT_MACID127_96_DROP_8197F)
#define BIT_CLEAR_MACID127_96_DROP_8197F(x) \
((x) & (~BITS_MACID127_96_DROP_8197F))
#define BIT_GET_MACID127_96_DROP_8197F(x) \
(((x) >> BIT_SHIFT_MACID127_96_DROP_8197F) & \
BIT_MASK_MACID127_96_DROP_8197F)
#define BIT_SET_MACID127_96_DROP_8197F(x, v) \
(BIT_CLEAR_MACID127_96_DROP_8197F(x) | BIT_MACID127_96_DROP_8197F(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_0_8197F */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8197F 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8197F 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_0_8197F(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8197F) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8197F)
#define BITS_R_MACID_RELEASE_SUCCESS_0_8197F \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8197F \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8197F)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8197F(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_0_8197F))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_0_8197F(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8197F) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8197F)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_0_8197F(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8197F(x) | \
BIT_R_MACID_RELEASE_SUCCESS_0_8197F(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_1_8197F */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8197F 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8197F 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_1_8197F(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8197F) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8197F)
#define BITS_R_MACID_RELEASE_SUCCESS_1_8197F \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8197F \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8197F)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8197F(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_1_8197F))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_1_8197F(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8197F) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8197F)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_1_8197F(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8197F(x) | \
BIT_R_MACID_RELEASE_SUCCESS_1_8197F(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_2_8197F */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8197F 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8197F 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_2_8197F(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8197F) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8197F)
#define BITS_R_MACID_RELEASE_SUCCESS_2_8197F \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8197F \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8197F)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8197F(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_2_8197F))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_2_8197F(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8197F) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8197F)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_2_8197F(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8197F(x) | \
BIT_R_MACID_RELEASE_SUCCESS_2_8197F(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_3_8197F */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8197F 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8197F 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_3_8197F(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8197F) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8197F)
#define BITS_R_MACID_RELEASE_SUCCESS_3_8197F \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8197F \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8197F)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8197F(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_3_8197F))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_3_8197F(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8197F) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8197F)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_3_8197F(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8197F(x) | \
BIT_R_MACID_RELEASE_SUCCESS_3_8197F(v))
/* 2 REG_MGG_FIFO_CRTL_8197F */
#define BIT_R_MGG_FIFO_EN_8197F BIT(31)
#define BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8197F 28
#define BIT_MASK_R_MGG_FIFO_PG_SIZE_8197F 0x7
#define BIT_R_MGG_FIFO_PG_SIZE_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_PG_SIZE_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8197F)
#define BITS_R_MGG_FIFO_PG_SIZE_8197F \
(BIT_MASK_R_MGG_FIFO_PG_SIZE_8197F \
<< BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8197F)
#define BIT_CLEAR_R_MGG_FIFO_PG_SIZE_8197F(x) \
((x) & (~BITS_R_MGG_FIFO_PG_SIZE_8197F))
#define BIT_GET_R_MGG_FIFO_PG_SIZE_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8197F) & \
BIT_MASK_R_MGG_FIFO_PG_SIZE_8197F)
#define BIT_SET_R_MGG_FIFO_PG_SIZE_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_PG_SIZE_8197F(x) | \
BIT_R_MGG_FIFO_PG_SIZE_8197F(v))
#define BIT_SHIFT_R_MGG_FIFO_START_PG_8197F 16
#define BIT_MASK_R_MGG_FIFO_START_PG_8197F 0xfff
#define BIT_R_MGG_FIFO_START_PG_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_START_PG_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_START_PG_8197F)
#define BITS_R_MGG_FIFO_START_PG_8197F \
(BIT_MASK_R_MGG_FIFO_START_PG_8197F \
<< BIT_SHIFT_R_MGG_FIFO_START_PG_8197F)
#define BIT_CLEAR_R_MGG_FIFO_START_PG_8197F(x) \
((x) & (~BITS_R_MGG_FIFO_START_PG_8197F))
#define BIT_GET_R_MGG_FIFO_START_PG_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_START_PG_8197F) & \
BIT_MASK_R_MGG_FIFO_START_PG_8197F)
#define BIT_SET_R_MGG_FIFO_START_PG_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_START_PG_8197F(x) | \
BIT_R_MGG_FIFO_START_PG_8197F(v))
#define BIT_SHIFT_R_MGG_FIFO_SIZE_8197F 14
#define BIT_MASK_R_MGG_FIFO_SIZE_8197F 0x3
#define BIT_R_MGG_FIFO_SIZE_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_SIZE_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_SIZE_8197F)
#define BITS_R_MGG_FIFO_SIZE_8197F \
(BIT_MASK_R_MGG_FIFO_SIZE_8197F << BIT_SHIFT_R_MGG_FIFO_SIZE_8197F)
#define BIT_CLEAR_R_MGG_FIFO_SIZE_8197F(x) ((x) & (~BITS_R_MGG_FIFO_SIZE_8197F))
#define BIT_GET_R_MGG_FIFO_SIZE_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_SIZE_8197F) & \
BIT_MASK_R_MGG_FIFO_SIZE_8197F)
#define BIT_SET_R_MGG_FIFO_SIZE_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_SIZE_8197F(x) | BIT_R_MGG_FIFO_SIZE_8197F(v))
#define BIT_R_MGG_FIFO_PAUSE_8197F BIT(13)
#define BIT_SHIFT_R_MGG_FIFO_RPTR_8197F 8
#define BIT_MASK_R_MGG_FIFO_RPTR_8197F 0x1f
#define BIT_R_MGG_FIFO_RPTR_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_RPTR_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_RPTR_8197F)
#define BITS_R_MGG_FIFO_RPTR_8197F \
(BIT_MASK_R_MGG_FIFO_RPTR_8197F << BIT_SHIFT_R_MGG_FIFO_RPTR_8197F)
#define BIT_CLEAR_R_MGG_FIFO_RPTR_8197F(x) ((x) & (~BITS_R_MGG_FIFO_RPTR_8197F))
#define BIT_GET_R_MGG_FIFO_RPTR_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_RPTR_8197F) & \
BIT_MASK_R_MGG_FIFO_RPTR_8197F)
#define BIT_SET_R_MGG_FIFO_RPTR_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_RPTR_8197F(x) | BIT_R_MGG_FIFO_RPTR_8197F(v))
#define BIT_R_MGG_FIFO_OV_8197F BIT(7)
#define BIT_R_MGG_FIFO_WPTR_ERROR_8197F BIT(6)
#define BIT_R_EN_CPU_LIFETIME_8197F BIT(5)
#define BIT_SHIFT_R_MGG_FIFO_WPTR_8197F 0
#define BIT_MASK_R_MGG_FIFO_WPTR_8197F 0x1f
#define BIT_R_MGG_FIFO_WPTR_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_WPTR_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_WPTR_8197F)
#define BITS_R_MGG_FIFO_WPTR_8197F \
(BIT_MASK_R_MGG_FIFO_WPTR_8197F << BIT_SHIFT_R_MGG_FIFO_WPTR_8197F)
#define BIT_CLEAR_R_MGG_FIFO_WPTR_8197F(x) ((x) & (~BITS_R_MGG_FIFO_WPTR_8197F))
#define BIT_GET_R_MGG_FIFO_WPTR_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_WPTR_8197F) & \
BIT_MASK_R_MGG_FIFO_WPTR_8197F)
#define BIT_SET_R_MGG_FIFO_WPTR_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_WPTR_8197F(x) | BIT_R_MGG_FIFO_WPTR_8197F(v))
/* 2 REG_MGG_FIFO_INT_8197F */
#define BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8197F 16
#define BIT_MASK_R_MGG_FIFO_INT_FLAG_8197F 0xffff
#define BIT_R_MGG_FIFO_INT_FLAG_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_INT_FLAG_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8197F)
#define BITS_R_MGG_FIFO_INT_FLAG_8197F \
(BIT_MASK_R_MGG_FIFO_INT_FLAG_8197F \
<< BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8197F)
#define BIT_CLEAR_R_MGG_FIFO_INT_FLAG_8197F(x) \
((x) & (~BITS_R_MGG_FIFO_INT_FLAG_8197F))
#define BIT_GET_R_MGG_FIFO_INT_FLAG_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8197F) & \
BIT_MASK_R_MGG_FIFO_INT_FLAG_8197F)
#define BIT_SET_R_MGG_FIFO_INT_FLAG_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_INT_FLAG_8197F(x) | \
BIT_R_MGG_FIFO_INT_FLAG_8197F(v))
#define BIT_SHIFT_R_MGG_FIFO_INT_MASK_8197F 0
#define BIT_MASK_R_MGG_FIFO_INT_MASK_8197F 0xffff
#define BIT_R_MGG_FIFO_INT_MASK_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_INT_MASK_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_INT_MASK_8197F)
#define BITS_R_MGG_FIFO_INT_MASK_8197F \
(BIT_MASK_R_MGG_FIFO_INT_MASK_8197F \
<< BIT_SHIFT_R_MGG_FIFO_INT_MASK_8197F)
#define BIT_CLEAR_R_MGG_FIFO_INT_MASK_8197F(x) \
((x) & (~BITS_R_MGG_FIFO_INT_MASK_8197F))
#define BIT_GET_R_MGG_FIFO_INT_MASK_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_INT_MASK_8197F) & \
BIT_MASK_R_MGG_FIFO_INT_MASK_8197F)
#define BIT_SET_R_MGG_FIFO_INT_MASK_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_INT_MASK_8197F(x) | \
BIT_R_MGG_FIFO_INT_MASK_8197F(v))
/* 2 REG_MGG_FIFO_LIFETIME_8197F */
#define BIT_SHIFT_R_MGG_FIFO_LIFETIME_8197F 16
#define BIT_MASK_R_MGG_FIFO_LIFETIME_8197F 0xffff
#define BIT_R_MGG_FIFO_LIFETIME_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_LIFETIME_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_LIFETIME_8197F)
#define BITS_R_MGG_FIFO_LIFETIME_8197F \
(BIT_MASK_R_MGG_FIFO_LIFETIME_8197F \
<< BIT_SHIFT_R_MGG_FIFO_LIFETIME_8197F)
#define BIT_CLEAR_R_MGG_FIFO_LIFETIME_8197F(x) \
((x) & (~BITS_R_MGG_FIFO_LIFETIME_8197F))
#define BIT_GET_R_MGG_FIFO_LIFETIME_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_LIFETIME_8197F) & \
BIT_MASK_R_MGG_FIFO_LIFETIME_8197F)
#define BIT_SET_R_MGG_FIFO_LIFETIME_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_LIFETIME_8197F(x) | \
BIT_R_MGG_FIFO_LIFETIME_8197F(v))
#define BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8197F 0
#define BIT_MASK_R_MGG_FIFO_VALID_MAP_8197F 0xffff
#define BIT_R_MGG_FIFO_VALID_MAP_8197F(x) \
(((x) & BIT_MASK_R_MGG_FIFO_VALID_MAP_8197F) \
<< BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8197F)
#define BITS_R_MGG_FIFO_VALID_MAP_8197F \
(BIT_MASK_R_MGG_FIFO_VALID_MAP_8197F \
<< BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8197F)
#define BIT_CLEAR_R_MGG_FIFO_VALID_MAP_8197F(x) \
((x) & (~BITS_R_MGG_FIFO_VALID_MAP_8197F))
#define BIT_GET_R_MGG_FIFO_VALID_MAP_8197F(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8197F) & \
BIT_MASK_R_MGG_FIFO_VALID_MAP_8197F)
#define BIT_SET_R_MGG_FIFO_VALID_MAP_8197F(x, v) \
(BIT_CLEAR_R_MGG_FIFO_VALID_MAP_8197F(x) | \
BIT_R_MGG_FIFO_VALID_MAP_8197F(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F 0x7f
#define BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F)
#define BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F(x) | \
BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F(v))
/* 2 REG_SHCUT_SETTING_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SHCUT_LLC_ETH_TYPE0_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SHCUT_LLC_ETH_TYPE1_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SHCUT_LLC_OUI0_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SHCUT_LLC_OUI1_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SHCUT_LLC_OUI2_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_SHCUT_LLC_OUI3_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_CHNL_INFO_CTRL_8197F */
#define BIT_CHNL_REF_RXNAV_8197F BIT(7)
#define BIT_CHNL_REF_VBON_8197F BIT(6)
#define BIT_CHNL_REF_EDCCA_8197F BIT(5)
#define BIT_RST_CHNL_BUSY_8197F BIT(3)
#define BIT_RST_CHNL_IDLE_8197F BIT(2)
#define BIT_CHNL_INFO_RST_8197F BIT(1)
#define BIT_ATM_AIRTIME_EN_8197F BIT(0)
/* 2 REG_CHNL_IDLE_TIME_8197F */
#define BIT_SHIFT_CHNL_IDLE_TIME_8197F 0
#define BIT_MASK_CHNL_IDLE_TIME_8197F 0xffffffffL
#define BIT_CHNL_IDLE_TIME_8197F(x) \
(((x) & BIT_MASK_CHNL_IDLE_TIME_8197F) \
<< BIT_SHIFT_CHNL_IDLE_TIME_8197F)
#define BITS_CHNL_IDLE_TIME_8197F \
(BIT_MASK_CHNL_IDLE_TIME_8197F << BIT_SHIFT_CHNL_IDLE_TIME_8197F)
#define BIT_CLEAR_CHNL_IDLE_TIME_8197F(x) ((x) & (~BITS_CHNL_IDLE_TIME_8197F))
#define BIT_GET_CHNL_IDLE_TIME_8197F(x) \
(((x) >> BIT_SHIFT_CHNL_IDLE_TIME_8197F) & \
BIT_MASK_CHNL_IDLE_TIME_8197F)
#define BIT_SET_CHNL_IDLE_TIME_8197F(x, v) \
(BIT_CLEAR_CHNL_IDLE_TIME_8197F(x) | BIT_CHNL_IDLE_TIME_8197F(v))
/* 2 REG_CHNL_BUSY_TIME_8197F */
#define BIT_SHIFT_CHNL_BUSY_TIME_8197F 0
#define BIT_MASK_CHNL_BUSY_TIME_8197F 0xffffffffL
#define BIT_CHNL_BUSY_TIME_8197F(x) \
(((x) & BIT_MASK_CHNL_BUSY_TIME_8197F) \
<< BIT_SHIFT_CHNL_BUSY_TIME_8197F)
#define BITS_CHNL_BUSY_TIME_8197F \
(BIT_MASK_CHNL_BUSY_TIME_8197F << BIT_SHIFT_CHNL_BUSY_TIME_8197F)
#define BIT_CLEAR_CHNL_BUSY_TIME_8197F(x) ((x) & (~BITS_CHNL_BUSY_TIME_8197F))
#define BIT_GET_CHNL_BUSY_TIME_8197F(x) \
(((x) >> BIT_SHIFT_CHNL_BUSY_TIME_8197F) & \
BIT_MASK_CHNL_BUSY_TIME_8197F)
#define BIT_SET_CHNL_BUSY_TIME_8197F(x, v) \
(BIT_CLEAR_CHNL_BUSY_TIME_8197F(x) | BIT_CHNL_BUSY_TIME_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_EDCA_VO_PARAM_8197F */
#define BIT_SHIFT_TXOPLIMIT_8197F 16
#define BIT_MASK_TXOPLIMIT_8197F 0x7ff
#define BIT_TXOPLIMIT_8197F(x) \
(((x) & BIT_MASK_TXOPLIMIT_8197F) << BIT_SHIFT_TXOPLIMIT_8197F)
#define BITS_TXOPLIMIT_8197F \
(BIT_MASK_TXOPLIMIT_8197F << BIT_SHIFT_TXOPLIMIT_8197F)
#define BIT_CLEAR_TXOPLIMIT_8197F(x) ((x) & (~BITS_TXOPLIMIT_8197F))
#define BIT_GET_TXOPLIMIT_8197F(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8197F) & BIT_MASK_TXOPLIMIT_8197F)
#define BIT_SET_TXOPLIMIT_8197F(x, v) \
(BIT_CLEAR_TXOPLIMIT_8197F(x) | BIT_TXOPLIMIT_8197F(v))
#define BIT_SHIFT_CW_8197F 8
#define BIT_MASK_CW_8197F 0xff
#define BIT_CW_8197F(x) (((x) & BIT_MASK_CW_8197F) << BIT_SHIFT_CW_8197F)
#define BITS_CW_8197F (BIT_MASK_CW_8197F << BIT_SHIFT_CW_8197F)
#define BIT_CLEAR_CW_8197F(x) ((x) & (~BITS_CW_8197F))
#define BIT_GET_CW_8197F(x) (((x) >> BIT_SHIFT_CW_8197F) & BIT_MASK_CW_8197F)
#define BIT_SET_CW_8197F(x, v) (BIT_CLEAR_CW_8197F(x) | BIT_CW_8197F(v))
#define BIT_SHIFT_AIFS_8197F 0
#define BIT_MASK_AIFS_8197F 0xff
#define BIT_AIFS_8197F(x) (((x) & BIT_MASK_AIFS_8197F) << BIT_SHIFT_AIFS_8197F)
#define BITS_AIFS_8197F (BIT_MASK_AIFS_8197F << BIT_SHIFT_AIFS_8197F)
#define BIT_CLEAR_AIFS_8197F(x) ((x) & (~BITS_AIFS_8197F))
#define BIT_GET_AIFS_8197F(x) \
(((x) >> BIT_SHIFT_AIFS_8197F) & BIT_MASK_AIFS_8197F)
#define BIT_SET_AIFS_8197F(x, v) (BIT_CLEAR_AIFS_8197F(x) | BIT_AIFS_8197F(v))
/* 2 REG_EDCA_VI_PARAM_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_TXOPLIMIT_8197F 16
#define BIT_MASK_TXOPLIMIT_8197F 0x7ff
#define BIT_TXOPLIMIT_8197F(x) \
(((x) & BIT_MASK_TXOPLIMIT_8197F) << BIT_SHIFT_TXOPLIMIT_8197F)
#define BITS_TXOPLIMIT_8197F \
(BIT_MASK_TXOPLIMIT_8197F << BIT_SHIFT_TXOPLIMIT_8197F)
#define BIT_CLEAR_TXOPLIMIT_8197F(x) ((x) & (~BITS_TXOPLIMIT_8197F))
#define BIT_GET_TXOPLIMIT_8197F(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8197F) & BIT_MASK_TXOPLIMIT_8197F)
#define BIT_SET_TXOPLIMIT_8197F(x, v) \
(BIT_CLEAR_TXOPLIMIT_8197F(x) | BIT_TXOPLIMIT_8197F(v))
#define BIT_SHIFT_CW_8197F 8
#define BIT_MASK_CW_8197F 0xff
#define BIT_CW_8197F(x) (((x) & BIT_MASK_CW_8197F) << BIT_SHIFT_CW_8197F)
#define BITS_CW_8197F (BIT_MASK_CW_8197F << BIT_SHIFT_CW_8197F)
#define BIT_CLEAR_CW_8197F(x) ((x) & (~BITS_CW_8197F))
#define BIT_GET_CW_8197F(x) (((x) >> BIT_SHIFT_CW_8197F) & BIT_MASK_CW_8197F)
#define BIT_SET_CW_8197F(x, v) (BIT_CLEAR_CW_8197F(x) | BIT_CW_8197F(v))
#define BIT_SHIFT_AIFS_8197F 0
#define BIT_MASK_AIFS_8197F 0xff
#define BIT_AIFS_8197F(x) (((x) & BIT_MASK_AIFS_8197F) << BIT_SHIFT_AIFS_8197F)
#define BITS_AIFS_8197F (BIT_MASK_AIFS_8197F << BIT_SHIFT_AIFS_8197F)
#define BIT_CLEAR_AIFS_8197F(x) ((x) & (~BITS_AIFS_8197F))
#define BIT_GET_AIFS_8197F(x) \
(((x) >> BIT_SHIFT_AIFS_8197F) & BIT_MASK_AIFS_8197F)
#define BIT_SET_AIFS_8197F(x, v) (BIT_CLEAR_AIFS_8197F(x) | BIT_AIFS_8197F(v))
/* 2 REG_EDCA_BE_PARAM_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_TXOPLIMIT_8197F 16
#define BIT_MASK_TXOPLIMIT_8197F 0x7ff
#define BIT_TXOPLIMIT_8197F(x) \
(((x) & BIT_MASK_TXOPLIMIT_8197F) << BIT_SHIFT_TXOPLIMIT_8197F)
#define BITS_TXOPLIMIT_8197F \
(BIT_MASK_TXOPLIMIT_8197F << BIT_SHIFT_TXOPLIMIT_8197F)
#define BIT_CLEAR_TXOPLIMIT_8197F(x) ((x) & (~BITS_TXOPLIMIT_8197F))
#define BIT_GET_TXOPLIMIT_8197F(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8197F) & BIT_MASK_TXOPLIMIT_8197F)
#define BIT_SET_TXOPLIMIT_8197F(x, v) \
(BIT_CLEAR_TXOPLIMIT_8197F(x) | BIT_TXOPLIMIT_8197F(v))
#define BIT_SHIFT_CW_8197F 8
#define BIT_MASK_CW_8197F 0xff
#define BIT_CW_8197F(x) (((x) & BIT_MASK_CW_8197F) << BIT_SHIFT_CW_8197F)
#define BITS_CW_8197F (BIT_MASK_CW_8197F << BIT_SHIFT_CW_8197F)
#define BIT_CLEAR_CW_8197F(x) ((x) & (~BITS_CW_8197F))
#define BIT_GET_CW_8197F(x) (((x) >> BIT_SHIFT_CW_8197F) & BIT_MASK_CW_8197F)
#define BIT_SET_CW_8197F(x, v) (BIT_CLEAR_CW_8197F(x) | BIT_CW_8197F(v))
#define BIT_SHIFT_AIFS_8197F 0
#define BIT_MASK_AIFS_8197F 0xff
#define BIT_AIFS_8197F(x) (((x) & BIT_MASK_AIFS_8197F) << BIT_SHIFT_AIFS_8197F)
#define BITS_AIFS_8197F (BIT_MASK_AIFS_8197F << BIT_SHIFT_AIFS_8197F)
#define BIT_CLEAR_AIFS_8197F(x) ((x) & (~BITS_AIFS_8197F))
#define BIT_GET_AIFS_8197F(x) \
(((x) >> BIT_SHIFT_AIFS_8197F) & BIT_MASK_AIFS_8197F)
#define BIT_SET_AIFS_8197F(x, v) (BIT_CLEAR_AIFS_8197F(x) | BIT_AIFS_8197F(v))
/* 2 REG_EDCA_BK_PARAM_8197F */
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_TXOPLIMIT_8197F 16
#define BIT_MASK_TXOPLIMIT_8197F 0x7ff
#define BIT_TXOPLIMIT_8197F(x) \
(((x) & BIT_MASK_TXOPLIMIT_8197F) << BIT_SHIFT_TXOPLIMIT_8197F)
#define BITS_TXOPLIMIT_8197F \
(BIT_MASK_TXOPLIMIT_8197F << BIT_SHIFT_TXOPLIMIT_8197F)
#define BIT_CLEAR_TXOPLIMIT_8197F(x) ((x) & (~BITS_TXOPLIMIT_8197F))
#define BIT_GET_TXOPLIMIT_8197F(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8197F) & BIT_MASK_TXOPLIMIT_8197F)
#define BIT_SET_TXOPLIMIT_8197F(x, v) \
(BIT_CLEAR_TXOPLIMIT_8197F(x) | BIT_TXOPLIMIT_8197F(v))
#define BIT_SHIFT_CW_8197F 8
#define BIT_MASK_CW_8197F 0xff
#define BIT_CW_8197F(x) (((x) & BIT_MASK_CW_8197F) << BIT_SHIFT_CW_8197F)
#define BITS_CW_8197F (BIT_MASK_CW_8197F << BIT_SHIFT_CW_8197F)
#define BIT_CLEAR_CW_8197F(x) ((x) & (~BITS_CW_8197F))
#define BIT_GET_CW_8197F(x) (((x) >> BIT_SHIFT_CW_8197F) & BIT_MASK_CW_8197F)
#define BIT_SET_CW_8197F(x, v) (BIT_CLEAR_CW_8197F(x) | BIT_CW_8197F(v))
#define BIT_SHIFT_AIFS_8197F 0
#define BIT_MASK_AIFS_8197F 0xff
#define BIT_AIFS_8197F(x) (((x) & BIT_MASK_AIFS_8197F) << BIT_SHIFT_AIFS_8197F)
#define BITS_AIFS_8197F (BIT_MASK_AIFS_8197F << BIT_SHIFT_AIFS_8197F)
#define BIT_CLEAR_AIFS_8197F(x) ((x) & (~BITS_AIFS_8197F))
#define BIT_GET_AIFS_8197F(x) \
(((x) >> BIT_SHIFT_AIFS_8197F) & BIT_MASK_AIFS_8197F)
#define BIT_SET_AIFS_8197F(x, v) (BIT_CLEAR_AIFS_8197F(x) | BIT_AIFS_8197F(v))
/* 2 REG_BCNTCFG_8197F */
#define BIT_SHIFT_BCNCW_MAX_8197F 12
#define BIT_MASK_BCNCW_MAX_8197F 0xf
#define BIT_BCNCW_MAX_8197F(x) \
(((x) & BIT_MASK_BCNCW_MAX_8197F) << BIT_SHIFT_BCNCW_MAX_8197F)
#define BITS_BCNCW_MAX_8197F \
(BIT_MASK_BCNCW_MAX_8197F << BIT_SHIFT_BCNCW_MAX_8197F)
#define BIT_CLEAR_BCNCW_MAX_8197F(x) ((x) & (~BITS_BCNCW_MAX_8197F))
#define BIT_GET_BCNCW_MAX_8197F(x) \
(((x) >> BIT_SHIFT_BCNCW_MAX_8197F) & BIT_MASK_BCNCW_MAX_8197F)
#define BIT_SET_BCNCW_MAX_8197F(x, v) \
(BIT_CLEAR_BCNCW_MAX_8197F(x) | BIT_BCNCW_MAX_8197F(v))
#define BIT_SHIFT_BCNCW_MIN_8197F 8
#define BIT_MASK_BCNCW_MIN_8197F 0xf
#define BIT_BCNCW_MIN_8197F(x) \
(((x) & BIT_MASK_BCNCW_MIN_8197F) << BIT_SHIFT_BCNCW_MIN_8197F)
#define BITS_BCNCW_MIN_8197F \
(BIT_MASK_BCNCW_MIN_8197F << BIT_SHIFT_BCNCW_MIN_8197F)
#define BIT_CLEAR_BCNCW_MIN_8197F(x) ((x) & (~BITS_BCNCW_MIN_8197F))
#define BIT_GET_BCNCW_MIN_8197F(x) \
(((x) >> BIT_SHIFT_BCNCW_MIN_8197F) & BIT_MASK_BCNCW_MIN_8197F)
#define BIT_SET_BCNCW_MIN_8197F(x, v) \
(BIT_CLEAR_BCNCW_MIN_8197F(x) | BIT_BCNCW_MIN_8197F(v))
#define BIT_SHIFT_BCNIFS_8197F 0
#define BIT_MASK_BCNIFS_8197F 0xff
#define BIT_BCNIFS_8197F(x) \
(((x) & BIT_MASK_BCNIFS_8197F) << BIT_SHIFT_BCNIFS_8197F)
#define BITS_BCNIFS_8197F (BIT_MASK_BCNIFS_8197F << BIT_SHIFT_BCNIFS_8197F)
#define BIT_CLEAR_BCNIFS_8197F(x) ((x) & (~BITS_BCNIFS_8197F))
#define BIT_GET_BCNIFS_8197F(x) \
(((x) >> BIT_SHIFT_BCNIFS_8197F) & BIT_MASK_BCNIFS_8197F)
#define BIT_SET_BCNIFS_8197F(x, v) \
(BIT_CLEAR_BCNIFS_8197F(x) | BIT_BCNIFS_8197F(v))
/* 2 REG_PIFS_8197F */
#define BIT_SHIFT_PIFS_8197F 0
#define BIT_MASK_PIFS_8197F 0xff
#define BIT_PIFS_8197F(x) (((x) & BIT_MASK_PIFS_8197F) << BIT_SHIFT_PIFS_8197F)
#define BITS_PIFS_8197F (BIT_MASK_PIFS_8197F << BIT_SHIFT_PIFS_8197F)
#define BIT_CLEAR_PIFS_8197F(x) ((x) & (~BITS_PIFS_8197F))
#define BIT_GET_PIFS_8197F(x) \
(((x) >> BIT_SHIFT_PIFS_8197F) & BIT_MASK_PIFS_8197F)
#define BIT_SET_PIFS_8197F(x, v) (BIT_CLEAR_PIFS_8197F(x) | BIT_PIFS_8197F(v))
/* 2 REG_RDG_PIFS_8197F */
#define BIT_SHIFT_RDG_PIFS_8197F 0
#define BIT_MASK_RDG_PIFS_8197F 0xff
#define BIT_RDG_PIFS_8197F(x) \
(((x) & BIT_MASK_RDG_PIFS_8197F) << BIT_SHIFT_RDG_PIFS_8197F)
#define BITS_RDG_PIFS_8197F \
(BIT_MASK_RDG_PIFS_8197F << BIT_SHIFT_RDG_PIFS_8197F)
#define BIT_CLEAR_RDG_PIFS_8197F(x) ((x) & (~BITS_RDG_PIFS_8197F))
#define BIT_GET_RDG_PIFS_8197F(x) \
(((x) >> BIT_SHIFT_RDG_PIFS_8197F) & BIT_MASK_RDG_PIFS_8197F)
#define BIT_SET_RDG_PIFS_8197F(x, v) \
(BIT_CLEAR_RDG_PIFS_8197F(x) | BIT_RDG_PIFS_8197F(v))
/* 2 REG_SIFS_8197F */
#define BIT_SHIFT_SIFS_OFDM_TRX_8197F 24
#define BIT_MASK_SIFS_OFDM_TRX_8197F 0xff
#define BIT_SIFS_OFDM_TRX_8197F(x) \
(((x) & BIT_MASK_SIFS_OFDM_TRX_8197F) << BIT_SHIFT_SIFS_OFDM_TRX_8197F)
#define BITS_SIFS_OFDM_TRX_8197F \
(BIT_MASK_SIFS_OFDM_TRX_8197F << BIT_SHIFT_SIFS_OFDM_TRX_8197F)
#define BIT_CLEAR_SIFS_OFDM_TRX_8197F(x) ((x) & (~BITS_SIFS_OFDM_TRX_8197F))
#define BIT_GET_SIFS_OFDM_TRX_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_TRX_8197F) & BIT_MASK_SIFS_OFDM_TRX_8197F)
#define BIT_SET_SIFS_OFDM_TRX_8197F(x, v) \
(BIT_CLEAR_SIFS_OFDM_TRX_8197F(x) | BIT_SIFS_OFDM_TRX_8197F(v))
#define BIT_SHIFT_SIFS_CCK_TRX_8197F 16
#define BIT_MASK_SIFS_CCK_TRX_8197F 0xff
#define BIT_SIFS_CCK_TRX_8197F(x) \
(((x) & BIT_MASK_SIFS_CCK_TRX_8197F) << BIT_SHIFT_SIFS_CCK_TRX_8197F)
#define BITS_SIFS_CCK_TRX_8197F \
(BIT_MASK_SIFS_CCK_TRX_8197F << BIT_SHIFT_SIFS_CCK_TRX_8197F)
#define BIT_CLEAR_SIFS_CCK_TRX_8197F(x) ((x) & (~BITS_SIFS_CCK_TRX_8197F))
#define BIT_GET_SIFS_CCK_TRX_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_TRX_8197F) & BIT_MASK_SIFS_CCK_TRX_8197F)
#define BIT_SET_SIFS_CCK_TRX_8197F(x, v) \
(BIT_CLEAR_SIFS_CCK_TRX_8197F(x) | BIT_SIFS_CCK_TRX_8197F(v))
#define BIT_SHIFT_SIFS_OFDM_CTX_8197F 8
#define BIT_MASK_SIFS_OFDM_CTX_8197F 0xff
#define BIT_SIFS_OFDM_CTX_8197F(x) \
(((x) & BIT_MASK_SIFS_OFDM_CTX_8197F) << BIT_SHIFT_SIFS_OFDM_CTX_8197F)
#define BITS_SIFS_OFDM_CTX_8197F \
(BIT_MASK_SIFS_OFDM_CTX_8197F << BIT_SHIFT_SIFS_OFDM_CTX_8197F)
#define BIT_CLEAR_SIFS_OFDM_CTX_8197F(x) ((x) & (~BITS_SIFS_OFDM_CTX_8197F))
#define BIT_GET_SIFS_OFDM_CTX_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_CTX_8197F) & BIT_MASK_SIFS_OFDM_CTX_8197F)
#define BIT_SET_SIFS_OFDM_CTX_8197F(x, v) \
(BIT_CLEAR_SIFS_OFDM_CTX_8197F(x) | BIT_SIFS_OFDM_CTX_8197F(v))
#define BIT_SHIFT_SIFS_CCK_CTX_8197F 0
#define BIT_MASK_SIFS_CCK_CTX_8197F 0xff
#define BIT_SIFS_CCK_CTX_8197F(x) \
(((x) & BIT_MASK_SIFS_CCK_CTX_8197F) << BIT_SHIFT_SIFS_CCK_CTX_8197F)
#define BITS_SIFS_CCK_CTX_8197F \
(BIT_MASK_SIFS_CCK_CTX_8197F << BIT_SHIFT_SIFS_CCK_CTX_8197F)
#define BIT_CLEAR_SIFS_CCK_CTX_8197F(x) ((x) & (~BITS_SIFS_CCK_CTX_8197F))
#define BIT_GET_SIFS_CCK_CTX_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_CTX_8197F) & BIT_MASK_SIFS_CCK_CTX_8197F)
#define BIT_SET_SIFS_CCK_CTX_8197F(x, v) \
(BIT_CLEAR_SIFS_CCK_CTX_8197F(x) | BIT_SIFS_CCK_CTX_8197F(v))
/* 2 REG_TSFTR_SYN_OFFSET_8197F */
#define BIT_SHIFT_TSFTR_SNC_OFFSET_8197F 0
#define BIT_MASK_TSFTR_SNC_OFFSET_8197F 0xffff
#define BIT_TSFTR_SNC_OFFSET_8197F(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET_8197F) \
<< BIT_SHIFT_TSFTR_SNC_OFFSET_8197F)
#define BITS_TSFTR_SNC_OFFSET_8197F \
(BIT_MASK_TSFTR_SNC_OFFSET_8197F << BIT_SHIFT_TSFTR_SNC_OFFSET_8197F)
#define BIT_CLEAR_TSFTR_SNC_OFFSET_8197F(x) \
((x) & (~BITS_TSFTR_SNC_OFFSET_8197F))
#define BIT_GET_TSFTR_SNC_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET_8197F) & \
BIT_MASK_TSFTR_SNC_OFFSET_8197F)
#define BIT_SET_TSFTR_SNC_OFFSET_8197F(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET_8197F(x) | BIT_TSFTR_SNC_OFFSET_8197F(v))
/* 2 REG_AGGR_BREAK_TIME_8197F */
#define BIT_SHIFT_AGGR_BK_TIME_8197F 0
#define BIT_MASK_AGGR_BK_TIME_8197F 0xff
#define BIT_AGGR_BK_TIME_8197F(x) \
(((x) & BIT_MASK_AGGR_BK_TIME_8197F) << BIT_SHIFT_AGGR_BK_TIME_8197F)
#define BITS_AGGR_BK_TIME_8197F \
(BIT_MASK_AGGR_BK_TIME_8197F << BIT_SHIFT_AGGR_BK_TIME_8197F)
#define BIT_CLEAR_AGGR_BK_TIME_8197F(x) ((x) & (~BITS_AGGR_BK_TIME_8197F))
#define BIT_GET_AGGR_BK_TIME_8197F(x) \
(((x) >> BIT_SHIFT_AGGR_BK_TIME_8197F) & BIT_MASK_AGGR_BK_TIME_8197F)
#define BIT_SET_AGGR_BK_TIME_8197F(x, v) \
(BIT_CLEAR_AGGR_BK_TIME_8197F(x) | BIT_AGGR_BK_TIME_8197F(v))
/* 2 REG_SLOT_8197F */
#define BIT_SHIFT_SLOT_8197F 0
#define BIT_MASK_SLOT_8197F 0xff
#define BIT_SLOT_8197F(x) (((x) & BIT_MASK_SLOT_8197F) << BIT_SHIFT_SLOT_8197F)
#define BITS_SLOT_8197F (BIT_MASK_SLOT_8197F << BIT_SHIFT_SLOT_8197F)
#define BIT_CLEAR_SLOT_8197F(x) ((x) & (~BITS_SLOT_8197F))
#define BIT_GET_SLOT_8197F(x) \
(((x) >> BIT_SHIFT_SLOT_8197F) & BIT_MASK_SLOT_8197F)
#define BIT_SET_SLOT_8197F(x, v) (BIT_CLEAR_SLOT_8197F(x) | BIT_SLOT_8197F(v))
/* 2 REG_TX_PTCL_CTRL_8197F */
#define BIT_DIS_EDCCA_8197F BIT(15)
#define BIT_DIS_CCA_8197F BIT(14)
#define BIT_LSIG_TXOP_TXCMD_NAV_8197F BIT(13)
#define BIT_SIFS_BK_EN_8197F BIT(12)
#define BIT_SHIFT_TXQ_NAV_MSK_8197F 8
#define BIT_MASK_TXQ_NAV_MSK_8197F 0xf
#define BIT_TXQ_NAV_MSK_8197F(x) \
(((x) & BIT_MASK_TXQ_NAV_MSK_8197F) << BIT_SHIFT_TXQ_NAV_MSK_8197F)
#define BITS_TXQ_NAV_MSK_8197F \
(BIT_MASK_TXQ_NAV_MSK_8197F << BIT_SHIFT_TXQ_NAV_MSK_8197F)
#define BIT_CLEAR_TXQ_NAV_MSK_8197F(x) ((x) & (~BITS_TXQ_NAV_MSK_8197F))
#define BIT_GET_TXQ_NAV_MSK_8197F(x) \
(((x) >> BIT_SHIFT_TXQ_NAV_MSK_8197F) & BIT_MASK_TXQ_NAV_MSK_8197F)
#define BIT_SET_TXQ_NAV_MSK_8197F(x, v) \
(BIT_CLEAR_TXQ_NAV_MSK_8197F(x) | BIT_TXQ_NAV_MSK_8197F(v))
#define BIT_DIS_CW_8197F BIT(7)
#define BIT_NAV_END_TXOP_8197F BIT(6)
#define BIT_RDG_END_TXOP_8197F BIT(5)
#define BIT_AC_INBCN_HOLD_8197F BIT(4)
#define BIT_MGTQ_TXOP_EN_8197F BIT(3)
#define BIT_MGTQ_RTSMF_EN_8197F BIT(2)
#define BIT_HIQ_RTSMF_EN_8197F BIT(1)
#define BIT_BCN_RTSMF_EN_8197F BIT(0)
/* 2 REG_TXPAUSE_8197F */
#define BIT_STOP_BCN_HI_MGT_8197F BIT(7)
#define BIT_MAC_STOPBCNQ_8197F BIT(6)
#define BIT_MAC_STOPHIQ_8197F BIT(5)
#define BIT_MAC_STOPMGQ_8197F BIT(4)
#define BIT_MAC_STOPBK_8197F BIT(3)
#define BIT_MAC_STOPBE_8197F BIT(2)
#define BIT_MAC_STOPVI_8197F BIT(1)
#define BIT_MAC_STOPVO_8197F BIT(0)
/* 2 REG_DIS_TXREQ_CLR_8197F */
#define BIT_DIS_BT_CCA_8197F BIT(7)
#define BIT_DIS_TXREQ_CLR_CPUMGQ_8197F BIT(6)
#define BIT_DIS_TXREQ_CLR_HI_8197F BIT(5)
#define BIT_DIS_TXREQ_CLR_MGQ_8197F BIT(4)
#define BIT_DIS_TXREQ_CLR_VO_8197F BIT(3)
#define BIT_DIS_TXREQ_CLR_VI_8197F BIT(2)
#define BIT_DIS_TXREQ_CLR_BE_8197F BIT(1)
#define BIT_DIS_TXREQ_CLR_BK_8197F BIT(0)
/* 2 REG_RD_CTRL_8197F */
#define BIT_EN_CLR_TXREQ_INCCA_8197F BIT(15)
#define BIT_DIS_TX_OVER_BCNQ_8197F BIT(14)
#define BIT_EN_BCNERR_INCCA_8197F BIT(13)
#define BIT_EN_BCNERR_INEDCCA_8197F BIT(12)
#define BIT_EDCCA_MSK_CNTDOWN_EN_8197F BIT(11)
#define BIT_DIS_TXOP_CFE_8197F BIT(10)
#define BIT_DIS_LSIG_CFE_8197F BIT(9)
#define BIT_DIS_STBC_CFE_8197F BIT(8)
#define BIT_BKQ_RD_INIT_EN_8197F BIT(7)
#define BIT_BEQ_RD_INIT_EN_8197F BIT(6)
#define BIT_VIQ_RD_INIT_EN_8197F BIT(5)
#define BIT_VOQ_RD_INIT_EN_8197F BIT(4)
#define BIT_BKQ_RD_RESP_EN_8197F BIT(3)
#define BIT_BEQ_RD_RESP_EN_8197F BIT(2)
#define BIT_VIQ_RD_RESP_EN_8197F BIT(1)
#define BIT_VOQ_RD_RESP_EN_8197F BIT(0)
/* 2 REG_MBSSID_CTRL_8197F */
#define BIT_MBID_BCNQ7_EN_8197F BIT(7)
#define BIT_MBID_BCNQ6_EN_8197F BIT(6)
#define BIT_MBID_BCNQ5_EN_8197F BIT(5)
#define BIT_MBID_BCNQ4_EN_8197F BIT(4)
#define BIT_MBID_BCNQ3_EN_8197F BIT(3)
#define BIT_MBID_BCNQ2_EN_8197F BIT(2)
#define BIT_MBID_BCNQ1_EN_8197F BIT(1)
#define BIT_MBID_BCNQ0_EN_8197F BIT(0)
/* 2 REG_P2PPS_CTRL_8197F */
#define BIT_P2P_CTW_ALLSTASLEEP_8197F BIT(7)
#define BIT_P2P_OFF_DISTX_EN_8197F BIT(6)
#define BIT_PWR_MGT_EN_8197F BIT(5)
#define BIT_P2P_NOA1_EN_8197F BIT(2)
#define BIT_P2P_NOA0_EN_8197F BIT(1)
/* 2 REG_PKT_LIFETIME_CTRL_8197F */
#define BIT_EN_TBTT_AREA_FOR_BB_8197F BIT(23)
#define BIT_EN_BKF_CLR_TXREQ_8197F BIT(22)
#define BIT_EN_TSFBIT32_RST_P2P_8197F BIT(21)
#define BIT_EN_BCN_TX_BTCCA_8197F BIT(20)
#define BIT_DIS_PKT_TX_ATIM_8197F BIT(19)
#define BIT_DIS_BCN_DIS_CTN_8197F BIT(18)
#define BIT_EN_NAVEND_RST_TXOP_8197F BIT(17)
#define BIT_EN_FILTER_CCA_8197F BIT(16)
#define BIT_SHIFT_CCA_FILTER_THRS_8197F 8
#define BIT_MASK_CCA_FILTER_THRS_8197F 0xff
#define BIT_CCA_FILTER_THRS_8197F(x) \
(((x) & BIT_MASK_CCA_FILTER_THRS_8197F) \
<< BIT_SHIFT_CCA_FILTER_THRS_8197F)
#define BITS_CCA_FILTER_THRS_8197F \
(BIT_MASK_CCA_FILTER_THRS_8197F << BIT_SHIFT_CCA_FILTER_THRS_8197F)
#define BIT_CLEAR_CCA_FILTER_THRS_8197F(x) ((x) & (~BITS_CCA_FILTER_THRS_8197F))
#define BIT_GET_CCA_FILTER_THRS_8197F(x) \
(((x) >> BIT_SHIFT_CCA_FILTER_THRS_8197F) & \
BIT_MASK_CCA_FILTER_THRS_8197F)
#define BIT_SET_CCA_FILTER_THRS_8197F(x, v) \
(BIT_CLEAR_CCA_FILTER_THRS_8197F(x) | BIT_CCA_FILTER_THRS_8197F(v))
#define BIT_SHIFT_EDCCA_THRS_8197F 0
#define BIT_MASK_EDCCA_THRS_8197F 0xff
#define BIT_EDCCA_THRS_8197F(x) \
(((x) & BIT_MASK_EDCCA_THRS_8197F) << BIT_SHIFT_EDCCA_THRS_8197F)
#define BITS_EDCCA_THRS_8197F \
(BIT_MASK_EDCCA_THRS_8197F << BIT_SHIFT_EDCCA_THRS_8197F)
#define BIT_CLEAR_EDCCA_THRS_8197F(x) ((x) & (~BITS_EDCCA_THRS_8197F))
#define BIT_GET_EDCCA_THRS_8197F(x) \
(((x) >> BIT_SHIFT_EDCCA_THRS_8197F) & BIT_MASK_EDCCA_THRS_8197F)
#define BIT_SET_EDCCA_THRS_8197F(x, v) \
(BIT_CLEAR_EDCCA_THRS_8197F(x) | BIT_EDCCA_THRS_8197F(v))
/* 2 REG_P2PPS_SPEC_STATE_8197F */
#define BIT_SPEC_POWER_STATE_8197F BIT(7)
#define BIT_SPEC_CTWINDOW_ON_8197F BIT(6)
#define BIT_SPEC_BEACON_AREA_ON_8197F BIT(5)
#define BIT_SPEC_CTWIN_EARLY_DISTX_8197F BIT(4)
#define BIT_SPEC_NOA1_OFF_PERIOD_8197F BIT(3)
#define BIT_SPEC_FORCE_DOZE1_8197F BIT(2)
#define BIT_SPEC_NOA0_OFF_PERIOD_8197F BIT(1)
#define BIT_SPEC_FORCE_DOZE0_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_P2PON_DIS_TXTIME_8197F 0
#define BIT_MASK_P2PON_DIS_TXTIME_8197F 0xff
#define BIT_P2PON_DIS_TXTIME_8197F(x) \
(((x) & BIT_MASK_P2PON_DIS_TXTIME_8197F) \
<< BIT_SHIFT_P2PON_DIS_TXTIME_8197F)
#define BITS_P2PON_DIS_TXTIME_8197F \
(BIT_MASK_P2PON_DIS_TXTIME_8197F << BIT_SHIFT_P2PON_DIS_TXTIME_8197F)
#define BIT_CLEAR_P2PON_DIS_TXTIME_8197F(x) \
((x) & (~BITS_P2PON_DIS_TXTIME_8197F))
#define BIT_GET_P2PON_DIS_TXTIME_8197F(x) \
(((x) >> BIT_SHIFT_P2PON_DIS_TXTIME_8197F) & \
BIT_MASK_P2PON_DIS_TXTIME_8197F)
#define BIT_SET_P2PON_DIS_TXTIME_8197F(x, v) \
(BIT_CLEAR_P2PON_DIS_TXTIME_8197F(x) | BIT_P2PON_DIS_TXTIME_8197F(v))
/* 2 REG_QUEUE_INCOL_THR_8197F */
#define BIT_SHIFT_BK_QUEUE_THR_8197F 24
#define BIT_MASK_BK_QUEUE_THR_8197F 0xff
#define BIT_BK_QUEUE_THR_8197F(x) \
(((x) & BIT_MASK_BK_QUEUE_THR_8197F) << BIT_SHIFT_BK_QUEUE_THR_8197F)
#define BITS_BK_QUEUE_THR_8197F \
(BIT_MASK_BK_QUEUE_THR_8197F << BIT_SHIFT_BK_QUEUE_THR_8197F)
#define BIT_CLEAR_BK_QUEUE_THR_8197F(x) ((x) & (~BITS_BK_QUEUE_THR_8197F))
#define BIT_GET_BK_QUEUE_THR_8197F(x) \
(((x) >> BIT_SHIFT_BK_QUEUE_THR_8197F) & BIT_MASK_BK_QUEUE_THR_8197F)
#define BIT_SET_BK_QUEUE_THR_8197F(x, v) \
(BIT_CLEAR_BK_QUEUE_THR_8197F(x) | BIT_BK_QUEUE_THR_8197F(v))
#define BIT_SHIFT_BE_QUEUE_THR_8197F 16
#define BIT_MASK_BE_QUEUE_THR_8197F 0xff
#define BIT_BE_QUEUE_THR_8197F(x) \
(((x) & BIT_MASK_BE_QUEUE_THR_8197F) << BIT_SHIFT_BE_QUEUE_THR_8197F)
#define BITS_BE_QUEUE_THR_8197F \
(BIT_MASK_BE_QUEUE_THR_8197F << BIT_SHIFT_BE_QUEUE_THR_8197F)
#define BIT_CLEAR_BE_QUEUE_THR_8197F(x) ((x) & (~BITS_BE_QUEUE_THR_8197F))
#define BIT_GET_BE_QUEUE_THR_8197F(x) \
(((x) >> BIT_SHIFT_BE_QUEUE_THR_8197F) & BIT_MASK_BE_QUEUE_THR_8197F)
#define BIT_SET_BE_QUEUE_THR_8197F(x, v) \
(BIT_CLEAR_BE_QUEUE_THR_8197F(x) | BIT_BE_QUEUE_THR_8197F(v))
#define BIT_SHIFT_VI_QUEUE_THR_8197F 8
#define BIT_MASK_VI_QUEUE_THR_8197F 0xff
#define BIT_VI_QUEUE_THR_8197F(x) \
(((x) & BIT_MASK_VI_QUEUE_THR_8197F) << BIT_SHIFT_VI_QUEUE_THR_8197F)
#define BITS_VI_QUEUE_THR_8197F \
(BIT_MASK_VI_QUEUE_THR_8197F << BIT_SHIFT_VI_QUEUE_THR_8197F)
#define BIT_CLEAR_VI_QUEUE_THR_8197F(x) ((x) & (~BITS_VI_QUEUE_THR_8197F))
#define BIT_GET_VI_QUEUE_THR_8197F(x) \
(((x) >> BIT_SHIFT_VI_QUEUE_THR_8197F) & BIT_MASK_VI_QUEUE_THR_8197F)
#define BIT_SET_VI_QUEUE_THR_8197F(x, v) \
(BIT_CLEAR_VI_QUEUE_THR_8197F(x) | BIT_VI_QUEUE_THR_8197F(v))
#define BIT_SHIFT_VO_QUEUE_THR_8197F 0
#define BIT_MASK_VO_QUEUE_THR_8197F 0xff
#define BIT_VO_QUEUE_THR_8197F(x) \
(((x) & BIT_MASK_VO_QUEUE_THR_8197F) << BIT_SHIFT_VO_QUEUE_THR_8197F)
#define BITS_VO_QUEUE_THR_8197F \
(BIT_MASK_VO_QUEUE_THR_8197F << BIT_SHIFT_VO_QUEUE_THR_8197F)
#define BIT_CLEAR_VO_QUEUE_THR_8197F(x) ((x) & (~BITS_VO_QUEUE_THR_8197F))
#define BIT_GET_VO_QUEUE_THR_8197F(x) \
(((x) >> BIT_SHIFT_VO_QUEUE_THR_8197F) & BIT_MASK_VO_QUEUE_THR_8197F)
#define BIT_SET_VO_QUEUE_THR_8197F(x, v) \
(BIT_CLEAR_VO_QUEUE_THR_8197F(x) | BIT_VO_QUEUE_THR_8197F(v))
/* 2 REG_QUEUE_INCOL_EN_8197F */
#define BIT_QUEUE_INCOL_EN_8197F BIT(16)
#define BIT_SHIFT_BK_TRIGGER_NUM_V1_8197F 12
#define BIT_MASK_BK_TRIGGER_NUM_V1_8197F 0xf
#define BIT_BK_TRIGGER_NUM_V1_8197F(x) \
(((x) & BIT_MASK_BK_TRIGGER_NUM_V1_8197F) \
<< BIT_SHIFT_BK_TRIGGER_NUM_V1_8197F)
#define BITS_BK_TRIGGER_NUM_V1_8197F \
(BIT_MASK_BK_TRIGGER_NUM_V1_8197F << BIT_SHIFT_BK_TRIGGER_NUM_V1_8197F)
#define BIT_CLEAR_BK_TRIGGER_NUM_V1_8197F(x) \
((x) & (~BITS_BK_TRIGGER_NUM_V1_8197F))
#define BIT_GET_BK_TRIGGER_NUM_V1_8197F(x) \
(((x) >> BIT_SHIFT_BK_TRIGGER_NUM_V1_8197F) & \
BIT_MASK_BK_TRIGGER_NUM_V1_8197F)
#define BIT_SET_BK_TRIGGER_NUM_V1_8197F(x, v) \
(BIT_CLEAR_BK_TRIGGER_NUM_V1_8197F(x) | BIT_BK_TRIGGER_NUM_V1_8197F(v))
#define BIT_SHIFT_BE_TRIGGER_NUM_V1_8197F 8
#define BIT_MASK_BE_TRIGGER_NUM_V1_8197F 0xf
#define BIT_BE_TRIGGER_NUM_V1_8197F(x) \
(((x) & BIT_MASK_BE_TRIGGER_NUM_V1_8197F) \
<< BIT_SHIFT_BE_TRIGGER_NUM_V1_8197F)
#define BITS_BE_TRIGGER_NUM_V1_8197F \
(BIT_MASK_BE_TRIGGER_NUM_V1_8197F << BIT_SHIFT_BE_TRIGGER_NUM_V1_8197F)
#define BIT_CLEAR_BE_TRIGGER_NUM_V1_8197F(x) \
((x) & (~BITS_BE_TRIGGER_NUM_V1_8197F))
#define BIT_GET_BE_TRIGGER_NUM_V1_8197F(x) \
(((x) >> BIT_SHIFT_BE_TRIGGER_NUM_V1_8197F) & \
BIT_MASK_BE_TRIGGER_NUM_V1_8197F)
#define BIT_SET_BE_TRIGGER_NUM_V1_8197F(x, v) \
(BIT_CLEAR_BE_TRIGGER_NUM_V1_8197F(x) | BIT_BE_TRIGGER_NUM_V1_8197F(v))
#define BIT_SHIFT_VI_TRIGGER_NUM_8197F 4
#define BIT_MASK_VI_TRIGGER_NUM_8197F 0xf
#define BIT_VI_TRIGGER_NUM_8197F(x) \
(((x) & BIT_MASK_VI_TRIGGER_NUM_8197F) \
<< BIT_SHIFT_VI_TRIGGER_NUM_8197F)
#define BITS_VI_TRIGGER_NUM_8197F \
(BIT_MASK_VI_TRIGGER_NUM_8197F << BIT_SHIFT_VI_TRIGGER_NUM_8197F)
#define BIT_CLEAR_VI_TRIGGER_NUM_8197F(x) ((x) & (~BITS_VI_TRIGGER_NUM_8197F))
#define BIT_GET_VI_TRIGGER_NUM_8197F(x) \
(((x) >> BIT_SHIFT_VI_TRIGGER_NUM_8197F) & \
BIT_MASK_VI_TRIGGER_NUM_8197F)
#define BIT_SET_VI_TRIGGER_NUM_8197F(x, v) \
(BIT_CLEAR_VI_TRIGGER_NUM_8197F(x) | BIT_VI_TRIGGER_NUM_8197F(v))
#define BIT_SHIFT_VO_TRIGGER_NUM_8197F 0
#define BIT_MASK_VO_TRIGGER_NUM_8197F 0xf
#define BIT_VO_TRIGGER_NUM_8197F(x) \
(((x) & BIT_MASK_VO_TRIGGER_NUM_8197F) \
<< BIT_SHIFT_VO_TRIGGER_NUM_8197F)
#define BITS_VO_TRIGGER_NUM_8197F \
(BIT_MASK_VO_TRIGGER_NUM_8197F << BIT_SHIFT_VO_TRIGGER_NUM_8197F)
#define BIT_CLEAR_VO_TRIGGER_NUM_8197F(x) ((x) & (~BITS_VO_TRIGGER_NUM_8197F))
#define BIT_GET_VO_TRIGGER_NUM_8197F(x) \
(((x) >> BIT_SHIFT_VO_TRIGGER_NUM_8197F) & \
BIT_MASK_VO_TRIGGER_NUM_8197F)
#define BIT_SET_VO_TRIGGER_NUM_8197F(x, v) \
(BIT_CLEAR_VO_TRIGGER_NUM_8197F(x) | BIT_VO_TRIGGER_NUM_8197F(v))
/* 2 REG_TBTT_PROHIBIT_8197F */
#define BIT_SHIFT_TBTT_HOLD_TIME_AP_8197F 8
#define BIT_MASK_TBTT_HOLD_TIME_AP_8197F 0xfff
#define BIT_TBTT_HOLD_TIME_AP_8197F(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_AP_8197F) \
<< BIT_SHIFT_TBTT_HOLD_TIME_AP_8197F)
#define BITS_TBTT_HOLD_TIME_AP_8197F \
(BIT_MASK_TBTT_HOLD_TIME_AP_8197F << BIT_SHIFT_TBTT_HOLD_TIME_AP_8197F)
#define BIT_CLEAR_TBTT_HOLD_TIME_AP_8197F(x) \
((x) & (~BITS_TBTT_HOLD_TIME_AP_8197F))
#define BIT_GET_TBTT_HOLD_TIME_AP_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_AP_8197F) & \
BIT_MASK_TBTT_HOLD_TIME_AP_8197F)
#define BIT_SET_TBTT_HOLD_TIME_AP_8197F(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_AP_8197F(x) | BIT_TBTT_HOLD_TIME_AP_8197F(v))
#define BIT_SHIFT_TBTT_PROHIBIT_SETUP_8197F 0
#define BIT_MASK_TBTT_PROHIBIT_SETUP_8197F 0xf
#define BIT_TBTT_PROHIBIT_SETUP_8197F(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_SETUP_8197F) \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8197F)
#define BITS_TBTT_PROHIBIT_SETUP_8197F \
(BIT_MASK_TBTT_PROHIBIT_SETUP_8197F \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8197F)
#define BIT_CLEAR_TBTT_PROHIBIT_SETUP_8197F(x) \
((x) & (~BITS_TBTT_PROHIBIT_SETUP_8197F))
#define BIT_GET_TBTT_PROHIBIT_SETUP_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_SETUP_8197F) & \
BIT_MASK_TBTT_PROHIBIT_SETUP_8197F)
#define BIT_SET_TBTT_PROHIBIT_SETUP_8197F(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_SETUP_8197F(x) | \
BIT_TBTT_PROHIBIT_SETUP_8197F(v))
/* 2 REG_P2PPS_STATE_8197F */
#define BIT_POWER_STATE_8197F BIT(7)
#define BIT_CTWINDOW_ON_8197F BIT(6)
#define BIT_BEACON_AREA_ON_8197F BIT(5)
#define BIT_CTWIN_EARLY_DISTX_8197F BIT(4)
#define BIT_NOA1_OFF_PERIOD_8197F BIT(3)
#define BIT_FORCE_DOZE1_8197F BIT(2)
#define BIT_NOA0_OFF_PERIOD_8197F BIT(1)
#define BIT_FORCE_DOZE0_8197F BIT(0)
/* 2 REG_RD_NAV_NXT_8197F */
#define BIT_SHIFT_RD_NAV_PROT_NXT_8197F 0
#define BIT_MASK_RD_NAV_PROT_NXT_8197F 0xffff
#define BIT_RD_NAV_PROT_NXT_8197F(x) \
(((x) & BIT_MASK_RD_NAV_PROT_NXT_8197F) \
<< BIT_SHIFT_RD_NAV_PROT_NXT_8197F)
#define BITS_RD_NAV_PROT_NXT_8197F \
(BIT_MASK_RD_NAV_PROT_NXT_8197F << BIT_SHIFT_RD_NAV_PROT_NXT_8197F)
#define BIT_CLEAR_RD_NAV_PROT_NXT_8197F(x) ((x) & (~BITS_RD_NAV_PROT_NXT_8197F))
#define BIT_GET_RD_NAV_PROT_NXT_8197F(x) \
(((x) >> BIT_SHIFT_RD_NAV_PROT_NXT_8197F) & \
BIT_MASK_RD_NAV_PROT_NXT_8197F)
#define BIT_SET_RD_NAV_PROT_NXT_8197F(x, v) \
(BIT_CLEAR_RD_NAV_PROT_NXT_8197F(x) | BIT_RD_NAV_PROT_NXT_8197F(v))
/* 2 REG_NAV_PROT_LEN_8197F */
#define BIT_SHIFT_NAV_PROT_LEN_8197F 0
#define BIT_MASK_NAV_PROT_LEN_8197F 0xffff
#define BIT_NAV_PROT_LEN_8197F(x) \
(((x) & BIT_MASK_NAV_PROT_LEN_8197F) << BIT_SHIFT_NAV_PROT_LEN_8197F)
#define BITS_NAV_PROT_LEN_8197F \
(BIT_MASK_NAV_PROT_LEN_8197F << BIT_SHIFT_NAV_PROT_LEN_8197F)
#define BIT_CLEAR_NAV_PROT_LEN_8197F(x) ((x) & (~BITS_NAV_PROT_LEN_8197F))
#define BIT_GET_NAV_PROT_LEN_8197F(x) \
(((x) >> BIT_SHIFT_NAV_PROT_LEN_8197F) & BIT_MASK_NAV_PROT_LEN_8197F)
#define BIT_SET_NAV_PROT_LEN_8197F(x, v) \
(BIT_CLEAR_NAV_PROT_LEN_8197F(x) | BIT_NAV_PROT_LEN_8197F(v))
/* 2 REG_FTM_CTRL_8197F */
#define BIT_SHIFT_FTM_TSF_R2T_PORT_8197F 22
#define BIT_MASK_FTM_TSF_R2T_PORT_8197F 0x7
#define BIT_FTM_TSF_R2T_PORT_8197F(x) \
(((x) & BIT_MASK_FTM_TSF_R2T_PORT_8197F) \
<< BIT_SHIFT_FTM_TSF_R2T_PORT_8197F)
#define BITS_FTM_TSF_R2T_PORT_8197F \
(BIT_MASK_FTM_TSF_R2T_PORT_8197F << BIT_SHIFT_FTM_TSF_R2T_PORT_8197F)
#define BIT_CLEAR_FTM_TSF_R2T_PORT_8197F(x) \
((x) & (~BITS_FTM_TSF_R2T_PORT_8197F))
#define BIT_GET_FTM_TSF_R2T_PORT_8197F(x) \
(((x) >> BIT_SHIFT_FTM_TSF_R2T_PORT_8197F) & \
BIT_MASK_FTM_TSF_R2T_PORT_8197F)
#define BIT_SET_FTM_TSF_R2T_PORT_8197F(x, v) \
(BIT_CLEAR_FTM_TSF_R2T_PORT_8197F(x) | BIT_FTM_TSF_R2T_PORT_8197F(v))
#define BIT_SHIFT_FTM_TSF_T2R_PORT_8197F 19
#define BIT_MASK_FTM_TSF_T2R_PORT_8197F 0x7
#define BIT_FTM_TSF_T2R_PORT_8197F(x) \
(((x) & BIT_MASK_FTM_TSF_T2R_PORT_8197F) \
<< BIT_SHIFT_FTM_TSF_T2R_PORT_8197F)
#define BITS_FTM_TSF_T2R_PORT_8197F \
(BIT_MASK_FTM_TSF_T2R_PORT_8197F << BIT_SHIFT_FTM_TSF_T2R_PORT_8197F)
#define BIT_CLEAR_FTM_TSF_T2R_PORT_8197F(x) \
((x) & (~BITS_FTM_TSF_T2R_PORT_8197F))
#define BIT_GET_FTM_TSF_T2R_PORT_8197F(x) \
(((x) >> BIT_SHIFT_FTM_TSF_T2R_PORT_8197F) & \
BIT_MASK_FTM_TSF_T2R_PORT_8197F)
#define BIT_SET_FTM_TSF_T2R_PORT_8197F(x, v) \
(BIT_CLEAR_FTM_TSF_T2R_PORT_8197F(x) | BIT_FTM_TSF_T2R_PORT_8197F(v))
#define BIT_SHIFT_FTM_PTT_PORT_8197F 16
#define BIT_MASK_FTM_PTT_PORT_8197F 0x7
#define BIT_FTM_PTT_PORT_8197F(x) \
(((x) & BIT_MASK_FTM_PTT_PORT_8197F) << BIT_SHIFT_FTM_PTT_PORT_8197F)
#define BITS_FTM_PTT_PORT_8197F \
(BIT_MASK_FTM_PTT_PORT_8197F << BIT_SHIFT_FTM_PTT_PORT_8197F)
#define BIT_CLEAR_FTM_PTT_PORT_8197F(x) ((x) & (~BITS_FTM_PTT_PORT_8197F))
#define BIT_GET_FTM_PTT_PORT_8197F(x) \
(((x) >> BIT_SHIFT_FTM_PTT_PORT_8197F) & BIT_MASK_FTM_PTT_PORT_8197F)
#define BIT_SET_FTM_PTT_PORT_8197F(x, v) \
(BIT_CLEAR_FTM_PTT_PORT_8197F(x) | BIT_FTM_PTT_PORT_8197F(v))
#define BIT_SHIFT_FTM_PTT_8197F 0
#define BIT_MASK_FTM_PTT_8197F 0xffff
#define BIT_FTM_PTT_8197F(x) \
(((x) & BIT_MASK_FTM_PTT_8197F) << BIT_SHIFT_FTM_PTT_8197F)
#define BITS_FTM_PTT_8197F (BIT_MASK_FTM_PTT_8197F << BIT_SHIFT_FTM_PTT_8197F)
#define BIT_CLEAR_FTM_PTT_8197F(x) ((x) & (~BITS_FTM_PTT_8197F))
#define BIT_GET_FTM_PTT_8197F(x) \
(((x) >> BIT_SHIFT_FTM_PTT_8197F) & BIT_MASK_FTM_PTT_8197F)
#define BIT_SET_FTM_PTT_8197F(x, v) \
(BIT_CLEAR_FTM_PTT_8197F(x) | BIT_FTM_PTT_8197F(v))
/* 2 REG_FTM_TSF_CNT_8197F */
#define BIT_SHIFT_FTM_TSF_R2T_8197F 16
#define BIT_MASK_FTM_TSF_R2T_8197F 0xffff
#define BIT_FTM_TSF_R2T_8197F(x) \
(((x) & BIT_MASK_FTM_TSF_R2T_8197F) << BIT_SHIFT_FTM_TSF_R2T_8197F)
#define BITS_FTM_TSF_R2T_8197F \
(BIT_MASK_FTM_TSF_R2T_8197F << BIT_SHIFT_FTM_TSF_R2T_8197F)
#define BIT_CLEAR_FTM_TSF_R2T_8197F(x) ((x) & (~BITS_FTM_TSF_R2T_8197F))
#define BIT_GET_FTM_TSF_R2T_8197F(x) \
(((x) >> BIT_SHIFT_FTM_TSF_R2T_8197F) & BIT_MASK_FTM_TSF_R2T_8197F)
#define BIT_SET_FTM_TSF_R2T_8197F(x, v) \
(BIT_CLEAR_FTM_TSF_R2T_8197F(x) | BIT_FTM_TSF_R2T_8197F(v))
#define BIT_SHIFT_FTM_TSF_T2R_8197F 0
#define BIT_MASK_FTM_TSF_T2R_8197F 0xffff
#define BIT_FTM_TSF_T2R_8197F(x) \
(((x) & BIT_MASK_FTM_TSF_T2R_8197F) << BIT_SHIFT_FTM_TSF_T2R_8197F)
#define BITS_FTM_TSF_T2R_8197F \
(BIT_MASK_FTM_TSF_T2R_8197F << BIT_SHIFT_FTM_TSF_T2R_8197F)
#define BIT_CLEAR_FTM_TSF_T2R_8197F(x) ((x) & (~BITS_FTM_TSF_T2R_8197F))
#define BIT_GET_FTM_TSF_T2R_8197F(x) \
(((x) >> BIT_SHIFT_FTM_TSF_T2R_8197F) & BIT_MASK_FTM_TSF_T2R_8197F)
#define BIT_SET_FTM_TSF_T2R_8197F(x, v) \
(BIT_CLEAR_FTM_TSF_T2R_8197F(x) | BIT_FTM_TSF_T2R_8197F(v))
/* 2 REG_BCN_CTRL_8197F */
#define BIT_DIS_RX_BSSID_FIT_8197F BIT(6)
#define BIT_P0_EN_TXBCN_RPT_8197F BIT(5)
#define BIT_DIS_TSF_UDT_8197F BIT(4)
#define BIT_EN_BCN_FUNCTION_8197F BIT(3)
#define BIT_P0_EN_RXBCN_RPT_8197F BIT(2)
#define BIT_EN_P2P_CTWINDOW_8197F BIT(1)
#define BIT_EN_P2P_BCNQ_AREA_8197F BIT(0)
/* 2 REG_BCN_CTRL_CLINT0_8197F */
#define BIT_CLI0_DIS_RX_BSSID_FIT_8197F BIT(6)
#define BIT_CLI0_DIS_TSF_UDT_8197F BIT(4)
#define BIT_CLI0_EN_BCN_FUNCTION_8197F BIT(3)
#define BIT_CLI0_EN_RXBCN_RPT_8197F BIT(2)
#define BIT_CLI0_ENP2P_CTWINDOW_8197F BIT(1)
#define BIT_CLI0_ENP2P_BCNQ_AREA_8197F BIT(0)
/* 2 REG_MBID_NUM_8197F */
#define BIT_EN_PRE_DL_BEACON_8197F BIT(3)
#define BIT_SHIFT_MBID_BCN_NUM_8197F 0
#define BIT_MASK_MBID_BCN_NUM_8197F 0x7
#define BIT_MBID_BCN_NUM_8197F(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_8197F) << BIT_SHIFT_MBID_BCN_NUM_8197F)
#define BITS_MBID_BCN_NUM_8197F \
(BIT_MASK_MBID_BCN_NUM_8197F << BIT_SHIFT_MBID_BCN_NUM_8197F)
#define BIT_CLEAR_MBID_BCN_NUM_8197F(x) ((x) & (~BITS_MBID_BCN_NUM_8197F))
#define BIT_GET_MBID_BCN_NUM_8197F(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_8197F) & BIT_MASK_MBID_BCN_NUM_8197F)
#define BIT_SET_MBID_BCN_NUM_8197F(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_8197F(x) | BIT_MBID_BCN_NUM_8197F(v))
/* 2 REG_DUAL_TSF_RST_8197F */
#define BIT_FREECNT_RST_8197F BIT(5)
#define BIT_TSFTR_CLI3_RST_8197F BIT(4)
#define BIT_TSFTR_CLI2_RST_8197F BIT(3)
#define BIT_TSFTR_CLI1_RST_8197F BIT(2)
#define BIT_TSFTR_CLI0_RST_8197F BIT(1)
#define BIT_TSFTR_RST_8197F BIT(0)
/* 2 REG_MBSSID_BCN_SPACE_8197F */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD_8197F 28
#define BIT_MASK_BCN_TIMER_SEL_FWRD_8197F 0x7
#define BIT_BCN_TIMER_SEL_FWRD_8197F(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD_8197F) \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8197F)
#define BITS_BCN_TIMER_SEL_FWRD_8197F \
(BIT_MASK_BCN_TIMER_SEL_FWRD_8197F \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8197F)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD_8197F(x) \
((x) & (~BITS_BCN_TIMER_SEL_FWRD_8197F))
#define BIT_GET_BCN_TIMER_SEL_FWRD_8197F(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD_8197F) & \
BIT_MASK_BCN_TIMER_SEL_FWRD_8197F)
#define BIT_SET_BCN_TIMER_SEL_FWRD_8197F(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD_8197F(x) | \
BIT_BCN_TIMER_SEL_FWRD_8197F(v))
#define BIT_SHIFT_BCN_SPACE_CLINT0_8197F 16
#define BIT_MASK_BCN_SPACE_CLINT0_8197F 0xfff
#define BIT_BCN_SPACE_CLINT0_8197F(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT0_8197F) \
<< BIT_SHIFT_BCN_SPACE_CLINT0_8197F)
#define BITS_BCN_SPACE_CLINT0_8197F \
(BIT_MASK_BCN_SPACE_CLINT0_8197F << BIT_SHIFT_BCN_SPACE_CLINT0_8197F)
#define BIT_CLEAR_BCN_SPACE_CLINT0_8197F(x) \
((x) & (~BITS_BCN_SPACE_CLINT0_8197F))
#define BIT_GET_BCN_SPACE_CLINT0_8197F(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT0_8197F) & \
BIT_MASK_BCN_SPACE_CLINT0_8197F)
#define BIT_SET_BCN_SPACE_CLINT0_8197F(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT0_8197F(x) | BIT_BCN_SPACE_CLINT0_8197F(v))
#define BIT_SHIFT_BCN_SPACE0_8197F 0
#define BIT_MASK_BCN_SPACE0_8197F 0xffff
#define BIT_BCN_SPACE0_8197F(x) \
(((x) & BIT_MASK_BCN_SPACE0_8197F) << BIT_SHIFT_BCN_SPACE0_8197F)
#define BITS_BCN_SPACE0_8197F \
(BIT_MASK_BCN_SPACE0_8197F << BIT_SHIFT_BCN_SPACE0_8197F)
#define BIT_CLEAR_BCN_SPACE0_8197F(x) ((x) & (~BITS_BCN_SPACE0_8197F))
#define BIT_GET_BCN_SPACE0_8197F(x) \
(((x) >> BIT_SHIFT_BCN_SPACE0_8197F) & BIT_MASK_BCN_SPACE0_8197F)
#define BIT_SET_BCN_SPACE0_8197F(x, v) \
(BIT_CLEAR_BCN_SPACE0_8197F(x) | BIT_BCN_SPACE0_8197F(v))
/* 2 REG_DRVERLYINT_8197F */
#define BIT_SHIFT_DRVERLYITV_8197F 0
#define BIT_MASK_DRVERLYITV_8197F 0xff
#define BIT_DRVERLYITV_8197F(x) \
(((x) & BIT_MASK_DRVERLYITV_8197F) << BIT_SHIFT_DRVERLYITV_8197F)
#define BITS_DRVERLYITV_8197F \
(BIT_MASK_DRVERLYITV_8197F << BIT_SHIFT_DRVERLYITV_8197F)
#define BIT_CLEAR_DRVERLYITV_8197F(x) ((x) & (~BITS_DRVERLYITV_8197F))
#define BIT_GET_DRVERLYITV_8197F(x) \
(((x) >> BIT_SHIFT_DRVERLYITV_8197F) & BIT_MASK_DRVERLYITV_8197F)
#define BIT_SET_DRVERLYITV_8197F(x, v) \
(BIT_CLEAR_DRVERLYITV_8197F(x) | BIT_DRVERLYITV_8197F(v))
/* 2 REG_BCNDMATIM_8197F */
#define BIT_SHIFT_BCNDMATIM_8197F 0
#define BIT_MASK_BCNDMATIM_8197F 0xff
#define BIT_BCNDMATIM_8197F(x) \
(((x) & BIT_MASK_BCNDMATIM_8197F) << BIT_SHIFT_BCNDMATIM_8197F)
#define BITS_BCNDMATIM_8197F \
(BIT_MASK_BCNDMATIM_8197F << BIT_SHIFT_BCNDMATIM_8197F)
#define BIT_CLEAR_BCNDMATIM_8197F(x) ((x) & (~BITS_BCNDMATIM_8197F))
#define BIT_GET_BCNDMATIM_8197F(x) \
(((x) >> BIT_SHIFT_BCNDMATIM_8197F) & BIT_MASK_BCNDMATIM_8197F)
#define BIT_SET_BCNDMATIM_8197F(x, v) \
(BIT_CLEAR_BCNDMATIM_8197F(x) | BIT_BCNDMATIM_8197F(v))
/* 2 REG_ATIMWND_8197F */
#define BIT_SHIFT_ATIMWND0_8197F 0
#define BIT_MASK_ATIMWND0_8197F 0xffff
#define BIT_ATIMWND0_8197F(x) \
(((x) & BIT_MASK_ATIMWND0_8197F) << BIT_SHIFT_ATIMWND0_8197F)
#define BITS_ATIMWND0_8197F \
(BIT_MASK_ATIMWND0_8197F << BIT_SHIFT_ATIMWND0_8197F)
#define BIT_CLEAR_ATIMWND0_8197F(x) ((x) & (~BITS_ATIMWND0_8197F))
#define BIT_GET_ATIMWND0_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND0_8197F) & BIT_MASK_ATIMWND0_8197F)
#define BIT_SET_ATIMWND0_8197F(x, v) \
(BIT_CLEAR_ATIMWND0_8197F(x) | BIT_ATIMWND0_8197F(v))
/* 2 REG_USTIME_TSF_8197F */
#define BIT_SHIFT_USTIME_TSF_V1_8197F 0
#define BIT_MASK_USTIME_TSF_V1_8197F 0xff
#define BIT_USTIME_TSF_V1_8197F(x) \
(((x) & BIT_MASK_USTIME_TSF_V1_8197F) << BIT_SHIFT_USTIME_TSF_V1_8197F)
#define BITS_USTIME_TSF_V1_8197F \
(BIT_MASK_USTIME_TSF_V1_8197F << BIT_SHIFT_USTIME_TSF_V1_8197F)
#define BIT_CLEAR_USTIME_TSF_V1_8197F(x) ((x) & (~BITS_USTIME_TSF_V1_8197F))
#define BIT_GET_USTIME_TSF_V1_8197F(x) \
(((x) >> BIT_SHIFT_USTIME_TSF_V1_8197F) & BIT_MASK_USTIME_TSF_V1_8197F)
#define BIT_SET_USTIME_TSF_V1_8197F(x, v) \
(BIT_CLEAR_USTIME_TSF_V1_8197F(x) | BIT_USTIME_TSF_V1_8197F(v))
/* 2 REG_BCN_MAX_ERR_8197F */
#define BIT_SHIFT_BCN_MAX_ERR_8197F 0
#define BIT_MASK_BCN_MAX_ERR_8197F 0xff
#define BIT_BCN_MAX_ERR_8197F(x) \
(((x) & BIT_MASK_BCN_MAX_ERR_8197F) << BIT_SHIFT_BCN_MAX_ERR_8197F)
#define BITS_BCN_MAX_ERR_8197F \
(BIT_MASK_BCN_MAX_ERR_8197F << BIT_SHIFT_BCN_MAX_ERR_8197F)
#define BIT_CLEAR_BCN_MAX_ERR_8197F(x) ((x) & (~BITS_BCN_MAX_ERR_8197F))
#define BIT_GET_BCN_MAX_ERR_8197F(x) \
(((x) >> BIT_SHIFT_BCN_MAX_ERR_8197F) & BIT_MASK_BCN_MAX_ERR_8197F)
#define BIT_SET_BCN_MAX_ERR_8197F(x, v) \
(BIT_CLEAR_BCN_MAX_ERR_8197F(x) | BIT_BCN_MAX_ERR_8197F(v))
/* 2 REG_RXTSF_OFFSET_CCK_8197F */
#define BIT_SHIFT_CCK_RXTSF_OFFSET_8197F 0
#define BIT_MASK_CCK_RXTSF_OFFSET_8197F 0xff
#define BIT_CCK_RXTSF_OFFSET_8197F(x) \
(((x) & BIT_MASK_CCK_RXTSF_OFFSET_8197F) \
<< BIT_SHIFT_CCK_RXTSF_OFFSET_8197F)
#define BITS_CCK_RXTSF_OFFSET_8197F \
(BIT_MASK_CCK_RXTSF_OFFSET_8197F << BIT_SHIFT_CCK_RXTSF_OFFSET_8197F)
#define BIT_CLEAR_CCK_RXTSF_OFFSET_8197F(x) \
((x) & (~BITS_CCK_RXTSF_OFFSET_8197F))
#define BIT_GET_CCK_RXTSF_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_CCK_RXTSF_OFFSET_8197F) & \
BIT_MASK_CCK_RXTSF_OFFSET_8197F)
#define BIT_SET_CCK_RXTSF_OFFSET_8197F(x, v) \
(BIT_CLEAR_CCK_RXTSF_OFFSET_8197F(x) | BIT_CCK_RXTSF_OFFSET_8197F(v))
/* 2 REG_RXTSF_OFFSET_OFDM_8197F */
#define BIT_SHIFT_OFDM_RXTSF_OFFSET_8197F 0
#define BIT_MASK_OFDM_RXTSF_OFFSET_8197F 0xff
#define BIT_OFDM_RXTSF_OFFSET_8197F(x) \
(((x) & BIT_MASK_OFDM_RXTSF_OFFSET_8197F) \
<< BIT_SHIFT_OFDM_RXTSF_OFFSET_8197F)
#define BITS_OFDM_RXTSF_OFFSET_8197F \
(BIT_MASK_OFDM_RXTSF_OFFSET_8197F << BIT_SHIFT_OFDM_RXTSF_OFFSET_8197F)
#define BIT_CLEAR_OFDM_RXTSF_OFFSET_8197F(x) \
((x) & (~BITS_OFDM_RXTSF_OFFSET_8197F))
#define BIT_GET_OFDM_RXTSF_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_OFDM_RXTSF_OFFSET_8197F) & \
BIT_MASK_OFDM_RXTSF_OFFSET_8197F)
#define BIT_SET_OFDM_RXTSF_OFFSET_8197F(x, v) \
(BIT_CLEAR_OFDM_RXTSF_OFFSET_8197F(x) | BIT_OFDM_RXTSF_OFFSET_8197F(v))
/* 2 REG_TSFTR_8197F */
#define BIT_SHIFT_TSF_TIMER_8197F 0
#define BIT_MASK_TSF_TIMER_8197F 0xffffffffffffffffL
#define BIT_TSF_TIMER_8197F(x) \
(((x) & BIT_MASK_TSF_TIMER_8197F) << BIT_SHIFT_TSF_TIMER_8197F)
#define BITS_TSF_TIMER_8197F \
(BIT_MASK_TSF_TIMER_8197F << BIT_SHIFT_TSF_TIMER_8197F)
#define BIT_CLEAR_TSF_TIMER_8197F(x) ((x) & (~BITS_TSF_TIMER_8197F))
#define BIT_GET_TSF_TIMER_8197F(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_8197F) & BIT_MASK_TSF_TIMER_8197F)
#define BIT_SET_TSF_TIMER_8197F(x, v) \
(BIT_CLEAR_TSF_TIMER_8197F(x) | BIT_TSF_TIMER_8197F(v))
/* 2 REG_FREERUN_CNT_8197F */
#define BIT_SHIFT_FREERUN_CNT_8197F 0
#define BIT_MASK_FREERUN_CNT_8197F 0xffffffffffffffffL
#define BIT_FREERUN_CNT_8197F(x) \
(((x) & BIT_MASK_FREERUN_CNT_8197F) << BIT_SHIFT_FREERUN_CNT_8197F)
#define BITS_FREERUN_CNT_8197F \
(BIT_MASK_FREERUN_CNT_8197F << BIT_SHIFT_FREERUN_CNT_8197F)
#define BIT_CLEAR_FREERUN_CNT_8197F(x) ((x) & (~BITS_FREERUN_CNT_8197F))
#define BIT_GET_FREERUN_CNT_8197F(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_8197F) & BIT_MASK_FREERUN_CNT_8197F)
#define BIT_SET_FREERUN_CNT_8197F(x, v) \
(BIT_CLEAR_FREERUN_CNT_8197F(x) | BIT_FREERUN_CNT_8197F(v))
/* 2 REG_ATIMWND1_8197F */
#define BIT_SHIFT_ATIMWND1_V1_8197F 0
#define BIT_MASK_ATIMWND1_V1_8197F 0xff
#define BIT_ATIMWND1_V1_8197F(x) \
(((x) & BIT_MASK_ATIMWND1_V1_8197F) << BIT_SHIFT_ATIMWND1_V1_8197F)
#define BITS_ATIMWND1_V1_8197F \
(BIT_MASK_ATIMWND1_V1_8197F << BIT_SHIFT_ATIMWND1_V1_8197F)
#define BIT_CLEAR_ATIMWND1_V1_8197F(x) ((x) & (~BITS_ATIMWND1_V1_8197F))
#define BIT_GET_ATIMWND1_V1_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND1_V1_8197F) & BIT_MASK_ATIMWND1_V1_8197F)
#define BIT_SET_ATIMWND1_V1_8197F(x, v) \
(BIT_CLEAR_ATIMWND1_V1_8197F(x) | BIT_ATIMWND1_V1_8197F(v))
/* 2 REG_TBTT_PROHIBIT_INFRA_8197F */
#define BIT_SHIFT_TBTT_PROHIBIT_INFRA_8197F 0
#define BIT_MASK_TBTT_PROHIBIT_INFRA_8197F 0xff
#define BIT_TBTT_PROHIBIT_INFRA_8197F(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_INFRA_8197F) \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8197F)
#define BITS_TBTT_PROHIBIT_INFRA_8197F \
(BIT_MASK_TBTT_PROHIBIT_INFRA_8197F \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8197F)
#define BIT_CLEAR_TBTT_PROHIBIT_INFRA_8197F(x) \
((x) & (~BITS_TBTT_PROHIBIT_INFRA_8197F))
#define BIT_GET_TBTT_PROHIBIT_INFRA_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_INFRA_8197F) & \
BIT_MASK_TBTT_PROHIBIT_INFRA_8197F)
#define BIT_SET_TBTT_PROHIBIT_INFRA_8197F(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_INFRA_8197F(x) | \
BIT_TBTT_PROHIBIT_INFRA_8197F(v))
/* 2 REG_CTWND_8197F */
#define BIT_SHIFT_CTWND_8197F 0
#define BIT_MASK_CTWND_8197F 0xff
#define BIT_CTWND_8197F(x) \
(((x) & BIT_MASK_CTWND_8197F) << BIT_SHIFT_CTWND_8197F)
#define BITS_CTWND_8197F (BIT_MASK_CTWND_8197F << BIT_SHIFT_CTWND_8197F)
#define BIT_CLEAR_CTWND_8197F(x) ((x) & (~BITS_CTWND_8197F))
#define BIT_GET_CTWND_8197F(x) \
(((x) >> BIT_SHIFT_CTWND_8197F) & BIT_MASK_CTWND_8197F)
#define BIT_SET_CTWND_8197F(x, v) \
(BIT_CLEAR_CTWND_8197F(x) | BIT_CTWND_8197F(v))
/* 2 REG_BCNIVLCUNT_8197F */
#define BIT_SHIFT_BCNIVLCUNT_8197F 0
#define BIT_MASK_BCNIVLCUNT_8197F 0x7f
#define BIT_BCNIVLCUNT_8197F(x) \
(((x) & BIT_MASK_BCNIVLCUNT_8197F) << BIT_SHIFT_BCNIVLCUNT_8197F)
#define BITS_BCNIVLCUNT_8197F \
(BIT_MASK_BCNIVLCUNT_8197F << BIT_SHIFT_BCNIVLCUNT_8197F)
#define BIT_CLEAR_BCNIVLCUNT_8197F(x) ((x) & (~BITS_BCNIVLCUNT_8197F))
#define BIT_GET_BCNIVLCUNT_8197F(x) \
(((x) >> BIT_SHIFT_BCNIVLCUNT_8197F) & BIT_MASK_BCNIVLCUNT_8197F)
#define BIT_SET_BCNIVLCUNT_8197F(x, v) \
(BIT_CLEAR_BCNIVLCUNT_8197F(x) | BIT_BCNIVLCUNT_8197F(v))
/* 2 REG_BCNDROPCTRL_8197F */
#define BIT_BEACON_DROP_EN_8197F BIT(7)
#define BIT_SHIFT_BEACON_DROP_IVL_8197F 0
#define BIT_MASK_BEACON_DROP_IVL_8197F 0x7f
#define BIT_BEACON_DROP_IVL_8197F(x) \
(((x) & BIT_MASK_BEACON_DROP_IVL_8197F) \
<< BIT_SHIFT_BEACON_DROP_IVL_8197F)
#define BITS_BEACON_DROP_IVL_8197F \
(BIT_MASK_BEACON_DROP_IVL_8197F << BIT_SHIFT_BEACON_DROP_IVL_8197F)
#define BIT_CLEAR_BEACON_DROP_IVL_8197F(x) ((x) & (~BITS_BEACON_DROP_IVL_8197F))
#define BIT_GET_BEACON_DROP_IVL_8197F(x) \
(((x) >> BIT_SHIFT_BEACON_DROP_IVL_8197F) & \
BIT_MASK_BEACON_DROP_IVL_8197F)
#define BIT_SET_BEACON_DROP_IVL_8197F(x, v) \
(BIT_CLEAR_BEACON_DROP_IVL_8197F(x) | BIT_BEACON_DROP_IVL_8197F(v))
/* 2 REG_HGQ_TIMEOUT_PERIOD_8197F */
#define BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8197F 0
#define BIT_MASK_HGQ_TIMEOUT_PERIOD_8197F 0xff
#define BIT_HGQ_TIMEOUT_PERIOD_8197F(x) \
(((x) & BIT_MASK_HGQ_TIMEOUT_PERIOD_8197F) \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8197F)
#define BITS_HGQ_TIMEOUT_PERIOD_8197F \
(BIT_MASK_HGQ_TIMEOUT_PERIOD_8197F \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8197F)
#define BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8197F(x) \
((x) & (~BITS_HGQ_TIMEOUT_PERIOD_8197F))
#define BIT_GET_HGQ_TIMEOUT_PERIOD_8197F(x) \
(((x) >> BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8197F) & \
BIT_MASK_HGQ_TIMEOUT_PERIOD_8197F)
#define BIT_SET_HGQ_TIMEOUT_PERIOD_8197F(x, v) \
(BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8197F(x) | \
BIT_HGQ_TIMEOUT_PERIOD_8197F(v))
/* 2 REG_TXCMD_TIMEOUT_PERIOD_8197F */
#define BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8197F 0
#define BIT_MASK_TXCMD_TIMEOUT_PERIOD_8197F 0xff
#define BIT_TXCMD_TIMEOUT_PERIOD_8197F(x) \
(((x) & BIT_MASK_TXCMD_TIMEOUT_PERIOD_8197F) \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8197F)
#define BITS_TXCMD_TIMEOUT_PERIOD_8197F \
(BIT_MASK_TXCMD_TIMEOUT_PERIOD_8197F \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8197F)
#define BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8197F(x) \
((x) & (~BITS_TXCMD_TIMEOUT_PERIOD_8197F))
#define BIT_GET_TXCMD_TIMEOUT_PERIOD_8197F(x) \
(((x) >> BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8197F) & \
BIT_MASK_TXCMD_TIMEOUT_PERIOD_8197F)
#define BIT_SET_TXCMD_TIMEOUT_PERIOD_8197F(x, v) \
(BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8197F(x) | \
BIT_TXCMD_TIMEOUT_PERIOD_8197F(v))
/* 2 REG_MISC_CTRL_8197F */
#define BIT_DIS_MARK_TSF_US_8197F BIT(7)
#define BIT_EN_TSFAUTO_SYNC_8197F BIT(6)
#define BIT_DIS_TRX_CAL_BCN_8197F BIT(5)
#define BIT_DIS_TX_CAL_TBTT_8197F BIT(4)
#define BIT_EN_FREECNT_8197F BIT(3)
#define BIT_BCN_AGGRESSION_8197F BIT(2)
#define BIT_SHIFT_DIS_SECONDARY_CCA_8197F 0
#define BIT_MASK_DIS_SECONDARY_CCA_8197F 0x3
#define BIT_DIS_SECONDARY_CCA_8197F(x) \
(((x) & BIT_MASK_DIS_SECONDARY_CCA_8197F) \
<< BIT_SHIFT_DIS_SECONDARY_CCA_8197F)
#define BITS_DIS_SECONDARY_CCA_8197F \
(BIT_MASK_DIS_SECONDARY_CCA_8197F << BIT_SHIFT_DIS_SECONDARY_CCA_8197F)
#define BIT_CLEAR_DIS_SECONDARY_CCA_8197F(x) \
((x) & (~BITS_DIS_SECONDARY_CCA_8197F))
#define BIT_GET_DIS_SECONDARY_CCA_8197F(x) \
(((x) >> BIT_SHIFT_DIS_SECONDARY_CCA_8197F) & \
BIT_MASK_DIS_SECONDARY_CCA_8197F)
#define BIT_SET_DIS_SECONDARY_CCA_8197F(x, v) \
(BIT_CLEAR_DIS_SECONDARY_CCA_8197F(x) | BIT_DIS_SECONDARY_CCA_8197F(v))
/* 2 REG_BCN_CTRL_CLINT1_8197F */
#define BIT_CLI1_DIS_RX_BSSID_FIT_8197F BIT(6)
#define BIT_CLI1_DIS_TSF_UDT_8197F BIT(4)
#define BIT_CLI1_EN_BCN_FUNCTION_8197F BIT(3)
#define BIT_CLI1_EN_RXBCN_RPT_8197F BIT(2)
#define BIT_CLI1_ENP2P_CTWINDOW_8197F BIT(1)
#define BIT_CLI1_ENP2P_BCNQ_AREA_8197F BIT(0)
/* 2 REG_BCN_CTRL_CLINT2_8197F */
#define BIT_CLI2_DIS_RX_BSSID_FIT_8197F BIT(6)
#define BIT_CLI2_DIS_TSF_UDT_8197F BIT(4)
#define BIT_CLI2_EN_BCN_FUNCTION_8197F BIT(3)
#define BIT_CLI2_EN_RXBCN_RPT_8197F BIT(2)
#define BIT_CLI2_ENP2P_CTWINDOW_8197F BIT(1)
#define BIT_CLI2_ENP2P_BCNQ_AREA_8197F BIT(0)
/* 2 REG_BCN_CTRL_CLINT3_8197F */
#define BIT_CLI3_DIS_RX_BSSID_FIT_8197F BIT(6)
#define BIT_CLI3_DIS_TSF_UDT_8197F BIT(4)
#define BIT_CLI3_EN_BCN_FUNCTION_8197F BIT(3)
#define BIT_CLI3_EN_RXBCN_RPT_8197F BIT(2)
#define BIT_CLI3_ENP2P_CTWINDOW_8197F BIT(1)
#define BIT_CLI3_ENP2P_BCNQ_AREA_8197F BIT(0)
/* 2 REG_EXTEND_CTRL_8197F */
#define BIT_EN_TSFBIT32_RST_P2P2_8197F BIT(5)
#define BIT_EN_TSFBIT32_RST_P2P1_8197F BIT(4)
#define BIT_SHIFT_PORT_SEL_8197F 0
#define BIT_MASK_PORT_SEL_8197F 0x7
#define BIT_PORT_SEL_8197F(x) \
(((x) & BIT_MASK_PORT_SEL_8197F) << BIT_SHIFT_PORT_SEL_8197F)
#define BITS_PORT_SEL_8197F \
(BIT_MASK_PORT_SEL_8197F << BIT_SHIFT_PORT_SEL_8197F)
#define BIT_CLEAR_PORT_SEL_8197F(x) ((x) & (~BITS_PORT_SEL_8197F))
#define BIT_GET_PORT_SEL_8197F(x) \
(((x) >> BIT_SHIFT_PORT_SEL_8197F) & BIT_MASK_PORT_SEL_8197F)
#define BIT_SET_PORT_SEL_8197F(x, v) \
(BIT_CLEAR_PORT_SEL_8197F(x) | BIT_PORT_SEL_8197F(v))
/* 2 REG_P2PPS1_SPEC_STATE_8197F */
#define BIT_P2P1_SPEC_POWER_STATE_8197F BIT(7)
#define BIT_P2P1_SPEC_CTWINDOW_ON_8197F BIT(6)
#define BIT_P2P1_SPEC_BCN_AREA_ON_8197F BIT(5)
#define BIT_P2P1_SPEC_CTWIN_EARLY_DISTX_8197F BIT(4)
#define BIT_P2P1_SPEC_NOA1_OFF_PERIOD_8197F BIT(3)
#define BIT_P2P1_SPEC_FORCE_DOZE1_8197F BIT(2)
#define BIT_P2P1_SPEC_NOA0_OFF_PERIOD_8197F BIT(1)
#define BIT_P2P1_SPEC_FORCE_DOZE0_8197F BIT(0)
/* 2 REG_P2PPS1_STATE_8197F */
#define BIT_P2P1_POWER_STATE_8197F BIT(7)
#define BIT_P2P1_CTWINDOW_ON_8197F BIT(6)
#define BIT_P2P1_BEACON_AREA_ON_8197F BIT(5)
#define BIT_P2P1_CTWIN_EARLY_DISTX_8197F BIT(4)
#define BIT_P2P1_NOA1_OFF_PERIOD_8197F BIT(3)
#define BIT_P2P1_FORCE_DOZE1_8197F BIT(2)
#define BIT_P2P1_NOA0_OFF_PERIOD_8197F BIT(1)
#define BIT_P2P1_FORCE_DOZE0_8197F BIT(0)
/* 2 REG_P2PPS2_SPEC_STATE_8197F */
#define BIT_P2P2_SPEC_POWER_STATE_8197F BIT(7)
#define BIT_P2P2_SPEC_CTWINDOW_ON_8197F BIT(6)
#define BIT_P2P2_SPEC_BCN_AREA_ON_8197F BIT(5)
#define BIT_P2P2_SPEC_CTWIN_EARLY_DISTX_8197F BIT(4)
#define BIT_P2P2_SPEC_NOA1_OFF_PERIOD_8197F BIT(3)
#define BIT_P2P2_SPEC_FORCE_DOZE1_8197F BIT(2)
#define BIT_P2P2_SPEC_NOA0_OFF_PERIOD_8197F BIT(1)
#define BIT_P2P2_SPEC_FORCE_DOZE0_8197F BIT(0)
/* 2 REG_P2PPS2_STATE_8197F */
#define BIT_P2P2_POWER_STATE_8197F BIT(7)
#define BIT_P2P2_CTWINDOW_ON_8197F BIT(6)
#define BIT_P2P2_BEACON_AREA_ON_8197F BIT(5)
#define BIT_P2P2_CTWIN_EARLY_DISTX_8197F BIT(4)
#define BIT_P2P2_NOA1_OFF_PERIOD_8197F BIT(3)
#define BIT_P2P2_FORCE_DOZE1_8197F BIT(2)
#define BIT_P2P2_NOA0_OFF_PERIOD_8197F BIT(1)
#define BIT_P2P2_FORCE_DOZE0_8197F BIT(0)
/* 2 REG_PS_TIMER0_8197F */
#define BIT_SHIFT_PSTIMER0_INT_8197F 5
#define BIT_MASK_PSTIMER0_INT_8197F 0x7ffffff
#define BIT_PSTIMER0_INT_8197F(x) \
(((x) & BIT_MASK_PSTIMER0_INT_8197F) << BIT_SHIFT_PSTIMER0_INT_8197F)
#define BITS_PSTIMER0_INT_8197F \
(BIT_MASK_PSTIMER0_INT_8197F << BIT_SHIFT_PSTIMER0_INT_8197F)
#define BIT_CLEAR_PSTIMER0_INT_8197F(x) ((x) & (~BITS_PSTIMER0_INT_8197F))
#define BIT_GET_PSTIMER0_INT_8197F(x) \
(((x) >> BIT_SHIFT_PSTIMER0_INT_8197F) & BIT_MASK_PSTIMER0_INT_8197F)
#define BIT_SET_PSTIMER0_INT_8197F(x, v) \
(BIT_CLEAR_PSTIMER0_INT_8197F(x) | BIT_PSTIMER0_INT_8197F(v))
/* 2 REG_PS_TIMER1_8197F */
#define BIT_SHIFT_PSTIMER1_INT_8197F 5
#define BIT_MASK_PSTIMER1_INT_8197F 0x7ffffff
#define BIT_PSTIMER1_INT_8197F(x) \
(((x) & BIT_MASK_PSTIMER1_INT_8197F) << BIT_SHIFT_PSTIMER1_INT_8197F)
#define BITS_PSTIMER1_INT_8197F \
(BIT_MASK_PSTIMER1_INT_8197F << BIT_SHIFT_PSTIMER1_INT_8197F)
#define BIT_CLEAR_PSTIMER1_INT_8197F(x) ((x) & (~BITS_PSTIMER1_INT_8197F))
#define BIT_GET_PSTIMER1_INT_8197F(x) \
(((x) >> BIT_SHIFT_PSTIMER1_INT_8197F) & BIT_MASK_PSTIMER1_INT_8197F)
#define BIT_SET_PSTIMER1_INT_8197F(x, v) \
(BIT_CLEAR_PSTIMER1_INT_8197F(x) | BIT_PSTIMER1_INT_8197F(v))
/* 2 REG_PS_TIMER2_8197F */
#define BIT_SHIFT_PSTIMER2_INT_8197F 5
#define BIT_MASK_PSTIMER2_INT_8197F 0x7ffffff
#define BIT_PSTIMER2_INT_8197F(x) \
(((x) & BIT_MASK_PSTIMER2_INT_8197F) << BIT_SHIFT_PSTIMER2_INT_8197F)
#define BITS_PSTIMER2_INT_8197F \
(BIT_MASK_PSTIMER2_INT_8197F << BIT_SHIFT_PSTIMER2_INT_8197F)
#define BIT_CLEAR_PSTIMER2_INT_8197F(x) ((x) & (~BITS_PSTIMER2_INT_8197F))
#define BIT_GET_PSTIMER2_INT_8197F(x) \
(((x) >> BIT_SHIFT_PSTIMER2_INT_8197F) & BIT_MASK_PSTIMER2_INT_8197F)
#define BIT_SET_PSTIMER2_INT_8197F(x, v) \
(BIT_CLEAR_PSTIMER2_INT_8197F(x) | BIT_PSTIMER2_INT_8197F(v))
/* 2 REG_TBTT_CTN_AREA_8197F */
#define BIT_SHIFT_TBTT_CTN_AREA_8197F 0
#define BIT_MASK_TBTT_CTN_AREA_8197F 0xff
#define BIT_TBTT_CTN_AREA_8197F(x) \
(((x) & BIT_MASK_TBTT_CTN_AREA_8197F) << BIT_SHIFT_TBTT_CTN_AREA_8197F)
#define BITS_TBTT_CTN_AREA_8197F \
(BIT_MASK_TBTT_CTN_AREA_8197F << BIT_SHIFT_TBTT_CTN_AREA_8197F)
#define BIT_CLEAR_TBTT_CTN_AREA_8197F(x) ((x) & (~BITS_TBTT_CTN_AREA_8197F))
#define BIT_GET_TBTT_CTN_AREA_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_CTN_AREA_8197F) & BIT_MASK_TBTT_CTN_AREA_8197F)
#define BIT_SET_TBTT_CTN_AREA_8197F(x, v) \
(BIT_CLEAR_TBTT_CTN_AREA_8197F(x) | BIT_TBTT_CTN_AREA_8197F(v))
/* 2 REG_FORCE_BCN_IFS_8197F */
#define BIT_SHIFT_FORCE_BCN_IFS_8197F 0
#define BIT_MASK_FORCE_BCN_IFS_8197F 0xff
#define BIT_FORCE_BCN_IFS_8197F(x) \
(((x) & BIT_MASK_FORCE_BCN_IFS_8197F) << BIT_SHIFT_FORCE_BCN_IFS_8197F)
#define BITS_FORCE_BCN_IFS_8197F \
(BIT_MASK_FORCE_BCN_IFS_8197F << BIT_SHIFT_FORCE_BCN_IFS_8197F)
#define BIT_CLEAR_FORCE_BCN_IFS_8197F(x) ((x) & (~BITS_FORCE_BCN_IFS_8197F))
#define BIT_GET_FORCE_BCN_IFS_8197F(x) \
(((x) >> BIT_SHIFT_FORCE_BCN_IFS_8197F) & BIT_MASK_FORCE_BCN_IFS_8197F)
#define BIT_SET_FORCE_BCN_IFS_8197F(x, v) \
(BIT_CLEAR_FORCE_BCN_IFS_8197F(x) | BIT_FORCE_BCN_IFS_8197F(v))
/* 2 REG_TXOP_MIN_8197F */
#define BIT_NAV_BLK_HGQ_8197F BIT(15)
#define BIT_NAV_BLK_MGQ_8197F BIT(14)
#define BIT_SHIFT_TXOP_MIN_8197F 0
#define BIT_MASK_TXOP_MIN_8197F 0x3fff
#define BIT_TXOP_MIN_8197F(x) \
(((x) & BIT_MASK_TXOP_MIN_8197F) << BIT_SHIFT_TXOP_MIN_8197F)
#define BITS_TXOP_MIN_8197F \
(BIT_MASK_TXOP_MIN_8197F << BIT_SHIFT_TXOP_MIN_8197F)
#define BIT_CLEAR_TXOP_MIN_8197F(x) ((x) & (~BITS_TXOP_MIN_8197F))
#define BIT_GET_TXOP_MIN_8197F(x) \
(((x) >> BIT_SHIFT_TXOP_MIN_8197F) & BIT_MASK_TXOP_MIN_8197F)
#define BIT_SET_TXOP_MIN_8197F(x, v) \
(BIT_CLEAR_TXOP_MIN_8197F(x) | BIT_TXOP_MIN_8197F(v))
/* 2 REG_PRE_BKF_TIME_8197F */
#define BIT_SHIFT_PRE_BKF_TIME_8197F 0
#define BIT_MASK_PRE_BKF_TIME_8197F 0xff
#define BIT_PRE_BKF_TIME_8197F(x) \
(((x) & BIT_MASK_PRE_BKF_TIME_8197F) << BIT_SHIFT_PRE_BKF_TIME_8197F)
#define BITS_PRE_BKF_TIME_8197F \
(BIT_MASK_PRE_BKF_TIME_8197F << BIT_SHIFT_PRE_BKF_TIME_8197F)
#define BIT_CLEAR_PRE_BKF_TIME_8197F(x) ((x) & (~BITS_PRE_BKF_TIME_8197F))
#define BIT_GET_PRE_BKF_TIME_8197F(x) \
(((x) >> BIT_SHIFT_PRE_BKF_TIME_8197F) & BIT_MASK_PRE_BKF_TIME_8197F)
#define BIT_SET_PRE_BKF_TIME_8197F(x, v) \
(BIT_CLEAR_PRE_BKF_TIME_8197F(x) | BIT_PRE_BKF_TIME_8197F(v))
/* 2 REG_CROSS_TXOP_CTRL_8197F */
#define BIT_DTIM_BYPASS_8197F BIT(2)
#define BIT_RTS_NAV_TXOP_8197F BIT(1)
#define BIT_NOT_CROSS_TXOP_8197F BIT(0)
/* 2 REG_TBTT_INT_SHIFT_CLI0_8197F */
#define BIT_TBTT_INT_SHIFT_DIR_CLI0_8197F BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI0_8197F 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI0_8197F 0x7f
#define BIT_TBTT_INT_SHIFT_CLI0_8197F(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI0_8197F) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI0_8197F)
#define BITS_TBTT_INT_SHIFT_CLI0_8197F \
(BIT_MASK_TBTT_INT_SHIFT_CLI0_8197F \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI0_8197F)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI0_8197F(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI0_8197F))
#define BIT_GET_TBTT_INT_SHIFT_CLI0_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI0_8197F) & \
BIT_MASK_TBTT_INT_SHIFT_CLI0_8197F)
#define BIT_SET_TBTT_INT_SHIFT_CLI0_8197F(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI0_8197F(x) | \
BIT_TBTT_INT_SHIFT_CLI0_8197F(v))
/* 2 REG_TBTT_INT_SHIFT_CLI1_8197F */
#define BIT_TBTT_INT_SHIFT_DIR_CLI1_8197F BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI1_8197F 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI1_8197F 0x7f
#define BIT_TBTT_INT_SHIFT_CLI1_8197F(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI1_8197F) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI1_8197F)
#define BITS_TBTT_INT_SHIFT_CLI1_8197F \
(BIT_MASK_TBTT_INT_SHIFT_CLI1_8197F \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI1_8197F)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI1_8197F(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI1_8197F))
#define BIT_GET_TBTT_INT_SHIFT_CLI1_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI1_8197F) & \
BIT_MASK_TBTT_INT_SHIFT_CLI1_8197F)
#define BIT_SET_TBTT_INT_SHIFT_CLI1_8197F(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI1_8197F(x) | \
BIT_TBTT_INT_SHIFT_CLI1_8197F(v))
/* 2 REG_TBTT_INT_SHIFT_CLI2_8197F */
#define BIT_TBTT_INT_SHIFT_DIR_CLI2_8197F BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI2_8197F 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI2_8197F 0x7f
#define BIT_TBTT_INT_SHIFT_CLI2_8197F(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI2_8197F) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI2_8197F)
#define BITS_TBTT_INT_SHIFT_CLI2_8197F \
(BIT_MASK_TBTT_INT_SHIFT_CLI2_8197F \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI2_8197F)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI2_8197F(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI2_8197F))
#define BIT_GET_TBTT_INT_SHIFT_CLI2_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI2_8197F) & \
BIT_MASK_TBTT_INT_SHIFT_CLI2_8197F)
#define BIT_SET_TBTT_INT_SHIFT_CLI2_8197F(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI2_8197F(x) | \
BIT_TBTT_INT_SHIFT_CLI2_8197F(v))
/* 2 REG_TBTT_INT_SHIFT_CLI3_8197F */
#define BIT_TBTT_INT_SHIFT_DIR_CLI3_8197F BIT(7)
#define BIT_SHIFT_TBTT_INT_SHIFT_CLI3_8197F 0
#define BIT_MASK_TBTT_INT_SHIFT_CLI3_8197F 0x7f
#define BIT_TBTT_INT_SHIFT_CLI3_8197F(x) \
(((x) & BIT_MASK_TBTT_INT_SHIFT_CLI3_8197F) \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI3_8197F)
#define BITS_TBTT_INT_SHIFT_CLI3_8197F \
(BIT_MASK_TBTT_INT_SHIFT_CLI3_8197F \
<< BIT_SHIFT_TBTT_INT_SHIFT_CLI3_8197F)
#define BIT_CLEAR_TBTT_INT_SHIFT_CLI3_8197F(x) \
((x) & (~BITS_TBTT_INT_SHIFT_CLI3_8197F))
#define BIT_GET_TBTT_INT_SHIFT_CLI3_8197F(x) \
(((x) >> BIT_SHIFT_TBTT_INT_SHIFT_CLI3_8197F) & \
BIT_MASK_TBTT_INT_SHIFT_CLI3_8197F)
#define BIT_SET_TBTT_INT_SHIFT_CLI3_8197F(x, v) \
(BIT_CLEAR_TBTT_INT_SHIFT_CLI3_8197F(x) | \
BIT_TBTT_INT_SHIFT_CLI3_8197F(v))
/* 2 REG_TBTT_INT_SHIFT_ENABLE_8197F */
#define BIT_EN_TBTT_RTY_8197F BIT(1)
#define BIT_TBTT_INT_SHIFT_ENABLE_8197F BIT(0)
/* 2 REG_ATIMWND2_8197F */
#define BIT_SHIFT_ATIMWND2_8197F 0
#define BIT_MASK_ATIMWND2_8197F 0xff
#define BIT_ATIMWND2_8197F(x) \
(((x) & BIT_MASK_ATIMWND2_8197F) << BIT_SHIFT_ATIMWND2_8197F)
#define BITS_ATIMWND2_8197F \
(BIT_MASK_ATIMWND2_8197F << BIT_SHIFT_ATIMWND2_8197F)
#define BIT_CLEAR_ATIMWND2_8197F(x) ((x) & (~BITS_ATIMWND2_8197F))
#define BIT_GET_ATIMWND2_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND2_8197F) & BIT_MASK_ATIMWND2_8197F)
#define BIT_SET_ATIMWND2_8197F(x, v) \
(BIT_CLEAR_ATIMWND2_8197F(x) | BIT_ATIMWND2_8197F(v))
/* 2 REG_ATIMWND3_8197F */
#define BIT_SHIFT_ATIMWND3_8197F 0
#define BIT_MASK_ATIMWND3_8197F 0xff
#define BIT_ATIMWND3_8197F(x) \
(((x) & BIT_MASK_ATIMWND3_8197F) << BIT_SHIFT_ATIMWND3_8197F)
#define BITS_ATIMWND3_8197F \
(BIT_MASK_ATIMWND3_8197F << BIT_SHIFT_ATIMWND3_8197F)
#define BIT_CLEAR_ATIMWND3_8197F(x) ((x) & (~BITS_ATIMWND3_8197F))
#define BIT_GET_ATIMWND3_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND3_8197F) & BIT_MASK_ATIMWND3_8197F)
#define BIT_SET_ATIMWND3_8197F(x, v) \
(BIT_CLEAR_ATIMWND3_8197F(x) | BIT_ATIMWND3_8197F(v))
/* 2 REG_ATIMWND4_8197F */
#define BIT_SHIFT_ATIMWND4_8197F 0
#define BIT_MASK_ATIMWND4_8197F 0xff
#define BIT_ATIMWND4_8197F(x) \
(((x) & BIT_MASK_ATIMWND4_8197F) << BIT_SHIFT_ATIMWND4_8197F)
#define BITS_ATIMWND4_8197F \
(BIT_MASK_ATIMWND4_8197F << BIT_SHIFT_ATIMWND4_8197F)
#define BIT_CLEAR_ATIMWND4_8197F(x) ((x) & (~BITS_ATIMWND4_8197F))
#define BIT_GET_ATIMWND4_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND4_8197F) & BIT_MASK_ATIMWND4_8197F)
#define BIT_SET_ATIMWND4_8197F(x, v) \
(BIT_CLEAR_ATIMWND4_8197F(x) | BIT_ATIMWND4_8197F(v))
/* 2 REG_ATIMWND5_8197F */
#define BIT_SHIFT_ATIMWND5_8197F 0
#define BIT_MASK_ATIMWND5_8197F 0xff
#define BIT_ATIMWND5_8197F(x) \
(((x) & BIT_MASK_ATIMWND5_8197F) << BIT_SHIFT_ATIMWND5_8197F)
#define BITS_ATIMWND5_8197F \
(BIT_MASK_ATIMWND5_8197F << BIT_SHIFT_ATIMWND5_8197F)
#define BIT_CLEAR_ATIMWND5_8197F(x) ((x) & (~BITS_ATIMWND5_8197F))
#define BIT_GET_ATIMWND5_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND5_8197F) & BIT_MASK_ATIMWND5_8197F)
#define BIT_SET_ATIMWND5_8197F(x, v) \
(BIT_CLEAR_ATIMWND5_8197F(x) | BIT_ATIMWND5_8197F(v))
/* 2 REG_ATIMWND6_8197F */
#define BIT_SHIFT_ATIMWND6_8197F 0
#define BIT_MASK_ATIMWND6_8197F 0xff
#define BIT_ATIMWND6_8197F(x) \
(((x) & BIT_MASK_ATIMWND6_8197F) << BIT_SHIFT_ATIMWND6_8197F)
#define BITS_ATIMWND6_8197F \
(BIT_MASK_ATIMWND6_8197F << BIT_SHIFT_ATIMWND6_8197F)
#define BIT_CLEAR_ATIMWND6_8197F(x) ((x) & (~BITS_ATIMWND6_8197F))
#define BIT_GET_ATIMWND6_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND6_8197F) & BIT_MASK_ATIMWND6_8197F)
#define BIT_SET_ATIMWND6_8197F(x, v) \
(BIT_CLEAR_ATIMWND6_8197F(x) | BIT_ATIMWND6_8197F(v))
/* 2 REG_ATIMWND7_8197F */
#define BIT_SHIFT_ATIMWND7_8197F 0
#define BIT_MASK_ATIMWND7_8197F 0xff
#define BIT_ATIMWND7_8197F(x) \
(((x) & BIT_MASK_ATIMWND7_8197F) << BIT_SHIFT_ATIMWND7_8197F)
#define BITS_ATIMWND7_8197F \
(BIT_MASK_ATIMWND7_8197F << BIT_SHIFT_ATIMWND7_8197F)
#define BIT_CLEAR_ATIMWND7_8197F(x) ((x) & (~BITS_ATIMWND7_8197F))
#define BIT_GET_ATIMWND7_8197F(x) \
(((x) >> BIT_SHIFT_ATIMWND7_8197F) & BIT_MASK_ATIMWND7_8197F)
#define BIT_SET_ATIMWND7_8197F(x, v) \
(BIT_CLEAR_ATIMWND7_8197F(x) | BIT_ATIMWND7_8197F(v))
/* 2 REG_ATIMUGT_8197F */
#define BIT_SHIFT_ATIM_URGENT_8197F 0
#define BIT_MASK_ATIM_URGENT_8197F 0xff
#define BIT_ATIM_URGENT_8197F(x) \
(((x) & BIT_MASK_ATIM_URGENT_8197F) << BIT_SHIFT_ATIM_URGENT_8197F)
#define BITS_ATIM_URGENT_8197F \
(BIT_MASK_ATIM_URGENT_8197F << BIT_SHIFT_ATIM_URGENT_8197F)
#define BIT_CLEAR_ATIM_URGENT_8197F(x) ((x) & (~BITS_ATIM_URGENT_8197F))
#define BIT_GET_ATIM_URGENT_8197F(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT_8197F) & BIT_MASK_ATIM_URGENT_8197F)
#define BIT_SET_ATIM_URGENT_8197F(x, v) \
(BIT_CLEAR_ATIM_URGENT_8197F(x) | BIT_ATIM_URGENT_8197F(v))
/* 2 REG_HIQ_NO_LMT_EN_8197F */
#define BIT_HIQ_NO_LMT_EN_VAP7_8197F BIT(7)
#define BIT_HIQ_NO_LMT_EN_VAP6_8197F BIT(6)
#define BIT_HIQ_NO_LMT_EN_VAP5_8197F BIT(5)
#define BIT_HIQ_NO_LMT_EN_VAP4_8197F BIT(4)
#define BIT_HIQ_NO_LMT_EN_VAP3_8197F BIT(3)
#define BIT_HIQ_NO_LMT_EN_VAP2_8197F BIT(2)
#define BIT_HIQ_NO_LMT_EN_VAP1_8197F BIT(1)
#define BIT_HIQ_NO_LMT_EN_ROOT_8197F BIT(0)
/* 2 REG_DTIM_COUNTER_ROOT_8197F */
#define BIT_SHIFT_DTIM_COUNT_ROOT_8197F 0
#define BIT_MASK_DTIM_COUNT_ROOT_8197F 0xff
#define BIT_DTIM_COUNT_ROOT_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_ROOT_8197F) \
<< BIT_SHIFT_DTIM_COUNT_ROOT_8197F)
#define BITS_DTIM_COUNT_ROOT_8197F \
(BIT_MASK_DTIM_COUNT_ROOT_8197F << BIT_SHIFT_DTIM_COUNT_ROOT_8197F)
#define BIT_CLEAR_DTIM_COUNT_ROOT_8197F(x) ((x) & (~BITS_DTIM_COUNT_ROOT_8197F))
#define BIT_GET_DTIM_COUNT_ROOT_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_ROOT_8197F) & \
BIT_MASK_DTIM_COUNT_ROOT_8197F)
#define BIT_SET_DTIM_COUNT_ROOT_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_ROOT_8197F(x) | BIT_DTIM_COUNT_ROOT_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP1_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP1_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP1_8197F 0xff
#define BIT_DTIM_COUNT_VAP1_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP1_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP1_8197F)
#define BITS_DTIM_COUNT_VAP1_8197F \
(BIT_MASK_DTIM_COUNT_VAP1_8197F << BIT_SHIFT_DTIM_COUNT_VAP1_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP1_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP1_8197F))
#define BIT_GET_DTIM_COUNT_VAP1_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP1_8197F) & \
BIT_MASK_DTIM_COUNT_VAP1_8197F)
#define BIT_SET_DTIM_COUNT_VAP1_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP1_8197F(x) | BIT_DTIM_COUNT_VAP1_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP2_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP2_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP2_8197F 0xff
#define BIT_DTIM_COUNT_VAP2_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP2_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP2_8197F)
#define BITS_DTIM_COUNT_VAP2_8197F \
(BIT_MASK_DTIM_COUNT_VAP2_8197F << BIT_SHIFT_DTIM_COUNT_VAP2_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP2_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP2_8197F))
#define BIT_GET_DTIM_COUNT_VAP2_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP2_8197F) & \
BIT_MASK_DTIM_COUNT_VAP2_8197F)
#define BIT_SET_DTIM_COUNT_VAP2_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP2_8197F(x) | BIT_DTIM_COUNT_VAP2_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP3_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP3_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP3_8197F 0xff
#define BIT_DTIM_COUNT_VAP3_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP3_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP3_8197F)
#define BITS_DTIM_COUNT_VAP3_8197F \
(BIT_MASK_DTIM_COUNT_VAP3_8197F << BIT_SHIFT_DTIM_COUNT_VAP3_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP3_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP3_8197F))
#define BIT_GET_DTIM_COUNT_VAP3_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP3_8197F) & \
BIT_MASK_DTIM_COUNT_VAP3_8197F)
#define BIT_SET_DTIM_COUNT_VAP3_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP3_8197F(x) | BIT_DTIM_COUNT_VAP3_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP4_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP4_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP4_8197F 0xff
#define BIT_DTIM_COUNT_VAP4_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP4_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP4_8197F)
#define BITS_DTIM_COUNT_VAP4_8197F \
(BIT_MASK_DTIM_COUNT_VAP4_8197F << BIT_SHIFT_DTIM_COUNT_VAP4_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP4_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP4_8197F))
#define BIT_GET_DTIM_COUNT_VAP4_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP4_8197F) & \
BIT_MASK_DTIM_COUNT_VAP4_8197F)
#define BIT_SET_DTIM_COUNT_VAP4_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP4_8197F(x) | BIT_DTIM_COUNT_VAP4_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP5_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP5_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP5_8197F 0xff
#define BIT_DTIM_COUNT_VAP5_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP5_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP5_8197F)
#define BITS_DTIM_COUNT_VAP5_8197F \
(BIT_MASK_DTIM_COUNT_VAP5_8197F << BIT_SHIFT_DTIM_COUNT_VAP5_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP5_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP5_8197F))
#define BIT_GET_DTIM_COUNT_VAP5_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP5_8197F) & \
BIT_MASK_DTIM_COUNT_VAP5_8197F)
#define BIT_SET_DTIM_COUNT_VAP5_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP5_8197F(x) | BIT_DTIM_COUNT_VAP5_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP6_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP6_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP6_8197F 0xff
#define BIT_DTIM_COUNT_VAP6_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP6_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP6_8197F)
#define BITS_DTIM_COUNT_VAP6_8197F \
(BIT_MASK_DTIM_COUNT_VAP6_8197F << BIT_SHIFT_DTIM_COUNT_VAP6_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP6_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP6_8197F))
#define BIT_GET_DTIM_COUNT_VAP6_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP6_8197F) & \
BIT_MASK_DTIM_COUNT_VAP6_8197F)
#define BIT_SET_DTIM_COUNT_VAP6_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP6_8197F(x) | BIT_DTIM_COUNT_VAP6_8197F(v))
/* 2 REG_DTIM_COUNTER_VAP7_8197F */
#define BIT_SHIFT_DTIM_COUNT_VAP7_8197F 0
#define BIT_MASK_DTIM_COUNT_VAP7_8197F 0xff
#define BIT_DTIM_COUNT_VAP7_8197F(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP7_8197F) \
<< BIT_SHIFT_DTIM_COUNT_VAP7_8197F)
#define BITS_DTIM_COUNT_VAP7_8197F \
(BIT_MASK_DTIM_COUNT_VAP7_8197F << BIT_SHIFT_DTIM_COUNT_VAP7_8197F)
#define BIT_CLEAR_DTIM_COUNT_VAP7_8197F(x) ((x) & (~BITS_DTIM_COUNT_VAP7_8197F))
#define BIT_GET_DTIM_COUNT_VAP7_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP7_8197F) & \
BIT_MASK_DTIM_COUNT_VAP7_8197F)
#define BIT_SET_DTIM_COUNT_VAP7_8197F(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP7_8197F(x) | BIT_DTIM_COUNT_VAP7_8197F(v))
/* 2 REG_DIS_ATIM_8197F */
#define BIT_DIS_ATIM_VAP7_8197F BIT(7)
#define BIT_DIS_ATIM_VAP6_8197F BIT(6)
#define BIT_DIS_ATIM_VAP5_8197F BIT(5)
#define BIT_DIS_ATIM_VAP4_8197F BIT(4)
#define BIT_DIS_ATIM_VAP3_8197F BIT(3)
#define BIT_DIS_ATIM_VAP2_8197F BIT(2)
#define BIT_DIS_ATIM_VAP1_8197F BIT(1)
#define BIT_DIS_ATIM_ROOT_8197F BIT(0)
/* 2 REG_EARLY_128US_8197F */
#define BIT_SHIFT_TSFT_SEL_TIMER1_8197F 3
#define BIT_MASK_TSFT_SEL_TIMER1_8197F 0x7
#define BIT_TSFT_SEL_TIMER1_8197F(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER1_8197F) \
<< BIT_SHIFT_TSFT_SEL_TIMER1_8197F)
#define BITS_TSFT_SEL_TIMER1_8197F \
(BIT_MASK_TSFT_SEL_TIMER1_8197F << BIT_SHIFT_TSFT_SEL_TIMER1_8197F)
#define BIT_CLEAR_TSFT_SEL_TIMER1_8197F(x) ((x) & (~BITS_TSFT_SEL_TIMER1_8197F))
#define BIT_GET_TSFT_SEL_TIMER1_8197F(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER1_8197F) & \
BIT_MASK_TSFT_SEL_TIMER1_8197F)
#define BIT_SET_TSFT_SEL_TIMER1_8197F(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER1_8197F(x) | BIT_TSFT_SEL_TIMER1_8197F(v))
#define BIT_SHIFT_EARLY_128US_8197F 0
#define BIT_MASK_EARLY_128US_8197F 0x7
#define BIT_EARLY_128US_8197F(x) \
(((x) & BIT_MASK_EARLY_128US_8197F) << BIT_SHIFT_EARLY_128US_8197F)
#define BITS_EARLY_128US_8197F \
(BIT_MASK_EARLY_128US_8197F << BIT_SHIFT_EARLY_128US_8197F)
#define BIT_CLEAR_EARLY_128US_8197F(x) ((x) & (~BITS_EARLY_128US_8197F))
#define BIT_GET_EARLY_128US_8197F(x) \
(((x) >> BIT_SHIFT_EARLY_128US_8197F) & BIT_MASK_EARLY_128US_8197F)
#define BIT_SET_EARLY_128US_8197F(x, v) \
(BIT_CLEAR_EARLY_128US_8197F(x) | BIT_EARLY_128US_8197F(v))
/* 2 REG_P2PPS1_CTRL_8197F */
#define BIT_P2P1_CTW_ALLSTASLEEP_8197F BIT(7)
#define BIT_P2P1_OFF_DISTX_EN_8197F BIT(6)
#define BIT_P2P1_PWR_MGT_EN_8197F BIT(5)
#define BIT_P2P1_NOA1_EN_8197F BIT(2)
#define BIT_P2P1_NOA0_EN_8197F BIT(1)
/* 2 REG_P2PPS2_CTRL_8197F */
#define BIT_P2P2_CTW_ALLSTASLEEP_8197F BIT(7)
#define BIT_P2P2_OFF_DISTX_EN_8197F BIT(6)
#define BIT_P2P2_PWR_MGT_EN_8197F BIT(5)
#define BIT_P2P2_NOA1_EN_8197F BIT(2)
#define BIT_P2P2_NOA0_EN_8197F BIT(1)
/* 2 REG_TIMER0_SRC_SEL_8197F */
#define BIT_SHIFT_SYNC_CLI_SEL_8197F 4
#define BIT_MASK_SYNC_CLI_SEL_8197F 0x7
#define BIT_SYNC_CLI_SEL_8197F(x) \
(((x) & BIT_MASK_SYNC_CLI_SEL_8197F) << BIT_SHIFT_SYNC_CLI_SEL_8197F)
#define BITS_SYNC_CLI_SEL_8197F \
(BIT_MASK_SYNC_CLI_SEL_8197F << BIT_SHIFT_SYNC_CLI_SEL_8197F)
#define BIT_CLEAR_SYNC_CLI_SEL_8197F(x) ((x) & (~BITS_SYNC_CLI_SEL_8197F))
#define BIT_GET_SYNC_CLI_SEL_8197F(x) \
(((x) >> BIT_SHIFT_SYNC_CLI_SEL_8197F) & BIT_MASK_SYNC_CLI_SEL_8197F)
#define BIT_SET_SYNC_CLI_SEL_8197F(x, v) \
(BIT_CLEAR_SYNC_CLI_SEL_8197F(x) | BIT_SYNC_CLI_SEL_8197F(v))
#define BIT_SHIFT_TSFT_SEL_TIMER0_8197F 0
#define BIT_MASK_TSFT_SEL_TIMER0_8197F 0x7
#define BIT_TSFT_SEL_TIMER0_8197F(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER0_8197F) \
<< BIT_SHIFT_TSFT_SEL_TIMER0_8197F)
#define BITS_TSFT_SEL_TIMER0_8197F \
(BIT_MASK_TSFT_SEL_TIMER0_8197F << BIT_SHIFT_TSFT_SEL_TIMER0_8197F)
#define BIT_CLEAR_TSFT_SEL_TIMER0_8197F(x) ((x) & (~BITS_TSFT_SEL_TIMER0_8197F))
#define BIT_GET_TSFT_SEL_TIMER0_8197F(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER0_8197F) & \
BIT_MASK_TSFT_SEL_TIMER0_8197F)
#define BIT_SET_TSFT_SEL_TIMER0_8197F(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER0_8197F(x) | BIT_TSFT_SEL_TIMER0_8197F(v))
/* 2 REG_NOA_UNIT_SEL_8197F */
#define BIT_SHIFT_NOA_UNIT2_SEL_8197F 8
#define BIT_MASK_NOA_UNIT2_SEL_8197F 0x7
#define BIT_NOA_UNIT2_SEL_8197F(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL_8197F) << BIT_SHIFT_NOA_UNIT2_SEL_8197F)
#define BITS_NOA_UNIT2_SEL_8197F \
(BIT_MASK_NOA_UNIT2_SEL_8197F << BIT_SHIFT_NOA_UNIT2_SEL_8197F)
#define BIT_CLEAR_NOA_UNIT2_SEL_8197F(x) ((x) & (~BITS_NOA_UNIT2_SEL_8197F))
#define BIT_GET_NOA_UNIT2_SEL_8197F(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL_8197F) & BIT_MASK_NOA_UNIT2_SEL_8197F)
#define BIT_SET_NOA_UNIT2_SEL_8197F(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL_8197F(x) | BIT_NOA_UNIT2_SEL_8197F(v))
#define BIT_SHIFT_NOA_UNIT1_SEL_8197F 4
#define BIT_MASK_NOA_UNIT1_SEL_8197F 0x7
#define BIT_NOA_UNIT1_SEL_8197F(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL_8197F) << BIT_SHIFT_NOA_UNIT1_SEL_8197F)
#define BITS_NOA_UNIT1_SEL_8197F \
(BIT_MASK_NOA_UNIT1_SEL_8197F << BIT_SHIFT_NOA_UNIT1_SEL_8197F)
#define BIT_CLEAR_NOA_UNIT1_SEL_8197F(x) ((x) & (~BITS_NOA_UNIT1_SEL_8197F))
#define BIT_GET_NOA_UNIT1_SEL_8197F(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL_8197F) & BIT_MASK_NOA_UNIT1_SEL_8197F)
#define BIT_SET_NOA_UNIT1_SEL_8197F(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL_8197F(x) | BIT_NOA_UNIT1_SEL_8197F(v))
#define BIT_SHIFT_NOA_UNIT0_SEL_8197F 0
#define BIT_MASK_NOA_UNIT0_SEL_8197F 0x7
#define BIT_NOA_UNIT0_SEL_8197F(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL_8197F) << BIT_SHIFT_NOA_UNIT0_SEL_8197F)
#define BITS_NOA_UNIT0_SEL_8197F \
(BIT_MASK_NOA_UNIT0_SEL_8197F << BIT_SHIFT_NOA_UNIT0_SEL_8197F)
#define BIT_CLEAR_NOA_UNIT0_SEL_8197F(x) ((x) & (~BITS_NOA_UNIT0_SEL_8197F))
#define BIT_GET_NOA_UNIT0_SEL_8197F(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL_8197F) & BIT_MASK_NOA_UNIT0_SEL_8197F)
#define BIT_SET_NOA_UNIT0_SEL_8197F(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL_8197F(x) | BIT_NOA_UNIT0_SEL_8197F(v))
/* 2 REG_P2POFF_DIS_TXTIME_8197F */
#define BIT_SHIFT_P2POFF_DIS_TXTIME_8197F 0
#define BIT_MASK_P2POFF_DIS_TXTIME_8197F 0xff
#define BIT_P2POFF_DIS_TXTIME_8197F(x) \
(((x) & BIT_MASK_P2POFF_DIS_TXTIME_8197F) \
<< BIT_SHIFT_P2POFF_DIS_TXTIME_8197F)
#define BITS_P2POFF_DIS_TXTIME_8197F \
(BIT_MASK_P2POFF_DIS_TXTIME_8197F << BIT_SHIFT_P2POFF_DIS_TXTIME_8197F)
#define BIT_CLEAR_P2POFF_DIS_TXTIME_8197F(x) \
((x) & (~BITS_P2POFF_DIS_TXTIME_8197F))
#define BIT_GET_P2POFF_DIS_TXTIME_8197F(x) \
(((x) >> BIT_SHIFT_P2POFF_DIS_TXTIME_8197F) & \
BIT_MASK_P2POFF_DIS_TXTIME_8197F)
#define BIT_SET_P2POFF_DIS_TXTIME_8197F(x, v) \
(BIT_CLEAR_P2POFF_DIS_TXTIME_8197F(x) | BIT_P2POFF_DIS_TXTIME_8197F(v))
/* 2 REG_MBSSID_BCN_SPACE2_8197F */
#define BIT_SHIFT_BCN_SPACE_CLINT2_8197F 16
#define BIT_MASK_BCN_SPACE_CLINT2_8197F 0xfff
#define BIT_BCN_SPACE_CLINT2_8197F(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT2_8197F) \
<< BIT_SHIFT_BCN_SPACE_CLINT2_8197F)
#define BITS_BCN_SPACE_CLINT2_8197F \
(BIT_MASK_BCN_SPACE_CLINT2_8197F << BIT_SHIFT_BCN_SPACE_CLINT2_8197F)
#define BIT_CLEAR_BCN_SPACE_CLINT2_8197F(x) \
((x) & (~BITS_BCN_SPACE_CLINT2_8197F))
#define BIT_GET_BCN_SPACE_CLINT2_8197F(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT2_8197F) & \
BIT_MASK_BCN_SPACE_CLINT2_8197F)
#define BIT_SET_BCN_SPACE_CLINT2_8197F(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT2_8197F(x) | BIT_BCN_SPACE_CLINT2_8197F(v))
#define BIT_SHIFT_BCN_SPACE_CLINT1_8197F 0
#define BIT_MASK_BCN_SPACE_CLINT1_8197F 0xfff
#define BIT_BCN_SPACE_CLINT1_8197F(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT1_8197F) \
<< BIT_SHIFT_BCN_SPACE_CLINT1_8197F)
#define BITS_BCN_SPACE_CLINT1_8197F \
(BIT_MASK_BCN_SPACE_CLINT1_8197F << BIT_SHIFT_BCN_SPACE_CLINT1_8197F)
#define BIT_CLEAR_BCN_SPACE_CLINT1_8197F(x) \
((x) & (~BITS_BCN_SPACE_CLINT1_8197F))
#define BIT_GET_BCN_SPACE_CLINT1_8197F(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT1_8197F) & \
BIT_MASK_BCN_SPACE_CLINT1_8197F)
#define BIT_SET_BCN_SPACE_CLINT1_8197F(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT1_8197F(x) | BIT_BCN_SPACE_CLINT1_8197F(v))
/* 2 REG_MBSSID_BCN_SPACE3_8197F */
#define BIT_SHIFT_SUB_BCN_SPACE_8197F 16
#define BIT_MASK_SUB_BCN_SPACE_8197F 0xff
#define BIT_SUB_BCN_SPACE_8197F(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE_8197F) << BIT_SHIFT_SUB_BCN_SPACE_8197F)
#define BITS_SUB_BCN_SPACE_8197F \
(BIT_MASK_SUB_BCN_SPACE_8197F << BIT_SHIFT_SUB_BCN_SPACE_8197F)
#define BIT_CLEAR_SUB_BCN_SPACE_8197F(x) ((x) & (~BITS_SUB_BCN_SPACE_8197F))
#define BIT_GET_SUB_BCN_SPACE_8197F(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE_8197F) & BIT_MASK_SUB_BCN_SPACE_8197F)
#define BIT_SET_SUB_BCN_SPACE_8197F(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE_8197F(x) | BIT_SUB_BCN_SPACE_8197F(v))
#define BIT_SHIFT_BCN_SPACE_CLINT3_8197F 0
#define BIT_MASK_BCN_SPACE_CLINT3_8197F 0xfff
#define BIT_BCN_SPACE_CLINT3_8197F(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT3_8197F) \
<< BIT_SHIFT_BCN_SPACE_CLINT3_8197F)
#define BITS_BCN_SPACE_CLINT3_8197F \
(BIT_MASK_BCN_SPACE_CLINT3_8197F << BIT_SHIFT_BCN_SPACE_CLINT3_8197F)
#define BIT_CLEAR_BCN_SPACE_CLINT3_8197F(x) \
((x) & (~BITS_BCN_SPACE_CLINT3_8197F))
#define BIT_GET_BCN_SPACE_CLINT3_8197F(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT3_8197F) & \
BIT_MASK_BCN_SPACE_CLINT3_8197F)
#define BIT_SET_BCN_SPACE_CLINT3_8197F(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT3_8197F(x) | BIT_BCN_SPACE_CLINT3_8197F(v))
/* 2 REG_ACMHWCTRL_8197F */
#define BIT_BEQ_ACM_STATUS_8197F BIT(7)
#define BIT_VIQ_ACM_STATUS_8197F BIT(6)
#define BIT_VOQ_ACM_STATUS_8197F BIT(5)
#define BIT_BEQ_ACM_EN_8197F BIT(3)
#define BIT_VIQ_ACM_EN_8197F BIT(2)
#define BIT_VOQ_ACM_EN_8197F BIT(1)
#define BIT_ACMHWEN_8197F BIT(0)
/* 2 REG_ACMRSTCTRL_8197F */
#define BIT_BE_ACM_RESET_USED_TIME_8197F BIT(2)
#define BIT_VI_ACM_RESET_USED_TIME_8197F BIT(1)
#define BIT_VO_ACM_RESET_USED_TIME_8197F BIT(0)
/* 2 REG_ACMAVG_8197F */
#define BIT_SHIFT_AVGPERIOD_8197F 0
#define BIT_MASK_AVGPERIOD_8197F 0xffff
#define BIT_AVGPERIOD_8197F(x) \
(((x) & BIT_MASK_AVGPERIOD_8197F) << BIT_SHIFT_AVGPERIOD_8197F)
#define BITS_AVGPERIOD_8197F \
(BIT_MASK_AVGPERIOD_8197F << BIT_SHIFT_AVGPERIOD_8197F)
#define BIT_CLEAR_AVGPERIOD_8197F(x) ((x) & (~BITS_AVGPERIOD_8197F))
#define BIT_GET_AVGPERIOD_8197F(x) \
(((x) >> BIT_SHIFT_AVGPERIOD_8197F) & BIT_MASK_AVGPERIOD_8197F)
#define BIT_SET_AVGPERIOD_8197F(x, v) \
(BIT_CLEAR_AVGPERIOD_8197F(x) | BIT_AVGPERIOD_8197F(v))
/* 2 REG_VO_ADMTIME_8197F */
#define BIT_SHIFT_VO_ADMITTED_TIME_8197F 0
#define BIT_MASK_VO_ADMITTED_TIME_8197F 0xffff
#define BIT_VO_ADMITTED_TIME_8197F(x) \
(((x) & BIT_MASK_VO_ADMITTED_TIME_8197F) \
<< BIT_SHIFT_VO_ADMITTED_TIME_8197F)
#define BITS_VO_ADMITTED_TIME_8197F \
(BIT_MASK_VO_ADMITTED_TIME_8197F << BIT_SHIFT_VO_ADMITTED_TIME_8197F)
#define BIT_CLEAR_VO_ADMITTED_TIME_8197F(x) \
((x) & (~BITS_VO_ADMITTED_TIME_8197F))
#define BIT_GET_VO_ADMITTED_TIME_8197F(x) \
(((x) >> BIT_SHIFT_VO_ADMITTED_TIME_8197F) & \
BIT_MASK_VO_ADMITTED_TIME_8197F)
#define BIT_SET_VO_ADMITTED_TIME_8197F(x, v) \
(BIT_CLEAR_VO_ADMITTED_TIME_8197F(x) | BIT_VO_ADMITTED_TIME_8197F(v))
/* 2 REG_VI_ADMTIME_8197F */
#define BIT_SHIFT_VI_ADMITTED_TIME_8197F 0
#define BIT_MASK_VI_ADMITTED_TIME_8197F 0xffff
#define BIT_VI_ADMITTED_TIME_8197F(x) \
(((x) & BIT_MASK_VI_ADMITTED_TIME_8197F) \
<< BIT_SHIFT_VI_ADMITTED_TIME_8197F)
#define BITS_VI_ADMITTED_TIME_8197F \
(BIT_MASK_VI_ADMITTED_TIME_8197F << BIT_SHIFT_VI_ADMITTED_TIME_8197F)
#define BIT_CLEAR_VI_ADMITTED_TIME_8197F(x) \
((x) & (~BITS_VI_ADMITTED_TIME_8197F))
#define BIT_GET_VI_ADMITTED_TIME_8197F(x) \
(((x) >> BIT_SHIFT_VI_ADMITTED_TIME_8197F) & \
BIT_MASK_VI_ADMITTED_TIME_8197F)
#define BIT_SET_VI_ADMITTED_TIME_8197F(x, v) \
(BIT_CLEAR_VI_ADMITTED_TIME_8197F(x) | BIT_VI_ADMITTED_TIME_8197F(v))
/* 2 REG_BE_ADMTIME_8197F */
#define BIT_SHIFT_BE_ADMITTED_TIME_8197F 0
#define BIT_MASK_BE_ADMITTED_TIME_8197F 0xffff
#define BIT_BE_ADMITTED_TIME_8197F(x) \
(((x) & BIT_MASK_BE_ADMITTED_TIME_8197F) \
<< BIT_SHIFT_BE_ADMITTED_TIME_8197F)
#define BITS_BE_ADMITTED_TIME_8197F \
(BIT_MASK_BE_ADMITTED_TIME_8197F << BIT_SHIFT_BE_ADMITTED_TIME_8197F)
#define BIT_CLEAR_BE_ADMITTED_TIME_8197F(x) \
((x) & (~BITS_BE_ADMITTED_TIME_8197F))
#define BIT_GET_BE_ADMITTED_TIME_8197F(x) \
(((x) >> BIT_SHIFT_BE_ADMITTED_TIME_8197F) & \
BIT_MASK_BE_ADMITTED_TIME_8197F)
#define BIT_SET_BE_ADMITTED_TIME_8197F(x, v) \
(BIT_CLEAR_BE_ADMITTED_TIME_8197F(x) | BIT_BE_ADMITTED_TIME_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_CHANGE_POW_BCN_AREA_8197F BIT(9)
/* 2 REG_EDCA_RANDOM_GEN_8197F */
#define BIT_SHIFT_RANDOM_GEN_8197F 0
#define BIT_MASK_RANDOM_GEN_8197F 0xffffff
#define BIT_RANDOM_GEN_8197F(x) \
(((x) & BIT_MASK_RANDOM_GEN_8197F) << BIT_SHIFT_RANDOM_GEN_8197F)
#define BITS_RANDOM_GEN_8197F \
(BIT_MASK_RANDOM_GEN_8197F << BIT_SHIFT_RANDOM_GEN_8197F)
#define BIT_CLEAR_RANDOM_GEN_8197F(x) ((x) & (~BITS_RANDOM_GEN_8197F))
#define BIT_GET_RANDOM_GEN_8197F(x) \
(((x) >> BIT_SHIFT_RANDOM_GEN_8197F) & BIT_MASK_RANDOM_GEN_8197F)
#define BIT_SET_RANDOM_GEN_8197F(x, v) \
(BIT_CLEAR_RANDOM_GEN_8197F(x) | BIT_RANDOM_GEN_8197F(v))
/* 2 REG_TXCMD_NOA_SEL_8197F */
#define BIT_SHIFT_NOA_SEL_V2_8197F 4
#define BIT_MASK_NOA_SEL_V2_8197F 0x7
#define BIT_NOA_SEL_V2_8197F(x) \
(((x) & BIT_MASK_NOA_SEL_V2_8197F) << BIT_SHIFT_NOA_SEL_V2_8197F)
#define BITS_NOA_SEL_V2_8197F \
(BIT_MASK_NOA_SEL_V2_8197F << BIT_SHIFT_NOA_SEL_V2_8197F)
#define BIT_CLEAR_NOA_SEL_V2_8197F(x) ((x) & (~BITS_NOA_SEL_V2_8197F))
#define BIT_GET_NOA_SEL_V2_8197F(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V2_8197F) & BIT_MASK_NOA_SEL_V2_8197F)
#define BIT_SET_NOA_SEL_V2_8197F(x, v) \
(BIT_CLEAR_NOA_SEL_V2_8197F(x) | BIT_NOA_SEL_V2_8197F(v))
#define BIT_SHIFT_TXCMD_SEG_SEL_8197F 0
#define BIT_MASK_TXCMD_SEG_SEL_8197F 0xf
#define BIT_TXCMD_SEG_SEL_8197F(x) \
(((x) & BIT_MASK_TXCMD_SEG_SEL_8197F) << BIT_SHIFT_TXCMD_SEG_SEL_8197F)
#define BITS_TXCMD_SEG_SEL_8197F \
(BIT_MASK_TXCMD_SEG_SEL_8197F << BIT_SHIFT_TXCMD_SEG_SEL_8197F)
#define BIT_CLEAR_TXCMD_SEG_SEL_8197F(x) ((x) & (~BITS_TXCMD_SEG_SEL_8197F))
#define BIT_GET_TXCMD_SEG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_TXCMD_SEG_SEL_8197F) & BIT_MASK_TXCMD_SEG_SEL_8197F)
#define BIT_SET_TXCMD_SEG_SEL_8197F(x, v) \
(BIT_CLEAR_TXCMD_SEG_SEL_8197F(x) | BIT_TXCMD_SEG_SEL_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_BCNERR_CNT_EN_8197F BIT(20)
#define BIT_SHIFT_BCNERR_PORT_SEL_8197F 16
#define BIT_MASK_BCNERR_PORT_SEL_8197F 0x7
#define BIT_BCNERR_PORT_SEL_8197F(x) \
(((x) & BIT_MASK_BCNERR_PORT_SEL_8197F) \
<< BIT_SHIFT_BCNERR_PORT_SEL_8197F)
#define BITS_BCNERR_PORT_SEL_8197F \
(BIT_MASK_BCNERR_PORT_SEL_8197F << BIT_SHIFT_BCNERR_PORT_SEL_8197F)
#define BIT_CLEAR_BCNERR_PORT_SEL_8197F(x) ((x) & (~BITS_BCNERR_PORT_SEL_8197F))
#define BIT_GET_BCNERR_PORT_SEL_8197F(x) \
(((x) >> BIT_SHIFT_BCNERR_PORT_SEL_8197F) & \
BIT_MASK_BCNERR_PORT_SEL_8197F)
#define BIT_SET_BCNERR_PORT_SEL_8197F(x, v) \
(BIT_CLEAR_BCNERR_PORT_SEL_8197F(x) | BIT_BCNERR_PORT_SEL_8197F(v))
#define BIT_SHIFT_TXPAUSE1_8197F 8
#define BIT_MASK_TXPAUSE1_8197F 0xff
#define BIT_TXPAUSE1_8197F(x) \
(((x) & BIT_MASK_TXPAUSE1_8197F) << BIT_SHIFT_TXPAUSE1_8197F)
#define BITS_TXPAUSE1_8197F \
(BIT_MASK_TXPAUSE1_8197F << BIT_SHIFT_TXPAUSE1_8197F)
#define BIT_CLEAR_TXPAUSE1_8197F(x) ((x) & (~BITS_TXPAUSE1_8197F))
#define BIT_GET_TXPAUSE1_8197F(x) \
(((x) >> BIT_SHIFT_TXPAUSE1_8197F) & BIT_MASK_TXPAUSE1_8197F)
#define BIT_SET_TXPAUSE1_8197F(x, v) \
(BIT_CLEAR_TXPAUSE1_8197F(x) | BIT_TXPAUSE1_8197F(v))
#define BIT_SHIFT_BW_CFG_8197F 0
#define BIT_MASK_BW_CFG_8197F 0x3
#define BIT_BW_CFG_8197F(x) \
(((x) & BIT_MASK_BW_CFG_8197F) << BIT_SHIFT_BW_CFG_8197F)
#define BITS_BW_CFG_8197F (BIT_MASK_BW_CFG_8197F << BIT_SHIFT_BW_CFG_8197F)
#define BIT_CLEAR_BW_CFG_8197F(x) ((x) & (~BITS_BW_CFG_8197F))
#define BIT_GET_BW_CFG_8197F(x) \
(((x) >> BIT_SHIFT_BW_CFG_8197F) & BIT_MASK_BW_CFG_8197F)
#define BIT_SET_BW_CFG_8197F(x, v) \
(BIT_CLEAR_BW_CFG_8197F(x) | BIT_BW_CFG_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_RXBCN_TIMER_8197F 16
#define BIT_MASK_RXBCN_TIMER_8197F 0xffff
#define BIT_RXBCN_TIMER_8197F(x) \
(((x) & BIT_MASK_RXBCN_TIMER_8197F) << BIT_SHIFT_RXBCN_TIMER_8197F)
#define BITS_RXBCN_TIMER_8197F \
(BIT_MASK_RXBCN_TIMER_8197F << BIT_SHIFT_RXBCN_TIMER_8197F)
#define BIT_CLEAR_RXBCN_TIMER_8197F(x) ((x) & (~BITS_RXBCN_TIMER_8197F))
#define BIT_GET_RXBCN_TIMER_8197F(x) \
(((x) >> BIT_SHIFT_RXBCN_TIMER_8197F) & BIT_MASK_RXBCN_TIMER_8197F)
#define BIT_SET_RXBCN_TIMER_8197F(x, v) \
(BIT_CLEAR_RXBCN_TIMER_8197F(x) | BIT_RXBCN_TIMER_8197F(v))
#define BIT_SHIFT_BCN_ELY_ADJ_8197F 0
#define BIT_MASK_BCN_ELY_ADJ_8197F 0xffff
#define BIT_BCN_ELY_ADJ_8197F(x) \
(((x) & BIT_MASK_BCN_ELY_ADJ_8197F) << BIT_SHIFT_BCN_ELY_ADJ_8197F)
#define BITS_BCN_ELY_ADJ_8197F \
(BIT_MASK_BCN_ELY_ADJ_8197F << BIT_SHIFT_BCN_ELY_ADJ_8197F)
#define BIT_CLEAR_BCN_ELY_ADJ_8197F(x) ((x) & (~BITS_BCN_ELY_ADJ_8197F))
#define BIT_GET_BCN_ELY_ADJ_8197F(x) \
(((x) >> BIT_SHIFT_BCN_ELY_ADJ_8197F) & BIT_MASK_BCN_ELY_ADJ_8197F)
#define BIT_SET_BCN_ELY_ADJ_8197F(x, v) \
(BIT_CLEAR_BCN_ELY_ADJ_8197F(x) | BIT_BCN_ELY_ADJ_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_BCNERR_CNT_OTHERS_8197F 24
#define BIT_MASK_BCNERR_CNT_OTHERS_8197F 0xff
#define BIT_BCNERR_CNT_OTHERS_8197F(x) \
(((x) & BIT_MASK_BCNERR_CNT_OTHERS_8197F) \
<< BIT_SHIFT_BCNERR_CNT_OTHERS_8197F)
#define BITS_BCNERR_CNT_OTHERS_8197F \
(BIT_MASK_BCNERR_CNT_OTHERS_8197F << BIT_SHIFT_BCNERR_CNT_OTHERS_8197F)
#define BIT_CLEAR_BCNERR_CNT_OTHERS_8197F(x) \
((x) & (~BITS_BCNERR_CNT_OTHERS_8197F))
#define BIT_GET_BCNERR_CNT_OTHERS_8197F(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_OTHERS_8197F) & \
BIT_MASK_BCNERR_CNT_OTHERS_8197F)
#define BIT_SET_BCNERR_CNT_OTHERS_8197F(x, v) \
(BIT_CLEAR_BCNERR_CNT_OTHERS_8197F(x) | BIT_BCNERR_CNT_OTHERS_8197F(v))
#define BIT_SHIFT_BCNERR_CNT_INVALID_8197F 16
#define BIT_MASK_BCNERR_CNT_INVALID_8197F 0xff
#define BIT_BCNERR_CNT_INVALID_8197F(x) \
(((x) & BIT_MASK_BCNERR_CNT_INVALID_8197F) \
<< BIT_SHIFT_BCNERR_CNT_INVALID_8197F)
#define BITS_BCNERR_CNT_INVALID_8197F \
(BIT_MASK_BCNERR_CNT_INVALID_8197F \
<< BIT_SHIFT_BCNERR_CNT_INVALID_8197F)
#define BIT_CLEAR_BCNERR_CNT_INVALID_8197F(x) \
((x) & (~BITS_BCNERR_CNT_INVALID_8197F))
#define BIT_GET_BCNERR_CNT_INVALID_8197F(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_INVALID_8197F) & \
BIT_MASK_BCNERR_CNT_INVALID_8197F)
#define BIT_SET_BCNERR_CNT_INVALID_8197F(x, v) \
(BIT_CLEAR_BCNERR_CNT_INVALID_8197F(x) | \
BIT_BCNERR_CNT_INVALID_8197F(v))
#define BIT_SHIFT_BCNERR_CNT_MAC_8197F 8
#define BIT_MASK_BCNERR_CNT_MAC_8197F 0xff
#define BIT_BCNERR_CNT_MAC_8197F(x) \
(((x) & BIT_MASK_BCNERR_CNT_MAC_8197F) \
<< BIT_SHIFT_BCNERR_CNT_MAC_8197F)
#define BITS_BCNERR_CNT_MAC_8197F \
(BIT_MASK_BCNERR_CNT_MAC_8197F << BIT_SHIFT_BCNERR_CNT_MAC_8197F)
#define BIT_CLEAR_BCNERR_CNT_MAC_8197F(x) ((x) & (~BITS_BCNERR_CNT_MAC_8197F))
#define BIT_GET_BCNERR_CNT_MAC_8197F(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_MAC_8197F) & \
BIT_MASK_BCNERR_CNT_MAC_8197F)
#define BIT_SET_BCNERR_CNT_MAC_8197F(x, v) \
(BIT_CLEAR_BCNERR_CNT_MAC_8197F(x) | BIT_BCNERR_CNT_MAC_8197F(v))
#define BIT_SHIFT_BCNERR_CNT_CCA_8197F 0
#define BIT_MASK_BCNERR_CNT_CCA_8197F 0xff
#define BIT_BCNERR_CNT_CCA_8197F(x) \
(((x) & BIT_MASK_BCNERR_CNT_CCA_8197F) \
<< BIT_SHIFT_BCNERR_CNT_CCA_8197F)
#define BITS_BCNERR_CNT_CCA_8197F \
(BIT_MASK_BCNERR_CNT_CCA_8197F << BIT_SHIFT_BCNERR_CNT_CCA_8197F)
#define BIT_CLEAR_BCNERR_CNT_CCA_8197F(x) ((x) & (~BITS_BCNERR_CNT_CCA_8197F))
#define BIT_GET_BCNERR_CNT_CCA_8197F(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_CCA_8197F) & \
BIT_MASK_BCNERR_CNT_CCA_8197F)
#define BIT_SET_BCNERR_CNT_CCA_8197F(x, v) \
(BIT_CLEAR_BCNERR_CNT_CCA_8197F(x) | BIT_BCNERR_CNT_CCA_8197F(v))
/* 2 REG_NOA_PARAM_8197F */
#define BIT_SHIFT_NOA_COUNT_8197F (96 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_COUNT_8197F 0xff
#define BIT_NOA_COUNT_8197F(x) \
(((x) & BIT_MASK_NOA_COUNT_8197F) << BIT_SHIFT_NOA_COUNT_8197F)
#define BITS_NOA_COUNT_8197F \
(BIT_MASK_NOA_COUNT_8197F << BIT_SHIFT_NOA_COUNT_8197F)
#define BIT_CLEAR_NOA_COUNT_8197F(x) ((x) & (~BITS_NOA_COUNT_8197F))
#define BIT_GET_NOA_COUNT_8197F(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_8197F) & BIT_MASK_NOA_COUNT_8197F)
#define BIT_SET_NOA_COUNT_8197F(x, v) \
(BIT_CLEAR_NOA_COUNT_8197F(x) | BIT_NOA_COUNT_8197F(v))
#define BIT_SHIFT_NOA_START_TIME_8197F (64 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_START_TIME_8197F 0xffffffffL
#define BIT_NOA_START_TIME_8197F(x) \
(((x) & BIT_MASK_NOA_START_TIME_8197F) \
<< BIT_SHIFT_NOA_START_TIME_8197F)
#define BITS_NOA_START_TIME_8197F \
(BIT_MASK_NOA_START_TIME_8197F << BIT_SHIFT_NOA_START_TIME_8197F)
#define BIT_CLEAR_NOA_START_TIME_8197F(x) ((x) & (~BITS_NOA_START_TIME_8197F))
#define BIT_GET_NOA_START_TIME_8197F(x) \
(((x) >> BIT_SHIFT_NOA_START_TIME_8197F) & \
BIT_MASK_NOA_START_TIME_8197F)
#define BIT_SET_NOA_START_TIME_8197F(x, v) \
(BIT_CLEAR_NOA_START_TIME_8197F(x) | BIT_NOA_START_TIME_8197F(v))
#define BIT_SHIFT_NOA_INTERVAL_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_INTERVAL_8197F 0xffffffffL
#define BIT_NOA_INTERVAL_8197F(x) \
(((x) & BIT_MASK_NOA_INTERVAL_8197F) << BIT_SHIFT_NOA_INTERVAL_8197F)
#define BITS_NOA_INTERVAL_8197F \
(BIT_MASK_NOA_INTERVAL_8197F << BIT_SHIFT_NOA_INTERVAL_8197F)
#define BIT_CLEAR_NOA_INTERVAL_8197F(x) ((x) & (~BITS_NOA_INTERVAL_8197F))
#define BIT_GET_NOA_INTERVAL_8197F(x) \
(((x) >> BIT_SHIFT_NOA_INTERVAL_8197F) & BIT_MASK_NOA_INTERVAL_8197F)
#define BIT_SET_NOA_INTERVAL_8197F(x, v) \
(BIT_CLEAR_NOA_INTERVAL_8197F(x) | BIT_NOA_INTERVAL_8197F(v))
#define BIT_SHIFT_NOA_DURATION_8197F 0
#define BIT_MASK_NOA_DURATION_8197F 0xffffffffL
#define BIT_NOA_DURATION_8197F(x) \
(((x) & BIT_MASK_NOA_DURATION_8197F) << BIT_SHIFT_NOA_DURATION_8197F)
#define BITS_NOA_DURATION_8197F \
(BIT_MASK_NOA_DURATION_8197F << BIT_SHIFT_NOA_DURATION_8197F)
#define BIT_CLEAR_NOA_DURATION_8197F(x) ((x) & (~BITS_NOA_DURATION_8197F))
#define BIT_GET_NOA_DURATION_8197F(x) \
(((x) >> BIT_SHIFT_NOA_DURATION_8197F) & BIT_MASK_NOA_DURATION_8197F)
#define BIT_SET_NOA_DURATION_8197F(x, v) \
(BIT_CLEAR_NOA_DURATION_8197F(x) | BIT_NOA_DURATION_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_P2P_RST_8197F */
#define BIT_P2P2_PWR_RST1_8197F BIT(5)
#define BIT_P2P2_PWR_RST0_8197F BIT(4)
#define BIT_P2P1_PWR_RST1_8197F BIT(3)
#define BIT_P2P1_PWR_RST0_8197F BIT(2)
#define BIT_P2P_PWR_RST1_V1_8197F BIT(1)
#define BIT_P2P_PWR_RST0_V1_8197F BIT(0)
/* 2 REG_SCHEDULER_RST_8197F */
#define BIT_SYNC_TSF_NOW_8197F BIT(2)
#define BIT_SYNC_CLI_8197F BIT(1)
#define BIT_SCHEDULER_RST_V1_8197F BIT(0)
/* 2 REG_SCH_TXCMD_8197F */
#define BIT_SHIFT_SCH_TXCMD_8197F 0
#define BIT_MASK_SCH_TXCMD_8197F 0xffffffffL
#define BIT_SCH_TXCMD_8197F(x) \
(((x) & BIT_MASK_SCH_TXCMD_8197F) << BIT_SHIFT_SCH_TXCMD_8197F)
#define BITS_SCH_TXCMD_8197F \
(BIT_MASK_SCH_TXCMD_8197F << BIT_SHIFT_SCH_TXCMD_8197F)
#define BIT_CLEAR_SCH_TXCMD_8197F(x) ((x) & (~BITS_SCH_TXCMD_8197F))
#define BIT_GET_SCH_TXCMD_8197F(x) \
(((x) >> BIT_SHIFT_SCH_TXCMD_8197F) & BIT_MASK_SCH_TXCMD_8197F)
#define BIT_SET_SCH_TXCMD_8197F(x, v) \
(BIT_CLEAR_SCH_TXCMD_8197F(x) | BIT_SCH_TXCMD_8197F(v))
/* 2 REG_PAGE5_DUMMY_8197F */
/* 2 REG_CPUMGQ_TX_TIMER_8197F */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8197F 0
#define BIT_MASK_CPUMGQ_TX_TIMER_V1_8197F 0xffffffffL
#define BIT_CPUMGQ_TX_TIMER_V1_8197F(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_V1_8197F) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8197F)
#define BITS_CPUMGQ_TX_TIMER_V1_8197F \
(BIT_MASK_CPUMGQ_TX_TIMER_V1_8197F \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8197F)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8197F(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_V1_8197F))
#define BIT_GET_CPUMGQ_TX_TIMER_V1_8197F(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8197F) & \
BIT_MASK_CPUMGQ_TX_TIMER_V1_8197F)
#define BIT_SET_CPUMGQ_TX_TIMER_V1_8197F(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8197F(x) | \
BIT_CPUMGQ_TX_TIMER_V1_8197F(v))
/* 2 REG_PS_TIMER_A_8197F */
#define BIT_SHIFT_PS_TIMER_A_V1_8197F 0
#define BIT_MASK_PS_TIMER_A_V1_8197F 0xffffffffL
#define BIT_PS_TIMER_A_V1_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_A_V1_8197F) << BIT_SHIFT_PS_TIMER_A_V1_8197F)
#define BITS_PS_TIMER_A_V1_8197F \
(BIT_MASK_PS_TIMER_A_V1_8197F << BIT_SHIFT_PS_TIMER_A_V1_8197F)
#define BIT_CLEAR_PS_TIMER_A_V1_8197F(x) ((x) & (~BITS_PS_TIMER_A_V1_8197F))
#define BIT_GET_PS_TIMER_A_V1_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_V1_8197F) & BIT_MASK_PS_TIMER_A_V1_8197F)
#define BIT_SET_PS_TIMER_A_V1_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_A_V1_8197F(x) | BIT_PS_TIMER_A_V1_8197F(v))
/* 2 REG_PS_TIMER_B_8197F */
#define BIT_SHIFT_PS_TIMER_B_V1_8197F 0
#define BIT_MASK_PS_TIMER_B_V1_8197F 0xffffffffL
#define BIT_PS_TIMER_B_V1_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_B_V1_8197F) << BIT_SHIFT_PS_TIMER_B_V1_8197F)
#define BITS_PS_TIMER_B_V1_8197F \
(BIT_MASK_PS_TIMER_B_V1_8197F << BIT_SHIFT_PS_TIMER_B_V1_8197F)
#define BIT_CLEAR_PS_TIMER_B_V1_8197F(x) ((x) & (~BITS_PS_TIMER_B_V1_8197F))
#define BIT_GET_PS_TIMER_B_V1_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_V1_8197F) & BIT_MASK_PS_TIMER_B_V1_8197F)
#define BIT_SET_PS_TIMER_B_V1_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_B_V1_8197F(x) | BIT_PS_TIMER_B_V1_8197F(v))
/* 2 REG_PS_TIMER_C_8197F */
#define BIT_SHIFT_PS_TIMER_C_V1_8197F 0
#define BIT_MASK_PS_TIMER_C_V1_8197F 0xffffffffL
#define BIT_PS_TIMER_C_V1_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_C_V1_8197F) << BIT_SHIFT_PS_TIMER_C_V1_8197F)
#define BITS_PS_TIMER_C_V1_8197F \
(BIT_MASK_PS_TIMER_C_V1_8197F << BIT_SHIFT_PS_TIMER_C_V1_8197F)
#define BIT_CLEAR_PS_TIMER_C_V1_8197F(x) ((x) & (~BITS_PS_TIMER_C_V1_8197F))
#define BIT_GET_PS_TIMER_C_V1_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_V1_8197F) & BIT_MASK_PS_TIMER_C_V1_8197F)
#define BIT_SET_PS_TIMER_C_V1_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_C_V1_8197F(x) | BIT_PS_TIMER_C_V1_8197F(v))
/* 2 REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8197F */
#define BIT_CPUMGQ_TIMER_EN_8197F BIT(31)
#define BIT_CPUMGQ_TX_EN_8197F BIT(28)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8197F 24
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8197F 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL_8197F(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8197F) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8197F)
#define BITS_CPUMGQ_TIMER_TSF_SEL_8197F \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8197F \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8197F)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8197F(x) \
((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL_8197F))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL_8197F(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8197F) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8197F)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL_8197F(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8197F(x) | \
BIT_CPUMGQ_TIMER_TSF_SEL_8197F(v))
#define BIT_PS_TIMER_C_EN_8197F BIT(23)
#define BIT_SHIFT_PS_TIMER_C_TSF_SEL_8197F 16
#define BIT_MASK_PS_TIMER_C_TSF_SEL_8197F 0x7
#define BIT_PS_TIMER_C_TSF_SEL_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_C_TSF_SEL_8197F) \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8197F)
#define BITS_PS_TIMER_C_TSF_SEL_8197F \
(BIT_MASK_PS_TIMER_C_TSF_SEL_8197F \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8197F)
#define BIT_CLEAR_PS_TIMER_C_TSF_SEL_8197F(x) \
((x) & (~BITS_PS_TIMER_C_TSF_SEL_8197F))
#define BIT_GET_PS_TIMER_C_TSF_SEL_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_TSF_SEL_8197F) & \
BIT_MASK_PS_TIMER_C_TSF_SEL_8197F)
#define BIT_SET_PS_TIMER_C_TSF_SEL_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_C_TSF_SEL_8197F(x) | \
BIT_PS_TIMER_C_TSF_SEL_8197F(v))
#define BIT_PS_TIMER_B_EN_8197F BIT(15)
#define BIT_SHIFT_PS_TIMER_B_TSF_SEL_8197F 8
#define BIT_MASK_PS_TIMER_B_TSF_SEL_8197F 0x7
#define BIT_PS_TIMER_B_TSF_SEL_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_B_TSF_SEL_8197F) \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8197F)
#define BITS_PS_TIMER_B_TSF_SEL_8197F \
(BIT_MASK_PS_TIMER_B_TSF_SEL_8197F \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8197F)
#define BIT_CLEAR_PS_TIMER_B_TSF_SEL_8197F(x) \
((x) & (~BITS_PS_TIMER_B_TSF_SEL_8197F))
#define BIT_GET_PS_TIMER_B_TSF_SEL_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_TSF_SEL_8197F) & \
BIT_MASK_PS_TIMER_B_TSF_SEL_8197F)
#define BIT_SET_PS_TIMER_B_TSF_SEL_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_B_TSF_SEL_8197F(x) | \
BIT_PS_TIMER_B_TSF_SEL_8197F(v))
#define BIT_PS_TIMER_A_EN_8197F BIT(7)
#define BIT_SHIFT_PS_TIMER_A_TSF_SEL_8197F 0
#define BIT_MASK_PS_TIMER_A_TSF_SEL_8197F 0x7
#define BIT_PS_TIMER_A_TSF_SEL_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_A_TSF_SEL_8197F) \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8197F)
#define BITS_PS_TIMER_A_TSF_SEL_8197F \
(BIT_MASK_PS_TIMER_A_TSF_SEL_8197F \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8197F)
#define BIT_CLEAR_PS_TIMER_A_TSF_SEL_8197F(x) \
((x) & (~BITS_PS_TIMER_A_TSF_SEL_8197F))
#define BIT_GET_PS_TIMER_A_TSF_SEL_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_TSF_SEL_8197F) & \
BIT_MASK_PS_TIMER_A_TSF_SEL_8197F)
#define BIT_SET_PS_TIMER_A_TSF_SEL_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_A_TSF_SEL_8197F(x) | \
BIT_PS_TIMER_A_TSF_SEL_8197F(v))
/* 2 REG_CPUMGQ_TX_TIMER_EARLY_8197F */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8197F 0
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8197F 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY_8197F(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8197F) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8197F)
#define BITS_CPUMGQ_TX_TIMER_EARLY_8197F \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8197F \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8197F)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8197F(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY_8197F))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY_8197F(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8197F) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8197F)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY_8197F(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8197F(x) | \
BIT_CPUMGQ_TX_TIMER_EARLY_8197F(v))
/* 2 REG_PS_TIMER_A_EARLY_8197F */
#define BIT_SHIFT_PS_TIMER_A_EARLY_8197F 0
#define BIT_MASK_PS_TIMER_A_EARLY_8197F 0xff
#define BIT_PS_TIMER_A_EARLY_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_A_EARLY_8197F) \
<< BIT_SHIFT_PS_TIMER_A_EARLY_8197F)
#define BITS_PS_TIMER_A_EARLY_8197F \
(BIT_MASK_PS_TIMER_A_EARLY_8197F << BIT_SHIFT_PS_TIMER_A_EARLY_8197F)
#define BIT_CLEAR_PS_TIMER_A_EARLY_8197F(x) \
((x) & (~BITS_PS_TIMER_A_EARLY_8197F))
#define BIT_GET_PS_TIMER_A_EARLY_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_EARLY_8197F) & \
BIT_MASK_PS_TIMER_A_EARLY_8197F)
#define BIT_SET_PS_TIMER_A_EARLY_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_A_EARLY_8197F(x) | BIT_PS_TIMER_A_EARLY_8197F(v))
/* 2 REG_PS_TIMER_B_EARLY_8197F */
#define BIT_SHIFT_PS_TIMER_B_EARLY_8197F 0
#define BIT_MASK_PS_TIMER_B_EARLY_8197F 0xff
#define BIT_PS_TIMER_B_EARLY_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_B_EARLY_8197F) \
<< BIT_SHIFT_PS_TIMER_B_EARLY_8197F)
#define BITS_PS_TIMER_B_EARLY_8197F \
(BIT_MASK_PS_TIMER_B_EARLY_8197F << BIT_SHIFT_PS_TIMER_B_EARLY_8197F)
#define BIT_CLEAR_PS_TIMER_B_EARLY_8197F(x) \
((x) & (~BITS_PS_TIMER_B_EARLY_8197F))
#define BIT_GET_PS_TIMER_B_EARLY_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_EARLY_8197F) & \
BIT_MASK_PS_TIMER_B_EARLY_8197F)
#define BIT_SET_PS_TIMER_B_EARLY_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_B_EARLY_8197F(x) | BIT_PS_TIMER_B_EARLY_8197F(v))
/* 2 REG_PS_TIMER_C_EARLY_8197F */
#define BIT_SHIFT_PS_TIMER_C_EARLY_8197F 0
#define BIT_MASK_PS_TIMER_C_EARLY_8197F 0xff
#define BIT_PS_TIMER_C_EARLY_8197F(x) \
(((x) & BIT_MASK_PS_TIMER_C_EARLY_8197F) \
<< BIT_SHIFT_PS_TIMER_C_EARLY_8197F)
#define BITS_PS_TIMER_C_EARLY_8197F \
(BIT_MASK_PS_TIMER_C_EARLY_8197F << BIT_SHIFT_PS_TIMER_C_EARLY_8197F)
#define BIT_CLEAR_PS_TIMER_C_EARLY_8197F(x) \
((x) & (~BITS_PS_TIMER_C_EARLY_8197F))
#define BIT_GET_PS_TIMER_C_EARLY_8197F(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_EARLY_8197F) & \
BIT_MASK_PS_TIMER_C_EARLY_8197F)
#define BIT_SET_PS_TIMER_C_EARLY_8197F(x, v) \
(BIT_CLEAR_PS_TIMER_C_EARLY_8197F(x) | BIT_PS_TIMER_C_EARLY_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_STOP_CPUMGQ_8197F BIT(16)
#define BIT_SHIFT_CPUMGQ_PARAMETER_8197F 0
#define BIT_MASK_CPUMGQ_PARAMETER_8197F 0xffff
#define BIT_CPUMGQ_PARAMETER_8197F(x) \
(((x) & BIT_MASK_CPUMGQ_PARAMETER_8197F) \
<< BIT_SHIFT_CPUMGQ_PARAMETER_8197F)
#define BITS_CPUMGQ_PARAMETER_8197F \
(BIT_MASK_CPUMGQ_PARAMETER_8197F << BIT_SHIFT_CPUMGQ_PARAMETER_8197F)
#define BIT_CLEAR_CPUMGQ_PARAMETER_8197F(x) \
((x) & (~BITS_CPUMGQ_PARAMETER_8197F))
#define BIT_GET_CPUMGQ_PARAMETER_8197F(x) \
(((x) >> BIT_SHIFT_CPUMGQ_PARAMETER_8197F) & \
BIT_MASK_CPUMGQ_PARAMETER_8197F)
#define BIT_SET_CPUMGQ_PARAMETER_8197F(x, v) \
(BIT_CLEAR_CPUMGQ_PARAMETER_8197F(x) | BIT_CPUMGQ_PARAMETER_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_BWOPMODE_8197F (BW OPERATION MODE REGISTER) */
/* 2 REG_WMAC_FWPKT_CR_8197F */
#define BIT_FWEN_8197F BIT(7)
#define BIT_PHYSTS_PKT_CTRL_8197F BIT(6)
#define BIT_APPHDR_MIDSRCH_FAIL_8197F BIT(4)
#define BIT_FWPARSING_EN_8197F BIT(3)
#define BIT_SHIFT_APPEND_MHDR_LEN_8197F 0
#define BIT_MASK_APPEND_MHDR_LEN_8197F 0x7
#define BIT_APPEND_MHDR_LEN_8197F(x) \
(((x) & BIT_MASK_APPEND_MHDR_LEN_8197F) \
<< BIT_SHIFT_APPEND_MHDR_LEN_8197F)
#define BITS_APPEND_MHDR_LEN_8197F \
(BIT_MASK_APPEND_MHDR_LEN_8197F << BIT_SHIFT_APPEND_MHDR_LEN_8197F)
#define BIT_CLEAR_APPEND_MHDR_LEN_8197F(x) ((x) & (~BITS_APPEND_MHDR_LEN_8197F))
#define BIT_GET_APPEND_MHDR_LEN_8197F(x) \
(((x) >> BIT_SHIFT_APPEND_MHDR_LEN_8197F) & \
BIT_MASK_APPEND_MHDR_LEN_8197F)
#define BIT_SET_APPEND_MHDR_LEN_8197F(x, v) \
(BIT_CLEAR_APPEND_MHDR_LEN_8197F(x) | BIT_APPEND_MHDR_LEN_8197F(v))
/* 2 REG_WMAC_CR_8197F (WMAC CR AND APSD CONTROL REGISTER) */
#define BIT_APSDOFF_8197F BIT(6)
#define BIT_IC_MACPHY_M_8197F BIT(0)
/* 2 REG_TCR_8197F (TRANSMISSION CONFIGURATION REGISTER) */
#define BIT_WMAC_EN_RTS_ADDR_8197F BIT(31)
#define BIT_WMAC_DISABLE_CCK_8197F BIT(30)
#define BIT_WMAC_RAW_LEN_8197F BIT(29)
#define BIT_WMAC_NOTX_IN_RXNDP_8197F BIT(28)
#define BIT_WMAC_EN_EOF_8197F BIT(27)
#define BIT_WMAC_BF_SEL_8197F BIT(26)
#define BIT_WMAC_ANTMODE_SEL_8197F BIT(25)
#define BIT_WMAC_TCRPWRMGT_HWCTL_8197F BIT(24)
#define BIT_WMAC_SMOOTH_VAL_8197F BIT(23)
#define BIT_UNDERFLOWEN_CMPLEN_SEL_8197F BIT(21)
#define BIT_FETCH_MPDU_AFTER_WSEC_RDY_8197F BIT(20)
#define BIT_WMAC_TCR_EN_20MST_8197F BIT(19)
#define BIT_WMAC_DIS_SIGTA_8197F BIT(18)
#define BIT_WMAC_DIS_A2B0_8197F BIT(17)
#define BIT_WMAC_MSK_SIGBCRC_8197F BIT(16)
#define BIT_WMAC_TCR_ERRSTEN_3_8197F BIT(15)
#define BIT_WMAC_TCR_ERRSTEN_2_8197F BIT(14)
#define BIT_WMAC_TCR_ERRSTEN_1_8197F BIT(13)
#define BIT_WMAC_TCR_ERRSTEN_0_8197F BIT(12)
#define BIT_WMAC_TCR_TXSK_PERPKT_8197F BIT(11)
#define BIT_ICV_8197F BIT(10)
#define BIT_CFEND_FORMAT_8197F BIT(9)
#define BIT_CRC_8197F BIT(8)
#define BIT_PWRBIT_OW_EN_8197F BIT(7)
#define BIT_PWR_ST_8197F BIT(6)
#define BIT_WMAC_TCR_UPD_TIMIE_8197F BIT(5)
#define BIT_WMAC_TCR_UPD_HGQMD_8197F BIT(4)
#define BIT_VHTSIGA1_TXPS_8197F BIT(3)
#define BIT_PAD_SEL_8197F BIT(2)
#define BIT_DIS_GCLK_8197F BIT(1)
/* 2 REG_RCR_8197F (RECEIVE CONFIGURATION REGISTER) */
#define BIT_APP_FCS_8197F BIT(31)
#define BIT_APP_MIC_8197F BIT(30)
#define BIT_APP_ICV_8197F BIT(29)
#define BIT_APP_PHYSTS_8197F BIT(28)
#define BIT_APP_BASSN_8197F BIT(27)
#define BIT_VHT_DACK_8197F BIT(26)
#define BIT_TCPOFLD_EN_8197F BIT(25)
#define BIT_ENMBID_8197F BIT(24)
#define BIT_LSIGEN_8197F BIT(23)
#define BIT_MFBEN_8197F BIT(22)
#define BIT_DISCHKPPDLLEN_8197F BIT(21)
#define BIT_PKTCTL_DLEN_8197F BIT(20)
#define BIT_TIM_PARSER_EN_8197F BIT(18)
#define BIT_BC_MD_EN_8197F BIT(17)
#define BIT_UC_MD_EN_8197F BIT(16)
#define BIT_RXSK_PERPKT_8197F BIT(15)
#define BIT_HTC_LOC_CTRL_8197F BIT(14)
#define BIT_TA_BCN_8197F BIT(11)
#define BIT_DISDECMYPKT_8197F BIT(10)
#define BIT_AICV_8197F BIT(9)
#define BIT_ACRC32_8197F BIT(8)
#define BIT_CBSSID_BCN_8197F BIT(7)
#define BIT_CBSSID_DATA_8197F BIT(6)
#define BIT_APWRMGT_8197F BIT(5)
#define BIT_ADD3_8197F BIT(4)
#define BIT_AB_8197F BIT(3)
#define BIT_AM_8197F BIT(2)
#define BIT_APM_8197F BIT(1)
#define BIT_AAP_8197F BIT(0)
/* 2 REG_RX_DRVINFO_SZ_8197F (RX DRIVER INFO SIZE REGISTER) */
#define BIT_APP_PHYSTS_PER_SUBMPDU_8197F BIT(7)
#define BIT_APP_MH_SHIFT_VAL_8197F BIT(6)
#define BIT_WMAC_ENSHIFT_8197F BIT(5)
#define BIT_SHIFT_DRVINFO_SZ_V1_8197F 0
#define BIT_MASK_DRVINFO_SZ_V1_8197F 0xf
#define BIT_DRVINFO_SZ_V1_8197F(x) \
(((x) & BIT_MASK_DRVINFO_SZ_V1_8197F) << BIT_SHIFT_DRVINFO_SZ_V1_8197F)
#define BITS_DRVINFO_SZ_V1_8197F \
(BIT_MASK_DRVINFO_SZ_V1_8197F << BIT_SHIFT_DRVINFO_SZ_V1_8197F)
#define BIT_CLEAR_DRVINFO_SZ_V1_8197F(x) ((x) & (~BITS_DRVINFO_SZ_V1_8197F))
#define BIT_GET_DRVINFO_SZ_V1_8197F(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ_V1_8197F) & BIT_MASK_DRVINFO_SZ_V1_8197F)
#define BIT_SET_DRVINFO_SZ_V1_8197F(x, v) \
(BIT_CLEAR_DRVINFO_SZ_V1_8197F(x) | BIT_DRVINFO_SZ_V1_8197F(v))
/* 2 REG_RX_DLK_TIME_8197F (RX DEADLOCK TIME REGISTER) */
#define BIT_SHIFT_RX_DLK_TIME_8197F 0
#define BIT_MASK_RX_DLK_TIME_8197F 0xff
#define BIT_RX_DLK_TIME_8197F(x) \
(((x) & BIT_MASK_RX_DLK_TIME_8197F) << BIT_SHIFT_RX_DLK_TIME_8197F)
#define BITS_RX_DLK_TIME_8197F \
(BIT_MASK_RX_DLK_TIME_8197F << BIT_SHIFT_RX_DLK_TIME_8197F)
#define BIT_CLEAR_RX_DLK_TIME_8197F(x) ((x) & (~BITS_RX_DLK_TIME_8197F))
#define BIT_GET_RX_DLK_TIME_8197F(x) \
(((x) >> BIT_SHIFT_RX_DLK_TIME_8197F) & BIT_MASK_RX_DLK_TIME_8197F)
#define BIT_SET_RX_DLK_TIME_8197F(x, v) \
(BIT_CLEAR_RX_DLK_TIME_8197F(x) | BIT_RX_DLK_TIME_8197F(v))
/* 2 REG_RX_PKT_LIMIT_8197F (RX PACKET LENGTH LIMIT REGISTER) */
#define BIT_SHIFT_RXPKTLMT_8197F 0
#define BIT_MASK_RXPKTLMT_8197F 0x3f
#define BIT_RXPKTLMT_8197F(x) \
(((x) & BIT_MASK_RXPKTLMT_8197F) << BIT_SHIFT_RXPKTLMT_8197F)
#define BITS_RXPKTLMT_8197F \
(BIT_MASK_RXPKTLMT_8197F << BIT_SHIFT_RXPKTLMT_8197F)
#define BIT_CLEAR_RXPKTLMT_8197F(x) ((x) & (~BITS_RXPKTLMT_8197F))
#define BIT_GET_RXPKTLMT_8197F(x) \
(((x) >> BIT_SHIFT_RXPKTLMT_8197F) & BIT_MASK_RXPKTLMT_8197F)
#define BIT_SET_RXPKTLMT_8197F(x, v) \
(BIT_CLEAR_RXPKTLMT_8197F(x) | BIT_RXPKTLMT_8197F(v))
/* 2 REG_MACID_8197F (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_8197F 0
#define BIT_MASK_MACID_8197F 0xffffffffffffL
#define BIT_MACID_8197F(x) \
(((x) & BIT_MASK_MACID_8197F) << BIT_SHIFT_MACID_8197F)
#define BITS_MACID_8197F (BIT_MASK_MACID_8197F << BIT_SHIFT_MACID_8197F)
#define BIT_CLEAR_MACID_8197F(x) ((x) & (~BITS_MACID_8197F))
#define BIT_GET_MACID_8197F(x) \
(((x) >> BIT_SHIFT_MACID_8197F) & BIT_MASK_MACID_8197F)
#define BIT_SET_MACID_8197F(x, v) \
(BIT_CLEAR_MACID_8197F(x) | BIT_MACID_8197F(v))
/* 2 REG_BSSID_8197F (BSSID REGISTER) */
#define BIT_SHIFT_BSSID_8197F 0
#define BIT_MASK_BSSID_8197F 0xffffffffffffL
#define BIT_BSSID_8197F(x) \
(((x) & BIT_MASK_BSSID_8197F) << BIT_SHIFT_BSSID_8197F)
#define BITS_BSSID_8197F (BIT_MASK_BSSID_8197F << BIT_SHIFT_BSSID_8197F)
#define BIT_CLEAR_BSSID_8197F(x) ((x) & (~BITS_BSSID_8197F))
#define BIT_GET_BSSID_8197F(x) \
(((x) >> BIT_SHIFT_BSSID_8197F) & BIT_MASK_BSSID_8197F)
#define BIT_SET_BSSID_8197F(x, v) \
(BIT_CLEAR_BSSID_8197F(x) | BIT_BSSID_8197F(v))
/* 2 REG_MAR_8197F (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_8197F 0
#define BIT_MASK_MAR_8197F 0xffffffffffffffffL
#define BIT_MAR_8197F(x) (((x) & BIT_MASK_MAR_8197F) << BIT_SHIFT_MAR_8197F)
#define BITS_MAR_8197F (BIT_MASK_MAR_8197F << BIT_SHIFT_MAR_8197F)
#define BIT_CLEAR_MAR_8197F(x) ((x) & (~BITS_MAR_8197F))
#define BIT_GET_MAR_8197F(x) (((x) >> BIT_SHIFT_MAR_8197F) & BIT_MASK_MAR_8197F)
#define BIT_SET_MAR_8197F(x, v) (BIT_CLEAR_MAR_8197F(x) | BIT_MAR_8197F(v))
/* 2 REG_MBIDCAMCFG_1_8197F (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_SHIFT_MBIDCAM_RWDATA_L_8197F 0
#define BIT_MASK_MBIDCAM_RWDATA_L_8197F 0xffffffffL
#define BIT_MBIDCAM_RWDATA_L_8197F(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_L_8197F) \
<< BIT_SHIFT_MBIDCAM_RWDATA_L_8197F)
#define BITS_MBIDCAM_RWDATA_L_8197F \
(BIT_MASK_MBIDCAM_RWDATA_L_8197F << BIT_SHIFT_MBIDCAM_RWDATA_L_8197F)
#define BIT_CLEAR_MBIDCAM_RWDATA_L_8197F(x) \
((x) & (~BITS_MBIDCAM_RWDATA_L_8197F))
#define BIT_GET_MBIDCAM_RWDATA_L_8197F(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_L_8197F) & \
BIT_MASK_MBIDCAM_RWDATA_L_8197F)
#define BIT_SET_MBIDCAM_RWDATA_L_8197F(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_L_8197F(x) | BIT_MBIDCAM_RWDATA_L_8197F(v))
/* 2 REG_MBIDCAMCFG_2_8197F (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_MBIDCAM_POLL_8197F BIT(31)
#define BIT_MBIDCAM_WT_EN_8197F BIT(30)
#define BIT_SHIFT_MBIDCAM_ADDR_V1_8197F 24
#define BIT_MASK_MBIDCAM_ADDR_V1_8197F 0x3f
#define BIT_MBIDCAM_ADDR_V1_8197F(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR_V1_8197F) \
<< BIT_SHIFT_MBIDCAM_ADDR_V1_8197F)
#define BITS_MBIDCAM_ADDR_V1_8197F \
(BIT_MASK_MBIDCAM_ADDR_V1_8197F << BIT_SHIFT_MBIDCAM_ADDR_V1_8197F)
#define BIT_CLEAR_MBIDCAM_ADDR_V1_8197F(x) ((x) & (~BITS_MBIDCAM_ADDR_V1_8197F))
#define BIT_GET_MBIDCAM_ADDR_V1_8197F(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR_V1_8197F) & \
BIT_MASK_MBIDCAM_ADDR_V1_8197F)
#define BIT_SET_MBIDCAM_ADDR_V1_8197F(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR_V1_8197F(x) | BIT_MBIDCAM_ADDR_V1_8197F(v))
#define BIT_MBIDCAM_VALID_8197F BIT(23)
#define BIT_LSIC_TXOP_EN_8197F BIT(17)
#define BIT_REPEAT_MODE_EN_8197F BIT(16)
#define BIT_SHIFT_MBIDCAM_RWDATA_H_8197F 0
#define BIT_MASK_MBIDCAM_RWDATA_H_8197F 0xffff
#define BIT_MBIDCAM_RWDATA_H_8197F(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_H_8197F) \
<< BIT_SHIFT_MBIDCAM_RWDATA_H_8197F)
#define BITS_MBIDCAM_RWDATA_H_8197F \
(BIT_MASK_MBIDCAM_RWDATA_H_8197F << BIT_SHIFT_MBIDCAM_RWDATA_H_8197F)
#define BIT_CLEAR_MBIDCAM_RWDATA_H_8197F(x) \
((x) & (~BITS_MBIDCAM_RWDATA_H_8197F))
#define BIT_GET_MBIDCAM_RWDATA_H_8197F(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_H_8197F) & \
BIT_MASK_MBIDCAM_RWDATA_H_8197F)
#define BIT_SET_MBIDCAM_RWDATA_H_8197F(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_H_8197F(x) | BIT_MBIDCAM_RWDATA_H_8197F(v))
/* 2 REG_ZLD_NUM_8197F */
#define BIT_SHIFT_ZLD_NUM_8197F 0
#define BIT_MASK_ZLD_NUM_8197F 0xff
#define BIT_ZLD_NUM_8197F(x) \
(((x) & BIT_MASK_ZLD_NUM_8197F) << BIT_SHIFT_ZLD_NUM_8197F)
#define BITS_ZLD_NUM_8197F (BIT_MASK_ZLD_NUM_8197F << BIT_SHIFT_ZLD_NUM_8197F)
#define BIT_CLEAR_ZLD_NUM_8197F(x) ((x) & (~BITS_ZLD_NUM_8197F))
#define BIT_GET_ZLD_NUM_8197F(x) \
(((x) >> BIT_SHIFT_ZLD_NUM_8197F) & BIT_MASK_ZLD_NUM_8197F)
#define BIT_SET_ZLD_NUM_8197F(x, v) \
(BIT_CLEAR_ZLD_NUM_8197F(x) | BIT_ZLD_NUM_8197F(v))
/* 2 REG_UDF_THSD_8197F */
#define BIT_SHIFT_UDF_THSD_8197F 0
#define BIT_MASK_UDF_THSD_8197F 0xff
#define BIT_UDF_THSD_8197F(x) \
(((x) & BIT_MASK_UDF_THSD_8197F) << BIT_SHIFT_UDF_THSD_8197F)
#define BITS_UDF_THSD_8197F \
(BIT_MASK_UDF_THSD_8197F << BIT_SHIFT_UDF_THSD_8197F)
#define BIT_CLEAR_UDF_THSD_8197F(x) ((x) & (~BITS_UDF_THSD_8197F))
#define BIT_GET_UDF_THSD_8197F(x) \
(((x) >> BIT_SHIFT_UDF_THSD_8197F) & BIT_MASK_UDF_THSD_8197F)
#define BIT_SET_UDF_THSD_8197F(x, v) \
(BIT_CLEAR_UDF_THSD_8197F(x) | BIT_UDF_THSD_8197F(v))
/* 2 REG_WMAC_TCR_TSFT_OFS_8197F */
#define BIT_SHIFT_WMAC_TCR_TSFT_OFS_8197F 0
#define BIT_MASK_WMAC_TCR_TSFT_OFS_8197F 0xffff
#define BIT_WMAC_TCR_TSFT_OFS_8197F(x) \
(((x) & BIT_MASK_WMAC_TCR_TSFT_OFS_8197F) \
<< BIT_SHIFT_WMAC_TCR_TSFT_OFS_8197F)
#define BITS_WMAC_TCR_TSFT_OFS_8197F \
(BIT_MASK_WMAC_TCR_TSFT_OFS_8197F << BIT_SHIFT_WMAC_TCR_TSFT_OFS_8197F)
#define BIT_CLEAR_WMAC_TCR_TSFT_OFS_8197F(x) \
((x) & (~BITS_WMAC_TCR_TSFT_OFS_8197F))
#define BIT_GET_WMAC_TCR_TSFT_OFS_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_TCR_TSFT_OFS_8197F) & \
BIT_MASK_WMAC_TCR_TSFT_OFS_8197F)
#define BIT_SET_WMAC_TCR_TSFT_OFS_8197F(x, v) \
(BIT_CLEAR_WMAC_TCR_TSFT_OFS_8197F(x) | BIT_WMAC_TCR_TSFT_OFS_8197F(v))
/* 2 REG_MCU_TEST_2_V1_8197F */
#define BIT_SHIFT_MCU_RSVD_2_V1_8197F 0
#define BIT_MASK_MCU_RSVD_2_V1_8197F 0xffff
#define BIT_MCU_RSVD_2_V1_8197F(x) \
(((x) & BIT_MASK_MCU_RSVD_2_V1_8197F) << BIT_SHIFT_MCU_RSVD_2_V1_8197F)
#define BITS_MCU_RSVD_2_V1_8197F \
(BIT_MASK_MCU_RSVD_2_V1_8197F << BIT_SHIFT_MCU_RSVD_2_V1_8197F)
#define BIT_CLEAR_MCU_RSVD_2_V1_8197F(x) ((x) & (~BITS_MCU_RSVD_2_V1_8197F))
#define BIT_GET_MCU_RSVD_2_V1_8197F(x) \
(((x) >> BIT_SHIFT_MCU_RSVD_2_V1_8197F) & BIT_MASK_MCU_RSVD_2_V1_8197F)
#define BIT_SET_MCU_RSVD_2_V1_8197F(x, v) \
(BIT_CLEAR_MCU_RSVD_2_V1_8197F(x) | BIT_MCU_RSVD_2_V1_8197F(v))
/* 2 REG_WMAC_TXTIMEOUT_8197F */
#define BIT_SHIFT_WMAC_TXTIMEOUT_8197F 0
#define BIT_MASK_WMAC_TXTIMEOUT_8197F 0xff
#define BIT_WMAC_TXTIMEOUT_8197F(x) \
(((x) & BIT_MASK_WMAC_TXTIMEOUT_8197F) \
<< BIT_SHIFT_WMAC_TXTIMEOUT_8197F)
#define BITS_WMAC_TXTIMEOUT_8197F \
(BIT_MASK_WMAC_TXTIMEOUT_8197F << BIT_SHIFT_WMAC_TXTIMEOUT_8197F)
#define BIT_CLEAR_WMAC_TXTIMEOUT_8197F(x) ((x) & (~BITS_WMAC_TXTIMEOUT_8197F))
#define BIT_GET_WMAC_TXTIMEOUT_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_TXTIMEOUT_8197F) & \
BIT_MASK_WMAC_TXTIMEOUT_8197F)
#define BIT_SET_WMAC_TXTIMEOUT_8197F(x, v) \
(BIT_CLEAR_WMAC_TXTIMEOUT_8197F(x) | BIT_WMAC_TXTIMEOUT_8197F(v))
/* 2 REG_STMP_THSD_8197F */
#define BIT_SHIFT_STMP_THSD_8197F 0
#define BIT_MASK_STMP_THSD_8197F 0xff
#define BIT_STMP_THSD_8197F(x) \
(((x) & BIT_MASK_STMP_THSD_8197F) << BIT_SHIFT_STMP_THSD_8197F)
#define BITS_STMP_THSD_8197F \
(BIT_MASK_STMP_THSD_8197F << BIT_SHIFT_STMP_THSD_8197F)
#define BIT_CLEAR_STMP_THSD_8197F(x) ((x) & (~BITS_STMP_THSD_8197F))
#define BIT_GET_STMP_THSD_8197F(x) \
(((x) >> BIT_SHIFT_STMP_THSD_8197F) & BIT_MASK_STMP_THSD_8197F)
#define BIT_SET_STMP_THSD_8197F(x, v) \
(BIT_CLEAR_STMP_THSD_8197F(x) | BIT_STMP_THSD_8197F(v))
/* 2 REG_MAC_SPEC_SIFS_8197F (SPECIFICATION SIFS REGISTER) */
#define BIT_SHIFT_SPEC_SIFS_OFDM_8197F 8
#define BIT_MASK_SPEC_SIFS_OFDM_8197F 0xff
#define BIT_SPEC_SIFS_OFDM_8197F(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_8197F) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_8197F)
#define BITS_SPEC_SIFS_OFDM_8197F \
(BIT_MASK_SPEC_SIFS_OFDM_8197F << BIT_SHIFT_SPEC_SIFS_OFDM_8197F)
#define BIT_CLEAR_SPEC_SIFS_OFDM_8197F(x) ((x) & (~BITS_SPEC_SIFS_OFDM_8197F))
#define BIT_GET_SPEC_SIFS_OFDM_8197F(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_8197F) & \
BIT_MASK_SPEC_SIFS_OFDM_8197F)
#define BIT_SET_SPEC_SIFS_OFDM_8197F(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_8197F(x) | BIT_SPEC_SIFS_OFDM_8197F(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_8197F 0
#define BIT_MASK_SPEC_SIFS_CCK_8197F 0xff
#define BIT_SPEC_SIFS_CCK_8197F(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_8197F) << BIT_SHIFT_SPEC_SIFS_CCK_8197F)
#define BITS_SPEC_SIFS_CCK_8197F \
(BIT_MASK_SPEC_SIFS_CCK_8197F << BIT_SHIFT_SPEC_SIFS_CCK_8197F)
#define BIT_CLEAR_SPEC_SIFS_CCK_8197F(x) ((x) & (~BITS_SPEC_SIFS_CCK_8197F))
#define BIT_GET_SPEC_SIFS_CCK_8197F(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_8197F) & BIT_MASK_SPEC_SIFS_CCK_8197F)
#define BIT_SET_SPEC_SIFS_CCK_8197F(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_8197F(x) | BIT_SPEC_SIFS_CCK_8197F(v))
/* 2 REG_USTIME_EDCA_8197F (US TIME TUNING FOR EDCA REGISTER) */
#define BIT_SHIFT_USTIME_EDCA_8197F 0
#define BIT_MASK_USTIME_EDCA_8197F 0xff
#define BIT_USTIME_EDCA_8197F(x) \
(((x) & BIT_MASK_USTIME_EDCA_8197F) << BIT_SHIFT_USTIME_EDCA_8197F)
#define BITS_USTIME_EDCA_8197F \
(BIT_MASK_USTIME_EDCA_8197F << BIT_SHIFT_USTIME_EDCA_8197F)
#define BIT_CLEAR_USTIME_EDCA_8197F(x) ((x) & (~BITS_USTIME_EDCA_8197F))
#define BIT_GET_USTIME_EDCA_8197F(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA_8197F) & BIT_MASK_USTIME_EDCA_8197F)
#define BIT_SET_USTIME_EDCA_8197F(x, v) \
(BIT_CLEAR_USTIME_EDCA_8197F(x) | BIT_USTIME_EDCA_8197F(v))
/* 2 REG_RESP_SIFS_OFDM_8197F (RESPONSE SIFS FOR OFDM REGISTER) */
#define BIT_SHIFT_SIFS_R2T_OFDM_8197F 8
#define BIT_MASK_SIFS_R2T_OFDM_8197F 0xff
#define BIT_SIFS_R2T_OFDM_8197F(x) \
(((x) & BIT_MASK_SIFS_R2T_OFDM_8197F) << BIT_SHIFT_SIFS_R2T_OFDM_8197F)
#define BITS_SIFS_R2T_OFDM_8197F \
(BIT_MASK_SIFS_R2T_OFDM_8197F << BIT_SHIFT_SIFS_R2T_OFDM_8197F)
#define BIT_CLEAR_SIFS_R2T_OFDM_8197F(x) ((x) & (~BITS_SIFS_R2T_OFDM_8197F))
#define BIT_GET_SIFS_R2T_OFDM_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_OFDM_8197F) & BIT_MASK_SIFS_R2T_OFDM_8197F)
#define BIT_SET_SIFS_R2T_OFDM_8197F(x, v) \
(BIT_CLEAR_SIFS_R2T_OFDM_8197F(x) | BIT_SIFS_R2T_OFDM_8197F(v))
#define BIT_SHIFT_SIFS_T2T_OFDM_8197F 0
#define BIT_MASK_SIFS_T2T_OFDM_8197F 0xff
#define BIT_SIFS_T2T_OFDM_8197F(x) \
(((x) & BIT_MASK_SIFS_T2T_OFDM_8197F) << BIT_SHIFT_SIFS_T2T_OFDM_8197F)
#define BITS_SIFS_T2T_OFDM_8197F \
(BIT_MASK_SIFS_T2T_OFDM_8197F << BIT_SHIFT_SIFS_T2T_OFDM_8197F)
#define BIT_CLEAR_SIFS_T2T_OFDM_8197F(x) ((x) & (~BITS_SIFS_T2T_OFDM_8197F))
#define BIT_GET_SIFS_T2T_OFDM_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_OFDM_8197F) & BIT_MASK_SIFS_T2T_OFDM_8197F)
#define BIT_SET_SIFS_T2T_OFDM_8197F(x, v) \
(BIT_CLEAR_SIFS_T2T_OFDM_8197F(x) | BIT_SIFS_T2T_OFDM_8197F(v))
/* 2 REG_RESP_SIFS_CCK_8197F (RESPONSE SIFS FOR CCK REGISTER) */
#define BIT_SHIFT_SIFS_R2T_CCK_8197F 8
#define BIT_MASK_SIFS_R2T_CCK_8197F 0xff
#define BIT_SIFS_R2T_CCK_8197F(x) \
(((x) & BIT_MASK_SIFS_R2T_CCK_8197F) << BIT_SHIFT_SIFS_R2T_CCK_8197F)
#define BITS_SIFS_R2T_CCK_8197F \
(BIT_MASK_SIFS_R2T_CCK_8197F << BIT_SHIFT_SIFS_R2T_CCK_8197F)
#define BIT_CLEAR_SIFS_R2T_CCK_8197F(x) ((x) & (~BITS_SIFS_R2T_CCK_8197F))
#define BIT_GET_SIFS_R2T_CCK_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_CCK_8197F) & BIT_MASK_SIFS_R2T_CCK_8197F)
#define BIT_SET_SIFS_R2T_CCK_8197F(x, v) \
(BIT_CLEAR_SIFS_R2T_CCK_8197F(x) | BIT_SIFS_R2T_CCK_8197F(v))
#define BIT_SHIFT_SIFS_T2T_CCK_8197F 0
#define BIT_MASK_SIFS_T2T_CCK_8197F 0xff
#define BIT_SIFS_T2T_CCK_8197F(x) \
(((x) & BIT_MASK_SIFS_T2T_CCK_8197F) << BIT_SHIFT_SIFS_T2T_CCK_8197F)
#define BITS_SIFS_T2T_CCK_8197F \
(BIT_MASK_SIFS_T2T_CCK_8197F << BIT_SHIFT_SIFS_T2T_CCK_8197F)
#define BIT_CLEAR_SIFS_T2T_CCK_8197F(x) ((x) & (~BITS_SIFS_T2T_CCK_8197F))
#define BIT_GET_SIFS_T2T_CCK_8197F(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_CCK_8197F) & BIT_MASK_SIFS_T2T_CCK_8197F)
#define BIT_SET_SIFS_T2T_CCK_8197F(x, v) \
(BIT_CLEAR_SIFS_T2T_CCK_8197F(x) | BIT_SIFS_T2T_CCK_8197F(v))
/* 2 REG_EIFS_8197F (EIFS REGISTER) */
#define BIT_SHIFT_EIFS_8197F 0
#define BIT_MASK_EIFS_8197F 0xffff
#define BIT_EIFS_8197F(x) (((x) & BIT_MASK_EIFS_8197F) << BIT_SHIFT_EIFS_8197F)
#define BITS_EIFS_8197F (BIT_MASK_EIFS_8197F << BIT_SHIFT_EIFS_8197F)
#define BIT_CLEAR_EIFS_8197F(x) ((x) & (~BITS_EIFS_8197F))
#define BIT_GET_EIFS_8197F(x) \
(((x) >> BIT_SHIFT_EIFS_8197F) & BIT_MASK_EIFS_8197F)
#define BIT_SET_EIFS_8197F(x, v) (BIT_CLEAR_EIFS_8197F(x) | BIT_EIFS_8197F(v))
/* 2 REG_CTS2TO_8197F (CTS2 TIMEOUT REGISTER) */
#define BIT_SHIFT_CTS2TO_8197F 0
#define BIT_MASK_CTS2TO_8197F 0xff
#define BIT_CTS2TO_8197F(x) \
(((x) & BIT_MASK_CTS2TO_8197F) << BIT_SHIFT_CTS2TO_8197F)
#define BITS_CTS2TO_8197F (BIT_MASK_CTS2TO_8197F << BIT_SHIFT_CTS2TO_8197F)
#define BIT_CLEAR_CTS2TO_8197F(x) ((x) & (~BITS_CTS2TO_8197F))
#define BIT_GET_CTS2TO_8197F(x) \
(((x) >> BIT_SHIFT_CTS2TO_8197F) & BIT_MASK_CTS2TO_8197F)
#define BIT_SET_CTS2TO_8197F(x, v) \
(BIT_CLEAR_CTS2TO_8197F(x) | BIT_CTS2TO_8197F(v))
/* 2 REG_ACKTO_8197F (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_ACKTO_8197F 0
#define BIT_MASK_ACKTO_8197F 0xff
#define BIT_ACKTO_8197F(x) \
(((x) & BIT_MASK_ACKTO_8197F) << BIT_SHIFT_ACKTO_8197F)
#define BITS_ACKTO_8197F (BIT_MASK_ACKTO_8197F << BIT_SHIFT_ACKTO_8197F)
#define BIT_CLEAR_ACKTO_8197F(x) ((x) & (~BITS_ACKTO_8197F))
#define BIT_GET_ACKTO_8197F(x) \
(((x) >> BIT_SHIFT_ACKTO_8197F) & BIT_MASK_ACKTO_8197F)
#define BIT_SET_ACKTO_8197F(x, v) \
(BIT_CLEAR_ACKTO_8197F(x) | BIT_ACKTO_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NAV_CTRL_8197F (NAV CONTROL REGISTER) */
#define BIT_SHIFT_NAV_UPPER_8197F 16
#define BIT_MASK_NAV_UPPER_8197F 0xff
#define BIT_NAV_UPPER_8197F(x) \
(((x) & BIT_MASK_NAV_UPPER_8197F) << BIT_SHIFT_NAV_UPPER_8197F)
#define BITS_NAV_UPPER_8197F \
(BIT_MASK_NAV_UPPER_8197F << BIT_SHIFT_NAV_UPPER_8197F)
#define BIT_CLEAR_NAV_UPPER_8197F(x) ((x) & (~BITS_NAV_UPPER_8197F))
#define BIT_GET_NAV_UPPER_8197F(x) \
(((x) >> BIT_SHIFT_NAV_UPPER_8197F) & BIT_MASK_NAV_UPPER_8197F)
#define BIT_SET_NAV_UPPER_8197F(x, v) \
(BIT_CLEAR_NAV_UPPER_8197F(x) | BIT_NAV_UPPER_8197F(v))
#define BIT_SHIFT_RXMYRTS_NAV_8197F 8
#define BIT_MASK_RXMYRTS_NAV_8197F 0xf
#define BIT_RXMYRTS_NAV_8197F(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_8197F) << BIT_SHIFT_RXMYRTS_NAV_8197F)
#define BITS_RXMYRTS_NAV_8197F \
(BIT_MASK_RXMYRTS_NAV_8197F << BIT_SHIFT_RXMYRTS_NAV_8197F)
#define BIT_CLEAR_RXMYRTS_NAV_8197F(x) ((x) & (~BITS_RXMYRTS_NAV_8197F))
#define BIT_GET_RXMYRTS_NAV_8197F(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_8197F) & BIT_MASK_RXMYRTS_NAV_8197F)
#define BIT_SET_RXMYRTS_NAV_8197F(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_8197F(x) | BIT_RXMYRTS_NAV_8197F(v))
#define BIT_SHIFT_RTSRST_8197F 0
#define BIT_MASK_RTSRST_8197F 0xff
#define BIT_RTSRST_8197F(x) \
(((x) & BIT_MASK_RTSRST_8197F) << BIT_SHIFT_RTSRST_8197F)
#define BITS_RTSRST_8197F (BIT_MASK_RTSRST_8197F << BIT_SHIFT_RTSRST_8197F)
#define BIT_CLEAR_RTSRST_8197F(x) ((x) & (~BITS_RTSRST_8197F))
#define BIT_GET_RTSRST_8197F(x) \
(((x) >> BIT_SHIFT_RTSRST_8197F) & BIT_MASK_RTSRST_8197F)
#define BIT_SET_RTSRST_8197F(x, v) \
(BIT_CLEAR_RTSRST_8197F(x) | BIT_RTSRST_8197F(v))
/* 2 REG_BACAMCMD_8197F (BLOCK ACK CAM COMMAND REGISTER) */
#define BIT_BACAM_POLL_8197F BIT(31)
#define BIT_BACAM_RST_8197F BIT(17)
#define BIT_BACAM_RW_8197F BIT(16)
#define BIT_SHIFT_TXSBM_8197F 14
#define BIT_MASK_TXSBM_8197F 0x3
#define BIT_TXSBM_8197F(x) \
(((x) & BIT_MASK_TXSBM_8197F) << BIT_SHIFT_TXSBM_8197F)
#define BITS_TXSBM_8197F (BIT_MASK_TXSBM_8197F << BIT_SHIFT_TXSBM_8197F)
#define BIT_CLEAR_TXSBM_8197F(x) ((x) & (~BITS_TXSBM_8197F))
#define BIT_GET_TXSBM_8197F(x) \
(((x) >> BIT_SHIFT_TXSBM_8197F) & BIT_MASK_TXSBM_8197F)
#define BIT_SET_TXSBM_8197F(x, v) \
(BIT_CLEAR_TXSBM_8197F(x) | BIT_TXSBM_8197F(v))
#define BIT_SHIFT_BACAM_ADDR_8197F 0
#define BIT_MASK_BACAM_ADDR_8197F 0x3f
#define BIT_BACAM_ADDR_8197F(x) \
(((x) & BIT_MASK_BACAM_ADDR_8197F) << BIT_SHIFT_BACAM_ADDR_8197F)
#define BITS_BACAM_ADDR_8197F \
(BIT_MASK_BACAM_ADDR_8197F << BIT_SHIFT_BACAM_ADDR_8197F)
#define BIT_CLEAR_BACAM_ADDR_8197F(x) ((x) & (~BITS_BACAM_ADDR_8197F))
#define BIT_GET_BACAM_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_BACAM_ADDR_8197F) & BIT_MASK_BACAM_ADDR_8197F)
#define BIT_SET_BACAM_ADDR_8197F(x, v) \
(BIT_CLEAR_BACAM_ADDR_8197F(x) | BIT_BACAM_ADDR_8197F(v))
/* 2 REG_BACAMCONTENT_8197F (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_H_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_BA_CONTENT_H_8197F 0xffffffffL
#define BIT_BA_CONTENT_H_8197F(x) \
(((x) & BIT_MASK_BA_CONTENT_H_8197F) << BIT_SHIFT_BA_CONTENT_H_8197F)
#define BITS_BA_CONTENT_H_8197F \
(BIT_MASK_BA_CONTENT_H_8197F << BIT_SHIFT_BA_CONTENT_H_8197F)
#define BIT_CLEAR_BA_CONTENT_H_8197F(x) ((x) & (~BITS_BA_CONTENT_H_8197F))
#define BIT_GET_BA_CONTENT_H_8197F(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_H_8197F) & BIT_MASK_BA_CONTENT_H_8197F)
#define BIT_SET_BA_CONTENT_H_8197F(x, v) \
(BIT_CLEAR_BA_CONTENT_H_8197F(x) | BIT_BA_CONTENT_H_8197F(v))
#define BIT_SHIFT_BA_CONTENT_L_8197F 0
#define BIT_MASK_BA_CONTENT_L_8197F 0xffffffffL
#define BIT_BA_CONTENT_L_8197F(x) \
(((x) & BIT_MASK_BA_CONTENT_L_8197F) << BIT_SHIFT_BA_CONTENT_L_8197F)
#define BITS_BA_CONTENT_L_8197F \
(BIT_MASK_BA_CONTENT_L_8197F << BIT_SHIFT_BA_CONTENT_L_8197F)
#define BIT_CLEAR_BA_CONTENT_L_8197F(x) ((x) & (~BITS_BA_CONTENT_L_8197F))
#define BIT_GET_BA_CONTENT_L_8197F(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_L_8197F) & BIT_MASK_BA_CONTENT_L_8197F)
#define BIT_SET_BA_CONTENT_L_8197F(x, v) \
(BIT_CLEAR_BA_CONTENT_L_8197F(x) | BIT_BA_CONTENT_L_8197F(v))
/* 2 REG_WMAC_BITMAP_CTL_8197F */
#define BIT_BITMAP_VO_8197F BIT(7)
#define BIT_BITMAP_VI_8197F BIT(6)
#define BIT_BITMAP_BE_8197F BIT(5)
#define BIT_BITMAP_BK_8197F BIT(4)
#define BIT_SHIFT_BITMAP_CONDITION_8197F 2
#define BIT_MASK_BITMAP_CONDITION_8197F 0x3
#define BIT_BITMAP_CONDITION_8197F(x) \
(((x) & BIT_MASK_BITMAP_CONDITION_8197F) \
<< BIT_SHIFT_BITMAP_CONDITION_8197F)
#define BITS_BITMAP_CONDITION_8197F \
(BIT_MASK_BITMAP_CONDITION_8197F << BIT_SHIFT_BITMAP_CONDITION_8197F)
#define BIT_CLEAR_BITMAP_CONDITION_8197F(x) \
((x) & (~BITS_BITMAP_CONDITION_8197F))
#define BIT_GET_BITMAP_CONDITION_8197F(x) \
(((x) >> BIT_SHIFT_BITMAP_CONDITION_8197F) & \
BIT_MASK_BITMAP_CONDITION_8197F)
#define BIT_SET_BITMAP_CONDITION_8197F(x, v) \
(BIT_CLEAR_BITMAP_CONDITION_8197F(x) | BIT_BITMAP_CONDITION_8197F(v))
#define BIT_BITMAP_SSNBK_COUNTER_CLR_8197F BIT(1)
#define BIT_BITMAP_FORCE_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_RXPKT_TYPE_8197F 2
#define BIT_MASK_RXPKT_TYPE_8197F 0x3f
#define BIT_RXPKT_TYPE_8197F(x) \
(((x) & BIT_MASK_RXPKT_TYPE_8197F) << BIT_SHIFT_RXPKT_TYPE_8197F)
#define BITS_RXPKT_TYPE_8197F \
(BIT_MASK_RXPKT_TYPE_8197F << BIT_SHIFT_RXPKT_TYPE_8197F)
#define BIT_CLEAR_RXPKT_TYPE_8197F(x) ((x) & (~BITS_RXPKT_TYPE_8197F))
#define BIT_GET_RXPKT_TYPE_8197F(x) \
(((x) >> BIT_SHIFT_RXPKT_TYPE_8197F) & BIT_MASK_RXPKT_TYPE_8197F)
#define BIT_SET_RXPKT_TYPE_8197F(x, v) \
(BIT_CLEAR_RXPKT_TYPE_8197F(x) | BIT_RXPKT_TYPE_8197F(v))
#define BIT_TXACT_IND_8197F BIT(1)
#define BIT_RXACT_IND_8197F BIT(0)
/* 2 REG_WMAC_BACAM_RPMEN_8197F */
#define BIT_SHIFT_BITMAP_SSNBK_COUNTER_8197F 2
#define BIT_MASK_BITMAP_SSNBK_COUNTER_8197F 0x3f
#define BIT_BITMAP_SSNBK_COUNTER_8197F(x) \
(((x) & BIT_MASK_BITMAP_SSNBK_COUNTER_8197F) \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8197F)
#define BITS_BITMAP_SSNBK_COUNTER_8197F \
(BIT_MASK_BITMAP_SSNBK_COUNTER_8197F \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8197F)
#define BIT_CLEAR_BITMAP_SSNBK_COUNTER_8197F(x) \
((x) & (~BITS_BITMAP_SSNBK_COUNTER_8197F))
#define BIT_GET_BITMAP_SSNBK_COUNTER_8197F(x) \
(((x) >> BIT_SHIFT_BITMAP_SSNBK_COUNTER_8197F) & \
BIT_MASK_BITMAP_SSNBK_COUNTER_8197F)
#define BIT_SET_BITMAP_SSNBK_COUNTER_8197F(x, v) \
(BIT_CLEAR_BITMAP_SSNBK_COUNTER_8197F(x) | \
BIT_BITMAP_SSNBK_COUNTER_8197F(v))
#define BIT_BITMAP_EN_8197F BIT(1)
#define BIT_WMAC_BACAM_RPMEN_8197F BIT(0)
/* 2 REG_LBDLY_8197F (LOOPBACK DELAY REGISTER) */
#define BIT_SHIFT_LBDLY_8197F 0
#define BIT_MASK_LBDLY_8197F 0x1f
#define BIT_LBDLY_8197F(x) \
(((x) & BIT_MASK_LBDLY_8197F) << BIT_SHIFT_LBDLY_8197F)
#define BITS_LBDLY_8197F (BIT_MASK_LBDLY_8197F << BIT_SHIFT_LBDLY_8197F)
#define BIT_CLEAR_LBDLY_8197F(x) ((x) & (~BITS_LBDLY_8197F))
#define BIT_GET_LBDLY_8197F(x) \
(((x) >> BIT_SHIFT_LBDLY_8197F) & BIT_MASK_LBDLY_8197F)
#define BIT_SET_LBDLY_8197F(x, v) \
(BIT_CLEAR_LBDLY_8197F(x) | BIT_LBDLY_8197F(v))
/* 2 REG_RXERR_RPT_8197F (RX ERROR REPORT REGISTER) */
#define BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8197F 28
#define BIT_MASK_RXERR_RPT_SEL_V1_3_0_8197F 0xf
#define BIT_RXERR_RPT_SEL_V1_3_0_8197F(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL_V1_3_0_8197F) \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8197F)
#define BITS_RXERR_RPT_SEL_V1_3_0_8197F \
(BIT_MASK_RXERR_RPT_SEL_V1_3_0_8197F \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8197F)
#define BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8197F(x) \
((x) & (~BITS_RXERR_RPT_SEL_V1_3_0_8197F))
#define BIT_GET_RXERR_RPT_SEL_V1_3_0_8197F(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8197F) & \
BIT_MASK_RXERR_RPT_SEL_V1_3_0_8197F)
#define BIT_SET_RXERR_RPT_SEL_V1_3_0_8197F(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8197F(x) | \
BIT_RXERR_RPT_SEL_V1_3_0_8197F(v))
#define BIT_RXERR_RPT_RST_8197F BIT(27)
#define BIT_RXERR_RPT_SEL_V1_4_8197F BIT(26)
#define BIT_SHIFT_UD_SELECT_BSSID_2_1_8197F 24
#define BIT_MASK_UD_SELECT_BSSID_2_1_8197F 0x3
#define BIT_UD_SELECT_BSSID_2_1_8197F(x) \
(((x) & BIT_MASK_UD_SELECT_BSSID_2_1_8197F) \
<< BIT_SHIFT_UD_SELECT_BSSID_2_1_8197F)
#define BITS_UD_SELECT_BSSID_2_1_8197F \
(BIT_MASK_UD_SELECT_BSSID_2_1_8197F \
<< BIT_SHIFT_UD_SELECT_BSSID_2_1_8197F)
#define BIT_CLEAR_UD_SELECT_BSSID_2_1_8197F(x) \
((x) & (~BITS_UD_SELECT_BSSID_2_1_8197F))
#define BIT_GET_UD_SELECT_BSSID_2_1_8197F(x) \
(((x) >> BIT_SHIFT_UD_SELECT_BSSID_2_1_8197F) & \
BIT_MASK_UD_SELECT_BSSID_2_1_8197F)
#define BIT_SET_UD_SELECT_BSSID_2_1_8197F(x, v) \
(BIT_CLEAR_UD_SELECT_BSSID_2_1_8197F(x) | \
BIT_UD_SELECT_BSSID_2_1_8197F(v))
#define BIT_W1S_8197F BIT(23)
#define BIT_UD_SELECT_BSSID_0_8197F BIT(22)
#define BIT_SHIFT_UD_SUB_TYPE_8197F 18
#define BIT_MASK_UD_SUB_TYPE_8197F 0xf
#define BIT_UD_SUB_TYPE_8197F(x) \
(((x) & BIT_MASK_UD_SUB_TYPE_8197F) << BIT_SHIFT_UD_SUB_TYPE_8197F)
#define BITS_UD_SUB_TYPE_8197F \
(BIT_MASK_UD_SUB_TYPE_8197F << BIT_SHIFT_UD_SUB_TYPE_8197F)
#define BIT_CLEAR_UD_SUB_TYPE_8197F(x) ((x) & (~BITS_UD_SUB_TYPE_8197F))
#define BIT_GET_UD_SUB_TYPE_8197F(x) \
(((x) >> BIT_SHIFT_UD_SUB_TYPE_8197F) & BIT_MASK_UD_SUB_TYPE_8197F)
#define BIT_SET_UD_SUB_TYPE_8197F(x, v) \
(BIT_CLEAR_UD_SUB_TYPE_8197F(x) | BIT_UD_SUB_TYPE_8197F(v))
#define BIT_SHIFT_UD_TYPE_8197F 16
#define BIT_MASK_UD_TYPE_8197F 0x3
#define BIT_UD_TYPE_8197F(x) \
(((x) & BIT_MASK_UD_TYPE_8197F) << BIT_SHIFT_UD_TYPE_8197F)
#define BITS_UD_TYPE_8197F (BIT_MASK_UD_TYPE_8197F << BIT_SHIFT_UD_TYPE_8197F)
#define BIT_CLEAR_UD_TYPE_8197F(x) ((x) & (~BITS_UD_TYPE_8197F))
#define BIT_GET_UD_TYPE_8197F(x) \
(((x) >> BIT_SHIFT_UD_TYPE_8197F) & BIT_MASK_UD_TYPE_8197F)
#define BIT_SET_UD_TYPE_8197F(x, v) \
(BIT_CLEAR_UD_TYPE_8197F(x) | BIT_UD_TYPE_8197F(v))
#define BIT_SHIFT_RPT_COUNTER_8197F 0
#define BIT_MASK_RPT_COUNTER_8197F 0xffff
#define BIT_RPT_COUNTER_8197F(x) \
(((x) & BIT_MASK_RPT_COUNTER_8197F) << BIT_SHIFT_RPT_COUNTER_8197F)
#define BITS_RPT_COUNTER_8197F \
(BIT_MASK_RPT_COUNTER_8197F << BIT_SHIFT_RPT_COUNTER_8197F)
#define BIT_CLEAR_RPT_COUNTER_8197F(x) ((x) & (~BITS_RPT_COUNTER_8197F))
#define BIT_GET_RPT_COUNTER_8197F(x) \
(((x) >> BIT_SHIFT_RPT_COUNTER_8197F) & BIT_MASK_RPT_COUNTER_8197F)
#define BIT_SET_RPT_COUNTER_8197F(x, v) \
(BIT_CLEAR_RPT_COUNTER_8197F(x) | BIT_RPT_COUNTER_8197F(v))
/* 2 REG_WMAC_TRXPTCL_CTL_8197F (WMAC TX/RX PROTOCOL CONTROL REGISTER) */
#define BIT_SHIFT_ACKBA_TYPSEL_8197F (60 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBA_TYPSEL_8197F 0xf
#define BIT_ACKBA_TYPSEL_8197F(x) \
(((x) & BIT_MASK_ACKBA_TYPSEL_8197F) << BIT_SHIFT_ACKBA_TYPSEL_8197F)
#define BITS_ACKBA_TYPSEL_8197F \
(BIT_MASK_ACKBA_TYPSEL_8197F << BIT_SHIFT_ACKBA_TYPSEL_8197F)
#define BIT_CLEAR_ACKBA_TYPSEL_8197F(x) ((x) & (~BITS_ACKBA_TYPSEL_8197F))
#define BIT_GET_ACKBA_TYPSEL_8197F(x) \
(((x) >> BIT_SHIFT_ACKBA_TYPSEL_8197F) & BIT_MASK_ACKBA_TYPSEL_8197F)
#define BIT_SET_ACKBA_TYPSEL_8197F(x, v) \
(BIT_CLEAR_ACKBA_TYPSEL_8197F(x) | BIT_ACKBA_TYPSEL_8197F(v))
#define BIT_SHIFT_ACKBA_ACKPCHK_8197F (56 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBA_ACKPCHK_8197F 0xf
#define BIT_ACKBA_ACKPCHK_8197F(x) \
(((x) & BIT_MASK_ACKBA_ACKPCHK_8197F) << BIT_SHIFT_ACKBA_ACKPCHK_8197F)
#define BITS_ACKBA_ACKPCHK_8197F \
(BIT_MASK_ACKBA_ACKPCHK_8197F << BIT_SHIFT_ACKBA_ACKPCHK_8197F)
#define BIT_CLEAR_ACKBA_ACKPCHK_8197F(x) ((x) & (~BITS_ACKBA_ACKPCHK_8197F))
#define BIT_GET_ACKBA_ACKPCHK_8197F(x) \
(((x) >> BIT_SHIFT_ACKBA_ACKPCHK_8197F) & BIT_MASK_ACKBA_ACKPCHK_8197F)
#define BIT_SET_ACKBA_ACKPCHK_8197F(x, v) \
(BIT_CLEAR_ACKBA_ACKPCHK_8197F(x) | BIT_ACKBA_ACKPCHK_8197F(v))
#define BIT_SHIFT_ACKBAR_TYPESEL_8197F (48 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBAR_TYPESEL_8197F 0xff
#define BIT_ACKBAR_TYPESEL_8197F(x) \
(((x) & BIT_MASK_ACKBAR_TYPESEL_8197F) \
<< BIT_SHIFT_ACKBAR_TYPESEL_8197F)
#define BITS_ACKBAR_TYPESEL_8197F \
(BIT_MASK_ACKBAR_TYPESEL_8197F << BIT_SHIFT_ACKBAR_TYPESEL_8197F)
#define BIT_CLEAR_ACKBAR_TYPESEL_8197F(x) ((x) & (~BITS_ACKBAR_TYPESEL_8197F))
#define BIT_GET_ACKBAR_TYPESEL_8197F(x) \
(((x) >> BIT_SHIFT_ACKBAR_TYPESEL_8197F) & \
BIT_MASK_ACKBAR_TYPESEL_8197F)
#define BIT_SET_ACKBAR_TYPESEL_8197F(x, v) \
(BIT_CLEAR_ACKBAR_TYPESEL_8197F(x) | BIT_ACKBAR_TYPESEL_8197F(v))
#define BIT_SHIFT_ACKBAR_ACKPCHK_8197F (44 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBAR_ACKPCHK_8197F 0xf
#define BIT_ACKBAR_ACKPCHK_8197F(x) \
(((x) & BIT_MASK_ACKBAR_ACKPCHK_8197F) \
<< BIT_SHIFT_ACKBAR_ACKPCHK_8197F)
#define BITS_ACKBAR_ACKPCHK_8197F \
(BIT_MASK_ACKBAR_ACKPCHK_8197F << BIT_SHIFT_ACKBAR_ACKPCHK_8197F)
#define BIT_CLEAR_ACKBAR_ACKPCHK_8197F(x) ((x) & (~BITS_ACKBAR_ACKPCHK_8197F))
#define BIT_GET_ACKBAR_ACKPCHK_8197F(x) \
(((x) >> BIT_SHIFT_ACKBAR_ACKPCHK_8197F) & \
BIT_MASK_ACKBAR_ACKPCHK_8197F)
#define BIT_SET_ACKBAR_ACKPCHK_8197F(x, v) \
(BIT_CLEAR_ACKBAR_ACKPCHK_8197F(x) | BIT_ACKBAR_ACKPCHK_8197F(v))
#define BIT_RXBA_IGNOREA2_8197F BIT(42)
#define BIT_EN_SAVE_ALL_TXOPADDR_8197F BIT(41)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV_8197F BIT(40)
#define BIT_DIS_TXBA_AMPDUFCSERR_8197F BIT(39)
#define BIT_DIS_TXBA_RXBARINFULL_8197F BIT(38)
#define BIT_DIS_TXCFE_INFULL_8197F BIT(37)
#define BIT_DIS_TXCTS_INFULL_8197F BIT(36)
#define BIT_EN_TXACKBA_IN_TX_RDG_8197F BIT(35)
#define BIT_EN_TXACKBA_IN_TXOP_8197F BIT(34)
#define BIT_EN_TXCTS_IN_RXNAV_8197F BIT(33)
#define BIT_EN_TXCTS_INTXOP_8197F BIT(32)
#define BIT_BLK_EDCA_BBSLP_8197F BIT(31)
#define BIT_BLK_EDCA_BBSBY_8197F BIT(30)
#define BIT_ACKTO_BLOCK_SCH_EN_8197F BIT(27)
#define BIT_EIFS_BLOCK_SCH_EN_8197F BIT(26)
#define BIT_PLCPCHK_RST_EIFS_8197F BIT(25)
#define BIT_CCA_RST_EIFS_8197F BIT(24)
#define BIT_DIS_UPD_MYRXPKTNAV_8197F BIT(23)
#define BIT_EARLY_TXBA_8197F BIT(22)
#define BIT_SHIFT_RESP_CHNBUSY_8197F 20
#define BIT_MASK_RESP_CHNBUSY_8197F 0x3
#define BIT_RESP_CHNBUSY_8197F(x) \
(((x) & BIT_MASK_RESP_CHNBUSY_8197F) << BIT_SHIFT_RESP_CHNBUSY_8197F)
#define BITS_RESP_CHNBUSY_8197F \
(BIT_MASK_RESP_CHNBUSY_8197F << BIT_SHIFT_RESP_CHNBUSY_8197F)
#define BIT_CLEAR_RESP_CHNBUSY_8197F(x) ((x) & (~BITS_RESP_CHNBUSY_8197F))
#define BIT_GET_RESP_CHNBUSY_8197F(x) \
(((x) >> BIT_SHIFT_RESP_CHNBUSY_8197F) & BIT_MASK_RESP_CHNBUSY_8197F)
#define BIT_SET_RESP_CHNBUSY_8197F(x, v) \
(BIT_CLEAR_RESP_CHNBUSY_8197F(x) | BIT_RESP_CHNBUSY_8197F(v))
#define BIT_RESP_DCTS_EN_8197F BIT(19)
#define BIT_RESP_DCFE_EN_8197F BIT(18)
#define BIT_RESP_SPLCPEN_8197F BIT(17)
#define BIT_RESP_SGIEN_8197F BIT(16)
#define BIT_RESP_LDPC_EN_8197F BIT(15)
#define BIT_DIS_RESP_ACKINCCA_8197F BIT(14)
#define BIT_DIS_RESP_CTSINCCA_8197F BIT(13)
#define BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8197F 10
#define BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8197F 0x7
#define BIT_R_WMAC_SECOND_CCA_TIMER_8197F(x) \
(((x) & BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8197F) \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8197F)
#define BITS_R_WMAC_SECOND_CCA_TIMER_8197F \
(BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8197F \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8197F)
#define BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8197F(x) \
((x) & (~BITS_R_WMAC_SECOND_CCA_TIMER_8197F))
#define BIT_GET_R_WMAC_SECOND_CCA_TIMER_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8197F) & \
BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8197F)
#define BIT_SET_R_WMAC_SECOND_CCA_TIMER_8197F(x, v) \
(BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8197F(x) | \
BIT_R_WMAC_SECOND_CCA_TIMER_8197F(v))
#define BIT_SHIFT_RFMOD_8197F 7
#define BIT_MASK_RFMOD_8197F 0x3
#define BIT_RFMOD_8197F(x) \
(((x) & BIT_MASK_RFMOD_8197F) << BIT_SHIFT_RFMOD_8197F)
#define BITS_RFMOD_8197F (BIT_MASK_RFMOD_8197F << BIT_SHIFT_RFMOD_8197F)
#define BIT_CLEAR_RFMOD_8197F(x) ((x) & (~BITS_RFMOD_8197F))
#define BIT_GET_RFMOD_8197F(x) \
(((x) >> BIT_SHIFT_RFMOD_8197F) & BIT_MASK_RFMOD_8197F)
#define BIT_SET_RFMOD_8197F(x, v) \
(BIT_CLEAR_RFMOD_8197F(x) | BIT_RFMOD_8197F(v))
#define BIT_SHIFT_RESP_CTS_DYNBW_SEL_8197F 5
#define BIT_MASK_RESP_CTS_DYNBW_SEL_8197F 0x3
#define BIT_RESP_CTS_DYNBW_SEL_8197F(x) \
(((x) & BIT_MASK_RESP_CTS_DYNBW_SEL_8197F) \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8197F)
#define BITS_RESP_CTS_DYNBW_SEL_8197F \
(BIT_MASK_RESP_CTS_DYNBW_SEL_8197F \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8197F)
#define BIT_CLEAR_RESP_CTS_DYNBW_SEL_8197F(x) \
((x) & (~BITS_RESP_CTS_DYNBW_SEL_8197F))
#define BIT_GET_RESP_CTS_DYNBW_SEL_8197F(x) \
(((x) >> BIT_SHIFT_RESP_CTS_DYNBW_SEL_8197F) & \
BIT_MASK_RESP_CTS_DYNBW_SEL_8197F)
#define BIT_SET_RESP_CTS_DYNBW_SEL_8197F(x, v) \
(BIT_CLEAR_RESP_CTS_DYNBW_SEL_8197F(x) | \
BIT_RESP_CTS_DYNBW_SEL_8197F(v))
#define BIT_DLY_TX_WAIT_RXANTSEL_8197F BIT(4)
#define BIT_TXRESP_BY_RXANTSEL_8197F BIT(3)
#define BIT_SHIFT_ORIG_DCTS_CHK_8197F 0
#define BIT_MASK_ORIG_DCTS_CHK_8197F 0x3
#define BIT_ORIG_DCTS_CHK_8197F(x) \
(((x) & BIT_MASK_ORIG_DCTS_CHK_8197F) << BIT_SHIFT_ORIG_DCTS_CHK_8197F)
#define BITS_ORIG_DCTS_CHK_8197F \
(BIT_MASK_ORIG_DCTS_CHK_8197F << BIT_SHIFT_ORIG_DCTS_CHK_8197F)
#define BIT_CLEAR_ORIG_DCTS_CHK_8197F(x) ((x) & (~BITS_ORIG_DCTS_CHK_8197F))
#define BIT_GET_ORIG_DCTS_CHK_8197F(x) \
(((x) >> BIT_SHIFT_ORIG_DCTS_CHK_8197F) & BIT_MASK_ORIG_DCTS_CHK_8197F)
#define BIT_SET_ORIG_DCTS_CHK_8197F(x, v) \
(BIT_CLEAR_ORIG_DCTS_CHK_8197F(x) | BIT_ORIG_DCTS_CHK_8197F(v))
/* 2 REG_CAMCMD_8197F (CAM COMMAND REGISTER) */
#define BIT_SECCAM_POLLING_8197F BIT(31)
#define BIT_SECCAM_CLR_8197F BIT(30)
#define BIT_MFBCAM_CLR_8197F BIT(29)
#define BIT_SECCAM_WE_8197F BIT(16)
#define BIT_SHIFT_SECCAM_ADDR_V2_8197F 0
#define BIT_MASK_SECCAM_ADDR_V2_8197F 0x3ff
#define BIT_SECCAM_ADDR_V2_8197F(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V2_8197F) \
<< BIT_SHIFT_SECCAM_ADDR_V2_8197F)
#define BITS_SECCAM_ADDR_V2_8197F \
(BIT_MASK_SECCAM_ADDR_V2_8197F << BIT_SHIFT_SECCAM_ADDR_V2_8197F)
#define BIT_CLEAR_SECCAM_ADDR_V2_8197F(x) ((x) & (~BITS_SECCAM_ADDR_V2_8197F))
#define BIT_GET_SECCAM_ADDR_V2_8197F(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V2_8197F) & \
BIT_MASK_SECCAM_ADDR_V2_8197F)
#define BIT_SET_SECCAM_ADDR_V2_8197F(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V2_8197F(x) | BIT_SECCAM_ADDR_V2_8197F(v))
/* 2 REG_CAMWRITE_8197F (CAM WRITE REGISTER) */
#define BIT_SHIFT_CAMW_DATA_8197F 0
#define BIT_MASK_CAMW_DATA_8197F 0xffffffffL
#define BIT_CAMW_DATA_8197F(x) \
(((x) & BIT_MASK_CAMW_DATA_8197F) << BIT_SHIFT_CAMW_DATA_8197F)
#define BITS_CAMW_DATA_8197F \
(BIT_MASK_CAMW_DATA_8197F << BIT_SHIFT_CAMW_DATA_8197F)
#define BIT_CLEAR_CAMW_DATA_8197F(x) ((x) & (~BITS_CAMW_DATA_8197F))
#define BIT_GET_CAMW_DATA_8197F(x) \
(((x) >> BIT_SHIFT_CAMW_DATA_8197F) & BIT_MASK_CAMW_DATA_8197F)
#define BIT_SET_CAMW_DATA_8197F(x, v) \
(BIT_CLEAR_CAMW_DATA_8197F(x) | BIT_CAMW_DATA_8197F(v))
/* 2 REG_CAMREAD_8197F (CAM READ REGISTER) */
#define BIT_SHIFT_CAMR_DATA_8197F 0
#define BIT_MASK_CAMR_DATA_8197F 0xffffffffL
#define BIT_CAMR_DATA_8197F(x) \
(((x) & BIT_MASK_CAMR_DATA_8197F) << BIT_SHIFT_CAMR_DATA_8197F)
#define BITS_CAMR_DATA_8197F \
(BIT_MASK_CAMR_DATA_8197F << BIT_SHIFT_CAMR_DATA_8197F)
#define BIT_CLEAR_CAMR_DATA_8197F(x) ((x) & (~BITS_CAMR_DATA_8197F))
#define BIT_GET_CAMR_DATA_8197F(x) \
(((x) >> BIT_SHIFT_CAMR_DATA_8197F) & BIT_MASK_CAMR_DATA_8197F)
#define BIT_SET_CAMR_DATA_8197F(x, v) \
(BIT_CLEAR_CAMR_DATA_8197F(x) | BIT_CAMR_DATA_8197F(v))
/* 2 REG_CAMDBG_8197F (CAM DEBUG REGISTER) */
#define BIT_SECCAM_INFO_8197F BIT(31)
#define BIT_SEC_KEYFOUND_8197F BIT(15)
#define BIT_SHIFT_CAMDBG_SEC_TYPE_8197F 12
#define BIT_MASK_CAMDBG_SEC_TYPE_8197F 0x7
#define BIT_CAMDBG_SEC_TYPE_8197F(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE_8197F) \
<< BIT_SHIFT_CAMDBG_SEC_TYPE_8197F)
#define BITS_CAMDBG_SEC_TYPE_8197F \
(BIT_MASK_CAMDBG_SEC_TYPE_8197F << BIT_SHIFT_CAMDBG_SEC_TYPE_8197F)
#define BIT_CLEAR_CAMDBG_SEC_TYPE_8197F(x) ((x) & (~BITS_CAMDBG_SEC_TYPE_8197F))
#define BIT_GET_CAMDBG_SEC_TYPE_8197F(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE_8197F) & \
BIT_MASK_CAMDBG_SEC_TYPE_8197F)
#define BIT_SET_CAMDBG_SEC_TYPE_8197F(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE_8197F(x) | BIT_CAMDBG_SEC_TYPE_8197F(v))
#define BIT_CAMDBG_EXT_SEC_TYPE_8197F BIT(11)
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8197F 5
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_8197F 0x1f
#define BIT_CAMDBG_MIC_KEY_IDX_8197F(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_8197F) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8197F)
#define BITS_CAMDBG_MIC_KEY_IDX_8197F \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_8197F \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8197F)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8197F(x) \
((x) & (~BITS_CAMDBG_MIC_KEY_IDX_8197F))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_8197F(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8197F) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_8197F)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_8197F(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8197F(x) | \
BIT_CAMDBG_MIC_KEY_IDX_8197F(v))
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8197F 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_8197F 0x1f
#define BIT_CAMDBG_SEC_KEY_IDX_8197F(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_8197F) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8197F)
#define BITS_CAMDBG_SEC_KEY_IDX_8197F \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_8197F \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8197F)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8197F(x) \
((x) & (~BITS_CAMDBG_SEC_KEY_IDX_8197F))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_8197F(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8197F) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_8197F)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_8197F(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8197F(x) | \
BIT_CAMDBG_SEC_KEY_IDX_8197F(v))
/* 2 REG_RXFILTER_ACTION_1_8197F */
#define BIT_SHIFT_RXFILTER_ACTION_1_8197F 0
#define BIT_MASK_RXFILTER_ACTION_1_8197F 0xff
#define BIT_RXFILTER_ACTION_1_8197F(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_1_8197F) \
<< BIT_SHIFT_RXFILTER_ACTION_1_8197F)
#define BITS_RXFILTER_ACTION_1_8197F \
(BIT_MASK_RXFILTER_ACTION_1_8197F << BIT_SHIFT_RXFILTER_ACTION_1_8197F)
#define BIT_CLEAR_RXFILTER_ACTION_1_8197F(x) \
((x) & (~BITS_RXFILTER_ACTION_1_8197F))
#define BIT_GET_RXFILTER_ACTION_1_8197F(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_1_8197F) & \
BIT_MASK_RXFILTER_ACTION_1_8197F)
#define BIT_SET_RXFILTER_ACTION_1_8197F(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_1_8197F(x) | BIT_RXFILTER_ACTION_1_8197F(v))
/* 2 REG_RXFILTER_CATEGORY_1_8197F */
#define BIT_SHIFT_RXFILTER_CATEGORY_1_8197F 0
#define BIT_MASK_RXFILTER_CATEGORY_1_8197F 0xff
#define BIT_RXFILTER_CATEGORY_1_8197F(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_1_8197F) \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8197F)
#define BITS_RXFILTER_CATEGORY_1_8197F \
(BIT_MASK_RXFILTER_CATEGORY_1_8197F \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8197F)
#define BIT_CLEAR_RXFILTER_CATEGORY_1_8197F(x) \
((x) & (~BITS_RXFILTER_CATEGORY_1_8197F))
#define BIT_GET_RXFILTER_CATEGORY_1_8197F(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_1_8197F) & \
BIT_MASK_RXFILTER_CATEGORY_1_8197F)
#define BIT_SET_RXFILTER_CATEGORY_1_8197F(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_1_8197F(x) | \
BIT_RXFILTER_CATEGORY_1_8197F(v))
/* 2 REG_SECCFG_8197F (SECURITY CONFIGURATION REGISTER) */
#define BIT_DIS_GCLK_WAPI_8197F BIT(15)
#define BIT_DIS_GCLK_AES_8197F BIT(14)
#define BIT_DIS_GCLK_TKIP_8197F BIT(13)
#define BIT_AES_SEL_QC_1_8197F BIT(12)
#define BIT_AES_SEL_QC_0_8197F BIT(11)
#define BIT_WMAC_CKECK_BMC_8197F BIT(9)
#define BIT_CHK_KEYID_8197F BIT(8)
#define BIT_RXBCUSEDK_8197F BIT(7)
#define BIT_TXBCUSEDK_8197F BIT(6)
#define BIT_NOSKMC_8197F BIT(5)
#define BIT_SKBYA2_8197F BIT(4)
#define BIT_RXDEC_8197F BIT(3)
#define BIT_TXENC_8197F BIT(2)
#define BIT_RXUHUSEDK_8197F BIT(1)
#define BIT_TXUHUSEDK_8197F BIT(0)
/* 2 REG_RXFILTER_ACTION_3_8197F */
#define BIT_SHIFT_RXFILTER_ACTION_3_8197F 0
#define BIT_MASK_RXFILTER_ACTION_3_8197F 0xff
#define BIT_RXFILTER_ACTION_3_8197F(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_3_8197F) \
<< BIT_SHIFT_RXFILTER_ACTION_3_8197F)
#define BITS_RXFILTER_ACTION_3_8197F \
(BIT_MASK_RXFILTER_ACTION_3_8197F << BIT_SHIFT_RXFILTER_ACTION_3_8197F)
#define BIT_CLEAR_RXFILTER_ACTION_3_8197F(x) \
((x) & (~BITS_RXFILTER_ACTION_3_8197F))
#define BIT_GET_RXFILTER_ACTION_3_8197F(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_3_8197F) & \
BIT_MASK_RXFILTER_ACTION_3_8197F)
#define BIT_SET_RXFILTER_ACTION_3_8197F(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_3_8197F(x) | BIT_RXFILTER_ACTION_3_8197F(v))
/* 2 REG_RXFILTER_CATEGORY_3_8197F */
#define BIT_SHIFT_RXFILTER_CATEGORY_3_8197F 0
#define BIT_MASK_RXFILTER_CATEGORY_3_8197F 0xff
#define BIT_RXFILTER_CATEGORY_3_8197F(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_3_8197F) \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8197F)
#define BITS_RXFILTER_CATEGORY_3_8197F \
(BIT_MASK_RXFILTER_CATEGORY_3_8197F \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8197F)
#define BIT_CLEAR_RXFILTER_CATEGORY_3_8197F(x) \
((x) & (~BITS_RXFILTER_CATEGORY_3_8197F))
#define BIT_GET_RXFILTER_CATEGORY_3_8197F(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_3_8197F) & \
BIT_MASK_RXFILTER_CATEGORY_3_8197F)
#define BIT_SET_RXFILTER_CATEGORY_3_8197F(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_3_8197F(x) | \
BIT_RXFILTER_CATEGORY_3_8197F(v))
/* 2 REG_RXFILTER_ACTION_2_8197F */
#define BIT_SHIFT_RXFILTER_ACTION_2_8197F 0
#define BIT_MASK_RXFILTER_ACTION_2_8197F 0xff
#define BIT_RXFILTER_ACTION_2_8197F(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_2_8197F) \
<< BIT_SHIFT_RXFILTER_ACTION_2_8197F)
#define BITS_RXFILTER_ACTION_2_8197F \
(BIT_MASK_RXFILTER_ACTION_2_8197F << BIT_SHIFT_RXFILTER_ACTION_2_8197F)
#define BIT_CLEAR_RXFILTER_ACTION_2_8197F(x) \
((x) & (~BITS_RXFILTER_ACTION_2_8197F))
#define BIT_GET_RXFILTER_ACTION_2_8197F(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_2_8197F) & \
BIT_MASK_RXFILTER_ACTION_2_8197F)
#define BIT_SET_RXFILTER_ACTION_2_8197F(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_2_8197F(x) | BIT_RXFILTER_ACTION_2_8197F(v))
/* 2 REG_RXFILTER_CATEGORY_2_8197F */
#define BIT_SHIFT_RXFILTER_CATEGORY_2_8197F 0
#define BIT_MASK_RXFILTER_CATEGORY_2_8197F 0xff
#define BIT_RXFILTER_CATEGORY_2_8197F(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_2_8197F) \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8197F)
#define BITS_RXFILTER_CATEGORY_2_8197F \
(BIT_MASK_RXFILTER_CATEGORY_2_8197F \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8197F)
#define BIT_CLEAR_RXFILTER_CATEGORY_2_8197F(x) \
((x) & (~BITS_RXFILTER_CATEGORY_2_8197F))
#define BIT_GET_RXFILTER_CATEGORY_2_8197F(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_2_8197F) & \
BIT_MASK_RXFILTER_CATEGORY_2_8197F)
#define BIT_SET_RXFILTER_CATEGORY_2_8197F(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_2_8197F(x) | \
BIT_RXFILTER_CATEGORY_2_8197F(v))
/* 2 REG_RXFLTMAP4_8197F (RX FILTER MAP GROUP 4) */
#define BIT_CTRLFLT15EN_FW_8197F BIT(15)
#define BIT_CTRLFLT14EN_FW_8197F BIT(14)
#define BIT_CTRLFLT13EN_FW_8197F BIT(13)
#define BIT_CTRLFLT12EN_FW_8197F BIT(12)
#define BIT_CTRLFLT11EN_FW_8197F BIT(11)
#define BIT_CTRLFLT10EN_FW_8197F BIT(10)
#define BIT_CTRLFLT9EN_FW_8197F BIT(9)
#define BIT_CTRLFLT8EN_FW_8197F BIT(8)
#define BIT_CTRLFLT7EN_FW_8197F BIT(7)
#define BIT_CTRLFLT6EN_FW_8197F BIT(6)
#define BIT_CTRLFLT5EN_FW_8197F BIT(5)
#define BIT_CTRLFLT4EN_FW_8197F BIT(4)
#define BIT_CTRLFLT3EN_FW_8197F BIT(3)
#define BIT_CTRLFLT2EN_FW_8197F BIT(2)
#define BIT_CTRLFLT1EN_FW_8197F BIT(1)
#define BIT_CTRLFLT0EN_FW_8197F BIT(0)
/* 2 REG_RXFLTMAP3_8197F (RX FILTER MAP GROUP 3) */
#define BIT_MGTFLT15EN_FW_8197F BIT(15)
#define BIT_MGTFLT14EN_FW_8197F BIT(14)
#define BIT_MGTFLT13EN_FW_8197F BIT(13)
#define BIT_MGTFLT12EN_FW_8197F BIT(12)
#define BIT_MGTFLT11EN_FW_8197F BIT(11)
#define BIT_MGTFLT10EN_FW_8197F BIT(10)
#define BIT_MGTFLT9EN_FW_8197F BIT(9)
#define BIT_MGTFLT8EN_FW_8197F BIT(8)
#define BIT_MGTFLT7EN_FW_8197F BIT(7)
#define BIT_MGTFLT6EN_FW_8197F BIT(6)
#define BIT_MGTFLT5EN_FW_8197F BIT(5)
#define BIT_MGTFLT4EN_FW_8197F BIT(4)
#define BIT_MGTFLT3EN_FW_8197F BIT(3)
#define BIT_MGTFLT2EN_FW_8197F BIT(2)
#define BIT_MGTFLT1EN_FW_8197F BIT(1)
#define BIT_MGTFLT0EN_FW_8197F BIT(0)
/* 2 REG_RXFLTMAP6_8197F (RX FILTER MAP GROUP 3) */
#define BIT_ACTIONFLT15EN_FW_8197F BIT(15)
#define BIT_ACTIONFLT14EN_FW_8197F BIT(14)
#define BIT_ACTIONFLT13EN_FW_8197F BIT(13)
#define BIT_ACTIONFLT12EN_FW_8197F BIT(12)
#define BIT_ACTIONFLT11EN_FW_8197F BIT(11)
#define BIT_ACTIONFLT10EN_FW_8197F BIT(10)
#define BIT_ACTIONFLT9EN_FW_8197F BIT(9)
#define BIT_ACTIONFLT8EN_FW_8197F BIT(8)
#define BIT_ACTIONFLT7EN_FW_8197F BIT(7)
#define BIT_ACTIONFLT6EN_FW_8197F BIT(6)
#define BIT_ACTIONFLT5EN_FW_8197F BIT(5)
#define BIT_ACTIONFLT4EN_FW_8197F BIT(4)
#define BIT_ACTIONFLT3EN_FW_8197F BIT(3)
#define BIT_ACTIONFLT2EN_FW_8197F BIT(2)
#define BIT_ACTIONFLT1EN_FW_8197F BIT(1)
#define BIT_ACTIONFLT0EN_FW_8197F BIT(0)
/* 2 REG_RXFLTMAP5_8197F (RX FILTER MAP GROUP 3) */
#define BIT_DATAFLT15EN_FW_8197F BIT(15)
#define BIT_DATAFLT14EN_FW_8197F BIT(14)
#define BIT_DATAFLT13EN_FW_8197F BIT(13)
#define BIT_DATAFLT12EN_FW_8197F BIT(12)
#define BIT_DATAFLT11EN_FW_8197F BIT(11)
#define BIT_DATAFLT10EN_FW_8197F BIT(10)
#define BIT_DATAFLT9EN_FW_8197F BIT(9)
#define BIT_DATAFLT8EN_FW_8197F BIT(8)
#define BIT_DATAFLT7EN_FW_8197F BIT(7)
#define BIT_DATAFLT6EN_FW_8197F BIT(6)
#define BIT_DATAFLT5EN_FW_8197F BIT(5)
#define BIT_DATAFLT4EN_FW_8197F BIT(4)
#define BIT_DATAFLT3EN_FW_8197F BIT(3)
#define BIT_DATAFLT2EN_FW_8197F BIT(2)
#define BIT_DATAFLT1EN_FW_8197F BIT(1)
#define BIT_DATAFLT0EN_FW_8197F BIT(0)
/* 2 REG_WMMPS_UAPSD_TID_8197F (WMM POWER SAVE UAPSD TID REGISTER) */
#define BIT_WMMPS_UAPSD_TID7_8197F BIT(7)
#define BIT_WMMPS_UAPSD_TID6_8197F BIT(6)
#define BIT_WMMPS_UAPSD_TID5_8197F BIT(5)
#define BIT_WMMPS_UAPSD_TID4_8197F BIT(4)
#define BIT_WMMPS_UAPSD_TID3_8197F BIT(3)
#define BIT_WMMPS_UAPSD_TID2_8197F BIT(2)
#define BIT_WMMPS_UAPSD_TID1_8197F BIT(1)
#define BIT_WMMPS_UAPSD_TID0_8197F BIT(0)
/* 2 REG_PS_RX_INFO_8197F (POWER SAVE RX INFORMATION REGISTER) */
#define BIT_SHIFT_PORTSEL__PS_RX_INFO_8197F 5
#define BIT_MASK_PORTSEL__PS_RX_INFO_8197F 0x7
#define BIT_PORTSEL__PS_RX_INFO_8197F(x) \
(((x) & BIT_MASK_PORTSEL__PS_RX_INFO_8197F) \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8197F)
#define BITS_PORTSEL__PS_RX_INFO_8197F \
(BIT_MASK_PORTSEL__PS_RX_INFO_8197F \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8197F)
#define BIT_CLEAR_PORTSEL__PS_RX_INFO_8197F(x) \
((x) & (~BITS_PORTSEL__PS_RX_INFO_8197F))
#define BIT_GET_PORTSEL__PS_RX_INFO_8197F(x) \
(((x) >> BIT_SHIFT_PORTSEL__PS_RX_INFO_8197F) & \
BIT_MASK_PORTSEL__PS_RX_INFO_8197F)
#define BIT_SET_PORTSEL__PS_RX_INFO_8197F(x, v) \
(BIT_CLEAR_PORTSEL__PS_RX_INFO_8197F(x) | \
BIT_PORTSEL__PS_RX_INFO_8197F(v))
#define BIT_RXCTRLIN0_8197F BIT(4)
#define BIT_RXMGTIN0_8197F BIT(3)
#define BIT_RXDATAIN2_8197F BIT(2)
#define BIT_RXDATAIN1_8197F BIT(1)
#define BIT_RXDATAIN0_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
#define BIT_CHK_TSF_TA_8197F BIT(2)
#define BIT_CHK_TSF_CBSSID_8197F BIT(1)
#define BIT_CHK_TSF_EN_8197F BIT(0)
/* 2 REG_WOW_CTRL_8197F (WAKE ON WLAN CONTROL REGISTER) */
#define BIT_SHIFT_PSF_BSSIDSEL_B2B1_8197F 6
#define BIT_MASK_PSF_BSSIDSEL_B2B1_8197F 0x3
#define BIT_PSF_BSSIDSEL_B2B1_8197F(x) \
(((x) & BIT_MASK_PSF_BSSIDSEL_B2B1_8197F) \
<< BIT_SHIFT_PSF_BSSIDSEL_B2B1_8197F)
#define BITS_PSF_BSSIDSEL_B2B1_8197F \
(BIT_MASK_PSF_BSSIDSEL_B2B1_8197F << BIT_SHIFT_PSF_BSSIDSEL_B2B1_8197F)
#define BIT_CLEAR_PSF_BSSIDSEL_B2B1_8197F(x) \
((x) & (~BITS_PSF_BSSIDSEL_B2B1_8197F))
#define BIT_GET_PSF_BSSIDSEL_B2B1_8197F(x) \
(((x) >> BIT_SHIFT_PSF_BSSIDSEL_B2B1_8197F) & \
BIT_MASK_PSF_BSSIDSEL_B2B1_8197F)
#define BIT_SET_PSF_BSSIDSEL_B2B1_8197F(x, v) \
(BIT_CLEAR_PSF_BSSIDSEL_B2B1_8197F(x) | BIT_PSF_BSSIDSEL_B2B1_8197F(v))
#define BIT_WOWHCI_8197F BIT(5)
#define BIT_PSF_BSSIDSEL_B0_8197F BIT(4)
#define BIT_UWF_8197F BIT(3)
#define BIT_MAGIC_8197F BIT(2)
#define BIT_WOWEN_8197F BIT(1)
#define BIT_FORCE_WAKEUP_8197F BIT(0)
/* 2 REG_LPNAV_CTRL_8197F (LOW POWER NAV CONTROL REGISTER) */
#define BIT_LPNAV_EN_8197F BIT(31)
#define BIT_SHIFT_LPNAV_EARLY_8197F 16
#define BIT_MASK_LPNAV_EARLY_8197F 0x7fff
#define BIT_LPNAV_EARLY_8197F(x) \
(((x) & BIT_MASK_LPNAV_EARLY_8197F) << BIT_SHIFT_LPNAV_EARLY_8197F)
#define BITS_LPNAV_EARLY_8197F \
(BIT_MASK_LPNAV_EARLY_8197F << BIT_SHIFT_LPNAV_EARLY_8197F)
#define BIT_CLEAR_LPNAV_EARLY_8197F(x) ((x) & (~BITS_LPNAV_EARLY_8197F))
#define BIT_GET_LPNAV_EARLY_8197F(x) \
(((x) >> BIT_SHIFT_LPNAV_EARLY_8197F) & BIT_MASK_LPNAV_EARLY_8197F)
#define BIT_SET_LPNAV_EARLY_8197F(x, v) \
(BIT_CLEAR_LPNAV_EARLY_8197F(x) | BIT_LPNAV_EARLY_8197F(v))
#define BIT_SHIFT_LPNAV_TH_8197F 0
#define BIT_MASK_LPNAV_TH_8197F 0xffff
#define BIT_LPNAV_TH_8197F(x) \
(((x) & BIT_MASK_LPNAV_TH_8197F) << BIT_SHIFT_LPNAV_TH_8197F)
#define BITS_LPNAV_TH_8197F \
(BIT_MASK_LPNAV_TH_8197F << BIT_SHIFT_LPNAV_TH_8197F)
#define BIT_CLEAR_LPNAV_TH_8197F(x) ((x) & (~BITS_LPNAV_TH_8197F))
#define BIT_GET_LPNAV_TH_8197F(x) \
(((x) >> BIT_SHIFT_LPNAV_TH_8197F) & BIT_MASK_LPNAV_TH_8197F)
#define BIT_SET_LPNAV_TH_8197F(x, v) \
(BIT_CLEAR_LPNAV_TH_8197F(x) | BIT_LPNAV_TH_8197F(v))
/* 2 REG_WKFMCAM_CMD_8197F (WAKEUP FRAME CAM COMMAND REGISTER) */
#define BIT_WKFCAM_POLLING_V1_8197F BIT(31)
#define BIT_WKFCAM_CLR_V1_8197F BIT(30)
#define BIT_WKFCAM_WE_8197F BIT(16)
#define BIT_SHIFT_WKFCAM_ADDR_V2_8197F 8
#define BIT_MASK_WKFCAM_ADDR_V2_8197F 0xff
#define BIT_WKFCAM_ADDR_V2_8197F(x) \
(((x) & BIT_MASK_WKFCAM_ADDR_V2_8197F) \
<< BIT_SHIFT_WKFCAM_ADDR_V2_8197F)
#define BITS_WKFCAM_ADDR_V2_8197F \
(BIT_MASK_WKFCAM_ADDR_V2_8197F << BIT_SHIFT_WKFCAM_ADDR_V2_8197F)
#define BIT_CLEAR_WKFCAM_ADDR_V2_8197F(x) ((x) & (~BITS_WKFCAM_ADDR_V2_8197F))
#define BIT_GET_WKFCAM_ADDR_V2_8197F(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR_V2_8197F) & \
BIT_MASK_WKFCAM_ADDR_V2_8197F)
#define BIT_SET_WKFCAM_ADDR_V2_8197F(x, v) \
(BIT_CLEAR_WKFCAM_ADDR_V2_8197F(x) | BIT_WKFCAM_ADDR_V2_8197F(v))
#define BIT_SHIFT_WKFCAM_CAM_NUM_V1_8197F 0
#define BIT_MASK_WKFCAM_CAM_NUM_V1_8197F 0xff
#define BIT_WKFCAM_CAM_NUM_V1_8197F(x) \
(((x) & BIT_MASK_WKFCAM_CAM_NUM_V1_8197F) \
<< BIT_SHIFT_WKFCAM_CAM_NUM_V1_8197F)
#define BITS_WKFCAM_CAM_NUM_V1_8197F \
(BIT_MASK_WKFCAM_CAM_NUM_V1_8197F << BIT_SHIFT_WKFCAM_CAM_NUM_V1_8197F)
#define BIT_CLEAR_WKFCAM_CAM_NUM_V1_8197F(x) \
((x) & (~BITS_WKFCAM_CAM_NUM_V1_8197F))
#define BIT_GET_WKFCAM_CAM_NUM_V1_8197F(x) \
(((x) >> BIT_SHIFT_WKFCAM_CAM_NUM_V1_8197F) & \
BIT_MASK_WKFCAM_CAM_NUM_V1_8197F)
#define BIT_SET_WKFCAM_CAM_NUM_V1_8197F(x, v) \
(BIT_CLEAR_WKFCAM_CAM_NUM_V1_8197F(x) | BIT_WKFCAM_CAM_NUM_V1_8197F(v))
/* 2 REG_WKFMCAM_RWD_8197F (WAKEUP FRAME READ/WRITE DATA) */
#define BIT_SHIFT_WKFMCAM_RWD_8197F 0
#define BIT_MASK_WKFMCAM_RWD_8197F 0xffffffffL
#define BIT_WKFMCAM_RWD_8197F(x) \
(((x) & BIT_MASK_WKFMCAM_RWD_8197F) << BIT_SHIFT_WKFMCAM_RWD_8197F)
#define BITS_WKFMCAM_RWD_8197F \
(BIT_MASK_WKFMCAM_RWD_8197F << BIT_SHIFT_WKFMCAM_RWD_8197F)
#define BIT_CLEAR_WKFMCAM_RWD_8197F(x) ((x) & (~BITS_WKFMCAM_RWD_8197F))
#define BIT_GET_WKFMCAM_RWD_8197F(x) \
(((x) >> BIT_SHIFT_WKFMCAM_RWD_8197F) & BIT_MASK_WKFMCAM_RWD_8197F)
#define BIT_SET_WKFMCAM_RWD_8197F(x, v) \
(BIT_CLEAR_WKFMCAM_RWD_8197F(x) | BIT_WKFMCAM_RWD_8197F(v))
/* 2 REG_RXFLTMAP1_8197F (RX FILTER MAP GROUP 1) */
#define BIT_CTRLFLT15EN_8197F BIT(15)
#define BIT_CTRLFLT14EN_8197F BIT(14)
#define BIT_CTRLFLT13EN_8197F BIT(13)
#define BIT_CTRLFLT12EN_8197F BIT(12)
#define BIT_CTRLFLT11EN_8197F BIT(11)
#define BIT_CTRLFLT10EN_8197F BIT(10)
#define BIT_CTRLFLT9EN_8197F BIT(9)
#define BIT_CTRLFLT8EN_8197F BIT(8)
#define BIT_CTRLFLT7EN_8197F BIT(7)
#define BIT_CTRLFLT6EN_8197F BIT(6)
#define BIT_CTRLFLT5EN_8197F BIT(5)
#define BIT_CTRLFLT4EN_8197F BIT(4)
#define BIT_CTRLFLT3EN_8197F BIT(3)
#define BIT_CTRLFLT2EN_8197F BIT(2)
#define BIT_CTRLFLT1EN_8197F BIT(1)
#define BIT_CTRLFLT0EN_8197F BIT(0)
/* 2 REG_RXFLTMAP0_8197F (RX FILTER MAP GROUP 0) */
#define BIT_MGTFLT15EN_8197F BIT(15)
#define BIT_MGTFLT14EN_8197F BIT(14)
#define BIT_MGTFLT13EN_8197F BIT(13)
#define BIT_MGTFLT12EN_8197F BIT(12)
#define BIT_MGTFLT11EN_8197F BIT(11)
#define BIT_MGTFLT10EN_8197F BIT(10)
#define BIT_MGTFLT9EN_8197F BIT(9)
#define BIT_MGTFLT8EN_8197F BIT(8)
#define BIT_MGTFLT7EN_8197F BIT(7)
#define BIT_MGTFLT6EN_8197F BIT(6)
#define BIT_MGTFLT5EN_8197F BIT(5)
#define BIT_MGTFLT4EN_8197F BIT(4)
#define BIT_MGTFLT3EN_8197F BIT(3)
#define BIT_MGTFLT2EN_8197F BIT(2)
#define BIT_MGTFLT1EN_8197F BIT(1)
#define BIT_MGTFLT0EN_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_RXFLTMAP_8197F (RX FILTER MAP GROUP 2) */
#define BIT_DATAFLT15EN_8197F BIT(15)
#define BIT_DATAFLT14EN_8197F BIT(14)
#define BIT_DATAFLT13EN_8197F BIT(13)
#define BIT_DATAFLT12EN_8197F BIT(12)
#define BIT_DATAFLT11EN_8197F BIT(11)
#define BIT_DATAFLT10EN_8197F BIT(10)
#define BIT_DATAFLT9EN_8197F BIT(9)
#define BIT_DATAFLT8EN_8197F BIT(8)
#define BIT_DATAFLT7EN_8197F BIT(7)
#define BIT_DATAFLT6EN_8197F BIT(6)
#define BIT_DATAFLT5EN_8197F BIT(5)
#define BIT_DATAFLT4EN_8197F BIT(4)
#define BIT_DATAFLT3EN_8197F BIT(3)
#define BIT_DATAFLT2EN_8197F BIT(2)
#define BIT_DATAFLT1EN_8197F BIT(1)
#define BIT_DATAFLT0EN_8197F BIT(0)
/* 2 REG_BCN_PSR_RPT_8197F (BEACON PARSER REPORT REGISTER) */
#define BIT_SHIFT_DTIM_CNT_8197F 24
#define BIT_MASK_DTIM_CNT_8197F 0xff
#define BIT_DTIM_CNT_8197F(x) \
(((x) & BIT_MASK_DTIM_CNT_8197F) << BIT_SHIFT_DTIM_CNT_8197F)
#define BITS_DTIM_CNT_8197F \
(BIT_MASK_DTIM_CNT_8197F << BIT_SHIFT_DTIM_CNT_8197F)
#define BIT_CLEAR_DTIM_CNT_8197F(x) ((x) & (~BITS_DTIM_CNT_8197F))
#define BIT_GET_DTIM_CNT_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_CNT_8197F) & BIT_MASK_DTIM_CNT_8197F)
#define BIT_SET_DTIM_CNT_8197F(x, v) \
(BIT_CLEAR_DTIM_CNT_8197F(x) | BIT_DTIM_CNT_8197F(v))
#define BIT_SHIFT_DTIM_PERIOD_8197F 16
#define BIT_MASK_DTIM_PERIOD_8197F 0xff
#define BIT_DTIM_PERIOD_8197F(x) \
(((x) & BIT_MASK_DTIM_PERIOD_8197F) << BIT_SHIFT_DTIM_PERIOD_8197F)
#define BITS_DTIM_PERIOD_8197F \
(BIT_MASK_DTIM_PERIOD_8197F << BIT_SHIFT_DTIM_PERIOD_8197F)
#define BIT_CLEAR_DTIM_PERIOD_8197F(x) ((x) & (~BITS_DTIM_PERIOD_8197F))
#define BIT_GET_DTIM_PERIOD_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD_8197F) & BIT_MASK_DTIM_PERIOD_8197F)
#define BIT_SET_DTIM_PERIOD_8197F(x, v) \
(BIT_CLEAR_DTIM_PERIOD_8197F(x) | BIT_DTIM_PERIOD_8197F(v))
#define BIT_DTIM_8197F BIT(15)
#define BIT_TIM_8197F BIT(14)
#define BIT_SHIFT_PS_AID_0_8197F 0
#define BIT_MASK_PS_AID_0_8197F 0x7ff
#define BIT_PS_AID_0_8197F(x) \
(((x) & BIT_MASK_PS_AID_0_8197F) << BIT_SHIFT_PS_AID_0_8197F)
#define BITS_PS_AID_0_8197F \
(BIT_MASK_PS_AID_0_8197F << BIT_SHIFT_PS_AID_0_8197F)
#define BIT_CLEAR_PS_AID_0_8197F(x) ((x) & (~BITS_PS_AID_0_8197F))
#define BIT_GET_PS_AID_0_8197F(x) \
(((x) >> BIT_SHIFT_PS_AID_0_8197F) & BIT_MASK_PS_AID_0_8197F)
#define BIT_SET_PS_AID_0_8197F(x, v) \
(BIT_CLEAR_PS_AID_0_8197F(x) | BIT_PS_AID_0_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_FLC_RPCT_V1_8197F BIT(7)
#define BIT_MODE_8197F BIT(6)
#define BIT_SHIFT_TRPCD_8197F 0
#define BIT_MASK_TRPCD_8197F 0x3f
#define BIT_TRPCD_8197F(x) \
(((x) & BIT_MASK_TRPCD_8197F) << BIT_SHIFT_TRPCD_8197F)
#define BITS_TRPCD_8197F (BIT_MASK_TRPCD_8197F << BIT_SHIFT_TRPCD_8197F)
#define BIT_CLEAR_TRPCD_8197F(x) ((x) & (~BITS_TRPCD_8197F))
#define BIT_GET_TRPCD_8197F(x) \
(((x) >> BIT_SHIFT_TRPCD_8197F) & BIT_MASK_TRPCD_8197F)
#define BIT_SET_TRPCD_8197F(x, v) \
(BIT_CLEAR_TRPCD_8197F(x) | BIT_TRPCD_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_CMF_8197F BIT(2)
#define BIT_CCF_8197F BIT(1)
#define BIT_CDF_8197F BIT(0)
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_FLC_RPCT_8197F 0
#define BIT_MASK_FLC_RPCT_8197F 0xff
#define BIT_FLC_RPCT_8197F(x) \
(((x) & BIT_MASK_FLC_RPCT_8197F) << BIT_SHIFT_FLC_RPCT_8197F)
#define BITS_FLC_RPCT_8197F \
(BIT_MASK_FLC_RPCT_8197F << BIT_SHIFT_FLC_RPCT_8197F)
#define BIT_CLEAR_FLC_RPCT_8197F(x) ((x) & (~BITS_FLC_RPCT_8197F))
#define BIT_GET_FLC_RPCT_8197F(x) \
(((x) >> BIT_SHIFT_FLC_RPCT_8197F) & BIT_MASK_FLC_RPCT_8197F)
#define BIT_SET_FLC_RPCT_8197F(x, v) \
(BIT_CLEAR_FLC_RPCT_8197F(x) | BIT_FLC_RPCT_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_SHIFT_FLC_RPC_8197F 0
#define BIT_MASK_FLC_RPC_8197F 0xff
#define BIT_FLC_RPC_8197F(x) \
(((x) & BIT_MASK_FLC_RPC_8197F) << BIT_SHIFT_FLC_RPC_8197F)
#define BITS_FLC_RPC_8197F (BIT_MASK_FLC_RPC_8197F << BIT_SHIFT_FLC_RPC_8197F)
#define BIT_CLEAR_FLC_RPC_8197F(x) ((x) & (~BITS_FLC_RPC_8197F))
#define BIT_GET_FLC_RPC_8197F(x) \
(((x) >> BIT_SHIFT_FLC_RPC_8197F) & BIT_MASK_FLC_RPC_8197F)
#define BIT_SET_FLC_RPC_8197F(x, v) \
(BIT_CLEAR_FLC_RPC_8197F(x) | BIT_FLC_RPC_8197F(v))
/* 2 REG_RXPKTMON_CTRL_8197F */
#define BIT_SHIFT_RXBKQPKT_SEQ_8197F 20
#define BIT_MASK_RXBKQPKT_SEQ_8197F 0xf
#define BIT_RXBKQPKT_SEQ_8197F(x) \
(((x) & BIT_MASK_RXBKQPKT_SEQ_8197F) << BIT_SHIFT_RXBKQPKT_SEQ_8197F)
#define BITS_RXBKQPKT_SEQ_8197F \
(BIT_MASK_RXBKQPKT_SEQ_8197F << BIT_SHIFT_RXBKQPKT_SEQ_8197F)
#define BIT_CLEAR_RXBKQPKT_SEQ_8197F(x) ((x) & (~BITS_RXBKQPKT_SEQ_8197F))
#define BIT_GET_RXBKQPKT_SEQ_8197F(x) \
(((x) >> BIT_SHIFT_RXBKQPKT_SEQ_8197F) & BIT_MASK_RXBKQPKT_SEQ_8197F)
#define BIT_SET_RXBKQPKT_SEQ_8197F(x, v) \
(BIT_CLEAR_RXBKQPKT_SEQ_8197F(x) | BIT_RXBKQPKT_SEQ_8197F(v))
#define BIT_SHIFT_RXBEQPKT_SEQ_8197F 16
#define BIT_MASK_RXBEQPKT_SEQ_8197F 0xf
#define BIT_RXBEQPKT_SEQ_8197F(x) \
(((x) & BIT_MASK_RXBEQPKT_SEQ_8197F) << BIT_SHIFT_RXBEQPKT_SEQ_8197F)
#define BITS_RXBEQPKT_SEQ_8197F \
(BIT_MASK_RXBEQPKT_SEQ_8197F << BIT_SHIFT_RXBEQPKT_SEQ_8197F)
#define BIT_CLEAR_RXBEQPKT_SEQ_8197F(x) ((x) & (~BITS_RXBEQPKT_SEQ_8197F))
#define BIT_GET_RXBEQPKT_SEQ_8197F(x) \
(((x) >> BIT_SHIFT_RXBEQPKT_SEQ_8197F) & BIT_MASK_RXBEQPKT_SEQ_8197F)
#define BIT_SET_RXBEQPKT_SEQ_8197F(x, v) \
(BIT_CLEAR_RXBEQPKT_SEQ_8197F(x) | BIT_RXBEQPKT_SEQ_8197F(v))
#define BIT_SHIFT_RXVIQPKT_SEQ_8197F 12
#define BIT_MASK_RXVIQPKT_SEQ_8197F 0xf
#define BIT_RXVIQPKT_SEQ_8197F(x) \
(((x) & BIT_MASK_RXVIQPKT_SEQ_8197F) << BIT_SHIFT_RXVIQPKT_SEQ_8197F)
#define BITS_RXVIQPKT_SEQ_8197F \
(BIT_MASK_RXVIQPKT_SEQ_8197F << BIT_SHIFT_RXVIQPKT_SEQ_8197F)
#define BIT_CLEAR_RXVIQPKT_SEQ_8197F(x) ((x) & (~BITS_RXVIQPKT_SEQ_8197F))
#define BIT_GET_RXVIQPKT_SEQ_8197F(x) \
(((x) >> BIT_SHIFT_RXVIQPKT_SEQ_8197F) & BIT_MASK_RXVIQPKT_SEQ_8197F)
#define BIT_SET_RXVIQPKT_SEQ_8197F(x, v) \
(BIT_CLEAR_RXVIQPKT_SEQ_8197F(x) | BIT_RXVIQPKT_SEQ_8197F(v))
#define BIT_SHIFT_RXVOQPKT_SEQ_8197F 8
#define BIT_MASK_RXVOQPKT_SEQ_8197F 0xf
#define BIT_RXVOQPKT_SEQ_8197F(x) \
(((x) & BIT_MASK_RXVOQPKT_SEQ_8197F) << BIT_SHIFT_RXVOQPKT_SEQ_8197F)
#define BITS_RXVOQPKT_SEQ_8197F \
(BIT_MASK_RXVOQPKT_SEQ_8197F << BIT_SHIFT_RXVOQPKT_SEQ_8197F)
#define BIT_CLEAR_RXVOQPKT_SEQ_8197F(x) ((x) & (~BITS_RXVOQPKT_SEQ_8197F))
#define BIT_GET_RXVOQPKT_SEQ_8197F(x) \
(((x) >> BIT_SHIFT_RXVOQPKT_SEQ_8197F) & BIT_MASK_RXVOQPKT_SEQ_8197F)
#define BIT_SET_RXVOQPKT_SEQ_8197F(x, v) \
(BIT_CLEAR_RXVOQPKT_SEQ_8197F(x) | BIT_RXVOQPKT_SEQ_8197F(v))
#define BIT_RXBKQPKT_ERR_8197F BIT(7)
#define BIT_RXBEQPKT_ERR_8197F BIT(6)
#define BIT_RXVIQPKT_ERR_8197F BIT(5)
#define BIT_RXVOQPKT_ERR_8197F BIT(4)
#define BIT_RXDMA_MON_EN_8197F BIT(2)
#define BIT_RXPKT_MON_RST_8197F BIT(1)
#define BIT_RXPKT_MON_EN_8197F BIT(0)
/* 2 REG_STATE_MON_8197F */
#define BIT_SHIFT_STATE_SEL_8197F 24
#define BIT_MASK_STATE_SEL_8197F 0x1f
#define BIT_STATE_SEL_8197F(x) \
(((x) & BIT_MASK_STATE_SEL_8197F) << BIT_SHIFT_STATE_SEL_8197F)
#define BITS_STATE_SEL_8197F \
(BIT_MASK_STATE_SEL_8197F << BIT_SHIFT_STATE_SEL_8197F)
#define BIT_CLEAR_STATE_SEL_8197F(x) ((x) & (~BITS_STATE_SEL_8197F))
#define BIT_GET_STATE_SEL_8197F(x) \
(((x) >> BIT_SHIFT_STATE_SEL_8197F) & BIT_MASK_STATE_SEL_8197F)
#define BIT_SET_STATE_SEL_8197F(x, v) \
(BIT_CLEAR_STATE_SEL_8197F(x) | BIT_STATE_SEL_8197F(v))
#define BIT_SHIFT_STATE_INFO_8197F 8
#define BIT_MASK_STATE_INFO_8197F 0xff
#define BIT_STATE_INFO_8197F(x) \
(((x) & BIT_MASK_STATE_INFO_8197F) << BIT_SHIFT_STATE_INFO_8197F)
#define BITS_STATE_INFO_8197F \
(BIT_MASK_STATE_INFO_8197F << BIT_SHIFT_STATE_INFO_8197F)
#define BIT_CLEAR_STATE_INFO_8197F(x) ((x) & (~BITS_STATE_INFO_8197F))
#define BIT_GET_STATE_INFO_8197F(x) \
(((x) >> BIT_SHIFT_STATE_INFO_8197F) & BIT_MASK_STATE_INFO_8197F)
#define BIT_SET_STATE_INFO_8197F(x, v) \
(BIT_CLEAR_STATE_INFO_8197F(x) | BIT_STATE_INFO_8197F(v))
#define BIT_UPD_NXT_STATE_8197F BIT(7)
#define BIT_SHIFT_CUR_STATE_8197F 0
#define BIT_MASK_CUR_STATE_8197F 0x7f
#define BIT_CUR_STATE_8197F(x) \
(((x) & BIT_MASK_CUR_STATE_8197F) << BIT_SHIFT_CUR_STATE_8197F)
#define BITS_CUR_STATE_8197F \
(BIT_MASK_CUR_STATE_8197F << BIT_SHIFT_CUR_STATE_8197F)
#define BIT_CLEAR_CUR_STATE_8197F(x) ((x) & (~BITS_CUR_STATE_8197F))
#define BIT_GET_CUR_STATE_8197F(x) \
(((x) >> BIT_SHIFT_CUR_STATE_8197F) & BIT_MASK_CUR_STATE_8197F)
#define BIT_SET_CUR_STATE_8197F(x, v) \
(BIT_CLEAR_CUR_STATE_8197F(x) | BIT_CUR_STATE_8197F(v))
/* 2 REG_ERROR_MON_8197F */
#define BIT_MACRX_ERR_1_8197F BIT(17)
#define BIT_MACRX_ERR_0_8197F BIT(16)
#define BIT_MACTX_ERR_3_8197F BIT(3)
#define BIT_MACTX_ERR_2_8197F BIT(2)
#define BIT_MACTX_ERR_1_8197F BIT(1)
#define BIT_MACTX_ERR_0_8197F BIT(0)
/* 2 REG_SEARCH_MACID_8197F */
#define BIT_EN_TXRPTBUF_CLK_8197F BIT(31)
#define BIT_SHIFT_INFO_INDEX_OFFSET_8197F 16
#define BIT_MASK_INFO_INDEX_OFFSET_8197F 0x1fff
#define BIT_INFO_INDEX_OFFSET_8197F(x) \
(((x) & BIT_MASK_INFO_INDEX_OFFSET_8197F) \
<< BIT_SHIFT_INFO_INDEX_OFFSET_8197F)
#define BITS_INFO_INDEX_OFFSET_8197F \
(BIT_MASK_INFO_INDEX_OFFSET_8197F << BIT_SHIFT_INFO_INDEX_OFFSET_8197F)
#define BIT_CLEAR_INFO_INDEX_OFFSET_8197F(x) \
((x) & (~BITS_INFO_INDEX_OFFSET_8197F))
#define BIT_GET_INFO_INDEX_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_INFO_INDEX_OFFSET_8197F) & \
BIT_MASK_INFO_INDEX_OFFSET_8197F)
#define BIT_SET_INFO_INDEX_OFFSET_8197F(x, v) \
(BIT_CLEAR_INFO_INDEX_OFFSET_8197F(x) | BIT_INFO_INDEX_OFFSET_8197F(v))
#define BIT_DIS_INFOSRCH_8197F BIT(14)
#define BIT_DISABLE_B0_8197F BIT(13)
#define BIT_SHIFT_INFO_ADDR_OFFSET_8197F 0
#define BIT_MASK_INFO_ADDR_OFFSET_8197F 0x1fff
#define BIT_INFO_ADDR_OFFSET_8197F(x) \
(((x) & BIT_MASK_INFO_ADDR_OFFSET_8197F) \
<< BIT_SHIFT_INFO_ADDR_OFFSET_8197F)
#define BITS_INFO_ADDR_OFFSET_8197F \
(BIT_MASK_INFO_ADDR_OFFSET_8197F << BIT_SHIFT_INFO_ADDR_OFFSET_8197F)
#define BIT_CLEAR_INFO_ADDR_OFFSET_8197F(x) \
((x) & (~BITS_INFO_ADDR_OFFSET_8197F))
#define BIT_GET_INFO_ADDR_OFFSET_8197F(x) \
(((x) >> BIT_SHIFT_INFO_ADDR_OFFSET_8197F) & \
BIT_MASK_INFO_ADDR_OFFSET_8197F)
#define BIT_SET_INFO_ADDR_OFFSET_8197F(x, v) \
(BIT_CLEAR_INFO_ADDR_OFFSET_8197F(x) | BIT_INFO_ADDR_OFFSET_8197F(v))
/* 2 REG_BT_COEX_TABLE_8197F (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_PRI_MASK_RX_RESP_8197F BIT(126)
#define BIT_PRI_MASK_RXOFDM_8197F BIT(125)
#define BIT_PRI_MASK_RXCCK_8197F BIT(124)
#define BIT_SHIFT_PRI_MASK_TXAC_8197F (117 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_TXAC_8197F 0x7f
#define BIT_PRI_MASK_TXAC_8197F(x) \
(((x) & BIT_MASK_PRI_MASK_TXAC_8197F) << BIT_SHIFT_PRI_MASK_TXAC_8197F)
#define BITS_PRI_MASK_TXAC_8197F \
(BIT_MASK_PRI_MASK_TXAC_8197F << BIT_SHIFT_PRI_MASK_TXAC_8197F)
#define BIT_CLEAR_PRI_MASK_TXAC_8197F(x) ((x) & (~BITS_PRI_MASK_TXAC_8197F))
#define BIT_GET_PRI_MASK_TXAC_8197F(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TXAC_8197F) & BIT_MASK_PRI_MASK_TXAC_8197F)
#define BIT_SET_PRI_MASK_TXAC_8197F(x, v) \
(BIT_CLEAR_PRI_MASK_TXAC_8197F(x) | BIT_PRI_MASK_TXAC_8197F(v))
#define BIT_SHIFT_PRI_MASK_NAV_8197F (109 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_NAV_8197F 0xff
#define BIT_PRI_MASK_NAV_8197F(x) \
(((x) & BIT_MASK_PRI_MASK_NAV_8197F) << BIT_SHIFT_PRI_MASK_NAV_8197F)
#define BITS_PRI_MASK_NAV_8197F \
(BIT_MASK_PRI_MASK_NAV_8197F << BIT_SHIFT_PRI_MASK_NAV_8197F)
#define BIT_CLEAR_PRI_MASK_NAV_8197F(x) ((x) & (~BITS_PRI_MASK_NAV_8197F))
#define BIT_GET_PRI_MASK_NAV_8197F(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NAV_8197F) & BIT_MASK_PRI_MASK_NAV_8197F)
#define BIT_SET_PRI_MASK_NAV_8197F(x, v) \
(BIT_CLEAR_PRI_MASK_NAV_8197F(x) | BIT_PRI_MASK_NAV_8197F(v))
#define BIT_PRI_MASK_CCK_8197F BIT(108)
#define BIT_PRI_MASK_OFDM_8197F BIT(107)
#define BIT_PRI_MASK_RTY_8197F BIT(106)
#define BIT_SHIFT_PRI_MASK_NUM_8197F (102 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_NUM_8197F 0xf
#define BIT_PRI_MASK_NUM_8197F(x) \
(((x) & BIT_MASK_PRI_MASK_NUM_8197F) << BIT_SHIFT_PRI_MASK_NUM_8197F)
#define BITS_PRI_MASK_NUM_8197F \
(BIT_MASK_PRI_MASK_NUM_8197F << BIT_SHIFT_PRI_MASK_NUM_8197F)
#define BIT_CLEAR_PRI_MASK_NUM_8197F(x) ((x) & (~BITS_PRI_MASK_NUM_8197F))
#define BIT_GET_PRI_MASK_NUM_8197F(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NUM_8197F) & BIT_MASK_PRI_MASK_NUM_8197F)
#define BIT_SET_PRI_MASK_NUM_8197F(x, v) \
(BIT_CLEAR_PRI_MASK_NUM_8197F(x) | BIT_PRI_MASK_NUM_8197F(v))
#define BIT_SHIFT_PRI_MASK_TYPE_8197F (98 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_TYPE_8197F 0xf
#define BIT_PRI_MASK_TYPE_8197F(x) \
(((x) & BIT_MASK_PRI_MASK_TYPE_8197F) << BIT_SHIFT_PRI_MASK_TYPE_8197F)
#define BITS_PRI_MASK_TYPE_8197F \
(BIT_MASK_PRI_MASK_TYPE_8197F << BIT_SHIFT_PRI_MASK_TYPE_8197F)
#define BIT_CLEAR_PRI_MASK_TYPE_8197F(x) ((x) & (~BITS_PRI_MASK_TYPE_8197F))
#define BIT_GET_PRI_MASK_TYPE_8197F(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TYPE_8197F) & BIT_MASK_PRI_MASK_TYPE_8197F)
#define BIT_SET_PRI_MASK_TYPE_8197F(x, v) \
(BIT_CLEAR_PRI_MASK_TYPE_8197F(x) | BIT_PRI_MASK_TYPE_8197F(v))
#define BIT_OOB_8197F BIT(97)
#define BIT_ANT_SEL_8197F BIT(96)
#define BIT_SHIFT_BREAK_TABLE_2_8197F (80 & CPU_OPT_WIDTH)
#define BIT_MASK_BREAK_TABLE_2_8197F 0xffff
#define BIT_BREAK_TABLE_2_8197F(x) \
(((x) & BIT_MASK_BREAK_TABLE_2_8197F) << BIT_SHIFT_BREAK_TABLE_2_8197F)
#define BITS_BREAK_TABLE_2_8197F \
(BIT_MASK_BREAK_TABLE_2_8197F << BIT_SHIFT_BREAK_TABLE_2_8197F)
#define BIT_CLEAR_BREAK_TABLE_2_8197F(x) ((x) & (~BITS_BREAK_TABLE_2_8197F))
#define BIT_GET_BREAK_TABLE_2_8197F(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_2_8197F) & BIT_MASK_BREAK_TABLE_2_8197F)
#define BIT_SET_BREAK_TABLE_2_8197F(x, v) \
(BIT_CLEAR_BREAK_TABLE_2_8197F(x) | BIT_BREAK_TABLE_2_8197F(v))
#define BIT_SHIFT_BREAK_TABLE_1_8197F (64 & CPU_OPT_WIDTH)
#define BIT_MASK_BREAK_TABLE_1_8197F 0xffff
#define BIT_BREAK_TABLE_1_8197F(x) \
(((x) & BIT_MASK_BREAK_TABLE_1_8197F) << BIT_SHIFT_BREAK_TABLE_1_8197F)
#define BITS_BREAK_TABLE_1_8197F \
(BIT_MASK_BREAK_TABLE_1_8197F << BIT_SHIFT_BREAK_TABLE_1_8197F)
#define BIT_CLEAR_BREAK_TABLE_1_8197F(x) ((x) & (~BITS_BREAK_TABLE_1_8197F))
#define BIT_GET_BREAK_TABLE_1_8197F(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_1_8197F) & BIT_MASK_BREAK_TABLE_1_8197F)
#define BIT_SET_BREAK_TABLE_1_8197F(x, v) \
(BIT_CLEAR_BREAK_TABLE_1_8197F(x) | BIT_BREAK_TABLE_1_8197F(v))
#define BIT_SHIFT_COEX_TABLE_2_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_COEX_TABLE_2_8197F 0xffffffffL
#define BIT_COEX_TABLE_2_8197F(x) \
(((x) & BIT_MASK_COEX_TABLE_2_8197F) << BIT_SHIFT_COEX_TABLE_2_8197F)
#define BITS_COEX_TABLE_2_8197F \
(BIT_MASK_COEX_TABLE_2_8197F << BIT_SHIFT_COEX_TABLE_2_8197F)
#define BIT_CLEAR_COEX_TABLE_2_8197F(x) ((x) & (~BITS_COEX_TABLE_2_8197F))
#define BIT_GET_COEX_TABLE_2_8197F(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_2_8197F) & BIT_MASK_COEX_TABLE_2_8197F)
#define BIT_SET_COEX_TABLE_2_8197F(x, v) \
(BIT_CLEAR_COEX_TABLE_2_8197F(x) | BIT_COEX_TABLE_2_8197F(v))
#define BIT_SHIFT_COEX_TABLE_1_8197F 0
#define BIT_MASK_COEX_TABLE_1_8197F 0xffffffffL
#define BIT_COEX_TABLE_1_8197F(x) \
(((x) & BIT_MASK_COEX_TABLE_1_8197F) << BIT_SHIFT_COEX_TABLE_1_8197F)
#define BITS_COEX_TABLE_1_8197F \
(BIT_MASK_COEX_TABLE_1_8197F << BIT_SHIFT_COEX_TABLE_1_8197F)
#define BIT_CLEAR_COEX_TABLE_1_8197F(x) ((x) & (~BITS_COEX_TABLE_1_8197F))
#define BIT_GET_COEX_TABLE_1_8197F(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_1_8197F) & BIT_MASK_COEX_TABLE_1_8197F)
#define BIT_SET_COEX_TABLE_1_8197F(x, v) \
(BIT_CLEAR_COEX_TABLE_1_8197F(x) | BIT_COEX_TABLE_1_8197F(v))
/* 2 REG_RXCMD_0_8197F */
#define BIT_RXCMD_EN_8197F BIT(31)
#define BIT_SHIFT_RXCMD_INFO_8197F 0
#define BIT_MASK_RXCMD_INFO_8197F 0x7fffffffL
#define BIT_RXCMD_INFO_8197F(x) \
(((x) & BIT_MASK_RXCMD_INFO_8197F) << BIT_SHIFT_RXCMD_INFO_8197F)
#define BITS_RXCMD_INFO_8197F \
(BIT_MASK_RXCMD_INFO_8197F << BIT_SHIFT_RXCMD_INFO_8197F)
#define BIT_CLEAR_RXCMD_INFO_8197F(x) ((x) & (~BITS_RXCMD_INFO_8197F))
#define BIT_GET_RXCMD_INFO_8197F(x) \
(((x) >> BIT_SHIFT_RXCMD_INFO_8197F) & BIT_MASK_RXCMD_INFO_8197F)
#define BIT_SET_RXCMD_INFO_8197F(x, v) \
(BIT_CLEAR_RXCMD_INFO_8197F(x) | BIT_RXCMD_INFO_8197F(v))
/* 2 REG_RXCMD_1_8197F */
#define BIT_SHIFT_RXCMD_PRD_8197F 0
#define BIT_MASK_RXCMD_PRD_8197F 0xffff
#define BIT_RXCMD_PRD_8197F(x) \
(((x) & BIT_MASK_RXCMD_PRD_8197F) << BIT_SHIFT_RXCMD_PRD_8197F)
#define BITS_RXCMD_PRD_8197F \
(BIT_MASK_RXCMD_PRD_8197F << BIT_SHIFT_RXCMD_PRD_8197F)
#define BIT_CLEAR_RXCMD_PRD_8197F(x) ((x) & (~BITS_RXCMD_PRD_8197F))
#define BIT_GET_RXCMD_PRD_8197F(x) \
(((x) >> BIT_SHIFT_RXCMD_PRD_8197F) & BIT_MASK_RXCMD_PRD_8197F)
#define BIT_SET_RXCMD_PRD_8197F(x, v) \
(BIT_CLEAR_RXCMD_PRD_8197F(x) | BIT_RXCMD_PRD_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_WMAC_RESP_TXINFO_8197F (RESPONSE TXINFO REGISTER) */
#define BIT_SHIFT_WMAC_RESP_MFB_8197F 25
#define BIT_MASK_WMAC_RESP_MFB_8197F 0x7f
#define BIT_WMAC_RESP_MFB_8197F(x) \
(((x) & BIT_MASK_WMAC_RESP_MFB_8197F) << BIT_SHIFT_WMAC_RESP_MFB_8197F)
#define BITS_WMAC_RESP_MFB_8197F \
(BIT_MASK_WMAC_RESP_MFB_8197F << BIT_SHIFT_WMAC_RESP_MFB_8197F)
#define BIT_CLEAR_WMAC_RESP_MFB_8197F(x) ((x) & (~BITS_WMAC_RESP_MFB_8197F))
#define BIT_GET_WMAC_RESP_MFB_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_MFB_8197F) & BIT_MASK_WMAC_RESP_MFB_8197F)
#define BIT_SET_WMAC_RESP_MFB_8197F(x, v) \
(BIT_CLEAR_WMAC_RESP_MFB_8197F(x) | BIT_WMAC_RESP_MFB_8197F(v))
#define BIT_SHIFT_WMAC_ANTINF_SEL_8197F 23
#define BIT_MASK_WMAC_ANTINF_SEL_8197F 0x3
#define BIT_WMAC_ANTINF_SEL_8197F(x) \
(((x) & BIT_MASK_WMAC_ANTINF_SEL_8197F) \
<< BIT_SHIFT_WMAC_ANTINF_SEL_8197F)
#define BITS_WMAC_ANTINF_SEL_8197F \
(BIT_MASK_WMAC_ANTINF_SEL_8197F << BIT_SHIFT_WMAC_ANTINF_SEL_8197F)
#define BIT_CLEAR_WMAC_ANTINF_SEL_8197F(x) ((x) & (~BITS_WMAC_ANTINF_SEL_8197F))
#define BIT_GET_WMAC_ANTINF_SEL_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_ANTINF_SEL_8197F) & \
BIT_MASK_WMAC_ANTINF_SEL_8197F)
#define BIT_SET_WMAC_ANTINF_SEL_8197F(x, v) \
(BIT_CLEAR_WMAC_ANTINF_SEL_8197F(x) | BIT_WMAC_ANTINF_SEL_8197F(v))
#define BIT_SHIFT_WMAC_ANTSEL_SEL_8197F 21
#define BIT_MASK_WMAC_ANTSEL_SEL_8197F 0x3
#define BIT_WMAC_ANTSEL_SEL_8197F(x) \
(((x) & BIT_MASK_WMAC_ANTSEL_SEL_8197F) \
<< BIT_SHIFT_WMAC_ANTSEL_SEL_8197F)
#define BITS_WMAC_ANTSEL_SEL_8197F \
(BIT_MASK_WMAC_ANTSEL_SEL_8197F << BIT_SHIFT_WMAC_ANTSEL_SEL_8197F)
#define BIT_CLEAR_WMAC_ANTSEL_SEL_8197F(x) ((x) & (~BITS_WMAC_ANTSEL_SEL_8197F))
#define BIT_GET_WMAC_ANTSEL_SEL_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_ANTSEL_SEL_8197F) & \
BIT_MASK_WMAC_ANTSEL_SEL_8197F)
#define BIT_SET_WMAC_ANTSEL_SEL_8197F(x, v) \
(BIT_CLEAR_WMAC_ANTSEL_SEL_8197F(x) | BIT_WMAC_ANTSEL_SEL_8197F(v))
#define BIT_SHIFT_R_WMAC_RESP_TXPOWER_8197F 18
#define BIT_MASK_R_WMAC_RESP_TXPOWER_8197F 0x7
#define BIT_R_WMAC_RESP_TXPOWER_8197F(x) \
(((x) & BIT_MASK_R_WMAC_RESP_TXPOWER_8197F) \
<< BIT_SHIFT_R_WMAC_RESP_TXPOWER_8197F)
#define BITS_R_WMAC_RESP_TXPOWER_8197F \
(BIT_MASK_R_WMAC_RESP_TXPOWER_8197F \
<< BIT_SHIFT_R_WMAC_RESP_TXPOWER_8197F)
#define BIT_CLEAR_R_WMAC_RESP_TXPOWER_8197F(x) \
((x) & (~BITS_R_WMAC_RESP_TXPOWER_8197F))
#define BIT_GET_R_WMAC_RESP_TXPOWER_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_RESP_TXPOWER_8197F) & \
BIT_MASK_R_WMAC_RESP_TXPOWER_8197F)
#define BIT_SET_R_WMAC_RESP_TXPOWER_8197F(x, v) \
(BIT_CLEAR_R_WMAC_RESP_TXPOWER_8197F(x) | \
BIT_R_WMAC_RESP_TXPOWER_8197F(v))
#define BIT_SHIFT_WMAC_RESP_TXANT_8197F 0
#define BIT_MASK_WMAC_RESP_TXANT_8197F 0x3ffff
#define BIT_WMAC_RESP_TXANT_8197F(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT_8197F) \
<< BIT_SHIFT_WMAC_RESP_TXANT_8197F)
#define BITS_WMAC_RESP_TXANT_8197F \
(BIT_MASK_WMAC_RESP_TXANT_8197F << BIT_SHIFT_WMAC_RESP_TXANT_8197F)
#define BIT_CLEAR_WMAC_RESP_TXANT_8197F(x) ((x) & (~BITS_WMAC_RESP_TXANT_8197F))
#define BIT_GET_WMAC_RESP_TXANT_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT_8197F) & \
BIT_MASK_WMAC_RESP_TXANT_8197F)
#define BIT_SET_WMAC_RESP_TXANT_8197F(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT_8197F(x) | BIT_WMAC_RESP_TXANT_8197F(v))
/* 2 REG_BBPSF_CTRL_8197F */
#define BIT_CTL_IDLE_CLR_CSI_RPT_8197F BIT(31)
#define BIT_WMAC_USE_NDPARATE_8197F BIT(30)
#define BIT_SHIFT_WMAC_CSI_RATE_8197F 24
#define BIT_MASK_WMAC_CSI_RATE_8197F 0x3f
#define BIT_WMAC_CSI_RATE_8197F(x) \
(((x) & BIT_MASK_WMAC_CSI_RATE_8197F) << BIT_SHIFT_WMAC_CSI_RATE_8197F)
#define BITS_WMAC_CSI_RATE_8197F \
(BIT_MASK_WMAC_CSI_RATE_8197F << BIT_SHIFT_WMAC_CSI_RATE_8197F)
#define BIT_CLEAR_WMAC_CSI_RATE_8197F(x) ((x) & (~BITS_WMAC_CSI_RATE_8197F))
#define BIT_GET_WMAC_CSI_RATE_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RATE_8197F) & BIT_MASK_WMAC_CSI_RATE_8197F)
#define BIT_SET_WMAC_CSI_RATE_8197F(x, v) \
(BIT_CLEAR_WMAC_CSI_RATE_8197F(x) | BIT_WMAC_CSI_RATE_8197F(v))
#define BIT_SHIFT_WMAC_RESP_TXRATE_8197F 16
#define BIT_MASK_WMAC_RESP_TXRATE_8197F 0xff
#define BIT_WMAC_RESP_TXRATE_8197F(x) \
(((x) & BIT_MASK_WMAC_RESP_TXRATE_8197F) \
<< BIT_SHIFT_WMAC_RESP_TXRATE_8197F)
#define BITS_WMAC_RESP_TXRATE_8197F \
(BIT_MASK_WMAC_RESP_TXRATE_8197F << BIT_SHIFT_WMAC_RESP_TXRATE_8197F)
#define BIT_CLEAR_WMAC_RESP_TXRATE_8197F(x) \
((x) & (~BITS_WMAC_RESP_TXRATE_8197F))
#define BIT_GET_WMAC_RESP_TXRATE_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXRATE_8197F) & \
BIT_MASK_WMAC_RESP_TXRATE_8197F)
#define BIT_SET_WMAC_RESP_TXRATE_8197F(x, v) \
(BIT_CLEAR_WMAC_RESP_TXRATE_8197F(x) | BIT_WMAC_RESP_TXRATE_8197F(v))
#define BIT_BBPSF_MPDUCHKEN_8197F BIT(5)
#define BIT_BBPSF_MHCHKEN_8197F BIT(4)
#define BIT_BBPSF_ERRCHKEN_8197F BIT(3)
#define BIT_SHIFT_BBPSF_ERRTHR_8197F 0
#define BIT_MASK_BBPSF_ERRTHR_8197F 0x7
#define BIT_BBPSF_ERRTHR_8197F(x) \
(((x) & BIT_MASK_BBPSF_ERRTHR_8197F) << BIT_SHIFT_BBPSF_ERRTHR_8197F)
#define BITS_BBPSF_ERRTHR_8197F \
(BIT_MASK_BBPSF_ERRTHR_8197F << BIT_SHIFT_BBPSF_ERRTHR_8197F)
#define BIT_CLEAR_BBPSF_ERRTHR_8197F(x) ((x) & (~BITS_BBPSF_ERRTHR_8197F))
#define BIT_GET_BBPSF_ERRTHR_8197F(x) \
(((x) >> BIT_SHIFT_BBPSF_ERRTHR_8197F) & BIT_MASK_BBPSF_ERRTHR_8197F)
#define BIT_SET_BBPSF_ERRTHR_8197F(x, v) \
(BIT_CLEAR_BBPSF_ERRTHR_8197F(x) | BIT_BBPSF_ERRTHR_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_P2P_RX_BCN_NOA_8197F (P2P RX BEACON NOA REGISTER) */
#define BIT_NOA_PARSER_EN_8197F BIT(15)
#define BIT_SHIFT_BSSID_SEL_V1_8197F 12
#define BIT_MASK_BSSID_SEL_V1_8197F 0x7
#define BIT_BSSID_SEL_V1_8197F(x) \
(((x) & BIT_MASK_BSSID_SEL_V1_8197F) << BIT_SHIFT_BSSID_SEL_V1_8197F)
#define BITS_BSSID_SEL_V1_8197F \
(BIT_MASK_BSSID_SEL_V1_8197F << BIT_SHIFT_BSSID_SEL_V1_8197F)
#define BIT_CLEAR_BSSID_SEL_V1_8197F(x) ((x) & (~BITS_BSSID_SEL_V1_8197F))
#define BIT_GET_BSSID_SEL_V1_8197F(x) \
(((x) >> BIT_SHIFT_BSSID_SEL_V1_8197F) & BIT_MASK_BSSID_SEL_V1_8197F)
#define BIT_SET_BSSID_SEL_V1_8197F(x, v) \
(BIT_CLEAR_BSSID_SEL_V1_8197F(x) | BIT_BSSID_SEL_V1_8197F(v))
#define BIT_SHIFT_P2P_OUI_TYPE_8197F 0
#define BIT_MASK_P2P_OUI_TYPE_8197F 0xff
#define BIT_P2P_OUI_TYPE_8197F(x) \
(((x) & BIT_MASK_P2P_OUI_TYPE_8197F) << BIT_SHIFT_P2P_OUI_TYPE_8197F)
#define BITS_P2P_OUI_TYPE_8197F \
(BIT_MASK_P2P_OUI_TYPE_8197F << BIT_SHIFT_P2P_OUI_TYPE_8197F)
#define BIT_CLEAR_P2P_OUI_TYPE_8197F(x) ((x) & (~BITS_P2P_OUI_TYPE_8197F))
#define BIT_GET_P2P_OUI_TYPE_8197F(x) \
(((x) >> BIT_SHIFT_P2P_OUI_TYPE_8197F) & BIT_MASK_P2P_OUI_TYPE_8197F)
#define BIT_SET_P2P_OUI_TYPE_8197F(x, v) \
(BIT_CLEAR_P2P_OUI_TYPE_8197F(x) | BIT_P2P_OUI_TYPE_8197F(v))
/* 2 REG_ASSOCIATED_BFMER0_INFO_8197F (ASSOCIATED BEAMFORMER0 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_TXCSI_AID0_8197F (48 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_TXCSI_AID0_8197F 0x1ff
#define BIT_R_WMAC_TXCSI_AID0_8197F(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID0_8197F) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID0_8197F)
#define BITS_R_WMAC_TXCSI_AID0_8197F \
(BIT_MASK_R_WMAC_TXCSI_AID0_8197F << BIT_SHIFT_R_WMAC_TXCSI_AID0_8197F)
#define BIT_CLEAR_R_WMAC_TXCSI_AID0_8197F(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID0_8197F))
#define BIT_GET_R_WMAC_TXCSI_AID0_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID0_8197F) & \
BIT_MASK_R_WMAC_TXCSI_AID0_8197F)
#define BIT_SET_R_WMAC_TXCSI_AID0_8197F(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID0_8197F(x) | BIT_R_WMAC_TXCSI_AID0_8197F(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8197F 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8197F 0xffffffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0_8197F(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8197F) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8197F)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_8197F \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8197F \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8197F)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_8197F(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_8197F))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8197F) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8197F)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_8197F(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_8197F(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_8197F(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_8197F (ASSOCIATED BEAMFORMER1 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_TXCSI_AID1_8197F (48 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_TXCSI_AID1_8197F 0x1ff
#define BIT_R_WMAC_TXCSI_AID1_8197F(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID1_8197F) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID1_8197F)
#define BITS_R_WMAC_TXCSI_AID1_8197F \
(BIT_MASK_R_WMAC_TXCSI_AID1_8197F << BIT_SHIFT_R_WMAC_TXCSI_AID1_8197F)
#define BIT_CLEAR_R_WMAC_TXCSI_AID1_8197F(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID1_8197F))
#define BIT_GET_R_WMAC_TXCSI_AID1_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID1_8197F) & \
BIT_MASK_R_WMAC_TXCSI_AID1_8197F)
#define BIT_SET_R_WMAC_TXCSI_AID1_8197F(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID1_8197F(x) | BIT_R_WMAC_TXCSI_AID1_8197F(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8197F 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8197F 0xffffffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_8197F(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8197F) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8197F)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_8197F \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8197F \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8197F)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_8197F(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_8197F))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8197F) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8197F)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_8197F(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_8197F(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_TX_CSI_RPT_PARAM_BW20_8197F (TX CSI REPORT PARAMETER_BW20 REGISTER) */
#define BIT_SHIFT_R_WMAC_BFINFO_20M_1_8197F 16
#define BIT_MASK_R_WMAC_BFINFO_20M_1_8197F 0xfff
#define BIT_R_WMAC_BFINFO_20M_1_8197F(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_1_8197F) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8197F)
#define BITS_R_WMAC_BFINFO_20M_1_8197F \
(BIT_MASK_R_WMAC_BFINFO_20M_1_8197F \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8197F)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_1_8197F(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_1_8197F))
#define BIT_GET_R_WMAC_BFINFO_20M_1_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_1_8197F) & \
BIT_MASK_R_WMAC_BFINFO_20M_1_8197F)
#define BIT_SET_R_WMAC_BFINFO_20M_1_8197F(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_1_8197F(x) | \
BIT_R_WMAC_BFINFO_20M_1_8197F(v))
#define BIT_SHIFT_R_WMAC_BFINFO_20M_0_8197F 0
#define BIT_MASK_R_WMAC_BFINFO_20M_0_8197F 0xfff
#define BIT_R_WMAC_BFINFO_20M_0_8197F(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_0_8197F) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8197F)
#define BITS_R_WMAC_BFINFO_20M_0_8197F \
(BIT_MASK_R_WMAC_BFINFO_20M_0_8197F \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8197F)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_0_8197F(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_0_8197F))
#define BIT_GET_R_WMAC_BFINFO_20M_0_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_0_8197F) & \
BIT_MASK_R_WMAC_BFINFO_20M_0_8197F)
#define BIT_SET_R_WMAC_BFINFO_20M_0_8197F(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_0_8197F(x) | \
BIT_R_WMAC_BFINFO_20M_0_8197F(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW40_8197F (TX CSI REPORT PARAMETER_BW40 REGISTER) */
#define BIT_SHIFT_WMAC_RESP_ANTCD_8197F 0
#define BIT_MASK_WMAC_RESP_ANTCD_8197F 0xf
#define BIT_WMAC_RESP_ANTCD_8197F(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTCD_8197F) \
<< BIT_SHIFT_WMAC_RESP_ANTCD_8197F)
#define BITS_WMAC_RESP_ANTCD_8197F \
(BIT_MASK_WMAC_RESP_ANTCD_8197F << BIT_SHIFT_WMAC_RESP_ANTCD_8197F)
#define BIT_CLEAR_WMAC_RESP_ANTCD_8197F(x) ((x) & (~BITS_WMAC_RESP_ANTCD_8197F))
#define BIT_GET_WMAC_RESP_ANTCD_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTCD_8197F) & \
BIT_MASK_WMAC_RESP_ANTCD_8197F)
#define BIT_SET_WMAC_RESP_ANTCD_8197F(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTCD_8197F(x) | BIT_WMAC_RESP_ANTCD_8197F(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW80_8197F (TX CSI REPORT PARAMETER_BW80 REGISTER) */
/* 2 REG_BCN_PSR_RPT2_8197F (BEACON PARSER REPORT REGISTER2) */
#define BIT_SHIFT_DTIM_CNT2_8197F 24
#define BIT_MASK_DTIM_CNT2_8197F 0xff
#define BIT_DTIM_CNT2_8197F(x) \
(((x) & BIT_MASK_DTIM_CNT2_8197F) << BIT_SHIFT_DTIM_CNT2_8197F)
#define BITS_DTIM_CNT2_8197F \
(BIT_MASK_DTIM_CNT2_8197F << BIT_SHIFT_DTIM_CNT2_8197F)
#define BIT_CLEAR_DTIM_CNT2_8197F(x) ((x) & (~BITS_DTIM_CNT2_8197F))
#define BIT_GET_DTIM_CNT2_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_CNT2_8197F) & BIT_MASK_DTIM_CNT2_8197F)
#define BIT_SET_DTIM_CNT2_8197F(x, v) \
(BIT_CLEAR_DTIM_CNT2_8197F(x) | BIT_DTIM_CNT2_8197F(v))
#define BIT_SHIFT_DTIM_PERIOD2_8197F 16
#define BIT_MASK_DTIM_PERIOD2_8197F 0xff
#define BIT_DTIM_PERIOD2_8197F(x) \
(((x) & BIT_MASK_DTIM_PERIOD2_8197F) << BIT_SHIFT_DTIM_PERIOD2_8197F)
#define BITS_DTIM_PERIOD2_8197F \
(BIT_MASK_DTIM_PERIOD2_8197F << BIT_SHIFT_DTIM_PERIOD2_8197F)
#define BIT_CLEAR_DTIM_PERIOD2_8197F(x) ((x) & (~BITS_DTIM_PERIOD2_8197F))
#define BIT_GET_DTIM_PERIOD2_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD2_8197F) & BIT_MASK_DTIM_PERIOD2_8197F)
#define BIT_SET_DTIM_PERIOD2_8197F(x, v) \
(BIT_CLEAR_DTIM_PERIOD2_8197F(x) | BIT_DTIM_PERIOD2_8197F(v))
#define BIT_DTIM2_8197F BIT(15)
#define BIT_TIM2_8197F BIT(14)
#define BIT_SHIFT_PS_AID_2_8197F 0
#define BIT_MASK_PS_AID_2_8197F 0x7ff
#define BIT_PS_AID_2_8197F(x) \
(((x) & BIT_MASK_PS_AID_2_8197F) << BIT_SHIFT_PS_AID_2_8197F)
#define BITS_PS_AID_2_8197F \
(BIT_MASK_PS_AID_2_8197F << BIT_SHIFT_PS_AID_2_8197F)
#define BIT_CLEAR_PS_AID_2_8197F(x) ((x) & (~BITS_PS_AID_2_8197F))
#define BIT_GET_PS_AID_2_8197F(x) \
(((x) >> BIT_SHIFT_PS_AID_2_8197F) & BIT_MASK_PS_AID_2_8197F)
#define BIT_SET_PS_AID_2_8197F(x, v) \
(BIT_CLEAR_PS_AID_2_8197F(x) | BIT_PS_AID_2_8197F(v))
/* 2 REG_BCN_PSR_RPT3_8197F (BEACON PARSER REPORT REGISTER3) */
#define BIT_SHIFT_DTIM_CNT3_8197F 24
#define BIT_MASK_DTIM_CNT3_8197F 0xff
#define BIT_DTIM_CNT3_8197F(x) \
(((x) & BIT_MASK_DTIM_CNT3_8197F) << BIT_SHIFT_DTIM_CNT3_8197F)
#define BITS_DTIM_CNT3_8197F \
(BIT_MASK_DTIM_CNT3_8197F << BIT_SHIFT_DTIM_CNT3_8197F)
#define BIT_CLEAR_DTIM_CNT3_8197F(x) ((x) & (~BITS_DTIM_CNT3_8197F))
#define BIT_GET_DTIM_CNT3_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_CNT3_8197F) & BIT_MASK_DTIM_CNT3_8197F)
#define BIT_SET_DTIM_CNT3_8197F(x, v) \
(BIT_CLEAR_DTIM_CNT3_8197F(x) | BIT_DTIM_CNT3_8197F(v))
#define BIT_SHIFT_DTIM_PERIOD3_8197F 16
#define BIT_MASK_DTIM_PERIOD3_8197F 0xff
#define BIT_DTIM_PERIOD3_8197F(x) \
(((x) & BIT_MASK_DTIM_PERIOD3_8197F) << BIT_SHIFT_DTIM_PERIOD3_8197F)
#define BITS_DTIM_PERIOD3_8197F \
(BIT_MASK_DTIM_PERIOD3_8197F << BIT_SHIFT_DTIM_PERIOD3_8197F)
#define BIT_CLEAR_DTIM_PERIOD3_8197F(x) ((x) & (~BITS_DTIM_PERIOD3_8197F))
#define BIT_GET_DTIM_PERIOD3_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD3_8197F) & BIT_MASK_DTIM_PERIOD3_8197F)
#define BIT_SET_DTIM_PERIOD3_8197F(x, v) \
(BIT_CLEAR_DTIM_PERIOD3_8197F(x) | BIT_DTIM_PERIOD3_8197F(v))
#define BIT_DTIM3_8197F BIT(15)
#define BIT_TIM3_8197F BIT(14)
#define BIT_SHIFT_PS_AID_3_8197F 0
#define BIT_MASK_PS_AID_3_8197F 0x7ff
#define BIT_PS_AID_3_8197F(x) \
(((x) & BIT_MASK_PS_AID_3_8197F) << BIT_SHIFT_PS_AID_3_8197F)
#define BITS_PS_AID_3_8197F \
(BIT_MASK_PS_AID_3_8197F << BIT_SHIFT_PS_AID_3_8197F)
#define BIT_CLEAR_PS_AID_3_8197F(x) ((x) & (~BITS_PS_AID_3_8197F))
#define BIT_GET_PS_AID_3_8197F(x) \
(((x) >> BIT_SHIFT_PS_AID_3_8197F) & BIT_MASK_PS_AID_3_8197F)
#define BIT_SET_PS_AID_3_8197F(x, v) \
(BIT_CLEAR_PS_AID_3_8197F(x) | BIT_PS_AID_3_8197F(v))
/* 2 REG_BCN_PSR_RPT4_8197F (BEACON PARSER REPORT REGISTER4) */
#define BIT_SHIFT_DTIM_CNT4_8197F 24
#define BIT_MASK_DTIM_CNT4_8197F 0xff
#define BIT_DTIM_CNT4_8197F(x) \
(((x) & BIT_MASK_DTIM_CNT4_8197F) << BIT_SHIFT_DTIM_CNT4_8197F)
#define BITS_DTIM_CNT4_8197F \
(BIT_MASK_DTIM_CNT4_8197F << BIT_SHIFT_DTIM_CNT4_8197F)
#define BIT_CLEAR_DTIM_CNT4_8197F(x) ((x) & (~BITS_DTIM_CNT4_8197F))
#define BIT_GET_DTIM_CNT4_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_CNT4_8197F) & BIT_MASK_DTIM_CNT4_8197F)
#define BIT_SET_DTIM_CNT4_8197F(x, v) \
(BIT_CLEAR_DTIM_CNT4_8197F(x) | BIT_DTIM_CNT4_8197F(v))
#define BIT_SHIFT_DTIM_PERIOD4_8197F 16
#define BIT_MASK_DTIM_PERIOD4_8197F 0xff
#define BIT_DTIM_PERIOD4_8197F(x) \
(((x) & BIT_MASK_DTIM_PERIOD4_8197F) << BIT_SHIFT_DTIM_PERIOD4_8197F)
#define BITS_DTIM_PERIOD4_8197F \
(BIT_MASK_DTIM_PERIOD4_8197F << BIT_SHIFT_DTIM_PERIOD4_8197F)
#define BIT_CLEAR_DTIM_PERIOD4_8197F(x) ((x) & (~BITS_DTIM_PERIOD4_8197F))
#define BIT_GET_DTIM_PERIOD4_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD4_8197F) & BIT_MASK_DTIM_PERIOD4_8197F)
#define BIT_SET_DTIM_PERIOD4_8197F(x, v) \
(BIT_CLEAR_DTIM_PERIOD4_8197F(x) | BIT_DTIM_PERIOD4_8197F(v))
#define BIT_DTIM4_8197F BIT(15)
#define BIT_TIM4_8197F BIT(14)
#define BIT_SHIFT_PS_AID_4_8197F 0
#define BIT_MASK_PS_AID_4_8197F 0x7ff
#define BIT_PS_AID_4_8197F(x) \
(((x) & BIT_MASK_PS_AID_4_8197F) << BIT_SHIFT_PS_AID_4_8197F)
#define BITS_PS_AID_4_8197F \
(BIT_MASK_PS_AID_4_8197F << BIT_SHIFT_PS_AID_4_8197F)
#define BIT_CLEAR_PS_AID_4_8197F(x) ((x) & (~BITS_PS_AID_4_8197F))
#define BIT_GET_PS_AID_4_8197F(x) \
(((x) >> BIT_SHIFT_PS_AID_4_8197F) & BIT_MASK_PS_AID_4_8197F)
#define BIT_SET_PS_AID_4_8197F(x, v) \
(BIT_CLEAR_PS_AID_4_8197F(x) | BIT_PS_AID_4_8197F(v))
/* 2 REG_A1_ADDR_MASK_8197F (A1 ADDR MASK REGISTER) */
#define BIT_SHIFT_A1_ADDR_MASK_8197F 0
#define BIT_MASK_A1_ADDR_MASK_8197F 0xffffffffL
#define BIT_A1_ADDR_MASK_8197F(x) \
(((x) & BIT_MASK_A1_ADDR_MASK_8197F) << BIT_SHIFT_A1_ADDR_MASK_8197F)
#define BITS_A1_ADDR_MASK_8197F \
(BIT_MASK_A1_ADDR_MASK_8197F << BIT_SHIFT_A1_ADDR_MASK_8197F)
#define BIT_CLEAR_A1_ADDR_MASK_8197F(x) ((x) & (~BITS_A1_ADDR_MASK_8197F))
#define BIT_GET_A1_ADDR_MASK_8197F(x) \
(((x) >> BIT_SHIFT_A1_ADDR_MASK_8197F) & BIT_MASK_A1_ADDR_MASK_8197F)
#define BIT_SET_A1_ADDR_MASK_8197F(x, v) \
(BIT_CLEAR_A1_ADDR_MASK_8197F(x) | BIT_A1_ADDR_MASK_8197F(v))
/* 2 REG_MACID2_8197F (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_8197F 0
#define BIT_MASK_MACID2_8197F 0xffffffffffffL
#define BIT_MACID2_8197F(x) \
(((x) & BIT_MASK_MACID2_8197F) << BIT_SHIFT_MACID2_8197F)
#define BITS_MACID2_8197F (BIT_MASK_MACID2_8197F << BIT_SHIFT_MACID2_8197F)
#define BIT_CLEAR_MACID2_8197F(x) ((x) & (~BITS_MACID2_8197F))
#define BIT_GET_MACID2_8197F(x) \
(((x) >> BIT_SHIFT_MACID2_8197F) & BIT_MASK_MACID2_8197F)
#define BIT_SET_MACID2_8197F(x, v) \
(BIT_CLEAR_MACID2_8197F(x) | BIT_MACID2_8197F(v))
/* 2 REG_BSSID2_8197F (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_8197F 0
#define BIT_MASK_BSSID2_8197F 0xffffffffffffL
#define BIT_BSSID2_8197F(x) \
(((x) & BIT_MASK_BSSID2_8197F) << BIT_SHIFT_BSSID2_8197F)
#define BITS_BSSID2_8197F (BIT_MASK_BSSID2_8197F << BIT_SHIFT_BSSID2_8197F)
#define BIT_CLEAR_BSSID2_8197F(x) ((x) & (~BITS_BSSID2_8197F))
#define BIT_GET_BSSID2_8197F(x) \
(((x) >> BIT_SHIFT_BSSID2_8197F) & BIT_MASK_BSSID2_8197F)
#define BIT_SET_BSSID2_8197F(x, v) \
(BIT_CLEAR_BSSID2_8197F(x) | BIT_BSSID2_8197F(v))
/* 2 REG_MACID3_8197F (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_8197F 0
#define BIT_MASK_MACID3_8197F 0xffffffffffffL
#define BIT_MACID3_8197F(x) \
(((x) & BIT_MASK_MACID3_8197F) << BIT_SHIFT_MACID3_8197F)
#define BITS_MACID3_8197F (BIT_MASK_MACID3_8197F << BIT_SHIFT_MACID3_8197F)
#define BIT_CLEAR_MACID3_8197F(x) ((x) & (~BITS_MACID3_8197F))
#define BIT_GET_MACID3_8197F(x) \
(((x) >> BIT_SHIFT_MACID3_8197F) & BIT_MASK_MACID3_8197F)
#define BIT_SET_MACID3_8197F(x, v) \
(BIT_CLEAR_MACID3_8197F(x) | BIT_MACID3_8197F(v))
/* 2 REG_BSSID3_8197F (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_8197F 0
#define BIT_MASK_BSSID3_8197F 0xffffffffffffL
#define BIT_BSSID3_8197F(x) \
(((x) & BIT_MASK_BSSID3_8197F) << BIT_SHIFT_BSSID3_8197F)
#define BITS_BSSID3_8197F (BIT_MASK_BSSID3_8197F << BIT_SHIFT_BSSID3_8197F)
#define BIT_CLEAR_BSSID3_8197F(x) ((x) & (~BITS_BSSID3_8197F))
#define BIT_GET_BSSID3_8197F(x) \
(((x) >> BIT_SHIFT_BSSID3_8197F) & BIT_MASK_BSSID3_8197F)
#define BIT_SET_BSSID3_8197F(x, v) \
(BIT_CLEAR_BSSID3_8197F(x) | BIT_BSSID3_8197F(v))
/* 2 REG_MACID4_8197F (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_8197F 0
#define BIT_MASK_MACID4_8197F 0xffffffffffffL
#define BIT_MACID4_8197F(x) \
(((x) & BIT_MASK_MACID4_8197F) << BIT_SHIFT_MACID4_8197F)
#define BITS_MACID4_8197F (BIT_MASK_MACID4_8197F << BIT_SHIFT_MACID4_8197F)
#define BIT_CLEAR_MACID4_8197F(x) ((x) & (~BITS_MACID4_8197F))
#define BIT_GET_MACID4_8197F(x) \
(((x) >> BIT_SHIFT_MACID4_8197F) & BIT_MASK_MACID4_8197F)
#define BIT_SET_MACID4_8197F(x, v) \
(BIT_CLEAR_MACID4_8197F(x) | BIT_MACID4_8197F(v))
/* 2 REG_BSSID4_8197F (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_8197F 0
#define BIT_MASK_BSSID4_8197F 0xffffffffffffL
#define BIT_BSSID4_8197F(x) \
(((x) & BIT_MASK_BSSID4_8197F) << BIT_SHIFT_BSSID4_8197F)
#define BITS_BSSID4_8197F (BIT_MASK_BSSID4_8197F << BIT_SHIFT_BSSID4_8197F)
#define BIT_CLEAR_BSSID4_8197F(x) ((x) & (~BITS_BSSID4_8197F))
#define BIT_GET_BSSID4_8197F(x) \
(((x) >> BIT_SHIFT_BSSID4_8197F) & BIT_MASK_BSSID4_8197F)
#define BIT_SET_BSSID4_8197F(x, v) \
(BIT_CLEAR_BSSID4_8197F(x) | BIT_BSSID4_8197F(v))
/* 2 REG_NOA_REPORT_8197F */
/* 2 REG_PWRBIT_SETTING_8197F */
#define BIT_CLI3_PWRBIT_OW_EN_8197F BIT(7)
#define BIT_CLI3_PWR_ST_8197F BIT(6)
#define BIT_CLI2_PWRBIT_OW_EN_8197F BIT(5)
#define BIT_CLI2_PWR_ST_8197F BIT(4)
#define BIT_CLI1_PWRBIT_OW_EN_8197F BIT(3)
#define BIT_CLI1_PWR_ST_8197F BIT(2)
#define BIT_CLI0_PWRBIT_OW_EN_8197F BIT(1)
#define BIT_CLI0_PWR_ST_8197F BIT(0)
/* 2 REG_WMAC_MU_BF_OPTION_8197F */
#define BIT_WMAC_RESP_NONSTA1_DIS_8197F BIT(7)
#define BIT_BIT_WMAC_TXMU_ACKPOLICY_EN_8197F BIT(6)
#define BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8197F 4
#define BIT_MASK_WMAC_TXMU_ACKPOLICY_8197F 0x3
#define BIT_WMAC_TXMU_ACKPOLICY_8197F(x) \
(((x) & BIT_MASK_WMAC_TXMU_ACKPOLICY_8197F) \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8197F)
#define BITS_WMAC_TXMU_ACKPOLICY_8197F \
(BIT_MASK_WMAC_TXMU_ACKPOLICY_8197F \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8197F)
#define BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8197F(x) \
((x) & (~BITS_WMAC_TXMU_ACKPOLICY_8197F))
#define BIT_GET_WMAC_TXMU_ACKPOLICY_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8197F) & \
BIT_MASK_WMAC_TXMU_ACKPOLICY_8197F)
#define BIT_SET_WMAC_TXMU_ACKPOLICY_8197F(x, v) \
(BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8197F(x) | \
BIT_WMAC_TXMU_ACKPOLICY_8197F(v))
#define BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8197F 1
#define BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8197F 0x7
#define BIT_WMAC_MU_BFEE_PORT_SEL_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8197F)
#define BITS_WMAC_MU_BFEE_PORT_SEL_8197F \
(BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8197F \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE_PORT_SEL_8197F))
#define BIT_GET_WMAC_MU_BFEE_PORT_SEL_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8197F) & \
BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8197F)
#define BIT_SET_WMAC_MU_BFEE_PORT_SEL_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8197F(x) | \
BIT_WMAC_MU_BFEE_PORT_SEL_8197F(v))
#define BIT_WMAC_MU_BFEE_DIS_8197F BIT(0)
/* 2 REG_WMAC_PAUSE_BB_CLR_TH_8197F */
#define BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8197F 0
#define BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8197F 0xff
#define BIT_WMAC_PAUSE_BB_CLR_TH_8197F(x) \
(((x) & BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8197F) \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8197F)
#define BITS_WMAC_PAUSE_BB_CLR_TH_8197F \
(BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8197F \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8197F)
#define BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8197F(x) \
((x) & (~BITS_WMAC_PAUSE_BB_CLR_TH_8197F))
#define BIT_GET_WMAC_PAUSE_BB_CLR_TH_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8197F) & \
BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8197F)
#define BIT_SET_WMAC_PAUSE_BB_CLR_TH_8197F(x, v) \
(BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8197F(x) | \
BIT_WMAC_PAUSE_BB_CLR_TH_8197F(v))
/* 2 REG_WMAC_MU_ARB_8197F */
#define BIT_WMAC_ARB_HW_ADAPT_EN_8197F BIT(7)
#define BIT_WMAC_ARB_SW_EN_8197F BIT(6)
#define BIT_SHIFT_WMAC_ARB_SW_STATE_8197F 0
#define BIT_MASK_WMAC_ARB_SW_STATE_8197F 0x3f
#define BIT_WMAC_ARB_SW_STATE_8197F(x) \
(((x) & BIT_MASK_WMAC_ARB_SW_STATE_8197F) \
<< BIT_SHIFT_WMAC_ARB_SW_STATE_8197F)
#define BITS_WMAC_ARB_SW_STATE_8197F \
(BIT_MASK_WMAC_ARB_SW_STATE_8197F << BIT_SHIFT_WMAC_ARB_SW_STATE_8197F)
#define BIT_CLEAR_WMAC_ARB_SW_STATE_8197F(x) \
((x) & (~BITS_WMAC_ARB_SW_STATE_8197F))
#define BIT_GET_WMAC_ARB_SW_STATE_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_ARB_SW_STATE_8197F) & \
BIT_MASK_WMAC_ARB_SW_STATE_8197F)
#define BIT_SET_WMAC_ARB_SW_STATE_8197F(x, v) \
(BIT_CLEAR_WMAC_ARB_SW_STATE_8197F(x) | BIT_WMAC_ARB_SW_STATE_8197F(v))
/* 2 REG_WMAC_MU_OPTION_8197F */
#define BIT_SHIFT_WMAC_MU_DBGSEL_8197F 5
#define BIT_MASK_WMAC_MU_DBGSEL_8197F 0x3
#define BIT_WMAC_MU_DBGSEL_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_DBGSEL_8197F) \
<< BIT_SHIFT_WMAC_MU_DBGSEL_8197F)
#define BITS_WMAC_MU_DBGSEL_8197F \
(BIT_MASK_WMAC_MU_DBGSEL_8197F << BIT_SHIFT_WMAC_MU_DBGSEL_8197F)
#define BIT_CLEAR_WMAC_MU_DBGSEL_8197F(x) ((x) & (~BITS_WMAC_MU_DBGSEL_8197F))
#define BIT_GET_WMAC_MU_DBGSEL_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_DBGSEL_8197F) & \
BIT_MASK_WMAC_MU_DBGSEL_8197F)
#define BIT_SET_WMAC_MU_DBGSEL_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_DBGSEL_8197F(x) | BIT_WMAC_MU_DBGSEL_8197F(v))
#define BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8197F 0
#define BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8197F 0x1f
#define BIT_WMAC_MU_CPRD_TIMEOUT_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8197F) \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8197F)
#define BITS_WMAC_MU_CPRD_TIMEOUT_8197F \
(BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8197F \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8197F)
#define BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT_8197F(x) \
((x) & (~BITS_WMAC_MU_CPRD_TIMEOUT_8197F))
#define BIT_GET_WMAC_MU_CPRD_TIMEOUT_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8197F) & \
BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8197F)
#define BIT_SET_WMAC_MU_CPRD_TIMEOUT_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT_8197F(x) | \
BIT_WMAC_MU_CPRD_TIMEOUT_8197F(v))
/* 2 REG_WMAC_MU_BF_CTL_8197F */
#define BIT_WMAC_INVLD_BFPRT_CHK_8197F BIT(15)
#define BIT_WMAC_RETXBFRPTSEQ_UPD_8197F BIT(14)
#define BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8197F 12
#define BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8197F 0x3
#define BIT_WMAC_MU_BFRPTSEG_SEL_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8197F) \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8197F)
#define BITS_WMAC_MU_BFRPTSEG_SEL_8197F \
(BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8197F \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8197F)
#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8197F(x) \
((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL_8197F))
#define BIT_GET_WMAC_MU_BFRPTSEG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8197F) & \
BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8197F)
#define BIT_SET_WMAC_MU_BFRPTSEG_SEL_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8197F(x) | \
BIT_WMAC_MU_BFRPTSEG_SEL_8197F(v))
#define BIT_SHIFT_WMAC_MU_BF_MYAID_8197F 0
#define BIT_MASK_WMAC_MU_BF_MYAID_8197F 0xfff
#define BIT_WMAC_MU_BF_MYAID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BF_MYAID_8197F) \
<< BIT_SHIFT_WMAC_MU_BF_MYAID_8197F)
#define BITS_WMAC_MU_BF_MYAID_8197F \
(BIT_MASK_WMAC_MU_BF_MYAID_8197F << BIT_SHIFT_WMAC_MU_BF_MYAID_8197F)
#define BIT_CLEAR_WMAC_MU_BF_MYAID_8197F(x) \
((x) & (~BITS_WMAC_MU_BF_MYAID_8197F))
#define BIT_GET_WMAC_MU_BF_MYAID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BF_MYAID_8197F) & \
BIT_MASK_WMAC_MU_BF_MYAID_8197F)
#define BIT_SET_WMAC_MU_BF_MYAID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BF_MYAID_8197F(x) | BIT_WMAC_MU_BF_MYAID_8197F(v))
/* 2 REG_WMAC_MU_BFRPT_PARA_8197F */
#define BIT_SHIFT_BFRPT_PARA_USERID_SEL_8197F 12
#define BIT_MASK_BFRPT_PARA_USERID_SEL_8197F 0x7
#define BIT_BFRPT_PARA_USERID_SEL_8197F(x) \
(((x) & BIT_MASK_BFRPT_PARA_USERID_SEL_8197F) \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_8197F)
#define BITS_BFRPT_PARA_USERID_SEL_8197F \
(BIT_MASK_BFRPT_PARA_USERID_SEL_8197F \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_8197F)
#define BIT_CLEAR_BFRPT_PARA_USERID_SEL_8197F(x) \
((x) & (~BITS_BFRPT_PARA_USERID_SEL_8197F))
#define BIT_GET_BFRPT_PARA_USERID_SEL_8197F(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_USERID_SEL_8197F) & \
BIT_MASK_BFRPT_PARA_USERID_SEL_8197F)
#define BIT_SET_BFRPT_PARA_USERID_SEL_8197F(x, v) \
(BIT_CLEAR_BFRPT_PARA_USERID_SEL_8197F(x) | \
BIT_BFRPT_PARA_USERID_SEL_8197F(v))
#define BIT_SHIFT_BFRPT_PARA_8197F 0
#define BIT_MASK_BFRPT_PARA_8197F 0xfff
#define BIT_BFRPT_PARA_8197F(x) \
(((x) & BIT_MASK_BFRPT_PARA_8197F) << BIT_SHIFT_BFRPT_PARA_8197F)
#define BITS_BFRPT_PARA_8197F \
(BIT_MASK_BFRPT_PARA_8197F << BIT_SHIFT_BFRPT_PARA_8197F)
#define BIT_CLEAR_BFRPT_PARA_8197F(x) ((x) & (~BITS_BFRPT_PARA_8197F))
#define BIT_GET_BFRPT_PARA_8197F(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_8197F) & BIT_MASK_BFRPT_PARA_8197F)
#define BIT_SET_BFRPT_PARA_8197F(x, v) \
(BIT_CLEAR_BFRPT_PARA_8197F(x) | BIT_BFRPT_PARA_8197F(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2_8197F */
#define BIT_STATUS_BFEE2_8197F BIT(10)
#define BIT_WMAC_MU_BFEE2_EN_8197F BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE2_AID_8197F 0
#define BIT_MASK_WMAC_MU_BFEE2_AID_8197F 0x1ff
#define BIT_WMAC_MU_BFEE2_AID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE2_AID_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE2_AID_8197F)
#define BITS_WMAC_MU_BFEE2_AID_8197F \
(BIT_MASK_WMAC_MU_BFEE2_AID_8197F << BIT_SHIFT_WMAC_MU_BFEE2_AID_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE2_AID_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE2_AID_8197F))
#define BIT_GET_WMAC_MU_BFEE2_AID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE2_AID_8197F) & \
BIT_MASK_WMAC_MU_BFEE2_AID_8197F)
#define BIT_SET_WMAC_MU_BFEE2_AID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE2_AID_8197F(x) | BIT_WMAC_MU_BFEE2_AID_8197F(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3_8197F */
#define BIT_STATUS_BFEE3_8197F BIT(10)
#define BIT_WMAC_MU_BFEE3_EN_8197F BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE3_AID_8197F 0
#define BIT_MASK_WMAC_MU_BFEE3_AID_8197F 0x1ff
#define BIT_WMAC_MU_BFEE3_AID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE3_AID_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE3_AID_8197F)
#define BITS_WMAC_MU_BFEE3_AID_8197F \
(BIT_MASK_WMAC_MU_BFEE3_AID_8197F << BIT_SHIFT_WMAC_MU_BFEE3_AID_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE3_AID_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE3_AID_8197F))
#define BIT_GET_WMAC_MU_BFEE3_AID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE3_AID_8197F) & \
BIT_MASK_WMAC_MU_BFEE3_AID_8197F)
#define BIT_SET_WMAC_MU_BFEE3_AID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE3_AID_8197F(x) | BIT_WMAC_MU_BFEE3_AID_8197F(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE4_8197F */
#define BIT_STATUS_BFEE4_8197F BIT(10)
#define BIT_WMAC_MU_BFEE4_EN_8197F BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE4_AID_8197F 0
#define BIT_MASK_WMAC_MU_BFEE4_AID_8197F 0x1ff
#define BIT_WMAC_MU_BFEE4_AID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE4_AID_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE4_AID_8197F)
#define BITS_WMAC_MU_BFEE4_AID_8197F \
(BIT_MASK_WMAC_MU_BFEE4_AID_8197F << BIT_SHIFT_WMAC_MU_BFEE4_AID_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE4_AID_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE4_AID_8197F))
#define BIT_GET_WMAC_MU_BFEE4_AID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE4_AID_8197F) & \
BIT_MASK_WMAC_MU_BFEE4_AID_8197F)
#define BIT_SET_WMAC_MU_BFEE4_AID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE4_AID_8197F(x) | BIT_WMAC_MU_BFEE4_AID_8197F(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5_8197F */
#define BIT_STATUS_BFEE5_8197F BIT(10)
#define BIT_WMAC_MU_BFEE5_EN_8197F BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE5_AID_8197F 0
#define BIT_MASK_WMAC_MU_BFEE5_AID_8197F 0x1ff
#define BIT_WMAC_MU_BFEE5_AID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE5_AID_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE5_AID_8197F)
#define BITS_WMAC_MU_BFEE5_AID_8197F \
(BIT_MASK_WMAC_MU_BFEE5_AID_8197F << BIT_SHIFT_WMAC_MU_BFEE5_AID_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE5_AID_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE5_AID_8197F))
#define BIT_GET_WMAC_MU_BFEE5_AID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE5_AID_8197F) & \
BIT_MASK_WMAC_MU_BFEE5_AID_8197F)
#define BIT_SET_WMAC_MU_BFEE5_AID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE5_AID_8197F(x) | BIT_WMAC_MU_BFEE5_AID_8197F(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE6_8197F */
#define BIT_STATUS_BFEE6_8197F BIT(10)
#define BIT_WMAC_MU_BFEE6_EN_8197F BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE6_AID_8197F 0
#define BIT_MASK_WMAC_MU_BFEE6_AID_8197F 0x1ff
#define BIT_WMAC_MU_BFEE6_AID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE6_AID_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE6_AID_8197F)
#define BITS_WMAC_MU_BFEE6_AID_8197F \
(BIT_MASK_WMAC_MU_BFEE6_AID_8197F << BIT_SHIFT_WMAC_MU_BFEE6_AID_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE6_AID_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE6_AID_8197F))
#define BIT_GET_WMAC_MU_BFEE6_AID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE6_AID_8197F) & \
BIT_MASK_WMAC_MU_BFEE6_AID_8197F)
#define BIT_SET_WMAC_MU_BFEE6_AID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE6_AID_8197F(x) | BIT_WMAC_MU_BFEE6_AID_8197F(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7_8197F */
#define BIT_BIT_STATUS_BFEE4_8197F BIT(10)
#define BIT_WMAC_MU_BFEE7_EN_8197F BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE7_AID_8197F 0
#define BIT_MASK_WMAC_MU_BFEE7_AID_8197F 0x1ff
#define BIT_WMAC_MU_BFEE7_AID_8197F(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE7_AID_8197F) \
<< BIT_SHIFT_WMAC_MU_BFEE7_AID_8197F)
#define BITS_WMAC_MU_BFEE7_AID_8197F \
(BIT_MASK_WMAC_MU_BFEE7_AID_8197F << BIT_SHIFT_WMAC_MU_BFEE7_AID_8197F)
#define BIT_CLEAR_WMAC_MU_BFEE7_AID_8197F(x) \
((x) & (~BITS_WMAC_MU_BFEE7_AID_8197F))
#define BIT_GET_WMAC_MU_BFEE7_AID_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE7_AID_8197F) & \
BIT_MASK_WMAC_MU_BFEE7_AID_8197F)
#define BIT_SET_WMAC_MU_BFEE7_AID_8197F(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE7_AID_8197F(x) | BIT_WMAC_MU_BFEE7_AID_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_RST_ALL_COUNTER_8197F BIT(31)
#define BIT_SHIFT_ABORT_RX_VBON_COUNTER_8197F 16
#define BIT_MASK_ABORT_RX_VBON_COUNTER_8197F 0xff
#define BIT_ABORT_RX_VBON_COUNTER_8197F(x) \
(((x) & BIT_MASK_ABORT_RX_VBON_COUNTER_8197F) \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8197F)
#define BITS_ABORT_RX_VBON_COUNTER_8197F \
(BIT_MASK_ABORT_RX_VBON_COUNTER_8197F \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8197F)
#define BIT_CLEAR_ABORT_RX_VBON_COUNTER_8197F(x) \
((x) & (~BITS_ABORT_RX_VBON_COUNTER_8197F))
#define BIT_GET_ABORT_RX_VBON_COUNTER_8197F(x) \
(((x) >> BIT_SHIFT_ABORT_RX_VBON_COUNTER_8197F) & \
BIT_MASK_ABORT_RX_VBON_COUNTER_8197F)
#define BIT_SET_ABORT_RX_VBON_COUNTER_8197F(x, v) \
(BIT_CLEAR_ABORT_RX_VBON_COUNTER_8197F(x) | \
BIT_ABORT_RX_VBON_COUNTER_8197F(v))
#define BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8197F 8
#define BIT_MASK_ABORT_RX_RDRDY_COUNTER_8197F 0xff
#define BIT_ABORT_RX_RDRDY_COUNTER_8197F(x) \
(((x) & BIT_MASK_ABORT_RX_RDRDY_COUNTER_8197F) \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8197F)
#define BITS_ABORT_RX_RDRDY_COUNTER_8197F \
(BIT_MASK_ABORT_RX_RDRDY_COUNTER_8197F \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8197F)
#define BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8197F(x) \
((x) & (~BITS_ABORT_RX_RDRDY_COUNTER_8197F))
#define BIT_GET_ABORT_RX_RDRDY_COUNTER_8197F(x) \
(((x) >> BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8197F) & \
BIT_MASK_ABORT_RX_RDRDY_COUNTER_8197F)
#define BIT_SET_ABORT_RX_RDRDY_COUNTER_8197F(x, v) \
(BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8197F(x) | \
BIT_ABORT_RX_RDRDY_COUNTER_8197F(v))
#define BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8197F 0
#define BIT_MASK_VBON_EARLY_FALLING_COUNTER_8197F 0xff
#define BIT_VBON_EARLY_FALLING_COUNTER_8197F(x) \
(((x) & BIT_MASK_VBON_EARLY_FALLING_COUNTER_8197F) \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8197F)
#define BITS_VBON_EARLY_FALLING_COUNTER_8197F \
(BIT_MASK_VBON_EARLY_FALLING_COUNTER_8197F \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8197F)
#define BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8197F(x) \
((x) & (~BITS_VBON_EARLY_FALLING_COUNTER_8197F))
#define BIT_GET_VBON_EARLY_FALLING_COUNTER_8197F(x) \
(((x) >> BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8197F) & \
BIT_MASK_VBON_EARLY_FALLING_COUNTER_8197F)
#define BIT_SET_VBON_EARLY_FALLING_COUNTER_8197F(x, v) \
(BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8197F(x) | \
BIT_VBON_EARLY_FALLING_COUNTER_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#define BIT_WMAC_PLCP_TRX_SEL_8197F BIT(31)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8197F 28
#define BIT_MASK_WMAC_PLCP_RDSIG_SEL_8197F 0x7
#define BIT_WMAC_PLCP_RDSIG_SEL_8197F(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_SEL_8197F) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8197F)
#define BITS_WMAC_PLCP_RDSIG_SEL_8197F \
(BIT_MASK_WMAC_PLCP_RDSIG_SEL_8197F \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8197F)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8197F(x) \
((x) & (~BITS_WMAC_PLCP_RDSIG_SEL_8197F))
#define BIT_GET_WMAC_PLCP_RDSIG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8197F) & \
BIT_MASK_WMAC_PLCP_RDSIG_SEL_8197F)
#define BIT_SET_WMAC_PLCP_RDSIG_SEL_8197F(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8197F(x) | \
BIT_WMAC_PLCP_RDSIG_SEL_8197F(v))
#define BIT_SHIFT_WMAC_RATE_IDX_8197F 24
#define BIT_MASK_WMAC_RATE_IDX_8197F 0xf
#define BIT_WMAC_RATE_IDX_8197F(x) \
(((x) & BIT_MASK_WMAC_RATE_IDX_8197F) << BIT_SHIFT_WMAC_RATE_IDX_8197F)
#define BITS_WMAC_RATE_IDX_8197F \
(BIT_MASK_WMAC_RATE_IDX_8197F << BIT_SHIFT_WMAC_RATE_IDX_8197F)
#define BIT_CLEAR_WMAC_RATE_IDX_8197F(x) ((x) & (~BITS_WMAC_RATE_IDX_8197F))
#define BIT_GET_WMAC_RATE_IDX_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_RATE_IDX_8197F) & BIT_MASK_WMAC_RATE_IDX_8197F)
#define BIT_SET_WMAC_RATE_IDX_8197F(x, v) \
(BIT_CLEAR_WMAC_RATE_IDX_8197F(x) | BIT_WMAC_RATE_IDX_8197F(v))
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8197F 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8197F 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8197F(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8197F) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8197F)
#define BITS_WMAC_PLCP_RDSIG_8197F \
(BIT_MASK_WMAC_PLCP_RDSIG_8197F << BIT_SHIFT_WMAC_PLCP_RDSIG_8197F)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8197F(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8197F))
#define BIT_GET_WMAC_PLCP_RDSIG_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8197F) & \
BIT_MASK_WMAC_PLCP_RDSIG_8197F)
#define BIT_SET_WMAC_PLCP_RDSIG_8197F(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8197F(x) | BIT_WMAC_PLCP_RDSIG_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_TRANSMIT_ADDRSS_0_8197F (TA0 REGISTER) */
#define BIT_SHIFT_TA0_8197F 0
#define BIT_MASK_TA0_8197F 0xffffffffffffL
#define BIT_TA0_8197F(x) (((x) & BIT_MASK_TA0_8197F) << BIT_SHIFT_TA0_8197F)
#define BITS_TA0_8197F (BIT_MASK_TA0_8197F << BIT_SHIFT_TA0_8197F)
#define BIT_CLEAR_TA0_8197F(x) ((x) & (~BITS_TA0_8197F))
#define BIT_GET_TA0_8197F(x) (((x) >> BIT_SHIFT_TA0_8197F) & BIT_MASK_TA0_8197F)
#define BIT_SET_TA0_8197F(x, v) (BIT_CLEAR_TA0_8197F(x) | BIT_TA0_8197F(v))
/* 2 REG_TRANSMIT_ADDRSS_1_8197F (TA1 REGISTER) */
#define BIT_SHIFT_TA1_8197F 0
#define BIT_MASK_TA1_8197F 0xffffffffffffL
#define BIT_TA1_8197F(x) (((x) & BIT_MASK_TA1_8197F) << BIT_SHIFT_TA1_8197F)
#define BITS_TA1_8197F (BIT_MASK_TA1_8197F << BIT_SHIFT_TA1_8197F)
#define BIT_CLEAR_TA1_8197F(x) ((x) & (~BITS_TA1_8197F))
#define BIT_GET_TA1_8197F(x) (((x) >> BIT_SHIFT_TA1_8197F) & BIT_MASK_TA1_8197F)
#define BIT_SET_TA1_8197F(x, v) (BIT_CLEAR_TA1_8197F(x) | BIT_TA1_8197F(v))
/* 2 REG_TRANSMIT_ADDRSS_2_8197F (TA2 REGISTER) */
#define BIT_SHIFT_TA2_8197F 0
#define BIT_MASK_TA2_8197F 0xffffffffffffL
#define BIT_TA2_8197F(x) (((x) & BIT_MASK_TA2_8197F) << BIT_SHIFT_TA2_8197F)
#define BITS_TA2_8197F (BIT_MASK_TA2_8197F << BIT_SHIFT_TA2_8197F)
#define BIT_CLEAR_TA2_8197F(x) ((x) & (~BITS_TA2_8197F))
#define BIT_GET_TA2_8197F(x) (((x) >> BIT_SHIFT_TA2_8197F) & BIT_MASK_TA2_8197F)
#define BIT_SET_TA2_8197F(x, v) (BIT_CLEAR_TA2_8197F(x) | BIT_TA2_8197F(v))
/* 2 REG_TRANSMIT_ADDRSS_3_8197F (TA3 REGISTER) */
#define BIT_SHIFT_TA3_8197F 0
#define BIT_MASK_TA3_8197F 0xffffffffffffL
#define BIT_TA3_8197F(x) (((x) & BIT_MASK_TA3_8197F) << BIT_SHIFT_TA3_8197F)
#define BITS_TA3_8197F (BIT_MASK_TA3_8197F << BIT_SHIFT_TA3_8197F)
#define BIT_CLEAR_TA3_8197F(x) ((x) & (~BITS_TA3_8197F))
#define BIT_GET_TA3_8197F(x) (((x) >> BIT_SHIFT_TA3_8197F) & BIT_MASK_TA3_8197F)
#define BIT_SET_TA3_8197F(x, v) (BIT_CLEAR_TA3_8197F(x) | BIT_TA3_8197F(v))
/* 2 REG_TRANSMIT_ADDRSS_4_8197F (TA4 REGISTER) */
#define BIT_SHIFT_TA4_8197F 0
#define BIT_MASK_TA4_8197F 0xffffffffffffL
#define BIT_TA4_8197F(x) (((x) & BIT_MASK_TA4_8197F) << BIT_SHIFT_TA4_8197F)
#define BITS_TA4_8197F (BIT_MASK_TA4_8197F << BIT_SHIFT_TA4_8197F)
#define BIT_CLEAR_TA4_8197F(x) ((x) & (~BITS_TA4_8197F))
#define BIT_GET_TA4_8197F(x) (((x) >> BIT_SHIFT_TA4_8197F) & BIT_MASK_TA4_8197F)
#define BIT_SET_TA4_8197F(x, v) (BIT_CLEAR_TA4_8197F(x) | BIT_TA4_8197F(v))
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_MACID1_8197F */
#define BIT_SHIFT_MACID1_8197F 0
#define BIT_MASK_MACID1_8197F 0xffffffffffffL
#define BIT_MACID1_8197F(x) \
(((x) & BIT_MASK_MACID1_8197F) << BIT_SHIFT_MACID1_8197F)
#define BITS_MACID1_8197F (BIT_MASK_MACID1_8197F << BIT_SHIFT_MACID1_8197F)
#define BIT_CLEAR_MACID1_8197F(x) ((x) & (~BITS_MACID1_8197F))
#define BIT_GET_MACID1_8197F(x) \
(((x) >> BIT_SHIFT_MACID1_8197F) & BIT_MASK_MACID1_8197F)
#define BIT_SET_MACID1_8197F(x, v) \
(BIT_CLEAR_MACID1_8197F(x) | BIT_MACID1_8197F(v))
/* 2 REG_BSSID1_8197F */
#define BIT_SHIFT_BSSID1_8197F 0
#define BIT_MASK_BSSID1_8197F 0xffffffffffffL
#define BIT_BSSID1_8197F(x) \
(((x) & BIT_MASK_BSSID1_8197F) << BIT_SHIFT_BSSID1_8197F)
#define BITS_BSSID1_8197F (BIT_MASK_BSSID1_8197F << BIT_SHIFT_BSSID1_8197F)
#define BIT_CLEAR_BSSID1_8197F(x) ((x) & (~BITS_BSSID1_8197F))
#define BIT_GET_BSSID1_8197F(x) \
(((x) >> BIT_SHIFT_BSSID1_8197F) & BIT_MASK_BSSID1_8197F)
#define BIT_SET_BSSID1_8197F(x, v) \
(BIT_CLEAR_BSSID1_8197F(x) | BIT_BSSID1_8197F(v))
/* 2 REG_BCN_PSR_RPT1_8197F */
#define BIT_SHIFT_DTIM_CNT1_8197F 24
#define BIT_MASK_DTIM_CNT1_8197F 0xff
#define BIT_DTIM_CNT1_8197F(x) \
(((x) & BIT_MASK_DTIM_CNT1_8197F) << BIT_SHIFT_DTIM_CNT1_8197F)
#define BITS_DTIM_CNT1_8197F \
(BIT_MASK_DTIM_CNT1_8197F << BIT_SHIFT_DTIM_CNT1_8197F)
#define BIT_CLEAR_DTIM_CNT1_8197F(x) ((x) & (~BITS_DTIM_CNT1_8197F))
#define BIT_GET_DTIM_CNT1_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_CNT1_8197F) & BIT_MASK_DTIM_CNT1_8197F)
#define BIT_SET_DTIM_CNT1_8197F(x, v) \
(BIT_CLEAR_DTIM_CNT1_8197F(x) | BIT_DTIM_CNT1_8197F(v))
#define BIT_SHIFT_DTIM_PERIOD1_8197F 16
#define BIT_MASK_DTIM_PERIOD1_8197F 0xff
#define BIT_DTIM_PERIOD1_8197F(x) \
(((x) & BIT_MASK_DTIM_PERIOD1_8197F) << BIT_SHIFT_DTIM_PERIOD1_8197F)
#define BITS_DTIM_PERIOD1_8197F \
(BIT_MASK_DTIM_PERIOD1_8197F << BIT_SHIFT_DTIM_PERIOD1_8197F)
#define BIT_CLEAR_DTIM_PERIOD1_8197F(x) ((x) & (~BITS_DTIM_PERIOD1_8197F))
#define BIT_GET_DTIM_PERIOD1_8197F(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD1_8197F) & BIT_MASK_DTIM_PERIOD1_8197F)
#define BIT_SET_DTIM_PERIOD1_8197F(x, v) \
(BIT_CLEAR_DTIM_PERIOD1_8197F(x) | BIT_DTIM_PERIOD1_8197F(v))
#define BIT_DTIM1_8197F BIT(15)
#define BIT_TIM1_8197F BIT(14)
#define BIT_SHIFT_PS_AID_1_8197F 0
#define BIT_MASK_PS_AID_1_8197F 0x7ff
#define BIT_PS_AID_1_8197F(x) \
(((x) & BIT_MASK_PS_AID_1_8197F) << BIT_SHIFT_PS_AID_1_8197F)
#define BITS_PS_AID_1_8197F \
(BIT_MASK_PS_AID_1_8197F << BIT_SHIFT_PS_AID_1_8197F)
#define BIT_CLEAR_PS_AID_1_8197F(x) ((x) & (~BITS_PS_AID_1_8197F))
#define BIT_GET_PS_AID_1_8197F(x) \
(((x) >> BIT_SHIFT_PS_AID_1_8197F) & BIT_MASK_PS_AID_1_8197F)
#define BIT_SET_PS_AID_1_8197F(x, v) \
(BIT_CLEAR_PS_AID_1_8197F(x) | BIT_PS_AID_1_8197F(v))
/* 2 REG_ASSOCIATED_BFMEE_SEL_8197F */
#define BIT_TXUSER_ID1_8197F BIT(25)
#define BIT_SHIFT_AID1_8197F 16
#define BIT_MASK_AID1_8197F 0x1ff
#define BIT_AID1_8197F(x) (((x) & BIT_MASK_AID1_8197F) << BIT_SHIFT_AID1_8197F)
#define BITS_AID1_8197F (BIT_MASK_AID1_8197F << BIT_SHIFT_AID1_8197F)
#define BIT_CLEAR_AID1_8197F(x) ((x) & (~BITS_AID1_8197F))
#define BIT_GET_AID1_8197F(x) \
(((x) >> BIT_SHIFT_AID1_8197F) & BIT_MASK_AID1_8197F)
#define BIT_SET_AID1_8197F(x, v) (BIT_CLEAR_AID1_8197F(x) | BIT_AID1_8197F(v))
#define BIT_TXUSER_ID0_8197F BIT(9)
#define BIT_SHIFT_AID0_8197F 0
#define BIT_MASK_AID0_8197F 0x1ff
#define BIT_AID0_8197F(x) (((x) & BIT_MASK_AID0_8197F) << BIT_SHIFT_AID0_8197F)
#define BITS_AID0_8197F (BIT_MASK_AID0_8197F << BIT_SHIFT_AID0_8197F)
#define BIT_CLEAR_AID0_8197F(x) ((x) & (~BITS_AID0_8197F))
#define BIT_GET_AID0_8197F(x) \
(((x) >> BIT_SHIFT_AID0_8197F) & BIT_MASK_AID0_8197F)
#define BIT_SET_AID0_8197F(x, v) (BIT_CLEAR_AID0_8197F(x) | BIT_AID0_8197F(v))
/* 2 REG_SND_PTCL_CTRL_8197F */
#define BIT_SHIFT_NDP_RX_STANDBY_TIMER_8197F 24
#define BIT_MASK_NDP_RX_STANDBY_TIMER_8197F 0xff
#define BIT_NDP_RX_STANDBY_TIMER_8197F(x) \
(((x) & BIT_MASK_NDP_RX_STANDBY_TIMER_8197F) \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8197F)
#define BITS_NDP_RX_STANDBY_TIMER_8197F \
(BIT_MASK_NDP_RX_STANDBY_TIMER_8197F \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8197F)
#define BIT_CLEAR_NDP_RX_STANDBY_TIMER_8197F(x) \
((x) & (~BITS_NDP_RX_STANDBY_TIMER_8197F))
#define BIT_GET_NDP_RX_STANDBY_TIMER_8197F(x) \
(((x) >> BIT_SHIFT_NDP_RX_STANDBY_TIMER_8197F) & \
BIT_MASK_NDP_RX_STANDBY_TIMER_8197F)
#define BIT_SET_NDP_RX_STANDBY_TIMER_8197F(x, v) \
(BIT_CLEAR_NDP_RX_STANDBY_TIMER_8197F(x) | \
BIT_NDP_RX_STANDBY_TIMER_8197F(v))
#define BIT_SHIFT_CSI_RPT_OFFSET_HT_8197F 16
#define BIT_MASK_CSI_RPT_OFFSET_HT_8197F 0xff
#define BIT_CSI_RPT_OFFSET_HT_8197F(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT_8197F) \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_8197F)
#define BITS_CSI_RPT_OFFSET_HT_8197F \
(BIT_MASK_CSI_RPT_OFFSET_HT_8197F << BIT_SHIFT_CSI_RPT_OFFSET_HT_8197F)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT_8197F(x) \
((x) & (~BITS_CSI_RPT_OFFSET_HT_8197F))
#define BIT_GET_CSI_RPT_OFFSET_HT_8197F(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT_8197F) & \
BIT_MASK_CSI_RPT_OFFSET_HT_8197F)
#define BIT_SET_CSI_RPT_OFFSET_HT_8197F(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT_8197F(x) | BIT_CSI_RPT_OFFSET_HT_8197F(v))
#define BIT_SHIFT_CSI_RPT_OFFSET_VHT_8197F 8
#define BIT_MASK_CSI_RPT_OFFSET_VHT_8197F 0xff
#define BIT_CSI_RPT_OFFSET_VHT_8197F(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_VHT_8197F) \
<< BIT_SHIFT_CSI_RPT_OFFSET_VHT_8197F)
#define BITS_CSI_RPT_OFFSET_VHT_8197F \
(BIT_MASK_CSI_RPT_OFFSET_VHT_8197F \
<< BIT_SHIFT_CSI_RPT_OFFSET_VHT_8197F)
#define BIT_CLEAR_CSI_RPT_OFFSET_VHT_8197F(x) \
((x) & (~BITS_CSI_RPT_OFFSET_VHT_8197F))
#define BIT_GET_CSI_RPT_OFFSET_VHT_8197F(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_VHT_8197F) & \
BIT_MASK_CSI_RPT_OFFSET_VHT_8197F)
#define BIT_SET_CSI_RPT_OFFSET_VHT_8197F(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_VHT_8197F(x) | \
BIT_CSI_RPT_OFFSET_VHT_8197F(v))
#define BIT_R_WMAC_USE_NSTS_8197F BIT(7)
#define BIT_R_DISABLE_CHECK_VHTSIGB_CRC_8197F BIT(6)
#define BIT_R_DISABLE_CHECK_VHTSIGA_CRC_8197F BIT(5)
#define BIT_R_WMAC_BFPARAM_SEL_8197F BIT(4)
#define BIT_R_WMAC_CSISEQ_SEL_8197F BIT(3)
#define BIT_R_WMAC_CSI_WITHHTC_EN_8197F BIT(2)
#define BIT_R_WMAC_HT_NDPA_EN_8197F BIT(1)
#define BIT_R_WMAC_VHT_NDPA_EN_8197F BIT(0)
/* 2 REG_RX_CSI_RPT_INFO_8197F */
/* 2 REG_NS_ARP_CTRL_8197F */
#define BIT_R_WMAC_NSARP_RSPEN_8197F BIT(15)
#define BIT_R_WMAC_NSARP_RARP_8197F BIT(9)
#define BIT_R_WMAC_NSARP_RIPV6_8197F BIT(8)
#define BIT_SHIFT_R_WMAC_NSARP_MODEN_8197F 6
#define BIT_MASK_R_WMAC_NSARP_MODEN_8197F 0x3
#define BIT_R_WMAC_NSARP_MODEN_8197F(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_MODEN_8197F) \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8197F)
#define BITS_R_WMAC_NSARP_MODEN_8197F \
(BIT_MASK_R_WMAC_NSARP_MODEN_8197F \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8197F)
#define BIT_CLEAR_R_WMAC_NSARP_MODEN_8197F(x) \
((x) & (~BITS_R_WMAC_NSARP_MODEN_8197F))
#define BIT_GET_R_WMAC_NSARP_MODEN_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_MODEN_8197F) & \
BIT_MASK_R_WMAC_NSARP_MODEN_8197F)
#define BIT_SET_R_WMAC_NSARP_MODEN_8197F(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_MODEN_8197F(x) | \
BIT_R_WMAC_NSARP_MODEN_8197F(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8197F 4
#define BIT_MASK_R_WMAC_NSARP_RSPFTP_8197F 0x3
#define BIT_R_WMAC_NSARP_RSPFTP_8197F(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPFTP_8197F) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8197F)
#define BITS_R_WMAC_NSARP_RSPFTP_8197F \
(BIT_MASK_R_WMAC_NSARP_RSPFTP_8197F \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8197F)
#define BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8197F(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPFTP_8197F))
#define BIT_GET_R_WMAC_NSARP_RSPFTP_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8197F) & \
BIT_MASK_R_WMAC_NSARP_RSPFTP_8197F)
#define BIT_SET_R_WMAC_NSARP_RSPFTP_8197F(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8197F(x) | \
BIT_R_WMAC_NSARP_RSPFTP_8197F(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8197F 0
#define BIT_MASK_R_WMAC_NSARP_RSPSEC_8197F 0xf
#define BIT_R_WMAC_NSARP_RSPSEC_8197F(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPSEC_8197F) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8197F)
#define BITS_R_WMAC_NSARP_RSPSEC_8197F \
(BIT_MASK_R_WMAC_NSARP_RSPSEC_8197F \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8197F)
#define BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8197F(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPSEC_8197F))
#define BIT_GET_R_WMAC_NSARP_RSPSEC_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8197F) & \
BIT_MASK_R_WMAC_NSARP_RSPSEC_8197F)
#define BIT_SET_R_WMAC_NSARP_RSPSEC_8197F(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8197F(x) | \
BIT_R_WMAC_NSARP_RSPSEC_8197F(v))
/* 2 REG_NS_ARP_INFO_8197F */
/* 2 REG_BEAMFORMING_INFO_NSARP_V1_8197F */
/* 2 REG_BEAMFORMING_INFO_NSARP_8197F */
/* 2 REG_NOT_VALID_8197F */
/* 2 REG_RSVD_0X740_8197F */
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG_8197F */
#define BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8197F 4
#define BIT_MASK_R_WMAC_CTX_SUBTYPE_8197F 0xf
#define BIT_R_WMAC_CTX_SUBTYPE_8197F(x) \
(((x) & BIT_MASK_R_WMAC_CTX_SUBTYPE_8197F) \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8197F)
#define BITS_R_WMAC_CTX_SUBTYPE_8197F \
(BIT_MASK_R_WMAC_CTX_SUBTYPE_8197F \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8197F)
#define BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8197F(x) \
((x) & (~BITS_R_WMAC_CTX_SUBTYPE_8197F))
#define BIT_GET_R_WMAC_CTX_SUBTYPE_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8197F) & \
BIT_MASK_R_WMAC_CTX_SUBTYPE_8197F)
#define BIT_SET_R_WMAC_CTX_SUBTYPE_8197F(x, v) \
(BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8197F(x) | \
BIT_R_WMAC_CTX_SUBTYPE_8197F(v))
#define BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8197F 0
#define BIT_MASK_R_WMAC_RTX_SUBTYPE_8197F 0xf
#define BIT_R_WMAC_RTX_SUBTYPE_8197F(x) \
(((x) & BIT_MASK_R_WMAC_RTX_SUBTYPE_8197F) \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8197F)
#define BITS_R_WMAC_RTX_SUBTYPE_8197F \
(BIT_MASK_R_WMAC_RTX_SUBTYPE_8197F \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8197F)
#define BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8197F(x) \
((x) & (~BITS_R_WMAC_RTX_SUBTYPE_8197F))
#define BIT_GET_R_WMAC_RTX_SUBTYPE_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8197F) & \
BIT_MASK_R_WMAC_RTX_SUBTYPE_8197F)
#define BIT_SET_R_WMAC_RTX_SUBTYPE_8197F(x, v) \
(BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8197F(x) | \
BIT_R_WMAC_RTX_SUBTYPE_8197F(v))
/* 2 REG_WMAC_SWAES_CFG_8197F */
/* 2 REG_BT_COEX_V2_8197F */
#define BIT_GNT_BT_POLARITY_8197F BIT(12)
#define BIT_GNT_BT_BYPASS_PRIORITY_8197F BIT(8)
#define BIT_SHIFT_TIMER_8197F 0
#define BIT_MASK_TIMER_8197F 0xff
#define BIT_TIMER_8197F(x) \
(((x) & BIT_MASK_TIMER_8197F) << BIT_SHIFT_TIMER_8197F)
#define BITS_TIMER_8197F (BIT_MASK_TIMER_8197F << BIT_SHIFT_TIMER_8197F)
#define BIT_CLEAR_TIMER_8197F(x) ((x) & (~BITS_TIMER_8197F))
#define BIT_GET_TIMER_8197F(x) \
(((x) >> BIT_SHIFT_TIMER_8197F) & BIT_MASK_TIMER_8197F)
#define BIT_SET_TIMER_8197F(x, v) \
(BIT_CLEAR_TIMER_8197F(x) | BIT_TIMER_8197F(v))
/* 2 REG_BT_COEX_8197F */
#define BIT_R_GNT_BT_RFC_SW_8197F BIT(12)
#define BIT_R_GNT_BT_RFC_SW_EN_8197F BIT(11)
#define BIT_R_GNT_BT_BB_SW_8197F BIT(10)
#define BIT_R_GNT_BT_BB_SW_EN_8197F BIT(9)
#define BIT_R_BT_CNT_THREN_8197F BIT(8)
#define BIT_SHIFT_R_BT_CNT_THR_8197F 0
#define BIT_MASK_R_BT_CNT_THR_8197F 0xff
#define BIT_R_BT_CNT_THR_8197F(x) \
(((x) & BIT_MASK_R_BT_CNT_THR_8197F) << BIT_SHIFT_R_BT_CNT_THR_8197F)
#define BITS_R_BT_CNT_THR_8197F \
(BIT_MASK_R_BT_CNT_THR_8197F << BIT_SHIFT_R_BT_CNT_THR_8197F)
#define BIT_CLEAR_R_BT_CNT_THR_8197F(x) ((x) & (~BITS_R_BT_CNT_THR_8197F))
#define BIT_GET_R_BT_CNT_THR_8197F(x) \
(((x) >> BIT_SHIFT_R_BT_CNT_THR_8197F) & BIT_MASK_R_BT_CNT_THR_8197F)
#define BIT_SET_R_BT_CNT_THR_8197F(x, v) \
(BIT_CLEAR_R_BT_CNT_THR_8197F(x) | BIT_R_BT_CNT_THR_8197F(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_8197F */
#define BIT_WLRX_TER_BY_CTL_8197F BIT(43)
#define BIT_WLRX_TER_BY_AD_8197F BIT(42)
#define BIT_ANT_DIVERSITY_SEL_8197F BIT(41)
#define BIT_ANTSEL_FOR_BT_CTRL_EN_8197F BIT(40)
#define BIT_WLACT_LOW_GNTWL_EN_8197F BIT(34)
#define BIT_WLACT_HIGH_GNTBT_EN_8197F BIT(33)
#define BIT_SHIFT_RXMYRTS_NAV_V1_8197F 8
#define BIT_MASK_RXMYRTS_NAV_V1_8197F 0xff
#define BIT_RXMYRTS_NAV_V1_8197F(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_V1_8197F) \
<< BIT_SHIFT_RXMYRTS_NAV_V1_8197F)
#define BITS_RXMYRTS_NAV_V1_8197F \
(BIT_MASK_RXMYRTS_NAV_V1_8197F << BIT_SHIFT_RXMYRTS_NAV_V1_8197F)
#define BIT_CLEAR_RXMYRTS_NAV_V1_8197F(x) ((x) & (~BITS_RXMYRTS_NAV_V1_8197F))
#define BIT_GET_RXMYRTS_NAV_V1_8197F(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_V1_8197F) & \
BIT_MASK_RXMYRTS_NAV_V1_8197F)
#define BIT_SET_RXMYRTS_NAV_V1_8197F(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_V1_8197F(x) | BIT_RXMYRTS_NAV_V1_8197F(v))
#define BIT_SHIFT_RTSRST_V1_8197F 0
#define BIT_MASK_RTSRST_V1_8197F 0xff
#define BIT_RTSRST_V1_8197F(x) \
(((x) & BIT_MASK_RTSRST_V1_8197F) << BIT_SHIFT_RTSRST_V1_8197F)
#define BITS_RTSRST_V1_8197F \
(BIT_MASK_RTSRST_V1_8197F << BIT_SHIFT_RTSRST_V1_8197F)
#define BIT_CLEAR_RTSRST_V1_8197F(x) ((x) & (~BITS_RTSRST_V1_8197F))
#define BIT_GET_RTSRST_V1_8197F(x) \
(((x) >> BIT_SHIFT_RTSRST_V1_8197F) & BIT_MASK_RTSRST_V1_8197F)
#define BIT_SET_RTSRST_V1_8197F(x, v) \
(BIT_CLEAR_RTSRST_V1_8197F(x) | BIT_RTSRST_V1_8197F(v))
/* 2 REG_BT_COEX_ENHANCED_INTR_CTRL_8197F */
#define BIT_SHIFT_BT_STAT_DELAY_8197F 12
#define BIT_MASK_BT_STAT_DELAY_8197F 0xf
#define BIT_BT_STAT_DELAY_8197F(x) \
(((x) & BIT_MASK_BT_STAT_DELAY_8197F) << BIT_SHIFT_BT_STAT_DELAY_8197F)
#define BITS_BT_STAT_DELAY_8197F \
(BIT_MASK_BT_STAT_DELAY_8197F << BIT_SHIFT_BT_STAT_DELAY_8197F)
#define BIT_CLEAR_BT_STAT_DELAY_8197F(x) ((x) & (~BITS_BT_STAT_DELAY_8197F))
#define BIT_GET_BT_STAT_DELAY_8197F(x) \
(((x) >> BIT_SHIFT_BT_STAT_DELAY_8197F) & BIT_MASK_BT_STAT_DELAY_8197F)
#define BIT_SET_BT_STAT_DELAY_8197F(x, v) \
(BIT_CLEAR_BT_STAT_DELAY_8197F(x) | BIT_BT_STAT_DELAY_8197F(v))
#define BIT_SHIFT_BT_TRX_INIT_DETECT_8197F 8
#define BIT_MASK_BT_TRX_INIT_DETECT_8197F 0xf
#define BIT_BT_TRX_INIT_DETECT_8197F(x) \
(((x) & BIT_MASK_BT_TRX_INIT_DETECT_8197F) \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8197F)
#define BITS_BT_TRX_INIT_DETECT_8197F \
(BIT_MASK_BT_TRX_INIT_DETECT_8197F \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8197F)
#define BIT_CLEAR_BT_TRX_INIT_DETECT_8197F(x) \
((x) & (~BITS_BT_TRX_INIT_DETECT_8197F))
#define BIT_GET_BT_TRX_INIT_DETECT_8197F(x) \
(((x) >> BIT_SHIFT_BT_TRX_INIT_DETECT_8197F) & \
BIT_MASK_BT_TRX_INIT_DETECT_8197F)
#define BIT_SET_BT_TRX_INIT_DETECT_8197F(x, v) \
(BIT_CLEAR_BT_TRX_INIT_DETECT_8197F(x) | \
BIT_BT_TRX_INIT_DETECT_8197F(v))
#define BIT_SHIFT_BT_PRI_DETECT_TO_8197F 4
#define BIT_MASK_BT_PRI_DETECT_TO_8197F 0xf
#define BIT_BT_PRI_DETECT_TO_8197F(x) \
(((x) & BIT_MASK_BT_PRI_DETECT_TO_8197F) \
<< BIT_SHIFT_BT_PRI_DETECT_TO_8197F)
#define BITS_BT_PRI_DETECT_TO_8197F \
(BIT_MASK_BT_PRI_DETECT_TO_8197F << BIT_SHIFT_BT_PRI_DETECT_TO_8197F)
#define BIT_CLEAR_BT_PRI_DETECT_TO_8197F(x) \
((x) & (~BITS_BT_PRI_DETECT_TO_8197F))
#define BIT_GET_BT_PRI_DETECT_TO_8197F(x) \
(((x) >> BIT_SHIFT_BT_PRI_DETECT_TO_8197F) & \
BIT_MASK_BT_PRI_DETECT_TO_8197F)
#define BIT_SET_BT_PRI_DETECT_TO_8197F(x, v) \
(BIT_CLEAR_BT_PRI_DETECT_TO_8197F(x) | BIT_BT_PRI_DETECT_TO_8197F(v))
#define BIT_R_GRANTALL_WLMASK_8197F BIT(3)
#define BIT_STATIS_BT_EN_8197F BIT(2)
#define BIT_WL_ACT_MASK_ENABLE_8197F BIT(1)
#define BIT_ENHANCED_BT_8197F BIT(0)
/* 2 REG_BT_ACT_STATISTICS_8197F */
#define BIT_SHIFT_STATIS_BT_LO_RX_8197F (48 & CPU_OPT_WIDTH)
#define BIT_MASK_STATIS_BT_LO_RX_8197F 0xffff
#define BIT_STATIS_BT_LO_RX_8197F(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX_8197F) \
<< BIT_SHIFT_STATIS_BT_LO_RX_8197F)
#define BITS_STATIS_BT_LO_RX_8197F \
(BIT_MASK_STATIS_BT_LO_RX_8197F << BIT_SHIFT_STATIS_BT_LO_RX_8197F)
#define BIT_CLEAR_STATIS_BT_LO_RX_8197F(x) ((x) & (~BITS_STATIS_BT_LO_RX_8197F))
#define BIT_GET_STATIS_BT_LO_RX_8197F(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX_8197F) & \
BIT_MASK_STATIS_BT_LO_RX_8197F)
#define BIT_SET_STATIS_BT_LO_RX_8197F(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX_8197F(x) | BIT_STATIS_BT_LO_RX_8197F(v))
#define BIT_SHIFT_STATIS_BT_LO_TX_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_STATIS_BT_LO_TX_8197F 0xffff
#define BIT_STATIS_BT_LO_TX_8197F(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX_8197F) \
<< BIT_SHIFT_STATIS_BT_LO_TX_8197F)
#define BITS_STATIS_BT_LO_TX_8197F \
(BIT_MASK_STATIS_BT_LO_TX_8197F << BIT_SHIFT_STATIS_BT_LO_TX_8197F)
#define BIT_CLEAR_STATIS_BT_LO_TX_8197F(x) ((x) & (~BITS_STATIS_BT_LO_TX_8197F))
#define BIT_GET_STATIS_BT_LO_TX_8197F(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX_8197F) & \
BIT_MASK_STATIS_BT_LO_TX_8197F)
#define BIT_SET_STATIS_BT_LO_TX_8197F(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX_8197F(x) | BIT_STATIS_BT_LO_TX_8197F(v))
#define BIT_SHIFT_STATIS_BT_HI_RX_8197F 16
#define BIT_MASK_STATIS_BT_HI_RX_8197F 0xffff
#define BIT_STATIS_BT_HI_RX_8197F(x) \
(((x) & BIT_MASK_STATIS_BT_HI_RX_8197F) \
<< BIT_SHIFT_STATIS_BT_HI_RX_8197F)
#define BITS_STATIS_BT_HI_RX_8197F \
(BIT_MASK_STATIS_BT_HI_RX_8197F << BIT_SHIFT_STATIS_BT_HI_RX_8197F)
#define BIT_CLEAR_STATIS_BT_HI_RX_8197F(x) ((x) & (~BITS_STATIS_BT_HI_RX_8197F))
#define BIT_GET_STATIS_BT_HI_RX_8197F(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_RX_8197F) & \
BIT_MASK_STATIS_BT_HI_RX_8197F)
#define BIT_SET_STATIS_BT_HI_RX_8197F(x, v) \
(BIT_CLEAR_STATIS_BT_HI_RX_8197F(x) | BIT_STATIS_BT_HI_RX_8197F(v))
#define BIT_SHIFT_STATIS_BT_HI_TX_8197F 0
#define BIT_MASK_STATIS_BT_HI_TX_8197F 0xffff
#define BIT_STATIS_BT_HI_TX_8197F(x) \
(((x) & BIT_MASK_STATIS_BT_HI_TX_8197F) \
<< BIT_SHIFT_STATIS_BT_HI_TX_8197F)
#define BITS_STATIS_BT_HI_TX_8197F \
(BIT_MASK_STATIS_BT_HI_TX_8197F << BIT_SHIFT_STATIS_BT_HI_TX_8197F)
#define BIT_CLEAR_STATIS_BT_HI_TX_8197F(x) ((x) & (~BITS_STATIS_BT_HI_TX_8197F))
#define BIT_GET_STATIS_BT_HI_TX_8197F(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_TX_8197F) & \
BIT_MASK_STATIS_BT_HI_TX_8197F)
#define BIT_SET_STATIS_BT_HI_TX_8197F(x, v) \
(BIT_CLEAR_STATIS_BT_HI_TX_8197F(x) | BIT_STATIS_BT_HI_TX_8197F(v))
/* 2 REG_BT_STATISTICS_CONTROL_REGISTER_8197F */
#define BIT_SHIFT_R_BT_CMD_RPT_8197F 16
#define BIT_MASK_R_BT_CMD_RPT_8197F 0xffff
#define BIT_R_BT_CMD_RPT_8197F(x) \
(((x) & BIT_MASK_R_BT_CMD_RPT_8197F) << BIT_SHIFT_R_BT_CMD_RPT_8197F)
#define BITS_R_BT_CMD_RPT_8197F \
(BIT_MASK_R_BT_CMD_RPT_8197F << BIT_SHIFT_R_BT_CMD_RPT_8197F)
#define BIT_CLEAR_R_BT_CMD_RPT_8197F(x) ((x) & (~BITS_R_BT_CMD_RPT_8197F))
#define BIT_GET_R_BT_CMD_RPT_8197F(x) \
(((x) >> BIT_SHIFT_R_BT_CMD_RPT_8197F) & BIT_MASK_R_BT_CMD_RPT_8197F)
#define BIT_SET_R_BT_CMD_RPT_8197F(x, v) \
(BIT_CLEAR_R_BT_CMD_RPT_8197F(x) | BIT_R_BT_CMD_RPT_8197F(v))
#define BIT_SHIFT_R_RPT_FROM_BT_8197F 8
#define BIT_MASK_R_RPT_FROM_BT_8197F 0xff
#define BIT_R_RPT_FROM_BT_8197F(x) \
(((x) & BIT_MASK_R_RPT_FROM_BT_8197F) << BIT_SHIFT_R_RPT_FROM_BT_8197F)
#define BITS_R_RPT_FROM_BT_8197F \
(BIT_MASK_R_RPT_FROM_BT_8197F << BIT_SHIFT_R_RPT_FROM_BT_8197F)
#define BIT_CLEAR_R_RPT_FROM_BT_8197F(x) ((x) & (~BITS_R_RPT_FROM_BT_8197F))
#define BIT_GET_R_RPT_FROM_BT_8197F(x) \
(((x) >> BIT_SHIFT_R_RPT_FROM_BT_8197F) & BIT_MASK_R_RPT_FROM_BT_8197F)
#define BIT_SET_R_RPT_FROM_BT_8197F(x, v) \
(BIT_CLEAR_R_RPT_FROM_BT_8197F(x) | BIT_R_RPT_FROM_BT_8197F(v))
#define BIT_SHIFT_BT_HID_ISR_SET_8197F 6
#define BIT_MASK_BT_HID_ISR_SET_8197F 0x3
#define BIT_BT_HID_ISR_SET_8197F(x) \
(((x) & BIT_MASK_BT_HID_ISR_SET_8197F) \
<< BIT_SHIFT_BT_HID_ISR_SET_8197F)
#define BITS_BT_HID_ISR_SET_8197F \
(BIT_MASK_BT_HID_ISR_SET_8197F << BIT_SHIFT_BT_HID_ISR_SET_8197F)
#define BIT_CLEAR_BT_HID_ISR_SET_8197F(x) ((x) & (~BITS_BT_HID_ISR_SET_8197F))
#define BIT_GET_BT_HID_ISR_SET_8197F(x) \
(((x) >> BIT_SHIFT_BT_HID_ISR_SET_8197F) & \
BIT_MASK_BT_HID_ISR_SET_8197F)
#define BIT_SET_BT_HID_ISR_SET_8197F(x, v) \
(BIT_CLEAR_BT_HID_ISR_SET_8197F(x) | BIT_BT_HID_ISR_SET_8197F(v))
#define BIT_TDMA_BT_START_NOTIFY_8197F BIT(5)
#define BIT_ENABLE_TDMA_FW_MODE_8197F BIT(4)
#define BIT_ENABLE_PTA_TDMA_MODE_8197F BIT(3)
#define BIT_ENABLE_COEXIST_TAB_IN_TDMA_8197F BIT(2)
#define BIT_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA_8197F BIT(1)
#define BIT_RTK_BT_ENABLE_8197F BIT(0)
/* 2 REG_BT_STATUS_REPORT_REGISTER_8197F */
#define BIT_SHIFT_BT_PROFILE_8197F 24
#define BIT_MASK_BT_PROFILE_8197F 0xff
#define BIT_BT_PROFILE_8197F(x) \
(((x) & BIT_MASK_BT_PROFILE_8197F) << BIT_SHIFT_BT_PROFILE_8197F)
#define BITS_BT_PROFILE_8197F \
(BIT_MASK_BT_PROFILE_8197F << BIT_SHIFT_BT_PROFILE_8197F)
#define BIT_CLEAR_BT_PROFILE_8197F(x) ((x) & (~BITS_BT_PROFILE_8197F))
#define BIT_GET_BT_PROFILE_8197F(x) \
(((x) >> BIT_SHIFT_BT_PROFILE_8197F) & BIT_MASK_BT_PROFILE_8197F)
#define BIT_SET_BT_PROFILE_8197F(x, v) \
(BIT_CLEAR_BT_PROFILE_8197F(x) | BIT_BT_PROFILE_8197F(v))
#define BIT_SHIFT_BT_POWER_8197F 16
#define BIT_MASK_BT_POWER_8197F 0xff
#define BIT_BT_POWER_8197F(x) \
(((x) & BIT_MASK_BT_POWER_8197F) << BIT_SHIFT_BT_POWER_8197F)
#define BITS_BT_POWER_8197F \
(BIT_MASK_BT_POWER_8197F << BIT_SHIFT_BT_POWER_8197F)
#define BIT_CLEAR_BT_POWER_8197F(x) ((x) & (~BITS_BT_POWER_8197F))
#define BIT_GET_BT_POWER_8197F(x) \
(((x) >> BIT_SHIFT_BT_POWER_8197F) & BIT_MASK_BT_POWER_8197F)
#define BIT_SET_BT_POWER_8197F(x, v) \
(BIT_CLEAR_BT_POWER_8197F(x) | BIT_BT_POWER_8197F(v))
#define BIT_SHIFT_BT_PREDECT_STATUS_8197F 8
#define BIT_MASK_BT_PREDECT_STATUS_8197F 0xff
#define BIT_BT_PREDECT_STATUS_8197F(x) \
(((x) & BIT_MASK_BT_PREDECT_STATUS_8197F) \
<< BIT_SHIFT_BT_PREDECT_STATUS_8197F)
#define BITS_BT_PREDECT_STATUS_8197F \
(BIT_MASK_BT_PREDECT_STATUS_8197F << BIT_SHIFT_BT_PREDECT_STATUS_8197F)
#define BIT_CLEAR_BT_PREDECT_STATUS_8197F(x) \
((x) & (~BITS_BT_PREDECT_STATUS_8197F))
#define BIT_GET_BT_PREDECT_STATUS_8197F(x) \
(((x) >> BIT_SHIFT_BT_PREDECT_STATUS_8197F) & \
BIT_MASK_BT_PREDECT_STATUS_8197F)
#define BIT_SET_BT_PREDECT_STATUS_8197F(x, v) \
(BIT_CLEAR_BT_PREDECT_STATUS_8197F(x) | BIT_BT_PREDECT_STATUS_8197F(v))
#define BIT_SHIFT_BT_CMD_INFO_8197F 0
#define BIT_MASK_BT_CMD_INFO_8197F 0xff
#define BIT_BT_CMD_INFO_8197F(x) \
(((x) & BIT_MASK_BT_CMD_INFO_8197F) << BIT_SHIFT_BT_CMD_INFO_8197F)
#define BITS_BT_CMD_INFO_8197F \
(BIT_MASK_BT_CMD_INFO_8197F << BIT_SHIFT_BT_CMD_INFO_8197F)
#define BIT_CLEAR_BT_CMD_INFO_8197F(x) ((x) & (~BITS_BT_CMD_INFO_8197F))
#define BIT_GET_BT_CMD_INFO_8197F(x) \
(((x) >> BIT_SHIFT_BT_CMD_INFO_8197F) & BIT_MASK_BT_CMD_INFO_8197F)
#define BIT_SET_BT_CMD_INFO_8197F(x, v) \
(BIT_CLEAR_BT_CMD_INFO_8197F(x) | BIT_BT_CMD_INFO_8197F(v))
/* 2 REG_BT_INTERRUPT_CONTROL_REGISTER_8197F */
#define BIT_EN_MAC_NULL_PKT_NOTIFY_8197F BIT(31)
#define BIT_EN_WLAN_RPT_AND_BT_QUERY_8197F BIT(30)
#define BIT_EN_BT_STSTUS_RPT_8197F BIT(29)
#define BIT_EN_BT_POWER_8197F BIT(28)
#define BIT_EN_BT_CHANNEL_8197F BIT(27)
#define BIT_EN_BT_SLOT_CHANGE_8197F BIT(26)
#define BIT_EN_BT_PROFILE_OR_HID_8197F BIT(25)
#define BIT_WLAN_RPT_NOTIFY_8197F BIT(24)
#define BIT_SHIFT_WLAN_RPT_DATA_8197F 16
#define BIT_MASK_WLAN_RPT_DATA_8197F 0xff
#define BIT_WLAN_RPT_DATA_8197F(x) \
(((x) & BIT_MASK_WLAN_RPT_DATA_8197F) << BIT_SHIFT_WLAN_RPT_DATA_8197F)
#define BITS_WLAN_RPT_DATA_8197F \
(BIT_MASK_WLAN_RPT_DATA_8197F << BIT_SHIFT_WLAN_RPT_DATA_8197F)
#define BIT_CLEAR_WLAN_RPT_DATA_8197F(x) ((x) & (~BITS_WLAN_RPT_DATA_8197F))
#define BIT_GET_WLAN_RPT_DATA_8197F(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_DATA_8197F) & BIT_MASK_WLAN_RPT_DATA_8197F)
#define BIT_SET_WLAN_RPT_DATA_8197F(x, v) \
(BIT_CLEAR_WLAN_RPT_DATA_8197F(x) | BIT_WLAN_RPT_DATA_8197F(v))
#define BIT_SHIFT_CMD_ID_8197F 8
#define BIT_MASK_CMD_ID_8197F 0xff
#define BIT_CMD_ID_8197F(x) \
(((x) & BIT_MASK_CMD_ID_8197F) << BIT_SHIFT_CMD_ID_8197F)
#define BITS_CMD_ID_8197F (BIT_MASK_CMD_ID_8197F << BIT_SHIFT_CMD_ID_8197F)
#define BIT_CLEAR_CMD_ID_8197F(x) ((x) & (~BITS_CMD_ID_8197F))
#define BIT_GET_CMD_ID_8197F(x) \
(((x) >> BIT_SHIFT_CMD_ID_8197F) & BIT_MASK_CMD_ID_8197F)
#define BIT_SET_CMD_ID_8197F(x, v) \
(BIT_CLEAR_CMD_ID_8197F(x) | BIT_CMD_ID_8197F(v))
#define BIT_SHIFT_BT_DATA_8197F 0
#define BIT_MASK_BT_DATA_8197F 0xff
#define BIT_BT_DATA_8197F(x) \
(((x) & BIT_MASK_BT_DATA_8197F) << BIT_SHIFT_BT_DATA_8197F)
#define BITS_BT_DATA_8197F (BIT_MASK_BT_DATA_8197F << BIT_SHIFT_BT_DATA_8197F)
#define BIT_CLEAR_BT_DATA_8197F(x) ((x) & (~BITS_BT_DATA_8197F))
#define BIT_GET_BT_DATA_8197F(x) \
(((x) >> BIT_SHIFT_BT_DATA_8197F) & BIT_MASK_BT_DATA_8197F)
#define BIT_SET_BT_DATA_8197F(x, v) \
(BIT_CLEAR_BT_DATA_8197F(x) | BIT_BT_DATA_8197F(v))
/* 2 REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8197F */
#define BIT_SHIFT_WLAN_RPT_TO_8197F 0
#define BIT_MASK_WLAN_RPT_TO_8197F 0xff
#define BIT_WLAN_RPT_TO_8197F(x) \
(((x) & BIT_MASK_WLAN_RPT_TO_8197F) << BIT_SHIFT_WLAN_RPT_TO_8197F)
#define BITS_WLAN_RPT_TO_8197F \
(BIT_MASK_WLAN_RPT_TO_8197F << BIT_SHIFT_WLAN_RPT_TO_8197F)
#define BIT_CLEAR_WLAN_RPT_TO_8197F(x) ((x) & (~BITS_WLAN_RPT_TO_8197F))
#define BIT_GET_WLAN_RPT_TO_8197F(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_TO_8197F) & BIT_MASK_WLAN_RPT_TO_8197F)
#define BIT_SET_WLAN_RPT_TO_8197F(x, v) \
(BIT_CLEAR_WLAN_RPT_TO_8197F(x) | BIT_WLAN_RPT_TO_8197F(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8197F */
#define BIT_SHIFT_ISOLATION_CHK_8197F 1
#define BIT_MASK_ISOLATION_CHK_8197F 0x7fffffffffffffffffffL
#define BIT_ISOLATION_CHK_8197F(x) \
(((x) & BIT_MASK_ISOLATION_CHK_8197F) << BIT_SHIFT_ISOLATION_CHK_8197F)
#define BITS_ISOLATION_CHK_8197F \
(BIT_MASK_ISOLATION_CHK_8197F << BIT_SHIFT_ISOLATION_CHK_8197F)
#define BIT_CLEAR_ISOLATION_CHK_8197F(x) ((x) & (~BITS_ISOLATION_CHK_8197F))
#define BIT_GET_ISOLATION_CHK_8197F(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_8197F) & BIT_MASK_ISOLATION_CHK_8197F)
#define BIT_SET_ISOLATION_CHK_8197F(x, v) \
(BIT_CLEAR_ISOLATION_CHK_8197F(x) | BIT_ISOLATION_CHK_8197F(v))
#define BIT_ISOLATION_EN_8197F BIT(0)
/* 2 REG_BT_INTERRUPT_STATUS_REGISTER_8197F */
#define BIT_BT_HID_ISR_8197F BIT(7)
#define BIT_BT_QUERY_ISR_8197F BIT(6)
#define BIT_MAC_NULL_PKT_NOTIFY_ISR_8197F BIT(5)
#define BIT_WLAN_RPT_ISR_8197F BIT(4)
#define BIT_BT_POWER_ISR_8197F BIT(3)
#define BIT_BT_CHANNEL_ISR_8197F BIT(2)
#define BIT_BT_SLOT_CHANGE_ISR_8197F BIT(1)
#define BIT_BT_PROFILE_ISR_8197F BIT(0)
/* 2 REG_BT_TDMA_TIME_REGISTER_8197F */
#define BIT_SHIFT_BT_TIME_8197F 6
#define BIT_MASK_BT_TIME_8197F 0x3ffffff
#define BIT_BT_TIME_8197F(x) \
(((x) & BIT_MASK_BT_TIME_8197F) << BIT_SHIFT_BT_TIME_8197F)
#define BITS_BT_TIME_8197F (BIT_MASK_BT_TIME_8197F << BIT_SHIFT_BT_TIME_8197F)
#define BIT_CLEAR_BT_TIME_8197F(x) ((x) & (~BITS_BT_TIME_8197F))
#define BIT_GET_BT_TIME_8197F(x) \
(((x) >> BIT_SHIFT_BT_TIME_8197F) & BIT_MASK_BT_TIME_8197F)
#define BIT_SET_BT_TIME_8197F(x, v) \
(BIT_CLEAR_BT_TIME_8197F(x) | BIT_BT_TIME_8197F(v))
#define BIT_SHIFT_BT_RPT_SAMPLE_RATE_8197F 0
#define BIT_MASK_BT_RPT_SAMPLE_RATE_8197F 0x3f
#define BIT_BT_RPT_SAMPLE_RATE_8197F(x) \
(((x) & BIT_MASK_BT_RPT_SAMPLE_RATE_8197F) \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8197F)
#define BITS_BT_RPT_SAMPLE_RATE_8197F \
(BIT_MASK_BT_RPT_SAMPLE_RATE_8197F \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8197F)
#define BIT_CLEAR_BT_RPT_SAMPLE_RATE_8197F(x) \
((x) & (~BITS_BT_RPT_SAMPLE_RATE_8197F))
#define BIT_GET_BT_RPT_SAMPLE_RATE_8197F(x) \
(((x) >> BIT_SHIFT_BT_RPT_SAMPLE_RATE_8197F) & \
BIT_MASK_BT_RPT_SAMPLE_RATE_8197F)
#define BIT_SET_BT_RPT_SAMPLE_RATE_8197F(x, v) \
(BIT_CLEAR_BT_RPT_SAMPLE_RATE_8197F(x) | \
BIT_BT_RPT_SAMPLE_RATE_8197F(v))
/* 2 REG_BT_ACT_REGISTER_8197F */
#define BIT_SHIFT_BT_EISR_EN_8197F 16
#define BIT_MASK_BT_EISR_EN_8197F 0xff
#define BIT_BT_EISR_EN_8197F(x) \
(((x) & BIT_MASK_BT_EISR_EN_8197F) << BIT_SHIFT_BT_EISR_EN_8197F)
#define BITS_BT_EISR_EN_8197F \
(BIT_MASK_BT_EISR_EN_8197F << BIT_SHIFT_BT_EISR_EN_8197F)
#define BIT_CLEAR_BT_EISR_EN_8197F(x) ((x) & (~BITS_BT_EISR_EN_8197F))
#define BIT_GET_BT_EISR_EN_8197F(x) \
(((x) >> BIT_SHIFT_BT_EISR_EN_8197F) & BIT_MASK_BT_EISR_EN_8197F)
#define BIT_SET_BT_EISR_EN_8197F(x, v) \
(BIT_CLEAR_BT_EISR_EN_8197F(x) | BIT_BT_EISR_EN_8197F(v))
#define BIT_BT_ACT_FALLING_ISR_8197F BIT(10)
#define BIT_BT_ACT_RISING_ISR_8197F BIT(9)
#define BIT_TDMA_TO_ISR_8197F BIT(8)
#define BIT_SHIFT_BT_CH_8197F 0
#define BIT_MASK_BT_CH_8197F 0xff
#define BIT_BT_CH_8197F(x) \
(((x) & BIT_MASK_BT_CH_8197F) << BIT_SHIFT_BT_CH_8197F)
#define BITS_BT_CH_8197F (BIT_MASK_BT_CH_8197F << BIT_SHIFT_BT_CH_8197F)
#define BIT_CLEAR_BT_CH_8197F(x) ((x) & (~BITS_BT_CH_8197F))
#define BIT_GET_BT_CH_8197F(x) \
(((x) >> BIT_SHIFT_BT_CH_8197F) & BIT_MASK_BT_CH_8197F)
#define BIT_SET_BT_CH_8197F(x, v) \
(BIT_CLEAR_BT_CH_8197F(x) | BIT_BT_CH_8197F(v))
/* 2 REG_OBFF_CTRL_BASIC_8197F */
#define BIT_OBFF_EN_V1_8197F BIT(31)
#define BIT_SHIFT_OBFF_STATE_V1_8197F 28
#define BIT_MASK_OBFF_STATE_V1_8197F 0x3
#define BIT_OBFF_STATE_V1_8197F(x) \
(((x) & BIT_MASK_OBFF_STATE_V1_8197F) << BIT_SHIFT_OBFF_STATE_V1_8197F)
#define BITS_OBFF_STATE_V1_8197F \
(BIT_MASK_OBFF_STATE_V1_8197F << BIT_SHIFT_OBFF_STATE_V1_8197F)
#define BIT_CLEAR_OBFF_STATE_V1_8197F(x) ((x) & (~BITS_OBFF_STATE_V1_8197F))
#define BIT_GET_OBFF_STATE_V1_8197F(x) \
(((x) >> BIT_SHIFT_OBFF_STATE_V1_8197F) & BIT_MASK_OBFF_STATE_V1_8197F)
#define BIT_SET_OBFF_STATE_V1_8197F(x, v) \
(BIT_CLEAR_OBFF_STATE_V1_8197F(x) | BIT_OBFF_STATE_V1_8197F(v))
#define BIT_OBFF_ACT_RXDMA_EN_8197F BIT(27)
#define BIT_OBFF_BLOCK_INT_EN_8197F BIT(26)
#define BIT_OBFF_AUTOACT_EN_8197F BIT(25)
#define BIT_OBFF_AUTOIDLE_EN_8197F BIT(24)
#define BIT_SHIFT_WAKE_MAX_PLS_8197F 20
#define BIT_MASK_WAKE_MAX_PLS_8197F 0x7
#define BIT_WAKE_MAX_PLS_8197F(x) \
(((x) & BIT_MASK_WAKE_MAX_PLS_8197F) << BIT_SHIFT_WAKE_MAX_PLS_8197F)
#define BITS_WAKE_MAX_PLS_8197F \
(BIT_MASK_WAKE_MAX_PLS_8197F << BIT_SHIFT_WAKE_MAX_PLS_8197F)
#define BIT_CLEAR_WAKE_MAX_PLS_8197F(x) ((x) & (~BITS_WAKE_MAX_PLS_8197F))
#define BIT_GET_WAKE_MAX_PLS_8197F(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_PLS_8197F) & BIT_MASK_WAKE_MAX_PLS_8197F)
#define BIT_SET_WAKE_MAX_PLS_8197F(x, v) \
(BIT_CLEAR_WAKE_MAX_PLS_8197F(x) | BIT_WAKE_MAX_PLS_8197F(v))
#define BIT_SHIFT_WAKE_MIN_PLS_8197F 16
#define BIT_MASK_WAKE_MIN_PLS_8197F 0x7
#define BIT_WAKE_MIN_PLS_8197F(x) \
(((x) & BIT_MASK_WAKE_MIN_PLS_8197F) << BIT_SHIFT_WAKE_MIN_PLS_8197F)
#define BITS_WAKE_MIN_PLS_8197F \
(BIT_MASK_WAKE_MIN_PLS_8197F << BIT_SHIFT_WAKE_MIN_PLS_8197F)
#define BIT_CLEAR_WAKE_MIN_PLS_8197F(x) ((x) & (~BITS_WAKE_MIN_PLS_8197F))
#define BIT_GET_WAKE_MIN_PLS_8197F(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_PLS_8197F) & BIT_MASK_WAKE_MIN_PLS_8197F)
#define BIT_SET_WAKE_MIN_PLS_8197F(x, v) \
(BIT_CLEAR_WAKE_MIN_PLS_8197F(x) | BIT_WAKE_MIN_PLS_8197F(v))
#define BIT_SHIFT_WAKE_MAX_F2F_8197F 12
#define BIT_MASK_WAKE_MAX_F2F_8197F 0x7
#define BIT_WAKE_MAX_F2F_8197F(x) \
(((x) & BIT_MASK_WAKE_MAX_F2F_8197F) << BIT_SHIFT_WAKE_MAX_F2F_8197F)
#define BITS_WAKE_MAX_F2F_8197F \
(BIT_MASK_WAKE_MAX_F2F_8197F << BIT_SHIFT_WAKE_MAX_F2F_8197F)
#define BIT_CLEAR_WAKE_MAX_F2F_8197F(x) ((x) & (~BITS_WAKE_MAX_F2F_8197F))
#define BIT_GET_WAKE_MAX_F2F_8197F(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_F2F_8197F) & BIT_MASK_WAKE_MAX_F2F_8197F)
#define BIT_SET_WAKE_MAX_F2F_8197F(x, v) \
(BIT_CLEAR_WAKE_MAX_F2F_8197F(x) | BIT_WAKE_MAX_F2F_8197F(v))
#define BIT_SHIFT_WAKE_MIN_F2F_8197F 8
#define BIT_MASK_WAKE_MIN_F2F_8197F 0x7
#define BIT_WAKE_MIN_F2F_8197F(x) \
(((x) & BIT_MASK_WAKE_MIN_F2F_8197F) << BIT_SHIFT_WAKE_MIN_F2F_8197F)
#define BITS_WAKE_MIN_F2F_8197F \
(BIT_MASK_WAKE_MIN_F2F_8197F << BIT_SHIFT_WAKE_MIN_F2F_8197F)
#define BIT_CLEAR_WAKE_MIN_F2F_8197F(x) ((x) & (~BITS_WAKE_MIN_F2F_8197F))
#define BIT_GET_WAKE_MIN_F2F_8197F(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_F2F_8197F) & BIT_MASK_WAKE_MIN_F2F_8197F)
#define BIT_SET_WAKE_MIN_F2F_8197F(x, v) \
(BIT_CLEAR_WAKE_MIN_F2F_8197F(x) | BIT_WAKE_MIN_F2F_8197F(v))
#define BIT_APP_CPU_ACT_V1_8197F BIT(3)
#define BIT_APP_OBFF_V1_8197F BIT(2)
#define BIT_APP_IDLE_V1_8197F BIT(1)
#define BIT_APP_INIT_V1_8197F BIT(0)
/* 2 REG_OBFF_CTRL2_TIMER_8197F */
#define BIT_SHIFT_RX_HIGH_TIMER_IDX_8197F 24
#define BIT_MASK_RX_HIGH_TIMER_IDX_8197F 0x7
#define BIT_RX_HIGH_TIMER_IDX_8197F(x) \
(((x) & BIT_MASK_RX_HIGH_TIMER_IDX_8197F) \
<< BIT_SHIFT_RX_HIGH_TIMER_IDX_8197F)
#define BITS_RX_HIGH_TIMER_IDX_8197F \
(BIT_MASK_RX_HIGH_TIMER_IDX_8197F << BIT_SHIFT_RX_HIGH_TIMER_IDX_8197F)
#define BIT_CLEAR_RX_HIGH_TIMER_IDX_8197F(x) \
((x) & (~BITS_RX_HIGH_TIMER_IDX_8197F))
#define BIT_GET_RX_HIGH_TIMER_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TIMER_IDX_8197F) & \
BIT_MASK_RX_HIGH_TIMER_IDX_8197F)
#define BIT_SET_RX_HIGH_TIMER_IDX_8197F(x, v) \
(BIT_CLEAR_RX_HIGH_TIMER_IDX_8197F(x) | BIT_RX_HIGH_TIMER_IDX_8197F(v))
#define BIT_SHIFT_RX_MED_TIMER_IDX_8197F 16
#define BIT_MASK_RX_MED_TIMER_IDX_8197F 0x7
#define BIT_RX_MED_TIMER_IDX_8197F(x) \
(((x) & BIT_MASK_RX_MED_TIMER_IDX_8197F) \
<< BIT_SHIFT_RX_MED_TIMER_IDX_8197F)
#define BITS_RX_MED_TIMER_IDX_8197F \
(BIT_MASK_RX_MED_TIMER_IDX_8197F << BIT_SHIFT_RX_MED_TIMER_IDX_8197F)
#define BIT_CLEAR_RX_MED_TIMER_IDX_8197F(x) \
((x) & (~BITS_RX_MED_TIMER_IDX_8197F))
#define BIT_GET_RX_MED_TIMER_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_MED_TIMER_IDX_8197F) & \
BIT_MASK_RX_MED_TIMER_IDX_8197F)
#define BIT_SET_RX_MED_TIMER_IDX_8197F(x, v) \
(BIT_CLEAR_RX_MED_TIMER_IDX_8197F(x) | BIT_RX_MED_TIMER_IDX_8197F(v))
#define BIT_SHIFT_RX_LOW_TIMER_IDX_8197F 8
#define BIT_MASK_RX_LOW_TIMER_IDX_8197F 0x7
#define BIT_RX_LOW_TIMER_IDX_8197F(x) \
(((x) & BIT_MASK_RX_LOW_TIMER_IDX_8197F) \
<< BIT_SHIFT_RX_LOW_TIMER_IDX_8197F)
#define BITS_RX_LOW_TIMER_IDX_8197F \
(BIT_MASK_RX_LOW_TIMER_IDX_8197F << BIT_SHIFT_RX_LOW_TIMER_IDX_8197F)
#define BIT_CLEAR_RX_LOW_TIMER_IDX_8197F(x) \
((x) & (~BITS_RX_LOW_TIMER_IDX_8197F))
#define BIT_GET_RX_LOW_TIMER_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_LOW_TIMER_IDX_8197F) & \
BIT_MASK_RX_LOW_TIMER_IDX_8197F)
#define BIT_SET_RX_LOW_TIMER_IDX_8197F(x, v) \
(BIT_CLEAR_RX_LOW_TIMER_IDX_8197F(x) | BIT_RX_LOW_TIMER_IDX_8197F(v))
#define BIT_SHIFT_OBFF_INT_TIMER_IDX_8197F 0
#define BIT_MASK_OBFF_INT_TIMER_IDX_8197F 0x7
#define BIT_OBFF_INT_TIMER_IDX_8197F(x) \
(((x) & BIT_MASK_OBFF_INT_TIMER_IDX_8197F) \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8197F)
#define BITS_OBFF_INT_TIMER_IDX_8197F \
(BIT_MASK_OBFF_INT_TIMER_IDX_8197F \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8197F)
#define BIT_CLEAR_OBFF_INT_TIMER_IDX_8197F(x) \
((x) & (~BITS_OBFF_INT_TIMER_IDX_8197F))
#define BIT_GET_OBFF_INT_TIMER_IDX_8197F(x) \
(((x) >> BIT_SHIFT_OBFF_INT_TIMER_IDX_8197F) & \
BIT_MASK_OBFF_INT_TIMER_IDX_8197F)
#define BIT_SET_OBFF_INT_TIMER_IDX_8197F(x, v) \
(BIT_CLEAR_OBFF_INT_TIMER_IDX_8197F(x) | \
BIT_OBFF_INT_TIMER_IDX_8197F(v))
/* 2 REG_LTR_CTRL_BASIC_8197F */
#define BIT_LTR_EN_V1_8197F BIT(31)
#define BIT_LTR_HW_EN_V1_8197F BIT(30)
#define BIT_LRT_ACT_CTS_EN_8197F BIT(29)
#define BIT_LTR_ACT_RXPKT_EN_8197F BIT(28)
#define BIT_LTR_ACT_RXDMA_EN_8197F BIT(27)
#define BIT_LTR_IDLE_NO_SNOOP_8197F BIT(26)
#define BIT_SPDUP_MGTPKT_8197F BIT(25)
#define BIT_RX_AGG_EN_8197F BIT(24)
#define BIT_APP_LTR_ACT_8197F BIT(23)
#define BIT_APP_LTR_IDLE_8197F BIT(22)
#define BIT_SHIFT_HIGH_RATE_TRIG_SEL_8197F 20
#define BIT_MASK_HIGH_RATE_TRIG_SEL_8197F 0x3
#define BIT_HIGH_RATE_TRIG_SEL_8197F(x) \
(((x) & BIT_MASK_HIGH_RATE_TRIG_SEL_8197F) \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8197F)
#define BITS_HIGH_RATE_TRIG_SEL_8197F \
(BIT_MASK_HIGH_RATE_TRIG_SEL_8197F \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8197F)
#define BIT_CLEAR_HIGH_RATE_TRIG_SEL_8197F(x) \
((x) & (~BITS_HIGH_RATE_TRIG_SEL_8197F))
#define BIT_GET_HIGH_RATE_TRIG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_TRIG_SEL_8197F) & \
BIT_MASK_HIGH_RATE_TRIG_SEL_8197F)
#define BIT_SET_HIGH_RATE_TRIG_SEL_8197F(x, v) \
(BIT_CLEAR_HIGH_RATE_TRIG_SEL_8197F(x) | \
BIT_HIGH_RATE_TRIG_SEL_8197F(v))
#define BIT_SHIFT_MED_RATE_TRIG_SEL_8197F 18
#define BIT_MASK_MED_RATE_TRIG_SEL_8197F 0x3
#define BIT_MED_RATE_TRIG_SEL_8197F(x) \
(((x) & BIT_MASK_MED_RATE_TRIG_SEL_8197F) \
<< BIT_SHIFT_MED_RATE_TRIG_SEL_8197F)
#define BITS_MED_RATE_TRIG_SEL_8197F \
(BIT_MASK_MED_RATE_TRIG_SEL_8197F << BIT_SHIFT_MED_RATE_TRIG_SEL_8197F)
#define BIT_CLEAR_MED_RATE_TRIG_SEL_8197F(x) \
((x) & (~BITS_MED_RATE_TRIG_SEL_8197F))
#define BIT_GET_MED_RATE_TRIG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_MED_RATE_TRIG_SEL_8197F) & \
BIT_MASK_MED_RATE_TRIG_SEL_8197F)
#define BIT_SET_MED_RATE_TRIG_SEL_8197F(x, v) \
(BIT_CLEAR_MED_RATE_TRIG_SEL_8197F(x) | BIT_MED_RATE_TRIG_SEL_8197F(v))
#define BIT_SHIFT_LOW_RATE_TRIG_SEL_8197F 16
#define BIT_MASK_LOW_RATE_TRIG_SEL_8197F 0x3
#define BIT_LOW_RATE_TRIG_SEL_8197F(x) \
(((x) & BIT_MASK_LOW_RATE_TRIG_SEL_8197F) \
<< BIT_SHIFT_LOW_RATE_TRIG_SEL_8197F)
#define BITS_LOW_RATE_TRIG_SEL_8197F \
(BIT_MASK_LOW_RATE_TRIG_SEL_8197F << BIT_SHIFT_LOW_RATE_TRIG_SEL_8197F)
#define BIT_CLEAR_LOW_RATE_TRIG_SEL_8197F(x) \
((x) & (~BITS_LOW_RATE_TRIG_SEL_8197F))
#define BIT_GET_LOW_RATE_TRIG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_LOW_RATE_TRIG_SEL_8197F) & \
BIT_MASK_LOW_RATE_TRIG_SEL_8197F)
#define BIT_SET_LOW_RATE_TRIG_SEL_8197F(x, v) \
(BIT_CLEAR_LOW_RATE_TRIG_SEL_8197F(x) | BIT_LOW_RATE_TRIG_SEL_8197F(v))
#define BIT_SHIFT_HIGH_RATE_BD_IDX_8197F 8
#define BIT_MASK_HIGH_RATE_BD_IDX_8197F 0x7f
#define BIT_HIGH_RATE_BD_IDX_8197F(x) \
(((x) & BIT_MASK_HIGH_RATE_BD_IDX_8197F) \
<< BIT_SHIFT_HIGH_RATE_BD_IDX_8197F)
#define BITS_HIGH_RATE_BD_IDX_8197F \
(BIT_MASK_HIGH_RATE_BD_IDX_8197F << BIT_SHIFT_HIGH_RATE_BD_IDX_8197F)
#define BIT_CLEAR_HIGH_RATE_BD_IDX_8197F(x) \
((x) & (~BITS_HIGH_RATE_BD_IDX_8197F))
#define BIT_GET_HIGH_RATE_BD_IDX_8197F(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_BD_IDX_8197F) & \
BIT_MASK_HIGH_RATE_BD_IDX_8197F)
#define BIT_SET_HIGH_RATE_BD_IDX_8197F(x, v) \
(BIT_CLEAR_HIGH_RATE_BD_IDX_8197F(x) | BIT_HIGH_RATE_BD_IDX_8197F(v))
#define BIT_SHIFT_LOW_RATE_BD_IDX_8197F 0
#define BIT_MASK_LOW_RATE_BD_IDX_8197F 0x7f
#define BIT_LOW_RATE_BD_IDX_8197F(x) \
(((x) & BIT_MASK_LOW_RATE_BD_IDX_8197F) \
<< BIT_SHIFT_LOW_RATE_BD_IDX_8197F)
#define BITS_LOW_RATE_BD_IDX_8197F \
(BIT_MASK_LOW_RATE_BD_IDX_8197F << BIT_SHIFT_LOW_RATE_BD_IDX_8197F)
#define BIT_CLEAR_LOW_RATE_BD_IDX_8197F(x) ((x) & (~BITS_LOW_RATE_BD_IDX_8197F))
#define BIT_GET_LOW_RATE_BD_IDX_8197F(x) \
(((x) >> BIT_SHIFT_LOW_RATE_BD_IDX_8197F) & \
BIT_MASK_LOW_RATE_BD_IDX_8197F)
#define BIT_SET_LOW_RATE_BD_IDX_8197F(x, v) \
(BIT_CLEAR_LOW_RATE_BD_IDX_8197F(x) | BIT_LOW_RATE_BD_IDX_8197F(v))
/* 2 REG_LTR_CTRL2_TIMER_THRESHOLD_8197F */
#define BIT_SHIFT_RX_EMPTY_TIMER_IDX_8197F 24
#define BIT_MASK_RX_EMPTY_TIMER_IDX_8197F 0x7
#define BIT_RX_EMPTY_TIMER_IDX_8197F(x) \
(((x) & BIT_MASK_RX_EMPTY_TIMER_IDX_8197F) \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8197F)
#define BITS_RX_EMPTY_TIMER_IDX_8197F \
(BIT_MASK_RX_EMPTY_TIMER_IDX_8197F \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8197F)
#define BIT_CLEAR_RX_EMPTY_TIMER_IDX_8197F(x) \
((x) & (~BITS_RX_EMPTY_TIMER_IDX_8197F))
#define BIT_GET_RX_EMPTY_TIMER_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_EMPTY_TIMER_IDX_8197F) & \
BIT_MASK_RX_EMPTY_TIMER_IDX_8197F)
#define BIT_SET_RX_EMPTY_TIMER_IDX_8197F(x, v) \
(BIT_CLEAR_RX_EMPTY_TIMER_IDX_8197F(x) | \
BIT_RX_EMPTY_TIMER_IDX_8197F(v))
#define BIT_SHIFT_RX_AFULL_TH_IDX_8197F 20
#define BIT_MASK_RX_AFULL_TH_IDX_8197F 0x7
#define BIT_RX_AFULL_TH_IDX_8197F(x) \
(((x) & BIT_MASK_RX_AFULL_TH_IDX_8197F) \
<< BIT_SHIFT_RX_AFULL_TH_IDX_8197F)
#define BITS_RX_AFULL_TH_IDX_8197F \
(BIT_MASK_RX_AFULL_TH_IDX_8197F << BIT_SHIFT_RX_AFULL_TH_IDX_8197F)
#define BIT_CLEAR_RX_AFULL_TH_IDX_8197F(x) ((x) & (~BITS_RX_AFULL_TH_IDX_8197F))
#define BIT_GET_RX_AFULL_TH_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_AFULL_TH_IDX_8197F) & \
BIT_MASK_RX_AFULL_TH_IDX_8197F)
#define BIT_SET_RX_AFULL_TH_IDX_8197F(x, v) \
(BIT_CLEAR_RX_AFULL_TH_IDX_8197F(x) | BIT_RX_AFULL_TH_IDX_8197F(v))
#define BIT_SHIFT_RX_HIGH_TH_IDX_8197F 16
#define BIT_MASK_RX_HIGH_TH_IDX_8197F 0x7
#define BIT_RX_HIGH_TH_IDX_8197F(x) \
(((x) & BIT_MASK_RX_HIGH_TH_IDX_8197F) \
<< BIT_SHIFT_RX_HIGH_TH_IDX_8197F)
#define BITS_RX_HIGH_TH_IDX_8197F \
(BIT_MASK_RX_HIGH_TH_IDX_8197F << BIT_SHIFT_RX_HIGH_TH_IDX_8197F)
#define BIT_CLEAR_RX_HIGH_TH_IDX_8197F(x) ((x) & (~BITS_RX_HIGH_TH_IDX_8197F))
#define BIT_GET_RX_HIGH_TH_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TH_IDX_8197F) & \
BIT_MASK_RX_HIGH_TH_IDX_8197F)
#define BIT_SET_RX_HIGH_TH_IDX_8197F(x, v) \
(BIT_CLEAR_RX_HIGH_TH_IDX_8197F(x) | BIT_RX_HIGH_TH_IDX_8197F(v))
#define BIT_SHIFT_RX_MED_TH_IDX_8197F 12
#define BIT_MASK_RX_MED_TH_IDX_8197F 0x7
#define BIT_RX_MED_TH_IDX_8197F(x) \
(((x) & BIT_MASK_RX_MED_TH_IDX_8197F) << BIT_SHIFT_RX_MED_TH_IDX_8197F)
#define BITS_RX_MED_TH_IDX_8197F \
(BIT_MASK_RX_MED_TH_IDX_8197F << BIT_SHIFT_RX_MED_TH_IDX_8197F)
#define BIT_CLEAR_RX_MED_TH_IDX_8197F(x) ((x) & (~BITS_RX_MED_TH_IDX_8197F))
#define BIT_GET_RX_MED_TH_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_MED_TH_IDX_8197F) & BIT_MASK_RX_MED_TH_IDX_8197F)
#define BIT_SET_RX_MED_TH_IDX_8197F(x, v) \
(BIT_CLEAR_RX_MED_TH_IDX_8197F(x) | BIT_RX_MED_TH_IDX_8197F(v))
#define BIT_SHIFT_RX_LOW_TH_IDX_8197F 8
#define BIT_MASK_RX_LOW_TH_IDX_8197F 0x7
#define BIT_RX_LOW_TH_IDX_8197F(x) \
(((x) & BIT_MASK_RX_LOW_TH_IDX_8197F) << BIT_SHIFT_RX_LOW_TH_IDX_8197F)
#define BITS_RX_LOW_TH_IDX_8197F \
(BIT_MASK_RX_LOW_TH_IDX_8197F << BIT_SHIFT_RX_LOW_TH_IDX_8197F)
#define BIT_CLEAR_RX_LOW_TH_IDX_8197F(x) ((x) & (~BITS_RX_LOW_TH_IDX_8197F))
#define BIT_GET_RX_LOW_TH_IDX_8197F(x) \
(((x) >> BIT_SHIFT_RX_LOW_TH_IDX_8197F) & BIT_MASK_RX_LOW_TH_IDX_8197F)
#define BIT_SET_RX_LOW_TH_IDX_8197F(x, v) \
(BIT_CLEAR_RX_LOW_TH_IDX_8197F(x) | BIT_RX_LOW_TH_IDX_8197F(v))
#define BIT_SHIFT_LTR_SPACE_IDX_8197F 4
#define BIT_MASK_LTR_SPACE_IDX_8197F 0x3
#define BIT_LTR_SPACE_IDX_8197F(x) \
(((x) & BIT_MASK_LTR_SPACE_IDX_8197F) << BIT_SHIFT_LTR_SPACE_IDX_8197F)
#define BITS_LTR_SPACE_IDX_8197F \
(BIT_MASK_LTR_SPACE_IDX_8197F << BIT_SHIFT_LTR_SPACE_IDX_8197F)
#define BIT_CLEAR_LTR_SPACE_IDX_8197F(x) ((x) & (~BITS_LTR_SPACE_IDX_8197F))
#define BIT_GET_LTR_SPACE_IDX_8197F(x) \
(((x) >> BIT_SHIFT_LTR_SPACE_IDX_8197F) & BIT_MASK_LTR_SPACE_IDX_8197F)
#define BIT_SET_LTR_SPACE_IDX_8197F(x, v) \
(BIT_CLEAR_LTR_SPACE_IDX_8197F(x) | BIT_LTR_SPACE_IDX_8197F(v))
#define BIT_SHIFT_LTR_IDLE_TIMER_IDX_8197F 0
#define BIT_MASK_LTR_IDLE_TIMER_IDX_8197F 0x7
#define BIT_LTR_IDLE_TIMER_IDX_8197F(x) \
(((x) & BIT_MASK_LTR_IDLE_TIMER_IDX_8197F) \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8197F)
#define BITS_LTR_IDLE_TIMER_IDX_8197F \
(BIT_MASK_LTR_IDLE_TIMER_IDX_8197F \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8197F)
#define BIT_CLEAR_LTR_IDLE_TIMER_IDX_8197F(x) \
((x) & (~BITS_LTR_IDLE_TIMER_IDX_8197F))
#define BIT_GET_LTR_IDLE_TIMER_IDX_8197F(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_TIMER_IDX_8197F) & \
BIT_MASK_LTR_IDLE_TIMER_IDX_8197F)
#define BIT_SET_LTR_IDLE_TIMER_IDX_8197F(x, v) \
(BIT_CLEAR_LTR_IDLE_TIMER_IDX_8197F(x) | \
BIT_LTR_IDLE_TIMER_IDX_8197F(v))
/* 2 REG_LTR_IDLE_LATENCY_V1_8197F */
#define BIT_SHIFT_LTR_IDLE_L_8197F 0
#define BIT_MASK_LTR_IDLE_L_8197F 0xffffffffL
#define BIT_LTR_IDLE_L_8197F(x) \
(((x) & BIT_MASK_LTR_IDLE_L_8197F) << BIT_SHIFT_LTR_IDLE_L_8197F)
#define BITS_LTR_IDLE_L_8197F \
(BIT_MASK_LTR_IDLE_L_8197F << BIT_SHIFT_LTR_IDLE_L_8197F)
#define BIT_CLEAR_LTR_IDLE_L_8197F(x) ((x) & (~BITS_LTR_IDLE_L_8197F))
#define BIT_GET_LTR_IDLE_L_8197F(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_L_8197F) & BIT_MASK_LTR_IDLE_L_8197F)
#define BIT_SET_LTR_IDLE_L_8197F(x, v) \
(BIT_CLEAR_LTR_IDLE_L_8197F(x) | BIT_LTR_IDLE_L_8197F(v))
/* 2 REG_LTR_ACTIVE_LATENCY_V1_8197F */
#define BIT_SHIFT_LTR_ACT_L_8197F 0
#define BIT_MASK_LTR_ACT_L_8197F 0xffffffffL
#define BIT_LTR_ACT_L_8197F(x) \
(((x) & BIT_MASK_LTR_ACT_L_8197F) << BIT_SHIFT_LTR_ACT_L_8197F)
#define BITS_LTR_ACT_L_8197F \
(BIT_MASK_LTR_ACT_L_8197F << BIT_SHIFT_LTR_ACT_L_8197F)
#define BIT_CLEAR_LTR_ACT_L_8197F(x) ((x) & (~BITS_LTR_ACT_L_8197F))
#define BIT_GET_LTR_ACT_L_8197F(x) \
(((x) >> BIT_SHIFT_LTR_ACT_L_8197F) & BIT_MASK_LTR_ACT_L_8197F)
#define BIT_SET_LTR_ACT_L_8197F(x, v) \
(BIT_CLEAR_LTR_ACT_L_8197F(x) | BIT_LTR_ACT_L_8197F(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_8197F */
#define BIT_APPEND_MACID_IN_RESP_EN_8197F BIT(50)
#define BIT_ADDR2_MATCH_EN_8197F BIT(49)
#define BIT_ANTTRN_EN_8197F BIT(48)
#define BIT_SHIFT_TRAIN_STA_ADDR_8197F 0
#define BIT_MASK_TRAIN_STA_ADDR_8197F 0xffffffffffffL
#define BIT_TRAIN_STA_ADDR_8197F(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_8197F) \
<< BIT_SHIFT_TRAIN_STA_ADDR_8197F)
#define BITS_TRAIN_STA_ADDR_8197F \
(BIT_MASK_TRAIN_STA_ADDR_8197F << BIT_SHIFT_TRAIN_STA_ADDR_8197F)
#define BIT_CLEAR_TRAIN_STA_ADDR_8197F(x) ((x) & (~BITS_TRAIN_STA_ADDR_8197F))
#define BIT_GET_TRAIN_STA_ADDR_8197F(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_8197F) & \
BIT_MASK_TRAIN_STA_ADDR_8197F)
#define BIT_SET_TRAIN_STA_ADDR_8197F(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_8197F(x) | BIT_TRAIN_STA_ADDR_8197F(v))
/* 2 REG_RSVD_0X7B4_8197F */
/* 2 REG_WMAC_PKTCNT_RWD_8197F */
#define BIT_SHIFT_PKTCNT_BSSIDMAP_8197F 4
#define BIT_MASK_PKTCNT_BSSIDMAP_8197F 0xf
#define BIT_PKTCNT_BSSIDMAP_8197F(x) \
(((x) & BIT_MASK_PKTCNT_BSSIDMAP_8197F) \
<< BIT_SHIFT_PKTCNT_BSSIDMAP_8197F)
#define BITS_PKTCNT_BSSIDMAP_8197F \
(BIT_MASK_PKTCNT_BSSIDMAP_8197F << BIT_SHIFT_PKTCNT_BSSIDMAP_8197F)
#define BIT_CLEAR_PKTCNT_BSSIDMAP_8197F(x) ((x) & (~BITS_PKTCNT_BSSIDMAP_8197F))
#define BIT_GET_PKTCNT_BSSIDMAP_8197F(x) \
(((x) >> BIT_SHIFT_PKTCNT_BSSIDMAP_8197F) & \
BIT_MASK_PKTCNT_BSSIDMAP_8197F)
#define BIT_SET_PKTCNT_BSSIDMAP_8197F(x, v) \
(BIT_CLEAR_PKTCNT_BSSIDMAP_8197F(x) | BIT_PKTCNT_BSSIDMAP_8197F(v))
#define BIT_PKTCNT_CNTRST_8197F BIT(1)
#define BIT_PKTCNT_CNTEN_8197F BIT(0)
/* 2 REG_WMAC_PKTCNT_CTRL_8197F */
#define BIT_WMAC_PKTCNT_TRST_8197F BIT(9)
#define BIT_WMAC_PKTCNT_FEN_8197F BIT(8)
#define BIT_SHIFT_WMAC_PKTCNT_CFGAD_8197F 0
#define BIT_MASK_WMAC_PKTCNT_CFGAD_8197F 0xff
#define BIT_WMAC_PKTCNT_CFGAD_8197F(x) \
(((x) & BIT_MASK_WMAC_PKTCNT_CFGAD_8197F) \
<< BIT_SHIFT_WMAC_PKTCNT_CFGAD_8197F)
#define BITS_WMAC_PKTCNT_CFGAD_8197F \
(BIT_MASK_WMAC_PKTCNT_CFGAD_8197F << BIT_SHIFT_WMAC_PKTCNT_CFGAD_8197F)
#define BIT_CLEAR_WMAC_PKTCNT_CFGAD_8197F(x) \
((x) & (~BITS_WMAC_PKTCNT_CFGAD_8197F))
#define BIT_GET_WMAC_PKTCNT_CFGAD_8197F(x) \
(((x) >> BIT_SHIFT_WMAC_PKTCNT_CFGAD_8197F) & \
BIT_MASK_WMAC_PKTCNT_CFGAD_8197F)
#define BIT_SET_WMAC_PKTCNT_CFGAD_8197F(x, v) \
(BIT_CLEAR_WMAC_PKTCNT_CFGAD_8197F(x) | BIT_WMAC_PKTCNT_CFGAD_8197F(v))
/* 2 REG_IQ_DUMP_8197F */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8197F (64 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_MATCH_REF_MAC_8197F 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC_8197F(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC_8197F) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8197F)
#define BITS_R_WMAC_MATCH_REF_MAC_8197F \
(BIT_MASK_R_WMAC_MATCH_REF_MAC_8197F \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8197F)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC_8197F(x) \
((x) & (~BITS_R_WMAC_MATCH_REF_MAC_8197F))
#define BIT_GET_R_WMAC_MATCH_REF_MAC_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8197F) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC_8197F)
#define BIT_SET_R_WMAC_MATCH_REF_MAC_8197F(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC_8197F(x) | \
BIT_R_WMAC_MATCH_REF_MAC_8197F(v))
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_MASK_LA_MAC_8197F 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC_8197F(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC_8197F) \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_8197F)
#define BITS_R_WMAC_MASK_LA_MAC_8197F \
(BIT_MASK_R_WMAC_MASK_LA_MAC_8197F \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_8197F)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC_8197F(x) \
((x) & (~BITS_R_WMAC_MASK_LA_MAC_8197F))
#define BIT_GET_R_WMAC_MASK_LA_MAC_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC_8197F) & \
BIT_MASK_R_WMAC_MASK_LA_MAC_8197F)
#define BIT_SET_R_WMAC_MASK_LA_MAC_8197F(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC_8197F(x) | \
BIT_R_WMAC_MASK_LA_MAC_8197F(v))
#define BIT_SHIFT_DUMP_OK_ADDR_V1_8197F 15
#define BIT_MASK_DUMP_OK_ADDR_V1_8197F 0x1ffff
#define BIT_DUMP_OK_ADDR_V1_8197F(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR_V1_8197F) \
<< BIT_SHIFT_DUMP_OK_ADDR_V1_8197F)
#define BITS_DUMP_OK_ADDR_V1_8197F \
(BIT_MASK_DUMP_OK_ADDR_V1_8197F << BIT_SHIFT_DUMP_OK_ADDR_V1_8197F)
#define BIT_CLEAR_DUMP_OK_ADDR_V1_8197F(x) ((x) & (~BITS_DUMP_OK_ADDR_V1_8197F))
#define BIT_GET_DUMP_OK_ADDR_V1_8197F(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR_V1_8197F) & \
BIT_MASK_DUMP_OK_ADDR_V1_8197F)
#define BIT_SET_DUMP_OK_ADDR_V1_8197F(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR_V1_8197F(x) | BIT_DUMP_OK_ADDR_V1_8197F(v))
#define BIT_SHIFT_R_TRIG_TIME_SEL_8197F 8
#define BIT_MASK_R_TRIG_TIME_SEL_8197F 0x7f
#define BIT_R_TRIG_TIME_SEL_8197F(x) \
(((x) & BIT_MASK_R_TRIG_TIME_SEL_8197F) \
<< BIT_SHIFT_R_TRIG_TIME_SEL_8197F)
#define BITS_R_TRIG_TIME_SEL_8197F \
(BIT_MASK_R_TRIG_TIME_SEL_8197F << BIT_SHIFT_R_TRIG_TIME_SEL_8197F)
#define BIT_CLEAR_R_TRIG_TIME_SEL_8197F(x) ((x) & (~BITS_R_TRIG_TIME_SEL_8197F))
#define BIT_GET_R_TRIG_TIME_SEL_8197F(x) \
(((x) >> BIT_SHIFT_R_TRIG_TIME_SEL_8197F) & \
BIT_MASK_R_TRIG_TIME_SEL_8197F)
#define BIT_SET_R_TRIG_TIME_SEL_8197F(x, v) \
(BIT_CLEAR_R_TRIG_TIME_SEL_8197F(x) | BIT_R_TRIG_TIME_SEL_8197F(v))
#define BIT_SHIFT_R_MAC_TRIG_SEL_8197F 6
#define BIT_MASK_R_MAC_TRIG_SEL_8197F 0x3
#define BIT_R_MAC_TRIG_SEL_8197F(x) \
(((x) & BIT_MASK_R_MAC_TRIG_SEL_8197F) \
<< BIT_SHIFT_R_MAC_TRIG_SEL_8197F)
#define BITS_R_MAC_TRIG_SEL_8197F \
(BIT_MASK_R_MAC_TRIG_SEL_8197F << BIT_SHIFT_R_MAC_TRIG_SEL_8197F)
#define BIT_CLEAR_R_MAC_TRIG_SEL_8197F(x) ((x) & (~BITS_R_MAC_TRIG_SEL_8197F))
#define BIT_GET_R_MAC_TRIG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_R_MAC_TRIG_SEL_8197F) & \
BIT_MASK_R_MAC_TRIG_SEL_8197F)
#define BIT_SET_R_MAC_TRIG_SEL_8197F(x, v) \
(BIT_CLEAR_R_MAC_TRIG_SEL_8197F(x) | BIT_R_MAC_TRIG_SEL_8197F(v))
#define BIT_MAC_TRIG_REG_8197F BIT(5)
#define BIT_SHIFT_R_LEVEL_PULSE_SEL_8197F 3
#define BIT_MASK_R_LEVEL_PULSE_SEL_8197F 0x3
#define BIT_R_LEVEL_PULSE_SEL_8197F(x) \
(((x) & BIT_MASK_R_LEVEL_PULSE_SEL_8197F) \
<< BIT_SHIFT_R_LEVEL_PULSE_SEL_8197F)
#define BITS_R_LEVEL_PULSE_SEL_8197F \
(BIT_MASK_R_LEVEL_PULSE_SEL_8197F << BIT_SHIFT_R_LEVEL_PULSE_SEL_8197F)
#define BIT_CLEAR_R_LEVEL_PULSE_SEL_8197F(x) \
((x) & (~BITS_R_LEVEL_PULSE_SEL_8197F))
#define BIT_GET_R_LEVEL_PULSE_SEL_8197F(x) \
(((x) >> BIT_SHIFT_R_LEVEL_PULSE_SEL_8197F) & \
BIT_MASK_R_LEVEL_PULSE_SEL_8197F)
#define BIT_SET_R_LEVEL_PULSE_SEL_8197F(x, v) \
(BIT_CLEAR_R_LEVEL_PULSE_SEL_8197F(x) | BIT_R_LEVEL_PULSE_SEL_8197F(v))
#define BIT_EN_LA_MAC_8197F BIT(2)
#define BIT_R_EN_IQDUMP_8197F BIT(1)
#define BIT_R_IQDATA_DUMP_8197F BIT(0)
/* 2 REG_WMAC_FTM_CTL_8197F */
#define BIT_RXFTM_TXACK_SC_8197F BIT(6)
#define BIT_RXFTM_TXACK_BW_8197F BIT(5)
#define BIT_RXFTM_EN_8197F BIT(3)
#define BIT_RXFTMREQ_BYDRV_8197F BIT(2)
#define BIT_RXFTMREQ_EN_8197F BIT(1)
#define BIT_FTM_EN_8197F BIT(0)
/* 2 REG_IQ_DUMP_EXT_8197F */
#define BIT_SHIFT_R_TIME_UNIT_SEL_8197F 0
#define BIT_MASK_R_TIME_UNIT_SEL_8197F 0x7
#define BIT_R_TIME_UNIT_SEL_8197F(x) \
(((x) & BIT_MASK_R_TIME_UNIT_SEL_8197F) \
<< BIT_SHIFT_R_TIME_UNIT_SEL_8197F)
#define BITS_R_TIME_UNIT_SEL_8197F \
(BIT_MASK_R_TIME_UNIT_SEL_8197F << BIT_SHIFT_R_TIME_UNIT_SEL_8197F)
#define BIT_CLEAR_R_TIME_UNIT_SEL_8197F(x) ((x) & (~BITS_R_TIME_UNIT_SEL_8197F))
#define BIT_GET_R_TIME_UNIT_SEL_8197F(x) \
(((x) >> BIT_SHIFT_R_TIME_UNIT_SEL_8197F) & \
BIT_MASK_R_TIME_UNIT_SEL_8197F)
#define BIT_SET_R_TIME_UNIT_SEL_8197F(x, v) \
(BIT_CLEAR_R_TIME_UNIT_SEL_8197F(x) | BIT_R_TIME_UNIT_SEL_8197F(v))
/* 2 REG_OFDM_CCK_LEN_MASK_8197F */
#define BIT_SHIFT_R_WMAC_RX_FIL_LEN_8197F (64 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_RX_FIL_LEN_8197F 0xffff
#define BIT_R_WMAC_RX_FIL_LEN_8197F(x) \
(((x) & BIT_MASK_R_WMAC_RX_FIL_LEN_8197F) \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_8197F)
#define BITS_R_WMAC_RX_FIL_LEN_8197F \
(BIT_MASK_R_WMAC_RX_FIL_LEN_8197F << BIT_SHIFT_R_WMAC_RX_FIL_LEN_8197F)
#define BIT_CLEAR_R_WMAC_RX_FIL_LEN_8197F(x) \
((x) & (~BITS_R_WMAC_RX_FIL_LEN_8197F))
#define BIT_GET_R_WMAC_RX_FIL_LEN_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_RX_FIL_LEN_8197F) & \
BIT_MASK_R_WMAC_RX_FIL_LEN_8197F)
#define BIT_SET_R_WMAC_RX_FIL_LEN_8197F(x, v) \
(BIT_CLEAR_R_WMAC_RX_FIL_LEN_8197F(x) | BIT_R_WMAC_RX_FIL_LEN_8197F(v))
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8197F (56 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8197F 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH_8197F(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8197F) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8197F)
#define BITS_R_WMAC_RXFIFO_FULL_TH_8197F \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8197F \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8197F)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_8197F(x) \
((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH_8197F))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8197F) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8197F)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH_8197F(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_8197F(x) | \
BIT_R_WMAC_RXFIFO_FULL_TH_8197F(v))
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC_8197F BIT(55)
#define BIT_R_WMAC_RXRST_DLY_8197F BIT(54)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP_8197F BIT(53)
#define BIT_R_WMAC_SRCH_TXRPT_UA1_8197F BIT(52)
#define BIT_R_WMAC_SRCH_TXRPT_TYPE_8197F BIT(51)
#define BIT_R_WMAC_NDP_RST_8197F BIT(50)
#define BIT_R_WMAC_POWINT_EN_8197F BIT(49)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT_8197F BIT(48)
#define BIT_R_WMAC_SRCH_TXRPT_MID_8197F BIT(47)
#define BIT_R_WMAC_PFIN_TOEN_8197F BIT(46)
#define BIT_R_WMAC_FIL_SECERR_8197F BIT(45)
#define BIT_R_WMAC_FIL_CTLPKTLEN_8197F BIT(44)
#define BIT_R_WMAC_FIL_FCTYPE_8197F BIT(43)
#define BIT_R_WMAC_FIL_FCPROVER_8197F BIT(42)
#define BIT_R_WMAC_PHYSTS_SNIF_8197F BIT(41)
#define BIT_R_WMAC_PHYSTS_PLCP_8197F BIT(40)
#define BIT_R_MAC_TCR_VBONF_RD_8197F BIT(39)
#define BIT_R_WMAC_TCR_MPAR_NDP_8197F BIT(38)
#define BIT_R_WMAC_NDP_FILTER_8197F BIT(37)
#define BIT_R_WMAC_RXLEN_SEL_8197F BIT(36)
#define BIT_R_WMAC_RXLEN_SEL1_8197F BIT(35)
#define BIT_R_OFDM_FILTER_8197F BIT(34)
#define BIT_R_WMAC_CHK_OFDM_LEN_8197F BIT(33)
#define BIT_R_WMAC_CHK_CCK_LEN_8197F BIT(32)
#define BIT_SHIFT_R_OFDM_LEN_8197F 26
#define BIT_MASK_R_OFDM_LEN_8197F 0x3f
#define BIT_R_OFDM_LEN_8197F(x) \
(((x) & BIT_MASK_R_OFDM_LEN_8197F) << BIT_SHIFT_R_OFDM_LEN_8197F)
#define BITS_R_OFDM_LEN_8197F \
(BIT_MASK_R_OFDM_LEN_8197F << BIT_SHIFT_R_OFDM_LEN_8197F)
#define BIT_CLEAR_R_OFDM_LEN_8197F(x) ((x) & (~BITS_R_OFDM_LEN_8197F))
#define BIT_GET_R_OFDM_LEN_8197F(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN_8197F) & BIT_MASK_R_OFDM_LEN_8197F)
#define BIT_SET_R_OFDM_LEN_8197F(x, v) \
(BIT_CLEAR_R_OFDM_LEN_8197F(x) | BIT_R_OFDM_LEN_8197F(v))
#define BIT_SHIFT_R_CCK_LEN_8197F 0
#define BIT_MASK_R_CCK_LEN_8197F 0xffff
#define BIT_R_CCK_LEN_8197F(x) \
(((x) & BIT_MASK_R_CCK_LEN_8197F) << BIT_SHIFT_R_CCK_LEN_8197F)
#define BITS_R_CCK_LEN_8197F \
(BIT_MASK_R_CCK_LEN_8197F << BIT_SHIFT_R_CCK_LEN_8197F)
#define BIT_CLEAR_R_CCK_LEN_8197F(x) ((x) & (~BITS_R_CCK_LEN_8197F))
#define BIT_GET_R_CCK_LEN_8197F(x) \
(((x) >> BIT_SHIFT_R_CCK_LEN_8197F) & BIT_MASK_R_CCK_LEN_8197F)
#define BIT_SET_R_CCK_LEN_8197F(x, v) \
(BIT_CLEAR_R_CCK_LEN_8197F(x) | BIT_R_CCK_LEN_8197F(v))
/* 2 REG_RX_FILTER_FUNCTION_8197F */
#define BIT_R_WMAC_RXHANG_EN_8197F BIT(15)
#define BIT_R_WMAC_MHRDDY_LATCH_8197F BIT(14)
#define BIT_R_MHRDDY_CLR_8197F BIT(13)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY1_8197F BIT(12)
#define BIT_R_WMAC_DIS_VHT_PLCP_CHK_MU_8197F BIT(11)
#define BIT_R_CHK_DELIMIT_LEN_8197F BIT(10)
#define BIT_R_REAPTER_ADDR_MATCH_8197F BIT(9)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY_8197F BIT(8)
#define BIT_R_LATCH_MACHRDY_8197F BIT(7)
#define BIT_R_WMAC_RXFIL_REND_8197F BIT(6)
#define BIT_R_WMAC_MPDURDY_CLR_8197F BIT(5)
#define BIT_R_WMAC_CLRRXSEC_8197F BIT(4)
#define BIT_R_WMAC_RXFIL_RDEL_8197F BIT(3)
#define BIT_R_WMAC_RXFIL_FCSE_8197F BIT(2)
#define BIT_R_WMAC_RXFIL_MESH_DEL_8197F BIT(1)
#define BIT_R_WMAC_RXFIL_MASKM_8197F BIT(0)
/* 2 REG_NDP_SIG_8197F */
#define BIT_SHIFT_R_WMAC_TXNDP_SIGB_8197F 0
#define BIT_MASK_R_WMAC_TXNDP_SIGB_8197F 0x1fffff
#define BIT_R_WMAC_TXNDP_SIGB_8197F(x) \
(((x) & BIT_MASK_R_WMAC_TXNDP_SIGB_8197F) \
<< BIT_SHIFT_R_WMAC_TXNDP_SIGB_8197F)
#define BITS_R_WMAC_TXNDP_SIGB_8197F \
(BIT_MASK_R_WMAC_TXNDP_SIGB_8197F << BIT_SHIFT_R_WMAC_TXNDP_SIGB_8197F)
#define BIT_CLEAR_R_WMAC_TXNDP_SIGB_8197F(x) \
((x) & (~BITS_R_WMAC_TXNDP_SIGB_8197F))
#define BIT_GET_R_WMAC_TXNDP_SIGB_8197F(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXNDP_SIGB_8197F) & \
BIT_MASK_R_WMAC_TXNDP_SIGB_8197F)
#define BIT_SET_R_WMAC_TXNDP_SIGB_8197F(x, v) \
(BIT_CLEAR_R_WMAC_TXNDP_SIGB_8197F(x) | BIT_R_WMAC_TXNDP_SIGB_8197F(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_8197F */
#define BIT_SHIFT_R_MAC_DEBUG_8197F (32 & CPU_OPT_WIDTH)
#define BIT_MASK_R_MAC_DEBUG_8197F 0xffffffffL
#define BIT_R_MAC_DEBUG_8197F(x) \
(((x) & BIT_MASK_R_MAC_DEBUG_8197F) << BIT_SHIFT_R_MAC_DEBUG_8197F)
#define BITS_R_MAC_DEBUG_8197F \
(BIT_MASK_R_MAC_DEBUG_8197F << BIT_SHIFT_R_MAC_DEBUG_8197F)
#define BIT_CLEAR_R_MAC_DEBUG_8197F(x) ((x) & (~BITS_R_MAC_DEBUG_8197F))
#define BIT_GET_R_MAC_DEBUG_8197F(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG_8197F) & BIT_MASK_R_MAC_DEBUG_8197F)
#define BIT_SET_R_MAC_DEBUG_8197F(x, v) \
(BIT_CLEAR_R_MAC_DEBUG_8197F(x) | BIT_R_MAC_DEBUG_8197F(v))
#define BIT_SHIFT_R_MAC_DBG_SHIFT_8197F 8
#define BIT_MASK_R_MAC_DBG_SHIFT_8197F 0x7
#define BIT_R_MAC_DBG_SHIFT_8197F(x) \
(((x) & BIT_MASK_R_MAC_DBG_SHIFT_8197F) \
<< BIT_SHIFT_R_MAC_DBG_SHIFT_8197F)
#define BITS_R_MAC_DBG_SHIFT_8197F \
(BIT_MASK_R_MAC_DBG_SHIFT_8197F << BIT_SHIFT_R_MAC_DBG_SHIFT_8197F)
#define BIT_CLEAR_R_MAC_DBG_SHIFT_8197F(x) ((x) & (~BITS_R_MAC_DBG_SHIFT_8197F))
#define BIT_GET_R_MAC_DBG_SHIFT_8197F(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SHIFT_8197F) & \
BIT_MASK_R_MAC_DBG_SHIFT_8197F)
#define BIT_SET_R_MAC_DBG_SHIFT_8197F(x, v) \
(BIT_CLEAR_R_MAC_DBG_SHIFT_8197F(x) | BIT_R_MAC_DBG_SHIFT_8197F(v))
#define BIT_SHIFT_R_MAC_DBG_SEL_8197F 0
#define BIT_MASK_R_MAC_DBG_SEL_8197F 0x3
#define BIT_R_MAC_DBG_SEL_8197F(x) \
(((x) & BIT_MASK_R_MAC_DBG_SEL_8197F) << BIT_SHIFT_R_MAC_DBG_SEL_8197F)
#define BITS_R_MAC_DBG_SEL_8197F \
(BIT_MASK_R_MAC_DBG_SEL_8197F << BIT_SHIFT_R_MAC_DBG_SEL_8197F)
#define BIT_CLEAR_R_MAC_DBG_SEL_8197F(x) ((x) & (~BITS_R_MAC_DBG_SEL_8197F))
#define BIT_GET_R_MAC_DBG_SEL_8197F(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SEL_8197F) & BIT_MASK_R_MAC_DBG_SEL_8197F)
#define BIT_SET_R_MAC_DBG_SEL_8197F(x, v) \
(BIT_CLEAR_R_MAC_DBG_SEL_8197F(x) | BIT_R_MAC_DBG_SEL_8197F(v))
/* 2 REG_SEC_OPT_V2_8197F */
#define BIT_MASK_IV_8197F BIT(18)
#define BIT_EIVL_ENDIAN_8197F BIT(17)
#define BIT_EIVH_ENDIAN_8197F BIT(16)
#define BIT_SHIFT_BT_TIME_CNT_8197F 0
#define BIT_MASK_BT_TIME_CNT_8197F 0xff
#define BIT_BT_TIME_CNT_8197F(x) \
(((x) & BIT_MASK_BT_TIME_CNT_8197F) << BIT_SHIFT_BT_TIME_CNT_8197F)
#define BITS_BT_TIME_CNT_8197F \
(BIT_MASK_BT_TIME_CNT_8197F << BIT_SHIFT_BT_TIME_CNT_8197F)
#define BIT_CLEAR_BT_TIME_CNT_8197F(x) ((x) & (~BITS_BT_TIME_CNT_8197F))
#define BIT_GET_BT_TIME_CNT_8197F(x) \
(((x) >> BIT_SHIFT_BT_TIME_CNT_8197F) & BIT_MASK_BT_TIME_CNT_8197F)
#define BIT_SET_BT_TIME_CNT_8197F(x, v) \
(BIT_CLEAR_BT_TIME_CNT_8197F(x) | BIT_BT_TIME_CNT_8197F(v))
/* 2 REG_RTS_ADDRESS_0_8197F */
/* 2 REG_RTS_ADDRESS_1_8197F */
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8197F */
#define BIT_LTECOEX_ACCESS_START_V1_8197F BIT(31)
#define BIT_LTECOEX_WRITE_MODE_V1_8197F BIT(30)
#define BIT_LTECOEX_READY_BIT_V1_8197F BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN_V1_8197F 16
#define BIT_MASK_WRITE_BYTE_EN_V1_8197F 0xf
#define BIT_WRITE_BYTE_EN_V1_8197F(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN_V1_8197F) \
<< BIT_SHIFT_WRITE_BYTE_EN_V1_8197F)
#define BITS_WRITE_BYTE_EN_V1_8197F \
(BIT_MASK_WRITE_BYTE_EN_V1_8197F << BIT_SHIFT_WRITE_BYTE_EN_V1_8197F)
#define BIT_CLEAR_WRITE_BYTE_EN_V1_8197F(x) \
((x) & (~BITS_WRITE_BYTE_EN_V1_8197F))
#define BIT_GET_WRITE_BYTE_EN_V1_8197F(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN_V1_8197F) & \
BIT_MASK_WRITE_BYTE_EN_V1_8197F)
#define BIT_SET_WRITE_BYTE_EN_V1_8197F(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN_V1_8197F(x) | BIT_WRITE_BYTE_EN_V1_8197F(v))
#define BIT_SHIFT_LTECOEX_REG_ADDR_V1_8197F 0
#define BIT_MASK_LTECOEX_REG_ADDR_V1_8197F 0xffff
#define BIT_LTECOEX_REG_ADDR_V1_8197F(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR_V1_8197F) \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8197F)
#define BITS_LTECOEX_REG_ADDR_V1_8197F \
(BIT_MASK_LTECOEX_REG_ADDR_V1_8197F \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8197F)
#define BIT_CLEAR_LTECOEX_REG_ADDR_V1_8197F(x) \
((x) & (~BITS_LTECOEX_REG_ADDR_V1_8197F))
#define BIT_GET_LTECOEX_REG_ADDR_V1_8197F(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR_V1_8197F) & \
BIT_MASK_LTECOEX_REG_ADDR_V1_8197F)
#define BIT_SET_LTECOEX_REG_ADDR_V1_8197F(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR_V1_8197F(x) | \
BIT_LTECOEX_REG_ADDR_V1_8197F(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8197F */
#define BIT_SHIFT_LTECOEX_W_DATA_V1_8197F 0
#define BIT_MASK_LTECOEX_W_DATA_V1_8197F 0xffffffffL
#define BIT_LTECOEX_W_DATA_V1_8197F(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA_V1_8197F) \
<< BIT_SHIFT_LTECOEX_W_DATA_V1_8197F)
#define BITS_LTECOEX_W_DATA_V1_8197F \
(BIT_MASK_LTECOEX_W_DATA_V1_8197F << BIT_SHIFT_LTECOEX_W_DATA_V1_8197F)
#define BIT_CLEAR_LTECOEX_W_DATA_V1_8197F(x) \
((x) & (~BITS_LTECOEX_W_DATA_V1_8197F))
#define BIT_GET_LTECOEX_W_DATA_V1_8197F(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA_V1_8197F) & \
BIT_MASK_LTECOEX_W_DATA_V1_8197F)
#define BIT_SET_LTECOEX_W_DATA_V1_8197F(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA_V1_8197F(x) | BIT_LTECOEX_W_DATA_V1_8197F(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8197F */
#define BIT_SHIFT_LTECOEX_R_DATA_V1_8197F 0
#define BIT_MASK_LTECOEX_R_DATA_V1_8197F 0xffffffffL
#define BIT_LTECOEX_R_DATA_V1_8197F(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA_V1_8197F) \
<< BIT_SHIFT_LTECOEX_R_DATA_V1_8197F)
#define BITS_LTECOEX_R_DATA_V1_8197F \
(BIT_MASK_LTECOEX_R_DATA_V1_8197F << BIT_SHIFT_LTECOEX_R_DATA_V1_8197F)
#define BIT_CLEAR_LTECOEX_R_DATA_V1_8197F(x) \
((x) & (~BITS_LTECOEX_R_DATA_V1_8197F))
#define BIT_GET_LTECOEX_R_DATA_V1_8197F(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA_V1_8197F) & \
BIT_MASK_LTECOEX_R_DATA_V1_8197F)
#define BIT_SET_LTECOEX_R_DATA_V1_8197F(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA_V1_8197F(x) | BIT_LTECOEX_R_DATA_V1_8197F(v))
/* 2 REG_NOT_VALID_8197F */
#endif
================================================
FILE: hal/halmac/halmac_bit_8814b.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_BIT_8814B_H
#define __INC_HALMAC_BIT_8814B_H
#define CPU_OPT_WIDTH 0x1F
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_SYS_ISO_CTRL_8814B */
#define BIT_PWC_EV12V_8814B BIT(15)
/* 2 REG_NOT_VALID_8814B */
#define BIT_PA33V_EN_8814B BIT(13)
#define BIT_PA12V_EN_8814B BIT(12)
#define BIT_UA33V_EN_8814B BIT(11)
#define BIT_UA12V_EN_8814B BIT(10)
#define BIT_ISO_RFDIO_8814B BIT(9)
#define BIT_ISO_EB2CORE_8814B BIT(8)
#define BIT_ISO_DIOE_8814B BIT(7)
#define BIT_ISO_WLPON2PP_8814B BIT(6)
#define BIT_ISO_IP2MAC_WA2PP_8814B BIT(5)
#define BIT_ISO_PD2CORE_8814B BIT(4)
#define BIT_ISO_PA2PCIE_8814B BIT(3)
#define BIT_ISO_UD2CORE_8814B BIT(2)
#define BIT_ISO_UA2USB_8814B BIT(1)
#define BIT_ISO_WD2PP_8814B BIT(0)
/* 2 REG_SYS_FUNC_EN_8814B */
#define BIT_FEN_MREGEN_8814B BIT(15)
#define BIT_FEN_HWPDN_8814B BIT(14)
/* 2 REG_NOT_VALID_8814B */
#define BIT_FEN_ELDR_8814B BIT(12)
#define BIT_FEN_DCORE_8814B BIT(11)
#define BIT_FEN_CPUEN_8814B BIT(10)
#define BIT_FEN_DIOE_8814B BIT(9)
#define BIT_FEN_PCIED_8814B BIT(8)
#define BIT_FEN_PPLL_8814B BIT(7)
#define BIT_FEN_PCIEA_8814B BIT(6)
#define BIT_FEN_DIO_PCIE_8814B BIT(5)
#define BIT_FEN_USBD_8814B BIT(4)
#define BIT_FEN_UPLL_8814B BIT(3)
#define BIT_FEN_USBA_8814B BIT(2)
#define BIT_FEN_BB_GLB_RSTN_8814B BIT(1)
#define BIT_FEN_BBRSTB_8814B BIT(0)
/* 2 REG_SYS_PW_CTRL_8814B */
#define BIT_SOP_EABM_8814B BIT(31)
#define BIT_SOP_ACKF_8814B BIT(30)
#define BIT_SOP_ERCK_8814B BIT(29)
#define BIT_SOP_ESWR_8814B BIT(28)
#define BIT_SOP_PWMM_8814B BIT(27)
#define BIT_SOP_EECK_8814B BIT(26)
#define BIT_SOP_EXTL_8814B BIT(24)
#define BIT_SYM_OP_RING_12M_8814B BIT(22)
#define BIT_ROP_SWPR_8814B BIT(21)
#define BIT_DIS_HW_LPLDM_8814B BIT(20)
#define BIT_OPT_SWRST_WLMCU_8814B BIT(19)
#define BIT_RDY_SYSPWR_8814B BIT(17)
#define BIT_EN_WLON_8814B BIT(16)
#define BIT_APDM_HPDN_8814B BIT(15)
#define BIT_AFSM_PCIE_SUS_EN_8814B BIT(12)
#define BIT_AFSM_WLSUS_EN_8814B BIT(11)
#define BIT_APFM_SWLPS_8814B BIT(10)
#define BIT_APFM_OFFMAC_8814B BIT(9)
#define BIT_APFN_ONMAC_8814B BIT(8)
#define BIT_CHIP_PDN_EN_8814B BIT(7)
#define BIT_RDY_MACDIS_8814B BIT(6)
/* 2 REG_NOT_VALID_8814B */
#define BIT_PFM_WOWL_8814B BIT(3)
#define BIT_PFM_LDKP_8814B BIT(2)
#define BIT_WL_HCI_ALD_8814B BIT(1)
#define BIT_PFM_LDALL_8814B BIT(0)
/* 2 REG_SYS_CLK_CTRL_8814B */
#define BIT_DATA_CPU_CLK_EN_8814B BIT(15)
#define BIT_CPU_CLK_EN_8814B BIT(14)
#define BIT_SYMREG_CLK_EN_8814B BIT(13)
#define BIT_HCI_CLK_EN_8814B BIT(12)
#define BIT_MAC_CLK_EN_8814B BIT(11)
#define BIT_SEC_CLK_EN_8814B BIT(10)
#define BIT_PHY_SSC_RSTB_8814B BIT(9)
#define BIT_EXT_32K_EN_8814B BIT(8)
#define BIT_WL_CLK_TEST_8814B BIT(7)
#define BIT_OP_SPS_PWM_EN_8814B BIT(6)
#define BIT_LOADER_CLK_EN_8814B BIT(5)
#define BIT_MACSLP_8814B BIT(4)
#define BIT_WAKEPAD_EN_8814B BIT(3)
#define BIT_ROMD16V_EN_8814B BIT(2)
/* 2 REG_NOT_VALID_8814B */
#define BIT_CNTD16V_EN_8814B BIT(0)
/* 2 REG_SYS_EEPROM_CTRL_8814B */
#define BIT_SHIFT_VPDIDX_8814B 8
#define BIT_MASK_VPDIDX_8814B 0xff
#define BIT_VPDIDX_8814B(x) \
(((x) & BIT_MASK_VPDIDX_8814B) << BIT_SHIFT_VPDIDX_8814B)
#define BITS_VPDIDX_8814B (BIT_MASK_VPDIDX_8814B << BIT_SHIFT_VPDIDX_8814B)
#define BIT_CLEAR_VPDIDX_8814B(x) ((x) & (~BITS_VPDIDX_8814B))
#define BIT_GET_VPDIDX_8814B(x) \
(((x) >> BIT_SHIFT_VPDIDX_8814B) & BIT_MASK_VPDIDX_8814B)
#define BIT_SET_VPDIDX_8814B(x, v) \
(BIT_CLEAR_VPDIDX_8814B(x) | BIT_VPDIDX_8814B(v))
#define BIT_SHIFT_EEM1_0_8814B 6
#define BIT_MASK_EEM1_0_8814B 0x3
#define BIT_EEM1_0_8814B(x) \
(((x) & BIT_MASK_EEM1_0_8814B) << BIT_SHIFT_EEM1_0_8814B)
#define BITS_EEM1_0_8814B (BIT_MASK_EEM1_0_8814B << BIT_SHIFT_EEM1_0_8814B)
#define BIT_CLEAR_EEM1_0_8814B(x) ((x) & (~BITS_EEM1_0_8814B))
#define BIT_GET_EEM1_0_8814B(x) \
(((x) >> BIT_SHIFT_EEM1_0_8814B) & BIT_MASK_EEM1_0_8814B)
#define BIT_SET_EEM1_0_8814B(x, v) \
(BIT_CLEAR_EEM1_0_8814B(x) | BIT_EEM1_0_8814B(v))
#define BIT_AUTOLOAD_SUS_8814B BIT(5)
#define BIT_EERPOMSEL_8814B BIT(4)
#define BIT_EECS_V1_8814B BIT(3)
#define BIT_EESK_V1_8814B BIT(2)
#define BIT_EEDI_V1_8814B BIT(1)
#define BIT_EEDO_V1_8814B BIT(0)
/* 2 REG_EE_VPD_8814B */
#define BIT_SHIFT_VPD_DATA_8814B 0
#define BIT_MASK_VPD_DATA_8814B 0xffffffffL
#define BIT_VPD_DATA_8814B(x) \
(((x) & BIT_MASK_VPD_DATA_8814B) << BIT_SHIFT_VPD_DATA_8814B)
#define BITS_VPD_DATA_8814B \
(BIT_MASK_VPD_DATA_8814B << BIT_SHIFT_VPD_DATA_8814B)
#define BIT_CLEAR_VPD_DATA_8814B(x) ((x) & (~BITS_VPD_DATA_8814B))
#define BIT_GET_VPD_DATA_8814B(x) \
(((x) >> BIT_SHIFT_VPD_DATA_8814B) & BIT_MASK_VPD_DATA_8814B)
#define BIT_SET_VPD_DATA_8814B(x, v) \
(BIT_CLEAR_VPD_DATA_8814B(x) | BIT_VPD_DATA_8814B(v))
/* 2 REG_SYS_SWR_CTRL1_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CTRL_SPS_PWM_FREQ_8814B BIT(10)
/* 2 REG_NOT_VALID_8814B */
#define BIT_DISABLE_OPEN_SPS_LDO_8814B BIT(8)
#define BIT_MAC_ID_EN_8814B BIT(7)
#define BIT_WL_CTRL_XTAL_CADJ_8814B BIT(6)
#define BIT_AFE_BGEN_PCIE_OP_8814B BIT(2)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_SYS_SWR_CTRL2_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_SYS_SWR_CTRL3_8814B */
#define BIT_SPS18_OCP_DIS_8814B BIT(31)
#define BIT_SHIFT_SPS18_OCP_TH_8814B 16
#define BIT_MASK_SPS18_OCP_TH_8814B 0x7fff
#define BIT_SPS18_OCP_TH_8814B(x) \
(((x) & BIT_MASK_SPS18_OCP_TH_8814B) << BIT_SHIFT_SPS18_OCP_TH_8814B)
#define BITS_SPS18_OCP_TH_8814B \
(BIT_MASK_SPS18_OCP_TH_8814B << BIT_SHIFT_SPS18_OCP_TH_8814B)
#define BIT_CLEAR_SPS18_OCP_TH_8814B(x) ((x) & (~BITS_SPS18_OCP_TH_8814B))
#define BIT_GET_SPS18_OCP_TH_8814B(x) \
(((x) >> BIT_SHIFT_SPS18_OCP_TH_8814B) & BIT_MASK_SPS18_OCP_TH_8814B)
#define BIT_SET_SPS18_OCP_TH_8814B(x, v) \
(BIT_CLEAR_SPS18_OCP_TH_8814B(x) | BIT_SPS18_OCP_TH_8814B(v))
#define BIT_SHIFT_OCP_WINDOW_8814B 0
#define BIT_MASK_OCP_WINDOW_8814B 0xffff
#define BIT_OCP_WINDOW_8814B(x) \
(((x) & BIT_MASK_OCP_WINDOW_8814B) << BIT_SHIFT_OCP_WINDOW_8814B)
#define BITS_OCP_WINDOW_8814B \
(BIT_MASK_OCP_WINDOW_8814B << BIT_SHIFT_OCP_WINDOW_8814B)
#define BIT_CLEAR_OCP_WINDOW_8814B(x) ((x) & (~BITS_OCP_WINDOW_8814B))
#define BIT_GET_OCP_WINDOW_8814B(x) \
(((x) >> BIT_SHIFT_OCP_WINDOW_8814B) & BIT_MASK_OCP_WINDOW_8814B)
#define BIT_SET_OCP_WINDOW_8814B(x, v) \
(BIT_CLEAR_OCP_WINDOW_8814B(x) | BIT_OCP_WINDOW_8814B(v))
/* 2 REG_RSV_CTRL_8814B */
#define BIT_SHIFT_HREG_DBG_V1_8814B 12
#define BIT_MASK_HREG_DBG_V1_8814B 0xfff
#define BIT_HREG_DBG_V1_8814B(x) \
(((x) & BIT_MASK_HREG_DBG_V1_8814B) << BIT_SHIFT_HREG_DBG_V1_8814B)
#define BITS_HREG_DBG_V1_8814B \
(BIT_MASK_HREG_DBG_V1_8814B << BIT_SHIFT_HREG_DBG_V1_8814B)
#define BIT_CLEAR_HREG_DBG_V1_8814B(x) ((x) & (~BITS_HREG_DBG_V1_8814B))
#define BIT_GET_HREG_DBG_V1_8814B(x) \
(((x) >> BIT_SHIFT_HREG_DBG_V1_8814B) & BIT_MASK_HREG_DBG_V1_8814B)
#define BIT_SET_HREG_DBG_V1_8814B(x, v) \
(BIT_CLEAR_HREG_DBG_V1_8814B(x) | BIT_HREG_DBG_V1_8814B(v))
#define BIT_WLMCUIOIF_8814B BIT(8)
#define BIT_LOCK_ALL_EN_8814B BIT(7)
#define BIT_R_DIS_PRST_8814B BIT(6)
#define BIT_WLOCK_1C_B6_8814B BIT(5)
#define BIT_WLOCK_40_8814B BIT(4)
#define BIT_WLOCK_08_8814B BIT(3)
#define BIT_WLOCK_04_8814B BIT(2)
#define BIT_WLOCK_00_8814B BIT(1)
#define BIT_WLOCK_ALL_8814B BIT(0)
/* 2 REG_RF_CTRL_8814B */
#define BIT_RF_SDMRSTB_8814B BIT(2)
#define BIT_RF_RSTB_8814B BIT(1)
#define BIT_RF_EN_8814B BIT(0)
/* 2 REG_AFE_LDO_CTRL_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CPHY_LDO_CL_EN_8814B BIT(19)
#define BIT_CPHY_LDO_OK_8814B BIT(18)
#define BIT_PCIE_CALIB_EN_8814B BIT(17)
#define BIT_LDH12_EN_8814B BIT(16)
#define BIT_DATA_CPU_PWC_8814B BIT(15)
#define BIT_WLBBOFF_BIG_PWC_EN_8814B BIT(14)
#define BIT_WLBBOFF_SMALL_PWC_EN_8814B BIT(13)
#define BIT_WLMACOFF_BIG_PWC_EN_8814B BIT(12)
#define BIT_WLPON_PWC_EN_8814B BIT(11)
/* 2 REG_NOT_VALID_8814B */
#define BIT_LDOV12W_EN_8814B BIT(8)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_AFE_CTRL1_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_MAC_CLK_SEL_8814B 20
#define BIT_MASK_MAC_CLK_SEL_8814B 0x3
#define BIT_MAC_CLK_SEL_8814B(x) \
(((x) & BIT_MASK_MAC_CLK_SEL_8814B) << BIT_SHIFT_MAC_CLK_SEL_8814B)
#define BITS_MAC_CLK_SEL_8814B \
(BIT_MASK_MAC_CLK_SEL_8814B << BIT_SHIFT_MAC_CLK_SEL_8814B)
#define BIT_CLEAR_MAC_CLK_SEL_8814B(x) ((x) & (~BITS_MAC_CLK_SEL_8814B))
#define BIT_GET_MAC_CLK_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL_8814B) & BIT_MASK_MAC_CLK_SEL_8814B)
#define BIT_SET_MAC_CLK_SEL_8814B(x, v) \
(BIT_CLEAR_MAC_CLK_SEL_8814B(x) | BIT_MAC_CLK_SEL_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ANAPARSW_POW_MAC_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_ENB_LDO_DIODE_L_8814B BIT(3)
#define BIT_POW_LDO15_8814B BIT(2)
#define BIT_POW_SW_8814B BIT(1)
#define BIT_POW_LDO14_8814B BIT(0)
/* 2 REG_ANAPARLDO_POW_MAC_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_LDOE25_POW_L_8814B BIT(0)
/* 2 REG_ANAPAR_POW_MAC_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_POW_PC_LDO3_8814B BIT(5)
#define BIT_POW_PC_LDO2_8814B BIT(4)
#define BIT_POW_PC_LDO1_8814B BIT(3)
#define BIT_POW_PC_LDO0_8814B BIT(2)
#define BIT_POW_PLL_V1_8814B BIT(1)
#define BIT_POW_POWER_CUT_8814B BIT(0)
/* 2 REG_ANAPAR_POW_XTAL_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_POW_XTAL_8814B BIT(1)
#define BIT_POW_BG_8814B BIT(0)
/* 2 REG_ANAPARLDO_MAC_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_EFUSE_CTRL_8814B */
#define BIT_EF_FLAG_8814B BIT(31)
#define BIT_SHIFT_EF_PGPD_8814B 28
#define BIT_MASK_EF_PGPD_8814B 0x7
#define BIT_EF_PGPD_8814B(x) \
(((x) & BIT_MASK_EF_PGPD_8814B) << BIT_SHIFT_EF_PGPD_8814B)
#define BITS_EF_PGPD_8814B (BIT_MASK_EF_PGPD_8814B << BIT_SHIFT_EF_PGPD_8814B)
#define BIT_CLEAR_EF_PGPD_8814B(x) ((x) & (~BITS_EF_PGPD_8814B))
#define BIT_GET_EF_PGPD_8814B(x) \
(((x) >> BIT_SHIFT_EF_PGPD_8814B) & BIT_MASK_EF_PGPD_8814B)
#define BIT_SET_EF_PGPD_8814B(x, v) \
(BIT_CLEAR_EF_PGPD_8814B(x) | BIT_EF_PGPD_8814B(v))
#define BIT_SHIFT_EF_RDT_8814B 24
#define BIT_MASK_EF_RDT_8814B 0xf
#define BIT_EF_RDT_8814B(x) \
(((x) & BIT_MASK_EF_RDT_8814B) << BIT_SHIFT_EF_RDT_8814B)
#define BITS_EF_RDT_8814B (BIT_MASK_EF_RDT_8814B << BIT_SHIFT_EF_RDT_8814B)
#define BIT_CLEAR_EF_RDT_8814B(x) ((x) & (~BITS_EF_RDT_8814B))
#define BIT_GET_EF_RDT_8814B(x) \
(((x) >> BIT_SHIFT_EF_RDT_8814B) & BIT_MASK_EF_RDT_8814B)
#define BIT_SET_EF_RDT_8814B(x, v) \
(BIT_CLEAR_EF_RDT_8814B(x) | BIT_EF_RDT_8814B(v))
#define BIT_SHIFT_EF_PGTS_8814B 20
#define BIT_MASK_EF_PGTS_8814B 0xf
#define BIT_EF_PGTS_8814B(x) \
(((x) & BIT_MASK_EF_PGTS_8814B) << BIT_SHIFT_EF_PGTS_8814B)
#define BITS_EF_PGTS_8814B (BIT_MASK_EF_PGTS_8814B << BIT_SHIFT_EF_PGTS_8814B)
#define BIT_CLEAR_EF_PGTS_8814B(x) ((x) & (~BITS_EF_PGTS_8814B))
#define BIT_GET_EF_PGTS_8814B(x) \
(((x) >> BIT_SHIFT_EF_PGTS_8814B) & BIT_MASK_EF_PGTS_8814B)
#define BIT_SET_EF_PGTS_8814B(x, v) \
(BIT_CLEAR_EF_PGTS_8814B(x) | BIT_EF_PGTS_8814B(v))
#define BIT_EF_PDWN_8814B BIT(19)
#define BIT_EF_ALDEN_8814B BIT(18)
#define BIT_SHIFT_EF_ADDR_8814B 8
#define BIT_MASK_EF_ADDR_8814B 0x3ff
#define BIT_EF_ADDR_8814B(x) \
(((x) & BIT_MASK_EF_ADDR_8814B) << BIT_SHIFT_EF_ADDR_8814B)
#define BITS_EF_ADDR_8814B (BIT_MASK_EF_ADDR_8814B << BIT_SHIFT_EF_ADDR_8814B)
#define BIT_CLEAR_EF_ADDR_8814B(x) ((x) & (~BITS_EF_ADDR_8814B))
#define BIT_GET_EF_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_EF_ADDR_8814B) & BIT_MASK_EF_ADDR_8814B)
#define BIT_SET_EF_ADDR_8814B(x, v) \
(BIT_CLEAR_EF_ADDR_8814B(x) | BIT_EF_ADDR_8814B(v))
#define BIT_SHIFT_EF_DATA_8814B 0
#define BIT_MASK_EF_DATA_8814B 0xff
#define BIT_EF_DATA_8814B(x) \
(((x) & BIT_MASK_EF_DATA_8814B) << BIT_SHIFT_EF_DATA_8814B)
#define BITS_EF_DATA_8814B (BIT_MASK_EF_DATA_8814B << BIT_SHIFT_EF_DATA_8814B)
#define BIT_CLEAR_EF_DATA_8814B(x) ((x) & (~BITS_EF_DATA_8814B))
#define BIT_GET_EF_DATA_8814B(x) \
(((x) >> BIT_SHIFT_EF_DATA_8814B) & BIT_MASK_EF_DATA_8814B)
#define BIT_SET_EF_DATA_8814B(x, v) \
(BIT_CLEAR_EF_DATA_8814B(x) | BIT_EF_DATA_8814B(v))
/* 2 REG_LDO_EFUSE_CTRL_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_EF_CRES_SEL_8814B BIT(26)
#define BIT_SHIFT_EF_SCAN_START_V1_8814B 16
#define BIT_MASK_EF_SCAN_START_V1_8814B 0x3ff
#define BIT_EF_SCAN_START_V1_8814B(x) \
(((x) & BIT_MASK_EF_SCAN_START_V1_8814B) \
<< BIT_SHIFT_EF_SCAN_START_V1_8814B)
#define BITS_EF_SCAN_START_V1_8814B \
(BIT_MASK_EF_SCAN_START_V1_8814B << BIT_SHIFT_EF_SCAN_START_V1_8814B)
#define BIT_CLEAR_EF_SCAN_START_V1_8814B(x) \
((x) & (~BITS_EF_SCAN_START_V1_8814B))
#define BIT_GET_EF_SCAN_START_V1_8814B(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START_V1_8814B) & \
BIT_MASK_EF_SCAN_START_V1_8814B)
#define BIT_SET_EF_SCAN_START_V1_8814B(x, v) \
(BIT_CLEAR_EF_SCAN_START_V1_8814B(x) | BIT_EF_SCAN_START_V1_8814B(v))
#define BIT_SHIFT_EF_SCAN_END_8814B 12
#define BIT_MASK_EF_SCAN_END_8814B 0xf
#define BIT_EF_SCAN_END_8814B(x) \
(((x) & BIT_MASK_EF_SCAN_END_8814B) << BIT_SHIFT_EF_SCAN_END_8814B)
#define BITS_EF_SCAN_END_8814B \
(BIT_MASK_EF_SCAN_END_8814B << BIT_SHIFT_EF_SCAN_END_8814B)
#define BIT_CLEAR_EF_SCAN_END_8814B(x) ((x) & (~BITS_EF_SCAN_END_8814B))
#define BIT_GET_EF_SCAN_END_8814B(x) \
(((x) >> BIT_SHIFT_EF_SCAN_END_8814B) & BIT_MASK_EF_SCAN_END_8814B)
#define BIT_SET_EF_SCAN_END_8814B(x, v) \
(BIT_CLEAR_EF_SCAN_END_8814B(x) | BIT_EF_SCAN_END_8814B(v))
#define BIT_EF_PD_DIS_8814B BIT(11)
#define BIT_SHIFT_EF_CELL_SEL_8814B 8
#define BIT_MASK_EF_CELL_SEL_8814B 0x3
#define BIT_EF_CELL_SEL_8814B(x) \
(((x) & BIT_MASK_EF_CELL_SEL_8814B) << BIT_SHIFT_EF_CELL_SEL_8814B)
#define BITS_EF_CELL_SEL_8814B \
(BIT_MASK_EF_CELL_SEL_8814B << BIT_SHIFT_EF_CELL_SEL_8814B)
#define BIT_CLEAR_EF_CELL_SEL_8814B(x) ((x) & (~BITS_EF_CELL_SEL_8814B))
#define BIT_GET_EF_CELL_SEL_8814B(x) \
(((x) >> BIT_SHIFT_EF_CELL_SEL_8814B) & BIT_MASK_EF_CELL_SEL_8814B)
#define BIT_SET_EF_CELL_SEL_8814B(x, v) \
(BIT_CLEAR_EF_CELL_SEL_8814B(x) | BIT_EF_CELL_SEL_8814B(v))
#define BIT_EF_TRPT_8814B BIT(7)
#define BIT_SHIFT_EF_TTHD_8814B 0
#define BIT_MASK_EF_TTHD_8814B 0x7f
#define BIT_EF_TTHD_8814B(x) \
(((x) & BIT_MASK_EF_TTHD_8814B) << BIT_SHIFT_EF_TTHD_8814B)
#define BITS_EF_TTHD_8814B (BIT_MASK_EF_TTHD_8814B << BIT_SHIFT_EF_TTHD_8814B)
#define BIT_CLEAR_EF_TTHD_8814B(x) ((x) & (~BITS_EF_TTHD_8814B))
#define BIT_GET_EF_TTHD_8814B(x) \
(((x) >> BIT_SHIFT_EF_TTHD_8814B) & BIT_MASK_EF_TTHD_8814B)
#define BIT_SET_EF_TTHD_8814B(x, v) \
(BIT_CLEAR_EF_TTHD_8814B(x) | BIT_EF_TTHD_8814B(v))
/* 2 REG_PWR_OPTION_CTRL_8814B */
#define BIT_SHIFT_DBG_SEL_V1_8814B 16
#define BIT_MASK_DBG_SEL_V1_8814B 0xff
#define BIT_DBG_SEL_V1_8814B(x) \
(((x) & BIT_MASK_DBG_SEL_V1_8814B) << BIT_SHIFT_DBG_SEL_V1_8814B)
#define BITS_DBG_SEL_V1_8814B \
(BIT_MASK_DBG_SEL_V1_8814B << BIT_SHIFT_DBG_SEL_V1_8814B)
#define BIT_CLEAR_DBG_SEL_V1_8814B(x) ((x) & (~BITS_DBG_SEL_V1_8814B))
#define BIT_GET_DBG_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_DBG_SEL_V1_8814B) & BIT_MASK_DBG_SEL_V1_8814B)
#define BIT_SET_DBG_SEL_V1_8814B(x, v) \
(BIT_CLEAR_DBG_SEL_V1_8814B(x) | BIT_DBG_SEL_V1_8814B(v))
#define BIT_SHIFT_DBG_SEL_BYTE_8814B 14
#define BIT_MASK_DBG_SEL_BYTE_8814B 0x3
#define BIT_DBG_SEL_BYTE_8814B(x) \
(((x) & BIT_MASK_DBG_SEL_BYTE_8814B) << BIT_SHIFT_DBG_SEL_BYTE_8814B)
#define BITS_DBG_SEL_BYTE_8814B \
(BIT_MASK_DBG_SEL_BYTE_8814B << BIT_SHIFT_DBG_SEL_BYTE_8814B)
#define BIT_CLEAR_DBG_SEL_BYTE_8814B(x) ((x) & (~BITS_DBG_SEL_BYTE_8814B))
#define BIT_GET_DBG_SEL_BYTE_8814B(x) \
(((x) >> BIT_SHIFT_DBG_SEL_BYTE_8814B) & BIT_MASK_DBG_SEL_BYTE_8814B)
#define BIT_SET_DBG_SEL_BYTE_8814B(x, v) \
(BIT_CLEAR_DBG_SEL_BYTE_8814B(x) | BIT_DBG_SEL_BYTE_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SYSON_DBG_PAD_E2_8814B BIT(11)
#define BIT_SYSON_LED_PAD_E2_8814B BIT(10)
#define BIT_SYSON_GPEE_PAD_E2_8814B BIT(9)
#define BIT_SYSON_PCI_PAD_E2_8814B BIT(8)
#define BIT_AUTO_SW_LDO_VOL_EN_8814B BIT(7)
#define BIT_SHIFT_SYSON_SPS0WWV_WT_8814B 4
#define BIT_MASK_SYSON_SPS0WWV_WT_8814B 0x3
#define BIT_SYSON_SPS0WWV_WT_8814B(x) \
(((x) & BIT_MASK_SYSON_SPS0WWV_WT_8814B) \
<< BIT_SHIFT_SYSON_SPS0WWV_WT_8814B)
#define BITS_SYSON_SPS0WWV_WT_8814B \
(BIT_MASK_SYSON_SPS0WWV_WT_8814B << BIT_SHIFT_SYSON_SPS0WWV_WT_8814B)
#define BIT_CLEAR_SYSON_SPS0WWV_WT_8814B(x) \
((x) & (~BITS_SYSON_SPS0WWV_WT_8814B))
#define BIT_GET_SYSON_SPS0WWV_WT_8814B(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0WWV_WT_8814B) & \
BIT_MASK_SYSON_SPS0WWV_WT_8814B)
#define BIT_SET_SYSON_SPS0WWV_WT_8814B(x, v) \
(BIT_CLEAR_SYSON_SPS0WWV_WT_8814B(x) | BIT_SYSON_SPS0WWV_WT_8814B(v))
#define BIT_SHIFT_SYSON_SPS0LDO_WT_8814B 2
#define BIT_MASK_SYSON_SPS0LDO_WT_8814B 0x3
#define BIT_SYSON_SPS0LDO_WT_8814B(x) \
(((x) & BIT_MASK_SYSON_SPS0LDO_WT_8814B) \
<< BIT_SHIFT_SYSON_SPS0LDO_WT_8814B)
#define BITS_SYSON_SPS0LDO_WT_8814B \
(BIT_MASK_SYSON_SPS0LDO_WT_8814B << BIT_SHIFT_SYSON_SPS0LDO_WT_8814B)
#define BIT_CLEAR_SYSON_SPS0LDO_WT_8814B(x) \
((x) & (~BITS_SYSON_SPS0LDO_WT_8814B))
#define BIT_GET_SYSON_SPS0LDO_WT_8814B(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0LDO_WT_8814B) & \
BIT_MASK_SYSON_SPS0LDO_WT_8814B)
#define BIT_SET_SYSON_SPS0LDO_WT_8814B(x, v) \
(BIT_CLEAR_SYSON_SPS0LDO_WT_8814B(x) | BIT_SYSON_SPS0LDO_WT_8814B(v))
#define BIT_SHIFT_SYSON_RCLK_SCALE_8814B 0
#define BIT_MASK_SYSON_RCLK_SCALE_8814B 0x3
#define BIT_SYSON_RCLK_SCALE_8814B(x) \
(((x) & BIT_MASK_SYSON_RCLK_SCALE_8814B) \
<< BIT_SHIFT_SYSON_RCLK_SCALE_8814B)
#define BITS_SYSON_RCLK_SCALE_8814B \
(BIT_MASK_SYSON_RCLK_SCALE_8814B << BIT_SHIFT_SYSON_RCLK_SCALE_8814B)
#define BIT_CLEAR_SYSON_RCLK_SCALE_8814B(x) \
((x) & (~BITS_SYSON_RCLK_SCALE_8814B))
#define BIT_GET_SYSON_RCLK_SCALE_8814B(x) \
(((x) >> BIT_SHIFT_SYSON_RCLK_SCALE_8814B) & \
BIT_MASK_SYSON_RCLK_SCALE_8814B)
#define BIT_SET_SYSON_RCLK_SCALE_8814B(x, v) \
(BIT_CLEAR_SYSON_RCLK_SCALE_8814B(x) | BIT_SYSON_RCLK_SCALE_8814B(v))
/* 2 REG_CAL_TIMER_8814B */
#define BIT_SHIFT_MATCH_CNT_8814B 8
#define BIT_MASK_MATCH_CNT_8814B 0xff
#define BIT_MATCH_CNT_8814B(x) \
(((x) & BIT_MASK_MATCH_CNT_8814B) << BIT_SHIFT_MATCH_CNT_8814B)
#define BITS_MATCH_CNT_8814B \
(BIT_MASK_MATCH_CNT_8814B << BIT_SHIFT_MATCH_CNT_8814B)
#define BIT_CLEAR_MATCH_CNT_8814B(x) ((x) & (~BITS_MATCH_CNT_8814B))
#define BIT_GET_MATCH_CNT_8814B(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8814B) & BIT_MASK_MATCH_CNT_8814B)
#define BIT_SET_MATCH_CNT_8814B(x, v) \
(BIT_CLEAR_MATCH_CNT_8814B(x) | BIT_MATCH_CNT_8814B(v))
#define BIT_SHIFT_CAL_SCAL_8814B 0
#define BIT_MASK_CAL_SCAL_8814B 0xff
#define BIT_CAL_SCAL_8814B(x) \
(((x) & BIT_MASK_CAL_SCAL_8814B) << BIT_SHIFT_CAL_SCAL_8814B)
#define BITS_CAL_SCAL_8814B \
(BIT_MASK_CAL_SCAL_8814B << BIT_SHIFT_CAL_SCAL_8814B)
#define BIT_CLEAR_CAL_SCAL_8814B(x) ((x) & (~BITS_CAL_SCAL_8814B))
#define BIT_GET_CAL_SCAL_8814B(x) \
(((x) >> BIT_SHIFT_CAL_SCAL_8814B) & BIT_MASK_CAL_SCAL_8814B)
#define BIT_SET_CAL_SCAL_8814B(x, v) \
(BIT_CLEAR_CAL_SCAL_8814B(x) | BIT_CAL_SCAL_8814B(v))
/* 2 REG_ACLK_MON_8814B */
#define BIT_SHIFT_RCLK_MON_8814B 5
#define BIT_MASK_RCLK_MON_8814B 0x7ff
#define BIT_RCLK_MON_8814B(x) \
(((x) & BIT_MASK_RCLK_MON_8814B) << BIT_SHIFT_RCLK_MON_8814B)
#define BITS_RCLK_MON_8814B \
(BIT_MASK_RCLK_MON_8814B << BIT_SHIFT_RCLK_MON_8814B)
#define BIT_CLEAR_RCLK_MON_8814B(x) ((x) & (~BITS_RCLK_MON_8814B))
#define BIT_GET_RCLK_MON_8814B(x) \
(((x) >> BIT_SHIFT_RCLK_MON_8814B) & BIT_MASK_RCLK_MON_8814B)
#define BIT_SET_RCLK_MON_8814B(x, v) \
(BIT_CLEAR_RCLK_MON_8814B(x) | BIT_RCLK_MON_8814B(v))
#define BIT_CAL_EN_8814B BIT(4)
#define BIT_SHIFT_DPSTU_8814B 2
#define BIT_MASK_DPSTU_8814B 0x3
#define BIT_DPSTU_8814B(x) \
(((x) & BIT_MASK_DPSTU_8814B) << BIT_SHIFT_DPSTU_8814B)
#define BITS_DPSTU_8814B (BIT_MASK_DPSTU_8814B << BIT_SHIFT_DPSTU_8814B)
#define BIT_CLEAR_DPSTU_8814B(x) ((x) & (~BITS_DPSTU_8814B))
#define BIT_GET_DPSTU_8814B(x) \
(((x) >> BIT_SHIFT_DPSTU_8814B) & BIT_MASK_DPSTU_8814B)
#define BIT_SET_DPSTU_8814B(x, v) \
(BIT_CLEAR_DPSTU_8814B(x) | BIT_DPSTU_8814B(v))
#define BIT_SUS_16X_8814B BIT(1)
/* 2 REG_GPIO_MUXCFG_8814B */
#define BIT_EN_DATACPU_GPIO2_8814B BIT(24)
#define BIT_EN_DATACPU_GPIO_8814B BIT(23)
#define BIT_EN_DATACPU_UART_8814B BIT(22)
#define BIT_DATACPU_FSPI_EN_8814B BIT(21)
#define BIT_EN_GPIO8_UART_OUT_8814B BIT(20)
#define BIT_FSPI_EN_8814B BIT(19)
#define BIT_WL_RTS_EXT_32K_SEL_8814B BIT(18)
#define BIT_WLGP_SPI_EN_8814B BIT(16)
#define BIT_SIC_LBK_8814B BIT(15)
#define BIT_ENHTP_8814B BIT(14)
#define BIT_ENSIC_8814B BIT(12)
#define BIT_SIC_SWRST_8814B BIT(11)
#define BIT_PO_WIFI_PTA_PINS_8814B BIT(10)
#define BIT_PO_BT_PTA_PINS_8814B BIT(9)
#define BIT_ENUART_8814B BIT(8)
#define BIT_SHIFT_BTMODE_8814B 6
#define BIT_MASK_BTMODE_8814B 0x3
#define BIT_BTMODE_8814B(x) \
(((x) & BIT_MASK_BTMODE_8814B) << BIT_SHIFT_BTMODE_8814B)
#define BITS_BTMODE_8814B (BIT_MASK_BTMODE_8814B << BIT_SHIFT_BTMODE_8814B)
#define BIT_CLEAR_BTMODE_8814B(x) ((x) & (~BITS_BTMODE_8814B))
#define BIT_GET_BTMODE_8814B(x) \
(((x) >> BIT_SHIFT_BTMODE_8814B) & BIT_MASK_BTMODE_8814B)
#define BIT_SET_BTMODE_8814B(x, v) \
(BIT_CLEAR_BTMODE_8814B(x) | BIT_BTMODE_8814B(v))
#define BIT_ENBT_8814B BIT(5)
#define BIT_EROM_EN_8814B BIT(4)
#define BIT_WLRFE_6_7_EN_8814B BIT(3)
#define BIT_WLRFE_4_5_EN_8814B BIT(2)
#define BIT_SHIFT_GPIOSEL_8814B 0
#define BIT_MASK_GPIOSEL_8814B 0x3
#define BIT_GPIOSEL_8814B(x) \
(((x) & BIT_MASK_GPIOSEL_8814B) << BIT_SHIFT_GPIOSEL_8814B)
#define BITS_GPIOSEL_8814B (BIT_MASK_GPIOSEL_8814B << BIT_SHIFT_GPIOSEL_8814B)
#define BIT_CLEAR_GPIOSEL_8814B(x) ((x) & (~BITS_GPIOSEL_8814B))
#define BIT_GET_GPIOSEL_8814B(x) \
(((x) >> BIT_SHIFT_GPIOSEL_8814B) & BIT_MASK_GPIOSEL_8814B)
#define BIT_SET_GPIOSEL_8814B(x, v) \
(BIT_CLEAR_GPIOSEL_8814B(x) | BIT_GPIOSEL_8814B(v))
/* 2 REG_GPIO_PIN_CTRL_8814B */
#define BIT_SHIFT_GPIO_MOD_7_TO_0_8814B 24
#define BIT_MASK_GPIO_MOD_7_TO_0_8814B 0xff
#define BIT_GPIO_MOD_7_TO_0_8814B(x) \
(((x) & BIT_MASK_GPIO_MOD_7_TO_0_8814B) \
<< BIT_SHIFT_GPIO_MOD_7_TO_0_8814B)
#define BITS_GPIO_MOD_7_TO_0_8814B \
(BIT_MASK_GPIO_MOD_7_TO_0_8814B << BIT_SHIFT_GPIO_MOD_7_TO_0_8814B)
#define BIT_CLEAR_GPIO_MOD_7_TO_0_8814B(x) ((x) & (~BITS_GPIO_MOD_7_TO_0_8814B))
#define BIT_GET_GPIO_MOD_7_TO_0_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_7_TO_0_8814B) & \
BIT_MASK_GPIO_MOD_7_TO_0_8814B)
#define BIT_SET_GPIO_MOD_7_TO_0_8814B(x, v) \
(BIT_CLEAR_GPIO_MOD_7_TO_0_8814B(x) | BIT_GPIO_MOD_7_TO_0_8814B(v))
#define BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8814B 16
#define BIT_MASK_GPIO_IO_SEL_7_TO_0_8814B 0xff
#define BIT_GPIO_IO_SEL_7_TO_0_8814B(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_7_TO_0_8814B) \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8814B)
#define BITS_GPIO_IO_SEL_7_TO_0_8814B \
(BIT_MASK_GPIO_IO_SEL_7_TO_0_8814B \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8814B)
#define BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8814B(x) \
((x) & (~BITS_GPIO_IO_SEL_7_TO_0_8814B))
#define BIT_GET_GPIO_IO_SEL_7_TO_0_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8814B) & \
BIT_MASK_GPIO_IO_SEL_7_TO_0_8814B)
#define BIT_SET_GPIO_IO_SEL_7_TO_0_8814B(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8814B(x) | \
BIT_GPIO_IO_SEL_7_TO_0_8814B(v))
#define BIT_SHIFT_GPIO_OUT_7_TO_0_8814B 8
#define BIT_MASK_GPIO_OUT_7_TO_0_8814B 0xff
#define BIT_GPIO_OUT_7_TO_0_8814B(x) \
(((x) & BIT_MASK_GPIO_OUT_7_TO_0_8814B) \
<< BIT_SHIFT_GPIO_OUT_7_TO_0_8814B)
#define BITS_GPIO_OUT_7_TO_0_8814B \
(BIT_MASK_GPIO_OUT_7_TO_0_8814B << BIT_SHIFT_GPIO_OUT_7_TO_0_8814B)
#define BIT_CLEAR_GPIO_OUT_7_TO_0_8814B(x) ((x) & (~BITS_GPIO_OUT_7_TO_0_8814B))
#define BIT_GET_GPIO_OUT_7_TO_0_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_7_TO_0_8814B) & \
BIT_MASK_GPIO_OUT_7_TO_0_8814B)
#define BIT_SET_GPIO_OUT_7_TO_0_8814B(x, v) \
(BIT_CLEAR_GPIO_OUT_7_TO_0_8814B(x) | BIT_GPIO_OUT_7_TO_0_8814B(v))
#define BIT_SHIFT_GPIO_IN_7_TO_0_8814B 0
#define BIT_MASK_GPIO_IN_7_TO_0_8814B 0xff
#define BIT_GPIO_IN_7_TO_0_8814B(x) \
(((x) & BIT_MASK_GPIO_IN_7_TO_0_8814B) \
<< BIT_SHIFT_GPIO_IN_7_TO_0_8814B)
#define BITS_GPIO_IN_7_TO_0_8814B \
(BIT_MASK_GPIO_IN_7_TO_0_8814B << BIT_SHIFT_GPIO_IN_7_TO_0_8814B)
#define BIT_CLEAR_GPIO_IN_7_TO_0_8814B(x) ((x) & (~BITS_GPIO_IN_7_TO_0_8814B))
#define BIT_GET_GPIO_IN_7_TO_0_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_IN_7_TO_0_8814B) & \
BIT_MASK_GPIO_IN_7_TO_0_8814B)
#define BIT_SET_GPIO_IN_7_TO_0_8814B(x, v) \
(BIT_CLEAR_GPIO_IN_7_TO_0_8814B(x) | BIT_GPIO_IN_7_TO_0_8814B(v))
/* 2 REG_GPIO_INTM_8814B */
#define BIT_SHIFT_MUXDBG_SEL_8814B 30
#define BIT_MASK_MUXDBG_SEL_8814B 0x3
#define BIT_MUXDBG_SEL_8814B(x) \
(((x) & BIT_MASK_MUXDBG_SEL_8814B) << BIT_SHIFT_MUXDBG_SEL_8814B)
#define BITS_MUXDBG_SEL_8814B \
(BIT_MASK_MUXDBG_SEL_8814B << BIT_SHIFT_MUXDBG_SEL_8814B)
#define BIT_CLEAR_MUXDBG_SEL_8814B(x) ((x) & (~BITS_MUXDBG_SEL_8814B))
#define BIT_GET_MUXDBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL_8814B) & BIT_MASK_MUXDBG_SEL_8814B)
#define BIT_SET_MUXDBG_SEL_8814B(x, v) \
(BIT_CLEAR_MUXDBG_SEL_8814B(x) | BIT_MUXDBG_SEL_8814B(v))
#define BIT_EXTWOL_SEL_8814B BIT(17)
#define BIT_EXTWOL_EN_8814B BIT(16)
#define BIT_GPIOF_INT_MD_8814B BIT(15)
#define BIT_GPIOE_INT_MD_8814B BIT(14)
#define BIT_GPIOD_INT_MD_8814B BIT(13)
#define BIT_GPIOF_INT_MD_8814B BIT(15)
#define BIT_GPIOE_INT_MD_8814B BIT(14)
#define BIT_GPIOD_INT_MD_8814B BIT(13)
#define BIT_GPIOC_INT_MD_8814B BIT(12)
#define BIT_GPIOB_INT_MD_8814B BIT(11)
#define BIT_GPIOA_INT_MD_8814B BIT(10)
#define BIT_GPIO9_INT_MD_8814B BIT(9)
#define BIT_GPIO8_INT_MD_8814B BIT(8)
#define BIT_GPIO7_INT_MD_8814B BIT(7)
#define BIT_GPIO6_INT_MD_8814B BIT(6)
#define BIT_GPIO5_INT_MD_8814B BIT(5)
#define BIT_GPIO4_INT_MD_8814B BIT(4)
#define BIT_GPIO3_INT_MD_8814B BIT(3)
#define BIT_GPIO2_INT_MD_8814B BIT(2)
#define BIT_GPIO1_INT_MD_8814B BIT(1)
#define BIT_GPIO0_INT_MD_8814B BIT(0)
/* 2 REG_LED_CFG_8814B */
#define BIT_GPIO3_WL_CTRL_EN_8814B BIT(27)
#define BIT_LNAON_SEL_EN_8814B BIT(26)
#define BIT_PAPE_SEL_EN_8814B BIT(25)
#define BIT_DPDT_WLBT_SEL_8814B BIT(24)
#define BIT_DPDT_SEL_EN_8814B BIT(23)
#define BIT_GPIO13_14_WL_CTRL_EN_8814B BIT(22)
#define BIT_LED2DIS_8814B BIT(21)
#define BIT_LED2PL_8814B BIT(20)
#define BIT_LED2SV_8814B BIT(19)
#define BIT_SHIFT_LED2CM_8814B 16
#define BIT_MASK_LED2CM_8814B 0x7
#define BIT_LED2CM_8814B(x) \
(((x) & BIT_MASK_LED2CM_8814B) << BIT_SHIFT_LED2CM_8814B)
#define BITS_LED2CM_8814B (BIT_MASK_LED2CM_8814B << BIT_SHIFT_LED2CM_8814B)
#define BIT_CLEAR_LED2CM_8814B(x) ((x) & (~BITS_LED2CM_8814B))
#define BIT_GET_LED2CM_8814B(x) \
(((x) >> BIT_SHIFT_LED2CM_8814B) & BIT_MASK_LED2CM_8814B)
#define BIT_SET_LED2CM_8814B(x, v) \
(BIT_CLEAR_LED2CM_8814B(x) | BIT_LED2CM_8814B(v))
#define BIT_LED1DIS_8814B BIT(15)
#define BIT_LED1PL_8814B BIT(12)
#define BIT_LED1SV_8814B BIT(11)
#define BIT_SHIFT_LED1CM_8814B 8
#define BIT_MASK_LED1CM_8814B 0x7
#define BIT_LED1CM_8814B(x) \
(((x) & BIT_MASK_LED1CM_8814B) << BIT_SHIFT_LED1CM_8814B)
#define BITS_LED1CM_8814B (BIT_MASK_LED1CM_8814B << BIT_SHIFT_LED1CM_8814B)
#define BIT_CLEAR_LED1CM_8814B(x) ((x) & (~BITS_LED1CM_8814B))
#define BIT_GET_LED1CM_8814B(x) \
(((x) >> BIT_SHIFT_LED1CM_8814B) & BIT_MASK_LED1CM_8814B)
#define BIT_SET_LED1CM_8814B(x, v) \
(BIT_CLEAR_LED1CM_8814B(x) | BIT_LED1CM_8814B(v))
#define BIT_LED0DIS_8814B BIT(7)
#define BIT_SHIFT_AFE_LDO_SWR_CHECK_8814B 5
#define BIT_MASK_AFE_LDO_SWR_CHECK_8814B 0x3
#define BIT_AFE_LDO_SWR_CHECK_8814B(x) \
(((x) & BIT_MASK_AFE_LDO_SWR_CHECK_8814B) \
<< BIT_SHIFT_AFE_LDO_SWR_CHECK_8814B)
#define BITS_AFE_LDO_SWR_CHECK_8814B \
(BIT_MASK_AFE_LDO_SWR_CHECK_8814B << BIT_SHIFT_AFE_LDO_SWR_CHECK_8814B)
#define BIT_CLEAR_AFE_LDO_SWR_CHECK_8814B(x) \
((x) & (~BITS_AFE_LDO_SWR_CHECK_8814B))
#define BIT_GET_AFE_LDO_SWR_CHECK_8814B(x) \
(((x) >> BIT_SHIFT_AFE_LDO_SWR_CHECK_8814B) & \
BIT_MASK_AFE_LDO_SWR_CHECK_8814B)
#define BIT_SET_AFE_LDO_SWR_CHECK_8814B(x, v) \
(BIT_CLEAR_AFE_LDO_SWR_CHECK_8814B(x) | BIT_AFE_LDO_SWR_CHECK_8814B(v))
#define BIT_LED0PL_8814B BIT(4)
#define BIT_LED0SV_8814B BIT(3)
#define BIT_SHIFT_LED0CM_8814B 0
#define BIT_MASK_LED0CM_8814B 0x7
#define BIT_LED0CM_8814B(x) \
(((x) & BIT_MASK_LED0CM_8814B) << BIT_SHIFT_LED0CM_8814B)
#define BITS_LED0CM_8814B (BIT_MASK_LED0CM_8814B << BIT_SHIFT_LED0CM_8814B)
#define BIT_CLEAR_LED0CM_8814B(x) ((x) & (~BITS_LED0CM_8814B))
#define BIT_GET_LED0CM_8814B(x) \
(((x) >> BIT_SHIFT_LED0CM_8814B) & BIT_MASK_LED0CM_8814B)
#define BIT_SET_LED0CM_8814B(x, v) \
(BIT_CLEAR_LED0CM_8814B(x) | BIT_LED0CM_8814B(v))
/* 2 REG_FSIMR_8814B */
#define BIT_FS_PDNINT_EN_8814B BIT(31)
#define BIT_NFC_INT_PAD_EN_8814B BIT(30)
#define BIT_FS_SPS_OCP_INT_EN_8814B BIT(29)
#define BIT_FS_PWMERR_INT_EN_8814B BIT(28)
#define BIT_FS_GPIOF_INT_EN_8814B BIT(27)
#define BIT_FS_GPIOE_INT_EN_8814B BIT(26)
#define BIT_FS_GPIOD_INT_EN_8814B BIT(25)
#define BIT_FS_GPIOC_INT_EN_8814B BIT(24)
#define BIT_FS_GPIOB_INT_EN_8814B BIT(23)
#define BIT_FS_GPIOA_INT_EN_8814B BIT(22)
#define BIT_FS_GPIO9_INT_EN_8814B BIT(21)
#define BIT_FS_GPIO8_INT_EN_8814B BIT(20)
#define BIT_FS_GPIO7_INT_EN_8814B BIT(19)
#define BIT_FS_GPIO6_INT_EN_8814B BIT(18)
#define BIT_FS_GPIO5_INT_EN_8814B BIT(17)
#define BIT_FS_GPIO4_INT_EN_8814B BIT(16)
#define BIT_FS_GPIO3_INT_EN_8814B BIT(15)
#define BIT_FS_GPIO2_INT_EN_8814B BIT(14)
#define BIT_FS_GPIO1_INT_EN_8814B BIT(13)
#define BIT_FS_GPIO0_INT_EN_8814B BIT(12)
#define BIT_FS_HCI_SUS_EN_8814B BIT(11)
#define BIT_FS_HCI_RES_EN_8814B BIT(10)
#define BIT_FS_HCI_RESET_EN_8814B BIT(9)
#define BIT_USB_SCSI_CMD_EN_8814B BIT(8)
#define BIT_FS_BTON_STS_UPDATE_MSK_EN_8814B BIT(7)
#define BIT_ACT2RECOVERY_INT_EN_V1_8814B BIT(6)
#define BIT_GEN1GEN2_SWITCH_8814B BIT(5)
#define BIT_HCI_TXDMA_REQ_HIMR_8814B BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_MAK_8814B BIT(3)
#define BIT_FS_32K_ENTER_SETTING_MAK_8814B BIT(2)
#define BIT_FS_USB_LPMRSM_MSK_8814B BIT(1)
#define BIT_FS_USB_LPMINT_MSK_8814B BIT(0)
/* 2 REG_FSISR_8814B */
#define BIT_FS_PDNINT_8814B BIT(31)
#define BIT_FS_SPS_OCP_INT_8814B BIT(29)
#define BIT_FS_PWMERR_INT_8814B BIT(28)
#define BIT_FS_GPIOF_INT_8814B BIT(27)
#define BIT_FS_GPIOE_INT_8814B BIT(26)
#define BIT_FS_GPIOD_INT_8814B BIT(25)
#define BIT_FS_GPIOC_INT_8814B BIT(24)
#define BIT_FS_GPIOB_INT_8814B BIT(23)
#define BIT_FS_GPIOA_INT_8814B BIT(22)
#define BIT_FS_GPIO9_INT_8814B BIT(21)
#define BIT_FS_GPIO8_INT_8814B BIT(20)
#define BIT_FS_GPIO7_INT_8814B BIT(19)
#define BIT_FS_GPIO6_INT_8814B BIT(18)
#define BIT_FS_GPIO5_INT_8814B BIT(17)
#define BIT_FS_GPIO4_INT_8814B BIT(16)
#define BIT_FS_GPIO3_INT_8814B BIT(15)
#define BIT_FS_GPIO2_INT_8814B BIT(14)
#define BIT_FS_GPIO1_INT_8814B BIT(13)
#define BIT_FS_GPIO0_INT_8814B BIT(12)
#define BIT_FS_HCI_SUS_INT_8814B BIT(11)
#define BIT_FS_HCI_RES_INT_8814B BIT(10)
#define BIT_FS_HCI_RESET_INT_8814B BIT(9)
#define BIT_USB_SCSI_CMD_INT_8814B BIT(8)
#define BIT_FS_BTON_STS_UPDATE_INT_8814B BIT(7)
#define BIT_ACT2RECOVERY_8814B BIT(6)
#define BIT_GEN1GEN2_SWITCH_8814B BIT(5)
#define BIT_HCI_TXDMA_REQ_HISR_8814B BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_INT_8814B BIT(3)
#define BIT_FS_32K_ENTER_SETTING_INT_8814B BIT(2)
#define BIT_FS_USB_LPMRSM_INT_8814B BIT(1)
#define BIT_FS_USB_LPMINT_INT_8814B BIT(0)
/* 2 REG_HSIMR_8814B */
#define BIT_GPIOF_INT_EN_8814B BIT(31)
#define BIT_GPIOE_INT_EN_8814B BIT(30)
#define BIT_GPIOD_INT_EN_8814B BIT(29)
#define BIT_GPIOC_INT_EN_8814B BIT(28)
#define BIT_GPIOB_INT_EN_8814B BIT(27)
#define BIT_GPIOA_INT_EN_8814B BIT(26)
#define BIT_GPIO9_INT_EN_8814B BIT(25)
#define BIT_GPIO8_INT_EN_8814B BIT(24)
#define BIT_GPIO7_INT_EN_8814B BIT(23)
#define BIT_GPIO6_INT_EN_8814B BIT(22)
#define BIT_GPIO5_INT_EN_8814B BIT(21)
#define BIT_GPIO4_INT_EN_8814B BIT(20)
#define BIT_GPIO3_INT_EN_8814B BIT(19)
#define BIT_GPIO2_INT_EN_V1_8814B BIT(18)
#define BIT_GPIO1_INT_EN_8814B BIT(17)
#define BIT_GPIO0_INT_EN_8814B BIT(16)
#define BIT_PDNINT_EN_8814B BIT(7)
#define BIT_RON_INT_EN_8814B BIT(6)
#define BIT_SPS_OCP_INT_EN_8814B BIT(5)
#define BIT_GPIO15_0_INT_EN_8814B BIT(0)
/* 2 REG_HSISR_8814B */
#define BIT_GPIOF_INT_8814B BIT(31)
#define BIT_GPIOE_INT_8814B BIT(30)
#define BIT_GPIOD_INT_8814B BIT(29)
#define BIT_GPIOC_INT_8814B BIT(28)
#define BIT_GPIOB_INT_8814B BIT(27)
#define BIT_GPIOA_INT_8814B BIT(26)
#define BIT_GPIO9_INT_8814B BIT(25)
#define BIT_GPIO8_INT_8814B BIT(24)
#define BIT_GPIO7_INT_8814B BIT(23)
#define BIT_GPIO6_INT_8814B BIT(22)
#define BIT_GPIO5_INT_8814B BIT(21)
#define BIT_GPIO4_INT_8814B BIT(20)
#define BIT_GPIO3_INT_8814B BIT(19)
#define BIT_GPIO2_INT_V1_8814B BIT(18)
#define BIT_GPIO1_INT_8814B BIT(17)
#define BIT_GPIO0_INT_8814B BIT(16)
#define BIT_PDNINT_8814B BIT(7)
#define BIT_RON_INT_8814B BIT(6)
#define BIT_SPS_OCP_INT_8814B BIT(5)
#define BIT_GPIO15_0_INT_8814B BIT(0)
/* 2 REG_GPIO_EXT_CTRL_8814B */
#define BIT_SHIFT_GPIO_MOD_15_TO_8_8814B 24
#define BIT_MASK_GPIO_MOD_15_TO_8_8814B 0xff
#define BIT_GPIO_MOD_15_TO_8_8814B(x) \
(((x) & BIT_MASK_GPIO_MOD_15_TO_8_8814B) \
<< BIT_SHIFT_GPIO_MOD_15_TO_8_8814B)
#define BITS_GPIO_MOD_15_TO_8_8814B \
(BIT_MASK_GPIO_MOD_15_TO_8_8814B << BIT_SHIFT_GPIO_MOD_15_TO_8_8814B)
#define BIT_CLEAR_GPIO_MOD_15_TO_8_8814B(x) \
((x) & (~BITS_GPIO_MOD_15_TO_8_8814B))
#define BIT_GET_GPIO_MOD_15_TO_8_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_15_TO_8_8814B) & \
BIT_MASK_GPIO_MOD_15_TO_8_8814B)
#define BIT_SET_GPIO_MOD_15_TO_8_8814B(x, v) \
(BIT_CLEAR_GPIO_MOD_15_TO_8_8814B(x) | BIT_GPIO_MOD_15_TO_8_8814B(v))
#define BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8814B 16
#define BIT_MASK_GPIO_IO_SEL_15_TO_8_8814B 0xff
#define BIT_GPIO_IO_SEL_15_TO_8_8814B(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_15_TO_8_8814B) \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8814B)
#define BITS_GPIO_IO_SEL_15_TO_8_8814B \
(BIT_MASK_GPIO_IO_SEL_15_TO_8_8814B \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8814B)
#define BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8814B(x) \
((x) & (~BITS_GPIO_IO_SEL_15_TO_8_8814B))
#define BIT_GET_GPIO_IO_SEL_15_TO_8_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8814B) & \
BIT_MASK_GPIO_IO_SEL_15_TO_8_8814B)
#define BIT_SET_GPIO_IO_SEL_15_TO_8_8814B(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8814B(x) | \
BIT_GPIO_IO_SEL_15_TO_8_8814B(v))
#define BIT_SHIFT_GPIO_OUT_15_TO_8_8814B 8
#define BIT_MASK_GPIO_OUT_15_TO_8_8814B 0xff
#define BIT_GPIO_OUT_15_TO_8_8814B(x) \
(((x) & BIT_MASK_GPIO_OUT_15_TO_8_8814B) \
<< BIT_SHIFT_GPIO_OUT_15_TO_8_8814B)
#define BITS_GPIO_OUT_15_TO_8_8814B \
(BIT_MASK_GPIO_OUT_15_TO_8_8814B << BIT_SHIFT_GPIO_OUT_15_TO_8_8814B)
#define BIT_CLEAR_GPIO_OUT_15_TO_8_8814B(x) \
((x) & (~BITS_GPIO_OUT_15_TO_8_8814B))
#define BIT_GET_GPIO_OUT_15_TO_8_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_15_TO_8_8814B) & \
BIT_MASK_GPIO_OUT_15_TO_8_8814B)
#define BIT_SET_GPIO_OUT_15_TO_8_8814B(x, v) \
(BIT_CLEAR_GPIO_OUT_15_TO_8_8814B(x) | BIT_GPIO_OUT_15_TO_8_8814B(v))
#define BIT_SHIFT_GPIO_IN_15_TO_8_8814B 0
#define BIT_MASK_GPIO_IN_15_TO_8_8814B 0xff
#define BIT_GPIO_IN_15_TO_8_8814B(x) \
(((x) & BIT_MASK_GPIO_IN_15_TO_8_8814B) \
<< BIT_SHIFT_GPIO_IN_15_TO_8_8814B)
#define BITS_GPIO_IN_15_TO_8_8814B \
(BIT_MASK_GPIO_IN_15_TO_8_8814B << BIT_SHIFT_GPIO_IN_15_TO_8_8814B)
#define BIT_CLEAR_GPIO_IN_15_TO_8_8814B(x) ((x) & (~BITS_GPIO_IN_15_TO_8_8814B))
#define BIT_GET_GPIO_IN_15_TO_8_8814B(x) \
(((x) >> BIT_SHIFT_GPIO_IN_15_TO_8_8814B) & \
BIT_MASK_GPIO_IN_15_TO_8_8814B)
#define BIT_SET_GPIO_IN_15_TO_8_8814B(x, v) \
(BIT_CLEAR_GPIO_IN_15_TO_8_8814B(x) | BIT_GPIO_IN_15_TO_8_8814B(v))
/* 2 REG_PAD_CTRL1_8814B */
#define BIT_DATA_CPU_JTAG_8814B BIT(30)
#define BIT_PAPE_WLBT_SEL_8814B BIT(29)
#define BIT_LNAON_WLBT_SEL_8814B BIT(28)
#define BIT_BTGP_GPG3_FEN_8814B BIT(26)
#define BIT_BTGP_GPG2_FEN_8814B BIT(25)
#define BIT_BTGP_JTAG_EN_8814B BIT(24)
#define BIT_XTAL_CLK_EXTARNAL_EN_8814B BIT(23)
#define BIT_BTGP_UART0_EN_8814B BIT(22)
#define BIT_BTGP_UART1_EN_8814B BIT(21)
#define BIT_BTGP_SPI_EN_8814B BIT(20)
#define BIT_BTGP_GPIO_E2_8814B BIT(19)
#define BIT_BTGP_GPIO_EN_8814B BIT(18)
#define BIT_SHIFT_BTGP_GPIO_SL_8814B 16
#define BIT_MASK_BTGP_GPIO_SL_8814B 0x3
#define BIT_BTGP_GPIO_SL_8814B(x) \
(((x) & BIT_MASK_BTGP_GPIO_SL_8814B) << BIT_SHIFT_BTGP_GPIO_SL_8814B)
#define BITS_BTGP_GPIO_SL_8814B \
(BIT_MASK_BTGP_GPIO_SL_8814B << BIT_SHIFT_BTGP_GPIO_SL_8814B)
#define BIT_CLEAR_BTGP_GPIO_SL_8814B(x) ((x) & (~BITS_BTGP_GPIO_SL_8814B))
#define BIT_GET_BTGP_GPIO_SL_8814B(x) \
(((x) >> BIT_SHIFT_BTGP_GPIO_SL_8814B) & BIT_MASK_BTGP_GPIO_SL_8814B)
#define BIT_SET_BTGP_GPIO_SL_8814B(x, v) \
(BIT_CLEAR_BTGP_GPIO_SL_8814B(x) | BIT_BTGP_GPIO_SL_8814B(v))
#define BIT_WL_JTAG_8814B BIT(15)
#define BIT_PAD_SDIO_SR_8814B BIT(14)
#define BIT_GPIO14_OUTPUT_PL_8814B BIT(13)
#define BIT_HOST_WAKE_PAD_PULL_EN_8814B BIT(12)
#define BIT_HOST_WAKE_PAD_SL_8814B BIT(11)
#define BIT_SW_LNAON_G_SEL_DATA_8814B BIT(8)
#define BIT_SW_LNAON_A_SEL_DATA_8814B BIT(7)
#define BIT_SW_PAPE_G_SEL_DATA_8814B BIT(4)
#define BIT_SW_PAPE_A_SEL_DATA_8814B BIT(3)
#define BIT_SW_DPDT_SEL_DATA_8814B BIT(0)
/* 2 REG_WL_BT_PWR_CTRL_8814B */
#define BIT_ISO_BD2PP_8814B BIT(31)
#define BIT_LDOV12B_EN_8814B BIT(30)
#define BIT_CKEN_BTGPS_8814B BIT(29)
#define BIT_FEN_BTGPS_8814B BIT(28)
#define BIT_BTCPU_BOOTSEL_8814B BIT(27)
#define BIT_SPI_SPEEDUP_8814B BIT(26)
#define BIT_BT_SUS_8814B BIT(25)
#define BIT_DEVWAKE_PAD_TYPE_SEL_8814B BIT(24)
#define BIT_CLKREQ_PAD_TYPE_SEL_8814B BIT(23)
#define BIT_ISO_BTPON2PP_8814B BIT(22)
#define BIT_BTCOEX_CMD_8814B BIT(21)
#define BIT_BT_UART_INTF_8814B BIT(20)
#define BIT_BT_HWROF_EN_8814B BIT(19)
#define BIT_BT_FUNC_EN_8814B BIT(18)
#define BIT_BT_HWPDN_SL_8814B BIT(17)
#define BIT_BT_DISN_EN_8814B BIT(16)
#define BIT_BT_PDN_PULL_EN_8814B BIT(15)
#define BIT_WL_PDN_PULL_EN_8814B BIT(14)
#define BIT_EXTERNAL_REQUEST_PL_8814B BIT(13)
#define BIT_GPIO0_2_3_PULL_LOW_EN_8814B BIT(12)
#define BIT_ISO_BA2PP_8814B BIT(11)
#define BIT_BT_AFE_LDO_EN_8814B BIT(10)
#define BIT_BT_AFE_PLL_EN_8814B BIT(9)
#define BIT_BT_DIG_CLK_EN_8814B BIT(8)
#define BIT_UART_BRIDGE_8814B BIT(7)
#define BIT_OSC32K_CTRL_SEL_8814B BIT(6)
#define BIT_WL_DRV_EXIST_IDX_8814B BIT(5)
#define BIT_DOP_EHPAD_8814B BIT(4)
#define BIT_WL_HWROF_EN_8814B BIT(3)
#define BIT_WL_FUNC_EN_8814B BIT(2)
#define BIT_WL_HWPDN_SL_8814B BIT(1)
#define BIT_WL_HWPDN_EN_8814B BIT(0)
/* 2 REG_SDM_DEBUG_8814B */
#define BIT_BT_WAKE_DEV_EN_V1_8814B BIT(19)
#define BIT_BT_WAKE_HST_EN_V1_8814B BIT(18)
#define BIT_BT_WAKE_HST_PL_V1_8814B BIT(17)
#define BIT_BT_CLKREQ_EN_V1_8814B BIT(16)
#define BIT_SHIFT_WLCLK_PHASE_8814B 0
#define BIT_MASK_WLCLK_PHASE_8814B 0x1f
#define BIT_WLCLK_PHASE_8814B(x) \
(((x) & BIT_MASK_WLCLK_PHASE_8814B) << BIT_SHIFT_WLCLK_PHASE_8814B)
#define BITS_WLCLK_PHASE_8814B \
(BIT_MASK_WLCLK_PHASE_8814B << BIT_SHIFT_WLCLK_PHASE_8814B)
#define BIT_CLEAR_WLCLK_PHASE_8814B(x) ((x) & (~BITS_WLCLK_PHASE_8814B))
#define BIT_GET_WLCLK_PHASE_8814B(x) \
(((x) >> BIT_SHIFT_WLCLK_PHASE_8814B) & BIT_MASK_WLCLK_PHASE_8814B)
#define BIT_SET_WLCLK_PHASE_8814B(x, v) \
(BIT_CLEAR_WLCLK_PHASE_8814B(x) | BIT_WLCLK_PHASE_8814B(v))
/* 2 REG_SYS_SDIO_CTRL_8814B */
#define BIT_DBG_GNT_WL_BT_8814B BIT(27)
#define BIT_LTE_MUX_CTRL_PATH_8814B BIT(26)
#define BIT_LTE_COEX_UART_8814B BIT(25)
#define BIT_3W_LTE_WL_GPIO_8814B BIT(24)
#define BIT_SDIO_INT_POLARITY_8814B BIT(19)
#define BIT_SDIO_INT_8814B BIT(18)
#define BIT_SDIO_OFF_EN_8814B BIT(17)
#define BIT_SDIO_ON_EN_8814B BIT(16)
#define BIT_PCIE_WAIT_TIMEOUT_EVENT_8814B BIT(10)
#define BIT_PCIE_WAIT_TIME_8814B BIT(9)
#define BIT_MPCIE_REFCLK_XTAL_SEL_8814B BIT(8)
#define BIT_BT_CLKREQ_EN_8814B BIT(6)
#define BIT_SHIFT_USB_CKREF_CML_R_8814B 4
#define BIT_MASK_USB_CKREF_CML_R_8814B 0x3
#define BIT_USB_CKREF_CML_R_8814B(x) \
(((x) & BIT_MASK_USB_CKREF_CML_R_8814B) \
<< BIT_SHIFT_USB_CKREF_CML_R_8814B)
#define BITS_USB_CKREF_CML_R_8814B \
(BIT_MASK_USB_CKREF_CML_R_8814B << BIT_SHIFT_USB_CKREF_CML_R_8814B)
#define BIT_CLEAR_USB_CKREF_CML_R_8814B(x) ((x) & (~BITS_USB_CKREF_CML_R_8814B))
#define BIT_GET_USB_CKREF_CML_R_8814B(x) \
(((x) >> BIT_SHIFT_USB_CKREF_CML_R_8814B) & \
BIT_MASK_USB_CKREF_CML_R_8814B)
#define BIT_SET_USB_CKREF_CML_R_8814B(x, v) \
(BIT_CLEAR_USB_CKREF_CML_R_8814B(x) | BIT_USB_CKREF_CML_R_8814B(v))
#define BIT_SHIFT_USB_CKREF_D2S_I_8814B 2
#define BIT_MASK_USB_CKREF_D2S_I_8814B 0x3
#define BIT_USB_CKREF_D2S_I_8814B(x) \
(((x) & BIT_MASK_USB_CKREF_D2S_I_8814B) \
<< BIT_SHIFT_USB_CKREF_D2S_I_8814B)
#define BITS_USB_CKREF_D2S_I_8814B \
(BIT_MASK_USB_CKREF_D2S_I_8814B << BIT_SHIFT_USB_CKREF_D2S_I_8814B)
#define BIT_CLEAR_USB_CKREF_D2S_I_8814B(x) ((x) & (~BITS_USB_CKREF_D2S_I_8814B))
#define BIT_GET_USB_CKREF_D2S_I_8814B(x) \
(((x) >> BIT_SHIFT_USB_CKREF_D2S_I_8814B) & \
BIT_MASK_USB_CKREF_D2S_I_8814B)
#define BIT_SET_USB_CKREF_D2S_I_8814B(x, v) \
(BIT_CLEAR_USB_CKREF_D2S_I_8814B(x) | BIT_USB_CKREF_D2S_I_8814B(v))
#define BIT_RES_USB_MASS_STORAGE_DESC_8814B BIT(1)
#define BIT_USB_WAIT_TIME_8814B BIT(0)
/* 2 REG_HCI_OPT_CTRL_8814B */
#define BIT_SHIFT_TSFT_SEL_8814B 29
#define BIT_MASK_TSFT_SEL_8814B 0x7
#define BIT_TSFT_SEL_8814B(x) \
(((x) & BIT_MASK_TSFT_SEL_8814B) << BIT_SHIFT_TSFT_SEL_8814B)
#define BITS_TSFT_SEL_8814B \
(BIT_MASK_TSFT_SEL_8814B << BIT_SHIFT_TSFT_SEL_8814B)
#define BIT_CLEAR_TSFT_SEL_8814B(x) ((x) & (~BITS_TSFT_SEL_8814B))
#define BIT_GET_TSFT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_8814B) & BIT_MASK_TSFT_SEL_8814B)
#define BIT_SET_TSFT_SEL_8814B(x, v) \
(BIT_CLEAR_TSFT_SEL_8814B(x) | BIT_TSFT_SEL_8814B(v))
#define BIT_TSFT_BAND_SEL_8814B BIT(28)
#define BIT_USB_HOST_PWR_OFF_EN_8814B BIT(12)
#define BIT_SYM_LPS_BLOCK_EN_8814B BIT(11)
#define BIT_USB_LPM_ACT_EN_8814B BIT(10)
#define BIT_USB_LPM_NY_8814B BIT(9)
#define BIT_USB_SUS_DIS_8814B BIT(8)
#define BIT_SHIFT_SDIO_PAD_E_8814B 5
#define BIT_MASK_SDIO_PAD_E_8814B 0x7
#define BIT_SDIO_PAD_E_8814B(x) \
(((x) & BIT_MASK_SDIO_PAD_E_8814B) << BIT_SHIFT_SDIO_PAD_E_8814B)
#define BITS_SDIO_PAD_E_8814B \
(BIT_MASK_SDIO_PAD_E_8814B << BIT_SHIFT_SDIO_PAD_E_8814B)
#define BIT_CLEAR_SDIO_PAD_E_8814B(x) ((x) & (~BITS_SDIO_PAD_E_8814B))
#define BIT_GET_SDIO_PAD_E_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_PAD_E_8814B) & BIT_MASK_SDIO_PAD_E_8814B)
#define BIT_SET_SDIO_PAD_E_8814B(x, v) \
(BIT_CLEAR_SDIO_PAD_E_8814B(x) | BIT_SDIO_PAD_E_8814B(v))
#define BIT_USB_LPPLL_EN_8814B BIT(4)
#define BIT_ROP_SW15_8814B BIT(2)
#define BIT_PCI_CKRDY_OPT_8814B BIT(1)
#define BIT_PCI_VAUX_EN_8814B BIT(0)
/* 2 REG_AFE_CTRL4_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_LDO_SWR_CTRL_8814B */
#define BIT_ZCD_HW_AUTO_EN_8814B BIT(27)
#define BIT_ZCD_REGSEL_8814B BIT(26)
#define BIT_SHIFT_AUTO_ZCD_IN_CODE_8814B 21
#define BIT_MASK_AUTO_ZCD_IN_CODE_8814B 0x1f
#define BIT_AUTO_ZCD_IN_CODE_8814B(x) \
(((x) & BIT_MASK_AUTO_ZCD_IN_CODE_8814B) \
<< BIT_SHIFT_AUTO_ZCD_IN_CODE_8814B)
#define BITS_AUTO_ZCD_IN_CODE_8814B \
(BIT_MASK_AUTO_ZCD_IN_CODE_8814B << BIT_SHIFT_AUTO_ZCD_IN_CODE_8814B)
#define BIT_CLEAR_AUTO_ZCD_IN_CODE_8814B(x) \
((x) & (~BITS_AUTO_ZCD_IN_CODE_8814B))
#define BIT_GET_AUTO_ZCD_IN_CODE_8814B(x) \
(((x) >> BIT_SHIFT_AUTO_ZCD_IN_CODE_8814B) & \
BIT_MASK_AUTO_ZCD_IN_CODE_8814B)
#define BIT_SET_AUTO_ZCD_IN_CODE_8814B(x, v) \
(BIT_CLEAR_AUTO_ZCD_IN_CODE_8814B(x) | BIT_AUTO_ZCD_IN_CODE_8814B(v))
#define BIT_SHIFT_ZCD_CODE_IN_L_8814B 16
#define BIT_MASK_ZCD_CODE_IN_L_8814B 0x1f
#define BIT_ZCD_CODE_IN_L_8814B(x) \
(((x) & BIT_MASK_ZCD_CODE_IN_L_8814B) << BIT_SHIFT_ZCD_CODE_IN_L_8814B)
#define BITS_ZCD_CODE_IN_L_8814B \
(BIT_MASK_ZCD_CODE_IN_L_8814B << BIT_SHIFT_ZCD_CODE_IN_L_8814B)
#define BIT_CLEAR_ZCD_CODE_IN_L_8814B(x) ((x) & (~BITS_ZCD_CODE_IN_L_8814B))
#define BIT_GET_ZCD_CODE_IN_L_8814B(x) \
(((x) >> BIT_SHIFT_ZCD_CODE_IN_L_8814B) & BIT_MASK_ZCD_CODE_IN_L_8814B)
#define BIT_SET_ZCD_CODE_IN_L_8814B(x, v) \
(BIT_CLEAR_ZCD_CODE_IN_L_8814B(x) | BIT_ZCD_CODE_IN_L_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_MCUFW_CTRL_8814B */
#define BIT_SHIFT_RPWM_8814B 24
#define BIT_MASK_RPWM_8814B 0xff
#define BIT_RPWM_8814B(x) (((x) & BIT_MASK_RPWM_8814B) << BIT_SHIFT_RPWM_8814B)
#define BITS_RPWM_8814B (BIT_MASK_RPWM_8814B << BIT_SHIFT_RPWM_8814B)
#define BIT_CLEAR_RPWM_8814B(x) ((x) & (~BITS_RPWM_8814B))
#define BIT_GET_RPWM_8814B(x) \
(((x) >> BIT_SHIFT_RPWM_8814B) & BIT_MASK_RPWM_8814B)
#define BIT_SET_RPWM_8814B(x, v) (BIT_CLEAR_RPWM_8814B(x) | BIT_RPWM_8814B(v))
#define BIT_ANA_PORT_EN_8814B BIT(22)
#define BIT_MAC_PORT_EN_8814B BIT(21)
#define BIT_BOOT_FSPI_EN_8814B BIT(20)
#define BIT_ROM_DLEN_8814B BIT(19)
#define BIT_SHIFT_ROM_PGE_8814B 16
#define BIT_MASK_ROM_PGE_8814B 0x7
#define BIT_ROM_PGE_8814B(x) \
(((x) & BIT_MASK_ROM_PGE_8814B) << BIT_SHIFT_ROM_PGE_8814B)
#define BITS_ROM_PGE_8814B (BIT_MASK_ROM_PGE_8814B << BIT_SHIFT_ROM_PGE_8814B)
#define BIT_CLEAR_ROM_PGE_8814B(x) ((x) & (~BITS_ROM_PGE_8814B))
#define BIT_GET_ROM_PGE_8814B(x) \
(((x) >> BIT_SHIFT_ROM_PGE_8814B) & BIT_MASK_ROM_PGE_8814B)
#define BIT_SET_ROM_PGE_8814B(x, v) \
(BIT_CLEAR_ROM_PGE_8814B(x) | BIT_ROM_PGE_8814B(v))
#define BIT_FW_INIT_RDY_8814B BIT(15)
#define BIT_FW_DW_RDY_8814B BIT(14)
#define BIT_SHIFT_CPU_CLK_SEL_8814B 12
#define BIT_MASK_CPU_CLK_SEL_8814B 0x3
#define BIT_CPU_CLK_SEL_8814B(x) \
(((x) & BIT_MASK_CPU_CLK_SEL_8814B) << BIT_SHIFT_CPU_CLK_SEL_8814B)
#define BITS_CPU_CLK_SEL_8814B \
(BIT_MASK_CPU_CLK_SEL_8814B << BIT_SHIFT_CPU_CLK_SEL_8814B)
#define BIT_CLEAR_CPU_CLK_SEL_8814B(x) ((x) & (~BITS_CPU_CLK_SEL_8814B))
#define BIT_GET_CPU_CLK_SEL_8814B(x) \
(((x) >> BIT_SHIFT_CPU_CLK_SEL_8814B) & BIT_MASK_CPU_CLK_SEL_8814B)
#define BIT_SET_CPU_CLK_SEL_8814B(x, v) \
(BIT_CLEAR_CPU_CLK_SEL_8814B(x) | BIT_CPU_CLK_SEL_8814B(v))
#define BIT_CCLK_CHG_MASK_8814B BIT(11)
#define BIT_EMEM__TXBUF_CHKSUM_OK_8814B BIT(10)
#define BIT_EMEM_TXBUF_DW_RDY_8814B BIT(9)
#define BIT_EMEM_CHKSUM_OK_8814B BIT(8)
#define BIT_EMEM_DW_OK_8814B BIT(7)
#define BIT_DMEM_CHKSUM_OK_8814B BIT(6)
#define BIT_DMEM_DW_OK_8814B BIT(5)
#define BIT_IMEM_CHKSUM_OK_8814B BIT(4)
#define BIT_IMEM_DW_OK_8814B BIT(3)
#define BIT_IMEM_BOOT_LOAD_CHKSUM_OK_8814B BIT(2)
#define BIT_IMEM_BOOT_LOAD_DW_OK_8814B BIT(1)
#define BIT_MCUFWDL_EN_8814B BIT(0)
/* 2 REG_MCU_TST_CFG_8814B */
#define BIT_SHIFT_C2H_MSG_8814B 0
#define BIT_MASK_C2H_MSG_8814B 0xffff
#define BIT_C2H_MSG_8814B(x) \
(((x) & BIT_MASK_C2H_MSG_8814B) << BIT_SHIFT_C2H_MSG_8814B)
#define BITS_C2H_MSG_8814B (BIT_MASK_C2H_MSG_8814B << BIT_SHIFT_C2H_MSG_8814B)
#define BIT_CLEAR_C2H_MSG_8814B(x) ((x) & (~BITS_C2H_MSG_8814B))
#define BIT_GET_C2H_MSG_8814B(x) \
(((x) >> BIT_SHIFT_C2H_MSG_8814B) & BIT_MASK_C2H_MSG_8814B)
#define BIT_SET_C2H_MSG_8814B(x, v) \
(BIT_CLEAR_C2H_MSG_8814B(x) | BIT_C2H_MSG_8814B(v))
/* 2 REG_HMEBOX_E0_E1_8814B */
#define BIT_SHIFT_HOST_MSG_E1_8814B 16
#define BIT_MASK_HOST_MSG_E1_8814B 0xffff
#define BIT_HOST_MSG_E1_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_E1_8814B) << BIT_SHIFT_HOST_MSG_E1_8814B)
#define BITS_HOST_MSG_E1_8814B \
(BIT_MASK_HOST_MSG_E1_8814B << BIT_SHIFT_HOST_MSG_E1_8814B)
#define BIT_CLEAR_HOST_MSG_E1_8814B(x) ((x) & (~BITS_HOST_MSG_E1_8814B))
#define BIT_GET_HOST_MSG_E1_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E1_8814B) & BIT_MASK_HOST_MSG_E1_8814B)
#define BIT_SET_HOST_MSG_E1_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_E1_8814B(x) | BIT_HOST_MSG_E1_8814B(v))
#define BIT_SHIFT_HOST_MSG_E0_8814B 0
#define BIT_MASK_HOST_MSG_E0_8814B 0xffff
#define BIT_HOST_MSG_E0_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_E0_8814B) << BIT_SHIFT_HOST_MSG_E0_8814B)
#define BITS_HOST_MSG_E0_8814B \
(BIT_MASK_HOST_MSG_E0_8814B << BIT_SHIFT_HOST_MSG_E0_8814B)
#define BIT_CLEAR_HOST_MSG_E0_8814B(x) ((x) & (~BITS_HOST_MSG_E0_8814B))
#define BIT_GET_HOST_MSG_E0_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E0_8814B) & BIT_MASK_HOST_MSG_E0_8814B)
#define BIT_SET_HOST_MSG_E0_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_E0_8814B(x) | BIT_HOST_MSG_E0_8814B(v))
/* 2 REG_HMEBOX_E2_E3_8814B */
#define BIT_SHIFT_HOST_MSG_E3_8814B 16
#define BIT_MASK_HOST_MSG_E3_8814B 0xffff
#define BIT_HOST_MSG_E3_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_E3_8814B) << BIT_SHIFT_HOST_MSG_E3_8814B)
#define BITS_HOST_MSG_E3_8814B \
(BIT_MASK_HOST_MSG_E3_8814B << BIT_SHIFT_HOST_MSG_E3_8814B)
#define BIT_CLEAR_HOST_MSG_E3_8814B(x) ((x) & (~BITS_HOST_MSG_E3_8814B))
#define BIT_GET_HOST_MSG_E3_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E3_8814B) & BIT_MASK_HOST_MSG_E3_8814B)
#define BIT_SET_HOST_MSG_E3_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_E3_8814B(x) | BIT_HOST_MSG_E3_8814B(v))
#define BIT_SHIFT_HOST_MSG_E2_8814B 0
#define BIT_MASK_HOST_MSG_E2_8814B 0xffff
#define BIT_HOST_MSG_E2_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_E2_8814B) << BIT_SHIFT_HOST_MSG_E2_8814B)
#define BITS_HOST_MSG_E2_8814B \
(BIT_MASK_HOST_MSG_E2_8814B << BIT_SHIFT_HOST_MSG_E2_8814B)
#define BIT_CLEAR_HOST_MSG_E2_8814B(x) ((x) & (~BITS_HOST_MSG_E2_8814B))
#define BIT_GET_HOST_MSG_E2_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E2_8814B) & BIT_MASK_HOST_MSG_E2_8814B)
#define BIT_SET_HOST_MSG_E2_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_E2_8814B(x) | BIT_HOST_MSG_E2_8814B(v))
/* 2 REG_WLLPS_CTRL_8814B */
#define BIT_WLLPSOP_EABM_8814B BIT(31)
#define BIT_WLLPSOP_ACKF_8814B BIT(30)
#define BIT_WLLPSOP_DLDM_8814B BIT(29)
#define BIT_WLLPSOP_ESWR_8814B BIT(28)
#define BIT_WLLPSOP_PWMM_8814B BIT(27)
#define BIT_WLLPSOP_EECK_8814B BIT(26)
#define BIT_WLLPSOP_WLMACOFF_8814B BIT(25)
#define BIT_WLLPSOP_EXTAL_8814B BIT(24)
#define BIT_WL_SYNPON_VOLTSPDN_8814B BIT(23)
#define BIT_WLLPSOP_WLBBOFF_8814B BIT(22)
#define BIT_WLLPSOP_WLMEM_DS_8814B BIT(21)
#define BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8814B 12
#define BIT_MASK_LPLDH12_VADJ_STEP_DN_8814B 0xf
#define BIT_LPLDH12_VADJ_STEP_DN_8814B(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_STEP_DN_8814B) \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8814B)
#define BITS_LPLDH12_VADJ_STEP_DN_8814B \
(BIT_MASK_LPLDH12_VADJ_STEP_DN_8814B \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8814B)
#define BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8814B(x) \
((x) & (~BITS_LPLDH12_VADJ_STEP_DN_8814B))
#define BIT_GET_LPLDH12_VADJ_STEP_DN_8814B(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8814B) & \
BIT_MASK_LPLDH12_VADJ_STEP_DN_8814B)
#define BIT_SET_LPLDH12_VADJ_STEP_DN_8814B(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8814B(x) | \
BIT_LPLDH12_VADJ_STEP_DN_8814B(v))
#define BIT_SHIFT_V15ADJ_L1_STEP_DN_8814B 8
#define BIT_MASK_V15ADJ_L1_STEP_DN_8814B 0x7
#define BIT_V15ADJ_L1_STEP_DN_8814B(x) \
(((x) & BIT_MASK_V15ADJ_L1_STEP_DN_8814B) \
<< BIT_SHIFT_V15ADJ_L1_STEP_DN_8814B)
#define BITS_V15ADJ_L1_STEP_DN_8814B \
(BIT_MASK_V15ADJ_L1_STEP_DN_8814B << BIT_SHIFT_V15ADJ_L1_STEP_DN_8814B)
#define BIT_CLEAR_V15ADJ_L1_STEP_DN_8814B(x) \
((x) & (~BITS_V15ADJ_L1_STEP_DN_8814B))
#define BIT_GET_V15ADJ_L1_STEP_DN_8814B(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_STEP_DN_8814B) & \
BIT_MASK_V15ADJ_L1_STEP_DN_8814B)
#define BIT_SET_V15ADJ_L1_STEP_DN_8814B(x, v) \
(BIT_CLEAR_V15ADJ_L1_STEP_DN_8814B(x) | BIT_V15ADJ_L1_STEP_DN_8814B(v))
#define BIT_REGU_32K_CLK_EN_8814B BIT(1)
#define BIT_WL_LPS_EN_8814B BIT(0)
/* 2 REG_AFE_CTRL5_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_GPIO_DEBOUNCE_CTRL_8814B */
#define BIT_WLGP_DBC1EN_8814B BIT(15)
#define BIT_SHIFT_WLGP_DBC1_8814B 8
#define BIT_MASK_WLGP_DBC1_8814B 0xf
#define BIT_WLGP_DBC1_8814B(x) \
(((x) & BIT_MASK_WLGP_DBC1_8814B) << BIT_SHIFT_WLGP_DBC1_8814B)
#define BITS_WLGP_DBC1_8814B \
(BIT_MASK_WLGP_DBC1_8814B << BIT_SHIFT_WLGP_DBC1_8814B)
#define BIT_CLEAR_WLGP_DBC1_8814B(x) ((x) & (~BITS_WLGP_DBC1_8814B))
#define BIT_GET_WLGP_DBC1_8814B(x) \
(((x) >> BIT_SHIFT_WLGP_DBC1_8814B) & BIT_MASK_WLGP_DBC1_8814B)
#define BIT_SET_WLGP_DBC1_8814B(x, v) \
(BIT_CLEAR_WLGP_DBC1_8814B(x) | BIT_WLGP_DBC1_8814B(v))
#define BIT_WLGP_DBC0EN_8814B BIT(7)
#define BIT_SHIFT_WLGP_DBC0_8814B 0
#define BIT_MASK_WLGP_DBC0_8814B 0xf
#define BIT_WLGP_DBC0_8814B(x) \
(((x) & BIT_MASK_WLGP_DBC0_8814B) << BIT_SHIFT_WLGP_DBC0_8814B)
#define BITS_WLGP_DBC0_8814B \
(BIT_MASK_WLGP_DBC0_8814B << BIT_SHIFT_WLGP_DBC0_8814B)
#define BIT_CLEAR_WLGP_DBC0_8814B(x) ((x) & (~BITS_WLGP_DBC0_8814B))
#define BIT_GET_WLGP_DBC0_8814B(x) \
(((x) >> BIT_SHIFT_WLGP_DBC0_8814B) & BIT_MASK_WLGP_DBC0_8814B)
#define BIT_SET_WLGP_DBC0_8814B(x, v) \
(BIT_CLEAR_WLGP_DBC0_8814B(x) | BIT_WLGP_DBC0_8814B(v))
/* 2 REG_RPWM2_8814B */
#define BIT_SHIFT_RPWM2_8814B 16
#define BIT_MASK_RPWM2_8814B 0xffff
#define BIT_RPWM2_8814B(x) \
(((x) & BIT_MASK_RPWM2_8814B) << BIT_SHIFT_RPWM2_8814B)
#define BITS_RPWM2_8814B (BIT_MASK_RPWM2_8814B << BIT_SHIFT_RPWM2_8814B)
#define BIT_CLEAR_RPWM2_8814B(x) ((x) & (~BITS_RPWM2_8814B))
#define BIT_GET_RPWM2_8814B(x) \
(((x) >> BIT_SHIFT_RPWM2_8814B) & BIT_MASK_RPWM2_8814B)
#define BIT_SET_RPWM2_8814B(x, v) \
(BIT_CLEAR_RPWM2_8814B(x) | BIT_RPWM2_8814B(v))
/* 2 REG_SYSON_FSM_MON_8814B */
#define BIT_SHIFT_FSM_MON_SEL_8814B 24
#define BIT_MASK_FSM_MON_SEL_8814B 0x7
#define BIT_FSM_MON_SEL_8814B(x) \
(((x) & BIT_MASK_FSM_MON_SEL_8814B) << BIT_SHIFT_FSM_MON_SEL_8814B)
#define BITS_FSM_MON_SEL_8814B \
(BIT_MASK_FSM_MON_SEL_8814B << BIT_SHIFT_FSM_MON_SEL_8814B)
#define BIT_CLEAR_FSM_MON_SEL_8814B(x) ((x) & (~BITS_FSM_MON_SEL_8814B))
#define BIT_GET_FSM_MON_SEL_8814B(x) \
(((x) >> BIT_SHIFT_FSM_MON_SEL_8814B) & BIT_MASK_FSM_MON_SEL_8814B)
#define BIT_SET_FSM_MON_SEL_8814B(x, v) \
(BIT_CLEAR_FSM_MON_SEL_8814B(x) | BIT_FSM_MON_SEL_8814B(v))
#define BIT_DOP_ELDO_8814B BIT(23)
#define BIT_FSM_MON_UPD_8814B BIT(15)
#define BIT_SHIFT_FSM_PAR_8814B 0
#define BIT_MASK_FSM_PAR_8814B 0x7fff
#define BIT_FSM_PAR_8814B(x) \
(((x) & BIT_MASK_FSM_PAR_8814B) << BIT_SHIFT_FSM_PAR_8814B)
#define BITS_FSM_PAR_8814B (BIT_MASK_FSM_PAR_8814B << BIT_SHIFT_FSM_PAR_8814B)
#define BIT_CLEAR_FSM_PAR_8814B(x) ((x) & (~BITS_FSM_PAR_8814B))
#define BIT_GET_FSM_PAR_8814B(x) \
(((x) >> BIT_SHIFT_FSM_PAR_8814B) & BIT_MASK_FSM_PAR_8814B)
#define BIT_SET_FSM_PAR_8814B(x, v) \
(BIT_CLEAR_FSM_PAR_8814B(x) | BIT_FSM_PAR_8814B(v))
/* 2 REG_AFE_CTRL6_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PMC_DBG_CTRL1_8814B */
#define BIT_BT_INT_EN_8814B BIT(31)
#define BIT_SHIFT_RD_WR_WIFI_BT_INFO_8814B 16
#define BIT_MASK_RD_WR_WIFI_BT_INFO_8814B 0x7fff
#define BIT_RD_WR_WIFI_BT_INFO_8814B(x) \
(((x) & BIT_MASK_RD_WR_WIFI_BT_INFO_8814B) \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8814B)
#define BITS_RD_WR_WIFI_BT_INFO_8814B \
(BIT_MASK_RD_WR_WIFI_BT_INFO_8814B \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8814B)
#define BIT_CLEAR_RD_WR_WIFI_BT_INFO_8814B(x) \
((x) & (~BITS_RD_WR_WIFI_BT_INFO_8814B))
#define BIT_GET_RD_WR_WIFI_BT_INFO_8814B(x) \
(((x) >> BIT_SHIFT_RD_WR_WIFI_BT_INFO_8814B) & \
BIT_MASK_RD_WR_WIFI_BT_INFO_8814B)
#define BIT_SET_RD_WR_WIFI_BT_INFO_8814B(x, v) \
(BIT_CLEAR_RD_WR_WIFI_BT_INFO_8814B(x) | \
BIT_RD_WR_WIFI_BT_INFO_8814B(v))
#define BIT_PMC_WR_OVF_8814B BIT(8)
#define BIT_SHIFT_WLPMC_ERRINT_8814B 0
#define BIT_MASK_WLPMC_ERRINT_8814B 0xff
#define BIT_WLPMC_ERRINT_8814B(x) \
(((x) & BIT_MASK_WLPMC_ERRINT_8814B) << BIT_SHIFT_WLPMC_ERRINT_8814B)
#define BITS_WLPMC_ERRINT_8814B \
(BIT_MASK_WLPMC_ERRINT_8814B << BIT_SHIFT_WLPMC_ERRINT_8814B)
#define BIT_CLEAR_WLPMC_ERRINT_8814B(x) ((x) & (~BITS_WLPMC_ERRINT_8814B))
#define BIT_GET_WLPMC_ERRINT_8814B(x) \
(((x) >> BIT_SHIFT_WLPMC_ERRINT_8814B) & BIT_MASK_WLPMC_ERRINT_8814B)
#define BIT_SET_WLPMC_ERRINT_8814B(x, v) \
(BIT_CLEAR_WLPMC_ERRINT_8814B(x) | BIT_WLPMC_ERRINT_8814B(v))
/* 2 REG_AFE_CTRL7_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HIMR0_8814B */
#define BIT_PSTIMER_2_MSK_8814B BIT(31)
#define BIT_PSTIMER_1_MSK_8814B BIT(30)
#define BIT_PSTIMER_0_MSK_8814B BIT(29)
#define BIT_GTINT4_MSK_8814B BIT(28)
#define BIT_GTINT3_MSK_8814B BIT(27)
#define BIT_TXBCN0ERR_MSK_8814B BIT(26)
#define BIT_TXBCN0OK_MSK_8814B BIT(25)
#define BIT_TSF_BIT32_TOGGLE_MSK_8814B BIT(24)
#define BIT_TXDMA_START_INT_MSK_8814B BIT(23)
#define BIT_TXDMA_STOP_INT_MSK_8814B BIT(22)
#define BIT_HISR7_IND_MSK_8814B BIT(21)
#define BIT_BCNDMAINT0_MSK_8814B BIT(20)
#define BIT_HISR6_IND_MSK_8814B BIT(19)
#define BIT_HISR5_IND_MSK_8814B BIT(18)
#define BIT_HISR4_IND_MSK_8814B BIT(17)
#define BIT_BCNDERR0_MSK_8814B BIT(16)
#define BIT_HSISR_IND_ON_INT_MSK_8814B BIT(15)
#define BIT_HISR3_IND_MSK_8814B BIT(14)
#define BIT_HISR2_IND_MSK_8814B BIT(13)
/* 2 REG_NOT_VALID_8814B */
#define BIT_HISR1_IND_MSK_8814B BIT(11)
#define BIT_C2HCMD_MSK_8814B BIT(10)
#define BIT_CPWM2_MSK_8814B BIT(9)
#define BIT_CPWM_MSK_8814B BIT(8)
#define BIT_TXDMAOK_CHANNEL15_MSK_8814B BIT(7)
#define BIT_TXDMAOK_CHANNEL14_MSK_8814B BIT(6)
#define BIT_TXDMAOK_CHANNEL3_MSK_8814B BIT(5)
#define BIT_TXDMAOK_CHANNEL2_MSK_8814B BIT(4)
#define BIT_TXDMAOK_CHANNEL1_MSK_8814B BIT(3)
#define BIT_TXDMAOK_CHANNEL0_MSK_8814B BIT(2)
#define BIT_RDU_MSK_8814B BIT(1)
#define BIT_RXOK_MSK_8814B BIT(0)
/* 2 REG_HISR0_8814B */
#define BIT_PSTIMER_2_8814B BIT(31)
#define BIT_PSTIMER_1_8814B BIT(30)
#define BIT_PSTIMER_0_8814B BIT(29)
#define BIT_GTINT4_8814B BIT(28)
#define BIT_GTINT3_8814B BIT(27)
#define BIT_TXBCN0ERR_8814B BIT(26)
#define BIT_TXBCN0OK_8814B BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8814B BIT(24)
#define BIT_TXDMA_START_INT_8814B BIT(23)
#define BIT_TXDMA_STOP_INT_8814B BIT(22)
#define BIT_HISR7_IND_8814B BIT(21)
#define BIT_BCNDMAINT0_8814B BIT(20)
#define BIT_HISR6_IND_8814B BIT(19)
#define BIT_HISR5_IND_8814B BIT(18)
#define BIT_HISR4_IND_8814B BIT(17)
#define BIT_BCNDERR0_8814B BIT(16)
#define BIT_HSISR_IND_ON_INT_8814B BIT(15)
#define BIT_HISR3_IND_8814B BIT(14)
#define BIT_HISR2_IND_8814B BIT(13)
/* 2 REG_NOT_VALID_8814B */
#define BIT_HISR1_IND_8814B BIT(11)
#define BIT_C2HCMD_8814B BIT(10)
#define BIT_CPWM2_8814B BIT(9)
#define BIT_CPWM_8814B BIT(8)
#define BIT_TXDMAOK_CHANNEL15_8814B BIT(7)
#define BIT_TXDMAOK_CHANNEL14_8814B BIT(6)
#define BIT_TXDMAOK_CHANNEL3_8814B BIT(5)
#define BIT_TXDMAOK_CHANNEL2_8814B BIT(4)
#define BIT_TXDMAOK_CHANNEL1_8814B BIT(3)
#define BIT_TXDMAOK_CHANNEL0_8814B BIT(2)
#define BIT_RDU_8814B BIT(1)
#define BIT_RXOK_8814B BIT(0)
/* 2 REG_HIMR1_8814B */
#define BIT_PRE_TX_ERR_INT_MSK_8814B BIT(31)
#define BIT_TXFIFO_TH_INT_8814B BIT(30)
#define BIT_BTON_STS_UPDATE_MASK_8814B BIT(29)
#define BIT_BCNDMAINT7__MSK_8814B BIT(27)
#define BIT_BCNDMAINT6__MSK_8814B BIT(26)
#define BIT_BCNDMAINT5__MSK_8814B BIT(25)
#define BIT_BCNDMAINT4__MSK_8814B BIT(24)
#define BIT_BCNDMAINT3_MSK_8814B BIT(23)
#define BIT_BCNDMAINT2_MSK_8814B BIT(22)
#define BIT_BCNDMAINT1_MSK_8814B BIT(21)
#define BIT_BCNDERR7_MSK_8814B BIT(20)
#define BIT_BCNDERR6_MSK_8814B BIT(19)
#define BIT_BCNDERR5_MSK_8814B BIT(18)
#define BIT_BCNDERR4_MSK_8814B BIT(17)
#define BIT_BCNDERR3_MSK_8814B BIT(16)
#define BIT_BCNDERR2_MSK_8814B BIT(15)
#define BIT_BCNDERR1_MSK_8814B BIT(14)
#define BIT_ATIMEND__MSK_8814B BIT(12)
#define BIT_TXERR_MSK_8814B BIT(11)
#define BIT_RXERR_MSK_8814B BIT(10)
#define BIT_TXFOVW_MSK_8814B BIT(9)
#define BIT_FOVW_MSK_8814B BIT(8)
#define BIT_CPU_MGQ_EARLY_INT_MSK_8814B BIT(6)
#define BIT_CPU_MGQ_TXDONE_MSK_8814B BIT(5)
#define BIT_PSTIMER_5_MSK_8814B BIT(4)
#define BIT_PSTIMER_4_MSK_8814B BIT(3)
#define BIT_PSTIMER_3_MSK_8814B BIT(2)
#define BIT_CPUMGQ_TX_TIMER_MSK_8814B BIT(1)
#define BIT_BB_STOPRX_INT_MSK_8814B BIT(0)
/* 2 REG_HISR1_8814B */
#define BIT_PRE_TX_ERR_INT_8814B BIT(31)
#define BIT_TXFIFO_TH_INT_8814B BIT(30)
#define BIT_BTON_STS_UPDATE_INT_8814B BIT(29)
#define BIT_BCNDMAINT7_8814B BIT(27)
#define BIT_BCNDMAINT6_8814B BIT(26)
#define BIT_BCNDMAINT5_8814B BIT(25)
#define BIT_BCNDMAINT4_8814B BIT(24)
#define BIT_BCNDMAINT3_8814B BIT(23)
#define BIT_BCNDMAINT2_8814B BIT(22)
#define BIT_BCNDMAINT1_8814B BIT(21)
#define BIT_BCNDERR7_8814B BIT(20)
#define BIT_BCNDERR6_8814B BIT(19)
#define BIT_BCNDERR5_8814B BIT(18)
#define BIT_BCNDERR4_8814B BIT(17)
#define BIT_BCNDERR3_8814B BIT(16)
#define BIT_BCNDERR2_8814B BIT(15)
#define BIT_BCNDERR1_8814B BIT(14)
#define BIT_ATIMEND_8814B BIT(12)
#define BIT_TXERR_INT_8814B BIT(11)
#define BIT_RXERR_INT_8814B BIT(10)
#define BIT_TXFOVW_8814B BIT(9)
#define BIT_FOVW_8814B BIT(8)
/* 2 REG_NOT_VALID_8814B */
#define BIT_CPU_MGQ_EARLY_INT_8814B BIT(6)
#define BIT_CPU_MGQ_TXDONE_8814B BIT(5)
#define BIT_PSTIMER_5_8814B BIT(4)
#define BIT_PSTIMER_4_8814B BIT(3)
#define BIT_PSTIMER_3_8814B BIT(2)
#define BIT_CPUMGQ_TX_TIMER_8814B BIT(1)
#define BIT_BB_STOPRX_INT_8814B BIT(0)
/* 2 REG_DBG_PORT_SEL_8814B */
#define BIT_SHIFT_DEBUG_ST_8814B 0
#define BIT_MASK_DEBUG_ST_8814B 0xffffffffL
#define BIT_DEBUG_ST_8814B(x) \
(((x) & BIT_MASK_DEBUG_ST_8814B) << BIT_SHIFT_DEBUG_ST_8814B)
#define BITS_DEBUG_ST_8814B \
(BIT_MASK_DEBUG_ST_8814B << BIT_SHIFT_DEBUG_ST_8814B)
#define BIT_CLEAR_DEBUG_ST_8814B(x) ((x) & (~BITS_DEBUG_ST_8814B))
#define BIT_GET_DEBUG_ST_8814B(x) \
(((x) >> BIT_SHIFT_DEBUG_ST_8814B) & BIT_MASK_DEBUG_ST_8814B)
#define BIT_SET_DEBUG_ST_8814B(x, v) \
(BIT_CLEAR_DEBUG_ST_8814B(x) | BIT_DEBUG_ST_8814B(v))
/* 2 REG_PAD_CTRL2_8814B */
#define BIT_USB3_USB2_TRANSITION_8814B BIT(20)
#define BIT_SHIFT_USB23_SW_MODE_V1_8814B 18
#define BIT_MASK_USB23_SW_MODE_V1_8814B 0x3
#define BIT_USB23_SW_MODE_V1_8814B(x) \
(((x) & BIT_MASK_USB23_SW_MODE_V1_8814B) \
<< BIT_SHIFT_USB23_SW_MODE_V1_8814B)
#define BITS_USB23_SW_MODE_V1_8814B \
(BIT_MASK_USB23_SW_MODE_V1_8814B << BIT_SHIFT_USB23_SW_MODE_V1_8814B)
#define BIT_CLEAR_USB23_SW_MODE_V1_8814B(x) \
((x) & (~BITS_USB23_SW_MODE_V1_8814B))
#define BIT_GET_USB23_SW_MODE_V1_8814B(x) \
(((x) >> BIT_SHIFT_USB23_SW_MODE_V1_8814B) & \
BIT_MASK_USB23_SW_MODE_V1_8814B)
#define BIT_SET_USB23_SW_MODE_V1_8814B(x, v) \
(BIT_CLEAR_USB23_SW_MODE_V1_8814B(x) | BIT_USB23_SW_MODE_V1_8814B(v))
#define BIT_NO_PDN_CHIPOFF_V1_8814B BIT(17)
#define BIT_RSM_EN_V1_8814B BIT(16)
#define BIT_SHIFT_MATCH_CNT_8814B 8
#define BIT_MASK_MATCH_CNT_8814B 0xff
#define BIT_MATCH_CNT_8814B(x) \
(((x) & BIT_MASK_MATCH_CNT_8814B) << BIT_SHIFT_MATCH_CNT_8814B)
#define BITS_MATCH_CNT_8814B \
(BIT_MASK_MATCH_CNT_8814B << BIT_SHIFT_MATCH_CNT_8814B)
#define BIT_CLEAR_MATCH_CNT_8814B(x) ((x) & (~BITS_MATCH_CNT_8814B))
#define BIT_GET_MATCH_CNT_8814B(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8814B) & BIT_MASK_MATCH_CNT_8814B)
#define BIT_SET_MATCH_CNT_8814B(x, v) \
(BIT_CLEAR_MATCH_CNT_8814B(x) | BIT_MATCH_CNT_8814B(v))
#define BIT_LD_B12V_EN_8814B BIT(7)
#define BIT_EECS_IOSEL_V1_8814B BIT(6)
#define BIT_EECS_DATA_O_V1_8814B BIT(5)
#define BIT_EECS_DATA_I_V1_8814B BIT(4)
#define BIT_EESK_IOSEL_V1_8814B BIT(2)
#define BIT_EESK_DATA_O_V1_8814B BIT(1)
#define BIT_EESK_DATA_I_V1_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PMC_DBG_CTRL2_8814B */
#define BIT_SHIFT_EFUSE_BURN_GNT_8814B 24
#define BIT_MASK_EFUSE_BURN_GNT_8814B 0xff
#define BIT_EFUSE_BURN_GNT_8814B(x) \
(((x) & BIT_MASK_EFUSE_BURN_GNT_8814B) \
<< BIT_SHIFT_EFUSE_BURN_GNT_8814B)
#define BITS_EFUSE_BURN_GNT_8814B \
(BIT_MASK_EFUSE_BURN_GNT_8814B << BIT_SHIFT_EFUSE_BURN_GNT_8814B)
#define BIT_CLEAR_EFUSE_BURN_GNT_8814B(x) ((x) & (~BITS_EFUSE_BURN_GNT_8814B))
#define BIT_GET_EFUSE_BURN_GNT_8814B(x) \
(((x) >> BIT_SHIFT_EFUSE_BURN_GNT_8814B) & \
BIT_MASK_EFUSE_BURN_GNT_8814B)
#define BIT_SET_EFUSE_BURN_GNT_8814B(x, v) \
(BIT_CLEAR_EFUSE_BURN_GNT_8814B(x) | BIT_EFUSE_BURN_GNT_8814B(v))
#define BIT_STOP_WL_PMC_8814B BIT(9)
#define BIT_STOP_SYM_PMC_8814B BIT(8)
#define BIT_BT_ACCESS_WL_PAGE0_8814B BIT(6)
#define BIT_REG_RST_WLPMC_8814B BIT(5)
#define BIT_REG_RST_PD12N_8814B BIT(4)
#define BIT_SYSON_DIS_WLREG_WRMSK_8814B BIT(3)
#define BIT_SYSON_DIS_PMCREG_WRMSK_8814B BIT(2)
#define BIT_SHIFT_SYSON_REG_ARB_8814B 0
#define BIT_MASK_SYSON_REG_ARB_8814B 0x3
#define BIT_SYSON_REG_ARB_8814B(x) \
(((x) & BIT_MASK_SYSON_REG_ARB_8814B) << BIT_SHIFT_SYSON_REG_ARB_8814B)
#define BITS_SYSON_REG_ARB_8814B \
(BIT_MASK_SYSON_REG_ARB_8814B << BIT_SHIFT_SYSON_REG_ARB_8814B)
#define BIT_CLEAR_SYSON_REG_ARB_8814B(x) ((x) & (~BITS_SYSON_REG_ARB_8814B))
#define BIT_GET_SYSON_REG_ARB_8814B(x) \
(((x) >> BIT_SHIFT_SYSON_REG_ARB_8814B) & BIT_MASK_SYSON_REG_ARB_8814B)
#define BIT_SET_SYSON_REG_ARB_8814B(x, v) \
(BIT_CLEAR_SYSON_REG_ARB_8814B(x) | BIT_SYSON_REG_ARB_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_MEM_CTRL_8814B */
#define BIT_UMEM_RME_8814B BIT(31)
#define BIT_SHIFT_BT_SPRAM_8814B 28
#define BIT_MASK_BT_SPRAM_8814B 0x3
#define BIT_BT_SPRAM_8814B(x) \
(((x) & BIT_MASK_BT_SPRAM_8814B) << BIT_SHIFT_BT_SPRAM_8814B)
#define BITS_BT_SPRAM_8814B \
(BIT_MASK_BT_SPRAM_8814B << BIT_SHIFT_BT_SPRAM_8814B)
#define BIT_CLEAR_BT_SPRAM_8814B(x) ((x) & (~BITS_BT_SPRAM_8814B))
#define BIT_GET_BT_SPRAM_8814B(x) \
(((x) >> BIT_SHIFT_BT_SPRAM_8814B) & BIT_MASK_BT_SPRAM_8814B)
#define BIT_SET_BT_SPRAM_8814B(x, v) \
(BIT_CLEAR_BT_SPRAM_8814B(x) | BIT_BT_SPRAM_8814B(v))
#define BIT_SHIFT_BT_ROM_8814B 24
#define BIT_MASK_BT_ROM_8814B 0xf
#define BIT_BT_ROM_8814B(x) \
(((x) & BIT_MASK_BT_ROM_8814B) << BIT_SHIFT_BT_ROM_8814B)
#define BITS_BT_ROM_8814B (BIT_MASK_BT_ROM_8814B << BIT_SHIFT_BT_ROM_8814B)
#define BIT_CLEAR_BT_ROM_8814B(x) ((x) & (~BITS_BT_ROM_8814B))
#define BIT_GET_BT_ROM_8814B(x) \
(((x) >> BIT_SHIFT_BT_ROM_8814B) & BIT_MASK_BT_ROM_8814B)
#define BIT_SET_BT_ROM_8814B(x, v) \
(BIT_CLEAR_BT_ROM_8814B(x) | BIT_BT_ROM_8814B(v))
#define BIT_SHIFT_PCI_DPRAM_8814B 10
#define BIT_MASK_PCI_DPRAM_8814B 0x3
#define BIT_PCI_DPRAM_8814B(x) \
(((x) & BIT_MASK_PCI_DPRAM_8814B) << BIT_SHIFT_PCI_DPRAM_8814B)
#define BITS_PCI_DPRAM_8814B \
(BIT_MASK_PCI_DPRAM_8814B << BIT_SHIFT_PCI_DPRAM_8814B)
#define BIT_CLEAR_PCI_DPRAM_8814B(x) ((x) & (~BITS_PCI_DPRAM_8814B))
#define BIT_GET_PCI_DPRAM_8814B(x) \
(((x) >> BIT_SHIFT_PCI_DPRAM_8814B) & BIT_MASK_PCI_DPRAM_8814B)
#define BIT_SET_PCI_DPRAM_8814B(x, v) \
(BIT_CLEAR_PCI_DPRAM_8814B(x) | BIT_PCI_DPRAM_8814B(v))
#define BIT_SHIFT_PCI_SPRAM_8814B 8
#define BIT_MASK_PCI_SPRAM_8814B 0x3
#define BIT_PCI_SPRAM_8814B(x) \
(((x) & BIT_MASK_PCI_SPRAM_8814B) << BIT_SHIFT_PCI_SPRAM_8814B)
#define BITS_PCI_SPRAM_8814B \
(BIT_MASK_PCI_SPRAM_8814B << BIT_SHIFT_PCI_SPRAM_8814B)
#define BIT_CLEAR_PCI_SPRAM_8814B(x) ((x) & (~BITS_PCI_SPRAM_8814B))
#define BIT_GET_PCI_SPRAM_8814B(x) \
(((x) >> BIT_SHIFT_PCI_SPRAM_8814B) & BIT_MASK_PCI_SPRAM_8814B)
#define BIT_SET_PCI_SPRAM_8814B(x, v) \
(BIT_CLEAR_PCI_SPRAM_8814B(x) | BIT_PCI_SPRAM_8814B(v))
#define BIT_SHIFT_USB_SPRAM_8814B 6
#define BIT_MASK_USB_SPRAM_8814B 0x3
#define BIT_USB_SPRAM_8814B(x) \
(((x) & BIT_MASK_USB_SPRAM_8814B) << BIT_SHIFT_USB_SPRAM_8814B)
#define BITS_USB_SPRAM_8814B \
(BIT_MASK_USB_SPRAM_8814B << BIT_SHIFT_USB_SPRAM_8814B)
#define BIT_CLEAR_USB_SPRAM_8814B(x) ((x) & (~BITS_USB_SPRAM_8814B))
#define BIT_GET_USB_SPRAM_8814B(x) \
(((x) >> BIT_SHIFT_USB_SPRAM_8814B) & BIT_MASK_USB_SPRAM_8814B)
#define BIT_SET_USB_SPRAM_8814B(x, v) \
(BIT_CLEAR_USB_SPRAM_8814B(x) | BIT_USB_SPRAM_8814B(v))
#define BIT_SHIFT_USB_SPRF_8814B 4
#define BIT_MASK_USB_SPRF_8814B 0x3
#define BIT_USB_SPRF_8814B(x) \
(((x) & BIT_MASK_USB_SPRF_8814B) << BIT_SHIFT_USB_SPRF_8814B)
#define BITS_USB_SPRF_8814B \
(BIT_MASK_USB_SPRF_8814B << BIT_SHIFT_USB_SPRF_8814B)
#define BIT_CLEAR_USB_SPRF_8814B(x) ((x) & (~BITS_USB_SPRF_8814B))
#define BIT_GET_USB_SPRF_8814B(x) \
(((x) >> BIT_SHIFT_USB_SPRF_8814B) & BIT_MASK_USB_SPRF_8814B)
#define BIT_SET_USB_SPRF_8814B(x, v) \
(BIT_CLEAR_USB_SPRF_8814B(x) | BIT_USB_SPRF_8814B(v))
#define BIT_SHIFT_MCU_ROM_8814B 0
#define BIT_MASK_MCU_ROM_8814B 0xf
#define BIT_MCU_ROM_8814B(x) \
(((x) & BIT_MASK_MCU_ROM_8814B) << BIT_SHIFT_MCU_ROM_8814B)
#define BITS_MCU_ROM_8814B (BIT_MASK_MCU_ROM_8814B << BIT_SHIFT_MCU_ROM_8814B)
#define BIT_CLEAR_MCU_ROM_8814B(x) ((x) & (~BITS_MCU_ROM_8814B))
#define BIT_GET_MCU_ROM_8814B(x) \
(((x) >> BIT_SHIFT_MCU_ROM_8814B) & BIT_MASK_MCU_ROM_8814B)
#define BIT_SET_MCU_ROM_8814B(x, v) \
(BIT_CLEAR_MCU_ROM_8814B(x) | BIT_MCU_ROM_8814B(v))
/* 2 REG_SYN_RFC_CTRL_8814B */
#define BIT_SHIFT_SYN_RF1_CTRL_8814B 8
#define BIT_MASK_SYN_RF1_CTRL_8814B 0xff
#define BIT_SYN_RF1_CTRL_8814B(x) \
(((x) & BIT_MASK_SYN_RF1_CTRL_8814B) << BIT_SHIFT_SYN_RF1_CTRL_8814B)
#define BITS_SYN_RF1_CTRL_8814B \
(BIT_MASK_SYN_RF1_CTRL_8814B << BIT_SHIFT_SYN_RF1_CTRL_8814B)
#define BIT_CLEAR_SYN_RF1_CTRL_8814B(x) ((x) & (~BITS_SYN_RF1_CTRL_8814B))
#define BIT_GET_SYN_RF1_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_SYN_RF1_CTRL_8814B) & BIT_MASK_SYN_RF1_CTRL_8814B)
#define BIT_SET_SYN_RF1_CTRL_8814B(x, v) \
(BIT_CLEAR_SYN_RF1_CTRL_8814B(x) | BIT_SYN_RF1_CTRL_8814B(v))
#define BIT_SHIFT_SYN_RF0_CTRL_8814B 0
#define BIT_MASK_SYN_RF0_CTRL_8814B 0xff
#define BIT_SYN_RF0_CTRL_8814B(x) \
(((x) & BIT_MASK_SYN_RF0_CTRL_8814B) << BIT_SHIFT_SYN_RF0_CTRL_8814B)
#define BITS_SYN_RF0_CTRL_8814B \
(BIT_MASK_SYN_RF0_CTRL_8814B << BIT_SHIFT_SYN_RF0_CTRL_8814B)
#define BIT_CLEAR_SYN_RF0_CTRL_8814B(x) ((x) & (~BITS_SYN_RF0_CTRL_8814B))
#define BIT_GET_SYN_RF0_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_SYN_RF0_CTRL_8814B) & BIT_MASK_SYN_RF0_CTRL_8814B)
#define BIT_SET_SYN_RF0_CTRL_8814B(x, v) \
(BIT_CLEAR_SYN_RF0_CTRL_8814B(x) | BIT_SYN_RF0_CTRL_8814B(v))
/* 2 REG_USB_SIE_INTF_8814B */
#define BIT_RD_SEL_8814B BIT(31)
#define BIT_USB_SIE_INTF_WE_V1_8814B BIT(30)
#define BIT_USB_SIE_INTF_BYIOREG_V1_8814B BIT(29)
#define BIT_USB_SIE_SELECT_8814B BIT(28)
#define BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8814B 16
#define BIT_MASK_USB_SIE_INTF_ADDR_V1_8814B 0x1ff
#define BIT_USB_SIE_INTF_ADDR_V1_8814B(x) \
(((x) & BIT_MASK_USB_SIE_INTF_ADDR_V1_8814B) \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8814B)
#define BITS_USB_SIE_INTF_ADDR_V1_8814B \
(BIT_MASK_USB_SIE_INTF_ADDR_V1_8814B \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8814B)
#define BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8814B(x) \
((x) & (~BITS_USB_SIE_INTF_ADDR_V1_8814B))
#define BIT_GET_USB_SIE_INTF_ADDR_V1_8814B(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8814B) & \
BIT_MASK_USB_SIE_INTF_ADDR_V1_8814B)
#define BIT_SET_USB_SIE_INTF_ADDR_V1_8814B(x, v) \
(BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8814B(x) | \
BIT_USB_SIE_INTF_ADDR_V1_8814B(v))
#define BIT_SHIFT_USB_SIE_INTF_RD_8814B 8
#define BIT_MASK_USB_SIE_INTF_RD_8814B 0xff
#define BIT_USB_SIE_INTF_RD_8814B(x) \
(((x) & BIT_MASK_USB_SIE_INTF_RD_8814B) \
<< BIT_SHIFT_USB_SIE_INTF_RD_8814B)
#define BITS_USB_SIE_INTF_RD_8814B \
(BIT_MASK_USB_SIE_INTF_RD_8814B << BIT_SHIFT_USB_SIE_INTF_RD_8814B)
#define BIT_CLEAR_USB_SIE_INTF_RD_8814B(x) ((x) & (~BITS_USB_SIE_INTF_RD_8814B))
#define BIT_GET_USB_SIE_INTF_RD_8814B(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_RD_8814B) & \
BIT_MASK_USB_SIE_INTF_RD_8814B)
#define BIT_SET_USB_SIE_INTF_RD_8814B(x, v) \
(BIT_CLEAR_USB_SIE_INTF_RD_8814B(x) | BIT_USB_SIE_INTF_RD_8814B(v))
#define BIT_SHIFT_USB_SIE_INTF_WD_8814B 0
#define BIT_MASK_USB_SIE_INTF_WD_8814B 0xff
#define BIT_USB_SIE_INTF_WD_8814B(x) \
(((x) & BIT_MASK_USB_SIE_INTF_WD_8814B) \
<< BIT_SHIFT_USB_SIE_INTF_WD_8814B)
#define BITS_USB_SIE_INTF_WD_8814B \
(BIT_MASK_USB_SIE_INTF_WD_8814B << BIT_SHIFT_USB_SIE_INTF_WD_8814B)
#define BIT_CLEAR_USB_SIE_INTF_WD_8814B(x) ((x) & (~BITS_USB_SIE_INTF_WD_8814B))
#define BIT_GET_USB_SIE_INTF_WD_8814B(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_WD_8814B) & \
BIT_MASK_USB_SIE_INTF_WD_8814B)
#define BIT_SET_USB_SIE_INTF_WD_8814B(x, v) \
(BIT_CLEAR_USB_SIE_INTF_WD_8814B(x) | BIT_USB_SIE_INTF_WD_8814B(v))
/* 2 REG_PCIE_MIO_INTF_8814B */
#define BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8814B 16
#define BIT_MASK_PCIE_MIO_ADDR_PAGE_8814B 0x3
#define BIT_PCIE_MIO_ADDR_PAGE_8814B(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_PAGE_8814B) \
<< BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8814B)
#define BITS_PCIE_MIO_ADDR_PAGE_8814B \
(BIT_MASK_PCIE_MIO_ADDR_PAGE_8814B \
<< BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8814B)
#define BIT_CLEAR_PCIE_MIO_ADDR_PAGE_8814B(x) \
((x) & (~BITS_PCIE_MIO_ADDR_PAGE_8814B))
#define BIT_GET_PCIE_MIO_ADDR_PAGE_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8814B) & \
BIT_MASK_PCIE_MIO_ADDR_PAGE_8814B)
#define BIT_SET_PCIE_MIO_ADDR_PAGE_8814B(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_PAGE_8814B(x) | \
BIT_PCIE_MIO_ADDR_PAGE_8814B(v))
#define BIT_PCIE_MIO_BYIOREG_8814B BIT(13)
#define BIT_PCIE_MIO_RE_8814B BIT(12)
#define BIT_SHIFT_PCIE_MIO_WE_8814B 8
#define BIT_MASK_PCIE_MIO_WE_8814B 0xf
#define BIT_PCIE_MIO_WE_8814B(x) \
(((x) & BIT_MASK_PCIE_MIO_WE_8814B) << BIT_SHIFT_PCIE_MIO_WE_8814B)
#define BITS_PCIE_MIO_WE_8814B \
(BIT_MASK_PCIE_MIO_WE_8814B << BIT_SHIFT_PCIE_MIO_WE_8814B)
#define BIT_CLEAR_PCIE_MIO_WE_8814B(x) ((x) & (~BITS_PCIE_MIO_WE_8814B))
#define BIT_GET_PCIE_MIO_WE_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_WE_8814B) & BIT_MASK_PCIE_MIO_WE_8814B)
#define BIT_SET_PCIE_MIO_WE_8814B(x, v) \
(BIT_CLEAR_PCIE_MIO_WE_8814B(x) | BIT_PCIE_MIO_WE_8814B(v))
#define BIT_SHIFT_PCIE_MIO_ADDR_8814B 0
#define BIT_MASK_PCIE_MIO_ADDR_8814B 0xff
#define BIT_PCIE_MIO_ADDR_8814B(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_8814B) << BIT_SHIFT_PCIE_MIO_ADDR_8814B)
#define BITS_PCIE_MIO_ADDR_8814B \
(BIT_MASK_PCIE_MIO_ADDR_8814B << BIT_SHIFT_PCIE_MIO_ADDR_8814B)
#define BIT_CLEAR_PCIE_MIO_ADDR_8814B(x) ((x) & (~BITS_PCIE_MIO_ADDR_8814B))
#define BIT_GET_PCIE_MIO_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_8814B) & BIT_MASK_PCIE_MIO_ADDR_8814B)
#define BIT_SET_PCIE_MIO_ADDR_8814B(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_8814B(x) | BIT_PCIE_MIO_ADDR_8814B(v))
/* 2 REG_PCIE_MIO_INTD_8814B */
#define BIT_SHIFT_PCIE_MIO_DATA_8814B 0
#define BIT_MASK_PCIE_MIO_DATA_8814B 0xffffffffL
#define BIT_PCIE_MIO_DATA_8814B(x) \
(((x) & BIT_MASK_PCIE_MIO_DATA_8814B) << BIT_SHIFT_PCIE_MIO_DATA_8814B)
#define BITS_PCIE_MIO_DATA_8814B \
(BIT_MASK_PCIE_MIO_DATA_8814B << BIT_SHIFT_PCIE_MIO_DATA_8814B)
#define BIT_CLEAR_PCIE_MIO_DATA_8814B(x) ((x) & (~BITS_PCIE_MIO_DATA_8814B))
#define BIT_GET_PCIE_MIO_DATA_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_DATA_8814B) & BIT_MASK_PCIE_MIO_DATA_8814B)
#define BIT_SET_PCIE_MIO_DATA_8814B(x, v) \
(BIT_CLEAR_PCIE_MIO_DATA_8814B(x) | BIT_PCIE_MIO_DATA_8814B(v))
/* 2 REG_WLRF1_8814B */
#define BIT_SHIFT_WLRF1_CTRL_8814B 24
#define BIT_MASK_WLRF1_CTRL_8814B 0xff
#define BIT_WLRF1_CTRL_8814B(x) \
(((x) & BIT_MASK_WLRF1_CTRL_8814B) << BIT_SHIFT_WLRF1_CTRL_8814B)
#define BITS_WLRF1_CTRL_8814B \
(BIT_MASK_WLRF1_CTRL_8814B << BIT_SHIFT_WLRF1_CTRL_8814B)
#define BIT_CLEAR_WLRF1_CTRL_8814B(x) ((x) & (~BITS_WLRF1_CTRL_8814B))
#define BIT_GET_WLRF1_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_WLRF1_CTRL_8814B) & BIT_MASK_WLRF1_CTRL_8814B)
#define BIT_SET_WLRF1_CTRL_8814B(x, v) \
(BIT_CLEAR_WLRF1_CTRL_8814B(x) | BIT_WLRF1_CTRL_8814B(v))
#define BIT_SHIFT_WLRF2_CTRL_8814B 16
#define BIT_MASK_WLRF2_CTRL_8814B 0xff
#define BIT_WLRF2_CTRL_8814B(x) \
(((x) & BIT_MASK_WLRF2_CTRL_8814B) << BIT_SHIFT_WLRF2_CTRL_8814B)
#define BITS_WLRF2_CTRL_8814B \
(BIT_MASK_WLRF2_CTRL_8814B << BIT_SHIFT_WLRF2_CTRL_8814B)
#define BIT_CLEAR_WLRF2_CTRL_8814B(x) ((x) & (~BITS_WLRF2_CTRL_8814B))
#define BIT_GET_WLRF2_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_WLRF2_CTRL_8814B) & BIT_MASK_WLRF2_CTRL_8814B)
#define BIT_SET_WLRF2_CTRL_8814B(x, v) \
(BIT_CLEAR_WLRF2_CTRL_8814B(x) | BIT_WLRF2_CTRL_8814B(v))
#define BIT_SHIFT_WLRF3_CTRL_8814B 8
#define BIT_MASK_WLRF3_CTRL_8814B 0xff
#define BIT_WLRF3_CTRL_8814B(x) \
(((x) & BIT_MASK_WLRF3_CTRL_8814B) << BIT_SHIFT_WLRF3_CTRL_8814B)
#define BITS_WLRF3_CTRL_8814B \
(BIT_MASK_WLRF3_CTRL_8814B << BIT_SHIFT_WLRF3_CTRL_8814B)
#define BIT_CLEAR_WLRF3_CTRL_8814B(x) ((x) & (~BITS_WLRF3_CTRL_8814B))
#define BIT_GET_WLRF3_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_WLRF3_CTRL_8814B) & BIT_MASK_WLRF3_CTRL_8814B)
#define BIT_SET_WLRF3_CTRL_8814B(x, v) \
(BIT_CLEAR_WLRF3_CTRL_8814B(x) | BIT_WLRF3_CTRL_8814B(v))
/* 2 REG_SYS_CFG1_8814B */
#define BIT_SHIFT_TRP_ICFG_8814B 28
#define BIT_MASK_TRP_ICFG_8814B 0xf
#define BIT_TRP_ICFG_8814B(x) \
(((x) & BIT_MASK_TRP_ICFG_8814B) << BIT_SHIFT_TRP_ICFG_8814B)
#define BITS_TRP_ICFG_8814B \
(BIT_MASK_TRP_ICFG_8814B << BIT_SHIFT_TRP_ICFG_8814B)
#define BIT_CLEAR_TRP_ICFG_8814B(x) ((x) & (~BITS_TRP_ICFG_8814B))
#define BIT_GET_TRP_ICFG_8814B(x) \
(((x) >> BIT_SHIFT_TRP_ICFG_8814B) & BIT_MASK_TRP_ICFG_8814B)
#define BIT_SET_TRP_ICFG_8814B(x, v) \
(BIT_CLEAR_TRP_ICFG_8814B(x) | BIT_TRP_ICFG_8814B(v))
#define BIT_RF_TYPE_ID_8814B BIT(27)
#define BIT_BD_HCI_SEL_8814B BIT(26)
#define BIT_BD_PKG_SEL_8814B BIT(25)
#define BIT_SPSLDO_SEL_8814B BIT(24)
#define BIT_RTL_ID_8814B BIT(23)
#define BIT_PAD_HWPD_IDN_8814B BIT(22)
#define BIT_TESTMODE_8814B BIT(20)
#define BIT_SHIFT_VENDOR_ID_8814B 16
#define BIT_MASK_VENDOR_ID_8814B 0xf
#define BIT_VENDOR_ID_8814B(x) \
(((x) & BIT_MASK_VENDOR_ID_8814B) << BIT_SHIFT_VENDOR_ID_8814B)
#define BITS_VENDOR_ID_8814B \
(BIT_MASK_VENDOR_ID_8814B << BIT_SHIFT_VENDOR_ID_8814B)
#define BIT_CLEAR_VENDOR_ID_8814B(x) ((x) & (~BITS_VENDOR_ID_8814B))
#define BIT_GET_VENDOR_ID_8814B(x) \
(((x) >> BIT_SHIFT_VENDOR_ID_8814B) & BIT_MASK_VENDOR_ID_8814B)
#define BIT_SET_VENDOR_ID_8814B(x, v) \
(BIT_CLEAR_VENDOR_ID_8814B(x) | BIT_VENDOR_ID_8814B(v))
#define BIT_SHIFT_CHIP_VER_8814B 12
#define BIT_MASK_CHIP_VER_8814B 0xf
#define BIT_CHIP_VER_8814B(x) \
(((x) & BIT_MASK_CHIP_VER_8814B) << BIT_SHIFT_CHIP_VER_8814B)
#define BITS_CHIP_VER_8814B \
(BIT_MASK_CHIP_VER_8814B << BIT_SHIFT_CHIP_VER_8814B)
#define BIT_CLEAR_CHIP_VER_8814B(x) ((x) & (~BITS_CHIP_VER_8814B))
#define BIT_GET_CHIP_VER_8814B(x) \
(((x) >> BIT_SHIFT_CHIP_VER_8814B) & BIT_MASK_CHIP_VER_8814B)
#define BIT_SET_CHIP_VER_8814B(x, v) \
(BIT_CLEAR_CHIP_VER_8814B(x) | BIT_CHIP_VER_8814B(v))
#define BIT_BD_MAC3_8814B BIT(11)
#define BIT_BD_MAC1_8814B BIT(10)
#define BIT_BD_MAC2_8814B BIT(9)
#define BIT_SIC_IDLE_8814B BIT(8)
#define BIT_SW_OFFLOAD_EN_8814B BIT(7)
#define BIT_OCP_SHUTDN_8814B BIT(6)
#define BIT_V15_VLD_8814B BIT(5)
#define BIT_PCIRSTB_8814B BIT(4)
#define BIT_PCLK_VLD_8814B BIT(3)
#define BIT_UCLK_VLD_8814B BIT(2)
#define BIT_ACLK_VLD_8814B BIT(1)
#define BIT_XCLK_VLD_8814B BIT(0)
/* 2 REG_SYS_STATUS1_8814B */
#define BIT_SHIFT_RF_RL_ID_8814B 28
#define BIT_MASK_RF_RL_ID_8814B 0xf
#define BIT_RF_RL_ID_8814B(x) \
(((x) & BIT_MASK_RF_RL_ID_8814B) << BIT_SHIFT_RF_RL_ID_8814B)
#define BITS_RF_RL_ID_8814B \
(BIT_MASK_RF_RL_ID_8814B << BIT_SHIFT_RF_RL_ID_8814B)
#define BIT_CLEAR_RF_RL_ID_8814B(x) ((x) & (~BITS_RF_RL_ID_8814B))
#define BIT_GET_RF_RL_ID_8814B(x) \
(((x) >> BIT_SHIFT_RF_RL_ID_8814B) & BIT_MASK_RF_RL_ID_8814B)
#define BIT_SET_RF_RL_ID_8814B(x, v) \
(BIT_CLEAR_RF_RL_ID_8814B(x) | BIT_RF_RL_ID_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_XTAL_SEL_8814B 25
#define BIT_MASK_XTAL_SEL_8814B 0x3
#define BIT_XTAL_SEL_8814B(x) \
(((x) & BIT_MASK_XTAL_SEL_8814B) << BIT_SHIFT_XTAL_SEL_8814B)
#define BITS_XTAL_SEL_8814B \
(BIT_MASK_XTAL_SEL_8814B << BIT_SHIFT_XTAL_SEL_8814B)
#define BIT_CLEAR_XTAL_SEL_8814B(x) ((x) & (~BITS_XTAL_SEL_8814B))
#define BIT_GET_XTAL_SEL_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_8814B) & BIT_MASK_XTAL_SEL_8814B)
#define BIT_SET_XTAL_SEL_8814B(x, v) \
(BIT_CLEAR_XTAL_SEL_8814B(x) | BIT_XTAL_SEL_8814B(v))
#define BIT_HPHY_ICFG_8814B BIT(19)
#define BIT_SHIFT_SEL_0XC0_8814B 16
#define BIT_MASK_SEL_0XC0_8814B 0x3
#define BIT_SEL_0XC0_8814B(x) \
(((x) & BIT_MASK_SEL_0XC0_8814B) << BIT_SHIFT_SEL_0XC0_8814B)
#define BITS_SEL_0XC0_8814B \
(BIT_MASK_SEL_0XC0_8814B << BIT_SHIFT_SEL_0XC0_8814B)
#define BIT_CLEAR_SEL_0XC0_8814B(x) ((x) & (~BITS_SEL_0XC0_8814B))
#define BIT_GET_SEL_0XC0_8814B(x) \
(((x) >> BIT_SHIFT_SEL_0XC0_8814B) & BIT_MASK_SEL_0XC0_8814B)
#define BIT_SET_SEL_0XC0_8814B(x, v) \
(BIT_CLEAR_SEL_0XC0_8814B(x) | BIT_SEL_0XC0_8814B(v))
#define BIT_SHIFT_HCI_SEL_V4_8814B 12
#define BIT_MASK_HCI_SEL_V4_8814B 0x3
#define BIT_HCI_SEL_V4_8814B(x) \
(((x) & BIT_MASK_HCI_SEL_V4_8814B) << BIT_SHIFT_HCI_SEL_V4_8814B)
#define BITS_HCI_SEL_V4_8814B \
(BIT_MASK_HCI_SEL_V4_8814B << BIT_SHIFT_HCI_SEL_V4_8814B)
#define BIT_CLEAR_HCI_SEL_V4_8814B(x) ((x) & (~BITS_HCI_SEL_V4_8814B))
#define BIT_GET_HCI_SEL_V4_8814B(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V4_8814B) & BIT_MASK_HCI_SEL_V4_8814B)
#define BIT_SET_HCI_SEL_V4_8814B(x, v) \
(BIT_CLEAR_HCI_SEL_V4_8814B(x) | BIT_HCI_SEL_V4_8814B(v))
#define BIT_USB_OPERATION_MODE_8814B BIT(10)
#define BIT_BT_PDN_8814B BIT(9)
#define BIT_AUTO_WLPON_8814B BIT(8)
#define BIT_WL_MODE_8814B BIT(7)
#define BIT_PKG_SEL_HCI_8814B BIT(6)
#define BIT_SHIFT_PAD_HCI_SEL_V2_8814B 3
#define BIT_MASK_PAD_HCI_SEL_V2_8814B 0x3
#define BIT_PAD_HCI_SEL_V2_8814B(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_V2_8814B) \
<< BIT_SHIFT_PAD_HCI_SEL_V2_8814B)
#define BITS_PAD_HCI_SEL_V2_8814B \
(BIT_MASK_PAD_HCI_SEL_V2_8814B << BIT_SHIFT_PAD_HCI_SEL_V2_8814B)
#define BIT_CLEAR_PAD_HCI_SEL_V2_8814B(x) ((x) & (~BITS_PAD_HCI_SEL_V2_8814B))
#define BIT_GET_PAD_HCI_SEL_V2_8814B(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_V2_8814B) & \
BIT_MASK_PAD_HCI_SEL_V2_8814B)
#define BIT_SET_PAD_HCI_SEL_V2_8814B(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_V2_8814B(x) | BIT_PAD_HCI_SEL_V2_8814B(v))
#define BIT_SHIFT_EFS_HCI_SEL_8814B 0
#define BIT_MASK_EFS_HCI_SEL_8814B 0x3
#define BIT_EFS_HCI_SEL_8814B(x) \
(((x) & BIT_MASK_EFS_HCI_SEL_8814B) << BIT_SHIFT_EFS_HCI_SEL_8814B)
#define BITS_EFS_HCI_SEL_8814B \
(BIT_MASK_EFS_HCI_SEL_8814B << BIT_SHIFT_EFS_HCI_SEL_8814B)
#define BIT_CLEAR_EFS_HCI_SEL_8814B(x) ((x) & (~BITS_EFS_HCI_SEL_8814B))
#define BIT_GET_EFS_HCI_SEL_8814B(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL_8814B) & BIT_MASK_EFS_HCI_SEL_8814B)
#define BIT_SET_EFS_HCI_SEL_8814B(x, v) \
(BIT_CLEAR_EFS_HCI_SEL_8814B(x) | BIT_EFS_HCI_SEL_8814B(v))
/* 2 REG_SYS_STATUS2_8814B */
#define BIT_SIO_ALDN_8814B BIT(19)
#define BIT_USB_ALDN_8814B BIT(18)
#define BIT_PCI_ALDN_8814B BIT(17)
#define BIT_SYS_ALDN_8814B BIT(16)
#define BIT_SHIFT_EPVID1_8814B 8
#define BIT_MASK_EPVID1_8814B 0xff
#define BIT_EPVID1_8814B(x) \
(((x) & BIT_MASK_EPVID1_8814B) << BIT_SHIFT_EPVID1_8814B)
#define BITS_EPVID1_8814B (BIT_MASK_EPVID1_8814B << BIT_SHIFT_EPVID1_8814B)
#define BIT_CLEAR_EPVID1_8814B(x) ((x) & (~BITS_EPVID1_8814B))
#define BIT_GET_EPVID1_8814B(x) \
(((x) >> BIT_SHIFT_EPVID1_8814B) & BIT_MASK_EPVID1_8814B)
#define BIT_SET_EPVID1_8814B(x, v) \
(BIT_CLEAR_EPVID1_8814B(x) | BIT_EPVID1_8814B(v))
#define BIT_SHIFT_EPVID0_8814B 0
#define BIT_MASK_EPVID0_8814B 0xff
#define BIT_EPVID0_8814B(x) \
(((x) & BIT_MASK_EPVID0_8814B) << BIT_SHIFT_EPVID0_8814B)
#define BITS_EPVID0_8814B (BIT_MASK_EPVID0_8814B << BIT_SHIFT_EPVID0_8814B)
#define BIT_CLEAR_EPVID0_8814B(x) ((x) & (~BITS_EPVID0_8814B))
#define BIT_GET_EPVID0_8814B(x) \
(((x) >> BIT_SHIFT_EPVID0_8814B) & BIT_MASK_EPVID0_8814B)
#define BIT_SET_EPVID0_8814B(x, v) \
(BIT_CLEAR_EPVID0_8814B(x) | BIT_EPVID0_8814B(v))
/* 2 REG_SYS_CFG2_8814B */
#define BIT_USB2_SEL_8814B BIT(31)
#define BIT_U3PHY_RST_V1_8814B BIT(30)
#define BIT_U3_TERM_DETECT_8814B BIT(29)
#define BIT_SHIFT_HW_ID_8814B 0
#define BIT_MASK_HW_ID_8814B 0xff
#define BIT_HW_ID_8814B(x) \
(((x) & BIT_MASK_HW_ID_8814B) << BIT_SHIFT_HW_ID_8814B)
#define BITS_HW_ID_8814B (BIT_MASK_HW_ID_8814B << BIT_SHIFT_HW_ID_8814B)
#define BIT_CLEAR_HW_ID_8814B(x) ((x) & (~BITS_HW_ID_8814B))
#define BIT_GET_HW_ID_8814B(x) \
(((x) >> BIT_SHIFT_HW_ID_8814B) & BIT_MASK_HW_ID_8814B)
#define BIT_SET_HW_ID_8814B(x, v) \
(BIT_CLEAR_HW_ID_8814B(x) | BIT_HW_ID_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_FEN_WLMAC_OFF_8814B BIT(31)
#define BIT_PWC_MA33V_8814B BIT(15)
#define BIT_PWC_MA12V_8814B BIT(14)
#define BIT_PWC_MD12V_8814B BIT(13)
#define BIT_PWC_PD12V_8814B BIT(12)
#define BIT_PWC_UD12V_8814B BIT(11)
#define BIT_ISO_BB2PP_8814B BIT(7)
#define BIT_ISO_DENG2PP_8814B BIT(6)
#define BIT_ISO_MA2MD_8814B BIT(1)
#define BIT_ISO_MD2PP_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ANAPARSW_MAC_0_8814B */
#define BIT_OCP_L_0_8814B BIT(31)
#define BIT_POWOCP_L_8814B BIT(30)
#define BIT_SHIFT_CF_L_1_0_8814B 28
#define BIT_MASK_CF_L_1_0_8814B 0x3
#define BIT_CF_L_1_0_8814B(x) \
(((x) & BIT_MASK_CF_L_1_0_8814B) << BIT_SHIFT_CF_L_1_0_8814B)
#define BITS_CF_L_1_0_8814B \
(BIT_MASK_CF_L_1_0_8814B << BIT_SHIFT_CF_L_1_0_8814B)
#define BIT_CLEAR_CF_L_1_0_8814B(x) ((x) & (~BITS_CF_L_1_0_8814B))
#define BIT_GET_CF_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_CF_L_1_0_8814B) & BIT_MASK_CF_L_1_0_8814B)
#define BIT_SET_CF_L_1_0_8814B(x, v) \
(BIT_CLEAR_CF_L_1_0_8814B(x) | BIT_CF_L_1_0_8814B(v))
#define BIT_SHIFT_CFC_L_1_0_8814B 26
#define BIT_MASK_CFC_L_1_0_8814B 0x3
#define BIT_CFC_L_1_0_8814B(x) \
(((x) & BIT_MASK_CFC_L_1_0_8814B) << BIT_SHIFT_CFC_L_1_0_8814B)
#define BITS_CFC_L_1_0_8814B \
(BIT_MASK_CFC_L_1_0_8814B << BIT_SHIFT_CFC_L_1_0_8814B)
#define BIT_CLEAR_CFC_L_1_0_8814B(x) ((x) & (~BITS_CFC_L_1_0_8814B))
#define BIT_GET_CFC_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_CFC_L_1_0_8814B) & BIT_MASK_CFC_L_1_0_8814B)
#define BIT_SET_CFC_L_1_0_8814B(x, v) \
(BIT_CLEAR_CFC_L_1_0_8814B(x) | BIT_CFC_L_1_0_8814B(v))
#define BIT_SHIFT_R3_L_1_0_8814B 24
#define BIT_MASK_R3_L_1_0_8814B 0x3
#define BIT_R3_L_1_0_8814B(x) \
(((x) & BIT_MASK_R3_L_1_0_8814B) << BIT_SHIFT_R3_L_1_0_8814B)
#define BITS_R3_L_1_0_8814B \
(BIT_MASK_R3_L_1_0_8814B << BIT_SHIFT_R3_L_1_0_8814B)
#define BIT_CLEAR_R3_L_1_0_8814B(x) ((x) & (~BITS_R3_L_1_0_8814B))
#define BIT_GET_R3_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_R3_L_1_0_8814B) & BIT_MASK_R3_L_1_0_8814B)
#define BIT_SET_R3_L_1_0_8814B(x, v) \
(BIT_CLEAR_R3_L_1_0_8814B(x) | BIT_R3_L_1_0_8814B(v))
#define BIT_SHIFT_R2_L_1_0_8814B 22
#define BIT_MASK_R2_L_1_0_8814B 0x3
#define BIT_R2_L_1_0_8814B(x) \
(((x) & BIT_MASK_R2_L_1_0_8814B) << BIT_SHIFT_R2_L_1_0_8814B)
#define BITS_R2_L_1_0_8814B \
(BIT_MASK_R2_L_1_0_8814B << BIT_SHIFT_R2_L_1_0_8814B)
#define BIT_CLEAR_R2_L_1_0_8814B(x) ((x) & (~BITS_R2_L_1_0_8814B))
#define BIT_GET_R2_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_R2_L_1_0_8814B) & BIT_MASK_R2_L_1_0_8814B)
#define BIT_SET_R2_L_1_0_8814B(x, v) \
(BIT_CLEAR_R2_L_1_0_8814B(x) | BIT_R2_L_1_0_8814B(v))
#define BIT_SHIFT_R1_L_1_0_8814B 20
#define BIT_MASK_R1_L_1_0_8814B 0x3
#define BIT_R1_L_1_0_8814B(x) \
(((x) & BIT_MASK_R1_L_1_0_8814B) << BIT_SHIFT_R1_L_1_0_8814B)
#define BITS_R1_L_1_0_8814B \
(BIT_MASK_R1_L_1_0_8814B << BIT_SHIFT_R1_L_1_0_8814B)
#define BIT_CLEAR_R1_L_1_0_8814B(x) ((x) & (~BITS_R1_L_1_0_8814B))
#define BIT_GET_R1_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_R1_L_1_0_8814B) & BIT_MASK_R1_L_1_0_8814B)
#define BIT_SET_R1_L_1_0_8814B(x, v) \
(BIT_CLEAR_R1_L_1_0_8814B(x) | BIT_R1_L_1_0_8814B(v))
#define BIT_SHIFT_C3_L_1_0_8814B 18
#define BIT_MASK_C3_L_1_0_8814B 0x3
#define BIT_C3_L_1_0_8814B(x) \
(((x) & BIT_MASK_C3_L_1_0_8814B) << BIT_SHIFT_C3_L_1_0_8814B)
#define BITS_C3_L_1_0_8814B \
(BIT_MASK_C3_L_1_0_8814B << BIT_SHIFT_C3_L_1_0_8814B)
#define BIT_CLEAR_C3_L_1_0_8814B(x) ((x) & (~BITS_C3_L_1_0_8814B))
#define BIT_GET_C3_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_C3_L_1_0_8814B) & BIT_MASK_C3_L_1_0_8814B)
#define BIT_SET_C3_L_1_0_8814B(x, v) \
(BIT_CLEAR_C3_L_1_0_8814B(x) | BIT_C3_L_1_0_8814B(v))
#define BIT_SHIFT_C2_L_1_0_8814B 16
#define BIT_MASK_C2_L_1_0_8814B 0x3
#define BIT_C2_L_1_0_8814B(x) \
(((x) & BIT_MASK_C2_L_1_0_8814B) << BIT_SHIFT_C2_L_1_0_8814B)
#define BITS_C2_L_1_0_8814B \
(BIT_MASK_C2_L_1_0_8814B << BIT_SHIFT_C2_L_1_0_8814B)
#define BIT_CLEAR_C2_L_1_0_8814B(x) ((x) & (~BITS_C2_L_1_0_8814B))
#define BIT_GET_C2_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_C2_L_1_0_8814B) & BIT_MASK_C2_L_1_0_8814B)
#define BIT_SET_C2_L_1_0_8814B(x, v) \
(BIT_CLEAR_C2_L_1_0_8814B(x) | BIT_C2_L_1_0_8814B(v))
#define BIT_SHIFT_C1_L_1_0_8814B 14
#define BIT_MASK_C1_L_1_0_8814B 0x3
#define BIT_C1_L_1_0_8814B(x) \
(((x) & BIT_MASK_C1_L_1_0_8814B) << BIT_SHIFT_C1_L_1_0_8814B)
#define BITS_C1_L_1_0_8814B \
(BIT_MASK_C1_L_1_0_8814B << BIT_SHIFT_C1_L_1_0_8814B)
#define BIT_CLEAR_C1_L_1_0_8814B(x) ((x) & (~BITS_C1_L_1_0_8814B))
#define BIT_GET_C1_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_C1_L_1_0_8814B) & BIT_MASK_C1_L_1_0_8814B)
#define BIT_SET_C1_L_1_0_8814B(x, v) \
(BIT_CLEAR_C1_L_1_0_8814B(x) | BIT_C1_L_1_0_8814B(v))
#define BIT_REG_TYPE_L_V2_8814B BIT(13)
#define BIT_REG_PWM_L_8814B BIT(12)
#define BIT_SHIFT_V15ADJ_L_2_0_8814B 9
#define BIT_MASK_V15ADJ_L_2_0_8814B 0x7
#define BIT_V15ADJ_L_2_0_8814B(x) \
(((x) & BIT_MASK_V15ADJ_L_2_0_8814B) << BIT_SHIFT_V15ADJ_L_2_0_8814B)
#define BITS_V15ADJ_L_2_0_8814B \
(BIT_MASK_V15ADJ_L_2_0_8814B << BIT_SHIFT_V15ADJ_L_2_0_8814B)
#define BIT_CLEAR_V15ADJ_L_2_0_8814B(x) ((x) & (~BITS_V15ADJ_L_2_0_8814B))
#define BIT_GET_V15ADJ_L_2_0_8814B(x) \
(((x) >> BIT_SHIFT_V15ADJ_L_2_0_8814B) & BIT_MASK_V15ADJ_L_2_0_8814B)
#define BIT_SET_V15ADJ_L_2_0_8814B(x, v) \
(BIT_CLEAR_V15ADJ_L_2_0_8814B(x) | BIT_V15ADJ_L_2_0_8814B(v))
#define BIT_SHIFT_IN_L_2_0_8814B 6
#define BIT_MASK_IN_L_2_0_8814B 0x7
#define BIT_IN_L_2_0_8814B(x) \
(((x) & BIT_MASK_IN_L_2_0_8814B) << BIT_SHIFT_IN_L_2_0_8814B)
#define BITS_IN_L_2_0_8814B \
(BIT_MASK_IN_L_2_0_8814B << BIT_SHIFT_IN_L_2_0_8814B)
#define BIT_CLEAR_IN_L_2_0_8814B(x) ((x) & (~BITS_IN_L_2_0_8814B))
#define BIT_GET_IN_L_2_0_8814B(x) \
(((x) >> BIT_SHIFT_IN_L_2_0_8814B) & BIT_MASK_IN_L_2_0_8814B)
#define BIT_SET_IN_L_2_0_8814B(x, v) \
(BIT_CLEAR_IN_L_2_0_8814B(x) | BIT_IN_L_2_0_8814B(v))
#define BIT_SHIFT_STD_L_1_0_8814B 4
#define BIT_MASK_STD_L_1_0_8814B 0x3
#define BIT_STD_L_1_0_8814B(x) \
(((x) & BIT_MASK_STD_L_1_0_8814B) << BIT_SHIFT_STD_L_1_0_8814B)
#define BITS_STD_L_1_0_8814B \
(BIT_MASK_STD_L_1_0_8814B << BIT_SHIFT_STD_L_1_0_8814B)
#define BIT_CLEAR_STD_L_1_0_8814B(x) ((x) & (~BITS_STD_L_1_0_8814B))
#define BIT_GET_STD_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_STD_L_1_0_8814B) & BIT_MASK_STD_L_1_0_8814B)
#define BIT_SET_STD_L_1_0_8814B(x, v) \
(BIT_CLEAR_STD_L_1_0_8814B(x) | BIT_STD_L_1_0_8814B(v))
#define BIT_SHIFT_VOL_L_3_0_8814B 0
#define BIT_MASK_VOL_L_3_0_8814B 0xf
#define BIT_VOL_L_3_0_8814B(x) \
(((x) & BIT_MASK_VOL_L_3_0_8814B) << BIT_SHIFT_VOL_L_3_0_8814B)
#define BITS_VOL_L_3_0_8814B \
(BIT_MASK_VOL_L_3_0_8814B << BIT_SHIFT_VOL_L_3_0_8814B)
#define BIT_CLEAR_VOL_L_3_0_8814B(x) ((x) & (~BITS_VOL_L_3_0_8814B))
#define BIT_GET_VOL_L_3_0_8814B(x) \
(((x) >> BIT_SHIFT_VOL_L_3_0_8814B) & BIT_MASK_VOL_L_3_0_8814B)
#define BIT_SET_VOL_L_3_0_8814B(x, v) \
(BIT_CLEAR_VOL_L_3_0_8814B(x) | BIT_VOL_L_3_0_8814B(v))
/* 2 REG_ANAPARSW_MAC_1_8814B */
#define BIT_SHIFT_REG_FREQ_L_V1_8814B 20
#define BIT_MASK_REG_FREQ_L_V1_8814B 0x7
#define BIT_REG_FREQ_L_V1_8814B(x) \
(((x) & BIT_MASK_REG_FREQ_L_V1_8814B) << BIT_SHIFT_REG_FREQ_L_V1_8814B)
#define BITS_REG_FREQ_L_V1_8814B \
(BIT_MASK_REG_FREQ_L_V1_8814B << BIT_SHIFT_REG_FREQ_L_V1_8814B)
#define BIT_CLEAR_REG_FREQ_L_V1_8814B(x) ((x) & (~BITS_REG_FREQ_L_V1_8814B))
#define BIT_GET_REG_FREQ_L_V1_8814B(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L_V1_8814B) & BIT_MASK_REG_FREQ_L_V1_8814B)
#define BIT_SET_REG_FREQ_L_V1_8814B(x, v) \
(BIT_CLEAR_REG_FREQ_L_V1_8814B(x) | BIT_REG_FREQ_L_V1_8814B(v))
#define BIT_EN_DUTY_8814B BIT(19)
#define BIT_SHIFT_REG_MOS_HALF_8814B 17
#define BIT_MASK_REG_MOS_HALF_8814B 0x3
#define BIT_REG_MOS_HALF_8814B(x) \
(((x) & BIT_MASK_REG_MOS_HALF_8814B) << BIT_SHIFT_REG_MOS_HALF_8814B)
#define BITS_REG_MOS_HALF_8814B \
(BIT_MASK_REG_MOS_HALF_8814B << BIT_SHIFT_REG_MOS_HALF_8814B)
#define BIT_CLEAR_REG_MOS_HALF_8814B(x) ((x) & (~BITS_REG_MOS_HALF_8814B))
#define BIT_GET_REG_MOS_HALF_8814B(x) \
(((x) >> BIT_SHIFT_REG_MOS_HALF_8814B) & BIT_MASK_REG_MOS_HALF_8814B)
#define BIT_SET_REG_MOS_HALF_8814B(x, v) \
(BIT_CLEAR_REG_MOS_HALF_8814B(x) | BIT_REG_MOS_HALF_8814B(v))
#define BIT_EN_SP_8814B BIT(16)
#define BIT_REG_AUTO_L_V1_8814B BIT(15)
#define BIT_REG_LDOF_L_V2_8814B BIT(14)
#define BIT_REG_OCPS_L_V2_8814B BIT(13)
/* 2 REG_NOT_VALID_8814B */
#define BIT_ARENB_L_V1_8814B BIT(11)
#define BIT_SHIFT_TBOX_L1_1_0_8814B 9
#define BIT_MASK_TBOX_L1_1_0_8814B 0x3
#define BIT_TBOX_L1_1_0_8814B(x) \
(((x) & BIT_MASK_TBOX_L1_1_0_8814B) << BIT_SHIFT_TBOX_L1_1_0_8814B)
#define BITS_TBOX_L1_1_0_8814B \
(BIT_MASK_TBOX_L1_1_0_8814B << BIT_SHIFT_TBOX_L1_1_0_8814B)
#define BIT_CLEAR_TBOX_L1_1_0_8814B(x) ((x) & (~BITS_TBOX_L1_1_0_8814B))
#define BIT_GET_TBOX_L1_1_0_8814B(x) \
(((x) >> BIT_SHIFT_TBOX_L1_1_0_8814B) & BIT_MASK_TBOX_L1_1_0_8814B)
#define BIT_SET_TBOX_L1_1_0_8814B(x, v) \
(BIT_CLEAR_TBOX_L1_1_0_8814B(x) | BIT_TBOX_L1_1_0_8814B(v))
#define BIT_SHIFT_REG_DELAY_L_1_0_8814B 7
#define BIT_MASK_REG_DELAY_L_1_0_8814B 0x3
#define BIT_REG_DELAY_L_1_0_8814B(x) \
(((x) & BIT_MASK_REG_DELAY_L_1_0_8814B) \
<< BIT_SHIFT_REG_DELAY_L_1_0_8814B)
#define BITS_REG_DELAY_L_1_0_8814B \
(BIT_MASK_REG_DELAY_L_1_0_8814B << BIT_SHIFT_REG_DELAY_L_1_0_8814B)
#define BIT_CLEAR_REG_DELAY_L_1_0_8814B(x) ((x) & (~BITS_REG_DELAY_L_1_0_8814B))
#define BIT_GET_REG_DELAY_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_REG_DELAY_L_1_0_8814B) & \
BIT_MASK_REG_DELAY_L_1_0_8814B)
#define BIT_SET_REG_DELAY_L_1_0_8814B(x, v) \
(BIT_CLEAR_REG_DELAY_L_1_0_8814B(x) | BIT_REG_DELAY_L_1_0_8814B(v))
#define BIT_REG_CLAMP_D_L_8814B BIT(6)
#define BIT_REG_BYPASS_L_V1_8814B BIT(5)
#define BIT_REG_AUTOZCD_L_8814B BIT(4)
#define BIT_POW_ZCD_L_V1_8814B BIT(3)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_OCP_L_2_1_8814B 0
#define BIT_MASK_OCP_L_2_1_8814B 0x3
#define BIT_OCP_L_2_1_8814B(x) \
(((x) & BIT_MASK_OCP_L_2_1_8814B) << BIT_SHIFT_OCP_L_2_1_8814B)
#define BITS_OCP_L_2_1_8814B \
(BIT_MASK_OCP_L_2_1_8814B << BIT_SHIFT_OCP_L_2_1_8814B)
#define BIT_CLEAR_OCP_L_2_1_8814B(x) ((x) & (~BITS_OCP_L_2_1_8814B))
#define BIT_GET_OCP_L_2_1_8814B(x) \
(((x) >> BIT_SHIFT_OCP_L_2_1_8814B) & BIT_MASK_OCP_L_2_1_8814B)
#define BIT_SET_OCP_L_2_1_8814B(x, v) \
(BIT_CLEAR_OCP_L_2_1_8814B(x) | BIT_OCP_L_2_1_8814B(v))
/* 2 REG_ANAPAR_MAC_0_8814B */
#define BIT_SHIFT_LPF_C2_1_0_8814B 30
#define BIT_MASK_LPF_C2_1_0_8814B 0x3
#define BIT_LPF_C2_1_0_8814B(x) \
(((x) & BIT_MASK_LPF_C2_1_0_8814B) << BIT_SHIFT_LPF_C2_1_0_8814B)
#define BITS_LPF_C2_1_0_8814B \
(BIT_MASK_LPF_C2_1_0_8814B << BIT_SHIFT_LPF_C2_1_0_8814B)
#define BIT_CLEAR_LPF_C2_1_0_8814B(x) ((x) & (~BITS_LPF_C2_1_0_8814B))
#define BIT_GET_LPF_C2_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LPF_C2_1_0_8814B) & BIT_MASK_LPF_C2_1_0_8814B)
#define BIT_SET_LPF_C2_1_0_8814B(x, v) \
(BIT_CLEAR_LPF_C2_1_0_8814B(x) | BIT_LPF_C2_1_0_8814B(v))
#define BIT_SHIFT_LPF_C1_5_0_8814B 24
#define BIT_MASK_LPF_C1_5_0_8814B 0x3f
#define BIT_LPF_C1_5_0_8814B(x) \
(((x) & BIT_MASK_LPF_C1_5_0_8814B) << BIT_SHIFT_LPF_C1_5_0_8814B)
#define BITS_LPF_C1_5_0_8814B \
(BIT_MASK_LPF_C1_5_0_8814B << BIT_SHIFT_LPF_C1_5_0_8814B)
#define BIT_CLEAR_LPF_C1_5_0_8814B(x) ((x) & (~BITS_LPF_C1_5_0_8814B))
#define BIT_GET_LPF_C1_5_0_8814B(x) \
(((x) >> BIT_SHIFT_LPF_C1_5_0_8814B) & BIT_MASK_LPF_C1_5_0_8814B)
#define BIT_SET_LPF_C1_5_0_8814B(x, v) \
(BIT_CLEAR_LPF_C1_5_0_8814B(x) | BIT_LPF_C1_5_0_8814B(v))
#define BIT_LPF_TIEL_8814B BIT(23)
#define BIT_LPF_TIEH_8814B BIT(22)
#define BIT_SHIFT_LOCKDET_VREF_L_1_0_8814B 20
#define BIT_MASK_LOCKDET_VREF_L_1_0_8814B 0x3
#define BIT_LOCKDET_VREF_L_1_0_8814B(x) \
(((x) & BIT_MASK_LOCKDET_VREF_L_1_0_8814B) \
<< BIT_SHIFT_LOCKDET_VREF_L_1_0_8814B)
#define BITS_LOCKDET_VREF_L_1_0_8814B \
(BIT_MASK_LOCKDET_VREF_L_1_0_8814B \
<< BIT_SHIFT_LOCKDET_VREF_L_1_0_8814B)
#define BIT_CLEAR_LOCKDET_VREF_L_1_0_8814B(x) \
((x) & (~BITS_LOCKDET_VREF_L_1_0_8814B))
#define BIT_GET_LOCKDET_VREF_L_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LOCKDET_VREF_L_1_0_8814B) & \
BIT_MASK_LOCKDET_VREF_L_1_0_8814B)
#define BIT_SET_LOCKDET_VREF_L_1_0_8814B(x, v) \
(BIT_CLEAR_LOCKDET_VREF_L_1_0_8814B(x) | \
BIT_LOCKDET_VREF_L_1_0_8814B(v))
#define BIT_SHIFT_LOCKDET_VREF_H_1_0_8814B 18
#define BIT_MASK_LOCKDET_VREF_H_1_0_8814B 0x3
#define BIT_LOCKDET_VREF_H_1_0_8814B(x) \
(((x) & BIT_MASK_LOCKDET_VREF_H_1_0_8814B) \
<< BIT_SHIFT_LOCKDET_VREF_H_1_0_8814B)
#define BITS_LOCKDET_VREF_H_1_0_8814B \
(BIT_MASK_LOCKDET_VREF_H_1_0_8814B \
<< BIT_SHIFT_LOCKDET_VREF_H_1_0_8814B)
#define BIT_CLEAR_LOCKDET_VREF_H_1_0_8814B(x) \
((x) & (~BITS_LOCKDET_VREF_H_1_0_8814B))
#define BIT_GET_LOCKDET_VREF_H_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LOCKDET_VREF_H_1_0_8814B) & \
BIT_MASK_LOCKDET_VREF_H_1_0_8814B)
#define BIT_SET_LOCKDET_VREF_H_1_0_8814B(x, v) \
(BIT_CLEAR_LOCKDET_VREF_H_1_0_8814B(x) | \
BIT_LOCKDET_VREF_H_1_0_8814B(v))
#define BIT_SHIFT_LDO_SEL_1_0_8814B 16
#define BIT_MASK_LDO_SEL_1_0_8814B 0x3
#define BIT_LDO_SEL_1_0_8814B(x) \
(((x) & BIT_MASK_LDO_SEL_1_0_8814B) << BIT_SHIFT_LDO_SEL_1_0_8814B)
#define BITS_LDO_SEL_1_0_8814B \
(BIT_MASK_LDO_SEL_1_0_8814B << BIT_SHIFT_LDO_SEL_1_0_8814B)
#define BIT_CLEAR_LDO_SEL_1_0_8814B(x) ((x) & (~BITS_LDO_SEL_1_0_8814B))
#define BIT_GET_LDO_SEL_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LDO_SEL_1_0_8814B) & BIT_MASK_LDO_SEL_1_0_8814B)
#define BIT_SET_LDO_SEL_1_0_8814B(x, v) \
(BIT_CLEAR_LDO_SEL_1_0_8814B(x) | BIT_LDO_SEL_1_0_8814B(v))
#define BIT_SHIFT_IOFFSET_5_0_8814B 10
#define BIT_MASK_IOFFSET_5_0_8814B 0x3f
#define BIT_IOFFSET_5_0_8814B(x) \
(((x) & BIT_MASK_IOFFSET_5_0_8814B) << BIT_SHIFT_IOFFSET_5_0_8814B)
#define BITS_IOFFSET_5_0_8814B \
(BIT_MASK_IOFFSET_5_0_8814B << BIT_SHIFT_IOFFSET_5_0_8814B)
#define BIT_CLEAR_IOFFSET_5_0_8814B(x) ((x) & (~BITS_IOFFSET_5_0_8814B))
#define BIT_GET_IOFFSET_5_0_8814B(x) \
(((x) >> BIT_SHIFT_IOFFSET_5_0_8814B) & BIT_MASK_IOFFSET_5_0_8814B)
#define BIT_SET_IOFFSET_5_0_8814B(x, v) \
(BIT_CLEAR_IOFFSET_5_0_8814B(x) | BIT_IOFFSET_5_0_8814B(v))
#define BIT_CP_ICPX2_8814B BIT(9)
#define BIT_SHIFT_CP_ICP_SEL_4_0_8814B 4
#define BIT_MASK_CP_ICP_SEL_4_0_8814B 0x1f
#define BIT_CP_ICP_SEL_4_0_8814B(x) \
(((x) & BIT_MASK_CP_ICP_SEL_4_0_8814B) \
<< BIT_SHIFT_CP_ICP_SEL_4_0_8814B)
#define BITS_CP_ICP_SEL_4_0_8814B \
(BIT_MASK_CP_ICP_SEL_4_0_8814B << BIT_SHIFT_CP_ICP_SEL_4_0_8814B)
#define BIT_CLEAR_CP_ICP_SEL_4_0_8814B(x) ((x) & (~BITS_CP_ICP_SEL_4_0_8814B))
#define BIT_GET_CP_ICP_SEL_4_0_8814B(x) \
(((x) >> BIT_SHIFT_CP_ICP_SEL_4_0_8814B) & \
BIT_MASK_CP_ICP_SEL_4_0_8814B)
#define BIT_SET_CP_ICP_SEL_4_0_8814B(x, v) \
(BIT_CLEAR_CP_ICP_SEL_4_0_8814B(x) | BIT_CP_ICP_SEL_4_0_8814B(v))
#define BIT_SHIFT_IB_PI_1_0_8814B 2
#define BIT_MASK_IB_PI_1_0_8814B 0x3
#define BIT_IB_PI_1_0_8814B(x) \
(((x) & BIT_MASK_IB_PI_1_0_8814B) << BIT_SHIFT_IB_PI_1_0_8814B)
#define BITS_IB_PI_1_0_8814B \
(BIT_MASK_IB_PI_1_0_8814B << BIT_SHIFT_IB_PI_1_0_8814B)
#define BIT_CLEAR_IB_PI_1_0_8814B(x) ((x) & (~BITS_IB_PI_1_0_8814B))
#define BIT_GET_IB_PI_1_0_8814B(x) \
(((x) >> BIT_SHIFT_IB_PI_1_0_8814B) & BIT_MASK_IB_PI_1_0_8814B)
#define BIT_SET_IB_PI_1_0_8814B(x, v) \
(BIT_CLEAR_IB_PI_1_0_8814B(x) | BIT_IB_PI_1_0_8814B(v))
#define BIT_SHIFT_LDO_VSEL_8814B 0
#define BIT_MASK_LDO_VSEL_8814B 0x3
#define BIT_LDO_VSEL_8814B(x) \
(((x) & BIT_MASK_LDO_VSEL_8814B) << BIT_SHIFT_LDO_VSEL_8814B)
#define BITS_LDO_VSEL_8814B \
(BIT_MASK_LDO_VSEL_8814B << BIT_SHIFT_LDO_VSEL_8814B)
#define BIT_CLEAR_LDO_VSEL_8814B(x) ((x) & (~BITS_LDO_VSEL_8814B))
#define BIT_GET_LDO_VSEL_8814B(x) \
(((x) >> BIT_SHIFT_LDO_VSEL_8814B) & BIT_MASK_LDO_VSEL_8814B)
#define BIT_SET_LDO_VSEL_8814B(x, v) \
(BIT_CLEAR_LDO_VSEL_8814B(x) | BIT_LDO_VSEL_8814B(v))
/* 2 REG_ANAPAR_MAC_1_8814B */
#define BIT_SHIFT_CKX_USB_IB_SEL_8814B 29
#define BIT_MASK_CKX_USB_IB_SEL_8814B 0x7
#define BIT_CKX_USB_IB_SEL_8814B(x) \
(((x) & BIT_MASK_CKX_USB_IB_SEL_8814B) \
<< BIT_SHIFT_CKX_USB_IB_SEL_8814B)
#define BITS_CKX_USB_IB_SEL_8814B \
(BIT_MASK_CKX_USB_IB_SEL_8814B << BIT_SHIFT_CKX_USB_IB_SEL_8814B)
#define BIT_CLEAR_CKX_USB_IB_SEL_8814B(x) ((x) & (~BITS_CKX_USB_IB_SEL_8814B))
#define BIT_GET_CKX_USB_IB_SEL_8814B(x) \
(((x) >> BIT_SHIFT_CKX_USB_IB_SEL_8814B) & \
BIT_MASK_CKX_USB_IB_SEL_8814B)
#define BIT_SET_CKX_USB_IB_SEL_8814B(x, v) \
(BIT_CLEAR_CKX_USB_IB_SEL_8814B(x) | BIT_CKX_USB_IB_SEL_8814B(v))
#define BIT_PFD_DN_GATED_8814B BIT(28)
#define BIT_PFD_UP_GATED_8814B BIT(27)
#define BIT_PFD_RESET_GATED_8814B BIT(26)
#define BIT_SHIFT_PFD_OUT_DRV_1_0_8814B 24
#define BIT_MASK_PFD_OUT_DRV_1_0_8814B 0x3
#define BIT_PFD_OUT_DRV_1_0_8814B(x) \
(((x) & BIT_MASK_PFD_OUT_DRV_1_0_8814B) \
<< BIT_SHIFT_PFD_OUT_DRV_1_0_8814B)
#define BITS_PFD_OUT_DRV_1_0_8814B \
(BIT_MASK_PFD_OUT_DRV_1_0_8814B << BIT_SHIFT_PFD_OUT_DRV_1_0_8814B)
#define BIT_CLEAR_PFD_OUT_DRV_1_0_8814B(x) ((x) & (~BITS_PFD_OUT_DRV_1_0_8814B))
#define BIT_GET_PFD_OUT_DRV_1_0_8814B(x) \
(((x) >> BIT_SHIFT_PFD_OUT_DRV_1_0_8814B) & \
BIT_MASK_PFD_OUT_DRV_1_0_8814B)
#define BIT_SET_PFD_OUT_DRV_1_0_8814B(x, v) \
(BIT_CLEAR_PFD_OUT_DRV_1_0_8814B(x) | BIT_PFD_OUT_DRV_1_0_8814B(v))
#define BIT_SHIFT_LPF_TIEMID_2_0_8814B 20
#define BIT_MASK_LPF_TIEMID_2_0_8814B 0x7
#define BIT_LPF_TIEMID_2_0_8814B(x) \
(((x) & BIT_MASK_LPF_TIEMID_2_0_8814B) \
<< BIT_SHIFT_LPF_TIEMID_2_0_8814B)
#define BITS_LPF_TIEMID_2_0_8814B \
(BIT_MASK_LPF_TIEMID_2_0_8814B << BIT_SHIFT_LPF_TIEMID_2_0_8814B)
#define BIT_CLEAR_LPF_TIEMID_2_0_8814B(x) ((x) & (~BITS_LPF_TIEMID_2_0_8814B))
#define BIT_GET_LPF_TIEMID_2_0_8814B(x) \
(((x) >> BIT_SHIFT_LPF_TIEMID_2_0_8814B) & \
BIT_MASK_LPF_TIEMID_2_0_8814B)
#define BIT_SET_LPF_TIEMID_2_0_8814B(x, v) \
(BIT_CLEAR_LPF_TIEMID_2_0_8814B(x) | BIT_LPF_TIEMID_2_0_8814B(v))
#define BIT_SHIFT_LPF_R3_4_0_8814B 15
#define BIT_MASK_LPF_R3_4_0_8814B 0x1f
#define BIT_LPF_R3_4_0_8814B(x) \
(((x) & BIT_MASK_LPF_R3_4_0_8814B) << BIT_SHIFT_LPF_R3_4_0_8814B)
#define BITS_LPF_R3_4_0_8814B \
(BIT_MASK_LPF_R3_4_0_8814B << BIT_SHIFT_LPF_R3_4_0_8814B)
#define BIT_CLEAR_LPF_R3_4_0_8814B(x) ((x) & (~BITS_LPF_R3_4_0_8814B))
#define BIT_GET_LPF_R3_4_0_8814B(x) \
(((x) >> BIT_SHIFT_LPF_R3_4_0_8814B) & BIT_MASK_LPF_R3_4_0_8814B)
#define BIT_SET_LPF_R3_4_0_8814B(x, v) \
(BIT_CLEAR_LPF_R3_4_0_8814B(x) | BIT_LPF_R3_4_0_8814B(v))
#define BIT_SHIFT_LPF_R2_4_0_8814B 10
#define BIT_MASK_LPF_R2_4_0_8814B 0x1f
#define BIT_LPF_R2_4_0_8814B(x) \
(((x) & BIT_MASK_LPF_R2_4_0_8814B) << BIT_SHIFT_LPF_R2_4_0_8814B)
#define BITS_LPF_R2_4_0_8814B \
(BIT_MASK_LPF_R2_4_0_8814B << BIT_SHIFT_LPF_R2_4_0_8814B)
#define BIT_CLEAR_LPF_R2_4_0_8814B(x) ((x) & (~BITS_LPF_R2_4_0_8814B))
#define BIT_GET_LPF_R2_4_0_8814B(x) \
(((x) >> BIT_SHIFT_LPF_R2_4_0_8814B) & BIT_MASK_LPF_R2_4_0_8814B)
#define BIT_SET_LPF_R2_4_0_8814B(x, v) \
(BIT_CLEAR_LPF_R2_4_0_8814B(x) | BIT_LPF_R2_4_0_8814B(v))
#define BIT_SHIFT_LPF_C3_5_0_8814B 4
#define BIT_MASK_LPF_C3_5_0_8814B 0x3f
#define BIT_LPF_C3_5_0_8814B(x) \
(((x) & BIT_MASK_LPF_C3_5_0_8814B) << BIT_SHIFT_LPF_C3_5_0_8814B)
#define BITS_LPF_C3_5_0_8814B \
(BIT_MASK_LPF_C3_5_0_8814B << BIT_SHIFT_LPF_C3_5_0_8814B)
#define BIT_CLEAR_LPF_C3_5_0_8814B(x) ((x) & (~BITS_LPF_C3_5_0_8814B))
#define BIT_GET_LPF_C3_5_0_8814B(x) \
(((x) >> BIT_SHIFT_LPF_C3_5_0_8814B) & BIT_MASK_LPF_C3_5_0_8814B)
#define BIT_SET_LPF_C3_5_0_8814B(x, v) \
(BIT_CLEAR_LPF_C3_5_0_8814B(x) | BIT_LPF_C3_5_0_8814B(v))
#define BIT_SHIFT_LPF_C2_5_2_8814B 0
#define BIT_MASK_LPF_C2_5_2_8814B 0xf
#define BIT_LPF_C2_5_2_8814B(x) \
(((x) & BIT_MASK_LPF_C2_5_2_8814B) << BIT_SHIFT_LPF_C2_5_2_8814B)
#define BITS_LPF_C2_5_2_8814B \
(BIT_MASK_LPF_C2_5_2_8814B << BIT_SHIFT_LPF_C2_5_2_8814B)
#define BIT_CLEAR_LPF_C2_5_2_8814B(x) ((x) & (~BITS_LPF_C2_5_2_8814B))
#define BIT_GET_LPF_C2_5_2_8814B(x) \
(((x) >> BIT_SHIFT_LPF_C2_5_2_8814B) & BIT_MASK_LPF_C2_5_2_8814B)
#define BIT_SET_LPF_C2_5_2_8814B(x, v) \
(BIT_CLEAR_LPF_C2_5_2_8814B(x) | BIT_LPF_C2_5_2_8814B(v))
/* 2 REG_ANAPAR_MAC_2_8814B */
#define BIT_CK_PHASE_SEL_8814B BIT(31)
#define BIT_CK960M_EN_8814B BIT(30)
#define BIT_CK640M_EN_8814B BIT(29)
#define BIT_CK240M_EN_8814B BIT(28)
#define BIT_SHIFT_CK_MON_SEL_2_0_8814B 25
#define BIT_MASK_CK_MON_SEL_2_0_8814B 0x7
#define BIT_CK_MON_SEL_2_0_8814B(x) \
(((x) & BIT_MASK_CK_MON_SEL_2_0_8814B) \
<< BIT_SHIFT_CK_MON_SEL_2_0_8814B)
#define BITS_CK_MON_SEL_2_0_8814B \
(BIT_MASK_CK_MON_SEL_2_0_8814B << BIT_SHIFT_CK_MON_SEL_2_0_8814B)
#define BIT_CLEAR_CK_MON_SEL_2_0_8814B(x) ((x) & (~BITS_CK_MON_SEL_2_0_8814B))
#define BIT_GET_CK_MON_SEL_2_0_8814B(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL_2_0_8814B) & \
BIT_MASK_CK_MON_SEL_2_0_8814B)
#define BIT_SET_CK_MON_SEL_2_0_8814B(x, v) \
(BIT_CLEAR_CK_MON_SEL_2_0_8814B(x) | BIT_CK_MON_SEL_2_0_8814B(v))
#define BIT_CK_MON_EN_V1_8814B BIT(24)
#define BIT_XTAL_SOURCE_SEL_8814B BIT(23)
#define BIT_XTAL_FREQ_SEL_8814B BIT(22)
#define BIT_XTAL_EDGE_SEL_8814B BIT(21)
#define BIT_XTAL_BUF_SEL_8814B BIT(20)
#define BIT_SHIFT_VCO_CV_7_0_8814B 4
#define BIT_MASK_VCO_CV_7_0_8814B 0xff
#define BIT_VCO_CV_7_0_8814B(x) \
(((x) & BIT_MASK_VCO_CV_7_0_8814B) << BIT_SHIFT_VCO_CV_7_0_8814B)
#define BITS_VCO_CV_7_0_8814B \
(BIT_MASK_VCO_CV_7_0_8814B << BIT_SHIFT_VCO_CV_7_0_8814B)
#define BIT_CLEAR_VCO_CV_7_0_8814B(x) ((x) & (~BITS_VCO_CV_7_0_8814B))
#define BIT_GET_VCO_CV_7_0_8814B(x) \
(((x) >> BIT_SHIFT_VCO_CV_7_0_8814B) & BIT_MASK_VCO_CV_7_0_8814B)
#define BIT_SET_VCO_CV_7_0_8814B(x, v) \
(BIT_CLEAR_VCO_CV_7_0_8814B(x) | BIT_VCO_CV_7_0_8814B(v))
#define BIT_VCO_KVCO_8814B BIT(3)
#define BIT_SDM_EDGE_SEL_8814B BIT(2)
#define BIT_SDM_CK_SEL_8814B BIT(1)
#define BIT_SDM_CK_GATED_8814B BIT(0)
/* 2 REG_ANAPAR_MAC_3_8814B */
#define BIT_SHIFT_LCK_WAIT_CYCLE_2_0_8814B 28
#define BIT_MASK_LCK_WAIT_CYCLE_2_0_8814B 0x7
#define BIT_LCK_WAIT_CYCLE_2_0_8814B(x) \
(((x) & BIT_MASK_LCK_WAIT_CYCLE_2_0_8814B) \
<< BIT_SHIFT_LCK_WAIT_CYCLE_2_0_8814B)
#define BITS_LCK_WAIT_CYCLE_2_0_8814B \
(BIT_MASK_LCK_WAIT_CYCLE_2_0_8814B \
<< BIT_SHIFT_LCK_WAIT_CYCLE_2_0_8814B)
#define BIT_CLEAR_LCK_WAIT_CYCLE_2_0_8814B(x) \
((x) & (~BITS_LCK_WAIT_CYCLE_2_0_8814B))
#define BIT_GET_LCK_WAIT_CYCLE_2_0_8814B(x) \
(((x) >> BIT_SHIFT_LCK_WAIT_CYCLE_2_0_8814B) & \
BIT_MASK_LCK_WAIT_CYCLE_2_0_8814B)
#define BIT_SET_LCK_WAIT_CYCLE_2_0_8814B(x, v) \
(BIT_CLEAR_LCK_WAIT_CYCLE_2_0_8814B(x) | \
BIT_LCK_WAIT_CYCLE_2_0_8814B(v))
#define BIT_SHIFT_LCK_VCO_DIVISOR_1_0_8814B 26
#define BIT_MASK_LCK_VCO_DIVISOR_1_0_8814B 0x3
#define BIT_LCK_VCO_DIVISOR_1_0_8814B(x) \
(((x) & BIT_MASK_LCK_VCO_DIVISOR_1_0_8814B) \
<< BIT_SHIFT_LCK_VCO_DIVISOR_1_0_8814B)
#define BITS_LCK_VCO_DIVISOR_1_0_8814B \
(BIT_MASK_LCK_VCO_DIVISOR_1_0_8814B \
<< BIT_SHIFT_LCK_VCO_DIVISOR_1_0_8814B)
#define BIT_CLEAR_LCK_VCO_DIVISOR_1_0_8814B(x) \
((x) & (~BITS_LCK_VCO_DIVISOR_1_0_8814B))
#define BIT_GET_LCK_VCO_DIVISOR_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LCK_VCO_DIVISOR_1_0_8814B) & \
BIT_MASK_LCK_VCO_DIVISOR_1_0_8814B)
#define BIT_SET_LCK_VCO_DIVISOR_1_0_8814B(x, v) \
(BIT_CLEAR_LCK_VCO_DIVISOR_1_0_8814B(x) | \
BIT_LCK_VCO_DIVISOR_1_0_8814B(v))
#define BIT_SHIFT_LCK_SEARCH_MODE_1_0_8814B 24
#define BIT_MASK_LCK_SEARCH_MODE_1_0_8814B 0x3
#define BIT_LCK_SEARCH_MODE_1_0_8814B(x) \
(((x) & BIT_MASK_LCK_SEARCH_MODE_1_0_8814B) \
<< BIT_SHIFT_LCK_SEARCH_MODE_1_0_8814B)
#define BITS_LCK_SEARCH_MODE_1_0_8814B \
(BIT_MASK_LCK_SEARCH_MODE_1_0_8814B \
<< BIT_SHIFT_LCK_SEARCH_MODE_1_0_8814B)
#define BIT_CLEAR_LCK_SEARCH_MODE_1_0_8814B(x) \
((x) & (~BITS_LCK_SEARCH_MODE_1_0_8814B))
#define BIT_GET_LCK_SEARCH_MODE_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LCK_SEARCH_MODE_1_0_8814B) & \
BIT_MASK_LCK_SEARCH_MODE_1_0_8814B)
#define BIT_SET_LCK_SEARCH_MODE_1_0_8814B(x, v) \
(BIT_CLEAR_LCK_SEARCH_MODE_1_0_8814B(x) | \
BIT_LCK_SEARCH_MODE_1_0_8814B(v))
#define BIT_SHIFT_LS_CV_OFFSET_3_0_8814B 12
#define BIT_MASK_LS_CV_OFFSET_3_0_8814B 0xf
#define BIT_LS_CV_OFFSET_3_0_8814B(x) \
(((x) & BIT_MASK_LS_CV_OFFSET_3_0_8814B) \
<< BIT_SHIFT_LS_CV_OFFSET_3_0_8814B)
#define BITS_LS_CV_OFFSET_3_0_8814B \
(BIT_MASK_LS_CV_OFFSET_3_0_8814B << BIT_SHIFT_LS_CV_OFFSET_3_0_8814B)
#define BIT_CLEAR_LS_CV_OFFSET_3_0_8814B(x) \
((x) & (~BITS_LS_CV_OFFSET_3_0_8814B))
#define BIT_GET_LS_CV_OFFSET_3_0_8814B(x) \
(((x) >> BIT_SHIFT_LS_CV_OFFSET_3_0_8814B) & \
BIT_MASK_LS_CV_OFFSET_3_0_8814B)
#define BIT_SET_LS_CV_OFFSET_3_0_8814B(x, v) \
(BIT_CLEAR_LS_CV_OFFSET_3_0_8814B(x) | BIT_LS_CV_OFFSET_3_0_8814B(v))
#define BIT_LS_EN_LC_CK40M_8814B BIT(11)
#define BIT_LS__CV_MANUAL_8814B BIT(10)
#define BIT_LS_PYPASS_PI_8814B BIT(9)
#define BIT_MBIASE_8814B BIT(4)
/* 2 REG_ANAPAR_MAC_4_8814B */
#define BIT_LS_TIE_MID_MODE_8814B BIT(28)
#define BIT_SHIFT_LS_SYNC_CYCLE_1_0_8814B 26
#define BIT_MASK_LS_SYNC_CYCLE_1_0_8814B 0x3
#define BIT_LS_SYNC_CYCLE_1_0_8814B(x) \
(((x) & BIT_MASK_LS_SYNC_CYCLE_1_0_8814B) \
<< BIT_SHIFT_LS_SYNC_CYCLE_1_0_8814B)
#define BITS_LS_SYNC_CYCLE_1_0_8814B \
(BIT_MASK_LS_SYNC_CYCLE_1_0_8814B << BIT_SHIFT_LS_SYNC_CYCLE_1_0_8814B)
#define BIT_CLEAR_LS_SYNC_CYCLE_1_0_8814B(x) \
((x) & (~BITS_LS_SYNC_CYCLE_1_0_8814B))
#define BIT_GET_LS_SYNC_CYCLE_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LS_SYNC_CYCLE_1_0_8814B) & \
BIT_MASK_LS_SYNC_CYCLE_1_0_8814B)
#define BIT_SET_LS_SYNC_CYCLE_1_0_8814B(x, v) \
(BIT_CLEAR_LS_SYNC_CYCLE_1_0_8814B(x) | BIT_LS_SYNC_CYCLE_1_0_8814B(v))
#define BIT_LS_SDM_ORDER_8814B BIT(25)
#define BIT_LS_RST_LC_CAL_8814B BIT(14)
#define BIT_LS_RSTB_8814B BIT(13)
#define BIT_LS_POW_LC_CAL_PREP_8814B BIT(11)
#define BIT_SHIFT_LCK_XTAL_DIVISOR_1_0_8814B 0
#define BIT_MASK_LCK_XTAL_DIVISOR_1_0_8814B 0x3
#define BIT_LCK_XTAL_DIVISOR_1_0_8814B(x) \
(((x) & BIT_MASK_LCK_XTAL_DIVISOR_1_0_8814B) \
<< BIT_SHIFT_LCK_XTAL_DIVISOR_1_0_8814B)
#define BITS_LCK_XTAL_DIVISOR_1_0_8814B \
(BIT_MASK_LCK_XTAL_DIVISOR_1_0_8814B \
<< BIT_SHIFT_LCK_XTAL_DIVISOR_1_0_8814B)
#define BIT_CLEAR_LCK_XTAL_DIVISOR_1_0_8814B(x) \
((x) & (~BITS_LCK_XTAL_DIVISOR_1_0_8814B))
#define BIT_GET_LCK_XTAL_DIVISOR_1_0_8814B(x) \
(((x) >> BIT_SHIFT_LCK_XTAL_DIVISOR_1_0_8814B) & \
BIT_MASK_LCK_XTAL_DIVISOR_1_0_8814B)
#define BIT_SET_LCK_XTAL_DIVISOR_1_0_8814B(x, v) \
(BIT_CLEAR_LCK_XTAL_DIVISOR_1_0_8814B(x) | \
BIT_LCK_XTAL_DIVISOR_1_0_8814B(v))
/* 2 REG_ANAPAR_MAC_5_8814B */
#define BIT_SHIFT_LS_XTAL_SEL_3_0_8814B 0
#define BIT_MASK_LS_XTAL_SEL_3_0_8814B 0xf
#define BIT_LS_XTAL_SEL_3_0_8814B(x) \
(((x) & BIT_MASK_LS_XTAL_SEL_3_0_8814B) \
<< BIT_SHIFT_LS_XTAL_SEL_3_0_8814B)
#define BITS_LS_XTAL_SEL_3_0_8814B \
(BIT_MASK_LS_XTAL_SEL_3_0_8814B << BIT_SHIFT_LS_XTAL_SEL_3_0_8814B)
#define BIT_CLEAR_LS_XTAL_SEL_3_0_8814B(x) ((x) & (~BITS_LS_XTAL_SEL_3_0_8814B))
#define BIT_GET_LS_XTAL_SEL_3_0_8814B(x) \
(((x) >> BIT_SHIFT_LS_XTAL_SEL_3_0_8814B) & \
BIT_MASK_LS_XTAL_SEL_3_0_8814B)
#define BIT_SET_LS_XTAL_SEL_3_0_8814B(x, v) \
(BIT_CLEAR_LS_XTAL_SEL_3_0_8814B(x) | BIT_LS_XTAL_SEL_3_0_8814B(v))
/* 2 REG_ANAPAR_MAC_6_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ANAPAR_MAC_7_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ANAPAR_MAC_8_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ANAPAR_XTAL_0_8814B */
#define BIT_XTAL_DRV_RF1_0_8814B BIT(31)
#define BIT_XTAL_GATED_RF1N_8814B BIT(30)
#define BIT_XTAL_GATED_RF1P_8814B BIT(29)
#define BIT_XTAL_GM_SEP_V2_8814B BIT(28)
#define BIT_SHIFT_XTAL_LDO_1_0_8814B 26
#define BIT_MASK_XTAL_LDO_1_0_8814B 0x3
#define BIT_XTAL_LDO_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_LDO_1_0_8814B) << BIT_SHIFT_XTAL_LDO_1_0_8814B)
#define BITS_XTAL_LDO_1_0_8814B \
(BIT_MASK_XTAL_LDO_1_0_8814B << BIT_SHIFT_XTAL_LDO_1_0_8814B)
#define BIT_CLEAR_XTAL_LDO_1_0_8814B(x) ((x) & (~BITS_XTAL_LDO_1_0_8814B))
#define BIT_GET_XTAL_LDO_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_1_0_8814B) & BIT_MASK_XTAL_LDO_1_0_8814B)
#define BIT_SET_XTAL_LDO_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_LDO_1_0_8814B(x) | BIT_XTAL_LDO_1_0_8814B(v))
#define BIT_XQSEL_V1_8814B BIT(25)
#define BIT_GATED_XTAL_OK0_8814B BIT(24)
#define BIT_SHIFT_XTAL_SC_XO_6_0_8814B 17
#define BIT_MASK_XTAL_SC_XO_6_0_8814B 0x7f
#define BIT_XTAL_SC_XO_6_0_8814B(x) \
(((x) & BIT_MASK_XTAL_SC_XO_6_0_8814B) \
<< BIT_SHIFT_XTAL_SC_XO_6_0_8814B)
#define BITS_XTAL_SC_XO_6_0_8814B \
(BIT_MASK_XTAL_SC_XO_6_0_8814B << BIT_SHIFT_XTAL_SC_XO_6_0_8814B)
#define BIT_CLEAR_XTAL_SC_XO_6_0_8814B(x) ((x) & (~BITS_XTAL_SC_XO_6_0_8814B))
#define BIT_GET_XTAL_SC_XO_6_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XO_6_0_8814B) & \
BIT_MASK_XTAL_SC_XO_6_0_8814B)
#define BIT_SET_XTAL_SC_XO_6_0_8814B(x, v) \
(BIT_CLEAR_XTAL_SC_XO_6_0_8814B(x) | BIT_XTAL_SC_XO_6_0_8814B(v))
#define BIT_SHIFT_XTAL_SC_XI_6_0_8814B 10
#define BIT_MASK_XTAL_SC_XI_6_0_8814B 0x7f
#define BIT_XTAL_SC_XI_6_0_8814B(x) \
(((x) & BIT_MASK_XTAL_SC_XI_6_0_8814B) \
<< BIT_SHIFT_XTAL_SC_XI_6_0_8814B)
#define BITS_XTAL_SC_XI_6_0_8814B \
(BIT_MASK_XTAL_SC_XI_6_0_8814B << BIT_SHIFT_XTAL_SC_XI_6_0_8814B)
#define BIT_CLEAR_XTAL_SC_XI_6_0_8814B(x) ((x) & (~BITS_XTAL_SC_XI_6_0_8814B))
#define BIT_GET_XTAL_SC_XI_6_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XI_6_0_8814B) & \
BIT_MASK_XTAL_SC_XI_6_0_8814B)
#define BIT_SET_XTAL_SC_XI_6_0_8814B(x, v) \
(BIT_CLEAR_XTAL_SC_XI_6_0_8814B(x) | BIT_XTAL_SC_XI_6_0_8814B(v))
#define BIT_SHIFT_XTAL_GMN_4_0_8814B 5
#define BIT_MASK_XTAL_GMN_4_0_8814B 0x1f
#define BIT_XTAL_GMN_4_0_8814B(x) \
(((x) & BIT_MASK_XTAL_GMN_4_0_8814B) << BIT_SHIFT_XTAL_GMN_4_0_8814B)
#define BITS_XTAL_GMN_4_0_8814B \
(BIT_MASK_XTAL_GMN_4_0_8814B << BIT_SHIFT_XTAL_GMN_4_0_8814B)
#define BIT_CLEAR_XTAL_GMN_4_0_8814B(x) ((x) & (~BITS_XTAL_GMN_4_0_8814B))
#define BIT_GET_XTAL_GMN_4_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_4_0_8814B) & BIT_MASK_XTAL_GMN_4_0_8814B)
#define BIT_SET_XTAL_GMN_4_0_8814B(x, v) \
(BIT_CLEAR_XTAL_GMN_4_0_8814B(x) | BIT_XTAL_GMN_4_0_8814B(v))
#define BIT_SHIFT_XTAL_GMP_4_0_8814B 0
#define BIT_MASK_XTAL_GMP_4_0_8814B 0x1f
#define BIT_XTAL_GMP_4_0_8814B(x) \
(((x) & BIT_MASK_XTAL_GMP_4_0_8814B) << BIT_SHIFT_XTAL_GMP_4_0_8814B)
#define BITS_XTAL_GMP_4_0_8814B \
(BIT_MASK_XTAL_GMP_4_0_8814B << BIT_SHIFT_XTAL_GMP_4_0_8814B)
#define BIT_CLEAR_XTAL_GMP_4_0_8814B(x) ((x) & (~BITS_XTAL_GMP_4_0_8814B))
#define BIT_GET_XTAL_GMP_4_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_4_0_8814B) & BIT_MASK_XTAL_GMP_4_0_8814B)
#define BIT_SET_XTAL_GMP_4_0_8814B(x, v) \
(BIT_CLEAR_XTAL_GMP_4_0_8814B(x) | BIT_XTAL_GMP_4_0_8814B(v))
/* 2 REG_ANAPAR_XTAL_1_8814B */
#define BIT_SHIFT_XTAL_LDO_OK_1_0_8814B 30
#define BIT_MASK_XTAL_LDO_OK_1_0_8814B 0x3
#define BIT_XTAL_LDO_OK_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_LDO_OK_1_0_8814B) \
<< BIT_SHIFT_XTAL_LDO_OK_1_0_8814B)
#define BITS_XTAL_LDO_OK_1_0_8814B \
(BIT_MASK_XTAL_LDO_OK_1_0_8814B << BIT_SHIFT_XTAL_LDO_OK_1_0_8814B)
#define BIT_CLEAR_XTAL_LDO_OK_1_0_8814B(x) ((x) & (~BITS_XTAL_LDO_OK_1_0_8814B))
#define BIT_GET_XTAL_LDO_OK_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_OK_1_0_8814B) & \
BIT_MASK_XTAL_LDO_OK_1_0_8814B)
#define BIT_SET_XTAL_LDO_OK_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_LDO_OK_1_0_8814B(x) | BIT_XTAL_LDO_OK_1_0_8814B(v))
#define BIT_SHIFT_XTAL_XORES_SEL_2_0_8814B 27
#define BIT_MASK_XTAL_XORES_SEL_2_0_8814B 0x7
#define BIT_XTAL_XORES_SEL_2_0_8814B(x) \
(((x) & BIT_MASK_XTAL_XORES_SEL_2_0_8814B) \
<< BIT_SHIFT_XTAL_XORES_SEL_2_0_8814B)
#define BITS_XTAL_XORES_SEL_2_0_8814B \
(BIT_MASK_XTAL_XORES_SEL_2_0_8814B \
<< BIT_SHIFT_XTAL_XORES_SEL_2_0_8814B)
#define BIT_CLEAR_XTAL_XORES_SEL_2_0_8814B(x) \
((x) & (~BITS_XTAL_XORES_SEL_2_0_8814B))
#define BIT_GET_XTAL_XORES_SEL_2_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_XORES_SEL_2_0_8814B) & \
BIT_MASK_XTAL_XORES_SEL_2_0_8814B)
#define BIT_SET_XTAL_XORES_SEL_2_0_8814B(x, v) \
(BIT_CLEAR_XTAL_XORES_SEL_2_0_8814B(x) | \
BIT_XTAL_XORES_SEL_2_0_8814B(v))
#define BIT_SHIFT_XTAL_AAC_PK_SEL_1_0_8814B 25
#define BIT_MASK_XTAL_AAC_PK_SEL_1_0_8814B 0x3
#define BIT_XTAL_AAC_PK_SEL_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_AAC_PK_SEL_1_0_8814B) \
<< BIT_SHIFT_XTAL_AAC_PK_SEL_1_0_8814B)
#define BITS_XTAL_AAC_PK_SEL_1_0_8814B \
(BIT_MASK_XTAL_AAC_PK_SEL_1_0_8814B \
<< BIT_SHIFT_XTAL_AAC_PK_SEL_1_0_8814B)
#define BIT_CLEAR_XTAL_AAC_PK_SEL_1_0_8814B(x) \
((x) & (~BITS_XTAL_AAC_PK_SEL_1_0_8814B))
#define BIT_GET_XTAL_AAC_PK_SEL_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_AAC_PK_SEL_1_0_8814B) & \
BIT_MASK_XTAL_AAC_PK_SEL_1_0_8814B)
#define BIT_SET_XTAL_AAC_PK_SEL_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_AAC_PK_SEL_1_0_8814B(x) | \
BIT_XTAL_AAC_PK_SEL_1_0_8814B(v))
#define BIT_EN_XTAL_AAC_PKDET_8814B BIT(24)
#define BIT_EN_XTAL_AAC_GM_8814B BIT(23)
#define BIT_XTAL_LPMODE_8814B BIT(22)
#define BIT_SHIFT_XTAL_SEL_TOK_2_0_8814B 19
#define BIT_MASK_XTAL_SEL_TOK_2_0_8814B 0x7
#define BIT_XTAL_SEL_TOK_2_0_8814B(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_2_0_8814B) \
<< BIT_SHIFT_XTAL_SEL_TOK_2_0_8814B)
#define BITS_XTAL_SEL_TOK_2_0_8814B \
(BIT_MASK_XTAL_SEL_TOK_2_0_8814B << BIT_SHIFT_XTAL_SEL_TOK_2_0_8814B)
#define BIT_CLEAR_XTAL_SEL_TOK_2_0_8814B(x) \
((x) & (~BITS_XTAL_SEL_TOK_2_0_8814B))
#define BIT_GET_XTAL_SEL_TOK_2_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_2_0_8814B) & \
BIT_MASK_XTAL_SEL_TOK_2_0_8814B)
#define BIT_SET_XTAL_SEL_TOK_2_0_8814B(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_2_0_8814B(x) | BIT_XTAL_SEL_TOK_2_0_8814B(v))
#define BIT_XQSEL_RF_AWAKE_V2_8814B BIT(18)
#define BIT_XQSEL_RF_INITIAL_V2_8814B BIT(17)
#define BIT_XTAL_DELAY_USB_V1_8814B BIT(16)
#define BIT_XTAL_DELAY_DIGI_V1_8814B BIT(15)
#define BIT_XTAL_DELAY_AFE_V1_8814B BIT(14)
#define BIT_XTAL_DRV_RF_LATCH_V3_8814B BIT(13)
#define BIT_SHIFT_XTAL_DRV_DIGI_1_0_8814B 11
#define BIT_MASK_XTAL_DRV_DIGI_1_0_8814B 0x3
#define BIT_XTAL_DRV_DIGI_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_1_0_8814B) \
<< BIT_SHIFT_XTAL_DRV_DIGI_1_0_8814B)
#define BITS_XTAL_DRV_DIGI_1_0_8814B \
(BIT_MASK_XTAL_DRV_DIGI_1_0_8814B << BIT_SHIFT_XTAL_DRV_DIGI_1_0_8814B)
#define BIT_CLEAR_XTAL_DRV_DIGI_1_0_8814B(x) \
((x) & (~BITS_XTAL_DRV_DIGI_1_0_8814B))
#define BIT_GET_XTAL_DRV_DIGI_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_1_0_8814B) & \
BIT_MASK_XTAL_DRV_DIGI_1_0_8814B)
#define BIT_SET_XTAL_DRV_DIGI_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_1_0_8814B(x) | BIT_XTAL_DRV_DIGI_1_0_8814B(v))
#define BIT_XTAL_GATED_DIGIN_8814B BIT(10)
#define BIT_XTAL_GATED_DIGIP_8814B BIT(9)
#define BIT_SHIFT_XTAL_DRV_USB_1_0_8814B 7
#define BIT_MASK_XTAL_DRV_USB_1_0_8814B 0x3
#define BIT_XTAL_DRV_USB_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_DRV_USB_1_0_8814B) \
<< BIT_SHIFT_XTAL_DRV_USB_1_0_8814B)
#define BITS_XTAL_DRV_USB_1_0_8814B \
(BIT_MASK_XTAL_DRV_USB_1_0_8814B << BIT_SHIFT_XTAL_DRV_USB_1_0_8814B)
#define BIT_CLEAR_XTAL_DRV_USB_1_0_8814B(x) \
((x) & (~BITS_XTAL_DRV_USB_1_0_8814B))
#define BIT_GET_XTAL_DRV_USB_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_USB_1_0_8814B) & \
BIT_MASK_XTAL_DRV_USB_1_0_8814B)
#define BIT_SET_XTAL_DRV_USB_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_DRV_USB_1_0_8814B(x) | BIT_XTAL_DRV_USB_1_0_8814B(v))
#define BIT_XTAL_GATED_USBN_8814B BIT(6)
#define BIT_XTAL_GATED_USBP_8814B BIT(5)
#define BIT_SHIFT_XTAL_DRV_AFE_1_0_8814B 3
#define BIT_MASK_XTAL_DRV_AFE_1_0_8814B 0x3
#define BIT_XTAL_DRV_AFE_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_1_0_8814B) \
<< BIT_SHIFT_XTAL_DRV_AFE_1_0_8814B)
#define BITS_XTAL_DRV_AFE_1_0_8814B \
(BIT_MASK_XTAL_DRV_AFE_1_0_8814B << BIT_SHIFT_XTAL_DRV_AFE_1_0_8814B)
#define BIT_CLEAR_XTAL_DRV_AFE_1_0_8814B(x) \
((x) & (~BITS_XTAL_DRV_AFE_1_0_8814B))
#define BIT_GET_XTAL_DRV_AFE_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_1_0_8814B) & \
BIT_MASK_XTAL_DRV_AFE_1_0_8814B)
#define BIT_SET_XTAL_DRV_AFE_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_1_0_8814B(x) | BIT_XTAL_DRV_AFE_1_0_8814B(v))
#define BIT_XTAL_GATED_AFEN_8814B BIT(2)
#define BIT_XTAL_GATED_AFEP_8814B BIT(1)
#define BIT_XTAL_DRV_RF1_1_8814B BIT(0)
/* 2 REG_ANAPAR_XTAL_2_8814B */
#define BIT_XTAL_DRV_RF2_LATCH_8814B BIT(6)
#define BIT_SHIFT_XTAL_DRV_RF2_1_0_8814B 4
#define BIT_MASK_XTAL_DRV_RF2_1_0_8814B 0x3
#define BIT_XTAL_DRV_RF2_1_0_8814B(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_1_0_8814B) \
<< BIT_SHIFT_XTAL_DRV_RF2_1_0_8814B)
#define BITS_XTAL_DRV_RF2_1_0_8814B \
(BIT_MASK_XTAL_DRV_RF2_1_0_8814B << BIT_SHIFT_XTAL_DRV_RF2_1_0_8814B)
#define BIT_CLEAR_XTAL_DRV_RF2_1_0_8814B(x) \
((x) & (~BITS_XTAL_DRV_RF2_1_0_8814B))
#define BIT_GET_XTAL_DRV_RF2_1_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_1_0_8814B) & \
BIT_MASK_XTAL_DRV_RF2_1_0_8814B)
#define BIT_SET_XTAL_DRV_RF2_1_0_8814B(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_1_0_8814B(x) | BIT_XTAL_DRV_RF2_1_0_8814B(v))
#define BIT_XTAL_GATED_RF2N_8814B BIT(3)
#define BIT_XTAL_GATED_RF2P_8814B BIT(2)
#define BIT_XTAL_LDO_DI_8814B BIT(1)
#define BIT_XTAL_SEL_PWR_8814B BIT(0)
/* 2 REG_ANAPAR_XTAL_AAC_8814B */
#define BIT_EN_XTAL_AAC_TRIG_8814B BIT(28)
#define BIT_EN_XTAL_AAC_8814B BIT(27)
#define BIT_EN_XTAL_AAC_DIGI_8814B BIT(26)
#define BIT_SHIFT_GM_MANUAL_4_0_8814B 21
#define BIT_MASK_GM_MANUAL_4_0_8814B 0x1f
#define BIT_GM_MANUAL_4_0_8814B(x) \
(((x) & BIT_MASK_GM_MANUAL_4_0_8814B) << BIT_SHIFT_GM_MANUAL_4_0_8814B)
#define BITS_GM_MANUAL_4_0_8814B \
(BIT_MASK_GM_MANUAL_4_0_8814B << BIT_SHIFT_GM_MANUAL_4_0_8814B)
#define BIT_CLEAR_GM_MANUAL_4_0_8814B(x) ((x) & (~BITS_GM_MANUAL_4_0_8814B))
#define BIT_GET_GM_MANUAL_4_0_8814B(x) \
(((x) >> BIT_SHIFT_GM_MANUAL_4_0_8814B) & BIT_MASK_GM_MANUAL_4_0_8814B)
#define BIT_SET_GM_MANUAL_4_0_8814B(x, v) \
(BIT_CLEAR_GM_MANUAL_4_0_8814B(x) | BIT_GM_MANUAL_4_0_8814B(v))
#define BIT_SHIFT_GM_STUP_4_0_8814B 16
#define BIT_MASK_GM_STUP_4_0_8814B 0x1f
#define BIT_GM_STUP_4_0_8814B(x) \
(((x) & BIT_MASK_GM_STUP_4_0_8814B) << BIT_SHIFT_GM_STUP_4_0_8814B)
#define BITS_GM_STUP_4_0_8814B \
(BIT_MASK_GM_STUP_4_0_8814B << BIT_SHIFT_GM_STUP_4_0_8814B)
#define BIT_CLEAR_GM_STUP_4_0_8814B(x) ((x) & (~BITS_GM_STUP_4_0_8814B))
#define BIT_GET_GM_STUP_4_0_8814B(x) \
(((x) >> BIT_SHIFT_GM_STUP_4_0_8814B) & BIT_MASK_GM_STUP_4_0_8814B)
#define BIT_SET_GM_STUP_4_0_8814B(x, v) \
(BIT_CLEAR_GM_STUP_4_0_8814B(x) | BIT_GM_STUP_4_0_8814B(v))
#define BIT_SHIFT_XTAL_CK_SET_2_0_8814B 13
#define BIT_MASK_XTAL_CK_SET_2_0_8814B 0x7
#define BIT_XTAL_CK_SET_2_0_8814B(x) \
(((x) & BIT_MASK_XTAL_CK_SET_2_0_8814B) \
<< BIT_SHIFT_XTAL_CK_SET_2_0_8814B)
#define BITS_XTAL_CK_SET_2_0_8814B \
(BIT_MASK_XTAL_CK_SET_2_0_8814B << BIT_SHIFT_XTAL_CK_SET_2_0_8814B)
#define BIT_CLEAR_XTAL_CK_SET_2_0_8814B(x) ((x) & (~BITS_XTAL_CK_SET_2_0_8814B))
#define BIT_GET_XTAL_CK_SET_2_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_CK_SET_2_0_8814B) & \
BIT_MASK_XTAL_CK_SET_2_0_8814B)
#define BIT_SET_XTAL_CK_SET_2_0_8814B(x, v) \
(BIT_CLEAR_XTAL_CK_SET_2_0_8814B(x) | BIT_XTAL_CK_SET_2_0_8814B(v))
#define BIT_SHIFT_GM_INIT_4_0_8814B 8
#define BIT_MASK_GM_INIT_4_0_8814B 0x1f
#define BIT_GM_INIT_4_0_8814B(x) \
(((x) & BIT_MASK_GM_INIT_4_0_8814B) << BIT_SHIFT_GM_INIT_4_0_8814B)
#define BITS_GM_INIT_4_0_8814B \
(BIT_MASK_GM_INIT_4_0_8814B << BIT_SHIFT_GM_INIT_4_0_8814B)
#define BIT_CLEAR_GM_INIT_4_0_8814B(x) ((x) & (~BITS_GM_INIT_4_0_8814B))
#define BIT_GET_GM_INIT_4_0_8814B(x) \
(((x) >> BIT_SHIFT_GM_INIT_4_0_8814B) & BIT_MASK_GM_INIT_4_0_8814B)
#define BIT_SET_GM_INIT_4_0_8814B(x, v) \
(BIT_CLEAR_GM_INIT_4_0_8814B(x) | BIT_GM_INIT_4_0_8814B(v))
#define BIT_GM_STEP_8814B BIT(7)
#define BIT_SHIFT_XAAC_GM_OFFSET_4_0_8814B 2
#define BIT_MASK_XAAC_GM_OFFSET_4_0_8814B 0x1f
#define BIT_XAAC_GM_OFFSET_4_0_8814B(x) \
(((x) & BIT_MASK_XAAC_GM_OFFSET_4_0_8814B) \
<< BIT_SHIFT_XAAC_GM_OFFSET_4_0_8814B)
#define BITS_XAAC_GM_OFFSET_4_0_8814B \
(BIT_MASK_XAAC_GM_OFFSET_4_0_8814B \
<< BIT_SHIFT_XAAC_GM_OFFSET_4_0_8814B)
#define BIT_CLEAR_XAAC_GM_OFFSET_4_0_8814B(x) \
((x) & (~BITS_XAAC_GM_OFFSET_4_0_8814B))
#define BIT_GET_XAAC_GM_OFFSET_4_0_8814B(x) \
(((x) >> BIT_SHIFT_XAAC_GM_OFFSET_4_0_8814B) & \
BIT_MASK_XAAC_GM_OFFSET_4_0_8814B)
#define BIT_SET_XAAC_GM_OFFSET_4_0_8814B(x, v) \
(BIT_CLEAR_XAAC_GM_OFFSET_4_0_8814B(x) | \
BIT_XAAC_GM_OFFSET_4_0_8814B(v))
#define BIT_OFFSET_PLUS_8814B BIT(1)
#define BIT_RESET_N_8814B BIT(0)
/* 2 REG_ANAPAR_XTAL_R_ONLY_8814B */
#define BIT_XTAL_PKDET_OUT_8814B BIT(6)
#define BIT_SHIFT_XTAL_GM_AAC_4_0_8814B 1
#define BIT_MASK_XTAL_GM_AAC_4_0_8814B 0x1f
#define BIT_XTAL_GM_AAC_4_0_8814B(x) \
(((x) & BIT_MASK_XTAL_GM_AAC_4_0_8814B) \
<< BIT_SHIFT_XTAL_GM_AAC_4_0_8814B)
#define BITS_XTAL_GM_AAC_4_0_8814B \
(BIT_MASK_XTAL_GM_AAC_4_0_8814B << BIT_SHIFT_XTAL_GM_AAC_4_0_8814B)
#define BIT_CLEAR_XTAL_GM_AAC_4_0_8814B(x) ((x) & (~BITS_XTAL_GM_AAC_4_0_8814B))
#define BIT_GET_XTAL_GM_AAC_4_0_8814B(x) \
(((x) >> BIT_SHIFT_XTAL_GM_AAC_4_0_8814B) & \
BIT_MASK_XTAL_GM_AAC_4_0_8814B)
#define BIT_SET_XTAL_GM_AAC_4_0_8814B(x, v) \
(BIT_CLEAR_XTAL_GM_AAC_4_0_8814B(x) | BIT_XTAL_GM_AAC_4_0_8814B(v))
#define BIT_XAAC_READY_8814B BIT(0)
/* 2 REG_CPHY_LDO_8814B */
#define BIT_SHIFT_CPHY_LDO_PD_8814B 12
#define BIT_MASK_CPHY_LDO_PD_8814B 0x3
#define BIT_CPHY_LDO_PD_8814B(x) \
(((x) & BIT_MASK_CPHY_LDO_PD_8814B) << BIT_SHIFT_CPHY_LDO_PD_8814B)
#define BITS_CPHY_LDO_PD_8814B \
(BIT_MASK_CPHY_LDO_PD_8814B << BIT_SHIFT_CPHY_LDO_PD_8814B)
#define BIT_CLEAR_CPHY_LDO_PD_8814B(x) ((x) & (~BITS_CPHY_LDO_PD_8814B))
#define BIT_GET_CPHY_LDO_PD_8814B(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_PD_8814B) & BIT_MASK_CPHY_LDO_PD_8814B)
#define BIT_SET_CPHY_LDO_PD_8814B(x, v) \
(BIT_CLEAR_CPHY_LDO_PD_8814B(x) | BIT_CPHY_LDO_PD_8814B(v))
#define BIT_SHIFT_CPHY_LDO_SR_8814B 10
#define BIT_MASK_CPHY_LDO_SR_8814B 0x3
#define BIT_CPHY_LDO_SR_8814B(x) \
(((x) & BIT_MASK_CPHY_LDO_SR_8814B) << BIT_SHIFT_CPHY_LDO_SR_8814B)
#define BITS_CPHY_LDO_SR_8814B \
(BIT_MASK_CPHY_LDO_SR_8814B << BIT_SHIFT_CPHY_LDO_SR_8814B)
#define BIT_CLEAR_CPHY_LDO_SR_8814B(x) ((x) & (~BITS_CPHY_LDO_SR_8814B))
#define BIT_GET_CPHY_LDO_SR_8814B(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_SR_8814B) & BIT_MASK_CPHY_LDO_SR_8814B)
#define BIT_SET_CPHY_LDO_SR_8814B(x, v) \
(BIT_CLEAR_CPHY_LDO_SR_8814B(x) | BIT_CPHY_LDO_SR_8814B(v))
#define BIT_SHIFT_CPHY_LDO_TUNEREF_8814B 8
#define BIT_MASK_CPHY_LDO_TUNEREF_8814B 0x3
#define BIT_CPHY_LDO_TUNEREF_8814B(x) \
(((x) & BIT_MASK_CPHY_LDO_TUNEREF_8814B) \
<< BIT_SHIFT_CPHY_LDO_TUNEREF_8814B)
#define BITS_CPHY_LDO_TUNEREF_8814B \
(BIT_MASK_CPHY_LDO_TUNEREF_8814B << BIT_SHIFT_CPHY_LDO_TUNEREF_8814B)
#define BIT_CLEAR_CPHY_LDO_TUNEREF_8814B(x) \
((x) & (~BITS_CPHY_LDO_TUNEREF_8814B))
#define BIT_GET_CPHY_LDO_TUNEREF_8814B(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_TUNEREF_8814B) & \
BIT_MASK_CPHY_LDO_TUNEREF_8814B)
#define BIT_SET_CPHY_LDO_TUNEREF_8814B(x, v) \
(BIT_CLEAR_CPHY_LDO_TUNEREF_8814B(x) | BIT_CPHY_LDO_TUNEREF_8814B(v))
#define BIT_SHIFT_CPHY_LDO_TUNE_VO_8814B 5
#define BIT_MASK_CPHY_LDO_TUNE_VO_8814B 0x7
#define BIT_CPHY_LDO_TUNE_VO_8814B(x) \
(((x) & BIT_MASK_CPHY_LDO_TUNE_VO_8814B) \
<< BIT_SHIFT_CPHY_LDO_TUNE_VO_8814B)
#define BITS_CPHY_LDO_TUNE_VO_8814B \
(BIT_MASK_CPHY_LDO_TUNE_VO_8814B << BIT_SHIFT_CPHY_LDO_TUNE_VO_8814B)
#define BIT_CLEAR_CPHY_LDO_TUNE_VO_8814B(x) \
((x) & (~BITS_CPHY_LDO_TUNE_VO_8814B))
#define BIT_GET_CPHY_LDO_TUNE_VO_8814B(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_TUNE_VO_8814B) & \
BIT_MASK_CPHY_LDO_TUNE_VO_8814B)
#define BIT_SET_CPHY_LDO_TUNE_VO_8814B(x, v) \
(BIT_CLEAR_CPHY_LDO_TUNE_VO_8814B(x) | BIT_CPHY_LDO_TUNE_VO_8814B(v))
#define BIT_SHIFT_CPHY_LDO_OCP_VTH_8814B 2
#define BIT_MASK_CPHY_LDO_OCP_VTH_8814B 0x7
#define BIT_CPHY_LDO_OCP_VTH_8814B(x) \
(((x) & BIT_MASK_CPHY_LDO_OCP_VTH_8814B) \
<< BIT_SHIFT_CPHY_LDO_OCP_VTH_8814B)
#define BITS_CPHY_LDO_OCP_VTH_8814B \
(BIT_MASK_CPHY_LDO_OCP_VTH_8814B << BIT_SHIFT_CPHY_LDO_OCP_VTH_8814B)
#define BIT_CLEAR_CPHY_LDO_OCP_VTH_8814B(x) \
((x) & (~BITS_CPHY_LDO_OCP_VTH_8814B))
#define BIT_GET_CPHY_LDO_OCP_VTH_8814B(x) \
(((x) >> BIT_SHIFT_CPHY_LDO_OCP_VTH_8814B) & \
BIT_MASK_CPHY_LDO_OCP_VTH_8814B)
#define BIT_SET_CPHY_LDO_OCP_VTH_8814B(x, v) \
(BIT_CLEAR_CPHY_LDO_OCP_VTH_8814B(x) | BIT_CPHY_LDO_OCP_VTH_8814B(v))
#define BIT_SHIFT_VREF_LDO_OK_8814B 0
#define BIT_MASK_VREF_LDO_OK_8814B 0x3
#define BIT_VREF_LDO_OK_8814B(x) \
(((x) & BIT_MASK_VREF_LDO_OK_8814B) << BIT_SHIFT_VREF_LDO_OK_8814B)
#define BITS_VREF_LDO_OK_8814B \
(BIT_MASK_VREF_LDO_OK_8814B << BIT_SHIFT_VREF_LDO_OK_8814B)
#define BIT_CLEAR_VREF_LDO_OK_8814B(x) ((x) & (~BITS_VREF_LDO_OK_8814B))
#define BIT_GET_VREF_LDO_OK_8814B(x) \
(((x) >> BIT_SHIFT_VREF_LDO_OK_8814B) & BIT_MASK_VREF_LDO_OK_8814B)
#define BIT_SET_VREF_LDO_OK_8814B(x, v) \
(BIT_CLEAR_VREF_LDO_OK_8814B(x) | BIT_VREF_LDO_OK_8814B(v))
/* 2 REG_CPHY_BG_8814B */
#define BIT_SHIFT_BG_8814B 0
#define BIT_MASK_BG_8814B 0x7
#define BIT_BG_8814B(x) (((x) & BIT_MASK_BG_8814B) << BIT_SHIFT_BG_8814B)
#define BITS_BG_8814B (BIT_MASK_BG_8814B << BIT_SHIFT_BG_8814B)
#define BIT_CLEAR_BG_8814B(x) ((x) & (~BITS_BG_8814B))
#define BIT_GET_BG_8814B(x) (((x) >> BIT_SHIFT_BG_8814B) & BIT_MASK_BG_8814B)
#define BIT_SET_BG_8814B(x, v) (BIT_CLEAR_BG_8814B(x) | BIT_BG_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HIMR_4_8814B */
#define BIT_TXBCN_OK_PORT4_8814B BIT(31)
#define BIT_TXBCN_OK_PORT3_8814B BIT(30)
#define BIT_TXBCN_OK_PORT2_8814B BIT(29)
#define BIT_TXBCN_OK_PORT1_8814B BIT(28)
#define BIT_TXBCN15OK_8814B BIT(23)
#define BIT_TXBCN14OK_8814B BIT(22)
#define BIT_TXBCN13OK_8814B BIT(21)
#define BIT_TXBCN12OK_8814B BIT(20)
#define BIT_TXBCN11OK_8814B BIT(19)
#define BIT_TXBCN10OK_8814B BIT(18)
#define BIT_TXBCN9OK_8814B BIT(17)
#define BIT_TXBCN8OK_8814B BIT(16)
#define BIT_BCNDERR_PORT4_8814B BIT(15)
#define BIT_BCNDERR_PORT3_8814B BIT(14)
#define BIT_BCNDERR_PORT2_8814B BIT(13)
#define BIT_BCNDERR_PORT1_8814B BIT(12)
#define BIT_TXBCN15ERR_8814B BIT(7)
#define BIT_TXBCN14ERR_8814B BIT(6)
#define BIT_TXBCN13ERR_8814B BIT(5)
#define BIT_TXBCN12ERR_8814B BIT(4)
#define BIT_TXBCN11ERR_8814B BIT(3)
#define BIT_TXBCN10ERR_8814B BIT(2)
#define BIT_TXBCN9ERR_8814B BIT(1)
#define BIT_TXBCN8ERR_8814B BIT(0)
/* 2 REG_HISR_4_8814B */
#define BIT_TXBCN_OK_PORT4_8814B BIT(31)
#define BIT_TXBCN_OK_PORT3_8814B BIT(30)
#define BIT_TXBCN_OK_PORT2_8814B BIT(29)
#define BIT_TXBCN_OK_PORT1_8814B BIT(28)
#define BIT_TXBCN15OK_8814B BIT(23)
#define BIT_TXBCN14OK_8814B BIT(22)
#define BIT_TXBCN13OK_8814B BIT(21)
#define BIT_TXBCN12OK_8814B BIT(20)
#define BIT_TXBCN11OK_8814B BIT(19)
#define BIT_TXBCN10OK_8814B BIT(18)
#define BIT_TXBCN9OK_8814B BIT(17)
#define BIT_TXBCN8OK_8814B BIT(16)
#define BIT_BCNDERR_PORT4_8814B BIT(15)
#define BIT_BCNDERR_PORT3_8814B BIT(14)
#define BIT_BCNDERR_PORT2_8814B BIT(13)
#define BIT_BCNDERR_PORT1_8814B BIT(12)
#define BIT_TXBCN15ERR_8814B BIT(7)
#define BIT_TXBCN14ERR_8814B BIT(6)
#define BIT_TXBCN13ERR_8814B BIT(5)
#define BIT_TXBCN12ERR_8814B BIT(4)
#define BIT_TXBCN11ERR_8814B BIT(3)
#define BIT_TXBCN10ERR_8814B BIT(2)
#define BIT_TXBCN9ERR_8814B BIT(1)
#define BIT_TXBCN8ERR_8814B BIT(0)
/* 2 REG_HIMR_5_8814B */
#define BIT_BCNDMAINT15_8814B BIT(23)
#define BIT_BCNDMAINT14_8814B BIT(22)
#define BIT_BCNDMAINT13_8814B BIT(21)
#define BIT_BCNDMAINT12_8814B BIT(20)
#define BIT_BCNDMAINT11_8814B BIT(19)
#define BIT_BCNDMAINT10_8814B BIT(18)
#define BIT_BCNDMAINT9_8814B BIT(17)
#define BIT_BCNDMAINT8_8814B BIT(16)
#define BIT_BCNDERR_PORT4_8814B BIT(15)
#define BIT_BCNDERR_PORT3_8814B BIT(14)
#define BIT_BCNDERR_PORT2_8814B BIT(13)
#define BIT_BCNDERR_PORT1_8814B BIT(12)
#define BIT_BCNDERR15_8814B BIT(7)
#define BIT_BCNDERR14_8814B BIT(6)
#define BIT_BCNDERR13_8814B BIT(5)
#define BIT_BCNDERR12_8814B BIT(4)
#define BIT_BCNDERR11_8814B BIT(3)
#define BIT_BCNDERR10_8814B BIT(2)
#define BIT_BCNDERR9_8814B BIT(1)
#define BIT_BCNDERR8_8814B BIT(0)
/* 2 REG_HISR_5_8814B */
#define BIT_BCNDMAINT15_8814B BIT(23)
#define BIT_BCNDMAINT14_8814B BIT(22)
#define BIT_BCNDMAINT13_8814B BIT(21)
#define BIT_BCNDMAINT12_8814B BIT(20)
#define BIT_BCNDMAINT11_8814B BIT(19)
#define BIT_BCNDMAINT10_8814B BIT(18)
#define BIT_BCNDMAINT9_8814B BIT(17)
#define BIT_BCNDMAINT8_8814B BIT(16)
#define BIT_BCNDERR_PORT4_8814B BIT(15)
#define BIT_BCNDERR_PORT3_8814B BIT(14)
#define BIT_BCNDERR_PORT2_8814B BIT(13)
#define BIT_BCNDERR_PORT1_8814B BIT(12)
#define BIT_BCNDERR15_8814B BIT(7)
#define BIT_BCNDERR14_8814B BIT(6)
#define BIT_BCNDERR13_8814B BIT(5)
#define BIT_BCNDERR12_8814B BIT(4)
#define BIT_BCNDERR11_8814B BIT(3)
#define BIT_BCNDERR10_8814B BIT(2)
#define BIT_BCNDERR9_8814B BIT(1)
#define BIT_BCNDERR8_8814B BIT(0)
/* 2 REG_SYS_CFG5_8814B */
#define BIT_LPS_STATUS_8814B BIT(3)
#define BIT_HCI_TXDMA_BUSY_8814B BIT(2)
#define BIT_HCI_TXDMA_ALLOW_8814B BIT(1)
#define BIT_FW_CTRL_HCI_TXDMA_EN_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HIMR_6_8814B */
#define BIT_ATIMEND_PORT4_8814B BIT(31)
#define BIT_ATIMEND_PORT3_8814B BIT(30)
#define BIT_ATIMEND_PORT2_8814B BIT(29)
#define BIT_ATIMEND_PORT1_8814B BIT(28)
#define BIT_ATIMEND15_8814B BIT(23)
#define BIT_ATIMEND14_8814B BIT(22)
#define BIT_ATIMEND13_8814B BIT(21)
#define BIT_ATIMEND12_8814B BIT(20)
#define BIT_ATIMEND11_8814B BIT(19)
#define BIT_ATIMEND10_8814B BIT(18)
#define BIT_ATIMEND9_8814B BIT(17)
#define BIT_ATIMEND8_8814B BIT(16)
#define BIT_PS_TIMER_EARLY_INT_5_8814B BIT(5)
#define BIT_PS_TIMER_EARLY_INT_4_8814B BIT(4)
#define BIT_PS_TIMER_EARLY_INT_3_8814B BIT(3)
#define BIT_PS_TIMER_EARLY_INT_2_8814B BIT(2)
#define BIT_PS_TIMER_EARLY_INT_1_8814B BIT(1)
#define BIT_PS_TIMER_EARLY_INT_0_8814B BIT(0)
/* 2 REG_HISR_6_8814B */
#define BIT_ATIMEND_PORT4_8814B BIT(31)
#define BIT_ATIMEND_PORT3_8814B BIT(30)
#define BIT_ATIMEND_PORT2_8814B BIT(29)
#define BIT_ATIMEND_PORT1_8814B BIT(28)
#define BIT_ATIMEND15_8814B BIT(23)
#define BIT_ATIMEND14_8814B BIT(22)
#define BIT_ATIMEND13_8814B BIT(21)
#define BIT_ATIMEND12_8814B BIT(20)
#define BIT_ATIMEND11_8814B BIT(19)
#define BIT_ATIMEND10_8814B BIT(18)
#define BIT_ATIMEND9_8814B BIT(17)
#define BIT_ATIMEND8_8814B BIT(16)
#define BIT_PS_TIMER_EARLY_INT_5_8814B BIT(5)
#define BIT_PS_TIMER_EARLY_INT_4_8814B BIT(4)
#define BIT_PS_TIMER_EARLY_INT_3_8814B BIT(3)
#define BIT_PS_TIMER_EARLY_INT_2_8814B BIT(2)
#define BIT_PS_TIMER_EARLY_INT_1_8814B BIT(1)
#define BIT_PS_TIMER_EARLY_INT_0_8814B BIT(0)
/* 2 REG_CPU_DMEM_CON_8814B */
#define BIT_WDT_AUTO_MODE_8814B BIT(22)
#define BIT_WDT_PLATFORM_EN_8814B BIT(21)
#define BIT_WDT_CPU_EN_8814B BIT(20)
#define BIT_WDT_OPT_IOWRAPPER_8814B BIT(19)
#define BIT_ANA_PORT_IDLE_8814B BIT(18)
#define BIT_MAC_PORT_IDLE_8814B BIT(17)
#define BIT_WL_PLATFORM_RST_8814B BIT(16)
#define BIT_WL_SECURITY_CLK_8814B BIT(15)
#define BIT_DDMA_EN_8814B BIT(8)
#define BIT_SHIFT_CPU_DMEM_CON_8814B 0
#define BIT_MASK_CPU_DMEM_CON_8814B 0xff
#define BIT_CPU_DMEM_CON_8814B(x) \
(((x) & BIT_MASK_CPU_DMEM_CON_8814B) << BIT_SHIFT_CPU_DMEM_CON_8814B)
#define BITS_CPU_DMEM_CON_8814B \
(BIT_MASK_CPU_DMEM_CON_8814B << BIT_SHIFT_CPU_DMEM_CON_8814B)
#define BIT_CLEAR_CPU_DMEM_CON_8814B(x) ((x) & (~BITS_CPU_DMEM_CON_8814B))
#define BIT_GET_CPU_DMEM_CON_8814B(x) \
(((x) >> BIT_SHIFT_CPU_DMEM_CON_8814B) & BIT_MASK_CPU_DMEM_CON_8814B)
#define BIT_SET_CPU_DMEM_CON_8814B(x, v) \
(BIT_CLEAR_CPU_DMEM_CON_8814B(x) | BIT_CPU_DMEM_CON_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BOOT_REASON_8814B */
#define BIT_SHIFT_BOOT_REASON_V1_8814B 0
#define BIT_MASK_BOOT_REASON_V1_8814B 0x7
#define BIT_BOOT_REASON_V1_8814B(x) \
(((x) & BIT_MASK_BOOT_REASON_V1_8814B) \
<< BIT_SHIFT_BOOT_REASON_V1_8814B)
#define BITS_BOOT_REASON_V1_8814B \
(BIT_MASK_BOOT_REASON_V1_8814B << BIT_SHIFT_BOOT_REASON_V1_8814B)
#define BIT_CLEAR_BOOT_REASON_V1_8814B(x) ((x) & (~BITS_BOOT_REASON_V1_8814B))
#define BIT_GET_BOOT_REASON_V1_8814B(x) \
(((x) >> BIT_SHIFT_BOOT_REASON_V1_8814B) & \
BIT_MASK_BOOT_REASON_V1_8814B)
#define BIT_SET_BOOT_REASON_V1_8814B(x, v) \
(BIT_CLEAR_BOOT_REASON_V1_8814B(x) | BIT_BOOT_REASON_V1_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_DATA_CPU_CTL0_8814B */
#define BIT_DATA_FW_READY_8814B BIT(31)
#define BIT_WDT_SYS_RST_8814B BIT(13)
#define BIT_WDT_ENABLE_8814B BIT(12)
#define BIT_SHIFT_BOOT_SEL_8814B 6
#define BIT_MASK_BOOT_SEL_8814B 0x3
#define BIT_BOOT_SEL_8814B(x) \
(((x) & BIT_MASK_BOOT_SEL_8814B) << BIT_SHIFT_BOOT_SEL_8814B)
#define BITS_BOOT_SEL_8814B \
(BIT_MASK_BOOT_SEL_8814B << BIT_SHIFT_BOOT_SEL_8814B)
#define BIT_CLEAR_BOOT_SEL_8814B(x) ((x) & (~BITS_BOOT_SEL_8814B))
#define BIT_GET_BOOT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_BOOT_SEL_8814B) & BIT_MASK_BOOT_SEL_8814B)
#define BIT_SET_BOOT_SEL_8814B(x, v) \
(BIT_CLEAR_BOOT_SEL_8814B(x) | BIT_BOOT_SEL_8814B(v))
#define BIT_CLK_SEL_8814B BIT(4)
#define BIT_DATA_PLATFORM_RST_8814B BIT(1)
#define BIT_DATA_CPU_RST_8814B BIT(0)
/* 2 REG_DATA_CPU_CTL1_8814B */
#define BIT_HOST_INTERFACE_IO_PATH_8814B BIT(7)
#define BIT_EN_TXDMA_OFLD_8814B BIT(6)
#define BIT_EN_RXDMA_OFLD_8814B BIT(5)
#define BIT_EN_HCI_DMA_TX_8814B BIT(4)
#define BIT_EN_HCI_DMA_RX_8814B BIT(3)
#define BIT_EN_AXI_DMA_TX_8814B BIT(2)
#define BIT_EN_AXI_DMA_RX_8814B BIT(1)
#define BIT_EN_PKT_ENG_8814B BIT(0)
/* 2 REG_TXDMA_STOP_HIMR_8814B */
#define BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK_8814B 0
#define BIT_MASK_NTH_TXDMA_STOP_INT_MSK_8814B 0x1ffff
#define BIT_NTH_TXDMA_STOP_INT_MSK_8814B(x) \
(((x) & BIT_MASK_NTH_TXDMA_STOP_INT_MSK_8814B) \
<< BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK_8814B)
#define BITS_NTH_TXDMA_STOP_INT_MSK_8814B \
(BIT_MASK_NTH_TXDMA_STOP_INT_MSK_8814B \
<< BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK_8814B)
#define BIT_CLEAR_NTH_TXDMA_STOP_INT_MSK_8814B(x) \
((x) & (~BITS_NTH_TXDMA_STOP_INT_MSK_8814B))
#define BIT_GET_NTH_TXDMA_STOP_INT_MSK_8814B(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_STOP_INT_MSK_8814B) & \
BIT_MASK_NTH_TXDMA_STOP_INT_MSK_8814B)
#define BIT_SET_NTH_TXDMA_STOP_INT_MSK_8814B(x, v) \
(BIT_CLEAR_NTH_TXDMA_STOP_INT_MSK_8814B(x) | \
BIT_NTH_TXDMA_STOP_INT_MSK_8814B(v))
/* 2 REG_TXDMA_STOP_HISR_8814B */
#define BIT_SHIFT_NTH_TXDMA_STOP_INT_8814B 0
#define BIT_MASK_NTH_TXDMA_STOP_INT_8814B 0x1ffff
#define BIT_NTH_TXDMA_STOP_INT_8814B(x) \
(((x) & BIT_MASK_NTH_TXDMA_STOP_INT_8814B) \
<< BIT_SHIFT_NTH_TXDMA_STOP_INT_8814B)
#define BITS_NTH_TXDMA_STOP_INT_8814B \
(BIT_MASK_NTH_TXDMA_STOP_INT_8814B \
<< BIT_SHIFT_NTH_TXDMA_STOP_INT_8814B)
#define BIT_CLEAR_NTH_TXDMA_STOP_INT_8814B(x) \
((x) & (~BITS_NTH_TXDMA_STOP_INT_8814B))
#define BIT_GET_NTH_TXDMA_STOP_INT_8814B(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_STOP_INT_8814B) & \
BIT_MASK_NTH_TXDMA_STOP_INT_8814B)
#define BIT_SET_NTH_TXDMA_STOP_INT_8814B(x, v) \
(BIT_CLEAR_NTH_TXDMA_STOP_INT_8814B(x) | \
BIT_NTH_TXDMA_STOP_INT_8814B(v))
/* 2 REG_TXDMA_START_HIMR_8814B */
#define BIT_SHIFT_NTH_TXDMA_START_INT_MSK_8814B 0
#define BIT_MASK_NTH_TXDMA_START_INT_MSK_8814B 0x1ffff
#define BIT_NTH_TXDMA_START_INT_MSK_8814B(x) \
(((x) & BIT_MASK_NTH_TXDMA_START_INT_MSK_8814B) \
<< BIT_SHIFT_NTH_TXDMA_START_INT_MSK_8814B)
#define BITS_NTH_TXDMA_START_INT_MSK_8814B \
(BIT_MASK_NTH_TXDMA_START_INT_MSK_8814B \
<< BIT_SHIFT_NTH_TXDMA_START_INT_MSK_8814B)
#define BIT_CLEAR_NTH_TXDMA_START_INT_MSK_8814B(x) \
((x) & (~BITS_NTH_TXDMA_START_INT_MSK_8814B))
#define BIT_GET_NTH_TXDMA_START_INT_MSK_8814B(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_START_INT_MSK_8814B) & \
BIT_MASK_NTH_TXDMA_START_INT_MSK_8814B)
#define BIT_SET_NTH_TXDMA_START_INT_MSK_8814B(x, v) \
(BIT_CLEAR_NTH_TXDMA_START_INT_MSK_8814B(x) | \
BIT_NTH_TXDMA_START_INT_MSK_8814B(v))
/* 2 REG_TXDMA_START_HISR_8814B */
#define BIT_SHIFT_NTH_TXDMA_START_INT_8814B 0
#define BIT_MASK_NTH_TXDMA_START_INT_8814B 0x1ffff
#define BIT_NTH_TXDMA_START_INT_8814B(x) \
(((x) & BIT_MASK_NTH_TXDMA_START_INT_8814B) \
<< BIT_SHIFT_NTH_TXDMA_START_INT_8814B)
#define BITS_NTH_TXDMA_START_INT_8814B \
(BIT_MASK_NTH_TXDMA_START_INT_8814B \
<< BIT_SHIFT_NTH_TXDMA_START_INT_8814B)
#define BIT_CLEAR_NTH_TXDMA_START_INT_8814B(x) \
((x) & (~BITS_NTH_TXDMA_START_INT_8814B))
#define BIT_GET_NTH_TXDMA_START_INT_8814B(x) \
(((x) >> BIT_SHIFT_NTH_TXDMA_START_INT_8814B) & \
BIT_MASK_NTH_TXDMA_START_INT_8814B)
#define BIT_SET_NTH_TXDMA_START_INT_8814B(x, v) \
(BIT_CLEAR_NTH_TXDMA_START_INT_8814B(x) | \
BIT_NTH_TXDMA_START_INT_8814B(v))
/* 2 REG_NFCPAD_CTRL_8814B */
#define BIT_PAD_SHUTDW_8814B BIT(18)
#define BIT_SYSON_NFC_PAD_8814B BIT(17)
#define BIT_NFC_INT_PAD_CTRL_8814B BIT(16)
#define BIT_NFC_RFDIS_PAD_CTRL_8814B BIT(15)
#define BIT_NFC_CLK_PAD_CTRL_8814B BIT(14)
#define BIT_NFC_DATA_PAD_CTRL_8814B BIT(13)
#define BIT_NFC_PAD_PULL_CTRL_8814B BIT(12)
#define BIT_SHIFT_NFCPAD_IO_SEL_8814B 8
#define BIT_MASK_NFCPAD_IO_SEL_8814B 0xf
#define BIT_NFCPAD_IO_SEL_8814B(x) \
(((x) & BIT_MASK_NFCPAD_IO_SEL_8814B) << BIT_SHIFT_NFCPAD_IO_SEL_8814B)
#define BITS_NFCPAD_IO_SEL_8814B \
(BIT_MASK_NFCPAD_IO_SEL_8814B << BIT_SHIFT_NFCPAD_IO_SEL_8814B)
#define BIT_CLEAR_NFCPAD_IO_SEL_8814B(x) ((x) & (~BITS_NFCPAD_IO_SEL_8814B))
#define BIT_GET_NFCPAD_IO_SEL_8814B(x) \
(((x) >> BIT_SHIFT_NFCPAD_IO_SEL_8814B) & BIT_MASK_NFCPAD_IO_SEL_8814B)
#define BIT_SET_NFCPAD_IO_SEL_8814B(x, v) \
(BIT_CLEAR_NFCPAD_IO_SEL_8814B(x) | BIT_NFCPAD_IO_SEL_8814B(v))
#define BIT_SHIFT_NFCPAD_OUT_8814B 4
#define BIT_MASK_NFCPAD_OUT_8814B 0xf
#define BIT_NFCPAD_OUT_8814B(x) \
(((x) & BIT_MASK_NFCPAD_OUT_8814B) << BIT_SHIFT_NFCPAD_OUT_8814B)
#define BITS_NFCPAD_OUT_8814B \
(BIT_MASK_NFCPAD_OUT_8814B << BIT_SHIFT_NFCPAD_OUT_8814B)
#define BIT_CLEAR_NFCPAD_OUT_8814B(x) ((x) & (~BITS_NFCPAD_OUT_8814B))
#define BIT_GET_NFCPAD_OUT_8814B(x) \
(((x) >> BIT_SHIFT_NFCPAD_OUT_8814B) & BIT_MASK_NFCPAD_OUT_8814B)
#define BIT_SET_NFCPAD_OUT_8814B(x, v) \
(BIT_CLEAR_NFCPAD_OUT_8814B(x) | BIT_NFCPAD_OUT_8814B(v))
#define BIT_SHIFT_NFCPAD_IN_8814B 0
#define BIT_MASK_NFCPAD_IN_8814B 0xf
#define BIT_NFCPAD_IN_8814B(x) \
(((x) & BIT_MASK_NFCPAD_IN_8814B) << BIT_SHIFT_NFCPAD_IN_8814B)
#define BITS_NFCPAD_IN_8814B \
(BIT_MASK_NFCPAD_IN_8814B << BIT_SHIFT_NFCPAD_IN_8814B)
#define BIT_CLEAR_NFCPAD_IN_8814B(x) ((x) & (~BITS_NFCPAD_IN_8814B))
#define BIT_GET_NFCPAD_IN_8814B(x) \
(((x) >> BIT_SHIFT_NFCPAD_IN_8814B) & BIT_MASK_NFCPAD_IN_8814B)
#define BIT_SET_NFCPAD_IN_8814B(x, v) \
(BIT_CLEAR_NFCPAD_IN_8814B(x) | BIT_NFCPAD_IN_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HIMR2_8814B */
#define BIT_BCNDMAINT_P4_MSK_8814B BIT(31)
#define BIT_BCNDMAINT_P3_MSK_8814B BIT(30)
#define BIT_BCNDMAINT_P2_MSK_8814B BIT(29)
#define BIT_BCNDMAINT_P1_MSK_8814B BIT(28)
#define BIT_SCH_PHY_TXOP_SIFS_INT_MSK_8814B BIT(23)
#define BIT_ATIMEND7_MSK_8814B BIT(22)
#define BIT_ATIMEND6_MSK_8814B BIT(21)
#define BIT_ATIMEND5_MSK_8814B BIT(20)
#define BIT_ATIMEND4_MSK_8814B BIT(19)
#define BIT_ATIMEND3_MSK_8814B BIT(18)
#define BIT_ATIMEND2_MSK_8814B BIT(17)
#define BIT_ATIMEND1_MSK_8814B BIT(16)
#define BIT_TXBCN7OK_MSK_8814B BIT(14)
#define BIT_TXBCN6OK_MSK_8814B BIT(13)
#define BIT_TXBCN5OK_MSK_8814B BIT(12)
#define BIT_TXBCN4OK_MSK_8814B BIT(11)
#define BIT_TXBCN3OK_MSK_8814B BIT(10)
#define BIT_TXBCN2OK_MSK_8814B BIT(9)
#define BIT_TXBCN1OK_MSK_V1_8814B BIT(8)
#define BIT_TXBCN7ERR_MSK_8814B BIT(6)
#define BIT_TXBCN6ERR_MSK_8814B BIT(5)
#define BIT_TXBCN5ERR_MSK_8814B BIT(4)
#define BIT_TXBCN4ERR_MSK_8814B BIT(3)
#define BIT_TXBCN3ERR_MSK_8814B BIT(2)
#define BIT_TXBCN2ERR_MSK_8814B BIT(1)
#define BIT_TXBCN1ERR_MSK_V1_8814B BIT(0)
/* 2 REG_HISR2_8814B */
#define BIT_BCNDMAINT_P4_8814B BIT(31)
#define BIT_BCNDMAINT_P3_8814B BIT(30)
#define BIT_BCNDMAINT_P2_8814B BIT(29)
#define BIT_BCNDMAINT_P1_8814B BIT(28)
#define BIT_SCH_PHY_TXOP_SIFS_INT_8814B BIT(23)
#define BIT_ATIMEND7_8814B BIT(22)
#define BIT_ATIMEND6_8814B BIT(21)
#define BIT_ATIMEND5_8814B BIT(20)
#define BIT_ATIMEND4_8814B BIT(19)
#define BIT_ATIMEND3_8814B BIT(18)
#define BIT_ATIMEND2_8814B BIT(17)
#define BIT_ATIMEND1_8814B BIT(16)
#define BIT_TXBCN7OK_8814B BIT(14)
#define BIT_TXBCN6OK_8814B BIT(13)
#define BIT_TXBCN5OK_8814B BIT(12)
#define BIT_TXBCN4OK_8814B BIT(11)
#define BIT_TXBCN3OK_8814B BIT(10)
#define BIT_TXBCN2OK_8814B BIT(9)
#define BIT_TXBCN1OK_8814B BIT(8)
#define BIT_TXBCN7ERR_8814B BIT(6)
#define BIT_TXBCN6ERR_8814B BIT(5)
#define BIT_TXBCN5ERR_8814B BIT(4)
#define BIT_TXBCN4ERR_8814B BIT(3)
#define BIT_TXBCN3ERR_8814B BIT(2)
#define BIT_TXBCN2ERR_8814B BIT(1)
#define BIT_TXBCN1ERR_8814B BIT(0)
/* 2 REG_HIMR3_8814B */
#define BIT_GTINT12_MSK_8814B BIT(24)
#define BIT_GTINT11_MSK_8814B BIT(23)
#define BIT_GTINT10_MSK_8814B BIT(22)
#define BIT_GTINT9_MSK_8814B BIT(21)
#define BIT_RX_DESC_BUF_FULL_MSK_8814B BIT(20)
#define BIT_CPHY_LDO_OCP_DET_INT_MSK_8814B BIT(19)
#define BIT_WDT_PLATFORM_INT_MSK_8814B BIT(18)
#define BIT_WDT_CPU_INT_MSK_8814B BIT(17)
#define BIT_SETH2CDOK_MASK_8814B BIT(16)
#define BIT_H2C_CMD_FULL_MASK_8814B BIT(15)
#define BIT_PKT_TRANS_ERR_MASK_8814B BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_MASK_8814B BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_MASK_8814B BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_MASK_8814B BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_MAS_8814B BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_MASK_8814B BIT(9)
#define BIT_SEARCH_FAIL_MSK_8814B BIT(8)
#define BIT_PWR_INT_127TO96_MASK_8814B BIT(7)
#define BIT_PWR_INT_95TO64_MASK_8814B BIT(6)
#define BIT_PWR_INT_63TO32_MASK_8814B BIT(5)
#define BIT_PWR_INT_31TO0_MASK_8814B BIT(4)
#define BIT_RX_DMA_STUCK_MSK_8814B BIT(3)
#define BIT_TX_DMA_STUCK_MSK_8814B BIT(2)
#define BIT_DDMA0_LP_INT_MSK_8814B BIT(1)
#define BIT_DDMA0_HP_INT_MSK_8814B BIT(0)
/* 2 REG_HISR3_8814B */
#define BIT_GTINT12_8814B BIT(24)
#define BIT_GTINT11_8814B BIT(23)
#define BIT_GTINT10_8814B BIT(22)
#define BIT_GTINT9_8814B BIT(21)
#define BIT_RX_DESC_BUF_FULL_8814B BIT(20)
#define BIT_CPHY_LDO_OCP_DET_INT_8814B BIT(19)
#define BIT_WDT_PLATFORM_INT_8814B BIT(18)
#define BIT_WDT_CPU_INT_8814B BIT(17)
#define BIT_SETH2CDOK_8814B BIT(16)
#define BIT_H2C_CMD_FULL_8814B BIT(15)
#define BIT_PKT_TRANS_ERR_8814B BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8814B BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8814B BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8814B BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8814B BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8814B BIT(9)
#define BIT_SEARCH_FAIL_8814B BIT(8)
#define BIT_PWR_INT_127TO96_8814B BIT(7)
#define BIT_PWR_INT_95TO64_8814B BIT(6)
#define BIT_PWR_INT_63TO32_8814B BIT(5)
#define BIT_PWR_INT_31TO0_8814B BIT(4)
#define BIT_RX_DMA_STUCK_8814B BIT(3)
#define BIT_TX_DMA_STUCK_8814B BIT(2)
#define BIT_DDMA0_LP_INT_8814B BIT(1)
#define BIT_DDMA0_HP_INT_8814B BIT(0)
/* 2 REG_SW_MDIO_8814B */
#define BIT_DIS_TIMEOUT_IO_8814B BIT(24)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HIMR_7_8814B */
#define BIT_DATA_CPU_WDT_INT_MSK_8814B BIT(31)
#define BIT_OFLD_TXDMA_ERR_MSK_8814B BIT(30)
#define BIT_OFLD_TXDMA_FULL_MSK_8814B BIT(29)
#define BIT_OFLD_RXDMA_OVR_MSK_8814B BIT(28)
#define BIT_OFLD_RXDMA_ERR_MSK_8814B BIT(27)
#define BIT_OFLD_RXDMA_DES_UA_MSK_8814B BIT(26)
#define BIT_TXDMAOK_CHANNEL_16_MSK_8814B BIT(16)
#define BIT_TXDMAOK_CHANNEL_13_MSK_8814B BIT(13)
#define BIT_TXDMAOK_CHANNEL_12_MSK_8814B BIT(12)
#define BIT_TXDMAOK_CHANNEL_11_MSK_8814B BIT(11)
#define BIT_TXDMAOK_CHANNEL_10_MSK_8814B BIT(10)
#define BIT_TXDMAOK_CHANNEL_9_MSK_8814B BIT(9)
#define BIT_TXDMAOK_CHANNEL_8_MSK_8814B BIT(8)
#define BIT_TXDMAOK_CHANNEL_7_MSK_8814B BIT(7)
#define BIT_TXDMAOK_CHANNEL_6_MSK_8814B BIT(6)
#define BIT_TXDMAOK_CHANNEL_5_MSK_8814B BIT(5)
#define BIT_TXDMAOK_CHANNEL_4_MSK_8814B BIT(4)
/* 2 REG_HISR_7_8814B */
#define BIT_DATA_CPU_WDT_INT_8814B BIT(31)
#define BIT_OFLD_TXDMA_ERR_8814B BIT(30)
#define BIT_OFLD_TXDMA_FULL_8814B BIT(29)
#define BIT_OFLD_RXDMA_OVR_8814B BIT(28)
#define BIT_OFLD_RXDMA_ERR_8814B BIT(27)
#define BIT_OFLD_RXDMA_DES_UA_8814B BIT(26)
#define BIT_TXDMAOK_CHANNEL_16_8814B BIT(16)
#define BIT_TXDMAOK_CHANNEL_13_8814B BIT(13)
#define BIT_TXDMAOK_CHANNEL_12_8814B BIT(12)
#define BIT_TXDMAOK_CHANNEL_11_8814B BIT(11)
#define BIT_TXDMAOK_CHANNEL_10_8814B BIT(10)
#define BIT_TXDMAOK_CHANNEL_9_8814B BIT(9)
#define BIT_TXDMAOK_CHANNEL_8_8814B BIT(8)
#define BIT_TXDMAOK_CHANNEL_7_8814B BIT(7)
#define BIT_TXDMAOK_CHANNEL_6_8814B BIT(6)
#define BIT_TXDMAOK_CHANNEL_5_8814B BIT(5)
#define BIT_TXDMAOK_CHANNEL_4_8814B BIT(4)
/* 2 REG_H2C_PKT_READADDR_8814B */
#define BIT_SHIFT_H2C_PKT_READADDR_8814B 0
#define BIT_MASK_H2C_PKT_READADDR_8814B 0x3ffff
#define BIT_H2C_PKT_READADDR_8814B(x) \
(((x) & BIT_MASK_H2C_PKT_READADDR_8814B) \
<< BIT_SHIFT_H2C_PKT_READADDR_8814B)
#define BITS_H2C_PKT_READADDR_8814B \
(BIT_MASK_H2C_PKT_READADDR_8814B << BIT_SHIFT_H2C_PKT_READADDR_8814B)
#define BIT_CLEAR_H2C_PKT_READADDR_8814B(x) \
((x) & (~BITS_H2C_PKT_READADDR_8814B))
#define BIT_GET_H2C_PKT_READADDR_8814B(x) \
(((x) >> BIT_SHIFT_H2C_PKT_READADDR_8814B) & \
BIT_MASK_H2C_PKT_READADDR_8814B)
#define BIT_SET_H2C_PKT_READADDR_8814B(x, v) \
(BIT_CLEAR_H2C_PKT_READADDR_8814B(x) | BIT_H2C_PKT_READADDR_8814B(v))
/* 2 REG_H2C_PKT_WRITEADDR_8814B */
#define BIT_SHIFT_H2C_PKT_WRITEADDR_8814B 0
#define BIT_MASK_H2C_PKT_WRITEADDR_8814B 0x3ffff
#define BIT_H2C_PKT_WRITEADDR_8814B(x) \
(((x) & BIT_MASK_H2C_PKT_WRITEADDR_8814B) \
<< BIT_SHIFT_H2C_PKT_WRITEADDR_8814B)
#define BITS_H2C_PKT_WRITEADDR_8814B \
(BIT_MASK_H2C_PKT_WRITEADDR_8814B << BIT_SHIFT_H2C_PKT_WRITEADDR_8814B)
#define BIT_CLEAR_H2C_PKT_WRITEADDR_8814B(x) \
((x) & (~BITS_H2C_PKT_WRITEADDR_8814B))
#define BIT_GET_H2C_PKT_WRITEADDR_8814B(x) \
(((x) >> BIT_SHIFT_H2C_PKT_WRITEADDR_8814B) & \
BIT_MASK_H2C_PKT_WRITEADDR_8814B)
#define BIT_SET_H2C_PKT_WRITEADDR_8814B(x, v) \
(BIT_CLEAR_H2C_PKT_WRITEADDR_8814B(x) | BIT_H2C_PKT_WRITEADDR_8814B(v))
/* 2 REG_MEM_PWR_CRTL_8814B */
#define BIT_MEM_BB_SD_8814B BIT(17)
#define BIT_MEM_BB_DS_8814B BIT(16)
#define BIT_MEM_DENG_LS_8814B BIT(13)
#define BIT_MEM_DENG_DS_8814B BIT(12)
#define BIT_MEM_BT_DS_8814B BIT(10)
#define BIT_MEM_SDIO_LS_8814B BIT(9)
#define BIT_MEM_SDIO_DS_8814B BIT(8)
#define BIT_MEM_USB_LS_8814B BIT(7)
#define BIT_MEM_USB_DS_8814B BIT(6)
#define BIT_MEM_PCI_LS_8814B BIT(5)
#define BIT_MEM_PCI_DS_8814B BIT(4)
#define BIT_MEM_WLMAC_LS_8814B BIT(3)
#define BIT_MEM_WLMAC_DS_8814B BIT(2)
#define BIT_MEM_WLMCU_LS_8814B BIT(1)
#define BIT_MEM_WLMCU_DS_8814B BIT(0)
/* 2 REG_FW_DRV_HANDSHAKE_8814B */
#define BIT_SHIFT_FW_DRV_HANDSHAKE_8814B 0
#define BIT_MASK_FW_DRV_HANDSHAKE_8814B 0xffffffffL
#define BIT_FW_DRV_HANDSHAKE_8814B(x) \
(((x) & BIT_MASK_FW_DRV_HANDSHAKE_8814B) \
<< BIT_SHIFT_FW_DRV_HANDSHAKE_8814B)
#define BITS_FW_DRV_HANDSHAKE_8814B \
(BIT_MASK_FW_DRV_HANDSHAKE_8814B << BIT_SHIFT_FW_DRV_HANDSHAKE_8814B)
#define BIT_CLEAR_FW_DRV_HANDSHAKE_8814B(x) \
((x) & (~BITS_FW_DRV_HANDSHAKE_8814B))
#define BIT_GET_FW_DRV_HANDSHAKE_8814B(x) \
(((x) >> BIT_SHIFT_FW_DRV_HANDSHAKE_8814B) & \
BIT_MASK_FW_DRV_HANDSHAKE_8814B)
#define BIT_SET_FW_DRV_HANDSHAKE_8814B(x, v) \
(BIT_CLEAR_FW_DRV_HANDSHAKE_8814B(x) | BIT_FW_DRV_HANDSHAKE_8814B(v))
/* 2 REG_FW_DBG0_8814B */
#define BIT_SHIFT_FW_DBG0_8814B 0
#define BIT_MASK_FW_DBG0_8814B 0xffffffffL
#define BIT_FW_DBG0_8814B(x) \
(((x) & BIT_MASK_FW_DBG0_8814B) << BIT_SHIFT_FW_DBG0_8814B)
#define BITS_FW_DBG0_8814B (BIT_MASK_FW_DBG0_8814B << BIT_SHIFT_FW_DBG0_8814B)
#define BIT_CLEAR_FW_DBG0_8814B(x) ((x) & (~BITS_FW_DBG0_8814B))
#define BIT_GET_FW_DBG0_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG0_8814B) & BIT_MASK_FW_DBG0_8814B)
#define BIT_SET_FW_DBG0_8814B(x, v) \
(BIT_CLEAR_FW_DBG0_8814B(x) | BIT_FW_DBG0_8814B(v))
/* 2 REG_FW_DBG1_8814B */
#define BIT_SHIFT_FW_DBG1_8814B 0
#define BIT_MASK_FW_DBG1_8814B 0xffffffffL
#define BIT_FW_DBG1_8814B(x) \
(((x) & BIT_MASK_FW_DBG1_8814B) << BIT_SHIFT_FW_DBG1_8814B)
#define BITS_FW_DBG1_8814B (BIT_MASK_FW_DBG1_8814B << BIT_SHIFT_FW_DBG1_8814B)
#define BIT_CLEAR_FW_DBG1_8814B(x) ((x) & (~BITS_FW_DBG1_8814B))
#define BIT_GET_FW_DBG1_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG1_8814B) & BIT_MASK_FW_DBG1_8814B)
#define BIT_SET_FW_DBG1_8814B(x, v) \
(BIT_CLEAR_FW_DBG1_8814B(x) | BIT_FW_DBG1_8814B(v))
/* 2 REG_FW_DBG2_8814B */
#define BIT_SHIFT_FW_DBG2_8814B 0
#define BIT_MASK_FW_DBG2_8814B 0xffffffffL
#define BIT_FW_DBG2_8814B(x) \
(((x) & BIT_MASK_FW_DBG2_8814B) << BIT_SHIFT_FW_DBG2_8814B)
#define BITS_FW_DBG2_8814B (BIT_MASK_FW_DBG2_8814B << BIT_SHIFT_FW_DBG2_8814B)
#define BIT_CLEAR_FW_DBG2_8814B(x) ((x) & (~BITS_FW_DBG2_8814B))
#define BIT_GET_FW_DBG2_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG2_8814B) & BIT_MASK_FW_DBG2_8814B)
#define BIT_SET_FW_DBG2_8814B(x, v) \
(BIT_CLEAR_FW_DBG2_8814B(x) | BIT_FW_DBG2_8814B(v))
/* 2 REG_FW_DBG3_8814B */
#define BIT_SHIFT_FW_DBG3_8814B 0
#define BIT_MASK_FW_DBG3_8814B 0xffffffffL
#define BIT_FW_DBG3_8814B(x) \
(((x) & BIT_MASK_FW_DBG3_8814B) << BIT_SHIFT_FW_DBG3_8814B)
#define BITS_FW_DBG3_8814B (BIT_MASK_FW_DBG3_8814B << BIT_SHIFT_FW_DBG3_8814B)
#define BIT_CLEAR_FW_DBG3_8814B(x) ((x) & (~BITS_FW_DBG3_8814B))
#define BIT_GET_FW_DBG3_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG3_8814B) & BIT_MASK_FW_DBG3_8814B)
#define BIT_SET_FW_DBG3_8814B(x, v) \
(BIT_CLEAR_FW_DBG3_8814B(x) | BIT_FW_DBG3_8814B(v))
/* 2 REG_FW_DBG4_8814B */
#define BIT_SHIFT_FW_DBG4_8814B 0
#define BIT_MASK_FW_DBG4_8814B 0xffffffffL
#define BIT_FW_DBG4_8814B(x) \
(((x) & BIT_MASK_FW_DBG4_8814B) << BIT_SHIFT_FW_DBG4_8814B)
#define BITS_FW_DBG4_8814B (BIT_MASK_FW_DBG4_8814B << BIT_SHIFT_FW_DBG4_8814B)
#define BIT_CLEAR_FW_DBG4_8814B(x) ((x) & (~BITS_FW_DBG4_8814B))
#define BIT_GET_FW_DBG4_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG4_8814B) & BIT_MASK_FW_DBG4_8814B)
#define BIT_SET_FW_DBG4_8814B(x, v) \
(BIT_CLEAR_FW_DBG4_8814B(x) | BIT_FW_DBG4_8814B(v))
/* 2 REG_FW_DBG5_8814B */
#define BIT_SHIFT_FW_DBG5_8814B 0
#define BIT_MASK_FW_DBG5_8814B 0xffffffffL
#define BIT_FW_DBG5_8814B(x) \
(((x) & BIT_MASK_FW_DBG5_8814B) << BIT_SHIFT_FW_DBG5_8814B)
#define BITS_FW_DBG5_8814B (BIT_MASK_FW_DBG5_8814B << BIT_SHIFT_FW_DBG5_8814B)
#define BIT_CLEAR_FW_DBG5_8814B(x) ((x) & (~BITS_FW_DBG5_8814B))
#define BIT_GET_FW_DBG5_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG5_8814B) & BIT_MASK_FW_DBG5_8814B)
#define BIT_SET_FW_DBG5_8814B(x, v) \
(BIT_CLEAR_FW_DBG5_8814B(x) | BIT_FW_DBG5_8814B(v))
/* 2 REG_FW_DBG6_8814B */
#define BIT_SHIFT_FW_DBG6_8814B 0
#define BIT_MASK_FW_DBG6_8814B 0xffffffffL
#define BIT_FW_DBG6_8814B(x) \
(((x) & BIT_MASK_FW_DBG6_8814B) << BIT_SHIFT_FW_DBG6_8814B)
#define BITS_FW_DBG6_8814B (BIT_MASK_FW_DBG6_8814B << BIT_SHIFT_FW_DBG6_8814B)
#define BIT_CLEAR_FW_DBG6_8814B(x) ((x) & (~BITS_FW_DBG6_8814B))
#define BIT_GET_FW_DBG6_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG6_8814B) & BIT_MASK_FW_DBG6_8814B)
#define BIT_SET_FW_DBG6_8814B(x, v) \
(BIT_CLEAR_FW_DBG6_8814B(x) | BIT_FW_DBG6_8814B(v))
/* 2 REG_FW_DBG7_8814B */
#define BIT_SHIFT_FW_DBG7_8814B 0
#define BIT_MASK_FW_DBG7_8814B 0xffffffffL
#define BIT_FW_DBG7_8814B(x) \
(((x) & BIT_MASK_FW_DBG7_8814B) << BIT_SHIFT_FW_DBG7_8814B)
#define BITS_FW_DBG7_8814B (BIT_MASK_FW_DBG7_8814B << BIT_SHIFT_FW_DBG7_8814B)
#define BIT_CLEAR_FW_DBG7_8814B(x) ((x) & (~BITS_FW_DBG7_8814B))
#define BIT_GET_FW_DBG7_8814B(x) \
(((x) >> BIT_SHIFT_FW_DBG7_8814B) & BIT_MASK_FW_DBG7_8814B)
#define BIT_SET_FW_DBG7_8814B(x, v) \
(BIT_CLEAR_FW_DBG7_8814B(x) | BIT_FW_DBG7_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_CR_8814B */
#define BIT_SHIFT_LBMODE_8814B 24
#define BIT_MASK_LBMODE_8814B 0x1f
#define BIT_LBMODE_8814B(x) \
(((x) & BIT_MASK_LBMODE_8814B) << BIT_SHIFT_LBMODE_8814B)
#define BITS_LBMODE_8814B (BIT_MASK_LBMODE_8814B << BIT_SHIFT_LBMODE_8814B)
#define BIT_CLEAR_LBMODE_8814B(x) ((x) & (~BITS_LBMODE_8814B))
#define BIT_GET_LBMODE_8814B(x) \
(((x) >> BIT_SHIFT_LBMODE_8814B) & BIT_MASK_LBMODE_8814B)
#define BIT_SET_LBMODE_8814B(x, v) \
(BIT_CLEAR_LBMODE_8814B(x) | BIT_LBMODE_8814B(v))
#define BIT_SHIFT_NETYPE1_8814B 18
#define BIT_MASK_NETYPE1_8814B 0x3
#define BIT_NETYPE1_8814B(x) \
(((x) & BIT_MASK_NETYPE1_8814B) << BIT_SHIFT_NETYPE1_8814B)
#define BITS_NETYPE1_8814B (BIT_MASK_NETYPE1_8814B << BIT_SHIFT_NETYPE1_8814B)
#define BIT_CLEAR_NETYPE1_8814B(x) ((x) & (~BITS_NETYPE1_8814B))
#define BIT_GET_NETYPE1_8814B(x) \
(((x) >> BIT_SHIFT_NETYPE1_8814B) & BIT_MASK_NETYPE1_8814B)
#define BIT_SET_NETYPE1_8814B(x, v) \
(BIT_CLEAR_NETYPE1_8814B(x) | BIT_NETYPE1_8814B(v))
#define BIT_SHIFT_NETYPE0_8814B 16
#define BIT_MASK_NETYPE0_8814B 0x3
#define BIT_NETYPE0_8814B(x) \
(((x) & BIT_MASK_NETYPE0_8814B) << BIT_SHIFT_NETYPE0_8814B)
#define BITS_NETYPE0_8814B (BIT_MASK_NETYPE0_8814B << BIT_SHIFT_NETYPE0_8814B)
#define BIT_CLEAR_NETYPE0_8814B(x) ((x) & (~BITS_NETYPE0_8814B))
#define BIT_GET_NETYPE0_8814B(x) \
(((x) >> BIT_SHIFT_NETYPE0_8814B) & BIT_MASK_NETYPE0_8814B)
#define BIT_SET_NETYPE0_8814B(x, v) \
(BIT_CLEAR_NETYPE0_8814B(x) | BIT_NETYPE0_8814B(v))
#define BIT_COUNTER_STS_EN_8814B BIT(13)
#define BIT_I2C_MAILBOX_EN_8814B BIT(12)
#define BIT_SHCUT_EN_8814B BIT(11)
#define BIT_32K_CAL_TMR_EN_8814B BIT(10)
#define BIT_MAC_SEC_EN_8814B BIT(9)
#define BIT_ENSWBCN_8814B BIT(8)
#define BIT_MACRXEN_8814B BIT(7)
#define BIT_MACTXEN_8814B BIT(6)
#define BIT_SCHEDULE_EN_8814B BIT(5)
#define BIT_PROTOCOL_EN_8814B BIT(4)
#define BIT_RXDMA_EN_8814B BIT(3)
#define BIT_TXDMA_EN_8814B BIT(2)
#define BIT_HCI_RXDMA_EN_8814B BIT(1)
#define BIT_HCI_TXDMA_EN_8814B BIT(0)
/* 2 REG_PG_SIZE_8814B */
#define BIT_SHIFT_DBG_FIFO_SEL_8814B 16
#define BIT_MASK_DBG_FIFO_SEL_8814B 0xff
#define BIT_DBG_FIFO_SEL_8814B(x) \
(((x) & BIT_MASK_DBG_FIFO_SEL_8814B) << BIT_SHIFT_DBG_FIFO_SEL_8814B)
#define BITS_DBG_FIFO_SEL_8814B \
(BIT_MASK_DBG_FIFO_SEL_8814B << BIT_SHIFT_DBG_FIFO_SEL_8814B)
#define BIT_CLEAR_DBG_FIFO_SEL_8814B(x) ((x) & (~BITS_DBG_FIFO_SEL_8814B))
#define BIT_GET_DBG_FIFO_SEL_8814B(x) \
(((x) >> BIT_SHIFT_DBG_FIFO_SEL_8814B) & BIT_MASK_DBG_FIFO_SEL_8814B)
#define BIT_SET_DBG_FIFO_SEL_8814B(x, v) \
(BIT_CLEAR_DBG_FIFO_SEL_8814B(x) | BIT_DBG_FIFO_SEL_8814B(v))
/* 2 REG_PKT_BUFF_ACCESS_CTRL_8814B */
#define BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8814B 0
#define BIT_MASK_PKT_BUFF_ACCESS_CTRL_8814B 0xff
#define BIT_PKT_BUFF_ACCESS_CTRL_8814B(x) \
(((x) & BIT_MASK_PKT_BUFF_ACCESS_CTRL_8814B) \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8814B)
#define BITS_PKT_BUFF_ACCESS_CTRL_8814B \
(BIT_MASK_PKT_BUFF_ACCESS_CTRL_8814B \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8814B)
#define BIT_CLEAR_PKT_BUFF_ACCESS_CTRL_8814B(x) \
((x) & (~BITS_PKT_BUFF_ACCESS_CTRL_8814B))
#define BIT_GET_PKT_BUFF_ACCESS_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8814B) & \
BIT_MASK_PKT_BUFF_ACCESS_CTRL_8814B)
#define BIT_SET_PKT_BUFF_ACCESS_CTRL_8814B(x, v) \
(BIT_CLEAR_PKT_BUFF_ACCESS_CTRL_8814B(x) | \
BIT_PKT_BUFF_ACCESS_CTRL_8814B(v))
/* 2 REG_TSF_CLK_STATE_8814B */
#define BIT_TSF_CLK_STABLE_8814B BIT(15)
/* 2 REG_TXDMA_PQ_MAP_8814B */
#define BIT_SHIFT_TXDMA_H2C_MAP_8814B 16
#define BIT_MASK_TXDMA_H2C_MAP_8814B 0x3
#define BIT_TXDMA_H2C_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_H2C_MAP_8814B) << BIT_SHIFT_TXDMA_H2C_MAP_8814B)
#define BITS_TXDMA_H2C_MAP_8814B \
(BIT_MASK_TXDMA_H2C_MAP_8814B << BIT_SHIFT_TXDMA_H2C_MAP_8814B)
#define BIT_CLEAR_TXDMA_H2C_MAP_8814B(x) ((x) & (~BITS_TXDMA_H2C_MAP_8814B))
#define BIT_GET_TXDMA_H2C_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_H2C_MAP_8814B) & BIT_MASK_TXDMA_H2C_MAP_8814B)
#define BIT_SET_TXDMA_H2C_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_H2C_MAP_8814B(x) | BIT_TXDMA_H2C_MAP_8814B(v))
#define BIT_SHIFT_TXDMA_HIQ_MAP_8814B 14
#define BIT_MASK_TXDMA_HIQ_MAP_8814B 0x3
#define BIT_TXDMA_HIQ_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP_8814B) << BIT_SHIFT_TXDMA_HIQ_MAP_8814B)
#define BITS_TXDMA_HIQ_MAP_8814B \
(BIT_MASK_TXDMA_HIQ_MAP_8814B << BIT_SHIFT_TXDMA_HIQ_MAP_8814B)
#define BIT_CLEAR_TXDMA_HIQ_MAP_8814B(x) ((x) & (~BITS_TXDMA_HIQ_MAP_8814B))
#define BIT_GET_TXDMA_HIQ_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP_8814B) & BIT_MASK_TXDMA_HIQ_MAP_8814B)
#define BIT_SET_TXDMA_HIQ_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP_8814B(x) | BIT_TXDMA_HIQ_MAP_8814B(v))
#define BIT_SHIFT_TXDMA_MGQ_MAP_8814B 12
#define BIT_MASK_TXDMA_MGQ_MAP_8814B 0x3
#define BIT_TXDMA_MGQ_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP_8814B) << BIT_SHIFT_TXDMA_MGQ_MAP_8814B)
#define BITS_TXDMA_MGQ_MAP_8814B \
(BIT_MASK_TXDMA_MGQ_MAP_8814B << BIT_SHIFT_TXDMA_MGQ_MAP_8814B)
#define BIT_CLEAR_TXDMA_MGQ_MAP_8814B(x) ((x) & (~BITS_TXDMA_MGQ_MAP_8814B))
#define BIT_GET_TXDMA_MGQ_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP_8814B) & BIT_MASK_TXDMA_MGQ_MAP_8814B)
#define BIT_SET_TXDMA_MGQ_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP_8814B(x) | BIT_TXDMA_MGQ_MAP_8814B(v))
#define BIT_SHIFT_TXDMA_BKQ_MAP_8814B 10
#define BIT_MASK_TXDMA_BKQ_MAP_8814B 0x3
#define BIT_TXDMA_BKQ_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP_8814B) << BIT_SHIFT_TXDMA_BKQ_MAP_8814B)
#define BITS_TXDMA_BKQ_MAP_8814B \
(BIT_MASK_TXDMA_BKQ_MAP_8814B << BIT_SHIFT_TXDMA_BKQ_MAP_8814B)
#define BIT_CLEAR_TXDMA_BKQ_MAP_8814B(x) ((x) & (~BITS_TXDMA_BKQ_MAP_8814B))
#define BIT_GET_TXDMA_BKQ_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP_8814B) & BIT_MASK_TXDMA_BKQ_MAP_8814B)
#define BIT_SET_TXDMA_BKQ_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP_8814B(x) | BIT_TXDMA_BKQ_MAP_8814B(v))
#define BIT_SHIFT_TXDMA_BEQ_MAP_8814B 8
#define BIT_MASK_TXDMA_BEQ_MAP_8814B 0x3
#define BIT_TXDMA_BEQ_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP_8814B) << BIT_SHIFT_TXDMA_BEQ_MAP_8814B)
#define BITS_TXDMA_BEQ_MAP_8814B \
(BIT_MASK_TXDMA_BEQ_MAP_8814B << BIT_SHIFT_TXDMA_BEQ_MAP_8814B)
#define BIT_CLEAR_TXDMA_BEQ_MAP_8814B(x) ((x) & (~BITS_TXDMA_BEQ_MAP_8814B))
#define BIT_GET_TXDMA_BEQ_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP_8814B) & BIT_MASK_TXDMA_BEQ_MAP_8814B)
#define BIT_SET_TXDMA_BEQ_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP_8814B(x) | BIT_TXDMA_BEQ_MAP_8814B(v))
#define BIT_SHIFT_TXDMA_VIQ_MAP_8814B 6
#define BIT_MASK_TXDMA_VIQ_MAP_8814B 0x3
#define BIT_TXDMA_VIQ_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP_8814B) << BIT_SHIFT_TXDMA_VIQ_MAP_8814B)
#define BITS_TXDMA_VIQ_MAP_8814B \
(BIT_MASK_TXDMA_VIQ_MAP_8814B << BIT_SHIFT_TXDMA_VIQ_MAP_8814B)
#define BIT_CLEAR_TXDMA_VIQ_MAP_8814B(x) ((x) & (~BITS_TXDMA_VIQ_MAP_8814B))
#define BIT_GET_TXDMA_VIQ_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP_8814B) & BIT_MASK_TXDMA_VIQ_MAP_8814B)
#define BIT_SET_TXDMA_VIQ_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP_8814B(x) | BIT_TXDMA_VIQ_MAP_8814B(v))
#define BIT_SHIFT_TXDMA_VOQ_MAP_8814B 4
#define BIT_MASK_TXDMA_VOQ_MAP_8814B 0x3
#define BIT_TXDMA_VOQ_MAP_8814B(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP_8814B) << BIT_SHIFT_TXDMA_VOQ_MAP_8814B)
#define BITS_TXDMA_VOQ_MAP_8814B \
(BIT_MASK_TXDMA_VOQ_MAP_8814B << BIT_SHIFT_TXDMA_VOQ_MAP_8814B)
#define BIT_CLEAR_TXDMA_VOQ_MAP_8814B(x) ((x) & (~BITS_TXDMA_VOQ_MAP_8814B))
#define BIT_GET_TXDMA_VOQ_MAP_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP_8814B) & BIT_MASK_TXDMA_VOQ_MAP_8814B)
#define BIT_SET_TXDMA_VOQ_MAP_8814B(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP_8814B(x) | BIT_TXDMA_VOQ_MAP_8814B(v))
#define BIT_RXDMA_AGG_EN_8814B BIT(2)
#define BIT_RXSHFT_EN_8814B BIT(1)
#define BIT_RXDMA_ARBBW_EN_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TRXFF_BNDY_8814B */
#define BIT_SHIFT_FWFFOVFL_RSV_8814B 16
#define BIT_MASK_FWFFOVFL_RSV_8814B 0xf
#define BIT_FWFFOVFL_RSV_8814B(x) \
(((x) & BIT_MASK_FWFFOVFL_RSV_8814B) << BIT_SHIFT_FWFFOVFL_RSV_8814B)
#define BITS_FWFFOVFL_RSV_8814B \
(BIT_MASK_FWFFOVFL_RSV_8814B << BIT_SHIFT_FWFFOVFL_RSV_8814B)
#define BIT_CLEAR_FWFFOVFL_RSV_8814B(x) ((x) & (~BITS_FWFFOVFL_RSV_8814B))
#define BIT_GET_FWFFOVFL_RSV_8814B(x) \
(((x) >> BIT_SHIFT_FWFFOVFL_RSV_8814B) & BIT_MASK_FWFFOVFL_RSV_8814B)
#define BIT_SET_FWFFOVFL_RSV_8814B(x, v) \
(BIT_CLEAR_FWFFOVFL_RSV_8814B(x) | BIT_FWFFOVFL_RSV_8814B(v))
#define BIT_SHIFT_RXFFOVFL_RSV_V2_8814B 8
#define BIT_MASK_RXFFOVFL_RSV_V2_8814B 0xf
#define BIT_RXFFOVFL_RSV_V2_8814B(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V2_8814B) \
<< BIT_SHIFT_RXFFOVFL_RSV_V2_8814B)
#define BITS_RXFFOVFL_RSV_V2_8814B \
(BIT_MASK_RXFFOVFL_RSV_V2_8814B << BIT_SHIFT_RXFFOVFL_RSV_V2_8814B)
#define BIT_CLEAR_RXFFOVFL_RSV_V2_8814B(x) ((x) & (~BITS_RXFFOVFL_RSV_V2_8814B))
#define BIT_GET_RXFFOVFL_RSV_V2_8814B(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V2_8814B) & \
BIT_MASK_RXFFOVFL_RSV_V2_8814B)
#define BIT_SET_RXFFOVFL_RSV_V2_8814B(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V2_8814B(x) | BIT_RXFFOVFL_RSV_V2_8814B(v))
/* 2 REG_PTA_I2C_MBOX_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_I2C_M_STATUS_8814B 8
#define BIT_MASK_I2C_M_STATUS_8814B 0xf
#define BIT_I2C_M_STATUS_8814B(x) \
(((x) & BIT_MASK_I2C_M_STATUS_8814B) << BIT_SHIFT_I2C_M_STATUS_8814B)
#define BITS_I2C_M_STATUS_8814B \
(BIT_MASK_I2C_M_STATUS_8814B << BIT_SHIFT_I2C_M_STATUS_8814B)
#define BIT_CLEAR_I2C_M_STATUS_8814B(x) ((x) & (~BITS_I2C_M_STATUS_8814B))
#define BIT_GET_I2C_M_STATUS_8814B(x) \
(((x) >> BIT_SHIFT_I2C_M_STATUS_8814B) & BIT_MASK_I2C_M_STATUS_8814B)
#define BIT_SET_I2C_M_STATUS_8814B(x, v) \
(BIT_CLEAR_I2C_M_STATUS_8814B(x) | BIT_I2C_M_STATUS_8814B(v))
#define BIT_SHIFT_I2C_M_BUS_GNT_FW_8814B 4
#define BIT_MASK_I2C_M_BUS_GNT_FW_8814B 0x7
#define BIT_I2C_M_BUS_GNT_FW_8814B(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT_FW_8814B) \
<< BIT_SHIFT_I2C_M_BUS_GNT_FW_8814B)
#define BITS_I2C_M_BUS_GNT_FW_8814B \
(BIT_MASK_I2C_M_BUS_GNT_FW_8814B << BIT_SHIFT_I2C_M_BUS_GNT_FW_8814B)
#define BIT_CLEAR_I2C_M_BUS_GNT_FW_8814B(x) \
((x) & (~BITS_I2C_M_BUS_GNT_FW_8814B))
#define BIT_GET_I2C_M_BUS_GNT_FW_8814B(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT_FW_8814B) & \
BIT_MASK_I2C_M_BUS_GNT_FW_8814B)
#define BIT_SET_I2C_M_BUS_GNT_FW_8814B(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT_FW_8814B(x) | BIT_I2C_M_BUS_GNT_FW_8814B(v))
#define BIT_I2C_M_GNT_FW_8814B BIT(3)
#define BIT_SHIFT_I2C_M_SPEED_8814B 1
#define BIT_MASK_I2C_M_SPEED_8814B 0x3
#define BIT_I2C_M_SPEED_8814B(x) \
(((x) & BIT_MASK_I2C_M_SPEED_8814B) << BIT_SHIFT_I2C_M_SPEED_8814B)
#define BITS_I2C_M_SPEED_8814B \
(BIT_MASK_I2C_M_SPEED_8814B << BIT_SHIFT_I2C_M_SPEED_8814B)
#define BIT_CLEAR_I2C_M_SPEED_8814B(x) ((x) & (~BITS_I2C_M_SPEED_8814B))
#define BIT_GET_I2C_M_SPEED_8814B(x) \
(((x) >> BIT_SHIFT_I2C_M_SPEED_8814B) & BIT_MASK_I2C_M_SPEED_8814B)
#define BIT_SET_I2C_M_SPEED_8814B(x, v) \
(BIT_CLEAR_I2C_M_SPEED_8814B(x) | BIT_I2C_M_SPEED_8814B(v))
#define BIT_I2C_M_UNLOCK_8814B BIT(0)
/* 2 REG_RXFF_BNDY_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_RXFF0_BNDY_V2_8814B 0
#define BIT_MASK_RXFF0_BNDY_V2_8814B 0x3ffff
#define BIT_RXFF0_BNDY_V2_8814B(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V2_8814B) << BIT_SHIFT_RXFF0_BNDY_V2_8814B)
#define BITS_RXFF0_BNDY_V2_8814B \
(BIT_MASK_RXFF0_BNDY_V2_8814B << BIT_SHIFT_RXFF0_BNDY_V2_8814B)
#define BIT_CLEAR_RXFF0_BNDY_V2_8814B(x) ((x) & (~BITS_RXFF0_BNDY_V2_8814B))
#define BIT_GET_RXFF0_BNDY_V2_8814B(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V2_8814B) & BIT_MASK_RXFF0_BNDY_V2_8814B)
#define BIT_SET_RXFF0_BNDY_V2_8814B(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V2_8814B(x) | BIT_RXFF0_BNDY_V2_8814B(v))
/* 2 REG_FE1IMR_8814B */
#define BIT_CPUMGQ_DROP_BY_HOLD_TIME_INT_EN_8814B BIT(31)
#define BIT_FWFF_FULL_INT_EN_8814B BIT(30)
#define BIT_BB_STOP_RX_INT_EN_8814B BIT(29)
#define BIT_FS_RXDMA2_DONE_INT_EN_8814B BIT(28)
#define BIT_FS_RXDONE3_INT_EN_8814B BIT(27)
#define BIT_FS_RXDONE2_INT_EN_8814B BIT(26)
#define BIT_FS_RX_BCN_P4_INT_EN_8814B BIT(25)
#define BIT_FS_RX_BCN_P3_INT_EN_8814B BIT(24)
#define BIT_FS_RX_BCN_P2_INT_EN_8814B BIT(23)
#define BIT_FS_RX_BCN_P1_INT_EN_8814B BIT(22)
#define BIT_FS_RX_BCN_P0_INT_EN_8814B BIT(21)
#define BIT_FS_RX_UMD0_INT_EN_8814B BIT(20)
#define BIT_FS_RX_UMD1_INT_EN_8814B BIT(19)
#define BIT_FS_RX_BMD0_INT_EN_8814B BIT(18)
#define BIT_FS_RX_BMD1_INT_EN_8814B BIT(17)
#define BIT_FS_RXDONE_INT_EN_8814B BIT(16)
#define BIT_FS_WWLAN_INT_EN_8814B BIT(15)
#define BIT_FS_SOUND_DONE_INT_EN_8814B BIT(14)
#define BIT_FS_TRL_MTR_INT_EN_8814B BIT(12)
#define BIT_FS_BF1_PRETO_INT_EN_8814B BIT(11)
#define BIT_FS_BF0_PRETO_INT_EN_8814B BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_EN_8814B BIT(9)
#define BIT_PRETX_ERRHLD_INT_EN_8814B BIT(8)
#define BIT_FS_GTRD_INT_EN_8814B BIT(7)
#define BIT_FS_LTE_COEX_EN_8814B BIT(6)
#define BIT_FS_WLACTOFF_INT_EN_8814B BIT(5)
#define BIT_FS_WLACTON_INT_EN_8814B BIT(4)
#define BIT_FS_BTCMD_INT_EN_8814B BIT(3)
#define BIT_FS_REG_MAILBOX_TO_I2C_INT_EN_8814B BIT(2)
#define BIT_FS_TRPC_TO_INT_EN_V1_8814B BIT(1)
#define BIT_FS_RPC_O_T_INT_EN_V1_8814B BIT(0)
/* 2 REG_FE1ISR_8814B */
#define BIT_CPUMGQ_DROP_BY_HOLD_TIME_INT_8814B BIT(31)
#define BIT_FWFF_FULL_INT_8814B BIT(30)
#define BIT_BB_STOP_RX_INT_8814B BIT(29)
#define BIT_FS_RXDMA2_DONE_INT_8814B BIT(28)
#define BIT_FS_RXDONE3_INT_INT_8814B BIT(27)
#define BIT_FS_RXDONE2_INT_8814B BIT(26)
#define BIT_FS_RX_BCN_P4_INT_8814B BIT(25)
#define BIT_FS_RX_BCN_P3_INT_8814B BIT(24)
#define BIT_FS_RX_BCN_P2_INT_8814B BIT(23)
#define BIT_FS_RX_BCN_P1_INT_8814B BIT(22)
#define BIT_FS_RX_BCN_P0_INT_8814B BIT(21)
#define BIT_FS_RX_UMD0_INT_8814B BIT(20)
#define BIT_FS_RX_UMD1_INT_8814B BIT(19)
#define BIT_FS_RX_BMD0_INT_8814B BIT(18)
#define BIT_FS_RX_BMD1_INT_8814B BIT(17)
#define BIT_FS_RXDONE_INT_8814B BIT(16)
#define BIT_FS_WWLAN_INT_8814B BIT(15)
#define BIT_FS_SOUND_DONE_INT_8814B BIT(14)
#define BIT_FS_TRL_MTR_INT_8814B BIT(12)
#define BIT_FS_BF1_PRETO_INT_8814B BIT(11)
#define BIT_FS_BF0_PRETO_INT_8814B BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_8814B BIT(9)
#define BIT_PRETX_ERRHLD_INT_8814B BIT(8)
#define BIT_SND_RDY_INT_8814B BIT(7)
#define BIT_FS_LTE_COEX_INT_8814B BIT(6)
#define BIT_FS_WLACTOFF_INT_8814B BIT(5)
#define BIT_FS_WLACTON_INT_8814B BIT(4)
#define BIT_BT_CMD_INT_8814B BIT(3)
#define BIT_FS_MAILBOX_TO_I2C_INT_8814B BIT(2)
#define BIT_FS_TRPC_TO_INT_8814B BIT(1)
#define BIT_FS_RPC_O_T_INT_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_CPWM_8814B */
#define BIT_CPWM_TOGGLING_8814B BIT(31)
#define BIT_SHIFT_CPWM_MOD_8814B 24
#define BIT_MASK_CPWM_MOD_8814B 0x7f
#define BIT_CPWM_MOD_8814B(x) \
(((x) & BIT_MASK_CPWM_MOD_8814B) << BIT_SHIFT_CPWM_MOD_8814B)
#define BITS_CPWM_MOD_8814B \
(BIT_MASK_CPWM_MOD_8814B << BIT_SHIFT_CPWM_MOD_8814B)
#define BIT_CLEAR_CPWM_MOD_8814B(x) ((x) & (~BITS_CPWM_MOD_8814B))
#define BIT_GET_CPWM_MOD_8814B(x) \
(((x) >> BIT_SHIFT_CPWM_MOD_8814B) & BIT_MASK_CPWM_MOD_8814B)
#define BIT_SET_CPWM_MOD_8814B(x, v) \
(BIT_CLEAR_CPWM_MOD_8814B(x) | BIT_CPWM_MOD_8814B(v))
/* 2 REG_FWIMR_8814B */
#define BIT_FS_TXBCNOK_MB7_INT_EN_8814B BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_EN_8814B BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_EN_8814B BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_EN_8814B BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_EN_8814B BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_EN_8814B BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_EN_8814B BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_EN_8814B BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_EN_8814B BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_EN_8814B BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_EN_8814B BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_EN_8814B BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_EN_8814B BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_EN_8814B BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_EN_8814B BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_EN_8814B BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_EN_8814B BIT(15)
#define BIT_SIFS_OVERSPEC_INT_EN_8814B BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_EN_8814B BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_EN_8814B BIT(12)
#define BIT_FS_CPUMGQ_ERR_INT_EN_8814B BIT(11)
#define BIT_FS_DDMA0_LP_INT_EN_8814B BIT(9)
#define BIT_FS_DDMA0_HP_INT_EN_8814B BIT(8)
#define BIT_FS_TRXRPT_INT_EN_8814B BIT(7)
#define BIT_FS_C2H_W_READY_INT_EN_8814B BIT(6)
#define BIT_FS_HRCV_INT_EN_8814B BIT(5)
#define BIT_FS_H2CCMD_INT_EN_8814B BIT(4)
#define BIT_FS_TXPKTIN_INT_EN_8814B BIT(3)
#define BIT_FS_ERRORHDL_INT_EN_8814B BIT(2)
#define BIT_FS_TXCCX_INT_EN_8814B BIT(1)
#define BIT_FS_TXCLOSE_INT_EN_8814B BIT(0)
/* 2 REG_FWISR_8814B */
#define BIT_FS_TXBCNOK_MB7_INT_8814B BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_8814B BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_8814B BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_8814B BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_8814B BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_8814B BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_8814B BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_8814B BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_8814B BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_8814B BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_8814B BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_8814B BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_8814B BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_8814B BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_8814B BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_8814B BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_8814B BIT(15)
#define BIT_SIFS_OVERSPEC_INT_8814B BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_8814B BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_8814B BIT(12)
#define BIT_FS_CPUMGQ_ERR_INT_8814B BIT(11)
#define BIT_FWCMD_PKTIN_INT_8814B BIT(10)
#define BIT_FS_DDMA0_LP_INT_8814B BIT(9)
#define BIT_FS_DDMA0_HP_INT_8814B BIT(8)
#define BIT_FS_TRXRPT_INT_8814B BIT(7)
#define BIT_FS_C2H_W_READY_INT_8814B BIT(6)
#define BIT_FS_HRCV_INT_8814B BIT(5)
#define BIT_FS_H2CCMD_INT_8814B BIT(4)
#define BIT_FS_TXPKTIN_INT_8814B BIT(3)
#define BIT_FS_ERRORHDL_INT_8814B BIT(2)
#define BIT_FS_TXCCX_INT_8814B BIT(1)
#define BIT_FS_TXCLOSE_INT_8814B BIT(0)
/* 2 REG_FTIMR_8814B */
#define BIT_PS_TIMER_C_EARLY_INT_EN_8814B BIT(23)
#define BIT_PS_TIMER_B_EARLY_INT_EN_8814B BIT(22)
#define BIT_PS_TIMER_A_EARLY_INT_EN_8814B BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_EN_8814B BIT(20)
#define BIT_PS_TIMER_C_INT_EN_8814B BIT(19)
#define BIT_PS_TIMER_B_INT_EN_8814B BIT(18)
#define BIT_PS_TIMER_A_INT_EN_8814B BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_EN_8814B BIT(16)
#define BIT_FS_PS_TIMEOUT2_EN_8814B BIT(15)
#define BIT_FS_PS_TIMEOUT1_EN_8814B BIT(14)
#define BIT_FS_PS_TIMEOUT0_EN_8814B BIT(13)
#define BIT_FS_GTINT12_EN_8814B BIT(12)
#define BIT_FS_GTINT11_EN_8814B BIT(11)
#define BIT_FS_GTINT10_EN_8814B BIT(10)
#define BIT_FS_GTINT9_EN_8814B BIT(9)
#define BIT_FS_GTINT8_EN_8814B BIT(8)
#define BIT_FS_GTINT7_EN_8814B BIT(7)
#define BIT_FS_GTINT6_EN_8814B BIT(6)
#define BIT_FS_GTINT5_EN_8814B BIT(5)
#define BIT_FS_GTINT4_EN_8814B BIT(4)
#define BIT_FS_GTINT3_EN_8814B BIT(3)
#define BIT_FS_GTINT2_EN_8814B BIT(2)
#define BIT_FS_GTINT1_EN_8814B BIT(1)
#define BIT_FS_GTINT0_EN_8814B BIT(0)
/* 2 REG_FTISR_8814B */
#define BIT_PS_TIMER_5_EARLY__INT_8814B BIT(26)
#define BIT_PS_TIMER_4_EARLY__INT_8814B BIT(25)
#define BIT_PS_TIMER_3_EARLY__INT_8814B BIT(24)
#define BIT_PS_TIMER_2_EARLY__INT_8814B BIT(23)
#define BIT_PS_TIMER_1_EARLY__INT_8814B BIT(22)
#define BIT_PS_TIMER_0_EARLY__INT_8814B BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_8814B BIT(20)
#define BIT_PS_TIMER_5_INT_8814B BIT(19)
#define BIT_PS_TIMER_4_INT_8814B BIT(18)
#define BIT_PS_TIMER_3_INT_8814B BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_8814B BIT(16)
#define BIT_PS_TIMER_2_INT_8814B BIT(15)
#define BIT_PS_TIMER_1_INT_8814B BIT(14)
#define BIT_PS_TIMER_0_INT_8814B BIT(13)
#define BIT_FS_GTINT12_INT_8814B BIT(12)
#define BIT_FS_GTINT11_INT_8814B BIT(11)
#define BIT_FS_GTINT10_INT_8814B BIT(10)
#define BIT_FS_GTINT9_INT_8814B BIT(9)
#define BIT_FS_GTINT8_INT_8814B BIT(8)
#define BIT_FS_GTINT7_INT_8814B BIT(7)
#define BIT_FS_GTINT6_INT_8814B BIT(6)
#define BIT_FS_GTINT5_INT_8814B BIT(5)
#define BIT_FS_GTINT4_INT_8814B BIT(4)
#define BIT_FS_GTINT3_INT_8814B BIT(3)
#define BIT_FS_GTINT2_INT_8814B BIT(2)
#define BIT_FS_GTINT1_INT_8814B BIT(1)
#define BIT_FS_GTINT0_INT_8814B BIT(0)
/* 2 REG_PKTBUF_DBG_CTRL_8814B */
#define BIT_SHIFT_PKTBUF_WRITE_EN_8814B 24
#define BIT_MASK_PKTBUF_WRITE_EN_8814B 0xff
#define BIT_PKTBUF_WRITE_EN_8814B(x) \
(((x) & BIT_MASK_PKTBUF_WRITE_EN_8814B) \
<< BIT_SHIFT_PKTBUF_WRITE_EN_8814B)
#define BITS_PKTBUF_WRITE_EN_8814B \
(BIT_MASK_PKTBUF_WRITE_EN_8814B << BIT_SHIFT_PKTBUF_WRITE_EN_8814B)
#define BIT_CLEAR_PKTBUF_WRITE_EN_8814B(x) ((x) & (~BITS_PKTBUF_WRITE_EN_8814B))
#define BIT_GET_PKTBUF_WRITE_EN_8814B(x) \
(((x) >> BIT_SHIFT_PKTBUF_WRITE_EN_8814B) & \
BIT_MASK_PKTBUF_WRITE_EN_8814B)
#define BIT_SET_PKTBUF_WRITE_EN_8814B(x, v) \
(BIT_CLEAR_PKTBUF_WRITE_EN_8814B(x) | BIT_PKTBUF_WRITE_EN_8814B(v))
#define BIT_TXRPTBUF_DBG_8814B BIT(23)
/* 2 REG_NOT_VALID_8814B */
#define BIT_TXPKTBUF_DBG_V2_8814B BIT(20)
#define BIT_RXPKTBUF_DBG_8814B BIT(16)
#define BIT_SHIFT_PKTBUF_DBG_ADDR_8814B 0
#define BIT_MASK_PKTBUF_DBG_ADDR_8814B 0x1fff
#define BIT_PKTBUF_DBG_ADDR_8814B(x) \
(((x) & BIT_MASK_PKTBUF_DBG_ADDR_8814B) \
<< BIT_SHIFT_PKTBUF_DBG_ADDR_8814B)
#define BITS_PKTBUF_DBG_ADDR_8814B \
(BIT_MASK_PKTBUF_DBG_ADDR_8814B << BIT_SHIFT_PKTBUF_DBG_ADDR_8814B)
#define BIT_CLEAR_PKTBUF_DBG_ADDR_8814B(x) ((x) & (~BITS_PKTBUF_DBG_ADDR_8814B))
#define BIT_GET_PKTBUF_DBG_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_ADDR_8814B) & \
BIT_MASK_PKTBUF_DBG_ADDR_8814B)
#define BIT_SET_PKTBUF_DBG_ADDR_8814B(x, v) \
(BIT_CLEAR_PKTBUF_DBG_ADDR_8814B(x) | BIT_PKTBUF_DBG_ADDR_8814B(v))
/* 2 REG_PKTBUF_DBG_DATA_L_8814B */
#define BIT_SHIFT_PKTBUF_DBG_DATA_L_8814B 0
#define BIT_MASK_PKTBUF_DBG_DATA_L_8814B 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_L_8814B(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_L_8814B) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_L_8814B)
#define BITS_PKTBUF_DBG_DATA_L_8814B \
(BIT_MASK_PKTBUF_DBG_DATA_L_8814B << BIT_SHIFT_PKTBUF_DBG_DATA_L_8814B)
#define BIT_CLEAR_PKTBUF_DBG_DATA_L_8814B(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_L_8814B))
#define BIT_GET_PKTBUF_DBG_DATA_L_8814B(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_L_8814B) & \
BIT_MASK_PKTBUF_DBG_DATA_L_8814B)
#define BIT_SET_PKTBUF_DBG_DATA_L_8814B(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_L_8814B(x) | BIT_PKTBUF_DBG_DATA_L_8814B(v))
/* 2 REG_PKTBUF_DBG_DATA_H_8814B */
#define BIT_SHIFT_PKTBUF_DBG_DATA_H_8814B 0
#define BIT_MASK_PKTBUF_DBG_DATA_H_8814B 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_H_8814B(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_H_8814B) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_H_8814B)
#define BITS_PKTBUF_DBG_DATA_H_8814B \
(BIT_MASK_PKTBUF_DBG_DATA_H_8814B << BIT_SHIFT_PKTBUF_DBG_DATA_H_8814B)
#define BIT_CLEAR_PKTBUF_DBG_DATA_H_8814B(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_H_8814B))
#define BIT_GET_PKTBUF_DBG_DATA_H_8814B(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_H_8814B) & \
BIT_MASK_PKTBUF_DBG_DATA_H_8814B)
#define BIT_SET_PKTBUF_DBG_DATA_H_8814B(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_H_8814B(x) | BIT_PKTBUF_DBG_DATA_H_8814B(v))
/* 2 REG_CPWM2_8814B */
#define BIT_SHIFT_L0S_TO_RCVY_NUM_8814B 16
#define BIT_MASK_L0S_TO_RCVY_NUM_8814B 0xff
#define BIT_L0S_TO_RCVY_NUM_8814B(x) \
(((x) & BIT_MASK_L0S_TO_RCVY_NUM_8814B) \
<< BIT_SHIFT_L0S_TO_RCVY_NUM_8814B)
#define BITS_L0S_TO_RCVY_NUM_8814B \
(BIT_MASK_L0S_TO_RCVY_NUM_8814B << BIT_SHIFT_L0S_TO_RCVY_NUM_8814B)
#define BIT_CLEAR_L0S_TO_RCVY_NUM_8814B(x) ((x) & (~BITS_L0S_TO_RCVY_NUM_8814B))
#define BIT_GET_L0S_TO_RCVY_NUM_8814B(x) \
(((x) >> BIT_SHIFT_L0S_TO_RCVY_NUM_8814B) & \
BIT_MASK_L0S_TO_RCVY_NUM_8814B)
#define BIT_SET_L0S_TO_RCVY_NUM_8814B(x, v) \
(BIT_CLEAR_L0S_TO_RCVY_NUM_8814B(x) | BIT_L0S_TO_RCVY_NUM_8814B(v))
#define BIT_CPWM2_TOGGLING_8814B BIT(15)
#define BIT_SHIFT_CPWM2_MOD_8814B 0
#define BIT_MASK_CPWM2_MOD_8814B 0x7fff
#define BIT_CPWM2_MOD_8814B(x) \
(((x) & BIT_MASK_CPWM2_MOD_8814B) << BIT_SHIFT_CPWM2_MOD_8814B)
#define BITS_CPWM2_MOD_8814B \
(BIT_MASK_CPWM2_MOD_8814B << BIT_SHIFT_CPWM2_MOD_8814B)
#define BIT_CLEAR_CPWM2_MOD_8814B(x) ((x) & (~BITS_CPWM2_MOD_8814B))
#define BIT_GET_CPWM2_MOD_8814B(x) \
(((x) >> BIT_SHIFT_CPWM2_MOD_8814B) & BIT_MASK_CPWM2_MOD_8814B)
#define BIT_SET_CPWM2_MOD_8814B(x, v) \
(BIT_CLEAR_CPWM2_MOD_8814B(x) | BIT_CPWM2_MOD_8814B(v))
/* 2 REG_TC0_CTRL_8814B */
#define BIT_TC0INT_EN_8814B BIT(26)
#define BIT_TC0MODE_8814B BIT(25)
#define BIT_TC0EN_8814B BIT(24)
#define BIT_SHIFT_TC0DATA_8814B 0
#define BIT_MASK_TC0DATA_8814B 0xffffff
#define BIT_TC0DATA_8814B(x) \
(((x) & BIT_MASK_TC0DATA_8814B) << BIT_SHIFT_TC0DATA_8814B)
#define BITS_TC0DATA_8814B (BIT_MASK_TC0DATA_8814B << BIT_SHIFT_TC0DATA_8814B)
#define BIT_CLEAR_TC0DATA_8814B(x) ((x) & (~BITS_TC0DATA_8814B))
#define BIT_GET_TC0DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC0DATA_8814B) & BIT_MASK_TC0DATA_8814B)
#define BIT_SET_TC0DATA_8814B(x, v) \
(BIT_CLEAR_TC0DATA_8814B(x) | BIT_TC0DATA_8814B(v))
/* 2 REG_TC1_CTRL_8814B */
#define BIT_TC1INT_EN_8814B BIT(26)
#define BIT_TC1MODE_8814B BIT(25)
#define BIT_TC1EN_8814B BIT(24)
#define BIT_SHIFT_TC1DATA_8814B 0
#define BIT_MASK_TC1DATA_8814B 0xffffff
#define BIT_TC1DATA_8814B(x) \
(((x) & BIT_MASK_TC1DATA_8814B) << BIT_SHIFT_TC1DATA_8814B)
#define BITS_TC1DATA_8814B (BIT_MASK_TC1DATA_8814B << BIT_SHIFT_TC1DATA_8814B)
#define BIT_CLEAR_TC1DATA_8814B(x) ((x) & (~BITS_TC1DATA_8814B))
#define BIT_GET_TC1DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC1DATA_8814B) & BIT_MASK_TC1DATA_8814B)
#define BIT_SET_TC1DATA_8814B(x, v) \
(BIT_CLEAR_TC1DATA_8814B(x) | BIT_TC1DATA_8814B(v))
/* 2 REG_TC2_CTRL_8814B */
#define BIT_TC2INT_EN_8814B BIT(26)
#define BIT_TC2MODE_8814B BIT(25)
#define BIT_TC2EN_8814B BIT(24)
#define BIT_SHIFT_TC2DATA_8814B 0
#define BIT_MASK_TC2DATA_8814B 0xffffff
#define BIT_TC2DATA_8814B(x) \
(((x) & BIT_MASK_TC2DATA_8814B) << BIT_SHIFT_TC2DATA_8814B)
#define BITS_TC2DATA_8814B (BIT_MASK_TC2DATA_8814B << BIT_SHIFT_TC2DATA_8814B)
#define BIT_CLEAR_TC2DATA_8814B(x) ((x) & (~BITS_TC2DATA_8814B))
#define BIT_GET_TC2DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC2DATA_8814B) & BIT_MASK_TC2DATA_8814B)
#define BIT_SET_TC2DATA_8814B(x, v) \
(BIT_CLEAR_TC2DATA_8814B(x) | BIT_TC2DATA_8814B(v))
/* 2 REG_TC3_CTRL_8814B */
#define BIT_TC3INT_EN_8814B BIT(26)
#define BIT_TC3MODE_8814B BIT(25)
#define BIT_TC3EN_8814B BIT(24)
#define BIT_SHIFT_TC3DATA_8814B 0
#define BIT_MASK_TC3DATA_8814B 0xffffff
#define BIT_TC3DATA_8814B(x) \
(((x) & BIT_MASK_TC3DATA_8814B) << BIT_SHIFT_TC3DATA_8814B)
#define BITS_TC3DATA_8814B (BIT_MASK_TC3DATA_8814B << BIT_SHIFT_TC3DATA_8814B)
#define BIT_CLEAR_TC3DATA_8814B(x) ((x) & (~BITS_TC3DATA_8814B))
#define BIT_GET_TC3DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC3DATA_8814B) & BIT_MASK_TC3DATA_8814B)
#define BIT_SET_TC3DATA_8814B(x, v) \
(BIT_CLEAR_TC3DATA_8814B(x) | BIT_TC3DATA_8814B(v))
/* 2 REG_TC4_CTRL_8814B */
#define BIT_TC4INT_EN_8814B BIT(26)
#define BIT_TC4MODE_8814B BIT(25)
#define BIT_TC4EN_8814B BIT(24)
#define BIT_SHIFT_TC4DATA_8814B 0
#define BIT_MASK_TC4DATA_8814B 0xffffff
#define BIT_TC4DATA_8814B(x) \
(((x) & BIT_MASK_TC4DATA_8814B) << BIT_SHIFT_TC4DATA_8814B)
#define BITS_TC4DATA_8814B (BIT_MASK_TC4DATA_8814B << BIT_SHIFT_TC4DATA_8814B)
#define BIT_CLEAR_TC4DATA_8814B(x) ((x) & (~BITS_TC4DATA_8814B))
#define BIT_GET_TC4DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC4DATA_8814B) & BIT_MASK_TC4DATA_8814B)
#define BIT_SET_TC4DATA_8814B(x, v) \
(BIT_CLEAR_TC4DATA_8814B(x) | BIT_TC4DATA_8814B(v))
/* 2 REG_TCUNIT_BASE_8814B */
#define BIT_SHIFT_TCUNIT_BASE_8814B 0
#define BIT_MASK_TCUNIT_BASE_8814B 0x3fff
#define BIT_TCUNIT_BASE_8814B(x) \
(((x) & BIT_MASK_TCUNIT_BASE_8814B) << BIT_SHIFT_TCUNIT_BASE_8814B)
#define BITS_TCUNIT_BASE_8814B \
(BIT_MASK_TCUNIT_BASE_8814B << BIT_SHIFT_TCUNIT_BASE_8814B)
#define BIT_CLEAR_TCUNIT_BASE_8814B(x) ((x) & (~BITS_TCUNIT_BASE_8814B))
#define BIT_GET_TCUNIT_BASE_8814B(x) \
(((x) >> BIT_SHIFT_TCUNIT_BASE_8814B) & BIT_MASK_TCUNIT_BASE_8814B)
#define BIT_SET_TCUNIT_BASE_8814B(x, v) \
(BIT_CLEAR_TCUNIT_BASE_8814B(x) | BIT_TCUNIT_BASE_8814B(v))
/* 2 REG_TC5_CTRL_8814B */
#define BIT_TC5INT_EN_8814B BIT(26)
#define BIT_TC5MODE_8814B BIT(25)
#define BIT_TC5EN_8814B BIT(24)
#define BIT_SHIFT_TC5DATA_8814B 0
#define BIT_MASK_TC5DATA_8814B 0xffffff
#define BIT_TC5DATA_8814B(x) \
(((x) & BIT_MASK_TC5DATA_8814B) << BIT_SHIFT_TC5DATA_8814B)
#define BITS_TC5DATA_8814B (BIT_MASK_TC5DATA_8814B << BIT_SHIFT_TC5DATA_8814B)
#define BIT_CLEAR_TC5DATA_8814B(x) ((x) & (~BITS_TC5DATA_8814B))
#define BIT_GET_TC5DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC5DATA_8814B) & BIT_MASK_TC5DATA_8814B)
#define BIT_SET_TC5DATA_8814B(x, v) \
(BIT_CLEAR_TC5DATA_8814B(x) | BIT_TC5DATA_8814B(v))
/* 2 REG_TC6_CTRL_8814B */
#define BIT_TC6INT_EN_8814B BIT(26)
#define BIT_TC6MODE_8814B BIT(25)
#define BIT_TC6EN_8814B BIT(24)
#define BIT_SHIFT_TC6DATA_8814B 0
#define BIT_MASK_TC6DATA_8814B 0xffffff
#define BIT_TC6DATA_8814B(x) \
(((x) & BIT_MASK_TC6DATA_8814B) << BIT_SHIFT_TC6DATA_8814B)
#define BITS_TC6DATA_8814B (BIT_MASK_TC6DATA_8814B << BIT_SHIFT_TC6DATA_8814B)
#define BIT_CLEAR_TC6DATA_8814B(x) ((x) & (~BITS_TC6DATA_8814B))
#define BIT_GET_TC6DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC6DATA_8814B) & BIT_MASK_TC6DATA_8814B)
#define BIT_SET_TC6DATA_8814B(x, v) \
(BIT_CLEAR_TC6DATA_8814B(x) | BIT_TC6DATA_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_AES_DECRPT_DATA_8814B */
#define BIT_SHIFT_IPS_CFG_ADDR_8814B 0
#define BIT_MASK_IPS_CFG_ADDR_8814B 0xff
#define BIT_IPS_CFG_ADDR_8814B(x) \
(((x) & BIT_MASK_IPS_CFG_ADDR_8814B) << BIT_SHIFT_IPS_CFG_ADDR_8814B)
#define BITS_IPS_CFG_ADDR_8814B \
(BIT_MASK_IPS_CFG_ADDR_8814B << BIT_SHIFT_IPS_CFG_ADDR_8814B)
#define BIT_CLEAR_IPS_CFG_ADDR_8814B(x) ((x) & (~BITS_IPS_CFG_ADDR_8814B))
#define BIT_GET_IPS_CFG_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_IPS_CFG_ADDR_8814B) & BIT_MASK_IPS_CFG_ADDR_8814B)
#define BIT_SET_IPS_CFG_ADDR_8814B(x, v) \
(BIT_CLEAR_IPS_CFG_ADDR_8814B(x) | BIT_IPS_CFG_ADDR_8814B(v))
/* 2 REG_AES_DECRPT_CFG_8814B */
#define BIT_SHIFT_IPS_CFG_DATA_8814B 0
#define BIT_MASK_IPS_CFG_DATA_8814B 0xffffffffL
#define BIT_IPS_CFG_DATA_8814B(x) \
(((x) & BIT_MASK_IPS_CFG_DATA_8814B) << BIT_SHIFT_IPS_CFG_DATA_8814B)
#define BITS_IPS_CFG_DATA_8814B \
(BIT_MASK_IPS_CFG_DATA_8814B << BIT_SHIFT_IPS_CFG_DATA_8814B)
#define BIT_CLEAR_IPS_CFG_DATA_8814B(x) ((x) & (~BITS_IPS_CFG_DATA_8814B))
#define BIT_GET_IPS_CFG_DATA_8814B(x) \
(((x) >> BIT_SHIFT_IPS_CFG_DATA_8814B) & BIT_MASK_IPS_CFG_DATA_8814B)
#define BIT_SET_IPS_CFG_DATA_8814B(x, v) \
(BIT_CLEAR_IPS_CFG_DATA_8814B(x) | BIT_IPS_CFG_DATA_8814B(v))
/* 2 REG_HIOE_CTRL_8814B */
#define BIT_HIOE_WRITE_REQ_8814B BIT(30)
#define BIT_HIOE_READ_REQ_8814B BIT(29)
#define BIT_INST_FORMAT_ERR_8814B BIT(25)
#define BIT_OP_TIMEOUT_ERR_8814B BIT(24)
#define BIT_SHIFT_HIOE_OP_TIMEOUT_8814B 16
#define BIT_MASK_HIOE_OP_TIMEOUT_8814B 0xff
#define BIT_HIOE_OP_TIMEOUT_8814B(x) \
(((x) & BIT_MASK_HIOE_OP_TIMEOUT_8814B) \
<< BIT_SHIFT_HIOE_OP_TIMEOUT_8814B)
#define BITS_HIOE_OP_TIMEOUT_8814B \
(BIT_MASK_HIOE_OP_TIMEOUT_8814B << BIT_SHIFT_HIOE_OP_TIMEOUT_8814B)
#define BIT_CLEAR_HIOE_OP_TIMEOUT_8814B(x) ((x) & (~BITS_HIOE_OP_TIMEOUT_8814B))
#define BIT_GET_HIOE_OP_TIMEOUT_8814B(x) \
(((x) >> BIT_SHIFT_HIOE_OP_TIMEOUT_8814B) & \
BIT_MASK_HIOE_OP_TIMEOUT_8814B)
#define BIT_SET_HIOE_OP_TIMEOUT_8814B(x, v) \
(BIT_CLEAR_HIOE_OP_TIMEOUT_8814B(x) | BIT_HIOE_OP_TIMEOUT_8814B(v))
#define BIT_SHIFT_BITDATA_CHECKSUM_8814B 0
#define BIT_MASK_BITDATA_CHECKSUM_8814B 0xffff
#define BIT_BITDATA_CHECKSUM_8814B(x) \
(((x) & BIT_MASK_BITDATA_CHECKSUM_8814B) \
<< BIT_SHIFT_BITDATA_CHECKSUM_8814B)
#define BITS_BITDATA_CHECKSUM_8814B \
(BIT_MASK_BITDATA_CHECKSUM_8814B << BIT_SHIFT_BITDATA_CHECKSUM_8814B)
#define BIT_CLEAR_BITDATA_CHECKSUM_8814B(x) \
((x) & (~BITS_BITDATA_CHECKSUM_8814B))
#define BIT_GET_BITDATA_CHECKSUM_8814B(x) \
(((x) >> BIT_SHIFT_BITDATA_CHECKSUM_8814B) & \
BIT_MASK_BITDATA_CHECKSUM_8814B)
#define BIT_SET_BITDATA_CHECKSUM_8814B(x, v) \
(BIT_CLEAR_BITDATA_CHECKSUM_8814B(x) | BIT_BITDATA_CHECKSUM_8814B(v))
/* 2 REG_HIOE_CFG_FILE_8814B */
#define BIT_SHIFT_TXBF_END_ADDR_8814B 16
#define BIT_MASK_TXBF_END_ADDR_8814B 0xffff
#define BIT_TXBF_END_ADDR_8814B(x) \
(((x) & BIT_MASK_TXBF_END_ADDR_8814B) << BIT_SHIFT_TXBF_END_ADDR_8814B)
#define BITS_TXBF_END_ADDR_8814B \
(BIT_MASK_TXBF_END_ADDR_8814B << BIT_SHIFT_TXBF_END_ADDR_8814B)
#define BIT_CLEAR_TXBF_END_ADDR_8814B(x) ((x) & (~BITS_TXBF_END_ADDR_8814B))
#define BIT_GET_TXBF_END_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_TXBF_END_ADDR_8814B) & BIT_MASK_TXBF_END_ADDR_8814B)
#define BIT_SET_TXBF_END_ADDR_8814B(x, v) \
(BIT_CLEAR_TXBF_END_ADDR_8814B(x) | BIT_TXBF_END_ADDR_8814B(v))
#define BIT_SHIFT_TXBF_STR_ADDR_8814B 0
#define BIT_MASK_TXBF_STR_ADDR_8814B 0xffff
#define BIT_TXBF_STR_ADDR_8814B(x) \
(((x) & BIT_MASK_TXBF_STR_ADDR_8814B) << BIT_SHIFT_TXBF_STR_ADDR_8814B)
#define BITS_TXBF_STR_ADDR_8814B \
(BIT_MASK_TXBF_STR_ADDR_8814B << BIT_SHIFT_TXBF_STR_ADDR_8814B)
#define BIT_CLEAR_TXBF_STR_ADDR_8814B(x) ((x) & (~BITS_TXBF_STR_ADDR_8814B))
#define BIT_GET_TXBF_STR_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_TXBF_STR_ADDR_8814B) & BIT_MASK_TXBF_STR_ADDR_8814B)
#define BIT_SET_TXBF_STR_ADDR_8814B(x, v) \
(BIT_CLEAR_TXBF_STR_ADDR_8814B(x) | BIT_TXBF_STR_ADDR_8814B(v))
/* 2 REG_TMETER_8814B */
#define BIT_TEMP_VALID_8814B BIT(31)
#define BIT_SHIFT_TEMP_VALUE_8814B 24
#define BIT_MASK_TEMP_VALUE_8814B 0x3f
#define BIT_TEMP_VALUE_8814B(x) \
(((x) & BIT_MASK_TEMP_VALUE_8814B) << BIT_SHIFT_TEMP_VALUE_8814B)
#define BITS_TEMP_VALUE_8814B \
(BIT_MASK_TEMP_VALUE_8814B << BIT_SHIFT_TEMP_VALUE_8814B)
#define BIT_CLEAR_TEMP_VALUE_8814B(x) ((x) & (~BITS_TEMP_VALUE_8814B))
#define BIT_GET_TEMP_VALUE_8814B(x) \
(((x) >> BIT_SHIFT_TEMP_VALUE_8814B) & BIT_MASK_TEMP_VALUE_8814B)
#define BIT_SET_TEMP_VALUE_8814B(x, v) \
(BIT_CLEAR_TEMP_VALUE_8814B(x) | BIT_TEMP_VALUE_8814B(v))
#define BIT_SHIFT_REG_TMETER_TIMER_8814B 8
#define BIT_MASK_REG_TMETER_TIMER_8814B 0xfff
#define BIT_REG_TMETER_TIMER_8814B(x) \
(((x) & BIT_MASK_REG_TMETER_TIMER_8814B) \
<< BIT_SHIFT_REG_TMETER_TIMER_8814B)
#define BITS_REG_TMETER_TIMER_8814B \
(BIT_MASK_REG_TMETER_TIMER_8814B << BIT_SHIFT_REG_TMETER_TIMER_8814B)
#define BIT_CLEAR_REG_TMETER_TIMER_8814B(x) \
((x) & (~BITS_REG_TMETER_TIMER_8814B))
#define BIT_GET_REG_TMETER_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_REG_TMETER_TIMER_8814B) & \
BIT_MASK_REG_TMETER_TIMER_8814B)
#define BIT_SET_REG_TMETER_TIMER_8814B(x, v) \
(BIT_CLEAR_REG_TMETER_TIMER_8814B(x) | BIT_REG_TMETER_TIMER_8814B(v))
#define BIT_SHIFT_REG_TEMP_DELTA_8814B 2
#define BIT_MASK_REG_TEMP_DELTA_8814B 0x3f
#define BIT_REG_TEMP_DELTA_8814B(x) \
(((x) & BIT_MASK_REG_TEMP_DELTA_8814B) \
<< BIT_SHIFT_REG_TEMP_DELTA_8814B)
#define BITS_REG_TEMP_DELTA_8814B \
(BIT_MASK_REG_TEMP_DELTA_8814B << BIT_SHIFT_REG_TEMP_DELTA_8814B)
#define BIT_CLEAR_REG_TEMP_DELTA_8814B(x) ((x) & (~BITS_REG_TEMP_DELTA_8814B))
#define BIT_GET_REG_TEMP_DELTA_8814B(x) \
(((x) >> BIT_SHIFT_REG_TEMP_DELTA_8814B) & \
BIT_MASK_REG_TEMP_DELTA_8814B)
#define BIT_SET_REG_TEMP_DELTA_8814B(x, v) \
(BIT_CLEAR_REG_TEMP_DELTA_8814B(x) | BIT_REG_TEMP_DELTA_8814B(v))
#define BIT_REG_TMETER_EN_8814B BIT(0)
/* 2 REG_OSC_32K_CTRL_8814B */
#define BIT_SHIFT_OSC_32K_CLKGEN_0_8814B 16
#define BIT_MASK_OSC_32K_CLKGEN_0_8814B 0xffff
#define BIT_OSC_32K_CLKGEN_0_8814B(x) \
(((x) & BIT_MASK_OSC_32K_CLKGEN_0_8814B) \
<< BIT_SHIFT_OSC_32K_CLKGEN_0_8814B)
#define BITS_OSC_32K_CLKGEN_0_8814B \
(BIT_MASK_OSC_32K_CLKGEN_0_8814B << BIT_SHIFT_OSC_32K_CLKGEN_0_8814B)
#define BIT_CLEAR_OSC_32K_CLKGEN_0_8814B(x) \
((x) & (~BITS_OSC_32K_CLKGEN_0_8814B))
#define BIT_GET_OSC_32K_CLKGEN_0_8814B(x) \
(((x) >> BIT_SHIFT_OSC_32K_CLKGEN_0_8814B) & \
BIT_MASK_OSC_32K_CLKGEN_0_8814B)
#define BIT_SET_OSC_32K_CLKGEN_0_8814B(x, v) \
(BIT_CLEAR_OSC_32K_CLKGEN_0_8814B(x) | BIT_OSC_32K_CLKGEN_0_8814B(v))
#define BIT_SHIFT_OSC_32K_RES_COMP_8814B 4
#define BIT_MASK_OSC_32K_RES_COMP_8814B 0x3
#define BIT_OSC_32K_RES_COMP_8814B(x) \
(((x) & BIT_MASK_OSC_32K_RES_COMP_8814B) \
<< BIT_SHIFT_OSC_32K_RES_COMP_8814B)
#define BITS_OSC_32K_RES_COMP_8814B \
(BIT_MASK_OSC_32K_RES_COMP_8814B << BIT_SHIFT_OSC_32K_RES_COMP_8814B)
#define BIT_CLEAR_OSC_32K_RES_COMP_8814B(x) \
((x) & (~BITS_OSC_32K_RES_COMP_8814B))
#define BIT_GET_OSC_32K_RES_COMP_8814B(x) \
(((x) >> BIT_SHIFT_OSC_32K_RES_COMP_8814B) & \
BIT_MASK_OSC_32K_RES_COMP_8814B)
#define BIT_SET_OSC_32K_RES_COMP_8814B(x, v) \
(BIT_CLEAR_OSC_32K_RES_COMP_8814B(x) | BIT_OSC_32K_RES_COMP_8814B(v))
#define BIT_OSC_32K_OUT_SEL_8814B BIT(3)
#define BIT_ISO_WL_2_OSC_32K_8814B BIT(1)
#define BIT_POW_CKGEN_8814B BIT(0)
/* 2 REG_32K_CAL_REG1_8814B */
#define BIT_CAL_32K_REG_WR_8814B BIT(31)
#define BIT_CAL_32K_DBG_SEL_8814B BIT(22)
#define BIT_SHIFT_CAL_32K_REG_ADDR_8814B 16
#define BIT_MASK_CAL_32K_REG_ADDR_8814B 0x3f
#define BIT_CAL_32K_REG_ADDR_8814B(x) \
(((x) & BIT_MASK_CAL_32K_REG_ADDR_8814B) \
<< BIT_SHIFT_CAL_32K_REG_ADDR_8814B)
#define BITS_CAL_32K_REG_ADDR_8814B \
(BIT_MASK_CAL_32K_REG_ADDR_8814B << BIT_SHIFT_CAL_32K_REG_ADDR_8814B)
#define BIT_CLEAR_CAL_32K_REG_ADDR_8814B(x) \
((x) & (~BITS_CAL_32K_REG_ADDR_8814B))
#define BIT_GET_CAL_32K_REG_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_ADDR_8814B) & \
BIT_MASK_CAL_32K_REG_ADDR_8814B)
#define BIT_SET_CAL_32K_REG_ADDR_8814B(x, v) \
(BIT_CLEAR_CAL_32K_REG_ADDR_8814B(x) | BIT_CAL_32K_REG_ADDR_8814B(v))
#define BIT_SHIFT_CAL_32K_REG_DATA_8814B 0
#define BIT_MASK_CAL_32K_REG_DATA_8814B 0xffff
#define BIT_CAL_32K_REG_DATA_8814B(x) \
(((x) & BIT_MASK_CAL_32K_REG_DATA_8814B) \
<< BIT_SHIFT_CAL_32K_REG_DATA_8814B)
#define BITS_CAL_32K_REG_DATA_8814B \
(BIT_MASK_CAL_32K_REG_DATA_8814B << BIT_SHIFT_CAL_32K_REG_DATA_8814B)
#define BIT_CLEAR_CAL_32K_REG_DATA_8814B(x) \
((x) & (~BITS_CAL_32K_REG_DATA_8814B))
#define BIT_GET_CAL_32K_REG_DATA_8814B(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_DATA_8814B) & \
BIT_MASK_CAL_32K_REG_DATA_8814B)
#define BIT_SET_CAL_32K_REG_DATA_8814B(x, v) \
(BIT_CLEAR_CAL_32K_REG_DATA_8814B(x) | BIT_CAL_32K_REG_DATA_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_C2HEVT_8814B */
#define BIT_SHIFT_C2HEVT_MSG_V1_8814B 0
#define BIT_MASK_C2HEVT_MSG_V1_8814B 0xffffffffL
#define BIT_C2HEVT_MSG_V1_8814B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_V1_8814B) << BIT_SHIFT_C2HEVT_MSG_V1_8814B)
#define BITS_C2HEVT_MSG_V1_8814B \
(BIT_MASK_C2HEVT_MSG_V1_8814B << BIT_SHIFT_C2HEVT_MSG_V1_8814B)
#define BIT_CLEAR_C2HEVT_MSG_V1_8814B(x) ((x) & (~BITS_C2HEVT_MSG_V1_8814B))
#define BIT_GET_C2HEVT_MSG_V1_8814B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_V1_8814B) & BIT_MASK_C2HEVT_MSG_V1_8814B)
#define BIT_SET_C2HEVT_MSG_V1_8814B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_V1_8814B(x) | BIT_C2HEVT_MSG_V1_8814B(v))
/* 2 REG_C2HEVT_1_8814B */
#define BIT_SHIFT_C2HEVT_MSG_1_8814B 0
#define BIT_MASK_C2HEVT_MSG_1_8814B 0xffffffffL
#define BIT_C2HEVT_MSG_1_8814B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_1_8814B) << BIT_SHIFT_C2HEVT_MSG_1_8814B)
#define BITS_C2HEVT_MSG_1_8814B \
(BIT_MASK_C2HEVT_MSG_1_8814B << BIT_SHIFT_C2HEVT_MSG_1_8814B)
#define BIT_CLEAR_C2HEVT_MSG_1_8814B(x) ((x) & (~BITS_C2HEVT_MSG_1_8814B))
#define BIT_GET_C2HEVT_MSG_1_8814B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_1_8814B) & BIT_MASK_C2HEVT_MSG_1_8814B)
#define BIT_SET_C2HEVT_MSG_1_8814B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_1_8814B(x) | BIT_C2HEVT_MSG_1_8814B(v))
/* 2 REG_C2HEVT_2_8814B */
#define BIT_SHIFT_C2HEVT_MSG_2_8814B 0
#define BIT_MASK_C2HEVT_MSG_2_8814B 0xffffffffL
#define BIT_C2HEVT_MSG_2_8814B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_2_8814B) << BIT_SHIFT_C2HEVT_MSG_2_8814B)
#define BITS_C2HEVT_MSG_2_8814B \
(BIT_MASK_C2HEVT_MSG_2_8814B << BIT_SHIFT_C2HEVT_MSG_2_8814B)
#define BIT_CLEAR_C2HEVT_MSG_2_8814B(x) ((x) & (~BITS_C2HEVT_MSG_2_8814B))
#define BIT_GET_C2HEVT_MSG_2_8814B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_2_8814B) & BIT_MASK_C2HEVT_MSG_2_8814B)
#define BIT_SET_C2HEVT_MSG_2_8814B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_2_8814B(x) | BIT_C2HEVT_MSG_2_8814B(v))
/* 2 REG_C2HEVT_3_8814B */
#define BIT_SHIFT_C2HEVT_MSG_3_8814B 0
#define BIT_MASK_C2HEVT_MSG_3_8814B 0xffffffffL
#define BIT_C2HEVT_MSG_3_8814B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_3_8814B) << BIT_SHIFT_C2HEVT_MSG_3_8814B)
#define BITS_C2HEVT_MSG_3_8814B \
(BIT_MASK_C2HEVT_MSG_3_8814B << BIT_SHIFT_C2HEVT_MSG_3_8814B)
#define BIT_CLEAR_C2HEVT_MSG_3_8814B(x) ((x) & (~BITS_C2HEVT_MSG_3_8814B))
#define BIT_GET_C2HEVT_MSG_3_8814B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_3_8814B) & BIT_MASK_C2HEVT_MSG_3_8814B)
#define BIT_SET_C2HEVT_MSG_3_8814B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_3_8814B(x) | BIT_C2HEVT_MSG_3_8814B(v))
/* 2 REG_RXDESC_BUFF_RPTR_8814B */
#define BIT_SHIFT_RXDESC_BUFF_RPTR_8814B 0
#define BIT_MASK_RXDESC_BUFF_RPTR_8814B 0xffffffffL
#define BIT_RXDESC_BUFF_RPTR_8814B(x) \
(((x) & BIT_MASK_RXDESC_BUFF_RPTR_8814B) \
<< BIT_SHIFT_RXDESC_BUFF_RPTR_8814B)
#define BITS_RXDESC_BUFF_RPTR_8814B \
(BIT_MASK_RXDESC_BUFF_RPTR_8814B << BIT_SHIFT_RXDESC_BUFF_RPTR_8814B)
#define BIT_CLEAR_RXDESC_BUFF_RPTR_8814B(x) \
((x) & (~BITS_RXDESC_BUFF_RPTR_8814B))
#define BIT_GET_RXDESC_BUFF_RPTR_8814B(x) \
(((x) >> BIT_SHIFT_RXDESC_BUFF_RPTR_8814B) & \
BIT_MASK_RXDESC_BUFF_RPTR_8814B)
#define BIT_SET_RXDESC_BUFF_RPTR_8814B(x, v) \
(BIT_CLEAR_RXDESC_BUFF_RPTR_8814B(x) | BIT_RXDESC_BUFF_RPTR_8814B(v))
/* 2 REG_RXDESC_BUFF_WPTR_8814B */
#define BIT_SHIFT_RXDESC_BUFF_WPTR_8814B 0
#define BIT_MASK_RXDESC_BUFF_WPTR_8814B 0xffffffffL
#define BIT_RXDESC_BUFF_WPTR_8814B(x) \
(((x) & BIT_MASK_RXDESC_BUFF_WPTR_8814B) \
<< BIT_SHIFT_RXDESC_BUFF_WPTR_8814B)
#define BITS_RXDESC_BUFF_WPTR_8814B \
(BIT_MASK_RXDESC_BUFF_WPTR_8814B << BIT_SHIFT_RXDESC_BUFF_WPTR_8814B)
#define BIT_CLEAR_RXDESC_BUFF_WPTR_8814B(x) \
((x) & (~BITS_RXDESC_BUFF_WPTR_8814B))
#define BIT_GET_RXDESC_BUFF_WPTR_8814B(x) \
(((x) >> BIT_SHIFT_RXDESC_BUFF_WPTR_8814B) & \
BIT_MASK_RXDESC_BUFF_WPTR_8814B)
#define BIT_SET_RXDESC_BUFF_WPTR_8814B(x, v) \
(BIT_CLEAR_RXDESC_BUFF_WPTR_8814B(x) | BIT_RXDESC_BUFF_WPTR_8814B(v))
/* 2 REG_SW_DEFINED_PAGE1_8814B */
#define BIT_SHIFT_SW_DEFINED_PAGE1_V1_8814B 0
#define BIT_MASK_SW_DEFINED_PAGE1_V1_8814B 0xffffffffL
#define BIT_SW_DEFINED_PAGE1_V1_8814B(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1_V1_8814B) \
<< BIT_SHIFT_SW_DEFINED_PAGE1_V1_8814B)
#define BITS_SW_DEFINED_PAGE1_V1_8814B \
(BIT_MASK_SW_DEFINED_PAGE1_V1_8814B \
<< BIT_SHIFT_SW_DEFINED_PAGE1_V1_8814B)
#define BIT_CLEAR_SW_DEFINED_PAGE1_V1_8814B(x) \
((x) & (~BITS_SW_DEFINED_PAGE1_V1_8814B))
#define BIT_GET_SW_DEFINED_PAGE1_V1_8814B(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1_V1_8814B) & \
BIT_MASK_SW_DEFINED_PAGE1_V1_8814B)
#define BIT_SET_SW_DEFINED_PAGE1_V1_8814B(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1_V1_8814B(x) | \
BIT_SW_DEFINED_PAGE1_V1_8814B(v))
/* 2 REG_SW_DEFINED_PAGE2_8814B */
#define BIT_SHIFT_SW_DEFINED_PAGE2_8814B 0
#define BIT_MASK_SW_DEFINED_PAGE2_8814B 0xffffffffL
#define BIT_SW_DEFINED_PAGE2_8814B(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE2_8814B) \
<< BIT_SHIFT_SW_DEFINED_PAGE2_8814B)
#define BITS_SW_DEFINED_PAGE2_8814B \
(BIT_MASK_SW_DEFINED_PAGE2_8814B << BIT_SHIFT_SW_DEFINED_PAGE2_8814B)
#define BIT_CLEAR_SW_DEFINED_PAGE2_8814B(x) \
((x) & (~BITS_SW_DEFINED_PAGE2_8814B))
#define BIT_GET_SW_DEFINED_PAGE2_8814B(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE2_8814B) & \
BIT_MASK_SW_DEFINED_PAGE2_8814B)
#define BIT_SET_SW_DEFINED_PAGE2_8814B(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE2_8814B(x) | BIT_SW_DEFINED_PAGE2_8814B(v))
/* 2 REG_MCUTST_I_8814B */
#define BIT_SHIFT_MCUDMSG_I_8814B 0
#define BIT_MASK_MCUDMSG_I_8814B 0xffffffffL
#define BIT_MCUDMSG_I_8814B(x) \
(((x) & BIT_MASK_MCUDMSG_I_8814B) << BIT_SHIFT_MCUDMSG_I_8814B)
#define BITS_MCUDMSG_I_8814B \
(BIT_MASK_MCUDMSG_I_8814B << BIT_SHIFT_MCUDMSG_I_8814B)
#define BIT_CLEAR_MCUDMSG_I_8814B(x) ((x) & (~BITS_MCUDMSG_I_8814B))
#define BIT_GET_MCUDMSG_I_8814B(x) \
(((x) >> BIT_SHIFT_MCUDMSG_I_8814B) & BIT_MASK_MCUDMSG_I_8814B)
#define BIT_SET_MCUDMSG_I_8814B(x, v) \
(BIT_CLEAR_MCUDMSG_I_8814B(x) | BIT_MCUDMSG_I_8814B(v))
/* 2 REG_MCUTST_II_8814B */
#define BIT_SHIFT_MCUDMSG_II_8814B 0
#define BIT_MASK_MCUDMSG_II_8814B 0xffffffffL
#define BIT_MCUDMSG_II_8814B(x) \
(((x) & BIT_MASK_MCUDMSG_II_8814B) << BIT_SHIFT_MCUDMSG_II_8814B)
#define BITS_MCUDMSG_II_8814B \
(BIT_MASK_MCUDMSG_II_8814B << BIT_SHIFT_MCUDMSG_II_8814B)
#define BIT_CLEAR_MCUDMSG_II_8814B(x) ((x) & (~BITS_MCUDMSG_II_8814B))
#define BIT_GET_MCUDMSG_II_8814B(x) \
(((x) >> BIT_SHIFT_MCUDMSG_II_8814B) & BIT_MASK_MCUDMSG_II_8814B)
#define BIT_SET_MCUDMSG_II_8814B(x, v) \
(BIT_CLEAR_MCUDMSG_II_8814B(x) | BIT_MCUDMSG_II_8814B(v))
/* 2 REG_FMETHR_8814B */
#define BIT_FMSG_INT_8814B BIT(31)
#define BIT_SHIFT_FW_MSG_8814B 0
#define BIT_MASK_FW_MSG_8814B 0xffffffffL
#define BIT_FW_MSG_8814B(x) \
(((x) & BIT_MASK_FW_MSG_8814B) << BIT_SHIFT_FW_MSG_8814B)
#define BITS_FW_MSG_8814B (BIT_MASK_FW_MSG_8814B << BIT_SHIFT_FW_MSG_8814B)
#define BIT_CLEAR_FW_MSG_8814B(x) ((x) & (~BITS_FW_MSG_8814B))
#define BIT_GET_FW_MSG_8814B(x) \
(((x) >> BIT_SHIFT_FW_MSG_8814B) & BIT_MASK_FW_MSG_8814B)
#define BIT_SET_FW_MSG_8814B(x, v) \
(BIT_CLEAR_FW_MSG_8814B(x) | BIT_FW_MSG_8814B(v))
/* 2 REG_HMETFR_8814B */
#define BIT_SHIFT_HRCV_MSG_8814B 24
#define BIT_MASK_HRCV_MSG_8814B 0xff
#define BIT_HRCV_MSG_8814B(x) \
(((x) & BIT_MASK_HRCV_MSG_8814B) << BIT_SHIFT_HRCV_MSG_8814B)
#define BITS_HRCV_MSG_8814B \
(BIT_MASK_HRCV_MSG_8814B << BIT_SHIFT_HRCV_MSG_8814B)
#define BIT_CLEAR_HRCV_MSG_8814B(x) ((x) & (~BITS_HRCV_MSG_8814B))
#define BIT_GET_HRCV_MSG_8814B(x) \
(((x) >> BIT_SHIFT_HRCV_MSG_8814B) & BIT_MASK_HRCV_MSG_8814B)
#define BIT_SET_HRCV_MSG_8814B(x, v) \
(BIT_CLEAR_HRCV_MSG_8814B(x) | BIT_HRCV_MSG_8814B(v))
#define BIT_INT_BOX3_8814B BIT(3)
#define BIT_INT_BOX2_8814B BIT(2)
#define BIT_INT_BOX1_8814B BIT(1)
#define BIT_INT_BOX0_8814B BIT(0)
/* 2 REG_HMEBOX0_8814B */
#define BIT_SHIFT_HOST_MSG_0_8814B 0
#define BIT_MASK_HOST_MSG_0_8814B 0xffffffffL
#define BIT_HOST_MSG_0_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_0_8814B) << BIT_SHIFT_HOST_MSG_0_8814B)
#define BITS_HOST_MSG_0_8814B \
(BIT_MASK_HOST_MSG_0_8814B << BIT_SHIFT_HOST_MSG_0_8814B)
#define BIT_CLEAR_HOST_MSG_0_8814B(x) ((x) & (~BITS_HOST_MSG_0_8814B))
#define BIT_GET_HOST_MSG_0_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_0_8814B) & BIT_MASK_HOST_MSG_0_8814B)
#define BIT_SET_HOST_MSG_0_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_0_8814B(x) | BIT_HOST_MSG_0_8814B(v))
/* 2 REG_HMEBOX1_8814B */
#define BIT_SHIFT_HOST_MSG_1_8814B 0
#define BIT_MASK_HOST_MSG_1_8814B 0xffffffffL
#define BIT_HOST_MSG_1_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_1_8814B) << BIT_SHIFT_HOST_MSG_1_8814B)
#define BITS_HOST_MSG_1_8814B \
(BIT_MASK_HOST_MSG_1_8814B << BIT_SHIFT_HOST_MSG_1_8814B)
#define BIT_CLEAR_HOST_MSG_1_8814B(x) ((x) & (~BITS_HOST_MSG_1_8814B))
#define BIT_GET_HOST_MSG_1_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_1_8814B) & BIT_MASK_HOST_MSG_1_8814B)
#define BIT_SET_HOST_MSG_1_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_1_8814B(x) | BIT_HOST_MSG_1_8814B(v))
/* 2 REG_HMEBOX2_8814B */
#define BIT_SHIFT_HOST_MSG_2_8814B 0
#define BIT_MASK_HOST_MSG_2_8814B 0xffffffffL
#define BIT_HOST_MSG_2_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_2_8814B) << BIT_SHIFT_HOST_MSG_2_8814B)
#define BITS_HOST_MSG_2_8814B \
(BIT_MASK_HOST_MSG_2_8814B << BIT_SHIFT_HOST_MSG_2_8814B)
#define BIT_CLEAR_HOST_MSG_2_8814B(x) ((x) & (~BITS_HOST_MSG_2_8814B))
#define BIT_GET_HOST_MSG_2_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_2_8814B) & BIT_MASK_HOST_MSG_2_8814B)
#define BIT_SET_HOST_MSG_2_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_2_8814B(x) | BIT_HOST_MSG_2_8814B(v))
/* 2 REG_HMEBOX3_8814B */
#define BIT_SHIFT_HOST_MSG_3_8814B 0
#define BIT_MASK_HOST_MSG_3_8814B 0xffffffffL
#define BIT_HOST_MSG_3_8814B(x) \
(((x) & BIT_MASK_HOST_MSG_3_8814B) << BIT_SHIFT_HOST_MSG_3_8814B)
#define BITS_HOST_MSG_3_8814B \
(BIT_MASK_HOST_MSG_3_8814B << BIT_SHIFT_HOST_MSG_3_8814B)
#define BIT_CLEAR_HOST_MSG_3_8814B(x) ((x) & (~BITS_HOST_MSG_3_8814B))
#define BIT_GET_HOST_MSG_3_8814B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_3_8814B) & BIT_MASK_HOST_MSG_3_8814B)
#define BIT_SET_HOST_MSG_3_8814B(x, v) \
(BIT_CLEAR_HOST_MSG_3_8814B(x) | BIT_HOST_MSG_3_8814B(v))
/* 2 REG_RXDESC_BUFF_BNDY_8814B */
#define BIT_SHIFT_RXDESC_BUFF_BNDY_8814B 0
#define BIT_MASK_RXDESC_BUFF_BNDY_8814B 0xffffffffL
#define BIT_RXDESC_BUFF_BNDY_8814B(x) \
(((x) & BIT_MASK_RXDESC_BUFF_BNDY_8814B) \
<< BIT_SHIFT_RXDESC_BUFF_BNDY_8814B)
#define BITS_RXDESC_BUFF_BNDY_8814B \
(BIT_MASK_RXDESC_BUFF_BNDY_8814B << BIT_SHIFT_RXDESC_BUFF_BNDY_8814B)
#define BIT_CLEAR_RXDESC_BUFF_BNDY_8814B(x) \
((x) & (~BITS_RXDESC_BUFF_BNDY_8814B))
#define BIT_GET_RXDESC_BUFF_BNDY_8814B(x) \
(((x) >> BIT_SHIFT_RXDESC_BUFF_BNDY_8814B) & \
BIT_MASK_RXDESC_BUFF_BNDY_8814B)
#define BIT_SET_RXDESC_BUFF_BNDY_8814B(x, v) \
(BIT_CLEAR_RXDESC_BUFF_BNDY_8814B(x) | BIT_RXDESC_BUFF_BNDY_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BB_ACCESS_CTRL_8814B */
#define BIT_SHIFT_BB_WRITE_READ_8814B 30
#define BIT_MASK_BB_WRITE_READ_8814B 0x3
#define BIT_BB_WRITE_READ_8814B(x) \
(((x) & BIT_MASK_BB_WRITE_READ_8814B) << BIT_SHIFT_BB_WRITE_READ_8814B)
#define BITS_BB_WRITE_READ_8814B \
(BIT_MASK_BB_WRITE_READ_8814B << BIT_SHIFT_BB_WRITE_READ_8814B)
#define BIT_CLEAR_BB_WRITE_READ_8814B(x) ((x) & (~BITS_BB_WRITE_READ_8814B))
#define BIT_GET_BB_WRITE_READ_8814B(x) \
(((x) >> BIT_SHIFT_BB_WRITE_READ_8814B) & BIT_MASK_BB_WRITE_READ_8814B)
#define BIT_SET_BB_WRITE_READ_8814B(x, v) \
(BIT_CLEAR_BB_WRITE_READ_8814B(x) | BIT_BB_WRITE_READ_8814B(v))
#define BIT_SHIFT_BB_WRITE_EN_8814B 12
#define BIT_MASK_BB_WRITE_EN_8814B 0xf
#define BIT_BB_WRITE_EN_8814B(x) \
(((x) & BIT_MASK_BB_WRITE_EN_8814B) << BIT_SHIFT_BB_WRITE_EN_8814B)
#define BITS_BB_WRITE_EN_8814B \
(BIT_MASK_BB_WRITE_EN_8814B << BIT_SHIFT_BB_WRITE_EN_8814B)
#define BIT_CLEAR_BB_WRITE_EN_8814B(x) ((x) & (~BITS_BB_WRITE_EN_8814B))
#define BIT_GET_BB_WRITE_EN_8814B(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN_8814B) & BIT_MASK_BB_WRITE_EN_8814B)
#define BIT_SET_BB_WRITE_EN_8814B(x, v) \
(BIT_CLEAR_BB_WRITE_EN_8814B(x) | BIT_BB_WRITE_EN_8814B(v))
#define BIT_SHIFT_BB_ADDR_8814B 2
#define BIT_MASK_BB_ADDR_8814B 0x1ff
#define BIT_BB_ADDR_8814B(x) \
(((x) & BIT_MASK_BB_ADDR_8814B) << BIT_SHIFT_BB_ADDR_8814B)
#define BITS_BB_ADDR_8814B (BIT_MASK_BB_ADDR_8814B << BIT_SHIFT_BB_ADDR_8814B)
#define BIT_CLEAR_BB_ADDR_8814B(x) ((x) & (~BITS_BB_ADDR_8814B))
#define BIT_GET_BB_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_BB_ADDR_8814B) & BIT_MASK_BB_ADDR_8814B)
#define BIT_SET_BB_ADDR_8814B(x, v) \
(BIT_CLEAR_BB_ADDR_8814B(x) | BIT_BB_ADDR_8814B(v))
#define BIT_BB_ERRACC_8814B BIT(0)
/* 2 REG_BB_ACCESS_DATA_8814B */
#define BIT_SHIFT_BB_DATA_8814B 0
#define BIT_MASK_BB_DATA_8814B 0xffffffffL
#define BIT_BB_DATA_8814B(x) \
(((x) & BIT_MASK_BB_DATA_8814B) << BIT_SHIFT_BB_DATA_8814B)
#define BITS_BB_DATA_8814B (BIT_MASK_BB_DATA_8814B << BIT_SHIFT_BB_DATA_8814B)
#define BIT_CLEAR_BB_DATA_8814B(x) ((x) & (~BITS_BB_DATA_8814B))
#define BIT_GET_BB_DATA_8814B(x) \
(((x) >> BIT_SHIFT_BB_DATA_8814B) & BIT_MASK_BB_DATA_8814B)
#define BIT_SET_BB_DATA_8814B(x, v) \
(BIT_CLEAR_BB_DATA_8814B(x) | BIT_BB_DATA_8814B(v))
/* 2 REG_HMEBOX_E0_8814B */
#define BIT_SHIFT_HMEBOX_E0_8814B 0
#define BIT_MASK_HMEBOX_E0_8814B 0xffffffffL
#define BIT_HMEBOX_E0_8814B(x) \
(((x) & BIT_MASK_HMEBOX_E0_8814B) << BIT_SHIFT_HMEBOX_E0_8814B)
#define BITS_HMEBOX_E0_8814B \
(BIT_MASK_HMEBOX_E0_8814B << BIT_SHIFT_HMEBOX_E0_8814B)
#define BIT_CLEAR_HMEBOX_E0_8814B(x) ((x) & (~BITS_HMEBOX_E0_8814B))
#define BIT_GET_HMEBOX_E0_8814B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E0_8814B) & BIT_MASK_HMEBOX_E0_8814B)
#define BIT_SET_HMEBOX_E0_8814B(x, v) \
(BIT_CLEAR_HMEBOX_E0_8814B(x) | BIT_HMEBOX_E0_8814B(v))
/* 2 REG_HMEBOX_E1_8814B */
#define BIT_SHIFT_HMEBOX_E1_8814B 0
#define BIT_MASK_HMEBOX_E1_8814B 0xffffffffL
#define BIT_HMEBOX_E1_8814B(x) \
(((x) & BIT_MASK_HMEBOX_E1_8814B) << BIT_SHIFT_HMEBOX_E1_8814B)
#define BITS_HMEBOX_E1_8814B \
(BIT_MASK_HMEBOX_E1_8814B << BIT_SHIFT_HMEBOX_E1_8814B)
#define BIT_CLEAR_HMEBOX_E1_8814B(x) ((x) & (~BITS_HMEBOX_E1_8814B))
#define BIT_GET_HMEBOX_E1_8814B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E1_8814B) & BIT_MASK_HMEBOX_E1_8814B)
#define BIT_SET_HMEBOX_E1_8814B(x, v) \
(BIT_CLEAR_HMEBOX_E1_8814B(x) | BIT_HMEBOX_E1_8814B(v))
/* 2 REG_HMEBOX_E2_8814B */
#define BIT_SHIFT_HMEBOX_E2_8814B 0
#define BIT_MASK_HMEBOX_E2_8814B 0xffffffffL
#define BIT_HMEBOX_E2_8814B(x) \
(((x) & BIT_MASK_HMEBOX_E2_8814B) << BIT_SHIFT_HMEBOX_E2_8814B)
#define BITS_HMEBOX_E2_8814B \
(BIT_MASK_HMEBOX_E2_8814B << BIT_SHIFT_HMEBOX_E2_8814B)
#define BIT_CLEAR_HMEBOX_E2_8814B(x) ((x) & (~BITS_HMEBOX_E2_8814B))
#define BIT_GET_HMEBOX_E2_8814B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E2_8814B) & BIT_MASK_HMEBOX_E2_8814B)
#define BIT_SET_HMEBOX_E2_8814B(x, v) \
(BIT_CLEAR_HMEBOX_E2_8814B(x) | BIT_HMEBOX_E2_8814B(v))
/* 2 REG_HMEBOX_E3_8814B */
#define BIT_SHIFT_HMEBOX_E3_8814B 0
#define BIT_MASK_HMEBOX_E3_8814B 0xffffffffL
#define BIT_HMEBOX_E3_8814B(x) \
(((x) & BIT_MASK_HMEBOX_E3_8814B) << BIT_SHIFT_HMEBOX_E3_8814B)
#define BITS_HMEBOX_E3_8814B \
(BIT_MASK_HMEBOX_E3_8814B << BIT_SHIFT_HMEBOX_E3_8814B)
#define BIT_CLEAR_HMEBOX_E3_8814B(x) ((x) & (~BITS_HMEBOX_E3_8814B))
#define BIT_GET_HMEBOX_E3_8814B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E3_8814B) & BIT_MASK_HMEBOX_E3_8814B)
#define BIT_SET_HMEBOX_E3_8814B(x, v) \
(BIT_CLEAR_HMEBOX_E3_8814B(x) | BIT_HMEBOX_E3_8814B(v))
/* 2 REG_CR_EXT_8814B */
#define BIT_SHIFT_PHY_REQ_DELAY_8814B 24
#define BIT_MASK_PHY_REQ_DELAY_8814B 0xf
#define BIT_PHY_REQ_DELAY_8814B(x) \
(((x) & BIT_MASK_PHY_REQ_DELAY_8814B) << BIT_SHIFT_PHY_REQ_DELAY_8814B)
#define BITS_PHY_REQ_DELAY_8814B \
(BIT_MASK_PHY_REQ_DELAY_8814B << BIT_SHIFT_PHY_REQ_DELAY_8814B)
#define BIT_CLEAR_PHY_REQ_DELAY_8814B(x) ((x) & (~BITS_PHY_REQ_DELAY_8814B))
#define BIT_GET_PHY_REQ_DELAY_8814B(x) \
(((x) >> BIT_SHIFT_PHY_REQ_DELAY_8814B) & BIT_MASK_PHY_REQ_DELAY_8814B)
#define BIT_SET_PHY_REQ_DELAY_8814B(x, v) \
(BIT_CLEAR_PHY_REQ_DELAY_8814B(x) | BIT_PHY_REQ_DELAY_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_FW_FIFO_PTR_RST_8814B BIT(18)
#define BIT_PHY_FIFO_PTR_RST_8814B BIT(17)
#define BIT_SPD_DOWN_8814B BIT(16)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_NETYPE4_8814B 4
#define BIT_MASK_NETYPE4_8814B 0x3
#define BIT_NETYPE4_8814B(x) \
(((x) & BIT_MASK_NETYPE4_8814B) << BIT_SHIFT_NETYPE4_8814B)
#define BITS_NETYPE4_8814B (BIT_MASK_NETYPE4_8814B << BIT_SHIFT_NETYPE4_8814B)
#define BIT_CLEAR_NETYPE4_8814B(x) ((x) & (~BITS_NETYPE4_8814B))
#define BIT_GET_NETYPE4_8814B(x) \
(((x) >> BIT_SHIFT_NETYPE4_8814B) & BIT_MASK_NETYPE4_8814B)
#define BIT_SET_NETYPE4_8814B(x, v) \
(BIT_CLEAR_NETYPE4_8814B(x) | BIT_NETYPE4_8814B(v))
#define BIT_SHIFT_NETYPE3_8814B 2
#define BIT_MASK_NETYPE3_8814B 0x3
#define BIT_NETYPE3_8814B(x) \
(((x) & BIT_MASK_NETYPE3_8814B) << BIT_SHIFT_NETYPE3_8814B)
#define BITS_NETYPE3_8814B (BIT_MASK_NETYPE3_8814B << BIT_SHIFT_NETYPE3_8814B)
#define BIT_CLEAR_NETYPE3_8814B(x) ((x) & (~BITS_NETYPE3_8814B))
#define BIT_GET_NETYPE3_8814B(x) \
(((x) >> BIT_SHIFT_NETYPE3_8814B) & BIT_MASK_NETYPE3_8814B)
#define BIT_SET_NETYPE3_8814B(x, v) \
(BIT_CLEAR_NETYPE3_8814B(x) | BIT_NETYPE3_8814B(v))
#define BIT_SHIFT_NETYPE2_8814B 0
#define BIT_MASK_NETYPE2_8814B 0x3
#define BIT_NETYPE2_8814B(x) \
(((x) & BIT_MASK_NETYPE2_8814B) << BIT_SHIFT_NETYPE2_8814B)
#define BITS_NETYPE2_8814B (BIT_MASK_NETYPE2_8814B << BIT_SHIFT_NETYPE2_8814B)
#define BIT_CLEAR_NETYPE2_8814B(x) ((x) & (~BITS_NETYPE2_8814B))
#define BIT_GET_NETYPE2_8814B(x) \
(((x) >> BIT_SHIFT_NETYPE2_8814B) & BIT_MASK_NETYPE2_8814B)
#define BIT_SET_NETYPE2_8814B(x, v) \
(BIT_CLEAR_NETYPE2_8814B(x) | BIT_NETYPE2_8814B(v))
/* 2 REG_TC9_CTRL_8814B */
#define BIT_TC9INT_EN_8814B BIT(26)
#define BIT_TC9MODE_8814B BIT(25)
#define BIT_TC9EN_8814B BIT(24)
#define BIT_SHIFT_TC9DATA_8814B 0
#define BIT_MASK_TC9DATA_8814B 0xffffff
#define BIT_TC9DATA_8814B(x) \
(((x) & BIT_MASK_TC9DATA_8814B) << BIT_SHIFT_TC9DATA_8814B)
#define BITS_TC9DATA_8814B (BIT_MASK_TC9DATA_8814B << BIT_SHIFT_TC9DATA_8814B)
#define BIT_CLEAR_TC9DATA_8814B(x) ((x) & (~BITS_TC9DATA_8814B))
#define BIT_GET_TC9DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC9DATA_8814B) & BIT_MASK_TC9DATA_8814B)
#define BIT_SET_TC9DATA_8814B(x, v) \
(BIT_CLEAR_TC9DATA_8814B(x) | BIT_TC9DATA_8814B(v))
/* 2 REG_TC10_CTRL_8814B */
#define BIT_TC10INT_EN_8814B BIT(26)
#define BIT_TC10MODE_8814B BIT(25)
#define BIT_TC10EN_8814B BIT(24)
#define BIT_SHIFT_TC10DATA_8814B 0
#define BIT_MASK_TC10DATA_8814B 0xffffff
#define BIT_TC10DATA_8814B(x) \
(((x) & BIT_MASK_TC10DATA_8814B) << BIT_SHIFT_TC10DATA_8814B)
#define BITS_TC10DATA_8814B \
(BIT_MASK_TC10DATA_8814B << BIT_SHIFT_TC10DATA_8814B)
#define BIT_CLEAR_TC10DATA_8814B(x) ((x) & (~BITS_TC10DATA_8814B))
#define BIT_GET_TC10DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC10DATA_8814B) & BIT_MASK_TC10DATA_8814B)
#define BIT_SET_TC10DATA_8814B(x, v) \
(BIT_CLEAR_TC10DATA_8814B(x) | BIT_TC10DATA_8814B(v))
/* 2 REG_TC11_CTRL_8814B */
#define BIT_TC11INT_EN_8814B BIT(26)
#define BIT_TC11MODE_8814B BIT(25)
#define BIT_TC11EN_8814B BIT(24)
#define BIT_SHIFT_TC11DATA_8814B 0
#define BIT_MASK_TC11DATA_8814B 0xffffff
#define BIT_TC11DATA_8814B(x) \
(((x) & BIT_MASK_TC11DATA_8814B) << BIT_SHIFT_TC11DATA_8814B)
#define BITS_TC11DATA_8814B \
(BIT_MASK_TC11DATA_8814B << BIT_SHIFT_TC11DATA_8814B)
#define BIT_CLEAR_TC11DATA_8814B(x) ((x) & (~BITS_TC11DATA_8814B))
#define BIT_GET_TC11DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC11DATA_8814B) & BIT_MASK_TC11DATA_8814B)
#define BIT_SET_TC11DATA_8814B(x, v) \
(BIT_CLEAR_TC11DATA_8814B(x) | BIT_TC11DATA_8814B(v))
/* 2 REG_TC12_CTRL_8814B */
#define BIT_TC12INT_EN_8814B BIT(26)
#define BIT_TC12MODE_8814B BIT(25)
#define BIT_TC12EN_8814B BIT(24)
#define BIT_SHIFT_TC12DATA_8814B 0
#define BIT_MASK_TC12DATA_8814B 0xffffff
#define BIT_TC12DATA_8814B(x) \
(((x) & BIT_MASK_TC12DATA_8814B) << BIT_SHIFT_TC12DATA_8814B)
#define BITS_TC12DATA_8814B \
(BIT_MASK_TC12DATA_8814B << BIT_SHIFT_TC12DATA_8814B)
#define BIT_CLEAR_TC12DATA_8814B(x) ((x) & (~BITS_TC12DATA_8814B))
#define BIT_GET_TC12DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC12DATA_8814B) & BIT_MASK_TC12DATA_8814B)
#define BIT_SET_TC12DATA_8814B(x, v) \
(BIT_CLEAR_TC12DATA_8814B(x) | BIT_TC12DATA_8814B(v))
/* 2 REG_FWFF_8814B */
#define BIT_SHIFT_PKTNUM_TH_V1_8814B 24
#define BIT_MASK_PKTNUM_TH_V1_8814B 0xff
#define BIT_PKTNUM_TH_V1_8814B(x) \
(((x) & BIT_MASK_PKTNUM_TH_V1_8814B) << BIT_SHIFT_PKTNUM_TH_V1_8814B)
#define BITS_PKTNUM_TH_V1_8814B \
(BIT_MASK_PKTNUM_TH_V1_8814B << BIT_SHIFT_PKTNUM_TH_V1_8814B)
#define BIT_CLEAR_PKTNUM_TH_V1_8814B(x) ((x) & (~BITS_PKTNUM_TH_V1_8814B))
#define BIT_GET_PKTNUM_TH_V1_8814B(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V1_8814B) & BIT_MASK_PKTNUM_TH_V1_8814B)
#define BIT_SET_PKTNUM_TH_V1_8814B(x, v) \
(BIT_CLEAR_PKTNUM_TH_V1_8814B(x) | BIT_PKTNUM_TH_V1_8814B(v))
#define BIT_SHIFT_TIMER_TH_8814B 16
#define BIT_MASK_TIMER_TH_8814B 0xff
#define BIT_TIMER_TH_8814B(x) \
(((x) & BIT_MASK_TIMER_TH_8814B) << BIT_SHIFT_TIMER_TH_8814B)
#define BITS_TIMER_TH_8814B \
(BIT_MASK_TIMER_TH_8814B << BIT_SHIFT_TIMER_TH_8814B)
#define BIT_CLEAR_TIMER_TH_8814B(x) ((x) & (~BITS_TIMER_TH_8814B))
#define BIT_GET_TIMER_TH_8814B(x) \
(((x) >> BIT_SHIFT_TIMER_TH_8814B) & BIT_MASK_TIMER_TH_8814B)
#define BIT_SET_TIMER_TH_8814B(x, v) \
(BIT_CLEAR_TIMER_TH_8814B(x) | BIT_TIMER_TH_8814B(v))
#define BIT_SHIFT_RXPKT1ENADDR_8814B 0
#define BIT_MASK_RXPKT1ENADDR_8814B 0xffff
#define BIT_RXPKT1ENADDR_8814B(x) \
(((x) & BIT_MASK_RXPKT1ENADDR_8814B) << BIT_SHIFT_RXPKT1ENADDR_8814B)
#define BITS_RXPKT1ENADDR_8814B \
(BIT_MASK_RXPKT1ENADDR_8814B << BIT_SHIFT_RXPKT1ENADDR_8814B)
#define BIT_CLEAR_RXPKT1ENADDR_8814B(x) ((x) & (~BITS_RXPKT1ENADDR_8814B))
#define BIT_GET_RXPKT1ENADDR_8814B(x) \
(((x) >> BIT_SHIFT_RXPKT1ENADDR_8814B) & BIT_MASK_RXPKT1ENADDR_8814B)
#define BIT_SET_RXPKT1ENADDR_8814B(x, v) \
(BIT_CLEAR_RXPKT1ENADDR_8814B(x) | BIT_RXPKT1ENADDR_8814B(v))
/* 2 REG_RXFF_PTR_V1_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_RXFF0_RDPTR_V2_8814B 0
#define BIT_MASK_RXFF0_RDPTR_V2_8814B 0x3ffff
#define BIT_RXFF0_RDPTR_V2_8814B(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V2_8814B) \
<< BIT_SHIFT_RXFF0_RDPTR_V2_8814B)
#define BITS_RXFF0_RDPTR_V2_8814B \
(BIT_MASK_RXFF0_RDPTR_V2_8814B << BIT_SHIFT_RXFF0_RDPTR_V2_8814B)
#define BIT_CLEAR_RXFF0_RDPTR_V2_8814B(x) ((x) & (~BITS_RXFF0_RDPTR_V2_8814B))
#define BIT_GET_RXFF0_RDPTR_V2_8814B(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V2_8814B) & \
BIT_MASK_RXFF0_RDPTR_V2_8814B)
#define BIT_SET_RXFF0_RDPTR_V2_8814B(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V2_8814B(x) | BIT_RXFF0_RDPTR_V2_8814B(v))
/* 2 REG_RXFF_WTR_V1_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_RXFF0_WTPTR_V2_8814B 0
#define BIT_MASK_RXFF0_WTPTR_V2_8814B 0x3ffff
#define BIT_RXFF0_WTPTR_V2_8814B(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V2_8814B) \
<< BIT_SHIFT_RXFF0_WTPTR_V2_8814B)
#define BITS_RXFF0_WTPTR_V2_8814B \
(BIT_MASK_RXFF0_WTPTR_V2_8814B << BIT_SHIFT_RXFF0_WTPTR_V2_8814B)
#define BIT_CLEAR_RXFF0_WTPTR_V2_8814B(x) ((x) & (~BITS_RXFF0_WTPTR_V2_8814B))
#define BIT_GET_RXFF0_WTPTR_V2_8814B(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V2_8814B) & \
BIT_MASK_RXFF0_WTPTR_V2_8814B)
#define BIT_SET_RXFF0_WTPTR_V2_8814B(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V2_8814B(x) | BIT_RXFF0_WTPTR_V2_8814B(v))
/* 2 REG_FE2IMR_8814B */
#define BIT__FE4ISR__IND_MSK_8814B BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_EN_8814B BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_EN_8814B BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_EN_8814B BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_EN_8814B BIT(25)
#define BIT_FS_TXSC_VODONE_INT_EN_8814B BIT(24)
#define BIT_FS_ATIM_MB7_INT_EN_8814B BIT(23)
#define BIT_FS_ATIM_MB6_INT_EN_8814B BIT(22)
#define BIT_FS_ATIM_MB5_INT_EN_8814B BIT(21)
#define BIT_FS_ATIM_MB4_INT_EN_8814B BIT(20)
#define BIT_FS_ATIM_MB3_INT_EN_8814B BIT(19)
#define BIT_FS_ATIM_MB2_INT_EN_8814B BIT(18)
#define BIT_FS_ATIM_MB1_INT_EN_8814B BIT(17)
#define BIT_FS_ATIM_MB0_INT_EN_8814B BIT(16)
#define BIT_FS_TBTT4INT_EN_8814B BIT(11)
#define BIT_FS_TBTT3INT_EN_8814B BIT(10)
#define BIT_FS_TBTT2INT_EN_8814B BIT(9)
#define BIT_FS_TBTT1INT_EN_8814B BIT(8)
#define BIT_FS_TBTT0_MB7INT_EN_8814B BIT(7)
#define BIT_FS_TBTT0_MB6INT_EN_8814B BIT(6)
#define BIT_FS_TBTT0_MB5INT_EN_8814B BIT(5)
#define BIT_FS_TBTT0_MB4INT_EN_8814B BIT(4)
#define BIT_FS_TBTT0_MB3INT_EN_8814B BIT(3)
#define BIT_FS_TBTT0_MB2INT_EN_8814B BIT(2)
#define BIT_FS_TBTT0_MB1INT_EN_8814B BIT(1)
#define BIT_FS_TBTT0_INT_EN_8814B BIT(0)
/* 2 REG_FE2ISR_8814B */
#define BIT__FE4ISR__IND_INT_8814B BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_8814B BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_8814B BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_8814B BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_8814B BIT(25)
#define BIT_FS_TXSC_VODONE_INT_8814B BIT(24)
#define BIT_FS_ATIM_MB7_INT_8814B BIT(23)
#define BIT_FS_ATIM_MB6_INT_8814B BIT(22)
#define BIT_FS_ATIM_MB5_INT_8814B BIT(21)
#define BIT_FS_ATIM_MB4_INT_8814B BIT(20)
#define BIT_FS_ATIM_MB3_INT_8814B BIT(19)
#define BIT_FS_ATIM_MB2_INT_8814B BIT(18)
#define BIT_FS_ATIM_MB1_INT_8814B BIT(17)
#define BIT_FS_ATIM_MB0_INT_8814B BIT(16)
#define BIT_FS_TBTT4INT_8814B BIT(11)
#define BIT_FS_TBTT3INT_8814B BIT(10)
#define BIT_FS_TBTT2INT_8814B BIT(9)
#define BIT_FS_TBTT1INT_8814B BIT(8)
#define BIT_FS_TBTT0_MB7INT_8814B BIT(7)
#define BIT_FS_TBTT0_MB6INT_8814B BIT(6)
#define BIT_FS_TBTT0_MB5INT_8814B BIT(5)
#define BIT_FS_TBTT0_MB4INT_8814B BIT(4)
#define BIT_FS_TBTT0_MB3INT_8814B BIT(3)
#define BIT_FS_TBTT0_MB2INT_8814B BIT(2)
#define BIT_FS_TBTT0_MB1INT_8814B BIT(1)
#define BIT_FS_TBTT0_INT_8814B BIT(0)
/* 2 REG_FE3IMR_8814B */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT__EN_8814B BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT__EN_8814B BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT__EN_8814B BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT__EN_8814B BIT(28)
#define BIT_FS_BCNDMA4_INT_EN_8814B BIT(27)
#define BIT_FS_BCNDMA3_INT_EN_8814B BIT(26)
#define BIT_FS_BCNDMA2_INT_EN_8814B BIT(25)
#define BIT_FS_BCNDMA1_INT_EN_8814B BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_EN_8814B BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_EN_8814B BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_EN_8814B BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_EN_8814B BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_EN_8814B BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_EN_8814B BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_EN_8814B BIT(17)
#define BIT_FS_BCNDMA0_INT_EN_8814B BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT__EN_8814B BIT(15)
#define BIT_FS_BCNERLY4_INT_EN_8814B BIT(11)
#define BIT_FS_BCNERLY3_INT_EN_8814B BIT(10)
#define BIT_FS_BCNERLY2_INT_EN_8814B BIT(9)
#define BIT_FS_BCNERLY1_INT_EN_8814B BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_EN_8814B BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_EN_8814B BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_EN_8814B BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_EN_8814B BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_EN_8814B BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_EN_8814B BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_EN_8814B BIT(1)
#define BIT_FS_BCNERLY0_INT_EN_8814B BIT(0)
/* 2 REG_FE3ISR_8814B */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT_8814B BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT_8814B BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT_8814B BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT_8814B BIT(28)
#define BIT_FS_BCNDMA4_INT_8814B BIT(27)
#define BIT_FS_BCNDMA3_INT_8814B BIT(26)
#define BIT_FS_BCNDMA2_INT_8814B BIT(25)
#define BIT_FS_BCNDMA1_INT_8814B BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_8814B BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_8814B BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_8814B BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_8814B BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_8814B BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_8814B BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_8814B BIT(17)
#define BIT_FS_BCNDMA0_INT_8814B BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT_8814B BIT(15)
#define BIT_FS_BCNERLY4_INT_8814B BIT(11)
#define BIT_FS_BCNERLY3_INT_8814B BIT(10)
#define BIT_FS_BCNERLY2_INT_8814B BIT(9)
#define BIT_FS_BCNERLY1_INT_8814B BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_8814B BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_8814B BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_8814B BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_8814B BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_8814B BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_8814B BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_8814B BIT(1)
#define BIT_FS_BCNERLY0_INT_8814B BIT(0)
/* 2 REG_FE4IMR_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_FS_CLI3_TXPKTIN_INT_EN_8814B BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_EN_8814B BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_EN_8814B BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_EN_8814B BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_EN_8814B BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_EN_8814B BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_EN_8814B BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_EN_8814B BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_EN_8814B BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_EN_8814B BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_EN_8814B BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_EN_8814B BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_EN_8814B BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_EN_8814B BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_EN_8814B BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_EN_8814B BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_EN_8814B BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_EN_8814B BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_EN_8814B BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_EN_8814B BIT(0)
/* 2 REG_FE4ISR_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_P2P_PWROFF_NOA2_ERLY_INT_8814B BIT(22)
#define BIT_P2P_PWROFF_NOA1_ERLY_INT_8814B BIT(21)
#define BIT_P2P_PWROFF_NOA0_ERLY_INT_8814B BIT(20)
#define BIT_FS_CLI3_TXPKTIN_INT_8814B BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_8814B BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_8814B BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_8814B BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_8814B BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_8814B BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_8814B BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_8814B BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_8814B BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_8814B BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_8814B BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_8814B BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_8814B BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_8814B BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_8814B BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_8814B BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_8814B BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_8814B BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_8814B BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_8814B BIT(0)
/* 2 REG_FT1IMR_8814B */
#define BIT__FT2ISR__IND_MSK_8814B BIT(30)
#define BIT_FTM_PTT_INT_EN_8814B BIT(29)
#define BIT_RXFTMREQ_INT_EN_8814B BIT(28)
#define BIT_RXFTM_INT_EN_8814B BIT(27)
#define BIT_TXFTM_INT_EN_8814B BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_EN_8814B BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_EN_8814B BIT(24)
#define BIT_FS_MACID_SEARCH_FAIL_INT_EN_8814B BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_EN_8814B BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_EN_8814B BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_EN_8814B BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_EN_8814B BIT(18)
#define BIT_FS_CTWEND2_INT_EN_8814B BIT(17)
#define BIT_FS_CTWEND1_INT_EN_8814B BIT(16)
#define BIT_FS_CTWEND0_INT_EN_8814B BIT(15)
#define BIT_FS_TX_NULL1_INT_EN_8814B BIT(14)
#define BIT_FS_TX_NULL0_INT_EN_8814B BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_EN_8814B BIT(12)
#define BIT_FS_P2P_RFON2_INT_EN_8814B BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_EN_8814B BIT(10)
#define BIT_FS_P2P_RFON1_INT_EN_8814B BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_EN_8814B BIT(8)
#define BIT_FS_P2P_RFON0_INT_EN_8814B BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_EN_8814B BIT(6)
#define BIT_FS_RX_UAPSDMD1_EN_8814B BIT(5)
#define BIT_FS_RX_UAPSDMD0_EN_8814B BIT(4)
#define BIT_FS_TRIGGER_PKT_EN_8814B BIT(3)
#define BIT_FS_EOSP_INT_EN_8814B BIT(2)
#define BIT_FS_RPWM2_INT_EN_8814B BIT(1)
#define BIT_FS_RPWM_INT_EN_8814B BIT(0)
/* 2 REG_FT1ISR_8814B */
#define BIT__FT2ISR__IND_INT_8814B BIT(30)
#define BIT_FTM_PTT_INT_8814B BIT(29)
#define BIT_RXFTMREQ_INT_8814B BIT(28)
#define BIT_RXFTM_INT_8814B BIT(27)
#define BIT_TXFTM_INT_8814B BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_8814B BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_8814B BIT(24)
#define BIT_FS_MACID_SEARCH_FAIL_INT_8814B BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_8814B BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_8814B BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_8814B BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_8814B BIT(18)
#define BIT_FS_CTWEND2_INT_8814B BIT(17)
#define BIT_FS_CTWEND1_INT_8814B BIT(16)
#define BIT_FS_CTWEND0_INT_8814B BIT(15)
#define BIT_FS_TX_NULL1_INT_8814B BIT(14)
#define BIT_FS_TX_NULL0_INT_8814B BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_INT_8814B BIT(12)
#define BIT_FS_P2P_RFON2_INT_8814B BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_8814B BIT(10)
#define BIT_FS_P2P_RFON1_INT_8814B BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_8814B BIT(8)
#define BIT_FS_P2P_RFON0_INT_8814B BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_8814B BIT(6)
#define BIT_FS_RX_UAPSDMD1_INT_8814B BIT(5)
#define BIT_FS_RX_UAPSDMD0_INT_8814B BIT(4)
#define BIT_FS_TRIGGER_PKT_INT_8814B BIT(3)
#define BIT_FS_EOSP_INT_8814B BIT(2)
#define BIT_FS_RPWM2_INT_8814B BIT(1)
#define BIT_FS_RPWM_INT_8814B BIT(0)
/* 2 REG_SPWR0_8814B */
#define BIT_SHIFT_MID_31TO0_8814B 0
#define BIT_MASK_MID_31TO0_8814B 0xffffffffL
#define BIT_MID_31TO0_8814B(x) \
(((x) & BIT_MASK_MID_31TO0_8814B) << BIT_SHIFT_MID_31TO0_8814B)
#define BITS_MID_31TO0_8814B \
(BIT_MASK_MID_31TO0_8814B << BIT_SHIFT_MID_31TO0_8814B)
#define BIT_CLEAR_MID_31TO0_8814B(x) ((x) & (~BITS_MID_31TO0_8814B))
#define BIT_GET_MID_31TO0_8814B(x) \
(((x) >> BIT_SHIFT_MID_31TO0_8814B) & BIT_MASK_MID_31TO0_8814B)
#define BIT_SET_MID_31TO0_8814B(x, v) \
(BIT_CLEAR_MID_31TO0_8814B(x) | BIT_MID_31TO0_8814B(v))
/* 2 REG_SPWR1_8814B */
#define BIT_SHIFT_MID_63TO32_8814B 0
#define BIT_MASK_MID_63TO32_8814B 0xffffffffL
#define BIT_MID_63TO32_8814B(x) \
(((x) & BIT_MASK_MID_63TO32_8814B) << BIT_SHIFT_MID_63TO32_8814B)
#define BITS_MID_63TO32_8814B \
(BIT_MASK_MID_63TO32_8814B << BIT_SHIFT_MID_63TO32_8814B)
#define BIT_CLEAR_MID_63TO32_8814B(x) ((x) & (~BITS_MID_63TO32_8814B))
#define BIT_GET_MID_63TO32_8814B(x) \
(((x) >> BIT_SHIFT_MID_63TO32_8814B) & BIT_MASK_MID_63TO32_8814B)
#define BIT_SET_MID_63TO32_8814B(x, v) \
(BIT_CLEAR_MID_63TO32_8814B(x) | BIT_MID_63TO32_8814B(v))
/* 2 REG_SPWR2_8814B */
#define BIT_SHIFT_MID_95O64_8814B 0
#define BIT_MASK_MID_95O64_8814B 0xffffffffL
#define BIT_MID_95O64_8814B(x) \
(((x) & BIT_MASK_MID_95O64_8814B) << BIT_SHIFT_MID_95O64_8814B)
#define BITS_MID_95O64_8814B \
(BIT_MASK_MID_95O64_8814B << BIT_SHIFT_MID_95O64_8814B)
#define BIT_CLEAR_MID_95O64_8814B(x) ((x) & (~BITS_MID_95O64_8814B))
#define BIT_GET_MID_95O64_8814B(x) \
(((x) >> BIT_SHIFT_MID_95O64_8814B) & BIT_MASK_MID_95O64_8814B)
#define BIT_SET_MID_95O64_8814B(x, v) \
(BIT_CLEAR_MID_95O64_8814B(x) | BIT_MID_95O64_8814B(v))
/* 2 REG_SPWR3_8814B */
#define BIT_SHIFT_MID_127TO96_8814B 0
#define BIT_MASK_MID_127TO96_8814B 0xffffffffL
#define BIT_MID_127TO96_8814B(x) \
(((x) & BIT_MASK_MID_127TO96_8814B) << BIT_SHIFT_MID_127TO96_8814B)
#define BITS_MID_127TO96_8814B \
(BIT_MASK_MID_127TO96_8814B << BIT_SHIFT_MID_127TO96_8814B)
#define BIT_CLEAR_MID_127TO96_8814B(x) ((x) & (~BITS_MID_127TO96_8814B))
#define BIT_GET_MID_127TO96_8814B(x) \
(((x) >> BIT_SHIFT_MID_127TO96_8814B) & BIT_MASK_MID_127TO96_8814B)
#define BIT_SET_MID_127TO96_8814B(x, v) \
(BIT_CLEAR_MID_127TO96_8814B(x) | BIT_MID_127TO96_8814B(v))
/* 2 REG_POWSEQ_8814B */
#define BIT_SHIFT_SEQNUM_MID_8814B 16
#define BIT_MASK_SEQNUM_MID_8814B 0xffff
#define BIT_SEQNUM_MID_8814B(x) \
(((x) & BIT_MASK_SEQNUM_MID_8814B) << BIT_SHIFT_SEQNUM_MID_8814B)
#define BITS_SEQNUM_MID_8814B \
(BIT_MASK_SEQNUM_MID_8814B << BIT_SHIFT_SEQNUM_MID_8814B)
#define BIT_CLEAR_SEQNUM_MID_8814B(x) ((x) & (~BITS_SEQNUM_MID_8814B))
#define BIT_GET_SEQNUM_MID_8814B(x) \
(((x) >> BIT_SHIFT_SEQNUM_MID_8814B) & BIT_MASK_SEQNUM_MID_8814B)
#define BIT_SET_SEQNUM_MID_8814B(x, v) \
(BIT_CLEAR_SEQNUM_MID_8814B(x) | BIT_SEQNUM_MID_8814B(v))
#define BIT_SHIFT_REF_MID_8814B 0
#define BIT_MASK_REF_MID_8814B 0x7f
#define BIT_REF_MID_8814B(x) \
(((x) & BIT_MASK_REF_MID_8814B) << BIT_SHIFT_REF_MID_8814B)
#define BITS_REF_MID_8814B (BIT_MASK_REF_MID_8814B << BIT_SHIFT_REF_MID_8814B)
#define BIT_CLEAR_REF_MID_8814B(x) ((x) & (~BITS_REF_MID_8814B))
#define BIT_GET_REF_MID_8814B(x) \
(((x) >> BIT_SHIFT_REF_MID_8814B) & BIT_MASK_REF_MID_8814B)
#define BIT_SET_REF_MID_8814B(x, v) \
(BIT_CLEAR_REF_MID_8814B(x) | BIT_REF_MID_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TC7_CTRL_V1_8814B */
#define BIT_TC7INT_EN_8814B BIT(26)
#define BIT_TC7MODE_8814B BIT(25)
#define BIT_TC7EN_8814B BIT(24)
#define BIT_SHIFT_TC7DATA_8814B 0
#define BIT_MASK_TC7DATA_8814B 0xffffff
#define BIT_TC7DATA_8814B(x) \
(((x) & BIT_MASK_TC7DATA_8814B) << BIT_SHIFT_TC7DATA_8814B)
#define BITS_TC7DATA_8814B (BIT_MASK_TC7DATA_8814B << BIT_SHIFT_TC7DATA_8814B)
#define BIT_CLEAR_TC7DATA_8814B(x) ((x) & (~BITS_TC7DATA_8814B))
#define BIT_GET_TC7DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC7DATA_8814B) & BIT_MASK_TC7DATA_8814B)
#define BIT_SET_TC7DATA_8814B(x, v) \
(BIT_CLEAR_TC7DATA_8814B(x) | BIT_TC7DATA_8814B(v))
/* 2 REG_TC8_CTRL_V1_8814B */
#define BIT_TC8INT_EN_8814B BIT(26)
#define BIT_TC8MODE_8814B BIT(25)
#define BIT_TC8EN_8814B BIT(24)
#define BIT_SHIFT_TC8DATA_8814B 0
#define BIT_MASK_TC8DATA_8814B 0xffffff
#define BIT_TC8DATA_8814B(x) \
(((x) & BIT_MASK_TC8DATA_8814B) << BIT_SHIFT_TC8DATA_8814B)
#define BITS_TC8DATA_8814B (BIT_MASK_TC8DATA_8814B << BIT_SHIFT_TC8DATA_8814B)
#define BIT_CLEAR_TC8DATA_8814B(x) ((x) & (~BITS_TC8DATA_8814B))
#define BIT_GET_TC8DATA_8814B(x) \
(((x) >> BIT_SHIFT_TC8DATA_8814B) & BIT_MASK_TC8DATA_8814B)
#define BIT_SET_TC8DATA_8814B(x, v) \
(BIT_CLEAR_TC8DATA_8814B(x) | BIT_TC8DATA_8814B(v))
/* 2 REG_RX_BCN_TBTT_ITVL0_8814B */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8814B 24
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8814B 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT2_8814B(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8814B) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8814B)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT2_8814B \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8814B \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8814B)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2_8814B(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT2_8814B))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT2_8814B(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8814B) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8814B)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT2_8814B(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2_8814B(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT2_8814B(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8814B 16
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8814B 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT1_8814B(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8814B) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8814B)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT1_8814B \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8814B \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8814B)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1_8814B(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT1_8814B))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT1_8814B(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8814B) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8814B)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT1_8814B(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1_8814B(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT1_8814B(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8814B 8
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8814B 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT0_8814B(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8814B) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8814B)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT0_8814B \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8814B \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8814B)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0_8814B(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT0_8814B))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT0_8814B(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8814B) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8814B)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT0_8814B(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0_8814B(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT0_8814B(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8814B 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8814B 0xff
#define BIT_RX_BCN_TBTT_ITVL_PORT0_8814B(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8814B) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8814B)
#define BITS_RX_BCN_TBTT_ITVL_PORT0_8814B \
(BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8814B \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8814B)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0_8814B(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_PORT0_8814B))
#define BIT_GET_RX_BCN_TBTT_ITVL_PORT0_8814B(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8814B) & \
BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8814B)
#define BIT_SET_RX_BCN_TBTT_ITVL_PORT0_8814B(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0_8814B(x) | \
BIT_RX_BCN_TBTT_ITVL_PORT0_8814B(v))
/* 2 REG_RX_BCN_TBTT_ITVL1_8814B */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8814B 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8814B 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT3_8814B(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8814B) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8814B)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT3_8814B \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8814B \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8814B)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3_8814B(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT3_8814B))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT3_8814B(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8814B) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8814B)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT3_8814B(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3_8814B(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT3_8814B(v))
/* 2 REG_FWIMR1_8814B */
#define BIT_FS_ATIM_MB15_INT_EN_8814B BIT(31)
#define BIT_FS_ATIM_MB14_INT_EN_8814B BIT(30)
#define BIT_FS_ATIM_MB13_INT_EN_8814B BIT(29)
#define BIT_FS_ATIM_MB12_INT_EN_8814B BIT(28)
#define BIT_FS_ATIM_MB11_INT_EN_8814B BIT(27)
#define BIT_FS_ATIM_MB10_INT_EN_8814B BIT(26)
#define BIT_FS_ATIM_MB9_INT_EN_8814B BIT(25)
#define BIT_FS_ATIM_MB8_INT_EN_8814B BIT(24)
#define BIT_FS_TXBCNERR_MB15_INT_EN_8814B BIT(23)
#define BIT_FS_TXBCNERR_MB14_INT_EN_8814B BIT(22)
#define BIT_FS_TXBCNERR_MB13_INT_EN_8814B BIT(21)
#define BIT_FS_TXBCNERR_MB12_INT_EN_8814B BIT(20)
#define BIT_FS_TXBCNERR_MB11_INT_EN_8814B BIT(19)
#define BIT_FS_TXBCNERR_MB10_INT_EN_8814B BIT(18)
#define BIT_FS_TXBCNERR_MB9_INT_EN_8814B BIT(17)
#define BIT_FS_TXBCNERR_MB8_INT_EN_8814B BIT(16)
#define BIT_FS_TXBCNOK_MB15_INT_EN_8814B BIT(15)
#define BIT_FS_TXBCNOK_MB14_INT_EN_8814B BIT(14)
#define BIT_FS_TXBCNOK_MB13_INT_EN_8814B BIT(13)
#define BIT_FS_TXBCNOK_MB12_INT_EN_8814B BIT(12)
#define BIT_FS_TXBCNOK_MB11_INT_EN_8814B BIT(11)
#define BIT_FS_TXBCNOK_MB10_INT_EN_8814B BIT(10)
#define BIT_FS_TXBCNOK_MB9_INT_EN_8814B BIT(9)
#define BIT_FS_TXBCNOK_MB8_INT_EN_8814B BIT(8)
#define BIT_FS_BCNERLY0_MB15INT_EN_8814B BIT(7)
#define BIT_FS_BCNERLY0_MB14INT_EN_8814B BIT(6)
#define BIT_FS_BCNERLY0_MB13INT_EN_8814B BIT(5)
#define BIT_FS_BCNERLY0_MB12INT_EN_8814B BIT(4)
#define BIT_FS_BCNERLY0_MB11INT_EN_8814B BIT(3)
#define BIT_FS_BCNERLY0_MB10INT_EN_8814B BIT(2)
#define BIT_FS_BCNERLY0_MB9INT_EN_8814B BIT(1)
#define BIT_FS_BCNERLY0_MB8INT_EN_8814B BIT(0)
/* 2 REG_FWISR1_8814B */
#define BIT_FS_ATIM_MB15_INT_8814B BIT(31)
#define BIT_FS_ATIM_MB14_INT_8814B BIT(30)
#define BIT_FS_ATIM_MB13_INT_8814B BIT(29)
#define BIT_FS_ATIM_MB12_INT_8814B BIT(28)
#define BIT_FS_ATIM_MB11_INT_8814B BIT(27)
#define BIT_FS_ATIM_MB10_INT_8814B BIT(26)
#define BIT_FS_ATIM_MB9_INT_8814B BIT(25)
#define BIT_FS_ATIM_MB8_INT_8814B BIT(24)
#define BIT_FS_TXBCNERR_MB15_INT_8814B BIT(23)
#define BIT_FS_TXBCNERR_MB14_INT_8814B BIT(22)
#define BIT_FS_TXBCNERR_MB13_INT_8814B BIT(21)
#define BIT_FS_TXBCNERR_MB12_INT_8814B BIT(20)
#define BIT_FS_TXBCNERR_MB11_INT_8814B BIT(19)
#define BIT_FS_TXBCNERR_MB10_INT_8814B BIT(18)
#define BIT_FS_TXBCNERR_MB9_INT_8814B BIT(17)
#define BIT_FS_TXBCNERR_MB8_INT_8814B BIT(16)
#define BIT_FS_TXBCNOK_MB15_INT_8814B BIT(15)
#define BIT_FS_TXBCNOK_MB14_INT_8814B BIT(14)
#define BIT_FS_TXBCNOK_MB13_INT_8814B BIT(13)
#define BIT_FS_TXBCNOK_MB12_INT_8814B BIT(12)
#define BIT_FS_TXBCNOK_MB11_INT_8814B BIT(11)
#define BIT_FS_TXBCNOK_MB10_INT_8814B BIT(10)
#define BIT_FS_TXBCNOK_MB9_INT_8814B BIT(9)
#define BIT_FS_TXBCNOK_MB8_INT_8814B BIT(8)
#define BIT_FS_BCNERLY0_MB15INT_8814B BIT(7)
#define BIT_FS_BCNERLY0_MB14INT_8814B BIT(6)
#define BIT_FS_BCNERLY0_MB13INT_8814B BIT(5)
#define BIT_FS_BCNERLY0_MB12INT_8814B BIT(4)
#define BIT_FS_BCNERLY0_MB11INT_8814B BIT(3)
#define BIT_FS_BCNERLY0_MB10INT_8814B BIT(2)
#define BIT_FS_BCNERLY0_MB9INT_8814B BIT(1)
#define BIT_FS_BCNERLY0_MB8INT_8814B BIT(0)
/* 2 REG_FWIMR2_8814B */
#define BIT_FS_BCNDMA0_MB15_INT_EN_8814B BIT(15)
#define BIT_FS_BCNDMA0_MB14_INT_EN_8814B BIT(14)
#define BIT_FS_BCNDMA0_MB13_INT_EN_8814B BIT(13)
#define BIT_FS_BCNDMA0_MB12_INT_EN_8814B BIT(12)
#define BIT_FS_BCNDMA0_MB11_INT_EN_8814B BIT(11)
#define BIT_FS_BCNDMA0_MB10_INT_EN_8814B BIT(10)
#define BIT_FS_BCNDMA0_MB9_INT_EN_8814B BIT(9)
#define BIT_FS_BCNDMA0_MB8_INT_EN_8814B BIT(8)
#define BIT_FS_TBTT0_MB15INT_EN_8814B BIT(7)
#define BIT_FS_TBTT0_MB14INT_EN_8814B BIT(6)
#define BIT_FS_TBTT0_MB13INT_EN_8814B BIT(5)
#define BIT_FS_TBTT0_MB12INT_EN_8814B BIT(4)
#define BIT_FS_TBTT0_MB11INT_EN_8814B BIT(3)
#define BIT_FS_TBTT0_MB10INT_EN_8814B BIT(2)
#define BIT_FS_TBTT0_MB9INT_EN_8814B BIT(1)
#define BIT_FS_TBTT0_MB8INT_EN_8814B BIT(0)
/* 2 REG_FWISR2_8814B */
#define BIT_FS_BCNDMA0_MB15_INT_8814B BIT(15)
#define BIT_FS_BCNDMA0_MB14_INT_8814B BIT(14)
#define BIT_FS_BCNDMA0_MB13_INT_8814B BIT(13)
#define BIT_FS_BCNDMA0_MB12_INT_8814B BIT(12)
#define BIT_FS_BCNDMA0_MB11_INT_8814B BIT(11)
#define BIT_FS_BCNDMA0_MB10_INT_8814B BIT(10)
#define BIT_FS_BCNDMA0_MB9_INT_8814B BIT(9)
#define BIT_FS_BCNDMA0_MB8_INT_8814B BIT(8)
#define BIT_FS_TBTT0_MB15INT_8814B BIT(7)
#define BIT_FS_TBTT0_MB14INT_8814B BIT(6)
#define BIT_FS_TBTT0_MB13INT_8814B BIT(5)
#define BIT_FS_TBTT0_MB12INT_8814B BIT(4)
#define BIT_FS_TBTT0_MB11INT_8814B BIT(3)
#define BIT_FS_TBTT0_MB10INT_8814B BIT(2)
#define BIT_FS_TBTT0_MB9INT_8814B BIT(1)
#define BIT_FS_TBTT0_MB8INT_8814B BIT(0)
/* 2 REG_FWIMR3_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_FS_TXBCNOK_PORT4_INT_EN_8814B BIT(11)
#define BIT_FS_TXBCNOK_PORT3_INT_EN_8814B BIT(10)
#define BIT_FS_TXBCNOK_PORT2_INT_EN_8814B BIT(9)
#define BIT_FS_TXBCNOK_PORT1_INT_EN_8814B BIT(8)
#define BIT_FS_TXBCNERR_PORT4_INT_EN_8814B BIT(7)
#define BIT_FS_TXBCNERR_PORT3_INT_EN_8814B BIT(6)
#define BIT_FS_TXBCNERR_PORT2_INT_EN_8814B BIT(5)
#define BIT_FS_TXBCNERR_PORT1_INT_EN_8814B BIT(4)
#define BIT_FS_ATIM_PORT4_INT_EN_8814B BIT(3)
#define BIT_FS_ATIM_PORT3_INT_EN_8814B BIT(2)
#define BIT_FS_ATIM_PORT2_INT_EN_8814B BIT(1)
#define BIT_FS_ATIM_PORT1_INT_EN_8814B BIT(0)
/* 2 REG_FWISR3_8814B */
#define BIT_FS_TXBCNOK_PORT4_INT_8814B BIT(11)
#define BIT_FS_TXBCNOK_PORT3_INT_8814B BIT(10)
#define BIT_FS_TXBCNOK_PORT2_INT_8814B BIT(9)
#define BIT_FS_TXBCNOK_PORT1_INT_8814B BIT(8)
#define BIT_FS_TXBCNERR_PORT4_INT_8814B BIT(7)
#define BIT_FS_TXBCNERR_PORT3_INT_8814B BIT(6)
#define BIT_FS_TXBCNERR_PORT2_INT_8814B BIT(5)
#define BIT_FS_TXBCNERR_PORT1_INT_8814B BIT(4)
#define BIT_FS_ATIM_PORT4_INT_8814B BIT(3)
#define BIT_FS_ATIM_PORT3_INT_8814B BIT(2)
#define BIT_FS_ATIM_PORT2_INT_8814B BIT(1)
#define BIT_FS_ATIM_PORT1_INT_8814B BIT(0)
/* 2 REG_SPEED_SENSOR_8814B */
#define BIT_DSS_1_RST_N_8814B BIT(31)
#define BIT_DSS_1_SPEED_EN_8814B BIT(30)
#define BIT_DSS_1_WIRE_SEL_8814B BIT(29)
#define BIT_DSS_ENCLK_8814B BIT(28)
#define BIT_SHIFT_DSS_1_RO_SEL_8814B 24
#define BIT_MASK_DSS_1_RO_SEL_8814B 0x7
#define BIT_DSS_1_RO_SEL_8814B(x) \
(((x) & BIT_MASK_DSS_1_RO_SEL_8814B) << BIT_SHIFT_DSS_1_RO_SEL_8814B)
#define BITS_DSS_1_RO_SEL_8814B \
(BIT_MASK_DSS_1_RO_SEL_8814B << BIT_SHIFT_DSS_1_RO_SEL_8814B)
#define BIT_CLEAR_DSS_1_RO_SEL_8814B(x) ((x) & (~BITS_DSS_1_RO_SEL_8814B))
#define BIT_GET_DSS_1_RO_SEL_8814B(x) \
(((x) >> BIT_SHIFT_DSS_1_RO_SEL_8814B) & BIT_MASK_DSS_1_RO_SEL_8814B)
#define BIT_SET_DSS_1_RO_SEL_8814B(x, v) \
(BIT_CLEAR_DSS_1_RO_SEL_8814B(x) | BIT_DSS_1_RO_SEL_8814B(v))
#define BIT_SHIFT_DSS_1_DATA_IN_8814B 0
#define BIT_MASK_DSS_1_DATA_IN_8814B 0xfffff
#define BIT_DSS_1_DATA_IN_8814B(x) \
(((x) & BIT_MASK_DSS_1_DATA_IN_8814B) << BIT_SHIFT_DSS_1_DATA_IN_8814B)
#define BITS_DSS_1_DATA_IN_8814B \
(BIT_MASK_DSS_1_DATA_IN_8814B << BIT_SHIFT_DSS_1_DATA_IN_8814B)
#define BIT_CLEAR_DSS_1_DATA_IN_8814B(x) ((x) & (~BITS_DSS_1_DATA_IN_8814B))
#define BIT_GET_DSS_1_DATA_IN_8814B(x) \
(((x) >> BIT_SHIFT_DSS_1_DATA_IN_8814B) & BIT_MASK_DSS_1_DATA_IN_8814B)
#define BIT_SET_DSS_1_DATA_IN_8814B(x, v) \
(BIT_CLEAR_DSS_1_DATA_IN_8814B(x) | BIT_DSS_1_DATA_IN_8814B(v))
/* 2 REG_SPEED_SENSOR1_8814B */
#define BIT_DSS_1_READY_8814B BIT(31)
#define BIT_DSS_1_WSORT_GO_8814B BIT(30)
#define BIT_SHIFT_DSS_1_COUNT_OUT_8814B 0
#define BIT_MASK_DSS_1_COUNT_OUT_8814B 0xfffff
#define BIT_DSS_1_COUNT_OUT_8814B(x) \
(((x) & BIT_MASK_DSS_1_COUNT_OUT_8814B) \
<< BIT_SHIFT_DSS_1_COUNT_OUT_8814B)
#define BITS_DSS_1_COUNT_OUT_8814B \
(BIT_MASK_DSS_1_COUNT_OUT_8814B << BIT_SHIFT_DSS_1_COUNT_OUT_8814B)
#define BIT_CLEAR_DSS_1_COUNT_OUT_8814B(x) ((x) & (~BITS_DSS_1_COUNT_OUT_8814B))
#define BIT_GET_DSS_1_COUNT_OUT_8814B(x) \
(((x) >> BIT_SHIFT_DSS_1_COUNT_OUT_8814B) & \
BIT_MASK_DSS_1_COUNT_OUT_8814B)
#define BIT_SET_DSS_1_COUNT_OUT_8814B(x, v) \
(BIT_CLEAR_DSS_1_COUNT_OUT_8814B(x) | BIT_DSS_1_COUNT_OUT_8814B(v))
/* 2 REG_SPEED_SENSOR2_8814B */
#define BIT_DSS_2_RST_N_8814B BIT(31)
#define BIT_DSS_2_SPEED_EN_8814B BIT(30)
#define BIT_DSS_2_WIRE_SEL_8814B BIT(29)
#define BIT_DSS_ENCLK_8814B BIT(28)
#define BIT_SHIFT_DSS_2_RO_SEL_8814B 24
#define BIT_MASK_DSS_2_RO_SEL_8814B 0x7
#define BIT_DSS_2_RO_SEL_8814B(x) \
(((x) & BIT_MASK_DSS_2_RO_SEL_8814B) << BIT_SHIFT_DSS_2_RO_SEL_8814B)
#define BITS_DSS_2_RO_SEL_8814B \
(BIT_MASK_DSS_2_RO_SEL_8814B << BIT_SHIFT_DSS_2_RO_SEL_8814B)
#define BIT_CLEAR_DSS_2_RO_SEL_8814B(x) ((x) & (~BITS_DSS_2_RO_SEL_8814B))
#define BIT_GET_DSS_2_RO_SEL_8814B(x) \
(((x) >> BIT_SHIFT_DSS_2_RO_SEL_8814B) & BIT_MASK_DSS_2_RO_SEL_8814B)
#define BIT_SET_DSS_2_RO_SEL_8814B(x, v) \
(BIT_CLEAR_DSS_2_RO_SEL_8814B(x) | BIT_DSS_2_RO_SEL_8814B(v))
#define BIT_SHIFT_DSS_2_DATA_IN_8814B 0
#define BIT_MASK_DSS_2_DATA_IN_8814B 0xfffff
#define BIT_DSS_2_DATA_IN_8814B(x) \
(((x) & BIT_MASK_DSS_2_DATA_IN_8814B) << BIT_SHIFT_DSS_2_DATA_IN_8814B)
#define BITS_DSS_2_DATA_IN_8814B \
(BIT_MASK_DSS_2_DATA_IN_8814B << BIT_SHIFT_DSS_2_DATA_IN_8814B)
#define BIT_CLEAR_DSS_2_DATA_IN_8814B(x) ((x) & (~BITS_DSS_2_DATA_IN_8814B))
#define BIT_GET_DSS_2_DATA_IN_8814B(x) \
(((x) >> BIT_SHIFT_DSS_2_DATA_IN_8814B) & BIT_MASK_DSS_2_DATA_IN_8814B)
#define BIT_SET_DSS_2_DATA_IN_8814B(x, v) \
(BIT_CLEAR_DSS_2_DATA_IN_8814B(x) | BIT_DSS_2_DATA_IN_8814B(v))
/* 2 REG_SPEED_SENSOR3_8814B */
#define BIT_DSS_2_READY_8814B BIT(31)
#define BIT_DSS_2_WSORT_GO_8814B BIT(30)
#define BIT_SHIFT_DSS_2_COUNT_OUT_8814B 0
#define BIT_MASK_DSS_2_COUNT_OUT_8814B 0xfffff
#define BIT_DSS_2_COUNT_OUT_8814B(x) \
(((x) & BIT_MASK_DSS_2_COUNT_OUT_8814B) \
<< BIT_SHIFT_DSS_2_COUNT_OUT_8814B)
#define BITS_DSS_2_COUNT_OUT_8814B \
(BIT_MASK_DSS_2_COUNT_OUT_8814B << BIT_SHIFT_DSS_2_COUNT_OUT_8814B)
#define BIT_CLEAR_DSS_2_COUNT_OUT_8814B(x) ((x) & (~BITS_DSS_2_COUNT_OUT_8814B))
#define BIT_GET_DSS_2_COUNT_OUT_8814B(x) \
(((x) >> BIT_SHIFT_DSS_2_COUNT_OUT_8814B) & \
BIT_MASK_DSS_2_COUNT_OUT_8814B)
#define BIT_SET_DSS_2_COUNT_OUT_8814B(x, v) \
(BIT_CLEAR_DSS_2_COUNT_OUT_8814B(x) | BIT_DSS_2_COUNT_OUT_8814B(v))
/* 2 REG_SPEED_SENSOR4_8814B */
#define BIT_DSS_3_RST_N_8814B BIT(31)
#define BIT_DSS_3_SPEED_EN_8814B BIT(30)
#define BIT_DSS_3_WIRE_SEL_8814B BIT(29)
#define BIT_DSS_ENCLK_8814B BIT(28)
#define BIT_SHIFT_DSS_3_RO_SEL_8814B 24
#define BIT_MASK_DSS_3_RO_SEL_8814B 0x7
#define BIT_DSS_3_RO_SEL_8814B(x) \
(((x) & BIT_MASK_DSS_3_RO_SEL_8814B) << BIT_SHIFT_DSS_3_RO_SEL_8814B)
#define BITS_DSS_3_RO_SEL_8814B \
(BIT_MASK_DSS_3_RO_SEL_8814B << BIT_SHIFT_DSS_3_RO_SEL_8814B)
#define BIT_CLEAR_DSS_3_RO_SEL_8814B(x) ((x) & (~BITS_DSS_3_RO_SEL_8814B))
#define BIT_GET_DSS_3_RO_SEL_8814B(x) \
(((x) >> BIT_SHIFT_DSS_3_RO_SEL_8814B) & BIT_MASK_DSS_3_RO_SEL_8814B)
#define BIT_SET_DSS_3_RO_SEL_8814B(x, v) \
(BIT_CLEAR_DSS_3_RO_SEL_8814B(x) | BIT_DSS_3_RO_SEL_8814B(v))
#define BIT_SHIFT_DSS_3_DATA_IN_8814B 0
#define BIT_MASK_DSS_3_DATA_IN_8814B 0xfffff
#define BIT_DSS_3_DATA_IN_8814B(x) \
(((x) & BIT_MASK_DSS_3_DATA_IN_8814B) << BIT_SHIFT_DSS_3_DATA_IN_8814B)
#define BITS_DSS_3_DATA_IN_8814B \
(BIT_MASK_DSS_3_DATA_IN_8814B << BIT_SHIFT_DSS_3_DATA_IN_8814B)
#define BIT_CLEAR_DSS_3_DATA_IN_8814B(x) ((x) & (~BITS_DSS_3_DATA_IN_8814B))
#define BIT_GET_DSS_3_DATA_IN_8814B(x) \
(((x) >> BIT_SHIFT_DSS_3_DATA_IN_8814B) & BIT_MASK_DSS_3_DATA_IN_8814B)
#define BIT_SET_DSS_3_DATA_IN_8814B(x, v) \
(BIT_CLEAR_DSS_3_DATA_IN_8814B(x) | BIT_DSS_3_DATA_IN_8814B(v))
/* 2 REG_SPEED_SENSOR5_8814B */
#define BIT_DSS_3_READY_8814B BIT(31)
#define BIT_DSS_3_WSORT_GO_8814B BIT(30)
#define BIT_SHIFT_DSS_3_COUNT_OUT_8814B 0
#define BIT_MASK_DSS_3_COUNT_OUT_8814B 0xfffff
#define BIT_DSS_3_COUNT_OUT_8814B(x) \
(((x) & BIT_MASK_DSS_3_COUNT_OUT_8814B) \
<< BIT_SHIFT_DSS_3_COUNT_OUT_8814B)
#define BITS_DSS_3_COUNT_OUT_8814B \
(BIT_MASK_DSS_3_COUNT_OUT_8814B << BIT_SHIFT_DSS_3_COUNT_OUT_8814B)
#define BIT_CLEAR_DSS_3_COUNT_OUT_8814B(x) ((x) & (~BITS_DSS_3_COUNT_OUT_8814B))
#define BIT_GET_DSS_3_COUNT_OUT_8814B(x) \
(((x) >> BIT_SHIFT_DSS_3_COUNT_OUT_8814B) & \
BIT_MASK_DSS_3_COUNT_OUT_8814B)
#define BIT_SET_DSS_3_COUNT_OUT_8814B(x, v) \
(BIT_CLEAR_DSS_3_COUNT_OUT_8814B(x) | BIT_DSS_3_COUNT_OUT_8814B(v))
/* 2 REG_RXPKTBUF_1_MAX_ADDR_8814B */
#define BIT_SHIFT_RXPKTBUF_SIZE_8814B 30
#define BIT_MASK_RXPKTBUF_SIZE_8814B 0x3
#define BIT_RXPKTBUF_SIZE_8814B(x) \
(((x) & BIT_MASK_RXPKTBUF_SIZE_8814B) << BIT_SHIFT_RXPKTBUF_SIZE_8814B)
#define BITS_RXPKTBUF_SIZE_8814B \
(BIT_MASK_RXPKTBUF_SIZE_8814B << BIT_SHIFT_RXPKTBUF_SIZE_8814B)
#define BIT_CLEAR_RXPKTBUF_SIZE_8814B(x) ((x) & (~BITS_RXPKTBUF_SIZE_8814B))
#define BIT_GET_RXPKTBUF_SIZE_8814B(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_SIZE_8814B) & BIT_MASK_RXPKTBUF_SIZE_8814B)
#define BIT_SET_RXPKTBUF_SIZE_8814B(x, v) \
(BIT_CLEAR_RXPKTBUF_SIZE_8814B(x) | BIT_RXPKTBUF_SIZE_8814B(v))
#define BIT_RXPKTBUF_DBG_SEL_8814B BIT(29)
#define BIT_SHIFT_RXPKTBUF_1_MAX_ADDR_8814B 0
#define BIT_MASK_RXPKTBUF_1_MAX_ADDR_8814B 0x3ffff
#define BIT_RXPKTBUF_1_MAX_ADDR_8814B(x) \
(((x) & BIT_MASK_RXPKTBUF_1_MAX_ADDR_8814B) \
<< BIT_SHIFT_RXPKTBUF_1_MAX_ADDR_8814B)
#define BITS_RXPKTBUF_1_MAX_ADDR_8814B \
(BIT_MASK_RXPKTBUF_1_MAX_ADDR_8814B \
<< BIT_SHIFT_RXPKTBUF_1_MAX_ADDR_8814B)
#define BIT_CLEAR_RXPKTBUF_1_MAX_ADDR_8814B(x) \
((x) & (~BITS_RXPKTBUF_1_MAX_ADDR_8814B))
#define BIT_GET_RXPKTBUF_1_MAX_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_1_MAX_ADDR_8814B) & \
BIT_MASK_RXPKTBUF_1_MAX_ADDR_8814B)
#define BIT_SET_RXPKTBUF_1_MAX_ADDR_8814B(x, v) \
(BIT_CLEAR_RXPKTBUF_1_MAX_ADDR_8814B(x) | \
BIT_RXPKTBUF_1_MAX_ADDR_8814B(v))
/* 2 REG_RXFWBUF_1_MAX_ADDR_8814B */
#define BIT_SHIFT_RXFWBUF_1_MAX_ADDR_8814B 0
#define BIT_MASK_RXFWBUF_1_MAX_ADDR_8814B 0xffff
#define BIT_RXFWBUF_1_MAX_ADDR_8814B(x) \
(((x) & BIT_MASK_RXFWBUF_1_MAX_ADDR_8814B) \
<< BIT_SHIFT_RXFWBUF_1_MAX_ADDR_8814B)
#define BITS_RXFWBUF_1_MAX_ADDR_8814B \
(BIT_MASK_RXFWBUF_1_MAX_ADDR_8814B \
<< BIT_SHIFT_RXFWBUF_1_MAX_ADDR_8814B)
#define BIT_CLEAR_RXFWBUF_1_MAX_ADDR_8814B(x) \
((x) & (~BITS_RXFWBUF_1_MAX_ADDR_8814B))
#define BIT_GET_RXFWBUF_1_MAX_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_RXFWBUF_1_MAX_ADDR_8814B) & \
BIT_MASK_RXFWBUF_1_MAX_ADDR_8814B)
#define BIT_SET_RXFWBUF_1_MAX_ADDR_8814B(x, v) \
(BIT_CLEAR_RXFWBUF_1_MAX_ADDR_8814B(x) | \
BIT_RXFWBUF_1_MAX_ADDR_8814B(v))
/* 2 REG_IO_WRAP_ERR_FLAG_V1_8814B */
#define BIT_IO_WRAP_ERR_8814B BIT(0)
/* 2 REG_RXPKTBUF_1_READ_8814B */
#define BIT_SHIFT_RXPKTBUF_1_READ_8814B 0
#define BIT_MASK_RXPKTBUF_1_READ_8814B 0x3ffff
#define BIT_RXPKTBUF_1_READ_8814B(x) \
(((x) & BIT_MASK_RXPKTBUF_1_READ_8814B) \
<< BIT_SHIFT_RXPKTBUF_1_READ_8814B)
#define BITS_RXPKTBUF_1_READ_8814B \
(BIT_MASK_RXPKTBUF_1_READ_8814B << BIT_SHIFT_RXPKTBUF_1_READ_8814B)
#define BIT_CLEAR_RXPKTBUF_1_READ_8814B(x) ((x) & (~BITS_RXPKTBUF_1_READ_8814B))
#define BIT_GET_RXPKTBUF_1_READ_8814B(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_1_READ_8814B) & \
BIT_MASK_RXPKTBUF_1_READ_8814B)
#define BIT_SET_RXPKTBUF_1_READ_8814B(x, v) \
(BIT_CLEAR_RXPKTBUF_1_READ_8814B(x) | BIT_RXPKTBUF_1_READ_8814B(v))
/* 2 REG_RXPKTBUF_1_WRITE_8814B */
#define BIT_SHIFT_RXPKTBUF_1_WRITE_8814B 0
#define BIT_MASK_RXPKTBUF_1_WRITE_8814B 0x3ffff
#define BIT_RXPKTBUF_1_WRITE_8814B(x) \
(((x) & BIT_MASK_RXPKTBUF_1_WRITE_8814B) \
<< BIT_SHIFT_RXPKTBUF_1_WRITE_8814B)
#define BITS_RXPKTBUF_1_WRITE_8814B \
(BIT_MASK_RXPKTBUF_1_WRITE_8814B << BIT_SHIFT_RXPKTBUF_1_WRITE_8814B)
#define BIT_CLEAR_RXPKTBUF_1_WRITE_8814B(x) \
((x) & (~BITS_RXPKTBUF_1_WRITE_8814B))
#define BIT_GET_RXPKTBUF_1_WRITE_8814B(x) \
(((x) >> BIT_SHIFT_RXPKTBUF_1_WRITE_8814B) & \
BIT_MASK_RXPKTBUF_1_WRITE_8814B)
#define BIT_SET_RXPKTBUF_1_WRITE_8814B(x, v) \
(BIT_CLEAR_RXPKTBUF_1_WRITE_8814B(x) | BIT_RXPKTBUF_1_WRITE_8814B(v))
/* 2 REG_BUFF_DBGUG_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_R_OQT_DBG_SEL_8814B 16
#define BIT_MASK_R_OQT_DBG_SEL_8814B 0xff
#define BIT_R_OQT_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_R_OQT_DBG_SEL_8814B) << BIT_SHIFT_R_OQT_DBG_SEL_8814B)
#define BITS_R_OQT_DBG_SEL_8814B \
(BIT_MASK_R_OQT_DBG_SEL_8814B << BIT_SHIFT_R_OQT_DBG_SEL_8814B)
#define BIT_CLEAR_R_OQT_DBG_SEL_8814B(x) ((x) & (~BITS_R_OQT_DBG_SEL_8814B))
#define BIT_GET_R_OQT_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_OQT_DBG_SEL_8814B) & BIT_MASK_R_OQT_DBG_SEL_8814B)
#define BIT_SET_R_OQT_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_R_OQT_DBG_SEL_8814B(x) | BIT_R_OQT_DBG_SEL_8814B(v))
#define BIT_SHIFT_R_TXPKTBF_DBG_SEL_8814B 8
#define BIT_MASK_R_TXPKTBF_DBG_SEL_8814B 0x7
#define BIT_R_TXPKTBF_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_R_TXPKTBF_DBG_SEL_8814B) \
<< BIT_SHIFT_R_TXPKTBF_DBG_SEL_8814B)
#define BITS_R_TXPKTBF_DBG_SEL_8814B \
(BIT_MASK_R_TXPKTBF_DBG_SEL_8814B << BIT_SHIFT_R_TXPKTBF_DBG_SEL_8814B)
#define BIT_CLEAR_R_TXPKTBF_DBG_SEL_8814B(x) \
((x) & (~BITS_R_TXPKTBF_DBG_SEL_8814B))
#define BIT_GET_R_TXPKTBF_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_TXPKTBF_DBG_SEL_8814B) & \
BIT_MASK_R_TXPKTBF_DBG_SEL_8814B)
#define BIT_SET_R_TXPKTBF_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_R_TXPKTBF_DBG_SEL_8814B(x) | BIT_R_TXPKTBF_DBG_SEL_8814B(v))
#define BIT_SHIFT_R_RXPKT_DBG_SEL_8814B 6
#define BIT_MASK_R_RXPKT_DBG_SEL_8814B 0x3
#define BIT_R_RXPKT_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_R_RXPKT_DBG_SEL_8814B) \
<< BIT_SHIFT_R_RXPKT_DBG_SEL_8814B)
#define BITS_R_RXPKT_DBG_SEL_8814B \
(BIT_MASK_R_RXPKT_DBG_SEL_8814B << BIT_SHIFT_R_RXPKT_DBG_SEL_8814B)
#define BIT_CLEAR_R_RXPKT_DBG_SEL_8814B(x) ((x) & (~BITS_R_RXPKT_DBG_SEL_8814B))
#define BIT_GET_R_RXPKT_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_RXPKT_DBG_SEL_8814B) & \
BIT_MASK_R_RXPKT_DBG_SEL_8814B)
#define BIT_SET_R_RXPKT_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_R_RXPKT_DBG_SEL_8814B(x) | BIT_R_RXPKT_DBG_SEL_8814B(v))
#define BIT_SHIFT_R_RXPKTBF_DBG_SEL_8814B 0
#define BIT_MASK_R_RXPKTBF_DBG_SEL_8814B 0x3
#define BIT_R_RXPKTBF_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_R_RXPKTBF_DBG_SEL_8814B) \
<< BIT_SHIFT_R_RXPKTBF_DBG_SEL_8814B)
#define BITS_R_RXPKTBF_DBG_SEL_8814B \
(BIT_MASK_R_RXPKTBF_DBG_SEL_8814B << BIT_SHIFT_R_RXPKTBF_DBG_SEL_8814B)
#define BIT_CLEAR_R_RXPKTBF_DBG_SEL_8814B(x) \
((x) & (~BITS_R_RXPKTBF_DBG_SEL_8814B))
#define BIT_GET_R_RXPKTBF_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_RXPKTBF_DBG_SEL_8814B) & \
BIT_MASK_R_RXPKTBF_DBG_SEL_8814B)
#define BIT_SET_R_RXPKTBF_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_R_RXPKTBF_DBG_SEL_8814B(x) | BIT_R_RXPKTBF_DBG_SEL_8814B(v))
/* 2 REG_RFE_CTRL_PAD_E2_8814B */
#define BIT_RFE_CTRL_ANTSW_E2_8814B BIT(16)
#define BIT_RFE_CTRL_PIN15_E2_8814B BIT(15)
#define BIT_RFE_CTRL_PIN14_E2_8814B BIT(14)
#define BIT_RFE_CTRL_PIN13_E2_8814B BIT(13)
#define BIT_RFE_CTRL_PIN12_E2_8814B BIT(12)
#define BIT_RFE_CTRL_PIN11_E2_8814B BIT(11)
#define BIT_RFE_CTRL_PIN10_E2_8814B BIT(10)
#define BIT_RFE_CTRL_PIN9_E2_8814B BIT(9)
#define BIT_RFE_CTRL_PIN8_E2_8814B BIT(8)
#define BIT_RFE_CTRL_PIN7_E2_8814B BIT(7)
#define BIT_RFE_CTRL_PIN6_E2_8814B BIT(6)
#define BIT_RFE_CTRL_PIN5_E2_8814B BIT(5)
#define BIT_RFE_CTRL_PIN4_E2_8814B BIT(4)
#define BIT_RFE_CTRL_PIN3_E2_8814B BIT(3)
#define BIT_RFE_CTRL_PIN2_E2_8814B BIT(2)
#define BIT_RFE_CTRL_PIN1_E2_8814B BIT(1)
#define BIT_RFE_CTRL_PIN0_E2_8814B BIT(0)
/* 2 REG_RFE_CTRL_PAD_SR_8814B */
#define BIT_RFE_CTRL_ANTSW_SR_8814B BIT(16)
#define BIT_RFE_CTRL_PIN15_SR_8814B BIT(15)
#define BIT_RFE_CTRL_PIN14_SR_8814B BIT(14)
#define BIT_RFE_CTRL_PIN13_SR_8814B BIT(13)
#define BIT_RFE_CTRL_PIN12_SR_8814B BIT(12)
#define BIT_RFE_CTRL_PIN11_SR_8814B BIT(11)
#define BIT_RFE_CTRL_PIN10_SR_8814B BIT(10)
#define BIT_RFE_CTRL_PIN9_SR_8814B BIT(9)
#define BIT_RFE_CTRL_PIN8_SR_8814B BIT(8)
#define BIT_RFE_CTRL_PIN7_SR_8814B BIT(7)
#define BIT_RFE_CTRL_PIN6_SR_8814B BIT(6)
#define BIT_RFE_CTRL_PIN5_SR_8814B BIT(5)
#define BIT_RFE_CTRL_PIN4_SR_8814B BIT(4)
#define BIT_RFE_CTRL_PIN3_SR_8814B BIT(3)
#define BIT_RFE_CTRL_PIN2_SR_8814B BIT(2)
#define BIT_RFE_CTRL_PIN1_SR_8814B BIT(1)
#define BIT_RFE_CTRL_PIN0_SR_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_H2C_PRIORITY_SEL_8814B */
#define BIT_SHIFT_H2C_PRIORITY_SEL_8814B 0
#define BIT_MASK_H2C_PRIORITY_SEL_8814B 0x3
#define BIT_H2C_PRIORITY_SEL_8814B(x) \
(((x) & BIT_MASK_H2C_PRIORITY_SEL_8814B) \
<< BIT_SHIFT_H2C_PRIORITY_SEL_8814B)
#define BITS_H2C_PRIORITY_SEL_8814B \
(BIT_MASK_H2C_PRIORITY_SEL_8814B << BIT_SHIFT_H2C_PRIORITY_SEL_8814B)
#define BIT_CLEAR_H2C_PRIORITY_SEL_8814B(x) \
((x) & (~BITS_H2C_PRIORITY_SEL_8814B))
#define BIT_GET_H2C_PRIORITY_SEL_8814B(x) \
(((x) >> BIT_SHIFT_H2C_PRIORITY_SEL_8814B) & \
BIT_MASK_H2C_PRIORITY_SEL_8814B)
#define BIT_SET_H2C_PRIORITY_SEL_8814B(x, v) \
(BIT_CLEAR_H2C_PRIORITY_SEL_8814B(x) | BIT_H2C_PRIORITY_SEL_8814B(v))
/* 2 REG_COUNTER_CTRL_8814B */
#define BIT_SHIFT_COUNTER_BASE_8814B 16
#define BIT_MASK_COUNTER_BASE_8814B 0x1fff
#define BIT_COUNTER_BASE_8814B(x) \
(((x) & BIT_MASK_COUNTER_BASE_8814B) << BIT_SHIFT_COUNTER_BASE_8814B)
#define BITS_COUNTER_BASE_8814B \
(BIT_MASK_COUNTER_BASE_8814B << BIT_SHIFT_COUNTER_BASE_8814B)
#define BIT_CLEAR_COUNTER_BASE_8814B(x) ((x) & (~BITS_COUNTER_BASE_8814B))
#define BIT_GET_COUNTER_BASE_8814B(x) \
(((x) >> BIT_SHIFT_COUNTER_BASE_8814B) & BIT_MASK_COUNTER_BASE_8814B)
#define BIT_SET_COUNTER_BASE_8814B(x, v) \
(BIT_CLEAR_COUNTER_BASE_8814B(x) | BIT_COUNTER_BASE_8814B(v))
#define BIT_EN_RTS_REQ_8814B BIT(9)
#define BIT_EN_EDCA_REQ_8814B BIT(8)
#define BIT_EN_PTCL_REQ_8814B BIT(7)
#define BIT_EN_SCH_REQ_8814B BIT(6)
#define BIT_USB_COUNT_EN_8814B BIT(5)
#define BIT_PCIE_COUNT_EN_8814B BIT(4)
#define BIT_RQPN_COUNT_EN_8814B BIT(3)
#define BIT_RDE_COUNT_EN_8814B BIT(2)
#define BIT_TDE_COUNT_EN_8814B BIT(1)
#define BIT_DISABLE_COUNTER_8814B BIT(0)
/* 2 REG_COUNTER_THRESHOLD_8814B */
#define BIT_SEL_ALL_MACID_8814B BIT(31)
#define BIT_SHIFT_COUNTER_MACID_8814B 24
#define BIT_MASK_COUNTER_MACID_8814B 0x7f
#define BIT_COUNTER_MACID_8814B(x) \
(((x) & BIT_MASK_COUNTER_MACID_8814B) << BIT_SHIFT_COUNTER_MACID_8814B)
#define BITS_COUNTER_MACID_8814B \
(BIT_MASK_COUNTER_MACID_8814B << BIT_SHIFT_COUNTER_MACID_8814B)
#define BIT_CLEAR_COUNTER_MACID_8814B(x) ((x) & (~BITS_COUNTER_MACID_8814B))
#define BIT_GET_COUNTER_MACID_8814B(x) \
(((x) >> BIT_SHIFT_COUNTER_MACID_8814B) & BIT_MASK_COUNTER_MACID_8814B)
#define BIT_SET_COUNTER_MACID_8814B(x, v) \
(BIT_CLEAR_COUNTER_MACID_8814B(x) | BIT_COUNTER_MACID_8814B(v))
#define BIT_SHIFT_AGG_VALUE2_8814B 16
#define BIT_MASK_AGG_VALUE2_8814B 0x7f
#define BIT_AGG_VALUE2_8814B(x) \
(((x) & BIT_MASK_AGG_VALUE2_8814B) << BIT_SHIFT_AGG_VALUE2_8814B)
#define BITS_AGG_VALUE2_8814B \
(BIT_MASK_AGG_VALUE2_8814B << BIT_SHIFT_AGG_VALUE2_8814B)
#define BIT_CLEAR_AGG_VALUE2_8814B(x) ((x) & (~BITS_AGG_VALUE2_8814B))
#define BIT_GET_AGG_VALUE2_8814B(x) \
(((x) >> BIT_SHIFT_AGG_VALUE2_8814B) & BIT_MASK_AGG_VALUE2_8814B)
#define BIT_SET_AGG_VALUE2_8814B(x, v) \
(BIT_CLEAR_AGG_VALUE2_8814B(x) | BIT_AGG_VALUE2_8814B(v))
#define BIT_SHIFT_AGG_VALUE1_8814B 8
#define BIT_MASK_AGG_VALUE1_8814B 0x7f
#define BIT_AGG_VALUE1_8814B(x) \
(((x) & BIT_MASK_AGG_VALUE1_8814B) << BIT_SHIFT_AGG_VALUE1_8814B)
#define BITS_AGG_VALUE1_8814B \
(BIT_MASK_AGG_VALUE1_8814B << BIT_SHIFT_AGG_VALUE1_8814B)
#define BIT_CLEAR_AGG_VALUE1_8814B(x) ((x) & (~BITS_AGG_VALUE1_8814B))
#define BIT_GET_AGG_VALUE1_8814B(x) \
(((x) >> BIT_SHIFT_AGG_VALUE1_8814B) & BIT_MASK_AGG_VALUE1_8814B)
#define BIT_SET_AGG_VALUE1_8814B(x, v) \
(BIT_CLEAR_AGG_VALUE1_8814B(x) | BIT_AGG_VALUE1_8814B(v))
#define BIT_SHIFT_AGG_VALUE0_8814B 0
#define BIT_MASK_AGG_VALUE0_8814B 0x7f
#define BIT_AGG_VALUE0_8814B(x) \
(((x) & BIT_MASK_AGG_VALUE0_8814B) << BIT_SHIFT_AGG_VALUE0_8814B)
#define BITS_AGG_VALUE0_8814B \
(BIT_MASK_AGG_VALUE0_8814B << BIT_SHIFT_AGG_VALUE0_8814B)
#define BIT_CLEAR_AGG_VALUE0_8814B(x) ((x) & (~BITS_AGG_VALUE0_8814B))
#define BIT_GET_AGG_VALUE0_8814B(x) \
(((x) >> BIT_SHIFT_AGG_VALUE0_8814B) & BIT_MASK_AGG_VALUE0_8814B)
#define BIT_SET_AGG_VALUE0_8814B(x, v) \
(BIT_CLEAR_AGG_VALUE0_8814B(x) | BIT_AGG_VALUE0_8814B(v))
/* 2 REG_COUNTER_SET_8814B */
#define BIT_SHIFT_REQUEST_RESET_8814B 16
#define BIT_MASK_REQUEST_RESET_8814B 0xffff
#define BIT_REQUEST_RESET_8814B(x) \
(((x) & BIT_MASK_REQUEST_RESET_8814B) << BIT_SHIFT_REQUEST_RESET_8814B)
#define BITS_REQUEST_RESET_8814B \
(BIT_MASK_REQUEST_RESET_8814B << BIT_SHIFT_REQUEST_RESET_8814B)
#define BIT_CLEAR_REQUEST_RESET_8814B(x) ((x) & (~BITS_REQUEST_RESET_8814B))
#define BIT_GET_REQUEST_RESET_8814B(x) \
(((x) >> BIT_SHIFT_REQUEST_RESET_8814B) & BIT_MASK_REQUEST_RESET_8814B)
#define BIT_SET_REQUEST_RESET_8814B(x, v) \
(BIT_CLEAR_REQUEST_RESET_8814B(x) | BIT_REQUEST_RESET_8814B(v))
#define BIT_SHIFT_REQUEST_START_8814B 0
#define BIT_MASK_REQUEST_START_8814B 0xffff
#define BIT_REQUEST_START_8814B(x) \
(((x) & BIT_MASK_REQUEST_START_8814B) << BIT_SHIFT_REQUEST_START_8814B)
#define BITS_REQUEST_START_8814B \
(BIT_MASK_REQUEST_START_8814B << BIT_SHIFT_REQUEST_START_8814B)
#define BIT_CLEAR_REQUEST_START_8814B(x) ((x) & (~BITS_REQUEST_START_8814B))
#define BIT_GET_REQUEST_START_8814B(x) \
(((x) >> BIT_SHIFT_REQUEST_START_8814B) & BIT_MASK_REQUEST_START_8814B)
#define BIT_SET_REQUEST_START_8814B(x, v) \
(BIT_CLEAR_REQUEST_START_8814B(x) | BIT_REQUEST_START_8814B(v))
/* 2 REG_COUNTER_OVERFLOW_8814B */
#define BIT_SHIFT_CNT_OVF_REG_8814B 0
#define BIT_MASK_CNT_OVF_REG_8814B 0xffff
#define BIT_CNT_OVF_REG_8814B(x) \
(((x) & BIT_MASK_CNT_OVF_REG_8814B) << BIT_SHIFT_CNT_OVF_REG_8814B)
#define BITS_CNT_OVF_REG_8814B \
(BIT_MASK_CNT_OVF_REG_8814B << BIT_SHIFT_CNT_OVF_REG_8814B)
#define BIT_CLEAR_CNT_OVF_REG_8814B(x) ((x) & (~BITS_CNT_OVF_REG_8814B))
#define BIT_GET_CNT_OVF_REG_8814B(x) \
(((x) >> BIT_SHIFT_CNT_OVF_REG_8814B) & BIT_MASK_CNT_OVF_REG_8814B)
#define BIT_SET_CNT_OVF_REG_8814B(x, v) \
(BIT_CLEAR_CNT_OVF_REG_8814B(x) | BIT_CNT_OVF_REG_8814B(v))
/* 2 REG_TXDMA_LEN_THRESHOLD_8814B */
#define BIT_SHIFT_TDE_LEN_TH1_8814B 16
#define BIT_MASK_TDE_LEN_TH1_8814B 0xffff
#define BIT_TDE_LEN_TH1_8814B(x) \
(((x) & BIT_MASK_TDE_LEN_TH1_8814B) << BIT_SHIFT_TDE_LEN_TH1_8814B)
#define BITS_TDE_LEN_TH1_8814B \
(BIT_MASK_TDE_LEN_TH1_8814B << BIT_SHIFT_TDE_LEN_TH1_8814B)
#define BIT_CLEAR_TDE_LEN_TH1_8814B(x) ((x) & (~BITS_TDE_LEN_TH1_8814B))
#define BIT_GET_TDE_LEN_TH1_8814B(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH1_8814B) & BIT_MASK_TDE_LEN_TH1_8814B)
#define BIT_SET_TDE_LEN_TH1_8814B(x, v) \
(BIT_CLEAR_TDE_LEN_TH1_8814B(x) | BIT_TDE_LEN_TH1_8814B(v))
#define BIT_SHIFT_TDE_LEN_TH0_8814B 0
#define BIT_MASK_TDE_LEN_TH0_8814B 0xffff
#define BIT_TDE_LEN_TH0_8814B(x) \
(((x) & BIT_MASK_TDE_LEN_TH0_8814B) << BIT_SHIFT_TDE_LEN_TH0_8814B)
#define BITS_TDE_LEN_TH0_8814B \
(BIT_MASK_TDE_LEN_TH0_8814B << BIT_SHIFT_TDE_LEN_TH0_8814B)
#define BIT_CLEAR_TDE_LEN_TH0_8814B(x) ((x) & (~BITS_TDE_LEN_TH0_8814B))
#define BIT_GET_TDE_LEN_TH0_8814B(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH0_8814B) & BIT_MASK_TDE_LEN_TH0_8814B)
#define BIT_SET_TDE_LEN_TH0_8814B(x, v) \
(BIT_CLEAR_TDE_LEN_TH0_8814B(x) | BIT_TDE_LEN_TH0_8814B(v))
/* 2 REG_RXDMA_LEN_THRESHOLD_8814B */
#define BIT_SHIFT_RDE_LEN_TH1_8814B 16
#define BIT_MASK_RDE_LEN_TH1_8814B 0xffff
#define BIT_RDE_LEN_TH1_8814B(x) \
(((x) & BIT_MASK_RDE_LEN_TH1_8814B) << BIT_SHIFT_RDE_LEN_TH1_8814B)
#define BITS_RDE_LEN_TH1_8814B \
(BIT_MASK_RDE_LEN_TH1_8814B << BIT_SHIFT_RDE_LEN_TH1_8814B)
#define BIT_CLEAR_RDE_LEN_TH1_8814B(x) ((x) & (~BITS_RDE_LEN_TH1_8814B))
#define BIT_GET_RDE_LEN_TH1_8814B(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH1_8814B) & BIT_MASK_RDE_LEN_TH1_8814B)
#define BIT_SET_RDE_LEN_TH1_8814B(x, v) \
(BIT_CLEAR_RDE_LEN_TH1_8814B(x) | BIT_RDE_LEN_TH1_8814B(v))
#define BIT_SHIFT_RDE_LEN_TH0_8814B 0
#define BIT_MASK_RDE_LEN_TH0_8814B 0xffff
#define BIT_RDE_LEN_TH0_8814B(x) \
(((x) & BIT_MASK_RDE_LEN_TH0_8814B) << BIT_SHIFT_RDE_LEN_TH0_8814B)
#define BITS_RDE_LEN_TH0_8814B \
(BIT_MASK_RDE_LEN_TH0_8814B << BIT_SHIFT_RDE_LEN_TH0_8814B)
#define BIT_CLEAR_RDE_LEN_TH0_8814B(x) ((x) & (~BITS_RDE_LEN_TH0_8814B))
#define BIT_GET_RDE_LEN_TH0_8814B(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH0_8814B) & BIT_MASK_RDE_LEN_TH0_8814B)
#define BIT_SET_RDE_LEN_TH0_8814B(x, v) \
(BIT_CLEAR_RDE_LEN_TH0_8814B(x) | BIT_RDE_LEN_TH0_8814B(v))
/* 2 REG_PCIE_EXEC_TIME_THRESHOLD_8814B */
#define BIT_SHIFT_COUNT_INT_SEL_8814B 16
#define BIT_MASK_COUNT_INT_SEL_8814B 0x3
#define BIT_COUNT_INT_SEL_8814B(x) \
(((x) & BIT_MASK_COUNT_INT_SEL_8814B) << BIT_SHIFT_COUNT_INT_SEL_8814B)
#define BITS_COUNT_INT_SEL_8814B \
(BIT_MASK_COUNT_INT_SEL_8814B << BIT_SHIFT_COUNT_INT_SEL_8814B)
#define BIT_CLEAR_COUNT_INT_SEL_8814B(x) ((x) & (~BITS_COUNT_INT_SEL_8814B))
#define BIT_GET_COUNT_INT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_COUNT_INT_SEL_8814B) & BIT_MASK_COUNT_INT_SEL_8814B)
#define BIT_SET_COUNT_INT_SEL_8814B(x, v) \
(BIT_CLEAR_COUNT_INT_SEL_8814B(x) | BIT_COUNT_INT_SEL_8814B(v))
#define BIT_SHIFT_EXEC_TIME_TH_8814B 0
#define BIT_MASK_EXEC_TIME_TH_8814B 0xffff
#define BIT_EXEC_TIME_TH_8814B(x) \
(((x) & BIT_MASK_EXEC_TIME_TH_8814B) << BIT_SHIFT_EXEC_TIME_TH_8814B)
#define BITS_EXEC_TIME_TH_8814B \
(BIT_MASK_EXEC_TIME_TH_8814B << BIT_SHIFT_EXEC_TIME_TH_8814B)
#define BIT_CLEAR_EXEC_TIME_TH_8814B(x) ((x) & (~BITS_EXEC_TIME_TH_8814B))
#define BIT_GET_EXEC_TIME_TH_8814B(x) \
(((x) >> BIT_SHIFT_EXEC_TIME_TH_8814B) & BIT_MASK_EXEC_TIME_TH_8814B)
#define BIT_SET_EXEC_TIME_TH_8814B(x, v) \
(BIT_CLEAR_EXEC_TIME_TH_8814B(x) | BIT_EXEC_TIME_TH_8814B(v))
/* 2 REG_FT2IMR_8814B */
#define BIT_FS_CLI3_RX_UAPSDMD1_EN_8814B BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_EN_8814B BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_EN_8814B BIT(29)
#define BIT_FS_CLI3_EOSP_INT_EN_8814B BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_EN_8814B BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_EN_8814B BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_EN_8814B BIT(25)
#define BIT_FS_CLI2_EOSP_INT_EN_8814B BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_EN_8814B BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_EN_8814B BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_EN_8814B BIT(21)
#define BIT_FS_CLI1_EOSP_INT_EN_8814B BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_EN_8814B BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_EN_8814B BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_EN_8814B BIT(17)
#define BIT_FS_CLI0_EOSP_INT_EN_8814B BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_EN_8814B BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_EN_8814B BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_EN_8814B BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_EN_8814B BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_EN_8814B BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_EN_8814B BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_EN_8814B BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_EN_8814B BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_EN_8814B BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_EN_8814B BIT(0)
/* 2 REG_FT2ISR_8814B */
#define BIT_FS_CLI3_RX_UAPSDMD1_INT_8814B BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_INT_8814B BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_INT_8814B BIT(29)
#define BIT_FS_CLI3_EOSP_INT_8814B BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_INT_8814B BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_INT_8814B BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_INT_8814B BIT(25)
#define BIT_FS_CLI2_EOSP_INT_8814B BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_INT_8814B BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_INT_8814B BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_INT_8814B BIT(21)
#define BIT_FS_CLI1_EOSP_INT_8814B BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_INT_8814B BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_INT_8814B BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_INT_8814B BIT(17)
#define BIT_FS_CLI0_EOSP_INT_8814B BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_INT_8814B BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_INT_8814B BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_8814B BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_8814B BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_8814B BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_8814B BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_8814B BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_8814B BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_8814B BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_MSG2_8814B */
#define BIT_SHIFT_FW_MSG2_8814B 0
#define BIT_MASK_FW_MSG2_8814B 0xffffffffL
#define BIT_FW_MSG2_8814B(x) \
(((x) & BIT_MASK_FW_MSG2_8814B) << BIT_SHIFT_FW_MSG2_8814B)
#define BITS_FW_MSG2_8814B (BIT_MASK_FW_MSG2_8814B << BIT_SHIFT_FW_MSG2_8814B)
#define BIT_CLEAR_FW_MSG2_8814B(x) ((x) & (~BITS_FW_MSG2_8814B))
#define BIT_GET_FW_MSG2_8814B(x) \
(((x) >> BIT_SHIFT_FW_MSG2_8814B) & BIT_MASK_FW_MSG2_8814B)
#define BIT_SET_FW_MSG2_8814B(x, v) \
(BIT_CLEAR_FW_MSG2_8814B(x) | BIT_FW_MSG2_8814B(v))
/* 2 REG_MSG3_8814B */
#define BIT_SHIFT_FW_MSG3_8814B 0
#define BIT_MASK_FW_MSG3_8814B 0xffffffffL
#define BIT_FW_MSG3_8814B(x) \
(((x) & BIT_MASK_FW_MSG3_8814B) << BIT_SHIFT_FW_MSG3_8814B)
#define BITS_FW_MSG3_8814B (BIT_MASK_FW_MSG3_8814B << BIT_SHIFT_FW_MSG3_8814B)
#define BIT_CLEAR_FW_MSG3_8814B(x) ((x) & (~BITS_FW_MSG3_8814B))
#define BIT_GET_FW_MSG3_8814B(x) \
(((x) >> BIT_SHIFT_FW_MSG3_8814B) & BIT_MASK_FW_MSG3_8814B)
#define BIT_SET_FW_MSG3_8814B(x, v) \
(BIT_CLEAR_FW_MSG3_8814B(x) | BIT_FW_MSG3_8814B(v))
/* 2 REG_MSG4_8814B */
#define BIT_SHIFT_FW_MSG4_8814B 0
#define BIT_MASK_FW_MSG4_8814B 0xffffffffL
#define BIT_FW_MSG4_8814B(x) \
(((x) & BIT_MASK_FW_MSG4_8814B) << BIT_SHIFT_FW_MSG4_8814B)
#define BITS_FW_MSG4_8814B (BIT_MASK_FW_MSG4_8814B << BIT_SHIFT_FW_MSG4_8814B)
#define BIT_CLEAR_FW_MSG4_8814B(x) ((x) & (~BITS_FW_MSG4_8814B))
#define BIT_GET_FW_MSG4_8814B(x) \
(((x) >> BIT_SHIFT_FW_MSG4_8814B) & BIT_MASK_FW_MSG4_8814B)
#define BIT_SET_FW_MSG4_8814B(x, v) \
(BIT_CLEAR_FW_MSG4_8814B(x) | BIT_FW_MSG4_8814B(v))
/* 2 REG_MSG5_8814B */
#define BIT_SHIFT_FW_MSG5_8814B 0
#define BIT_MASK_FW_MSG5_8814B 0xffffffffL
#define BIT_FW_MSG5_8814B(x) \
(((x) & BIT_MASK_FW_MSG5_8814B) << BIT_SHIFT_FW_MSG5_8814B)
#define BITS_FW_MSG5_8814B (BIT_MASK_FW_MSG5_8814B << BIT_SHIFT_FW_MSG5_8814B)
#define BIT_CLEAR_FW_MSG5_8814B(x) ((x) & (~BITS_FW_MSG5_8814B))
#define BIT_GET_FW_MSG5_8814B(x) \
(((x) >> BIT_SHIFT_FW_MSG5_8814B) & BIT_MASK_FW_MSG5_8814B)
#define BIT_SET_FW_MSG5_8814B(x, v) \
(BIT_CLEAR_FW_MSG5_8814B(x) | BIT_FW_MSG5_8814B(v))
/* 2 REG_BIST_RSTN0_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_RSTN2_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_MODE_NRML0_8814B */
/* 2 REG_BIST_MODE_NRML1_8814B */
/* 2 REG_BIST_MODE_NRML2_8814B */
/* 2 REG_BIST_MODE_NRML3_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_DONE_NRML_MAC_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_DONE_NRML1_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_DONE_DRF_MAC_8814B */
/* 2 REG_BIST_DONE_DRF_8814B */
/* 2 REG_BIST_DONE_DRF1_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_FAIL_NRML_MAC_8814B */
/* 2 REG_BIST_FAIL_NRML_8814B */
/* 2 REG_BIST_FAIL_NRML1_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_FAIL_NRML_MAC_V1_8814B */
/* 2 REG_BIST_FAIL_NRML_V1_8814B */
/* 2 REG_BIST_FAIL_NRML1_V1_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BIST_MISR_DATAOUT_8814B */
/* 2 REG_BIST_MISR_DATAOUT1_8814B */
/* 2 REG_BIST_MISR_DATAOUT_CPU_8814B */
/* 2 REG_BIST_MISR_DATAOUT_CPU1_8814B */
/* 2 REG_BIST_MISR_DATAOUT_CPU2_8814B */
/* 2 REG_BIST_MISR_DATOUT_CPU3_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BCN_CTRL_0_8814B */
#define BIT_BCN1_VALID_8814B BIT(31)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCN1_HEAD_8814B 16
#define BIT_MASK_BCN1_HEAD_8814B 0xfff
#define BIT_BCN1_HEAD_8814B(x) \
(((x) & BIT_MASK_BCN1_HEAD_8814B) << BIT_SHIFT_BCN1_HEAD_8814B)
#define BITS_BCN1_HEAD_8814B \
(BIT_MASK_BCN1_HEAD_8814B << BIT_SHIFT_BCN1_HEAD_8814B)
#define BIT_CLEAR_BCN1_HEAD_8814B(x) ((x) & (~BITS_BCN1_HEAD_8814B))
#define BIT_GET_BCN1_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_BCN1_HEAD_8814B) & BIT_MASK_BCN1_HEAD_8814B)
#define BIT_SET_BCN1_HEAD_8814B(x, v) \
(BIT_CLEAR_BCN1_HEAD_8814B(x) | BIT_BCN1_HEAD_8814B(v))
#define BIT_BCN0_VALID_8814B BIT(15)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCN0_HEAD_8814B 0
#define BIT_MASK_BCN0_HEAD_8814B 0xfff
#define BIT_BCN0_HEAD_8814B(x) \
(((x) & BIT_MASK_BCN0_HEAD_8814B) << BIT_SHIFT_BCN0_HEAD_8814B)
#define BITS_BCN0_HEAD_8814B \
(BIT_MASK_BCN0_HEAD_8814B << BIT_SHIFT_BCN0_HEAD_8814B)
#define BIT_CLEAR_BCN0_HEAD_8814B(x) ((x) & (~BITS_BCN0_HEAD_8814B))
#define BIT_GET_BCN0_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_BCN0_HEAD_8814B) & BIT_MASK_BCN0_HEAD_8814B)
#define BIT_SET_BCN0_HEAD_8814B(x, v) \
(BIT_CLEAR_BCN0_HEAD_8814B(x) | BIT_BCN0_HEAD_8814B(v))
/* 2 REG_BCN_CTRL_1_8814B */
#define BIT_BCN3_VALID_8814B BIT(31)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCN3_HEAD_8814B 16
#define BIT_MASK_BCN3_HEAD_8814B 0xfff
#define BIT_BCN3_HEAD_8814B(x) \
(((x) & BIT_MASK_BCN3_HEAD_8814B) << BIT_SHIFT_BCN3_HEAD_8814B)
#define BITS_BCN3_HEAD_8814B \
(BIT_MASK_BCN3_HEAD_8814B << BIT_SHIFT_BCN3_HEAD_8814B)
#define BIT_CLEAR_BCN3_HEAD_8814B(x) ((x) & (~BITS_BCN3_HEAD_8814B))
#define BIT_GET_BCN3_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_BCN3_HEAD_8814B) & BIT_MASK_BCN3_HEAD_8814B)
#define BIT_SET_BCN3_HEAD_8814B(x, v) \
(BIT_CLEAR_BCN3_HEAD_8814B(x) | BIT_BCN3_HEAD_8814B(v))
#define BIT_BCN2_VALID_8814B BIT(15)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCN2_HEAD_8814B 0
#define BIT_MASK_BCN2_HEAD_8814B 0xfff
#define BIT_BCN2_HEAD_8814B(x) \
(((x) & BIT_MASK_BCN2_HEAD_8814B) << BIT_SHIFT_BCN2_HEAD_8814B)
#define BITS_BCN2_HEAD_8814B \
(BIT_MASK_BCN2_HEAD_8814B << BIT_SHIFT_BCN2_HEAD_8814B)
#define BIT_CLEAR_BCN2_HEAD_8814B(x) ((x) & (~BITS_BCN2_HEAD_8814B))
#define BIT_GET_BCN2_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_BCN2_HEAD_8814B) & BIT_MASK_BCN2_HEAD_8814B)
#define BIT_SET_BCN2_HEAD_8814B(x, v) \
(BIT_CLEAR_BCN2_HEAD_8814B(x) | BIT_BCN2_HEAD_8814B(v))
/* 2 REG_AUTO_LLT_V1_8814B */
#define BIT_SHIFT_MAX_TX_PKT_V1_8814B 24
#define BIT_MASK_MAX_TX_PKT_V1_8814B 0xff
#define BIT_MAX_TX_PKT_V1_8814B(x) \
(((x) & BIT_MASK_MAX_TX_PKT_V1_8814B) << BIT_SHIFT_MAX_TX_PKT_V1_8814B)
#define BITS_MAX_TX_PKT_V1_8814B \
(BIT_MASK_MAX_TX_PKT_V1_8814B << BIT_SHIFT_MAX_TX_PKT_V1_8814B)
#define BIT_CLEAR_MAX_TX_PKT_V1_8814B(x) ((x) & (~BITS_MAX_TX_PKT_V1_8814B))
#define BIT_GET_MAX_TX_PKT_V1_8814B(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_V1_8814B) & BIT_MASK_MAX_TX_PKT_V1_8814B)
#define BIT_SET_MAX_TX_PKT_V1_8814B(x, v) \
(BIT_CLEAR_MAX_TX_PKT_V1_8814B(x) | BIT_MAX_TX_PKT_V1_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_R_BCN_HEAD_SEL_V1_8814B 20
#define BIT_MASK_R_BCN_HEAD_SEL_V1_8814B 0x7
#define BIT_R_BCN_HEAD_SEL_V1_8814B(x) \
(((x) & BIT_MASK_R_BCN_HEAD_SEL_V1_8814B) \
<< BIT_SHIFT_R_BCN_HEAD_SEL_V1_8814B)
#define BITS_R_BCN_HEAD_SEL_V1_8814B \
(BIT_MASK_R_BCN_HEAD_SEL_V1_8814B << BIT_SHIFT_R_BCN_HEAD_SEL_V1_8814B)
#define BIT_CLEAR_R_BCN_HEAD_SEL_V1_8814B(x) \
((x) & (~BITS_R_BCN_HEAD_SEL_V1_8814B))
#define BIT_GET_R_BCN_HEAD_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_BCN_HEAD_SEL_V1_8814B) & \
BIT_MASK_R_BCN_HEAD_SEL_V1_8814B)
#define BIT_SET_R_BCN_HEAD_SEL_V1_8814B(x, v) \
(BIT_CLEAR_R_BCN_HEAD_SEL_V1_8814B(x) | BIT_R_BCN_HEAD_SEL_V1_8814B(v))
#define BIT_SHIFT_LLT_FREE_PAGE_V2_8814B 8
#define BIT_MASK_LLT_FREE_PAGE_V2_8814B 0xfff
#define BIT_LLT_FREE_PAGE_V2_8814B(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V2_8814B) \
<< BIT_SHIFT_LLT_FREE_PAGE_V2_8814B)
#define BITS_LLT_FREE_PAGE_V2_8814B \
(BIT_MASK_LLT_FREE_PAGE_V2_8814B << BIT_SHIFT_LLT_FREE_PAGE_V2_8814B)
#define BIT_CLEAR_LLT_FREE_PAGE_V2_8814B(x) \
((x) & (~BITS_LLT_FREE_PAGE_V2_8814B))
#define BIT_GET_LLT_FREE_PAGE_V2_8814B(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V2_8814B) & \
BIT_MASK_LLT_FREE_PAGE_V2_8814B)
#define BIT_SET_LLT_FREE_PAGE_V2_8814B(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V2_8814B(x) | BIT_LLT_FREE_PAGE_V2_8814B(v))
#define BIT_SHIFT_BLK_DESC_NUM_8814B 4
#define BIT_MASK_BLK_DESC_NUM_8814B 0xf
#define BIT_BLK_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_BLK_DESC_NUM_8814B) << BIT_SHIFT_BLK_DESC_NUM_8814B)
#define BITS_BLK_DESC_NUM_8814B \
(BIT_MASK_BLK_DESC_NUM_8814B << BIT_SHIFT_BLK_DESC_NUM_8814B)
#define BIT_CLEAR_BLK_DESC_NUM_8814B(x) ((x) & (~BITS_BLK_DESC_NUM_8814B))
#define BIT_GET_BLK_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_BLK_DESC_NUM_8814B) & BIT_MASK_BLK_DESC_NUM_8814B)
#define BIT_SET_BLK_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_BLK_DESC_NUM_8814B(x) | BIT_BLK_DESC_NUM_8814B(v))
#define BIT_TDE_ERROR_STOP_8814B BIT(3)
#define BIT_R_EN_BCN_SW_HEAD_SEL_8814B BIT(2)
#define BIT_LLT_DBG_SEL_8814B BIT(1)
#define BIT_AUTO_INIT_LLT_V1_8814B BIT(0)
/* 2 REG_TXDMA_OFFSET_CHK_8814B */
#define BIT_EM_CHKSUM_FIN_8814B BIT(31)
#define BIT_EMN_PCIE_DMA_MOD_8814B BIT(30)
#define BIT_EN_TXQUE_CLR_8814B BIT(29)
#define BIT_EN_PCIE_FIFO_MODE_8814B BIT(28)
#define BIT_SHIFT_PG_UNDER_TH_V1_8814B 16
#define BIT_MASK_PG_UNDER_TH_V1_8814B 0xfff
#define BIT_PG_UNDER_TH_V1_8814B(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V1_8814B) \
<< BIT_SHIFT_PG_UNDER_TH_V1_8814B)
#define BITS_PG_UNDER_TH_V1_8814B \
(BIT_MASK_PG_UNDER_TH_V1_8814B << BIT_SHIFT_PG_UNDER_TH_V1_8814B)
#define BIT_CLEAR_PG_UNDER_TH_V1_8814B(x) ((x) & (~BITS_PG_UNDER_TH_V1_8814B))
#define BIT_GET_PG_UNDER_TH_V1_8814B(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V1_8814B) & \
BIT_MASK_PG_UNDER_TH_V1_8814B)
#define BIT_SET_PG_UNDER_TH_V1_8814B(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V1_8814B(x) | BIT_PG_UNDER_TH_V1_8814B(v))
#define BIT_R_EN_RESET_RESTORE_H2C_8814B BIT(15)
#define BIT_SDIO_TDE_FINISH_8814B BIT(14)
#define BIT_SDIO_TXDESC_CHKSUM_EN_8814B BIT(13)
#define BIT_RST_RDPTR_8814B BIT(12)
#define BIT_RST_WRPTR_8814B BIT(11)
#define BIT_CHK_PG_TH_EN_8814B BIT(10)
#define BIT_DROP_DATA_EN_8814B BIT(9)
#define BIT_CHECK_OFFSET_EN_8814B BIT(8)
#define BIT_SHIFT_CHECK_OFFSET_8814B 0
#define BIT_MASK_CHECK_OFFSET_8814B 0xff
#define BIT_CHECK_OFFSET_8814B(x) \
(((x) & BIT_MASK_CHECK_OFFSET_8814B) << BIT_SHIFT_CHECK_OFFSET_8814B)
#define BITS_CHECK_OFFSET_8814B \
(BIT_MASK_CHECK_OFFSET_8814B << BIT_SHIFT_CHECK_OFFSET_8814B)
#define BIT_CLEAR_CHECK_OFFSET_8814B(x) ((x) & (~BITS_CHECK_OFFSET_8814B))
#define BIT_GET_CHECK_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_CHECK_OFFSET_8814B) & BIT_MASK_CHECK_OFFSET_8814B)
#define BIT_SET_CHECK_OFFSET_8814B(x, v) \
(BIT_CLEAR_CHECK_OFFSET_8814B(x) | BIT_CHECK_OFFSET_8814B(v))
/* 2 REG_TXDMA_STATUS_8814B */
#define BIT_AMSDU_PKT_SIZE_ERR_8814B BIT(31)
#define BIT_AMSDU_EN_ERR_8814B BIT(30)
#define BIT_CHKSUM_AMSDU_EN_ERR_8814B BIT(29)
#define BIT_TXPKTBF_REQ_ERR_8814B BIT(28)
#define BIT_OQT_UDN_16_8814B BIT(27)
#define BIT_OQT_OVF_16_8814B BIT(26)
#define BIT_OQT_UDN_14_15_8814B BIT(25)
#define BIT_OQT_OVF_14_15_8814B BIT(24)
#define BIT_OQT_UDN_13_8814B BIT(23)
#define BIT_OQT_OVF_13_8814B BIT(22)
#define BIT_OQT_UDN_12_8814B BIT(21)
#define BIT_OQT_OVF_12_8814B BIT(20)
#define BIT_OQT_UDN_8_11_8814B BIT(19)
#define BIT_OQT_OVF_8_11_8814B BIT(18)
#define BIT_OQT_UDN_4_7_8814B BIT(17)
#define BIT_OQT_OVF_4_7_8814B BIT(16)
#define BIT_PAYLOAD_CHKSUM_ERR_8814B BIT(15)
#define BIT_PAYLOAD_UDN_8814B BIT(14)
#define BIT_PAYLOAD_OVF_8814B BIT(13)
#define BIT_DSC_CHKSUM_FAIL_8814B BIT(12)
#define BIT_EP_QSEL_DIFF_8814B BIT(10)
#define BIT_TX_OFFS_UNMATCH_8814B BIT(9)
#define BIT_TXOQT_UDN_0_3_8814B BIT(8)
#define BIT_TXOQT_OVF_0_3_8814B BIT(7)
#define BIT_TXDMA_SFF_UDN_8814B BIT(6)
#define BIT_TXDMA_SFF_OVF_8814B BIT(5)
#define BIT_LLT_NULL_PG_8814B BIT(4)
#define BIT_PAGE_UDN_8814B BIT(3)
#define BIT_PAGE_OVF_8814B BIT(2)
#define BIT_TXFF_PG_UDN_8814B BIT(1)
#define BIT_TXFF_PG_OVF_8814B BIT(0)
/* 2 REG_TX_DMA_DBG_8814B */
/* 2 REG_DMA_RQPN_INFO_PUB_8814B */
#define BIT_SHIFT_PUB_AVAL_PG_8814B 16
#define BIT_MASK_PUB_AVAL_PG_8814B 0xfff
#define BIT_PUB_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_PUB_AVAL_PG_8814B) << BIT_SHIFT_PUB_AVAL_PG_8814B)
#define BITS_PUB_AVAL_PG_8814B \
(BIT_MASK_PUB_AVAL_PG_8814B << BIT_SHIFT_PUB_AVAL_PG_8814B)
#define BIT_CLEAR_PUB_AVAL_PG_8814B(x) ((x) & (~BITS_PUB_AVAL_PG_8814B))
#define BIT_GET_PUB_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_PUB_AVAL_PG_8814B) & BIT_MASK_PUB_AVAL_PG_8814B)
#define BIT_SET_PUB_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_PUB_AVAL_PG_8814B(x) | BIT_PUB_AVAL_PG_8814B(v))
#define BIT_SHIFT_PUB_RSVD_PG_8814B 0
#define BIT_MASK_PUB_RSVD_PG_8814B 0xfff
#define BIT_PUB_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_PUB_RSVD_PG_8814B) << BIT_SHIFT_PUB_RSVD_PG_8814B)
#define BITS_PUB_RSVD_PG_8814B \
(BIT_MASK_PUB_RSVD_PG_8814B << BIT_SHIFT_PUB_RSVD_PG_8814B)
#define BIT_CLEAR_PUB_RSVD_PG_8814B(x) ((x) & (~BITS_PUB_RSVD_PG_8814B))
#define BIT_GET_PUB_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_PUB_RSVD_PG_8814B) & BIT_MASK_PUB_RSVD_PG_8814B)
#define BIT_SET_PUB_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_PUB_RSVD_PG_8814B(x) | BIT_PUB_RSVD_PG_8814B(v))
/* 2 REG_RQPN_CTRL_2_V1_8814B */
#define BIT_LD_RQPN_V1_8814B BIT(31)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CH16_PUBLIC_DIS_8814B BIT(16)
#define BIT_CH15_PUBLIC_DIS_8814B BIT(15)
#define BIT_CH14_PUBLIC_DIS_8814B BIT(14)
#define BIT_CH13_PUBLIC_DIS_8814B BIT(13)
#define BIT_CH12_PUBLIC_DIS_8814B BIT(12)
#define BIT_CH11_PUBLIC_DIS_8814B BIT(11)
#define BIT_CH10_PUBLIC_DIS_8814B BIT(10)
#define BIT_CH9_PUBLIC_DIS_8814B BIT(9)
#define BIT_CH8_PUBLIC_DIS_8814B BIT(8)
#define BIT_CH7_PUBLIC_DIS_8814B BIT(7)
#define BIT_CH6_PUBLIC_DIS_8814B BIT(6)
#define BIT_CH5_PUBLIC_DIS_8814B BIT(5)
#define BIT_CH4_PUBLIC_DIS_8814B BIT(4)
#define BIT_CH3_PUBLIC_DIS_8814B BIT(3)
#define BIT_CH2_PUBLIC_DIS_8814B BIT(2)
#define BIT_CH1_PUBLIC_DIS_8814B BIT(1)
#define BIT_CH0_PUBLIC_DIS_8814B BIT(0)
/* 2 REG_BCN_CTRL_2_8814B */
#define BIT_BCN0_EXT_VALID_8814B BIT(31)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCN0_EXT_HEAD_8814B 16
#define BIT_MASK_BCN0_EXT_HEAD_8814B 0xfff
#define BIT_BCN0_EXT_HEAD_8814B(x) \
(((x) & BIT_MASK_BCN0_EXT_HEAD_8814B) << BIT_SHIFT_BCN0_EXT_HEAD_8814B)
#define BITS_BCN0_EXT_HEAD_8814B \
(BIT_MASK_BCN0_EXT_HEAD_8814B << BIT_SHIFT_BCN0_EXT_HEAD_8814B)
#define BIT_CLEAR_BCN0_EXT_HEAD_8814B(x) ((x) & (~BITS_BCN0_EXT_HEAD_8814B))
#define BIT_GET_BCN0_EXT_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_BCN0_EXT_HEAD_8814B) & BIT_MASK_BCN0_EXT_HEAD_8814B)
#define BIT_SET_BCN0_EXT_HEAD_8814B(x, v) \
(BIT_CLEAR_BCN0_EXT_HEAD_8814B(x) | BIT_BCN0_EXT_HEAD_8814B(v))
#define BIT_BCN4_VALID_8814B BIT(15)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCN4_HEAD_8814B 0
#define BIT_MASK_BCN4_HEAD_8814B 0xfff
#define BIT_BCN4_HEAD_8814B(x) \
(((x) & BIT_MASK_BCN4_HEAD_8814B) << BIT_SHIFT_BCN4_HEAD_8814B)
#define BITS_BCN4_HEAD_8814B \
(BIT_MASK_BCN4_HEAD_8814B << BIT_SHIFT_BCN4_HEAD_8814B)
#define BIT_CLEAR_BCN4_HEAD_8814B(x) ((x) & (~BITS_BCN4_HEAD_8814B))
#define BIT_GET_BCN4_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_BCN4_HEAD_8814B) & BIT_MASK_BCN4_HEAD_8814B)
#define BIT_SET_BCN4_HEAD_8814B(x, v) \
(BIT_CLEAR_BCN4_HEAD_8814B(x) | BIT_BCN4_HEAD_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TXPKTNUM_0_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH4_7_8814B 16
#define BIT_MASK_TXPKTNUM_CH4_7_8814B 0xfff
#define BIT_TXPKTNUM_CH4_7_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH4_7_8814B) \
<< BIT_SHIFT_TXPKTNUM_CH4_7_8814B)
#define BITS_TXPKTNUM_CH4_7_8814B \
(BIT_MASK_TXPKTNUM_CH4_7_8814B << BIT_SHIFT_TXPKTNUM_CH4_7_8814B)
#define BIT_CLEAR_TXPKTNUM_CH4_7_8814B(x) ((x) & (~BITS_TXPKTNUM_CH4_7_8814B))
#define BIT_GET_TXPKTNUM_CH4_7_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH4_7_8814B) & \
BIT_MASK_TXPKTNUM_CH4_7_8814B)
#define BIT_SET_TXPKTNUM_CH4_7_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH4_7_8814B(x) | BIT_TXPKTNUM_CH4_7_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH0_3_8814B 0
#define BIT_MASK_TXPKTNUM_CH0_3_8814B 0xfff
#define BIT_TXPKTNUM_CH0_3_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH0_3_8814B) \
<< BIT_SHIFT_TXPKTNUM_CH0_3_8814B)
#define BITS_TXPKTNUM_CH0_3_8814B \
(BIT_MASK_TXPKTNUM_CH0_3_8814B << BIT_SHIFT_TXPKTNUM_CH0_3_8814B)
#define BIT_CLEAR_TXPKTNUM_CH0_3_8814B(x) ((x) & (~BITS_TXPKTNUM_CH0_3_8814B))
#define BIT_GET_TXPKTNUM_CH0_3_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH0_3_8814B) & \
BIT_MASK_TXPKTNUM_CH0_3_8814B)
#define BIT_SET_TXPKTNUM_CH0_3_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH0_3_8814B(x) | BIT_TXPKTNUM_CH0_3_8814B(v))
/* 2 REG_TXPKTNUM_1_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH12_8814B 16
#define BIT_MASK_TXPKTNUM_CH12_8814B 0xfff
#define BIT_TXPKTNUM_CH12_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH12_8814B) << BIT_SHIFT_TXPKTNUM_CH12_8814B)
#define BITS_TXPKTNUM_CH12_8814B \
(BIT_MASK_TXPKTNUM_CH12_8814B << BIT_SHIFT_TXPKTNUM_CH12_8814B)
#define BIT_CLEAR_TXPKTNUM_CH12_8814B(x) ((x) & (~BITS_TXPKTNUM_CH12_8814B))
#define BIT_GET_TXPKTNUM_CH12_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH12_8814B) & BIT_MASK_TXPKTNUM_CH12_8814B)
#define BIT_SET_TXPKTNUM_CH12_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH12_8814B(x) | BIT_TXPKTNUM_CH12_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH8_11_8814B 0
#define BIT_MASK_TXPKTNUM_CH8_11_8814B 0xfff
#define BIT_TXPKTNUM_CH8_11_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH8_11_8814B) \
<< BIT_SHIFT_TXPKTNUM_CH8_11_8814B)
#define BITS_TXPKTNUM_CH8_11_8814B \
(BIT_MASK_TXPKTNUM_CH8_11_8814B << BIT_SHIFT_TXPKTNUM_CH8_11_8814B)
#define BIT_CLEAR_TXPKTNUM_CH8_11_8814B(x) ((x) & (~BITS_TXPKTNUM_CH8_11_8814B))
#define BIT_GET_TXPKTNUM_CH8_11_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH8_11_8814B) & \
BIT_MASK_TXPKTNUM_CH8_11_8814B)
#define BIT_SET_TXPKTNUM_CH8_11_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH8_11_8814B(x) | BIT_TXPKTNUM_CH8_11_8814B(v))
/* 2 REG_TXPKTNUM_2_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH14_15_8814B 16
#define BIT_MASK_TXPKTNUM_CH14_15_8814B 0xfff
#define BIT_TXPKTNUM_CH14_15_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH14_15_8814B) \
<< BIT_SHIFT_TXPKTNUM_CH14_15_8814B)
#define BITS_TXPKTNUM_CH14_15_8814B \
(BIT_MASK_TXPKTNUM_CH14_15_8814B << BIT_SHIFT_TXPKTNUM_CH14_15_8814B)
#define BIT_CLEAR_TXPKTNUM_CH14_15_8814B(x) \
((x) & (~BITS_TXPKTNUM_CH14_15_8814B))
#define BIT_GET_TXPKTNUM_CH14_15_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH14_15_8814B) & \
BIT_MASK_TXPKTNUM_CH14_15_8814B)
#define BIT_SET_TXPKTNUM_CH14_15_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH14_15_8814B(x) | BIT_TXPKTNUM_CH14_15_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH13_8814B 0
#define BIT_MASK_TXPKTNUM_CH13_8814B 0xfff
#define BIT_TXPKTNUM_CH13_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH13_8814B) << BIT_SHIFT_TXPKTNUM_CH13_8814B)
#define BITS_TXPKTNUM_CH13_8814B \
(BIT_MASK_TXPKTNUM_CH13_8814B << BIT_SHIFT_TXPKTNUM_CH13_8814B)
#define BIT_CLEAR_TXPKTNUM_CH13_8814B(x) ((x) & (~BITS_TXPKTNUM_CH13_8814B))
#define BIT_GET_TXPKTNUM_CH13_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH13_8814B) & BIT_MASK_TXPKTNUM_CH13_8814B)
#define BIT_SET_TXPKTNUM_CH13_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH13_8814B(x) | BIT_TXPKTNUM_CH13_8814B(v))
/* 2 REG_TXPKTNUM_3_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXPKTNUM_CH16_8814B 0
#define BIT_MASK_TXPKTNUM_CH16_8814B 0xfff
#define BIT_TXPKTNUM_CH16_8814B(x) \
(((x) & BIT_MASK_TXPKTNUM_CH16_8814B) << BIT_SHIFT_TXPKTNUM_CH16_8814B)
#define BITS_TXPKTNUM_CH16_8814B \
(BIT_MASK_TXPKTNUM_CH16_8814B << BIT_SHIFT_TXPKTNUM_CH16_8814B)
#define BIT_CLEAR_TXPKTNUM_CH16_8814B(x) ((x) & (~BITS_TXPKTNUM_CH16_8814B))
#define BIT_GET_TXPKTNUM_CH16_8814B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_CH16_8814B) & BIT_MASK_TXPKTNUM_CH16_8814B)
#define BIT_SET_TXPKTNUM_CH16_8814B(x, v) \
(BIT_CLEAR_TXPKTNUM_CH16_8814B(x) | BIT_TXPKTNUM_CH16_8814B(v))
/* 2 REG_TX_AGG_ALIGN_8814B */
#define BIT_SHIFT_HW_FLOW_CTL_EN_8814B 16
#define BIT_MASK_HW_FLOW_CTL_EN_8814B 0xffff
#define BIT_HW_FLOW_CTL_EN_8814B(x) \
(((x) & BIT_MASK_HW_FLOW_CTL_EN_8814B) \
<< BIT_SHIFT_HW_FLOW_CTL_EN_8814B)
#define BITS_HW_FLOW_CTL_EN_8814B \
(BIT_MASK_HW_FLOW_CTL_EN_8814B << BIT_SHIFT_HW_FLOW_CTL_EN_8814B)
#define BIT_CLEAR_HW_FLOW_CTL_EN_8814B(x) ((x) & (~BITS_HW_FLOW_CTL_EN_8814B))
#define BIT_GET_HW_FLOW_CTL_EN_8814B(x) \
(((x) >> BIT_SHIFT_HW_FLOW_CTL_EN_8814B) & \
BIT_MASK_HW_FLOW_CTL_EN_8814B)
#define BIT_SET_HW_FLOW_CTL_EN_8814B(x, v) \
(BIT_CLEAR_HW_FLOW_CTL_EN_8814B(x) | BIT_HW_FLOW_CTL_EN_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SDIO_TXAGG_ALIGN_ADJUST_EN_V1_8814B BIT(15)
#define BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1_8814B 0
#define BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1_8814B 0xfff
#define BIT_SDIO_TXAGG_ALIGN_SIZE_V1_8814B(x) \
(((x) & BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1_8814B) \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1_8814B)
#define BITS_SDIO_TXAGG_ALIGN_SIZE_V1_8814B \
(BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1_8814B \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1_8814B)
#define BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_V1_8814B(x) \
((x) & (~BITS_SDIO_TXAGG_ALIGN_SIZE_V1_8814B))
#define BIT_GET_SDIO_TXAGG_ALIGN_SIZE_V1_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_V1_8814B) & \
BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_V1_8814B)
#define BIT_SET_SDIO_TXAGG_ALIGN_SIZE_V1_8814B(x, v) \
(BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_V1_8814B(x) | \
BIT_SDIO_TXAGG_ALIGN_SIZE_V1_8814B(v))
/* 2 REG_H2C_HEAD_8814B */
#define BIT_SHIFT_H2C_HEAD_V1_8814B 0
#define BIT_MASK_H2C_HEAD_V1_8814B 0x7ffff
#define BIT_H2C_HEAD_V1_8814B(x) \
(((x) & BIT_MASK_H2C_HEAD_V1_8814B) << BIT_SHIFT_H2C_HEAD_V1_8814B)
#define BITS_H2C_HEAD_V1_8814B \
(BIT_MASK_H2C_HEAD_V1_8814B << BIT_SHIFT_H2C_HEAD_V1_8814B)
#define BIT_CLEAR_H2C_HEAD_V1_8814B(x) ((x) & (~BITS_H2C_HEAD_V1_8814B))
#define BIT_GET_H2C_HEAD_V1_8814B(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_V1_8814B) & BIT_MASK_H2C_HEAD_V1_8814B)
#define BIT_SET_H2C_HEAD_V1_8814B(x, v) \
(BIT_CLEAR_H2C_HEAD_V1_8814B(x) | BIT_H2C_HEAD_V1_8814B(v))
/* 2 REG_H2C_TAIL_8814B */
#define BIT_SHIFT_H2C_TAIL_V1_8814B 0
#define BIT_MASK_H2C_TAIL_V1_8814B 0x7ffff
#define BIT_H2C_TAIL_V1_8814B(x) \
(((x) & BIT_MASK_H2C_TAIL_V1_8814B) << BIT_SHIFT_H2C_TAIL_V1_8814B)
#define BITS_H2C_TAIL_V1_8814B \
(BIT_MASK_H2C_TAIL_V1_8814B << BIT_SHIFT_H2C_TAIL_V1_8814B)
#define BIT_CLEAR_H2C_TAIL_V1_8814B(x) ((x) & (~BITS_H2C_TAIL_V1_8814B))
#define BIT_GET_H2C_TAIL_V1_8814B(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_V1_8814B) & BIT_MASK_H2C_TAIL_V1_8814B)
#define BIT_SET_H2C_TAIL_V1_8814B(x, v) \
(BIT_CLEAR_H2C_TAIL_V1_8814B(x) | BIT_H2C_TAIL_V1_8814B(v))
/* 2 REG_H2C_READ_ADDR_8814B */
#define BIT_SHIFT_H2C_READ_ADDR_V1_8814B 0
#define BIT_MASK_H2C_READ_ADDR_V1_8814B 0x7ffff
#define BIT_H2C_READ_ADDR_V1_8814B(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_V1_8814B) \
<< BIT_SHIFT_H2C_READ_ADDR_V1_8814B)
#define BITS_H2C_READ_ADDR_V1_8814B \
(BIT_MASK_H2C_READ_ADDR_V1_8814B << BIT_SHIFT_H2C_READ_ADDR_V1_8814B)
#define BIT_CLEAR_H2C_READ_ADDR_V1_8814B(x) \
((x) & (~BITS_H2C_READ_ADDR_V1_8814B))
#define BIT_GET_H2C_READ_ADDR_V1_8814B(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_V1_8814B) & \
BIT_MASK_H2C_READ_ADDR_V1_8814B)
#define BIT_SET_H2C_READ_ADDR_V1_8814B(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_V1_8814B(x) | BIT_H2C_READ_ADDR_V1_8814B(v))
/* 2 REG_H2C_WR_ADDR_8814B */
#define BIT_SHIFT_H2C_WR_ADDR_V1_8814B 0
#define BIT_MASK_H2C_WR_ADDR_V1_8814B 0x7ffff
#define BIT_H2C_WR_ADDR_V1_8814B(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_V1_8814B) \
<< BIT_SHIFT_H2C_WR_ADDR_V1_8814B)
#define BITS_H2C_WR_ADDR_V1_8814B \
(BIT_MASK_H2C_WR_ADDR_V1_8814B << BIT_SHIFT_H2C_WR_ADDR_V1_8814B)
#define BIT_CLEAR_H2C_WR_ADDR_V1_8814B(x) ((x) & (~BITS_H2C_WR_ADDR_V1_8814B))
#define BIT_GET_H2C_WR_ADDR_V1_8814B(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_V1_8814B) & \
BIT_MASK_H2C_WR_ADDR_V1_8814B)
#define BIT_SET_H2C_WR_ADDR_V1_8814B(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_V1_8814B(x) | BIT_H2C_WR_ADDR_V1_8814B(v))
/* 2 REG_H2C_INFO_8814B */
#define BIT_H2C_SPACE_VLD_8814B BIT(3)
#define BIT_H2C_WR_ADDR_RST_8814B BIT(2)
#define BIT_SHIFT_H2C_LEN_SEL_8814B 0
#define BIT_MASK_H2C_LEN_SEL_8814B 0x3
#define BIT_H2C_LEN_SEL_8814B(x) \
(((x) & BIT_MASK_H2C_LEN_SEL_8814B) << BIT_SHIFT_H2C_LEN_SEL_8814B)
#define BITS_H2C_LEN_SEL_8814B \
(BIT_MASK_H2C_LEN_SEL_8814B << BIT_SHIFT_H2C_LEN_SEL_8814B)
#define BIT_CLEAR_H2C_LEN_SEL_8814B(x) ((x) & (~BITS_H2C_LEN_SEL_8814B))
#define BIT_GET_H2C_LEN_SEL_8814B(x) \
(((x) >> BIT_SHIFT_H2C_LEN_SEL_8814B) & BIT_MASK_H2C_LEN_SEL_8814B)
#define BIT_SET_H2C_LEN_SEL_8814B(x, v) \
(BIT_CLEAR_H2C_LEN_SEL_8814B(x) | BIT_H2C_LEN_SEL_8814B(v))
/* 2 REG_DMA_OQT_0_8814B */
#define BIT_SHIFT_TX_OQT_12_FREE_SPACE_8814B 24
#define BIT_MASK_TX_OQT_12_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_12_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_12_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_12_FREE_SPACE_8814B)
#define BITS_TX_OQT_12_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_12_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_12_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_12_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_12_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_12_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_12_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_12_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_12_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_12_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_12_FREE_SPACE_8814B(v))
#define BIT_SHIFT_TX_OQT_8_11_FREE_SPACE_8814B 16
#define BIT_MASK_TX_OQT_8_11_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_8_11_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_8_11_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_8_11_FREE_SPACE_8814B)
#define BITS_TX_OQT_8_11_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_8_11_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_8_11_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_8_11_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_8_11_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_8_11_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_8_11_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_8_11_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_8_11_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_8_11_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_8_11_FREE_SPACE_8814B(v))
#define BIT_SHIFT_TX_OQT_4_7_FREE_SPACE_8814B 8
#define BIT_MASK_TX_OQT_4_7_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_4_7_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_4_7_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_4_7_FREE_SPACE_8814B)
#define BITS_TX_OQT_4_7_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_4_7_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_4_7_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_4_7_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_4_7_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_4_7_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_4_7_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_4_7_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_4_7_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_4_7_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_4_7_FREE_SPACE_8814B(v))
#define BIT_SHIFT_TX_OQT_0_3_FREE_SPACE_8814B 0
#define BIT_MASK_TX_OQT_0_3_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_0_3_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_0_3_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_0_3_FREE_SPACE_8814B)
#define BITS_TX_OQT_0_3_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_0_3_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_0_3_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_0_3_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_0_3_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_0_3_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_0_3_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_0_3_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_0_3_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_0_3_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_0_3_FREE_SPACE_8814B(v))
/* 2 REG_DMA_OQT_1_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TX_OQT_16_FREE_SPACE_8814B 16
#define BIT_MASK_TX_OQT_16_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_16_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_16_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_16_FREE_SPACE_8814B)
#define BITS_TX_OQT_16_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_16_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_16_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_16_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_16_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_16_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_16_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_16_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_16_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_16_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_16_FREE_SPACE_8814B(v))
#define BIT_SHIFT_TX_OQT_14_15_FREE_SPACE_8814B 8
#define BIT_MASK_TX_OQT_14_15_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_14_15_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_14_15_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_14_15_FREE_SPACE_8814B)
#define BITS_TX_OQT_14_15_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_14_15_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_14_15_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_14_15_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_14_15_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_14_15_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_14_15_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_14_15_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_14_15_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_14_15_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_14_15_FREE_SPACE_8814B(v))
#define BIT_SHIFT_TX_OQT_13_FREE_SPACE_8814B 0
#define BIT_MASK_TX_OQT_13_FREE_SPACE_8814B 0xff
#define BIT_TX_OQT_13_FREE_SPACE_8814B(x) \
(((x) & BIT_MASK_TX_OQT_13_FREE_SPACE_8814B) \
<< BIT_SHIFT_TX_OQT_13_FREE_SPACE_8814B)
#define BITS_TX_OQT_13_FREE_SPACE_8814B \
(BIT_MASK_TX_OQT_13_FREE_SPACE_8814B \
<< BIT_SHIFT_TX_OQT_13_FREE_SPACE_8814B)
#define BIT_CLEAR_TX_OQT_13_FREE_SPACE_8814B(x) \
((x) & (~BITS_TX_OQT_13_FREE_SPACE_8814B))
#define BIT_GET_TX_OQT_13_FREE_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_TX_OQT_13_FREE_SPACE_8814B) & \
BIT_MASK_TX_OQT_13_FREE_SPACE_8814B)
#define BIT_SET_TX_OQT_13_FREE_SPACE_8814B(x, v) \
(BIT_CLEAR_TX_OQT_13_FREE_SPACE_8814B(x) | \
BIT_TX_OQT_13_FREE_SPACE_8814B(v))
/* 2 REG_RXDMA_AGG_PG_TH_8814B */
#define BIT_DMA_STORE_8814B BIT(31)
/* 2 REG_NOT_VALID_8814B */
#define BIT_EN_PRE_CALC_8814B BIT(29)
#define BIT_RXAGG_SW_EN_8814B BIT(28)
#define BIT_RXAGG_SW_TRIG_8814B BIT(27)
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_DMA_AGG_TO_V1_8814B 8
#define BIT_MASK_DMA_AGG_TO_V1_8814B 0xff
#define BIT_DMA_AGG_TO_V1_8814B(x) \
(((x) & BIT_MASK_DMA_AGG_TO_V1_8814B) << BIT_SHIFT_DMA_AGG_TO_V1_8814B)
#define BITS_DMA_AGG_TO_V1_8814B \
(BIT_MASK_DMA_AGG_TO_V1_8814B << BIT_SHIFT_DMA_AGG_TO_V1_8814B)
#define BIT_CLEAR_DMA_AGG_TO_V1_8814B(x) ((x) & (~BITS_DMA_AGG_TO_V1_8814B))
#define BIT_GET_DMA_AGG_TO_V1_8814B(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO_V1_8814B) & BIT_MASK_DMA_AGG_TO_V1_8814B)
#define BIT_SET_DMA_AGG_TO_V1_8814B(x, v) \
(BIT_CLEAR_DMA_AGG_TO_V1_8814B(x) | BIT_DMA_AGG_TO_V1_8814B(v))
#define BIT_SHIFT_RXDMA_AGG_PG_TH_8814B 0
#define BIT_MASK_RXDMA_AGG_PG_TH_8814B 0xff
#define BIT_RXDMA_AGG_PG_TH_8814B(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_8814B) \
<< BIT_SHIFT_RXDMA_AGG_PG_TH_8814B)
#define BITS_RXDMA_AGG_PG_TH_8814B \
(BIT_MASK_RXDMA_AGG_PG_TH_8814B << BIT_SHIFT_RXDMA_AGG_PG_TH_8814B)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_8814B(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_8814B))
#define BIT_GET_RXDMA_AGG_PG_TH_8814B(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_8814B) & \
BIT_MASK_RXDMA_AGG_PG_TH_8814B)
#define BIT_SET_RXDMA_AGG_PG_TH_8814B(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_8814B(x) | BIT_RXDMA_AGG_PG_TH_8814B(v))
/* 2 REG_RXDMA_CTRL_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8814B 20
#define BIT_MASK_FW_UPD_RDPTR19_TO_16_8814B 0xf
#define BIT_FW_UPD_RDPTR19_TO_16_8814B(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR19_TO_16_8814B) \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8814B)
#define BITS_FW_UPD_RDPTR19_TO_16_8814B \
(BIT_MASK_FW_UPD_RDPTR19_TO_16_8814B \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8814B)
#define BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8814B(x) \
((x) & (~BITS_FW_UPD_RDPTR19_TO_16_8814B))
#define BIT_GET_FW_UPD_RDPTR19_TO_16_8814B(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8814B) & \
BIT_MASK_FW_UPD_RDPTR19_TO_16_8814B)
#define BIT_SET_FW_UPD_RDPTR19_TO_16_8814B(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8814B(x) | \
BIT_FW_UPD_RDPTR19_TO_16_8814B(v))
#define BIT_RXDMA_REQ_8814B BIT(19)
#define BIT_RW_RELEASE_EN_8814B BIT(18)
#define BIT_RXDMA_IDLE_8814B BIT(17)
#define BIT_RXPKT_RELEASE_POLL_8814B BIT(16)
#define BIT_SHIFT_FW_UPD_RDPTR_8814B 0
#define BIT_MASK_FW_UPD_RDPTR_8814B 0xffff
#define BIT_FW_UPD_RDPTR_8814B(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR_8814B) << BIT_SHIFT_FW_UPD_RDPTR_8814B)
#define BITS_FW_UPD_RDPTR_8814B \
(BIT_MASK_FW_UPD_RDPTR_8814B << BIT_SHIFT_FW_UPD_RDPTR_8814B)
#define BIT_CLEAR_FW_UPD_RDPTR_8814B(x) ((x) & (~BITS_FW_UPD_RDPTR_8814B))
#define BIT_GET_FW_UPD_RDPTR_8814B(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR_8814B) & BIT_MASK_FW_UPD_RDPTR_8814B)
#define BIT_SET_FW_UPD_RDPTR_8814B(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR_8814B(x) | BIT_FW_UPD_RDPTR_8814B(v))
/* 2 REG_RXDMA_STATUS_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_C2H_PKT_OVF_8814B BIT(7)
#define BIT_AGG_CONFGI_ISSUE_8814B BIT(6)
#define BIT_FW_POLL_ISSUE_8814B BIT(5)
#define BIT_RX_DATA_UDN_8814B BIT(4)
#define BIT_RX_SFF_UDN_8814B BIT(3)
#define BIT_RX_SFF_OVF_8814B BIT(2)
#define BIT_RXPKT_OVF_8814B BIT(0)
/* 2 REG_RXDMA_DPR_8814B */
#define BIT_SHIFT_RDE_DEBUG_8814B 0
#define BIT_MASK_RDE_DEBUG_8814B 0xffffffffL
#define BIT_RDE_DEBUG_8814B(x) \
(((x) & BIT_MASK_RDE_DEBUG_8814B) << BIT_SHIFT_RDE_DEBUG_8814B)
#define BITS_RDE_DEBUG_8814B \
(BIT_MASK_RDE_DEBUG_8814B << BIT_SHIFT_RDE_DEBUG_8814B)
#define BIT_CLEAR_RDE_DEBUG_8814B(x) ((x) & (~BITS_RDE_DEBUG_8814B))
#define BIT_GET_RDE_DEBUG_8814B(x) \
(((x) >> BIT_SHIFT_RDE_DEBUG_8814B) & BIT_MASK_RDE_DEBUG_8814B)
#define BIT_SET_RDE_DEBUG_8814B(x, v) \
(BIT_CLEAR_RDE_DEBUG_8814B(x) | BIT_RDE_DEBUG_8814B(v))
/* 2 REG_RXDMA_MODE_8814B */
#define BIT_SHIFT_PKTNUM_TH_V2_8814B 24
#define BIT_MASK_PKTNUM_TH_V2_8814B 0x1f
#define BIT_PKTNUM_TH_V2_8814B(x) \
(((x) & BIT_MASK_PKTNUM_TH_V2_8814B) << BIT_SHIFT_PKTNUM_TH_V2_8814B)
#define BITS_PKTNUM_TH_V2_8814B \
(BIT_MASK_PKTNUM_TH_V2_8814B << BIT_SHIFT_PKTNUM_TH_V2_8814B)
#define BIT_CLEAR_PKTNUM_TH_V2_8814B(x) ((x) & (~BITS_PKTNUM_TH_V2_8814B))
#define BIT_GET_PKTNUM_TH_V2_8814B(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V2_8814B) & BIT_MASK_PKTNUM_TH_V2_8814B)
#define BIT_SET_PKTNUM_TH_V2_8814B(x, v) \
(BIT_CLEAR_PKTNUM_TH_V2_8814B(x) | BIT_PKTNUM_TH_V2_8814B(v))
#define BIT_TXBA_BREAK_USBAGG_8814B BIT(23)
#define BIT_SHIFT_PKTLEN_PARA_8814B 16
#define BIT_MASK_PKTLEN_PARA_8814B 0x7
#define BIT_PKTLEN_PARA_8814B(x) \
(((x) & BIT_MASK_PKTLEN_PARA_8814B) << BIT_SHIFT_PKTLEN_PARA_8814B)
#define BITS_PKTLEN_PARA_8814B \
(BIT_MASK_PKTLEN_PARA_8814B << BIT_SHIFT_PKTLEN_PARA_8814B)
#define BIT_CLEAR_PKTLEN_PARA_8814B(x) ((x) & (~BITS_PKTLEN_PARA_8814B))
#define BIT_GET_PKTLEN_PARA_8814B(x) \
(((x) >> BIT_SHIFT_PKTLEN_PARA_8814B) & BIT_MASK_PKTLEN_PARA_8814B)
#define BIT_SET_PKTLEN_PARA_8814B(x, v) \
(BIT_CLEAR_PKTLEN_PARA_8814B(x) | BIT_PKTLEN_PARA_8814B(v))
#define BIT_RX_DBG_SEL_8814B BIT(7)
#define BIT_EN_SPD_8814B BIT(6)
#define BIT_SHIFT_BURST_SIZE_8814B 4
#define BIT_MASK_BURST_SIZE_8814B 0x3
#define BIT_BURST_SIZE_8814B(x) \
(((x) & BIT_MASK_BURST_SIZE_8814B) << BIT_SHIFT_BURST_SIZE_8814B)
#define BITS_BURST_SIZE_8814B \
(BIT_MASK_BURST_SIZE_8814B << BIT_SHIFT_BURST_SIZE_8814B)
#define BIT_CLEAR_BURST_SIZE_8814B(x) ((x) & (~BITS_BURST_SIZE_8814B))
#define BIT_GET_BURST_SIZE_8814B(x) \
(((x) >> BIT_SHIFT_BURST_SIZE_8814B) & BIT_MASK_BURST_SIZE_8814B)
#define BIT_SET_BURST_SIZE_8814B(x, v) \
(BIT_CLEAR_BURST_SIZE_8814B(x) | BIT_BURST_SIZE_8814B(v))
#define BIT_SHIFT_BURST_CNT_8814B 2
#define BIT_MASK_BURST_CNT_8814B 0x3
#define BIT_BURST_CNT_8814B(x) \
(((x) & BIT_MASK_BURST_CNT_8814B) << BIT_SHIFT_BURST_CNT_8814B)
#define BITS_BURST_CNT_8814B \
(BIT_MASK_BURST_CNT_8814B << BIT_SHIFT_BURST_CNT_8814B)
#define BIT_CLEAR_BURST_CNT_8814B(x) ((x) & (~BITS_BURST_CNT_8814B))
#define BIT_GET_BURST_CNT_8814B(x) \
(((x) >> BIT_SHIFT_BURST_CNT_8814B) & BIT_MASK_BURST_CNT_8814B)
#define BIT_SET_BURST_CNT_8814B(x, v) \
(BIT_CLEAR_BURST_CNT_8814B(x) | BIT_BURST_CNT_8814B(v))
#define BIT_DMA_MODE_8814B BIT(1)
/* 2 REG_C2H_PKT_8814B */
#define BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8814B 24
#define BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8814B 0xf
#define BIT_R_C2H_STR_ADDR_16_TO_19_8814B(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8814B) \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8814B)
#define BITS_R_C2H_STR_ADDR_16_TO_19_8814B \
(BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8814B \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8814B)
#define BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8814B(x) \
((x) & (~BITS_R_C2H_STR_ADDR_16_TO_19_8814B))
#define BIT_GET_R_C2H_STR_ADDR_16_TO_19_8814B(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8814B) & \
BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8814B)
#define BIT_SET_R_C2H_STR_ADDR_16_TO_19_8814B(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8814B(x) | \
BIT_R_C2H_STR_ADDR_16_TO_19_8814B(v))
#define BIT_R_C2H_PKT_REQ_8814B BIT(16)
#define BIT_SHIFT_R_C2H_STR_ADDR_8814B 0
#define BIT_MASK_R_C2H_STR_ADDR_8814B 0xffff
#define BIT_R_C2H_STR_ADDR_8814B(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_8814B) \
<< BIT_SHIFT_R_C2H_STR_ADDR_8814B)
#define BITS_R_C2H_STR_ADDR_8814B \
(BIT_MASK_R_C2H_STR_ADDR_8814B << BIT_SHIFT_R_C2H_STR_ADDR_8814B)
#define BIT_CLEAR_R_C2H_STR_ADDR_8814B(x) ((x) & (~BITS_R_C2H_STR_ADDR_8814B))
#define BIT_GET_R_C2H_STR_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_8814B) & \
BIT_MASK_R_C2H_STR_ADDR_8814B)
#define BIT_SET_R_C2H_STR_ADDR_8814B(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_8814B(x) | BIT_R_C2H_STR_ADDR_8814B(v))
/* 2 REG_FWFF_C2H_8814B */
#define BIT_SHIFT_C2H_DMA_ADDR_8814B 0
#define BIT_MASK_C2H_DMA_ADDR_8814B 0x3ffff
#define BIT_C2H_DMA_ADDR_8814B(x) \
(((x) & BIT_MASK_C2H_DMA_ADDR_8814B) << BIT_SHIFT_C2H_DMA_ADDR_8814B)
#define BITS_C2H_DMA_ADDR_8814B \
(BIT_MASK_C2H_DMA_ADDR_8814B << BIT_SHIFT_C2H_DMA_ADDR_8814B)
#define BIT_CLEAR_C2H_DMA_ADDR_8814B(x) ((x) & (~BITS_C2H_DMA_ADDR_8814B))
#define BIT_GET_C2H_DMA_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_C2H_DMA_ADDR_8814B) & BIT_MASK_C2H_DMA_ADDR_8814B)
#define BIT_SET_C2H_DMA_ADDR_8814B(x, v) \
(BIT_CLEAR_C2H_DMA_ADDR_8814B(x) | BIT_C2H_DMA_ADDR_8814B(v))
/* 2 REG_FWFF_CTRL_8814B */
#define BIT_FWFF_DMAPKT_REQ_8814B BIT(31)
#define BIT_SHIFT_FWFF_DMA_PKT_NUM_V1_8814B 16
#define BIT_MASK_FWFF_DMA_PKT_NUM_V1_8814B 0x7fff
#define BIT_FWFF_DMA_PKT_NUM_V1_8814B(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM_V1_8814B) \
<< BIT_SHIFT_FWFF_DMA_PKT_NUM_V1_8814B)
#define BITS_FWFF_DMA_PKT_NUM_V1_8814B \
(BIT_MASK_FWFF_DMA_PKT_NUM_V1_8814B \
<< BIT_SHIFT_FWFF_DMA_PKT_NUM_V1_8814B)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM_V1_8814B(x) \
((x) & (~BITS_FWFF_DMA_PKT_NUM_V1_8814B))
#define BIT_GET_FWFF_DMA_PKT_NUM_V1_8814B(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM_V1_8814B) & \
BIT_MASK_FWFF_DMA_PKT_NUM_V1_8814B)
#define BIT_SET_FWFF_DMA_PKT_NUM_V1_8814B(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM_V1_8814B(x) | \
BIT_FWFF_DMA_PKT_NUM_V1_8814B(v))
#define BIT_SHIFT_FWFF_STR_ADDR_8814B 0
#define BIT_MASK_FWFF_STR_ADDR_8814B 0xffff
#define BIT_FWFF_STR_ADDR_8814B(x) \
(((x) & BIT_MASK_FWFF_STR_ADDR_8814B) << BIT_SHIFT_FWFF_STR_ADDR_8814B)
#define BITS_FWFF_STR_ADDR_8814B \
(BIT_MASK_FWFF_STR_ADDR_8814B << BIT_SHIFT_FWFF_STR_ADDR_8814B)
#define BIT_CLEAR_FWFF_STR_ADDR_8814B(x) ((x) & (~BITS_FWFF_STR_ADDR_8814B))
#define BIT_GET_FWFF_STR_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_FWFF_STR_ADDR_8814B) & BIT_MASK_FWFF_STR_ADDR_8814B)
#define BIT_SET_FWFF_STR_ADDR_8814B(x, v) \
(BIT_CLEAR_FWFF_STR_ADDR_8814B(x) | BIT_FWFF_STR_ADDR_8814B(v))
/* 2 REG_FWFF_PKT_INFO_8814B */
#define BIT_SHIFT_FWFF_PKT_READ_ADDR_8814B 16
#define BIT_MASK_FWFF_PKT_READ_ADDR_8814B 0xffff
#define BIT_FWFF_PKT_READ_ADDR_8814B(x) \
(((x) & BIT_MASK_FWFF_PKT_READ_ADDR_8814B) \
<< BIT_SHIFT_FWFF_PKT_READ_ADDR_8814B)
#define BITS_FWFF_PKT_READ_ADDR_8814B \
(BIT_MASK_FWFF_PKT_READ_ADDR_8814B \
<< BIT_SHIFT_FWFF_PKT_READ_ADDR_8814B)
#define BIT_CLEAR_FWFF_PKT_READ_ADDR_8814B(x) \
((x) & (~BITS_FWFF_PKT_READ_ADDR_8814B))
#define BIT_GET_FWFF_PKT_READ_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_READ_ADDR_8814B) & \
BIT_MASK_FWFF_PKT_READ_ADDR_8814B)
#define BIT_SET_FWFF_PKT_READ_ADDR_8814B(x, v) \
(BIT_CLEAR_FWFF_PKT_READ_ADDR_8814B(x) | \
BIT_FWFF_PKT_READ_ADDR_8814B(v))
#define BIT_SHIFT_FWFF_PKT_WRITE_ADDR_8814B 0
#define BIT_MASK_FWFF_PKT_WRITE_ADDR_8814B 0xffff
#define BIT_FWFF_PKT_WRITE_ADDR_8814B(x) \
(((x) & BIT_MASK_FWFF_PKT_WRITE_ADDR_8814B) \
<< BIT_SHIFT_FWFF_PKT_WRITE_ADDR_8814B)
#define BITS_FWFF_PKT_WRITE_ADDR_8814B \
(BIT_MASK_FWFF_PKT_WRITE_ADDR_8814B \
<< BIT_SHIFT_FWFF_PKT_WRITE_ADDR_8814B)
#define BIT_CLEAR_FWFF_PKT_WRITE_ADDR_8814B(x) \
((x) & (~BITS_FWFF_PKT_WRITE_ADDR_8814B))
#define BIT_GET_FWFF_PKT_WRITE_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_WRITE_ADDR_8814B) & \
BIT_MASK_FWFF_PKT_WRITE_ADDR_8814B)
#define BIT_SET_FWFF_PKT_WRITE_ADDR_8814B(x, v) \
(BIT_CLEAR_FWFF_PKT_WRITE_ADDR_8814B(x) | \
BIT_FWFF_PKT_WRITE_ADDR_8814B(v))
/* 2 REG_FWFF_PKT_INFO2_8814B */
#define BIT_SHIFT_FWFF_PKT_QUEUED_V1_8814B 0
#define BIT_MASK_FWFF_PKT_QUEUED_V1_8814B 0xffff
#define BIT_FWFF_PKT_QUEUED_V1_8814B(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED_V1_8814B) \
<< BIT_SHIFT_FWFF_PKT_QUEUED_V1_8814B)
#define BITS_FWFF_PKT_QUEUED_V1_8814B \
(BIT_MASK_FWFF_PKT_QUEUED_V1_8814B \
<< BIT_SHIFT_FWFF_PKT_QUEUED_V1_8814B)
#define BIT_CLEAR_FWFF_PKT_QUEUED_V1_8814B(x) \
((x) & (~BITS_FWFF_PKT_QUEUED_V1_8814B))
#define BIT_GET_FWFF_PKT_QUEUED_V1_8814B(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED_V1_8814B) & \
BIT_MASK_FWFF_PKT_QUEUED_V1_8814B)
#define BIT_SET_FWFF_PKT_QUEUED_V1_8814B(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED_V1_8814B(x) | \
BIT_FWFF_PKT_QUEUED_V1_8814B(v))
/* 2 REG_RXPKTNUM_8814B */
#define BIT_SHIFT_PKT_NUM_WOL_V1_8814B 16
#define BIT_MASK_PKT_NUM_WOL_V1_8814B 0xffff
#define BIT_PKT_NUM_WOL_V1_8814B(x) \
(((x) & BIT_MASK_PKT_NUM_WOL_V1_8814B) \
<< BIT_SHIFT_PKT_NUM_WOL_V1_8814B)
#define BITS_PKT_NUM_WOL_V1_8814B \
(BIT_MASK_PKT_NUM_WOL_V1_8814B << BIT_SHIFT_PKT_NUM_WOL_V1_8814B)
#define BIT_CLEAR_PKT_NUM_WOL_V1_8814B(x) ((x) & (~BITS_PKT_NUM_WOL_V1_8814B))
#define BIT_GET_PKT_NUM_WOL_V1_8814B(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL_V1_8814B) & \
BIT_MASK_PKT_NUM_WOL_V1_8814B)
#define BIT_SET_PKT_NUM_WOL_V1_8814B(x, v) \
(BIT_CLEAR_PKT_NUM_WOL_V1_8814B(x) | BIT_PKT_NUM_WOL_V1_8814B(v))
#define BIT_SHIFT_RXPKT_NUM_V1_8814B 0
#define BIT_MASK_RXPKT_NUM_V1_8814B 0xffff
#define BIT_RXPKT_NUM_V1_8814B(x) \
(((x) & BIT_MASK_RXPKT_NUM_V1_8814B) << BIT_SHIFT_RXPKT_NUM_V1_8814B)
#define BITS_RXPKT_NUM_V1_8814B \
(BIT_MASK_RXPKT_NUM_V1_8814B << BIT_SHIFT_RXPKT_NUM_V1_8814B)
#define BIT_CLEAR_RXPKT_NUM_V1_8814B(x) ((x) & (~BITS_RXPKT_NUM_V1_8814B))
#define BIT_GET_RXPKT_NUM_V1_8814B(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_V1_8814B) & BIT_MASK_RXPKT_NUM_V1_8814B)
#define BIT_SET_RXPKT_NUM_V1_8814B(x, v) \
(BIT_CLEAR_RXPKT_NUM_V1_8814B(x) | BIT_RXPKT_NUM_V1_8814B(v))
/* 2 REG_RXPKTNUM_TH_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_RXPKT_NUM_TH_8814B 0
#define BIT_MASK_RXPKT_NUM_TH_8814B 0xff
#define BIT_RXPKT_NUM_TH_8814B(x) \
(((x) & BIT_MASK_RXPKT_NUM_TH_8814B) << BIT_SHIFT_RXPKT_NUM_TH_8814B)
#define BITS_RXPKT_NUM_TH_8814B \
(BIT_MASK_RXPKT_NUM_TH_8814B << BIT_SHIFT_RXPKT_NUM_TH_8814B)
#define BIT_CLEAR_RXPKT_NUM_TH_8814B(x) ((x) & (~BITS_RXPKT_NUM_TH_8814B))
#define BIT_GET_RXPKT_NUM_TH_8814B(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_TH_8814B) & BIT_MASK_RXPKT_NUM_TH_8814B)
#define BIT_SET_RXPKT_NUM_TH_8814B(x, v) \
(BIT_CLEAR_RXPKT_NUM_TH_8814B(x) | BIT_RXPKT_NUM_TH_8814B(v))
/* 2 REG_FW_UPD_RXDES_RDPTR_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_FW_UPD_RXDES_RD_PTR_8814B 0
#define BIT_MASK_FW_UPD_RXDES_RD_PTR_8814B 0x3ffff
#define BIT_FW_UPD_RXDES_RD_PTR_8814B(x) \
(((x) & BIT_MASK_FW_UPD_RXDES_RD_PTR_8814B) \
<< BIT_SHIFT_FW_UPD_RXDES_RD_PTR_8814B)
#define BITS_FW_UPD_RXDES_RD_PTR_8814B \
(BIT_MASK_FW_UPD_RXDES_RD_PTR_8814B \
<< BIT_SHIFT_FW_UPD_RXDES_RD_PTR_8814B)
#define BIT_CLEAR_FW_UPD_RXDES_RD_PTR_8814B(x) \
((x) & (~BITS_FW_UPD_RXDES_RD_PTR_8814B))
#define BIT_GET_FW_UPD_RXDES_RD_PTR_8814B(x) \
(((x) >> BIT_SHIFT_FW_UPD_RXDES_RD_PTR_8814B) & \
BIT_MASK_FW_UPD_RXDES_RD_PTR_8814B)
#define BIT_SET_FW_UPD_RXDES_RD_PTR_8814B(x, v) \
(BIT_CLEAR_FW_UPD_RXDES_RD_PTR_8814B(x) | \
BIT_FW_UPD_RXDES_RD_PTR_8814B(v))
/* 2 REG_DDMA_CH0SA_8814B */
#define BIT_SHIFT_DDMACH0_SA_8814B 0
#define BIT_MASK_DDMACH0_SA_8814B 0xffffffffL
#define BIT_DDMACH0_SA_8814B(x) \
(((x) & BIT_MASK_DDMACH0_SA_8814B) << BIT_SHIFT_DDMACH0_SA_8814B)
#define BITS_DDMACH0_SA_8814B \
(BIT_MASK_DDMACH0_SA_8814B << BIT_SHIFT_DDMACH0_SA_8814B)
#define BIT_CLEAR_DDMACH0_SA_8814B(x) ((x) & (~BITS_DDMACH0_SA_8814B))
#define BIT_GET_DDMACH0_SA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH0_SA_8814B) & BIT_MASK_DDMACH0_SA_8814B)
#define BIT_SET_DDMACH0_SA_8814B(x, v) \
(BIT_CLEAR_DDMACH0_SA_8814B(x) | BIT_DDMACH0_SA_8814B(v))
/* 2 REG_DDMA_CH0DA_8814B */
#define BIT_SHIFT_DDMACH0_DA_8814B 0
#define BIT_MASK_DDMACH0_DA_8814B 0xffffffffL
#define BIT_DDMACH0_DA_8814B(x) \
(((x) & BIT_MASK_DDMACH0_DA_8814B) << BIT_SHIFT_DDMACH0_DA_8814B)
#define BITS_DDMACH0_DA_8814B \
(BIT_MASK_DDMACH0_DA_8814B << BIT_SHIFT_DDMACH0_DA_8814B)
#define BIT_CLEAR_DDMACH0_DA_8814B(x) ((x) & (~BITS_DDMACH0_DA_8814B))
#define BIT_GET_DDMACH0_DA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH0_DA_8814B) & BIT_MASK_DDMACH0_DA_8814B)
#define BIT_SET_DDMACH0_DA_8814B(x, v) \
(BIT_CLEAR_DDMACH0_DA_8814B(x) | BIT_DDMACH0_DA_8814B(v))
/* 2 REG_DDMA_CH0CTRL_8814B */
#define BIT_DDMACH0_OWN_8814B BIT(31)
#define BIT_DDMACH0_IDMEM_ERR_8814B BIT(30)
#define BIT_DDMACH0_CHKSUM_EN_8814B BIT(29)
#define BIT_DDMACH0_DA_W_DISABLE_8814B BIT(28)
#define BIT_DDMACH0_CHKSUM_STS_8814B BIT(27)
#define BIT_DDMACH0_DDMA_MODE_8814B BIT(26)
#define BIT_DDMACH0_RESET_CHKSUM_STS_8814B BIT(25)
#define BIT_DDMACH0_CHKSUM_CONT_8814B BIT(24)
#define BIT_SHIFT_DDMACH0_DLEN_8814B 0
#define BIT_MASK_DDMACH0_DLEN_8814B 0x3ffff
#define BIT_DDMACH0_DLEN_8814B(x) \
(((x) & BIT_MASK_DDMACH0_DLEN_8814B) << BIT_SHIFT_DDMACH0_DLEN_8814B)
#define BITS_DDMACH0_DLEN_8814B \
(BIT_MASK_DDMACH0_DLEN_8814B << BIT_SHIFT_DDMACH0_DLEN_8814B)
#define BIT_CLEAR_DDMACH0_DLEN_8814B(x) ((x) & (~BITS_DDMACH0_DLEN_8814B))
#define BIT_GET_DDMACH0_DLEN_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH0_DLEN_8814B) & BIT_MASK_DDMACH0_DLEN_8814B)
#define BIT_SET_DDMACH0_DLEN_8814B(x, v) \
(BIT_CLEAR_DDMACH0_DLEN_8814B(x) | BIT_DDMACH0_DLEN_8814B(v))
/* 2 REG_DDMA_CH1SA_8814B */
#define BIT_SHIFT_DDMACH1_SA_8814B 0
#define BIT_MASK_DDMACH1_SA_8814B 0xffffffffL
#define BIT_DDMACH1_SA_8814B(x) \
(((x) & BIT_MASK_DDMACH1_SA_8814B) << BIT_SHIFT_DDMACH1_SA_8814B)
#define BITS_DDMACH1_SA_8814B \
(BIT_MASK_DDMACH1_SA_8814B << BIT_SHIFT_DDMACH1_SA_8814B)
#define BIT_CLEAR_DDMACH1_SA_8814B(x) ((x) & (~BITS_DDMACH1_SA_8814B))
#define BIT_GET_DDMACH1_SA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH1_SA_8814B) & BIT_MASK_DDMACH1_SA_8814B)
#define BIT_SET_DDMACH1_SA_8814B(x, v) \
(BIT_CLEAR_DDMACH1_SA_8814B(x) | BIT_DDMACH1_SA_8814B(v))
/* 2 REG_DDMA_CH1DA_8814B */
#define BIT_SHIFT_DDMACH1_DA_8814B 0
#define BIT_MASK_DDMACH1_DA_8814B 0xffffffffL
#define BIT_DDMACH1_DA_8814B(x) \
(((x) & BIT_MASK_DDMACH1_DA_8814B) << BIT_SHIFT_DDMACH1_DA_8814B)
#define BITS_DDMACH1_DA_8814B \
(BIT_MASK_DDMACH1_DA_8814B << BIT_SHIFT_DDMACH1_DA_8814B)
#define BIT_CLEAR_DDMACH1_DA_8814B(x) ((x) & (~BITS_DDMACH1_DA_8814B))
#define BIT_GET_DDMACH1_DA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH1_DA_8814B) & BIT_MASK_DDMACH1_DA_8814B)
#define BIT_SET_DDMACH1_DA_8814B(x, v) \
(BIT_CLEAR_DDMACH1_DA_8814B(x) | BIT_DDMACH1_DA_8814B(v))
/* 2 REG_DDMA_CH1CTRL_8814B */
#define BIT_DDMACH1_OWN_8814B BIT(31)
#define BIT_DDMACH1_IDMEM_ERR_8814B BIT(30)
#define BIT_DDMACH1_CHKSUM_EN_8814B BIT(29)
#define BIT_DDMACH1_DA_W_DISABLE_8814B BIT(28)
#define BIT_DDMACH1_CHKSUM_STS_8814B BIT(27)
#define BIT_DDMACH1_DDMA_MODE_8814B BIT(26)
#define BIT_DDMACH1_RESET_CHKSUM_STS_8814B BIT(25)
#define BIT_DDMACH1_CHKSUM_CONT_8814B BIT(24)
#define BIT_SHIFT_DDMACH1_DLEN_8814B 0
#define BIT_MASK_DDMACH1_DLEN_8814B 0x3ffff
#define BIT_DDMACH1_DLEN_8814B(x) \
(((x) & BIT_MASK_DDMACH1_DLEN_8814B) << BIT_SHIFT_DDMACH1_DLEN_8814B)
#define BITS_DDMACH1_DLEN_8814B \
(BIT_MASK_DDMACH1_DLEN_8814B << BIT_SHIFT_DDMACH1_DLEN_8814B)
#define BIT_CLEAR_DDMACH1_DLEN_8814B(x) ((x) & (~BITS_DDMACH1_DLEN_8814B))
#define BIT_GET_DDMACH1_DLEN_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH1_DLEN_8814B) & BIT_MASK_DDMACH1_DLEN_8814B)
#define BIT_SET_DDMACH1_DLEN_8814B(x, v) \
(BIT_CLEAR_DDMACH1_DLEN_8814B(x) | BIT_DDMACH1_DLEN_8814B(v))
/* 2 REG_DDMA_CH2SA_8814B */
#define BIT_SHIFT_DDMACH2_SA_8814B 0
#define BIT_MASK_DDMACH2_SA_8814B 0xffffffffL
#define BIT_DDMACH2_SA_8814B(x) \
(((x) & BIT_MASK_DDMACH2_SA_8814B) << BIT_SHIFT_DDMACH2_SA_8814B)
#define BITS_DDMACH2_SA_8814B \
(BIT_MASK_DDMACH2_SA_8814B << BIT_SHIFT_DDMACH2_SA_8814B)
#define BIT_CLEAR_DDMACH2_SA_8814B(x) ((x) & (~BITS_DDMACH2_SA_8814B))
#define BIT_GET_DDMACH2_SA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH2_SA_8814B) & BIT_MASK_DDMACH2_SA_8814B)
#define BIT_SET_DDMACH2_SA_8814B(x, v) \
(BIT_CLEAR_DDMACH2_SA_8814B(x) | BIT_DDMACH2_SA_8814B(v))
/* 2 REG_DDMA_CH2DA_8814B */
#define BIT_SHIFT_DDMACH2_DA_8814B 0
#define BIT_MASK_DDMACH2_DA_8814B 0xffffffffL
#define BIT_DDMACH2_DA_8814B(x) \
(((x) & BIT_MASK_DDMACH2_DA_8814B) << BIT_SHIFT_DDMACH2_DA_8814B)
#define BITS_DDMACH2_DA_8814B \
(BIT_MASK_DDMACH2_DA_8814B << BIT_SHIFT_DDMACH2_DA_8814B)
#define BIT_CLEAR_DDMACH2_DA_8814B(x) ((x) & (~BITS_DDMACH2_DA_8814B))
#define BIT_GET_DDMACH2_DA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH2_DA_8814B) & BIT_MASK_DDMACH2_DA_8814B)
#define BIT_SET_DDMACH2_DA_8814B(x, v) \
(BIT_CLEAR_DDMACH2_DA_8814B(x) | BIT_DDMACH2_DA_8814B(v))
/* 2 REG_DDMA_CH2CTRL_8814B */
#define BIT_DDMACH2_OWN_8814B BIT(31)
#define BIT_DDMACH2_IDMEM_ERR_8814B BIT(30)
#define BIT_DDMACH2_CHKSUM_EN_8814B BIT(29)
#define BIT_DDMACH2_DA_W_DISABLE_8814B BIT(28)
#define BIT_DDMACH2_CHKSUM_STS_8814B BIT(27)
#define BIT_DDMACH2_DDMA_MODE_8814B BIT(26)
#define BIT_DDMACH2_RESET_CHKSUM_STS_8814B BIT(25)
#define BIT_DDMACH2_CHKSUM_CONT_8814B BIT(24)
#define BIT_SHIFT_DDMACH2_DLEN_8814B 0
#define BIT_MASK_DDMACH2_DLEN_8814B 0x3ffff
#define BIT_DDMACH2_DLEN_8814B(x) \
(((x) & BIT_MASK_DDMACH2_DLEN_8814B) << BIT_SHIFT_DDMACH2_DLEN_8814B)
#define BITS_DDMACH2_DLEN_8814B \
(BIT_MASK_DDMACH2_DLEN_8814B << BIT_SHIFT_DDMACH2_DLEN_8814B)
#define BIT_CLEAR_DDMACH2_DLEN_8814B(x) ((x) & (~BITS_DDMACH2_DLEN_8814B))
#define BIT_GET_DDMACH2_DLEN_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH2_DLEN_8814B) & BIT_MASK_DDMACH2_DLEN_8814B)
#define BIT_SET_DDMACH2_DLEN_8814B(x, v) \
(BIT_CLEAR_DDMACH2_DLEN_8814B(x) | BIT_DDMACH2_DLEN_8814B(v))
/* 2 REG_DDMA_CH3SA_8814B */
#define BIT_SHIFT_DDMACH3_SA_8814B 0
#define BIT_MASK_DDMACH3_SA_8814B 0xffffffffL
#define BIT_DDMACH3_SA_8814B(x) \
(((x) & BIT_MASK_DDMACH3_SA_8814B) << BIT_SHIFT_DDMACH3_SA_8814B)
#define BITS_DDMACH3_SA_8814B \
(BIT_MASK_DDMACH3_SA_8814B << BIT_SHIFT_DDMACH3_SA_8814B)
#define BIT_CLEAR_DDMACH3_SA_8814B(x) ((x) & (~BITS_DDMACH3_SA_8814B))
#define BIT_GET_DDMACH3_SA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH3_SA_8814B) & BIT_MASK_DDMACH3_SA_8814B)
#define BIT_SET_DDMACH3_SA_8814B(x, v) \
(BIT_CLEAR_DDMACH3_SA_8814B(x) | BIT_DDMACH3_SA_8814B(v))
/* 2 REG_DDMA_CH3DA_8814B */
#define BIT_SHIFT_DDMACH3_DA_8814B 0
#define BIT_MASK_DDMACH3_DA_8814B 0xffffffffL
#define BIT_DDMACH3_DA_8814B(x) \
(((x) & BIT_MASK_DDMACH3_DA_8814B) << BIT_SHIFT_DDMACH3_DA_8814B)
#define BITS_DDMACH3_DA_8814B \
(BIT_MASK_DDMACH3_DA_8814B << BIT_SHIFT_DDMACH3_DA_8814B)
#define BIT_CLEAR_DDMACH3_DA_8814B(x) ((x) & (~BITS_DDMACH3_DA_8814B))
#define BIT_GET_DDMACH3_DA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH3_DA_8814B) & BIT_MASK_DDMACH3_DA_8814B)
#define BIT_SET_DDMACH3_DA_8814B(x, v) \
(BIT_CLEAR_DDMACH3_DA_8814B(x) | BIT_DDMACH3_DA_8814B(v))
/* 2 REG_DDMA_CH3CTRL_8814B */
#define BIT_DDMACH3_OWN_8814B BIT(31)
#define BIT_DDMACH3_IDMEM_ERR_8814B BIT(30)
#define BIT_DDMACH3_CHKSUM_EN_8814B BIT(29)
#define BIT_DDMACH3_DA_W_DISABLE_8814B BIT(28)
#define BIT_DDMACH3_CHKSUM_STS_8814B BIT(27)
#define BIT_DDMACH3_DDMA_MODE_8814B BIT(26)
#define BIT_DDMACH3_RESET_CHKSUM_STS_8814B BIT(25)
#define BIT_DDMACH3_CHKSUM_CONT_8814B BIT(24)
#define BIT_SHIFT_DDMACH3_DLEN_8814B 0
#define BIT_MASK_DDMACH3_DLEN_8814B 0x3ffff
#define BIT_DDMACH3_DLEN_8814B(x) \
(((x) & BIT_MASK_DDMACH3_DLEN_8814B) << BIT_SHIFT_DDMACH3_DLEN_8814B)
#define BITS_DDMACH3_DLEN_8814B \
(BIT_MASK_DDMACH3_DLEN_8814B << BIT_SHIFT_DDMACH3_DLEN_8814B)
#define BIT_CLEAR_DDMACH3_DLEN_8814B(x) ((x) & (~BITS_DDMACH3_DLEN_8814B))
#define BIT_GET_DDMACH3_DLEN_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH3_DLEN_8814B) & BIT_MASK_DDMACH3_DLEN_8814B)
#define BIT_SET_DDMACH3_DLEN_8814B(x, v) \
(BIT_CLEAR_DDMACH3_DLEN_8814B(x) | BIT_DDMACH3_DLEN_8814B(v))
/* 2 REG_DDMA_CH4SA_8814B */
#define BIT_SHIFT_DDMACH4_SA_8814B 0
#define BIT_MASK_DDMACH4_SA_8814B 0xffffffffL
#define BIT_DDMACH4_SA_8814B(x) \
(((x) & BIT_MASK_DDMACH4_SA_8814B) << BIT_SHIFT_DDMACH4_SA_8814B)
#define BITS_DDMACH4_SA_8814B \
(BIT_MASK_DDMACH4_SA_8814B << BIT_SHIFT_DDMACH4_SA_8814B)
#define BIT_CLEAR_DDMACH4_SA_8814B(x) ((x) & (~BITS_DDMACH4_SA_8814B))
#define BIT_GET_DDMACH4_SA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH4_SA_8814B) & BIT_MASK_DDMACH4_SA_8814B)
#define BIT_SET_DDMACH4_SA_8814B(x, v) \
(BIT_CLEAR_DDMACH4_SA_8814B(x) | BIT_DDMACH4_SA_8814B(v))
/* 2 REG_DDMA_CH4DA_8814B */
#define BIT_SHIFT_DDMACH4_DA_8814B 0
#define BIT_MASK_DDMACH4_DA_8814B 0xffffffffL
#define BIT_DDMACH4_DA_8814B(x) \
(((x) & BIT_MASK_DDMACH4_DA_8814B) << BIT_SHIFT_DDMACH4_DA_8814B)
#define BITS_DDMACH4_DA_8814B \
(BIT_MASK_DDMACH4_DA_8814B << BIT_SHIFT_DDMACH4_DA_8814B)
#define BIT_CLEAR_DDMACH4_DA_8814B(x) ((x) & (~BITS_DDMACH4_DA_8814B))
#define BIT_GET_DDMACH4_DA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH4_DA_8814B) & BIT_MASK_DDMACH4_DA_8814B)
#define BIT_SET_DDMACH4_DA_8814B(x, v) \
(BIT_CLEAR_DDMACH4_DA_8814B(x) | BIT_DDMACH4_DA_8814B(v))
/* 2 REG_DDMA_CH4CTRL_8814B */
#define BIT_DDMACH4_OWN_8814B BIT(31)
#define BIT_DDMACH4_IDMEM_ERR_8814B BIT(30)
#define BIT_DDMACH4_CHKSUM_EN_8814B BIT(29)
#define BIT_DDMACH4_DA_W_DISABLE_8814B BIT(28)
#define BIT_DDMACH4_CHKSUM_STS_8814B BIT(27)
#define BIT_DDMACH4_DDMA_MODE_8814B BIT(26)
#define BIT_DDMACH4_RESET_CHKSUM_STS_8814B BIT(25)
#define BIT_DDMACH4_CHKSUM_CONT_8814B BIT(24)
#define BIT_SHIFT_DDMACH4_DLEN_8814B 0
#define BIT_MASK_DDMACH4_DLEN_8814B 0x3ffff
#define BIT_DDMACH4_DLEN_8814B(x) \
(((x) & BIT_MASK_DDMACH4_DLEN_8814B) << BIT_SHIFT_DDMACH4_DLEN_8814B)
#define BITS_DDMACH4_DLEN_8814B \
(BIT_MASK_DDMACH4_DLEN_8814B << BIT_SHIFT_DDMACH4_DLEN_8814B)
#define BIT_CLEAR_DDMACH4_DLEN_8814B(x) ((x) & (~BITS_DDMACH4_DLEN_8814B))
#define BIT_GET_DDMACH4_DLEN_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH4_DLEN_8814B) & BIT_MASK_DDMACH4_DLEN_8814B)
#define BIT_SET_DDMACH4_DLEN_8814B(x, v) \
(BIT_CLEAR_DDMACH4_DLEN_8814B(x) | BIT_DDMACH4_DLEN_8814B(v))
/* 2 REG_DDMA_CH5SA_8814B */
#define BIT_SHIFT_DDMACH5_SA_8814B 0
#define BIT_MASK_DDMACH5_SA_8814B 0xffffffffL
#define BIT_DDMACH5_SA_8814B(x) \
(((x) & BIT_MASK_DDMACH5_SA_8814B) << BIT_SHIFT_DDMACH5_SA_8814B)
#define BITS_DDMACH5_SA_8814B \
(BIT_MASK_DDMACH5_SA_8814B << BIT_SHIFT_DDMACH5_SA_8814B)
#define BIT_CLEAR_DDMACH5_SA_8814B(x) ((x) & (~BITS_DDMACH5_SA_8814B))
#define BIT_GET_DDMACH5_SA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH5_SA_8814B) & BIT_MASK_DDMACH5_SA_8814B)
#define BIT_SET_DDMACH5_SA_8814B(x, v) \
(BIT_CLEAR_DDMACH5_SA_8814B(x) | BIT_DDMACH5_SA_8814B(v))
/* 2 REG_DDMA_CH5DA_8814B */
#define BIT_SHIFT_DDMACH5_DA_8814B 0
#define BIT_MASK_DDMACH5_DA_8814B 0xffffffffL
#define BIT_DDMACH5_DA_8814B(x) \
(((x) & BIT_MASK_DDMACH5_DA_8814B) << BIT_SHIFT_DDMACH5_DA_8814B)
#define BITS_DDMACH5_DA_8814B \
(BIT_MASK_DDMACH5_DA_8814B << BIT_SHIFT_DDMACH5_DA_8814B)
#define BIT_CLEAR_DDMACH5_DA_8814B(x) ((x) & (~BITS_DDMACH5_DA_8814B))
#define BIT_GET_DDMACH5_DA_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH5_DA_8814B) & BIT_MASK_DDMACH5_DA_8814B)
#define BIT_SET_DDMACH5_DA_8814B(x, v) \
(BIT_CLEAR_DDMACH5_DA_8814B(x) | BIT_DDMACH5_DA_8814B(v))
/* 2 REG_DDMA_CH5CTRL_8814B */
#define BIT_DDMACH5_OWN_8814B BIT(31)
#define BIT_DDMACH5_IDMEM_ERR_8814B BIT(30)
#define BIT_DDMACH5_CHKSUM_EN_8814B BIT(29)
#define BIT_DDMACH5_DA_W_DISABLE_8814B BIT(28)
#define BIT_DDMACH5_CHKSUM_STS_8814B BIT(27)
#define BIT_DDMACH5_DDMA_MODE_8814B BIT(26)
#define BIT_DDMACH5_RESET_CHKSUM_STS_8814B BIT(25)
#define BIT_DDMACH5_CHKSUM_CONT_8814B BIT(24)
#define BIT_SHIFT_DDMACH5_DLEN_8814B 0
#define BIT_MASK_DDMACH5_DLEN_8814B 0x3ffff
#define BIT_DDMACH5_DLEN_8814B(x) \
(((x) & BIT_MASK_DDMACH5_DLEN_8814B) << BIT_SHIFT_DDMACH5_DLEN_8814B)
#define BITS_DDMACH5_DLEN_8814B \
(BIT_MASK_DDMACH5_DLEN_8814B << BIT_SHIFT_DDMACH5_DLEN_8814B)
#define BIT_CLEAR_DDMACH5_DLEN_8814B(x) ((x) & (~BITS_DDMACH5_DLEN_8814B))
#define BIT_GET_DDMACH5_DLEN_8814B(x) \
(((x) >> BIT_SHIFT_DDMACH5_DLEN_8814B) & BIT_MASK_DDMACH5_DLEN_8814B)
#define BIT_SET_DDMACH5_DLEN_8814B(x, v) \
(BIT_CLEAR_DDMACH5_DLEN_8814B(x) | BIT_DDMACH5_DLEN_8814B(v))
/* 2 REG_DDMA_INT_MSK_8814B */
#define BIT_DDMACH5_MSK_8814B BIT(5)
#define BIT_DDMACH4_MSK_8814B BIT(4)
#define BIT_DDMACH3_MSK_8814B BIT(3)
#define BIT_DDMACH2_MSK_8814B BIT(2)
#define BIT_DDMACH1_MSK_8814B BIT(1)
#define BIT_DDMACH0_MSK_8814B BIT(0)
/* 2 REG_DDMA_CHSTATUS_8814B */
#define BIT_DDMACH5_BUSY_8814B BIT(5)
#define BIT_DDMACH4_BUSY_8814B BIT(4)
#define BIT_DDMACH3_BUSY_8814B BIT(3)
#define BIT_DDMACH2_BUSY_8814B BIT(2)
#define BIT_DDMACH1_BUSY_8814B BIT(1)
#define BIT_DDMACH0_BUSY_8814B BIT(0)
/* 2 REG_DDMA_CHKSUM_8814B */
#define BIT_SHIFT_IDDMA0_CHKSUM_8814B 0
#define BIT_MASK_IDDMA0_CHKSUM_8814B 0xffff
#define BIT_IDDMA0_CHKSUM_8814B(x) \
(((x) & BIT_MASK_IDDMA0_CHKSUM_8814B) << BIT_SHIFT_IDDMA0_CHKSUM_8814B)
#define BITS_IDDMA0_CHKSUM_8814B \
(BIT_MASK_IDDMA0_CHKSUM_8814B << BIT_SHIFT_IDDMA0_CHKSUM_8814B)
#define BIT_CLEAR_IDDMA0_CHKSUM_8814B(x) ((x) & (~BITS_IDDMA0_CHKSUM_8814B))
#define BIT_GET_IDDMA0_CHKSUM_8814B(x) \
(((x) >> BIT_SHIFT_IDDMA0_CHKSUM_8814B) & BIT_MASK_IDDMA0_CHKSUM_8814B)
#define BIT_SET_IDDMA0_CHKSUM_8814B(x, v) \
(BIT_CLEAR_IDDMA0_CHKSUM_8814B(x) | BIT_IDDMA0_CHKSUM_8814B(v))
/* 2 REG_DDMA_MONITOR_8814B */
#define BIT_IDDMA0_PERMU_UNDERFLOW_8814B BIT(14)
#define BIT_IDDMA0_FIFO_UNDERFLOW_8814B BIT(13)
#define BIT_IDDMA0_FIFO_OVERFLOW_8814B BIT(12)
#define BIT_CH5_ERR_8814B BIT(5)
#define BIT_CH4_ERR_8814B BIT(4)
#define BIT_CH3_ERR_8814B BIT(3)
#define BIT_CH2_ERR_8814B BIT(2)
#define BIT_CH1_ERR_8814B BIT(1)
#define BIT_CH0_ERR_8814B BIT(0)
/* 2 REG_DMA_RQPN_INFO_0_8814B */
#define BIT_SHIFT_CH0_AVAL_PG_8814B 16
#define BIT_MASK_CH0_AVAL_PG_8814B 0xfff
#define BIT_CH0_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH0_AVAL_PG_8814B) << BIT_SHIFT_CH0_AVAL_PG_8814B)
#define BITS_CH0_AVAL_PG_8814B \
(BIT_MASK_CH0_AVAL_PG_8814B << BIT_SHIFT_CH0_AVAL_PG_8814B)
#define BIT_CLEAR_CH0_AVAL_PG_8814B(x) ((x) & (~BITS_CH0_AVAL_PG_8814B))
#define BIT_GET_CH0_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH0_AVAL_PG_8814B) & BIT_MASK_CH0_AVAL_PG_8814B)
#define BIT_SET_CH0_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH0_AVAL_PG_8814B(x) | BIT_CH0_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH0_RSVD_PG_8814B 0
#define BIT_MASK_CH0_RSVD_PG_8814B 0xfff
#define BIT_CH0_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH0_RSVD_PG_8814B) << BIT_SHIFT_CH0_RSVD_PG_8814B)
#define BITS_CH0_RSVD_PG_8814B \
(BIT_MASK_CH0_RSVD_PG_8814B << BIT_SHIFT_CH0_RSVD_PG_8814B)
#define BIT_CLEAR_CH0_RSVD_PG_8814B(x) ((x) & (~BITS_CH0_RSVD_PG_8814B))
#define BIT_GET_CH0_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH0_RSVD_PG_8814B) & BIT_MASK_CH0_RSVD_PG_8814B)
#define BIT_SET_CH0_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH0_RSVD_PG_8814B(x) | BIT_CH0_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_1_8814B */
#define BIT_SHIFT_CH1_AVAL_PG_8814B 16
#define BIT_MASK_CH1_AVAL_PG_8814B 0xfff
#define BIT_CH1_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH1_AVAL_PG_8814B) << BIT_SHIFT_CH1_AVAL_PG_8814B)
#define BITS_CH1_AVAL_PG_8814B \
(BIT_MASK_CH1_AVAL_PG_8814B << BIT_SHIFT_CH1_AVAL_PG_8814B)
#define BIT_CLEAR_CH1_AVAL_PG_8814B(x) ((x) & (~BITS_CH1_AVAL_PG_8814B))
#define BIT_GET_CH1_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH1_AVAL_PG_8814B) & BIT_MASK_CH1_AVAL_PG_8814B)
#define BIT_SET_CH1_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH1_AVAL_PG_8814B(x) | BIT_CH1_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH1_RSVD_PG_8814B 0
#define BIT_MASK_CH1_RSVD_PG_8814B 0xfff
#define BIT_CH1_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH1_RSVD_PG_8814B) << BIT_SHIFT_CH1_RSVD_PG_8814B)
#define BITS_CH1_RSVD_PG_8814B \
(BIT_MASK_CH1_RSVD_PG_8814B << BIT_SHIFT_CH1_RSVD_PG_8814B)
#define BIT_CLEAR_CH1_RSVD_PG_8814B(x) ((x) & (~BITS_CH1_RSVD_PG_8814B))
#define BIT_GET_CH1_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH1_RSVD_PG_8814B) & BIT_MASK_CH1_RSVD_PG_8814B)
#define BIT_SET_CH1_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH1_RSVD_PG_8814B(x) | BIT_CH1_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_2_8814B */
#define BIT_SHIFT_CH2_AVAL_PG_8814B 16
#define BIT_MASK_CH2_AVAL_PG_8814B 0xfff
#define BIT_CH2_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH2_AVAL_PG_8814B) << BIT_SHIFT_CH2_AVAL_PG_8814B)
#define BITS_CH2_AVAL_PG_8814B \
(BIT_MASK_CH2_AVAL_PG_8814B << BIT_SHIFT_CH2_AVAL_PG_8814B)
#define BIT_CLEAR_CH2_AVAL_PG_8814B(x) ((x) & (~BITS_CH2_AVAL_PG_8814B))
#define BIT_GET_CH2_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH2_AVAL_PG_8814B) & BIT_MASK_CH2_AVAL_PG_8814B)
#define BIT_SET_CH2_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH2_AVAL_PG_8814B(x) | BIT_CH2_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH2_RSVD_PG_8814B 0
#define BIT_MASK_CH2_RSVD_PG_8814B 0xfff
#define BIT_CH2_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH2_RSVD_PG_8814B) << BIT_SHIFT_CH2_RSVD_PG_8814B)
#define BITS_CH2_RSVD_PG_8814B \
(BIT_MASK_CH2_RSVD_PG_8814B << BIT_SHIFT_CH2_RSVD_PG_8814B)
#define BIT_CLEAR_CH2_RSVD_PG_8814B(x) ((x) & (~BITS_CH2_RSVD_PG_8814B))
#define BIT_GET_CH2_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH2_RSVD_PG_8814B) & BIT_MASK_CH2_RSVD_PG_8814B)
#define BIT_SET_CH2_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH2_RSVD_PG_8814B(x) | BIT_CH2_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_3_8814B */
#define BIT_SHIFT_CH3_AVAL_PG_8814B 16
#define BIT_MASK_CH3_AVAL_PG_8814B 0xfff
#define BIT_CH3_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH3_AVAL_PG_8814B) << BIT_SHIFT_CH3_AVAL_PG_8814B)
#define BITS_CH3_AVAL_PG_8814B \
(BIT_MASK_CH3_AVAL_PG_8814B << BIT_SHIFT_CH3_AVAL_PG_8814B)
#define BIT_CLEAR_CH3_AVAL_PG_8814B(x) ((x) & (~BITS_CH3_AVAL_PG_8814B))
#define BIT_GET_CH3_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH3_AVAL_PG_8814B) & BIT_MASK_CH3_AVAL_PG_8814B)
#define BIT_SET_CH3_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH3_AVAL_PG_8814B(x) | BIT_CH3_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH3_RSVD_PG_8814B 0
#define BIT_MASK_CH3_RSVD_PG_8814B 0xfff
#define BIT_CH3_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH3_RSVD_PG_8814B) << BIT_SHIFT_CH3_RSVD_PG_8814B)
#define BITS_CH3_RSVD_PG_8814B \
(BIT_MASK_CH3_RSVD_PG_8814B << BIT_SHIFT_CH3_RSVD_PG_8814B)
#define BIT_CLEAR_CH3_RSVD_PG_8814B(x) ((x) & (~BITS_CH3_RSVD_PG_8814B))
#define BIT_GET_CH3_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH3_RSVD_PG_8814B) & BIT_MASK_CH3_RSVD_PG_8814B)
#define BIT_SET_CH3_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH3_RSVD_PG_8814B(x) | BIT_CH3_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_4_8814B */
#define BIT_SHIFT_CH4_AVAL_PG_8814B 16
#define BIT_MASK_CH4_AVAL_PG_8814B 0xfff
#define BIT_CH4_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH4_AVAL_PG_8814B) << BIT_SHIFT_CH4_AVAL_PG_8814B)
#define BITS_CH4_AVAL_PG_8814B \
(BIT_MASK_CH4_AVAL_PG_8814B << BIT_SHIFT_CH4_AVAL_PG_8814B)
#define BIT_CLEAR_CH4_AVAL_PG_8814B(x) ((x) & (~BITS_CH4_AVAL_PG_8814B))
#define BIT_GET_CH4_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH4_AVAL_PG_8814B) & BIT_MASK_CH4_AVAL_PG_8814B)
#define BIT_SET_CH4_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH4_AVAL_PG_8814B(x) | BIT_CH4_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH4_RSVD_PG_8814B 0
#define BIT_MASK_CH4_RSVD_PG_8814B 0xfff
#define BIT_CH4_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH4_RSVD_PG_8814B) << BIT_SHIFT_CH4_RSVD_PG_8814B)
#define BITS_CH4_RSVD_PG_8814B \
(BIT_MASK_CH4_RSVD_PG_8814B << BIT_SHIFT_CH4_RSVD_PG_8814B)
#define BIT_CLEAR_CH4_RSVD_PG_8814B(x) ((x) & (~BITS_CH4_RSVD_PG_8814B))
#define BIT_GET_CH4_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH4_RSVD_PG_8814B) & BIT_MASK_CH4_RSVD_PG_8814B)
#define BIT_SET_CH4_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH4_RSVD_PG_8814B(x) | BIT_CH4_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_5_8814B */
#define BIT_SHIFT_CH5_AVAL_PG_8814B 16
#define BIT_MASK_CH5_AVAL_PG_8814B 0xfff
#define BIT_CH5_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH5_AVAL_PG_8814B) << BIT_SHIFT_CH5_AVAL_PG_8814B)
#define BITS_CH5_AVAL_PG_8814B \
(BIT_MASK_CH5_AVAL_PG_8814B << BIT_SHIFT_CH5_AVAL_PG_8814B)
#define BIT_CLEAR_CH5_AVAL_PG_8814B(x) ((x) & (~BITS_CH5_AVAL_PG_8814B))
#define BIT_GET_CH5_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH5_AVAL_PG_8814B) & BIT_MASK_CH5_AVAL_PG_8814B)
#define BIT_SET_CH5_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH5_AVAL_PG_8814B(x) | BIT_CH5_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH5_RSVD_PG_8814B 0
#define BIT_MASK_CH5_RSVD_PG_8814B 0xfff
#define BIT_CH5_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH5_RSVD_PG_8814B) << BIT_SHIFT_CH5_RSVD_PG_8814B)
#define BITS_CH5_RSVD_PG_8814B \
(BIT_MASK_CH5_RSVD_PG_8814B << BIT_SHIFT_CH5_RSVD_PG_8814B)
#define BIT_CLEAR_CH5_RSVD_PG_8814B(x) ((x) & (~BITS_CH5_RSVD_PG_8814B))
#define BIT_GET_CH5_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH5_RSVD_PG_8814B) & BIT_MASK_CH5_RSVD_PG_8814B)
#define BIT_SET_CH5_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH5_RSVD_PG_8814B(x) | BIT_CH5_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_6_8814B */
#define BIT_SHIFT_CH6_AVAL_PG_8814B 16
#define BIT_MASK_CH6_AVAL_PG_8814B 0xfff
#define BIT_CH6_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH6_AVAL_PG_8814B) << BIT_SHIFT_CH6_AVAL_PG_8814B)
#define BITS_CH6_AVAL_PG_8814B \
(BIT_MASK_CH6_AVAL_PG_8814B << BIT_SHIFT_CH6_AVAL_PG_8814B)
#define BIT_CLEAR_CH6_AVAL_PG_8814B(x) ((x) & (~BITS_CH6_AVAL_PG_8814B))
#define BIT_GET_CH6_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH6_AVAL_PG_8814B) & BIT_MASK_CH6_AVAL_PG_8814B)
#define BIT_SET_CH6_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH6_AVAL_PG_8814B(x) | BIT_CH6_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH6_RSVD_PG_8814B 0
#define BIT_MASK_CH6_RSVD_PG_8814B 0xfff
#define BIT_CH6_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH6_RSVD_PG_8814B) << BIT_SHIFT_CH6_RSVD_PG_8814B)
#define BITS_CH6_RSVD_PG_8814B \
(BIT_MASK_CH6_RSVD_PG_8814B << BIT_SHIFT_CH6_RSVD_PG_8814B)
#define BIT_CLEAR_CH6_RSVD_PG_8814B(x) ((x) & (~BITS_CH6_RSVD_PG_8814B))
#define BIT_GET_CH6_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH6_RSVD_PG_8814B) & BIT_MASK_CH6_RSVD_PG_8814B)
#define BIT_SET_CH6_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH6_RSVD_PG_8814B(x) | BIT_CH6_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_7_8814B */
#define BIT_SHIFT_CH7_AVAL_PG_8814B 16
#define BIT_MASK_CH7_AVAL_PG_8814B 0xfff
#define BIT_CH7_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH7_AVAL_PG_8814B) << BIT_SHIFT_CH7_AVAL_PG_8814B)
#define BITS_CH7_AVAL_PG_8814B \
(BIT_MASK_CH7_AVAL_PG_8814B << BIT_SHIFT_CH7_AVAL_PG_8814B)
#define BIT_CLEAR_CH7_AVAL_PG_8814B(x) ((x) & (~BITS_CH7_AVAL_PG_8814B))
#define BIT_GET_CH7_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH7_AVAL_PG_8814B) & BIT_MASK_CH7_AVAL_PG_8814B)
#define BIT_SET_CH7_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH7_AVAL_PG_8814B(x) | BIT_CH7_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH7_RSVD_PG_8814B 0
#define BIT_MASK_CH7_RSVD_PG_8814B 0xfff
#define BIT_CH7_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH7_RSVD_PG_8814B) << BIT_SHIFT_CH7_RSVD_PG_8814B)
#define BITS_CH7_RSVD_PG_8814B \
(BIT_MASK_CH7_RSVD_PG_8814B << BIT_SHIFT_CH7_RSVD_PG_8814B)
#define BIT_CLEAR_CH7_RSVD_PG_8814B(x) ((x) & (~BITS_CH7_RSVD_PG_8814B))
#define BIT_GET_CH7_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH7_RSVD_PG_8814B) & BIT_MASK_CH7_RSVD_PG_8814B)
#define BIT_SET_CH7_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH7_RSVD_PG_8814B(x) | BIT_CH7_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_8_8814B */
#define BIT_SHIFT_CH8_AVAL_PG_8814B 16
#define BIT_MASK_CH8_AVAL_PG_8814B 0xfff
#define BIT_CH8_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH8_AVAL_PG_8814B) << BIT_SHIFT_CH8_AVAL_PG_8814B)
#define BITS_CH8_AVAL_PG_8814B \
(BIT_MASK_CH8_AVAL_PG_8814B << BIT_SHIFT_CH8_AVAL_PG_8814B)
#define BIT_CLEAR_CH8_AVAL_PG_8814B(x) ((x) & (~BITS_CH8_AVAL_PG_8814B))
#define BIT_GET_CH8_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH8_AVAL_PG_8814B) & BIT_MASK_CH8_AVAL_PG_8814B)
#define BIT_SET_CH8_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH8_AVAL_PG_8814B(x) | BIT_CH8_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH8_RSVD_PG_8814B 0
#define BIT_MASK_CH8_RSVD_PG_8814B 0xfff
#define BIT_CH8_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH8_RSVD_PG_8814B) << BIT_SHIFT_CH8_RSVD_PG_8814B)
#define BITS_CH8_RSVD_PG_8814B \
(BIT_MASK_CH8_RSVD_PG_8814B << BIT_SHIFT_CH8_RSVD_PG_8814B)
#define BIT_CLEAR_CH8_RSVD_PG_8814B(x) ((x) & (~BITS_CH8_RSVD_PG_8814B))
#define BIT_GET_CH8_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH8_RSVD_PG_8814B) & BIT_MASK_CH8_RSVD_PG_8814B)
#define BIT_SET_CH8_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH8_RSVD_PG_8814B(x) | BIT_CH8_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_9_8814B */
#define BIT_SHIFT_CH9_AVAL_PG_8814B 16
#define BIT_MASK_CH9_AVAL_PG_8814B 0xfff
#define BIT_CH9_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH9_AVAL_PG_8814B) << BIT_SHIFT_CH9_AVAL_PG_8814B)
#define BITS_CH9_AVAL_PG_8814B \
(BIT_MASK_CH9_AVAL_PG_8814B << BIT_SHIFT_CH9_AVAL_PG_8814B)
#define BIT_CLEAR_CH9_AVAL_PG_8814B(x) ((x) & (~BITS_CH9_AVAL_PG_8814B))
#define BIT_GET_CH9_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH9_AVAL_PG_8814B) & BIT_MASK_CH9_AVAL_PG_8814B)
#define BIT_SET_CH9_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH9_AVAL_PG_8814B(x) | BIT_CH9_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH9_RSVD_PG_8814B 0
#define BIT_MASK_CH9_RSVD_PG_8814B 0xfff
#define BIT_CH9_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH9_RSVD_PG_8814B) << BIT_SHIFT_CH9_RSVD_PG_8814B)
#define BITS_CH9_RSVD_PG_8814B \
(BIT_MASK_CH9_RSVD_PG_8814B << BIT_SHIFT_CH9_RSVD_PG_8814B)
#define BIT_CLEAR_CH9_RSVD_PG_8814B(x) ((x) & (~BITS_CH9_RSVD_PG_8814B))
#define BIT_GET_CH9_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH9_RSVD_PG_8814B) & BIT_MASK_CH9_RSVD_PG_8814B)
#define BIT_SET_CH9_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH9_RSVD_PG_8814B(x) | BIT_CH9_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_10_8814B */
#define BIT_SHIFT_CH10_AVAL_PG_8814B 16
#define BIT_MASK_CH10_AVAL_PG_8814B 0xfff
#define BIT_CH10_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH10_AVAL_PG_8814B) << BIT_SHIFT_CH10_AVAL_PG_8814B)
#define BITS_CH10_AVAL_PG_8814B \
(BIT_MASK_CH10_AVAL_PG_8814B << BIT_SHIFT_CH10_AVAL_PG_8814B)
#define BIT_CLEAR_CH10_AVAL_PG_8814B(x) ((x) & (~BITS_CH10_AVAL_PG_8814B))
#define BIT_GET_CH10_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH10_AVAL_PG_8814B) & BIT_MASK_CH10_AVAL_PG_8814B)
#define BIT_SET_CH10_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH10_AVAL_PG_8814B(x) | BIT_CH10_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH10_RSVD_PG_8814B 0
#define BIT_MASK_CH10_RSVD_PG_8814B 0xfff
#define BIT_CH10_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH10_RSVD_PG_8814B) << BIT_SHIFT_CH10_RSVD_PG_8814B)
#define BITS_CH10_RSVD_PG_8814B \
(BIT_MASK_CH10_RSVD_PG_8814B << BIT_SHIFT_CH10_RSVD_PG_8814B)
#define BIT_CLEAR_CH10_RSVD_PG_8814B(x) ((x) & (~BITS_CH10_RSVD_PG_8814B))
#define BIT_GET_CH10_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH10_RSVD_PG_8814B) & BIT_MASK_CH10_RSVD_PG_8814B)
#define BIT_SET_CH10_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH10_RSVD_PG_8814B(x) | BIT_CH10_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_11_8814B */
#define BIT_SHIFT_CH11_AVAL_PG_8814B 16
#define BIT_MASK_CH11_AVAL_PG_8814B 0xfff
#define BIT_CH11_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH11_AVAL_PG_8814B) << BIT_SHIFT_CH11_AVAL_PG_8814B)
#define BITS_CH11_AVAL_PG_8814B \
(BIT_MASK_CH11_AVAL_PG_8814B << BIT_SHIFT_CH11_AVAL_PG_8814B)
#define BIT_CLEAR_CH11_AVAL_PG_8814B(x) ((x) & (~BITS_CH11_AVAL_PG_8814B))
#define BIT_GET_CH11_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH11_AVAL_PG_8814B) & BIT_MASK_CH11_AVAL_PG_8814B)
#define BIT_SET_CH11_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH11_AVAL_PG_8814B(x) | BIT_CH11_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH11_RSVD_PG_8814B 0
#define BIT_MASK_CH11_RSVD_PG_8814B 0xfff
#define BIT_CH11_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH11_RSVD_PG_8814B) << BIT_SHIFT_CH11_RSVD_PG_8814B)
#define BITS_CH11_RSVD_PG_8814B \
(BIT_MASK_CH11_RSVD_PG_8814B << BIT_SHIFT_CH11_RSVD_PG_8814B)
#define BIT_CLEAR_CH11_RSVD_PG_8814B(x) ((x) & (~BITS_CH11_RSVD_PG_8814B))
#define BIT_GET_CH11_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH11_RSVD_PG_8814B) & BIT_MASK_CH11_RSVD_PG_8814B)
#define BIT_SET_CH11_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH11_RSVD_PG_8814B(x) | BIT_CH11_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_12_8814B */
#define BIT_SHIFT_CH12_AVAL_PG_8814B 16
#define BIT_MASK_CH12_AVAL_PG_8814B 0xfff
#define BIT_CH12_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH12_AVAL_PG_8814B) << BIT_SHIFT_CH12_AVAL_PG_8814B)
#define BITS_CH12_AVAL_PG_8814B \
(BIT_MASK_CH12_AVAL_PG_8814B << BIT_SHIFT_CH12_AVAL_PG_8814B)
#define BIT_CLEAR_CH12_AVAL_PG_8814B(x) ((x) & (~BITS_CH12_AVAL_PG_8814B))
#define BIT_GET_CH12_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH12_AVAL_PG_8814B) & BIT_MASK_CH12_AVAL_PG_8814B)
#define BIT_SET_CH12_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH12_AVAL_PG_8814B(x) | BIT_CH12_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH12_RSVD_PG_8814B 0
#define BIT_MASK_CH12_RSVD_PG_8814B 0xfff
#define BIT_CH12_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH12_RSVD_PG_8814B) << BIT_SHIFT_CH12_RSVD_PG_8814B)
#define BITS_CH12_RSVD_PG_8814B \
(BIT_MASK_CH12_RSVD_PG_8814B << BIT_SHIFT_CH12_RSVD_PG_8814B)
#define BIT_CLEAR_CH12_RSVD_PG_8814B(x) ((x) & (~BITS_CH12_RSVD_PG_8814B))
#define BIT_GET_CH12_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH12_RSVD_PG_8814B) & BIT_MASK_CH12_RSVD_PG_8814B)
#define BIT_SET_CH12_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH12_RSVD_PG_8814B(x) | BIT_CH12_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_13_8814B */
#define BIT_SHIFT_CH13_AVAL_PG_8814B 16
#define BIT_MASK_CH13_AVAL_PG_8814B 0xfff
#define BIT_CH13_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH13_AVAL_PG_8814B) << BIT_SHIFT_CH13_AVAL_PG_8814B)
#define BITS_CH13_AVAL_PG_8814B \
(BIT_MASK_CH13_AVAL_PG_8814B << BIT_SHIFT_CH13_AVAL_PG_8814B)
#define BIT_CLEAR_CH13_AVAL_PG_8814B(x) ((x) & (~BITS_CH13_AVAL_PG_8814B))
#define BIT_GET_CH13_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH13_AVAL_PG_8814B) & BIT_MASK_CH13_AVAL_PG_8814B)
#define BIT_SET_CH13_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH13_AVAL_PG_8814B(x) | BIT_CH13_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH13_RSVD_PG_8814B 0
#define BIT_MASK_CH13_RSVD_PG_8814B 0xfff
#define BIT_CH13_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH13_RSVD_PG_8814B) << BIT_SHIFT_CH13_RSVD_PG_8814B)
#define BITS_CH13_RSVD_PG_8814B \
(BIT_MASK_CH13_RSVD_PG_8814B << BIT_SHIFT_CH13_RSVD_PG_8814B)
#define BIT_CLEAR_CH13_RSVD_PG_8814B(x) ((x) & (~BITS_CH13_RSVD_PG_8814B))
#define BIT_GET_CH13_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH13_RSVD_PG_8814B) & BIT_MASK_CH13_RSVD_PG_8814B)
#define BIT_SET_CH13_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH13_RSVD_PG_8814B(x) | BIT_CH13_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_14_8814B */
#define BIT_SHIFT_CH14_AVAL_PG_8814B 16
#define BIT_MASK_CH14_AVAL_PG_8814B 0xfff
#define BIT_CH14_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH14_AVAL_PG_8814B) << BIT_SHIFT_CH14_AVAL_PG_8814B)
#define BITS_CH14_AVAL_PG_8814B \
(BIT_MASK_CH14_AVAL_PG_8814B << BIT_SHIFT_CH14_AVAL_PG_8814B)
#define BIT_CLEAR_CH14_AVAL_PG_8814B(x) ((x) & (~BITS_CH14_AVAL_PG_8814B))
#define BIT_GET_CH14_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH14_AVAL_PG_8814B) & BIT_MASK_CH14_AVAL_PG_8814B)
#define BIT_SET_CH14_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH14_AVAL_PG_8814B(x) | BIT_CH14_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH14_RSVD_PG_8814B 0
#define BIT_MASK_CH14_RSVD_PG_8814B 0xfff
#define BIT_CH14_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH14_RSVD_PG_8814B) << BIT_SHIFT_CH14_RSVD_PG_8814B)
#define BITS_CH14_RSVD_PG_8814B \
(BIT_MASK_CH14_RSVD_PG_8814B << BIT_SHIFT_CH14_RSVD_PG_8814B)
#define BIT_CLEAR_CH14_RSVD_PG_8814B(x) ((x) & (~BITS_CH14_RSVD_PG_8814B))
#define BIT_GET_CH14_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH14_RSVD_PG_8814B) & BIT_MASK_CH14_RSVD_PG_8814B)
#define BIT_SET_CH14_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH14_RSVD_PG_8814B(x) | BIT_CH14_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_15_8814B */
#define BIT_SHIFT_CH15_AVAL_PG_8814B 16
#define BIT_MASK_CH15_AVAL_PG_8814B 0xfff
#define BIT_CH15_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH15_AVAL_PG_8814B) << BIT_SHIFT_CH15_AVAL_PG_8814B)
#define BITS_CH15_AVAL_PG_8814B \
(BIT_MASK_CH15_AVAL_PG_8814B << BIT_SHIFT_CH15_AVAL_PG_8814B)
#define BIT_CLEAR_CH15_AVAL_PG_8814B(x) ((x) & (~BITS_CH15_AVAL_PG_8814B))
#define BIT_GET_CH15_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH15_AVAL_PG_8814B) & BIT_MASK_CH15_AVAL_PG_8814B)
#define BIT_SET_CH15_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH15_AVAL_PG_8814B(x) | BIT_CH15_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH15_RSVD_PG_8814B 0
#define BIT_MASK_CH15_RSVD_PG_8814B 0xfff
#define BIT_CH15_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH15_RSVD_PG_8814B) << BIT_SHIFT_CH15_RSVD_PG_8814B)
#define BITS_CH15_RSVD_PG_8814B \
(BIT_MASK_CH15_RSVD_PG_8814B << BIT_SHIFT_CH15_RSVD_PG_8814B)
#define BIT_CLEAR_CH15_RSVD_PG_8814B(x) ((x) & (~BITS_CH15_RSVD_PG_8814B))
#define BIT_GET_CH15_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH15_RSVD_PG_8814B) & BIT_MASK_CH15_RSVD_PG_8814B)
#define BIT_SET_CH15_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH15_RSVD_PG_8814B(x) | BIT_CH15_RSVD_PG_8814B(v))
/* 2 REG_DMA_RQPN_INFO_16_8814B */
#define BIT_SHIFT_CH16_AVAL_PG_8814B 16
#define BIT_MASK_CH16_AVAL_PG_8814B 0xfff
#define BIT_CH16_AVAL_PG_8814B(x) \
(((x) & BIT_MASK_CH16_AVAL_PG_8814B) << BIT_SHIFT_CH16_AVAL_PG_8814B)
#define BITS_CH16_AVAL_PG_8814B \
(BIT_MASK_CH16_AVAL_PG_8814B << BIT_SHIFT_CH16_AVAL_PG_8814B)
#define BIT_CLEAR_CH16_AVAL_PG_8814B(x) ((x) & (~BITS_CH16_AVAL_PG_8814B))
#define BIT_GET_CH16_AVAL_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH16_AVAL_PG_8814B) & BIT_MASK_CH16_AVAL_PG_8814B)
#define BIT_SET_CH16_AVAL_PG_8814B(x, v) \
(BIT_CLEAR_CH16_AVAL_PG_8814B(x) | BIT_CH16_AVAL_PG_8814B(v))
#define BIT_SHIFT_CH16_RSVD_PG_8814B 0
#define BIT_MASK_CH16_RSVD_PG_8814B 0xfff
#define BIT_CH16_RSVD_PG_8814B(x) \
(((x) & BIT_MASK_CH16_RSVD_PG_8814B) << BIT_SHIFT_CH16_RSVD_PG_8814B)
#define BITS_CH16_RSVD_PG_8814B \
(BIT_MASK_CH16_RSVD_PG_8814B << BIT_SHIFT_CH16_RSVD_PG_8814B)
#define BIT_CLEAR_CH16_RSVD_PG_8814B(x) ((x) & (~BITS_CH16_RSVD_PG_8814B))
#define BIT_GET_CH16_RSVD_PG_8814B(x) \
(((x) >> BIT_SHIFT_CH16_RSVD_PG_8814B) & BIT_MASK_CH16_RSVD_PG_8814B)
#define BIT_SET_CH16_RSVD_PG_8814B(x, v) \
(BIT_CLEAR_CH16_RSVD_PG_8814B(x) | BIT_CH16_RSVD_PG_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HWAMSDU_CTL1_8814B */
#define BIT_SHIFT_HWAMSDU_PKTNUM_8814B 8
#define BIT_MASK_HWAMSDU_PKTNUM_8814B 0x3f
#define BIT_HWAMSDU_PKTNUM_8814B(x) \
(((x) & BIT_MASK_HWAMSDU_PKTNUM_8814B) \
<< BIT_SHIFT_HWAMSDU_PKTNUM_8814B)
#define BITS_HWAMSDU_PKTNUM_8814B \
(BIT_MASK_HWAMSDU_PKTNUM_8814B << BIT_SHIFT_HWAMSDU_PKTNUM_8814B)
#define BIT_CLEAR_HWAMSDU_PKTNUM_8814B(x) ((x) & (~BITS_HWAMSDU_PKTNUM_8814B))
#define BIT_GET_HWAMSDU_PKTNUM_8814B(x) \
(((x) >> BIT_SHIFT_HWAMSDU_PKTNUM_8814B) & \
BIT_MASK_HWAMSDU_PKTNUM_8814B)
#define BIT_SET_HWAMSDU_PKTNUM_8814B(x, v) \
(BIT_CLEAR_HWAMSDU_PKTNUM_8814B(x) | BIT_HWAMSDU_PKTNUM_8814B(v))
#define BIT_HWAMSDU_BUSY_8814B BIT(7)
#define BIT_SINGLE_AMSDU_8814B BIT(2)
#define BIT_HWAMSDU_PADDING_MODE_8814B BIT(1)
#define BIT_HWAMSDU_EN_8814B BIT(0)
/* 2 REG_HWAMSDU_CTL2_8814B */
#define BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT_8814B 16
#define BIT_MASK_HWAMSDU_AMSDU_TIMEOUT_8814B 0xffff
#define BIT_HWAMSDU_AMSDU_TIMEOUT_8814B(x) \
(((x) & BIT_MASK_HWAMSDU_AMSDU_TIMEOUT_8814B) \
<< BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT_8814B)
#define BITS_HWAMSDU_AMSDU_TIMEOUT_8814B \
(BIT_MASK_HWAMSDU_AMSDU_TIMEOUT_8814B \
<< BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT_8814B)
#define BIT_CLEAR_HWAMSDU_AMSDU_TIMEOUT_8814B(x) \
((x) & (~BITS_HWAMSDU_AMSDU_TIMEOUT_8814B))
#define BIT_GET_HWAMSDU_AMSDU_TIMEOUT_8814B(x) \
(((x) >> BIT_SHIFT_HWAMSDU_AMSDU_TIMEOUT_8814B) & \
BIT_MASK_HWAMSDU_AMSDU_TIMEOUT_8814B)
#define BIT_SET_HWAMSDU_AMSDU_TIMEOUT_8814B(x, v) \
(BIT_CLEAR_HWAMSDU_AMSDU_TIMEOUT_8814B(x) | \
BIT_HWAMSDU_AMSDU_TIMEOUT_8814B(v))
#define BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT_8814B 0
#define BIT_MASK_HWAMSDU_MSDU_TIMEOUT_8814B 0xffff
#define BIT_HWAMSDU_MSDU_TIMEOUT_8814B(x) \
(((x) & BIT_MASK_HWAMSDU_MSDU_TIMEOUT_8814B) \
<< BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT_8814B)
#define BITS_HWAMSDU_MSDU_TIMEOUT_8814B \
(BIT_MASK_HWAMSDU_MSDU_TIMEOUT_8814B \
<< BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT_8814B)
#define BIT_CLEAR_HWAMSDU_MSDU_TIMEOUT_8814B(x) \
((x) & (~BITS_HWAMSDU_MSDU_TIMEOUT_8814B))
#define BIT_GET_HWAMSDU_MSDU_TIMEOUT_8814B(x) \
(((x) >> BIT_SHIFT_HWAMSDU_MSDU_TIMEOUT_8814B) & \
BIT_MASK_HWAMSDU_MSDU_TIMEOUT_8814B)
#define BIT_SET_HWAMSDU_MSDU_TIMEOUT_8814B(x, v) \
(BIT_CLEAR_HWAMSDU_MSDU_TIMEOUT_8814B(x) | \
BIT_HWAMSDU_MSDU_TIMEOUT_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_0_8814B */
#define BIT_CH0_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH0_HIGH_TH_8814B 16
#define BIT_MASK_CH0_HIGH_TH_8814B 0xfff
#define BIT_CH0_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH0_HIGH_TH_8814B) << BIT_SHIFT_CH0_HIGH_TH_8814B)
#define BITS_CH0_HIGH_TH_8814B \
(BIT_MASK_CH0_HIGH_TH_8814B << BIT_SHIFT_CH0_HIGH_TH_8814B)
#define BIT_CLEAR_CH0_HIGH_TH_8814B(x) ((x) & (~BITS_CH0_HIGH_TH_8814B))
#define BIT_GET_CH0_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH0_HIGH_TH_8814B) & BIT_MASK_CH0_HIGH_TH_8814B)
#define BIT_SET_CH0_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH0_HIGH_TH_8814B(x) | BIT_CH0_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH0_LOW_TH_8814B 0
#define BIT_MASK_CH0_LOW_TH_8814B 0xfff
#define BIT_CH0_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH0_LOW_TH_8814B) << BIT_SHIFT_CH0_LOW_TH_8814B)
#define BITS_CH0_LOW_TH_8814B \
(BIT_MASK_CH0_LOW_TH_8814B << BIT_SHIFT_CH0_LOW_TH_8814B)
#define BIT_CLEAR_CH0_LOW_TH_8814B(x) ((x) & (~BITS_CH0_LOW_TH_8814B))
#define BIT_GET_CH0_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH0_LOW_TH_8814B) & BIT_MASK_CH0_LOW_TH_8814B)
#define BIT_SET_CH0_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH0_LOW_TH_8814B(x) | BIT_CH0_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_1_8814B */
#define BIT_CH1_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH1_HIGH_TH_8814B 16
#define BIT_MASK_CH1_HIGH_TH_8814B 0xfff
#define BIT_CH1_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH1_HIGH_TH_8814B) << BIT_SHIFT_CH1_HIGH_TH_8814B)
#define BITS_CH1_HIGH_TH_8814B \
(BIT_MASK_CH1_HIGH_TH_8814B << BIT_SHIFT_CH1_HIGH_TH_8814B)
#define BIT_CLEAR_CH1_HIGH_TH_8814B(x) ((x) & (~BITS_CH1_HIGH_TH_8814B))
#define BIT_GET_CH1_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH1_HIGH_TH_8814B) & BIT_MASK_CH1_HIGH_TH_8814B)
#define BIT_SET_CH1_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH1_HIGH_TH_8814B(x) | BIT_CH1_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH1_LOW_TH_8814B 0
#define BIT_MASK_CH1_LOW_TH_8814B 0xfff
#define BIT_CH1_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH1_LOW_TH_8814B) << BIT_SHIFT_CH1_LOW_TH_8814B)
#define BITS_CH1_LOW_TH_8814B \
(BIT_MASK_CH1_LOW_TH_8814B << BIT_SHIFT_CH1_LOW_TH_8814B)
#define BIT_CLEAR_CH1_LOW_TH_8814B(x) ((x) & (~BITS_CH1_LOW_TH_8814B))
#define BIT_GET_CH1_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH1_LOW_TH_8814B) & BIT_MASK_CH1_LOW_TH_8814B)
#define BIT_SET_CH1_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH1_LOW_TH_8814B(x) | BIT_CH1_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_2_8814B */
#define BIT_CH2_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH2_HIGH_TH_8814B 16
#define BIT_MASK_CH2_HIGH_TH_8814B 0xfff
#define BIT_CH2_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH2_HIGH_TH_8814B) << BIT_SHIFT_CH2_HIGH_TH_8814B)
#define BITS_CH2_HIGH_TH_8814B \
(BIT_MASK_CH2_HIGH_TH_8814B << BIT_SHIFT_CH2_HIGH_TH_8814B)
#define BIT_CLEAR_CH2_HIGH_TH_8814B(x) ((x) & (~BITS_CH2_HIGH_TH_8814B))
#define BIT_GET_CH2_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH2_HIGH_TH_8814B) & BIT_MASK_CH2_HIGH_TH_8814B)
#define BIT_SET_CH2_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH2_HIGH_TH_8814B(x) | BIT_CH2_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH2_LOW_TH_8814B 0
#define BIT_MASK_CH2_LOW_TH_8814B 0xfff
#define BIT_CH2_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH2_LOW_TH_8814B) << BIT_SHIFT_CH2_LOW_TH_8814B)
#define BITS_CH2_LOW_TH_8814B \
(BIT_MASK_CH2_LOW_TH_8814B << BIT_SHIFT_CH2_LOW_TH_8814B)
#define BIT_CLEAR_CH2_LOW_TH_8814B(x) ((x) & (~BITS_CH2_LOW_TH_8814B))
#define BIT_GET_CH2_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH2_LOW_TH_8814B) & BIT_MASK_CH2_LOW_TH_8814B)
#define BIT_SET_CH2_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH2_LOW_TH_8814B(x) | BIT_CH2_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_3_8814B */
#define BIT_CH3_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH3_HIGH_TH_8814B 16
#define BIT_MASK_CH3_HIGH_TH_8814B 0xfff
#define BIT_CH3_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH3_HIGH_TH_8814B) << BIT_SHIFT_CH3_HIGH_TH_8814B)
#define BITS_CH3_HIGH_TH_8814B \
(BIT_MASK_CH3_HIGH_TH_8814B << BIT_SHIFT_CH3_HIGH_TH_8814B)
#define BIT_CLEAR_CH3_HIGH_TH_8814B(x) ((x) & (~BITS_CH3_HIGH_TH_8814B))
#define BIT_GET_CH3_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH3_HIGH_TH_8814B) & BIT_MASK_CH3_HIGH_TH_8814B)
#define BIT_SET_CH3_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH3_HIGH_TH_8814B(x) | BIT_CH3_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH3_LOW_TH_8814B 0
#define BIT_MASK_CH3_LOW_TH_8814B 0xfff
#define BIT_CH3_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH3_LOW_TH_8814B) << BIT_SHIFT_CH3_LOW_TH_8814B)
#define BITS_CH3_LOW_TH_8814B \
(BIT_MASK_CH3_LOW_TH_8814B << BIT_SHIFT_CH3_LOW_TH_8814B)
#define BIT_CLEAR_CH3_LOW_TH_8814B(x) ((x) & (~BITS_CH3_LOW_TH_8814B))
#define BIT_GET_CH3_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH3_LOW_TH_8814B) & BIT_MASK_CH3_LOW_TH_8814B)
#define BIT_SET_CH3_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH3_LOW_TH_8814B(x) | BIT_CH3_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_4_8814B */
#define BIT_CH4_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH4_HIGH_TH_8814B 16
#define BIT_MASK_CH4_HIGH_TH_8814B 0xfff
#define BIT_CH4_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH4_HIGH_TH_8814B) << BIT_SHIFT_CH4_HIGH_TH_8814B)
#define BITS_CH4_HIGH_TH_8814B \
(BIT_MASK_CH4_HIGH_TH_8814B << BIT_SHIFT_CH4_HIGH_TH_8814B)
#define BIT_CLEAR_CH4_HIGH_TH_8814B(x) ((x) & (~BITS_CH4_HIGH_TH_8814B))
#define BIT_GET_CH4_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH4_HIGH_TH_8814B) & BIT_MASK_CH4_HIGH_TH_8814B)
#define BIT_SET_CH4_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH4_HIGH_TH_8814B(x) | BIT_CH4_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH4_LOW_TH_8814B 0
#define BIT_MASK_CH4_LOW_TH_8814B 0xfff
#define BIT_CH4_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH4_LOW_TH_8814B) << BIT_SHIFT_CH4_LOW_TH_8814B)
#define BITS_CH4_LOW_TH_8814B \
(BIT_MASK_CH4_LOW_TH_8814B << BIT_SHIFT_CH4_LOW_TH_8814B)
#define BIT_CLEAR_CH4_LOW_TH_8814B(x) ((x) & (~BITS_CH4_LOW_TH_8814B))
#define BIT_GET_CH4_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH4_LOW_TH_8814B) & BIT_MASK_CH4_LOW_TH_8814B)
#define BIT_SET_CH4_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH4_LOW_TH_8814B(x) | BIT_CH4_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_5_8814B */
#define BIT_CH5_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH5_HIGH_TH_8814B 16
#define BIT_MASK_CH5_HIGH_TH_8814B 0xfff
#define BIT_CH5_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH5_HIGH_TH_8814B) << BIT_SHIFT_CH5_HIGH_TH_8814B)
#define BITS_CH5_HIGH_TH_8814B \
(BIT_MASK_CH5_HIGH_TH_8814B << BIT_SHIFT_CH5_HIGH_TH_8814B)
#define BIT_CLEAR_CH5_HIGH_TH_8814B(x) ((x) & (~BITS_CH5_HIGH_TH_8814B))
#define BIT_GET_CH5_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH5_HIGH_TH_8814B) & BIT_MASK_CH5_HIGH_TH_8814B)
#define BIT_SET_CH5_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH5_HIGH_TH_8814B(x) | BIT_CH5_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH5_LOW_TH_8814B 0
#define BIT_MASK_CH5_LOW_TH_8814B 0xfff
#define BIT_CH5_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH5_LOW_TH_8814B) << BIT_SHIFT_CH5_LOW_TH_8814B)
#define BITS_CH5_LOW_TH_8814B \
(BIT_MASK_CH5_LOW_TH_8814B << BIT_SHIFT_CH5_LOW_TH_8814B)
#define BIT_CLEAR_CH5_LOW_TH_8814B(x) ((x) & (~BITS_CH5_LOW_TH_8814B))
#define BIT_GET_CH5_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH5_LOW_TH_8814B) & BIT_MASK_CH5_LOW_TH_8814B)
#define BIT_SET_CH5_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH5_LOW_TH_8814B(x) | BIT_CH5_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_6_8814B */
#define BIT_CH6_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH6_HIGH_TH_8814B 16
#define BIT_MASK_CH6_HIGH_TH_8814B 0xfff
#define BIT_CH6_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH6_HIGH_TH_8814B) << BIT_SHIFT_CH6_HIGH_TH_8814B)
#define BITS_CH6_HIGH_TH_8814B \
(BIT_MASK_CH6_HIGH_TH_8814B << BIT_SHIFT_CH6_HIGH_TH_8814B)
#define BIT_CLEAR_CH6_HIGH_TH_8814B(x) ((x) & (~BITS_CH6_HIGH_TH_8814B))
#define BIT_GET_CH6_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH6_HIGH_TH_8814B) & BIT_MASK_CH6_HIGH_TH_8814B)
#define BIT_SET_CH6_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH6_HIGH_TH_8814B(x) | BIT_CH6_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH6_LOW_TH_8814B 0
#define BIT_MASK_CH6_LOW_TH_8814B 0xfff
#define BIT_CH6_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH6_LOW_TH_8814B) << BIT_SHIFT_CH6_LOW_TH_8814B)
#define BITS_CH6_LOW_TH_8814B \
(BIT_MASK_CH6_LOW_TH_8814B << BIT_SHIFT_CH6_LOW_TH_8814B)
#define BIT_CLEAR_CH6_LOW_TH_8814B(x) ((x) & (~BITS_CH6_LOW_TH_8814B))
#define BIT_GET_CH6_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH6_LOW_TH_8814B) & BIT_MASK_CH6_LOW_TH_8814B)
#define BIT_SET_CH6_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH6_LOW_TH_8814B(x) | BIT_CH6_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_7_8814B */
#define BIT_CH7_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH7_HIGH_TH_8814B 16
#define BIT_MASK_CH7_HIGH_TH_8814B 0xfff
#define BIT_CH7_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH7_HIGH_TH_8814B) << BIT_SHIFT_CH7_HIGH_TH_8814B)
#define BITS_CH7_HIGH_TH_8814B \
(BIT_MASK_CH7_HIGH_TH_8814B << BIT_SHIFT_CH7_HIGH_TH_8814B)
#define BIT_CLEAR_CH7_HIGH_TH_8814B(x) ((x) & (~BITS_CH7_HIGH_TH_8814B))
#define BIT_GET_CH7_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH7_HIGH_TH_8814B) & BIT_MASK_CH7_HIGH_TH_8814B)
#define BIT_SET_CH7_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH7_HIGH_TH_8814B(x) | BIT_CH7_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH7_LOW_TH_8814B 0
#define BIT_MASK_CH7_LOW_TH_8814B 0xfff
#define BIT_CH7_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH7_LOW_TH_8814B) << BIT_SHIFT_CH7_LOW_TH_8814B)
#define BITS_CH7_LOW_TH_8814B \
(BIT_MASK_CH7_LOW_TH_8814B << BIT_SHIFT_CH7_LOW_TH_8814B)
#define BIT_CLEAR_CH7_LOW_TH_8814B(x) ((x) & (~BITS_CH7_LOW_TH_8814B))
#define BIT_GET_CH7_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH7_LOW_TH_8814B) & BIT_MASK_CH7_LOW_TH_8814B)
#define BIT_SET_CH7_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH7_LOW_TH_8814B(x) | BIT_CH7_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_8_8814B */
#define BIT_CH8_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH8_HIGH_TH_8814B 16
#define BIT_MASK_CH8_HIGH_TH_8814B 0xfff
#define BIT_CH8_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH8_HIGH_TH_8814B) << BIT_SHIFT_CH8_HIGH_TH_8814B)
#define BITS_CH8_HIGH_TH_8814B \
(BIT_MASK_CH8_HIGH_TH_8814B << BIT_SHIFT_CH8_HIGH_TH_8814B)
#define BIT_CLEAR_CH8_HIGH_TH_8814B(x) ((x) & (~BITS_CH8_HIGH_TH_8814B))
#define BIT_GET_CH8_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH8_HIGH_TH_8814B) & BIT_MASK_CH8_HIGH_TH_8814B)
#define BIT_SET_CH8_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH8_HIGH_TH_8814B(x) | BIT_CH8_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH8_LOW_TH_8814B 0
#define BIT_MASK_CH8_LOW_TH_8814B 0xfff
#define BIT_CH8_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH8_LOW_TH_8814B) << BIT_SHIFT_CH8_LOW_TH_8814B)
#define BITS_CH8_LOW_TH_8814B \
(BIT_MASK_CH8_LOW_TH_8814B << BIT_SHIFT_CH8_LOW_TH_8814B)
#define BIT_CLEAR_CH8_LOW_TH_8814B(x) ((x) & (~BITS_CH8_LOW_TH_8814B))
#define BIT_GET_CH8_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH8_LOW_TH_8814B) & BIT_MASK_CH8_LOW_TH_8814B)
#define BIT_SET_CH8_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH8_LOW_TH_8814B(x) | BIT_CH8_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_9_8814B */
#define BIT_CH9_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH9_HIGH_TH_8814B 16
#define BIT_MASK_CH9_HIGH_TH_8814B 0xfff
#define BIT_CH9_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH9_HIGH_TH_8814B) << BIT_SHIFT_CH9_HIGH_TH_8814B)
#define BITS_CH9_HIGH_TH_8814B \
(BIT_MASK_CH9_HIGH_TH_8814B << BIT_SHIFT_CH9_HIGH_TH_8814B)
#define BIT_CLEAR_CH9_HIGH_TH_8814B(x) ((x) & (~BITS_CH9_HIGH_TH_8814B))
#define BIT_GET_CH9_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH9_HIGH_TH_8814B) & BIT_MASK_CH9_HIGH_TH_8814B)
#define BIT_SET_CH9_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH9_HIGH_TH_8814B(x) | BIT_CH9_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH9_LOW_TH_8814B 0
#define BIT_MASK_CH9_LOW_TH_8814B 0xfff
#define BIT_CH9_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH9_LOW_TH_8814B) << BIT_SHIFT_CH9_LOW_TH_8814B)
#define BITS_CH9_LOW_TH_8814B \
(BIT_MASK_CH9_LOW_TH_8814B << BIT_SHIFT_CH9_LOW_TH_8814B)
#define BIT_CLEAR_CH9_LOW_TH_8814B(x) ((x) & (~BITS_CH9_LOW_TH_8814B))
#define BIT_GET_CH9_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH9_LOW_TH_8814B) & BIT_MASK_CH9_LOW_TH_8814B)
#define BIT_SET_CH9_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH9_LOW_TH_8814B(x) | BIT_CH9_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_10_8814B */
#define BIT_CH10_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH10_HIGH_TH_8814B 16
#define BIT_MASK_CH10_HIGH_TH_8814B 0xfff
#define BIT_CH10_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH10_HIGH_TH_8814B) << BIT_SHIFT_CH10_HIGH_TH_8814B)
#define BITS_CH10_HIGH_TH_8814B \
(BIT_MASK_CH10_HIGH_TH_8814B << BIT_SHIFT_CH10_HIGH_TH_8814B)
#define BIT_CLEAR_CH10_HIGH_TH_8814B(x) ((x) & (~BITS_CH10_HIGH_TH_8814B))
#define BIT_GET_CH10_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH10_HIGH_TH_8814B) & BIT_MASK_CH10_HIGH_TH_8814B)
#define BIT_SET_CH10_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH10_HIGH_TH_8814B(x) | BIT_CH10_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH10_LOW_TH_8814B 0
#define BIT_MASK_CH10_LOW_TH_8814B 0xfff
#define BIT_CH10_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH10_LOW_TH_8814B) << BIT_SHIFT_CH10_LOW_TH_8814B)
#define BITS_CH10_LOW_TH_8814B \
(BIT_MASK_CH10_LOW_TH_8814B << BIT_SHIFT_CH10_LOW_TH_8814B)
#define BIT_CLEAR_CH10_LOW_TH_8814B(x) ((x) & (~BITS_CH10_LOW_TH_8814B))
#define BIT_GET_CH10_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH10_LOW_TH_8814B) & BIT_MASK_CH10_LOW_TH_8814B)
#define BIT_SET_CH10_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH10_LOW_TH_8814B(x) | BIT_CH10_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_11_8814B */
#define BIT_CH11_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH11_HIGH_TH_8814B 16
#define BIT_MASK_CH11_HIGH_TH_8814B 0xfff
#define BIT_CH11_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH11_HIGH_TH_8814B) << BIT_SHIFT_CH11_HIGH_TH_8814B)
#define BITS_CH11_HIGH_TH_8814B \
(BIT_MASK_CH11_HIGH_TH_8814B << BIT_SHIFT_CH11_HIGH_TH_8814B)
#define BIT_CLEAR_CH11_HIGH_TH_8814B(x) ((x) & (~BITS_CH11_HIGH_TH_8814B))
#define BIT_GET_CH11_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH11_HIGH_TH_8814B) & BIT_MASK_CH11_HIGH_TH_8814B)
#define BIT_SET_CH11_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH11_HIGH_TH_8814B(x) | BIT_CH11_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH11_LOW_TH_8814B 0
#define BIT_MASK_CH11_LOW_TH_8814B 0xfff
#define BIT_CH11_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH11_LOW_TH_8814B) << BIT_SHIFT_CH11_LOW_TH_8814B)
#define BITS_CH11_LOW_TH_8814B \
(BIT_MASK_CH11_LOW_TH_8814B << BIT_SHIFT_CH11_LOW_TH_8814B)
#define BIT_CLEAR_CH11_LOW_TH_8814B(x) ((x) & (~BITS_CH11_LOW_TH_8814B))
#define BIT_GET_CH11_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH11_LOW_TH_8814B) & BIT_MASK_CH11_LOW_TH_8814B)
#define BIT_SET_CH11_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH11_LOW_TH_8814B(x) | BIT_CH11_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_12_8814B */
#define BIT_CH12_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH12_HIGH_TH_8814B 16
#define BIT_MASK_CH12_HIGH_TH_8814B 0xfff
#define BIT_CH12_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH12_HIGH_TH_8814B) << BIT_SHIFT_CH12_HIGH_TH_8814B)
#define BITS_CH12_HIGH_TH_8814B \
(BIT_MASK_CH12_HIGH_TH_8814B << BIT_SHIFT_CH12_HIGH_TH_8814B)
#define BIT_CLEAR_CH12_HIGH_TH_8814B(x) ((x) & (~BITS_CH12_HIGH_TH_8814B))
#define BIT_GET_CH12_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH12_HIGH_TH_8814B) & BIT_MASK_CH12_HIGH_TH_8814B)
#define BIT_SET_CH12_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH12_HIGH_TH_8814B(x) | BIT_CH12_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH12_LOW_TH_8814B 0
#define BIT_MASK_CH12_LOW_TH_8814B 0xfff
#define BIT_CH12_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH12_LOW_TH_8814B) << BIT_SHIFT_CH12_LOW_TH_8814B)
#define BITS_CH12_LOW_TH_8814B \
(BIT_MASK_CH12_LOW_TH_8814B << BIT_SHIFT_CH12_LOW_TH_8814B)
#define BIT_CLEAR_CH12_LOW_TH_8814B(x) ((x) & (~BITS_CH12_LOW_TH_8814B))
#define BIT_GET_CH12_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH12_LOW_TH_8814B) & BIT_MASK_CH12_LOW_TH_8814B)
#define BIT_SET_CH12_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH12_LOW_TH_8814B(x) | BIT_CH12_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_13_8814B */
#define BIT_CH13_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH13_HIGH_TH_8814B 16
#define BIT_MASK_CH13_HIGH_TH_8814B 0xfff
#define BIT_CH13_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH13_HIGH_TH_8814B) << BIT_SHIFT_CH13_HIGH_TH_8814B)
#define BITS_CH13_HIGH_TH_8814B \
(BIT_MASK_CH13_HIGH_TH_8814B << BIT_SHIFT_CH13_HIGH_TH_8814B)
#define BIT_CLEAR_CH13_HIGH_TH_8814B(x) ((x) & (~BITS_CH13_HIGH_TH_8814B))
#define BIT_GET_CH13_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH13_HIGH_TH_8814B) & BIT_MASK_CH13_HIGH_TH_8814B)
#define BIT_SET_CH13_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH13_HIGH_TH_8814B(x) | BIT_CH13_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH13_LOW_TH_8814B 0
#define BIT_MASK_CH13_LOW_TH_8814B 0xfff
#define BIT_CH13_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH13_LOW_TH_8814B) << BIT_SHIFT_CH13_LOW_TH_8814B)
#define BITS_CH13_LOW_TH_8814B \
(BIT_MASK_CH13_LOW_TH_8814B << BIT_SHIFT_CH13_LOW_TH_8814B)
#define BIT_CLEAR_CH13_LOW_TH_8814B(x) ((x) & (~BITS_CH13_LOW_TH_8814B))
#define BIT_GET_CH13_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH13_LOW_TH_8814B) & BIT_MASK_CH13_LOW_TH_8814B)
#define BIT_SET_CH13_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH13_LOW_TH_8814B(x) | BIT_CH13_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_14_8814B */
#define BIT_CH14_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH14_HIGH_TH_8814B 16
#define BIT_MASK_CH14_HIGH_TH_8814B 0xfff
#define BIT_CH14_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH14_HIGH_TH_8814B) << BIT_SHIFT_CH14_HIGH_TH_8814B)
#define BITS_CH14_HIGH_TH_8814B \
(BIT_MASK_CH14_HIGH_TH_8814B << BIT_SHIFT_CH14_HIGH_TH_8814B)
#define BIT_CLEAR_CH14_HIGH_TH_8814B(x) ((x) & (~BITS_CH14_HIGH_TH_8814B))
#define BIT_GET_CH14_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH14_HIGH_TH_8814B) & BIT_MASK_CH14_HIGH_TH_8814B)
#define BIT_SET_CH14_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH14_HIGH_TH_8814B(x) | BIT_CH14_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH14_LOW_TH_8814B 0
#define BIT_MASK_CH14_LOW_TH_8814B 0xfff
#define BIT_CH14_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH14_LOW_TH_8814B) << BIT_SHIFT_CH14_LOW_TH_8814B)
#define BITS_CH14_LOW_TH_8814B \
(BIT_MASK_CH14_LOW_TH_8814B << BIT_SHIFT_CH14_LOW_TH_8814B)
#define BIT_CLEAR_CH14_LOW_TH_8814B(x) ((x) & (~BITS_CH14_LOW_TH_8814B))
#define BIT_GET_CH14_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH14_LOW_TH_8814B) & BIT_MASK_CH14_LOW_TH_8814B)
#define BIT_SET_CH14_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH14_LOW_TH_8814B(x) | BIT_CH14_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_15_8814B */
#define BIT_CH15_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH15_HIGH_TH_8814B 16
#define BIT_MASK_CH15_HIGH_TH_8814B 0xfff
#define BIT_CH15_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH15_HIGH_TH_8814B) << BIT_SHIFT_CH15_HIGH_TH_8814B)
#define BITS_CH15_HIGH_TH_8814B \
(BIT_MASK_CH15_HIGH_TH_8814B << BIT_SHIFT_CH15_HIGH_TH_8814B)
#define BIT_CLEAR_CH15_HIGH_TH_8814B(x) ((x) & (~BITS_CH15_HIGH_TH_8814B))
#define BIT_GET_CH15_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH15_HIGH_TH_8814B) & BIT_MASK_CH15_HIGH_TH_8814B)
#define BIT_SET_CH15_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH15_HIGH_TH_8814B(x) | BIT_CH15_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH15_LOW_TH_8814B 0
#define BIT_MASK_CH15_LOW_TH_8814B 0xfff
#define BIT_CH15_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH15_LOW_TH_8814B) << BIT_SHIFT_CH15_LOW_TH_8814B)
#define BITS_CH15_LOW_TH_8814B \
(BIT_MASK_CH15_LOW_TH_8814B << BIT_SHIFT_CH15_LOW_TH_8814B)
#define BIT_CLEAR_CH15_LOW_TH_8814B(x) ((x) & (~BITS_CH15_LOW_TH_8814B))
#define BIT_GET_CH15_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH15_LOW_TH_8814B) & BIT_MASK_CH15_LOW_TH_8814B)
#define BIT_SET_CH15_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH15_LOW_TH_8814B(x) | BIT_CH15_LOW_TH_8814B(v))
/* 2 REG_TXPAGE_INT_CTRL_16_8814B */
#define BIT_CH16_INT_EN_8814B BIT(31)
#define BIT_SHIFT_CH16_HIGH_TH_8814B 16
#define BIT_MASK_CH16_HIGH_TH_8814B 0xfff
#define BIT_CH16_HIGH_TH_8814B(x) \
(((x) & BIT_MASK_CH16_HIGH_TH_8814B) << BIT_SHIFT_CH16_HIGH_TH_8814B)
#define BITS_CH16_HIGH_TH_8814B \
(BIT_MASK_CH16_HIGH_TH_8814B << BIT_SHIFT_CH16_HIGH_TH_8814B)
#define BIT_CLEAR_CH16_HIGH_TH_8814B(x) ((x) & (~BITS_CH16_HIGH_TH_8814B))
#define BIT_GET_CH16_HIGH_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH16_HIGH_TH_8814B) & BIT_MASK_CH16_HIGH_TH_8814B)
#define BIT_SET_CH16_HIGH_TH_8814B(x, v) \
(BIT_CLEAR_CH16_HIGH_TH_8814B(x) | BIT_CH16_HIGH_TH_8814B(v))
#define BIT_SHIFT_CH16_LOW_TH_8814B 0
#define BIT_MASK_CH16_LOW_TH_8814B 0xfff
#define BIT_CH16_LOW_TH_8814B(x) \
(((x) & BIT_MASK_CH16_LOW_TH_8814B) << BIT_SHIFT_CH16_LOW_TH_8814B)
#define BITS_CH16_LOW_TH_8814B \
(BIT_MASK_CH16_LOW_TH_8814B << BIT_SHIFT_CH16_LOW_TH_8814B)
#define BIT_CLEAR_CH16_LOW_TH_8814B(x) ((x) & (~BITS_CH16_LOW_TH_8814B))
#define BIT_GET_CH16_LOW_TH_8814B(x) \
(((x) >> BIT_SHIFT_CH16_LOW_TH_8814B) & BIT_MASK_CH16_LOW_TH_8814B)
#define BIT_SET_CH16_LOW_TH_8814B(x, v) \
(BIT_CLEAR_CH16_LOW_TH_8814B(x) | BIT_CH16_LOW_TH_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PCIE_CTRL_8814B */
#define BIT_PCIEIO_PERSTB_SEL_8814B BIT(31)
#define BIT_SHIFT_PCIE_MAX_RXDMA_8814B 28
#define BIT_MASK_PCIE_MAX_RXDMA_8814B 0x7
#define BIT_PCIE_MAX_RXDMA_8814B(x) \
(((x) & BIT_MASK_PCIE_MAX_RXDMA_8814B) \
<< BIT_SHIFT_PCIE_MAX_RXDMA_8814B)
#define BITS_PCIE_MAX_RXDMA_8814B \
(BIT_MASK_PCIE_MAX_RXDMA_8814B << BIT_SHIFT_PCIE_MAX_RXDMA_8814B)
#define BIT_CLEAR_PCIE_MAX_RXDMA_8814B(x) ((x) & (~BITS_PCIE_MAX_RXDMA_8814B))
#define BIT_GET_PCIE_MAX_RXDMA_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_RXDMA_8814B) & \
BIT_MASK_PCIE_MAX_RXDMA_8814B)
#define BIT_SET_PCIE_MAX_RXDMA_8814B(x, v) \
(BIT_CLEAR_PCIE_MAX_RXDMA_8814B(x) | BIT_PCIE_MAX_RXDMA_8814B(v))
#define BIT_MULRW_8814B BIT(27)
#define BIT_SHIFT_PCIE_MAX_TXDMA_8814B 24
#define BIT_MASK_PCIE_MAX_TXDMA_8814B 0x7
#define BIT_PCIE_MAX_TXDMA_8814B(x) \
(((x) & BIT_MASK_PCIE_MAX_TXDMA_8814B) \
<< BIT_SHIFT_PCIE_MAX_TXDMA_8814B)
#define BITS_PCIE_MAX_TXDMA_8814B \
(BIT_MASK_PCIE_MAX_TXDMA_8814B << BIT_SHIFT_PCIE_MAX_TXDMA_8814B)
#define BIT_CLEAR_PCIE_MAX_TXDMA_8814B(x) ((x) & (~BITS_PCIE_MAX_TXDMA_8814B))
#define BIT_GET_PCIE_MAX_TXDMA_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_TXDMA_8814B) & \
BIT_MASK_PCIE_MAX_TXDMA_8814B)
#define BIT_SET_PCIE_MAX_TXDMA_8814B(x, v) \
(BIT_CLEAR_PCIE_MAX_TXDMA_8814B(x) | BIT_PCIE_MAX_TXDMA_8814B(v))
#define BIT_PWR_SCALE_START_PS_8814B BIT(23)
#define BIT_EN_CPL_TIMEOUT_PS_8814B BIT(22)
#define BIT_REG_TXDMA_FAIL_PS_8814B BIT(21)
#define BIT_PCIE_RST_TRXDMA_INTF_8814B BIT(20)
#define BIT_EN_HWENTR_L1_8814B BIT(19)
#define BIT_EN_ADV_CLKGATE_8814B BIT(18)
#define BIT_PCIE_EN_SWENT_L23_8814B BIT(17)
#define BIT_PCIE_EN_HWEXT_L1_8814B BIT(16)
#define BIT_STOP_P0_MPRT_BCNQ4_8814B BIT(6)
#define BIT_STOP_P0_MPRT_BCNQ3_8814B BIT(4)
#define BIT_STOP_P0_MPRT_BCNQ2_8814B BIT(2)
#define BIT_STOP_P0_MPRT_BCNQ1_8814B BIT(0)
/* 2 REG_ACH_CTRL_8814B */
#define BIT_STOP_P0HIQ19_8814B BIT(27)
#define BIT_STOP_P0HIQ18_8814B BIT(26)
#define BIT_STOP_P0HIQ17_8814B BIT(25)
#define BIT_STOP_P0HIQ16_8814B BIT(24)
#define BIT_RX_CLOSE_EN_V1_8814B BIT(21)
#define BIT_STOP_FWCMDQ_8814B BIT(20)
#define BIT_STOP_P0BCNQ_8814B BIT(18)
#define BIT_STOP_P0MGQ_8814B BIT(16)
#define BIT_STOP_ACH13_8814B BIT(15)
#define BIT_STOP_ACH12_8814B BIT(14)
#define BIT_STOP_ACH11_8814B BIT(13)
#define BIT_STOP_ACH10_8814B BIT(12)
#define BIT_STOP_ACH9_8814B BIT(11)
#define BIT_STOP_ACH8_8814B BIT(10)
#define BIT_STOP_ACH7_8814B BIT(9)
#define BIT_STOP_ACH6_8814B BIT(8)
#define BIT_STOP_ACH5_8814B BIT(7)
#define BIT_STOP_ACH4_8814B BIT(6)
#define BIT_STOP_ACH3_8814B BIT(5)
#define BIT_STOP_ACH2_8814B BIT(4)
#define BIT_STOP_ACH1_8814B BIT(3)
#define BIT_STOP_ACH0_8814B BIT(2)
#define BIT_STOP_P0RX_8814B BIT(0)
/* 2 REG_HIQ_CTRL_8814B */
#define BIT_STOP_P0HIQ15_8814B BIT(15)
#define BIT_STOP_P0HIQ14_8814B BIT(14)
#define BIT_STOP_P0HIQ13_8814B BIT(13)
#define BIT_STOP_P0HIQ12_8814B BIT(12)
#define BIT_STOP_P0HIQ11_8814B BIT(11)
#define BIT_STOP_P0HIQ10_8814B BIT(10)
#define BIT_STOP_P0HIQ9_8814B BIT(9)
#define BIT_STOP_P0HIQ8_8814B BIT(8)
#define BIT_STOP_P0HIQ7_8814B BIT(7)
#define BIT_STOP_P0HIQ6_8814B BIT(6)
#define BIT_STOP_P0HIQ5_8814B BIT(5)
#define BIT_STOP_P0HIQ4_8814B BIT(4)
#define BIT_STOP_P0HIQ3_8814B BIT(3)
#define BIT_STOP_P0HIQ2_8814B BIT(2)
#define BIT_STOP_P0HIQ1_8814B BIT(1)
#define BIT_STOP_P0HIQ0_8814B BIT(0)
/* 2 REG_INT_MIG_V1_8814B */
#define BIT_SHIFT_TXTTIMER_MATCH_NUM_8814B 28
#define BIT_MASK_TXTTIMER_MATCH_NUM_8814B 0xf
#define BIT_TXTTIMER_MATCH_NUM_8814B(x) \
(((x) & BIT_MASK_TXTTIMER_MATCH_NUM_8814B) \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8814B)
#define BITS_TXTTIMER_MATCH_NUM_8814B \
(BIT_MASK_TXTTIMER_MATCH_NUM_8814B \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8814B)
#define BIT_CLEAR_TXTTIMER_MATCH_NUM_8814B(x) \
((x) & (~BITS_TXTTIMER_MATCH_NUM_8814B))
#define BIT_GET_TXTTIMER_MATCH_NUM_8814B(x) \
(((x) >> BIT_SHIFT_TXTTIMER_MATCH_NUM_8814B) & \
BIT_MASK_TXTTIMER_MATCH_NUM_8814B)
#define BIT_SET_TXTTIMER_MATCH_NUM_8814B(x, v) \
(BIT_CLEAR_TXTTIMER_MATCH_NUM_8814B(x) | \
BIT_TXTTIMER_MATCH_NUM_8814B(v))
#define BIT_SHIFT_TXPKT_NUM_MATCH_8814B 24
#define BIT_MASK_TXPKT_NUM_MATCH_8814B 0xf
#define BIT_TXPKT_NUM_MATCH_8814B(x) \
(((x) & BIT_MASK_TXPKT_NUM_MATCH_8814B) \
<< BIT_SHIFT_TXPKT_NUM_MATCH_8814B)
#define BITS_TXPKT_NUM_MATCH_8814B \
(BIT_MASK_TXPKT_NUM_MATCH_8814B << BIT_SHIFT_TXPKT_NUM_MATCH_8814B)
#define BIT_CLEAR_TXPKT_NUM_MATCH_8814B(x) ((x) & (~BITS_TXPKT_NUM_MATCH_8814B))
#define BIT_GET_TXPKT_NUM_MATCH_8814B(x) \
(((x) >> BIT_SHIFT_TXPKT_NUM_MATCH_8814B) & \
BIT_MASK_TXPKT_NUM_MATCH_8814B)
#define BIT_SET_TXPKT_NUM_MATCH_8814B(x, v) \
(BIT_CLEAR_TXPKT_NUM_MATCH_8814B(x) | BIT_TXPKT_NUM_MATCH_8814B(v))
#define BIT_SHIFT_RXTTIMER_MATCH_NUM_8814B 20
#define BIT_MASK_RXTTIMER_MATCH_NUM_8814B 0xf
#define BIT_RXTTIMER_MATCH_NUM_8814B(x) \
(((x) & BIT_MASK_RXTTIMER_MATCH_NUM_8814B) \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8814B)
#define BITS_RXTTIMER_MATCH_NUM_8814B \
(BIT_MASK_RXTTIMER_MATCH_NUM_8814B \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8814B)
#define BIT_CLEAR_RXTTIMER_MATCH_NUM_8814B(x) \
((x) & (~BITS_RXTTIMER_MATCH_NUM_8814B))
#define BIT_GET_RXTTIMER_MATCH_NUM_8814B(x) \
(((x) >> BIT_SHIFT_RXTTIMER_MATCH_NUM_8814B) & \
BIT_MASK_RXTTIMER_MATCH_NUM_8814B)
#define BIT_SET_RXTTIMER_MATCH_NUM_8814B(x, v) \
(BIT_CLEAR_RXTTIMER_MATCH_NUM_8814B(x) | \
BIT_RXTTIMER_MATCH_NUM_8814B(v))
#define BIT_SHIFT_RXPKT_NUM_MATCH_8814B 16
#define BIT_MASK_RXPKT_NUM_MATCH_8814B 0xf
#define BIT_RXPKT_NUM_MATCH_8814B(x) \
(((x) & BIT_MASK_RXPKT_NUM_MATCH_8814B) \
<< BIT_SHIFT_RXPKT_NUM_MATCH_8814B)
#define BITS_RXPKT_NUM_MATCH_8814B \
(BIT_MASK_RXPKT_NUM_MATCH_8814B << BIT_SHIFT_RXPKT_NUM_MATCH_8814B)
#define BIT_CLEAR_RXPKT_NUM_MATCH_8814B(x) ((x) & (~BITS_RXPKT_NUM_MATCH_8814B))
#define BIT_GET_RXPKT_NUM_MATCH_8814B(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_MATCH_8814B) & \
BIT_MASK_RXPKT_NUM_MATCH_8814B)
#define BIT_SET_RXPKT_NUM_MATCH_8814B(x, v) \
(BIT_CLEAR_RXPKT_NUM_MATCH_8814B(x) | BIT_RXPKT_NUM_MATCH_8814B(v))
#define BIT_SHIFT_MIGRATE_TIMER_8814B 0
#define BIT_MASK_MIGRATE_TIMER_8814B 0xffff
#define BIT_MIGRATE_TIMER_8814B(x) \
(((x) & BIT_MASK_MIGRATE_TIMER_8814B) << BIT_SHIFT_MIGRATE_TIMER_8814B)
#define BITS_MIGRATE_TIMER_8814B \
(BIT_MASK_MIGRATE_TIMER_8814B << BIT_SHIFT_MIGRATE_TIMER_8814B)
#define BIT_CLEAR_MIGRATE_TIMER_8814B(x) ((x) & (~BITS_MIGRATE_TIMER_8814B))
#define BIT_GET_MIGRATE_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_MIGRATE_TIMER_8814B) & BIT_MASK_MIGRATE_TIMER_8814B)
#define BIT_SET_MIGRATE_TIMER_8814B(x, v) \
(BIT_CLEAR_MIGRATE_TIMER_8814B(x) | BIT_MIGRATE_TIMER_8814B(v))
/* 2 REG_P0MGQ_TXBD_DESA_L_8814B */
/* 2 REG_P0MGQ_TXBD_DESA_H_8814B */
/* 2 REG_ACH0_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH0_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH0_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH0_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH0_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH0_TXBD_DESA_L_8814B)
#define BITS_ACH0_TXBD_DESA_L_8814B \
(BIT_MASK_ACH0_TXBD_DESA_L_8814B << BIT_SHIFT_ACH0_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH0_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH0_TXBD_DESA_L_8814B))
#define BIT_GET_ACH0_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH0_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH0_TXBD_DESA_L_8814B)
#define BIT_SET_ACH0_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH0_TXBD_DESA_L_8814B(x) | BIT_ACH0_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH0_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH0_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH0_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH0_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH0_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH0_TXBD_DESA_H_8814B)
#define BITS_ACH0_TXBD_DESA_H_8814B \
(BIT_MASK_ACH0_TXBD_DESA_H_8814B << BIT_SHIFT_ACH0_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH0_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH0_TXBD_DESA_H_8814B))
#define BIT_GET_ACH0_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH0_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH0_TXBD_DESA_H_8814B)
#define BIT_SET_ACH0_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH0_TXBD_DESA_H_8814B(x) | BIT_ACH0_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH1_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH1_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH1_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH1_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH1_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH1_TXBD_DESA_L_8814B)
#define BITS_ACH1_TXBD_DESA_L_8814B \
(BIT_MASK_ACH1_TXBD_DESA_L_8814B << BIT_SHIFT_ACH1_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH1_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH1_TXBD_DESA_L_8814B))
#define BIT_GET_ACH1_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH1_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH1_TXBD_DESA_L_8814B)
#define BIT_SET_ACH1_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH1_TXBD_DESA_L_8814B(x) | BIT_ACH1_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH1_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH1_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH1_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH1_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH1_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH1_TXBD_DESA_H_8814B)
#define BITS_ACH1_TXBD_DESA_H_8814B \
(BIT_MASK_ACH1_TXBD_DESA_H_8814B << BIT_SHIFT_ACH1_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH1_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH1_TXBD_DESA_H_8814B))
#define BIT_GET_ACH1_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH1_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH1_TXBD_DESA_H_8814B)
#define BIT_SET_ACH1_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH1_TXBD_DESA_H_8814B(x) | BIT_ACH1_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH2_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH2_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH2_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH2_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH2_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH2_TXBD_DESA_L_8814B)
#define BITS_ACH2_TXBD_DESA_L_8814B \
(BIT_MASK_ACH2_TXBD_DESA_L_8814B << BIT_SHIFT_ACH2_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH2_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH2_TXBD_DESA_L_8814B))
#define BIT_GET_ACH2_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH2_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH2_TXBD_DESA_L_8814B)
#define BIT_SET_ACH2_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH2_TXBD_DESA_L_8814B(x) | BIT_ACH2_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH2_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH2_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH2_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH2_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH2_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH2_TXBD_DESA_H_8814B)
#define BITS_ACH2_TXBD_DESA_H_8814B \
(BIT_MASK_ACH2_TXBD_DESA_H_8814B << BIT_SHIFT_ACH2_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH2_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH2_TXBD_DESA_H_8814B))
#define BIT_GET_ACH2_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH2_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH2_TXBD_DESA_H_8814B)
#define BIT_SET_ACH2_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH2_TXBD_DESA_H_8814B(x) | BIT_ACH2_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH3_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH3_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH3_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH3_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH3_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH3_TXBD_DESA_L_8814B)
#define BITS_ACH3_TXBD_DESA_L_8814B \
(BIT_MASK_ACH3_TXBD_DESA_L_8814B << BIT_SHIFT_ACH3_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH3_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH3_TXBD_DESA_L_8814B))
#define BIT_GET_ACH3_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH3_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH3_TXBD_DESA_L_8814B)
#define BIT_SET_ACH3_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH3_TXBD_DESA_L_8814B(x) | BIT_ACH3_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH3_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH3_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH3_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH3_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH3_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH3_TXBD_DESA_H_8814B)
#define BITS_ACH3_TXBD_DESA_H_8814B \
(BIT_MASK_ACH3_TXBD_DESA_H_8814B << BIT_SHIFT_ACH3_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH3_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH3_TXBD_DESA_H_8814B))
#define BIT_GET_ACH3_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH3_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH3_TXBD_DESA_H_8814B)
#define BIT_SET_ACH3_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH3_TXBD_DESA_H_8814B(x) | BIT_ACH3_TXBD_DESA_H_8814B(v))
/* 2 REG_P0RXQ_RXBD_DESA_L_8814B */
#define BIT_SHIFT_P0RXQ_RXBD_DESA_L_8814B 0
#define BIT_MASK_P0RXQ_RXBD_DESA_L_8814B 0xffffffffL
#define BIT_P0RXQ_RXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_P0RXQ_RXBD_DESA_L_8814B) \
<< BIT_SHIFT_P0RXQ_RXBD_DESA_L_8814B)
#define BITS_P0RXQ_RXBD_DESA_L_8814B \
(BIT_MASK_P0RXQ_RXBD_DESA_L_8814B << BIT_SHIFT_P0RXQ_RXBD_DESA_L_8814B)
#define BIT_CLEAR_P0RXQ_RXBD_DESA_L_8814B(x) \
((x) & (~BITS_P0RXQ_RXBD_DESA_L_8814B))
#define BIT_GET_P0RXQ_RXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_P0RXQ_RXBD_DESA_L_8814B) & \
BIT_MASK_P0RXQ_RXBD_DESA_L_8814B)
#define BIT_SET_P0RXQ_RXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_P0RXQ_RXBD_DESA_L_8814B(x) | BIT_P0RXQ_RXBD_DESA_L_8814B(v))
/* 2 REG_P0RXQ_RXBD_DESA_H_8814B */
#define BIT_SHIFT_P0RXQ_RXBD_DESA_H_8814B 0
#define BIT_MASK_P0RXQ_RXBD_DESA_H_8814B 0xffffffffL
#define BIT_P0RXQ_RXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_P0RXQ_RXBD_DESA_H_8814B) \
<< BIT_SHIFT_P0RXQ_RXBD_DESA_H_8814B)
#define BITS_P0RXQ_RXBD_DESA_H_8814B \
(BIT_MASK_P0RXQ_RXBD_DESA_H_8814B << BIT_SHIFT_P0RXQ_RXBD_DESA_H_8814B)
#define BIT_CLEAR_P0RXQ_RXBD_DESA_H_8814B(x) \
((x) & (~BITS_P0RXQ_RXBD_DESA_H_8814B))
#define BIT_GET_P0RXQ_RXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_P0RXQ_RXBD_DESA_H_8814B) & \
BIT_MASK_P0RXQ_RXBD_DESA_H_8814B)
#define BIT_SET_P0RXQ_RXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_P0RXQ_RXBD_DESA_H_8814B(x) | BIT_P0RXQ_RXBD_DESA_H_8814B(v))
/* 2 REG_P0BCNQ_TXBD_DESA_L_8814B */
#define BIT_SHIFT_P0BCNQ_TXBD_DESA_L_8814B 0
#define BIT_MASK_P0BCNQ_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_P0BCNQ_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_P0BCNQ_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_P0BCNQ_TXBD_DESA_L_8814B)
#define BITS_P0BCNQ_TXBD_DESA_L_8814B \
(BIT_MASK_P0BCNQ_TXBD_DESA_L_8814B \
<< BIT_SHIFT_P0BCNQ_TXBD_DESA_L_8814B)
#define BIT_CLEAR_P0BCNQ_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_P0BCNQ_TXBD_DESA_L_8814B))
#define BIT_GET_P0BCNQ_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_P0BCNQ_TXBD_DESA_L_8814B) & \
BIT_MASK_P0BCNQ_TXBD_DESA_L_8814B)
#define BIT_SET_P0BCNQ_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_P0BCNQ_TXBD_DESA_L_8814B(x) | \
BIT_P0BCNQ_TXBD_DESA_L_8814B(v))
/* 2 REG_P0BCNQ_TXBD_DESA_H_8814B */
#define BIT_SHIFT_P0BCNQ_TXBD_DESA_H_8814B 0
#define BIT_MASK_P0BCNQ_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_P0BCNQ_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_P0BCNQ_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_P0BCNQ_TXBD_DESA_H_8814B)
#define BITS_P0BCNQ_TXBD_DESA_H_8814B \
(BIT_MASK_P0BCNQ_TXBD_DESA_H_8814B \
<< BIT_SHIFT_P0BCNQ_TXBD_DESA_H_8814B)
#define BIT_CLEAR_P0BCNQ_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_P0BCNQ_TXBD_DESA_H_8814B))
#define BIT_GET_P0BCNQ_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_P0BCNQ_TXBD_DESA_H_8814B) & \
BIT_MASK_P0BCNQ_TXBD_DESA_H_8814B)
#define BIT_SET_P0BCNQ_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_P0BCNQ_TXBD_DESA_H_8814B(x) | \
BIT_P0BCNQ_TXBD_DESA_H_8814B(v))
/* 2 REG_FWCMDQ_TXBD_DESA_L_8814B */
#define BIT_SHIFT_FWCMDQ_TXBD_DESA_L_8814B 0
#define BIT_MASK_FWCMDQ_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_FWCMDQ_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_FWCMDQ_TXBD_DESA_L_8814B)
#define BITS_FWCMDQ_TXBD_DESA_L_8814B \
(BIT_MASK_FWCMDQ_TXBD_DESA_L_8814B \
<< BIT_SHIFT_FWCMDQ_TXBD_DESA_L_8814B)
#define BIT_CLEAR_FWCMDQ_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_FWCMDQ_TXBD_DESA_L_8814B))
#define BIT_GET_FWCMDQ_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TXBD_DESA_L_8814B) & \
BIT_MASK_FWCMDQ_TXBD_DESA_L_8814B)
#define BIT_SET_FWCMDQ_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_TXBD_DESA_L_8814B(x) | \
BIT_FWCMDQ_TXBD_DESA_L_8814B(v))
/* 2 REG_FWCMDQ_TXBD_DESA_H_8814B */
#define BIT_SHIFT_FWCMDQ_TXBD_DESA_H_8814B 0
#define BIT_MASK_FWCMDQ_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_FWCMDQ_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_FWCMDQ_TXBD_DESA_H_8814B)
#define BITS_FWCMDQ_TXBD_DESA_H_8814B \
(BIT_MASK_FWCMDQ_TXBD_DESA_H_8814B \
<< BIT_SHIFT_FWCMDQ_TXBD_DESA_H_8814B)
#define BIT_CLEAR_FWCMDQ_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_FWCMDQ_TXBD_DESA_H_8814B))
#define BIT_GET_FWCMDQ_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TXBD_DESA_H_8814B) & \
BIT_MASK_FWCMDQ_TXBD_DESA_H_8814B)
#define BIT_SET_FWCMDQ_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_TXBD_DESA_H_8814B(x) | \
BIT_FWCMDQ_TXBD_DESA_H_8814B(v))
/* 2 REG_PCIE_HRPWM1_HCPWM1_DCPU_8814B */
#define BIT_SHIFT_PCIE_HCPWM1_DCPU_8814B 16
#define BIT_MASK_PCIE_HCPWM1_DCPU_8814B 0xff
#define BIT_PCIE_HCPWM1_DCPU_8814B(x) \
(((x) & BIT_MASK_PCIE_HCPWM1_DCPU_8814B) \
<< BIT_SHIFT_PCIE_HCPWM1_DCPU_8814B)
#define BITS_PCIE_HCPWM1_DCPU_8814B \
(BIT_MASK_PCIE_HCPWM1_DCPU_8814B << BIT_SHIFT_PCIE_HCPWM1_DCPU_8814B)
#define BIT_CLEAR_PCIE_HCPWM1_DCPU_8814B(x) \
((x) & (~BITS_PCIE_HCPWM1_DCPU_8814B))
#define BIT_GET_PCIE_HCPWM1_DCPU_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM1_DCPU_8814B) & \
BIT_MASK_PCIE_HCPWM1_DCPU_8814B)
#define BIT_SET_PCIE_HCPWM1_DCPU_8814B(x, v) \
(BIT_CLEAR_PCIE_HCPWM1_DCPU_8814B(x) | BIT_PCIE_HCPWM1_DCPU_8814B(v))
#define BIT_SHIFT_PCIE_HRPWM1_DCPU_8814B 8
#define BIT_MASK_PCIE_HRPWM1_DCPU_8814B 0xff
#define BIT_PCIE_HRPWM1_DCPU_8814B(x) \
(((x) & BIT_MASK_PCIE_HRPWM1_DCPU_8814B) \
<< BIT_SHIFT_PCIE_HRPWM1_DCPU_8814B)
#define BITS_PCIE_HRPWM1_DCPU_8814B \
(BIT_MASK_PCIE_HRPWM1_DCPU_8814B << BIT_SHIFT_PCIE_HRPWM1_DCPU_8814B)
#define BIT_CLEAR_PCIE_HRPWM1_DCPU_8814B(x) \
((x) & (~BITS_PCIE_HRPWM1_DCPU_8814B))
#define BIT_GET_PCIE_HRPWM1_DCPU_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM1_DCPU_8814B) & \
BIT_MASK_PCIE_HRPWM1_DCPU_8814B)
#define BIT_SET_PCIE_HRPWM1_DCPU_8814B(x, v) \
(BIT_CLEAR_PCIE_HRPWM1_DCPU_8814B(x) | BIT_PCIE_HRPWM1_DCPU_8814B(v))
/* 2 REG_P0_MPRT_BCNQ_TXBD_DESA_L_8814B */
#define BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L_8814B 0
#define BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_P0_MPRT_BCNQ_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L_8814B)
#define BITS_P0_MPRT_BCNQ_TXBD_DESA_L_8814B \
(BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L_8814B \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L_8814B)
#define BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_P0_MPRT_BCNQ_TXBD_DESA_L_8814B))
#define BIT_GET_P0_MPRT_BCNQ_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_L_8814B) & \
BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_L_8814B)
#define BIT_SET_P0_MPRT_BCNQ_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_L_8814B(x) | \
BIT_P0_MPRT_BCNQ_TXBD_DESA_L_8814B(v))
/* 2 REG_P0_MPRT_BCNQ_TXBD_DESA_H_8814B */
#define BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H_8814B 0
#define BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_P0_MPRT_BCNQ_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H_8814B)
#define BITS_P0_MPRT_BCNQ_TXBD_DESA_H_8814B \
(BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H_8814B \
<< BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H_8814B)
#define BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_P0_MPRT_BCNQ_TXBD_DESA_H_8814B))
#define BIT_GET_P0_MPRT_BCNQ_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_P0_MPRT_BCNQ_TXBD_DESA_H_8814B) & \
BIT_MASK_P0_MPRT_BCNQ_TXBD_DESA_H_8814B)
#define BIT_SET_P0_MPRT_BCNQ_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_P0_MPRT_BCNQ_TXBD_DESA_H_8814B(x) | \
BIT_P0_MPRT_BCNQ_TXBD_DESA_H_8814B(v))
/* 2 REG_P0_MPRT_BCNQ_TXRXBD_NUM_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE_8814B 13
#define BIT_MASK_P0_MPRT_BCNQ_DESC_MODE_8814B 0x3
#define BIT_P0_MPRT_BCNQ_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0_MPRT_BCNQ_DESC_MODE_8814B) \
<< BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE_8814B)
#define BITS_P0_MPRT_BCNQ_DESC_MODE_8814B \
(BIT_MASK_P0_MPRT_BCNQ_DESC_MODE_8814B \
<< BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE_8814B)
#define BIT_CLEAR_P0_MPRT_BCNQ_DESC_MODE_8814B(x) \
((x) & (~BITS_P0_MPRT_BCNQ_DESC_MODE_8814B))
#define BIT_GET_P0_MPRT_BCNQ_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0_MPRT_BCNQ_DESC_MODE_8814B) & \
BIT_MASK_P0_MPRT_BCNQ_DESC_MODE_8814B)
#define BIT_SET_P0_MPRT_BCNQ_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0_MPRT_BCNQ_DESC_MODE_8814B(x) | \
BIT_P0_MPRT_BCNQ_DESC_MODE_8814B(v))
#define BIT_PCIE_P0MPRT_BCNQ4_FLAG_8814B BIT(11)
#define BIT_PCIE_P0MPRT_BCNQ3_FLAG_8814B BIT(10)
#define BIT_PCIE_P0MPRT_BCNQ2_FLAG_8814B BIT(9)
#define BIT_PCIE_P0MPRT_BCNQ1_FLAG_8814B BIT(8)
#define BIT_EPHY_CAL_DONE_8814B BIT(1)
#define BIT_RESET_APHY_8814B BIT(0)
/* 2 REG_BD_RWPTR_CLR2_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_ACH7_HW_IDX_8814B BIT(21)
#define BIT_CLR_ACH6_HW_IDX_8814B BIT(20)
#define BIT_CLR_ACH5_HW_IDX_8814B BIT(19)
#define BIT_CLR_ACH4_HW_IDX_8814B BIT(18)
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_ACH7_HOST_IDX_8814B BIT(5)
#define BIT_CLR_ACH6_HOST_IDX_8814B BIT(4)
#define BIT_CLR_ACH5_HOST_IDX_8814B BIT(3)
#define BIT_CLR_ACH4_HOST_IDX_8814B BIT(2)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_BD_RWPTR_CLR3_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_P0HI15Q_HW_IDX_8814B BIT(29)
#define BIT_CLR_P0HI14Q_HW_IDX_8814B BIT(28)
#define BIT_CLR_P0HI13Q_HW_IDX_8814B BIT(27)
#define BIT_CLR_P0HI12Q_HW_IDX_8814B BIT(26)
#define BIT_CLR_P0HI11Q_HW_IDX_8814B BIT(25)
#define BIT_CLR_P0HI10Q_HW_IDX_8814B BIT(24)
#define BIT_CLR_P0HI9Q_HW_IDX_8814B BIT(23)
#define BIT_CLR_P0HI8Q_HW_IDX_8814B BIT(22)
#define BIT_CLR_ACH13_HW_IDX_8814B BIT(21)
#define BIT_CLR_ACH12_HW_IDX_8814B BIT(20)
#define BIT_CLR_ACH11_HW_IDX_8814B BIT(19)
#define BIT_CLR_ACH10_HW_IDX_8814B BIT(18)
#define BIT_CLR_ACH9_HW_IDX_8814B BIT(17)
#define BIT_CLR_ACH8_HW_IDX_8814B BIT(16)
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_P0HI15Q_HOST_IDX_8814B BIT(13)
#define BIT_CLR_P0HI14Q_HOST_IDX_8814B BIT(12)
#define BIT_CLR_P0HI13Q_HOST_IDX_8814B BIT(11)
#define BIT_CLR_P0HI12Q_HOST_IDX_8814B BIT(10)
#define BIT_CLR_P0HI11Q_HOST_IDX_8814B BIT(9)
#define BIT_CLR_P0HI10Q_HOST_IDX_8814B BIT(8)
#define BIT_CLR_P0HI9Q_HOST_IDX_8814B BIT(7)
#define BIT_CLR_P0HI8Q_HOST_IDX_8814B BIT(6)
#define BIT_CLR_ACH13_HOST_IDX_8814B BIT(5)
#define BIT_CLR_ACH12_HOST_IDX_8814B BIT(4)
#define BIT_CLR_ACH11_HOST_IDX_8814B BIT(3)
#define BIT_CLR_ACH10_HOST_IDX_8814B BIT(2)
#define BIT_CLR_ACH9_HOST_IDX_8814B BIT(1)
#define BIT_CLR_ACH8_HOST_IDX_8814B BIT(0)
/* 2 REG_P0MGQ_RXQ_TXRXBD_NUM_8814B */
#define BIT_SYS_32_64_V1_8814B BIT(31)
#define BIT_SHIFT_P0BCNQ_DESC_MODE_8814B 29
#define BIT_MASK_P0BCNQ_DESC_MODE_8814B 0x3
#define BIT_P0BCNQ_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0BCNQ_DESC_MODE_8814B) \
<< BIT_SHIFT_P0BCNQ_DESC_MODE_8814B)
#define BITS_P0BCNQ_DESC_MODE_8814B \
(BIT_MASK_P0BCNQ_DESC_MODE_8814B << BIT_SHIFT_P0BCNQ_DESC_MODE_8814B)
#define BIT_CLEAR_P0BCNQ_DESC_MODE_8814B(x) \
((x) & (~BITS_P0BCNQ_DESC_MODE_8814B))
#define BIT_GET_P0BCNQ_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0BCNQ_DESC_MODE_8814B) & \
BIT_MASK_P0BCNQ_DESC_MODE_8814B)
#define BIT_SET_P0BCNQ_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0BCNQ_DESC_MODE_8814B(x) | BIT_P0BCNQ_DESC_MODE_8814B(v))
#define BIT_PCIE_P0BCNQ_FLAG_8814B BIT(28)
#define BIT_SHIFT_P0RXQ_DESC_NUM_8814B 16
#define BIT_MASK_P0RXQ_DESC_NUM_8814B 0xfff
#define BIT_P0RXQ_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0RXQ_DESC_NUM_8814B) \
<< BIT_SHIFT_P0RXQ_DESC_NUM_8814B)
#define BITS_P0RXQ_DESC_NUM_8814B \
(BIT_MASK_P0RXQ_DESC_NUM_8814B << BIT_SHIFT_P0RXQ_DESC_NUM_8814B)
#define BIT_CLEAR_P0RXQ_DESC_NUM_8814B(x) ((x) & (~BITS_P0RXQ_DESC_NUM_8814B))
#define BIT_GET_P0RXQ_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0RXQ_DESC_NUM_8814B) & \
BIT_MASK_P0RXQ_DESC_NUM_8814B)
#define BIT_SET_P0RXQ_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0RXQ_DESC_NUM_8814B(x) | BIT_P0RXQ_DESC_NUM_8814B(v))
#define BIT_PCIE_P0MGQ_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0MGQ_DESC_MODE_8814B 12
#define BIT_MASK_P0MGQ_DESC_MODE_8814B 0x3
#define BIT_P0MGQ_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0MGQ_DESC_MODE_8814B) \
<< BIT_SHIFT_P0MGQ_DESC_MODE_8814B)
#define BITS_P0MGQ_DESC_MODE_8814B \
(BIT_MASK_P0MGQ_DESC_MODE_8814B << BIT_SHIFT_P0MGQ_DESC_MODE_8814B)
#define BIT_CLEAR_P0MGQ_DESC_MODE_8814B(x) ((x) & (~BITS_P0MGQ_DESC_MODE_8814B))
#define BIT_GET_P0MGQ_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0MGQ_DESC_MODE_8814B) & \
BIT_MASK_P0MGQ_DESC_MODE_8814B)
#define BIT_SET_P0MGQ_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0MGQ_DESC_MODE_8814B(x) | BIT_P0MGQ_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0MGQ_DESC_NUM_8814B 0
#define BIT_MASK_P0MGQ_DESC_NUM_8814B 0xfff
#define BIT_P0MGQ_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0MGQ_DESC_NUM_8814B) \
<< BIT_SHIFT_P0MGQ_DESC_NUM_8814B)
#define BITS_P0MGQ_DESC_NUM_8814B \
(BIT_MASK_P0MGQ_DESC_NUM_8814B << BIT_SHIFT_P0MGQ_DESC_NUM_8814B)
#define BIT_CLEAR_P0MGQ_DESC_NUM_8814B(x) ((x) & (~BITS_P0MGQ_DESC_NUM_8814B))
#define BIT_GET_P0MGQ_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0MGQ_DESC_NUM_8814B) & \
BIT_MASK_P0MGQ_DESC_NUM_8814B)
#define BIT_SET_P0MGQ_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0MGQ_DESC_NUM_8814B(x) | BIT_P0MGQ_DESC_NUM_8814B(v))
/* 2 REG_CHNL_DMA_CFG_8814B */
#define BIT_TXHCI_EN_8814B BIT(26)
#define BIT_TXHCI_IDLE_8814B BIT(25)
#define BIT_DMA_PRI_EN_8814B BIT(24)
/* 2 REG_FWCMDQ_TXBD_NUM_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_PCIE_FWCMDQ_FLAG_8814B BIT(14)
#define BIT_SHIFT_FWCMDQ_DESC_MODE_8814B 12
#define BIT_MASK_FWCMDQ_DESC_MODE_8814B 0x3
#define BIT_FWCMDQ_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_DESC_MODE_8814B) \
<< BIT_SHIFT_FWCMDQ_DESC_MODE_8814B)
#define BITS_FWCMDQ_DESC_MODE_8814B \
(BIT_MASK_FWCMDQ_DESC_MODE_8814B << BIT_SHIFT_FWCMDQ_DESC_MODE_8814B)
#define BIT_CLEAR_FWCMDQ_DESC_MODE_8814B(x) \
((x) & (~BITS_FWCMDQ_DESC_MODE_8814B))
#define BIT_GET_FWCMDQ_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_DESC_MODE_8814B) & \
BIT_MASK_FWCMDQ_DESC_MODE_8814B)
#define BIT_SET_FWCMDQ_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_DESC_MODE_8814B(x) | BIT_FWCMDQ_DESC_MODE_8814B(v))
#define BIT_SHIFT_FWCMDQ_DESC_NUM_8814B 0
#define BIT_MASK_FWCMDQ_DESC_NUM_8814B 0xfff
#define BIT_FWCMDQ_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_DESC_NUM_8814B) \
<< BIT_SHIFT_FWCMDQ_DESC_NUM_8814B)
#define BITS_FWCMDQ_DESC_NUM_8814B \
(BIT_MASK_FWCMDQ_DESC_NUM_8814B << BIT_SHIFT_FWCMDQ_DESC_NUM_8814B)
#define BIT_CLEAR_FWCMDQ_DESC_NUM_8814B(x) ((x) & (~BITS_FWCMDQ_DESC_NUM_8814B))
#define BIT_GET_FWCMDQ_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_DESC_NUM_8814B) & \
BIT_MASK_FWCMDQ_DESC_NUM_8814B)
#define BIT_SET_FWCMDQ_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_DESC_NUM_8814B(x) | BIT_FWCMDQ_DESC_NUM_8814B(v))
/* 2 REG_ACH0_ACH1_TXBD_NUM_8814B */
#define BIT_PCIE_ACH1_FLAG_V1_8814B BIT(30)
#define BIT_SHIFT_ACH1_DESC_MODE_V1_8814B 28
#define BIT_MASK_ACH1_DESC_MODE_V1_8814B 0x3
#define BIT_ACH1_DESC_MODE_V1_8814B(x) \
(((x) & BIT_MASK_ACH1_DESC_MODE_V1_8814B) \
<< BIT_SHIFT_ACH1_DESC_MODE_V1_8814B)
#define BITS_ACH1_DESC_MODE_V1_8814B \
(BIT_MASK_ACH1_DESC_MODE_V1_8814B << BIT_SHIFT_ACH1_DESC_MODE_V1_8814B)
#define BIT_CLEAR_ACH1_DESC_MODE_V1_8814B(x) \
((x) & (~BITS_ACH1_DESC_MODE_V1_8814B))
#define BIT_GET_ACH1_DESC_MODE_V1_8814B(x) \
(((x) >> BIT_SHIFT_ACH1_DESC_MODE_V1_8814B) & \
BIT_MASK_ACH1_DESC_MODE_V1_8814B)
#define BIT_SET_ACH1_DESC_MODE_V1_8814B(x, v) \
(BIT_CLEAR_ACH1_DESC_MODE_V1_8814B(x) | BIT_ACH1_DESC_MODE_V1_8814B(v))
#define BIT_SHIFT_ACH1_DESC_NUM_V1_8814B 16
#define BIT_MASK_ACH1_DESC_NUM_V1_8814B 0xfff
#define BIT_ACH1_DESC_NUM_V1_8814B(x) \
(((x) & BIT_MASK_ACH1_DESC_NUM_V1_8814B) \
<< BIT_SHIFT_ACH1_DESC_NUM_V1_8814B)
#define BITS_ACH1_DESC_NUM_V1_8814B \
(BIT_MASK_ACH1_DESC_NUM_V1_8814B << BIT_SHIFT_ACH1_DESC_NUM_V1_8814B)
#define BIT_CLEAR_ACH1_DESC_NUM_V1_8814B(x) \
((x) & (~BITS_ACH1_DESC_NUM_V1_8814B))
#define BIT_GET_ACH1_DESC_NUM_V1_8814B(x) \
(((x) >> BIT_SHIFT_ACH1_DESC_NUM_V1_8814B) & \
BIT_MASK_ACH1_DESC_NUM_V1_8814B)
#define BIT_SET_ACH1_DESC_NUM_V1_8814B(x, v) \
(BIT_CLEAR_ACH1_DESC_NUM_V1_8814B(x) | BIT_ACH1_DESC_NUM_V1_8814B(v))
#define BIT_PCIE_ACH0_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH0_DESC_MODE_8814B 12
#define BIT_MASK_ACH0_DESC_MODE_8814B 0x3
#define BIT_ACH0_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH0_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH0_DESC_MODE_8814B)
#define BITS_ACH0_DESC_MODE_8814B \
(BIT_MASK_ACH0_DESC_MODE_8814B << BIT_SHIFT_ACH0_DESC_MODE_8814B)
#define BIT_CLEAR_ACH0_DESC_MODE_8814B(x) ((x) & (~BITS_ACH0_DESC_MODE_8814B))
#define BIT_GET_ACH0_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH0_DESC_MODE_8814B) & \
BIT_MASK_ACH0_DESC_MODE_8814B)
#define BIT_SET_ACH0_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH0_DESC_MODE_8814B(x) | BIT_ACH0_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH0_DESC_NUM_8814B 0
#define BIT_MASK_ACH0_DESC_NUM_8814B 0xfff
#define BIT_ACH0_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH0_DESC_NUM_8814B) << BIT_SHIFT_ACH0_DESC_NUM_8814B)
#define BITS_ACH0_DESC_NUM_8814B \
(BIT_MASK_ACH0_DESC_NUM_8814B << BIT_SHIFT_ACH0_DESC_NUM_8814B)
#define BIT_CLEAR_ACH0_DESC_NUM_8814B(x) ((x) & (~BITS_ACH0_DESC_NUM_8814B))
#define BIT_GET_ACH0_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH0_DESC_NUM_8814B) & BIT_MASK_ACH0_DESC_NUM_8814B)
#define BIT_SET_ACH0_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH0_DESC_NUM_8814B(x) | BIT_ACH0_DESC_NUM_8814B(v))
/* 2 REG_ACH2_ACH3_TXBD_NUM_8814B */
#define BIT_PCIE_ACH3_FLAG_V1_8814B BIT(30)
#define BIT_SHIFT_ACH3_DESC_MODE_V1_8814B 28
#define BIT_MASK_ACH3_DESC_MODE_V1_8814B 0x3
#define BIT_ACH3_DESC_MODE_V1_8814B(x) \
(((x) & BIT_MASK_ACH3_DESC_MODE_V1_8814B) \
<< BIT_SHIFT_ACH3_DESC_MODE_V1_8814B)
#define BITS_ACH3_DESC_MODE_V1_8814B \
(BIT_MASK_ACH3_DESC_MODE_V1_8814B << BIT_SHIFT_ACH3_DESC_MODE_V1_8814B)
#define BIT_CLEAR_ACH3_DESC_MODE_V1_8814B(x) \
((x) & (~BITS_ACH3_DESC_MODE_V1_8814B))
#define BIT_GET_ACH3_DESC_MODE_V1_8814B(x) \
(((x) >> BIT_SHIFT_ACH3_DESC_MODE_V1_8814B) & \
BIT_MASK_ACH3_DESC_MODE_V1_8814B)
#define BIT_SET_ACH3_DESC_MODE_V1_8814B(x, v) \
(BIT_CLEAR_ACH3_DESC_MODE_V1_8814B(x) | BIT_ACH3_DESC_MODE_V1_8814B(v))
#define BIT_SHIFT_ACH3_DESC_NUM_V1_8814B 16
#define BIT_MASK_ACH3_DESC_NUM_V1_8814B 0xfff
#define BIT_ACH3_DESC_NUM_V1_8814B(x) \
(((x) & BIT_MASK_ACH3_DESC_NUM_V1_8814B) \
<< BIT_SHIFT_ACH3_DESC_NUM_V1_8814B)
#define BITS_ACH3_DESC_NUM_V1_8814B \
(BIT_MASK_ACH3_DESC_NUM_V1_8814B << BIT_SHIFT_ACH3_DESC_NUM_V1_8814B)
#define BIT_CLEAR_ACH3_DESC_NUM_V1_8814B(x) \
((x) & (~BITS_ACH3_DESC_NUM_V1_8814B))
#define BIT_GET_ACH3_DESC_NUM_V1_8814B(x) \
(((x) >> BIT_SHIFT_ACH3_DESC_NUM_V1_8814B) & \
BIT_MASK_ACH3_DESC_NUM_V1_8814B)
#define BIT_SET_ACH3_DESC_NUM_V1_8814B(x, v) \
(BIT_CLEAR_ACH3_DESC_NUM_V1_8814B(x) | BIT_ACH3_DESC_NUM_V1_8814B(v))
#define BIT_PCIE_ACH2_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH2_DESC_MODE_8814B 12
#define BIT_MASK_ACH2_DESC_MODE_8814B 0x3
#define BIT_ACH2_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH2_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH2_DESC_MODE_8814B)
#define BITS_ACH2_DESC_MODE_8814B \
(BIT_MASK_ACH2_DESC_MODE_8814B << BIT_SHIFT_ACH2_DESC_MODE_8814B)
#define BIT_CLEAR_ACH2_DESC_MODE_8814B(x) ((x) & (~BITS_ACH2_DESC_MODE_8814B))
#define BIT_GET_ACH2_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH2_DESC_MODE_8814B) & \
BIT_MASK_ACH2_DESC_MODE_8814B)
#define BIT_SET_ACH2_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH2_DESC_MODE_8814B(x) | BIT_ACH2_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH2_DESC_NUM_8814B 0
#define BIT_MASK_ACH2_DESC_NUM_8814B 0xfff
#define BIT_ACH2_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH2_DESC_NUM_8814B) << BIT_SHIFT_ACH2_DESC_NUM_8814B)
#define BITS_ACH2_DESC_NUM_8814B \
(BIT_MASK_ACH2_DESC_NUM_8814B << BIT_SHIFT_ACH2_DESC_NUM_8814B)
#define BIT_CLEAR_ACH2_DESC_NUM_8814B(x) ((x) & (~BITS_ACH2_DESC_NUM_8814B))
#define BIT_GET_ACH2_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH2_DESC_NUM_8814B) & BIT_MASK_ACH2_DESC_NUM_8814B)
#define BIT_SET_ACH2_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH2_DESC_NUM_8814B(x) | BIT_ACH2_DESC_NUM_8814B(v))
/* 2 REG_P0HI0Q_HI1Q_TXBD_NUM_8814B */
#define BIT_P0HI1Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI1Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI1Q_DESC_MODE_8814B 0x3
#define BIT_P0HI1Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI1Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI1Q_DESC_MODE_8814B)
#define BITS_P0HI1Q_DESC_MODE_8814B \
(BIT_MASK_P0HI1Q_DESC_MODE_8814B << BIT_SHIFT_P0HI1Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI1Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI1Q_DESC_MODE_8814B))
#define BIT_GET_P0HI1Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI1Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI1Q_DESC_MODE_8814B)
#define BIT_SET_P0HI1Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI1Q_DESC_MODE_8814B(x) | BIT_P0HI1Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI1Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI1Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI1Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI1Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI1Q_DESC_NUM_8814B)
#define BITS_P0HI1Q_DESC_NUM_8814B \
(BIT_MASK_P0HI1Q_DESC_NUM_8814B << BIT_SHIFT_P0HI1Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI1Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI1Q_DESC_NUM_8814B))
#define BIT_GET_P0HI1Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI1Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI1Q_DESC_NUM_8814B)
#define BIT_SET_P0HI1Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI1Q_DESC_NUM_8814B(x) | BIT_P0HI1Q_DESC_NUM_8814B(v))
#define BIT_P0HI0Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI0Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI0Q_DESC_MODE_8814B 0x3
#define BIT_P0HI0Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI0Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI0Q_DESC_MODE_8814B)
#define BITS_P0HI0Q_DESC_MODE_8814B \
(BIT_MASK_P0HI0Q_DESC_MODE_8814B << BIT_SHIFT_P0HI0Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI0Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI0Q_DESC_MODE_8814B))
#define BIT_GET_P0HI0Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI0Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI0Q_DESC_MODE_8814B)
#define BIT_SET_P0HI0Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI0Q_DESC_MODE_8814B(x) | BIT_P0HI0Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI0Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI0Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI0Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI0Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI0Q_DESC_NUM_8814B)
#define BITS_P0HI0Q_DESC_NUM_8814B \
(BIT_MASK_P0HI0Q_DESC_NUM_8814B << BIT_SHIFT_P0HI0Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI0Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI0Q_DESC_NUM_8814B))
#define BIT_GET_P0HI0Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI0Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI0Q_DESC_NUM_8814B)
#define BIT_SET_P0HI0Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI0Q_DESC_NUM_8814B(x) | BIT_P0HI0Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI2Q_HI3Q_TXBD_NUM_8814B */
#define BIT_P0HI3Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI3Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI3Q_DESC_MODE_8814B 0x3
#define BIT_P0HI3Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI3Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI3Q_DESC_MODE_8814B)
#define BITS_P0HI3Q_DESC_MODE_8814B \
(BIT_MASK_P0HI3Q_DESC_MODE_8814B << BIT_SHIFT_P0HI3Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI3Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI3Q_DESC_MODE_8814B))
#define BIT_GET_P0HI3Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI3Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI3Q_DESC_MODE_8814B)
#define BIT_SET_P0HI3Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI3Q_DESC_MODE_8814B(x) | BIT_P0HI3Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI3Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI3Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI3Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI3Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI3Q_DESC_NUM_8814B)
#define BITS_P0HI3Q_DESC_NUM_8814B \
(BIT_MASK_P0HI3Q_DESC_NUM_8814B << BIT_SHIFT_P0HI3Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI3Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI3Q_DESC_NUM_8814B))
#define BIT_GET_P0HI3Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI3Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI3Q_DESC_NUM_8814B)
#define BIT_SET_P0HI3Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI3Q_DESC_NUM_8814B(x) | BIT_P0HI3Q_DESC_NUM_8814B(v))
#define BIT_P0HI2Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI2Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI2Q_DESC_MODE_8814B 0x3
#define BIT_P0HI2Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI2Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI2Q_DESC_MODE_8814B)
#define BITS_P0HI2Q_DESC_MODE_8814B \
(BIT_MASK_P0HI2Q_DESC_MODE_8814B << BIT_SHIFT_P0HI2Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI2Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI2Q_DESC_MODE_8814B))
#define BIT_GET_P0HI2Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI2Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI2Q_DESC_MODE_8814B)
#define BIT_SET_P0HI2Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI2Q_DESC_MODE_8814B(x) | BIT_P0HI2Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI2Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI2Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI2Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI2Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI2Q_DESC_NUM_8814B)
#define BITS_P0HI2Q_DESC_NUM_8814B \
(BIT_MASK_P0HI2Q_DESC_NUM_8814B << BIT_SHIFT_P0HI2Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI2Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI2Q_DESC_NUM_8814B))
#define BIT_GET_P0HI2Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI2Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI2Q_DESC_NUM_8814B)
#define BIT_SET_P0HI2Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI2Q_DESC_NUM_8814B(x) | BIT_P0HI2Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI4Q_HI5Q_TXBD_NUM_8814B */
#define BIT_P0HI5Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI5Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI5Q_DESC_MODE_8814B 0x3
#define BIT_P0HI5Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI5Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI5Q_DESC_MODE_8814B)
#define BITS_P0HI5Q_DESC_MODE_8814B \
(BIT_MASK_P0HI5Q_DESC_MODE_8814B << BIT_SHIFT_P0HI5Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI5Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI5Q_DESC_MODE_8814B))
#define BIT_GET_P0HI5Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI5Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI5Q_DESC_MODE_8814B)
#define BIT_SET_P0HI5Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI5Q_DESC_MODE_8814B(x) | BIT_P0HI5Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI5Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI5Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI5Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI5Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI5Q_DESC_NUM_8814B)
#define BITS_P0HI5Q_DESC_NUM_8814B \
(BIT_MASK_P0HI5Q_DESC_NUM_8814B << BIT_SHIFT_P0HI5Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI5Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI5Q_DESC_NUM_8814B))
#define BIT_GET_P0HI5Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI5Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI5Q_DESC_NUM_8814B)
#define BIT_SET_P0HI5Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI5Q_DESC_NUM_8814B(x) | BIT_P0HI5Q_DESC_NUM_8814B(v))
#define BIT_P0HI4Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI4Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI4Q_DESC_MODE_8814B 0x3
#define BIT_P0HI4Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI4Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI4Q_DESC_MODE_8814B)
#define BITS_P0HI4Q_DESC_MODE_8814B \
(BIT_MASK_P0HI4Q_DESC_MODE_8814B << BIT_SHIFT_P0HI4Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI4Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI4Q_DESC_MODE_8814B))
#define BIT_GET_P0HI4Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI4Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI4Q_DESC_MODE_8814B)
#define BIT_SET_P0HI4Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI4Q_DESC_MODE_8814B(x) | BIT_P0HI4Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI4Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI4Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI4Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI4Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI4Q_DESC_NUM_8814B)
#define BITS_P0HI4Q_DESC_NUM_8814B \
(BIT_MASK_P0HI4Q_DESC_NUM_8814B << BIT_SHIFT_P0HI4Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI4Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI4Q_DESC_NUM_8814B))
#define BIT_GET_P0HI4Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI4Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI4Q_DESC_NUM_8814B)
#define BIT_SET_P0HI4Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI4Q_DESC_NUM_8814B(x) | BIT_P0HI4Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI6Q_HI7Q_TXBD_NUM_8814B */
#define BIT_P0HI7Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI7Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI7Q_DESC_MODE_8814B 0x3
#define BIT_P0HI7Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI7Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI7Q_DESC_MODE_8814B)
#define BITS_P0HI7Q_DESC_MODE_8814B \
(BIT_MASK_P0HI7Q_DESC_MODE_8814B << BIT_SHIFT_P0HI7Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI7Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI7Q_DESC_MODE_8814B))
#define BIT_GET_P0HI7Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI7Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI7Q_DESC_MODE_8814B)
#define BIT_SET_P0HI7Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI7Q_DESC_MODE_8814B(x) | BIT_P0HI7Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI7Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI7Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI7Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI7Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI7Q_DESC_NUM_8814B)
#define BITS_P0HI7Q_DESC_NUM_8814B \
(BIT_MASK_P0HI7Q_DESC_NUM_8814B << BIT_SHIFT_P0HI7Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI7Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI7Q_DESC_NUM_8814B))
#define BIT_GET_P0HI7Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI7Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI7Q_DESC_NUM_8814B)
#define BIT_SET_P0HI7Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI7Q_DESC_NUM_8814B(x) | BIT_P0HI7Q_DESC_NUM_8814B(v))
#define BIT_P0HI6Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI6Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI6Q_DESC_MODE_8814B 0x3
#define BIT_P0HI6Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI6Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI6Q_DESC_MODE_8814B)
#define BITS_P0HI6Q_DESC_MODE_8814B \
(BIT_MASK_P0HI6Q_DESC_MODE_8814B << BIT_SHIFT_P0HI6Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI6Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI6Q_DESC_MODE_8814B))
#define BIT_GET_P0HI6Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI6Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI6Q_DESC_MODE_8814B)
#define BIT_SET_P0HI6Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI6Q_DESC_MODE_8814B(x) | BIT_P0HI6Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI6Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI6Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI6Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI6Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI6Q_DESC_NUM_8814B)
#define BITS_P0HI6Q_DESC_NUM_8814B \
(BIT_MASK_P0HI6Q_DESC_NUM_8814B << BIT_SHIFT_P0HI6Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI6Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI6Q_DESC_NUM_8814B))
#define BIT_GET_P0HI6Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI6Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI6Q_DESC_NUM_8814B)
#define BIT_SET_P0HI6Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI6Q_DESC_NUM_8814B(x) | BIT_P0HI6Q_DESC_NUM_8814B(v))
/* 2 REG_BD_RWPTR_CLR1_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_FWCMDQ_HW_IDX_8814B BIT(30)
#define BIT_CLR_P0HI7Q_HW_IDX_8814B BIT(29)
#define BIT_CLR_P0HI6Q_HW_IDX_8814B BIT(28)
#define BIT_CLR_P0HI5Q_HW_IDX_8814B BIT(27)
#define BIT_CLR_P0HI4Q_HW_IDX_8814B BIT(26)
#define BIT_CLR_P0HI3Q_HW_IDX_8814B BIT(25)
#define BIT_CLR_P0HI2Q_HW_IDX_8814B BIT(24)
#define BIT_CLR_P0HI1Q_HW_IDX_8814B BIT(23)
#define BIT_CLR_P0HI0Q_HW_IDX_8814B BIT(22)
#define BIT_CLR_ACH3_HW_IDX_8814B BIT(21)
#define BIT_CLR_ACH2_HW_IDX_8814B BIT(20)
#define BIT_CLR_ACH1_HW_IDX_8814B BIT(19)
#define BIT_CLR_ACH0_HW_IDX_8814B BIT(18)
#define BIT_CLR_P0MGQ_HW_IDX_8814B BIT(17)
#define BIT_CLR_P0RXQ_HW_IDX_8814B BIT(16)
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_PFWCMDQ_HOST_IDX_8814B BIT(14)
#define BIT_CLR_P0HI7Q_HOST_IDX_8814B BIT(13)
#define BIT_CLR_P0HI6Q_HOST_IDX_8814B BIT(12)
#define BIT_CLR_P0HI5Q_HOST_IDX_8814B BIT(11)
#define BIT_CLR_P0HI4Q_HOST_IDX_8814B BIT(10)
#define BIT_CLR_P0HI3Q_HOST_IDX_8814B BIT(9)
#define BIT_CLR_P0HI2Q_HOST_IDX_8814B BIT(8)
#define BIT_CLR_P0HI1Q_HOST_IDX_8814B BIT(7)
#define BIT_CLR_P0HI0Q_HOST_IDX_8814B BIT(6)
#define BIT_CLR_ACH3_HOST_IDX_8814B BIT(5)
#define BIT_CLR_ACH2_HOST_IDX_8814B BIT(4)
#define BIT_CLR_ACH1_HOST_IDX_8814B BIT(3)
#define BIT_CLR_ACH0_HOST_IDX_8814B BIT(2)
#define BIT_CLR_P0MGQ_HOST_IDX_8814B BIT(1)
#define BIT_CLR_P0RXQ_HOST_IDX_8814B BIT(0)
/* 2 REG_TSFTIMER_HCI_8814B */
#define BIT_SHIFT_TSFT2_HCI_8814B 16
#define BIT_MASK_TSFT2_HCI_8814B 0xffff
#define BIT_TSFT2_HCI_8814B(x) \
(((x) & BIT_MASK_TSFT2_HCI_8814B) << BIT_SHIFT_TSFT2_HCI_8814B)
#define BITS_TSFT2_HCI_8814B \
(BIT_MASK_TSFT2_HCI_8814B << BIT_SHIFT_TSFT2_HCI_8814B)
#define BIT_CLEAR_TSFT2_HCI_8814B(x) ((x) & (~BITS_TSFT2_HCI_8814B))
#define BIT_GET_TSFT2_HCI_8814B(x) \
(((x) >> BIT_SHIFT_TSFT2_HCI_8814B) & BIT_MASK_TSFT2_HCI_8814B)
#define BIT_SET_TSFT2_HCI_8814B(x, v) \
(BIT_CLEAR_TSFT2_HCI_8814B(x) | BIT_TSFT2_HCI_8814B(v))
#define BIT_SHIFT_TSFT1_HCI_8814B 0
#define BIT_MASK_TSFT1_HCI_8814B 0xffff
#define BIT_TSFT1_HCI_8814B(x) \
(((x) & BIT_MASK_TSFT1_HCI_8814B) << BIT_SHIFT_TSFT1_HCI_8814B)
#define BITS_TSFT1_HCI_8814B \
(BIT_MASK_TSFT1_HCI_8814B << BIT_SHIFT_TSFT1_HCI_8814B)
#define BIT_CLEAR_TSFT1_HCI_8814B(x) ((x) & (~BITS_TSFT1_HCI_8814B))
#define BIT_GET_TSFT1_HCI_8814B(x) \
(((x) >> BIT_SHIFT_TSFT1_HCI_8814B) & BIT_MASK_TSFT1_HCI_8814B)
#define BIT_SET_TSFT1_HCI_8814B(x, v) \
(BIT_CLEAR_TSFT1_HCI_8814B(x) | BIT_TSFT1_HCI_8814B(v))
/* 2 REG_ACH0_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH0_HW_IDX_8814B 16
#define BIT_MASK_ACH0_HW_IDX_8814B 0xfff
#define BIT_ACH0_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH0_HW_IDX_8814B) << BIT_SHIFT_ACH0_HW_IDX_8814B)
#define BITS_ACH0_HW_IDX_8814B \
(BIT_MASK_ACH0_HW_IDX_8814B << BIT_SHIFT_ACH0_HW_IDX_8814B)
#define BIT_CLEAR_ACH0_HW_IDX_8814B(x) ((x) & (~BITS_ACH0_HW_IDX_8814B))
#define BIT_GET_ACH0_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH0_HW_IDX_8814B) & BIT_MASK_ACH0_HW_IDX_8814B)
#define BIT_SET_ACH0_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH0_HW_IDX_8814B(x) | BIT_ACH0_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH0_HOST_IDX_8814B 0
#define BIT_MASK_ACH0_HOST_IDX_8814B 0xfff
#define BIT_ACH0_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH0_HOST_IDX_8814B) << BIT_SHIFT_ACH0_HOST_IDX_8814B)
#define BITS_ACH0_HOST_IDX_8814B \
(BIT_MASK_ACH0_HOST_IDX_8814B << BIT_SHIFT_ACH0_HOST_IDX_8814B)
#define BIT_CLEAR_ACH0_HOST_IDX_8814B(x) ((x) & (~BITS_ACH0_HOST_IDX_8814B))
#define BIT_GET_ACH0_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH0_HOST_IDX_8814B) & BIT_MASK_ACH0_HOST_IDX_8814B)
#define BIT_SET_ACH0_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH0_HOST_IDX_8814B(x) | BIT_ACH0_HOST_IDX_8814B(v))
/* 2 REG_ACH1_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH1_HW_IDX_8814B 16
#define BIT_MASK_ACH1_HW_IDX_8814B 0xfff
#define BIT_ACH1_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH1_HW_IDX_8814B) << BIT_SHIFT_ACH1_HW_IDX_8814B)
#define BITS_ACH1_HW_IDX_8814B \
(BIT_MASK_ACH1_HW_IDX_8814B << BIT_SHIFT_ACH1_HW_IDX_8814B)
#define BIT_CLEAR_ACH1_HW_IDX_8814B(x) ((x) & (~BITS_ACH1_HW_IDX_8814B))
#define BIT_GET_ACH1_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH1_HW_IDX_8814B) & BIT_MASK_ACH1_HW_IDX_8814B)
#define BIT_SET_ACH1_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH1_HW_IDX_8814B(x) | BIT_ACH1_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH1_HOST_IDX_8814B 0
#define BIT_MASK_ACH1_HOST_IDX_8814B 0xfff
#define BIT_ACH1_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH1_HOST_IDX_8814B) << BIT_SHIFT_ACH1_HOST_IDX_8814B)
#define BITS_ACH1_HOST_IDX_8814B \
(BIT_MASK_ACH1_HOST_IDX_8814B << BIT_SHIFT_ACH1_HOST_IDX_8814B)
#define BIT_CLEAR_ACH1_HOST_IDX_8814B(x) ((x) & (~BITS_ACH1_HOST_IDX_8814B))
#define BIT_GET_ACH1_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH1_HOST_IDX_8814B) & BIT_MASK_ACH1_HOST_IDX_8814B)
#define BIT_SET_ACH1_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH1_HOST_IDX_8814B(x) | BIT_ACH1_HOST_IDX_8814B(v))
/* 2 REG_ACH2_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH2_HW_IDX_8814B 16
#define BIT_MASK_ACH2_HW_IDX_8814B 0xfff
#define BIT_ACH2_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH2_HW_IDX_8814B) << BIT_SHIFT_ACH2_HW_IDX_8814B)
#define BITS_ACH2_HW_IDX_8814B \
(BIT_MASK_ACH2_HW_IDX_8814B << BIT_SHIFT_ACH2_HW_IDX_8814B)
#define BIT_CLEAR_ACH2_HW_IDX_8814B(x) ((x) & (~BITS_ACH2_HW_IDX_8814B))
#define BIT_GET_ACH2_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH2_HW_IDX_8814B) & BIT_MASK_ACH2_HW_IDX_8814B)
#define BIT_SET_ACH2_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH2_HW_IDX_8814B(x) | BIT_ACH2_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH2_HOST_IDX_8814B 0
#define BIT_MASK_ACH2_HOST_IDX_8814B 0xfff
#define BIT_ACH2_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH2_HOST_IDX_8814B) << BIT_SHIFT_ACH2_HOST_IDX_8814B)
#define BITS_ACH2_HOST_IDX_8814B \
(BIT_MASK_ACH2_HOST_IDX_8814B << BIT_SHIFT_ACH2_HOST_IDX_8814B)
#define BIT_CLEAR_ACH2_HOST_IDX_8814B(x) ((x) & (~BITS_ACH2_HOST_IDX_8814B))
#define BIT_GET_ACH2_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH2_HOST_IDX_8814B) & BIT_MASK_ACH2_HOST_IDX_8814B)
#define BIT_SET_ACH2_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH2_HOST_IDX_8814B(x) | BIT_ACH2_HOST_IDX_8814B(v))
/* 2 REG_ACH3_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH3_HW_IDX_8814B 16
#define BIT_MASK_ACH3_HW_IDX_8814B 0xfff
#define BIT_ACH3_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH3_HW_IDX_8814B) << BIT_SHIFT_ACH3_HW_IDX_8814B)
#define BITS_ACH3_HW_IDX_8814B \
(BIT_MASK_ACH3_HW_IDX_8814B << BIT_SHIFT_ACH3_HW_IDX_8814B)
#define BIT_CLEAR_ACH3_HW_IDX_8814B(x) ((x) & (~BITS_ACH3_HW_IDX_8814B))
#define BIT_GET_ACH3_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH3_HW_IDX_8814B) & BIT_MASK_ACH3_HW_IDX_8814B)
#define BIT_SET_ACH3_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH3_HW_IDX_8814B(x) | BIT_ACH3_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH3_HOST_IDX_8814B 0
#define BIT_MASK_ACH3_HOST_IDX_8814B 0xfff
#define BIT_ACH3_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH3_HOST_IDX_8814B) << BIT_SHIFT_ACH3_HOST_IDX_8814B)
#define BITS_ACH3_HOST_IDX_8814B \
(BIT_MASK_ACH3_HOST_IDX_8814B << BIT_SHIFT_ACH3_HOST_IDX_8814B)
#define BIT_CLEAR_ACH3_HOST_IDX_8814B(x) ((x) & (~BITS_ACH3_HOST_IDX_8814B))
#define BIT_GET_ACH3_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH3_HOST_IDX_8814B) & BIT_MASK_ACH3_HOST_IDX_8814B)
#define BIT_SET_ACH3_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH3_HOST_IDX_8814B(x) | BIT_ACH3_HOST_IDX_8814B(v))
/* 2 REG_P0MGQ_TXBD_IDX_8814B */
#define BIT_SHIFT_P0MGQ_HW_IDX_8814B 16
#define BIT_MASK_P0MGQ_HW_IDX_8814B 0xfff
#define BIT_P0MGQ_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0MGQ_HW_IDX_8814B) << BIT_SHIFT_P0MGQ_HW_IDX_8814B)
#define BITS_P0MGQ_HW_IDX_8814B \
(BIT_MASK_P0MGQ_HW_IDX_8814B << BIT_SHIFT_P0MGQ_HW_IDX_8814B)
#define BIT_CLEAR_P0MGQ_HW_IDX_8814B(x) ((x) & (~BITS_P0MGQ_HW_IDX_8814B))
#define BIT_GET_P0MGQ_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0MGQ_HW_IDX_8814B) & BIT_MASK_P0MGQ_HW_IDX_8814B)
#define BIT_SET_P0MGQ_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0MGQ_HW_IDX_8814B(x) | BIT_P0MGQ_HW_IDX_8814B(v))
#define BIT_SHIFT_P0MGQ_HOST_IDX_8814B 0
#define BIT_MASK_P0MGQ_HOST_IDX_8814B 0xfff
#define BIT_P0MGQ_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0MGQ_HOST_IDX_8814B) \
<< BIT_SHIFT_P0MGQ_HOST_IDX_8814B)
#define BITS_P0MGQ_HOST_IDX_8814B \
(BIT_MASK_P0MGQ_HOST_IDX_8814B << BIT_SHIFT_P0MGQ_HOST_IDX_8814B)
#define BIT_CLEAR_P0MGQ_HOST_IDX_8814B(x) ((x) & (~BITS_P0MGQ_HOST_IDX_8814B))
#define BIT_GET_P0MGQ_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0MGQ_HOST_IDX_8814B) & \
BIT_MASK_P0MGQ_HOST_IDX_8814B)
#define BIT_SET_P0MGQ_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0MGQ_HOST_IDX_8814B(x) | BIT_P0MGQ_HOST_IDX_8814B(v))
/* 2 REG_P0RXQ_RXBD_IDX_8814B */
#define BIT_SHIFT_P0RXQ_HW_IDX_8814B 16
#define BIT_MASK_P0RXQ_HW_IDX_8814B 0xfff
#define BIT_P0RXQ_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0RXQ_HW_IDX_8814B) << BIT_SHIFT_P0RXQ_HW_IDX_8814B)
#define BITS_P0RXQ_HW_IDX_8814B \
(BIT_MASK_P0RXQ_HW_IDX_8814B << BIT_SHIFT_P0RXQ_HW_IDX_8814B)
#define BIT_CLEAR_P0RXQ_HW_IDX_8814B(x) ((x) & (~BITS_P0RXQ_HW_IDX_8814B))
#define BIT_GET_P0RXQ_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0RXQ_HW_IDX_8814B) & BIT_MASK_P0RXQ_HW_IDX_8814B)
#define BIT_SET_P0RXQ_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0RXQ_HW_IDX_8814B(x) | BIT_P0RXQ_HW_IDX_8814B(v))
#define BIT_SHIFT_P0RXQ_HOST_IDX_8814B 0
#define BIT_MASK_P0RXQ_HOST_IDX_8814B 0xfff
#define BIT_P0RXQ_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0RXQ_HOST_IDX_8814B) \
<< BIT_SHIFT_P0RXQ_HOST_IDX_8814B)
#define BITS_P0RXQ_HOST_IDX_8814B \
(BIT_MASK_P0RXQ_HOST_IDX_8814B << BIT_SHIFT_P0RXQ_HOST_IDX_8814B)
#define BIT_CLEAR_P0RXQ_HOST_IDX_8814B(x) ((x) & (~BITS_P0RXQ_HOST_IDX_8814B))
#define BIT_GET_P0RXQ_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0RXQ_HOST_IDX_8814B) & \
BIT_MASK_P0RXQ_HOST_IDX_8814B)
#define BIT_SET_P0RXQ_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0RXQ_HOST_IDX_8814B(x) | BIT_P0RXQ_HOST_IDX_8814B(v))
/* 2 REG_P0HI0Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI0Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI0Q_HW_IDX_8814B 0xfff
#define BIT_P0HI0Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI0Q_HW_IDX_8814B) << BIT_SHIFT_P0HI0Q_HW_IDX_8814B)
#define BITS_P0HI0Q_HW_IDX_8814B \
(BIT_MASK_P0HI0Q_HW_IDX_8814B << BIT_SHIFT_P0HI0Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI0Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI0Q_HW_IDX_8814B))
#define BIT_GET_P0HI0Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI0Q_HW_IDX_8814B) & BIT_MASK_P0HI0Q_HW_IDX_8814B)
#define BIT_SET_P0HI0Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI0Q_HW_IDX_8814B(x) | BIT_P0HI0Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI0Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI0Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI0Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI0Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI0Q_HOST_IDX_8814B)
#define BITS_P0HI0Q_HOST_IDX_8814B \
(BIT_MASK_P0HI0Q_HOST_IDX_8814B << BIT_SHIFT_P0HI0Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI0Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI0Q_HOST_IDX_8814B))
#define BIT_GET_P0HI0Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI0Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI0Q_HOST_IDX_8814B)
#define BIT_SET_P0HI0Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI0Q_HOST_IDX_8814B(x) | BIT_P0HI0Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI1Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI1Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI1Q_HW_IDX_8814B 0xfff
#define BIT_P0HI1Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI1Q_HW_IDX_8814B) << BIT_SHIFT_P0HI1Q_HW_IDX_8814B)
#define BITS_P0HI1Q_HW_IDX_8814B \
(BIT_MASK_P0HI1Q_HW_IDX_8814B << BIT_SHIFT_P0HI1Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI1Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI1Q_HW_IDX_8814B))
#define BIT_GET_P0HI1Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI1Q_HW_IDX_8814B) & BIT_MASK_P0HI1Q_HW_IDX_8814B)
#define BIT_SET_P0HI1Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI1Q_HW_IDX_8814B(x) | BIT_P0HI1Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI1Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI1Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI1Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI1Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI1Q_HOST_IDX_8814B)
#define BITS_P0HI1Q_HOST_IDX_8814B \
(BIT_MASK_P0HI1Q_HOST_IDX_8814B << BIT_SHIFT_P0HI1Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI1Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI1Q_HOST_IDX_8814B))
#define BIT_GET_P0HI1Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI1Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI1Q_HOST_IDX_8814B)
#define BIT_SET_P0HI1Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI1Q_HOST_IDX_8814B(x) | BIT_P0HI1Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI2Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI2Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI2Q_HW_IDX_8814B 0xfff
#define BIT_P0HI2Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI2Q_HW_IDX_8814B) << BIT_SHIFT_P0HI2Q_HW_IDX_8814B)
#define BITS_P0HI2Q_HW_IDX_8814B \
(BIT_MASK_P0HI2Q_HW_IDX_8814B << BIT_SHIFT_P0HI2Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI2Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI2Q_HW_IDX_8814B))
#define BIT_GET_P0HI2Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI2Q_HW_IDX_8814B) & BIT_MASK_P0HI2Q_HW_IDX_8814B)
#define BIT_SET_P0HI2Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI2Q_HW_IDX_8814B(x) | BIT_P0HI2Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI2Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI2Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI2Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI2Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI2Q_HOST_IDX_8814B)
#define BITS_P0HI2Q_HOST_IDX_8814B \
(BIT_MASK_P0HI2Q_HOST_IDX_8814B << BIT_SHIFT_P0HI2Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI2Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI2Q_HOST_IDX_8814B))
#define BIT_GET_P0HI2Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI2Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI2Q_HOST_IDX_8814B)
#define BIT_SET_P0HI2Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI2Q_HOST_IDX_8814B(x) | BIT_P0HI2Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI3Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI3Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI3Q_HW_IDX_8814B 0xfff
#define BIT_P0HI3Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI3Q_HW_IDX_8814B) << BIT_SHIFT_P0HI3Q_HW_IDX_8814B)
#define BITS_P0HI3Q_HW_IDX_8814B \
(BIT_MASK_P0HI3Q_HW_IDX_8814B << BIT_SHIFT_P0HI3Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI3Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI3Q_HW_IDX_8814B))
#define BIT_GET_P0HI3Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI3Q_HW_IDX_8814B) & BIT_MASK_P0HI3Q_HW_IDX_8814B)
#define BIT_SET_P0HI3Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI3Q_HW_IDX_8814B(x) | BIT_P0HI3Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI3Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI3Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI3Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI3Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI3Q_HOST_IDX_8814B)
#define BITS_P0HI3Q_HOST_IDX_8814B \
(BIT_MASK_P0HI3Q_HOST_IDX_8814B << BIT_SHIFT_P0HI3Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI3Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI3Q_HOST_IDX_8814B))
#define BIT_GET_P0HI3Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI3Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI3Q_HOST_IDX_8814B)
#define BIT_SET_P0HI3Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI3Q_HOST_IDX_8814B(x) | BIT_P0HI3Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI4Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI4Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI4Q_HW_IDX_8814B 0xfff
#define BIT_P0HI4Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI4Q_HW_IDX_8814B) << BIT_SHIFT_P0HI4Q_HW_IDX_8814B)
#define BITS_P0HI4Q_HW_IDX_8814B \
(BIT_MASK_P0HI4Q_HW_IDX_8814B << BIT_SHIFT_P0HI4Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI4Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI4Q_HW_IDX_8814B))
#define BIT_GET_P0HI4Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI4Q_HW_IDX_8814B) & BIT_MASK_P0HI4Q_HW_IDX_8814B)
#define BIT_SET_P0HI4Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI4Q_HW_IDX_8814B(x) | BIT_P0HI4Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI4Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI4Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI4Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI4Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI4Q_HOST_IDX_8814B)
#define BITS_P0HI4Q_HOST_IDX_8814B \
(BIT_MASK_P0HI4Q_HOST_IDX_8814B << BIT_SHIFT_P0HI4Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI4Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI4Q_HOST_IDX_8814B))
#define BIT_GET_P0HI4Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI4Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI4Q_HOST_IDX_8814B)
#define BIT_SET_P0HI4Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI4Q_HOST_IDX_8814B(x) | BIT_P0HI4Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI5Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI5Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI5Q_HW_IDX_8814B 0xfff
#define BIT_P0HI5Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI5Q_HW_IDX_8814B) << BIT_SHIFT_P0HI5Q_HW_IDX_8814B)
#define BITS_P0HI5Q_HW_IDX_8814B \
(BIT_MASK_P0HI5Q_HW_IDX_8814B << BIT_SHIFT_P0HI5Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI5Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI5Q_HW_IDX_8814B))
#define BIT_GET_P0HI5Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI5Q_HW_IDX_8814B) & BIT_MASK_P0HI5Q_HW_IDX_8814B)
#define BIT_SET_P0HI5Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI5Q_HW_IDX_8814B(x) | BIT_P0HI5Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI5Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI5Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI5Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI5Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI5Q_HOST_IDX_8814B)
#define BITS_P0HI5Q_HOST_IDX_8814B \
(BIT_MASK_P0HI5Q_HOST_IDX_8814B << BIT_SHIFT_P0HI5Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI5Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI5Q_HOST_IDX_8814B))
#define BIT_GET_P0HI5Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI5Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI5Q_HOST_IDX_8814B)
#define BIT_SET_P0HI5Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI5Q_HOST_IDX_8814B(x) | BIT_P0HI5Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI6Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI6Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI6Q_HW_IDX_8814B 0xfff
#define BIT_P0HI6Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI6Q_HW_IDX_8814B) << BIT_SHIFT_P0HI6Q_HW_IDX_8814B)
#define BITS_P0HI6Q_HW_IDX_8814B \
(BIT_MASK_P0HI6Q_HW_IDX_8814B << BIT_SHIFT_P0HI6Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI6Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI6Q_HW_IDX_8814B))
#define BIT_GET_P0HI6Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI6Q_HW_IDX_8814B) & BIT_MASK_P0HI6Q_HW_IDX_8814B)
#define BIT_SET_P0HI6Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI6Q_HW_IDX_8814B(x) | BIT_P0HI6Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI6Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI6Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI6Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI6Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI6Q_HOST_IDX_8814B)
#define BITS_P0HI6Q_HOST_IDX_8814B \
(BIT_MASK_P0HI6Q_HOST_IDX_8814B << BIT_SHIFT_P0HI6Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI6Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI6Q_HOST_IDX_8814B))
#define BIT_GET_P0HI6Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI6Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI6Q_HOST_IDX_8814B)
#define BIT_SET_P0HI6Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI6Q_HOST_IDX_8814B(x) | BIT_P0HI6Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI7Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI7Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI7Q_HW_IDX_8814B 0xfff
#define BIT_P0HI7Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI7Q_HW_IDX_8814B) << BIT_SHIFT_P0HI7Q_HW_IDX_8814B)
#define BITS_P0HI7Q_HW_IDX_8814B \
(BIT_MASK_P0HI7Q_HW_IDX_8814B << BIT_SHIFT_P0HI7Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI7Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI7Q_HW_IDX_8814B))
#define BIT_GET_P0HI7Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI7Q_HW_IDX_8814B) & BIT_MASK_P0HI7Q_HW_IDX_8814B)
#define BIT_SET_P0HI7Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI7Q_HW_IDX_8814B(x) | BIT_P0HI7Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI7Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI7Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI7Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI7Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI7Q_HOST_IDX_8814B)
#define BITS_P0HI7Q_HOST_IDX_8814B \
(BIT_MASK_P0HI7Q_HOST_IDX_8814B << BIT_SHIFT_P0HI7Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI7Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI7Q_HOST_IDX_8814B))
#define BIT_GET_P0HI7Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI7Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI7Q_HOST_IDX_8814B)
#define BIT_SET_P0HI7Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI7Q_HOST_IDX_8814B(x) | BIT_P0HI7Q_HOST_IDX_8814B(v))
/* 2 REG_DBGSEL_PCIE_HRPWM1_HCPWM1_V1_8814B */
#define BIT_DIS_TXDMA_PRE_V1_8814B BIT(31)
#define BIT_DIS_RXDMA_PRE_V1_8814B BIT(30)
#define BIT_SHIFT_HPS_CLKR_PCIE_V1_8814B 28
#define BIT_MASK_HPS_CLKR_PCIE_V1_8814B 0x3
#define BIT_HPS_CLKR_PCIE_V1_8814B(x) \
(((x) & BIT_MASK_HPS_CLKR_PCIE_V1_8814B) \
<< BIT_SHIFT_HPS_CLKR_PCIE_V1_8814B)
#define BITS_HPS_CLKR_PCIE_V1_8814B \
(BIT_MASK_HPS_CLKR_PCIE_V1_8814B << BIT_SHIFT_HPS_CLKR_PCIE_V1_8814B)
#define BIT_CLEAR_HPS_CLKR_PCIE_V1_8814B(x) \
((x) & (~BITS_HPS_CLKR_PCIE_V1_8814B))
#define BIT_GET_HPS_CLKR_PCIE_V1_8814B(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_PCIE_V1_8814B) & \
BIT_MASK_HPS_CLKR_PCIE_V1_8814B)
#define BIT_SET_HPS_CLKR_PCIE_V1_8814B(x, v) \
(BIT_CLEAR_HPS_CLKR_PCIE_V1_8814B(x) | BIT_HPS_CLKR_PCIE_V1_8814B(v))
#define BIT_PCIE_INT_V1_8814B BIT(27)
#define BIT_TXFLAG_EXIT_L1_EN_V1_8814B BIT(26)
#define BIT_EN_RXDMA_ALIGN_V2_8814B BIT(25)
#define BIT_EN_TXDMA_ALIGN_V2_8814B BIT(24)
#define BIT_SHIFT_PCIE_HCPWM_V1_8814B 16
#define BIT_MASK_PCIE_HCPWM_V1_8814B 0xff
#define BIT_PCIE_HCPWM_V1_8814B(x) \
(((x) & BIT_MASK_PCIE_HCPWM_V1_8814B) << BIT_SHIFT_PCIE_HCPWM_V1_8814B)
#define BITS_PCIE_HCPWM_V1_8814B \
(BIT_MASK_PCIE_HCPWM_V1_8814B << BIT_SHIFT_PCIE_HCPWM_V1_8814B)
#define BIT_CLEAR_PCIE_HCPWM_V1_8814B(x) ((x) & (~BITS_PCIE_HCPWM_V1_8814B))
#define BIT_GET_PCIE_HCPWM_V1_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM_V1_8814B) & BIT_MASK_PCIE_HCPWM_V1_8814B)
#define BIT_SET_PCIE_HCPWM_V1_8814B(x, v) \
(BIT_CLEAR_PCIE_HCPWM_V1_8814B(x) | BIT_PCIE_HCPWM_V1_8814B(v))
#define BIT_SHIFT_PCIE_HRPWM_V1_8814B 8
#define BIT_MASK_PCIE_HRPWM_V1_8814B 0xff
#define BIT_PCIE_HRPWM_V1_8814B(x) \
(((x) & BIT_MASK_PCIE_HRPWM_V1_8814B) << BIT_SHIFT_PCIE_HRPWM_V1_8814B)
#define BITS_PCIE_HRPWM_V1_8814B \
(BIT_MASK_PCIE_HRPWM_V1_8814B << BIT_SHIFT_PCIE_HRPWM_V1_8814B)
#define BIT_CLEAR_PCIE_HRPWM_V1_8814B(x) ((x) & (~BITS_PCIE_HRPWM_V1_8814B))
#define BIT_GET_PCIE_HRPWM_V1_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM_V1_8814B) & BIT_MASK_PCIE_HRPWM_V1_8814B)
#define BIT_SET_PCIE_HRPWM_V1_8814B(x, v) \
(BIT_CLEAR_PCIE_HRPWM_V1_8814B(x) | BIT_PCIE_HRPWM_V1_8814B(v))
#define BIT_SHIFT_DBG_SEL_8814B 0
#define BIT_MASK_DBG_SEL_8814B 0xff
#define BIT_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_DBG_SEL_8814B) << BIT_SHIFT_DBG_SEL_8814B)
#define BITS_DBG_SEL_8814B (BIT_MASK_DBG_SEL_8814B << BIT_SHIFT_DBG_SEL_8814B)
#define BIT_CLEAR_DBG_SEL_8814B(x) ((x) & (~BITS_DBG_SEL_8814B))
#define BIT_GET_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_DBG_SEL_8814B) & BIT_MASK_DBG_SEL_8814B)
#define BIT_SET_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_DBG_SEL_8814B(x) | BIT_DBG_SEL_8814B(v))
/* 2 REG_PCIE_HRPWM2_HCPWM2_V1_8814B */
#define BIT_SHIFT_PCIE_HCPWM2_V1_8814B 16
#define BIT_MASK_PCIE_HCPWM2_V1_8814B 0xffff
#define BIT_PCIE_HCPWM2_V1_8814B(x) \
(((x) & BIT_MASK_PCIE_HCPWM2_V1_8814B) \
<< BIT_SHIFT_PCIE_HCPWM2_V1_8814B)
#define BITS_PCIE_HCPWM2_V1_8814B \
(BIT_MASK_PCIE_HCPWM2_V1_8814B << BIT_SHIFT_PCIE_HCPWM2_V1_8814B)
#define BIT_CLEAR_PCIE_HCPWM2_V1_8814B(x) ((x) & (~BITS_PCIE_HCPWM2_V1_8814B))
#define BIT_GET_PCIE_HCPWM2_V1_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM2_V1_8814B) & \
BIT_MASK_PCIE_HCPWM2_V1_8814B)
#define BIT_SET_PCIE_HCPWM2_V1_8814B(x, v) \
(BIT_CLEAR_PCIE_HCPWM2_V1_8814B(x) | BIT_PCIE_HCPWM2_V1_8814B(v))
#define BIT_SHIFT_PCIE_HRPWM2_8814B 0
#define BIT_MASK_PCIE_HRPWM2_8814B 0xffff
#define BIT_PCIE_HRPWM2_8814B(x) \
(((x) & BIT_MASK_PCIE_HRPWM2_8814B) << BIT_SHIFT_PCIE_HRPWM2_8814B)
#define BITS_PCIE_HRPWM2_8814B \
(BIT_MASK_PCIE_HRPWM2_8814B << BIT_SHIFT_PCIE_HRPWM2_8814B)
#define BIT_CLEAR_PCIE_HRPWM2_8814B(x) ((x) & (~BITS_PCIE_HRPWM2_8814B))
#define BIT_GET_PCIE_HRPWM2_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM2_8814B) & BIT_MASK_PCIE_HRPWM2_8814B)
#define BIT_SET_PCIE_HRPWM2_8814B(x, v) \
(BIT_CLEAR_PCIE_HRPWM2_8814B(x) | BIT_PCIE_HRPWM2_8814B(v))
/* 2 REG_PCIE_H2C_MSG_V1_8814B */
#define BIT_SHIFT_DRV2FW_INFO_8814B 0
#define BIT_MASK_DRV2FW_INFO_8814B 0xffffffffL
#define BIT_DRV2FW_INFO_8814B(x) \
(((x) & BIT_MASK_DRV2FW_INFO_8814B) << BIT_SHIFT_DRV2FW_INFO_8814B)
#define BITS_DRV2FW_INFO_8814B \
(BIT_MASK_DRV2FW_INFO_8814B << BIT_SHIFT_DRV2FW_INFO_8814B)
#define BIT_CLEAR_DRV2FW_INFO_8814B(x) ((x) & (~BITS_DRV2FW_INFO_8814B))
#define BIT_GET_DRV2FW_INFO_8814B(x) \
(((x) >> BIT_SHIFT_DRV2FW_INFO_8814B) & BIT_MASK_DRV2FW_INFO_8814B)
#define BIT_SET_DRV2FW_INFO_8814B(x, v) \
(BIT_CLEAR_DRV2FW_INFO_8814B(x) | BIT_DRV2FW_INFO_8814B(v))
/* 2 REG_PCIE_C2H_MSG_V1_8814B */
#define BIT_SHIFT_HCI_PCIE_C2H_MSG_8814B 0
#define BIT_MASK_HCI_PCIE_C2H_MSG_8814B 0xffffffffL
#define BIT_HCI_PCIE_C2H_MSG_8814B(x) \
(((x) & BIT_MASK_HCI_PCIE_C2H_MSG_8814B) \
<< BIT_SHIFT_HCI_PCIE_C2H_MSG_8814B)
#define BITS_HCI_PCIE_C2H_MSG_8814B \
(BIT_MASK_HCI_PCIE_C2H_MSG_8814B << BIT_SHIFT_HCI_PCIE_C2H_MSG_8814B)
#define BIT_CLEAR_HCI_PCIE_C2H_MSG_8814B(x) \
((x) & (~BITS_HCI_PCIE_C2H_MSG_8814B))
#define BIT_GET_HCI_PCIE_C2H_MSG_8814B(x) \
(((x) >> BIT_SHIFT_HCI_PCIE_C2H_MSG_8814B) & \
BIT_MASK_HCI_PCIE_C2H_MSG_8814B)
#define BIT_SET_HCI_PCIE_C2H_MSG_8814B(x, v) \
(BIT_CLEAR_HCI_PCIE_C2H_MSG_8814B(x) | BIT_HCI_PCIE_C2H_MSG_8814B(v))
/* 2 REG_DBI_WDATA_V1_8814B */
#define BIT_SHIFT_DBI_WDATA_8814B 0
#define BIT_MASK_DBI_WDATA_8814B 0xffffffffL
#define BIT_DBI_WDATA_8814B(x) \
(((x) & BIT_MASK_DBI_WDATA_8814B) << BIT_SHIFT_DBI_WDATA_8814B)
#define BITS_DBI_WDATA_8814B \
(BIT_MASK_DBI_WDATA_8814B << BIT_SHIFT_DBI_WDATA_8814B)
#define BIT_CLEAR_DBI_WDATA_8814B(x) ((x) & (~BITS_DBI_WDATA_8814B))
#define BIT_GET_DBI_WDATA_8814B(x) \
(((x) >> BIT_SHIFT_DBI_WDATA_8814B) & BIT_MASK_DBI_WDATA_8814B)
#define BIT_SET_DBI_WDATA_8814B(x, v) \
(BIT_CLEAR_DBI_WDATA_8814B(x) | BIT_DBI_WDATA_8814B(v))
/* 2 REG_DBI_RDATA_V1_8814B */
#define BIT_SHIFT_DBI_RDATA_8814B 0
#define BIT_MASK_DBI_RDATA_8814B 0xffffffffL
#define BIT_DBI_RDATA_8814B(x) \
(((x) & BIT_MASK_DBI_RDATA_8814B) << BIT_SHIFT_DBI_RDATA_8814B)
#define BITS_DBI_RDATA_8814B \
(BIT_MASK_DBI_RDATA_8814B << BIT_SHIFT_DBI_RDATA_8814B)
#define BIT_CLEAR_DBI_RDATA_8814B(x) ((x) & (~BITS_DBI_RDATA_8814B))
#define BIT_GET_DBI_RDATA_8814B(x) \
(((x) >> BIT_SHIFT_DBI_RDATA_8814B) & BIT_MASK_DBI_RDATA_8814B)
#define BIT_SET_DBI_RDATA_8814B(x, v) \
(BIT_CLEAR_DBI_RDATA_8814B(x) | BIT_DBI_RDATA_8814B(v))
/* 2 REG_DBI_FLAG_V1_8814B */
#define BIT_SHIFT_LOOPBACK_DBG_SEL_8814B 28
#define BIT_MASK_LOOPBACK_DBG_SEL_8814B 0xf
#define BIT_LOOPBACK_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_LOOPBACK_DBG_SEL_8814B) \
<< BIT_SHIFT_LOOPBACK_DBG_SEL_8814B)
#define BITS_LOOPBACK_DBG_SEL_8814B \
(BIT_MASK_LOOPBACK_DBG_SEL_8814B << BIT_SHIFT_LOOPBACK_DBG_SEL_8814B)
#define BIT_CLEAR_LOOPBACK_DBG_SEL_8814B(x) \
((x) & (~BITS_LOOPBACK_DBG_SEL_8814B))
#define BIT_GET_LOOPBACK_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_LOOPBACK_DBG_SEL_8814B) & \
BIT_MASK_LOOPBACK_DBG_SEL_8814B)
#define BIT_SET_LOOPBACK_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_LOOPBACK_DBG_SEL_8814B(x) | BIT_LOOPBACK_DBG_SEL_8814B(v))
#define BIT_EN_STUCK_DBG_8814B BIT(26)
#define BIT_RX_STUCK_8814B BIT(25)
#define BIT_TX_STUCK_8814B BIT(24)
#define BIT_DBI_RFLAG_8814B BIT(17)
#define BIT_DBI_WFLAG_8814B BIT(16)
#define BIT_SHIFT_DBI_WREN_8814B 12
#define BIT_MASK_DBI_WREN_8814B 0xf
#define BIT_DBI_WREN_8814B(x) \
(((x) & BIT_MASK_DBI_WREN_8814B) << BIT_SHIFT_DBI_WREN_8814B)
#define BITS_DBI_WREN_8814B \
(BIT_MASK_DBI_WREN_8814B << BIT_SHIFT_DBI_WREN_8814B)
#define BIT_CLEAR_DBI_WREN_8814B(x) ((x) & (~BITS_DBI_WREN_8814B))
#define BIT_GET_DBI_WREN_8814B(x) \
(((x) >> BIT_SHIFT_DBI_WREN_8814B) & BIT_MASK_DBI_WREN_8814B)
#define BIT_SET_DBI_WREN_8814B(x, v) \
(BIT_CLEAR_DBI_WREN_8814B(x) | BIT_DBI_WREN_8814B(v))
#define BIT_SHIFT_DBI_ADDR_8814B 0
#define BIT_MASK_DBI_ADDR_8814B 0xfff
#define BIT_DBI_ADDR_8814B(x) \
(((x) & BIT_MASK_DBI_ADDR_8814B) << BIT_SHIFT_DBI_ADDR_8814B)
#define BITS_DBI_ADDR_8814B \
(BIT_MASK_DBI_ADDR_8814B << BIT_SHIFT_DBI_ADDR_8814B)
#define BIT_CLEAR_DBI_ADDR_8814B(x) ((x) & (~BITS_DBI_ADDR_8814B))
#define BIT_GET_DBI_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_DBI_ADDR_8814B) & BIT_MASK_DBI_ADDR_8814B)
#define BIT_SET_DBI_ADDR_8814B(x, v) \
(BIT_CLEAR_DBI_ADDR_8814B(x) | BIT_DBI_ADDR_8814B(v))
/* 2 REG_MDIO_V1_8814B */
#define BIT_SHIFT_MDIO_RDATA_8814B 16
#define BIT_MASK_MDIO_RDATA_8814B 0xffff
#define BIT_MDIO_RDATA_8814B(x) \
(((x) & BIT_MASK_MDIO_RDATA_8814B) << BIT_SHIFT_MDIO_RDATA_8814B)
#define BITS_MDIO_RDATA_8814B \
(BIT_MASK_MDIO_RDATA_8814B << BIT_SHIFT_MDIO_RDATA_8814B)
#define BIT_CLEAR_MDIO_RDATA_8814B(x) ((x) & (~BITS_MDIO_RDATA_8814B))
#define BIT_GET_MDIO_RDATA_8814B(x) \
(((x) >> BIT_SHIFT_MDIO_RDATA_8814B) & BIT_MASK_MDIO_RDATA_8814B)
#define BIT_SET_MDIO_RDATA_8814B(x, v) \
(BIT_CLEAR_MDIO_RDATA_8814B(x) | BIT_MDIO_RDATA_8814B(v))
#define BIT_SHIFT_MDIO_WDATA_8814B 0
#define BIT_MASK_MDIO_WDATA_8814B 0xffff
#define BIT_MDIO_WDATA_8814B(x) \
(((x) & BIT_MASK_MDIO_WDATA_8814B) << BIT_SHIFT_MDIO_WDATA_8814B)
#define BITS_MDIO_WDATA_8814B \
(BIT_MASK_MDIO_WDATA_8814B << BIT_SHIFT_MDIO_WDATA_8814B)
#define BIT_CLEAR_MDIO_WDATA_8814B(x) ((x) & (~BITS_MDIO_WDATA_8814B))
#define BIT_GET_MDIO_WDATA_8814B(x) \
(((x) >> BIT_SHIFT_MDIO_WDATA_8814B) & BIT_MASK_MDIO_WDATA_8814B)
#define BIT_SET_MDIO_WDATA_8814B(x, v) \
(BIT_CLEAR_MDIO_WDATA_8814B(x) | BIT_MDIO_WDATA_8814B(v))
/* 2 REG_PCIE_MIX_CFG_8814B */
#define BIT_SHIFT_MDIO_PHY_ADDR_8814B 24
#define BIT_MASK_MDIO_PHY_ADDR_8814B 0x1f
#define BIT_MDIO_PHY_ADDR_8814B(x) \
(((x) & BIT_MASK_MDIO_PHY_ADDR_8814B) << BIT_SHIFT_MDIO_PHY_ADDR_8814B)
#define BITS_MDIO_PHY_ADDR_8814B \
(BIT_MASK_MDIO_PHY_ADDR_8814B << BIT_SHIFT_MDIO_PHY_ADDR_8814B)
#define BIT_CLEAR_MDIO_PHY_ADDR_8814B(x) ((x) & (~BITS_MDIO_PHY_ADDR_8814B))
#define BIT_GET_MDIO_PHY_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_MDIO_PHY_ADDR_8814B) & BIT_MASK_MDIO_PHY_ADDR_8814B)
#define BIT_SET_MDIO_PHY_ADDR_8814B(x, v) \
(BIT_CLEAR_MDIO_PHY_ADDR_8814B(x) | BIT_MDIO_PHY_ADDR_8814B(v))
#define BIT_SHIFT_WATCH_DOG_RECORD_V1_8814B 10
#define BIT_MASK_WATCH_DOG_RECORD_V1_8814B 0x3fff
#define BIT_WATCH_DOG_RECORD_V1_8814B(x) \
(((x) & BIT_MASK_WATCH_DOG_RECORD_V1_8814B) \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8814B)
#define BITS_WATCH_DOG_RECORD_V1_8814B \
(BIT_MASK_WATCH_DOG_RECORD_V1_8814B \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8814B)
#define BIT_CLEAR_WATCH_DOG_RECORD_V1_8814B(x) \
((x) & (~BITS_WATCH_DOG_RECORD_V1_8814B))
#define BIT_GET_WATCH_DOG_RECORD_V1_8814B(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_RECORD_V1_8814B) & \
BIT_MASK_WATCH_DOG_RECORD_V1_8814B)
#define BIT_SET_WATCH_DOG_RECORD_V1_8814B(x, v) \
(BIT_CLEAR_WATCH_DOG_RECORD_V1_8814B(x) | \
BIT_WATCH_DOG_RECORD_V1_8814B(v))
#define BIT_R_IO_TIMEOUT_FLAG_V1_8814B BIT(9)
#define BIT_EN_WATCH_DOG_8814B BIT(8)
#define BIT_ECRC_EN_8814B BIT(7)
#define BIT_MDIO_RFLAG_8814B BIT(6)
#define BIT_MDIO_WFLAG_8814B BIT(5)
#define BIT_SHIFT_MDIO_REG_ADDR_8814B 0
#define BIT_MASK_MDIO_REG_ADDR_8814B 0x1f
#define BIT_MDIO_REG_ADDR_8814B(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR_8814B) << BIT_SHIFT_MDIO_REG_ADDR_8814B)
#define BITS_MDIO_REG_ADDR_8814B \
(BIT_MASK_MDIO_REG_ADDR_8814B << BIT_SHIFT_MDIO_REG_ADDR_8814B)
#define BIT_CLEAR_MDIO_REG_ADDR_8814B(x) ((x) & (~BITS_MDIO_REG_ADDR_8814B))
#define BIT_GET_MDIO_REG_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR_8814B) & BIT_MASK_MDIO_REG_ADDR_8814B)
#define BIT_SET_MDIO_REG_ADDR_8814B(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR_8814B(x) | BIT_MDIO_REG_ADDR_8814B(v))
/* 2 REG_HCI_MIX_CFG_8814B */
#define BIT_EN_ALIGN_MTU_8814B BIT(23)
#define BIT_SHIFT_LATENCY_CONTROL_8814B 21
#define BIT_MASK_LATENCY_CONTROL_8814B 0x3
#define BIT_LATENCY_CONTROL_8814B(x) \
(((x) & BIT_MASK_LATENCY_CONTROL_8814B) \
<< BIT_SHIFT_LATENCY_CONTROL_8814B)
#define BITS_LATENCY_CONTROL_8814B \
(BIT_MASK_LATENCY_CONTROL_8814B << BIT_SHIFT_LATENCY_CONTROL_8814B)
#define BIT_CLEAR_LATENCY_CONTROL_8814B(x) ((x) & (~BITS_LATENCY_CONTROL_8814B))
#define BIT_GET_LATENCY_CONTROL_8814B(x) \
(((x) >> BIT_SHIFT_LATENCY_CONTROL_8814B) & \
BIT_MASK_LATENCY_CONTROL_8814B)
#define BIT_SET_LATENCY_CONTROL_8814B(x, v) \
(BIT_CLEAR_LATENCY_CONTROL_8814B(x) | BIT_LATENCY_CONTROL_8814B(v))
#define BIT_HOST_GEN2_SUPPORT_8814B BIT(20)
#define BIT_SHIFT_TXDMA_ERR_FLAG_V1_8814B 15
#define BIT_MASK_TXDMA_ERR_FLAG_V1_8814B 0x1f
#define BIT_TXDMA_ERR_FLAG_V1_8814B(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG_V1_8814B) \
<< BIT_SHIFT_TXDMA_ERR_FLAG_V1_8814B)
#define BITS_TXDMA_ERR_FLAG_V1_8814B \
(BIT_MASK_TXDMA_ERR_FLAG_V1_8814B << BIT_SHIFT_TXDMA_ERR_FLAG_V1_8814B)
#define BIT_CLEAR_TXDMA_ERR_FLAG_V1_8814B(x) \
((x) & (~BITS_TXDMA_ERR_FLAG_V1_8814B))
#define BIT_GET_TXDMA_ERR_FLAG_V1_8814B(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG_V1_8814B) & \
BIT_MASK_TXDMA_ERR_FLAG_V1_8814B)
#define BIT_SET_TXDMA_ERR_FLAG_V1_8814B(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG_V1_8814B(x) | BIT_TXDMA_ERR_FLAG_V1_8814B(v))
#define BIT_EPHY_RX50_EN_8814B BIT(11)
#define BIT_SHIFT_MSI_TIMEOUT_ID_V1_8814B 8
#define BIT_MASK_MSI_TIMEOUT_ID_V1_8814B 0x7
#define BIT_MSI_TIMEOUT_ID_V1_8814B(x) \
(((x) & BIT_MASK_MSI_TIMEOUT_ID_V1_8814B) \
<< BIT_SHIFT_MSI_TIMEOUT_ID_V1_8814B)
#define BITS_MSI_TIMEOUT_ID_V1_8814B \
(BIT_MASK_MSI_TIMEOUT_ID_V1_8814B << BIT_SHIFT_MSI_TIMEOUT_ID_V1_8814B)
#define BIT_CLEAR_MSI_TIMEOUT_ID_V1_8814B(x) \
((x) & (~BITS_MSI_TIMEOUT_ID_V1_8814B))
#define BIT_GET_MSI_TIMEOUT_ID_V1_8814B(x) \
(((x) >> BIT_SHIFT_MSI_TIMEOUT_ID_V1_8814B) & \
BIT_MASK_MSI_TIMEOUT_ID_V1_8814B)
#define BIT_SET_MSI_TIMEOUT_ID_V1_8814B(x, v) \
(BIT_CLEAR_MSI_TIMEOUT_ID_V1_8814B(x) | BIT_MSI_TIMEOUT_ID_V1_8814B(v))
#define BIT_RADDR_RD_8814B BIT(7)
#define BIT_L0S_LINK_OFF_8814B BIT(4)
#define BIT_ACT_LINK_OFF_8814B BIT(3)
#define BIT_EN_SLOW_MAC_TX_8814B BIT(2)
#define BIT_EN_SLOW_MAC_RX_8814B BIT(1)
#define BIT_EN_SLOW_MAC_HW_8814B BIT(0)
/* 2 REG_STC_INT_CS_8814B(PCIE STATE CHANGE INTERRUPT CONTROL AND STATUS) */
#define BIT_STC_INT_EN_8814B BIT(31)
#define BIT_SHIFT_STC_INT_FLAG_8814B 16
#define BIT_MASK_STC_INT_FLAG_8814B 0xff
#define BIT_STC_INT_FLAG_8814B(x) \
(((x) & BIT_MASK_STC_INT_FLAG_8814B) << BIT_SHIFT_STC_INT_FLAG_8814B)
#define BITS_STC_INT_FLAG_8814B \
(BIT_MASK_STC_INT_FLAG_8814B << BIT_SHIFT_STC_INT_FLAG_8814B)
#define BIT_CLEAR_STC_INT_FLAG_8814B(x) ((x) & (~BITS_STC_INT_FLAG_8814B))
#define BIT_GET_STC_INT_FLAG_8814B(x) \
(((x) >> BIT_SHIFT_STC_INT_FLAG_8814B) & BIT_MASK_STC_INT_FLAG_8814B)
#define BIT_SET_STC_INT_FLAG_8814B(x, v) \
(BIT_CLEAR_STC_INT_FLAG_8814B(x) | BIT_STC_INT_FLAG_8814B(v))
#define BIT_SHIFT_STC_INT_IDX_8814B 8
#define BIT_MASK_STC_INT_IDX_8814B 0x7
#define BIT_STC_INT_IDX_8814B(x) \
(((x) & BIT_MASK_STC_INT_IDX_8814B) << BIT_SHIFT_STC_INT_IDX_8814B)
#define BITS_STC_INT_IDX_8814B \
(BIT_MASK_STC_INT_IDX_8814B << BIT_SHIFT_STC_INT_IDX_8814B)
#define BIT_CLEAR_STC_INT_IDX_8814B(x) ((x) & (~BITS_STC_INT_IDX_8814B))
#define BIT_GET_STC_INT_IDX_8814B(x) \
(((x) >> BIT_SHIFT_STC_INT_IDX_8814B) & BIT_MASK_STC_INT_IDX_8814B)
#define BIT_SET_STC_INT_IDX_8814B(x, v) \
(BIT_CLEAR_STC_INT_IDX_8814B(x) | BIT_STC_INT_IDX_8814B(v))
#define BIT_SHIFT_STC_INT_REALTIME_CS_8814B 0
#define BIT_MASK_STC_INT_REALTIME_CS_8814B 0x3f
#define BIT_STC_INT_REALTIME_CS_8814B(x) \
(((x) & BIT_MASK_STC_INT_REALTIME_CS_8814B) \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8814B)
#define BITS_STC_INT_REALTIME_CS_8814B \
(BIT_MASK_STC_INT_REALTIME_CS_8814B \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8814B)
#define BIT_CLEAR_STC_INT_REALTIME_CS_8814B(x) \
((x) & (~BITS_STC_INT_REALTIME_CS_8814B))
#define BIT_GET_STC_INT_REALTIME_CS_8814B(x) \
(((x) >> BIT_SHIFT_STC_INT_REALTIME_CS_8814B) & \
BIT_MASK_STC_INT_REALTIME_CS_8814B)
#define BIT_SET_STC_INT_REALTIME_CS_8814B(x, v) \
(BIT_CLEAR_STC_INT_REALTIME_CS_8814B(x) | \
BIT_STC_INT_REALTIME_CS_8814B(v))
/* 2 REG_ST_INT_CFG_8814B(PCIE STATE CHANGE INTERRUPT CONFIGURATION) */
#define BIT_STC_INT_GRP_EN_8814B BIT(31)
#define BIT_SHIFT_STC_INT_EXPECT_LS_8814B 8
#define BIT_MASK_STC_INT_EXPECT_LS_8814B 0x3f
#define BIT_STC_INT_EXPECT_LS_8814B(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_LS_8814B) \
<< BIT_SHIFT_STC_INT_EXPECT_LS_8814B)
#define BITS_STC_INT_EXPECT_LS_8814B \
(BIT_MASK_STC_INT_EXPECT_LS_8814B << BIT_SHIFT_STC_INT_EXPECT_LS_8814B)
#define BIT_CLEAR_STC_INT_EXPECT_LS_8814B(x) \
((x) & (~BITS_STC_INT_EXPECT_LS_8814B))
#define BIT_GET_STC_INT_EXPECT_LS_8814B(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_LS_8814B) & \
BIT_MASK_STC_INT_EXPECT_LS_8814B)
#define BIT_SET_STC_INT_EXPECT_LS_8814B(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_LS_8814B(x) | BIT_STC_INT_EXPECT_LS_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_STC_INT_EXPECT_CS_8814B 0
#define BIT_MASK_STC_INT_EXPECT_CS_8814B 0x3f
#define BIT_STC_INT_EXPECT_CS_8814B(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_CS_8814B) \
<< BIT_SHIFT_STC_INT_EXPECT_CS_8814B)
#define BITS_STC_INT_EXPECT_CS_8814B \
(BIT_MASK_STC_INT_EXPECT_CS_8814B << BIT_SHIFT_STC_INT_EXPECT_CS_8814B)
#define BIT_CLEAR_STC_INT_EXPECT_CS_8814B(x) \
((x) & (~BITS_STC_INT_EXPECT_CS_8814B))
#define BIT_GET_STC_INT_EXPECT_CS_8814B(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_CS_8814B) & \
BIT_MASK_STC_INT_EXPECT_CS_8814B)
#define BIT_SET_STC_INT_EXPECT_CS_8814B(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_CS_8814B(x) | BIT_STC_INT_EXPECT_CS_8814B(v))
/* 2 REG_ACH4_ACH5_TXBD_NUM_8814B */
#define BIT_PCIE_ACH5_FLAG_8814B BIT(30)
#define BIT_SHIFT_ACH5_DESC_MODE_8814B 28
#define BIT_MASK_ACH5_DESC_MODE_8814B 0x3
#define BIT_ACH5_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH5_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH5_DESC_MODE_8814B)
#define BITS_ACH5_DESC_MODE_8814B \
(BIT_MASK_ACH5_DESC_MODE_8814B << BIT_SHIFT_ACH5_DESC_MODE_8814B)
#define BIT_CLEAR_ACH5_DESC_MODE_8814B(x) ((x) & (~BITS_ACH5_DESC_MODE_8814B))
#define BIT_GET_ACH5_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH5_DESC_MODE_8814B) & \
BIT_MASK_ACH5_DESC_MODE_8814B)
#define BIT_SET_ACH5_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH5_DESC_MODE_8814B(x) | BIT_ACH5_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH5_DESC_NUM_8814B 16
#define BIT_MASK_ACH5_DESC_NUM_8814B 0xfff
#define BIT_ACH5_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH5_DESC_NUM_8814B) << BIT_SHIFT_ACH5_DESC_NUM_8814B)
#define BITS_ACH5_DESC_NUM_8814B \
(BIT_MASK_ACH5_DESC_NUM_8814B << BIT_SHIFT_ACH5_DESC_NUM_8814B)
#define BIT_CLEAR_ACH5_DESC_NUM_8814B(x) ((x) & (~BITS_ACH5_DESC_NUM_8814B))
#define BIT_GET_ACH5_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH5_DESC_NUM_8814B) & BIT_MASK_ACH5_DESC_NUM_8814B)
#define BIT_SET_ACH5_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH5_DESC_NUM_8814B(x) | BIT_ACH5_DESC_NUM_8814B(v))
#define BIT_PCIE_ACH4_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH4_DESC_MODE_8814B 12
#define BIT_MASK_ACH4_DESC_MODE_8814B 0x3
#define BIT_ACH4_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH4_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH4_DESC_MODE_8814B)
#define BITS_ACH4_DESC_MODE_8814B \
(BIT_MASK_ACH4_DESC_MODE_8814B << BIT_SHIFT_ACH4_DESC_MODE_8814B)
#define BIT_CLEAR_ACH4_DESC_MODE_8814B(x) ((x) & (~BITS_ACH4_DESC_MODE_8814B))
#define BIT_GET_ACH4_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH4_DESC_MODE_8814B) & \
BIT_MASK_ACH4_DESC_MODE_8814B)
#define BIT_SET_ACH4_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH4_DESC_MODE_8814B(x) | BIT_ACH4_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH4_DESC_NUM_8814B 0
#define BIT_MASK_ACH4_DESC_NUM_8814B 0xfff
#define BIT_ACH4_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH4_DESC_NUM_8814B) << BIT_SHIFT_ACH4_DESC_NUM_8814B)
#define BITS_ACH4_DESC_NUM_8814B \
(BIT_MASK_ACH4_DESC_NUM_8814B << BIT_SHIFT_ACH4_DESC_NUM_8814B)
#define BIT_CLEAR_ACH4_DESC_NUM_8814B(x) ((x) & (~BITS_ACH4_DESC_NUM_8814B))
#define BIT_GET_ACH4_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH4_DESC_NUM_8814B) & BIT_MASK_ACH4_DESC_NUM_8814B)
#define BIT_SET_ACH4_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH4_DESC_NUM_8814B(x) | BIT_ACH4_DESC_NUM_8814B(v))
/* 2 REG_FWCMDQ_TXBD_IDX_8814B */
#define BIT_SHIFT_FWCMDQ_HW_IDX_8814B 16
#define BIT_MASK_FWCMDQ_HW_IDX_8814B 0xfff
#define BIT_FWCMDQ_HW_IDX_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_HW_IDX_8814B) << BIT_SHIFT_FWCMDQ_HW_IDX_8814B)
#define BITS_FWCMDQ_HW_IDX_8814B \
(BIT_MASK_FWCMDQ_HW_IDX_8814B << BIT_SHIFT_FWCMDQ_HW_IDX_8814B)
#define BIT_CLEAR_FWCMDQ_HW_IDX_8814B(x) ((x) & (~BITS_FWCMDQ_HW_IDX_8814B))
#define BIT_GET_FWCMDQ_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_HW_IDX_8814B) & BIT_MASK_FWCMDQ_HW_IDX_8814B)
#define BIT_SET_FWCMDQ_HW_IDX_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_HW_IDX_8814B(x) | BIT_FWCMDQ_HW_IDX_8814B(v))
#define BIT_SHIFT_FWCMDQ_HOST_IDX_8814B 0
#define BIT_MASK_FWCMDQ_HOST_IDX_8814B 0xfff
#define BIT_FWCMDQ_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_HOST_IDX_8814B) \
<< BIT_SHIFT_FWCMDQ_HOST_IDX_8814B)
#define BITS_FWCMDQ_HOST_IDX_8814B \
(BIT_MASK_FWCMDQ_HOST_IDX_8814B << BIT_SHIFT_FWCMDQ_HOST_IDX_8814B)
#define BIT_CLEAR_FWCMDQ_HOST_IDX_8814B(x) ((x) & (~BITS_FWCMDQ_HOST_IDX_8814B))
#define BIT_GET_FWCMDQ_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_HOST_IDX_8814B) & \
BIT_MASK_FWCMDQ_HOST_IDX_8814B)
#define BIT_SET_FWCMDQ_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_HOST_IDX_8814B(x) | BIT_FWCMDQ_HOST_IDX_8814B(v))
/* 2 REG_P0HI8Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI8Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI8Q_HW_IDX_8814B 0xfff
#define BIT_P0HI8Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI8Q_HW_IDX_8814B) << BIT_SHIFT_P0HI8Q_HW_IDX_8814B)
#define BITS_P0HI8Q_HW_IDX_8814B \
(BIT_MASK_P0HI8Q_HW_IDX_8814B << BIT_SHIFT_P0HI8Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI8Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI8Q_HW_IDX_8814B))
#define BIT_GET_P0HI8Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI8Q_HW_IDX_8814B) & BIT_MASK_P0HI8Q_HW_IDX_8814B)
#define BIT_SET_P0HI8Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI8Q_HW_IDX_8814B(x) | BIT_P0HI8Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI8Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI8Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI8Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI8Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI8Q_HOST_IDX_8814B)
#define BITS_P0HI8Q_HOST_IDX_8814B \
(BIT_MASK_P0HI8Q_HOST_IDX_8814B << BIT_SHIFT_P0HI8Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI8Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI8Q_HOST_IDX_8814B))
#define BIT_GET_P0HI8Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI8Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI8Q_HOST_IDX_8814B)
#define BIT_SET_P0HI8Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI8Q_HOST_IDX_8814B(x) | BIT_P0HI8Q_HOST_IDX_8814B(v))
/* 2 REG_H2CQ_TXBD_DESA_L_8814B */
#define BIT_SHIFT_H2CQ_TXBD_DESA_L_8814B 0
#define BIT_MASK_H2CQ_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_H2CQ_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_H2CQ_TXBD_DESA_L_8814B)
#define BITS_H2CQ_TXBD_DESA_L_8814B \
(BIT_MASK_H2CQ_TXBD_DESA_L_8814B << BIT_SHIFT_H2CQ_TXBD_DESA_L_8814B)
#define BIT_CLEAR_H2CQ_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_H2CQ_TXBD_DESA_L_8814B))
#define BIT_GET_H2CQ_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_L_8814B) & \
BIT_MASK_H2CQ_TXBD_DESA_L_8814B)
#define BIT_SET_H2CQ_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_L_8814B(x) | BIT_H2CQ_TXBD_DESA_L_8814B(v))
/* 2 REG_H2CQ_TXBD_DESA_H_8814B */
#define BIT_SHIFT_H2CQ_TXBD_DESA_H_8814B 0
#define BIT_MASK_H2CQ_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_H2CQ_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_H2CQ_TXBD_DESA_H_8814B)
#define BITS_H2CQ_TXBD_DESA_H_8814B \
(BIT_MASK_H2CQ_TXBD_DESA_H_8814B << BIT_SHIFT_H2CQ_TXBD_DESA_H_8814B)
#define BIT_CLEAR_H2CQ_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_H2CQ_TXBD_DESA_H_8814B))
#define BIT_GET_H2CQ_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_H_8814B) & \
BIT_MASK_H2CQ_TXBD_DESA_H_8814B)
#define BIT_SET_H2CQ_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_H_8814B(x) | BIT_H2CQ_TXBD_DESA_H_8814B(v))
/* 2 REG_H2CQ_TXBD_NUM_8814B */
#define BIT_PCIE_H2CQ_FLAG_8814B BIT(14)
#define BIT_SHIFT_H2CQ_DESC_MODE_8814B 12
#define BIT_MASK_H2CQ_DESC_MODE_8814B 0x3
#define BIT_H2CQ_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_H2CQ_DESC_MODE_8814B) \
<< BIT_SHIFT_H2CQ_DESC_MODE_8814B)
#define BITS_H2CQ_DESC_MODE_8814B \
(BIT_MASK_H2CQ_DESC_MODE_8814B << BIT_SHIFT_H2CQ_DESC_MODE_8814B)
#define BIT_CLEAR_H2CQ_DESC_MODE_8814B(x) ((x) & (~BITS_H2CQ_DESC_MODE_8814B))
#define BIT_GET_H2CQ_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_MODE_8814B) & \
BIT_MASK_H2CQ_DESC_MODE_8814B)
#define BIT_SET_H2CQ_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_H2CQ_DESC_MODE_8814B(x) | BIT_H2CQ_DESC_MODE_8814B(v))
#define BIT_SHIFT_H2CQ_DESC_NUM_8814B 0
#define BIT_MASK_H2CQ_DESC_NUM_8814B 0xfff
#define BIT_H2CQ_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_H2CQ_DESC_NUM_8814B) << BIT_SHIFT_H2CQ_DESC_NUM_8814B)
#define BITS_H2CQ_DESC_NUM_8814B \
(BIT_MASK_H2CQ_DESC_NUM_8814B << BIT_SHIFT_H2CQ_DESC_NUM_8814B)
#define BIT_CLEAR_H2CQ_DESC_NUM_8814B(x) ((x) & (~BITS_H2CQ_DESC_NUM_8814B))
#define BIT_GET_H2CQ_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_NUM_8814B) & BIT_MASK_H2CQ_DESC_NUM_8814B)
#define BIT_SET_H2CQ_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_H2CQ_DESC_NUM_8814B(x) | BIT_H2CQ_DESC_NUM_8814B(v))
/* 2 REG_H2CQ_TXBD_IDX_8814B */
#define BIT_SHIFT_H2CQ_HW_IDX_8814B 16
#define BIT_MASK_H2CQ_HW_IDX_8814B 0xfff
#define BIT_H2CQ_HW_IDX_8814B(x) \
(((x) & BIT_MASK_H2CQ_HW_IDX_8814B) << BIT_SHIFT_H2CQ_HW_IDX_8814B)
#define BITS_H2CQ_HW_IDX_8814B \
(BIT_MASK_H2CQ_HW_IDX_8814B << BIT_SHIFT_H2CQ_HW_IDX_8814B)
#define BIT_CLEAR_H2CQ_HW_IDX_8814B(x) ((x) & (~BITS_H2CQ_HW_IDX_8814B))
#define BIT_GET_H2CQ_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_H2CQ_HW_IDX_8814B) & BIT_MASK_H2CQ_HW_IDX_8814B)
#define BIT_SET_H2CQ_HW_IDX_8814B(x, v) \
(BIT_CLEAR_H2CQ_HW_IDX_8814B(x) | BIT_H2CQ_HW_IDX_8814B(v))
#define BIT_SHIFT_H2CQ_HOST_IDX_8814B 0
#define BIT_MASK_H2CQ_HOST_IDX_8814B 0xfff
#define BIT_H2CQ_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_H2CQ_HOST_IDX_8814B) << BIT_SHIFT_H2CQ_HOST_IDX_8814B)
#define BITS_H2CQ_HOST_IDX_8814B \
(BIT_MASK_H2CQ_HOST_IDX_8814B << BIT_SHIFT_H2CQ_HOST_IDX_8814B)
#define BIT_CLEAR_H2CQ_HOST_IDX_8814B(x) ((x) & (~BITS_H2CQ_HOST_IDX_8814B))
#define BIT_GET_H2CQ_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_H2CQ_HOST_IDX_8814B) & BIT_MASK_H2CQ_HOST_IDX_8814B)
#define BIT_SET_H2CQ_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_H2CQ_HOST_IDX_8814B(x) | BIT_H2CQ_HOST_IDX_8814B(v))
/* 2 REG_H2CQ_CSR_8814B[31:0] (H2CQ CONTROL AND STATUS) */
#define BIT_H2CQ_FULL_8814B BIT(31)
#define BIT_CLR_H2CQ_HOST_IDX_8814B BIT(16)
#define BIT_CLR_H2CQ_HW_IDX_8814B BIT(8)
#define BIT_STOP_H2CQ_8814B BIT(0)
/* 2 REG_P0HI9Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI9Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI9Q_HW_IDX_8814B 0xfff
#define BIT_P0HI9Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI9Q_HW_IDX_8814B) << BIT_SHIFT_P0HI9Q_HW_IDX_8814B)
#define BITS_P0HI9Q_HW_IDX_8814B \
(BIT_MASK_P0HI9Q_HW_IDX_8814B << BIT_SHIFT_P0HI9Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI9Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI9Q_HW_IDX_8814B))
#define BIT_GET_P0HI9Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI9Q_HW_IDX_8814B) & BIT_MASK_P0HI9Q_HW_IDX_8814B)
#define BIT_SET_P0HI9Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI9Q_HW_IDX_8814B(x) | BIT_P0HI9Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI9Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI9Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI9Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI9Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI9Q_HOST_IDX_8814B)
#define BITS_P0HI9Q_HOST_IDX_8814B \
(BIT_MASK_P0HI9Q_HOST_IDX_8814B << BIT_SHIFT_P0HI9Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI9Q_HOST_IDX_8814B(x) ((x) & (~BITS_P0HI9Q_HOST_IDX_8814B))
#define BIT_GET_P0HI9Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI9Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI9Q_HOST_IDX_8814B)
#define BIT_SET_P0HI9Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI9Q_HOST_IDX_8814B(x) | BIT_P0HI9Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI10Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI10Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI10Q_HW_IDX_8814B 0xfff
#define BIT_P0HI10Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI10Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI10Q_HW_IDX_8814B)
#define BITS_P0HI10Q_HW_IDX_8814B \
(BIT_MASK_P0HI10Q_HW_IDX_8814B << BIT_SHIFT_P0HI10Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI10Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI10Q_HW_IDX_8814B))
#define BIT_GET_P0HI10Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI10Q_HW_IDX_8814B) & \
BIT_MASK_P0HI10Q_HW_IDX_8814B)
#define BIT_SET_P0HI10Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI10Q_HW_IDX_8814B(x) | BIT_P0HI10Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI10Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI10Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI10Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI10Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI10Q_HOST_IDX_8814B)
#define BITS_P0HI10Q_HOST_IDX_8814B \
(BIT_MASK_P0HI10Q_HOST_IDX_8814B << BIT_SHIFT_P0HI10Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI10Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI10Q_HOST_IDX_8814B))
#define BIT_GET_P0HI10Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI10Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI10Q_HOST_IDX_8814B)
#define BIT_SET_P0HI10Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI10Q_HOST_IDX_8814B(x) | BIT_P0HI10Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI11Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI11Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI11Q_HW_IDX_8814B 0xfff
#define BIT_P0HI11Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI11Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI11Q_HW_IDX_8814B)
#define BITS_P0HI11Q_HW_IDX_8814B \
(BIT_MASK_P0HI11Q_HW_IDX_8814B << BIT_SHIFT_P0HI11Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI11Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI11Q_HW_IDX_8814B))
#define BIT_GET_P0HI11Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI11Q_HW_IDX_8814B) & \
BIT_MASK_P0HI11Q_HW_IDX_8814B)
#define BIT_SET_P0HI11Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI11Q_HW_IDX_8814B(x) | BIT_P0HI11Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI11Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI11Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI11Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI11Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI11Q_HOST_IDX_8814B)
#define BITS_P0HI11Q_HOST_IDX_8814B \
(BIT_MASK_P0HI11Q_HOST_IDX_8814B << BIT_SHIFT_P0HI11Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI11Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI11Q_HOST_IDX_8814B))
#define BIT_GET_P0HI11Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI11Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI11Q_HOST_IDX_8814B)
#define BIT_SET_P0HI11Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI11Q_HOST_IDX_8814B(x) | BIT_P0HI11Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI12Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI12Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI12Q_HW_IDX_8814B 0xfff
#define BIT_P0HI12Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI12Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI12Q_HW_IDX_8814B)
#define BITS_P0HI12Q_HW_IDX_8814B \
(BIT_MASK_P0HI12Q_HW_IDX_8814B << BIT_SHIFT_P0HI12Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI12Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI12Q_HW_IDX_8814B))
#define BIT_GET_P0HI12Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI12Q_HW_IDX_8814B) & \
BIT_MASK_P0HI12Q_HW_IDX_8814B)
#define BIT_SET_P0HI12Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI12Q_HW_IDX_8814B(x) | BIT_P0HI12Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI12Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI12Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI12Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI12Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI12Q_HOST_IDX_8814B)
#define BITS_P0HI12Q_HOST_IDX_8814B \
(BIT_MASK_P0HI12Q_HOST_IDX_8814B << BIT_SHIFT_P0HI12Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI12Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI12Q_HOST_IDX_8814B))
#define BIT_GET_P0HI12Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI12Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI12Q_HOST_IDX_8814B)
#define BIT_SET_P0HI12Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI12Q_HOST_IDX_8814B(x) | BIT_P0HI12Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI13Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI13Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI13Q_HW_IDX_8814B 0xfff
#define BIT_P0HI13Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI13Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI13Q_HW_IDX_8814B)
#define BITS_P0HI13Q_HW_IDX_8814B \
(BIT_MASK_P0HI13Q_HW_IDX_8814B << BIT_SHIFT_P0HI13Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI13Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI13Q_HW_IDX_8814B))
#define BIT_GET_P0HI13Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI13Q_HW_IDX_8814B) & \
BIT_MASK_P0HI13Q_HW_IDX_8814B)
#define BIT_SET_P0HI13Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI13Q_HW_IDX_8814B(x) | BIT_P0HI13Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI13Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI13Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI13Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI13Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI13Q_HOST_IDX_8814B)
#define BITS_P0HI13Q_HOST_IDX_8814B \
(BIT_MASK_P0HI13Q_HOST_IDX_8814B << BIT_SHIFT_P0HI13Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI13Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI13Q_HOST_IDX_8814B))
#define BIT_GET_P0HI13Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI13Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI13Q_HOST_IDX_8814B)
#define BIT_SET_P0HI13Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI13Q_HOST_IDX_8814B(x) | BIT_P0HI13Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI14Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI14Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI14Q_HW_IDX_8814B 0xfff
#define BIT_P0HI14Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI14Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI14Q_HW_IDX_8814B)
#define BITS_P0HI14Q_HW_IDX_8814B \
(BIT_MASK_P0HI14Q_HW_IDX_8814B << BIT_SHIFT_P0HI14Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI14Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI14Q_HW_IDX_8814B))
#define BIT_GET_P0HI14Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI14Q_HW_IDX_8814B) & \
BIT_MASK_P0HI14Q_HW_IDX_8814B)
#define BIT_SET_P0HI14Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI14Q_HW_IDX_8814B(x) | BIT_P0HI14Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI14Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI14Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI14Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI14Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI14Q_HOST_IDX_8814B)
#define BITS_P0HI14Q_HOST_IDX_8814B \
(BIT_MASK_P0HI14Q_HOST_IDX_8814B << BIT_SHIFT_P0HI14Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI14Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI14Q_HOST_IDX_8814B))
#define BIT_GET_P0HI14Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI14Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI14Q_HOST_IDX_8814B)
#define BIT_SET_P0HI14Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI14Q_HOST_IDX_8814B(x) | BIT_P0HI14Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI15Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI15Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI15Q_HW_IDX_8814B 0xfff
#define BIT_P0HI15Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI15Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI15Q_HW_IDX_8814B)
#define BITS_P0HI15Q_HW_IDX_8814B \
(BIT_MASK_P0HI15Q_HW_IDX_8814B << BIT_SHIFT_P0HI15Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI15Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI15Q_HW_IDX_8814B))
#define BIT_GET_P0HI15Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI15Q_HW_IDX_8814B) & \
BIT_MASK_P0HI15Q_HW_IDX_8814B)
#define BIT_SET_P0HI15Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI15Q_HW_IDX_8814B(x) | BIT_P0HI15Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI15Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI15Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI15Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI15Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI15Q_HOST_IDX_8814B)
#define BITS_P0HI15Q_HOST_IDX_8814B \
(BIT_MASK_P0HI15Q_HOST_IDX_8814B << BIT_SHIFT_P0HI15Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI15Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI15Q_HOST_IDX_8814B))
#define BIT_GET_P0HI15Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI15Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI15Q_HOST_IDX_8814B)
#define BIT_SET_P0HI15Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI15Q_HOST_IDX_8814B(x) | BIT_P0HI15Q_HOST_IDX_8814B(v))
/* 2 REG_CHANGE_PCIE_SPEED_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_RXDMA_ERR_CNT_8814B 8
#define BIT_MASK_RXDMA_ERR_CNT_8814B 0xff
#define BIT_RXDMA_ERR_CNT_8814B(x) \
(((x) & BIT_MASK_RXDMA_ERR_CNT_8814B) << BIT_SHIFT_RXDMA_ERR_CNT_8814B)
#define BITS_RXDMA_ERR_CNT_8814B \
(BIT_MASK_RXDMA_ERR_CNT_8814B << BIT_SHIFT_RXDMA_ERR_CNT_8814B)
#define BIT_CLEAR_RXDMA_ERR_CNT_8814B(x) ((x) & (~BITS_RXDMA_ERR_CNT_8814B))
#define BIT_GET_RXDMA_ERR_CNT_8814B(x) \
(((x) >> BIT_SHIFT_RXDMA_ERR_CNT_8814B) & BIT_MASK_RXDMA_ERR_CNT_8814B)
#define BIT_SET_RXDMA_ERR_CNT_8814B(x, v) \
(BIT_CLEAR_RXDMA_ERR_CNT_8814B(x) | BIT_RXDMA_ERR_CNT_8814B(v))
#define BIT_TXDMA_ERR_HANDLE_REQ_8814B BIT(7)
#define BIT_TXDMA_ERROR_PS_8814B BIT(6)
#define BIT_EN_TXDMA_STUCK_ERR_HANDLE_8814B BIT(5)
#define BIT_EN_TXDMA_RTN_ERR_HANDLE_8814B BIT(4)
#define BIT_RXDMA_ERR_HANDLE_REQ_8814B BIT(3)
#define BIT_RXDMA_ERROR_PS_8814B BIT(2)
#define BIT_EN_RXDMA_STUCK_ERR_HANDLE_8814B BIT(1)
#define BIT_EN_RXDMA_RTN_ERR_HANDLE_8814B BIT(0)
/* 2 REG_DEBUG_STATE1_8814B */
#define BIT_SHIFT_DEBUG_STATE1_8814B 0
#define BIT_MASK_DEBUG_STATE1_8814B 0xffffffffL
#define BIT_DEBUG_STATE1_8814B(x) \
(((x) & BIT_MASK_DEBUG_STATE1_8814B) << BIT_SHIFT_DEBUG_STATE1_8814B)
#define BITS_DEBUG_STATE1_8814B \
(BIT_MASK_DEBUG_STATE1_8814B << BIT_SHIFT_DEBUG_STATE1_8814B)
#define BIT_CLEAR_DEBUG_STATE1_8814B(x) ((x) & (~BITS_DEBUG_STATE1_8814B))
#define BIT_GET_DEBUG_STATE1_8814B(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE1_8814B) & BIT_MASK_DEBUG_STATE1_8814B)
#define BIT_SET_DEBUG_STATE1_8814B(x, v) \
(BIT_CLEAR_DEBUG_STATE1_8814B(x) | BIT_DEBUG_STATE1_8814B(v))
/* 2 REG_DEBUG_STATE2_8814B */
#define BIT_SHIFT_DEBUG_STATE2_8814B 0
#define BIT_MASK_DEBUG_STATE2_8814B 0xffffffffL
#define BIT_DEBUG_STATE2_8814B(x) \
(((x) & BIT_MASK_DEBUG_STATE2_8814B) << BIT_SHIFT_DEBUG_STATE2_8814B)
#define BITS_DEBUG_STATE2_8814B \
(BIT_MASK_DEBUG_STATE2_8814B << BIT_SHIFT_DEBUG_STATE2_8814B)
#define BIT_CLEAR_DEBUG_STATE2_8814B(x) ((x) & (~BITS_DEBUG_STATE2_8814B))
#define BIT_GET_DEBUG_STATE2_8814B(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE2_8814B) & BIT_MASK_DEBUG_STATE2_8814B)
#define BIT_SET_DEBUG_STATE2_8814B(x, v) \
(BIT_CLEAR_DEBUG_STATE2_8814B(x) | BIT_DEBUG_STATE2_8814B(v))
/* 2 REG_DEBUG_STATE3_8814B */
#define BIT_SHIFT_DEBUG_STATE3_8814B 0
#define BIT_MASK_DEBUG_STATE3_8814B 0xffffffffL
#define BIT_DEBUG_STATE3_8814B(x) \
(((x) & BIT_MASK_DEBUG_STATE3_8814B) << BIT_SHIFT_DEBUG_STATE3_8814B)
#define BITS_DEBUG_STATE3_8814B \
(BIT_MASK_DEBUG_STATE3_8814B << BIT_SHIFT_DEBUG_STATE3_8814B)
#define BIT_CLEAR_DEBUG_STATE3_8814B(x) ((x) & (~BITS_DEBUG_STATE3_8814B))
#define BIT_GET_DEBUG_STATE3_8814B(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE3_8814B) & BIT_MASK_DEBUG_STATE3_8814B)
#define BIT_SET_DEBUG_STATE3_8814B(x, v) \
(BIT_CLEAR_DEBUG_STATE3_8814B(x) | BIT_DEBUG_STATE3_8814B(v))
/* 2 REG_ACH5_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH5_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH5_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH5_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH5_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH5_TXBD_DESA_L_8814B)
#define BITS_ACH5_TXBD_DESA_L_8814B \
(BIT_MASK_ACH5_TXBD_DESA_L_8814B << BIT_SHIFT_ACH5_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH5_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH5_TXBD_DESA_L_8814B))
#define BIT_GET_ACH5_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH5_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH5_TXBD_DESA_L_8814B)
#define BIT_SET_ACH5_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH5_TXBD_DESA_L_8814B(x) | BIT_ACH5_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH5_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH5_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH5_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH5_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH5_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH5_TXBD_DESA_H_8814B)
#define BITS_ACH5_TXBD_DESA_H_8814B \
(BIT_MASK_ACH5_TXBD_DESA_H_8814B << BIT_SHIFT_ACH5_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH5_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH5_TXBD_DESA_H_8814B))
#define BIT_GET_ACH5_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH5_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH5_TXBD_DESA_H_8814B)
#define BIT_SET_ACH5_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH5_TXBD_DESA_H_8814B(x) | BIT_ACH5_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH6_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH6_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH6_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH6_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH6_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH6_TXBD_DESA_L_8814B)
#define BITS_ACH6_TXBD_DESA_L_8814B \
(BIT_MASK_ACH6_TXBD_DESA_L_8814B << BIT_SHIFT_ACH6_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH6_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH6_TXBD_DESA_L_8814B))
#define BIT_GET_ACH6_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH6_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH6_TXBD_DESA_L_8814B)
#define BIT_SET_ACH6_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH6_TXBD_DESA_L_8814B(x) | BIT_ACH6_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH6_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH6_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH6_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH6_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH6_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH6_TXBD_DESA_H_8814B)
#define BITS_ACH6_TXBD_DESA_H_8814B \
(BIT_MASK_ACH6_TXBD_DESA_H_8814B << BIT_SHIFT_ACH6_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH6_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH6_TXBD_DESA_H_8814B))
#define BIT_GET_ACH6_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH6_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH6_TXBD_DESA_H_8814B)
#define BIT_SET_ACH6_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH6_TXBD_DESA_H_8814B(x) | BIT_ACH6_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH7_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH7_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH7_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH7_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH7_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH7_TXBD_DESA_L_8814B)
#define BITS_ACH7_TXBD_DESA_L_8814B \
(BIT_MASK_ACH7_TXBD_DESA_L_8814B << BIT_SHIFT_ACH7_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH7_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH7_TXBD_DESA_L_8814B))
#define BIT_GET_ACH7_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH7_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH7_TXBD_DESA_L_8814B)
#define BIT_SET_ACH7_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH7_TXBD_DESA_L_8814B(x) | BIT_ACH7_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH7_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH7_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH7_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH7_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH7_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH7_TXBD_DESA_H_8814B)
#define BITS_ACH7_TXBD_DESA_H_8814B \
(BIT_MASK_ACH7_TXBD_DESA_H_8814B << BIT_SHIFT_ACH7_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH7_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH7_TXBD_DESA_H_8814B))
#define BIT_GET_ACH7_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH7_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH7_TXBD_DESA_H_8814B)
#define BIT_SET_ACH7_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH7_TXBD_DESA_H_8814B(x) | BIT_ACH7_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH8_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH8_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH8_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH8_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH8_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH8_TXBD_DESA_L_8814B)
#define BITS_ACH8_TXBD_DESA_L_8814B \
(BIT_MASK_ACH8_TXBD_DESA_L_8814B << BIT_SHIFT_ACH8_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH8_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH8_TXBD_DESA_L_8814B))
#define BIT_GET_ACH8_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH8_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH8_TXBD_DESA_L_8814B)
#define BIT_SET_ACH8_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH8_TXBD_DESA_L_8814B(x) | BIT_ACH8_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH8_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH8_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH8_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH8_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH8_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH8_TXBD_DESA_H_8814B)
#define BITS_ACH8_TXBD_DESA_H_8814B \
(BIT_MASK_ACH8_TXBD_DESA_H_8814B << BIT_SHIFT_ACH8_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH8_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH8_TXBD_DESA_H_8814B))
#define BIT_GET_ACH8_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH8_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH8_TXBD_DESA_H_8814B)
#define BIT_SET_ACH8_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH8_TXBD_DESA_H_8814B(x) | BIT_ACH8_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH9_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH9_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH9_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH9_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH9_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH9_TXBD_DESA_L_8814B)
#define BITS_ACH9_TXBD_DESA_L_8814B \
(BIT_MASK_ACH9_TXBD_DESA_L_8814B << BIT_SHIFT_ACH9_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH9_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH9_TXBD_DESA_L_8814B))
#define BIT_GET_ACH9_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH9_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH9_TXBD_DESA_L_8814B)
#define BIT_SET_ACH9_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH9_TXBD_DESA_L_8814B(x) | BIT_ACH9_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH9_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH9_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH9_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH9_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH9_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH9_TXBD_DESA_H_8814B)
#define BITS_ACH9_TXBD_DESA_H_8814B \
(BIT_MASK_ACH9_TXBD_DESA_H_8814B << BIT_SHIFT_ACH9_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH9_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH9_TXBD_DESA_H_8814B))
#define BIT_GET_ACH9_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH9_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH9_TXBD_DESA_H_8814B)
#define BIT_SET_ACH9_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH9_TXBD_DESA_H_8814B(x) | BIT_ACH9_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH10_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH10_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH10_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH10_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH10_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH10_TXBD_DESA_L_8814B)
#define BITS_ACH10_TXBD_DESA_L_8814B \
(BIT_MASK_ACH10_TXBD_DESA_L_8814B << BIT_SHIFT_ACH10_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH10_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH10_TXBD_DESA_L_8814B))
#define BIT_GET_ACH10_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH10_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH10_TXBD_DESA_L_8814B)
#define BIT_SET_ACH10_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH10_TXBD_DESA_L_8814B(x) | BIT_ACH10_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH10_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH10_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH10_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH10_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH10_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH10_TXBD_DESA_H_8814B)
#define BITS_ACH10_TXBD_DESA_H_8814B \
(BIT_MASK_ACH10_TXBD_DESA_H_8814B << BIT_SHIFT_ACH10_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH10_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH10_TXBD_DESA_H_8814B))
#define BIT_GET_ACH10_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH10_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH10_TXBD_DESA_H_8814B)
#define BIT_SET_ACH10_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH10_TXBD_DESA_H_8814B(x) | BIT_ACH10_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH11_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH11_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH11_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH11_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH11_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH11_TXBD_DESA_L_8814B)
#define BITS_ACH11_TXBD_DESA_L_8814B \
(BIT_MASK_ACH11_TXBD_DESA_L_8814B << BIT_SHIFT_ACH11_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH11_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH11_TXBD_DESA_L_8814B))
#define BIT_GET_ACH11_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH11_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH11_TXBD_DESA_L_8814B)
#define BIT_SET_ACH11_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH11_TXBD_DESA_L_8814B(x) | BIT_ACH11_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH11_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH11_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH11_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH11_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH11_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH11_TXBD_DESA_H_8814B)
#define BITS_ACH11_TXBD_DESA_H_8814B \
(BIT_MASK_ACH11_TXBD_DESA_H_8814B << BIT_SHIFT_ACH11_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH11_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH11_TXBD_DESA_H_8814B))
#define BIT_GET_ACH11_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH11_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH11_TXBD_DESA_H_8814B)
#define BIT_SET_ACH11_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH11_TXBD_DESA_H_8814B(x) | BIT_ACH11_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH12_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH12_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH12_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH12_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH12_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH12_TXBD_DESA_L_8814B)
#define BITS_ACH12_TXBD_DESA_L_8814B \
(BIT_MASK_ACH12_TXBD_DESA_L_8814B << BIT_SHIFT_ACH12_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH12_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH12_TXBD_DESA_L_8814B))
#define BIT_GET_ACH12_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH12_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH12_TXBD_DESA_L_8814B)
#define BIT_SET_ACH12_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH12_TXBD_DESA_L_8814B(x) | BIT_ACH12_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH12_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH12_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH12_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH12_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH12_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH12_TXBD_DESA_H_8814B)
#define BITS_ACH12_TXBD_DESA_H_8814B \
(BIT_MASK_ACH12_TXBD_DESA_H_8814B << BIT_SHIFT_ACH12_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH12_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH12_TXBD_DESA_H_8814B))
#define BIT_GET_ACH12_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH12_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH12_TXBD_DESA_H_8814B)
#define BIT_SET_ACH12_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH12_TXBD_DESA_H_8814B(x) | BIT_ACH12_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH13_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH13_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH13_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH13_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH13_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH13_TXBD_DESA_L_8814B)
#define BITS_ACH13_TXBD_DESA_L_8814B \
(BIT_MASK_ACH13_TXBD_DESA_L_8814B << BIT_SHIFT_ACH13_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH13_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH13_TXBD_DESA_L_8814B))
#define BIT_GET_ACH13_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH13_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH13_TXBD_DESA_L_8814B)
#define BIT_SET_ACH13_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH13_TXBD_DESA_L_8814B(x) | BIT_ACH13_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH13_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH13_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH13_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH13_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH13_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH13_TXBD_DESA_H_8814B)
#define BITS_ACH13_TXBD_DESA_H_8814B \
(BIT_MASK_ACH13_TXBD_DESA_H_8814B << BIT_SHIFT_ACH13_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH13_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH13_TXBD_DESA_H_8814B))
#define BIT_GET_ACH13_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH13_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH13_TXBD_DESA_H_8814B)
#define BIT_SET_ACH13_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH13_TXBD_DESA_H_8814B(x) | BIT_ACH13_TXBD_DESA_H_8814B(v))
/* 2 REG_HI0Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI0Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI0Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI0Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI0Q_TXBD_DESA_L_8814B)
#define BITS_HI0Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI0Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI0Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI0Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI0Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI0Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI0Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI0Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_L_8814B(x) | BIT_HI0Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI0Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI0Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI0Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI0Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI0Q_TXBD_DESA_H_8814B)
#define BITS_HI0Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI0Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI0Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI0Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI0Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI0Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI0Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI0Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_H_8814B(x) | BIT_HI0Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI1Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI1Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI1Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI1Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI1Q_TXBD_DESA_L_8814B)
#define BITS_HI1Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI1Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI1Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI1Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI1Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI1Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI1Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI1Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_L_8814B(x) | BIT_HI1Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI1Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI1Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI1Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI1Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI1Q_TXBD_DESA_H_8814B)
#define BITS_HI1Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI1Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI1Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI1Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI1Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI1Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI1Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI1Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_H_8814B(x) | BIT_HI1Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI2Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI2Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI2Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI2Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI2Q_TXBD_DESA_L_8814B)
#define BITS_HI2Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI2Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI2Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI2Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI2Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI2Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI2Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI2Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_L_8814B(x) | BIT_HI2Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI2Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI2Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI2Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI2Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI2Q_TXBD_DESA_H_8814B)
#define BITS_HI2Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI2Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI2Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI2Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI2Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI2Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI2Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI2Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_H_8814B(x) | BIT_HI2Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI3Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI3Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI3Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI3Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI3Q_TXBD_DESA_L_8814B)
#define BITS_HI3Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI3Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI3Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI3Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI3Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI3Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI3Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI3Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_L_8814B(x) | BIT_HI3Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI3Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI3Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI3Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI3Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI3Q_TXBD_DESA_H_8814B)
#define BITS_HI3Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI3Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI3Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI3Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI3Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI3Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI3Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI3Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_H_8814B(x) | BIT_HI3Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI4Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI4Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI4Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI4Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI4Q_TXBD_DESA_L_8814B)
#define BITS_HI4Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI4Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI4Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI4Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI4Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI4Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI4Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI4Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_L_8814B(x) | BIT_HI4Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI4Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI4Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI4Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI4Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI4Q_TXBD_DESA_H_8814B)
#define BITS_HI4Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI4Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI4Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI4Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI4Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI4Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI4Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI4Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_H_8814B(x) | BIT_HI4Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI5Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI5Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI5Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI5Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI5Q_TXBD_DESA_L_8814B)
#define BITS_HI5Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI5Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI5Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI5Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI5Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI5Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI5Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI5Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_L_8814B(x) | BIT_HI5Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI5Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI5Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI5Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI5Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI5Q_TXBD_DESA_H_8814B)
#define BITS_HI5Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI5Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI5Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI5Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI5Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI5Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI5Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI5Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_H_8814B(x) | BIT_HI5Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI6Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI6Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI6Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI6Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI6Q_TXBD_DESA_L_8814B)
#define BITS_HI6Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI6Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI6Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI6Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI6Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI6Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI6Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI6Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_L_8814B(x) | BIT_HI6Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI6Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI6Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI6Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI6Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI6Q_TXBD_DESA_H_8814B)
#define BITS_HI6Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI6Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI6Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI6Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI6Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI6Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI6Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI6Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_H_8814B(x) | BIT_HI6Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI7Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI7Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI7Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI7Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI7Q_TXBD_DESA_L_8814B)
#define BITS_HI7Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI7Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI7Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI7Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI7Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI7Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI7Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI7Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_L_8814B(x) | BIT_HI7Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI7Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI7Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI7Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI7Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI7Q_TXBD_DESA_H_8814B)
#define BITS_HI7Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI7Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI7Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI7Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI7Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI7Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI7Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI7Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_H_8814B(x) | BIT_HI7Q_TXBD_DESA_H_8814B(v))
/* 2 REG_ACH8_ACH9_TXBD_NUM_8814B */
#define BIT_PCIE_ACH9_FLAG_8814B BIT(30)
#define BIT_SHIFT_ACH9_DESC_MODE_8814B 28
#define BIT_MASK_ACH9_DESC_MODE_8814B 0x3
#define BIT_ACH9_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH9_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH9_DESC_MODE_8814B)
#define BITS_ACH9_DESC_MODE_8814B \
(BIT_MASK_ACH9_DESC_MODE_8814B << BIT_SHIFT_ACH9_DESC_MODE_8814B)
#define BIT_CLEAR_ACH9_DESC_MODE_8814B(x) ((x) & (~BITS_ACH9_DESC_MODE_8814B))
#define BIT_GET_ACH9_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH9_DESC_MODE_8814B) & \
BIT_MASK_ACH9_DESC_MODE_8814B)
#define BIT_SET_ACH9_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH9_DESC_MODE_8814B(x) | BIT_ACH9_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH9_DESC_NUM_8814B 16
#define BIT_MASK_ACH9_DESC_NUM_8814B 0xfff
#define BIT_ACH9_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH9_DESC_NUM_8814B) << BIT_SHIFT_ACH9_DESC_NUM_8814B)
#define BITS_ACH9_DESC_NUM_8814B \
(BIT_MASK_ACH9_DESC_NUM_8814B << BIT_SHIFT_ACH9_DESC_NUM_8814B)
#define BIT_CLEAR_ACH9_DESC_NUM_8814B(x) ((x) & (~BITS_ACH9_DESC_NUM_8814B))
#define BIT_GET_ACH9_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH9_DESC_NUM_8814B) & BIT_MASK_ACH9_DESC_NUM_8814B)
#define BIT_SET_ACH9_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH9_DESC_NUM_8814B(x) | BIT_ACH9_DESC_NUM_8814B(v))
#define BIT_PCIE_ACH8_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH8_DESC_MODE_8814B 12
#define BIT_MASK_ACH8_DESC_MODE_8814B 0x3
#define BIT_ACH8_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH8_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH8_DESC_MODE_8814B)
#define BITS_ACH8_DESC_MODE_8814B \
(BIT_MASK_ACH8_DESC_MODE_8814B << BIT_SHIFT_ACH8_DESC_MODE_8814B)
#define BIT_CLEAR_ACH8_DESC_MODE_8814B(x) ((x) & (~BITS_ACH8_DESC_MODE_8814B))
#define BIT_GET_ACH8_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH8_DESC_MODE_8814B) & \
BIT_MASK_ACH8_DESC_MODE_8814B)
#define BIT_SET_ACH8_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH8_DESC_MODE_8814B(x) | BIT_ACH8_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH8_DESC_NUM_8814B 0
#define BIT_MASK_ACH8_DESC_NUM_8814B 0xfff
#define BIT_ACH8_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH8_DESC_NUM_8814B) << BIT_SHIFT_ACH8_DESC_NUM_8814B)
#define BITS_ACH8_DESC_NUM_8814B \
(BIT_MASK_ACH8_DESC_NUM_8814B << BIT_SHIFT_ACH8_DESC_NUM_8814B)
#define BIT_CLEAR_ACH8_DESC_NUM_8814B(x) ((x) & (~BITS_ACH8_DESC_NUM_8814B))
#define BIT_GET_ACH8_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH8_DESC_NUM_8814B) & BIT_MASK_ACH8_DESC_NUM_8814B)
#define BIT_SET_ACH8_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH8_DESC_NUM_8814B(x) | BIT_ACH8_DESC_NUM_8814B(v))
/* 2 REG_ACH10_ACH11_TXBD_NUM_8814B */
#define BIT_PCIE_ACH11_FLAG_8814B BIT(30)
#define BIT_SHIFT_ACH11_DESC_MODE_8814B 28
#define BIT_MASK_ACH11_DESC_MODE_8814B 0x3
#define BIT_ACH11_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH11_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH11_DESC_MODE_8814B)
#define BITS_ACH11_DESC_MODE_8814B \
(BIT_MASK_ACH11_DESC_MODE_8814B << BIT_SHIFT_ACH11_DESC_MODE_8814B)
#define BIT_CLEAR_ACH11_DESC_MODE_8814B(x) ((x) & (~BITS_ACH11_DESC_MODE_8814B))
#define BIT_GET_ACH11_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH11_DESC_MODE_8814B) & \
BIT_MASK_ACH11_DESC_MODE_8814B)
#define BIT_SET_ACH11_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH11_DESC_MODE_8814B(x) | BIT_ACH11_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH11_DESC_NUM_8814B 16
#define BIT_MASK_ACH11_DESC_NUM_8814B 0xfff
#define BIT_ACH11_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH11_DESC_NUM_8814B) \
<< BIT_SHIFT_ACH11_DESC_NUM_8814B)
#define BITS_ACH11_DESC_NUM_8814B \
(BIT_MASK_ACH11_DESC_NUM_8814B << BIT_SHIFT_ACH11_DESC_NUM_8814B)
#define BIT_CLEAR_ACH11_DESC_NUM_8814B(x) ((x) & (~BITS_ACH11_DESC_NUM_8814B))
#define BIT_GET_ACH11_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH11_DESC_NUM_8814B) & \
BIT_MASK_ACH11_DESC_NUM_8814B)
#define BIT_SET_ACH11_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH11_DESC_NUM_8814B(x) | BIT_ACH11_DESC_NUM_8814B(v))
#define BIT_PCIE_ACH10_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH10_DESC_MODE_8814B 12
#define BIT_MASK_ACH10_DESC_MODE_8814B 0x3
#define BIT_ACH10_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH10_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH10_DESC_MODE_8814B)
#define BITS_ACH10_DESC_MODE_8814B \
(BIT_MASK_ACH10_DESC_MODE_8814B << BIT_SHIFT_ACH10_DESC_MODE_8814B)
#define BIT_CLEAR_ACH10_DESC_MODE_8814B(x) ((x) & (~BITS_ACH10_DESC_MODE_8814B))
#define BIT_GET_ACH10_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH10_DESC_MODE_8814B) & \
BIT_MASK_ACH10_DESC_MODE_8814B)
#define BIT_SET_ACH10_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH10_DESC_MODE_8814B(x) | BIT_ACH10_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH10_DESC_NUM_8814B 0
#define BIT_MASK_ACH10_DESC_NUM_8814B 0xfff
#define BIT_ACH10_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH10_DESC_NUM_8814B) \
<< BIT_SHIFT_ACH10_DESC_NUM_8814B)
#define BITS_ACH10_DESC_NUM_8814B \
(BIT_MASK_ACH10_DESC_NUM_8814B << BIT_SHIFT_ACH10_DESC_NUM_8814B)
#define BIT_CLEAR_ACH10_DESC_NUM_8814B(x) ((x) & (~BITS_ACH10_DESC_NUM_8814B))
#define BIT_GET_ACH10_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH10_DESC_NUM_8814B) & \
BIT_MASK_ACH10_DESC_NUM_8814B)
#define BIT_SET_ACH10_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH10_DESC_NUM_8814B(x) | BIT_ACH10_DESC_NUM_8814B(v))
/* 2 REG_ACH12_ACH13_TXBD_NUM_8814B */
#define BIT_PCIE_ACH13_FLAG_8814B BIT(30)
#define BIT_SHIFT_ACH13_DESC_MODE_8814B 28
#define BIT_MASK_ACH13_DESC_MODE_8814B 0x3
#define BIT_ACH13_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH13_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH13_DESC_MODE_8814B)
#define BITS_ACH13_DESC_MODE_8814B \
(BIT_MASK_ACH13_DESC_MODE_8814B << BIT_SHIFT_ACH13_DESC_MODE_8814B)
#define BIT_CLEAR_ACH13_DESC_MODE_8814B(x) ((x) & (~BITS_ACH13_DESC_MODE_8814B))
#define BIT_GET_ACH13_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH13_DESC_MODE_8814B) & \
BIT_MASK_ACH13_DESC_MODE_8814B)
#define BIT_SET_ACH13_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH13_DESC_MODE_8814B(x) | BIT_ACH13_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH13_DESC_NUM_8814B 16
#define BIT_MASK_ACH13_DESC_NUM_8814B 0xfff
#define BIT_ACH13_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH13_DESC_NUM_8814B) \
<< BIT_SHIFT_ACH13_DESC_NUM_8814B)
#define BITS_ACH13_DESC_NUM_8814B \
(BIT_MASK_ACH13_DESC_NUM_8814B << BIT_SHIFT_ACH13_DESC_NUM_8814B)
#define BIT_CLEAR_ACH13_DESC_NUM_8814B(x) ((x) & (~BITS_ACH13_DESC_NUM_8814B))
#define BIT_GET_ACH13_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH13_DESC_NUM_8814B) & \
BIT_MASK_ACH13_DESC_NUM_8814B)
#define BIT_SET_ACH13_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH13_DESC_NUM_8814B(x) | BIT_ACH13_DESC_NUM_8814B(v))
#define BIT_PCIE_ACH12_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH12_DESC_MODE_8814B 12
#define BIT_MASK_ACH12_DESC_MODE_8814B 0x3
#define BIT_ACH12_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH12_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH12_DESC_MODE_8814B)
#define BITS_ACH12_DESC_MODE_8814B \
(BIT_MASK_ACH12_DESC_MODE_8814B << BIT_SHIFT_ACH12_DESC_MODE_8814B)
#define BIT_CLEAR_ACH12_DESC_MODE_8814B(x) ((x) & (~BITS_ACH12_DESC_MODE_8814B))
#define BIT_GET_ACH12_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH12_DESC_MODE_8814B) & \
BIT_MASK_ACH12_DESC_MODE_8814B)
#define BIT_SET_ACH12_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH12_DESC_MODE_8814B(x) | BIT_ACH12_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH12_DESC_NUM_8814B 0
#define BIT_MASK_ACH12_DESC_NUM_8814B 0xfff
#define BIT_ACH12_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH12_DESC_NUM_8814B) \
<< BIT_SHIFT_ACH12_DESC_NUM_8814B)
#define BITS_ACH12_DESC_NUM_8814B \
(BIT_MASK_ACH12_DESC_NUM_8814B << BIT_SHIFT_ACH12_DESC_NUM_8814B)
#define BIT_CLEAR_ACH12_DESC_NUM_8814B(x) ((x) & (~BITS_ACH12_DESC_NUM_8814B))
#define BIT_GET_ACH12_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH12_DESC_NUM_8814B) & \
BIT_MASK_ACH12_DESC_NUM_8814B)
#define BIT_SET_ACH12_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH12_DESC_NUM_8814B(x) | BIT_ACH12_DESC_NUM_8814B(v))
/* 2 REG_OLD_DEHANG_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_OLD_DEHANG_8814B BIT(1)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ACH4_TXBD_DESA_L_8814B */
#define BIT_SHIFT_ACH4_TXBD_DESA_L_8814B 0
#define BIT_MASK_ACH4_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_ACH4_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_ACH4_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_ACH4_TXBD_DESA_L_8814B)
#define BITS_ACH4_TXBD_DESA_L_8814B \
(BIT_MASK_ACH4_TXBD_DESA_L_8814B << BIT_SHIFT_ACH4_TXBD_DESA_L_8814B)
#define BIT_CLEAR_ACH4_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_ACH4_TXBD_DESA_L_8814B))
#define BIT_GET_ACH4_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_ACH4_TXBD_DESA_L_8814B) & \
BIT_MASK_ACH4_TXBD_DESA_L_8814B)
#define BIT_SET_ACH4_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_ACH4_TXBD_DESA_L_8814B(x) | BIT_ACH4_TXBD_DESA_L_8814B(v))
/* 2 REG_ACH4_TXBD_DESA_H_8814B */
#define BIT_SHIFT_ACH4_TXBD_DESA_H_8814B 0
#define BIT_MASK_ACH4_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_ACH4_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_ACH4_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_ACH4_TXBD_DESA_H_8814B)
#define BITS_ACH4_TXBD_DESA_H_8814B \
(BIT_MASK_ACH4_TXBD_DESA_H_8814B << BIT_SHIFT_ACH4_TXBD_DESA_H_8814B)
#define BIT_CLEAR_ACH4_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_ACH4_TXBD_DESA_H_8814B))
#define BIT_GET_ACH4_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_ACH4_TXBD_DESA_H_8814B) & \
BIT_MASK_ACH4_TXBD_DESA_H_8814B)
#define BIT_SET_ACH4_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_ACH4_TXBD_DESA_H_8814B(x) | BIT_ACH4_TXBD_DESA_H_8814B(v))
/* 2 REG_HI8Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI8Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI8Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI8Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI8Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI8Q_TXBD_DESA_L_8814B)
#define BITS_HI8Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI8Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI8Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI8Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI8Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI8Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI8Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI8Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI8Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI8Q_TXBD_DESA_L_8814B(x) | BIT_HI8Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI8Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI8Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI8Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI8Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI8Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI8Q_TXBD_DESA_H_8814B)
#define BITS_HI8Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI8Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI8Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI8Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI8Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI8Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI8Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI8Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI8Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI8Q_TXBD_DESA_H_8814B(x) | BIT_HI8Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI9Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI9Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI9Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI9Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI9Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI9Q_TXBD_DESA_L_8814B)
#define BITS_HI9Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI9Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI9Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI9Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI9Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI9Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI9Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI9Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI9Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI9Q_TXBD_DESA_L_8814B(x) | BIT_HI9Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI9Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI9Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI9Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI9Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI9Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI9Q_TXBD_DESA_H_8814B)
#define BITS_HI9Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI9Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI9Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI9Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI9Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI9Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI9Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI9Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI9Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI9Q_TXBD_DESA_H_8814B(x) | BIT_HI9Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI10Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI10Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI10Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI10Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI10Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI10Q_TXBD_DESA_L_8814B)
#define BITS_HI10Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI10Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI10Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI10Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI10Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI10Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI10Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI10Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI10Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI10Q_TXBD_DESA_L_8814B(x) | BIT_HI10Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI10Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI10Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI10Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI10Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI10Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI10Q_TXBD_DESA_H_8814B)
#define BITS_HI10Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI10Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI10Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI10Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI10Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI10Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI10Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI10Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI10Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI10Q_TXBD_DESA_H_8814B(x) | BIT_HI10Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI11Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI11Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI11Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI11Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI11Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI11Q_TXBD_DESA_L_8814B)
#define BITS_HI11Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI11Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI11Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI11Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI11Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI11Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI11Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI11Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI11Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI11Q_TXBD_DESA_L_8814B(x) | BIT_HI11Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI11Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI11Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI11Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI11Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI11Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI11Q_TXBD_DESA_H_8814B)
#define BITS_HI11Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI11Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI11Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI11Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI11Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI11Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI11Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI11Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI11Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI11Q_TXBD_DESA_H_8814B(x) | BIT_HI11Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI12Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI12Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI12Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI12Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI12Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI12Q_TXBD_DESA_L_8814B)
#define BITS_HI12Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI12Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI12Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI12Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI12Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI12Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI12Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI12Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI12Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI12Q_TXBD_DESA_L_8814B(x) | BIT_HI12Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI12Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI12Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI12Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI12Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI12Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI12Q_TXBD_DESA_H_8814B)
#define BITS_HI12Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI12Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI12Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI12Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI12Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI12Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI12Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI12Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI12Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI12Q_TXBD_DESA_H_8814B(x) | BIT_HI12Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI13Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI13Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI13Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI13Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI13Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI13Q_TXBD_DESA_L_8814B)
#define BITS_HI13Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI13Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI13Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI13Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI13Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI13Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI13Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI13Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI13Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI13Q_TXBD_DESA_L_8814B(x) | BIT_HI13Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI13Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI13Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI13Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI13Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI13Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI13Q_TXBD_DESA_H_8814B)
#define BITS_HI13Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI13Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI13Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI13Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI13Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI13Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI13Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI13Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI13Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI13Q_TXBD_DESA_H_8814B(x) | BIT_HI13Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI14Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI14Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI14Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI14Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI14Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI14Q_TXBD_DESA_L_8814B)
#define BITS_HI14Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI14Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI14Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI14Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI14Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI14Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI14Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI14Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI14Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI14Q_TXBD_DESA_L_8814B(x) | BIT_HI14Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI14Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI14Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI14Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI14Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI14Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI14Q_TXBD_DESA_H_8814B)
#define BITS_HI14Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI14Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI14Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI14Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI14Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI14Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI14Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI14Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI14Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI14Q_TXBD_DESA_H_8814B(x) | BIT_HI14Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI15Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI15Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI15Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI15Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI15Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI15Q_TXBD_DESA_L_8814B)
#define BITS_HI15Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI15Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI15Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI15Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI15Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI15Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI15Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI15Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI15Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI15Q_TXBD_DESA_L_8814B(x) | BIT_HI15Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI15Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI15Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI15Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI15Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI15Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI15Q_TXBD_DESA_H_8814B)
#define BITS_HI15Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI15Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI15Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI15Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI15Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI15Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI15Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI15Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI15Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI15Q_TXBD_DESA_H_8814B(x) | BIT_HI15Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI16Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI16Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI16Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI16Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI16Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI16Q_TXBD_DESA_L_8814B)
#define BITS_HI16Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI16Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI16Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI16Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI16Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI16Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI16Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI16Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI16Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI16Q_TXBD_DESA_L_8814B(x) | BIT_HI16Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI16Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI16Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI16Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI16Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI16Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI16Q_TXBD_DESA_H_8814B)
#define BITS_HI16Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI16Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI16Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI16Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI16Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI16Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI16Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI16Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI16Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI16Q_TXBD_DESA_H_8814B(x) | BIT_HI16Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI17Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI17Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI17Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI17Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI17Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI17Q_TXBD_DESA_L_8814B)
#define BITS_HI17Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI17Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI17Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI17Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI17Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI17Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI17Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI17Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI17Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI17Q_TXBD_DESA_L_8814B(x) | BIT_HI17Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI17Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI17Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI17Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI17Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI17Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI17Q_TXBD_DESA_H_8814B)
#define BITS_HI17Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI17Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI17Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI17Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI17Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI17Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI17Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI17Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI17Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI17Q_TXBD_DESA_H_8814B(x) | BIT_HI17Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI18Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI18Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI18Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI18Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI18Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI18Q_TXBD_DESA_L_8814B)
#define BITS_HI18Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI18Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI18Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI18Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI18Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI18Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI18Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI18Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI18Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI18Q_TXBD_DESA_L_8814B(x) | BIT_HI18Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI18Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI18Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI18Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI18Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI18Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI18Q_TXBD_DESA_H_8814B)
#define BITS_HI18Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI18Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI18Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI18Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI18Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI18Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI18Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI18Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI18Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI18Q_TXBD_DESA_H_8814B(x) | BIT_HI18Q_TXBD_DESA_H_8814B(v))
/* 2 REG_HI19Q_TXBD_DESA_L_8814B */
#define BIT_SHIFT_HI19Q_TXBD_DESA_L_8814B 0
#define BIT_MASK_HI19Q_TXBD_DESA_L_8814B 0xffffffffL
#define BIT_HI19Q_TXBD_DESA_L_8814B(x) \
(((x) & BIT_MASK_HI19Q_TXBD_DESA_L_8814B) \
<< BIT_SHIFT_HI19Q_TXBD_DESA_L_8814B)
#define BITS_HI19Q_TXBD_DESA_L_8814B \
(BIT_MASK_HI19Q_TXBD_DESA_L_8814B << BIT_SHIFT_HI19Q_TXBD_DESA_L_8814B)
#define BIT_CLEAR_HI19Q_TXBD_DESA_L_8814B(x) \
((x) & (~BITS_HI19Q_TXBD_DESA_L_8814B))
#define BIT_GET_HI19Q_TXBD_DESA_L_8814B(x) \
(((x) >> BIT_SHIFT_HI19Q_TXBD_DESA_L_8814B) & \
BIT_MASK_HI19Q_TXBD_DESA_L_8814B)
#define BIT_SET_HI19Q_TXBD_DESA_L_8814B(x, v) \
(BIT_CLEAR_HI19Q_TXBD_DESA_L_8814B(x) | BIT_HI19Q_TXBD_DESA_L_8814B(v))
/* 2 REG_HI19Q_TXBD_DESA_H_8814B */
#define BIT_SHIFT_HI19Q_TXBD_DESA_H_8814B 0
#define BIT_MASK_HI19Q_TXBD_DESA_H_8814B 0xffffffffL
#define BIT_HI19Q_TXBD_DESA_H_8814B(x) \
(((x) & BIT_MASK_HI19Q_TXBD_DESA_H_8814B) \
<< BIT_SHIFT_HI19Q_TXBD_DESA_H_8814B)
#define BITS_HI19Q_TXBD_DESA_H_8814B \
(BIT_MASK_HI19Q_TXBD_DESA_H_8814B << BIT_SHIFT_HI19Q_TXBD_DESA_H_8814B)
#define BIT_CLEAR_HI19Q_TXBD_DESA_H_8814B(x) \
((x) & (~BITS_HI19Q_TXBD_DESA_H_8814B))
#define BIT_GET_HI19Q_TXBD_DESA_H_8814B(x) \
(((x) >> BIT_SHIFT_HI19Q_TXBD_DESA_H_8814B) & \
BIT_MASK_HI19Q_TXBD_DESA_H_8814B)
#define BIT_SET_HI19Q_TXBD_DESA_H_8814B(x, v) \
(BIT_CLEAR_HI19Q_TXBD_DESA_H_8814B(x) | BIT_HI19Q_TXBD_DESA_H_8814B(v))
/* 2 REG_BD_RWPTR_CLR6_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_P0HI19Q_HW_IDX_8814B BIT(25)
#define BIT_CLR_P0HI18Q_HW_IDX_8814B BIT(24)
#define BIT_CLR_P0HI17Q_HW_IDX_8814B BIT(23)
#define BIT_CLR_P0HI16Q_HW_IDX_8814B BIT(22)
/* 2 REG_NOT_VALID_8814B */
#define BIT_CLR_P0HI19Q_HOST_IDX_8814B BIT(9)
#define BIT_CLR_P0HI18Q_HOST_IDX_8814B BIT(8)
#define BIT_CLR_P0HI17Q_HOST_IDX_8814B BIT(7)
#define BIT_CLR_P0HI16Q_HOST_IDX_8814B BIT(6)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_P0HI16Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI16Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI16Q_HW_IDX_8814B 0xfff
#define BIT_P0HI16Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI16Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI16Q_HW_IDX_8814B)
#define BITS_P0HI16Q_HW_IDX_8814B \
(BIT_MASK_P0HI16Q_HW_IDX_8814B << BIT_SHIFT_P0HI16Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI16Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI16Q_HW_IDX_8814B))
#define BIT_GET_P0HI16Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI16Q_HW_IDX_8814B) & \
BIT_MASK_P0HI16Q_HW_IDX_8814B)
#define BIT_SET_P0HI16Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI16Q_HW_IDX_8814B(x) | BIT_P0HI16Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI16Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI16Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI16Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI16Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI16Q_HOST_IDX_8814B)
#define BITS_P0HI16Q_HOST_IDX_8814B \
(BIT_MASK_P0HI16Q_HOST_IDX_8814B << BIT_SHIFT_P0HI16Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI16Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI16Q_HOST_IDX_8814B))
#define BIT_GET_P0HI16Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI16Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI16Q_HOST_IDX_8814B)
#define BIT_SET_P0HI16Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI16Q_HOST_IDX_8814B(x) | BIT_P0HI16Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI17Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI17Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI17Q_HW_IDX_8814B 0xfff
#define BIT_P0HI17Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI17Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI17Q_HW_IDX_8814B)
#define BITS_P0HI17Q_HW_IDX_8814B \
(BIT_MASK_P0HI17Q_HW_IDX_8814B << BIT_SHIFT_P0HI17Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI17Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI17Q_HW_IDX_8814B))
#define BIT_GET_P0HI17Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI17Q_HW_IDX_8814B) & \
BIT_MASK_P0HI17Q_HW_IDX_8814B)
#define BIT_SET_P0HI17Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI17Q_HW_IDX_8814B(x) | BIT_P0HI17Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI17Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI17Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI17Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI17Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI17Q_HOST_IDX_8814B)
#define BITS_P0HI17Q_HOST_IDX_8814B \
(BIT_MASK_P0HI17Q_HOST_IDX_8814B << BIT_SHIFT_P0HI17Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI17Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI17Q_HOST_IDX_8814B))
#define BIT_GET_P0HI17Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI17Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI17Q_HOST_IDX_8814B)
#define BIT_SET_P0HI17Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI17Q_HOST_IDX_8814B(x) | BIT_P0HI17Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI18Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI18Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI18Q_HW_IDX_8814B 0xfff
#define BIT_P0HI18Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI18Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI18Q_HW_IDX_8814B)
#define BITS_P0HI18Q_HW_IDX_8814B \
(BIT_MASK_P0HI18Q_HW_IDX_8814B << BIT_SHIFT_P0HI18Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI18Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI18Q_HW_IDX_8814B))
#define BIT_GET_P0HI18Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI18Q_HW_IDX_8814B) & \
BIT_MASK_P0HI18Q_HW_IDX_8814B)
#define BIT_SET_P0HI18Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI18Q_HW_IDX_8814B(x) | BIT_P0HI18Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI18Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI18Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI18Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI18Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI18Q_HOST_IDX_8814B)
#define BITS_P0HI18Q_HOST_IDX_8814B \
(BIT_MASK_P0HI18Q_HOST_IDX_8814B << BIT_SHIFT_P0HI18Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI18Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI18Q_HOST_IDX_8814B))
#define BIT_GET_P0HI18Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI18Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI18Q_HOST_IDX_8814B)
#define BIT_SET_P0HI18Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI18Q_HOST_IDX_8814B(x) | BIT_P0HI18Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI19Q_TXBD_IDX_8814B */
#define BIT_SHIFT_P0HI19Q_HW_IDX_8814B 16
#define BIT_MASK_P0HI19Q_HW_IDX_8814B 0xfff
#define BIT_P0HI19Q_HW_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI19Q_HW_IDX_8814B) \
<< BIT_SHIFT_P0HI19Q_HW_IDX_8814B)
#define BITS_P0HI19Q_HW_IDX_8814B \
(BIT_MASK_P0HI19Q_HW_IDX_8814B << BIT_SHIFT_P0HI19Q_HW_IDX_8814B)
#define BIT_CLEAR_P0HI19Q_HW_IDX_8814B(x) ((x) & (~BITS_P0HI19Q_HW_IDX_8814B))
#define BIT_GET_P0HI19Q_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI19Q_HW_IDX_8814B) & \
BIT_MASK_P0HI19Q_HW_IDX_8814B)
#define BIT_SET_P0HI19Q_HW_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI19Q_HW_IDX_8814B(x) | BIT_P0HI19Q_HW_IDX_8814B(v))
#define BIT_SHIFT_P0HI19Q_HOST_IDX_8814B 0
#define BIT_MASK_P0HI19Q_HOST_IDX_8814B 0xfff
#define BIT_P0HI19Q_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_P0HI19Q_HOST_IDX_8814B) \
<< BIT_SHIFT_P0HI19Q_HOST_IDX_8814B)
#define BITS_P0HI19Q_HOST_IDX_8814B \
(BIT_MASK_P0HI19Q_HOST_IDX_8814B << BIT_SHIFT_P0HI19Q_HOST_IDX_8814B)
#define BIT_CLEAR_P0HI19Q_HOST_IDX_8814B(x) \
((x) & (~BITS_P0HI19Q_HOST_IDX_8814B))
#define BIT_GET_P0HI19Q_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_P0HI19Q_HOST_IDX_8814B) & \
BIT_MASK_P0HI19Q_HOST_IDX_8814B)
#define BIT_SET_P0HI19Q_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_P0HI19Q_HOST_IDX_8814B(x) | BIT_P0HI19Q_HOST_IDX_8814B(v))
/* 2 REG_P0HI16Q_HI17Q_TXBD_NUM_8814B */
#define BIT_P0HI17Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI17Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI17Q_DESC_MODE_8814B 0x3
#define BIT_P0HI17Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI17Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI17Q_DESC_MODE_8814B)
#define BITS_P0HI17Q_DESC_MODE_8814B \
(BIT_MASK_P0HI17Q_DESC_MODE_8814B << BIT_SHIFT_P0HI17Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI17Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI17Q_DESC_MODE_8814B))
#define BIT_GET_P0HI17Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI17Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI17Q_DESC_MODE_8814B)
#define BIT_SET_P0HI17Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI17Q_DESC_MODE_8814B(x) | BIT_P0HI17Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI17Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI17Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI17Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI17Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI17Q_DESC_NUM_8814B)
#define BITS_P0HI17Q_DESC_NUM_8814B \
(BIT_MASK_P0HI17Q_DESC_NUM_8814B << BIT_SHIFT_P0HI17Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI17Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI17Q_DESC_NUM_8814B))
#define BIT_GET_P0HI17Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI17Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI17Q_DESC_NUM_8814B)
#define BIT_SET_P0HI17Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI17Q_DESC_NUM_8814B(x) | BIT_P0HI17Q_DESC_NUM_8814B(v))
#define BIT_P0HI16Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI16Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI16Q_DESC_MODE_8814B 0x3
#define BIT_P0HI16Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI16Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI16Q_DESC_MODE_8814B)
#define BITS_P0HI16Q_DESC_MODE_8814B \
(BIT_MASK_P0HI16Q_DESC_MODE_8814B << BIT_SHIFT_P0HI16Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI16Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI16Q_DESC_MODE_8814B))
#define BIT_GET_P0HI16Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI16Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI16Q_DESC_MODE_8814B)
#define BIT_SET_P0HI16Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI16Q_DESC_MODE_8814B(x) | BIT_P0HI16Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI16Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI16Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI16Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI16Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI16Q_DESC_NUM_8814B)
#define BITS_P0HI16Q_DESC_NUM_8814B \
(BIT_MASK_P0HI16Q_DESC_NUM_8814B << BIT_SHIFT_P0HI16Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI16Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI16Q_DESC_NUM_8814B))
#define BIT_GET_P0HI16Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI16Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI16Q_DESC_NUM_8814B)
#define BIT_SET_P0HI16Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI16Q_DESC_NUM_8814B(x) | BIT_P0HI16Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI18Q_HI19Q_TXBD_NUM_8814B */
#define BIT_P0HI19Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI19Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI19Q_DESC_MODE_8814B 0x3
#define BIT_P0HI19Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI19Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI19Q_DESC_MODE_8814B)
#define BITS_P0HI19Q_DESC_MODE_8814B \
(BIT_MASK_P0HI19Q_DESC_MODE_8814B << BIT_SHIFT_P0HI19Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI19Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI19Q_DESC_MODE_8814B))
#define BIT_GET_P0HI19Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI19Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI19Q_DESC_MODE_8814B)
#define BIT_SET_P0HI19Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI19Q_DESC_MODE_8814B(x) | BIT_P0HI19Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI19Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI19Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI19Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI19Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI19Q_DESC_NUM_8814B)
#define BITS_P0HI19Q_DESC_NUM_8814B \
(BIT_MASK_P0HI19Q_DESC_NUM_8814B << BIT_SHIFT_P0HI19Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI19Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI19Q_DESC_NUM_8814B))
#define BIT_GET_P0HI19Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI19Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI19Q_DESC_NUM_8814B)
#define BIT_SET_P0HI19Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI19Q_DESC_NUM_8814B(x) | BIT_P0HI19Q_DESC_NUM_8814B(v))
#define BIT_P0HI18Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI18Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI18Q_DESC_MODE_8814B 0x3
#define BIT_P0HI18Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI18Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI18Q_DESC_MODE_8814B)
#define BITS_P0HI18Q_DESC_MODE_8814B \
(BIT_MASK_P0HI18Q_DESC_MODE_8814B << BIT_SHIFT_P0HI18Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI18Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI18Q_DESC_MODE_8814B))
#define BIT_GET_P0HI18Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI18Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI18Q_DESC_MODE_8814B)
#define BIT_SET_P0HI18Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI18Q_DESC_MODE_8814B(x) | BIT_P0HI18Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI18Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI18Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI18Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI18Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI18Q_DESC_NUM_8814B)
#define BITS_P0HI18Q_DESC_NUM_8814B \
(BIT_MASK_P0HI18Q_DESC_NUM_8814B << BIT_SHIFT_P0HI18Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI18Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI18Q_DESC_NUM_8814B))
#define BIT_GET_P0HI18Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI18Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI18Q_DESC_NUM_8814B)
#define BIT_SET_P0HI18Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI18Q_DESC_NUM_8814B(x) | BIT_P0HI18Q_DESC_NUM_8814B(v))
/* 2 REG_PCIE_HISR0_8814B */
#define BIT_PSTIMER_2_8814B BIT(31)
#define BIT_PSTIMER_1_8814B BIT(30)
#define BIT_PSTIMER_0_8814B BIT(29)
#define BIT_GTINT4_8814B BIT(28)
#define BIT_GTINT3_8814B BIT(27)
#define BIT_TXBCN0ERR_8814B BIT(26)
#define BIT_TXBCN0OK_8814B BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8814B BIT(24)
#define BIT_TXDMA_START_INT_8814B BIT(23)
#define BIT_TXDMA_STOP_INT_8814B BIT(22)
#define BIT_HISR7_IND_8814B BIT(21)
#define BIT_BCNDMAINT0_8814B BIT(20)
#define BIT_HISR6_IND_8814B BIT(19)
#define BIT_HISR5_IND_8814B BIT(18)
#define BIT_HISR4_IND_8814B BIT(17)
#define BIT_BCNDERR0_8814B BIT(16)
#define BIT_HSISR_IND_ON_INT_8814B BIT(15)
#define BIT_HISR3_IND_8814B BIT(14)
#define BIT_HISR2_IND_8814B BIT(13)
#define BIT_HISR1_IND_8814B BIT(11)
#define BIT_C2HCMD_8814B BIT(10)
#define BIT_CPWM2_8814B BIT(9)
#define BIT_CPWM_8814B BIT(8)
#define BIT_TXDMAOK_CHANNEL15_8814B BIT(7)
#define BIT_TXDMAOK_CHANNEL14_8814B BIT(6)
#define BIT_TXDMAOK_CHANNEL3_8814B BIT(5)
#define BIT_TXDMAOK_CHANNEL2_8814B BIT(4)
#define BIT_TXDMAOK_CHANNEL1_8814B BIT(3)
#define BIT_TXDMAOK_CHANNEL0_8814B BIT(2)
#define BIT_RDU_8814B BIT(1)
#define BIT_RXOK_8814B BIT(0)
/* 2 REG_PCIE_HISR1_8814B */
#define BIT_PRE_TX_ERR_INT_8814B BIT(31)
#define BIT_TXFIFO_TH_INT_8814B BIT(30)
#define BIT_BTON_STS_UPDATE_INT_8814B BIT(29)
#define BIT_BCNDMAINT7_8814B BIT(27)
#define BIT_BCNDMAINT6_8814B BIT(26)
#define BIT_BCNDMAINT5_8814B BIT(25)
#define BIT_BCNDMAINT4_8814B BIT(24)
#define BIT_BCNDMAINT3_8814B BIT(23)
#define BIT_BCNDMAINT2_8814B BIT(22)
#define BIT_BCNDMAINT1_8814B BIT(21)
#define BIT_BCNDERR7_8814B BIT(20)
#define BIT_BCNDERR6_8814B BIT(19)
#define BIT_BCNDERR5_8814B BIT(18)
#define BIT_BCNDERR4_8814B BIT(17)
#define BIT_BCNDERR3_8814B BIT(16)
#define BIT_BCNDERR2_8814B BIT(15)
#define BIT_BCNDERR1_8814B BIT(14)
#define BIT_ATIMEND_8814B BIT(12)
#define BIT_TXERR_INT_8814B BIT(11)
#define BIT_RXERR_INT_8814B BIT(10)
#define BIT_TXFOVW_8814B BIT(9)
#define BIT_FOVW_8814B BIT(8)
#define BIT_CPU_MGQ_EARLY_INT_8814B BIT(6)
#define BIT_CPU_MGQ_TXDONE_8814B BIT(5)
#define BIT_PSTIMER_5_8814B BIT(4)
#define BIT_PSTIMER_4_8814B BIT(3)
#define BIT_PSTIMER_3_8814B BIT(2)
#define BIT_CPUMGQ_TX_TIMER_8814B BIT(1)
#define BIT_BB_STOPRX_INT_8814B BIT(0)
/* 2 REG_P0HI8Q_HI9Q_TXBD_NUM_8814B */
#define BIT_P0HI9Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI9Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI9Q_DESC_MODE_8814B 0x3
#define BIT_P0HI9Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI9Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI9Q_DESC_MODE_8814B)
#define BITS_P0HI9Q_DESC_MODE_8814B \
(BIT_MASK_P0HI9Q_DESC_MODE_8814B << BIT_SHIFT_P0HI9Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI9Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI9Q_DESC_MODE_8814B))
#define BIT_GET_P0HI9Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI9Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI9Q_DESC_MODE_8814B)
#define BIT_SET_P0HI9Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI9Q_DESC_MODE_8814B(x) | BIT_P0HI9Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI9Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI9Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI9Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI9Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI9Q_DESC_NUM_8814B)
#define BITS_P0HI9Q_DESC_NUM_8814B \
(BIT_MASK_P0HI9Q_DESC_NUM_8814B << BIT_SHIFT_P0HI9Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI9Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI9Q_DESC_NUM_8814B))
#define BIT_GET_P0HI9Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI9Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI9Q_DESC_NUM_8814B)
#define BIT_SET_P0HI9Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI9Q_DESC_NUM_8814B(x) | BIT_P0HI9Q_DESC_NUM_8814B(v))
#define BIT_P0HI8Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI8Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI8Q_DESC_MODE_8814B 0x3
#define BIT_P0HI8Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI8Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI8Q_DESC_MODE_8814B)
#define BITS_P0HI8Q_DESC_MODE_8814B \
(BIT_MASK_P0HI8Q_DESC_MODE_8814B << BIT_SHIFT_P0HI8Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI8Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI8Q_DESC_MODE_8814B))
#define BIT_GET_P0HI8Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI8Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI8Q_DESC_MODE_8814B)
#define BIT_SET_P0HI8Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI8Q_DESC_MODE_8814B(x) | BIT_P0HI8Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI8Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI8Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI8Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI8Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI8Q_DESC_NUM_8814B)
#define BITS_P0HI8Q_DESC_NUM_8814B \
(BIT_MASK_P0HI8Q_DESC_NUM_8814B << BIT_SHIFT_P0HI8Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI8Q_DESC_NUM_8814B(x) ((x) & (~BITS_P0HI8Q_DESC_NUM_8814B))
#define BIT_GET_P0HI8Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI8Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI8Q_DESC_NUM_8814B)
#define BIT_SET_P0HI8Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI8Q_DESC_NUM_8814B(x) | BIT_P0HI8Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI10Q_HI11Q_TXBD_NUM_8814B */
#define BIT_P0HI11Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI11Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI11Q_DESC_MODE_8814B 0x3
#define BIT_P0HI11Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI11Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI11Q_DESC_MODE_8814B)
#define BITS_P0HI11Q_DESC_MODE_8814B \
(BIT_MASK_P0HI11Q_DESC_MODE_8814B << BIT_SHIFT_P0HI11Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI11Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI11Q_DESC_MODE_8814B))
#define BIT_GET_P0HI11Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI11Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI11Q_DESC_MODE_8814B)
#define BIT_SET_P0HI11Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI11Q_DESC_MODE_8814B(x) | BIT_P0HI11Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI11Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI11Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI11Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI11Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI11Q_DESC_NUM_8814B)
#define BITS_P0HI11Q_DESC_NUM_8814B \
(BIT_MASK_P0HI11Q_DESC_NUM_8814B << BIT_SHIFT_P0HI11Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI11Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI11Q_DESC_NUM_8814B))
#define BIT_GET_P0HI11Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI11Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI11Q_DESC_NUM_8814B)
#define BIT_SET_P0HI11Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI11Q_DESC_NUM_8814B(x) | BIT_P0HI11Q_DESC_NUM_8814B(v))
#define BIT_P0HI10Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI10Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI10Q_DESC_MODE_8814B 0x3
#define BIT_P0HI10Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI10Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI10Q_DESC_MODE_8814B)
#define BITS_P0HI10Q_DESC_MODE_8814B \
(BIT_MASK_P0HI10Q_DESC_MODE_8814B << BIT_SHIFT_P0HI10Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI10Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI10Q_DESC_MODE_8814B))
#define BIT_GET_P0HI10Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI10Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI10Q_DESC_MODE_8814B)
#define BIT_SET_P0HI10Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI10Q_DESC_MODE_8814B(x) | BIT_P0HI10Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI10Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI10Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI10Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI10Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI10Q_DESC_NUM_8814B)
#define BITS_P0HI10Q_DESC_NUM_8814B \
(BIT_MASK_P0HI10Q_DESC_NUM_8814B << BIT_SHIFT_P0HI10Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI10Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI10Q_DESC_NUM_8814B))
#define BIT_GET_P0HI10Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI10Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI10Q_DESC_NUM_8814B)
#define BIT_SET_P0HI10Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI10Q_DESC_NUM_8814B(x) | BIT_P0HI10Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI12Q_HI13Q_TXBD_NUM_8814B */
#define BIT_P0HI13Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI13Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI13Q_DESC_MODE_8814B 0x3
#define BIT_P0HI13Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI13Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI13Q_DESC_MODE_8814B)
#define BITS_P0HI13Q_DESC_MODE_8814B \
(BIT_MASK_P0HI13Q_DESC_MODE_8814B << BIT_SHIFT_P0HI13Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI13Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI13Q_DESC_MODE_8814B))
#define BIT_GET_P0HI13Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI13Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI13Q_DESC_MODE_8814B)
#define BIT_SET_P0HI13Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI13Q_DESC_MODE_8814B(x) | BIT_P0HI13Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI13Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI13Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI13Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI13Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI13Q_DESC_NUM_8814B)
#define BITS_P0HI13Q_DESC_NUM_8814B \
(BIT_MASK_P0HI13Q_DESC_NUM_8814B << BIT_SHIFT_P0HI13Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI13Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI13Q_DESC_NUM_8814B))
#define BIT_GET_P0HI13Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI13Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI13Q_DESC_NUM_8814B)
#define BIT_SET_P0HI13Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI13Q_DESC_NUM_8814B(x) | BIT_P0HI13Q_DESC_NUM_8814B(v))
#define BIT_P0HI12Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI12Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI12Q_DESC_MODE_8814B 0x3
#define BIT_P0HI12Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI12Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI12Q_DESC_MODE_8814B)
#define BITS_P0HI12Q_DESC_MODE_8814B \
(BIT_MASK_P0HI12Q_DESC_MODE_8814B << BIT_SHIFT_P0HI12Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI12Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI12Q_DESC_MODE_8814B))
#define BIT_GET_P0HI12Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI12Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI12Q_DESC_MODE_8814B)
#define BIT_SET_P0HI12Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI12Q_DESC_MODE_8814B(x) | BIT_P0HI12Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI12Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI12Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI12Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI12Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI12Q_DESC_NUM_8814B)
#define BITS_P0HI12Q_DESC_NUM_8814B \
(BIT_MASK_P0HI12Q_DESC_NUM_8814B << BIT_SHIFT_P0HI12Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI12Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI12Q_DESC_NUM_8814B))
#define BIT_GET_P0HI12Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI12Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI12Q_DESC_NUM_8814B)
#define BIT_SET_P0HI12Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI12Q_DESC_NUM_8814B(x) | BIT_P0HI12Q_DESC_NUM_8814B(v))
/* 2 REG_P0HI14Q_HI15Q_TXBD_NUM_8814B */
#define BIT_P0HI15Q_FLAG_8814B BIT(30)
#define BIT_SHIFT_P0HI15Q_DESC_MODE_8814B 28
#define BIT_MASK_P0HI15Q_DESC_MODE_8814B 0x3
#define BIT_P0HI15Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI15Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI15Q_DESC_MODE_8814B)
#define BITS_P0HI15Q_DESC_MODE_8814B \
(BIT_MASK_P0HI15Q_DESC_MODE_8814B << BIT_SHIFT_P0HI15Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI15Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI15Q_DESC_MODE_8814B))
#define BIT_GET_P0HI15Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI15Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI15Q_DESC_MODE_8814B)
#define BIT_SET_P0HI15Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI15Q_DESC_MODE_8814B(x) | BIT_P0HI15Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI15Q_DESC_NUM_8814B 16
#define BIT_MASK_P0HI15Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI15Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI15Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI15Q_DESC_NUM_8814B)
#define BITS_P0HI15Q_DESC_NUM_8814B \
(BIT_MASK_P0HI15Q_DESC_NUM_8814B << BIT_SHIFT_P0HI15Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI15Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI15Q_DESC_NUM_8814B))
#define BIT_GET_P0HI15Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI15Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI15Q_DESC_NUM_8814B)
#define BIT_SET_P0HI15Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI15Q_DESC_NUM_8814B(x) | BIT_P0HI15Q_DESC_NUM_8814B(v))
#define BIT_P0HI14Q_FLAG_8814B BIT(14)
#define BIT_SHIFT_P0HI14Q_DESC_MODE_8814B 12
#define BIT_MASK_P0HI14Q_DESC_MODE_8814B 0x3
#define BIT_P0HI14Q_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_P0HI14Q_DESC_MODE_8814B) \
<< BIT_SHIFT_P0HI14Q_DESC_MODE_8814B)
#define BITS_P0HI14Q_DESC_MODE_8814B \
(BIT_MASK_P0HI14Q_DESC_MODE_8814B << BIT_SHIFT_P0HI14Q_DESC_MODE_8814B)
#define BIT_CLEAR_P0HI14Q_DESC_MODE_8814B(x) \
((x) & (~BITS_P0HI14Q_DESC_MODE_8814B))
#define BIT_GET_P0HI14Q_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_P0HI14Q_DESC_MODE_8814B) & \
BIT_MASK_P0HI14Q_DESC_MODE_8814B)
#define BIT_SET_P0HI14Q_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_P0HI14Q_DESC_MODE_8814B(x) | BIT_P0HI14Q_DESC_MODE_8814B(v))
#define BIT_SHIFT_P0HI14Q_DESC_NUM_8814B 0
#define BIT_MASK_P0HI14Q_DESC_NUM_8814B 0xfff
#define BIT_P0HI14Q_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_P0HI14Q_DESC_NUM_8814B) \
<< BIT_SHIFT_P0HI14Q_DESC_NUM_8814B)
#define BITS_P0HI14Q_DESC_NUM_8814B \
(BIT_MASK_P0HI14Q_DESC_NUM_8814B << BIT_SHIFT_P0HI14Q_DESC_NUM_8814B)
#define BIT_CLEAR_P0HI14Q_DESC_NUM_8814B(x) \
((x) & (~BITS_P0HI14Q_DESC_NUM_8814B))
#define BIT_GET_P0HI14Q_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_P0HI14Q_DESC_NUM_8814B) & \
BIT_MASK_P0HI14Q_DESC_NUM_8814B)
#define BIT_SET_P0HI14Q_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_P0HI14Q_DESC_NUM_8814B(x) | BIT_P0HI14Q_DESC_NUM_8814B(v))
/* 2 REG_ACH6_ACH7_TXBD_NUM_8814B */
#define BIT_PCIE_ACH7_FLAG_8814B BIT(30)
#define BIT_SHIFT_ACH7_DESC_MODE_8814B 28
#define BIT_MASK_ACH7_DESC_MODE_8814B 0x3
#define BIT_ACH7_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH7_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH7_DESC_MODE_8814B)
#define BITS_ACH7_DESC_MODE_8814B \
(BIT_MASK_ACH7_DESC_MODE_8814B << BIT_SHIFT_ACH7_DESC_MODE_8814B)
#define BIT_CLEAR_ACH7_DESC_MODE_8814B(x) ((x) & (~BITS_ACH7_DESC_MODE_8814B))
#define BIT_GET_ACH7_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH7_DESC_MODE_8814B) & \
BIT_MASK_ACH7_DESC_MODE_8814B)
#define BIT_SET_ACH7_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH7_DESC_MODE_8814B(x) | BIT_ACH7_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH7_DESC_NUM_8814B 16
#define BIT_MASK_ACH7_DESC_NUM_8814B 0xfff
#define BIT_ACH7_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH7_DESC_NUM_8814B) << BIT_SHIFT_ACH7_DESC_NUM_8814B)
#define BITS_ACH7_DESC_NUM_8814B \
(BIT_MASK_ACH7_DESC_NUM_8814B << BIT_SHIFT_ACH7_DESC_NUM_8814B)
#define BIT_CLEAR_ACH7_DESC_NUM_8814B(x) ((x) & (~BITS_ACH7_DESC_NUM_8814B))
#define BIT_GET_ACH7_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH7_DESC_NUM_8814B) & BIT_MASK_ACH7_DESC_NUM_8814B)
#define BIT_SET_ACH7_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH7_DESC_NUM_8814B(x) | BIT_ACH7_DESC_NUM_8814B(v))
#define BIT_PCIE_ACH6_FLAG_8814B BIT(14)
#define BIT_SHIFT_ACH6_DESC_MODE_8814B 12
#define BIT_MASK_ACH6_DESC_MODE_8814B 0x3
#define BIT_ACH6_DESC_MODE_8814B(x) \
(((x) & BIT_MASK_ACH6_DESC_MODE_8814B) \
<< BIT_SHIFT_ACH6_DESC_MODE_8814B)
#define BITS_ACH6_DESC_MODE_8814B \
(BIT_MASK_ACH6_DESC_MODE_8814B << BIT_SHIFT_ACH6_DESC_MODE_8814B)
#define BIT_CLEAR_ACH6_DESC_MODE_8814B(x) ((x) & (~BITS_ACH6_DESC_MODE_8814B))
#define BIT_GET_ACH6_DESC_MODE_8814B(x) \
(((x) >> BIT_SHIFT_ACH6_DESC_MODE_8814B) & \
BIT_MASK_ACH6_DESC_MODE_8814B)
#define BIT_SET_ACH6_DESC_MODE_8814B(x, v) \
(BIT_CLEAR_ACH6_DESC_MODE_8814B(x) | BIT_ACH6_DESC_MODE_8814B(v))
#define BIT_SHIFT_ACH6_DESC_NUM_8814B 0
#define BIT_MASK_ACH6_DESC_NUM_8814B 0xfff
#define BIT_ACH6_DESC_NUM_8814B(x) \
(((x) & BIT_MASK_ACH6_DESC_NUM_8814B) << BIT_SHIFT_ACH6_DESC_NUM_8814B)
#define BITS_ACH6_DESC_NUM_8814B \
(BIT_MASK_ACH6_DESC_NUM_8814B << BIT_SHIFT_ACH6_DESC_NUM_8814B)
#define BIT_CLEAR_ACH6_DESC_NUM_8814B(x) ((x) & (~BITS_ACH6_DESC_NUM_8814B))
#define BIT_GET_ACH6_DESC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ACH6_DESC_NUM_8814B) & BIT_MASK_ACH6_DESC_NUM_8814B)
#define BIT_SET_ACH6_DESC_NUM_8814B(x, v) \
(BIT_CLEAR_ACH6_DESC_NUM_8814B(x) | BIT_ACH6_DESC_NUM_8814B(v))
/* 2 REG_ACH4_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH4_HW_IDX_8814B 16
#define BIT_MASK_ACH4_HW_IDX_8814B 0xfff
#define BIT_ACH4_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH4_HW_IDX_8814B) << BIT_SHIFT_ACH4_HW_IDX_8814B)
#define BITS_ACH4_HW_IDX_8814B \
(BIT_MASK_ACH4_HW_IDX_8814B << BIT_SHIFT_ACH4_HW_IDX_8814B)
#define BIT_CLEAR_ACH4_HW_IDX_8814B(x) ((x) & (~BITS_ACH4_HW_IDX_8814B))
#define BIT_GET_ACH4_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH4_HW_IDX_8814B) & BIT_MASK_ACH4_HW_IDX_8814B)
#define BIT_SET_ACH4_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH4_HW_IDX_8814B(x) | BIT_ACH4_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH4_HOST_IDX_8814B 0
#define BIT_MASK_ACH4_HOST_IDX_8814B 0xfff
#define BIT_ACH4_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH4_HOST_IDX_8814B) << BIT_SHIFT_ACH4_HOST_IDX_8814B)
#define BITS_ACH4_HOST_IDX_8814B \
(BIT_MASK_ACH4_HOST_IDX_8814B << BIT_SHIFT_ACH4_HOST_IDX_8814B)
#define BIT_CLEAR_ACH4_HOST_IDX_8814B(x) ((x) & (~BITS_ACH4_HOST_IDX_8814B))
#define BIT_GET_ACH4_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH4_HOST_IDX_8814B) & BIT_MASK_ACH4_HOST_IDX_8814B)
#define BIT_SET_ACH4_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH4_HOST_IDX_8814B(x) | BIT_ACH4_HOST_IDX_8814B(v))
/* 2 REG_ACH5_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH5_HW_IDX_8814B 16
#define BIT_MASK_ACH5_HW_IDX_8814B 0xfff
#define BIT_ACH5_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH5_HW_IDX_8814B) << BIT_SHIFT_ACH5_HW_IDX_8814B)
#define BITS_ACH5_HW_IDX_8814B \
(BIT_MASK_ACH5_HW_IDX_8814B << BIT_SHIFT_ACH5_HW_IDX_8814B)
#define BIT_CLEAR_ACH5_HW_IDX_8814B(x) ((x) & (~BITS_ACH5_HW_IDX_8814B))
#define BIT_GET_ACH5_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH5_HW_IDX_8814B) & BIT_MASK_ACH5_HW_IDX_8814B)
#define BIT_SET_ACH5_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH5_HW_IDX_8814B(x) | BIT_ACH5_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH5_HOST_IDX_8814B 0
#define BIT_MASK_ACH5_HOST_IDX_8814B 0xfff
#define BIT_ACH5_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH5_HOST_IDX_8814B) << BIT_SHIFT_ACH5_HOST_IDX_8814B)
#define BITS_ACH5_HOST_IDX_8814B \
(BIT_MASK_ACH5_HOST_IDX_8814B << BIT_SHIFT_ACH5_HOST_IDX_8814B)
#define BIT_CLEAR_ACH5_HOST_IDX_8814B(x) ((x) & (~BITS_ACH5_HOST_IDX_8814B))
#define BIT_GET_ACH5_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH5_HOST_IDX_8814B) & BIT_MASK_ACH5_HOST_IDX_8814B)
#define BIT_SET_ACH5_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH5_HOST_IDX_8814B(x) | BIT_ACH5_HOST_IDX_8814B(v))
/* 2 REG_ACH6_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH6_HW_IDX_8814B 16
#define BIT_MASK_ACH6_HW_IDX_8814B 0xfff
#define BIT_ACH6_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH6_HW_IDX_8814B) << BIT_SHIFT_ACH6_HW_IDX_8814B)
#define BITS_ACH6_HW_IDX_8814B \
(BIT_MASK_ACH6_HW_IDX_8814B << BIT_SHIFT_ACH6_HW_IDX_8814B)
#define BIT_CLEAR_ACH6_HW_IDX_8814B(x) ((x) & (~BITS_ACH6_HW_IDX_8814B))
#define BIT_GET_ACH6_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH6_HW_IDX_8814B) & BIT_MASK_ACH6_HW_IDX_8814B)
#define BIT_SET_ACH6_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH6_HW_IDX_8814B(x) | BIT_ACH6_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH6_HOST_IDX_8814B 0
#define BIT_MASK_ACH6_HOST_IDX_8814B 0xfff
#define BIT_ACH6_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH6_HOST_IDX_8814B) << BIT_SHIFT_ACH6_HOST_IDX_8814B)
#define BITS_ACH6_HOST_IDX_8814B \
(BIT_MASK_ACH6_HOST_IDX_8814B << BIT_SHIFT_ACH6_HOST_IDX_8814B)
#define BIT_CLEAR_ACH6_HOST_IDX_8814B(x) ((x) & (~BITS_ACH6_HOST_IDX_8814B))
#define BIT_GET_ACH6_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH6_HOST_IDX_8814B) & BIT_MASK_ACH6_HOST_IDX_8814B)
#define BIT_SET_ACH6_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH6_HOST_IDX_8814B(x) | BIT_ACH6_HOST_IDX_8814B(v))
/* 2 REG_ACH7_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH7_HW_IDX_8814B 16
#define BIT_MASK_ACH7_HW_IDX_8814B 0xfff
#define BIT_ACH7_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH7_HW_IDX_8814B) << BIT_SHIFT_ACH7_HW_IDX_8814B)
#define BITS_ACH7_HW_IDX_8814B \
(BIT_MASK_ACH7_HW_IDX_8814B << BIT_SHIFT_ACH7_HW_IDX_8814B)
#define BIT_CLEAR_ACH7_HW_IDX_8814B(x) ((x) & (~BITS_ACH7_HW_IDX_8814B))
#define BIT_GET_ACH7_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH7_HW_IDX_8814B) & BIT_MASK_ACH7_HW_IDX_8814B)
#define BIT_SET_ACH7_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH7_HW_IDX_8814B(x) | BIT_ACH7_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH7_HOST_IDX_8814B 0
#define BIT_MASK_ACH7_HOST_IDX_8814B 0xfff
#define BIT_ACH7_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH7_HOST_IDX_8814B) << BIT_SHIFT_ACH7_HOST_IDX_8814B)
#define BITS_ACH7_HOST_IDX_8814B \
(BIT_MASK_ACH7_HOST_IDX_8814B << BIT_SHIFT_ACH7_HOST_IDX_8814B)
#define BIT_CLEAR_ACH7_HOST_IDX_8814B(x) ((x) & (~BITS_ACH7_HOST_IDX_8814B))
#define BIT_GET_ACH7_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH7_HOST_IDX_8814B) & BIT_MASK_ACH7_HOST_IDX_8814B)
#define BIT_SET_ACH7_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH7_HOST_IDX_8814B(x) | BIT_ACH7_HOST_IDX_8814B(v))
/* 2 REG_ACH8_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH8_HW_IDX_8814B 16
#define BIT_MASK_ACH8_HW_IDX_8814B 0xfff
#define BIT_ACH8_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH8_HW_IDX_8814B) << BIT_SHIFT_ACH8_HW_IDX_8814B)
#define BITS_ACH8_HW_IDX_8814B \
(BIT_MASK_ACH8_HW_IDX_8814B << BIT_SHIFT_ACH8_HW_IDX_8814B)
#define BIT_CLEAR_ACH8_HW_IDX_8814B(x) ((x) & (~BITS_ACH8_HW_IDX_8814B))
#define BIT_GET_ACH8_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH8_HW_IDX_8814B) & BIT_MASK_ACH8_HW_IDX_8814B)
#define BIT_SET_ACH8_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH8_HW_IDX_8814B(x) | BIT_ACH8_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH8_HOST_IDX_8814B 0
#define BIT_MASK_ACH8_HOST_IDX_8814B 0xfff
#define BIT_ACH8_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH8_HOST_IDX_8814B) << BIT_SHIFT_ACH8_HOST_IDX_8814B)
#define BITS_ACH8_HOST_IDX_8814B \
(BIT_MASK_ACH8_HOST_IDX_8814B << BIT_SHIFT_ACH8_HOST_IDX_8814B)
#define BIT_CLEAR_ACH8_HOST_IDX_8814B(x) ((x) & (~BITS_ACH8_HOST_IDX_8814B))
#define BIT_GET_ACH8_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH8_HOST_IDX_8814B) & BIT_MASK_ACH8_HOST_IDX_8814B)
#define BIT_SET_ACH8_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH8_HOST_IDX_8814B(x) | BIT_ACH8_HOST_IDX_8814B(v))
/* 2 REG_ACH9_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH9_HW_IDX_8814B 16
#define BIT_MASK_ACH9_HW_IDX_8814B 0xfff
#define BIT_ACH9_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH9_HW_IDX_8814B) << BIT_SHIFT_ACH9_HW_IDX_8814B)
#define BITS_ACH9_HW_IDX_8814B \
(BIT_MASK_ACH9_HW_IDX_8814B << BIT_SHIFT_ACH9_HW_IDX_8814B)
#define BIT_CLEAR_ACH9_HW_IDX_8814B(x) ((x) & (~BITS_ACH9_HW_IDX_8814B))
#define BIT_GET_ACH9_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH9_HW_IDX_8814B) & BIT_MASK_ACH9_HW_IDX_8814B)
#define BIT_SET_ACH9_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH9_HW_IDX_8814B(x) | BIT_ACH9_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH9_HOST_IDX_8814B 0
#define BIT_MASK_ACH9_HOST_IDX_8814B 0xfff
#define BIT_ACH9_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH9_HOST_IDX_8814B) << BIT_SHIFT_ACH9_HOST_IDX_8814B)
#define BITS_ACH9_HOST_IDX_8814B \
(BIT_MASK_ACH9_HOST_IDX_8814B << BIT_SHIFT_ACH9_HOST_IDX_8814B)
#define BIT_CLEAR_ACH9_HOST_IDX_8814B(x) ((x) & (~BITS_ACH9_HOST_IDX_8814B))
#define BIT_GET_ACH9_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH9_HOST_IDX_8814B) & BIT_MASK_ACH9_HOST_IDX_8814B)
#define BIT_SET_ACH9_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH9_HOST_IDX_8814B(x) | BIT_ACH9_HOST_IDX_8814B(v))
/* 2 REG_ACH10_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH10_HW_IDX_8814B 16
#define BIT_MASK_ACH10_HW_IDX_8814B 0xfff
#define BIT_ACH10_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH10_HW_IDX_8814B) << BIT_SHIFT_ACH10_HW_IDX_8814B)
#define BITS_ACH10_HW_IDX_8814B \
(BIT_MASK_ACH10_HW_IDX_8814B << BIT_SHIFT_ACH10_HW_IDX_8814B)
#define BIT_CLEAR_ACH10_HW_IDX_8814B(x) ((x) & (~BITS_ACH10_HW_IDX_8814B))
#define BIT_GET_ACH10_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH10_HW_IDX_8814B) & BIT_MASK_ACH10_HW_IDX_8814B)
#define BIT_SET_ACH10_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH10_HW_IDX_8814B(x) | BIT_ACH10_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH10_HOST_IDX_8814B 0
#define BIT_MASK_ACH10_HOST_IDX_8814B 0xfff
#define BIT_ACH10_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH10_HOST_IDX_8814B) \
<< BIT_SHIFT_ACH10_HOST_IDX_8814B)
#define BITS_ACH10_HOST_IDX_8814B \
(BIT_MASK_ACH10_HOST_IDX_8814B << BIT_SHIFT_ACH10_HOST_IDX_8814B)
#define BIT_CLEAR_ACH10_HOST_IDX_8814B(x) ((x) & (~BITS_ACH10_HOST_IDX_8814B))
#define BIT_GET_ACH10_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH10_HOST_IDX_8814B) & \
BIT_MASK_ACH10_HOST_IDX_8814B)
#define BIT_SET_ACH10_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH10_HOST_IDX_8814B(x) | BIT_ACH10_HOST_IDX_8814B(v))
/* 2 REG_ACH11_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH11_HW_IDX_8814B 16
#define BIT_MASK_ACH11_HW_IDX_8814B 0xfff
#define BIT_ACH11_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH11_HW_IDX_8814B) << BIT_SHIFT_ACH11_HW_IDX_8814B)
#define BITS_ACH11_HW_IDX_8814B \
(BIT_MASK_ACH11_HW_IDX_8814B << BIT_SHIFT_ACH11_HW_IDX_8814B)
#define BIT_CLEAR_ACH11_HW_IDX_8814B(x) ((x) & (~BITS_ACH11_HW_IDX_8814B))
#define BIT_GET_ACH11_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH11_HW_IDX_8814B) & BIT_MASK_ACH11_HW_IDX_8814B)
#define BIT_SET_ACH11_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH11_HW_IDX_8814B(x) | BIT_ACH11_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH11_HOST_IDX_8814B 0
#define BIT_MASK_ACH11_HOST_IDX_8814B 0xfff
#define BIT_ACH11_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH11_HOST_IDX_8814B) \
<< BIT_SHIFT_ACH11_HOST_IDX_8814B)
#define BITS_ACH11_HOST_IDX_8814B \
(BIT_MASK_ACH11_HOST_IDX_8814B << BIT_SHIFT_ACH11_HOST_IDX_8814B)
#define BIT_CLEAR_ACH11_HOST_IDX_8814B(x) ((x) & (~BITS_ACH11_HOST_IDX_8814B))
#define BIT_GET_ACH11_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH11_HOST_IDX_8814B) & \
BIT_MASK_ACH11_HOST_IDX_8814B)
#define BIT_SET_ACH11_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH11_HOST_IDX_8814B(x) | BIT_ACH11_HOST_IDX_8814B(v))
/* 2 REG_ACH12_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH12_HW_IDX_8814B 16
#define BIT_MASK_ACH12_HW_IDX_8814B 0xfff
#define BIT_ACH12_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH12_HW_IDX_8814B) << BIT_SHIFT_ACH12_HW_IDX_8814B)
#define BITS_ACH12_HW_IDX_8814B \
(BIT_MASK_ACH12_HW_IDX_8814B << BIT_SHIFT_ACH12_HW_IDX_8814B)
#define BIT_CLEAR_ACH12_HW_IDX_8814B(x) ((x) & (~BITS_ACH12_HW_IDX_8814B))
#define BIT_GET_ACH12_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH12_HW_IDX_8814B) & BIT_MASK_ACH12_HW_IDX_8814B)
#define BIT_SET_ACH12_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH12_HW_IDX_8814B(x) | BIT_ACH12_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH12_HOST_IDX_8814B 0
#define BIT_MASK_ACH12_HOST_IDX_8814B 0xfff
#define BIT_ACH12_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH12_HOST_IDX_8814B) \
<< BIT_SHIFT_ACH12_HOST_IDX_8814B)
#define BITS_ACH12_HOST_IDX_8814B \
(BIT_MASK_ACH12_HOST_IDX_8814B << BIT_SHIFT_ACH12_HOST_IDX_8814B)
#define BIT_CLEAR_ACH12_HOST_IDX_8814B(x) ((x) & (~BITS_ACH12_HOST_IDX_8814B))
#define BIT_GET_ACH12_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH12_HOST_IDX_8814B) & \
BIT_MASK_ACH12_HOST_IDX_8814B)
#define BIT_SET_ACH12_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH12_HOST_IDX_8814B(x) | BIT_ACH12_HOST_IDX_8814B(v))
/* 2 REG_ACH13_TXBD_IDX_8814B */
#define BIT_SHIFT_ACH13_HW_IDX_8814B 16
#define BIT_MASK_ACH13_HW_IDX_8814B 0xfff
#define BIT_ACH13_HW_IDX_8814B(x) \
(((x) & BIT_MASK_ACH13_HW_IDX_8814B) << BIT_SHIFT_ACH13_HW_IDX_8814B)
#define BITS_ACH13_HW_IDX_8814B \
(BIT_MASK_ACH13_HW_IDX_8814B << BIT_SHIFT_ACH13_HW_IDX_8814B)
#define BIT_CLEAR_ACH13_HW_IDX_8814B(x) ((x) & (~BITS_ACH13_HW_IDX_8814B))
#define BIT_GET_ACH13_HW_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH13_HW_IDX_8814B) & BIT_MASK_ACH13_HW_IDX_8814B)
#define BIT_SET_ACH13_HW_IDX_8814B(x, v) \
(BIT_CLEAR_ACH13_HW_IDX_8814B(x) | BIT_ACH13_HW_IDX_8814B(v))
#define BIT_SHIFT_ACH13_HOST_IDX_8814B 0
#define BIT_MASK_ACH13_HOST_IDX_8814B 0xfff
#define BIT_ACH13_HOST_IDX_8814B(x) \
(((x) & BIT_MASK_ACH13_HOST_IDX_8814B) \
<< BIT_SHIFT_ACH13_HOST_IDX_8814B)
#define BITS_ACH13_HOST_IDX_8814B \
(BIT_MASK_ACH13_HOST_IDX_8814B << BIT_SHIFT_ACH13_HOST_IDX_8814B)
#define BIT_CLEAR_ACH13_HOST_IDX_8814B(x) ((x) & (~BITS_ACH13_HOST_IDX_8814B))
#define BIT_GET_ACH13_HOST_IDX_8814B(x) \
(((x) >> BIT_SHIFT_ACH13_HOST_IDX_8814B) & \
BIT_MASK_ACH13_HOST_IDX_8814B)
#define BIT_SET_ACH13_HOST_IDX_8814B(x, v) \
(BIT_CLEAR_ACH13_HOST_IDX_8814B(x) | BIT_ACH13_HOST_IDX_8814B(v))
/* 2 REG_AC_CHANNEL0_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL0_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL0_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL0_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL0_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL0_WEIGHT_8814B)
#define BITS_AC_CHANNEL0_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL0_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL0_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL0_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL0_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL0_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL0_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL0_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL0_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL0_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL0_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL1_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL1_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL1_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL1_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL1_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL1_WEIGHT_8814B)
#define BITS_AC_CHANNEL1_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL1_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL1_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL1_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL1_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL1_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL1_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL1_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL1_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL1_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL1_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL2_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL2_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL2_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL2_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL2_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL2_WEIGHT_8814B)
#define BITS_AC_CHANNEL2_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL2_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL2_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL2_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL2_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL2_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL2_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL2_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL2_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL2_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL2_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL3_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL3_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL3_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL3_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL3_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL3_WEIGHT_8814B)
#define BITS_AC_CHANNEL3_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL3_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL3_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL3_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL3_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL3_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL3_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL3_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL3_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL3_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL3_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL4_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL4_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL4_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL4_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL4_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL4_WEIGHT_8814B)
#define BITS_AC_CHANNEL4_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL4_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL4_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL4_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL4_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL4_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL4_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL4_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL4_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL4_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL4_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL5_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL5_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL5_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL5_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL5_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL5_WEIGHT_8814B)
#define BITS_AC_CHANNEL5_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL5_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL5_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL5_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL5_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL5_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL5_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL5_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL5_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL5_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL5_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL6_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL6_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL6_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL6_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL6_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL6_WEIGHT_8814B)
#define BITS_AC_CHANNEL6_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL6_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL6_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL6_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL6_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL6_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL6_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL6_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL6_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL6_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL6_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL7_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL7_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL7_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL7_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL7_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL7_WEIGHT_8814B)
#define BITS_AC_CHANNEL7_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL7_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL7_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL7_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL7_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL7_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL7_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL7_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL7_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL7_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL7_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL8_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL8_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL8_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL8_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL8_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL8_WEIGHT_8814B)
#define BITS_AC_CHANNEL8_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL8_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL8_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL8_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL8_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL8_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL8_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL8_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL8_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL8_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL8_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL9_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL9_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL9_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL9_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL9_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL9_WEIGHT_8814B)
#define BITS_AC_CHANNEL9_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL9_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL9_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL9_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL9_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL9_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL9_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL9_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL9_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL9_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL9_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL10_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL10_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL10_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL10_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL10_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL10_WEIGHT_8814B)
#define BITS_AC_CHANNEL10_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL10_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL10_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL10_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL10_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL10_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL10_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL10_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL10_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL10_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL10_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL11_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL11_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL11_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL11_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL11_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL11_WEIGHT_8814B)
#define BITS_AC_CHANNEL11_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL11_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL11_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL11_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL11_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL11_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL11_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL11_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL11_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL11_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL11_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL12_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL12_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL12_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL12_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL12_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL12_WEIGHT_8814B)
#define BITS_AC_CHANNEL12_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL12_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL12_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL12_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL12_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL12_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL12_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL12_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL12_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL12_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL12_WEIGHT_8814B(v))
/* 2 REG_AC_CHANNEL13_WEIGHT_8814B */
#define BIT_SHIFT_AC_CHANNEL13_WEIGHT_8814B 0
#define BIT_MASK_AC_CHANNEL13_WEIGHT_8814B 0xff
#define BIT_AC_CHANNEL13_WEIGHT_8814B(x) \
(((x) & BIT_MASK_AC_CHANNEL13_WEIGHT_8814B) \
<< BIT_SHIFT_AC_CHANNEL13_WEIGHT_8814B)
#define BITS_AC_CHANNEL13_WEIGHT_8814B \
(BIT_MASK_AC_CHANNEL13_WEIGHT_8814B \
<< BIT_SHIFT_AC_CHANNEL13_WEIGHT_8814B)
#define BIT_CLEAR_AC_CHANNEL13_WEIGHT_8814B(x) \
((x) & (~BITS_AC_CHANNEL13_WEIGHT_8814B))
#define BIT_GET_AC_CHANNEL13_WEIGHT_8814B(x) \
(((x) >> BIT_SHIFT_AC_CHANNEL13_WEIGHT_8814B) & \
BIT_MASK_AC_CHANNEL13_WEIGHT_8814B)
#define BIT_SET_AC_CHANNEL13_WEIGHT_8814B(x, v) \
(BIT_CLEAR_AC_CHANNEL13_WEIGHT_8814B(x) | \
BIT_AC_CHANNEL13_WEIGHT_8814B(v))
/* 2 REG_PCIE_HISR2_8814B */
#define BIT_BCNDMAINT_P4_8814B BIT(31)
#define BIT_BCNDMAINT_P3_8814B BIT(30)
#define BIT_BCNDMAINT_P2_8814B BIT(29)
#define BIT_BCNDMAINT_P1_8814B BIT(28)
#define BIT_SCH_PHY_TXOP_SIFS_INT_8814B BIT(23)
#define BIT_ATIMEND7_8814B BIT(22)
#define BIT_ATIMEND6_8814B BIT(21)
#define BIT_ATIMEND5_8814B BIT(20)
#define BIT_ATIMEND4_8814B BIT(19)
#define BIT_ATIMEND3_8814B BIT(18)
#define BIT_ATIMEND2_8814B BIT(17)
#define BIT_ATIMEND1_8814B BIT(16)
#define BIT_TXBCN7OK_8814B BIT(14)
#define BIT_TXBCN6OK_8814B BIT(13)
#define BIT_TXBCN5OK_8814B BIT(12)
#define BIT_TXBCN4OK_8814B BIT(11)
#define BIT_TXBCN3OK_8814B BIT(10)
#define BIT_TXBCN2OK_8814B BIT(9)
#define BIT_TXBCN1OK_8814B BIT(8)
#define BIT_TXBCN7ERR_8814B BIT(6)
#define BIT_TXBCN6ERR_8814B BIT(5)
#define BIT_TXBCN5ERR_8814B BIT(4)
#define BIT_TXBCN4ERR_8814B BIT(3)
#define BIT_TXBCN3ERR_8814B BIT(2)
#define BIT_TXBCN2ERR_8814B BIT(1)
#define BIT_TXBCN1ERR_8814B BIT(0)
/* 2 REG_PCIE_HISR3_8814B */
#define BIT_GTINT12_8814B BIT(24)
#define BIT_GTINT11_8814B BIT(23)
#define BIT_GTINT10_8814B BIT(22)
#define BIT_GTINT9_8814B BIT(21)
#define BIT_RX_DESC_BUF_FULL_8814B BIT(20)
#define BIT_CPHY_LDO_OCP_DET_INT_8814B BIT(19)
#define BIT_WDT_PLATFORM_INT_8814B BIT(18)
#define BIT_WDT_CPU_INT_8814B BIT(17)
#define BIT_SETH2CDOK_8814B BIT(16)
#define BIT_H2C_CMD_FULL_8814B BIT(15)
#define BIT_PKT_TRANS_ERR_8814B BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8814B BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8814B BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8814B BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8814B BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8814B BIT(9)
#define BIT_SEARCH_FAIL_8814B BIT(8)
#define BIT_PWR_INT_127TO96_8814B BIT(7)
#define BIT_PWR_INT_95TO64_8814B BIT(6)
#define BIT_PWR_INT_63TO32_8814B BIT(5)
#define BIT_PWR_INT_31TO0_8814B BIT(4)
#define BIT_RX_DMA_STUCK_8814B BIT(3)
#define BIT_TX_DMA_STUCK_8814B BIT(2)
#define BIT_DDMA0_LP_INT_8814B BIT(1)
#define BIT_DDMA0_HP_INT_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_QUEUELIST_INFO0_8814B */
#define BIT_SHIFT_QINFO0_8814B 0
#define BIT_MASK_QINFO0_8814B 0xffffffffL
#define BIT_QINFO0_8814B(x) \
(((x) & BIT_MASK_QINFO0_8814B) << BIT_SHIFT_QINFO0_8814B)
#define BITS_QINFO0_8814B (BIT_MASK_QINFO0_8814B << BIT_SHIFT_QINFO0_8814B)
#define BIT_CLEAR_QINFO0_8814B(x) ((x) & (~BITS_QINFO0_8814B))
#define BIT_GET_QINFO0_8814B(x) \
(((x) >> BIT_SHIFT_QINFO0_8814B) & BIT_MASK_QINFO0_8814B)
#define BIT_SET_QINFO0_8814B(x, v) \
(BIT_CLEAR_QINFO0_8814B(x) | BIT_QINFO0_8814B(v))
/* 2 REG_QUEUELIST_INFO1_8814B */
#define BIT_SHIFT_QINFO1_8814B 0
#define BIT_MASK_QINFO1_8814B 0xffffffffL
#define BIT_QINFO1_8814B(x) \
(((x) & BIT_MASK_QINFO1_8814B) << BIT_SHIFT_QINFO1_8814B)
#define BITS_QINFO1_8814B (BIT_MASK_QINFO1_8814B << BIT_SHIFT_QINFO1_8814B)
#define BIT_CLEAR_QINFO1_8814B(x) ((x) & (~BITS_QINFO1_8814B))
#define BIT_GET_QINFO1_8814B(x) \
(((x) >> BIT_SHIFT_QINFO1_8814B) & BIT_MASK_QINFO1_8814B)
#define BIT_SET_QINFO1_8814B(x, v) \
(BIT_CLEAR_QINFO1_8814B(x) | BIT_QINFO1_8814B(v))
/* 2 REG_QUEUELIST_INFO2_8814B */
#define BIT_SHIFT_QINFO2_8814B 0
#define BIT_MASK_QINFO2_8814B 0xffffffffL
#define BIT_QINFO2_8814B(x) \
(((x) & BIT_MASK_QINFO2_8814B) << BIT_SHIFT_QINFO2_8814B)
#define BITS_QINFO2_8814B (BIT_MASK_QINFO2_8814B << BIT_SHIFT_QINFO2_8814B)
#define BIT_CLEAR_QINFO2_8814B(x) ((x) & (~BITS_QINFO2_8814B))
#define BIT_GET_QINFO2_8814B(x) \
(((x) >> BIT_SHIFT_QINFO2_8814B) & BIT_MASK_QINFO2_8814B)
#define BIT_SET_QINFO2_8814B(x, v) \
(BIT_CLEAR_QINFO2_8814B(x) | BIT_QINFO2_8814B(v))
/* 2 REG_QUEUELIST_INFO3_8814B */
#define BIT_SHIFT_QINFO3_8814B 0
#define BIT_MASK_QINFO3_8814B 0xffffffffL
#define BIT_QINFO3_8814B(x) \
(((x) & BIT_MASK_QINFO3_8814B) << BIT_SHIFT_QINFO3_8814B)
#define BITS_QINFO3_8814B (BIT_MASK_QINFO3_8814B << BIT_SHIFT_QINFO3_8814B)
#define BIT_CLEAR_QINFO3_8814B(x) ((x) & (~BITS_QINFO3_8814B))
#define BIT_GET_QINFO3_8814B(x) \
(((x) >> BIT_SHIFT_QINFO3_8814B) & BIT_MASK_QINFO3_8814B)
#define BIT_SET_QINFO3_8814B(x, v) \
(BIT_CLEAR_QINFO3_8814B(x) | BIT_QINFO3_8814B(v))
/* 2 REG_QUEUELIST_INFO_EMPTY_8814B */
#define BIT_FWCMDQ_EMPTY_8814B BIT(31)
#define BIT_MGQ_CPU_EMPTY_V1_8814B BIT(30)
#define BIT_BCNQ_EMPTY_EXTP0_8814B BIT(29)
#define BIT_BCNQ_EMPTY_PORT4_8814B BIT(28)
#define BIT_BCNQ_EMPTY_PORT3_8814B BIT(27)
#define BIT_BCNQ_EMPTY_PORT2_8814B BIT(26)
#define BIT_BCNQ_EMPTY_PORT1_8814B BIT(25)
#define BIT_BCNQ_EMPTY_PORT0_8814B BIT(24)
#define BIT_HQQ_EMPTY_V1_8814B BIT(23)
#define BIT_MQQ_EMPTY_V2_8814B BIT(22)
#define BIT_S1_EMPTY_8814B BIT(21)
#define BIT_S0_EMPTY_8814B BIT(20)
#define BIT_AC19Q_EMPTY_8814B BIT(19)
#define BIT_AC18Q_EMPTY_8814B BIT(18)
#define BIT_AC17Q_EMPTY_8814B BIT(17)
#define BIT_AC16Q_EMPTY_8814B BIT(16)
#define BIT_AC15Q_EMPTY_8814B BIT(15)
#define BIT_AC14Q_EMPTY_8814B BIT(14)
#define BIT_AC13Q_EMPTY_8814B BIT(13)
#define BIT_AC12Q_EMPTY_8814B BIT(12)
#define BIT_AC11Q_EMPTY_8814B BIT(11)
#define BIT_AC10Q_EMPTY_8814B BIT(10)
#define BIT_AC9Q_EMPTY_8814B BIT(9)
#define BIT_AC8Q_EMPTY_8814B BIT(8)
#define BIT_AC7Q_EMPTY_8814B BIT(7)
#define BIT_AC6Q_EMPTY_8814B BIT(6)
#define BIT_AC5Q_EMPTY_8814B BIT(5)
#define BIT_AC4Q_EMPTY_8814B BIT(4)
#define BIT_AC3Q_EMPTY_8814B BIT(3)
#define BIT_AC2Q_EMPTY_8814B BIT(2)
#define BIT_AC1Q_EMPTY_8814B BIT(1)
#define BIT_AC0Q_EMPTY_8814B BIT(0)
/* 2 REG_QUEUELIST_ACQ_EN_8814B */
#define BIT_SHIFT_QINFO_CTRL_8814B 24
#define BIT_MASK_QINFO_CTRL_8814B 0x3f
#define BIT_QINFO_CTRL_8814B(x) \
(((x) & BIT_MASK_QINFO_CTRL_8814B) << BIT_SHIFT_QINFO_CTRL_8814B)
#define BITS_QINFO_CTRL_8814B \
(BIT_MASK_QINFO_CTRL_8814B << BIT_SHIFT_QINFO_CTRL_8814B)
#define BIT_CLEAR_QINFO_CTRL_8814B(x) ((x) & (~BITS_QINFO_CTRL_8814B))
#define BIT_GET_QINFO_CTRL_8814B(x) \
(((x) >> BIT_SHIFT_QINFO_CTRL_8814B) & BIT_MASK_QINFO_CTRL_8814B)
#define BIT_SET_QINFO_CTRL_8814B(x, v) \
(BIT_CLEAR_QINFO_CTRL_8814B(x) | BIT_QINFO_CTRL_8814B(v))
#define BIT_SHIFT_QINFO_MODE_BAND_8814B 20
#define BIT_MASK_QINFO_MODE_BAND_8814B 0x7
#define BIT_QINFO_MODE_BAND_8814B(x) \
(((x) & BIT_MASK_QINFO_MODE_BAND_8814B) \
<< BIT_SHIFT_QINFO_MODE_BAND_8814B)
#define BITS_QINFO_MODE_BAND_8814B \
(BIT_MASK_QINFO_MODE_BAND_8814B << BIT_SHIFT_QINFO_MODE_BAND_8814B)
#define BIT_CLEAR_QINFO_MODE_BAND_8814B(x) ((x) & (~BITS_QINFO_MODE_BAND_8814B))
#define BIT_GET_QINFO_MODE_BAND_8814B(x) \
(((x) >> BIT_SHIFT_QINFO_MODE_BAND_8814B) & \
BIT_MASK_QINFO_MODE_BAND_8814B)
#define BIT_SET_QINFO_MODE_BAND_8814B(x, v) \
(BIT_CLEAR_QINFO_MODE_BAND_8814B(x) | BIT_QINFO_MODE_BAND_8814B(v))
#define BIT_ACQ19_ENABLE_8814B BIT(19)
#define BIT_ACQ18_ENABLE_8814B BIT(18)
#define BIT_ACQ17_ENABLE_8814B BIT(17)
#define BIT_ACQ16_ENABLE_8814B BIT(16)
#define BIT_ACQ15_ENABLE_8814B BIT(15)
#define BIT_ACQ14_ENABLE_8814B BIT(14)
#define BIT_ACQ13_ENABLE_8814B BIT(13)
#define BIT_ACQ12_ENABLE_8814B BIT(12)
#define BIT_ACQ11_ENABLE_8814B BIT(11)
#define BIT_ACQ10_ENABLE_8814B BIT(10)
#define BIT_ACQ9_ENABLE_8814B BIT(9)
#define BIT_ACQ8_ENABLE_8814B BIT(8)
#define BIT_ACQ7_ENABLE_8814B BIT(7)
#define BIT_ACQ6_ENABLE_8814B BIT(6)
#define BIT_ACQ5_ENABLE_8814B BIT(5)
#define BIT_ACQ4_ENABLE_8814B BIT(4)
#define BIT_ACQ3_ENABLE_8814B BIT(3)
#define BIT_ACQ2_ENABLE_8814B BIT(2)
#define BIT_ACQ1_ENABLE_8814B BIT(1)
#define BIT_ACQ0_ENABLE_8814B BIT(0)
/* 2 REG_BCNQ_BDNY_V2_8814B */
#define BIT_SHIFT_BCNQ_PGBNDY_WSEL_8814B 28
#define BIT_MASK_BCNQ_PGBNDY_WSEL_8814B 0x7
#define BIT_BCNQ_PGBNDY_WSEL_8814B(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_WSEL_8814B) \
<< BIT_SHIFT_BCNQ_PGBNDY_WSEL_8814B)
#define BITS_BCNQ_PGBNDY_WSEL_8814B \
(BIT_MASK_BCNQ_PGBNDY_WSEL_8814B << BIT_SHIFT_BCNQ_PGBNDY_WSEL_8814B)
#define BIT_CLEAR_BCNQ_PGBNDY_WSEL_8814B(x) \
((x) & (~BITS_BCNQ_PGBNDY_WSEL_8814B))
#define BIT_GET_BCNQ_PGBNDY_WSEL_8814B(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_WSEL_8814B) & \
BIT_MASK_BCNQ_PGBNDY_WSEL_8814B)
#define BIT_SET_BCNQ_PGBNDY_WSEL_8814B(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_WSEL_8814B(x) | BIT_BCNQ_PGBNDY_WSEL_8814B(v))
#define BIT_SHIFT_BCNQ_PGBNDY_RCONTENT_8814B 12
#define BIT_MASK_BCNQ_PGBNDY_RCONTENT_8814B 0xfff
#define BIT_BCNQ_PGBNDY_RCONTENT_8814B(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_RCONTENT_8814B) \
<< BIT_SHIFT_BCNQ_PGBNDY_RCONTENT_8814B)
#define BITS_BCNQ_PGBNDY_RCONTENT_8814B \
(BIT_MASK_BCNQ_PGBNDY_RCONTENT_8814B \
<< BIT_SHIFT_BCNQ_PGBNDY_RCONTENT_8814B)
#define BIT_CLEAR_BCNQ_PGBNDY_RCONTENT_8814B(x) \
((x) & (~BITS_BCNQ_PGBNDY_RCONTENT_8814B))
#define BIT_GET_BCNQ_PGBNDY_RCONTENT_8814B(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_RCONTENT_8814B) & \
BIT_MASK_BCNQ_PGBNDY_RCONTENT_8814B)
#define BIT_SET_BCNQ_PGBNDY_RCONTENT_8814B(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_RCONTENT_8814B(x) | \
BIT_BCNQ_PGBNDY_RCONTENT_8814B(v))
#define BIT_SHIFT_BCNQ_PGBNDY_WCONTENT_8814B 0
#define BIT_MASK_BCNQ_PGBNDY_WCONTENT_8814B 0xfff
#define BIT_BCNQ_PGBNDY_WCONTENT_8814B(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_WCONTENT_8814B) \
<< BIT_SHIFT_BCNQ_PGBNDY_WCONTENT_8814B)
#define BITS_BCNQ_PGBNDY_WCONTENT_8814B \
(BIT_MASK_BCNQ_PGBNDY_WCONTENT_8814B \
<< BIT_SHIFT_BCNQ_PGBNDY_WCONTENT_8814B)
#define BIT_CLEAR_BCNQ_PGBNDY_WCONTENT_8814B(x) \
((x) & (~BITS_BCNQ_PGBNDY_WCONTENT_8814B))
#define BIT_GET_BCNQ_PGBNDY_WCONTENT_8814B(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_WCONTENT_8814B) & \
BIT_MASK_BCNQ_PGBNDY_WCONTENT_8814B)
#define BIT_SET_BCNQ_PGBNDY_WCONTENT_8814B(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_WCONTENT_8814B(x) | \
BIT_BCNQ_PGBNDY_WCONTENT_8814B(v))
/* 2 REG_CPU_MGQ_INFO_8814B */
#define BIT_CPUMGT_CLR_V1_8814B BIT(30)
#define BIT_CPUMGT_POLL_8814B BIT(29)
#define BIT_BCN_EXT_POLL_8814B BIT(21)
#define BIT_BCN4_POLL_8814B BIT(20)
#define BIT_BCN3_POLL_8814B BIT(19)
#define BIT_BCN2_POLL_8814B BIT(18)
#define BIT_BCN1_POLL_V1_8814B BIT(17)
#define BIT_BCN_POLL_V1_8814B BIT(16)
#define BIT_SHIFT_FREE_TAIL_PAGE_8814B 0
#define BIT_MASK_FREE_TAIL_PAGE_8814B 0xfff
#define BIT_FREE_TAIL_PAGE_8814B(x) \
(((x) & BIT_MASK_FREE_TAIL_PAGE_8814B) \
<< BIT_SHIFT_FREE_TAIL_PAGE_8814B)
#define BITS_FREE_TAIL_PAGE_8814B \
(BIT_MASK_FREE_TAIL_PAGE_8814B << BIT_SHIFT_FREE_TAIL_PAGE_8814B)
#define BIT_CLEAR_FREE_TAIL_PAGE_8814B(x) ((x) & (~BITS_FREE_TAIL_PAGE_8814B))
#define BIT_GET_FREE_TAIL_PAGE_8814B(x) \
(((x) >> BIT_SHIFT_FREE_TAIL_PAGE_8814B) & \
BIT_MASK_FREE_TAIL_PAGE_8814B)
#define BIT_SET_FREE_TAIL_PAGE_8814B(x, v) \
(BIT_CLEAR_FREE_TAIL_PAGE_8814B(x) | BIT_FREE_TAIL_PAGE_8814B(v))
/* 2 REG_FWHW_TXQ_CTRL_8814B */
#define BIT_RTS_LIMIT_IN_OFDM_8814B BIT(23)
#define BIT_EN_RD_RESP_NAV_BK_8814B BIT(21)
#define BIT_EN_WR_FREE_TAIL_8814B BIT(20)
#define BIT_NOTXRPT_USERATE_EN_8814B BIT(19)
#define BIT_DIS_TXFAIL_RPT_8814B BIT(18)
#define BIT_FTM_TIMEOUT_BYPASS_8814B BIT(16)
#define BIT_EN_BCNQ_DL5_8814B BIT(13)
#define BIT_EN_BCNQ_DL4_8814B BIT(12)
#define BIT_EN_BCNQ_DL3_8814B BIT(11)
#define BIT_EN_BCNQ_DL2_8814B BIT(10)
#define BIT_EN_BCNQ_DL1_8814B BIT(9)
#define BIT_EN_BCNQ_DL0_8814B BIT(8)
#define BIT_EN_RTY_BK_8814B BIT(7)
#define BIT_EN_USE_INI_RAT_8814B BIT(6)
#define BIT_EN_RTS_NAV_BK_8814B BIT(5)
#define BIT_DIS_SSN_CHECK_8814B BIT(4)
#define BIT_MACID_MATCH_RTS_8814B BIT(3)
#define BIT_EN_BCN_TRXRPT_V1_8814B BIT(2)
#define BIT_EN_FTMRPT_V1_8814B BIT(1)
#define BIT_BMC_NAV_PROTECT_8814B BIT(0)
/* 2 REG_DATAFB_SEL_8814B */
#define BIT_BROADCAST_RTY_EN_8814B BIT(3)
#define BIT_EN_RTY_BK_COD_8814B BIT(2)
#define BIT_SHIFT__DATA_FALLBACK_SEL_8814B 0
#define BIT_MASK__DATA_FALLBACK_SEL_8814B 0x3
#define BIT__DATA_FALLBACK_SEL_8814B(x) \
(((x) & BIT_MASK__DATA_FALLBACK_SEL_8814B) \
<< BIT_SHIFT__DATA_FALLBACK_SEL_8814B)
#define BITS__DATA_FALLBACK_SEL_8814B \
(BIT_MASK__DATA_FALLBACK_SEL_8814B \
<< BIT_SHIFT__DATA_FALLBACK_SEL_8814B)
#define BIT_CLEAR__DATA_FALLBACK_SEL_8814B(x) \
((x) & (~BITS__DATA_FALLBACK_SEL_8814B))
#define BIT_GET__DATA_FALLBACK_SEL_8814B(x) \
(((x) >> BIT_SHIFT__DATA_FALLBACK_SEL_8814B) & \
BIT_MASK__DATA_FALLBACK_SEL_8814B)
#define BIT_SET__DATA_FALLBACK_SEL_8814B(x, v) \
(BIT_CLEAR__DATA_FALLBACK_SEL_8814B(x) | \
BIT__DATA_FALLBACK_SEL_8814B(v))
/* 2 REG_TXBDNY_8814B */
#define BIT_SHIFT_TXBNDY_8814B 0
#define BIT_MASK_TXBNDY_8814B 0xfff
#define BIT_TXBNDY_8814B(x) \
(((x) & BIT_MASK_TXBNDY_8814B) << BIT_SHIFT_TXBNDY_8814B)
#define BITS_TXBNDY_8814B (BIT_MASK_TXBNDY_8814B << BIT_SHIFT_TXBNDY_8814B)
#define BIT_CLEAR_TXBNDY_8814B(x) ((x) & (~BITS_TXBNDY_8814B))
#define BIT_GET_TXBNDY_8814B(x) \
(((x) >> BIT_SHIFT_TXBNDY_8814B) & BIT_MASK_TXBNDY_8814B)
#define BIT_SET_TXBNDY_8814B(x, v) \
(BIT_CLEAR_TXBNDY_8814B(x) | BIT_TXBNDY_8814B(v))
/* 2 REG_LIFETIME_EN_8814B */
#define BIT_BT_INT_CPU_8814B BIT(7)
#define BIT_BT_INT_PTA_8814B BIT(6)
#define BIT_EN_CTRL_RTYBIT_8814B BIT(4)
#define BIT_LIFETIME_BK_EN_8814B BIT(3)
#define BIT_LIFETIME_BE_EN_8814B BIT(2)
#define BIT_LIFETIME_VI_EN_8814B BIT(1)
#define BIT_LIFETIME_VO_EN_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_SPEC_SIFS_8814B */
#define BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8814B 8
#define BIT_MASK_SPEC_SIFS_OFDM_PTCL_8814B 0xff
#define BIT_SPEC_SIFS_OFDM_PTCL_8814B(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_PTCL_8814B) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8814B)
#define BITS_SPEC_SIFS_OFDM_PTCL_8814B \
(BIT_MASK_SPEC_SIFS_OFDM_PTCL_8814B \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8814B)
#define BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8814B(x) \
((x) & (~BITS_SPEC_SIFS_OFDM_PTCL_8814B))
#define BIT_GET_SPEC_SIFS_OFDM_PTCL_8814B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8814B) & \
BIT_MASK_SPEC_SIFS_OFDM_PTCL_8814B)
#define BIT_SET_SPEC_SIFS_OFDM_PTCL_8814B(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8814B(x) | \
BIT_SPEC_SIFS_OFDM_PTCL_8814B(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8814B 0
#define BIT_MASK_SPEC_SIFS_CCK_PTCL_8814B 0xff
#define BIT_SPEC_SIFS_CCK_PTCL_8814B(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_PTCL_8814B) \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8814B)
#define BITS_SPEC_SIFS_CCK_PTCL_8814B \
(BIT_MASK_SPEC_SIFS_CCK_PTCL_8814B \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8814B)
#define BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8814B(x) \
((x) & (~BITS_SPEC_SIFS_CCK_PTCL_8814B))
#define BIT_GET_SPEC_SIFS_CCK_PTCL_8814B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8814B) & \
BIT_MASK_SPEC_SIFS_CCK_PTCL_8814B)
#define BIT_SET_SPEC_SIFS_CCK_PTCL_8814B(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8814B(x) | \
BIT_SPEC_SIFS_CCK_PTCL_8814B(v))
/* 2 REG_RETRY_LIMIT_8814B */
#define BIT_SHIFT_SRL_8814B 8
#define BIT_MASK_SRL_8814B 0x3f
#define BIT_SRL_8814B(x) (((x) & BIT_MASK_SRL_8814B) << BIT_SHIFT_SRL_8814B)
#define BITS_SRL_8814B (BIT_MASK_SRL_8814B << BIT_SHIFT_SRL_8814B)
#define BIT_CLEAR_SRL_8814B(x) ((x) & (~BITS_SRL_8814B))
#define BIT_GET_SRL_8814B(x) (((x) >> BIT_SHIFT_SRL_8814B) & BIT_MASK_SRL_8814B)
#define BIT_SET_SRL_8814B(x, v) (BIT_CLEAR_SRL_8814B(x) | BIT_SRL_8814B(v))
#define BIT_SHIFT_LRL_8814B 0
#define BIT_MASK_LRL_8814B 0x3f
#define BIT_LRL_8814B(x) (((x) & BIT_MASK_LRL_8814B) << BIT_SHIFT_LRL_8814B)
#define BITS_LRL_8814B (BIT_MASK_LRL_8814B << BIT_SHIFT_LRL_8814B)
#define BIT_CLEAR_LRL_8814B(x) ((x) & (~BITS_LRL_8814B))
#define BIT_GET_LRL_8814B(x) (((x) >> BIT_SHIFT_LRL_8814B) & BIT_MASK_LRL_8814B)
#define BIT_SET_LRL_8814B(x, v) (BIT_CLEAR_LRL_8814B(x) | BIT_LRL_8814B(v))
/* 2 REG_TXBF_CTRL_8814B */
#define BIT_ENABLE_NDPA_8814B BIT(31)
#define BIT_NDPA_PARA_8814B BIT(30)
#define BIT_PROP_TXBF_8814B BIT(29)
#define BIT_EN_NDPA_INT_8814B BIT(28)
#define BIT_TXBF1_80M_160M_8814B BIT(27)
#define BIT_TXBF1_40M_8814B BIT(26)
#define BIT_TXBF1_20M_8814B BIT(25)
#define BIT_SHIFT_TXBF1_AID_8814B 16
#define BIT_MASK_TXBF1_AID_8814B 0x1ff
#define BIT_TXBF1_AID_8814B(x) \
(((x) & BIT_MASK_TXBF1_AID_8814B) << BIT_SHIFT_TXBF1_AID_8814B)
#define BITS_TXBF1_AID_8814B \
(BIT_MASK_TXBF1_AID_8814B << BIT_SHIFT_TXBF1_AID_8814B)
#define BIT_CLEAR_TXBF1_AID_8814B(x) ((x) & (~BITS_TXBF1_AID_8814B))
#define BIT_GET_TXBF1_AID_8814B(x) \
(((x) >> BIT_SHIFT_TXBF1_AID_8814B) & BIT_MASK_TXBF1_AID_8814B)
#define BIT_SET_TXBF1_AID_8814B(x, v) \
(BIT_CLEAR_TXBF1_AID_8814B(x) | BIT_TXBF1_AID_8814B(v))
#define BIT_DIS_NDP_BFEN_8814B BIT(15)
#define BIT_TXBCN_NOBLOCK_NDP_8814B BIT(14)
#define BIT_TXBF0_80M_160M_8814B BIT(11)
#define BIT_TXBF0_40M_8814B BIT(10)
#define BIT_TXBF0_20M_8814B BIT(9)
#define BIT_SHIFT_TXBF0_AID_8814B 0
#define BIT_MASK_TXBF0_AID_8814B 0x1ff
#define BIT_TXBF0_AID_8814B(x) \
(((x) & BIT_MASK_TXBF0_AID_8814B) << BIT_SHIFT_TXBF0_AID_8814B)
#define BITS_TXBF0_AID_8814B \
(BIT_MASK_TXBF0_AID_8814B << BIT_SHIFT_TXBF0_AID_8814B)
#define BIT_CLEAR_TXBF0_AID_8814B(x) ((x) & (~BITS_TXBF0_AID_8814B))
#define BIT_GET_TXBF0_AID_8814B(x) \
(((x) >> BIT_SHIFT_TXBF0_AID_8814B) & BIT_MASK_TXBF0_AID_8814B)
#define BIT_SET_TXBF0_AID_8814B(x, v) \
(BIT_CLEAR_TXBF0_AID_8814B(x) | BIT_TXBF0_AID_8814B(v))
/* 2 REG_DARFRC_8814B */
#define BIT_SHIFT_DARF_RC4_V1_8814B 24
#define BIT_MASK_DARF_RC4_V1_8814B 0x3f
#define BIT_DARF_RC4_V1_8814B(x) \
(((x) & BIT_MASK_DARF_RC4_V1_8814B) << BIT_SHIFT_DARF_RC4_V1_8814B)
#define BITS_DARF_RC4_V1_8814B \
(BIT_MASK_DARF_RC4_V1_8814B << BIT_SHIFT_DARF_RC4_V1_8814B)
#define BIT_CLEAR_DARF_RC4_V1_8814B(x) ((x) & (~BITS_DARF_RC4_V1_8814B))
#define BIT_GET_DARF_RC4_V1_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC4_V1_8814B) & BIT_MASK_DARF_RC4_V1_8814B)
#define BIT_SET_DARF_RC4_V1_8814B(x, v) \
(BIT_CLEAR_DARF_RC4_V1_8814B(x) | BIT_DARF_RC4_V1_8814B(v))
#define BIT_SHIFT_DARF_RC3_V1_8814B 16
#define BIT_MASK_DARF_RC3_V1_8814B 0x3f
#define BIT_DARF_RC3_V1_8814B(x) \
(((x) & BIT_MASK_DARF_RC3_V1_8814B) << BIT_SHIFT_DARF_RC3_V1_8814B)
#define BITS_DARF_RC3_V1_8814B \
(BIT_MASK_DARF_RC3_V1_8814B << BIT_SHIFT_DARF_RC3_V1_8814B)
#define BIT_CLEAR_DARF_RC3_V1_8814B(x) ((x) & (~BITS_DARF_RC3_V1_8814B))
#define BIT_GET_DARF_RC3_V1_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC3_V1_8814B) & BIT_MASK_DARF_RC3_V1_8814B)
#define BIT_SET_DARF_RC3_V1_8814B(x, v) \
(BIT_CLEAR_DARF_RC3_V1_8814B(x) | BIT_DARF_RC3_V1_8814B(v))
#define BIT_SHIFT_DARF_RC2_V1_8814B 8
#define BIT_MASK_DARF_RC2_V1_8814B 0x3f
#define BIT_DARF_RC2_V1_8814B(x) \
(((x) & BIT_MASK_DARF_RC2_V1_8814B) << BIT_SHIFT_DARF_RC2_V1_8814B)
#define BITS_DARF_RC2_V1_8814B \
(BIT_MASK_DARF_RC2_V1_8814B << BIT_SHIFT_DARF_RC2_V1_8814B)
#define BIT_CLEAR_DARF_RC2_V1_8814B(x) ((x) & (~BITS_DARF_RC2_V1_8814B))
#define BIT_GET_DARF_RC2_V1_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC2_V1_8814B) & BIT_MASK_DARF_RC2_V1_8814B)
#define BIT_SET_DARF_RC2_V1_8814B(x, v) \
(BIT_CLEAR_DARF_RC2_V1_8814B(x) | BIT_DARF_RC2_V1_8814B(v))
#define BIT_SHIFT_DARF_RC1_V1_8814B 0
#define BIT_MASK_DARF_RC1_V1_8814B 0x3f
#define BIT_DARF_RC1_V1_8814B(x) \
(((x) & BIT_MASK_DARF_RC1_V1_8814B) << BIT_SHIFT_DARF_RC1_V1_8814B)
#define BITS_DARF_RC1_V1_8814B \
(BIT_MASK_DARF_RC1_V1_8814B << BIT_SHIFT_DARF_RC1_V1_8814B)
#define BIT_CLEAR_DARF_RC1_V1_8814B(x) ((x) & (~BITS_DARF_RC1_V1_8814B))
#define BIT_GET_DARF_RC1_V1_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC1_V1_8814B) & BIT_MASK_DARF_RC1_V1_8814B)
#define BIT_SET_DARF_RC1_V1_8814B(x, v) \
(BIT_CLEAR_DARF_RC1_V1_8814B(x) | BIT_DARF_RC1_V1_8814B(v))
/* 2 REG_DARFRCH_8814B */
#define BIT_SHIFT_DARF_RC8_V2_8814B 24
#define BIT_MASK_DARF_RC8_V2_8814B 0x3f
#define BIT_DARF_RC8_V2_8814B(x) \
(((x) & BIT_MASK_DARF_RC8_V2_8814B) << BIT_SHIFT_DARF_RC8_V2_8814B)
#define BITS_DARF_RC8_V2_8814B \
(BIT_MASK_DARF_RC8_V2_8814B << BIT_SHIFT_DARF_RC8_V2_8814B)
#define BIT_CLEAR_DARF_RC8_V2_8814B(x) ((x) & (~BITS_DARF_RC8_V2_8814B))
#define BIT_GET_DARF_RC8_V2_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC8_V2_8814B) & BIT_MASK_DARF_RC8_V2_8814B)
#define BIT_SET_DARF_RC8_V2_8814B(x, v) \
(BIT_CLEAR_DARF_RC8_V2_8814B(x) | BIT_DARF_RC8_V2_8814B(v))
#define BIT_SHIFT_DARF_RC7_V2_8814B 16
#define BIT_MASK_DARF_RC7_V2_8814B 0x3f
#define BIT_DARF_RC7_V2_8814B(x) \
(((x) & BIT_MASK_DARF_RC7_V2_8814B) << BIT_SHIFT_DARF_RC7_V2_8814B)
#define BITS_DARF_RC7_V2_8814B \
(BIT_MASK_DARF_RC7_V2_8814B << BIT_SHIFT_DARF_RC7_V2_8814B)
#define BIT_CLEAR_DARF_RC7_V2_8814B(x) ((x) & (~BITS_DARF_RC7_V2_8814B))
#define BIT_GET_DARF_RC7_V2_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC7_V2_8814B) & BIT_MASK_DARF_RC7_V2_8814B)
#define BIT_SET_DARF_RC7_V2_8814B(x, v) \
(BIT_CLEAR_DARF_RC7_V2_8814B(x) | BIT_DARF_RC7_V2_8814B(v))
#define BIT_SHIFT_DARF_RC6_V2_8814B 8
#define BIT_MASK_DARF_RC6_V2_8814B 0x3f
#define BIT_DARF_RC6_V2_8814B(x) \
(((x) & BIT_MASK_DARF_RC6_V2_8814B) << BIT_SHIFT_DARF_RC6_V2_8814B)
#define BITS_DARF_RC6_V2_8814B \
(BIT_MASK_DARF_RC6_V2_8814B << BIT_SHIFT_DARF_RC6_V2_8814B)
#define BIT_CLEAR_DARF_RC6_V2_8814B(x) ((x) & (~BITS_DARF_RC6_V2_8814B))
#define BIT_GET_DARF_RC6_V2_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC6_V2_8814B) & BIT_MASK_DARF_RC6_V2_8814B)
#define BIT_SET_DARF_RC6_V2_8814B(x, v) \
(BIT_CLEAR_DARF_RC6_V2_8814B(x) | BIT_DARF_RC6_V2_8814B(v))
#define BIT_SHIFT_DARF_RC5_V2_8814B 0
#define BIT_MASK_DARF_RC5_V2_8814B 0x3f
#define BIT_DARF_RC5_V2_8814B(x) \
(((x) & BIT_MASK_DARF_RC5_V2_8814B) << BIT_SHIFT_DARF_RC5_V2_8814B)
#define BITS_DARF_RC5_V2_8814B \
(BIT_MASK_DARF_RC5_V2_8814B << BIT_SHIFT_DARF_RC5_V2_8814B)
#define BIT_CLEAR_DARF_RC5_V2_8814B(x) ((x) & (~BITS_DARF_RC5_V2_8814B))
#define BIT_GET_DARF_RC5_V2_8814B(x) \
(((x) >> BIT_SHIFT_DARF_RC5_V2_8814B) & BIT_MASK_DARF_RC5_V2_8814B)
#define BIT_SET_DARF_RC5_V2_8814B(x, v) \
(BIT_CLEAR_DARF_RC5_V2_8814B(x) | BIT_DARF_RC5_V2_8814B(v))
/* 2 REG_RARFRC_8814B */
#define BIT_SHIFT_RARF_RC4_8814B 24
#define BIT_MASK_RARF_RC4_8814B 0x1f
#define BIT_RARF_RC4_8814B(x) \
(((x) & BIT_MASK_RARF_RC4_8814B) << BIT_SHIFT_RARF_RC4_8814B)
#define BITS_RARF_RC4_8814B \
(BIT_MASK_RARF_RC4_8814B << BIT_SHIFT_RARF_RC4_8814B)
#define BIT_CLEAR_RARF_RC4_8814B(x) ((x) & (~BITS_RARF_RC4_8814B))
#define BIT_GET_RARF_RC4_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC4_8814B) & BIT_MASK_RARF_RC4_8814B)
#define BIT_SET_RARF_RC4_8814B(x, v) \
(BIT_CLEAR_RARF_RC4_8814B(x) | BIT_RARF_RC4_8814B(v))
#define BIT_SHIFT_RARF_RC3_8814B 16
#define BIT_MASK_RARF_RC3_8814B 0x1f
#define BIT_RARF_RC3_8814B(x) \
(((x) & BIT_MASK_RARF_RC3_8814B) << BIT_SHIFT_RARF_RC3_8814B)
#define BITS_RARF_RC3_8814B \
(BIT_MASK_RARF_RC3_8814B << BIT_SHIFT_RARF_RC3_8814B)
#define BIT_CLEAR_RARF_RC3_8814B(x) ((x) & (~BITS_RARF_RC3_8814B))
#define BIT_GET_RARF_RC3_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC3_8814B) & BIT_MASK_RARF_RC3_8814B)
#define BIT_SET_RARF_RC3_8814B(x, v) \
(BIT_CLEAR_RARF_RC3_8814B(x) | BIT_RARF_RC3_8814B(v))
#define BIT_SHIFT_RARF_RC2_8814B 8
#define BIT_MASK_RARF_RC2_8814B 0x1f
#define BIT_RARF_RC2_8814B(x) \
(((x) & BIT_MASK_RARF_RC2_8814B) << BIT_SHIFT_RARF_RC2_8814B)
#define BITS_RARF_RC2_8814B \
(BIT_MASK_RARF_RC2_8814B << BIT_SHIFT_RARF_RC2_8814B)
#define BIT_CLEAR_RARF_RC2_8814B(x) ((x) & (~BITS_RARF_RC2_8814B))
#define BIT_GET_RARF_RC2_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC2_8814B) & BIT_MASK_RARF_RC2_8814B)
#define BIT_SET_RARF_RC2_8814B(x, v) \
(BIT_CLEAR_RARF_RC2_8814B(x) | BIT_RARF_RC2_8814B(v))
#define BIT_SHIFT_RARF_RC1_8814B 0
#define BIT_MASK_RARF_RC1_8814B 0x1f
#define BIT_RARF_RC1_8814B(x) \
(((x) & BIT_MASK_RARF_RC1_8814B) << BIT_SHIFT_RARF_RC1_8814B)
#define BITS_RARF_RC1_8814B \
(BIT_MASK_RARF_RC1_8814B << BIT_SHIFT_RARF_RC1_8814B)
#define BIT_CLEAR_RARF_RC1_8814B(x) ((x) & (~BITS_RARF_RC1_8814B))
#define BIT_GET_RARF_RC1_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC1_8814B) & BIT_MASK_RARF_RC1_8814B)
#define BIT_SET_RARF_RC1_8814B(x, v) \
(BIT_CLEAR_RARF_RC1_8814B(x) | BIT_RARF_RC1_8814B(v))
/* 2 REG_RARFRCH_8814B */
#define BIT_SHIFT_RARF_RC8_V1_8814B 24
#define BIT_MASK_RARF_RC8_V1_8814B 0x1f
#define BIT_RARF_RC8_V1_8814B(x) \
(((x) & BIT_MASK_RARF_RC8_V1_8814B) << BIT_SHIFT_RARF_RC8_V1_8814B)
#define BITS_RARF_RC8_V1_8814B \
(BIT_MASK_RARF_RC8_V1_8814B << BIT_SHIFT_RARF_RC8_V1_8814B)
#define BIT_CLEAR_RARF_RC8_V1_8814B(x) ((x) & (~BITS_RARF_RC8_V1_8814B))
#define BIT_GET_RARF_RC8_V1_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC8_V1_8814B) & BIT_MASK_RARF_RC8_V1_8814B)
#define BIT_SET_RARF_RC8_V1_8814B(x, v) \
(BIT_CLEAR_RARF_RC8_V1_8814B(x) | BIT_RARF_RC8_V1_8814B(v))
#define BIT_SHIFT_RARF_RC7_V1_8814B 16
#define BIT_MASK_RARF_RC7_V1_8814B 0x1f
#define BIT_RARF_RC7_V1_8814B(x) \
(((x) & BIT_MASK_RARF_RC7_V1_8814B) << BIT_SHIFT_RARF_RC7_V1_8814B)
#define BITS_RARF_RC7_V1_8814B \
(BIT_MASK_RARF_RC7_V1_8814B << BIT_SHIFT_RARF_RC7_V1_8814B)
#define BIT_CLEAR_RARF_RC7_V1_8814B(x) ((x) & (~BITS_RARF_RC7_V1_8814B))
#define BIT_GET_RARF_RC7_V1_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC7_V1_8814B) & BIT_MASK_RARF_RC7_V1_8814B)
#define BIT_SET_RARF_RC7_V1_8814B(x, v) \
(BIT_CLEAR_RARF_RC7_V1_8814B(x) | BIT_RARF_RC7_V1_8814B(v))
#define BIT_SHIFT_RARF_RC6_V1_8814B 8
#define BIT_MASK_RARF_RC6_V1_8814B 0x1f
#define BIT_RARF_RC6_V1_8814B(x) \
(((x) & BIT_MASK_RARF_RC6_V1_8814B) << BIT_SHIFT_RARF_RC6_V1_8814B)
#define BITS_RARF_RC6_V1_8814B \
(BIT_MASK_RARF_RC6_V1_8814B << BIT_SHIFT_RARF_RC6_V1_8814B)
#define BIT_CLEAR_RARF_RC6_V1_8814B(x) ((x) & (~BITS_RARF_RC6_V1_8814B))
#define BIT_GET_RARF_RC6_V1_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC6_V1_8814B) & BIT_MASK_RARF_RC6_V1_8814B)
#define BIT_SET_RARF_RC6_V1_8814B(x, v) \
(BIT_CLEAR_RARF_RC6_V1_8814B(x) | BIT_RARF_RC6_V1_8814B(v))
#define BIT_SHIFT_RARF_RC5_V1_8814B 0
#define BIT_MASK_RARF_RC5_V1_8814B 0x1f
#define BIT_RARF_RC5_V1_8814B(x) \
(((x) & BIT_MASK_RARF_RC5_V1_8814B) << BIT_SHIFT_RARF_RC5_V1_8814B)
#define BITS_RARF_RC5_V1_8814B \
(BIT_MASK_RARF_RC5_V1_8814B << BIT_SHIFT_RARF_RC5_V1_8814B)
#define BIT_CLEAR_RARF_RC5_V1_8814B(x) ((x) & (~BITS_RARF_RC5_V1_8814B))
#define BIT_GET_RARF_RC5_V1_8814B(x) \
(((x) >> BIT_SHIFT_RARF_RC5_V1_8814B) & BIT_MASK_RARF_RC5_V1_8814B)
#define BIT_SET_RARF_RC5_V1_8814B(x, v) \
(BIT_CLEAR_RARF_RC5_V1_8814B(x) | BIT_RARF_RC5_V1_8814B(v))
/* 2 REG_RRSR_8814B */
#define BIT_SHIFT_RRSR_RSC_8814B 21
#define BIT_MASK_RRSR_RSC_8814B 0x3
#define BIT_RRSR_RSC_8814B(x) \
(((x) & BIT_MASK_RRSR_RSC_8814B) << BIT_SHIFT_RRSR_RSC_8814B)
#define BITS_RRSR_RSC_8814B \
(BIT_MASK_RRSR_RSC_8814B << BIT_SHIFT_RRSR_RSC_8814B)
#define BIT_CLEAR_RRSR_RSC_8814B(x) ((x) & (~BITS_RRSR_RSC_8814B))
#define BIT_GET_RRSR_RSC_8814B(x) \
(((x) >> BIT_SHIFT_RRSR_RSC_8814B) & BIT_MASK_RRSR_RSC_8814B)
#define BIT_SET_RRSR_RSC_8814B(x, v) \
(BIT_CLEAR_RRSR_RSC_8814B(x) | BIT_RRSR_RSC_8814B(v))
#define BIT_SHIFT_RRSC_BITMAP_8814B 0
#define BIT_MASK_RRSC_BITMAP_8814B 0xfffff
#define BIT_RRSC_BITMAP_8814B(x) \
(((x) & BIT_MASK_RRSC_BITMAP_8814B) << BIT_SHIFT_RRSC_BITMAP_8814B)
#define BITS_RRSC_BITMAP_8814B \
(BIT_MASK_RRSC_BITMAP_8814B << BIT_SHIFT_RRSC_BITMAP_8814B)
#define BIT_CLEAR_RRSC_BITMAP_8814B(x) ((x) & (~BITS_RRSC_BITMAP_8814B))
#define BIT_GET_RRSC_BITMAP_8814B(x) \
(((x) >> BIT_SHIFT_RRSC_BITMAP_8814B) & BIT_MASK_RRSC_BITMAP_8814B)
#define BIT_SET_RRSC_BITMAP_8814B(x, v) \
(BIT_CLEAR_RRSC_BITMAP_8814B(x) | BIT_RRSC_BITMAP_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ARFR0_8814B */
#define BIT_SHIFT_ARFRL0_8814B 0
#define BIT_MASK_ARFRL0_8814B 0xffffffffL
#define BIT_ARFRL0_8814B(x) \
(((x) & BIT_MASK_ARFRL0_8814B) << BIT_SHIFT_ARFRL0_8814B)
#define BITS_ARFRL0_8814B (BIT_MASK_ARFRL0_8814B << BIT_SHIFT_ARFRL0_8814B)
#define BIT_CLEAR_ARFRL0_8814B(x) ((x) & (~BITS_ARFRL0_8814B))
#define BIT_GET_ARFRL0_8814B(x) \
(((x) >> BIT_SHIFT_ARFRL0_8814B) & BIT_MASK_ARFRL0_8814B)
#define BIT_SET_ARFRL0_8814B(x, v) \
(BIT_CLEAR_ARFRL0_8814B(x) | BIT_ARFRL0_8814B(v))
/* 2 REG_ARFRH0_8814B */
#define BIT_SHIFT_ARFRH0_8814B 0
#define BIT_MASK_ARFRH0_8814B 0xffffffffL
#define BIT_ARFRH0_8814B(x) \
(((x) & BIT_MASK_ARFRH0_8814B) << BIT_SHIFT_ARFRH0_8814B)
#define BITS_ARFRH0_8814B (BIT_MASK_ARFRH0_8814B << BIT_SHIFT_ARFRH0_8814B)
#define BIT_CLEAR_ARFRH0_8814B(x) ((x) & (~BITS_ARFRH0_8814B))
#define BIT_GET_ARFRH0_8814B(x) \
(((x) >> BIT_SHIFT_ARFRH0_8814B) & BIT_MASK_ARFRH0_8814B)
#define BIT_SET_ARFRH0_8814B(x, v) \
(BIT_CLEAR_ARFRH0_8814B(x) | BIT_ARFRH0_8814B(v))
/* 2 REG_REG_ARFR_WT0_8814B */
#define BIT_SHIFT_RATE7_WEIGHTING_8814B 28
#define BIT_MASK_RATE7_WEIGHTING_8814B 0xf
#define BIT_RATE7_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE7_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE7_WEIGHTING_8814B)
#define BITS_RATE7_WEIGHTING_8814B \
(BIT_MASK_RATE7_WEIGHTING_8814B << BIT_SHIFT_RATE7_WEIGHTING_8814B)
#define BIT_CLEAR_RATE7_WEIGHTING_8814B(x) ((x) & (~BITS_RATE7_WEIGHTING_8814B))
#define BIT_GET_RATE7_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE7_WEIGHTING_8814B) & \
BIT_MASK_RATE7_WEIGHTING_8814B)
#define BIT_SET_RATE7_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE7_WEIGHTING_8814B(x) | BIT_RATE7_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE6_WEIGHTING_8814B 24
#define BIT_MASK_RATE6_WEIGHTING_8814B 0xf
#define BIT_RATE6_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE6_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE6_WEIGHTING_8814B)
#define BITS_RATE6_WEIGHTING_8814B \
(BIT_MASK_RATE6_WEIGHTING_8814B << BIT_SHIFT_RATE6_WEIGHTING_8814B)
#define BIT_CLEAR_RATE6_WEIGHTING_8814B(x) ((x) & (~BITS_RATE6_WEIGHTING_8814B))
#define BIT_GET_RATE6_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE6_WEIGHTING_8814B) & \
BIT_MASK_RATE6_WEIGHTING_8814B)
#define BIT_SET_RATE6_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE6_WEIGHTING_8814B(x) | BIT_RATE6_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE5_WEIGHTING_8814B 20
#define BIT_MASK_RATE5_WEIGHTING_8814B 0xf
#define BIT_RATE5_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE5_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE5_WEIGHTING_8814B)
#define BITS_RATE5_WEIGHTING_8814B \
(BIT_MASK_RATE5_WEIGHTING_8814B << BIT_SHIFT_RATE5_WEIGHTING_8814B)
#define BIT_CLEAR_RATE5_WEIGHTING_8814B(x) ((x) & (~BITS_RATE5_WEIGHTING_8814B))
#define BIT_GET_RATE5_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE5_WEIGHTING_8814B) & \
BIT_MASK_RATE5_WEIGHTING_8814B)
#define BIT_SET_RATE5_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE5_WEIGHTING_8814B(x) | BIT_RATE5_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE4_WEIGHTING_8814B 16
#define BIT_MASK_RATE4_WEIGHTING_8814B 0xf
#define BIT_RATE4_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE4_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE4_WEIGHTING_8814B)
#define BITS_RATE4_WEIGHTING_8814B \
(BIT_MASK_RATE4_WEIGHTING_8814B << BIT_SHIFT_RATE4_WEIGHTING_8814B)
#define BIT_CLEAR_RATE4_WEIGHTING_8814B(x) ((x) & (~BITS_RATE4_WEIGHTING_8814B))
#define BIT_GET_RATE4_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE4_WEIGHTING_8814B) & \
BIT_MASK_RATE4_WEIGHTING_8814B)
#define BIT_SET_RATE4_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE4_WEIGHTING_8814B(x) | BIT_RATE4_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE3_WEIGHTING_8814B 12
#define BIT_MASK_RATE3_WEIGHTING_8814B 0xf
#define BIT_RATE3_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE3_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE3_WEIGHTING_8814B)
#define BITS_RATE3_WEIGHTING_8814B \
(BIT_MASK_RATE3_WEIGHTING_8814B << BIT_SHIFT_RATE3_WEIGHTING_8814B)
#define BIT_CLEAR_RATE3_WEIGHTING_8814B(x) ((x) & (~BITS_RATE3_WEIGHTING_8814B))
#define BIT_GET_RATE3_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE3_WEIGHTING_8814B) & \
BIT_MASK_RATE3_WEIGHTING_8814B)
#define BIT_SET_RATE3_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE3_WEIGHTING_8814B(x) | BIT_RATE3_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE2_WEIGHTING_8814B 8
#define BIT_MASK_RATE2_WEIGHTING_8814B 0xf
#define BIT_RATE2_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE2_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE2_WEIGHTING_8814B)
#define BITS_RATE2_WEIGHTING_8814B \
(BIT_MASK_RATE2_WEIGHTING_8814B << BIT_SHIFT_RATE2_WEIGHTING_8814B)
#define BIT_CLEAR_RATE2_WEIGHTING_8814B(x) ((x) & (~BITS_RATE2_WEIGHTING_8814B))
#define BIT_GET_RATE2_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE2_WEIGHTING_8814B) & \
BIT_MASK_RATE2_WEIGHTING_8814B)
#define BIT_SET_RATE2_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE2_WEIGHTING_8814B(x) | BIT_RATE2_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE1_WEIGHTING_8814B 4
#define BIT_MASK_RATE1_WEIGHTING_8814B 0xf
#define BIT_RATE1_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE1_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE1_WEIGHTING_8814B)
#define BITS_RATE1_WEIGHTING_8814B \
(BIT_MASK_RATE1_WEIGHTING_8814B << BIT_SHIFT_RATE1_WEIGHTING_8814B)
#define BIT_CLEAR_RATE1_WEIGHTING_8814B(x) ((x) & (~BITS_RATE1_WEIGHTING_8814B))
#define BIT_GET_RATE1_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE1_WEIGHTING_8814B) & \
BIT_MASK_RATE1_WEIGHTING_8814B)
#define BIT_SET_RATE1_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE1_WEIGHTING_8814B(x) | BIT_RATE1_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE0_WEIGHTING_8814B 0
#define BIT_MASK_RATE0_WEIGHTING_8814B 0xf
#define BIT_RATE0_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE0_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE0_WEIGHTING_8814B)
#define BITS_RATE0_WEIGHTING_8814B \
(BIT_MASK_RATE0_WEIGHTING_8814B << BIT_SHIFT_RATE0_WEIGHTING_8814B)
#define BIT_CLEAR_RATE0_WEIGHTING_8814B(x) ((x) & (~BITS_RATE0_WEIGHTING_8814B))
#define BIT_GET_RATE0_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE0_WEIGHTING_8814B) & \
BIT_MASK_RATE0_WEIGHTING_8814B)
#define BIT_SET_RATE0_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE0_WEIGHTING_8814B(x) | BIT_RATE0_WEIGHTING_8814B(v))
/* 2 REG_REG_ARFR_WT1_8814B */
#define BIT_SHIFT_RATE15_WEIGHTING_8814B 28
#define BIT_MASK_RATE15_WEIGHTING_8814B 0xf
#define BIT_RATE15_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE15_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE15_WEIGHTING_8814B)
#define BITS_RATE15_WEIGHTING_8814B \
(BIT_MASK_RATE15_WEIGHTING_8814B << BIT_SHIFT_RATE15_WEIGHTING_8814B)
#define BIT_CLEAR_RATE15_WEIGHTING_8814B(x) \
((x) & (~BITS_RATE15_WEIGHTING_8814B))
#define BIT_GET_RATE15_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE15_WEIGHTING_8814B) & \
BIT_MASK_RATE15_WEIGHTING_8814B)
#define BIT_SET_RATE15_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE15_WEIGHTING_8814B(x) | BIT_RATE15_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE14_WEIGHTING_8814B 24
#define BIT_MASK_RATE14_WEIGHTING_8814B 0xf
#define BIT_RATE14_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE14_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE14_WEIGHTING_8814B)
#define BITS_RATE14_WEIGHTING_8814B \
(BIT_MASK_RATE14_WEIGHTING_8814B << BIT_SHIFT_RATE14_WEIGHTING_8814B)
#define BIT_CLEAR_RATE14_WEIGHTING_8814B(x) \
((x) & (~BITS_RATE14_WEIGHTING_8814B))
#define BIT_GET_RATE14_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE14_WEIGHTING_8814B) & \
BIT_MASK_RATE14_WEIGHTING_8814B)
#define BIT_SET_RATE14_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE14_WEIGHTING_8814B(x) | BIT_RATE14_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE13_WEIGHTING_8814B 20
#define BIT_MASK_RATE13_WEIGHTING_8814B 0xf
#define BIT_RATE13_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE13_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE13_WEIGHTING_8814B)
#define BITS_RATE13_WEIGHTING_8814B \
(BIT_MASK_RATE13_WEIGHTING_8814B << BIT_SHIFT_RATE13_WEIGHTING_8814B)
#define BIT_CLEAR_RATE13_WEIGHTING_8814B(x) \
((x) & (~BITS_RATE13_WEIGHTING_8814B))
#define BIT_GET_RATE13_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE13_WEIGHTING_8814B) & \
BIT_MASK_RATE13_WEIGHTING_8814B)
#define BIT_SET_RATE13_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE13_WEIGHTING_8814B(x) | BIT_RATE13_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE12_WEIGHTING_8814B 16
#define BIT_MASK_RATE12_WEIGHTING_8814B 0xf
#define BIT_RATE12_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE12_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE12_WEIGHTING_8814B)
#define BITS_RATE12_WEIGHTING_8814B \
(BIT_MASK_RATE12_WEIGHTING_8814B << BIT_SHIFT_RATE12_WEIGHTING_8814B)
#define BIT_CLEAR_RATE12_WEIGHTING_8814B(x) \
((x) & (~BITS_RATE12_WEIGHTING_8814B))
#define BIT_GET_RATE12_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE12_WEIGHTING_8814B) & \
BIT_MASK_RATE12_WEIGHTING_8814B)
#define BIT_SET_RATE12_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE12_WEIGHTING_8814B(x) | BIT_RATE12_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE11_WEIGHTING_8814B 12
#define BIT_MASK_RATE11_WEIGHTING_8814B 0xf
#define BIT_RATE11_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE11_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE11_WEIGHTING_8814B)
#define BITS_RATE11_WEIGHTING_8814B \
(BIT_MASK_RATE11_WEIGHTING_8814B << BIT_SHIFT_RATE11_WEIGHTING_8814B)
#define BIT_CLEAR_RATE11_WEIGHTING_8814B(x) \
((x) & (~BITS_RATE11_WEIGHTING_8814B))
#define BIT_GET_RATE11_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE11_WEIGHTING_8814B) & \
BIT_MASK_RATE11_WEIGHTING_8814B)
#define BIT_SET_RATE11_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE11_WEIGHTING_8814B(x) | BIT_RATE11_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE10_WEIGHTING_8814B 8
#define BIT_MASK_RATE10_WEIGHTING_8814B 0xf
#define BIT_RATE10_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE10_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE10_WEIGHTING_8814B)
#define BITS_RATE10_WEIGHTING_8814B \
(BIT_MASK_RATE10_WEIGHTING_8814B << BIT_SHIFT_RATE10_WEIGHTING_8814B)
#define BIT_CLEAR_RATE10_WEIGHTING_8814B(x) \
((x) & (~BITS_RATE10_WEIGHTING_8814B))
#define BIT_GET_RATE10_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE10_WEIGHTING_8814B) & \
BIT_MASK_RATE10_WEIGHTING_8814B)
#define BIT_SET_RATE10_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE10_WEIGHTING_8814B(x) | BIT_RATE10_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE9_WEIGHTING_8814B 4
#define BIT_MASK_RATE9_WEIGHTING_8814B 0xf
#define BIT_RATE9_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE9_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE9_WEIGHTING_8814B)
#define BITS_RATE9_WEIGHTING_8814B \
(BIT_MASK_RATE9_WEIGHTING_8814B << BIT_SHIFT_RATE9_WEIGHTING_8814B)
#define BIT_CLEAR_RATE9_WEIGHTING_8814B(x) ((x) & (~BITS_RATE9_WEIGHTING_8814B))
#define BIT_GET_RATE9_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE9_WEIGHTING_8814B) & \
BIT_MASK_RATE9_WEIGHTING_8814B)
#define BIT_SET_RATE9_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE9_WEIGHTING_8814B(x) | BIT_RATE9_WEIGHTING_8814B(v))
#define BIT_SHIFT_RATE8_WEIGHTING_8814B 0
#define BIT_MASK_RATE8_WEIGHTING_8814B 0xf
#define BIT_RATE8_WEIGHTING_8814B(x) \
(((x) & BIT_MASK_RATE8_WEIGHTING_8814B) \
<< BIT_SHIFT_RATE8_WEIGHTING_8814B)
#define BITS_RATE8_WEIGHTING_8814B \
(BIT_MASK_RATE8_WEIGHTING_8814B << BIT_SHIFT_RATE8_WEIGHTING_8814B)
#define BIT_CLEAR_RATE8_WEIGHTING_8814B(x) ((x) & (~BITS_RATE8_WEIGHTING_8814B))
#define BIT_GET_RATE8_WEIGHTING_8814B(x) \
(((x) >> BIT_SHIFT_RATE8_WEIGHTING_8814B) & \
BIT_MASK_RATE8_WEIGHTING_8814B)
#define BIT_SET_RATE8_WEIGHTING_8814B(x, v) \
(BIT_CLEAR_RATE8_WEIGHTING_8814B(x) | BIT_RATE8_WEIGHTING_8814B(v))
/* 2 REG_CCK_CHECK_8814B */
#define BIT_CHECK_CCK_EN_8814B BIT(7)
#define BIT_EN_BCN_PKT_REL_P0_8814B BIT(6)
#define BIT_BCN_PORT_SEL_8814B BIT(5)
#define BIT_MOREDATA_BYPASS_8814B BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P0_8814B BIT(3)
#define BIT_EN_SET_MOREDATA_8814B BIT(2)
#define BIT__R_DIS_CLEAR_MACID_RELEASE_8814B BIT(1)
#define BIT__R_MACID_RELEASE_EN_8814B BIT(0)
/* 2 REG_AMPDU_MAX_TIME_V1_8814B */
#define BIT_SHIFT_AMPDU_MAX_TIME_8814B 0
#define BIT_MASK_AMPDU_MAX_TIME_8814B 0xff
#define BIT_AMPDU_MAX_TIME_8814B(x) \
(((x) & BIT_MASK_AMPDU_MAX_TIME_8814B) \
<< BIT_SHIFT_AMPDU_MAX_TIME_8814B)
#define BITS_AMPDU_MAX_TIME_8814B \
(BIT_MASK_AMPDU_MAX_TIME_8814B << BIT_SHIFT_AMPDU_MAX_TIME_8814B)
#define BIT_CLEAR_AMPDU_MAX_TIME_8814B(x) ((x) & (~BITS_AMPDU_MAX_TIME_8814B))
#define BIT_GET_AMPDU_MAX_TIME_8814B(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_TIME_8814B) & \
BIT_MASK_AMPDU_MAX_TIME_8814B)
#define BIT_SET_AMPDU_MAX_TIME_8814B(x, v) \
(BIT_CLEAR_AMPDU_MAX_TIME_8814B(x) | BIT_AMPDU_MAX_TIME_8814B(v))
/* 2 REG_TAB_SEL_8814B */
#define BIT_SHIFT_RATE_SEL_8814B 0
#define BIT_MASK_RATE_SEL_8814B 0xf
#define BIT_RATE_SEL_8814B(x) \
(((x) & BIT_MASK_RATE_SEL_8814B) << BIT_SHIFT_RATE_SEL_8814B)
#define BITS_RATE_SEL_8814B \
(BIT_MASK_RATE_SEL_8814B << BIT_SHIFT_RATE_SEL_8814B)
#define BIT_CLEAR_RATE_SEL_8814B(x) ((x) & (~BITS_RATE_SEL_8814B))
#define BIT_GET_RATE_SEL_8814B(x) \
(((x) >> BIT_SHIFT_RATE_SEL_8814B) & BIT_MASK_RATE_SEL_8814B)
#define BIT_SET_RATE_SEL_8814B(x, v) \
(BIT_CLEAR_RATE_SEL_8814B(x) | BIT_RATE_SEL_8814B(v))
/* 2 REG_BCN_INVALID_CTRL_8814B */
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P4_8814B BIT(7)
#define BIT_EN_BCN_PKT_REL_P4_8814B BIT(6)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P3_8814B BIT(5)
#define BIT_EN_BCN_PKT_REL_P3_8814B BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P2_8814B BIT(3)
#define BIT_EN_BCN_PKT_REL_P2_8814B BIT(2)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_P1_8814B BIT(1)
#define BIT_EN_BCN_PKT_REL_P1_8814B BIT(0)
/* 2 REG_AMPDU_MAX_LENGTH_HT_8814B */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8814B 0
#define BIT_MASK_AMPDU_MAX_LENGTH_HT_8814B 0xffff
#define BIT_AMPDU_MAX_LENGTH_HT_8814B(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_HT_8814B) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8814B)
#define BITS_AMPDU_MAX_LENGTH_HT_8814B \
(BIT_MASK_AMPDU_MAX_LENGTH_HT_8814B \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8814B)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_HT_8814B(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_HT_8814B))
#define BIT_GET_AMPDU_MAX_LENGTH_HT_8814B(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8814B) & \
BIT_MASK_AMPDU_MAX_LENGTH_HT_8814B)
#define BIT_SET_AMPDU_MAX_LENGTH_HT_8814B(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_HT_8814B(x) | \
BIT_AMPDU_MAX_LENGTH_HT_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NDPA_RATE_8814B */
#define BIT_SHIFT_R_NDPA_RATE_V1_8814B 0
#define BIT_MASK_R_NDPA_RATE_V1_8814B 0xff
#define BIT_R_NDPA_RATE_V1_8814B(x) \
(((x) & BIT_MASK_R_NDPA_RATE_V1_8814B) \
<< BIT_SHIFT_R_NDPA_RATE_V1_8814B)
#define BITS_R_NDPA_RATE_V1_8814B \
(BIT_MASK_R_NDPA_RATE_V1_8814B << BIT_SHIFT_R_NDPA_RATE_V1_8814B)
#define BIT_CLEAR_R_NDPA_RATE_V1_8814B(x) ((x) & (~BITS_R_NDPA_RATE_V1_8814B))
#define BIT_GET_R_NDPA_RATE_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE_V1_8814B) & \
BIT_MASK_R_NDPA_RATE_V1_8814B)
#define BIT_SET_R_NDPA_RATE_V1_8814B(x, v) \
(BIT_CLEAR_R_NDPA_RATE_V1_8814B(x) | BIT_R_NDPA_RATE_V1_8814B(v))
/* 2 REG_TX_HANG_CTRL_8814B */
#define BIT_EN_GNT_BT_AWAKE_8814B BIT(3)
#define BIT_EN_EOF_V1_8814B BIT(2)
#define BIT_DIS_OQT_BLOCK_8814B BIT(1)
#define BIT_SEARCH_QUEUE_EN_8814B BIT(0)
/* 2 REG_NDPA_OPT_CTRL_8814B */
#define BIT_DIS_MACID_RELEASE_RTY_8814B BIT(5)
#define BIT_SHIFT_BW_SIGTA_8814B 3
#define BIT_MASK_BW_SIGTA_8814B 0x3
#define BIT_BW_SIGTA_8814B(x) \
(((x) & BIT_MASK_BW_SIGTA_8814B) << BIT_SHIFT_BW_SIGTA_8814B)
#define BITS_BW_SIGTA_8814B \
(BIT_MASK_BW_SIGTA_8814B << BIT_SHIFT_BW_SIGTA_8814B)
#define BIT_CLEAR_BW_SIGTA_8814B(x) ((x) & (~BITS_BW_SIGTA_8814B))
#define BIT_GET_BW_SIGTA_8814B(x) \
(((x) >> BIT_SHIFT_BW_SIGTA_8814B) & BIT_MASK_BW_SIGTA_8814B)
#define BIT_SET_BW_SIGTA_8814B(x, v) \
(BIT_CLEAR_BW_SIGTA_8814B(x) | BIT_BW_SIGTA_8814B(v))
#define BIT_EN_BAR_SIGTA_8814B BIT(2)
#define BIT_SHIFT_NDPA_BW_8814B 0
#define BIT_MASK_NDPA_BW_8814B 0x3
#define BIT_NDPA_BW_8814B(x) \
(((x) & BIT_MASK_NDPA_BW_8814B) << BIT_SHIFT_NDPA_BW_8814B)
#define BITS_NDPA_BW_8814B (BIT_MASK_NDPA_BW_8814B << BIT_SHIFT_NDPA_BW_8814B)
#define BIT_CLEAR_NDPA_BW_8814B(x) ((x) & (~BITS_NDPA_BW_8814B))
#define BIT_GET_NDPA_BW_8814B(x) \
(((x) >> BIT_SHIFT_NDPA_BW_8814B) & BIT_MASK_NDPA_BW_8814B)
#define BIT_SET_NDPA_BW_8814B(x, v) \
(BIT_CLEAR_NDPA_BW_8814B(x) | BIT_NDPA_BW_8814B(v))
/* 2 REG_AMPDU_MAX_LENGTH_VHT_8814B */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_8814B 0
#define BIT_MASK_AMPDU_MAX_LENGTH_VHT_8814B 0x3ffff
#define BIT_AMPDU_MAX_LENGTH_VHT_8814B(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_VHT_8814B) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_8814B)
#define BITS_AMPDU_MAX_LENGTH_VHT_8814B \
(BIT_MASK_AMPDU_MAX_LENGTH_VHT_8814B \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_8814B)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_VHT_8814B(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_VHT_8814B))
#define BIT_GET_AMPDU_MAX_LENGTH_VHT_8814B(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_8814B) & \
BIT_MASK_AMPDU_MAX_LENGTH_VHT_8814B)
#define BIT_SET_AMPDU_MAX_LENGTH_VHT_8814B(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_VHT_8814B(x) | \
BIT_AMPDU_MAX_LENGTH_VHT_8814B(v))
/* 2 REG_RD_RESP_PKT_TH_8814B */
#define BIT_SHIFT_RD_RESP_PKT_TH_V1_8814B 0
#define BIT_MASK_RD_RESP_PKT_TH_V1_8814B 0x3f
#define BIT_RD_RESP_PKT_TH_V1_8814B(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH_V1_8814B) \
<< BIT_SHIFT_RD_RESP_PKT_TH_V1_8814B)
#define BITS_RD_RESP_PKT_TH_V1_8814B \
(BIT_MASK_RD_RESP_PKT_TH_V1_8814B << BIT_SHIFT_RD_RESP_PKT_TH_V1_8814B)
#define BIT_CLEAR_RD_RESP_PKT_TH_V1_8814B(x) \
((x) & (~BITS_RD_RESP_PKT_TH_V1_8814B))
#define BIT_GET_RD_RESP_PKT_TH_V1_8814B(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH_V1_8814B) & \
BIT_MASK_RD_RESP_PKT_TH_V1_8814B)
#define BIT_SET_RD_RESP_PKT_TH_V1_8814B(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH_V1_8814B(x) | BIT_RD_RESP_PKT_TH_V1_8814B(v))
/* 2 REG_NEW_EDCA_CTRL_V1_8814B */
#define BIT_SHIFT_RANDOM_VALUE_SHIFT_8814B 9
#define BIT_MASK_RANDOM_VALUE_SHIFT_8814B 0x7
#define BIT_RANDOM_VALUE_SHIFT_8814B(x) \
(((x) & BIT_MASK_RANDOM_VALUE_SHIFT_8814B) \
<< BIT_SHIFT_RANDOM_VALUE_SHIFT_8814B)
#define BITS_RANDOM_VALUE_SHIFT_8814B \
(BIT_MASK_RANDOM_VALUE_SHIFT_8814B \
<< BIT_SHIFT_RANDOM_VALUE_SHIFT_8814B)
#define BIT_CLEAR_RANDOM_VALUE_SHIFT_8814B(x) \
((x) & (~BITS_RANDOM_VALUE_SHIFT_8814B))
#define BIT_GET_RANDOM_VALUE_SHIFT_8814B(x) \
(((x) >> BIT_SHIFT_RANDOM_VALUE_SHIFT_8814B) & \
BIT_MASK_RANDOM_VALUE_SHIFT_8814B)
#define BIT_SET_RANDOM_VALUE_SHIFT_8814B(x, v) \
(BIT_CLEAR_RANDOM_VALUE_SHIFT_8814B(x) | \
BIT_RANDOM_VALUE_SHIFT_8814B(v))
#define BIT_ENABLE_NEW_EDCA_8814B BIT(8)
#define BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER_8814B 0
#define BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER_8814B 0xff
#define BIT_MEDIUM_HAS_IDKE_TRIGGER_8814B(x) \
(((x) & BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER_8814B) \
<< BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER_8814B)
#define BITS_MEDIUM_HAS_IDKE_TRIGGER_8814B \
(BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER_8814B \
<< BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER_8814B)
#define BIT_CLEAR_MEDIUM_HAS_IDKE_TRIGGER_8814B(x) \
((x) & (~BITS_MEDIUM_HAS_IDKE_TRIGGER_8814B))
#define BIT_GET_MEDIUM_HAS_IDKE_TRIGGER_8814B(x) \
(((x) >> BIT_SHIFT_MEDIUM_HAS_IDKE_TRIGGER_8814B) & \
BIT_MASK_MEDIUM_HAS_IDKE_TRIGGER_8814B)
#define BIT_SET_MEDIUM_HAS_IDKE_TRIGGER_8814B(x, v) \
(BIT_CLEAR_MEDIUM_HAS_IDKE_TRIGGER_8814B(x) | \
BIT_MEDIUM_HAS_IDKE_TRIGGER_8814B(v))
/* 2 REG_ACQ_STOP_V2_8814B */
#define BIT_AC19Q_STOP_8814B BIT(19)
#define BIT_AC18Q_STOP_8814B BIT(18)
#define BIT_AC17Q_STOP_8814B BIT(17)
#define BIT_AC16Q_STOP_8814B BIT(16)
#define BIT_AC15Q_STOP_8814B BIT(15)
#define BIT_AC14Q_STOP_8814B BIT(14)
#define BIT_AC13Q_STOP_8814B BIT(13)
#define BIT_AC12Q_STOP_8814B BIT(12)
#define BIT_AC11Q_STOP_8814B BIT(11)
#define BIT_AC10Q_STOP_8814B BIT(10)
#define BIT_AC9Q_STOP_8814B BIT(9)
#define BIT_AC8Q_STOP_8814B BIT(8)
#define BIT_AC7Q_STOP_8814B BIT(7)
#define BIT_AC6Q_STOP_8814B BIT(6)
#define BIT_AC5Q_STOP_8814B BIT(5)
#define BIT_AC4Q_STOP_8814B BIT(4)
#define BIT_AC3Q_STOP_8814B BIT(3)
#define BIT_AC2Q_STOP_8814B BIT(2)
#define BIT_AC1Q_STOP_8814B BIT(1)
#define BIT_AC0Q_STOP_8814B BIT(0)
/* 2 REG_WMAC_LBK_BUF_HD_V1_8814B */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8814B 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8814B 0xfff
#define BIT_WMAC_LBK_BUF_HEAD_V1_8814B(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8814B) \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8814B)
#define BITS_WMAC_LBK_BUF_HEAD_V1_8814B \
(BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8814B \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8814B)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8814B(x) \
((x) & (~BITS_WMAC_LBK_BUF_HEAD_V1_8814B))
#define BIT_GET_WMAC_LBK_BUF_HEAD_V1_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8814B) & \
BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8814B)
#define BIT_SET_WMAC_LBK_BUF_HEAD_V1_8814B(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8814B(x) | \
BIT_WMAC_LBK_BUF_HEAD_V1_8814B(v))
/* 2 REG_MGQ_BDNY_V1_8814B */
#define BIT_SHIFT_MGQ_PGBNDY_V1_8814B 0
#define BIT_MASK_MGQ_PGBNDY_V1_8814B 0xfff
#define BIT_MGQ_PGBNDY_V1_8814B(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V1_8814B) << BIT_SHIFT_MGQ_PGBNDY_V1_8814B)
#define BITS_MGQ_PGBNDY_V1_8814B \
(BIT_MASK_MGQ_PGBNDY_V1_8814B << BIT_SHIFT_MGQ_PGBNDY_V1_8814B)
#define BIT_CLEAR_MGQ_PGBNDY_V1_8814B(x) ((x) & (~BITS_MGQ_PGBNDY_V1_8814B))
#define BIT_GET_MGQ_PGBNDY_V1_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V1_8814B) & BIT_MASK_MGQ_PGBNDY_V1_8814B)
#define BIT_SET_MGQ_PGBNDY_V1_8814B(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V1_8814B(x) | BIT_MGQ_PGBNDY_V1_8814B(v))
/* 2 REG_TXRPT_CTRL_8814B */
#define BIT_SHIFT_TRXRPT_TIMER_TH_8814B 24
#define BIT_MASK_TRXRPT_TIMER_TH_8814B 0xff
#define BIT_TRXRPT_TIMER_TH_8814B(x) \
(((x) & BIT_MASK_TRXRPT_TIMER_TH_8814B) \
<< BIT_SHIFT_TRXRPT_TIMER_TH_8814B)
#define BITS_TRXRPT_TIMER_TH_8814B \
(BIT_MASK_TRXRPT_TIMER_TH_8814B << BIT_SHIFT_TRXRPT_TIMER_TH_8814B)
#define BIT_CLEAR_TRXRPT_TIMER_TH_8814B(x) ((x) & (~BITS_TRXRPT_TIMER_TH_8814B))
#define BIT_GET_TRXRPT_TIMER_TH_8814B(x) \
(((x) >> BIT_SHIFT_TRXRPT_TIMER_TH_8814B) & \
BIT_MASK_TRXRPT_TIMER_TH_8814B)
#define BIT_SET_TRXRPT_TIMER_TH_8814B(x, v) \
(BIT_CLEAR_TRXRPT_TIMER_TH_8814B(x) | BIT_TRXRPT_TIMER_TH_8814B(v))
#define BIT_SHIFT_TRXRPT_LEN_TH_8814B 16
#define BIT_MASK_TRXRPT_LEN_TH_8814B 0xff
#define BIT_TRXRPT_LEN_TH_8814B(x) \
(((x) & BIT_MASK_TRXRPT_LEN_TH_8814B) << BIT_SHIFT_TRXRPT_LEN_TH_8814B)
#define BITS_TRXRPT_LEN_TH_8814B \
(BIT_MASK_TRXRPT_LEN_TH_8814B << BIT_SHIFT_TRXRPT_LEN_TH_8814B)
#define BIT_CLEAR_TRXRPT_LEN_TH_8814B(x) ((x) & (~BITS_TRXRPT_LEN_TH_8814B))
#define BIT_GET_TRXRPT_LEN_TH_8814B(x) \
(((x) >> BIT_SHIFT_TRXRPT_LEN_TH_8814B) & BIT_MASK_TRXRPT_LEN_TH_8814B)
#define BIT_SET_TRXRPT_LEN_TH_8814B(x, v) \
(BIT_CLEAR_TRXRPT_LEN_TH_8814B(x) | BIT_TRXRPT_LEN_TH_8814B(v))
#define BIT_SHIFT_TRXRPT_READ_PTR_8814B 8
#define BIT_MASK_TRXRPT_READ_PTR_8814B 0xff
#define BIT_TRXRPT_READ_PTR_8814B(x) \
(((x) & BIT_MASK_TRXRPT_READ_PTR_8814B) \
<< BIT_SHIFT_TRXRPT_READ_PTR_8814B)
#define BITS_TRXRPT_READ_PTR_8814B \
(BIT_MASK_TRXRPT_READ_PTR_8814B << BIT_SHIFT_TRXRPT_READ_PTR_8814B)
#define BIT_CLEAR_TRXRPT_READ_PTR_8814B(x) ((x) & (~BITS_TRXRPT_READ_PTR_8814B))
#define BIT_GET_TRXRPT_READ_PTR_8814B(x) \
(((x) >> BIT_SHIFT_TRXRPT_READ_PTR_8814B) & \
BIT_MASK_TRXRPT_READ_PTR_8814B)
#define BIT_SET_TRXRPT_READ_PTR_8814B(x, v) \
(BIT_CLEAR_TRXRPT_READ_PTR_8814B(x) | BIT_TRXRPT_READ_PTR_8814B(v))
#define BIT_SHIFT_TRXRPT_WRITE_PTR_8814B 0
#define BIT_MASK_TRXRPT_WRITE_PTR_8814B 0xff
#define BIT_TRXRPT_WRITE_PTR_8814B(x) \
(((x) & BIT_MASK_TRXRPT_WRITE_PTR_8814B) \
<< BIT_SHIFT_TRXRPT_WRITE_PTR_8814B)
#define BITS_TRXRPT_WRITE_PTR_8814B \
(BIT_MASK_TRXRPT_WRITE_PTR_8814B << BIT_SHIFT_TRXRPT_WRITE_PTR_8814B)
#define BIT_CLEAR_TRXRPT_WRITE_PTR_8814B(x) \
((x) & (~BITS_TRXRPT_WRITE_PTR_8814B))
#define BIT_GET_TRXRPT_WRITE_PTR_8814B(x) \
(((x) >> BIT_SHIFT_TRXRPT_WRITE_PTR_8814B) & \
BIT_MASK_TRXRPT_WRITE_PTR_8814B)
#define BIT_SET_TRXRPT_WRITE_PTR_8814B(x, v) \
(BIT_CLEAR_TRXRPT_WRITE_PTR_8814B(x) | BIT_TRXRPT_WRITE_PTR_8814B(v))
/* 2 REG_INIRTS_RATE_SEL_8814B */
#define BIT_LEAG_RTS_BW_DUP_8814B BIT(5)
/* 2 REG_BASIC_CFEND_RATE_8814B */
#define BIT_SHIFT_BASIC_CFEND_RATE_8814B 0
#define BIT_MASK_BASIC_CFEND_RATE_8814B 0x1f
#define BIT_BASIC_CFEND_RATE_8814B(x) \
(((x) & BIT_MASK_BASIC_CFEND_RATE_8814B) \
<< BIT_SHIFT_BASIC_CFEND_RATE_8814B)
#define BITS_BASIC_CFEND_RATE_8814B \
(BIT_MASK_BASIC_CFEND_RATE_8814B << BIT_SHIFT_BASIC_CFEND_RATE_8814B)
#define BIT_CLEAR_BASIC_CFEND_RATE_8814B(x) \
((x) & (~BITS_BASIC_CFEND_RATE_8814B))
#define BIT_GET_BASIC_CFEND_RATE_8814B(x) \
(((x) >> BIT_SHIFT_BASIC_CFEND_RATE_8814B) & \
BIT_MASK_BASIC_CFEND_RATE_8814B)
#define BIT_SET_BASIC_CFEND_RATE_8814B(x, v) \
(BIT_CLEAR_BASIC_CFEND_RATE_8814B(x) | BIT_BASIC_CFEND_RATE_8814B(v))
/* 2 REG_STBC_CFEND_RATE_8814B */
#define BIT_SHIFT_STBC_CFEND_RATE_8814B 0
#define BIT_MASK_STBC_CFEND_RATE_8814B 0x1f
#define BIT_STBC_CFEND_RATE_8814B(x) \
(((x) & BIT_MASK_STBC_CFEND_RATE_8814B) \
<< BIT_SHIFT_STBC_CFEND_RATE_8814B)
#define BITS_STBC_CFEND_RATE_8814B \
(BIT_MASK_STBC_CFEND_RATE_8814B << BIT_SHIFT_STBC_CFEND_RATE_8814B)
#define BIT_CLEAR_STBC_CFEND_RATE_8814B(x) ((x) & (~BITS_STBC_CFEND_RATE_8814B))
#define BIT_GET_STBC_CFEND_RATE_8814B(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_RATE_8814B) & \
BIT_MASK_STBC_CFEND_RATE_8814B)
#define BIT_SET_STBC_CFEND_RATE_8814B(x, v) \
(BIT_CLEAR_STBC_CFEND_RATE_8814B(x) | BIT_STBC_CFEND_RATE_8814B(v))
/* 2 REG_DATA_SC_8814B */
#define BIT_SHIFT_TXSC_40M_8814B 4
#define BIT_MASK_TXSC_40M_8814B 0xf
#define BIT_TXSC_40M_8814B(x) \
(((x) & BIT_MASK_TXSC_40M_8814B) << BIT_SHIFT_TXSC_40M_8814B)
#define BITS_TXSC_40M_8814B \
(BIT_MASK_TXSC_40M_8814B << BIT_SHIFT_TXSC_40M_8814B)
#define BIT_CLEAR_TXSC_40M_8814B(x) ((x) & (~BITS_TXSC_40M_8814B))
#define BIT_GET_TXSC_40M_8814B(x) \
(((x) >> BIT_SHIFT_TXSC_40M_8814B) & BIT_MASK_TXSC_40M_8814B)
#define BIT_SET_TXSC_40M_8814B(x, v) \
(BIT_CLEAR_TXSC_40M_8814B(x) | BIT_TXSC_40M_8814B(v))
#define BIT_SHIFT_TXSC_20M_8814B 0
#define BIT_MASK_TXSC_20M_8814B 0xf
#define BIT_TXSC_20M_8814B(x) \
(((x) & BIT_MASK_TXSC_20M_8814B) << BIT_SHIFT_TXSC_20M_8814B)
#define BITS_TXSC_20M_8814B \
(BIT_MASK_TXSC_20M_8814B << BIT_SHIFT_TXSC_20M_8814B)
#define BIT_CLEAR_TXSC_20M_8814B(x) ((x) & (~BITS_TXSC_20M_8814B))
#define BIT_GET_TXSC_20M_8814B(x) \
(((x) >> BIT_SHIFT_TXSC_20M_8814B) & BIT_MASK_TXSC_20M_8814B)
#define BIT_SET_TXSC_20M_8814B(x, v) \
(BIT_CLEAR_TXSC_20M_8814B(x) | BIT_TXSC_20M_8814B(v))
/* 2 REG_MOREDATA_V1_8814B */
#define BIT_MOREDATA_CTRL2_EN_V1_8814B BIT(3)
#define BIT_MOREDATA_CTRL1_EN_V1_8814B BIT(2)
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE_V1_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_DATA_SC1_8814B */
#define BIT_SHIFT_TXSC_160M_8814B 4
#define BIT_MASK_TXSC_160M_8814B 0xf
#define BIT_TXSC_160M_8814B(x) \
(((x) & BIT_MASK_TXSC_160M_8814B) << BIT_SHIFT_TXSC_160M_8814B)
#define BITS_TXSC_160M_8814B \
(BIT_MASK_TXSC_160M_8814B << BIT_SHIFT_TXSC_160M_8814B)
#define BIT_CLEAR_TXSC_160M_8814B(x) ((x) & (~BITS_TXSC_160M_8814B))
#define BIT_GET_TXSC_160M_8814B(x) \
(((x) >> BIT_SHIFT_TXSC_160M_8814B) & BIT_MASK_TXSC_160M_8814B)
#define BIT_SET_TXSC_160M_8814B(x, v) \
(BIT_CLEAR_TXSC_160M_8814B(x) | BIT_TXSC_160M_8814B(v))
#define BIT_SHIFT_TXSC_80M_8814B 0
#define BIT_MASK_TXSC_80M_8814B 0xf
#define BIT_TXSC_80M_8814B(x) \
(((x) & BIT_MASK_TXSC_80M_8814B) << BIT_SHIFT_TXSC_80M_8814B)
#define BITS_TXSC_80M_8814B \
(BIT_MASK_TXSC_80M_8814B << BIT_SHIFT_TXSC_80M_8814B)
#define BIT_CLEAR_TXSC_80M_8814B(x) ((x) & (~BITS_TXSC_80M_8814B))
#define BIT_GET_TXSC_80M_8814B(x) \
(((x) >> BIT_SHIFT_TXSC_80M_8814B) & BIT_MASK_TXSC_80M_8814B)
#define BIT_SET_TXSC_80M_8814B(x, v) \
(BIT_CLEAR_TXSC_80M_8814B(x) | BIT_TXSC_80M_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TXRPT_START_OFFSET_8814B */
#define BIT_RPTFIFO_RPTNUM_OPT_8814B BIT(31)
#define BIT_SHIFT_MISSED_RPT_NUM_8814B 28
#define BIT_MASK_MISSED_RPT_NUM_8814B 0x7
#define BIT_MISSED_RPT_NUM_8814B(x) \
(((x) & BIT_MASK_MISSED_RPT_NUM_8814B) \
<< BIT_SHIFT_MISSED_RPT_NUM_8814B)
#define BITS_MISSED_RPT_NUM_8814B \
(BIT_MASK_MISSED_RPT_NUM_8814B << BIT_SHIFT_MISSED_RPT_NUM_8814B)
#define BIT_CLEAR_MISSED_RPT_NUM_8814B(x) ((x) & (~BITS_MISSED_RPT_NUM_8814B))
#define BIT_GET_MISSED_RPT_NUM_8814B(x) \
(((x) >> BIT_SHIFT_MISSED_RPT_NUM_8814B) & \
BIT_MASK_MISSED_RPT_NUM_8814B)
#define BIT_SET_MISSED_RPT_NUM_8814B(x, v) \
(BIT_CLEAR_MISSED_RPT_NUM_8814B(x) | BIT_MISSED_RPT_NUM_8814B(v))
#define BIT_SHIFT_MACID_CTRL_OFFSET_V1_8814B 16
#define BIT_MASK_MACID_CTRL_OFFSET_V1_8814B 0x1ff
#define BIT_MACID_CTRL_OFFSET_V1_8814B(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET_V1_8814B) \
<< BIT_SHIFT_MACID_CTRL_OFFSET_V1_8814B)
#define BITS_MACID_CTRL_OFFSET_V1_8814B \
(BIT_MASK_MACID_CTRL_OFFSET_V1_8814B \
<< BIT_SHIFT_MACID_CTRL_OFFSET_V1_8814B)
#define BIT_CLEAR_MACID_CTRL_OFFSET_V1_8814B(x) \
((x) & (~BITS_MACID_CTRL_OFFSET_V1_8814B))
#define BIT_GET_MACID_CTRL_OFFSET_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET_V1_8814B) & \
BIT_MASK_MACID_CTRL_OFFSET_V1_8814B)
#define BIT_SET_MACID_CTRL_OFFSET_V1_8814B(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET_V1_8814B(x) | \
BIT_MACID_CTRL_OFFSET_V1_8814B(v))
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1_8814B 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET_V1_8814B 0x1ff
#define BIT_AMPDU_TXRPT_OFFSET_V1_8814B(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET_V1_8814B) \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1_8814B)
#define BITS_AMPDU_TXRPT_OFFSET_V1_8814B \
(BIT_MASK_AMPDU_TXRPT_OFFSET_V1_8814B \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1_8814B)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET_V1_8814B(x) \
((x) & (~BITS_AMPDU_TXRPT_OFFSET_V1_8814B))
#define BIT_GET_AMPDU_TXRPT_OFFSET_V1_8814B(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET_V1_8814B) & \
BIT_MASK_AMPDU_TXRPT_OFFSET_V1_8814B)
#define BIT_SET_AMPDU_TXRPT_OFFSET_V1_8814B(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET_V1_8814B(x) | \
BIT_AMPDU_TXRPT_OFFSET_V1_8814B(v))
/* 2 REG_POWER_STAGE1_8814B */
#define BIT_PTA_WL_PRI_MASK_CPU_MGQ_8814B BIT(31)
#define BIT_PTA_WL_PRI_MASK_BCNQ_8814B BIT(30)
#define BIT_PTA_WL_PRI_MASK_HIQ_8814B BIT(29)
#define BIT_PTA_WL_PRI_MASK_MGQ_8814B BIT(28)
#define BIT_PTA_WL_PRI_MASK_BK_8814B BIT(27)
#define BIT_PTA_WL_PRI_MASK_BE_8814B BIT(26)
#define BIT_PTA_WL_PRI_MASK_VI_8814B BIT(25)
#define BIT_PTA_WL_PRI_MASK_VO_8814B BIT(24)
#define BIT_SHIFT_POWER_STAGE1_8814B 0
#define BIT_MASK_POWER_STAGE1_8814B 0xffffff
#define BIT_POWER_STAGE1_8814B(x) \
(((x) & BIT_MASK_POWER_STAGE1_8814B) << BIT_SHIFT_POWER_STAGE1_8814B)
#define BITS_POWER_STAGE1_8814B \
(BIT_MASK_POWER_STAGE1_8814B << BIT_SHIFT_POWER_STAGE1_8814B)
#define BIT_CLEAR_POWER_STAGE1_8814B(x) ((x) & (~BITS_POWER_STAGE1_8814B))
#define BIT_GET_POWER_STAGE1_8814B(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1_8814B) & BIT_MASK_POWER_STAGE1_8814B)
#define BIT_SET_POWER_STAGE1_8814B(x, v) \
(BIT_CLEAR_POWER_STAGE1_8814B(x) | BIT_POWER_STAGE1_8814B(v))
/* 2 REG_POWER_STAGE2_8814B */
#define BIT__CTRL_PKT_POW_ADJ_8814B BIT(24)
#define BIT_SHIFT_POWER_STAGE2_8814B 0
#define BIT_MASK_POWER_STAGE2_8814B 0xffffff
#define BIT_POWER_STAGE2_8814B(x) \
(((x) & BIT_MASK_POWER_STAGE2_8814B) << BIT_SHIFT_POWER_STAGE2_8814B)
#define BITS_POWER_STAGE2_8814B \
(BIT_MASK_POWER_STAGE2_8814B << BIT_SHIFT_POWER_STAGE2_8814B)
#define BIT_CLEAR_POWER_STAGE2_8814B(x) ((x) & (~BITS_POWER_STAGE2_8814B))
#define BIT_GET_POWER_STAGE2_8814B(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2_8814B) & BIT_MASK_POWER_STAGE2_8814B)
#define BIT_SET_POWER_STAGE2_8814B(x, v) \
(BIT_CLEAR_POWER_STAGE2_8814B(x) | BIT_POWER_STAGE2_8814B(v))
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL_8814B */
#define BIT_DMA_THIS_QUEUE_BK_8814B BIT(23)
#define BIT_DMA_THIS_QUEUE_BE_8814B BIT(22)
#define BIT_DMA_THIS_QUEUE_VI_8814B BIT(21)
#define BIT_DMA_THIS_QUEUE_VO_8814B BIT(20)
#define BIT_SHIFT_TOTAL_LEN_TH_8814B 8
#define BIT_MASK_TOTAL_LEN_TH_8814B 0xfff
#define BIT_TOTAL_LEN_TH_8814B(x) \
(((x) & BIT_MASK_TOTAL_LEN_TH_8814B) << BIT_SHIFT_TOTAL_LEN_TH_8814B)
#define BITS_TOTAL_LEN_TH_8814B \
(BIT_MASK_TOTAL_LEN_TH_8814B << BIT_SHIFT_TOTAL_LEN_TH_8814B)
#define BIT_CLEAR_TOTAL_LEN_TH_8814B(x) ((x) & (~BITS_TOTAL_LEN_TH_8814B))
#define BIT_GET_TOTAL_LEN_TH_8814B(x) \
(((x) >> BIT_SHIFT_TOTAL_LEN_TH_8814B) & BIT_MASK_TOTAL_LEN_TH_8814B)
#define BIT_SET_TOTAL_LEN_TH_8814B(x, v) \
(BIT_CLEAR_TOTAL_LEN_TH_8814B(x) | BIT_TOTAL_LEN_TH_8814B(v))
#define BIT_PRE_TX_CMD_8814B BIT(6)
#define BIT_SHIFT_NUM_SCL_EN_8814B 4
#define BIT_MASK_NUM_SCL_EN_8814B 0x3
#define BIT_NUM_SCL_EN_8814B(x) \
(((x) & BIT_MASK_NUM_SCL_EN_8814B) << BIT_SHIFT_NUM_SCL_EN_8814B)
#define BITS_NUM_SCL_EN_8814B \
(BIT_MASK_NUM_SCL_EN_8814B << BIT_SHIFT_NUM_SCL_EN_8814B)
#define BIT_CLEAR_NUM_SCL_EN_8814B(x) ((x) & (~BITS_NUM_SCL_EN_8814B))
#define BIT_GET_NUM_SCL_EN_8814B(x) \
(((x) >> BIT_SHIFT_NUM_SCL_EN_8814B) & BIT_MASK_NUM_SCL_EN_8814B)
#define BIT_SET_NUM_SCL_EN_8814B(x, v) \
(BIT_CLEAR_NUM_SCL_EN_8814B(x) | BIT_NUM_SCL_EN_8814B(v))
#define BIT_BK_EN_8814B BIT(3)
#define BIT_BE_EN_8814B BIT(2)
#define BIT_VI_EN_8814B BIT(1)
#define BIT_VO_EN_8814B BIT(0)
/* 2 REG_PKT_LIFE_TIME_8814B */
#define BIT_SHIFT_PKT_LIFTIME_BEBK_8814B 16
#define BIT_MASK_PKT_LIFTIME_BEBK_8814B 0xffff
#define BIT_PKT_LIFTIME_BEBK_8814B(x) \
(((x) & BIT_MASK_PKT_LIFTIME_BEBK_8814B) \
<< BIT_SHIFT_PKT_LIFTIME_BEBK_8814B)
#define BITS_PKT_LIFTIME_BEBK_8814B \
(BIT_MASK_PKT_LIFTIME_BEBK_8814B << BIT_SHIFT_PKT_LIFTIME_BEBK_8814B)
#define BIT_CLEAR_PKT_LIFTIME_BEBK_8814B(x) \
((x) & (~BITS_PKT_LIFTIME_BEBK_8814B))
#define BIT_GET_PKT_LIFTIME_BEBK_8814B(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_BEBK_8814B) & \
BIT_MASK_PKT_LIFTIME_BEBK_8814B)
#define BIT_SET_PKT_LIFTIME_BEBK_8814B(x, v) \
(BIT_CLEAR_PKT_LIFTIME_BEBK_8814B(x) | BIT_PKT_LIFTIME_BEBK_8814B(v))
#define BIT_SHIFT_PKT_LIFTIME_VOVI_8814B 0
#define BIT_MASK_PKT_LIFTIME_VOVI_8814B 0xffff
#define BIT_PKT_LIFTIME_VOVI_8814B(x) \
(((x) & BIT_MASK_PKT_LIFTIME_VOVI_8814B) \
<< BIT_SHIFT_PKT_LIFTIME_VOVI_8814B)
#define BITS_PKT_LIFTIME_VOVI_8814B \
(BIT_MASK_PKT_LIFTIME_VOVI_8814B << BIT_SHIFT_PKT_LIFTIME_VOVI_8814B)
#define BIT_CLEAR_PKT_LIFTIME_VOVI_8814B(x) \
((x) & (~BITS_PKT_LIFTIME_VOVI_8814B))
#define BIT_GET_PKT_LIFTIME_VOVI_8814B(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_VOVI_8814B) & \
BIT_MASK_PKT_LIFTIME_VOVI_8814B)
#define BIT_SET_PKT_LIFTIME_VOVI_8814B(x, v) \
(BIT_CLEAR_PKT_LIFTIME_VOVI_8814B(x) | BIT_PKT_LIFTIME_VOVI_8814B(v))
/* 2 REG_STBC_SETTING_8814B */
#define BIT_SHIFT_CDEND_TXTIME_L_8814B 4
#define BIT_MASK_CDEND_TXTIME_L_8814B 0xf
#define BIT_CDEND_TXTIME_L_8814B(x) \
(((x) & BIT_MASK_CDEND_TXTIME_L_8814B) \
<< BIT_SHIFT_CDEND_TXTIME_L_8814B)
#define BITS_CDEND_TXTIME_L_8814B \
(BIT_MASK_CDEND_TXTIME_L_8814B << BIT_SHIFT_CDEND_TXTIME_L_8814B)
#define BIT_CLEAR_CDEND_TXTIME_L_8814B(x) ((x) & (~BITS_CDEND_TXTIME_L_8814B))
#define BIT_GET_CDEND_TXTIME_L_8814B(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_L_8814B) & \
BIT_MASK_CDEND_TXTIME_L_8814B)
#define BIT_SET_CDEND_TXTIME_L_8814B(x, v) \
(BIT_CLEAR_CDEND_TXTIME_L_8814B(x) | BIT_CDEND_TXTIME_L_8814B(v))
#define BIT_SHIFT_NESS_8814B 2
#define BIT_MASK_NESS_8814B 0x3
#define BIT_NESS_8814B(x) (((x) & BIT_MASK_NESS_8814B) << BIT_SHIFT_NESS_8814B)
#define BITS_NESS_8814B (BIT_MASK_NESS_8814B << BIT_SHIFT_NESS_8814B)
#define BIT_CLEAR_NESS_8814B(x) ((x) & (~BITS_NESS_8814B))
#define BIT_GET_NESS_8814B(x) \
(((x) >> BIT_SHIFT_NESS_8814B) & BIT_MASK_NESS_8814B)
#define BIT_SET_NESS_8814B(x, v) (BIT_CLEAR_NESS_8814B(x) | BIT_NESS_8814B(v))
#define BIT_SHIFT_STBC_CFEND_8814B 0
#define BIT_MASK_STBC_CFEND_8814B 0x3
#define BIT_STBC_CFEND_8814B(x) \
(((x) & BIT_MASK_STBC_CFEND_8814B) << BIT_SHIFT_STBC_CFEND_8814B)
#define BITS_STBC_CFEND_8814B \
(BIT_MASK_STBC_CFEND_8814B << BIT_SHIFT_STBC_CFEND_8814B)
#define BIT_CLEAR_STBC_CFEND_8814B(x) ((x) & (~BITS_STBC_CFEND_8814B))
#define BIT_GET_STBC_CFEND_8814B(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_8814B) & BIT_MASK_STBC_CFEND_8814B)
#define BIT_SET_STBC_CFEND_8814B(x, v) \
(BIT_CLEAR_STBC_CFEND_8814B(x) | BIT_STBC_CFEND_8814B(v))
/* 2 REG_STBC_SETTING2_8814B */
#define BIT_SHIFT_CDEND_TXTIME_H_8814B 0
#define BIT_MASK_CDEND_TXTIME_H_8814B 0x1f
#define BIT_CDEND_TXTIME_H_8814B(x) \
(((x) & BIT_MASK_CDEND_TXTIME_H_8814B) \
<< BIT_SHIFT_CDEND_TXTIME_H_8814B)
#define BITS_CDEND_TXTIME_H_8814B \
(BIT_MASK_CDEND_TXTIME_H_8814B << BIT_SHIFT_CDEND_TXTIME_H_8814B)
#define BIT_CLEAR_CDEND_TXTIME_H_8814B(x) ((x) & (~BITS_CDEND_TXTIME_H_8814B))
#define BIT_GET_CDEND_TXTIME_H_8814B(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_H_8814B) & \
BIT_MASK_CDEND_TXTIME_H_8814B)
#define BIT_SET_CDEND_TXTIME_H_8814B(x, v) \
(BIT_CLEAR_CDEND_TXTIME_H_8814B(x) | BIT_CDEND_TXTIME_H_8814B(v))
/* 2 REG_QUEUE_CTRL_8814B */
#define BIT_FORCE_RND_PRI_8814B BIT(6)
#define BIT_PTA_EDCCA_EN_8814B BIT(5)
#define BIT_PTA_WL_TX_EN_8814B BIT(4)
#define BIT_USE_DATA_BW_8814B BIT(3)
#define BIT_TRI_PKT_INT_MODE1_8814B BIT(2)
#define BIT_TRI_PKT_INT_MODE0_8814B BIT(1)
#define BIT_ACQ_MODE_SEL_8814B BIT(0)
/* 2 REG_SINGLE_AMPDU_CTRL_8814B */
#define BIT_EN_SINGLE_APMDU_8814B BIT(7)
/* 2 REG_PROT_MODE_CTRL_8814B */
#define BIT_SHIFT_RTS_MAX_AGG_NUM_8814B 24
#define BIT_MASK_RTS_MAX_AGG_NUM_8814B 0x3f
#define BIT_RTS_MAX_AGG_NUM_8814B(x) \
(((x) & BIT_MASK_RTS_MAX_AGG_NUM_8814B) \
<< BIT_SHIFT_RTS_MAX_AGG_NUM_8814B)
#define BITS_RTS_MAX_AGG_NUM_8814B \
(BIT_MASK_RTS_MAX_AGG_NUM_8814B << BIT_SHIFT_RTS_MAX_AGG_NUM_8814B)
#define BIT_CLEAR_RTS_MAX_AGG_NUM_8814B(x) ((x) & (~BITS_RTS_MAX_AGG_NUM_8814B))
#define BIT_GET_RTS_MAX_AGG_NUM_8814B(x) \
(((x) >> BIT_SHIFT_RTS_MAX_AGG_NUM_8814B) & \
BIT_MASK_RTS_MAX_AGG_NUM_8814B)
#define BIT_SET_RTS_MAX_AGG_NUM_8814B(x, v) \
(BIT_CLEAR_RTS_MAX_AGG_NUM_8814B(x) | BIT_RTS_MAX_AGG_NUM_8814B(v))
#define BIT_SHIFT_MAX_AGG_NUM_8814B 16
#define BIT_MASK_MAX_AGG_NUM_8814B 0x3f
#define BIT_MAX_AGG_NUM_8814B(x) \
(((x) & BIT_MASK_MAX_AGG_NUM_8814B) << BIT_SHIFT_MAX_AGG_NUM_8814B)
#define BITS_MAX_AGG_NUM_8814B \
(BIT_MASK_MAX_AGG_NUM_8814B << BIT_SHIFT_MAX_AGG_NUM_8814B)
#define BIT_CLEAR_MAX_AGG_NUM_8814B(x) ((x) & (~BITS_MAX_AGG_NUM_8814B))
#define BIT_GET_MAX_AGG_NUM_8814B(x) \
(((x) >> BIT_SHIFT_MAX_AGG_NUM_8814B) & BIT_MASK_MAX_AGG_NUM_8814B)
#define BIT_SET_MAX_AGG_NUM_8814B(x, v) \
(BIT_CLEAR_MAX_AGG_NUM_8814B(x) | BIT_MAX_AGG_NUM_8814B(v))
#define BIT_SHIFT_RTS_TXTIME_TH_8814B 8
#define BIT_MASK_RTS_TXTIME_TH_8814B 0xff
#define BIT_RTS_TXTIME_TH_8814B(x) \
(((x) & BIT_MASK_RTS_TXTIME_TH_8814B) << BIT_SHIFT_RTS_TXTIME_TH_8814B)
#define BITS_RTS_TXTIME_TH_8814B \
(BIT_MASK_RTS_TXTIME_TH_8814B << BIT_SHIFT_RTS_TXTIME_TH_8814B)
#define BIT_CLEAR_RTS_TXTIME_TH_8814B(x) ((x) & (~BITS_RTS_TXTIME_TH_8814B))
#define BIT_GET_RTS_TXTIME_TH_8814B(x) \
(((x) >> BIT_SHIFT_RTS_TXTIME_TH_8814B) & BIT_MASK_RTS_TXTIME_TH_8814B)
#define BIT_SET_RTS_TXTIME_TH_8814B(x, v) \
(BIT_CLEAR_RTS_TXTIME_TH_8814B(x) | BIT_RTS_TXTIME_TH_8814B(v))
#define BIT_SHIFT_RTS_LEN_TH_8814B 0
#define BIT_MASK_RTS_LEN_TH_8814B 0xff
#define BIT_RTS_LEN_TH_8814B(x) \
(((x) & BIT_MASK_RTS_LEN_TH_8814B) << BIT_SHIFT_RTS_LEN_TH_8814B)
#define BITS_RTS_LEN_TH_8814B \
(BIT_MASK_RTS_LEN_TH_8814B << BIT_SHIFT_RTS_LEN_TH_8814B)
#define BIT_CLEAR_RTS_LEN_TH_8814B(x) ((x) & (~BITS_RTS_LEN_TH_8814B))
#define BIT_GET_RTS_LEN_TH_8814B(x) \
(((x) >> BIT_SHIFT_RTS_LEN_TH_8814B) & BIT_MASK_RTS_LEN_TH_8814B)
#define BIT_SET_RTS_LEN_TH_8814B(x, v) \
(BIT_CLEAR_RTS_LEN_TH_8814B(x) | BIT_RTS_LEN_TH_8814B(v))
/* 2 REG_BAR_MODE_CTRL_8814B */
#define BIT_SHIFT_BAR_RTY_LMT_8814B 16
#define BIT_MASK_BAR_RTY_LMT_8814B 0x3
#define BIT_BAR_RTY_LMT_8814B(x) \
(((x) & BIT_MASK_BAR_RTY_LMT_8814B) << BIT_SHIFT_BAR_RTY_LMT_8814B)
#define BITS_BAR_RTY_LMT_8814B \
(BIT_MASK_BAR_RTY_LMT_8814B << BIT_SHIFT_BAR_RTY_LMT_8814B)
#define BIT_CLEAR_BAR_RTY_LMT_8814B(x) ((x) & (~BITS_BAR_RTY_LMT_8814B))
#define BIT_GET_BAR_RTY_LMT_8814B(x) \
(((x) >> BIT_SHIFT_BAR_RTY_LMT_8814B) & BIT_MASK_BAR_RTY_LMT_8814B)
#define BIT_SET_BAR_RTY_LMT_8814B(x, v) \
(BIT_CLEAR_BAR_RTY_LMT_8814B(x) | BIT_BAR_RTY_LMT_8814B(v))
#define BIT_SHIFT_BAR_PKT_TXTIME_TH_8814B 8
#define BIT_MASK_BAR_PKT_TXTIME_TH_8814B 0xff
#define BIT_BAR_PKT_TXTIME_TH_8814B(x) \
(((x) & BIT_MASK_BAR_PKT_TXTIME_TH_8814B) \
<< BIT_SHIFT_BAR_PKT_TXTIME_TH_8814B)
#define BITS_BAR_PKT_TXTIME_TH_8814B \
(BIT_MASK_BAR_PKT_TXTIME_TH_8814B << BIT_SHIFT_BAR_PKT_TXTIME_TH_8814B)
#define BIT_CLEAR_BAR_PKT_TXTIME_TH_8814B(x) \
((x) & (~BITS_BAR_PKT_TXTIME_TH_8814B))
#define BIT_GET_BAR_PKT_TXTIME_TH_8814B(x) \
(((x) >> BIT_SHIFT_BAR_PKT_TXTIME_TH_8814B) & \
BIT_MASK_BAR_PKT_TXTIME_TH_8814B)
#define BIT_SET_BAR_PKT_TXTIME_TH_8814B(x, v) \
(BIT_CLEAR_BAR_PKT_TXTIME_TH_8814B(x) | BIT_BAR_PKT_TXTIME_TH_8814B(v))
#define BIT_BAR_EN_V1_8814B BIT(6)
#define BIT_SHIFT_BAR_PKTNUM_TH_V1_8814B 0
#define BIT_MASK_BAR_PKTNUM_TH_V1_8814B 0x3f
#define BIT_BAR_PKTNUM_TH_V1_8814B(x) \
(((x) & BIT_MASK_BAR_PKTNUM_TH_V1_8814B) \
<< BIT_SHIFT_BAR_PKTNUM_TH_V1_8814B)
#define BITS_BAR_PKTNUM_TH_V1_8814B \
(BIT_MASK_BAR_PKTNUM_TH_V1_8814B << BIT_SHIFT_BAR_PKTNUM_TH_V1_8814B)
#define BIT_CLEAR_BAR_PKTNUM_TH_V1_8814B(x) \
((x) & (~BITS_BAR_PKTNUM_TH_V1_8814B))
#define BIT_GET_BAR_PKTNUM_TH_V1_8814B(x) \
(((x) >> BIT_SHIFT_BAR_PKTNUM_TH_V1_8814B) & \
BIT_MASK_BAR_PKTNUM_TH_V1_8814B)
#define BIT_SET_BAR_PKTNUM_TH_V1_8814B(x, v) \
(BIT_CLEAR_BAR_PKTNUM_TH_V1_8814B(x) | BIT_BAR_PKTNUM_TH_V1_8814B(v))
/* 2 REG_RA_TRY_RATE_AGG_LMT_8814B */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8814B 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8814B 0x3f
#define BIT_RA_TRY_RATE_AGG_LMT_V1_8814B(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8814B) \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8814B)
#define BITS_RA_TRY_RATE_AGG_LMT_V1_8814B \
(BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8814B \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8814B)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8814B(x) \
((x) & (~BITS_RA_TRY_RATE_AGG_LMT_V1_8814B))
#define BIT_GET_RA_TRY_RATE_AGG_LMT_V1_8814B(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8814B) & \
BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8814B)
#define BIT_SET_RA_TRY_RATE_AGG_LMT_V1_8814B(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8814B(x) | \
BIT_RA_TRY_RATE_AGG_LMT_V1_8814B(v))
/* 2 REG_MACID_SLEEP_CTRL_8814B */
#define BIT_SHIFT_DEBUG_PROTOCOL_8814B 24
#define BIT_MASK_DEBUG_PROTOCOL_8814B 0xff
#define BIT_DEBUG_PROTOCOL_8814B(x) \
(((x) & BIT_MASK_DEBUG_PROTOCOL_8814B) \
<< BIT_SHIFT_DEBUG_PROTOCOL_8814B)
#define BITS_DEBUG_PROTOCOL_8814B \
(BIT_MASK_DEBUG_PROTOCOL_8814B << BIT_SHIFT_DEBUG_PROTOCOL_8814B)
#define BIT_CLEAR_DEBUG_PROTOCOL_8814B(x) ((x) & (~BITS_DEBUG_PROTOCOL_8814B))
#define BIT_GET_DEBUG_PROTOCOL_8814B(x) \
(((x) >> BIT_SHIFT_DEBUG_PROTOCOL_8814B) & \
BIT_MASK_DEBUG_PROTOCOL_8814B)
#define BIT_SET_DEBUG_PROTOCOL_8814B(x, v) \
(BIT_CLEAR_DEBUG_PROTOCOL_8814B(x) | BIT_DEBUG_PROTOCOL_8814B(v))
#define BIT_SHIFT_BCNQ_PGBNDY_RSEL_8814B 16
#define BIT_MASK_BCNQ_PGBNDY_RSEL_8814B 0x7
#define BIT_BCNQ_PGBNDY_RSEL_8814B(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_RSEL_8814B) \
<< BIT_SHIFT_BCNQ_PGBNDY_RSEL_8814B)
#define BITS_BCNQ_PGBNDY_RSEL_8814B \
(BIT_MASK_BCNQ_PGBNDY_RSEL_8814B << BIT_SHIFT_BCNQ_PGBNDY_RSEL_8814B)
#define BIT_CLEAR_BCNQ_PGBNDY_RSEL_8814B(x) \
((x) & (~BITS_BCNQ_PGBNDY_RSEL_8814B))
#define BIT_GET_BCNQ_PGBNDY_RSEL_8814B(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_RSEL_8814B) & \
BIT_MASK_BCNQ_PGBNDY_RSEL_8814B)
#define BIT_SET_BCNQ_PGBNDY_RSEL_8814B(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_RSEL_8814B(x) | BIT_BCNQ_PGBNDY_RSEL_8814B(v))
#define BIT_SHIFT_MACID_SLEEP_SEL_8814B 0
#define BIT_MASK_MACID_SLEEP_SEL_8814B 0x7
#define BIT_MACID_SLEEP_SEL_8814B(x) \
(((x) & BIT_MASK_MACID_SLEEP_SEL_8814B) \
<< BIT_SHIFT_MACID_SLEEP_SEL_8814B)
#define BITS_MACID_SLEEP_SEL_8814B \
(BIT_MASK_MACID_SLEEP_SEL_8814B << BIT_SHIFT_MACID_SLEEP_SEL_8814B)
#define BIT_CLEAR_MACID_SLEEP_SEL_8814B(x) ((x) & (~BITS_MACID_SLEEP_SEL_8814B))
#define BIT_GET_MACID_SLEEP_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MACID_SLEEP_SEL_8814B) & \
BIT_MASK_MACID_SLEEP_SEL_8814B)
#define BIT_SET_MACID_SLEEP_SEL_8814B(x, v) \
(BIT_CLEAR_MACID_SLEEP_SEL_8814B(x) | BIT_MACID_SLEEP_SEL_8814B(v))
/* 2 REG_MACID_SLEEP_INFO_8814B */
#define BIT_SHIFT_MACID_SLEEP_INFO_8814B 0
#define BIT_MASK_MACID_SLEEP_INFO_8814B 0xffffffffL
#define BIT_MACID_SLEEP_INFO_8814B(x) \
(((x) & BIT_MASK_MACID_SLEEP_INFO_8814B) \
<< BIT_SHIFT_MACID_SLEEP_INFO_8814B)
#define BITS_MACID_SLEEP_INFO_8814B \
(BIT_MASK_MACID_SLEEP_INFO_8814B << BIT_SHIFT_MACID_SLEEP_INFO_8814B)
#define BIT_CLEAR_MACID_SLEEP_INFO_8814B(x) \
((x) & (~BITS_MACID_SLEEP_INFO_8814B))
#define BIT_GET_MACID_SLEEP_INFO_8814B(x) \
(((x) >> BIT_SHIFT_MACID_SLEEP_INFO_8814B) & \
BIT_MASK_MACID_SLEEP_INFO_8814B)
#define BIT_SET_MACID_SLEEP_INFO_8814B(x, v) \
(BIT_CLEAR_MACID_SLEEP_INFO_8814B(x) | BIT_MACID_SLEEP_INFO_8814B(v))
/* 2 REG_HW_SEQ0_8814B */
#define BIT_SHIFT_HW_SSN_SEQ0_8814B 0
#define BIT_MASK_HW_SSN_SEQ0_8814B 0xfff
#define BIT_HW_SSN_SEQ0_8814B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ0_8814B) << BIT_SHIFT_HW_SSN_SEQ0_8814B)
#define BITS_HW_SSN_SEQ0_8814B \
(BIT_MASK_HW_SSN_SEQ0_8814B << BIT_SHIFT_HW_SSN_SEQ0_8814B)
#define BIT_CLEAR_HW_SSN_SEQ0_8814B(x) ((x) & (~BITS_HW_SSN_SEQ0_8814B))
#define BIT_GET_HW_SSN_SEQ0_8814B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ0_8814B) & BIT_MASK_HW_SSN_SEQ0_8814B)
#define BIT_SET_HW_SSN_SEQ0_8814B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ0_8814B(x) | BIT_HW_SSN_SEQ0_8814B(v))
/* 2 REG_HW_SEQ1_8814B */
#define BIT_SHIFT_HW_SSN_SEQ1_8814B 0
#define BIT_MASK_HW_SSN_SEQ1_8814B 0xfff
#define BIT_HW_SSN_SEQ1_8814B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ1_8814B) << BIT_SHIFT_HW_SSN_SEQ1_8814B)
#define BITS_HW_SSN_SEQ1_8814B \
(BIT_MASK_HW_SSN_SEQ1_8814B << BIT_SHIFT_HW_SSN_SEQ1_8814B)
#define BIT_CLEAR_HW_SSN_SEQ1_8814B(x) ((x) & (~BITS_HW_SSN_SEQ1_8814B))
#define BIT_GET_HW_SSN_SEQ1_8814B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ1_8814B) & BIT_MASK_HW_SSN_SEQ1_8814B)
#define BIT_SET_HW_SSN_SEQ1_8814B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ1_8814B(x) | BIT_HW_SSN_SEQ1_8814B(v))
/* 2 REG_HW_SEQ2_8814B */
#define BIT_SHIFT_HW_SSN_SEQ2_8814B 0
#define BIT_MASK_HW_SSN_SEQ2_8814B 0xfff
#define BIT_HW_SSN_SEQ2_8814B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ2_8814B) << BIT_SHIFT_HW_SSN_SEQ2_8814B)
#define BITS_HW_SSN_SEQ2_8814B \
(BIT_MASK_HW_SSN_SEQ2_8814B << BIT_SHIFT_HW_SSN_SEQ2_8814B)
#define BIT_CLEAR_HW_SSN_SEQ2_8814B(x) ((x) & (~BITS_HW_SSN_SEQ2_8814B))
#define BIT_GET_HW_SSN_SEQ2_8814B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ2_8814B) & BIT_MASK_HW_SSN_SEQ2_8814B)
#define BIT_SET_HW_SSN_SEQ2_8814B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ2_8814B(x) | BIT_HW_SSN_SEQ2_8814B(v))
/* 2 REG_HW_SEQ3_8814B */
#define BIT_SHIFT_CSI_HWSEQ_SEL_8814B 12
#define BIT_MASK_CSI_HWSEQ_SEL_8814B 0x3
#define BIT_CSI_HWSEQ_SEL_8814B(x) \
(((x) & BIT_MASK_CSI_HWSEQ_SEL_8814B) << BIT_SHIFT_CSI_HWSEQ_SEL_8814B)
#define BITS_CSI_HWSEQ_SEL_8814B \
(BIT_MASK_CSI_HWSEQ_SEL_8814B << BIT_SHIFT_CSI_HWSEQ_SEL_8814B)
#define BIT_CLEAR_CSI_HWSEQ_SEL_8814B(x) ((x) & (~BITS_CSI_HWSEQ_SEL_8814B))
#define BIT_GET_CSI_HWSEQ_SEL_8814B(x) \
(((x) >> BIT_SHIFT_CSI_HWSEQ_SEL_8814B) & BIT_MASK_CSI_HWSEQ_SEL_8814B)
#define BIT_SET_CSI_HWSEQ_SEL_8814B(x, v) \
(BIT_CLEAR_CSI_HWSEQ_SEL_8814B(x) | BIT_CSI_HWSEQ_SEL_8814B(v))
#define BIT_SHIFT_HW_SSN_SEQ3_8814B 0
#define BIT_MASK_HW_SSN_SEQ3_8814B 0xfff
#define BIT_HW_SSN_SEQ3_8814B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ3_8814B) << BIT_SHIFT_HW_SSN_SEQ3_8814B)
#define BITS_HW_SSN_SEQ3_8814B \
(BIT_MASK_HW_SSN_SEQ3_8814B << BIT_SHIFT_HW_SSN_SEQ3_8814B)
#define BIT_CLEAR_HW_SSN_SEQ3_8814B(x) ((x) & (~BITS_HW_SSN_SEQ3_8814B))
#define BIT_GET_HW_SSN_SEQ3_8814B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ3_8814B) & BIT_MASK_HW_SSN_SEQ3_8814B)
#define BIT_SET_HW_SSN_SEQ3_8814B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ3_8814B(x) | BIT_HW_SSN_SEQ3_8814B(v))
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_PTCL_TOTAL_PG_V3_8814B 0
#define BIT_MASK_PTCL_TOTAL_PG_V3_8814B 0x1fff
#define BIT_PTCL_TOTAL_PG_V3_8814B(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V3_8814B) \
<< BIT_SHIFT_PTCL_TOTAL_PG_V3_8814B)
#define BITS_PTCL_TOTAL_PG_V3_8814B \
(BIT_MASK_PTCL_TOTAL_PG_V3_8814B << BIT_SHIFT_PTCL_TOTAL_PG_V3_8814B)
#define BIT_CLEAR_PTCL_TOTAL_PG_V3_8814B(x) \
((x) & (~BITS_PTCL_TOTAL_PG_V3_8814B))
#define BIT_GET_PTCL_TOTAL_PG_V3_8814B(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V3_8814B) & \
BIT_MASK_PTCL_TOTAL_PG_V3_8814B)
#define BIT_SET_PTCL_TOTAL_PG_V3_8814B(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V3_8814B(x) | BIT_PTCL_TOTAL_PG_V3_8814B(v))
/* 2 REG_PTCL_ERR_STATUS_V1_8814B */
#define BIT_MUARB_SEARCH_ERR_8814B BIT(14)
#define BIT_MU_BFEN_ERR_8814B BIT(12)
#define BIT_NDPA_DROPNULL_ERR_8814B BIT(11)
#define BIT_NDPA_DROPPKT_ERR_8814B BIT(10)
#define BIT_PTCL_PKYIN_ERR_8814B BIT(9)
#define BIT_PTCL_QSELCNL_ERR_8814B BIT(8)
#define BIT_PTCL_RATE_TABLE_INVALID_8814B BIT(7)
#define BIT_FTM_T2R_ERROR_8814B BIT(6)
#define BIT_TXTIMEOUT_ERR_8814B BIT(5)
#define BIT_NULLPAGE_ERR_8814B BIT(4)
#define BIT_CONTENTION_ERR_8814B BIT(3)
#define BIT_HEADNULL_ERR_8814B BIT(2)
#define BIT_OVERFLOW_ERR_8814B BIT(1)
#define BIT_QUEUE_INDEX_ERR_8814B BIT(0)
/* 2 REG_NULL_PKT_STATUS_V2_8814B */
#define BIT_HIQ_DROP_8814B BIT(7)
#define BIT_MGQ_DROP_8814B BIT(6)
#define BIT_TX_NULL_1_V1_8814B BIT(1)
#define BIT_TX_NULL_0_V1_8814B BIT(0)
/* 2 REG_PRECNT_CTRL_8814B */
#define BIT_EN_PRECNT_8814B BIT(11)
#define BIT_SHIFT_PRECNT_TH_8814B 0
#define BIT_MASK_PRECNT_TH_8814B 0x7ff
#define BIT_PRECNT_TH_8814B(x) \
(((x) & BIT_MASK_PRECNT_TH_8814B) << BIT_SHIFT_PRECNT_TH_8814B)
#define BITS_PRECNT_TH_8814B \
(BIT_MASK_PRECNT_TH_8814B << BIT_SHIFT_PRECNT_TH_8814B)
#define BIT_CLEAR_PRECNT_TH_8814B(x) ((x) & (~BITS_PRECNT_TH_8814B))
#define BIT_GET_PRECNT_TH_8814B(x) \
(((x) >> BIT_SHIFT_PRECNT_TH_8814B) & BIT_MASK_PRECNT_TH_8814B)
#define BIT_SET_PRECNT_TH_8814B(x, v) \
(BIT_CLEAR_PRECNT_TH_8814B(x) | BIT_PRECNT_TH_8814B(v))
/* 2 REG_NULL_PKT_STATUS_EXTEND_V1_8814B */
#define BIT_CLI3_TX_NULL_1_V1_8814B BIT(7)
#define BIT_CLI3_TX_NULL_0_V1_8814B BIT(6)
#define BIT_CLI2_TX_NULL_1_V1_8814B BIT(5)
#define BIT_CLI2_TX_NULL_0_V1_8814B BIT(4)
#define BIT_CLI1_TX_NULL_1_V1_8814B BIT(3)
#define BIT_CLI1_TX_NULL_0_V1_8814B BIT(2)
#define BIT_CLI0_TX_NULL_1_V1_8814B BIT(1)
#define BIT_CLI0_TX_NULL_0_V1_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PTCL_DBG_V1_8814B */
#define BIT_SHIFT_PTCL_DBG_8814B 0
#define BIT_MASK_PTCL_DBG_8814B 0xffffffffL
#define BIT_PTCL_DBG_8814B(x) \
(((x) & BIT_MASK_PTCL_DBG_8814B) << BIT_SHIFT_PTCL_DBG_8814B)
#define BITS_PTCL_DBG_8814B \
(BIT_MASK_PTCL_DBG_8814B << BIT_SHIFT_PTCL_DBG_8814B)
#define BIT_CLEAR_PTCL_DBG_8814B(x) ((x) & (~BITS_PTCL_DBG_8814B))
#define BIT_GET_PTCL_DBG_8814B(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_8814B) & BIT_MASK_PTCL_DBG_8814B)
#define BIT_SET_PTCL_DBG_8814B(x, v) \
(BIT_CLEAR_PTCL_DBG_8814B(x) | BIT_PTCL_DBG_8814B(v))
/* 2 REG_BT_POLLUTE_PKTCNT_8814B */
#define BIT_SHIFT_BT_POLLUTE_PKTCNT_8814B 0
#define BIT_MASK_BT_POLLUTE_PKTCNT_8814B 0xffff
#define BIT_BT_POLLUTE_PKTCNT_8814B(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKTCNT_8814B) \
<< BIT_SHIFT_BT_POLLUTE_PKTCNT_8814B)
#define BITS_BT_POLLUTE_PKTCNT_8814B \
(BIT_MASK_BT_POLLUTE_PKTCNT_8814B << BIT_SHIFT_BT_POLLUTE_PKTCNT_8814B)
#define BIT_CLEAR_BT_POLLUTE_PKTCNT_8814B(x) \
((x) & (~BITS_BT_POLLUTE_PKTCNT_8814B))
#define BIT_GET_BT_POLLUTE_PKTCNT_8814B(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKTCNT_8814B) & \
BIT_MASK_BT_POLLUTE_PKTCNT_8814B)
#define BIT_SET_BT_POLLUTE_PKTCNT_8814B(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKTCNT_8814B(x) | BIT_BT_POLLUTE_PKTCNT_8814B(v))
/* 2 REG_CPUMGQ_TIMER_CTRL2_8814B */
#define BIT_SHIFT_TRI_HEAD_ADDR_8814B 16
#define BIT_MASK_TRI_HEAD_ADDR_8814B 0xfff
#define BIT_TRI_HEAD_ADDR_8814B(x) \
(((x) & BIT_MASK_TRI_HEAD_ADDR_8814B) << BIT_SHIFT_TRI_HEAD_ADDR_8814B)
#define BITS_TRI_HEAD_ADDR_8814B \
(BIT_MASK_TRI_HEAD_ADDR_8814B << BIT_SHIFT_TRI_HEAD_ADDR_8814B)
#define BIT_CLEAR_TRI_HEAD_ADDR_8814B(x) ((x) & (~BITS_TRI_HEAD_ADDR_8814B))
#define BIT_GET_TRI_HEAD_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_TRI_HEAD_ADDR_8814B) & BIT_MASK_TRI_HEAD_ADDR_8814B)
#define BIT_SET_TRI_HEAD_ADDR_8814B(x, v) \
(BIT_CLEAR_TRI_HEAD_ADDR_8814B(x) | BIT_TRI_HEAD_ADDR_8814B(v))
#define BIT_DROP_TH_EN_8814B BIT(8)
#define BIT_SHIFT_DROP_TH_8814B 0
#define BIT_MASK_DROP_TH_8814B 0xff
#define BIT_DROP_TH_8814B(x) \
(((x) & BIT_MASK_DROP_TH_8814B) << BIT_SHIFT_DROP_TH_8814B)
#define BITS_DROP_TH_8814B (BIT_MASK_DROP_TH_8814B << BIT_SHIFT_DROP_TH_8814B)
#define BIT_CLEAR_DROP_TH_8814B(x) ((x) & (~BITS_DROP_TH_8814B))
#define BIT_GET_DROP_TH_8814B(x) \
(((x) >> BIT_SHIFT_DROP_TH_8814B) & BIT_MASK_DROP_TH_8814B)
#define BIT_SET_DROP_TH_8814B(x, v) \
(BIT_CLEAR_DROP_TH_8814B(x) | BIT_DROP_TH_8814B(v))
/* 2 REG_PTCL_DBG_OUT_8814B */
#define BIT_SHIFT_PTCL_DBG_OUT_8814B 0
#define BIT_MASK_PTCL_DBG_OUT_8814B 0xffffffffL
#define BIT_PTCL_DBG_OUT_8814B(x) \
(((x) & BIT_MASK_PTCL_DBG_OUT_8814B) << BIT_SHIFT_PTCL_DBG_OUT_8814B)
#define BITS_PTCL_DBG_OUT_8814B \
(BIT_MASK_PTCL_DBG_OUT_8814B << BIT_SHIFT_PTCL_DBG_OUT_8814B)
#define BIT_CLEAR_PTCL_DBG_OUT_8814B(x) ((x) & (~BITS_PTCL_DBG_OUT_8814B))
#define BIT_GET_PTCL_DBG_OUT_8814B(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_OUT_8814B) & BIT_MASK_PTCL_DBG_OUT_8814B)
#define BIT_SET_PTCL_DBG_OUT_8814B(x, v) \
(BIT_CLEAR_PTCL_DBG_OUT_8814B(x) | BIT_PTCL_DBG_OUT_8814B(v))
/* 2 REG_DUMMY_PAGE4_V1_8814B */
/* 2 REG_DUMMY_PAGE4_1_8814B */
/* 2 REG_MU_OFFSET_8814B */
#define BIT_SHIFT_MU_RATETABLE_OFFSET_8814B 16
#define BIT_MASK_MU_RATETABLE_OFFSET_8814B 0x1ff
#define BIT_MU_RATETABLE_OFFSET_8814B(x) \
(((x) & BIT_MASK_MU_RATETABLE_OFFSET_8814B) \
<< BIT_SHIFT_MU_RATETABLE_OFFSET_8814B)
#define BITS_MU_RATETABLE_OFFSET_8814B \
(BIT_MASK_MU_RATETABLE_OFFSET_8814B \
<< BIT_SHIFT_MU_RATETABLE_OFFSET_8814B)
#define BIT_CLEAR_MU_RATETABLE_OFFSET_8814B(x) \
((x) & (~BITS_MU_RATETABLE_OFFSET_8814B))
#define BIT_GET_MU_RATETABLE_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_MU_RATETABLE_OFFSET_8814B) & \
BIT_MASK_MU_RATETABLE_OFFSET_8814B)
#define BIT_SET_MU_RATETABLE_OFFSET_8814B(x, v) \
(BIT_CLEAR_MU_RATETABLE_OFFSET_8814B(x) | \
BIT_MU_RATETABLE_OFFSET_8814B(v))
#define BIT_SHIFT_MU_SCORETABLE_OFFSET_8814B 0
#define BIT_MASK_MU_SCORETABLE_OFFSET_8814B 0x1ff
#define BIT_MU_SCORETABLE_OFFSET_8814B(x) \
(((x) & BIT_MASK_MU_SCORETABLE_OFFSET_8814B) \
<< BIT_SHIFT_MU_SCORETABLE_OFFSET_8814B)
#define BITS_MU_SCORETABLE_OFFSET_8814B \
(BIT_MASK_MU_SCORETABLE_OFFSET_8814B \
<< BIT_SHIFT_MU_SCORETABLE_OFFSET_8814B)
#define BIT_CLEAR_MU_SCORETABLE_OFFSET_8814B(x) \
((x) & (~BITS_MU_SCORETABLE_OFFSET_8814B))
#define BIT_GET_MU_SCORETABLE_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_MU_SCORETABLE_OFFSET_8814B) & \
BIT_MASK_MU_SCORETABLE_OFFSET_8814B)
#define BIT_SET_MU_SCORETABLE_OFFSET_8814B(x, v) \
(BIT_CLEAR_MU_SCORETABLE_OFFSET_8814B(x) | \
BIT_MU_SCORETABLE_OFFSET_8814B(v))
/* 2 REG_BF0_TIME_SETTING_8814B */
#define BIT_BF0_TIMER_SET_8814B BIT(31)
#define BIT_BF0_TIMER_CLR_8814B BIT(30)
#define BIT_BF0_UPDATE_EN_8814B BIT(29)
#define BIT_BF0_TIMER_EN_8814B BIT(28)
#define BIT_SHIFT_BF0_PRETIME_OVER_8814B 16
#define BIT_MASK_BF0_PRETIME_OVER_8814B 0xfff
#define BIT_BF0_PRETIME_OVER_8814B(x) \
(((x) & BIT_MASK_BF0_PRETIME_OVER_8814B) \
<< BIT_SHIFT_BF0_PRETIME_OVER_8814B)
#define BITS_BF0_PRETIME_OVER_8814B \
(BIT_MASK_BF0_PRETIME_OVER_8814B << BIT_SHIFT_BF0_PRETIME_OVER_8814B)
#define BIT_CLEAR_BF0_PRETIME_OVER_8814B(x) \
((x) & (~BITS_BF0_PRETIME_OVER_8814B))
#define BIT_GET_BF0_PRETIME_OVER_8814B(x) \
(((x) >> BIT_SHIFT_BF0_PRETIME_OVER_8814B) & \
BIT_MASK_BF0_PRETIME_OVER_8814B)
#define BIT_SET_BF0_PRETIME_OVER_8814B(x, v) \
(BIT_CLEAR_BF0_PRETIME_OVER_8814B(x) | BIT_BF0_PRETIME_OVER_8814B(v))
#define BIT_SHIFT_BF0_LIFETIME_8814B 0
#define BIT_MASK_BF0_LIFETIME_8814B 0xffff
#define BIT_BF0_LIFETIME_8814B(x) \
(((x) & BIT_MASK_BF0_LIFETIME_8814B) << BIT_SHIFT_BF0_LIFETIME_8814B)
#define BITS_BF0_LIFETIME_8814B \
(BIT_MASK_BF0_LIFETIME_8814B << BIT_SHIFT_BF0_LIFETIME_8814B)
#define BIT_CLEAR_BF0_LIFETIME_8814B(x) ((x) & (~BITS_BF0_LIFETIME_8814B))
#define BIT_GET_BF0_LIFETIME_8814B(x) \
(((x) >> BIT_SHIFT_BF0_LIFETIME_8814B) & BIT_MASK_BF0_LIFETIME_8814B)
#define BIT_SET_BF0_LIFETIME_8814B(x, v) \
(BIT_CLEAR_BF0_LIFETIME_8814B(x) | BIT_BF0_LIFETIME_8814B(v))
/* 2 REG_BF1_TIME_SETTING_8814B */
#define BIT_BF1_TIMER_SET_8814B BIT(31)
#define BIT_BF1_TIMER_CLR_8814B BIT(30)
#define BIT_BF1_UPDATE_EN_8814B BIT(29)
#define BIT_BF1_TIMER_EN_8814B BIT(28)
#define BIT_SHIFT_BF1_PRETIME_OVER_8814B 16
#define BIT_MASK_BF1_PRETIME_OVER_8814B 0xfff
#define BIT_BF1_PRETIME_OVER_8814B(x) \
(((x) & BIT_MASK_BF1_PRETIME_OVER_8814B) \
<< BIT_SHIFT_BF1_PRETIME_OVER_8814B)
#define BITS_BF1_PRETIME_OVER_8814B \
(BIT_MASK_BF1_PRETIME_OVER_8814B << BIT_SHIFT_BF1_PRETIME_OVER_8814B)
#define BIT_CLEAR_BF1_PRETIME_OVER_8814B(x) \
((x) & (~BITS_BF1_PRETIME_OVER_8814B))
#define BIT_GET_BF1_PRETIME_OVER_8814B(x) \
(((x) >> BIT_SHIFT_BF1_PRETIME_OVER_8814B) & \
BIT_MASK_BF1_PRETIME_OVER_8814B)
#define BIT_SET_BF1_PRETIME_OVER_8814B(x, v) \
(BIT_CLEAR_BF1_PRETIME_OVER_8814B(x) | BIT_BF1_PRETIME_OVER_8814B(v))
#define BIT_SHIFT_BF1_LIFETIME_8814B 0
#define BIT_MASK_BF1_LIFETIME_8814B 0xffff
#define BIT_BF1_LIFETIME_8814B(x) \
(((x) & BIT_MASK_BF1_LIFETIME_8814B) << BIT_SHIFT_BF1_LIFETIME_8814B)
#define BITS_BF1_LIFETIME_8814B \
(BIT_MASK_BF1_LIFETIME_8814B << BIT_SHIFT_BF1_LIFETIME_8814B)
#define BIT_CLEAR_BF1_LIFETIME_8814B(x) ((x) & (~BITS_BF1_LIFETIME_8814B))
#define BIT_GET_BF1_LIFETIME_8814B(x) \
(((x) >> BIT_SHIFT_BF1_LIFETIME_8814B) & BIT_MASK_BF1_LIFETIME_8814B)
#define BIT_SET_BF1_LIFETIME_8814B(x, v) \
(BIT_CLEAR_BF1_LIFETIME_8814B(x) | BIT_BF1_LIFETIME_8814B(v))
/* 2 REG_BF_TIMEOUT_EN_8814B */
#define BIT_EN_VHT_LDPC_8814B BIT(9)
#define BIT_EN_HT_LDPC_8814B BIT(8)
#define BIT_BF1_TIMEOUT_EN_8814B BIT(1)
#define BIT_BF0_TIMEOUT_EN_8814B BIT(0)
/* 2 REG_MACID_RELEASE_INFO_8814B */
#define BIT_SHIFT_MACID_RELEASE_INFO_8814B 0
#define BIT_MASK_MACID_RELEASE_INFO_8814B 0xffffffffL
#define BIT_MACID_RELEASE_INFO_8814B(x) \
(((x) & BIT_MASK_MACID_RELEASE_INFO_8814B) \
<< BIT_SHIFT_MACID_RELEASE_INFO_8814B)
#define BITS_MACID_RELEASE_INFO_8814B \
(BIT_MASK_MACID_RELEASE_INFO_8814B \
<< BIT_SHIFT_MACID_RELEASE_INFO_8814B)
#define BIT_CLEAR_MACID_RELEASE_INFO_8814B(x) \
((x) & (~BITS_MACID_RELEASE_INFO_8814B))
#define BIT_GET_MACID_RELEASE_INFO_8814B(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_INFO_8814B) & \
BIT_MASK_MACID_RELEASE_INFO_8814B)
#define BIT_SET_MACID_RELEASE_INFO_8814B(x, v) \
(BIT_CLEAR_MACID_RELEASE_INFO_8814B(x) | \
BIT_MACID_RELEASE_INFO_8814B(v))
/* 2 REG_MACID_RELEASE_SUCCESS_INFO_8814B */
#define BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO_8814B 0
#define BIT_MASK_MACID_RELEASE_SUCCESS_INFO_8814B 0xffffffffL
#define BIT_MACID_RELEASE_SUCCESS_INFO_8814B(x) \
(((x) & BIT_MASK_MACID_RELEASE_SUCCESS_INFO_8814B) \
<< BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO_8814B)
#define BITS_MACID_RELEASE_SUCCESS_INFO_8814B \
(BIT_MASK_MACID_RELEASE_SUCCESS_INFO_8814B \
<< BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO_8814B)
#define BIT_CLEAR_MACID_RELEASE_SUCCESS_INFO_8814B(x) \
((x) & (~BITS_MACID_RELEASE_SUCCESS_INFO_8814B))
#define BIT_GET_MACID_RELEASE_SUCCESS_INFO_8814B(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_SUCCESS_INFO_8814B) & \
BIT_MASK_MACID_RELEASE_SUCCESS_INFO_8814B)
#define BIT_SET_MACID_RELEASE_SUCCESS_INFO_8814B(x, v) \
(BIT_CLEAR_MACID_RELEASE_SUCCESS_INFO_8814B(x) | \
BIT_MACID_RELEASE_SUCCESS_INFO_8814B(v))
/* 2 REG_MACID_RELEASE_CTRL_8814B */
#define BIT_SHIFT_MACID_RELEASE_SEL_8814B 24
#define BIT_MASK_MACID_RELEASE_SEL_8814B 0x7
#define BIT_MACID_RELEASE_SEL_8814B(x) \
(((x) & BIT_MASK_MACID_RELEASE_SEL_8814B) \
<< BIT_SHIFT_MACID_RELEASE_SEL_8814B)
#define BITS_MACID_RELEASE_SEL_8814B \
(BIT_MASK_MACID_RELEASE_SEL_8814B << BIT_SHIFT_MACID_RELEASE_SEL_8814B)
#define BIT_CLEAR_MACID_RELEASE_SEL_8814B(x) \
((x) & (~BITS_MACID_RELEASE_SEL_8814B))
#define BIT_GET_MACID_RELEASE_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_SEL_8814B) & \
BIT_MASK_MACID_RELEASE_SEL_8814B)
#define BIT_SET_MACID_RELEASE_SEL_8814B(x, v) \
(BIT_CLEAR_MACID_RELEASE_SEL_8814B(x) | BIT_MACID_RELEASE_SEL_8814B(v))
#define BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET_8814B 16
#define BIT_MASK_MACID_RELEASE_CLEAR_OFFSET_8814B 0xff
#define BIT_MACID_RELEASE_CLEAR_OFFSET_8814B(x) \
(((x) & BIT_MASK_MACID_RELEASE_CLEAR_OFFSET_8814B) \
<< BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET_8814B)
#define BITS_MACID_RELEASE_CLEAR_OFFSET_8814B \
(BIT_MASK_MACID_RELEASE_CLEAR_OFFSET_8814B \
<< BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET_8814B)
#define BIT_CLEAR_MACID_RELEASE_CLEAR_OFFSET_8814B(x) \
((x) & (~BITS_MACID_RELEASE_CLEAR_OFFSET_8814B))
#define BIT_GET_MACID_RELEASE_CLEAR_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_CLEAR_OFFSET_8814B) & \
BIT_MASK_MACID_RELEASE_CLEAR_OFFSET_8814B)
#define BIT_SET_MACID_RELEASE_CLEAR_OFFSET_8814B(x, v) \
(BIT_CLEAR_MACID_RELEASE_CLEAR_OFFSET_8814B(x) | \
BIT_MACID_RELEASE_CLEAR_OFFSET_8814B(v))
#define BIT_MACID_RELEASE_VALUE_8814B BIT(8)
#define BIT_SHIFT_MACID_RELEASE_OFFSET_8814B 0
#define BIT_MASK_MACID_RELEASE_OFFSET_8814B 0xff
#define BIT_MACID_RELEASE_OFFSET_8814B(x) \
(((x) & BIT_MASK_MACID_RELEASE_OFFSET_8814B) \
<< BIT_SHIFT_MACID_RELEASE_OFFSET_8814B)
#define BITS_MACID_RELEASE_OFFSET_8814B \
(BIT_MASK_MACID_RELEASE_OFFSET_8814B \
<< BIT_SHIFT_MACID_RELEASE_OFFSET_8814B)
#define BIT_CLEAR_MACID_RELEASE_OFFSET_8814B(x) \
((x) & (~BITS_MACID_RELEASE_OFFSET_8814B))
#define BIT_GET_MACID_RELEASE_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_MACID_RELEASE_OFFSET_8814B) & \
BIT_MASK_MACID_RELEASE_OFFSET_8814B)
#define BIT_SET_MACID_RELEASE_OFFSET_8814B(x, v) \
(BIT_CLEAR_MACID_RELEASE_OFFSET_8814B(x) | \
BIT_MACID_RELEASE_OFFSET_8814B(v))
/* 2 REG_FAST_EDCA_VOVI_SETTING_8814B */
#define BIT_SHIFT_VI_FAST_EDCA_TO_8814B 24
#define BIT_MASK_VI_FAST_EDCA_TO_8814B 0xff
#define BIT_VI_FAST_EDCA_TO_8814B(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_TO_8814B) \
<< BIT_SHIFT_VI_FAST_EDCA_TO_8814B)
#define BITS_VI_FAST_EDCA_TO_8814B \
(BIT_MASK_VI_FAST_EDCA_TO_8814B << BIT_SHIFT_VI_FAST_EDCA_TO_8814B)
#define BIT_CLEAR_VI_FAST_EDCA_TO_8814B(x) ((x) & (~BITS_VI_FAST_EDCA_TO_8814B))
#define BIT_GET_VI_FAST_EDCA_TO_8814B(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_TO_8814B) & \
BIT_MASK_VI_FAST_EDCA_TO_8814B)
#define BIT_SET_VI_FAST_EDCA_TO_8814B(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_TO_8814B(x) | BIT_VI_FAST_EDCA_TO_8814B(v))
#define BIT_VI_THRESHOLD_SEL_8814B BIT(23)
#define BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8814B 16
#define BIT_MASK_VI_FAST_EDCA_PKT_TH_8814B 0x7f
#define BIT_VI_FAST_EDCA_PKT_TH_8814B(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_PKT_TH_8814B) \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8814B)
#define BITS_VI_FAST_EDCA_PKT_TH_8814B \
(BIT_MASK_VI_FAST_EDCA_PKT_TH_8814B \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8814B)
#define BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8814B(x) \
((x) & (~BITS_VI_FAST_EDCA_PKT_TH_8814B))
#define BIT_GET_VI_FAST_EDCA_PKT_TH_8814B(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8814B) & \
BIT_MASK_VI_FAST_EDCA_PKT_TH_8814B)
#define BIT_SET_VI_FAST_EDCA_PKT_TH_8814B(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8814B(x) | \
BIT_VI_FAST_EDCA_PKT_TH_8814B(v))
#define BIT_SHIFT_VO_FAST_EDCA_TO_8814B 8
#define BIT_MASK_VO_FAST_EDCA_TO_8814B 0xff
#define BIT_VO_FAST_EDCA_TO_8814B(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO_8814B) \
<< BIT_SHIFT_VO_FAST_EDCA_TO_8814B)
#define BITS_VO_FAST_EDCA_TO_8814B \
(BIT_MASK_VO_FAST_EDCA_TO_8814B << BIT_SHIFT_VO_FAST_EDCA_TO_8814B)
#define BIT_CLEAR_VO_FAST_EDCA_TO_8814B(x) ((x) & (~BITS_VO_FAST_EDCA_TO_8814B))
#define BIT_GET_VO_FAST_EDCA_TO_8814B(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO_8814B) & \
BIT_MASK_VO_FAST_EDCA_TO_8814B)
#define BIT_SET_VO_FAST_EDCA_TO_8814B(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO_8814B(x) | BIT_VO_FAST_EDCA_TO_8814B(v))
#define BIT_VO_THRESHOLD_SEL_8814B BIT(7)
#define BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8814B 0
#define BIT_MASK_VO_FAST_EDCA_PKT_TH_8814B 0x7f
#define BIT_VO_FAST_EDCA_PKT_TH_8814B(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_PKT_TH_8814B) \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8814B)
#define BITS_VO_FAST_EDCA_PKT_TH_8814B \
(BIT_MASK_VO_FAST_EDCA_PKT_TH_8814B \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8814B)
#define BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8814B(x) \
((x) & (~BITS_VO_FAST_EDCA_PKT_TH_8814B))
#define BIT_GET_VO_FAST_EDCA_PKT_TH_8814B(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8814B) & \
BIT_MASK_VO_FAST_EDCA_PKT_TH_8814B)
#define BIT_SET_VO_FAST_EDCA_PKT_TH_8814B(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8814B(x) | \
BIT_VO_FAST_EDCA_PKT_TH_8814B(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING_8814B */
#define BIT_SHIFT_BK_FAST_EDCA_TO_8814B 24
#define BIT_MASK_BK_FAST_EDCA_TO_8814B 0xff
#define BIT_BK_FAST_EDCA_TO_8814B(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_TO_8814B) \
<< BIT_SHIFT_BK_FAST_EDCA_TO_8814B)
#define BITS_BK_FAST_EDCA_TO_8814B \
(BIT_MASK_BK_FAST_EDCA_TO_8814B << BIT_SHIFT_BK_FAST_EDCA_TO_8814B)
#define BIT_CLEAR_BK_FAST_EDCA_TO_8814B(x) ((x) & (~BITS_BK_FAST_EDCA_TO_8814B))
#define BIT_GET_BK_FAST_EDCA_TO_8814B(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_TO_8814B) & \
BIT_MASK_BK_FAST_EDCA_TO_8814B)
#define BIT_SET_BK_FAST_EDCA_TO_8814B(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_TO_8814B(x) | BIT_BK_FAST_EDCA_TO_8814B(v))
#define BIT_BK_THRESHOLD_SEL_8814B BIT(23)
#define BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8814B 16
#define BIT_MASK_BK_FAST_EDCA_PKT_TH_8814B 0x7f
#define BIT_BK_FAST_EDCA_PKT_TH_8814B(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_PKT_TH_8814B) \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8814B)
#define BITS_BK_FAST_EDCA_PKT_TH_8814B \
(BIT_MASK_BK_FAST_EDCA_PKT_TH_8814B \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8814B)
#define BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8814B(x) \
((x) & (~BITS_BK_FAST_EDCA_PKT_TH_8814B))
#define BIT_GET_BK_FAST_EDCA_PKT_TH_8814B(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8814B) & \
BIT_MASK_BK_FAST_EDCA_PKT_TH_8814B)
#define BIT_SET_BK_FAST_EDCA_PKT_TH_8814B(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8814B(x) | \
BIT_BK_FAST_EDCA_PKT_TH_8814B(v))
#define BIT_SHIFT_BE_FAST_EDCA_TO_8814B 8
#define BIT_MASK_BE_FAST_EDCA_TO_8814B 0xff
#define BIT_BE_FAST_EDCA_TO_8814B(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO_8814B) \
<< BIT_SHIFT_BE_FAST_EDCA_TO_8814B)
#define BITS_BE_FAST_EDCA_TO_8814B \
(BIT_MASK_BE_FAST_EDCA_TO_8814B << BIT_SHIFT_BE_FAST_EDCA_TO_8814B)
#define BIT_CLEAR_BE_FAST_EDCA_TO_8814B(x) ((x) & (~BITS_BE_FAST_EDCA_TO_8814B))
#define BIT_GET_BE_FAST_EDCA_TO_8814B(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO_8814B) & \
BIT_MASK_BE_FAST_EDCA_TO_8814B)
#define BIT_SET_BE_FAST_EDCA_TO_8814B(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO_8814B(x) | BIT_BE_FAST_EDCA_TO_8814B(v))
#define BIT_BE_THRESHOLD_SEL_8814B BIT(7)
#define BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8814B 0
#define BIT_MASK_BE_FAST_EDCA_PKT_TH_8814B 0x7f
#define BIT_BE_FAST_EDCA_PKT_TH_8814B(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_PKT_TH_8814B) \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8814B)
#define BITS_BE_FAST_EDCA_PKT_TH_8814B \
(BIT_MASK_BE_FAST_EDCA_PKT_TH_8814B \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8814B)
#define BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8814B(x) \
((x) & (~BITS_BE_FAST_EDCA_PKT_TH_8814B))
#define BIT_GET_BE_FAST_EDCA_PKT_TH_8814B(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8814B) & \
BIT_MASK_BE_FAST_EDCA_PKT_TH_8814B)
#define BIT_SET_BE_FAST_EDCA_PKT_TH_8814B(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8814B(x) | \
BIT_BE_FAST_EDCA_PKT_TH_8814B(v))
/* 2 REG_MACID_DROP_INFO_8814B */
#define BIT_SHIFT_MACID_DROP_INFO_8814B 0
#define BIT_MASK_MACID_DROP_INFO_8814B 0xffffffffL
#define BIT_MACID_DROP_INFO_8814B(x) \
(((x) & BIT_MASK_MACID_DROP_INFO_8814B) \
<< BIT_SHIFT_MACID_DROP_INFO_8814B)
#define BITS_MACID_DROP_INFO_8814B \
(BIT_MASK_MACID_DROP_INFO_8814B << BIT_SHIFT_MACID_DROP_INFO_8814B)
#define BIT_CLEAR_MACID_DROP_INFO_8814B(x) ((x) & (~BITS_MACID_DROP_INFO_8814B))
#define BIT_GET_MACID_DROP_INFO_8814B(x) \
(((x) >> BIT_SHIFT_MACID_DROP_INFO_8814B) & \
BIT_MASK_MACID_DROP_INFO_8814B)
#define BIT_SET_MACID_DROP_INFO_8814B(x, v) \
(BIT_CLEAR_MACID_DROP_INFO_8814B(x) | BIT_MACID_DROP_INFO_8814B(v))
/* 2 REG_MACID_DROP_CTRL_8814B */
#define BIT_SHIFT_MACID_DROP_SEL_8814B 0
#define BIT_MASK_MACID_DROP_SEL_8814B 0x7
#define BIT_MACID_DROP_SEL_8814B(x) \
(((x) & BIT_MASK_MACID_DROP_SEL_8814B) \
<< BIT_SHIFT_MACID_DROP_SEL_8814B)
#define BITS_MACID_DROP_SEL_8814B \
(BIT_MASK_MACID_DROP_SEL_8814B << BIT_SHIFT_MACID_DROP_SEL_8814B)
#define BIT_CLEAR_MACID_DROP_SEL_8814B(x) ((x) & (~BITS_MACID_DROP_SEL_8814B))
#define BIT_GET_MACID_DROP_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MACID_DROP_SEL_8814B) & \
BIT_MASK_MACID_DROP_SEL_8814B)
#define BIT_SET_MACID_DROP_SEL_8814B(x, v) \
(BIT_CLEAR_MACID_DROP_SEL_8814B(x) | BIT_MACID_DROP_SEL_8814B(v))
/* 2 REG_MGQ_FIFO_WRITE_POINTER_8814B */
#define BIT_MGQ_FIFO_OV_8814B BIT(7)
#define BIT_MGQ_FIFO_WPTR_ERROR_8814B BIT(6)
#define BIT_EN_MGQ_FIFO_LIFETIME_8814B BIT(5)
#define BIT_SHIFT_MGQ_FIFO_WPTR_8814B 0
#define BIT_MASK_MGQ_FIFO_WPTR_8814B 0x1f
#define BIT_MGQ_FIFO_WPTR_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_WPTR_8814B) << BIT_SHIFT_MGQ_FIFO_WPTR_8814B)
#define BITS_MGQ_FIFO_WPTR_8814B \
(BIT_MASK_MGQ_FIFO_WPTR_8814B << BIT_SHIFT_MGQ_FIFO_WPTR_8814B)
#define BIT_CLEAR_MGQ_FIFO_WPTR_8814B(x) ((x) & (~BITS_MGQ_FIFO_WPTR_8814B))
#define BIT_GET_MGQ_FIFO_WPTR_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_WPTR_8814B) & BIT_MASK_MGQ_FIFO_WPTR_8814B)
#define BIT_SET_MGQ_FIFO_WPTR_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_WPTR_8814B(x) | BIT_MGQ_FIFO_WPTR_8814B(v))
/* 2 REG_MGQ_FIFO_READ_POINTER_8814B */
#define BIT_SHIFT_MGQ_FIFO_SIZE_8814B 14
#define BIT_MASK_MGQ_FIFO_SIZE_8814B 0x3
#define BIT_MGQ_FIFO_SIZE_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_SIZE_8814B) << BIT_SHIFT_MGQ_FIFO_SIZE_8814B)
#define BITS_MGQ_FIFO_SIZE_8814B \
(BIT_MASK_MGQ_FIFO_SIZE_8814B << BIT_SHIFT_MGQ_FIFO_SIZE_8814B)
#define BIT_CLEAR_MGQ_FIFO_SIZE_8814B(x) ((x) & (~BITS_MGQ_FIFO_SIZE_8814B))
#define BIT_GET_MGQ_FIFO_SIZE_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_SIZE_8814B) & BIT_MASK_MGQ_FIFO_SIZE_8814B)
#define BIT_SET_MGQ_FIFO_SIZE_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_SIZE_8814B(x) | BIT_MGQ_FIFO_SIZE_8814B(v))
#define BIT_MGQ_FIFO_PAUSE_8814B BIT(13)
#define BIT_SHIFT_MGQ_FIFO_RPTR_8814B 8
#define BIT_MASK_MGQ_FIFO_RPTR_8814B 0x1f
#define BIT_MGQ_FIFO_RPTR_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_RPTR_8814B) << BIT_SHIFT_MGQ_FIFO_RPTR_8814B)
#define BITS_MGQ_FIFO_RPTR_8814B \
(BIT_MASK_MGQ_FIFO_RPTR_8814B << BIT_SHIFT_MGQ_FIFO_RPTR_8814B)
#define BIT_CLEAR_MGQ_FIFO_RPTR_8814B(x) ((x) & (~BITS_MGQ_FIFO_RPTR_8814B))
#define BIT_GET_MGQ_FIFO_RPTR_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_RPTR_8814B) & BIT_MASK_MGQ_FIFO_RPTR_8814B)
#define BIT_SET_MGQ_FIFO_RPTR_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_RPTR_8814B(x) | BIT_MGQ_FIFO_RPTR_8814B(v))
/* 2 REG_MGQ_FIFO_ENABLE_8814B */
#define BIT_MGQ_FIFO_EN_V1_8814B BIT(15)
#define BIT_SHIFT_MGQ_FIFO_PG_SIZE_8814B 12
#define BIT_MASK_MGQ_FIFO_PG_SIZE_8814B 0x7
#define BIT_MGQ_FIFO_PG_SIZE_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_PG_SIZE_8814B) \
<< BIT_SHIFT_MGQ_FIFO_PG_SIZE_8814B)
#define BITS_MGQ_FIFO_PG_SIZE_8814B \
(BIT_MASK_MGQ_FIFO_PG_SIZE_8814B << BIT_SHIFT_MGQ_FIFO_PG_SIZE_8814B)
#define BIT_CLEAR_MGQ_FIFO_PG_SIZE_8814B(x) \
((x) & (~BITS_MGQ_FIFO_PG_SIZE_8814B))
#define BIT_GET_MGQ_FIFO_PG_SIZE_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PG_SIZE_8814B) & \
BIT_MASK_MGQ_FIFO_PG_SIZE_8814B)
#define BIT_SET_MGQ_FIFO_PG_SIZE_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_PG_SIZE_8814B(x) | BIT_MGQ_FIFO_PG_SIZE_8814B(v))
#define BIT_SHIFT_MGQ_FIFO_START_PG_8814B 0
#define BIT_MASK_MGQ_FIFO_START_PG_8814B 0xfff
#define BIT_MGQ_FIFO_START_PG_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_START_PG_8814B) \
<< BIT_SHIFT_MGQ_FIFO_START_PG_8814B)
#define BITS_MGQ_FIFO_START_PG_8814B \
(BIT_MASK_MGQ_FIFO_START_PG_8814B << BIT_SHIFT_MGQ_FIFO_START_PG_8814B)
#define BIT_CLEAR_MGQ_FIFO_START_PG_8814B(x) \
((x) & (~BITS_MGQ_FIFO_START_PG_8814B))
#define BIT_GET_MGQ_FIFO_START_PG_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_START_PG_8814B) & \
BIT_MASK_MGQ_FIFO_START_PG_8814B)
#define BIT_SET_MGQ_FIFO_START_PG_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_START_PG_8814B(x) | BIT_MGQ_FIFO_START_PG_8814B(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_MASK_8814B */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8814B 0
#define BIT_MASK_MGQ_FIFO_REL_INT_MASK_8814B 0xffff
#define BIT_MGQ_FIFO_REL_INT_MASK_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_MASK_8814B) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8814B)
#define BITS_MGQ_FIFO_REL_INT_MASK_8814B \
(BIT_MASK_MGQ_FIFO_REL_INT_MASK_8814B \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8814B)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_MASK_8814B(x) \
((x) & (~BITS_MGQ_FIFO_REL_INT_MASK_8814B))
#define BIT_GET_MGQ_FIFO_REL_INT_MASK_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8814B) & \
BIT_MASK_MGQ_FIFO_REL_INT_MASK_8814B)
#define BIT_SET_MGQ_FIFO_REL_INT_MASK_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_MASK_8814B(x) | \
BIT_MGQ_FIFO_REL_INT_MASK_8814B(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_FLAG_8814B */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8814B 0
#define BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8814B 0xffff
#define BIT_MGQ_FIFO_REL_INT_FLAG_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8814B) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8814B)
#define BITS_MGQ_FIFO_REL_INT_FLAG_8814B \
(BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8814B \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8814B)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG_8814B(x) \
((x) & (~BITS_MGQ_FIFO_REL_INT_FLAG_8814B))
#define BIT_GET_MGQ_FIFO_REL_INT_FLAG_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8814B) & \
BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8814B)
#define BIT_SET_MGQ_FIFO_REL_INT_FLAG_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG_8814B(x) | \
BIT_MGQ_FIFO_REL_INT_FLAG_8814B(v))
/* 2 REG_MGQ_FIFO_VALID_MAP_8814B */
#define BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8814B 0
#define BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8814B 0xffff
#define BIT_MGQ_FIFO_PKT_VALID_MAP_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8814B) \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8814B)
#define BITS_MGQ_FIFO_PKT_VALID_MAP_8814B \
(BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8814B \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8814B)
#define BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP_8814B(x) \
((x) & (~BITS_MGQ_FIFO_PKT_VALID_MAP_8814B))
#define BIT_GET_MGQ_FIFO_PKT_VALID_MAP_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8814B) & \
BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8814B)
#define BIT_SET_MGQ_FIFO_PKT_VALID_MAP_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP_8814B(x) | \
BIT_MGQ_FIFO_PKT_VALID_MAP_8814B(v))
/* 2 REG_MGQ_FIFO_LIFETIME_8814B */
#define BIT_SHIFT_MGQ_FIFO_LIFETIME_8814B 0
#define BIT_MASK_MGQ_FIFO_LIFETIME_8814B 0xffff
#define BIT_MGQ_FIFO_LIFETIME_8814B(x) \
(((x) & BIT_MASK_MGQ_FIFO_LIFETIME_8814B) \
<< BIT_SHIFT_MGQ_FIFO_LIFETIME_8814B)
#define BITS_MGQ_FIFO_LIFETIME_8814B \
(BIT_MASK_MGQ_FIFO_LIFETIME_8814B << BIT_SHIFT_MGQ_FIFO_LIFETIME_8814B)
#define BIT_CLEAR_MGQ_FIFO_LIFETIME_8814B(x) \
((x) & (~BITS_MGQ_FIFO_LIFETIME_8814B))
#define BIT_GET_MGQ_FIFO_LIFETIME_8814B(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_LIFETIME_8814B) & \
BIT_MASK_MGQ_FIFO_LIFETIME_8814B)
#define BIT_SET_MGQ_FIFO_LIFETIME_8814B(x, v) \
(BIT_CLEAR_MGQ_FIFO_LIFETIME_8814B(x) | BIT_MGQ_FIFO_LIFETIME_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PKT_TRANS_8814B */
#define BIT_SHIFT_IE_DESC_OFFSET_8814B 16
#define BIT_MASK_IE_DESC_OFFSET_8814B 0x1ff
#define BIT_IE_DESC_OFFSET_8814B(x) \
(((x) & BIT_MASK_IE_DESC_OFFSET_8814B) \
<< BIT_SHIFT_IE_DESC_OFFSET_8814B)
#define BITS_IE_DESC_OFFSET_8814B \
(BIT_MASK_IE_DESC_OFFSET_8814B << BIT_SHIFT_IE_DESC_OFFSET_8814B)
#define BIT_CLEAR_IE_DESC_OFFSET_8814B(x) ((x) & (~BITS_IE_DESC_OFFSET_8814B))
#define BIT_GET_IE_DESC_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_IE_DESC_OFFSET_8814B) & \
BIT_MASK_IE_DESC_OFFSET_8814B)
#define BIT_SET_IE_DESC_OFFSET_8814B(x, v) \
(BIT_CLEAR_IE_DESC_OFFSET_8814B(x) | BIT_IE_DESC_OFFSET_8814B(v))
#define BIT_DIS_FWCMD_PATH_ERRCHK_8814B BIT(13)
#define BIT_MAC_HDR_CONVERT_EN_8814B BIT(12)
#define BIT_TXDESC_TRANS_EN_8814B BIT(8)
#define BIT_PKT_TRANS_ERRINT_EN_8814B BIT(7)
#define BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL_8814B 4
#define BIT_MASK_PKT_TRANS_ERR_MACID_SEL_8814B 0x3
#define BIT_PKT_TRANS_ERR_MACID_SEL_8814B(x) \
(((x) & BIT_MASK_PKT_TRANS_ERR_MACID_SEL_8814B) \
<< BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL_8814B)
#define BITS_PKT_TRANS_ERR_MACID_SEL_8814B \
(BIT_MASK_PKT_TRANS_ERR_MACID_SEL_8814B \
<< BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL_8814B)
#define BIT_CLEAR_PKT_TRANS_ERR_MACID_SEL_8814B(x) \
((x) & (~BITS_PKT_TRANS_ERR_MACID_SEL_8814B))
#define BIT_GET_PKT_TRANS_ERR_MACID_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PKT_TRANS_ERR_MACID_SEL_8814B) & \
BIT_MASK_PKT_TRANS_ERR_MACID_SEL_8814B)
#define BIT_SET_PKT_TRANS_ERR_MACID_SEL_8814B(x, v) \
(BIT_CLEAR_PKT_TRANS_ERR_MACID_SEL_8814B(x) | \
BIT_PKT_TRANS_ERR_MACID_SEL_8814B(v))
#define BIT_PKT_TRANS_IEINIT_ERR_8814B BIT(3)
#define BIT_PKT_TRANS_IENUM_ERR_8814B BIT(2)
#define BIT_PKT_TRANS_IECNT_ERR1_8814B BIT(1)
#define BIT_PKT_TRANS_IECNT_ERR0_8814B BIT(0)
/* 2 REG_SHCUT_LLC_ETH_TYPE0_8814B */
/* 2 REG_SHCUT_LLC_ETH_TYPE1_8814B */
#define BIT_SHIFT_SHCUT_MHDR_OFFSET_8814B 16
#define BIT_MASK_SHCUT_MHDR_OFFSET_8814B 0x1ff
#define BIT_SHCUT_MHDR_OFFSET_8814B(x) \
(((x) & BIT_MASK_SHCUT_MHDR_OFFSET_8814B) \
<< BIT_SHIFT_SHCUT_MHDR_OFFSET_8814B)
#define BITS_SHCUT_MHDR_OFFSET_8814B \
(BIT_MASK_SHCUT_MHDR_OFFSET_8814B << BIT_SHIFT_SHCUT_MHDR_OFFSET_8814B)
#define BIT_CLEAR_SHCUT_MHDR_OFFSET_8814B(x) \
((x) & (~BITS_SHCUT_MHDR_OFFSET_8814B))
#define BIT_GET_SHCUT_MHDR_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_SHCUT_MHDR_OFFSET_8814B) & \
BIT_MASK_SHCUT_MHDR_OFFSET_8814B)
#define BIT_SET_SHCUT_MHDR_OFFSET_8814B(x, v) \
(BIT_CLEAR_SHCUT_MHDR_OFFSET_8814B(x) | BIT_SHCUT_MHDR_OFFSET_8814B(v))
/* 2 REG_SHCUT_LLC_OUI0_8814B */
/* 2 REG_SHCUT_LLC_OUI1_8814B */
/* 2 REG_SHCUT_LLC_OUI2_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_PKT_TRANS_ERR_MACID_8814B 0
#define BIT_MASK_PKT_TRANS_ERR_MACID_8814B 0xffffffffL
#define BIT_PKT_TRANS_ERR_MACID_8814B(x) \
(((x) & BIT_MASK_PKT_TRANS_ERR_MACID_8814B) \
<< BIT_SHIFT_PKT_TRANS_ERR_MACID_8814B)
#define BITS_PKT_TRANS_ERR_MACID_8814B \
(BIT_MASK_PKT_TRANS_ERR_MACID_8814B \
<< BIT_SHIFT_PKT_TRANS_ERR_MACID_8814B)
#define BIT_CLEAR_PKT_TRANS_ERR_MACID_8814B(x) \
((x) & (~BITS_PKT_TRANS_ERR_MACID_8814B))
#define BIT_GET_PKT_TRANS_ERR_MACID_8814B(x) \
(((x) >> BIT_SHIFT_PKT_TRANS_ERR_MACID_8814B) & \
BIT_MASK_PKT_TRANS_ERR_MACID_8814B)
#define BIT_SET_PKT_TRANS_ERR_MACID_8814B(x, v) \
(BIT_CLEAR_PKT_TRANS_ERR_MACID_8814B(x) | \
BIT_PKT_TRANS_ERR_MACID_8814B(v))
/* 2 REG_FWCMDQ_CTRL_8814B */
#define BIT_FW_RELEASEPKT_POLLING_8814B BIT(31)
#define BIT_SHIFT_FWCMDQ_RELEASE_HEAD_8814B 16
#define BIT_MASK_FWCMDQ_RELEASE_HEAD_8814B 0xfff
#define BIT_FWCMDQ_RELEASE_HEAD_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_RELEASE_HEAD_8814B) \
<< BIT_SHIFT_FWCMDQ_RELEASE_HEAD_8814B)
#define BITS_FWCMDQ_RELEASE_HEAD_8814B \
(BIT_MASK_FWCMDQ_RELEASE_HEAD_8814B \
<< BIT_SHIFT_FWCMDQ_RELEASE_HEAD_8814B)
#define BIT_CLEAR_FWCMDQ_RELEASE_HEAD_8814B(x) \
((x) & (~BITS_FWCMDQ_RELEASE_HEAD_8814B))
#define BIT_GET_FWCMDQ_RELEASE_HEAD_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_RELEASE_HEAD_8814B) & \
BIT_MASK_FWCMDQ_RELEASE_HEAD_8814B)
#define BIT_SET_FWCMDQ_RELEASE_HEAD_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_RELEASE_HEAD_8814B(x) | \
BIT_FWCMDQ_RELEASE_HEAD_8814B(v))
#define BIT_FW_GETPKTT_POLLING_8814B BIT(15)
#define BIT_SHIFT_FWCMDQ_H_8814B 0
#define BIT_MASK_FWCMDQ_H_8814B 0xfff
#define BIT_FWCMDQ_H_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_H_8814B) << BIT_SHIFT_FWCMDQ_H_8814B)
#define BITS_FWCMDQ_H_8814B \
(BIT_MASK_FWCMDQ_H_8814B << BIT_SHIFT_FWCMDQ_H_8814B)
#define BIT_CLEAR_FWCMDQ_H_8814B(x) ((x) & (~BITS_FWCMDQ_H_8814B))
#define BIT_GET_FWCMDQ_H_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_H_8814B) & BIT_MASK_FWCMDQ_H_8814B)
#define BIT_SET_FWCMDQ_H_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_H_8814B(x) | BIT_FWCMDQ_H_8814B(v))
/* 2 REG_FWCMDQ_PAGE_8814B */
#define BIT_SHIFT_FWCMDQ_TOTAL_PAGE_8814B 16
#define BIT_MASK_FWCMDQ_TOTAL_PAGE_8814B 0xfff
#define BIT_FWCMDQ_TOTAL_PAGE_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_TOTAL_PAGE_8814B) \
<< BIT_SHIFT_FWCMDQ_TOTAL_PAGE_8814B)
#define BITS_FWCMDQ_TOTAL_PAGE_8814B \
(BIT_MASK_FWCMDQ_TOTAL_PAGE_8814B << BIT_SHIFT_FWCMDQ_TOTAL_PAGE_8814B)
#define BIT_CLEAR_FWCMDQ_TOTAL_PAGE_8814B(x) \
((x) & (~BITS_FWCMDQ_TOTAL_PAGE_8814B))
#define BIT_GET_FWCMDQ_TOTAL_PAGE_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TOTAL_PAGE_8814B) & \
BIT_MASK_FWCMDQ_TOTAL_PAGE_8814B)
#define BIT_SET_FWCMDQ_TOTAL_PAGE_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_TOTAL_PAGE_8814B(x) | BIT_FWCMDQ_TOTAL_PAGE_8814B(v))
#define BIT_SHIFT_FWCMDQ_QUEUE_PAGE_8814B 0
#define BIT_MASK_FWCMDQ_QUEUE_PAGE_8814B 0xfff
#define BIT_FWCMDQ_QUEUE_PAGE_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_QUEUE_PAGE_8814B) \
<< BIT_SHIFT_FWCMDQ_QUEUE_PAGE_8814B)
#define BITS_FWCMDQ_QUEUE_PAGE_8814B \
(BIT_MASK_FWCMDQ_QUEUE_PAGE_8814B << BIT_SHIFT_FWCMDQ_QUEUE_PAGE_8814B)
#define BIT_CLEAR_FWCMDQ_QUEUE_PAGE_8814B(x) \
((x) & (~BITS_FWCMDQ_QUEUE_PAGE_8814B))
#define BIT_GET_FWCMDQ_QUEUE_PAGE_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_QUEUE_PAGE_8814B) & \
BIT_MASK_FWCMDQ_QUEUE_PAGE_8814B)
#define BIT_SET_FWCMDQ_QUEUE_PAGE_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_QUEUE_PAGE_8814B(x) | BIT_FWCMDQ_QUEUE_PAGE_8814B(v))
/* 2 REG_FWCMDQ_INFO_8814B */
#define BIT_FWCMD_READY_8814B BIT(31)
#define BIT_FWCMDQ_OVERFLOW_8814B BIT(30)
#define BIT_FWCMDQ_UNDERFLOW_8814B BIT(29)
#define BIT_FWCMDQ_RELEASE_MISS_8814B BIT(28)
#define BIT_SHIFT_FWCMDQ_TOTAL_PKT_8814B 16
#define BIT_MASK_FWCMDQ_TOTAL_PKT_8814B 0xfff
#define BIT_FWCMDQ_TOTAL_PKT_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_TOTAL_PKT_8814B) \
<< BIT_SHIFT_FWCMDQ_TOTAL_PKT_8814B)
#define BITS_FWCMDQ_TOTAL_PKT_8814B \
(BIT_MASK_FWCMDQ_TOTAL_PKT_8814B << BIT_SHIFT_FWCMDQ_TOTAL_PKT_8814B)
#define BIT_CLEAR_FWCMDQ_TOTAL_PKT_8814B(x) \
((x) & (~BITS_FWCMDQ_TOTAL_PKT_8814B))
#define BIT_GET_FWCMDQ_TOTAL_PKT_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_TOTAL_PKT_8814B) & \
BIT_MASK_FWCMDQ_TOTAL_PKT_8814B)
#define BIT_SET_FWCMDQ_TOTAL_PKT_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_TOTAL_PKT_8814B(x) | BIT_FWCMDQ_TOTAL_PKT_8814B(v))
#define BIT_SHIFT_FWCMDQ_QUEUE_PKT_8814B 0
#define BIT_MASK_FWCMDQ_QUEUE_PKT_8814B 0xfff
#define BIT_FWCMDQ_QUEUE_PKT_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_QUEUE_PKT_8814B) \
<< BIT_SHIFT_FWCMDQ_QUEUE_PKT_8814B)
#define BITS_FWCMDQ_QUEUE_PKT_8814B \
(BIT_MASK_FWCMDQ_QUEUE_PKT_8814B << BIT_SHIFT_FWCMDQ_QUEUE_PKT_8814B)
#define BIT_CLEAR_FWCMDQ_QUEUE_PKT_8814B(x) \
((x) & (~BITS_FWCMDQ_QUEUE_PKT_8814B))
#define BIT_GET_FWCMDQ_QUEUE_PKT_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_QUEUE_PKT_8814B) & \
BIT_MASK_FWCMDQ_QUEUE_PKT_8814B)
#define BIT_SET_FWCMDQ_QUEUE_PKT_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_QUEUE_PKT_8814B(x) | BIT_FWCMDQ_QUEUE_PKT_8814B(v))
/* 2 REG_FWCMDQ_HOLD_PKTNUM_8814B */
#define BIT_SHIFT_FWCMDQ_HOLD__PKTNUM_8814B 0
#define BIT_MASK_FWCMDQ_HOLD__PKTNUM_8814B 0xfff
#define BIT_FWCMDQ_HOLD__PKTNUM_8814B(x) \
(((x) & BIT_MASK_FWCMDQ_HOLD__PKTNUM_8814B) \
<< BIT_SHIFT_FWCMDQ_HOLD__PKTNUM_8814B)
#define BITS_FWCMDQ_HOLD__PKTNUM_8814B \
(BIT_MASK_FWCMDQ_HOLD__PKTNUM_8814B \
<< BIT_SHIFT_FWCMDQ_HOLD__PKTNUM_8814B)
#define BIT_CLEAR_FWCMDQ_HOLD__PKTNUM_8814B(x) \
((x) & (~BITS_FWCMDQ_HOLD__PKTNUM_8814B))
#define BIT_GET_FWCMDQ_HOLD__PKTNUM_8814B(x) \
(((x) >> BIT_SHIFT_FWCMDQ_HOLD__PKTNUM_8814B) & \
BIT_MASK_FWCMDQ_HOLD__PKTNUM_8814B)
#define BIT_SET_FWCMDQ_HOLD__PKTNUM_8814B(x, v) \
(BIT_CLEAR_FWCMDQ_HOLD__PKTNUM_8814B(x) | \
BIT_FWCMDQ_HOLD__PKTNUM_8814B(v))
/* 2 REG_MU_TX_CTRL_8814B */
#define BIT_SEARCH_DONE_RDY_8814B BIT(31)
#define BIT_MU_EN_8814B BIT(30)
#define BIT_MU_SECONDARY_WAITMODE_EN_8814B BIT(29)
#define BIT_MU_BB_SCORE_EN_8814B BIT(28)
#define BIT_MU_SECONDARY_ANT_COUNT_EN_8814B BIT(27)
#define BIT_MUARB_SEARCH_ERR_EN_8814B BIT(26)
#define BIT_SHIFT_DIS_SU_TXBF_8814B 16
#define BIT_MASK_DIS_SU_TXBF_8814B 0x3f
#define BIT_DIS_SU_TXBF_8814B(x) \
(((x) & BIT_MASK_DIS_SU_TXBF_8814B) << BIT_SHIFT_DIS_SU_TXBF_8814B)
#define BITS_DIS_SU_TXBF_8814B \
(BIT_MASK_DIS_SU_TXBF_8814B << BIT_SHIFT_DIS_SU_TXBF_8814B)
#define BIT_CLEAR_DIS_SU_TXBF_8814B(x) ((x) & (~BITS_DIS_SU_TXBF_8814B))
#define BIT_GET_DIS_SU_TXBF_8814B(x) \
(((x) >> BIT_SHIFT_DIS_SU_TXBF_8814B) & BIT_MASK_DIS_SU_TXBF_8814B)
#define BIT_SET_DIS_SU_TXBF_8814B(x, v) \
(BIT_CLEAR_DIS_SU_TXBF_8814B(x) | BIT_DIS_SU_TXBF_8814B(v))
#define BIT_SHIFT_MU_RL_8814B 12
#define BIT_MASK_MU_RL_8814B 0xf
#define BIT_MU_RL_8814B(x) \
(((x) & BIT_MASK_MU_RL_8814B) << BIT_SHIFT_MU_RL_8814B)
#define BITS_MU_RL_8814B (BIT_MASK_MU_RL_8814B << BIT_SHIFT_MU_RL_8814B)
#define BIT_CLEAR_MU_RL_8814B(x) ((x) & (~BITS_MU_RL_8814B))
#define BIT_GET_MU_RL_8814B(x) \
(((x) >> BIT_SHIFT_MU_RL_8814B) & BIT_MASK_MU_RL_8814B)
#define BIT_SET_MU_RL_8814B(x, v) \
(BIT_CLEAR_MU_RL_8814B(x) | BIT_MU_RL_8814B(v))
#define BIT_SHIFT_MU_TAB_SEL_8814B 8
#define BIT_MASK_MU_TAB_SEL_8814B 0xf
#define BIT_MU_TAB_SEL_8814B(x) \
(((x) & BIT_MASK_MU_TAB_SEL_8814B) << BIT_SHIFT_MU_TAB_SEL_8814B)
#define BITS_MU_TAB_SEL_8814B \
(BIT_MASK_MU_TAB_SEL_8814B << BIT_SHIFT_MU_TAB_SEL_8814B)
#define BIT_CLEAR_MU_TAB_SEL_8814B(x) ((x) & (~BITS_MU_TAB_SEL_8814B))
#define BIT_GET_MU_TAB_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MU_TAB_SEL_8814B) & BIT_MASK_MU_TAB_SEL_8814B)
#define BIT_SET_MU_TAB_SEL_8814B(x, v) \
(BIT_CLEAR_MU_TAB_SEL_8814B(x) | BIT_MU_TAB_SEL_8814B(v))
#define BIT_SHIFT_MU_TAB_VALID_8814B 0
#define BIT_MASK_MU_TAB_VALID_8814B 0x3f
#define BIT_MU_TAB_VALID_8814B(x) \
(((x) & BIT_MASK_MU_TAB_VALID_8814B) << BIT_SHIFT_MU_TAB_VALID_8814B)
#define BITS_MU_TAB_VALID_8814B \
(BIT_MASK_MU_TAB_VALID_8814B << BIT_SHIFT_MU_TAB_VALID_8814B)
#define BIT_CLEAR_MU_TAB_VALID_8814B(x) ((x) & (~BITS_MU_TAB_VALID_8814B))
#define BIT_GET_MU_TAB_VALID_8814B(x) \
(((x) >> BIT_SHIFT_MU_TAB_VALID_8814B) & BIT_MASK_MU_TAB_VALID_8814B)
#define BIT_SET_MU_TAB_VALID_8814B(x, v) \
(BIT_CLEAR_MU_TAB_VALID_8814B(x) | BIT_MU_TAB_VALID_8814B(v))
/* 2 REG_MU_STA_GID_VLD_8814B */
#define BIT_SHIFT_MU_STA_GTAB_VALID_8814B 0
#define BIT_MASK_MU_STA_GTAB_VALID_8814B 0xffffffffL
#define BIT_MU_STA_GTAB_VALID_8814B(x) \
(((x) & BIT_MASK_MU_STA_GTAB_VALID_8814B) \
<< BIT_SHIFT_MU_STA_GTAB_VALID_8814B)
#define BITS_MU_STA_GTAB_VALID_8814B \
(BIT_MASK_MU_STA_GTAB_VALID_8814B << BIT_SHIFT_MU_STA_GTAB_VALID_8814B)
#define BIT_CLEAR_MU_STA_GTAB_VALID_8814B(x) \
((x) & (~BITS_MU_STA_GTAB_VALID_8814B))
#define BIT_GET_MU_STA_GTAB_VALID_8814B(x) \
(((x) >> BIT_SHIFT_MU_STA_GTAB_VALID_8814B) & \
BIT_MASK_MU_STA_GTAB_VALID_8814B)
#define BIT_SET_MU_STA_GTAB_VALID_8814B(x, v) \
(BIT_CLEAR_MU_STA_GTAB_VALID_8814B(x) | BIT_MU_STA_GTAB_VALID_8814B(v))
/* 2 REG_MU_STA_USER_POS_INFO_8814B */
#define BIT_SHIFT_MU_STA_GTAB_POSITION_L_8814B 0
#define BIT_MASK_MU_STA_GTAB_POSITION_L_8814B 0xffffffffL
#define BIT_MU_STA_GTAB_POSITION_L_8814B(x) \
(((x) & BIT_MASK_MU_STA_GTAB_POSITION_L_8814B) \
<< BIT_SHIFT_MU_STA_GTAB_POSITION_L_8814B)
#define BITS_MU_STA_GTAB_POSITION_L_8814B \
(BIT_MASK_MU_STA_GTAB_POSITION_L_8814B \
<< BIT_SHIFT_MU_STA_GTAB_POSITION_L_8814B)
#define BIT_CLEAR_MU_STA_GTAB_POSITION_L_8814B(x) \
((x) & (~BITS_MU_STA_GTAB_POSITION_L_8814B))
#define BIT_GET_MU_STA_GTAB_POSITION_L_8814B(x) \
(((x) >> BIT_SHIFT_MU_STA_GTAB_POSITION_L_8814B) & \
BIT_MASK_MU_STA_GTAB_POSITION_L_8814B)
#define BIT_SET_MU_STA_GTAB_POSITION_L_8814B(x, v) \
(BIT_CLEAR_MU_STA_GTAB_POSITION_L_8814B(x) | \
BIT_MU_STA_GTAB_POSITION_L_8814B(v))
/* 2 REG_MU_STA_USER_POS_INFO_H_8814B */
#define BIT_SHIFT_MU_STA_GTAB_POSITION_H_8814B 0
#define BIT_MASK_MU_STA_GTAB_POSITION_H_8814B 0xffffffffL
#define BIT_MU_STA_GTAB_POSITION_H_8814B(x) \
(((x) & BIT_MASK_MU_STA_GTAB_POSITION_H_8814B) \
<< BIT_SHIFT_MU_STA_GTAB_POSITION_H_8814B)
#define BITS_MU_STA_GTAB_POSITION_H_8814B \
(BIT_MASK_MU_STA_GTAB_POSITION_H_8814B \
<< BIT_SHIFT_MU_STA_GTAB_POSITION_H_8814B)
#define BIT_CLEAR_MU_STA_GTAB_POSITION_H_8814B(x) \
((x) & (~BITS_MU_STA_GTAB_POSITION_H_8814B))
#define BIT_GET_MU_STA_GTAB_POSITION_H_8814B(x) \
(((x) >> BIT_SHIFT_MU_STA_GTAB_POSITION_H_8814B) & \
BIT_MASK_MU_STA_GTAB_POSITION_H_8814B)
#define BIT_SET_MU_STA_GTAB_POSITION_H_8814B(x, v) \
(BIT_CLEAR_MU_STA_GTAB_POSITION_H_8814B(x) | \
BIT_MU_STA_GTAB_POSITION_H_8814B(v))
/* 2 REG_CHNL_INFO_CTRL_8814B */
#define BIT_CHNL_REF_RXNAV_8814B BIT(7)
#define BIT_CHNL_REF_VBON_8814B BIT(6)
#define BIT_CHNL_REF_EDCA_8814B BIT(5)
#define BIT_CHNL_REF_CCA_8814B BIT(4)
#define BIT_RST_CHNL_BUSY_8814B BIT(3)
#define BIT_RST_CHNL_IDLE_8814B BIT(2)
#define BIT_CHNL_INFO_RST_8814B BIT(1)
#define BIT_ATM_AIRTIME_EN_8814B BIT(0)
/* 2 REG_CHNL_IDLE_TIME_8814B */
#define BIT_SHIFT_CHNL_IDLE_TIME_8814B 0
#define BIT_MASK_CHNL_IDLE_TIME_8814B 0xffffffffL
#define BIT_CHNL_IDLE_TIME_8814B(x) \
(((x) & BIT_MASK_CHNL_IDLE_TIME_8814B) \
<< BIT_SHIFT_CHNL_IDLE_TIME_8814B)
#define BITS_CHNL_IDLE_TIME_8814B \
(BIT_MASK_CHNL_IDLE_TIME_8814B << BIT_SHIFT_CHNL_IDLE_TIME_8814B)
#define BIT_CLEAR_CHNL_IDLE_TIME_8814B(x) ((x) & (~BITS_CHNL_IDLE_TIME_8814B))
#define BIT_GET_CHNL_IDLE_TIME_8814B(x) \
(((x) >> BIT_SHIFT_CHNL_IDLE_TIME_8814B) & \
BIT_MASK_CHNL_IDLE_TIME_8814B)
#define BIT_SET_CHNL_IDLE_TIME_8814B(x, v) \
(BIT_CLEAR_CHNL_IDLE_TIME_8814B(x) | BIT_CHNL_IDLE_TIME_8814B(v))
/* 2 REG_CHNL_BUSY_TIME_8814B */
#define BIT_SHIFT_CHNL_BUSY_TIME_8814B 0
#define BIT_MASK_CHNL_BUSY_TIME_8814B 0xffffffffL
#define BIT_CHNL_BUSY_TIME_8814B(x) \
(((x) & BIT_MASK_CHNL_BUSY_TIME_8814B) \
<< BIT_SHIFT_CHNL_BUSY_TIME_8814B)
#define BITS_CHNL_BUSY_TIME_8814B \
(BIT_MASK_CHNL_BUSY_TIME_8814B << BIT_SHIFT_CHNL_BUSY_TIME_8814B)
#define BIT_CLEAR_CHNL_BUSY_TIME_8814B(x) ((x) & (~BITS_CHNL_BUSY_TIME_8814B))
#define BIT_GET_CHNL_BUSY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_CHNL_BUSY_TIME_8814B) & \
BIT_MASK_CHNL_BUSY_TIME_8814B)
#define BIT_SET_CHNL_BUSY_TIME_8814B(x, v) \
(BIT_CLEAR_CHNL_BUSY_TIME_8814B(x) | BIT_CHNL_BUSY_TIME_8814B(v))
/* 2 REG_MU_TRX_DBG_CNT_V1_8814B */
#define BIT_FORCE_SND_STS_EN_8814B BIT(31)
#define BIT_SHIFT_SND_STS_VALUE_8814B 24
#define BIT_MASK_SND_STS_VALUE_8814B 0x3f
#define BIT_SND_STS_VALUE_8814B(x) \
(((x) & BIT_MASK_SND_STS_VALUE_8814B) << BIT_SHIFT_SND_STS_VALUE_8814B)
#define BITS_SND_STS_VALUE_8814B \
(BIT_MASK_SND_STS_VALUE_8814B << BIT_SHIFT_SND_STS_VALUE_8814B)
#define BIT_CLEAR_SND_STS_VALUE_8814B(x) ((x) & (~BITS_SND_STS_VALUE_8814B))
#define BIT_GET_SND_STS_VALUE_8814B(x) \
(((x) >> BIT_SHIFT_SND_STS_VALUE_8814B) & BIT_MASK_SND_STS_VALUE_8814B)
#define BIT_SET_SND_STS_VALUE_8814B(x, v) \
(BIT_CLEAR_SND_STS_VALUE_8814B(x) | BIT_SND_STS_VALUE_8814B(v))
#define BIT_MU_DNGCNT_RST_8814B BIT(20)
#define BIT_SHIFT_MU_DNGCNT_SEL_8814B 16
#define BIT_MASK_MU_DNGCNT_SEL_8814B 0xf
#define BIT_MU_DNGCNT_SEL_8814B(x) \
(((x) & BIT_MASK_MU_DNGCNT_SEL_8814B) << BIT_SHIFT_MU_DNGCNT_SEL_8814B)
#define BITS_MU_DNGCNT_SEL_8814B \
(BIT_MASK_MU_DNGCNT_SEL_8814B << BIT_SHIFT_MU_DNGCNT_SEL_8814B)
#define BIT_CLEAR_MU_DNGCNT_SEL_8814B(x) ((x) & (~BITS_MU_DNGCNT_SEL_8814B))
#define BIT_GET_MU_DNGCNT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_SEL_8814B) & BIT_MASK_MU_DNGCNT_SEL_8814B)
#define BIT_SET_MU_DNGCNT_SEL_8814B(x, v) \
(BIT_CLEAR_MU_DNGCNT_SEL_8814B(x) | BIT_MU_DNGCNT_SEL_8814B(v))
#define BIT_SHIFT_MU_DNGCNT_8814B 0
#define BIT_MASK_MU_DNGCNT_8814B 0xffff
#define BIT_MU_DNGCNT_8814B(x) \
(((x) & BIT_MASK_MU_DNGCNT_8814B) << BIT_SHIFT_MU_DNGCNT_8814B)
#define BITS_MU_DNGCNT_8814B \
(BIT_MASK_MU_DNGCNT_8814B << BIT_SHIFT_MU_DNGCNT_8814B)
#define BIT_CLEAR_MU_DNGCNT_8814B(x) ((x) & (~BITS_MU_DNGCNT_8814B))
#define BIT_GET_MU_DNGCNT_8814B(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_8814B) & BIT_MASK_MU_DNGCNT_8814B)
#define BIT_SET_MU_DNGCNT_8814B(x, v) \
(BIT_CLEAR_MU_DNGCNT_8814B(x) | BIT_MU_DNGCNT_8814B(v))
/* 2 REG_SWPS_CTRL_8814B */
#define BIT_SHIFT_SWPS_RPT_LENGTH_8814B 8
#define BIT_MASK_SWPS_RPT_LENGTH_8814B 0x7f
#define BIT_SWPS_RPT_LENGTH_8814B(x) \
(((x) & BIT_MASK_SWPS_RPT_LENGTH_8814B) \
<< BIT_SHIFT_SWPS_RPT_LENGTH_8814B)
#define BITS_SWPS_RPT_LENGTH_8814B \
(BIT_MASK_SWPS_RPT_LENGTH_8814B << BIT_SHIFT_SWPS_RPT_LENGTH_8814B)
#define BIT_CLEAR_SWPS_RPT_LENGTH_8814B(x) ((x) & (~BITS_SWPS_RPT_LENGTH_8814B))
#define BIT_GET_SWPS_RPT_LENGTH_8814B(x) \
(((x) >> BIT_SHIFT_SWPS_RPT_LENGTH_8814B) & \
BIT_MASK_SWPS_RPT_LENGTH_8814B)
#define BIT_SET_SWPS_RPT_LENGTH_8814B(x, v) \
(BIT_CLEAR_SWPS_RPT_LENGTH_8814B(x) | BIT_SWPS_RPT_LENGTH_8814B(v))
#define BIT_SHIFT_MACID_SWPS_EN_SEL_8814B 2
#define BIT_MASK_MACID_SWPS_EN_SEL_8814B 0x3
#define BIT_MACID_SWPS_EN_SEL_8814B(x) \
(((x) & BIT_MASK_MACID_SWPS_EN_SEL_8814B) \
<< BIT_SHIFT_MACID_SWPS_EN_SEL_8814B)
#define BITS_MACID_SWPS_EN_SEL_8814B \
(BIT_MASK_MACID_SWPS_EN_SEL_8814B << BIT_SHIFT_MACID_SWPS_EN_SEL_8814B)
#define BIT_CLEAR_MACID_SWPS_EN_SEL_8814B(x) \
((x) & (~BITS_MACID_SWPS_EN_SEL_8814B))
#define BIT_GET_MACID_SWPS_EN_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MACID_SWPS_EN_SEL_8814B) & \
BIT_MASK_MACID_SWPS_EN_SEL_8814B)
#define BIT_SET_MACID_SWPS_EN_SEL_8814B(x, v) \
(BIT_CLEAR_MACID_SWPS_EN_SEL_8814B(x) | BIT_MACID_SWPS_EN_SEL_8814B(v))
#define BIT_SWPS_MANUALL_POLLING_8814B BIT(1)
#define BIT_SWPS_EN_8814B BIT(0)
/* 2 REG_SWPS_PKT_TH_8814B */
#define BIT_SHIFT_SWPS_PKT_TH_8814B 0
#define BIT_MASK_SWPS_PKT_TH_8814B 0xffff
#define BIT_SWPS_PKT_TH_8814B(x) \
(((x) & BIT_MASK_SWPS_PKT_TH_8814B) << BIT_SHIFT_SWPS_PKT_TH_8814B)
#define BITS_SWPS_PKT_TH_8814B \
(BIT_MASK_SWPS_PKT_TH_8814B << BIT_SHIFT_SWPS_PKT_TH_8814B)
#define BIT_CLEAR_SWPS_PKT_TH_8814B(x) ((x) & (~BITS_SWPS_PKT_TH_8814B))
#define BIT_GET_SWPS_PKT_TH_8814B(x) \
(((x) >> BIT_SHIFT_SWPS_PKT_TH_8814B) & BIT_MASK_SWPS_PKT_TH_8814B)
#define BIT_SET_SWPS_PKT_TH_8814B(x, v) \
(BIT_CLEAR_SWPS_PKT_TH_8814B(x) | BIT_SWPS_PKT_TH_8814B(v))
/* 2 REG_SWPS_TIME_TH_8814B */
#define BIT_SHIFT_SWPS_PSTIME_TH_8814B 16
#define BIT_MASK_SWPS_PSTIME_TH_8814B 0xffff
#define BIT_SWPS_PSTIME_TH_8814B(x) \
(((x) & BIT_MASK_SWPS_PSTIME_TH_8814B) \
<< BIT_SHIFT_SWPS_PSTIME_TH_8814B)
#define BITS_SWPS_PSTIME_TH_8814B \
(BIT_MASK_SWPS_PSTIME_TH_8814B << BIT_SHIFT_SWPS_PSTIME_TH_8814B)
#define BIT_CLEAR_SWPS_PSTIME_TH_8814B(x) ((x) & (~BITS_SWPS_PSTIME_TH_8814B))
#define BIT_GET_SWPS_PSTIME_TH_8814B(x) \
(((x) >> BIT_SHIFT_SWPS_PSTIME_TH_8814B) & \
BIT_MASK_SWPS_PSTIME_TH_8814B)
#define BIT_SET_SWPS_PSTIME_TH_8814B(x, v) \
(BIT_CLEAR_SWPS_PSTIME_TH_8814B(x) | BIT_SWPS_PSTIME_TH_8814B(v))
#define BIT_SHIFT_SWPS_TIME_TH_8814B 0
#define BIT_MASK_SWPS_TIME_TH_8814B 0xffff
#define BIT_SWPS_TIME_TH_8814B(x) \
(((x) & BIT_MASK_SWPS_TIME_TH_8814B) << BIT_SHIFT_SWPS_TIME_TH_8814B)
#define BITS_SWPS_TIME_TH_8814B \
(BIT_MASK_SWPS_TIME_TH_8814B << BIT_SHIFT_SWPS_TIME_TH_8814B)
#define BIT_CLEAR_SWPS_TIME_TH_8814B(x) ((x) & (~BITS_SWPS_TIME_TH_8814B))
#define BIT_GET_SWPS_TIME_TH_8814B(x) \
(((x) >> BIT_SHIFT_SWPS_TIME_TH_8814B) & BIT_MASK_SWPS_TIME_TH_8814B)
#define BIT_SET_SWPS_TIME_TH_8814B(x, v) \
(BIT_CLEAR_SWPS_TIME_TH_8814B(x) | BIT_SWPS_TIME_TH_8814B(v))
/* 2 REG_MACID_SWPS_EN_8814B */
#define BIT_SHIFT_MACID_SWPS_EN_8814B 0
#define BIT_MASK_MACID_SWPS_EN_8814B 0xffffffffL
#define BIT_MACID_SWPS_EN_8814B(x) \
(((x) & BIT_MASK_MACID_SWPS_EN_8814B) << BIT_SHIFT_MACID_SWPS_EN_8814B)
#define BITS_MACID_SWPS_EN_8814B \
(BIT_MASK_MACID_SWPS_EN_8814B << BIT_SHIFT_MACID_SWPS_EN_8814B)
#define BIT_CLEAR_MACID_SWPS_EN_8814B(x) ((x) & (~BITS_MACID_SWPS_EN_8814B))
#define BIT_GET_MACID_SWPS_EN_8814B(x) \
(((x) >> BIT_SHIFT_MACID_SWPS_EN_8814B) & BIT_MASK_MACID_SWPS_EN_8814B)
#define BIT_SET_MACID_SWPS_EN_8814B(x, v) \
(BIT_CLEAR_MACID_SWPS_EN_8814B(x) | BIT_MACID_SWPS_EN_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_EDCA_VO_PARAM_8814B */
#define BIT_SHIFT_TXOPLIMIT_8814B 16
#define BIT_MASK_TXOPLIMIT_8814B 0x7ff
#define BIT_TXOPLIMIT_8814B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8814B) << BIT_SHIFT_TXOPLIMIT_8814B)
#define BITS_TXOPLIMIT_8814B \
(BIT_MASK_TXOPLIMIT_8814B << BIT_SHIFT_TXOPLIMIT_8814B)
#define BIT_CLEAR_TXOPLIMIT_8814B(x) ((x) & (~BITS_TXOPLIMIT_8814B))
#define BIT_GET_TXOPLIMIT_8814B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8814B) & BIT_MASK_TXOPLIMIT_8814B)
#define BIT_SET_TXOPLIMIT_8814B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8814B(x) | BIT_TXOPLIMIT_8814B(v))
#define BIT_SHIFT_CW_8814B 8
#define BIT_MASK_CW_8814B 0xff
#define BIT_CW_8814B(x) (((x) & BIT_MASK_CW_8814B) << BIT_SHIFT_CW_8814B)
#define BITS_CW_8814B (BIT_MASK_CW_8814B << BIT_SHIFT_CW_8814B)
#define BIT_CLEAR_CW_8814B(x) ((x) & (~BITS_CW_8814B))
#define BIT_GET_CW_8814B(x) (((x) >> BIT_SHIFT_CW_8814B) & BIT_MASK_CW_8814B)
#define BIT_SET_CW_8814B(x, v) (BIT_CLEAR_CW_8814B(x) | BIT_CW_8814B(v))
#define BIT_SHIFT_AIFS_8814B 0
#define BIT_MASK_AIFS_8814B 0xff
#define BIT_AIFS_8814B(x) (((x) & BIT_MASK_AIFS_8814B) << BIT_SHIFT_AIFS_8814B)
#define BITS_AIFS_8814B (BIT_MASK_AIFS_8814B << BIT_SHIFT_AIFS_8814B)
#define BIT_CLEAR_AIFS_8814B(x) ((x) & (~BITS_AIFS_8814B))
#define BIT_GET_AIFS_8814B(x) \
(((x) >> BIT_SHIFT_AIFS_8814B) & BIT_MASK_AIFS_8814B)
#define BIT_SET_AIFS_8814B(x, v) (BIT_CLEAR_AIFS_8814B(x) | BIT_AIFS_8814B(v))
/* 2 REG_EDCA_VI_PARAM_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXOPLIMIT_8814B 16
#define BIT_MASK_TXOPLIMIT_8814B 0x7ff
#define BIT_TXOPLIMIT_8814B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8814B) << BIT_SHIFT_TXOPLIMIT_8814B)
#define BITS_TXOPLIMIT_8814B \
(BIT_MASK_TXOPLIMIT_8814B << BIT_SHIFT_TXOPLIMIT_8814B)
#define BIT_CLEAR_TXOPLIMIT_8814B(x) ((x) & (~BITS_TXOPLIMIT_8814B))
#define BIT_GET_TXOPLIMIT_8814B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8814B) & BIT_MASK_TXOPLIMIT_8814B)
#define BIT_SET_TXOPLIMIT_8814B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8814B(x) | BIT_TXOPLIMIT_8814B(v))
#define BIT_SHIFT_CW_8814B 8
#define BIT_MASK_CW_8814B 0xff
#define BIT_CW_8814B(x) (((x) & BIT_MASK_CW_8814B) << BIT_SHIFT_CW_8814B)
#define BITS_CW_8814B (BIT_MASK_CW_8814B << BIT_SHIFT_CW_8814B)
#define BIT_CLEAR_CW_8814B(x) ((x) & (~BITS_CW_8814B))
#define BIT_GET_CW_8814B(x) (((x) >> BIT_SHIFT_CW_8814B) & BIT_MASK_CW_8814B)
#define BIT_SET_CW_8814B(x, v) (BIT_CLEAR_CW_8814B(x) | BIT_CW_8814B(v))
#define BIT_SHIFT_AIFS_8814B 0
#define BIT_MASK_AIFS_8814B 0xff
#define BIT_AIFS_8814B(x) (((x) & BIT_MASK_AIFS_8814B) << BIT_SHIFT_AIFS_8814B)
#define BITS_AIFS_8814B (BIT_MASK_AIFS_8814B << BIT_SHIFT_AIFS_8814B)
#define BIT_CLEAR_AIFS_8814B(x) ((x) & (~BITS_AIFS_8814B))
#define BIT_GET_AIFS_8814B(x) \
(((x) >> BIT_SHIFT_AIFS_8814B) & BIT_MASK_AIFS_8814B)
#define BIT_SET_AIFS_8814B(x, v) (BIT_CLEAR_AIFS_8814B(x) | BIT_AIFS_8814B(v))
/* 2 REG_EDCA_BE_PARAM_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXOPLIMIT_8814B 16
#define BIT_MASK_TXOPLIMIT_8814B 0x7ff
#define BIT_TXOPLIMIT_8814B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8814B) << BIT_SHIFT_TXOPLIMIT_8814B)
#define BITS_TXOPLIMIT_8814B \
(BIT_MASK_TXOPLIMIT_8814B << BIT_SHIFT_TXOPLIMIT_8814B)
#define BIT_CLEAR_TXOPLIMIT_8814B(x) ((x) & (~BITS_TXOPLIMIT_8814B))
#define BIT_GET_TXOPLIMIT_8814B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8814B) & BIT_MASK_TXOPLIMIT_8814B)
#define BIT_SET_TXOPLIMIT_8814B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8814B(x) | BIT_TXOPLIMIT_8814B(v))
#define BIT_SHIFT_CW_8814B 8
#define BIT_MASK_CW_8814B 0xff
#define BIT_CW_8814B(x) (((x) & BIT_MASK_CW_8814B) << BIT_SHIFT_CW_8814B)
#define BITS_CW_8814B (BIT_MASK_CW_8814B << BIT_SHIFT_CW_8814B)
#define BIT_CLEAR_CW_8814B(x) ((x) & (~BITS_CW_8814B))
#define BIT_GET_CW_8814B(x) (((x) >> BIT_SHIFT_CW_8814B) & BIT_MASK_CW_8814B)
#define BIT_SET_CW_8814B(x, v) (BIT_CLEAR_CW_8814B(x) | BIT_CW_8814B(v))
#define BIT_SHIFT_AIFS_8814B 0
#define BIT_MASK_AIFS_8814B 0xff
#define BIT_AIFS_8814B(x) (((x) & BIT_MASK_AIFS_8814B) << BIT_SHIFT_AIFS_8814B)
#define BITS_AIFS_8814B (BIT_MASK_AIFS_8814B << BIT_SHIFT_AIFS_8814B)
#define BIT_CLEAR_AIFS_8814B(x) ((x) & (~BITS_AIFS_8814B))
#define BIT_GET_AIFS_8814B(x) \
(((x) >> BIT_SHIFT_AIFS_8814B) & BIT_MASK_AIFS_8814B)
#define BIT_SET_AIFS_8814B(x, v) (BIT_CLEAR_AIFS_8814B(x) | BIT_AIFS_8814B(v))
/* 2 REG_EDCA_BK_PARAM_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_TXOPLIMIT_8814B 16
#define BIT_MASK_TXOPLIMIT_8814B 0x7ff
#define BIT_TXOPLIMIT_8814B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8814B) << BIT_SHIFT_TXOPLIMIT_8814B)
#define BITS_TXOPLIMIT_8814B \
(BIT_MASK_TXOPLIMIT_8814B << BIT_SHIFT_TXOPLIMIT_8814B)
#define BIT_CLEAR_TXOPLIMIT_8814B(x) ((x) & (~BITS_TXOPLIMIT_8814B))
#define BIT_GET_TXOPLIMIT_8814B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8814B) & BIT_MASK_TXOPLIMIT_8814B)
#define BIT_SET_TXOPLIMIT_8814B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8814B(x) | BIT_TXOPLIMIT_8814B(v))
#define BIT_SHIFT_CW_8814B 8
#define BIT_MASK_CW_8814B 0xff
#define BIT_CW_8814B(x) (((x) & BIT_MASK_CW_8814B) << BIT_SHIFT_CW_8814B)
#define BITS_CW_8814B (BIT_MASK_CW_8814B << BIT_SHIFT_CW_8814B)
#define BIT_CLEAR_CW_8814B(x) ((x) & (~BITS_CW_8814B))
#define BIT_GET_CW_8814B(x) (((x) >> BIT_SHIFT_CW_8814B) & BIT_MASK_CW_8814B)
#define BIT_SET_CW_8814B(x, v) (BIT_CLEAR_CW_8814B(x) | BIT_CW_8814B(v))
#define BIT_SHIFT_AIFS_8814B 0
#define BIT_MASK_AIFS_8814B 0xff
#define BIT_AIFS_8814B(x) (((x) & BIT_MASK_AIFS_8814B) << BIT_SHIFT_AIFS_8814B)
#define BITS_AIFS_8814B (BIT_MASK_AIFS_8814B << BIT_SHIFT_AIFS_8814B)
#define BIT_CLEAR_AIFS_8814B(x) ((x) & (~BITS_AIFS_8814B))
#define BIT_GET_AIFS_8814B(x) \
(((x) >> BIT_SHIFT_AIFS_8814B) & BIT_MASK_AIFS_8814B)
#define BIT_SET_AIFS_8814B(x, v) (BIT_CLEAR_AIFS_8814B(x) | BIT_AIFS_8814B(v))
/* 2 REG_BCNTCFG_8814B */
#define BIT_SHIFT_BCNCW_MAX_8814B 12
#define BIT_MASK_BCNCW_MAX_8814B 0xf
#define BIT_BCNCW_MAX_8814B(x) \
(((x) & BIT_MASK_BCNCW_MAX_8814B) << BIT_SHIFT_BCNCW_MAX_8814B)
#define BITS_BCNCW_MAX_8814B \
(BIT_MASK_BCNCW_MAX_8814B << BIT_SHIFT_BCNCW_MAX_8814B)
#define BIT_CLEAR_BCNCW_MAX_8814B(x) ((x) & (~BITS_BCNCW_MAX_8814B))
#define BIT_GET_BCNCW_MAX_8814B(x) \
(((x) >> BIT_SHIFT_BCNCW_MAX_8814B) & BIT_MASK_BCNCW_MAX_8814B)
#define BIT_SET_BCNCW_MAX_8814B(x, v) \
(BIT_CLEAR_BCNCW_MAX_8814B(x) | BIT_BCNCW_MAX_8814B(v))
#define BIT_SHIFT_BCNCW_MIN_8814B 8
#define BIT_MASK_BCNCW_MIN_8814B 0xf
#define BIT_BCNCW_MIN_8814B(x) \
(((x) & BIT_MASK_BCNCW_MIN_8814B) << BIT_SHIFT_BCNCW_MIN_8814B)
#define BITS_BCNCW_MIN_8814B \
(BIT_MASK_BCNCW_MIN_8814B << BIT_SHIFT_BCNCW_MIN_8814B)
#define BIT_CLEAR_BCNCW_MIN_8814B(x) ((x) & (~BITS_BCNCW_MIN_8814B))
#define BIT_GET_BCNCW_MIN_8814B(x) \
(((x) >> BIT_SHIFT_BCNCW_MIN_8814B) & BIT_MASK_BCNCW_MIN_8814B)
#define BIT_SET_BCNCW_MIN_8814B(x, v) \
(BIT_CLEAR_BCNCW_MIN_8814B(x) | BIT_BCNCW_MIN_8814B(v))
#define BIT_SHIFT_BCNIFS_8814B 0
#define BIT_MASK_BCNIFS_8814B 0xff
#define BIT_BCNIFS_8814B(x) \
(((x) & BIT_MASK_BCNIFS_8814B) << BIT_SHIFT_BCNIFS_8814B)
#define BITS_BCNIFS_8814B (BIT_MASK_BCNIFS_8814B << BIT_SHIFT_BCNIFS_8814B)
#define BIT_CLEAR_BCNIFS_8814B(x) ((x) & (~BITS_BCNIFS_8814B))
#define BIT_GET_BCNIFS_8814B(x) \
(((x) >> BIT_SHIFT_BCNIFS_8814B) & BIT_MASK_BCNIFS_8814B)
#define BIT_SET_BCNIFS_8814B(x, v) \
(BIT_CLEAR_BCNIFS_8814B(x) | BIT_BCNIFS_8814B(v))
/* 2 REG_PIFS_8814B */
#define BIT_SHIFT_PIFS_8814B 0
#define BIT_MASK_PIFS_8814B 0xff
#define BIT_PIFS_8814B(x) (((x) & BIT_MASK_PIFS_8814B) << BIT_SHIFT_PIFS_8814B)
#define BITS_PIFS_8814B (BIT_MASK_PIFS_8814B << BIT_SHIFT_PIFS_8814B)
#define BIT_CLEAR_PIFS_8814B(x) ((x) & (~BITS_PIFS_8814B))
#define BIT_GET_PIFS_8814B(x) \
(((x) >> BIT_SHIFT_PIFS_8814B) & BIT_MASK_PIFS_8814B)
#define BIT_SET_PIFS_8814B(x, v) (BIT_CLEAR_PIFS_8814B(x) | BIT_PIFS_8814B(v))
/* 2 REG_RDG_PIFS_8814B */
#define BIT_SHIFT_RDG_PIFS_8814B 0
#define BIT_MASK_RDG_PIFS_8814B 0xff
#define BIT_RDG_PIFS_8814B(x) \
(((x) & BIT_MASK_RDG_PIFS_8814B) << BIT_SHIFT_RDG_PIFS_8814B)
#define BITS_RDG_PIFS_8814B \
(BIT_MASK_RDG_PIFS_8814B << BIT_SHIFT_RDG_PIFS_8814B)
#define BIT_CLEAR_RDG_PIFS_8814B(x) ((x) & (~BITS_RDG_PIFS_8814B))
#define BIT_GET_RDG_PIFS_8814B(x) \
(((x) >> BIT_SHIFT_RDG_PIFS_8814B) & BIT_MASK_RDG_PIFS_8814B)
#define BIT_SET_RDG_PIFS_8814B(x, v) \
(BIT_CLEAR_RDG_PIFS_8814B(x) | BIT_RDG_PIFS_8814B(v))
/* 2 REG_SIFS_8814B */
#define BIT_SHIFT_SIFS_OFDM_TRX_8814B 24
#define BIT_MASK_SIFS_OFDM_TRX_8814B 0xff
#define BIT_SIFS_OFDM_TRX_8814B(x) \
(((x) & BIT_MASK_SIFS_OFDM_TRX_8814B) << BIT_SHIFT_SIFS_OFDM_TRX_8814B)
#define BITS_SIFS_OFDM_TRX_8814B \
(BIT_MASK_SIFS_OFDM_TRX_8814B << BIT_SHIFT_SIFS_OFDM_TRX_8814B)
#define BIT_CLEAR_SIFS_OFDM_TRX_8814B(x) ((x) & (~BITS_SIFS_OFDM_TRX_8814B))
#define BIT_GET_SIFS_OFDM_TRX_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_TRX_8814B) & BIT_MASK_SIFS_OFDM_TRX_8814B)
#define BIT_SET_SIFS_OFDM_TRX_8814B(x, v) \
(BIT_CLEAR_SIFS_OFDM_TRX_8814B(x) | BIT_SIFS_OFDM_TRX_8814B(v))
#define BIT_SHIFT_SIFS_CCK_TRX_8814B 16
#define BIT_MASK_SIFS_CCK_TRX_8814B 0xff
#define BIT_SIFS_CCK_TRX_8814B(x) \
(((x) & BIT_MASK_SIFS_CCK_TRX_8814B) << BIT_SHIFT_SIFS_CCK_TRX_8814B)
#define BITS_SIFS_CCK_TRX_8814B \
(BIT_MASK_SIFS_CCK_TRX_8814B << BIT_SHIFT_SIFS_CCK_TRX_8814B)
#define BIT_CLEAR_SIFS_CCK_TRX_8814B(x) ((x) & (~BITS_SIFS_CCK_TRX_8814B))
#define BIT_GET_SIFS_CCK_TRX_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_TRX_8814B) & BIT_MASK_SIFS_CCK_TRX_8814B)
#define BIT_SET_SIFS_CCK_TRX_8814B(x, v) \
(BIT_CLEAR_SIFS_CCK_TRX_8814B(x) | BIT_SIFS_CCK_TRX_8814B(v))
#define BIT_SHIFT_SIFS_OFDM_CTX_8814B 8
#define BIT_MASK_SIFS_OFDM_CTX_8814B 0xff
#define BIT_SIFS_OFDM_CTX_8814B(x) \
(((x) & BIT_MASK_SIFS_OFDM_CTX_8814B) << BIT_SHIFT_SIFS_OFDM_CTX_8814B)
#define BITS_SIFS_OFDM_CTX_8814B \
(BIT_MASK_SIFS_OFDM_CTX_8814B << BIT_SHIFT_SIFS_OFDM_CTX_8814B)
#define BIT_CLEAR_SIFS_OFDM_CTX_8814B(x) ((x) & (~BITS_SIFS_OFDM_CTX_8814B))
#define BIT_GET_SIFS_OFDM_CTX_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_CTX_8814B) & BIT_MASK_SIFS_OFDM_CTX_8814B)
#define BIT_SET_SIFS_OFDM_CTX_8814B(x, v) \
(BIT_CLEAR_SIFS_OFDM_CTX_8814B(x) | BIT_SIFS_OFDM_CTX_8814B(v))
#define BIT_SHIFT_SIFS_CCK_CTX_8814B 0
#define BIT_MASK_SIFS_CCK_CTX_8814B 0xff
#define BIT_SIFS_CCK_CTX_8814B(x) \
(((x) & BIT_MASK_SIFS_CCK_CTX_8814B) << BIT_SHIFT_SIFS_CCK_CTX_8814B)
#define BITS_SIFS_CCK_CTX_8814B \
(BIT_MASK_SIFS_CCK_CTX_8814B << BIT_SHIFT_SIFS_CCK_CTX_8814B)
#define BIT_CLEAR_SIFS_CCK_CTX_8814B(x) ((x) & (~BITS_SIFS_CCK_CTX_8814B))
#define BIT_GET_SIFS_CCK_CTX_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_CTX_8814B) & BIT_MASK_SIFS_CCK_CTX_8814B)
#define BIT_SET_SIFS_CCK_CTX_8814B(x, v) \
(BIT_CLEAR_SIFS_CCK_CTX_8814B(x) | BIT_SIFS_CCK_CTX_8814B(v))
/* 2 REG_FORCE_BCN_IFS_V1_8814B */
#define BIT_SHIFT_FORCE_BCN_IFS_8814B 0
#define BIT_MASK_FORCE_BCN_IFS_8814B 0xff
#define BIT_FORCE_BCN_IFS_8814B(x) \
(((x) & BIT_MASK_FORCE_BCN_IFS_8814B) << BIT_SHIFT_FORCE_BCN_IFS_8814B)
#define BITS_FORCE_BCN_IFS_8814B \
(BIT_MASK_FORCE_BCN_IFS_8814B << BIT_SHIFT_FORCE_BCN_IFS_8814B)
#define BIT_CLEAR_FORCE_BCN_IFS_8814B(x) ((x) & (~BITS_FORCE_BCN_IFS_8814B))
#define BIT_GET_FORCE_BCN_IFS_8814B(x) \
(((x) >> BIT_SHIFT_FORCE_BCN_IFS_8814B) & BIT_MASK_FORCE_BCN_IFS_8814B)
#define BIT_SET_FORCE_BCN_IFS_8814B(x, v) \
(BIT_CLEAR_FORCE_BCN_IFS_8814B(x) | BIT_FORCE_BCN_IFS_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_AGGR_BREAK_TIME_8814B */
#define BIT_SHIFT_AGGR_BK_TIME_8814B 0
#define BIT_MASK_AGGR_BK_TIME_8814B 0xff
#define BIT_AGGR_BK_TIME_8814B(x) \
(((x) & BIT_MASK_AGGR_BK_TIME_8814B) << BIT_SHIFT_AGGR_BK_TIME_8814B)
#define BITS_AGGR_BK_TIME_8814B \
(BIT_MASK_AGGR_BK_TIME_8814B << BIT_SHIFT_AGGR_BK_TIME_8814B)
#define BIT_CLEAR_AGGR_BK_TIME_8814B(x) ((x) & (~BITS_AGGR_BK_TIME_8814B))
#define BIT_GET_AGGR_BK_TIME_8814B(x) \
(((x) >> BIT_SHIFT_AGGR_BK_TIME_8814B) & BIT_MASK_AGGR_BK_TIME_8814B)
#define BIT_SET_AGGR_BK_TIME_8814B(x, v) \
(BIT_CLEAR_AGGR_BK_TIME_8814B(x) | BIT_AGGR_BK_TIME_8814B(v))
/* 2 REG_SLOT_8814B */
#define BIT_SHIFT_SLOT_8814B 0
#define BIT_MASK_SLOT_8814B 0xff
#define BIT_SLOT_8814B(x) (((x) & BIT_MASK_SLOT_8814B) << BIT_SHIFT_SLOT_8814B)
#define BITS_SLOT_8814B (BIT_MASK_SLOT_8814B << BIT_SHIFT_SLOT_8814B)
#define BIT_CLEAR_SLOT_8814B(x) ((x) & (~BITS_SLOT_8814B))
#define BIT_GET_SLOT_8814B(x) \
(((x) >> BIT_SHIFT_SLOT_8814B) & BIT_MASK_SLOT_8814B)
#define BIT_SET_SLOT_8814B(x, v) (BIT_CLEAR_SLOT_8814B(x) | BIT_SLOT_8814B(v))
/* 2 REG_EDCA_CPUMGQ_PARAM_8814B */
#define BIT_SHIFT_CW_V1_8814B 8
#define BIT_MASK_CW_V1_8814B 0xff
#define BIT_CW_V1_8814B(x) \
(((x) & BIT_MASK_CW_V1_8814B) << BIT_SHIFT_CW_V1_8814B)
#define BITS_CW_V1_8814B (BIT_MASK_CW_V1_8814B << BIT_SHIFT_CW_V1_8814B)
#define BIT_CLEAR_CW_V1_8814B(x) ((x) & (~BITS_CW_V1_8814B))
#define BIT_GET_CW_V1_8814B(x) \
(((x) >> BIT_SHIFT_CW_V1_8814B) & BIT_MASK_CW_V1_8814B)
#define BIT_SET_CW_V1_8814B(x, v) \
(BIT_CLEAR_CW_V1_8814B(x) | BIT_CW_V1_8814B(v))
#define BIT_SHIFT_AIFS_V1_8814B 0
#define BIT_MASK_AIFS_V1_8814B 0xff
#define BIT_AIFS_V1_8814B(x) \
(((x) & BIT_MASK_AIFS_V1_8814B) << BIT_SHIFT_AIFS_V1_8814B)
#define BITS_AIFS_V1_8814B (BIT_MASK_AIFS_V1_8814B << BIT_SHIFT_AIFS_V1_8814B)
#define BIT_CLEAR_AIFS_V1_8814B(x) ((x) & (~BITS_AIFS_V1_8814B))
#define BIT_GET_AIFS_V1_8814B(x) \
(((x) >> BIT_SHIFT_AIFS_V1_8814B) & BIT_MASK_AIFS_V1_8814B)
#define BIT_SET_AIFS_V1_8814B(x, v) \
(BIT_CLEAR_AIFS_V1_8814B(x) | BIT_AIFS_V1_8814B(v))
/* 2 REG_CPUMGQ_PAUSE_8814B */
#define BIT_MAC_STOP_CPUMGQ_V1_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TX_PTCL_CTRL_8814B */
#define BIT_DIS_EDCCA_8814B BIT(15)
#define BIT_DIS_CCA_8814B BIT(14)
#define BIT_LSIG_TXOP_TXCMD_NAV_8814B BIT(13)
#define BIT_SIFS_BK_EN_8814B BIT(12)
#define BIT_SHIFT_TXQ_NAV_MSK_8814B 8
#define BIT_MASK_TXQ_NAV_MSK_8814B 0xf
#define BIT_TXQ_NAV_MSK_8814B(x) \
(((x) & BIT_MASK_TXQ_NAV_MSK_8814B) << BIT_SHIFT_TXQ_NAV_MSK_8814B)
#define BITS_TXQ_NAV_MSK_8814B \
(BIT_MASK_TXQ_NAV_MSK_8814B << BIT_SHIFT_TXQ_NAV_MSK_8814B)
#define BIT_CLEAR_TXQ_NAV_MSK_8814B(x) ((x) & (~BITS_TXQ_NAV_MSK_8814B))
#define BIT_GET_TXQ_NAV_MSK_8814B(x) \
(((x) >> BIT_SHIFT_TXQ_NAV_MSK_8814B) & BIT_MASK_TXQ_NAV_MSK_8814B)
#define BIT_SET_TXQ_NAV_MSK_8814B(x, v) \
(BIT_CLEAR_TXQ_NAV_MSK_8814B(x) | BIT_TXQ_NAV_MSK_8814B(v))
#define BIT_DIS_CW_8814B BIT(7)
#define BIT_NAV_END_TXOP_8814B BIT(6)
#define BIT_RDG_END_TXOP_8814B BIT(5)
#define BIT_AC_INBCN_HOLD_8814B BIT(4)
#define BIT_MGTQ_TXOP_EN_8814B BIT(3)
#define BIT_MGTQ_RTSMF_EN_8814B BIT(2)
#define BIT_HIQ_RTSMF_EN_8814B BIT(1)
#define BIT_BCN_RTSMF_EN_8814B BIT(0)
/* 2 REG_TXPAUSE_8814B */
#define BIT_STOP_BCN_HI_MGT_8814B BIT(7)
#define BIT_MAC_STOPBCNQ_8814B BIT(6)
#define BIT_MAC_STOPHIQ_8814B BIT(5)
#define BIT_MAC_STOPMGQ_8814B BIT(4)
#define BIT_MAC_STOPBK_8814B BIT(3)
#define BIT_MAC_STOPBE_8814B BIT(2)
#define BIT_MAC_STOPVI_8814B BIT(1)
#define BIT_MAC_STOPVO_8814B BIT(0)
/* 2 REG_DIS_TXREQ_CLR_8814B */
#define BIT_DIS_BT_CCA_8814B BIT(7)
#define BIT_DIS_TXREQ_CLR_HI_8814B BIT(5)
#define BIT_DIS_TXREQ_CLR_MGQ_8814B BIT(4)
#define BIT_DIS_TXREQ_CLR_VO_8814B BIT(3)
#define BIT_DIS_TXREQ_CLR_VI_8814B BIT(2)
#define BIT_DIS_TXREQ_CLR_BE_8814B BIT(1)
#define BIT_DIS_TXREQ_CLR_BK_8814B BIT(0)
/* 2 REG_RD_CTRL_8814B */
#define BIT_EN_CLR_TXREQ_INCCA_8814B BIT(15)
#define BIT_DIS_TX_OVER_BCNQ_8814B BIT(14)
#define BIT_EN_BCNERR_INCCCA_8814B BIT(13)
#define BIT_EDCCA_MSK_CNTDOWN_EN_8814B BIT(11)
#define BIT_DIS_TXOP_CFE_8814B BIT(10)
#define BIT_DIS_LSIG_CFE_8814B BIT(9)
#define BIT_BKQ_RD_INIT_EN_8814B BIT(7)
#define BIT_BEQ_RD_INIT_EN_8814B BIT(6)
#define BIT_VIQ_RD_INIT_EN_8814B BIT(5)
#define BIT_VOQ_RD_INIT_EN_8814B BIT(4)
#define BIT_BKQ_RD_RESP_EN_8814B BIT(3)
#define BIT_BEQ_RD_RESP_EN_8814B BIT(2)
#define BIT_VIQ_RD_RESP_EN_8814B BIT(1)
#define BIT_VOQ_RD_RESP_EN_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PKT_LIFETIME_CTRL_8814B */
#define BIT_EN_P2P_CTWND1_8814B BIT(23)
#define BIT_EN_BKF_CLR_TXREQ_8814B BIT(22)
#define BIT_EN_BCN_TX_BTCCA_8814B BIT(20)
#define BIT_DIS_PKT_TX_ATIM_8814B BIT(19)
#define BIT_DIS_BCN_DIS_CTN_8814B BIT(18)
#define BIT_EN_NAVEND_RST_TXOP_8814B BIT(17)
#define BIT_EN_FILTER_CCA_8814B BIT(16)
#define BIT_SHIFT_CCA_FILTER_THRS_8814B 8
#define BIT_MASK_CCA_FILTER_THRS_8814B 0xff
#define BIT_CCA_FILTER_THRS_8814B(x) \
(((x) & BIT_MASK_CCA_FILTER_THRS_8814B) \
<< BIT_SHIFT_CCA_FILTER_THRS_8814B)
#define BITS_CCA_FILTER_THRS_8814B \
(BIT_MASK_CCA_FILTER_THRS_8814B << BIT_SHIFT_CCA_FILTER_THRS_8814B)
#define BIT_CLEAR_CCA_FILTER_THRS_8814B(x) ((x) & (~BITS_CCA_FILTER_THRS_8814B))
#define BIT_GET_CCA_FILTER_THRS_8814B(x) \
(((x) >> BIT_SHIFT_CCA_FILTER_THRS_8814B) & \
BIT_MASK_CCA_FILTER_THRS_8814B)
#define BIT_SET_CCA_FILTER_THRS_8814B(x, v) \
(BIT_CLEAR_CCA_FILTER_THRS_8814B(x) | BIT_CCA_FILTER_THRS_8814B(v))
#define BIT_SHIFT_EDCCA_THRS_8814B 0
#define BIT_MASK_EDCCA_THRS_8814B 0xff
#define BIT_EDCCA_THRS_8814B(x) \
(((x) & BIT_MASK_EDCCA_THRS_8814B) << BIT_SHIFT_EDCCA_THRS_8814B)
#define BITS_EDCCA_THRS_8814B \
(BIT_MASK_EDCCA_THRS_8814B << BIT_SHIFT_EDCCA_THRS_8814B)
#define BIT_CLEAR_EDCCA_THRS_8814B(x) ((x) & (~BITS_EDCCA_THRS_8814B))
#define BIT_GET_EDCCA_THRS_8814B(x) \
(((x) >> BIT_SHIFT_EDCCA_THRS_8814B) & BIT_MASK_EDCCA_THRS_8814B)
#define BIT_SET_EDCCA_THRS_8814B(x, v) \
(BIT_CLEAR_EDCCA_THRS_8814B(x) | BIT_EDCCA_THRS_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TXOP_LIMIT_CTRL_8814B */
#define BIT_SHIFT_TXOP_TBTT_CNT_8814B 24
#define BIT_MASK_TXOP_TBTT_CNT_8814B 0xff
#define BIT_TXOP_TBTT_CNT_8814B(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_8814B) << BIT_SHIFT_TXOP_TBTT_CNT_8814B)
#define BITS_TXOP_TBTT_CNT_8814B \
(BIT_MASK_TXOP_TBTT_CNT_8814B << BIT_SHIFT_TXOP_TBTT_CNT_8814B)
#define BIT_CLEAR_TXOP_TBTT_CNT_8814B(x) ((x) & (~BITS_TXOP_TBTT_CNT_8814B))
#define BIT_GET_TXOP_TBTT_CNT_8814B(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_8814B) & BIT_MASK_TXOP_TBTT_CNT_8814B)
#define BIT_SET_TXOP_TBTT_CNT_8814B(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_8814B(x) | BIT_TXOP_TBTT_CNT_8814B(v))
#define BIT_SHIFT_TXOP_TBTT_CNT_SEL_8814B 20
#define BIT_MASK_TXOP_TBTT_CNT_SEL_8814B 0xf
#define BIT_TXOP_TBTT_CNT_SEL_8814B(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_SEL_8814B) \
<< BIT_SHIFT_TXOP_TBTT_CNT_SEL_8814B)
#define BITS_TXOP_TBTT_CNT_SEL_8814B \
(BIT_MASK_TXOP_TBTT_CNT_SEL_8814B << BIT_SHIFT_TXOP_TBTT_CNT_SEL_8814B)
#define BIT_CLEAR_TXOP_TBTT_CNT_SEL_8814B(x) \
((x) & (~BITS_TXOP_TBTT_CNT_SEL_8814B))
#define BIT_GET_TXOP_TBTT_CNT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_SEL_8814B) & \
BIT_MASK_TXOP_TBTT_CNT_SEL_8814B)
#define BIT_SET_TXOP_TBTT_CNT_SEL_8814B(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_SEL_8814B(x) | BIT_TXOP_TBTT_CNT_SEL_8814B(v))
#define BIT_SHIFT_TXOP_LMT_EN_8814B 16
#define BIT_MASK_TXOP_LMT_EN_8814B 0xf
#define BIT_TXOP_LMT_EN_8814B(x) \
(((x) & BIT_MASK_TXOP_LMT_EN_8814B) << BIT_SHIFT_TXOP_LMT_EN_8814B)
#define BITS_TXOP_LMT_EN_8814B \
(BIT_MASK_TXOP_LMT_EN_8814B << BIT_SHIFT_TXOP_LMT_EN_8814B)
#define BIT_CLEAR_TXOP_LMT_EN_8814B(x) ((x) & (~BITS_TXOP_LMT_EN_8814B))
#define BIT_GET_TXOP_LMT_EN_8814B(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_EN_8814B) & BIT_MASK_TXOP_LMT_EN_8814B)
#define BIT_SET_TXOP_LMT_EN_8814B(x, v) \
(BIT_CLEAR_TXOP_LMT_EN_8814B(x) | BIT_TXOP_LMT_EN_8814B(v))
#define BIT_SHIFT_TXOP_LMT_TX_TIME_8814B 8
#define BIT_MASK_TXOP_LMT_TX_TIME_8814B 0xff
#define BIT_TXOP_LMT_TX_TIME_8814B(x) \
(((x) & BIT_MASK_TXOP_LMT_TX_TIME_8814B) \
<< BIT_SHIFT_TXOP_LMT_TX_TIME_8814B)
#define BITS_TXOP_LMT_TX_TIME_8814B \
(BIT_MASK_TXOP_LMT_TX_TIME_8814B << BIT_SHIFT_TXOP_LMT_TX_TIME_8814B)
#define BIT_CLEAR_TXOP_LMT_TX_TIME_8814B(x) \
((x) & (~BITS_TXOP_LMT_TX_TIME_8814B))
#define BIT_GET_TXOP_LMT_TX_TIME_8814B(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_TX_TIME_8814B) & \
BIT_MASK_TXOP_LMT_TX_TIME_8814B)
#define BIT_SET_TXOP_LMT_TX_TIME_8814B(x, v) \
(BIT_CLEAR_TXOP_LMT_TX_TIME_8814B(x) | BIT_TXOP_LMT_TX_TIME_8814B(v))
#define BIT_TXOP_CNT_TRIGGER_RESET_8814B BIT(7)
#define BIT_SHIFT_TXOP_LMT_PKT_NUM_8814B 0
#define BIT_MASK_TXOP_LMT_PKT_NUM_8814B 0x3f
#define BIT_TXOP_LMT_PKT_NUM_8814B(x) \
(((x) & BIT_MASK_TXOP_LMT_PKT_NUM_8814B) \
<< BIT_SHIFT_TXOP_LMT_PKT_NUM_8814B)
#define BITS_TXOP_LMT_PKT_NUM_8814B \
(BIT_MASK_TXOP_LMT_PKT_NUM_8814B << BIT_SHIFT_TXOP_LMT_PKT_NUM_8814B)
#define BIT_CLEAR_TXOP_LMT_PKT_NUM_8814B(x) \
((x) & (~BITS_TXOP_LMT_PKT_NUM_8814B))
#define BIT_GET_TXOP_LMT_PKT_NUM_8814B(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_PKT_NUM_8814B) & \
BIT_MASK_TXOP_LMT_PKT_NUM_8814B)
#define BIT_SET_TXOP_LMT_PKT_NUM_8814B(x, v) \
(BIT_CLEAR_TXOP_LMT_PKT_NUM_8814B(x) | BIT_TXOP_LMT_PKT_NUM_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_CCA_TXEN_CNT_8814B */
#define BIT_CCA_TXEN_CNT_SWITCH_8814B BIT(17)
#define BIT_CCA_TXEN_CNT_EN_8814B BIT(16)
#define BIT_SHIFT_CCA_TXEN_BIG_CNT_8814B 8
#define BIT_MASK_CCA_TXEN_BIG_CNT_8814B 0xff
#define BIT_CCA_TXEN_BIG_CNT_8814B(x) \
(((x) & BIT_MASK_CCA_TXEN_BIG_CNT_8814B) \
<< BIT_SHIFT_CCA_TXEN_BIG_CNT_8814B)
#define BITS_CCA_TXEN_BIG_CNT_8814B \
(BIT_MASK_CCA_TXEN_BIG_CNT_8814B << BIT_SHIFT_CCA_TXEN_BIG_CNT_8814B)
#define BIT_CLEAR_CCA_TXEN_BIG_CNT_8814B(x) \
((x) & (~BITS_CCA_TXEN_BIG_CNT_8814B))
#define BIT_GET_CCA_TXEN_BIG_CNT_8814B(x) \
(((x) >> BIT_SHIFT_CCA_TXEN_BIG_CNT_8814B) & \
BIT_MASK_CCA_TXEN_BIG_CNT_8814B)
#define BIT_SET_CCA_TXEN_BIG_CNT_8814B(x, v) \
(BIT_CLEAR_CCA_TXEN_BIG_CNT_8814B(x) | BIT_CCA_TXEN_BIG_CNT_8814B(v))
#define BIT_SHIFT_CCA_TXEN_SMALL_CNT_8814B 0
#define BIT_MASK_CCA_TXEN_SMALL_CNT_8814B 0xff
#define BIT_CCA_TXEN_SMALL_CNT_8814B(x) \
(((x) & BIT_MASK_CCA_TXEN_SMALL_CNT_8814B) \
<< BIT_SHIFT_CCA_TXEN_SMALL_CNT_8814B)
#define BITS_CCA_TXEN_SMALL_CNT_8814B \
(BIT_MASK_CCA_TXEN_SMALL_CNT_8814B \
<< BIT_SHIFT_CCA_TXEN_SMALL_CNT_8814B)
#define BIT_CLEAR_CCA_TXEN_SMALL_CNT_8814B(x) \
((x) & (~BITS_CCA_TXEN_SMALL_CNT_8814B))
#define BIT_GET_CCA_TXEN_SMALL_CNT_8814B(x) \
(((x) >> BIT_SHIFT_CCA_TXEN_SMALL_CNT_8814B) & \
BIT_MASK_CCA_TXEN_SMALL_CNT_8814B)
#define BIT_SET_CCA_TXEN_SMALL_CNT_8814B(x, v) \
(BIT_CLEAR_CCA_TXEN_SMALL_CNT_8814B(x) | \
BIT_CCA_TXEN_SMALL_CNT_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_MAX_INTER_COLLISION_8814B */
#define BIT_SHIFT_MAX_INTER_COLLISION_BK_8814B 24
#define BIT_MASK_MAX_INTER_COLLISION_BK_8814B 0xff
#define BIT_MAX_INTER_COLLISION_BK_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_BK_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_BK_8814B)
#define BITS_MAX_INTER_COLLISION_BK_8814B \
(BIT_MASK_MAX_INTER_COLLISION_BK_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_BK_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_BK_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_BK_8814B))
#define BIT_GET_MAX_INTER_COLLISION_BK_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_BK_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_BK_8814B)
#define BIT_SET_MAX_INTER_COLLISION_BK_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_BK_8814B(x) | \
BIT_MAX_INTER_COLLISION_BK_8814B(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_BE_8814B 16
#define BIT_MASK_MAX_INTER_COLLISION_BE_8814B 0xff
#define BIT_MAX_INTER_COLLISION_BE_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_BE_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_BE_8814B)
#define BITS_MAX_INTER_COLLISION_BE_8814B \
(BIT_MASK_MAX_INTER_COLLISION_BE_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_BE_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_BE_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_BE_8814B))
#define BIT_GET_MAX_INTER_COLLISION_BE_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_BE_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_BE_8814B)
#define BIT_SET_MAX_INTER_COLLISION_BE_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_BE_8814B(x) | \
BIT_MAX_INTER_COLLISION_BE_8814B(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_VI_8814B 8
#define BIT_MASK_MAX_INTER_COLLISION_VI_8814B 0xff
#define BIT_MAX_INTER_COLLISION_VI_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_VI_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_VI_8814B)
#define BITS_MAX_INTER_COLLISION_VI_8814B \
(BIT_MASK_MAX_INTER_COLLISION_VI_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_VI_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_VI_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_VI_8814B))
#define BIT_GET_MAX_INTER_COLLISION_VI_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_VI_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_VI_8814B)
#define BIT_SET_MAX_INTER_COLLISION_VI_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_VI_8814B(x) | \
BIT_MAX_INTER_COLLISION_VI_8814B(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_VO_8814B 0
#define BIT_MASK_MAX_INTER_COLLISION_VO_8814B 0xff
#define BIT_MAX_INTER_COLLISION_VO_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_VO_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_VO_8814B)
#define BITS_MAX_INTER_COLLISION_VO_8814B \
(BIT_MASK_MAX_INTER_COLLISION_VO_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_VO_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_VO_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_VO_8814B))
#define BIT_GET_MAX_INTER_COLLISION_VO_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_VO_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_VO_8814B)
#define BIT_SET_MAX_INTER_COLLISION_VO_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_VO_8814B(x) | \
BIT_MAX_INTER_COLLISION_VO_8814B(v))
/* 2 REG_MAX_INTER_COLLISION_CNT_8814B */
#define BIT_MAX_INTER_COLLISION_EN_8814B BIT(16)
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8814B 12
#define BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8814B 0xf
#define BIT_MAX_INTER_COLLISION_CNT_BK_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8814B)
#define BITS_MAX_INTER_COLLISION_CNT_BK_8814B \
(BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_BK_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_BK_8814B))
#define BIT_GET_MAX_INTER_COLLISION_CNT_BK_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8814B)
#define BIT_SET_MAX_INTER_COLLISION_CNT_BK_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_BK_8814B(x) | \
BIT_MAX_INTER_COLLISION_CNT_BK_8814B(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8814B 8
#define BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8814B 0xf
#define BIT_MAX_INTER_COLLISION_CNT_BE_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8814B)
#define BITS_MAX_INTER_COLLISION_CNT_BE_8814B \
(BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_BE_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_BE_8814B))
#define BIT_GET_MAX_INTER_COLLISION_CNT_BE_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8814B)
#define BIT_SET_MAX_INTER_COLLISION_CNT_BE_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_BE_8814B(x) | \
BIT_MAX_INTER_COLLISION_CNT_BE_8814B(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8814B 4
#define BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8814B 0xf
#define BIT_MAX_INTER_COLLISION_CNT_VI_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8814B)
#define BITS_MAX_INTER_COLLISION_CNT_VI_8814B \
(BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_VI_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_VI_8814B))
#define BIT_GET_MAX_INTER_COLLISION_CNT_VI_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8814B)
#define BIT_SET_MAX_INTER_COLLISION_CNT_VI_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_VI_8814B(x) | \
BIT_MAX_INTER_COLLISION_CNT_VI_8814B(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8814B 0
#define BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8814B 0xf
#define BIT_MAX_INTER_COLLISION_CNT_VO_8814B(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8814B) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8814B)
#define BITS_MAX_INTER_COLLISION_CNT_VO_8814B \
(BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8814B \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8814B)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_VO_8814B(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_VO_8814B))
#define BIT_GET_MAX_INTER_COLLISION_CNT_VO_8814B(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8814B) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8814B)
#define BIT_SET_MAX_INTER_COLLISION_CNT_VO_8814B(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_VO_8814B(x) | \
BIT_MAX_INTER_COLLISION_CNT_VO_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_RD_NAV_NXT_8814B */
#define BIT_SHIFT_RD_NAV_PROT_NXT_8814B 0
#define BIT_MASK_RD_NAV_PROT_NXT_8814B 0xffff
#define BIT_RD_NAV_PROT_NXT_8814B(x) \
(((x) & BIT_MASK_RD_NAV_PROT_NXT_8814B) \
<< BIT_SHIFT_RD_NAV_PROT_NXT_8814B)
#define BITS_RD_NAV_PROT_NXT_8814B \
(BIT_MASK_RD_NAV_PROT_NXT_8814B << BIT_SHIFT_RD_NAV_PROT_NXT_8814B)
#define BIT_CLEAR_RD_NAV_PROT_NXT_8814B(x) ((x) & (~BITS_RD_NAV_PROT_NXT_8814B))
#define BIT_GET_RD_NAV_PROT_NXT_8814B(x) \
(((x) >> BIT_SHIFT_RD_NAV_PROT_NXT_8814B) & \
BIT_MASK_RD_NAV_PROT_NXT_8814B)
#define BIT_SET_RD_NAV_PROT_NXT_8814B(x, v) \
(BIT_CLEAR_RD_NAV_PROT_NXT_8814B(x) | BIT_RD_NAV_PROT_NXT_8814B(v))
/* 2 REG_NAV_PROT_LEN_8814B */
#define BIT_SHIFT_NAV_PROT_LEN_8814B 0
#define BIT_MASK_NAV_PROT_LEN_8814B 0xffff
#define BIT_NAV_PROT_LEN_8814B(x) \
(((x) & BIT_MASK_NAV_PROT_LEN_8814B) << BIT_SHIFT_NAV_PROT_LEN_8814B)
#define BITS_NAV_PROT_LEN_8814B \
(BIT_MASK_NAV_PROT_LEN_8814B << BIT_SHIFT_NAV_PROT_LEN_8814B)
#define BIT_CLEAR_NAV_PROT_LEN_8814B(x) ((x) & (~BITS_NAV_PROT_LEN_8814B))
#define BIT_GET_NAV_PROT_LEN_8814B(x) \
(((x) >> BIT_SHIFT_NAV_PROT_LEN_8814B) & BIT_MASK_NAV_PROT_LEN_8814B)
#define BIT_SET_NAV_PROT_LEN_8814B(x, v) \
(BIT_CLEAR_NAV_PROT_LEN_8814B(x) | BIT_NAV_PROT_LEN_8814B(v))
/* 2 REG_FTM_PTT_8814B */
#define BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8814B 22
#define BIT_MASK_FTM_PTT_TSF_R2T_SEL_8814B 0x7
#define BIT_FTM_PTT_TSF_R2T_SEL_8814B(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_R2T_SEL_8814B) \
<< BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8814B)
#define BITS_FTM_PTT_TSF_R2T_SEL_8814B \
(BIT_MASK_FTM_PTT_TSF_R2T_SEL_8814B \
<< BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8814B)
#define BIT_CLEAR_FTM_PTT_TSF_R2T_SEL_8814B(x) \
((x) & (~BITS_FTM_PTT_TSF_R2T_SEL_8814B))
#define BIT_GET_FTM_PTT_TSF_R2T_SEL_8814B(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8814B) & \
BIT_MASK_FTM_PTT_TSF_R2T_SEL_8814B)
#define BIT_SET_FTM_PTT_TSF_R2T_SEL_8814B(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_R2T_SEL_8814B(x) | \
BIT_FTM_PTT_TSF_R2T_SEL_8814B(v))
#define BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8814B 19
#define BIT_MASK_FTM_PTT_TSF_T2R_SEL_8814B 0x7
#define BIT_FTM_PTT_TSF_T2R_SEL_8814B(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_T2R_SEL_8814B) \
<< BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8814B)
#define BITS_FTM_PTT_TSF_T2R_SEL_8814B \
(BIT_MASK_FTM_PTT_TSF_T2R_SEL_8814B \
<< BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8814B)
#define BIT_CLEAR_FTM_PTT_TSF_T2R_SEL_8814B(x) \
((x) & (~BITS_FTM_PTT_TSF_T2R_SEL_8814B))
#define BIT_GET_FTM_PTT_TSF_T2R_SEL_8814B(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8814B) & \
BIT_MASK_FTM_PTT_TSF_T2R_SEL_8814B)
#define BIT_SET_FTM_PTT_TSF_T2R_SEL_8814B(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_T2R_SEL_8814B(x) | \
BIT_FTM_PTT_TSF_T2R_SEL_8814B(v))
#define BIT_SHIFT_FTM_PTT_TSF_SEL_8814B 16
#define BIT_MASK_FTM_PTT_TSF_SEL_8814B 0x7
#define BIT_FTM_PTT_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_SEL_8814B) \
<< BIT_SHIFT_FTM_PTT_TSF_SEL_8814B)
#define BITS_FTM_PTT_TSF_SEL_8814B \
(BIT_MASK_FTM_PTT_TSF_SEL_8814B << BIT_SHIFT_FTM_PTT_TSF_SEL_8814B)
#define BIT_CLEAR_FTM_PTT_TSF_SEL_8814B(x) ((x) & (~BITS_FTM_PTT_TSF_SEL_8814B))
#define BIT_GET_FTM_PTT_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_SEL_8814B) & \
BIT_MASK_FTM_PTT_TSF_SEL_8814B)
#define BIT_SET_FTM_PTT_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_SEL_8814B(x) | BIT_FTM_PTT_TSF_SEL_8814B(v))
#define BIT_SHIFT_FTM_PTT_VALUE_8814B 0
#define BIT_MASK_FTM_PTT_VALUE_8814B 0xffff
#define BIT_FTM_PTT_VALUE_8814B(x) \
(((x) & BIT_MASK_FTM_PTT_VALUE_8814B) << BIT_SHIFT_FTM_PTT_VALUE_8814B)
#define BITS_FTM_PTT_VALUE_8814B \
(BIT_MASK_FTM_PTT_VALUE_8814B << BIT_SHIFT_FTM_PTT_VALUE_8814B)
#define BIT_CLEAR_FTM_PTT_VALUE_8814B(x) ((x) & (~BITS_FTM_PTT_VALUE_8814B))
#define BIT_GET_FTM_PTT_VALUE_8814B(x) \
(((x) >> BIT_SHIFT_FTM_PTT_VALUE_8814B) & BIT_MASK_FTM_PTT_VALUE_8814B)
#define BIT_SET_FTM_PTT_VALUE_8814B(x, v) \
(BIT_CLEAR_FTM_PTT_VALUE_8814B(x) | BIT_FTM_PTT_VALUE_8814B(v))
/* 2 REG_FTM_TSF_8814B */
#define BIT_SHIFT_FTM_T2_TSF_8814B 16
#define BIT_MASK_FTM_T2_TSF_8814B 0xffff
#define BIT_FTM_T2_TSF_8814B(x) \
(((x) & BIT_MASK_FTM_T2_TSF_8814B) << BIT_SHIFT_FTM_T2_TSF_8814B)
#define BITS_FTM_T2_TSF_8814B \
(BIT_MASK_FTM_T2_TSF_8814B << BIT_SHIFT_FTM_T2_TSF_8814B)
#define BIT_CLEAR_FTM_T2_TSF_8814B(x) ((x) & (~BITS_FTM_T2_TSF_8814B))
#define BIT_GET_FTM_T2_TSF_8814B(x) \
(((x) >> BIT_SHIFT_FTM_T2_TSF_8814B) & BIT_MASK_FTM_T2_TSF_8814B)
#define BIT_SET_FTM_T2_TSF_8814B(x, v) \
(BIT_CLEAR_FTM_T2_TSF_8814B(x) | BIT_FTM_T2_TSF_8814B(v))
#define BIT_SHIFT_FTM_T1_TSF_8814B 0
#define BIT_MASK_FTM_T1_TSF_8814B 0xffff
#define BIT_FTM_T1_TSF_8814B(x) \
(((x) & BIT_MASK_FTM_T1_TSF_8814B) << BIT_SHIFT_FTM_T1_TSF_8814B)
#define BITS_FTM_T1_TSF_8814B \
(BIT_MASK_FTM_T1_TSF_8814B << BIT_SHIFT_FTM_T1_TSF_8814B)
#define BIT_CLEAR_FTM_T1_TSF_8814B(x) ((x) & (~BITS_FTM_T1_TSF_8814B))
#define BIT_GET_FTM_T1_TSF_8814B(x) \
(((x) >> BIT_SHIFT_FTM_T1_TSF_8814B) & BIT_MASK_FTM_T1_TSF_8814B)
#define BIT_SET_FTM_T1_TSF_8814B(x, v) \
(BIT_CLEAR_FTM_T1_TSF_8814B(x) | BIT_FTM_T1_TSF_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HGQ_TIMEOUT_PERIOD_8814B */
#define BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8814B 0
#define BIT_MASK_HGQ_TIMEOUT_PERIOD_8814B 0xff
#define BIT_HGQ_TIMEOUT_PERIOD_8814B(x) \
(((x) & BIT_MASK_HGQ_TIMEOUT_PERIOD_8814B) \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8814B)
#define BITS_HGQ_TIMEOUT_PERIOD_8814B \
(BIT_MASK_HGQ_TIMEOUT_PERIOD_8814B \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8814B)
#define BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8814B(x) \
((x) & (~BITS_HGQ_TIMEOUT_PERIOD_8814B))
#define BIT_GET_HGQ_TIMEOUT_PERIOD_8814B(x) \
(((x) >> BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8814B) & \
BIT_MASK_HGQ_TIMEOUT_PERIOD_8814B)
#define BIT_SET_HGQ_TIMEOUT_PERIOD_8814B(x, v) \
(BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8814B(x) | \
BIT_HGQ_TIMEOUT_PERIOD_8814B(v))
/* 2 REG_TXCMD_TIMEOUT_PERIOD_8814B */
#define BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8814B 0
#define BIT_MASK_TXCMD_TIMEOUT_PERIOD_8814B 0xff
#define BIT_TXCMD_TIMEOUT_PERIOD_8814B(x) \
(((x) & BIT_MASK_TXCMD_TIMEOUT_PERIOD_8814B) \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8814B)
#define BITS_TXCMD_TIMEOUT_PERIOD_8814B \
(BIT_MASK_TXCMD_TIMEOUT_PERIOD_8814B \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8814B)
#define BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8814B(x) \
((x) & (~BITS_TXCMD_TIMEOUT_PERIOD_8814B))
#define BIT_GET_TXCMD_TIMEOUT_PERIOD_8814B(x) \
(((x) >> BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8814B) & \
BIT_MASK_TXCMD_TIMEOUT_PERIOD_8814B)
#define BIT_SET_TXCMD_TIMEOUT_PERIOD_8814B(x, v) \
(BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8814B(x) | \
BIT_TXCMD_TIMEOUT_PERIOD_8814B(v))
/* 2 REG_MISC_CTRL_8814B */
#define BIT_DIS_SECONDARY_CCA_80M_8814B BIT(2)
#define BIT_DIS_SECONDARY_CCA_40M_8814B BIT(1)
#define BIT_DIS_SECONDARY_CCA_20M_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TXOP_MIN_8814B */
#define BIT_HIQ_NAV_BREAK_EN_8814B BIT(15)
#define BIT_MGQ_NAV_BREAK_EN_8814B BIT(14)
#define BIT_SHIFT_TXOP_MIN_8814B 0
#define BIT_MASK_TXOP_MIN_8814B 0x3fff
#define BIT_TXOP_MIN_8814B(x) \
(((x) & BIT_MASK_TXOP_MIN_8814B) << BIT_SHIFT_TXOP_MIN_8814B)
#define BITS_TXOP_MIN_8814B \
(BIT_MASK_TXOP_MIN_8814B << BIT_SHIFT_TXOP_MIN_8814B)
#define BIT_CLEAR_TXOP_MIN_8814B(x) ((x) & (~BITS_TXOP_MIN_8814B))
#define BIT_GET_TXOP_MIN_8814B(x) \
(((x) >> BIT_SHIFT_TXOP_MIN_8814B) & BIT_MASK_TXOP_MIN_8814B)
#define BIT_SET_TXOP_MIN_8814B(x, v) \
(BIT_CLEAR_TXOP_MIN_8814B(x) | BIT_TXOP_MIN_8814B(v))
/* 2 REG_PRE_BKF_TIME_8814B */
#define BIT_SHIFT_PRE_BKF_TIME_8814B 0
#define BIT_MASK_PRE_BKF_TIME_8814B 0xff
#define BIT_PRE_BKF_TIME_8814B(x) \
(((x) & BIT_MASK_PRE_BKF_TIME_8814B) << BIT_SHIFT_PRE_BKF_TIME_8814B)
#define BITS_PRE_BKF_TIME_8814B \
(BIT_MASK_PRE_BKF_TIME_8814B << BIT_SHIFT_PRE_BKF_TIME_8814B)
#define BIT_CLEAR_PRE_BKF_TIME_8814B(x) ((x) & (~BITS_PRE_BKF_TIME_8814B))
#define BIT_GET_PRE_BKF_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PRE_BKF_TIME_8814B) & BIT_MASK_PRE_BKF_TIME_8814B)
#define BIT_SET_PRE_BKF_TIME_8814B(x, v) \
(BIT_CLEAR_PRE_BKF_TIME_8814B(x) | BIT_PRE_BKF_TIME_8814B(v))
/* 2 REG_CROSS_TXOP_CTRL_8814B */
#define BIT_TBTT_RETRY_8814B BIT(4)
#define BIT_TXFAIL_BREACK_TXOP_EN_8814B BIT(3)
#define BIT_RTS_NAV_TXOP_8814B BIT(1)
#define BIT_NOT_CROSS_TXOP_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_ACMHWCTRL_8814B */
#define BIT_BEQ_ACM_STATUS_8814B BIT(7)
#define BIT_VIQ_ACM_STATUS_8814B BIT(6)
#define BIT_VOQ_ACM_STATUS_8814B BIT(5)
#define BIT_BEQ_ACM_EN_8814B BIT(3)
#define BIT_VIQ_ACM_EN_8814B BIT(2)
#define BIT_VOQ_ACM_EN_8814B BIT(1)
#define BIT_ACMHWEN_8814B BIT(0)
/* 2 REG_ACMRSTCTRL_8814B */
#define BIT_BE_ACM_RESET_USED_TIME_8814B BIT(2)
#define BIT_VI_ACM_RESET_USED_TIME_8814B BIT(1)
#define BIT_VO_ACM_RESET_USED_TIME_8814B BIT(0)
/* 2 REG_ACMAVG_8814B */
#define BIT_SHIFT_AVGPERIOD_8814B 0
#define BIT_MASK_AVGPERIOD_8814B 0xffff
#define BIT_AVGPERIOD_8814B(x) \
(((x) & BIT_MASK_AVGPERIOD_8814B) << BIT_SHIFT_AVGPERIOD_8814B)
#define BITS_AVGPERIOD_8814B \
(BIT_MASK_AVGPERIOD_8814B << BIT_SHIFT_AVGPERIOD_8814B)
#define BIT_CLEAR_AVGPERIOD_8814B(x) ((x) & (~BITS_AVGPERIOD_8814B))
#define BIT_GET_AVGPERIOD_8814B(x) \
(((x) >> BIT_SHIFT_AVGPERIOD_8814B) & BIT_MASK_AVGPERIOD_8814B)
#define BIT_SET_AVGPERIOD_8814B(x, v) \
(BIT_CLEAR_AVGPERIOD_8814B(x) | BIT_AVGPERIOD_8814B(v))
/* 2 REG_VO_ADMTIME_8814B */
#define BIT_SHIFT_VO_ADMITTED_TIME_8814B 0
#define BIT_MASK_VO_ADMITTED_TIME_8814B 0xffff
#define BIT_VO_ADMITTED_TIME_8814B(x) \
(((x) & BIT_MASK_VO_ADMITTED_TIME_8814B) \
<< BIT_SHIFT_VO_ADMITTED_TIME_8814B)
#define BITS_VO_ADMITTED_TIME_8814B \
(BIT_MASK_VO_ADMITTED_TIME_8814B << BIT_SHIFT_VO_ADMITTED_TIME_8814B)
#define BIT_CLEAR_VO_ADMITTED_TIME_8814B(x) \
((x) & (~BITS_VO_ADMITTED_TIME_8814B))
#define BIT_GET_VO_ADMITTED_TIME_8814B(x) \
(((x) >> BIT_SHIFT_VO_ADMITTED_TIME_8814B) & \
BIT_MASK_VO_ADMITTED_TIME_8814B)
#define BIT_SET_VO_ADMITTED_TIME_8814B(x, v) \
(BIT_CLEAR_VO_ADMITTED_TIME_8814B(x) | BIT_VO_ADMITTED_TIME_8814B(v))
/* 2 REG_VI_ADMTIME_8814B */
#define BIT_SHIFT_VI_ADMITTED_TIME_8814B 0
#define BIT_MASK_VI_ADMITTED_TIME_8814B 0xffff
#define BIT_VI_ADMITTED_TIME_8814B(x) \
(((x) & BIT_MASK_VI_ADMITTED_TIME_8814B) \
<< BIT_SHIFT_VI_ADMITTED_TIME_8814B)
#define BITS_VI_ADMITTED_TIME_8814B \
(BIT_MASK_VI_ADMITTED_TIME_8814B << BIT_SHIFT_VI_ADMITTED_TIME_8814B)
#define BIT_CLEAR_VI_ADMITTED_TIME_8814B(x) \
((x) & (~BITS_VI_ADMITTED_TIME_8814B))
#define BIT_GET_VI_ADMITTED_TIME_8814B(x) \
(((x) >> BIT_SHIFT_VI_ADMITTED_TIME_8814B) & \
BIT_MASK_VI_ADMITTED_TIME_8814B)
#define BIT_SET_VI_ADMITTED_TIME_8814B(x, v) \
(BIT_CLEAR_VI_ADMITTED_TIME_8814B(x) | BIT_VI_ADMITTED_TIME_8814B(v))
/* 2 REG_BE_ADMTIME_8814B */
#define BIT_SHIFT_BE_ADMITTED_TIME_8814B 0
#define BIT_MASK_BE_ADMITTED_TIME_8814B 0xffff
#define BIT_BE_ADMITTED_TIME_8814B(x) \
(((x) & BIT_MASK_BE_ADMITTED_TIME_8814B) \
<< BIT_SHIFT_BE_ADMITTED_TIME_8814B)
#define BITS_BE_ADMITTED_TIME_8814B \
(BIT_MASK_BE_ADMITTED_TIME_8814B << BIT_SHIFT_BE_ADMITTED_TIME_8814B)
#define BIT_CLEAR_BE_ADMITTED_TIME_8814B(x) \
((x) & (~BITS_BE_ADMITTED_TIME_8814B))
#define BIT_GET_BE_ADMITTED_TIME_8814B(x) \
(((x) >> BIT_SHIFT_BE_ADMITTED_TIME_8814B) & \
BIT_MASK_BE_ADMITTED_TIME_8814B)
#define BIT_SET_BE_ADMITTED_TIME_8814B(x, v) \
(BIT_CLEAR_BE_ADMITTED_TIME_8814B(x) | BIT_BE_ADMITTED_TIME_8814B(v))
/* 2 REG_MAC_HEADER_NAV_OFFSET_8814B */
#define BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8814B 0
#define BIT_MASK_MAC_HEADER_NAV_OFFSET_8814B 0xff
#define BIT_MAC_HEADER_NAV_OFFSET_8814B(x) \
(((x) & BIT_MASK_MAC_HEADER_NAV_OFFSET_8814B) \
<< BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8814B)
#define BITS_MAC_HEADER_NAV_OFFSET_8814B \
(BIT_MASK_MAC_HEADER_NAV_OFFSET_8814B \
<< BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8814B)
#define BIT_CLEAR_MAC_HEADER_NAV_OFFSET_8814B(x) \
((x) & (~BITS_MAC_HEADER_NAV_OFFSET_8814B))
#define BIT_GET_MAC_HEADER_NAV_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8814B) & \
BIT_MASK_MAC_HEADER_NAV_OFFSET_8814B)
#define BIT_SET_MAC_HEADER_NAV_OFFSET_8814B(x, v) \
(BIT_CLEAR_MAC_HEADER_NAV_OFFSET_8814B(x) | \
BIT_MAC_HEADER_NAV_OFFSET_8814B(v))
/* 2 REG_DIS_NDPA_NAV_CHECK_8814B */
#define BIT_DIS_NDPA_NAV_CHECK_8814B BIT(0)
/* 2 REG_EDCA_RANDOM_GEN_8814B */
#define BIT_SHIFT_RANDOM_GEN_8814B 0
#define BIT_MASK_RANDOM_GEN_8814B 0xffffff
#define BIT_RANDOM_GEN_8814B(x) \
(((x) & BIT_MASK_RANDOM_GEN_8814B) << BIT_SHIFT_RANDOM_GEN_8814B)
#define BITS_RANDOM_GEN_8814B \
(BIT_MASK_RANDOM_GEN_8814B << BIT_SHIFT_RANDOM_GEN_8814B)
#define BIT_CLEAR_RANDOM_GEN_8814B(x) ((x) & (~BITS_RANDOM_GEN_8814B))
#define BIT_GET_RANDOM_GEN_8814B(x) \
(((x) >> BIT_SHIFT_RANDOM_GEN_8814B) & BIT_MASK_RANDOM_GEN_8814B)
#define BIT_SET_RANDOM_GEN_8814B(x, v) \
(BIT_CLEAR_RANDOM_GEN_8814B(x) | BIT_RANDOM_GEN_8814B(v))
/* 2 REG_TXCMD_SEL_8814B */
#define BIT_SHIFT_TXCMD_SEG_SEL_8814B 0
#define BIT_MASK_TXCMD_SEG_SEL_8814B 0xf
#define BIT_TXCMD_SEG_SEL_8814B(x) \
(((x) & BIT_MASK_TXCMD_SEG_SEL_8814B) << BIT_SHIFT_TXCMD_SEG_SEL_8814B)
#define BITS_TXCMD_SEG_SEL_8814B \
(BIT_MASK_TXCMD_SEG_SEL_8814B << BIT_SHIFT_TXCMD_SEG_SEL_8814B)
#define BIT_CLEAR_TXCMD_SEG_SEL_8814B(x) ((x) & (~BITS_TXCMD_SEG_SEL_8814B))
#define BIT_GET_TXCMD_SEG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_TXCMD_SEG_SEL_8814B) & BIT_MASK_TXCMD_SEG_SEL_8814B)
#define BIT_SET_TXCMD_SEG_SEL_8814B(x, v) \
(BIT_CLEAR_TXCMD_SEG_SEL_8814B(x) | BIT_TXCMD_SEG_SEL_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_MU_DBG_INFO_8814B */
#define BIT_SHIFT_MU_DBG_INFO_8814B 0
#define BIT_MASK_MU_DBG_INFO_8814B 0xffffffffL
#define BIT_MU_DBG_INFO_8814B(x) \
(((x) & BIT_MASK_MU_DBG_INFO_8814B) << BIT_SHIFT_MU_DBG_INFO_8814B)
#define BITS_MU_DBG_INFO_8814B \
(BIT_MASK_MU_DBG_INFO_8814B << BIT_SHIFT_MU_DBG_INFO_8814B)
#define BIT_CLEAR_MU_DBG_INFO_8814B(x) ((x) & (~BITS_MU_DBG_INFO_8814B))
#define BIT_GET_MU_DBG_INFO_8814B(x) \
(((x) >> BIT_SHIFT_MU_DBG_INFO_8814B) & BIT_MASK_MU_DBG_INFO_8814B)
#define BIT_SET_MU_DBG_INFO_8814B(x, v) \
(BIT_CLEAR_MU_DBG_INFO_8814B(x) | BIT_MU_DBG_INFO_8814B(v))
/* 2 REG_MU_DBG_INFO_1_8814B */
#define BIT_SHIFT_MU_DBG_INFO_1_8814B 0
#define BIT_MASK_MU_DBG_INFO_1_8814B 0xffffffffL
#define BIT_MU_DBG_INFO_1_8814B(x) \
(((x) & BIT_MASK_MU_DBG_INFO_1_8814B) << BIT_SHIFT_MU_DBG_INFO_1_8814B)
#define BITS_MU_DBG_INFO_1_8814B \
(BIT_MASK_MU_DBG_INFO_1_8814B << BIT_SHIFT_MU_DBG_INFO_1_8814B)
#define BIT_CLEAR_MU_DBG_INFO_1_8814B(x) ((x) & (~BITS_MU_DBG_INFO_1_8814B))
#define BIT_GET_MU_DBG_INFO_1_8814B(x) \
(((x) >> BIT_SHIFT_MU_DBG_INFO_1_8814B) & BIT_MASK_MU_DBG_INFO_1_8814B)
#define BIT_SET_MU_DBG_INFO_1_8814B(x, v) \
(BIT_CLEAR_MU_DBG_INFO_1_8814B(x) | BIT_MU_DBG_INFO_1_8814B(v))
/* 2 REG_SCH_DBG_SEL_8814B */
#define BIT_SHIFT_SCH_DBG_SEL_8814B 0
#define BIT_MASK_SCH_DBG_SEL_8814B 0xff
#define BIT_SCH_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_SCH_DBG_SEL_8814B) << BIT_SHIFT_SCH_DBG_SEL_8814B)
#define BITS_SCH_DBG_SEL_8814B \
(BIT_MASK_SCH_DBG_SEL_8814B << BIT_SHIFT_SCH_DBG_SEL_8814B)
#define BIT_CLEAR_SCH_DBG_SEL_8814B(x) ((x) & (~BITS_SCH_DBG_SEL_8814B))
#define BIT_GET_SCH_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_SCH_DBG_SEL_8814B) & BIT_MASK_SCH_DBG_SEL_8814B)
#define BIT_SET_SCH_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_SCH_DBG_SEL_8814B(x) | BIT_SCH_DBG_SEL_8814B(v))
/* 2 REG_SCHEDULER_RST_8814B */
#define BIT_SCHEDULER_RST_V1_8814B BIT(0)
/* 2 REG_MU_DBG_ERR_FLAG_8814B */
#define BIT_BCN_PORTID_ERR_8814B BIT(2)
#define BIT_SHIFT_MU_DBG_ERR_FLAG_8814B 0
#define BIT_MASK_MU_DBG_ERR_FLAG_8814B 0x3
#define BIT_MU_DBG_ERR_FLAG_8814B(x) \
(((x) & BIT_MASK_MU_DBG_ERR_FLAG_8814B) \
<< BIT_SHIFT_MU_DBG_ERR_FLAG_8814B)
#define BITS_MU_DBG_ERR_FLAG_8814B \
(BIT_MASK_MU_DBG_ERR_FLAG_8814B << BIT_SHIFT_MU_DBG_ERR_FLAG_8814B)
#define BIT_CLEAR_MU_DBG_ERR_FLAG_8814B(x) ((x) & (~BITS_MU_DBG_ERR_FLAG_8814B))
#define BIT_GET_MU_DBG_ERR_FLAG_8814B(x) \
(((x) >> BIT_SHIFT_MU_DBG_ERR_FLAG_8814B) & \
BIT_MASK_MU_DBG_ERR_FLAG_8814B)
#define BIT_SET_MU_DBG_ERR_FLAG_8814B(x, v) \
(BIT_CLEAR_MU_DBG_ERR_FLAG_8814B(x) | BIT_MU_DBG_ERR_FLAG_8814B(v))
/* 2 REG_TX_ERR_RECOVERY_RST_8814B */
#define BIT_SHIFT_ERR_RECOVER_CNT_8814B 4
#define BIT_MASK_ERR_RECOVER_CNT_8814B 0xf
#define BIT_ERR_RECOVER_CNT_8814B(x) \
(((x) & BIT_MASK_ERR_RECOVER_CNT_8814B) \
<< BIT_SHIFT_ERR_RECOVER_CNT_8814B)
#define BITS_ERR_RECOVER_CNT_8814B \
(BIT_MASK_ERR_RECOVER_CNT_8814B << BIT_SHIFT_ERR_RECOVER_CNT_8814B)
#define BIT_CLEAR_ERR_RECOVER_CNT_8814B(x) ((x) & (~BITS_ERR_RECOVER_CNT_8814B))
#define BIT_GET_ERR_RECOVER_CNT_8814B(x) \
(((x) >> BIT_SHIFT_ERR_RECOVER_CNT_8814B) & \
BIT_MASK_ERR_RECOVER_CNT_8814B)
#define BIT_SET_ERR_RECOVER_CNT_8814B(x, v) \
(BIT_CLEAR_ERR_RECOVER_CNT_8814B(x) | BIT_ERR_RECOVER_CNT_8814B(v))
#define BIT_RX_HANG_ERR_8814B BIT(2)
#define BIT_TX_HANG_ERR_8814B BIT(1)
#define BIT_TX_ERR_RECOVERY_RST_8814B BIT(0)
/* 2 REG_SCH_DBG_VALUE_8814B */
#define BIT_SHIFT_SCH_DBG_VALUE_8814B 0
#define BIT_MASK_SCH_DBG_VALUE_8814B 0xffffffffL
#define BIT_SCH_DBG_VALUE_8814B(x) \
(((x) & BIT_MASK_SCH_DBG_VALUE_8814B) << BIT_SHIFT_SCH_DBG_VALUE_8814B)
#define BITS_SCH_DBG_VALUE_8814B \
(BIT_MASK_SCH_DBG_VALUE_8814B << BIT_SHIFT_SCH_DBG_VALUE_8814B)
#define BIT_CLEAR_SCH_DBG_VALUE_8814B(x) ((x) & (~BITS_SCH_DBG_VALUE_8814B))
#define BIT_GET_SCH_DBG_VALUE_8814B(x) \
(((x) >> BIT_SHIFT_SCH_DBG_VALUE_8814B) & BIT_MASK_SCH_DBG_VALUE_8814B)
#define BIT_SET_SCH_DBG_VALUE_8814B(x, v) \
(BIT_CLEAR_SCH_DBG_VALUE_8814B(x) | BIT_SCH_DBG_VALUE_8814B(v))
/* 2 REG_SCH_TXCMD_8814B */
#define BIT_SHIFT_SCH_TXCMD_8814B 0
#define BIT_MASK_SCH_TXCMD_8814B 0xffffffffL
#define BIT_SCH_TXCMD_8814B(x) \
(((x) & BIT_MASK_SCH_TXCMD_8814B) << BIT_SHIFT_SCH_TXCMD_8814B)
#define BITS_SCH_TXCMD_8814B \
(BIT_MASK_SCH_TXCMD_8814B << BIT_SHIFT_SCH_TXCMD_8814B)
#define BIT_CLEAR_SCH_TXCMD_8814B(x) ((x) & (~BITS_SCH_TXCMD_8814B))
#define BIT_GET_SCH_TXCMD_8814B(x) \
(((x) >> BIT_SHIFT_SCH_TXCMD_8814B) & BIT_MASK_SCH_TXCMD_8814B)
#define BIT_SET_SCH_TXCMD_8814B(x, v) \
(BIT_CLEAR_SCH_TXCMD_8814B(x) | BIT_SCH_TXCMD_8814B(v))
/* 2 REG_PAGE5_DUMMY_8814B */
/* 2 REG_PORT_CTRL_SEL_8814B */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1_8814B 4
#define BIT_MASK_BCN_TIMER_SEL_FWRD_V1_8814B 0x7
#define BIT_BCN_TIMER_SEL_FWRD_V1_8814B(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD_V1_8814B) \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1_8814B)
#define BITS_BCN_TIMER_SEL_FWRD_V1_8814B \
(BIT_MASK_BCN_TIMER_SEL_FWRD_V1_8814B \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1_8814B)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD_V1_8814B(x) \
((x) & (~BITS_BCN_TIMER_SEL_FWRD_V1_8814B))
#define BIT_GET_BCN_TIMER_SEL_FWRD_V1_8814B(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD_V1_8814B) & \
BIT_MASK_BCN_TIMER_SEL_FWRD_V1_8814B)
#define BIT_SET_BCN_TIMER_SEL_FWRD_V1_8814B(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD_V1_8814B(x) | \
BIT_BCN_TIMER_SEL_FWRD_V1_8814B(v))
#define BIT_SHIFT_PORT_CTRL_SEL_8814B 0
#define BIT_MASK_PORT_CTRL_SEL_8814B 0x7
#define BIT_PORT_CTRL_SEL_8814B(x) \
(((x) & BIT_MASK_PORT_CTRL_SEL_8814B) << BIT_SHIFT_PORT_CTRL_SEL_8814B)
#define BITS_PORT_CTRL_SEL_8814B \
(BIT_MASK_PORT_CTRL_SEL_8814B << BIT_SHIFT_PORT_CTRL_SEL_8814B)
#define BIT_CLEAR_PORT_CTRL_SEL_8814B(x) ((x) & (~BITS_PORT_CTRL_SEL_8814B))
#define BIT_GET_PORT_CTRL_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PORT_CTRL_SEL_8814B) & BIT_MASK_PORT_CTRL_SEL_8814B)
#define BIT_SET_PORT_CTRL_SEL_8814B(x, v) \
(BIT_CLEAR_PORT_CTRL_SEL_8814B(x) | BIT_PORT_CTRL_SEL_8814B(v))
/* 2 REG_PORT_CTRL_CFG_8814B */
#define BIT_BCNERR_CNT_EN_V1_8814B BIT(11)
#define BIT_DIS_TRX_CAL_BCN_V1_8814B BIT(10)
#define BIT_DIS_TX_CAL_TBTT_V1_8814B BIT(9)
#define BIT_BCN_AGGRESSION_V1_8814B BIT(8)
#define BIT_TSFTR_RST_V1_8814B BIT(7)
#define BIT_DIS_RX_BSSID_FIT_8814B BIT(6)
#define BIT_EN_TXBCN_RPT_V1_8814B BIT(5)
#define BIT_DIS_TSF_UDT_8814B BIT(4)
#define BIT_EN_PORT_FUNCTION_8814B BIT(3)
#define BIT_EN_RXBCN_RPT_8814B BIT(2)
#define BIT_EN_P2P_CTWINDOW_8814B BIT(1)
#define BIT_EN_P2P_BCNQ_AREA_8814B BIT(0)
/* 2 REG_TBTT_PROHIBIT_CFG_8814B */
#define BIT_MASK_PROHIBIT_8814B BIT(23)
#define BIT_SHIFT_TBTT_HOLD_TIME_8814B 8
#define BIT_MASK_TBTT_HOLD_TIME_8814B 0xfff
#define BIT_TBTT_HOLD_TIME_8814B(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_8814B) \
<< BIT_SHIFT_TBTT_HOLD_TIME_8814B)
#define BITS_TBTT_HOLD_TIME_8814B \
(BIT_MASK_TBTT_HOLD_TIME_8814B << BIT_SHIFT_TBTT_HOLD_TIME_8814B)
#define BIT_CLEAR_TBTT_HOLD_TIME_8814B(x) ((x) & (~BITS_TBTT_HOLD_TIME_8814B))
#define BIT_GET_TBTT_HOLD_TIME_8814B(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_8814B) & \
BIT_MASK_TBTT_HOLD_TIME_8814B)
#define BIT_SET_TBTT_HOLD_TIME_8814B(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_8814B(x) | BIT_TBTT_HOLD_TIME_8814B(v))
#define BIT_SHIFT_TBTT_PROHIBIT_SETUP_8814B 0
#define BIT_MASK_TBTT_PROHIBIT_SETUP_8814B 0xf
#define BIT_TBTT_PROHIBIT_SETUP_8814B(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_SETUP_8814B) \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8814B)
#define BITS_TBTT_PROHIBIT_SETUP_8814B \
(BIT_MASK_TBTT_PROHIBIT_SETUP_8814B \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8814B)
#define BIT_CLEAR_TBTT_PROHIBIT_SETUP_8814B(x) \
((x) & (~BITS_TBTT_PROHIBIT_SETUP_8814B))
#define BIT_GET_TBTT_PROHIBIT_SETUP_8814B(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_SETUP_8814B) & \
BIT_MASK_TBTT_PROHIBIT_SETUP_8814B)
#define BIT_SET_TBTT_PROHIBIT_SETUP_8814B(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_SETUP_8814B(x) | \
BIT_TBTT_PROHIBIT_SETUP_8814B(v))
/* 2 REG_DRVERLYINT_CFG_8814B */
#define BIT_SHIFT_DRVERLYITV_8814B 0
#define BIT_MASK_DRVERLYITV_8814B 0xff
#define BIT_DRVERLYITV_8814B(x) \
(((x) & BIT_MASK_DRVERLYITV_8814B) << BIT_SHIFT_DRVERLYITV_8814B)
#define BITS_DRVERLYITV_8814B \
(BIT_MASK_DRVERLYITV_8814B << BIT_SHIFT_DRVERLYITV_8814B)
#define BIT_CLEAR_DRVERLYITV_8814B(x) ((x) & (~BITS_DRVERLYITV_8814B))
#define BIT_GET_DRVERLYITV_8814B(x) \
(((x) >> BIT_SHIFT_DRVERLYITV_8814B) & BIT_MASK_DRVERLYITV_8814B)
#define BIT_SET_DRVERLYITV_8814B(x, v) \
(BIT_CLEAR_DRVERLYITV_8814B(x) | BIT_DRVERLYITV_8814B(v))
/* 2 REG_BCNDMATIM_CFG_8814B */
#define BIT_SHIFT_BCNDMATIM_8814B 0
#define BIT_MASK_BCNDMATIM_8814B 0xff
#define BIT_BCNDMATIM_8814B(x) \
(((x) & BIT_MASK_BCNDMATIM_8814B) << BIT_SHIFT_BCNDMATIM_8814B)
#define BITS_BCNDMATIM_8814B \
(BIT_MASK_BCNDMATIM_8814B << BIT_SHIFT_BCNDMATIM_8814B)
#define BIT_CLEAR_BCNDMATIM_8814B(x) ((x) & (~BITS_BCNDMATIM_8814B))
#define BIT_GET_BCNDMATIM_8814B(x) \
(((x) >> BIT_SHIFT_BCNDMATIM_8814B) & BIT_MASK_BCNDMATIM_8814B)
#define BIT_SET_BCNDMATIM_8814B(x, v) \
(BIT_CLEAR_BCNDMATIM_8814B(x) | BIT_BCNDMATIM_8814B(v))
/* 2 REG_CTWND_CFG_8814B */
#define BIT_SHIFT_CTWND_8814B 0
#define BIT_MASK_CTWND_8814B 0xff
#define BIT_CTWND_8814B(x) \
(((x) & BIT_MASK_CTWND_8814B) << BIT_SHIFT_CTWND_8814B)
#define BITS_CTWND_8814B (BIT_MASK_CTWND_8814B << BIT_SHIFT_CTWND_8814B)
#define BIT_CLEAR_CTWND_8814B(x) ((x) & (~BITS_CTWND_8814B))
#define BIT_GET_CTWND_8814B(x) \
(((x) >> BIT_SHIFT_CTWND_8814B) & BIT_MASK_CTWND_8814B)
#define BIT_SET_CTWND_8814B(x, v) \
(BIT_CLEAR_CTWND_8814B(x) | BIT_CTWND_8814B(v))
/* 2 REG_BCNIVLCUNT_CFG_8814B */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BCNIVLCUNT_8814B 0
#define BIT_MASK_BCNIVLCUNT_8814B 0x7f
#define BIT_BCNIVLCUNT_8814B(x) \
(((x) & BIT_MASK_BCNIVLCUNT_8814B) << BIT_SHIFT_BCNIVLCUNT_8814B)
#define BITS_BCNIVLCUNT_8814B \
(BIT_MASK_BCNIVLCUNT_8814B << BIT_SHIFT_BCNIVLCUNT_8814B)
#define BIT_CLEAR_BCNIVLCUNT_8814B(x) ((x) & (~BITS_BCNIVLCUNT_8814B))
#define BIT_GET_BCNIVLCUNT_8814B(x) \
(((x) >> BIT_SHIFT_BCNIVLCUNT_8814B) & BIT_MASK_BCNIVLCUNT_8814B)
#define BIT_SET_BCNIVLCUNT_8814B(x, v) \
(BIT_CLEAR_BCNIVLCUNT_8814B(x) | BIT_BCNIVLCUNT_8814B(v))
/* 2 REG_EARLY_128US_CFG_8814B */
#define BIT_SHIFT_EARLY_128US_8814B 0
#define BIT_MASK_EARLY_128US_8814B 0x7
#define BIT_EARLY_128US_8814B(x) \
(((x) & BIT_MASK_EARLY_128US_8814B) << BIT_SHIFT_EARLY_128US_8814B)
#define BITS_EARLY_128US_8814B \
(BIT_MASK_EARLY_128US_8814B << BIT_SHIFT_EARLY_128US_8814B)
#define BIT_CLEAR_EARLY_128US_8814B(x) ((x) & (~BITS_EARLY_128US_8814B))
#define BIT_GET_EARLY_128US_8814B(x) \
(((x) >> BIT_SHIFT_EARLY_128US_8814B) & BIT_MASK_EARLY_128US_8814B)
#define BIT_SET_EARLY_128US_8814B(x, v) \
(BIT_CLEAR_EARLY_128US_8814B(x) | BIT_EARLY_128US_8814B(v))
/* 2 REG_TSFTR_SYNC_OFFSET_CFG_8814B */
#define BIT_SHIFT_TSFTR_SNC_OFFSET_V1_8814B 0
#define BIT_MASK_TSFTR_SNC_OFFSET_V1_8814B 0xffffff
#define BIT_TSFTR_SNC_OFFSET_V1_8814B(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET_V1_8814B) \
<< BIT_SHIFT_TSFTR_SNC_OFFSET_V1_8814B)
#define BITS_TSFTR_SNC_OFFSET_V1_8814B \
(BIT_MASK_TSFTR_SNC_OFFSET_V1_8814B \
<< BIT_SHIFT_TSFTR_SNC_OFFSET_V1_8814B)
#define BIT_CLEAR_TSFTR_SNC_OFFSET_V1_8814B(x) \
((x) & (~BITS_TSFTR_SNC_OFFSET_V1_8814B))
#define BIT_GET_TSFTR_SNC_OFFSET_V1_8814B(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET_V1_8814B) & \
BIT_MASK_TSFTR_SNC_OFFSET_V1_8814B)
#define BIT_SET_TSFTR_SNC_OFFSET_V1_8814B(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET_V1_8814B(x) | \
BIT_TSFTR_SNC_OFFSET_V1_8814B(v))
/* 2 REG_TSFTR_SYNC_CTRL_CFG_8814B */
#define BIT_SYNC_TSF_NOW_V1_8814B BIT(5)
#define BIT_SYNC_TSF_ONCE_8814B BIT(4)
#define BIT_SYNC_TSF_AUTO_8814B BIT(3)
#define BIT_SHIFT_SYNC_PORT_SEL_8814B 0
#define BIT_MASK_SYNC_PORT_SEL_8814B 0x7
#define BIT_SYNC_PORT_SEL_8814B(x) \
(((x) & BIT_MASK_SYNC_PORT_SEL_8814B) << BIT_SHIFT_SYNC_PORT_SEL_8814B)
#define BITS_SYNC_PORT_SEL_8814B \
(BIT_MASK_SYNC_PORT_SEL_8814B << BIT_SHIFT_SYNC_PORT_SEL_8814B)
#define BIT_CLEAR_SYNC_PORT_SEL_8814B(x) ((x) & (~BITS_SYNC_PORT_SEL_8814B))
#define BIT_GET_SYNC_PORT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_SYNC_PORT_SEL_8814B) & BIT_MASK_SYNC_PORT_SEL_8814B)
#define BIT_SET_SYNC_PORT_SEL_8814B(x, v) \
(BIT_CLEAR_SYNC_PORT_SEL_8814B(x) | BIT_SYNC_PORT_SEL_8814B(v))
/* 2 REG_BCN_SPACE_CFG_8814B */
#define BIT_SHIFT_BCN_SPACE_8814B 0
#define BIT_MASK_BCN_SPACE_8814B 0xffff
#define BIT_BCN_SPACE_8814B(x) \
(((x) & BIT_MASK_BCN_SPACE_8814B) << BIT_SHIFT_BCN_SPACE_8814B)
#define BITS_BCN_SPACE_8814B \
(BIT_MASK_BCN_SPACE_8814B << BIT_SHIFT_BCN_SPACE_8814B)
#define BIT_CLEAR_BCN_SPACE_8814B(x) ((x) & (~BITS_BCN_SPACE_8814B))
#define BIT_GET_BCN_SPACE_8814B(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_8814B) & BIT_MASK_BCN_SPACE_8814B)
#define BIT_SET_BCN_SPACE_8814B(x, v) \
(BIT_CLEAR_BCN_SPACE_8814B(x) | BIT_BCN_SPACE_8814B(v))
/* 2 REG_EARLY_INT_ADJUST_CFG_8814B */
#define BIT_SHIFT_EARLY_INT_ADJUST_8814B 0
#define BIT_MASK_EARLY_INT_ADJUST_8814B 0xffff
#define BIT_EARLY_INT_ADJUST_8814B(x) \
(((x) & BIT_MASK_EARLY_INT_ADJUST_8814B) \
<< BIT_SHIFT_EARLY_INT_ADJUST_8814B)
#define BITS_EARLY_INT_ADJUST_8814B \
(BIT_MASK_EARLY_INT_ADJUST_8814B << BIT_SHIFT_EARLY_INT_ADJUST_8814B)
#define BIT_CLEAR_EARLY_INT_ADJUST_8814B(x) \
((x) & (~BITS_EARLY_INT_ADJUST_8814B))
#define BIT_GET_EARLY_INT_ADJUST_8814B(x) \
(((x) >> BIT_SHIFT_EARLY_INT_ADJUST_8814B) & \
BIT_MASK_EARLY_INT_ADJUST_8814B)
#define BIT_SET_EARLY_INT_ADJUST_8814B(x, v) \
(BIT_CLEAR_EARLY_INT_ADJUST_8814B(x) | BIT_EARLY_INT_ADJUST_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_SW_TBTT_TSF_INFO_8814B */
#define BIT_SHIFT_SW_TBTT_TSF_INFO_8814B 0
#define BIT_MASK_SW_TBTT_TSF_INFO_8814B 0xffffffffL
#define BIT_SW_TBTT_TSF_INFO_8814B(x) \
(((x) & BIT_MASK_SW_TBTT_TSF_INFO_8814B) \
<< BIT_SHIFT_SW_TBTT_TSF_INFO_8814B)
#define BITS_SW_TBTT_TSF_INFO_8814B \
(BIT_MASK_SW_TBTT_TSF_INFO_8814B << BIT_SHIFT_SW_TBTT_TSF_INFO_8814B)
#define BIT_CLEAR_SW_TBTT_TSF_INFO_8814B(x) \
((x) & (~BITS_SW_TBTT_TSF_INFO_8814B))
#define BIT_GET_SW_TBTT_TSF_INFO_8814B(x) \
(((x) >> BIT_SHIFT_SW_TBTT_TSF_INFO_8814B) & \
BIT_MASK_SW_TBTT_TSF_INFO_8814B)
#define BIT_SET_SW_TBTT_TSF_INFO_8814B(x, v) \
(BIT_CLEAR_SW_TBTT_TSF_INFO_8814B(x) | BIT_SW_TBTT_TSF_INFO_8814B(v))
/* 2 REG_TSFTR_LOW_8814B */
#define BIT_SHIFT_TSF_TIMER_LOW_8814B 0
#define BIT_MASK_TSF_TIMER_LOW_8814B 0xffffffffL
#define BIT_TSF_TIMER_LOW_8814B(x) \
(((x) & BIT_MASK_TSF_TIMER_LOW_8814B) << BIT_SHIFT_TSF_TIMER_LOW_8814B)
#define BITS_TSF_TIMER_LOW_8814B \
(BIT_MASK_TSF_TIMER_LOW_8814B << BIT_SHIFT_TSF_TIMER_LOW_8814B)
#define BIT_CLEAR_TSF_TIMER_LOW_8814B(x) ((x) & (~BITS_TSF_TIMER_LOW_8814B))
#define BIT_GET_TSF_TIMER_LOW_8814B(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_LOW_8814B) & BIT_MASK_TSF_TIMER_LOW_8814B)
#define BIT_SET_TSF_TIMER_LOW_8814B(x, v) \
(BIT_CLEAR_TSF_TIMER_LOW_8814B(x) | BIT_TSF_TIMER_LOW_8814B(v))
/* 2 REG_TSFTR_HIGH_8814B */
#define BIT_SHIFT_TSF_TIMER_HIGH_8814B 0
#define BIT_MASK_TSF_TIMER_HIGH_8814B 0xffffffffL
#define BIT_TSF_TIMER_HIGH_8814B(x) \
(((x) & BIT_MASK_TSF_TIMER_HIGH_8814B) \
<< BIT_SHIFT_TSF_TIMER_HIGH_8814B)
#define BITS_TSF_TIMER_HIGH_8814B \
(BIT_MASK_TSF_TIMER_HIGH_8814B << BIT_SHIFT_TSF_TIMER_HIGH_8814B)
#define BIT_CLEAR_TSF_TIMER_HIGH_8814B(x) ((x) & (~BITS_TSF_TIMER_HIGH_8814B))
#define BIT_GET_TSF_TIMER_HIGH_8814B(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_HIGH_8814B) & \
BIT_MASK_TSF_TIMER_HIGH_8814B)
#define BIT_SET_TSF_TIMER_HIGH_8814B(x, v) \
(BIT_CLEAR_TSF_TIMER_HIGH_8814B(x) | BIT_TSF_TIMER_HIGH_8814B(v))
/* 2 REG_BCN_ERR_CNT_MAC_8814B */
#define BIT_SHIFT_BCN_ERR_CNT_MAC_8814B 0
#define BIT_MASK_BCN_ERR_CNT_MAC_8814B 0xff
#define BIT_BCN_ERR_CNT_MAC_8814B(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_MAC_8814B) \
<< BIT_SHIFT_BCN_ERR_CNT_MAC_8814B)
#define BITS_BCN_ERR_CNT_MAC_8814B \
(BIT_MASK_BCN_ERR_CNT_MAC_8814B << BIT_SHIFT_BCN_ERR_CNT_MAC_8814B)
#define BIT_CLEAR_BCN_ERR_CNT_MAC_8814B(x) ((x) & (~BITS_BCN_ERR_CNT_MAC_8814B))
#define BIT_GET_BCN_ERR_CNT_MAC_8814B(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_MAC_8814B) & \
BIT_MASK_BCN_ERR_CNT_MAC_8814B)
#define BIT_SET_BCN_ERR_CNT_MAC_8814B(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_MAC_8814B(x) | BIT_BCN_ERR_CNT_MAC_8814B(v))
/* 2 REG_BCN_ERR_CNT_EDCCA_8814B */
#define BIT_SHIFT_BCN_ERR_CNT_EDCCA_8814B 0
#define BIT_MASK_BCN_ERR_CNT_EDCCA_8814B 0xff
#define BIT_BCN_ERR_CNT_EDCCA_8814B(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_EDCCA_8814B) \
<< BIT_SHIFT_BCN_ERR_CNT_EDCCA_8814B)
#define BITS_BCN_ERR_CNT_EDCCA_8814B \
(BIT_MASK_BCN_ERR_CNT_EDCCA_8814B << BIT_SHIFT_BCN_ERR_CNT_EDCCA_8814B)
#define BIT_CLEAR_BCN_ERR_CNT_EDCCA_8814B(x) \
((x) & (~BITS_BCN_ERR_CNT_EDCCA_8814B))
#define BIT_GET_BCN_ERR_CNT_EDCCA_8814B(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_EDCCA_8814B) & \
BIT_MASK_BCN_ERR_CNT_EDCCA_8814B)
#define BIT_SET_BCN_ERR_CNT_EDCCA_8814B(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_EDCCA_8814B(x) | BIT_BCN_ERR_CNT_EDCCA_8814B(v))
/* 2 REG_BCN_ERR_CNT_CCA_8814B */
#define BIT_SHIFT_BCN_ERR_CNT_CCA_8814B 0
#define BIT_MASK_BCN_ERR_CNT_CCA_8814B 0xff
#define BIT_BCN_ERR_CNT_CCA_8814B(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_CCA_8814B) \
<< BIT_SHIFT_BCN_ERR_CNT_CCA_8814B)
#define BITS_BCN_ERR_CNT_CCA_8814B \
(BIT_MASK_BCN_ERR_CNT_CCA_8814B << BIT_SHIFT_BCN_ERR_CNT_CCA_8814B)
#define BIT_CLEAR_BCN_ERR_CNT_CCA_8814B(x) ((x) & (~BITS_BCN_ERR_CNT_CCA_8814B))
#define BIT_GET_BCN_ERR_CNT_CCA_8814B(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_CCA_8814B) & \
BIT_MASK_BCN_ERR_CNT_CCA_8814B)
#define BIT_SET_BCN_ERR_CNT_CCA_8814B(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_CCA_8814B(x) | BIT_BCN_ERR_CNT_CCA_8814B(v))
/* 2 REG_BCN_ERR_CNT_INVALID_8814B */
#define BIT_SHIFT_BCN_ERR_CNT_INVALID_8814B 0
#define BIT_MASK_BCN_ERR_CNT_INVALID_8814B 0xff
#define BIT_BCN_ERR_CNT_INVALID_8814B(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_INVALID_8814B) \
<< BIT_SHIFT_BCN_ERR_CNT_INVALID_8814B)
#define BITS_BCN_ERR_CNT_INVALID_8814B \
(BIT_MASK_BCN_ERR_CNT_INVALID_8814B \
<< BIT_SHIFT_BCN_ERR_CNT_INVALID_8814B)
#define BIT_CLEAR_BCN_ERR_CNT_INVALID_8814B(x) \
((x) & (~BITS_BCN_ERR_CNT_INVALID_8814B))
#define BIT_GET_BCN_ERR_CNT_INVALID_8814B(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_INVALID_8814B) & \
BIT_MASK_BCN_ERR_CNT_INVALID_8814B)
#define BIT_SET_BCN_ERR_CNT_INVALID_8814B(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_INVALID_8814B(x) | \
BIT_BCN_ERR_CNT_INVALID_8814B(v))
/* 2 REG_BCN_ERR_CNT_OTHERS_8814B */
#define BIT_SHIFT_BCN_ERR_CNT_OTHERS_8814B 0
#define BIT_MASK_BCN_ERR_CNT_OTHERS_8814B 0xff
#define BIT_BCN_ERR_CNT_OTHERS_8814B(x) \
(((x) & BIT_MASK_BCN_ERR_CNT_OTHERS_8814B) \
<< BIT_SHIFT_BCN_ERR_CNT_OTHERS_8814B)
#define BITS_BCN_ERR_CNT_OTHERS_8814B \
(BIT_MASK_BCN_ERR_CNT_OTHERS_8814B \
<< BIT_SHIFT_BCN_ERR_CNT_OTHERS_8814B)
#define BIT_CLEAR_BCN_ERR_CNT_OTHERS_8814B(x) \
((x) & (~BITS_BCN_ERR_CNT_OTHERS_8814B))
#define BIT_GET_BCN_ERR_CNT_OTHERS_8814B(x) \
(((x) >> BIT_SHIFT_BCN_ERR_CNT_OTHERS_8814B) & \
BIT_MASK_BCN_ERR_CNT_OTHERS_8814B)
#define BIT_SET_BCN_ERR_CNT_OTHERS_8814B(x, v) \
(BIT_CLEAR_BCN_ERR_CNT_OTHERS_8814B(x) | \
BIT_BCN_ERR_CNT_OTHERS_8814B(v))
/* 2 REG_RX_BCN_TIMER_8814B */
#define BIT_SHIFT_RX_BCN_TIMER_8814B 0
#define BIT_MASK_RX_BCN_TIMER_8814B 0xffff
#define BIT_RX_BCN_TIMER_8814B(x) \
(((x) & BIT_MASK_RX_BCN_TIMER_8814B) << BIT_SHIFT_RX_BCN_TIMER_8814B)
#define BITS_RX_BCN_TIMER_8814B \
(BIT_MASK_RX_BCN_TIMER_8814B << BIT_SHIFT_RX_BCN_TIMER_8814B)
#define BIT_CLEAR_RX_BCN_TIMER_8814B(x) ((x) & (~BITS_RX_BCN_TIMER_8814B))
#define BIT_GET_RX_BCN_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_RX_BCN_TIMER_8814B) & BIT_MASK_RX_BCN_TIMER_8814B)
#define BIT_SET_RX_BCN_TIMER_8814B(x, v) \
(BIT_CLEAR_RX_BCN_TIMER_8814B(x) | BIT_RX_BCN_TIMER_8814B(v))
/* 2 REG_TBTT_CTN_AREA_V1_8814B */
#define BIT_SHIFT_TBTT_CTN_AREA_8814B 0
#define BIT_MASK_TBTT_CTN_AREA_8814B 0xff
#define BIT_TBTT_CTN_AREA_8814B(x) \
(((x) & BIT_MASK_TBTT_CTN_AREA_8814B) << BIT_SHIFT_TBTT_CTN_AREA_8814B)
#define BITS_TBTT_CTN_AREA_8814B \
(BIT_MASK_TBTT_CTN_AREA_8814B << BIT_SHIFT_TBTT_CTN_AREA_8814B)
#define BIT_CLEAR_TBTT_CTN_AREA_8814B(x) ((x) & (~BITS_TBTT_CTN_AREA_8814B))
#define BIT_GET_TBTT_CTN_AREA_8814B(x) \
(((x) >> BIT_SHIFT_TBTT_CTN_AREA_8814B) & BIT_MASK_TBTT_CTN_AREA_8814B)
#define BIT_SET_TBTT_CTN_AREA_8814B(x, v) \
(BIT_CLEAR_TBTT_CTN_AREA_8814B(x) | BIT_TBTT_CTN_AREA_8814B(v))
/* 2 REG_BCN_MAX_ERR_V1_8814B */
#define BIT_SHIFT_BCN_MAX_ERR_8814B 0
#define BIT_MASK_BCN_MAX_ERR_8814B 0xff
#define BIT_BCN_MAX_ERR_8814B(x) \
(((x) & BIT_MASK_BCN_MAX_ERR_8814B) << BIT_SHIFT_BCN_MAX_ERR_8814B)
#define BITS_BCN_MAX_ERR_8814B \
(BIT_MASK_BCN_MAX_ERR_8814B << BIT_SHIFT_BCN_MAX_ERR_8814B)
#define BIT_CLEAR_BCN_MAX_ERR_8814B(x) ((x) & (~BITS_BCN_MAX_ERR_8814B))
#define BIT_GET_BCN_MAX_ERR_8814B(x) \
(((x) >> BIT_SHIFT_BCN_MAX_ERR_8814B) & BIT_MASK_BCN_MAX_ERR_8814B)
#define BIT_SET_BCN_MAX_ERR_8814B(x, v) \
(BIT_CLEAR_BCN_MAX_ERR_8814B(x) | BIT_BCN_MAX_ERR_8814B(v))
/* 2 REG_RXTSF_OFFSET_CCK_V1_8814B */
#define BIT_SHIFT_CCK_RXTSF_OFFSET_8814B 0
#define BIT_MASK_CCK_RXTSF_OFFSET_8814B 0xff
#define BIT_CCK_RXTSF_OFFSET_8814B(x) \
(((x) & BIT_MASK_CCK_RXTSF_OFFSET_8814B) \
<< BIT_SHIFT_CCK_RXTSF_OFFSET_8814B)
#define BITS_CCK_RXTSF_OFFSET_8814B \
(BIT_MASK_CCK_RXTSF_OFFSET_8814B << BIT_SHIFT_CCK_RXTSF_OFFSET_8814B)
#define BIT_CLEAR_CCK_RXTSF_OFFSET_8814B(x) \
((x) & (~BITS_CCK_RXTSF_OFFSET_8814B))
#define BIT_GET_CCK_RXTSF_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_CCK_RXTSF_OFFSET_8814B) & \
BIT_MASK_CCK_RXTSF_OFFSET_8814B)
#define BIT_SET_CCK_RXTSF_OFFSET_8814B(x, v) \
(BIT_CLEAR_CCK_RXTSF_OFFSET_8814B(x) | BIT_CCK_RXTSF_OFFSET_8814B(v))
/* 2 REG_RXTSF_OFFSET_OFDM_V1_8814B */
#define BIT_SHIFT_OFDM_RXTSF_OFFSET_8814B 0
#define BIT_MASK_OFDM_RXTSF_OFFSET_8814B 0xff
#define BIT_OFDM_RXTSF_OFFSET_8814B(x) \
(((x) & BIT_MASK_OFDM_RXTSF_OFFSET_8814B) \
<< BIT_SHIFT_OFDM_RXTSF_OFFSET_8814B)
#define BITS_OFDM_RXTSF_OFFSET_8814B \
(BIT_MASK_OFDM_RXTSF_OFFSET_8814B << BIT_SHIFT_OFDM_RXTSF_OFFSET_8814B)
#define BIT_CLEAR_OFDM_RXTSF_OFFSET_8814B(x) \
((x) & (~BITS_OFDM_RXTSF_OFFSET_8814B))
#define BIT_GET_OFDM_RXTSF_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_OFDM_RXTSF_OFFSET_8814B) & \
BIT_MASK_OFDM_RXTSF_OFFSET_8814B)
#define BIT_SET_OFDM_RXTSF_OFFSET_8814B(x, v) \
(BIT_CLEAR_OFDM_RXTSF_OFFSET_8814B(x) | BIT_OFDM_RXTSF_OFFSET_8814B(v))
/* 2 REG_SUB_BCN_SPACE_8814B */
#define BIT_SHIFT_SUB_BCN_SPACE_V2_8814B 0
#define BIT_MASK_SUB_BCN_SPACE_V2_8814B 0xff
#define BIT_SUB_BCN_SPACE_V2_8814B(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE_V2_8814B) \
<< BIT_SHIFT_SUB_BCN_SPACE_V2_8814B)
#define BITS_SUB_BCN_SPACE_V2_8814B \
(BIT_MASK_SUB_BCN_SPACE_V2_8814B << BIT_SHIFT_SUB_BCN_SPACE_V2_8814B)
#define BIT_CLEAR_SUB_BCN_SPACE_V2_8814B(x) \
((x) & (~BITS_SUB_BCN_SPACE_V2_8814B))
#define BIT_GET_SUB_BCN_SPACE_V2_8814B(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE_V2_8814B) & \
BIT_MASK_SUB_BCN_SPACE_V2_8814B)
#define BIT_SET_SUB_BCN_SPACE_V2_8814B(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE_V2_8814B(x) | BIT_SUB_BCN_SPACE_V2_8814B(v))
/* 2 REG_MBID_NUM_V1_8814B */
#define BIT_SHIFT_BCN_ERR_PORT_SEL_8814B 4
#define BIT_MASK_BCN_ERR_PORT_SEL_8814B 0xf
#define BIT_BCN_ERR_PORT_SEL_8814B(x) \
(((x) & BIT_MASK_BCN_ERR_PORT_SEL_8814B) \
<< BIT_SHIFT_BCN_ERR_PORT_SEL_8814B)
#define BITS_BCN_ERR_PORT_SEL_8814B \
(BIT_MASK_BCN_ERR_PORT_SEL_8814B << BIT_SHIFT_BCN_ERR_PORT_SEL_8814B)
#define BIT_CLEAR_BCN_ERR_PORT_SEL_8814B(x) \
((x) & (~BITS_BCN_ERR_PORT_SEL_8814B))
#define BIT_GET_BCN_ERR_PORT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_BCN_ERR_PORT_SEL_8814B) & \
BIT_MASK_BCN_ERR_PORT_SEL_8814B)
#define BIT_SET_BCN_ERR_PORT_SEL_8814B(x, v) \
(BIT_CLEAR_BCN_ERR_PORT_SEL_8814B(x) | BIT_BCN_ERR_PORT_SEL_8814B(v))
#define BIT_SHIFT_MBID_BCN_NUM_V1_8814B 0
#define BIT_MASK_MBID_BCN_NUM_V1_8814B 0xf
#define BIT_MBID_BCN_NUM_V1_8814B(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_V1_8814B) \
<< BIT_SHIFT_MBID_BCN_NUM_V1_8814B)
#define BITS_MBID_BCN_NUM_V1_8814B \
(BIT_MASK_MBID_BCN_NUM_V1_8814B << BIT_SHIFT_MBID_BCN_NUM_V1_8814B)
#define BIT_CLEAR_MBID_BCN_NUM_V1_8814B(x) ((x) & (~BITS_MBID_BCN_NUM_V1_8814B))
#define BIT_GET_MBID_BCN_NUM_V1_8814B(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_V1_8814B) & \
BIT_MASK_MBID_BCN_NUM_V1_8814B)
#define BIT_SET_MBID_BCN_NUM_V1_8814B(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_V1_8814B(x) | BIT_MBID_BCN_NUM_V1_8814B(v))
/* 2 REG_MBSSID_CTRL_V1_8814B */
#define BIT_MBID_BCNQ15_EN_8814B BIT(15)
#define BIT_MBID_BCNQ14_EN_8814B BIT(14)
#define BIT_MBID_BCNQ13_EN_8814B BIT(13)
#define BIT_MBID_BCNQ12_EN_8814B BIT(12)
#define BIT_MBID_BCNQ11_EN_8814B BIT(11)
#define BIT_MBID_BCNQ10_EN_8814B BIT(10)
#define BIT_MBID_BCNQ9_EN_8814B BIT(9)
#define BIT_MBID_BCNQ8_EN_8814B BIT(8)
#define BIT_MBID_BCNQ7_EN_8814B BIT(7)
#define BIT_MBID_BCNQ6_EN_8814B BIT(6)
#define BIT_MBID_BCNQ5_EN_8814B BIT(5)
#define BIT_MBID_BCNQ4_EN_8814B BIT(4)
#define BIT_MBID_BCNQ3_EN_8814B BIT(3)
#define BIT_MBID_BCNQ2_EN_8814B BIT(2)
#define BIT_MBID_BCNQ1_EN_8814B BIT(1)
#define BIT_MBID_BCNQ0_EN_8814B BIT(0)
/* 2 REG_USTIME_TSF_V1_8814B */
#define BIT_SHIFT_USTIME_TSF_V1_8814B 0
#define BIT_MASK_USTIME_TSF_V1_8814B 0xff
#define BIT_USTIME_TSF_V1_8814B(x) \
(((x) & BIT_MASK_USTIME_TSF_V1_8814B) << BIT_SHIFT_USTIME_TSF_V1_8814B)
#define BITS_USTIME_TSF_V1_8814B \
(BIT_MASK_USTIME_TSF_V1_8814B << BIT_SHIFT_USTIME_TSF_V1_8814B)
#define BIT_CLEAR_USTIME_TSF_V1_8814B(x) ((x) & (~BITS_USTIME_TSF_V1_8814B))
#define BIT_GET_USTIME_TSF_V1_8814B(x) \
(((x) >> BIT_SHIFT_USTIME_TSF_V1_8814B) & BIT_MASK_USTIME_TSF_V1_8814B)
#define BIT_SET_USTIME_TSF_V1_8814B(x, v) \
(BIT_CLEAR_USTIME_TSF_V1_8814B(x) | BIT_USTIME_TSF_V1_8814B(v))
/* 2 REG_BW_CFG_8814B */
#define BIT_SLEEP_32K_EN_8814B BIT(3)
#define BIT_DIS_MARK_TSF_US_V1_8814B BIT(2)
#define BIT_SHIFT_BW_CFG_8814B 0
#define BIT_MASK_BW_CFG_8814B 0x3
#define BIT_BW_CFG_8814B(x) \
(((x) & BIT_MASK_BW_CFG_8814B) << BIT_SHIFT_BW_CFG_8814B)
#define BITS_BW_CFG_8814B (BIT_MASK_BW_CFG_8814B << BIT_SHIFT_BW_CFG_8814B)
#define BIT_CLEAR_BW_CFG_8814B(x) ((x) & (~BITS_BW_CFG_8814B))
#define BIT_GET_BW_CFG_8814B(x) \
(((x) >> BIT_SHIFT_BW_CFG_8814B) & BIT_MASK_BW_CFG_8814B)
#define BIT_SET_BW_CFG_8814B(x, v) \
(BIT_CLEAR_BW_CFG_8814B(x) | BIT_BW_CFG_8814B(v))
/* 2 REG_ATIMWND_CFG_8814B */
#define BIT_SHIFT_ATIMWND_V1_8814B 0
#define BIT_MASK_ATIMWND_V1_8814B 0xff
#define BIT_ATIMWND_V1_8814B(x) \
(((x) & BIT_MASK_ATIMWND_V1_8814B) << BIT_SHIFT_ATIMWND_V1_8814B)
#define BITS_ATIMWND_V1_8814B \
(BIT_MASK_ATIMWND_V1_8814B << BIT_SHIFT_ATIMWND_V1_8814B)
#define BIT_CLEAR_ATIMWND_V1_8814B(x) ((x) & (~BITS_ATIMWND_V1_8814B))
#define BIT_GET_ATIMWND_V1_8814B(x) \
(((x) >> BIT_SHIFT_ATIMWND_V1_8814B) & BIT_MASK_ATIMWND_V1_8814B)
#define BIT_SET_ATIMWND_V1_8814B(x, v) \
(BIT_CLEAR_ATIMWND_V1_8814B(x) | BIT_ATIMWND_V1_8814B(v))
/* 2 REG_DTIM_COUNTER_CFG_8814B */
#define BIT_SHIFT_DTIM_COUNT_8814B 0
#define BIT_MASK_DTIM_COUNT_8814B 0xff
#define BIT_DTIM_COUNT_8814B(x) \
(((x) & BIT_MASK_DTIM_COUNT_8814B) << BIT_SHIFT_DTIM_COUNT_8814B)
#define BITS_DTIM_COUNT_8814B \
(BIT_MASK_DTIM_COUNT_8814B << BIT_SHIFT_DTIM_COUNT_8814B)
#define BIT_CLEAR_DTIM_COUNT_8814B(x) ((x) & (~BITS_DTIM_COUNT_8814B))
#define BIT_GET_DTIM_COUNT_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_8814B) & BIT_MASK_DTIM_COUNT_8814B)
#define BIT_SET_DTIM_COUNT_8814B(x, v) \
(BIT_CLEAR_DTIM_COUNT_8814B(x) | BIT_DTIM_COUNT_8814B(v))
/* 2 REG_ATIM_DTIM_CTRL_SEL_8814B */
#define BIT_DTIM_BYPASS_V1_8814B BIT(7)
#define BIT_SHIFT_ATIM_DTIM_SEL_8814B 0
#define BIT_MASK_ATIM_DTIM_SEL_8814B 0x1f
#define BIT_ATIM_DTIM_SEL_8814B(x) \
(((x) & BIT_MASK_ATIM_DTIM_SEL_8814B) << BIT_SHIFT_ATIM_DTIM_SEL_8814B)
#define BITS_ATIM_DTIM_SEL_8814B \
(BIT_MASK_ATIM_DTIM_SEL_8814B << BIT_SHIFT_ATIM_DTIM_SEL_8814B)
#define BIT_CLEAR_ATIM_DTIM_SEL_8814B(x) ((x) & (~BITS_ATIM_DTIM_SEL_8814B))
#define BIT_GET_ATIM_DTIM_SEL_8814B(x) \
(((x) >> BIT_SHIFT_ATIM_DTIM_SEL_8814B) & BIT_MASK_ATIM_DTIM_SEL_8814B)
#define BIT_SET_ATIM_DTIM_SEL_8814B(x, v) \
(BIT_CLEAR_ATIM_DTIM_SEL_8814B(x) | BIT_ATIM_DTIM_SEL_8814B(v))
/* 2 REG_ATIMUGT_V1_8814B */
#define BIT_SHIFT_ATIM_URGENT_8814B 0
#define BIT_MASK_ATIM_URGENT_8814B 0xff
#define BIT_ATIM_URGENT_8814B(x) \
(((x) & BIT_MASK_ATIM_URGENT_8814B) << BIT_SHIFT_ATIM_URGENT_8814B)
#define BITS_ATIM_URGENT_8814B \
(BIT_MASK_ATIM_URGENT_8814B << BIT_SHIFT_ATIM_URGENT_8814B)
#define BIT_CLEAR_ATIM_URGENT_8814B(x) ((x) & (~BITS_ATIM_URGENT_8814B))
#define BIT_GET_ATIM_URGENT_8814B(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT_8814B) & BIT_MASK_ATIM_URGENT_8814B)
#define BIT_SET_ATIM_URGENT_8814B(x, v) \
(BIT_CLEAR_ATIM_URGENT_8814B(x) | BIT_ATIM_URGENT_8814B(v))
/* 2 REG_BCNDROPCTRL_V1_8814B */
#define BIT_BEACON_DROP_EN_8814B BIT(7)
#define BIT_SHIFT_BEACON_DROP_IVL_8814B 0
#define BIT_MASK_BEACON_DROP_IVL_8814B 0x7f
#define BIT_BEACON_DROP_IVL_8814B(x) \
(((x) & BIT_MASK_BEACON_DROP_IVL_8814B) \
<< BIT_SHIFT_BEACON_DROP_IVL_8814B)
#define BITS_BEACON_DROP_IVL_8814B \
(BIT_MASK_BEACON_DROP_IVL_8814B << BIT_SHIFT_BEACON_DROP_IVL_8814B)
#define BIT_CLEAR_BEACON_DROP_IVL_8814B(x) ((x) & (~BITS_BEACON_DROP_IVL_8814B))
#define BIT_GET_BEACON_DROP_IVL_8814B(x) \
(((x) >> BIT_SHIFT_BEACON_DROP_IVL_8814B) & \
BIT_MASK_BEACON_DROP_IVL_8814B)
#define BIT_SET_BEACON_DROP_IVL_8814B(x, v) \
(BIT_CLEAR_BEACON_DROP_IVL_8814B(x) | BIT_BEACON_DROP_IVL_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_DIS_ATIM_V1_8814B */
#define BIT_DIS_ATIM_P4_8814B BIT(19)
#define BIT_DIS_ATIM_P3_8814B BIT(18)
#define BIT_DIS_ATIM_P2_8814B BIT(17)
#define BIT_DIS_ATIM_P1_8814B BIT(16)
#define BIT_DIS_ATIM_VAP15_8814B BIT(15)
#define BIT_DIS_ATIM_VAP14_8814B BIT(14)
#define BIT_DIS_ATIM_VAP13_8814B BIT(13)
#define BIT_DIS_ATIM_VAP12_8814B BIT(12)
#define BIT_DIS_ATIM_VAP11_8814B BIT(11)
#define BIT_DIS_ATIM_VAP10_8814B BIT(10)
#define BIT_DIS_ATIM_VAP9_8814B BIT(9)
#define BIT_DIS_ATIM_VAP8_8814B BIT(8)
#define BIT_DIS_ATIM_VAP7_8814B BIT(7)
#define BIT_DIS_ATIM_VAP6_8814B BIT(6)
#define BIT_DIS_ATIM_VAP5_8814B BIT(5)
#define BIT_DIS_ATIM_VAP4_8814B BIT(4)
#define BIT_DIS_ATIM_VAP3_8814B BIT(3)
#define BIT_DIS_ATIM_VAP2_8814B BIT(2)
#define BIT_DIS_ATIM_VAP1_8814B BIT(1)
#define BIT_DIS_ATIM_ROOT_P0_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_HIQ_NO_LMT_EN_V1_8814B */
#define BIT_HIQ_NO_LMT_EN_P4_8814B BIT(19)
#define BIT_HIQ_NO_LMT_EN_P3_8814B BIT(18)
#define BIT_HIQ_NO_LMT_EN_P2_8814B BIT(17)
#define BIT_HIQ_NO_LMT_EN_P1_8814B BIT(16)
#define BIT_HIQ_NO_LMT_EN_VAP15_8814B BIT(15)
#define BIT_HIQ_NO_LMT_EN_VAP14_8814B BIT(14)
#define BIT_HIQ_NO_LMT_EN_VAP13_8814B BIT(13)
#define BIT_HIQ_NO_LMT_EN_VAP12_8814B BIT(12)
#define BIT_HIQ_NO_LMT_EN_VAP11_8814B BIT(11)
#define BIT_HIQ_NO_LMT_EN_VAP10_8814B BIT(10)
#define BIT_HIQ_NO_LMT_EN_VAP9_8814B BIT(9)
#define BIT_HIQ_NO_LMT_EN_VAP8_8814B BIT(8)
#define BIT_HIQ_NO_LMT_EN_VAP7_8814B BIT(7)
#define BIT_HIQ_NO_LMT_EN_VAP6_8814B BIT(6)
#define BIT_HIQ_NO_LMT_EN_VAP5_8814B BIT(5)
#define BIT_HIQ_NO_LMT_EN_VAP4_8814B BIT(4)
#define BIT_HIQ_NO_LMT_EN_VAP3_8814B BIT(3)
#define BIT_HIQ_NO_LMT_EN_VAP2_8814B BIT(2)
#define BIT_HIQ_NO_LMT_EN_VAP1_8814B BIT(1)
#define BIT_HIQ_NO_LMT_EN_ROOT_P0_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_P2PPS_CTRL_V1_8814B */
#define BIT_P2P_PWR_RST1_V2_8814B BIT(15)
#define BIT_P2P_PWR_RST0_V2_8814B BIT(14)
#define BIT_EN_TSFBIT32_RST_P2P_V1_8814B BIT(13)
#define BIT_SHIFT_NOA_UNIT0_SEL_V1_8814B 8
#define BIT_MASK_NOA_UNIT0_SEL_V1_8814B 0x7
#define BIT_NOA_UNIT0_SEL_V1_8814B(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL_V1_8814B) \
<< BIT_SHIFT_NOA_UNIT0_SEL_V1_8814B)
#define BITS_NOA_UNIT0_SEL_V1_8814B \
(BIT_MASK_NOA_UNIT0_SEL_V1_8814B << BIT_SHIFT_NOA_UNIT0_SEL_V1_8814B)
#define BIT_CLEAR_NOA_UNIT0_SEL_V1_8814B(x) \
((x) & (~BITS_NOA_UNIT0_SEL_V1_8814B))
#define BIT_GET_NOA_UNIT0_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL_V1_8814B) & \
BIT_MASK_NOA_UNIT0_SEL_V1_8814B)
#define BIT_SET_NOA_UNIT0_SEL_V1_8814B(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL_V1_8814B(x) | BIT_NOA_UNIT0_SEL_V1_8814B(v))
#define BIT_P2P_CTW_ALLSTASLEEP_V1_8814B BIT(7)
#define BIT_P2P_OFF_DISTX_EN_V1_8814B BIT(6)
#define BIT_PWR_MGT_EN_V1_8814B BIT(5)
#define BIT_P2P_NOA1_EN_V1_8814B BIT(2)
#define BIT_P2P_NOA0_EN_V1_8814B BIT(1)
/* 2 REG_P2PPS_SPEC_STATE_V1_8814B */
#define BIT_SPEC_POWER_STATE_8814B BIT(7)
#define BIT_SPEC_CTWINDOW_ON_8814B BIT(6)
#define BIT_SPEC_BEACON_AREA_ON_8814B BIT(5)
#define BIT_SPEC_CTWIN_EARLY_DISTX_8814B BIT(4)
#define BIT_SPEC_NOA1_OFF_PERIOD_8814B BIT(3)
#define BIT_SPEC_FORCE_DOZE1_8814B BIT(2)
#define BIT_SPEC_NOA0_OFF_PERIOD_8814B BIT(1)
#define BIT_SPEC_FORCE_DOZE0_8814B BIT(0)
/* 2 REG_P2PPS_STATE_V1_8814B */
#define BIT_POWER_STATE_8814B BIT(7)
#define BIT_CTWINDOW_ON_8814B BIT(6)
#define BIT_BEACON_AREA_ON_8814B BIT(5)
#define BIT_CTWIN_EARLY_DISTX_8814B BIT(4)
#define BIT_NOA1_OFF_PERIOD_8814B BIT(3)
#define BIT_FORCE_DOZE1_8814B BIT(2)
#define BIT_NOA0_OFF_PERIOD_8814B BIT(1)
#define BIT_FORCE_DOZE0_8814B BIT(0)
/* 2 REG_P2PPS1_CTRL_V1_8814B */
#define BIT_P2P1_PWR_RST1_V2_8814B BIT(15)
#define BIT_P2P1_PWR_RST0_V2_8814B BIT(14)
#define BIT_EN_TSFBIT32_RST_P2P1_V1_8814B BIT(13)
#define BIT_SHIFT_NOA_UNIT1_SEL_V1_8814B 8
#define BIT_MASK_NOA_UNIT1_SEL_V1_8814B 0x7
#define BIT_NOA_UNIT1_SEL_V1_8814B(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL_V1_8814B) \
<< BIT_SHIFT_NOA_UNIT1_SEL_V1_8814B)
#define BITS_NOA_UNIT1_SEL_V1_8814B \
(BIT_MASK_NOA_UNIT1_SEL_V1_8814B << BIT_SHIFT_NOA_UNIT1_SEL_V1_8814B)
#define BIT_CLEAR_NOA_UNIT1_SEL_V1_8814B(x) \
((x) & (~BITS_NOA_UNIT1_SEL_V1_8814B))
#define BIT_GET_NOA_UNIT1_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL_V1_8814B) & \
BIT_MASK_NOA_UNIT1_SEL_V1_8814B)
#define BIT_SET_NOA_UNIT1_SEL_V1_8814B(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL_V1_8814B(x) | BIT_NOA_UNIT1_SEL_V1_8814B(v))
#define BIT_P2P1_CTW_ALLSTASLEEP_V1_8814B BIT(7)
#define BIT_P2P1_OFF_DISTX_EN_8814B BIT(6)
#define BIT_P2P1_PWR_MGT_EN_V1_8814B BIT(5)
#define BIT_P2P1_NOA1_EN_V1_8814B BIT(2)
#define BIT_P2P1_NOA0_EN_V1_8814B BIT(1)
/* 2 REG_P2PPS1_SPEC_STATE_V1_8814B */
#define BIT_P2P1_SPEC_POWER_STATEP_8814B BIT(7)
#define BIT_P2P1_SPEC_CTWINDOW_ON_8814B BIT(6)
#define BIT_P2P1_SPEC_BEACON_AREA_ON_8814B BIT(5)
#define BIT_P2P1_SPEC_CTWIN_EARLY_DISTX_8814B BIT(4)
#define BIT_P2P1_SPEC_NOA1_OFF_PERIOD_8814B BIT(3)
#define BIT_P2P1_SPEC_FORCE_DOZE1_8814B BIT(2)
#define BIT_P2P1_SPEC_NOA0_OFF_PERIOD_8814B BIT(1)
#define BIT_P2P1_SPEC_FORCE_DOZE0_8814B BIT(0)
/* 2 REG_P2PPS1_STATE_V1_8814B */
#define BIT_P2P1_POWER_STATE_8814B BIT(7)
#define BIT_P2P1_CTWINDOW_ON_8814B BIT(6)
#define BIT_P2P1_BEACON_AREA_ON_8814B BIT(5)
#define BIT_P2P1_CTWIN_EARLY_DISTX_8814B BIT(4)
#define BIT_P2P1_NOA1_OFF_PERIOD_8814B BIT(3)
#define BIT_P2P1_FORCE_DOZE1_8814B BIT(2)
#define BIT_P2P1_NOA0_OFF_PERIOD_8814B BIT(1)
#define BIT_P2P1_FORCE_DOZE0_8814B BIT(0)
/* 2 REG_P2PPS2_CTRL_V1_8814B */
#define BIT_P2P2_PWR_RST1_V2_8814B BIT(15)
#define BIT_P2P2_PWR_RST0_V2_8814B BIT(14)
#define BIT_EN_TSFBIT32_RST_P2P2_V1_8814B BIT(13)
#define BIT_SHIFT_NOA_UNIT2_SEL_V1_8814B 8
#define BIT_MASK_NOA_UNIT2_SEL_V1_8814B 0x7
#define BIT_NOA_UNIT2_SEL_V1_8814B(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL_V1_8814B) \
<< BIT_SHIFT_NOA_UNIT2_SEL_V1_8814B)
#define BITS_NOA_UNIT2_SEL_V1_8814B \
(BIT_MASK_NOA_UNIT2_SEL_V1_8814B << BIT_SHIFT_NOA_UNIT2_SEL_V1_8814B)
#define BIT_CLEAR_NOA_UNIT2_SEL_V1_8814B(x) \
((x) & (~BITS_NOA_UNIT2_SEL_V1_8814B))
#define BIT_GET_NOA_UNIT2_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL_V1_8814B) & \
BIT_MASK_NOA_UNIT2_SEL_V1_8814B)
#define BIT_SET_NOA_UNIT2_SEL_V1_8814B(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL_V1_8814B(x) | BIT_NOA_UNIT2_SEL_V1_8814B(v))
#define BIT_P2P2_CTW_ALLSTASLEEP_V1_8814B BIT(7)
#define BIT_P2P2_OFF_DISTX_EN_V1_8814B BIT(6)
#define BIT_P2P2_PWR_MGT_EN_V1_8814B BIT(5)
#define BIT_P2P2_NOA1_EN_V1_8814B BIT(2)
#define BIT_P2P2_NOA0_EN_V1_8814B BIT(1)
/* 2 REG_P2PPS2_SPEC_STATE_V1_8814B */
#define BIT_P2P2_SPEC_POWER_STATEP_8814B BIT(7)
#define BIT_P2P2_SPEC_CTWINDOW_ON_8814B BIT(6)
#define BIT_P2P2_SPEC_BEACON_AREA_ON_8814B BIT(5)
#define BIT_P2P2_SPEC_CTWIN_EARLY_DISTX_8814B BIT(4)
#define BIT_P2P2_SPEC_NOA1_OFF_PERIOD_8814B BIT(3)
#define BIT_P2P2_SPEC_FORCE_DOZE1_8814B BIT(2)
#define BIT_P2P2_SPEC_NOA0_OFF_PERIOD_8814B BIT(1)
#define BIT_P2P2_SPEC_FORCE_DOZE0_8814B BIT(0)
/* 2 REG_P2PPS2_STATE_V1_8814B */
#define BIT_P2P2_POWER_STATE_8814B BIT(7)
#define BIT_P2P2_CTWINDOW_ON_8814B BIT(6)
#define BIT_P2P2_BEACON_AREA_ON_8814B BIT(5)
#define BIT_P2P2_CTWIN_EARLY_DISTX_8814B BIT(4)
#define BIT_P2P2_NOA1_OFF_PERIOD_8814B BIT(3)
#define BIT_P2P2_FORCE_DOZE1_8814B BIT(2)
#define BIT_P2P2_NOA0_OFF_PERIOD_8814B BIT(1)
#define BIT_P2P2_FORCE_DOZE0_8814B BIT(0)
/* 2 REG_P2PON_DIS_TXTIME_V1_8814B */
#define BIT_SHIFT_P2PON_DIS_TXTIME_8814B 0
#define BIT_MASK_P2PON_DIS_TXTIME_8814B 0xff
#define BIT_P2PON_DIS_TXTIME_8814B(x) \
(((x) & BIT_MASK_P2PON_DIS_TXTIME_8814B) \
<< BIT_SHIFT_P2PON_DIS_TXTIME_8814B)
#define BITS_P2PON_DIS_TXTIME_8814B \
(BIT_MASK_P2PON_DIS_TXTIME_8814B << BIT_SHIFT_P2PON_DIS_TXTIME_8814B)
#define BIT_CLEAR_P2PON_DIS_TXTIME_8814B(x) \
((x) & (~BITS_P2PON_DIS_TXTIME_8814B))
#define BIT_GET_P2PON_DIS_TXTIME_8814B(x) \
(((x) >> BIT_SHIFT_P2PON_DIS_TXTIME_8814B) & \
BIT_MASK_P2PON_DIS_TXTIME_8814B)
#define BIT_SET_P2PON_DIS_TXTIME_8814B(x, v) \
(BIT_CLEAR_P2PON_DIS_TXTIME_8814B(x) | BIT_P2PON_DIS_TXTIME_8814B(v))
/* 2 REG_P2POFF_DIS_TXTIME_V1_8814B */
#define BIT_SHIFT_P2POFF_DIS_TXTIME_8814B 0
#define BIT_MASK_P2POFF_DIS_TXTIME_8814B 0xff
#define BIT_P2POFF_DIS_TXTIME_8814B(x) \
(((x) & BIT_MASK_P2POFF_DIS_TXTIME_8814B) \
<< BIT_SHIFT_P2POFF_DIS_TXTIME_8814B)
#define BITS_P2POFF_DIS_TXTIME_8814B \
(BIT_MASK_P2POFF_DIS_TXTIME_8814B << BIT_SHIFT_P2POFF_DIS_TXTIME_8814B)
#define BIT_CLEAR_P2POFF_DIS_TXTIME_8814B(x) \
((x) & (~BITS_P2POFF_DIS_TXTIME_8814B))
#define BIT_GET_P2POFF_DIS_TXTIME_8814B(x) \
(((x) >> BIT_SHIFT_P2POFF_DIS_TXTIME_8814B) & \
BIT_MASK_P2POFF_DIS_TXTIME_8814B)
#define BIT_SET_P2POFF_DIS_TXTIME_8814B(x, v) \
(BIT_CLEAR_P2POFF_DIS_TXTIME_8814B(x) | BIT_P2POFF_DIS_TXTIME_8814B(v))
/* 2 REG_CHG_POWER_BCN_AREA_8814B */
#define BIT_CHG_POWER_BCN_AREA_8814B BIT(0)
/* 2 REG_NOA_SEL_8814B */
#define BIT_SHIFT_NOA_SEL_V1_8814B 0
#define BIT_MASK_NOA_SEL_V1_8814B 0x7
#define BIT_NOA_SEL_V1_8814B(x) \
(((x) & BIT_MASK_NOA_SEL_V1_8814B) << BIT_SHIFT_NOA_SEL_V1_8814B)
#define BITS_NOA_SEL_V1_8814B \
(BIT_MASK_NOA_SEL_V1_8814B << BIT_SHIFT_NOA_SEL_V1_8814B)
#define BIT_CLEAR_NOA_SEL_V1_8814B(x) ((x) & (~BITS_NOA_SEL_V1_8814B))
#define BIT_GET_NOA_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V1_8814B) & BIT_MASK_NOA_SEL_V1_8814B)
#define BIT_SET_NOA_SEL_V1_8814B(x, v) \
(BIT_CLEAR_NOA_SEL_V1_8814B(x) | BIT_NOA_SEL_V1_8814B(v))
/* 2 REG_NOA_PARAM_V1_8814B */
#define BIT_SHIFT_NOA_DURATION_8814B 0
#define BIT_MASK_NOA_DURATION_8814B 0xffffffffL
#define BIT_NOA_DURATION_8814B(x) \
(((x) & BIT_MASK_NOA_DURATION_8814B) << BIT_SHIFT_NOA_DURATION_8814B)
#define BITS_NOA_DURATION_8814B \
(BIT_MASK_NOA_DURATION_8814B << BIT_SHIFT_NOA_DURATION_8814B)
#define BIT_CLEAR_NOA_DURATION_8814B(x) ((x) & (~BITS_NOA_DURATION_8814B))
#define BIT_GET_NOA_DURATION_8814B(x) \
(((x) >> BIT_SHIFT_NOA_DURATION_8814B) & BIT_MASK_NOA_DURATION_8814B)
#define BIT_SET_NOA_DURATION_8814B(x, v) \
(BIT_CLEAR_NOA_DURATION_8814B(x) | BIT_NOA_DURATION_8814B(v))
/* 2 REG_NOA_PARAM_1_V1_8814B */
#define BIT_SHIFT_NOA_INTERVAL_8814B 0
#define BIT_MASK_NOA_INTERVAL_8814B 0xffffffffL
#define BIT_NOA_INTERVAL_8814B(x) \
(((x) & BIT_MASK_NOA_INTERVAL_8814B) << BIT_SHIFT_NOA_INTERVAL_8814B)
#define BITS_NOA_INTERVAL_8814B \
(BIT_MASK_NOA_INTERVAL_8814B << BIT_SHIFT_NOA_INTERVAL_8814B)
#define BIT_CLEAR_NOA_INTERVAL_8814B(x) ((x) & (~BITS_NOA_INTERVAL_8814B))
#define BIT_GET_NOA_INTERVAL_8814B(x) \
(((x) >> BIT_SHIFT_NOA_INTERVAL_8814B) & BIT_MASK_NOA_INTERVAL_8814B)
#define BIT_SET_NOA_INTERVAL_8814B(x, v) \
(BIT_CLEAR_NOA_INTERVAL_8814B(x) | BIT_NOA_INTERVAL_8814B(v))
/* 2 REG_NOA_PARAM_2_V1_8814B */
#define BIT_SHIFT_NOA_START_TIME_8814B 0
#define BIT_MASK_NOA_START_TIME_8814B 0xffffffffL
#define BIT_NOA_START_TIME_8814B(x) \
(((x) & BIT_MASK_NOA_START_TIME_8814B) \
<< BIT_SHIFT_NOA_START_TIME_8814B)
#define BITS_NOA_START_TIME_8814B \
(BIT_MASK_NOA_START_TIME_8814B << BIT_SHIFT_NOA_START_TIME_8814B)
#define BIT_CLEAR_NOA_START_TIME_8814B(x) ((x) & (~BITS_NOA_START_TIME_8814B))
#define BIT_GET_NOA_START_TIME_8814B(x) \
(((x) >> BIT_SHIFT_NOA_START_TIME_8814B) & \
BIT_MASK_NOA_START_TIME_8814B)
#define BIT_SET_NOA_START_TIME_8814B(x, v) \
(BIT_CLEAR_NOA_START_TIME_8814B(x) | BIT_NOA_START_TIME_8814B(v))
/* 2 REG_NOA_PARAM_3_V1_8814B */
#define BIT_SHIFT_NOA_COUNT_V2_8814B 0
#define BIT_MASK_NOA_COUNT_V2_8814B 0xffffffffL
#define BIT_NOA_COUNT_V2_8814B(x) \
(((x) & BIT_MASK_NOA_COUNT_V2_8814B) << BIT_SHIFT_NOA_COUNT_V2_8814B)
#define BITS_NOA_COUNT_V2_8814B \
(BIT_MASK_NOA_COUNT_V2_8814B << BIT_SHIFT_NOA_COUNT_V2_8814B)
#define BIT_CLEAR_NOA_COUNT_V2_8814B(x) ((x) & (~BITS_NOA_COUNT_V2_8814B))
#define BIT_GET_NOA_COUNT_V2_8814B(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_V2_8814B) & BIT_MASK_NOA_COUNT_V2_8814B)
#define BIT_SET_NOA_COUNT_V2_8814B(x, v) \
(BIT_CLEAR_NOA_COUNT_V2_8814B(x) | BIT_NOA_COUNT_V2_8814B(v))
/* 2 REG_NOA_ON_ERLY_TIME_V1_8814B */
#define BIT_SHIFT__NOA_ON_ERLY_TIME_8814B 0
#define BIT_MASK__NOA_ON_ERLY_TIME_8814B 0xff
#define BIT__NOA_ON_ERLY_TIME_8814B(x) \
(((x) & BIT_MASK__NOA_ON_ERLY_TIME_8814B) \
<< BIT_SHIFT__NOA_ON_ERLY_TIME_8814B)
#define BITS__NOA_ON_ERLY_TIME_8814B \
(BIT_MASK__NOA_ON_ERLY_TIME_8814B << BIT_SHIFT__NOA_ON_ERLY_TIME_8814B)
#define BIT_CLEAR__NOA_ON_ERLY_TIME_8814B(x) \
((x) & (~BITS__NOA_ON_ERLY_TIME_8814B))
#define BIT_GET__NOA_ON_ERLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT__NOA_ON_ERLY_TIME_8814B) & \
BIT_MASK__NOA_ON_ERLY_TIME_8814B)
#define BIT_SET__NOA_ON_ERLY_TIME_8814B(x, v) \
(BIT_CLEAR__NOA_ON_ERLY_TIME_8814B(x) | BIT__NOA_ON_ERLY_TIME_8814B(v))
/* 2 REG_NOA_OFF_ERLY_TIME_V1_8814B */
#define BIT_SHIFT__NOA_OFF_ERLY_TIME_8814B 0
#define BIT_MASK__NOA_OFF_ERLY_TIME_8814B 0xff
#define BIT__NOA_OFF_ERLY_TIME_8814B(x) \
(((x) & BIT_MASK__NOA_OFF_ERLY_TIME_8814B) \
<< BIT_SHIFT__NOA_OFF_ERLY_TIME_8814B)
#define BITS__NOA_OFF_ERLY_TIME_8814B \
(BIT_MASK__NOA_OFF_ERLY_TIME_8814B \
<< BIT_SHIFT__NOA_OFF_ERLY_TIME_8814B)
#define BIT_CLEAR__NOA_OFF_ERLY_TIME_8814B(x) \
((x) & (~BITS__NOA_OFF_ERLY_TIME_8814B))
#define BIT_GET__NOA_OFF_ERLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT__NOA_OFF_ERLY_TIME_8814B) & \
BIT_MASK__NOA_OFF_ERLY_TIME_8814B)
#define BIT_SET__NOA_OFF_ERLY_TIME_8814B(x, v) \
(BIT_CLEAR__NOA_OFF_ERLY_TIME_8814B(x) | \
BIT__NOA_OFF_ERLY_TIME_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_P2PPS_HW_AUTO_PAUSE_CTRL_8814B */
#define BIT_P2PPS_NOA_STOP_TX_HANG_8814B BIT(31)
#define BIT_P2PPS_MACID_PAUSE_EN_8814B BIT(11)
#define BIT_P2PPS__MGQ_PAUSE_8814B BIT(10)
#define BIT_P2PPS__HIQ_PAUSE_8814B BIT(9)
#define BIT_P2PPS__BCNQ_PAUSE_8814B BIT(8)
#define BIT_SHIFT_P2PPS_MACID_PAUSE_8814B 0
#define BIT_MASK_P2PPS_MACID_PAUSE_8814B 0xff
#define BIT_P2PPS_MACID_PAUSE_8814B(x) \
(((x) & BIT_MASK_P2PPS_MACID_PAUSE_8814B) \
<< BIT_SHIFT_P2PPS_MACID_PAUSE_8814B)
#define BITS_P2PPS_MACID_PAUSE_8814B \
(BIT_MASK_P2PPS_MACID_PAUSE_8814B << BIT_SHIFT_P2PPS_MACID_PAUSE_8814B)
#define BIT_CLEAR_P2PPS_MACID_PAUSE_8814B(x) \
((x) & (~BITS_P2PPS_MACID_PAUSE_8814B))
#define BIT_GET_P2PPS_MACID_PAUSE_8814B(x) \
(((x) >> BIT_SHIFT_P2PPS_MACID_PAUSE_8814B) & \
BIT_MASK_P2PPS_MACID_PAUSE_8814B)
#define BIT_SET_P2PPS_MACID_PAUSE_8814B(x, v) \
(BIT_CLEAR_P2PPS_MACID_PAUSE_8814B(x) | BIT_P2PPS_MACID_PAUSE_8814B(v))
/* 2 REG_P2PPS1_HW_AUTO_PAUSE_CTRL_8814B */
#define BIT_P2PPS1_NOA_STOP_TX_HANG_8814B BIT(31)
#define BIT_P2PPS1_MACID_PAUSE_EN_8814B BIT(11)
#define BIT_P2PPS1__MGQ_PAUSE_8814B BIT(10)
#define BIT_P2PPS1__HIQ_PAUSE_8814B BIT(9)
#define BIT_P2PPS1__BCNQ_PAUSE_8814B BIT(8)
#define BIT_SHIFT_P2PPS1_MACID_PAUSE_8814B 0
#define BIT_MASK_P2PPS1_MACID_PAUSE_8814B 0xff
#define BIT_P2PPS1_MACID_PAUSE_8814B(x) \
(((x) & BIT_MASK_P2PPS1_MACID_PAUSE_8814B) \
<< BIT_SHIFT_P2PPS1_MACID_PAUSE_8814B)
#define BITS_P2PPS1_MACID_PAUSE_8814B \
(BIT_MASK_P2PPS1_MACID_PAUSE_8814B \
<< BIT_SHIFT_P2PPS1_MACID_PAUSE_8814B)
#define BIT_CLEAR_P2PPS1_MACID_PAUSE_8814B(x) \
((x) & (~BITS_P2PPS1_MACID_PAUSE_8814B))
#define BIT_GET_P2PPS1_MACID_PAUSE_8814B(x) \
(((x) >> BIT_SHIFT_P2PPS1_MACID_PAUSE_8814B) & \
BIT_MASK_P2PPS1_MACID_PAUSE_8814B)
#define BIT_SET_P2PPS1_MACID_PAUSE_8814B(x, v) \
(BIT_CLEAR_P2PPS1_MACID_PAUSE_8814B(x) | \
BIT_P2PPS1_MACID_PAUSE_8814B(v))
/* 2 REG_P2PPS2_HW_AUTO_PAUSE_CTRL_8814B */
#define BIT_P2PPS2_NOA_STOP_TX_HANG_8814B BIT(31)
#define BIT_P2PPS2_MACID_PAUSE_EN_8814B BIT(11)
#define BIT_P2PPS2__MGQ_PAUSE_8814B BIT(10)
#define BIT_P2PPS2__HIQ_PAUSE_8814B BIT(9)
#define BIT_P2PPS2__BCNQ_PAUSE_8814B BIT(8)
#define BIT_SHIFT_P2PPS2_MACID_PAUSE_8814B 0
#define BIT_MASK_P2PPS2_MACID_PAUSE_8814B 0xff
#define BIT_P2PPS2_MACID_PAUSE_8814B(x) \
(((x) & BIT_MASK_P2PPS2_MACID_PAUSE_8814B) \
<< BIT_SHIFT_P2PPS2_MACID_PAUSE_8814B)
#define BITS_P2PPS2_MACID_PAUSE_8814B \
(BIT_MASK_P2PPS2_MACID_PAUSE_8814B \
<< BIT_SHIFT_P2PPS2_MACID_PAUSE_8814B)
#define BIT_CLEAR_P2PPS2_MACID_PAUSE_8814B(x) \
((x) & (~BITS_P2PPS2_MACID_PAUSE_8814B))
#define BIT_GET_P2PPS2_MACID_PAUSE_8814B(x) \
(((x) >> BIT_SHIFT_P2PPS2_MACID_PAUSE_8814B) & \
BIT_MASK_P2PPS2_MACID_PAUSE_8814B)
#define BIT_SET_P2PPS2_MACID_PAUSE_8814B(x, v) \
(BIT_CLEAR_P2PPS2_MACID_PAUSE_8814B(x) | \
BIT_P2PPS2_MACID_PAUSE_8814B(v))
/* 2 REG_RX_TBTT_SHIFT_8814B */
#define BIT_SHIFT_RX_TBTT_SHIFT_SEL_8814B 24
#define BIT_MASK_RX_TBTT_SHIFT_SEL_8814B 0x7
#define BIT_RX_TBTT_SHIFT_SEL_8814B(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_SEL_8814B) \
<< BIT_SHIFT_RX_TBTT_SHIFT_SEL_8814B)
#define BITS_RX_TBTT_SHIFT_SEL_8814B \
(BIT_MASK_RX_TBTT_SHIFT_SEL_8814B << BIT_SHIFT_RX_TBTT_SHIFT_SEL_8814B)
#define BIT_CLEAR_RX_TBTT_SHIFT_SEL_8814B(x) \
((x) & (~BITS_RX_TBTT_SHIFT_SEL_8814B))
#define BIT_GET_RX_TBTT_SHIFT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_SEL_8814B) & \
BIT_MASK_RX_TBTT_SHIFT_SEL_8814B)
#define BIT_SET_RX_TBTT_SHIFT_SEL_8814B(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_SEL_8814B(x) | BIT_RX_TBTT_SHIFT_SEL_8814B(v))
#define BIT_RX_TBTT_SHIFT_RW_FLAG_8814B BIT(15)
#define BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_8814B 0
#define BIT_MASK_RX_TBTT_SHIFT_OFFSET_8814B 0xfff
#define BIT_RX_TBTT_SHIFT_OFFSET_8814B(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_OFFSET_8814B) \
<< BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_8814B)
#define BITS_RX_TBTT_SHIFT_OFFSET_8814B \
(BIT_MASK_RX_TBTT_SHIFT_OFFSET_8814B \
<< BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_8814B)
#define BIT_CLEAR_RX_TBTT_SHIFT_OFFSET_8814B(x) \
((x) & (~BITS_RX_TBTT_SHIFT_OFFSET_8814B))
#define BIT_GET_RX_TBTT_SHIFT_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_8814B) & \
BIT_MASK_RX_TBTT_SHIFT_OFFSET_8814B)
#define BIT_SET_RX_TBTT_SHIFT_OFFSET_8814B(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_OFFSET_8814B(x) | \
BIT_RX_TBTT_SHIFT_OFFSET_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_FREERUN_CNT_LOW_8814B */
#define BIT_SHIFT_FREERUN_CNT_LOW_8814B 0
#define BIT_MASK_FREERUN_CNT_LOW_8814B 0xffffffffL
#define BIT_FREERUN_CNT_LOW_8814B(x) \
(((x) & BIT_MASK_FREERUN_CNT_LOW_8814B) \
<< BIT_SHIFT_FREERUN_CNT_LOW_8814B)
#define BITS_FREERUN_CNT_LOW_8814B \
(BIT_MASK_FREERUN_CNT_LOW_8814B << BIT_SHIFT_FREERUN_CNT_LOW_8814B)
#define BIT_CLEAR_FREERUN_CNT_LOW_8814B(x) ((x) & (~BITS_FREERUN_CNT_LOW_8814B))
#define BIT_GET_FREERUN_CNT_LOW_8814B(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_LOW_8814B) & \
BIT_MASK_FREERUN_CNT_LOW_8814B)
#define BIT_SET_FREERUN_CNT_LOW_8814B(x, v) \
(BIT_CLEAR_FREERUN_CNT_LOW_8814B(x) | BIT_FREERUN_CNT_LOW_8814B(v))
/* 2 REG_FREERUN_CNT_HIGH_8814B */
#define BIT_SHIFT_FREERUN_CNT_HIGH_8814B 0
#define BIT_MASK_FREERUN_CNT_HIGH_8814B 0xffffffffL
#define BIT_FREERUN_CNT_HIGH_8814B(x) \
(((x) & BIT_MASK_FREERUN_CNT_HIGH_8814B) \
<< BIT_SHIFT_FREERUN_CNT_HIGH_8814B)
#define BITS_FREERUN_CNT_HIGH_8814B \
(BIT_MASK_FREERUN_CNT_HIGH_8814B << BIT_SHIFT_FREERUN_CNT_HIGH_8814B)
#define BIT_CLEAR_FREERUN_CNT_HIGH_8814B(x) \
((x) & (~BITS_FREERUN_CNT_HIGH_8814B))
#define BIT_GET_FREERUN_CNT_HIGH_8814B(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_HIGH_8814B) & \
BIT_MASK_FREERUN_CNT_HIGH_8814B)
#define BIT_SET_FREERUN_CNT_HIGH_8814B(x, v) \
(BIT_CLEAR_FREERUN_CNT_HIGH_8814B(x) | BIT_FREERUN_CNT_HIGH_8814B(v))
/* 2 REG_CPUMGQ_TX_TIMER_V1_8814B */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8814B 0
#define BIT_MASK_CPUMGQ_TX_TIMER_V1_8814B 0xffffffffL
#define BIT_CPUMGQ_TX_TIMER_V1_8814B(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_V1_8814B) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8814B)
#define BITS_CPUMGQ_TX_TIMER_V1_8814B \
(BIT_MASK_CPUMGQ_TX_TIMER_V1_8814B \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8814B)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8814B(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_V1_8814B))
#define BIT_GET_CPUMGQ_TX_TIMER_V1_8814B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8814B) & \
BIT_MASK_CPUMGQ_TX_TIMER_V1_8814B)
#define BIT_SET_CPUMGQ_TX_TIMER_V1_8814B(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8814B(x) | \
BIT_CPUMGQ_TX_TIMER_V1_8814B(v))
/* 2 REG_PS_TIMER_0_8814B */
#define BIT_SHIFT_PS_TIMER_0_8814B 0
#define BIT_MASK_PS_TIMER_0_8814B 0xffffffffL
#define BIT_PS_TIMER_0_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_0_8814B) << BIT_SHIFT_PS_TIMER_0_8814B)
#define BITS_PS_TIMER_0_8814B \
(BIT_MASK_PS_TIMER_0_8814B << BIT_SHIFT_PS_TIMER_0_8814B)
#define BIT_CLEAR_PS_TIMER_0_8814B(x) ((x) & (~BITS_PS_TIMER_0_8814B))
#define BIT_GET_PS_TIMER_0_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_0_8814B) & BIT_MASK_PS_TIMER_0_8814B)
#define BIT_SET_PS_TIMER_0_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_0_8814B(x) | BIT_PS_TIMER_0_8814B(v))
/* 2 REG_PS_TIMER_1_8814B */
#define BIT_SHIFT_PS_TIMER_1_8814B 0
#define BIT_MASK_PS_TIMER_1_8814B 0xffffffffL
#define BIT_PS_TIMER_1_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_1_8814B) << BIT_SHIFT_PS_TIMER_1_8814B)
#define BITS_PS_TIMER_1_8814B \
(BIT_MASK_PS_TIMER_1_8814B << BIT_SHIFT_PS_TIMER_1_8814B)
#define BIT_CLEAR_PS_TIMER_1_8814B(x) ((x) & (~BITS_PS_TIMER_1_8814B))
#define BIT_GET_PS_TIMER_1_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_1_8814B) & BIT_MASK_PS_TIMER_1_8814B)
#define BIT_SET_PS_TIMER_1_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_1_8814B(x) | BIT_PS_TIMER_1_8814B(v))
/* 2 REG_PS_TIMER_2_8814B */
#define BIT_SHIFT_PS_TIMER_2_8814B 0
#define BIT_MASK_PS_TIMER_2_8814B 0xffffffffL
#define BIT_PS_TIMER_2_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_2_8814B) << BIT_SHIFT_PS_TIMER_2_8814B)
#define BITS_PS_TIMER_2_8814B \
(BIT_MASK_PS_TIMER_2_8814B << BIT_SHIFT_PS_TIMER_2_8814B)
#define BIT_CLEAR_PS_TIMER_2_8814B(x) ((x) & (~BITS_PS_TIMER_2_8814B))
#define BIT_GET_PS_TIMER_2_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_2_8814B) & BIT_MASK_PS_TIMER_2_8814B)
#define BIT_SET_PS_TIMER_2_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_2_8814B(x) | BIT_PS_TIMER_2_8814B(v))
/* 2 REG_PS_TIMER_3_8814B */
#define BIT_SHIFT_PS_TIMER_3_8814B 0
#define BIT_MASK_PS_TIMER_3_8814B 0xffffffffL
#define BIT_PS_TIMER_3_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_3_8814B) << BIT_SHIFT_PS_TIMER_3_8814B)
#define BITS_PS_TIMER_3_8814B \
(BIT_MASK_PS_TIMER_3_8814B << BIT_SHIFT_PS_TIMER_3_8814B)
#define BIT_CLEAR_PS_TIMER_3_8814B(x) ((x) & (~BITS_PS_TIMER_3_8814B))
#define BIT_GET_PS_TIMER_3_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_3_8814B) & BIT_MASK_PS_TIMER_3_8814B)
#define BIT_SET_PS_TIMER_3_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_3_8814B(x) | BIT_PS_TIMER_3_8814B(v))
/* 2 REG_PS_TIMER_4_8814B */
#define BIT_SHIFT_PS_TIMER_4_8814B 0
#define BIT_MASK_PS_TIMER_4_8814B 0xffffffffL
#define BIT_PS_TIMER_4_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_4_8814B) << BIT_SHIFT_PS_TIMER_4_8814B)
#define BITS_PS_TIMER_4_8814B \
(BIT_MASK_PS_TIMER_4_8814B << BIT_SHIFT_PS_TIMER_4_8814B)
#define BIT_CLEAR_PS_TIMER_4_8814B(x) ((x) & (~BITS_PS_TIMER_4_8814B))
#define BIT_GET_PS_TIMER_4_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_4_8814B) & BIT_MASK_PS_TIMER_4_8814B)
#define BIT_SET_PS_TIMER_4_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_4_8814B(x) | BIT_PS_TIMER_4_8814B(v))
/* 2 REG_PS_TIMER_5_8814B */
#define BIT_SHIFT_PS_TIMER_5_8814B 0
#define BIT_MASK_PS_TIMER_5_8814B 0xffffffffL
#define BIT_PS_TIMER_5_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_5_8814B) << BIT_SHIFT_PS_TIMER_5_8814B)
#define BITS_PS_TIMER_5_8814B \
(BIT_MASK_PS_TIMER_5_8814B << BIT_SHIFT_PS_TIMER_5_8814B)
#define BIT_CLEAR_PS_TIMER_5_8814B(x) ((x) & (~BITS_PS_TIMER_5_8814B))
#define BIT_GET_PS_TIMER_5_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_5_8814B) & BIT_MASK_PS_TIMER_5_8814B)
#define BIT_SET_PS_TIMER_5_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_5_8814B(x) | BIT_PS_TIMER_5_8814B(v))
/* 2 REG_PS_TIMER_01_CTRL_8814B */
#define BIT_SHIFT_PS_TIMER_1_EARLY_TIME_8814B 24
#define BIT_MASK_PS_TIMER_1_EARLY_TIME_8814B 0xff
#define BIT_PS_TIMER_1_EARLY_TIME_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_1_EARLY_TIME_8814B) \
<< BIT_SHIFT_PS_TIMER_1_EARLY_TIME_8814B)
#define BITS_PS_TIMER_1_EARLY_TIME_8814B \
(BIT_MASK_PS_TIMER_1_EARLY_TIME_8814B \
<< BIT_SHIFT_PS_TIMER_1_EARLY_TIME_8814B)
#define BIT_CLEAR_PS_TIMER_1_EARLY_TIME_8814B(x) \
((x) & (~BITS_PS_TIMER_1_EARLY_TIME_8814B))
#define BIT_GET_PS_TIMER_1_EARLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_1_EARLY_TIME_8814B) & \
BIT_MASK_PS_TIMER_1_EARLY_TIME_8814B)
#define BIT_SET_PS_TIMER_1_EARLY_TIME_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_1_EARLY_TIME_8814B(x) | \
BIT_PS_TIMER_1_EARLY_TIME_8814B(v))
#define BIT_PS_TIMER_1_EN_8814B BIT(23)
#define BIT_SHIFT_PS_TIMER_1_TSF_SEL_8814B 16
#define BIT_MASK_PS_TIMER_1_TSF_SEL_8814B 0x7
#define BIT_PS_TIMER_1_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_1_TSF_SEL_8814B) \
<< BIT_SHIFT_PS_TIMER_1_TSF_SEL_8814B)
#define BITS_PS_TIMER_1_TSF_SEL_8814B \
(BIT_MASK_PS_TIMER_1_TSF_SEL_8814B \
<< BIT_SHIFT_PS_TIMER_1_TSF_SEL_8814B)
#define BIT_CLEAR_PS_TIMER_1_TSF_SEL_8814B(x) \
((x) & (~BITS_PS_TIMER_1_TSF_SEL_8814B))
#define BIT_GET_PS_TIMER_1_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_1_TSF_SEL_8814B) & \
BIT_MASK_PS_TIMER_1_TSF_SEL_8814B)
#define BIT_SET_PS_TIMER_1_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_1_TSF_SEL_8814B(x) | \
BIT_PS_TIMER_1_TSF_SEL_8814B(v))
#define BIT_SHIFT_PS_TIMER_0_EARLY_TIME_8814B 8
#define BIT_MASK_PS_TIMER_0_EARLY_TIME_8814B 0xff
#define BIT_PS_TIMER_0_EARLY_TIME_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_0_EARLY_TIME_8814B) \
<< BIT_SHIFT_PS_TIMER_0_EARLY_TIME_8814B)
#define BITS_PS_TIMER_0_EARLY_TIME_8814B \
(BIT_MASK_PS_TIMER_0_EARLY_TIME_8814B \
<< BIT_SHIFT_PS_TIMER_0_EARLY_TIME_8814B)
#define BIT_CLEAR_PS_TIMER_0_EARLY_TIME_8814B(x) \
((x) & (~BITS_PS_TIMER_0_EARLY_TIME_8814B))
#define BIT_GET_PS_TIMER_0_EARLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_0_EARLY_TIME_8814B) & \
BIT_MASK_PS_TIMER_0_EARLY_TIME_8814B)
#define BIT_SET_PS_TIMER_0_EARLY_TIME_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_0_EARLY_TIME_8814B(x) | \
BIT_PS_TIMER_0_EARLY_TIME_8814B(v))
#define BIT_PS_TIMER_0_EN_8814B BIT(7)
#define BIT_SHIFT_PS_TIMER_0_TSF_SEL_8814B 0
#define BIT_MASK_PS_TIMER_0_TSF_SEL_8814B 0x7
#define BIT_PS_TIMER_0_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_0_TSF_SEL_8814B) \
<< BIT_SHIFT_PS_TIMER_0_TSF_SEL_8814B)
#define BITS_PS_TIMER_0_TSF_SEL_8814B \
(BIT_MASK_PS_TIMER_0_TSF_SEL_8814B \
<< BIT_SHIFT_PS_TIMER_0_TSF_SEL_8814B)
#define BIT_CLEAR_PS_TIMER_0_TSF_SEL_8814B(x) \
((x) & (~BITS_PS_TIMER_0_TSF_SEL_8814B))
#define BIT_GET_PS_TIMER_0_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_0_TSF_SEL_8814B) & \
BIT_MASK_PS_TIMER_0_TSF_SEL_8814B)
#define BIT_SET_PS_TIMER_0_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_0_TSF_SEL_8814B(x) | \
BIT_PS_TIMER_0_TSF_SEL_8814B(v))
/* 2 REG_PS_TIMER_23_CTRL_8814B */
#define BIT_SHIFT_PS_TIMER_3_EARLY_TIME_8814B 24
#define BIT_MASK_PS_TIMER_3_EARLY_TIME_8814B 0xff
#define BIT_PS_TIMER_3_EARLY_TIME_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_3_EARLY_TIME_8814B) \
<< BIT_SHIFT_PS_TIMER_3_EARLY_TIME_8814B)
#define BITS_PS_TIMER_3_EARLY_TIME_8814B \
(BIT_MASK_PS_TIMER_3_EARLY_TIME_8814B \
<< BIT_SHIFT_PS_TIMER_3_EARLY_TIME_8814B)
#define BIT_CLEAR_PS_TIMER_3_EARLY_TIME_8814B(x) \
((x) & (~BITS_PS_TIMER_3_EARLY_TIME_8814B))
#define BIT_GET_PS_TIMER_3_EARLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_3_EARLY_TIME_8814B) & \
BIT_MASK_PS_TIMER_3_EARLY_TIME_8814B)
#define BIT_SET_PS_TIMER_3_EARLY_TIME_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_3_EARLY_TIME_8814B(x) | \
BIT_PS_TIMER_3_EARLY_TIME_8814B(v))
#define BIT_PS_TIMER_3_EN_8814B BIT(23)
#define BIT_SHIFT_PS_TIMER_3_TSF_SEL_8814B 16
#define BIT_MASK_PS_TIMER_3_TSF_SEL_8814B 0x7
#define BIT_PS_TIMER_3_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_3_TSF_SEL_8814B) \
<< BIT_SHIFT_PS_TIMER_3_TSF_SEL_8814B)
#define BITS_PS_TIMER_3_TSF_SEL_8814B \
(BIT_MASK_PS_TIMER_3_TSF_SEL_8814B \
<< BIT_SHIFT_PS_TIMER_3_TSF_SEL_8814B)
#define BIT_CLEAR_PS_TIMER_3_TSF_SEL_8814B(x) \
((x) & (~BITS_PS_TIMER_3_TSF_SEL_8814B))
#define BIT_GET_PS_TIMER_3_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_3_TSF_SEL_8814B) & \
BIT_MASK_PS_TIMER_3_TSF_SEL_8814B)
#define BIT_SET_PS_TIMER_3_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_3_TSF_SEL_8814B(x) | \
BIT_PS_TIMER_3_TSF_SEL_8814B(v))
#define BIT_SHIFT_PS_TIMER_2_EARLY_TIME_8814B 8
#define BIT_MASK_PS_TIMER_2_EARLY_TIME_8814B 0xff
#define BIT_PS_TIMER_2_EARLY_TIME_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_2_EARLY_TIME_8814B) \
<< BIT_SHIFT_PS_TIMER_2_EARLY_TIME_8814B)
#define BITS_PS_TIMER_2_EARLY_TIME_8814B \
(BIT_MASK_PS_TIMER_2_EARLY_TIME_8814B \
<< BIT_SHIFT_PS_TIMER_2_EARLY_TIME_8814B)
#define BIT_CLEAR_PS_TIMER_2_EARLY_TIME_8814B(x) \
((x) & (~BITS_PS_TIMER_2_EARLY_TIME_8814B))
#define BIT_GET_PS_TIMER_2_EARLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_2_EARLY_TIME_8814B) & \
BIT_MASK_PS_TIMER_2_EARLY_TIME_8814B)
#define BIT_SET_PS_TIMER_2_EARLY_TIME_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_2_EARLY_TIME_8814B(x) | \
BIT_PS_TIMER_2_EARLY_TIME_8814B(v))
#define BIT_PS_TIMER_2_EN_8814B BIT(7)
#define BIT_SHIFT_PS_TIMER_2_TSF_SEL_8814B 0
#define BIT_MASK_PS_TIMER_2_TSF_SEL_8814B 0x7
#define BIT_PS_TIMER_2_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_2_TSF_SEL_8814B) \
<< BIT_SHIFT_PS_TIMER_2_TSF_SEL_8814B)
#define BITS_PS_TIMER_2_TSF_SEL_8814B \
(BIT_MASK_PS_TIMER_2_TSF_SEL_8814B \
<< BIT_SHIFT_PS_TIMER_2_TSF_SEL_8814B)
#define BIT_CLEAR_PS_TIMER_2_TSF_SEL_8814B(x) \
((x) & (~BITS_PS_TIMER_2_TSF_SEL_8814B))
#define BIT_GET_PS_TIMER_2_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_2_TSF_SEL_8814B) & \
BIT_MASK_PS_TIMER_2_TSF_SEL_8814B)
#define BIT_SET_PS_TIMER_2_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_2_TSF_SEL_8814B(x) | \
BIT_PS_TIMER_2_TSF_SEL_8814B(v))
/* 2 REG_PS_TIMER_45_CTRL_8814B */
#define BIT_SHIFT_PS_TIMER_5_EARLY_TIME_8814B 24
#define BIT_MASK_PS_TIMER_5_EARLY_TIME_8814B 0xff
#define BIT_PS_TIMER_5_EARLY_TIME_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_5_EARLY_TIME_8814B) \
<< BIT_SHIFT_PS_TIMER_5_EARLY_TIME_8814B)
#define BITS_PS_TIMER_5_EARLY_TIME_8814B \
(BIT_MASK_PS_TIMER_5_EARLY_TIME_8814B \
<< BIT_SHIFT_PS_TIMER_5_EARLY_TIME_8814B)
#define BIT_CLEAR_PS_TIMER_5_EARLY_TIME_8814B(x) \
((x) & (~BITS_PS_TIMER_5_EARLY_TIME_8814B))
#define BIT_GET_PS_TIMER_5_EARLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_5_EARLY_TIME_8814B) & \
BIT_MASK_PS_TIMER_5_EARLY_TIME_8814B)
#define BIT_SET_PS_TIMER_5_EARLY_TIME_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_5_EARLY_TIME_8814B(x) | \
BIT_PS_TIMER_5_EARLY_TIME_8814B(v))
#define BIT_PS_TIMER_5_EN_8814B BIT(23)
#define BIT_SHIFT_PS_TIMER_5_TSF_SEL_8814B 16
#define BIT_MASK_PS_TIMER_5_TSF_SEL_8814B 0x7
#define BIT_PS_TIMER_5_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_5_TSF_SEL_8814B) \
<< BIT_SHIFT_PS_TIMER_5_TSF_SEL_8814B)
#define BITS_PS_TIMER_5_TSF_SEL_8814B \
(BIT_MASK_PS_TIMER_5_TSF_SEL_8814B \
<< BIT_SHIFT_PS_TIMER_5_TSF_SEL_8814B)
#define BIT_CLEAR_PS_TIMER_5_TSF_SEL_8814B(x) \
((x) & (~BITS_PS_TIMER_5_TSF_SEL_8814B))
#define BIT_GET_PS_TIMER_5_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_5_TSF_SEL_8814B) & \
BIT_MASK_PS_TIMER_5_TSF_SEL_8814B)
#define BIT_SET_PS_TIMER_5_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_5_TSF_SEL_8814B(x) | \
BIT_PS_TIMER_5_TSF_SEL_8814B(v))
#define BIT_SHIFT_PS_TIMER_4_EARLY_TIME_8814B 8
#define BIT_MASK_PS_TIMER_4_EARLY_TIME_8814B 0xff
#define BIT_PS_TIMER_4_EARLY_TIME_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_4_EARLY_TIME_8814B) \
<< BIT_SHIFT_PS_TIMER_4_EARLY_TIME_8814B)
#define BITS_PS_TIMER_4_EARLY_TIME_8814B \
(BIT_MASK_PS_TIMER_4_EARLY_TIME_8814B \
<< BIT_SHIFT_PS_TIMER_4_EARLY_TIME_8814B)
#define BIT_CLEAR_PS_TIMER_4_EARLY_TIME_8814B(x) \
((x) & (~BITS_PS_TIMER_4_EARLY_TIME_8814B))
#define BIT_GET_PS_TIMER_4_EARLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_4_EARLY_TIME_8814B) & \
BIT_MASK_PS_TIMER_4_EARLY_TIME_8814B)
#define BIT_SET_PS_TIMER_4_EARLY_TIME_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_4_EARLY_TIME_8814B(x) | \
BIT_PS_TIMER_4_EARLY_TIME_8814B(v))
#define BIT_PS_TIMER_4_EN_8814B BIT(7)
#define BIT_SHIFT_PS_TIMER_4_TSF_SEL_8814B 0
#define BIT_MASK_PS_TIMER_4_TSF_SEL_8814B 0x7
#define BIT_PS_TIMER_4_TSF_SEL_8814B(x) \
(((x) & BIT_MASK_PS_TIMER_4_TSF_SEL_8814B) \
<< BIT_SHIFT_PS_TIMER_4_TSF_SEL_8814B)
#define BITS_PS_TIMER_4_TSF_SEL_8814B \
(BIT_MASK_PS_TIMER_4_TSF_SEL_8814B \
<< BIT_SHIFT_PS_TIMER_4_TSF_SEL_8814B)
#define BIT_CLEAR_PS_TIMER_4_TSF_SEL_8814B(x) \
((x) & (~BITS_PS_TIMER_4_TSF_SEL_8814B))
#define BIT_GET_PS_TIMER_4_TSF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_4_TSF_SEL_8814B) & \
BIT_MASK_PS_TIMER_4_TSF_SEL_8814B)
#define BIT_SET_PS_TIMER_4_TSF_SEL_8814B(x, v) \
(BIT_CLEAR_PS_TIMER_4_TSF_SEL_8814B(x) | \
BIT_PS_TIMER_4_TSF_SEL_8814B(v))
/* 2 REG_CPUMGQ_FREERUN_TIMER_CTRL_8814B */
#define BIT_FREECNT_RST_V1_8814B BIT(23)
#define BIT_EN_FREECNT_V1_8814B BIT(16)
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1_8814B 8
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1_8814B 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY_V1_8814B(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1_8814B) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1_8814B)
#define BITS_CPUMGQ_TX_TIMER_EARLY_V1_8814B \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1_8814B \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1_8814B)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_V1_8814B(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY_V1_8814B))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY_V1_8814B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_V1_8814B) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY_V1_8814B)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY_V1_8814B(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_V1_8814B(x) | \
BIT_CPUMGQ_TX_TIMER_EARLY_V1_8814B(v))
#define BIT_CPUMGQ_TIMER_EN_V1_8814B BIT(7)
#define BIT_CPUMGQ_DROP_BY_HOLDTIME_8814B BIT(5)
#define BIT_CPUMGQ_TX_EN_V1_8814B BIT(4)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1_8814B 0
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1_8814B 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL_V1_8814B(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1_8814B) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1_8814B)
#define BITS_CPUMGQ_TIMER_TSF_SEL_V1_8814B \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1_8814B \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1_8814B)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_V1_8814B(x) \
((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL_V1_8814B))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_V1_8814B) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL_V1_8814B)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL_V1_8814B(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_V1_8814B(x) | \
BIT_CPUMGQ_TIMER_TSF_SEL_V1_8814B(v))
/* 2 REG_CPUMGQ_PROHIBIT_8814B */
#define BIT_SHIFT_CPUMGQ_HOLD_TIME_8814B 8
#define BIT_MASK_CPUMGQ_HOLD_TIME_8814B 0xfff
#define BIT_CPUMGQ_HOLD_TIME_8814B(x) \
(((x) & BIT_MASK_CPUMGQ_HOLD_TIME_8814B) \
<< BIT_SHIFT_CPUMGQ_HOLD_TIME_8814B)
#define BITS_CPUMGQ_HOLD_TIME_8814B \
(BIT_MASK_CPUMGQ_HOLD_TIME_8814B << BIT_SHIFT_CPUMGQ_HOLD_TIME_8814B)
#define BIT_CLEAR_CPUMGQ_HOLD_TIME_8814B(x) \
((x) & (~BITS_CPUMGQ_HOLD_TIME_8814B))
#define BIT_GET_CPUMGQ_HOLD_TIME_8814B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_HOLD_TIME_8814B) & \
BIT_MASK_CPUMGQ_HOLD_TIME_8814B)
#define BIT_SET_CPUMGQ_HOLD_TIME_8814B(x, v) \
(BIT_CLEAR_CPUMGQ_HOLD_TIME_8814B(x) | BIT_CPUMGQ_HOLD_TIME_8814B(v))
#define BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP_8814B 0
#define BIT_MASK_CPUMGQ_PROHIBIT_SETUP_8814B 0xf
#define BIT_CPUMGQ_PROHIBIT_SETUP_8814B(x) \
(((x) & BIT_MASK_CPUMGQ_PROHIBIT_SETUP_8814B) \
<< BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP_8814B)
#define BITS_CPUMGQ_PROHIBIT_SETUP_8814B \
(BIT_MASK_CPUMGQ_PROHIBIT_SETUP_8814B \
<< BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP_8814B)
#define BIT_CLEAR_CPUMGQ_PROHIBIT_SETUP_8814B(x) \
((x) & (~BITS_CPUMGQ_PROHIBIT_SETUP_8814B))
#define BIT_GET_CPUMGQ_PROHIBIT_SETUP_8814B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_PROHIBIT_SETUP_8814B) & \
BIT_MASK_CPUMGQ_PROHIBIT_SETUP_8814B)
#define BIT_SET_CPUMGQ_PROHIBIT_SETUP_8814B(x, v) \
(BIT_CLEAR_CPUMGQ_PROHIBIT_SETUP_8814B(x) | \
BIT_CPUMGQ_PROHIBIT_SETUP_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_TIMER_COMPARE_8814B */
#define BIT_COMP_TRIGGER_8814B BIT(7)
#define BIT_SHIFT_Y_COMP_8814B 4
#define BIT_MASK_Y_COMP_8814B 0x7
#define BIT_Y_COMP_8814B(x) \
(((x) & BIT_MASK_Y_COMP_8814B) << BIT_SHIFT_Y_COMP_8814B)
#define BITS_Y_COMP_8814B (BIT_MASK_Y_COMP_8814B << BIT_SHIFT_Y_COMP_8814B)
#define BIT_CLEAR_Y_COMP_8814B(x) ((x) & (~BITS_Y_COMP_8814B))
#define BIT_GET_Y_COMP_8814B(x) \
(((x) >> BIT_SHIFT_Y_COMP_8814B) & BIT_MASK_Y_COMP_8814B)
#define BIT_SET_Y_COMP_8814B(x, v) \
(BIT_CLEAR_Y_COMP_8814B(x) | BIT_Y_COMP_8814B(v))
#define BIT_X_COMP_Y_OVERFLOW_8814B BIT(3)
#define BIT_SHIFT_X_COMP_8814B 0
#define BIT_MASK_X_COMP_8814B 0x7
#define BIT_X_COMP_8814B(x) \
(((x) & BIT_MASK_X_COMP_8814B) << BIT_SHIFT_X_COMP_8814B)
#define BITS_X_COMP_8814B (BIT_MASK_X_COMP_8814B << BIT_SHIFT_X_COMP_8814B)
#define BIT_CLEAR_X_COMP_8814B(x) ((x) & (~BITS_X_COMP_8814B))
#define BIT_GET_X_COMP_8814B(x) \
(((x) >> BIT_SHIFT_X_COMP_8814B) & BIT_MASK_X_COMP_8814B)
#define BIT_SET_X_COMP_8814B(x, v) \
(BIT_CLEAR_X_COMP_8814B(x) | BIT_X_COMP_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_TIMER_COMPARE_VALUE_LOW_8814B */
#define BIT_SHIFT_COMP_VALUE_LOW_8814B 0
#define BIT_MASK_COMP_VALUE_LOW_8814B 0xffffffffL
#define BIT_COMP_VALUE_LOW_8814B(x) \
(((x) & BIT_MASK_COMP_VALUE_LOW_8814B) \
<< BIT_SHIFT_COMP_VALUE_LOW_8814B)
#define BITS_COMP_VALUE_LOW_8814B \
(BIT_MASK_COMP_VALUE_LOW_8814B << BIT_SHIFT_COMP_VALUE_LOW_8814B)
#define BIT_CLEAR_COMP_VALUE_LOW_8814B(x) ((x) & (~BITS_COMP_VALUE_LOW_8814B))
#define BIT_GET_COMP_VALUE_LOW_8814B(x) \
(((x) >> BIT_SHIFT_COMP_VALUE_LOW_8814B) & \
BIT_MASK_COMP_VALUE_LOW_8814B)
#define BIT_SET_COMP_VALUE_LOW_8814B(x, v) \
(BIT_CLEAR_COMP_VALUE_LOW_8814B(x) | BIT_COMP_VALUE_LOW_8814B(v))
/* 2 REG_TIMER_COMPARE_VALUE_HIGH_8814B */
#define BIT_SHIFT_COMP_VALUE_HIGH_8814B 0
#define BIT_MASK_COMP_VALUE_HIGH_8814B 0xffffffffL
#define BIT_COMP_VALUE_HIGH_8814B(x) \
(((x) & BIT_MASK_COMP_VALUE_HIGH_8814B) \
<< BIT_SHIFT_COMP_VALUE_HIGH_8814B)
#define BITS_COMP_VALUE_HIGH_8814B \
(BIT_MASK_COMP_VALUE_HIGH_8814B << BIT_SHIFT_COMP_VALUE_HIGH_8814B)
#define BIT_CLEAR_COMP_VALUE_HIGH_8814B(x) ((x) & (~BITS_COMP_VALUE_HIGH_8814B))
#define BIT_GET_COMP_VALUE_HIGH_8814B(x) \
(((x) >> BIT_SHIFT_COMP_VALUE_HIGH_8814B) & \
BIT_MASK_COMP_VALUE_HIGH_8814B)
#define BIT_SET_COMP_VALUE_HIGH_8814B(x, v) \
(BIT_CLEAR_COMP_VALUE_HIGH_8814B(x) | BIT_COMP_VALUE_HIGH_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_SCHEDULER_COUNTER_8814B */
#define BIT_SHIFT__SCHEDULER_COUNTER_8814B 16
#define BIT_MASK__SCHEDULER_COUNTER_8814B 0xffff
#define BIT__SCHEDULER_COUNTER_8814B(x) \
(((x) & BIT_MASK__SCHEDULER_COUNTER_8814B) \
<< BIT_SHIFT__SCHEDULER_COUNTER_8814B)
#define BITS__SCHEDULER_COUNTER_8814B \
(BIT_MASK__SCHEDULER_COUNTER_8814B \
<< BIT_SHIFT__SCHEDULER_COUNTER_8814B)
#define BIT_CLEAR__SCHEDULER_COUNTER_8814B(x) \
((x) & (~BITS__SCHEDULER_COUNTER_8814B))
#define BIT_GET__SCHEDULER_COUNTER_8814B(x) \
(((x) >> BIT_SHIFT__SCHEDULER_COUNTER_8814B) & \
BIT_MASK__SCHEDULER_COUNTER_8814B)
#define BIT_SET__SCHEDULER_COUNTER_8814B(x, v) \
(BIT_CLEAR__SCHEDULER_COUNTER_8814B(x) | \
BIT__SCHEDULER_COUNTER_8814B(v))
#define BIT__SCHEDULER_COUNTER_RST_8814B BIT(8)
#define BIT_SHIFT_SCHEDULER_COUNTER_SEL_8814B 0
#define BIT_MASK_SCHEDULER_COUNTER_SEL_8814B 0xff
#define BIT_SCHEDULER_COUNTER_SEL_8814B(x) \
(((x) & BIT_MASK_SCHEDULER_COUNTER_SEL_8814B) \
<< BIT_SHIFT_SCHEDULER_COUNTER_SEL_8814B)
#define BITS_SCHEDULER_COUNTER_SEL_8814B \
(BIT_MASK_SCHEDULER_COUNTER_SEL_8814B \
<< BIT_SHIFT_SCHEDULER_COUNTER_SEL_8814B)
#define BIT_CLEAR_SCHEDULER_COUNTER_SEL_8814B(x) \
((x) & (~BITS_SCHEDULER_COUNTER_SEL_8814B))
#define BIT_GET_SCHEDULER_COUNTER_SEL_8814B(x) \
(((x) >> BIT_SHIFT_SCHEDULER_COUNTER_SEL_8814B) & \
BIT_MASK_SCHEDULER_COUNTER_SEL_8814B)
#define BIT_SET_SCHEDULER_COUNTER_SEL_8814B(x, v) \
(BIT_CLEAR_SCHEDULER_COUNTER_SEL_8814B(x) | \
BIT_SCHEDULER_COUNTER_SEL_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_WMAC_CR_8814B (WMAC CR AND APSD CONTROL REGISTER) */
#define BIT_IC_MACPHY_M_8814B BIT(0)
/* 2 REG_WMAC_FWPKT_CR_8814B */
#define BIT_FWEN_8814B BIT(7)
#define BIT_PHYSTS_PKT_CTRL_8814B BIT(6)
#define BIT_FWFULL_TO_RXFF_EN_8814B BIT(5)
#define BIT_APPHDR_MIDSRCH_FAIL_8814B BIT(4)
#define BIT_FWPARSING_EN_8814B BIT(3)
#define BIT_SHIFT_APPEND_MHDR_LEN_8814B 0
#define BIT_MASK_APPEND_MHDR_LEN_8814B 0x7
#define BIT_APPEND_MHDR_LEN_8814B(x) \
(((x) & BIT_MASK_APPEND_MHDR_LEN_8814B) \
<< BIT_SHIFT_APPEND_MHDR_LEN_8814B)
#define BITS_APPEND_MHDR_LEN_8814B \
(BIT_MASK_APPEND_MHDR_LEN_8814B << BIT_SHIFT_APPEND_MHDR_LEN_8814B)
#define BIT_CLEAR_APPEND_MHDR_LEN_8814B(x) ((x) & (~BITS_APPEND_MHDR_LEN_8814B))
#define BIT_GET_APPEND_MHDR_LEN_8814B(x) \
(((x) >> BIT_SHIFT_APPEND_MHDR_LEN_8814B) & \
BIT_MASK_APPEND_MHDR_LEN_8814B)
#define BIT_SET_APPEND_MHDR_LEN_8814B(x, v) \
(BIT_CLEAR_APPEND_MHDR_LEN_8814B(x) | BIT_APPEND_MHDR_LEN_8814B(v))
/* 2 REG_FW_STS_FILTER_8814B */
#define BIT_DATA_FW_STS_FILTER_8814B BIT(2)
#define BIT_CTRL_FW_STS_FILTER_8814B BIT(1)
#define BIT_MGNT_FW_STS_FILTER_8814B BIT(0)
/* 2 REG_RSVD_8814B */
/* 2 REG_TCR_8814B (TRANSMISSION CONFIGURATION REGISTER) */
#define BIT_WMAC_EN_RTS_ADDR_8814B BIT(31)
#define BIT_WMAC_DISABLE_CCK_8814B BIT(30)
#define BIT_WMAC_RAW_LEN_8814B BIT(29)
#define BIT_WMAC_NOTX_IN_RXNDP_8814B BIT(28)
#define BIT_WMAC_EN_EOF_8814B BIT(27)
#define BIT_WMAC_BF_SEL_8814B BIT(26)
#define BIT_WMAC_TCRPWRMGT_HWCTL_EN_8814B BIT(24)
#define BIT_WMAC_SMOOTH_VAL_8814B BIT(23)
#define BIT_WMAC_EN_SCRAM_INC_8814B BIT(22)
#define BIT_UNDERFLOWEN_CMPLEN_SEL_8814B BIT(21)
#define BIT_FETCH_MPDU_AFTER_WSEC_RDY_8814B BIT(20)
#define BIT_WMAC_TCR_EN_20MST_8814B BIT(19)
#define BIT_WMAC_DIS_SIGTA_8814B BIT(18)
#define BIT_WMAC_DIS_A2B0_8814B BIT(17)
#define BIT_WMAC_MSK_SIGBCRC_8814B BIT(16)
#define BIT_WMAC_TCR_ERRSTEN_3_8814B BIT(15)
#define BIT_WMAC_TCR_ERRSTEN_2_8814B BIT(14)
#define BIT_WMAC_TCR_ERRSTEN_1_8814B BIT(13)
#define BIT_WMAC_TCR_ERRSTEN_0_8814B BIT(12)
#define BIT_WMAC_TCR_TXSK_PERPKT_8814B BIT(11)
#define BIT_ICV_8814B BIT(10)
#define BIT_CRC_8814B BIT(8)
#define BIT_WMAC_TCRPWRMGT_HWDATA_EN_8814B BIT(7)
#define BIT_PWR_ST_8814B BIT(6)
#define BIT_WMAC_TCR_UPD_TIMIE_8814B BIT(5)
#define BIT_WMAC_TCR_UPD_HGQMD_8814B BIT(4)
#define BIT_VHTSIGA1_TXPS_8814B BIT(3)
#define BIT_PAD_SEL_8814B BIT(2)
#define BIT_DIS_GCLK_8814B BIT(1)
#define BIT_WMAC_TCRPWRMGT_HWACT_EN_8814B BIT(0)
/* 2 REG_RCR_8814B (RECEIVE CONFIGURATION REGISTER) */
#define BIT_APP_FCS_8814B BIT(31)
#define BIT_APP_MIC_8814B BIT(30)
#define BIT_APP_ICV_8814B BIT(29)
#define BIT_APP_PHYSTS_8814B BIT(28)
#define BIT_APP_BASSN_8814B BIT(27)
#define BIT_VHT_DACK_8814B BIT(26)
#define BIT_TCPOFLD_EN_8814B BIT(25)
#define BIT_ENADDRCAM_8814B BIT(24)
#define BIT_LSIGEN_8814B BIT(23)
#define BIT_MFBEN_8814B BIT(22)
#define BIT_DISCHKPPDLLEN_8814B BIT(21)
#define BIT_PKTCTL_DLEN_8814B BIT(20)
#define BIT_DISGCLK_8814B BIT(19)
#define BIT_TIM_PARSER_EN_8814B BIT(18)
#define BIT_BC_MD_EN_8814B BIT(17)
#define BIT_UC_MD_EN_8814B BIT(16)
#define BIT_RXSK_PERPKT_8814B BIT(15)
#define BIT_HTC_LOC_CTRL_8814B BIT(14)
#define BIT_ACK_WITH_CBSSID_DATA_OPTION_8814B BIT(13)
#define BIT_RPFM_CAM_ENABLE_8814B BIT(12)
#define BIT_TA_BCN_8814B BIT(11)
#define BIT_DISDECMYPKT_8814B BIT(10)
#define BIT_AICV_8814B BIT(9)
#define BIT_ACRC32_8814B BIT(8)
#define BIT_CBSSID_BCN_8814B BIT(7)
#define BIT_CBSSID_DATA_8814B BIT(6)
#define BIT_APWRMGT_8814B BIT(5)
#define BIT_ADD3_8814B BIT(4)
#define BIT_AB_8814B BIT(3)
#define BIT_AM_8814B BIT(2)
#define BIT_APM_8814B BIT(1)
#define BIT_AAP_8814B BIT(0)
/* 2 REG_RX_PKT_LIMIT_8814B (RX PACKET LENGTH LIMIT REGISTER) */
#define BIT_SHIFT_RXPKTLMT_8814B 0
#define BIT_MASK_RXPKTLMT_8814B 0x3f
#define BIT_RXPKTLMT_8814B(x) \
(((x) & BIT_MASK_RXPKTLMT_8814B) << BIT_SHIFT_RXPKTLMT_8814B)
#define BITS_RXPKTLMT_8814B \
(BIT_MASK_RXPKTLMT_8814B << BIT_SHIFT_RXPKTLMT_8814B)
#define BIT_CLEAR_RXPKTLMT_8814B(x) ((x) & (~BITS_RXPKTLMT_8814B))
#define BIT_GET_RXPKTLMT_8814B(x) \
(((x) >> BIT_SHIFT_RXPKTLMT_8814B) & BIT_MASK_RXPKTLMT_8814B)
#define BIT_SET_RXPKTLMT_8814B(x, v) \
(BIT_CLEAR_RXPKTLMT_8814B(x) | BIT_RXPKTLMT_8814B(v))
/* 2 REG_RX_DLK_TIME_8814B (RX DEADLOCK TIME REGISTER) */
#define BIT_SHIFT_RX_DLK_TIME_8814B 0
#define BIT_MASK_RX_DLK_TIME_8814B 0xff
#define BIT_RX_DLK_TIME_8814B(x) \
(((x) & BIT_MASK_RX_DLK_TIME_8814B) << BIT_SHIFT_RX_DLK_TIME_8814B)
#define BITS_RX_DLK_TIME_8814B \
(BIT_MASK_RX_DLK_TIME_8814B << BIT_SHIFT_RX_DLK_TIME_8814B)
#define BIT_CLEAR_RX_DLK_TIME_8814B(x) ((x) & (~BITS_RX_DLK_TIME_8814B))
#define BIT_GET_RX_DLK_TIME_8814B(x) \
(((x) >> BIT_SHIFT_RX_DLK_TIME_8814B) & BIT_MASK_RX_DLK_TIME_8814B)
#define BIT_SET_RX_DLK_TIME_8814B(x, v) \
(BIT_CLEAR_RX_DLK_TIME_8814B(x) | BIT_RX_DLK_TIME_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_RX_DRVINFO_SZ_8814B (RX DRIVER INFO SIZE REGISTER) */
#define BIT_PHYSTS_PER_PKT_MODE_8814B BIT(7)
#define BIT_SHIFT_DRVINFO_SZ_V1_8814B 0
#define BIT_MASK_DRVINFO_SZ_V1_8814B 0xf
#define BIT_DRVINFO_SZ_V1_8814B(x) \
(((x) & BIT_MASK_DRVINFO_SZ_V1_8814B) << BIT_SHIFT_DRVINFO_SZ_V1_8814B)
#define BITS_DRVINFO_SZ_V1_8814B \
(BIT_MASK_DRVINFO_SZ_V1_8814B << BIT_SHIFT_DRVINFO_SZ_V1_8814B)
#define BIT_CLEAR_DRVINFO_SZ_V1_8814B(x) ((x) & (~BITS_DRVINFO_SZ_V1_8814B))
#define BIT_GET_DRVINFO_SZ_V1_8814B(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ_V1_8814B) & BIT_MASK_DRVINFO_SZ_V1_8814B)
#define BIT_SET_DRVINFO_SZ_V1_8814B(x, v) \
(BIT_CLEAR_DRVINFO_SZ_V1_8814B(x) | BIT_DRVINFO_SZ_V1_8814B(v))
/* 2 REG_MACID_8814B (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_V1_8814B 0
#define BIT_MASK_MACID_V1_8814B 0xffffffffL
#define BIT_MACID_V1_8814B(x) \
(((x) & BIT_MASK_MACID_V1_8814B) << BIT_SHIFT_MACID_V1_8814B)
#define BITS_MACID_V1_8814B \
(BIT_MASK_MACID_V1_8814B << BIT_SHIFT_MACID_V1_8814B)
#define BIT_CLEAR_MACID_V1_8814B(x) ((x) & (~BITS_MACID_V1_8814B))
#define BIT_GET_MACID_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID_V1_8814B) & BIT_MASK_MACID_V1_8814B)
#define BIT_SET_MACID_V1_8814B(x, v) \
(BIT_CLEAR_MACID_V1_8814B(x) | BIT_MACID_V1_8814B(v))
/* 2 REG_MACID_H_8814B (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_H_V1_8814B 0
#define BIT_MASK_MACID_H_V1_8814B 0xffff
#define BIT_MACID_H_V1_8814B(x) \
(((x) & BIT_MASK_MACID_H_V1_8814B) << BIT_SHIFT_MACID_H_V1_8814B)
#define BITS_MACID_H_V1_8814B \
(BIT_MASK_MACID_H_V1_8814B << BIT_SHIFT_MACID_H_V1_8814B)
#define BIT_CLEAR_MACID_H_V1_8814B(x) ((x) & (~BITS_MACID_H_V1_8814B))
#define BIT_GET_MACID_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID_H_V1_8814B) & BIT_MASK_MACID_H_V1_8814B)
#define BIT_SET_MACID_H_V1_8814B(x, v) \
(BIT_CLEAR_MACID_H_V1_8814B(x) | BIT_MACID_H_V1_8814B(v))
/* 2 REG_BSSID_8814B (BSSID REGISTER) */
#define BIT_SHIFT_BSSID_V1_8814B 0
#define BIT_MASK_BSSID_V1_8814B 0xffffffffL
#define BIT_BSSID_V1_8814B(x) \
(((x) & BIT_MASK_BSSID_V1_8814B) << BIT_SHIFT_BSSID_V1_8814B)
#define BITS_BSSID_V1_8814B \
(BIT_MASK_BSSID_V1_8814B << BIT_SHIFT_BSSID_V1_8814B)
#define BIT_CLEAR_BSSID_V1_8814B(x) ((x) & (~BITS_BSSID_V1_8814B))
#define BIT_GET_BSSID_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID_V1_8814B) & BIT_MASK_BSSID_V1_8814B)
#define BIT_SET_BSSID_V1_8814B(x, v) \
(BIT_CLEAR_BSSID_V1_8814B(x) | BIT_BSSID_V1_8814B(v))
/* 2 REG_BSSID_H_8814B (BSSID REGISTER) */
/* 2 REG_NOT_VALID_8814B */
#define BIT_SHIFT_BSSID_H_V1_8814B 0
#define BIT_MASK_BSSID_H_V1_8814B 0xffff
#define BIT_BSSID_H_V1_8814B(x) \
(((x) & BIT_MASK_BSSID_H_V1_8814B) << BIT_SHIFT_BSSID_H_V1_8814B)
#define BITS_BSSID_H_V1_8814B \
(BIT_MASK_BSSID_H_V1_8814B << BIT_SHIFT_BSSID_H_V1_8814B)
#define BIT_CLEAR_BSSID_H_V1_8814B(x) ((x) & (~BITS_BSSID_H_V1_8814B))
#define BIT_GET_BSSID_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID_H_V1_8814B) & BIT_MASK_BSSID_H_V1_8814B)
#define BIT_SET_BSSID_H_V1_8814B(x, v) \
(BIT_CLEAR_BSSID_H_V1_8814B(x) | BIT_BSSID_H_V1_8814B(v))
/* 2 REG_MAR_8814B (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_V1_8814B 0
#define BIT_MASK_MAR_V1_8814B 0xffffffffL
#define BIT_MAR_V1_8814B(x) \
(((x) & BIT_MASK_MAR_V1_8814B) << BIT_SHIFT_MAR_V1_8814B)
#define BITS_MAR_V1_8814B (BIT_MASK_MAR_V1_8814B << BIT_SHIFT_MAR_V1_8814B)
#define BIT_CLEAR_MAR_V1_8814B(x) ((x) & (~BITS_MAR_V1_8814B))
#define BIT_GET_MAR_V1_8814B(x) \
(((x) >> BIT_SHIFT_MAR_V1_8814B) & BIT_MASK_MAR_V1_8814B)
#define BIT_SET_MAR_V1_8814B(x, v) \
(BIT_CLEAR_MAR_V1_8814B(x) | BIT_MAR_V1_8814B(v))
/* 2 REG_MAR_H_8814B (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_H_V1_8814B 0
#define BIT_MASK_MAR_H_V1_8814B 0xffffffffL
#define BIT_MAR_H_V1_8814B(x) \
(((x) & BIT_MASK_MAR_H_V1_8814B) << BIT_SHIFT_MAR_H_V1_8814B)
#define BITS_MAR_H_V1_8814B \
(BIT_MASK_MAR_H_V1_8814B << BIT_SHIFT_MAR_H_V1_8814B)
#define BIT_CLEAR_MAR_H_V1_8814B(x) ((x) & (~BITS_MAR_H_V1_8814B))
#define BIT_GET_MAR_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_MAR_H_V1_8814B) & BIT_MASK_MAR_H_V1_8814B)
#define BIT_SET_MAR_H_V1_8814B(x, v) \
(BIT_CLEAR_MAR_H_V1_8814B(x) | BIT_MAR_H_V1_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_WMAC_DEBUG_SEL_8814B */
#define BIT_SHIFT_WMAC_ARB_DBG_SEL_8814B 3
#define BIT_MASK_WMAC_ARB_DBG_SEL_8814B 0x3
#define BIT_WMAC_ARB_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_WMAC_ARB_DBG_SEL_8814B) \
<< BIT_SHIFT_WMAC_ARB_DBG_SEL_8814B)
#define BITS_WMAC_ARB_DBG_SEL_8814B \
(BIT_MASK_WMAC_ARB_DBG_SEL_8814B << BIT_SHIFT_WMAC_ARB_DBG_SEL_8814B)
#define BIT_CLEAR_WMAC_ARB_DBG_SEL_8814B(x) \
((x) & (~BITS_WMAC_ARB_DBG_SEL_8814B))
#define BIT_GET_WMAC_ARB_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_ARB_DBG_SEL_8814B) & \
BIT_MASK_WMAC_ARB_DBG_SEL_8814B)
#define BIT_SET_WMAC_ARB_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_WMAC_ARB_DBG_SEL_8814B(x) | BIT_WMAC_ARB_DBG_SEL_8814B(v))
#define BIT_WMAC_EXT_DBG_SEL_8814B BIT(2)
#define BIT_SHIFT_WMAC_MU_DBGSEL_V1_8814B 0
#define BIT_MASK_WMAC_MU_DBGSEL_V1_8814B 0x3
#define BIT_WMAC_MU_DBGSEL_V1_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_DBGSEL_V1_8814B) \
<< BIT_SHIFT_WMAC_MU_DBGSEL_V1_8814B)
#define BITS_WMAC_MU_DBGSEL_V1_8814B \
(BIT_MASK_WMAC_MU_DBGSEL_V1_8814B << BIT_SHIFT_WMAC_MU_DBGSEL_V1_8814B)
#define BIT_CLEAR_WMAC_MU_DBGSEL_V1_8814B(x) \
((x) & (~BITS_WMAC_MU_DBGSEL_V1_8814B))
#define BIT_GET_WMAC_MU_DBGSEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_DBGSEL_V1_8814B) & \
BIT_MASK_WMAC_MU_DBGSEL_V1_8814B)
#define BIT_SET_WMAC_MU_DBGSEL_V1_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_DBGSEL_V1_8814B(x) | BIT_WMAC_MU_DBGSEL_V1_8814B(v))
/* 2 REG_WMAC_TCR_TSFT_OFS_8814B */
#define BIT_SHIFT_WMAC_TCR_TSFT_OFS_8814B 0
#define BIT_MASK_WMAC_TCR_TSFT_OFS_8814B 0xffff
#define BIT_WMAC_TCR_TSFT_OFS_8814B(x) \
(((x) & BIT_MASK_WMAC_TCR_TSFT_OFS_8814B) \
<< BIT_SHIFT_WMAC_TCR_TSFT_OFS_8814B)
#define BITS_WMAC_TCR_TSFT_OFS_8814B \
(BIT_MASK_WMAC_TCR_TSFT_OFS_8814B << BIT_SHIFT_WMAC_TCR_TSFT_OFS_8814B)
#define BIT_CLEAR_WMAC_TCR_TSFT_OFS_8814B(x) \
((x) & (~BITS_WMAC_TCR_TSFT_OFS_8814B))
#define BIT_GET_WMAC_TCR_TSFT_OFS_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_TCR_TSFT_OFS_8814B) & \
BIT_MASK_WMAC_TCR_TSFT_OFS_8814B)
#define BIT_SET_WMAC_TCR_TSFT_OFS_8814B(x, v) \
(BIT_CLEAR_WMAC_TCR_TSFT_OFS_8814B(x) | BIT_WMAC_TCR_TSFT_OFS_8814B(v))
/* 2 REG_UDF_THSD_8814B */
#define BIT_UDF_THSD_V1_8814B BIT(7)
#define BIT_SHIFT_UDF_THSD_VALUE_8814B 0
#define BIT_MASK_UDF_THSD_VALUE_8814B 0x7f
#define BIT_UDF_THSD_VALUE_8814B(x) \
(((x) & BIT_MASK_UDF_THSD_VALUE_8814B) \
<< BIT_SHIFT_UDF_THSD_VALUE_8814B)
#define BITS_UDF_THSD_VALUE_8814B \
(BIT_MASK_UDF_THSD_VALUE_8814B << BIT_SHIFT_UDF_THSD_VALUE_8814B)
#define BIT_CLEAR_UDF_THSD_VALUE_8814B(x) ((x) & (~BITS_UDF_THSD_VALUE_8814B))
#define BIT_GET_UDF_THSD_VALUE_8814B(x) \
(((x) >> BIT_SHIFT_UDF_THSD_VALUE_8814B) & \
BIT_MASK_UDF_THSD_VALUE_8814B)
#define BIT_SET_UDF_THSD_VALUE_8814B(x, v) \
(BIT_CLEAR_UDF_THSD_VALUE_8814B(x) | BIT_UDF_THSD_VALUE_8814B(v))
/* 2 REG_ZLD_NUM_8814B */
#define BIT_SHIFT_ZLD_NUM_8814B 0
#define BIT_MASK_ZLD_NUM_8814B 0xff
#define BIT_ZLD_NUM_8814B(x) \
(((x) & BIT_MASK_ZLD_NUM_8814B) << BIT_SHIFT_ZLD_NUM_8814B)
#define BITS_ZLD_NUM_8814B (BIT_MASK_ZLD_NUM_8814B << BIT_SHIFT_ZLD_NUM_8814B)
#define BIT_CLEAR_ZLD_NUM_8814B(x) ((x) & (~BITS_ZLD_NUM_8814B))
#define BIT_GET_ZLD_NUM_8814B(x) \
(((x) >> BIT_SHIFT_ZLD_NUM_8814B) & BIT_MASK_ZLD_NUM_8814B)
#define BIT_SET_ZLD_NUM_8814B(x, v) \
(BIT_CLEAR_ZLD_NUM_8814B(x) | BIT_ZLD_NUM_8814B(v))
/* 2 REG_STMP_THSD_8814B */
#define BIT_SHIFT_STMP_THSD_8814B 0
#define BIT_MASK_STMP_THSD_8814B 0xff
#define BIT_STMP_THSD_8814B(x) \
(((x) & BIT_MASK_STMP_THSD_8814B) << BIT_SHIFT_STMP_THSD_8814B)
#define BITS_STMP_THSD_8814B \
(BIT_MASK_STMP_THSD_8814B << BIT_SHIFT_STMP_THSD_8814B)
#define BIT_CLEAR_STMP_THSD_8814B(x) ((x) & (~BITS_STMP_THSD_8814B))
#define BIT_GET_STMP_THSD_8814B(x) \
(((x) >> BIT_SHIFT_STMP_THSD_8814B) & BIT_MASK_STMP_THSD_8814B)
#define BIT_SET_STMP_THSD_8814B(x, v) \
(BIT_CLEAR_STMP_THSD_8814B(x) | BIT_STMP_THSD_8814B(v))
/* 2 REG_WMAC_TXTIMEOUT_8814B */
#define BIT_SHIFT_WMAC_TXTIMEOUT_8814B 0
#define BIT_MASK_WMAC_TXTIMEOUT_8814B 0xff
#define BIT_WMAC_TXTIMEOUT_8814B(x) \
(((x) & BIT_MASK_WMAC_TXTIMEOUT_8814B) \
<< BIT_SHIFT_WMAC_TXTIMEOUT_8814B)
#define BITS_WMAC_TXTIMEOUT_8814B \
(BIT_MASK_WMAC_TXTIMEOUT_8814B << BIT_SHIFT_WMAC_TXTIMEOUT_8814B)
#define BIT_CLEAR_WMAC_TXTIMEOUT_8814B(x) ((x) & (~BITS_WMAC_TXTIMEOUT_8814B))
#define BIT_GET_WMAC_TXTIMEOUT_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_TXTIMEOUT_8814B) & \
BIT_MASK_WMAC_TXTIMEOUT_8814B)
#define BIT_SET_WMAC_TXTIMEOUT_8814B(x, v) \
(BIT_CLEAR_WMAC_TXTIMEOUT_8814B(x) | BIT_WMAC_TXTIMEOUT_8814B(v))
/* 2 REG_MCU_TEST_2_V1_8814B */
#define BIT_SHIFT_MCU_RSVD_2_V1_8814B 0
#define BIT_MASK_MCU_RSVD_2_V1_8814B 0xffff
#define BIT_MCU_RSVD_2_V1_8814B(x) \
(((x) & BIT_MASK_MCU_RSVD_2_V1_8814B) << BIT_SHIFT_MCU_RSVD_2_V1_8814B)
#define BITS_MCU_RSVD_2_V1_8814B \
(BIT_MASK_MCU_RSVD_2_V1_8814B << BIT_SHIFT_MCU_RSVD_2_V1_8814B)
#define BIT_CLEAR_MCU_RSVD_2_V1_8814B(x) ((x) & (~BITS_MCU_RSVD_2_V1_8814B))
#define BIT_GET_MCU_RSVD_2_V1_8814B(x) \
(((x) >> BIT_SHIFT_MCU_RSVD_2_V1_8814B) & BIT_MASK_MCU_RSVD_2_V1_8814B)
#define BIT_SET_MCU_RSVD_2_V1_8814B(x, v) \
(BIT_CLEAR_MCU_RSVD_2_V1_8814B(x) | BIT_MCU_RSVD_2_V1_8814B(v))
/* 2 REG_USTIME_EDCA_8814B (US TIME TUNING FOR EDCA REGISTER) */
#define BIT_SHIFT_USTIME_EDCA_8814B 0
#define BIT_MASK_USTIME_EDCA_8814B 0xff
#define BIT_USTIME_EDCA_8814B(x) \
(((x) & BIT_MASK_USTIME_EDCA_8814B) << BIT_SHIFT_USTIME_EDCA_8814B)
#define BITS_USTIME_EDCA_8814B \
(BIT_MASK_USTIME_EDCA_8814B << BIT_SHIFT_USTIME_EDCA_8814B)
#define BIT_CLEAR_USTIME_EDCA_8814B(x) ((x) & (~BITS_USTIME_EDCA_8814B))
#define BIT_GET_USTIME_EDCA_8814B(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA_8814B) & BIT_MASK_USTIME_EDCA_8814B)
#define BIT_SET_USTIME_EDCA_8814B(x, v) \
(BIT_CLEAR_USTIME_EDCA_8814B(x) | BIT_USTIME_EDCA_8814B(v))
/* 2 REG_ACKTO_CCK_8814B (ACK TIMEOUT REGISTER FOR CCK RATE) */
#define BIT_SHIFT_ACKTO_CCK_8814B 0
#define BIT_MASK_ACKTO_CCK_8814B 0xff
#define BIT_ACKTO_CCK_8814B(x) \
(((x) & BIT_MASK_ACKTO_CCK_8814B) << BIT_SHIFT_ACKTO_CCK_8814B)
#define BITS_ACKTO_CCK_8814B \
(BIT_MASK_ACKTO_CCK_8814B << BIT_SHIFT_ACKTO_CCK_8814B)
#define BIT_CLEAR_ACKTO_CCK_8814B(x) ((x) & (~BITS_ACKTO_CCK_8814B))
#define BIT_GET_ACKTO_CCK_8814B(x) \
(((x) >> BIT_SHIFT_ACKTO_CCK_8814B) & BIT_MASK_ACKTO_CCK_8814B)
#define BIT_SET_ACKTO_CCK_8814B(x, v) \
(BIT_CLEAR_ACKTO_CCK_8814B(x) | BIT_ACKTO_CCK_8814B(v))
/* 2 REG_MAC_SPEC_SIFS_8814B (SPECIFICATION SIFS REGISTER) */
#define BIT_SHIFT_SPEC_SIFS_OFDM_8814B 8
#define BIT_MASK_SPEC_SIFS_OFDM_8814B 0xff
#define BIT_SPEC_SIFS_OFDM_8814B(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_8814B) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_8814B)
#define BITS_SPEC_SIFS_OFDM_8814B \
(BIT_MASK_SPEC_SIFS_OFDM_8814B << BIT_SHIFT_SPEC_SIFS_OFDM_8814B)
#define BIT_CLEAR_SPEC_SIFS_OFDM_8814B(x) ((x) & (~BITS_SPEC_SIFS_OFDM_8814B))
#define BIT_GET_SPEC_SIFS_OFDM_8814B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_8814B) & \
BIT_MASK_SPEC_SIFS_OFDM_8814B)
#define BIT_SET_SPEC_SIFS_OFDM_8814B(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_8814B(x) | BIT_SPEC_SIFS_OFDM_8814B(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_8814B 0
#define BIT_MASK_SPEC_SIFS_CCK_8814B 0xff
#define BIT_SPEC_SIFS_CCK_8814B(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_8814B) << BIT_SHIFT_SPEC_SIFS_CCK_8814B)
#define BITS_SPEC_SIFS_CCK_8814B \
(BIT_MASK_SPEC_SIFS_CCK_8814B << BIT_SHIFT_SPEC_SIFS_CCK_8814B)
#define BIT_CLEAR_SPEC_SIFS_CCK_8814B(x) ((x) & (~BITS_SPEC_SIFS_CCK_8814B))
#define BIT_GET_SPEC_SIFS_CCK_8814B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_8814B) & BIT_MASK_SPEC_SIFS_CCK_8814B)
#define BIT_SET_SPEC_SIFS_CCK_8814B(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_8814B(x) | BIT_SPEC_SIFS_CCK_8814B(v))
/* 2 REG_RESP_SIFS_CCK_8814B (RESPONSE SIFS FOR CCK REGISTER) */
#define BIT_SHIFT_SIFS_R2T_CCK_8814B 8
#define BIT_MASK_SIFS_R2T_CCK_8814B 0xff
#define BIT_SIFS_R2T_CCK_8814B(x) \
(((x) & BIT_MASK_SIFS_R2T_CCK_8814B) << BIT_SHIFT_SIFS_R2T_CCK_8814B)
#define BITS_SIFS_R2T_CCK_8814B \
(BIT_MASK_SIFS_R2T_CCK_8814B << BIT_SHIFT_SIFS_R2T_CCK_8814B)
#define BIT_CLEAR_SIFS_R2T_CCK_8814B(x) ((x) & (~BITS_SIFS_R2T_CCK_8814B))
#define BIT_GET_SIFS_R2T_CCK_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_CCK_8814B) & BIT_MASK_SIFS_R2T_CCK_8814B)
#define BIT_SET_SIFS_R2T_CCK_8814B(x, v) \
(BIT_CLEAR_SIFS_R2T_CCK_8814B(x) | BIT_SIFS_R2T_CCK_8814B(v))
#define BIT_SHIFT_SIFS_T2T_CCK_8814B 0
#define BIT_MASK_SIFS_T2T_CCK_8814B 0xff
#define BIT_SIFS_T2T_CCK_8814B(x) \
(((x) & BIT_MASK_SIFS_T2T_CCK_8814B) << BIT_SHIFT_SIFS_T2T_CCK_8814B)
#define BITS_SIFS_T2T_CCK_8814B \
(BIT_MASK_SIFS_T2T_CCK_8814B << BIT_SHIFT_SIFS_T2T_CCK_8814B)
#define BIT_CLEAR_SIFS_T2T_CCK_8814B(x) ((x) & (~BITS_SIFS_T2T_CCK_8814B))
#define BIT_GET_SIFS_T2T_CCK_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_CCK_8814B) & BIT_MASK_SIFS_T2T_CCK_8814B)
#define BIT_SET_SIFS_T2T_CCK_8814B(x, v) \
(BIT_CLEAR_SIFS_T2T_CCK_8814B(x) | BIT_SIFS_T2T_CCK_8814B(v))
/* 2 REG_RESP_SIFS_OFDM_8814B (RESPONSE SIFS FOR OFDM REGISTER) */
#define BIT_SHIFT_SIFS_R2T_OFDM_8814B 8
#define BIT_MASK_SIFS_R2T_OFDM_8814B 0xff
#define BIT_SIFS_R2T_OFDM_8814B(x) \
(((x) & BIT_MASK_SIFS_R2T_OFDM_8814B) << BIT_SHIFT_SIFS_R2T_OFDM_8814B)
#define BITS_SIFS_R2T_OFDM_8814B \
(BIT_MASK_SIFS_R2T_OFDM_8814B << BIT_SHIFT_SIFS_R2T_OFDM_8814B)
#define BIT_CLEAR_SIFS_R2T_OFDM_8814B(x) ((x) & (~BITS_SIFS_R2T_OFDM_8814B))
#define BIT_GET_SIFS_R2T_OFDM_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_OFDM_8814B) & BIT_MASK_SIFS_R2T_OFDM_8814B)
#define BIT_SET_SIFS_R2T_OFDM_8814B(x, v) \
(BIT_CLEAR_SIFS_R2T_OFDM_8814B(x) | BIT_SIFS_R2T_OFDM_8814B(v))
#define BIT_SHIFT_SIFS_T2T_OFDM_8814B 0
#define BIT_MASK_SIFS_T2T_OFDM_8814B 0xff
#define BIT_SIFS_T2T_OFDM_8814B(x) \
(((x) & BIT_MASK_SIFS_T2T_OFDM_8814B) << BIT_SHIFT_SIFS_T2T_OFDM_8814B)
#define BITS_SIFS_T2T_OFDM_8814B \
(BIT_MASK_SIFS_T2T_OFDM_8814B << BIT_SHIFT_SIFS_T2T_OFDM_8814B)
#define BIT_CLEAR_SIFS_T2T_OFDM_8814B(x) ((x) & (~BITS_SIFS_T2T_OFDM_8814B))
#define BIT_GET_SIFS_T2T_OFDM_8814B(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_OFDM_8814B) & BIT_MASK_SIFS_T2T_OFDM_8814B)
#define BIT_SET_SIFS_T2T_OFDM_8814B(x, v) \
(BIT_CLEAR_SIFS_T2T_OFDM_8814B(x) | BIT_SIFS_T2T_OFDM_8814B(v))
/* 2 REG_ACKTO_8814B (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_ACKTO_8814B 0
#define BIT_MASK_ACKTO_8814B 0xff
#define BIT_ACKTO_8814B(x) \
(((x) & BIT_MASK_ACKTO_8814B) << BIT_SHIFT_ACKTO_8814B)
#define BITS_ACKTO_8814B (BIT_MASK_ACKTO_8814B << BIT_SHIFT_ACKTO_8814B)
#define BIT_CLEAR_ACKTO_8814B(x) ((x) & (~BITS_ACKTO_8814B))
#define BIT_GET_ACKTO_8814B(x) \
(((x) >> BIT_SHIFT_ACKTO_8814B) & BIT_MASK_ACKTO_8814B)
#define BIT_SET_ACKTO_8814B(x, v) \
(BIT_CLEAR_ACKTO_8814B(x) | BIT_ACKTO_8814B(v))
/* 2 REG_CTS2TO_8814B (CTS2 TIMEOUT REGISTER) */
#define BIT_SHIFT_CTS2TO_8814B 0
#define BIT_MASK_CTS2TO_8814B 0xff
#define BIT_CTS2TO_8814B(x) \
(((x) & BIT_MASK_CTS2TO_8814B) << BIT_SHIFT_CTS2TO_8814B)
#define BITS_CTS2TO_8814B (BIT_MASK_CTS2TO_8814B << BIT_SHIFT_CTS2TO_8814B)
#define BIT_CLEAR_CTS2TO_8814B(x) ((x) & (~BITS_CTS2TO_8814B))
#define BIT_GET_CTS2TO_8814B(x) \
(((x) >> BIT_SHIFT_CTS2TO_8814B) & BIT_MASK_CTS2TO_8814B)
#define BIT_SET_CTS2TO_8814B(x, v) \
(BIT_CLEAR_CTS2TO_8814B(x) | BIT_CTS2TO_8814B(v))
/* 2 REG_EIFS_8814B (EIFS REGISTER) */
#define BIT_SHIFT_EIFS_8814B 0
#define BIT_MASK_EIFS_8814B 0xffff
#define BIT_EIFS_8814B(x) (((x) & BIT_MASK_EIFS_8814B) << BIT_SHIFT_EIFS_8814B)
#define BITS_EIFS_8814B (BIT_MASK_EIFS_8814B << BIT_SHIFT_EIFS_8814B)
#define BIT_CLEAR_EIFS_8814B(x) ((x) & (~BITS_EIFS_8814B))
#define BIT_GET_EIFS_8814B(x) \
(((x) >> BIT_SHIFT_EIFS_8814B) & BIT_MASK_EIFS_8814B)
#define BIT_SET_EIFS_8814B(x, v) (BIT_CLEAR_EIFS_8814B(x) | BIT_EIFS_8814B(v))
/* 2 REG_RPFM_MAP0_8814B */
#define BIT_MGT_RPFM15EN_8814B BIT(15)
#define BIT_MGT_RPFM14EN_8814B BIT(14)
#define BIT_MGT_RPFM13EN_8814B BIT(13)
#define BIT_MGT_RPFM12EN_8814B BIT(12)
#define BIT_MGT_RPFM11EN_8814B BIT(11)
#define BIT_MGT_RPFM10EN_8814B BIT(10)
#define BIT_MGT_RPFM9EN_8814B BIT(9)
#define BIT_MGT_RPFM8EN_8814B BIT(8)
#define BIT_MGT_RPFM7EN_8814B BIT(7)
#define BIT_MGT_RPFM6EN_8814B BIT(6)
#define BIT_MGT_RPFM5EN_8814B BIT(5)
#define BIT_MGT_RPFM4EN_8814B BIT(4)
#define BIT_MGT_RPFM3EN_8814B BIT(3)
#define BIT_MGT_RPFM2EN_8814B BIT(2)
#define BIT_MGT_RPFM1EN_8814B BIT(1)
#define BIT_MGT_RPFM0EN_8814B BIT(0)
/* 2 REG_RPFM_MAP1_V1_8814B */
#define BIT_DATA_RPFM15EN_8814B BIT(15)
#define BIT_DATA_RPFM14EN_8814B BIT(14)
#define BIT_DATA_RPFM13EN_8814B BIT(13)
#define BIT_DATA_RPFM12EN_8814B BIT(12)
#define BIT_DATA_RPFM11EN_8814B BIT(11)
#define BIT_DATA_RPFM10EN_8814B BIT(10)
#define BIT_DATA_RPFM9EN_8814B BIT(9)
#define BIT_DATA_RPFM8EN_8814B BIT(8)
#define BIT_DATA_RPFM7EN_8814B BIT(7)
#define BIT_DATA_RPFM6EN_8814B BIT(6)
#define BIT_DATA_RPFM5EN_8814B BIT(5)
#define BIT_DATA_RPFM4EN_8814B BIT(4)
#define BIT_DATA_RPFM3EN_8814B BIT(3)
#define BIT_DATA_RPFM2EN_8814B BIT(2)
#define BIT_DATA_RPFM1EN_8814B BIT(1)
#define BIT_DATA_RPFM0EN_8814B BIT(0)
/* 2 REG_RPFM_CAM_CMD_8814B (RX PAYLOAD FRAME MASK CAM COMMAND REGISTER) */
#define BIT_RPFM_CAM_POLLING_8814B BIT(31)
#define BIT_RPFM_CAM_CLR_8814B BIT(30)
#define BIT_RPFM_CAM_WE_8814B BIT(16)
#define BIT_SHIFT_RPFM_CAM_ADDR_8814B 0
#define BIT_MASK_RPFM_CAM_ADDR_8814B 0x7f
#define BIT_RPFM_CAM_ADDR_8814B(x) \
(((x) & BIT_MASK_RPFM_CAM_ADDR_8814B) << BIT_SHIFT_RPFM_CAM_ADDR_8814B)
#define BITS_RPFM_CAM_ADDR_8814B \
(BIT_MASK_RPFM_CAM_ADDR_8814B << BIT_SHIFT_RPFM_CAM_ADDR_8814B)
#define BIT_CLEAR_RPFM_CAM_ADDR_8814B(x) ((x) & (~BITS_RPFM_CAM_ADDR_8814B))
#define BIT_GET_RPFM_CAM_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_ADDR_8814B) & BIT_MASK_RPFM_CAM_ADDR_8814B)
#define BIT_SET_RPFM_CAM_ADDR_8814B(x, v) \
(BIT_CLEAR_RPFM_CAM_ADDR_8814B(x) | BIT_RPFM_CAM_ADDR_8814B(v))
/* 2 REG_RPFM_CAM_RWD_8814B (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_RPFM_CAM_RWD_8814B 0
#define BIT_MASK_RPFM_CAM_RWD_8814B 0xffffffffL
#define BIT_RPFM_CAM_RWD_8814B(x) \
(((x) & BIT_MASK_RPFM_CAM_RWD_8814B) << BIT_SHIFT_RPFM_CAM_RWD_8814B)
#define BITS_RPFM_CAM_RWD_8814B \
(BIT_MASK_RPFM_CAM_RWD_8814B << BIT_SHIFT_RPFM_CAM_RWD_8814B)
#define BIT_CLEAR_RPFM_CAM_RWD_8814B(x) ((x) & (~BITS_RPFM_CAM_RWD_8814B))
#define BIT_GET_RPFM_CAM_RWD_8814B(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_RWD_8814B) & BIT_MASK_RPFM_CAM_RWD_8814B)
#define BIT_SET_RPFM_CAM_RWD_8814B(x, v) \
(BIT_CLEAR_RPFM_CAM_RWD_8814B(x) | BIT_RPFM_CAM_RWD_8814B(v))
/* 2 REG_NAV_CTRL_8814B (NAV CONTROL REGISTER) */
#define BIT_SHIFT_NAV_UPPER_8814B 16
#define BIT_MASK_NAV_UPPER_8814B 0xff
#define BIT_NAV_UPPER_8814B(x) \
(((x) & BIT_MASK_NAV_UPPER_8814B) << BIT_SHIFT_NAV_UPPER_8814B)
#define BITS_NAV_UPPER_8814B \
(BIT_MASK_NAV_UPPER_8814B << BIT_SHIFT_NAV_UPPER_8814B)
#define BIT_CLEAR_NAV_UPPER_8814B(x) ((x) & (~BITS_NAV_UPPER_8814B))
#define BIT_GET_NAV_UPPER_8814B(x) \
(((x) >> BIT_SHIFT_NAV_UPPER_8814B) & BIT_MASK_NAV_UPPER_8814B)
#define BIT_SET_NAV_UPPER_8814B(x, v) \
(BIT_CLEAR_NAV_UPPER_8814B(x) | BIT_NAV_UPPER_8814B(v))
#define BIT_SHIFT_RXMYRTS_NAV_8814B 8
#define BIT_MASK_RXMYRTS_NAV_8814B 0xf
#define BIT_RXMYRTS_NAV_8814B(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_8814B) << BIT_SHIFT_RXMYRTS_NAV_8814B)
#define BITS_RXMYRTS_NAV_8814B \
(BIT_MASK_RXMYRTS_NAV_8814B << BIT_SHIFT_RXMYRTS_NAV_8814B)
#define BIT_CLEAR_RXMYRTS_NAV_8814B(x) ((x) & (~BITS_RXMYRTS_NAV_8814B))
#define BIT_GET_RXMYRTS_NAV_8814B(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_8814B) & BIT_MASK_RXMYRTS_NAV_8814B)
#define BIT_SET_RXMYRTS_NAV_8814B(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_8814B(x) | BIT_RXMYRTS_NAV_8814B(v))
#define BIT_SHIFT_RTSRST_8814B 0
#define BIT_MASK_RTSRST_8814B 0xff
#define BIT_RTSRST_8814B(x) \
(((x) & BIT_MASK_RTSRST_8814B) << BIT_SHIFT_RTSRST_8814B)
#define BITS_RTSRST_8814B (BIT_MASK_RTSRST_8814B << BIT_SHIFT_RTSRST_8814B)
#define BIT_CLEAR_RTSRST_8814B(x) ((x) & (~BITS_RTSRST_8814B))
#define BIT_GET_RTSRST_8814B(x) \
(((x) >> BIT_SHIFT_RTSRST_8814B) & BIT_MASK_RTSRST_8814B)
#define BIT_SET_RTSRST_8814B(x, v) \
(BIT_CLEAR_RTSRST_8814B(x) | BIT_RTSRST_8814B(v))
/* 2 REG_BACAMCMD_8814B (BLOCK ACK CAM COMMAND REGISTER) */
#define BIT_BACAM_POLL_8814B BIT(31)
#define BIT_BACAM_RST_8814B BIT(17)
#define BIT_BACAM_RW_8814B BIT(16)
#define BIT_SHIFT_TXSBM_8814B 14
#define BIT_MASK_TXSBM_8814B 0x3
#define BIT_TXSBM_8814B(x) \
(((x) & BIT_MASK_TXSBM_8814B) << BIT_SHIFT_TXSBM_8814B)
#define BITS_TXSBM_8814B (BIT_MASK_TXSBM_8814B << BIT_SHIFT_TXSBM_8814B)
#define BIT_CLEAR_TXSBM_8814B(x) ((x) & (~BITS_TXSBM_8814B))
#define BIT_GET_TXSBM_8814B(x) \
(((x) >> BIT_SHIFT_TXSBM_8814B) & BIT_MASK_TXSBM_8814B)
#define BIT_SET_TXSBM_8814B(x, v) \
(BIT_CLEAR_TXSBM_8814B(x) | BIT_TXSBM_8814B(v))
#define BIT_SHIFT_BACAM_ADDR_8814B 0
#define BIT_MASK_BACAM_ADDR_8814B 0x3f
#define BIT_BACAM_ADDR_8814B(x) \
(((x) & BIT_MASK_BACAM_ADDR_8814B) << BIT_SHIFT_BACAM_ADDR_8814B)
#define BITS_BACAM_ADDR_8814B \
(BIT_MASK_BACAM_ADDR_8814B << BIT_SHIFT_BACAM_ADDR_8814B)
#define BIT_CLEAR_BACAM_ADDR_8814B(x) ((x) & (~BITS_BACAM_ADDR_8814B))
#define BIT_GET_BACAM_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_BACAM_ADDR_8814B) & BIT_MASK_BACAM_ADDR_8814B)
#define BIT_SET_BACAM_ADDR_8814B(x, v) \
(BIT_CLEAR_BACAM_ADDR_8814B(x) | BIT_BACAM_ADDR_8814B(v))
/* 2 REG_BACAMCONTENT_8814B (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_L_8814B 0
#define BIT_MASK_BA_CONTENT_L_8814B 0xffffffffL
#define BIT_BA_CONTENT_L_8814B(x) \
(((x) & BIT_MASK_BA_CONTENT_L_8814B) << BIT_SHIFT_BA_CONTENT_L_8814B)
#define BITS_BA_CONTENT_L_8814B \
(BIT_MASK_BA_CONTENT_L_8814B << BIT_SHIFT_BA_CONTENT_L_8814B)
#define BIT_CLEAR_BA_CONTENT_L_8814B(x) ((x) & (~BITS_BA_CONTENT_L_8814B))
#define BIT_GET_BA_CONTENT_L_8814B(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_L_8814B) & BIT_MASK_BA_CONTENT_L_8814B)
#define BIT_SET_BA_CONTENT_L_8814B(x, v) \
(BIT_CLEAR_BA_CONTENT_L_8814B(x) | BIT_BA_CONTENT_L_8814B(v))
/* 2 REG_BACAMCONTENT_H_8814B (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_H_8814B 0
#define BIT_MASK_BA_CONTENT_H_8814B 0xffffffffL
#define BIT_BA_CONTENT_H_8814B(x) \
(((x) & BIT_MASK_BA_CONTENT_H_8814B) << BIT_SHIFT_BA_CONTENT_H_8814B)
#define BITS_BA_CONTENT_H_8814B \
(BIT_MASK_BA_CONTENT_H_8814B << BIT_SHIFT_BA_CONTENT_H_8814B)
#define BIT_CLEAR_BA_CONTENT_H_8814B(x) ((x) & (~BITS_BA_CONTENT_H_8814B))
#define BIT_GET_BA_CONTENT_H_8814B(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_H_8814B) & BIT_MASK_BA_CONTENT_H_8814B)
#define BIT_SET_BA_CONTENT_H_8814B(x, v) \
(BIT_CLEAR_BA_CONTENT_H_8814B(x) | BIT_BA_CONTENT_H_8814B(v))
/* 2 REG_LBDLY_8814B (LOOPBACK DELAY REGISTER) */
#define BIT_SHIFT_LBDLY_8814B 0
#define BIT_MASK_LBDLY_8814B 0x1f
#define BIT_LBDLY_8814B(x) \
(((x) & BIT_MASK_LBDLY_8814B) << BIT_SHIFT_LBDLY_8814B)
#define BITS_LBDLY_8814B (BIT_MASK_LBDLY_8814B << BIT_SHIFT_LBDLY_8814B)
#define BIT_CLEAR_LBDLY_8814B(x) ((x) & (~BITS_LBDLY_8814B))
#define BIT_GET_LBDLY_8814B(x) \
(((x) >> BIT_SHIFT_LBDLY_8814B) & BIT_MASK_LBDLY_8814B)
#define BIT_SET_LBDLY_8814B(x, v) \
(BIT_CLEAR_LBDLY_8814B(x) | BIT_LBDLY_8814B(v))
/* 2 REG_WMAC_BACAM_RPMEN_8814B */
#define BIT_SHIFT_BITMAP_SSNBK_COUNTER_8814B 2
#define BIT_MASK_BITMAP_SSNBK_COUNTER_8814B 0x3f
#define BIT_BITMAP_SSNBK_COUNTER_8814B(x) \
(((x) & BIT_MASK_BITMAP_SSNBK_COUNTER_8814B) \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8814B)
#define BITS_BITMAP_SSNBK_COUNTER_8814B \
(BIT_MASK_BITMAP_SSNBK_COUNTER_8814B \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8814B)
#define BIT_CLEAR_BITMAP_SSNBK_COUNTER_8814B(x) \
((x) & (~BITS_BITMAP_SSNBK_COUNTER_8814B))
#define BIT_GET_BITMAP_SSNBK_COUNTER_8814B(x) \
(((x) >> BIT_SHIFT_BITMAP_SSNBK_COUNTER_8814B) & \
BIT_MASK_BITMAP_SSNBK_COUNTER_8814B)
#define BIT_SET_BITMAP_SSNBK_COUNTER_8814B(x, v) \
(BIT_CLEAR_BITMAP_SSNBK_COUNTER_8814B(x) | \
BIT_BITMAP_SSNBK_COUNTER_8814B(v))
#define BIT_BITMAP_EN_8814B BIT(1)
#define BIT_WMAC_BACAM_RPMEN_8814B BIT(0)
/* 2 REG_TX_RX_8814B STATUS */
#define BIT_SHIFT_RXPKT_TYPE_8814B 2
#define BIT_MASK_RXPKT_TYPE_8814B 0x3f
#define BIT_RXPKT_TYPE_8814B(x) \
(((x) & BIT_MASK_RXPKT_TYPE_8814B) << BIT_SHIFT_RXPKT_TYPE_8814B)
#define BITS_RXPKT_TYPE_8814B \
(BIT_MASK_RXPKT_TYPE_8814B << BIT_SHIFT_RXPKT_TYPE_8814B)
#define BIT_CLEAR_RXPKT_TYPE_8814B(x) ((x) & (~BITS_RXPKT_TYPE_8814B))
#define BIT_GET_RXPKT_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_RXPKT_TYPE_8814B) & BIT_MASK_RXPKT_TYPE_8814B)
#define BIT_SET_RXPKT_TYPE_8814B(x, v) \
(BIT_CLEAR_RXPKT_TYPE_8814B(x) | BIT_RXPKT_TYPE_8814B(v))
#define BIT_TXACT_IND_8814B BIT(1)
#define BIT_RXACT_IND_8814B BIT(0)
/* 2 REG_WMAC_BITMAP_CTL_8814B */
#define BIT_BITMAP_VO_8814B BIT(7)
#define BIT_BITMAP_VI_8814B BIT(6)
#define BIT_BITMAP_BE_8814B BIT(5)
#define BIT_BITMAP_BK_8814B BIT(4)
#define BIT_SHIFT_BITMAP_CONDITION_8814B 2
#define BIT_MASK_BITMAP_CONDITION_8814B 0x3
#define BIT_BITMAP_CONDITION_8814B(x) \
(((x) & BIT_MASK_BITMAP_CONDITION_8814B) \
<< BIT_SHIFT_BITMAP_CONDITION_8814B)
#define BITS_BITMAP_CONDITION_8814B \
(BIT_MASK_BITMAP_CONDITION_8814B << BIT_SHIFT_BITMAP_CONDITION_8814B)
#define BIT_CLEAR_BITMAP_CONDITION_8814B(x) \
((x) & (~BITS_BITMAP_CONDITION_8814B))
#define BIT_GET_BITMAP_CONDITION_8814B(x) \
(((x) >> BIT_SHIFT_BITMAP_CONDITION_8814B) & \
BIT_MASK_BITMAP_CONDITION_8814B)
#define BIT_SET_BITMAP_CONDITION_8814B(x, v) \
(BIT_CLEAR_BITMAP_CONDITION_8814B(x) | BIT_BITMAP_CONDITION_8814B(v))
#define BIT_BITMAP_SSNBK_COUNTER_CLR_8814B BIT(1)
#define BIT_BITMAP_FORCE_8814B BIT(0)
/* 2 REG_RXERR_RPT_8814B (RX ERROR REPORT REGISTER) */
#define BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8814B 28
#define BIT_MASK_RXERR_RPT_SEL_V1_3_0_8814B 0xf
#define BIT_RXERR_RPT_SEL_V1_3_0_8814B(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL_V1_3_0_8814B) \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8814B)
#define BITS_RXERR_RPT_SEL_V1_3_0_8814B \
(BIT_MASK_RXERR_RPT_SEL_V1_3_0_8814B \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8814B)
#define BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8814B(x) \
((x) & (~BITS_RXERR_RPT_SEL_V1_3_0_8814B))
#define BIT_GET_RXERR_RPT_SEL_V1_3_0_8814B(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8814B) & \
BIT_MASK_RXERR_RPT_SEL_V1_3_0_8814B)
#define BIT_SET_RXERR_RPT_SEL_V1_3_0_8814B(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8814B(x) | \
BIT_RXERR_RPT_SEL_V1_3_0_8814B(v))
#define BIT_RXERR_RPT_RST_8814B BIT(27)
#define BIT_RXERR_RPT_SEL_V1_4_8814B BIT(26)
#define BIT_W1S_8814B BIT(23)
#define BIT_UD_SELECT_BSSID_8814B BIT(22)
#define BIT_SHIFT_UD_SUB_TYPE_8814B 18
#define BIT_MASK_UD_SUB_TYPE_8814B 0xf
#define BIT_UD_SUB_TYPE_8814B(x) \
(((x) & BIT_MASK_UD_SUB_TYPE_8814B) << BIT_SHIFT_UD_SUB_TYPE_8814B)
#define BITS_UD_SUB_TYPE_8814B \
(BIT_MASK_UD_SUB_TYPE_8814B << BIT_SHIFT_UD_SUB_TYPE_8814B)
#define BIT_CLEAR_UD_SUB_TYPE_8814B(x) ((x) & (~BITS_UD_SUB_TYPE_8814B))
#define BIT_GET_UD_SUB_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_UD_SUB_TYPE_8814B) & BIT_MASK_UD_SUB_TYPE_8814B)
#define BIT_SET_UD_SUB_TYPE_8814B(x, v) \
(BIT_CLEAR_UD_SUB_TYPE_8814B(x) | BIT_UD_SUB_TYPE_8814B(v))
#define BIT_SHIFT_UD_TYPE_8814B 16
#define BIT_MASK_UD_TYPE_8814B 0x3
#define BIT_UD_TYPE_8814B(x) \
(((x) & BIT_MASK_UD_TYPE_8814B) << BIT_SHIFT_UD_TYPE_8814B)
#define BITS_UD_TYPE_8814B (BIT_MASK_UD_TYPE_8814B << BIT_SHIFT_UD_TYPE_8814B)
#define BIT_CLEAR_UD_TYPE_8814B(x) ((x) & (~BITS_UD_TYPE_8814B))
#define BIT_GET_UD_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_UD_TYPE_8814B) & BIT_MASK_UD_TYPE_8814B)
#define BIT_SET_UD_TYPE_8814B(x, v) \
(BIT_CLEAR_UD_TYPE_8814B(x) | BIT_UD_TYPE_8814B(v))
#define BIT_SHIFT_RPT_COUNTER_8814B 0
#define BIT_MASK_RPT_COUNTER_8814B 0xffff
#define BIT_RPT_COUNTER_8814B(x) \
(((x) & BIT_MASK_RPT_COUNTER_8814B) << BIT_SHIFT_RPT_COUNTER_8814B)
#define BITS_RPT_COUNTER_8814B \
(BIT_MASK_RPT_COUNTER_8814B << BIT_SHIFT_RPT_COUNTER_8814B)
#define BIT_CLEAR_RPT_COUNTER_8814B(x) ((x) & (~BITS_RPT_COUNTER_8814B))
#define BIT_GET_RPT_COUNTER_8814B(x) \
(((x) >> BIT_SHIFT_RPT_COUNTER_8814B) & BIT_MASK_RPT_COUNTER_8814B)
#define BIT_SET_RPT_COUNTER_8814B(x, v) \
(BIT_CLEAR_RPT_COUNTER_8814B(x) | BIT_RPT_COUNTER_8814B(v))
/* 2 REG_WMAC_TRXPTCL_CTL_8814B (WMAC TX/RX PROTOCOL CONTROL REGISTER) */
#define BIT_EN_TXCTS_INTXOP_8814B BIT(32)
#define BIT_BLK_EDCA_BBSLP_8814B BIT(31)
#define BIT_BLK_EDCA_BBSBY_8814B BIT(30)
#define BIT_ACKTO_BLOCK_SCH_EN_8814B BIT(27)
#define BIT_EIFS_BLOCK_SCH_EN_8814B BIT(26)
#define BIT_PLCPCHK_RST_EIFS_8814B BIT(25)
#define BIT_CCA_RST_EIFS_8814B BIT(24)
#define BIT_DIS_UPD_MYRXPKTNAV_8814B BIT(23)
#define BIT_EARLY_TXBA_8814B BIT(22)
#define BIT_SHIFT_RESP_CHNBUSY_8814B 20
#define BIT_MASK_RESP_CHNBUSY_8814B 0x3
#define BIT_RESP_CHNBUSY_8814B(x) \
(((x) & BIT_MASK_RESP_CHNBUSY_8814B) << BIT_SHIFT_RESP_CHNBUSY_8814B)
#define BITS_RESP_CHNBUSY_8814B \
(BIT_MASK_RESP_CHNBUSY_8814B << BIT_SHIFT_RESP_CHNBUSY_8814B)
#define BIT_CLEAR_RESP_CHNBUSY_8814B(x) ((x) & (~BITS_RESP_CHNBUSY_8814B))
#define BIT_GET_RESP_CHNBUSY_8814B(x) \
(((x) >> BIT_SHIFT_RESP_CHNBUSY_8814B) & BIT_MASK_RESP_CHNBUSY_8814B)
#define BIT_SET_RESP_CHNBUSY_8814B(x, v) \
(BIT_CLEAR_RESP_CHNBUSY_8814B(x) | BIT_RESP_CHNBUSY_8814B(v))
#define BIT_RESP_DCTS_EN_8814B BIT(19)
#define BIT_RESP_DCFE_EN_8814B BIT(18)
#define BIT_RESP_SPLCPEN_8814B BIT(17)
#define BIT_RESP_SGIEN_8814B BIT(16)
#define BIT_RESP_LDPC_EN_8814B BIT(15)
#define BIT_DIS_RESP_ACKINCCA_8814B BIT(14)
#define BIT_DIS_RESP_CTSINCCA_8814B BIT(13)
#define BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8814B 10
#define BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8814B 0x7
#define BIT_R_WMAC_SECOND_CCA_TIMER_8814B(x) \
(((x) & BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8814B) \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8814B)
#define BITS_R_WMAC_SECOND_CCA_TIMER_8814B \
(BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8814B \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8814B)
#define BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8814B(x) \
((x) & (~BITS_R_WMAC_SECOND_CCA_TIMER_8814B))
#define BIT_GET_R_WMAC_SECOND_CCA_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8814B) & \
BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8814B)
#define BIT_SET_R_WMAC_SECOND_CCA_TIMER_8814B(x, v) \
(BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8814B(x) | \
BIT_R_WMAC_SECOND_CCA_TIMER_8814B(v))
#define BIT_SHIFT_RFMOD_8814B 7
#define BIT_MASK_RFMOD_8814B 0x3
#define BIT_RFMOD_8814B(x) \
(((x) & BIT_MASK_RFMOD_8814B) << BIT_SHIFT_RFMOD_8814B)
#define BITS_RFMOD_8814B (BIT_MASK_RFMOD_8814B << BIT_SHIFT_RFMOD_8814B)
#define BIT_CLEAR_RFMOD_8814B(x) ((x) & (~BITS_RFMOD_8814B))
#define BIT_GET_RFMOD_8814B(x) \
(((x) >> BIT_SHIFT_RFMOD_8814B) & BIT_MASK_RFMOD_8814B)
#define BIT_SET_RFMOD_8814B(x, v) \
(BIT_CLEAR_RFMOD_8814B(x) | BIT_RFMOD_8814B(v))
#define BIT_SHIFT_RESP_CTS_DYNBW_SEL_8814B 5
#define BIT_MASK_RESP_CTS_DYNBW_SEL_8814B 0x3
#define BIT_RESP_CTS_DYNBW_SEL_8814B(x) \
(((x) & BIT_MASK_RESP_CTS_DYNBW_SEL_8814B) \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8814B)
#define BITS_RESP_CTS_DYNBW_SEL_8814B \
(BIT_MASK_RESP_CTS_DYNBW_SEL_8814B \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8814B)
#define BIT_CLEAR_RESP_CTS_DYNBW_SEL_8814B(x) \
((x) & (~BITS_RESP_CTS_DYNBW_SEL_8814B))
#define BIT_GET_RESP_CTS_DYNBW_SEL_8814B(x) \
(((x) >> BIT_SHIFT_RESP_CTS_DYNBW_SEL_8814B) & \
BIT_MASK_RESP_CTS_DYNBW_SEL_8814B)
#define BIT_SET_RESP_CTS_DYNBW_SEL_8814B(x, v) \
(BIT_CLEAR_RESP_CTS_DYNBW_SEL_8814B(x) | \
BIT_RESP_CTS_DYNBW_SEL_8814B(v))
#define BIT_DLY_TX_WAIT_RXANTSEL_8814B BIT(4)
#define BIT_TXRESP_BY_RXANTSEL_8814B BIT(3)
#define BIT_SHIFT_ORIG_DCTS_CHK_8814B 0
#define BIT_MASK_ORIG_DCTS_CHK_8814B 0x3
#define BIT_ORIG_DCTS_CHK_8814B(x) \
(((x) & BIT_MASK_ORIG_DCTS_CHK_8814B) << BIT_SHIFT_ORIG_DCTS_CHK_8814B)
#define BITS_ORIG_DCTS_CHK_8814B \
(BIT_MASK_ORIG_DCTS_CHK_8814B << BIT_SHIFT_ORIG_DCTS_CHK_8814B)
#define BIT_CLEAR_ORIG_DCTS_CHK_8814B(x) ((x) & (~BITS_ORIG_DCTS_CHK_8814B))
#define BIT_GET_ORIG_DCTS_CHK_8814B(x) \
(((x) >> BIT_SHIFT_ORIG_DCTS_CHK_8814B) & BIT_MASK_ORIG_DCTS_CHK_8814B)
#define BIT_SET_ORIG_DCTS_CHK_8814B(x, v) \
(BIT_CLEAR_ORIG_DCTS_CHK_8814B(x) | BIT_ORIG_DCTS_CHK_8814B(v))
/* 2 REG_WMAC_TRXPTCL_CTL_H_8814B */
#define BIT_SHIFT_ACKBA_TYPSEL_8814B 28
#define BIT_MASK_ACKBA_TYPSEL_8814B 0xf
#define BIT_ACKBA_TYPSEL_8814B(x) \
(((x) & BIT_MASK_ACKBA_TYPSEL_8814B) << BIT_SHIFT_ACKBA_TYPSEL_8814B)
#define BITS_ACKBA_TYPSEL_8814B \
(BIT_MASK_ACKBA_TYPSEL_8814B << BIT_SHIFT_ACKBA_TYPSEL_8814B)
#define BIT_CLEAR_ACKBA_TYPSEL_8814B(x) ((x) & (~BITS_ACKBA_TYPSEL_8814B))
#define BIT_GET_ACKBA_TYPSEL_8814B(x) \
(((x) >> BIT_SHIFT_ACKBA_TYPSEL_8814B) & BIT_MASK_ACKBA_TYPSEL_8814B)
#define BIT_SET_ACKBA_TYPSEL_8814B(x, v) \
(BIT_CLEAR_ACKBA_TYPSEL_8814B(x) | BIT_ACKBA_TYPSEL_8814B(v))
#define BIT_SHIFT_ACKBA_ACKPCHK_8814B 24
#define BIT_MASK_ACKBA_ACKPCHK_8814B 0xf
#define BIT_ACKBA_ACKPCHK_8814B(x) \
(((x) & BIT_MASK_ACKBA_ACKPCHK_8814B) << BIT_SHIFT_ACKBA_ACKPCHK_8814B)
#define BITS_ACKBA_ACKPCHK_8814B \
(BIT_MASK_ACKBA_ACKPCHK_8814B << BIT_SHIFT_ACKBA_ACKPCHK_8814B)
#define BIT_CLEAR_ACKBA_ACKPCHK_8814B(x) ((x) & (~BITS_ACKBA_ACKPCHK_8814B))
#define BIT_GET_ACKBA_ACKPCHK_8814B(x) \
(((x) >> BIT_SHIFT_ACKBA_ACKPCHK_8814B) & BIT_MASK_ACKBA_ACKPCHK_8814B)
#define BIT_SET_ACKBA_ACKPCHK_8814B(x, v) \
(BIT_CLEAR_ACKBA_ACKPCHK_8814B(x) | BIT_ACKBA_ACKPCHK_8814B(v))
#define BIT_SHIFT_ACKBAR_TYPESEL_8814B 16
#define BIT_MASK_ACKBAR_TYPESEL_8814B 0xff
#define BIT_ACKBAR_TYPESEL_8814B(x) \
(((x) & BIT_MASK_ACKBAR_TYPESEL_8814B) \
<< BIT_SHIFT_ACKBAR_TYPESEL_8814B)
#define BITS_ACKBAR_TYPESEL_8814B \
(BIT_MASK_ACKBAR_TYPESEL_8814B << BIT_SHIFT_ACKBAR_TYPESEL_8814B)
#define BIT_CLEAR_ACKBAR_TYPESEL_8814B(x) ((x) & (~BITS_ACKBAR_TYPESEL_8814B))
#define BIT_GET_ACKBAR_TYPESEL_8814B(x) \
(((x) >> BIT_SHIFT_ACKBAR_TYPESEL_8814B) & \
BIT_MASK_ACKBAR_TYPESEL_8814B)
#define BIT_SET_ACKBAR_TYPESEL_8814B(x, v) \
(BIT_CLEAR_ACKBAR_TYPESEL_8814B(x) | BIT_ACKBAR_TYPESEL_8814B(v))
#define BIT_SHIFT_ACKBAR_ACKPCHK_8814B 12
#define BIT_MASK_ACKBAR_ACKPCHK_8814B 0xf
#define BIT_ACKBAR_ACKPCHK_8814B(x) \
(((x) & BIT_MASK_ACKBAR_ACKPCHK_8814B) \
<< BIT_SHIFT_ACKBAR_ACKPCHK_8814B)
#define BITS_ACKBAR_ACKPCHK_8814B \
(BIT_MASK_ACKBAR_ACKPCHK_8814B << BIT_SHIFT_ACKBAR_ACKPCHK_8814B)
#define BIT_CLEAR_ACKBAR_ACKPCHK_8814B(x) ((x) & (~BITS_ACKBAR_ACKPCHK_8814B))
#define BIT_GET_ACKBAR_ACKPCHK_8814B(x) \
(((x) >> BIT_SHIFT_ACKBAR_ACKPCHK_8814B) & \
BIT_MASK_ACKBAR_ACKPCHK_8814B)
#define BIT_SET_ACKBAR_ACKPCHK_8814B(x, v) \
(BIT_CLEAR_ACKBAR_ACKPCHK_8814B(x) | BIT_ACKBAR_ACKPCHK_8814B(v))
#define BIT_RXBA_IGNOREA2_V1_8814B BIT(10)
#define BIT_EN_SAVE_ALL_TXOPADDR_V1_8814B BIT(9)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV_V1_8814B BIT(8)
#define BIT_DIS_TXBA_AMPDUFCSERR_V1_8814B BIT(7)
#define BIT_DIS_TXBA_RXBARINFULL_V1_8814B BIT(6)
#define BIT_DIS_TXCFE_INFULL_V1_8814B BIT(5)
#define BIT_DIS_TXCTS_INFULL_V1_8814B BIT(4)
#define BIT_EN_TXACKBA_IN_TX_RDG_V1_8814B BIT(3)
#define BIT_EN_TXACKBA_IN_TXOP_V1_8814B BIT(2)
#define BIT_EN_TXCTS_IN_RXNAV_V1_8814B BIT(1)
#define BIT_EN_TXCTS_INTXOP_V1_8814B BIT(0)
/* 2 REG_CAMCMD_8814B (CAM COMMAND REGISTER) */
#define BIT_SECCAM_POLLING_8814B BIT(31)
#define BIT_SECCAM_CLR_8814B BIT(30)
#define BIT_SECCAM_WE_8814B BIT(16)
#define BIT_SHIFT_SECCAM_ADDR_V2_8814B 0
#define BIT_MASK_SECCAM_ADDR_V2_8814B 0x3ff
#define BIT_SECCAM_ADDR_V2_8814B(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V2_8814B) \
<< BIT_SHIFT_SECCAM_ADDR_V2_8814B)
#define BITS_SECCAM_ADDR_V2_8814B \
(BIT_MASK_SECCAM_ADDR_V2_8814B << BIT_SHIFT_SECCAM_ADDR_V2_8814B)
#define BIT_CLEAR_SECCAM_ADDR_V2_8814B(x) ((x) & (~BITS_SECCAM_ADDR_V2_8814B))
#define BIT_GET_SECCAM_ADDR_V2_8814B(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V2_8814B) & \
BIT_MASK_SECCAM_ADDR_V2_8814B)
#define BIT_SET_SECCAM_ADDR_V2_8814B(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V2_8814B(x) | BIT_SECCAM_ADDR_V2_8814B(v))
/* 2 REG_CAMWRITE_8814B (CAM WRITE REGISTER) */
#define BIT_SHIFT_CAMW_DATA_8814B 0
#define BIT_MASK_CAMW_DATA_8814B 0xffffffffL
#define BIT_CAMW_DATA_8814B(x) \
(((x) & BIT_MASK_CAMW_DATA_8814B) << BIT_SHIFT_CAMW_DATA_8814B)
#define BITS_CAMW_DATA_8814B \
(BIT_MASK_CAMW_DATA_8814B << BIT_SHIFT_CAMW_DATA_8814B)
#define BIT_CLEAR_CAMW_DATA_8814B(x) ((x) & (~BITS_CAMW_DATA_8814B))
#define BIT_GET_CAMW_DATA_8814B(x) \
(((x) >> BIT_SHIFT_CAMW_DATA_8814B) & BIT_MASK_CAMW_DATA_8814B)
#define BIT_SET_CAMW_DATA_8814B(x, v) \
(BIT_CLEAR_CAMW_DATA_8814B(x) | BIT_CAMW_DATA_8814B(v))
/* 2 REG_CAMREAD_8814B (CAM READ REGISTER) */
#define BIT_SHIFT_CAMR_DATA_8814B 0
#define BIT_MASK_CAMR_DATA_8814B 0xffffffffL
#define BIT_CAMR_DATA_8814B(x) \
(((x) & BIT_MASK_CAMR_DATA_8814B) << BIT_SHIFT_CAMR_DATA_8814B)
#define BITS_CAMR_DATA_8814B \
(BIT_MASK_CAMR_DATA_8814B << BIT_SHIFT_CAMR_DATA_8814B)
#define BIT_CLEAR_CAMR_DATA_8814B(x) ((x) & (~BITS_CAMR_DATA_8814B))
#define BIT_GET_CAMR_DATA_8814B(x) \
(((x) >> BIT_SHIFT_CAMR_DATA_8814B) & BIT_MASK_CAMR_DATA_8814B)
#define BIT_SET_CAMR_DATA_8814B(x, v) \
(BIT_CLEAR_CAMR_DATA_8814B(x) | BIT_CAMR_DATA_8814B(v))
/* 2 REG_CAMDBG_8814B (CAM DEBUG REGISTER) */
#define BIT_SECCAM_INFO_8814B BIT(31)
#define BIT_SEC_KEYFOUND_8814B BIT(15)
#define BIT_SHIFT_CAMDBG_SEC_TYPE_8814B 12
#define BIT_MASK_CAMDBG_SEC_TYPE_8814B 0x7
#define BIT_CAMDBG_SEC_TYPE_8814B(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE_8814B) \
<< BIT_SHIFT_CAMDBG_SEC_TYPE_8814B)
#define BITS_CAMDBG_SEC_TYPE_8814B \
(BIT_MASK_CAMDBG_SEC_TYPE_8814B << BIT_SHIFT_CAMDBG_SEC_TYPE_8814B)
#define BIT_CLEAR_CAMDBG_SEC_TYPE_8814B(x) ((x) & (~BITS_CAMDBG_SEC_TYPE_8814B))
#define BIT_GET_CAMDBG_SEC_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE_8814B) & \
BIT_MASK_CAMDBG_SEC_TYPE_8814B)
#define BIT_SET_CAMDBG_SEC_TYPE_8814B(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE_8814B(x) | BIT_CAMDBG_SEC_TYPE_8814B(v))
#define BIT_CAMDBG_EXT_SECTYPE_8814B BIT(11)
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8814B 5
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_8814B 0x1f
#define BIT_CAMDBG_MIC_KEY_IDX_8814B(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_8814B) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8814B)
#define BITS_CAMDBG_MIC_KEY_IDX_8814B \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_8814B \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8814B)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8814B(x) \
((x) & (~BITS_CAMDBG_MIC_KEY_IDX_8814B))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_8814B(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8814B) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_8814B)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_8814B(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8814B(x) | \
BIT_CAMDBG_MIC_KEY_IDX_8814B(v))
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8814B 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_8814B 0x1f
#define BIT_CAMDBG_SEC_KEY_IDX_8814B(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_8814B) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8814B)
#define BITS_CAMDBG_SEC_KEY_IDX_8814B \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_8814B \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8814B)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8814B(x) \
((x) & (~BITS_CAMDBG_SEC_KEY_IDX_8814B))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_8814B(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8814B) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_8814B)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_8814B(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8814B(x) | \
BIT_CAMDBG_SEC_KEY_IDX_8814B(v))
/* 2 REG_SECCFG_8814B (SECURITY CONFIGURATION REGISTER) */
#define BIT_DIS_GCLK_WAPI_8814B BIT(15)
#define BIT_DIS_GCLK_AES_8814B BIT(14)
#define BIT_DIS_GCLK_TKIP_8814B BIT(13)
#define BIT_AES_SEL_QC_1_8814B BIT(12)
#define BIT_AES_SEL_QC_0_8814B BIT(11)
#define BIT_CHK_BMC_8814B BIT(9)
#define BIT_CHK_KEYID_8814B BIT(8)
#define BIT_RXBCUSEDK_8814B BIT(7)
#define BIT_TXBCUSEDK_8814B BIT(6)
#define BIT_NOSKMC_8814B BIT(5)
#define BIT_SKBYA2_8814B BIT(4)
#define BIT_RXDEC_8814B BIT(3)
#define BIT_TXENC_8814B BIT(2)
#define BIT_RXUHUSEDK_8814B BIT(1)
#define BIT_TXUHUSEDK_8814B BIT(0)
/* 2 REG_RXFILTER_CATEGORY_1_8814B */
#define BIT_SHIFT_RXFILTER_CATEGORY_1_8814B 0
#define BIT_MASK_RXFILTER_CATEGORY_1_8814B 0xff
#define BIT_RXFILTER_CATEGORY_1_8814B(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_1_8814B) \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8814B)
#define BITS_RXFILTER_CATEGORY_1_8814B \
(BIT_MASK_RXFILTER_CATEGORY_1_8814B \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8814B)
#define BIT_CLEAR_RXFILTER_CATEGORY_1_8814B(x) \
((x) & (~BITS_RXFILTER_CATEGORY_1_8814B))
#define BIT_GET_RXFILTER_CATEGORY_1_8814B(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_1_8814B) & \
BIT_MASK_RXFILTER_CATEGORY_1_8814B)
#define BIT_SET_RXFILTER_CATEGORY_1_8814B(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_1_8814B(x) | \
BIT_RXFILTER_CATEGORY_1_8814B(v))
/* 2 REG_RXFILTER_ACTION_1_8814B */
#define BIT_SHIFT_RXFILTER_ACTION_1_8814B 0
#define BIT_MASK_RXFILTER_ACTION_1_8814B 0xff
#define BIT_RXFILTER_ACTION_1_8814B(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_1_8814B) \
<< BIT_SHIFT_RXFILTER_ACTION_1_8814B)
#define BITS_RXFILTER_ACTION_1_8814B \
(BIT_MASK_RXFILTER_ACTION_1_8814B << BIT_SHIFT_RXFILTER_ACTION_1_8814B)
#define BIT_CLEAR_RXFILTER_ACTION_1_8814B(x) \
((x) & (~BITS_RXFILTER_ACTION_1_8814B))
#define BIT_GET_RXFILTER_ACTION_1_8814B(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_1_8814B) & \
BIT_MASK_RXFILTER_ACTION_1_8814B)
#define BIT_SET_RXFILTER_ACTION_1_8814B(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_1_8814B(x) | BIT_RXFILTER_ACTION_1_8814B(v))
/* 2 REG_RXFILTER_CATEGORY_2_8814B */
#define BIT_SHIFT_RXFILTER_CATEGORY_2_8814B 0
#define BIT_MASK_RXFILTER_CATEGORY_2_8814B 0xff
#define BIT_RXFILTER_CATEGORY_2_8814B(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_2_8814B) \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8814B)
#define BITS_RXFILTER_CATEGORY_2_8814B \
(BIT_MASK_RXFILTER_CATEGORY_2_8814B \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8814B)
#define BIT_CLEAR_RXFILTER_CATEGORY_2_8814B(x) \
((x) & (~BITS_RXFILTER_CATEGORY_2_8814B))
#define BIT_GET_RXFILTER_CATEGORY_2_8814B(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_2_8814B) & \
BIT_MASK_RXFILTER_CATEGORY_2_8814B)
#define BIT_SET_RXFILTER_CATEGORY_2_8814B(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_2_8814B(x) | \
BIT_RXFILTER_CATEGORY_2_8814B(v))
/* 2 REG_RXFILTER_ACTION_2_8814B */
#define BIT_SHIFT_RXFILTER_ACTION_2_8814B 0
#define BIT_MASK_RXFILTER_ACTION_2_8814B 0xff
#define BIT_RXFILTER_ACTION_2_8814B(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_2_8814B) \
<< BIT_SHIFT_RXFILTER_ACTION_2_8814B)
#define BITS_RXFILTER_ACTION_2_8814B \
(BIT_MASK_RXFILTER_ACTION_2_8814B << BIT_SHIFT_RXFILTER_ACTION_2_8814B)
#define BIT_CLEAR_RXFILTER_ACTION_2_8814B(x) \
((x) & (~BITS_RXFILTER_ACTION_2_8814B))
#define BIT_GET_RXFILTER_ACTION_2_8814B(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_2_8814B) & \
BIT_MASK_RXFILTER_ACTION_2_8814B)
#define BIT_SET_RXFILTER_ACTION_2_8814B(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_2_8814B(x) | BIT_RXFILTER_ACTION_2_8814B(v))
/* 2 REG_RXFILTER_CATEGORY_3_8814B */
#define BIT_SHIFT_RXFILTER_CATEGORY_3_8814B 0
#define BIT_MASK_RXFILTER_CATEGORY_3_8814B 0xff
#define BIT_RXFILTER_CATEGORY_3_8814B(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_3_8814B) \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8814B)
#define BITS_RXFILTER_CATEGORY_3_8814B \
(BIT_MASK_RXFILTER_CATEGORY_3_8814B \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8814B)
#define BIT_CLEAR_RXFILTER_CATEGORY_3_8814B(x) \
((x) & (~BITS_RXFILTER_CATEGORY_3_8814B))
#define BIT_GET_RXFILTER_CATEGORY_3_8814B(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_3_8814B) & \
BIT_MASK_RXFILTER_CATEGORY_3_8814B)
#define BIT_SET_RXFILTER_CATEGORY_3_8814B(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_3_8814B(x) | \
BIT_RXFILTER_CATEGORY_3_8814B(v))
/* 2 REG_RXFILTER_ACTION_3_8814B */
#define BIT_SHIFT_RXFILTER_ACTION_3_8814B 0
#define BIT_MASK_RXFILTER_ACTION_3_8814B 0xff
#define BIT_RXFILTER_ACTION_3_8814B(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_3_8814B) \
<< BIT_SHIFT_RXFILTER_ACTION_3_8814B)
#define BITS_RXFILTER_ACTION_3_8814B \
(BIT_MASK_RXFILTER_ACTION_3_8814B << BIT_SHIFT_RXFILTER_ACTION_3_8814B)
#define BIT_CLEAR_RXFILTER_ACTION_3_8814B(x) \
((x) & (~BITS_RXFILTER_ACTION_3_8814B))
#define BIT_GET_RXFILTER_ACTION_3_8814B(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_3_8814B) & \
BIT_MASK_RXFILTER_ACTION_3_8814B)
#define BIT_SET_RXFILTER_ACTION_3_8814B(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_3_8814B(x) | BIT_RXFILTER_ACTION_3_8814B(v))
/* 2 REG_RXFLTMAP3_8814B (RX FILTER MAP GROUP 3) */
#define BIT_MGTFLT15EN_FW_8814B BIT(15)
#define BIT_MGTFLT14EN_FW_8814B BIT(14)
#define BIT_MGTFLT13EN_FW_8814B BIT(13)
#define BIT_MGTFLT12EN_FW_8814B BIT(12)
#define BIT_MGTFLT11EN_FW_8814B BIT(11)
#define BIT_MGTFLT10EN_FW_8814B BIT(10)
#define BIT_MGTFLT9EN_FW_8814B BIT(9)
#define BIT_MGTFLT8EN_FW_8814B BIT(8)
#define BIT_MGTFLT7EN_FW_8814B BIT(7)
#define BIT_MGTFLT6EN_FW_8814B BIT(6)
#define BIT_MGTFLT5EN_FW_8814B BIT(5)
#define BIT_MGTFLT4EN_FW_8814B BIT(4)
#define BIT_MGTFLT3EN_FW_8814B BIT(3)
#define BIT_MGTFLT2EN_FW_8814B BIT(2)
#define BIT_MGTFLT1EN_FW_8814B BIT(1)
#define BIT_MGTFLT0EN_FW_8814B BIT(0)
/* 2 REG_RXFLTMAP4_8814B (RX FILTER MAP GROUP 4) */
#define BIT_CTRLFLT15EN_FW_8814B BIT(15)
#define BIT_CTRLFLT14EN_FW_8814B BIT(14)
#define BIT_CTRLFLT13EN_FW_8814B BIT(13)
#define BIT_CTRLFLT12EN_FW_8814B BIT(12)
#define BIT_CTRLFLT11EN_FW_8814B BIT(11)
#define BIT_CTRLFLT10EN_FW_8814B BIT(10)
#define BIT_CTRLFLT9EN_FW_8814B BIT(9)
#define BIT_CTRLFLT8EN_FW_8814B BIT(8)
#define BIT_CTRLFLT7EN_FW_8814B BIT(7)
#define BIT_CTRLFLT6EN_FW_8814B BIT(6)
#define BIT_CTRLFLT5EN_FW_8814B BIT(5)
#define BIT_CTRLFLT4EN_FW_8814B BIT(4)
#define BIT_CTRLFLT3EN_FW_8814B BIT(3)
#define BIT_CTRLFLT2EN_FW_8814B BIT(2)
#define BIT_CTRLFLT1EN_FW_8814B BIT(1)
#define BIT_CTRLFLT0EN_FW_8814B BIT(0)
/* 2 REG_RXFLTMAP5_8814B (RX FILTER MAP GROUP 5) */
#define BIT_DATAFLT15EN_FW_8814B BIT(15)
#define BIT_DATAFLT14EN_FW_8814B BIT(14)
#define BIT_DATAFLT13EN_FW_8814B BIT(13)
#define BIT_DATAFLT12EN_FW_8814B BIT(12)
#define BIT_DATAFLT11EN_FW_8814B BIT(11)
#define BIT_DATAFLT10EN_FW_8814B BIT(10)
#define BIT_DATAFLT9EN_FW_8814B BIT(9)
#define BIT_DATAFLT8EN_FW_8814B BIT(8)
#define BIT_DATAFLT7EN_FW_8814B BIT(7)
#define BIT_DATAFLT6EN_FW_8814B BIT(6)
#define BIT_DATAFLT5EN_FW_8814B BIT(5)
#define BIT_DATAFLT4EN_FW_8814B BIT(4)
#define BIT_DATAFLT3EN_FW_8814B BIT(3)
#define BIT_DATAFLT2EN_FW_8814B BIT(2)
#define BIT_DATAFLT1EN_FW_8814B BIT(1)
#define BIT_DATAFLT0EN_FW_8814B BIT(0)
/* 2 REG_RXFLTMAP6_8814B (RX FILTER MAP GROUP 6) */
#define BIT_ACTIONFLT15EN_FW_8814B BIT(15)
#define BIT_ACTIONFLT14EN_FW_8814B BIT(14)
#define BIT_ACTIONFLT13EN_FW_8814B BIT(13)
#define BIT_ACTIONFLT12EN_FW_8814B BIT(12)
#define BIT_ACTIONFLT11EN_FW_8814B BIT(11)
#define BIT_ACTIONFLT10EN_FW_8814B BIT(10)
#define BIT_ACTIONFLT9EN_FW_8814B BIT(9)
#define BIT_ACTIONFLT8EN_FW_8814B BIT(8)
#define BIT_ACTIONFLT7EN_FW_8814B BIT(7)
#define BIT_ACTIONFLT6EN_FW_8814B BIT(6)
#define BIT_ACTIONFLT5EN_FW_8814B BIT(5)
#define BIT_ACTIONFLT4EN_FW_8814B BIT(4)
#define BIT_ACTIONFLT3EN_FW_8814B BIT(3)
#define BIT_ACTIONFLT2EN_FW_8814B BIT(2)
#define BIT_ACTIONFLT1EN_FW_8814B BIT(1)
#define BIT_ACTIONFLT0EN_FW_8814B BIT(0)
/* 2 REG_WOW_CTRL_8814B (WAKE ON WLAN CONTROL REGISTER) */
#define BIT_SHIFT_PSF_BSSIDSEL_B2B1_8814B 6
#define BIT_MASK_PSF_BSSIDSEL_B2B1_8814B 0x3
#define BIT_PSF_BSSIDSEL_B2B1_8814B(x) \
(((x) & BIT_MASK_PSF_BSSIDSEL_B2B1_8814B) \
<< BIT_SHIFT_PSF_BSSIDSEL_B2B1_8814B)
#define BITS_PSF_BSSIDSEL_B2B1_8814B \
(BIT_MASK_PSF_BSSIDSEL_B2B1_8814B << BIT_SHIFT_PSF_BSSIDSEL_B2B1_8814B)
#define BIT_CLEAR_PSF_BSSIDSEL_B2B1_8814B(x) \
((x) & (~BITS_PSF_BSSIDSEL_B2B1_8814B))
#define BIT_GET_PSF_BSSIDSEL_B2B1_8814B(x) \
(((x) >> BIT_SHIFT_PSF_BSSIDSEL_B2B1_8814B) & \
BIT_MASK_PSF_BSSIDSEL_B2B1_8814B)
#define BIT_SET_PSF_BSSIDSEL_B2B1_8814B(x, v) \
(BIT_CLEAR_PSF_BSSIDSEL_B2B1_8814B(x) | BIT_PSF_BSSIDSEL_B2B1_8814B(v))
#define BIT_WOWHCI_8814B BIT(5)
#define BIT_PSF_BSSIDSEL_B0_8814B BIT(4)
#define BIT_UWF_8814B BIT(3)
#define BIT_MAGIC_8814B BIT(2)
#define BIT_WOWEN_8814B BIT(1)
#define BIT_FORCE_WAKEUP_8814B BIT(0)
/* 2 REG_NAN_RX_TSF_FILTER_8814B(NAN_RX_TSF_ADDRESS_FILTER) */
#define BIT_CHK_TSF_TA_8814B BIT(2)
#define BIT_CHK_TSF_CBSSID_8814B BIT(1)
#define BIT_CHK_TSF_EN_8814B BIT(0)
/* 2 REG_PS_RX_INFO_8814B (POWER SAVE RX INFORMATION REGISTER) */
#define BIT_SHIFT_PORTSEL__PS_RX_INFO_8814B 5
#define BIT_MASK_PORTSEL__PS_RX_INFO_8814B 0x7
#define BIT_PORTSEL__PS_RX_INFO_8814B(x) \
(((x) & BIT_MASK_PORTSEL__PS_RX_INFO_8814B) \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8814B)
#define BITS_PORTSEL__PS_RX_INFO_8814B \
(BIT_MASK_PORTSEL__PS_RX_INFO_8814B \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8814B)
#define BIT_CLEAR_PORTSEL__PS_RX_INFO_8814B(x) \
((x) & (~BITS_PORTSEL__PS_RX_INFO_8814B))
#define BIT_GET_PORTSEL__PS_RX_INFO_8814B(x) \
(((x) >> BIT_SHIFT_PORTSEL__PS_RX_INFO_8814B) & \
BIT_MASK_PORTSEL__PS_RX_INFO_8814B)
#define BIT_SET_PORTSEL__PS_RX_INFO_8814B(x, v) \
(BIT_CLEAR_PORTSEL__PS_RX_INFO_8814B(x) | \
BIT_PORTSEL__PS_RX_INFO_8814B(v))
#define BIT_RXCTRLIN0_8814B BIT(4)
#define BIT_RXMGTIN0_8814B BIT(3)
#define BIT_RXDATAIN2_8814B BIT(2)
#define BIT_RXDATAIN1_8814B BIT(1)
#define BIT_RXDATAIN0_8814B BIT(0)
/* 2 REG_WMMPS_UAPSD_TID_8814B (WMM POWER SAVE UAPSD TID REGISTER) */
#define BIT_WMMPS_UAPSD_TID7_8814B BIT(7)
#define BIT_WMMPS_UAPSD_TID6_8814B BIT(6)
#define BIT_WMMPS_UAPSD_TID5_8814B BIT(5)
#define BIT_WMMPS_UAPSD_TID4_8814B BIT(4)
#define BIT_WMMPS_UAPSD_TID3_8814B BIT(3)
#define BIT_WMMPS_UAPSD_TID2_8814B BIT(2)
#define BIT_WMMPS_UAPSD_TID1_8814B BIT(1)
#define BIT_WMMPS_UAPSD_TID0_8814B BIT(0)
/* 2 REG_LPNAV_CTRL_8814B (LOW POWER NAV CONTROL REGISTER) */
/* 2 REG_WKFMCAM_CMD_8814B (WAKEUP FRAME CAM COMMAND REGISTER) */
#define BIT_WKFCAM_POLLING_V1_8814B BIT(31)
#define BIT_WKFCAM_CLR_V1_8814B BIT(30)
#define BIT_WKFCAM_WE_8814B BIT(16)
#define BIT_SHIFT_WKFCAM_ADDR_V2_8814B 8
#define BIT_MASK_WKFCAM_ADDR_V2_8814B 0xff
#define BIT_WKFCAM_ADDR_V2_8814B(x) \
(((x) & BIT_MASK_WKFCAM_ADDR_V2_8814B) \
<< BIT_SHIFT_WKFCAM_ADDR_V2_8814B)
#define BITS_WKFCAM_ADDR_V2_8814B \
(BIT_MASK_WKFCAM_ADDR_V2_8814B << BIT_SHIFT_WKFCAM_ADDR_V2_8814B)
#define BIT_CLEAR_WKFCAM_ADDR_V2_8814B(x) ((x) & (~BITS_WKFCAM_ADDR_V2_8814B))
#define BIT_GET_WKFCAM_ADDR_V2_8814B(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR_V2_8814B) & \
BIT_MASK_WKFCAM_ADDR_V2_8814B)
#define BIT_SET_WKFCAM_ADDR_V2_8814B(x, v) \
(BIT_CLEAR_WKFCAM_ADDR_V2_8814B(x) | BIT_WKFCAM_ADDR_V2_8814B(v))
#define BIT_SHIFT_WKFCAM_CAM_NUM_V1_8814B 0
#define BIT_MASK_WKFCAM_CAM_NUM_V1_8814B 0xff
#define BIT_WKFCAM_CAM_NUM_V1_8814B(x) \
(((x) & BIT_MASK_WKFCAM_CAM_NUM_V1_8814B) \
<< BIT_SHIFT_WKFCAM_CAM_NUM_V1_8814B)
#define BITS_WKFCAM_CAM_NUM_V1_8814B \
(BIT_MASK_WKFCAM_CAM_NUM_V1_8814B << BIT_SHIFT_WKFCAM_CAM_NUM_V1_8814B)
#define BIT_CLEAR_WKFCAM_CAM_NUM_V1_8814B(x) \
((x) & (~BITS_WKFCAM_CAM_NUM_V1_8814B))
#define BIT_GET_WKFCAM_CAM_NUM_V1_8814B(x) \
(((x) >> BIT_SHIFT_WKFCAM_CAM_NUM_V1_8814B) & \
BIT_MASK_WKFCAM_CAM_NUM_V1_8814B)
#define BIT_SET_WKFCAM_CAM_NUM_V1_8814B(x, v) \
(BIT_CLEAR_WKFCAM_CAM_NUM_V1_8814B(x) | BIT_WKFCAM_CAM_NUM_V1_8814B(v))
/* 2 REG_WKFMCAM_RWD_8814B (WAKEUP FRAME READ/WRITE DATA) */
#define BIT_SHIFT_WKFMCAM_RWD_8814B 0
#define BIT_MASK_WKFMCAM_RWD_8814B 0xffffffffL
#define BIT_WKFMCAM_RWD_8814B(x) \
(((x) & BIT_MASK_WKFMCAM_RWD_8814B) << BIT_SHIFT_WKFMCAM_RWD_8814B)
#define BITS_WKFMCAM_RWD_8814B \
(BIT_MASK_WKFMCAM_RWD_8814B << BIT_SHIFT_WKFMCAM_RWD_8814B)
#define BIT_CLEAR_WKFMCAM_RWD_8814B(x) ((x) & (~BITS_WKFMCAM_RWD_8814B))
#define BIT_GET_WKFMCAM_RWD_8814B(x) \
(((x) >> BIT_SHIFT_WKFMCAM_RWD_8814B) & BIT_MASK_WKFMCAM_RWD_8814B)
#define BIT_SET_WKFMCAM_RWD_8814B(x, v) \
(BIT_CLEAR_WKFMCAM_RWD_8814B(x) | BIT_WKFMCAM_RWD_8814B(v))
/* 2 REG_RXFLTMAP0_8814B (RX FILTER MAP GROUP 0) */
#define BIT_MGTFLT15EN_8814B BIT(15)
#define BIT_MGTFLT14EN_8814B BIT(14)
#define BIT_MGTFLT13EN_8814B BIT(13)
#define BIT_MGTFLT12EN_8814B BIT(12)
#define BIT_MGTFLT11EN_8814B BIT(11)
#define BIT_MGTFLT10EN_8814B BIT(10)
#define BIT_MGTFLT9EN_8814B BIT(9)
#define BIT_MGTFLT8EN_8814B BIT(8)
#define BIT_MGTFLT7EN_8814B BIT(7)
#define BIT_MGTFLT6EN_8814B BIT(6)
#define BIT_MGTFLT5EN_8814B BIT(5)
#define BIT_MGTFLT4EN_8814B BIT(4)
#define BIT_MGTFLT3EN_8814B BIT(3)
#define BIT_MGTFLT2EN_8814B BIT(2)
#define BIT_MGTFLT1EN_8814B BIT(1)
#define BIT_MGTFLT0EN_8814B BIT(0)
/* 2 REG_RXFLTMAP1_8814B (RX FILTER MAP GROUP 1) */
#define BIT_CTRLFLT15EN_8814B BIT(15)
#define BIT_CTRLFLT14EN_8814B BIT(14)
#define BIT_CTRLFLT13EN_8814B BIT(13)
#define BIT_CTRLFLT12EN_8814B BIT(12)
#define BIT_CTRLFLT11EN_8814B BIT(11)
#define BIT_CTRLFLT10EN_8814B BIT(10)
#define BIT_CTRLFLT9EN_8814B BIT(9)
#define BIT_CTRLFLT8EN_8814B BIT(8)
#define BIT_CTRLFLT7EN_8814B BIT(7)
#define BIT_CTRLFLT6EN_8814B BIT(6)
#define BIT_CTRLFLT5EN_8814B BIT(5)
#define BIT_CTRLFLT4EN_8814B BIT(4)
#define BIT_CTRLFLT3EN_8814B BIT(3)
#define BIT_CTRLFLT2EN_8814B BIT(2)
#define BIT_CTRLFLT1EN_8814B BIT(1)
#define BIT_CTRLFLT0EN_8814B BIT(0)
/* 2 REG_RXFLTMAP2_8814B (RX FILTER MAP GROUP 2) */
#define BIT_DATAFLT15EN_8814B BIT(15)
#define BIT_DATAFLT14EN_8814B BIT(14)
#define BIT_DATAFLT13EN_8814B BIT(13)
#define BIT_DATAFLT12EN_8814B BIT(12)
#define BIT_DATAFLT11EN_8814B BIT(11)
#define BIT_DATAFLT10EN_8814B BIT(10)
#define BIT_DATAFLT9EN_8814B BIT(9)
#define BIT_DATAFLT8EN_8814B BIT(8)
#define BIT_DATAFLT7EN_8814B BIT(7)
#define BIT_DATAFLT6EN_8814B BIT(6)
#define BIT_DATAFLT5EN_8814B BIT(5)
#define BIT_DATAFLT4EN_8814B BIT(4)
#define BIT_DATAFLT3EN_8814B BIT(3)
#define BIT_DATAFLT2EN_8814B BIT(2)
#define BIT_DATAFLT1EN_8814B BIT(1)
#define BIT_DATAFLT0EN_8814B BIT(0)
/* 2 REG_RSVD_8814B */
/* 2 REG_BCN_PSR_RPT_8814B (BEACON PARSER REPORT REGISTER) */
#define BIT_SHIFT_DTIM_CNT_8814B 24
#define BIT_MASK_DTIM_CNT_8814B 0xff
#define BIT_DTIM_CNT_8814B(x) \
(((x) & BIT_MASK_DTIM_CNT_8814B) << BIT_SHIFT_DTIM_CNT_8814B)
#define BITS_DTIM_CNT_8814B \
(BIT_MASK_DTIM_CNT_8814B << BIT_SHIFT_DTIM_CNT_8814B)
#define BIT_CLEAR_DTIM_CNT_8814B(x) ((x) & (~BITS_DTIM_CNT_8814B))
#define BIT_GET_DTIM_CNT_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT_8814B) & BIT_MASK_DTIM_CNT_8814B)
#define BIT_SET_DTIM_CNT_8814B(x, v) \
(BIT_CLEAR_DTIM_CNT_8814B(x) | BIT_DTIM_CNT_8814B(v))
#define BIT_SHIFT_DTIM_PERIOD_8814B 16
#define BIT_MASK_DTIM_PERIOD_8814B 0xff
#define BIT_DTIM_PERIOD_8814B(x) \
(((x) & BIT_MASK_DTIM_PERIOD_8814B) << BIT_SHIFT_DTIM_PERIOD_8814B)
#define BITS_DTIM_PERIOD_8814B \
(BIT_MASK_DTIM_PERIOD_8814B << BIT_SHIFT_DTIM_PERIOD_8814B)
#define BIT_CLEAR_DTIM_PERIOD_8814B(x) ((x) & (~BITS_DTIM_PERIOD_8814B))
#define BIT_GET_DTIM_PERIOD_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD_8814B) & BIT_MASK_DTIM_PERIOD_8814B)
#define BIT_SET_DTIM_PERIOD_8814B(x, v) \
(BIT_CLEAR_DTIM_PERIOD_8814B(x) | BIT_DTIM_PERIOD_8814B(v))
#define BIT_DTIM_8814B BIT(15)
#define BIT_TIM_8814B BIT(14)
#define BIT_RPT_VALID_8814B BIT(13)
#define BIT_SHIFT_PS_AID_0_8814B 0
#define BIT_MASK_PS_AID_0_8814B 0x7ff
#define BIT_PS_AID_0_8814B(x) \
(((x) & BIT_MASK_PS_AID_0_8814B) << BIT_SHIFT_PS_AID_0_8814B)
#define BITS_PS_AID_0_8814B \
(BIT_MASK_PS_AID_0_8814B << BIT_SHIFT_PS_AID_0_8814B)
#define BIT_CLEAR_PS_AID_0_8814B(x) ((x) & (~BITS_PS_AID_0_8814B))
#define BIT_GET_PS_AID_0_8814B(x) \
(((x) >> BIT_SHIFT_PS_AID_0_8814B) & BIT_MASK_PS_AID_0_8814B)
#define BIT_SET_PS_AID_0_8814B(x, v) \
(BIT_CLEAR_PS_AID_0_8814B(x) | BIT_PS_AID_0_8814B(v))
/* 2 REG_FLC_RPC_8814B (FW LPS CONDITION -- RX PKT COUNTER) */
#define BIT_SHIFT_FLC_RPC_8814B 0
#define BIT_MASK_FLC_RPC_8814B 0xff
#define BIT_FLC_RPC_8814B(x) \
(((x) & BIT_MASK_FLC_RPC_8814B) << BIT_SHIFT_FLC_RPC_8814B)
#define BITS_FLC_RPC_8814B (BIT_MASK_FLC_RPC_8814B << BIT_SHIFT_FLC_RPC_8814B)
#define BIT_CLEAR_FLC_RPC_8814B(x) ((x) & (~BITS_FLC_RPC_8814B))
#define BIT_GET_FLC_RPC_8814B(x) \
(((x) >> BIT_SHIFT_FLC_RPC_8814B) & BIT_MASK_FLC_RPC_8814B)
#define BIT_SET_FLC_RPC_8814B(x, v) \
(BIT_CLEAR_FLC_RPC_8814B(x) | BIT_FLC_RPC_8814B(v))
/* 2 REG_FLC_RPCT_8814B (FLC_RPC THRESHOLD) */
#define BIT_SHIFT_FLC_RPCT_8814B 0
#define BIT_MASK_FLC_RPCT_8814B 0xff
#define BIT_FLC_RPCT_8814B(x) \
(((x) & BIT_MASK_FLC_RPCT_8814B) << BIT_SHIFT_FLC_RPCT_8814B)
#define BITS_FLC_RPCT_8814B \
(BIT_MASK_FLC_RPCT_8814B << BIT_SHIFT_FLC_RPCT_8814B)
#define BIT_CLEAR_FLC_RPCT_8814B(x) ((x) & (~BITS_FLC_RPCT_8814B))
#define BIT_GET_FLC_RPCT_8814B(x) \
(((x) >> BIT_SHIFT_FLC_RPCT_8814B) & BIT_MASK_FLC_RPCT_8814B)
#define BIT_SET_FLC_RPCT_8814B(x, v) \
(BIT_CLEAR_FLC_RPCT_8814B(x) | BIT_FLC_RPCT_8814B(v))
/* 2 REG_FLC_PTS_8814B (PKT TYPE SELECTION OF FLC_RPC T) */
#define BIT_CMF_8814B BIT(2)
#define BIT_CCF_8814B BIT(1)
#define BIT_CDF_8814B BIT(0)
/* 2 REG_FLC_TRPC_8814B (TIMER OF FLC_RPC) */
#define BIT_FLC_RPCT_V1_8814B BIT(7)
#define BIT_MODE_8814B BIT(6)
#define BIT_SHIFT_TRPCD_8814B 0
#define BIT_MASK_TRPCD_8814B 0x3f
#define BIT_TRPCD_8814B(x) \
(((x) & BIT_MASK_TRPCD_8814B) << BIT_SHIFT_TRPCD_8814B)
#define BITS_TRPCD_8814B (BIT_MASK_TRPCD_8814B << BIT_SHIFT_TRPCD_8814B)
#define BIT_CLEAR_TRPCD_8814B(x) ((x) & (~BITS_TRPCD_8814B))
#define BIT_GET_TRPCD_8814B(x) \
(((x) >> BIT_SHIFT_TRPCD_8814B) & BIT_MASK_TRPCD_8814B)
#define BIT_SET_TRPCD_8814B(x, v) \
(BIT_CLEAR_TRPCD_8814B(x) | BIT_TRPCD_8814B(v))
/* 2 REG_RXPKTMON_CTRL_8814B */
#define BIT_SHIFT_RXBKQPKT_SEQ_8814B 20
#define BIT_MASK_RXBKQPKT_SEQ_8814B 0xf
#define BIT_RXBKQPKT_SEQ_8814B(x) \
(((x) & BIT_MASK_RXBKQPKT_SEQ_8814B) << BIT_SHIFT_RXBKQPKT_SEQ_8814B)
#define BITS_RXBKQPKT_SEQ_8814B \
(BIT_MASK_RXBKQPKT_SEQ_8814B << BIT_SHIFT_RXBKQPKT_SEQ_8814B)
#define BIT_CLEAR_RXBKQPKT_SEQ_8814B(x) ((x) & (~BITS_RXBKQPKT_SEQ_8814B))
#define BIT_GET_RXBKQPKT_SEQ_8814B(x) \
(((x) >> BIT_SHIFT_RXBKQPKT_SEQ_8814B) & BIT_MASK_RXBKQPKT_SEQ_8814B)
#define BIT_SET_RXBKQPKT_SEQ_8814B(x, v) \
(BIT_CLEAR_RXBKQPKT_SEQ_8814B(x) | BIT_RXBKQPKT_SEQ_8814B(v))
#define BIT_SHIFT_RXBEQPKT_SEQ_8814B 16
#define BIT_MASK_RXBEQPKT_SEQ_8814B 0xf
#define BIT_RXBEQPKT_SEQ_8814B(x) \
(((x) & BIT_MASK_RXBEQPKT_SEQ_8814B) << BIT_SHIFT_RXBEQPKT_SEQ_8814B)
#define BITS_RXBEQPKT_SEQ_8814B \
(BIT_MASK_RXBEQPKT_SEQ_8814B << BIT_SHIFT_RXBEQPKT_SEQ_8814B)
#define BIT_CLEAR_RXBEQPKT_SEQ_8814B(x) ((x) & (~BITS_RXBEQPKT_SEQ_8814B))
#define BIT_GET_RXBEQPKT_SEQ_8814B(x) \
(((x) >> BIT_SHIFT_RXBEQPKT_SEQ_8814B) & BIT_MASK_RXBEQPKT_SEQ_8814B)
#define BIT_SET_RXBEQPKT_SEQ_8814B(x, v) \
(BIT_CLEAR_RXBEQPKT_SEQ_8814B(x) | BIT_RXBEQPKT_SEQ_8814B(v))
#define BIT_SHIFT_RXVIQPKT_SEQ_8814B 12
#define BIT_MASK_RXVIQPKT_SEQ_8814B 0xf
#define BIT_RXVIQPKT_SEQ_8814B(x) \
(((x) & BIT_MASK_RXVIQPKT_SEQ_8814B) << BIT_SHIFT_RXVIQPKT_SEQ_8814B)
#define BITS_RXVIQPKT_SEQ_8814B \
(BIT_MASK_RXVIQPKT_SEQ_8814B << BIT_SHIFT_RXVIQPKT_SEQ_8814B)
#define BIT_CLEAR_RXVIQPKT_SEQ_8814B(x) ((x) & (~BITS_RXVIQPKT_SEQ_8814B))
#define BIT_GET_RXVIQPKT_SEQ_8814B(x) \
(((x) >> BIT_SHIFT_RXVIQPKT_SEQ_8814B) & BIT_MASK_RXVIQPKT_SEQ_8814B)
#define BIT_SET_RXVIQPKT_SEQ_8814B(x, v) \
(BIT_CLEAR_RXVIQPKT_SEQ_8814B(x) | BIT_RXVIQPKT_SEQ_8814B(v))
#define BIT_SHIFT_RXVOQPKT_SEQ_8814B 8
#define BIT_MASK_RXVOQPKT_SEQ_8814B 0xf
#define BIT_RXVOQPKT_SEQ_8814B(x) \
(((x) & BIT_MASK_RXVOQPKT_SEQ_8814B) << BIT_SHIFT_RXVOQPKT_SEQ_8814B)
#define BITS_RXVOQPKT_SEQ_8814B \
(BIT_MASK_RXVOQPKT_SEQ_8814B << BIT_SHIFT_RXVOQPKT_SEQ_8814B)
#define BIT_CLEAR_RXVOQPKT_SEQ_8814B(x) ((x) & (~BITS_RXVOQPKT_SEQ_8814B))
#define BIT_GET_RXVOQPKT_SEQ_8814B(x) \
(((x) >> BIT_SHIFT_RXVOQPKT_SEQ_8814B) & BIT_MASK_RXVOQPKT_SEQ_8814B)
#define BIT_SET_RXVOQPKT_SEQ_8814B(x, v) \
(BIT_CLEAR_RXVOQPKT_SEQ_8814B(x) | BIT_RXVOQPKT_SEQ_8814B(v))
#define BIT_RXBKQPKT_ERR_8814B BIT(7)
#define BIT_RXBEQPKT_ERR_8814B BIT(6)
#define BIT_RXVIQPKT_ERR_8814B BIT(5)
#define BIT_RXVOQPKT_ERR_8814B BIT(4)
#define BIT_RXDMA_MON_EN_8814B BIT(2)
#define BIT_RXPKT_MON_RST_8814B BIT(1)
#define BIT_RXPKT_MON_EN_8814B BIT(0)
/* 2 REG_STATE_MON_8814B */
#define BIT_SHIFT_STATE_SEL_8814B 24
#define BIT_MASK_STATE_SEL_8814B 0x1f
#define BIT_STATE_SEL_8814B(x) \
(((x) & BIT_MASK_STATE_SEL_8814B) << BIT_SHIFT_STATE_SEL_8814B)
#define BITS_STATE_SEL_8814B \
(BIT_MASK_STATE_SEL_8814B << BIT_SHIFT_STATE_SEL_8814B)
#define BIT_CLEAR_STATE_SEL_8814B(x) ((x) & (~BITS_STATE_SEL_8814B))
#define BIT_GET_STATE_SEL_8814B(x) \
(((x) >> BIT_SHIFT_STATE_SEL_8814B) & BIT_MASK_STATE_SEL_8814B)
#define BIT_SET_STATE_SEL_8814B(x, v) \
(BIT_CLEAR_STATE_SEL_8814B(x) | BIT_STATE_SEL_8814B(v))
#define BIT_SHIFT_STATE_INFO_8814B 8
#define BIT_MASK_STATE_INFO_8814B 0xff
#define BIT_STATE_INFO_8814B(x) \
(((x) & BIT_MASK_STATE_INFO_8814B) << BIT_SHIFT_STATE_INFO_8814B)
#define BITS_STATE_INFO_8814B \
(BIT_MASK_STATE_INFO_8814B << BIT_SHIFT_STATE_INFO_8814B)
#define BIT_CLEAR_STATE_INFO_8814B(x) ((x) & (~BITS_STATE_INFO_8814B))
#define BIT_GET_STATE_INFO_8814B(x) \
(((x) >> BIT_SHIFT_STATE_INFO_8814B) & BIT_MASK_STATE_INFO_8814B)
#define BIT_SET_STATE_INFO_8814B(x, v) \
(BIT_CLEAR_STATE_INFO_8814B(x) | BIT_STATE_INFO_8814B(v))
#define BIT_UPD_NXT_STATE_8814B BIT(7)
#define BIT_SHIFT_CUR_STATE_8814B 0
#define BIT_MASK_CUR_STATE_8814B 0x7f
#define BIT_CUR_STATE_8814B(x) \
(((x) & BIT_MASK_CUR_STATE_8814B) << BIT_SHIFT_CUR_STATE_8814B)
#define BITS_CUR_STATE_8814B \
(BIT_MASK_CUR_STATE_8814B << BIT_SHIFT_CUR_STATE_8814B)
#define BIT_CLEAR_CUR_STATE_8814B(x) ((x) & (~BITS_CUR_STATE_8814B))
#define BIT_GET_CUR_STATE_8814B(x) \
(((x) >> BIT_SHIFT_CUR_STATE_8814B) & BIT_MASK_CUR_STATE_8814B)
#define BIT_SET_CUR_STATE_8814B(x, v) \
(BIT_CLEAR_CUR_STATE_8814B(x) | BIT_CUR_STATE_8814B(v))
/* 2 REG_ERROR_MON_8814B */
#define BIT_CSIRPT_LEN_BB_MORE_THAN_MAC_8814B BIT(23)
#define BIT_CSI_CHKSUM_ERROR_8814B BIT(22)
#define BIT_MACRX_ERR_5_8814B BIT(21)
#define BIT_MACRX_ERR_4_8814B BIT(20)
#define BIT_MACRX_ERR_3_8814B BIT(19)
#define BIT_MACRX_ERR_2_8814B BIT(18)
#define BIT_MACRX_ERR_1_8814B BIT(17)
#define BIT_MACRX_ERR_0_8814B BIT(16)
#define BIT_WMAC_PRETX_ERRHDL_EN_8814B BIT(15)
#define BIT_MACTX_ERR_5_8814B BIT(5)
#define BIT_MACTX_ERR_4_8814B BIT(4)
#define BIT_MACTX_ERR_3_8814B BIT(3)
#define BIT_MACTX_ERR_2_8814B BIT(2)
#define BIT_MACTX_ERR_1_8814B BIT(1)
#define BIT_MACTX_ERR_0_8814B BIT(0)
/* 2 REG_SEARCH_MACID_8814B */
#define BIT_EN_TXRPTBUF_CLK_8814B BIT(31)
#define BIT_WMAC_SRCH_FIFOFULL_8814B BIT(15)
#define BIT_DIS_INFOSRCH_8814B BIT(14)
#define BIT_DISABLE_B0_8814B BIT(13)
#define BIT_SHIFT_INFO_ADDR_OFFSET_8814B 0
#define BIT_MASK_INFO_ADDR_OFFSET_8814B 0x1fff
#define BIT_INFO_ADDR_OFFSET_8814B(x) \
(((x) & BIT_MASK_INFO_ADDR_OFFSET_8814B) \
<< BIT_SHIFT_INFO_ADDR_OFFSET_8814B)
#define BITS_INFO_ADDR_OFFSET_8814B \
(BIT_MASK_INFO_ADDR_OFFSET_8814B << BIT_SHIFT_INFO_ADDR_OFFSET_8814B)
#define BIT_CLEAR_INFO_ADDR_OFFSET_8814B(x) \
((x) & (~BITS_INFO_ADDR_OFFSET_8814B))
#define BIT_GET_INFO_ADDR_OFFSET_8814B(x) \
(((x) >> BIT_SHIFT_INFO_ADDR_OFFSET_8814B) & \
BIT_MASK_INFO_ADDR_OFFSET_8814B)
#define BIT_SET_INFO_ADDR_OFFSET_8814B(x, v) \
(BIT_CLEAR_INFO_ADDR_OFFSET_8814B(x) | BIT_INFO_ADDR_OFFSET_8814B(v))
/* 2 REG_BT_COEX_TABLE_8814B (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_COEX_TABLE_1_8814B 0
#define BIT_MASK_COEX_TABLE_1_8814B 0xffffffffL
#define BIT_COEX_TABLE_1_8814B(x) \
(((x) & BIT_MASK_COEX_TABLE_1_8814B) << BIT_SHIFT_COEX_TABLE_1_8814B)
#define BITS_COEX_TABLE_1_8814B \
(BIT_MASK_COEX_TABLE_1_8814B << BIT_SHIFT_COEX_TABLE_1_8814B)
#define BIT_CLEAR_COEX_TABLE_1_8814B(x) ((x) & (~BITS_COEX_TABLE_1_8814B))
#define BIT_GET_COEX_TABLE_1_8814B(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_1_8814B) & BIT_MASK_COEX_TABLE_1_8814B)
#define BIT_SET_COEX_TABLE_1_8814B(x, v) \
(BIT_CLEAR_COEX_TABLE_1_8814B(x) | BIT_COEX_TABLE_1_8814B(v))
/* 2 REG_BT_COEX_TABLE2_8814B (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_COEX_TABLE_2_8814B 0
#define BIT_MASK_COEX_TABLE_2_8814B 0xffffffffL
#define BIT_COEX_TABLE_2_8814B(x) \
(((x) & BIT_MASK_COEX_TABLE_2_8814B) << BIT_SHIFT_COEX_TABLE_2_8814B)
#define BITS_COEX_TABLE_2_8814B \
(BIT_MASK_COEX_TABLE_2_8814B << BIT_SHIFT_COEX_TABLE_2_8814B)
#define BIT_CLEAR_COEX_TABLE_2_8814B(x) ((x) & (~BITS_COEX_TABLE_2_8814B))
#define BIT_GET_COEX_TABLE_2_8814B(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_2_8814B) & BIT_MASK_COEX_TABLE_2_8814B)
#define BIT_SET_COEX_TABLE_2_8814B(x, v) \
(BIT_CLEAR_COEX_TABLE_2_8814B(x) | BIT_COEX_TABLE_2_8814B(v))
/* 2 REG_BT_COEX_BREAK_TABLE_8814B (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_BREAK_TABLE_2_8814B 16
#define BIT_MASK_BREAK_TABLE_2_8814B 0xffff
#define BIT_BREAK_TABLE_2_8814B(x) \
(((x) & BIT_MASK_BREAK_TABLE_2_8814B) << BIT_SHIFT_BREAK_TABLE_2_8814B)
#define BITS_BREAK_TABLE_2_8814B \
(BIT_MASK_BREAK_TABLE_2_8814B << BIT_SHIFT_BREAK_TABLE_2_8814B)
#define BIT_CLEAR_BREAK_TABLE_2_8814B(x) ((x) & (~BITS_BREAK_TABLE_2_8814B))
#define BIT_GET_BREAK_TABLE_2_8814B(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_2_8814B) & BIT_MASK_BREAK_TABLE_2_8814B)
#define BIT_SET_BREAK_TABLE_2_8814B(x, v) \
(BIT_CLEAR_BREAK_TABLE_2_8814B(x) | BIT_BREAK_TABLE_2_8814B(v))
#define BIT_SHIFT_BREAK_TABLE_1_8814B 0
#define BIT_MASK_BREAK_TABLE_1_8814B 0xffff
#define BIT_BREAK_TABLE_1_8814B(x) \
(((x) & BIT_MASK_BREAK_TABLE_1_8814B) << BIT_SHIFT_BREAK_TABLE_1_8814B)
#define BITS_BREAK_TABLE_1_8814B \
(BIT_MASK_BREAK_TABLE_1_8814B << BIT_SHIFT_BREAK_TABLE_1_8814B)
#define BIT_CLEAR_BREAK_TABLE_1_8814B(x) ((x) & (~BITS_BREAK_TABLE_1_8814B))
#define BIT_GET_BREAK_TABLE_1_8814B(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_1_8814B) & BIT_MASK_BREAK_TABLE_1_8814B)
#define BIT_SET_BREAK_TABLE_1_8814B(x, v) \
(BIT_CLEAR_BREAK_TABLE_1_8814B(x) | BIT_BREAK_TABLE_1_8814B(v))
/* 2 REG_BT_COEX_TABLE_H_8814B (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_PRI_MASK_RX_RESP_V1_8814B BIT(30)
#define BIT_PRI_MASK_RXOFDM_V1_8814B BIT(29)
#define BIT_PRI_MASK_RXCCK_V1_8814B BIT(28)
#define BIT_SHIFT_PRI_MASK_TXAC_8814B 21
#define BIT_MASK_PRI_MASK_TXAC_8814B 0x7f
#define BIT_PRI_MASK_TXAC_8814B(x) \
(((x) & BIT_MASK_PRI_MASK_TXAC_8814B) << BIT_SHIFT_PRI_MASK_TXAC_8814B)
#define BITS_PRI_MASK_TXAC_8814B \
(BIT_MASK_PRI_MASK_TXAC_8814B << BIT_SHIFT_PRI_MASK_TXAC_8814B)
#define BIT_CLEAR_PRI_MASK_TXAC_8814B(x) ((x) & (~BITS_PRI_MASK_TXAC_8814B))
#define BIT_GET_PRI_MASK_TXAC_8814B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TXAC_8814B) & BIT_MASK_PRI_MASK_TXAC_8814B)
#define BIT_SET_PRI_MASK_TXAC_8814B(x, v) \
(BIT_CLEAR_PRI_MASK_TXAC_8814B(x) | BIT_PRI_MASK_TXAC_8814B(v))
#define BIT_SHIFT_PRI_MASK_NAV_8814B 13
#define BIT_MASK_PRI_MASK_NAV_8814B 0xff
#define BIT_PRI_MASK_NAV_8814B(x) \
(((x) & BIT_MASK_PRI_MASK_NAV_8814B) << BIT_SHIFT_PRI_MASK_NAV_8814B)
#define BITS_PRI_MASK_NAV_8814B \
(BIT_MASK_PRI_MASK_NAV_8814B << BIT_SHIFT_PRI_MASK_NAV_8814B)
#define BIT_CLEAR_PRI_MASK_NAV_8814B(x) ((x) & (~BITS_PRI_MASK_NAV_8814B))
#define BIT_GET_PRI_MASK_NAV_8814B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NAV_8814B) & BIT_MASK_PRI_MASK_NAV_8814B)
#define BIT_SET_PRI_MASK_NAV_8814B(x, v) \
(BIT_CLEAR_PRI_MASK_NAV_8814B(x) | BIT_PRI_MASK_NAV_8814B(v))
#define BIT_PRI_MASK_CCK_V1_8814B BIT(12)
#define BIT_PRI_MASK_OFDM_V1_8814B BIT(11)
#define BIT_PRI_MASK_RTY_V1_8814B BIT(10)
#define BIT_SHIFT_PRI_MASK_NUM_8814B 6
#define BIT_MASK_PRI_MASK_NUM_8814B 0xf
#define BIT_PRI_MASK_NUM_8814B(x) \
(((x) & BIT_MASK_PRI_MASK_NUM_8814B) << BIT_SHIFT_PRI_MASK_NUM_8814B)
#define BITS_PRI_MASK_NUM_8814B \
(BIT_MASK_PRI_MASK_NUM_8814B << BIT_SHIFT_PRI_MASK_NUM_8814B)
#define BIT_CLEAR_PRI_MASK_NUM_8814B(x) ((x) & (~BITS_PRI_MASK_NUM_8814B))
#define BIT_GET_PRI_MASK_NUM_8814B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NUM_8814B) & BIT_MASK_PRI_MASK_NUM_8814B)
#define BIT_SET_PRI_MASK_NUM_8814B(x, v) \
(BIT_CLEAR_PRI_MASK_NUM_8814B(x) | BIT_PRI_MASK_NUM_8814B(v))
#define BIT_SHIFT_PRI_MASK_TYPE_8814B 2
#define BIT_MASK_PRI_MASK_TYPE_8814B 0xf
#define BIT_PRI_MASK_TYPE_8814B(x) \
(((x) & BIT_MASK_PRI_MASK_TYPE_8814B) << BIT_SHIFT_PRI_MASK_TYPE_8814B)
#define BITS_PRI_MASK_TYPE_8814B \
(BIT_MASK_PRI_MASK_TYPE_8814B << BIT_SHIFT_PRI_MASK_TYPE_8814B)
#define BIT_CLEAR_PRI_MASK_TYPE_8814B(x) ((x) & (~BITS_PRI_MASK_TYPE_8814B))
#define BIT_GET_PRI_MASK_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TYPE_8814B) & BIT_MASK_PRI_MASK_TYPE_8814B)
#define BIT_SET_PRI_MASK_TYPE_8814B(x, v) \
(BIT_CLEAR_PRI_MASK_TYPE_8814B(x) | BIT_PRI_MASK_TYPE_8814B(v))
#define BIT_OOB_V1_8814B BIT(1)
#define BIT_ANT_SEL_V1_8814B BIT(0)
/* 2 REG_RXCMD_0_8814B */
#define BIT_RXCMD_EN_8814B BIT(31)
#define BIT_SHIFT_RXCMD_INFO_8814B 0
#define BIT_MASK_RXCMD_INFO_8814B 0x7fffffffL
#define BIT_RXCMD_INFO_8814B(x) \
(((x) & BIT_MASK_RXCMD_INFO_8814B) << BIT_SHIFT_RXCMD_INFO_8814B)
#define BITS_RXCMD_INFO_8814B \
(BIT_MASK_RXCMD_INFO_8814B << BIT_SHIFT_RXCMD_INFO_8814B)
#define BIT_CLEAR_RXCMD_INFO_8814B(x) ((x) & (~BITS_RXCMD_INFO_8814B))
#define BIT_GET_RXCMD_INFO_8814B(x) \
(((x) >> BIT_SHIFT_RXCMD_INFO_8814B) & BIT_MASK_RXCMD_INFO_8814B)
#define BIT_SET_RXCMD_INFO_8814B(x, v) \
(BIT_CLEAR_RXCMD_INFO_8814B(x) | BIT_RXCMD_INFO_8814B(v))
/* 2 REG_RXCMD_1_8814B */
#define BIT_SHIFT_CSI_RADDR_LATCH_8814B 24
#define BIT_MASK_CSI_RADDR_LATCH_8814B 0xff
#define BIT_CSI_RADDR_LATCH_8814B(x) \
(((x) & BIT_MASK_CSI_RADDR_LATCH_8814B) \
<< BIT_SHIFT_CSI_RADDR_LATCH_8814B)
#define BITS_CSI_RADDR_LATCH_8814B \
(BIT_MASK_CSI_RADDR_LATCH_8814B << BIT_SHIFT_CSI_RADDR_LATCH_8814B)
#define BIT_CLEAR_CSI_RADDR_LATCH_8814B(x) ((x) & (~BITS_CSI_RADDR_LATCH_8814B))
#define BIT_GET_CSI_RADDR_LATCH_8814B(x) \
(((x) >> BIT_SHIFT_CSI_RADDR_LATCH_8814B) & \
BIT_MASK_CSI_RADDR_LATCH_8814B)
#define BIT_SET_CSI_RADDR_LATCH_8814B(x, v) \
(BIT_CLEAR_CSI_RADDR_LATCH_8814B(x) | BIT_CSI_RADDR_LATCH_8814B(v))
#define BIT_SHIFT_CSI_WADDR_LATCH_8814B 16
#define BIT_MASK_CSI_WADDR_LATCH_8814B 0xff
#define BIT_CSI_WADDR_LATCH_8814B(x) \
(((x) & BIT_MASK_CSI_WADDR_LATCH_8814B) \
<< BIT_SHIFT_CSI_WADDR_LATCH_8814B)
#define BITS_CSI_WADDR_LATCH_8814B \
(BIT_MASK_CSI_WADDR_LATCH_8814B << BIT_SHIFT_CSI_WADDR_LATCH_8814B)
#define BIT_CLEAR_CSI_WADDR_LATCH_8814B(x) ((x) & (~BITS_CSI_WADDR_LATCH_8814B))
#define BIT_GET_CSI_WADDR_LATCH_8814B(x) \
(((x) >> BIT_SHIFT_CSI_WADDR_LATCH_8814B) & \
BIT_MASK_CSI_WADDR_LATCH_8814B)
#define BIT_SET_CSI_WADDR_LATCH_8814B(x, v) \
(BIT_CLEAR_CSI_WADDR_LATCH_8814B(x) | BIT_CSI_WADDR_LATCH_8814B(v))
#define BIT_SHIFT_RXCMD_PRD_8814B 0
#define BIT_MASK_RXCMD_PRD_8814B 0xffff
#define BIT_RXCMD_PRD_8814B(x) \
(((x) & BIT_MASK_RXCMD_PRD_8814B) << BIT_SHIFT_RXCMD_PRD_8814B)
#define BITS_RXCMD_PRD_8814B \
(BIT_MASK_RXCMD_PRD_8814B << BIT_SHIFT_RXCMD_PRD_8814B)
#define BIT_CLEAR_RXCMD_PRD_8814B(x) ((x) & (~BITS_RXCMD_PRD_8814B))
#define BIT_GET_RXCMD_PRD_8814B(x) \
(((x) >> BIT_SHIFT_RXCMD_PRD_8814B) & BIT_MASK_RXCMD_PRD_8814B)
#define BIT_SET_RXCMD_PRD_8814B(x, v) \
(BIT_CLEAR_RXCMD_PRD_8814B(x) | BIT_RXCMD_PRD_8814B(v))
/* 2 REG_WMAC_RESP_TXINFO_8814B (RESPONSE TXINFO REGISTER) */
#define BIT_SHIFT_WMAC_RESP_MFB_8814B 25
#define BIT_MASK_WMAC_RESP_MFB_8814B 0x7f
#define BIT_WMAC_RESP_MFB_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_MFB_8814B) << BIT_SHIFT_WMAC_RESP_MFB_8814B)
#define BITS_WMAC_RESP_MFB_8814B \
(BIT_MASK_WMAC_RESP_MFB_8814B << BIT_SHIFT_WMAC_RESP_MFB_8814B)
#define BIT_CLEAR_WMAC_RESP_MFB_8814B(x) ((x) & (~BITS_WMAC_RESP_MFB_8814B))
#define BIT_GET_WMAC_RESP_MFB_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_MFB_8814B) & BIT_MASK_WMAC_RESP_MFB_8814B)
#define BIT_SET_WMAC_RESP_MFB_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_MFB_8814B(x) | BIT_WMAC_RESP_MFB_8814B(v))
#define BIT_SHIFT_WMAC_ANTINF_SEL_8814B 23
#define BIT_MASK_WMAC_ANTINF_SEL_8814B 0x3
#define BIT_WMAC_ANTINF_SEL_8814B(x) \
(((x) & BIT_MASK_WMAC_ANTINF_SEL_8814B) \
<< BIT_SHIFT_WMAC_ANTINF_SEL_8814B)
#define BITS_WMAC_ANTINF_SEL_8814B \
(BIT_MASK_WMAC_ANTINF_SEL_8814B << BIT_SHIFT_WMAC_ANTINF_SEL_8814B)
#define BIT_CLEAR_WMAC_ANTINF_SEL_8814B(x) ((x) & (~BITS_WMAC_ANTINF_SEL_8814B))
#define BIT_GET_WMAC_ANTINF_SEL_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_ANTINF_SEL_8814B) & \
BIT_MASK_WMAC_ANTINF_SEL_8814B)
#define BIT_SET_WMAC_ANTINF_SEL_8814B(x, v) \
(BIT_CLEAR_WMAC_ANTINF_SEL_8814B(x) | BIT_WMAC_ANTINF_SEL_8814B(v))
#define BIT_SHIFT_WMAC_ANTSEL_SEL_8814B 21
#define BIT_MASK_WMAC_ANTSEL_SEL_8814B 0x3
#define BIT_WMAC_ANTSEL_SEL_8814B(x) \
(((x) & BIT_MASK_WMAC_ANTSEL_SEL_8814B) \
<< BIT_SHIFT_WMAC_ANTSEL_SEL_8814B)
#define BITS_WMAC_ANTSEL_SEL_8814B \
(BIT_MASK_WMAC_ANTSEL_SEL_8814B << BIT_SHIFT_WMAC_ANTSEL_SEL_8814B)
#define BIT_CLEAR_WMAC_ANTSEL_SEL_8814B(x) ((x) & (~BITS_WMAC_ANTSEL_SEL_8814B))
#define BIT_GET_WMAC_ANTSEL_SEL_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_ANTSEL_SEL_8814B) & \
BIT_MASK_WMAC_ANTSEL_SEL_8814B)
#define BIT_SET_WMAC_ANTSEL_SEL_8814B(x, v) \
(BIT_CLEAR_WMAC_ANTSEL_SEL_8814B(x) | BIT_WMAC_ANTSEL_SEL_8814B(v))
#define BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B 18
#define BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B 0x3
#define BIT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B) \
<< BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B)
#define BITS_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B \
(BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B \
<< BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B)
#define BIT_CLEAR_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B(x) \
((x) & (~BITS_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B))
#define BIT_GET_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B) & \
BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B)
#define BIT_SET_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B(x) | \
BIT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8814B(v))
#define BIT_SHIFT_WMAC_RESP_TXANT_V1_8814B 6
#define BIT_MASK_WMAC_RESP_TXANT_V1_8814B 0xfff
#define BIT_WMAC_RESP_TXANT_V1_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT_V1_8814B) \
<< BIT_SHIFT_WMAC_RESP_TXANT_V1_8814B)
#define BITS_WMAC_RESP_TXANT_V1_8814B \
(BIT_MASK_WMAC_RESP_TXANT_V1_8814B \
<< BIT_SHIFT_WMAC_RESP_TXANT_V1_8814B)
#define BIT_CLEAR_WMAC_RESP_TXANT_V1_8814B(x) \
((x) & (~BITS_WMAC_RESP_TXANT_V1_8814B))
#define BIT_GET_WMAC_RESP_TXANT_V1_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT_V1_8814B) & \
BIT_MASK_WMAC_RESP_TXANT_V1_8814B)
#define BIT_SET_WMAC_RESP_TXANT_V1_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT_V1_8814B(x) | \
BIT_WMAC_RESP_TXANT_V1_8814B(v))
/* 2 REG_BBPSF_CTRL_8814B */
#define BIT_CTL_IDLE_CLR_CSI_RPT_8814B BIT(31)
#define BIT_WMAC_USE_NDPARATE_8814B BIT(30)
#define BIT_SHIFT_WMAC_CSI_RATE_8814B 24
#define BIT_MASK_WMAC_CSI_RATE_8814B 0x3f
#define BIT_WMAC_CSI_RATE_8814B(x) \
(((x) & BIT_MASK_WMAC_CSI_RATE_8814B) << BIT_SHIFT_WMAC_CSI_RATE_8814B)
#define BITS_WMAC_CSI_RATE_8814B \
(BIT_MASK_WMAC_CSI_RATE_8814B << BIT_SHIFT_WMAC_CSI_RATE_8814B)
#define BIT_CLEAR_WMAC_CSI_RATE_8814B(x) ((x) & (~BITS_WMAC_CSI_RATE_8814B))
#define BIT_GET_WMAC_CSI_RATE_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RATE_8814B) & BIT_MASK_WMAC_CSI_RATE_8814B)
#define BIT_SET_WMAC_CSI_RATE_8814B(x, v) \
(BIT_CLEAR_WMAC_CSI_RATE_8814B(x) | BIT_WMAC_CSI_RATE_8814B(v))
#define BIT_SHIFT_WMAC_RESP_TXRATE_8814B 16
#define BIT_MASK_WMAC_RESP_TXRATE_8814B 0xff
#define BIT_WMAC_RESP_TXRATE_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_TXRATE_8814B) \
<< BIT_SHIFT_WMAC_RESP_TXRATE_8814B)
#define BITS_WMAC_RESP_TXRATE_8814B \
(BIT_MASK_WMAC_RESP_TXRATE_8814B << BIT_SHIFT_WMAC_RESP_TXRATE_8814B)
#define BIT_CLEAR_WMAC_RESP_TXRATE_8814B(x) \
((x) & (~BITS_WMAC_RESP_TXRATE_8814B))
#define BIT_GET_WMAC_RESP_TXRATE_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXRATE_8814B) & \
BIT_MASK_WMAC_RESP_TXRATE_8814B)
#define BIT_SET_WMAC_RESP_TXRATE_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_TXRATE_8814B(x) | BIT_WMAC_RESP_TXRATE_8814B(v))
#define BIT_CSI_FORCE_RATE_EN_8814B BIT(15)
#define BIT_SHIFT_CSI_RSC_8814B 13
#define BIT_MASK_CSI_RSC_8814B 0x3
#define BIT_CSI_RSC_8814B(x) \
(((x) & BIT_MASK_CSI_RSC_8814B) << BIT_SHIFT_CSI_RSC_8814B)
#define BITS_CSI_RSC_8814B (BIT_MASK_CSI_RSC_8814B << BIT_SHIFT_CSI_RSC_8814B)
#define BIT_CLEAR_CSI_RSC_8814B(x) ((x) & (~BITS_CSI_RSC_8814B))
#define BIT_GET_CSI_RSC_8814B(x) \
(((x) >> BIT_SHIFT_CSI_RSC_8814B) & BIT_MASK_CSI_RSC_8814B)
#define BIT_SET_CSI_RSC_8814B(x, v) \
(BIT_CLEAR_CSI_RSC_8814B(x) | BIT_CSI_RSC_8814B(v))
#define BIT_CSI_GID_SEL_8814B BIT(12)
#define BIT_RDCSIMD_FLAG_TRIG_SEL_8814B BIT(11)
#define BIT_NDPVLD_POS_RST_FFPTR_DIS_V1_8814B BIT(10)
#define BIT_NDPVLD_PROTECT_RDRDY_DIS_8814B BIT(9)
#define BIT_RDCSI_EMPTY_APPZERO_8814B BIT(8)
#define BIT_CSI_RATE_FB_EN_8814B BIT(7)
#define BIT_RXFIFO_WRPTR_WO_CHKSUM_8814B BIT(6)
/* 2 REG_P2P_RX_BCN_NOA_8814B (P2P RX BEACON NOA REGISTER) */
#define BIT_NOA_PARSER_EN_8814B BIT(15)
#define BIT_SHIFT_BSSID_SEL_V1_8814B 12
#define BIT_MASK_BSSID_SEL_V1_8814B 0x7
#define BIT_BSSID_SEL_V1_8814B(x) \
(((x) & BIT_MASK_BSSID_SEL_V1_8814B) << BIT_SHIFT_BSSID_SEL_V1_8814B)
#define BITS_BSSID_SEL_V1_8814B \
(BIT_MASK_BSSID_SEL_V1_8814B << BIT_SHIFT_BSSID_SEL_V1_8814B)
#define BIT_CLEAR_BSSID_SEL_V1_8814B(x) ((x) & (~BITS_BSSID_SEL_V1_8814B))
#define BIT_GET_BSSID_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID_SEL_V1_8814B) & BIT_MASK_BSSID_SEL_V1_8814B)
#define BIT_SET_BSSID_SEL_V1_8814B(x, v) \
(BIT_CLEAR_BSSID_SEL_V1_8814B(x) | BIT_BSSID_SEL_V1_8814B(v))
#define BIT_SHIFT_P2P_OUI_TYPE_8814B 0
#define BIT_MASK_P2P_OUI_TYPE_8814B 0xff
#define BIT_P2P_OUI_TYPE_8814B(x) \
(((x) & BIT_MASK_P2P_OUI_TYPE_8814B) << BIT_SHIFT_P2P_OUI_TYPE_8814B)
#define BITS_P2P_OUI_TYPE_8814B \
(BIT_MASK_P2P_OUI_TYPE_8814B << BIT_SHIFT_P2P_OUI_TYPE_8814B)
#define BIT_CLEAR_P2P_OUI_TYPE_8814B(x) ((x) & (~BITS_P2P_OUI_TYPE_8814B))
#define BIT_GET_P2P_OUI_TYPE_8814B(x) \
(((x) >> BIT_SHIFT_P2P_OUI_TYPE_8814B) & BIT_MASK_P2P_OUI_TYPE_8814B)
#define BIT_SET_P2P_OUI_TYPE_8814B(x, v) \
(BIT_CLEAR_P2P_OUI_TYPE_8814B(x) | BIT_P2P_OUI_TYPE_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_ASSOCIATED_BFMER0_INFO_8814B (ASSOCIATED BEAMFORMER0 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8814B 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8814B 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0_V1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8814B) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8814B)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_V1_8814B \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8814B \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8814B)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1_8814B(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_V1_8814B))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8814B) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8814B)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_V1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1_8814B(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_V1_8814B(v))
/* 2 REG_ASSOCIATED_BFMER0_INFO_H_8814B */
#define BIT_SHIFT_R_WMAC_TXCSI_AID0_8814B 16
#define BIT_MASK_R_WMAC_TXCSI_AID0_8814B 0x1ff
#define BIT_R_WMAC_TXCSI_AID0_8814B(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID0_8814B) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID0_8814B)
#define BITS_R_WMAC_TXCSI_AID0_8814B \
(BIT_MASK_R_WMAC_TXCSI_AID0_8814B << BIT_SHIFT_R_WMAC_TXCSI_AID0_8814B)
#define BIT_CLEAR_R_WMAC_TXCSI_AID0_8814B(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID0_8814B))
#define BIT_GET_R_WMAC_TXCSI_AID0_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID0_8814B) & \
BIT_MASK_R_WMAC_TXCSI_AID0_8814B)
#define BIT_SET_R_WMAC_TXCSI_AID0_8814B(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID0_8814B(x) | BIT_R_WMAC_TXCSI_AID0_8814B(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8814B(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_8814B (ASSOCIATED BEAMFORMER1 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8814B 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8814B 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_V1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8814B) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8814B)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_V1_8814B \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8814B \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8814B)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1_8814B(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_V1_8814B))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8814B) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8814B)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_V1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1_8814B(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_V1_8814B(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_H_8814B */
#define BIT_SHIFT_R_WMAC_TXCSI_AID1_8814B 16
#define BIT_MASK_R_WMAC_TXCSI_AID1_8814B 0x1ff
#define BIT_R_WMAC_TXCSI_AID1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID1_8814B) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID1_8814B)
#define BITS_R_WMAC_TXCSI_AID1_8814B \
(BIT_MASK_R_WMAC_TXCSI_AID1_8814B << BIT_SHIFT_R_WMAC_TXCSI_AID1_8814B)
#define BIT_CLEAR_R_WMAC_TXCSI_AID1_8814B(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID1_8814B))
#define BIT_GET_R_WMAC_TXCSI_AID1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID1_8814B) & \
BIT_MASK_R_WMAC_TXCSI_AID1_8814B)
#define BIT_SET_R_WMAC_TXCSI_AID1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID1_8814B(x) | BIT_R_WMAC_TXCSI_AID1_8814B(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8814B(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW20_8814B (TX CSI REPORT PARAMETER REGISTER) */
#define BIT_SHIFT_R_WMAC_BFINFO_20M_1_8814B 16
#define BIT_MASK_R_WMAC_BFINFO_20M_1_8814B 0xfff
#define BIT_R_WMAC_BFINFO_20M_1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_1_8814B) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8814B)
#define BITS_R_WMAC_BFINFO_20M_1_8814B \
(BIT_MASK_R_WMAC_BFINFO_20M_1_8814B \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8814B)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_1_8814B(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_1_8814B))
#define BIT_GET_R_WMAC_BFINFO_20M_1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_1_8814B) & \
BIT_MASK_R_WMAC_BFINFO_20M_1_8814B)
#define BIT_SET_R_WMAC_BFINFO_20M_1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_1_8814B(x) | \
BIT_R_WMAC_BFINFO_20M_1_8814B(v))
#define BIT_SHIFT_R_WMAC_BFINFO_20M_0_8814B 0
#define BIT_MASK_R_WMAC_BFINFO_20M_0_8814B 0xfff
#define BIT_R_WMAC_BFINFO_20M_0_8814B(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_0_8814B) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8814B)
#define BITS_R_WMAC_BFINFO_20M_0_8814B \
(BIT_MASK_R_WMAC_BFINFO_20M_0_8814B \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8814B)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_0_8814B(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_0_8814B))
#define BIT_GET_R_WMAC_BFINFO_20M_0_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_0_8814B) & \
BIT_MASK_R_WMAC_BFINFO_20M_0_8814B)
#define BIT_SET_R_WMAC_BFINFO_20M_0_8814B(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_0_8814B(x) | \
BIT_R_WMAC_BFINFO_20M_0_8814B(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW40_8814B (TX CSI REPORT PARAMETER_BW40 REGISTER) */
#define BIT_SHIFT_WMAC_RESP_ANTD_8814B 12
#define BIT_MASK_WMAC_RESP_ANTD_8814B 0xf
#define BIT_WMAC_RESP_ANTD_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTD_8814B) \
<< BIT_SHIFT_WMAC_RESP_ANTD_8814B)
#define BITS_WMAC_RESP_ANTD_8814B \
(BIT_MASK_WMAC_RESP_ANTD_8814B << BIT_SHIFT_WMAC_RESP_ANTD_8814B)
#define BIT_CLEAR_WMAC_RESP_ANTD_8814B(x) ((x) & (~BITS_WMAC_RESP_ANTD_8814B))
#define BIT_GET_WMAC_RESP_ANTD_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTD_8814B) & \
BIT_MASK_WMAC_RESP_ANTD_8814B)
#define BIT_SET_WMAC_RESP_ANTD_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTD_8814B(x) | BIT_WMAC_RESP_ANTD_8814B(v))
#define BIT_SHIFT_WMAC_RESP_ANTC_8814B 8
#define BIT_MASK_WMAC_RESP_ANTC_8814B 0xf
#define BIT_WMAC_RESP_ANTC_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTC_8814B) \
<< BIT_SHIFT_WMAC_RESP_ANTC_8814B)
#define BITS_WMAC_RESP_ANTC_8814B \
(BIT_MASK_WMAC_RESP_ANTC_8814B << BIT_SHIFT_WMAC_RESP_ANTC_8814B)
#define BIT_CLEAR_WMAC_RESP_ANTC_8814B(x) ((x) & (~BITS_WMAC_RESP_ANTC_8814B))
#define BIT_GET_WMAC_RESP_ANTC_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTC_8814B) & \
BIT_MASK_WMAC_RESP_ANTC_8814B)
#define BIT_SET_WMAC_RESP_ANTC_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTC_8814B(x) | BIT_WMAC_RESP_ANTC_8814B(v))
#define BIT_SHIFT_WMAC_RESP_ANTB_8814B 4
#define BIT_MASK_WMAC_RESP_ANTB_8814B 0xf
#define BIT_WMAC_RESP_ANTB_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTB_8814B) \
<< BIT_SHIFT_WMAC_RESP_ANTB_8814B)
#define BITS_WMAC_RESP_ANTB_8814B \
(BIT_MASK_WMAC_RESP_ANTB_8814B << BIT_SHIFT_WMAC_RESP_ANTB_8814B)
#define BIT_CLEAR_WMAC_RESP_ANTB_8814B(x) ((x) & (~BITS_WMAC_RESP_ANTB_8814B))
#define BIT_GET_WMAC_RESP_ANTB_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTB_8814B) & \
BIT_MASK_WMAC_RESP_ANTB_8814B)
#define BIT_SET_WMAC_RESP_ANTB_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTB_8814B(x) | BIT_WMAC_RESP_ANTB_8814B(v))
#define BIT_SHIFT_WMAC_RESP_ANTA_8814B 0
#define BIT_MASK_WMAC_RESP_ANTA_8814B 0xf
#define BIT_WMAC_RESP_ANTA_8814B(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTA_8814B) \
<< BIT_SHIFT_WMAC_RESP_ANTA_8814B)
#define BITS_WMAC_RESP_ANTA_8814B \
(BIT_MASK_WMAC_RESP_ANTA_8814B << BIT_SHIFT_WMAC_RESP_ANTA_8814B)
#define BIT_CLEAR_WMAC_RESP_ANTA_8814B(x) ((x) & (~BITS_WMAC_RESP_ANTA_8814B))
#define BIT_GET_WMAC_RESP_ANTA_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTA_8814B) & \
BIT_MASK_WMAC_RESP_ANTA_8814B)
#define BIT_SET_WMAC_RESP_ANTA_8814B(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTA_8814B(x) | BIT_WMAC_RESP_ANTA_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_BCN_PSR_RPT2_8814B (BEACON PARSER REPORT REGISTER2) */
#define BIT_SHIFT_DTIM_CNT2_8814B 24
#define BIT_MASK_DTIM_CNT2_8814B 0xff
#define BIT_DTIM_CNT2_8814B(x) \
(((x) & BIT_MASK_DTIM_CNT2_8814B) << BIT_SHIFT_DTIM_CNT2_8814B)
#define BITS_DTIM_CNT2_8814B \
(BIT_MASK_DTIM_CNT2_8814B << BIT_SHIFT_DTIM_CNT2_8814B)
#define BIT_CLEAR_DTIM_CNT2_8814B(x) ((x) & (~BITS_DTIM_CNT2_8814B))
#define BIT_GET_DTIM_CNT2_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT2_8814B) & BIT_MASK_DTIM_CNT2_8814B)
#define BIT_SET_DTIM_CNT2_8814B(x, v) \
(BIT_CLEAR_DTIM_CNT2_8814B(x) | BIT_DTIM_CNT2_8814B(v))
#define BIT_SHIFT_DTIM_PERIOD2_8814B 16
#define BIT_MASK_DTIM_PERIOD2_8814B 0xff
#define BIT_DTIM_PERIOD2_8814B(x) \
(((x) & BIT_MASK_DTIM_PERIOD2_8814B) << BIT_SHIFT_DTIM_PERIOD2_8814B)
#define BITS_DTIM_PERIOD2_8814B \
(BIT_MASK_DTIM_PERIOD2_8814B << BIT_SHIFT_DTIM_PERIOD2_8814B)
#define BIT_CLEAR_DTIM_PERIOD2_8814B(x) ((x) & (~BITS_DTIM_PERIOD2_8814B))
#define BIT_GET_DTIM_PERIOD2_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD2_8814B) & BIT_MASK_DTIM_PERIOD2_8814B)
#define BIT_SET_DTIM_PERIOD2_8814B(x, v) \
(BIT_CLEAR_DTIM_PERIOD2_8814B(x) | BIT_DTIM_PERIOD2_8814B(v))
#define BIT_DTIM2_8814B BIT(15)
#define BIT_TIM2_8814B BIT(14)
#define BIT_RPT_VALID_8814B BIT(13)
#define BIT_SHIFT_PS_AID_2_8814B 0
#define BIT_MASK_PS_AID_2_8814B 0x7ff
#define BIT_PS_AID_2_8814B(x) \
(((x) & BIT_MASK_PS_AID_2_8814B) << BIT_SHIFT_PS_AID_2_8814B)
#define BITS_PS_AID_2_8814B \
(BIT_MASK_PS_AID_2_8814B << BIT_SHIFT_PS_AID_2_8814B)
#define BIT_CLEAR_PS_AID_2_8814B(x) ((x) & (~BITS_PS_AID_2_8814B))
#define BIT_GET_PS_AID_2_8814B(x) \
(((x) >> BIT_SHIFT_PS_AID_2_8814B) & BIT_MASK_PS_AID_2_8814B)
#define BIT_SET_PS_AID_2_8814B(x, v) \
(BIT_CLEAR_PS_AID_2_8814B(x) | BIT_PS_AID_2_8814B(v))
/* 2 REG_BCN_PSR_RPT3_8814B (BEACON PARSER REPORT REGISTER3) */
#define BIT_SHIFT_DTIM_CNT3_8814B 24
#define BIT_MASK_DTIM_CNT3_8814B 0xff
#define BIT_DTIM_CNT3_8814B(x) \
(((x) & BIT_MASK_DTIM_CNT3_8814B) << BIT_SHIFT_DTIM_CNT3_8814B)
#define BITS_DTIM_CNT3_8814B \
(BIT_MASK_DTIM_CNT3_8814B << BIT_SHIFT_DTIM_CNT3_8814B)
#define BIT_CLEAR_DTIM_CNT3_8814B(x) ((x) & (~BITS_DTIM_CNT3_8814B))
#define BIT_GET_DTIM_CNT3_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT3_8814B) & BIT_MASK_DTIM_CNT3_8814B)
#define BIT_SET_DTIM_CNT3_8814B(x, v) \
(BIT_CLEAR_DTIM_CNT3_8814B(x) | BIT_DTIM_CNT3_8814B(v))
#define BIT_SHIFT_DTIM_PERIOD3_8814B 16
#define BIT_MASK_DTIM_PERIOD3_8814B 0xff
#define BIT_DTIM_PERIOD3_8814B(x) \
(((x) & BIT_MASK_DTIM_PERIOD3_8814B) << BIT_SHIFT_DTIM_PERIOD3_8814B)
#define BITS_DTIM_PERIOD3_8814B \
(BIT_MASK_DTIM_PERIOD3_8814B << BIT_SHIFT_DTIM_PERIOD3_8814B)
#define BIT_CLEAR_DTIM_PERIOD3_8814B(x) ((x) & (~BITS_DTIM_PERIOD3_8814B))
#define BIT_GET_DTIM_PERIOD3_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD3_8814B) & BIT_MASK_DTIM_PERIOD3_8814B)
#define BIT_SET_DTIM_PERIOD3_8814B(x, v) \
(BIT_CLEAR_DTIM_PERIOD3_8814B(x) | BIT_DTIM_PERIOD3_8814B(v))
#define BIT_DTIM3_8814B BIT(15)
#define BIT_TIM3_8814B BIT(14)
#define BIT_RPT_VALID_8814B BIT(13)
#define BIT_SHIFT_PS_AID_3_8814B 0
#define BIT_MASK_PS_AID_3_8814B 0x7ff
#define BIT_PS_AID_3_8814B(x) \
(((x) & BIT_MASK_PS_AID_3_8814B) << BIT_SHIFT_PS_AID_3_8814B)
#define BITS_PS_AID_3_8814B \
(BIT_MASK_PS_AID_3_8814B << BIT_SHIFT_PS_AID_3_8814B)
#define BIT_CLEAR_PS_AID_3_8814B(x) ((x) & (~BITS_PS_AID_3_8814B))
#define BIT_GET_PS_AID_3_8814B(x) \
(((x) >> BIT_SHIFT_PS_AID_3_8814B) & BIT_MASK_PS_AID_3_8814B)
#define BIT_SET_PS_AID_3_8814B(x, v) \
(BIT_CLEAR_PS_AID_3_8814B(x) | BIT_PS_AID_3_8814B(v))
/* 2 REG_BCN_PSR_RPT4_8814B (BEACON PARSER REPORT REGISTER4) */
#define BIT_SHIFT_DTIM_CNT4_8814B 24
#define BIT_MASK_DTIM_CNT4_8814B 0xff
#define BIT_DTIM_CNT4_8814B(x) \
(((x) & BIT_MASK_DTIM_CNT4_8814B) << BIT_SHIFT_DTIM_CNT4_8814B)
#define BITS_DTIM_CNT4_8814B \
(BIT_MASK_DTIM_CNT4_8814B << BIT_SHIFT_DTIM_CNT4_8814B)
#define BIT_CLEAR_DTIM_CNT4_8814B(x) ((x) & (~BITS_DTIM_CNT4_8814B))
#define BIT_GET_DTIM_CNT4_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT4_8814B) & BIT_MASK_DTIM_CNT4_8814B)
#define BIT_SET_DTIM_CNT4_8814B(x, v) \
(BIT_CLEAR_DTIM_CNT4_8814B(x) | BIT_DTIM_CNT4_8814B(v))
#define BIT_SHIFT_DTIM_PERIOD4_8814B 16
#define BIT_MASK_DTIM_PERIOD4_8814B 0xff
#define BIT_DTIM_PERIOD4_8814B(x) \
(((x) & BIT_MASK_DTIM_PERIOD4_8814B) << BIT_SHIFT_DTIM_PERIOD4_8814B)
#define BITS_DTIM_PERIOD4_8814B \
(BIT_MASK_DTIM_PERIOD4_8814B << BIT_SHIFT_DTIM_PERIOD4_8814B)
#define BIT_CLEAR_DTIM_PERIOD4_8814B(x) ((x) & (~BITS_DTIM_PERIOD4_8814B))
#define BIT_GET_DTIM_PERIOD4_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD4_8814B) & BIT_MASK_DTIM_PERIOD4_8814B)
#define BIT_SET_DTIM_PERIOD4_8814B(x, v) \
(BIT_CLEAR_DTIM_PERIOD4_8814B(x) | BIT_DTIM_PERIOD4_8814B(v))
#define BIT_DTIM4_8814B BIT(15)
#define BIT_TIM4_8814B BIT(14)
#define BIT_RPT_VALID_8814B BIT(13)
#define BIT_SHIFT_PS_AID_4_8814B 0
#define BIT_MASK_PS_AID_4_8814B 0x7ff
#define BIT_PS_AID_4_8814B(x) \
(((x) & BIT_MASK_PS_AID_4_8814B) << BIT_SHIFT_PS_AID_4_8814B)
#define BITS_PS_AID_4_8814B \
(BIT_MASK_PS_AID_4_8814B << BIT_SHIFT_PS_AID_4_8814B)
#define BIT_CLEAR_PS_AID_4_8814B(x) ((x) & (~BITS_PS_AID_4_8814B))
#define BIT_GET_PS_AID_4_8814B(x) \
(((x) >> BIT_SHIFT_PS_AID_4_8814B) & BIT_MASK_PS_AID_4_8814B)
#define BIT_SET_PS_AID_4_8814B(x, v) \
(BIT_CLEAR_PS_AID_4_8814B(x) | BIT_PS_AID_4_8814B(v))
/* 2 REG_A1_ADDR_MASK_8814B (A1 ADDR MASK REGISTER) */
#define BIT_SHIFT_A1_ADDR_MASK_8814B 0
#define BIT_MASK_A1_ADDR_MASK_8814B 0xffffffffL
#define BIT_A1_ADDR_MASK_8814B(x) \
(((x) & BIT_MASK_A1_ADDR_MASK_8814B) << BIT_SHIFT_A1_ADDR_MASK_8814B)
#define BITS_A1_ADDR_MASK_8814B \
(BIT_MASK_A1_ADDR_MASK_8814B << BIT_SHIFT_A1_ADDR_MASK_8814B)
#define BIT_CLEAR_A1_ADDR_MASK_8814B(x) ((x) & (~BITS_A1_ADDR_MASK_8814B))
#define BIT_GET_A1_ADDR_MASK_8814B(x) \
(((x) >> BIT_SHIFT_A1_ADDR_MASK_8814B) & BIT_MASK_A1_ADDR_MASK_8814B)
#define BIT_SET_A1_ADDR_MASK_8814B(x, v) \
(BIT_CLEAR_A1_ADDR_MASK_8814B(x) | BIT_A1_ADDR_MASK_8814B(v))
/* 2 REG_RXPSF_CTRL_8814B */
#define BIT_RXGCK_FIFOTHR_EN_8814B BIT(28)
#define BIT_SHIFT_RXGCK_VHT_FIFOTHR_8814B 26
#define BIT_MASK_RXGCK_VHT_FIFOTHR_8814B 0x3
#define BIT_RXGCK_VHT_FIFOTHR_8814B(x) \
(((x) & BIT_MASK_RXGCK_VHT_FIFOTHR_8814B) \
<< BIT_SHIFT_RXGCK_VHT_FIFOTHR_8814B)
#define BITS_RXGCK_VHT_FIFOTHR_8814B \
(BIT_MASK_RXGCK_VHT_FIFOTHR_8814B << BIT_SHIFT_RXGCK_VHT_FIFOTHR_8814B)
#define BIT_CLEAR_RXGCK_VHT_FIFOTHR_8814B(x) \
((x) & (~BITS_RXGCK_VHT_FIFOTHR_8814B))
#define BIT_GET_RXGCK_VHT_FIFOTHR_8814B(x) \
(((x) >> BIT_SHIFT_RXGCK_VHT_FIFOTHR_8814B) & \
BIT_MASK_RXGCK_VHT_FIFOTHR_8814B)
#define BIT_SET_RXGCK_VHT_FIFOTHR_8814B(x, v) \
(BIT_CLEAR_RXGCK_VHT_FIFOTHR_8814B(x) | BIT_RXGCK_VHT_FIFOTHR_8814B(v))
#define BIT_SHIFT_RXGCK_HT_FIFOTHR_8814B 24
#define BIT_MASK_RXGCK_HT_FIFOTHR_8814B 0x3
#define BIT_RXGCK_HT_FIFOTHR_8814B(x) \
(((x) & BIT_MASK_RXGCK_HT_FIFOTHR_8814B) \
<< BIT_SHIFT_RXGCK_HT_FIFOTHR_8814B)
#define BITS_RXGCK_HT_FIFOTHR_8814B \
(BIT_MASK_RXGCK_HT_FIFOTHR_8814B << BIT_SHIFT_RXGCK_HT_FIFOTHR_8814B)
#define BIT_CLEAR_RXGCK_HT_FIFOTHR_8814B(x) \
((x) & (~BITS_RXGCK_HT_FIFOTHR_8814B))
#define BIT_GET_RXGCK_HT_FIFOTHR_8814B(x) \
(((x) >> BIT_SHIFT_RXGCK_HT_FIFOTHR_8814B) & \
BIT_MASK_RXGCK_HT_FIFOTHR_8814B)
#define BIT_SET_RXGCK_HT_FIFOTHR_8814B(x, v) \
(BIT_CLEAR_RXGCK_HT_FIFOTHR_8814B(x) | BIT_RXGCK_HT_FIFOTHR_8814B(v))
#define BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8814B 22
#define BIT_MASK_RXGCK_OFDM_FIFOTHR_8814B 0x3
#define BIT_RXGCK_OFDM_FIFOTHR_8814B(x) \
(((x) & BIT_MASK_RXGCK_OFDM_FIFOTHR_8814B) \
<< BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8814B)
#define BITS_RXGCK_OFDM_FIFOTHR_8814B \
(BIT_MASK_RXGCK_OFDM_FIFOTHR_8814B \
<< BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8814B)
#define BIT_CLEAR_RXGCK_OFDM_FIFOTHR_8814B(x) \
((x) & (~BITS_RXGCK_OFDM_FIFOTHR_8814B))
#define BIT_GET_RXGCK_OFDM_FIFOTHR_8814B(x) \
(((x) >> BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8814B) & \
BIT_MASK_RXGCK_OFDM_FIFOTHR_8814B)
#define BIT_SET_RXGCK_OFDM_FIFOTHR_8814B(x, v) \
(BIT_CLEAR_RXGCK_OFDM_FIFOTHR_8814B(x) | \
BIT_RXGCK_OFDM_FIFOTHR_8814B(v))
#define BIT_SHIFT_RXGCK_CCK_FIFOTHR_8814B 20
#define BIT_MASK_RXGCK_CCK_FIFOTHR_8814B 0x3
#define BIT_RXGCK_CCK_FIFOTHR_8814B(x) \
(((x) & BIT_MASK_RXGCK_CCK_FIFOTHR_8814B) \
<< BIT_SHIFT_RXGCK_CCK_FIFOTHR_8814B)
#define BITS_RXGCK_CCK_FIFOTHR_8814B \
(BIT_MASK_RXGCK_CCK_FIFOTHR_8814B << BIT_SHIFT_RXGCK_CCK_FIFOTHR_8814B)
#define BIT_CLEAR_RXGCK_CCK_FIFOTHR_8814B(x) \
((x) & (~BITS_RXGCK_CCK_FIFOTHR_8814B))
#define BIT_GET_RXGCK_CCK_FIFOTHR_8814B(x) \
(((x) >> BIT_SHIFT_RXGCK_CCK_FIFOTHR_8814B) & \
BIT_MASK_RXGCK_CCK_FIFOTHR_8814B)
#define BIT_SET_RXGCK_CCK_FIFOTHR_8814B(x, v) \
(BIT_CLEAR_RXGCK_CCK_FIFOTHR_8814B(x) | BIT_RXGCK_CCK_FIFOTHR_8814B(v))
#define BIT_SHIFT_RXGCK_ENTRY_DELAY_8814B 17
#define BIT_MASK_RXGCK_ENTRY_DELAY_8814B 0x7
#define BIT_RXGCK_ENTRY_DELAY_8814B(x) \
(((x) & BIT_MASK_RXGCK_ENTRY_DELAY_8814B) \
<< BIT_SHIFT_RXGCK_ENTRY_DELAY_8814B)
#define BITS_RXGCK_ENTRY_DELAY_8814B \
(BIT_MASK_RXGCK_ENTRY_DELAY_8814B << BIT_SHIFT_RXGCK_ENTRY_DELAY_8814B)
#define BIT_CLEAR_RXGCK_ENTRY_DELAY_8814B(x) \
((x) & (~BITS_RXGCK_ENTRY_DELAY_8814B))
#define BIT_GET_RXGCK_ENTRY_DELAY_8814B(x) \
(((x) >> BIT_SHIFT_RXGCK_ENTRY_DELAY_8814B) & \
BIT_MASK_RXGCK_ENTRY_DELAY_8814B)
#define BIT_SET_RXGCK_ENTRY_DELAY_8814B(x, v) \
(BIT_CLEAR_RXGCK_ENTRY_DELAY_8814B(x) | BIT_RXGCK_ENTRY_DELAY_8814B(v))
#define BIT_RXGCK_OFDMCCA_EN_8814B BIT(16)
#define BIT_SHIFT_RXPSF_PKTLENTHR_8814B 13
#define BIT_MASK_RXPSF_PKTLENTHR_8814B 0x7
#define BIT_RXPSF_PKTLENTHR_8814B(x) \
(((x) & BIT_MASK_RXPSF_PKTLENTHR_8814B) \
<< BIT_SHIFT_RXPSF_PKTLENTHR_8814B)
#define BITS_RXPSF_PKTLENTHR_8814B \
(BIT_MASK_RXPSF_PKTLENTHR_8814B << BIT_SHIFT_RXPSF_PKTLENTHR_8814B)
#define BIT_CLEAR_RXPSF_PKTLENTHR_8814B(x) ((x) & (~BITS_RXPSF_PKTLENTHR_8814B))
#define BIT_GET_RXPSF_PKTLENTHR_8814B(x) \
(((x) >> BIT_SHIFT_RXPSF_PKTLENTHR_8814B) & \
BIT_MASK_RXPSF_PKTLENTHR_8814B)
#define BIT_SET_RXPSF_PKTLENTHR_8814B(x, v) \
(BIT_CLEAR_RXPSF_PKTLENTHR_8814B(x) | BIT_RXPSF_PKTLENTHR_8814B(v))
#define BIT_RXPSF_CTRLEN_8814B BIT(12)
#define BIT_RXPSF_VHTCHKEN_8814B BIT(11)
#define BIT_RXPSF_HTCHKEN_8814B BIT(10)
#define BIT_RXPSF_OFDMCHKEN_8814B BIT(9)
#define BIT_RXPSF_CCKCHKEN_8814B BIT(8)
#define BIT_RXPSF_OFDMRST_8814B BIT(7)
#define BIT_RXPSF_CCKRST_8814B BIT(6)
#define BIT_RXPSF_MHCHKEN_8814B BIT(5)
#define BIT_RXPSF_CONT_ERRCHKEN_8814B BIT(4)
#define BIT_RXPSF_ALL_ERRCHKEN_8814B BIT(3)
#define BIT_SHIFT_RXPSF_ERRTHR_8814B 0
#define BIT_MASK_RXPSF_ERRTHR_8814B 0x7
#define BIT_RXPSF_ERRTHR_8814B(x) \
(((x) & BIT_MASK_RXPSF_ERRTHR_8814B) << BIT_SHIFT_RXPSF_ERRTHR_8814B)
#define BITS_RXPSF_ERRTHR_8814B \
(BIT_MASK_RXPSF_ERRTHR_8814B << BIT_SHIFT_RXPSF_ERRTHR_8814B)
#define BIT_CLEAR_RXPSF_ERRTHR_8814B(x) ((x) & (~BITS_RXPSF_ERRTHR_8814B))
#define BIT_GET_RXPSF_ERRTHR_8814B(x) \
(((x) >> BIT_SHIFT_RXPSF_ERRTHR_8814B) & BIT_MASK_RXPSF_ERRTHR_8814B)
#define BIT_SET_RXPSF_ERRTHR_8814B(x, v) \
(BIT_CLEAR_RXPSF_ERRTHR_8814B(x) | BIT_RXPSF_ERRTHR_8814B(v))
/* 2 REG_RXPSF_TYPE_CTRL_8814B */
#define BIT_RXPSF_DATA15EN_8814B BIT(31)
#define BIT_RXPSF_DATA14EN_8814B BIT(30)
#define BIT_RXPSF_DATA13EN_8814B BIT(29)
#define BIT_RXPSF_DATA12EN_8814B BIT(28)
#define BIT_RXPSF_DATA11EN_8814B BIT(27)
#define BIT_RXPSF_DATA10EN_8814B BIT(26)
#define BIT_RXPSF_DATA9EN_8814B BIT(25)
#define BIT_RXPSF_DATA8EN_8814B BIT(24)
#define BIT_RXPSF_DATA7EN_8814B BIT(23)
#define BIT_RXPSF_DATA6EN_8814B BIT(22)
#define BIT_RXPSF_DATA5EN_8814B BIT(21)
#define BIT_RXPSF_DATA4EN_8814B BIT(20)
#define BIT_RXPSF_DATA3EN_8814B BIT(19)
#define BIT_RXPSF_DATA2EN_8814B BIT(18)
#define BIT_RXPSF_DATA1EN_8814B BIT(17)
#define BIT_RXPSF_DATA0EN_8814B BIT(16)
#define BIT_RXPSF_MGT15EN_8814B BIT(15)
#define BIT_RXPSF_MGT14EN_8814B BIT(14)
#define BIT_RXPSF_MGT13EN_8814B BIT(13)
#define BIT_RXPSF_MGT12EN_8814B BIT(12)
#define BIT_RXPSF_MGT11EN_8814B BIT(11)
#define BIT_RXPSF_MGT10EN_8814B BIT(10)
#define BIT_RXPSF_MGT9EN_8814B BIT(9)
#define BIT_RXPSF_MGT8EN_8814B BIT(8)
#define BIT_RXPSF_MGT7EN_8814B BIT(7)
#define BIT_RXPSF_MGT6EN_8814B BIT(6)
#define BIT_RXPSF_MGT5EN_8814B BIT(5)
#define BIT_RXPSF_MGT4EN_8814B BIT(4)
#define BIT_RXPSF_MGT3EN_8814B BIT(3)
#define BIT_RXPSF_MGT2EN_8814B BIT(2)
#define BIT_RXPSF_MGT1EN_8814B BIT(1)
#define BIT_RXPSF_MGT0EN_8814B BIT(0)
/* 2 REG_CAM_ACCESS_CTRL_8814B */
#define BIT_INDIRECT_ERR_8814B BIT(6)
#define BIT_DIRECT_ERR_8814B BIT(5)
#define BIT_DIR_ACCESS_EN_RX_BA_8814B BIT(4)
#define BIT_DIR_ACCESS_EN_ADDRCAM_8814B BIT(3)
#define BIT_DIR_ACCESS_EN_KEY_8814B BIT(2)
#define BIT_DIR_ACCESS_EN_WOWLAN_8814B BIT(1)
#define BIT_DIR_ACCESS_EN_FW_FILTER_8814B BIT(0)
/* 2 REG_CUT_AMSDU_CTRL_8814B */
#define BIT__CUT_AMSDU_CHKLEN_EN_8814B BIT(31)
#define BIT_EN_CUT_AMSDU_8814B BIT(30)
#define BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH_8814B 16
#define BIT_MASK_CUT_AMSDU_CHKLEN_L_TH_8814B 0xff
#define BIT_CUT_AMSDU_CHKLEN_L_TH_8814B(x) \
(((x) & BIT_MASK_CUT_AMSDU_CHKLEN_L_TH_8814B) \
<< BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH_8814B)
#define BITS_CUT_AMSDU_CHKLEN_L_TH_8814B \
(BIT_MASK_CUT_AMSDU_CHKLEN_L_TH_8814B \
<< BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH_8814B)
#define BIT_CLEAR_CUT_AMSDU_CHKLEN_L_TH_8814B(x) \
((x) & (~BITS_CUT_AMSDU_CHKLEN_L_TH_8814B))
#define BIT_GET_CUT_AMSDU_CHKLEN_L_TH_8814B(x) \
(((x) >> BIT_SHIFT_CUT_AMSDU_CHKLEN_L_TH_8814B) & \
BIT_MASK_CUT_AMSDU_CHKLEN_L_TH_8814B)
#define BIT_SET_CUT_AMSDU_CHKLEN_L_TH_8814B(x, v) \
(BIT_CLEAR_CUT_AMSDU_CHKLEN_L_TH_8814B(x) | \
BIT_CUT_AMSDU_CHKLEN_L_TH_8814B(v))
#define BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH_8814B 0
#define BIT_MASK_CUT_AMSDU_CHKLEN_H_TH_8814B 0xffff
#define BIT_CUT_AMSDU_CHKLEN_H_TH_8814B(x) \
(((x) & BIT_MASK_CUT_AMSDU_CHKLEN_H_TH_8814B) \
<< BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH_8814B)
#define BITS_CUT_AMSDU_CHKLEN_H_TH_8814B \
(BIT_MASK_CUT_AMSDU_CHKLEN_H_TH_8814B \
<< BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH_8814B)
#define BIT_CLEAR_CUT_AMSDU_CHKLEN_H_TH_8814B(x) \
((x) & (~BITS_CUT_AMSDU_CHKLEN_H_TH_8814B))
#define BIT_GET_CUT_AMSDU_CHKLEN_H_TH_8814B(x) \
(((x) >> BIT_SHIFT_CUT_AMSDU_CHKLEN_H_TH_8814B) & \
BIT_MASK_CUT_AMSDU_CHKLEN_H_TH_8814B)
#define BIT_SET_CUT_AMSDU_CHKLEN_H_TH_8814B(x, v) \
(BIT_CLEAR_CUT_AMSDU_CHKLEN_H_TH_8814B(x) | \
BIT_CUT_AMSDU_CHKLEN_H_TH_8814B(v))
/* 2 REG_MACID2_8814B (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_V1_8814B 0
#define BIT_MASK_MACID2_V1_8814B 0xffffffffL
#define BIT_MACID2_V1_8814B(x) \
(((x) & BIT_MASK_MACID2_V1_8814B) << BIT_SHIFT_MACID2_V1_8814B)
#define BITS_MACID2_V1_8814B \
(BIT_MASK_MACID2_V1_8814B << BIT_SHIFT_MACID2_V1_8814B)
#define BIT_CLEAR_MACID2_V1_8814B(x) ((x) & (~BITS_MACID2_V1_8814B))
#define BIT_GET_MACID2_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID2_V1_8814B) & BIT_MASK_MACID2_V1_8814B)
#define BIT_SET_MACID2_V1_8814B(x, v) \
(BIT_CLEAR_MACID2_V1_8814B(x) | BIT_MACID2_V1_8814B(v))
/* 2 REG_MACID2_H_8814B (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_H_V1_8814B 0
#define BIT_MASK_MACID2_H_V1_8814B 0xffff
#define BIT_MACID2_H_V1_8814B(x) \
(((x) & BIT_MASK_MACID2_H_V1_8814B) << BIT_SHIFT_MACID2_H_V1_8814B)
#define BITS_MACID2_H_V1_8814B \
(BIT_MASK_MACID2_H_V1_8814B << BIT_SHIFT_MACID2_H_V1_8814B)
#define BIT_CLEAR_MACID2_H_V1_8814B(x) ((x) & (~BITS_MACID2_H_V1_8814B))
#define BIT_GET_MACID2_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID2_H_V1_8814B) & BIT_MASK_MACID2_H_V1_8814B)
#define BIT_SET_MACID2_H_V1_8814B(x, v) \
(BIT_CLEAR_MACID2_H_V1_8814B(x) | BIT_MACID2_H_V1_8814B(v))
/* 2 REG_BSSID2_8814B (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_V1_8814B 0
#define BIT_MASK_BSSID2_V1_8814B 0xffffffffL
#define BIT_BSSID2_V1_8814B(x) \
(((x) & BIT_MASK_BSSID2_V1_8814B) << BIT_SHIFT_BSSID2_V1_8814B)
#define BITS_BSSID2_V1_8814B \
(BIT_MASK_BSSID2_V1_8814B << BIT_SHIFT_BSSID2_V1_8814B)
#define BIT_CLEAR_BSSID2_V1_8814B(x) ((x) & (~BITS_BSSID2_V1_8814B))
#define BIT_GET_BSSID2_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID2_V1_8814B) & BIT_MASK_BSSID2_V1_8814B)
#define BIT_SET_BSSID2_V1_8814B(x, v) \
(BIT_CLEAR_BSSID2_V1_8814B(x) | BIT_BSSID2_V1_8814B(v))
/* 2 REG_BSSID2_H_8814B (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_H_V1_8814B 0
#define BIT_MASK_BSSID2_H_V1_8814B 0xffff
#define BIT_BSSID2_H_V1_8814B(x) \
(((x) & BIT_MASK_BSSID2_H_V1_8814B) << BIT_SHIFT_BSSID2_H_V1_8814B)
#define BITS_BSSID2_H_V1_8814B \
(BIT_MASK_BSSID2_H_V1_8814B << BIT_SHIFT_BSSID2_H_V1_8814B)
#define BIT_CLEAR_BSSID2_H_V1_8814B(x) ((x) & (~BITS_BSSID2_H_V1_8814B))
#define BIT_GET_BSSID2_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID2_H_V1_8814B) & BIT_MASK_BSSID2_H_V1_8814B)
#define BIT_SET_BSSID2_H_V1_8814B(x, v) \
(BIT_CLEAR_BSSID2_H_V1_8814B(x) | BIT_BSSID2_H_V1_8814B(v))
/* 2 REG_MACID3_8814B (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_V1_8814B 0
#define BIT_MASK_MACID3_V1_8814B 0xffffffffL
#define BIT_MACID3_V1_8814B(x) \
(((x) & BIT_MASK_MACID3_V1_8814B) << BIT_SHIFT_MACID3_V1_8814B)
#define BITS_MACID3_V1_8814B \
(BIT_MASK_MACID3_V1_8814B << BIT_SHIFT_MACID3_V1_8814B)
#define BIT_CLEAR_MACID3_V1_8814B(x) ((x) & (~BITS_MACID3_V1_8814B))
#define BIT_GET_MACID3_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID3_V1_8814B) & BIT_MASK_MACID3_V1_8814B)
#define BIT_SET_MACID3_V1_8814B(x, v) \
(BIT_CLEAR_MACID3_V1_8814B(x) | BIT_MACID3_V1_8814B(v))
/* 2 REG_MACID3_H_8814B (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_H_V1_8814B 0
#define BIT_MASK_MACID3_H_V1_8814B 0xffff
#define BIT_MACID3_H_V1_8814B(x) \
(((x) & BIT_MASK_MACID3_H_V1_8814B) << BIT_SHIFT_MACID3_H_V1_8814B)
#define BITS_MACID3_H_V1_8814B \
(BIT_MASK_MACID3_H_V1_8814B << BIT_SHIFT_MACID3_H_V1_8814B)
#define BIT_CLEAR_MACID3_H_V1_8814B(x) ((x) & (~BITS_MACID3_H_V1_8814B))
#define BIT_GET_MACID3_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID3_H_V1_8814B) & BIT_MASK_MACID3_H_V1_8814B)
#define BIT_SET_MACID3_H_V1_8814B(x, v) \
(BIT_CLEAR_MACID3_H_V1_8814B(x) | BIT_MACID3_H_V1_8814B(v))
/* 2 REG_BSSID3_8814B (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_V1_8814B 0
#define BIT_MASK_BSSID3_V1_8814B 0xffffffffL
#define BIT_BSSID3_V1_8814B(x) \
(((x) & BIT_MASK_BSSID3_V1_8814B) << BIT_SHIFT_BSSID3_V1_8814B)
#define BITS_BSSID3_V1_8814B \
(BIT_MASK_BSSID3_V1_8814B << BIT_SHIFT_BSSID3_V1_8814B)
#define BIT_CLEAR_BSSID3_V1_8814B(x) ((x) & (~BITS_BSSID3_V1_8814B))
#define BIT_GET_BSSID3_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID3_V1_8814B) & BIT_MASK_BSSID3_V1_8814B)
#define BIT_SET_BSSID3_V1_8814B(x, v) \
(BIT_CLEAR_BSSID3_V1_8814B(x) | BIT_BSSID3_V1_8814B(v))
/* 2 REG_BSSID3_H_8814B (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_H_V1_8814B 0
#define BIT_MASK_BSSID3_H_V1_8814B 0xffff
#define BIT_BSSID3_H_V1_8814B(x) \
(((x) & BIT_MASK_BSSID3_H_V1_8814B) << BIT_SHIFT_BSSID3_H_V1_8814B)
#define BITS_BSSID3_H_V1_8814B \
(BIT_MASK_BSSID3_H_V1_8814B << BIT_SHIFT_BSSID3_H_V1_8814B)
#define BIT_CLEAR_BSSID3_H_V1_8814B(x) ((x) & (~BITS_BSSID3_H_V1_8814B))
#define BIT_GET_BSSID3_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID3_H_V1_8814B) & BIT_MASK_BSSID3_H_V1_8814B)
#define BIT_SET_BSSID3_H_V1_8814B(x, v) \
(BIT_CLEAR_BSSID3_H_V1_8814B(x) | BIT_BSSID3_H_V1_8814B(v))
/* 2 REG_MACID4_8814B (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_V1_8814B 0
#define BIT_MASK_MACID4_V1_8814B 0xffffffffL
#define BIT_MACID4_V1_8814B(x) \
(((x) & BIT_MASK_MACID4_V1_8814B) << BIT_SHIFT_MACID4_V1_8814B)
#define BITS_MACID4_V1_8814B \
(BIT_MASK_MACID4_V1_8814B << BIT_SHIFT_MACID4_V1_8814B)
#define BIT_CLEAR_MACID4_V1_8814B(x) ((x) & (~BITS_MACID4_V1_8814B))
#define BIT_GET_MACID4_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID4_V1_8814B) & BIT_MASK_MACID4_V1_8814B)
#define BIT_SET_MACID4_V1_8814B(x, v) \
(BIT_CLEAR_MACID4_V1_8814B(x) | BIT_MACID4_V1_8814B(v))
/* 2 REG_MACID4_H_8814B (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_H_V1_8814B 0
#define BIT_MASK_MACID4_H_V1_8814B 0xffff
#define BIT_MACID4_H_V1_8814B(x) \
(((x) & BIT_MASK_MACID4_H_V1_8814B) << BIT_SHIFT_MACID4_H_V1_8814B)
#define BITS_MACID4_H_V1_8814B \
(BIT_MASK_MACID4_H_V1_8814B << BIT_SHIFT_MACID4_H_V1_8814B)
#define BIT_CLEAR_MACID4_H_V1_8814B(x) ((x) & (~BITS_MACID4_H_V1_8814B))
#define BIT_GET_MACID4_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_MACID4_H_V1_8814B) & BIT_MASK_MACID4_H_V1_8814B)
#define BIT_SET_MACID4_H_V1_8814B(x, v) \
(BIT_CLEAR_MACID4_H_V1_8814B(x) | BIT_MACID4_H_V1_8814B(v))
/* 2 REG_BSSID4_8814B (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_V1_8814B 0
#define BIT_MASK_BSSID4_V1_8814B 0xffffffffL
#define BIT_BSSID4_V1_8814B(x) \
(((x) & BIT_MASK_BSSID4_V1_8814B) << BIT_SHIFT_BSSID4_V1_8814B)
#define BITS_BSSID4_V1_8814B \
(BIT_MASK_BSSID4_V1_8814B << BIT_SHIFT_BSSID4_V1_8814B)
#define BIT_CLEAR_BSSID4_V1_8814B(x) ((x) & (~BITS_BSSID4_V1_8814B))
#define BIT_GET_BSSID4_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID4_V1_8814B) & BIT_MASK_BSSID4_V1_8814B)
#define BIT_SET_BSSID4_V1_8814B(x, v) \
(BIT_CLEAR_BSSID4_V1_8814B(x) | BIT_BSSID4_V1_8814B(v))
/* 2 REG_BSSID4_H_8814B (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_H_V1_8814B 0
#define BIT_MASK_BSSID4_H_V1_8814B 0xffff
#define BIT_BSSID4_H_V1_8814B(x) \
(((x) & BIT_MASK_BSSID4_H_V1_8814B) << BIT_SHIFT_BSSID4_H_V1_8814B)
#define BITS_BSSID4_H_V1_8814B \
(BIT_MASK_BSSID4_H_V1_8814B << BIT_SHIFT_BSSID4_H_V1_8814B)
#define BIT_CLEAR_BSSID4_H_V1_8814B(x) ((x) & (~BITS_BSSID4_H_V1_8814B))
#define BIT_GET_BSSID4_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID4_H_V1_8814B) & BIT_MASK_BSSID4_H_V1_8814B)
#define BIT_SET_BSSID4_H_V1_8814B(x, v) \
(BIT_CLEAR_BSSID4_H_V1_8814B(x) | BIT_BSSID4_H_V1_8814B(v))
/* 2 REG_NOA_REPORT_8814B */
#define BIT_SHIFT_NOA_RPT_8814B 0
#define BIT_MASK_NOA_RPT_8814B 0xffffffffL
#define BIT_NOA_RPT_8814B(x) \
(((x) & BIT_MASK_NOA_RPT_8814B) << BIT_SHIFT_NOA_RPT_8814B)
#define BITS_NOA_RPT_8814B (BIT_MASK_NOA_RPT_8814B << BIT_SHIFT_NOA_RPT_8814B)
#define BIT_CLEAR_NOA_RPT_8814B(x) ((x) & (~BITS_NOA_RPT_8814B))
#define BIT_GET_NOA_RPT_8814B(x) \
(((x) >> BIT_SHIFT_NOA_RPT_8814B) & BIT_MASK_NOA_RPT_8814B)
#define BIT_SET_NOA_RPT_8814B(x, v) \
(BIT_CLEAR_NOA_RPT_8814B(x) | BIT_NOA_RPT_8814B(v))
/* 2 REG_NOA_REPORT_1_8814B */
#define BIT_SHIFT_NOA_RPT_1_8814B 0
#define BIT_MASK_NOA_RPT_1_8814B 0xffffffffL
#define BIT_NOA_RPT_1_8814B(x) \
(((x) & BIT_MASK_NOA_RPT_1_8814B) << BIT_SHIFT_NOA_RPT_1_8814B)
#define BITS_NOA_RPT_1_8814B \
(BIT_MASK_NOA_RPT_1_8814B << BIT_SHIFT_NOA_RPT_1_8814B)
#define BIT_CLEAR_NOA_RPT_1_8814B(x) ((x) & (~BITS_NOA_RPT_1_8814B))
#define BIT_GET_NOA_RPT_1_8814B(x) \
(((x) >> BIT_SHIFT_NOA_RPT_1_8814B) & BIT_MASK_NOA_RPT_1_8814B)
#define BIT_SET_NOA_RPT_1_8814B(x, v) \
(BIT_CLEAR_NOA_RPT_1_8814B(x) | BIT_NOA_RPT_1_8814B(v))
/* 2 REG_NOA_REPORT_2_8814B */
#define BIT_SHIFT_NOA_RPT_2_8814B 0
#define BIT_MASK_NOA_RPT_2_8814B 0xffffffffL
#define BIT_NOA_RPT_2_8814B(x) \
(((x) & BIT_MASK_NOA_RPT_2_8814B) << BIT_SHIFT_NOA_RPT_2_8814B)
#define BITS_NOA_RPT_2_8814B \
(BIT_MASK_NOA_RPT_2_8814B << BIT_SHIFT_NOA_RPT_2_8814B)
#define BIT_CLEAR_NOA_RPT_2_8814B(x) ((x) & (~BITS_NOA_RPT_2_8814B))
#define BIT_GET_NOA_RPT_2_8814B(x) \
(((x) >> BIT_SHIFT_NOA_RPT_2_8814B) & BIT_MASK_NOA_RPT_2_8814B)
#define BIT_SET_NOA_RPT_2_8814B(x, v) \
(BIT_CLEAR_NOA_RPT_2_8814B(x) | BIT_NOA_RPT_2_8814B(v))
/* 2 REG_NOA_REPORT_3_8814B */
#define BIT_SHIFT_NOA_RPT_3_8814B 0
#define BIT_MASK_NOA_RPT_3_8814B 0xff
#define BIT_NOA_RPT_3_8814B(x) \
(((x) & BIT_MASK_NOA_RPT_3_8814B) << BIT_SHIFT_NOA_RPT_3_8814B)
#define BITS_NOA_RPT_3_8814B \
(BIT_MASK_NOA_RPT_3_8814B << BIT_SHIFT_NOA_RPT_3_8814B)
#define BIT_CLEAR_NOA_RPT_3_8814B(x) ((x) & (~BITS_NOA_RPT_3_8814B))
#define BIT_GET_NOA_RPT_3_8814B(x) \
(((x) >> BIT_SHIFT_NOA_RPT_3_8814B) & BIT_MASK_NOA_RPT_3_8814B)
#define BIT_SET_NOA_RPT_3_8814B(x, v) \
(BIT_CLEAR_NOA_RPT_3_8814B(x) | BIT_NOA_RPT_3_8814B(v))
/* 2 REG_PWRBIT_SETTING_8814B */
#define BIT_CLI3_WMAC_TCRPWRMGT_HWCTL_EN_8814B BIT(15)
#define BIT_CLI3_WMAC_TCRPWRMGT_HWDATA_EN_8814B BIT(14)
#define BIT_CLI3_WMAC_TCRPWRMGT_HWACT_EN_8814B BIT(13)
#define BIT_CLI3_PWR_ST_V1_8814B BIT(12)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWCTL_EN_8814B BIT(11)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWDATA_EN_8814B BIT(10)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWACT_EN_8814B BIT(9)
#define BIT_CLI2_PWR_ST_V1_8814B BIT(8)
#define BIT_CLI1_WMAC_TCRPWRMGT_HWCTL_EN_8814B BIT(7)
#define BIT_CLI1_WMAC_TCRPWRMGT_HWDATA_EN_8814B BIT(6)
#define BIT_CLI1_WMAC_TCRPWRMGT_HWACT_EN_8814B BIT(5)
#define BIT_CLI1_PWR_ST_V1_8814B BIT(4)
#define BIT_CLI0_WMAC_TCRPWRMGT_HWCTL_EN_8814B BIT(3)
#define BIT_CLI0_WMAC_TCRPWRMGT_HWDATA_EN_8814B BIT(2)
#define BIT_CLI0_WMAC_TCRPWRMGT_HWACT_EN_8814B BIT(1)
#define BIT_CLI0_PWR_ST_V1_8814B BIT(0)
/* 2 REG_GENERAL_OPTION_8814B */
#define BIT_FIX_MSDU_TAIL_WR_8814B BIT(12)
#define BIT_FIX_MSDU_SHIFT_8814B BIT(11)
#define BIT_RXFIFO_GNT_CUT_8814B BIT(8)
#define BIT_WMAC_FIX_FIRST_MPDU_WITH_PHYSTS_8814B BIT(5)
#define BIT_DUMMY_RXD_FCS_ERROR_MASK_EN_8814B BIT(4)
#define BIT_PATTERN_MATCH_FIX_EN_8814B BIT(3)
#define BIT_TXSERV_FIELD_SEL_8814B BIT(2)
#define BIT_RXVHT_LEN_SEL_8814B BIT(1)
#define BIT_RXMIC_PROTECT_EN_8814B BIT(0)
/* 2 REG_FWPHYFF_RCR_8814B */
#define BIT_RCR2_AAMSDU_8814B BIT(25)
#define BIT_RCR2_CBSSID_BCN_8814B BIT(24)
#define BIT_RCR2_ACRC32_8814B BIT(23)
#define BIT_RCR2_TA_BCN_8814B BIT(22)
#define BIT_RCR2_CBSSID_DATA_8814B BIT(21)
#define BIT_RCR2_ADD3_8814B BIT(20)
#define BIT_RCR2_AB_8814B BIT(19)
#define BIT_RCR2_AM_8814B BIT(18)
#define BIT_RCR2_APM_8814B BIT(17)
#define BIT_RCR2_AAP_8814B BIT(16)
#define BIT_RCR1_AAMSDU_8814B BIT(9)
#define BIT_RCR1_CBSSID_BCN_8814B BIT(8)
#define BIT_RCR1_ACRC32_8814B BIT(7)
#define BIT_RCR1_TA_BCN_8814B BIT(6)
#define BIT_RCR1_CBSSID_DATA_8814B BIT(5)
#define BIT_RCR1_ADD3_8814B BIT(4)
#define BIT_RCR1_AB_8814B BIT(3)
#define BIT_RCR1_AM_8814B BIT(2)
#define BIT_RCR1_APM_8814B BIT(1)
#define BIT_RCR1_AAP_8814B BIT(0)
/* 2 REG_ADDRCAM_WRITE_CONTENT_8814B */
#define BIT_SHIFT_ADDRCAM_WDATA_8814B 0
#define BIT_MASK_ADDRCAM_WDATA_8814B 0xffffffffL
#define BIT_ADDRCAM_WDATA_8814B(x) \
(((x) & BIT_MASK_ADDRCAM_WDATA_8814B) << BIT_SHIFT_ADDRCAM_WDATA_8814B)
#define BITS_ADDRCAM_WDATA_8814B \
(BIT_MASK_ADDRCAM_WDATA_8814B << BIT_SHIFT_ADDRCAM_WDATA_8814B)
#define BIT_CLEAR_ADDRCAM_WDATA_8814B(x) ((x) & (~BITS_ADDRCAM_WDATA_8814B))
#define BIT_GET_ADDRCAM_WDATA_8814B(x) \
(((x) >> BIT_SHIFT_ADDRCAM_WDATA_8814B) & BIT_MASK_ADDRCAM_WDATA_8814B)
#define BIT_SET_ADDRCAM_WDATA_8814B(x, v) \
(BIT_CLEAR_ADDRCAM_WDATA_8814B(x) | BIT_ADDRCAM_WDATA_8814B(v))
/* 2 REG_ADDRCAM_READ_CONTENT_8814B */
#define BIT_SHIFT_ADDRCAM_RDATA_8814B 0
#define BIT_MASK_ADDRCAM_RDATA_8814B 0xffffffffL
#define BIT_ADDRCAM_RDATA_8814B(x) \
(((x) & BIT_MASK_ADDRCAM_RDATA_8814B) << BIT_SHIFT_ADDRCAM_RDATA_8814B)
#define BITS_ADDRCAM_RDATA_8814B \
(BIT_MASK_ADDRCAM_RDATA_8814B << BIT_SHIFT_ADDRCAM_RDATA_8814B)
#define BIT_CLEAR_ADDRCAM_RDATA_8814B(x) ((x) & (~BITS_ADDRCAM_RDATA_8814B))
#define BIT_GET_ADDRCAM_RDATA_8814B(x) \
(((x) >> BIT_SHIFT_ADDRCAM_RDATA_8814B) & BIT_MASK_ADDRCAM_RDATA_8814B)
#define BIT_SET_ADDRCAM_RDATA_8814B(x, v) \
(BIT_CLEAR_ADDRCAM_RDATA_8814B(x) | BIT_ADDRCAM_RDATA_8814B(v))
/* 2 REG_ADDRCAM_CFG_8814B */
#define BIT_ADDRCAM_POLL_8814B BIT(31)
#define BIT__ADDRCAM_WT_EN_8814B BIT(30)
#define BIT_CLRADDRCAM_8814B BIT(29)
#define BIT_SHIFT__ADDRCAM_ADDR_8814B 8
#define BIT_MASK__ADDRCAM_ADDR_8814B 0x3ff
#define BIT__ADDRCAM_ADDR_8814B(x) \
(((x) & BIT_MASK__ADDRCAM_ADDR_8814B) << BIT_SHIFT__ADDRCAM_ADDR_8814B)
#define BITS__ADDRCAM_ADDR_8814B \
(BIT_MASK__ADDRCAM_ADDR_8814B << BIT_SHIFT__ADDRCAM_ADDR_8814B)
#define BIT_CLEAR__ADDRCAM_ADDR_8814B(x) ((x) & (~BITS__ADDRCAM_ADDR_8814B))
#define BIT_GET__ADDRCAM_ADDR_8814B(x) \
(((x) >> BIT_SHIFT__ADDRCAM_ADDR_8814B) & BIT_MASK__ADDRCAM_ADDR_8814B)
#define BIT_SET__ADDRCAM_ADDR_8814B(x, v) \
(BIT_CLEAR__ADDRCAM_ADDR_8814B(x) | BIT__ADDRCAM_ADDR_8814B(v))
#define BIT_SHIFT_ADDRCAM_RANGE_8814B 0
#define BIT_MASK_ADDRCAM_RANGE_8814B 0x7f
#define BIT_ADDRCAM_RANGE_8814B(x) \
(((x) & BIT_MASK_ADDRCAM_RANGE_8814B) << BIT_SHIFT_ADDRCAM_RANGE_8814B)
#define BITS_ADDRCAM_RANGE_8814B \
(BIT_MASK_ADDRCAM_RANGE_8814B << BIT_SHIFT_ADDRCAM_RANGE_8814B)
#define BIT_CLEAR_ADDRCAM_RANGE_8814B(x) ((x) & (~BITS_ADDRCAM_RANGE_8814B))
#define BIT_GET_ADDRCAM_RANGE_8814B(x) \
(((x) >> BIT_SHIFT_ADDRCAM_RANGE_8814B) & BIT_MASK_ADDRCAM_RANGE_8814B)
#define BIT_SET_ADDRCAM_RANGE_8814B(x, v) \
(BIT_CLEAR_ADDRCAM_RANGE_8814B(x) | BIT_ADDRCAM_RANGE_8814B(v))
/* 2 REG_CSI_RRSR_8814B */
#define BIT_CSI_LDPC_EN_8814B BIT(29)
#define BIT_CSI_STBC_EN_8814B BIT(28)
#define BIT_SHIFT_CSI_RRSC_BITMAP_8814B 4
#define BIT_MASK_CSI_RRSC_BITMAP_8814B 0xffffff
#define BIT_CSI_RRSC_BITMAP_8814B(x) \
(((x) & BIT_MASK_CSI_RRSC_BITMAP_8814B) \
<< BIT_SHIFT_CSI_RRSC_BITMAP_8814B)
#define BITS_CSI_RRSC_BITMAP_8814B \
(BIT_MASK_CSI_RRSC_BITMAP_8814B << BIT_SHIFT_CSI_RRSC_BITMAP_8814B)
#define BIT_CLEAR_CSI_RRSC_BITMAP_8814B(x) ((x) & (~BITS_CSI_RRSC_BITMAP_8814B))
#define BIT_GET_CSI_RRSC_BITMAP_8814B(x) \
(((x) >> BIT_SHIFT_CSI_RRSC_BITMAP_8814B) & \
BIT_MASK_CSI_RRSC_BITMAP_8814B)
#define BIT_SET_CSI_RRSC_BITMAP_8814B(x, v) \
(BIT_CLEAR_CSI_RRSC_BITMAP_8814B(x) | BIT_CSI_RRSC_BITMAP_8814B(v))
#define BIT_SHIFT_OFDM_LEN_TH_8814B 0
#define BIT_MASK_OFDM_LEN_TH_8814B 0xf
#define BIT_OFDM_LEN_TH_8814B(x) \
(((x) & BIT_MASK_OFDM_LEN_TH_8814B) << BIT_SHIFT_OFDM_LEN_TH_8814B)
#define BITS_OFDM_LEN_TH_8814B \
(BIT_MASK_OFDM_LEN_TH_8814B << BIT_SHIFT_OFDM_LEN_TH_8814B)
#define BIT_CLEAR_OFDM_LEN_TH_8814B(x) ((x) & (~BITS_OFDM_LEN_TH_8814B))
#define BIT_GET_OFDM_LEN_TH_8814B(x) \
(((x) >> BIT_SHIFT_OFDM_LEN_TH_8814B) & BIT_MASK_OFDM_LEN_TH_8814B)
#define BIT_SET_OFDM_LEN_TH_8814B(x, v) \
(BIT_CLEAR_OFDM_LEN_TH_8814B(x) | BIT_OFDM_LEN_TH_8814B(v))
/* 2 REG_MU_BF_OPTION_8814B */
#define BIT_WMAC_RESP_NONSTA1_DIS_8814B BIT(7)
#define BIT_WMAC_TXMU_ACKPOLICY_EN_8814B BIT(6)
#define BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8814B 4
#define BIT_MASK_WMAC_TXMU_ACKPOLICY_8814B 0x3
#define BIT_WMAC_TXMU_ACKPOLICY_8814B(x) \
(((x) & BIT_MASK_WMAC_TXMU_ACKPOLICY_8814B) \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8814B)
#define BITS_WMAC_TXMU_ACKPOLICY_8814B \
(BIT_MASK_WMAC_TXMU_ACKPOLICY_8814B \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8814B)
#define BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8814B(x) \
((x) & (~BITS_WMAC_TXMU_ACKPOLICY_8814B))
#define BIT_GET_WMAC_TXMU_ACKPOLICY_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8814B) & \
BIT_MASK_WMAC_TXMU_ACKPOLICY_8814B)
#define BIT_SET_WMAC_TXMU_ACKPOLICY_8814B(x, v) \
(BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8814B(x) | \
BIT_WMAC_TXMU_ACKPOLICY_8814B(v))
#define BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8814B 1
#define BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8814B 0x7
#define BIT_WMAC_MU_BFEE_PORT_SEL_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8814B)
#define BITS_WMAC_MU_BFEE_PORT_SEL_8814B \
(BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8814B \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE_PORT_SEL_8814B))
#define BIT_GET_WMAC_MU_BFEE_PORT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8814B) & \
BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8814B)
#define BIT_SET_WMAC_MU_BFEE_PORT_SEL_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8814B(x) | \
BIT_WMAC_MU_BFEE_PORT_SEL_8814B(v))
#define BIT_WMAC_MU_BFEE_DIS_8814B BIT(0)
/* 2 REG_WMAC_PAUSE_BB_CLR_TH_8814B */
#define BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8814B 0
#define BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8814B 0xff
#define BIT_WMAC_PAUSE_BB_CLR_TH_8814B(x) \
(((x) & BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8814B) \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8814B)
#define BITS_WMAC_PAUSE_BB_CLR_TH_8814B \
(BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8814B \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8814B)
#define BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8814B(x) \
((x) & (~BITS_WMAC_PAUSE_BB_CLR_TH_8814B))
#define BIT_GET_WMAC_PAUSE_BB_CLR_TH_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8814B) & \
BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8814B)
#define BIT_SET_WMAC_PAUSE_BB_CLR_TH_8814B(x, v) \
(BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8814B(x) | \
BIT_WMAC_PAUSE_BB_CLR_TH_8814B(v))
/* 2 REG_WMAC_MULBK_BUF_8814B */
#define BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8814B 0
#define BIT_MASK_WMAC_MULBK_PAGE_SIZE_8814B 0xff
#define BIT_WMAC_MULBK_PAGE_SIZE_8814B(x) \
(((x) & BIT_MASK_WMAC_MULBK_PAGE_SIZE_8814B) \
<< BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8814B)
#define BITS_WMAC_MULBK_PAGE_SIZE_8814B \
(BIT_MASK_WMAC_MULBK_PAGE_SIZE_8814B \
<< BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8814B)
#define BIT_CLEAR_WMAC_MULBK_PAGE_SIZE_8814B(x) \
((x) & (~BITS_WMAC_MULBK_PAGE_SIZE_8814B))
#define BIT_GET_WMAC_MULBK_PAGE_SIZE_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8814B) & \
BIT_MASK_WMAC_MULBK_PAGE_SIZE_8814B)
#define BIT_SET_WMAC_MULBK_PAGE_SIZE_8814B(x, v) \
(BIT_CLEAR_WMAC_MULBK_PAGE_SIZE_8814B(x) | \
BIT_WMAC_MULBK_PAGE_SIZE_8814B(v))
/* 2 REG_WMAC_MU_OPTION_8814B */
#define BIT_NOCHK_BFPOLL_BMP_8814B BIT(7)
/* 2 REG_WMAC_MU_BF_CTL_8814B */
#define BIT_WMAC_INVLD_BFPRT_CHK_8814B BIT(15)
#define BIT_WMAC_RETXBFRPTSEQ_UPD_8814B BIT(14)
#define BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8814B 12
#define BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8814B 0x3
#define BIT_WMAC_MU_BFRPTSEG_SEL_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8814B) \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8814B)
#define BITS_WMAC_MU_BFRPTSEG_SEL_8814B \
(BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8814B \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8814B)
#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8814B(x) \
((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL_8814B))
#define BIT_GET_WMAC_MU_BFRPTSEG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8814B) & \
BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8814B)
#define BIT_SET_WMAC_MU_BFRPTSEG_SEL_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8814B(x) | \
BIT_WMAC_MU_BFRPTSEG_SEL_8814B(v))
#define BIT_SHIFT_WMAC_MU_BF_MYAID_8814B 0
#define BIT_MASK_WMAC_MU_BF_MYAID_8814B 0xfff
#define BIT_WMAC_MU_BF_MYAID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BF_MYAID_8814B) \
<< BIT_SHIFT_WMAC_MU_BF_MYAID_8814B)
#define BITS_WMAC_MU_BF_MYAID_8814B \
(BIT_MASK_WMAC_MU_BF_MYAID_8814B << BIT_SHIFT_WMAC_MU_BF_MYAID_8814B)
#define BIT_CLEAR_WMAC_MU_BF_MYAID_8814B(x) \
((x) & (~BITS_WMAC_MU_BF_MYAID_8814B))
#define BIT_GET_WMAC_MU_BF_MYAID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BF_MYAID_8814B) & \
BIT_MASK_WMAC_MU_BF_MYAID_8814B)
#define BIT_SET_WMAC_MU_BF_MYAID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BF_MYAID_8814B(x) | BIT_WMAC_MU_BF_MYAID_8814B(v))
/* 2 REG_WMAC_MU_BFRPT_PARA_8814B */
#define BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8814B 13
#define BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8814B 0x7
#define BIT_BFRPT_PARA_USERID_SEL_V1_8814B(x) \
(((x) & BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8814B) \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8814B)
#define BITS_BFRPT_PARA_USERID_SEL_V1_8814B \
(BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8814B \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8814B)
#define BIT_CLEAR_BFRPT_PARA_USERID_SEL_V1_8814B(x) \
((x) & (~BITS_BFRPT_PARA_USERID_SEL_V1_8814B))
#define BIT_GET_BFRPT_PARA_USERID_SEL_V1_8814B(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8814B) & \
BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8814B)
#define BIT_SET_BFRPT_PARA_USERID_SEL_V1_8814B(x, v) \
(BIT_CLEAR_BFRPT_PARA_USERID_SEL_V1_8814B(x) | \
BIT_BFRPT_PARA_USERID_SEL_V1_8814B(v))
#define BIT_SHIFT_BFRPT_PARA_V1_8814B 0
#define BIT_MASK_BFRPT_PARA_V1_8814B 0x1fff
#define BIT_BFRPT_PARA_V1_8814B(x) \
(((x) & BIT_MASK_BFRPT_PARA_V1_8814B) << BIT_SHIFT_BFRPT_PARA_V1_8814B)
#define BITS_BFRPT_PARA_V1_8814B \
(BIT_MASK_BFRPT_PARA_V1_8814B << BIT_SHIFT_BFRPT_PARA_V1_8814B)
#define BIT_CLEAR_BFRPT_PARA_V1_8814B(x) ((x) & (~BITS_BFRPT_PARA_V1_8814B))
#define BIT_GET_BFRPT_PARA_V1_8814B(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_V1_8814B) & BIT_MASK_BFRPT_PARA_V1_8814B)
#define BIT_SET_BFRPT_PARA_V1_8814B(x, v) \
(BIT_CLEAR_BFRPT_PARA_V1_8814B(x) | BIT_BFRPT_PARA_V1_8814B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2_8814B */
#define BIT_STATUS_BFEE2_8814B BIT(10)
#define BIT_WMAC_MU_BFEE2_EN_8814B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE2_AID_8814B 0
#define BIT_MASK_WMAC_MU_BFEE2_AID_8814B 0x1ff
#define BIT_WMAC_MU_BFEE2_AID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE2_AID_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE2_AID_8814B)
#define BITS_WMAC_MU_BFEE2_AID_8814B \
(BIT_MASK_WMAC_MU_BFEE2_AID_8814B << BIT_SHIFT_WMAC_MU_BFEE2_AID_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE2_AID_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE2_AID_8814B))
#define BIT_GET_WMAC_MU_BFEE2_AID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE2_AID_8814B) & \
BIT_MASK_WMAC_MU_BFEE2_AID_8814B)
#define BIT_SET_WMAC_MU_BFEE2_AID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE2_AID_8814B(x) | BIT_WMAC_MU_BFEE2_AID_8814B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3_8814B */
#define BIT_STATUS_BFEE3_8814B BIT(10)
#define BIT_WMAC_MU_BFEE3_EN_8814B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE3_AID_8814B 0
#define BIT_MASK_WMAC_MU_BFEE3_AID_8814B 0x1ff
#define BIT_WMAC_MU_BFEE3_AID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE3_AID_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE3_AID_8814B)
#define BITS_WMAC_MU_BFEE3_AID_8814B \
(BIT_MASK_WMAC_MU_BFEE3_AID_8814B << BIT_SHIFT_WMAC_MU_BFEE3_AID_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE3_AID_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE3_AID_8814B))
#define BIT_GET_WMAC_MU_BFEE3_AID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE3_AID_8814B) & \
BIT_MASK_WMAC_MU_BFEE3_AID_8814B)
#define BIT_SET_WMAC_MU_BFEE3_AID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE3_AID_8814B(x) | BIT_WMAC_MU_BFEE3_AID_8814B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE4_8814B */
#define BIT_STATUS_BFEE4_8814B BIT(10)
#define BIT_WMAC_MU_BFEE4_EN_8814B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE4_AID_8814B 0
#define BIT_MASK_WMAC_MU_BFEE4_AID_8814B 0x1ff
#define BIT_WMAC_MU_BFEE4_AID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE4_AID_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE4_AID_8814B)
#define BITS_WMAC_MU_BFEE4_AID_8814B \
(BIT_MASK_WMAC_MU_BFEE4_AID_8814B << BIT_SHIFT_WMAC_MU_BFEE4_AID_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE4_AID_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE4_AID_8814B))
#define BIT_GET_WMAC_MU_BFEE4_AID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE4_AID_8814B) & \
BIT_MASK_WMAC_MU_BFEE4_AID_8814B)
#define BIT_SET_WMAC_MU_BFEE4_AID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE4_AID_8814B(x) | BIT_WMAC_MU_BFEE4_AID_8814B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5_8814B */
#define BIT_BIT_STATUS_BFEE5_8814B BIT(10)
#define BIT_WMAC_MU_BFEE5_EN_8814B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE5_AID_8814B 0
#define BIT_MASK_WMAC_MU_BFEE5_AID_8814B 0x1ff
#define BIT_WMAC_MU_BFEE5_AID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE5_AID_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE5_AID_8814B)
#define BITS_WMAC_MU_BFEE5_AID_8814B \
(BIT_MASK_WMAC_MU_BFEE5_AID_8814B << BIT_SHIFT_WMAC_MU_BFEE5_AID_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE5_AID_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE5_AID_8814B))
#define BIT_GET_WMAC_MU_BFEE5_AID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE5_AID_8814B) & \
BIT_MASK_WMAC_MU_BFEE5_AID_8814B)
#define BIT_SET_WMAC_MU_BFEE5_AID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE5_AID_8814B(x) | BIT_WMAC_MU_BFEE5_AID_8814B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE6_8814B */
#define BIT_STATUS_BFEE6_8814B BIT(10)
#define BIT_WMAC_MU_BFEE6_EN_8814B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE6_AID_8814B 0
#define BIT_MASK_WMAC_MU_BFEE6_AID_8814B 0x1ff
#define BIT_WMAC_MU_BFEE6_AID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE6_AID_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE6_AID_8814B)
#define BITS_WMAC_MU_BFEE6_AID_8814B \
(BIT_MASK_WMAC_MU_BFEE6_AID_8814B << BIT_SHIFT_WMAC_MU_BFEE6_AID_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE6_AID_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE6_AID_8814B))
#define BIT_GET_WMAC_MU_BFEE6_AID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE6_AID_8814B) & \
BIT_MASK_WMAC_MU_BFEE6_AID_8814B)
#define BIT_SET_WMAC_MU_BFEE6_AID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE6_AID_8814B(x) | BIT_WMAC_MU_BFEE6_AID_8814B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7_8814B */
#define BIT_STATUS_BFEE7_8814B BIT(10)
#define BIT_WMAC_MU_BFEE7_EN_8814B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE7_AID_8814B 0
#define BIT_MASK_WMAC_MU_BFEE7_AID_8814B 0x1ff
#define BIT_WMAC_MU_BFEE7_AID_8814B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE7_AID_8814B) \
<< BIT_SHIFT_WMAC_MU_BFEE7_AID_8814B)
#define BITS_WMAC_MU_BFEE7_AID_8814B \
(BIT_MASK_WMAC_MU_BFEE7_AID_8814B << BIT_SHIFT_WMAC_MU_BFEE7_AID_8814B)
#define BIT_CLEAR_WMAC_MU_BFEE7_AID_8814B(x) \
((x) & (~BITS_WMAC_MU_BFEE7_AID_8814B))
#define BIT_GET_WMAC_MU_BFEE7_AID_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE7_AID_8814B) & \
BIT_MASK_WMAC_MU_BFEE7_AID_8814B)
#define BIT_SET_WMAC_MU_BFEE7_AID_8814B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE7_AID_8814B(x) | BIT_WMAC_MU_BFEE7_AID_8814B(v))
/* 2 REG_WMAC_BB_STOP_RX_COUNTER_8814B */
#define BIT_RST_ALL_COUNTER_8814B BIT(31)
#define BIT_SHIFT_ABORT_RX_VBON_COUNTER_8814B 16
#define BIT_MASK_ABORT_RX_VBON_COUNTER_8814B 0xff
#define BIT_ABORT_RX_VBON_COUNTER_8814B(x) \
(((x) & BIT_MASK_ABORT_RX_VBON_COUNTER_8814B) \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8814B)
#define BITS_ABORT_RX_VBON_COUNTER_8814B \
(BIT_MASK_ABORT_RX_VBON_COUNTER_8814B \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8814B)
#define BIT_CLEAR_ABORT_RX_VBON_COUNTER_8814B(x) \
((x) & (~BITS_ABORT_RX_VBON_COUNTER_8814B))
#define BIT_GET_ABORT_RX_VBON_COUNTER_8814B(x) \
(((x) >> BIT_SHIFT_ABORT_RX_VBON_COUNTER_8814B) & \
BIT_MASK_ABORT_RX_VBON_COUNTER_8814B)
#define BIT_SET_ABORT_RX_VBON_COUNTER_8814B(x, v) \
(BIT_CLEAR_ABORT_RX_VBON_COUNTER_8814B(x) | \
BIT_ABORT_RX_VBON_COUNTER_8814B(v))
#define BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8814B 8
#define BIT_MASK_ABORT_RX_RDRDY_COUNTER_8814B 0xff
#define BIT_ABORT_RX_RDRDY_COUNTER_8814B(x) \
(((x) & BIT_MASK_ABORT_RX_RDRDY_COUNTER_8814B) \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8814B)
#define BITS_ABORT_RX_RDRDY_COUNTER_8814B \
(BIT_MASK_ABORT_RX_RDRDY_COUNTER_8814B \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8814B)
#define BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8814B(x) \
((x) & (~BITS_ABORT_RX_RDRDY_COUNTER_8814B))
#define BIT_GET_ABORT_RX_RDRDY_COUNTER_8814B(x) \
(((x) >> BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8814B) & \
BIT_MASK_ABORT_RX_RDRDY_COUNTER_8814B)
#define BIT_SET_ABORT_RX_RDRDY_COUNTER_8814B(x, v) \
(BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8814B(x) | \
BIT_ABORT_RX_RDRDY_COUNTER_8814B(v))
#define BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8814B 0
#define BIT_MASK_VBON_EARLY_FALLING_COUNTER_8814B 0xff
#define BIT_VBON_EARLY_FALLING_COUNTER_8814B(x) \
(((x) & BIT_MASK_VBON_EARLY_FALLING_COUNTER_8814B) \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8814B)
#define BITS_VBON_EARLY_FALLING_COUNTER_8814B \
(BIT_MASK_VBON_EARLY_FALLING_COUNTER_8814B \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8814B)
#define BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8814B(x) \
((x) & (~BITS_VBON_EARLY_FALLING_COUNTER_8814B))
#define BIT_GET_VBON_EARLY_FALLING_COUNTER_8814B(x) \
(((x) >> BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8814B) & \
BIT_MASK_VBON_EARLY_FALLING_COUNTER_8814B)
#define BIT_SET_VBON_EARLY_FALLING_COUNTER_8814B(x, v) \
(BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8814B(x) | \
BIT_VBON_EARLY_FALLING_COUNTER_8814B(v))
/* 2 REG_WMAC_PLCP_MONITOR_8814B */
#define BIT_WMAC_PLCP_TRX_SEL_8814B BIT(31)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8814B 28
#define BIT_MASK_WMAC_PLCP_RDSIG_SEL_8814B 0x7
#define BIT_WMAC_PLCP_RDSIG_SEL_8814B(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_SEL_8814B) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8814B)
#define BITS_WMAC_PLCP_RDSIG_SEL_8814B \
(BIT_MASK_WMAC_PLCP_RDSIG_SEL_8814B \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8814B)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8814B(x) \
((x) & (~BITS_WMAC_PLCP_RDSIG_SEL_8814B))
#define BIT_GET_WMAC_PLCP_RDSIG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8814B) & \
BIT_MASK_WMAC_PLCP_RDSIG_SEL_8814B)
#define BIT_SET_WMAC_PLCP_RDSIG_SEL_8814B(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8814B(x) | \
BIT_WMAC_PLCP_RDSIG_SEL_8814B(v))
#define BIT_SHIFT_WMAC_RATE_IDX_8814B 24
#define BIT_MASK_WMAC_RATE_IDX_8814B 0xf
#define BIT_WMAC_RATE_IDX_8814B(x) \
(((x) & BIT_MASK_WMAC_RATE_IDX_8814B) << BIT_SHIFT_WMAC_RATE_IDX_8814B)
#define BITS_WMAC_RATE_IDX_8814B \
(BIT_MASK_WMAC_RATE_IDX_8814B << BIT_SHIFT_WMAC_RATE_IDX_8814B)
#define BIT_CLEAR_WMAC_RATE_IDX_8814B(x) ((x) & (~BITS_WMAC_RATE_IDX_8814B))
#define BIT_GET_WMAC_RATE_IDX_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_RATE_IDX_8814B) & BIT_MASK_WMAC_RATE_IDX_8814B)
#define BIT_SET_WMAC_RATE_IDX_8814B(x, v) \
(BIT_CLEAR_WMAC_RATE_IDX_8814B(x) | BIT_WMAC_RATE_IDX_8814B(v))
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8814B 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8814B 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8814B(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8814B) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8814B)
#define BITS_WMAC_PLCP_RDSIG_8814B \
(BIT_MASK_WMAC_PLCP_RDSIG_8814B << BIT_SHIFT_WMAC_PLCP_RDSIG_8814B)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8814B(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8814B))
#define BIT_GET_WMAC_PLCP_RDSIG_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8814B) & \
BIT_MASK_WMAC_PLCP_RDSIG_8814B)
#define BIT_SET_WMAC_PLCP_RDSIG_8814B(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8814B(x) | BIT_WMAC_PLCP_RDSIG_8814B(v))
/* 2 REG_WMAC_DEBUG_PORT_8814B */
#define BIT_SHIFT_WMAC_DEBUG_PORT_8814B 0
#define BIT_MASK_WMAC_DEBUG_PORT_8814B 0xffffffffL
#define BIT_WMAC_DEBUG_PORT_8814B(x) \
(((x) & BIT_MASK_WMAC_DEBUG_PORT_8814B) \
<< BIT_SHIFT_WMAC_DEBUG_PORT_8814B)
#define BITS_WMAC_DEBUG_PORT_8814B \
(BIT_MASK_WMAC_DEBUG_PORT_8814B << BIT_SHIFT_WMAC_DEBUG_PORT_8814B)
#define BIT_CLEAR_WMAC_DEBUG_PORT_8814B(x) ((x) & (~BITS_WMAC_DEBUG_PORT_8814B))
#define BIT_GET_WMAC_DEBUG_PORT_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_DEBUG_PORT_8814B) & \
BIT_MASK_WMAC_DEBUG_PORT_8814B)
#define BIT_SET_WMAC_DEBUG_PORT_8814B(x, v) \
(BIT_CLEAR_WMAC_DEBUG_PORT_8814B(x) | BIT_WMAC_DEBUG_PORT_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_TRANSMIT_ADDRSS_0_8814B (TA0 REGISTER) */
#define BIT_SHIFT_TA0_V1_8814B 0
#define BIT_MASK_TA0_V1_8814B 0xffffffffL
#define BIT_TA0_V1_8814B(x) \
(((x) & BIT_MASK_TA0_V1_8814B) << BIT_SHIFT_TA0_V1_8814B)
#define BITS_TA0_V1_8814B (BIT_MASK_TA0_V1_8814B << BIT_SHIFT_TA0_V1_8814B)
#define BIT_CLEAR_TA0_V1_8814B(x) ((x) & (~BITS_TA0_V1_8814B))
#define BIT_GET_TA0_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA0_V1_8814B) & BIT_MASK_TA0_V1_8814B)
#define BIT_SET_TA0_V1_8814B(x, v) \
(BIT_CLEAR_TA0_V1_8814B(x) | BIT_TA0_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_0_H_8814B (TA0 REGISTER) */
#define BIT_SHIFT_TA0_H_V1_8814B 0
#define BIT_MASK_TA0_H_V1_8814B 0xffff
#define BIT_TA0_H_V1_8814B(x) \
(((x) & BIT_MASK_TA0_H_V1_8814B) << BIT_SHIFT_TA0_H_V1_8814B)
#define BITS_TA0_H_V1_8814B \
(BIT_MASK_TA0_H_V1_8814B << BIT_SHIFT_TA0_H_V1_8814B)
#define BIT_CLEAR_TA0_H_V1_8814B(x) ((x) & (~BITS_TA0_H_V1_8814B))
#define BIT_GET_TA0_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA0_H_V1_8814B) & BIT_MASK_TA0_H_V1_8814B)
#define BIT_SET_TA0_H_V1_8814B(x, v) \
(BIT_CLEAR_TA0_H_V1_8814B(x) | BIT_TA0_H_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_1_8814B (TA1 REGISTER) */
#define BIT_SHIFT_TA1_V1_8814B 0
#define BIT_MASK_TA1_V1_8814B 0xffffffffL
#define BIT_TA1_V1_8814B(x) \
(((x) & BIT_MASK_TA1_V1_8814B) << BIT_SHIFT_TA1_V1_8814B)
#define BITS_TA1_V1_8814B (BIT_MASK_TA1_V1_8814B << BIT_SHIFT_TA1_V1_8814B)
#define BIT_CLEAR_TA1_V1_8814B(x) ((x) & (~BITS_TA1_V1_8814B))
#define BIT_GET_TA1_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA1_V1_8814B) & BIT_MASK_TA1_V1_8814B)
#define BIT_SET_TA1_V1_8814B(x, v) \
(BIT_CLEAR_TA1_V1_8814B(x) | BIT_TA1_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_1_H_8814B (TA1 REGISTER) */
#define BIT_SHIFT_TA1_H_V1_8814B 0
#define BIT_MASK_TA1_H_V1_8814B 0xffff
#define BIT_TA1_H_V1_8814B(x) \
(((x) & BIT_MASK_TA1_H_V1_8814B) << BIT_SHIFT_TA1_H_V1_8814B)
#define BITS_TA1_H_V1_8814B \
(BIT_MASK_TA1_H_V1_8814B << BIT_SHIFT_TA1_H_V1_8814B)
#define BIT_CLEAR_TA1_H_V1_8814B(x) ((x) & (~BITS_TA1_H_V1_8814B))
#define BIT_GET_TA1_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA1_H_V1_8814B) & BIT_MASK_TA1_H_V1_8814B)
#define BIT_SET_TA1_H_V1_8814B(x, v) \
(BIT_CLEAR_TA1_H_V1_8814B(x) | BIT_TA1_H_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_2_8814B (TA2 REGISTER) */
#define BIT_SHIFT_TA2_V1_8814B 0
#define BIT_MASK_TA2_V1_8814B 0xffffffffL
#define BIT_TA2_V1_8814B(x) \
(((x) & BIT_MASK_TA2_V1_8814B) << BIT_SHIFT_TA2_V1_8814B)
#define BITS_TA2_V1_8814B (BIT_MASK_TA2_V1_8814B << BIT_SHIFT_TA2_V1_8814B)
#define BIT_CLEAR_TA2_V1_8814B(x) ((x) & (~BITS_TA2_V1_8814B))
#define BIT_GET_TA2_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA2_V1_8814B) & BIT_MASK_TA2_V1_8814B)
#define BIT_SET_TA2_V1_8814B(x, v) \
(BIT_CLEAR_TA2_V1_8814B(x) | BIT_TA2_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_2_H_8814B (TA2 REGISTER) */
#define BIT_SHIFT_TA2_H_V1_8814B 0
#define BIT_MASK_TA2_H_V1_8814B 0xffff
#define BIT_TA2_H_V1_8814B(x) \
(((x) & BIT_MASK_TA2_H_V1_8814B) << BIT_SHIFT_TA2_H_V1_8814B)
#define BITS_TA2_H_V1_8814B \
(BIT_MASK_TA2_H_V1_8814B << BIT_SHIFT_TA2_H_V1_8814B)
#define BIT_CLEAR_TA2_H_V1_8814B(x) ((x) & (~BITS_TA2_H_V1_8814B))
#define BIT_GET_TA2_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA2_H_V1_8814B) & BIT_MASK_TA2_H_V1_8814B)
#define BIT_SET_TA2_H_V1_8814B(x, v) \
(BIT_CLEAR_TA2_H_V1_8814B(x) | BIT_TA2_H_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_3_8814B (TA3 REGISTER) */
#define BIT_SHIFT_TA2_V1_8814B 0
#define BIT_MASK_TA2_V1_8814B 0xffffffffL
#define BIT_TA2_V1_8814B(x) \
(((x) & BIT_MASK_TA2_V1_8814B) << BIT_SHIFT_TA2_V1_8814B)
#define BITS_TA2_V1_8814B (BIT_MASK_TA2_V1_8814B << BIT_SHIFT_TA2_V1_8814B)
#define BIT_CLEAR_TA2_V1_8814B(x) ((x) & (~BITS_TA2_V1_8814B))
#define BIT_GET_TA2_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA2_V1_8814B) & BIT_MASK_TA2_V1_8814B)
#define BIT_SET_TA2_V1_8814B(x, v) \
(BIT_CLEAR_TA2_V1_8814B(x) | BIT_TA2_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_3_H_8814B (TA3 REGISTER) */
#define BIT_SHIFT_TA3_H_V1_8814B 0
#define BIT_MASK_TA3_H_V1_8814B 0xffff
#define BIT_TA3_H_V1_8814B(x) \
(((x) & BIT_MASK_TA3_H_V1_8814B) << BIT_SHIFT_TA3_H_V1_8814B)
#define BITS_TA3_H_V1_8814B \
(BIT_MASK_TA3_H_V1_8814B << BIT_SHIFT_TA3_H_V1_8814B)
#define BIT_CLEAR_TA3_H_V1_8814B(x) ((x) & (~BITS_TA3_H_V1_8814B))
#define BIT_GET_TA3_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA3_H_V1_8814B) & BIT_MASK_TA3_H_V1_8814B)
#define BIT_SET_TA3_H_V1_8814B(x, v) \
(BIT_CLEAR_TA3_H_V1_8814B(x) | BIT_TA3_H_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_4_8814B (TA4 REGISTER) */
#define BIT_SHIFT_TA4_V1_8814B 0
#define BIT_MASK_TA4_V1_8814B 0xffffffffL
#define BIT_TA4_V1_8814B(x) \
(((x) & BIT_MASK_TA4_V1_8814B) << BIT_SHIFT_TA4_V1_8814B)
#define BITS_TA4_V1_8814B (BIT_MASK_TA4_V1_8814B << BIT_SHIFT_TA4_V1_8814B)
#define BIT_CLEAR_TA4_V1_8814B(x) ((x) & (~BITS_TA4_V1_8814B))
#define BIT_GET_TA4_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA4_V1_8814B) & BIT_MASK_TA4_V1_8814B)
#define BIT_SET_TA4_V1_8814B(x, v) \
(BIT_CLEAR_TA4_V1_8814B(x) | BIT_TA4_V1_8814B(v))
/* 2 REG_TRANSMIT_ADDRSS_4_H_8814B (TA4 REGISTER) */
#define BIT_SHIFT_TA4_H_V1_8814B 0
#define BIT_MASK_TA4_H_V1_8814B 0xffff
#define BIT_TA4_H_V1_8814B(x) \
(((x) & BIT_MASK_TA4_H_V1_8814B) << BIT_SHIFT_TA4_H_V1_8814B)
#define BITS_TA4_H_V1_8814B \
(BIT_MASK_TA4_H_V1_8814B << BIT_SHIFT_TA4_H_V1_8814B)
#define BIT_CLEAR_TA4_H_V1_8814B(x) ((x) & (~BITS_TA4_H_V1_8814B))
#define BIT_GET_TA4_H_V1_8814B(x) \
(((x) >> BIT_SHIFT_TA4_H_V1_8814B) & BIT_MASK_TA4_H_V1_8814B)
#define BIT_SET_TA4_H_V1_8814B(x, v) \
(BIT_CLEAR_TA4_H_V1_8814B(x) | BIT_TA4_H_V1_8814B(v))
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_RSVD_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_MACID1_8814B */
#define BIT_SHIFT_MACID1_0_8814B 0
#define BIT_MASK_MACID1_0_8814B 0xffffffffL
#define BIT_MACID1_0_8814B(x) \
(((x) & BIT_MASK_MACID1_0_8814B) << BIT_SHIFT_MACID1_0_8814B)
#define BITS_MACID1_0_8814B \
(BIT_MASK_MACID1_0_8814B << BIT_SHIFT_MACID1_0_8814B)
#define BIT_CLEAR_MACID1_0_8814B(x) ((x) & (~BITS_MACID1_0_8814B))
#define BIT_GET_MACID1_0_8814B(x) \
(((x) >> BIT_SHIFT_MACID1_0_8814B) & BIT_MASK_MACID1_0_8814B)
#define BIT_SET_MACID1_0_8814B(x, v) \
(BIT_CLEAR_MACID1_0_8814B(x) | BIT_MACID1_0_8814B(v))
/* 2 REG_MACID1_1_8814B */
#define BIT_SHIFT_MACID1_1_8814B 0
#define BIT_MASK_MACID1_1_8814B 0xffff
#define BIT_MACID1_1_8814B(x) \
(((x) & BIT_MASK_MACID1_1_8814B) << BIT_SHIFT_MACID1_1_8814B)
#define BITS_MACID1_1_8814B \
(BIT_MASK_MACID1_1_8814B << BIT_SHIFT_MACID1_1_8814B)
#define BIT_CLEAR_MACID1_1_8814B(x) ((x) & (~BITS_MACID1_1_8814B))
#define BIT_GET_MACID1_1_8814B(x) \
(((x) >> BIT_SHIFT_MACID1_1_8814B) & BIT_MASK_MACID1_1_8814B)
#define BIT_SET_MACID1_1_8814B(x, v) \
(BIT_CLEAR_MACID1_1_8814B(x) | BIT_MACID1_1_8814B(v))
/* 2 REG_BSSID1_8814B */
#define BIT_SHIFT_BSSID1_0_8814B 0
#define BIT_MASK_BSSID1_0_8814B 0xffffffffL
#define BIT_BSSID1_0_8814B(x) \
(((x) & BIT_MASK_BSSID1_0_8814B) << BIT_SHIFT_BSSID1_0_8814B)
#define BITS_BSSID1_0_8814B \
(BIT_MASK_BSSID1_0_8814B << BIT_SHIFT_BSSID1_0_8814B)
#define BIT_CLEAR_BSSID1_0_8814B(x) ((x) & (~BITS_BSSID1_0_8814B))
#define BIT_GET_BSSID1_0_8814B(x) \
(((x) >> BIT_SHIFT_BSSID1_0_8814B) & BIT_MASK_BSSID1_0_8814B)
#define BIT_SET_BSSID1_0_8814B(x, v) \
(BIT_CLEAR_BSSID1_0_8814B(x) | BIT_BSSID1_0_8814B(v))
/* 2 REG_BSSID1_1_8814B */
#define BIT_SHIFT_BSSID1_1_8814B 0
#define BIT_MASK_BSSID1_1_8814B 0xffff
#define BIT_BSSID1_1_8814B(x) \
(((x) & BIT_MASK_BSSID1_1_8814B) << BIT_SHIFT_BSSID1_1_8814B)
#define BITS_BSSID1_1_8814B \
(BIT_MASK_BSSID1_1_8814B << BIT_SHIFT_BSSID1_1_8814B)
#define BIT_CLEAR_BSSID1_1_8814B(x) ((x) & (~BITS_BSSID1_1_8814B))
#define BIT_GET_BSSID1_1_8814B(x) \
(((x) >> BIT_SHIFT_BSSID1_1_8814B) & BIT_MASK_BSSID1_1_8814B)
#define BIT_SET_BSSID1_1_8814B(x, v) \
(BIT_CLEAR_BSSID1_1_8814B(x) | BIT_BSSID1_1_8814B(v))
/* 2 REG_BCN_PSR_RPT1_8814B */
#define BIT_SHIFT_DTIM_CNT1_8814B 24
#define BIT_MASK_DTIM_CNT1_8814B 0xff
#define BIT_DTIM_CNT1_8814B(x) \
(((x) & BIT_MASK_DTIM_CNT1_8814B) << BIT_SHIFT_DTIM_CNT1_8814B)
#define BITS_DTIM_CNT1_8814B \
(BIT_MASK_DTIM_CNT1_8814B << BIT_SHIFT_DTIM_CNT1_8814B)
#define BIT_CLEAR_DTIM_CNT1_8814B(x) ((x) & (~BITS_DTIM_CNT1_8814B))
#define BIT_GET_DTIM_CNT1_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT1_8814B) & BIT_MASK_DTIM_CNT1_8814B)
#define BIT_SET_DTIM_CNT1_8814B(x, v) \
(BIT_CLEAR_DTIM_CNT1_8814B(x) | BIT_DTIM_CNT1_8814B(v))
#define BIT_SHIFT_DTIM_PERIOD1_8814B 16
#define BIT_MASK_DTIM_PERIOD1_8814B 0xff
#define BIT_DTIM_PERIOD1_8814B(x) \
(((x) & BIT_MASK_DTIM_PERIOD1_8814B) << BIT_SHIFT_DTIM_PERIOD1_8814B)
#define BITS_DTIM_PERIOD1_8814B \
(BIT_MASK_DTIM_PERIOD1_8814B << BIT_SHIFT_DTIM_PERIOD1_8814B)
#define BIT_CLEAR_DTIM_PERIOD1_8814B(x) ((x) & (~BITS_DTIM_PERIOD1_8814B))
#define BIT_GET_DTIM_PERIOD1_8814B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD1_8814B) & BIT_MASK_DTIM_PERIOD1_8814B)
#define BIT_SET_DTIM_PERIOD1_8814B(x, v) \
(BIT_CLEAR_DTIM_PERIOD1_8814B(x) | BIT_DTIM_PERIOD1_8814B(v))
#define BIT_DTIM1_8814B BIT(15)
#define BIT_TIM1_8814B BIT(14)
#define BIT_SHIFT_PS_AID_1_8814B 0
#define BIT_MASK_PS_AID_1_8814B 0x7ff
#define BIT_PS_AID_1_8814B(x) \
(((x) & BIT_MASK_PS_AID_1_8814B) << BIT_SHIFT_PS_AID_1_8814B)
#define BITS_PS_AID_1_8814B \
(BIT_MASK_PS_AID_1_8814B << BIT_SHIFT_PS_AID_1_8814B)
#define BIT_CLEAR_PS_AID_1_8814B(x) ((x) & (~BITS_PS_AID_1_8814B))
#define BIT_GET_PS_AID_1_8814B(x) \
(((x) >> BIT_SHIFT_PS_AID_1_8814B) & BIT_MASK_PS_AID_1_8814B)
#define BIT_SET_PS_AID_1_8814B(x, v) \
(BIT_CLEAR_PS_AID_1_8814B(x) | BIT_PS_AID_1_8814B(v))
/* 2 REG_ASSOCIATED_BFMEE_SEL_8814B */
#define BIT_TXUSER_ID1_8814B BIT(25)
#define BIT_SHIFT_AID1_8814B 16
#define BIT_MASK_AID1_8814B 0x1ff
#define BIT_AID1_8814B(x) (((x) & BIT_MASK_AID1_8814B) << BIT_SHIFT_AID1_8814B)
#define BITS_AID1_8814B (BIT_MASK_AID1_8814B << BIT_SHIFT_AID1_8814B)
#define BIT_CLEAR_AID1_8814B(x) ((x) & (~BITS_AID1_8814B))
#define BIT_GET_AID1_8814B(x) \
(((x) >> BIT_SHIFT_AID1_8814B) & BIT_MASK_AID1_8814B)
#define BIT_SET_AID1_8814B(x, v) (BIT_CLEAR_AID1_8814B(x) | BIT_AID1_8814B(v))
#define BIT_TXUSER_ID0_8814B BIT(9)
#define BIT_SHIFT_AID0_8814B 0
#define BIT_MASK_AID0_8814B 0x1ff
#define BIT_AID0_8814B(x) (((x) & BIT_MASK_AID0_8814B) << BIT_SHIFT_AID0_8814B)
#define BITS_AID0_8814B (BIT_MASK_AID0_8814B << BIT_SHIFT_AID0_8814B)
#define BIT_CLEAR_AID0_8814B(x) ((x) & (~BITS_AID0_8814B))
#define BIT_GET_AID0_8814B(x) \
(((x) >> BIT_SHIFT_AID0_8814B) & BIT_MASK_AID0_8814B)
#define BIT_SET_AID0_8814B(x, v) (BIT_CLEAR_AID0_8814B(x) | BIT_AID0_8814B(v))
/* 2 REG_SND_PTCL_CTRL_8814B */
#define BIT_SHIFT_NDP_RX_STANDBY_TIMER_8814B 24
#define BIT_MASK_NDP_RX_STANDBY_TIMER_8814B 0xff
#define BIT_NDP_RX_STANDBY_TIMER_8814B(x) \
(((x) & BIT_MASK_NDP_RX_STANDBY_TIMER_8814B) \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8814B)
#define BITS_NDP_RX_STANDBY_TIMER_8814B \
(BIT_MASK_NDP_RX_STANDBY_TIMER_8814B \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8814B)
#define BIT_CLEAR_NDP_RX_STANDBY_TIMER_8814B(x) \
((x) & (~BITS_NDP_RX_STANDBY_TIMER_8814B))
#define BIT_GET_NDP_RX_STANDBY_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_NDP_RX_STANDBY_TIMER_8814B) & \
BIT_MASK_NDP_RX_STANDBY_TIMER_8814B)
#define BIT_SET_NDP_RX_STANDBY_TIMER_8814B(x, v) \
(BIT_CLEAR_NDP_RX_STANDBY_TIMER_8814B(x) | \
BIT_NDP_RX_STANDBY_TIMER_8814B(v))
#define BIT_SHIFT_CSI_RPT_OFFSET_HT_8814B 16
#define BIT_MASK_CSI_RPT_OFFSET_HT_8814B 0xff
#define BIT_CSI_RPT_OFFSET_HT_8814B(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT_8814B) \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_8814B)
#define BITS_CSI_RPT_OFFSET_HT_8814B \
(BIT_MASK_CSI_RPT_OFFSET_HT_8814B << BIT_SHIFT_CSI_RPT_OFFSET_HT_8814B)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT_8814B(x) \
((x) & (~BITS_CSI_RPT_OFFSET_HT_8814B))
#define BIT_GET_CSI_RPT_OFFSET_HT_8814B(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT_8814B) & \
BIT_MASK_CSI_RPT_OFFSET_HT_8814B)
#define BIT_SET_CSI_RPT_OFFSET_HT_8814B(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT_8814B(x) | BIT_CSI_RPT_OFFSET_HT_8814B(v))
#define BIT_VHTNDP_RPTPOLL_CSI_STR_OFFSET_SEL_8814B BIT(15)
#define BIT_R_WMAC_CSI_CHKSUM_DIS_8814B BIT(14)
#define BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8814B 8
#define BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8814B 0x3f
#define BIT_R_CSI_RPT_OFFSET_VHT_V1_8814B(x) \
(((x) & BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8814B) \
<< BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8814B)
#define BITS_R_CSI_RPT_OFFSET_VHT_V1_8814B \
(BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8814B \
<< BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8814B)
#define BIT_CLEAR_R_CSI_RPT_OFFSET_VHT_V1_8814B(x) \
((x) & (~BITS_R_CSI_RPT_OFFSET_VHT_V1_8814B))
#define BIT_GET_R_CSI_RPT_OFFSET_VHT_V1_8814B(x) \
(((x) >> BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8814B) & \
BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8814B)
#define BIT_SET_R_CSI_RPT_OFFSET_VHT_V1_8814B(x, v) \
(BIT_CLEAR_R_CSI_RPT_OFFSET_VHT_V1_8814B(x) | \
BIT_R_CSI_RPT_OFFSET_VHT_V1_8814B(v))
#define BIT_R_WMAC_USE_NSTS_8814B BIT(7)
#define BIT_R_DISABLE_CHECK_VHTSIGB_CRC_8814B BIT(6)
#define BIT_R_DISABLE_CHECK_VHTSIGA_CRC_8814B BIT(5)
#define BIT_R_WMAC_BFPARAM_SEL_8814B BIT(4)
#define BIT_R_WMAC_CSISEQ_SEL_8814B BIT(3)
#define BIT_R_WMAC_CSI_WITHHTC_EN_8814B BIT(2)
#define BIT_R_WMAC_HT_NDPA_EN_8814B BIT(1)
#define BIT_R_WMAC_VHT_NDPA_EN_8814B BIT(0)
/* 2 REG_RX_CSI_RPT_INFO_8814B */
#define BIT_WRITE_ENABLE_8814B BIT(31)
#define BIT_WMAC_CHECK_SOUNDING_SEQ_8814B BIT(30)
#define BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8814B 1
#define BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8814B 0xffffff
#define BIT_VHTHT_MIMO_CTRL_FIELD_8814B(x) \
(((x) & BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8814B) \
<< BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8814B)
#define BITS_VHTHT_MIMO_CTRL_FIELD_8814B \
(BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8814B \
<< BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8814B)
#define BIT_CLEAR_VHTHT_MIMO_CTRL_FIELD_8814B(x) \
((x) & (~BITS_VHTHT_MIMO_CTRL_FIELD_8814B))
#define BIT_GET_VHTHT_MIMO_CTRL_FIELD_8814B(x) \
(((x) >> BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8814B) & \
BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8814B)
#define BIT_SET_VHTHT_MIMO_CTRL_FIELD_8814B(x, v) \
(BIT_CLEAR_VHTHT_MIMO_CTRL_FIELD_8814B(x) | \
BIT_VHTHT_MIMO_CTRL_FIELD_8814B(v))
#define BIT_CSI_INTERRUPT_STATUS_8814B BIT(0)
/* 2 REG_NS_ARP_CTRL_8814B */
#define BIT_R_WMAC_NSARP_RSPEN_8814B BIT(15)
#define BIT_R_WMAC_NSARP_RARP_8814B BIT(9)
#define BIT_R_WMAC_NSARP_RIPV6_8814B BIT(8)
#define BIT_SHIFT_R_WMAC_NSARP_MODEN_8814B 6
#define BIT_MASK_R_WMAC_NSARP_MODEN_8814B 0x3
#define BIT_R_WMAC_NSARP_MODEN_8814B(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_MODEN_8814B) \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8814B)
#define BITS_R_WMAC_NSARP_MODEN_8814B \
(BIT_MASK_R_WMAC_NSARP_MODEN_8814B \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8814B)
#define BIT_CLEAR_R_WMAC_NSARP_MODEN_8814B(x) \
((x) & (~BITS_R_WMAC_NSARP_MODEN_8814B))
#define BIT_GET_R_WMAC_NSARP_MODEN_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_MODEN_8814B) & \
BIT_MASK_R_WMAC_NSARP_MODEN_8814B)
#define BIT_SET_R_WMAC_NSARP_MODEN_8814B(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_MODEN_8814B(x) | \
BIT_R_WMAC_NSARP_MODEN_8814B(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8814B 4
#define BIT_MASK_R_WMAC_NSARP_RSPFTP_8814B 0x3
#define BIT_R_WMAC_NSARP_RSPFTP_8814B(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPFTP_8814B) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8814B)
#define BITS_R_WMAC_NSARP_RSPFTP_8814B \
(BIT_MASK_R_WMAC_NSARP_RSPFTP_8814B \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8814B)
#define BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8814B(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPFTP_8814B))
#define BIT_GET_R_WMAC_NSARP_RSPFTP_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8814B) & \
BIT_MASK_R_WMAC_NSARP_RSPFTP_8814B)
#define BIT_SET_R_WMAC_NSARP_RSPFTP_8814B(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8814B(x) | \
BIT_R_WMAC_NSARP_RSPFTP_8814B(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8814B 0
#define BIT_MASK_R_WMAC_NSARP_RSPSEC_8814B 0xf
#define BIT_R_WMAC_NSARP_RSPSEC_8814B(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPSEC_8814B) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8814B)
#define BITS_R_WMAC_NSARP_RSPSEC_8814B \
(BIT_MASK_R_WMAC_NSARP_RSPSEC_8814B \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8814B)
#define BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8814B(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPSEC_8814B))
#define BIT_GET_R_WMAC_NSARP_RSPSEC_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8814B) & \
BIT_MASK_R_WMAC_NSARP_RSPSEC_8814B)
#define BIT_SET_R_WMAC_NSARP_RSPSEC_8814B(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8814B(x) | \
BIT_R_WMAC_NSARP_RSPSEC_8814B(v))
/* 2 REG_NS_ARP_INFO_8814B */
#define BIT_REQ_IS_MCNS_8814B BIT(23)
#define BIT_REQ_IS_UCNS_8814B BIT(22)
#define BIT_REQ_IS_USNS_8814B BIT(21)
#define BIT_REQ_IS_ARP_8814B BIT(20)
#define BIT_EXPRSP_MH_WITHQC_8814B BIT(19)
#define BIT_SHIFT_EXPRSP_SECTYPE_8814B 16
#define BIT_MASK_EXPRSP_SECTYPE_8814B 0x7
#define BIT_EXPRSP_SECTYPE_8814B(x) \
(((x) & BIT_MASK_EXPRSP_SECTYPE_8814B) \
<< BIT_SHIFT_EXPRSP_SECTYPE_8814B)
#define BITS_EXPRSP_SECTYPE_8814B \
(BIT_MASK_EXPRSP_SECTYPE_8814B << BIT_SHIFT_EXPRSP_SECTYPE_8814B)
#define BIT_CLEAR_EXPRSP_SECTYPE_8814B(x) ((x) & (~BITS_EXPRSP_SECTYPE_8814B))
#define BIT_GET_EXPRSP_SECTYPE_8814B(x) \
(((x) >> BIT_SHIFT_EXPRSP_SECTYPE_8814B) & \
BIT_MASK_EXPRSP_SECTYPE_8814B)
#define BIT_SET_EXPRSP_SECTYPE_8814B(x, v) \
(BIT_CLEAR_EXPRSP_SECTYPE_8814B(x) | BIT_EXPRSP_SECTYPE_8814B(v))
#define BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8814B 8
#define BIT_MASK_EXPRSP_CHKSM_7_TO_0_8814B 0xff
#define BIT_EXPRSP_CHKSM_7_TO_0_8814B(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_7_TO_0_8814B) \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8814B)
#define BITS_EXPRSP_CHKSM_7_TO_0_8814B \
(BIT_MASK_EXPRSP_CHKSM_7_TO_0_8814B \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8814B)
#define BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8814B(x) \
((x) & (~BITS_EXPRSP_CHKSM_7_TO_0_8814B))
#define BIT_GET_EXPRSP_CHKSM_7_TO_0_8814B(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8814B) & \
BIT_MASK_EXPRSP_CHKSM_7_TO_0_8814B)
#define BIT_SET_EXPRSP_CHKSM_7_TO_0_8814B(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8814B(x) | \
BIT_EXPRSP_CHKSM_7_TO_0_8814B(v))
#define BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8814B 0
#define BIT_MASK_EXPRSP_CHKSM_15_TO_8_8814B 0xff
#define BIT_EXPRSP_CHKSM_15_TO_8_8814B(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_15_TO_8_8814B) \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8814B)
#define BITS_EXPRSP_CHKSM_15_TO_8_8814B \
(BIT_MASK_EXPRSP_CHKSM_15_TO_8_8814B \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8814B)
#define BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8814B(x) \
((x) & (~BITS_EXPRSP_CHKSM_15_TO_8_8814B))
#define BIT_GET_EXPRSP_CHKSM_15_TO_8_8814B(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8814B) & \
BIT_MASK_EXPRSP_CHKSM_15_TO_8_8814B)
#define BIT_SET_EXPRSP_CHKSM_15_TO_8_8814B(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8814B(x) | \
BIT_EXPRSP_CHKSM_15_TO_8_8814B(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_V1_8814B */
#define BIT_SHIFT_WMAC_ARPIP_8814B 0
#define BIT_MASK_WMAC_ARPIP_8814B 0xffffffffL
#define BIT_WMAC_ARPIP_8814B(x) \
(((x) & BIT_MASK_WMAC_ARPIP_8814B) << BIT_SHIFT_WMAC_ARPIP_8814B)
#define BITS_WMAC_ARPIP_8814B \
(BIT_MASK_WMAC_ARPIP_8814B << BIT_SHIFT_WMAC_ARPIP_8814B)
#define BIT_CLEAR_WMAC_ARPIP_8814B(x) ((x) & (~BITS_WMAC_ARPIP_8814B))
#define BIT_GET_WMAC_ARPIP_8814B(x) \
(((x) >> BIT_SHIFT_WMAC_ARPIP_8814B) & BIT_MASK_WMAC_ARPIP_8814B)
#define BIT_SET_WMAC_ARPIP_8814B(x, v) \
(BIT_CLEAR_WMAC_ARPIP_8814B(x) | BIT_WMAC_ARPIP_8814B(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_8814B */
#define BIT_SHIFT_BEAMFORMING_INFO_8814B 0
#define BIT_MASK_BEAMFORMING_INFO_8814B 0xffffffffL
#define BIT_BEAMFORMING_INFO_8814B(x) \
(((x) & BIT_MASK_BEAMFORMING_INFO_8814B) \
<< BIT_SHIFT_BEAMFORMING_INFO_8814B)
#define BITS_BEAMFORMING_INFO_8814B \
(BIT_MASK_BEAMFORMING_INFO_8814B << BIT_SHIFT_BEAMFORMING_INFO_8814B)
#define BIT_CLEAR_BEAMFORMING_INFO_8814B(x) \
((x) & (~BITS_BEAMFORMING_INFO_8814B))
#define BIT_GET_BEAMFORMING_INFO_8814B(x) \
(((x) >> BIT_SHIFT_BEAMFORMING_INFO_8814B) & \
BIT_MASK_BEAMFORMING_INFO_8814B)
#define BIT_SET_BEAMFORMING_INFO_8814B(x, v) \
(BIT_CLEAR_BEAMFORMING_INFO_8814B(x) | BIT_BEAMFORMING_INFO_8814B(v))
/* 2 REG_IPV6_8814B */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8814B 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8814B 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_0_8814B(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8814B) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8814B)
#define BITS_R_WMAC_IPV6_MYIPAD_0_8814B \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8814B \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8814B)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0_8814B(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_0_8814B))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_0_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8814B) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8814B)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_0_8814B(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0_8814B(x) | \
BIT_R_WMAC_IPV6_MYIPAD_0_8814B(v))
/* 2 REG_IPV6_1_8814B */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8814B 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8814B 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8814B) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8814B)
#define BITS_R_WMAC_IPV6_MYIPAD_1_8814B \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8814B \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8814B)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1_8814B(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_1_8814B))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8814B) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8814B)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1_8814B(x) | \
BIT_R_WMAC_IPV6_MYIPAD_1_8814B(v))
/* 2 REG_IPV6_2_8814B */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8814B 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8814B 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_2_8814B(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8814B) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8814B)
#define BITS_R_WMAC_IPV6_MYIPAD_2_8814B \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8814B \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8814B)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2_8814B(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_2_8814B))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_2_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8814B) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8814B)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_2_8814B(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2_8814B(x) | \
BIT_R_WMAC_IPV6_MYIPAD_2_8814B(v))
/* 2 REG_IPV6_3_8814B */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8814B 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8814B 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_3_8814B(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8814B) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8814B)
#define BITS_R_WMAC_IPV6_MYIPAD_3_8814B \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8814B \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8814B)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3_8814B(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_3_8814B))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_3_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8814B) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8814B)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_3_8814B(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3_8814B(x) | \
BIT_R_WMAC_IPV6_MYIPAD_3_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG_8814B */
#define BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8814B 4
#define BIT_MASK_R_WMAC_CTX_SUBTYPE_8814B 0xf
#define BIT_R_WMAC_CTX_SUBTYPE_8814B(x) \
(((x) & BIT_MASK_R_WMAC_CTX_SUBTYPE_8814B) \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8814B)
#define BITS_R_WMAC_CTX_SUBTYPE_8814B \
(BIT_MASK_R_WMAC_CTX_SUBTYPE_8814B \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8814B)
#define BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8814B(x) \
((x) & (~BITS_R_WMAC_CTX_SUBTYPE_8814B))
#define BIT_GET_R_WMAC_CTX_SUBTYPE_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8814B) & \
BIT_MASK_R_WMAC_CTX_SUBTYPE_8814B)
#define BIT_SET_R_WMAC_CTX_SUBTYPE_8814B(x, v) \
(BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8814B(x) | \
BIT_R_WMAC_CTX_SUBTYPE_8814B(v))
#define BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8814B 0
#define BIT_MASK_R_WMAC_RTX_SUBTYPE_8814B 0xf
#define BIT_R_WMAC_RTX_SUBTYPE_8814B(x) \
(((x) & BIT_MASK_R_WMAC_RTX_SUBTYPE_8814B) \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8814B)
#define BITS_R_WMAC_RTX_SUBTYPE_8814B \
(BIT_MASK_R_WMAC_RTX_SUBTYPE_8814B \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8814B)
#define BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8814B(x) \
((x) & (~BITS_R_WMAC_RTX_SUBTYPE_8814B))
#define BIT_GET_R_WMAC_RTX_SUBTYPE_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8814B) & \
BIT_MASK_R_WMAC_RTX_SUBTYPE_8814B)
#define BIT_SET_R_WMAC_RTX_SUBTYPE_8814B(x, v) \
(BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8814B(x) | \
BIT_R_WMAC_RTX_SUBTYPE_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_WMAC_SWAES_CFG_8814B */
/* 2 REG_BT_COEX_V2_8814B */
#define BIT_GNT_BT_POLARITY_8814B BIT(12)
#define BIT_GNT_BT_BYPASS_PRIORITY_8814B BIT(8)
#define BIT_SHIFT_TIMER_8814B 0
#define BIT_MASK_TIMER_8814B 0xff
#define BIT_TIMER_8814B(x) \
(((x) & BIT_MASK_TIMER_8814B) << BIT_SHIFT_TIMER_8814B)
#define BITS_TIMER_8814B (BIT_MASK_TIMER_8814B << BIT_SHIFT_TIMER_8814B)
#define BIT_CLEAR_TIMER_8814B(x) ((x) & (~BITS_TIMER_8814B))
#define BIT_GET_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_TIMER_8814B) & BIT_MASK_TIMER_8814B)
#define BIT_SET_TIMER_8814B(x, v) \
(BIT_CLEAR_TIMER_8814B(x) | BIT_TIMER_8814B(v))
/* 2 REG_BT_COEX_8814B */
#define BIT_R_GNT_BT_RFC_SW_8814B BIT(12)
#define BIT_R_GNT_BT_RFC_SW_EN_8814B BIT(11)
#define BIT_R_GNT_BT_BB_SW_8814B BIT(10)
#define BIT_R_GNT_BT_BB_SW_EN_8814B BIT(9)
#define BIT_R_BT_CNT_THREN_8814B BIT(8)
#define BIT_SHIFT_R_BT_CNT_THR_8814B 0
#define BIT_MASK_R_BT_CNT_THR_8814B 0xff
#define BIT_R_BT_CNT_THR_8814B(x) \
(((x) & BIT_MASK_R_BT_CNT_THR_8814B) << BIT_SHIFT_R_BT_CNT_THR_8814B)
#define BITS_R_BT_CNT_THR_8814B \
(BIT_MASK_R_BT_CNT_THR_8814B << BIT_SHIFT_R_BT_CNT_THR_8814B)
#define BIT_CLEAR_R_BT_CNT_THR_8814B(x) ((x) & (~BITS_R_BT_CNT_THR_8814B))
#define BIT_GET_R_BT_CNT_THR_8814B(x) \
(((x) >> BIT_SHIFT_R_BT_CNT_THR_8814B) & BIT_MASK_R_BT_CNT_THR_8814B)
#define BIT_SET_R_BT_CNT_THR_8814B(x, v) \
(BIT_CLEAR_R_BT_CNT_THR_8814B(x) | BIT_R_BT_CNT_THR_8814B(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_8814B */
#define BIT_SHIFT_RXMYRTS_NAV_V1_8814B 8
#define BIT_MASK_RXMYRTS_NAV_V1_8814B 0xff
#define BIT_RXMYRTS_NAV_V1_8814B(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_V1_8814B) \
<< BIT_SHIFT_RXMYRTS_NAV_V1_8814B)
#define BITS_RXMYRTS_NAV_V1_8814B \
(BIT_MASK_RXMYRTS_NAV_V1_8814B << BIT_SHIFT_RXMYRTS_NAV_V1_8814B)
#define BIT_CLEAR_RXMYRTS_NAV_V1_8814B(x) ((x) & (~BITS_RXMYRTS_NAV_V1_8814B))
#define BIT_GET_RXMYRTS_NAV_V1_8814B(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_V1_8814B) & \
BIT_MASK_RXMYRTS_NAV_V1_8814B)
#define BIT_SET_RXMYRTS_NAV_V1_8814B(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_V1_8814B(x) | BIT_RXMYRTS_NAV_V1_8814B(v))
#define BIT_SHIFT_RTSRST_V1_8814B 0
#define BIT_MASK_RTSRST_V1_8814B 0xff
#define BIT_RTSRST_V1_8814B(x) \
(((x) & BIT_MASK_RTSRST_V1_8814B) << BIT_SHIFT_RTSRST_V1_8814B)
#define BITS_RTSRST_V1_8814B \
(BIT_MASK_RTSRST_V1_8814B << BIT_SHIFT_RTSRST_V1_8814B)
#define BIT_CLEAR_RTSRST_V1_8814B(x) ((x) & (~BITS_RTSRST_V1_8814B))
#define BIT_GET_RTSRST_V1_8814B(x) \
(((x) >> BIT_SHIFT_RTSRST_V1_8814B) & BIT_MASK_RTSRST_V1_8814B)
#define BIT_SET_RTSRST_V1_8814B(x, v) \
(BIT_CLEAR_RTSRST_V1_8814B(x) | BIT_RTSRST_V1_8814B(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_1_8814B */
#define BIT_WLRX_TER_BY_CTL_1_8814B BIT(11)
#define BIT_WLRX_TER_BY_AD_1_8814B BIT(10)
#define BIT_ANT_DIVERSITY_SEL_1_8814B BIT(9)
#define BIT_ANTSEL_FOR_BT_CTRL_EN_1_8814B BIT(8)
#define BIT_WLACT_LOW_GNTWL_EN_1_8814B BIT(2)
#define BIT_WLACT_HIGH_GNTBT_EN_1_8814B BIT(1)
#define BIT_NAV_UPPER_1_V1_8814B BIT(0)
/* 2 REG_BT_COEX_ENHANCED_INTR_CTRL_8814B */
#define BIT_SHIFT_BT_STAT_DELAY_8814B 12
#define BIT_MASK_BT_STAT_DELAY_8814B 0xf
#define BIT_BT_STAT_DELAY_8814B(x) \
(((x) & BIT_MASK_BT_STAT_DELAY_8814B) << BIT_SHIFT_BT_STAT_DELAY_8814B)
#define BITS_BT_STAT_DELAY_8814B \
(BIT_MASK_BT_STAT_DELAY_8814B << BIT_SHIFT_BT_STAT_DELAY_8814B)
#define BIT_CLEAR_BT_STAT_DELAY_8814B(x) ((x) & (~BITS_BT_STAT_DELAY_8814B))
#define BIT_GET_BT_STAT_DELAY_8814B(x) \
(((x) >> BIT_SHIFT_BT_STAT_DELAY_8814B) & BIT_MASK_BT_STAT_DELAY_8814B)
#define BIT_SET_BT_STAT_DELAY_8814B(x, v) \
(BIT_CLEAR_BT_STAT_DELAY_8814B(x) | BIT_BT_STAT_DELAY_8814B(v))
#define BIT_SHIFT_BT_TRX_INIT_DETECT_8814B 8
#define BIT_MASK_BT_TRX_INIT_DETECT_8814B 0xf
#define BIT_BT_TRX_INIT_DETECT_8814B(x) \
(((x) & BIT_MASK_BT_TRX_INIT_DETECT_8814B) \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8814B)
#define BITS_BT_TRX_INIT_DETECT_8814B \
(BIT_MASK_BT_TRX_INIT_DETECT_8814B \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8814B)
#define BIT_CLEAR_BT_TRX_INIT_DETECT_8814B(x) \
((x) & (~BITS_BT_TRX_INIT_DETECT_8814B))
#define BIT_GET_BT_TRX_INIT_DETECT_8814B(x) \
(((x) >> BIT_SHIFT_BT_TRX_INIT_DETECT_8814B) & \
BIT_MASK_BT_TRX_INIT_DETECT_8814B)
#define BIT_SET_BT_TRX_INIT_DETECT_8814B(x, v) \
(BIT_CLEAR_BT_TRX_INIT_DETECT_8814B(x) | \
BIT_BT_TRX_INIT_DETECT_8814B(v))
#define BIT_SHIFT_BT_PRI_DETECT_TO_8814B 4
#define BIT_MASK_BT_PRI_DETECT_TO_8814B 0xf
#define BIT_BT_PRI_DETECT_TO_8814B(x) \
(((x) & BIT_MASK_BT_PRI_DETECT_TO_8814B) \
<< BIT_SHIFT_BT_PRI_DETECT_TO_8814B)
#define BITS_BT_PRI_DETECT_TO_8814B \
(BIT_MASK_BT_PRI_DETECT_TO_8814B << BIT_SHIFT_BT_PRI_DETECT_TO_8814B)
#define BIT_CLEAR_BT_PRI_DETECT_TO_8814B(x) \
((x) & (~BITS_BT_PRI_DETECT_TO_8814B))
#define BIT_GET_BT_PRI_DETECT_TO_8814B(x) \
(((x) >> BIT_SHIFT_BT_PRI_DETECT_TO_8814B) & \
BIT_MASK_BT_PRI_DETECT_TO_8814B)
#define BIT_SET_BT_PRI_DETECT_TO_8814B(x, v) \
(BIT_CLEAR_BT_PRI_DETECT_TO_8814B(x) | BIT_BT_PRI_DETECT_TO_8814B(v))
#define BIT_R_GRANTALL_WLMASK_8814B BIT(3)
#define BIT_STATIS_BT_EN_8814B BIT(2)
#define BIT_WL_ACT_MASK_ENABLE_8814B BIT(1)
#define BIT_ENHANCED_BT_8814B BIT(0)
/* 2 REG_BT_ACT_STATISTICS_8814B */
#define BIT_SHIFT_STATIS_BT_HI_RX_8814B 16
#define BIT_MASK_STATIS_BT_HI_RX_8814B 0xffff
#define BIT_STATIS_BT_HI_RX_8814B(x) \
(((x) & BIT_MASK_STATIS_BT_HI_RX_8814B) \
<< BIT_SHIFT_STATIS_BT_HI_RX_8814B)
#define BITS_STATIS_BT_HI_RX_8814B \
(BIT_MASK_STATIS_BT_HI_RX_8814B << BIT_SHIFT_STATIS_BT_HI_RX_8814B)
#define BIT_CLEAR_STATIS_BT_HI_RX_8814B(x) ((x) & (~BITS_STATIS_BT_HI_RX_8814B))
#define BIT_GET_STATIS_BT_HI_RX_8814B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_RX_8814B) & \
BIT_MASK_STATIS_BT_HI_RX_8814B)
#define BIT_SET_STATIS_BT_HI_RX_8814B(x, v) \
(BIT_CLEAR_STATIS_BT_HI_RX_8814B(x) | BIT_STATIS_BT_HI_RX_8814B(v))
#define BIT_SHIFT_STATIS_BT_HI_TX_8814B 0
#define BIT_MASK_STATIS_BT_HI_TX_8814B 0xffff
#define BIT_STATIS_BT_HI_TX_8814B(x) \
(((x) & BIT_MASK_STATIS_BT_HI_TX_8814B) \
<< BIT_SHIFT_STATIS_BT_HI_TX_8814B)
#define BITS_STATIS_BT_HI_TX_8814B \
(BIT_MASK_STATIS_BT_HI_TX_8814B << BIT_SHIFT_STATIS_BT_HI_TX_8814B)
#define BIT_CLEAR_STATIS_BT_HI_TX_8814B(x) ((x) & (~BITS_STATIS_BT_HI_TX_8814B))
#define BIT_GET_STATIS_BT_HI_TX_8814B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_TX_8814B) & \
BIT_MASK_STATIS_BT_HI_TX_8814B)
#define BIT_SET_STATIS_BT_HI_TX_8814B(x, v) \
(BIT_CLEAR_STATIS_BT_HI_TX_8814B(x) | BIT_STATIS_BT_HI_TX_8814B(v))
/* 2 REG_BT_ACT_STATISTICS_1_8814B */
#define BIT_SHIFT_STATIS_BT_LO_RX_1_8814B 16
#define BIT_MASK_STATIS_BT_LO_RX_1_8814B 0xffff
#define BIT_STATIS_BT_LO_RX_1_8814B(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX_1_8814B) \
<< BIT_SHIFT_STATIS_BT_LO_RX_1_8814B)
#define BITS_STATIS_BT_LO_RX_1_8814B \
(BIT_MASK_STATIS_BT_LO_RX_1_8814B << BIT_SHIFT_STATIS_BT_LO_RX_1_8814B)
#define BIT_CLEAR_STATIS_BT_LO_RX_1_8814B(x) \
((x) & (~BITS_STATIS_BT_LO_RX_1_8814B))
#define BIT_GET_STATIS_BT_LO_RX_1_8814B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX_1_8814B) & \
BIT_MASK_STATIS_BT_LO_RX_1_8814B)
#define BIT_SET_STATIS_BT_LO_RX_1_8814B(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX_1_8814B(x) | BIT_STATIS_BT_LO_RX_1_8814B(v))
#define BIT_SHIFT_STATIS_BT_LO_TX_1_8814B 0
#define BIT_MASK_STATIS_BT_LO_TX_1_8814B 0xffff
#define BIT_STATIS_BT_LO_TX_1_8814B(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX_1_8814B) \
<< BIT_SHIFT_STATIS_BT_LO_TX_1_8814B)
#define BITS_STATIS_BT_LO_TX_1_8814B \
(BIT_MASK_STATIS_BT_LO_TX_1_8814B << BIT_SHIFT_STATIS_BT_LO_TX_1_8814B)
#define BIT_CLEAR_STATIS_BT_LO_TX_1_8814B(x) \
((x) & (~BITS_STATIS_BT_LO_TX_1_8814B))
#define BIT_GET_STATIS_BT_LO_TX_1_8814B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX_1_8814B) & \
BIT_MASK_STATIS_BT_LO_TX_1_8814B)
#define BIT_SET_STATIS_BT_LO_TX_1_8814B(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX_1_8814B(x) | BIT_STATIS_BT_LO_TX_1_8814B(v))
/* 2 REG_BT_STATISTICS_CONTROL_REGISTER_8814B */
#define BIT_SHIFT_R_BT_CMD_RPT_8814B 16
#define BIT_MASK_R_BT_CMD_RPT_8814B 0xffff
#define BIT_R_BT_CMD_RPT_8814B(x) \
(((x) & BIT_MASK_R_BT_CMD_RPT_8814B) << BIT_SHIFT_R_BT_CMD_RPT_8814B)
#define BITS_R_BT_CMD_RPT_8814B \
(BIT_MASK_R_BT_CMD_RPT_8814B << BIT_SHIFT_R_BT_CMD_RPT_8814B)
#define BIT_CLEAR_R_BT_CMD_RPT_8814B(x) ((x) & (~BITS_R_BT_CMD_RPT_8814B))
#define BIT_GET_R_BT_CMD_RPT_8814B(x) \
(((x) >> BIT_SHIFT_R_BT_CMD_RPT_8814B) & BIT_MASK_R_BT_CMD_RPT_8814B)
#define BIT_SET_R_BT_CMD_RPT_8814B(x, v) \
(BIT_CLEAR_R_BT_CMD_RPT_8814B(x) | BIT_R_BT_CMD_RPT_8814B(v))
#define BIT_SHIFT_R_RPT_FROM_BT_8814B 8
#define BIT_MASK_R_RPT_FROM_BT_8814B 0xff
#define BIT_R_RPT_FROM_BT_8814B(x) \
(((x) & BIT_MASK_R_RPT_FROM_BT_8814B) << BIT_SHIFT_R_RPT_FROM_BT_8814B)
#define BITS_R_RPT_FROM_BT_8814B \
(BIT_MASK_R_RPT_FROM_BT_8814B << BIT_SHIFT_R_RPT_FROM_BT_8814B)
#define BIT_CLEAR_R_RPT_FROM_BT_8814B(x) ((x) & (~BITS_R_RPT_FROM_BT_8814B))
#define BIT_GET_R_RPT_FROM_BT_8814B(x) \
(((x) >> BIT_SHIFT_R_RPT_FROM_BT_8814B) & BIT_MASK_R_RPT_FROM_BT_8814B)
#define BIT_SET_R_RPT_FROM_BT_8814B(x, v) \
(BIT_CLEAR_R_RPT_FROM_BT_8814B(x) | BIT_R_RPT_FROM_BT_8814B(v))
#define BIT_SHIFT_BT_HID_ISR_SET_8814B 6
#define BIT_MASK_BT_HID_ISR_SET_8814B 0x3
#define BIT_BT_HID_ISR_SET_8814B(x) \
(((x) & BIT_MASK_BT_HID_ISR_SET_8814B) \
<< BIT_SHIFT_BT_HID_ISR_SET_8814B)
#define BITS_BT_HID_ISR_SET_8814B \
(BIT_MASK_BT_HID_ISR_SET_8814B << BIT_SHIFT_BT_HID_ISR_SET_8814B)
#define BIT_CLEAR_BT_HID_ISR_SET_8814B(x) ((x) & (~BITS_BT_HID_ISR_SET_8814B))
#define BIT_GET_BT_HID_ISR_SET_8814B(x) \
(((x) >> BIT_SHIFT_BT_HID_ISR_SET_8814B) & \
BIT_MASK_BT_HID_ISR_SET_8814B)
#define BIT_SET_BT_HID_ISR_SET_8814B(x, v) \
(BIT_CLEAR_BT_HID_ISR_SET_8814B(x) | BIT_BT_HID_ISR_SET_8814B(v))
#define BIT_TDMA_BT_START_NOTIFY_8814B BIT(5)
#define BIT_ENABLE_TDMA_FW_MODE_8814B BIT(4)
#define BIT_ENABLE_PTA_TDMA_MODE_8814B BIT(3)
#define BIT_ENABLE_COEXIST_TAB_IN_TDMA_8814B BIT(2)
#define BIT_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA_8814B BIT(1)
#define BIT_RTK_BT_ENABLE_8814B BIT(0)
/* 2 REG_BT_STATUS_REPORT_REGISTER_8814B */
#define BIT_SHIFT_BT_PROFILE_8814B 24
#define BIT_MASK_BT_PROFILE_8814B 0xff
#define BIT_BT_PROFILE_8814B(x) \
(((x) & BIT_MASK_BT_PROFILE_8814B) << BIT_SHIFT_BT_PROFILE_8814B)
#define BITS_BT_PROFILE_8814B \
(BIT_MASK_BT_PROFILE_8814B << BIT_SHIFT_BT_PROFILE_8814B)
#define BIT_CLEAR_BT_PROFILE_8814B(x) ((x) & (~BITS_BT_PROFILE_8814B))
#define BIT_GET_BT_PROFILE_8814B(x) \
(((x) >> BIT_SHIFT_BT_PROFILE_8814B) & BIT_MASK_BT_PROFILE_8814B)
#define BIT_SET_BT_PROFILE_8814B(x, v) \
(BIT_CLEAR_BT_PROFILE_8814B(x) | BIT_BT_PROFILE_8814B(v))
#define BIT_SHIFT_BT_POWER_8814B 16
#define BIT_MASK_BT_POWER_8814B 0xff
#define BIT_BT_POWER_8814B(x) \
(((x) & BIT_MASK_BT_POWER_8814B) << BIT_SHIFT_BT_POWER_8814B)
#define BITS_BT_POWER_8814B \
(BIT_MASK_BT_POWER_8814B << BIT_SHIFT_BT_POWER_8814B)
#define BIT_CLEAR_BT_POWER_8814B(x) ((x) & (~BITS_BT_POWER_8814B))
#define BIT_GET_BT_POWER_8814B(x) \
(((x) >> BIT_SHIFT_BT_POWER_8814B) & BIT_MASK_BT_POWER_8814B)
#define BIT_SET_BT_POWER_8814B(x, v) \
(BIT_CLEAR_BT_POWER_8814B(x) | BIT_BT_POWER_8814B(v))
#define BIT_SHIFT_BT_PREDECT_STATUS_8814B 8
#define BIT_MASK_BT_PREDECT_STATUS_8814B 0xff
#define BIT_BT_PREDECT_STATUS_8814B(x) \
(((x) & BIT_MASK_BT_PREDECT_STATUS_8814B) \
<< BIT_SHIFT_BT_PREDECT_STATUS_8814B)
#define BITS_BT_PREDECT_STATUS_8814B \
(BIT_MASK_BT_PREDECT_STATUS_8814B << BIT_SHIFT_BT_PREDECT_STATUS_8814B)
#define BIT_CLEAR_BT_PREDECT_STATUS_8814B(x) \
((x) & (~BITS_BT_PREDECT_STATUS_8814B))
#define BIT_GET_BT_PREDECT_STATUS_8814B(x) \
(((x) >> BIT_SHIFT_BT_PREDECT_STATUS_8814B) & \
BIT_MASK_BT_PREDECT_STATUS_8814B)
#define BIT_SET_BT_PREDECT_STATUS_8814B(x, v) \
(BIT_CLEAR_BT_PREDECT_STATUS_8814B(x) | BIT_BT_PREDECT_STATUS_8814B(v))
#define BIT_SHIFT_BT_CMD_INFO_8814B 0
#define BIT_MASK_BT_CMD_INFO_8814B 0xff
#define BIT_BT_CMD_INFO_8814B(x) \
(((x) & BIT_MASK_BT_CMD_INFO_8814B) << BIT_SHIFT_BT_CMD_INFO_8814B)
#define BITS_BT_CMD_INFO_8814B \
(BIT_MASK_BT_CMD_INFO_8814B << BIT_SHIFT_BT_CMD_INFO_8814B)
#define BIT_CLEAR_BT_CMD_INFO_8814B(x) ((x) & (~BITS_BT_CMD_INFO_8814B))
#define BIT_GET_BT_CMD_INFO_8814B(x) \
(((x) >> BIT_SHIFT_BT_CMD_INFO_8814B) & BIT_MASK_BT_CMD_INFO_8814B)
#define BIT_SET_BT_CMD_INFO_8814B(x, v) \
(BIT_CLEAR_BT_CMD_INFO_8814B(x) | BIT_BT_CMD_INFO_8814B(v))
/* 2 REG_BT_INTERRUPT_CONTROL_REGISTER_8814B */
#define BIT_EN_MAC_NULL_PKT_NOTIFY_8814B BIT(31)
#define BIT_EN_WLAN_RPT_AND_BT_QUERY_8814B BIT(30)
#define BIT_EN_BT_STSTUS_RPT_8814B BIT(29)
#define BIT_EN_BT_POWER_8814B BIT(28)
#define BIT_EN_BT_CHANNEL_8814B BIT(27)
#define BIT_EN_BT_SLOT_CHANGE_8814B BIT(26)
#define BIT_EN_BT_PROFILE_OR_HID_8814B BIT(25)
#define BIT_WLAN_RPT_NOTIFY_8814B BIT(24)
#define BIT_SHIFT_WLAN_RPT_DATA_8814B 16
#define BIT_MASK_WLAN_RPT_DATA_8814B 0xff
#define BIT_WLAN_RPT_DATA_8814B(x) \
(((x) & BIT_MASK_WLAN_RPT_DATA_8814B) << BIT_SHIFT_WLAN_RPT_DATA_8814B)
#define BITS_WLAN_RPT_DATA_8814B \
(BIT_MASK_WLAN_RPT_DATA_8814B << BIT_SHIFT_WLAN_RPT_DATA_8814B)
#define BIT_CLEAR_WLAN_RPT_DATA_8814B(x) ((x) & (~BITS_WLAN_RPT_DATA_8814B))
#define BIT_GET_WLAN_RPT_DATA_8814B(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_DATA_8814B) & BIT_MASK_WLAN_RPT_DATA_8814B)
#define BIT_SET_WLAN_RPT_DATA_8814B(x, v) \
(BIT_CLEAR_WLAN_RPT_DATA_8814B(x) | BIT_WLAN_RPT_DATA_8814B(v))
#define BIT_SHIFT_CMD_ID_8814B 8
#define BIT_MASK_CMD_ID_8814B 0xff
#define BIT_CMD_ID_8814B(x) \
(((x) & BIT_MASK_CMD_ID_8814B) << BIT_SHIFT_CMD_ID_8814B)
#define BITS_CMD_ID_8814B (BIT_MASK_CMD_ID_8814B << BIT_SHIFT_CMD_ID_8814B)
#define BIT_CLEAR_CMD_ID_8814B(x) ((x) & (~BITS_CMD_ID_8814B))
#define BIT_GET_CMD_ID_8814B(x) \
(((x) >> BIT_SHIFT_CMD_ID_8814B) & BIT_MASK_CMD_ID_8814B)
#define BIT_SET_CMD_ID_8814B(x, v) \
(BIT_CLEAR_CMD_ID_8814B(x) | BIT_CMD_ID_8814B(v))
#define BIT_SHIFT_BT_DATA_8814B 0
#define BIT_MASK_BT_DATA_8814B 0xff
#define BIT_BT_DATA_8814B(x) \
(((x) & BIT_MASK_BT_DATA_8814B) << BIT_SHIFT_BT_DATA_8814B)
#define BITS_BT_DATA_8814B (BIT_MASK_BT_DATA_8814B << BIT_SHIFT_BT_DATA_8814B)
#define BIT_CLEAR_BT_DATA_8814B(x) ((x) & (~BITS_BT_DATA_8814B))
#define BIT_GET_BT_DATA_8814B(x) \
(((x) >> BIT_SHIFT_BT_DATA_8814B) & BIT_MASK_BT_DATA_8814B)
#define BIT_SET_BT_DATA_8814B(x, v) \
(BIT_CLEAR_BT_DATA_8814B(x) | BIT_BT_DATA_8814B(v))
/* 2 REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8814B */
#define BIT_SHIFT_WLAN_RPT_TO_8814B 0
#define BIT_MASK_WLAN_RPT_TO_8814B 0xff
#define BIT_WLAN_RPT_TO_8814B(x) \
(((x) & BIT_MASK_WLAN_RPT_TO_8814B) << BIT_SHIFT_WLAN_RPT_TO_8814B)
#define BITS_WLAN_RPT_TO_8814B \
(BIT_MASK_WLAN_RPT_TO_8814B << BIT_SHIFT_WLAN_RPT_TO_8814B)
#define BIT_CLEAR_WLAN_RPT_TO_8814B(x) ((x) & (~BITS_WLAN_RPT_TO_8814B))
#define BIT_GET_WLAN_RPT_TO_8814B(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_TO_8814B) & BIT_MASK_WLAN_RPT_TO_8814B)
#define BIT_SET_WLAN_RPT_TO_8814B(x, v) \
(BIT_CLEAR_WLAN_RPT_TO_8814B(x) | BIT_WLAN_RPT_TO_8814B(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8814B */
#define BIT_SHIFT_ISOLATION_CHK_0_8814B 1
#define BIT_MASK_ISOLATION_CHK_0_8814B 0x7fffff
#define BIT_ISOLATION_CHK_0_8814B(x) \
(((x) & BIT_MASK_ISOLATION_CHK_0_8814B) \
<< BIT_SHIFT_ISOLATION_CHK_0_8814B)
#define BITS_ISOLATION_CHK_0_8814B \
(BIT_MASK_ISOLATION_CHK_0_8814B << BIT_SHIFT_ISOLATION_CHK_0_8814B)
#define BIT_CLEAR_ISOLATION_CHK_0_8814B(x) ((x) & (~BITS_ISOLATION_CHK_0_8814B))
#define BIT_GET_ISOLATION_CHK_0_8814B(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_0_8814B) & \
BIT_MASK_ISOLATION_CHK_0_8814B)
#define BIT_SET_ISOLATION_CHK_0_8814B(x, v) \
(BIT_CLEAR_ISOLATION_CHK_0_8814B(x) | BIT_ISOLATION_CHK_0_8814B(v))
#define BIT_ISOLATION_EN_8814B BIT(0)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8814B */
#define BIT_SHIFT_ISOLATION_CHK_1_8814B 0
#define BIT_MASK_ISOLATION_CHK_1_8814B 0xffffffffL
#define BIT_ISOLATION_CHK_1_8814B(x) \
(((x) & BIT_MASK_ISOLATION_CHK_1_8814B) \
<< BIT_SHIFT_ISOLATION_CHK_1_8814B)
#define BITS_ISOLATION_CHK_1_8814B \
(BIT_MASK_ISOLATION_CHK_1_8814B << BIT_SHIFT_ISOLATION_CHK_1_8814B)
#define BIT_CLEAR_ISOLATION_CHK_1_8814B(x) ((x) & (~BITS_ISOLATION_CHK_1_8814B))
#define BIT_GET_ISOLATION_CHK_1_8814B(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_1_8814B) & \
BIT_MASK_ISOLATION_CHK_1_8814B)
#define BIT_SET_ISOLATION_CHK_1_8814B(x, v) \
(BIT_CLEAR_ISOLATION_CHK_1_8814B(x) | BIT_ISOLATION_CHK_1_8814B(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8814B */
#define BIT_SHIFT_ISOLATION_CHK_2_8814B 0
#define BIT_MASK_ISOLATION_CHK_2_8814B 0xffffff
#define BIT_ISOLATION_CHK_2_8814B(x) \
(((x) & BIT_MASK_ISOLATION_CHK_2_8814B) \
<< BIT_SHIFT_ISOLATION_CHK_2_8814B)
#define BITS_ISOLATION_CHK_2_8814B \
(BIT_MASK_ISOLATION_CHK_2_8814B << BIT_SHIFT_ISOLATION_CHK_2_8814B)
#define BIT_CLEAR_ISOLATION_CHK_2_8814B(x) ((x) & (~BITS_ISOLATION_CHK_2_8814B))
#define BIT_GET_ISOLATION_CHK_2_8814B(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_2_8814B) & \
BIT_MASK_ISOLATION_CHK_2_8814B)
#define BIT_SET_ISOLATION_CHK_2_8814B(x, v) \
(BIT_CLEAR_ISOLATION_CHK_2_8814B(x) | BIT_ISOLATION_CHK_2_8814B(v))
/* 2 REG_BT_INTERRUPT_STATUS_REGISTER_8814B */
#define BIT_BT_HID_ISR_8814B BIT(7)
#define BIT_BT_QUERY_ISR_8814B BIT(6)
#define BIT_MAC_NULL_PKT_NOTIFY_ISR_8814B BIT(5)
#define BIT_WLAN_RPT_ISR_8814B BIT(4)
#define BIT_BT_POWER_ISR_8814B BIT(3)
#define BIT_BT_CHANNEL_ISR_8814B BIT(2)
#define BIT_BT_SLOT_CHANGE_ISR_8814B BIT(1)
#define BIT_BT_PROFILE_ISR_8814B BIT(0)
/* 2 REG_BT_TDMA_TIME_REGISTER_8814B */
#define BIT_SHIFT_BT_TIME_8814B 6
#define BIT_MASK_BT_TIME_8814B 0x3ffffff
#define BIT_BT_TIME_8814B(x) \
(((x) & BIT_MASK_BT_TIME_8814B) << BIT_SHIFT_BT_TIME_8814B)
#define BITS_BT_TIME_8814B (BIT_MASK_BT_TIME_8814B << BIT_SHIFT_BT_TIME_8814B)
#define BIT_CLEAR_BT_TIME_8814B(x) ((x) & (~BITS_BT_TIME_8814B))
#define BIT_GET_BT_TIME_8814B(x) \
(((x) >> BIT_SHIFT_BT_TIME_8814B) & BIT_MASK_BT_TIME_8814B)
#define BIT_SET_BT_TIME_8814B(x, v) \
(BIT_CLEAR_BT_TIME_8814B(x) | BIT_BT_TIME_8814B(v))
#define BIT_SHIFT_BT_RPT_SAMPLE_RATE_8814B 0
#define BIT_MASK_BT_RPT_SAMPLE_RATE_8814B 0x3f
#define BIT_BT_RPT_SAMPLE_RATE_8814B(x) \
(((x) & BIT_MASK_BT_RPT_SAMPLE_RATE_8814B) \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8814B)
#define BITS_BT_RPT_SAMPLE_RATE_8814B \
(BIT_MASK_BT_RPT_SAMPLE_RATE_8814B \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8814B)
#define BIT_CLEAR_BT_RPT_SAMPLE_RATE_8814B(x) \
((x) & (~BITS_BT_RPT_SAMPLE_RATE_8814B))
#define BIT_GET_BT_RPT_SAMPLE_RATE_8814B(x) \
(((x) >> BIT_SHIFT_BT_RPT_SAMPLE_RATE_8814B) & \
BIT_MASK_BT_RPT_SAMPLE_RATE_8814B)
#define BIT_SET_BT_RPT_SAMPLE_RATE_8814B(x, v) \
(BIT_CLEAR_BT_RPT_SAMPLE_RATE_8814B(x) | \
BIT_BT_RPT_SAMPLE_RATE_8814B(v))
/* 2 REG_BT_ACT_REGISTER_8814B */
#define BIT_SHIFT_BT_EISR_EN_8814B 16
#define BIT_MASK_BT_EISR_EN_8814B 0xff
#define BIT_BT_EISR_EN_8814B(x) \
(((x) & BIT_MASK_BT_EISR_EN_8814B) << BIT_SHIFT_BT_EISR_EN_8814B)
#define BITS_BT_EISR_EN_8814B \
(BIT_MASK_BT_EISR_EN_8814B << BIT_SHIFT_BT_EISR_EN_8814B)
#define BIT_CLEAR_BT_EISR_EN_8814B(x) ((x) & (~BITS_BT_EISR_EN_8814B))
#define BIT_GET_BT_EISR_EN_8814B(x) \
(((x) >> BIT_SHIFT_BT_EISR_EN_8814B) & BIT_MASK_BT_EISR_EN_8814B)
#define BIT_SET_BT_EISR_EN_8814B(x, v) \
(BIT_CLEAR_BT_EISR_EN_8814B(x) | BIT_BT_EISR_EN_8814B(v))
#define BIT_BT_ACT_FALLING_ISR_8814B BIT(10)
#define BIT_BT_ACT_RISING_ISR_8814B BIT(9)
#define BIT_TDMA_TO_ISR_8814B BIT(8)
#define BIT_SHIFT_BT_CH_8814B 0
#define BIT_MASK_BT_CH_8814B 0xff
#define BIT_BT_CH_8814B(x) \
(((x) & BIT_MASK_BT_CH_8814B) << BIT_SHIFT_BT_CH_8814B)
#define BITS_BT_CH_8814B (BIT_MASK_BT_CH_8814B << BIT_SHIFT_BT_CH_8814B)
#define BIT_CLEAR_BT_CH_8814B(x) ((x) & (~BITS_BT_CH_8814B))
#define BIT_GET_BT_CH_8814B(x) \
(((x) >> BIT_SHIFT_BT_CH_8814B) & BIT_MASK_BT_CH_8814B)
#define BIT_SET_BT_CH_8814B(x, v) \
(BIT_CLEAR_BT_CH_8814B(x) | BIT_BT_CH_8814B(v))
/* 2 REG_OBFF_CTRL_BASIC_8814B */
#define BIT_OBFF_EN_V1_8814B BIT(31)
#define BIT_SHIFT_OBFF_STATE_V1_8814B 28
#define BIT_MASK_OBFF_STATE_V1_8814B 0x3
#define BIT_OBFF_STATE_V1_8814B(x) \
(((x) & BIT_MASK_OBFF_STATE_V1_8814B) << BIT_SHIFT_OBFF_STATE_V1_8814B)
#define BITS_OBFF_STATE_V1_8814B \
(BIT_MASK_OBFF_STATE_V1_8814B << BIT_SHIFT_OBFF_STATE_V1_8814B)
#define BIT_CLEAR_OBFF_STATE_V1_8814B(x) ((x) & (~BITS_OBFF_STATE_V1_8814B))
#define BIT_GET_OBFF_STATE_V1_8814B(x) \
(((x) >> BIT_SHIFT_OBFF_STATE_V1_8814B) & BIT_MASK_OBFF_STATE_V1_8814B)
#define BIT_SET_OBFF_STATE_V1_8814B(x, v) \
(BIT_CLEAR_OBFF_STATE_V1_8814B(x) | BIT_OBFF_STATE_V1_8814B(v))
#define BIT_OBFF_ACT_RXDMA_EN_8814B BIT(27)
#define BIT_OBFF_BLOCK_INT_EN_8814B BIT(26)
#define BIT_OBFF_AUTOACT_EN_8814B BIT(25)
#define BIT_OBFF_AUTOIDLE_EN_8814B BIT(24)
#define BIT_SHIFT_WAKE_MAX_PLS_8814B 20
#define BIT_MASK_WAKE_MAX_PLS_8814B 0x7
#define BIT_WAKE_MAX_PLS_8814B(x) \
(((x) & BIT_MASK_WAKE_MAX_PLS_8814B) << BIT_SHIFT_WAKE_MAX_PLS_8814B)
#define BITS_WAKE_MAX_PLS_8814B \
(BIT_MASK_WAKE_MAX_PLS_8814B << BIT_SHIFT_WAKE_MAX_PLS_8814B)
#define BIT_CLEAR_WAKE_MAX_PLS_8814B(x) ((x) & (~BITS_WAKE_MAX_PLS_8814B))
#define BIT_GET_WAKE_MAX_PLS_8814B(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_PLS_8814B) & BIT_MASK_WAKE_MAX_PLS_8814B)
#define BIT_SET_WAKE_MAX_PLS_8814B(x, v) \
(BIT_CLEAR_WAKE_MAX_PLS_8814B(x) | BIT_WAKE_MAX_PLS_8814B(v))
#define BIT_SHIFT_WAKE_MIN_PLS_8814B 16
#define BIT_MASK_WAKE_MIN_PLS_8814B 0x7
#define BIT_WAKE_MIN_PLS_8814B(x) \
(((x) & BIT_MASK_WAKE_MIN_PLS_8814B) << BIT_SHIFT_WAKE_MIN_PLS_8814B)
#define BITS_WAKE_MIN_PLS_8814B \
(BIT_MASK_WAKE_MIN_PLS_8814B << BIT_SHIFT_WAKE_MIN_PLS_8814B)
#define BIT_CLEAR_WAKE_MIN_PLS_8814B(x) ((x) & (~BITS_WAKE_MIN_PLS_8814B))
#define BIT_GET_WAKE_MIN_PLS_8814B(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_PLS_8814B) & BIT_MASK_WAKE_MIN_PLS_8814B)
#define BIT_SET_WAKE_MIN_PLS_8814B(x, v) \
(BIT_CLEAR_WAKE_MIN_PLS_8814B(x) | BIT_WAKE_MIN_PLS_8814B(v))
#define BIT_SHIFT_WAKE_MAX_F2F_8814B 12
#define BIT_MASK_WAKE_MAX_F2F_8814B 0x7
#define BIT_WAKE_MAX_F2F_8814B(x) \
(((x) & BIT_MASK_WAKE_MAX_F2F_8814B) << BIT_SHIFT_WAKE_MAX_F2F_8814B)
#define BITS_WAKE_MAX_F2F_8814B \
(BIT_MASK_WAKE_MAX_F2F_8814B << BIT_SHIFT_WAKE_MAX_F2F_8814B)
#define BIT_CLEAR_WAKE_MAX_F2F_8814B(x) ((x) & (~BITS_WAKE_MAX_F2F_8814B))
#define BIT_GET_WAKE_MAX_F2F_8814B(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_F2F_8814B) & BIT_MASK_WAKE_MAX_F2F_8814B)
#define BIT_SET_WAKE_MAX_F2F_8814B(x, v) \
(BIT_CLEAR_WAKE_MAX_F2F_8814B(x) | BIT_WAKE_MAX_F2F_8814B(v))
#define BIT_SHIFT_WAKE_MIN_F2F_8814B 8
#define BIT_MASK_WAKE_MIN_F2F_8814B 0x7
#define BIT_WAKE_MIN_F2F_8814B(x) \
(((x) & BIT_MASK_WAKE_MIN_F2F_8814B) << BIT_SHIFT_WAKE_MIN_F2F_8814B)
#define BITS_WAKE_MIN_F2F_8814B \
(BIT_MASK_WAKE_MIN_F2F_8814B << BIT_SHIFT_WAKE_MIN_F2F_8814B)
#define BIT_CLEAR_WAKE_MIN_F2F_8814B(x) ((x) & (~BITS_WAKE_MIN_F2F_8814B))
#define BIT_GET_WAKE_MIN_F2F_8814B(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_F2F_8814B) & BIT_MASK_WAKE_MIN_F2F_8814B)
#define BIT_SET_WAKE_MIN_F2F_8814B(x, v) \
(BIT_CLEAR_WAKE_MIN_F2F_8814B(x) | BIT_WAKE_MIN_F2F_8814B(v))
#define BIT_APP_CPU_ACT_V1_8814B BIT(3)
#define BIT_APP_OBFF_V1_8814B BIT(2)
#define BIT_APP_IDLE_V1_8814B BIT(1)
#define BIT_APP_INIT_V1_8814B BIT(0)
/* 2 REG_OBFF_CTRL2_TIMER_8814B */
#define BIT_SHIFT_RX_HIGH_TIMER_IDX_8814B 24
#define BIT_MASK_RX_HIGH_TIMER_IDX_8814B 0x7
#define BIT_RX_HIGH_TIMER_IDX_8814B(x) \
(((x) & BIT_MASK_RX_HIGH_TIMER_IDX_8814B) \
<< BIT_SHIFT_RX_HIGH_TIMER_IDX_8814B)
#define BITS_RX_HIGH_TIMER_IDX_8814B \
(BIT_MASK_RX_HIGH_TIMER_IDX_8814B << BIT_SHIFT_RX_HIGH_TIMER_IDX_8814B)
#define BIT_CLEAR_RX_HIGH_TIMER_IDX_8814B(x) \
((x) & (~BITS_RX_HIGH_TIMER_IDX_8814B))
#define BIT_GET_RX_HIGH_TIMER_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TIMER_IDX_8814B) & \
BIT_MASK_RX_HIGH_TIMER_IDX_8814B)
#define BIT_SET_RX_HIGH_TIMER_IDX_8814B(x, v) \
(BIT_CLEAR_RX_HIGH_TIMER_IDX_8814B(x) | BIT_RX_HIGH_TIMER_IDX_8814B(v))
#define BIT_SHIFT_RX_MED_TIMER_IDX_8814B 16
#define BIT_MASK_RX_MED_TIMER_IDX_8814B 0x7
#define BIT_RX_MED_TIMER_IDX_8814B(x) \
(((x) & BIT_MASK_RX_MED_TIMER_IDX_8814B) \
<< BIT_SHIFT_RX_MED_TIMER_IDX_8814B)
#define BITS_RX_MED_TIMER_IDX_8814B \
(BIT_MASK_RX_MED_TIMER_IDX_8814B << BIT_SHIFT_RX_MED_TIMER_IDX_8814B)
#define BIT_CLEAR_RX_MED_TIMER_IDX_8814B(x) \
((x) & (~BITS_RX_MED_TIMER_IDX_8814B))
#define BIT_GET_RX_MED_TIMER_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_MED_TIMER_IDX_8814B) & \
BIT_MASK_RX_MED_TIMER_IDX_8814B)
#define BIT_SET_RX_MED_TIMER_IDX_8814B(x, v) \
(BIT_CLEAR_RX_MED_TIMER_IDX_8814B(x) | BIT_RX_MED_TIMER_IDX_8814B(v))
#define BIT_SHIFT_RX_LOW_TIMER_IDX_8814B 8
#define BIT_MASK_RX_LOW_TIMER_IDX_8814B 0x7
#define BIT_RX_LOW_TIMER_IDX_8814B(x) \
(((x) & BIT_MASK_RX_LOW_TIMER_IDX_8814B) \
<< BIT_SHIFT_RX_LOW_TIMER_IDX_8814B)
#define BITS_RX_LOW_TIMER_IDX_8814B \
(BIT_MASK_RX_LOW_TIMER_IDX_8814B << BIT_SHIFT_RX_LOW_TIMER_IDX_8814B)
#define BIT_CLEAR_RX_LOW_TIMER_IDX_8814B(x) \
((x) & (~BITS_RX_LOW_TIMER_IDX_8814B))
#define BIT_GET_RX_LOW_TIMER_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_LOW_TIMER_IDX_8814B) & \
BIT_MASK_RX_LOW_TIMER_IDX_8814B)
#define BIT_SET_RX_LOW_TIMER_IDX_8814B(x, v) \
(BIT_CLEAR_RX_LOW_TIMER_IDX_8814B(x) | BIT_RX_LOW_TIMER_IDX_8814B(v))
#define BIT_SHIFT_OBFF_INT_TIMER_IDX_8814B 0
#define BIT_MASK_OBFF_INT_TIMER_IDX_8814B 0x7
#define BIT_OBFF_INT_TIMER_IDX_8814B(x) \
(((x) & BIT_MASK_OBFF_INT_TIMER_IDX_8814B) \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8814B)
#define BITS_OBFF_INT_TIMER_IDX_8814B \
(BIT_MASK_OBFF_INT_TIMER_IDX_8814B \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8814B)
#define BIT_CLEAR_OBFF_INT_TIMER_IDX_8814B(x) \
((x) & (~BITS_OBFF_INT_TIMER_IDX_8814B))
#define BIT_GET_OBFF_INT_TIMER_IDX_8814B(x) \
(((x) >> BIT_SHIFT_OBFF_INT_TIMER_IDX_8814B) & \
BIT_MASK_OBFF_INT_TIMER_IDX_8814B)
#define BIT_SET_OBFF_INT_TIMER_IDX_8814B(x, v) \
(BIT_CLEAR_OBFF_INT_TIMER_IDX_8814B(x) | \
BIT_OBFF_INT_TIMER_IDX_8814B(v))
/* 2 REG_LTR_CTRL_BASIC_8814B */
#define BIT_LTR_EN_V1_8814B BIT(31)
#define BIT_LTR_HW_EN_V1_8814B BIT(30)
#define BIT_LRT_ACT_CTS_EN_8814B BIT(29)
#define BIT_LTR_ACT_RXPKT_EN_8814B BIT(28)
#define BIT_LTR_ACT_RXDMA_EN_8814B BIT(27)
#define BIT_LTR_IDLE_NO_SNOOP_8814B BIT(26)
#define BIT_SPDUP_MGTPKT_8814B BIT(25)
#define BIT_RX_AGG_EN_8814B BIT(24)
#define BIT_APP_LTR_ACT_8814B BIT(23)
#define BIT_APP_LTR_IDLE_8814B BIT(22)
#define BIT_SHIFT_HIGH_RATE_TRIG_SEL_8814B 20
#define BIT_MASK_HIGH_RATE_TRIG_SEL_8814B 0x3
#define BIT_HIGH_RATE_TRIG_SEL_8814B(x) \
(((x) & BIT_MASK_HIGH_RATE_TRIG_SEL_8814B) \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8814B)
#define BITS_HIGH_RATE_TRIG_SEL_8814B \
(BIT_MASK_HIGH_RATE_TRIG_SEL_8814B \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8814B)
#define BIT_CLEAR_HIGH_RATE_TRIG_SEL_8814B(x) \
((x) & (~BITS_HIGH_RATE_TRIG_SEL_8814B))
#define BIT_GET_HIGH_RATE_TRIG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_TRIG_SEL_8814B) & \
BIT_MASK_HIGH_RATE_TRIG_SEL_8814B)
#define BIT_SET_HIGH_RATE_TRIG_SEL_8814B(x, v) \
(BIT_CLEAR_HIGH_RATE_TRIG_SEL_8814B(x) | \
BIT_HIGH_RATE_TRIG_SEL_8814B(v))
#define BIT_SHIFT_MED_RATE_TRIG_SEL_8814B 18
#define BIT_MASK_MED_RATE_TRIG_SEL_8814B 0x3
#define BIT_MED_RATE_TRIG_SEL_8814B(x) \
(((x) & BIT_MASK_MED_RATE_TRIG_SEL_8814B) \
<< BIT_SHIFT_MED_RATE_TRIG_SEL_8814B)
#define BITS_MED_RATE_TRIG_SEL_8814B \
(BIT_MASK_MED_RATE_TRIG_SEL_8814B << BIT_SHIFT_MED_RATE_TRIG_SEL_8814B)
#define BIT_CLEAR_MED_RATE_TRIG_SEL_8814B(x) \
((x) & (~BITS_MED_RATE_TRIG_SEL_8814B))
#define BIT_GET_MED_RATE_TRIG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_MED_RATE_TRIG_SEL_8814B) & \
BIT_MASK_MED_RATE_TRIG_SEL_8814B)
#define BIT_SET_MED_RATE_TRIG_SEL_8814B(x, v) \
(BIT_CLEAR_MED_RATE_TRIG_SEL_8814B(x) | BIT_MED_RATE_TRIG_SEL_8814B(v))
#define BIT_SHIFT_LOW_RATE_TRIG_SEL_8814B 16
#define BIT_MASK_LOW_RATE_TRIG_SEL_8814B 0x3
#define BIT_LOW_RATE_TRIG_SEL_8814B(x) \
(((x) & BIT_MASK_LOW_RATE_TRIG_SEL_8814B) \
<< BIT_SHIFT_LOW_RATE_TRIG_SEL_8814B)
#define BITS_LOW_RATE_TRIG_SEL_8814B \
(BIT_MASK_LOW_RATE_TRIG_SEL_8814B << BIT_SHIFT_LOW_RATE_TRIG_SEL_8814B)
#define BIT_CLEAR_LOW_RATE_TRIG_SEL_8814B(x) \
((x) & (~BITS_LOW_RATE_TRIG_SEL_8814B))
#define BIT_GET_LOW_RATE_TRIG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_LOW_RATE_TRIG_SEL_8814B) & \
BIT_MASK_LOW_RATE_TRIG_SEL_8814B)
#define BIT_SET_LOW_RATE_TRIG_SEL_8814B(x, v) \
(BIT_CLEAR_LOW_RATE_TRIG_SEL_8814B(x) | BIT_LOW_RATE_TRIG_SEL_8814B(v))
#define BIT_SHIFT_HIGH_RATE_BD_IDX_8814B 8
#define BIT_MASK_HIGH_RATE_BD_IDX_8814B 0x7f
#define BIT_HIGH_RATE_BD_IDX_8814B(x) \
(((x) & BIT_MASK_HIGH_RATE_BD_IDX_8814B) \
<< BIT_SHIFT_HIGH_RATE_BD_IDX_8814B)
#define BITS_HIGH_RATE_BD_IDX_8814B \
(BIT_MASK_HIGH_RATE_BD_IDX_8814B << BIT_SHIFT_HIGH_RATE_BD_IDX_8814B)
#define BIT_CLEAR_HIGH_RATE_BD_IDX_8814B(x) \
((x) & (~BITS_HIGH_RATE_BD_IDX_8814B))
#define BIT_GET_HIGH_RATE_BD_IDX_8814B(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_BD_IDX_8814B) & \
BIT_MASK_HIGH_RATE_BD_IDX_8814B)
#define BIT_SET_HIGH_RATE_BD_IDX_8814B(x, v) \
(BIT_CLEAR_HIGH_RATE_BD_IDX_8814B(x) | BIT_HIGH_RATE_BD_IDX_8814B(v))
#define BIT_SHIFT_LOW_RATE_BD_IDX_8814B 0
#define BIT_MASK_LOW_RATE_BD_IDX_8814B 0x7f
#define BIT_LOW_RATE_BD_IDX_8814B(x) \
(((x) & BIT_MASK_LOW_RATE_BD_IDX_8814B) \
<< BIT_SHIFT_LOW_RATE_BD_IDX_8814B)
#define BITS_LOW_RATE_BD_IDX_8814B \
(BIT_MASK_LOW_RATE_BD_IDX_8814B << BIT_SHIFT_LOW_RATE_BD_IDX_8814B)
#define BIT_CLEAR_LOW_RATE_BD_IDX_8814B(x) ((x) & (~BITS_LOW_RATE_BD_IDX_8814B))
#define BIT_GET_LOW_RATE_BD_IDX_8814B(x) \
(((x) >> BIT_SHIFT_LOW_RATE_BD_IDX_8814B) & \
BIT_MASK_LOW_RATE_BD_IDX_8814B)
#define BIT_SET_LOW_RATE_BD_IDX_8814B(x, v) \
(BIT_CLEAR_LOW_RATE_BD_IDX_8814B(x) | BIT_LOW_RATE_BD_IDX_8814B(v))
/* 2 REG_LTR_CTRL2_TIMER_THRESHOLD_8814B */
#define BIT_SHIFT_RX_EMPTY_TIMER_IDX_8814B 24
#define BIT_MASK_RX_EMPTY_TIMER_IDX_8814B 0x7
#define BIT_RX_EMPTY_TIMER_IDX_8814B(x) \
(((x) & BIT_MASK_RX_EMPTY_TIMER_IDX_8814B) \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8814B)
#define BITS_RX_EMPTY_TIMER_IDX_8814B \
(BIT_MASK_RX_EMPTY_TIMER_IDX_8814B \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8814B)
#define BIT_CLEAR_RX_EMPTY_TIMER_IDX_8814B(x) \
((x) & (~BITS_RX_EMPTY_TIMER_IDX_8814B))
#define BIT_GET_RX_EMPTY_TIMER_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_EMPTY_TIMER_IDX_8814B) & \
BIT_MASK_RX_EMPTY_TIMER_IDX_8814B)
#define BIT_SET_RX_EMPTY_TIMER_IDX_8814B(x, v) \
(BIT_CLEAR_RX_EMPTY_TIMER_IDX_8814B(x) | \
BIT_RX_EMPTY_TIMER_IDX_8814B(v))
#define BIT_SHIFT_RX_AFULL_TH_IDX_8814B 20
#define BIT_MASK_RX_AFULL_TH_IDX_8814B 0x7
#define BIT_RX_AFULL_TH_IDX_8814B(x) \
(((x) & BIT_MASK_RX_AFULL_TH_IDX_8814B) \
<< BIT_SHIFT_RX_AFULL_TH_IDX_8814B)
#define BITS_RX_AFULL_TH_IDX_8814B \
(BIT_MASK_RX_AFULL_TH_IDX_8814B << BIT_SHIFT_RX_AFULL_TH_IDX_8814B)
#define BIT_CLEAR_RX_AFULL_TH_IDX_8814B(x) ((x) & (~BITS_RX_AFULL_TH_IDX_8814B))
#define BIT_GET_RX_AFULL_TH_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_AFULL_TH_IDX_8814B) & \
BIT_MASK_RX_AFULL_TH_IDX_8814B)
#define BIT_SET_RX_AFULL_TH_IDX_8814B(x, v) \
(BIT_CLEAR_RX_AFULL_TH_IDX_8814B(x) | BIT_RX_AFULL_TH_IDX_8814B(v))
#define BIT_SHIFT_RX_HIGH_TH_IDX_8814B 16
#define BIT_MASK_RX_HIGH_TH_IDX_8814B 0x7
#define BIT_RX_HIGH_TH_IDX_8814B(x) \
(((x) & BIT_MASK_RX_HIGH_TH_IDX_8814B) \
<< BIT_SHIFT_RX_HIGH_TH_IDX_8814B)
#define BITS_RX_HIGH_TH_IDX_8814B \
(BIT_MASK_RX_HIGH_TH_IDX_8814B << BIT_SHIFT_RX_HIGH_TH_IDX_8814B)
#define BIT_CLEAR_RX_HIGH_TH_IDX_8814B(x) ((x) & (~BITS_RX_HIGH_TH_IDX_8814B))
#define BIT_GET_RX_HIGH_TH_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TH_IDX_8814B) & \
BIT_MASK_RX_HIGH_TH_IDX_8814B)
#define BIT_SET_RX_HIGH_TH_IDX_8814B(x, v) \
(BIT_CLEAR_RX_HIGH_TH_IDX_8814B(x) | BIT_RX_HIGH_TH_IDX_8814B(v))
#define BIT_SHIFT_RX_MED_TH_IDX_8814B 12
#define BIT_MASK_RX_MED_TH_IDX_8814B 0x7
#define BIT_RX_MED_TH_IDX_8814B(x) \
(((x) & BIT_MASK_RX_MED_TH_IDX_8814B) << BIT_SHIFT_RX_MED_TH_IDX_8814B)
#define BITS_RX_MED_TH_IDX_8814B \
(BIT_MASK_RX_MED_TH_IDX_8814B << BIT_SHIFT_RX_MED_TH_IDX_8814B)
#define BIT_CLEAR_RX_MED_TH_IDX_8814B(x) ((x) & (~BITS_RX_MED_TH_IDX_8814B))
#define BIT_GET_RX_MED_TH_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_MED_TH_IDX_8814B) & BIT_MASK_RX_MED_TH_IDX_8814B)
#define BIT_SET_RX_MED_TH_IDX_8814B(x, v) \
(BIT_CLEAR_RX_MED_TH_IDX_8814B(x) | BIT_RX_MED_TH_IDX_8814B(v))
#define BIT_SHIFT_RX_LOW_TH_IDX_8814B 8
#define BIT_MASK_RX_LOW_TH_IDX_8814B 0x7
#define BIT_RX_LOW_TH_IDX_8814B(x) \
(((x) & BIT_MASK_RX_LOW_TH_IDX_8814B) << BIT_SHIFT_RX_LOW_TH_IDX_8814B)
#define BITS_RX_LOW_TH_IDX_8814B \
(BIT_MASK_RX_LOW_TH_IDX_8814B << BIT_SHIFT_RX_LOW_TH_IDX_8814B)
#define BIT_CLEAR_RX_LOW_TH_IDX_8814B(x) ((x) & (~BITS_RX_LOW_TH_IDX_8814B))
#define BIT_GET_RX_LOW_TH_IDX_8814B(x) \
(((x) >> BIT_SHIFT_RX_LOW_TH_IDX_8814B) & BIT_MASK_RX_LOW_TH_IDX_8814B)
#define BIT_SET_RX_LOW_TH_IDX_8814B(x, v) \
(BIT_CLEAR_RX_LOW_TH_IDX_8814B(x) | BIT_RX_LOW_TH_IDX_8814B(v))
#define BIT_SHIFT_LTR_SPACE_IDX_8814B 4
#define BIT_MASK_LTR_SPACE_IDX_8814B 0x3
#define BIT_LTR_SPACE_IDX_8814B(x) \
(((x) & BIT_MASK_LTR_SPACE_IDX_8814B) << BIT_SHIFT_LTR_SPACE_IDX_8814B)
#define BITS_LTR_SPACE_IDX_8814B \
(BIT_MASK_LTR_SPACE_IDX_8814B << BIT_SHIFT_LTR_SPACE_IDX_8814B)
#define BIT_CLEAR_LTR_SPACE_IDX_8814B(x) ((x) & (~BITS_LTR_SPACE_IDX_8814B))
#define BIT_GET_LTR_SPACE_IDX_8814B(x) \
(((x) >> BIT_SHIFT_LTR_SPACE_IDX_8814B) & BIT_MASK_LTR_SPACE_IDX_8814B)
#define BIT_SET_LTR_SPACE_IDX_8814B(x, v) \
(BIT_CLEAR_LTR_SPACE_IDX_8814B(x) | BIT_LTR_SPACE_IDX_8814B(v))
#define BIT_SHIFT_LTR_IDLE_TIMER_IDX_8814B 0
#define BIT_MASK_LTR_IDLE_TIMER_IDX_8814B 0x7
#define BIT_LTR_IDLE_TIMER_IDX_8814B(x) \
(((x) & BIT_MASK_LTR_IDLE_TIMER_IDX_8814B) \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8814B)
#define BITS_LTR_IDLE_TIMER_IDX_8814B \
(BIT_MASK_LTR_IDLE_TIMER_IDX_8814B \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8814B)
#define BIT_CLEAR_LTR_IDLE_TIMER_IDX_8814B(x) \
((x) & (~BITS_LTR_IDLE_TIMER_IDX_8814B))
#define BIT_GET_LTR_IDLE_TIMER_IDX_8814B(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_TIMER_IDX_8814B) & \
BIT_MASK_LTR_IDLE_TIMER_IDX_8814B)
#define BIT_SET_LTR_IDLE_TIMER_IDX_8814B(x, v) \
(BIT_CLEAR_LTR_IDLE_TIMER_IDX_8814B(x) | \
BIT_LTR_IDLE_TIMER_IDX_8814B(v))
/* 2 REG_LTR_IDLE_LATENCY_V1_8814B */
#define BIT_SHIFT_LTR_IDLE_L_8814B 0
#define BIT_MASK_LTR_IDLE_L_8814B 0xffffffffL
#define BIT_LTR_IDLE_L_8814B(x) \
(((x) & BIT_MASK_LTR_IDLE_L_8814B) << BIT_SHIFT_LTR_IDLE_L_8814B)
#define BITS_LTR_IDLE_L_8814B \
(BIT_MASK_LTR_IDLE_L_8814B << BIT_SHIFT_LTR_IDLE_L_8814B)
#define BIT_CLEAR_LTR_IDLE_L_8814B(x) ((x) & (~BITS_LTR_IDLE_L_8814B))
#define BIT_GET_LTR_IDLE_L_8814B(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_L_8814B) & BIT_MASK_LTR_IDLE_L_8814B)
#define BIT_SET_LTR_IDLE_L_8814B(x, v) \
(BIT_CLEAR_LTR_IDLE_L_8814B(x) | BIT_LTR_IDLE_L_8814B(v))
/* 2 REG_LTR_ACTIVE_LATENCY_V1_8814B */
#define BIT_SHIFT_LTR_ACT_L_8814B 0
#define BIT_MASK_LTR_ACT_L_8814B 0xffffffffL
#define BIT_LTR_ACT_L_8814B(x) \
(((x) & BIT_MASK_LTR_ACT_L_8814B) << BIT_SHIFT_LTR_ACT_L_8814B)
#define BITS_LTR_ACT_L_8814B \
(BIT_MASK_LTR_ACT_L_8814B << BIT_SHIFT_LTR_ACT_L_8814B)
#define BIT_CLEAR_LTR_ACT_L_8814B(x) ((x) & (~BITS_LTR_ACT_L_8814B))
#define BIT_GET_LTR_ACT_L_8814B(x) \
(((x) >> BIT_SHIFT_LTR_ACT_L_8814B) & BIT_MASK_LTR_ACT_L_8814B)
#define BIT_SET_LTR_ACT_L_8814B(x, v) \
(BIT_CLEAR_LTR_ACT_L_8814B(x) | BIT_LTR_ACT_L_8814B(v))
#define BIT_SHIFT_ANT_ADDR2_1_8814B 0
#define BIT_MASK_ANT_ADDR2_1_8814B 0xffffffffL
#define BIT_ANT_ADDR2_1_8814B(x) \
(((x) & BIT_MASK_ANT_ADDR2_1_8814B) << BIT_SHIFT_ANT_ADDR2_1_8814B)
#define BITS_ANT_ADDR2_1_8814B \
(BIT_MASK_ANT_ADDR2_1_8814B << BIT_SHIFT_ANT_ADDR2_1_8814B)
#define BIT_CLEAR_ANT_ADDR2_1_8814B(x) ((x) & (~BITS_ANT_ADDR2_1_8814B))
#define BIT_GET_ANT_ADDR2_1_8814B(x) \
(((x) >> BIT_SHIFT_ANT_ADDR2_1_8814B) & BIT_MASK_ANT_ADDR2_1_8814B)
#define BIT_SET_ANT_ADDR2_1_8814B(x, v) \
(BIT_CLEAR_ANT_ADDR2_1_8814B(x) | BIT_ANT_ADDR2_1_8814B(v))
/* 2 REG_SMART_ANT_CTRL_8814B */
#define BIT_ANTTRN_SWITCH_8814B BIT(19)
#define BIT_APPEND_MACID_IN_RESP_EN_1_8814B BIT(18)
#define BIT_ADDR2_MATCH_EN_1_8814B BIT(17)
#define BIT_ANTTRN_EN_1_8814B BIT(16)
#define BIT_SHIFT_ANT_ADDR2_2_8814B 0
#define BIT_MASK_ANT_ADDR2_2_8814B 0xffff
#define BIT_ANT_ADDR2_2_8814B(x) \
(((x) & BIT_MASK_ANT_ADDR2_2_8814B) << BIT_SHIFT_ANT_ADDR2_2_8814B)
#define BITS_ANT_ADDR2_2_8814B \
(BIT_MASK_ANT_ADDR2_2_8814B << BIT_SHIFT_ANT_ADDR2_2_8814B)
#define BIT_CLEAR_ANT_ADDR2_2_8814B(x) ((x) & (~BITS_ANT_ADDR2_2_8814B))
#define BIT_GET_ANT_ADDR2_2_8814B(x) \
(((x) >> BIT_SHIFT_ANT_ADDR2_2_8814B) & BIT_MASK_ANT_ADDR2_2_8814B)
#define BIT_SET_ANT_ADDR2_2_8814B(x, v) \
(BIT_CLEAR_ANT_ADDR2_2_8814B(x) | BIT_ANT_ADDR2_2_8814B(v))
/* 2 REG_CONTROL_FRAME_REPORT_8814B */
#define BIT_SHIFT_CONTROL_FRAME_REPORT_8814B 0
#define BIT_MASK_CONTROL_FRAME_REPORT_8814B 0xffffffffL
#define BIT_CONTROL_FRAME_REPORT_8814B(x) \
(((x) & BIT_MASK_CONTROL_FRAME_REPORT_8814B) \
<< BIT_SHIFT_CONTROL_FRAME_REPORT_8814B)
#define BITS_CONTROL_FRAME_REPORT_8814B \
(BIT_MASK_CONTROL_FRAME_REPORT_8814B \
<< BIT_SHIFT_CONTROL_FRAME_REPORT_8814B)
#define BIT_CLEAR_CONTROL_FRAME_REPORT_8814B(x) \
((x) & (~BITS_CONTROL_FRAME_REPORT_8814B))
#define BIT_GET_CONTROL_FRAME_REPORT_8814B(x) \
(((x) >> BIT_SHIFT_CONTROL_FRAME_REPORT_8814B) & \
BIT_MASK_CONTROL_FRAME_REPORT_8814B)
#define BIT_SET_CONTROL_FRAME_REPORT_8814B(x, v) \
(BIT_CLEAR_CONTROL_FRAME_REPORT_8814B(x) | \
BIT_CONTROL_FRAME_REPORT_8814B(v))
/* 2 REG_CONTROL_FRAME_CNT_CTRL_8814B */
#define BIT_ALLCNTRST_8814B BIT(9)
#define BIT__ALLCNTEN_8814B BIT(8)
#define BIT_SHIFT_ADDR_8814B 4
#define BIT_MASK_ADDR_8814B 0xf
#define BIT_ADDR_8814B(x) (((x) & BIT_MASK_ADDR_8814B) << BIT_SHIFT_ADDR_8814B)
#define BITS_ADDR_8814B (BIT_MASK_ADDR_8814B << BIT_SHIFT_ADDR_8814B)
#define BIT_CLEAR_ADDR_8814B(x) ((x) & (~BITS_ADDR_8814B))
#define BIT_GET_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_ADDR_8814B) & BIT_MASK_ADDR_8814B)
#define BIT_SET_ADDR_8814B(x, v) (BIT_CLEAR_ADDR_8814B(x) | BIT_ADDR_8814B(v))
#define BIT_SHIFT_CTRL_SEL_8814B 0
#define BIT_MASK_CTRL_SEL_8814B 0xf
#define BIT_CTRL_SEL_8814B(x) \
(((x) & BIT_MASK_CTRL_SEL_8814B) << BIT_SHIFT_CTRL_SEL_8814B)
#define BITS_CTRL_SEL_8814B \
(BIT_MASK_CTRL_SEL_8814B << BIT_SHIFT_CTRL_SEL_8814B)
#define BIT_CLEAR_CTRL_SEL_8814B(x) ((x) & (~BITS_CTRL_SEL_8814B))
#define BIT_GET_CTRL_SEL_8814B(x) \
(((x) >> BIT_SHIFT_CTRL_SEL_8814B) & BIT_MASK_CTRL_SEL_8814B)
#define BIT_SET_CTRL_SEL_8814B(x, v) \
(BIT_CLEAR_CTRL_SEL_8814B(x) | BIT_CTRL_SEL_8814B(v))
/* 2 REG_IQ_DUMP_8814B */
#define BIT_SHIFT_DUMP_OK_ADDR_8814B 16
#define BIT_MASK_DUMP_OK_ADDR_8814B 0xffff
#define BIT_DUMP_OK_ADDR_8814B(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR_8814B) << BIT_SHIFT_DUMP_OK_ADDR_8814B)
#define BITS_DUMP_OK_ADDR_8814B \
(BIT_MASK_DUMP_OK_ADDR_8814B << BIT_SHIFT_DUMP_OK_ADDR_8814B)
#define BIT_CLEAR_DUMP_OK_ADDR_8814B(x) ((x) & (~BITS_DUMP_OK_ADDR_8814B))
#define BIT_GET_DUMP_OK_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR_8814B) & BIT_MASK_DUMP_OK_ADDR_8814B)
#define BIT_SET_DUMP_OK_ADDR_8814B(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR_8814B(x) | BIT_DUMP_OK_ADDR_8814B(v))
#define BIT_SHIFT_R_TRIG_TIME_SEL_8814B 8
#define BIT_MASK_R_TRIG_TIME_SEL_8814B 0x7f
#define BIT_R_TRIG_TIME_SEL_8814B(x) \
(((x) & BIT_MASK_R_TRIG_TIME_SEL_8814B) \
<< BIT_SHIFT_R_TRIG_TIME_SEL_8814B)
#define BITS_R_TRIG_TIME_SEL_8814B \
(BIT_MASK_R_TRIG_TIME_SEL_8814B << BIT_SHIFT_R_TRIG_TIME_SEL_8814B)
#define BIT_CLEAR_R_TRIG_TIME_SEL_8814B(x) ((x) & (~BITS_R_TRIG_TIME_SEL_8814B))
#define BIT_GET_R_TRIG_TIME_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_TRIG_TIME_SEL_8814B) & \
BIT_MASK_R_TRIG_TIME_SEL_8814B)
#define BIT_SET_R_TRIG_TIME_SEL_8814B(x, v) \
(BIT_CLEAR_R_TRIG_TIME_SEL_8814B(x) | BIT_R_TRIG_TIME_SEL_8814B(v))
#define BIT_SHIFT_R_MAC_TRIG_SEL_8814B 6
#define BIT_MASK_R_MAC_TRIG_SEL_8814B 0x3
#define BIT_R_MAC_TRIG_SEL_8814B(x) \
(((x) & BIT_MASK_R_MAC_TRIG_SEL_8814B) \
<< BIT_SHIFT_R_MAC_TRIG_SEL_8814B)
#define BITS_R_MAC_TRIG_SEL_8814B \
(BIT_MASK_R_MAC_TRIG_SEL_8814B << BIT_SHIFT_R_MAC_TRIG_SEL_8814B)
#define BIT_CLEAR_R_MAC_TRIG_SEL_8814B(x) ((x) & (~BITS_R_MAC_TRIG_SEL_8814B))
#define BIT_GET_R_MAC_TRIG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_MAC_TRIG_SEL_8814B) & \
BIT_MASK_R_MAC_TRIG_SEL_8814B)
#define BIT_SET_R_MAC_TRIG_SEL_8814B(x, v) \
(BIT_CLEAR_R_MAC_TRIG_SEL_8814B(x) | BIT_R_MAC_TRIG_SEL_8814B(v))
#define BIT_MAC_TRIG_REG_8814B BIT(5)
#define BIT_SHIFT_R_LEVEL_PULSE_SEL_8814B 3
#define BIT_MASK_R_LEVEL_PULSE_SEL_8814B 0x3
#define BIT_R_LEVEL_PULSE_SEL_8814B(x) \
(((x) & BIT_MASK_R_LEVEL_PULSE_SEL_8814B) \
<< BIT_SHIFT_R_LEVEL_PULSE_SEL_8814B)
#define BITS_R_LEVEL_PULSE_SEL_8814B \
(BIT_MASK_R_LEVEL_PULSE_SEL_8814B << BIT_SHIFT_R_LEVEL_PULSE_SEL_8814B)
#define BIT_CLEAR_R_LEVEL_PULSE_SEL_8814B(x) \
((x) & (~BITS_R_LEVEL_PULSE_SEL_8814B))
#define BIT_GET_R_LEVEL_PULSE_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_LEVEL_PULSE_SEL_8814B) & \
BIT_MASK_R_LEVEL_PULSE_SEL_8814B)
#define BIT_SET_R_LEVEL_PULSE_SEL_8814B(x, v) \
(BIT_CLEAR_R_LEVEL_PULSE_SEL_8814B(x) | BIT_R_LEVEL_PULSE_SEL_8814B(v))
#define BIT_EN_LA_MAC_8814B BIT(2)
#define BIT_R_EN_IQDUMP_8814B BIT(1)
#define BIT_R_IQDATA_DUMP_8814B BIT(0)
/* 2 REG_IQ_DUMP_1_8814B */
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8814B 0
#define BIT_MASK_R_WMAC_MASK_LA_MAC_1_8814B 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC_1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC_1_8814B) \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8814B)
#define BITS_R_WMAC_MASK_LA_MAC_1_8814B \
(BIT_MASK_R_WMAC_MASK_LA_MAC_1_8814B \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8814B)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC_1_8814B(x) \
((x) & (~BITS_R_WMAC_MASK_LA_MAC_1_8814B))
#define BIT_GET_R_WMAC_MASK_LA_MAC_1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8814B) & \
BIT_MASK_R_WMAC_MASK_LA_MAC_1_8814B)
#define BIT_SET_R_WMAC_MASK_LA_MAC_1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC_1_8814B(x) | \
BIT_R_WMAC_MASK_LA_MAC_1_8814B(v))
/* 2 REG_IQ_DUMP_2_8814B */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8814B 0
#define BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8814B 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC_2_8814B(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8814B) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8814B)
#define BITS_R_WMAC_MATCH_REF_MAC_2_8814B \
(BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8814B \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8814B)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2_8814B(x) \
((x) & (~BITS_R_WMAC_MATCH_REF_MAC_2_8814B))
#define BIT_GET_R_WMAC_MATCH_REF_MAC_2_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8814B) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8814B)
#define BIT_SET_R_WMAC_MATCH_REF_MAC_2_8814B(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2_8814B(x) | \
BIT_R_WMAC_MATCH_REF_MAC_2_8814B(v))
/* 2 REG_WMAC_FTM_CTL_8814B */
#define BIT_RXFTM_TXACK_SC_8814B BIT(6)
#define BIT_RXFTM_TXACK_BW_8814B BIT(5)
#define BIT_RXFTM_EN_8814B BIT(3)
#define BIT_RXFTMREQ_BYDRV_8814B BIT(2)
#define BIT_RXFTMREQ_EN_8814B BIT(1)
#define BIT_FTM_EN_8814B BIT(0)
/* 2 REG_WMAC_IQ_MDPK_FUNC_8814B */
/* 2 REG_WMAC_OPTION_FUNCTION_8814B */
#define BIT_SHIFT_R_OFDM_LEN_8814B 26
#define BIT_MASK_R_OFDM_LEN_8814B 0x3f
#define BIT_R_OFDM_LEN_8814B(x) \
(((x) & BIT_MASK_R_OFDM_LEN_8814B) << BIT_SHIFT_R_OFDM_LEN_8814B)
#define BITS_R_OFDM_LEN_8814B \
(BIT_MASK_R_OFDM_LEN_8814B << BIT_SHIFT_R_OFDM_LEN_8814B)
#define BIT_CLEAR_R_OFDM_LEN_8814B(x) ((x) & (~BITS_R_OFDM_LEN_8814B))
#define BIT_GET_R_OFDM_LEN_8814B(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN_8814B) & BIT_MASK_R_OFDM_LEN_8814B)
#define BIT_SET_R_OFDM_LEN_8814B(x, v) \
(BIT_CLEAR_R_OFDM_LEN_8814B(x) | BIT_R_OFDM_LEN_8814B(v))
#define BIT_SHIFT_R_CCK_LEN_8814B 0
#define BIT_MASK_R_CCK_LEN_8814B 0xffff
#define BIT_R_CCK_LEN_8814B(x) \
(((x) & BIT_MASK_R_CCK_LEN_8814B) << BIT_SHIFT_R_CCK_LEN_8814B)
#define BITS_R_CCK_LEN_8814B \
(BIT_MASK_R_CCK_LEN_8814B << BIT_SHIFT_R_CCK_LEN_8814B)
#define BIT_CLEAR_R_CCK_LEN_8814B(x) ((x) & (~BITS_R_CCK_LEN_8814B))
#define BIT_GET_R_CCK_LEN_8814B(x) \
(((x) >> BIT_SHIFT_R_CCK_LEN_8814B) & BIT_MASK_R_CCK_LEN_8814B)
#define BIT_SET_R_CCK_LEN_8814B(x, v) \
(BIT_CLEAR_R_CCK_LEN_8814B(x) | BIT_R_CCK_LEN_8814B(v))
/* 2 REG_WMAC_OPTION_FUNCTION_1_8814B */
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8814B 24
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8814B 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH_1_8814B(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8814B) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8814B)
#define BITS_R_WMAC_RXFIFO_FULL_TH_1_8814B \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8814B \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8814B)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1_8814B(x) \
((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH_1_8814B))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH_1_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8814B) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8814B)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH_1_8814B(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1_8814B(x) | \
BIT_R_WMAC_RXFIFO_FULL_TH_1_8814B(v))
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC_1_8814B BIT(23)
#define BIT_R_WMAC_RXRST_DLY_1_8814B BIT(22)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP_1_8814B BIT(21)
#define BIT_R_WMAC_SRCH_TXRPT_UA1_1_8814B BIT(20)
#define BIT_R_WMAC_SRCH_TXRPT_TYPE_1_8814B BIT(19)
#define BIT_R_WMAC_NDP_RST_1_8814B BIT(18)
#define BIT_R_WMAC_POWINT_EN_1_8814B BIT(17)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT_1_8814B BIT(16)
#define BIT_R_WMAC_SRCH_TXRPT_MID_1_8814B BIT(15)
#define BIT_R_WMAC_PFIN_TOEN_1_8814B BIT(14)
#define BIT_R_WMAC_FIL_SECERR_1_8814B BIT(13)
#define BIT_R_WMAC_FIL_CTLPKTLEN_1_8814B BIT(12)
#define BIT_R_WMAC_FIL_FCTYPE_1_8814B BIT(11)
#define BIT_R_WMAC_FIL_FCPROVER_1_8814B BIT(10)
#define BIT_R_WMAC_PHYSTS_SNIF_1_8814B BIT(9)
#define BIT_R_WMAC_PHYSTS_PLCP_1_8814B BIT(8)
#define BIT_R_MAC_TCR_VBONF_RD_1_8814B BIT(7)
#define BIT_R_WMAC_TCR_MPAR_NDP_1_8814B BIT(6)
#define BIT_R_WMAC_NDP_FILTER_1_8814B BIT(5)
#define BIT_R_WMAC_RXLEN_SEL_1_8814B BIT(4)
#define BIT_R_WMAC_RXLEN_SEL1_1_8814B BIT(3)
#define BIT_R_OFDM_FILTER_1_8814B BIT(2)
#define BIT_R_WMAC_CHK_OFDM_LEN_1_8814B BIT(1)
#define BIT_R_WMAC_CHK_CCK_LEN_1_8814B BIT(0)
/* 2 REG_WMAC_OPTION_FUNCTION_2_8814B */
#define BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8814B 0
#define BIT_MASK_R_WMAC_RX_FIL_LEN_2_8814B 0xffff
#define BIT_R_WMAC_RX_FIL_LEN_2_8814B(x) \
(((x) & BIT_MASK_R_WMAC_RX_FIL_LEN_2_8814B) \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8814B)
#define BITS_R_WMAC_RX_FIL_LEN_2_8814B \
(BIT_MASK_R_WMAC_RX_FIL_LEN_2_8814B \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8814B)
#define BIT_CLEAR_R_WMAC_RX_FIL_LEN_2_8814B(x) \
((x) & (~BITS_R_WMAC_RX_FIL_LEN_2_8814B))
#define BIT_GET_R_WMAC_RX_FIL_LEN_2_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8814B) & \
BIT_MASK_R_WMAC_RX_FIL_LEN_2_8814B)
#define BIT_SET_R_WMAC_RX_FIL_LEN_2_8814B(x, v) \
(BIT_CLEAR_R_WMAC_RX_FIL_LEN_2_8814B(x) | \
BIT_R_WMAC_RX_FIL_LEN_2_8814B(v))
/* 2 REG_RX_FILTER_FUNCTION_8814B */
#define BIT_R_WMAC_MHRDDY_LATCH_8814B BIT(14)
#define BIT_R_WMAC_MHRDDY_CLR_8814B BIT(13)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY1_8814B BIT(12)
#define BIT_WMAC_DIS_VHT_PLCP_CHK_MU_8814B BIT(11)
#define BIT_R_CHK_DELIMIT_LEN_8814B BIT(10)
#define BIT_R_REAPTER_ADDR_MATCH_8814B BIT(9)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY_8814B BIT(8)
#define BIT_R_LATCH_MACHRDY_8814B BIT(7)
#define BIT_R_WMAC_RXFIL_REND_8814B BIT(6)
#define BIT_R_WMAC_MPDURDY_CLR_8814B BIT(5)
#define BIT_R_WMAC_CLRRXSEC_8814B BIT(4)
#define BIT_R_WMAC_RXFIL_RDEL_8814B BIT(3)
#define BIT_R_WMAC_RXFIL_FCSE_8814B BIT(2)
#define BIT_R_WMAC_RXFIL_MESH_DEL_8814B BIT(1)
#define BIT_R_WMAC_RXFIL_MASKM_8814B BIT(0)
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NDP_SIG_8814B */
#define BIT_SHIFT_R_WMAC_TXNDP_SIGB_8814B 0
#define BIT_MASK_R_WMAC_TXNDP_SIGB_8814B 0x1fffff
#define BIT_R_WMAC_TXNDP_SIGB_8814B(x) \
(((x) & BIT_MASK_R_WMAC_TXNDP_SIGB_8814B) \
<< BIT_SHIFT_R_WMAC_TXNDP_SIGB_8814B)
#define BITS_R_WMAC_TXNDP_SIGB_8814B \
(BIT_MASK_R_WMAC_TXNDP_SIGB_8814B << BIT_SHIFT_R_WMAC_TXNDP_SIGB_8814B)
#define BIT_CLEAR_R_WMAC_TXNDP_SIGB_8814B(x) \
((x) & (~BITS_R_WMAC_TXNDP_SIGB_8814B))
#define BIT_GET_R_WMAC_TXNDP_SIGB_8814B(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXNDP_SIGB_8814B) & \
BIT_MASK_R_WMAC_TXNDP_SIGB_8814B)
#define BIT_SET_R_WMAC_TXNDP_SIGB_8814B(x, v) \
(BIT_CLEAR_R_WMAC_TXNDP_SIGB_8814B(x) | BIT_R_WMAC_TXNDP_SIGB_8814B(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_8814B */
#define BIT_SHIFT_R_MAC_DBG_SHIFT_8814B 8
#define BIT_MASK_R_MAC_DBG_SHIFT_8814B 0x7
#define BIT_R_MAC_DBG_SHIFT_8814B(x) \
(((x) & BIT_MASK_R_MAC_DBG_SHIFT_8814B) \
<< BIT_SHIFT_R_MAC_DBG_SHIFT_8814B)
#define BITS_R_MAC_DBG_SHIFT_8814B \
(BIT_MASK_R_MAC_DBG_SHIFT_8814B << BIT_SHIFT_R_MAC_DBG_SHIFT_8814B)
#define BIT_CLEAR_R_MAC_DBG_SHIFT_8814B(x) ((x) & (~BITS_R_MAC_DBG_SHIFT_8814B))
#define BIT_GET_R_MAC_DBG_SHIFT_8814B(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SHIFT_8814B) & \
BIT_MASK_R_MAC_DBG_SHIFT_8814B)
#define BIT_SET_R_MAC_DBG_SHIFT_8814B(x, v) \
(BIT_CLEAR_R_MAC_DBG_SHIFT_8814B(x) | BIT_R_MAC_DBG_SHIFT_8814B(v))
#define BIT_SHIFT_R_MAC_DBG_SEL_8814B 0
#define BIT_MASK_R_MAC_DBG_SEL_8814B 0x3
#define BIT_R_MAC_DBG_SEL_8814B(x) \
(((x) & BIT_MASK_R_MAC_DBG_SEL_8814B) << BIT_SHIFT_R_MAC_DBG_SEL_8814B)
#define BITS_R_MAC_DBG_SEL_8814B \
(BIT_MASK_R_MAC_DBG_SEL_8814B << BIT_SHIFT_R_MAC_DBG_SEL_8814B)
#define BIT_CLEAR_R_MAC_DBG_SEL_8814B(x) ((x) & (~BITS_R_MAC_DBG_SEL_8814B))
#define BIT_GET_R_MAC_DBG_SEL_8814B(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SEL_8814B) & BIT_MASK_R_MAC_DBG_SEL_8814B)
#define BIT_SET_R_MAC_DBG_SEL_8814B(x, v) \
(BIT_CLEAR_R_MAC_DBG_SEL_8814B(x) | BIT_R_MAC_DBG_SEL_8814B(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_1_8814B */
#define BIT_SHIFT_R_MAC_DEBUG_1_8814B 0
#define BIT_MASK_R_MAC_DEBUG_1_8814B 0xffffffffL
#define BIT_R_MAC_DEBUG_1_8814B(x) \
(((x) & BIT_MASK_R_MAC_DEBUG_1_8814B) << BIT_SHIFT_R_MAC_DEBUG_1_8814B)
#define BITS_R_MAC_DEBUG_1_8814B \
(BIT_MASK_R_MAC_DEBUG_1_8814B << BIT_SHIFT_R_MAC_DEBUG_1_8814B)
#define BIT_CLEAR_R_MAC_DEBUG_1_8814B(x) ((x) & (~BITS_R_MAC_DEBUG_1_8814B))
#define BIT_GET_R_MAC_DEBUG_1_8814B(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG_1_8814B) & BIT_MASK_R_MAC_DEBUG_1_8814B)
#define BIT_SET_R_MAC_DEBUG_1_8814B(x, v) \
(BIT_CLEAR_R_MAC_DEBUG_1_8814B(x) | BIT_R_MAC_DEBUG_1_8814B(v))
/* 2 REG_WSEC_OPTION_8814B */
#define BIT_RXDEC_BM_MGNT_8814B BIT(22)
#define BIT_TXENC_BM_MGNT_8814B BIT(21)
#define BIT_RXDEC_UNI_MGNT_8814B BIT(20)
#define BIT_TXENC_UNI_MGNT_8814B BIT(19)
/* 2 REG_RTS_ADDRESS_0_8814B */
/* 2 REG_RTS_ADDRESS_0_1_8814B */
/* 2 REG_RTS_ADDRESS_1_8814B */
/* 2 REG_RTS_ADDRESS_1_1_8814B */
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8814B */
#define BIT_LTECOEX_ACCESS_START_V1_8814B BIT(31)
#define BIT_LTECOEX_WRITE_MODE_V1_8814B BIT(30)
#define BIT_LTECOEX_READY_BIT_V1_8814B BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN_V1_8814B 16
#define BIT_MASK_WRITE_BYTE_EN_V1_8814B 0xf
#define BIT_WRITE_BYTE_EN_V1_8814B(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN_V1_8814B) \
<< BIT_SHIFT_WRITE_BYTE_EN_V1_8814B)
#define BITS_WRITE_BYTE_EN_V1_8814B \
(BIT_MASK_WRITE_BYTE_EN_V1_8814B << BIT_SHIFT_WRITE_BYTE_EN_V1_8814B)
#define BIT_CLEAR_WRITE_BYTE_EN_V1_8814B(x) \
((x) & (~BITS_WRITE_BYTE_EN_V1_8814B))
#define BIT_GET_WRITE_BYTE_EN_V1_8814B(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN_V1_8814B) & \
BIT_MASK_WRITE_BYTE_EN_V1_8814B)
#define BIT_SET_WRITE_BYTE_EN_V1_8814B(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN_V1_8814B(x) | BIT_WRITE_BYTE_EN_V1_8814B(v))
#define BIT_SHIFT_LTECOEX_REG_ADDR_V1_8814B 0
#define BIT_MASK_LTECOEX_REG_ADDR_V1_8814B 0xffff
#define BIT_LTECOEX_REG_ADDR_V1_8814B(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR_V1_8814B) \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8814B)
#define BITS_LTECOEX_REG_ADDR_V1_8814B \
(BIT_MASK_LTECOEX_REG_ADDR_V1_8814B \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8814B)
#define BIT_CLEAR_LTECOEX_REG_ADDR_V1_8814B(x) \
((x) & (~BITS_LTECOEX_REG_ADDR_V1_8814B))
#define BIT_GET_LTECOEX_REG_ADDR_V1_8814B(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR_V1_8814B) & \
BIT_MASK_LTECOEX_REG_ADDR_V1_8814B)
#define BIT_SET_LTECOEX_REG_ADDR_V1_8814B(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR_V1_8814B(x) | \
BIT_LTECOEX_REG_ADDR_V1_8814B(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8814B */
#define BIT_SHIFT_LTECOEX_W_DATA_V1_8814B 0
#define BIT_MASK_LTECOEX_W_DATA_V1_8814B 0xffffffffL
#define BIT_LTECOEX_W_DATA_V1_8814B(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA_V1_8814B) \
<< BIT_SHIFT_LTECOEX_W_DATA_V1_8814B)
#define BITS_LTECOEX_W_DATA_V1_8814B \
(BIT_MASK_LTECOEX_W_DATA_V1_8814B << BIT_SHIFT_LTECOEX_W_DATA_V1_8814B)
#define BIT_CLEAR_LTECOEX_W_DATA_V1_8814B(x) \
((x) & (~BITS_LTECOEX_W_DATA_V1_8814B))
#define BIT_GET_LTECOEX_W_DATA_V1_8814B(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA_V1_8814B) & \
BIT_MASK_LTECOEX_W_DATA_V1_8814B)
#define BIT_SET_LTECOEX_W_DATA_V1_8814B(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA_V1_8814B(x) | BIT_LTECOEX_W_DATA_V1_8814B(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8814B */
#define BIT_SHIFT_LTECOEX_R_DATA_V1_8814B 0
#define BIT_MASK_LTECOEX_R_DATA_V1_8814B 0xffffffffL
#define BIT_LTECOEX_R_DATA_V1_8814B(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA_V1_8814B) \
<< BIT_SHIFT_LTECOEX_R_DATA_V1_8814B)
#define BITS_LTECOEX_R_DATA_V1_8814B \
(BIT_MASK_LTECOEX_R_DATA_V1_8814B << BIT_SHIFT_LTECOEX_R_DATA_V1_8814B)
#define BIT_CLEAR_LTECOEX_R_DATA_V1_8814B(x) \
((x) & (~BITS_LTECOEX_R_DATA_V1_8814B))
#define BIT_GET_LTECOEX_R_DATA_V1_8814B(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA_V1_8814B) & \
BIT_MASK_LTECOEX_R_DATA_V1_8814B)
#define BIT_SET_LTECOEX_R_DATA_V1_8814B(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA_V1_8814B(x) | BIT_LTECOEX_R_DATA_V1_8814B(v))
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_NOT_VALID_8814B */
/* 2 REG_PCIE_CFG_FORCE_LINK_L_8814B */
#define BIT_PCIE_CFG_FORCE_EN_8814B BIT(7)
/* 2 REG_PCIE_CFG_FORCE_LINK_H_8814B */
#define BIT_PCIE_CFG_TRXACT_DIS_IDLE_TIMER_8814B BIT(6)
#define BIT_SHIFT_PCIE_CFG_LINK_STATE_8814B 0
#define BIT_MASK_PCIE_CFG_LINK_STATE_8814B 0x3f
#define BIT_PCIE_CFG_LINK_STATE_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_LINK_STATE_8814B) \
<< BIT_SHIFT_PCIE_CFG_LINK_STATE_8814B)
#define BITS_PCIE_CFG_LINK_STATE_8814B \
(BIT_MASK_PCIE_CFG_LINK_STATE_8814B \
<< BIT_SHIFT_PCIE_CFG_LINK_STATE_8814B)
#define BIT_CLEAR_PCIE_CFG_LINK_STATE_8814B(x) \
((x) & (~BITS_PCIE_CFG_LINK_STATE_8814B))
#define BIT_GET_PCIE_CFG_LINK_STATE_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_LINK_STATE_8814B) & \
BIT_MASK_PCIE_CFG_LINK_STATE_8814B)
#define BIT_SET_PCIE_CFG_LINK_STATE_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_LINK_STATE_8814B(x) | \
BIT_PCIE_CFG_LINK_STATE_8814B(v))
/* 2 REG_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B */
#define BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B 0
#define BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B 0xff
#define BIT_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B)
#define BITS_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B \
(BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B))
#define BIT_GET_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B) & \
BIT_MASK_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B)
#define BIT_SET_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B(x) | \
BIT_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B(v))
/* 2 REG_PCIE_CFG_CX_NFTS_8814B */
#define BIT_SHIFT_PCIE_CFG_CX_NFTS_8814B 0
#define BIT_MASK_PCIE_CFG_CX_NFTS_8814B 0xff
#define BIT_PCIE_CFG_CX_NFTS_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_CX_NFTS_8814B) \
<< BIT_SHIFT_PCIE_CFG_CX_NFTS_8814B)
#define BITS_PCIE_CFG_CX_NFTS_8814B \
(BIT_MASK_PCIE_CFG_CX_NFTS_8814B << BIT_SHIFT_PCIE_CFG_CX_NFTS_8814B)
#define BIT_CLEAR_PCIE_CFG_CX_NFTS_8814B(x) \
((x) & (~BITS_PCIE_CFG_CX_NFTS_8814B))
#define BIT_GET_PCIE_CFG_CX_NFTS_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_CX_NFTS_8814B) & \
BIT_MASK_PCIE_CFG_CX_NFTS_8814B)
#define BIT_SET_PCIE_CFG_CX_NFTS_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_CX_NFTS_8814B(x) | BIT_PCIE_CFG_CX_NFTS_8814B(v))
/* 2 REG_PCIE_CFG_DEFAULT_ENTR_LATENCY_8814B */
#define BIT_PCIE_CFG_REAL_EN_L0S_8814B BIT(7)
#define BIT_PCIE_CFG_ENTER_ASPM_8814B BIT(6)
#define BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B 3
#define BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B 0x7
#define BIT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B)
#define BITS_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B \
(BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B))
#define BIT_GET_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B) & \
BIT_MASK_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B)
#define BIT_SET_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B(x) | \
BIT_PCIE_CFG_DEFAULT_L1_ENTR_LATENCY_8814B(v))
#define BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B 0
#define BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B 0x7
#define BIT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B)
#define BITS_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B \
(BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B))
#define BIT_GET_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B) & \
BIT_MASK_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B)
#define BIT_SET_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B(x) | \
BIT_PCIE_CFG_DEFAULT_L0S_ENTR_LATENCY_8814B(v))
/* 2 REG_PCIE_CFG_L1_MISC_SEL_8814B */
#define BIT_PCIE_CFG_L1_RIDLE_SEL_8814B BIT(6)
#define BIT_PCIE_CFG_L1_TIMEOUT_SEL_8814B BIT(5)
#define BIT_PCIE_CFG_L1_EIDLE_SEL_8814B BIT(4)
#define BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE_8814B 0
#define BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE_8814B 0xf
#define BIT_PCIE_CFG_DEFAULT_LINK_RATE_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE_8814B) \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE_8814B)
#define BITS_PCIE_CFG_DEFAULT_LINK_RATE_8814B \
(BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE_8814B \
<< BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE_8814B)
#define BIT_CLEAR_PCIE_CFG_DEFAULT_LINK_RATE_8814B(x) \
((x) & (~BITS_PCIE_CFG_DEFAULT_LINK_RATE_8814B))
#define BIT_GET_PCIE_CFG_DEFAULT_LINK_RATE_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_DEFAULT_LINK_RATE_8814B) & \
BIT_MASK_PCIE_CFG_DEFAULT_LINK_RATE_8814B)
#define BIT_SET_PCIE_CFG_DEFAULT_LINK_RATE_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_DEFAULT_LINK_RATE_8814B(x) | \
BIT_PCIE_CFG_DEFAULT_LINK_RATE_8814B(v))
/* 2 REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF_8814B */
#define BIT_PCIE_CFG_REAL_PTM_ENABLE_8814B BIT(6)
#define BIT_PCIE_CFG_REAL_EN_L1SUB_8814B BIT(5)
#define BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM_8814B 0
#define BIT_MASK_PCIE_CFG_MAX_FUNC_NUM_8814B 0x7
#define BIT_PCIE_CFG_MAX_FUNC_NUM_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_MAX_FUNC_NUM_8814B) \
<< BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM_8814B)
#define BITS_PCIE_CFG_MAX_FUNC_NUM_8814B \
(BIT_MASK_PCIE_CFG_MAX_FUNC_NUM_8814B \
<< BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM_8814B)
#define BIT_CLEAR_PCIE_CFG_MAX_FUNC_NUM_8814B(x) \
((x) & (~BITS_PCIE_CFG_MAX_FUNC_NUM_8814B))
#define BIT_GET_PCIE_CFG_MAX_FUNC_NUM_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_MAX_FUNC_NUM_8814B) & \
BIT_MASK_PCIE_CFG_MAX_FUNC_NUM_8814B)
#define BIT_SET_PCIE_CFG_MAX_FUNC_NUM_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_MAX_FUNC_NUM_8814B(x) | \
BIT_PCIE_CFG_MAX_FUNC_NUM_8814B(v))
/* 2 REG_PCIE_CFG_FORCE_CLKREQ_N_PAD_8814B */
#define BIT_PCIE_CFG_REAL_EN_64BITS_8814B BIT(5)
#define BIT_PCIE_CFG_REAL_EN_CLKREQ_8814B BIT(4)
#define BIT_PCIE_CFG_REAL_EN_L1_8814B BIT(3)
#define BIT_PCIE_CFG_WAKE_N_EN_8814B BIT(2)
#define BIT_PCIE_CFG_BYPASS_LTR_OPTION_8814B BIT(1)
#define BIT_PCIE_CFG_FORCE_CLKREQ_N_PAD_8814B BIT(0)
/* 2 REG_PCIE_CFG_TIMER_MODIFIER_FOR_ACK_NAK_LATENCY_8814B */
#define BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B 0
#define BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B 0xff
#define BIT_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B) \
<< BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B)
#define BITS_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B \
(BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B \
<< BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B)
#define BIT_CLEAR_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B(x) \
((x) & (~BITS_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B))
#define BIT_GET_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B) & \
BIT_MASK_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B)
#define BIT_SET_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B(x) | \
BIT_PCIE_CFG_TIMER_MOD_ACK_NAK_8814B(v))
/* 2 REG_PCIE_CFG_TIMER_MODIFIER_FOR_FLOW_CONTROL_WATCHDOG_8814B */
#define BIT_PCIE_CFG_BYPASS_L1_SUBSTATE_OPTION_8814B BIT(7)
#define BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B 5
#define BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B 0x3
#define BIT_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B) \
<< BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B)
#define BITS_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B \
(BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B \
<< BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B)
#define BIT_CLEAR_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B(x) \
((x) & (~BITS_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B))
#define BIT_GET_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B) & \
BIT_MASK_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B)
#define BIT_SET_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B(x) | \
BIT_PCIE_CFG_FAST_LINK_SCALING_FACTOR_8814B(v))
#define BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER_8814B 0
#define BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER_8814B 0x1f
#define BIT_PCIE_CFG_UPDATE_FREQ_TIMER_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER_8814B) \
<< BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER_8814B)
#define BITS_PCIE_CFG_UPDATE_FREQ_TIMER_8814B \
(BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER_8814B \
<< BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER_8814B)
#define BIT_CLEAR_PCIE_CFG_UPDATE_FREQ_TIMER_8814B(x) \
((x) & (~BITS_PCIE_CFG_UPDATE_FREQ_TIMER_8814B))
#define BIT_GET_PCIE_CFG_UPDATE_FREQ_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_UPDATE_FREQ_TIMER_8814B) & \
BIT_MASK_PCIE_CFG_UPDATE_FREQ_TIMER_8814B)
#define BIT_SET_PCIE_CFG_UPDATE_FREQ_TIMER_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_UPDATE_FREQ_TIMER_8814B(x) | \
BIT_PCIE_CFG_UPDATE_FREQ_TIMER_8814B(v))
/* 2 REG_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B */
#define BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B 0
#define BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B 0xff
#define BIT_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B) \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B)
#define BITS_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B \
(BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B)
#define BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B(x) \
((x) & (~BITS_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B))
#define BIT_GET_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B) & \
BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B)
#define BIT_SET_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B(x) | \
BIT_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B(v))
/* 2 REG_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B */
#define BIT_PCIE_CFG_DISABLE_FC_WATCHDOG_TIMER_8814B BIT(7)
#define BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B 0
#define BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B 0x7
#define BIT_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B) \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B)
#define BITS_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B \
(BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B \
<< BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B)
#define BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B(x) \
((x) & (~BITS_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B))
#define BIT_GET_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B) & \
BIT_MASK_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B)
#define BIT_SET_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B(x) | \
BIT_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B(v))
/* 2 REG_PCIE_CFG_L1_UNIT_SEL_8814B */
#define BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL_8814B 0
#define BIT_MASK_PCIE_CFG_L1_UNIT_SEL_8814B 0xff
#define BIT_PCIE_CFG_L1_UNIT_SEL_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_L1_UNIT_SEL_8814B) \
<< BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL_8814B)
#define BITS_PCIE_CFG_L1_UNIT_SEL_8814B \
(BIT_MASK_PCIE_CFG_L1_UNIT_SEL_8814B \
<< BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL_8814B)
#define BIT_CLEAR_PCIE_CFG_L1_UNIT_SEL_8814B(x) \
((x) & (~BITS_PCIE_CFG_L1_UNIT_SEL_8814B))
#define BIT_GET_PCIE_CFG_L1_UNIT_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_L1_UNIT_SEL_8814B) & \
BIT_MASK_PCIE_CFG_L1_UNIT_SEL_8814B)
#define BIT_SET_PCIE_CFG_L1_UNIT_SEL_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_L1_UNIT_SEL_8814B(x) | \
BIT_PCIE_CFG_L1_UNIT_SEL_8814B(v))
/* 2 REG_PCIE_CFG_MIN_CLKREQ_SEL_8814B */
#define BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL_8814B 0
#define BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL_8814B 0xf
#define BIT_PCIE_CFG_MIN_CLKREQ_SEL_8814B(x) \
(((x) & BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL_8814B) \
<< BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL_8814B)
#define BITS_PCIE_CFG_MIN_CLKREQ_SEL_8814B \
(BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL_8814B \
<< BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL_8814B)
#define BIT_CLEAR_PCIE_CFG_MIN_CLKREQ_SEL_8814B(x) \
((x) & (~BITS_PCIE_CFG_MIN_CLKREQ_SEL_8814B))
#define BIT_GET_PCIE_CFG_MIN_CLKREQ_SEL_8814B(x) \
(((x) >> BIT_SHIFT_PCIE_CFG_MIN_CLKREQ_SEL_8814B) & \
BIT_MASK_PCIE_CFG_MIN_CLKREQ_SEL_8814B)
#define BIT_SET_PCIE_CFG_MIN_CLKREQ_SEL_8814B(x, v) \
(BIT_CLEAR_PCIE_CFG_MIN_CLKREQ_SEL_8814B(x) | \
BIT_PCIE_CFG_MIN_CLKREQ_SEL_8814B(v))
/* 2 REG_SDIO_TX_CTRL_8814B */
#define BIT_SHIFT_SDIO_INT_TIMEOUT_8814B 16
#define BIT_MASK_SDIO_INT_TIMEOUT_8814B 0xffff
#define BIT_SDIO_INT_TIMEOUT_8814B(x) \
(((x) & BIT_MASK_SDIO_INT_TIMEOUT_8814B) \
<< BIT_SHIFT_SDIO_INT_TIMEOUT_8814B)
#define BITS_SDIO_INT_TIMEOUT_8814B \
(BIT_MASK_SDIO_INT_TIMEOUT_8814B << BIT_SHIFT_SDIO_INT_TIMEOUT_8814B)
#define BIT_CLEAR_SDIO_INT_TIMEOUT_8814B(x) \
((x) & (~BITS_SDIO_INT_TIMEOUT_8814B))
#define BIT_GET_SDIO_INT_TIMEOUT_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_INT_TIMEOUT_8814B) & \
BIT_MASK_SDIO_INT_TIMEOUT_8814B)
#define BIT_SET_SDIO_INT_TIMEOUT_8814B(x, v) \
(BIT_CLEAR_SDIO_INT_TIMEOUT_8814B(x) | BIT_SDIO_INT_TIMEOUT_8814B(v))
#define BIT_IO_ERR_STATUS_8814B BIT(15)
#define BIT_REPLY_ERRCRC_IN_DATA_8814B BIT(9)
#define BIT_EN_CMD53_OVERLAP_8814B BIT(8)
#define BIT_REPLY_ERR_IN_R5_8814B BIT(7)
#define BIT_R18A_EN_8814B BIT(6)
#define BIT_SDIO_CMD_FORCE_VLD_8814B BIT(5)
#define BIT_INIT_CMD_EN_8814B BIT(4)
#define BIT_EN_RXDMA_MASK_INT_8814B BIT(2)
#define BIT_EN_MASK_TIMER_8814B BIT(1)
#define BIT_CMD_ERR_STOP_INT_EN_8814B BIT(0)
/* 2 REG_SDIO_HIMR_8814B */
#define BIT_SDIO_CRCERR_MSK_8814B BIT(31)
#define BIT_SDIO_HSISR3_IND_MSK_8814B BIT(30)
#define BIT_SDIO_HSISR2_IND_MSK_8814B BIT(29)
#define BIT_SDIO_HEISR_IND_MSK_8814B BIT(28)
#define BIT_SDIO_CTWEND_MSK_8814B BIT(27)
#define BIT_SDIO_ATIMEND_E_MSK_8814B BIT(26)
#define BIT_SDIIO_ATIMEND_MSK_8814B BIT(25)
#define BIT_SDIO_OCPINT_MSK_8814B BIT(24)
#define BIT_SDIO_PSTIMEOUT_MSK_8814B BIT(23)
#define BIT_SDIO_GTINT4_MSK_8814B BIT(22)
#define BIT_SDIO_GTINT3_MSK_8814B BIT(21)
#define BIT_SDIO_HSISR_IND_MSK_8814B BIT(20)
#define BIT_SDIO_CPWM2_MSK_8814B BIT(19)
#define BIT_SDIO_CPWM1_MSK_8814B BIT(18)
#define BIT_SDIO_C2HCMD_INT_MSK_8814B BIT(17)
#define BIT_SDIO_BCNERLY_INT_MSK_8814B BIT(16)
#define BIT_SDIO_TXBCNERR_MSK_8814B BIT(7)
#define BIT_SDIO_TXBCNOK_MSK_8814B BIT(6)
#define BIT_SDIO_RXFOVW_MSK_8814B BIT(5)
#define BIT_SDIO_TXFOVW_MSK_8814B BIT(4)
#define BIT_SDIO_RXERR_MSK_8814B BIT(3)
#define BIT_SDIO_TXERR_MSK_8814B BIT(2)
#define BIT_SDIO_AVAL_MSK_8814B BIT(1)
#define BIT_RX_REQUEST_MSK_8814B BIT(0)
/* 2 REG_SDIO_HISR_8814B */
#define BIT_SDIO_CRCERR_8814B BIT(31)
#define BIT_SDIO_HSISR3_IND_8814B BIT(30)
#define BIT_SDIO_HSISR2_IND_8814B BIT(29)
#define BIT_SDIO_HEISR_IND_8814B BIT(28)
#define BIT_SDIO_CTWEND_8814B BIT(27)
#define BIT_SDIO_ATIMEND_E_8814B BIT(26)
#define BIT_SDIO_ATIMEND_8814B BIT(25)
#define BIT_SDIO_OCPINT_8814B BIT(24)
#define BIT_SDIO_PSTIMEOUT_8814B BIT(23)
#define BIT_SDIO_GTINT4_8814B BIT(22)
#define BIT_SDIO_GTINT3_8814B BIT(21)
#define BIT_SDIO_HSISR_IND_8814B BIT(20)
#define BIT_SDIO_CPWM2_8814B BIT(19)
#define BIT_SDIO_CPWM1_8814B BIT(18)
#define BIT_SDIO_C2HCMD_INT_8814B BIT(17)
#define BIT_SDIO_BCNERLY_INT_8814B BIT(16)
#define BIT_SDIO_TXBCNERR_8814B BIT(7)
#define BIT_SDIO_TXBCNOK_8814B BIT(6)
#define BIT_SDIO_RXFOVW_8814B BIT(5)
#define BIT_SDIO_TXFOVW_8814B BIT(4)
#define BIT_SDIO_RXERR_8814B BIT(3)
#define BIT_SDIO_TXERR_8814B BIT(2)
#define BIT_SDIO_AVAL_8814B BIT(1)
#define BIT_RX_REQUEST_8814B BIT(0)
/* 2 REG_SDIO_RX_REQ_LEN_8814B */
#define BIT_SHIFT_RX_REQ_LEN_V1_8814B 0
#define BIT_MASK_RX_REQ_LEN_V1_8814B 0x3ffff
#define BIT_RX_REQ_LEN_V1_8814B(x) \
(((x) & BIT_MASK_RX_REQ_LEN_V1_8814B) << BIT_SHIFT_RX_REQ_LEN_V1_8814B)
#define BITS_RX_REQ_LEN_V1_8814B \
(BIT_MASK_RX_REQ_LEN_V1_8814B << BIT_SHIFT_RX_REQ_LEN_V1_8814B)
#define BIT_CLEAR_RX_REQ_LEN_V1_8814B(x) ((x) & (~BITS_RX_REQ_LEN_V1_8814B))
#define BIT_GET_RX_REQ_LEN_V1_8814B(x) \
(((x) >> BIT_SHIFT_RX_REQ_LEN_V1_8814B) & BIT_MASK_RX_REQ_LEN_V1_8814B)
#define BIT_SET_RX_REQ_LEN_V1_8814B(x, v) \
(BIT_CLEAR_RX_REQ_LEN_V1_8814B(x) | BIT_RX_REQ_LEN_V1_8814B(v))
/* 2 REG_SDIO_FREE_TXPG_SEQ_V1_8814B */
#define BIT_SHIFT_FREE_TXPG_SEQ_8814B 0
#define BIT_MASK_FREE_TXPG_SEQ_8814B 0xff
#define BIT_FREE_TXPG_SEQ_8814B(x) \
(((x) & BIT_MASK_FREE_TXPG_SEQ_8814B) << BIT_SHIFT_FREE_TXPG_SEQ_8814B)
#define BITS_FREE_TXPG_SEQ_8814B \
(BIT_MASK_FREE_TXPG_SEQ_8814B << BIT_SHIFT_FREE_TXPG_SEQ_8814B)
#define BIT_CLEAR_FREE_TXPG_SEQ_8814B(x) ((x) & (~BITS_FREE_TXPG_SEQ_8814B))
#define BIT_GET_FREE_TXPG_SEQ_8814B(x) \
(((x) >> BIT_SHIFT_FREE_TXPG_SEQ_8814B) & BIT_MASK_FREE_TXPG_SEQ_8814B)
#define BIT_SET_FREE_TXPG_SEQ_8814B(x, v) \
(BIT_CLEAR_FREE_TXPG_SEQ_8814B(x) | BIT_FREE_TXPG_SEQ_8814B(v))
/* 2 REG_SDIO_FREE_TXPG_8814B */
#define BIT_SHIFT_MID_FREEPG_V1_8814B 16
#define BIT_MASK_MID_FREEPG_V1_8814B 0xfff
#define BIT_MID_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_MID_FREEPG_V1_8814B) << BIT_SHIFT_MID_FREEPG_V1_8814B)
#define BITS_MID_FREEPG_V1_8814B \
(BIT_MASK_MID_FREEPG_V1_8814B << BIT_SHIFT_MID_FREEPG_V1_8814B)
#define BIT_CLEAR_MID_FREEPG_V1_8814B(x) ((x) & (~BITS_MID_FREEPG_V1_8814B))
#define BIT_GET_MID_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_MID_FREEPG_V1_8814B) & BIT_MASK_MID_FREEPG_V1_8814B)
#define BIT_SET_MID_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_MID_FREEPG_V1_8814B(x) | BIT_MID_FREEPG_V1_8814B(v))
#define BIT_SHIFT_HIQ_FREEPG_V1_8814B 0
#define BIT_MASK_HIQ_FREEPG_V1_8814B 0xfff
#define BIT_HIQ_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_HIQ_FREEPG_V1_8814B) << BIT_SHIFT_HIQ_FREEPG_V1_8814B)
#define BITS_HIQ_FREEPG_V1_8814B \
(BIT_MASK_HIQ_FREEPG_V1_8814B << BIT_SHIFT_HIQ_FREEPG_V1_8814B)
#define BIT_CLEAR_HIQ_FREEPG_V1_8814B(x) ((x) & (~BITS_HIQ_FREEPG_V1_8814B))
#define BIT_GET_HIQ_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_HIQ_FREEPG_V1_8814B) & BIT_MASK_HIQ_FREEPG_V1_8814B)
#define BIT_SET_HIQ_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_HIQ_FREEPG_V1_8814B(x) | BIT_HIQ_FREEPG_V1_8814B(v))
/* 2 REG_SDIO_FREE_TXPG2_8814B */
#define BIT_SHIFT_PUB_FREEPG_V1_8814B 16
#define BIT_MASK_PUB_FREEPG_V1_8814B 0xfff
#define BIT_PUB_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_PUB_FREEPG_V1_8814B) << BIT_SHIFT_PUB_FREEPG_V1_8814B)
#define BITS_PUB_FREEPG_V1_8814B \
(BIT_MASK_PUB_FREEPG_V1_8814B << BIT_SHIFT_PUB_FREEPG_V1_8814B)
#define BIT_CLEAR_PUB_FREEPG_V1_8814B(x) ((x) & (~BITS_PUB_FREEPG_V1_8814B))
#define BIT_GET_PUB_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_PUB_FREEPG_V1_8814B) & BIT_MASK_PUB_FREEPG_V1_8814B)
#define BIT_SET_PUB_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_PUB_FREEPG_V1_8814B(x) | BIT_PUB_FREEPG_V1_8814B(v))
#define BIT_SHIFT_LOW_FREEPG_V1_8814B 0
#define BIT_MASK_LOW_FREEPG_V1_8814B 0xfff
#define BIT_LOW_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_LOW_FREEPG_V1_8814B) << BIT_SHIFT_LOW_FREEPG_V1_8814B)
#define BITS_LOW_FREEPG_V1_8814B \
(BIT_MASK_LOW_FREEPG_V1_8814B << BIT_SHIFT_LOW_FREEPG_V1_8814B)
#define BIT_CLEAR_LOW_FREEPG_V1_8814B(x) ((x) & (~BITS_LOW_FREEPG_V1_8814B))
#define BIT_GET_LOW_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_LOW_FREEPG_V1_8814B) & BIT_MASK_LOW_FREEPG_V1_8814B)
#define BIT_SET_LOW_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_LOW_FREEPG_V1_8814B(x) | BIT_LOW_FREEPG_V1_8814B(v))
/* 2 REG_SDIO_OQT_FREE_TXPG_V1_8814B */
#define BIT_SHIFT_NOAC_OQT_FREEPG_V1_8814B 24
#define BIT_MASK_NOAC_OQT_FREEPG_V1_8814B 0xff
#define BIT_NOAC_OQT_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_NOAC_OQT_FREEPG_V1_8814B) \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8814B)
#define BITS_NOAC_OQT_FREEPG_V1_8814B \
(BIT_MASK_NOAC_OQT_FREEPG_V1_8814B \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8814B)
#define BIT_CLEAR_NOAC_OQT_FREEPG_V1_8814B(x) \
((x) & (~BITS_NOAC_OQT_FREEPG_V1_8814B))
#define BIT_GET_NOAC_OQT_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_NOAC_OQT_FREEPG_V1_8814B) & \
BIT_MASK_NOAC_OQT_FREEPG_V1_8814B)
#define BIT_SET_NOAC_OQT_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_NOAC_OQT_FREEPG_V1_8814B(x) | \
BIT_NOAC_OQT_FREEPG_V1_8814B(v))
#define BIT_SHIFT_AC_OQT_FREEPG_V1_8814B 16
#define BIT_MASK_AC_OQT_FREEPG_V1_8814B 0xff
#define BIT_AC_OQT_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_AC_OQT_FREEPG_V1_8814B) \
<< BIT_SHIFT_AC_OQT_FREEPG_V1_8814B)
#define BITS_AC_OQT_FREEPG_V1_8814B \
(BIT_MASK_AC_OQT_FREEPG_V1_8814B << BIT_SHIFT_AC_OQT_FREEPG_V1_8814B)
#define BIT_CLEAR_AC_OQT_FREEPG_V1_8814B(x) \
((x) & (~BITS_AC_OQT_FREEPG_V1_8814B))
#define BIT_GET_AC_OQT_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_AC_OQT_FREEPG_V1_8814B) & \
BIT_MASK_AC_OQT_FREEPG_V1_8814B)
#define BIT_SET_AC_OQT_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_AC_OQT_FREEPG_V1_8814B(x) | BIT_AC_OQT_FREEPG_V1_8814B(v))
#define BIT_SHIFT_EXQ_FREEPG_V1_8814B 0
#define BIT_MASK_EXQ_FREEPG_V1_8814B 0xfff
#define BIT_EXQ_FREEPG_V1_8814B(x) \
(((x) & BIT_MASK_EXQ_FREEPG_V1_8814B) << BIT_SHIFT_EXQ_FREEPG_V1_8814B)
#define BITS_EXQ_FREEPG_V1_8814B \
(BIT_MASK_EXQ_FREEPG_V1_8814B << BIT_SHIFT_EXQ_FREEPG_V1_8814B)
#define BIT_CLEAR_EXQ_FREEPG_V1_8814B(x) ((x) & (~BITS_EXQ_FREEPG_V1_8814B))
#define BIT_GET_EXQ_FREEPG_V1_8814B(x) \
(((x) >> BIT_SHIFT_EXQ_FREEPG_V1_8814B) & BIT_MASK_EXQ_FREEPG_V1_8814B)
#define BIT_SET_EXQ_FREEPG_V1_8814B(x, v) \
(BIT_CLEAR_EXQ_FREEPG_V1_8814B(x) | BIT_EXQ_FREEPG_V1_8814B(v))
/* 2 REG_SDIO_HTSFR_INFO_8814B */
#define BIT_SHIFT_HTSFR1_8814B 16
#define BIT_MASK_HTSFR1_8814B 0xffff
#define BIT_HTSFR1_8814B(x) \
(((x) & BIT_MASK_HTSFR1_8814B) << BIT_SHIFT_HTSFR1_8814B)
#define BITS_HTSFR1_8814B (BIT_MASK_HTSFR1_8814B << BIT_SHIFT_HTSFR1_8814B)
#define BIT_CLEAR_HTSFR1_8814B(x) ((x) & (~BITS_HTSFR1_8814B))
#define BIT_GET_HTSFR1_8814B(x) \
(((x) >> BIT_SHIFT_HTSFR1_8814B) & BIT_MASK_HTSFR1_8814B)
#define BIT_SET_HTSFR1_8814B(x, v) \
(BIT_CLEAR_HTSFR1_8814B(x) | BIT_HTSFR1_8814B(v))
#define BIT_SHIFT_HTSFR0_8814B 0
#define BIT_MASK_HTSFR0_8814B 0xffff
#define BIT_HTSFR0_8814B(x) \
(((x) & BIT_MASK_HTSFR0_8814B) << BIT_SHIFT_HTSFR0_8814B)
#define BITS_HTSFR0_8814B (BIT_MASK_HTSFR0_8814B << BIT_SHIFT_HTSFR0_8814B)
#define BIT_CLEAR_HTSFR0_8814B(x) ((x) & (~BITS_HTSFR0_8814B))
#define BIT_GET_HTSFR0_8814B(x) \
(((x) >> BIT_SHIFT_HTSFR0_8814B) & BIT_MASK_HTSFR0_8814B)
#define BIT_SET_HTSFR0_8814B(x, v) \
(BIT_CLEAR_HTSFR0_8814B(x) | BIT_HTSFR0_8814B(v))
/* 2 REG_SDIO_HCPWM1_V2_8814B */
#define BIT_TOGGLE_8814B BIT(7)
#define BIT_CUR_PS_8814B BIT(0)
/* 2 REG_SDIO_HCPWM2_V2_8814B */
/* 2 REG_SDIO_INDIRECT_REG_CFG_8814B */
#define BIT_INDIRECT_REG_RDY_8814B BIT(20)
#define BIT_INDIRECT_REG_R_8814B BIT(19)
#define BIT_INDIRECT_REG_W_8814B BIT(18)
#define BIT_SHIFT_INDIRECT_REG_SIZE_8814B 16
#define BIT_MASK_INDIRECT_REG_SIZE_8814B 0x3
#define BIT_INDIRECT_REG_SIZE_8814B(x) \
(((x) & BIT_MASK_INDIRECT_REG_SIZE_8814B) \
<< BIT_SHIFT_INDIRECT_REG_SIZE_8814B)
#define BITS_INDIRECT_REG_SIZE_8814B \
(BIT_MASK_INDIRECT_REG_SIZE_8814B << BIT_SHIFT_INDIRECT_REG_SIZE_8814B)
#define BIT_CLEAR_INDIRECT_REG_SIZE_8814B(x) \
((x) & (~BITS_INDIRECT_REG_SIZE_8814B))
#define BIT_GET_INDIRECT_REG_SIZE_8814B(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_SIZE_8814B) & \
BIT_MASK_INDIRECT_REG_SIZE_8814B)
#define BIT_SET_INDIRECT_REG_SIZE_8814B(x, v) \
(BIT_CLEAR_INDIRECT_REG_SIZE_8814B(x) | BIT_INDIRECT_REG_SIZE_8814B(v))
#define BIT_SHIFT_INDIRECT_REG_ADDR_8814B 0
#define BIT_MASK_INDIRECT_REG_ADDR_8814B 0xffff
#define BIT_INDIRECT_REG_ADDR_8814B(x) \
(((x) & BIT_MASK_INDIRECT_REG_ADDR_8814B) \
<< BIT_SHIFT_INDIRECT_REG_ADDR_8814B)
#define BITS_INDIRECT_REG_ADDR_8814B \
(BIT_MASK_INDIRECT_REG_ADDR_8814B << BIT_SHIFT_INDIRECT_REG_ADDR_8814B)
#define BIT_CLEAR_INDIRECT_REG_ADDR_8814B(x) \
((x) & (~BITS_INDIRECT_REG_ADDR_8814B))
#define BIT_GET_INDIRECT_REG_ADDR_8814B(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_ADDR_8814B) & \
BIT_MASK_INDIRECT_REG_ADDR_8814B)
#define BIT_SET_INDIRECT_REG_ADDR_8814B(x, v) \
(BIT_CLEAR_INDIRECT_REG_ADDR_8814B(x) | BIT_INDIRECT_REG_ADDR_8814B(v))
/* 2 REG_SDIO_INDIRECT_REG_DATA_8814B */
#define BIT_SHIFT_INDIRECT_REG_DATA_8814B 0
#define BIT_MASK_INDIRECT_REG_DATA_8814B 0xffffffffL
#define BIT_INDIRECT_REG_DATA_8814B(x) \
(((x) & BIT_MASK_INDIRECT_REG_DATA_8814B) \
<< BIT_SHIFT_INDIRECT_REG_DATA_8814B)
#define BITS_INDIRECT_REG_DATA_8814B \
(BIT_MASK_INDIRECT_REG_DATA_8814B << BIT_SHIFT_INDIRECT_REG_DATA_8814B)
#define BIT_CLEAR_INDIRECT_REG_DATA_8814B(x) \
((x) & (~BITS_INDIRECT_REG_DATA_8814B))
#define BIT_GET_INDIRECT_REG_DATA_8814B(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_DATA_8814B) & \
BIT_MASK_INDIRECT_REG_DATA_8814B)
#define BIT_SET_INDIRECT_REG_DATA_8814B(x, v) \
(BIT_CLEAR_INDIRECT_REG_DATA_8814B(x) | BIT_INDIRECT_REG_DATA_8814B(v))
/* 2 REG_SDIO_H2C_8814B */
#define BIT_SHIFT_SDIO_H2C_MSG_8814B 0
#define BIT_MASK_SDIO_H2C_MSG_8814B 0xffffffffL
#define BIT_SDIO_H2C_MSG_8814B(x) \
(((x) & BIT_MASK_SDIO_H2C_MSG_8814B) << BIT_SHIFT_SDIO_H2C_MSG_8814B)
#define BITS_SDIO_H2C_MSG_8814B \
(BIT_MASK_SDIO_H2C_MSG_8814B << BIT_SHIFT_SDIO_H2C_MSG_8814B)
#define BIT_CLEAR_SDIO_H2C_MSG_8814B(x) ((x) & (~BITS_SDIO_H2C_MSG_8814B))
#define BIT_GET_SDIO_H2C_MSG_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_H2C_MSG_8814B) & BIT_MASK_SDIO_H2C_MSG_8814B)
#define BIT_SET_SDIO_H2C_MSG_8814B(x, v) \
(BIT_CLEAR_SDIO_H2C_MSG_8814B(x) | BIT_SDIO_H2C_MSG_8814B(v))
/* 2 REG_SDIO_C2H_8814B */
#define BIT_SHIFT_SDIO_C2H_MSG_8814B 0
#define BIT_MASK_SDIO_C2H_MSG_8814B 0xffffffffL
#define BIT_SDIO_C2H_MSG_8814B(x) \
(((x) & BIT_MASK_SDIO_C2H_MSG_8814B) << BIT_SHIFT_SDIO_C2H_MSG_8814B)
#define BITS_SDIO_C2H_MSG_8814B \
(BIT_MASK_SDIO_C2H_MSG_8814B << BIT_SHIFT_SDIO_C2H_MSG_8814B)
#define BIT_CLEAR_SDIO_C2H_MSG_8814B(x) ((x) & (~BITS_SDIO_C2H_MSG_8814B))
#define BIT_GET_SDIO_C2H_MSG_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_C2H_MSG_8814B) & BIT_MASK_SDIO_C2H_MSG_8814B)
#define BIT_SET_SDIO_C2H_MSG_8814B(x, v) \
(BIT_CLEAR_SDIO_C2H_MSG_8814B(x) | BIT_SDIO_C2H_MSG_8814B(v))
/* 2 REG_SDIO_HRPWM1_8814B */
#define BIT_TOGGLE_8814B BIT(7)
#define BIT_ACK_8814B BIT(6)
#define BIT_REQ_PS_8814B BIT(0)
/* 2 REG_SDIO_HRPWM2_8814B */
/* 2 REG_SDIO_HPS_CLKR_8814B */
/* 2 REG_SDIO_BUS_CTRL_8814B */
#define BIT_PAD_CLK_XHGE_EN_8814B BIT(3)
#define BIT_INTER_CLK_EN_8814B BIT(2)
#define BIT_EN_RPT_TXCRC_8814B BIT(1)
#define BIT_DIS_RXDMA_STS_8814B BIT(0)
/* 2 REG_SDIO_HSUS_CTRL_8814B */
#define BIT_INTR_CTRL_8814B BIT(4)
#define BIT_SDIO_VOLTAGE_8814B BIT(3)
#define BIT_BYPASS_INIT_8814B BIT(2)
#define BIT_HCI_RESUME_RDY_8814B BIT(1)
#define BIT_HCI_SUS_REQ_8814B BIT(0)
/* 2 REG_SDIO_RESPONSE_TIMER_8814B */
#define BIT_SHIFT_CMDIN_2RESP_TIMER_8814B 0
#define BIT_MASK_CMDIN_2RESP_TIMER_8814B 0xffff
#define BIT_CMDIN_2RESP_TIMER_8814B(x) \
(((x) & BIT_MASK_CMDIN_2RESP_TIMER_8814B) \
<< BIT_SHIFT_CMDIN_2RESP_TIMER_8814B)
#define BITS_CMDIN_2RESP_TIMER_8814B \
(BIT_MASK_CMDIN_2RESP_TIMER_8814B << BIT_SHIFT_CMDIN_2RESP_TIMER_8814B)
#define BIT_CLEAR_CMDIN_2RESP_TIMER_8814B(x) \
((x) & (~BITS_CMDIN_2RESP_TIMER_8814B))
#define BIT_GET_CMDIN_2RESP_TIMER_8814B(x) \
(((x) >> BIT_SHIFT_CMDIN_2RESP_TIMER_8814B) & \
BIT_MASK_CMDIN_2RESP_TIMER_8814B)
#define BIT_SET_CMDIN_2RESP_TIMER_8814B(x, v) \
(BIT_CLEAR_CMDIN_2RESP_TIMER_8814B(x) | BIT_CMDIN_2RESP_TIMER_8814B(v))
/* 2 REG_SDIO_CMD_CRC_8814B */
#define BIT_SHIFT_SDIO_CMD_CRC_V1_8814B 0
#define BIT_MASK_SDIO_CMD_CRC_V1_8814B 0xff
#define BIT_SDIO_CMD_CRC_V1_8814B(x) \
(((x) & BIT_MASK_SDIO_CMD_CRC_V1_8814B) \
<< BIT_SHIFT_SDIO_CMD_CRC_V1_8814B)
#define BITS_SDIO_CMD_CRC_V1_8814B \
(BIT_MASK_SDIO_CMD_CRC_V1_8814B << BIT_SHIFT_SDIO_CMD_CRC_V1_8814B)
#define BIT_CLEAR_SDIO_CMD_CRC_V1_8814B(x) ((x) & (~BITS_SDIO_CMD_CRC_V1_8814B))
#define BIT_GET_SDIO_CMD_CRC_V1_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_CRC_V1_8814B) & \
BIT_MASK_SDIO_CMD_CRC_V1_8814B)
#define BIT_SET_SDIO_CMD_CRC_V1_8814B(x, v) \
(BIT_CLEAR_SDIO_CMD_CRC_V1_8814B(x) | BIT_SDIO_CMD_CRC_V1_8814B(v))
/* 2 REG_SDIO_HSISR_8814B */
#define BIT_DRV_WLAN_INT_CLR_8814B BIT(1)
#define BIT_DRV_WLAN_INT_8814B BIT(0)
/* 2 REG_SDIO_ERR_RPT_8814B */
#define BIT_HR_FF_OVF_8814B BIT(6)
#define BIT_HR_FF_UDN_8814B BIT(5)
#define BIT_TXDMA_BUSY_ERR_8814B BIT(4)
#define BIT_TXDMA_VLD_ERR_8814B BIT(3)
#define BIT_QSEL_UNKNOWN_ERR_8814B BIT(2)
#define BIT_QSEL_MIS_ERR_8814B BIT(1)
#define BIT_SDIO_OVERRD_ERR_8814B BIT(0)
/* 2 REG_SDIO_CMD_ERRCNT_8814B */
#define BIT_SHIFT_CMD_CRC_ERR_CNT_8814B 0
#define BIT_MASK_CMD_CRC_ERR_CNT_8814B 0xff
#define BIT_CMD_CRC_ERR_CNT_8814B(x) \
(((x) & BIT_MASK_CMD_CRC_ERR_CNT_8814B) \
<< BIT_SHIFT_CMD_CRC_ERR_CNT_8814B)
#define BITS_CMD_CRC_ERR_CNT_8814B \
(BIT_MASK_CMD_CRC_ERR_CNT_8814B << BIT_SHIFT_CMD_CRC_ERR_CNT_8814B)
#define BIT_CLEAR_CMD_CRC_ERR_CNT_8814B(x) ((x) & (~BITS_CMD_CRC_ERR_CNT_8814B))
#define BIT_GET_CMD_CRC_ERR_CNT_8814B(x) \
(((x) >> BIT_SHIFT_CMD_CRC_ERR_CNT_8814B) & \
BIT_MASK_CMD_CRC_ERR_CNT_8814B)
#define BIT_SET_CMD_CRC_ERR_CNT_8814B(x, v) \
(BIT_CLEAR_CMD_CRC_ERR_CNT_8814B(x) | BIT_CMD_CRC_ERR_CNT_8814B(v))
/* 2 REG_SDIO_DATA_ERRCNT_8814B */
#define BIT_SHIFT_DATA_CRC_ERR_CNT_8814B 0
#define BIT_MASK_DATA_CRC_ERR_CNT_8814B 0xff
#define BIT_DATA_CRC_ERR_CNT_8814B(x) \
(((x) & BIT_MASK_DATA_CRC_ERR_CNT_8814B) \
<< BIT_SHIFT_DATA_CRC_ERR_CNT_8814B)
#define BITS_DATA_CRC_ERR_CNT_8814B \
(BIT_MASK_DATA_CRC_ERR_CNT_8814B << BIT_SHIFT_DATA_CRC_ERR_CNT_8814B)
#define BIT_CLEAR_DATA_CRC_ERR_CNT_8814B(x) \
((x) & (~BITS_DATA_CRC_ERR_CNT_8814B))
#define BIT_GET_DATA_CRC_ERR_CNT_8814B(x) \
(((x) >> BIT_SHIFT_DATA_CRC_ERR_CNT_8814B) & \
BIT_MASK_DATA_CRC_ERR_CNT_8814B)
#define BIT_SET_DATA_CRC_ERR_CNT_8814B(x, v) \
(BIT_CLEAR_DATA_CRC_ERR_CNT_8814B(x) | BIT_DATA_CRC_ERR_CNT_8814B(v))
/* 2 REG_SDIO_CMD_ERR_CONTENT_8814B */
#define BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8814B 0
#define BIT_MASK_SDIO_CMD_ERR_CONTENT_8814B 0xffffffffffL
#define BIT_SDIO_CMD_ERR_CONTENT_8814B(x) \
(((x) & BIT_MASK_SDIO_CMD_ERR_CONTENT_8814B) \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8814B)
#define BITS_SDIO_CMD_ERR_CONTENT_8814B \
(BIT_MASK_SDIO_CMD_ERR_CONTENT_8814B \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8814B)
#define BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8814B(x) \
((x) & (~BITS_SDIO_CMD_ERR_CONTENT_8814B))
#define BIT_GET_SDIO_CMD_ERR_CONTENT_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8814B) & \
BIT_MASK_SDIO_CMD_ERR_CONTENT_8814B)
#define BIT_SET_SDIO_CMD_ERR_CONTENT_8814B(x, v) \
(BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8814B(x) | \
BIT_SDIO_CMD_ERR_CONTENT_8814B(v))
/* 2 REG_SDIO_CRC_ERR_IDX_8814B */
#define BIT_D3_CRC_ERR_8814B BIT(4)
#define BIT_D2_CRC_ERR_8814B BIT(3)
#define BIT_D1_CRC_ERR_8814B BIT(2)
#define BIT_D0_CRC_ERR_8814B BIT(1)
#define BIT_CMD_CRC_ERR_8814B BIT(0)
/* 2 REG_SDIO_DATA_CRC_8814B */
#define BIT_SHIFT_SDIO_DATA_CRC_8814B 0
#define BIT_MASK_SDIO_DATA_CRC_8814B 0xffff
#define BIT_SDIO_DATA_CRC_8814B(x) \
(((x) & BIT_MASK_SDIO_DATA_CRC_8814B) << BIT_SHIFT_SDIO_DATA_CRC_8814B)
#define BITS_SDIO_DATA_CRC_8814B \
(BIT_MASK_SDIO_DATA_CRC_8814B << BIT_SHIFT_SDIO_DATA_CRC_8814B)
#define BIT_CLEAR_SDIO_DATA_CRC_8814B(x) ((x) & (~BITS_SDIO_DATA_CRC_8814B))
#define BIT_GET_SDIO_DATA_CRC_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_CRC_8814B) & BIT_MASK_SDIO_DATA_CRC_8814B)
#define BIT_SET_SDIO_DATA_CRC_8814B(x, v) \
(BIT_CLEAR_SDIO_DATA_CRC_8814B(x) | BIT_SDIO_DATA_CRC_8814B(v))
/* 2 REG_SDIO_DATA_REPLY_TIME_8814B */
#define BIT_SHIFT_SDIO_DATA_REPLY_TIME_8814B 0
#define BIT_MASK_SDIO_DATA_REPLY_TIME_8814B 0x7
#define BIT_SDIO_DATA_REPLY_TIME_8814B(x) \
(((x) & BIT_MASK_SDIO_DATA_REPLY_TIME_8814B) \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME_8814B)
#define BITS_SDIO_DATA_REPLY_TIME_8814B \
(BIT_MASK_SDIO_DATA_REPLY_TIME_8814B \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME_8814B)
#define BIT_CLEAR_SDIO_DATA_REPLY_TIME_8814B(x) \
((x) & (~BITS_SDIO_DATA_REPLY_TIME_8814B))
#define BIT_GET_SDIO_DATA_REPLY_TIME_8814B(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_REPLY_TIME_8814B) & \
BIT_MASK_SDIO_DATA_REPLY_TIME_8814B)
#define BIT_SET_SDIO_DATA_REPLY_TIME_8814B(x, v) \
(BIT_CLEAR_SDIO_DATA_REPLY_TIME_8814B(x) | \
BIT_SDIO_DATA_REPLY_TIME_8814B(v))
#endif
================================================
FILE: hal/halmac/halmac_bit_8821c.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_BIT_8821C_H
#define __INC_HALMAC_BIT_8821C_H
#define CPU_OPT_WIDTH 0x1F
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SYS_ISO_CTRL_8821C */
#define BIT_PWC_EV12V_8821C BIT(15)
#define BIT_PWC_EV25V_8821C BIT(14)
#define BIT_PA33V_EN_8821C BIT(13)
#define BIT_PA12V_EN_8821C BIT(12)
#define BIT_UA33V_EN_8821C BIT(11)
#define BIT_UA12V_EN_8821C BIT(10)
#define BIT_ISO_RFDIO_8821C BIT(9)
#define BIT_ISO_EB2CORE_8821C BIT(8)
#define BIT_ISO_DIOE_8821C BIT(7)
#define BIT_ISO_WLPON2PP_8821C BIT(6)
#define BIT_ISO_IP2MAC_WA2PP_8821C BIT(5)
#define BIT_ISO_PD2CORE_8821C BIT(4)
#define BIT_ISO_PA2PCIE_8821C BIT(3)
#define BIT_ISO_UD2CORE_8821C BIT(2)
#define BIT_ISO_UA2USB_8821C BIT(1)
#define BIT_ISO_WD2PP_8821C BIT(0)
/* 2 REG_SYS_FUNC_EN_8821C */
#define BIT_FEN_MREGEN_8821C BIT(15)
#define BIT_FEN_HWPDN_8821C BIT(14)
#define BIT_EN_25_1_8821C BIT(13)
#define BIT_FEN_ELDR_8821C BIT(12)
#define BIT_FEN_DCORE_8821C BIT(11)
#define BIT_FEN_CPUEN_8821C BIT(10)
#define BIT_FEN_DIOE_8821C BIT(9)
#define BIT_FEN_PCIED_8821C BIT(8)
#define BIT_FEN_PPLL_8821C BIT(7)
#define BIT_FEN_PCIEA_8821C BIT(6)
#define BIT_FEN_DIO_PCIE_8821C BIT(5)
#define BIT_FEN_USBD_8821C BIT(4)
#define BIT_FEN_UPLL_8821C BIT(3)
#define BIT_FEN_USBA_8821C BIT(2)
#define BIT_FEN_BB_GLB_RSTN_8821C BIT(1)
#define BIT_FEN_BBRSTB_8821C BIT(0)
/* 2 REG_SYS_PW_CTRL_8821C */
#define BIT_SOP_EABM_8821C BIT(31)
#define BIT_SOP_ACKF_8821C BIT(30)
#define BIT_SOP_ERCK_8821C BIT(29)
#define BIT_SOP_ESWR_8821C BIT(28)
#define BIT_SOP_PWMM_8821C BIT(27)
#define BIT_SOP_EECK_8821C BIT(26)
#define BIT_SOP_EXTL_8821C BIT(24)
#define BIT_SYM_OP_RING_12M_8821C BIT(22)
#define BIT_ROP_SWPR_8821C BIT(21)
#define BIT_DIS_HW_LPLDM_8821C BIT(20)
#define BIT_OPT_SWRST_WLMCU_8821C BIT(19)
#define BIT_RDY_SYSPWR_8821C BIT(17)
#define BIT_EN_WLON_8821C BIT(16)
#define BIT_APDM_HPDN_8821C BIT(15)
#define BIT_AFSM_PCIE_SUS_EN_8821C BIT(12)
#define BIT_AFSM_WLSUS_EN_8821C BIT(11)
#define BIT_APFM_SWLPS_8821C BIT(10)
#define BIT_APFM_OFFMAC_8821C BIT(9)
#define BIT_APFN_ONMAC_8821C BIT(8)
#define BIT_CHIP_PDN_EN_8821C BIT(7)
#define BIT_RDY_MACDIS_8821C BIT(6)
#define BIT_RING_CLK_12M_EN_8821C BIT(4)
#define BIT_PFM_WOWL_8821C BIT(3)
#define BIT_PFM_LDKP_8821C BIT(2)
#define BIT_WL_HCI_ALD_8821C BIT(1)
#define BIT_PFM_LDALL_8821C BIT(0)
/* 2 REG_SYS_CLK_CTRL_8821C */
#define BIT_LDO_DUMMY_8821C BIT(15)
#define BIT_CPU_CLK_EN_8821C BIT(14)
#define BIT_SYMREG_CLK_EN_8821C BIT(13)
#define BIT_HCI_CLK_EN_8821C BIT(12)
#define BIT_MAC_CLK_EN_8821C BIT(11)
#define BIT_SEC_CLK_EN_8821C BIT(10)
#define BIT_PHY_SSC_RSTB_8821C BIT(9)
#define BIT_EXT_32K_EN_8821C BIT(8)
#define BIT_WL_CLK_TEST_8821C BIT(7)
#define BIT_OP_SPS_PWM_EN_8821C BIT(6)
#define BIT_LOADER_CLK_EN_8821C BIT(5)
#define BIT_MACSLP_8821C BIT(4)
#define BIT_WAKEPAD_EN_8821C BIT(3)
#define BIT_ROMD16V_EN_8821C BIT(2)
#define BIT_CKANA12M_EN_8821C BIT(1)
#define BIT_CNTD16V_EN_8821C BIT(0)
/* 2 REG_SYS_EEPROM_CTRL_8821C */
#define BIT_SHIFT_VPDIDX_8821C 8
#define BIT_MASK_VPDIDX_8821C 0xff
#define BIT_VPDIDX_8821C(x) \
(((x) & BIT_MASK_VPDIDX_8821C) << BIT_SHIFT_VPDIDX_8821C)
#define BITS_VPDIDX_8821C (BIT_MASK_VPDIDX_8821C << BIT_SHIFT_VPDIDX_8821C)
#define BIT_CLEAR_VPDIDX_8821C(x) ((x) & (~BITS_VPDIDX_8821C))
#define BIT_GET_VPDIDX_8821C(x) \
(((x) >> BIT_SHIFT_VPDIDX_8821C) & BIT_MASK_VPDIDX_8821C)
#define BIT_SET_VPDIDX_8821C(x, v) \
(BIT_CLEAR_VPDIDX_8821C(x) | BIT_VPDIDX_8821C(v))
#define BIT_SHIFT_EEM1_0_8821C 6
#define BIT_MASK_EEM1_0_8821C 0x3
#define BIT_EEM1_0_8821C(x) \
(((x) & BIT_MASK_EEM1_0_8821C) << BIT_SHIFT_EEM1_0_8821C)
#define BITS_EEM1_0_8821C (BIT_MASK_EEM1_0_8821C << BIT_SHIFT_EEM1_0_8821C)
#define BIT_CLEAR_EEM1_0_8821C(x) ((x) & (~BITS_EEM1_0_8821C))
#define BIT_GET_EEM1_0_8821C(x) \
(((x) >> BIT_SHIFT_EEM1_0_8821C) & BIT_MASK_EEM1_0_8821C)
#define BIT_SET_EEM1_0_8821C(x, v) \
(BIT_CLEAR_EEM1_0_8821C(x) | BIT_EEM1_0_8821C(v))
#define BIT_AUTOLOAD_SUS_8821C BIT(5)
#define BIT_EERPOMSEL_8821C BIT(4)
#define BIT_EECS_V1_8821C BIT(3)
#define BIT_EESK_V1_8821C BIT(2)
#define BIT_EEDI_V1_8821C BIT(1)
#define BIT_EEDO_V1_8821C BIT(0)
/* 2 REG_EE_VPD_8821C */
#define BIT_SHIFT_VPD_DATA_8821C 0
#define BIT_MASK_VPD_DATA_8821C 0xffffffffL
#define BIT_VPD_DATA_8821C(x) \
(((x) & BIT_MASK_VPD_DATA_8821C) << BIT_SHIFT_VPD_DATA_8821C)
#define BITS_VPD_DATA_8821C \
(BIT_MASK_VPD_DATA_8821C << BIT_SHIFT_VPD_DATA_8821C)
#define BIT_CLEAR_VPD_DATA_8821C(x) ((x) & (~BITS_VPD_DATA_8821C))
#define BIT_GET_VPD_DATA_8821C(x) \
(((x) >> BIT_SHIFT_VPD_DATA_8821C) & BIT_MASK_VPD_DATA_8821C)
#define BIT_SET_VPD_DATA_8821C(x, v) \
(BIT_CLEAR_VPD_DATA_8821C(x) | BIT_VPD_DATA_8821C(v))
/* 2 REG_SYS_SWR_CTRL1_8821C */
#define BIT_C2_L_BIT0_8821C BIT(31)
#define BIT_SHIFT_C1_L_8821C 29
#define BIT_MASK_C1_L_8821C 0x3
#define BIT_C1_L_8821C(x) (((x) & BIT_MASK_C1_L_8821C) << BIT_SHIFT_C1_L_8821C)
#define BITS_C1_L_8821C (BIT_MASK_C1_L_8821C << BIT_SHIFT_C1_L_8821C)
#define BIT_CLEAR_C1_L_8821C(x) ((x) & (~BITS_C1_L_8821C))
#define BIT_GET_C1_L_8821C(x) \
(((x) >> BIT_SHIFT_C1_L_8821C) & BIT_MASK_C1_L_8821C)
#define BIT_SET_C1_L_8821C(x, v) (BIT_CLEAR_C1_L_8821C(x) | BIT_C1_L_8821C(v))
#define BIT_SHIFT_REG_FREQ_L_8821C 25
#define BIT_MASK_REG_FREQ_L_8821C 0x7
#define BIT_REG_FREQ_L_8821C(x) \
(((x) & BIT_MASK_REG_FREQ_L_8821C) << BIT_SHIFT_REG_FREQ_L_8821C)
#define BITS_REG_FREQ_L_8821C \
(BIT_MASK_REG_FREQ_L_8821C << BIT_SHIFT_REG_FREQ_L_8821C)
#define BIT_CLEAR_REG_FREQ_L_8821C(x) ((x) & (~BITS_REG_FREQ_L_8821C))
#define BIT_GET_REG_FREQ_L_8821C(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L_8821C) & BIT_MASK_REG_FREQ_L_8821C)
#define BIT_SET_REG_FREQ_L_8821C(x, v) \
(BIT_CLEAR_REG_FREQ_L_8821C(x) | BIT_REG_FREQ_L_8821C(v))
#define BIT_REG_EN_DUTY_8821C BIT(24)
#define BIT_SHIFT_REG_MODE_8821C 22
#define BIT_MASK_REG_MODE_8821C 0x3
#define BIT_REG_MODE_8821C(x) \
(((x) & BIT_MASK_REG_MODE_8821C) << BIT_SHIFT_REG_MODE_8821C)
#define BITS_REG_MODE_8821C \
(BIT_MASK_REG_MODE_8821C << BIT_SHIFT_REG_MODE_8821C)
#define BIT_CLEAR_REG_MODE_8821C(x) ((x) & (~BITS_REG_MODE_8821C))
#define BIT_GET_REG_MODE_8821C(x) \
(((x) >> BIT_SHIFT_REG_MODE_8821C) & BIT_MASK_REG_MODE_8821C)
#define BIT_SET_REG_MODE_8821C(x, v) \
(BIT_CLEAR_REG_MODE_8821C(x) | BIT_REG_MODE_8821C(v))
#define BIT_REG_EN_SP_8821C BIT(21)
#define BIT_REG_AUTO_L_8821C BIT(20)
#define BIT_SW18_SELD_BIT0_8821C BIT(19)
#define BIT_SW18_POWOCP_8821C BIT(18)
#define BIT_SHIFT_OCP_L1_8821C 15
#define BIT_MASK_OCP_L1_8821C 0x7
#define BIT_OCP_L1_8821C(x) \
(((x) & BIT_MASK_OCP_L1_8821C) << BIT_SHIFT_OCP_L1_8821C)
#define BITS_OCP_L1_8821C (BIT_MASK_OCP_L1_8821C << BIT_SHIFT_OCP_L1_8821C)
#define BIT_CLEAR_OCP_L1_8821C(x) ((x) & (~BITS_OCP_L1_8821C))
#define BIT_GET_OCP_L1_8821C(x) \
(((x) >> BIT_SHIFT_OCP_L1_8821C) & BIT_MASK_OCP_L1_8821C)
#define BIT_SET_OCP_L1_8821C(x, v) \
(BIT_CLEAR_OCP_L1_8821C(x) | BIT_OCP_L1_8821C(v))
#define BIT_SHIFT_CF_L_8821C 13
#define BIT_MASK_CF_L_8821C 0x3
#define BIT_CF_L_8821C(x) (((x) & BIT_MASK_CF_L_8821C) << BIT_SHIFT_CF_L_8821C)
#define BITS_CF_L_8821C (BIT_MASK_CF_L_8821C << BIT_SHIFT_CF_L_8821C)
#define BIT_CLEAR_CF_L_8821C(x) ((x) & (~BITS_CF_L_8821C))
#define BIT_GET_CF_L_8821C(x) \
(((x) >> BIT_SHIFT_CF_L_8821C) & BIT_MASK_CF_L_8821C)
#define BIT_SET_CF_L_8821C(x, v) (BIT_CLEAR_CF_L_8821C(x) | BIT_CF_L_8821C(v))
#define BIT_SW18_FPWM_8821C BIT(11)
#define BIT_SW18_SWEN_8821C BIT(9)
#define BIT_SW18_LDEN_8821C BIT(8)
#define BIT_MAC_ID_EN_8821C BIT(7)
#define BIT_AFE_BGEN_8821C BIT(0)
/* 2 REG_SYS_SWR_CTRL2_8821C */
#define BIT_POW_ZCD_L_8821C BIT(31)
#define BIT_AUTOZCD_L_8821C BIT(30)
#define BIT_SHIFT_REG_DELAY_8821C 28
#define BIT_MASK_REG_DELAY_8821C 0x3
#define BIT_REG_DELAY_8821C(x) \
(((x) & BIT_MASK_REG_DELAY_8821C) << BIT_SHIFT_REG_DELAY_8821C)
#define BITS_REG_DELAY_8821C \
(BIT_MASK_REG_DELAY_8821C << BIT_SHIFT_REG_DELAY_8821C)
#define BIT_CLEAR_REG_DELAY_8821C(x) ((x) & (~BITS_REG_DELAY_8821C))
#define BIT_GET_REG_DELAY_8821C(x) \
(((x) >> BIT_SHIFT_REG_DELAY_8821C) & BIT_MASK_REG_DELAY_8821C)
#define BIT_SET_REG_DELAY_8821C(x, v) \
(BIT_CLEAR_REG_DELAY_8821C(x) | BIT_REG_DELAY_8821C(v))
#define BIT_SHIFT_V15ADJ_L1_V1_8821C 24
#define BIT_MASK_V15ADJ_L1_V1_8821C 0x7
#define BIT_V15ADJ_L1_V1_8821C(x) \
(((x) & BIT_MASK_V15ADJ_L1_V1_8821C) << BIT_SHIFT_V15ADJ_L1_V1_8821C)
#define BITS_V15ADJ_L1_V1_8821C \
(BIT_MASK_V15ADJ_L1_V1_8821C << BIT_SHIFT_V15ADJ_L1_V1_8821C)
#define BIT_CLEAR_V15ADJ_L1_V1_8821C(x) ((x) & (~BITS_V15ADJ_L1_V1_8821C))
#define BIT_GET_V15ADJ_L1_V1_8821C(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_V1_8821C) & BIT_MASK_V15ADJ_L1_V1_8821C)
#define BIT_SET_V15ADJ_L1_V1_8821C(x, v) \
(BIT_CLEAR_V15ADJ_L1_V1_8821C(x) | BIT_V15ADJ_L1_V1_8821C(v))
#define BIT_SHIFT_VOL_L1_V1_8821C 20
#define BIT_MASK_VOL_L1_V1_8821C 0xf
#define BIT_VOL_L1_V1_8821C(x) \
(((x) & BIT_MASK_VOL_L1_V1_8821C) << BIT_SHIFT_VOL_L1_V1_8821C)
#define BITS_VOL_L1_V1_8821C \
(BIT_MASK_VOL_L1_V1_8821C << BIT_SHIFT_VOL_L1_V1_8821C)
#define BIT_CLEAR_VOL_L1_V1_8821C(x) ((x) & (~BITS_VOL_L1_V1_8821C))
#define BIT_GET_VOL_L1_V1_8821C(x) \
(((x) >> BIT_SHIFT_VOL_L1_V1_8821C) & BIT_MASK_VOL_L1_V1_8821C)
#define BIT_SET_VOL_L1_V1_8821C(x, v) \
(BIT_CLEAR_VOL_L1_V1_8821C(x) | BIT_VOL_L1_V1_8821C(v))
#define BIT_SHIFT_IN_L1_V1_8821C 17
#define BIT_MASK_IN_L1_V1_8821C 0x7
#define BIT_IN_L1_V1_8821C(x) \
(((x) & BIT_MASK_IN_L1_V1_8821C) << BIT_SHIFT_IN_L1_V1_8821C)
#define BITS_IN_L1_V1_8821C \
(BIT_MASK_IN_L1_V1_8821C << BIT_SHIFT_IN_L1_V1_8821C)
#define BIT_CLEAR_IN_L1_V1_8821C(x) ((x) & (~BITS_IN_L1_V1_8821C))
#define BIT_GET_IN_L1_V1_8821C(x) \
(((x) >> BIT_SHIFT_IN_L1_V1_8821C) & BIT_MASK_IN_L1_V1_8821C)
#define BIT_SET_IN_L1_V1_8821C(x, v) \
(BIT_CLEAR_IN_L1_V1_8821C(x) | BIT_IN_L1_V1_8821C(v))
#define BIT_SHIFT_TBOX_L1_8821C 15
#define BIT_MASK_TBOX_L1_8821C 0x3
#define BIT_TBOX_L1_8821C(x) \
(((x) & BIT_MASK_TBOX_L1_8821C) << BIT_SHIFT_TBOX_L1_8821C)
#define BITS_TBOX_L1_8821C (BIT_MASK_TBOX_L1_8821C << BIT_SHIFT_TBOX_L1_8821C)
#define BIT_CLEAR_TBOX_L1_8821C(x) ((x) & (~BITS_TBOX_L1_8821C))
#define BIT_GET_TBOX_L1_8821C(x) \
(((x) >> BIT_SHIFT_TBOX_L1_8821C) & BIT_MASK_TBOX_L1_8821C)
#define BIT_SET_TBOX_L1_8821C(x, v) \
(BIT_CLEAR_TBOX_L1_8821C(x) | BIT_TBOX_L1_8821C(v))
#define BIT_SW18_SEL_8821C BIT(13)
/* 2 REG_NOT_VALID_8821C */
#define BIT_SW18_SD_8821C BIT(10)
#define BIT_SHIFT_R3_L_8821C 7
#define BIT_MASK_R3_L_8821C 0x3
#define BIT_R3_L_8821C(x) (((x) & BIT_MASK_R3_L_8821C) << BIT_SHIFT_R3_L_8821C)
#define BITS_R3_L_8821C (BIT_MASK_R3_L_8821C << BIT_SHIFT_R3_L_8821C)
#define BIT_CLEAR_R3_L_8821C(x) ((x) & (~BITS_R3_L_8821C))
#define BIT_GET_R3_L_8821C(x) \
(((x) >> BIT_SHIFT_R3_L_8821C) & BIT_MASK_R3_L_8821C)
#define BIT_SET_R3_L_8821C(x, v) (BIT_CLEAR_R3_L_8821C(x) | BIT_R3_L_8821C(v))
#define BIT_SHIFT_SW18_R2_8821C 5
#define BIT_MASK_SW18_R2_8821C 0x3
#define BIT_SW18_R2_8821C(x) \
(((x) & BIT_MASK_SW18_R2_8821C) << BIT_SHIFT_SW18_R2_8821C)
#define BITS_SW18_R2_8821C (BIT_MASK_SW18_R2_8821C << BIT_SHIFT_SW18_R2_8821C)
#define BIT_CLEAR_SW18_R2_8821C(x) ((x) & (~BITS_SW18_R2_8821C))
#define BIT_GET_SW18_R2_8821C(x) \
(((x) >> BIT_SHIFT_SW18_R2_8821C) & BIT_MASK_SW18_R2_8821C)
#define BIT_SET_SW18_R2_8821C(x, v) \
(BIT_CLEAR_SW18_R2_8821C(x) | BIT_SW18_R2_8821C(v))
#define BIT_SHIFT_SW18_R1_8821C 3
#define BIT_MASK_SW18_R1_8821C 0x3
#define BIT_SW18_R1_8821C(x) \
(((x) & BIT_MASK_SW18_R1_8821C) << BIT_SHIFT_SW18_R1_8821C)
#define BITS_SW18_R1_8821C (BIT_MASK_SW18_R1_8821C << BIT_SHIFT_SW18_R1_8821C)
#define BIT_CLEAR_SW18_R1_8821C(x) ((x) & (~BITS_SW18_R1_8821C))
#define BIT_GET_SW18_R1_8821C(x) \
(((x) >> BIT_SHIFT_SW18_R1_8821C) & BIT_MASK_SW18_R1_8821C)
#define BIT_SET_SW18_R1_8821C(x, v) \
(BIT_CLEAR_SW18_R1_8821C(x) | BIT_SW18_R1_8821C(v))
#define BIT_SHIFT_C3_L_C3_8821C 1
#define BIT_MASK_C3_L_C3_8821C 0x3
#define BIT_C3_L_C3_8821C(x) \
(((x) & BIT_MASK_C3_L_C3_8821C) << BIT_SHIFT_C3_L_C3_8821C)
#define BITS_C3_L_C3_8821C (BIT_MASK_C3_L_C3_8821C << BIT_SHIFT_C3_L_C3_8821C)
#define BIT_CLEAR_C3_L_C3_8821C(x) ((x) & (~BITS_C3_L_C3_8821C))
#define BIT_GET_C3_L_C3_8821C(x) \
(((x) >> BIT_SHIFT_C3_L_C3_8821C) & BIT_MASK_C3_L_C3_8821C)
#define BIT_SET_C3_L_C3_8821C(x, v) \
(BIT_CLEAR_C3_L_C3_8821C(x) | BIT_C3_L_C3_8821C(v))
#define BIT_C2_L_BIT1_8821C BIT(0)
/* 2 REG_SYS_SWR_CTRL3_8821C */
#define BIT_SPS18_OCP_DIS_8821C BIT(31)
#define BIT_SHIFT_SPS18_OCP_TH_8821C 16
#define BIT_MASK_SPS18_OCP_TH_8821C 0x7fff
#define BIT_SPS18_OCP_TH_8821C(x) \
(((x) & BIT_MASK_SPS18_OCP_TH_8821C) << BIT_SHIFT_SPS18_OCP_TH_8821C)
#define BITS_SPS18_OCP_TH_8821C \
(BIT_MASK_SPS18_OCP_TH_8821C << BIT_SHIFT_SPS18_OCP_TH_8821C)
#define BIT_CLEAR_SPS18_OCP_TH_8821C(x) ((x) & (~BITS_SPS18_OCP_TH_8821C))
#define BIT_GET_SPS18_OCP_TH_8821C(x) \
(((x) >> BIT_SHIFT_SPS18_OCP_TH_8821C) & BIT_MASK_SPS18_OCP_TH_8821C)
#define BIT_SET_SPS18_OCP_TH_8821C(x, v) \
(BIT_CLEAR_SPS18_OCP_TH_8821C(x) | BIT_SPS18_OCP_TH_8821C(v))
#define BIT_SHIFT_OCP_WINDOW_8821C 0
#define BIT_MASK_OCP_WINDOW_8821C 0xffff
#define BIT_OCP_WINDOW_8821C(x) \
(((x) & BIT_MASK_OCP_WINDOW_8821C) << BIT_SHIFT_OCP_WINDOW_8821C)
#define BITS_OCP_WINDOW_8821C \
(BIT_MASK_OCP_WINDOW_8821C << BIT_SHIFT_OCP_WINDOW_8821C)
#define BIT_CLEAR_OCP_WINDOW_8821C(x) ((x) & (~BITS_OCP_WINDOW_8821C))
#define BIT_GET_OCP_WINDOW_8821C(x) \
(((x) >> BIT_SHIFT_OCP_WINDOW_8821C) & BIT_MASK_OCP_WINDOW_8821C)
#define BIT_SET_OCP_WINDOW_8821C(x, v) \
(BIT_CLEAR_OCP_WINDOW_8821C(x) | BIT_OCP_WINDOW_8821C(v))
/* 2 REG_RSV_CTRL_8821C */
#define BIT_HREG_DBG_8821C BIT(23)
#define BIT_WLMCUIOIF_8821C BIT(8)
#define BIT_LOCK_ALL_EN_8821C BIT(7)
#define BIT_R_DIS_PRST_8821C BIT(6)
#define BIT_WLOCK_1C_B6_8821C BIT(5)
#define BIT_WLOCK_40_8821C BIT(4)
#define BIT_WLOCK_08_8821C BIT(3)
#define BIT_WLOCK_04_8821C BIT(2)
#define BIT_WLOCK_00_8821C BIT(1)
#define BIT_WLOCK_ALL_8821C BIT(0)
/* 2 REG_RF_CTRL_8821C */
#define BIT_RF_SDMRSTB_8821C BIT(2)
#define BIT_RF_RSTB_8821C BIT(1)
#define BIT_RF_EN_8821C BIT(0)
/* 2 REG_AFE_LDO_CTRL_8821C */
#define BIT_SHIFT_LPLDH12_RSV_8821C 29
#define BIT_MASK_LPLDH12_RSV_8821C 0x7
#define BIT_LPLDH12_RSV_8821C(x) \
(((x) & BIT_MASK_LPLDH12_RSV_8821C) << BIT_SHIFT_LPLDH12_RSV_8821C)
#define BITS_LPLDH12_RSV_8821C \
(BIT_MASK_LPLDH12_RSV_8821C << BIT_SHIFT_LPLDH12_RSV_8821C)
#define BIT_CLEAR_LPLDH12_RSV_8821C(x) ((x) & (~BITS_LPLDH12_RSV_8821C))
#define BIT_GET_LPLDH12_RSV_8821C(x) \
(((x) >> BIT_SHIFT_LPLDH12_RSV_8821C) & BIT_MASK_LPLDH12_RSV_8821C)
#define BIT_SET_LPLDH12_RSV_8821C(x, v) \
(BIT_CLEAR_LPLDH12_RSV_8821C(x) | BIT_LPLDH12_RSV_8821C(v))
#define BIT_LPLDH12_SLP_8821C BIT(28)
#define BIT_SHIFT_LPLDH12_VADJ_8821C 24
#define BIT_MASK_LPLDH12_VADJ_8821C 0xf
#define BIT_LPLDH12_VADJ_8821C(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_8821C) << BIT_SHIFT_LPLDH12_VADJ_8821C)
#define BITS_LPLDH12_VADJ_8821C \
(BIT_MASK_LPLDH12_VADJ_8821C << BIT_SHIFT_LPLDH12_VADJ_8821C)
#define BIT_CLEAR_LPLDH12_VADJ_8821C(x) ((x) & (~BITS_LPLDH12_VADJ_8821C))
#define BIT_GET_LPLDH12_VADJ_8821C(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_8821C) & BIT_MASK_LPLDH12_VADJ_8821C)
#define BIT_SET_LPLDH12_VADJ_8821C(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_8821C(x) | BIT_LPLDH12_VADJ_8821C(v))
#define BIT_PCIE_CALIB_EN_8821C BIT(17)
#define BIT_LDH12_EN_8821C BIT(16)
#define BIT_WLBBOFF_BIG_PWC_EN_8821C BIT(14)
#define BIT_WLBBOFF_SMALL_PWC_EN_8821C BIT(13)
#define BIT_WLMACOFF_BIG_PWC_EN_8821C BIT(12)
#define BIT_WLPON_PWC_EN_8821C BIT(11)
#define BIT_POW_REGU_P1_8821C BIT(10)
#define BIT_LDOV12W_EN_8821C BIT(8)
#define BIT_EX_XTAL_DRV_DIGI_8821C BIT(7)
#define BIT_EX_XTAL_DRV_USB_8821C BIT(6)
#define BIT_EX_XTAL_DRV_AFE_8821C BIT(5)
#define BIT_EX_XTAL_DRV_RF2_8821C BIT(4)
#define BIT_EX_XTAL_DRV_RF1_8821C BIT(3)
#define BIT_POW_REGU_P0_8821C BIT(2)
/* 2 REG_NOT_VALID_8821C */
#define BIT_POW_PLL_LDO_8821C BIT(0)
/* 2 REG_AFE_CTRL1_8821C */
#define BIT_AGPIO_GPE_8821C BIT(31)
#define BIT_SHIFT_XTAL_CAP_XI_8821C 25
#define BIT_MASK_XTAL_CAP_XI_8821C 0x3f
#define BIT_XTAL_CAP_XI_8821C(x) \
(((x) & BIT_MASK_XTAL_CAP_XI_8821C) << BIT_SHIFT_XTAL_CAP_XI_8821C)
#define BITS_XTAL_CAP_XI_8821C \
(BIT_MASK_XTAL_CAP_XI_8821C << BIT_SHIFT_XTAL_CAP_XI_8821C)
#define BIT_CLEAR_XTAL_CAP_XI_8821C(x) ((x) & (~BITS_XTAL_CAP_XI_8821C))
#define BIT_GET_XTAL_CAP_XI_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XI_8821C) & BIT_MASK_XTAL_CAP_XI_8821C)
#define BIT_SET_XTAL_CAP_XI_8821C(x, v) \
(BIT_CLEAR_XTAL_CAP_XI_8821C(x) | BIT_XTAL_CAP_XI_8821C(v))
#define BIT_SHIFT_XTAL_DRV_DIGI_8821C 23
#define BIT_MASK_XTAL_DRV_DIGI_8821C 0x3
#define BIT_XTAL_DRV_DIGI_8821C(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_8821C) << BIT_SHIFT_XTAL_DRV_DIGI_8821C)
#define BITS_XTAL_DRV_DIGI_8821C \
(BIT_MASK_XTAL_DRV_DIGI_8821C << BIT_SHIFT_XTAL_DRV_DIGI_8821C)
#define BIT_CLEAR_XTAL_DRV_DIGI_8821C(x) ((x) & (~BITS_XTAL_DRV_DIGI_8821C))
#define BIT_GET_XTAL_DRV_DIGI_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_8821C) & BIT_MASK_XTAL_DRV_DIGI_8821C)
#define BIT_SET_XTAL_DRV_DIGI_8821C(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_8821C(x) | BIT_XTAL_DRV_DIGI_8821C(v))
#define BIT_XTAL_DRV_USB_BIT1_8821C BIT(22)
#define BIT_SHIFT_MAC_CLK_SEL_8821C 20
#define BIT_MASK_MAC_CLK_SEL_8821C 0x3
#define BIT_MAC_CLK_SEL_8821C(x) \
(((x) & BIT_MASK_MAC_CLK_SEL_8821C) << BIT_SHIFT_MAC_CLK_SEL_8821C)
#define BITS_MAC_CLK_SEL_8821C \
(BIT_MASK_MAC_CLK_SEL_8821C << BIT_SHIFT_MAC_CLK_SEL_8821C)
#define BIT_CLEAR_MAC_CLK_SEL_8821C(x) ((x) & (~BITS_MAC_CLK_SEL_8821C))
#define BIT_GET_MAC_CLK_SEL_8821C(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL_8821C) & BIT_MASK_MAC_CLK_SEL_8821C)
#define BIT_SET_MAC_CLK_SEL_8821C(x, v) \
(BIT_CLEAR_MAC_CLK_SEL_8821C(x) | BIT_MAC_CLK_SEL_8821C(v))
#define BIT_XTAL_DRV_USB_BIT0_8821C BIT(19)
#define BIT_SHIFT_XTAL_DRV_AFE_8821C 17
#define BIT_MASK_XTAL_DRV_AFE_8821C 0x3
#define BIT_XTAL_DRV_AFE_8821C(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_8821C) << BIT_SHIFT_XTAL_DRV_AFE_8821C)
#define BITS_XTAL_DRV_AFE_8821C \
(BIT_MASK_XTAL_DRV_AFE_8821C << BIT_SHIFT_XTAL_DRV_AFE_8821C)
#define BIT_CLEAR_XTAL_DRV_AFE_8821C(x) ((x) & (~BITS_XTAL_DRV_AFE_8821C))
#define BIT_GET_XTAL_DRV_AFE_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_8821C) & BIT_MASK_XTAL_DRV_AFE_8821C)
#define BIT_SET_XTAL_DRV_AFE_8821C(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_8821C(x) | BIT_XTAL_DRV_AFE_8821C(v))
#define BIT_SHIFT_XTAL_DRV_RF2_8821C 15
#define BIT_MASK_XTAL_DRV_RF2_8821C 0x3
#define BIT_XTAL_DRV_RF2_8821C(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_8821C) << BIT_SHIFT_XTAL_DRV_RF2_8821C)
#define BITS_XTAL_DRV_RF2_8821C \
(BIT_MASK_XTAL_DRV_RF2_8821C << BIT_SHIFT_XTAL_DRV_RF2_8821C)
#define BIT_CLEAR_XTAL_DRV_RF2_8821C(x) ((x) & (~BITS_XTAL_DRV_RF2_8821C))
#define BIT_GET_XTAL_DRV_RF2_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_8821C) & BIT_MASK_XTAL_DRV_RF2_8821C)
#define BIT_SET_XTAL_DRV_RF2_8821C(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_8821C(x) | BIT_XTAL_DRV_RF2_8821C(v))
#define BIT_SHIFT_XTAL_DRV_RF1_8821C 13
#define BIT_MASK_XTAL_DRV_RF1_8821C 0x3
#define BIT_XTAL_DRV_RF1_8821C(x) \
(((x) & BIT_MASK_XTAL_DRV_RF1_8821C) << BIT_SHIFT_XTAL_DRV_RF1_8821C)
#define BITS_XTAL_DRV_RF1_8821C \
(BIT_MASK_XTAL_DRV_RF1_8821C << BIT_SHIFT_XTAL_DRV_RF1_8821C)
#define BIT_CLEAR_XTAL_DRV_RF1_8821C(x) ((x) & (~BITS_XTAL_DRV_RF1_8821C))
#define BIT_GET_XTAL_DRV_RF1_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF1_8821C) & BIT_MASK_XTAL_DRV_RF1_8821C)
#define BIT_SET_XTAL_DRV_RF1_8821C(x, v) \
(BIT_CLEAR_XTAL_DRV_RF1_8821C(x) | BIT_XTAL_DRV_RF1_8821C(v))
#define BIT_XTAL_DELAY_DIGI_8821C BIT(12)
#define BIT_XTAL_DELAY_USB_8821C BIT(11)
#define BIT_XTAL_DELAY_AFE_8821C BIT(10)
#define BIT_SHIFT_XTAL_LDO_VREF_8821C 7
#define BIT_MASK_XTAL_LDO_VREF_8821C 0x7
#define BIT_XTAL_LDO_VREF_8821C(x) \
(((x) & BIT_MASK_XTAL_LDO_VREF_8821C) << BIT_SHIFT_XTAL_LDO_VREF_8821C)
#define BITS_XTAL_LDO_VREF_8821C \
(BIT_MASK_XTAL_LDO_VREF_8821C << BIT_SHIFT_XTAL_LDO_VREF_8821C)
#define BIT_CLEAR_XTAL_LDO_VREF_8821C(x) ((x) & (~BITS_XTAL_LDO_VREF_8821C))
#define BIT_GET_XTAL_LDO_VREF_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_VREF_8821C) & BIT_MASK_XTAL_LDO_VREF_8821C)
#define BIT_SET_XTAL_LDO_VREF_8821C(x, v) \
(BIT_CLEAR_XTAL_LDO_VREF_8821C(x) | BIT_XTAL_LDO_VREF_8821C(v))
#define BIT_XTAL_XQSEL_RF_8821C BIT(6)
#define BIT_XTAL_XQSEL_8821C BIT(5)
#define BIT_SHIFT_XTAL_GMN_V2_8821C 3
#define BIT_MASK_XTAL_GMN_V2_8821C 0x3
#define BIT_XTAL_GMN_V2_8821C(x) \
(((x) & BIT_MASK_XTAL_GMN_V2_8821C) << BIT_SHIFT_XTAL_GMN_V2_8821C)
#define BITS_XTAL_GMN_V2_8821C \
(BIT_MASK_XTAL_GMN_V2_8821C << BIT_SHIFT_XTAL_GMN_V2_8821C)
#define BIT_CLEAR_XTAL_GMN_V2_8821C(x) ((x) & (~BITS_XTAL_GMN_V2_8821C))
#define BIT_GET_XTAL_GMN_V2_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V2_8821C) & BIT_MASK_XTAL_GMN_V2_8821C)
#define BIT_SET_XTAL_GMN_V2_8821C(x, v) \
(BIT_CLEAR_XTAL_GMN_V2_8821C(x) | BIT_XTAL_GMN_V2_8821C(v))
#define BIT_SHIFT_XTAL_GMP_V2_8821C 1
#define BIT_MASK_XTAL_GMP_V2_8821C 0x3
#define BIT_XTAL_GMP_V2_8821C(x) \
(((x) & BIT_MASK_XTAL_GMP_V2_8821C) << BIT_SHIFT_XTAL_GMP_V2_8821C)
#define BITS_XTAL_GMP_V2_8821C \
(BIT_MASK_XTAL_GMP_V2_8821C << BIT_SHIFT_XTAL_GMP_V2_8821C)
#define BIT_CLEAR_XTAL_GMP_V2_8821C(x) ((x) & (~BITS_XTAL_GMP_V2_8821C))
#define BIT_GET_XTAL_GMP_V2_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V2_8821C) & BIT_MASK_XTAL_GMP_V2_8821C)
#define BIT_SET_XTAL_GMP_V2_8821C(x, v) \
(BIT_CLEAR_XTAL_GMP_V2_8821C(x) | BIT_XTAL_GMP_V2_8821C(v))
#define BIT_XTAL_EN_8821C BIT(0)
/* 2 REG_AFE_CTRL2_8821C */
#define BIT_SHIFT_REG_C3_V4_8821C 30
#define BIT_MASK_REG_C3_V4_8821C 0x3
#define BIT_REG_C3_V4_8821C(x) \
(((x) & BIT_MASK_REG_C3_V4_8821C) << BIT_SHIFT_REG_C3_V4_8821C)
#define BITS_REG_C3_V4_8821C \
(BIT_MASK_REG_C3_V4_8821C << BIT_SHIFT_REG_C3_V4_8821C)
#define BIT_CLEAR_REG_C3_V4_8821C(x) ((x) & (~BITS_REG_C3_V4_8821C))
#define BIT_GET_REG_C3_V4_8821C(x) \
(((x) >> BIT_SHIFT_REG_C3_V4_8821C) & BIT_MASK_REG_C3_V4_8821C)
#define BIT_SET_REG_C3_V4_8821C(x, v) \
(BIT_CLEAR_REG_C3_V4_8821C(x) | BIT_REG_C3_V4_8821C(v))
#define BIT_REG_CP_BIT1_8821C BIT(29)
#define BIT_SHIFT_REG_RS_V4_8821C 26
#define BIT_MASK_REG_RS_V4_8821C 0x7
#define BIT_REG_RS_V4_8821C(x) \
(((x) & BIT_MASK_REG_RS_V4_8821C) << BIT_SHIFT_REG_RS_V4_8821C)
#define BITS_REG_RS_V4_8821C \
(BIT_MASK_REG_RS_V4_8821C << BIT_SHIFT_REG_RS_V4_8821C)
#define BIT_CLEAR_REG_RS_V4_8821C(x) ((x) & (~BITS_REG_RS_V4_8821C))
#define BIT_GET_REG_RS_V4_8821C(x) \
(((x) >> BIT_SHIFT_REG_RS_V4_8821C) & BIT_MASK_REG_RS_V4_8821C)
#define BIT_SET_REG_RS_V4_8821C(x, v) \
(BIT_CLEAR_REG_RS_V4_8821C(x) | BIT_REG_RS_V4_8821C(v))
#define BIT_SHIFT_REG__CS_8821C 24
#define BIT_MASK_REG__CS_8821C 0x3
#define BIT_REG__CS_8821C(x) \
(((x) & BIT_MASK_REG__CS_8821C) << BIT_SHIFT_REG__CS_8821C)
#define BITS_REG__CS_8821C (BIT_MASK_REG__CS_8821C << BIT_SHIFT_REG__CS_8821C)
#define BIT_CLEAR_REG__CS_8821C(x) ((x) & (~BITS_REG__CS_8821C))
#define BIT_GET_REG__CS_8821C(x) \
(((x) >> BIT_SHIFT_REG__CS_8821C) & BIT_MASK_REG__CS_8821C)
#define BIT_SET_REG__CS_8821C(x, v) \
(BIT_CLEAR_REG__CS_8821C(x) | BIT_REG__CS_8821C(v))
#define BIT_SHIFT_REG_CP_OFFSET_8821C 21
#define BIT_MASK_REG_CP_OFFSET_8821C 0x7
#define BIT_REG_CP_OFFSET_8821C(x) \
(((x) & BIT_MASK_REG_CP_OFFSET_8821C) << BIT_SHIFT_REG_CP_OFFSET_8821C)
#define BITS_REG_CP_OFFSET_8821C \
(BIT_MASK_REG_CP_OFFSET_8821C << BIT_SHIFT_REG_CP_OFFSET_8821C)
#define BIT_CLEAR_REG_CP_OFFSET_8821C(x) ((x) & (~BITS_REG_CP_OFFSET_8821C))
#define BIT_GET_REG_CP_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_REG_CP_OFFSET_8821C) & BIT_MASK_REG_CP_OFFSET_8821C)
#define BIT_SET_REG_CP_OFFSET_8821C(x, v) \
(BIT_CLEAR_REG_CP_OFFSET_8821C(x) | BIT_REG_CP_OFFSET_8821C(v))
#define BIT_SHIFT_CP_BIAS_8821C 18
#define BIT_MASK_CP_BIAS_8821C 0x7
#define BIT_CP_BIAS_8821C(x) \
(((x) & BIT_MASK_CP_BIAS_8821C) << BIT_SHIFT_CP_BIAS_8821C)
#define BITS_CP_BIAS_8821C (BIT_MASK_CP_BIAS_8821C << BIT_SHIFT_CP_BIAS_8821C)
#define BIT_CLEAR_CP_BIAS_8821C(x) ((x) & (~BITS_CP_BIAS_8821C))
#define BIT_GET_CP_BIAS_8821C(x) \
(((x) >> BIT_SHIFT_CP_BIAS_8821C) & BIT_MASK_CP_BIAS_8821C)
#define BIT_SET_CP_BIAS_8821C(x, v) \
(BIT_CLEAR_CP_BIAS_8821C(x) | BIT_CP_BIAS_8821C(v))
#define BIT_REG_IDOUBLE_V2_8821C BIT(17)
#define BIT_EN_SYN_8821C BIT(16)
#define BIT_SHIFT_MCCO_8821C 14
#define BIT_MASK_MCCO_8821C 0x3
#define BIT_MCCO_8821C(x) (((x) & BIT_MASK_MCCO_8821C) << BIT_SHIFT_MCCO_8821C)
#define BITS_MCCO_8821C (BIT_MASK_MCCO_8821C << BIT_SHIFT_MCCO_8821C)
#define BIT_CLEAR_MCCO_8821C(x) ((x) & (~BITS_MCCO_8821C))
#define BIT_GET_MCCO_8821C(x) \
(((x) >> BIT_SHIFT_MCCO_8821C) & BIT_MASK_MCCO_8821C)
#define BIT_SET_MCCO_8821C(x, v) (BIT_CLEAR_MCCO_8821C(x) | BIT_MCCO_8821C(v))
#define BIT_SHIFT_REG_LDO_SEL_8821C 12
#define BIT_MASK_REG_LDO_SEL_8821C 0x3
#define BIT_REG_LDO_SEL_8821C(x) \
(((x) & BIT_MASK_REG_LDO_SEL_8821C) << BIT_SHIFT_REG_LDO_SEL_8821C)
#define BITS_REG_LDO_SEL_8821C \
(BIT_MASK_REG_LDO_SEL_8821C << BIT_SHIFT_REG_LDO_SEL_8821C)
#define BIT_CLEAR_REG_LDO_SEL_8821C(x) ((x) & (~BITS_REG_LDO_SEL_8821C))
#define BIT_GET_REG_LDO_SEL_8821C(x) \
(((x) >> BIT_SHIFT_REG_LDO_SEL_8821C) & BIT_MASK_REG_LDO_SEL_8821C)
#define BIT_SET_REG_LDO_SEL_8821C(x, v) \
(BIT_CLEAR_REG_LDO_SEL_8821C(x) | BIT_REG_LDO_SEL_8821C(v))
#define BIT_REG_KVCO_V2_8821C BIT(10)
#define BIT_AGPIO_GPO_8821C BIT(9)
#define BIT_SHIFT_AGPIO_DRV_8821C 7
#define BIT_MASK_AGPIO_DRV_8821C 0x3
#define BIT_AGPIO_DRV_8821C(x) \
(((x) & BIT_MASK_AGPIO_DRV_8821C) << BIT_SHIFT_AGPIO_DRV_8821C)
#define BITS_AGPIO_DRV_8821C \
(BIT_MASK_AGPIO_DRV_8821C << BIT_SHIFT_AGPIO_DRV_8821C)
#define BIT_CLEAR_AGPIO_DRV_8821C(x) ((x) & (~BITS_AGPIO_DRV_8821C))
#define BIT_GET_AGPIO_DRV_8821C(x) \
(((x) >> BIT_SHIFT_AGPIO_DRV_8821C) & BIT_MASK_AGPIO_DRV_8821C)
#define BIT_SET_AGPIO_DRV_8821C(x, v) \
(BIT_CLEAR_AGPIO_DRV_8821C(x) | BIT_AGPIO_DRV_8821C(v))
#define BIT_SHIFT_XTAL_CAP_XO_8821C 1
#define BIT_MASK_XTAL_CAP_XO_8821C 0x3f
#define BIT_XTAL_CAP_XO_8821C(x) \
(((x) & BIT_MASK_XTAL_CAP_XO_8821C) << BIT_SHIFT_XTAL_CAP_XO_8821C)
#define BITS_XTAL_CAP_XO_8821C \
(BIT_MASK_XTAL_CAP_XO_8821C << BIT_SHIFT_XTAL_CAP_XO_8821C)
#define BIT_CLEAR_XTAL_CAP_XO_8821C(x) ((x) & (~BITS_XTAL_CAP_XO_8821C))
#define BIT_GET_XTAL_CAP_XO_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XO_8821C) & BIT_MASK_XTAL_CAP_XO_8821C)
#define BIT_SET_XTAL_CAP_XO_8821C(x, v) \
(BIT_CLEAR_XTAL_CAP_XO_8821C(x) | BIT_XTAL_CAP_XO_8821C(v))
#define BIT_POW_PLL_8821C BIT(0)
/* 2 REG_AFE_CTRL3_8821C */
#define BIT_SHIFT_PS_8821C 7
#define BIT_MASK_PS_8821C 0x7
#define BIT_PS_8821C(x) (((x) & BIT_MASK_PS_8821C) << BIT_SHIFT_PS_8821C)
#define BITS_PS_8821C (BIT_MASK_PS_8821C << BIT_SHIFT_PS_8821C)
#define BIT_CLEAR_PS_8821C(x) ((x) & (~BITS_PS_8821C))
#define BIT_GET_PS_8821C(x) (((x) >> BIT_SHIFT_PS_8821C) & BIT_MASK_PS_8821C)
#define BIT_SET_PS_8821C(x, v) (BIT_CLEAR_PS_8821C(x) | BIT_PS_8821C(v))
#define BIT_PSEN_8821C BIT(6)
#define BIT_DOGENB_8821C BIT(5)
#define BIT_REG_MBIAS_8821C BIT(4)
#define BIT_SHIFT_REG_R3_V4_8821C 1
#define BIT_MASK_REG_R3_V4_8821C 0x7
#define BIT_REG_R3_V4_8821C(x) \
(((x) & BIT_MASK_REG_R3_V4_8821C) << BIT_SHIFT_REG_R3_V4_8821C)
#define BITS_REG_R3_V4_8821C \
(BIT_MASK_REG_R3_V4_8821C << BIT_SHIFT_REG_R3_V4_8821C)
#define BIT_CLEAR_REG_R3_V4_8821C(x) ((x) & (~BITS_REG_R3_V4_8821C))
#define BIT_GET_REG_R3_V4_8821C(x) \
(((x) >> BIT_SHIFT_REG_R3_V4_8821C) & BIT_MASK_REG_R3_V4_8821C)
#define BIT_SET_REG_R3_V4_8821C(x, v) \
(BIT_CLEAR_REG_R3_V4_8821C(x) | BIT_REG_R3_V4_8821C(v))
#define BIT_REG_CP_BIT0_8821C BIT(0)
/* 2 REG_EFUSE_CTRL_8821C */
#define BIT_EF_FLAG_8821C BIT(31)
#define BIT_SHIFT_EF_PGPD_8821C 28
#define BIT_MASK_EF_PGPD_8821C 0x7
#define BIT_EF_PGPD_8821C(x) \
(((x) & BIT_MASK_EF_PGPD_8821C) << BIT_SHIFT_EF_PGPD_8821C)
#define BITS_EF_PGPD_8821C (BIT_MASK_EF_PGPD_8821C << BIT_SHIFT_EF_PGPD_8821C)
#define BIT_CLEAR_EF_PGPD_8821C(x) ((x) & (~BITS_EF_PGPD_8821C))
#define BIT_GET_EF_PGPD_8821C(x) \
(((x) >> BIT_SHIFT_EF_PGPD_8821C) & BIT_MASK_EF_PGPD_8821C)
#define BIT_SET_EF_PGPD_8821C(x, v) \
(BIT_CLEAR_EF_PGPD_8821C(x) | BIT_EF_PGPD_8821C(v))
#define BIT_SHIFT_EF_RDT_8821C 24
#define BIT_MASK_EF_RDT_8821C 0xf
#define BIT_EF_RDT_8821C(x) \
(((x) & BIT_MASK_EF_RDT_8821C) << BIT_SHIFT_EF_RDT_8821C)
#define BITS_EF_RDT_8821C (BIT_MASK_EF_RDT_8821C << BIT_SHIFT_EF_RDT_8821C)
#define BIT_CLEAR_EF_RDT_8821C(x) ((x) & (~BITS_EF_RDT_8821C))
#define BIT_GET_EF_RDT_8821C(x) \
(((x) >> BIT_SHIFT_EF_RDT_8821C) & BIT_MASK_EF_RDT_8821C)
#define BIT_SET_EF_RDT_8821C(x, v) \
(BIT_CLEAR_EF_RDT_8821C(x) | BIT_EF_RDT_8821C(v))
#define BIT_SHIFT_EF_PGTS_8821C 20
#define BIT_MASK_EF_PGTS_8821C 0xf
#define BIT_EF_PGTS_8821C(x) \
(((x) & BIT_MASK_EF_PGTS_8821C) << BIT_SHIFT_EF_PGTS_8821C)
#define BITS_EF_PGTS_8821C (BIT_MASK_EF_PGTS_8821C << BIT_SHIFT_EF_PGTS_8821C)
#define BIT_CLEAR_EF_PGTS_8821C(x) ((x) & (~BITS_EF_PGTS_8821C))
#define BIT_GET_EF_PGTS_8821C(x) \
(((x) >> BIT_SHIFT_EF_PGTS_8821C) & BIT_MASK_EF_PGTS_8821C)
#define BIT_SET_EF_PGTS_8821C(x, v) \
(BIT_CLEAR_EF_PGTS_8821C(x) | BIT_EF_PGTS_8821C(v))
#define BIT_EF_PDWN_8821C BIT(19)
#define BIT_EF_ALDEN_8821C BIT(18)
#define BIT_SHIFT_EF_ADDR_8821C 8
#define BIT_MASK_EF_ADDR_8821C 0x3ff
#define BIT_EF_ADDR_8821C(x) \
(((x) & BIT_MASK_EF_ADDR_8821C) << BIT_SHIFT_EF_ADDR_8821C)
#define BITS_EF_ADDR_8821C (BIT_MASK_EF_ADDR_8821C << BIT_SHIFT_EF_ADDR_8821C)
#define BIT_CLEAR_EF_ADDR_8821C(x) ((x) & (~BITS_EF_ADDR_8821C))
#define BIT_GET_EF_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_EF_ADDR_8821C) & BIT_MASK_EF_ADDR_8821C)
#define BIT_SET_EF_ADDR_8821C(x, v) \
(BIT_CLEAR_EF_ADDR_8821C(x) | BIT_EF_ADDR_8821C(v))
#define BIT_SHIFT_EF_DATA_8821C 0
#define BIT_MASK_EF_DATA_8821C 0xff
#define BIT_EF_DATA_8821C(x) \
(((x) & BIT_MASK_EF_DATA_8821C) << BIT_SHIFT_EF_DATA_8821C)
#define BITS_EF_DATA_8821C (BIT_MASK_EF_DATA_8821C << BIT_SHIFT_EF_DATA_8821C)
#define BIT_CLEAR_EF_DATA_8821C(x) ((x) & (~BITS_EF_DATA_8821C))
#define BIT_GET_EF_DATA_8821C(x) \
(((x) >> BIT_SHIFT_EF_DATA_8821C) & BIT_MASK_EF_DATA_8821C)
#define BIT_SET_EF_DATA_8821C(x, v) \
(BIT_CLEAR_EF_DATA_8821C(x) | BIT_EF_DATA_8821C(v))
/* 2 REG_LDO_EFUSE_CTRL_8821C */
#define BIT_LDOE25_EN_8821C BIT(31)
#define BIT_SHIFT_LDOE25_V12ADJ_L_8821C 27
#define BIT_MASK_LDOE25_V12ADJ_L_8821C 0xf
#define BIT_LDOE25_V12ADJ_L_8821C(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L_8821C) \
<< BIT_SHIFT_LDOE25_V12ADJ_L_8821C)
#define BITS_LDOE25_V12ADJ_L_8821C \
(BIT_MASK_LDOE25_V12ADJ_L_8821C << BIT_SHIFT_LDOE25_V12ADJ_L_8821C)
#define BIT_CLEAR_LDOE25_V12ADJ_L_8821C(x) ((x) & (~BITS_LDOE25_V12ADJ_L_8821C))
#define BIT_GET_LDOE25_V12ADJ_L_8821C(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L_8821C) & \
BIT_MASK_LDOE25_V12ADJ_L_8821C)
#define BIT_SET_LDOE25_V12ADJ_L_8821C(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L_8821C(x) | BIT_LDOE25_V12ADJ_L_8821C(v))
#define BIT_EF_CRES_SEL_8821C BIT(26)
#define BIT_SHIFT_EF_SCAN_START_V1_8821C 16
#define BIT_MASK_EF_SCAN_START_V1_8821C 0x3ff
#define BIT_EF_SCAN_START_V1_8821C(x) \
(((x) & BIT_MASK_EF_SCAN_START_V1_8821C) \
<< BIT_SHIFT_EF_SCAN_START_V1_8821C)
#define BITS_EF_SCAN_START_V1_8821C \
(BIT_MASK_EF_SCAN_START_V1_8821C << BIT_SHIFT_EF_SCAN_START_V1_8821C)
#define BIT_CLEAR_EF_SCAN_START_V1_8821C(x) \
((x) & (~BITS_EF_SCAN_START_V1_8821C))
#define BIT_GET_EF_SCAN_START_V1_8821C(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START_V1_8821C) & \
BIT_MASK_EF_SCAN_START_V1_8821C)
#define BIT_SET_EF_SCAN_START_V1_8821C(x, v) \
(BIT_CLEAR_EF_SCAN_START_V1_8821C(x) | BIT_EF_SCAN_START_V1_8821C(v))
#define BIT_SHIFT_EF_SCAN_END_8821C 12
#define BIT_MASK_EF_SCAN_END_8821C 0xf
#define BIT_EF_SCAN_END_8821C(x) \
(((x) & BIT_MASK_EF_SCAN_END_8821C) << BIT_SHIFT_EF_SCAN_END_8821C)
#define BITS_EF_SCAN_END_8821C \
(BIT_MASK_EF_SCAN_END_8821C << BIT_SHIFT_EF_SCAN_END_8821C)
#define BIT_CLEAR_EF_SCAN_END_8821C(x) ((x) & (~BITS_EF_SCAN_END_8821C))
#define BIT_GET_EF_SCAN_END_8821C(x) \
(((x) >> BIT_SHIFT_EF_SCAN_END_8821C) & BIT_MASK_EF_SCAN_END_8821C)
#define BIT_SET_EF_SCAN_END_8821C(x, v) \
(BIT_CLEAR_EF_SCAN_END_8821C(x) | BIT_EF_SCAN_END_8821C(v))
#define BIT_EF_PD_DIS_8821C BIT(11)
#define BIT_SHIFT_EF_CELL_SEL_8821C 8
#define BIT_MASK_EF_CELL_SEL_8821C 0x3
#define BIT_EF_CELL_SEL_8821C(x) \
(((x) & BIT_MASK_EF_CELL_SEL_8821C) << BIT_SHIFT_EF_CELL_SEL_8821C)
#define BITS_EF_CELL_SEL_8821C \
(BIT_MASK_EF_CELL_SEL_8821C << BIT_SHIFT_EF_CELL_SEL_8821C)
#define BIT_CLEAR_EF_CELL_SEL_8821C(x) ((x) & (~BITS_EF_CELL_SEL_8821C))
#define BIT_GET_EF_CELL_SEL_8821C(x) \
(((x) >> BIT_SHIFT_EF_CELL_SEL_8821C) & BIT_MASK_EF_CELL_SEL_8821C)
#define BIT_SET_EF_CELL_SEL_8821C(x, v) \
(BIT_CLEAR_EF_CELL_SEL_8821C(x) | BIT_EF_CELL_SEL_8821C(v))
#define BIT_EF_TRPT_8821C BIT(7)
#define BIT_SHIFT_EF_TTHD_8821C 0
#define BIT_MASK_EF_TTHD_8821C 0x7f
#define BIT_EF_TTHD_8821C(x) \
(((x) & BIT_MASK_EF_TTHD_8821C) << BIT_SHIFT_EF_TTHD_8821C)
#define BITS_EF_TTHD_8821C (BIT_MASK_EF_TTHD_8821C << BIT_SHIFT_EF_TTHD_8821C)
#define BIT_CLEAR_EF_TTHD_8821C(x) ((x) & (~BITS_EF_TTHD_8821C))
#define BIT_GET_EF_TTHD_8821C(x) \
(((x) >> BIT_SHIFT_EF_TTHD_8821C) & BIT_MASK_EF_TTHD_8821C)
#define BIT_SET_EF_TTHD_8821C(x, v) \
(BIT_CLEAR_EF_TTHD_8821C(x) | BIT_EF_TTHD_8821C(v))
/* 2 REG_PWR_OPTION_CTRL_8821C */
#define BIT_SHIFT_DBG_SEL_V1_8821C 16
#define BIT_MASK_DBG_SEL_V1_8821C 0xff
#define BIT_DBG_SEL_V1_8821C(x) \
(((x) & BIT_MASK_DBG_SEL_V1_8821C) << BIT_SHIFT_DBG_SEL_V1_8821C)
#define BITS_DBG_SEL_V1_8821C \
(BIT_MASK_DBG_SEL_V1_8821C << BIT_SHIFT_DBG_SEL_V1_8821C)
#define BIT_CLEAR_DBG_SEL_V1_8821C(x) ((x) & (~BITS_DBG_SEL_V1_8821C))
#define BIT_GET_DBG_SEL_V1_8821C(x) \
(((x) >> BIT_SHIFT_DBG_SEL_V1_8821C) & BIT_MASK_DBG_SEL_V1_8821C)
#define BIT_SET_DBG_SEL_V1_8821C(x, v) \
(BIT_CLEAR_DBG_SEL_V1_8821C(x) | BIT_DBG_SEL_V1_8821C(v))
#define BIT_SHIFT_DBG_SEL_BYTE_8821C 14
#define BIT_MASK_DBG_SEL_BYTE_8821C 0x3
#define BIT_DBG_SEL_BYTE_8821C(x) \
(((x) & BIT_MASK_DBG_SEL_BYTE_8821C) << BIT_SHIFT_DBG_SEL_BYTE_8821C)
#define BITS_DBG_SEL_BYTE_8821C \
(BIT_MASK_DBG_SEL_BYTE_8821C << BIT_SHIFT_DBG_SEL_BYTE_8821C)
#define BIT_CLEAR_DBG_SEL_BYTE_8821C(x) ((x) & (~BITS_DBG_SEL_BYTE_8821C))
#define BIT_GET_DBG_SEL_BYTE_8821C(x) \
(((x) >> BIT_SHIFT_DBG_SEL_BYTE_8821C) & BIT_MASK_DBG_SEL_BYTE_8821C)
#define BIT_SET_DBG_SEL_BYTE_8821C(x, v) \
(BIT_CLEAR_DBG_SEL_BYTE_8821C(x) | BIT_DBG_SEL_BYTE_8821C(v))
#define BIT_SHIFT_STD_L1_V1_8821C 12
#define BIT_MASK_STD_L1_V1_8821C 0x3
#define BIT_STD_L1_V1_8821C(x) \
(((x) & BIT_MASK_STD_L1_V1_8821C) << BIT_SHIFT_STD_L1_V1_8821C)
#define BITS_STD_L1_V1_8821C \
(BIT_MASK_STD_L1_V1_8821C << BIT_SHIFT_STD_L1_V1_8821C)
#define BIT_CLEAR_STD_L1_V1_8821C(x) ((x) & (~BITS_STD_L1_V1_8821C))
#define BIT_GET_STD_L1_V1_8821C(x) \
(((x) >> BIT_SHIFT_STD_L1_V1_8821C) & BIT_MASK_STD_L1_V1_8821C)
#define BIT_SET_STD_L1_V1_8821C(x, v) \
(BIT_CLEAR_STD_L1_V1_8821C(x) | BIT_STD_L1_V1_8821C(v))
#define BIT_SYSON_DBG_PAD_E2_8821C BIT(11)
#define BIT_SYSON_LED_PAD_E2_8821C BIT(10)
#define BIT_SYSON_GPEE_PAD_E2_8821C BIT(9)
#define BIT_SYSON_PCI_PAD_E2_8821C BIT(8)
#define BIT_AUTO_SW_LDO_VOL_EN_8821C BIT(7)
#define BIT_SHIFT_SYSON_SPS0WWV_WT_8821C 4
#define BIT_MASK_SYSON_SPS0WWV_WT_8821C 0x3
#define BIT_SYSON_SPS0WWV_WT_8821C(x) \
(((x) & BIT_MASK_SYSON_SPS0WWV_WT_8821C) \
<< BIT_SHIFT_SYSON_SPS0WWV_WT_8821C)
#define BITS_SYSON_SPS0WWV_WT_8821C \
(BIT_MASK_SYSON_SPS0WWV_WT_8821C << BIT_SHIFT_SYSON_SPS0WWV_WT_8821C)
#define BIT_CLEAR_SYSON_SPS0WWV_WT_8821C(x) \
((x) & (~BITS_SYSON_SPS0WWV_WT_8821C))
#define BIT_GET_SYSON_SPS0WWV_WT_8821C(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0WWV_WT_8821C) & \
BIT_MASK_SYSON_SPS0WWV_WT_8821C)
#define BIT_SET_SYSON_SPS0WWV_WT_8821C(x, v) \
(BIT_CLEAR_SYSON_SPS0WWV_WT_8821C(x) | BIT_SYSON_SPS0WWV_WT_8821C(v))
#define BIT_SHIFT_SYSON_SPS0LDO_WT_8821C 2
#define BIT_MASK_SYSON_SPS0LDO_WT_8821C 0x3
#define BIT_SYSON_SPS0LDO_WT_8821C(x) \
(((x) & BIT_MASK_SYSON_SPS0LDO_WT_8821C) \
<< BIT_SHIFT_SYSON_SPS0LDO_WT_8821C)
#define BITS_SYSON_SPS0LDO_WT_8821C \
(BIT_MASK_SYSON_SPS0LDO_WT_8821C << BIT_SHIFT_SYSON_SPS0LDO_WT_8821C)
#define BIT_CLEAR_SYSON_SPS0LDO_WT_8821C(x) \
((x) & (~BITS_SYSON_SPS0LDO_WT_8821C))
#define BIT_GET_SYSON_SPS0LDO_WT_8821C(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0LDO_WT_8821C) & \
BIT_MASK_SYSON_SPS0LDO_WT_8821C)
#define BIT_SET_SYSON_SPS0LDO_WT_8821C(x, v) \
(BIT_CLEAR_SYSON_SPS0LDO_WT_8821C(x) | BIT_SYSON_SPS0LDO_WT_8821C(v))
#define BIT_SHIFT_SYSON_RCLK_SCALE_8821C 0
#define BIT_MASK_SYSON_RCLK_SCALE_8821C 0x3
#define BIT_SYSON_RCLK_SCALE_8821C(x) \
(((x) & BIT_MASK_SYSON_RCLK_SCALE_8821C) \
<< BIT_SHIFT_SYSON_RCLK_SCALE_8821C)
#define BITS_SYSON_RCLK_SCALE_8821C \
(BIT_MASK_SYSON_RCLK_SCALE_8821C << BIT_SHIFT_SYSON_RCLK_SCALE_8821C)
#define BIT_CLEAR_SYSON_RCLK_SCALE_8821C(x) \
((x) & (~BITS_SYSON_RCLK_SCALE_8821C))
#define BIT_GET_SYSON_RCLK_SCALE_8821C(x) \
(((x) >> BIT_SHIFT_SYSON_RCLK_SCALE_8821C) & \
BIT_MASK_SYSON_RCLK_SCALE_8821C)
#define BIT_SET_SYSON_RCLK_SCALE_8821C(x, v) \
(BIT_CLEAR_SYSON_RCLK_SCALE_8821C(x) | BIT_SYSON_RCLK_SCALE_8821C(v))
/* 2 REG_CAL_TIMER_8821C */
#define BIT_SHIFT_MATCH_CNT_8821C 8
#define BIT_MASK_MATCH_CNT_8821C 0xff
#define BIT_MATCH_CNT_8821C(x) \
(((x) & BIT_MASK_MATCH_CNT_8821C) << BIT_SHIFT_MATCH_CNT_8821C)
#define BITS_MATCH_CNT_8821C \
(BIT_MASK_MATCH_CNT_8821C << BIT_SHIFT_MATCH_CNT_8821C)
#define BIT_CLEAR_MATCH_CNT_8821C(x) ((x) & (~BITS_MATCH_CNT_8821C))
#define BIT_GET_MATCH_CNT_8821C(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8821C) & BIT_MASK_MATCH_CNT_8821C)
#define BIT_SET_MATCH_CNT_8821C(x, v) \
(BIT_CLEAR_MATCH_CNT_8821C(x) | BIT_MATCH_CNT_8821C(v))
#define BIT_SHIFT_CAL_SCAL_8821C 0
#define BIT_MASK_CAL_SCAL_8821C 0xff
#define BIT_CAL_SCAL_8821C(x) \
(((x) & BIT_MASK_CAL_SCAL_8821C) << BIT_SHIFT_CAL_SCAL_8821C)
#define BITS_CAL_SCAL_8821C \
(BIT_MASK_CAL_SCAL_8821C << BIT_SHIFT_CAL_SCAL_8821C)
#define BIT_CLEAR_CAL_SCAL_8821C(x) ((x) & (~BITS_CAL_SCAL_8821C))
#define BIT_GET_CAL_SCAL_8821C(x) \
(((x) >> BIT_SHIFT_CAL_SCAL_8821C) & BIT_MASK_CAL_SCAL_8821C)
#define BIT_SET_CAL_SCAL_8821C(x, v) \
(BIT_CLEAR_CAL_SCAL_8821C(x) | BIT_CAL_SCAL_8821C(v))
/* 2 REG_ACLK_MON_8821C */
#define BIT_SHIFT_RCLK_MON_8821C 5
#define BIT_MASK_RCLK_MON_8821C 0x7ff
#define BIT_RCLK_MON_8821C(x) \
(((x) & BIT_MASK_RCLK_MON_8821C) << BIT_SHIFT_RCLK_MON_8821C)
#define BITS_RCLK_MON_8821C \
(BIT_MASK_RCLK_MON_8821C << BIT_SHIFT_RCLK_MON_8821C)
#define BIT_CLEAR_RCLK_MON_8821C(x) ((x) & (~BITS_RCLK_MON_8821C))
#define BIT_GET_RCLK_MON_8821C(x) \
(((x) >> BIT_SHIFT_RCLK_MON_8821C) & BIT_MASK_RCLK_MON_8821C)
#define BIT_SET_RCLK_MON_8821C(x, v) \
(BIT_CLEAR_RCLK_MON_8821C(x) | BIT_RCLK_MON_8821C(v))
#define BIT_CAL_EN_8821C BIT(4)
#define BIT_SHIFT_DPSTU_8821C 2
#define BIT_MASK_DPSTU_8821C 0x3
#define BIT_DPSTU_8821C(x) \
(((x) & BIT_MASK_DPSTU_8821C) << BIT_SHIFT_DPSTU_8821C)
#define BITS_DPSTU_8821C (BIT_MASK_DPSTU_8821C << BIT_SHIFT_DPSTU_8821C)
#define BIT_CLEAR_DPSTU_8821C(x) ((x) & (~BITS_DPSTU_8821C))
#define BIT_GET_DPSTU_8821C(x) \
(((x) >> BIT_SHIFT_DPSTU_8821C) & BIT_MASK_DPSTU_8821C)
#define BIT_SET_DPSTU_8821C(x, v) \
(BIT_CLEAR_DPSTU_8821C(x) | BIT_DPSTU_8821C(v))
#define BIT_SUS_16X_8821C BIT(1)
/* 2 REG_GPIO_MUXCFG_8821C */
#define BIT_FSPI_EN_8821C BIT(19)
#define BIT_WL_RTS_EXT_32K_SEL_8821C BIT(18)
#define BIT_WLGP_SPI_EN_8821C BIT(16)
#define BIT_SIC_LBK_8821C BIT(15)
#define BIT_ENHTP_8821C BIT(14)
#define BIT_ENSIC_8821C BIT(12)
#define BIT_SIC_SWRST_8821C BIT(11)
#define BIT_PO_WIFI_PTA_PINS_8821C BIT(10)
#define BIT_PO_BT_PTA_PINS_8821C BIT(9)
#define BIT_ENUART_8821C BIT(8)
#define BIT_SHIFT_BTMODE_8821C 6
#define BIT_MASK_BTMODE_8821C 0x3
#define BIT_BTMODE_8821C(x) \
(((x) & BIT_MASK_BTMODE_8821C) << BIT_SHIFT_BTMODE_8821C)
#define BITS_BTMODE_8821C (BIT_MASK_BTMODE_8821C << BIT_SHIFT_BTMODE_8821C)
#define BIT_CLEAR_BTMODE_8821C(x) ((x) & (~BITS_BTMODE_8821C))
#define BIT_GET_BTMODE_8821C(x) \
(((x) >> BIT_SHIFT_BTMODE_8821C) & BIT_MASK_BTMODE_8821C)
#define BIT_SET_BTMODE_8821C(x, v) \
(BIT_CLEAR_BTMODE_8821C(x) | BIT_BTMODE_8821C(v))
#define BIT_ENBT_8821C BIT(5)
#define BIT_EROM_EN_8821C BIT(4)
#define BIT_WLRFE_6_7_EN_8821C BIT(3)
#define BIT_WLRFE_4_5_EN_8821C BIT(2)
#define BIT_SHIFT_GPIOSEL_8821C 0
#define BIT_MASK_GPIOSEL_8821C 0x3
#define BIT_GPIOSEL_8821C(x) \
(((x) & BIT_MASK_GPIOSEL_8821C) << BIT_SHIFT_GPIOSEL_8821C)
#define BITS_GPIOSEL_8821C (BIT_MASK_GPIOSEL_8821C << BIT_SHIFT_GPIOSEL_8821C)
#define BIT_CLEAR_GPIOSEL_8821C(x) ((x) & (~BITS_GPIOSEL_8821C))
#define BIT_GET_GPIOSEL_8821C(x) \
(((x) >> BIT_SHIFT_GPIOSEL_8821C) & BIT_MASK_GPIOSEL_8821C)
#define BIT_SET_GPIOSEL_8821C(x, v) \
(BIT_CLEAR_GPIOSEL_8821C(x) | BIT_GPIOSEL_8821C(v))
/* 2 REG_GPIO_PIN_CTRL_8821C */
#define BIT_SHIFT_GPIO_MOD_7_TO_0_8821C 24
#define BIT_MASK_GPIO_MOD_7_TO_0_8821C 0xff
#define BIT_GPIO_MOD_7_TO_0_8821C(x) \
(((x) & BIT_MASK_GPIO_MOD_7_TO_0_8821C) \
<< BIT_SHIFT_GPIO_MOD_7_TO_0_8821C)
#define BITS_GPIO_MOD_7_TO_0_8821C \
(BIT_MASK_GPIO_MOD_7_TO_0_8821C << BIT_SHIFT_GPIO_MOD_7_TO_0_8821C)
#define BIT_CLEAR_GPIO_MOD_7_TO_0_8821C(x) ((x) & (~BITS_GPIO_MOD_7_TO_0_8821C))
#define BIT_GET_GPIO_MOD_7_TO_0_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_7_TO_0_8821C) & \
BIT_MASK_GPIO_MOD_7_TO_0_8821C)
#define BIT_SET_GPIO_MOD_7_TO_0_8821C(x, v) \
(BIT_CLEAR_GPIO_MOD_7_TO_0_8821C(x) | BIT_GPIO_MOD_7_TO_0_8821C(v))
#define BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8821C 16
#define BIT_MASK_GPIO_IO_SEL_7_TO_0_8821C 0xff
#define BIT_GPIO_IO_SEL_7_TO_0_8821C(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_7_TO_0_8821C) \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8821C)
#define BITS_GPIO_IO_SEL_7_TO_0_8821C \
(BIT_MASK_GPIO_IO_SEL_7_TO_0_8821C \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8821C)
#define BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8821C(x) \
((x) & (~BITS_GPIO_IO_SEL_7_TO_0_8821C))
#define BIT_GET_GPIO_IO_SEL_7_TO_0_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8821C) & \
BIT_MASK_GPIO_IO_SEL_7_TO_0_8821C)
#define BIT_SET_GPIO_IO_SEL_7_TO_0_8821C(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8821C(x) | \
BIT_GPIO_IO_SEL_7_TO_0_8821C(v))
#define BIT_SHIFT_GPIO_OUT_7_TO_0_8821C 8
#define BIT_MASK_GPIO_OUT_7_TO_0_8821C 0xff
#define BIT_GPIO_OUT_7_TO_0_8821C(x) \
(((x) & BIT_MASK_GPIO_OUT_7_TO_0_8821C) \
<< BIT_SHIFT_GPIO_OUT_7_TO_0_8821C)
#define BITS_GPIO_OUT_7_TO_0_8821C \
(BIT_MASK_GPIO_OUT_7_TO_0_8821C << BIT_SHIFT_GPIO_OUT_7_TO_0_8821C)
#define BIT_CLEAR_GPIO_OUT_7_TO_0_8821C(x) ((x) & (~BITS_GPIO_OUT_7_TO_0_8821C))
#define BIT_GET_GPIO_OUT_7_TO_0_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_7_TO_0_8821C) & \
BIT_MASK_GPIO_OUT_7_TO_0_8821C)
#define BIT_SET_GPIO_OUT_7_TO_0_8821C(x, v) \
(BIT_CLEAR_GPIO_OUT_7_TO_0_8821C(x) | BIT_GPIO_OUT_7_TO_0_8821C(v))
#define BIT_SHIFT_GPIO_IN_7_TO_0_8821C 0
#define BIT_MASK_GPIO_IN_7_TO_0_8821C 0xff
#define BIT_GPIO_IN_7_TO_0_8821C(x) \
(((x) & BIT_MASK_GPIO_IN_7_TO_0_8821C) \
<< BIT_SHIFT_GPIO_IN_7_TO_0_8821C)
#define BITS_GPIO_IN_7_TO_0_8821C \
(BIT_MASK_GPIO_IN_7_TO_0_8821C << BIT_SHIFT_GPIO_IN_7_TO_0_8821C)
#define BIT_CLEAR_GPIO_IN_7_TO_0_8821C(x) ((x) & (~BITS_GPIO_IN_7_TO_0_8821C))
#define BIT_GET_GPIO_IN_7_TO_0_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_IN_7_TO_0_8821C) & \
BIT_MASK_GPIO_IN_7_TO_0_8821C)
#define BIT_SET_GPIO_IN_7_TO_0_8821C(x, v) \
(BIT_CLEAR_GPIO_IN_7_TO_0_8821C(x) | BIT_GPIO_IN_7_TO_0_8821C(v))
/* 2 REG_GPIO_INTM_8821C */
#define BIT_SHIFT_MUXDBG_SEL_8821C 30
#define BIT_MASK_MUXDBG_SEL_8821C 0x3
#define BIT_MUXDBG_SEL_8821C(x) \
(((x) & BIT_MASK_MUXDBG_SEL_8821C) << BIT_SHIFT_MUXDBG_SEL_8821C)
#define BITS_MUXDBG_SEL_8821C \
(BIT_MASK_MUXDBG_SEL_8821C << BIT_SHIFT_MUXDBG_SEL_8821C)
#define BIT_CLEAR_MUXDBG_SEL_8821C(x) ((x) & (~BITS_MUXDBG_SEL_8821C))
#define BIT_GET_MUXDBG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL_8821C) & BIT_MASK_MUXDBG_SEL_8821C)
#define BIT_SET_MUXDBG_SEL_8821C(x, v) \
(BIT_CLEAR_MUXDBG_SEL_8821C(x) | BIT_MUXDBG_SEL_8821C(v))
#define BIT_EXTWOL_SEL_8821C BIT(17)
#define BIT_EXTWOL_EN_8821C BIT(16)
#define BIT_GPIOF_INT_MD_8821C BIT(15)
#define BIT_GPIOE_INT_MD_8821C BIT(14)
#define BIT_GPIOD_INT_MD_8821C BIT(13)
#define BIT_GPIOF_INT_MD_8821C BIT(15)
#define BIT_GPIOE_INT_MD_8821C BIT(14)
#define BIT_GPIOD_INT_MD_8821C BIT(13)
#define BIT_GPIOC_INT_MD_8821C BIT(12)
#define BIT_GPIOB_INT_MD_8821C BIT(11)
#define BIT_GPIOA_INT_MD_8821C BIT(10)
#define BIT_GPIO9_INT_MD_8821C BIT(9)
#define BIT_GPIO8_INT_MD_8821C BIT(8)
#define BIT_GPIO7_INT_MD_8821C BIT(7)
#define BIT_GPIO6_INT_MD_8821C BIT(6)
#define BIT_GPIO5_INT_MD_8821C BIT(5)
#define BIT_GPIO4_INT_MD_8821C BIT(4)
#define BIT_GPIO3_INT_MD_8821C BIT(3)
#define BIT_GPIO2_INT_MD_8821C BIT(2)
#define BIT_GPIO1_INT_MD_8821C BIT(1)
#define BIT_GPIO0_INT_MD_8821C BIT(0)
/* 2 REG_LED_CFG_8821C */
#define BIT_GPIO3_WL_CTRL_EN_8821C BIT(27)
#define BIT_LNAON_SEL_EN_8821C BIT(26)
#define BIT_PAPE_SEL_EN_8821C BIT(25)
#define BIT_DPDT_WLBT_SEL_8821C BIT(24)
#define BIT_DPDT_SEL_EN_8821C BIT(23)
#define BIT_GPIO13_14_WL_CTRL_EN_8821C BIT(22)
#define BIT_LED2DIS_8821C BIT(21)
#define BIT_LED2PL_8821C BIT(20)
#define BIT_LED2SV_8821C BIT(19)
#define BIT_SHIFT_LED2CM_8821C 16
#define BIT_MASK_LED2CM_8821C 0x7
#define BIT_LED2CM_8821C(x) \
(((x) & BIT_MASK_LED2CM_8821C) << BIT_SHIFT_LED2CM_8821C)
#define BITS_LED2CM_8821C (BIT_MASK_LED2CM_8821C << BIT_SHIFT_LED2CM_8821C)
#define BIT_CLEAR_LED2CM_8821C(x) ((x) & (~BITS_LED2CM_8821C))
#define BIT_GET_LED2CM_8821C(x) \
(((x) >> BIT_SHIFT_LED2CM_8821C) & BIT_MASK_LED2CM_8821C)
#define BIT_SET_LED2CM_8821C(x, v) \
(BIT_CLEAR_LED2CM_8821C(x) | BIT_LED2CM_8821C(v))
#define BIT_LED1DIS_8821C BIT(15)
#define BIT_LED1PL_8821C BIT(12)
#define BIT_LED1SV_8821C BIT(11)
#define BIT_SHIFT_LED1CM_8821C 8
#define BIT_MASK_LED1CM_8821C 0x7
#define BIT_LED1CM_8821C(x) \
(((x) & BIT_MASK_LED1CM_8821C) << BIT_SHIFT_LED1CM_8821C)
#define BITS_LED1CM_8821C (BIT_MASK_LED1CM_8821C << BIT_SHIFT_LED1CM_8821C)
#define BIT_CLEAR_LED1CM_8821C(x) ((x) & (~BITS_LED1CM_8821C))
#define BIT_GET_LED1CM_8821C(x) \
(((x) >> BIT_SHIFT_LED1CM_8821C) & BIT_MASK_LED1CM_8821C)
#define BIT_SET_LED1CM_8821C(x, v) \
(BIT_CLEAR_LED1CM_8821C(x) | BIT_LED1CM_8821C(v))
#define BIT_LED0DIS_8821C BIT(7)
#define BIT_SHIFT_AFE_LDO_SWR_CHECK_8821C 5
#define BIT_MASK_AFE_LDO_SWR_CHECK_8821C 0x3
#define BIT_AFE_LDO_SWR_CHECK_8821C(x) \
(((x) & BIT_MASK_AFE_LDO_SWR_CHECK_8821C) \
<< BIT_SHIFT_AFE_LDO_SWR_CHECK_8821C)
#define BITS_AFE_LDO_SWR_CHECK_8821C \
(BIT_MASK_AFE_LDO_SWR_CHECK_8821C << BIT_SHIFT_AFE_LDO_SWR_CHECK_8821C)
#define BIT_CLEAR_AFE_LDO_SWR_CHECK_8821C(x) \
((x) & (~BITS_AFE_LDO_SWR_CHECK_8821C))
#define BIT_GET_AFE_LDO_SWR_CHECK_8821C(x) \
(((x) >> BIT_SHIFT_AFE_LDO_SWR_CHECK_8821C) & \
BIT_MASK_AFE_LDO_SWR_CHECK_8821C)
#define BIT_SET_AFE_LDO_SWR_CHECK_8821C(x, v) \
(BIT_CLEAR_AFE_LDO_SWR_CHECK_8821C(x) | BIT_AFE_LDO_SWR_CHECK_8821C(v))
#define BIT_LED0PL_8821C BIT(4)
#define BIT_LED0SV_8821C BIT(3)
#define BIT_SHIFT_LED0CM_8821C 0
#define BIT_MASK_LED0CM_8821C 0x7
#define BIT_LED0CM_8821C(x) \
(((x) & BIT_MASK_LED0CM_8821C) << BIT_SHIFT_LED0CM_8821C)
#define BITS_LED0CM_8821C (BIT_MASK_LED0CM_8821C << BIT_SHIFT_LED0CM_8821C)
#define BIT_CLEAR_LED0CM_8821C(x) ((x) & (~BITS_LED0CM_8821C))
#define BIT_GET_LED0CM_8821C(x) \
(((x) >> BIT_SHIFT_LED0CM_8821C) & BIT_MASK_LED0CM_8821C)
#define BIT_SET_LED0CM_8821C(x, v) \
(BIT_CLEAR_LED0CM_8821C(x) | BIT_LED0CM_8821C(v))
/* 2 REG_FSIMR_8821C */
#define BIT_FS_PDNINT_EN_8821C BIT(31)
#define BIT_NFC_INT_PAD_EN_8821C BIT(30)
#define BIT_FS_SPS_OCP_INT_EN_8821C BIT(29)
#define BIT_FS_PWMERR_INT_EN_8821C BIT(28)
#define BIT_FS_GPIOF_INT_EN_8821C BIT(27)
#define BIT_FS_GPIOE_INT_EN_8821C BIT(26)
#define BIT_FS_GPIOD_INT_EN_8821C BIT(25)
#define BIT_FS_GPIOC_INT_EN_8821C BIT(24)
#define BIT_FS_GPIOB_INT_EN_8821C BIT(23)
#define BIT_FS_GPIOA_INT_EN_8821C BIT(22)
#define BIT_FS_GPIO9_INT_EN_8821C BIT(21)
#define BIT_FS_GPIO8_INT_EN_8821C BIT(20)
#define BIT_FS_GPIO7_INT_EN_8821C BIT(19)
#define BIT_FS_GPIO6_INT_EN_8821C BIT(18)
#define BIT_FS_GPIO5_INT_EN_8821C BIT(17)
#define BIT_FS_GPIO4_INT_EN_8821C BIT(16)
#define BIT_FS_GPIO3_INT_EN_8821C BIT(15)
#define BIT_FS_GPIO2_INT_EN_8821C BIT(14)
#define BIT_FS_GPIO1_INT_EN_8821C BIT(13)
#define BIT_FS_GPIO0_INT_EN_8821C BIT(12)
#define BIT_FS_HCI_SUS_EN_8821C BIT(11)
#define BIT_FS_HCI_RES_EN_8821C BIT(10)
#define BIT_FS_HCI_RESET_EN_8821C BIT(9)
#define BIT_USB_SCSI_CMD_EN_8821C BIT(8)
#define BIT_FS_BTON_STS_UPDATE_MSK_EN_8821C BIT(7)
#define BIT_ACT2RECOVERY_INT_EN_V1_8821C BIT(6)
#define BIT_GEN1GEN2_SWITCH_8821C BIT(5)
#define BIT_HCI_TXDMA_REQ_HIMR_8821C BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_MAK_8821C BIT(3)
#define BIT_FS_32K_ENTER_SETTING_MAK_8821C BIT(2)
#define BIT_FS_USB_LPMRSM_MSK_8821C BIT(1)
#define BIT_FS_USB_LPMINT_MSK_8821C BIT(0)
/* 2 REG_FSISR_8821C */
#define BIT_FS_PDNINT_8821C BIT(31)
#define BIT_FS_SPS_OCP_INT_8821C BIT(29)
#define BIT_FS_PWMERR_INT_8821C BIT(28)
#define BIT_FS_GPIOF_INT_8821C BIT(27)
#define BIT_FS_GPIOE_INT_8821C BIT(26)
#define BIT_FS_GPIOD_INT_8821C BIT(25)
#define BIT_FS_GPIOC_INT_8821C BIT(24)
#define BIT_FS_GPIOB_INT_8821C BIT(23)
#define BIT_FS_GPIOA_INT_8821C BIT(22)
#define BIT_FS_GPIO9_INT_8821C BIT(21)
#define BIT_FS_GPIO8_INT_8821C BIT(20)
#define BIT_FS_GPIO7_INT_8821C BIT(19)
#define BIT_FS_GPIO6_INT_8821C BIT(18)
#define BIT_FS_GPIO5_INT_8821C BIT(17)
#define BIT_FS_GPIO4_INT_8821C BIT(16)
#define BIT_FS_GPIO3_INT_8821C BIT(15)
#define BIT_FS_GPIO2_INT_8821C BIT(14)
#define BIT_FS_GPIO1_INT_8821C BIT(13)
#define BIT_FS_GPIO0_INT_8821C BIT(12)
#define BIT_FS_HCI_SUS_INT_8821C BIT(11)
#define BIT_FS_HCI_RES_INT_8821C BIT(10)
#define BIT_FS_HCI_RESET_INT_8821C BIT(9)
#define BIT_USB_SCSI_CMD_INT_8821C BIT(8)
#define BIT_ACT2RECOVERY_8821C BIT(6)
#define BIT_GEN1GEN2_SWITCH_8821C BIT(5)
#define BIT_HCI_TXDMA_REQ_HISR_8821C BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_INT_8821C BIT(3)
#define BIT_FS_32K_ENTER_SETTING_INT_8821C BIT(2)
#define BIT_FS_USB_LPMRSM_INT_8821C BIT(1)
#define BIT_FS_USB_LPMINT_INT_8821C BIT(0)
/* 2 REG_HSIMR_8821C */
#define BIT_GPIOF_INT_EN_8821C BIT(31)
#define BIT_GPIOE_INT_EN_8821C BIT(30)
#define BIT_GPIOD_INT_EN_8821C BIT(29)
#define BIT_GPIOC_INT_EN_8821C BIT(28)
#define BIT_GPIOB_INT_EN_8821C BIT(27)
#define BIT_GPIOA_INT_EN_8821C BIT(26)
#define BIT_GPIO9_INT_EN_8821C BIT(25)
#define BIT_GPIO8_INT_EN_8821C BIT(24)
#define BIT_GPIO7_INT_EN_8821C BIT(23)
#define BIT_GPIO6_INT_EN_8821C BIT(22)
#define BIT_GPIO5_INT_EN_8821C BIT(21)
#define BIT_GPIO4_INT_EN_8821C BIT(20)
#define BIT_GPIO3_INT_EN_8821C BIT(19)
#define BIT_GPIO2_INT_EN_V1_8821C BIT(18)
#define BIT_GPIO1_INT_EN_8821C BIT(17)
#define BIT_GPIO0_INT_EN_8821C BIT(16)
#define BIT_PDNINT_EN_8821C BIT(7)
#define BIT_RON_INT_EN_8821C BIT(6)
#define BIT_SPS_OCP_INT_EN_8821C BIT(5)
#define BIT_GPIO15_0_INT_EN_8821C BIT(0)
/* 2 REG_HSISR_8821C */
#define BIT_GPIOF_INT_8821C BIT(31)
#define BIT_GPIOE_INT_8821C BIT(30)
#define BIT_GPIOD_INT_8821C BIT(29)
#define BIT_GPIOC_INT_8821C BIT(28)
#define BIT_GPIOB_INT_8821C BIT(27)
#define BIT_GPIOA_INT_8821C BIT(26)
#define BIT_GPIO9_INT_8821C BIT(25)
#define BIT_GPIO8_INT_8821C BIT(24)
#define BIT_GPIO7_INT_8821C BIT(23)
#define BIT_GPIO6_INT_8821C BIT(22)
#define BIT_GPIO5_INT_8821C BIT(21)
#define BIT_GPIO4_INT_8821C BIT(20)
#define BIT_GPIO3_INT_8821C BIT(19)
#define BIT_GPIO2_INT_V1_8821C BIT(18)
#define BIT_GPIO1_INT_8821C BIT(17)
#define BIT_GPIO0_INT_8821C BIT(16)
#define BIT_PDNINT_8821C BIT(7)
#define BIT_RON_INT_8821C BIT(6)
#define BIT_SPS_OCP_INT_8821C BIT(5)
#define BIT_GPIO15_0_INT_8821C BIT(0)
/* 2 REG_GPIO_EXT_CTRL_8821C */
#define BIT_SHIFT_GPIO_MOD_15_TO_8_8821C 24
#define BIT_MASK_GPIO_MOD_15_TO_8_8821C 0xff
#define BIT_GPIO_MOD_15_TO_8_8821C(x) \
(((x) & BIT_MASK_GPIO_MOD_15_TO_8_8821C) \
<< BIT_SHIFT_GPIO_MOD_15_TO_8_8821C)
#define BITS_GPIO_MOD_15_TO_8_8821C \
(BIT_MASK_GPIO_MOD_15_TO_8_8821C << BIT_SHIFT_GPIO_MOD_15_TO_8_8821C)
#define BIT_CLEAR_GPIO_MOD_15_TO_8_8821C(x) \
((x) & (~BITS_GPIO_MOD_15_TO_8_8821C))
#define BIT_GET_GPIO_MOD_15_TO_8_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_15_TO_8_8821C) & \
BIT_MASK_GPIO_MOD_15_TO_8_8821C)
#define BIT_SET_GPIO_MOD_15_TO_8_8821C(x, v) \
(BIT_CLEAR_GPIO_MOD_15_TO_8_8821C(x) | BIT_GPIO_MOD_15_TO_8_8821C(v))
#define BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8821C 16
#define BIT_MASK_GPIO_IO_SEL_15_TO_8_8821C 0xff
#define BIT_GPIO_IO_SEL_15_TO_8_8821C(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_15_TO_8_8821C) \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8821C)
#define BITS_GPIO_IO_SEL_15_TO_8_8821C \
(BIT_MASK_GPIO_IO_SEL_15_TO_8_8821C \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8821C)
#define BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8821C(x) \
((x) & (~BITS_GPIO_IO_SEL_15_TO_8_8821C))
#define BIT_GET_GPIO_IO_SEL_15_TO_8_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8821C) & \
BIT_MASK_GPIO_IO_SEL_15_TO_8_8821C)
#define BIT_SET_GPIO_IO_SEL_15_TO_8_8821C(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8821C(x) | \
BIT_GPIO_IO_SEL_15_TO_8_8821C(v))
#define BIT_SHIFT_GPIO_OUT_15_TO_8_8821C 8
#define BIT_MASK_GPIO_OUT_15_TO_8_8821C 0xff
#define BIT_GPIO_OUT_15_TO_8_8821C(x) \
(((x) & BIT_MASK_GPIO_OUT_15_TO_8_8821C) \
<< BIT_SHIFT_GPIO_OUT_15_TO_8_8821C)
#define BITS_GPIO_OUT_15_TO_8_8821C \
(BIT_MASK_GPIO_OUT_15_TO_8_8821C << BIT_SHIFT_GPIO_OUT_15_TO_8_8821C)
#define BIT_CLEAR_GPIO_OUT_15_TO_8_8821C(x) \
((x) & (~BITS_GPIO_OUT_15_TO_8_8821C))
#define BIT_GET_GPIO_OUT_15_TO_8_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_15_TO_8_8821C) & \
BIT_MASK_GPIO_OUT_15_TO_8_8821C)
#define BIT_SET_GPIO_OUT_15_TO_8_8821C(x, v) \
(BIT_CLEAR_GPIO_OUT_15_TO_8_8821C(x) | BIT_GPIO_OUT_15_TO_8_8821C(v))
#define BIT_SHIFT_GPIO_IN_15_TO_8_8821C 0
#define BIT_MASK_GPIO_IN_15_TO_8_8821C 0xff
#define BIT_GPIO_IN_15_TO_8_8821C(x) \
(((x) & BIT_MASK_GPIO_IN_15_TO_8_8821C) \
<< BIT_SHIFT_GPIO_IN_15_TO_8_8821C)
#define BITS_GPIO_IN_15_TO_8_8821C \
(BIT_MASK_GPIO_IN_15_TO_8_8821C << BIT_SHIFT_GPIO_IN_15_TO_8_8821C)
#define BIT_CLEAR_GPIO_IN_15_TO_8_8821C(x) ((x) & (~BITS_GPIO_IN_15_TO_8_8821C))
#define BIT_GET_GPIO_IN_15_TO_8_8821C(x) \
(((x) >> BIT_SHIFT_GPIO_IN_15_TO_8_8821C) & \
BIT_MASK_GPIO_IN_15_TO_8_8821C)
#define BIT_SET_GPIO_IN_15_TO_8_8821C(x, v) \
(BIT_CLEAR_GPIO_IN_15_TO_8_8821C(x) | BIT_GPIO_IN_15_TO_8_8821C(v))
/* 2 REG_PAD_CTRL1_8821C */
#define BIT_PAPE_WLBT_SEL_8821C BIT(29)
#define BIT_LNAON_WLBT_SEL_8821C BIT(28)
#define BIT_BTGP_GPG3_FEN_8821C BIT(26)
#define BIT_BTGP_GPG2_FEN_8821C BIT(25)
#define BIT_BTGP_JTAG_EN_8821C BIT(24)
#define BIT_XTAL_CLK_EXTARNAL_EN_8821C BIT(23)
#define BIT_BTGP_UART0_EN_8821C BIT(22)
#define BIT_BTGP_UART1_EN_8821C BIT(21)
#define BIT_BTGP_SPI_EN_8821C BIT(20)
#define BIT_BTGP_GPIO_E2_8821C BIT(19)
#define BIT_BTGP_GPIO_EN_8821C BIT(18)
#define BIT_SHIFT_BTGP_GPIO_SL_8821C 16
#define BIT_MASK_BTGP_GPIO_SL_8821C 0x3
#define BIT_BTGP_GPIO_SL_8821C(x) \
(((x) & BIT_MASK_BTGP_GPIO_SL_8821C) << BIT_SHIFT_BTGP_GPIO_SL_8821C)
#define BITS_BTGP_GPIO_SL_8821C \
(BIT_MASK_BTGP_GPIO_SL_8821C << BIT_SHIFT_BTGP_GPIO_SL_8821C)
#define BIT_CLEAR_BTGP_GPIO_SL_8821C(x) ((x) & (~BITS_BTGP_GPIO_SL_8821C))
#define BIT_GET_BTGP_GPIO_SL_8821C(x) \
(((x) >> BIT_SHIFT_BTGP_GPIO_SL_8821C) & BIT_MASK_BTGP_GPIO_SL_8821C)
#define BIT_SET_BTGP_GPIO_SL_8821C(x, v) \
(BIT_CLEAR_BTGP_GPIO_SL_8821C(x) | BIT_BTGP_GPIO_SL_8821C(v))
#define BIT_PAD_SDIO_SR_8821C BIT(14)
#define BIT_GPIO14_OUTPUT_PL_8821C BIT(13)
#define BIT_HOST_WAKE_PAD_PULL_EN_8821C BIT(12)
#define BIT_HOST_WAKE_PAD_SL_8821C BIT(11)
#define BIT_PAD_LNAON_SR_8821C BIT(10)
#define BIT_PAD_LNAON_E2_8821C BIT(9)
#define BIT_SW_LNAON_G_SEL_DATA_8821C BIT(8)
#define BIT_SW_LNAON_A_SEL_DATA_8821C BIT(7)
#define BIT_PAD_PAPE_SR_8821C BIT(6)
#define BIT_PAD_PAPE_E2_8821C BIT(5)
#define BIT_SW_PAPE_G_SEL_DATA_8821C BIT(4)
#define BIT_SW_PAPE_A_SEL_DATA_8821C BIT(3)
#define BIT_PAD_DPDT_SR_8821C BIT(2)
#define BIT_PAD_DPDT_PAD_E2_8821C BIT(1)
#define BIT_SW_DPDT_SEL_DATA_8821C BIT(0)
/* 2 REG_WL_BT_PWR_CTRL_8821C */
#define BIT_ISO_BD2PP_8821C BIT(31)
#define BIT_LDOV12B_EN_8821C BIT(30)
#define BIT_CKEN_BTGPS_8821C BIT(29)
#define BIT_FEN_BTGPS_8821C BIT(28)
#define BIT_BTCPU_BOOTSEL_8821C BIT(27)
#define BIT_SPI_SPEEDUP_8821C BIT(26)
#define BIT_DEVWAKE_PAD_TYPE_SEL_8821C BIT(24)
#define BIT_CLKREQ_PAD_TYPE_SEL_8821C BIT(23)
#define BIT_ISO_BTPON2PP_8821C BIT(22)
#define BIT_BT_HWROF_EN_8821C BIT(19)
#define BIT_BT_FUNC_EN_8821C BIT(18)
#define BIT_BT_HWPDN_SL_8821C BIT(17)
#define BIT_BT_DISN_EN_8821C BIT(16)
#define BIT_BT_PDN_PULL_EN_8821C BIT(15)
#define BIT_WL_PDN_PULL_EN_8821C BIT(14)
#define BIT_EXTERNAL_REQUEST_PL_8821C BIT(13)
#define BIT_GPIO0_2_3_PULL_LOW_EN_8821C BIT(12)
#define BIT_ISO_BA2PP_8821C BIT(11)
#define BIT_BT_AFE_LDO_EN_8821C BIT(10)
#define BIT_BT_AFE_PLL_EN_8821C BIT(9)
#define BIT_BT_DIG_CLK_EN_8821C BIT(8)
#define BIT_WL_DRV_EXIST_IDX_8821C BIT(5)
#define BIT_DOP_EHPAD_8821C BIT(4)
#define BIT_WL_HWROF_EN_8821C BIT(3)
#define BIT_WL_FUNC_EN_8821C BIT(2)
#define BIT_WL_HWPDN_SL_8821C BIT(1)
#define BIT_WL_HWPDN_EN_8821C BIT(0)
/* 2 REG_SDM_DEBUG_8821C */
#define BIT_SHIFT_WLCLK_PHASE_8821C 0
#define BIT_MASK_WLCLK_PHASE_8821C 0x1f
#define BIT_WLCLK_PHASE_8821C(x) \
(((x) & BIT_MASK_WLCLK_PHASE_8821C) << BIT_SHIFT_WLCLK_PHASE_8821C)
#define BITS_WLCLK_PHASE_8821C \
(BIT_MASK_WLCLK_PHASE_8821C << BIT_SHIFT_WLCLK_PHASE_8821C)
#define BIT_CLEAR_WLCLK_PHASE_8821C(x) ((x) & (~BITS_WLCLK_PHASE_8821C))
#define BIT_GET_WLCLK_PHASE_8821C(x) \
(((x) >> BIT_SHIFT_WLCLK_PHASE_8821C) & BIT_MASK_WLCLK_PHASE_8821C)
#define BIT_SET_WLCLK_PHASE_8821C(x, v) \
(BIT_CLEAR_WLCLK_PHASE_8821C(x) | BIT_WLCLK_PHASE_8821C(v))
/* 2 REG_SYS_SDIO_CTRL_8821C */
#define BIT_DBG_GNT_WL_BT_8821C BIT(27)
#define BIT_LTE_MUX_CTRL_PATH_8821C BIT(26)
#define BIT_LTE_COEX_UART_8821C BIT(25)
#define BIT_3W_LTE_WL_GPIO_8821C BIT(24)
#define BIT_SDIO_INT_POLARITY_8821C BIT(19)
#define BIT_SDIO_INT_8821C BIT(18)
#define BIT_SDIO_OFF_EN_8821C BIT(17)
#define BIT_SDIO_ON_EN_8821C BIT(16)
#define BIT_PCIE_WAIT_TIMEOUT_EVENT_8821C BIT(10)
#define BIT_PCIE_WAIT_TIME_8821C BIT(9)
#define BIT_MPCIE_REFCLK_XTAL_SEL_8821C BIT(8)
#define BIT_RES_USB_MASS_STORAGE_DESC_8821C BIT(1)
#define BIT_USB_WAIT_TIME_8821C BIT(0)
/* 2 REG_HCI_OPT_CTRL_8821C */
#define BIT_SHIFT_TSFT_SEL_8821C 29
#define BIT_MASK_TSFT_SEL_8821C 0x7
#define BIT_TSFT_SEL_8821C(x) \
(((x) & BIT_MASK_TSFT_SEL_8821C) << BIT_SHIFT_TSFT_SEL_8821C)
#define BITS_TSFT_SEL_8821C \
(BIT_MASK_TSFT_SEL_8821C << BIT_SHIFT_TSFT_SEL_8821C)
#define BIT_CLEAR_TSFT_SEL_8821C(x) ((x) & (~BITS_TSFT_SEL_8821C))
#define BIT_GET_TSFT_SEL_8821C(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_8821C) & BIT_MASK_TSFT_SEL_8821C)
#define BIT_SET_TSFT_SEL_8821C(x, v) \
(BIT_CLEAR_TSFT_SEL_8821C(x) | BIT_TSFT_SEL_8821C(v))
#define BIT_SDIO_PAD_E5_8821C BIT(18)
#define BIT_USB_HOST_PWR_OFF_EN_8821C BIT(12)
#define BIT_SYM_LPS_BLOCK_EN_8821C BIT(11)
#define BIT_USB_LPM_ACT_EN_8821C BIT(10)
#define BIT_USB_LPM_NY_8821C BIT(9)
#define BIT_USB_SUS_DIS_8821C BIT(8)
#define BIT_SHIFT_SDIO_PAD_E_8821C 5
#define BIT_MASK_SDIO_PAD_E_8821C 0x7
#define BIT_SDIO_PAD_E_8821C(x) \
(((x) & BIT_MASK_SDIO_PAD_E_8821C) << BIT_SHIFT_SDIO_PAD_E_8821C)
#define BITS_SDIO_PAD_E_8821C \
(BIT_MASK_SDIO_PAD_E_8821C << BIT_SHIFT_SDIO_PAD_E_8821C)
#define BIT_CLEAR_SDIO_PAD_E_8821C(x) ((x) & (~BITS_SDIO_PAD_E_8821C))
#define BIT_GET_SDIO_PAD_E_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_PAD_E_8821C) & BIT_MASK_SDIO_PAD_E_8821C)
#define BIT_SET_SDIO_PAD_E_8821C(x, v) \
(BIT_CLEAR_SDIO_PAD_E_8821C(x) | BIT_SDIO_PAD_E_8821C(v))
#define BIT_USB_LPPLL_EN_8821C BIT(4)
#define BIT_ROP_SW15_8821C BIT(2)
#define BIT_PCI_CKRDY_OPT_8821C BIT(1)
#define BIT_PCI_VAUX_EN_8821C BIT(0)
/* 2 REG_AFE_CTRL4_8821C */
/* 2 REG_LDO_SWR_CTRL_8821C */
#define BIT_ZCD_HW_AUTO_EN_8821C BIT(27)
#define BIT_ZCD_REGSEL_8821C BIT(26)
#define BIT_SHIFT_AUTO_ZCD_IN_CODE_8821C 21
#define BIT_MASK_AUTO_ZCD_IN_CODE_8821C 0x1f
#define BIT_AUTO_ZCD_IN_CODE_8821C(x) \
(((x) & BIT_MASK_AUTO_ZCD_IN_CODE_8821C) \
<< BIT_SHIFT_AUTO_ZCD_IN_CODE_8821C)
#define BITS_AUTO_ZCD_IN_CODE_8821C \
(BIT_MASK_AUTO_ZCD_IN_CODE_8821C << BIT_SHIFT_AUTO_ZCD_IN_CODE_8821C)
#define BIT_CLEAR_AUTO_ZCD_IN_CODE_8821C(x) \
((x) & (~BITS_AUTO_ZCD_IN_CODE_8821C))
#define BIT_GET_AUTO_ZCD_IN_CODE_8821C(x) \
(((x) >> BIT_SHIFT_AUTO_ZCD_IN_CODE_8821C) & \
BIT_MASK_AUTO_ZCD_IN_CODE_8821C)
#define BIT_SET_AUTO_ZCD_IN_CODE_8821C(x, v) \
(BIT_CLEAR_AUTO_ZCD_IN_CODE_8821C(x) | BIT_AUTO_ZCD_IN_CODE_8821C(v))
#define BIT_SHIFT_ZCD_CODE_IN_L_8821C 16
#define BIT_MASK_ZCD_CODE_IN_L_8821C 0x1f
#define BIT_ZCD_CODE_IN_L_8821C(x) \
(((x) & BIT_MASK_ZCD_CODE_IN_L_8821C) << BIT_SHIFT_ZCD_CODE_IN_L_8821C)
#define BITS_ZCD_CODE_IN_L_8821C \
(BIT_MASK_ZCD_CODE_IN_L_8821C << BIT_SHIFT_ZCD_CODE_IN_L_8821C)
#define BIT_CLEAR_ZCD_CODE_IN_L_8821C(x) ((x) & (~BITS_ZCD_CODE_IN_L_8821C))
#define BIT_GET_ZCD_CODE_IN_L_8821C(x) \
(((x) >> BIT_SHIFT_ZCD_CODE_IN_L_8821C) & BIT_MASK_ZCD_CODE_IN_L_8821C)
#define BIT_SET_ZCD_CODE_IN_L_8821C(x, v) \
(BIT_CLEAR_ZCD_CODE_IN_L_8821C(x) | BIT_ZCD_CODE_IN_L_8821C(v))
#define BIT_SHIFT_LDO_HV5_DUMMY_8821C 14
#define BIT_MASK_LDO_HV5_DUMMY_8821C 0x3
#define BIT_LDO_HV5_DUMMY_8821C(x) \
(((x) & BIT_MASK_LDO_HV5_DUMMY_8821C) << BIT_SHIFT_LDO_HV5_DUMMY_8821C)
#define BITS_LDO_HV5_DUMMY_8821C \
(BIT_MASK_LDO_HV5_DUMMY_8821C << BIT_SHIFT_LDO_HV5_DUMMY_8821C)
#define BIT_CLEAR_LDO_HV5_DUMMY_8821C(x) ((x) & (~BITS_LDO_HV5_DUMMY_8821C))
#define BIT_GET_LDO_HV5_DUMMY_8821C(x) \
(((x) >> BIT_SHIFT_LDO_HV5_DUMMY_8821C) & BIT_MASK_LDO_HV5_DUMMY_8821C)
#define BIT_SET_LDO_HV5_DUMMY_8821C(x, v) \
(BIT_CLEAR_LDO_HV5_DUMMY_8821C(x) | BIT_LDO_HV5_DUMMY_8821C(v))
#define BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8821C 12
#define BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8821C 0x3
#define BIT_REG_VTUNE33_BIT0_TO_BIT1_8821C(x) \
(((x) & BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8821C) \
<< BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8821C)
#define BITS_REG_VTUNE33_BIT0_TO_BIT1_8821C \
(BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8821C \
<< BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8821C)
#define BIT_CLEAR_REG_VTUNE33_BIT0_TO_BIT1_8821C(x) \
((x) & (~BITS_REG_VTUNE33_BIT0_TO_BIT1_8821C))
#define BIT_GET_REG_VTUNE33_BIT0_TO_BIT1_8821C(x) \
(((x) >> BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8821C) & \
BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8821C)
#define BIT_SET_REG_VTUNE33_BIT0_TO_BIT1_8821C(x, v) \
(BIT_CLEAR_REG_VTUNE33_BIT0_TO_BIT1_8821C(x) | \
BIT_REG_VTUNE33_BIT0_TO_BIT1_8821C(v))
#define BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8821C 10
#define BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8821C 0x3
#define BIT_REG_STANDBY33_BIT0_TO_BIT1_8821C(x) \
(((x) & BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8821C) \
<< BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8821C)
#define BITS_REG_STANDBY33_BIT0_TO_BIT1_8821C \
(BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8821C \
<< BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8821C)
#define BIT_CLEAR_REG_STANDBY33_BIT0_TO_BIT1_8821C(x) \
((x) & (~BITS_REG_STANDBY33_BIT0_TO_BIT1_8821C))
#define BIT_GET_REG_STANDBY33_BIT0_TO_BIT1_8821C(x) \
(((x) >> BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8821C) & \
BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8821C)
#define BIT_SET_REG_STANDBY33_BIT0_TO_BIT1_8821C(x, v) \
(BIT_CLEAR_REG_STANDBY33_BIT0_TO_BIT1_8821C(x) | \
BIT_REG_STANDBY33_BIT0_TO_BIT1_8821C(v))
#define BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8821C 8
#define BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8821C 0x3
#define BIT_REG_LOAD33_BIT0_TO_BIT1_8821C(x) \
(((x) & BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8821C) \
<< BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8821C)
#define BITS_REG_LOAD33_BIT0_TO_BIT1_8821C \
(BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8821C \
<< BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8821C)
#define BIT_CLEAR_REG_LOAD33_BIT0_TO_BIT1_8821C(x) \
((x) & (~BITS_REG_LOAD33_BIT0_TO_BIT1_8821C))
#define BIT_GET_REG_LOAD33_BIT0_TO_BIT1_8821C(x) \
(((x) >> BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8821C) & \
BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8821C)
#define BIT_SET_REG_LOAD33_BIT0_TO_BIT1_8821C(x, v) \
(BIT_CLEAR_REG_LOAD33_BIT0_TO_BIT1_8821C(x) | \
BIT_REG_LOAD33_BIT0_TO_BIT1_8821C(v))
#define BIT_REG_BYPASS_L_8821C BIT(7)
#define BIT_REG_LDOF_L_8821C BIT(6)
#define BIT_REG_OCPS_L_8821C BIT(5)
#define BIT_ARENB_L_8821C BIT(3)
#define BIT_SHIFT_CFC_L_8821C 1
#define BIT_MASK_CFC_L_8821C 0x3
#define BIT_CFC_L_8821C(x) \
(((x) & BIT_MASK_CFC_L_8821C) << BIT_SHIFT_CFC_L_8821C)
#define BITS_CFC_L_8821C (BIT_MASK_CFC_L_8821C << BIT_SHIFT_CFC_L_8821C)
#define BIT_CLEAR_CFC_L_8821C(x) ((x) & (~BITS_CFC_L_8821C))
#define BIT_GET_CFC_L_8821C(x) \
(((x) >> BIT_SHIFT_CFC_L_8821C) & BIT_MASK_CFC_L_8821C)
#define BIT_SET_CFC_L_8821C(x, v) \
(BIT_CLEAR_CFC_L_8821C(x) | BIT_CFC_L_8821C(v))
#define BIT_REG_TYPE_L_8821C BIT(0)
/* 2 REG_MCUFW_CTRL_8821C */
#define BIT_SHIFT_RPWM_8821C 24
#define BIT_MASK_RPWM_8821C 0xff
#define BIT_RPWM_8821C(x) (((x) & BIT_MASK_RPWM_8821C) << BIT_SHIFT_RPWM_8821C)
#define BITS_RPWM_8821C (BIT_MASK_RPWM_8821C << BIT_SHIFT_RPWM_8821C)
#define BIT_CLEAR_RPWM_8821C(x) ((x) & (~BITS_RPWM_8821C))
#define BIT_GET_RPWM_8821C(x) \
(((x) >> BIT_SHIFT_RPWM_8821C) & BIT_MASK_RPWM_8821C)
#define BIT_SET_RPWM_8821C(x, v) (BIT_CLEAR_RPWM_8821C(x) | BIT_RPWM_8821C(v))
#define BIT_ANA_PORT_EN_8821C BIT(22)
#define BIT_MAC_PORT_EN_8821C BIT(21)
#define BIT_BOOT_FSPI_EN_8821C BIT(20)
#define BIT_ROM_DLEN_8821C BIT(19)
#define BIT_SHIFT_ROM_PGE_8821C 16
#define BIT_MASK_ROM_PGE_8821C 0x7
#define BIT_ROM_PGE_8821C(x) \
(((x) & BIT_MASK_ROM_PGE_8821C) << BIT_SHIFT_ROM_PGE_8821C)
#define BITS_ROM_PGE_8821C (BIT_MASK_ROM_PGE_8821C << BIT_SHIFT_ROM_PGE_8821C)
#define BIT_CLEAR_ROM_PGE_8821C(x) ((x) & (~BITS_ROM_PGE_8821C))
#define BIT_GET_ROM_PGE_8821C(x) \
(((x) >> BIT_SHIFT_ROM_PGE_8821C) & BIT_MASK_ROM_PGE_8821C)
#define BIT_SET_ROM_PGE_8821C(x, v) \
(BIT_CLEAR_ROM_PGE_8821C(x) | BIT_ROM_PGE_8821C(v))
#define BIT_FW_INIT_RDY_8821C BIT(15)
#define BIT_FW_DW_RDY_8821C BIT(14)
#define BIT_SHIFT_CPU_CLK_SEL_8821C 12
#define BIT_MASK_CPU_CLK_SEL_8821C 0x3
#define BIT_CPU_CLK_SEL_8821C(x) \
(((x) & BIT_MASK_CPU_CLK_SEL_8821C) << BIT_SHIFT_CPU_CLK_SEL_8821C)
#define BITS_CPU_CLK_SEL_8821C \
(BIT_MASK_CPU_CLK_SEL_8821C << BIT_SHIFT_CPU_CLK_SEL_8821C)
#define BIT_CLEAR_CPU_CLK_SEL_8821C(x) ((x) & (~BITS_CPU_CLK_SEL_8821C))
#define BIT_GET_CPU_CLK_SEL_8821C(x) \
(((x) >> BIT_SHIFT_CPU_CLK_SEL_8821C) & BIT_MASK_CPU_CLK_SEL_8821C)
#define BIT_SET_CPU_CLK_SEL_8821C(x, v) \
(BIT_CLEAR_CPU_CLK_SEL_8821C(x) | BIT_CPU_CLK_SEL_8821C(v))
#define BIT_CCLK_CHG_MASK_8821C BIT(11)
#define BIT_EMEM__TXBUF_CHKSUM_OK_8821C BIT(10)
#define BIT_EMEM_TXBUF_DW_RDY_8821C BIT(9)
#define BIT_EMEM_CHKSUM_OK_8821C BIT(8)
#define BIT_EMEM_DW_OK_8821C BIT(7)
#define BIT_DMEM_CHKSUM_OK_8821C BIT(6)
#define BIT_DMEM_DW_OK_8821C BIT(5)
#define BIT_IMEM_CHKSUM_OK_8821C BIT(4)
#define BIT_IMEM_DW_OK_8821C BIT(3)
#define BIT_IMEM_BOOT_LOAD_CHKSUM_OK_8821C BIT(2)
#define BIT_IMEM_BOOT_LOAD_DW_OK_8821C BIT(1)
#define BIT_MCUFWDL_EN_8821C BIT(0)
/* 2 REG_MCU_TST_CFG_8821C */
#define BIT_SHIFT_C2H_MSG_8821C 0
#define BIT_MASK_C2H_MSG_8821C 0xffff
#define BIT_C2H_MSG_8821C(x) \
(((x) & BIT_MASK_C2H_MSG_8821C) << BIT_SHIFT_C2H_MSG_8821C)
#define BITS_C2H_MSG_8821C (BIT_MASK_C2H_MSG_8821C << BIT_SHIFT_C2H_MSG_8821C)
#define BIT_CLEAR_C2H_MSG_8821C(x) ((x) & (~BITS_C2H_MSG_8821C))
#define BIT_GET_C2H_MSG_8821C(x) \
(((x) >> BIT_SHIFT_C2H_MSG_8821C) & BIT_MASK_C2H_MSG_8821C)
#define BIT_SET_C2H_MSG_8821C(x, v) \
(BIT_CLEAR_C2H_MSG_8821C(x) | BIT_C2H_MSG_8821C(v))
/* 2 REG_HMEBOX_E0_E1_8821C */
#define BIT_SHIFT_HOST_MSG_E1_8821C 16
#define BIT_MASK_HOST_MSG_E1_8821C 0xffff
#define BIT_HOST_MSG_E1_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_E1_8821C) << BIT_SHIFT_HOST_MSG_E1_8821C)
#define BITS_HOST_MSG_E1_8821C \
(BIT_MASK_HOST_MSG_E1_8821C << BIT_SHIFT_HOST_MSG_E1_8821C)
#define BIT_CLEAR_HOST_MSG_E1_8821C(x) ((x) & (~BITS_HOST_MSG_E1_8821C))
#define BIT_GET_HOST_MSG_E1_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E1_8821C) & BIT_MASK_HOST_MSG_E1_8821C)
#define BIT_SET_HOST_MSG_E1_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_E1_8821C(x) | BIT_HOST_MSG_E1_8821C(v))
#define BIT_SHIFT_HOST_MSG_E0_8821C 0
#define BIT_MASK_HOST_MSG_E0_8821C 0xffff
#define BIT_HOST_MSG_E0_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_E0_8821C) << BIT_SHIFT_HOST_MSG_E0_8821C)
#define BITS_HOST_MSG_E0_8821C \
(BIT_MASK_HOST_MSG_E0_8821C << BIT_SHIFT_HOST_MSG_E0_8821C)
#define BIT_CLEAR_HOST_MSG_E0_8821C(x) ((x) & (~BITS_HOST_MSG_E0_8821C))
#define BIT_GET_HOST_MSG_E0_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E0_8821C) & BIT_MASK_HOST_MSG_E0_8821C)
#define BIT_SET_HOST_MSG_E0_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_E0_8821C(x) | BIT_HOST_MSG_E0_8821C(v))
/* 2 REG_HMEBOX_E2_E3_8821C */
#define BIT_SHIFT_HOST_MSG_E3_8821C 16
#define BIT_MASK_HOST_MSG_E3_8821C 0xffff
#define BIT_HOST_MSG_E3_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_E3_8821C) << BIT_SHIFT_HOST_MSG_E3_8821C)
#define BITS_HOST_MSG_E3_8821C \
(BIT_MASK_HOST_MSG_E3_8821C << BIT_SHIFT_HOST_MSG_E3_8821C)
#define BIT_CLEAR_HOST_MSG_E3_8821C(x) ((x) & (~BITS_HOST_MSG_E3_8821C))
#define BIT_GET_HOST_MSG_E3_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E3_8821C) & BIT_MASK_HOST_MSG_E3_8821C)
#define BIT_SET_HOST_MSG_E3_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_E3_8821C(x) | BIT_HOST_MSG_E3_8821C(v))
#define BIT_SHIFT_HOST_MSG_E2_8821C 0
#define BIT_MASK_HOST_MSG_E2_8821C 0xffff
#define BIT_HOST_MSG_E2_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_E2_8821C) << BIT_SHIFT_HOST_MSG_E2_8821C)
#define BITS_HOST_MSG_E2_8821C \
(BIT_MASK_HOST_MSG_E2_8821C << BIT_SHIFT_HOST_MSG_E2_8821C)
#define BIT_CLEAR_HOST_MSG_E2_8821C(x) ((x) & (~BITS_HOST_MSG_E2_8821C))
#define BIT_GET_HOST_MSG_E2_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E2_8821C) & BIT_MASK_HOST_MSG_E2_8821C)
#define BIT_SET_HOST_MSG_E2_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_E2_8821C(x) | BIT_HOST_MSG_E2_8821C(v))
/* 2 REG_WLLPS_CTRL_8821C */
#define BIT_WLLPSOP_EABM_8821C BIT(31)
#define BIT_WLLPSOP_ACKF_8821C BIT(30)
#define BIT_WLLPSOP_DLDM_8821C BIT(29)
#define BIT_WLLPSOP_ESWR_8821C BIT(28)
#define BIT_WLLPSOP_PWMM_8821C BIT(27)
#define BIT_WLLPSOP_EECK_8821C BIT(26)
#define BIT_WLLPSOP_WLMACOFF_8821C BIT(25)
#define BIT_WLLPSOP_EXTAL_8821C BIT(24)
#define BIT_WL_SYNPON_VOLTSPDN_8821C BIT(23)
#define BIT_WLLPSOP_WLBBOFF_8821C BIT(22)
#define BIT_WLLPSOP_WLMEM_DS_8821C BIT(21)
#define BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8821C 12
#define BIT_MASK_LPLDH12_VADJ_STEP_DN_8821C 0xf
#define BIT_LPLDH12_VADJ_STEP_DN_8821C(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_STEP_DN_8821C) \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8821C)
#define BITS_LPLDH12_VADJ_STEP_DN_8821C \
(BIT_MASK_LPLDH12_VADJ_STEP_DN_8821C \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8821C)
#define BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8821C(x) \
((x) & (~BITS_LPLDH12_VADJ_STEP_DN_8821C))
#define BIT_GET_LPLDH12_VADJ_STEP_DN_8821C(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8821C) & \
BIT_MASK_LPLDH12_VADJ_STEP_DN_8821C)
#define BIT_SET_LPLDH12_VADJ_STEP_DN_8821C(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8821C(x) | \
BIT_LPLDH12_VADJ_STEP_DN_8821C(v))
#define BIT_SHIFT_V15ADJ_L1_STEP_DN_8821C 8
#define BIT_MASK_V15ADJ_L1_STEP_DN_8821C 0x7
#define BIT_V15ADJ_L1_STEP_DN_8821C(x) \
(((x) & BIT_MASK_V15ADJ_L1_STEP_DN_8821C) \
<< BIT_SHIFT_V15ADJ_L1_STEP_DN_8821C)
#define BITS_V15ADJ_L1_STEP_DN_8821C \
(BIT_MASK_V15ADJ_L1_STEP_DN_8821C << BIT_SHIFT_V15ADJ_L1_STEP_DN_8821C)
#define BIT_CLEAR_V15ADJ_L1_STEP_DN_8821C(x) \
((x) & (~BITS_V15ADJ_L1_STEP_DN_8821C))
#define BIT_GET_V15ADJ_L1_STEP_DN_8821C(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_STEP_DN_8821C) & \
BIT_MASK_V15ADJ_L1_STEP_DN_8821C)
#define BIT_SET_V15ADJ_L1_STEP_DN_8821C(x, v) \
(BIT_CLEAR_V15ADJ_L1_STEP_DN_8821C(x) | BIT_V15ADJ_L1_STEP_DN_8821C(v))
#define BIT_REGU_32K_CLK_EN_8821C BIT(1)
#define BIT_WL_LPS_EN_8821C BIT(0)
/* 2 REG_AFE_CTRL5_8821C */
#define BIT_BB_DBG_SEL_AFE_SDM_BIT0_8821C BIT(31)
#define BIT_ORDER_SDM_8821C BIT(30)
#define BIT_RFE_SEL_SDM_8821C BIT(29)
#define BIT_SHIFT_REF_SEL_8821C 25
#define BIT_MASK_REF_SEL_8821C 0xf
#define BIT_REF_SEL_8821C(x) \
(((x) & BIT_MASK_REF_SEL_8821C) << BIT_SHIFT_REF_SEL_8821C)
#define BITS_REF_SEL_8821C (BIT_MASK_REF_SEL_8821C << BIT_SHIFT_REF_SEL_8821C)
#define BIT_CLEAR_REF_SEL_8821C(x) ((x) & (~BITS_REF_SEL_8821C))
#define BIT_GET_REF_SEL_8821C(x) \
(((x) >> BIT_SHIFT_REF_SEL_8821C) & BIT_MASK_REF_SEL_8821C)
#define BIT_SET_REF_SEL_8821C(x, v) \
(BIT_CLEAR_REF_SEL_8821C(x) | BIT_REF_SEL_8821C(v))
#define BIT_SHIFT_F0F_SDM_8821C 12
#define BIT_MASK_F0F_SDM_8821C 0x1fff
#define BIT_F0F_SDM_8821C(x) \
(((x) & BIT_MASK_F0F_SDM_8821C) << BIT_SHIFT_F0F_SDM_8821C)
#define BITS_F0F_SDM_8821C (BIT_MASK_F0F_SDM_8821C << BIT_SHIFT_F0F_SDM_8821C)
#define BIT_CLEAR_F0F_SDM_8821C(x) ((x) & (~BITS_F0F_SDM_8821C))
#define BIT_GET_F0F_SDM_8821C(x) \
(((x) >> BIT_SHIFT_F0F_SDM_8821C) & BIT_MASK_F0F_SDM_8821C)
#define BIT_SET_F0F_SDM_8821C(x, v) \
(BIT_CLEAR_F0F_SDM_8821C(x) | BIT_F0F_SDM_8821C(v))
#define BIT_SHIFT_F0N_SDM_8821C 9
#define BIT_MASK_F0N_SDM_8821C 0x7
#define BIT_F0N_SDM_8821C(x) \
(((x) & BIT_MASK_F0N_SDM_8821C) << BIT_SHIFT_F0N_SDM_8821C)
#define BITS_F0N_SDM_8821C (BIT_MASK_F0N_SDM_8821C << BIT_SHIFT_F0N_SDM_8821C)
#define BIT_CLEAR_F0N_SDM_8821C(x) ((x) & (~BITS_F0N_SDM_8821C))
#define BIT_GET_F0N_SDM_8821C(x) \
(((x) >> BIT_SHIFT_F0N_SDM_8821C) & BIT_MASK_F0N_SDM_8821C)
#define BIT_SET_F0N_SDM_8821C(x, v) \
(BIT_CLEAR_F0N_SDM_8821C(x) | BIT_F0N_SDM_8821C(v))
#define BIT_SHIFT_DIVN_SDM_8821C 3
#define BIT_MASK_DIVN_SDM_8821C 0x3f
#define BIT_DIVN_SDM_8821C(x) \
(((x) & BIT_MASK_DIVN_SDM_8821C) << BIT_SHIFT_DIVN_SDM_8821C)
#define BITS_DIVN_SDM_8821C \
(BIT_MASK_DIVN_SDM_8821C << BIT_SHIFT_DIVN_SDM_8821C)
#define BIT_CLEAR_DIVN_SDM_8821C(x) ((x) & (~BITS_DIVN_SDM_8821C))
#define BIT_GET_DIVN_SDM_8821C(x) \
(((x) >> BIT_SHIFT_DIVN_SDM_8821C) & BIT_MASK_DIVN_SDM_8821C)
#define BIT_SET_DIVN_SDM_8821C(x, v) \
(BIT_CLEAR_DIVN_SDM_8821C(x) | BIT_DIVN_SDM_8821C(v))
/* 2 REG_GPIO_DEBOUNCE_CTRL_8821C */
#define BIT_WLGP_DBC1EN_8821C BIT(15)
#define BIT_SHIFT_WLGP_DBC1_8821C 8
#define BIT_MASK_WLGP_DBC1_8821C 0xf
#define BIT_WLGP_DBC1_8821C(x) \
(((x) & BIT_MASK_WLGP_DBC1_8821C) << BIT_SHIFT_WLGP_DBC1_8821C)
#define BITS_WLGP_DBC1_8821C \
(BIT_MASK_WLGP_DBC1_8821C << BIT_SHIFT_WLGP_DBC1_8821C)
#define BIT_CLEAR_WLGP_DBC1_8821C(x) ((x) & (~BITS_WLGP_DBC1_8821C))
#define BIT_GET_WLGP_DBC1_8821C(x) \
(((x) >> BIT_SHIFT_WLGP_DBC1_8821C) & BIT_MASK_WLGP_DBC1_8821C)
#define BIT_SET_WLGP_DBC1_8821C(x, v) \
(BIT_CLEAR_WLGP_DBC1_8821C(x) | BIT_WLGP_DBC1_8821C(v))
#define BIT_WLGP_DBC0EN_8821C BIT(7)
#define BIT_SHIFT_WLGP_DBC0_8821C 0
#define BIT_MASK_WLGP_DBC0_8821C 0xf
#define BIT_WLGP_DBC0_8821C(x) \
(((x) & BIT_MASK_WLGP_DBC0_8821C) << BIT_SHIFT_WLGP_DBC0_8821C)
#define BITS_WLGP_DBC0_8821C \
(BIT_MASK_WLGP_DBC0_8821C << BIT_SHIFT_WLGP_DBC0_8821C)
#define BIT_CLEAR_WLGP_DBC0_8821C(x) ((x) & (~BITS_WLGP_DBC0_8821C))
#define BIT_GET_WLGP_DBC0_8821C(x) \
(((x) >> BIT_SHIFT_WLGP_DBC0_8821C) & BIT_MASK_WLGP_DBC0_8821C)
#define BIT_SET_WLGP_DBC0_8821C(x, v) \
(BIT_CLEAR_WLGP_DBC0_8821C(x) | BIT_WLGP_DBC0_8821C(v))
/* 2 REG_RPWM2_8821C */
#define BIT_SHIFT_RPWM2_8821C 16
#define BIT_MASK_RPWM2_8821C 0xffff
#define BIT_RPWM2_8821C(x) \
(((x) & BIT_MASK_RPWM2_8821C) << BIT_SHIFT_RPWM2_8821C)
#define BITS_RPWM2_8821C (BIT_MASK_RPWM2_8821C << BIT_SHIFT_RPWM2_8821C)
#define BIT_CLEAR_RPWM2_8821C(x) ((x) & (~BITS_RPWM2_8821C))
#define BIT_GET_RPWM2_8821C(x) \
(((x) >> BIT_SHIFT_RPWM2_8821C) & BIT_MASK_RPWM2_8821C)
#define BIT_SET_RPWM2_8821C(x, v) \
(BIT_CLEAR_RPWM2_8821C(x) | BIT_RPWM2_8821C(v))
/* 2 REG_SYSON_FSM_MON_8821C */
#define BIT_SHIFT_FSM_MON_SEL_8821C 24
#define BIT_MASK_FSM_MON_SEL_8821C 0x7
#define BIT_FSM_MON_SEL_8821C(x) \
(((x) & BIT_MASK_FSM_MON_SEL_8821C) << BIT_SHIFT_FSM_MON_SEL_8821C)
#define BITS_FSM_MON_SEL_8821C \
(BIT_MASK_FSM_MON_SEL_8821C << BIT_SHIFT_FSM_MON_SEL_8821C)
#define BIT_CLEAR_FSM_MON_SEL_8821C(x) ((x) & (~BITS_FSM_MON_SEL_8821C))
#define BIT_GET_FSM_MON_SEL_8821C(x) \
(((x) >> BIT_SHIFT_FSM_MON_SEL_8821C) & BIT_MASK_FSM_MON_SEL_8821C)
#define BIT_SET_FSM_MON_SEL_8821C(x, v) \
(BIT_CLEAR_FSM_MON_SEL_8821C(x) | BIT_FSM_MON_SEL_8821C(v))
#define BIT_DOP_ELDO_8821C BIT(23)
#define BIT_FSM_MON_UPD_8821C BIT(15)
#define BIT_SHIFT_FSM_PAR_8821C 0
#define BIT_MASK_FSM_PAR_8821C 0x7fff
#define BIT_FSM_PAR_8821C(x) \
(((x) & BIT_MASK_FSM_PAR_8821C) << BIT_SHIFT_FSM_PAR_8821C)
#define BITS_FSM_PAR_8821C (BIT_MASK_FSM_PAR_8821C << BIT_SHIFT_FSM_PAR_8821C)
#define BIT_CLEAR_FSM_PAR_8821C(x) ((x) & (~BITS_FSM_PAR_8821C))
#define BIT_GET_FSM_PAR_8821C(x) \
(((x) >> BIT_SHIFT_FSM_PAR_8821C) & BIT_MASK_FSM_PAR_8821C)
#define BIT_SET_FSM_PAR_8821C(x, v) \
(BIT_CLEAR_FSM_PAR_8821C(x) | BIT_FSM_PAR_8821C(v))
/* 2 REG_AFE_CTRL6_8821C */
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C 0
#define BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C 0x7
#define BIT_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C) \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C)
#define BITS_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C \
(BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C(x) \
((x) & (~BITS_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C))
#define BIT_GET_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C) & \
BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C)
#define BIT_SET_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C(x) | \
BIT_BB_DBG_SEL_AFE_SDM_BIT3_1_8821C(v))
/* 2 REG_PMC_DBG_CTRL1_8821C */
#define BIT_BT_INT_EN_8821C BIT(31)
#define BIT_SHIFT_RD_WR_WIFI_BT_INFO_8821C 16
#define BIT_MASK_RD_WR_WIFI_BT_INFO_8821C 0x7fff
#define BIT_RD_WR_WIFI_BT_INFO_8821C(x) \
(((x) & BIT_MASK_RD_WR_WIFI_BT_INFO_8821C) \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8821C)
#define BITS_RD_WR_WIFI_BT_INFO_8821C \
(BIT_MASK_RD_WR_WIFI_BT_INFO_8821C \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8821C)
#define BIT_CLEAR_RD_WR_WIFI_BT_INFO_8821C(x) \
((x) & (~BITS_RD_WR_WIFI_BT_INFO_8821C))
#define BIT_GET_RD_WR_WIFI_BT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_RD_WR_WIFI_BT_INFO_8821C) & \
BIT_MASK_RD_WR_WIFI_BT_INFO_8821C)
#define BIT_SET_RD_WR_WIFI_BT_INFO_8821C(x, v) \
(BIT_CLEAR_RD_WR_WIFI_BT_INFO_8821C(x) | \
BIT_RD_WR_WIFI_BT_INFO_8821C(v))
#define BIT_PMC_WR_OVF_8821C BIT(8)
#define BIT_SHIFT_WLPMC_ERRINT_8821C 0
#define BIT_MASK_WLPMC_ERRINT_8821C 0xff
#define BIT_WLPMC_ERRINT_8821C(x) \
(((x) & BIT_MASK_WLPMC_ERRINT_8821C) << BIT_SHIFT_WLPMC_ERRINT_8821C)
#define BITS_WLPMC_ERRINT_8821C \
(BIT_MASK_WLPMC_ERRINT_8821C << BIT_SHIFT_WLPMC_ERRINT_8821C)
#define BIT_CLEAR_WLPMC_ERRINT_8821C(x) ((x) & (~BITS_WLPMC_ERRINT_8821C))
#define BIT_GET_WLPMC_ERRINT_8821C(x) \
(((x) >> BIT_SHIFT_WLPMC_ERRINT_8821C) & BIT_MASK_WLPMC_ERRINT_8821C)
#define BIT_SET_WLPMC_ERRINT_8821C(x, v) \
(BIT_CLEAR_WLPMC_ERRINT_8821C(x) | BIT_WLPMC_ERRINT_8821C(v))
/* 2 REG_AFE_CTRL7_8821C */
#define BIT_SHIFT_SEL_V_8821C 30
#define BIT_MASK_SEL_V_8821C 0x3
#define BIT_SEL_V_8821C(x) \
(((x) & BIT_MASK_SEL_V_8821C) << BIT_SHIFT_SEL_V_8821C)
#define BITS_SEL_V_8821C (BIT_MASK_SEL_V_8821C << BIT_SHIFT_SEL_V_8821C)
#define BIT_CLEAR_SEL_V_8821C(x) ((x) & (~BITS_SEL_V_8821C))
#define BIT_GET_SEL_V_8821C(x) \
(((x) >> BIT_SHIFT_SEL_V_8821C) & BIT_MASK_SEL_V_8821C)
#define BIT_SET_SEL_V_8821C(x, v) \
(BIT_CLEAR_SEL_V_8821C(x) | BIT_SEL_V_8821C(v))
#define BIT_SEL_LDO_PC_8821C BIT(29)
#define BIT_SHIFT_CK_MON_SEL_8821C 26
#define BIT_MASK_CK_MON_SEL_8821C 0x7
#define BIT_CK_MON_SEL_8821C(x) \
(((x) & BIT_MASK_CK_MON_SEL_8821C) << BIT_SHIFT_CK_MON_SEL_8821C)
#define BITS_CK_MON_SEL_8821C \
(BIT_MASK_CK_MON_SEL_8821C << BIT_SHIFT_CK_MON_SEL_8821C)
#define BIT_CLEAR_CK_MON_SEL_8821C(x) ((x) & (~BITS_CK_MON_SEL_8821C))
#define BIT_GET_CK_MON_SEL_8821C(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL_8821C) & BIT_MASK_CK_MON_SEL_8821C)
#define BIT_SET_CK_MON_SEL_8821C(x, v) \
(BIT_CLEAR_CK_MON_SEL_8821C(x) | BIT_CK_MON_SEL_8821C(v))
#define BIT_CK_MON_EN_8821C BIT(25)
#define BIT_FREF_EDGE_8821C BIT(24)
#define BIT_CK320M_EN_8821C BIT(23)
#define BIT_CK_5M_EN_8821C BIT(22)
#define BIT_TESTEN_8821C BIT(21)
/* 2 REG_HIMR0_8821C */
#define BIT_TIMEOUT_INTERRUPT2_MASK_8821C BIT(31)
#define BIT_TIMEOUT_INTERRUTP1_MASK_8821C BIT(30)
#define BIT_PSTIMEOUT_MSK_8821C BIT(29)
#define BIT_GTINT4_MSK_8821C BIT(28)
#define BIT_GTINT3_MSK_8821C BIT(27)
#define BIT_TXBCN0ERR_MSK_8821C BIT(26)
#define BIT_TXBCN0OK_MSK_8821C BIT(25)
#define BIT_TSF_BIT32_TOGGLE_MSK_8821C BIT(24)
#define BIT_BCNDMAINT0_MSK_8821C BIT(20)
#define BIT_BCNDERR0_MSK_8821C BIT(16)
#define BIT_HSISR_IND_ON_INT_MSK_8821C BIT(15)
#define BIT_BCNDMAINT_E_MSK_8821C BIT(14)
#define BIT_CTWEND_MSK_8821C BIT(12)
#define BIT_HISR1_IND_MSK_8821C BIT(11)
#define BIT_C2HCMD_MSK_8821C BIT(10)
#define BIT_CPWM2_MSK_8821C BIT(9)
#define BIT_CPWM_MSK_8821C BIT(8)
#define BIT_HIGHDOK_MSK_8821C BIT(7)
#define BIT_MGTDOK_MSK_8821C BIT(6)
#define BIT_BKDOK_MSK_8821C BIT(5)
#define BIT_BEDOK_MSK_8821C BIT(4)
#define BIT_VIDOK_MSK_8821C BIT(3)
#define BIT_VODOK_MSK_8821C BIT(2)
#define BIT_RDU_MSK_8821C BIT(1)
#define BIT_RXOK_MSK_8821C BIT(0)
/* 2 REG_HISR0_8821C */
#define BIT_PSTIMEOUT2_8821C BIT(31)
#define BIT_PSTIMEOUT1_8821C BIT(30)
#define BIT_PSTIMEOUT_8821C BIT(29)
#define BIT_GTINT4_8821C BIT(28)
#define BIT_GTINT3_8821C BIT(27)
#define BIT_TXBCN0ERR_8821C BIT(26)
#define BIT_TXBCN0OK_8821C BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8821C BIT(24)
#define BIT_BCNDMAINT0_8821C BIT(20)
#define BIT_BCNDERR0_8821C BIT(16)
#define BIT_HSISR_IND_ON_INT_8821C BIT(15)
#define BIT_BCNDMAINT_E_8821C BIT(14)
#define BIT_CTWEND_8821C BIT(12)
#define BIT_HISR1_IND_INT_8821C BIT(11)
#define BIT_C2HCMD_8821C BIT(10)
#define BIT_CPWM2_8821C BIT(9)
#define BIT_CPWM_8821C BIT(8)
#define BIT_HIGHDOK_8821C BIT(7)
#define BIT_MGTDOK_8821C BIT(6)
#define BIT_BKDOK_8821C BIT(5)
#define BIT_BEDOK_8821C BIT(4)
#define BIT_VIDOK_8821C BIT(3)
#define BIT_VODOK_8821C BIT(2)
#define BIT_RDU_8821C BIT(1)
#define BIT_RXOK_8821C BIT(0)
/* 2 REG_HIMR1_8821C */
#define BIT_TXFIFO_TH_INT_8821C BIT(30)
#define BIT_BTON_STS_UPDATE_MASK_8821C BIT(29)
#define BIT_MCU_ERR_MASK_8821C BIT(28)
#define BIT_BCNDMAINT7__MSK_8821C BIT(27)
#define BIT_BCNDMAINT6__MSK_8821C BIT(26)
#define BIT_BCNDMAINT5__MSK_8821C BIT(25)
#define BIT_BCNDMAINT4__MSK_8821C BIT(24)
#define BIT_BCNDMAINT3_MSK_8821C BIT(23)
#define BIT_BCNDMAINT2_MSK_8821C BIT(22)
#define BIT_BCNDMAINT1_MSK_8821C BIT(21)
#define BIT_BCNDERR7_MSK_8821C BIT(20)
#define BIT_BCNDERR6_MSK_8821C BIT(19)
#define BIT_BCNDERR5_MSK_8821C BIT(18)
#define BIT_BCNDERR4_MSK_8821C BIT(17)
#define BIT_BCNDERR3_MSK_8821C BIT(16)
#define BIT_BCNDERR2_MSK_8821C BIT(15)
#define BIT_BCNDERR1_MSK_8821C BIT(14)
#define BIT_ATIMEND_E_MSK_8821C BIT(13)
#define BIT_ATIMEND__MSK_8821C BIT(12)
#define BIT_TXERR_MSK_8821C BIT(11)
#define BIT_RXERR_MSK_8821C BIT(10)
#define BIT_TXFOVW_MSK_8821C BIT(9)
#define BIT_FOVW_MSK_8821C BIT(8)
#define BIT_CPU_MGQ_TXDONE_MSK_8821C BIT(5)
#define BIT_PS_TIMER_C_MSK_8821C BIT(4)
#define BIT_PS_TIMER_B_MSK_8821C BIT(3)
#define BIT_PS_TIMER_A_MSK_8821C BIT(2)
#define BIT_CPUMGQ_TX_TIMER_MSK_8821C BIT(1)
/* 2 REG_HISR1_8821C */
#define BIT_TXFIFO_TH_INT_8821C BIT(30)
#define BIT_BTON_STS_UPDATE_INT_8821C BIT(29)
#define BIT_MCU_ERR_8821C BIT(28)
#define BIT_BCNDMAINT7_8821C BIT(27)
#define BIT_BCNDMAINT6_8821C BIT(26)
#define BIT_BCNDMAINT5_8821C BIT(25)
#define BIT_BCNDMAINT4_8821C BIT(24)
#define BIT_BCNDMAINT3_8821C BIT(23)
#define BIT_BCNDMAINT2_8821C BIT(22)
#define BIT_BCNDMAINT1_8821C BIT(21)
#define BIT_BCNDERR7_8821C BIT(20)
#define BIT_BCNDERR6_8821C BIT(19)
#define BIT_BCNDERR5_8821C BIT(18)
#define BIT_BCNDERR4_8821C BIT(17)
#define BIT_BCNDERR3_8821C BIT(16)
#define BIT_BCNDERR2_8821C BIT(15)
#define BIT_BCNDERR1_8821C BIT(14)
#define BIT_ATIMEND_E_8821C BIT(13)
#define BIT_ATIMEND_8821C BIT(12)
#define BIT_TXERR_INT_8821C BIT(11)
#define BIT_RXERR_INT_8821C BIT(10)
#define BIT_TXFOVW_8821C BIT(9)
#define BIT_FOVW_8821C BIT(8)
/* 2 REG_NOT_VALID_8821C */
#define BIT_CPU_MGQ_TXDONE_8821C BIT(5)
#define BIT_PS_TIMER_C_8821C BIT(4)
#define BIT_PS_TIMER_B_8821C BIT(3)
#define BIT_PS_TIMER_A_8821C BIT(2)
#define BIT_CPUMGQ_TX_TIMER_8821C BIT(1)
/* 2 REG_DBG_PORT_SEL_8821C */
#define BIT_SHIFT_DEBUG_ST_8821C 0
#define BIT_MASK_DEBUG_ST_8821C 0xffffffffL
#define BIT_DEBUG_ST_8821C(x) \
(((x) & BIT_MASK_DEBUG_ST_8821C) << BIT_SHIFT_DEBUG_ST_8821C)
#define BITS_DEBUG_ST_8821C \
(BIT_MASK_DEBUG_ST_8821C << BIT_SHIFT_DEBUG_ST_8821C)
#define BIT_CLEAR_DEBUG_ST_8821C(x) ((x) & (~BITS_DEBUG_ST_8821C))
#define BIT_GET_DEBUG_ST_8821C(x) \
(((x) >> BIT_SHIFT_DEBUG_ST_8821C) & BIT_MASK_DEBUG_ST_8821C)
#define BIT_SET_DEBUG_ST_8821C(x, v) \
(BIT_CLEAR_DEBUG_ST_8821C(x) | BIT_DEBUG_ST_8821C(v))
/* 2 REG_PAD_CTRL2_8821C */
#define BIT_USB3_USB2_TRANSITION_8821C BIT(20)
#define BIT_SHIFT_USB23_SW_MODE_V1_8821C 18
#define BIT_MASK_USB23_SW_MODE_V1_8821C 0x3
#define BIT_USB23_SW_MODE_V1_8821C(x) \
(((x) & BIT_MASK_USB23_SW_MODE_V1_8821C) \
<< BIT_SHIFT_USB23_SW_MODE_V1_8821C)
#define BITS_USB23_SW_MODE_V1_8821C \
(BIT_MASK_USB23_SW_MODE_V1_8821C << BIT_SHIFT_USB23_SW_MODE_V1_8821C)
#define BIT_CLEAR_USB23_SW_MODE_V1_8821C(x) \
((x) & (~BITS_USB23_SW_MODE_V1_8821C))
#define BIT_GET_USB23_SW_MODE_V1_8821C(x) \
(((x) >> BIT_SHIFT_USB23_SW_MODE_V1_8821C) & \
BIT_MASK_USB23_SW_MODE_V1_8821C)
#define BIT_SET_USB23_SW_MODE_V1_8821C(x, v) \
(BIT_CLEAR_USB23_SW_MODE_V1_8821C(x) | BIT_USB23_SW_MODE_V1_8821C(v))
#define BIT_NO_PDN_CHIPOFF_V1_8821C BIT(17)
#define BIT_RSM_EN_V1_8821C BIT(16)
#define BIT_SHIFT_MATCH_CNT_8821C 8
#define BIT_MASK_MATCH_CNT_8821C 0xff
#define BIT_MATCH_CNT_8821C(x) \
(((x) & BIT_MASK_MATCH_CNT_8821C) << BIT_SHIFT_MATCH_CNT_8821C)
#define BITS_MATCH_CNT_8821C \
(BIT_MASK_MATCH_CNT_8821C << BIT_SHIFT_MATCH_CNT_8821C)
#define BIT_CLEAR_MATCH_CNT_8821C(x) ((x) & (~BITS_MATCH_CNT_8821C))
#define BIT_GET_MATCH_CNT_8821C(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8821C) & BIT_MASK_MATCH_CNT_8821C)
#define BIT_SET_MATCH_CNT_8821C(x, v) \
(BIT_CLEAR_MATCH_CNT_8821C(x) | BIT_MATCH_CNT_8821C(v))
#define BIT_LD_B12V_EN_8821C BIT(7)
#define BIT_EECS_IOSEL_V1_8821C BIT(6)
#define BIT_EECS_DATA_O_V1_8821C BIT(5)
#define BIT_EECS_DATA_I_V1_8821C BIT(4)
#define BIT_EESK_IOSEL_V1_8821C BIT(2)
#define BIT_EESK_DATA_O_V1_8821C BIT(1)
#define BIT_EESK_DATA_I_V1_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_PMC_DBG_CTRL2_8821C */
#define BIT_SHIFT_EFUSE_BURN_GNT_8821C 24
#define BIT_MASK_EFUSE_BURN_GNT_8821C 0xff
#define BIT_EFUSE_BURN_GNT_8821C(x) \
(((x) & BIT_MASK_EFUSE_BURN_GNT_8821C) \
<< BIT_SHIFT_EFUSE_BURN_GNT_8821C)
#define BITS_EFUSE_BURN_GNT_8821C \
(BIT_MASK_EFUSE_BURN_GNT_8821C << BIT_SHIFT_EFUSE_BURN_GNT_8821C)
#define BIT_CLEAR_EFUSE_BURN_GNT_8821C(x) ((x) & (~BITS_EFUSE_BURN_GNT_8821C))
#define BIT_GET_EFUSE_BURN_GNT_8821C(x) \
(((x) >> BIT_SHIFT_EFUSE_BURN_GNT_8821C) & \
BIT_MASK_EFUSE_BURN_GNT_8821C)
#define BIT_SET_EFUSE_BURN_GNT_8821C(x, v) \
(BIT_CLEAR_EFUSE_BURN_GNT_8821C(x) | BIT_EFUSE_BURN_GNT_8821C(v))
#define BIT_STOP_WL_PMC_8821C BIT(9)
#define BIT_STOP_SYM_PMC_8821C BIT(8)
#define BIT_BT_ACCESS_WL_PAGE0_8821C BIT(6)
#define BIT_REG_RST_WLPMC_8821C BIT(5)
#define BIT_REG_RST_PD12N_8821C BIT(4)
#define BIT_SYSON_DIS_WLREG_WRMSK_8821C BIT(3)
#define BIT_SYSON_DIS_PMCREG_WRMSK_8821C BIT(2)
#define BIT_SHIFT_SYSON_REG_ARB_8821C 0
#define BIT_MASK_SYSON_REG_ARB_8821C 0x3
#define BIT_SYSON_REG_ARB_8821C(x) \
(((x) & BIT_MASK_SYSON_REG_ARB_8821C) << BIT_SHIFT_SYSON_REG_ARB_8821C)
#define BITS_SYSON_REG_ARB_8821C \
(BIT_MASK_SYSON_REG_ARB_8821C << BIT_SHIFT_SYSON_REG_ARB_8821C)
#define BIT_CLEAR_SYSON_REG_ARB_8821C(x) ((x) & (~BITS_SYSON_REG_ARB_8821C))
#define BIT_GET_SYSON_REG_ARB_8821C(x) \
(((x) >> BIT_SHIFT_SYSON_REG_ARB_8821C) & BIT_MASK_SYSON_REG_ARB_8821C)
#define BIT_SET_SYSON_REG_ARB_8821C(x, v) \
(BIT_CLEAR_SYSON_REG_ARB_8821C(x) | BIT_SYSON_REG_ARB_8821C(v))
/* 2 REG_BIST_CTRL_8821C */
#define BIT_BIST_USB_DIS_8821C BIT(27)
#define BIT_BIST_PCI_DIS_8821C BIT(26)
#define BIT_BIST_BT_DIS_8821C BIT(25)
#define BIT_BIST_WL_DIS_8821C BIT(24)
#define BIT_SHIFT_BIST_RPT_SEL_8821C 16
#define BIT_MASK_BIST_RPT_SEL_8821C 0xf
#define BIT_BIST_RPT_SEL_8821C(x) \
(((x) & BIT_MASK_BIST_RPT_SEL_8821C) << BIT_SHIFT_BIST_RPT_SEL_8821C)
#define BITS_BIST_RPT_SEL_8821C \
(BIT_MASK_BIST_RPT_SEL_8821C << BIT_SHIFT_BIST_RPT_SEL_8821C)
#define BIT_CLEAR_BIST_RPT_SEL_8821C(x) ((x) & (~BITS_BIST_RPT_SEL_8821C))
#define BIT_GET_BIST_RPT_SEL_8821C(x) \
(((x) >> BIT_SHIFT_BIST_RPT_SEL_8821C) & BIT_MASK_BIST_RPT_SEL_8821C)
#define BIT_SET_BIST_RPT_SEL_8821C(x, v) \
(BIT_CLEAR_BIST_RPT_SEL_8821C(x) | BIT_BIST_RPT_SEL_8821C(v))
#define BIT_BIST_RESUME_PS_8821C BIT(4)
#define BIT_BIST_RESUME_8821C BIT(3)
#define BIT_BIST_NORMAL_8821C BIT(2)
#define BIT_BIST_RSTN_8821C BIT(1)
#define BIT_BIST_CLK_EN_8821C BIT(0)
/* 2 REG_BIST_RPT_8821C */
#define BIT_SHIFT_MBIST_REPORT_8821C 0
#define BIT_MASK_MBIST_REPORT_8821C 0xffffffffL
#define BIT_MBIST_REPORT_8821C(x) \
(((x) & BIT_MASK_MBIST_REPORT_8821C) << BIT_SHIFT_MBIST_REPORT_8821C)
#define BITS_MBIST_REPORT_8821C \
(BIT_MASK_MBIST_REPORT_8821C << BIT_SHIFT_MBIST_REPORT_8821C)
#define BIT_CLEAR_MBIST_REPORT_8821C(x) ((x) & (~BITS_MBIST_REPORT_8821C))
#define BIT_GET_MBIST_REPORT_8821C(x) \
(((x) >> BIT_SHIFT_MBIST_REPORT_8821C) & BIT_MASK_MBIST_REPORT_8821C)
#define BIT_SET_MBIST_REPORT_8821C(x, v) \
(BIT_CLEAR_MBIST_REPORT_8821C(x) | BIT_MBIST_REPORT_8821C(v))
/* 2 REG_MEM_CTRL_8821C */
#define BIT_UMEM_RME_8821C BIT(31)
#define BIT_SHIFT_BT_SPRAM_8821C 28
#define BIT_MASK_BT_SPRAM_8821C 0x3
#define BIT_BT_SPRAM_8821C(x) \
(((x) & BIT_MASK_BT_SPRAM_8821C) << BIT_SHIFT_BT_SPRAM_8821C)
#define BITS_BT_SPRAM_8821C \
(BIT_MASK_BT_SPRAM_8821C << BIT_SHIFT_BT_SPRAM_8821C)
#define BIT_CLEAR_BT_SPRAM_8821C(x) ((x) & (~BITS_BT_SPRAM_8821C))
#define BIT_GET_BT_SPRAM_8821C(x) \
(((x) >> BIT_SHIFT_BT_SPRAM_8821C) & BIT_MASK_BT_SPRAM_8821C)
#define BIT_SET_BT_SPRAM_8821C(x, v) \
(BIT_CLEAR_BT_SPRAM_8821C(x) | BIT_BT_SPRAM_8821C(v))
#define BIT_SHIFT_BT_ROM_8821C 24
#define BIT_MASK_BT_ROM_8821C 0xf
#define BIT_BT_ROM_8821C(x) \
(((x) & BIT_MASK_BT_ROM_8821C) << BIT_SHIFT_BT_ROM_8821C)
#define BITS_BT_ROM_8821C (BIT_MASK_BT_ROM_8821C << BIT_SHIFT_BT_ROM_8821C)
#define BIT_CLEAR_BT_ROM_8821C(x) ((x) & (~BITS_BT_ROM_8821C))
#define BIT_GET_BT_ROM_8821C(x) \
(((x) >> BIT_SHIFT_BT_ROM_8821C) & BIT_MASK_BT_ROM_8821C)
#define BIT_SET_BT_ROM_8821C(x, v) \
(BIT_CLEAR_BT_ROM_8821C(x) | BIT_BT_ROM_8821C(v))
#define BIT_SHIFT_PCI_DPRAM_8821C 10
#define BIT_MASK_PCI_DPRAM_8821C 0x3
#define BIT_PCI_DPRAM_8821C(x) \
(((x) & BIT_MASK_PCI_DPRAM_8821C) << BIT_SHIFT_PCI_DPRAM_8821C)
#define BITS_PCI_DPRAM_8821C \
(BIT_MASK_PCI_DPRAM_8821C << BIT_SHIFT_PCI_DPRAM_8821C)
#define BIT_CLEAR_PCI_DPRAM_8821C(x) ((x) & (~BITS_PCI_DPRAM_8821C))
#define BIT_GET_PCI_DPRAM_8821C(x) \
(((x) >> BIT_SHIFT_PCI_DPRAM_8821C) & BIT_MASK_PCI_DPRAM_8821C)
#define BIT_SET_PCI_DPRAM_8821C(x, v) \
(BIT_CLEAR_PCI_DPRAM_8821C(x) | BIT_PCI_DPRAM_8821C(v))
#define BIT_SHIFT_PCI_SPRAM_8821C 8
#define BIT_MASK_PCI_SPRAM_8821C 0x3
#define BIT_PCI_SPRAM_8821C(x) \
(((x) & BIT_MASK_PCI_SPRAM_8821C) << BIT_SHIFT_PCI_SPRAM_8821C)
#define BITS_PCI_SPRAM_8821C \
(BIT_MASK_PCI_SPRAM_8821C << BIT_SHIFT_PCI_SPRAM_8821C)
#define BIT_CLEAR_PCI_SPRAM_8821C(x) ((x) & (~BITS_PCI_SPRAM_8821C))
#define BIT_GET_PCI_SPRAM_8821C(x) \
(((x) >> BIT_SHIFT_PCI_SPRAM_8821C) & BIT_MASK_PCI_SPRAM_8821C)
#define BIT_SET_PCI_SPRAM_8821C(x, v) \
(BIT_CLEAR_PCI_SPRAM_8821C(x) | BIT_PCI_SPRAM_8821C(v))
#define BIT_SHIFT_USB_SPRAM_8821C 6
#define BIT_MASK_USB_SPRAM_8821C 0x3
#define BIT_USB_SPRAM_8821C(x) \
(((x) & BIT_MASK_USB_SPRAM_8821C) << BIT_SHIFT_USB_SPRAM_8821C)
#define BITS_USB_SPRAM_8821C \
(BIT_MASK_USB_SPRAM_8821C << BIT_SHIFT_USB_SPRAM_8821C)
#define BIT_CLEAR_USB_SPRAM_8821C(x) ((x) & (~BITS_USB_SPRAM_8821C))
#define BIT_GET_USB_SPRAM_8821C(x) \
(((x) >> BIT_SHIFT_USB_SPRAM_8821C) & BIT_MASK_USB_SPRAM_8821C)
#define BIT_SET_USB_SPRAM_8821C(x, v) \
(BIT_CLEAR_USB_SPRAM_8821C(x) | BIT_USB_SPRAM_8821C(v))
#define BIT_SHIFT_USB_SPRF_8821C 4
#define BIT_MASK_USB_SPRF_8821C 0x3
#define BIT_USB_SPRF_8821C(x) \
(((x) & BIT_MASK_USB_SPRF_8821C) << BIT_SHIFT_USB_SPRF_8821C)
#define BITS_USB_SPRF_8821C \
(BIT_MASK_USB_SPRF_8821C << BIT_SHIFT_USB_SPRF_8821C)
#define BIT_CLEAR_USB_SPRF_8821C(x) ((x) & (~BITS_USB_SPRF_8821C))
#define BIT_GET_USB_SPRF_8821C(x) \
(((x) >> BIT_SHIFT_USB_SPRF_8821C) & BIT_MASK_USB_SPRF_8821C)
#define BIT_SET_USB_SPRF_8821C(x, v) \
(BIT_CLEAR_USB_SPRF_8821C(x) | BIT_USB_SPRF_8821C(v))
#define BIT_SHIFT_MCU_ROM_8821C 0
#define BIT_MASK_MCU_ROM_8821C 0xf
#define BIT_MCU_ROM_8821C(x) \
(((x) & BIT_MASK_MCU_ROM_8821C) << BIT_SHIFT_MCU_ROM_8821C)
#define BITS_MCU_ROM_8821C (BIT_MASK_MCU_ROM_8821C << BIT_SHIFT_MCU_ROM_8821C)
#define BIT_CLEAR_MCU_ROM_8821C(x) ((x) & (~BITS_MCU_ROM_8821C))
#define BIT_GET_MCU_ROM_8821C(x) \
(((x) >> BIT_SHIFT_MCU_ROM_8821C) & BIT_MASK_MCU_ROM_8821C)
#define BIT_SET_MCU_ROM_8821C(x, v) \
(BIT_CLEAR_MCU_ROM_8821C(x) | BIT_MCU_ROM_8821C(v))
/* 2 REG_AFE_CTRL8_8821C */
#define BIT_SYN_AGPIO_8821C BIT(20)
#define BIT_XTAL_LP_8821C BIT(4)
#define BIT_XTAL_GM_SEP_8821C BIT(3)
#define BIT_SHIFT_XTAL_SEL_TOK_8821C 0
#define BIT_MASK_XTAL_SEL_TOK_8821C 0x7
#define BIT_XTAL_SEL_TOK_8821C(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_8821C) << BIT_SHIFT_XTAL_SEL_TOK_8821C)
#define BITS_XTAL_SEL_TOK_8821C \
(BIT_MASK_XTAL_SEL_TOK_8821C << BIT_SHIFT_XTAL_SEL_TOK_8821C)
#define BIT_CLEAR_XTAL_SEL_TOK_8821C(x) ((x) & (~BITS_XTAL_SEL_TOK_8821C))
#define BIT_GET_XTAL_SEL_TOK_8821C(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_8821C) & BIT_MASK_XTAL_SEL_TOK_8821C)
#define BIT_SET_XTAL_SEL_TOK_8821C(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_8821C(x) | BIT_XTAL_SEL_TOK_8821C(v))
/* 2 REG_USB_SIE_INTF_8821C */
#define BIT_RD_SEL_8821C BIT(31)
#define BIT_USB_SIE_INTF_WE_V1_8821C BIT(30)
#define BIT_USB_SIE_INTF_BYIOREG_V1_8821C BIT(29)
#define BIT_USB_SIE_SELECT_8821C BIT(28)
#define BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8821C 16
#define BIT_MASK_USB_SIE_INTF_ADDR_V1_8821C 0x1ff
#define BIT_USB_SIE_INTF_ADDR_V1_8821C(x) \
(((x) & BIT_MASK_USB_SIE_INTF_ADDR_V1_8821C) \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8821C)
#define BITS_USB_SIE_INTF_ADDR_V1_8821C \
(BIT_MASK_USB_SIE_INTF_ADDR_V1_8821C \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8821C)
#define BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8821C(x) \
((x) & (~BITS_USB_SIE_INTF_ADDR_V1_8821C))
#define BIT_GET_USB_SIE_INTF_ADDR_V1_8821C(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8821C) & \
BIT_MASK_USB_SIE_INTF_ADDR_V1_8821C)
#define BIT_SET_USB_SIE_INTF_ADDR_V1_8821C(x, v) \
(BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8821C(x) | \
BIT_USB_SIE_INTF_ADDR_V1_8821C(v))
#define BIT_SHIFT_USB_SIE_INTF_RD_8821C 8
#define BIT_MASK_USB_SIE_INTF_RD_8821C 0xff
#define BIT_USB_SIE_INTF_RD_8821C(x) \
(((x) & BIT_MASK_USB_SIE_INTF_RD_8821C) \
<< BIT_SHIFT_USB_SIE_INTF_RD_8821C)
#define BITS_USB_SIE_INTF_RD_8821C \
(BIT_MASK_USB_SIE_INTF_RD_8821C << BIT_SHIFT_USB_SIE_INTF_RD_8821C)
#define BIT_CLEAR_USB_SIE_INTF_RD_8821C(x) ((x) & (~BITS_USB_SIE_INTF_RD_8821C))
#define BIT_GET_USB_SIE_INTF_RD_8821C(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_RD_8821C) & \
BIT_MASK_USB_SIE_INTF_RD_8821C)
#define BIT_SET_USB_SIE_INTF_RD_8821C(x, v) \
(BIT_CLEAR_USB_SIE_INTF_RD_8821C(x) | BIT_USB_SIE_INTF_RD_8821C(v))
#define BIT_SHIFT_USB_SIE_INTF_WD_8821C 0
#define BIT_MASK_USB_SIE_INTF_WD_8821C 0xff
#define BIT_USB_SIE_INTF_WD_8821C(x) \
(((x) & BIT_MASK_USB_SIE_INTF_WD_8821C) \
<< BIT_SHIFT_USB_SIE_INTF_WD_8821C)
#define BITS_USB_SIE_INTF_WD_8821C \
(BIT_MASK_USB_SIE_INTF_WD_8821C << BIT_SHIFT_USB_SIE_INTF_WD_8821C)
#define BIT_CLEAR_USB_SIE_INTF_WD_8821C(x) ((x) & (~BITS_USB_SIE_INTF_WD_8821C))
#define BIT_GET_USB_SIE_INTF_WD_8821C(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_WD_8821C) & \
BIT_MASK_USB_SIE_INTF_WD_8821C)
#define BIT_SET_USB_SIE_INTF_WD_8821C(x, v) \
(BIT_CLEAR_USB_SIE_INTF_WD_8821C(x) | BIT_USB_SIE_INTF_WD_8821C(v))
/* 2 REG_PCIE_MIO_INTF_8821C */
#define BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8821C 16
#define BIT_MASK_PCIE_MIO_ADDR_PAGE_8821C 0x3
#define BIT_PCIE_MIO_ADDR_PAGE_8821C(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_PAGE_8821C) \
<< BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8821C)
#define BITS_PCIE_MIO_ADDR_PAGE_8821C \
(BIT_MASK_PCIE_MIO_ADDR_PAGE_8821C \
<< BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8821C)
#define BIT_CLEAR_PCIE_MIO_ADDR_PAGE_8821C(x) \
((x) & (~BITS_PCIE_MIO_ADDR_PAGE_8821C))
#define BIT_GET_PCIE_MIO_ADDR_PAGE_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8821C) & \
BIT_MASK_PCIE_MIO_ADDR_PAGE_8821C)
#define BIT_SET_PCIE_MIO_ADDR_PAGE_8821C(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_PAGE_8821C(x) | \
BIT_PCIE_MIO_ADDR_PAGE_8821C(v))
#define BIT_PCIE_MIO_BYIOREG_8821C BIT(13)
#define BIT_PCIE_MIO_RE_8821C BIT(12)
#define BIT_SHIFT_PCIE_MIO_WE_8821C 8
#define BIT_MASK_PCIE_MIO_WE_8821C 0xf
#define BIT_PCIE_MIO_WE_8821C(x) \
(((x) & BIT_MASK_PCIE_MIO_WE_8821C) << BIT_SHIFT_PCIE_MIO_WE_8821C)
#define BITS_PCIE_MIO_WE_8821C \
(BIT_MASK_PCIE_MIO_WE_8821C << BIT_SHIFT_PCIE_MIO_WE_8821C)
#define BIT_CLEAR_PCIE_MIO_WE_8821C(x) ((x) & (~BITS_PCIE_MIO_WE_8821C))
#define BIT_GET_PCIE_MIO_WE_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_WE_8821C) & BIT_MASK_PCIE_MIO_WE_8821C)
#define BIT_SET_PCIE_MIO_WE_8821C(x, v) \
(BIT_CLEAR_PCIE_MIO_WE_8821C(x) | BIT_PCIE_MIO_WE_8821C(v))
#define BIT_SHIFT_PCIE_MIO_ADDR_8821C 0
#define BIT_MASK_PCIE_MIO_ADDR_8821C 0xff
#define BIT_PCIE_MIO_ADDR_8821C(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_8821C) << BIT_SHIFT_PCIE_MIO_ADDR_8821C)
#define BITS_PCIE_MIO_ADDR_8821C \
(BIT_MASK_PCIE_MIO_ADDR_8821C << BIT_SHIFT_PCIE_MIO_ADDR_8821C)
#define BIT_CLEAR_PCIE_MIO_ADDR_8821C(x) ((x) & (~BITS_PCIE_MIO_ADDR_8821C))
#define BIT_GET_PCIE_MIO_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_8821C) & BIT_MASK_PCIE_MIO_ADDR_8821C)
#define BIT_SET_PCIE_MIO_ADDR_8821C(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_8821C(x) | BIT_PCIE_MIO_ADDR_8821C(v))
/* 2 REG_PCIE_MIO_INTD_8821C */
#define BIT_SHIFT_PCIE_MIO_DATA_8821C 0
#define BIT_MASK_PCIE_MIO_DATA_8821C 0xffffffffL
#define BIT_PCIE_MIO_DATA_8821C(x) \
(((x) & BIT_MASK_PCIE_MIO_DATA_8821C) << BIT_SHIFT_PCIE_MIO_DATA_8821C)
#define BITS_PCIE_MIO_DATA_8821C \
(BIT_MASK_PCIE_MIO_DATA_8821C << BIT_SHIFT_PCIE_MIO_DATA_8821C)
#define BIT_CLEAR_PCIE_MIO_DATA_8821C(x) ((x) & (~BITS_PCIE_MIO_DATA_8821C))
#define BIT_GET_PCIE_MIO_DATA_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_DATA_8821C) & BIT_MASK_PCIE_MIO_DATA_8821C)
#define BIT_SET_PCIE_MIO_DATA_8821C(x, v) \
(BIT_CLEAR_PCIE_MIO_DATA_8821C(x) | BIT_PCIE_MIO_DATA_8821C(v))
/* 2 REG_WLRF1_8821C */
#define BIT_SHIFT_WLRF1_CTRL_8821C 24
#define BIT_MASK_WLRF1_CTRL_8821C 0xff
#define BIT_WLRF1_CTRL_8821C(x) \
(((x) & BIT_MASK_WLRF1_CTRL_8821C) << BIT_SHIFT_WLRF1_CTRL_8821C)
#define BITS_WLRF1_CTRL_8821C \
(BIT_MASK_WLRF1_CTRL_8821C << BIT_SHIFT_WLRF1_CTRL_8821C)
#define BIT_CLEAR_WLRF1_CTRL_8821C(x) ((x) & (~BITS_WLRF1_CTRL_8821C))
#define BIT_GET_WLRF1_CTRL_8821C(x) \
(((x) >> BIT_SHIFT_WLRF1_CTRL_8821C) & BIT_MASK_WLRF1_CTRL_8821C)
#define BIT_SET_WLRF1_CTRL_8821C(x, v) \
(BIT_CLEAR_WLRF1_CTRL_8821C(x) | BIT_WLRF1_CTRL_8821C(v))
/* 2 REG_SYS_CFG1_8821C */
#define BIT_SHIFT_TRP_ICFG_8821C 28
#define BIT_MASK_TRP_ICFG_8821C 0xf
#define BIT_TRP_ICFG_8821C(x) \
(((x) & BIT_MASK_TRP_ICFG_8821C) << BIT_SHIFT_TRP_ICFG_8821C)
#define BITS_TRP_ICFG_8821C \
(BIT_MASK_TRP_ICFG_8821C << BIT_SHIFT_TRP_ICFG_8821C)
#define BIT_CLEAR_TRP_ICFG_8821C(x) ((x) & (~BITS_TRP_ICFG_8821C))
#define BIT_GET_TRP_ICFG_8821C(x) \
(((x) >> BIT_SHIFT_TRP_ICFG_8821C) & BIT_MASK_TRP_ICFG_8821C)
#define BIT_SET_TRP_ICFG_8821C(x, v) \
(BIT_CLEAR_TRP_ICFG_8821C(x) | BIT_TRP_ICFG_8821C(v))
#define BIT_RF_TYPE_ID_8821C BIT(27)
#define BIT_BD_HCI_SEL_8821C BIT(26)
#define BIT_BD_PKG_SEL_8821C BIT(25)
#define BIT_SPSLDO_SEL_8821C BIT(24)
#define BIT_RTL_ID_8821C BIT(23)
#define BIT_PAD_HWPD_IDN_8821C BIT(22)
#define BIT_TESTMODE_8821C BIT(20)
#define BIT_SHIFT_VENDOR_ID_8821C 16
#define BIT_MASK_VENDOR_ID_8821C 0xf
#define BIT_VENDOR_ID_8821C(x) \
(((x) & BIT_MASK_VENDOR_ID_8821C) << BIT_SHIFT_VENDOR_ID_8821C)
#define BITS_VENDOR_ID_8821C \
(BIT_MASK_VENDOR_ID_8821C << BIT_SHIFT_VENDOR_ID_8821C)
#define BIT_CLEAR_VENDOR_ID_8821C(x) ((x) & (~BITS_VENDOR_ID_8821C))
#define BIT_GET_VENDOR_ID_8821C(x) \
(((x) >> BIT_SHIFT_VENDOR_ID_8821C) & BIT_MASK_VENDOR_ID_8821C)
#define BIT_SET_VENDOR_ID_8821C(x, v) \
(BIT_CLEAR_VENDOR_ID_8821C(x) | BIT_VENDOR_ID_8821C(v))
#define BIT_SHIFT_CHIP_VER_8821C 12
#define BIT_MASK_CHIP_VER_8821C 0xf
#define BIT_CHIP_VER_8821C(x) \
(((x) & BIT_MASK_CHIP_VER_8821C) << BIT_SHIFT_CHIP_VER_8821C)
#define BITS_CHIP_VER_8821C \
(BIT_MASK_CHIP_VER_8821C << BIT_SHIFT_CHIP_VER_8821C)
#define BIT_CLEAR_CHIP_VER_8821C(x) ((x) & (~BITS_CHIP_VER_8821C))
#define BIT_GET_CHIP_VER_8821C(x) \
(((x) >> BIT_SHIFT_CHIP_VER_8821C) & BIT_MASK_CHIP_VER_8821C)
#define BIT_SET_CHIP_VER_8821C(x, v) \
(BIT_CLEAR_CHIP_VER_8821C(x) | BIT_CHIP_VER_8821C(v))
#define BIT_BD_MAC3_8821C BIT(11)
#define BIT_BD_MAC1_8821C BIT(10)
#define BIT_BD_MAC2_8821C BIT(9)
#define BIT_SIC_IDLE_8821C BIT(8)
#define BIT_SW_OFFLOAD_EN_8821C BIT(7)
#define BIT_OCP_SHUTDN_8821C BIT(6)
#define BIT_V15_VLD_8821C BIT(5)
#define BIT_PCIRSTB_8821C BIT(4)
#define BIT_PCLK_VLD_8821C BIT(3)
#define BIT_UCLK_VLD_8821C BIT(2)
#define BIT_ACLK_VLD_8821C BIT(1)
#define BIT_XCLK_VLD_8821C BIT(0)
/* 2 REG_SYS_STATUS1_8821C */
#define BIT_SHIFT_RF_RL_ID_8821C 28
#define BIT_MASK_RF_RL_ID_8821C 0xf
#define BIT_RF_RL_ID_8821C(x) \
(((x) & BIT_MASK_RF_RL_ID_8821C) << BIT_SHIFT_RF_RL_ID_8821C)
#define BITS_RF_RL_ID_8821C \
(BIT_MASK_RF_RL_ID_8821C << BIT_SHIFT_RF_RL_ID_8821C)
#define BIT_CLEAR_RF_RL_ID_8821C(x) ((x) & (~BITS_RF_RL_ID_8821C))
#define BIT_GET_RF_RL_ID_8821C(x) \
(((x) >> BIT_SHIFT_RF_RL_ID_8821C) & BIT_MASK_RF_RL_ID_8821C)
#define BIT_SET_RF_RL_ID_8821C(x, v) \
(BIT_CLEAR_RF_RL_ID_8821C(x) | BIT_RF_RL_ID_8821C(v))
#define BIT_HPHY_ICFG_8821C BIT(19)
#define BIT_SHIFT_SEL_0XC0_8821C 16
#define BIT_MASK_SEL_0XC0_8821C 0x3
#define BIT_SEL_0XC0_8821C(x) \
(((x) & BIT_MASK_SEL_0XC0_8821C) << BIT_SHIFT_SEL_0XC0_8821C)
#define BITS_SEL_0XC0_8821C \
(BIT_MASK_SEL_0XC0_8821C << BIT_SHIFT_SEL_0XC0_8821C)
#define BIT_CLEAR_SEL_0XC0_8821C(x) ((x) & (~BITS_SEL_0XC0_8821C))
#define BIT_GET_SEL_0XC0_8821C(x) \
(((x) >> BIT_SHIFT_SEL_0XC0_8821C) & BIT_MASK_SEL_0XC0_8821C)
#define BIT_SET_SEL_0XC0_8821C(x, v) \
(BIT_CLEAR_SEL_0XC0_8821C(x) | BIT_SEL_0XC0_8821C(v))
#define BIT_SHIFT_HCI_SEL_V4_8821C 12
#define BIT_MASK_HCI_SEL_V4_8821C 0x3
#define BIT_HCI_SEL_V4_8821C(x) \
(((x) & BIT_MASK_HCI_SEL_V4_8821C) << BIT_SHIFT_HCI_SEL_V4_8821C)
#define BITS_HCI_SEL_V4_8821C \
(BIT_MASK_HCI_SEL_V4_8821C << BIT_SHIFT_HCI_SEL_V4_8821C)
#define BIT_CLEAR_HCI_SEL_V4_8821C(x) ((x) & (~BITS_HCI_SEL_V4_8821C))
#define BIT_GET_HCI_SEL_V4_8821C(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V4_8821C) & BIT_MASK_HCI_SEL_V4_8821C)
#define BIT_SET_HCI_SEL_V4_8821C(x, v) \
(BIT_CLEAR_HCI_SEL_V4_8821C(x) | BIT_HCI_SEL_V4_8821C(v))
#define BIT_USB_OPERATION_MODE_8821C BIT(10)
#define BIT_BT_PDN_8821C BIT(9)
#define BIT_AUTO_WLPON_8821C BIT(8)
#define BIT_WL_MODE_8821C BIT(7)
#define BIT_PKG_SEL_HCI_8821C BIT(6)
#define BIT_SHIFT_PAD_HCI_SEL_V2_8821C 3
#define BIT_MASK_PAD_HCI_SEL_V2_8821C 0x3
#define BIT_PAD_HCI_SEL_V2_8821C(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_V2_8821C) \
<< BIT_SHIFT_PAD_HCI_SEL_V2_8821C)
#define BITS_PAD_HCI_SEL_V2_8821C \
(BIT_MASK_PAD_HCI_SEL_V2_8821C << BIT_SHIFT_PAD_HCI_SEL_V2_8821C)
#define BIT_CLEAR_PAD_HCI_SEL_V2_8821C(x) ((x) & (~BITS_PAD_HCI_SEL_V2_8821C))
#define BIT_GET_PAD_HCI_SEL_V2_8821C(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_V2_8821C) & \
BIT_MASK_PAD_HCI_SEL_V2_8821C)
#define BIT_SET_PAD_HCI_SEL_V2_8821C(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_V2_8821C(x) | BIT_PAD_HCI_SEL_V2_8821C(v))
#define BIT_SHIFT_EFS_HCI_SEL_8821C 0
#define BIT_MASK_EFS_HCI_SEL_8821C 0x3
#define BIT_EFS_HCI_SEL_8821C(x) \
(((x) & BIT_MASK_EFS_HCI_SEL_8821C) << BIT_SHIFT_EFS_HCI_SEL_8821C)
#define BITS_EFS_HCI_SEL_8821C \
(BIT_MASK_EFS_HCI_SEL_8821C << BIT_SHIFT_EFS_HCI_SEL_8821C)
#define BIT_CLEAR_EFS_HCI_SEL_8821C(x) ((x) & (~BITS_EFS_HCI_SEL_8821C))
#define BIT_GET_EFS_HCI_SEL_8821C(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL_8821C) & BIT_MASK_EFS_HCI_SEL_8821C)
#define BIT_SET_EFS_HCI_SEL_8821C(x, v) \
(BIT_CLEAR_EFS_HCI_SEL_8821C(x) | BIT_EFS_HCI_SEL_8821C(v))
/* 2 REG_SYS_STATUS2_8821C */
#define BIT_SIO_ALDN_8821C BIT(19)
#define BIT_USB_ALDN_8821C BIT(18)
#define BIT_PCI_ALDN_8821C BIT(17)
#define BIT_SYS_ALDN_8821C BIT(16)
#define BIT_SHIFT_EPVID1_8821C 8
#define BIT_MASK_EPVID1_8821C 0xff
#define BIT_EPVID1_8821C(x) \
(((x) & BIT_MASK_EPVID1_8821C) << BIT_SHIFT_EPVID1_8821C)
#define BITS_EPVID1_8821C (BIT_MASK_EPVID1_8821C << BIT_SHIFT_EPVID1_8821C)
#define BIT_CLEAR_EPVID1_8821C(x) ((x) & (~BITS_EPVID1_8821C))
#define BIT_GET_EPVID1_8821C(x) \
(((x) >> BIT_SHIFT_EPVID1_8821C) & BIT_MASK_EPVID1_8821C)
#define BIT_SET_EPVID1_8821C(x, v) \
(BIT_CLEAR_EPVID1_8821C(x) | BIT_EPVID1_8821C(v))
#define BIT_SHIFT_EPVID0_8821C 0
#define BIT_MASK_EPVID0_8821C 0xff
#define BIT_EPVID0_8821C(x) \
(((x) & BIT_MASK_EPVID0_8821C) << BIT_SHIFT_EPVID0_8821C)
#define BITS_EPVID0_8821C (BIT_MASK_EPVID0_8821C << BIT_SHIFT_EPVID0_8821C)
#define BIT_CLEAR_EPVID0_8821C(x) ((x) & (~BITS_EPVID0_8821C))
#define BIT_GET_EPVID0_8821C(x) \
(((x) >> BIT_SHIFT_EPVID0_8821C) & BIT_MASK_EPVID0_8821C)
#define BIT_SET_EPVID0_8821C(x, v) \
(BIT_CLEAR_EPVID0_8821C(x) | BIT_EPVID0_8821C(v))
/* 2 REG_SYS_CFG2_8821C */
#define BIT_HCI_SEL_EMBEDDED_8821C BIT(8)
#define BIT_SHIFT_HW_ID_8821C 0
#define BIT_MASK_HW_ID_8821C 0xff
#define BIT_HW_ID_8821C(x) \
(((x) & BIT_MASK_HW_ID_8821C) << BIT_SHIFT_HW_ID_8821C)
#define BITS_HW_ID_8821C (BIT_MASK_HW_ID_8821C << BIT_SHIFT_HW_ID_8821C)
#define BIT_CLEAR_HW_ID_8821C(x) ((x) & (~BITS_HW_ID_8821C))
#define BIT_GET_HW_ID_8821C(x) \
(((x) >> BIT_SHIFT_HW_ID_8821C) & BIT_MASK_HW_ID_8821C)
#define BIT_SET_HW_ID_8821C(x, v) \
(BIT_CLEAR_HW_ID_8821C(x) | BIT_HW_ID_8821C(v))
/* 2 REG_SYS_CFG3_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SYS_CFG5_8821C */
#define BIT_LPS_STATUS_8821C BIT(3)
#define BIT_HCI_TXDMA_BUSY_8821C BIT(2)
#define BIT_HCI_TXDMA_ALLOW_8821C BIT(1)
#define BIT_FW_CTRL_HCI_TXDMA_EN_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_CPU_DMEM_CON_8821C */
#define BIT_WDT_AUTO_MODE_8821C BIT(22)
#define BIT_WDT_PLATFORM_EN_8821C BIT(21)
#define BIT_WDT_CPU_EN_8821C BIT(20)
#define BIT_WDT_OPT_IOWRAPPER_8821C BIT(19)
#define BIT_ANA_PORT_IDLE_8821C BIT(18)
#define BIT_MAC_PORT_IDLE_8821C BIT(17)
#define BIT_WL_PLATFORM_RST_8821C BIT(16)
#define BIT_WL_SECURITY_CLK_8821C BIT(15)
#define BIT_SHIFT_CPU_DMEM_CON_8821C 0
#define BIT_MASK_CPU_DMEM_CON_8821C 0xff
#define BIT_CPU_DMEM_CON_8821C(x) \
(((x) & BIT_MASK_CPU_DMEM_CON_8821C) << BIT_SHIFT_CPU_DMEM_CON_8821C)
#define BITS_CPU_DMEM_CON_8821C \
(BIT_MASK_CPU_DMEM_CON_8821C << BIT_SHIFT_CPU_DMEM_CON_8821C)
#define BIT_CLEAR_CPU_DMEM_CON_8821C(x) ((x) & (~BITS_CPU_DMEM_CON_8821C))
#define BIT_GET_CPU_DMEM_CON_8821C(x) \
(((x) >> BIT_SHIFT_CPU_DMEM_CON_8821C) & BIT_MASK_CPU_DMEM_CON_8821C)
#define BIT_SET_CPU_DMEM_CON_8821C(x, v) \
(BIT_CLEAR_CPU_DMEM_CON_8821C(x) | BIT_CPU_DMEM_CON_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_BOOT_REASON_8821C */
#define BIT_SHIFT_BOOT_REASON_V1_8821C 0
#define BIT_MASK_BOOT_REASON_V1_8821C 0x7
#define BIT_BOOT_REASON_V1_8821C(x) \
(((x) & BIT_MASK_BOOT_REASON_V1_8821C) \
<< BIT_SHIFT_BOOT_REASON_V1_8821C)
#define BITS_BOOT_REASON_V1_8821C \
(BIT_MASK_BOOT_REASON_V1_8821C << BIT_SHIFT_BOOT_REASON_V1_8821C)
#define BIT_CLEAR_BOOT_REASON_V1_8821C(x) ((x) & (~BITS_BOOT_REASON_V1_8821C))
#define BIT_GET_BOOT_REASON_V1_8821C(x) \
(((x) >> BIT_SHIFT_BOOT_REASON_V1_8821C) & \
BIT_MASK_BOOT_REASON_V1_8821C)
#define BIT_SET_BOOT_REASON_V1_8821C(x, v) \
(BIT_CLEAR_BOOT_REASON_V1_8821C(x) | BIT_BOOT_REASON_V1_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NFCPAD_CTRL_8821C */
#define BIT_PAD_SHUTDW_8821C BIT(18)
#define BIT_SYSON_NFC_PAD_8821C BIT(17)
#define BIT_NFC_INT_PAD_CTRL_8821C BIT(16)
#define BIT_NFC_RFDIS_PAD_CTRL_8821C BIT(15)
#define BIT_NFC_CLK_PAD_CTRL_8821C BIT(14)
#define BIT_NFC_DATA_PAD_CTRL_8821C BIT(13)
#define BIT_NFC_PAD_PULL_CTRL_8821C BIT(12)
#define BIT_SHIFT_NFCPAD_IO_SEL_8821C 8
#define BIT_MASK_NFCPAD_IO_SEL_8821C 0xf
#define BIT_NFCPAD_IO_SEL_8821C(x) \
(((x) & BIT_MASK_NFCPAD_IO_SEL_8821C) << BIT_SHIFT_NFCPAD_IO_SEL_8821C)
#define BITS_NFCPAD_IO_SEL_8821C \
(BIT_MASK_NFCPAD_IO_SEL_8821C << BIT_SHIFT_NFCPAD_IO_SEL_8821C)
#define BIT_CLEAR_NFCPAD_IO_SEL_8821C(x) ((x) & (~BITS_NFCPAD_IO_SEL_8821C))
#define BIT_GET_NFCPAD_IO_SEL_8821C(x) \
(((x) >> BIT_SHIFT_NFCPAD_IO_SEL_8821C) & BIT_MASK_NFCPAD_IO_SEL_8821C)
#define BIT_SET_NFCPAD_IO_SEL_8821C(x, v) \
(BIT_CLEAR_NFCPAD_IO_SEL_8821C(x) | BIT_NFCPAD_IO_SEL_8821C(v))
#define BIT_SHIFT_NFCPAD_OUT_8821C 4
#define BIT_MASK_NFCPAD_OUT_8821C 0xf
#define BIT_NFCPAD_OUT_8821C(x) \
(((x) & BIT_MASK_NFCPAD_OUT_8821C) << BIT_SHIFT_NFCPAD_OUT_8821C)
#define BITS_NFCPAD_OUT_8821C \
(BIT_MASK_NFCPAD_OUT_8821C << BIT_SHIFT_NFCPAD_OUT_8821C)
#define BIT_CLEAR_NFCPAD_OUT_8821C(x) ((x) & (~BITS_NFCPAD_OUT_8821C))
#define BIT_GET_NFCPAD_OUT_8821C(x) \
(((x) >> BIT_SHIFT_NFCPAD_OUT_8821C) & BIT_MASK_NFCPAD_OUT_8821C)
#define BIT_SET_NFCPAD_OUT_8821C(x, v) \
(BIT_CLEAR_NFCPAD_OUT_8821C(x) | BIT_NFCPAD_OUT_8821C(v))
#define BIT_SHIFT_NFCPAD_IN_8821C 0
#define BIT_MASK_NFCPAD_IN_8821C 0xf
#define BIT_NFCPAD_IN_8821C(x) \
(((x) & BIT_MASK_NFCPAD_IN_8821C) << BIT_SHIFT_NFCPAD_IN_8821C)
#define BITS_NFCPAD_IN_8821C \
(BIT_MASK_NFCPAD_IN_8821C << BIT_SHIFT_NFCPAD_IN_8821C)
#define BIT_CLEAR_NFCPAD_IN_8821C(x) ((x) & (~BITS_NFCPAD_IN_8821C))
#define BIT_GET_NFCPAD_IN_8821C(x) \
(((x) >> BIT_SHIFT_NFCPAD_IN_8821C) & BIT_MASK_NFCPAD_IN_8821C)
#define BIT_SET_NFCPAD_IN_8821C(x, v) \
(BIT_CLEAR_NFCPAD_IN_8821C(x) | BIT_NFCPAD_IN_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_HIMR2_8821C */
#define BIT_BCNDMAINT_P4_MSK_8821C BIT(31)
#define BIT_BCNDMAINT_P3_MSK_8821C BIT(30)
#define BIT_BCNDMAINT_P2_MSK_8821C BIT(29)
#define BIT_BCNDMAINT_P1_MSK_8821C BIT(28)
#define BIT_ATIMEND7_MSK_8821C BIT(22)
#define BIT_ATIMEND6_MSK_8821C BIT(21)
#define BIT_ATIMEND5_MSK_8821C BIT(20)
#define BIT_ATIMEND4_MSK_8821C BIT(19)
#define BIT_ATIMEND3_MSK_8821C BIT(18)
#define BIT_ATIMEND2_MSK_8821C BIT(17)
#define BIT_ATIMEND1_MSK_8821C BIT(16)
#define BIT_TXBCN7OK_MSK_8821C BIT(14)
#define BIT_TXBCN6OK_MSK_8821C BIT(13)
#define BIT_TXBCN5OK_MSK_8821C BIT(12)
#define BIT_TXBCN4OK_MSK_8821C BIT(11)
#define BIT_TXBCN3OK_MSK_8821C BIT(10)
#define BIT_TXBCN2OK_MSK_8821C BIT(9)
#define BIT_TXBCN1OK_MSK_V1_8821C BIT(8)
#define BIT_TXBCN7ERR_MSK_8821C BIT(6)
#define BIT_TXBCN6ERR_MSK_8821C BIT(5)
#define BIT_TXBCN5ERR_MSK_8821C BIT(4)
#define BIT_TXBCN4ERR_MSK_8821C BIT(3)
#define BIT_TXBCN3ERR_MSK_8821C BIT(2)
#define BIT_TXBCN2ERR_MSK_8821C BIT(1)
#define BIT_TXBCN1ERR_MSK_V1_8821C BIT(0)
/* 2 REG_HISR2_8821C */
#define BIT_BCNDMAINT_P4_8821C BIT(31)
#define BIT_BCNDMAINT_P3_8821C BIT(30)
#define BIT_BCNDMAINT_P2_8821C BIT(29)
#define BIT_BCNDMAINT_P1_8821C BIT(28)
#define BIT_ATIMEND7_8821C BIT(22)
#define BIT_ATIMEND6_8821C BIT(21)
#define BIT_ATIMEND5_8821C BIT(20)
#define BIT_ATIMEND4_8821C BIT(19)
#define BIT_ATIMEND3_8821C BIT(18)
#define BIT_ATIMEND2_8821C BIT(17)
#define BIT_ATIMEND1_8821C BIT(16)
#define BIT_TXBCN7OK_8821C BIT(14)
#define BIT_TXBCN6OK_8821C BIT(13)
#define BIT_TXBCN5OK_8821C BIT(12)
#define BIT_TXBCN4OK_8821C BIT(11)
#define BIT_TXBCN3OK_8821C BIT(10)
#define BIT_TXBCN2OK_8821C BIT(9)
#define BIT_TXBCN1OK_8821C BIT(8)
#define BIT_TXBCN7ERR_8821C BIT(6)
#define BIT_TXBCN6ERR_8821C BIT(5)
#define BIT_TXBCN5ERR_8821C BIT(4)
#define BIT_TXBCN4ERR_8821C BIT(3)
#define BIT_TXBCN3ERR_8821C BIT(2)
#define BIT_TXBCN2ERR_8821C BIT(1)
#define BIT_TXBCN1ERR_8821C BIT(0)
/* 2 REG_HIMR3_8821C */
#define BIT_WDT_PLATFORM_INT_MSK_8821C BIT(18)
#define BIT_WDT_CPU_INT_MSK_8821C BIT(17)
#define BIT_SETH2CDOK_MASK_8821C BIT(16)
#define BIT_H2C_CMD_FULL_MASK_8821C BIT(15)
#define BIT_PWR_INT_127_MASK_8821C BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_MASK_8821C BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_MASK_8821C BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_MASK_8821C BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_MAS_8821C BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_MASK_8821C BIT(9)
#define BIT_PWR_INT_127_MASK_V1_8821C BIT(8)
#define BIT_PWR_INT_126TO96_MASK_8821C BIT(7)
#define BIT_PWR_INT_95TO64_MASK_8821C BIT(6)
#define BIT_PWR_INT_63TO32_MASK_8821C BIT(5)
#define BIT_PWR_INT_31TO0_MASK_8821C BIT(4)
#define BIT_DDMA0_LP_INT_MSK_8821C BIT(1)
#define BIT_DDMA0_HP_INT_MSK_8821C BIT(0)
/* 2 REG_HISR3_8821C */
#define BIT_WDT_PLATFORM_INT_8821C BIT(18)
#define BIT_WDT_CPU_INT_8821C BIT(17)
#define BIT_SETH2CDOK_8821C BIT(16)
#define BIT_H2C_CMD_FULL_8821C BIT(15)
#define BIT_PWR_INT_127_8821C BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8821C BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8821C BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8821C BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8821C BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8821C BIT(9)
#define BIT_PWR_INT_127_V1_8821C BIT(8)
#define BIT_PWR_INT_126TO96_8821C BIT(7)
#define BIT_PWR_INT_95TO64_8821C BIT(6)
#define BIT_PWR_INT_63TO32_8821C BIT(5)
#define BIT_PWR_INT_31TO0_8821C BIT(4)
#define BIT_DDMA0_LP_INT_8821C BIT(1)
#define BIT_DDMA0_HP_INT_8821C BIT(0)
/* 2 REG_SW_MDIO_8821C */
#define BIT_DIS_TIMEOUT_IO_8821C BIT(24)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_H2C_PKT_READADDR_8821C */
#define BIT_SHIFT_H2C_PKT_READADDR_8821C 0
#define BIT_MASK_H2C_PKT_READADDR_8821C 0x3ffff
#define BIT_H2C_PKT_READADDR_8821C(x) \
(((x) & BIT_MASK_H2C_PKT_READADDR_8821C) \
<< BIT_SHIFT_H2C_PKT_READADDR_8821C)
#define BITS_H2C_PKT_READADDR_8821C \
(BIT_MASK_H2C_PKT_READADDR_8821C << BIT_SHIFT_H2C_PKT_READADDR_8821C)
#define BIT_CLEAR_H2C_PKT_READADDR_8821C(x) \
((x) & (~BITS_H2C_PKT_READADDR_8821C))
#define BIT_GET_H2C_PKT_READADDR_8821C(x) \
(((x) >> BIT_SHIFT_H2C_PKT_READADDR_8821C) & \
BIT_MASK_H2C_PKT_READADDR_8821C)
#define BIT_SET_H2C_PKT_READADDR_8821C(x, v) \
(BIT_CLEAR_H2C_PKT_READADDR_8821C(x) | BIT_H2C_PKT_READADDR_8821C(v))
/* 2 REG_H2C_PKT_WRITEADDR_8821C */
#define BIT_SHIFT_H2C_PKT_WRITEADDR_8821C 0
#define BIT_MASK_H2C_PKT_WRITEADDR_8821C 0x3ffff
#define BIT_H2C_PKT_WRITEADDR_8821C(x) \
(((x) & BIT_MASK_H2C_PKT_WRITEADDR_8821C) \
<< BIT_SHIFT_H2C_PKT_WRITEADDR_8821C)
#define BITS_H2C_PKT_WRITEADDR_8821C \
(BIT_MASK_H2C_PKT_WRITEADDR_8821C << BIT_SHIFT_H2C_PKT_WRITEADDR_8821C)
#define BIT_CLEAR_H2C_PKT_WRITEADDR_8821C(x) \
((x) & (~BITS_H2C_PKT_WRITEADDR_8821C))
#define BIT_GET_H2C_PKT_WRITEADDR_8821C(x) \
(((x) >> BIT_SHIFT_H2C_PKT_WRITEADDR_8821C) & \
BIT_MASK_H2C_PKT_WRITEADDR_8821C)
#define BIT_SET_H2C_PKT_WRITEADDR_8821C(x, v) \
(BIT_CLEAR_H2C_PKT_WRITEADDR_8821C(x) | BIT_H2C_PKT_WRITEADDR_8821C(v))
/* 2 REG_MEM_PWR_CRTL_8821C */
#define BIT_MEM_BB_SD_8821C BIT(17)
#define BIT_MEM_BB_DS_8821C BIT(16)
#define BIT_MEM_BT_DS_8821C BIT(10)
#define BIT_MEM_SDIO_LS_8821C BIT(9)
#define BIT_MEM_SDIO_DS_8821C BIT(8)
#define BIT_MEM_USB_LS_8821C BIT(7)
#define BIT_MEM_USB_DS_8821C BIT(6)
#define BIT_MEM_PCI_LS_8821C BIT(5)
#define BIT_MEM_PCI_DS_8821C BIT(4)
#define BIT_MEM_WLMAC_LS_8821C BIT(3)
#define BIT_MEM_WLMAC_DS_8821C BIT(2)
#define BIT_MEM_WLMCU_LS_8821C BIT(1)
#define BIT_MEM_WLMCU_DS_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_FW_DBG6_8821C */
#define BIT_SHIFT_FW_DBG6_8821C 0
#define BIT_MASK_FW_DBG6_8821C 0xffffffffL
#define BIT_FW_DBG6_8821C(x) \
(((x) & BIT_MASK_FW_DBG6_8821C) << BIT_SHIFT_FW_DBG6_8821C)
#define BITS_FW_DBG6_8821C (BIT_MASK_FW_DBG6_8821C << BIT_SHIFT_FW_DBG6_8821C)
#define BIT_CLEAR_FW_DBG6_8821C(x) ((x) & (~BITS_FW_DBG6_8821C))
#define BIT_GET_FW_DBG6_8821C(x) \
(((x) >> BIT_SHIFT_FW_DBG6_8821C) & BIT_MASK_FW_DBG6_8821C)
#define BIT_SET_FW_DBG6_8821C(x, v) \
(BIT_CLEAR_FW_DBG6_8821C(x) | BIT_FW_DBG6_8821C(v))
/* 2 REG_FW_DBG7_8821C */
#define BIT_SHIFT_FW_DBG7_8821C 0
#define BIT_MASK_FW_DBG7_8821C 0xffffffffL
#define BIT_FW_DBG7_8821C(x) \
(((x) & BIT_MASK_FW_DBG7_8821C) << BIT_SHIFT_FW_DBG7_8821C)
#define BITS_FW_DBG7_8821C (BIT_MASK_FW_DBG7_8821C << BIT_SHIFT_FW_DBG7_8821C)
#define BIT_CLEAR_FW_DBG7_8821C(x) ((x) & (~BITS_FW_DBG7_8821C))
#define BIT_GET_FW_DBG7_8821C(x) \
(((x) >> BIT_SHIFT_FW_DBG7_8821C) & BIT_MASK_FW_DBG7_8821C)
#define BIT_SET_FW_DBG7_8821C(x, v) \
(BIT_CLEAR_FW_DBG7_8821C(x) | BIT_FW_DBG7_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_CR_8821C */
#define BIT_SHIFT_LBMODE_8821C 24
#define BIT_MASK_LBMODE_8821C 0x1f
#define BIT_LBMODE_8821C(x) \
(((x) & BIT_MASK_LBMODE_8821C) << BIT_SHIFT_LBMODE_8821C)
#define BITS_LBMODE_8821C (BIT_MASK_LBMODE_8821C << BIT_SHIFT_LBMODE_8821C)
#define BIT_CLEAR_LBMODE_8821C(x) ((x) & (~BITS_LBMODE_8821C))
#define BIT_GET_LBMODE_8821C(x) \
(((x) >> BIT_SHIFT_LBMODE_8821C) & BIT_MASK_LBMODE_8821C)
#define BIT_SET_LBMODE_8821C(x, v) \
(BIT_CLEAR_LBMODE_8821C(x) | BIT_LBMODE_8821C(v))
#define BIT_SHIFT_NETYPE1_8821C 18
#define BIT_MASK_NETYPE1_8821C 0x3
#define BIT_NETYPE1_8821C(x) \
(((x) & BIT_MASK_NETYPE1_8821C) << BIT_SHIFT_NETYPE1_8821C)
#define BITS_NETYPE1_8821C (BIT_MASK_NETYPE1_8821C << BIT_SHIFT_NETYPE1_8821C)
#define BIT_CLEAR_NETYPE1_8821C(x) ((x) & (~BITS_NETYPE1_8821C))
#define BIT_GET_NETYPE1_8821C(x) \
(((x) >> BIT_SHIFT_NETYPE1_8821C) & BIT_MASK_NETYPE1_8821C)
#define BIT_SET_NETYPE1_8821C(x, v) \
(BIT_CLEAR_NETYPE1_8821C(x) | BIT_NETYPE1_8821C(v))
#define BIT_SHIFT_NETYPE0_8821C 16
#define BIT_MASK_NETYPE0_8821C 0x3
#define BIT_NETYPE0_8821C(x) \
(((x) & BIT_MASK_NETYPE0_8821C) << BIT_SHIFT_NETYPE0_8821C)
#define BITS_NETYPE0_8821C (BIT_MASK_NETYPE0_8821C << BIT_SHIFT_NETYPE0_8821C)
#define BIT_CLEAR_NETYPE0_8821C(x) ((x) & (~BITS_NETYPE0_8821C))
#define BIT_GET_NETYPE0_8821C(x) \
(((x) >> BIT_SHIFT_NETYPE0_8821C) & BIT_MASK_NETYPE0_8821C)
#define BIT_SET_NETYPE0_8821C(x, v) \
(BIT_CLEAR_NETYPE0_8821C(x) | BIT_NETYPE0_8821C(v))
#define BIT_COUNTER_STS_EN_8821C BIT(13)
#define BIT_I2C_MAILBOX_EN_8821C BIT(12)
#define BIT_SHCUT_EN_8821C BIT(11)
#define BIT_32K_CAL_TMR_EN_8821C BIT(10)
#define BIT_MAC_SEC_EN_8821C BIT(9)
#define BIT_ENSWBCN_8821C BIT(8)
#define BIT_MACRXEN_8821C BIT(7)
#define BIT_MACTXEN_8821C BIT(6)
#define BIT_SCHEDULE_EN_8821C BIT(5)
#define BIT_PROTOCOL_EN_8821C BIT(4)
#define BIT_RXDMA_EN_8821C BIT(3)
#define BIT_TXDMA_EN_8821C BIT(2)
#define BIT_HCI_RXDMA_EN_8821C BIT(1)
#define BIT_HCI_TXDMA_EN_8821C BIT(0)
/* 2 REG_PG_SIZE_8821C */
#define BIT_SHIFT_DBG_FIFO_SEL_8821C 16
#define BIT_MASK_DBG_FIFO_SEL_8821C 0xff
#define BIT_DBG_FIFO_SEL_8821C(x) \
(((x) & BIT_MASK_DBG_FIFO_SEL_8821C) << BIT_SHIFT_DBG_FIFO_SEL_8821C)
#define BITS_DBG_FIFO_SEL_8821C \
(BIT_MASK_DBG_FIFO_SEL_8821C << BIT_SHIFT_DBG_FIFO_SEL_8821C)
#define BIT_CLEAR_DBG_FIFO_SEL_8821C(x) ((x) & (~BITS_DBG_FIFO_SEL_8821C))
#define BIT_GET_DBG_FIFO_SEL_8821C(x) \
(((x) >> BIT_SHIFT_DBG_FIFO_SEL_8821C) & BIT_MASK_DBG_FIFO_SEL_8821C)
#define BIT_SET_DBG_FIFO_SEL_8821C(x, v) \
(BIT_CLEAR_DBG_FIFO_SEL_8821C(x) | BIT_DBG_FIFO_SEL_8821C(v))
/* 2 REG_PKT_BUFF_ACCESS_CTRL_8821C */
#define BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8821C 0
#define BIT_MASK_PKT_BUFF_ACCESS_CTRL_8821C 0xff
#define BIT_PKT_BUFF_ACCESS_CTRL_8821C(x) \
(((x) & BIT_MASK_PKT_BUFF_ACCESS_CTRL_8821C) \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8821C)
#define BITS_PKT_BUFF_ACCESS_CTRL_8821C \
(BIT_MASK_PKT_BUFF_ACCESS_CTRL_8821C \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8821C)
#define BIT_CLEAR_PKT_BUFF_ACCESS_CTRL_8821C(x) \
((x) & (~BITS_PKT_BUFF_ACCESS_CTRL_8821C))
#define BIT_GET_PKT_BUFF_ACCESS_CTRL_8821C(x) \
(((x) >> BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8821C) & \
BIT_MASK_PKT_BUFF_ACCESS_CTRL_8821C)
#define BIT_SET_PKT_BUFF_ACCESS_CTRL_8821C(x, v) \
(BIT_CLEAR_PKT_BUFF_ACCESS_CTRL_8821C(x) | \
BIT_PKT_BUFF_ACCESS_CTRL_8821C(v))
/* 2 REG_TSF_CLK_STATE_8821C */
#define BIT_TSF_CLK_STABLE_8821C BIT(15)
/* 2 REG_TXDMA_PQ_MAP_8821C */
#define BIT_SHIFT_TXDMA_H2C_MAP_8821C 16
#define BIT_MASK_TXDMA_H2C_MAP_8821C 0x3
#define BIT_TXDMA_H2C_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_H2C_MAP_8821C) << BIT_SHIFT_TXDMA_H2C_MAP_8821C)
#define BITS_TXDMA_H2C_MAP_8821C \
(BIT_MASK_TXDMA_H2C_MAP_8821C << BIT_SHIFT_TXDMA_H2C_MAP_8821C)
#define BIT_CLEAR_TXDMA_H2C_MAP_8821C(x) ((x) & (~BITS_TXDMA_H2C_MAP_8821C))
#define BIT_GET_TXDMA_H2C_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_H2C_MAP_8821C) & BIT_MASK_TXDMA_H2C_MAP_8821C)
#define BIT_SET_TXDMA_H2C_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_H2C_MAP_8821C(x) | BIT_TXDMA_H2C_MAP_8821C(v))
#define BIT_SHIFT_TXDMA_HIQ_MAP_8821C 14
#define BIT_MASK_TXDMA_HIQ_MAP_8821C 0x3
#define BIT_TXDMA_HIQ_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP_8821C) << BIT_SHIFT_TXDMA_HIQ_MAP_8821C)
#define BITS_TXDMA_HIQ_MAP_8821C \
(BIT_MASK_TXDMA_HIQ_MAP_8821C << BIT_SHIFT_TXDMA_HIQ_MAP_8821C)
#define BIT_CLEAR_TXDMA_HIQ_MAP_8821C(x) ((x) & (~BITS_TXDMA_HIQ_MAP_8821C))
#define BIT_GET_TXDMA_HIQ_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP_8821C) & BIT_MASK_TXDMA_HIQ_MAP_8821C)
#define BIT_SET_TXDMA_HIQ_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP_8821C(x) | BIT_TXDMA_HIQ_MAP_8821C(v))
#define BIT_SHIFT_TXDMA_MGQ_MAP_8821C 12
#define BIT_MASK_TXDMA_MGQ_MAP_8821C 0x3
#define BIT_TXDMA_MGQ_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP_8821C) << BIT_SHIFT_TXDMA_MGQ_MAP_8821C)
#define BITS_TXDMA_MGQ_MAP_8821C \
(BIT_MASK_TXDMA_MGQ_MAP_8821C << BIT_SHIFT_TXDMA_MGQ_MAP_8821C)
#define BIT_CLEAR_TXDMA_MGQ_MAP_8821C(x) ((x) & (~BITS_TXDMA_MGQ_MAP_8821C))
#define BIT_GET_TXDMA_MGQ_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP_8821C) & BIT_MASK_TXDMA_MGQ_MAP_8821C)
#define BIT_SET_TXDMA_MGQ_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP_8821C(x) | BIT_TXDMA_MGQ_MAP_8821C(v))
#define BIT_SHIFT_TXDMA_BKQ_MAP_8821C 10
#define BIT_MASK_TXDMA_BKQ_MAP_8821C 0x3
#define BIT_TXDMA_BKQ_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP_8821C) << BIT_SHIFT_TXDMA_BKQ_MAP_8821C)
#define BITS_TXDMA_BKQ_MAP_8821C \
(BIT_MASK_TXDMA_BKQ_MAP_8821C << BIT_SHIFT_TXDMA_BKQ_MAP_8821C)
#define BIT_CLEAR_TXDMA_BKQ_MAP_8821C(x) ((x) & (~BITS_TXDMA_BKQ_MAP_8821C))
#define BIT_GET_TXDMA_BKQ_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP_8821C) & BIT_MASK_TXDMA_BKQ_MAP_8821C)
#define BIT_SET_TXDMA_BKQ_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP_8821C(x) | BIT_TXDMA_BKQ_MAP_8821C(v))
#define BIT_SHIFT_TXDMA_BEQ_MAP_8821C 8
#define BIT_MASK_TXDMA_BEQ_MAP_8821C 0x3
#define BIT_TXDMA_BEQ_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP_8821C) << BIT_SHIFT_TXDMA_BEQ_MAP_8821C)
#define BITS_TXDMA_BEQ_MAP_8821C \
(BIT_MASK_TXDMA_BEQ_MAP_8821C << BIT_SHIFT_TXDMA_BEQ_MAP_8821C)
#define BIT_CLEAR_TXDMA_BEQ_MAP_8821C(x) ((x) & (~BITS_TXDMA_BEQ_MAP_8821C))
#define BIT_GET_TXDMA_BEQ_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP_8821C) & BIT_MASK_TXDMA_BEQ_MAP_8821C)
#define BIT_SET_TXDMA_BEQ_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP_8821C(x) | BIT_TXDMA_BEQ_MAP_8821C(v))
#define BIT_SHIFT_TXDMA_VIQ_MAP_8821C 6
#define BIT_MASK_TXDMA_VIQ_MAP_8821C 0x3
#define BIT_TXDMA_VIQ_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP_8821C) << BIT_SHIFT_TXDMA_VIQ_MAP_8821C)
#define BITS_TXDMA_VIQ_MAP_8821C \
(BIT_MASK_TXDMA_VIQ_MAP_8821C << BIT_SHIFT_TXDMA_VIQ_MAP_8821C)
#define BIT_CLEAR_TXDMA_VIQ_MAP_8821C(x) ((x) & (~BITS_TXDMA_VIQ_MAP_8821C))
#define BIT_GET_TXDMA_VIQ_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP_8821C) & BIT_MASK_TXDMA_VIQ_MAP_8821C)
#define BIT_SET_TXDMA_VIQ_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP_8821C(x) | BIT_TXDMA_VIQ_MAP_8821C(v))
#define BIT_SHIFT_TXDMA_VOQ_MAP_8821C 4
#define BIT_MASK_TXDMA_VOQ_MAP_8821C 0x3
#define BIT_TXDMA_VOQ_MAP_8821C(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP_8821C) << BIT_SHIFT_TXDMA_VOQ_MAP_8821C)
#define BITS_TXDMA_VOQ_MAP_8821C \
(BIT_MASK_TXDMA_VOQ_MAP_8821C << BIT_SHIFT_TXDMA_VOQ_MAP_8821C)
#define BIT_CLEAR_TXDMA_VOQ_MAP_8821C(x) ((x) & (~BITS_TXDMA_VOQ_MAP_8821C))
#define BIT_GET_TXDMA_VOQ_MAP_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP_8821C) & BIT_MASK_TXDMA_VOQ_MAP_8821C)
#define BIT_SET_TXDMA_VOQ_MAP_8821C(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP_8821C(x) | BIT_TXDMA_VOQ_MAP_8821C(v))
#define BIT_RXDMA_AGG_EN_8821C BIT(2)
#define BIT_RXSHFT_EN_8821C BIT(1)
#define BIT_RXDMA_ARBBW_EN_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_TRXFF_BNDY_8821C */
#define BIT_SHIFT_RXFFOVFL_RSV_V2_8821C 8
#define BIT_MASK_RXFFOVFL_RSV_V2_8821C 0xf
#define BIT_RXFFOVFL_RSV_V2_8821C(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V2_8821C) \
<< BIT_SHIFT_RXFFOVFL_RSV_V2_8821C)
#define BITS_RXFFOVFL_RSV_V2_8821C \
(BIT_MASK_RXFFOVFL_RSV_V2_8821C << BIT_SHIFT_RXFFOVFL_RSV_V2_8821C)
#define BIT_CLEAR_RXFFOVFL_RSV_V2_8821C(x) ((x) & (~BITS_RXFFOVFL_RSV_V2_8821C))
#define BIT_GET_RXFFOVFL_RSV_V2_8821C(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V2_8821C) & \
BIT_MASK_RXFFOVFL_RSV_V2_8821C)
#define BIT_SET_RXFFOVFL_RSV_V2_8821C(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V2_8821C(x) | BIT_RXFFOVFL_RSV_V2_8821C(v))
/* 2 REG_PTA_I2C_MBOX_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_I2C_M_STATUS_8821C 8
#define BIT_MASK_I2C_M_STATUS_8821C 0xf
#define BIT_I2C_M_STATUS_8821C(x) \
(((x) & BIT_MASK_I2C_M_STATUS_8821C) << BIT_SHIFT_I2C_M_STATUS_8821C)
#define BITS_I2C_M_STATUS_8821C \
(BIT_MASK_I2C_M_STATUS_8821C << BIT_SHIFT_I2C_M_STATUS_8821C)
#define BIT_CLEAR_I2C_M_STATUS_8821C(x) ((x) & (~BITS_I2C_M_STATUS_8821C))
#define BIT_GET_I2C_M_STATUS_8821C(x) \
(((x) >> BIT_SHIFT_I2C_M_STATUS_8821C) & BIT_MASK_I2C_M_STATUS_8821C)
#define BIT_SET_I2C_M_STATUS_8821C(x, v) \
(BIT_CLEAR_I2C_M_STATUS_8821C(x) | BIT_I2C_M_STATUS_8821C(v))
#define BIT_SHIFT_I2C_M_BUS_GNT_FW_8821C 4
#define BIT_MASK_I2C_M_BUS_GNT_FW_8821C 0x7
#define BIT_I2C_M_BUS_GNT_FW_8821C(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT_FW_8821C) \
<< BIT_SHIFT_I2C_M_BUS_GNT_FW_8821C)
#define BITS_I2C_M_BUS_GNT_FW_8821C \
(BIT_MASK_I2C_M_BUS_GNT_FW_8821C << BIT_SHIFT_I2C_M_BUS_GNT_FW_8821C)
#define BIT_CLEAR_I2C_M_BUS_GNT_FW_8821C(x) \
((x) & (~BITS_I2C_M_BUS_GNT_FW_8821C))
#define BIT_GET_I2C_M_BUS_GNT_FW_8821C(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT_FW_8821C) & \
BIT_MASK_I2C_M_BUS_GNT_FW_8821C)
#define BIT_SET_I2C_M_BUS_GNT_FW_8821C(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT_FW_8821C(x) | BIT_I2C_M_BUS_GNT_FW_8821C(v))
#define BIT_I2C_M_GNT_FW_8821C BIT(3)
#define BIT_SHIFT_I2C_M_SPEED_8821C 1
#define BIT_MASK_I2C_M_SPEED_8821C 0x3
#define BIT_I2C_M_SPEED_8821C(x) \
(((x) & BIT_MASK_I2C_M_SPEED_8821C) << BIT_SHIFT_I2C_M_SPEED_8821C)
#define BITS_I2C_M_SPEED_8821C \
(BIT_MASK_I2C_M_SPEED_8821C << BIT_SHIFT_I2C_M_SPEED_8821C)
#define BIT_CLEAR_I2C_M_SPEED_8821C(x) ((x) & (~BITS_I2C_M_SPEED_8821C))
#define BIT_GET_I2C_M_SPEED_8821C(x) \
(((x) >> BIT_SHIFT_I2C_M_SPEED_8821C) & BIT_MASK_I2C_M_SPEED_8821C)
#define BIT_SET_I2C_M_SPEED_8821C(x, v) \
(BIT_CLEAR_I2C_M_SPEED_8821C(x) | BIT_I2C_M_SPEED_8821C(v))
#define BIT_I2C_M_UNLOCK_8821C BIT(0)
/* 2 REG_RXFF_BNDY_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_RXFF0_BNDY_V2_8821C 0
#define BIT_MASK_RXFF0_BNDY_V2_8821C 0x3ffff
#define BIT_RXFF0_BNDY_V2_8821C(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V2_8821C) << BIT_SHIFT_RXFF0_BNDY_V2_8821C)
#define BITS_RXFF0_BNDY_V2_8821C \
(BIT_MASK_RXFF0_BNDY_V2_8821C << BIT_SHIFT_RXFF0_BNDY_V2_8821C)
#define BIT_CLEAR_RXFF0_BNDY_V2_8821C(x) ((x) & (~BITS_RXFF0_BNDY_V2_8821C))
#define BIT_GET_RXFF0_BNDY_V2_8821C(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V2_8821C) & BIT_MASK_RXFF0_BNDY_V2_8821C)
#define BIT_SET_RXFF0_BNDY_V2_8821C(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V2_8821C(x) | BIT_RXFF0_BNDY_V2_8821C(v))
/* 2 REG_FE1IMR_8821C */
#define BIT_FS_RXDMA2_DONE_INT_EN_8821C BIT(28)
#define BIT_FS_RXDONE3_INT_EN_8821C BIT(27)
#define BIT_FS_RXDONE2_INT_EN_8821C BIT(26)
#define BIT_FS_RX_BCN_P4_INT_EN_8821C BIT(25)
#define BIT_FS_RX_BCN_P3_INT_EN_8821C BIT(24)
#define BIT_FS_RX_BCN_P2_INT_EN_8821C BIT(23)
#define BIT_FS_RX_BCN_P1_INT_EN_8821C BIT(22)
#define BIT_FS_RX_BCN_P0_INT_EN_8821C BIT(21)
#define BIT_FS_RX_UMD0_INT_EN_8821C BIT(20)
#define BIT_FS_RX_UMD1_INT_EN_8821C BIT(19)
#define BIT_FS_RX_BMD0_INT_EN_8821C BIT(18)
#define BIT_FS_RX_BMD1_INT_EN_8821C BIT(17)
#define BIT_FS_RXDONE_INT_EN_8821C BIT(16)
#define BIT_FS_WWLAN_INT_EN_8821C BIT(15)
#define BIT_FS_SOUND_DONE_INT_EN_8821C BIT(14)
#define BIT_FS_LP_STBY_INT_EN_8821C BIT(13)
#define BIT_FS_TRL_MTR_INT_EN_8821C BIT(12)
#define BIT_FS_BF1_PRETO_INT_EN_8821C BIT(11)
#define BIT_FS_BF0_PRETO_INT_EN_8821C BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_EN_8821C BIT(9)
#define BIT_FS_LTE_COEX_EN_8821C BIT(6)
#define BIT_FS_WLACTOFF_INT_EN_8821C BIT(5)
#define BIT_FS_WLACTON_INT_EN_8821C BIT(4)
#define BIT_FS_BTCMD_INT_EN_8821C BIT(3)
#define BIT_FS_REG_MAILBOX_TO_I2C_INT_EN_8821C BIT(2)
#define BIT_FS_TRPC_TO_INT_EN_V1_8821C BIT(1)
#define BIT_FS_RPC_O_T_INT_EN_V1_8821C BIT(0)
/* 2 REG_FE1ISR_8821C */
#define BIT_FS_RXDMA2_DONE_INT_8821C BIT(28)
#define BIT_FS_RXDONE3_INT_8821C BIT(27)
#define BIT_FS_RXDONE2_INT_8821C BIT(26)
#define BIT_FS_RX_BCN_P4_INT_8821C BIT(25)
#define BIT_FS_RX_BCN_P3_INT_8821C BIT(24)
#define BIT_FS_RX_BCN_P2_INT_8821C BIT(23)
#define BIT_FS_RX_BCN_P1_INT_8821C BIT(22)
#define BIT_FS_RX_BCN_P0_INT_8821C BIT(21)
#define BIT_FS_RX_UMD0_INT_8821C BIT(20)
#define BIT_FS_RX_UMD1_INT_8821C BIT(19)
#define BIT_FS_RX_BMD0_INT_8821C BIT(18)
#define BIT_FS_RX_BMD1_INT_8821C BIT(17)
#define BIT_FS_RXDONE_INT_8821C BIT(16)
#define BIT_FS_WWLAN_INT_8821C BIT(15)
#define BIT_FS_SOUND_DONE_INT_8821C BIT(14)
#define BIT_FS_LP_STBY_INT_8821C BIT(13)
#define BIT_FS_TRL_MTR_INT_8821C BIT(12)
#define BIT_FS_BF1_PRETO_INT_8821C BIT(11)
#define BIT_FS_BF0_PRETO_INT_8821C BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_8821C BIT(9)
#define BIT_FS_LTE_COEX_INT_8821C BIT(6)
#define BIT_FS_WLACTOFF_INT_8821C BIT(5)
#define BIT_FS_WLACTON_INT_8821C BIT(4)
#define BIT_FS_BCN_RX_INT_INT_8821C BIT(3)
#define BIT_FS_MAILBOX_TO_I2C_INT_8821C BIT(2)
#define BIT_FS_TRPC_TO_INT_8821C BIT(1)
#define BIT_FS_RPC_O_T_INT_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_CPWM_8821C */
#define BIT_CPWM_TOGGLING_8821C BIT(31)
#define BIT_SHIFT_CPWM_MOD_8821C 24
#define BIT_MASK_CPWM_MOD_8821C 0x7f
#define BIT_CPWM_MOD_8821C(x) \
(((x) & BIT_MASK_CPWM_MOD_8821C) << BIT_SHIFT_CPWM_MOD_8821C)
#define BITS_CPWM_MOD_8821C \
(BIT_MASK_CPWM_MOD_8821C << BIT_SHIFT_CPWM_MOD_8821C)
#define BIT_CLEAR_CPWM_MOD_8821C(x) ((x) & (~BITS_CPWM_MOD_8821C))
#define BIT_GET_CPWM_MOD_8821C(x) \
(((x) >> BIT_SHIFT_CPWM_MOD_8821C) & BIT_MASK_CPWM_MOD_8821C)
#define BIT_SET_CPWM_MOD_8821C(x, v) \
(BIT_CLEAR_CPWM_MOD_8821C(x) | BIT_CPWM_MOD_8821C(v))
/* 2 REG_FWIMR_8821C */
#define BIT_FS_TXBCNOK_MB7_INT_EN_8821C BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_EN_8821C BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_EN_8821C BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_EN_8821C BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_EN_8821C BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_EN_8821C BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_EN_8821C BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_EN_8821C BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_EN_8821C BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_EN_8821C BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_EN_8821C BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_EN_8821C BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_EN_8821C BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_EN_8821C BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_EN_8821C BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_EN_8821C BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_EN_8821C BIT(15)
#define BIT_SIFS_OVERSPEC_INT_EN_8821C BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_EN_8821C BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_EN_8821C BIT(12)
#define BIT_FS_DDMA1_LP_INT_EN_8821C BIT(11)
#define BIT_FS_DDMA1_HP_INT_EN_8821C BIT(10)
#define BIT_FS_DDMA0_LP_INT_EN_8821C BIT(9)
#define BIT_FS_DDMA0_HP_INT_EN_8821C BIT(8)
#define BIT_FS_TRXRPT_INT_EN_8821C BIT(7)
#define BIT_FS_C2H_W_READY_INT_EN_8821C BIT(6)
#define BIT_FS_HRCV_INT_EN_8821C BIT(5)
#define BIT_FS_H2CCMD_INT_EN_8821C BIT(4)
#define BIT_FS_TXPKTIN_INT_EN_8821C BIT(3)
#define BIT_FS_ERRORHDL_INT_EN_8821C BIT(2)
#define BIT_FS_TXCCX_INT_EN_8821C BIT(1)
#define BIT_FS_TXCLOSE_INT_EN_8821C BIT(0)
/* 2 REG_FWISR_8821C */
#define BIT_FS_TXBCNOK_MB7_INT_8821C BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_8821C BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_8821C BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_8821C BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_8821C BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_8821C BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_8821C BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_8821C BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_8821C BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_8821C BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_8821C BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_8821C BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_8821C BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_8821C BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_8821C BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_8821C BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_8821C BIT(15)
#define BIT_SIFS_OVERSPEC_INT_8821C BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_8821C BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_8821C BIT(12)
#define BIT_FS_DDMA1_LP_INT_8821C BIT(11)
#define BIT_FS_DDMA1_HP_INT_8821C BIT(10)
#define BIT_FS_DDMA0_LP_INT_8821C BIT(9)
#define BIT_FS_DDMA0_HP_INT_8821C BIT(8)
#define BIT_FS_TRXRPT_INT_8821C BIT(7)
#define BIT_FS_C2H_W_READY_INT_8821C BIT(6)
#define BIT_FS_HRCV_INT_8821C BIT(5)
#define BIT_FS_H2CCMD_INT_8821C BIT(4)
#define BIT_FS_TXPKTIN_INT_8821C BIT(3)
#define BIT_FS_ERRORHDL_INT_8821C BIT(2)
#define BIT_FS_TXCCX_INT_8821C BIT(1)
#define BIT_FS_TXCLOSE_INT_8821C BIT(0)
/* 2 REG_FTIMR_8821C */
#define BIT_PS_TIMER_C_EARLY_INT_EN_8821C BIT(23)
#define BIT_PS_TIMER_B_EARLY_INT_EN_8821C BIT(22)
#define BIT_PS_TIMER_A_EARLY_INT_EN_8821C BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_EN_8821C BIT(20)
#define BIT_PS_TIMER_C_INT_EN_8821C BIT(19)
#define BIT_PS_TIMER_B_INT_EN_8821C BIT(18)
#define BIT_PS_TIMER_A_INT_EN_8821C BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_EN_8821C BIT(16)
#define BIT_FS_PS_TIMEOUT2_EN_8821C BIT(15)
#define BIT_FS_PS_TIMEOUT1_EN_8821C BIT(14)
#define BIT_FS_PS_TIMEOUT0_EN_8821C BIT(13)
#define BIT_FS_GTINT8_EN_8821C BIT(8)
#define BIT_FS_GTINT7_EN_8821C BIT(7)
#define BIT_FS_GTINT6_EN_8821C BIT(6)
#define BIT_FS_GTINT5_EN_8821C BIT(5)
#define BIT_FS_GTINT4_EN_8821C BIT(4)
#define BIT_FS_GTINT3_EN_8821C BIT(3)
#define BIT_FS_GTINT2_EN_8821C BIT(2)
#define BIT_FS_GTINT1_EN_8821C BIT(1)
#define BIT_FS_GTINT0_EN_8821C BIT(0)
/* 2 REG_FTISR_8821C */
#define BIT_PS_TIMER_C_EARLY__INT_8821C BIT(23)
#define BIT_PS_TIMER_B_EARLY__INT_8821C BIT(22)
#define BIT_PS_TIMER_A_EARLY__INT_8821C BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_8821C BIT(20)
#define BIT_PS_TIMER_C_INT_8821C BIT(19)
#define BIT_PS_TIMER_B_INT_8821C BIT(18)
#define BIT_PS_TIMER_A_INT_8821C BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_8821C BIT(16)
#define BIT_FS_PS_TIMEOUT2_INT_8821C BIT(15)
#define BIT_FS_PS_TIMEOUT1_INT_8821C BIT(14)
#define BIT_FS_PS_TIMEOUT0_INT_8821C BIT(13)
#define BIT_FS_GTINT8_INT_8821C BIT(8)
#define BIT_FS_GTINT7_INT_8821C BIT(7)
#define BIT_FS_GTINT6_INT_8821C BIT(6)
#define BIT_FS_GTINT5_INT_8821C BIT(5)
#define BIT_FS_GTINT4_INT_8821C BIT(4)
#define BIT_FS_GTINT3_INT_8821C BIT(3)
#define BIT_FS_GTINT2_INT_8821C BIT(2)
#define BIT_FS_GTINT1_INT_8821C BIT(1)
#define BIT_FS_GTINT0_INT_8821C BIT(0)
/* 2 REG_PKTBUF_DBG_CTRL_8821C */
#define BIT_SHIFT_PKTBUF_WRITE_EN_8821C 24
#define BIT_MASK_PKTBUF_WRITE_EN_8821C 0xff
#define BIT_PKTBUF_WRITE_EN_8821C(x) \
(((x) & BIT_MASK_PKTBUF_WRITE_EN_8821C) \
<< BIT_SHIFT_PKTBUF_WRITE_EN_8821C)
#define BITS_PKTBUF_WRITE_EN_8821C \
(BIT_MASK_PKTBUF_WRITE_EN_8821C << BIT_SHIFT_PKTBUF_WRITE_EN_8821C)
#define BIT_CLEAR_PKTBUF_WRITE_EN_8821C(x) ((x) & (~BITS_PKTBUF_WRITE_EN_8821C))
#define BIT_GET_PKTBUF_WRITE_EN_8821C(x) \
(((x) >> BIT_SHIFT_PKTBUF_WRITE_EN_8821C) & \
BIT_MASK_PKTBUF_WRITE_EN_8821C)
#define BIT_SET_PKTBUF_WRITE_EN_8821C(x, v) \
(BIT_CLEAR_PKTBUF_WRITE_EN_8821C(x) | BIT_PKTBUF_WRITE_EN_8821C(v))
#define BIT_TXRPTBUF_DBG_8821C BIT(23)
/* 2 REG_NOT_VALID_8821C */
#define BIT_TXPKTBUF_DBG_V2_8821C BIT(20)
#define BIT_RXPKTBUF_DBG_8821C BIT(16)
#define BIT_SHIFT_PKTBUF_DBG_ADDR_8821C 0
#define BIT_MASK_PKTBUF_DBG_ADDR_8821C 0x1fff
#define BIT_PKTBUF_DBG_ADDR_8821C(x) \
(((x) & BIT_MASK_PKTBUF_DBG_ADDR_8821C) \
<< BIT_SHIFT_PKTBUF_DBG_ADDR_8821C)
#define BITS_PKTBUF_DBG_ADDR_8821C \
(BIT_MASK_PKTBUF_DBG_ADDR_8821C << BIT_SHIFT_PKTBUF_DBG_ADDR_8821C)
#define BIT_CLEAR_PKTBUF_DBG_ADDR_8821C(x) ((x) & (~BITS_PKTBUF_DBG_ADDR_8821C))
#define BIT_GET_PKTBUF_DBG_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_ADDR_8821C) & \
BIT_MASK_PKTBUF_DBG_ADDR_8821C)
#define BIT_SET_PKTBUF_DBG_ADDR_8821C(x, v) \
(BIT_CLEAR_PKTBUF_DBG_ADDR_8821C(x) | BIT_PKTBUF_DBG_ADDR_8821C(v))
/* 2 REG_PKTBUF_DBG_DATA_L_8821C */
#define BIT_SHIFT_PKTBUF_DBG_DATA_L_8821C 0
#define BIT_MASK_PKTBUF_DBG_DATA_L_8821C 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_L_8821C(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_L_8821C) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_L_8821C)
#define BITS_PKTBUF_DBG_DATA_L_8821C \
(BIT_MASK_PKTBUF_DBG_DATA_L_8821C << BIT_SHIFT_PKTBUF_DBG_DATA_L_8821C)
#define BIT_CLEAR_PKTBUF_DBG_DATA_L_8821C(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_L_8821C))
#define BIT_GET_PKTBUF_DBG_DATA_L_8821C(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_L_8821C) & \
BIT_MASK_PKTBUF_DBG_DATA_L_8821C)
#define BIT_SET_PKTBUF_DBG_DATA_L_8821C(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_L_8821C(x) | BIT_PKTBUF_DBG_DATA_L_8821C(v))
/* 2 REG_PKTBUF_DBG_DATA_H_8821C */
#define BIT_SHIFT_PKTBUF_DBG_DATA_H_8821C 0
#define BIT_MASK_PKTBUF_DBG_DATA_H_8821C 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_H_8821C(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_H_8821C) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_H_8821C)
#define BITS_PKTBUF_DBG_DATA_H_8821C \
(BIT_MASK_PKTBUF_DBG_DATA_H_8821C << BIT_SHIFT_PKTBUF_DBG_DATA_H_8821C)
#define BIT_CLEAR_PKTBUF_DBG_DATA_H_8821C(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_H_8821C))
#define BIT_GET_PKTBUF_DBG_DATA_H_8821C(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_H_8821C) & \
BIT_MASK_PKTBUF_DBG_DATA_H_8821C)
#define BIT_SET_PKTBUF_DBG_DATA_H_8821C(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_H_8821C(x) | BIT_PKTBUF_DBG_DATA_H_8821C(v))
/* 2 REG_CPWM2_8821C */
#define BIT_SHIFT_L0S_TO_RCVY_NUM_8821C 16
#define BIT_MASK_L0S_TO_RCVY_NUM_8821C 0xff
#define BIT_L0S_TO_RCVY_NUM_8821C(x) \
(((x) & BIT_MASK_L0S_TO_RCVY_NUM_8821C) \
<< BIT_SHIFT_L0S_TO_RCVY_NUM_8821C)
#define BITS_L0S_TO_RCVY_NUM_8821C \
(BIT_MASK_L0S_TO_RCVY_NUM_8821C << BIT_SHIFT_L0S_TO_RCVY_NUM_8821C)
#define BIT_CLEAR_L0S_TO_RCVY_NUM_8821C(x) ((x) & (~BITS_L0S_TO_RCVY_NUM_8821C))
#define BIT_GET_L0S_TO_RCVY_NUM_8821C(x) \
(((x) >> BIT_SHIFT_L0S_TO_RCVY_NUM_8821C) & \
BIT_MASK_L0S_TO_RCVY_NUM_8821C)
#define BIT_SET_L0S_TO_RCVY_NUM_8821C(x, v) \
(BIT_CLEAR_L0S_TO_RCVY_NUM_8821C(x) | BIT_L0S_TO_RCVY_NUM_8821C(v))
#define BIT_CPWM2_TOGGLING_8821C BIT(15)
#define BIT_SHIFT_CPWM2_MOD_8821C 0
#define BIT_MASK_CPWM2_MOD_8821C 0x7fff
#define BIT_CPWM2_MOD_8821C(x) \
(((x) & BIT_MASK_CPWM2_MOD_8821C) << BIT_SHIFT_CPWM2_MOD_8821C)
#define BITS_CPWM2_MOD_8821C \
(BIT_MASK_CPWM2_MOD_8821C << BIT_SHIFT_CPWM2_MOD_8821C)
#define BIT_CLEAR_CPWM2_MOD_8821C(x) ((x) & (~BITS_CPWM2_MOD_8821C))
#define BIT_GET_CPWM2_MOD_8821C(x) \
(((x) >> BIT_SHIFT_CPWM2_MOD_8821C) & BIT_MASK_CPWM2_MOD_8821C)
#define BIT_SET_CPWM2_MOD_8821C(x, v) \
(BIT_CLEAR_CPWM2_MOD_8821C(x) | BIT_CPWM2_MOD_8821C(v))
/* 2 REG_TC0_CTRL_8821C */
#define BIT_TC0INT_EN_8821C BIT(26)
#define BIT_TC0MODE_8821C BIT(25)
#define BIT_TC0EN_8821C BIT(24)
#define BIT_SHIFT_TC0DATA_8821C 0
#define BIT_MASK_TC0DATA_8821C 0xffffff
#define BIT_TC0DATA_8821C(x) \
(((x) & BIT_MASK_TC0DATA_8821C) << BIT_SHIFT_TC0DATA_8821C)
#define BITS_TC0DATA_8821C (BIT_MASK_TC0DATA_8821C << BIT_SHIFT_TC0DATA_8821C)
#define BIT_CLEAR_TC0DATA_8821C(x) ((x) & (~BITS_TC0DATA_8821C))
#define BIT_GET_TC0DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC0DATA_8821C) & BIT_MASK_TC0DATA_8821C)
#define BIT_SET_TC0DATA_8821C(x, v) \
(BIT_CLEAR_TC0DATA_8821C(x) | BIT_TC0DATA_8821C(v))
/* 2 REG_TC1_CTRL_8821C */
#define BIT_TC1INT_EN_8821C BIT(26)
#define BIT_TC1MODE_8821C BIT(25)
#define BIT_TC1EN_8821C BIT(24)
#define BIT_SHIFT_TC1DATA_8821C 0
#define BIT_MASK_TC1DATA_8821C 0xffffff
#define BIT_TC1DATA_8821C(x) \
(((x) & BIT_MASK_TC1DATA_8821C) << BIT_SHIFT_TC1DATA_8821C)
#define BITS_TC1DATA_8821C (BIT_MASK_TC1DATA_8821C << BIT_SHIFT_TC1DATA_8821C)
#define BIT_CLEAR_TC1DATA_8821C(x) ((x) & (~BITS_TC1DATA_8821C))
#define BIT_GET_TC1DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC1DATA_8821C) & BIT_MASK_TC1DATA_8821C)
#define BIT_SET_TC1DATA_8821C(x, v) \
(BIT_CLEAR_TC1DATA_8821C(x) | BIT_TC1DATA_8821C(v))
/* 2 REG_TC2_CTRL_8821C */
#define BIT_TC2INT_EN_8821C BIT(26)
#define BIT_TC2MODE_8821C BIT(25)
#define BIT_TC2EN_8821C BIT(24)
#define BIT_SHIFT_TC2DATA_8821C 0
#define BIT_MASK_TC2DATA_8821C 0xffffff
#define BIT_TC2DATA_8821C(x) \
(((x) & BIT_MASK_TC2DATA_8821C) << BIT_SHIFT_TC2DATA_8821C)
#define BITS_TC2DATA_8821C (BIT_MASK_TC2DATA_8821C << BIT_SHIFT_TC2DATA_8821C)
#define BIT_CLEAR_TC2DATA_8821C(x) ((x) & (~BITS_TC2DATA_8821C))
#define BIT_GET_TC2DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC2DATA_8821C) & BIT_MASK_TC2DATA_8821C)
#define BIT_SET_TC2DATA_8821C(x, v) \
(BIT_CLEAR_TC2DATA_8821C(x) | BIT_TC2DATA_8821C(v))
/* 2 REG_TC3_CTRL_8821C */
#define BIT_TC3INT_EN_8821C BIT(26)
#define BIT_TC3MODE_8821C BIT(25)
#define BIT_TC3EN_8821C BIT(24)
#define BIT_SHIFT_TC3DATA_8821C 0
#define BIT_MASK_TC3DATA_8821C 0xffffff
#define BIT_TC3DATA_8821C(x) \
(((x) & BIT_MASK_TC3DATA_8821C) << BIT_SHIFT_TC3DATA_8821C)
#define BITS_TC3DATA_8821C (BIT_MASK_TC3DATA_8821C << BIT_SHIFT_TC3DATA_8821C)
#define BIT_CLEAR_TC3DATA_8821C(x) ((x) & (~BITS_TC3DATA_8821C))
#define BIT_GET_TC3DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC3DATA_8821C) & BIT_MASK_TC3DATA_8821C)
#define BIT_SET_TC3DATA_8821C(x, v) \
(BIT_CLEAR_TC3DATA_8821C(x) | BIT_TC3DATA_8821C(v))
/* 2 REG_TC4_CTRL_8821C */
#define BIT_TC4INT_EN_8821C BIT(26)
#define BIT_TC4MODE_8821C BIT(25)
#define BIT_TC4EN_8821C BIT(24)
#define BIT_SHIFT_TC4DATA_8821C 0
#define BIT_MASK_TC4DATA_8821C 0xffffff
#define BIT_TC4DATA_8821C(x) \
(((x) & BIT_MASK_TC4DATA_8821C) << BIT_SHIFT_TC4DATA_8821C)
#define BITS_TC4DATA_8821C (BIT_MASK_TC4DATA_8821C << BIT_SHIFT_TC4DATA_8821C)
#define BIT_CLEAR_TC4DATA_8821C(x) ((x) & (~BITS_TC4DATA_8821C))
#define BIT_GET_TC4DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC4DATA_8821C) & BIT_MASK_TC4DATA_8821C)
#define BIT_SET_TC4DATA_8821C(x, v) \
(BIT_CLEAR_TC4DATA_8821C(x) | BIT_TC4DATA_8821C(v))
/* 2 REG_TCUNIT_BASE_8821C */
#define BIT_SHIFT_TCUNIT_BASE_8821C 0
#define BIT_MASK_TCUNIT_BASE_8821C 0x3fff
#define BIT_TCUNIT_BASE_8821C(x) \
(((x) & BIT_MASK_TCUNIT_BASE_8821C) << BIT_SHIFT_TCUNIT_BASE_8821C)
#define BITS_TCUNIT_BASE_8821C \
(BIT_MASK_TCUNIT_BASE_8821C << BIT_SHIFT_TCUNIT_BASE_8821C)
#define BIT_CLEAR_TCUNIT_BASE_8821C(x) ((x) & (~BITS_TCUNIT_BASE_8821C))
#define BIT_GET_TCUNIT_BASE_8821C(x) \
(((x) >> BIT_SHIFT_TCUNIT_BASE_8821C) & BIT_MASK_TCUNIT_BASE_8821C)
#define BIT_SET_TCUNIT_BASE_8821C(x, v) \
(BIT_CLEAR_TCUNIT_BASE_8821C(x) | BIT_TCUNIT_BASE_8821C(v))
/* 2 REG_TC5_CTRL_8821C */
#define BIT_TC5INT_EN_8821C BIT(26)
#define BIT_TC5MODE_8821C BIT(25)
#define BIT_TC5EN_8821C BIT(24)
#define BIT_SHIFT_TC5DATA_8821C 0
#define BIT_MASK_TC5DATA_8821C 0xffffff
#define BIT_TC5DATA_8821C(x) \
(((x) & BIT_MASK_TC5DATA_8821C) << BIT_SHIFT_TC5DATA_8821C)
#define BITS_TC5DATA_8821C (BIT_MASK_TC5DATA_8821C << BIT_SHIFT_TC5DATA_8821C)
#define BIT_CLEAR_TC5DATA_8821C(x) ((x) & (~BITS_TC5DATA_8821C))
#define BIT_GET_TC5DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC5DATA_8821C) & BIT_MASK_TC5DATA_8821C)
#define BIT_SET_TC5DATA_8821C(x, v) \
(BIT_CLEAR_TC5DATA_8821C(x) | BIT_TC5DATA_8821C(v))
/* 2 REG_TC6_CTRL_8821C */
#define BIT_TC6INT_EN_8821C BIT(26)
#define BIT_TC6MODE_8821C BIT(25)
#define BIT_TC6EN_8821C BIT(24)
#define BIT_SHIFT_TC6DATA_8821C 0
#define BIT_MASK_TC6DATA_8821C 0xffffff
#define BIT_TC6DATA_8821C(x) \
(((x) & BIT_MASK_TC6DATA_8821C) << BIT_SHIFT_TC6DATA_8821C)
#define BITS_TC6DATA_8821C (BIT_MASK_TC6DATA_8821C << BIT_SHIFT_TC6DATA_8821C)
#define BIT_CLEAR_TC6DATA_8821C(x) ((x) & (~BITS_TC6DATA_8821C))
#define BIT_GET_TC6DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC6DATA_8821C) & BIT_MASK_TC6DATA_8821C)
#define BIT_SET_TC6DATA_8821C(x, v) \
(BIT_CLEAR_TC6DATA_8821C(x) | BIT_TC6DATA_8821C(v))
/* 2 REG_MBIST_DRF_FAIL_8821C */
#define BIT_SHIFT_8051_MBIST_DRF_FAIL_8821C 26
#define BIT_MASK_8051_MBIST_DRF_FAIL_8821C 0x3f
#define BIT_8051_MBIST_DRF_FAIL_8821C(x) \
(((x) & BIT_MASK_8051_MBIST_DRF_FAIL_8821C) \
<< BIT_SHIFT_8051_MBIST_DRF_FAIL_8821C)
#define BITS_8051_MBIST_DRF_FAIL_8821C \
(BIT_MASK_8051_MBIST_DRF_FAIL_8821C \
<< BIT_SHIFT_8051_MBIST_DRF_FAIL_8821C)
#define BIT_CLEAR_8051_MBIST_DRF_FAIL_8821C(x) \
((x) & (~BITS_8051_MBIST_DRF_FAIL_8821C))
#define BIT_GET_8051_MBIST_DRF_FAIL_8821C(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DRF_FAIL_8821C) & \
BIT_MASK_8051_MBIST_DRF_FAIL_8821C)
#define BIT_SET_8051_MBIST_DRF_FAIL_8821C(x, v) \
(BIT_CLEAR_8051_MBIST_DRF_FAIL_8821C(x) | \
BIT_8051_MBIST_DRF_FAIL_8821C(v))
#define BIT_SHIFT_USB_MBIST_DRF_FAIL_8821C 24
#define BIT_MASK_USB_MBIST_DRF_FAIL_8821C 0x3
#define BIT_USB_MBIST_DRF_FAIL_8821C(x) \
(((x) & BIT_MASK_USB_MBIST_DRF_FAIL_8821C) \
<< BIT_SHIFT_USB_MBIST_DRF_FAIL_8821C)
#define BITS_USB_MBIST_DRF_FAIL_8821C \
(BIT_MASK_USB_MBIST_DRF_FAIL_8821C \
<< BIT_SHIFT_USB_MBIST_DRF_FAIL_8821C)
#define BIT_CLEAR_USB_MBIST_DRF_FAIL_8821C(x) \
((x) & (~BITS_USB_MBIST_DRF_FAIL_8821C))
#define BIT_GET_USB_MBIST_DRF_FAIL_8821C(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DRF_FAIL_8821C) & \
BIT_MASK_USB_MBIST_DRF_FAIL_8821C)
#define BIT_SET_USB_MBIST_DRF_FAIL_8821C(x, v) \
(BIT_CLEAR_USB_MBIST_DRF_FAIL_8821C(x) | \
BIT_USB_MBIST_DRF_FAIL_8821C(v))
#define BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8821C 18
#define BIT_MASK_PCIE_MBIST_DRF_FAIL_8821C 0x3f
#define BIT_PCIE_MBIST_DRF_FAIL_8821C(x) \
(((x) & BIT_MASK_PCIE_MBIST_DRF_FAIL_8821C) \
<< BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8821C)
#define BITS_PCIE_MBIST_DRF_FAIL_8821C \
(BIT_MASK_PCIE_MBIST_DRF_FAIL_8821C \
<< BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8821C)
#define BIT_CLEAR_PCIE_MBIST_DRF_FAIL_8821C(x) \
((x) & (~BITS_PCIE_MBIST_DRF_FAIL_8821C))
#define BIT_GET_PCIE_MBIST_DRF_FAIL_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8821C) & \
BIT_MASK_PCIE_MBIST_DRF_FAIL_8821C)
#define BIT_SET_PCIE_MBIST_DRF_FAIL_8821C(x, v) \
(BIT_CLEAR_PCIE_MBIST_DRF_FAIL_8821C(x) | \
BIT_PCIE_MBIST_DRF_FAIL_8821C(v))
#define BIT_SHIFT_MAC_MBIST_DRF_FAIL_8821C 0
#define BIT_MASK_MAC_MBIST_DRF_FAIL_8821C 0x3ffff
#define BIT_MAC_MBIST_DRF_FAIL_8821C(x) \
(((x) & BIT_MASK_MAC_MBIST_DRF_FAIL_8821C) \
<< BIT_SHIFT_MAC_MBIST_DRF_FAIL_8821C)
#define BITS_MAC_MBIST_DRF_FAIL_8821C \
(BIT_MASK_MAC_MBIST_DRF_FAIL_8821C \
<< BIT_SHIFT_MAC_MBIST_DRF_FAIL_8821C)
#define BIT_CLEAR_MAC_MBIST_DRF_FAIL_8821C(x) \
((x) & (~BITS_MAC_MBIST_DRF_FAIL_8821C))
#define BIT_GET_MAC_MBIST_DRF_FAIL_8821C(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DRF_FAIL_8821C) & \
BIT_MASK_MAC_MBIST_DRF_FAIL_8821C)
#define BIT_SET_MAC_MBIST_DRF_FAIL_8821C(x, v) \
(BIT_CLEAR_MAC_MBIST_DRF_FAIL_8821C(x) | \
BIT_MAC_MBIST_DRF_FAIL_8821C(v))
/* 2 REG_MBIST_START_PAUSE_8821C */
#define BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8821C 26
#define BIT_MASK_8051_MBIST_START_PAUSE_V1_8821C 0x3f
#define BIT_8051_MBIST_START_PAUSE_V1_8821C(x) \
(((x) & BIT_MASK_8051_MBIST_START_PAUSE_V1_8821C) \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8821C)
#define BITS_8051_MBIST_START_PAUSE_V1_8821C \
(BIT_MASK_8051_MBIST_START_PAUSE_V1_8821C \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8821C)
#define BIT_CLEAR_8051_MBIST_START_PAUSE_V1_8821C(x) \
((x) & (~BITS_8051_MBIST_START_PAUSE_V1_8821C))
#define BIT_GET_8051_MBIST_START_PAUSE_V1_8821C(x) \
(((x) >> BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8821C) & \
BIT_MASK_8051_MBIST_START_PAUSE_V1_8821C)
#define BIT_SET_8051_MBIST_START_PAUSE_V1_8821C(x, v) \
(BIT_CLEAR_8051_MBIST_START_PAUSE_V1_8821C(x) | \
BIT_8051_MBIST_START_PAUSE_V1_8821C(v))
#define BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8821C 24
#define BIT_MASK_USB_MBIST_START_PAUSE_V1_8821C 0x3
#define BIT_USB_MBIST_START_PAUSE_V1_8821C(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE_V1_8821C) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8821C)
#define BITS_USB_MBIST_START_PAUSE_V1_8821C \
(BIT_MASK_USB_MBIST_START_PAUSE_V1_8821C \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8821C)
#define BIT_CLEAR_USB_MBIST_START_PAUSE_V1_8821C(x) \
((x) & (~BITS_USB_MBIST_START_PAUSE_V1_8821C))
#define BIT_GET_USB_MBIST_START_PAUSE_V1_8821C(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8821C) & \
BIT_MASK_USB_MBIST_START_PAUSE_V1_8821C)
#define BIT_SET_USB_MBIST_START_PAUSE_V1_8821C(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE_V1_8821C(x) | \
BIT_USB_MBIST_START_PAUSE_V1_8821C(v))
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8821C 18
#define BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8821C 0x3f
#define BIT_PCIE_MBIST_START_PAUSE_V1_8821C(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8821C) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8821C)
#define BITS_PCIE_MBIST_START_PAUSE_V1_8821C \
(BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8821C \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8821C)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE_V1_8821C(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE_V1_8821C))
#define BIT_GET_PCIE_MBIST_START_PAUSE_V1_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8821C) & \
BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8821C)
#define BIT_SET_PCIE_MBIST_START_PAUSE_V1_8821C(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE_V1_8821C(x) | \
BIT_PCIE_MBIST_START_PAUSE_V1_8821C(v))
#define BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8821C 0
#define BIT_MASK_MAC_MBIST_START_PAUSE_V1_8821C 0x3ffff
#define BIT_MAC_MBIST_START_PAUSE_V1_8821C(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE_V1_8821C) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8821C)
#define BITS_MAC_MBIST_START_PAUSE_V1_8821C \
(BIT_MASK_MAC_MBIST_START_PAUSE_V1_8821C \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8821C)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE_V1_8821C(x) \
((x) & (~BITS_MAC_MBIST_START_PAUSE_V1_8821C))
#define BIT_GET_MAC_MBIST_START_PAUSE_V1_8821C(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8821C) & \
BIT_MASK_MAC_MBIST_START_PAUSE_V1_8821C)
#define BIT_SET_MAC_MBIST_START_PAUSE_V1_8821C(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE_V1_8821C(x) | \
BIT_MAC_MBIST_START_PAUSE_V1_8821C(v))
/* 2 REG_MBIST_DONE_8821C */
#define BIT_SHIFT_8051_MBIST_DONE_V1_8821C 26
#define BIT_MASK_8051_MBIST_DONE_V1_8821C 0x3f
#define BIT_8051_MBIST_DONE_V1_8821C(x) \
(((x) & BIT_MASK_8051_MBIST_DONE_V1_8821C) \
<< BIT_SHIFT_8051_MBIST_DONE_V1_8821C)
#define BITS_8051_MBIST_DONE_V1_8821C \
(BIT_MASK_8051_MBIST_DONE_V1_8821C \
<< BIT_SHIFT_8051_MBIST_DONE_V1_8821C)
#define BIT_CLEAR_8051_MBIST_DONE_V1_8821C(x) \
((x) & (~BITS_8051_MBIST_DONE_V1_8821C))
#define BIT_GET_8051_MBIST_DONE_V1_8821C(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DONE_V1_8821C) & \
BIT_MASK_8051_MBIST_DONE_V1_8821C)
#define BIT_SET_8051_MBIST_DONE_V1_8821C(x, v) \
(BIT_CLEAR_8051_MBIST_DONE_V1_8821C(x) | \
BIT_8051_MBIST_DONE_V1_8821C(v))
#define BIT_SHIFT_USB_MBIST_DONE_V1_8821C 24
#define BIT_MASK_USB_MBIST_DONE_V1_8821C 0x3
#define BIT_USB_MBIST_DONE_V1_8821C(x) \
(((x) & BIT_MASK_USB_MBIST_DONE_V1_8821C) \
<< BIT_SHIFT_USB_MBIST_DONE_V1_8821C)
#define BITS_USB_MBIST_DONE_V1_8821C \
(BIT_MASK_USB_MBIST_DONE_V1_8821C << BIT_SHIFT_USB_MBIST_DONE_V1_8821C)
#define BIT_CLEAR_USB_MBIST_DONE_V1_8821C(x) \
((x) & (~BITS_USB_MBIST_DONE_V1_8821C))
#define BIT_GET_USB_MBIST_DONE_V1_8821C(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE_V1_8821C) & \
BIT_MASK_USB_MBIST_DONE_V1_8821C)
#define BIT_SET_USB_MBIST_DONE_V1_8821C(x, v) \
(BIT_CLEAR_USB_MBIST_DONE_V1_8821C(x) | BIT_USB_MBIST_DONE_V1_8821C(v))
#define BIT_SHIFT_PCIE_MBIST_DONE_V1_8821C 18
#define BIT_MASK_PCIE_MBIST_DONE_V1_8821C 0x3f
#define BIT_PCIE_MBIST_DONE_V1_8821C(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE_V1_8821C) \
<< BIT_SHIFT_PCIE_MBIST_DONE_V1_8821C)
#define BITS_PCIE_MBIST_DONE_V1_8821C \
(BIT_MASK_PCIE_MBIST_DONE_V1_8821C \
<< BIT_SHIFT_PCIE_MBIST_DONE_V1_8821C)
#define BIT_CLEAR_PCIE_MBIST_DONE_V1_8821C(x) \
((x) & (~BITS_PCIE_MBIST_DONE_V1_8821C))
#define BIT_GET_PCIE_MBIST_DONE_V1_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE_V1_8821C) & \
BIT_MASK_PCIE_MBIST_DONE_V1_8821C)
#define BIT_SET_PCIE_MBIST_DONE_V1_8821C(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE_V1_8821C(x) | \
BIT_PCIE_MBIST_DONE_V1_8821C(v))
#define BIT_SHIFT_MAC_MBIST_DONE_V1_8821C 0
#define BIT_MASK_MAC_MBIST_DONE_V1_8821C 0x3ffff
#define BIT_MAC_MBIST_DONE_V1_8821C(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE_V1_8821C) \
<< BIT_SHIFT_MAC_MBIST_DONE_V1_8821C)
#define BITS_MAC_MBIST_DONE_V1_8821C \
(BIT_MASK_MAC_MBIST_DONE_V1_8821C << BIT_SHIFT_MAC_MBIST_DONE_V1_8821C)
#define BIT_CLEAR_MAC_MBIST_DONE_V1_8821C(x) \
((x) & (~BITS_MAC_MBIST_DONE_V1_8821C))
#define BIT_GET_MAC_MBIST_DONE_V1_8821C(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE_V1_8821C) & \
BIT_MASK_MAC_MBIST_DONE_V1_8821C)
#define BIT_SET_MAC_MBIST_DONE_V1_8821C(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE_V1_8821C(x) | BIT_MAC_MBIST_DONE_V1_8821C(v))
/* 2 REG_MBIST_READ_BIST_RPT_8821C */
#define BIT_SHIFT_MBIST_READ_BIST_RPT_8821C 0
#define BIT_MASK_MBIST_READ_BIST_RPT_8821C 0xffffffffL
#define BIT_MBIST_READ_BIST_RPT_8821C(x) \
(((x) & BIT_MASK_MBIST_READ_BIST_RPT_8821C) \
<< BIT_SHIFT_MBIST_READ_BIST_RPT_8821C)
#define BITS_MBIST_READ_BIST_RPT_8821C \
(BIT_MASK_MBIST_READ_BIST_RPT_8821C \
<< BIT_SHIFT_MBIST_READ_BIST_RPT_8821C)
#define BIT_CLEAR_MBIST_READ_BIST_RPT_8821C(x) \
((x) & (~BITS_MBIST_READ_BIST_RPT_8821C))
#define BIT_GET_MBIST_READ_BIST_RPT_8821C(x) \
(((x) >> BIT_SHIFT_MBIST_READ_BIST_RPT_8821C) & \
BIT_MASK_MBIST_READ_BIST_RPT_8821C)
#define BIT_SET_MBIST_READ_BIST_RPT_8821C(x, v) \
(BIT_CLEAR_MBIST_READ_BIST_RPT_8821C(x) | \
BIT_MBIST_READ_BIST_RPT_8821C(v))
/* 2 REG_AES_DECRPT_DATA_8821C */
#define BIT_SHIFT_IPS_CFG_ADDR_8821C 0
#define BIT_MASK_IPS_CFG_ADDR_8821C 0xff
#define BIT_IPS_CFG_ADDR_8821C(x) \
(((x) & BIT_MASK_IPS_CFG_ADDR_8821C) << BIT_SHIFT_IPS_CFG_ADDR_8821C)
#define BITS_IPS_CFG_ADDR_8821C \
(BIT_MASK_IPS_CFG_ADDR_8821C << BIT_SHIFT_IPS_CFG_ADDR_8821C)
#define BIT_CLEAR_IPS_CFG_ADDR_8821C(x) ((x) & (~BITS_IPS_CFG_ADDR_8821C))
#define BIT_GET_IPS_CFG_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_IPS_CFG_ADDR_8821C) & BIT_MASK_IPS_CFG_ADDR_8821C)
#define BIT_SET_IPS_CFG_ADDR_8821C(x, v) \
(BIT_CLEAR_IPS_CFG_ADDR_8821C(x) | BIT_IPS_CFG_ADDR_8821C(v))
/* 2 REG_AES_DECRPT_CFG_8821C */
#define BIT_SHIFT_IPS_CFG_DATA_8821C 0
#define BIT_MASK_IPS_CFG_DATA_8821C 0xffffffffL
#define BIT_IPS_CFG_DATA_8821C(x) \
(((x) & BIT_MASK_IPS_CFG_DATA_8821C) << BIT_SHIFT_IPS_CFG_DATA_8821C)
#define BITS_IPS_CFG_DATA_8821C \
(BIT_MASK_IPS_CFG_DATA_8821C << BIT_SHIFT_IPS_CFG_DATA_8821C)
#define BIT_CLEAR_IPS_CFG_DATA_8821C(x) ((x) & (~BITS_IPS_CFG_DATA_8821C))
#define BIT_GET_IPS_CFG_DATA_8821C(x) \
(((x) >> BIT_SHIFT_IPS_CFG_DATA_8821C) & BIT_MASK_IPS_CFG_DATA_8821C)
#define BIT_SET_IPS_CFG_DATA_8821C(x, v) \
(BIT_CLEAR_IPS_CFG_DATA_8821C(x) | BIT_IPS_CFG_DATA_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_TMETER_8821C */
#define BIT_TEMP_VALID_8821C BIT(31)
#define BIT_SHIFT_TEMP_VALUE_8821C 24
#define BIT_MASK_TEMP_VALUE_8821C 0x3f
#define BIT_TEMP_VALUE_8821C(x) \
(((x) & BIT_MASK_TEMP_VALUE_8821C) << BIT_SHIFT_TEMP_VALUE_8821C)
#define BITS_TEMP_VALUE_8821C \
(BIT_MASK_TEMP_VALUE_8821C << BIT_SHIFT_TEMP_VALUE_8821C)
#define BIT_CLEAR_TEMP_VALUE_8821C(x) ((x) & (~BITS_TEMP_VALUE_8821C))
#define BIT_GET_TEMP_VALUE_8821C(x) \
(((x) >> BIT_SHIFT_TEMP_VALUE_8821C) & BIT_MASK_TEMP_VALUE_8821C)
#define BIT_SET_TEMP_VALUE_8821C(x, v) \
(BIT_CLEAR_TEMP_VALUE_8821C(x) | BIT_TEMP_VALUE_8821C(v))
#define BIT_SHIFT_REG_TMETER_TIMER_8821C 8
#define BIT_MASK_REG_TMETER_TIMER_8821C 0xfff
#define BIT_REG_TMETER_TIMER_8821C(x) \
(((x) & BIT_MASK_REG_TMETER_TIMER_8821C) \
<< BIT_SHIFT_REG_TMETER_TIMER_8821C)
#define BITS_REG_TMETER_TIMER_8821C \
(BIT_MASK_REG_TMETER_TIMER_8821C << BIT_SHIFT_REG_TMETER_TIMER_8821C)
#define BIT_CLEAR_REG_TMETER_TIMER_8821C(x) \
((x) & (~BITS_REG_TMETER_TIMER_8821C))
#define BIT_GET_REG_TMETER_TIMER_8821C(x) \
(((x) >> BIT_SHIFT_REG_TMETER_TIMER_8821C) & \
BIT_MASK_REG_TMETER_TIMER_8821C)
#define BIT_SET_REG_TMETER_TIMER_8821C(x, v) \
(BIT_CLEAR_REG_TMETER_TIMER_8821C(x) | BIT_REG_TMETER_TIMER_8821C(v))
#define BIT_SHIFT_REG_TEMP_DELTA_8821C 2
#define BIT_MASK_REG_TEMP_DELTA_8821C 0x3f
#define BIT_REG_TEMP_DELTA_8821C(x) \
(((x) & BIT_MASK_REG_TEMP_DELTA_8821C) \
<< BIT_SHIFT_REG_TEMP_DELTA_8821C)
#define BITS_REG_TEMP_DELTA_8821C \
(BIT_MASK_REG_TEMP_DELTA_8821C << BIT_SHIFT_REG_TEMP_DELTA_8821C)
#define BIT_CLEAR_REG_TEMP_DELTA_8821C(x) ((x) & (~BITS_REG_TEMP_DELTA_8821C))
#define BIT_GET_REG_TEMP_DELTA_8821C(x) \
(((x) >> BIT_SHIFT_REG_TEMP_DELTA_8821C) & \
BIT_MASK_REG_TEMP_DELTA_8821C)
#define BIT_SET_REG_TEMP_DELTA_8821C(x, v) \
(BIT_CLEAR_REG_TEMP_DELTA_8821C(x) | BIT_REG_TEMP_DELTA_8821C(v))
#define BIT_REG_TMETER_EN_8821C BIT(0)
/* 2 REG_OSC_32K_CTRL_8821C */
#define BIT_SHIFT_OSC_32K_CLKGEN_0_8821C 16
#define BIT_MASK_OSC_32K_CLKGEN_0_8821C 0xffff
#define BIT_OSC_32K_CLKGEN_0_8821C(x) \
(((x) & BIT_MASK_OSC_32K_CLKGEN_0_8821C) \
<< BIT_SHIFT_OSC_32K_CLKGEN_0_8821C)
#define BITS_OSC_32K_CLKGEN_0_8821C \
(BIT_MASK_OSC_32K_CLKGEN_0_8821C << BIT_SHIFT_OSC_32K_CLKGEN_0_8821C)
#define BIT_CLEAR_OSC_32K_CLKGEN_0_8821C(x) \
((x) & (~BITS_OSC_32K_CLKGEN_0_8821C))
#define BIT_GET_OSC_32K_CLKGEN_0_8821C(x) \
(((x) >> BIT_SHIFT_OSC_32K_CLKGEN_0_8821C) & \
BIT_MASK_OSC_32K_CLKGEN_0_8821C)
#define BIT_SET_OSC_32K_CLKGEN_0_8821C(x, v) \
(BIT_CLEAR_OSC_32K_CLKGEN_0_8821C(x) | BIT_OSC_32K_CLKGEN_0_8821C(v))
#define BIT_SHIFT_OSC_32K_RES_COMP_8821C 4
#define BIT_MASK_OSC_32K_RES_COMP_8821C 0x3
#define BIT_OSC_32K_RES_COMP_8821C(x) \
(((x) & BIT_MASK_OSC_32K_RES_COMP_8821C) \
<< BIT_SHIFT_OSC_32K_RES_COMP_8821C)
#define BITS_OSC_32K_RES_COMP_8821C \
(BIT_MASK_OSC_32K_RES_COMP_8821C << BIT_SHIFT_OSC_32K_RES_COMP_8821C)
#define BIT_CLEAR_OSC_32K_RES_COMP_8821C(x) \
((x) & (~BITS_OSC_32K_RES_COMP_8821C))
#define BIT_GET_OSC_32K_RES_COMP_8821C(x) \
(((x) >> BIT_SHIFT_OSC_32K_RES_COMP_8821C) & \
BIT_MASK_OSC_32K_RES_COMP_8821C)
#define BIT_SET_OSC_32K_RES_COMP_8821C(x, v) \
(BIT_CLEAR_OSC_32K_RES_COMP_8821C(x) | BIT_OSC_32K_RES_COMP_8821C(v))
#define BIT_OSC_32K_OUT_SEL_8821C BIT(3)
#define BIT_ISO_WL_2_OSC_32K_8821C BIT(1)
#define BIT_POW_CKGEN_8821C BIT(0)
/* 2 REG_32K_CAL_REG1_8821C */
#define BIT_CAL_32K_REG_WR_8821C BIT(31)
#define BIT_CAL_32K_DBG_SEL_8821C BIT(22)
#define BIT_SHIFT_CAL_32K_REG_ADDR_8821C 16
#define BIT_MASK_CAL_32K_REG_ADDR_8821C 0x3f
#define BIT_CAL_32K_REG_ADDR_8821C(x) \
(((x) & BIT_MASK_CAL_32K_REG_ADDR_8821C) \
<< BIT_SHIFT_CAL_32K_REG_ADDR_8821C)
#define BITS_CAL_32K_REG_ADDR_8821C \
(BIT_MASK_CAL_32K_REG_ADDR_8821C << BIT_SHIFT_CAL_32K_REG_ADDR_8821C)
#define BIT_CLEAR_CAL_32K_REG_ADDR_8821C(x) \
((x) & (~BITS_CAL_32K_REG_ADDR_8821C))
#define BIT_GET_CAL_32K_REG_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_ADDR_8821C) & \
BIT_MASK_CAL_32K_REG_ADDR_8821C)
#define BIT_SET_CAL_32K_REG_ADDR_8821C(x, v) \
(BIT_CLEAR_CAL_32K_REG_ADDR_8821C(x) | BIT_CAL_32K_REG_ADDR_8821C(v))
#define BIT_SHIFT_CAL_32K_REG_DATA_8821C 0
#define BIT_MASK_CAL_32K_REG_DATA_8821C 0xffff
#define BIT_CAL_32K_REG_DATA_8821C(x) \
(((x) & BIT_MASK_CAL_32K_REG_DATA_8821C) \
<< BIT_SHIFT_CAL_32K_REG_DATA_8821C)
#define BITS_CAL_32K_REG_DATA_8821C \
(BIT_MASK_CAL_32K_REG_DATA_8821C << BIT_SHIFT_CAL_32K_REG_DATA_8821C)
#define BIT_CLEAR_CAL_32K_REG_DATA_8821C(x) \
((x) & (~BITS_CAL_32K_REG_DATA_8821C))
#define BIT_GET_CAL_32K_REG_DATA_8821C(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_DATA_8821C) & \
BIT_MASK_CAL_32K_REG_DATA_8821C)
#define BIT_SET_CAL_32K_REG_DATA_8821C(x, v) \
(BIT_CLEAR_CAL_32K_REG_DATA_8821C(x) | BIT_CAL_32K_REG_DATA_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_C2HEVT_8821C */
#define BIT_SHIFT_C2HEVT_MSG_V1_8821C 0
#define BIT_MASK_C2HEVT_MSG_V1_8821C 0xffffffffL
#define BIT_C2HEVT_MSG_V1_8821C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_V1_8821C) << BIT_SHIFT_C2HEVT_MSG_V1_8821C)
#define BITS_C2HEVT_MSG_V1_8821C \
(BIT_MASK_C2HEVT_MSG_V1_8821C << BIT_SHIFT_C2HEVT_MSG_V1_8821C)
#define BIT_CLEAR_C2HEVT_MSG_V1_8821C(x) ((x) & (~BITS_C2HEVT_MSG_V1_8821C))
#define BIT_GET_C2HEVT_MSG_V1_8821C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_V1_8821C) & BIT_MASK_C2HEVT_MSG_V1_8821C)
#define BIT_SET_C2HEVT_MSG_V1_8821C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_V1_8821C(x) | BIT_C2HEVT_MSG_V1_8821C(v))
/* 2 REG_C2HEVT_1_8821C */
#define BIT_SHIFT_C2HEVT_MSG_1_8821C 0
#define BIT_MASK_C2HEVT_MSG_1_8821C 0xffffffffL
#define BIT_C2HEVT_MSG_1_8821C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_1_8821C) << BIT_SHIFT_C2HEVT_MSG_1_8821C)
#define BITS_C2HEVT_MSG_1_8821C \
(BIT_MASK_C2HEVT_MSG_1_8821C << BIT_SHIFT_C2HEVT_MSG_1_8821C)
#define BIT_CLEAR_C2HEVT_MSG_1_8821C(x) ((x) & (~BITS_C2HEVT_MSG_1_8821C))
#define BIT_GET_C2HEVT_MSG_1_8821C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_1_8821C) & BIT_MASK_C2HEVT_MSG_1_8821C)
#define BIT_SET_C2HEVT_MSG_1_8821C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_1_8821C(x) | BIT_C2HEVT_MSG_1_8821C(v))
/* 2 REG_C2HEVT_2_8821C */
#define BIT_SHIFT_C2HEVT_MSG_2_8821C 0
#define BIT_MASK_C2HEVT_MSG_2_8821C 0xffffffffL
#define BIT_C2HEVT_MSG_2_8821C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_2_8821C) << BIT_SHIFT_C2HEVT_MSG_2_8821C)
#define BITS_C2HEVT_MSG_2_8821C \
(BIT_MASK_C2HEVT_MSG_2_8821C << BIT_SHIFT_C2HEVT_MSG_2_8821C)
#define BIT_CLEAR_C2HEVT_MSG_2_8821C(x) ((x) & (~BITS_C2HEVT_MSG_2_8821C))
#define BIT_GET_C2HEVT_MSG_2_8821C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_2_8821C) & BIT_MASK_C2HEVT_MSG_2_8821C)
#define BIT_SET_C2HEVT_MSG_2_8821C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_2_8821C(x) | BIT_C2HEVT_MSG_2_8821C(v))
/* 2 REG_C2HEVT_3_8821C */
#define BIT_SHIFT_C2HEVT_MSG_3_8821C 0
#define BIT_MASK_C2HEVT_MSG_3_8821C 0xffffffffL
#define BIT_C2HEVT_MSG_3_8821C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_3_8821C) << BIT_SHIFT_C2HEVT_MSG_3_8821C)
#define BITS_C2HEVT_MSG_3_8821C \
(BIT_MASK_C2HEVT_MSG_3_8821C << BIT_SHIFT_C2HEVT_MSG_3_8821C)
#define BIT_CLEAR_C2HEVT_MSG_3_8821C(x) ((x) & (~BITS_C2HEVT_MSG_3_8821C))
#define BIT_GET_C2HEVT_MSG_3_8821C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_3_8821C) & BIT_MASK_C2HEVT_MSG_3_8821C)
#define BIT_SET_C2HEVT_MSG_3_8821C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_3_8821C(x) | BIT_C2HEVT_MSG_3_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SW_DEFINED_PAGE1_8821C */
#define BIT_SHIFT_SW_DEFINED_PAGE1_V1_8821C 0
#define BIT_MASK_SW_DEFINED_PAGE1_V1_8821C 0xffffffffL
#define BIT_SW_DEFINED_PAGE1_V1_8821C(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1_V1_8821C) \
<< BIT_SHIFT_SW_DEFINED_PAGE1_V1_8821C)
#define BITS_SW_DEFINED_PAGE1_V1_8821C \
(BIT_MASK_SW_DEFINED_PAGE1_V1_8821C \
<< BIT_SHIFT_SW_DEFINED_PAGE1_V1_8821C)
#define BIT_CLEAR_SW_DEFINED_PAGE1_V1_8821C(x) \
((x) & (~BITS_SW_DEFINED_PAGE1_V1_8821C))
#define BIT_GET_SW_DEFINED_PAGE1_V1_8821C(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1_V1_8821C) & \
BIT_MASK_SW_DEFINED_PAGE1_V1_8821C)
#define BIT_SET_SW_DEFINED_PAGE1_V1_8821C(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1_V1_8821C(x) | \
BIT_SW_DEFINED_PAGE1_V1_8821C(v))
/* 2 REG_SW_DEFINED_PAGE2_8821C */
#define BIT_SHIFT_SW_DEFINED_PAGE2_8821C 0
#define BIT_MASK_SW_DEFINED_PAGE2_8821C 0xffffffffL
#define BIT_SW_DEFINED_PAGE2_8821C(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE2_8821C) \
<< BIT_SHIFT_SW_DEFINED_PAGE2_8821C)
#define BITS_SW_DEFINED_PAGE2_8821C \
(BIT_MASK_SW_DEFINED_PAGE2_8821C << BIT_SHIFT_SW_DEFINED_PAGE2_8821C)
#define BIT_CLEAR_SW_DEFINED_PAGE2_8821C(x) \
((x) & (~BITS_SW_DEFINED_PAGE2_8821C))
#define BIT_GET_SW_DEFINED_PAGE2_8821C(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE2_8821C) & \
BIT_MASK_SW_DEFINED_PAGE2_8821C)
#define BIT_SET_SW_DEFINED_PAGE2_8821C(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE2_8821C(x) | BIT_SW_DEFINED_PAGE2_8821C(v))
/* 2 REG_MCUTST_I_8821C */
#define BIT_SHIFT_MCUDMSG_I_8821C 0
#define BIT_MASK_MCUDMSG_I_8821C 0xffffffffL
#define BIT_MCUDMSG_I_8821C(x) \
(((x) & BIT_MASK_MCUDMSG_I_8821C) << BIT_SHIFT_MCUDMSG_I_8821C)
#define BITS_MCUDMSG_I_8821C \
(BIT_MASK_MCUDMSG_I_8821C << BIT_SHIFT_MCUDMSG_I_8821C)
#define BIT_CLEAR_MCUDMSG_I_8821C(x) ((x) & (~BITS_MCUDMSG_I_8821C))
#define BIT_GET_MCUDMSG_I_8821C(x) \
(((x) >> BIT_SHIFT_MCUDMSG_I_8821C) & BIT_MASK_MCUDMSG_I_8821C)
#define BIT_SET_MCUDMSG_I_8821C(x, v) \
(BIT_CLEAR_MCUDMSG_I_8821C(x) | BIT_MCUDMSG_I_8821C(v))
/* 2 REG_MCUTST_II_8821C */
#define BIT_SHIFT_MCUDMSG_II_8821C 0
#define BIT_MASK_MCUDMSG_II_8821C 0xffffffffL
#define BIT_MCUDMSG_II_8821C(x) \
(((x) & BIT_MASK_MCUDMSG_II_8821C) << BIT_SHIFT_MCUDMSG_II_8821C)
#define BITS_MCUDMSG_II_8821C \
(BIT_MASK_MCUDMSG_II_8821C << BIT_SHIFT_MCUDMSG_II_8821C)
#define BIT_CLEAR_MCUDMSG_II_8821C(x) ((x) & (~BITS_MCUDMSG_II_8821C))
#define BIT_GET_MCUDMSG_II_8821C(x) \
(((x) >> BIT_SHIFT_MCUDMSG_II_8821C) & BIT_MASK_MCUDMSG_II_8821C)
#define BIT_SET_MCUDMSG_II_8821C(x, v) \
(BIT_CLEAR_MCUDMSG_II_8821C(x) | BIT_MCUDMSG_II_8821C(v))
/* 2 REG_FMETHR_8821C */
#define BIT_FMSG_INT_8821C BIT(31)
#define BIT_SHIFT_FW_MSG_8821C 0
#define BIT_MASK_FW_MSG_8821C 0xffffffffL
#define BIT_FW_MSG_8821C(x) \
(((x) & BIT_MASK_FW_MSG_8821C) << BIT_SHIFT_FW_MSG_8821C)
#define BITS_FW_MSG_8821C (BIT_MASK_FW_MSG_8821C << BIT_SHIFT_FW_MSG_8821C)
#define BIT_CLEAR_FW_MSG_8821C(x) ((x) & (~BITS_FW_MSG_8821C))
#define BIT_GET_FW_MSG_8821C(x) \
(((x) >> BIT_SHIFT_FW_MSG_8821C) & BIT_MASK_FW_MSG_8821C)
#define BIT_SET_FW_MSG_8821C(x, v) \
(BIT_CLEAR_FW_MSG_8821C(x) | BIT_FW_MSG_8821C(v))
/* 2 REG_HMETFR_8821C */
#define BIT_SHIFT_HRCV_MSG_8821C 24
#define BIT_MASK_HRCV_MSG_8821C 0xff
#define BIT_HRCV_MSG_8821C(x) \
(((x) & BIT_MASK_HRCV_MSG_8821C) << BIT_SHIFT_HRCV_MSG_8821C)
#define BITS_HRCV_MSG_8821C \
(BIT_MASK_HRCV_MSG_8821C << BIT_SHIFT_HRCV_MSG_8821C)
#define BIT_CLEAR_HRCV_MSG_8821C(x) ((x) & (~BITS_HRCV_MSG_8821C))
#define BIT_GET_HRCV_MSG_8821C(x) \
(((x) >> BIT_SHIFT_HRCV_MSG_8821C) & BIT_MASK_HRCV_MSG_8821C)
#define BIT_SET_HRCV_MSG_8821C(x, v) \
(BIT_CLEAR_HRCV_MSG_8821C(x) | BIT_HRCV_MSG_8821C(v))
#define BIT_INT_BOX3_8821C BIT(3)
#define BIT_INT_BOX2_8821C BIT(2)
#define BIT_INT_BOX1_8821C BIT(1)
#define BIT_INT_BOX0_8821C BIT(0)
/* 2 REG_HMEBOX0_8821C */
#define BIT_SHIFT_HOST_MSG_0_8821C 0
#define BIT_MASK_HOST_MSG_0_8821C 0xffffffffL
#define BIT_HOST_MSG_0_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_0_8821C) << BIT_SHIFT_HOST_MSG_0_8821C)
#define BITS_HOST_MSG_0_8821C \
(BIT_MASK_HOST_MSG_0_8821C << BIT_SHIFT_HOST_MSG_0_8821C)
#define BIT_CLEAR_HOST_MSG_0_8821C(x) ((x) & (~BITS_HOST_MSG_0_8821C))
#define BIT_GET_HOST_MSG_0_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_0_8821C) & BIT_MASK_HOST_MSG_0_8821C)
#define BIT_SET_HOST_MSG_0_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_0_8821C(x) | BIT_HOST_MSG_0_8821C(v))
/* 2 REG_HMEBOX1_8821C */
#define BIT_SHIFT_HOST_MSG_1_8821C 0
#define BIT_MASK_HOST_MSG_1_8821C 0xffffffffL
#define BIT_HOST_MSG_1_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_1_8821C) << BIT_SHIFT_HOST_MSG_1_8821C)
#define BITS_HOST_MSG_1_8821C \
(BIT_MASK_HOST_MSG_1_8821C << BIT_SHIFT_HOST_MSG_1_8821C)
#define BIT_CLEAR_HOST_MSG_1_8821C(x) ((x) & (~BITS_HOST_MSG_1_8821C))
#define BIT_GET_HOST_MSG_1_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_1_8821C) & BIT_MASK_HOST_MSG_1_8821C)
#define BIT_SET_HOST_MSG_1_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_1_8821C(x) | BIT_HOST_MSG_1_8821C(v))
/* 2 REG_HMEBOX2_8821C */
#define BIT_SHIFT_HOST_MSG_2_8821C 0
#define BIT_MASK_HOST_MSG_2_8821C 0xffffffffL
#define BIT_HOST_MSG_2_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_2_8821C) << BIT_SHIFT_HOST_MSG_2_8821C)
#define BITS_HOST_MSG_2_8821C \
(BIT_MASK_HOST_MSG_2_8821C << BIT_SHIFT_HOST_MSG_2_8821C)
#define BIT_CLEAR_HOST_MSG_2_8821C(x) ((x) & (~BITS_HOST_MSG_2_8821C))
#define BIT_GET_HOST_MSG_2_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_2_8821C) & BIT_MASK_HOST_MSG_2_8821C)
#define BIT_SET_HOST_MSG_2_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_2_8821C(x) | BIT_HOST_MSG_2_8821C(v))
/* 2 REG_HMEBOX3_8821C */
#define BIT_SHIFT_HOST_MSG_3_8821C 0
#define BIT_MASK_HOST_MSG_3_8821C 0xffffffffL
#define BIT_HOST_MSG_3_8821C(x) \
(((x) & BIT_MASK_HOST_MSG_3_8821C) << BIT_SHIFT_HOST_MSG_3_8821C)
#define BITS_HOST_MSG_3_8821C \
(BIT_MASK_HOST_MSG_3_8821C << BIT_SHIFT_HOST_MSG_3_8821C)
#define BIT_CLEAR_HOST_MSG_3_8821C(x) ((x) & (~BITS_HOST_MSG_3_8821C))
#define BIT_GET_HOST_MSG_3_8821C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_3_8821C) & BIT_MASK_HOST_MSG_3_8821C)
#define BIT_SET_HOST_MSG_3_8821C(x, v) \
(BIT_CLEAR_HOST_MSG_3_8821C(x) | BIT_HOST_MSG_3_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_BB_ACCESS_CTRL_8821C */
#define BIT_SHIFT_BB_WRITE_READ_8821C 30
#define BIT_MASK_BB_WRITE_READ_8821C 0x3
#define BIT_BB_WRITE_READ_8821C(x) \
(((x) & BIT_MASK_BB_WRITE_READ_8821C) << BIT_SHIFT_BB_WRITE_READ_8821C)
#define BITS_BB_WRITE_READ_8821C \
(BIT_MASK_BB_WRITE_READ_8821C << BIT_SHIFT_BB_WRITE_READ_8821C)
#define BIT_CLEAR_BB_WRITE_READ_8821C(x) ((x) & (~BITS_BB_WRITE_READ_8821C))
#define BIT_GET_BB_WRITE_READ_8821C(x) \
(((x) >> BIT_SHIFT_BB_WRITE_READ_8821C) & BIT_MASK_BB_WRITE_READ_8821C)
#define BIT_SET_BB_WRITE_READ_8821C(x, v) \
(BIT_CLEAR_BB_WRITE_READ_8821C(x) | BIT_BB_WRITE_READ_8821C(v))
#define BIT_SHIFT_BB_WRITE_EN_8821C 12
#define BIT_MASK_BB_WRITE_EN_8821C 0xf
#define BIT_BB_WRITE_EN_8821C(x) \
(((x) & BIT_MASK_BB_WRITE_EN_8821C) << BIT_SHIFT_BB_WRITE_EN_8821C)
#define BITS_BB_WRITE_EN_8821C \
(BIT_MASK_BB_WRITE_EN_8821C << BIT_SHIFT_BB_WRITE_EN_8821C)
#define BIT_CLEAR_BB_WRITE_EN_8821C(x) ((x) & (~BITS_BB_WRITE_EN_8821C))
#define BIT_GET_BB_WRITE_EN_8821C(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN_8821C) & BIT_MASK_BB_WRITE_EN_8821C)
#define BIT_SET_BB_WRITE_EN_8821C(x, v) \
(BIT_CLEAR_BB_WRITE_EN_8821C(x) | BIT_BB_WRITE_EN_8821C(v))
#define BIT_SHIFT_BB_ADDR_8821C 2
#define BIT_MASK_BB_ADDR_8821C 0x1ff
#define BIT_BB_ADDR_8821C(x) \
(((x) & BIT_MASK_BB_ADDR_8821C) << BIT_SHIFT_BB_ADDR_8821C)
#define BITS_BB_ADDR_8821C (BIT_MASK_BB_ADDR_8821C << BIT_SHIFT_BB_ADDR_8821C)
#define BIT_CLEAR_BB_ADDR_8821C(x) ((x) & (~BITS_BB_ADDR_8821C))
#define BIT_GET_BB_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_BB_ADDR_8821C) & BIT_MASK_BB_ADDR_8821C)
#define BIT_SET_BB_ADDR_8821C(x, v) \
(BIT_CLEAR_BB_ADDR_8821C(x) | BIT_BB_ADDR_8821C(v))
#define BIT_BB_ERRACC_8821C BIT(0)
/* 2 REG_BB_ACCESS_DATA_8821C */
#define BIT_SHIFT_BB_DATA_8821C 0
#define BIT_MASK_BB_DATA_8821C 0xffffffffL
#define BIT_BB_DATA_8821C(x) \
(((x) & BIT_MASK_BB_DATA_8821C) << BIT_SHIFT_BB_DATA_8821C)
#define BITS_BB_DATA_8821C (BIT_MASK_BB_DATA_8821C << BIT_SHIFT_BB_DATA_8821C)
#define BIT_CLEAR_BB_DATA_8821C(x) ((x) & (~BITS_BB_DATA_8821C))
#define BIT_GET_BB_DATA_8821C(x) \
(((x) >> BIT_SHIFT_BB_DATA_8821C) & BIT_MASK_BB_DATA_8821C)
#define BIT_SET_BB_DATA_8821C(x, v) \
(BIT_CLEAR_BB_DATA_8821C(x) | BIT_BB_DATA_8821C(v))
/* 2 REG_HMEBOX_E0_8821C */
#define BIT_SHIFT_HMEBOX_E0_8821C 0
#define BIT_MASK_HMEBOX_E0_8821C 0xffffffffL
#define BIT_HMEBOX_E0_8821C(x) \
(((x) & BIT_MASK_HMEBOX_E0_8821C) << BIT_SHIFT_HMEBOX_E0_8821C)
#define BITS_HMEBOX_E0_8821C \
(BIT_MASK_HMEBOX_E0_8821C << BIT_SHIFT_HMEBOX_E0_8821C)
#define BIT_CLEAR_HMEBOX_E0_8821C(x) ((x) & (~BITS_HMEBOX_E0_8821C))
#define BIT_GET_HMEBOX_E0_8821C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E0_8821C) & BIT_MASK_HMEBOX_E0_8821C)
#define BIT_SET_HMEBOX_E0_8821C(x, v) \
(BIT_CLEAR_HMEBOX_E0_8821C(x) | BIT_HMEBOX_E0_8821C(v))
/* 2 REG_HMEBOX_E1_8821C */
#define BIT_SHIFT_HMEBOX_E1_8821C 0
#define BIT_MASK_HMEBOX_E1_8821C 0xffffffffL
#define BIT_HMEBOX_E1_8821C(x) \
(((x) & BIT_MASK_HMEBOX_E1_8821C) << BIT_SHIFT_HMEBOX_E1_8821C)
#define BITS_HMEBOX_E1_8821C \
(BIT_MASK_HMEBOX_E1_8821C << BIT_SHIFT_HMEBOX_E1_8821C)
#define BIT_CLEAR_HMEBOX_E1_8821C(x) ((x) & (~BITS_HMEBOX_E1_8821C))
#define BIT_GET_HMEBOX_E1_8821C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E1_8821C) & BIT_MASK_HMEBOX_E1_8821C)
#define BIT_SET_HMEBOX_E1_8821C(x, v) \
(BIT_CLEAR_HMEBOX_E1_8821C(x) | BIT_HMEBOX_E1_8821C(v))
/* 2 REG_HMEBOX_E2_8821C */
#define BIT_SHIFT_HMEBOX_E2_8821C 0
#define BIT_MASK_HMEBOX_E2_8821C 0xffffffffL
#define BIT_HMEBOX_E2_8821C(x) \
(((x) & BIT_MASK_HMEBOX_E2_8821C) << BIT_SHIFT_HMEBOX_E2_8821C)
#define BITS_HMEBOX_E2_8821C \
(BIT_MASK_HMEBOX_E2_8821C << BIT_SHIFT_HMEBOX_E2_8821C)
#define BIT_CLEAR_HMEBOX_E2_8821C(x) ((x) & (~BITS_HMEBOX_E2_8821C))
#define BIT_GET_HMEBOX_E2_8821C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E2_8821C) & BIT_MASK_HMEBOX_E2_8821C)
#define BIT_SET_HMEBOX_E2_8821C(x, v) \
(BIT_CLEAR_HMEBOX_E2_8821C(x) | BIT_HMEBOX_E2_8821C(v))
/* 2 REG_HMEBOX_E3_8821C */
#define BIT_SHIFT_HMEBOX_E3_8821C 0
#define BIT_MASK_HMEBOX_E3_8821C 0xffffffffL
#define BIT_HMEBOX_E3_8821C(x) \
(((x) & BIT_MASK_HMEBOX_E3_8821C) << BIT_SHIFT_HMEBOX_E3_8821C)
#define BITS_HMEBOX_E3_8821C \
(BIT_MASK_HMEBOX_E3_8821C << BIT_SHIFT_HMEBOX_E3_8821C)
#define BIT_CLEAR_HMEBOX_E3_8821C(x) ((x) & (~BITS_HMEBOX_E3_8821C))
#define BIT_GET_HMEBOX_E3_8821C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E3_8821C) & BIT_MASK_HMEBOX_E3_8821C)
#define BIT_SET_HMEBOX_E3_8821C(x, v) \
(BIT_CLEAR_HMEBOX_E3_8821C(x) | BIT_HMEBOX_E3_8821C(v))
/* 2 REG_CR_EXT_8821C */
#define BIT_SHIFT_PHY_REQ_DELAY_8821C 24
#define BIT_MASK_PHY_REQ_DELAY_8821C 0xf
#define BIT_PHY_REQ_DELAY_8821C(x) \
(((x) & BIT_MASK_PHY_REQ_DELAY_8821C) << BIT_SHIFT_PHY_REQ_DELAY_8821C)
#define BITS_PHY_REQ_DELAY_8821C \
(BIT_MASK_PHY_REQ_DELAY_8821C << BIT_SHIFT_PHY_REQ_DELAY_8821C)
#define BIT_CLEAR_PHY_REQ_DELAY_8821C(x) ((x) & (~BITS_PHY_REQ_DELAY_8821C))
#define BIT_GET_PHY_REQ_DELAY_8821C(x) \
(((x) >> BIT_SHIFT_PHY_REQ_DELAY_8821C) & BIT_MASK_PHY_REQ_DELAY_8821C)
#define BIT_SET_PHY_REQ_DELAY_8821C(x, v) \
(BIT_CLEAR_PHY_REQ_DELAY_8821C(x) | BIT_PHY_REQ_DELAY_8821C(v))
/* 2 REG_NOT_VALID_8821C */
#define BIT_SPD_DOWN_8821C BIT(16)
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_NETYPE4_8821C 4
#define BIT_MASK_NETYPE4_8821C 0x3
#define BIT_NETYPE4_8821C(x) \
(((x) & BIT_MASK_NETYPE4_8821C) << BIT_SHIFT_NETYPE4_8821C)
#define BITS_NETYPE4_8821C (BIT_MASK_NETYPE4_8821C << BIT_SHIFT_NETYPE4_8821C)
#define BIT_CLEAR_NETYPE4_8821C(x) ((x) & (~BITS_NETYPE4_8821C))
#define BIT_GET_NETYPE4_8821C(x) \
(((x) >> BIT_SHIFT_NETYPE4_8821C) & BIT_MASK_NETYPE4_8821C)
#define BIT_SET_NETYPE4_8821C(x, v) \
(BIT_CLEAR_NETYPE4_8821C(x) | BIT_NETYPE4_8821C(v))
#define BIT_SHIFT_NETYPE3_8821C 2
#define BIT_MASK_NETYPE3_8821C 0x3
#define BIT_NETYPE3_8821C(x) \
(((x) & BIT_MASK_NETYPE3_8821C) << BIT_SHIFT_NETYPE3_8821C)
#define BITS_NETYPE3_8821C (BIT_MASK_NETYPE3_8821C << BIT_SHIFT_NETYPE3_8821C)
#define BIT_CLEAR_NETYPE3_8821C(x) ((x) & (~BITS_NETYPE3_8821C))
#define BIT_GET_NETYPE3_8821C(x) \
(((x) >> BIT_SHIFT_NETYPE3_8821C) & BIT_MASK_NETYPE3_8821C)
#define BIT_SET_NETYPE3_8821C(x, v) \
(BIT_CLEAR_NETYPE3_8821C(x) | BIT_NETYPE3_8821C(v))
#define BIT_SHIFT_NETYPE2_8821C 0
#define BIT_MASK_NETYPE2_8821C 0x3
#define BIT_NETYPE2_8821C(x) \
(((x) & BIT_MASK_NETYPE2_8821C) << BIT_SHIFT_NETYPE2_8821C)
#define BITS_NETYPE2_8821C (BIT_MASK_NETYPE2_8821C << BIT_SHIFT_NETYPE2_8821C)
#define BIT_CLEAR_NETYPE2_8821C(x) ((x) & (~BITS_NETYPE2_8821C))
#define BIT_GET_NETYPE2_8821C(x) \
(((x) >> BIT_SHIFT_NETYPE2_8821C) & BIT_MASK_NETYPE2_8821C)
#define BIT_SET_NETYPE2_8821C(x, v) \
(BIT_CLEAR_NETYPE2_8821C(x) | BIT_NETYPE2_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_FWFF_8821C */
#define BIT_SHIFT_PKTNUM_TH_V1_8821C 24
#define BIT_MASK_PKTNUM_TH_V1_8821C 0xff
#define BIT_PKTNUM_TH_V1_8821C(x) \
(((x) & BIT_MASK_PKTNUM_TH_V1_8821C) << BIT_SHIFT_PKTNUM_TH_V1_8821C)
#define BITS_PKTNUM_TH_V1_8821C \
(BIT_MASK_PKTNUM_TH_V1_8821C << BIT_SHIFT_PKTNUM_TH_V1_8821C)
#define BIT_CLEAR_PKTNUM_TH_V1_8821C(x) ((x) & (~BITS_PKTNUM_TH_V1_8821C))
#define BIT_GET_PKTNUM_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V1_8821C) & BIT_MASK_PKTNUM_TH_V1_8821C)
#define BIT_SET_PKTNUM_TH_V1_8821C(x, v) \
(BIT_CLEAR_PKTNUM_TH_V1_8821C(x) | BIT_PKTNUM_TH_V1_8821C(v))
#define BIT_SHIFT_TIMER_TH_8821C 16
#define BIT_MASK_TIMER_TH_8821C 0xff
#define BIT_TIMER_TH_8821C(x) \
(((x) & BIT_MASK_TIMER_TH_8821C) << BIT_SHIFT_TIMER_TH_8821C)
#define BITS_TIMER_TH_8821C \
(BIT_MASK_TIMER_TH_8821C << BIT_SHIFT_TIMER_TH_8821C)
#define BIT_CLEAR_TIMER_TH_8821C(x) ((x) & (~BITS_TIMER_TH_8821C))
#define BIT_GET_TIMER_TH_8821C(x) \
(((x) >> BIT_SHIFT_TIMER_TH_8821C) & BIT_MASK_TIMER_TH_8821C)
#define BIT_SET_TIMER_TH_8821C(x, v) \
(BIT_CLEAR_TIMER_TH_8821C(x) | BIT_TIMER_TH_8821C(v))
#define BIT_SHIFT_RXPKT1ENADDR_8821C 0
#define BIT_MASK_RXPKT1ENADDR_8821C 0xffff
#define BIT_RXPKT1ENADDR_8821C(x) \
(((x) & BIT_MASK_RXPKT1ENADDR_8821C) << BIT_SHIFT_RXPKT1ENADDR_8821C)
#define BITS_RXPKT1ENADDR_8821C \
(BIT_MASK_RXPKT1ENADDR_8821C << BIT_SHIFT_RXPKT1ENADDR_8821C)
#define BIT_CLEAR_RXPKT1ENADDR_8821C(x) ((x) & (~BITS_RXPKT1ENADDR_8821C))
#define BIT_GET_RXPKT1ENADDR_8821C(x) \
(((x) >> BIT_SHIFT_RXPKT1ENADDR_8821C) & BIT_MASK_RXPKT1ENADDR_8821C)
#define BIT_SET_RXPKT1ENADDR_8821C(x, v) \
(BIT_CLEAR_RXPKT1ENADDR_8821C(x) | BIT_RXPKT1ENADDR_8821C(v))
/* 2 REG_RXFF_PTR_V1_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_RXFF0_RDPTR_V2_8821C 0
#define BIT_MASK_RXFF0_RDPTR_V2_8821C 0x3ffff
#define BIT_RXFF0_RDPTR_V2_8821C(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V2_8821C) \
<< BIT_SHIFT_RXFF0_RDPTR_V2_8821C)
#define BITS_RXFF0_RDPTR_V2_8821C \
(BIT_MASK_RXFF0_RDPTR_V2_8821C << BIT_SHIFT_RXFF0_RDPTR_V2_8821C)
#define BIT_CLEAR_RXFF0_RDPTR_V2_8821C(x) ((x) & (~BITS_RXFF0_RDPTR_V2_8821C))
#define BIT_GET_RXFF0_RDPTR_V2_8821C(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V2_8821C) & \
BIT_MASK_RXFF0_RDPTR_V2_8821C)
#define BIT_SET_RXFF0_RDPTR_V2_8821C(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V2_8821C(x) | BIT_RXFF0_RDPTR_V2_8821C(v))
/* 2 REG_RXFF_WTR_V1_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_RXFF0_WTPTR_V2_8821C 0
#define BIT_MASK_RXFF0_WTPTR_V2_8821C 0x3ffff
#define BIT_RXFF0_WTPTR_V2_8821C(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V2_8821C) \
<< BIT_SHIFT_RXFF0_WTPTR_V2_8821C)
#define BITS_RXFF0_WTPTR_V2_8821C \
(BIT_MASK_RXFF0_WTPTR_V2_8821C << BIT_SHIFT_RXFF0_WTPTR_V2_8821C)
#define BIT_CLEAR_RXFF0_WTPTR_V2_8821C(x) ((x) & (~BITS_RXFF0_WTPTR_V2_8821C))
#define BIT_GET_RXFF0_WTPTR_V2_8821C(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V2_8821C) & \
BIT_MASK_RXFF0_WTPTR_V2_8821C)
#define BIT_SET_RXFF0_WTPTR_V2_8821C(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V2_8821C(x) | BIT_RXFF0_WTPTR_V2_8821C(v))
/* 2 REG_FE2IMR_8821C */
#define BIT__FE4ISR__IND_MSK_8821C BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_EN_8821C BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_EN_8821C BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_EN_8821C BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_EN_8821C BIT(25)
#define BIT_FS_TXSC_VODONE_INT_EN_8821C BIT(24)
#define BIT_FS_ATIM_MB7_INT_EN_8821C BIT(23)
#define BIT_FS_ATIM_MB6_INT_EN_8821C BIT(22)
#define BIT_FS_ATIM_MB5_INT_EN_8821C BIT(21)
#define BIT_FS_ATIM_MB4_INT_EN_8821C BIT(20)
#define BIT_FS_ATIM_MB3_INT_EN_8821C BIT(19)
#define BIT_FS_ATIM_MB2_INT_EN_8821C BIT(18)
#define BIT_FS_ATIM_MB1_INT_EN_8821C BIT(17)
#define BIT_FS_ATIM_MB0_INT_EN_8821C BIT(16)
#define BIT_FS_TBTT4INT_EN_8821C BIT(11)
#define BIT_FS_TBTT3INT_EN_8821C BIT(10)
#define BIT_FS_TBTT2INT_EN_8821C BIT(9)
#define BIT_FS_TBTT1INT_EN_8821C BIT(8)
#define BIT_FS_TBTT0_MB7INT_EN_8821C BIT(7)
#define BIT_FS_TBTT0_MB6INT_EN_8821C BIT(6)
#define BIT_FS_TBTT0_MB5INT_EN_8821C BIT(5)
#define BIT_FS_TBTT0_MB4INT_EN_8821C BIT(4)
#define BIT_FS_TBTT0_MB3INT_EN_8821C BIT(3)
#define BIT_FS_TBTT0_MB2INT_EN_8821C BIT(2)
#define BIT_FS_TBTT0_MB1INT_EN_8821C BIT(1)
#define BIT_FS_TBTT0_INT_EN_8821C BIT(0)
/* 2 REG_FE2ISR_8821C */
#define BIT__FE4ISR__IND_INT_8821C BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_8821C BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_8821C BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_8821C BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_8821C BIT(25)
#define BIT_FS_TXSC_VODONE_INT_8821C BIT(24)
#define BIT_FS_ATIM_MB7_INT_8821C BIT(23)
#define BIT_FS_ATIM_MB6_INT_8821C BIT(22)
#define BIT_FS_ATIM_MB5_INT_8821C BIT(21)
#define BIT_FS_ATIM_MB4_INT_8821C BIT(20)
#define BIT_FS_ATIM_MB3_INT_8821C BIT(19)
#define BIT_FS_ATIM_MB2_INT_8821C BIT(18)
#define BIT_FS_ATIM_MB1_INT_8821C BIT(17)
#define BIT_FS_ATIM_MB0_INT_8821C BIT(16)
#define BIT_FS_TBTT4INT_8821C BIT(11)
#define BIT_FS_TBTT3INT_8821C BIT(10)
#define BIT_FS_TBTT2INT_8821C BIT(9)
#define BIT_FS_TBTT1INT_8821C BIT(8)
#define BIT_FS_TBTT0_MB7INT_8821C BIT(7)
#define BIT_FS_TBTT0_MB6INT_8821C BIT(6)
#define BIT_FS_TBTT0_MB5INT_8821C BIT(5)
#define BIT_FS_TBTT0_MB4INT_8821C BIT(4)
#define BIT_FS_TBTT0_MB3INT_8821C BIT(3)
#define BIT_FS_TBTT0_MB2INT_8821C BIT(2)
#define BIT_FS_TBTT0_MB1INT_8821C BIT(1)
#define BIT_FS_TBTT0_INT_8821C BIT(0)
/* 2 REG_FE3IMR_8821C */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT__EN_8821C BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT__EN_8821C BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT__EN_8821C BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT__EN_8821C BIT(28)
#define BIT_FS_BCNDMA4_INT_EN_8821C BIT(27)
#define BIT_FS_BCNDMA3_INT_EN_8821C BIT(26)
#define BIT_FS_BCNDMA2_INT_EN_8821C BIT(25)
#define BIT_FS_BCNDMA1_INT_EN_8821C BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_EN_8821C BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_EN_8821C BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_EN_8821C BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_EN_8821C BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_EN_8821C BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_EN_8821C BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_EN_8821C BIT(17)
#define BIT_FS_BCNDMA0_INT_EN_8821C BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT__EN_8821C BIT(15)
#define BIT_FS_BCNERLY4_INT_EN_8821C BIT(11)
#define BIT_FS_BCNERLY3_INT_EN_8821C BIT(10)
#define BIT_FS_BCNERLY2_INT_EN_8821C BIT(9)
#define BIT_FS_BCNERLY1_INT_EN_8821C BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_EN_8821C BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_EN_8821C BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_EN_8821C BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_EN_8821C BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_EN_8821C BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_EN_8821C BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_EN_8821C BIT(1)
#define BIT_FS_BCNERLY0_INT_EN_8821C BIT(0)
/* 2 REG_FE3ISR_8821C */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT_8821C BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT_8821C BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT_8821C BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT_8821C BIT(28)
#define BIT_FS_BCNDMA4_INT_8821C BIT(27)
#define BIT_FS_BCNDMA3_INT_8821C BIT(26)
#define BIT_FS_BCNDMA2_INT_8821C BIT(25)
#define BIT_FS_BCNDMA1_INT_8821C BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_8821C BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_8821C BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_8821C BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_8821C BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_8821C BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_8821C BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_8821C BIT(17)
#define BIT_FS_BCNDMA0_INT_8821C BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT_8821C BIT(15)
#define BIT_FS_BCNERLY4_INT_8821C BIT(11)
#define BIT_FS_BCNERLY3_INT_8821C BIT(10)
#define BIT_FS_BCNERLY2_INT_8821C BIT(9)
#define BIT_FS_BCNERLY1_INT_8821C BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_8821C BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_8821C BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_8821C BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_8821C BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_8821C BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_8821C BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_8821C BIT(1)
#define BIT_FS_BCNERLY0_INT_8821C BIT(0)
/* 2 REG_FE4IMR_8821C */
#define BIT_FS_CLI3_TXPKTIN_INT_EN_8821C BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_EN_8821C BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_EN_8821C BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_EN_8821C BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_EN_8821C BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_EN_8821C BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_EN_8821C BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_EN_8821C BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_EN_8821C BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_EN_8821C BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_EN_8821C BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_EN_8821C BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_EN_8821C BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_EN_8821C BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_EN_8821C BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_EN_8821C BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_EN_8821C BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_EN_8821C BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_EN_8821C BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_EN_8821C BIT(0)
/* 2 REG_FE4ISR_8821C */
#define BIT_FS_CLI3_TXPKTIN_INT_8821C BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_8821C BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_8821C BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_8821C BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_8821C BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_8821C BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_8821C BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_8821C BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_8821C BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_8821C BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_8821C BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_8821C BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_8821C BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_8821C BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_8821C BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_8821C BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_8821C BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_8821C BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_8821C BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_8821C BIT(0)
/* 2 REG_FT1IMR_8821C */
#define BIT__FT2ISR__IND_MSK_8821C BIT(30)
#define BIT_FTM_PTT_INT_EN_8821C BIT(29)
#define BIT_RXFTMREQ_INT_EN_8821C BIT(28)
#define BIT_RXFTM_INT_EN_8821C BIT(27)
#define BIT_TXFTM_INT_EN_8821C BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_EN_8821C BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_EN_8821C BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_EN_8821C BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_EN_8821C BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_EN_8821C BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_EN_8821C BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_EN_8821C BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_EN_8821C BIT(18)
#define BIT_FS_CTWEND2_INT_EN_8821C BIT(17)
#define BIT_FS_CTWEND1_INT_EN_8821C BIT(16)
#define BIT_FS_CTWEND0_INT_EN_8821C BIT(15)
#define BIT_FS_TX_NULL1_INT_EN_8821C BIT(14)
#define BIT_FS_TX_NULL0_INT_EN_8821C BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_EN_8821C BIT(12)
#define BIT_FS_P2P_RFON2_INT_EN_8821C BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_EN_8821C BIT(10)
#define BIT_FS_P2P_RFON1_INT_EN_8821C BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_EN_8821C BIT(8)
#define BIT_FS_P2P_RFON0_INT_EN_8821C BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_EN_8821C BIT(6)
#define BIT_FS_RX_UAPSDMD1_EN_8821C BIT(5)
#define BIT_FS_RX_UAPSDMD0_EN_8821C BIT(4)
#define BIT_FS_TRIGGER_PKT_EN_8821C BIT(3)
#define BIT_FS_EOSP_INT_EN_8821C BIT(2)
#define BIT_FS_RPWM2_INT_EN_8821C BIT(1)
#define BIT_FS_RPWM_INT_EN_8821C BIT(0)
/* 2 REG_FT1ISR_8821C */
#define BIT__FT2ISR__IND_INT_8821C BIT(30)
#define BIT_FTM_PTT_INT_8821C BIT(29)
#define BIT_RXFTMREQ_INT_8821C BIT(28)
#define BIT_RXFTM_INT_8821C BIT(27)
#define BIT_TXFTM_INT_8821C BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_8821C BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_8821C BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_8821C BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_8821C BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_8821C BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_8821C BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_8821C BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_8821C BIT(18)
#define BIT_FS_CTWEND2_INT_8821C BIT(17)
#define BIT_FS_CTWEND1_INT_8821C BIT(16)
#define BIT_FS_CTWEND0_INT_8821C BIT(15)
#define BIT_FS_TX_NULL1_INT_8821C BIT(14)
#define BIT_FS_TX_NULL0_INT_8821C BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_INT_8821C BIT(12)
#define BIT_FS_P2P_RFON2_INT_8821C BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_8821C BIT(10)
#define BIT_FS_P2P_RFON1_INT_8821C BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_8821C BIT(8)
#define BIT_FS_P2P_RFON0_INT_8821C BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_8821C BIT(6)
#define BIT_FS_RX_UAPSDMD1_INT_8821C BIT(5)
#define BIT_FS_RX_UAPSDMD0_INT_8821C BIT(4)
#define BIT_FS_TRIGGER_PKT_INT_8821C BIT(3)
#define BIT_FS_EOSP_INT_8821C BIT(2)
#define BIT_FS_RPWM2_INT_8821C BIT(1)
#define BIT_FS_RPWM_INT_8821C BIT(0)
/* 2 REG_SPWR0_8821C */
#define BIT_SHIFT_MID_31TO0_8821C 0
#define BIT_MASK_MID_31TO0_8821C 0xffffffffL
#define BIT_MID_31TO0_8821C(x) \
(((x) & BIT_MASK_MID_31TO0_8821C) << BIT_SHIFT_MID_31TO0_8821C)
#define BITS_MID_31TO0_8821C \
(BIT_MASK_MID_31TO0_8821C << BIT_SHIFT_MID_31TO0_8821C)
#define BIT_CLEAR_MID_31TO0_8821C(x) ((x) & (~BITS_MID_31TO0_8821C))
#define BIT_GET_MID_31TO0_8821C(x) \
(((x) >> BIT_SHIFT_MID_31TO0_8821C) & BIT_MASK_MID_31TO0_8821C)
#define BIT_SET_MID_31TO0_8821C(x, v) \
(BIT_CLEAR_MID_31TO0_8821C(x) | BIT_MID_31TO0_8821C(v))
/* 2 REG_SPWR1_8821C */
#define BIT_SHIFT_MID_63TO32_8821C 0
#define BIT_MASK_MID_63TO32_8821C 0xffffffffL
#define BIT_MID_63TO32_8821C(x) \
(((x) & BIT_MASK_MID_63TO32_8821C) << BIT_SHIFT_MID_63TO32_8821C)
#define BITS_MID_63TO32_8821C \
(BIT_MASK_MID_63TO32_8821C << BIT_SHIFT_MID_63TO32_8821C)
#define BIT_CLEAR_MID_63TO32_8821C(x) ((x) & (~BITS_MID_63TO32_8821C))
#define BIT_GET_MID_63TO32_8821C(x) \
(((x) >> BIT_SHIFT_MID_63TO32_8821C) & BIT_MASK_MID_63TO32_8821C)
#define BIT_SET_MID_63TO32_8821C(x, v) \
(BIT_CLEAR_MID_63TO32_8821C(x) | BIT_MID_63TO32_8821C(v))
/* 2 REG_SPWR2_8821C */
#define BIT_SHIFT_MID_95O64_8821C 0
#define BIT_MASK_MID_95O64_8821C 0xffffffffL
#define BIT_MID_95O64_8821C(x) \
(((x) & BIT_MASK_MID_95O64_8821C) << BIT_SHIFT_MID_95O64_8821C)
#define BITS_MID_95O64_8821C \
(BIT_MASK_MID_95O64_8821C << BIT_SHIFT_MID_95O64_8821C)
#define BIT_CLEAR_MID_95O64_8821C(x) ((x) & (~BITS_MID_95O64_8821C))
#define BIT_GET_MID_95O64_8821C(x) \
(((x) >> BIT_SHIFT_MID_95O64_8821C) & BIT_MASK_MID_95O64_8821C)
#define BIT_SET_MID_95O64_8821C(x, v) \
(BIT_CLEAR_MID_95O64_8821C(x) | BIT_MID_95O64_8821C(v))
/* 2 REG_SPWR3_8821C */
#define BIT_SHIFT_MID_127TO96_8821C 0
#define BIT_MASK_MID_127TO96_8821C 0xffffffffL
#define BIT_MID_127TO96_8821C(x) \
(((x) & BIT_MASK_MID_127TO96_8821C) << BIT_SHIFT_MID_127TO96_8821C)
#define BITS_MID_127TO96_8821C \
(BIT_MASK_MID_127TO96_8821C << BIT_SHIFT_MID_127TO96_8821C)
#define BIT_CLEAR_MID_127TO96_8821C(x) ((x) & (~BITS_MID_127TO96_8821C))
#define BIT_GET_MID_127TO96_8821C(x) \
(((x) >> BIT_SHIFT_MID_127TO96_8821C) & BIT_MASK_MID_127TO96_8821C)
#define BIT_SET_MID_127TO96_8821C(x, v) \
(BIT_CLEAR_MID_127TO96_8821C(x) | BIT_MID_127TO96_8821C(v))
/* 2 REG_POWSEQ_8821C */
#define BIT_SHIFT_SEQNUM_MID_8821C 16
#define BIT_MASK_SEQNUM_MID_8821C 0xffff
#define BIT_SEQNUM_MID_8821C(x) \
(((x) & BIT_MASK_SEQNUM_MID_8821C) << BIT_SHIFT_SEQNUM_MID_8821C)
#define BITS_SEQNUM_MID_8821C \
(BIT_MASK_SEQNUM_MID_8821C << BIT_SHIFT_SEQNUM_MID_8821C)
#define BIT_CLEAR_SEQNUM_MID_8821C(x) ((x) & (~BITS_SEQNUM_MID_8821C))
#define BIT_GET_SEQNUM_MID_8821C(x) \
(((x) >> BIT_SHIFT_SEQNUM_MID_8821C) & BIT_MASK_SEQNUM_MID_8821C)
#define BIT_SET_SEQNUM_MID_8821C(x, v) \
(BIT_CLEAR_SEQNUM_MID_8821C(x) | BIT_SEQNUM_MID_8821C(v))
#define BIT_SHIFT_REF_MID_8821C 0
#define BIT_MASK_REF_MID_8821C 0x7f
#define BIT_REF_MID_8821C(x) \
(((x) & BIT_MASK_REF_MID_8821C) << BIT_SHIFT_REF_MID_8821C)
#define BITS_REF_MID_8821C (BIT_MASK_REF_MID_8821C << BIT_SHIFT_REF_MID_8821C)
#define BIT_CLEAR_REF_MID_8821C(x) ((x) & (~BITS_REF_MID_8821C))
#define BIT_GET_REF_MID_8821C(x) \
(((x) >> BIT_SHIFT_REF_MID_8821C) & BIT_MASK_REF_MID_8821C)
#define BIT_SET_REF_MID_8821C(x, v) \
(BIT_CLEAR_REF_MID_8821C(x) | BIT_REF_MID_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_TC7_CTRL_V1_8821C */
#define BIT_TC7INT_EN_8821C BIT(26)
#define BIT_TC7MODE_8821C BIT(25)
#define BIT_TC7EN_8821C BIT(24)
#define BIT_SHIFT_TC7DATA_8821C 0
#define BIT_MASK_TC7DATA_8821C 0xffffff
#define BIT_TC7DATA_8821C(x) \
(((x) & BIT_MASK_TC7DATA_8821C) << BIT_SHIFT_TC7DATA_8821C)
#define BITS_TC7DATA_8821C (BIT_MASK_TC7DATA_8821C << BIT_SHIFT_TC7DATA_8821C)
#define BIT_CLEAR_TC7DATA_8821C(x) ((x) & (~BITS_TC7DATA_8821C))
#define BIT_GET_TC7DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC7DATA_8821C) & BIT_MASK_TC7DATA_8821C)
#define BIT_SET_TC7DATA_8821C(x, v) \
(BIT_CLEAR_TC7DATA_8821C(x) | BIT_TC7DATA_8821C(v))
/* 2 REG_TC8_CTRL_V1_8821C */
#define BIT_TC8INT_EN_8821C BIT(26)
#define BIT_TC8MODE_8821C BIT(25)
#define BIT_TC8EN_8821C BIT(24)
#define BIT_SHIFT_TC8DATA_8821C 0
#define BIT_MASK_TC8DATA_8821C 0xffffff
#define BIT_TC8DATA_8821C(x) \
(((x) & BIT_MASK_TC8DATA_8821C) << BIT_SHIFT_TC8DATA_8821C)
#define BITS_TC8DATA_8821C (BIT_MASK_TC8DATA_8821C << BIT_SHIFT_TC8DATA_8821C)
#define BIT_CLEAR_TC8DATA_8821C(x) ((x) & (~BITS_TC8DATA_8821C))
#define BIT_GET_TC8DATA_8821C(x) \
(((x) >> BIT_SHIFT_TC8DATA_8821C) & BIT_MASK_TC8DATA_8821C)
#define BIT_SET_TC8DATA_8821C(x, v) \
(BIT_CLEAR_TC8DATA_8821C(x) | BIT_TC8DATA_8821C(v))
/* 2 REG_RX_BCN_TBTT_ITVL0_8821C */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8821C 24
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8821C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT2_8821C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8821C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8821C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT2_8821C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8821C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8821C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2_8821C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT2_8821C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT2_8821C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8821C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8821C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT2_8821C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2_8821C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT2_8821C(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8821C 16
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8821C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT1_8821C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8821C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8821C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT1_8821C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8821C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8821C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1_8821C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT1_8821C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT1_8821C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8821C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8821C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT1_8821C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1_8821C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT1_8821C(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8821C 8
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8821C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT0_8821C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8821C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8821C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT0_8821C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8821C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8821C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0_8821C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT0_8821C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT0_8821C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8821C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8821C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT0_8821C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0_8821C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT0_8821C(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8821C 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8821C 0xff
#define BIT_RX_BCN_TBTT_ITVL_PORT0_8821C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8821C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8821C)
#define BITS_RX_BCN_TBTT_ITVL_PORT0_8821C \
(BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8821C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8821C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0_8821C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_PORT0_8821C))
#define BIT_GET_RX_BCN_TBTT_ITVL_PORT0_8821C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8821C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8821C)
#define BIT_SET_RX_BCN_TBTT_ITVL_PORT0_8821C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0_8821C(x) | \
BIT_RX_BCN_TBTT_ITVL_PORT0_8821C(v))
/* 2 REG_RX_BCN_TBTT_ITVL1_8821C */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8821C 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8821C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT3_8821C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8821C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8821C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT3_8821C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8821C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8821C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3_8821C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT3_8821C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT3_8821C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8821C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8821C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT3_8821C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3_8821C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT3_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_IO_WRAP_ERR_FLAG_8821C */
#define BIT_IO_WRAP_ERR_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SPEED_SENSOR_8821C */
#define BIT_DSS_1_RST_N_8821C BIT(31)
#define BIT_DSS_1_SPEED_EN_8821C BIT(30)
#define BIT_DSS_1_WIRE_SEL_8821C BIT(29)
#define BIT_DSS_ENCLK_8821C BIT(28)
#define BIT_SHIFT_DSS_1_RO_SEL_8821C 24
#define BIT_MASK_DSS_1_RO_SEL_8821C 0x7
#define BIT_DSS_1_RO_SEL_8821C(x) \
(((x) & BIT_MASK_DSS_1_RO_SEL_8821C) << BIT_SHIFT_DSS_1_RO_SEL_8821C)
#define BITS_DSS_1_RO_SEL_8821C \
(BIT_MASK_DSS_1_RO_SEL_8821C << BIT_SHIFT_DSS_1_RO_SEL_8821C)
#define BIT_CLEAR_DSS_1_RO_SEL_8821C(x) ((x) & (~BITS_DSS_1_RO_SEL_8821C))
#define BIT_GET_DSS_1_RO_SEL_8821C(x) \
(((x) >> BIT_SHIFT_DSS_1_RO_SEL_8821C) & BIT_MASK_DSS_1_RO_SEL_8821C)
#define BIT_SET_DSS_1_RO_SEL_8821C(x, v) \
(BIT_CLEAR_DSS_1_RO_SEL_8821C(x) | BIT_DSS_1_RO_SEL_8821C(v))
#define BIT_SHIFT_DSS_1_DATA_IN_8821C 0
#define BIT_MASK_DSS_1_DATA_IN_8821C 0xfffff
#define BIT_DSS_1_DATA_IN_8821C(x) \
(((x) & BIT_MASK_DSS_1_DATA_IN_8821C) << BIT_SHIFT_DSS_1_DATA_IN_8821C)
#define BITS_DSS_1_DATA_IN_8821C \
(BIT_MASK_DSS_1_DATA_IN_8821C << BIT_SHIFT_DSS_1_DATA_IN_8821C)
#define BIT_CLEAR_DSS_1_DATA_IN_8821C(x) ((x) & (~BITS_DSS_1_DATA_IN_8821C))
#define BIT_GET_DSS_1_DATA_IN_8821C(x) \
(((x) >> BIT_SHIFT_DSS_1_DATA_IN_8821C) & BIT_MASK_DSS_1_DATA_IN_8821C)
#define BIT_SET_DSS_1_DATA_IN_8821C(x, v) \
(BIT_CLEAR_DSS_1_DATA_IN_8821C(x) | BIT_DSS_1_DATA_IN_8821C(v))
/* 2 REG_SPEED_SENSOR1_8821C */
#define BIT_DSS_1_READY_8821C BIT(31)
#define BIT_DSS_1_WSORT_GO_8821C BIT(30)
#define BIT_SHIFT_DSS_1_COUNT_OUT_8821C 0
#define BIT_MASK_DSS_1_COUNT_OUT_8821C 0xfffff
#define BIT_DSS_1_COUNT_OUT_8821C(x) \
(((x) & BIT_MASK_DSS_1_COUNT_OUT_8821C) \
<< BIT_SHIFT_DSS_1_COUNT_OUT_8821C)
#define BITS_DSS_1_COUNT_OUT_8821C \
(BIT_MASK_DSS_1_COUNT_OUT_8821C << BIT_SHIFT_DSS_1_COUNT_OUT_8821C)
#define BIT_CLEAR_DSS_1_COUNT_OUT_8821C(x) ((x) & (~BITS_DSS_1_COUNT_OUT_8821C))
#define BIT_GET_DSS_1_COUNT_OUT_8821C(x) \
(((x) >> BIT_SHIFT_DSS_1_COUNT_OUT_8821C) & \
BIT_MASK_DSS_1_COUNT_OUT_8821C)
#define BIT_SET_DSS_1_COUNT_OUT_8821C(x, v) \
(BIT_CLEAR_DSS_1_COUNT_OUT_8821C(x) | BIT_DSS_1_COUNT_OUT_8821C(v))
/* 2 REG_SPEED_SENSOR2_8821C */
#define BIT_DSS_2_RST_N_8821C BIT(31)
#define BIT_DSS_2_SPEED_EN_8821C BIT(30)
#define BIT_DSS_2_WIRE_SEL_8821C BIT(29)
#define BIT_DSS_ENCLK_8821C BIT(28)
#define BIT_SHIFT_DSS_2_RO_SEL_8821C 24
#define BIT_MASK_DSS_2_RO_SEL_8821C 0x7
#define BIT_DSS_2_RO_SEL_8821C(x) \
(((x) & BIT_MASK_DSS_2_RO_SEL_8821C) << BIT_SHIFT_DSS_2_RO_SEL_8821C)
#define BITS_DSS_2_RO_SEL_8821C \
(BIT_MASK_DSS_2_RO_SEL_8821C << BIT_SHIFT_DSS_2_RO_SEL_8821C)
#define BIT_CLEAR_DSS_2_RO_SEL_8821C(x) ((x) & (~BITS_DSS_2_RO_SEL_8821C))
#define BIT_GET_DSS_2_RO_SEL_8821C(x) \
(((x) >> BIT_SHIFT_DSS_2_RO_SEL_8821C) & BIT_MASK_DSS_2_RO_SEL_8821C)
#define BIT_SET_DSS_2_RO_SEL_8821C(x, v) \
(BIT_CLEAR_DSS_2_RO_SEL_8821C(x) | BIT_DSS_2_RO_SEL_8821C(v))
#define BIT_SHIFT_DSS_2_DATA_IN_8821C 0
#define BIT_MASK_DSS_2_DATA_IN_8821C 0xfffff
#define BIT_DSS_2_DATA_IN_8821C(x) \
(((x) & BIT_MASK_DSS_2_DATA_IN_8821C) << BIT_SHIFT_DSS_2_DATA_IN_8821C)
#define BITS_DSS_2_DATA_IN_8821C \
(BIT_MASK_DSS_2_DATA_IN_8821C << BIT_SHIFT_DSS_2_DATA_IN_8821C)
#define BIT_CLEAR_DSS_2_DATA_IN_8821C(x) ((x) & (~BITS_DSS_2_DATA_IN_8821C))
#define BIT_GET_DSS_2_DATA_IN_8821C(x) \
(((x) >> BIT_SHIFT_DSS_2_DATA_IN_8821C) & BIT_MASK_DSS_2_DATA_IN_8821C)
#define BIT_SET_DSS_2_DATA_IN_8821C(x, v) \
(BIT_CLEAR_DSS_2_DATA_IN_8821C(x) | BIT_DSS_2_DATA_IN_8821C(v))
/* 2 REG_SPEED_SENSOR3_8821C */
#define BIT_DSS_2_READY_8821C BIT(31)
#define BIT_DSS_2_WSORT_GO_8821C BIT(30)
#define BIT_SHIFT_DSS_2_COUNT_OUT_8821C 0
#define BIT_MASK_DSS_2_COUNT_OUT_8821C 0xfffff
#define BIT_DSS_2_COUNT_OUT_8821C(x) \
(((x) & BIT_MASK_DSS_2_COUNT_OUT_8821C) \
<< BIT_SHIFT_DSS_2_COUNT_OUT_8821C)
#define BITS_DSS_2_COUNT_OUT_8821C \
(BIT_MASK_DSS_2_COUNT_OUT_8821C << BIT_SHIFT_DSS_2_COUNT_OUT_8821C)
#define BIT_CLEAR_DSS_2_COUNT_OUT_8821C(x) ((x) & (~BITS_DSS_2_COUNT_OUT_8821C))
#define BIT_GET_DSS_2_COUNT_OUT_8821C(x) \
(((x) >> BIT_SHIFT_DSS_2_COUNT_OUT_8821C) & \
BIT_MASK_DSS_2_COUNT_OUT_8821C)
#define BIT_SET_DSS_2_COUNT_OUT_8821C(x, v) \
(BIT_CLEAR_DSS_2_COUNT_OUT_8821C(x) | BIT_DSS_2_COUNT_OUT_8821C(v))
/* 2 REG_SPEED_SENSOR4_8821C */
#define BIT_DSS_3_RST_N_8821C BIT(31)
#define BIT_DSS_3_SPEED_EN_8821C BIT(30)
#define BIT_DSS_3_WIRE_SEL_8821C BIT(29)
#define BIT_DSS_ENCLK_8821C BIT(28)
#define BIT_SHIFT_DSS_3_RO_SEL_8821C 24
#define BIT_MASK_DSS_3_RO_SEL_8821C 0x7
#define BIT_DSS_3_RO_SEL_8821C(x) \
(((x) & BIT_MASK_DSS_3_RO_SEL_8821C) << BIT_SHIFT_DSS_3_RO_SEL_8821C)
#define BITS_DSS_3_RO_SEL_8821C \
(BIT_MASK_DSS_3_RO_SEL_8821C << BIT_SHIFT_DSS_3_RO_SEL_8821C)
#define BIT_CLEAR_DSS_3_RO_SEL_8821C(x) ((x) & (~BITS_DSS_3_RO_SEL_8821C))
#define BIT_GET_DSS_3_RO_SEL_8821C(x) \
(((x) >> BIT_SHIFT_DSS_3_RO_SEL_8821C) & BIT_MASK_DSS_3_RO_SEL_8821C)
#define BIT_SET_DSS_3_RO_SEL_8821C(x, v) \
(BIT_CLEAR_DSS_3_RO_SEL_8821C(x) | BIT_DSS_3_RO_SEL_8821C(v))
#define BIT_SHIFT_DSS_3_DATA_IN_8821C 0
#define BIT_MASK_DSS_3_DATA_IN_8821C 0xfffff
#define BIT_DSS_3_DATA_IN_8821C(x) \
(((x) & BIT_MASK_DSS_3_DATA_IN_8821C) << BIT_SHIFT_DSS_3_DATA_IN_8821C)
#define BITS_DSS_3_DATA_IN_8821C \
(BIT_MASK_DSS_3_DATA_IN_8821C << BIT_SHIFT_DSS_3_DATA_IN_8821C)
#define BIT_CLEAR_DSS_3_DATA_IN_8821C(x) ((x) & (~BITS_DSS_3_DATA_IN_8821C))
#define BIT_GET_DSS_3_DATA_IN_8821C(x) \
(((x) >> BIT_SHIFT_DSS_3_DATA_IN_8821C) & BIT_MASK_DSS_3_DATA_IN_8821C)
#define BIT_SET_DSS_3_DATA_IN_8821C(x, v) \
(BIT_CLEAR_DSS_3_DATA_IN_8821C(x) | BIT_DSS_3_DATA_IN_8821C(v))
/* 2 REG_SPEED_SENSOR5_8821C */
#define BIT_DSS_3_READY_8821C BIT(31)
#define BIT_DSS_3_WSORT_GO_8821C BIT(30)
#define BIT_SHIFT_DSS_3_COUNT_OUT_8821C 0
#define BIT_MASK_DSS_3_COUNT_OUT_8821C 0xfffff
#define BIT_DSS_3_COUNT_OUT_8821C(x) \
(((x) & BIT_MASK_DSS_3_COUNT_OUT_8821C) \
<< BIT_SHIFT_DSS_3_COUNT_OUT_8821C)
#define BITS_DSS_3_COUNT_OUT_8821C \
(BIT_MASK_DSS_3_COUNT_OUT_8821C << BIT_SHIFT_DSS_3_COUNT_OUT_8821C)
#define BIT_CLEAR_DSS_3_COUNT_OUT_8821C(x) ((x) & (~BITS_DSS_3_COUNT_OUT_8821C))
#define BIT_GET_DSS_3_COUNT_OUT_8821C(x) \
(((x) >> BIT_SHIFT_DSS_3_COUNT_OUT_8821C) & \
BIT_MASK_DSS_3_COUNT_OUT_8821C)
#define BIT_SET_DSS_3_COUNT_OUT_8821C(x, v) \
(BIT_CLEAR_DSS_3_COUNT_OUT_8821C(x) | BIT_DSS_3_COUNT_OUT_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_COUNTER_CTRL_8821C */
#define BIT_SHIFT_COUNTER_BASE_8821C 16
#define BIT_MASK_COUNTER_BASE_8821C 0x1fff
#define BIT_COUNTER_BASE_8821C(x) \
(((x) & BIT_MASK_COUNTER_BASE_8821C) << BIT_SHIFT_COUNTER_BASE_8821C)
#define BITS_COUNTER_BASE_8821C \
(BIT_MASK_COUNTER_BASE_8821C << BIT_SHIFT_COUNTER_BASE_8821C)
#define BIT_CLEAR_COUNTER_BASE_8821C(x) ((x) & (~BITS_COUNTER_BASE_8821C))
#define BIT_GET_COUNTER_BASE_8821C(x) \
(((x) >> BIT_SHIFT_COUNTER_BASE_8821C) & BIT_MASK_COUNTER_BASE_8821C)
#define BIT_SET_COUNTER_BASE_8821C(x, v) \
(BIT_CLEAR_COUNTER_BASE_8821C(x) | BIT_COUNTER_BASE_8821C(v))
#define BIT_EN_RTS_REQ_8821C BIT(9)
#define BIT_EN_EDCA_REQ_8821C BIT(8)
#define BIT_EN_PTCL_REQ_8821C BIT(7)
#define BIT_EN_SCH_REQ_8821C BIT(6)
#define BIT_USB_COUNT_EN_8821C BIT(5)
#define BIT_PCIE_COUNT_EN_8821C BIT(4)
#define BIT_RQPN_COUNT_EN_8821C BIT(3)
#define BIT_RDE_COUNT_EN_8821C BIT(2)
#define BIT_TDE_COUNT_EN_8821C BIT(1)
#define BIT_DISABLE_COUNTER_8821C BIT(0)
/* 2 REG_COUNTER_THRESHOLD_8821C */
#define BIT_SEL_ALL_MACID_8821C BIT(31)
#define BIT_SHIFT_COUNTER_MACID_8821C 24
#define BIT_MASK_COUNTER_MACID_8821C 0x7f
#define BIT_COUNTER_MACID_8821C(x) \
(((x) & BIT_MASK_COUNTER_MACID_8821C) << BIT_SHIFT_COUNTER_MACID_8821C)
#define BITS_COUNTER_MACID_8821C \
(BIT_MASK_COUNTER_MACID_8821C << BIT_SHIFT_COUNTER_MACID_8821C)
#define BIT_CLEAR_COUNTER_MACID_8821C(x) ((x) & (~BITS_COUNTER_MACID_8821C))
#define BIT_GET_COUNTER_MACID_8821C(x) \
(((x) >> BIT_SHIFT_COUNTER_MACID_8821C) & BIT_MASK_COUNTER_MACID_8821C)
#define BIT_SET_COUNTER_MACID_8821C(x, v) \
(BIT_CLEAR_COUNTER_MACID_8821C(x) | BIT_COUNTER_MACID_8821C(v))
#define BIT_SHIFT_AGG_VALUE2_8821C 16
#define BIT_MASK_AGG_VALUE2_8821C 0x7f
#define BIT_AGG_VALUE2_8821C(x) \
(((x) & BIT_MASK_AGG_VALUE2_8821C) << BIT_SHIFT_AGG_VALUE2_8821C)
#define BITS_AGG_VALUE2_8821C \
(BIT_MASK_AGG_VALUE2_8821C << BIT_SHIFT_AGG_VALUE2_8821C)
#define BIT_CLEAR_AGG_VALUE2_8821C(x) ((x) & (~BITS_AGG_VALUE2_8821C))
#define BIT_GET_AGG_VALUE2_8821C(x) \
(((x) >> BIT_SHIFT_AGG_VALUE2_8821C) & BIT_MASK_AGG_VALUE2_8821C)
#define BIT_SET_AGG_VALUE2_8821C(x, v) \
(BIT_CLEAR_AGG_VALUE2_8821C(x) | BIT_AGG_VALUE2_8821C(v))
#define BIT_SHIFT_AGG_VALUE1_8821C 8
#define BIT_MASK_AGG_VALUE1_8821C 0x7f
#define BIT_AGG_VALUE1_8821C(x) \
(((x) & BIT_MASK_AGG_VALUE1_8821C) << BIT_SHIFT_AGG_VALUE1_8821C)
#define BITS_AGG_VALUE1_8821C \
(BIT_MASK_AGG_VALUE1_8821C << BIT_SHIFT_AGG_VALUE1_8821C)
#define BIT_CLEAR_AGG_VALUE1_8821C(x) ((x) & (~BITS_AGG_VALUE1_8821C))
#define BIT_GET_AGG_VALUE1_8821C(x) \
(((x) >> BIT_SHIFT_AGG_VALUE1_8821C) & BIT_MASK_AGG_VALUE1_8821C)
#define BIT_SET_AGG_VALUE1_8821C(x, v) \
(BIT_CLEAR_AGG_VALUE1_8821C(x) | BIT_AGG_VALUE1_8821C(v))
#define BIT_SHIFT_AGG_VALUE0_8821C 0
#define BIT_MASK_AGG_VALUE0_8821C 0x7f
#define BIT_AGG_VALUE0_8821C(x) \
(((x) & BIT_MASK_AGG_VALUE0_8821C) << BIT_SHIFT_AGG_VALUE0_8821C)
#define BITS_AGG_VALUE0_8821C \
(BIT_MASK_AGG_VALUE0_8821C << BIT_SHIFT_AGG_VALUE0_8821C)
#define BIT_CLEAR_AGG_VALUE0_8821C(x) ((x) & (~BITS_AGG_VALUE0_8821C))
#define BIT_GET_AGG_VALUE0_8821C(x) \
(((x) >> BIT_SHIFT_AGG_VALUE0_8821C) & BIT_MASK_AGG_VALUE0_8821C)
#define BIT_SET_AGG_VALUE0_8821C(x, v) \
(BIT_CLEAR_AGG_VALUE0_8821C(x) | BIT_AGG_VALUE0_8821C(v))
/* 2 REG_COUNTER_SET_8821C */
#define BIT_SHIFT_REQUEST_RESET_8821C 16
#define BIT_MASK_REQUEST_RESET_8821C 0xffff
#define BIT_REQUEST_RESET_8821C(x) \
(((x) & BIT_MASK_REQUEST_RESET_8821C) << BIT_SHIFT_REQUEST_RESET_8821C)
#define BITS_REQUEST_RESET_8821C \
(BIT_MASK_REQUEST_RESET_8821C << BIT_SHIFT_REQUEST_RESET_8821C)
#define BIT_CLEAR_REQUEST_RESET_8821C(x) ((x) & (~BITS_REQUEST_RESET_8821C))
#define BIT_GET_REQUEST_RESET_8821C(x) \
(((x) >> BIT_SHIFT_REQUEST_RESET_8821C) & BIT_MASK_REQUEST_RESET_8821C)
#define BIT_SET_REQUEST_RESET_8821C(x, v) \
(BIT_CLEAR_REQUEST_RESET_8821C(x) | BIT_REQUEST_RESET_8821C(v))
#define BIT_SHIFT_REQUEST_START_8821C 0
#define BIT_MASK_REQUEST_START_8821C 0xffff
#define BIT_REQUEST_START_8821C(x) \
(((x) & BIT_MASK_REQUEST_START_8821C) << BIT_SHIFT_REQUEST_START_8821C)
#define BITS_REQUEST_START_8821C \
(BIT_MASK_REQUEST_START_8821C << BIT_SHIFT_REQUEST_START_8821C)
#define BIT_CLEAR_REQUEST_START_8821C(x) ((x) & (~BITS_REQUEST_START_8821C))
#define BIT_GET_REQUEST_START_8821C(x) \
(((x) >> BIT_SHIFT_REQUEST_START_8821C) & BIT_MASK_REQUEST_START_8821C)
#define BIT_SET_REQUEST_START_8821C(x, v) \
(BIT_CLEAR_REQUEST_START_8821C(x) | BIT_REQUEST_START_8821C(v))
/* 2 REG_COUNTER_OVERFLOW_8821C */
#define BIT_SHIFT_CNT_OVF_REG_8821C 0
#define BIT_MASK_CNT_OVF_REG_8821C 0xffff
#define BIT_CNT_OVF_REG_8821C(x) \
(((x) & BIT_MASK_CNT_OVF_REG_8821C) << BIT_SHIFT_CNT_OVF_REG_8821C)
#define BITS_CNT_OVF_REG_8821C \
(BIT_MASK_CNT_OVF_REG_8821C << BIT_SHIFT_CNT_OVF_REG_8821C)
#define BIT_CLEAR_CNT_OVF_REG_8821C(x) ((x) & (~BITS_CNT_OVF_REG_8821C))
#define BIT_GET_CNT_OVF_REG_8821C(x) \
(((x) >> BIT_SHIFT_CNT_OVF_REG_8821C) & BIT_MASK_CNT_OVF_REG_8821C)
#define BIT_SET_CNT_OVF_REG_8821C(x, v) \
(BIT_CLEAR_CNT_OVF_REG_8821C(x) | BIT_CNT_OVF_REG_8821C(v))
/* 2 REG_TXDMA_LEN_THRESHOLD_8821C */
#define BIT_SHIFT_TDE_LEN_TH1_8821C 16
#define BIT_MASK_TDE_LEN_TH1_8821C 0xffff
#define BIT_TDE_LEN_TH1_8821C(x) \
(((x) & BIT_MASK_TDE_LEN_TH1_8821C) << BIT_SHIFT_TDE_LEN_TH1_8821C)
#define BITS_TDE_LEN_TH1_8821C \
(BIT_MASK_TDE_LEN_TH1_8821C << BIT_SHIFT_TDE_LEN_TH1_8821C)
#define BIT_CLEAR_TDE_LEN_TH1_8821C(x) ((x) & (~BITS_TDE_LEN_TH1_8821C))
#define BIT_GET_TDE_LEN_TH1_8821C(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH1_8821C) & BIT_MASK_TDE_LEN_TH1_8821C)
#define BIT_SET_TDE_LEN_TH1_8821C(x, v) \
(BIT_CLEAR_TDE_LEN_TH1_8821C(x) | BIT_TDE_LEN_TH1_8821C(v))
#define BIT_SHIFT_TDE_LEN_TH0_8821C 0
#define BIT_MASK_TDE_LEN_TH0_8821C 0xffff
#define BIT_TDE_LEN_TH0_8821C(x) \
(((x) & BIT_MASK_TDE_LEN_TH0_8821C) << BIT_SHIFT_TDE_LEN_TH0_8821C)
#define BITS_TDE_LEN_TH0_8821C \
(BIT_MASK_TDE_LEN_TH0_8821C << BIT_SHIFT_TDE_LEN_TH0_8821C)
#define BIT_CLEAR_TDE_LEN_TH0_8821C(x) ((x) & (~BITS_TDE_LEN_TH0_8821C))
#define BIT_GET_TDE_LEN_TH0_8821C(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH0_8821C) & BIT_MASK_TDE_LEN_TH0_8821C)
#define BIT_SET_TDE_LEN_TH0_8821C(x, v) \
(BIT_CLEAR_TDE_LEN_TH0_8821C(x) | BIT_TDE_LEN_TH0_8821C(v))
/* 2 REG_RXDMA_LEN_THRESHOLD_8821C */
#define BIT_SHIFT_RDE_LEN_TH1_8821C 16
#define BIT_MASK_RDE_LEN_TH1_8821C 0xffff
#define BIT_RDE_LEN_TH1_8821C(x) \
(((x) & BIT_MASK_RDE_LEN_TH1_8821C) << BIT_SHIFT_RDE_LEN_TH1_8821C)
#define BITS_RDE_LEN_TH1_8821C \
(BIT_MASK_RDE_LEN_TH1_8821C << BIT_SHIFT_RDE_LEN_TH1_8821C)
#define BIT_CLEAR_RDE_LEN_TH1_8821C(x) ((x) & (~BITS_RDE_LEN_TH1_8821C))
#define BIT_GET_RDE_LEN_TH1_8821C(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH1_8821C) & BIT_MASK_RDE_LEN_TH1_8821C)
#define BIT_SET_RDE_LEN_TH1_8821C(x, v) \
(BIT_CLEAR_RDE_LEN_TH1_8821C(x) | BIT_RDE_LEN_TH1_8821C(v))
#define BIT_SHIFT_RDE_LEN_TH0_8821C 0
#define BIT_MASK_RDE_LEN_TH0_8821C 0xffff
#define BIT_RDE_LEN_TH0_8821C(x) \
(((x) & BIT_MASK_RDE_LEN_TH0_8821C) << BIT_SHIFT_RDE_LEN_TH0_8821C)
#define BITS_RDE_LEN_TH0_8821C \
(BIT_MASK_RDE_LEN_TH0_8821C << BIT_SHIFT_RDE_LEN_TH0_8821C)
#define BIT_CLEAR_RDE_LEN_TH0_8821C(x) ((x) & (~BITS_RDE_LEN_TH0_8821C))
#define BIT_GET_RDE_LEN_TH0_8821C(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH0_8821C) & BIT_MASK_RDE_LEN_TH0_8821C)
#define BIT_SET_RDE_LEN_TH0_8821C(x, v) \
(BIT_CLEAR_RDE_LEN_TH0_8821C(x) | BIT_RDE_LEN_TH0_8821C(v))
/* 2 REG_PCIE_EXEC_TIME_THRESHOLD_8821C */
#define BIT_SHIFT_COUNT_INT_SEL_8821C 16
#define BIT_MASK_COUNT_INT_SEL_8821C 0x3
#define BIT_COUNT_INT_SEL_8821C(x) \
(((x) & BIT_MASK_COUNT_INT_SEL_8821C) << BIT_SHIFT_COUNT_INT_SEL_8821C)
#define BITS_COUNT_INT_SEL_8821C \
(BIT_MASK_COUNT_INT_SEL_8821C << BIT_SHIFT_COUNT_INT_SEL_8821C)
#define BIT_CLEAR_COUNT_INT_SEL_8821C(x) ((x) & (~BITS_COUNT_INT_SEL_8821C))
#define BIT_GET_COUNT_INT_SEL_8821C(x) \
(((x) >> BIT_SHIFT_COUNT_INT_SEL_8821C) & BIT_MASK_COUNT_INT_SEL_8821C)
#define BIT_SET_COUNT_INT_SEL_8821C(x, v) \
(BIT_CLEAR_COUNT_INT_SEL_8821C(x) | BIT_COUNT_INT_SEL_8821C(v))
#define BIT_SHIFT_EXEC_TIME_TH_8821C 0
#define BIT_MASK_EXEC_TIME_TH_8821C 0xffff
#define BIT_EXEC_TIME_TH_8821C(x) \
(((x) & BIT_MASK_EXEC_TIME_TH_8821C) << BIT_SHIFT_EXEC_TIME_TH_8821C)
#define BITS_EXEC_TIME_TH_8821C \
(BIT_MASK_EXEC_TIME_TH_8821C << BIT_SHIFT_EXEC_TIME_TH_8821C)
#define BIT_CLEAR_EXEC_TIME_TH_8821C(x) ((x) & (~BITS_EXEC_TIME_TH_8821C))
#define BIT_GET_EXEC_TIME_TH_8821C(x) \
(((x) >> BIT_SHIFT_EXEC_TIME_TH_8821C) & BIT_MASK_EXEC_TIME_TH_8821C)
#define BIT_SET_EXEC_TIME_TH_8821C(x, v) \
(BIT_CLEAR_EXEC_TIME_TH_8821C(x) | BIT_EXEC_TIME_TH_8821C(v))
/* 2 REG_FT2IMR_8821C */
#define BIT_FS_CLI3_RX_UAPSDMD1_EN_8821C BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_EN_8821C BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_EN_8821C BIT(29)
#define BIT_FS_CLI3_EOSP_INT_EN_8821C BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_EN_8821C BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_EN_8821C BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_EN_8821C BIT(25)
#define BIT_FS_CLI2_EOSP_INT_EN_8821C BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_EN_8821C BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_EN_8821C BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_EN_8821C BIT(21)
#define BIT_FS_CLI1_EOSP_INT_EN_8821C BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_EN_8821C BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_EN_8821C BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_EN_8821C BIT(17)
#define BIT_FS_CLI0_EOSP_INT_EN_8821C BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_EN_8821C BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_EN_8821C BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_EN_8821C BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_EN_8821C BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_EN_8821C BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_EN_8821C BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_EN_8821C BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_EN_8821C BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_EN_8821C BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_EN_8821C BIT(0)
/* 2 REG_FT2ISR_8821C */
#define BIT_FS_CLI3_RX_UAPSDMD1_INT_8821C BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_INT_8821C BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_INT_8821C BIT(29)
#define BIT_FS_CLI3_EOSP_INT_8821C BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_INT_8821C BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_INT_8821C BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_INT_8821C BIT(25)
#define BIT_FS_CLI2_EOSP_INT_8821C BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_INT_8821C BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_INT_8821C BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_INT_8821C BIT(21)
#define BIT_FS_CLI1_EOSP_INT_8821C BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_INT_8821C BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_INT_8821C BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_INT_8821C BIT(17)
#define BIT_FS_CLI0_EOSP_INT_8821C BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_INT_8821C BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_INT_8821C BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_8821C BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_8821C BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_8821C BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_8821C BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_8821C BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_8821C BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_8821C BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_MSG2_8821C */
#define BIT_SHIFT_FW_MSG2_8821C 0
#define BIT_MASK_FW_MSG2_8821C 0xffffffffL
#define BIT_FW_MSG2_8821C(x) \
(((x) & BIT_MASK_FW_MSG2_8821C) << BIT_SHIFT_FW_MSG2_8821C)
#define BITS_FW_MSG2_8821C (BIT_MASK_FW_MSG2_8821C << BIT_SHIFT_FW_MSG2_8821C)
#define BIT_CLEAR_FW_MSG2_8821C(x) ((x) & (~BITS_FW_MSG2_8821C))
#define BIT_GET_FW_MSG2_8821C(x) \
(((x) >> BIT_SHIFT_FW_MSG2_8821C) & BIT_MASK_FW_MSG2_8821C)
#define BIT_SET_FW_MSG2_8821C(x, v) \
(BIT_CLEAR_FW_MSG2_8821C(x) | BIT_FW_MSG2_8821C(v))
/* 2 REG_MSG3_8821C */
#define BIT_SHIFT_FW_MSG3_8821C 0
#define BIT_MASK_FW_MSG3_8821C 0xffffffffL
#define BIT_FW_MSG3_8821C(x) \
(((x) & BIT_MASK_FW_MSG3_8821C) << BIT_SHIFT_FW_MSG3_8821C)
#define BITS_FW_MSG3_8821C (BIT_MASK_FW_MSG3_8821C << BIT_SHIFT_FW_MSG3_8821C)
#define BIT_CLEAR_FW_MSG3_8821C(x) ((x) & (~BITS_FW_MSG3_8821C))
#define BIT_GET_FW_MSG3_8821C(x) \
(((x) >> BIT_SHIFT_FW_MSG3_8821C) & BIT_MASK_FW_MSG3_8821C)
#define BIT_SET_FW_MSG3_8821C(x, v) \
(BIT_CLEAR_FW_MSG3_8821C(x) | BIT_FW_MSG3_8821C(v))
/* 2 REG_MSG4_8821C */
#define BIT_SHIFT_FW_MSG4_8821C 0
#define BIT_MASK_FW_MSG4_8821C 0xffffffffL
#define BIT_FW_MSG4_8821C(x) \
(((x) & BIT_MASK_FW_MSG4_8821C) << BIT_SHIFT_FW_MSG4_8821C)
#define BITS_FW_MSG4_8821C (BIT_MASK_FW_MSG4_8821C << BIT_SHIFT_FW_MSG4_8821C)
#define BIT_CLEAR_FW_MSG4_8821C(x) ((x) & (~BITS_FW_MSG4_8821C))
#define BIT_GET_FW_MSG4_8821C(x) \
(((x) >> BIT_SHIFT_FW_MSG4_8821C) & BIT_MASK_FW_MSG4_8821C)
#define BIT_SET_FW_MSG4_8821C(x, v) \
(BIT_CLEAR_FW_MSG4_8821C(x) | BIT_FW_MSG4_8821C(v))
/* 2 REG_MSG5_8821C */
#define BIT_SHIFT_FW_MSG5_8821C 0
#define BIT_MASK_FW_MSG5_8821C 0xffffffffL
#define BIT_FW_MSG5_8821C(x) \
(((x) & BIT_MASK_FW_MSG5_8821C) << BIT_SHIFT_FW_MSG5_8821C)
#define BITS_FW_MSG5_8821C (BIT_MASK_FW_MSG5_8821C << BIT_SHIFT_FW_MSG5_8821C)
#define BIT_CLEAR_FW_MSG5_8821C(x) ((x) & (~BITS_FW_MSG5_8821C))
#define BIT_GET_FW_MSG5_8821C(x) \
(((x) >> BIT_SHIFT_FW_MSG5_8821C) & BIT_MASK_FW_MSG5_8821C)
#define BIT_SET_FW_MSG5_8821C(x, v) \
(BIT_CLEAR_FW_MSG5_8821C(x) | BIT_FW_MSG5_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_FIFOPAGE_CTRL_1_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8821C 16
#define BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8821C 0xff
#define BIT_TX_OQT_HE_FREE_SPACE_V1_8821C(x) \
(((x) & BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8821C) \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8821C)
#define BITS_TX_OQT_HE_FREE_SPACE_V1_8821C \
(BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8821C \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8821C)
#define BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8821C(x) \
((x) & (~BITS_TX_OQT_HE_FREE_SPACE_V1_8821C))
#define BIT_GET_TX_OQT_HE_FREE_SPACE_V1_8821C(x) \
(((x) >> BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8821C) & \
BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8821C)
#define BIT_SET_TX_OQT_HE_FREE_SPACE_V1_8821C(x, v) \
(BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8821C(x) | \
BIT_TX_OQT_HE_FREE_SPACE_V1_8821C(v))
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8821C 0
#define BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8821C 0xff
#define BIT_TX_OQT_NL_FREE_SPACE_V1_8821C(x) \
(((x) & BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8821C) \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8821C)
#define BITS_TX_OQT_NL_FREE_SPACE_V1_8821C \
(BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8821C \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8821C)
#define BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8821C(x) \
((x) & (~BITS_TX_OQT_NL_FREE_SPACE_V1_8821C))
#define BIT_GET_TX_OQT_NL_FREE_SPACE_V1_8821C(x) \
(((x) >> BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8821C) & \
BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8821C)
#define BIT_SET_TX_OQT_NL_FREE_SPACE_V1_8821C(x, v) \
(BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8821C(x) | \
BIT_TX_OQT_NL_FREE_SPACE_V1_8821C(v))
/* 2 REG_FIFOPAGE_CTRL_2_8821C */
#define BIT_BCN_VALID_1_V1_8821C BIT(31)
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_BCN_HEAD_1_V1_8821C 16
#define BIT_MASK_BCN_HEAD_1_V1_8821C 0xfff
#define BIT_BCN_HEAD_1_V1_8821C(x) \
(((x) & BIT_MASK_BCN_HEAD_1_V1_8821C) << BIT_SHIFT_BCN_HEAD_1_V1_8821C)
#define BITS_BCN_HEAD_1_V1_8821C \
(BIT_MASK_BCN_HEAD_1_V1_8821C << BIT_SHIFT_BCN_HEAD_1_V1_8821C)
#define BIT_CLEAR_BCN_HEAD_1_V1_8821C(x) ((x) & (~BITS_BCN_HEAD_1_V1_8821C))
#define BIT_GET_BCN_HEAD_1_V1_8821C(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_1_V1_8821C) & BIT_MASK_BCN_HEAD_1_V1_8821C)
#define BIT_SET_BCN_HEAD_1_V1_8821C(x, v) \
(BIT_CLEAR_BCN_HEAD_1_V1_8821C(x) | BIT_BCN_HEAD_1_V1_8821C(v))
#define BIT_BCN_VALID_V1_8821C BIT(15)
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_BCN_HEAD_V1_8821C 0
#define BIT_MASK_BCN_HEAD_V1_8821C 0xfff
#define BIT_BCN_HEAD_V1_8821C(x) \
(((x) & BIT_MASK_BCN_HEAD_V1_8821C) << BIT_SHIFT_BCN_HEAD_V1_8821C)
#define BITS_BCN_HEAD_V1_8821C \
(BIT_MASK_BCN_HEAD_V1_8821C << BIT_SHIFT_BCN_HEAD_V1_8821C)
#define BIT_CLEAR_BCN_HEAD_V1_8821C(x) ((x) & (~BITS_BCN_HEAD_V1_8821C))
#define BIT_GET_BCN_HEAD_V1_8821C(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_V1_8821C) & BIT_MASK_BCN_HEAD_V1_8821C)
#define BIT_SET_BCN_HEAD_V1_8821C(x, v) \
(BIT_CLEAR_BCN_HEAD_V1_8821C(x) | BIT_BCN_HEAD_V1_8821C(v))
/* 2 REG_AUTO_LLT_V1_8821C */
#define BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C 24
#define BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C 0xff
#define BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C(x) \
(((x) & BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C) \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C)
#define BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C \
(BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C)
#define BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C(x) \
((x) & (~BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C))
#define BIT_GET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C) & \
BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C)
#define BIT_SET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C(x, v) \
(BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C(x) | \
BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8821C(v))
#define BIT_SHIFT_LLT_FREE_PAGE_V1_8821C 8
#define BIT_MASK_LLT_FREE_PAGE_V1_8821C 0xffff
#define BIT_LLT_FREE_PAGE_V1_8821C(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V1_8821C) \
<< BIT_SHIFT_LLT_FREE_PAGE_V1_8821C)
#define BITS_LLT_FREE_PAGE_V1_8821C \
(BIT_MASK_LLT_FREE_PAGE_V1_8821C << BIT_SHIFT_LLT_FREE_PAGE_V1_8821C)
#define BIT_CLEAR_LLT_FREE_PAGE_V1_8821C(x) \
((x) & (~BITS_LLT_FREE_PAGE_V1_8821C))
#define BIT_GET_LLT_FREE_PAGE_V1_8821C(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V1_8821C) & \
BIT_MASK_LLT_FREE_PAGE_V1_8821C)
#define BIT_SET_LLT_FREE_PAGE_V1_8821C(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V1_8821C(x) | BIT_LLT_FREE_PAGE_V1_8821C(v))
#define BIT_SHIFT_BLK_DESC_NUM_8821C 4
#define BIT_MASK_BLK_DESC_NUM_8821C 0xf
#define BIT_BLK_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_BLK_DESC_NUM_8821C) << BIT_SHIFT_BLK_DESC_NUM_8821C)
#define BITS_BLK_DESC_NUM_8821C \
(BIT_MASK_BLK_DESC_NUM_8821C << BIT_SHIFT_BLK_DESC_NUM_8821C)
#define BIT_CLEAR_BLK_DESC_NUM_8821C(x) ((x) & (~BITS_BLK_DESC_NUM_8821C))
#define BIT_GET_BLK_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_BLK_DESC_NUM_8821C) & BIT_MASK_BLK_DESC_NUM_8821C)
#define BIT_SET_BLK_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_BLK_DESC_NUM_8821C(x) | BIT_BLK_DESC_NUM_8821C(v))
#define BIT_R_BCN_HEAD_SEL_8821C BIT(3)
#define BIT_R_EN_BCN_SW_HEAD_SEL_8821C BIT(2)
#define BIT_LLT_DBG_SEL_8821C BIT(1)
#define BIT_AUTO_INIT_LLT_V1_8821C BIT(0)
/* 2 REG_TXDMA_OFFSET_CHK_8821C */
#define BIT_EM_CHKSUM_FIN_8821C BIT(31)
#define BIT_EMN_PCIE_DMA_MOD_8821C BIT(30)
#define BIT_EN_TXQUE_CLR_8821C BIT(29)
#define BIT_EN_PCIE_FIFO_MODE_8821C BIT(28)
#define BIT_SHIFT_PG_UNDER_TH_V1_8821C 16
#define BIT_MASK_PG_UNDER_TH_V1_8821C 0xfff
#define BIT_PG_UNDER_TH_V1_8821C(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V1_8821C) \
<< BIT_SHIFT_PG_UNDER_TH_V1_8821C)
#define BITS_PG_UNDER_TH_V1_8821C \
(BIT_MASK_PG_UNDER_TH_V1_8821C << BIT_SHIFT_PG_UNDER_TH_V1_8821C)
#define BIT_CLEAR_PG_UNDER_TH_V1_8821C(x) ((x) & (~BITS_PG_UNDER_TH_V1_8821C))
#define BIT_GET_PG_UNDER_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V1_8821C) & \
BIT_MASK_PG_UNDER_TH_V1_8821C)
#define BIT_SET_PG_UNDER_TH_V1_8821C(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V1_8821C(x) | BIT_PG_UNDER_TH_V1_8821C(v))
/* 2 REG_NOT_VALID_8821C */
#define BIT_SDIO_TXDESC_CHKSUM_EN_8821C BIT(13)
#define BIT_RST_RDPTR_8821C BIT(12)
#define BIT_RST_WRPTR_8821C BIT(11)
#define BIT_CHK_PG_TH_EN_8821C BIT(10)
#define BIT_DROP_DATA_EN_8821C BIT(9)
#define BIT_CHECK_OFFSET_EN_8821C BIT(8)
#define BIT_SHIFT_CHECK_OFFSET_8821C 0
#define BIT_MASK_CHECK_OFFSET_8821C 0xff
#define BIT_CHECK_OFFSET_8821C(x) \
(((x) & BIT_MASK_CHECK_OFFSET_8821C) << BIT_SHIFT_CHECK_OFFSET_8821C)
#define BITS_CHECK_OFFSET_8821C \
(BIT_MASK_CHECK_OFFSET_8821C << BIT_SHIFT_CHECK_OFFSET_8821C)
#define BIT_CLEAR_CHECK_OFFSET_8821C(x) ((x) & (~BITS_CHECK_OFFSET_8821C))
#define BIT_GET_CHECK_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_CHECK_OFFSET_8821C) & BIT_MASK_CHECK_OFFSET_8821C)
#define BIT_SET_CHECK_OFFSET_8821C(x, v) \
(BIT_CLEAR_CHECK_OFFSET_8821C(x) | BIT_CHECK_OFFSET_8821C(v))
/* 2 REG_TXDMA_STATUS_8821C */
#define BIT_TXPKTBUF_REQ_ERR_8821C BIT(18)
#define BIT_HI_OQT_UDN_8821C BIT(17)
#define BIT_HI_OQT_OVF_8821C BIT(16)
#define BIT_PAYLOAD_CHKSUM_ERR_8821C BIT(15)
#define BIT_PAYLOAD_UDN_8821C BIT(14)
#define BIT_PAYLOAD_OVF_8821C BIT(13)
#define BIT_DSC_CHKSUM_FAIL_8821C BIT(12)
#define BIT_UNKNOWN_QSEL_8821C BIT(11)
#define BIT_EP_QSEL_DIFF_8821C BIT(10)
#define BIT_TX_OFFS_UNMATCH_8821C BIT(9)
#define BIT_TXOQT_UDN_8821C BIT(8)
#define BIT_TXOQT_OVF_8821C BIT(7)
#define BIT_TXDMA_SFF_UDN_8821C BIT(6)
#define BIT_TXDMA_SFF_OVF_8821C BIT(5)
#define BIT_LLT_NULL_PG_8821C BIT(4)
#define BIT_PAGE_UDN_8821C BIT(3)
#define BIT_PAGE_OVF_8821C BIT(2)
#define BIT_TXFF_PG_UDN_8821C BIT(1)
#define BIT_TXFF_PG_OVF_8821C BIT(0)
/* 2 REG_TX_DMA_DBG_8821C */
/* 2 REG_TQPNT1_8821C */
#define BIT_HPQ_INT_EN_8821C BIT(31)
#define BIT_SHIFT_HPQ_HIGH_TH_V1_8821C 16
#define BIT_MASK_HPQ_HIGH_TH_V1_8821C 0xfff
#define BIT_HPQ_HIGH_TH_V1_8821C(x) \
(((x) & BIT_MASK_HPQ_HIGH_TH_V1_8821C) \
<< BIT_SHIFT_HPQ_HIGH_TH_V1_8821C)
#define BITS_HPQ_HIGH_TH_V1_8821C \
(BIT_MASK_HPQ_HIGH_TH_V1_8821C << BIT_SHIFT_HPQ_HIGH_TH_V1_8821C)
#define BIT_CLEAR_HPQ_HIGH_TH_V1_8821C(x) ((x) & (~BITS_HPQ_HIGH_TH_V1_8821C))
#define BIT_GET_HPQ_HIGH_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_HPQ_HIGH_TH_V1_8821C) & \
BIT_MASK_HPQ_HIGH_TH_V1_8821C)
#define BIT_SET_HPQ_HIGH_TH_V1_8821C(x, v) \
(BIT_CLEAR_HPQ_HIGH_TH_V1_8821C(x) | BIT_HPQ_HIGH_TH_V1_8821C(v))
#define BIT_SHIFT_HPQ_LOW_TH_V1_8821C 0
#define BIT_MASK_HPQ_LOW_TH_V1_8821C 0xfff
#define BIT_HPQ_LOW_TH_V1_8821C(x) \
(((x) & BIT_MASK_HPQ_LOW_TH_V1_8821C) << BIT_SHIFT_HPQ_LOW_TH_V1_8821C)
#define BITS_HPQ_LOW_TH_V1_8821C \
(BIT_MASK_HPQ_LOW_TH_V1_8821C << BIT_SHIFT_HPQ_LOW_TH_V1_8821C)
#define BIT_CLEAR_HPQ_LOW_TH_V1_8821C(x) ((x) & (~BITS_HPQ_LOW_TH_V1_8821C))
#define BIT_GET_HPQ_LOW_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_HPQ_LOW_TH_V1_8821C) & BIT_MASK_HPQ_LOW_TH_V1_8821C)
#define BIT_SET_HPQ_LOW_TH_V1_8821C(x, v) \
(BIT_CLEAR_HPQ_LOW_TH_V1_8821C(x) | BIT_HPQ_LOW_TH_V1_8821C(v))
/* 2 REG_TQPNT2_8821C */
#define BIT_NPQ_INT_EN_8821C BIT(31)
#define BIT_SHIFT_NPQ_HIGH_TH_V1_8821C 16
#define BIT_MASK_NPQ_HIGH_TH_V1_8821C 0xfff
#define BIT_NPQ_HIGH_TH_V1_8821C(x) \
(((x) & BIT_MASK_NPQ_HIGH_TH_V1_8821C) \
<< BIT_SHIFT_NPQ_HIGH_TH_V1_8821C)
#define BITS_NPQ_HIGH_TH_V1_8821C \
(BIT_MASK_NPQ_HIGH_TH_V1_8821C << BIT_SHIFT_NPQ_HIGH_TH_V1_8821C)
#define BIT_CLEAR_NPQ_HIGH_TH_V1_8821C(x) ((x) & (~BITS_NPQ_HIGH_TH_V1_8821C))
#define BIT_GET_NPQ_HIGH_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_NPQ_HIGH_TH_V1_8821C) & \
BIT_MASK_NPQ_HIGH_TH_V1_8821C)
#define BIT_SET_NPQ_HIGH_TH_V1_8821C(x, v) \
(BIT_CLEAR_NPQ_HIGH_TH_V1_8821C(x) | BIT_NPQ_HIGH_TH_V1_8821C(v))
#define BIT_SHIFT_NPQ_LOW_TH_V1_8821C 0
#define BIT_MASK_NPQ_LOW_TH_V1_8821C 0xfff
#define BIT_NPQ_LOW_TH_V1_8821C(x) \
(((x) & BIT_MASK_NPQ_LOW_TH_V1_8821C) << BIT_SHIFT_NPQ_LOW_TH_V1_8821C)
#define BITS_NPQ_LOW_TH_V1_8821C \
(BIT_MASK_NPQ_LOW_TH_V1_8821C << BIT_SHIFT_NPQ_LOW_TH_V1_8821C)
#define BIT_CLEAR_NPQ_LOW_TH_V1_8821C(x) ((x) & (~BITS_NPQ_LOW_TH_V1_8821C))
#define BIT_GET_NPQ_LOW_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_NPQ_LOW_TH_V1_8821C) & BIT_MASK_NPQ_LOW_TH_V1_8821C)
#define BIT_SET_NPQ_LOW_TH_V1_8821C(x, v) \
(BIT_CLEAR_NPQ_LOW_TH_V1_8821C(x) | BIT_NPQ_LOW_TH_V1_8821C(v))
/* 2 REG_TQPNT3_8821C */
#define BIT_LPQ_INT_EN_8821C BIT(31)
#define BIT_SHIFT_LPQ_HIGH_TH_V1_8821C 16
#define BIT_MASK_LPQ_HIGH_TH_V1_8821C 0xfff
#define BIT_LPQ_HIGH_TH_V1_8821C(x) \
(((x) & BIT_MASK_LPQ_HIGH_TH_V1_8821C) \
<< BIT_SHIFT_LPQ_HIGH_TH_V1_8821C)
#define BITS_LPQ_HIGH_TH_V1_8821C \
(BIT_MASK_LPQ_HIGH_TH_V1_8821C << BIT_SHIFT_LPQ_HIGH_TH_V1_8821C)
#define BIT_CLEAR_LPQ_HIGH_TH_V1_8821C(x) ((x) & (~BITS_LPQ_HIGH_TH_V1_8821C))
#define BIT_GET_LPQ_HIGH_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_LPQ_HIGH_TH_V1_8821C) & \
BIT_MASK_LPQ_HIGH_TH_V1_8821C)
#define BIT_SET_LPQ_HIGH_TH_V1_8821C(x, v) \
(BIT_CLEAR_LPQ_HIGH_TH_V1_8821C(x) | BIT_LPQ_HIGH_TH_V1_8821C(v))
#define BIT_SHIFT_LPQ_LOW_TH_V1_8821C 0
#define BIT_MASK_LPQ_LOW_TH_V1_8821C 0xfff
#define BIT_LPQ_LOW_TH_V1_8821C(x) \
(((x) & BIT_MASK_LPQ_LOW_TH_V1_8821C) << BIT_SHIFT_LPQ_LOW_TH_V1_8821C)
#define BITS_LPQ_LOW_TH_V1_8821C \
(BIT_MASK_LPQ_LOW_TH_V1_8821C << BIT_SHIFT_LPQ_LOW_TH_V1_8821C)
#define BIT_CLEAR_LPQ_LOW_TH_V1_8821C(x) ((x) & (~BITS_LPQ_LOW_TH_V1_8821C))
#define BIT_GET_LPQ_LOW_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_LPQ_LOW_TH_V1_8821C) & BIT_MASK_LPQ_LOW_TH_V1_8821C)
#define BIT_SET_LPQ_LOW_TH_V1_8821C(x, v) \
(BIT_CLEAR_LPQ_LOW_TH_V1_8821C(x) | BIT_LPQ_LOW_TH_V1_8821C(v))
/* 2 REG_TQPNT4_8821C */
#define BIT_EXQ_INT_EN_8821C BIT(31)
#define BIT_SHIFT_EXQ_HIGH_TH_V1_8821C 16
#define BIT_MASK_EXQ_HIGH_TH_V1_8821C 0xfff
#define BIT_EXQ_HIGH_TH_V1_8821C(x) \
(((x) & BIT_MASK_EXQ_HIGH_TH_V1_8821C) \
<< BIT_SHIFT_EXQ_HIGH_TH_V1_8821C)
#define BITS_EXQ_HIGH_TH_V1_8821C \
(BIT_MASK_EXQ_HIGH_TH_V1_8821C << BIT_SHIFT_EXQ_HIGH_TH_V1_8821C)
#define BIT_CLEAR_EXQ_HIGH_TH_V1_8821C(x) ((x) & (~BITS_EXQ_HIGH_TH_V1_8821C))
#define BIT_GET_EXQ_HIGH_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_EXQ_HIGH_TH_V1_8821C) & \
BIT_MASK_EXQ_HIGH_TH_V1_8821C)
#define BIT_SET_EXQ_HIGH_TH_V1_8821C(x, v) \
(BIT_CLEAR_EXQ_HIGH_TH_V1_8821C(x) | BIT_EXQ_HIGH_TH_V1_8821C(v))
#define BIT_SHIFT_EXQ_LOW_TH_V1_8821C 0
#define BIT_MASK_EXQ_LOW_TH_V1_8821C 0xfff
#define BIT_EXQ_LOW_TH_V1_8821C(x) \
(((x) & BIT_MASK_EXQ_LOW_TH_V1_8821C) << BIT_SHIFT_EXQ_LOW_TH_V1_8821C)
#define BITS_EXQ_LOW_TH_V1_8821C \
(BIT_MASK_EXQ_LOW_TH_V1_8821C << BIT_SHIFT_EXQ_LOW_TH_V1_8821C)
#define BIT_CLEAR_EXQ_LOW_TH_V1_8821C(x) ((x) & (~BITS_EXQ_LOW_TH_V1_8821C))
#define BIT_GET_EXQ_LOW_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_EXQ_LOW_TH_V1_8821C) & BIT_MASK_EXQ_LOW_TH_V1_8821C)
#define BIT_SET_EXQ_LOW_TH_V1_8821C(x, v) \
(BIT_CLEAR_EXQ_LOW_TH_V1_8821C(x) | BIT_EXQ_LOW_TH_V1_8821C(v))
/* 2 REG_RQPN_CTRL_1_8821C */
#define BIT_SHIFT_TXPKTNUM_H_8821C 16
#define BIT_MASK_TXPKTNUM_H_8821C 0xffff
#define BIT_TXPKTNUM_H_8821C(x) \
(((x) & BIT_MASK_TXPKTNUM_H_8821C) << BIT_SHIFT_TXPKTNUM_H_8821C)
#define BITS_TXPKTNUM_H_8821C \
(BIT_MASK_TXPKTNUM_H_8821C << BIT_SHIFT_TXPKTNUM_H_8821C)
#define BIT_CLEAR_TXPKTNUM_H_8821C(x) ((x) & (~BITS_TXPKTNUM_H_8821C))
#define BIT_GET_TXPKTNUM_H_8821C(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_8821C) & BIT_MASK_TXPKTNUM_H_8821C)
#define BIT_SET_TXPKTNUM_H_8821C(x, v) \
(BIT_CLEAR_TXPKTNUM_H_8821C(x) | BIT_TXPKTNUM_H_8821C(v))
#define BIT_SHIFT_TXPKTNUM_V2_8821C 0
#define BIT_MASK_TXPKTNUM_V2_8821C 0xffff
#define BIT_TXPKTNUM_V2_8821C(x) \
(((x) & BIT_MASK_TXPKTNUM_V2_8821C) << BIT_SHIFT_TXPKTNUM_V2_8821C)
#define BITS_TXPKTNUM_V2_8821C \
(BIT_MASK_TXPKTNUM_V2_8821C << BIT_SHIFT_TXPKTNUM_V2_8821C)
#define BIT_CLEAR_TXPKTNUM_V2_8821C(x) ((x) & (~BITS_TXPKTNUM_V2_8821C))
#define BIT_GET_TXPKTNUM_V2_8821C(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_V2_8821C) & BIT_MASK_TXPKTNUM_V2_8821C)
#define BIT_SET_TXPKTNUM_V2_8821C(x, v) \
(BIT_CLEAR_TXPKTNUM_V2_8821C(x) | BIT_TXPKTNUM_V2_8821C(v))
/* 2 REG_RQPN_CTRL_2_8821C */
#define BIT_LD_RQPN_8821C BIT(31)
#define BIT_EXQ_PUBLIC_DIS_V1_8821C BIT(19)
#define BIT_NPQ_PUBLIC_DIS_V1_8821C BIT(18)
#define BIT_LPQ_PUBLIC_DIS_V1_8821C BIT(17)
#define BIT_HPQ_PUBLIC_DIS_V1_8821C BIT(16)
#define BIT_SDIO_TXAGG_ALIGN_ADJUST_EN_8821C BIT(15)
#define BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8821C 0
#define BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8821C 0xfff
#define BIT_SDIO_TXAGG_ALIGN_SIZE_8821C(x) \
(((x) & BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8821C) \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8821C)
#define BITS_SDIO_TXAGG_ALIGN_SIZE_8821C \
(BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8821C \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8821C)
#define BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_8821C(x) \
((x) & (~BITS_SDIO_TXAGG_ALIGN_SIZE_8821C))
#define BIT_GET_SDIO_TXAGG_ALIGN_SIZE_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8821C) & \
BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8821C)
#define BIT_SET_SDIO_TXAGG_ALIGN_SIZE_8821C(x, v) \
(BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_8821C(x) | \
BIT_SDIO_TXAGG_ALIGN_SIZE_8821C(v))
/* 2 REG_FIFOPAGE_INFO_1_8821C */
#define BIT_SHIFT_HPQ_AVAL_PG_V1_8821C 16
#define BIT_MASK_HPQ_AVAL_PG_V1_8821C 0xfff
#define BIT_HPQ_AVAL_PG_V1_8821C(x) \
(((x) & BIT_MASK_HPQ_AVAL_PG_V1_8821C) \
<< BIT_SHIFT_HPQ_AVAL_PG_V1_8821C)
#define BITS_HPQ_AVAL_PG_V1_8821C \
(BIT_MASK_HPQ_AVAL_PG_V1_8821C << BIT_SHIFT_HPQ_AVAL_PG_V1_8821C)
#define BIT_CLEAR_HPQ_AVAL_PG_V1_8821C(x) ((x) & (~BITS_HPQ_AVAL_PG_V1_8821C))
#define BIT_GET_HPQ_AVAL_PG_V1_8821C(x) \
(((x) >> BIT_SHIFT_HPQ_AVAL_PG_V1_8821C) & \
BIT_MASK_HPQ_AVAL_PG_V1_8821C)
#define BIT_SET_HPQ_AVAL_PG_V1_8821C(x, v) \
(BIT_CLEAR_HPQ_AVAL_PG_V1_8821C(x) | BIT_HPQ_AVAL_PG_V1_8821C(v))
#define BIT_SHIFT_HPQ_V1_8821C 0
#define BIT_MASK_HPQ_V1_8821C 0xfff
#define BIT_HPQ_V1_8821C(x) \
(((x) & BIT_MASK_HPQ_V1_8821C) << BIT_SHIFT_HPQ_V1_8821C)
#define BITS_HPQ_V1_8821C (BIT_MASK_HPQ_V1_8821C << BIT_SHIFT_HPQ_V1_8821C)
#define BIT_CLEAR_HPQ_V1_8821C(x) ((x) & (~BITS_HPQ_V1_8821C))
#define BIT_GET_HPQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_HPQ_V1_8821C) & BIT_MASK_HPQ_V1_8821C)
#define BIT_SET_HPQ_V1_8821C(x, v) \
(BIT_CLEAR_HPQ_V1_8821C(x) | BIT_HPQ_V1_8821C(v))
/* 2 REG_FIFOPAGE_INFO_2_8821C */
#define BIT_SHIFT_LPQ_AVAL_PG_V1_8821C 16
#define BIT_MASK_LPQ_AVAL_PG_V1_8821C 0xfff
#define BIT_LPQ_AVAL_PG_V1_8821C(x) \
(((x) & BIT_MASK_LPQ_AVAL_PG_V1_8821C) \
<< BIT_SHIFT_LPQ_AVAL_PG_V1_8821C)
#define BITS_LPQ_AVAL_PG_V1_8821C \
(BIT_MASK_LPQ_AVAL_PG_V1_8821C << BIT_SHIFT_LPQ_AVAL_PG_V1_8821C)
#define BIT_CLEAR_LPQ_AVAL_PG_V1_8821C(x) ((x) & (~BITS_LPQ_AVAL_PG_V1_8821C))
#define BIT_GET_LPQ_AVAL_PG_V1_8821C(x) \
(((x) >> BIT_SHIFT_LPQ_AVAL_PG_V1_8821C) & \
BIT_MASK_LPQ_AVAL_PG_V1_8821C)
#define BIT_SET_LPQ_AVAL_PG_V1_8821C(x, v) \
(BIT_CLEAR_LPQ_AVAL_PG_V1_8821C(x) | BIT_LPQ_AVAL_PG_V1_8821C(v))
#define BIT_SHIFT_LPQ_V1_8821C 0
#define BIT_MASK_LPQ_V1_8821C 0xfff
#define BIT_LPQ_V1_8821C(x) \
(((x) & BIT_MASK_LPQ_V1_8821C) << BIT_SHIFT_LPQ_V1_8821C)
#define BITS_LPQ_V1_8821C (BIT_MASK_LPQ_V1_8821C << BIT_SHIFT_LPQ_V1_8821C)
#define BIT_CLEAR_LPQ_V1_8821C(x) ((x) & (~BITS_LPQ_V1_8821C))
#define BIT_GET_LPQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_LPQ_V1_8821C) & BIT_MASK_LPQ_V1_8821C)
#define BIT_SET_LPQ_V1_8821C(x, v) \
(BIT_CLEAR_LPQ_V1_8821C(x) | BIT_LPQ_V1_8821C(v))
/* 2 REG_FIFOPAGE_INFO_3_8821C */
#define BIT_SHIFT_NPQ_AVAL_PG_V1_8821C 16
#define BIT_MASK_NPQ_AVAL_PG_V1_8821C 0xfff
#define BIT_NPQ_AVAL_PG_V1_8821C(x) \
(((x) & BIT_MASK_NPQ_AVAL_PG_V1_8821C) \
<< BIT_SHIFT_NPQ_AVAL_PG_V1_8821C)
#define BITS_NPQ_AVAL_PG_V1_8821C \
(BIT_MASK_NPQ_AVAL_PG_V1_8821C << BIT_SHIFT_NPQ_AVAL_PG_V1_8821C)
#define BIT_CLEAR_NPQ_AVAL_PG_V1_8821C(x) ((x) & (~BITS_NPQ_AVAL_PG_V1_8821C))
#define BIT_GET_NPQ_AVAL_PG_V1_8821C(x) \
(((x) >> BIT_SHIFT_NPQ_AVAL_PG_V1_8821C) & \
BIT_MASK_NPQ_AVAL_PG_V1_8821C)
#define BIT_SET_NPQ_AVAL_PG_V1_8821C(x, v) \
(BIT_CLEAR_NPQ_AVAL_PG_V1_8821C(x) | BIT_NPQ_AVAL_PG_V1_8821C(v))
#define BIT_SHIFT_NPQ_V1_8821C 0
#define BIT_MASK_NPQ_V1_8821C 0xfff
#define BIT_NPQ_V1_8821C(x) \
(((x) & BIT_MASK_NPQ_V1_8821C) << BIT_SHIFT_NPQ_V1_8821C)
#define BITS_NPQ_V1_8821C (BIT_MASK_NPQ_V1_8821C << BIT_SHIFT_NPQ_V1_8821C)
#define BIT_CLEAR_NPQ_V1_8821C(x) ((x) & (~BITS_NPQ_V1_8821C))
#define BIT_GET_NPQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_NPQ_V1_8821C) & BIT_MASK_NPQ_V1_8821C)
#define BIT_SET_NPQ_V1_8821C(x, v) \
(BIT_CLEAR_NPQ_V1_8821C(x) | BIT_NPQ_V1_8821C(v))
/* 2 REG_FIFOPAGE_INFO_4_8821C */
#define BIT_SHIFT_EXQ_AVAL_PG_V1_8821C 16
#define BIT_MASK_EXQ_AVAL_PG_V1_8821C 0xfff
#define BIT_EXQ_AVAL_PG_V1_8821C(x) \
(((x) & BIT_MASK_EXQ_AVAL_PG_V1_8821C) \
<< BIT_SHIFT_EXQ_AVAL_PG_V1_8821C)
#define BITS_EXQ_AVAL_PG_V1_8821C \
(BIT_MASK_EXQ_AVAL_PG_V1_8821C << BIT_SHIFT_EXQ_AVAL_PG_V1_8821C)
#define BIT_CLEAR_EXQ_AVAL_PG_V1_8821C(x) ((x) & (~BITS_EXQ_AVAL_PG_V1_8821C))
#define BIT_GET_EXQ_AVAL_PG_V1_8821C(x) \
(((x) >> BIT_SHIFT_EXQ_AVAL_PG_V1_8821C) & \
BIT_MASK_EXQ_AVAL_PG_V1_8821C)
#define BIT_SET_EXQ_AVAL_PG_V1_8821C(x, v) \
(BIT_CLEAR_EXQ_AVAL_PG_V1_8821C(x) | BIT_EXQ_AVAL_PG_V1_8821C(v))
#define BIT_SHIFT_EXQ_V1_8821C 0
#define BIT_MASK_EXQ_V1_8821C 0xfff
#define BIT_EXQ_V1_8821C(x) \
(((x) & BIT_MASK_EXQ_V1_8821C) << BIT_SHIFT_EXQ_V1_8821C)
#define BITS_EXQ_V1_8821C (BIT_MASK_EXQ_V1_8821C << BIT_SHIFT_EXQ_V1_8821C)
#define BIT_CLEAR_EXQ_V1_8821C(x) ((x) & (~BITS_EXQ_V1_8821C))
#define BIT_GET_EXQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_EXQ_V1_8821C) & BIT_MASK_EXQ_V1_8821C)
#define BIT_SET_EXQ_V1_8821C(x, v) \
(BIT_CLEAR_EXQ_V1_8821C(x) | BIT_EXQ_V1_8821C(v))
/* 2 REG_FIFOPAGE_INFO_5_8821C */
#define BIT_SHIFT_PUBQ_AVAL_PG_V1_8821C 16
#define BIT_MASK_PUBQ_AVAL_PG_V1_8821C 0xfff
#define BIT_PUBQ_AVAL_PG_V1_8821C(x) \
(((x) & BIT_MASK_PUBQ_AVAL_PG_V1_8821C) \
<< BIT_SHIFT_PUBQ_AVAL_PG_V1_8821C)
#define BITS_PUBQ_AVAL_PG_V1_8821C \
(BIT_MASK_PUBQ_AVAL_PG_V1_8821C << BIT_SHIFT_PUBQ_AVAL_PG_V1_8821C)
#define BIT_CLEAR_PUBQ_AVAL_PG_V1_8821C(x) ((x) & (~BITS_PUBQ_AVAL_PG_V1_8821C))
#define BIT_GET_PUBQ_AVAL_PG_V1_8821C(x) \
(((x) >> BIT_SHIFT_PUBQ_AVAL_PG_V1_8821C) & \
BIT_MASK_PUBQ_AVAL_PG_V1_8821C)
#define BIT_SET_PUBQ_AVAL_PG_V1_8821C(x, v) \
(BIT_CLEAR_PUBQ_AVAL_PG_V1_8821C(x) | BIT_PUBQ_AVAL_PG_V1_8821C(v))
#define BIT_SHIFT_PUBQ_V1_8821C 0
#define BIT_MASK_PUBQ_V1_8821C 0xfff
#define BIT_PUBQ_V1_8821C(x) \
(((x) & BIT_MASK_PUBQ_V1_8821C) << BIT_SHIFT_PUBQ_V1_8821C)
#define BITS_PUBQ_V1_8821C (BIT_MASK_PUBQ_V1_8821C << BIT_SHIFT_PUBQ_V1_8821C)
#define BIT_CLEAR_PUBQ_V1_8821C(x) ((x) & (~BITS_PUBQ_V1_8821C))
#define BIT_GET_PUBQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_PUBQ_V1_8821C) & BIT_MASK_PUBQ_V1_8821C)
#define BIT_SET_PUBQ_V1_8821C(x, v) \
(BIT_CLEAR_PUBQ_V1_8821C(x) | BIT_PUBQ_V1_8821C(v))
/* 2 REG_H2C_HEAD_8821C */
#define BIT_SHIFT_H2C_HEAD_8821C 0
#define BIT_MASK_H2C_HEAD_8821C 0x3ffff
#define BIT_H2C_HEAD_8821C(x) \
(((x) & BIT_MASK_H2C_HEAD_8821C) << BIT_SHIFT_H2C_HEAD_8821C)
#define BITS_H2C_HEAD_8821C \
(BIT_MASK_H2C_HEAD_8821C << BIT_SHIFT_H2C_HEAD_8821C)
#define BIT_CLEAR_H2C_HEAD_8821C(x) ((x) & (~BITS_H2C_HEAD_8821C))
#define BIT_GET_H2C_HEAD_8821C(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_8821C) & BIT_MASK_H2C_HEAD_8821C)
#define BIT_SET_H2C_HEAD_8821C(x, v) \
(BIT_CLEAR_H2C_HEAD_8821C(x) | BIT_H2C_HEAD_8821C(v))
/* 2 REG_H2C_TAIL_8821C */
#define BIT_SHIFT_H2C_TAIL_8821C 0
#define BIT_MASK_H2C_TAIL_8821C 0x3ffff
#define BIT_H2C_TAIL_8821C(x) \
(((x) & BIT_MASK_H2C_TAIL_8821C) << BIT_SHIFT_H2C_TAIL_8821C)
#define BITS_H2C_TAIL_8821C \
(BIT_MASK_H2C_TAIL_8821C << BIT_SHIFT_H2C_TAIL_8821C)
#define BIT_CLEAR_H2C_TAIL_8821C(x) ((x) & (~BITS_H2C_TAIL_8821C))
#define BIT_GET_H2C_TAIL_8821C(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_8821C) & BIT_MASK_H2C_TAIL_8821C)
#define BIT_SET_H2C_TAIL_8821C(x, v) \
(BIT_CLEAR_H2C_TAIL_8821C(x) | BIT_H2C_TAIL_8821C(v))
/* 2 REG_H2C_READ_ADDR_8821C */
#define BIT_SHIFT_H2C_READ_ADDR_8821C 0
#define BIT_MASK_H2C_READ_ADDR_8821C 0x3ffff
#define BIT_H2C_READ_ADDR_8821C(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_8821C) << BIT_SHIFT_H2C_READ_ADDR_8821C)
#define BITS_H2C_READ_ADDR_8821C \
(BIT_MASK_H2C_READ_ADDR_8821C << BIT_SHIFT_H2C_READ_ADDR_8821C)
#define BIT_CLEAR_H2C_READ_ADDR_8821C(x) ((x) & (~BITS_H2C_READ_ADDR_8821C))
#define BIT_GET_H2C_READ_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_8821C) & BIT_MASK_H2C_READ_ADDR_8821C)
#define BIT_SET_H2C_READ_ADDR_8821C(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_8821C(x) | BIT_H2C_READ_ADDR_8821C(v))
/* 2 REG_H2C_WR_ADDR_8821C */
#define BIT_SHIFT_H2C_WR_ADDR_8821C 0
#define BIT_MASK_H2C_WR_ADDR_8821C 0x3ffff
#define BIT_H2C_WR_ADDR_8821C(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_8821C) << BIT_SHIFT_H2C_WR_ADDR_8821C)
#define BITS_H2C_WR_ADDR_8821C \
(BIT_MASK_H2C_WR_ADDR_8821C << BIT_SHIFT_H2C_WR_ADDR_8821C)
#define BIT_CLEAR_H2C_WR_ADDR_8821C(x) ((x) & (~BITS_H2C_WR_ADDR_8821C))
#define BIT_GET_H2C_WR_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_8821C) & BIT_MASK_H2C_WR_ADDR_8821C)
#define BIT_SET_H2C_WR_ADDR_8821C(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_8821C(x) | BIT_H2C_WR_ADDR_8821C(v))
/* 2 REG_H2C_INFO_8821C */
#define BIT_H2C_SPACE_VLD_8821C BIT(3)
#define BIT_H2C_WR_ADDR_RST_8821C BIT(2)
#define BIT_SHIFT_H2C_LEN_SEL_8821C 0
#define BIT_MASK_H2C_LEN_SEL_8821C 0x3
#define BIT_H2C_LEN_SEL_8821C(x) \
(((x) & BIT_MASK_H2C_LEN_SEL_8821C) << BIT_SHIFT_H2C_LEN_SEL_8821C)
#define BITS_H2C_LEN_SEL_8821C \
(BIT_MASK_H2C_LEN_SEL_8821C << BIT_SHIFT_H2C_LEN_SEL_8821C)
#define BIT_CLEAR_H2C_LEN_SEL_8821C(x) ((x) & (~BITS_H2C_LEN_SEL_8821C))
#define BIT_GET_H2C_LEN_SEL_8821C(x) \
(((x) >> BIT_SHIFT_H2C_LEN_SEL_8821C) & BIT_MASK_H2C_LEN_SEL_8821C)
#define BIT_SET_H2C_LEN_SEL_8821C(x, v) \
(BIT_CLEAR_H2C_LEN_SEL_8821C(x) | BIT_H2C_LEN_SEL_8821C(v))
/* 2 REG_RXDMA_AGG_PG_TH_8821C */
#define BIT_USB_RXDMA_AGG_EN_8821C BIT(31)
#define BIT_EN_PRE_CALC_8821C BIT(29)
#define BIT_RXAGG_SW_EN_8821C BIT(28)
#define BIT_RXAGG_SW_TRIG_8821C BIT(27)
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_PKT_NUM_WOL_8821C 16
#define BIT_MASK_PKT_NUM_WOL_8821C 0xff
#define BIT_PKT_NUM_WOL_8821C(x) \
(((x) & BIT_MASK_PKT_NUM_WOL_8821C) << BIT_SHIFT_PKT_NUM_WOL_8821C)
#define BITS_PKT_NUM_WOL_8821C \
(BIT_MASK_PKT_NUM_WOL_8821C << BIT_SHIFT_PKT_NUM_WOL_8821C)
#define BIT_CLEAR_PKT_NUM_WOL_8821C(x) ((x) & (~BITS_PKT_NUM_WOL_8821C))
#define BIT_GET_PKT_NUM_WOL_8821C(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL_8821C) & BIT_MASK_PKT_NUM_WOL_8821C)
#define BIT_SET_PKT_NUM_WOL_8821C(x, v) \
(BIT_CLEAR_PKT_NUM_WOL_8821C(x) | BIT_PKT_NUM_WOL_8821C(v))
#define BIT_SHIFT_DMA_AGG_TO_V1_8821C 8
#define BIT_MASK_DMA_AGG_TO_V1_8821C 0xff
#define BIT_DMA_AGG_TO_V1_8821C(x) \
(((x) & BIT_MASK_DMA_AGG_TO_V1_8821C) << BIT_SHIFT_DMA_AGG_TO_V1_8821C)
#define BITS_DMA_AGG_TO_V1_8821C \
(BIT_MASK_DMA_AGG_TO_V1_8821C << BIT_SHIFT_DMA_AGG_TO_V1_8821C)
#define BIT_CLEAR_DMA_AGG_TO_V1_8821C(x) ((x) & (~BITS_DMA_AGG_TO_V1_8821C))
#define BIT_GET_DMA_AGG_TO_V1_8821C(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO_V1_8821C) & BIT_MASK_DMA_AGG_TO_V1_8821C)
#define BIT_SET_DMA_AGG_TO_V1_8821C(x, v) \
(BIT_CLEAR_DMA_AGG_TO_V1_8821C(x) | BIT_DMA_AGG_TO_V1_8821C(v))
#define BIT_SHIFT_RXDMA_AGG_PG_TH_8821C 0
#define BIT_MASK_RXDMA_AGG_PG_TH_8821C 0xff
#define BIT_RXDMA_AGG_PG_TH_8821C(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_8821C) \
<< BIT_SHIFT_RXDMA_AGG_PG_TH_8821C)
#define BITS_RXDMA_AGG_PG_TH_8821C \
(BIT_MASK_RXDMA_AGG_PG_TH_8821C << BIT_SHIFT_RXDMA_AGG_PG_TH_8821C)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_8821C(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_8821C))
#define BIT_GET_RXDMA_AGG_PG_TH_8821C(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_8821C) & \
BIT_MASK_RXDMA_AGG_PG_TH_8821C)
#define BIT_SET_RXDMA_AGG_PG_TH_8821C(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_8821C(x) | BIT_RXDMA_AGG_PG_TH_8821C(v))
/* 2 REG_RXPKT_NUM_8821C */
#define BIT_SHIFT_RXPKT_NUM_8821C 24
#define BIT_MASK_RXPKT_NUM_8821C 0xff
#define BIT_RXPKT_NUM_8821C(x) \
(((x) & BIT_MASK_RXPKT_NUM_8821C) << BIT_SHIFT_RXPKT_NUM_8821C)
#define BITS_RXPKT_NUM_8821C \
(BIT_MASK_RXPKT_NUM_8821C << BIT_SHIFT_RXPKT_NUM_8821C)
#define BIT_CLEAR_RXPKT_NUM_8821C(x) ((x) & (~BITS_RXPKT_NUM_8821C))
#define BIT_GET_RXPKT_NUM_8821C(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_8821C) & BIT_MASK_RXPKT_NUM_8821C)
#define BIT_SET_RXPKT_NUM_8821C(x, v) \
(BIT_CLEAR_RXPKT_NUM_8821C(x) | BIT_RXPKT_NUM_8821C(v))
#define BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8821C 20
#define BIT_MASK_FW_UPD_RDPTR19_TO_16_8821C 0xf
#define BIT_FW_UPD_RDPTR19_TO_16_8821C(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR19_TO_16_8821C) \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8821C)
#define BITS_FW_UPD_RDPTR19_TO_16_8821C \
(BIT_MASK_FW_UPD_RDPTR19_TO_16_8821C \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8821C)
#define BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8821C(x) \
((x) & (~BITS_FW_UPD_RDPTR19_TO_16_8821C))
#define BIT_GET_FW_UPD_RDPTR19_TO_16_8821C(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8821C) & \
BIT_MASK_FW_UPD_RDPTR19_TO_16_8821C)
#define BIT_SET_FW_UPD_RDPTR19_TO_16_8821C(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8821C(x) | \
BIT_FW_UPD_RDPTR19_TO_16_8821C(v))
#define BIT_RXDMA_REQ_8821C BIT(19)
#define BIT_RW_RELEASE_EN_8821C BIT(18)
#define BIT_RXDMA_IDLE_8821C BIT(17)
#define BIT_RXPKT_RELEASE_POLL_8821C BIT(16)
#define BIT_SHIFT_FW_UPD_RDPTR_8821C 0
#define BIT_MASK_FW_UPD_RDPTR_8821C 0xffff
#define BIT_FW_UPD_RDPTR_8821C(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR_8821C) << BIT_SHIFT_FW_UPD_RDPTR_8821C)
#define BITS_FW_UPD_RDPTR_8821C \
(BIT_MASK_FW_UPD_RDPTR_8821C << BIT_SHIFT_FW_UPD_RDPTR_8821C)
#define BIT_CLEAR_FW_UPD_RDPTR_8821C(x) ((x) & (~BITS_FW_UPD_RDPTR_8821C))
#define BIT_GET_FW_UPD_RDPTR_8821C(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR_8821C) & BIT_MASK_FW_UPD_RDPTR_8821C)
#define BIT_SET_FW_UPD_RDPTR_8821C(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR_8821C(x) | BIT_FW_UPD_RDPTR_8821C(v))
/* 2 REG_RXDMA_STATUS_8821C */
#define BIT_C2H_PKT_OVF_8821C BIT(7)
#define BIT_AGG_CONFGI_ISSUE_8821C BIT(6)
#define BIT_FW_POLL_ISSUE_8821C BIT(5)
#define BIT_RX_DATA_UDN_8821C BIT(4)
#define BIT_RX_SFF_UDN_8821C BIT(3)
#define BIT_RX_SFF_OVF_8821C BIT(2)
#define BIT_RXPKT_OVF_8821C BIT(0)
/* 2 REG_RXDMA_DPR_8821C */
#define BIT_SHIFT_RDE_DEBUG_8821C 0
#define BIT_MASK_RDE_DEBUG_8821C 0xffffffffL
#define BIT_RDE_DEBUG_8821C(x) \
(((x) & BIT_MASK_RDE_DEBUG_8821C) << BIT_SHIFT_RDE_DEBUG_8821C)
#define BITS_RDE_DEBUG_8821C \
(BIT_MASK_RDE_DEBUG_8821C << BIT_SHIFT_RDE_DEBUG_8821C)
#define BIT_CLEAR_RDE_DEBUG_8821C(x) ((x) & (~BITS_RDE_DEBUG_8821C))
#define BIT_GET_RDE_DEBUG_8821C(x) \
(((x) >> BIT_SHIFT_RDE_DEBUG_8821C) & BIT_MASK_RDE_DEBUG_8821C)
#define BIT_SET_RDE_DEBUG_8821C(x, v) \
(BIT_CLEAR_RDE_DEBUG_8821C(x) | BIT_RDE_DEBUG_8821C(v))
/* 2 REG_RXDMA_MODE_8821C */
#define BIT_SHIFT_PKTNUM_TH_V2_8821C 24
#define BIT_MASK_PKTNUM_TH_V2_8821C 0x1f
#define BIT_PKTNUM_TH_V2_8821C(x) \
(((x) & BIT_MASK_PKTNUM_TH_V2_8821C) << BIT_SHIFT_PKTNUM_TH_V2_8821C)
#define BITS_PKTNUM_TH_V2_8821C \
(BIT_MASK_PKTNUM_TH_V2_8821C << BIT_SHIFT_PKTNUM_TH_V2_8821C)
#define BIT_CLEAR_PKTNUM_TH_V2_8821C(x) ((x) & (~BITS_PKTNUM_TH_V2_8821C))
#define BIT_GET_PKTNUM_TH_V2_8821C(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V2_8821C) & BIT_MASK_PKTNUM_TH_V2_8821C)
#define BIT_SET_PKTNUM_TH_V2_8821C(x, v) \
(BIT_CLEAR_PKTNUM_TH_V2_8821C(x) | BIT_PKTNUM_TH_V2_8821C(v))
#define BIT_TXBA_BREAK_USBAGG_8821C BIT(23)
#define BIT_SHIFT_PKTLEN_PARA_8821C 16
#define BIT_MASK_PKTLEN_PARA_8821C 0x7
#define BIT_PKTLEN_PARA_8821C(x) \
(((x) & BIT_MASK_PKTLEN_PARA_8821C) << BIT_SHIFT_PKTLEN_PARA_8821C)
#define BITS_PKTLEN_PARA_8821C \
(BIT_MASK_PKTLEN_PARA_8821C << BIT_SHIFT_PKTLEN_PARA_8821C)
#define BIT_CLEAR_PKTLEN_PARA_8821C(x) ((x) & (~BITS_PKTLEN_PARA_8821C))
#define BIT_GET_PKTLEN_PARA_8821C(x) \
(((x) >> BIT_SHIFT_PKTLEN_PARA_8821C) & BIT_MASK_PKTLEN_PARA_8821C)
#define BIT_SET_PKTLEN_PARA_8821C(x, v) \
(BIT_CLEAR_PKTLEN_PARA_8821C(x) | BIT_PKTLEN_PARA_8821C(v))
#define BIT_SHIFT_BURST_SIZE_8821C 4
#define BIT_MASK_BURST_SIZE_8821C 0x3
#define BIT_BURST_SIZE_8821C(x) \
(((x) & BIT_MASK_BURST_SIZE_8821C) << BIT_SHIFT_BURST_SIZE_8821C)
#define BITS_BURST_SIZE_8821C \
(BIT_MASK_BURST_SIZE_8821C << BIT_SHIFT_BURST_SIZE_8821C)
#define BIT_CLEAR_BURST_SIZE_8821C(x) ((x) & (~BITS_BURST_SIZE_8821C))
#define BIT_GET_BURST_SIZE_8821C(x) \
(((x) >> BIT_SHIFT_BURST_SIZE_8821C) & BIT_MASK_BURST_SIZE_8821C)
#define BIT_SET_BURST_SIZE_8821C(x, v) \
(BIT_CLEAR_BURST_SIZE_8821C(x) | BIT_BURST_SIZE_8821C(v))
#define BIT_SHIFT_BURST_CNT_8821C 2
#define BIT_MASK_BURST_CNT_8821C 0x3
#define BIT_BURST_CNT_8821C(x) \
(((x) & BIT_MASK_BURST_CNT_8821C) << BIT_SHIFT_BURST_CNT_8821C)
#define BITS_BURST_CNT_8821C \
(BIT_MASK_BURST_CNT_8821C << BIT_SHIFT_BURST_CNT_8821C)
#define BIT_CLEAR_BURST_CNT_8821C(x) ((x) & (~BITS_BURST_CNT_8821C))
#define BIT_GET_BURST_CNT_8821C(x) \
(((x) >> BIT_SHIFT_BURST_CNT_8821C) & BIT_MASK_BURST_CNT_8821C)
#define BIT_SET_BURST_CNT_8821C(x, v) \
(BIT_CLEAR_BURST_CNT_8821C(x) | BIT_BURST_CNT_8821C(v))
#define BIT_DMA_MODE_8821C BIT(1)
/* 2 REG_C2H_PKT_8821C */
#define BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8821C 24
#define BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8821C 0xf
#define BIT_R_C2H_STR_ADDR_16_TO_19_8821C(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8821C) \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8821C)
#define BITS_R_C2H_STR_ADDR_16_TO_19_8821C \
(BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8821C \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8821C)
#define BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8821C(x) \
((x) & (~BITS_R_C2H_STR_ADDR_16_TO_19_8821C))
#define BIT_GET_R_C2H_STR_ADDR_16_TO_19_8821C(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8821C) & \
BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8821C)
#define BIT_SET_R_C2H_STR_ADDR_16_TO_19_8821C(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8821C(x) | \
BIT_R_C2H_STR_ADDR_16_TO_19_8821C(v))
#define BIT_R_C2H_PKT_REQ_8821C BIT(16)
#define BIT_SHIFT_R_C2H_STR_ADDR_8821C 0
#define BIT_MASK_R_C2H_STR_ADDR_8821C 0xffff
#define BIT_R_C2H_STR_ADDR_8821C(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_8821C) \
<< BIT_SHIFT_R_C2H_STR_ADDR_8821C)
#define BITS_R_C2H_STR_ADDR_8821C \
(BIT_MASK_R_C2H_STR_ADDR_8821C << BIT_SHIFT_R_C2H_STR_ADDR_8821C)
#define BIT_CLEAR_R_C2H_STR_ADDR_8821C(x) ((x) & (~BITS_R_C2H_STR_ADDR_8821C))
#define BIT_GET_R_C2H_STR_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_8821C) & \
BIT_MASK_R_C2H_STR_ADDR_8821C)
#define BIT_SET_R_C2H_STR_ADDR_8821C(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_8821C(x) | BIT_R_C2H_STR_ADDR_8821C(v))
/* 2 REG_FWFF_C2H_8821C */
#define BIT_SHIFT_C2H_DMA_ADDR_8821C 0
#define BIT_MASK_C2H_DMA_ADDR_8821C 0x3ffff
#define BIT_C2H_DMA_ADDR_8821C(x) \
(((x) & BIT_MASK_C2H_DMA_ADDR_8821C) << BIT_SHIFT_C2H_DMA_ADDR_8821C)
#define BITS_C2H_DMA_ADDR_8821C \
(BIT_MASK_C2H_DMA_ADDR_8821C << BIT_SHIFT_C2H_DMA_ADDR_8821C)
#define BIT_CLEAR_C2H_DMA_ADDR_8821C(x) ((x) & (~BITS_C2H_DMA_ADDR_8821C))
#define BIT_GET_C2H_DMA_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_C2H_DMA_ADDR_8821C) & BIT_MASK_C2H_DMA_ADDR_8821C)
#define BIT_SET_C2H_DMA_ADDR_8821C(x, v) \
(BIT_CLEAR_C2H_DMA_ADDR_8821C(x) | BIT_C2H_DMA_ADDR_8821C(v))
/* 2 REG_FWFF_CTRL_8821C */
#define BIT_FWFF_DMAPKT_REQ_8821C BIT(31)
#define BIT_SHIFT_FWFF_DMA_PKT_NUM_8821C 16
#define BIT_MASK_FWFF_DMA_PKT_NUM_8821C 0xff
#define BIT_FWFF_DMA_PKT_NUM_8821C(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM_8821C) \
<< BIT_SHIFT_FWFF_DMA_PKT_NUM_8821C)
#define BITS_FWFF_DMA_PKT_NUM_8821C \
(BIT_MASK_FWFF_DMA_PKT_NUM_8821C << BIT_SHIFT_FWFF_DMA_PKT_NUM_8821C)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM_8821C(x) \
((x) & (~BITS_FWFF_DMA_PKT_NUM_8821C))
#define BIT_GET_FWFF_DMA_PKT_NUM_8821C(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM_8821C) & \
BIT_MASK_FWFF_DMA_PKT_NUM_8821C)
#define BIT_SET_FWFF_DMA_PKT_NUM_8821C(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM_8821C(x) | BIT_FWFF_DMA_PKT_NUM_8821C(v))
#define BIT_SHIFT_FWFF_STR_ADDR_8821C 0
#define BIT_MASK_FWFF_STR_ADDR_8821C 0xffff
#define BIT_FWFF_STR_ADDR_8821C(x) \
(((x) & BIT_MASK_FWFF_STR_ADDR_8821C) << BIT_SHIFT_FWFF_STR_ADDR_8821C)
#define BITS_FWFF_STR_ADDR_8821C \
(BIT_MASK_FWFF_STR_ADDR_8821C << BIT_SHIFT_FWFF_STR_ADDR_8821C)
#define BIT_CLEAR_FWFF_STR_ADDR_8821C(x) ((x) & (~BITS_FWFF_STR_ADDR_8821C))
#define BIT_GET_FWFF_STR_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_FWFF_STR_ADDR_8821C) & BIT_MASK_FWFF_STR_ADDR_8821C)
#define BIT_SET_FWFF_STR_ADDR_8821C(x, v) \
(BIT_CLEAR_FWFF_STR_ADDR_8821C(x) | BIT_FWFF_STR_ADDR_8821C(v))
/* 2 REG_FWFF_PKT_INFO_8821C */
#define BIT_SHIFT_FWFF_PKT_QUEUED_8821C 16
#define BIT_MASK_FWFF_PKT_QUEUED_8821C 0xff
#define BIT_FWFF_PKT_QUEUED_8821C(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED_8821C) \
<< BIT_SHIFT_FWFF_PKT_QUEUED_8821C)
#define BITS_FWFF_PKT_QUEUED_8821C \
(BIT_MASK_FWFF_PKT_QUEUED_8821C << BIT_SHIFT_FWFF_PKT_QUEUED_8821C)
#define BIT_CLEAR_FWFF_PKT_QUEUED_8821C(x) ((x) & (~BITS_FWFF_PKT_QUEUED_8821C))
#define BIT_GET_FWFF_PKT_QUEUED_8821C(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED_8821C) & \
BIT_MASK_FWFF_PKT_QUEUED_8821C)
#define BIT_SET_FWFF_PKT_QUEUED_8821C(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED_8821C(x) | BIT_FWFF_PKT_QUEUED_8821C(v))
#define BIT_SHIFT_FWFF_PKT_STR_ADDR_8821C 0
#define BIT_MASK_FWFF_PKT_STR_ADDR_8821C 0xffff
#define BIT_FWFF_PKT_STR_ADDR_8821C(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR_8821C) \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_8821C)
#define BITS_FWFF_PKT_STR_ADDR_8821C \
(BIT_MASK_FWFF_PKT_STR_ADDR_8821C << BIT_SHIFT_FWFF_PKT_STR_ADDR_8821C)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR_8821C(x) \
((x) & (~BITS_FWFF_PKT_STR_ADDR_8821C))
#define BIT_GET_FWFF_PKT_STR_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR_8821C) & \
BIT_MASK_FWFF_PKT_STR_ADDR_8821C)
#define BIT_SET_FWFF_PKT_STR_ADDR_8821C(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR_8821C(x) | BIT_FWFF_PKT_STR_ADDR_8821C(v))
/* 2 REG_DDMA_CH0SA_8821C */
#define BIT_SHIFT_DDMACH0_SA_8821C 0
#define BIT_MASK_DDMACH0_SA_8821C 0xffffffffL
#define BIT_DDMACH0_SA_8821C(x) \
(((x) & BIT_MASK_DDMACH0_SA_8821C) << BIT_SHIFT_DDMACH0_SA_8821C)
#define BITS_DDMACH0_SA_8821C \
(BIT_MASK_DDMACH0_SA_8821C << BIT_SHIFT_DDMACH0_SA_8821C)
#define BIT_CLEAR_DDMACH0_SA_8821C(x) ((x) & (~BITS_DDMACH0_SA_8821C))
#define BIT_GET_DDMACH0_SA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH0_SA_8821C) & BIT_MASK_DDMACH0_SA_8821C)
#define BIT_SET_DDMACH0_SA_8821C(x, v) \
(BIT_CLEAR_DDMACH0_SA_8821C(x) | BIT_DDMACH0_SA_8821C(v))
/* 2 REG_DDMA_CH0DA_8821C */
#define BIT_SHIFT_DDMACH0_DA_8821C 0
#define BIT_MASK_DDMACH0_DA_8821C 0xffffffffL
#define BIT_DDMACH0_DA_8821C(x) \
(((x) & BIT_MASK_DDMACH0_DA_8821C) << BIT_SHIFT_DDMACH0_DA_8821C)
#define BITS_DDMACH0_DA_8821C \
(BIT_MASK_DDMACH0_DA_8821C << BIT_SHIFT_DDMACH0_DA_8821C)
#define BIT_CLEAR_DDMACH0_DA_8821C(x) ((x) & (~BITS_DDMACH0_DA_8821C))
#define BIT_GET_DDMACH0_DA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH0_DA_8821C) & BIT_MASK_DDMACH0_DA_8821C)
#define BIT_SET_DDMACH0_DA_8821C(x, v) \
(BIT_CLEAR_DDMACH0_DA_8821C(x) | BIT_DDMACH0_DA_8821C(v))
/* 2 REG_DDMA_CH0CTRL_8821C */
#define BIT_DDMACH0_OWN_8821C BIT(31)
#define BIT_DDMACH0_IDMEM_ERR_8821C BIT(30)
#define BIT_DDMACH0_CHKSUM_EN_8821C BIT(29)
#define BIT_DDMACH0_DA_W_DISABLE_8821C BIT(28)
#define BIT_DDMACH0_CHKSUM_STS_8821C BIT(27)
#define BIT_DDMACH0_DDMA_MODE_8821C BIT(26)
#define BIT_DDMACH0_RESET_CHKSUM_STS_8821C BIT(25)
#define BIT_DDMACH0_CHKSUM_CONT_8821C BIT(24)
#define BIT_SHIFT_DDMACH0_DLEN_8821C 0
#define BIT_MASK_DDMACH0_DLEN_8821C 0x3ffff
#define BIT_DDMACH0_DLEN_8821C(x) \
(((x) & BIT_MASK_DDMACH0_DLEN_8821C) << BIT_SHIFT_DDMACH0_DLEN_8821C)
#define BITS_DDMACH0_DLEN_8821C \
(BIT_MASK_DDMACH0_DLEN_8821C << BIT_SHIFT_DDMACH0_DLEN_8821C)
#define BIT_CLEAR_DDMACH0_DLEN_8821C(x) ((x) & (~BITS_DDMACH0_DLEN_8821C))
#define BIT_GET_DDMACH0_DLEN_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH0_DLEN_8821C) & BIT_MASK_DDMACH0_DLEN_8821C)
#define BIT_SET_DDMACH0_DLEN_8821C(x, v) \
(BIT_CLEAR_DDMACH0_DLEN_8821C(x) | BIT_DDMACH0_DLEN_8821C(v))
/* 2 REG_DDMA_CH1SA_8821C */
#define BIT_SHIFT_DDMACH1_SA_8821C 0
#define BIT_MASK_DDMACH1_SA_8821C 0xffffffffL
#define BIT_DDMACH1_SA_8821C(x) \
(((x) & BIT_MASK_DDMACH1_SA_8821C) << BIT_SHIFT_DDMACH1_SA_8821C)
#define BITS_DDMACH1_SA_8821C \
(BIT_MASK_DDMACH1_SA_8821C << BIT_SHIFT_DDMACH1_SA_8821C)
#define BIT_CLEAR_DDMACH1_SA_8821C(x) ((x) & (~BITS_DDMACH1_SA_8821C))
#define BIT_GET_DDMACH1_SA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH1_SA_8821C) & BIT_MASK_DDMACH1_SA_8821C)
#define BIT_SET_DDMACH1_SA_8821C(x, v) \
(BIT_CLEAR_DDMACH1_SA_8821C(x) | BIT_DDMACH1_SA_8821C(v))
/* 2 REG_DDMA_CH1DA_8821C */
#define BIT_SHIFT_DDMACH1_DA_8821C 0
#define BIT_MASK_DDMACH1_DA_8821C 0xffffffffL
#define BIT_DDMACH1_DA_8821C(x) \
(((x) & BIT_MASK_DDMACH1_DA_8821C) << BIT_SHIFT_DDMACH1_DA_8821C)
#define BITS_DDMACH1_DA_8821C \
(BIT_MASK_DDMACH1_DA_8821C << BIT_SHIFT_DDMACH1_DA_8821C)
#define BIT_CLEAR_DDMACH1_DA_8821C(x) ((x) & (~BITS_DDMACH1_DA_8821C))
#define BIT_GET_DDMACH1_DA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH1_DA_8821C) & BIT_MASK_DDMACH1_DA_8821C)
#define BIT_SET_DDMACH1_DA_8821C(x, v) \
(BIT_CLEAR_DDMACH1_DA_8821C(x) | BIT_DDMACH1_DA_8821C(v))
/* 2 REG_DDMA_CH1CTRL_8821C */
#define BIT_DDMACH1_OWN_8821C BIT(31)
#define BIT_DDMACH1_IDMEM_ERR_8821C BIT(30)
#define BIT_DDMACH1_CHKSUM_EN_8821C BIT(29)
#define BIT_DDMACH1_DA_W_DISABLE_8821C BIT(28)
#define BIT_DDMACH1_CHKSUM_STS_8821C BIT(27)
#define BIT_DDMACH1_DDMA_MODE_8821C BIT(26)
#define BIT_DDMACH1_RESET_CHKSUM_STS_8821C BIT(25)
#define BIT_DDMACH1_CHKSUM_CONT_8821C BIT(24)
#define BIT_SHIFT_DDMACH1_DLEN_8821C 0
#define BIT_MASK_DDMACH1_DLEN_8821C 0x3ffff
#define BIT_DDMACH1_DLEN_8821C(x) \
(((x) & BIT_MASK_DDMACH1_DLEN_8821C) << BIT_SHIFT_DDMACH1_DLEN_8821C)
#define BITS_DDMACH1_DLEN_8821C \
(BIT_MASK_DDMACH1_DLEN_8821C << BIT_SHIFT_DDMACH1_DLEN_8821C)
#define BIT_CLEAR_DDMACH1_DLEN_8821C(x) ((x) & (~BITS_DDMACH1_DLEN_8821C))
#define BIT_GET_DDMACH1_DLEN_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH1_DLEN_8821C) & BIT_MASK_DDMACH1_DLEN_8821C)
#define BIT_SET_DDMACH1_DLEN_8821C(x, v) \
(BIT_CLEAR_DDMACH1_DLEN_8821C(x) | BIT_DDMACH1_DLEN_8821C(v))
/* 2 REG_DDMA_CH2SA_8821C */
#define BIT_SHIFT_DDMACH2_SA_8821C 0
#define BIT_MASK_DDMACH2_SA_8821C 0xffffffffL
#define BIT_DDMACH2_SA_8821C(x) \
(((x) & BIT_MASK_DDMACH2_SA_8821C) << BIT_SHIFT_DDMACH2_SA_8821C)
#define BITS_DDMACH2_SA_8821C \
(BIT_MASK_DDMACH2_SA_8821C << BIT_SHIFT_DDMACH2_SA_8821C)
#define BIT_CLEAR_DDMACH2_SA_8821C(x) ((x) & (~BITS_DDMACH2_SA_8821C))
#define BIT_GET_DDMACH2_SA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH2_SA_8821C) & BIT_MASK_DDMACH2_SA_8821C)
#define BIT_SET_DDMACH2_SA_8821C(x, v) \
(BIT_CLEAR_DDMACH2_SA_8821C(x) | BIT_DDMACH2_SA_8821C(v))
/* 2 REG_DDMA_CH2DA_8821C */
#define BIT_SHIFT_DDMACH2_DA_8821C 0
#define BIT_MASK_DDMACH2_DA_8821C 0xffffffffL
#define BIT_DDMACH2_DA_8821C(x) \
(((x) & BIT_MASK_DDMACH2_DA_8821C) << BIT_SHIFT_DDMACH2_DA_8821C)
#define BITS_DDMACH2_DA_8821C \
(BIT_MASK_DDMACH2_DA_8821C << BIT_SHIFT_DDMACH2_DA_8821C)
#define BIT_CLEAR_DDMACH2_DA_8821C(x) ((x) & (~BITS_DDMACH2_DA_8821C))
#define BIT_GET_DDMACH2_DA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH2_DA_8821C) & BIT_MASK_DDMACH2_DA_8821C)
#define BIT_SET_DDMACH2_DA_8821C(x, v) \
(BIT_CLEAR_DDMACH2_DA_8821C(x) | BIT_DDMACH2_DA_8821C(v))
/* 2 REG_DDMA_CH2CTRL_8821C */
#define BIT_DDMACH2_OWN_8821C BIT(31)
#define BIT_DDMACH2_IDMEM_ERR_8821C BIT(30)
#define BIT_DDMACH2_CHKSUM_EN_8821C BIT(29)
#define BIT_DDMACH2_DA_W_DISABLE_8821C BIT(28)
#define BIT_DDMACH2_CHKSUM_STS_8821C BIT(27)
#define BIT_DDMACH2_DDMA_MODE_8821C BIT(26)
#define BIT_DDMACH2_RESET_CHKSUM_STS_8821C BIT(25)
#define BIT_DDMACH2_CHKSUM_CONT_8821C BIT(24)
#define BIT_SHIFT_DDMACH2_DLEN_8821C 0
#define BIT_MASK_DDMACH2_DLEN_8821C 0x3ffff
#define BIT_DDMACH2_DLEN_8821C(x) \
(((x) & BIT_MASK_DDMACH2_DLEN_8821C) << BIT_SHIFT_DDMACH2_DLEN_8821C)
#define BITS_DDMACH2_DLEN_8821C \
(BIT_MASK_DDMACH2_DLEN_8821C << BIT_SHIFT_DDMACH2_DLEN_8821C)
#define BIT_CLEAR_DDMACH2_DLEN_8821C(x) ((x) & (~BITS_DDMACH2_DLEN_8821C))
#define BIT_GET_DDMACH2_DLEN_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH2_DLEN_8821C) & BIT_MASK_DDMACH2_DLEN_8821C)
#define BIT_SET_DDMACH2_DLEN_8821C(x, v) \
(BIT_CLEAR_DDMACH2_DLEN_8821C(x) | BIT_DDMACH2_DLEN_8821C(v))
/* 2 REG_DDMA_CH3SA_8821C */
#define BIT_SHIFT_DDMACH3_SA_8821C 0
#define BIT_MASK_DDMACH3_SA_8821C 0xffffffffL
#define BIT_DDMACH3_SA_8821C(x) \
(((x) & BIT_MASK_DDMACH3_SA_8821C) << BIT_SHIFT_DDMACH3_SA_8821C)
#define BITS_DDMACH3_SA_8821C \
(BIT_MASK_DDMACH3_SA_8821C << BIT_SHIFT_DDMACH3_SA_8821C)
#define BIT_CLEAR_DDMACH3_SA_8821C(x) ((x) & (~BITS_DDMACH3_SA_8821C))
#define BIT_GET_DDMACH3_SA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH3_SA_8821C) & BIT_MASK_DDMACH3_SA_8821C)
#define BIT_SET_DDMACH3_SA_8821C(x, v) \
(BIT_CLEAR_DDMACH3_SA_8821C(x) | BIT_DDMACH3_SA_8821C(v))
/* 2 REG_DDMA_CH3DA_8821C */
#define BIT_SHIFT_DDMACH3_DA_8821C 0
#define BIT_MASK_DDMACH3_DA_8821C 0xffffffffL
#define BIT_DDMACH3_DA_8821C(x) \
(((x) & BIT_MASK_DDMACH3_DA_8821C) << BIT_SHIFT_DDMACH3_DA_8821C)
#define BITS_DDMACH3_DA_8821C \
(BIT_MASK_DDMACH3_DA_8821C << BIT_SHIFT_DDMACH3_DA_8821C)
#define BIT_CLEAR_DDMACH3_DA_8821C(x) ((x) & (~BITS_DDMACH3_DA_8821C))
#define BIT_GET_DDMACH3_DA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH3_DA_8821C) & BIT_MASK_DDMACH3_DA_8821C)
#define BIT_SET_DDMACH3_DA_8821C(x, v) \
(BIT_CLEAR_DDMACH3_DA_8821C(x) | BIT_DDMACH3_DA_8821C(v))
/* 2 REG_DDMA_CH3CTRL_8821C */
#define BIT_DDMACH3_OWN_8821C BIT(31)
#define BIT_DDMACH3_IDMEM_ERR_8821C BIT(30)
#define BIT_DDMACH3_CHKSUM_EN_8821C BIT(29)
#define BIT_DDMACH3_DA_W_DISABLE_8821C BIT(28)
#define BIT_DDMACH3_CHKSUM_STS_8821C BIT(27)
#define BIT_DDMACH3_DDMA_MODE_8821C BIT(26)
#define BIT_DDMACH3_RESET_CHKSUM_STS_8821C BIT(25)
#define BIT_DDMACH3_CHKSUM_CONT_8821C BIT(24)
#define BIT_SHIFT_DDMACH3_DLEN_8821C 0
#define BIT_MASK_DDMACH3_DLEN_8821C 0x3ffff
#define BIT_DDMACH3_DLEN_8821C(x) \
(((x) & BIT_MASK_DDMACH3_DLEN_8821C) << BIT_SHIFT_DDMACH3_DLEN_8821C)
#define BITS_DDMACH3_DLEN_8821C \
(BIT_MASK_DDMACH3_DLEN_8821C << BIT_SHIFT_DDMACH3_DLEN_8821C)
#define BIT_CLEAR_DDMACH3_DLEN_8821C(x) ((x) & (~BITS_DDMACH3_DLEN_8821C))
#define BIT_GET_DDMACH3_DLEN_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH3_DLEN_8821C) & BIT_MASK_DDMACH3_DLEN_8821C)
#define BIT_SET_DDMACH3_DLEN_8821C(x, v) \
(BIT_CLEAR_DDMACH3_DLEN_8821C(x) | BIT_DDMACH3_DLEN_8821C(v))
/* 2 REG_DDMA_CH4SA_8821C */
#define BIT_SHIFT_DDMACH4_SA_8821C 0
#define BIT_MASK_DDMACH4_SA_8821C 0xffffffffL
#define BIT_DDMACH4_SA_8821C(x) \
(((x) & BIT_MASK_DDMACH4_SA_8821C) << BIT_SHIFT_DDMACH4_SA_8821C)
#define BITS_DDMACH4_SA_8821C \
(BIT_MASK_DDMACH4_SA_8821C << BIT_SHIFT_DDMACH4_SA_8821C)
#define BIT_CLEAR_DDMACH4_SA_8821C(x) ((x) & (~BITS_DDMACH4_SA_8821C))
#define BIT_GET_DDMACH4_SA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH4_SA_8821C) & BIT_MASK_DDMACH4_SA_8821C)
#define BIT_SET_DDMACH4_SA_8821C(x, v) \
(BIT_CLEAR_DDMACH4_SA_8821C(x) | BIT_DDMACH4_SA_8821C(v))
/* 2 REG_DDMA_CH4DA_8821C */
#define BIT_SHIFT_DDMACH4_DA_8821C 0
#define BIT_MASK_DDMACH4_DA_8821C 0xffffffffL
#define BIT_DDMACH4_DA_8821C(x) \
(((x) & BIT_MASK_DDMACH4_DA_8821C) << BIT_SHIFT_DDMACH4_DA_8821C)
#define BITS_DDMACH4_DA_8821C \
(BIT_MASK_DDMACH4_DA_8821C << BIT_SHIFT_DDMACH4_DA_8821C)
#define BIT_CLEAR_DDMACH4_DA_8821C(x) ((x) & (~BITS_DDMACH4_DA_8821C))
#define BIT_GET_DDMACH4_DA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH4_DA_8821C) & BIT_MASK_DDMACH4_DA_8821C)
#define BIT_SET_DDMACH4_DA_8821C(x, v) \
(BIT_CLEAR_DDMACH4_DA_8821C(x) | BIT_DDMACH4_DA_8821C(v))
/* 2 REG_DDMA_CH4CTRL_8821C */
#define BIT_DDMACH4_OWN_8821C BIT(31)
#define BIT_DDMACH4_IDMEM_ERR_8821C BIT(30)
#define BIT_DDMACH4_CHKSUM_EN_8821C BIT(29)
#define BIT_DDMACH4_DA_W_DISABLE_8821C BIT(28)
#define BIT_DDMACH4_CHKSUM_STS_8821C BIT(27)
#define BIT_DDMACH4_DDMA_MODE_8821C BIT(26)
#define BIT_DDMACH4_RESET_CHKSUM_STS_8821C BIT(25)
#define BIT_DDMACH4_CHKSUM_CONT_8821C BIT(24)
#define BIT_SHIFT_DDMACH4_DLEN_8821C 0
#define BIT_MASK_DDMACH4_DLEN_8821C 0x3ffff
#define BIT_DDMACH4_DLEN_8821C(x) \
(((x) & BIT_MASK_DDMACH4_DLEN_8821C) << BIT_SHIFT_DDMACH4_DLEN_8821C)
#define BITS_DDMACH4_DLEN_8821C \
(BIT_MASK_DDMACH4_DLEN_8821C << BIT_SHIFT_DDMACH4_DLEN_8821C)
#define BIT_CLEAR_DDMACH4_DLEN_8821C(x) ((x) & (~BITS_DDMACH4_DLEN_8821C))
#define BIT_GET_DDMACH4_DLEN_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH4_DLEN_8821C) & BIT_MASK_DDMACH4_DLEN_8821C)
#define BIT_SET_DDMACH4_DLEN_8821C(x, v) \
(BIT_CLEAR_DDMACH4_DLEN_8821C(x) | BIT_DDMACH4_DLEN_8821C(v))
/* 2 REG_DDMA_CH5SA_8821C */
#define BIT_SHIFT_DDMACH5_SA_8821C 0
#define BIT_MASK_DDMACH5_SA_8821C 0xffffffffL
#define BIT_DDMACH5_SA_8821C(x) \
(((x) & BIT_MASK_DDMACH5_SA_8821C) << BIT_SHIFT_DDMACH5_SA_8821C)
#define BITS_DDMACH5_SA_8821C \
(BIT_MASK_DDMACH5_SA_8821C << BIT_SHIFT_DDMACH5_SA_8821C)
#define BIT_CLEAR_DDMACH5_SA_8821C(x) ((x) & (~BITS_DDMACH5_SA_8821C))
#define BIT_GET_DDMACH5_SA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH5_SA_8821C) & BIT_MASK_DDMACH5_SA_8821C)
#define BIT_SET_DDMACH5_SA_8821C(x, v) \
(BIT_CLEAR_DDMACH5_SA_8821C(x) | BIT_DDMACH5_SA_8821C(v))
/* 2 REG_DDMA_CH5DA_8821C */
#define BIT_SHIFT_DDMACH5_DA_8821C 0
#define BIT_MASK_DDMACH5_DA_8821C 0xffffffffL
#define BIT_DDMACH5_DA_8821C(x) \
(((x) & BIT_MASK_DDMACH5_DA_8821C) << BIT_SHIFT_DDMACH5_DA_8821C)
#define BITS_DDMACH5_DA_8821C \
(BIT_MASK_DDMACH5_DA_8821C << BIT_SHIFT_DDMACH5_DA_8821C)
#define BIT_CLEAR_DDMACH5_DA_8821C(x) ((x) & (~BITS_DDMACH5_DA_8821C))
#define BIT_GET_DDMACH5_DA_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH5_DA_8821C) & BIT_MASK_DDMACH5_DA_8821C)
#define BIT_SET_DDMACH5_DA_8821C(x, v) \
(BIT_CLEAR_DDMACH5_DA_8821C(x) | BIT_DDMACH5_DA_8821C(v))
/* 2 REG_DDMA_CH5CTRL_8821C */
#define BIT_DDMACH5_OWN_8821C BIT(31)
#define BIT_DDMACH5_IDMEM_ERR_8821C BIT(30)
#define BIT_DDMACH5_CHKSUM_EN_8821C BIT(29)
#define BIT_DDMACH5_DA_W_DISABLE_8821C BIT(28)
#define BIT_DDMACH5_CHKSUM_STS_8821C BIT(27)
#define BIT_DDMACH5_DDMA_MODE_8821C BIT(26)
#define BIT_DDMACH5_RESET_CHKSUM_STS_8821C BIT(25)
#define BIT_DDMACH5_CHKSUM_CONT_8821C BIT(24)
#define BIT_SHIFT_DDMACH5_DLEN_8821C 0
#define BIT_MASK_DDMACH5_DLEN_8821C 0x3ffff
#define BIT_DDMACH5_DLEN_8821C(x) \
(((x) & BIT_MASK_DDMACH5_DLEN_8821C) << BIT_SHIFT_DDMACH5_DLEN_8821C)
#define BITS_DDMACH5_DLEN_8821C \
(BIT_MASK_DDMACH5_DLEN_8821C << BIT_SHIFT_DDMACH5_DLEN_8821C)
#define BIT_CLEAR_DDMACH5_DLEN_8821C(x) ((x) & (~BITS_DDMACH5_DLEN_8821C))
#define BIT_GET_DDMACH5_DLEN_8821C(x) \
(((x) >> BIT_SHIFT_DDMACH5_DLEN_8821C) & BIT_MASK_DDMACH5_DLEN_8821C)
#define BIT_SET_DDMACH5_DLEN_8821C(x, v) \
(BIT_CLEAR_DDMACH5_DLEN_8821C(x) | BIT_DDMACH5_DLEN_8821C(v))
/* 2 REG_DDMA_INT_MSK_8821C */
#define BIT_DDMACH5_MSK_8821C BIT(5)
#define BIT_DDMACH4_MSK_8821C BIT(4)
#define BIT_DDMACH3_MSK_8821C BIT(3)
#define BIT_DDMACH2_MSK_8821C BIT(2)
#define BIT_DDMACH1_MSK_8821C BIT(1)
#define BIT_DDMACH0_MSK_8821C BIT(0)
/* 2 REG_DDMA_CHSTATUS_8821C */
#define BIT_DDMACH5_BUSY_8821C BIT(5)
#define BIT_DDMACH4_BUSY_8821C BIT(4)
#define BIT_DDMACH3_BUSY_8821C BIT(3)
#define BIT_DDMACH2_BUSY_8821C BIT(2)
#define BIT_DDMACH1_BUSY_8821C BIT(1)
#define BIT_DDMACH0_BUSY_8821C BIT(0)
/* 2 REG_DDMA_CHKSUM_8821C */
#define BIT_SHIFT_IDDMA0_CHKSUM_8821C 0
#define BIT_MASK_IDDMA0_CHKSUM_8821C 0xffff
#define BIT_IDDMA0_CHKSUM_8821C(x) \
(((x) & BIT_MASK_IDDMA0_CHKSUM_8821C) << BIT_SHIFT_IDDMA0_CHKSUM_8821C)
#define BITS_IDDMA0_CHKSUM_8821C \
(BIT_MASK_IDDMA0_CHKSUM_8821C << BIT_SHIFT_IDDMA0_CHKSUM_8821C)
#define BIT_CLEAR_IDDMA0_CHKSUM_8821C(x) ((x) & (~BITS_IDDMA0_CHKSUM_8821C))
#define BIT_GET_IDDMA0_CHKSUM_8821C(x) \
(((x) >> BIT_SHIFT_IDDMA0_CHKSUM_8821C) & BIT_MASK_IDDMA0_CHKSUM_8821C)
#define BIT_SET_IDDMA0_CHKSUM_8821C(x, v) \
(BIT_CLEAR_IDDMA0_CHKSUM_8821C(x) | BIT_IDDMA0_CHKSUM_8821C(v))
/* 2 REG_DDMA_MONITOR_8821C */
#define BIT_IDDMA0_PERMU_UNDERFLOW_8821C BIT(14)
#define BIT_IDDMA0_FIFO_UNDERFLOW_8821C BIT(13)
#define BIT_IDDMA0_FIFO_OVERFLOW_8821C BIT(12)
#define BIT_CH5_ERR_8821C BIT(5)
#define BIT_CH4_ERR_8821C BIT(4)
#define BIT_CH3_ERR_8821C BIT(3)
#define BIT_CH2_ERR_8821C BIT(2)
#define BIT_CH1_ERR_8821C BIT(1)
#define BIT_CH0_ERR_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_PCIE_CTRL_8821C */
#define BIT_PCIEIO_PERSTB_SEL_8821C BIT(31)
#define BIT_SHIFT_PCIE_MAX_RXDMA_8821C 28
#define BIT_MASK_PCIE_MAX_RXDMA_8821C 0x7
#define BIT_PCIE_MAX_RXDMA_8821C(x) \
(((x) & BIT_MASK_PCIE_MAX_RXDMA_8821C) \
<< BIT_SHIFT_PCIE_MAX_RXDMA_8821C)
#define BITS_PCIE_MAX_RXDMA_8821C \
(BIT_MASK_PCIE_MAX_RXDMA_8821C << BIT_SHIFT_PCIE_MAX_RXDMA_8821C)
#define BIT_CLEAR_PCIE_MAX_RXDMA_8821C(x) ((x) & (~BITS_PCIE_MAX_RXDMA_8821C))
#define BIT_GET_PCIE_MAX_RXDMA_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_RXDMA_8821C) & \
BIT_MASK_PCIE_MAX_RXDMA_8821C)
#define BIT_SET_PCIE_MAX_RXDMA_8821C(x, v) \
(BIT_CLEAR_PCIE_MAX_RXDMA_8821C(x) | BIT_PCIE_MAX_RXDMA_8821C(v))
#define BIT_MULRW_8821C BIT(27)
#define BIT_SHIFT_PCIE_MAX_TXDMA_8821C 24
#define BIT_MASK_PCIE_MAX_TXDMA_8821C 0x7
#define BIT_PCIE_MAX_TXDMA_8821C(x) \
(((x) & BIT_MASK_PCIE_MAX_TXDMA_8821C) \
<< BIT_SHIFT_PCIE_MAX_TXDMA_8821C)
#define BITS_PCIE_MAX_TXDMA_8821C \
(BIT_MASK_PCIE_MAX_TXDMA_8821C << BIT_SHIFT_PCIE_MAX_TXDMA_8821C)
#define BIT_CLEAR_PCIE_MAX_TXDMA_8821C(x) ((x) & (~BITS_PCIE_MAX_TXDMA_8821C))
#define BIT_GET_PCIE_MAX_TXDMA_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_TXDMA_8821C) & \
BIT_MASK_PCIE_MAX_TXDMA_8821C)
#define BIT_SET_PCIE_MAX_TXDMA_8821C(x, v) \
(BIT_CLEAR_PCIE_MAX_TXDMA_8821C(x) | BIT_PCIE_MAX_TXDMA_8821C(v))
#define BIT_EN_CPL_TIMEOUT_PS_8821C BIT(22)
#define BIT_REG_TXDMA_FAIL_PS_8821C BIT(21)
#define BIT_PCIE_RST_TRXDMA_INTF_8821C BIT(20)
#define BIT_EN_HWENTR_L1_8821C BIT(19)
#define BIT_EN_ADV_CLKGATE_8821C BIT(18)
#define BIT_PCIE_EN_SWENT_L23_8821C BIT(17)
#define BIT_PCIE_EN_HWEXT_L1_8821C BIT(16)
#define BIT_RX_CLOSE_EN_8821C BIT(15)
#define BIT_STOP_BCNQ_8821C BIT(14)
#define BIT_STOP_MGQ_8821C BIT(13)
#define BIT_STOP_VOQ_8821C BIT(12)
#define BIT_STOP_VIQ_8821C BIT(11)
#define BIT_STOP_BEQ_8821C BIT(10)
#define BIT_STOP_BKQ_8821C BIT(9)
#define BIT_STOP_RXQ_8821C BIT(8)
#define BIT_STOP_HI7Q_8821C BIT(7)
#define BIT_STOP_HI6Q_8821C BIT(6)
#define BIT_STOP_HI5Q_8821C BIT(5)
#define BIT_STOP_HI4Q_8821C BIT(4)
#define BIT_STOP_HI3Q_8821C BIT(3)
#define BIT_STOP_HI2Q_8821C BIT(2)
#define BIT_STOP_HI1Q_8821C BIT(1)
#define BIT_STOP_HI0Q_8821C BIT(0)
/* 2 REG_INT_MIG_8821C */
#define BIT_SHIFT_TXTTIMER_MATCH_NUM_8821C 28
#define BIT_MASK_TXTTIMER_MATCH_NUM_8821C 0xf
#define BIT_TXTTIMER_MATCH_NUM_8821C(x) \
(((x) & BIT_MASK_TXTTIMER_MATCH_NUM_8821C) \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8821C)
#define BITS_TXTTIMER_MATCH_NUM_8821C \
(BIT_MASK_TXTTIMER_MATCH_NUM_8821C \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8821C)
#define BIT_CLEAR_TXTTIMER_MATCH_NUM_8821C(x) \
((x) & (~BITS_TXTTIMER_MATCH_NUM_8821C))
#define BIT_GET_TXTTIMER_MATCH_NUM_8821C(x) \
(((x) >> BIT_SHIFT_TXTTIMER_MATCH_NUM_8821C) & \
BIT_MASK_TXTTIMER_MATCH_NUM_8821C)
#define BIT_SET_TXTTIMER_MATCH_NUM_8821C(x, v) \
(BIT_CLEAR_TXTTIMER_MATCH_NUM_8821C(x) | \
BIT_TXTTIMER_MATCH_NUM_8821C(v))
#define BIT_SHIFT_TXPKT_NUM_MATCH_8821C 24
#define BIT_MASK_TXPKT_NUM_MATCH_8821C 0xf
#define BIT_TXPKT_NUM_MATCH_8821C(x) \
(((x) & BIT_MASK_TXPKT_NUM_MATCH_8821C) \
<< BIT_SHIFT_TXPKT_NUM_MATCH_8821C)
#define BITS_TXPKT_NUM_MATCH_8821C \
(BIT_MASK_TXPKT_NUM_MATCH_8821C << BIT_SHIFT_TXPKT_NUM_MATCH_8821C)
#define BIT_CLEAR_TXPKT_NUM_MATCH_8821C(x) ((x) & (~BITS_TXPKT_NUM_MATCH_8821C))
#define BIT_GET_TXPKT_NUM_MATCH_8821C(x) \
(((x) >> BIT_SHIFT_TXPKT_NUM_MATCH_8821C) & \
BIT_MASK_TXPKT_NUM_MATCH_8821C)
#define BIT_SET_TXPKT_NUM_MATCH_8821C(x, v) \
(BIT_CLEAR_TXPKT_NUM_MATCH_8821C(x) | BIT_TXPKT_NUM_MATCH_8821C(v))
#define BIT_SHIFT_RXTTIMER_MATCH_NUM_8821C 20
#define BIT_MASK_RXTTIMER_MATCH_NUM_8821C 0xf
#define BIT_RXTTIMER_MATCH_NUM_8821C(x) \
(((x) & BIT_MASK_RXTTIMER_MATCH_NUM_8821C) \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8821C)
#define BITS_RXTTIMER_MATCH_NUM_8821C \
(BIT_MASK_RXTTIMER_MATCH_NUM_8821C \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8821C)
#define BIT_CLEAR_RXTTIMER_MATCH_NUM_8821C(x) \
((x) & (~BITS_RXTTIMER_MATCH_NUM_8821C))
#define BIT_GET_RXTTIMER_MATCH_NUM_8821C(x) \
(((x) >> BIT_SHIFT_RXTTIMER_MATCH_NUM_8821C) & \
BIT_MASK_RXTTIMER_MATCH_NUM_8821C)
#define BIT_SET_RXTTIMER_MATCH_NUM_8821C(x, v) \
(BIT_CLEAR_RXTTIMER_MATCH_NUM_8821C(x) | \
BIT_RXTTIMER_MATCH_NUM_8821C(v))
#define BIT_SHIFT_RXPKT_NUM_MATCH_8821C 16
#define BIT_MASK_RXPKT_NUM_MATCH_8821C 0xf
#define BIT_RXPKT_NUM_MATCH_8821C(x) \
(((x) & BIT_MASK_RXPKT_NUM_MATCH_8821C) \
<< BIT_SHIFT_RXPKT_NUM_MATCH_8821C)
#define BITS_RXPKT_NUM_MATCH_8821C \
(BIT_MASK_RXPKT_NUM_MATCH_8821C << BIT_SHIFT_RXPKT_NUM_MATCH_8821C)
#define BIT_CLEAR_RXPKT_NUM_MATCH_8821C(x) ((x) & (~BITS_RXPKT_NUM_MATCH_8821C))
#define BIT_GET_RXPKT_NUM_MATCH_8821C(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_MATCH_8821C) & \
BIT_MASK_RXPKT_NUM_MATCH_8821C)
#define BIT_SET_RXPKT_NUM_MATCH_8821C(x, v) \
(BIT_CLEAR_RXPKT_NUM_MATCH_8821C(x) | BIT_RXPKT_NUM_MATCH_8821C(v))
#define BIT_SHIFT_MIGRATE_TIMER_8821C 0
#define BIT_MASK_MIGRATE_TIMER_8821C 0xffff
#define BIT_MIGRATE_TIMER_8821C(x) \
(((x) & BIT_MASK_MIGRATE_TIMER_8821C) << BIT_SHIFT_MIGRATE_TIMER_8821C)
#define BITS_MIGRATE_TIMER_8821C \
(BIT_MASK_MIGRATE_TIMER_8821C << BIT_SHIFT_MIGRATE_TIMER_8821C)
#define BIT_CLEAR_MIGRATE_TIMER_8821C(x) ((x) & (~BITS_MIGRATE_TIMER_8821C))
#define BIT_GET_MIGRATE_TIMER_8821C(x) \
(((x) >> BIT_SHIFT_MIGRATE_TIMER_8821C) & BIT_MASK_MIGRATE_TIMER_8821C)
#define BIT_SET_MIGRATE_TIMER_8821C(x, v) \
(BIT_CLEAR_MIGRATE_TIMER_8821C(x) | BIT_MIGRATE_TIMER_8821C(v))
/* 2 REG_BCNQ_TXBD_DESA_8821C */
#define BIT_SHIFT_BCNQ_TXBD_DESA_8821C 0
#define BIT_MASK_BCNQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_BCNQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_BCNQ_TXBD_DESA_8821C) \
<< BIT_SHIFT_BCNQ_TXBD_DESA_8821C)
#define BITS_BCNQ_TXBD_DESA_8821C \
(BIT_MASK_BCNQ_TXBD_DESA_8821C << BIT_SHIFT_BCNQ_TXBD_DESA_8821C)
#define BIT_CLEAR_BCNQ_TXBD_DESA_8821C(x) ((x) & (~BITS_BCNQ_TXBD_DESA_8821C))
#define BIT_GET_BCNQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_BCNQ_TXBD_DESA_8821C) & \
BIT_MASK_BCNQ_TXBD_DESA_8821C)
#define BIT_SET_BCNQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_BCNQ_TXBD_DESA_8821C(x) | BIT_BCNQ_TXBD_DESA_8821C(v))
/* 2 REG_MGQ_TXBD_DESA_8821C */
#define BIT_SHIFT_MGQ_TXBD_DESA_8821C 0
#define BIT_MASK_MGQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_MGQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_MGQ_TXBD_DESA_8821C) << BIT_SHIFT_MGQ_TXBD_DESA_8821C)
#define BITS_MGQ_TXBD_DESA_8821C \
(BIT_MASK_MGQ_TXBD_DESA_8821C << BIT_SHIFT_MGQ_TXBD_DESA_8821C)
#define BIT_CLEAR_MGQ_TXBD_DESA_8821C(x) ((x) & (~BITS_MGQ_TXBD_DESA_8821C))
#define BIT_GET_MGQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_TXBD_DESA_8821C) & BIT_MASK_MGQ_TXBD_DESA_8821C)
#define BIT_SET_MGQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_MGQ_TXBD_DESA_8821C(x) | BIT_MGQ_TXBD_DESA_8821C(v))
/* 2 REG_VOQ_TXBD_DESA_8821C */
#define BIT_SHIFT_VOQ_TXBD_DESA_8821C 0
#define BIT_MASK_VOQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_VOQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_VOQ_TXBD_DESA_8821C) << BIT_SHIFT_VOQ_TXBD_DESA_8821C)
#define BITS_VOQ_TXBD_DESA_8821C \
(BIT_MASK_VOQ_TXBD_DESA_8821C << BIT_SHIFT_VOQ_TXBD_DESA_8821C)
#define BIT_CLEAR_VOQ_TXBD_DESA_8821C(x) ((x) & (~BITS_VOQ_TXBD_DESA_8821C))
#define BIT_GET_VOQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_VOQ_TXBD_DESA_8821C) & BIT_MASK_VOQ_TXBD_DESA_8821C)
#define BIT_SET_VOQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_VOQ_TXBD_DESA_8821C(x) | BIT_VOQ_TXBD_DESA_8821C(v))
/* 2 REG_VIQ_TXBD_DESA_8821C */
#define BIT_SHIFT_VIQ_TXBD_DESA_8821C 0
#define BIT_MASK_VIQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_VIQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_VIQ_TXBD_DESA_8821C) << BIT_SHIFT_VIQ_TXBD_DESA_8821C)
#define BITS_VIQ_TXBD_DESA_8821C \
(BIT_MASK_VIQ_TXBD_DESA_8821C << BIT_SHIFT_VIQ_TXBD_DESA_8821C)
#define BIT_CLEAR_VIQ_TXBD_DESA_8821C(x) ((x) & (~BITS_VIQ_TXBD_DESA_8821C))
#define BIT_GET_VIQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_VIQ_TXBD_DESA_8821C) & BIT_MASK_VIQ_TXBD_DESA_8821C)
#define BIT_SET_VIQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_VIQ_TXBD_DESA_8821C(x) | BIT_VIQ_TXBD_DESA_8821C(v))
/* 2 REG_BEQ_TXBD_DESA_8821C */
#define BIT_SHIFT_BEQ_TXBD_DESA_8821C 0
#define BIT_MASK_BEQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_BEQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_BEQ_TXBD_DESA_8821C) << BIT_SHIFT_BEQ_TXBD_DESA_8821C)
#define BITS_BEQ_TXBD_DESA_8821C \
(BIT_MASK_BEQ_TXBD_DESA_8821C << BIT_SHIFT_BEQ_TXBD_DESA_8821C)
#define BIT_CLEAR_BEQ_TXBD_DESA_8821C(x) ((x) & (~BITS_BEQ_TXBD_DESA_8821C))
#define BIT_GET_BEQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_BEQ_TXBD_DESA_8821C) & BIT_MASK_BEQ_TXBD_DESA_8821C)
#define BIT_SET_BEQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_BEQ_TXBD_DESA_8821C(x) | BIT_BEQ_TXBD_DESA_8821C(v))
/* 2 REG_BKQ_TXBD_DESA_8821C */
#define BIT_SHIFT_BKQ_TXBD_DESA_8821C 0
#define BIT_MASK_BKQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_BKQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_BKQ_TXBD_DESA_8821C) << BIT_SHIFT_BKQ_TXBD_DESA_8821C)
#define BITS_BKQ_TXBD_DESA_8821C \
(BIT_MASK_BKQ_TXBD_DESA_8821C << BIT_SHIFT_BKQ_TXBD_DESA_8821C)
#define BIT_CLEAR_BKQ_TXBD_DESA_8821C(x) ((x) & (~BITS_BKQ_TXBD_DESA_8821C))
#define BIT_GET_BKQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_BKQ_TXBD_DESA_8821C) & BIT_MASK_BKQ_TXBD_DESA_8821C)
#define BIT_SET_BKQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_BKQ_TXBD_DESA_8821C(x) | BIT_BKQ_TXBD_DESA_8821C(v))
/* 2 REG_RXQ_RXBD_DESA_8821C */
#define BIT_SHIFT_RXQ_RXBD_DESA_8821C 0
#define BIT_MASK_RXQ_RXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_RXQ_RXBD_DESA_8821C(x) \
(((x) & BIT_MASK_RXQ_RXBD_DESA_8821C) << BIT_SHIFT_RXQ_RXBD_DESA_8821C)
#define BITS_RXQ_RXBD_DESA_8821C \
(BIT_MASK_RXQ_RXBD_DESA_8821C << BIT_SHIFT_RXQ_RXBD_DESA_8821C)
#define BIT_CLEAR_RXQ_RXBD_DESA_8821C(x) ((x) & (~BITS_RXQ_RXBD_DESA_8821C))
#define BIT_GET_RXQ_RXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_RXQ_RXBD_DESA_8821C) & BIT_MASK_RXQ_RXBD_DESA_8821C)
#define BIT_SET_RXQ_RXBD_DESA_8821C(x, v) \
(BIT_CLEAR_RXQ_RXBD_DESA_8821C(x) | BIT_RXQ_RXBD_DESA_8821C(v))
/* 2 REG_HI0Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI0Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI0Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI0Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI0Q_TXBD_DESA_8821C)
#define BITS_HI0Q_TXBD_DESA_8821C \
(BIT_MASK_HI0Q_TXBD_DESA_8821C << BIT_SHIFT_HI0Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI0Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI0Q_TXBD_DESA_8821C))
#define BIT_GET_HI0Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_8821C) & \
BIT_MASK_HI0Q_TXBD_DESA_8821C)
#define BIT_SET_HI0Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_8821C(x) | BIT_HI0Q_TXBD_DESA_8821C(v))
/* 2 REG_HI1Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI1Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI1Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI1Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI1Q_TXBD_DESA_8821C)
#define BITS_HI1Q_TXBD_DESA_8821C \
(BIT_MASK_HI1Q_TXBD_DESA_8821C << BIT_SHIFT_HI1Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI1Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI1Q_TXBD_DESA_8821C))
#define BIT_GET_HI1Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_8821C) & \
BIT_MASK_HI1Q_TXBD_DESA_8821C)
#define BIT_SET_HI1Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_8821C(x) | BIT_HI1Q_TXBD_DESA_8821C(v))
/* 2 REG_HI2Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI2Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI2Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI2Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI2Q_TXBD_DESA_8821C)
#define BITS_HI2Q_TXBD_DESA_8821C \
(BIT_MASK_HI2Q_TXBD_DESA_8821C << BIT_SHIFT_HI2Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI2Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI2Q_TXBD_DESA_8821C))
#define BIT_GET_HI2Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_8821C) & \
BIT_MASK_HI2Q_TXBD_DESA_8821C)
#define BIT_SET_HI2Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_8821C(x) | BIT_HI2Q_TXBD_DESA_8821C(v))
/* 2 REG_HI3Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI3Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI3Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI3Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI3Q_TXBD_DESA_8821C)
#define BITS_HI3Q_TXBD_DESA_8821C \
(BIT_MASK_HI3Q_TXBD_DESA_8821C << BIT_SHIFT_HI3Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI3Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI3Q_TXBD_DESA_8821C))
#define BIT_GET_HI3Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_8821C) & \
BIT_MASK_HI3Q_TXBD_DESA_8821C)
#define BIT_SET_HI3Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_8821C(x) | BIT_HI3Q_TXBD_DESA_8821C(v))
/* 2 REG_HI4Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI4Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI4Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI4Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI4Q_TXBD_DESA_8821C)
#define BITS_HI4Q_TXBD_DESA_8821C \
(BIT_MASK_HI4Q_TXBD_DESA_8821C << BIT_SHIFT_HI4Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI4Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI4Q_TXBD_DESA_8821C))
#define BIT_GET_HI4Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_8821C) & \
BIT_MASK_HI4Q_TXBD_DESA_8821C)
#define BIT_SET_HI4Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_8821C(x) | BIT_HI4Q_TXBD_DESA_8821C(v))
/* 2 REG_HI5Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI5Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI5Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI5Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI5Q_TXBD_DESA_8821C)
#define BITS_HI5Q_TXBD_DESA_8821C \
(BIT_MASK_HI5Q_TXBD_DESA_8821C << BIT_SHIFT_HI5Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI5Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI5Q_TXBD_DESA_8821C))
#define BIT_GET_HI5Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_8821C) & \
BIT_MASK_HI5Q_TXBD_DESA_8821C)
#define BIT_SET_HI5Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_8821C(x) | BIT_HI5Q_TXBD_DESA_8821C(v))
/* 2 REG_HI6Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI6Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI6Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI6Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI6Q_TXBD_DESA_8821C)
#define BITS_HI6Q_TXBD_DESA_8821C \
(BIT_MASK_HI6Q_TXBD_DESA_8821C << BIT_SHIFT_HI6Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI6Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI6Q_TXBD_DESA_8821C))
#define BIT_GET_HI6Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_8821C) & \
BIT_MASK_HI6Q_TXBD_DESA_8821C)
#define BIT_SET_HI6Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_8821C(x) | BIT_HI6Q_TXBD_DESA_8821C(v))
/* 2 REG_HI7Q_TXBD_DESA_8821C */
#define BIT_SHIFT_HI7Q_TXBD_DESA_8821C 0
#define BIT_MASK_HI7Q_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_HI7Q_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_8821C) \
<< BIT_SHIFT_HI7Q_TXBD_DESA_8821C)
#define BITS_HI7Q_TXBD_DESA_8821C \
(BIT_MASK_HI7Q_TXBD_DESA_8821C << BIT_SHIFT_HI7Q_TXBD_DESA_8821C)
#define BIT_CLEAR_HI7Q_TXBD_DESA_8821C(x) ((x) & (~BITS_HI7Q_TXBD_DESA_8821C))
#define BIT_GET_HI7Q_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_8821C) & \
BIT_MASK_HI7Q_TXBD_DESA_8821C)
#define BIT_SET_HI7Q_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_8821C(x) | BIT_HI7Q_TXBD_DESA_8821C(v))
/* 2 REG_MGQ_TXBD_NUM_8821C */
#define BIT_PCIE_MGQ_FLAG_8821C BIT(14)
#define BIT_SHIFT_MGQ_DESC_MODE_8821C 12
#define BIT_MASK_MGQ_DESC_MODE_8821C 0x3
#define BIT_MGQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_MGQ_DESC_MODE_8821C) << BIT_SHIFT_MGQ_DESC_MODE_8821C)
#define BITS_MGQ_DESC_MODE_8821C \
(BIT_MASK_MGQ_DESC_MODE_8821C << BIT_SHIFT_MGQ_DESC_MODE_8821C)
#define BIT_CLEAR_MGQ_DESC_MODE_8821C(x) ((x) & (~BITS_MGQ_DESC_MODE_8821C))
#define BIT_GET_MGQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_MODE_8821C) & BIT_MASK_MGQ_DESC_MODE_8821C)
#define BIT_SET_MGQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_MGQ_DESC_MODE_8821C(x) | BIT_MGQ_DESC_MODE_8821C(v))
#define BIT_SHIFT_MGQ_DESC_NUM_8821C 0
#define BIT_MASK_MGQ_DESC_NUM_8821C 0xfff
#define BIT_MGQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_MGQ_DESC_NUM_8821C) << BIT_SHIFT_MGQ_DESC_NUM_8821C)
#define BITS_MGQ_DESC_NUM_8821C \
(BIT_MASK_MGQ_DESC_NUM_8821C << BIT_SHIFT_MGQ_DESC_NUM_8821C)
#define BIT_CLEAR_MGQ_DESC_NUM_8821C(x) ((x) & (~BITS_MGQ_DESC_NUM_8821C))
#define BIT_GET_MGQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_NUM_8821C) & BIT_MASK_MGQ_DESC_NUM_8821C)
#define BIT_SET_MGQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_MGQ_DESC_NUM_8821C(x) | BIT_MGQ_DESC_NUM_8821C(v))
/* 2 REG_RX_RXBD_NUM_8821C */
#define BIT_SYS_32_64_8821C BIT(15)
#define BIT_SHIFT_BCNQ_DESC_MODE_8821C 13
#define BIT_MASK_BCNQ_DESC_MODE_8821C 0x3
#define BIT_BCNQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_BCNQ_DESC_MODE_8821C) \
<< BIT_SHIFT_BCNQ_DESC_MODE_8821C)
#define BITS_BCNQ_DESC_MODE_8821C \
(BIT_MASK_BCNQ_DESC_MODE_8821C << BIT_SHIFT_BCNQ_DESC_MODE_8821C)
#define BIT_CLEAR_BCNQ_DESC_MODE_8821C(x) ((x) & (~BITS_BCNQ_DESC_MODE_8821C))
#define BIT_GET_BCNQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_BCNQ_DESC_MODE_8821C) & \
BIT_MASK_BCNQ_DESC_MODE_8821C)
#define BIT_SET_BCNQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_BCNQ_DESC_MODE_8821C(x) | BIT_BCNQ_DESC_MODE_8821C(v))
#define BIT_PCIE_BCNQ_FLAG_8821C BIT(12)
#define BIT_SHIFT_RXQ_DESC_NUM_8821C 0
#define BIT_MASK_RXQ_DESC_NUM_8821C 0xfff
#define BIT_RXQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_RXQ_DESC_NUM_8821C) << BIT_SHIFT_RXQ_DESC_NUM_8821C)
#define BITS_RXQ_DESC_NUM_8821C \
(BIT_MASK_RXQ_DESC_NUM_8821C << BIT_SHIFT_RXQ_DESC_NUM_8821C)
#define BIT_CLEAR_RXQ_DESC_NUM_8821C(x) ((x) & (~BITS_RXQ_DESC_NUM_8821C))
#define BIT_GET_RXQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_RXQ_DESC_NUM_8821C) & BIT_MASK_RXQ_DESC_NUM_8821C)
#define BIT_SET_RXQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_RXQ_DESC_NUM_8821C(x) | BIT_RXQ_DESC_NUM_8821C(v))
/* 2 REG_VOQ_TXBD_NUM_8821C */
#define BIT_PCIE_VOQ_FLAG_8821C BIT(14)
#define BIT_SHIFT_VOQ_DESC_MODE_8821C 12
#define BIT_MASK_VOQ_DESC_MODE_8821C 0x3
#define BIT_VOQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_VOQ_DESC_MODE_8821C) << BIT_SHIFT_VOQ_DESC_MODE_8821C)
#define BITS_VOQ_DESC_MODE_8821C \
(BIT_MASK_VOQ_DESC_MODE_8821C << BIT_SHIFT_VOQ_DESC_MODE_8821C)
#define BIT_CLEAR_VOQ_DESC_MODE_8821C(x) ((x) & (~BITS_VOQ_DESC_MODE_8821C))
#define BIT_GET_VOQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_MODE_8821C) & BIT_MASK_VOQ_DESC_MODE_8821C)
#define BIT_SET_VOQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_VOQ_DESC_MODE_8821C(x) | BIT_VOQ_DESC_MODE_8821C(v))
#define BIT_SHIFT_VOQ_DESC_NUM_8821C 0
#define BIT_MASK_VOQ_DESC_NUM_8821C 0xfff
#define BIT_VOQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_VOQ_DESC_NUM_8821C) << BIT_SHIFT_VOQ_DESC_NUM_8821C)
#define BITS_VOQ_DESC_NUM_8821C \
(BIT_MASK_VOQ_DESC_NUM_8821C << BIT_SHIFT_VOQ_DESC_NUM_8821C)
#define BIT_CLEAR_VOQ_DESC_NUM_8821C(x) ((x) & (~BITS_VOQ_DESC_NUM_8821C))
#define BIT_GET_VOQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_NUM_8821C) & BIT_MASK_VOQ_DESC_NUM_8821C)
#define BIT_SET_VOQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_VOQ_DESC_NUM_8821C(x) | BIT_VOQ_DESC_NUM_8821C(v))
/* 2 REG_VIQ_TXBD_NUM_8821C */
#define BIT_PCIE_VIQ_FLAG_8821C BIT(14)
#define BIT_SHIFT_VIQ_DESC_MODE_8821C 12
#define BIT_MASK_VIQ_DESC_MODE_8821C 0x3
#define BIT_VIQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_VIQ_DESC_MODE_8821C) << BIT_SHIFT_VIQ_DESC_MODE_8821C)
#define BITS_VIQ_DESC_MODE_8821C \
(BIT_MASK_VIQ_DESC_MODE_8821C << BIT_SHIFT_VIQ_DESC_MODE_8821C)
#define BIT_CLEAR_VIQ_DESC_MODE_8821C(x) ((x) & (~BITS_VIQ_DESC_MODE_8821C))
#define BIT_GET_VIQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_MODE_8821C) & BIT_MASK_VIQ_DESC_MODE_8821C)
#define BIT_SET_VIQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_VIQ_DESC_MODE_8821C(x) | BIT_VIQ_DESC_MODE_8821C(v))
#define BIT_SHIFT_VIQ_DESC_NUM_8821C 0
#define BIT_MASK_VIQ_DESC_NUM_8821C 0xfff
#define BIT_VIQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_VIQ_DESC_NUM_8821C) << BIT_SHIFT_VIQ_DESC_NUM_8821C)
#define BITS_VIQ_DESC_NUM_8821C \
(BIT_MASK_VIQ_DESC_NUM_8821C << BIT_SHIFT_VIQ_DESC_NUM_8821C)
#define BIT_CLEAR_VIQ_DESC_NUM_8821C(x) ((x) & (~BITS_VIQ_DESC_NUM_8821C))
#define BIT_GET_VIQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_NUM_8821C) & BIT_MASK_VIQ_DESC_NUM_8821C)
#define BIT_SET_VIQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_VIQ_DESC_NUM_8821C(x) | BIT_VIQ_DESC_NUM_8821C(v))
/* 2 REG_BEQ_TXBD_NUM_8821C */
#define BIT_PCIE_BEQ_FLAG_8821C BIT(14)
#define BIT_SHIFT_BEQ_DESC_MODE_8821C 12
#define BIT_MASK_BEQ_DESC_MODE_8821C 0x3
#define BIT_BEQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_BEQ_DESC_MODE_8821C) << BIT_SHIFT_BEQ_DESC_MODE_8821C)
#define BITS_BEQ_DESC_MODE_8821C \
(BIT_MASK_BEQ_DESC_MODE_8821C << BIT_SHIFT_BEQ_DESC_MODE_8821C)
#define BIT_CLEAR_BEQ_DESC_MODE_8821C(x) ((x) & (~BITS_BEQ_DESC_MODE_8821C))
#define BIT_GET_BEQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_MODE_8821C) & BIT_MASK_BEQ_DESC_MODE_8821C)
#define BIT_SET_BEQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_BEQ_DESC_MODE_8821C(x) | BIT_BEQ_DESC_MODE_8821C(v))
#define BIT_SHIFT_BEQ_DESC_NUM_8821C 0
#define BIT_MASK_BEQ_DESC_NUM_8821C 0xfff
#define BIT_BEQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_BEQ_DESC_NUM_8821C) << BIT_SHIFT_BEQ_DESC_NUM_8821C)
#define BITS_BEQ_DESC_NUM_8821C \
(BIT_MASK_BEQ_DESC_NUM_8821C << BIT_SHIFT_BEQ_DESC_NUM_8821C)
#define BIT_CLEAR_BEQ_DESC_NUM_8821C(x) ((x) & (~BITS_BEQ_DESC_NUM_8821C))
#define BIT_GET_BEQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_NUM_8821C) & BIT_MASK_BEQ_DESC_NUM_8821C)
#define BIT_SET_BEQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_BEQ_DESC_NUM_8821C(x) | BIT_BEQ_DESC_NUM_8821C(v))
/* 2 REG_BKQ_TXBD_NUM_8821C */
#define BIT_PCIE_BKQ_FLAG_8821C BIT(14)
#define BIT_SHIFT_BKQ_DESC_MODE_8821C 12
#define BIT_MASK_BKQ_DESC_MODE_8821C 0x3
#define BIT_BKQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_BKQ_DESC_MODE_8821C) << BIT_SHIFT_BKQ_DESC_MODE_8821C)
#define BITS_BKQ_DESC_MODE_8821C \
(BIT_MASK_BKQ_DESC_MODE_8821C << BIT_SHIFT_BKQ_DESC_MODE_8821C)
#define BIT_CLEAR_BKQ_DESC_MODE_8821C(x) ((x) & (~BITS_BKQ_DESC_MODE_8821C))
#define BIT_GET_BKQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_MODE_8821C) & BIT_MASK_BKQ_DESC_MODE_8821C)
#define BIT_SET_BKQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_BKQ_DESC_MODE_8821C(x) | BIT_BKQ_DESC_MODE_8821C(v))
#define BIT_SHIFT_BKQ_DESC_NUM_8821C 0
#define BIT_MASK_BKQ_DESC_NUM_8821C 0xfff
#define BIT_BKQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_BKQ_DESC_NUM_8821C) << BIT_SHIFT_BKQ_DESC_NUM_8821C)
#define BITS_BKQ_DESC_NUM_8821C \
(BIT_MASK_BKQ_DESC_NUM_8821C << BIT_SHIFT_BKQ_DESC_NUM_8821C)
#define BIT_CLEAR_BKQ_DESC_NUM_8821C(x) ((x) & (~BITS_BKQ_DESC_NUM_8821C))
#define BIT_GET_BKQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_NUM_8821C) & BIT_MASK_BKQ_DESC_NUM_8821C)
#define BIT_SET_BKQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_BKQ_DESC_NUM_8821C(x) | BIT_BKQ_DESC_NUM_8821C(v))
/* 2 REG_HI0Q_TXBD_NUM_8821C */
#define BIT_HI0Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI0Q_DESC_MODE_8821C 12
#define BIT_MASK_HI0Q_DESC_MODE_8821C 0x3
#define BIT_HI0Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI0Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI0Q_DESC_MODE_8821C)
#define BITS_HI0Q_DESC_MODE_8821C \
(BIT_MASK_HI0Q_DESC_MODE_8821C << BIT_SHIFT_HI0Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI0Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI0Q_DESC_MODE_8821C))
#define BIT_GET_HI0Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_MODE_8821C) & \
BIT_MASK_HI0Q_DESC_MODE_8821C)
#define BIT_SET_HI0Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI0Q_DESC_MODE_8821C(x) | BIT_HI0Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI0Q_DESC_NUM_8821C 0
#define BIT_MASK_HI0Q_DESC_NUM_8821C 0xfff
#define BIT_HI0Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI0Q_DESC_NUM_8821C) << BIT_SHIFT_HI0Q_DESC_NUM_8821C)
#define BITS_HI0Q_DESC_NUM_8821C \
(BIT_MASK_HI0Q_DESC_NUM_8821C << BIT_SHIFT_HI0Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI0Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI0Q_DESC_NUM_8821C))
#define BIT_GET_HI0Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_NUM_8821C) & BIT_MASK_HI0Q_DESC_NUM_8821C)
#define BIT_SET_HI0Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI0Q_DESC_NUM_8821C(x) | BIT_HI0Q_DESC_NUM_8821C(v))
/* 2 REG_HI1Q_TXBD_NUM_8821C */
#define BIT_HI1Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI1Q_DESC_MODE_8821C 12
#define BIT_MASK_HI1Q_DESC_MODE_8821C 0x3
#define BIT_HI1Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI1Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI1Q_DESC_MODE_8821C)
#define BITS_HI1Q_DESC_MODE_8821C \
(BIT_MASK_HI1Q_DESC_MODE_8821C << BIT_SHIFT_HI1Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI1Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI1Q_DESC_MODE_8821C))
#define BIT_GET_HI1Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_MODE_8821C) & \
BIT_MASK_HI1Q_DESC_MODE_8821C)
#define BIT_SET_HI1Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI1Q_DESC_MODE_8821C(x) | BIT_HI1Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI1Q_DESC_NUM_8821C 0
#define BIT_MASK_HI1Q_DESC_NUM_8821C 0xfff
#define BIT_HI1Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI1Q_DESC_NUM_8821C) << BIT_SHIFT_HI1Q_DESC_NUM_8821C)
#define BITS_HI1Q_DESC_NUM_8821C \
(BIT_MASK_HI1Q_DESC_NUM_8821C << BIT_SHIFT_HI1Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI1Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI1Q_DESC_NUM_8821C))
#define BIT_GET_HI1Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_NUM_8821C) & BIT_MASK_HI1Q_DESC_NUM_8821C)
#define BIT_SET_HI1Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI1Q_DESC_NUM_8821C(x) | BIT_HI1Q_DESC_NUM_8821C(v))
/* 2 REG_HI2Q_TXBD_NUM_8821C */
#define BIT_HI2Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI2Q_DESC_MODE_8821C 12
#define BIT_MASK_HI2Q_DESC_MODE_8821C 0x3
#define BIT_HI2Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI2Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI2Q_DESC_MODE_8821C)
#define BITS_HI2Q_DESC_MODE_8821C \
(BIT_MASK_HI2Q_DESC_MODE_8821C << BIT_SHIFT_HI2Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI2Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI2Q_DESC_MODE_8821C))
#define BIT_GET_HI2Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_MODE_8821C) & \
BIT_MASK_HI2Q_DESC_MODE_8821C)
#define BIT_SET_HI2Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI2Q_DESC_MODE_8821C(x) | BIT_HI2Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI2Q_DESC_NUM_8821C 0
#define BIT_MASK_HI2Q_DESC_NUM_8821C 0xfff
#define BIT_HI2Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI2Q_DESC_NUM_8821C) << BIT_SHIFT_HI2Q_DESC_NUM_8821C)
#define BITS_HI2Q_DESC_NUM_8821C \
(BIT_MASK_HI2Q_DESC_NUM_8821C << BIT_SHIFT_HI2Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI2Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI2Q_DESC_NUM_8821C))
#define BIT_GET_HI2Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_NUM_8821C) & BIT_MASK_HI2Q_DESC_NUM_8821C)
#define BIT_SET_HI2Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI2Q_DESC_NUM_8821C(x) | BIT_HI2Q_DESC_NUM_8821C(v))
/* 2 REG_HI3Q_TXBD_NUM_8821C */
#define BIT_HI3Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI3Q_DESC_MODE_8821C 12
#define BIT_MASK_HI3Q_DESC_MODE_8821C 0x3
#define BIT_HI3Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI3Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI3Q_DESC_MODE_8821C)
#define BITS_HI3Q_DESC_MODE_8821C \
(BIT_MASK_HI3Q_DESC_MODE_8821C << BIT_SHIFT_HI3Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI3Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI3Q_DESC_MODE_8821C))
#define BIT_GET_HI3Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_MODE_8821C) & \
BIT_MASK_HI3Q_DESC_MODE_8821C)
#define BIT_SET_HI3Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI3Q_DESC_MODE_8821C(x) | BIT_HI3Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI3Q_DESC_NUM_8821C 0
#define BIT_MASK_HI3Q_DESC_NUM_8821C 0xfff
#define BIT_HI3Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI3Q_DESC_NUM_8821C) << BIT_SHIFT_HI3Q_DESC_NUM_8821C)
#define BITS_HI3Q_DESC_NUM_8821C \
(BIT_MASK_HI3Q_DESC_NUM_8821C << BIT_SHIFT_HI3Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI3Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI3Q_DESC_NUM_8821C))
#define BIT_GET_HI3Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_NUM_8821C) & BIT_MASK_HI3Q_DESC_NUM_8821C)
#define BIT_SET_HI3Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI3Q_DESC_NUM_8821C(x) | BIT_HI3Q_DESC_NUM_8821C(v))
/* 2 REG_HI4Q_TXBD_NUM_8821C */
#define BIT_HI4Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI4Q_DESC_MODE_8821C 12
#define BIT_MASK_HI4Q_DESC_MODE_8821C 0x3
#define BIT_HI4Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI4Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI4Q_DESC_MODE_8821C)
#define BITS_HI4Q_DESC_MODE_8821C \
(BIT_MASK_HI4Q_DESC_MODE_8821C << BIT_SHIFT_HI4Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI4Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI4Q_DESC_MODE_8821C))
#define BIT_GET_HI4Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_MODE_8821C) & \
BIT_MASK_HI4Q_DESC_MODE_8821C)
#define BIT_SET_HI4Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI4Q_DESC_MODE_8821C(x) | BIT_HI4Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI4Q_DESC_NUM_8821C 0
#define BIT_MASK_HI4Q_DESC_NUM_8821C 0xfff
#define BIT_HI4Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI4Q_DESC_NUM_8821C) << BIT_SHIFT_HI4Q_DESC_NUM_8821C)
#define BITS_HI4Q_DESC_NUM_8821C \
(BIT_MASK_HI4Q_DESC_NUM_8821C << BIT_SHIFT_HI4Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI4Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI4Q_DESC_NUM_8821C))
#define BIT_GET_HI4Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_NUM_8821C) & BIT_MASK_HI4Q_DESC_NUM_8821C)
#define BIT_SET_HI4Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI4Q_DESC_NUM_8821C(x) | BIT_HI4Q_DESC_NUM_8821C(v))
/* 2 REG_HI5Q_TXBD_NUM_8821C */
#define BIT_HI5Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI5Q_DESC_MODE_8821C 12
#define BIT_MASK_HI5Q_DESC_MODE_8821C 0x3
#define BIT_HI5Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI5Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI5Q_DESC_MODE_8821C)
#define BITS_HI5Q_DESC_MODE_8821C \
(BIT_MASK_HI5Q_DESC_MODE_8821C << BIT_SHIFT_HI5Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI5Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI5Q_DESC_MODE_8821C))
#define BIT_GET_HI5Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_MODE_8821C) & \
BIT_MASK_HI5Q_DESC_MODE_8821C)
#define BIT_SET_HI5Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI5Q_DESC_MODE_8821C(x) | BIT_HI5Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI5Q_DESC_NUM_8821C 0
#define BIT_MASK_HI5Q_DESC_NUM_8821C 0xfff
#define BIT_HI5Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI5Q_DESC_NUM_8821C) << BIT_SHIFT_HI5Q_DESC_NUM_8821C)
#define BITS_HI5Q_DESC_NUM_8821C \
(BIT_MASK_HI5Q_DESC_NUM_8821C << BIT_SHIFT_HI5Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI5Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI5Q_DESC_NUM_8821C))
#define BIT_GET_HI5Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_NUM_8821C) & BIT_MASK_HI5Q_DESC_NUM_8821C)
#define BIT_SET_HI5Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI5Q_DESC_NUM_8821C(x) | BIT_HI5Q_DESC_NUM_8821C(v))
/* 2 REG_HI6Q_TXBD_NUM_8821C */
#define BIT_HI6Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI6Q_DESC_MODE_8821C 12
#define BIT_MASK_HI6Q_DESC_MODE_8821C 0x3
#define BIT_HI6Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI6Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI6Q_DESC_MODE_8821C)
#define BITS_HI6Q_DESC_MODE_8821C \
(BIT_MASK_HI6Q_DESC_MODE_8821C << BIT_SHIFT_HI6Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI6Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI6Q_DESC_MODE_8821C))
#define BIT_GET_HI6Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_MODE_8821C) & \
BIT_MASK_HI6Q_DESC_MODE_8821C)
#define BIT_SET_HI6Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI6Q_DESC_MODE_8821C(x) | BIT_HI6Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI6Q_DESC_NUM_8821C 0
#define BIT_MASK_HI6Q_DESC_NUM_8821C 0xfff
#define BIT_HI6Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI6Q_DESC_NUM_8821C) << BIT_SHIFT_HI6Q_DESC_NUM_8821C)
#define BITS_HI6Q_DESC_NUM_8821C \
(BIT_MASK_HI6Q_DESC_NUM_8821C << BIT_SHIFT_HI6Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI6Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI6Q_DESC_NUM_8821C))
#define BIT_GET_HI6Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_NUM_8821C) & BIT_MASK_HI6Q_DESC_NUM_8821C)
#define BIT_SET_HI6Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI6Q_DESC_NUM_8821C(x) | BIT_HI6Q_DESC_NUM_8821C(v))
/* 2 REG_HI7Q_TXBD_NUM_8821C */
#define BIT_HI7Q_FLAG_8821C BIT(14)
#define BIT_SHIFT_HI7Q_DESC_MODE_8821C 12
#define BIT_MASK_HI7Q_DESC_MODE_8821C 0x3
#define BIT_HI7Q_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_HI7Q_DESC_MODE_8821C) \
<< BIT_SHIFT_HI7Q_DESC_MODE_8821C)
#define BITS_HI7Q_DESC_MODE_8821C \
(BIT_MASK_HI7Q_DESC_MODE_8821C << BIT_SHIFT_HI7Q_DESC_MODE_8821C)
#define BIT_CLEAR_HI7Q_DESC_MODE_8821C(x) ((x) & (~BITS_HI7Q_DESC_MODE_8821C))
#define BIT_GET_HI7Q_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_MODE_8821C) & \
BIT_MASK_HI7Q_DESC_MODE_8821C)
#define BIT_SET_HI7Q_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_HI7Q_DESC_MODE_8821C(x) | BIT_HI7Q_DESC_MODE_8821C(v))
#define BIT_SHIFT_HI7Q_DESC_NUM_8821C 0
#define BIT_MASK_HI7Q_DESC_NUM_8821C 0xfff
#define BIT_HI7Q_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_HI7Q_DESC_NUM_8821C) << BIT_SHIFT_HI7Q_DESC_NUM_8821C)
#define BITS_HI7Q_DESC_NUM_8821C \
(BIT_MASK_HI7Q_DESC_NUM_8821C << BIT_SHIFT_HI7Q_DESC_NUM_8821C)
#define BIT_CLEAR_HI7Q_DESC_NUM_8821C(x) ((x) & (~BITS_HI7Q_DESC_NUM_8821C))
#define BIT_GET_HI7Q_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_NUM_8821C) & BIT_MASK_HI7Q_DESC_NUM_8821C)
#define BIT_SET_HI7Q_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_HI7Q_DESC_NUM_8821C(x) | BIT_HI7Q_DESC_NUM_8821C(v))
/* 2 REG_TSFTIMER_HCI_8821C */
#define BIT_SHIFT_TSFT2_HCI_8821C 16
#define BIT_MASK_TSFT2_HCI_8821C 0xffff
#define BIT_TSFT2_HCI_8821C(x) \
(((x) & BIT_MASK_TSFT2_HCI_8821C) << BIT_SHIFT_TSFT2_HCI_8821C)
#define BITS_TSFT2_HCI_8821C \
(BIT_MASK_TSFT2_HCI_8821C << BIT_SHIFT_TSFT2_HCI_8821C)
#define BIT_CLEAR_TSFT2_HCI_8821C(x) ((x) & (~BITS_TSFT2_HCI_8821C))
#define BIT_GET_TSFT2_HCI_8821C(x) \
(((x) >> BIT_SHIFT_TSFT2_HCI_8821C) & BIT_MASK_TSFT2_HCI_8821C)
#define BIT_SET_TSFT2_HCI_8821C(x, v) \
(BIT_CLEAR_TSFT2_HCI_8821C(x) | BIT_TSFT2_HCI_8821C(v))
#define BIT_SHIFT_TSFT1_HCI_8821C 0
#define BIT_MASK_TSFT1_HCI_8821C 0xffff
#define BIT_TSFT1_HCI_8821C(x) \
(((x) & BIT_MASK_TSFT1_HCI_8821C) << BIT_SHIFT_TSFT1_HCI_8821C)
#define BITS_TSFT1_HCI_8821C \
(BIT_MASK_TSFT1_HCI_8821C << BIT_SHIFT_TSFT1_HCI_8821C)
#define BIT_CLEAR_TSFT1_HCI_8821C(x) ((x) & (~BITS_TSFT1_HCI_8821C))
#define BIT_GET_TSFT1_HCI_8821C(x) \
(((x) >> BIT_SHIFT_TSFT1_HCI_8821C) & BIT_MASK_TSFT1_HCI_8821C)
#define BIT_SET_TSFT1_HCI_8821C(x, v) \
(BIT_CLEAR_TSFT1_HCI_8821C(x) | BIT_TSFT1_HCI_8821C(v))
/* 2 REG_BD_RWPTR_CLR_8821C */
#define BIT_CLR_HI7Q_HW_IDX_8821C BIT(29)
#define BIT_CLR_HI6Q_HW_IDX_8821C BIT(28)
#define BIT_CLR_HI5Q_HW_IDX_8821C BIT(27)
#define BIT_CLR_HI4Q_HW_IDX_8821C BIT(26)
#define BIT_CLR_HI3Q_HW_IDX_8821C BIT(25)
#define BIT_CLR_HI2Q_HW_IDX_8821C BIT(24)
#define BIT_CLR_HI1Q_HW_IDX_8821C BIT(23)
#define BIT_CLR_HI0Q_HW_IDX_8821C BIT(22)
#define BIT_CLR_BKQ_HW_IDX_8821C BIT(21)
#define BIT_CLR_BEQ_HW_IDX_8821C BIT(20)
#define BIT_CLR_VIQ_HW_IDX_8821C BIT(19)
#define BIT_CLR_VOQ_HW_IDX_8821C BIT(18)
#define BIT_CLR_MGQ_HW_IDX_8821C BIT(17)
#define BIT_CLR_RXQ_HW_IDX_8821C BIT(16)
#define BIT_CLR_HI7Q_HOST_IDX_8821C BIT(13)
#define BIT_CLR_HI6Q_HOST_IDX_8821C BIT(12)
#define BIT_CLR_HI5Q_HOST_IDX_8821C BIT(11)
#define BIT_CLR_HI4Q_HOST_IDX_8821C BIT(10)
#define BIT_CLR_HI3Q_HOST_IDX_8821C BIT(9)
#define BIT_CLR_HI2Q_HOST_IDX_8821C BIT(8)
#define BIT_CLR_HI1Q_HOST_IDX_8821C BIT(7)
#define BIT_CLR_HI0Q_HOST_IDX_8821C BIT(6)
#define BIT_CLR_BKQ_HOST_IDX_8821C BIT(5)
#define BIT_CLR_BEQ_HOST_IDX_8821C BIT(4)
#define BIT_CLR_VIQ_HOST_IDX_8821C BIT(3)
#define BIT_CLR_VOQ_HOST_IDX_8821C BIT(2)
#define BIT_CLR_MGQ_HOST_IDX_8821C BIT(1)
#define BIT_CLR_RXQ_HOST_IDX_8821C BIT(0)
/* 2 REG_VOQ_TXBD_IDX_8821C */
#define BIT_SHIFT_VOQ_HW_IDX_8821C 16
#define BIT_MASK_VOQ_HW_IDX_8821C 0xfff
#define BIT_VOQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_VOQ_HW_IDX_8821C) << BIT_SHIFT_VOQ_HW_IDX_8821C)
#define BITS_VOQ_HW_IDX_8821C \
(BIT_MASK_VOQ_HW_IDX_8821C << BIT_SHIFT_VOQ_HW_IDX_8821C)
#define BIT_CLEAR_VOQ_HW_IDX_8821C(x) ((x) & (~BITS_VOQ_HW_IDX_8821C))
#define BIT_GET_VOQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_VOQ_HW_IDX_8821C) & BIT_MASK_VOQ_HW_IDX_8821C)
#define BIT_SET_VOQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_VOQ_HW_IDX_8821C(x) | BIT_VOQ_HW_IDX_8821C(v))
#define BIT_SHIFT_VOQ_HOST_IDX_8821C 0
#define BIT_MASK_VOQ_HOST_IDX_8821C 0xfff
#define BIT_VOQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_VOQ_HOST_IDX_8821C) << BIT_SHIFT_VOQ_HOST_IDX_8821C)
#define BITS_VOQ_HOST_IDX_8821C \
(BIT_MASK_VOQ_HOST_IDX_8821C << BIT_SHIFT_VOQ_HOST_IDX_8821C)
#define BIT_CLEAR_VOQ_HOST_IDX_8821C(x) ((x) & (~BITS_VOQ_HOST_IDX_8821C))
#define BIT_GET_VOQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_VOQ_HOST_IDX_8821C) & BIT_MASK_VOQ_HOST_IDX_8821C)
#define BIT_SET_VOQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_VOQ_HOST_IDX_8821C(x) | BIT_VOQ_HOST_IDX_8821C(v))
/* 2 REG_VIQ_TXBD_IDX_8821C */
#define BIT_SHIFT_VIQ_HW_IDX_8821C 16
#define BIT_MASK_VIQ_HW_IDX_8821C 0xfff
#define BIT_VIQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_VIQ_HW_IDX_8821C) << BIT_SHIFT_VIQ_HW_IDX_8821C)
#define BITS_VIQ_HW_IDX_8821C \
(BIT_MASK_VIQ_HW_IDX_8821C << BIT_SHIFT_VIQ_HW_IDX_8821C)
#define BIT_CLEAR_VIQ_HW_IDX_8821C(x) ((x) & (~BITS_VIQ_HW_IDX_8821C))
#define BIT_GET_VIQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_VIQ_HW_IDX_8821C) & BIT_MASK_VIQ_HW_IDX_8821C)
#define BIT_SET_VIQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_VIQ_HW_IDX_8821C(x) | BIT_VIQ_HW_IDX_8821C(v))
#define BIT_SHIFT_VIQ_HOST_IDX_8821C 0
#define BIT_MASK_VIQ_HOST_IDX_8821C 0xfff
#define BIT_VIQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_VIQ_HOST_IDX_8821C) << BIT_SHIFT_VIQ_HOST_IDX_8821C)
#define BITS_VIQ_HOST_IDX_8821C \
(BIT_MASK_VIQ_HOST_IDX_8821C << BIT_SHIFT_VIQ_HOST_IDX_8821C)
#define BIT_CLEAR_VIQ_HOST_IDX_8821C(x) ((x) & (~BITS_VIQ_HOST_IDX_8821C))
#define BIT_GET_VIQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_VIQ_HOST_IDX_8821C) & BIT_MASK_VIQ_HOST_IDX_8821C)
#define BIT_SET_VIQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_VIQ_HOST_IDX_8821C(x) | BIT_VIQ_HOST_IDX_8821C(v))
/* 2 REG_BEQ_TXBD_IDX_8821C */
#define BIT_SHIFT_BEQ_HW_IDX_8821C 16
#define BIT_MASK_BEQ_HW_IDX_8821C 0xfff
#define BIT_BEQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_BEQ_HW_IDX_8821C) << BIT_SHIFT_BEQ_HW_IDX_8821C)
#define BITS_BEQ_HW_IDX_8821C \
(BIT_MASK_BEQ_HW_IDX_8821C << BIT_SHIFT_BEQ_HW_IDX_8821C)
#define BIT_CLEAR_BEQ_HW_IDX_8821C(x) ((x) & (~BITS_BEQ_HW_IDX_8821C))
#define BIT_GET_BEQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_BEQ_HW_IDX_8821C) & BIT_MASK_BEQ_HW_IDX_8821C)
#define BIT_SET_BEQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_BEQ_HW_IDX_8821C(x) | BIT_BEQ_HW_IDX_8821C(v))
#define BIT_SHIFT_BEQ_HOST_IDX_8821C 0
#define BIT_MASK_BEQ_HOST_IDX_8821C 0xfff
#define BIT_BEQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_BEQ_HOST_IDX_8821C) << BIT_SHIFT_BEQ_HOST_IDX_8821C)
#define BITS_BEQ_HOST_IDX_8821C \
(BIT_MASK_BEQ_HOST_IDX_8821C << BIT_SHIFT_BEQ_HOST_IDX_8821C)
#define BIT_CLEAR_BEQ_HOST_IDX_8821C(x) ((x) & (~BITS_BEQ_HOST_IDX_8821C))
#define BIT_GET_BEQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_BEQ_HOST_IDX_8821C) & BIT_MASK_BEQ_HOST_IDX_8821C)
#define BIT_SET_BEQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_BEQ_HOST_IDX_8821C(x) | BIT_BEQ_HOST_IDX_8821C(v))
/* 2 REG_BKQ_TXBD_IDX_8821C */
#define BIT_SHIFT_BKQ_HW_IDX_8821C 16
#define BIT_MASK_BKQ_HW_IDX_8821C 0xfff
#define BIT_BKQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_BKQ_HW_IDX_8821C) << BIT_SHIFT_BKQ_HW_IDX_8821C)
#define BITS_BKQ_HW_IDX_8821C \
(BIT_MASK_BKQ_HW_IDX_8821C << BIT_SHIFT_BKQ_HW_IDX_8821C)
#define BIT_CLEAR_BKQ_HW_IDX_8821C(x) ((x) & (~BITS_BKQ_HW_IDX_8821C))
#define BIT_GET_BKQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_BKQ_HW_IDX_8821C) & BIT_MASK_BKQ_HW_IDX_8821C)
#define BIT_SET_BKQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_BKQ_HW_IDX_8821C(x) | BIT_BKQ_HW_IDX_8821C(v))
#define BIT_SHIFT_BKQ_HOST_IDX_8821C 0
#define BIT_MASK_BKQ_HOST_IDX_8821C 0xfff
#define BIT_BKQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_BKQ_HOST_IDX_8821C) << BIT_SHIFT_BKQ_HOST_IDX_8821C)
#define BITS_BKQ_HOST_IDX_8821C \
(BIT_MASK_BKQ_HOST_IDX_8821C << BIT_SHIFT_BKQ_HOST_IDX_8821C)
#define BIT_CLEAR_BKQ_HOST_IDX_8821C(x) ((x) & (~BITS_BKQ_HOST_IDX_8821C))
#define BIT_GET_BKQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_BKQ_HOST_IDX_8821C) & BIT_MASK_BKQ_HOST_IDX_8821C)
#define BIT_SET_BKQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_BKQ_HOST_IDX_8821C(x) | BIT_BKQ_HOST_IDX_8821C(v))
/* 2 REG_MGQ_TXBD_IDX_8821C */
#define BIT_SHIFT_MGQ_HW_IDX_8821C 16
#define BIT_MASK_MGQ_HW_IDX_8821C 0xfff
#define BIT_MGQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_MGQ_HW_IDX_8821C) << BIT_SHIFT_MGQ_HW_IDX_8821C)
#define BITS_MGQ_HW_IDX_8821C \
(BIT_MASK_MGQ_HW_IDX_8821C << BIT_SHIFT_MGQ_HW_IDX_8821C)
#define BIT_CLEAR_MGQ_HW_IDX_8821C(x) ((x) & (~BITS_MGQ_HW_IDX_8821C))
#define BIT_GET_MGQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_HW_IDX_8821C) & BIT_MASK_MGQ_HW_IDX_8821C)
#define BIT_SET_MGQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_MGQ_HW_IDX_8821C(x) | BIT_MGQ_HW_IDX_8821C(v))
#define BIT_SHIFT_MGQ_HOST_IDX_8821C 0
#define BIT_MASK_MGQ_HOST_IDX_8821C 0xfff
#define BIT_MGQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_MGQ_HOST_IDX_8821C) << BIT_SHIFT_MGQ_HOST_IDX_8821C)
#define BITS_MGQ_HOST_IDX_8821C \
(BIT_MASK_MGQ_HOST_IDX_8821C << BIT_SHIFT_MGQ_HOST_IDX_8821C)
#define BIT_CLEAR_MGQ_HOST_IDX_8821C(x) ((x) & (~BITS_MGQ_HOST_IDX_8821C))
#define BIT_GET_MGQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_HOST_IDX_8821C) & BIT_MASK_MGQ_HOST_IDX_8821C)
#define BIT_SET_MGQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_MGQ_HOST_IDX_8821C(x) | BIT_MGQ_HOST_IDX_8821C(v))
/* 2 REG_RXQ_RXBD_IDX_8821C */
#define BIT_SHIFT_RXQ_HW_IDX_8821C 16
#define BIT_MASK_RXQ_HW_IDX_8821C 0xfff
#define BIT_RXQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_RXQ_HW_IDX_8821C) << BIT_SHIFT_RXQ_HW_IDX_8821C)
#define BITS_RXQ_HW_IDX_8821C \
(BIT_MASK_RXQ_HW_IDX_8821C << BIT_SHIFT_RXQ_HW_IDX_8821C)
#define BIT_CLEAR_RXQ_HW_IDX_8821C(x) ((x) & (~BITS_RXQ_HW_IDX_8821C))
#define BIT_GET_RXQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RXQ_HW_IDX_8821C) & BIT_MASK_RXQ_HW_IDX_8821C)
#define BIT_SET_RXQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_RXQ_HW_IDX_8821C(x) | BIT_RXQ_HW_IDX_8821C(v))
#define BIT_SHIFT_RXQ_HOST_IDX_8821C 0
#define BIT_MASK_RXQ_HOST_IDX_8821C 0xfff
#define BIT_RXQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_RXQ_HOST_IDX_8821C) << BIT_SHIFT_RXQ_HOST_IDX_8821C)
#define BITS_RXQ_HOST_IDX_8821C \
(BIT_MASK_RXQ_HOST_IDX_8821C << BIT_SHIFT_RXQ_HOST_IDX_8821C)
#define BIT_CLEAR_RXQ_HOST_IDX_8821C(x) ((x) & (~BITS_RXQ_HOST_IDX_8821C))
#define BIT_GET_RXQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RXQ_HOST_IDX_8821C) & BIT_MASK_RXQ_HOST_IDX_8821C)
#define BIT_SET_RXQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_RXQ_HOST_IDX_8821C(x) | BIT_RXQ_HOST_IDX_8821C(v))
/* 2 REG_HI0Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI0Q_HW_IDX_8821C 16
#define BIT_MASK_HI0Q_HW_IDX_8821C 0xfff
#define BIT_HI0Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI0Q_HW_IDX_8821C) << BIT_SHIFT_HI0Q_HW_IDX_8821C)
#define BITS_HI0Q_HW_IDX_8821C \
(BIT_MASK_HI0Q_HW_IDX_8821C << BIT_SHIFT_HI0Q_HW_IDX_8821C)
#define BIT_CLEAR_HI0Q_HW_IDX_8821C(x) ((x) & (~BITS_HI0Q_HW_IDX_8821C))
#define BIT_GET_HI0Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI0Q_HW_IDX_8821C) & BIT_MASK_HI0Q_HW_IDX_8821C)
#define BIT_SET_HI0Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI0Q_HW_IDX_8821C(x) | BIT_HI0Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI0Q_HOST_IDX_8821C 0
#define BIT_MASK_HI0Q_HOST_IDX_8821C 0xfff
#define BIT_HI0Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI0Q_HOST_IDX_8821C) << BIT_SHIFT_HI0Q_HOST_IDX_8821C)
#define BITS_HI0Q_HOST_IDX_8821C \
(BIT_MASK_HI0Q_HOST_IDX_8821C << BIT_SHIFT_HI0Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI0Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI0Q_HOST_IDX_8821C))
#define BIT_GET_HI0Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI0Q_HOST_IDX_8821C) & BIT_MASK_HI0Q_HOST_IDX_8821C)
#define BIT_SET_HI0Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI0Q_HOST_IDX_8821C(x) | BIT_HI0Q_HOST_IDX_8821C(v))
/* 2 REG_HI1Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI1Q_HW_IDX_8821C 16
#define BIT_MASK_HI1Q_HW_IDX_8821C 0xfff
#define BIT_HI1Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI1Q_HW_IDX_8821C) << BIT_SHIFT_HI1Q_HW_IDX_8821C)
#define BITS_HI1Q_HW_IDX_8821C \
(BIT_MASK_HI1Q_HW_IDX_8821C << BIT_SHIFT_HI1Q_HW_IDX_8821C)
#define BIT_CLEAR_HI1Q_HW_IDX_8821C(x) ((x) & (~BITS_HI1Q_HW_IDX_8821C))
#define BIT_GET_HI1Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI1Q_HW_IDX_8821C) & BIT_MASK_HI1Q_HW_IDX_8821C)
#define BIT_SET_HI1Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI1Q_HW_IDX_8821C(x) | BIT_HI1Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI1Q_HOST_IDX_8821C 0
#define BIT_MASK_HI1Q_HOST_IDX_8821C 0xfff
#define BIT_HI1Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI1Q_HOST_IDX_8821C) << BIT_SHIFT_HI1Q_HOST_IDX_8821C)
#define BITS_HI1Q_HOST_IDX_8821C \
(BIT_MASK_HI1Q_HOST_IDX_8821C << BIT_SHIFT_HI1Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI1Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI1Q_HOST_IDX_8821C))
#define BIT_GET_HI1Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI1Q_HOST_IDX_8821C) & BIT_MASK_HI1Q_HOST_IDX_8821C)
#define BIT_SET_HI1Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI1Q_HOST_IDX_8821C(x) | BIT_HI1Q_HOST_IDX_8821C(v))
/* 2 REG_HI2Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI2Q_HW_IDX_8821C 16
#define BIT_MASK_HI2Q_HW_IDX_8821C 0xfff
#define BIT_HI2Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI2Q_HW_IDX_8821C) << BIT_SHIFT_HI2Q_HW_IDX_8821C)
#define BITS_HI2Q_HW_IDX_8821C \
(BIT_MASK_HI2Q_HW_IDX_8821C << BIT_SHIFT_HI2Q_HW_IDX_8821C)
#define BIT_CLEAR_HI2Q_HW_IDX_8821C(x) ((x) & (~BITS_HI2Q_HW_IDX_8821C))
#define BIT_GET_HI2Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI2Q_HW_IDX_8821C) & BIT_MASK_HI2Q_HW_IDX_8821C)
#define BIT_SET_HI2Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI2Q_HW_IDX_8821C(x) | BIT_HI2Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI2Q_HOST_IDX_8821C 0
#define BIT_MASK_HI2Q_HOST_IDX_8821C 0xfff
#define BIT_HI2Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI2Q_HOST_IDX_8821C) << BIT_SHIFT_HI2Q_HOST_IDX_8821C)
#define BITS_HI2Q_HOST_IDX_8821C \
(BIT_MASK_HI2Q_HOST_IDX_8821C << BIT_SHIFT_HI2Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI2Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI2Q_HOST_IDX_8821C))
#define BIT_GET_HI2Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI2Q_HOST_IDX_8821C) & BIT_MASK_HI2Q_HOST_IDX_8821C)
#define BIT_SET_HI2Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI2Q_HOST_IDX_8821C(x) | BIT_HI2Q_HOST_IDX_8821C(v))
/* 2 REG_HI3Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI3Q_HW_IDX_8821C 16
#define BIT_MASK_HI3Q_HW_IDX_8821C 0xfff
#define BIT_HI3Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI3Q_HW_IDX_8821C) << BIT_SHIFT_HI3Q_HW_IDX_8821C)
#define BITS_HI3Q_HW_IDX_8821C \
(BIT_MASK_HI3Q_HW_IDX_8821C << BIT_SHIFT_HI3Q_HW_IDX_8821C)
#define BIT_CLEAR_HI3Q_HW_IDX_8821C(x) ((x) & (~BITS_HI3Q_HW_IDX_8821C))
#define BIT_GET_HI3Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI3Q_HW_IDX_8821C) & BIT_MASK_HI3Q_HW_IDX_8821C)
#define BIT_SET_HI3Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI3Q_HW_IDX_8821C(x) | BIT_HI3Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI3Q_HOST_IDX_8821C 0
#define BIT_MASK_HI3Q_HOST_IDX_8821C 0xfff
#define BIT_HI3Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI3Q_HOST_IDX_8821C) << BIT_SHIFT_HI3Q_HOST_IDX_8821C)
#define BITS_HI3Q_HOST_IDX_8821C \
(BIT_MASK_HI3Q_HOST_IDX_8821C << BIT_SHIFT_HI3Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI3Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI3Q_HOST_IDX_8821C))
#define BIT_GET_HI3Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI3Q_HOST_IDX_8821C) & BIT_MASK_HI3Q_HOST_IDX_8821C)
#define BIT_SET_HI3Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI3Q_HOST_IDX_8821C(x) | BIT_HI3Q_HOST_IDX_8821C(v))
/* 2 REG_HI4Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI4Q_HW_IDX_8821C 16
#define BIT_MASK_HI4Q_HW_IDX_8821C 0xfff
#define BIT_HI4Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI4Q_HW_IDX_8821C) << BIT_SHIFT_HI4Q_HW_IDX_8821C)
#define BITS_HI4Q_HW_IDX_8821C \
(BIT_MASK_HI4Q_HW_IDX_8821C << BIT_SHIFT_HI4Q_HW_IDX_8821C)
#define BIT_CLEAR_HI4Q_HW_IDX_8821C(x) ((x) & (~BITS_HI4Q_HW_IDX_8821C))
#define BIT_GET_HI4Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI4Q_HW_IDX_8821C) & BIT_MASK_HI4Q_HW_IDX_8821C)
#define BIT_SET_HI4Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI4Q_HW_IDX_8821C(x) | BIT_HI4Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI4Q_HOST_IDX_8821C 0
#define BIT_MASK_HI4Q_HOST_IDX_8821C 0xfff
#define BIT_HI4Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI4Q_HOST_IDX_8821C) << BIT_SHIFT_HI4Q_HOST_IDX_8821C)
#define BITS_HI4Q_HOST_IDX_8821C \
(BIT_MASK_HI4Q_HOST_IDX_8821C << BIT_SHIFT_HI4Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI4Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI4Q_HOST_IDX_8821C))
#define BIT_GET_HI4Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI4Q_HOST_IDX_8821C) & BIT_MASK_HI4Q_HOST_IDX_8821C)
#define BIT_SET_HI4Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI4Q_HOST_IDX_8821C(x) | BIT_HI4Q_HOST_IDX_8821C(v))
/* 2 REG_HI5Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI5Q_HW_IDX_8821C 16
#define BIT_MASK_HI5Q_HW_IDX_8821C 0xfff
#define BIT_HI5Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI5Q_HW_IDX_8821C) << BIT_SHIFT_HI5Q_HW_IDX_8821C)
#define BITS_HI5Q_HW_IDX_8821C \
(BIT_MASK_HI5Q_HW_IDX_8821C << BIT_SHIFT_HI5Q_HW_IDX_8821C)
#define BIT_CLEAR_HI5Q_HW_IDX_8821C(x) ((x) & (~BITS_HI5Q_HW_IDX_8821C))
#define BIT_GET_HI5Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI5Q_HW_IDX_8821C) & BIT_MASK_HI5Q_HW_IDX_8821C)
#define BIT_SET_HI5Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI5Q_HW_IDX_8821C(x) | BIT_HI5Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI5Q_HOST_IDX_8821C 0
#define BIT_MASK_HI5Q_HOST_IDX_8821C 0xfff
#define BIT_HI5Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI5Q_HOST_IDX_8821C) << BIT_SHIFT_HI5Q_HOST_IDX_8821C)
#define BITS_HI5Q_HOST_IDX_8821C \
(BIT_MASK_HI5Q_HOST_IDX_8821C << BIT_SHIFT_HI5Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI5Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI5Q_HOST_IDX_8821C))
#define BIT_GET_HI5Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI5Q_HOST_IDX_8821C) & BIT_MASK_HI5Q_HOST_IDX_8821C)
#define BIT_SET_HI5Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI5Q_HOST_IDX_8821C(x) | BIT_HI5Q_HOST_IDX_8821C(v))
/* 2 REG_HI6Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI6Q_HW_IDX_8821C 16
#define BIT_MASK_HI6Q_HW_IDX_8821C 0xfff
#define BIT_HI6Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI6Q_HW_IDX_8821C) << BIT_SHIFT_HI6Q_HW_IDX_8821C)
#define BITS_HI6Q_HW_IDX_8821C \
(BIT_MASK_HI6Q_HW_IDX_8821C << BIT_SHIFT_HI6Q_HW_IDX_8821C)
#define BIT_CLEAR_HI6Q_HW_IDX_8821C(x) ((x) & (~BITS_HI6Q_HW_IDX_8821C))
#define BIT_GET_HI6Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI6Q_HW_IDX_8821C) & BIT_MASK_HI6Q_HW_IDX_8821C)
#define BIT_SET_HI6Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI6Q_HW_IDX_8821C(x) | BIT_HI6Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI6Q_HOST_IDX_8821C 0
#define BIT_MASK_HI6Q_HOST_IDX_8821C 0xfff
#define BIT_HI6Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI6Q_HOST_IDX_8821C) << BIT_SHIFT_HI6Q_HOST_IDX_8821C)
#define BITS_HI6Q_HOST_IDX_8821C \
(BIT_MASK_HI6Q_HOST_IDX_8821C << BIT_SHIFT_HI6Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI6Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI6Q_HOST_IDX_8821C))
#define BIT_GET_HI6Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI6Q_HOST_IDX_8821C) & BIT_MASK_HI6Q_HOST_IDX_8821C)
#define BIT_SET_HI6Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI6Q_HOST_IDX_8821C(x) | BIT_HI6Q_HOST_IDX_8821C(v))
/* 2 REG_HI7Q_TXBD_IDX_8821C */
#define BIT_SHIFT_HI7Q_HW_IDX_8821C 16
#define BIT_MASK_HI7Q_HW_IDX_8821C 0xfff
#define BIT_HI7Q_HW_IDX_8821C(x) \
(((x) & BIT_MASK_HI7Q_HW_IDX_8821C) << BIT_SHIFT_HI7Q_HW_IDX_8821C)
#define BITS_HI7Q_HW_IDX_8821C \
(BIT_MASK_HI7Q_HW_IDX_8821C << BIT_SHIFT_HI7Q_HW_IDX_8821C)
#define BIT_CLEAR_HI7Q_HW_IDX_8821C(x) ((x) & (~BITS_HI7Q_HW_IDX_8821C))
#define BIT_GET_HI7Q_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI7Q_HW_IDX_8821C) & BIT_MASK_HI7Q_HW_IDX_8821C)
#define BIT_SET_HI7Q_HW_IDX_8821C(x, v) \
(BIT_CLEAR_HI7Q_HW_IDX_8821C(x) | BIT_HI7Q_HW_IDX_8821C(v))
#define BIT_SHIFT_HI7Q_HOST_IDX_8821C 0
#define BIT_MASK_HI7Q_HOST_IDX_8821C 0xfff
#define BIT_HI7Q_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_HI7Q_HOST_IDX_8821C) << BIT_SHIFT_HI7Q_HOST_IDX_8821C)
#define BITS_HI7Q_HOST_IDX_8821C \
(BIT_MASK_HI7Q_HOST_IDX_8821C << BIT_SHIFT_HI7Q_HOST_IDX_8821C)
#define BIT_CLEAR_HI7Q_HOST_IDX_8821C(x) ((x) & (~BITS_HI7Q_HOST_IDX_8821C))
#define BIT_GET_HI7Q_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HI7Q_HOST_IDX_8821C) & BIT_MASK_HI7Q_HOST_IDX_8821C)
#define BIT_SET_HI7Q_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_HI7Q_HOST_IDX_8821C(x) | BIT_HI7Q_HOST_IDX_8821C(v))
/* 2 REG_DBG_SEL_V1_8821C */
#define BIT_SHIFT_DBG_SEL_8821C 0
#define BIT_MASK_DBG_SEL_8821C 0xff
#define BIT_DBG_SEL_8821C(x) \
(((x) & BIT_MASK_DBG_SEL_8821C) << BIT_SHIFT_DBG_SEL_8821C)
#define BITS_DBG_SEL_8821C (BIT_MASK_DBG_SEL_8821C << BIT_SHIFT_DBG_SEL_8821C)
#define BIT_CLEAR_DBG_SEL_8821C(x) ((x) & (~BITS_DBG_SEL_8821C))
#define BIT_GET_DBG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_DBG_SEL_8821C) & BIT_MASK_DBG_SEL_8821C)
#define BIT_SET_DBG_SEL_8821C(x, v) \
(BIT_CLEAR_DBG_SEL_8821C(x) | BIT_DBG_SEL_8821C(v))
/* 2 REG_PCIE_HRPWM1_V1_8821C */
#define BIT_SHIFT_PCIE_HRPWM_8821C 0
#define BIT_MASK_PCIE_HRPWM_8821C 0xff
#define BIT_PCIE_HRPWM_8821C(x) \
(((x) & BIT_MASK_PCIE_HRPWM_8821C) << BIT_SHIFT_PCIE_HRPWM_8821C)
#define BITS_PCIE_HRPWM_8821C \
(BIT_MASK_PCIE_HRPWM_8821C << BIT_SHIFT_PCIE_HRPWM_8821C)
#define BIT_CLEAR_PCIE_HRPWM_8821C(x) ((x) & (~BITS_PCIE_HRPWM_8821C))
#define BIT_GET_PCIE_HRPWM_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM_8821C) & BIT_MASK_PCIE_HRPWM_8821C)
#define BIT_SET_PCIE_HRPWM_8821C(x, v) \
(BIT_CLEAR_PCIE_HRPWM_8821C(x) | BIT_PCIE_HRPWM_8821C(v))
/* 2 REG_PCIE_HCPWM1_V1_8821C */
#define BIT_SHIFT_PCIE_HCPWM_8821C 0
#define BIT_MASK_PCIE_HCPWM_8821C 0xff
#define BIT_PCIE_HCPWM_8821C(x) \
(((x) & BIT_MASK_PCIE_HCPWM_8821C) << BIT_SHIFT_PCIE_HCPWM_8821C)
#define BITS_PCIE_HCPWM_8821C \
(BIT_MASK_PCIE_HCPWM_8821C << BIT_SHIFT_PCIE_HCPWM_8821C)
#define BIT_CLEAR_PCIE_HCPWM_8821C(x) ((x) & (~BITS_PCIE_HCPWM_8821C))
#define BIT_GET_PCIE_HCPWM_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM_8821C) & BIT_MASK_PCIE_HCPWM_8821C)
#define BIT_SET_PCIE_HCPWM_8821C(x, v) \
(BIT_CLEAR_PCIE_HCPWM_8821C(x) | BIT_PCIE_HCPWM_8821C(v))
/* 2 REG_PCIE_CTRL2_8821C */
#define BIT_DIS_TXDMA_PRE_8821C BIT(7)
#define BIT_DIS_RXDMA_PRE_8821C BIT(6)
#define BIT_SHIFT_HPS_CLKR_PCIE_8821C 4
#define BIT_MASK_HPS_CLKR_PCIE_8821C 0x3
#define BIT_HPS_CLKR_PCIE_8821C(x) \
(((x) & BIT_MASK_HPS_CLKR_PCIE_8821C) << BIT_SHIFT_HPS_CLKR_PCIE_8821C)
#define BITS_HPS_CLKR_PCIE_8821C \
(BIT_MASK_HPS_CLKR_PCIE_8821C << BIT_SHIFT_HPS_CLKR_PCIE_8821C)
#define BIT_CLEAR_HPS_CLKR_PCIE_8821C(x) ((x) & (~BITS_HPS_CLKR_PCIE_8821C))
#define BIT_GET_HPS_CLKR_PCIE_8821C(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_PCIE_8821C) & BIT_MASK_HPS_CLKR_PCIE_8821C)
#define BIT_SET_HPS_CLKR_PCIE_8821C(x, v) \
(BIT_CLEAR_HPS_CLKR_PCIE_8821C(x) | BIT_HPS_CLKR_PCIE_8821C(v))
#define BIT_PCIE_INT_8821C BIT(3)
#define BIT_TXFLAG_EXIT_L1_EN_8821C BIT(2)
#define BIT_EN_RXDMA_ALIGN_8821C BIT(1)
#define BIT_EN_TXDMA_ALIGN_8821C BIT(0)
/* 2 REG_PCIE_HRPWM2_V1_8821C */
#define BIT_SHIFT_PCIE_HRPWM2_8821C 0
#define BIT_MASK_PCIE_HRPWM2_8821C 0xffff
#define BIT_PCIE_HRPWM2_8821C(x) \
(((x) & BIT_MASK_PCIE_HRPWM2_8821C) << BIT_SHIFT_PCIE_HRPWM2_8821C)
#define BITS_PCIE_HRPWM2_8821C \
(BIT_MASK_PCIE_HRPWM2_8821C << BIT_SHIFT_PCIE_HRPWM2_8821C)
#define BIT_CLEAR_PCIE_HRPWM2_8821C(x) ((x) & (~BITS_PCIE_HRPWM2_8821C))
#define BIT_GET_PCIE_HRPWM2_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM2_8821C) & BIT_MASK_PCIE_HRPWM2_8821C)
#define BIT_SET_PCIE_HRPWM2_8821C(x, v) \
(BIT_CLEAR_PCIE_HRPWM2_8821C(x) | BIT_PCIE_HRPWM2_8821C(v))
/* 2 REG_PCIE_HCPWM2_V1_8821C */
#define BIT_SHIFT_PCIE_HCPWM2_8821C 0
#define BIT_MASK_PCIE_HCPWM2_8821C 0xffff
#define BIT_PCIE_HCPWM2_8821C(x) \
(((x) & BIT_MASK_PCIE_HCPWM2_8821C) << BIT_SHIFT_PCIE_HCPWM2_8821C)
#define BITS_PCIE_HCPWM2_8821C \
(BIT_MASK_PCIE_HCPWM2_8821C << BIT_SHIFT_PCIE_HCPWM2_8821C)
#define BIT_CLEAR_PCIE_HCPWM2_8821C(x) ((x) & (~BITS_PCIE_HCPWM2_8821C))
#define BIT_GET_PCIE_HCPWM2_8821C(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM2_8821C) & BIT_MASK_PCIE_HCPWM2_8821C)
#define BIT_SET_PCIE_HCPWM2_8821C(x, v) \
(BIT_CLEAR_PCIE_HCPWM2_8821C(x) | BIT_PCIE_HCPWM2_8821C(v))
/* 2 REG_PCIE_H2C_MSG_V1_8821C */
#define BIT_SHIFT_DRV2FW_INFO_8821C 0
#define BIT_MASK_DRV2FW_INFO_8821C 0xffffffffL
#define BIT_DRV2FW_INFO_8821C(x) \
(((x) & BIT_MASK_DRV2FW_INFO_8821C) << BIT_SHIFT_DRV2FW_INFO_8821C)
#define BITS_DRV2FW_INFO_8821C \
(BIT_MASK_DRV2FW_INFO_8821C << BIT_SHIFT_DRV2FW_INFO_8821C)
#define BIT_CLEAR_DRV2FW_INFO_8821C(x) ((x) & (~BITS_DRV2FW_INFO_8821C))
#define BIT_GET_DRV2FW_INFO_8821C(x) \
(((x) >> BIT_SHIFT_DRV2FW_INFO_8821C) & BIT_MASK_DRV2FW_INFO_8821C)
#define BIT_SET_DRV2FW_INFO_8821C(x, v) \
(BIT_CLEAR_DRV2FW_INFO_8821C(x) | BIT_DRV2FW_INFO_8821C(v))
/* 2 REG_PCIE_C2H_MSG_V1_8821C */
#define BIT_SHIFT_HCI_PCIE_C2H_MSG_8821C 0
#define BIT_MASK_HCI_PCIE_C2H_MSG_8821C 0xffffffffL
#define BIT_HCI_PCIE_C2H_MSG_8821C(x) \
(((x) & BIT_MASK_HCI_PCIE_C2H_MSG_8821C) \
<< BIT_SHIFT_HCI_PCIE_C2H_MSG_8821C)
#define BITS_HCI_PCIE_C2H_MSG_8821C \
(BIT_MASK_HCI_PCIE_C2H_MSG_8821C << BIT_SHIFT_HCI_PCIE_C2H_MSG_8821C)
#define BIT_CLEAR_HCI_PCIE_C2H_MSG_8821C(x) \
((x) & (~BITS_HCI_PCIE_C2H_MSG_8821C))
#define BIT_GET_HCI_PCIE_C2H_MSG_8821C(x) \
(((x) >> BIT_SHIFT_HCI_PCIE_C2H_MSG_8821C) & \
BIT_MASK_HCI_PCIE_C2H_MSG_8821C)
#define BIT_SET_HCI_PCIE_C2H_MSG_8821C(x, v) \
(BIT_CLEAR_HCI_PCIE_C2H_MSG_8821C(x) | BIT_HCI_PCIE_C2H_MSG_8821C(v))
/* 2 REG_DBI_WDATA_V1_8821C */
#define BIT_SHIFT_DBI_WDATA_8821C 0
#define BIT_MASK_DBI_WDATA_8821C 0xffffffffL
#define BIT_DBI_WDATA_8821C(x) \
(((x) & BIT_MASK_DBI_WDATA_8821C) << BIT_SHIFT_DBI_WDATA_8821C)
#define BITS_DBI_WDATA_8821C \
(BIT_MASK_DBI_WDATA_8821C << BIT_SHIFT_DBI_WDATA_8821C)
#define BIT_CLEAR_DBI_WDATA_8821C(x) ((x) & (~BITS_DBI_WDATA_8821C))
#define BIT_GET_DBI_WDATA_8821C(x) \
(((x) >> BIT_SHIFT_DBI_WDATA_8821C) & BIT_MASK_DBI_WDATA_8821C)
#define BIT_SET_DBI_WDATA_8821C(x, v) \
(BIT_CLEAR_DBI_WDATA_8821C(x) | BIT_DBI_WDATA_8821C(v))
/* 2 REG_DBI_RDATA_V1_8821C */
#define BIT_SHIFT_DBI_RDATA_8821C 0
#define BIT_MASK_DBI_RDATA_8821C 0xffffffffL
#define BIT_DBI_RDATA_8821C(x) \
(((x) & BIT_MASK_DBI_RDATA_8821C) << BIT_SHIFT_DBI_RDATA_8821C)
#define BITS_DBI_RDATA_8821C \
(BIT_MASK_DBI_RDATA_8821C << BIT_SHIFT_DBI_RDATA_8821C)
#define BIT_CLEAR_DBI_RDATA_8821C(x) ((x) & (~BITS_DBI_RDATA_8821C))
#define BIT_GET_DBI_RDATA_8821C(x) \
(((x) >> BIT_SHIFT_DBI_RDATA_8821C) & BIT_MASK_DBI_RDATA_8821C)
#define BIT_SET_DBI_RDATA_8821C(x, v) \
(BIT_CLEAR_DBI_RDATA_8821C(x) | BIT_DBI_RDATA_8821C(v))
/* 2 REG_DBI_FLAG_V1_8821C */
#define BIT_EN_STUCK_DBG_8821C BIT(26)
#define BIT_RX_STUCK_8821C BIT(25)
#define BIT_TX_STUCK_8821C BIT(24)
#define BIT_DBI_RFLAG_8821C BIT(17)
#define BIT_DBI_WFLAG_8821C BIT(16)
#define BIT_SHIFT_DBI_WREN_8821C 12
#define BIT_MASK_DBI_WREN_8821C 0xf
#define BIT_DBI_WREN_8821C(x) \
(((x) & BIT_MASK_DBI_WREN_8821C) << BIT_SHIFT_DBI_WREN_8821C)
#define BITS_DBI_WREN_8821C \
(BIT_MASK_DBI_WREN_8821C << BIT_SHIFT_DBI_WREN_8821C)
#define BIT_CLEAR_DBI_WREN_8821C(x) ((x) & (~BITS_DBI_WREN_8821C))
#define BIT_GET_DBI_WREN_8821C(x) \
(((x) >> BIT_SHIFT_DBI_WREN_8821C) & BIT_MASK_DBI_WREN_8821C)
#define BIT_SET_DBI_WREN_8821C(x, v) \
(BIT_CLEAR_DBI_WREN_8821C(x) | BIT_DBI_WREN_8821C(v))
#define BIT_SHIFT_DBI_ADDR_8821C 0
#define BIT_MASK_DBI_ADDR_8821C 0xfff
#define BIT_DBI_ADDR_8821C(x) \
(((x) & BIT_MASK_DBI_ADDR_8821C) << BIT_SHIFT_DBI_ADDR_8821C)
#define BITS_DBI_ADDR_8821C \
(BIT_MASK_DBI_ADDR_8821C << BIT_SHIFT_DBI_ADDR_8821C)
#define BIT_CLEAR_DBI_ADDR_8821C(x) ((x) & (~BITS_DBI_ADDR_8821C))
#define BIT_GET_DBI_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_DBI_ADDR_8821C) & BIT_MASK_DBI_ADDR_8821C)
#define BIT_SET_DBI_ADDR_8821C(x, v) \
(BIT_CLEAR_DBI_ADDR_8821C(x) | BIT_DBI_ADDR_8821C(v))
/* 2 REG_MDIO_V1_8821C */
#define BIT_SHIFT_MDIO_RDATA_8821C 16
#define BIT_MASK_MDIO_RDATA_8821C 0xffff
#define BIT_MDIO_RDATA_8821C(x) \
(((x) & BIT_MASK_MDIO_RDATA_8821C) << BIT_SHIFT_MDIO_RDATA_8821C)
#define BITS_MDIO_RDATA_8821C \
(BIT_MASK_MDIO_RDATA_8821C << BIT_SHIFT_MDIO_RDATA_8821C)
#define BIT_CLEAR_MDIO_RDATA_8821C(x) ((x) & (~BITS_MDIO_RDATA_8821C))
#define BIT_GET_MDIO_RDATA_8821C(x) \
(((x) >> BIT_SHIFT_MDIO_RDATA_8821C) & BIT_MASK_MDIO_RDATA_8821C)
#define BIT_SET_MDIO_RDATA_8821C(x, v) \
(BIT_CLEAR_MDIO_RDATA_8821C(x) | BIT_MDIO_RDATA_8821C(v))
#define BIT_SHIFT_MDIO_WDATA_8821C 0
#define BIT_MASK_MDIO_WDATA_8821C 0xffff
#define BIT_MDIO_WDATA_8821C(x) \
(((x) & BIT_MASK_MDIO_WDATA_8821C) << BIT_SHIFT_MDIO_WDATA_8821C)
#define BITS_MDIO_WDATA_8821C \
(BIT_MASK_MDIO_WDATA_8821C << BIT_SHIFT_MDIO_WDATA_8821C)
#define BIT_CLEAR_MDIO_WDATA_8821C(x) ((x) & (~BITS_MDIO_WDATA_8821C))
#define BIT_GET_MDIO_WDATA_8821C(x) \
(((x) >> BIT_SHIFT_MDIO_WDATA_8821C) & BIT_MASK_MDIO_WDATA_8821C)
#define BIT_SET_MDIO_WDATA_8821C(x, v) \
(BIT_CLEAR_MDIO_WDATA_8821C(x) | BIT_MDIO_WDATA_8821C(v))
/* 2 REG_PCIE_MIX_CFG_8821C */
#define BIT_SHIFT_MDIO_PHY_ADDR_8821C 24
#define BIT_MASK_MDIO_PHY_ADDR_8821C 0x1f
#define BIT_MDIO_PHY_ADDR_8821C(x) \
(((x) & BIT_MASK_MDIO_PHY_ADDR_8821C) << BIT_SHIFT_MDIO_PHY_ADDR_8821C)
#define BITS_MDIO_PHY_ADDR_8821C \
(BIT_MASK_MDIO_PHY_ADDR_8821C << BIT_SHIFT_MDIO_PHY_ADDR_8821C)
#define BIT_CLEAR_MDIO_PHY_ADDR_8821C(x) ((x) & (~BITS_MDIO_PHY_ADDR_8821C))
#define BIT_GET_MDIO_PHY_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_MDIO_PHY_ADDR_8821C) & BIT_MASK_MDIO_PHY_ADDR_8821C)
#define BIT_SET_MDIO_PHY_ADDR_8821C(x, v) \
(BIT_CLEAR_MDIO_PHY_ADDR_8821C(x) | BIT_MDIO_PHY_ADDR_8821C(v))
#define BIT_SHIFT_WATCH_DOG_RECORD_V1_8821C 10
#define BIT_MASK_WATCH_DOG_RECORD_V1_8821C 0x3fff
#define BIT_WATCH_DOG_RECORD_V1_8821C(x) \
(((x) & BIT_MASK_WATCH_DOG_RECORD_V1_8821C) \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8821C)
#define BITS_WATCH_DOG_RECORD_V1_8821C \
(BIT_MASK_WATCH_DOG_RECORD_V1_8821C \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8821C)
#define BIT_CLEAR_WATCH_DOG_RECORD_V1_8821C(x) \
((x) & (~BITS_WATCH_DOG_RECORD_V1_8821C))
#define BIT_GET_WATCH_DOG_RECORD_V1_8821C(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_RECORD_V1_8821C) & \
BIT_MASK_WATCH_DOG_RECORD_V1_8821C)
#define BIT_SET_WATCH_DOG_RECORD_V1_8821C(x, v) \
(BIT_CLEAR_WATCH_DOG_RECORD_V1_8821C(x) | \
BIT_WATCH_DOG_RECORD_V1_8821C(v))
#define BIT_R_IO_TIMEOUT_FLAG_V1_8821C BIT(9)
#define BIT_EN_WATCH_DOG_8821C BIT(8)
#define BIT_ECRC_EN_V1_8821C BIT(7)
#define BIT_MDIO_RFLAG_V1_8821C BIT(6)
#define BIT_MDIO_WFLAG_V1_8821C BIT(5)
#define BIT_SHIFT_MDIO_REG_ADDR_V1_8821C 0
#define BIT_MASK_MDIO_REG_ADDR_V1_8821C 0x1f
#define BIT_MDIO_REG_ADDR_V1_8821C(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR_V1_8821C) \
<< BIT_SHIFT_MDIO_REG_ADDR_V1_8821C)
#define BITS_MDIO_REG_ADDR_V1_8821C \
(BIT_MASK_MDIO_REG_ADDR_V1_8821C << BIT_SHIFT_MDIO_REG_ADDR_V1_8821C)
#define BIT_CLEAR_MDIO_REG_ADDR_V1_8821C(x) \
((x) & (~BITS_MDIO_REG_ADDR_V1_8821C))
#define BIT_GET_MDIO_REG_ADDR_V1_8821C(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR_V1_8821C) & \
BIT_MASK_MDIO_REG_ADDR_V1_8821C)
#define BIT_SET_MDIO_REG_ADDR_V1_8821C(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR_V1_8821C(x) | BIT_MDIO_REG_ADDR_V1_8821C(v))
/* 2 REG_HCI_MIX_CFG_8821C */
#define BIT_HOST_GEN2_SUPPORT_8821C BIT(20)
#define BIT_SHIFT_TXDMA_ERR_FLAG_8821C 16
#define BIT_MASK_TXDMA_ERR_FLAG_8821C 0xf
#define BIT_TXDMA_ERR_FLAG_8821C(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG_8821C) \
<< BIT_SHIFT_TXDMA_ERR_FLAG_8821C)
#define BITS_TXDMA_ERR_FLAG_8821C \
(BIT_MASK_TXDMA_ERR_FLAG_8821C << BIT_SHIFT_TXDMA_ERR_FLAG_8821C)
#define BIT_CLEAR_TXDMA_ERR_FLAG_8821C(x) ((x) & (~BITS_TXDMA_ERR_FLAG_8821C))
#define BIT_GET_TXDMA_ERR_FLAG_8821C(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG_8821C) & \
BIT_MASK_TXDMA_ERR_FLAG_8821C)
#define BIT_SET_TXDMA_ERR_FLAG_8821C(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG_8821C(x) | BIT_TXDMA_ERR_FLAG_8821C(v))
#define BIT_SHIFT_EARLY_MODE_SEL_8821C 12
#define BIT_MASK_EARLY_MODE_SEL_8821C 0xf
#define BIT_EARLY_MODE_SEL_8821C(x) \
(((x) & BIT_MASK_EARLY_MODE_SEL_8821C) \
<< BIT_SHIFT_EARLY_MODE_SEL_8821C)
#define BITS_EARLY_MODE_SEL_8821C \
(BIT_MASK_EARLY_MODE_SEL_8821C << BIT_SHIFT_EARLY_MODE_SEL_8821C)
#define BIT_CLEAR_EARLY_MODE_SEL_8821C(x) ((x) & (~BITS_EARLY_MODE_SEL_8821C))
#define BIT_GET_EARLY_MODE_SEL_8821C(x) \
(((x) >> BIT_SHIFT_EARLY_MODE_SEL_8821C) & \
BIT_MASK_EARLY_MODE_SEL_8821C)
#define BIT_SET_EARLY_MODE_SEL_8821C(x, v) \
(BIT_CLEAR_EARLY_MODE_SEL_8821C(x) | BIT_EARLY_MODE_SEL_8821C(v))
#define BIT_EPHY_RX50_EN_8821C BIT(11)
#define BIT_SHIFT_MSI_TIMEOUT_ID_V1_8821C 8
#define BIT_MASK_MSI_TIMEOUT_ID_V1_8821C 0x7
#define BIT_MSI_TIMEOUT_ID_V1_8821C(x) \
(((x) & BIT_MASK_MSI_TIMEOUT_ID_V1_8821C) \
<< BIT_SHIFT_MSI_TIMEOUT_ID_V1_8821C)
#define BITS_MSI_TIMEOUT_ID_V1_8821C \
(BIT_MASK_MSI_TIMEOUT_ID_V1_8821C << BIT_SHIFT_MSI_TIMEOUT_ID_V1_8821C)
#define BIT_CLEAR_MSI_TIMEOUT_ID_V1_8821C(x) \
((x) & (~BITS_MSI_TIMEOUT_ID_V1_8821C))
#define BIT_GET_MSI_TIMEOUT_ID_V1_8821C(x) \
(((x) >> BIT_SHIFT_MSI_TIMEOUT_ID_V1_8821C) & \
BIT_MASK_MSI_TIMEOUT_ID_V1_8821C)
#define BIT_SET_MSI_TIMEOUT_ID_V1_8821C(x, v) \
(BIT_CLEAR_MSI_TIMEOUT_ID_V1_8821C(x) | BIT_MSI_TIMEOUT_ID_V1_8821C(v))
#define BIT_RADDR_RD_8821C BIT(7)
#define BIT_EN_MUL_TAG_8821C BIT(6)
#define BIT_EN_EARLY_MODE_8821C BIT(5)
#define BIT_L0S_LINK_OFF_8821C BIT(4)
#define BIT_ACT_LINK_OFF_8821C BIT(3)
#define BIT_EN_SLOW_MAC_TX_8821C BIT(2)
#define BIT_EN_SLOW_MAC_RX_8821C BIT(1)
/* 2 REG_STC_INT_CS_8821C(PCIE STATE CHANGE INTERRUPT CONTROL AND STATUS) */
#define BIT_STC_INT_EN_8821C BIT(31)
#define BIT_SHIFT_STC_INT_FLAG_8821C 16
#define BIT_MASK_STC_INT_FLAG_8821C 0xff
#define BIT_STC_INT_FLAG_8821C(x) \
(((x) & BIT_MASK_STC_INT_FLAG_8821C) << BIT_SHIFT_STC_INT_FLAG_8821C)
#define BITS_STC_INT_FLAG_8821C \
(BIT_MASK_STC_INT_FLAG_8821C << BIT_SHIFT_STC_INT_FLAG_8821C)
#define BIT_CLEAR_STC_INT_FLAG_8821C(x) ((x) & (~BITS_STC_INT_FLAG_8821C))
#define BIT_GET_STC_INT_FLAG_8821C(x) \
(((x) >> BIT_SHIFT_STC_INT_FLAG_8821C) & BIT_MASK_STC_INT_FLAG_8821C)
#define BIT_SET_STC_INT_FLAG_8821C(x, v) \
(BIT_CLEAR_STC_INT_FLAG_8821C(x) | BIT_STC_INT_FLAG_8821C(v))
#define BIT_SHIFT_STC_INT_IDX_8821C 8
#define BIT_MASK_STC_INT_IDX_8821C 0x7
#define BIT_STC_INT_IDX_8821C(x) \
(((x) & BIT_MASK_STC_INT_IDX_8821C) << BIT_SHIFT_STC_INT_IDX_8821C)
#define BITS_STC_INT_IDX_8821C \
(BIT_MASK_STC_INT_IDX_8821C << BIT_SHIFT_STC_INT_IDX_8821C)
#define BIT_CLEAR_STC_INT_IDX_8821C(x) ((x) & (~BITS_STC_INT_IDX_8821C))
#define BIT_GET_STC_INT_IDX_8821C(x) \
(((x) >> BIT_SHIFT_STC_INT_IDX_8821C) & BIT_MASK_STC_INT_IDX_8821C)
#define BIT_SET_STC_INT_IDX_8821C(x, v) \
(BIT_CLEAR_STC_INT_IDX_8821C(x) | BIT_STC_INT_IDX_8821C(v))
#define BIT_SHIFT_STC_INT_REALTIME_CS_8821C 0
#define BIT_MASK_STC_INT_REALTIME_CS_8821C 0x3f
#define BIT_STC_INT_REALTIME_CS_8821C(x) \
(((x) & BIT_MASK_STC_INT_REALTIME_CS_8821C) \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8821C)
#define BITS_STC_INT_REALTIME_CS_8821C \
(BIT_MASK_STC_INT_REALTIME_CS_8821C \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8821C)
#define BIT_CLEAR_STC_INT_REALTIME_CS_8821C(x) \
((x) & (~BITS_STC_INT_REALTIME_CS_8821C))
#define BIT_GET_STC_INT_REALTIME_CS_8821C(x) \
(((x) >> BIT_SHIFT_STC_INT_REALTIME_CS_8821C) & \
BIT_MASK_STC_INT_REALTIME_CS_8821C)
#define BIT_SET_STC_INT_REALTIME_CS_8821C(x, v) \
(BIT_CLEAR_STC_INT_REALTIME_CS_8821C(x) | \
BIT_STC_INT_REALTIME_CS_8821C(v))
/* 2 REG_ST_INT_CFG_8821C(PCIE STATE CHANGE INTERRUPT CONFIGURATION) */
#define BIT_STC_INT_GRP_EN_8821C BIT(31)
#define BIT_SHIFT_STC_INT_EXPECT_LS_8821C 8
#define BIT_MASK_STC_INT_EXPECT_LS_8821C 0x3f
#define BIT_STC_INT_EXPECT_LS_8821C(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_LS_8821C) \
<< BIT_SHIFT_STC_INT_EXPECT_LS_8821C)
#define BITS_STC_INT_EXPECT_LS_8821C \
(BIT_MASK_STC_INT_EXPECT_LS_8821C << BIT_SHIFT_STC_INT_EXPECT_LS_8821C)
#define BIT_CLEAR_STC_INT_EXPECT_LS_8821C(x) \
((x) & (~BITS_STC_INT_EXPECT_LS_8821C))
#define BIT_GET_STC_INT_EXPECT_LS_8821C(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_LS_8821C) & \
BIT_MASK_STC_INT_EXPECT_LS_8821C)
#define BIT_SET_STC_INT_EXPECT_LS_8821C(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_LS_8821C(x) | BIT_STC_INT_EXPECT_LS_8821C(v))
#define BIT_SHIFT_STC_INT_EXPECT_CS_8821C 0
#define BIT_MASK_STC_INT_EXPECT_CS_8821C 0x3f
#define BIT_STC_INT_EXPECT_CS_8821C(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_CS_8821C) \
<< BIT_SHIFT_STC_INT_EXPECT_CS_8821C)
#define BITS_STC_INT_EXPECT_CS_8821C \
(BIT_MASK_STC_INT_EXPECT_CS_8821C << BIT_SHIFT_STC_INT_EXPECT_CS_8821C)
#define BIT_CLEAR_STC_INT_EXPECT_CS_8821C(x) \
((x) & (~BITS_STC_INT_EXPECT_CS_8821C))
#define BIT_GET_STC_INT_EXPECT_CS_8821C(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_CS_8821C) & \
BIT_MASK_STC_INT_EXPECT_CS_8821C)
#define BIT_SET_STC_INT_EXPECT_CS_8821C(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_CS_8821C(x) | BIT_STC_INT_EXPECT_CS_8821C(v))
/* 2 REG_CMU_DLY_CTRL_8821C(PCIE PHY CLOCK MGT UNIT DELAY CONTROL ) */
#define BIT_CMU_DLY_EN_8821C BIT(31)
#define BIT_CMU_DLY_MODE_8821C BIT(30)
#define BIT_SHIFT_CMU_DLY_PRE_DIV_8821C 0
#define BIT_MASK_CMU_DLY_PRE_DIV_8821C 0xff
#define BIT_CMU_DLY_PRE_DIV_8821C(x) \
(((x) & BIT_MASK_CMU_DLY_PRE_DIV_8821C) \
<< BIT_SHIFT_CMU_DLY_PRE_DIV_8821C)
#define BITS_CMU_DLY_PRE_DIV_8821C \
(BIT_MASK_CMU_DLY_PRE_DIV_8821C << BIT_SHIFT_CMU_DLY_PRE_DIV_8821C)
#define BIT_CLEAR_CMU_DLY_PRE_DIV_8821C(x) ((x) & (~BITS_CMU_DLY_PRE_DIV_8821C))
#define BIT_GET_CMU_DLY_PRE_DIV_8821C(x) \
(((x) >> BIT_SHIFT_CMU_DLY_PRE_DIV_8821C) & \
BIT_MASK_CMU_DLY_PRE_DIV_8821C)
#define BIT_SET_CMU_DLY_PRE_DIV_8821C(x, v) \
(BIT_CLEAR_CMU_DLY_PRE_DIV_8821C(x) | BIT_CMU_DLY_PRE_DIV_8821C(v))
/* 2 REG_CMU_DLY_CFG_8821C(PCIE PHY CLOCK MGT UNIT DELAY CONFIGURATION ) */
#define BIT_SHIFT_CMU_DLY_LTR_A2I_8821C 24
#define BIT_MASK_CMU_DLY_LTR_A2I_8821C 0xff
#define BIT_CMU_DLY_LTR_A2I_8821C(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_A2I_8821C) \
<< BIT_SHIFT_CMU_DLY_LTR_A2I_8821C)
#define BITS_CMU_DLY_LTR_A2I_8821C \
(BIT_MASK_CMU_DLY_LTR_A2I_8821C << BIT_SHIFT_CMU_DLY_LTR_A2I_8821C)
#define BIT_CLEAR_CMU_DLY_LTR_A2I_8821C(x) ((x) & (~BITS_CMU_DLY_LTR_A2I_8821C))
#define BIT_GET_CMU_DLY_LTR_A2I_8821C(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_A2I_8821C) & \
BIT_MASK_CMU_DLY_LTR_A2I_8821C)
#define BIT_SET_CMU_DLY_LTR_A2I_8821C(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_A2I_8821C(x) | BIT_CMU_DLY_LTR_A2I_8821C(v))
#define BIT_SHIFT_CMU_DLY_LTR_I2A_8821C 16
#define BIT_MASK_CMU_DLY_LTR_I2A_8821C 0xff
#define BIT_CMU_DLY_LTR_I2A_8821C(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_I2A_8821C) \
<< BIT_SHIFT_CMU_DLY_LTR_I2A_8821C)
#define BITS_CMU_DLY_LTR_I2A_8821C \
(BIT_MASK_CMU_DLY_LTR_I2A_8821C << BIT_SHIFT_CMU_DLY_LTR_I2A_8821C)
#define BIT_CLEAR_CMU_DLY_LTR_I2A_8821C(x) ((x) & (~BITS_CMU_DLY_LTR_I2A_8821C))
#define BIT_GET_CMU_DLY_LTR_I2A_8821C(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_I2A_8821C) & \
BIT_MASK_CMU_DLY_LTR_I2A_8821C)
#define BIT_SET_CMU_DLY_LTR_I2A_8821C(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_I2A_8821C(x) | BIT_CMU_DLY_LTR_I2A_8821C(v))
#define BIT_SHIFT_CMU_DLY_LTR_IDLE_8821C 8
#define BIT_MASK_CMU_DLY_LTR_IDLE_8821C 0xff
#define BIT_CMU_DLY_LTR_IDLE_8821C(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_IDLE_8821C) \
<< BIT_SHIFT_CMU_DLY_LTR_IDLE_8821C)
#define BITS_CMU_DLY_LTR_IDLE_8821C \
(BIT_MASK_CMU_DLY_LTR_IDLE_8821C << BIT_SHIFT_CMU_DLY_LTR_IDLE_8821C)
#define BIT_CLEAR_CMU_DLY_LTR_IDLE_8821C(x) \
((x) & (~BITS_CMU_DLY_LTR_IDLE_8821C))
#define BIT_GET_CMU_DLY_LTR_IDLE_8821C(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_IDLE_8821C) & \
BIT_MASK_CMU_DLY_LTR_IDLE_8821C)
#define BIT_SET_CMU_DLY_LTR_IDLE_8821C(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_IDLE_8821C(x) | BIT_CMU_DLY_LTR_IDLE_8821C(v))
#define BIT_SHIFT_CMU_DLY_LTR_ACT_8821C 0
#define BIT_MASK_CMU_DLY_LTR_ACT_8821C 0xff
#define BIT_CMU_DLY_LTR_ACT_8821C(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_ACT_8821C) \
<< BIT_SHIFT_CMU_DLY_LTR_ACT_8821C)
#define BITS_CMU_DLY_LTR_ACT_8821C \
(BIT_MASK_CMU_DLY_LTR_ACT_8821C << BIT_SHIFT_CMU_DLY_LTR_ACT_8821C)
#define BIT_CLEAR_CMU_DLY_LTR_ACT_8821C(x) ((x) & (~BITS_CMU_DLY_LTR_ACT_8821C))
#define BIT_GET_CMU_DLY_LTR_ACT_8821C(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_ACT_8821C) & \
BIT_MASK_CMU_DLY_LTR_ACT_8821C)
#define BIT_SET_CMU_DLY_LTR_ACT_8821C(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_ACT_8821C(x) | BIT_CMU_DLY_LTR_ACT_8821C(v))
/* 2 REG_H2CQ_TXBD_DESA_8821C */
#define BIT_SHIFT_H2CQ_TXBD_DESA_8821C 0
#define BIT_MASK_H2CQ_TXBD_DESA_8821C 0xffffffffffffffffL
#define BIT_H2CQ_TXBD_DESA_8821C(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_8821C) \
<< BIT_SHIFT_H2CQ_TXBD_DESA_8821C)
#define BITS_H2CQ_TXBD_DESA_8821C \
(BIT_MASK_H2CQ_TXBD_DESA_8821C << BIT_SHIFT_H2CQ_TXBD_DESA_8821C)
#define BIT_CLEAR_H2CQ_TXBD_DESA_8821C(x) ((x) & (~BITS_H2CQ_TXBD_DESA_8821C))
#define BIT_GET_H2CQ_TXBD_DESA_8821C(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_8821C) & \
BIT_MASK_H2CQ_TXBD_DESA_8821C)
#define BIT_SET_H2CQ_TXBD_DESA_8821C(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_8821C(x) | BIT_H2CQ_TXBD_DESA_8821C(v))
/* 2 REG_H2CQ_TXBD_NUM_8821C */
#define BIT_PCIE_H2CQ_FLAG_8821C BIT(14)
#define BIT_SHIFT_H2CQ_DESC_MODE_8821C 12
#define BIT_MASK_H2CQ_DESC_MODE_8821C 0x3
#define BIT_H2CQ_DESC_MODE_8821C(x) \
(((x) & BIT_MASK_H2CQ_DESC_MODE_8821C) \
<< BIT_SHIFT_H2CQ_DESC_MODE_8821C)
#define BITS_H2CQ_DESC_MODE_8821C \
(BIT_MASK_H2CQ_DESC_MODE_8821C << BIT_SHIFT_H2CQ_DESC_MODE_8821C)
#define BIT_CLEAR_H2CQ_DESC_MODE_8821C(x) ((x) & (~BITS_H2CQ_DESC_MODE_8821C))
#define BIT_GET_H2CQ_DESC_MODE_8821C(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_MODE_8821C) & \
BIT_MASK_H2CQ_DESC_MODE_8821C)
#define BIT_SET_H2CQ_DESC_MODE_8821C(x, v) \
(BIT_CLEAR_H2CQ_DESC_MODE_8821C(x) | BIT_H2CQ_DESC_MODE_8821C(v))
#define BIT_SHIFT_H2CQ_DESC_NUM_8821C 0
#define BIT_MASK_H2CQ_DESC_NUM_8821C 0xfff
#define BIT_H2CQ_DESC_NUM_8821C(x) \
(((x) & BIT_MASK_H2CQ_DESC_NUM_8821C) << BIT_SHIFT_H2CQ_DESC_NUM_8821C)
#define BITS_H2CQ_DESC_NUM_8821C \
(BIT_MASK_H2CQ_DESC_NUM_8821C << BIT_SHIFT_H2CQ_DESC_NUM_8821C)
#define BIT_CLEAR_H2CQ_DESC_NUM_8821C(x) ((x) & (~BITS_H2CQ_DESC_NUM_8821C))
#define BIT_GET_H2CQ_DESC_NUM_8821C(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_NUM_8821C) & BIT_MASK_H2CQ_DESC_NUM_8821C)
#define BIT_SET_H2CQ_DESC_NUM_8821C(x, v) \
(BIT_CLEAR_H2CQ_DESC_NUM_8821C(x) | BIT_H2CQ_DESC_NUM_8821C(v))
/* 2 REG_H2CQ_TXBD_IDX_8821C */
#define BIT_SHIFT_H2CQ_HW_IDX_8821C 16
#define BIT_MASK_H2CQ_HW_IDX_8821C 0xfff
#define BIT_H2CQ_HW_IDX_8821C(x) \
(((x) & BIT_MASK_H2CQ_HW_IDX_8821C) << BIT_SHIFT_H2CQ_HW_IDX_8821C)
#define BITS_H2CQ_HW_IDX_8821C \
(BIT_MASK_H2CQ_HW_IDX_8821C << BIT_SHIFT_H2CQ_HW_IDX_8821C)
#define BIT_CLEAR_H2CQ_HW_IDX_8821C(x) ((x) & (~BITS_H2CQ_HW_IDX_8821C))
#define BIT_GET_H2CQ_HW_IDX_8821C(x) \
(((x) >> BIT_SHIFT_H2CQ_HW_IDX_8821C) & BIT_MASK_H2CQ_HW_IDX_8821C)
#define BIT_SET_H2CQ_HW_IDX_8821C(x, v) \
(BIT_CLEAR_H2CQ_HW_IDX_8821C(x) | BIT_H2CQ_HW_IDX_8821C(v))
#define BIT_SHIFT_H2CQ_HOST_IDX_8821C 0
#define BIT_MASK_H2CQ_HOST_IDX_8821C 0xfff
#define BIT_H2CQ_HOST_IDX_8821C(x) \
(((x) & BIT_MASK_H2CQ_HOST_IDX_8821C) << BIT_SHIFT_H2CQ_HOST_IDX_8821C)
#define BITS_H2CQ_HOST_IDX_8821C \
(BIT_MASK_H2CQ_HOST_IDX_8821C << BIT_SHIFT_H2CQ_HOST_IDX_8821C)
#define BIT_CLEAR_H2CQ_HOST_IDX_8821C(x) ((x) & (~BITS_H2CQ_HOST_IDX_8821C))
#define BIT_GET_H2CQ_HOST_IDX_8821C(x) \
(((x) >> BIT_SHIFT_H2CQ_HOST_IDX_8821C) & BIT_MASK_H2CQ_HOST_IDX_8821C)
#define BIT_SET_H2CQ_HOST_IDX_8821C(x, v) \
(BIT_CLEAR_H2CQ_HOST_IDX_8821C(x) | BIT_H2CQ_HOST_IDX_8821C(v))
/* 2 REG_H2CQ_CSR_8821C[31:0] (H2CQ CONTROL AND STATUS) */
#define BIT_H2CQ_FULL_8821C BIT(31)
#define BIT_CLR_H2CQ_HOST_IDX_8821C BIT(16)
#define BIT_CLR_H2CQ_HW_IDX_8821C BIT(8)
#define BIT_STOP_H2CQ_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_Q0_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q0_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q0_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q0_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q0_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q0_V1_8821C)
#define BITS_QUEUEMACID_Q0_V1_8821C \
(BIT_MASK_QUEUEMACID_Q0_V1_8821C << BIT_SHIFT_QUEUEMACID_Q0_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q0_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q0_V1_8821C))
#define BIT_GET_QUEUEMACID_Q0_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q0_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q0_V1_8821C)
#define BIT_SET_QUEUEMACID_Q0_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q0_V1_8821C(x) | BIT_QUEUEMACID_Q0_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q0_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q0_V1_8821C 0x3
#define BIT_QUEUEAC_Q0_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q0_V1_8821C) << BIT_SHIFT_QUEUEAC_Q0_V1_8821C)
#define BITS_QUEUEAC_Q0_V1_8821C \
(BIT_MASK_QUEUEAC_Q0_V1_8821C << BIT_SHIFT_QUEUEAC_Q0_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q0_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q0_V1_8821C))
#define BIT_GET_QUEUEAC_Q0_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q0_V1_8821C) & BIT_MASK_QUEUEAC_Q0_V1_8821C)
#define BIT_SET_QUEUEAC_Q0_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q0_V1_8821C(x) | BIT_QUEUEAC_Q0_V1_8821C(v))
#define BIT_TIDEMPTY_Q0_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q0_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q0_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q0_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q0_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q0_V2_8821C)
#define BITS_TAIL_PKT_Q0_V2_8821C \
(BIT_MASK_TAIL_PKT_Q0_V2_8821C << BIT_SHIFT_TAIL_PKT_Q0_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q0_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q0_V2_8821C))
#define BIT_GET_TAIL_PKT_Q0_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q0_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q0_V2_8821C)
#define BIT_SET_TAIL_PKT_Q0_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q0_V2_8821C(x) | BIT_TAIL_PKT_Q0_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q0_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q0_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q0_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q0_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q0_V1_8821C)
#define BITS_HEAD_PKT_Q0_V1_8821C \
(BIT_MASK_HEAD_PKT_Q0_V1_8821C << BIT_SHIFT_HEAD_PKT_Q0_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q0_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q0_V1_8821C))
#define BIT_GET_HEAD_PKT_Q0_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q0_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q0_V1_8821C)
#define BIT_SET_HEAD_PKT_Q0_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q0_V1_8821C(x) | BIT_HEAD_PKT_Q0_V1_8821C(v))
/* 2 REG_Q1_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q1_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q1_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q1_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q1_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q1_V1_8821C)
#define BITS_QUEUEMACID_Q1_V1_8821C \
(BIT_MASK_QUEUEMACID_Q1_V1_8821C << BIT_SHIFT_QUEUEMACID_Q1_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q1_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q1_V1_8821C))
#define BIT_GET_QUEUEMACID_Q1_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q1_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q1_V1_8821C)
#define BIT_SET_QUEUEMACID_Q1_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q1_V1_8821C(x) | BIT_QUEUEMACID_Q1_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q1_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q1_V1_8821C 0x3
#define BIT_QUEUEAC_Q1_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q1_V1_8821C) << BIT_SHIFT_QUEUEAC_Q1_V1_8821C)
#define BITS_QUEUEAC_Q1_V1_8821C \
(BIT_MASK_QUEUEAC_Q1_V1_8821C << BIT_SHIFT_QUEUEAC_Q1_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q1_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q1_V1_8821C))
#define BIT_GET_QUEUEAC_Q1_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q1_V1_8821C) & BIT_MASK_QUEUEAC_Q1_V1_8821C)
#define BIT_SET_QUEUEAC_Q1_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q1_V1_8821C(x) | BIT_QUEUEAC_Q1_V1_8821C(v))
#define BIT_TIDEMPTY_Q1_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q1_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q1_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q1_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q1_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q1_V2_8821C)
#define BITS_TAIL_PKT_Q1_V2_8821C \
(BIT_MASK_TAIL_PKT_Q1_V2_8821C << BIT_SHIFT_TAIL_PKT_Q1_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q1_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q1_V2_8821C))
#define BIT_GET_TAIL_PKT_Q1_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q1_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q1_V2_8821C)
#define BIT_SET_TAIL_PKT_Q1_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q1_V2_8821C(x) | BIT_TAIL_PKT_Q1_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q1_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q1_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q1_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q1_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q1_V1_8821C)
#define BITS_HEAD_PKT_Q1_V1_8821C \
(BIT_MASK_HEAD_PKT_Q1_V1_8821C << BIT_SHIFT_HEAD_PKT_Q1_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q1_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q1_V1_8821C))
#define BIT_GET_HEAD_PKT_Q1_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q1_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q1_V1_8821C)
#define BIT_SET_HEAD_PKT_Q1_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q1_V1_8821C(x) | BIT_HEAD_PKT_Q1_V1_8821C(v))
/* 2 REG_Q2_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q2_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q2_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q2_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q2_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q2_V1_8821C)
#define BITS_QUEUEMACID_Q2_V1_8821C \
(BIT_MASK_QUEUEMACID_Q2_V1_8821C << BIT_SHIFT_QUEUEMACID_Q2_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q2_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q2_V1_8821C))
#define BIT_GET_QUEUEMACID_Q2_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q2_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q2_V1_8821C)
#define BIT_SET_QUEUEMACID_Q2_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q2_V1_8821C(x) | BIT_QUEUEMACID_Q2_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q2_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q2_V1_8821C 0x3
#define BIT_QUEUEAC_Q2_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q2_V1_8821C) << BIT_SHIFT_QUEUEAC_Q2_V1_8821C)
#define BITS_QUEUEAC_Q2_V1_8821C \
(BIT_MASK_QUEUEAC_Q2_V1_8821C << BIT_SHIFT_QUEUEAC_Q2_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q2_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q2_V1_8821C))
#define BIT_GET_QUEUEAC_Q2_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q2_V1_8821C) & BIT_MASK_QUEUEAC_Q2_V1_8821C)
#define BIT_SET_QUEUEAC_Q2_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q2_V1_8821C(x) | BIT_QUEUEAC_Q2_V1_8821C(v))
#define BIT_TIDEMPTY_Q2_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q2_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q2_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q2_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q2_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q2_V2_8821C)
#define BITS_TAIL_PKT_Q2_V2_8821C \
(BIT_MASK_TAIL_PKT_Q2_V2_8821C << BIT_SHIFT_TAIL_PKT_Q2_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q2_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q2_V2_8821C))
#define BIT_GET_TAIL_PKT_Q2_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q2_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q2_V2_8821C)
#define BIT_SET_TAIL_PKT_Q2_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q2_V2_8821C(x) | BIT_TAIL_PKT_Q2_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q2_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q2_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q2_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q2_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q2_V1_8821C)
#define BITS_HEAD_PKT_Q2_V1_8821C \
(BIT_MASK_HEAD_PKT_Q2_V1_8821C << BIT_SHIFT_HEAD_PKT_Q2_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q2_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q2_V1_8821C))
#define BIT_GET_HEAD_PKT_Q2_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q2_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q2_V1_8821C)
#define BIT_SET_HEAD_PKT_Q2_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q2_V1_8821C(x) | BIT_HEAD_PKT_Q2_V1_8821C(v))
/* 2 REG_Q3_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q3_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q3_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q3_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q3_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q3_V1_8821C)
#define BITS_QUEUEMACID_Q3_V1_8821C \
(BIT_MASK_QUEUEMACID_Q3_V1_8821C << BIT_SHIFT_QUEUEMACID_Q3_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q3_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q3_V1_8821C))
#define BIT_GET_QUEUEMACID_Q3_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q3_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q3_V1_8821C)
#define BIT_SET_QUEUEMACID_Q3_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q3_V1_8821C(x) | BIT_QUEUEMACID_Q3_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q3_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q3_V1_8821C 0x3
#define BIT_QUEUEAC_Q3_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q3_V1_8821C) << BIT_SHIFT_QUEUEAC_Q3_V1_8821C)
#define BITS_QUEUEAC_Q3_V1_8821C \
(BIT_MASK_QUEUEAC_Q3_V1_8821C << BIT_SHIFT_QUEUEAC_Q3_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q3_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q3_V1_8821C))
#define BIT_GET_QUEUEAC_Q3_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q3_V1_8821C) & BIT_MASK_QUEUEAC_Q3_V1_8821C)
#define BIT_SET_QUEUEAC_Q3_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q3_V1_8821C(x) | BIT_QUEUEAC_Q3_V1_8821C(v))
#define BIT_TIDEMPTY_Q3_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q3_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q3_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q3_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q3_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q3_V2_8821C)
#define BITS_TAIL_PKT_Q3_V2_8821C \
(BIT_MASK_TAIL_PKT_Q3_V2_8821C << BIT_SHIFT_TAIL_PKT_Q3_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q3_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q3_V2_8821C))
#define BIT_GET_TAIL_PKT_Q3_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q3_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q3_V2_8821C)
#define BIT_SET_TAIL_PKT_Q3_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q3_V2_8821C(x) | BIT_TAIL_PKT_Q3_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q3_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q3_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q3_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q3_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q3_V1_8821C)
#define BITS_HEAD_PKT_Q3_V1_8821C \
(BIT_MASK_HEAD_PKT_Q3_V1_8821C << BIT_SHIFT_HEAD_PKT_Q3_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q3_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q3_V1_8821C))
#define BIT_GET_HEAD_PKT_Q3_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q3_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q3_V1_8821C)
#define BIT_SET_HEAD_PKT_Q3_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q3_V1_8821C(x) | BIT_HEAD_PKT_Q3_V1_8821C(v))
/* 2 REG_MGQ_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_MGQ_V1_8821C 25
#define BIT_MASK_QUEUEMACID_MGQ_V1_8821C 0x7f
#define BIT_QUEUEMACID_MGQ_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_MGQ_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_MGQ_V1_8821C)
#define BITS_QUEUEMACID_MGQ_V1_8821C \
(BIT_MASK_QUEUEMACID_MGQ_V1_8821C << BIT_SHIFT_QUEUEMACID_MGQ_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_MGQ_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_MGQ_V1_8821C))
#define BIT_GET_QUEUEMACID_MGQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_MGQ_V1_8821C) & \
BIT_MASK_QUEUEMACID_MGQ_V1_8821C)
#define BIT_SET_QUEUEMACID_MGQ_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_MGQ_V1_8821C(x) | BIT_QUEUEMACID_MGQ_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_MGQ_V1_8821C 23
#define BIT_MASK_QUEUEAC_MGQ_V1_8821C 0x3
#define BIT_QUEUEAC_MGQ_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_MGQ_V1_8821C) \
<< BIT_SHIFT_QUEUEAC_MGQ_V1_8821C)
#define BITS_QUEUEAC_MGQ_V1_8821C \
(BIT_MASK_QUEUEAC_MGQ_V1_8821C << BIT_SHIFT_QUEUEAC_MGQ_V1_8821C)
#define BIT_CLEAR_QUEUEAC_MGQ_V1_8821C(x) ((x) & (~BITS_QUEUEAC_MGQ_V1_8821C))
#define BIT_GET_QUEUEAC_MGQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_MGQ_V1_8821C) & \
BIT_MASK_QUEUEAC_MGQ_V1_8821C)
#define BIT_SET_QUEUEAC_MGQ_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_MGQ_V1_8821C(x) | BIT_QUEUEAC_MGQ_V1_8821C(v))
#define BIT_TIDEMPTY_MGQ_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_MGQ_V2_8821C 11
#define BIT_MASK_TAIL_PKT_MGQ_V2_8821C 0x7ff
#define BIT_TAIL_PKT_MGQ_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_MGQ_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_MGQ_V2_8821C)
#define BITS_TAIL_PKT_MGQ_V2_8821C \
(BIT_MASK_TAIL_PKT_MGQ_V2_8821C << BIT_SHIFT_TAIL_PKT_MGQ_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_MGQ_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_MGQ_V2_8821C))
#define BIT_GET_TAIL_PKT_MGQ_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_MGQ_V2_8821C) & \
BIT_MASK_TAIL_PKT_MGQ_V2_8821C)
#define BIT_SET_TAIL_PKT_MGQ_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_MGQ_V2_8821C(x) | BIT_TAIL_PKT_MGQ_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_MGQ_V1_8821C 0
#define BIT_MASK_HEAD_PKT_MGQ_V1_8821C 0x7ff
#define BIT_HEAD_PKT_MGQ_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_MGQ_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_MGQ_V1_8821C)
#define BITS_HEAD_PKT_MGQ_V1_8821C \
(BIT_MASK_HEAD_PKT_MGQ_V1_8821C << BIT_SHIFT_HEAD_PKT_MGQ_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_MGQ_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_MGQ_V1_8821C))
#define BIT_GET_HEAD_PKT_MGQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_MGQ_V1_8821C) & \
BIT_MASK_HEAD_PKT_MGQ_V1_8821C)
#define BIT_SET_HEAD_PKT_MGQ_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_MGQ_V1_8821C(x) | BIT_HEAD_PKT_MGQ_V1_8821C(v))
/* 2 REG_HIQ_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_HIQ_V1_8821C 25
#define BIT_MASK_QUEUEMACID_HIQ_V1_8821C 0x7f
#define BIT_QUEUEMACID_HIQ_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_HIQ_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_HIQ_V1_8821C)
#define BITS_QUEUEMACID_HIQ_V1_8821C \
(BIT_MASK_QUEUEMACID_HIQ_V1_8821C << BIT_SHIFT_QUEUEMACID_HIQ_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_HIQ_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_HIQ_V1_8821C))
#define BIT_GET_QUEUEMACID_HIQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_HIQ_V1_8821C) & \
BIT_MASK_QUEUEMACID_HIQ_V1_8821C)
#define BIT_SET_QUEUEMACID_HIQ_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_HIQ_V1_8821C(x) | BIT_QUEUEMACID_HIQ_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_HIQ_V1_8821C 23
#define BIT_MASK_QUEUEAC_HIQ_V1_8821C 0x3
#define BIT_QUEUEAC_HIQ_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_HIQ_V1_8821C) \
<< BIT_SHIFT_QUEUEAC_HIQ_V1_8821C)
#define BITS_QUEUEAC_HIQ_V1_8821C \
(BIT_MASK_QUEUEAC_HIQ_V1_8821C << BIT_SHIFT_QUEUEAC_HIQ_V1_8821C)
#define BIT_CLEAR_QUEUEAC_HIQ_V1_8821C(x) ((x) & (~BITS_QUEUEAC_HIQ_V1_8821C))
#define BIT_GET_QUEUEAC_HIQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_HIQ_V1_8821C) & \
BIT_MASK_QUEUEAC_HIQ_V1_8821C)
#define BIT_SET_QUEUEAC_HIQ_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_HIQ_V1_8821C(x) | BIT_QUEUEAC_HIQ_V1_8821C(v))
#define BIT_TIDEMPTY_HIQ_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_HIQ_V2_8821C 11
#define BIT_MASK_TAIL_PKT_HIQ_V2_8821C 0x7ff
#define BIT_TAIL_PKT_HIQ_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_HIQ_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_HIQ_V2_8821C)
#define BITS_TAIL_PKT_HIQ_V2_8821C \
(BIT_MASK_TAIL_PKT_HIQ_V2_8821C << BIT_SHIFT_TAIL_PKT_HIQ_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_HIQ_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_HIQ_V2_8821C))
#define BIT_GET_TAIL_PKT_HIQ_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_HIQ_V2_8821C) & \
BIT_MASK_TAIL_PKT_HIQ_V2_8821C)
#define BIT_SET_TAIL_PKT_HIQ_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_HIQ_V2_8821C(x) | BIT_TAIL_PKT_HIQ_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_HIQ_V1_8821C 0
#define BIT_MASK_HEAD_PKT_HIQ_V1_8821C 0x7ff
#define BIT_HEAD_PKT_HIQ_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_HIQ_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_HIQ_V1_8821C)
#define BITS_HEAD_PKT_HIQ_V1_8821C \
(BIT_MASK_HEAD_PKT_HIQ_V1_8821C << BIT_SHIFT_HEAD_PKT_HIQ_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_HIQ_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_HIQ_V1_8821C))
#define BIT_GET_HEAD_PKT_HIQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_HIQ_V1_8821C) & \
BIT_MASK_HEAD_PKT_HIQ_V1_8821C)
#define BIT_SET_HEAD_PKT_HIQ_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_HIQ_V1_8821C(x) | BIT_HEAD_PKT_HIQ_V1_8821C(v))
/* 2 REG_BCNQ_INFO_8821C */
#define BIT_SHIFT_BCNQ_HEAD_PG_V1_8821C 0
#define BIT_MASK_BCNQ_HEAD_PG_V1_8821C 0xfff
#define BIT_BCNQ_HEAD_PG_V1_8821C(x) \
(((x) & BIT_MASK_BCNQ_HEAD_PG_V1_8821C) \
<< BIT_SHIFT_BCNQ_HEAD_PG_V1_8821C)
#define BITS_BCNQ_HEAD_PG_V1_8821C \
(BIT_MASK_BCNQ_HEAD_PG_V1_8821C << BIT_SHIFT_BCNQ_HEAD_PG_V1_8821C)
#define BIT_CLEAR_BCNQ_HEAD_PG_V1_8821C(x) ((x) & (~BITS_BCNQ_HEAD_PG_V1_8821C))
#define BIT_GET_BCNQ_HEAD_PG_V1_8821C(x) \
(((x) >> BIT_SHIFT_BCNQ_HEAD_PG_V1_8821C) & \
BIT_MASK_BCNQ_HEAD_PG_V1_8821C)
#define BIT_SET_BCNQ_HEAD_PG_V1_8821C(x, v) \
(BIT_CLEAR_BCNQ_HEAD_PG_V1_8821C(x) | BIT_BCNQ_HEAD_PG_V1_8821C(v))
/* 2 REG_TXPKT_EMPTY_8821C */
#define BIT_BCNQ_EMPTY_8821C BIT(11)
#define BIT_HQQ_EMPTY_8821C BIT(10)
#define BIT_MQQ_EMPTY_8821C BIT(9)
#define BIT_MGQ_CPU_EMPTY_8821C BIT(8)
#define BIT_AC7Q_EMPTY_8821C BIT(7)
#define BIT_AC6Q_EMPTY_8821C BIT(6)
#define BIT_AC5Q_EMPTY_8821C BIT(5)
#define BIT_AC4Q_EMPTY_8821C BIT(4)
#define BIT_AC3Q_EMPTY_8821C BIT(3)
#define BIT_AC2Q_EMPTY_8821C BIT(2)
#define BIT_AC1Q_EMPTY_8821C BIT(1)
#define BIT_AC0Q_EMPTY_8821C BIT(0)
/* 2 REG_CPU_MGQ_INFO_8821C */
#define BIT_BCN1_POLL_8821C BIT(30)
#define BIT_CPUMGT_POLL_8821C BIT(29)
#define BIT_BCN_POLL_8821C BIT(28)
#define BIT_CPUMGQ_FW_NUM_V1_8821C BIT(12)
#define BIT_SHIFT_FW_FREE_TAIL_V1_8821C 0
#define BIT_MASK_FW_FREE_TAIL_V1_8821C 0xfff
#define BIT_FW_FREE_TAIL_V1_8821C(x) \
(((x) & BIT_MASK_FW_FREE_TAIL_V1_8821C) \
<< BIT_SHIFT_FW_FREE_TAIL_V1_8821C)
#define BITS_FW_FREE_TAIL_V1_8821C \
(BIT_MASK_FW_FREE_TAIL_V1_8821C << BIT_SHIFT_FW_FREE_TAIL_V1_8821C)
#define BIT_CLEAR_FW_FREE_TAIL_V1_8821C(x) ((x) & (~BITS_FW_FREE_TAIL_V1_8821C))
#define BIT_GET_FW_FREE_TAIL_V1_8821C(x) \
(((x) >> BIT_SHIFT_FW_FREE_TAIL_V1_8821C) & \
BIT_MASK_FW_FREE_TAIL_V1_8821C)
#define BIT_SET_FW_FREE_TAIL_V1_8821C(x, v) \
(BIT_CLEAR_FW_FREE_TAIL_V1_8821C(x) | BIT_FW_FREE_TAIL_V1_8821C(v))
/* 2 REG_FWHW_TXQ_CTRL_8821C */
#define BIT_RTS_LIMIT_IN_OFDM_8821C BIT(23)
#define BIT_EN_BCNQ_DL_8821C BIT(22)
#define BIT_EN_RD_RESP_NAV_BK_8821C BIT(21)
#define BIT_EN_WR_FREE_TAIL_8821C BIT(20)
#define BIT_SHIFT_EN_QUEUE_RPT_8821C 8
#define BIT_MASK_EN_QUEUE_RPT_8821C 0xff
#define BIT_EN_QUEUE_RPT_8821C(x) \
(((x) & BIT_MASK_EN_QUEUE_RPT_8821C) << BIT_SHIFT_EN_QUEUE_RPT_8821C)
#define BITS_EN_QUEUE_RPT_8821C \
(BIT_MASK_EN_QUEUE_RPT_8821C << BIT_SHIFT_EN_QUEUE_RPT_8821C)
#define BIT_CLEAR_EN_QUEUE_RPT_8821C(x) ((x) & (~BITS_EN_QUEUE_RPT_8821C))
#define BIT_GET_EN_QUEUE_RPT_8821C(x) \
(((x) >> BIT_SHIFT_EN_QUEUE_RPT_8821C) & BIT_MASK_EN_QUEUE_RPT_8821C)
#define BIT_SET_EN_QUEUE_RPT_8821C(x, v) \
(BIT_CLEAR_EN_QUEUE_RPT_8821C(x) | BIT_EN_QUEUE_RPT_8821C(v))
#define BIT_EN_RTY_BK_8821C BIT(7)
#define BIT_EN_USE_INI_RAT_8821C BIT(6)
#define BIT_EN_RTS_NAV_BK_8821C BIT(5)
#define BIT_DIS_SSN_CHECK_8821C BIT(4)
#define BIT_MACID_MATCH_RTS_8821C BIT(3)
#define BIT_EN_BCN_TRXRPT_V1_8821C BIT(2)
#define BIT_R_EN_FTMRPT_V1_8821C BIT(1)
#define BIT_R_BMC_NAV_PROTECT_8821C BIT(0)
/* 2 REG_DATAFB_SEL_8821C */
#define BIT_BROADCAST_RTY_EN_8821C BIT(3)
#define BIT_EN_RTY_BK_COD_8821C BIT(2)
#define BIT_SHIFT__R_DATA_FALLBACK_SEL_8821C 0
#define BIT_MASK__R_DATA_FALLBACK_SEL_8821C 0x3
#define BIT__R_DATA_FALLBACK_SEL_8821C(x) \
(((x) & BIT_MASK__R_DATA_FALLBACK_SEL_8821C) \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8821C)
#define BITS__R_DATA_FALLBACK_SEL_8821C \
(BIT_MASK__R_DATA_FALLBACK_SEL_8821C \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8821C)
#define BIT_CLEAR__R_DATA_FALLBACK_SEL_8821C(x) \
((x) & (~BITS__R_DATA_FALLBACK_SEL_8821C))
#define BIT_GET__R_DATA_FALLBACK_SEL_8821C(x) \
(((x) >> BIT_SHIFT__R_DATA_FALLBACK_SEL_8821C) & \
BIT_MASK__R_DATA_FALLBACK_SEL_8821C)
#define BIT_SET__R_DATA_FALLBACK_SEL_8821C(x, v) \
(BIT_CLEAR__R_DATA_FALLBACK_SEL_8821C(x) | \
BIT__R_DATA_FALLBACK_SEL_8821C(v))
/* 2 REG_BCNQ_BDNY_V1_8821C */
#define BIT_SHIFT_BCNQ_PGBNDY_V1_8821C 0
#define BIT_MASK_BCNQ_PGBNDY_V1_8821C 0xfff
#define BIT_BCNQ_PGBNDY_V1_8821C(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_V1_8821C) \
<< BIT_SHIFT_BCNQ_PGBNDY_V1_8821C)
#define BITS_BCNQ_PGBNDY_V1_8821C \
(BIT_MASK_BCNQ_PGBNDY_V1_8821C << BIT_SHIFT_BCNQ_PGBNDY_V1_8821C)
#define BIT_CLEAR_BCNQ_PGBNDY_V1_8821C(x) ((x) & (~BITS_BCNQ_PGBNDY_V1_8821C))
#define BIT_GET_BCNQ_PGBNDY_V1_8821C(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_V1_8821C) & \
BIT_MASK_BCNQ_PGBNDY_V1_8821C)
#define BIT_SET_BCNQ_PGBNDY_V1_8821C(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_V1_8821C(x) | BIT_BCNQ_PGBNDY_V1_8821C(v))
/* 2 REG_LIFETIME_EN_8821C */
#define BIT_BT_INT_CPU_8821C BIT(7)
#define BIT_BT_INT_PTA_8821C BIT(6)
#define BIT_EN_CTRL_RTYBIT_8821C BIT(4)
#define BIT_LIFETIME_BK_EN_8821C BIT(3)
#define BIT_LIFETIME_BE_EN_8821C BIT(2)
#define BIT_LIFETIME_VI_EN_8821C BIT(1)
#define BIT_LIFETIME_VO_EN_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SPEC_SIFS_8821C */
#define BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8821C 8
#define BIT_MASK_SPEC_SIFS_OFDM_PTCL_8821C 0xff
#define BIT_SPEC_SIFS_OFDM_PTCL_8821C(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_PTCL_8821C) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8821C)
#define BITS_SPEC_SIFS_OFDM_PTCL_8821C \
(BIT_MASK_SPEC_SIFS_OFDM_PTCL_8821C \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8821C)
#define BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8821C(x) \
((x) & (~BITS_SPEC_SIFS_OFDM_PTCL_8821C))
#define BIT_GET_SPEC_SIFS_OFDM_PTCL_8821C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8821C) & \
BIT_MASK_SPEC_SIFS_OFDM_PTCL_8821C)
#define BIT_SET_SPEC_SIFS_OFDM_PTCL_8821C(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8821C(x) | \
BIT_SPEC_SIFS_OFDM_PTCL_8821C(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8821C 0
#define BIT_MASK_SPEC_SIFS_CCK_PTCL_8821C 0xff
#define BIT_SPEC_SIFS_CCK_PTCL_8821C(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_PTCL_8821C) \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8821C)
#define BITS_SPEC_SIFS_CCK_PTCL_8821C \
(BIT_MASK_SPEC_SIFS_CCK_PTCL_8821C \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8821C)
#define BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8821C(x) \
((x) & (~BITS_SPEC_SIFS_CCK_PTCL_8821C))
#define BIT_GET_SPEC_SIFS_CCK_PTCL_8821C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8821C) & \
BIT_MASK_SPEC_SIFS_CCK_PTCL_8821C)
#define BIT_SET_SPEC_SIFS_CCK_PTCL_8821C(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8821C(x) | \
BIT_SPEC_SIFS_CCK_PTCL_8821C(v))
/* 2 REG_RETRY_LIMIT_8821C */
#define BIT_SHIFT_SRL_8821C 8
#define BIT_MASK_SRL_8821C 0x3f
#define BIT_SRL_8821C(x) (((x) & BIT_MASK_SRL_8821C) << BIT_SHIFT_SRL_8821C)
#define BITS_SRL_8821C (BIT_MASK_SRL_8821C << BIT_SHIFT_SRL_8821C)
#define BIT_CLEAR_SRL_8821C(x) ((x) & (~BITS_SRL_8821C))
#define BIT_GET_SRL_8821C(x) (((x) >> BIT_SHIFT_SRL_8821C) & BIT_MASK_SRL_8821C)
#define BIT_SET_SRL_8821C(x, v) (BIT_CLEAR_SRL_8821C(x) | BIT_SRL_8821C(v))
#define BIT_SHIFT_LRL_8821C 0
#define BIT_MASK_LRL_8821C 0x3f
#define BIT_LRL_8821C(x) (((x) & BIT_MASK_LRL_8821C) << BIT_SHIFT_LRL_8821C)
#define BITS_LRL_8821C (BIT_MASK_LRL_8821C << BIT_SHIFT_LRL_8821C)
#define BIT_CLEAR_LRL_8821C(x) ((x) & (~BITS_LRL_8821C))
#define BIT_GET_LRL_8821C(x) (((x) >> BIT_SHIFT_LRL_8821C) & BIT_MASK_LRL_8821C)
#define BIT_SET_LRL_8821C(x, v) (BIT_CLEAR_LRL_8821C(x) | BIT_LRL_8821C(v))
/* 2 REG_TXBF_CTRL_8821C */
#define BIT_R_ENABLE_NDPA_8821C BIT(31)
#define BIT_USE_NDPA_PARAMETER_8821C BIT(30)
#define BIT_R_PROP_TXBF_8821C BIT(29)
#define BIT_R_EN_NDPA_INT_8821C BIT(28)
#define BIT_R_TXBF1_80M_8821C BIT(27)
#define BIT_R_TXBF1_40M_8821C BIT(26)
#define BIT_R_TXBF1_20M_8821C BIT(25)
#define BIT_SHIFT_R_TXBF1_AID_8821C 16
#define BIT_MASK_R_TXBF1_AID_8821C 0x1ff
#define BIT_R_TXBF1_AID_8821C(x) \
(((x) & BIT_MASK_R_TXBF1_AID_8821C) << BIT_SHIFT_R_TXBF1_AID_8821C)
#define BITS_R_TXBF1_AID_8821C \
(BIT_MASK_R_TXBF1_AID_8821C << BIT_SHIFT_R_TXBF1_AID_8821C)
#define BIT_CLEAR_R_TXBF1_AID_8821C(x) ((x) & (~BITS_R_TXBF1_AID_8821C))
#define BIT_GET_R_TXBF1_AID_8821C(x) \
(((x) >> BIT_SHIFT_R_TXBF1_AID_8821C) & BIT_MASK_R_TXBF1_AID_8821C)
#define BIT_SET_R_TXBF1_AID_8821C(x, v) \
(BIT_CLEAR_R_TXBF1_AID_8821C(x) | BIT_R_TXBF1_AID_8821C(v))
#define BIT_DIS_NDP_BFEN_8821C BIT(15)
#define BIT_R_TXBCN_NOBLOCK_NDP_8821C BIT(14)
#define BIT_R_TXBF0_80M_8821C BIT(11)
#define BIT_R_TXBF0_40M_8821C BIT(10)
#define BIT_R_TXBF0_20M_8821C BIT(9)
#define BIT_SHIFT_R_TXBF0_AID_8821C 0
#define BIT_MASK_R_TXBF0_AID_8821C 0x1ff
#define BIT_R_TXBF0_AID_8821C(x) \
(((x) & BIT_MASK_R_TXBF0_AID_8821C) << BIT_SHIFT_R_TXBF0_AID_8821C)
#define BITS_R_TXBF0_AID_8821C \
(BIT_MASK_R_TXBF0_AID_8821C << BIT_SHIFT_R_TXBF0_AID_8821C)
#define BIT_CLEAR_R_TXBF0_AID_8821C(x) ((x) & (~BITS_R_TXBF0_AID_8821C))
#define BIT_GET_R_TXBF0_AID_8821C(x) \
(((x) >> BIT_SHIFT_R_TXBF0_AID_8821C) & BIT_MASK_R_TXBF0_AID_8821C)
#define BIT_SET_R_TXBF0_AID_8821C(x, v) \
(BIT_CLEAR_R_TXBF0_AID_8821C(x) | BIT_R_TXBF0_AID_8821C(v))
/* 2 REG_DARFRC_8821C */
#define BIT_SHIFT_DARF_RC4_8821C 24
#define BIT_MASK_DARF_RC4_8821C 0x1f
#define BIT_DARF_RC4_8821C(x) \
(((x) & BIT_MASK_DARF_RC4_8821C) << BIT_SHIFT_DARF_RC4_8821C)
#define BITS_DARF_RC4_8821C \
(BIT_MASK_DARF_RC4_8821C << BIT_SHIFT_DARF_RC4_8821C)
#define BIT_CLEAR_DARF_RC4_8821C(x) ((x) & (~BITS_DARF_RC4_8821C))
#define BIT_GET_DARF_RC4_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC4_8821C) & BIT_MASK_DARF_RC4_8821C)
#define BIT_SET_DARF_RC4_8821C(x, v) \
(BIT_CLEAR_DARF_RC4_8821C(x) | BIT_DARF_RC4_8821C(v))
#define BIT_SHIFT_DARF_RC3_8821C 16
#define BIT_MASK_DARF_RC3_8821C 0x1f
#define BIT_DARF_RC3_8821C(x) \
(((x) & BIT_MASK_DARF_RC3_8821C) << BIT_SHIFT_DARF_RC3_8821C)
#define BITS_DARF_RC3_8821C \
(BIT_MASK_DARF_RC3_8821C << BIT_SHIFT_DARF_RC3_8821C)
#define BIT_CLEAR_DARF_RC3_8821C(x) ((x) & (~BITS_DARF_RC3_8821C))
#define BIT_GET_DARF_RC3_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC3_8821C) & BIT_MASK_DARF_RC3_8821C)
#define BIT_SET_DARF_RC3_8821C(x, v) \
(BIT_CLEAR_DARF_RC3_8821C(x) | BIT_DARF_RC3_8821C(v))
#define BIT_SHIFT_DARF_RC2_8821C 8
#define BIT_MASK_DARF_RC2_8821C 0x1f
#define BIT_DARF_RC2_8821C(x) \
(((x) & BIT_MASK_DARF_RC2_8821C) << BIT_SHIFT_DARF_RC2_8821C)
#define BITS_DARF_RC2_8821C \
(BIT_MASK_DARF_RC2_8821C << BIT_SHIFT_DARF_RC2_8821C)
#define BIT_CLEAR_DARF_RC2_8821C(x) ((x) & (~BITS_DARF_RC2_8821C))
#define BIT_GET_DARF_RC2_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC2_8821C) & BIT_MASK_DARF_RC2_8821C)
#define BIT_SET_DARF_RC2_8821C(x, v) \
(BIT_CLEAR_DARF_RC2_8821C(x) | BIT_DARF_RC2_8821C(v))
#define BIT_SHIFT_DARF_RC1_8821C 0
#define BIT_MASK_DARF_RC1_8821C 0x1f
#define BIT_DARF_RC1_8821C(x) \
(((x) & BIT_MASK_DARF_RC1_8821C) << BIT_SHIFT_DARF_RC1_8821C)
#define BITS_DARF_RC1_8821C \
(BIT_MASK_DARF_RC1_8821C << BIT_SHIFT_DARF_RC1_8821C)
#define BIT_CLEAR_DARF_RC1_8821C(x) ((x) & (~BITS_DARF_RC1_8821C))
#define BIT_GET_DARF_RC1_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC1_8821C) & BIT_MASK_DARF_RC1_8821C)
#define BIT_SET_DARF_RC1_8821C(x, v) \
(BIT_CLEAR_DARF_RC1_8821C(x) | BIT_DARF_RC1_8821C(v))
/* 2 REG_DARFRCH_8821C */
#define BIT_SHIFT_DARF_RC8_V1_8821C 24
#define BIT_MASK_DARF_RC8_V1_8821C 0x1f
#define BIT_DARF_RC8_V1_8821C(x) \
(((x) & BIT_MASK_DARF_RC8_V1_8821C) << BIT_SHIFT_DARF_RC8_V1_8821C)
#define BITS_DARF_RC8_V1_8821C \
(BIT_MASK_DARF_RC8_V1_8821C << BIT_SHIFT_DARF_RC8_V1_8821C)
#define BIT_CLEAR_DARF_RC8_V1_8821C(x) ((x) & (~BITS_DARF_RC8_V1_8821C))
#define BIT_GET_DARF_RC8_V1_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC8_V1_8821C) & BIT_MASK_DARF_RC8_V1_8821C)
#define BIT_SET_DARF_RC8_V1_8821C(x, v) \
(BIT_CLEAR_DARF_RC8_V1_8821C(x) | BIT_DARF_RC8_V1_8821C(v))
#define BIT_SHIFT_DARF_RC7_V1_8821C 16
#define BIT_MASK_DARF_RC7_V1_8821C 0x1f
#define BIT_DARF_RC7_V1_8821C(x) \
(((x) & BIT_MASK_DARF_RC7_V1_8821C) << BIT_SHIFT_DARF_RC7_V1_8821C)
#define BITS_DARF_RC7_V1_8821C \
(BIT_MASK_DARF_RC7_V1_8821C << BIT_SHIFT_DARF_RC7_V1_8821C)
#define BIT_CLEAR_DARF_RC7_V1_8821C(x) ((x) & (~BITS_DARF_RC7_V1_8821C))
#define BIT_GET_DARF_RC7_V1_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC7_V1_8821C) & BIT_MASK_DARF_RC7_V1_8821C)
#define BIT_SET_DARF_RC7_V1_8821C(x, v) \
(BIT_CLEAR_DARF_RC7_V1_8821C(x) | BIT_DARF_RC7_V1_8821C(v))
#define BIT_SHIFT_DARF_RC6_V1_8821C 8
#define BIT_MASK_DARF_RC6_V1_8821C 0x1f
#define BIT_DARF_RC6_V1_8821C(x) \
(((x) & BIT_MASK_DARF_RC6_V1_8821C) << BIT_SHIFT_DARF_RC6_V1_8821C)
#define BITS_DARF_RC6_V1_8821C \
(BIT_MASK_DARF_RC6_V1_8821C << BIT_SHIFT_DARF_RC6_V1_8821C)
#define BIT_CLEAR_DARF_RC6_V1_8821C(x) ((x) & (~BITS_DARF_RC6_V1_8821C))
#define BIT_GET_DARF_RC6_V1_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC6_V1_8821C) & BIT_MASK_DARF_RC6_V1_8821C)
#define BIT_SET_DARF_RC6_V1_8821C(x, v) \
(BIT_CLEAR_DARF_RC6_V1_8821C(x) | BIT_DARF_RC6_V1_8821C(v))
#define BIT_SHIFT_DARF_RC5_V1_8821C 0
#define BIT_MASK_DARF_RC5_V1_8821C 0x1f
#define BIT_DARF_RC5_V1_8821C(x) \
(((x) & BIT_MASK_DARF_RC5_V1_8821C) << BIT_SHIFT_DARF_RC5_V1_8821C)
#define BITS_DARF_RC5_V1_8821C \
(BIT_MASK_DARF_RC5_V1_8821C << BIT_SHIFT_DARF_RC5_V1_8821C)
#define BIT_CLEAR_DARF_RC5_V1_8821C(x) ((x) & (~BITS_DARF_RC5_V1_8821C))
#define BIT_GET_DARF_RC5_V1_8821C(x) \
(((x) >> BIT_SHIFT_DARF_RC5_V1_8821C) & BIT_MASK_DARF_RC5_V1_8821C)
#define BIT_SET_DARF_RC5_V1_8821C(x, v) \
(BIT_CLEAR_DARF_RC5_V1_8821C(x) | BIT_DARF_RC5_V1_8821C(v))
/* 2 REG_RARFRC_8821C */
#define BIT_SHIFT_RARF_RC4_8821C 24
#define BIT_MASK_RARF_RC4_8821C 0x1f
#define BIT_RARF_RC4_8821C(x) \
(((x) & BIT_MASK_RARF_RC4_8821C) << BIT_SHIFT_RARF_RC4_8821C)
#define BITS_RARF_RC4_8821C \
(BIT_MASK_RARF_RC4_8821C << BIT_SHIFT_RARF_RC4_8821C)
#define BIT_CLEAR_RARF_RC4_8821C(x) ((x) & (~BITS_RARF_RC4_8821C))
#define BIT_GET_RARF_RC4_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC4_8821C) & BIT_MASK_RARF_RC4_8821C)
#define BIT_SET_RARF_RC4_8821C(x, v) \
(BIT_CLEAR_RARF_RC4_8821C(x) | BIT_RARF_RC4_8821C(v))
#define BIT_SHIFT_RARF_RC3_8821C 16
#define BIT_MASK_RARF_RC3_8821C 0x1f
#define BIT_RARF_RC3_8821C(x) \
(((x) & BIT_MASK_RARF_RC3_8821C) << BIT_SHIFT_RARF_RC3_8821C)
#define BITS_RARF_RC3_8821C \
(BIT_MASK_RARF_RC3_8821C << BIT_SHIFT_RARF_RC3_8821C)
#define BIT_CLEAR_RARF_RC3_8821C(x) ((x) & (~BITS_RARF_RC3_8821C))
#define BIT_GET_RARF_RC3_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC3_8821C) & BIT_MASK_RARF_RC3_8821C)
#define BIT_SET_RARF_RC3_8821C(x, v) \
(BIT_CLEAR_RARF_RC3_8821C(x) | BIT_RARF_RC3_8821C(v))
#define BIT_SHIFT_RARF_RC2_8821C 8
#define BIT_MASK_RARF_RC2_8821C 0x1f
#define BIT_RARF_RC2_8821C(x) \
(((x) & BIT_MASK_RARF_RC2_8821C) << BIT_SHIFT_RARF_RC2_8821C)
#define BITS_RARF_RC2_8821C \
(BIT_MASK_RARF_RC2_8821C << BIT_SHIFT_RARF_RC2_8821C)
#define BIT_CLEAR_RARF_RC2_8821C(x) ((x) & (~BITS_RARF_RC2_8821C))
#define BIT_GET_RARF_RC2_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC2_8821C) & BIT_MASK_RARF_RC2_8821C)
#define BIT_SET_RARF_RC2_8821C(x, v) \
(BIT_CLEAR_RARF_RC2_8821C(x) | BIT_RARF_RC2_8821C(v))
#define BIT_SHIFT_RARF_RC1_8821C 0
#define BIT_MASK_RARF_RC1_8821C 0x1f
#define BIT_RARF_RC1_8821C(x) \
(((x) & BIT_MASK_RARF_RC1_8821C) << BIT_SHIFT_RARF_RC1_8821C)
#define BITS_RARF_RC1_8821C \
(BIT_MASK_RARF_RC1_8821C << BIT_SHIFT_RARF_RC1_8821C)
#define BIT_CLEAR_RARF_RC1_8821C(x) ((x) & (~BITS_RARF_RC1_8821C))
#define BIT_GET_RARF_RC1_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC1_8821C) & BIT_MASK_RARF_RC1_8821C)
#define BIT_SET_RARF_RC1_8821C(x, v) \
(BIT_CLEAR_RARF_RC1_8821C(x) | BIT_RARF_RC1_8821C(v))
/* 2 REG_RARFRCH_8821C */
#define BIT_SHIFT_RARF_RC8_V1_8821C 24
#define BIT_MASK_RARF_RC8_V1_8821C 0x1f
#define BIT_RARF_RC8_V1_8821C(x) \
(((x) & BIT_MASK_RARF_RC8_V1_8821C) << BIT_SHIFT_RARF_RC8_V1_8821C)
#define BITS_RARF_RC8_V1_8821C \
(BIT_MASK_RARF_RC8_V1_8821C << BIT_SHIFT_RARF_RC8_V1_8821C)
#define BIT_CLEAR_RARF_RC8_V1_8821C(x) ((x) & (~BITS_RARF_RC8_V1_8821C))
#define BIT_GET_RARF_RC8_V1_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC8_V1_8821C) & BIT_MASK_RARF_RC8_V1_8821C)
#define BIT_SET_RARF_RC8_V1_8821C(x, v) \
(BIT_CLEAR_RARF_RC8_V1_8821C(x) | BIT_RARF_RC8_V1_8821C(v))
#define BIT_SHIFT_RARF_RC7_V1_8821C 16
#define BIT_MASK_RARF_RC7_V1_8821C 0x1f
#define BIT_RARF_RC7_V1_8821C(x) \
(((x) & BIT_MASK_RARF_RC7_V1_8821C) << BIT_SHIFT_RARF_RC7_V1_8821C)
#define BITS_RARF_RC7_V1_8821C \
(BIT_MASK_RARF_RC7_V1_8821C << BIT_SHIFT_RARF_RC7_V1_8821C)
#define BIT_CLEAR_RARF_RC7_V1_8821C(x) ((x) & (~BITS_RARF_RC7_V1_8821C))
#define BIT_GET_RARF_RC7_V1_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC7_V1_8821C) & BIT_MASK_RARF_RC7_V1_8821C)
#define BIT_SET_RARF_RC7_V1_8821C(x, v) \
(BIT_CLEAR_RARF_RC7_V1_8821C(x) | BIT_RARF_RC7_V1_8821C(v))
#define BIT_SHIFT_RARF_RC6_V1_8821C 8
#define BIT_MASK_RARF_RC6_V1_8821C 0x1f
#define BIT_RARF_RC6_V1_8821C(x) \
(((x) & BIT_MASK_RARF_RC6_V1_8821C) << BIT_SHIFT_RARF_RC6_V1_8821C)
#define BITS_RARF_RC6_V1_8821C \
(BIT_MASK_RARF_RC6_V1_8821C << BIT_SHIFT_RARF_RC6_V1_8821C)
#define BIT_CLEAR_RARF_RC6_V1_8821C(x) ((x) & (~BITS_RARF_RC6_V1_8821C))
#define BIT_GET_RARF_RC6_V1_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC6_V1_8821C) & BIT_MASK_RARF_RC6_V1_8821C)
#define BIT_SET_RARF_RC6_V1_8821C(x, v) \
(BIT_CLEAR_RARF_RC6_V1_8821C(x) | BIT_RARF_RC6_V1_8821C(v))
#define BIT_SHIFT_RARF_RC5_V1_8821C 0
#define BIT_MASK_RARF_RC5_V1_8821C 0x1f
#define BIT_RARF_RC5_V1_8821C(x) \
(((x) & BIT_MASK_RARF_RC5_V1_8821C) << BIT_SHIFT_RARF_RC5_V1_8821C)
#define BITS_RARF_RC5_V1_8821C \
(BIT_MASK_RARF_RC5_V1_8821C << BIT_SHIFT_RARF_RC5_V1_8821C)
#define BIT_CLEAR_RARF_RC5_V1_8821C(x) ((x) & (~BITS_RARF_RC5_V1_8821C))
#define BIT_GET_RARF_RC5_V1_8821C(x) \
(((x) >> BIT_SHIFT_RARF_RC5_V1_8821C) & BIT_MASK_RARF_RC5_V1_8821C)
#define BIT_SET_RARF_RC5_V1_8821C(x, v) \
(BIT_CLEAR_RARF_RC5_V1_8821C(x) | BIT_RARF_RC5_V1_8821C(v))
/* 2 REG_RRSR_8821C */
#define BIT_SHIFT_RRSR_RSC_8821C 21
#define BIT_MASK_RRSR_RSC_8821C 0x3
#define BIT_RRSR_RSC_8821C(x) \
(((x) & BIT_MASK_RRSR_RSC_8821C) << BIT_SHIFT_RRSR_RSC_8821C)
#define BITS_RRSR_RSC_8821C \
(BIT_MASK_RRSR_RSC_8821C << BIT_SHIFT_RRSR_RSC_8821C)
#define BIT_CLEAR_RRSR_RSC_8821C(x) ((x) & (~BITS_RRSR_RSC_8821C))
#define BIT_GET_RRSR_RSC_8821C(x) \
(((x) >> BIT_SHIFT_RRSR_RSC_8821C) & BIT_MASK_RRSR_RSC_8821C)
#define BIT_SET_RRSR_RSC_8821C(x, v) \
(BIT_CLEAR_RRSR_RSC_8821C(x) | BIT_RRSR_RSC_8821C(v))
#define BIT_SHIFT_RRSC_BITMAP_8821C 0
#define BIT_MASK_RRSC_BITMAP_8821C 0xfffff
#define BIT_RRSC_BITMAP_8821C(x) \
(((x) & BIT_MASK_RRSC_BITMAP_8821C) << BIT_SHIFT_RRSC_BITMAP_8821C)
#define BITS_RRSC_BITMAP_8821C \
(BIT_MASK_RRSC_BITMAP_8821C << BIT_SHIFT_RRSC_BITMAP_8821C)
#define BIT_CLEAR_RRSC_BITMAP_8821C(x) ((x) & (~BITS_RRSC_BITMAP_8821C))
#define BIT_GET_RRSC_BITMAP_8821C(x) \
(((x) >> BIT_SHIFT_RRSC_BITMAP_8821C) & BIT_MASK_RRSC_BITMAP_8821C)
#define BIT_SET_RRSC_BITMAP_8821C(x, v) \
(BIT_CLEAR_RRSC_BITMAP_8821C(x) | BIT_RRSC_BITMAP_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_ARFR0_8821C */
#define BIT_SHIFT_ARFRL0_8821C 0
#define BIT_MASK_ARFRL0_8821C 0xffffffffL
#define BIT_ARFRL0_8821C(x) \
(((x) & BIT_MASK_ARFRL0_8821C) << BIT_SHIFT_ARFRL0_8821C)
#define BITS_ARFRL0_8821C (BIT_MASK_ARFRL0_8821C << BIT_SHIFT_ARFRL0_8821C)
#define BIT_CLEAR_ARFRL0_8821C(x) ((x) & (~BITS_ARFRL0_8821C))
#define BIT_GET_ARFRL0_8821C(x) \
(((x) >> BIT_SHIFT_ARFRL0_8821C) & BIT_MASK_ARFRL0_8821C)
#define BIT_SET_ARFRL0_8821C(x, v) \
(BIT_CLEAR_ARFRL0_8821C(x) | BIT_ARFRL0_8821C(v))
/* 2 REG_ARFRH0_8821C */
#define BIT_SHIFT_ARFRH0_8821C 0
#define BIT_MASK_ARFRH0_8821C 0xffffffffL
#define BIT_ARFRH0_8821C(x) \
(((x) & BIT_MASK_ARFRH0_8821C) << BIT_SHIFT_ARFRH0_8821C)
#define BITS_ARFRH0_8821C (BIT_MASK_ARFRH0_8821C << BIT_SHIFT_ARFRH0_8821C)
#define BIT_CLEAR_ARFRH0_8821C(x) ((x) & (~BITS_ARFRH0_8821C))
#define BIT_GET_ARFRH0_8821C(x) \
(((x) >> BIT_SHIFT_ARFRH0_8821C) & BIT_MASK_ARFRH0_8821C)
#define BIT_SET_ARFRH0_8821C(x, v) \
(BIT_CLEAR_ARFRH0_8821C(x) | BIT_ARFRH0_8821C(v))
/* 2 REG_ARFR1_V1_8821C */
#define BIT_SHIFT_ARFRL1_8821C 0
#define BIT_MASK_ARFRL1_8821C 0xffffffffL
#define BIT_ARFRL1_8821C(x) \
(((x) & BIT_MASK_ARFRL1_8821C) << BIT_SHIFT_ARFRL1_8821C)
#define BITS_ARFRL1_8821C (BIT_MASK_ARFRL1_8821C << BIT_SHIFT_ARFRL1_8821C)
#define BIT_CLEAR_ARFRL1_8821C(x) ((x) & (~BITS_ARFRL1_8821C))
#define BIT_GET_ARFRL1_8821C(x) \
(((x) >> BIT_SHIFT_ARFRL1_8821C) & BIT_MASK_ARFRL1_8821C)
#define BIT_SET_ARFRL1_8821C(x, v) \
(BIT_CLEAR_ARFRL1_8821C(x) | BIT_ARFRL1_8821C(v))
/* 2 REG_ARFRH1_V1_8821C */
#define BIT_SHIFT_ARFRH1_8821C 0
#define BIT_MASK_ARFRH1_8821C 0xffffffffL
#define BIT_ARFRH1_8821C(x) \
(((x) & BIT_MASK_ARFRH1_8821C) << BIT_SHIFT_ARFRH1_8821C)
#define BITS_ARFRH1_8821C (BIT_MASK_ARFRH1_8821C << BIT_SHIFT_ARFRH1_8821C)
#define BIT_CLEAR_ARFRH1_8821C(x) ((x) & (~BITS_ARFRH1_8821C))
#define BIT_GET_ARFRH1_8821C(x) \
(((x) >> BIT_SHIFT_ARFRH1_8821C) & BIT_MASK_ARFRH1_8821C)
#define BIT_SET_ARFRH1_8821C(x, v) \
(BIT_CLEAR_ARFRH1_8821C(x) | BIT_ARFRH1_8821C(v))
/* 2 REG_CCK_CHECK_8821C */
#define BIT_CHECK_CCK_EN_8821C BIT(7)
#define BIT_EN_BCN_PKT_REL_8821C BIT(6)
#define BIT_BCN_PORT_SEL_8821C BIT(5)
#define BIT_MOREDATA_BYPASS_8821C BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_8821C BIT(3)
#define BIT_R_EN_SET_MOREDATA_8821C BIT(2)
#define BIT__R_DIS_CLEAR_MACID_RELEASE_8821C BIT(1)
#define BIT__R_MACID_RELEASE_EN_8821C BIT(0)
/* 2 REG_AMPDU_MAX_TIME_V1_8821C */
#define BIT_SHIFT_AMPDU_MAX_TIME_8821C 0
#define BIT_MASK_AMPDU_MAX_TIME_8821C 0xff
#define BIT_AMPDU_MAX_TIME_8821C(x) \
(((x) & BIT_MASK_AMPDU_MAX_TIME_8821C) \
<< BIT_SHIFT_AMPDU_MAX_TIME_8821C)
#define BITS_AMPDU_MAX_TIME_8821C \
(BIT_MASK_AMPDU_MAX_TIME_8821C << BIT_SHIFT_AMPDU_MAX_TIME_8821C)
#define BIT_CLEAR_AMPDU_MAX_TIME_8821C(x) ((x) & (~BITS_AMPDU_MAX_TIME_8821C))
#define BIT_GET_AMPDU_MAX_TIME_8821C(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_TIME_8821C) & \
BIT_MASK_AMPDU_MAX_TIME_8821C)
#define BIT_SET_AMPDU_MAX_TIME_8821C(x, v) \
(BIT_CLEAR_AMPDU_MAX_TIME_8821C(x) | BIT_AMPDU_MAX_TIME_8821C(v))
/* 2 REG_BCNQ1_BDNY_V1_8821C */
#define BIT_SHIFT_BCNQ1_PGBNDY_V1_8821C 0
#define BIT_MASK_BCNQ1_PGBNDY_V1_8821C 0xfff
#define BIT_BCNQ1_PGBNDY_V1_8821C(x) \
(((x) & BIT_MASK_BCNQ1_PGBNDY_V1_8821C) \
<< BIT_SHIFT_BCNQ1_PGBNDY_V1_8821C)
#define BITS_BCNQ1_PGBNDY_V1_8821C \
(BIT_MASK_BCNQ1_PGBNDY_V1_8821C << BIT_SHIFT_BCNQ1_PGBNDY_V1_8821C)
#define BIT_CLEAR_BCNQ1_PGBNDY_V1_8821C(x) ((x) & (~BITS_BCNQ1_PGBNDY_V1_8821C))
#define BIT_GET_BCNQ1_PGBNDY_V1_8821C(x) \
(((x) >> BIT_SHIFT_BCNQ1_PGBNDY_V1_8821C) & \
BIT_MASK_BCNQ1_PGBNDY_V1_8821C)
#define BIT_SET_BCNQ1_PGBNDY_V1_8821C(x, v) \
(BIT_CLEAR_BCNQ1_PGBNDY_V1_8821C(x) | BIT_BCNQ1_PGBNDY_V1_8821C(v))
/* 2 REG_AMPDU_MAX_LENGTH_8821C */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_8821C 0
#define BIT_MASK_AMPDU_MAX_LENGTH_8821C 0xffffffffL
#define BIT_AMPDU_MAX_LENGTH_8821C(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_8821C) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_8821C)
#define BITS_AMPDU_MAX_LENGTH_8821C \
(BIT_MASK_AMPDU_MAX_LENGTH_8821C << BIT_SHIFT_AMPDU_MAX_LENGTH_8821C)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_8821C(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_8821C))
#define BIT_GET_AMPDU_MAX_LENGTH_8821C(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_8821C) & \
BIT_MASK_AMPDU_MAX_LENGTH_8821C)
#define BIT_SET_AMPDU_MAX_LENGTH_8821C(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_8821C(x) | BIT_AMPDU_MAX_LENGTH_8821C(v))
/* 2 REG_ACQ_STOP_8821C */
#define BIT_AC7Q_STOP_8821C BIT(7)
#define BIT_AC6Q_STOP_8821C BIT(6)
#define BIT_AC5Q_STOP_8821C BIT(5)
#define BIT_AC4Q_STOP_8821C BIT(4)
#define BIT_AC3Q_STOP_8821C BIT(3)
#define BIT_AC2Q_STOP_8821C BIT(2)
#define BIT_AC1Q_STOP_8821C BIT(1)
#define BIT_AC0Q_STOP_8821C BIT(0)
/* 2 REG_NDPA_RATE_8821C */
#define BIT_SHIFT_R_NDPA_RATE_V1_8821C 0
#define BIT_MASK_R_NDPA_RATE_V1_8821C 0xff
#define BIT_R_NDPA_RATE_V1_8821C(x) \
(((x) & BIT_MASK_R_NDPA_RATE_V1_8821C) \
<< BIT_SHIFT_R_NDPA_RATE_V1_8821C)
#define BITS_R_NDPA_RATE_V1_8821C \
(BIT_MASK_R_NDPA_RATE_V1_8821C << BIT_SHIFT_R_NDPA_RATE_V1_8821C)
#define BIT_CLEAR_R_NDPA_RATE_V1_8821C(x) ((x) & (~BITS_R_NDPA_RATE_V1_8821C))
#define BIT_GET_R_NDPA_RATE_V1_8821C(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE_V1_8821C) & \
BIT_MASK_R_NDPA_RATE_V1_8821C)
#define BIT_SET_R_NDPA_RATE_V1_8821C(x, v) \
(BIT_CLEAR_R_NDPA_RATE_V1_8821C(x) | BIT_R_NDPA_RATE_V1_8821C(v))
/* 2 REG_TX_HANG_CTRL_8821C */
#define BIT_R_EN_GNT_BT_AWAKE_8821C BIT(3)
#define BIT_EN_EOF_V1_8821C BIT(2)
#define BIT_DIS_OQT_BLOCK_8821C BIT(1)
#define BIT_SEARCH_QUEUE_EN_8821C BIT(0)
/* 2 REG_NDPA_OPT_CTRL_8821C */
#define BIT_R_DIS_MACID_RELEASE_RTY_8821C BIT(5)
#define BIT_SHIFT_BW_SIGTA_8821C 3
#define BIT_MASK_BW_SIGTA_8821C 0x3
#define BIT_BW_SIGTA_8821C(x) \
(((x) & BIT_MASK_BW_SIGTA_8821C) << BIT_SHIFT_BW_SIGTA_8821C)
#define BITS_BW_SIGTA_8821C \
(BIT_MASK_BW_SIGTA_8821C << BIT_SHIFT_BW_SIGTA_8821C)
#define BIT_CLEAR_BW_SIGTA_8821C(x) ((x) & (~BITS_BW_SIGTA_8821C))
#define BIT_GET_BW_SIGTA_8821C(x) \
(((x) >> BIT_SHIFT_BW_SIGTA_8821C) & BIT_MASK_BW_SIGTA_8821C)
#define BIT_SET_BW_SIGTA_8821C(x, v) \
(BIT_CLEAR_BW_SIGTA_8821C(x) | BIT_BW_SIGTA_8821C(v))
#define BIT_EN_BAR_SIGTA_8821C BIT(2)
#define BIT_SHIFT_R_NDPA_BW_8821C 0
#define BIT_MASK_R_NDPA_BW_8821C 0x3
#define BIT_R_NDPA_BW_8821C(x) \
(((x) & BIT_MASK_R_NDPA_BW_8821C) << BIT_SHIFT_R_NDPA_BW_8821C)
#define BITS_R_NDPA_BW_8821C \
(BIT_MASK_R_NDPA_BW_8821C << BIT_SHIFT_R_NDPA_BW_8821C)
#define BIT_CLEAR_R_NDPA_BW_8821C(x) ((x) & (~BITS_R_NDPA_BW_8821C))
#define BIT_GET_R_NDPA_BW_8821C(x) \
(((x) >> BIT_SHIFT_R_NDPA_BW_8821C) & BIT_MASK_R_NDPA_BW_8821C)
#define BIT_SET_R_NDPA_BW_8821C(x, v) \
(BIT_CLEAR_R_NDPA_BW_8821C(x) | BIT_R_NDPA_BW_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_RD_RESP_PKT_TH_8821C */
#define BIT_SHIFT_RD_RESP_PKT_TH_V1_8821C 0
#define BIT_MASK_RD_RESP_PKT_TH_V1_8821C 0x3f
#define BIT_RD_RESP_PKT_TH_V1_8821C(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH_V1_8821C) \
<< BIT_SHIFT_RD_RESP_PKT_TH_V1_8821C)
#define BITS_RD_RESP_PKT_TH_V1_8821C \
(BIT_MASK_RD_RESP_PKT_TH_V1_8821C << BIT_SHIFT_RD_RESP_PKT_TH_V1_8821C)
#define BIT_CLEAR_RD_RESP_PKT_TH_V1_8821C(x) \
((x) & (~BITS_RD_RESP_PKT_TH_V1_8821C))
#define BIT_GET_RD_RESP_PKT_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH_V1_8821C) & \
BIT_MASK_RD_RESP_PKT_TH_V1_8821C)
#define BIT_SET_RD_RESP_PKT_TH_V1_8821C(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH_V1_8821C(x) | BIT_RD_RESP_PKT_TH_V1_8821C(v))
/* 2 REG_CMDQ_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_CMDQ_V1_8821C 25
#define BIT_MASK_QUEUEMACID_CMDQ_V1_8821C 0x7f
#define BIT_QUEUEMACID_CMDQ_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_CMDQ_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_CMDQ_V1_8821C)
#define BITS_QUEUEMACID_CMDQ_V1_8821C \
(BIT_MASK_QUEUEMACID_CMDQ_V1_8821C \
<< BIT_SHIFT_QUEUEMACID_CMDQ_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_CMDQ_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_CMDQ_V1_8821C))
#define BIT_GET_QUEUEMACID_CMDQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_CMDQ_V1_8821C) & \
BIT_MASK_QUEUEMACID_CMDQ_V1_8821C)
#define BIT_SET_QUEUEMACID_CMDQ_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_CMDQ_V1_8821C(x) | \
BIT_QUEUEMACID_CMDQ_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_CMDQ_V1_8821C 23
#define BIT_MASK_QUEUEAC_CMDQ_V1_8821C 0x3
#define BIT_QUEUEAC_CMDQ_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_CMDQ_V1_8821C) \
<< BIT_SHIFT_QUEUEAC_CMDQ_V1_8821C)
#define BITS_QUEUEAC_CMDQ_V1_8821C \
(BIT_MASK_QUEUEAC_CMDQ_V1_8821C << BIT_SHIFT_QUEUEAC_CMDQ_V1_8821C)
#define BIT_CLEAR_QUEUEAC_CMDQ_V1_8821C(x) ((x) & (~BITS_QUEUEAC_CMDQ_V1_8821C))
#define BIT_GET_QUEUEAC_CMDQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_CMDQ_V1_8821C) & \
BIT_MASK_QUEUEAC_CMDQ_V1_8821C)
#define BIT_SET_QUEUEAC_CMDQ_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_CMDQ_V1_8821C(x) | BIT_QUEUEAC_CMDQ_V1_8821C(v))
#define BIT_TIDEMPTY_CMDQ_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q4_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q4_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q4_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q4_V2_8821C)
#define BITS_TAIL_PKT_Q4_V2_8821C \
(BIT_MASK_TAIL_PKT_Q4_V2_8821C << BIT_SHIFT_TAIL_PKT_Q4_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q4_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q4_V2_8821C))
#define BIT_GET_TAIL_PKT_Q4_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q4_V2_8821C)
#define BIT_SET_TAIL_PKT_Q4_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2_8821C(x) | BIT_TAIL_PKT_Q4_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_CMDQ_V1_8821C 0
#define BIT_MASK_HEAD_PKT_CMDQ_V1_8821C 0x7ff
#define BIT_HEAD_PKT_CMDQ_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_CMDQ_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_CMDQ_V1_8821C)
#define BITS_HEAD_PKT_CMDQ_V1_8821C \
(BIT_MASK_HEAD_PKT_CMDQ_V1_8821C << BIT_SHIFT_HEAD_PKT_CMDQ_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_CMDQ_V1_8821C(x) \
((x) & (~BITS_HEAD_PKT_CMDQ_V1_8821C))
#define BIT_GET_HEAD_PKT_CMDQ_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_CMDQ_V1_8821C) & \
BIT_MASK_HEAD_PKT_CMDQ_V1_8821C)
#define BIT_SET_HEAD_PKT_CMDQ_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_CMDQ_V1_8821C(x) | BIT_HEAD_PKT_CMDQ_V1_8821C(v))
/* 2 REG_Q4_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q4_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q4_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q4_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q4_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q4_V1_8821C)
#define BITS_QUEUEMACID_Q4_V1_8821C \
(BIT_MASK_QUEUEMACID_Q4_V1_8821C << BIT_SHIFT_QUEUEMACID_Q4_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q4_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q4_V1_8821C))
#define BIT_GET_QUEUEMACID_Q4_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q4_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q4_V1_8821C)
#define BIT_SET_QUEUEMACID_Q4_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q4_V1_8821C(x) | BIT_QUEUEMACID_Q4_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q4_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q4_V1_8821C 0x3
#define BIT_QUEUEAC_Q4_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q4_V1_8821C) << BIT_SHIFT_QUEUEAC_Q4_V1_8821C)
#define BITS_QUEUEAC_Q4_V1_8821C \
(BIT_MASK_QUEUEAC_Q4_V1_8821C << BIT_SHIFT_QUEUEAC_Q4_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q4_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q4_V1_8821C))
#define BIT_GET_QUEUEAC_Q4_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q4_V1_8821C) & BIT_MASK_QUEUEAC_Q4_V1_8821C)
#define BIT_SET_QUEUEAC_Q4_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q4_V1_8821C(x) | BIT_QUEUEAC_Q4_V1_8821C(v))
#define BIT_TIDEMPTY_Q4_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q4_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q4_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q4_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q4_V2_8821C)
#define BITS_TAIL_PKT_Q4_V2_8821C \
(BIT_MASK_TAIL_PKT_Q4_V2_8821C << BIT_SHIFT_TAIL_PKT_Q4_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q4_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q4_V2_8821C))
#define BIT_GET_TAIL_PKT_Q4_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q4_V2_8821C)
#define BIT_SET_TAIL_PKT_Q4_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2_8821C(x) | BIT_TAIL_PKT_Q4_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q4_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q4_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q4_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q4_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q4_V1_8821C)
#define BITS_HEAD_PKT_Q4_V1_8821C \
(BIT_MASK_HEAD_PKT_Q4_V1_8821C << BIT_SHIFT_HEAD_PKT_Q4_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q4_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q4_V1_8821C))
#define BIT_GET_HEAD_PKT_Q4_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q4_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q4_V1_8821C)
#define BIT_SET_HEAD_PKT_Q4_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q4_V1_8821C(x) | BIT_HEAD_PKT_Q4_V1_8821C(v))
/* 2 REG_Q5_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q5_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q5_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q5_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q5_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q5_V1_8821C)
#define BITS_QUEUEMACID_Q5_V1_8821C \
(BIT_MASK_QUEUEMACID_Q5_V1_8821C << BIT_SHIFT_QUEUEMACID_Q5_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q5_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q5_V1_8821C))
#define BIT_GET_QUEUEMACID_Q5_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q5_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q5_V1_8821C)
#define BIT_SET_QUEUEMACID_Q5_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q5_V1_8821C(x) | BIT_QUEUEMACID_Q5_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q5_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q5_V1_8821C 0x3
#define BIT_QUEUEAC_Q5_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q5_V1_8821C) << BIT_SHIFT_QUEUEAC_Q5_V1_8821C)
#define BITS_QUEUEAC_Q5_V1_8821C \
(BIT_MASK_QUEUEAC_Q5_V1_8821C << BIT_SHIFT_QUEUEAC_Q5_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q5_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q5_V1_8821C))
#define BIT_GET_QUEUEAC_Q5_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q5_V1_8821C) & BIT_MASK_QUEUEAC_Q5_V1_8821C)
#define BIT_SET_QUEUEAC_Q5_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q5_V1_8821C(x) | BIT_QUEUEAC_Q5_V1_8821C(v))
#define BIT_TIDEMPTY_Q5_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q5_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q5_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q5_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q5_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q5_V2_8821C)
#define BITS_TAIL_PKT_Q5_V2_8821C \
(BIT_MASK_TAIL_PKT_Q5_V2_8821C << BIT_SHIFT_TAIL_PKT_Q5_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q5_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q5_V2_8821C))
#define BIT_GET_TAIL_PKT_Q5_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q5_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q5_V2_8821C)
#define BIT_SET_TAIL_PKT_Q5_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q5_V2_8821C(x) | BIT_TAIL_PKT_Q5_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q5_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q5_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q5_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q5_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q5_V1_8821C)
#define BITS_HEAD_PKT_Q5_V1_8821C \
(BIT_MASK_HEAD_PKT_Q5_V1_8821C << BIT_SHIFT_HEAD_PKT_Q5_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q5_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q5_V1_8821C))
#define BIT_GET_HEAD_PKT_Q5_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q5_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q5_V1_8821C)
#define BIT_SET_HEAD_PKT_Q5_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q5_V1_8821C(x) | BIT_HEAD_PKT_Q5_V1_8821C(v))
/* 2 REG_Q6_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q6_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q6_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q6_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q6_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q6_V1_8821C)
#define BITS_QUEUEMACID_Q6_V1_8821C \
(BIT_MASK_QUEUEMACID_Q6_V1_8821C << BIT_SHIFT_QUEUEMACID_Q6_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q6_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q6_V1_8821C))
#define BIT_GET_QUEUEMACID_Q6_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q6_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q6_V1_8821C)
#define BIT_SET_QUEUEMACID_Q6_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q6_V1_8821C(x) | BIT_QUEUEMACID_Q6_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q6_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q6_V1_8821C 0x3
#define BIT_QUEUEAC_Q6_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q6_V1_8821C) << BIT_SHIFT_QUEUEAC_Q6_V1_8821C)
#define BITS_QUEUEAC_Q6_V1_8821C \
(BIT_MASK_QUEUEAC_Q6_V1_8821C << BIT_SHIFT_QUEUEAC_Q6_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q6_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q6_V1_8821C))
#define BIT_GET_QUEUEAC_Q6_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q6_V1_8821C) & BIT_MASK_QUEUEAC_Q6_V1_8821C)
#define BIT_SET_QUEUEAC_Q6_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q6_V1_8821C(x) | BIT_QUEUEAC_Q6_V1_8821C(v))
#define BIT_TIDEMPTY_Q6_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q6_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q6_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q6_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q6_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q6_V2_8821C)
#define BITS_TAIL_PKT_Q6_V2_8821C \
(BIT_MASK_TAIL_PKT_Q6_V2_8821C << BIT_SHIFT_TAIL_PKT_Q6_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q6_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q6_V2_8821C))
#define BIT_GET_TAIL_PKT_Q6_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q6_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q6_V2_8821C)
#define BIT_SET_TAIL_PKT_Q6_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q6_V2_8821C(x) | BIT_TAIL_PKT_Q6_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q6_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q6_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q6_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q6_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q6_V1_8821C)
#define BITS_HEAD_PKT_Q6_V1_8821C \
(BIT_MASK_HEAD_PKT_Q6_V1_8821C << BIT_SHIFT_HEAD_PKT_Q6_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q6_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q6_V1_8821C))
#define BIT_GET_HEAD_PKT_Q6_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q6_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q6_V1_8821C)
#define BIT_SET_HEAD_PKT_Q6_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q6_V1_8821C(x) | BIT_HEAD_PKT_Q6_V1_8821C(v))
/* 2 REG_Q7_INFO_8821C */
#define BIT_SHIFT_QUEUEMACID_Q7_V1_8821C 25
#define BIT_MASK_QUEUEMACID_Q7_V1_8821C 0x7f
#define BIT_QUEUEMACID_Q7_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q7_V1_8821C) \
<< BIT_SHIFT_QUEUEMACID_Q7_V1_8821C)
#define BITS_QUEUEMACID_Q7_V1_8821C \
(BIT_MASK_QUEUEMACID_Q7_V1_8821C << BIT_SHIFT_QUEUEMACID_Q7_V1_8821C)
#define BIT_CLEAR_QUEUEMACID_Q7_V1_8821C(x) \
((x) & (~BITS_QUEUEMACID_Q7_V1_8821C))
#define BIT_GET_QUEUEMACID_Q7_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q7_V1_8821C) & \
BIT_MASK_QUEUEMACID_Q7_V1_8821C)
#define BIT_SET_QUEUEMACID_Q7_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q7_V1_8821C(x) | BIT_QUEUEMACID_Q7_V1_8821C(v))
#define BIT_SHIFT_QUEUEAC_Q7_V1_8821C 23
#define BIT_MASK_QUEUEAC_Q7_V1_8821C 0x3
#define BIT_QUEUEAC_Q7_V1_8821C(x) \
(((x) & BIT_MASK_QUEUEAC_Q7_V1_8821C) << BIT_SHIFT_QUEUEAC_Q7_V1_8821C)
#define BITS_QUEUEAC_Q7_V1_8821C \
(BIT_MASK_QUEUEAC_Q7_V1_8821C << BIT_SHIFT_QUEUEAC_Q7_V1_8821C)
#define BIT_CLEAR_QUEUEAC_Q7_V1_8821C(x) ((x) & (~BITS_QUEUEAC_Q7_V1_8821C))
#define BIT_GET_QUEUEAC_Q7_V1_8821C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q7_V1_8821C) & BIT_MASK_QUEUEAC_Q7_V1_8821C)
#define BIT_SET_QUEUEAC_Q7_V1_8821C(x, v) \
(BIT_CLEAR_QUEUEAC_Q7_V1_8821C(x) | BIT_QUEUEAC_Q7_V1_8821C(v))
#define BIT_TIDEMPTY_Q7_V1_8821C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q7_V2_8821C 11
#define BIT_MASK_TAIL_PKT_Q7_V2_8821C 0x7ff
#define BIT_TAIL_PKT_Q7_V2_8821C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q7_V2_8821C) \
<< BIT_SHIFT_TAIL_PKT_Q7_V2_8821C)
#define BITS_TAIL_PKT_Q7_V2_8821C \
(BIT_MASK_TAIL_PKT_Q7_V2_8821C << BIT_SHIFT_TAIL_PKT_Q7_V2_8821C)
#define BIT_CLEAR_TAIL_PKT_Q7_V2_8821C(x) ((x) & (~BITS_TAIL_PKT_Q7_V2_8821C))
#define BIT_GET_TAIL_PKT_Q7_V2_8821C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q7_V2_8821C) & \
BIT_MASK_TAIL_PKT_Q7_V2_8821C)
#define BIT_SET_TAIL_PKT_Q7_V2_8821C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q7_V2_8821C(x) | BIT_TAIL_PKT_Q7_V2_8821C(v))
#define BIT_SHIFT_HEAD_PKT_Q7_V1_8821C 0
#define BIT_MASK_HEAD_PKT_Q7_V1_8821C 0x7ff
#define BIT_HEAD_PKT_Q7_V1_8821C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q7_V1_8821C) \
<< BIT_SHIFT_HEAD_PKT_Q7_V1_8821C)
#define BITS_HEAD_PKT_Q7_V1_8821C \
(BIT_MASK_HEAD_PKT_Q7_V1_8821C << BIT_SHIFT_HEAD_PKT_Q7_V1_8821C)
#define BIT_CLEAR_HEAD_PKT_Q7_V1_8821C(x) ((x) & (~BITS_HEAD_PKT_Q7_V1_8821C))
#define BIT_GET_HEAD_PKT_Q7_V1_8821C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q7_V1_8821C) & \
BIT_MASK_HEAD_PKT_Q7_V1_8821C)
#define BIT_SET_HEAD_PKT_Q7_V1_8821C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q7_V1_8821C(x) | BIT_HEAD_PKT_Q7_V1_8821C(v))
/* 2 REG_WMAC_LBK_BUF_HD_V1_8821C */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8821C 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8821C 0xfff
#define BIT_WMAC_LBK_BUF_HEAD_V1_8821C(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8821C) \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8821C)
#define BITS_WMAC_LBK_BUF_HEAD_V1_8821C \
(BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8821C \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8821C)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8821C(x) \
((x) & (~BITS_WMAC_LBK_BUF_HEAD_V1_8821C))
#define BIT_GET_WMAC_LBK_BUF_HEAD_V1_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8821C) & \
BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8821C)
#define BIT_SET_WMAC_LBK_BUF_HEAD_V1_8821C(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8821C(x) | \
BIT_WMAC_LBK_BUF_HEAD_V1_8821C(v))
/* 2 REG_MGQ_BDNY_V1_8821C */
#define BIT_SHIFT_MGQ_PGBNDY_V1_8821C 0
#define BIT_MASK_MGQ_PGBNDY_V1_8821C 0xfff
#define BIT_MGQ_PGBNDY_V1_8821C(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V1_8821C) << BIT_SHIFT_MGQ_PGBNDY_V1_8821C)
#define BITS_MGQ_PGBNDY_V1_8821C \
(BIT_MASK_MGQ_PGBNDY_V1_8821C << BIT_SHIFT_MGQ_PGBNDY_V1_8821C)
#define BIT_CLEAR_MGQ_PGBNDY_V1_8821C(x) ((x) & (~BITS_MGQ_PGBNDY_V1_8821C))
#define BIT_GET_MGQ_PGBNDY_V1_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V1_8821C) & BIT_MASK_MGQ_PGBNDY_V1_8821C)
#define BIT_SET_MGQ_PGBNDY_V1_8821C(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V1_8821C(x) | BIT_MGQ_PGBNDY_V1_8821C(v))
/* 2 REG_TXRPT_CTRL_8821C */
#define BIT_SHIFT_TRXRPT_TIMER_TH_8821C 24
#define BIT_MASK_TRXRPT_TIMER_TH_8821C 0xff
#define BIT_TRXRPT_TIMER_TH_8821C(x) \
(((x) & BIT_MASK_TRXRPT_TIMER_TH_8821C) \
<< BIT_SHIFT_TRXRPT_TIMER_TH_8821C)
#define BITS_TRXRPT_TIMER_TH_8821C \
(BIT_MASK_TRXRPT_TIMER_TH_8821C << BIT_SHIFT_TRXRPT_TIMER_TH_8821C)
#define BIT_CLEAR_TRXRPT_TIMER_TH_8821C(x) ((x) & (~BITS_TRXRPT_TIMER_TH_8821C))
#define BIT_GET_TRXRPT_TIMER_TH_8821C(x) \
(((x) >> BIT_SHIFT_TRXRPT_TIMER_TH_8821C) & \
BIT_MASK_TRXRPT_TIMER_TH_8821C)
#define BIT_SET_TRXRPT_TIMER_TH_8821C(x, v) \
(BIT_CLEAR_TRXRPT_TIMER_TH_8821C(x) | BIT_TRXRPT_TIMER_TH_8821C(v))
#define BIT_SHIFT_TRXRPT_LEN_TH_8821C 16
#define BIT_MASK_TRXRPT_LEN_TH_8821C 0xff
#define BIT_TRXRPT_LEN_TH_8821C(x) \
(((x) & BIT_MASK_TRXRPT_LEN_TH_8821C) << BIT_SHIFT_TRXRPT_LEN_TH_8821C)
#define BITS_TRXRPT_LEN_TH_8821C \
(BIT_MASK_TRXRPT_LEN_TH_8821C << BIT_SHIFT_TRXRPT_LEN_TH_8821C)
#define BIT_CLEAR_TRXRPT_LEN_TH_8821C(x) ((x) & (~BITS_TRXRPT_LEN_TH_8821C))
#define BIT_GET_TRXRPT_LEN_TH_8821C(x) \
(((x) >> BIT_SHIFT_TRXRPT_LEN_TH_8821C) & BIT_MASK_TRXRPT_LEN_TH_8821C)
#define BIT_SET_TRXRPT_LEN_TH_8821C(x, v) \
(BIT_CLEAR_TRXRPT_LEN_TH_8821C(x) | BIT_TRXRPT_LEN_TH_8821C(v))
#define BIT_SHIFT_TRXRPT_READ_PTR_8821C 8
#define BIT_MASK_TRXRPT_READ_PTR_8821C 0xff
#define BIT_TRXRPT_READ_PTR_8821C(x) \
(((x) & BIT_MASK_TRXRPT_READ_PTR_8821C) \
<< BIT_SHIFT_TRXRPT_READ_PTR_8821C)
#define BITS_TRXRPT_READ_PTR_8821C \
(BIT_MASK_TRXRPT_READ_PTR_8821C << BIT_SHIFT_TRXRPT_READ_PTR_8821C)
#define BIT_CLEAR_TRXRPT_READ_PTR_8821C(x) ((x) & (~BITS_TRXRPT_READ_PTR_8821C))
#define BIT_GET_TRXRPT_READ_PTR_8821C(x) \
(((x) >> BIT_SHIFT_TRXRPT_READ_PTR_8821C) & \
BIT_MASK_TRXRPT_READ_PTR_8821C)
#define BIT_SET_TRXRPT_READ_PTR_8821C(x, v) \
(BIT_CLEAR_TRXRPT_READ_PTR_8821C(x) | BIT_TRXRPT_READ_PTR_8821C(v))
#define BIT_SHIFT_TRXRPT_WRITE_PTR_8821C 0
#define BIT_MASK_TRXRPT_WRITE_PTR_8821C 0xff
#define BIT_TRXRPT_WRITE_PTR_8821C(x) \
(((x) & BIT_MASK_TRXRPT_WRITE_PTR_8821C) \
<< BIT_SHIFT_TRXRPT_WRITE_PTR_8821C)
#define BITS_TRXRPT_WRITE_PTR_8821C \
(BIT_MASK_TRXRPT_WRITE_PTR_8821C << BIT_SHIFT_TRXRPT_WRITE_PTR_8821C)
#define BIT_CLEAR_TRXRPT_WRITE_PTR_8821C(x) \
((x) & (~BITS_TRXRPT_WRITE_PTR_8821C))
#define BIT_GET_TRXRPT_WRITE_PTR_8821C(x) \
(((x) >> BIT_SHIFT_TRXRPT_WRITE_PTR_8821C) & \
BIT_MASK_TRXRPT_WRITE_PTR_8821C)
#define BIT_SET_TRXRPT_WRITE_PTR_8821C(x, v) \
(BIT_CLEAR_TRXRPT_WRITE_PTR_8821C(x) | BIT_TRXRPT_WRITE_PTR_8821C(v))
/* 2 REG_INIRTS_RATE_SEL_8821C */
#define BIT_LEAG_RTS_BW_DUP_8821C BIT(5)
/* 2 REG_BASIC_CFEND_RATE_8821C */
#define BIT_SHIFT_BASIC_CFEND_RATE_8821C 0
#define BIT_MASK_BASIC_CFEND_RATE_8821C 0x1f
#define BIT_BASIC_CFEND_RATE_8821C(x) \
(((x) & BIT_MASK_BASIC_CFEND_RATE_8821C) \
<< BIT_SHIFT_BASIC_CFEND_RATE_8821C)
#define BITS_BASIC_CFEND_RATE_8821C \
(BIT_MASK_BASIC_CFEND_RATE_8821C << BIT_SHIFT_BASIC_CFEND_RATE_8821C)
#define BIT_CLEAR_BASIC_CFEND_RATE_8821C(x) \
((x) & (~BITS_BASIC_CFEND_RATE_8821C))
#define BIT_GET_BASIC_CFEND_RATE_8821C(x) \
(((x) >> BIT_SHIFT_BASIC_CFEND_RATE_8821C) & \
BIT_MASK_BASIC_CFEND_RATE_8821C)
#define BIT_SET_BASIC_CFEND_RATE_8821C(x, v) \
(BIT_CLEAR_BASIC_CFEND_RATE_8821C(x) | BIT_BASIC_CFEND_RATE_8821C(v))
/* 2 REG_STBC_CFEND_RATE_8821C */
#define BIT_SHIFT_STBC_CFEND_RATE_8821C 0
#define BIT_MASK_STBC_CFEND_RATE_8821C 0x1f
#define BIT_STBC_CFEND_RATE_8821C(x) \
(((x) & BIT_MASK_STBC_CFEND_RATE_8821C) \
<< BIT_SHIFT_STBC_CFEND_RATE_8821C)
#define BITS_STBC_CFEND_RATE_8821C \
(BIT_MASK_STBC_CFEND_RATE_8821C << BIT_SHIFT_STBC_CFEND_RATE_8821C)
#define BIT_CLEAR_STBC_CFEND_RATE_8821C(x) ((x) & (~BITS_STBC_CFEND_RATE_8821C))
#define BIT_GET_STBC_CFEND_RATE_8821C(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_RATE_8821C) & \
BIT_MASK_STBC_CFEND_RATE_8821C)
#define BIT_SET_STBC_CFEND_RATE_8821C(x, v) \
(BIT_CLEAR_STBC_CFEND_RATE_8821C(x) | BIT_STBC_CFEND_RATE_8821C(v))
/* 2 REG_DATA_SC_8821C */
#define BIT_SHIFT_TXSC_40M_8821C 4
#define BIT_MASK_TXSC_40M_8821C 0xf
#define BIT_TXSC_40M_8821C(x) \
(((x) & BIT_MASK_TXSC_40M_8821C) << BIT_SHIFT_TXSC_40M_8821C)
#define BITS_TXSC_40M_8821C \
(BIT_MASK_TXSC_40M_8821C << BIT_SHIFT_TXSC_40M_8821C)
#define BIT_CLEAR_TXSC_40M_8821C(x) ((x) & (~BITS_TXSC_40M_8821C))
#define BIT_GET_TXSC_40M_8821C(x) \
(((x) >> BIT_SHIFT_TXSC_40M_8821C) & BIT_MASK_TXSC_40M_8821C)
#define BIT_SET_TXSC_40M_8821C(x, v) \
(BIT_CLEAR_TXSC_40M_8821C(x) | BIT_TXSC_40M_8821C(v))
#define BIT_SHIFT_TXSC_20M_8821C 0
#define BIT_MASK_TXSC_20M_8821C 0xf
#define BIT_TXSC_20M_8821C(x) \
(((x) & BIT_MASK_TXSC_20M_8821C) << BIT_SHIFT_TXSC_20M_8821C)
#define BITS_TXSC_20M_8821C \
(BIT_MASK_TXSC_20M_8821C << BIT_SHIFT_TXSC_20M_8821C)
#define BIT_CLEAR_TXSC_20M_8821C(x) ((x) & (~BITS_TXSC_20M_8821C))
#define BIT_GET_TXSC_20M_8821C(x) \
(((x) >> BIT_SHIFT_TXSC_20M_8821C) & BIT_MASK_TXSC_20M_8821C)
#define BIT_SET_TXSC_20M_8821C(x, v) \
(BIT_CLEAR_TXSC_20M_8821C(x) | BIT_TXSC_20M_8821C(v))
/* 2 REG_MACID_SLEEP3_8821C */
#define BIT_SHIFT_MACID127_96_PKTSLEEP_8821C 0
#define BIT_MASK_MACID127_96_PKTSLEEP_8821C 0xffffffffL
#define BIT_MACID127_96_PKTSLEEP_8821C(x) \
(((x) & BIT_MASK_MACID127_96_PKTSLEEP_8821C) \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8821C)
#define BITS_MACID127_96_PKTSLEEP_8821C \
(BIT_MASK_MACID127_96_PKTSLEEP_8821C \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8821C)
#define BIT_CLEAR_MACID127_96_PKTSLEEP_8821C(x) \
((x) & (~BITS_MACID127_96_PKTSLEEP_8821C))
#define BIT_GET_MACID127_96_PKTSLEEP_8821C(x) \
(((x) >> BIT_SHIFT_MACID127_96_PKTSLEEP_8821C) & \
BIT_MASK_MACID127_96_PKTSLEEP_8821C)
#define BIT_SET_MACID127_96_PKTSLEEP_8821C(x, v) \
(BIT_CLEAR_MACID127_96_PKTSLEEP_8821C(x) | \
BIT_MACID127_96_PKTSLEEP_8821C(v))
/* 2 REG_MACID_SLEEP1_8821C */
#define BIT_SHIFT_MACID63_32_PKTSLEEP_8821C 0
#define BIT_MASK_MACID63_32_PKTSLEEP_8821C 0xffffffffL
#define BIT_MACID63_32_PKTSLEEP_8821C(x) \
(((x) & BIT_MASK_MACID63_32_PKTSLEEP_8821C) \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8821C)
#define BITS_MACID63_32_PKTSLEEP_8821C \
(BIT_MASK_MACID63_32_PKTSLEEP_8821C \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8821C)
#define BIT_CLEAR_MACID63_32_PKTSLEEP_8821C(x) \
((x) & (~BITS_MACID63_32_PKTSLEEP_8821C))
#define BIT_GET_MACID63_32_PKTSLEEP_8821C(x) \
(((x) >> BIT_SHIFT_MACID63_32_PKTSLEEP_8821C) & \
BIT_MASK_MACID63_32_PKTSLEEP_8821C)
#define BIT_SET_MACID63_32_PKTSLEEP_8821C(x, v) \
(BIT_CLEAR_MACID63_32_PKTSLEEP_8821C(x) | \
BIT_MACID63_32_PKTSLEEP_8821C(v))
/* 2 REG_ARFR2_V1_8821C */
#define BIT_SHIFT_ARFRL2_8821C 0
#define BIT_MASK_ARFRL2_8821C 0xffffffffL
#define BIT_ARFRL2_8821C(x) \
(((x) & BIT_MASK_ARFRL2_8821C) << BIT_SHIFT_ARFRL2_8821C)
#define BITS_ARFRL2_8821C (BIT_MASK_ARFRL2_8821C << BIT_SHIFT_ARFRL2_8821C)
#define BIT_CLEAR_ARFRL2_8821C(x) ((x) & (~BITS_ARFRL2_8821C))
#define BIT_GET_ARFRL2_8821C(x) \
(((x) >> BIT_SHIFT_ARFRL2_8821C) & BIT_MASK_ARFRL2_8821C)
#define BIT_SET_ARFRL2_8821C(x, v) \
(BIT_CLEAR_ARFRL2_8821C(x) | BIT_ARFRL2_8821C(v))
/* 2 REG_ARFRH2_V1_8821C */
#define BIT_SHIFT_ARFRH2_8821C 0
#define BIT_MASK_ARFRH2_8821C 0xffffffffL
#define BIT_ARFRH2_8821C(x) \
(((x) & BIT_MASK_ARFRH2_8821C) << BIT_SHIFT_ARFRH2_8821C)
#define BITS_ARFRH2_8821C (BIT_MASK_ARFRH2_8821C << BIT_SHIFT_ARFRH2_8821C)
#define BIT_CLEAR_ARFRH2_8821C(x) ((x) & (~BITS_ARFRH2_8821C))
#define BIT_GET_ARFRH2_8821C(x) \
(((x) >> BIT_SHIFT_ARFRH2_8821C) & BIT_MASK_ARFRH2_8821C)
#define BIT_SET_ARFRH2_8821C(x, v) \
(BIT_CLEAR_ARFRH2_8821C(x) | BIT_ARFRH2_8821C(v))
/* 2 REG_ARFR3_V1_8821C */
#define BIT_SHIFT_ARFRL3_8821C 0
#define BIT_MASK_ARFRL3_8821C 0xffffffffL
#define BIT_ARFRL3_8821C(x) \
(((x) & BIT_MASK_ARFRL3_8821C) << BIT_SHIFT_ARFRL3_8821C)
#define BITS_ARFRL3_8821C (BIT_MASK_ARFRL3_8821C << BIT_SHIFT_ARFRL3_8821C)
#define BIT_CLEAR_ARFRL3_8821C(x) ((x) & (~BITS_ARFRL3_8821C))
#define BIT_GET_ARFRL3_8821C(x) \
(((x) >> BIT_SHIFT_ARFRL3_8821C) & BIT_MASK_ARFRL3_8821C)
#define BIT_SET_ARFRL3_8821C(x, v) \
(BIT_CLEAR_ARFRL3_8821C(x) | BIT_ARFRL3_8821C(v))
/* 2 REG_ARFRH3_V1_8821C */
#define BIT_SHIFT_ARFRH3_8821C 0
#define BIT_MASK_ARFRH3_8821C 0xffffffffL
#define BIT_ARFRH3_8821C(x) \
(((x) & BIT_MASK_ARFRH3_8821C) << BIT_SHIFT_ARFRH3_8821C)
#define BITS_ARFRH3_8821C (BIT_MASK_ARFRH3_8821C << BIT_SHIFT_ARFRH3_8821C)
#define BIT_CLEAR_ARFRH3_8821C(x) ((x) & (~BITS_ARFRH3_8821C))
#define BIT_GET_ARFRH3_8821C(x) \
(((x) >> BIT_SHIFT_ARFRH3_8821C) & BIT_MASK_ARFRH3_8821C)
#define BIT_SET_ARFRH3_8821C(x, v) \
(BIT_CLEAR_ARFRH3_8821C(x) | BIT_ARFRH3_8821C(v))
/* 2 REG_ARFR4_8821C */
#define BIT_SHIFT_ARFRL4_8821C 0
#define BIT_MASK_ARFRL4_8821C 0xffffffffL
#define BIT_ARFRL4_8821C(x) \
(((x) & BIT_MASK_ARFRL4_8821C) << BIT_SHIFT_ARFRL4_8821C)
#define BITS_ARFRL4_8821C (BIT_MASK_ARFRL4_8821C << BIT_SHIFT_ARFRL4_8821C)
#define BIT_CLEAR_ARFRL4_8821C(x) ((x) & (~BITS_ARFRL4_8821C))
#define BIT_GET_ARFRL4_8821C(x) \
(((x) >> BIT_SHIFT_ARFRL4_8821C) & BIT_MASK_ARFRL4_8821C)
#define BIT_SET_ARFRL4_8821C(x, v) \
(BIT_CLEAR_ARFRL4_8821C(x) | BIT_ARFRL4_8821C(v))
/* 2 REG_ARFRH4_8821C */
#define BIT_SHIFT_ARFRH4_8821C 0
#define BIT_MASK_ARFRH4_8821C 0xffffffffL
#define BIT_ARFRH4_8821C(x) \
(((x) & BIT_MASK_ARFRH4_8821C) << BIT_SHIFT_ARFRH4_8821C)
#define BITS_ARFRH4_8821C (BIT_MASK_ARFRH4_8821C << BIT_SHIFT_ARFRH4_8821C)
#define BIT_CLEAR_ARFRH4_8821C(x) ((x) & (~BITS_ARFRH4_8821C))
#define BIT_GET_ARFRH4_8821C(x) \
(((x) >> BIT_SHIFT_ARFRH4_8821C) & BIT_MASK_ARFRH4_8821C)
#define BIT_SET_ARFRH4_8821C(x, v) \
(BIT_CLEAR_ARFRH4_8821C(x) | BIT_ARFRH4_8821C(v))
/* 2 REG_ARFR5_8821C */
#define BIT_SHIFT_ARFRL5_8821C 0
#define BIT_MASK_ARFRL5_8821C 0xffffffffL
#define BIT_ARFRL5_8821C(x) \
(((x) & BIT_MASK_ARFRL5_8821C) << BIT_SHIFT_ARFRL5_8821C)
#define BITS_ARFRL5_8821C (BIT_MASK_ARFRL5_8821C << BIT_SHIFT_ARFRL5_8821C)
#define BIT_CLEAR_ARFRL5_8821C(x) ((x) & (~BITS_ARFRL5_8821C))
#define BIT_GET_ARFRL5_8821C(x) \
(((x) >> BIT_SHIFT_ARFRL5_8821C) & BIT_MASK_ARFRL5_8821C)
#define BIT_SET_ARFRL5_8821C(x, v) \
(BIT_CLEAR_ARFRL5_8821C(x) | BIT_ARFRL5_8821C(v))
/* 2 REG_ARFRH5_8821C */
#define BIT_SHIFT_ARFRH5_8821C 0
#define BIT_MASK_ARFRH5_8821C 0xffffffffL
#define BIT_ARFRH5_8821C(x) \
(((x) & BIT_MASK_ARFRH5_8821C) << BIT_SHIFT_ARFRH5_8821C)
#define BITS_ARFRH5_8821C (BIT_MASK_ARFRH5_8821C << BIT_SHIFT_ARFRH5_8821C)
#define BIT_CLEAR_ARFRH5_8821C(x) ((x) & (~BITS_ARFRH5_8821C))
#define BIT_GET_ARFRH5_8821C(x) \
(((x) >> BIT_SHIFT_ARFRH5_8821C) & BIT_MASK_ARFRH5_8821C)
#define BIT_SET_ARFRH5_8821C(x, v) \
(BIT_CLEAR_ARFRH5_8821C(x) | BIT_ARFRH5_8821C(v))
/* 2 REG_TXRPT_START_OFFSET_8821C */
#define BIT_SHIFT_R_MUTAB_TXRPT_OFFSET_8821C 24
#define BIT_MASK_R_MUTAB_TXRPT_OFFSET_8821C 0xff
#define BIT_R_MUTAB_TXRPT_OFFSET_8821C(x) \
(((x) & BIT_MASK_R_MUTAB_TXRPT_OFFSET_8821C) \
<< BIT_SHIFT_R_MUTAB_TXRPT_OFFSET_8821C)
#define BITS_R_MUTAB_TXRPT_OFFSET_8821C \
(BIT_MASK_R_MUTAB_TXRPT_OFFSET_8821C \
<< BIT_SHIFT_R_MUTAB_TXRPT_OFFSET_8821C)
#define BIT_CLEAR_R_MUTAB_TXRPT_OFFSET_8821C(x) \
((x) & (~BITS_R_MUTAB_TXRPT_OFFSET_8821C))
#define BIT_GET_R_MUTAB_TXRPT_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_R_MUTAB_TXRPT_OFFSET_8821C) & \
BIT_MASK_R_MUTAB_TXRPT_OFFSET_8821C)
#define BIT_SET_R_MUTAB_TXRPT_OFFSET_8821C(x, v) \
(BIT_CLEAR_R_MUTAB_TXRPT_OFFSET_8821C(x) | \
BIT_R_MUTAB_TXRPT_OFFSET_8821C(v))
#define BIT__R_RPTFIFO_1K_8821C BIT(16)
#define BIT_SHIFT_MACID_CTRL_OFFSET_8821C 8
#define BIT_MASK_MACID_CTRL_OFFSET_8821C 0xff
#define BIT_MACID_CTRL_OFFSET_8821C(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET_8821C) \
<< BIT_SHIFT_MACID_CTRL_OFFSET_8821C)
#define BITS_MACID_CTRL_OFFSET_8821C \
(BIT_MASK_MACID_CTRL_OFFSET_8821C << BIT_SHIFT_MACID_CTRL_OFFSET_8821C)
#define BIT_CLEAR_MACID_CTRL_OFFSET_8821C(x) \
((x) & (~BITS_MACID_CTRL_OFFSET_8821C))
#define BIT_GET_MACID_CTRL_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET_8821C) & \
BIT_MASK_MACID_CTRL_OFFSET_8821C)
#define BIT_SET_MACID_CTRL_OFFSET_8821C(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET_8821C(x) | BIT_MACID_CTRL_OFFSET_8821C(v))
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET_8821C 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET_8821C 0xff
#define BIT_AMPDU_TXRPT_OFFSET_8821C(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET_8821C) \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8821C)
#define BITS_AMPDU_TXRPT_OFFSET_8821C \
(BIT_MASK_AMPDU_TXRPT_OFFSET_8821C \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8821C)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET_8821C(x) \
((x) & (~BITS_AMPDU_TXRPT_OFFSET_8821C))
#define BIT_GET_AMPDU_TXRPT_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET_8821C) & \
BIT_MASK_AMPDU_TXRPT_OFFSET_8821C)
#define BIT_SET_AMPDU_TXRPT_OFFSET_8821C(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET_8821C(x) | \
BIT_AMPDU_TXRPT_OFFSET_8821C(v))
/* 2 REG_POWER_STAGE1_8821C */
#define BIT_PTA_WL_PRI_MASK_CPU_MGQ_8821C BIT(31)
#define BIT_PTA_WL_PRI_MASK_BCNQ_8821C BIT(30)
#define BIT_PTA_WL_PRI_MASK_HIQ_8821C BIT(29)
#define BIT_PTA_WL_PRI_MASK_MGQ_8821C BIT(28)
#define BIT_PTA_WL_PRI_MASK_BK_8821C BIT(27)
#define BIT_PTA_WL_PRI_MASK_BE_8821C BIT(26)
#define BIT_PTA_WL_PRI_MASK_VI_8821C BIT(25)
#define BIT_PTA_WL_PRI_MASK_VO_8821C BIT(24)
#define BIT_SHIFT_POWER_STAGE1_8821C 0
#define BIT_MASK_POWER_STAGE1_8821C 0xffffff
#define BIT_POWER_STAGE1_8821C(x) \
(((x) & BIT_MASK_POWER_STAGE1_8821C) << BIT_SHIFT_POWER_STAGE1_8821C)
#define BITS_POWER_STAGE1_8821C \
(BIT_MASK_POWER_STAGE1_8821C << BIT_SHIFT_POWER_STAGE1_8821C)
#define BIT_CLEAR_POWER_STAGE1_8821C(x) ((x) & (~BITS_POWER_STAGE1_8821C))
#define BIT_GET_POWER_STAGE1_8821C(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1_8821C) & BIT_MASK_POWER_STAGE1_8821C)
#define BIT_SET_POWER_STAGE1_8821C(x, v) \
(BIT_CLEAR_POWER_STAGE1_8821C(x) | BIT_POWER_STAGE1_8821C(v))
/* 2 REG_POWER_STAGE2_8821C */
#define BIT__R_CTRL_PKT_POW_ADJ_8821C BIT(24)
#define BIT_SHIFT_POWER_STAGE2_8821C 0
#define BIT_MASK_POWER_STAGE2_8821C 0xffffff
#define BIT_POWER_STAGE2_8821C(x) \
(((x) & BIT_MASK_POWER_STAGE2_8821C) << BIT_SHIFT_POWER_STAGE2_8821C)
#define BITS_POWER_STAGE2_8821C \
(BIT_MASK_POWER_STAGE2_8821C << BIT_SHIFT_POWER_STAGE2_8821C)
#define BIT_CLEAR_POWER_STAGE2_8821C(x) ((x) & (~BITS_POWER_STAGE2_8821C))
#define BIT_GET_POWER_STAGE2_8821C(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2_8821C) & BIT_MASK_POWER_STAGE2_8821C)
#define BIT_SET_POWER_STAGE2_8821C(x, v) \
(BIT_CLEAR_POWER_STAGE2_8821C(x) | BIT_POWER_STAGE2_8821C(v))
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL_8821C */
#define BIT_SHIFT_PAD_NUM_THRES_8821C 24
#define BIT_MASK_PAD_NUM_THRES_8821C 0x3f
#define BIT_PAD_NUM_THRES_8821C(x) \
(((x) & BIT_MASK_PAD_NUM_THRES_8821C) << BIT_SHIFT_PAD_NUM_THRES_8821C)
#define BITS_PAD_NUM_THRES_8821C \
(BIT_MASK_PAD_NUM_THRES_8821C << BIT_SHIFT_PAD_NUM_THRES_8821C)
#define BIT_CLEAR_PAD_NUM_THRES_8821C(x) ((x) & (~BITS_PAD_NUM_THRES_8821C))
#define BIT_GET_PAD_NUM_THRES_8821C(x) \
(((x) >> BIT_SHIFT_PAD_NUM_THRES_8821C) & BIT_MASK_PAD_NUM_THRES_8821C)
#define BIT_SET_PAD_NUM_THRES_8821C(x, v) \
(BIT_CLEAR_PAD_NUM_THRES_8821C(x) | BIT_PAD_NUM_THRES_8821C(v))
#define BIT_R_DMA_THIS_QUEUE_BK_8821C BIT(23)
#define BIT_R_DMA_THIS_QUEUE_BE_8821C BIT(22)
#define BIT_R_DMA_THIS_QUEUE_VI_8821C BIT(21)
#define BIT_R_DMA_THIS_QUEUE_VO_8821C BIT(20)
#define BIT_SHIFT_R_TOTAL_LEN_TH_8821C 8
#define BIT_MASK_R_TOTAL_LEN_TH_8821C 0xfff
#define BIT_R_TOTAL_LEN_TH_8821C(x) \
(((x) & BIT_MASK_R_TOTAL_LEN_TH_8821C) \
<< BIT_SHIFT_R_TOTAL_LEN_TH_8821C)
#define BITS_R_TOTAL_LEN_TH_8821C \
(BIT_MASK_R_TOTAL_LEN_TH_8821C << BIT_SHIFT_R_TOTAL_LEN_TH_8821C)
#define BIT_CLEAR_R_TOTAL_LEN_TH_8821C(x) ((x) & (~BITS_R_TOTAL_LEN_TH_8821C))
#define BIT_GET_R_TOTAL_LEN_TH_8821C(x) \
(((x) >> BIT_SHIFT_R_TOTAL_LEN_TH_8821C) & \
BIT_MASK_R_TOTAL_LEN_TH_8821C)
#define BIT_SET_R_TOTAL_LEN_TH_8821C(x, v) \
(BIT_CLEAR_R_TOTAL_LEN_TH_8821C(x) | BIT_R_TOTAL_LEN_TH_8821C(v))
#define BIT_EN_NEW_EARLY_8821C BIT(7)
#define BIT_PRE_TX_CMD_8821C BIT(6)
#define BIT_SHIFT_NUM_SCL_EN_8821C 4
#define BIT_MASK_NUM_SCL_EN_8821C 0x3
#define BIT_NUM_SCL_EN_8821C(x) \
(((x) & BIT_MASK_NUM_SCL_EN_8821C) << BIT_SHIFT_NUM_SCL_EN_8821C)
#define BITS_NUM_SCL_EN_8821C \
(BIT_MASK_NUM_SCL_EN_8821C << BIT_SHIFT_NUM_SCL_EN_8821C)
#define BIT_CLEAR_NUM_SCL_EN_8821C(x) ((x) & (~BITS_NUM_SCL_EN_8821C))
#define BIT_GET_NUM_SCL_EN_8821C(x) \
(((x) >> BIT_SHIFT_NUM_SCL_EN_8821C) & BIT_MASK_NUM_SCL_EN_8821C)
#define BIT_SET_NUM_SCL_EN_8821C(x, v) \
(BIT_CLEAR_NUM_SCL_EN_8821C(x) | BIT_NUM_SCL_EN_8821C(v))
#define BIT_BK_EN_8821C BIT(3)
#define BIT_BE_EN_8821C BIT(2)
#define BIT_VI_EN_8821C BIT(1)
#define BIT_VO_EN_8821C BIT(0)
/* 2 REG_PKT_LIFE_TIME_8821C */
#define BIT_SHIFT_PKT_LIFTIME_BEBK_8821C 16
#define BIT_MASK_PKT_LIFTIME_BEBK_8821C 0xffff
#define BIT_PKT_LIFTIME_BEBK_8821C(x) \
(((x) & BIT_MASK_PKT_LIFTIME_BEBK_8821C) \
<< BIT_SHIFT_PKT_LIFTIME_BEBK_8821C)
#define BITS_PKT_LIFTIME_BEBK_8821C \
(BIT_MASK_PKT_LIFTIME_BEBK_8821C << BIT_SHIFT_PKT_LIFTIME_BEBK_8821C)
#define BIT_CLEAR_PKT_LIFTIME_BEBK_8821C(x) \
((x) & (~BITS_PKT_LIFTIME_BEBK_8821C))
#define BIT_GET_PKT_LIFTIME_BEBK_8821C(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_BEBK_8821C) & \
BIT_MASK_PKT_LIFTIME_BEBK_8821C)
#define BIT_SET_PKT_LIFTIME_BEBK_8821C(x, v) \
(BIT_CLEAR_PKT_LIFTIME_BEBK_8821C(x) | BIT_PKT_LIFTIME_BEBK_8821C(v))
#define BIT_SHIFT_PKT_LIFTIME_VOVI_8821C 0
#define BIT_MASK_PKT_LIFTIME_VOVI_8821C 0xffff
#define BIT_PKT_LIFTIME_VOVI_8821C(x) \
(((x) & BIT_MASK_PKT_LIFTIME_VOVI_8821C) \
<< BIT_SHIFT_PKT_LIFTIME_VOVI_8821C)
#define BITS_PKT_LIFTIME_VOVI_8821C \
(BIT_MASK_PKT_LIFTIME_VOVI_8821C << BIT_SHIFT_PKT_LIFTIME_VOVI_8821C)
#define BIT_CLEAR_PKT_LIFTIME_VOVI_8821C(x) \
((x) & (~BITS_PKT_LIFTIME_VOVI_8821C))
#define BIT_GET_PKT_LIFTIME_VOVI_8821C(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_VOVI_8821C) & \
BIT_MASK_PKT_LIFTIME_VOVI_8821C)
#define BIT_SET_PKT_LIFTIME_VOVI_8821C(x, v) \
(BIT_CLEAR_PKT_LIFTIME_VOVI_8821C(x) | BIT_PKT_LIFTIME_VOVI_8821C(v))
/* 2 REG_STBC_SETTING_8821C */
#define BIT_SHIFT_CDEND_TXTIME_L_8821C 4
#define BIT_MASK_CDEND_TXTIME_L_8821C 0xf
#define BIT_CDEND_TXTIME_L_8821C(x) \
(((x) & BIT_MASK_CDEND_TXTIME_L_8821C) \
<< BIT_SHIFT_CDEND_TXTIME_L_8821C)
#define BITS_CDEND_TXTIME_L_8821C \
(BIT_MASK_CDEND_TXTIME_L_8821C << BIT_SHIFT_CDEND_TXTIME_L_8821C)
#define BIT_CLEAR_CDEND_TXTIME_L_8821C(x) ((x) & (~BITS_CDEND_TXTIME_L_8821C))
#define BIT_GET_CDEND_TXTIME_L_8821C(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_L_8821C) & \
BIT_MASK_CDEND_TXTIME_L_8821C)
#define BIT_SET_CDEND_TXTIME_L_8821C(x, v) \
(BIT_CLEAR_CDEND_TXTIME_L_8821C(x) | BIT_CDEND_TXTIME_L_8821C(v))
#define BIT_SHIFT_NESS_8821C 2
#define BIT_MASK_NESS_8821C 0x3
#define BIT_NESS_8821C(x) (((x) & BIT_MASK_NESS_8821C) << BIT_SHIFT_NESS_8821C)
#define BITS_NESS_8821C (BIT_MASK_NESS_8821C << BIT_SHIFT_NESS_8821C)
#define BIT_CLEAR_NESS_8821C(x) ((x) & (~BITS_NESS_8821C))
#define BIT_GET_NESS_8821C(x) \
(((x) >> BIT_SHIFT_NESS_8821C) & BIT_MASK_NESS_8821C)
#define BIT_SET_NESS_8821C(x, v) (BIT_CLEAR_NESS_8821C(x) | BIT_NESS_8821C(v))
#define BIT_SHIFT_STBC_CFEND_8821C 0
#define BIT_MASK_STBC_CFEND_8821C 0x3
#define BIT_STBC_CFEND_8821C(x) \
(((x) & BIT_MASK_STBC_CFEND_8821C) << BIT_SHIFT_STBC_CFEND_8821C)
#define BITS_STBC_CFEND_8821C \
(BIT_MASK_STBC_CFEND_8821C << BIT_SHIFT_STBC_CFEND_8821C)
#define BIT_CLEAR_STBC_CFEND_8821C(x) ((x) & (~BITS_STBC_CFEND_8821C))
#define BIT_GET_STBC_CFEND_8821C(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_8821C) & BIT_MASK_STBC_CFEND_8821C)
#define BIT_SET_STBC_CFEND_8821C(x, v) \
(BIT_CLEAR_STBC_CFEND_8821C(x) | BIT_STBC_CFEND_8821C(v))
/* 2 REG_STBC_SETTING2_8821C */
#define BIT_SHIFT_CDEND_TXTIME_H_8821C 0
#define BIT_MASK_CDEND_TXTIME_H_8821C 0x1f
#define BIT_CDEND_TXTIME_H_8821C(x) \
(((x) & BIT_MASK_CDEND_TXTIME_H_8821C) \
<< BIT_SHIFT_CDEND_TXTIME_H_8821C)
#define BITS_CDEND_TXTIME_H_8821C \
(BIT_MASK_CDEND_TXTIME_H_8821C << BIT_SHIFT_CDEND_TXTIME_H_8821C)
#define BIT_CLEAR_CDEND_TXTIME_H_8821C(x) ((x) & (~BITS_CDEND_TXTIME_H_8821C))
#define BIT_GET_CDEND_TXTIME_H_8821C(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_H_8821C) & \
BIT_MASK_CDEND_TXTIME_H_8821C)
#define BIT_SET_CDEND_TXTIME_H_8821C(x, v) \
(BIT_CLEAR_CDEND_TXTIME_H_8821C(x) | BIT_CDEND_TXTIME_H_8821C(v))
/* 2 REG_QUEUE_CTRL_8821C */
#define BIT_PTA_EDCCA_EN_8821C BIT(5)
#define BIT_PTA_WL_TX_EN_8821C BIT(4)
#define BIT_R_USE_DATA_BW_8821C BIT(3)
#define BIT_TRI_PKT_INT_MODE1_8821C BIT(2)
#define BIT_TRI_PKT_INT_MODE0_8821C BIT(1)
#define BIT_ACQ_MODE_SEL_8821C BIT(0)
/* 2 REG_SINGLE_AMPDU_CTRL_8821C */
#define BIT_EN_SINGLE_APMDU_8821C BIT(7)
/* 2 REG_PROT_MODE_CTRL_8821C */
#define BIT_SHIFT_RTS_MAX_AGG_NUM_8821C 24
#define BIT_MASK_RTS_MAX_AGG_NUM_8821C 0x3f
#define BIT_RTS_MAX_AGG_NUM_8821C(x) \
(((x) & BIT_MASK_RTS_MAX_AGG_NUM_8821C) \
<< BIT_SHIFT_RTS_MAX_AGG_NUM_8821C)
#define BITS_RTS_MAX_AGG_NUM_8821C \
(BIT_MASK_RTS_MAX_AGG_NUM_8821C << BIT_SHIFT_RTS_MAX_AGG_NUM_8821C)
#define BIT_CLEAR_RTS_MAX_AGG_NUM_8821C(x) ((x) & (~BITS_RTS_MAX_AGG_NUM_8821C))
#define BIT_GET_RTS_MAX_AGG_NUM_8821C(x) \
(((x) >> BIT_SHIFT_RTS_MAX_AGG_NUM_8821C) & \
BIT_MASK_RTS_MAX_AGG_NUM_8821C)
#define BIT_SET_RTS_MAX_AGG_NUM_8821C(x, v) \
(BIT_CLEAR_RTS_MAX_AGG_NUM_8821C(x) | BIT_RTS_MAX_AGG_NUM_8821C(v))
#define BIT_SHIFT_MAX_AGG_NUM_8821C 16
#define BIT_MASK_MAX_AGG_NUM_8821C 0x3f
#define BIT_MAX_AGG_NUM_8821C(x) \
(((x) & BIT_MASK_MAX_AGG_NUM_8821C) << BIT_SHIFT_MAX_AGG_NUM_8821C)
#define BITS_MAX_AGG_NUM_8821C \
(BIT_MASK_MAX_AGG_NUM_8821C << BIT_SHIFT_MAX_AGG_NUM_8821C)
#define BIT_CLEAR_MAX_AGG_NUM_8821C(x) ((x) & (~BITS_MAX_AGG_NUM_8821C))
#define BIT_GET_MAX_AGG_NUM_8821C(x) \
(((x) >> BIT_SHIFT_MAX_AGG_NUM_8821C) & BIT_MASK_MAX_AGG_NUM_8821C)
#define BIT_SET_MAX_AGG_NUM_8821C(x, v) \
(BIT_CLEAR_MAX_AGG_NUM_8821C(x) | BIT_MAX_AGG_NUM_8821C(v))
#define BIT_SHIFT_RTS_TXTIME_TH_8821C 8
#define BIT_MASK_RTS_TXTIME_TH_8821C 0xff
#define BIT_RTS_TXTIME_TH_8821C(x) \
(((x) & BIT_MASK_RTS_TXTIME_TH_8821C) << BIT_SHIFT_RTS_TXTIME_TH_8821C)
#define BITS_RTS_TXTIME_TH_8821C \
(BIT_MASK_RTS_TXTIME_TH_8821C << BIT_SHIFT_RTS_TXTIME_TH_8821C)
#define BIT_CLEAR_RTS_TXTIME_TH_8821C(x) ((x) & (~BITS_RTS_TXTIME_TH_8821C))
#define BIT_GET_RTS_TXTIME_TH_8821C(x) \
(((x) >> BIT_SHIFT_RTS_TXTIME_TH_8821C) & BIT_MASK_RTS_TXTIME_TH_8821C)
#define BIT_SET_RTS_TXTIME_TH_8821C(x, v) \
(BIT_CLEAR_RTS_TXTIME_TH_8821C(x) | BIT_RTS_TXTIME_TH_8821C(v))
#define BIT_SHIFT_RTS_LEN_TH_8821C 0
#define BIT_MASK_RTS_LEN_TH_8821C 0xff
#define BIT_RTS_LEN_TH_8821C(x) \
(((x) & BIT_MASK_RTS_LEN_TH_8821C) << BIT_SHIFT_RTS_LEN_TH_8821C)
#define BITS_RTS_LEN_TH_8821C \
(BIT_MASK_RTS_LEN_TH_8821C << BIT_SHIFT_RTS_LEN_TH_8821C)
#define BIT_CLEAR_RTS_LEN_TH_8821C(x) ((x) & (~BITS_RTS_LEN_TH_8821C))
#define BIT_GET_RTS_LEN_TH_8821C(x) \
(((x) >> BIT_SHIFT_RTS_LEN_TH_8821C) & BIT_MASK_RTS_LEN_TH_8821C)
#define BIT_SET_RTS_LEN_TH_8821C(x, v) \
(BIT_CLEAR_RTS_LEN_TH_8821C(x) | BIT_RTS_LEN_TH_8821C(v))
/* 2 REG_BAR_MODE_CTRL_8821C */
#define BIT_SHIFT_BAR_RTY_LMT_8821C 16
#define BIT_MASK_BAR_RTY_LMT_8821C 0x3
#define BIT_BAR_RTY_LMT_8821C(x) \
(((x) & BIT_MASK_BAR_RTY_LMT_8821C) << BIT_SHIFT_BAR_RTY_LMT_8821C)
#define BITS_BAR_RTY_LMT_8821C \
(BIT_MASK_BAR_RTY_LMT_8821C << BIT_SHIFT_BAR_RTY_LMT_8821C)
#define BIT_CLEAR_BAR_RTY_LMT_8821C(x) ((x) & (~BITS_BAR_RTY_LMT_8821C))
#define BIT_GET_BAR_RTY_LMT_8821C(x) \
(((x) >> BIT_SHIFT_BAR_RTY_LMT_8821C) & BIT_MASK_BAR_RTY_LMT_8821C)
#define BIT_SET_BAR_RTY_LMT_8821C(x, v) \
(BIT_CLEAR_BAR_RTY_LMT_8821C(x) | BIT_BAR_RTY_LMT_8821C(v))
#define BIT_SHIFT_BAR_PKT_TXTIME_TH_8821C 8
#define BIT_MASK_BAR_PKT_TXTIME_TH_8821C 0xff
#define BIT_BAR_PKT_TXTIME_TH_8821C(x) \
(((x) & BIT_MASK_BAR_PKT_TXTIME_TH_8821C) \
<< BIT_SHIFT_BAR_PKT_TXTIME_TH_8821C)
#define BITS_BAR_PKT_TXTIME_TH_8821C \
(BIT_MASK_BAR_PKT_TXTIME_TH_8821C << BIT_SHIFT_BAR_PKT_TXTIME_TH_8821C)
#define BIT_CLEAR_BAR_PKT_TXTIME_TH_8821C(x) \
((x) & (~BITS_BAR_PKT_TXTIME_TH_8821C))
#define BIT_GET_BAR_PKT_TXTIME_TH_8821C(x) \
(((x) >> BIT_SHIFT_BAR_PKT_TXTIME_TH_8821C) & \
BIT_MASK_BAR_PKT_TXTIME_TH_8821C)
#define BIT_SET_BAR_PKT_TXTIME_TH_8821C(x, v) \
(BIT_CLEAR_BAR_PKT_TXTIME_TH_8821C(x) | BIT_BAR_PKT_TXTIME_TH_8821C(v))
#define BIT_BAR_EN_V1_8821C BIT(6)
#define BIT_SHIFT_BAR_PKTNUM_TH_V1_8821C 0
#define BIT_MASK_BAR_PKTNUM_TH_V1_8821C 0x3f
#define BIT_BAR_PKTNUM_TH_V1_8821C(x) \
(((x) & BIT_MASK_BAR_PKTNUM_TH_V1_8821C) \
<< BIT_SHIFT_BAR_PKTNUM_TH_V1_8821C)
#define BITS_BAR_PKTNUM_TH_V1_8821C \
(BIT_MASK_BAR_PKTNUM_TH_V1_8821C << BIT_SHIFT_BAR_PKTNUM_TH_V1_8821C)
#define BIT_CLEAR_BAR_PKTNUM_TH_V1_8821C(x) \
((x) & (~BITS_BAR_PKTNUM_TH_V1_8821C))
#define BIT_GET_BAR_PKTNUM_TH_V1_8821C(x) \
(((x) >> BIT_SHIFT_BAR_PKTNUM_TH_V1_8821C) & \
BIT_MASK_BAR_PKTNUM_TH_V1_8821C)
#define BIT_SET_BAR_PKTNUM_TH_V1_8821C(x, v) \
(BIT_CLEAR_BAR_PKTNUM_TH_V1_8821C(x) | BIT_BAR_PKTNUM_TH_V1_8821C(v))
/* 2 REG_RA_TRY_RATE_AGG_LMT_8821C */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8821C 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8821C 0x3f
#define BIT_RA_TRY_RATE_AGG_LMT_V1_8821C(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8821C) \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8821C)
#define BITS_RA_TRY_RATE_AGG_LMT_V1_8821C \
(BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8821C \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8821C)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8821C(x) \
((x) & (~BITS_RA_TRY_RATE_AGG_LMT_V1_8821C))
#define BIT_GET_RA_TRY_RATE_AGG_LMT_V1_8821C(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8821C) & \
BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8821C)
#define BIT_SET_RA_TRY_RATE_AGG_LMT_V1_8821C(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8821C(x) | \
BIT_RA_TRY_RATE_AGG_LMT_V1_8821C(v))
/* 2 REG_MACID_SLEEP2_8821C */
#define BIT_SHIFT_MACID95_64PKTSLEEP_8821C 0
#define BIT_MASK_MACID95_64PKTSLEEP_8821C 0xffffffffL
#define BIT_MACID95_64PKTSLEEP_8821C(x) \
(((x) & BIT_MASK_MACID95_64PKTSLEEP_8821C) \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8821C)
#define BITS_MACID95_64PKTSLEEP_8821C \
(BIT_MASK_MACID95_64PKTSLEEP_8821C \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8821C)
#define BIT_CLEAR_MACID95_64PKTSLEEP_8821C(x) \
((x) & (~BITS_MACID95_64PKTSLEEP_8821C))
#define BIT_GET_MACID95_64PKTSLEEP_8821C(x) \
(((x) >> BIT_SHIFT_MACID95_64PKTSLEEP_8821C) & \
BIT_MASK_MACID95_64PKTSLEEP_8821C)
#define BIT_SET_MACID95_64PKTSLEEP_8821C(x, v) \
(BIT_CLEAR_MACID95_64PKTSLEEP_8821C(x) | \
BIT_MACID95_64PKTSLEEP_8821C(v))
/* 2 REG_MACID_SLEEP_8821C */
#define BIT_SHIFT_MACID31_0_PKTSLEEP_8821C 0
#define BIT_MASK_MACID31_0_PKTSLEEP_8821C 0xffffffffL
#define BIT_MACID31_0_PKTSLEEP_8821C(x) \
(((x) & BIT_MASK_MACID31_0_PKTSLEEP_8821C) \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8821C)
#define BITS_MACID31_0_PKTSLEEP_8821C \
(BIT_MASK_MACID31_0_PKTSLEEP_8821C \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8821C)
#define BIT_CLEAR_MACID31_0_PKTSLEEP_8821C(x) \
((x) & (~BITS_MACID31_0_PKTSLEEP_8821C))
#define BIT_GET_MACID31_0_PKTSLEEP_8821C(x) \
(((x) >> BIT_SHIFT_MACID31_0_PKTSLEEP_8821C) & \
BIT_MASK_MACID31_0_PKTSLEEP_8821C)
#define BIT_SET_MACID31_0_PKTSLEEP_8821C(x, v) \
(BIT_CLEAR_MACID31_0_PKTSLEEP_8821C(x) | \
BIT_MACID31_0_PKTSLEEP_8821C(v))
/* 2 REG_HW_SEQ0_8821C */
#define BIT_SHIFT_HW_SSN_SEQ0_8821C 0
#define BIT_MASK_HW_SSN_SEQ0_8821C 0xfff
#define BIT_HW_SSN_SEQ0_8821C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ0_8821C) << BIT_SHIFT_HW_SSN_SEQ0_8821C)
#define BITS_HW_SSN_SEQ0_8821C \
(BIT_MASK_HW_SSN_SEQ0_8821C << BIT_SHIFT_HW_SSN_SEQ0_8821C)
#define BIT_CLEAR_HW_SSN_SEQ0_8821C(x) ((x) & (~BITS_HW_SSN_SEQ0_8821C))
#define BIT_GET_HW_SSN_SEQ0_8821C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ0_8821C) & BIT_MASK_HW_SSN_SEQ0_8821C)
#define BIT_SET_HW_SSN_SEQ0_8821C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ0_8821C(x) | BIT_HW_SSN_SEQ0_8821C(v))
/* 2 REG_HW_SEQ1_8821C */
#define BIT_SHIFT_HW_SSN_SEQ1_8821C 0
#define BIT_MASK_HW_SSN_SEQ1_8821C 0xfff
#define BIT_HW_SSN_SEQ1_8821C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ1_8821C) << BIT_SHIFT_HW_SSN_SEQ1_8821C)
#define BITS_HW_SSN_SEQ1_8821C \
(BIT_MASK_HW_SSN_SEQ1_8821C << BIT_SHIFT_HW_SSN_SEQ1_8821C)
#define BIT_CLEAR_HW_SSN_SEQ1_8821C(x) ((x) & (~BITS_HW_SSN_SEQ1_8821C))
#define BIT_GET_HW_SSN_SEQ1_8821C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ1_8821C) & BIT_MASK_HW_SSN_SEQ1_8821C)
#define BIT_SET_HW_SSN_SEQ1_8821C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ1_8821C(x) | BIT_HW_SSN_SEQ1_8821C(v))
/* 2 REG_HW_SEQ2_8821C */
#define BIT_SHIFT_HW_SSN_SEQ2_8821C 0
#define BIT_MASK_HW_SSN_SEQ2_8821C 0xfff
#define BIT_HW_SSN_SEQ2_8821C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ2_8821C) << BIT_SHIFT_HW_SSN_SEQ2_8821C)
#define BITS_HW_SSN_SEQ2_8821C \
(BIT_MASK_HW_SSN_SEQ2_8821C << BIT_SHIFT_HW_SSN_SEQ2_8821C)
#define BIT_CLEAR_HW_SSN_SEQ2_8821C(x) ((x) & (~BITS_HW_SSN_SEQ2_8821C))
#define BIT_GET_HW_SSN_SEQ2_8821C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ2_8821C) & BIT_MASK_HW_SSN_SEQ2_8821C)
#define BIT_SET_HW_SSN_SEQ2_8821C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ2_8821C(x) | BIT_HW_SSN_SEQ2_8821C(v))
/* 2 REG_HW_SEQ3_8821C */
#define BIT_SHIFT_CSI_HWSEQ_SEL_8821C 12
#define BIT_MASK_CSI_HWSEQ_SEL_8821C 0x3
#define BIT_CSI_HWSEQ_SEL_8821C(x) \
(((x) & BIT_MASK_CSI_HWSEQ_SEL_8821C) << BIT_SHIFT_CSI_HWSEQ_SEL_8821C)
#define BITS_CSI_HWSEQ_SEL_8821C \
(BIT_MASK_CSI_HWSEQ_SEL_8821C << BIT_SHIFT_CSI_HWSEQ_SEL_8821C)
#define BIT_CLEAR_CSI_HWSEQ_SEL_8821C(x) ((x) & (~BITS_CSI_HWSEQ_SEL_8821C))
#define BIT_GET_CSI_HWSEQ_SEL_8821C(x) \
(((x) >> BIT_SHIFT_CSI_HWSEQ_SEL_8821C) & BIT_MASK_CSI_HWSEQ_SEL_8821C)
#define BIT_SET_CSI_HWSEQ_SEL_8821C(x, v) \
(BIT_CLEAR_CSI_HWSEQ_SEL_8821C(x) | BIT_CSI_HWSEQ_SEL_8821C(v))
#define BIT_SHIFT_HW_SSN_SEQ3_8821C 0
#define BIT_MASK_HW_SSN_SEQ3_8821C 0xfff
#define BIT_HW_SSN_SEQ3_8821C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ3_8821C) << BIT_SHIFT_HW_SSN_SEQ3_8821C)
#define BITS_HW_SSN_SEQ3_8821C \
(BIT_MASK_HW_SSN_SEQ3_8821C << BIT_SHIFT_HW_SSN_SEQ3_8821C)
#define BIT_CLEAR_HW_SSN_SEQ3_8821C(x) ((x) & (~BITS_HW_SSN_SEQ3_8821C))
#define BIT_GET_HW_SSN_SEQ3_8821C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ3_8821C) & BIT_MASK_HW_SSN_SEQ3_8821C)
#define BIT_SET_HW_SSN_SEQ3_8821C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ3_8821C(x) | BIT_HW_SSN_SEQ3_8821C(v))
/* 2 REG_NULL_PKT_STATUS_V1_8821C */
#define BIT_SHIFT_PTCL_TOTAL_PG_V2_8821C 2
#define BIT_MASK_PTCL_TOTAL_PG_V2_8821C 0x3fff
#define BIT_PTCL_TOTAL_PG_V2_8821C(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V2_8821C) \
<< BIT_SHIFT_PTCL_TOTAL_PG_V2_8821C)
#define BITS_PTCL_TOTAL_PG_V2_8821C \
(BIT_MASK_PTCL_TOTAL_PG_V2_8821C << BIT_SHIFT_PTCL_TOTAL_PG_V2_8821C)
#define BIT_CLEAR_PTCL_TOTAL_PG_V2_8821C(x) \
((x) & (~BITS_PTCL_TOTAL_PG_V2_8821C))
#define BIT_GET_PTCL_TOTAL_PG_V2_8821C(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V2_8821C) & \
BIT_MASK_PTCL_TOTAL_PG_V2_8821C)
#define BIT_SET_PTCL_TOTAL_PG_V2_8821C(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V2_8821C(x) | BIT_PTCL_TOTAL_PG_V2_8821C(v))
#define BIT_TX_NULL_1_8821C BIT(1)
#define BIT_TX_NULL_0_8821C BIT(0)
/* 2 REG_PTCL_ERR_STATUS_8821C */
#define BIT_PTCL_RATE_TABLE_INVALID_8821C BIT(7)
#define BIT_FTM_T2R_ERROR_8821C BIT(6)
#define BIT_PTCL_ERR0_8821C BIT(5)
#define BIT_PTCL_ERR1_8821C BIT(4)
#define BIT_PTCL_ERR2_8821C BIT(3)
#define BIT_PTCL_ERR3_8821C BIT(2)
#define BIT_PTCL_ERR4_8821C BIT(1)
#define BIT_PTCL_ERR5_8821C BIT(0)
/* 2 REG_NULL_PKT_STATUS_EXTEND_8821C */
#define BIT_CLI3_TX_NULL_1_8821C BIT(7)
#define BIT_CLI3_TX_NULL_0_8821C BIT(6)
#define BIT_CLI2_TX_NULL_1_8821C BIT(5)
#define BIT_CLI2_TX_NULL_0_8821C BIT(4)
#define BIT_CLI1_TX_NULL_1_8821C BIT(3)
#define BIT_CLI1_TX_NULL_0_8821C BIT(2)
#define BIT_CLI0_TX_NULL_1_8821C BIT(1)
#define BIT_CLI0_TX_NULL_0_8821C BIT(0)
/* 2 REG_VIDEO_ENHANCEMENT_FUN_8821C */
#define BIT_HIQ_DROP_8821C BIT(7)
#define BIT_MGQ_DROP_8821C BIT(6)
#define BIT_VIDEO_JUST_DROP_8821C BIT(1)
#define BIT_VIDEO_ENHANCEMENT_FUN_EN_8821C BIT(0)
/* 2 REG_PRECNT_CTRL_8821C */
#define BIT_EN_PRECNT_8821C BIT(11)
#define BIT_SHIFT_PRECNT_TH_8821C 0
#define BIT_MASK_PRECNT_TH_8821C 0x7ff
#define BIT_PRECNT_TH_8821C(x) \
(((x) & BIT_MASK_PRECNT_TH_8821C) << BIT_SHIFT_PRECNT_TH_8821C)
#define BITS_PRECNT_TH_8821C \
(BIT_MASK_PRECNT_TH_8821C << BIT_SHIFT_PRECNT_TH_8821C)
#define BIT_CLEAR_PRECNT_TH_8821C(x) ((x) & (~BITS_PRECNT_TH_8821C))
#define BIT_GET_PRECNT_TH_8821C(x) \
(((x) >> BIT_SHIFT_PRECNT_TH_8821C) & BIT_MASK_PRECNT_TH_8821C)
#define BIT_SET_PRECNT_TH_8821C(x, v) \
(BIT_CLEAR_PRECNT_TH_8821C(x) | BIT_PRECNT_TH_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_BT_POLLUTE_PKT_CNT_8821C */
#define BIT_SHIFT_BT_POLLUTE_PKT_CNT_8821C 0
#define BIT_MASK_BT_POLLUTE_PKT_CNT_8821C 0xffff
#define BIT_BT_POLLUTE_PKT_CNT_8821C(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKT_CNT_8821C) \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8821C)
#define BITS_BT_POLLUTE_PKT_CNT_8821C \
(BIT_MASK_BT_POLLUTE_PKT_CNT_8821C \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8821C)
#define BIT_CLEAR_BT_POLLUTE_PKT_CNT_8821C(x) \
((x) & (~BITS_BT_POLLUTE_PKT_CNT_8821C))
#define BIT_GET_BT_POLLUTE_PKT_CNT_8821C(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKT_CNT_8821C) & \
BIT_MASK_BT_POLLUTE_PKT_CNT_8821C)
#define BIT_SET_BT_POLLUTE_PKT_CNT_8821C(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKT_CNT_8821C(x) | \
BIT_BT_POLLUTE_PKT_CNT_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_PTCL_DBG_8821C */
#define BIT_SHIFT_PTCL_DBG_8821C 0
#define BIT_MASK_PTCL_DBG_8821C 0xffffffffL
#define BIT_PTCL_DBG_8821C(x) \
(((x) & BIT_MASK_PTCL_DBG_8821C) << BIT_SHIFT_PTCL_DBG_8821C)
#define BITS_PTCL_DBG_8821C \
(BIT_MASK_PTCL_DBG_8821C << BIT_SHIFT_PTCL_DBG_8821C)
#define BIT_CLEAR_PTCL_DBG_8821C(x) ((x) & (~BITS_PTCL_DBG_8821C))
#define BIT_GET_PTCL_DBG_8821C(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_8821C) & BIT_MASK_PTCL_DBG_8821C)
#define BIT_SET_PTCL_DBG_8821C(x, v) \
(BIT_CLEAR_PTCL_DBG_8821C(x) | BIT_PTCL_DBG_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_CPUMGQ_TIMER_CTRL2_8821C */
#define BIT_SHIFT_TRI_HEAD_ADDR_8821C 16
#define BIT_MASK_TRI_HEAD_ADDR_8821C 0xfff
#define BIT_TRI_HEAD_ADDR_8821C(x) \
(((x) & BIT_MASK_TRI_HEAD_ADDR_8821C) << BIT_SHIFT_TRI_HEAD_ADDR_8821C)
#define BITS_TRI_HEAD_ADDR_8821C \
(BIT_MASK_TRI_HEAD_ADDR_8821C << BIT_SHIFT_TRI_HEAD_ADDR_8821C)
#define BIT_CLEAR_TRI_HEAD_ADDR_8821C(x) ((x) & (~BITS_TRI_HEAD_ADDR_8821C))
#define BIT_GET_TRI_HEAD_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_TRI_HEAD_ADDR_8821C) & BIT_MASK_TRI_HEAD_ADDR_8821C)
#define BIT_SET_TRI_HEAD_ADDR_8821C(x, v) \
(BIT_CLEAR_TRI_HEAD_ADDR_8821C(x) | BIT_TRI_HEAD_ADDR_8821C(v))
#define BIT_DROP_TH_EN_8821C BIT(8)
#define BIT_SHIFT_DROP_TH_8821C 0
#define BIT_MASK_DROP_TH_8821C 0xff
#define BIT_DROP_TH_8821C(x) \
(((x) & BIT_MASK_DROP_TH_8821C) << BIT_SHIFT_DROP_TH_8821C)
#define BITS_DROP_TH_8821C (BIT_MASK_DROP_TH_8821C << BIT_SHIFT_DROP_TH_8821C)
#define BIT_CLEAR_DROP_TH_8821C(x) ((x) & (~BITS_DROP_TH_8821C))
#define BIT_GET_DROP_TH_8821C(x) \
(((x) >> BIT_SHIFT_DROP_TH_8821C) & BIT_MASK_DROP_TH_8821C)
#define BIT_SET_DROP_TH_8821C(x, v) \
(BIT_CLEAR_DROP_TH_8821C(x) | BIT_DROP_TH_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_DUMMY_PAGE4_V1_8821C */
/* 2 REG_MOREDATA_8821C */
#define BIT_MOREDATA_CTRL2_EN_V1_8821C BIT(3)
#define BIT_MOREDATA_CTRL1_EN_V1_8821C BIT(2)
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE_V1_8821C BIT(0)
/* 2 REG_Q0_Q1_INFO_8821C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8821C BIT(31)
#define BIT_SHIFT_GTAB_ID_8821C 28
#define BIT_MASK_GTAB_ID_8821C 0x7
#define BIT_GTAB_ID_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_8821C) << BIT_SHIFT_GTAB_ID_8821C)
#define BITS_GTAB_ID_8821C (BIT_MASK_GTAB_ID_8821C << BIT_SHIFT_GTAB_ID_8821C)
#define BIT_CLEAR_GTAB_ID_8821C(x) ((x) & (~BITS_GTAB_ID_8821C))
#define BIT_GET_GTAB_ID_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8821C) & BIT_MASK_GTAB_ID_8821C)
#define BIT_SET_GTAB_ID_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_8821C(x) | BIT_GTAB_ID_8821C(v))
#define BIT_SHIFT_AC1_PKT_INFO_8821C 16
#define BIT_MASK_AC1_PKT_INFO_8821C 0xfff
#define BIT_AC1_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC1_PKT_INFO_8821C) << BIT_SHIFT_AC1_PKT_INFO_8821C)
#define BITS_AC1_PKT_INFO_8821C \
(BIT_MASK_AC1_PKT_INFO_8821C << BIT_SHIFT_AC1_PKT_INFO_8821C)
#define BIT_CLEAR_AC1_PKT_INFO_8821C(x) ((x) & (~BITS_AC1_PKT_INFO_8821C))
#define BIT_GET_AC1_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC1_PKT_INFO_8821C) & BIT_MASK_AC1_PKT_INFO_8821C)
#define BIT_SET_AC1_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC1_PKT_INFO_8821C(x) | BIT_AC1_PKT_INFO_8821C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8821C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8821C 12
#define BIT_MASK_GTAB_ID_V1_8821C 0x7
#define BIT_GTAB_ID_V1_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8821C) << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BITS_GTAB_ID_V1_8821C \
(BIT_MASK_GTAB_ID_V1_8821C << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BIT_CLEAR_GTAB_ID_V1_8821C(x) ((x) & (~BITS_GTAB_ID_V1_8821C))
#define BIT_GET_GTAB_ID_V1_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8821C) & BIT_MASK_GTAB_ID_V1_8821C)
#define BIT_SET_GTAB_ID_V1_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8821C(x) | BIT_GTAB_ID_V1_8821C(v))
#define BIT_SHIFT_AC0_PKT_INFO_8821C 0
#define BIT_MASK_AC0_PKT_INFO_8821C 0xfff
#define BIT_AC0_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC0_PKT_INFO_8821C) << BIT_SHIFT_AC0_PKT_INFO_8821C)
#define BITS_AC0_PKT_INFO_8821C \
(BIT_MASK_AC0_PKT_INFO_8821C << BIT_SHIFT_AC0_PKT_INFO_8821C)
#define BIT_CLEAR_AC0_PKT_INFO_8821C(x) ((x) & (~BITS_AC0_PKT_INFO_8821C))
#define BIT_GET_AC0_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC0_PKT_INFO_8821C) & BIT_MASK_AC0_PKT_INFO_8821C)
#define BIT_SET_AC0_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC0_PKT_INFO_8821C(x) | BIT_AC0_PKT_INFO_8821C(v))
/* 2 REG_Q2_Q3_INFO_8821C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8821C BIT(31)
#define BIT_SHIFT_GTAB_ID_8821C 28
#define BIT_MASK_GTAB_ID_8821C 0x7
#define BIT_GTAB_ID_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_8821C) << BIT_SHIFT_GTAB_ID_8821C)
#define BITS_GTAB_ID_8821C (BIT_MASK_GTAB_ID_8821C << BIT_SHIFT_GTAB_ID_8821C)
#define BIT_CLEAR_GTAB_ID_8821C(x) ((x) & (~BITS_GTAB_ID_8821C))
#define BIT_GET_GTAB_ID_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8821C) & BIT_MASK_GTAB_ID_8821C)
#define BIT_SET_GTAB_ID_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_8821C(x) | BIT_GTAB_ID_8821C(v))
#define BIT_SHIFT_AC3_PKT_INFO_8821C 16
#define BIT_MASK_AC3_PKT_INFO_8821C 0xfff
#define BIT_AC3_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC3_PKT_INFO_8821C) << BIT_SHIFT_AC3_PKT_INFO_8821C)
#define BITS_AC3_PKT_INFO_8821C \
(BIT_MASK_AC3_PKT_INFO_8821C << BIT_SHIFT_AC3_PKT_INFO_8821C)
#define BIT_CLEAR_AC3_PKT_INFO_8821C(x) ((x) & (~BITS_AC3_PKT_INFO_8821C))
#define BIT_GET_AC3_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC3_PKT_INFO_8821C) & BIT_MASK_AC3_PKT_INFO_8821C)
#define BIT_SET_AC3_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC3_PKT_INFO_8821C(x) | BIT_AC3_PKT_INFO_8821C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8821C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8821C 12
#define BIT_MASK_GTAB_ID_V1_8821C 0x7
#define BIT_GTAB_ID_V1_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8821C) << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BITS_GTAB_ID_V1_8821C \
(BIT_MASK_GTAB_ID_V1_8821C << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BIT_CLEAR_GTAB_ID_V1_8821C(x) ((x) & (~BITS_GTAB_ID_V1_8821C))
#define BIT_GET_GTAB_ID_V1_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8821C) & BIT_MASK_GTAB_ID_V1_8821C)
#define BIT_SET_GTAB_ID_V1_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8821C(x) | BIT_GTAB_ID_V1_8821C(v))
#define BIT_SHIFT_AC2_PKT_INFO_8821C 0
#define BIT_MASK_AC2_PKT_INFO_8821C 0xfff
#define BIT_AC2_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC2_PKT_INFO_8821C) << BIT_SHIFT_AC2_PKT_INFO_8821C)
#define BITS_AC2_PKT_INFO_8821C \
(BIT_MASK_AC2_PKT_INFO_8821C << BIT_SHIFT_AC2_PKT_INFO_8821C)
#define BIT_CLEAR_AC2_PKT_INFO_8821C(x) ((x) & (~BITS_AC2_PKT_INFO_8821C))
#define BIT_GET_AC2_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC2_PKT_INFO_8821C) & BIT_MASK_AC2_PKT_INFO_8821C)
#define BIT_SET_AC2_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC2_PKT_INFO_8821C(x) | BIT_AC2_PKT_INFO_8821C(v))
/* 2 REG_Q4_Q5_INFO_8821C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8821C BIT(31)
#define BIT_SHIFT_GTAB_ID_8821C 28
#define BIT_MASK_GTAB_ID_8821C 0x7
#define BIT_GTAB_ID_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_8821C) << BIT_SHIFT_GTAB_ID_8821C)
#define BITS_GTAB_ID_8821C (BIT_MASK_GTAB_ID_8821C << BIT_SHIFT_GTAB_ID_8821C)
#define BIT_CLEAR_GTAB_ID_8821C(x) ((x) & (~BITS_GTAB_ID_8821C))
#define BIT_GET_GTAB_ID_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8821C) & BIT_MASK_GTAB_ID_8821C)
#define BIT_SET_GTAB_ID_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_8821C(x) | BIT_GTAB_ID_8821C(v))
#define BIT_SHIFT_AC5_PKT_INFO_8821C 16
#define BIT_MASK_AC5_PKT_INFO_8821C 0xfff
#define BIT_AC5_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC5_PKT_INFO_8821C) << BIT_SHIFT_AC5_PKT_INFO_8821C)
#define BITS_AC5_PKT_INFO_8821C \
(BIT_MASK_AC5_PKT_INFO_8821C << BIT_SHIFT_AC5_PKT_INFO_8821C)
#define BIT_CLEAR_AC5_PKT_INFO_8821C(x) ((x) & (~BITS_AC5_PKT_INFO_8821C))
#define BIT_GET_AC5_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC5_PKT_INFO_8821C) & BIT_MASK_AC5_PKT_INFO_8821C)
#define BIT_SET_AC5_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC5_PKT_INFO_8821C(x) | BIT_AC5_PKT_INFO_8821C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8821C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8821C 12
#define BIT_MASK_GTAB_ID_V1_8821C 0x7
#define BIT_GTAB_ID_V1_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8821C) << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BITS_GTAB_ID_V1_8821C \
(BIT_MASK_GTAB_ID_V1_8821C << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BIT_CLEAR_GTAB_ID_V1_8821C(x) ((x) & (~BITS_GTAB_ID_V1_8821C))
#define BIT_GET_GTAB_ID_V1_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8821C) & BIT_MASK_GTAB_ID_V1_8821C)
#define BIT_SET_GTAB_ID_V1_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8821C(x) | BIT_GTAB_ID_V1_8821C(v))
#define BIT_SHIFT_AC4_PKT_INFO_8821C 0
#define BIT_MASK_AC4_PKT_INFO_8821C 0xfff
#define BIT_AC4_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC4_PKT_INFO_8821C) << BIT_SHIFT_AC4_PKT_INFO_8821C)
#define BITS_AC4_PKT_INFO_8821C \
(BIT_MASK_AC4_PKT_INFO_8821C << BIT_SHIFT_AC4_PKT_INFO_8821C)
#define BIT_CLEAR_AC4_PKT_INFO_8821C(x) ((x) & (~BITS_AC4_PKT_INFO_8821C))
#define BIT_GET_AC4_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC4_PKT_INFO_8821C) & BIT_MASK_AC4_PKT_INFO_8821C)
#define BIT_SET_AC4_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC4_PKT_INFO_8821C(x) | BIT_AC4_PKT_INFO_8821C(v))
/* 2 REG_Q6_Q7_INFO_8821C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8821C BIT(31)
#define BIT_SHIFT_GTAB_ID_8821C 28
#define BIT_MASK_GTAB_ID_8821C 0x7
#define BIT_GTAB_ID_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_8821C) << BIT_SHIFT_GTAB_ID_8821C)
#define BITS_GTAB_ID_8821C (BIT_MASK_GTAB_ID_8821C << BIT_SHIFT_GTAB_ID_8821C)
#define BIT_CLEAR_GTAB_ID_8821C(x) ((x) & (~BITS_GTAB_ID_8821C))
#define BIT_GET_GTAB_ID_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8821C) & BIT_MASK_GTAB_ID_8821C)
#define BIT_SET_GTAB_ID_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_8821C(x) | BIT_GTAB_ID_8821C(v))
#define BIT_SHIFT_AC7_PKT_INFO_8821C 16
#define BIT_MASK_AC7_PKT_INFO_8821C 0xfff
#define BIT_AC7_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC7_PKT_INFO_8821C) << BIT_SHIFT_AC7_PKT_INFO_8821C)
#define BITS_AC7_PKT_INFO_8821C \
(BIT_MASK_AC7_PKT_INFO_8821C << BIT_SHIFT_AC7_PKT_INFO_8821C)
#define BIT_CLEAR_AC7_PKT_INFO_8821C(x) ((x) & (~BITS_AC7_PKT_INFO_8821C))
#define BIT_GET_AC7_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC7_PKT_INFO_8821C) & BIT_MASK_AC7_PKT_INFO_8821C)
#define BIT_SET_AC7_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC7_PKT_INFO_8821C(x) | BIT_AC7_PKT_INFO_8821C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8821C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8821C 12
#define BIT_MASK_GTAB_ID_V1_8821C 0x7
#define BIT_GTAB_ID_V1_8821C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8821C) << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BITS_GTAB_ID_V1_8821C \
(BIT_MASK_GTAB_ID_V1_8821C << BIT_SHIFT_GTAB_ID_V1_8821C)
#define BIT_CLEAR_GTAB_ID_V1_8821C(x) ((x) & (~BITS_GTAB_ID_V1_8821C))
#define BIT_GET_GTAB_ID_V1_8821C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8821C) & BIT_MASK_GTAB_ID_V1_8821C)
#define BIT_SET_GTAB_ID_V1_8821C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8821C(x) | BIT_GTAB_ID_V1_8821C(v))
#define BIT_SHIFT_AC6_PKT_INFO_8821C 0
#define BIT_MASK_AC6_PKT_INFO_8821C 0xfff
#define BIT_AC6_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_AC6_PKT_INFO_8821C) << BIT_SHIFT_AC6_PKT_INFO_8821C)
#define BITS_AC6_PKT_INFO_8821C \
(BIT_MASK_AC6_PKT_INFO_8821C << BIT_SHIFT_AC6_PKT_INFO_8821C)
#define BIT_CLEAR_AC6_PKT_INFO_8821C(x) ((x) & (~BITS_AC6_PKT_INFO_8821C))
#define BIT_GET_AC6_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_AC6_PKT_INFO_8821C) & BIT_MASK_AC6_PKT_INFO_8821C)
#define BIT_SET_AC6_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_AC6_PKT_INFO_8821C(x) | BIT_AC6_PKT_INFO_8821C(v))
/* 2 REG_MGQ_HIQ_INFO_8821C */
#define BIT_SHIFT_HIQ_PKT_INFO_8821C 16
#define BIT_MASK_HIQ_PKT_INFO_8821C 0xfff
#define BIT_HIQ_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_HIQ_PKT_INFO_8821C) << BIT_SHIFT_HIQ_PKT_INFO_8821C)
#define BITS_HIQ_PKT_INFO_8821C \
(BIT_MASK_HIQ_PKT_INFO_8821C << BIT_SHIFT_HIQ_PKT_INFO_8821C)
#define BIT_CLEAR_HIQ_PKT_INFO_8821C(x) ((x) & (~BITS_HIQ_PKT_INFO_8821C))
#define BIT_GET_HIQ_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_HIQ_PKT_INFO_8821C) & BIT_MASK_HIQ_PKT_INFO_8821C)
#define BIT_SET_HIQ_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_HIQ_PKT_INFO_8821C(x) | BIT_HIQ_PKT_INFO_8821C(v))
#define BIT_SHIFT_MGQ_PKT_INFO_8821C 0
#define BIT_MASK_MGQ_PKT_INFO_8821C 0xfff
#define BIT_MGQ_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_MGQ_PKT_INFO_8821C) << BIT_SHIFT_MGQ_PKT_INFO_8821C)
#define BITS_MGQ_PKT_INFO_8821C \
(BIT_MASK_MGQ_PKT_INFO_8821C << BIT_SHIFT_MGQ_PKT_INFO_8821C)
#define BIT_CLEAR_MGQ_PKT_INFO_8821C(x) ((x) & (~BITS_MGQ_PKT_INFO_8821C))
#define BIT_GET_MGQ_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_PKT_INFO_8821C) & BIT_MASK_MGQ_PKT_INFO_8821C)
#define BIT_SET_MGQ_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_MGQ_PKT_INFO_8821C(x) | BIT_MGQ_PKT_INFO_8821C(v))
/* 2 REG_CMDQ_BCNQ_INFO_8821C */
#define BIT_SHIFT_CMDQ_PKT_INFO_8821C 16
#define BIT_MASK_CMDQ_PKT_INFO_8821C 0xfff
#define BIT_CMDQ_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_CMDQ_PKT_INFO_8821C) << BIT_SHIFT_CMDQ_PKT_INFO_8821C)
#define BITS_CMDQ_PKT_INFO_8821C \
(BIT_MASK_CMDQ_PKT_INFO_8821C << BIT_SHIFT_CMDQ_PKT_INFO_8821C)
#define BIT_CLEAR_CMDQ_PKT_INFO_8821C(x) ((x) & (~BITS_CMDQ_PKT_INFO_8821C))
#define BIT_GET_CMDQ_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_CMDQ_PKT_INFO_8821C) & BIT_MASK_CMDQ_PKT_INFO_8821C)
#define BIT_SET_CMDQ_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_CMDQ_PKT_INFO_8821C(x) | BIT_CMDQ_PKT_INFO_8821C(v))
#define BIT_SHIFT_BCNQ_PKT_INFO_8821C 0
#define BIT_MASK_BCNQ_PKT_INFO_8821C 0xfff
#define BIT_BCNQ_PKT_INFO_8821C(x) \
(((x) & BIT_MASK_BCNQ_PKT_INFO_8821C) << BIT_SHIFT_BCNQ_PKT_INFO_8821C)
#define BITS_BCNQ_PKT_INFO_8821C \
(BIT_MASK_BCNQ_PKT_INFO_8821C << BIT_SHIFT_BCNQ_PKT_INFO_8821C)
#define BIT_CLEAR_BCNQ_PKT_INFO_8821C(x) ((x) & (~BITS_BCNQ_PKT_INFO_8821C))
#define BIT_GET_BCNQ_PKT_INFO_8821C(x) \
(((x) >> BIT_SHIFT_BCNQ_PKT_INFO_8821C) & BIT_MASK_BCNQ_PKT_INFO_8821C)
#define BIT_SET_BCNQ_PKT_INFO_8821C(x, v) \
(BIT_CLEAR_BCNQ_PKT_INFO_8821C(x) | BIT_BCNQ_PKT_INFO_8821C(v))
/* 2 REG_USEREG_SETTING_8821C */
#define BIT_NDPA_USEREG_8821C BIT(21)
#define BIT_SHIFT_RETRY_USEREG_8821C 19
#define BIT_MASK_RETRY_USEREG_8821C 0x3
#define BIT_RETRY_USEREG_8821C(x) \
(((x) & BIT_MASK_RETRY_USEREG_8821C) << BIT_SHIFT_RETRY_USEREG_8821C)
#define BITS_RETRY_USEREG_8821C \
(BIT_MASK_RETRY_USEREG_8821C << BIT_SHIFT_RETRY_USEREG_8821C)
#define BIT_CLEAR_RETRY_USEREG_8821C(x) ((x) & (~BITS_RETRY_USEREG_8821C))
#define BIT_GET_RETRY_USEREG_8821C(x) \
(((x) >> BIT_SHIFT_RETRY_USEREG_8821C) & BIT_MASK_RETRY_USEREG_8821C)
#define BIT_SET_RETRY_USEREG_8821C(x, v) \
(BIT_CLEAR_RETRY_USEREG_8821C(x) | BIT_RETRY_USEREG_8821C(v))
#define BIT_SHIFT_TRYPKT_USEREG_8821C 17
#define BIT_MASK_TRYPKT_USEREG_8821C 0x3
#define BIT_TRYPKT_USEREG_8821C(x) \
(((x) & BIT_MASK_TRYPKT_USEREG_8821C) << BIT_SHIFT_TRYPKT_USEREG_8821C)
#define BITS_TRYPKT_USEREG_8821C \
(BIT_MASK_TRYPKT_USEREG_8821C << BIT_SHIFT_TRYPKT_USEREG_8821C)
#define BIT_CLEAR_TRYPKT_USEREG_8821C(x) ((x) & (~BITS_TRYPKT_USEREG_8821C))
#define BIT_GET_TRYPKT_USEREG_8821C(x) \
(((x) >> BIT_SHIFT_TRYPKT_USEREG_8821C) & BIT_MASK_TRYPKT_USEREG_8821C)
#define BIT_SET_TRYPKT_USEREG_8821C(x, v) \
(BIT_CLEAR_TRYPKT_USEREG_8821C(x) | BIT_TRYPKT_USEREG_8821C(v))
#define BIT_CTLPKT_USEREG_8821C BIT(16)
/* 2 REG_AESIV_SETTING_8821C */
#define BIT_SHIFT_AESIV_OFFSET_8821C 0
#define BIT_MASK_AESIV_OFFSET_8821C 0xfff
#define BIT_AESIV_OFFSET_8821C(x) \
(((x) & BIT_MASK_AESIV_OFFSET_8821C) << BIT_SHIFT_AESIV_OFFSET_8821C)
#define BITS_AESIV_OFFSET_8821C \
(BIT_MASK_AESIV_OFFSET_8821C << BIT_SHIFT_AESIV_OFFSET_8821C)
#define BIT_CLEAR_AESIV_OFFSET_8821C(x) ((x) & (~BITS_AESIV_OFFSET_8821C))
#define BIT_GET_AESIV_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_AESIV_OFFSET_8821C) & BIT_MASK_AESIV_OFFSET_8821C)
#define BIT_SET_AESIV_OFFSET_8821C(x, v) \
(BIT_CLEAR_AESIV_OFFSET_8821C(x) | BIT_AESIV_OFFSET_8821C(v))
/* 2 REG_BF0_TIME_SETTING_8821C */
#define BIT_BF0_TIMER_SET_8821C BIT(31)
#define BIT_BF0_TIMER_CLR_8821C BIT(30)
#define BIT_BF0_UPDATE_EN_8821C BIT(29)
#define BIT_BF0_TIMER_EN_8821C BIT(28)
#define BIT_SHIFT_BF0_PRETIME_OVER_8821C 16
#define BIT_MASK_BF0_PRETIME_OVER_8821C 0xfff
#define BIT_BF0_PRETIME_OVER_8821C(x) \
(((x) & BIT_MASK_BF0_PRETIME_OVER_8821C) \
<< BIT_SHIFT_BF0_PRETIME_OVER_8821C)
#define BITS_BF0_PRETIME_OVER_8821C \
(BIT_MASK_BF0_PRETIME_OVER_8821C << BIT_SHIFT_BF0_PRETIME_OVER_8821C)
#define BIT_CLEAR_BF0_PRETIME_OVER_8821C(x) \
((x) & (~BITS_BF0_PRETIME_OVER_8821C))
#define BIT_GET_BF0_PRETIME_OVER_8821C(x) \
(((x) >> BIT_SHIFT_BF0_PRETIME_OVER_8821C) & \
BIT_MASK_BF0_PRETIME_OVER_8821C)
#define BIT_SET_BF0_PRETIME_OVER_8821C(x, v) \
(BIT_CLEAR_BF0_PRETIME_OVER_8821C(x) | BIT_BF0_PRETIME_OVER_8821C(v))
#define BIT_SHIFT_BF0_LIFETIME_8821C 0
#define BIT_MASK_BF0_LIFETIME_8821C 0xffff
#define BIT_BF0_LIFETIME_8821C(x) \
(((x) & BIT_MASK_BF0_LIFETIME_8821C) << BIT_SHIFT_BF0_LIFETIME_8821C)
#define BITS_BF0_LIFETIME_8821C \
(BIT_MASK_BF0_LIFETIME_8821C << BIT_SHIFT_BF0_LIFETIME_8821C)
#define BIT_CLEAR_BF0_LIFETIME_8821C(x) ((x) & (~BITS_BF0_LIFETIME_8821C))
#define BIT_GET_BF0_LIFETIME_8821C(x) \
(((x) >> BIT_SHIFT_BF0_LIFETIME_8821C) & BIT_MASK_BF0_LIFETIME_8821C)
#define BIT_SET_BF0_LIFETIME_8821C(x, v) \
(BIT_CLEAR_BF0_LIFETIME_8821C(x) | BIT_BF0_LIFETIME_8821C(v))
/* 2 REG_BF1_TIME_SETTING_8821C */
#define BIT_BF1_TIMER_SET_8821C BIT(31)
#define BIT_BF1_TIMER_CLR_8821C BIT(30)
#define BIT_BF1_UPDATE_EN_8821C BIT(29)
#define BIT_BF1_TIMER_EN_8821C BIT(28)
#define BIT_SHIFT_BF1_PRETIME_OVER_8821C 16
#define BIT_MASK_BF1_PRETIME_OVER_8821C 0xfff
#define BIT_BF1_PRETIME_OVER_8821C(x) \
(((x) & BIT_MASK_BF1_PRETIME_OVER_8821C) \
<< BIT_SHIFT_BF1_PRETIME_OVER_8821C)
#define BITS_BF1_PRETIME_OVER_8821C \
(BIT_MASK_BF1_PRETIME_OVER_8821C << BIT_SHIFT_BF1_PRETIME_OVER_8821C)
#define BIT_CLEAR_BF1_PRETIME_OVER_8821C(x) \
((x) & (~BITS_BF1_PRETIME_OVER_8821C))
#define BIT_GET_BF1_PRETIME_OVER_8821C(x) \
(((x) >> BIT_SHIFT_BF1_PRETIME_OVER_8821C) & \
BIT_MASK_BF1_PRETIME_OVER_8821C)
#define BIT_SET_BF1_PRETIME_OVER_8821C(x, v) \
(BIT_CLEAR_BF1_PRETIME_OVER_8821C(x) | BIT_BF1_PRETIME_OVER_8821C(v))
#define BIT_SHIFT_BF1_LIFETIME_8821C 0
#define BIT_MASK_BF1_LIFETIME_8821C 0xffff
#define BIT_BF1_LIFETIME_8821C(x) \
(((x) & BIT_MASK_BF1_LIFETIME_8821C) << BIT_SHIFT_BF1_LIFETIME_8821C)
#define BITS_BF1_LIFETIME_8821C \
(BIT_MASK_BF1_LIFETIME_8821C << BIT_SHIFT_BF1_LIFETIME_8821C)
#define BIT_CLEAR_BF1_LIFETIME_8821C(x) ((x) & (~BITS_BF1_LIFETIME_8821C))
#define BIT_GET_BF1_LIFETIME_8821C(x) \
(((x) >> BIT_SHIFT_BF1_LIFETIME_8821C) & BIT_MASK_BF1_LIFETIME_8821C)
#define BIT_SET_BF1_LIFETIME_8821C(x, v) \
(BIT_CLEAR_BF1_LIFETIME_8821C(x) | BIT_BF1_LIFETIME_8821C(v))
/* 2 REG_BF_TIMEOUT_EN_8821C */
#define BIT_EN_VHT_LDPC_8821C BIT(9)
#define BIT_EN_HT_LDPC_8821C BIT(8)
#define BIT_BF1_TIMEOUT_EN_8821C BIT(1)
#define BIT_BF0_TIMEOUT_EN_8821C BIT(0)
/* 2 REG_MACID_RELEASE0_8821C */
#define BIT_SHIFT_MACID31_0_RELEASE_8821C 0
#define BIT_MASK_MACID31_0_RELEASE_8821C 0xffffffffL
#define BIT_MACID31_0_RELEASE_8821C(x) \
(((x) & BIT_MASK_MACID31_0_RELEASE_8821C) \
<< BIT_SHIFT_MACID31_0_RELEASE_8821C)
#define BITS_MACID31_0_RELEASE_8821C \
(BIT_MASK_MACID31_0_RELEASE_8821C << BIT_SHIFT_MACID31_0_RELEASE_8821C)
#define BIT_CLEAR_MACID31_0_RELEASE_8821C(x) \
((x) & (~BITS_MACID31_0_RELEASE_8821C))
#define BIT_GET_MACID31_0_RELEASE_8821C(x) \
(((x) >> BIT_SHIFT_MACID31_0_RELEASE_8821C) & \
BIT_MASK_MACID31_0_RELEASE_8821C)
#define BIT_SET_MACID31_0_RELEASE_8821C(x, v) \
(BIT_CLEAR_MACID31_0_RELEASE_8821C(x) | BIT_MACID31_0_RELEASE_8821C(v))
/* 2 REG_MACID_RELEASE1_8821C */
#define BIT_SHIFT_MACID63_32_RELEASE_8821C 0
#define BIT_MASK_MACID63_32_RELEASE_8821C 0xffffffffL
#define BIT_MACID63_32_RELEASE_8821C(x) \
(((x) & BIT_MASK_MACID63_32_RELEASE_8821C) \
<< BIT_SHIFT_MACID63_32_RELEASE_8821C)
#define BITS_MACID63_32_RELEASE_8821C \
(BIT_MASK_MACID63_32_RELEASE_8821C \
<< BIT_SHIFT_MACID63_32_RELEASE_8821C)
#define BIT_CLEAR_MACID63_32_RELEASE_8821C(x) \
((x) & (~BITS_MACID63_32_RELEASE_8821C))
#define BIT_GET_MACID63_32_RELEASE_8821C(x) \
(((x) >> BIT_SHIFT_MACID63_32_RELEASE_8821C) & \
BIT_MASK_MACID63_32_RELEASE_8821C)
#define BIT_SET_MACID63_32_RELEASE_8821C(x, v) \
(BIT_CLEAR_MACID63_32_RELEASE_8821C(x) | \
BIT_MACID63_32_RELEASE_8821C(v))
/* 2 REG_MACID_RELEASE2_8821C */
#define BIT_SHIFT_MACID95_64_RELEASE_8821C 0
#define BIT_MASK_MACID95_64_RELEASE_8821C 0xffffffffL
#define BIT_MACID95_64_RELEASE_8821C(x) \
(((x) & BIT_MASK_MACID95_64_RELEASE_8821C) \
<< BIT_SHIFT_MACID95_64_RELEASE_8821C)
#define BITS_MACID95_64_RELEASE_8821C \
(BIT_MASK_MACID95_64_RELEASE_8821C \
<< BIT_SHIFT_MACID95_64_RELEASE_8821C)
#define BIT_CLEAR_MACID95_64_RELEASE_8821C(x) \
((x) & (~BITS_MACID95_64_RELEASE_8821C))
#define BIT_GET_MACID95_64_RELEASE_8821C(x) \
(((x) >> BIT_SHIFT_MACID95_64_RELEASE_8821C) & \
BIT_MASK_MACID95_64_RELEASE_8821C)
#define BIT_SET_MACID95_64_RELEASE_8821C(x, v) \
(BIT_CLEAR_MACID95_64_RELEASE_8821C(x) | \
BIT_MACID95_64_RELEASE_8821C(v))
/* 2 REG_MACID_RELEASE3_8821C */
#define BIT_SHIFT_MACID127_96_RELEASE_8821C 0
#define BIT_MASK_MACID127_96_RELEASE_8821C 0xffffffffL
#define BIT_MACID127_96_RELEASE_8821C(x) \
(((x) & BIT_MASK_MACID127_96_RELEASE_8821C) \
<< BIT_SHIFT_MACID127_96_RELEASE_8821C)
#define BITS_MACID127_96_RELEASE_8821C \
(BIT_MASK_MACID127_96_RELEASE_8821C \
<< BIT_SHIFT_MACID127_96_RELEASE_8821C)
#define BIT_CLEAR_MACID127_96_RELEASE_8821C(x) \
((x) & (~BITS_MACID127_96_RELEASE_8821C))
#define BIT_GET_MACID127_96_RELEASE_8821C(x) \
(((x) >> BIT_SHIFT_MACID127_96_RELEASE_8821C) & \
BIT_MASK_MACID127_96_RELEASE_8821C)
#define BIT_SET_MACID127_96_RELEASE_8821C(x, v) \
(BIT_CLEAR_MACID127_96_RELEASE_8821C(x) | \
BIT_MACID127_96_RELEASE_8821C(v))
/* 2 REG_MACID_RELEASE_SETTING_8821C */
#define BIT_MACID_VALUE_8821C BIT(7)
#define BIT_SHIFT_MACID_OFFSET_8821C 0
#define BIT_MASK_MACID_OFFSET_8821C 0x7f
#define BIT_MACID_OFFSET_8821C(x) \
(((x) & BIT_MASK_MACID_OFFSET_8821C) << BIT_SHIFT_MACID_OFFSET_8821C)
#define BITS_MACID_OFFSET_8821C \
(BIT_MASK_MACID_OFFSET_8821C << BIT_SHIFT_MACID_OFFSET_8821C)
#define BIT_CLEAR_MACID_OFFSET_8821C(x) ((x) & (~BITS_MACID_OFFSET_8821C))
#define BIT_GET_MACID_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_MACID_OFFSET_8821C) & BIT_MASK_MACID_OFFSET_8821C)
#define BIT_SET_MACID_OFFSET_8821C(x, v) \
(BIT_CLEAR_MACID_OFFSET_8821C(x) | BIT_MACID_OFFSET_8821C(v))
/* 2 REG_FAST_EDCA_VOVI_SETTING_8821C */
#define BIT_SHIFT_VI_FAST_EDCA_TO_8821C 24
#define BIT_MASK_VI_FAST_EDCA_TO_8821C 0xff
#define BIT_VI_FAST_EDCA_TO_8821C(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_TO_8821C) \
<< BIT_SHIFT_VI_FAST_EDCA_TO_8821C)
#define BITS_VI_FAST_EDCA_TO_8821C \
(BIT_MASK_VI_FAST_EDCA_TO_8821C << BIT_SHIFT_VI_FAST_EDCA_TO_8821C)
#define BIT_CLEAR_VI_FAST_EDCA_TO_8821C(x) ((x) & (~BITS_VI_FAST_EDCA_TO_8821C))
#define BIT_GET_VI_FAST_EDCA_TO_8821C(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_TO_8821C) & \
BIT_MASK_VI_FAST_EDCA_TO_8821C)
#define BIT_SET_VI_FAST_EDCA_TO_8821C(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_TO_8821C(x) | BIT_VI_FAST_EDCA_TO_8821C(v))
#define BIT_VI_THRESHOLD_SEL_8821C BIT(23)
#define BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8821C 16
#define BIT_MASK_VI_FAST_EDCA_PKT_TH_8821C 0x7f
#define BIT_VI_FAST_EDCA_PKT_TH_8821C(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_PKT_TH_8821C) \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8821C)
#define BITS_VI_FAST_EDCA_PKT_TH_8821C \
(BIT_MASK_VI_FAST_EDCA_PKT_TH_8821C \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8821C)
#define BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8821C(x) \
((x) & (~BITS_VI_FAST_EDCA_PKT_TH_8821C))
#define BIT_GET_VI_FAST_EDCA_PKT_TH_8821C(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8821C) & \
BIT_MASK_VI_FAST_EDCA_PKT_TH_8821C)
#define BIT_SET_VI_FAST_EDCA_PKT_TH_8821C(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8821C(x) | \
BIT_VI_FAST_EDCA_PKT_TH_8821C(v))
#define BIT_SHIFT_VO_FAST_EDCA_TO_8821C 8
#define BIT_MASK_VO_FAST_EDCA_TO_8821C 0xff
#define BIT_VO_FAST_EDCA_TO_8821C(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO_8821C) \
<< BIT_SHIFT_VO_FAST_EDCA_TO_8821C)
#define BITS_VO_FAST_EDCA_TO_8821C \
(BIT_MASK_VO_FAST_EDCA_TO_8821C << BIT_SHIFT_VO_FAST_EDCA_TO_8821C)
#define BIT_CLEAR_VO_FAST_EDCA_TO_8821C(x) ((x) & (~BITS_VO_FAST_EDCA_TO_8821C))
#define BIT_GET_VO_FAST_EDCA_TO_8821C(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO_8821C) & \
BIT_MASK_VO_FAST_EDCA_TO_8821C)
#define BIT_SET_VO_FAST_EDCA_TO_8821C(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO_8821C(x) | BIT_VO_FAST_EDCA_TO_8821C(v))
#define BIT_VO_THRESHOLD_SEL_8821C BIT(7)
#define BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8821C 0
#define BIT_MASK_VO_FAST_EDCA_PKT_TH_8821C 0x7f
#define BIT_VO_FAST_EDCA_PKT_TH_8821C(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_PKT_TH_8821C) \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8821C)
#define BITS_VO_FAST_EDCA_PKT_TH_8821C \
(BIT_MASK_VO_FAST_EDCA_PKT_TH_8821C \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8821C)
#define BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8821C(x) \
((x) & (~BITS_VO_FAST_EDCA_PKT_TH_8821C))
#define BIT_GET_VO_FAST_EDCA_PKT_TH_8821C(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8821C) & \
BIT_MASK_VO_FAST_EDCA_PKT_TH_8821C)
#define BIT_SET_VO_FAST_EDCA_PKT_TH_8821C(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8821C(x) | \
BIT_VO_FAST_EDCA_PKT_TH_8821C(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING_8821C */
#define BIT_SHIFT_BK_FAST_EDCA_TO_8821C 24
#define BIT_MASK_BK_FAST_EDCA_TO_8821C 0xff
#define BIT_BK_FAST_EDCA_TO_8821C(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_TO_8821C) \
<< BIT_SHIFT_BK_FAST_EDCA_TO_8821C)
#define BITS_BK_FAST_EDCA_TO_8821C \
(BIT_MASK_BK_FAST_EDCA_TO_8821C << BIT_SHIFT_BK_FAST_EDCA_TO_8821C)
#define BIT_CLEAR_BK_FAST_EDCA_TO_8821C(x) ((x) & (~BITS_BK_FAST_EDCA_TO_8821C))
#define BIT_GET_BK_FAST_EDCA_TO_8821C(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_TO_8821C) & \
BIT_MASK_BK_FAST_EDCA_TO_8821C)
#define BIT_SET_BK_FAST_EDCA_TO_8821C(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_TO_8821C(x) | BIT_BK_FAST_EDCA_TO_8821C(v))
#define BIT_BK_THRESHOLD_SEL_8821C BIT(23)
#define BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8821C 16
#define BIT_MASK_BK_FAST_EDCA_PKT_TH_8821C 0x7f
#define BIT_BK_FAST_EDCA_PKT_TH_8821C(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_PKT_TH_8821C) \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8821C)
#define BITS_BK_FAST_EDCA_PKT_TH_8821C \
(BIT_MASK_BK_FAST_EDCA_PKT_TH_8821C \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8821C)
#define BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8821C(x) \
((x) & (~BITS_BK_FAST_EDCA_PKT_TH_8821C))
#define BIT_GET_BK_FAST_EDCA_PKT_TH_8821C(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8821C) & \
BIT_MASK_BK_FAST_EDCA_PKT_TH_8821C)
#define BIT_SET_BK_FAST_EDCA_PKT_TH_8821C(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8821C(x) | \
BIT_BK_FAST_EDCA_PKT_TH_8821C(v))
#define BIT_SHIFT_BE_FAST_EDCA_TO_8821C 8
#define BIT_MASK_BE_FAST_EDCA_TO_8821C 0xff
#define BIT_BE_FAST_EDCA_TO_8821C(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO_8821C) \
<< BIT_SHIFT_BE_FAST_EDCA_TO_8821C)
#define BITS_BE_FAST_EDCA_TO_8821C \
(BIT_MASK_BE_FAST_EDCA_TO_8821C << BIT_SHIFT_BE_FAST_EDCA_TO_8821C)
#define BIT_CLEAR_BE_FAST_EDCA_TO_8821C(x) ((x) & (~BITS_BE_FAST_EDCA_TO_8821C))
#define BIT_GET_BE_FAST_EDCA_TO_8821C(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO_8821C) & \
BIT_MASK_BE_FAST_EDCA_TO_8821C)
#define BIT_SET_BE_FAST_EDCA_TO_8821C(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO_8821C(x) | BIT_BE_FAST_EDCA_TO_8821C(v))
#define BIT_BE_THRESHOLD_SEL_8821C BIT(7)
#define BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8821C 0
#define BIT_MASK_BE_FAST_EDCA_PKT_TH_8821C 0x7f
#define BIT_BE_FAST_EDCA_PKT_TH_8821C(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_PKT_TH_8821C) \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8821C)
#define BITS_BE_FAST_EDCA_PKT_TH_8821C \
(BIT_MASK_BE_FAST_EDCA_PKT_TH_8821C \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8821C)
#define BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8821C(x) \
((x) & (~BITS_BE_FAST_EDCA_PKT_TH_8821C))
#define BIT_GET_BE_FAST_EDCA_PKT_TH_8821C(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8821C) & \
BIT_MASK_BE_FAST_EDCA_PKT_TH_8821C)
#define BIT_SET_BE_FAST_EDCA_PKT_TH_8821C(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8821C(x) | \
BIT_BE_FAST_EDCA_PKT_TH_8821C(v))
/* 2 REG_MACID_DROP0_8821C */
#define BIT_SHIFT_MACID31_0_DROP_8821C 0
#define BIT_MASK_MACID31_0_DROP_8821C 0xffffffffL
#define BIT_MACID31_0_DROP_8821C(x) \
(((x) & BIT_MASK_MACID31_0_DROP_8821C) \
<< BIT_SHIFT_MACID31_0_DROP_8821C)
#define BITS_MACID31_0_DROP_8821C \
(BIT_MASK_MACID31_0_DROP_8821C << BIT_SHIFT_MACID31_0_DROP_8821C)
#define BIT_CLEAR_MACID31_0_DROP_8821C(x) ((x) & (~BITS_MACID31_0_DROP_8821C))
#define BIT_GET_MACID31_0_DROP_8821C(x) \
(((x) >> BIT_SHIFT_MACID31_0_DROP_8821C) & \
BIT_MASK_MACID31_0_DROP_8821C)
#define BIT_SET_MACID31_0_DROP_8821C(x, v) \
(BIT_CLEAR_MACID31_0_DROP_8821C(x) | BIT_MACID31_0_DROP_8821C(v))
/* 2 REG_MACID_DROP1_8821C */
#define BIT_SHIFT_MACID63_32_DROP_8821C 0
#define BIT_MASK_MACID63_32_DROP_8821C 0xffffffffL
#define BIT_MACID63_32_DROP_8821C(x) \
(((x) & BIT_MASK_MACID63_32_DROP_8821C) \
<< BIT_SHIFT_MACID63_32_DROP_8821C)
#define BITS_MACID63_32_DROP_8821C \
(BIT_MASK_MACID63_32_DROP_8821C << BIT_SHIFT_MACID63_32_DROP_8821C)
#define BIT_CLEAR_MACID63_32_DROP_8821C(x) ((x) & (~BITS_MACID63_32_DROP_8821C))
#define BIT_GET_MACID63_32_DROP_8821C(x) \
(((x) >> BIT_SHIFT_MACID63_32_DROP_8821C) & \
BIT_MASK_MACID63_32_DROP_8821C)
#define BIT_SET_MACID63_32_DROP_8821C(x, v) \
(BIT_CLEAR_MACID63_32_DROP_8821C(x) | BIT_MACID63_32_DROP_8821C(v))
/* 2 REG_MACID_DROP2_8821C */
#define BIT_SHIFT_MACID95_64_DROP_8821C 0
#define BIT_MASK_MACID95_64_DROP_8821C 0xffffffffL
#define BIT_MACID95_64_DROP_8821C(x) \
(((x) & BIT_MASK_MACID95_64_DROP_8821C) \
<< BIT_SHIFT_MACID95_64_DROP_8821C)
#define BITS_MACID95_64_DROP_8821C \
(BIT_MASK_MACID95_64_DROP_8821C << BIT_SHIFT_MACID95_64_DROP_8821C)
#define BIT_CLEAR_MACID95_64_DROP_8821C(x) ((x) & (~BITS_MACID95_64_DROP_8821C))
#define BIT_GET_MACID95_64_DROP_8821C(x) \
(((x) >> BIT_SHIFT_MACID95_64_DROP_8821C) & \
BIT_MASK_MACID95_64_DROP_8821C)
#define BIT_SET_MACID95_64_DROP_8821C(x, v) \
(BIT_CLEAR_MACID95_64_DROP_8821C(x) | BIT_MACID95_64_DROP_8821C(v))
/* 2 REG_MACID_DROP3_8821C */
#define BIT_SHIFT_MACID127_96_DROP_8821C 0
#define BIT_MASK_MACID127_96_DROP_8821C 0xffffffffL
#define BIT_MACID127_96_DROP_8821C(x) \
(((x) & BIT_MASK_MACID127_96_DROP_8821C) \
<< BIT_SHIFT_MACID127_96_DROP_8821C)
#define BITS_MACID127_96_DROP_8821C \
(BIT_MASK_MACID127_96_DROP_8821C << BIT_SHIFT_MACID127_96_DROP_8821C)
#define BIT_CLEAR_MACID127_96_DROP_8821C(x) \
((x) & (~BITS_MACID127_96_DROP_8821C))
#define BIT_GET_MACID127_96_DROP_8821C(x) \
(((x) >> BIT_SHIFT_MACID127_96_DROP_8821C) & \
BIT_MASK_MACID127_96_DROP_8821C)
#define BIT_SET_MACID127_96_DROP_8821C(x, v) \
(BIT_CLEAR_MACID127_96_DROP_8821C(x) | BIT_MACID127_96_DROP_8821C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_0_8821C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8821C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8821C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_0_8821C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8821C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8821C)
#define BITS_R_MACID_RELEASE_SUCCESS_0_8821C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8821C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8821C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8821C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_0_8821C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_0_8821C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8821C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8821C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_0_8821C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8821C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_0_8821C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_1_8821C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8821C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8821C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_1_8821C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8821C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8821C)
#define BITS_R_MACID_RELEASE_SUCCESS_1_8821C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8821C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8821C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8821C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_1_8821C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_1_8821C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8821C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8821C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_1_8821C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8821C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_1_8821C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_2_8821C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8821C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8821C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_2_8821C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8821C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8821C)
#define BITS_R_MACID_RELEASE_SUCCESS_2_8821C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8821C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8821C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8821C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_2_8821C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_2_8821C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8821C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8821C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_2_8821C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8821C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_2_8821C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_3_8821C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8821C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8821C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_3_8821C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8821C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8821C)
#define BITS_R_MACID_RELEASE_SUCCESS_3_8821C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8821C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8821C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8821C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_3_8821C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_3_8821C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8821C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8821C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_3_8821C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8821C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_3_8821C(v))
/* 2 REG_MGQ_FIFO_WRITE_POINTER_8821C */
#define BIT_MGQ_FIFO_OV_8821C BIT(7)
#define BIT_MGQ_FIFO_WPTR_ERROR_8821C BIT(6)
#define BIT_EN_MGQ_FIFO_LIFETIME_8821C BIT(5)
#define BIT_SHIFT_MGQ_FIFO_WPTR_8821C 0
#define BIT_MASK_MGQ_FIFO_WPTR_8821C 0x1f
#define BIT_MGQ_FIFO_WPTR_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_WPTR_8821C) << BIT_SHIFT_MGQ_FIFO_WPTR_8821C)
#define BITS_MGQ_FIFO_WPTR_8821C \
(BIT_MASK_MGQ_FIFO_WPTR_8821C << BIT_SHIFT_MGQ_FIFO_WPTR_8821C)
#define BIT_CLEAR_MGQ_FIFO_WPTR_8821C(x) ((x) & (~BITS_MGQ_FIFO_WPTR_8821C))
#define BIT_GET_MGQ_FIFO_WPTR_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_WPTR_8821C) & BIT_MASK_MGQ_FIFO_WPTR_8821C)
#define BIT_SET_MGQ_FIFO_WPTR_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_WPTR_8821C(x) | BIT_MGQ_FIFO_WPTR_8821C(v))
/* 2 REG_MGQ_FIFO_READ_POINTER_8821C */
#define BIT_SHIFT_MGQ_FIFO_SIZE_8821C 14
#define BIT_MASK_MGQ_FIFO_SIZE_8821C 0x3
#define BIT_MGQ_FIFO_SIZE_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_SIZE_8821C) << BIT_SHIFT_MGQ_FIFO_SIZE_8821C)
#define BITS_MGQ_FIFO_SIZE_8821C \
(BIT_MASK_MGQ_FIFO_SIZE_8821C << BIT_SHIFT_MGQ_FIFO_SIZE_8821C)
#define BIT_CLEAR_MGQ_FIFO_SIZE_8821C(x) ((x) & (~BITS_MGQ_FIFO_SIZE_8821C))
#define BIT_GET_MGQ_FIFO_SIZE_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_SIZE_8821C) & BIT_MASK_MGQ_FIFO_SIZE_8821C)
#define BIT_SET_MGQ_FIFO_SIZE_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_SIZE_8821C(x) | BIT_MGQ_FIFO_SIZE_8821C(v))
#define BIT_MGQ_FIFO_PAUSE_8821C BIT(13)
#define BIT_SHIFT_MGQ_FIFO_RPTR_8821C 8
#define BIT_MASK_MGQ_FIFO_RPTR_8821C 0x1f
#define BIT_MGQ_FIFO_RPTR_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_RPTR_8821C) << BIT_SHIFT_MGQ_FIFO_RPTR_8821C)
#define BITS_MGQ_FIFO_RPTR_8821C \
(BIT_MASK_MGQ_FIFO_RPTR_8821C << BIT_SHIFT_MGQ_FIFO_RPTR_8821C)
#define BIT_CLEAR_MGQ_FIFO_RPTR_8821C(x) ((x) & (~BITS_MGQ_FIFO_RPTR_8821C))
#define BIT_GET_MGQ_FIFO_RPTR_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_RPTR_8821C) & BIT_MASK_MGQ_FIFO_RPTR_8821C)
#define BIT_SET_MGQ_FIFO_RPTR_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_RPTR_8821C(x) | BIT_MGQ_FIFO_RPTR_8821C(v))
/* 2 REG_MGQ_FIFO_ENABLE_8821C */
#define BIT_MGQ_FIFO_EN_8821C BIT(15)
#define BIT_SHIFT_MGQ_FIFO_PG_SIZE_8821C 12
#define BIT_MASK_MGQ_FIFO_PG_SIZE_8821C 0x7
#define BIT_MGQ_FIFO_PG_SIZE_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_PG_SIZE_8821C) \
<< BIT_SHIFT_MGQ_FIFO_PG_SIZE_8821C)
#define BITS_MGQ_FIFO_PG_SIZE_8821C \
(BIT_MASK_MGQ_FIFO_PG_SIZE_8821C << BIT_SHIFT_MGQ_FIFO_PG_SIZE_8821C)
#define BIT_CLEAR_MGQ_FIFO_PG_SIZE_8821C(x) \
((x) & (~BITS_MGQ_FIFO_PG_SIZE_8821C))
#define BIT_GET_MGQ_FIFO_PG_SIZE_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PG_SIZE_8821C) & \
BIT_MASK_MGQ_FIFO_PG_SIZE_8821C)
#define BIT_SET_MGQ_FIFO_PG_SIZE_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_PG_SIZE_8821C(x) | BIT_MGQ_FIFO_PG_SIZE_8821C(v))
#define BIT_SHIFT_MGQ_FIFO_START_PG_8821C 0
#define BIT_MASK_MGQ_FIFO_START_PG_8821C 0xfff
#define BIT_MGQ_FIFO_START_PG_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_START_PG_8821C) \
<< BIT_SHIFT_MGQ_FIFO_START_PG_8821C)
#define BITS_MGQ_FIFO_START_PG_8821C \
(BIT_MASK_MGQ_FIFO_START_PG_8821C << BIT_SHIFT_MGQ_FIFO_START_PG_8821C)
#define BIT_CLEAR_MGQ_FIFO_START_PG_8821C(x) \
((x) & (~BITS_MGQ_FIFO_START_PG_8821C))
#define BIT_GET_MGQ_FIFO_START_PG_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_START_PG_8821C) & \
BIT_MASK_MGQ_FIFO_START_PG_8821C)
#define BIT_SET_MGQ_FIFO_START_PG_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_START_PG_8821C(x) | BIT_MGQ_FIFO_START_PG_8821C(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_MASK_8821C */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8821C 0
#define BIT_MASK_MGQ_FIFO_REL_INT_MASK_8821C 0xffff
#define BIT_MGQ_FIFO_REL_INT_MASK_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_MASK_8821C) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8821C)
#define BITS_MGQ_FIFO_REL_INT_MASK_8821C \
(BIT_MASK_MGQ_FIFO_REL_INT_MASK_8821C \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8821C)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_MASK_8821C(x) \
((x) & (~BITS_MGQ_FIFO_REL_INT_MASK_8821C))
#define BIT_GET_MGQ_FIFO_REL_INT_MASK_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8821C) & \
BIT_MASK_MGQ_FIFO_REL_INT_MASK_8821C)
#define BIT_SET_MGQ_FIFO_REL_INT_MASK_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_MASK_8821C(x) | \
BIT_MGQ_FIFO_REL_INT_MASK_8821C(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_FLAG_8821C */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8821C 0
#define BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8821C 0xffff
#define BIT_MGQ_FIFO_REL_INT_FLAG_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8821C) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8821C)
#define BITS_MGQ_FIFO_REL_INT_FLAG_8821C \
(BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8821C \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8821C)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG_8821C(x) \
((x) & (~BITS_MGQ_FIFO_REL_INT_FLAG_8821C))
#define BIT_GET_MGQ_FIFO_REL_INT_FLAG_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8821C) & \
BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8821C)
#define BIT_SET_MGQ_FIFO_REL_INT_FLAG_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG_8821C(x) | \
BIT_MGQ_FIFO_REL_INT_FLAG_8821C(v))
/* 2 REG_MGQ_FIFO_VALID_MAP_8821C */
#define BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8821C 0
#define BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8821C 0xffff
#define BIT_MGQ_FIFO_PKT_VALID_MAP_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8821C) \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8821C)
#define BITS_MGQ_FIFO_PKT_VALID_MAP_8821C \
(BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8821C \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8821C)
#define BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP_8821C(x) \
((x) & (~BITS_MGQ_FIFO_PKT_VALID_MAP_8821C))
#define BIT_GET_MGQ_FIFO_PKT_VALID_MAP_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8821C) & \
BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8821C)
#define BIT_SET_MGQ_FIFO_PKT_VALID_MAP_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP_8821C(x) | \
BIT_MGQ_FIFO_PKT_VALID_MAP_8821C(v))
/* 2 REG_MGQ_FIFO_LIFETIME_8821C */
#define BIT_SHIFT_MGQ_FIFO_LIFETIME_8821C 0
#define BIT_MASK_MGQ_FIFO_LIFETIME_8821C 0xffff
#define BIT_MGQ_FIFO_LIFETIME_8821C(x) \
(((x) & BIT_MASK_MGQ_FIFO_LIFETIME_8821C) \
<< BIT_SHIFT_MGQ_FIFO_LIFETIME_8821C)
#define BITS_MGQ_FIFO_LIFETIME_8821C \
(BIT_MASK_MGQ_FIFO_LIFETIME_8821C << BIT_SHIFT_MGQ_FIFO_LIFETIME_8821C)
#define BIT_CLEAR_MGQ_FIFO_LIFETIME_8821C(x) \
((x) & (~BITS_MGQ_FIFO_LIFETIME_8821C))
#define BIT_GET_MGQ_FIFO_LIFETIME_8821C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_LIFETIME_8821C) & \
BIT_MASK_MGQ_FIFO_LIFETIME_8821C)
#define BIT_SET_MGQ_FIFO_LIFETIME_8821C(x, v) \
(BIT_CLEAR_MGQ_FIFO_LIFETIME_8821C(x) | BIT_MGQ_FIFO_LIFETIME_8821C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C 0x7f
#define BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C)
#define BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C(v))
/* 2 REG_SHCUT_SETTING_8821C */
/* 2 REG_SHCUT_LLC_ETH_TYPE0_8821C */
/* 2 REG_SHCUT_LLC_ETH_TYPE1_8821C */
/* 2 REG_SHCUT_LLC_OUI0_8821C */
/* 2 REG_SHCUT_LLC_OUI1_8821C */
/* 2 REG_SHCUT_LLC_OUI2_8821C */
/* 2 REG_MU_TX_CTL_8821C */
#define BIT_R_MU_P1_WAIT_STATE_EN_8821C BIT(16)
#define BIT_SHIFT_R_MU_RL_8821C 12
#define BIT_MASK_R_MU_RL_8821C 0xf
#define BIT_R_MU_RL_8821C(x) \
(((x) & BIT_MASK_R_MU_RL_8821C) << BIT_SHIFT_R_MU_RL_8821C)
#define BITS_R_MU_RL_8821C (BIT_MASK_R_MU_RL_8821C << BIT_SHIFT_R_MU_RL_8821C)
#define BIT_CLEAR_R_MU_RL_8821C(x) ((x) & (~BITS_R_MU_RL_8821C))
#define BIT_GET_R_MU_RL_8821C(x) \
(((x) >> BIT_SHIFT_R_MU_RL_8821C) & BIT_MASK_R_MU_RL_8821C)
#define BIT_SET_R_MU_RL_8821C(x, v) \
(BIT_CLEAR_R_MU_RL_8821C(x) | BIT_R_MU_RL_8821C(v))
#define BIT_R_FORCE_P1_RATEDOWN_8821C BIT(11)
#define BIT_SHIFT_R_MU_TAB_SEL_8821C 8
#define BIT_MASK_R_MU_TAB_SEL_8821C 0x7
#define BIT_R_MU_TAB_SEL_8821C(x) \
(((x) & BIT_MASK_R_MU_TAB_SEL_8821C) << BIT_SHIFT_R_MU_TAB_SEL_8821C)
#define BITS_R_MU_TAB_SEL_8821C \
(BIT_MASK_R_MU_TAB_SEL_8821C << BIT_SHIFT_R_MU_TAB_SEL_8821C)
#define BIT_CLEAR_R_MU_TAB_SEL_8821C(x) ((x) & (~BITS_R_MU_TAB_SEL_8821C))
#define BIT_GET_R_MU_TAB_SEL_8821C(x) \
(((x) >> BIT_SHIFT_R_MU_TAB_SEL_8821C) & BIT_MASK_R_MU_TAB_SEL_8821C)
#define BIT_SET_R_MU_TAB_SEL_8821C(x, v) \
(BIT_CLEAR_R_MU_TAB_SEL_8821C(x) | BIT_R_MU_TAB_SEL_8821C(v))
#define BIT_R_EN_MU_MIMO_8821C BIT(7)
#define BIT_R_EN_REVERS_GTAB_8821C BIT(6)
#define BIT_SHIFT_R_MU_TABLE_VALID_8821C 0
#define BIT_MASK_R_MU_TABLE_VALID_8821C 0x3f
#define BIT_R_MU_TABLE_VALID_8821C(x) \
(((x) & BIT_MASK_R_MU_TABLE_VALID_8821C) \
<< BIT_SHIFT_R_MU_TABLE_VALID_8821C)
#define BITS_R_MU_TABLE_VALID_8821C \
(BIT_MASK_R_MU_TABLE_VALID_8821C << BIT_SHIFT_R_MU_TABLE_VALID_8821C)
#define BIT_CLEAR_R_MU_TABLE_VALID_8821C(x) \
((x) & (~BITS_R_MU_TABLE_VALID_8821C))
#define BIT_GET_R_MU_TABLE_VALID_8821C(x) \
(((x) >> BIT_SHIFT_R_MU_TABLE_VALID_8821C) & \
BIT_MASK_R_MU_TABLE_VALID_8821C)
#define BIT_SET_R_MU_TABLE_VALID_8821C(x, v) \
(BIT_CLEAR_R_MU_TABLE_VALID_8821C(x) | BIT_R_MU_TABLE_VALID_8821C(v))
/* 2 REG_MU_STA_GID_VLD_8821C */
#define BIT_SHIFT_R_MU_STA_GTAB_VALID_8821C 0
#define BIT_MASK_R_MU_STA_GTAB_VALID_8821C 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID_8821C(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID_8821C) \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8821C)
#define BITS_R_MU_STA_GTAB_VALID_8821C \
(BIT_MASK_R_MU_STA_GTAB_VALID_8821C \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8821C)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID_8821C(x) \
((x) & (~BITS_R_MU_STA_GTAB_VALID_8821C))
#define BIT_GET_R_MU_STA_GTAB_VALID_8821C(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID_8821C) & \
BIT_MASK_R_MU_STA_GTAB_VALID_8821C)
#define BIT_SET_R_MU_STA_GTAB_VALID_8821C(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID_8821C(x) | \
BIT_R_MU_STA_GTAB_VALID_8821C(v))
/* 2 REG_MU_STA_USER_POS_INFO_8821C */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8821C 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_L_8821C 0xffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_L_8821C(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_L_8821C) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8821C)
#define BITS_R_MU_STA_GTAB_POSITION_L_8821C \
(BIT_MASK_R_MU_STA_GTAB_POSITION_L_8821C \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8821C)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_L_8821C(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_L_8821C))
#define BIT_GET_R_MU_STA_GTAB_POSITION_L_8821C(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8821C) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_L_8821C)
#define BIT_SET_R_MU_STA_GTAB_POSITION_L_8821C(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_L_8821C(x) | \
BIT_R_MU_STA_GTAB_POSITION_L_8821C(v))
/* 2 REG_MU_STA_USER_POS_INFO_H_8821C */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8821C 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_H_8821C 0xffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_H_8821C(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_H_8821C) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8821C)
#define BITS_R_MU_STA_GTAB_POSITION_H_8821C \
(BIT_MASK_R_MU_STA_GTAB_POSITION_H_8821C \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8821C)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_H_8821C(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_H_8821C))
#define BIT_GET_R_MU_STA_GTAB_POSITION_H_8821C(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8821C) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_H_8821C)
#define BIT_SET_R_MU_STA_GTAB_POSITION_H_8821C(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_H_8821C(x) | \
BIT_R_MU_STA_GTAB_POSITION_H_8821C(v))
/* 2 REG_MU_TRX_DBG_CNT_8821C */
#define BIT_MU_DNGCNT_RST_8821C BIT(20)
#define BIT_SHIFT_MU_DBGCNT_SEL_8821C 16
#define BIT_MASK_MU_DBGCNT_SEL_8821C 0xf
#define BIT_MU_DBGCNT_SEL_8821C(x) \
(((x) & BIT_MASK_MU_DBGCNT_SEL_8821C) << BIT_SHIFT_MU_DBGCNT_SEL_8821C)
#define BITS_MU_DBGCNT_SEL_8821C \
(BIT_MASK_MU_DBGCNT_SEL_8821C << BIT_SHIFT_MU_DBGCNT_SEL_8821C)
#define BIT_CLEAR_MU_DBGCNT_SEL_8821C(x) ((x) & (~BITS_MU_DBGCNT_SEL_8821C))
#define BIT_GET_MU_DBGCNT_SEL_8821C(x) \
(((x) >> BIT_SHIFT_MU_DBGCNT_SEL_8821C) & BIT_MASK_MU_DBGCNT_SEL_8821C)
#define BIT_SET_MU_DBGCNT_SEL_8821C(x, v) \
(BIT_CLEAR_MU_DBGCNT_SEL_8821C(x) | BIT_MU_DBGCNT_SEL_8821C(v))
#define BIT_SHIFT_MU_DNGCNT_8821C 0
#define BIT_MASK_MU_DNGCNT_8821C 0xffff
#define BIT_MU_DNGCNT_8821C(x) \
(((x) & BIT_MASK_MU_DNGCNT_8821C) << BIT_SHIFT_MU_DNGCNT_8821C)
#define BITS_MU_DNGCNT_8821C \
(BIT_MASK_MU_DNGCNT_8821C << BIT_SHIFT_MU_DNGCNT_8821C)
#define BIT_CLEAR_MU_DNGCNT_8821C(x) ((x) & (~BITS_MU_DNGCNT_8821C))
#define BIT_GET_MU_DNGCNT_8821C(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_8821C) & BIT_MASK_MU_DNGCNT_8821C)
#define BIT_SET_MU_DNGCNT_8821C(x, v) \
(BIT_CLEAR_MU_DNGCNT_8821C(x) | BIT_MU_DNGCNT_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_EDCA_VO_PARAM_8821C */
#define BIT_SHIFT_TXOPLIMIT_8821C 16
#define BIT_MASK_TXOPLIMIT_8821C 0x7ff
#define BIT_TXOPLIMIT_8821C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8821C) << BIT_SHIFT_TXOPLIMIT_8821C)
#define BITS_TXOPLIMIT_8821C \
(BIT_MASK_TXOPLIMIT_8821C << BIT_SHIFT_TXOPLIMIT_8821C)
#define BIT_CLEAR_TXOPLIMIT_8821C(x) ((x) & (~BITS_TXOPLIMIT_8821C))
#define BIT_GET_TXOPLIMIT_8821C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8821C) & BIT_MASK_TXOPLIMIT_8821C)
#define BIT_SET_TXOPLIMIT_8821C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8821C(x) | BIT_TXOPLIMIT_8821C(v))
#define BIT_SHIFT_CW_8821C 8
#define BIT_MASK_CW_8821C 0xff
#define BIT_CW_8821C(x) (((x) & BIT_MASK_CW_8821C) << BIT_SHIFT_CW_8821C)
#define BITS_CW_8821C (BIT_MASK_CW_8821C << BIT_SHIFT_CW_8821C)
#define BIT_CLEAR_CW_8821C(x) ((x) & (~BITS_CW_8821C))
#define BIT_GET_CW_8821C(x) (((x) >> BIT_SHIFT_CW_8821C) & BIT_MASK_CW_8821C)
#define BIT_SET_CW_8821C(x, v) (BIT_CLEAR_CW_8821C(x) | BIT_CW_8821C(v))
#define BIT_SHIFT_AIFS_8821C 0
#define BIT_MASK_AIFS_8821C 0xff
#define BIT_AIFS_8821C(x) (((x) & BIT_MASK_AIFS_8821C) << BIT_SHIFT_AIFS_8821C)
#define BITS_AIFS_8821C (BIT_MASK_AIFS_8821C << BIT_SHIFT_AIFS_8821C)
#define BIT_CLEAR_AIFS_8821C(x) ((x) & (~BITS_AIFS_8821C))
#define BIT_GET_AIFS_8821C(x) \
(((x) >> BIT_SHIFT_AIFS_8821C) & BIT_MASK_AIFS_8821C)
#define BIT_SET_AIFS_8821C(x, v) (BIT_CLEAR_AIFS_8821C(x) | BIT_AIFS_8821C(v))
/* 2 REG_EDCA_VI_PARAM_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_TXOPLIMIT_8821C 16
#define BIT_MASK_TXOPLIMIT_8821C 0x7ff
#define BIT_TXOPLIMIT_8821C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8821C) << BIT_SHIFT_TXOPLIMIT_8821C)
#define BITS_TXOPLIMIT_8821C \
(BIT_MASK_TXOPLIMIT_8821C << BIT_SHIFT_TXOPLIMIT_8821C)
#define BIT_CLEAR_TXOPLIMIT_8821C(x) ((x) & (~BITS_TXOPLIMIT_8821C))
#define BIT_GET_TXOPLIMIT_8821C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8821C) & BIT_MASK_TXOPLIMIT_8821C)
#define BIT_SET_TXOPLIMIT_8821C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8821C(x) | BIT_TXOPLIMIT_8821C(v))
#define BIT_SHIFT_CW_8821C 8
#define BIT_MASK_CW_8821C 0xff
#define BIT_CW_8821C(x) (((x) & BIT_MASK_CW_8821C) << BIT_SHIFT_CW_8821C)
#define BITS_CW_8821C (BIT_MASK_CW_8821C << BIT_SHIFT_CW_8821C)
#define BIT_CLEAR_CW_8821C(x) ((x) & (~BITS_CW_8821C))
#define BIT_GET_CW_8821C(x) (((x) >> BIT_SHIFT_CW_8821C) & BIT_MASK_CW_8821C)
#define BIT_SET_CW_8821C(x, v) (BIT_CLEAR_CW_8821C(x) | BIT_CW_8821C(v))
#define BIT_SHIFT_AIFS_8821C 0
#define BIT_MASK_AIFS_8821C 0xff
#define BIT_AIFS_8821C(x) (((x) & BIT_MASK_AIFS_8821C) << BIT_SHIFT_AIFS_8821C)
#define BITS_AIFS_8821C (BIT_MASK_AIFS_8821C << BIT_SHIFT_AIFS_8821C)
#define BIT_CLEAR_AIFS_8821C(x) ((x) & (~BITS_AIFS_8821C))
#define BIT_GET_AIFS_8821C(x) \
(((x) >> BIT_SHIFT_AIFS_8821C) & BIT_MASK_AIFS_8821C)
#define BIT_SET_AIFS_8821C(x, v) (BIT_CLEAR_AIFS_8821C(x) | BIT_AIFS_8821C(v))
/* 2 REG_EDCA_BE_PARAM_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_TXOPLIMIT_8821C 16
#define BIT_MASK_TXOPLIMIT_8821C 0x7ff
#define BIT_TXOPLIMIT_8821C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8821C) << BIT_SHIFT_TXOPLIMIT_8821C)
#define BITS_TXOPLIMIT_8821C \
(BIT_MASK_TXOPLIMIT_8821C << BIT_SHIFT_TXOPLIMIT_8821C)
#define BIT_CLEAR_TXOPLIMIT_8821C(x) ((x) & (~BITS_TXOPLIMIT_8821C))
#define BIT_GET_TXOPLIMIT_8821C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8821C) & BIT_MASK_TXOPLIMIT_8821C)
#define BIT_SET_TXOPLIMIT_8821C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8821C(x) | BIT_TXOPLIMIT_8821C(v))
#define BIT_SHIFT_CW_8821C 8
#define BIT_MASK_CW_8821C 0xff
#define BIT_CW_8821C(x) (((x) & BIT_MASK_CW_8821C) << BIT_SHIFT_CW_8821C)
#define BITS_CW_8821C (BIT_MASK_CW_8821C << BIT_SHIFT_CW_8821C)
#define BIT_CLEAR_CW_8821C(x) ((x) & (~BITS_CW_8821C))
#define BIT_GET_CW_8821C(x) (((x) >> BIT_SHIFT_CW_8821C) & BIT_MASK_CW_8821C)
#define BIT_SET_CW_8821C(x, v) (BIT_CLEAR_CW_8821C(x) | BIT_CW_8821C(v))
#define BIT_SHIFT_AIFS_8821C 0
#define BIT_MASK_AIFS_8821C 0xff
#define BIT_AIFS_8821C(x) (((x) & BIT_MASK_AIFS_8821C) << BIT_SHIFT_AIFS_8821C)
#define BITS_AIFS_8821C (BIT_MASK_AIFS_8821C << BIT_SHIFT_AIFS_8821C)
#define BIT_CLEAR_AIFS_8821C(x) ((x) & (~BITS_AIFS_8821C))
#define BIT_GET_AIFS_8821C(x) \
(((x) >> BIT_SHIFT_AIFS_8821C) & BIT_MASK_AIFS_8821C)
#define BIT_SET_AIFS_8821C(x, v) (BIT_CLEAR_AIFS_8821C(x) | BIT_AIFS_8821C(v))
/* 2 REG_EDCA_BK_PARAM_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_TXOPLIMIT_8821C 16
#define BIT_MASK_TXOPLIMIT_8821C 0x7ff
#define BIT_TXOPLIMIT_8821C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8821C) << BIT_SHIFT_TXOPLIMIT_8821C)
#define BITS_TXOPLIMIT_8821C \
(BIT_MASK_TXOPLIMIT_8821C << BIT_SHIFT_TXOPLIMIT_8821C)
#define BIT_CLEAR_TXOPLIMIT_8821C(x) ((x) & (~BITS_TXOPLIMIT_8821C))
#define BIT_GET_TXOPLIMIT_8821C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8821C) & BIT_MASK_TXOPLIMIT_8821C)
#define BIT_SET_TXOPLIMIT_8821C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8821C(x) | BIT_TXOPLIMIT_8821C(v))
#define BIT_SHIFT_CW_8821C 8
#define BIT_MASK_CW_8821C 0xff
#define BIT_CW_8821C(x) (((x) & BIT_MASK_CW_8821C) << BIT_SHIFT_CW_8821C)
#define BITS_CW_8821C (BIT_MASK_CW_8821C << BIT_SHIFT_CW_8821C)
#define BIT_CLEAR_CW_8821C(x) ((x) & (~BITS_CW_8821C))
#define BIT_GET_CW_8821C(x) (((x) >> BIT_SHIFT_CW_8821C) & BIT_MASK_CW_8821C)
#define BIT_SET_CW_8821C(x, v) (BIT_CLEAR_CW_8821C(x) | BIT_CW_8821C(v))
#define BIT_SHIFT_AIFS_8821C 0
#define BIT_MASK_AIFS_8821C 0xff
#define BIT_AIFS_8821C(x) (((x) & BIT_MASK_AIFS_8821C) << BIT_SHIFT_AIFS_8821C)
#define BITS_AIFS_8821C (BIT_MASK_AIFS_8821C << BIT_SHIFT_AIFS_8821C)
#define BIT_CLEAR_AIFS_8821C(x) ((x) & (~BITS_AIFS_8821C))
#define BIT_GET_AIFS_8821C(x) \
(((x) >> BIT_SHIFT_AIFS_8821C) & BIT_MASK_AIFS_8821C)
#define BIT_SET_AIFS_8821C(x, v) (BIT_CLEAR_AIFS_8821C(x) | BIT_AIFS_8821C(v))
/* 2 REG_BCNTCFG_8821C */
#define BIT_SHIFT_BCNCW_MAX_8821C 12
#define BIT_MASK_BCNCW_MAX_8821C 0xf
#define BIT_BCNCW_MAX_8821C(x) \
(((x) & BIT_MASK_BCNCW_MAX_8821C) << BIT_SHIFT_BCNCW_MAX_8821C)
#define BITS_BCNCW_MAX_8821C \
(BIT_MASK_BCNCW_MAX_8821C << BIT_SHIFT_BCNCW_MAX_8821C)
#define BIT_CLEAR_BCNCW_MAX_8821C(x) ((x) & (~BITS_BCNCW_MAX_8821C))
#define BIT_GET_BCNCW_MAX_8821C(x) \
(((x) >> BIT_SHIFT_BCNCW_MAX_8821C) & BIT_MASK_BCNCW_MAX_8821C)
#define BIT_SET_BCNCW_MAX_8821C(x, v) \
(BIT_CLEAR_BCNCW_MAX_8821C(x) | BIT_BCNCW_MAX_8821C(v))
#define BIT_SHIFT_BCNCW_MIN_8821C 8
#define BIT_MASK_BCNCW_MIN_8821C 0xf
#define BIT_BCNCW_MIN_8821C(x) \
(((x) & BIT_MASK_BCNCW_MIN_8821C) << BIT_SHIFT_BCNCW_MIN_8821C)
#define BITS_BCNCW_MIN_8821C \
(BIT_MASK_BCNCW_MIN_8821C << BIT_SHIFT_BCNCW_MIN_8821C)
#define BIT_CLEAR_BCNCW_MIN_8821C(x) ((x) & (~BITS_BCNCW_MIN_8821C))
#define BIT_GET_BCNCW_MIN_8821C(x) \
(((x) >> BIT_SHIFT_BCNCW_MIN_8821C) & BIT_MASK_BCNCW_MIN_8821C)
#define BIT_SET_BCNCW_MIN_8821C(x, v) \
(BIT_CLEAR_BCNCW_MIN_8821C(x) | BIT_BCNCW_MIN_8821C(v))
#define BIT_SHIFT_BCNIFS_8821C 0
#define BIT_MASK_BCNIFS_8821C 0xff
#define BIT_BCNIFS_8821C(x) \
(((x) & BIT_MASK_BCNIFS_8821C) << BIT_SHIFT_BCNIFS_8821C)
#define BITS_BCNIFS_8821C (BIT_MASK_BCNIFS_8821C << BIT_SHIFT_BCNIFS_8821C)
#define BIT_CLEAR_BCNIFS_8821C(x) ((x) & (~BITS_BCNIFS_8821C))
#define BIT_GET_BCNIFS_8821C(x) \
(((x) >> BIT_SHIFT_BCNIFS_8821C) & BIT_MASK_BCNIFS_8821C)
#define BIT_SET_BCNIFS_8821C(x, v) \
(BIT_CLEAR_BCNIFS_8821C(x) | BIT_BCNIFS_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_PIFS_8821C */
#define BIT_SHIFT_PIFS_8821C 0
#define BIT_MASK_PIFS_8821C 0xff
#define BIT_PIFS_8821C(x) (((x) & BIT_MASK_PIFS_8821C) << BIT_SHIFT_PIFS_8821C)
#define BITS_PIFS_8821C (BIT_MASK_PIFS_8821C << BIT_SHIFT_PIFS_8821C)
#define BIT_CLEAR_PIFS_8821C(x) ((x) & (~BITS_PIFS_8821C))
#define BIT_GET_PIFS_8821C(x) \
(((x) >> BIT_SHIFT_PIFS_8821C) & BIT_MASK_PIFS_8821C)
#define BIT_SET_PIFS_8821C(x, v) (BIT_CLEAR_PIFS_8821C(x) | BIT_PIFS_8821C(v))
/* 2 REG_RDG_PIFS_8821C */
#define BIT_SHIFT_RDG_PIFS_8821C 0
#define BIT_MASK_RDG_PIFS_8821C 0xff
#define BIT_RDG_PIFS_8821C(x) \
(((x) & BIT_MASK_RDG_PIFS_8821C) << BIT_SHIFT_RDG_PIFS_8821C)
#define BITS_RDG_PIFS_8821C \
(BIT_MASK_RDG_PIFS_8821C << BIT_SHIFT_RDG_PIFS_8821C)
#define BIT_CLEAR_RDG_PIFS_8821C(x) ((x) & (~BITS_RDG_PIFS_8821C))
#define BIT_GET_RDG_PIFS_8821C(x) \
(((x) >> BIT_SHIFT_RDG_PIFS_8821C) & BIT_MASK_RDG_PIFS_8821C)
#define BIT_SET_RDG_PIFS_8821C(x, v) \
(BIT_CLEAR_RDG_PIFS_8821C(x) | BIT_RDG_PIFS_8821C(v))
/* 2 REG_SIFS_8821C */
#define BIT_SHIFT_SIFS_OFDM_TRX_8821C 24
#define BIT_MASK_SIFS_OFDM_TRX_8821C 0xff
#define BIT_SIFS_OFDM_TRX_8821C(x) \
(((x) & BIT_MASK_SIFS_OFDM_TRX_8821C) << BIT_SHIFT_SIFS_OFDM_TRX_8821C)
#define BITS_SIFS_OFDM_TRX_8821C \
(BIT_MASK_SIFS_OFDM_TRX_8821C << BIT_SHIFT_SIFS_OFDM_TRX_8821C)
#define BIT_CLEAR_SIFS_OFDM_TRX_8821C(x) ((x) & (~BITS_SIFS_OFDM_TRX_8821C))
#define BIT_GET_SIFS_OFDM_TRX_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_TRX_8821C) & BIT_MASK_SIFS_OFDM_TRX_8821C)
#define BIT_SET_SIFS_OFDM_TRX_8821C(x, v) \
(BIT_CLEAR_SIFS_OFDM_TRX_8821C(x) | BIT_SIFS_OFDM_TRX_8821C(v))
#define BIT_SHIFT_SIFS_CCK_TRX_8821C 16
#define BIT_MASK_SIFS_CCK_TRX_8821C 0xff
#define BIT_SIFS_CCK_TRX_8821C(x) \
(((x) & BIT_MASK_SIFS_CCK_TRX_8821C) << BIT_SHIFT_SIFS_CCK_TRX_8821C)
#define BITS_SIFS_CCK_TRX_8821C \
(BIT_MASK_SIFS_CCK_TRX_8821C << BIT_SHIFT_SIFS_CCK_TRX_8821C)
#define BIT_CLEAR_SIFS_CCK_TRX_8821C(x) ((x) & (~BITS_SIFS_CCK_TRX_8821C))
#define BIT_GET_SIFS_CCK_TRX_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_TRX_8821C) & BIT_MASK_SIFS_CCK_TRX_8821C)
#define BIT_SET_SIFS_CCK_TRX_8821C(x, v) \
(BIT_CLEAR_SIFS_CCK_TRX_8821C(x) | BIT_SIFS_CCK_TRX_8821C(v))
#define BIT_SHIFT_SIFS_OFDM_CTX_8821C 8
#define BIT_MASK_SIFS_OFDM_CTX_8821C 0xff
#define BIT_SIFS_OFDM_CTX_8821C(x) \
(((x) & BIT_MASK_SIFS_OFDM_CTX_8821C) << BIT_SHIFT_SIFS_OFDM_CTX_8821C)
#define BITS_SIFS_OFDM_CTX_8821C \
(BIT_MASK_SIFS_OFDM_CTX_8821C << BIT_SHIFT_SIFS_OFDM_CTX_8821C)
#define BIT_CLEAR_SIFS_OFDM_CTX_8821C(x) ((x) & (~BITS_SIFS_OFDM_CTX_8821C))
#define BIT_GET_SIFS_OFDM_CTX_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_CTX_8821C) & BIT_MASK_SIFS_OFDM_CTX_8821C)
#define BIT_SET_SIFS_OFDM_CTX_8821C(x, v) \
(BIT_CLEAR_SIFS_OFDM_CTX_8821C(x) | BIT_SIFS_OFDM_CTX_8821C(v))
#define BIT_SHIFT_SIFS_CCK_CTX_8821C 0
#define BIT_MASK_SIFS_CCK_CTX_8821C 0xff
#define BIT_SIFS_CCK_CTX_8821C(x) \
(((x) & BIT_MASK_SIFS_CCK_CTX_8821C) << BIT_SHIFT_SIFS_CCK_CTX_8821C)
#define BITS_SIFS_CCK_CTX_8821C \
(BIT_MASK_SIFS_CCK_CTX_8821C << BIT_SHIFT_SIFS_CCK_CTX_8821C)
#define BIT_CLEAR_SIFS_CCK_CTX_8821C(x) ((x) & (~BITS_SIFS_CCK_CTX_8821C))
#define BIT_GET_SIFS_CCK_CTX_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_CTX_8821C) & BIT_MASK_SIFS_CCK_CTX_8821C)
#define BIT_SET_SIFS_CCK_CTX_8821C(x, v) \
(BIT_CLEAR_SIFS_CCK_CTX_8821C(x) | BIT_SIFS_CCK_CTX_8821C(v))
/* 2 REG_TSFTR_SYN_OFFSET_8821C */
#define BIT_SHIFT_TSFTR_SNC_OFFSET_8821C 0
#define BIT_MASK_TSFTR_SNC_OFFSET_8821C 0xffff
#define BIT_TSFTR_SNC_OFFSET_8821C(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET_8821C) \
<< BIT_SHIFT_TSFTR_SNC_OFFSET_8821C)
#define BITS_TSFTR_SNC_OFFSET_8821C \
(BIT_MASK_TSFTR_SNC_OFFSET_8821C << BIT_SHIFT_TSFTR_SNC_OFFSET_8821C)
#define BIT_CLEAR_TSFTR_SNC_OFFSET_8821C(x) \
((x) & (~BITS_TSFTR_SNC_OFFSET_8821C))
#define BIT_GET_TSFTR_SNC_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET_8821C) & \
BIT_MASK_TSFTR_SNC_OFFSET_8821C)
#define BIT_SET_TSFTR_SNC_OFFSET_8821C(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET_8821C(x) | BIT_TSFTR_SNC_OFFSET_8821C(v))
/* 2 REG_AGGR_BREAK_TIME_8821C */
#define BIT_SHIFT_AGGR_BK_TIME_8821C 0
#define BIT_MASK_AGGR_BK_TIME_8821C 0xff
#define BIT_AGGR_BK_TIME_8821C(x) \
(((x) & BIT_MASK_AGGR_BK_TIME_8821C) << BIT_SHIFT_AGGR_BK_TIME_8821C)
#define BITS_AGGR_BK_TIME_8821C \
(BIT_MASK_AGGR_BK_TIME_8821C << BIT_SHIFT_AGGR_BK_TIME_8821C)
#define BIT_CLEAR_AGGR_BK_TIME_8821C(x) ((x) & (~BITS_AGGR_BK_TIME_8821C))
#define BIT_GET_AGGR_BK_TIME_8821C(x) \
(((x) >> BIT_SHIFT_AGGR_BK_TIME_8821C) & BIT_MASK_AGGR_BK_TIME_8821C)
#define BIT_SET_AGGR_BK_TIME_8821C(x, v) \
(BIT_CLEAR_AGGR_BK_TIME_8821C(x) | BIT_AGGR_BK_TIME_8821C(v))
/* 2 REG_SLOT_8821C */
#define BIT_SHIFT_SLOT_8821C 0
#define BIT_MASK_SLOT_8821C 0xff
#define BIT_SLOT_8821C(x) (((x) & BIT_MASK_SLOT_8821C) << BIT_SHIFT_SLOT_8821C)
#define BITS_SLOT_8821C (BIT_MASK_SLOT_8821C << BIT_SHIFT_SLOT_8821C)
#define BIT_CLEAR_SLOT_8821C(x) ((x) & (~BITS_SLOT_8821C))
#define BIT_GET_SLOT_8821C(x) \
(((x) >> BIT_SHIFT_SLOT_8821C) & BIT_MASK_SLOT_8821C)
#define BIT_SET_SLOT_8821C(x, v) (BIT_CLEAR_SLOT_8821C(x) | BIT_SLOT_8821C(v))
/* 2 REG_NOA_ON_ERLY_TIME_8821C */
#define BIT_SHIFT__NOA_ON_ERLY_TIME_8821C 0
#define BIT_MASK__NOA_ON_ERLY_TIME_8821C 0xff
#define BIT__NOA_ON_ERLY_TIME_8821C(x) \
(((x) & BIT_MASK__NOA_ON_ERLY_TIME_8821C) \
<< BIT_SHIFT__NOA_ON_ERLY_TIME_8821C)
#define BITS__NOA_ON_ERLY_TIME_8821C \
(BIT_MASK__NOA_ON_ERLY_TIME_8821C << BIT_SHIFT__NOA_ON_ERLY_TIME_8821C)
#define BIT_CLEAR__NOA_ON_ERLY_TIME_8821C(x) \
((x) & (~BITS__NOA_ON_ERLY_TIME_8821C))
#define BIT_GET__NOA_ON_ERLY_TIME_8821C(x) \
(((x) >> BIT_SHIFT__NOA_ON_ERLY_TIME_8821C) & \
BIT_MASK__NOA_ON_ERLY_TIME_8821C)
#define BIT_SET__NOA_ON_ERLY_TIME_8821C(x, v) \
(BIT_CLEAR__NOA_ON_ERLY_TIME_8821C(x) | BIT__NOA_ON_ERLY_TIME_8821C(v))
/* 2 REG_NOA_OFF_ERLY_TIME_8821C */
#define BIT_SHIFT__NOA_OFF_ERLY_TIME_8821C 0
#define BIT_MASK__NOA_OFF_ERLY_TIME_8821C 0xff
#define BIT__NOA_OFF_ERLY_TIME_8821C(x) \
(((x) & BIT_MASK__NOA_OFF_ERLY_TIME_8821C) \
<< BIT_SHIFT__NOA_OFF_ERLY_TIME_8821C)
#define BITS__NOA_OFF_ERLY_TIME_8821C \
(BIT_MASK__NOA_OFF_ERLY_TIME_8821C \
<< BIT_SHIFT__NOA_OFF_ERLY_TIME_8821C)
#define BIT_CLEAR__NOA_OFF_ERLY_TIME_8821C(x) \
((x) & (~BITS__NOA_OFF_ERLY_TIME_8821C))
#define BIT_GET__NOA_OFF_ERLY_TIME_8821C(x) \
(((x) >> BIT_SHIFT__NOA_OFF_ERLY_TIME_8821C) & \
BIT_MASK__NOA_OFF_ERLY_TIME_8821C)
#define BIT_SET__NOA_OFF_ERLY_TIME_8821C(x, v) \
(BIT_CLEAR__NOA_OFF_ERLY_TIME_8821C(x) | \
BIT__NOA_OFF_ERLY_TIME_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_TX_PTCL_CTRL_8821C */
#define BIT_DIS_EDCCA_8821C BIT(15)
#define BIT_DIS_CCA_8821C BIT(14)
#define BIT_LSIG_TXOP_TXCMD_NAV_8821C BIT(13)
#define BIT_SIFS_BK_EN_8821C BIT(12)
#define BIT_SHIFT_TXQ_NAV_MSK_8821C 8
#define BIT_MASK_TXQ_NAV_MSK_8821C 0xf
#define BIT_TXQ_NAV_MSK_8821C(x) \
(((x) & BIT_MASK_TXQ_NAV_MSK_8821C) << BIT_SHIFT_TXQ_NAV_MSK_8821C)
#define BITS_TXQ_NAV_MSK_8821C \
(BIT_MASK_TXQ_NAV_MSK_8821C << BIT_SHIFT_TXQ_NAV_MSK_8821C)
#define BIT_CLEAR_TXQ_NAV_MSK_8821C(x) ((x) & (~BITS_TXQ_NAV_MSK_8821C))
#define BIT_GET_TXQ_NAV_MSK_8821C(x) \
(((x) >> BIT_SHIFT_TXQ_NAV_MSK_8821C) & BIT_MASK_TXQ_NAV_MSK_8821C)
#define BIT_SET_TXQ_NAV_MSK_8821C(x, v) \
(BIT_CLEAR_TXQ_NAV_MSK_8821C(x) | BIT_TXQ_NAV_MSK_8821C(v))
#define BIT_DIS_CW_8821C BIT(7)
#define BIT_NAV_END_TXOP_8821C BIT(6)
#define BIT_RDG_END_TXOP_8821C BIT(5)
#define BIT_AC_INBCN_HOLD_8821C BIT(4)
#define BIT_MGTQ_TXOP_EN_8821C BIT(3)
#define BIT_MGTQ_RTSMF_EN_8821C BIT(2)
#define BIT_HIQ_RTSMF_EN_8821C BIT(1)
#define BIT_BCN_RTSMF_EN_8821C BIT(0)
/* 2 REG_TXPAUSE_8821C */
#define BIT_STOP_BCN_HI_MGT_8821C BIT(7)
#define BIT_MAC_STOPBCNQ_8821C BIT(6)
#define BIT_MAC_STOPHIQ_8821C BIT(5)
#define BIT_MAC_STOPMGQ_8821C BIT(4)
#define BIT_MAC_STOPBK_8821C BIT(3)
#define BIT_MAC_STOPBE_8821C BIT(2)
#define BIT_MAC_STOPVI_8821C BIT(1)
#define BIT_MAC_STOPVO_8821C BIT(0)
/* 2 REG_DIS_TXREQ_CLR_8821C */
#define BIT_DIS_BT_CCA_8821C BIT(7)
#define BIT_DIS_TXREQ_CLR_HI_8821C BIT(5)
#define BIT_DIS_TXREQ_CLR_MGQ_8821C BIT(4)
#define BIT_DIS_TXREQ_CLR_VO_8821C BIT(3)
#define BIT_DIS_TXREQ_CLR_VI_8821C BIT(2)
#define BIT_DIS_TXREQ_CLR_BE_8821C BIT(1)
#define BIT_DIS_TXREQ_CLR_BK_8821C BIT(0)
/* 2 REG_RD_CTRL_8821C */
#define BIT_EN_CLR_TXREQ_INCCA_8821C BIT(15)
#define BIT_DIS_TX_OVER_BCNQ_8821C BIT(14)
#define BIT_EN_BCNERR_INCCCA_8821C BIT(13)
#define BIT_EDCCA_MSK_CNTDOWN_EN_8821C BIT(11)
#define BIT_DIS_TXOP_CFE_8821C BIT(10)
#define BIT_DIS_LSIG_CFE_8821C BIT(9)
#define BIT_DIS_STBC_CFE_8821C BIT(8)
#define BIT_BKQ_RD_INIT_EN_8821C BIT(7)
#define BIT_BEQ_RD_INIT_EN_8821C BIT(6)
#define BIT_VIQ_RD_INIT_EN_8821C BIT(5)
#define BIT_VOQ_RD_INIT_EN_8821C BIT(4)
#define BIT_BKQ_RD_RESP_EN_8821C BIT(3)
#define BIT_BEQ_RD_RESP_EN_8821C BIT(2)
#define BIT_VIQ_RD_RESP_EN_8821C BIT(1)
#define BIT_VOQ_RD_RESP_EN_8821C BIT(0)
/* 2 REG_MBSSID_CTRL_8821C */
#define BIT_MBID_BCNQ7_EN_8821C BIT(7)
#define BIT_MBID_BCNQ6_EN_8821C BIT(6)
#define BIT_MBID_BCNQ5_EN_8821C BIT(5)
#define BIT_MBID_BCNQ4_EN_8821C BIT(4)
#define BIT_MBID_BCNQ3_EN_8821C BIT(3)
#define BIT_MBID_BCNQ2_EN_8821C BIT(2)
#define BIT_MBID_BCNQ1_EN_8821C BIT(1)
#define BIT_MBID_BCNQ0_EN_8821C BIT(0)
/* 2 REG_P2PPS_CTRL_8821C */
#define BIT_P2P_CTW_ALLSTASLEEP_8821C BIT(7)
#define BIT_P2P_OFF_DISTX_EN_8821C BIT(6)
#define BIT_PWR_MGT_EN_8821C BIT(5)
#define BIT_P2P_NOA1_EN_8821C BIT(2)
#define BIT_P2P_NOA0_EN_8821C BIT(1)
/* 2 REG_PKT_LIFETIME_CTRL_8821C */
#define BIT_EN_P2P_CTWND1_8821C BIT(23)
#define BIT_EN_BKF_CLR_TXREQ_8821C BIT(22)
#define BIT_EN_TSFBIT32_RST_P2P_8821C BIT(21)
#define BIT_EN_BCN_TX_BTCCA_8821C BIT(20)
#define BIT_DIS_PKT_TX_ATIM_8821C BIT(19)
#define BIT_DIS_BCN_DIS_CTN_8821C BIT(18)
#define BIT_EN_NAVEND_RST_TXOP_8821C BIT(17)
#define BIT_EN_FILTER_CCA_8821C BIT(16)
#define BIT_SHIFT_CCA_FILTER_THRS_8821C 8
#define BIT_MASK_CCA_FILTER_THRS_8821C 0xff
#define BIT_CCA_FILTER_THRS_8821C(x) \
(((x) & BIT_MASK_CCA_FILTER_THRS_8821C) \
<< BIT_SHIFT_CCA_FILTER_THRS_8821C)
#define BITS_CCA_FILTER_THRS_8821C \
(BIT_MASK_CCA_FILTER_THRS_8821C << BIT_SHIFT_CCA_FILTER_THRS_8821C)
#define BIT_CLEAR_CCA_FILTER_THRS_8821C(x) ((x) & (~BITS_CCA_FILTER_THRS_8821C))
#define BIT_GET_CCA_FILTER_THRS_8821C(x) \
(((x) >> BIT_SHIFT_CCA_FILTER_THRS_8821C) & \
BIT_MASK_CCA_FILTER_THRS_8821C)
#define BIT_SET_CCA_FILTER_THRS_8821C(x, v) \
(BIT_CLEAR_CCA_FILTER_THRS_8821C(x) | BIT_CCA_FILTER_THRS_8821C(v))
#define BIT_SHIFT_EDCCA_THRS_8821C 0
#define BIT_MASK_EDCCA_THRS_8821C 0xff
#define BIT_EDCCA_THRS_8821C(x) \
(((x) & BIT_MASK_EDCCA_THRS_8821C) << BIT_SHIFT_EDCCA_THRS_8821C)
#define BITS_EDCCA_THRS_8821C \
(BIT_MASK_EDCCA_THRS_8821C << BIT_SHIFT_EDCCA_THRS_8821C)
#define BIT_CLEAR_EDCCA_THRS_8821C(x) ((x) & (~BITS_EDCCA_THRS_8821C))
#define BIT_GET_EDCCA_THRS_8821C(x) \
(((x) >> BIT_SHIFT_EDCCA_THRS_8821C) & BIT_MASK_EDCCA_THRS_8821C)
#define BIT_SET_EDCCA_THRS_8821C(x, v) \
(BIT_CLEAR_EDCCA_THRS_8821C(x) | BIT_EDCCA_THRS_8821C(v))
/* 2 REG_P2PPS_SPEC_STATE_8821C */
#define BIT_SPEC_POWER_STATE_8821C BIT(7)
#define BIT_SPEC_CTWINDOW_ON_8821C BIT(6)
#define BIT_SPEC_BEACON_AREA_ON_8821C BIT(5)
#define BIT_SPEC_CTWIN_EARLY_DISTX_8821C BIT(4)
#define BIT_SPEC_NOA1_OFF_PERIOD_8821C BIT(3)
#define BIT_SPEC_FORCE_DOZE1_8821C BIT(2)
#define BIT_SPEC_NOA0_OFF_PERIOD_8821C BIT(1)
#define BIT_SPEC_FORCE_DOZE0_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_BAR_TX_CTRL_8821C */
/* 2 REG_P2PON_DIS_TXTIME_8821C */
#define BIT_SHIFT_P2PON_DIS_TXTIME_8821C 0
#define BIT_MASK_P2PON_DIS_TXTIME_8821C 0xff
#define BIT_P2PON_DIS_TXTIME_8821C(x) \
(((x) & BIT_MASK_P2PON_DIS_TXTIME_8821C) \
<< BIT_SHIFT_P2PON_DIS_TXTIME_8821C)
#define BITS_P2PON_DIS_TXTIME_8821C \
(BIT_MASK_P2PON_DIS_TXTIME_8821C << BIT_SHIFT_P2PON_DIS_TXTIME_8821C)
#define BIT_CLEAR_P2PON_DIS_TXTIME_8821C(x) \
((x) & (~BITS_P2PON_DIS_TXTIME_8821C))
#define BIT_GET_P2PON_DIS_TXTIME_8821C(x) \
(((x) >> BIT_SHIFT_P2PON_DIS_TXTIME_8821C) & \
BIT_MASK_P2PON_DIS_TXTIME_8821C)
#define BIT_SET_P2PON_DIS_TXTIME_8821C(x, v) \
(BIT_CLEAR_P2PON_DIS_TXTIME_8821C(x) | BIT_P2PON_DIS_TXTIME_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_TBTT_PROHIBIT_8821C */
#define BIT_SHIFT_TBTT_HOLD_TIME_AP_8821C 8
#define BIT_MASK_TBTT_HOLD_TIME_AP_8821C 0xfff
#define BIT_TBTT_HOLD_TIME_AP_8821C(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_AP_8821C) \
<< BIT_SHIFT_TBTT_HOLD_TIME_AP_8821C)
#define BITS_TBTT_HOLD_TIME_AP_8821C \
(BIT_MASK_TBTT_HOLD_TIME_AP_8821C << BIT_SHIFT_TBTT_HOLD_TIME_AP_8821C)
#define BIT_CLEAR_TBTT_HOLD_TIME_AP_8821C(x) \
((x) & (~BITS_TBTT_HOLD_TIME_AP_8821C))
#define BIT_GET_TBTT_HOLD_TIME_AP_8821C(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_AP_8821C) & \
BIT_MASK_TBTT_HOLD_TIME_AP_8821C)
#define BIT_SET_TBTT_HOLD_TIME_AP_8821C(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_AP_8821C(x) | BIT_TBTT_HOLD_TIME_AP_8821C(v))
#define BIT_SHIFT_TBTT_PROHIBIT_SETUP_8821C 0
#define BIT_MASK_TBTT_PROHIBIT_SETUP_8821C 0xf
#define BIT_TBTT_PROHIBIT_SETUP_8821C(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_SETUP_8821C) \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8821C)
#define BITS_TBTT_PROHIBIT_SETUP_8821C \
(BIT_MASK_TBTT_PROHIBIT_SETUP_8821C \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8821C)
#define BIT_CLEAR_TBTT_PROHIBIT_SETUP_8821C(x) \
((x) & (~BITS_TBTT_PROHIBIT_SETUP_8821C))
#define BIT_GET_TBTT_PROHIBIT_SETUP_8821C(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_SETUP_8821C) & \
BIT_MASK_TBTT_PROHIBIT_SETUP_8821C)
#define BIT_SET_TBTT_PROHIBIT_SETUP_8821C(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_SETUP_8821C(x) | \
BIT_TBTT_PROHIBIT_SETUP_8821C(v))
/* 2 REG_P2PPS_STATE_8821C */
#define BIT_POWER_STATE_8821C BIT(7)
#define BIT_CTWINDOW_ON_8821C BIT(6)
#define BIT_BEACON_AREA_ON_8821C BIT(5)
#define BIT_CTWIN_EARLY_DISTX_8821C BIT(4)
#define BIT_NOA1_OFF_PERIOD_8821C BIT(3)
#define BIT_FORCE_DOZE1_8821C BIT(2)
#define BIT_NOA0_OFF_PERIOD_8821C BIT(1)
#define BIT_FORCE_DOZE0_8821C BIT(0)
/* 2 REG_RD_NAV_NXT_8821C */
#define BIT_SHIFT_RD_NAV_PROT_NXT_8821C 0
#define BIT_MASK_RD_NAV_PROT_NXT_8821C 0xffff
#define BIT_RD_NAV_PROT_NXT_8821C(x) \
(((x) & BIT_MASK_RD_NAV_PROT_NXT_8821C) \
<< BIT_SHIFT_RD_NAV_PROT_NXT_8821C)
#define BITS_RD_NAV_PROT_NXT_8821C \
(BIT_MASK_RD_NAV_PROT_NXT_8821C << BIT_SHIFT_RD_NAV_PROT_NXT_8821C)
#define BIT_CLEAR_RD_NAV_PROT_NXT_8821C(x) ((x) & (~BITS_RD_NAV_PROT_NXT_8821C))
#define BIT_GET_RD_NAV_PROT_NXT_8821C(x) \
(((x) >> BIT_SHIFT_RD_NAV_PROT_NXT_8821C) & \
BIT_MASK_RD_NAV_PROT_NXT_8821C)
#define BIT_SET_RD_NAV_PROT_NXT_8821C(x, v) \
(BIT_CLEAR_RD_NAV_PROT_NXT_8821C(x) | BIT_RD_NAV_PROT_NXT_8821C(v))
/* 2 REG_NAV_PROT_LEN_8821C */
#define BIT_SHIFT_NAV_PROT_LEN_8821C 0
#define BIT_MASK_NAV_PROT_LEN_8821C 0xffff
#define BIT_NAV_PROT_LEN_8821C(x) \
(((x) & BIT_MASK_NAV_PROT_LEN_8821C) << BIT_SHIFT_NAV_PROT_LEN_8821C)
#define BITS_NAV_PROT_LEN_8821C \
(BIT_MASK_NAV_PROT_LEN_8821C << BIT_SHIFT_NAV_PROT_LEN_8821C)
#define BIT_CLEAR_NAV_PROT_LEN_8821C(x) ((x) & (~BITS_NAV_PROT_LEN_8821C))
#define BIT_GET_NAV_PROT_LEN_8821C(x) \
(((x) >> BIT_SHIFT_NAV_PROT_LEN_8821C) & BIT_MASK_NAV_PROT_LEN_8821C)
#define BIT_SET_NAV_PROT_LEN_8821C(x, v) \
(BIT_CLEAR_NAV_PROT_LEN_8821C(x) | BIT_NAV_PROT_LEN_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_BCN_CTRL_8821C */
#define BIT_DIS_RX_BSSID_FIT_8821C BIT(6)
#define BIT_P0_EN_TXBCN_RPT_8821C BIT(5)
#define BIT_DIS_TSF_UDT_8821C BIT(4)
#define BIT_EN_BCN_FUNCTION_8821C BIT(3)
#define BIT_P0_EN_RXBCN_RPT_8821C BIT(2)
#define BIT_EN_P2P_CTWINDOW_8821C BIT(1)
#define BIT_EN_P2P_BCNQ_AREA_8821C BIT(0)
/* 2 REG_BCN_CTRL_CLINT0_8821C */
#define BIT_CLI0_DIS_RX_BSSID_FIT_8821C BIT(6)
#define BIT_CLI0_DIS_TSF_UDT_8821C BIT(4)
#define BIT_CLI0_EN_BCN_FUNCTION_8821C BIT(3)
#define BIT_CLI0_EN_RXBCN_RPT_8821C BIT(2)
#define BIT_CLI0_ENP2P_CTWINDOW_8821C BIT(1)
#define BIT_CLI0_ENP2P_BCNQ_AREA_8821C BIT(0)
/* 2 REG_MBID_NUM_8821C */
#define BIT_EN_PRE_DL_BEACON_8821C BIT(3)
#define BIT_SHIFT_MBID_BCN_NUM_8821C 0
#define BIT_MASK_MBID_BCN_NUM_8821C 0x7
#define BIT_MBID_BCN_NUM_8821C(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_8821C) << BIT_SHIFT_MBID_BCN_NUM_8821C)
#define BITS_MBID_BCN_NUM_8821C \
(BIT_MASK_MBID_BCN_NUM_8821C << BIT_SHIFT_MBID_BCN_NUM_8821C)
#define BIT_CLEAR_MBID_BCN_NUM_8821C(x) ((x) & (~BITS_MBID_BCN_NUM_8821C))
#define BIT_GET_MBID_BCN_NUM_8821C(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_8821C) & BIT_MASK_MBID_BCN_NUM_8821C)
#define BIT_SET_MBID_BCN_NUM_8821C(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_8821C(x) | BIT_MBID_BCN_NUM_8821C(v))
/* 2 REG_DUAL_TSF_RST_8821C */
#define BIT_FREECNT_RST_8821C BIT(5)
#define BIT_TSFTR_CLI3_RST_8821C BIT(4)
#define BIT_TSFTR_CLI2_RST_8821C BIT(3)
#define BIT_TSFTR_CLI1_RST_8821C BIT(2)
#define BIT_TSFTR_CLI0_RST_8821C BIT(1)
#define BIT_TSFTR_RST_8821C BIT(0)
/* 2 REG_MBSSID_BCN_SPACE_8821C */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD_8821C 28
#define BIT_MASK_BCN_TIMER_SEL_FWRD_8821C 0x7
#define BIT_BCN_TIMER_SEL_FWRD_8821C(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD_8821C) \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8821C)
#define BITS_BCN_TIMER_SEL_FWRD_8821C \
(BIT_MASK_BCN_TIMER_SEL_FWRD_8821C \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8821C)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD_8821C(x) \
((x) & (~BITS_BCN_TIMER_SEL_FWRD_8821C))
#define BIT_GET_BCN_TIMER_SEL_FWRD_8821C(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD_8821C) & \
BIT_MASK_BCN_TIMER_SEL_FWRD_8821C)
#define BIT_SET_BCN_TIMER_SEL_FWRD_8821C(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD_8821C(x) | \
BIT_BCN_TIMER_SEL_FWRD_8821C(v))
#define BIT_SHIFT_BCN_SPACE_CLINT0_8821C 16
#define BIT_MASK_BCN_SPACE_CLINT0_8821C 0xfff
#define BIT_BCN_SPACE_CLINT0_8821C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT0_8821C) \
<< BIT_SHIFT_BCN_SPACE_CLINT0_8821C)
#define BITS_BCN_SPACE_CLINT0_8821C \
(BIT_MASK_BCN_SPACE_CLINT0_8821C << BIT_SHIFT_BCN_SPACE_CLINT0_8821C)
#define BIT_CLEAR_BCN_SPACE_CLINT0_8821C(x) \
((x) & (~BITS_BCN_SPACE_CLINT0_8821C))
#define BIT_GET_BCN_SPACE_CLINT0_8821C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT0_8821C) & \
BIT_MASK_BCN_SPACE_CLINT0_8821C)
#define BIT_SET_BCN_SPACE_CLINT0_8821C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT0_8821C(x) | BIT_BCN_SPACE_CLINT0_8821C(v))
#define BIT_SHIFT_BCN_SPACE0_8821C 0
#define BIT_MASK_BCN_SPACE0_8821C 0xffff
#define BIT_BCN_SPACE0_8821C(x) \
(((x) & BIT_MASK_BCN_SPACE0_8821C) << BIT_SHIFT_BCN_SPACE0_8821C)
#define BITS_BCN_SPACE0_8821C \
(BIT_MASK_BCN_SPACE0_8821C << BIT_SHIFT_BCN_SPACE0_8821C)
#define BIT_CLEAR_BCN_SPACE0_8821C(x) ((x) & (~BITS_BCN_SPACE0_8821C))
#define BIT_GET_BCN_SPACE0_8821C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE0_8821C) & BIT_MASK_BCN_SPACE0_8821C)
#define BIT_SET_BCN_SPACE0_8821C(x, v) \
(BIT_CLEAR_BCN_SPACE0_8821C(x) | BIT_BCN_SPACE0_8821C(v))
/* 2 REG_DRVERLYINT_8821C */
#define BIT_SHIFT_DRVERLYITV_8821C 0
#define BIT_MASK_DRVERLYITV_8821C 0xff
#define BIT_DRVERLYITV_8821C(x) \
(((x) & BIT_MASK_DRVERLYITV_8821C) << BIT_SHIFT_DRVERLYITV_8821C)
#define BITS_DRVERLYITV_8821C \
(BIT_MASK_DRVERLYITV_8821C << BIT_SHIFT_DRVERLYITV_8821C)
#define BIT_CLEAR_DRVERLYITV_8821C(x) ((x) & (~BITS_DRVERLYITV_8821C))
#define BIT_GET_DRVERLYITV_8821C(x) \
(((x) >> BIT_SHIFT_DRVERLYITV_8821C) & BIT_MASK_DRVERLYITV_8821C)
#define BIT_SET_DRVERLYITV_8821C(x, v) \
(BIT_CLEAR_DRVERLYITV_8821C(x) | BIT_DRVERLYITV_8821C(v))
/* 2 REG_BCNDMATIM_8821C */
#define BIT_SHIFT_BCNDMATIM_8821C 0
#define BIT_MASK_BCNDMATIM_8821C 0xff
#define BIT_BCNDMATIM_8821C(x) \
(((x) & BIT_MASK_BCNDMATIM_8821C) << BIT_SHIFT_BCNDMATIM_8821C)
#define BITS_BCNDMATIM_8821C \
(BIT_MASK_BCNDMATIM_8821C << BIT_SHIFT_BCNDMATIM_8821C)
#define BIT_CLEAR_BCNDMATIM_8821C(x) ((x) & (~BITS_BCNDMATIM_8821C))
#define BIT_GET_BCNDMATIM_8821C(x) \
(((x) >> BIT_SHIFT_BCNDMATIM_8821C) & BIT_MASK_BCNDMATIM_8821C)
#define BIT_SET_BCNDMATIM_8821C(x, v) \
(BIT_CLEAR_BCNDMATIM_8821C(x) | BIT_BCNDMATIM_8821C(v))
/* 2 REG_ATIMWND_8821C */
#define BIT_SHIFT_ATIMWND0_8821C 0
#define BIT_MASK_ATIMWND0_8821C 0xffff
#define BIT_ATIMWND0_8821C(x) \
(((x) & BIT_MASK_ATIMWND0_8821C) << BIT_SHIFT_ATIMWND0_8821C)
#define BITS_ATIMWND0_8821C \
(BIT_MASK_ATIMWND0_8821C << BIT_SHIFT_ATIMWND0_8821C)
#define BIT_CLEAR_ATIMWND0_8821C(x) ((x) & (~BITS_ATIMWND0_8821C))
#define BIT_GET_ATIMWND0_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND0_8821C) & BIT_MASK_ATIMWND0_8821C)
#define BIT_SET_ATIMWND0_8821C(x, v) \
(BIT_CLEAR_ATIMWND0_8821C(x) | BIT_ATIMWND0_8821C(v))
/* 2 REG_USTIME_TSF_8821C */
#define BIT_SHIFT_USTIME_TSF_V1_8821C 0
#define BIT_MASK_USTIME_TSF_V1_8821C 0xff
#define BIT_USTIME_TSF_V1_8821C(x) \
(((x) & BIT_MASK_USTIME_TSF_V1_8821C) << BIT_SHIFT_USTIME_TSF_V1_8821C)
#define BITS_USTIME_TSF_V1_8821C \
(BIT_MASK_USTIME_TSF_V1_8821C << BIT_SHIFT_USTIME_TSF_V1_8821C)
#define BIT_CLEAR_USTIME_TSF_V1_8821C(x) ((x) & (~BITS_USTIME_TSF_V1_8821C))
#define BIT_GET_USTIME_TSF_V1_8821C(x) \
(((x) >> BIT_SHIFT_USTIME_TSF_V1_8821C) & BIT_MASK_USTIME_TSF_V1_8821C)
#define BIT_SET_USTIME_TSF_V1_8821C(x, v) \
(BIT_CLEAR_USTIME_TSF_V1_8821C(x) | BIT_USTIME_TSF_V1_8821C(v))
/* 2 REG_BCN_MAX_ERR_8821C */
#define BIT_SHIFT_BCN_MAX_ERR_8821C 0
#define BIT_MASK_BCN_MAX_ERR_8821C 0xff
#define BIT_BCN_MAX_ERR_8821C(x) \
(((x) & BIT_MASK_BCN_MAX_ERR_8821C) << BIT_SHIFT_BCN_MAX_ERR_8821C)
#define BITS_BCN_MAX_ERR_8821C \
(BIT_MASK_BCN_MAX_ERR_8821C << BIT_SHIFT_BCN_MAX_ERR_8821C)
#define BIT_CLEAR_BCN_MAX_ERR_8821C(x) ((x) & (~BITS_BCN_MAX_ERR_8821C))
#define BIT_GET_BCN_MAX_ERR_8821C(x) \
(((x) >> BIT_SHIFT_BCN_MAX_ERR_8821C) & BIT_MASK_BCN_MAX_ERR_8821C)
#define BIT_SET_BCN_MAX_ERR_8821C(x, v) \
(BIT_CLEAR_BCN_MAX_ERR_8821C(x) | BIT_BCN_MAX_ERR_8821C(v))
/* 2 REG_RXTSF_OFFSET_CCK_8821C */
#define BIT_SHIFT_CCK_RXTSF_OFFSET_8821C 0
#define BIT_MASK_CCK_RXTSF_OFFSET_8821C 0xff
#define BIT_CCK_RXTSF_OFFSET_8821C(x) \
(((x) & BIT_MASK_CCK_RXTSF_OFFSET_8821C) \
<< BIT_SHIFT_CCK_RXTSF_OFFSET_8821C)
#define BITS_CCK_RXTSF_OFFSET_8821C \
(BIT_MASK_CCK_RXTSF_OFFSET_8821C << BIT_SHIFT_CCK_RXTSF_OFFSET_8821C)
#define BIT_CLEAR_CCK_RXTSF_OFFSET_8821C(x) \
((x) & (~BITS_CCK_RXTSF_OFFSET_8821C))
#define BIT_GET_CCK_RXTSF_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_CCK_RXTSF_OFFSET_8821C) & \
BIT_MASK_CCK_RXTSF_OFFSET_8821C)
#define BIT_SET_CCK_RXTSF_OFFSET_8821C(x, v) \
(BIT_CLEAR_CCK_RXTSF_OFFSET_8821C(x) | BIT_CCK_RXTSF_OFFSET_8821C(v))
/* 2 REG_RXTSF_OFFSET_OFDM_8821C */
#define BIT_SHIFT_OFDM_RXTSF_OFFSET_8821C 0
#define BIT_MASK_OFDM_RXTSF_OFFSET_8821C 0xff
#define BIT_OFDM_RXTSF_OFFSET_8821C(x) \
(((x) & BIT_MASK_OFDM_RXTSF_OFFSET_8821C) \
<< BIT_SHIFT_OFDM_RXTSF_OFFSET_8821C)
#define BITS_OFDM_RXTSF_OFFSET_8821C \
(BIT_MASK_OFDM_RXTSF_OFFSET_8821C << BIT_SHIFT_OFDM_RXTSF_OFFSET_8821C)
#define BIT_CLEAR_OFDM_RXTSF_OFFSET_8821C(x) \
((x) & (~BITS_OFDM_RXTSF_OFFSET_8821C))
#define BIT_GET_OFDM_RXTSF_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_OFDM_RXTSF_OFFSET_8821C) & \
BIT_MASK_OFDM_RXTSF_OFFSET_8821C)
#define BIT_SET_OFDM_RXTSF_OFFSET_8821C(x, v) \
(BIT_CLEAR_OFDM_RXTSF_OFFSET_8821C(x) | BIT_OFDM_RXTSF_OFFSET_8821C(v))
/* 2 REG_TSFTR_8821C */
#define BIT_SHIFT_TSF_TIMER_V1_8821C 0
#define BIT_MASK_TSF_TIMER_V1_8821C 0xffffffffL
#define BIT_TSF_TIMER_V1_8821C(x) \
(((x) & BIT_MASK_TSF_TIMER_V1_8821C) << BIT_SHIFT_TSF_TIMER_V1_8821C)
#define BITS_TSF_TIMER_V1_8821C \
(BIT_MASK_TSF_TIMER_V1_8821C << BIT_SHIFT_TSF_TIMER_V1_8821C)
#define BIT_CLEAR_TSF_TIMER_V1_8821C(x) ((x) & (~BITS_TSF_TIMER_V1_8821C))
#define BIT_GET_TSF_TIMER_V1_8821C(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_V1_8821C) & BIT_MASK_TSF_TIMER_V1_8821C)
#define BIT_SET_TSF_TIMER_V1_8821C(x, v) \
(BIT_CLEAR_TSF_TIMER_V1_8821C(x) | BIT_TSF_TIMER_V1_8821C(v))
/* 2 REG_TSFTR_1_8821C */
#define BIT_SHIFT_TSF_TIMER_V2_8821C 0
#define BIT_MASK_TSF_TIMER_V2_8821C 0xffffffffL
#define BIT_TSF_TIMER_V2_8821C(x) \
(((x) & BIT_MASK_TSF_TIMER_V2_8821C) << BIT_SHIFT_TSF_TIMER_V2_8821C)
#define BITS_TSF_TIMER_V2_8821C \
(BIT_MASK_TSF_TIMER_V2_8821C << BIT_SHIFT_TSF_TIMER_V2_8821C)
#define BIT_CLEAR_TSF_TIMER_V2_8821C(x) ((x) & (~BITS_TSF_TIMER_V2_8821C))
#define BIT_GET_TSF_TIMER_V2_8821C(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_V2_8821C) & BIT_MASK_TSF_TIMER_V2_8821C)
#define BIT_SET_TSF_TIMER_V2_8821C(x, v) \
(BIT_CLEAR_TSF_TIMER_V2_8821C(x) | BIT_TSF_TIMER_V2_8821C(v))
/* 2 REG_FREERUN_CNT_8821C */
#define BIT_SHIFT_FREERUN_CNT_V1_8821C 0
#define BIT_MASK_FREERUN_CNT_V1_8821C 0xffffffffL
#define BIT_FREERUN_CNT_V1_8821C(x) \
(((x) & BIT_MASK_FREERUN_CNT_V1_8821C) \
<< BIT_SHIFT_FREERUN_CNT_V1_8821C)
#define BITS_FREERUN_CNT_V1_8821C \
(BIT_MASK_FREERUN_CNT_V1_8821C << BIT_SHIFT_FREERUN_CNT_V1_8821C)
#define BIT_CLEAR_FREERUN_CNT_V1_8821C(x) ((x) & (~BITS_FREERUN_CNT_V1_8821C))
#define BIT_GET_FREERUN_CNT_V1_8821C(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_V1_8821C) & \
BIT_MASK_FREERUN_CNT_V1_8821C)
#define BIT_SET_FREERUN_CNT_V1_8821C(x, v) \
(BIT_CLEAR_FREERUN_CNT_V1_8821C(x) | BIT_FREERUN_CNT_V1_8821C(v))
/* 2 REG_FREERUN_CNT_1_8821C */
#define BIT_SHIFT_FREERUN_CNT_V2_8821C 0
#define BIT_MASK_FREERUN_CNT_V2_8821C 0xffffffffL
#define BIT_FREERUN_CNT_V2_8821C(x) \
(((x) & BIT_MASK_FREERUN_CNT_V2_8821C) \
<< BIT_SHIFT_FREERUN_CNT_V2_8821C)
#define BITS_FREERUN_CNT_V2_8821C \
(BIT_MASK_FREERUN_CNT_V2_8821C << BIT_SHIFT_FREERUN_CNT_V2_8821C)
#define BIT_CLEAR_FREERUN_CNT_V2_8821C(x) ((x) & (~BITS_FREERUN_CNT_V2_8821C))
#define BIT_GET_FREERUN_CNT_V2_8821C(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_V2_8821C) & \
BIT_MASK_FREERUN_CNT_V2_8821C)
#define BIT_SET_FREERUN_CNT_V2_8821C(x, v) \
(BIT_CLEAR_FREERUN_CNT_V2_8821C(x) | BIT_FREERUN_CNT_V2_8821C(v))
/* 2 REG_ATIMWND1_V1_8821C */
#define BIT_SHIFT_ATIMWND1_V1_8821C 0
#define BIT_MASK_ATIMWND1_V1_8821C 0xff
#define BIT_ATIMWND1_V1_8821C(x) \
(((x) & BIT_MASK_ATIMWND1_V1_8821C) << BIT_SHIFT_ATIMWND1_V1_8821C)
#define BITS_ATIMWND1_V1_8821C \
(BIT_MASK_ATIMWND1_V1_8821C << BIT_SHIFT_ATIMWND1_V1_8821C)
#define BIT_CLEAR_ATIMWND1_V1_8821C(x) ((x) & (~BITS_ATIMWND1_V1_8821C))
#define BIT_GET_ATIMWND1_V1_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND1_V1_8821C) & BIT_MASK_ATIMWND1_V1_8821C)
#define BIT_SET_ATIMWND1_V1_8821C(x, v) \
(BIT_CLEAR_ATIMWND1_V1_8821C(x) | BIT_ATIMWND1_V1_8821C(v))
/* 2 REG_TBTT_PROHIBIT_INFRA_8821C */
#define BIT_SHIFT_TBTT_PROHIBIT_INFRA_8821C 0
#define BIT_MASK_TBTT_PROHIBIT_INFRA_8821C 0xff
#define BIT_TBTT_PROHIBIT_INFRA_8821C(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_INFRA_8821C) \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8821C)
#define BITS_TBTT_PROHIBIT_INFRA_8821C \
(BIT_MASK_TBTT_PROHIBIT_INFRA_8821C \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8821C)
#define BIT_CLEAR_TBTT_PROHIBIT_INFRA_8821C(x) \
((x) & (~BITS_TBTT_PROHIBIT_INFRA_8821C))
#define BIT_GET_TBTT_PROHIBIT_INFRA_8821C(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_INFRA_8821C) & \
BIT_MASK_TBTT_PROHIBIT_INFRA_8821C)
#define BIT_SET_TBTT_PROHIBIT_INFRA_8821C(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_INFRA_8821C(x) | \
BIT_TBTT_PROHIBIT_INFRA_8821C(v))
/* 2 REG_CTWND_8821C */
#define BIT_SHIFT_CTWND_8821C 0
#define BIT_MASK_CTWND_8821C 0xff
#define BIT_CTWND_8821C(x) \
(((x) & BIT_MASK_CTWND_8821C) << BIT_SHIFT_CTWND_8821C)
#define BITS_CTWND_8821C (BIT_MASK_CTWND_8821C << BIT_SHIFT_CTWND_8821C)
#define BIT_CLEAR_CTWND_8821C(x) ((x) & (~BITS_CTWND_8821C))
#define BIT_GET_CTWND_8821C(x) \
(((x) >> BIT_SHIFT_CTWND_8821C) & BIT_MASK_CTWND_8821C)
#define BIT_SET_CTWND_8821C(x, v) \
(BIT_CLEAR_CTWND_8821C(x) | BIT_CTWND_8821C(v))
/* 2 REG_BCNIVLCUNT_8821C */
#define BIT_SHIFT_BCNIVLCUNT_8821C 0
#define BIT_MASK_BCNIVLCUNT_8821C 0x7f
#define BIT_BCNIVLCUNT_8821C(x) \
(((x) & BIT_MASK_BCNIVLCUNT_8821C) << BIT_SHIFT_BCNIVLCUNT_8821C)
#define BITS_BCNIVLCUNT_8821C \
(BIT_MASK_BCNIVLCUNT_8821C << BIT_SHIFT_BCNIVLCUNT_8821C)
#define BIT_CLEAR_BCNIVLCUNT_8821C(x) ((x) & (~BITS_BCNIVLCUNT_8821C))
#define BIT_GET_BCNIVLCUNT_8821C(x) \
(((x) >> BIT_SHIFT_BCNIVLCUNT_8821C) & BIT_MASK_BCNIVLCUNT_8821C)
#define BIT_SET_BCNIVLCUNT_8821C(x, v) \
(BIT_CLEAR_BCNIVLCUNT_8821C(x) | BIT_BCNIVLCUNT_8821C(v))
/* 2 REG_BCNDROPCTRL_8821C */
#define BIT_BEACON_DROP_EN_8821C BIT(7)
#define BIT_SHIFT_BEACON_DROP_IVL_8821C 0
#define BIT_MASK_BEACON_DROP_IVL_8821C 0x7f
#define BIT_BEACON_DROP_IVL_8821C(x) \
(((x) & BIT_MASK_BEACON_DROP_IVL_8821C) \
<< BIT_SHIFT_BEACON_DROP_IVL_8821C)
#define BITS_BEACON_DROP_IVL_8821C \
(BIT_MASK_BEACON_DROP_IVL_8821C << BIT_SHIFT_BEACON_DROP_IVL_8821C)
#define BIT_CLEAR_BEACON_DROP_IVL_8821C(x) ((x) & (~BITS_BEACON_DROP_IVL_8821C))
#define BIT_GET_BEACON_DROP_IVL_8821C(x) \
(((x) >> BIT_SHIFT_BEACON_DROP_IVL_8821C) & \
BIT_MASK_BEACON_DROP_IVL_8821C)
#define BIT_SET_BEACON_DROP_IVL_8821C(x, v) \
(BIT_CLEAR_BEACON_DROP_IVL_8821C(x) | BIT_BEACON_DROP_IVL_8821C(v))
/* 2 REG_HGQ_TIMEOUT_PERIOD_8821C */
#define BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8821C 0
#define BIT_MASK_HGQ_TIMEOUT_PERIOD_8821C 0xff
#define BIT_HGQ_TIMEOUT_PERIOD_8821C(x) \
(((x) & BIT_MASK_HGQ_TIMEOUT_PERIOD_8821C) \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8821C)
#define BITS_HGQ_TIMEOUT_PERIOD_8821C \
(BIT_MASK_HGQ_TIMEOUT_PERIOD_8821C \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8821C)
#define BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8821C(x) \
((x) & (~BITS_HGQ_TIMEOUT_PERIOD_8821C))
#define BIT_GET_HGQ_TIMEOUT_PERIOD_8821C(x) \
(((x) >> BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8821C) & \
BIT_MASK_HGQ_TIMEOUT_PERIOD_8821C)
#define BIT_SET_HGQ_TIMEOUT_PERIOD_8821C(x, v) \
(BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8821C(x) | \
BIT_HGQ_TIMEOUT_PERIOD_8821C(v))
/* 2 REG_TXCMD_TIMEOUT_PERIOD_8821C */
#define BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8821C 0
#define BIT_MASK_TXCMD_TIMEOUT_PERIOD_8821C 0xff
#define BIT_TXCMD_TIMEOUT_PERIOD_8821C(x) \
(((x) & BIT_MASK_TXCMD_TIMEOUT_PERIOD_8821C) \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8821C)
#define BITS_TXCMD_TIMEOUT_PERIOD_8821C \
(BIT_MASK_TXCMD_TIMEOUT_PERIOD_8821C \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8821C)
#define BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8821C(x) \
((x) & (~BITS_TXCMD_TIMEOUT_PERIOD_8821C))
#define BIT_GET_TXCMD_TIMEOUT_PERIOD_8821C(x) \
(((x) >> BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8821C) & \
BIT_MASK_TXCMD_TIMEOUT_PERIOD_8821C)
#define BIT_SET_TXCMD_TIMEOUT_PERIOD_8821C(x, v) \
(BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8821C(x) | \
BIT_TXCMD_TIMEOUT_PERIOD_8821C(v))
/* 2 REG_MISC_CTRL_8821C */
#define BIT_AUTO_SYNC_BY_TBTT_8821C BIT(6)
#define BIT_DIS_TRX_CAL_BCN_8821C BIT(5)
#define BIT_DIS_TX_CAL_TBTT_8821C BIT(4)
#define BIT_EN_FREECNT_8821C BIT(3)
#define BIT_BCN_AGGRESSION_8821C BIT(2)
#define BIT_SHIFT_DIS_SECONDARY_CCA_8821C 0
#define BIT_MASK_DIS_SECONDARY_CCA_8821C 0x3
#define BIT_DIS_SECONDARY_CCA_8821C(x) \
(((x) & BIT_MASK_DIS_SECONDARY_CCA_8821C) \
<< BIT_SHIFT_DIS_SECONDARY_CCA_8821C)
#define BITS_DIS_SECONDARY_CCA_8821C \
(BIT_MASK_DIS_SECONDARY_CCA_8821C << BIT_SHIFT_DIS_SECONDARY_CCA_8821C)
#define BIT_CLEAR_DIS_SECONDARY_CCA_8821C(x) \
((x) & (~BITS_DIS_SECONDARY_CCA_8821C))
#define BIT_GET_DIS_SECONDARY_CCA_8821C(x) \
(((x) >> BIT_SHIFT_DIS_SECONDARY_CCA_8821C) & \
BIT_MASK_DIS_SECONDARY_CCA_8821C)
#define BIT_SET_DIS_SECONDARY_CCA_8821C(x, v) \
(BIT_CLEAR_DIS_SECONDARY_CCA_8821C(x) | BIT_DIS_SECONDARY_CCA_8821C(v))
/* 2 REG_BCN_CTRL_CLINT1_8821C */
#define BIT_CLI1_DIS_RX_BSSID_FIT_8821C BIT(6)
#define BIT_CLI1_DIS_TSF_UDT_8821C BIT(4)
#define BIT_CLI1_EN_BCN_FUNCTION_8821C BIT(3)
#define BIT_CLI1_EN_RXBCN_RPT_8821C BIT(2)
#define BIT_CLI1_ENP2P_CTWINDOW_8821C BIT(1)
#define BIT_CLI1_ENP2P_BCNQ_AREA_8821C BIT(0)
/* 2 REG_BCN_CTRL_CLINT2_8821C */
#define BIT_CLI2_DIS_RX_BSSID_FIT_8821C BIT(6)
#define BIT_CLI2_DIS_TSF_UDT_8821C BIT(4)
#define BIT_CLI2_EN_BCN_FUNCTION_8821C BIT(3)
#define BIT_CLI2_EN_RXBCN_RPT_8821C BIT(2)
#define BIT_CLI2_ENP2P_CTWINDOW_8821C BIT(1)
#define BIT_CLI2_ENP2P_BCNQ_AREA_8821C BIT(0)
/* 2 REG_BCN_CTRL_CLINT3_8821C */
#define BIT_CLI3_DIS_RX_BSSID_FIT_8821C BIT(6)
#define BIT_CLI3_DIS_TSF_UDT_8821C BIT(4)
#define BIT_CLI3_EN_BCN_FUNCTION_8821C BIT(3)
#define BIT_CLI3_EN_RXBCN_RPT_8821C BIT(2)
#define BIT_CLI3_ENP2P_CTWINDOW_8821C BIT(1)
#define BIT_CLI3_ENP2P_BCNQ_AREA_8821C BIT(0)
/* 2 REG_EXTEND_CTRL_8821C */
#define BIT_EN_TSFBIT32_RST_P2P2_8821C BIT(5)
#define BIT_EN_TSFBIT32_RST_P2P1_8821C BIT(4)
#define BIT_SHIFT_PORT_SEL_8821C 0
#define BIT_MASK_PORT_SEL_8821C 0x7
#define BIT_PORT_SEL_8821C(x) \
(((x) & BIT_MASK_PORT_SEL_8821C) << BIT_SHIFT_PORT_SEL_8821C)
#define BITS_PORT_SEL_8821C \
(BIT_MASK_PORT_SEL_8821C << BIT_SHIFT_PORT_SEL_8821C)
#define BIT_CLEAR_PORT_SEL_8821C(x) ((x) & (~BITS_PORT_SEL_8821C))
#define BIT_GET_PORT_SEL_8821C(x) \
(((x) >> BIT_SHIFT_PORT_SEL_8821C) & BIT_MASK_PORT_SEL_8821C)
#define BIT_SET_PORT_SEL_8821C(x, v) \
(BIT_CLEAR_PORT_SEL_8821C(x) | BIT_PORT_SEL_8821C(v))
/* 2 REG_P2PPS1_SPEC_STATE_8821C */
#define BIT_P2P1_SPEC_POWER_STATE_8821C BIT(7)
#define BIT_P2P1_SPEC_CTWINDOW_ON_8821C BIT(6)
#define BIT_P2P1_SPEC_BCN_AREA_ON_8821C BIT(5)
#define BIT_P2P1_SPEC_CTWIN_EARLY_DISTX_8821C BIT(4)
#define BIT_P2P1_SPEC_NOA1_OFF_PERIOD_8821C BIT(3)
#define BIT_P2P1_SPEC_FORCE_DOZE1_8821C BIT(2)
#define BIT_P2P1_SPEC_NOA0_OFF_PERIOD_8821C BIT(1)
#define BIT_P2P1_SPEC_FORCE_DOZE0_8821C BIT(0)
/* 2 REG_P2PPS1_STATE_8821C */
#define BIT_P2P1_POWER_STATE_8821C BIT(7)
#define BIT_P2P1_CTWINDOW_ON_8821C BIT(6)
#define BIT_P2P1_BEACON_AREA_ON_8821C BIT(5)
#define BIT_P2P1_CTWIN_EARLY_DISTX_8821C BIT(4)
#define BIT_P2P1_NOA1_OFF_PERIOD_8821C BIT(3)
#define BIT_P2P1_FORCE_DOZE1_8821C BIT(2)
#define BIT_P2P1_NOA0_OFF_PERIOD_8821C BIT(1)
#define BIT_P2P1_FORCE_DOZE0_8821C BIT(0)
/* 2 REG_P2PPS2_SPEC_STATE_8821C */
#define BIT_P2P2_SPEC_POWER_STATE_8821C BIT(7)
#define BIT_P2P2_SPEC_CTWINDOW_ON_8821C BIT(6)
#define BIT_P2P2_SPEC_BCN_AREA_ON_8821C BIT(5)
#define BIT_P2P2_SPEC_CTWIN_EARLY_DISTX_8821C BIT(4)
#define BIT_P2P2_SPEC_NOA1_OFF_PERIOD_8821C BIT(3)
#define BIT_P2P2_SPEC_FORCE_DOZE1_8821C BIT(2)
#define BIT_P2P2_SPEC_NOA0_OFF_PERIOD_8821C BIT(1)
#define BIT_P2P2_SPEC_FORCE_DOZE0_8821C BIT(0)
/* 2 REG_P2PPS2_STATE_8821C */
#define BIT_P2P2_POWER_STATE_8821C BIT(7)
#define BIT_P2P2_CTWINDOW_ON_8821C BIT(6)
#define BIT_P2P2_BEACON_AREA_ON_8821C BIT(5)
#define BIT_P2P2_CTWIN_EARLY_DISTX_8821C BIT(4)
#define BIT_P2P2_NOA1_OFF_PERIOD_8821C BIT(3)
#define BIT_P2P2_FORCE_DOZE1_8821C BIT(2)
#define BIT_P2P2_NOA0_OFF_PERIOD_8821C BIT(1)
#define BIT_P2P2_FORCE_DOZE0_8821C BIT(0)
/* 2 REG_PS_TIMER0_8821C */
#define BIT_SHIFT_PSTIMER0_INT_8821C 5
#define BIT_MASK_PSTIMER0_INT_8821C 0x7ffffff
#define BIT_PSTIMER0_INT_8821C(x) \
(((x) & BIT_MASK_PSTIMER0_INT_8821C) << BIT_SHIFT_PSTIMER0_INT_8821C)
#define BITS_PSTIMER0_INT_8821C \
(BIT_MASK_PSTIMER0_INT_8821C << BIT_SHIFT_PSTIMER0_INT_8821C)
#define BIT_CLEAR_PSTIMER0_INT_8821C(x) ((x) & (~BITS_PSTIMER0_INT_8821C))
#define BIT_GET_PSTIMER0_INT_8821C(x) \
(((x) >> BIT_SHIFT_PSTIMER0_INT_8821C) & BIT_MASK_PSTIMER0_INT_8821C)
#define BIT_SET_PSTIMER0_INT_8821C(x, v) \
(BIT_CLEAR_PSTIMER0_INT_8821C(x) | BIT_PSTIMER0_INT_8821C(v))
/* 2 REG_PS_TIMER1_8821C */
#define BIT_SHIFT_PSTIMER1_INT_8821C 5
#define BIT_MASK_PSTIMER1_INT_8821C 0x7ffffff
#define BIT_PSTIMER1_INT_8821C(x) \
(((x) & BIT_MASK_PSTIMER1_INT_8821C) << BIT_SHIFT_PSTIMER1_INT_8821C)
#define BITS_PSTIMER1_INT_8821C \
(BIT_MASK_PSTIMER1_INT_8821C << BIT_SHIFT_PSTIMER1_INT_8821C)
#define BIT_CLEAR_PSTIMER1_INT_8821C(x) ((x) & (~BITS_PSTIMER1_INT_8821C))
#define BIT_GET_PSTIMER1_INT_8821C(x) \
(((x) >> BIT_SHIFT_PSTIMER1_INT_8821C) & BIT_MASK_PSTIMER1_INT_8821C)
#define BIT_SET_PSTIMER1_INT_8821C(x, v) \
(BIT_CLEAR_PSTIMER1_INT_8821C(x) | BIT_PSTIMER1_INT_8821C(v))
/* 2 REG_PS_TIMER2_8821C */
#define BIT_SHIFT_PSTIMER2_INT_8821C 5
#define BIT_MASK_PSTIMER2_INT_8821C 0x7ffffff
#define BIT_PSTIMER2_INT_8821C(x) \
(((x) & BIT_MASK_PSTIMER2_INT_8821C) << BIT_SHIFT_PSTIMER2_INT_8821C)
#define BITS_PSTIMER2_INT_8821C \
(BIT_MASK_PSTIMER2_INT_8821C << BIT_SHIFT_PSTIMER2_INT_8821C)
#define BIT_CLEAR_PSTIMER2_INT_8821C(x) ((x) & (~BITS_PSTIMER2_INT_8821C))
#define BIT_GET_PSTIMER2_INT_8821C(x) \
(((x) >> BIT_SHIFT_PSTIMER2_INT_8821C) & BIT_MASK_PSTIMER2_INT_8821C)
#define BIT_SET_PSTIMER2_INT_8821C(x, v) \
(BIT_CLEAR_PSTIMER2_INT_8821C(x) | BIT_PSTIMER2_INT_8821C(v))
/* 2 REG_TBTT_CTN_AREA_8821C */
#define BIT_SHIFT_TBTT_CTN_AREA_8821C 0
#define BIT_MASK_TBTT_CTN_AREA_8821C 0xff
#define BIT_TBTT_CTN_AREA_8821C(x) \
(((x) & BIT_MASK_TBTT_CTN_AREA_8821C) << BIT_SHIFT_TBTT_CTN_AREA_8821C)
#define BITS_TBTT_CTN_AREA_8821C \
(BIT_MASK_TBTT_CTN_AREA_8821C << BIT_SHIFT_TBTT_CTN_AREA_8821C)
#define BIT_CLEAR_TBTT_CTN_AREA_8821C(x) ((x) & (~BITS_TBTT_CTN_AREA_8821C))
#define BIT_GET_TBTT_CTN_AREA_8821C(x) \
(((x) >> BIT_SHIFT_TBTT_CTN_AREA_8821C) & BIT_MASK_TBTT_CTN_AREA_8821C)
#define BIT_SET_TBTT_CTN_AREA_8821C(x, v) \
(BIT_CLEAR_TBTT_CTN_AREA_8821C(x) | BIT_TBTT_CTN_AREA_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_FORCE_BCN_IFS_8821C */
#define BIT_SHIFT_FORCE_BCN_IFS_8821C 0
#define BIT_MASK_FORCE_BCN_IFS_8821C 0xff
#define BIT_FORCE_BCN_IFS_8821C(x) \
(((x) & BIT_MASK_FORCE_BCN_IFS_8821C) << BIT_SHIFT_FORCE_BCN_IFS_8821C)
#define BITS_FORCE_BCN_IFS_8821C \
(BIT_MASK_FORCE_BCN_IFS_8821C << BIT_SHIFT_FORCE_BCN_IFS_8821C)
#define BIT_CLEAR_FORCE_BCN_IFS_8821C(x) ((x) & (~BITS_FORCE_BCN_IFS_8821C))
#define BIT_GET_FORCE_BCN_IFS_8821C(x) \
(((x) >> BIT_SHIFT_FORCE_BCN_IFS_8821C) & BIT_MASK_FORCE_BCN_IFS_8821C)
#define BIT_SET_FORCE_BCN_IFS_8821C(x, v) \
(BIT_CLEAR_FORCE_BCN_IFS_8821C(x) | BIT_FORCE_BCN_IFS_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_TXOP_MIN_8821C */
#define BIT_SHIFT_TXOP_MIN_8821C 0
#define BIT_MASK_TXOP_MIN_8821C 0x3fff
#define BIT_TXOP_MIN_8821C(x) \
(((x) & BIT_MASK_TXOP_MIN_8821C) << BIT_SHIFT_TXOP_MIN_8821C)
#define BITS_TXOP_MIN_8821C \
(BIT_MASK_TXOP_MIN_8821C << BIT_SHIFT_TXOP_MIN_8821C)
#define BIT_CLEAR_TXOP_MIN_8821C(x) ((x) & (~BITS_TXOP_MIN_8821C))
#define BIT_GET_TXOP_MIN_8821C(x) \
(((x) >> BIT_SHIFT_TXOP_MIN_8821C) & BIT_MASK_TXOP_MIN_8821C)
#define BIT_SET_TXOP_MIN_8821C(x, v) \
(BIT_CLEAR_TXOP_MIN_8821C(x) | BIT_TXOP_MIN_8821C(v))
/* 2 REG_PRE_BKF_TIME_8821C */
#define BIT_SHIFT_PRE_BKF_TIME_8821C 0
#define BIT_MASK_PRE_BKF_TIME_8821C 0xff
#define BIT_PRE_BKF_TIME_8821C(x) \
(((x) & BIT_MASK_PRE_BKF_TIME_8821C) << BIT_SHIFT_PRE_BKF_TIME_8821C)
#define BITS_PRE_BKF_TIME_8821C \
(BIT_MASK_PRE_BKF_TIME_8821C << BIT_SHIFT_PRE_BKF_TIME_8821C)
#define BIT_CLEAR_PRE_BKF_TIME_8821C(x) ((x) & (~BITS_PRE_BKF_TIME_8821C))
#define BIT_GET_PRE_BKF_TIME_8821C(x) \
(((x) >> BIT_SHIFT_PRE_BKF_TIME_8821C) & BIT_MASK_PRE_BKF_TIME_8821C)
#define BIT_SET_PRE_BKF_TIME_8821C(x, v) \
(BIT_CLEAR_PRE_BKF_TIME_8821C(x) | BIT_PRE_BKF_TIME_8821C(v))
/* 2 REG_CROSS_TXOP_CTRL_8821C */
#define BIT_TXFAIL_BREACK_TXOP_EN_8821C BIT(3)
#define BIT_DTIM_BYPASS_8821C BIT(2)
#define BIT_RTS_NAV_TXOP_8821C BIT(1)
#define BIT_NOT_CROSS_TXOP_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_ATIMWND2_8821C */
#define BIT_SHIFT_ATIMWND2_8821C 0
#define BIT_MASK_ATIMWND2_8821C 0xff
#define BIT_ATIMWND2_8821C(x) \
(((x) & BIT_MASK_ATIMWND2_8821C) << BIT_SHIFT_ATIMWND2_8821C)
#define BITS_ATIMWND2_8821C \
(BIT_MASK_ATIMWND2_8821C << BIT_SHIFT_ATIMWND2_8821C)
#define BIT_CLEAR_ATIMWND2_8821C(x) ((x) & (~BITS_ATIMWND2_8821C))
#define BIT_GET_ATIMWND2_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND2_8821C) & BIT_MASK_ATIMWND2_8821C)
#define BIT_SET_ATIMWND2_8821C(x, v) \
(BIT_CLEAR_ATIMWND2_8821C(x) | BIT_ATIMWND2_8821C(v))
/* 2 REG_ATIMWND3_8821C */
#define BIT_SHIFT_ATIMWND3_8821C 0
#define BIT_MASK_ATIMWND3_8821C 0xff
#define BIT_ATIMWND3_8821C(x) \
(((x) & BIT_MASK_ATIMWND3_8821C) << BIT_SHIFT_ATIMWND3_8821C)
#define BITS_ATIMWND3_8821C \
(BIT_MASK_ATIMWND3_8821C << BIT_SHIFT_ATIMWND3_8821C)
#define BIT_CLEAR_ATIMWND3_8821C(x) ((x) & (~BITS_ATIMWND3_8821C))
#define BIT_GET_ATIMWND3_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND3_8821C) & BIT_MASK_ATIMWND3_8821C)
#define BIT_SET_ATIMWND3_8821C(x, v) \
(BIT_CLEAR_ATIMWND3_8821C(x) | BIT_ATIMWND3_8821C(v))
/* 2 REG_ATIMWND4_8821C */
#define BIT_SHIFT_ATIMWND4_8821C 0
#define BIT_MASK_ATIMWND4_8821C 0xff
#define BIT_ATIMWND4_8821C(x) \
(((x) & BIT_MASK_ATIMWND4_8821C) << BIT_SHIFT_ATIMWND4_8821C)
#define BITS_ATIMWND4_8821C \
(BIT_MASK_ATIMWND4_8821C << BIT_SHIFT_ATIMWND4_8821C)
#define BIT_CLEAR_ATIMWND4_8821C(x) ((x) & (~BITS_ATIMWND4_8821C))
#define BIT_GET_ATIMWND4_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND4_8821C) & BIT_MASK_ATIMWND4_8821C)
#define BIT_SET_ATIMWND4_8821C(x, v) \
(BIT_CLEAR_ATIMWND4_8821C(x) | BIT_ATIMWND4_8821C(v))
/* 2 REG_ATIMWND5_8821C */
#define BIT_SHIFT_ATIMWND5_8821C 0
#define BIT_MASK_ATIMWND5_8821C 0xff
#define BIT_ATIMWND5_8821C(x) \
(((x) & BIT_MASK_ATIMWND5_8821C) << BIT_SHIFT_ATIMWND5_8821C)
#define BITS_ATIMWND5_8821C \
(BIT_MASK_ATIMWND5_8821C << BIT_SHIFT_ATIMWND5_8821C)
#define BIT_CLEAR_ATIMWND5_8821C(x) ((x) & (~BITS_ATIMWND5_8821C))
#define BIT_GET_ATIMWND5_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND5_8821C) & BIT_MASK_ATIMWND5_8821C)
#define BIT_SET_ATIMWND5_8821C(x, v) \
(BIT_CLEAR_ATIMWND5_8821C(x) | BIT_ATIMWND5_8821C(v))
/* 2 REG_ATIMWND6_8821C */
#define BIT_SHIFT_ATIMWND6_8821C 0
#define BIT_MASK_ATIMWND6_8821C 0xff
#define BIT_ATIMWND6_8821C(x) \
(((x) & BIT_MASK_ATIMWND6_8821C) << BIT_SHIFT_ATIMWND6_8821C)
#define BITS_ATIMWND6_8821C \
(BIT_MASK_ATIMWND6_8821C << BIT_SHIFT_ATIMWND6_8821C)
#define BIT_CLEAR_ATIMWND6_8821C(x) ((x) & (~BITS_ATIMWND6_8821C))
#define BIT_GET_ATIMWND6_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND6_8821C) & BIT_MASK_ATIMWND6_8821C)
#define BIT_SET_ATIMWND6_8821C(x, v) \
(BIT_CLEAR_ATIMWND6_8821C(x) | BIT_ATIMWND6_8821C(v))
/* 2 REG_ATIMWND7_8821C */
#define BIT_SHIFT_ATIMWND7_8821C 0
#define BIT_MASK_ATIMWND7_8821C 0xff
#define BIT_ATIMWND7_8821C(x) \
(((x) & BIT_MASK_ATIMWND7_8821C) << BIT_SHIFT_ATIMWND7_8821C)
#define BITS_ATIMWND7_8821C \
(BIT_MASK_ATIMWND7_8821C << BIT_SHIFT_ATIMWND7_8821C)
#define BIT_CLEAR_ATIMWND7_8821C(x) ((x) & (~BITS_ATIMWND7_8821C))
#define BIT_GET_ATIMWND7_8821C(x) \
(((x) >> BIT_SHIFT_ATIMWND7_8821C) & BIT_MASK_ATIMWND7_8821C)
#define BIT_SET_ATIMWND7_8821C(x, v) \
(BIT_CLEAR_ATIMWND7_8821C(x) | BIT_ATIMWND7_8821C(v))
/* 2 REG_ATIMUGT_8821C */
#define BIT_SHIFT_ATIM_URGENT_8821C 0
#define BIT_MASK_ATIM_URGENT_8821C 0xff
#define BIT_ATIM_URGENT_8821C(x) \
(((x) & BIT_MASK_ATIM_URGENT_8821C) << BIT_SHIFT_ATIM_URGENT_8821C)
#define BITS_ATIM_URGENT_8821C \
(BIT_MASK_ATIM_URGENT_8821C << BIT_SHIFT_ATIM_URGENT_8821C)
#define BIT_CLEAR_ATIM_URGENT_8821C(x) ((x) & (~BITS_ATIM_URGENT_8821C))
#define BIT_GET_ATIM_URGENT_8821C(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT_8821C) & BIT_MASK_ATIM_URGENT_8821C)
#define BIT_SET_ATIM_URGENT_8821C(x, v) \
(BIT_CLEAR_ATIM_URGENT_8821C(x) | BIT_ATIM_URGENT_8821C(v))
/* 2 REG_HIQ_NO_LMT_EN_8821C */
#define BIT_HIQ_NO_LMT_EN_VAP7_8821C BIT(7)
#define BIT_HIQ_NO_LMT_EN_VAP6_8821C BIT(6)
#define BIT_HIQ_NO_LMT_EN_VAP5_8821C BIT(5)
#define BIT_HIQ_NO_LMT_EN_VAP4_8821C BIT(4)
#define BIT_HIQ_NO_LMT_EN_VAP3_8821C BIT(3)
#define BIT_HIQ_NO_LMT_EN_VAP2_8821C BIT(2)
#define BIT_HIQ_NO_LMT_EN_VAP1_8821C BIT(1)
#define BIT_HIQ_NO_LMT_EN_ROOT_8821C BIT(0)
/* 2 REG_DTIM_COUNTER_ROOT_8821C */
#define BIT_SHIFT_DTIM_COUNT_ROOT_8821C 0
#define BIT_MASK_DTIM_COUNT_ROOT_8821C 0xff
#define BIT_DTIM_COUNT_ROOT_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_ROOT_8821C) \
<< BIT_SHIFT_DTIM_COUNT_ROOT_8821C)
#define BITS_DTIM_COUNT_ROOT_8821C \
(BIT_MASK_DTIM_COUNT_ROOT_8821C << BIT_SHIFT_DTIM_COUNT_ROOT_8821C)
#define BIT_CLEAR_DTIM_COUNT_ROOT_8821C(x) ((x) & (~BITS_DTIM_COUNT_ROOT_8821C))
#define BIT_GET_DTIM_COUNT_ROOT_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_ROOT_8821C) & \
BIT_MASK_DTIM_COUNT_ROOT_8821C)
#define BIT_SET_DTIM_COUNT_ROOT_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_ROOT_8821C(x) | BIT_DTIM_COUNT_ROOT_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP1_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP1_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP1_8821C 0xff
#define BIT_DTIM_COUNT_VAP1_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP1_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP1_8821C)
#define BITS_DTIM_COUNT_VAP1_8821C \
(BIT_MASK_DTIM_COUNT_VAP1_8821C << BIT_SHIFT_DTIM_COUNT_VAP1_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP1_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP1_8821C))
#define BIT_GET_DTIM_COUNT_VAP1_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP1_8821C) & \
BIT_MASK_DTIM_COUNT_VAP1_8821C)
#define BIT_SET_DTIM_COUNT_VAP1_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP1_8821C(x) | BIT_DTIM_COUNT_VAP1_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP2_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP2_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP2_8821C 0xff
#define BIT_DTIM_COUNT_VAP2_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP2_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP2_8821C)
#define BITS_DTIM_COUNT_VAP2_8821C \
(BIT_MASK_DTIM_COUNT_VAP2_8821C << BIT_SHIFT_DTIM_COUNT_VAP2_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP2_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP2_8821C))
#define BIT_GET_DTIM_COUNT_VAP2_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP2_8821C) & \
BIT_MASK_DTIM_COUNT_VAP2_8821C)
#define BIT_SET_DTIM_COUNT_VAP2_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP2_8821C(x) | BIT_DTIM_COUNT_VAP2_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP3_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP3_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP3_8821C 0xff
#define BIT_DTIM_COUNT_VAP3_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP3_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP3_8821C)
#define BITS_DTIM_COUNT_VAP3_8821C \
(BIT_MASK_DTIM_COUNT_VAP3_8821C << BIT_SHIFT_DTIM_COUNT_VAP3_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP3_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP3_8821C))
#define BIT_GET_DTIM_COUNT_VAP3_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP3_8821C) & \
BIT_MASK_DTIM_COUNT_VAP3_8821C)
#define BIT_SET_DTIM_COUNT_VAP3_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP3_8821C(x) | BIT_DTIM_COUNT_VAP3_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP4_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP4_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP4_8821C 0xff
#define BIT_DTIM_COUNT_VAP4_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP4_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP4_8821C)
#define BITS_DTIM_COUNT_VAP4_8821C \
(BIT_MASK_DTIM_COUNT_VAP4_8821C << BIT_SHIFT_DTIM_COUNT_VAP4_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP4_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP4_8821C))
#define BIT_GET_DTIM_COUNT_VAP4_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP4_8821C) & \
BIT_MASK_DTIM_COUNT_VAP4_8821C)
#define BIT_SET_DTIM_COUNT_VAP4_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP4_8821C(x) | BIT_DTIM_COUNT_VAP4_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP5_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP5_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP5_8821C 0xff
#define BIT_DTIM_COUNT_VAP5_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP5_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP5_8821C)
#define BITS_DTIM_COUNT_VAP5_8821C \
(BIT_MASK_DTIM_COUNT_VAP5_8821C << BIT_SHIFT_DTIM_COUNT_VAP5_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP5_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP5_8821C))
#define BIT_GET_DTIM_COUNT_VAP5_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP5_8821C) & \
BIT_MASK_DTIM_COUNT_VAP5_8821C)
#define BIT_SET_DTIM_COUNT_VAP5_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP5_8821C(x) | BIT_DTIM_COUNT_VAP5_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP6_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP6_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP6_8821C 0xff
#define BIT_DTIM_COUNT_VAP6_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP6_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP6_8821C)
#define BITS_DTIM_COUNT_VAP6_8821C \
(BIT_MASK_DTIM_COUNT_VAP6_8821C << BIT_SHIFT_DTIM_COUNT_VAP6_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP6_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP6_8821C))
#define BIT_GET_DTIM_COUNT_VAP6_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP6_8821C) & \
BIT_MASK_DTIM_COUNT_VAP6_8821C)
#define BIT_SET_DTIM_COUNT_VAP6_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP6_8821C(x) | BIT_DTIM_COUNT_VAP6_8821C(v))
/* 2 REG_DTIM_COUNTER_VAP7_8821C */
#define BIT_SHIFT_DTIM_COUNT_VAP7_8821C 0
#define BIT_MASK_DTIM_COUNT_VAP7_8821C 0xff
#define BIT_DTIM_COUNT_VAP7_8821C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP7_8821C) \
<< BIT_SHIFT_DTIM_COUNT_VAP7_8821C)
#define BITS_DTIM_COUNT_VAP7_8821C \
(BIT_MASK_DTIM_COUNT_VAP7_8821C << BIT_SHIFT_DTIM_COUNT_VAP7_8821C)
#define BIT_CLEAR_DTIM_COUNT_VAP7_8821C(x) ((x) & (~BITS_DTIM_COUNT_VAP7_8821C))
#define BIT_GET_DTIM_COUNT_VAP7_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP7_8821C) & \
BIT_MASK_DTIM_COUNT_VAP7_8821C)
#define BIT_SET_DTIM_COUNT_VAP7_8821C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP7_8821C(x) | BIT_DTIM_COUNT_VAP7_8821C(v))
/* 2 REG_DIS_ATIM_8821C */
#define BIT_DIS_ATIM_VAP7_8821C BIT(7)
#define BIT_DIS_ATIM_VAP6_8821C BIT(6)
#define BIT_DIS_ATIM_VAP5_8821C BIT(5)
#define BIT_DIS_ATIM_VAP4_8821C BIT(4)
#define BIT_DIS_ATIM_VAP3_8821C BIT(3)
#define BIT_DIS_ATIM_VAP2_8821C BIT(2)
#define BIT_DIS_ATIM_VAP1_8821C BIT(1)
#define BIT_DIS_ATIM_ROOT_8821C BIT(0)
/* 2 REG_EARLY_128US_8821C */
#define BIT_SHIFT_TSFT_SEL_TIMER1_8821C 3
#define BIT_MASK_TSFT_SEL_TIMER1_8821C 0x7
#define BIT_TSFT_SEL_TIMER1_8821C(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER1_8821C) \
<< BIT_SHIFT_TSFT_SEL_TIMER1_8821C)
#define BITS_TSFT_SEL_TIMER1_8821C \
(BIT_MASK_TSFT_SEL_TIMER1_8821C << BIT_SHIFT_TSFT_SEL_TIMER1_8821C)
#define BIT_CLEAR_TSFT_SEL_TIMER1_8821C(x) ((x) & (~BITS_TSFT_SEL_TIMER1_8821C))
#define BIT_GET_TSFT_SEL_TIMER1_8821C(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER1_8821C) & \
BIT_MASK_TSFT_SEL_TIMER1_8821C)
#define BIT_SET_TSFT_SEL_TIMER1_8821C(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER1_8821C(x) | BIT_TSFT_SEL_TIMER1_8821C(v))
#define BIT_SHIFT_EARLY_128US_8821C 0
#define BIT_MASK_EARLY_128US_8821C 0x7
#define BIT_EARLY_128US_8821C(x) \
(((x) & BIT_MASK_EARLY_128US_8821C) << BIT_SHIFT_EARLY_128US_8821C)
#define BITS_EARLY_128US_8821C \
(BIT_MASK_EARLY_128US_8821C << BIT_SHIFT_EARLY_128US_8821C)
#define BIT_CLEAR_EARLY_128US_8821C(x) ((x) & (~BITS_EARLY_128US_8821C))
#define BIT_GET_EARLY_128US_8821C(x) \
(((x) >> BIT_SHIFT_EARLY_128US_8821C) & BIT_MASK_EARLY_128US_8821C)
#define BIT_SET_EARLY_128US_8821C(x, v) \
(BIT_CLEAR_EARLY_128US_8821C(x) | BIT_EARLY_128US_8821C(v))
/* 2 REG_P2PPS1_CTRL_8821C */
#define BIT_P2P1_CTW_ALLSTASLEEP_8821C BIT(7)
#define BIT_P2P1_OFF_DISTX_EN_8821C BIT(6)
#define BIT_P2P1_PWR_MGT_EN_8821C BIT(5)
#define BIT_P2P1_NOA1_EN_8821C BIT(2)
#define BIT_P2P1_NOA0_EN_8821C BIT(1)
/* 2 REG_P2PPS2_CTRL_8821C */
#define BIT_P2P2_CTW_ALLSTASLEEP_8821C BIT(7)
#define BIT_P2P2_OFF_DISTX_EN_8821C BIT(6)
#define BIT_P2P2_PWR_MGT_EN_8821C BIT(5)
#define BIT_P2P2_NOA1_EN_8821C BIT(2)
#define BIT_P2P2_NOA0_EN_8821C BIT(1)
/* 2 REG_TIMER0_SRC_SEL_8821C */
#define BIT_SHIFT_SYNC_CLI_SEL_8821C 4
#define BIT_MASK_SYNC_CLI_SEL_8821C 0x7
#define BIT_SYNC_CLI_SEL_8821C(x) \
(((x) & BIT_MASK_SYNC_CLI_SEL_8821C) << BIT_SHIFT_SYNC_CLI_SEL_8821C)
#define BITS_SYNC_CLI_SEL_8821C \
(BIT_MASK_SYNC_CLI_SEL_8821C << BIT_SHIFT_SYNC_CLI_SEL_8821C)
#define BIT_CLEAR_SYNC_CLI_SEL_8821C(x) ((x) & (~BITS_SYNC_CLI_SEL_8821C))
#define BIT_GET_SYNC_CLI_SEL_8821C(x) \
(((x) >> BIT_SHIFT_SYNC_CLI_SEL_8821C) & BIT_MASK_SYNC_CLI_SEL_8821C)
#define BIT_SET_SYNC_CLI_SEL_8821C(x, v) \
(BIT_CLEAR_SYNC_CLI_SEL_8821C(x) | BIT_SYNC_CLI_SEL_8821C(v))
#define BIT_SHIFT_TSFT_SEL_TIMER0_8821C 0
#define BIT_MASK_TSFT_SEL_TIMER0_8821C 0x7
#define BIT_TSFT_SEL_TIMER0_8821C(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER0_8821C) \
<< BIT_SHIFT_TSFT_SEL_TIMER0_8821C)
#define BITS_TSFT_SEL_TIMER0_8821C \
(BIT_MASK_TSFT_SEL_TIMER0_8821C << BIT_SHIFT_TSFT_SEL_TIMER0_8821C)
#define BIT_CLEAR_TSFT_SEL_TIMER0_8821C(x) ((x) & (~BITS_TSFT_SEL_TIMER0_8821C))
#define BIT_GET_TSFT_SEL_TIMER0_8821C(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER0_8821C) & \
BIT_MASK_TSFT_SEL_TIMER0_8821C)
#define BIT_SET_TSFT_SEL_TIMER0_8821C(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER0_8821C(x) | BIT_TSFT_SEL_TIMER0_8821C(v))
/* 2 REG_NOA_UNIT_SEL_8821C */
#define BIT_SHIFT_NOA_UNIT2_SEL_8821C 8
#define BIT_MASK_NOA_UNIT2_SEL_8821C 0x7
#define BIT_NOA_UNIT2_SEL_8821C(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL_8821C) << BIT_SHIFT_NOA_UNIT2_SEL_8821C)
#define BITS_NOA_UNIT2_SEL_8821C \
(BIT_MASK_NOA_UNIT2_SEL_8821C << BIT_SHIFT_NOA_UNIT2_SEL_8821C)
#define BIT_CLEAR_NOA_UNIT2_SEL_8821C(x) ((x) & (~BITS_NOA_UNIT2_SEL_8821C))
#define BIT_GET_NOA_UNIT2_SEL_8821C(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL_8821C) & BIT_MASK_NOA_UNIT2_SEL_8821C)
#define BIT_SET_NOA_UNIT2_SEL_8821C(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL_8821C(x) | BIT_NOA_UNIT2_SEL_8821C(v))
#define BIT_SHIFT_NOA_UNIT1_SEL_8821C 4
#define BIT_MASK_NOA_UNIT1_SEL_8821C 0x7
#define BIT_NOA_UNIT1_SEL_8821C(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL_8821C) << BIT_SHIFT_NOA_UNIT1_SEL_8821C)
#define BITS_NOA_UNIT1_SEL_8821C \
(BIT_MASK_NOA_UNIT1_SEL_8821C << BIT_SHIFT_NOA_UNIT1_SEL_8821C)
#define BIT_CLEAR_NOA_UNIT1_SEL_8821C(x) ((x) & (~BITS_NOA_UNIT1_SEL_8821C))
#define BIT_GET_NOA_UNIT1_SEL_8821C(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL_8821C) & BIT_MASK_NOA_UNIT1_SEL_8821C)
#define BIT_SET_NOA_UNIT1_SEL_8821C(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL_8821C(x) | BIT_NOA_UNIT1_SEL_8821C(v))
#define BIT_SHIFT_NOA_UNIT0_SEL_8821C 0
#define BIT_MASK_NOA_UNIT0_SEL_8821C 0x7
#define BIT_NOA_UNIT0_SEL_8821C(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL_8821C) << BIT_SHIFT_NOA_UNIT0_SEL_8821C)
#define BITS_NOA_UNIT0_SEL_8821C \
(BIT_MASK_NOA_UNIT0_SEL_8821C << BIT_SHIFT_NOA_UNIT0_SEL_8821C)
#define BIT_CLEAR_NOA_UNIT0_SEL_8821C(x) ((x) & (~BITS_NOA_UNIT0_SEL_8821C))
#define BIT_GET_NOA_UNIT0_SEL_8821C(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL_8821C) & BIT_MASK_NOA_UNIT0_SEL_8821C)
#define BIT_SET_NOA_UNIT0_SEL_8821C(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL_8821C(x) | BIT_NOA_UNIT0_SEL_8821C(v))
/* 2 REG_P2POFF_DIS_TXTIME_8821C */
#define BIT_SHIFT_P2POFF_DIS_TXTIME_8821C 0
#define BIT_MASK_P2POFF_DIS_TXTIME_8821C 0xff
#define BIT_P2POFF_DIS_TXTIME_8821C(x) \
(((x) & BIT_MASK_P2POFF_DIS_TXTIME_8821C) \
<< BIT_SHIFT_P2POFF_DIS_TXTIME_8821C)
#define BITS_P2POFF_DIS_TXTIME_8821C \
(BIT_MASK_P2POFF_DIS_TXTIME_8821C << BIT_SHIFT_P2POFF_DIS_TXTIME_8821C)
#define BIT_CLEAR_P2POFF_DIS_TXTIME_8821C(x) \
((x) & (~BITS_P2POFF_DIS_TXTIME_8821C))
#define BIT_GET_P2POFF_DIS_TXTIME_8821C(x) \
(((x) >> BIT_SHIFT_P2POFF_DIS_TXTIME_8821C) & \
BIT_MASK_P2POFF_DIS_TXTIME_8821C)
#define BIT_SET_P2POFF_DIS_TXTIME_8821C(x, v) \
(BIT_CLEAR_P2POFF_DIS_TXTIME_8821C(x) | BIT_P2POFF_DIS_TXTIME_8821C(v))
/* 2 REG_MBSSID_BCN_SPACE2_8821C */
#define BIT_SHIFT_BCN_SPACE_CLINT2_8821C 16
#define BIT_MASK_BCN_SPACE_CLINT2_8821C 0xfff
#define BIT_BCN_SPACE_CLINT2_8821C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT2_8821C) \
<< BIT_SHIFT_BCN_SPACE_CLINT2_8821C)
#define BITS_BCN_SPACE_CLINT2_8821C \
(BIT_MASK_BCN_SPACE_CLINT2_8821C << BIT_SHIFT_BCN_SPACE_CLINT2_8821C)
#define BIT_CLEAR_BCN_SPACE_CLINT2_8821C(x) \
((x) & (~BITS_BCN_SPACE_CLINT2_8821C))
#define BIT_GET_BCN_SPACE_CLINT2_8821C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT2_8821C) & \
BIT_MASK_BCN_SPACE_CLINT2_8821C)
#define BIT_SET_BCN_SPACE_CLINT2_8821C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT2_8821C(x) | BIT_BCN_SPACE_CLINT2_8821C(v))
#define BIT_SHIFT_BCN_SPACE_CLINT1_8821C 0
#define BIT_MASK_BCN_SPACE_CLINT1_8821C 0xfff
#define BIT_BCN_SPACE_CLINT1_8821C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT1_8821C) \
<< BIT_SHIFT_BCN_SPACE_CLINT1_8821C)
#define BITS_BCN_SPACE_CLINT1_8821C \
(BIT_MASK_BCN_SPACE_CLINT1_8821C << BIT_SHIFT_BCN_SPACE_CLINT1_8821C)
#define BIT_CLEAR_BCN_SPACE_CLINT1_8821C(x) \
((x) & (~BITS_BCN_SPACE_CLINT1_8821C))
#define BIT_GET_BCN_SPACE_CLINT1_8821C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT1_8821C) & \
BIT_MASK_BCN_SPACE_CLINT1_8821C)
#define BIT_SET_BCN_SPACE_CLINT1_8821C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT1_8821C(x) | BIT_BCN_SPACE_CLINT1_8821C(v))
/* 2 REG_MBSSID_BCN_SPACE3_8821C */
#define BIT_SHIFT_SUB_BCN_SPACE_8821C 16
#define BIT_MASK_SUB_BCN_SPACE_8821C 0xff
#define BIT_SUB_BCN_SPACE_8821C(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE_8821C) << BIT_SHIFT_SUB_BCN_SPACE_8821C)
#define BITS_SUB_BCN_SPACE_8821C \
(BIT_MASK_SUB_BCN_SPACE_8821C << BIT_SHIFT_SUB_BCN_SPACE_8821C)
#define BIT_CLEAR_SUB_BCN_SPACE_8821C(x) ((x) & (~BITS_SUB_BCN_SPACE_8821C))
#define BIT_GET_SUB_BCN_SPACE_8821C(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE_8821C) & BIT_MASK_SUB_BCN_SPACE_8821C)
#define BIT_SET_SUB_BCN_SPACE_8821C(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE_8821C(x) | BIT_SUB_BCN_SPACE_8821C(v))
#define BIT_SHIFT_BCN_SPACE_CLINT3_8821C 0
#define BIT_MASK_BCN_SPACE_CLINT3_8821C 0xfff
#define BIT_BCN_SPACE_CLINT3_8821C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT3_8821C) \
<< BIT_SHIFT_BCN_SPACE_CLINT3_8821C)
#define BITS_BCN_SPACE_CLINT3_8821C \
(BIT_MASK_BCN_SPACE_CLINT3_8821C << BIT_SHIFT_BCN_SPACE_CLINT3_8821C)
#define BIT_CLEAR_BCN_SPACE_CLINT3_8821C(x) \
((x) & (~BITS_BCN_SPACE_CLINT3_8821C))
#define BIT_GET_BCN_SPACE_CLINT3_8821C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT3_8821C) & \
BIT_MASK_BCN_SPACE_CLINT3_8821C)
#define BIT_SET_BCN_SPACE_CLINT3_8821C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT3_8821C(x) | BIT_BCN_SPACE_CLINT3_8821C(v))
/* 2 REG_ACMHWCTRL_8821C */
#define BIT_BEQ_ACM_STATUS_8821C BIT(7)
#define BIT_VIQ_ACM_STATUS_8821C BIT(6)
#define BIT_VOQ_ACM_STATUS_8821C BIT(5)
#define BIT_BEQ_ACM_EN_8821C BIT(3)
#define BIT_VIQ_ACM_EN_8821C BIT(2)
#define BIT_VOQ_ACM_EN_8821C BIT(1)
#define BIT_ACMHWEN_8821C BIT(0)
/* 2 REG_ACMRSTCTRL_8821C */
#define BIT_BE_ACM_RESET_USED_TIME_8821C BIT(2)
#define BIT_VI_ACM_RESET_USED_TIME_8821C BIT(1)
#define BIT_VO_ACM_RESET_USED_TIME_8821C BIT(0)
/* 2 REG_ACMAVG_8821C */
#define BIT_SHIFT_AVGPERIOD_8821C 0
#define BIT_MASK_AVGPERIOD_8821C 0xffff
#define BIT_AVGPERIOD_8821C(x) \
(((x) & BIT_MASK_AVGPERIOD_8821C) << BIT_SHIFT_AVGPERIOD_8821C)
#define BITS_AVGPERIOD_8821C \
(BIT_MASK_AVGPERIOD_8821C << BIT_SHIFT_AVGPERIOD_8821C)
#define BIT_CLEAR_AVGPERIOD_8821C(x) ((x) & (~BITS_AVGPERIOD_8821C))
#define BIT_GET_AVGPERIOD_8821C(x) \
(((x) >> BIT_SHIFT_AVGPERIOD_8821C) & BIT_MASK_AVGPERIOD_8821C)
#define BIT_SET_AVGPERIOD_8821C(x, v) \
(BIT_CLEAR_AVGPERIOD_8821C(x) | BIT_AVGPERIOD_8821C(v))
/* 2 REG_VO_ADMTIME_8821C */
#define BIT_SHIFT_VO_ADMITTED_TIME_8821C 0
#define BIT_MASK_VO_ADMITTED_TIME_8821C 0xffff
#define BIT_VO_ADMITTED_TIME_8821C(x) \
(((x) & BIT_MASK_VO_ADMITTED_TIME_8821C) \
<< BIT_SHIFT_VO_ADMITTED_TIME_8821C)
#define BITS_VO_ADMITTED_TIME_8821C \
(BIT_MASK_VO_ADMITTED_TIME_8821C << BIT_SHIFT_VO_ADMITTED_TIME_8821C)
#define BIT_CLEAR_VO_ADMITTED_TIME_8821C(x) \
((x) & (~BITS_VO_ADMITTED_TIME_8821C))
#define BIT_GET_VO_ADMITTED_TIME_8821C(x) \
(((x) >> BIT_SHIFT_VO_ADMITTED_TIME_8821C) & \
BIT_MASK_VO_ADMITTED_TIME_8821C)
#define BIT_SET_VO_ADMITTED_TIME_8821C(x, v) \
(BIT_CLEAR_VO_ADMITTED_TIME_8821C(x) | BIT_VO_ADMITTED_TIME_8821C(v))
/* 2 REG_VI_ADMTIME_8821C */
#define BIT_SHIFT_VI_ADMITTED_TIME_8821C 0
#define BIT_MASK_VI_ADMITTED_TIME_8821C 0xffff
#define BIT_VI_ADMITTED_TIME_8821C(x) \
(((x) & BIT_MASK_VI_ADMITTED_TIME_8821C) \
<< BIT_SHIFT_VI_ADMITTED_TIME_8821C)
#define BITS_VI_ADMITTED_TIME_8821C \
(BIT_MASK_VI_ADMITTED_TIME_8821C << BIT_SHIFT_VI_ADMITTED_TIME_8821C)
#define BIT_CLEAR_VI_ADMITTED_TIME_8821C(x) \
((x) & (~BITS_VI_ADMITTED_TIME_8821C))
#define BIT_GET_VI_ADMITTED_TIME_8821C(x) \
(((x) >> BIT_SHIFT_VI_ADMITTED_TIME_8821C) & \
BIT_MASK_VI_ADMITTED_TIME_8821C)
#define BIT_SET_VI_ADMITTED_TIME_8821C(x, v) \
(BIT_CLEAR_VI_ADMITTED_TIME_8821C(x) | BIT_VI_ADMITTED_TIME_8821C(v))
/* 2 REG_BE_ADMTIME_8821C */
#define BIT_SHIFT_BE_ADMITTED_TIME_8821C 0
#define BIT_MASK_BE_ADMITTED_TIME_8821C 0xffff
#define BIT_BE_ADMITTED_TIME_8821C(x) \
(((x) & BIT_MASK_BE_ADMITTED_TIME_8821C) \
<< BIT_SHIFT_BE_ADMITTED_TIME_8821C)
#define BITS_BE_ADMITTED_TIME_8821C \
(BIT_MASK_BE_ADMITTED_TIME_8821C << BIT_SHIFT_BE_ADMITTED_TIME_8821C)
#define BIT_CLEAR_BE_ADMITTED_TIME_8821C(x) \
((x) & (~BITS_BE_ADMITTED_TIME_8821C))
#define BIT_GET_BE_ADMITTED_TIME_8821C(x) \
(((x) >> BIT_SHIFT_BE_ADMITTED_TIME_8821C) & \
BIT_MASK_BE_ADMITTED_TIME_8821C)
#define BIT_SET_BE_ADMITTED_TIME_8821C(x, v) \
(BIT_CLEAR_BE_ADMITTED_TIME_8821C(x) | BIT_BE_ADMITTED_TIME_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_EDCA_RANDOM_GEN_8821C */
#define BIT_SHIFT_RANDOM_GEN_8821C 0
#define BIT_MASK_RANDOM_GEN_8821C 0xffffff
#define BIT_RANDOM_GEN_8821C(x) \
(((x) & BIT_MASK_RANDOM_GEN_8821C) << BIT_SHIFT_RANDOM_GEN_8821C)
#define BITS_RANDOM_GEN_8821C \
(BIT_MASK_RANDOM_GEN_8821C << BIT_SHIFT_RANDOM_GEN_8821C)
#define BIT_CLEAR_RANDOM_GEN_8821C(x) ((x) & (~BITS_RANDOM_GEN_8821C))
#define BIT_GET_RANDOM_GEN_8821C(x) \
(((x) >> BIT_SHIFT_RANDOM_GEN_8821C) & BIT_MASK_RANDOM_GEN_8821C)
#define BIT_SET_RANDOM_GEN_8821C(x, v) \
(BIT_CLEAR_RANDOM_GEN_8821C(x) | BIT_RANDOM_GEN_8821C(v))
/* 2 REG_TXCMD_NOA_SEL_8821C */
#define BIT_SHIFT_NOA_SEL_V2_8821C 4
#define BIT_MASK_NOA_SEL_V2_8821C 0x7
#define BIT_NOA_SEL_V2_8821C(x) \
(((x) & BIT_MASK_NOA_SEL_V2_8821C) << BIT_SHIFT_NOA_SEL_V2_8821C)
#define BITS_NOA_SEL_V2_8821C \
(BIT_MASK_NOA_SEL_V2_8821C << BIT_SHIFT_NOA_SEL_V2_8821C)
#define BIT_CLEAR_NOA_SEL_V2_8821C(x) ((x) & (~BITS_NOA_SEL_V2_8821C))
#define BIT_GET_NOA_SEL_V2_8821C(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V2_8821C) & BIT_MASK_NOA_SEL_V2_8821C)
#define BIT_SET_NOA_SEL_V2_8821C(x, v) \
(BIT_CLEAR_NOA_SEL_V2_8821C(x) | BIT_NOA_SEL_V2_8821C(v))
#define BIT_SHIFT_TXCMD_SEG_SEL_8821C 0
#define BIT_MASK_TXCMD_SEG_SEL_8821C 0xf
#define BIT_TXCMD_SEG_SEL_8821C(x) \
(((x) & BIT_MASK_TXCMD_SEG_SEL_8821C) << BIT_SHIFT_TXCMD_SEG_SEL_8821C)
#define BITS_TXCMD_SEG_SEL_8821C \
(BIT_MASK_TXCMD_SEG_SEL_8821C << BIT_SHIFT_TXCMD_SEG_SEL_8821C)
#define BIT_CLEAR_TXCMD_SEG_SEL_8821C(x) ((x) & (~BITS_TXCMD_SEG_SEL_8821C))
#define BIT_GET_TXCMD_SEG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_TXCMD_SEG_SEL_8821C) & BIT_MASK_TXCMD_SEG_SEL_8821C)
#define BIT_SET_TXCMD_SEG_SEL_8821C(x, v) \
(BIT_CLEAR_TXCMD_SEG_SEL_8821C(x) | BIT_TXCMD_SEG_SEL_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOA_PARAM_8821C */
#define BIT_SHIFT_NOA_DURATION_V1_8821C 0
#define BIT_MASK_NOA_DURATION_V1_8821C 0xffffffffL
#define BIT_NOA_DURATION_V1_8821C(x) \
(((x) & BIT_MASK_NOA_DURATION_V1_8821C) \
<< BIT_SHIFT_NOA_DURATION_V1_8821C)
#define BITS_NOA_DURATION_V1_8821C \
(BIT_MASK_NOA_DURATION_V1_8821C << BIT_SHIFT_NOA_DURATION_V1_8821C)
#define BIT_CLEAR_NOA_DURATION_V1_8821C(x) ((x) & (~BITS_NOA_DURATION_V1_8821C))
#define BIT_GET_NOA_DURATION_V1_8821C(x) \
(((x) >> BIT_SHIFT_NOA_DURATION_V1_8821C) & \
BIT_MASK_NOA_DURATION_V1_8821C)
#define BIT_SET_NOA_DURATION_V1_8821C(x, v) \
(BIT_CLEAR_NOA_DURATION_V1_8821C(x) | BIT_NOA_DURATION_V1_8821C(v))
/* 2 REG_NOA_PARAM_1_8821C */
#define BIT_SHIFT_NOA_INTERVAL_V1_8821C 0
#define BIT_MASK_NOA_INTERVAL_V1_8821C 0xffffffffL
#define BIT_NOA_INTERVAL_V1_8821C(x) \
(((x) & BIT_MASK_NOA_INTERVAL_V1_8821C) \
<< BIT_SHIFT_NOA_INTERVAL_V1_8821C)
#define BITS_NOA_INTERVAL_V1_8821C \
(BIT_MASK_NOA_INTERVAL_V1_8821C << BIT_SHIFT_NOA_INTERVAL_V1_8821C)
#define BIT_CLEAR_NOA_INTERVAL_V1_8821C(x) ((x) & (~BITS_NOA_INTERVAL_V1_8821C))
#define BIT_GET_NOA_INTERVAL_V1_8821C(x) \
(((x) >> BIT_SHIFT_NOA_INTERVAL_V1_8821C) & \
BIT_MASK_NOA_INTERVAL_V1_8821C)
#define BIT_SET_NOA_INTERVAL_V1_8821C(x, v) \
(BIT_CLEAR_NOA_INTERVAL_V1_8821C(x) | BIT_NOA_INTERVAL_V1_8821C(v))
/* 2 REG_NOA_PARAM_2_8821C */
#define BIT_SHIFT_NOA_START_TIME_V1_8821C 0
#define BIT_MASK_NOA_START_TIME_V1_8821C 0xffffffffL
#define BIT_NOA_START_TIME_V1_8821C(x) \
(((x) & BIT_MASK_NOA_START_TIME_V1_8821C) \
<< BIT_SHIFT_NOA_START_TIME_V1_8821C)
#define BITS_NOA_START_TIME_V1_8821C \
(BIT_MASK_NOA_START_TIME_V1_8821C << BIT_SHIFT_NOA_START_TIME_V1_8821C)
#define BIT_CLEAR_NOA_START_TIME_V1_8821C(x) \
((x) & (~BITS_NOA_START_TIME_V1_8821C))
#define BIT_GET_NOA_START_TIME_V1_8821C(x) \
(((x) >> BIT_SHIFT_NOA_START_TIME_V1_8821C) & \
BIT_MASK_NOA_START_TIME_V1_8821C)
#define BIT_SET_NOA_START_TIME_V1_8821C(x, v) \
(BIT_CLEAR_NOA_START_TIME_V1_8821C(x) | BIT_NOA_START_TIME_V1_8821C(v))
/* 2 REG_NOA_PARAM_3_8821C */
#define BIT_SHIFT_NOA_COUNT_V1_8821C 0
#define BIT_MASK_NOA_COUNT_V1_8821C 0xffffffffL
#define BIT_NOA_COUNT_V1_8821C(x) \
(((x) & BIT_MASK_NOA_COUNT_V1_8821C) << BIT_SHIFT_NOA_COUNT_V1_8821C)
#define BITS_NOA_COUNT_V1_8821C \
(BIT_MASK_NOA_COUNT_V1_8821C << BIT_SHIFT_NOA_COUNT_V1_8821C)
#define BIT_CLEAR_NOA_COUNT_V1_8821C(x) ((x) & (~BITS_NOA_COUNT_V1_8821C))
#define BIT_GET_NOA_COUNT_V1_8821C(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_V1_8821C) & BIT_MASK_NOA_COUNT_V1_8821C)
#define BIT_SET_NOA_COUNT_V1_8821C(x, v) \
(BIT_CLEAR_NOA_COUNT_V1_8821C(x) | BIT_NOA_COUNT_V1_8821C(v))
/* 2 REG_P2P_RST_8821C */
#define BIT_P2P2_PWR_RST1_8821C BIT(5)
#define BIT_P2P2_PWR_RST0_8821C BIT(4)
#define BIT_P2P1_PWR_RST1_8821C BIT(3)
#define BIT_P2P1_PWR_RST0_8821C BIT(2)
#define BIT_P2P_PWR_RST1_V1_8821C BIT(1)
#define BIT_P2P_PWR_RST0_V1_8821C BIT(0)
/* 2 REG_SCHEDULER_RST_8821C */
#define BIT_SYNC_CLI_ONCE_RIGHT_NOW_8821C BIT(2)
#define BIT_SYNC_CLI_ONCE_BY_TBTT_8821C BIT(1)
#define BIT_SCHEDULER_RST_V1_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SCH_TXCMD_8821C */
#define BIT_SHIFT_SCH_TXCMD_8821C 0
#define BIT_MASK_SCH_TXCMD_8821C 0xffffffffL
#define BIT_SCH_TXCMD_8821C(x) \
(((x) & BIT_MASK_SCH_TXCMD_8821C) << BIT_SHIFT_SCH_TXCMD_8821C)
#define BITS_SCH_TXCMD_8821C \
(BIT_MASK_SCH_TXCMD_8821C << BIT_SHIFT_SCH_TXCMD_8821C)
#define BIT_CLEAR_SCH_TXCMD_8821C(x) ((x) & (~BITS_SCH_TXCMD_8821C))
#define BIT_GET_SCH_TXCMD_8821C(x) \
(((x) >> BIT_SHIFT_SCH_TXCMD_8821C) & BIT_MASK_SCH_TXCMD_8821C)
#define BIT_SET_SCH_TXCMD_8821C(x, v) \
(BIT_CLEAR_SCH_TXCMD_8821C(x) | BIT_SCH_TXCMD_8821C(v))
/* 2 REG_PAGE5_DUMMY_8821C */
#define BIT_ECO_TXOP_BREAK_FORCE_CFEND_8821C BIT(0)
/* 2 REG_CPUMGQ_TX_TIMER_8821C */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8821C 0
#define BIT_MASK_CPUMGQ_TX_TIMER_V1_8821C 0xffffffffL
#define BIT_CPUMGQ_TX_TIMER_V1_8821C(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_V1_8821C) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8821C)
#define BITS_CPUMGQ_TX_TIMER_V1_8821C \
(BIT_MASK_CPUMGQ_TX_TIMER_V1_8821C \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8821C)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8821C(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_V1_8821C))
#define BIT_GET_CPUMGQ_TX_TIMER_V1_8821C(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8821C) & \
BIT_MASK_CPUMGQ_TX_TIMER_V1_8821C)
#define BIT_SET_CPUMGQ_TX_TIMER_V1_8821C(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8821C(x) | \
BIT_CPUMGQ_TX_TIMER_V1_8821C(v))
/* 2 REG_PS_TIMER_A_8821C */
#define BIT_SHIFT_PS_TIMER_A_V1_8821C 0
#define BIT_MASK_PS_TIMER_A_V1_8821C 0xffffffffL
#define BIT_PS_TIMER_A_V1_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_A_V1_8821C) << BIT_SHIFT_PS_TIMER_A_V1_8821C)
#define BITS_PS_TIMER_A_V1_8821C \
(BIT_MASK_PS_TIMER_A_V1_8821C << BIT_SHIFT_PS_TIMER_A_V1_8821C)
#define BIT_CLEAR_PS_TIMER_A_V1_8821C(x) ((x) & (~BITS_PS_TIMER_A_V1_8821C))
#define BIT_GET_PS_TIMER_A_V1_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_V1_8821C) & BIT_MASK_PS_TIMER_A_V1_8821C)
#define BIT_SET_PS_TIMER_A_V1_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_A_V1_8821C(x) | BIT_PS_TIMER_A_V1_8821C(v))
/* 2 REG_PS_TIMER_B_8821C */
#define BIT_SHIFT_PS_TIMER_B_V1_8821C 0
#define BIT_MASK_PS_TIMER_B_V1_8821C 0xffffffffL
#define BIT_PS_TIMER_B_V1_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_B_V1_8821C) << BIT_SHIFT_PS_TIMER_B_V1_8821C)
#define BITS_PS_TIMER_B_V1_8821C \
(BIT_MASK_PS_TIMER_B_V1_8821C << BIT_SHIFT_PS_TIMER_B_V1_8821C)
#define BIT_CLEAR_PS_TIMER_B_V1_8821C(x) ((x) & (~BITS_PS_TIMER_B_V1_8821C))
#define BIT_GET_PS_TIMER_B_V1_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_V1_8821C) & BIT_MASK_PS_TIMER_B_V1_8821C)
#define BIT_SET_PS_TIMER_B_V1_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_B_V1_8821C(x) | BIT_PS_TIMER_B_V1_8821C(v))
/* 2 REG_PS_TIMER_C_8821C */
#define BIT_SHIFT_PS_TIMER_C_V1_8821C 0
#define BIT_MASK_PS_TIMER_C_V1_8821C 0xffffffffL
#define BIT_PS_TIMER_C_V1_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_C_V1_8821C) << BIT_SHIFT_PS_TIMER_C_V1_8821C)
#define BITS_PS_TIMER_C_V1_8821C \
(BIT_MASK_PS_TIMER_C_V1_8821C << BIT_SHIFT_PS_TIMER_C_V1_8821C)
#define BIT_CLEAR_PS_TIMER_C_V1_8821C(x) ((x) & (~BITS_PS_TIMER_C_V1_8821C))
#define BIT_GET_PS_TIMER_C_V1_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_V1_8821C) & BIT_MASK_PS_TIMER_C_V1_8821C)
#define BIT_SET_PS_TIMER_C_V1_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_C_V1_8821C(x) | BIT_PS_TIMER_C_V1_8821C(v))
/* 2 REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8821C */
#define BIT_CPUMGQ_TIMER_EN_8821C BIT(31)
#define BIT_CPUMGQ_TX_EN_8821C BIT(28)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8821C 24
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8821C 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL_8821C(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8821C) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8821C)
#define BITS_CPUMGQ_TIMER_TSF_SEL_8821C \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8821C \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8821C)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8821C(x) \
((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL_8821C))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL_8821C(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8821C) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8821C)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL_8821C(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8821C(x) | \
BIT_CPUMGQ_TIMER_TSF_SEL_8821C(v))
#define BIT_PS_TIMER_C_EN_8821C BIT(23)
#define BIT_SHIFT_PS_TIMER_C_TSF_SEL_8821C 16
#define BIT_MASK_PS_TIMER_C_TSF_SEL_8821C 0x7
#define BIT_PS_TIMER_C_TSF_SEL_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_C_TSF_SEL_8821C) \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8821C)
#define BITS_PS_TIMER_C_TSF_SEL_8821C \
(BIT_MASK_PS_TIMER_C_TSF_SEL_8821C \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8821C)
#define BIT_CLEAR_PS_TIMER_C_TSF_SEL_8821C(x) \
((x) & (~BITS_PS_TIMER_C_TSF_SEL_8821C))
#define BIT_GET_PS_TIMER_C_TSF_SEL_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_TSF_SEL_8821C) & \
BIT_MASK_PS_TIMER_C_TSF_SEL_8821C)
#define BIT_SET_PS_TIMER_C_TSF_SEL_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_C_TSF_SEL_8821C(x) | \
BIT_PS_TIMER_C_TSF_SEL_8821C(v))
#define BIT_PS_TIMER_B_EN_8821C BIT(15)
#define BIT_SHIFT_PS_TIMER_B_TSF_SEL_8821C 8
#define BIT_MASK_PS_TIMER_B_TSF_SEL_8821C 0x7
#define BIT_PS_TIMER_B_TSF_SEL_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_B_TSF_SEL_8821C) \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8821C)
#define BITS_PS_TIMER_B_TSF_SEL_8821C \
(BIT_MASK_PS_TIMER_B_TSF_SEL_8821C \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8821C)
#define BIT_CLEAR_PS_TIMER_B_TSF_SEL_8821C(x) \
((x) & (~BITS_PS_TIMER_B_TSF_SEL_8821C))
#define BIT_GET_PS_TIMER_B_TSF_SEL_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_TSF_SEL_8821C) & \
BIT_MASK_PS_TIMER_B_TSF_SEL_8821C)
#define BIT_SET_PS_TIMER_B_TSF_SEL_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_B_TSF_SEL_8821C(x) | \
BIT_PS_TIMER_B_TSF_SEL_8821C(v))
#define BIT_PS_TIMER_A_EN_8821C BIT(7)
#define BIT_SHIFT_PS_TIMER_A_TSF_SEL_8821C 0
#define BIT_MASK_PS_TIMER_A_TSF_SEL_8821C 0x7
#define BIT_PS_TIMER_A_TSF_SEL_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_A_TSF_SEL_8821C) \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8821C)
#define BITS_PS_TIMER_A_TSF_SEL_8821C \
(BIT_MASK_PS_TIMER_A_TSF_SEL_8821C \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8821C)
#define BIT_CLEAR_PS_TIMER_A_TSF_SEL_8821C(x) \
((x) & (~BITS_PS_TIMER_A_TSF_SEL_8821C))
#define BIT_GET_PS_TIMER_A_TSF_SEL_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_TSF_SEL_8821C) & \
BIT_MASK_PS_TIMER_A_TSF_SEL_8821C)
#define BIT_SET_PS_TIMER_A_TSF_SEL_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_A_TSF_SEL_8821C(x) | \
BIT_PS_TIMER_A_TSF_SEL_8821C(v))
/* 2 REG_CPUMGQ_TX_TIMER_EARLY_8821C */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8821C 0
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8821C 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY_8821C(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8821C) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8821C)
#define BITS_CPUMGQ_TX_TIMER_EARLY_8821C \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8821C \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8821C)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8821C(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY_8821C))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY_8821C(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8821C) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8821C)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY_8821C(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8821C(x) | \
BIT_CPUMGQ_TX_TIMER_EARLY_8821C(v))
/* 2 REG_PS_TIMER_A_EARLY_8821C */
#define BIT_SHIFT_PS_TIMER_A_EARLY_8821C 0
#define BIT_MASK_PS_TIMER_A_EARLY_8821C 0xff
#define BIT_PS_TIMER_A_EARLY_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_A_EARLY_8821C) \
<< BIT_SHIFT_PS_TIMER_A_EARLY_8821C)
#define BITS_PS_TIMER_A_EARLY_8821C \
(BIT_MASK_PS_TIMER_A_EARLY_8821C << BIT_SHIFT_PS_TIMER_A_EARLY_8821C)
#define BIT_CLEAR_PS_TIMER_A_EARLY_8821C(x) \
((x) & (~BITS_PS_TIMER_A_EARLY_8821C))
#define BIT_GET_PS_TIMER_A_EARLY_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_EARLY_8821C) & \
BIT_MASK_PS_TIMER_A_EARLY_8821C)
#define BIT_SET_PS_TIMER_A_EARLY_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_A_EARLY_8821C(x) | BIT_PS_TIMER_A_EARLY_8821C(v))
/* 2 REG_PS_TIMER_B_EARLY_8821C */
#define BIT_SHIFT_PS_TIMER_B_EARLY_8821C 0
#define BIT_MASK_PS_TIMER_B_EARLY_8821C 0xff
#define BIT_PS_TIMER_B_EARLY_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_B_EARLY_8821C) \
<< BIT_SHIFT_PS_TIMER_B_EARLY_8821C)
#define BITS_PS_TIMER_B_EARLY_8821C \
(BIT_MASK_PS_TIMER_B_EARLY_8821C << BIT_SHIFT_PS_TIMER_B_EARLY_8821C)
#define BIT_CLEAR_PS_TIMER_B_EARLY_8821C(x) \
((x) & (~BITS_PS_TIMER_B_EARLY_8821C))
#define BIT_GET_PS_TIMER_B_EARLY_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_EARLY_8821C) & \
BIT_MASK_PS_TIMER_B_EARLY_8821C)
#define BIT_SET_PS_TIMER_B_EARLY_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_B_EARLY_8821C(x) | BIT_PS_TIMER_B_EARLY_8821C(v))
/* 2 REG_PS_TIMER_C_EARLY_8821C */
#define BIT_SHIFT_PS_TIMER_C_EARLY_8821C 0
#define BIT_MASK_PS_TIMER_C_EARLY_8821C 0xff
#define BIT_PS_TIMER_C_EARLY_8821C(x) \
(((x) & BIT_MASK_PS_TIMER_C_EARLY_8821C) \
<< BIT_SHIFT_PS_TIMER_C_EARLY_8821C)
#define BITS_PS_TIMER_C_EARLY_8821C \
(BIT_MASK_PS_TIMER_C_EARLY_8821C << BIT_SHIFT_PS_TIMER_C_EARLY_8821C)
#define BIT_CLEAR_PS_TIMER_C_EARLY_8821C(x) \
((x) & (~BITS_PS_TIMER_C_EARLY_8821C))
#define BIT_GET_PS_TIMER_C_EARLY_8821C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_EARLY_8821C) & \
BIT_MASK_PS_TIMER_C_EARLY_8821C)
#define BIT_SET_PS_TIMER_C_EARLY_8821C(x, v) \
(BIT_CLEAR_PS_TIMER_C_EARLY_8821C(x) | BIT_PS_TIMER_C_EARLY_8821C(v))
/* 2 REG_CPUMGQ_PARAMETER_8821C */
/* 2 REG_NOT_VALID_8821C */
#define BIT_MAC_STOP_CPUMGQ_8821C BIT(16)
#define BIT_SHIFT_CW_8821C 8
#define BIT_MASK_CW_8821C 0xff
#define BIT_CW_8821C(x) (((x) & BIT_MASK_CW_8821C) << BIT_SHIFT_CW_8821C)
#define BITS_CW_8821C (BIT_MASK_CW_8821C << BIT_SHIFT_CW_8821C)
#define BIT_CLEAR_CW_8821C(x) ((x) & (~BITS_CW_8821C))
#define BIT_GET_CW_8821C(x) (((x) >> BIT_SHIFT_CW_8821C) & BIT_MASK_CW_8821C)
#define BIT_SET_CW_8821C(x, v) (BIT_CLEAR_CW_8821C(x) | BIT_CW_8821C(v))
#define BIT_SHIFT_AIFS_8821C 0
#define BIT_MASK_AIFS_8821C 0xff
#define BIT_AIFS_8821C(x) (((x) & BIT_MASK_AIFS_8821C) << BIT_SHIFT_AIFS_8821C)
#define BITS_AIFS_8821C (BIT_MASK_AIFS_8821C << BIT_SHIFT_AIFS_8821C)
#define BIT_CLEAR_AIFS_8821C(x) ((x) & (~BITS_AIFS_8821C))
#define BIT_GET_AIFS_8821C(x) \
(((x) >> BIT_SHIFT_AIFS_8821C) & BIT_MASK_AIFS_8821C)
#define BIT_SET_AIFS_8821C(x, v) (BIT_CLEAR_AIFS_8821C(x) | BIT_AIFS_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_WMAC_CR_8821C (WMAC CR AND APSD CONTROL REGISTER) */
#define BIT_IC_MACPHY_M_8821C BIT(0)
/* 2 REG_WMAC_FWPKT_CR_8821C */
#define BIT_FWEN_8821C BIT(7)
#define BIT_PHYSTS_PKT_CTRL_8821C BIT(6)
#define BIT_FWFULL_TO_RXFF_EN_8821C BIT(5)
#define BIT_APPHDR_MIDSRCH_FAIL_8821C BIT(4)
#define BIT_FWPARSING_EN_8821C BIT(3)
#define BIT_SHIFT_APPEND_MHDR_LEN_8821C 0
#define BIT_MASK_APPEND_MHDR_LEN_8821C 0x7
#define BIT_APPEND_MHDR_LEN_8821C(x) \
(((x) & BIT_MASK_APPEND_MHDR_LEN_8821C) \
<< BIT_SHIFT_APPEND_MHDR_LEN_8821C)
#define BITS_APPEND_MHDR_LEN_8821C \
(BIT_MASK_APPEND_MHDR_LEN_8821C << BIT_SHIFT_APPEND_MHDR_LEN_8821C)
#define BIT_CLEAR_APPEND_MHDR_LEN_8821C(x) ((x) & (~BITS_APPEND_MHDR_LEN_8821C))
#define BIT_GET_APPEND_MHDR_LEN_8821C(x) \
(((x) >> BIT_SHIFT_APPEND_MHDR_LEN_8821C) & \
BIT_MASK_APPEND_MHDR_LEN_8821C)
#define BIT_SET_APPEND_MHDR_LEN_8821C(x, v) \
(BIT_CLEAR_APPEND_MHDR_LEN_8821C(x) | BIT_APPEND_MHDR_LEN_8821C(v))
/* 2 REG_FW_STS_FILTER_8821C */
#define BIT_DATA_FW_STS_FILTER_8821C BIT(2)
#define BIT_CTRL_FW_STS_FILTER_8821C BIT(1)
#define BIT_MGNT_FW_STS_FILTER_8821C BIT(0)
/* 2 REG_RSVD_8821C */
/* 2 REG_TCR_8821C (TRANSMISSION CONFIGURATION REGISTER) */
#define BIT_WMAC_EN_RTS_ADDR_8821C BIT(31)
#define BIT_WMAC_DISABLE_CCK_8821C BIT(30)
#define BIT_WMAC_RAW_LEN_8821C BIT(29)
#define BIT_WMAC_NOTX_IN_RXNDP_8821C BIT(28)
#define BIT_WMAC_EN_EOF_8821C BIT(27)
#define BIT_WMAC_BF_SEL_8821C BIT(26)
#define BIT_WMAC_ANTMODE_SEL_8821C BIT(25)
#define BIT_WMAC_TCRPWRMGT_HWCTL_8821C BIT(24)
#define BIT_WMAC_SMOOTH_VAL_8821C BIT(23)
#define BIT_FETCH_MPDU_AFTER_WSEC_RDY_8821C BIT(20)
#define BIT_WMAC_TCR_EN_20MST_8821C BIT(19)
#define BIT_WMAC_DIS_SIGTA_8821C BIT(18)
#define BIT_WMAC_DIS_A2B0_8821C BIT(17)
#define BIT_WMAC_MSK_SIGBCRC_8821C BIT(16)
#define BIT_WMAC_TCR_ERRSTEN_3_8821C BIT(15)
#define BIT_WMAC_TCR_ERRSTEN_2_8821C BIT(14)
#define BIT_WMAC_TCR_ERRSTEN_1_8821C BIT(13)
#define BIT_WMAC_TCR_ERRSTEN_0_8821C BIT(12)
#define BIT_WMAC_TCR_TXSK_PERPKT_8821C BIT(11)
#define BIT_ICV_8821C BIT(10)
#define BIT_CFEND_FORMAT_8821C BIT(9)
#define BIT_CRC_8821C BIT(8)
#define BIT_PWRBIT_OW_EN_8821C BIT(7)
#define BIT_PWR_ST_8821C BIT(6)
#define BIT_WMAC_TCR_UPD_TIMIE_8821C BIT(5)
#define BIT_WMAC_TCR_UPD_HGQMD_8821C BIT(4)
#define BIT_VHTSIGA1_TXPS_8821C BIT(3)
#define BIT_PAD_SEL_8821C BIT(2)
#define BIT_DIS_GCLK_8821C BIT(1)
/* 2 REG_RCR_8821C (RECEIVE CONFIGURATION REGISTER) */
#define BIT_APP_FCS_8821C BIT(31)
#define BIT_APP_MIC_8821C BIT(30)
#define BIT_APP_ICV_8821C BIT(29)
#define BIT_APP_PHYSTS_8821C BIT(28)
#define BIT_APP_BASSN_8821C BIT(27)
#define BIT_VHT_DACK_8821C BIT(26)
#define BIT_TCPOFLD_EN_8821C BIT(25)
#define BIT_ENMBID_8821C BIT(24)
#define BIT_LSIGEN_8821C BIT(23)
#define BIT_MFBEN_8821C BIT(22)
#define BIT_DISCHKPPDLLEN_8821C BIT(21)
#define BIT_PKTCTL_DLEN_8821C BIT(20)
#define BIT_TIM_PARSER_EN_8821C BIT(18)
#define BIT_BC_MD_EN_8821C BIT(17)
#define BIT_UC_MD_EN_8821C BIT(16)
#define BIT_RXSK_PERPKT_8821C BIT(15)
#define BIT_HTC_LOC_CTRL_8821C BIT(14)
#define BIT_RPFM_CAM_ENABLE_8821C BIT(12)
#define BIT_TA_BCN_8821C BIT(11)
#define BIT_DISDECMYPKT_8821C BIT(10)
#define BIT_AICV_8821C BIT(9)
#define BIT_ACRC32_8821C BIT(8)
#define BIT_CBSSID_BCN_8821C BIT(7)
#define BIT_CBSSID_DATA_8821C BIT(6)
#define BIT_APWRMGT_8821C BIT(5)
#define BIT_ADD3_8821C BIT(4)
#define BIT_AB_8821C BIT(3)
#define BIT_AM_8821C BIT(2)
#define BIT_APM_8821C BIT(1)
#define BIT_AAP_8821C BIT(0)
/* 2 REG_RX_PKT_LIMIT_8821C (RX PACKET LENGTH LIMIT REGISTER) */
#define BIT_SHIFT_RXPKTLMT_8821C 0
#define BIT_MASK_RXPKTLMT_8821C 0x3f
#define BIT_RXPKTLMT_8821C(x) \
(((x) & BIT_MASK_RXPKTLMT_8821C) << BIT_SHIFT_RXPKTLMT_8821C)
#define BITS_RXPKTLMT_8821C \
(BIT_MASK_RXPKTLMT_8821C << BIT_SHIFT_RXPKTLMT_8821C)
#define BIT_CLEAR_RXPKTLMT_8821C(x) ((x) & (~BITS_RXPKTLMT_8821C))
#define BIT_GET_RXPKTLMT_8821C(x) \
(((x) >> BIT_SHIFT_RXPKTLMT_8821C) & BIT_MASK_RXPKTLMT_8821C)
#define BIT_SET_RXPKTLMT_8821C(x, v) \
(BIT_CLEAR_RXPKTLMT_8821C(x) | BIT_RXPKTLMT_8821C(v))
/* 2 REG_RX_DLK_TIME_8821C (RX DEADLOCK TIME REGISTER) */
#define BIT_SHIFT_RX_DLK_TIME_8821C 0
#define BIT_MASK_RX_DLK_TIME_8821C 0xff
#define BIT_RX_DLK_TIME_8821C(x) \
(((x) & BIT_MASK_RX_DLK_TIME_8821C) << BIT_SHIFT_RX_DLK_TIME_8821C)
#define BITS_RX_DLK_TIME_8821C \
(BIT_MASK_RX_DLK_TIME_8821C << BIT_SHIFT_RX_DLK_TIME_8821C)
#define BIT_CLEAR_RX_DLK_TIME_8821C(x) ((x) & (~BITS_RX_DLK_TIME_8821C))
#define BIT_GET_RX_DLK_TIME_8821C(x) \
(((x) >> BIT_SHIFT_RX_DLK_TIME_8821C) & BIT_MASK_RX_DLK_TIME_8821C)
#define BIT_SET_RX_DLK_TIME_8821C(x, v) \
(BIT_CLEAR_RX_DLK_TIME_8821C(x) | BIT_RX_DLK_TIME_8821C(v))
/* 2 REG_RSVD_8821C */
/* 2 REG_RX_DRVINFO_SZ_8821C (RX DRIVER INFO SIZE REGISTER) */
#define BIT_PHYSTS_PER_PKT_MODE_8821C BIT(7)
#define BIT_SHIFT_DRVINFO_SZ_V1_8821C 0
#define BIT_MASK_DRVINFO_SZ_V1_8821C 0xf
#define BIT_DRVINFO_SZ_V1_8821C(x) \
(((x) & BIT_MASK_DRVINFO_SZ_V1_8821C) << BIT_SHIFT_DRVINFO_SZ_V1_8821C)
#define BITS_DRVINFO_SZ_V1_8821C \
(BIT_MASK_DRVINFO_SZ_V1_8821C << BIT_SHIFT_DRVINFO_SZ_V1_8821C)
#define BIT_CLEAR_DRVINFO_SZ_V1_8821C(x) ((x) & (~BITS_DRVINFO_SZ_V1_8821C))
#define BIT_GET_DRVINFO_SZ_V1_8821C(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ_V1_8821C) & BIT_MASK_DRVINFO_SZ_V1_8821C)
#define BIT_SET_DRVINFO_SZ_V1_8821C(x, v) \
(BIT_CLEAR_DRVINFO_SZ_V1_8821C(x) | BIT_DRVINFO_SZ_V1_8821C(v))
/* 2 REG_MACID_8821C (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_V1_8821C 0
#define BIT_MASK_MACID_V1_8821C 0xffffffffL
#define BIT_MACID_V1_8821C(x) \
(((x) & BIT_MASK_MACID_V1_8821C) << BIT_SHIFT_MACID_V1_8821C)
#define BITS_MACID_V1_8821C \
(BIT_MASK_MACID_V1_8821C << BIT_SHIFT_MACID_V1_8821C)
#define BIT_CLEAR_MACID_V1_8821C(x) ((x) & (~BITS_MACID_V1_8821C))
#define BIT_GET_MACID_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID_V1_8821C) & BIT_MASK_MACID_V1_8821C)
#define BIT_SET_MACID_V1_8821C(x, v) \
(BIT_CLEAR_MACID_V1_8821C(x) | BIT_MACID_V1_8821C(v))
/* 2 REG_MACID_H_8821C (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_H_V1_8821C 0
#define BIT_MASK_MACID_H_V1_8821C 0xffff
#define BIT_MACID_H_V1_8821C(x) \
(((x) & BIT_MASK_MACID_H_V1_8821C) << BIT_SHIFT_MACID_H_V1_8821C)
#define BITS_MACID_H_V1_8821C \
(BIT_MASK_MACID_H_V1_8821C << BIT_SHIFT_MACID_H_V1_8821C)
#define BIT_CLEAR_MACID_H_V1_8821C(x) ((x) & (~BITS_MACID_H_V1_8821C))
#define BIT_GET_MACID_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID_H_V1_8821C) & BIT_MASK_MACID_H_V1_8821C)
#define BIT_SET_MACID_H_V1_8821C(x, v) \
(BIT_CLEAR_MACID_H_V1_8821C(x) | BIT_MACID_H_V1_8821C(v))
/* 2 REG_BSSID_8821C (BSSID REGISTER) */
#define BIT_SHIFT_BSSID_V1_8821C 0
#define BIT_MASK_BSSID_V1_8821C 0xffffffffL
#define BIT_BSSID_V1_8821C(x) \
(((x) & BIT_MASK_BSSID_V1_8821C) << BIT_SHIFT_BSSID_V1_8821C)
#define BITS_BSSID_V1_8821C \
(BIT_MASK_BSSID_V1_8821C << BIT_SHIFT_BSSID_V1_8821C)
#define BIT_CLEAR_BSSID_V1_8821C(x) ((x) & (~BITS_BSSID_V1_8821C))
#define BIT_GET_BSSID_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID_V1_8821C) & BIT_MASK_BSSID_V1_8821C)
#define BIT_SET_BSSID_V1_8821C(x, v) \
(BIT_CLEAR_BSSID_V1_8821C(x) | BIT_BSSID_V1_8821C(v))
/* 2 REG_BSSID_H_8821C (BSSID REGISTER) */
/* 2 REG_NOT_VALID_8821C */
#define BIT_SHIFT_BSSID_H_V1_8821C 0
#define BIT_MASK_BSSID_H_V1_8821C 0xffff
#define BIT_BSSID_H_V1_8821C(x) \
(((x) & BIT_MASK_BSSID_H_V1_8821C) << BIT_SHIFT_BSSID_H_V1_8821C)
#define BITS_BSSID_H_V1_8821C \
(BIT_MASK_BSSID_H_V1_8821C << BIT_SHIFT_BSSID_H_V1_8821C)
#define BIT_CLEAR_BSSID_H_V1_8821C(x) ((x) & (~BITS_BSSID_H_V1_8821C))
#define BIT_GET_BSSID_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID_H_V1_8821C) & BIT_MASK_BSSID_H_V1_8821C)
#define BIT_SET_BSSID_H_V1_8821C(x, v) \
(BIT_CLEAR_BSSID_H_V1_8821C(x) | BIT_BSSID_H_V1_8821C(v))
/* 2 REG_MAR_8821C (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_V1_8821C 0
#define BIT_MASK_MAR_V1_8821C 0xffffffffL
#define BIT_MAR_V1_8821C(x) \
(((x) & BIT_MASK_MAR_V1_8821C) << BIT_SHIFT_MAR_V1_8821C)
#define BITS_MAR_V1_8821C (BIT_MASK_MAR_V1_8821C << BIT_SHIFT_MAR_V1_8821C)
#define BIT_CLEAR_MAR_V1_8821C(x) ((x) & (~BITS_MAR_V1_8821C))
#define BIT_GET_MAR_V1_8821C(x) \
(((x) >> BIT_SHIFT_MAR_V1_8821C) & BIT_MASK_MAR_V1_8821C)
#define BIT_SET_MAR_V1_8821C(x, v) \
(BIT_CLEAR_MAR_V1_8821C(x) | BIT_MAR_V1_8821C(v))
/* 2 REG_MAR_H_8821C (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_H_V1_8821C 0
#define BIT_MASK_MAR_H_V1_8821C 0xffffffffL
#define BIT_MAR_H_V1_8821C(x) \
(((x) & BIT_MASK_MAR_H_V1_8821C) << BIT_SHIFT_MAR_H_V1_8821C)
#define BITS_MAR_H_V1_8821C \
(BIT_MASK_MAR_H_V1_8821C << BIT_SHIFT_MAR_H_V1_8821C)
#define BIT_CLEAR_MAR_H_V1_8821C(x) ((x) & (~BITS_MAR_H_V1_8821C))
#define BIT_GET_MAR_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_MAR_H_V1_8821C) & BIT_MASK_MAR_H_V1_8821C)
#define BIT_SET_MAR_H_V1_8821C(x, v) \
(BIT_CLEAR_MAR_H_V1_8821C(x) | BIT_MAR_H_V1_8821C(v))
/* 2 REG_MBIDCAMCFG_1_8821C (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_SHIFT_MBIDCAM_RWDATA_L_8821C 0
#define BIT_MASK_MBIDCAM_RWDATA_L_8821C 0xffffffffL
#define BIT_MBIDCAM_RWDATA_L_8821C(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_L_8821C) \
<< BIT_SHIFT_MBIDCAM_RWDATA_L_8821C)
#define BITS_MBIDCAM_RWDATA_L_8821C \
(BIT_MASK_MBIDCAM_RWDATA_L_8821C << BIT_SHIFT_MBIDCAM_RWDATA_L_8821C)
#define BIT_CLEAR_MBIDCAM_RWDATA_L_8821C(x) \
((x) & (~BITS_MBIDCAM_RWDATA_L_8821C))
#define BIT_GET_MBIDCAM_RWDATA_L_8821C(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_L_8821C) & \
BIT_MASK_MBIDCAM_RWDATA_L_8821C)
#define BIT_SET_MBIDCAM_RWDATA_L_8821C(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_L_8821C(x) | BIT_MBIDCAM_RWDATA_L_8821C(v))
/* 2 REG_MBIDCAMCFG_2_8821C (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_MBIDCAM_POLL_8821C BIT(31)
#define BIT_MBIDCAM_WT_EN_8821C BIT(30)
#define BIT_SHIFT_MBIDCAM_ADDR_8821C 24
#define BIT_MASK_MBIDCAM_ADDR_8821C 0x1f
#define BIT_MBIDCAM_ADDR_8821C(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR_8821C) << BIT_SHIFT_MBIDCAM_ADDR_8821C)
#define BITS_MBIDCAM_ADDR_8821C \
(BIT_MASK_MBIDCAM_ADDR_8821C << BIT_SHIFT_MBIDCAM_ADDR_8821C)
#define BIT_CLEAR_MBIDCAM_ADDR_8821C(x) ((x) & (~BITS_MBIDCAM_ADDR_8821C))
#define BIT_GET_MBIDCAM_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR_8821C) & BIT_MASK_MBIDCAM_ADDR_8821C)
#define BIT_SET_MBIDCAM_ADDR_8821C(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR_8821C(x) | BIT_MBIDCAM_ADDR_8821C(v))
#define BIT_MBIDCAM_VALID_8821C BIT(23)
#define BIT_LSIC_TXOP_EN_8821C BIT(17)
#define BIT_CTS_EN_8821C BIT(16)
#define BIT_SHIFT_MBIDCAM_RWDATA_H_8821C 0
#define BIT_MASK_MBIDCAM_RWDATA_H_8821C 0xffff
#define BIT_MBIDCAM_RWDATA_H_8821C(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_H_8821C) \
<< BIT_SHIFT_MBIDCAM_RWDATA_H_8821C)
#define BITS_MBIDCAM_RWDATA_H_8821C \
(BIT_MASK_MBIDCAM_RWDATA_H_8821C << BIT_SHIFT_MBIDCAM_RWDATA_H_8821C)
#define BIT_CLEAR_MBIDCAM_RWDATA_H_8821C(x) \
((x) & (~BITS_MBIDCAM_RWDATA_H_8821C))
#define BIT_GET_MBIDCAM_RWDATA_H_8821C(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_H_8821C) & \
BIT_MASK_MBIDCAM_RWDATA_H_8821C)
#define BIT_SET_MBIDCAM_RWDATA_H_8821C(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_H_8821C(x) | BIT_MBIDCAM_RWDATA_H_8821C(v))
/* 2 REG_WMAC_TCR_TSFT_OFS_8821C */
#define BIT_SHIFT_WMAC_TCR_TSFT_OFS_8821C 0
#define BIT_MASK_WMAC_TCR_TSFT_OFS_8821C 0xffff
#define BIT_WMAC_TCR_TSFT_OFS_8821C(x) \
(((x) & BIT_MASK_WMAC_TCR_TSFT_OFS_8821C) \
<< BIT_SHIFT_WMAC_TCR_TSFT_OFS_8821C)
#define BITS_WMAC_TCR_TSFT_OFS_8821C \
(BIT_MASK_WMAC_TCR_TSFT_OFS_8821C << BIT_SHIFT_WMAC_TCR_TSFT_OFS_8821C)
#define BIT_CLEAR_WMAC_TCR_TSFT_OFS_8821C(x) \
((x) & (~BITS_WMAC_TCR_TSFT_OFS_8821C))
#define BIT_GET_WMAC_TCR_TSFT_OFS_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_TCR_TSFT_OFS_8821C) & \
BIT_MASK_WMAC_TCR_TSFT_OFS_8821C)
#define BIT_SET_WMAC_TCR_TSFT_OFS_8821C(x, v) \
(BIT_CLEAR_WMAC_TCR_TSFT_OFS_8821C(x) | BIT_WMAC_TCR_TSFT_OFS_8821C(v))
/* 2 REG_UDF_THSD_8821C */
#define BIT_SHIFT_UDF_THSD_8821C 0
#define BIT_MASK_UDF_THSD_8821C 0xff
#define BIT_UDF_THSD_8821C(x) \
(((x) & BIT_MASK_UDF_THSD_8821C) << BIT_SHIFT_UDF_THSD_8821C)
#define BITS_UDF_THSD_8821C \
(BIT_MASK_UDF_THSD_8821C << BIT_SHIFT_UDF_THSD_8821C)
#define BIT_CLEAR_UDF_THSD_8821C(x) ((x) & (~BITS_UDF_THSD_8821C))
#define BIT_GET_UDF_THSD_8821C(x) \
(((x) >> BIT_SHIFT_UDF_THSD_8821C) & BIT_MASK_UDF_THSD_8821C)
#define BIT_SET_UDF_THSD_8821C(x, v) \
(BIT_CLEAR_UDF_THSD_8821C(x) | BIT_UDF_THSD_8821C(v))
/* 2 REG_ZLD_NUM_8821C */
#define BIT_SHIFT_ZLD_NUM_8821C 0
#define BIT_MASK_ZLD_NUM_8821C 0xff
#define BIT_ZLD_NUM_8821C(x) \
(((x) & BIT_MASK_ZLD_NUM_8821C) << BIT_SHIFT_ZLD_NUM_8821C)
#define BITS_ZLD_NUM_8821C (BIT_MASK_ZLD_NUM_8821C << BIT_SHIFT_ZLD_NUM_8821C)
#define BIT_CLEAR_ZLD_NUM_8821C(x) ((x) & (~BITS_ZLD_NUM_8821C))
#define BIT_GET_ZLD_NUM_8821C(x) \
(((x) >> BIT_SHIFT_ZLD_NUM_8821C) & BIT_MASK_ZLD_NUM_8821C)
#define BIT_SET_ZLD_NUM_8821C(x, v) \
(BIT_CLEAR_ZLD_NUM_8821C(x) | BIT_ZLD_NUM_8821C(v))
/* 2 REG_STMP_THSD_8821C */
#define BIT_SHIFT_STMP_THSD_8821C 0
#define BIT_MASK_STMP_THSD_8821C 0xff
#define BIT_STMP_THSD_8821C(x) \
(((x) & BIT_MASK_STMP_THSD_8821C) << BIT_SHIFT_STMP_THSD_8821C)
#define BITS_STMP_THSD_8821C \
(BIT_MASK_STMP_THSD_8821C << BIT_SHIFT_STMP_THSD_8821C)
#define BIT_CLEAR_STMP_THSD_8821C(x) ((x) & (~BITS_STMP_THSD_8821C))
#define BIT_GET_STMP_THSD_8821C(x) \
(((x) >> BIT_SHIFT_STMP_THSD_8821C) & BIT_MASK_STMP_THSD_8821C)
#define BIT_SET_STMP_THSD_8821C(x, v) \
(BIT_CLEAR_STMP_THSD_8821C(x) | BIT_STMP_THSD_8821C(v))
/* 2 REG_WMAC_TXTIMEOUT_8821C */
#define BIT_SHIFT_WMAC_TXTIMEOUT_8821C 0
#define BIT_MASK_WMAC_TXTIMEOUT_8821C 0xff
#define BIT_WMAC_TXTIMEOUT_8821C(x) \
(((x) & BIT_MASK_WMAC_TXTIMEOUT_8821C) \
<< BIT_SHIFT_WMAC_TXTIMEOUT_8821C)
#define BITS_WMAC_TXTIMEOUT_8821C \
(BIT_MASK_WMAC_TXTIMEOUT_8821C << BIT_SHIFT_WMAC_TXTIMEOUT_8821C)
#define BIT_CLEAR_WMAC_TXTIMEOUT_8821C(x) ((x) & (~BITS_WMAC_TXTIMEOUT_8821C))
#define BIT_GET_WMAC_TXTIMEOUT_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_TXTIMEOUT_8821C) & \
BIT_MASK_WMAC_TXTIMEOUT_8821C)
#define BIT_SET_WMAC_TXTIMEOUT_8821C(x, v) \
(BIT_CLEAR_WMAC_TXTIMEOUT_8821C(x) | BIT_WMAC_TXTIMEOUT_8821C(v))
/* 2 REG_MCU_TEST_2_V1_8821C */
#define BIT_SHIFT_MCU_RSVD_2_V1_8821C 0
#define BIT_MASK_MCU_RSVD_2_V1_8821C 0xffff
#define BIT_MCU_RSVD_2_V1_8821C(x) \
(((x) & BIT_MASK_MCU_RSVD_2_V1_8821C) << BIT_SHIFT_MCU_RSVD_2_V1_8821C)
#define BITS_MCU_RSVD_2_V1_8821C \
(BIT_MASK_MCU_RSVD_2_V1_8821C << BIT_SHIFT_MCU_RSVD_2_V1_8821C)
#define BIT_CLEAR_MCU_RSVD_2_V1_8821C(x) ((x) & (~BITS_MCU_RSVD_2_V1_8821C))
#define BIT_GET_MCU_RSVD_2_V1_8821C(x) \
(((x) >> BIT_SHIFT_MCU_RSVD_2_V1_8821C) & BIT_MASK_MCU_RSVD_2_V1_8821C)
#define BIT_SET_MCU_RSVD_2_V1_8821C(x, v) \
(BIT_CLEAR_MCU_RSVD_2_V1_8821C(x) | BIT_MCU_RSVD_2_V1_8821C(v))
/* 2 REG_USTIME_EDCA_8821C (US TIME TUNING FOR EDCA REGISTER) */
#define BIT_SHIFT_USTIME_EDCA_8821C 0
#define BIT_MASK_USTIME_EDCA_8821C 0xff
#define BIT_USTIME_EDCA_8821C(x) \
(((x) & BIT_MASK_USTIME_EDCA_8821C) << BIT_SHIFT_USTIME_EDCA_8821C)
#define BITS_USTIME_EDCA_8821C \
(BIT_MASK_USTIME_EDCA_8821C << BIT_SHIFT_USTIME_EDCA_8821C)
#define BIT_CLEAR_USTIME_EDCA_8821C(x) ((x) & (~BITS_USTIME_EDCA_8821C))
#define BIT_GET_USTIME_EDCA_8821C(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA_8821C) & BIT_MASK_USTIME_EDCA_8821C)
#define BIT_SET_USTIME_EDCA_8821C(x, v) \
(BIT_CLEAR_USTIME_EDCA_8821C(x) | BIT_USTIME_EDCA_8821C(v))
/* 2 REG_ACKTO_CCK_8821C (ACK TIMEOUT REGISTER FOR CCK RATE) */
#define BIT_SHIFT_ACKTO_CCK_8821C 0
#define BIT_MASK_ACKTO_CCK_8821C 0xff
#define BIT_ACKTO_CCK_8821C(x) \
(((x) & BIT_MASK_ACKTO_CCK_8821C) << BIT_SHIFT_ACKTO_CCK_8821C)
#define BITS_ACKTO_CCK_8821C \
(BIT_MASK_ACKTO_CCK_8821C << BIT_SHIFT_ACKTO_CCK_8821C)
#define BIT_CLEAR_ACKTO_CCK_8821C(x) ((x) & (~BITS_ACKTO_CCK_8821C))
#define BIT_GET_ACKTO_CCK_8821C(x) \
(((x) >> BIT_SHIFT_ACKTO_CCK_8821C) & BIT_MASK_ACKTO_CCK_8821C)
#define BIT_SET_ACKTO_CCK_8821C(x, v) \
(BIT_CLEAR_ACKTO_CCK_8821C(x) | BIT_ACKTO_CCK_8821C(v))
/* 2 REG_MAC_SPEC_SIFS_8821C (SPECIFICATION SIFS REGISTER) */
#define BIT_SHIFT_SPEC_SIFS_OFDM_8821C 8
#define BIT_MASK_SPEC_SIFS_OFDM_8821C 0xff
#define BIT_SPEC_SIFS_OFDM_8821C(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_8821C) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_8821C)
#define BITS_SPEC_SIFS_OFDM_8821C \
(BIT_MASK_SPEC_SIFS_OFDM_8821C << BIT_SHIFT_SPEC_SIFS_OFDM_8821C)
#define BIT_CLEAR_SPEC_SIFS_OFDM_8821C(x) ((x) & (~BITS_SPEC_SIFS_OFDM_8821C))
#define BIT_GET_SPEC_SIFS_OFDM_8821C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_8821C) & \
BIT_MASK_SPEC_SIFS_OFDM_8821C)
#define BIT_SET_SPEC_SIFS_OFDM_8821C(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_8821C(x) | BIT_SPEC_SIFS_OFDM_8821C(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_8821C 0
#define BIT_MASK_SPEC_SIFS_CCK_8821C 0xff
#define BIT_SPEC_SIFS_CCK_8821C(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_8821C) << BIT_SHIFT_SPEC_SIFS_CCK_8821C)
#define BITS_SPEC_SIFS_CCK_8821C \
(BIT_MASK_SPEC_SIFS_CCK_8821C << BIT_SHIFT_SPEC_SIFS_CCK_8821C)
#define BIT_CLEAR_SPEC_SIFS_CCK_8821C(x) ((x) & (~BITS_SPEC_SIFS_CCK_8821C))
#define BIT_GET_SPEC_SIFS_CCK_8821C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_8821C) & BIT_MASK_SPEC_SIFS_CCK_8821C)
#define BIT_SET_SPEC_SIFS_CCK_8821C(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_8821C(x) | BIT_SPEC_SIFS_CCK_8821C(v))
/* 2 REG_RESP_SIFS_CCK_8821C (RESPONSE SIFS FOR CCK REGISTER) */
#define BIT_SHIFT_SIFS_R2T_CCK_8821C 8
#define BIT_MASK_SIFS_R2T_CCK_8821C 0xff
#define BIT_SIFS_R2T_CCK_8821C(x) \
(((x) & BIT_MASK_SIFS_R2T_CCK_8821C) << BIT_SHIFT_SIFS_R2T_CCK_8821C)
#define BITS_SIFS_R2T_CCK_8821C \
(BIT_MASK_SIFS_R2T_CCK_8821C << BIT_SHIFT_SIFS_R2T_CCK_8821C)
#define BIT_CLEAR_SIFS_R2T_CCK_8821C(x) ((x) & (~BITS_SIFS_R2T_CCK_8821C))
#define BIT_GET_SIFS_R2T_CCK_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_CCK_8821C) & BIT_MASK_SIFS_R2T_CCK_8821C)
#define BIT_SET_SIFS_R2T_CCK_8821C(x, v) \
(BIT_CLEAR_SIFS_R2T_CCK_8821C(x) | BIT_SIFS_R2T_CCK_8821C(v))
#define BIT_SHIFT_SIFS_T2T_CCK_8821C 0
#define BIT_MASK_SIFS_T2T_CCK_8821C 0xff
#define BIT_SIFS_T2T_CCK_8821C(x) \
(((x) & BIT_MASK_SIFS_T2T_CCK_8821C) << BIT_SHIFT_SIFS_T2T_CCK_8821C)
#define BITS_SIFS_T2T_CCK_8821C \
(BIT_MASK_SIFS_T2T_CCK_8821C << BIT_SHIFT_SIFS_T2T_CCK_8821C)
#define BIT_CLEAR_SIFS_T2T_CCK_8821C(x) ((x) & (~BITS_SIFS_T2T_CCK_8821C))
#define BIT_GET_SIFS_T2T_CCK_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_CCK_8821C) & BIT_MASK_SIFS_T2T_CCK_8821C)
#define BIT_SET_SIFS_T2T_CCK_8821C(x, v) \
(BIT_CLEAR_SIFS_T2T_CCK_8821C(x) | BIT_SIFS_T2T_CCK_8821C(v))
/* 2 REG_RESP_SIFS_OFDM_8821C (RESPONSE SIFS FOR OFDM REGISTER) */
#define BIT_SHIFT_SIFS_R2T_OFDM_8821C 8
#define BIT_MASK_SIFS_R2T_OFDM_8821C 0xff
#define BIT_SIFS_R2T_OFDM_8821C(x) \
(((x) & BIT_MASK_SIFS_R2T_OFDM_8821C) << BIT_SHIFT_SIFS_R2T_OFDM_8821C)
#define BITS_SIFS_R2T_OFDM_8821C \
(BIT_MASK_SIFS_R2T_OFDM_8821C << BIT_SHIFT_SIFS_R2T_OFDM_8821C)
#define BIT_CLEAR_SIFS_R2T_OFDM_8821C(x) ((x) & (~BITS_SIFS_R2T_OFDM_8821C))
#define BIT_GET_SIFS_R2T_OFDM_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_OFDM_8821C) & BIT_MASK_SIFS_R2T_OFDM_8821C)
#define BIT_SET_SIFS_R2T_OFDM_8821C(x, v) \
(BIT_CLEAR_SIFS_R2T_OFDM_8821C(x) | BIT_SIFS_R2T_OFDM_8821C(v))
#define BIT_SHIFT_SIFS_T2T_OFDM_8821C 0
#define BIT_MASK_SIFS_T2T_OFDM_8821C 0xff
#define BIT_SIFS_T2T_OFDM_8821C(x) \
(((x) & BIT_MASK_SIFS_T2T_OFDM_8821C) << BIT_SHIFT_SIFS_T2T_OFDM_8821C)
#define BITS_SIFS_T2T_OFDM_8821C \
(BIT_MASK_SIFS_T2T_OFDM_8821C << BIT_SHIFT_SIFS_T2T_OFDM_8821C)
#define BIT_CLEAR_SIFS_T2T_OFDM_8821C(x) ((x) & (~BITS_SIFS_T2T_OFDM_8821C))
#define BIT_GET_SIFS_T2T_OFDM_8821C(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_OFDM_8821C) & BIT_MASK_SIFS_T2T_OFDM_8821C)
#define BIT_SET_SIFS_T2T_OFDM_8821C(x, v) \
(BIT_CLEAR_SIFS_T2T_OFDM_8821C(x) | BIT_SIFS_T2T_OFDM_8821C(v))
/* 2 REG_ACKTO_8821C (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_ACKTO_8821C 0
#define BIT_MASK_ACKTO_8821C 0xff
#define BIT_ACKTO_8821C(x) \
(((x) & BIT_MASK_ACKTO_8821C) << BIT_SHIFT_ACKTO_8821C)
#define BITS_ACKTO_8821C (BIT_MASK_ACKTO_8821C << BIT_SHIFT_ACKTO_8821C)
#define BIT_CLEAR_ACKTO_8821C(x) ((x) & (~BITS_ACKTO_8821C))
#define BIT_GET_ACKTO_8821C(x) \
(((x) >> BIT_SHIFT_ACKTO_8821C) & BIT_MASK_ACKTO_8821C)
#define BIT_SET_ACKTO_8821C(x, v) \
(BIT_CLEAR_ACKTO_8821C(x) | BIT_ACKTO_8821C(v))
/* 2 REG_CTS2TO_8821C (CTS2 TIMEOUT REGISTER) */
#define BIT_SHIFT_CTS2TO_8821C 0
#define BIT_MASK_CTS2TO_8821C 0xff
#define BIT_CTS2TO_8821C(x) \
(((x) & BIT_MASK_CTS2TO_8821C) << BIT_SHIFT_CTS2TO_8821C)
#define BITS_CTS2TO_8821C (BIT_MASK_CTS2TO_8821C << BIT_SHIFT_CTS2TO_8821C)
#define BIT_CLEAR_CTS2TO_8821C(x) ((x) & (~BITS_CTS2TO_8821C))
#define BIT_GET_CTS2TO_8821C(x) \
(((x) >> BIT_SHIFT_CTS2TO_8821C) & BIT_MASK_CTS2TO_8821C)
#define BIT_SET_CTS2TO_8821C(x, v) \
(BIT_CLEAR_CTS2TO_8821C(x) | BIT_CTS2TO_8821C(v))
/* 2 REG_EIFS_8821C (EIFS REGISTER) */
#define BIT_SHIFT_EIFS_8821C 0
#define BIT_MASK_EIFS_8821C 0xffff
#define BIT_EIFS_8821C(x) (((x) & BIT_MASK_EIFS_8821C) << BIT_SHIFT_EIFS_8821C)
#define BITS_EIFS_8821C (BIT_MASK_EIFS_8821C << BIT_SHIFT_EIFS_8821C)
#define BIT_CLEAR_EIFS_8821C(x) ((x) & (~BITS_EIFS_8821C))
#define BIT_GET_EIFS_8821C(x) \
(((x) >> BIT_SHIFT_EIFS_8821C) & BIT_MASK_EIFS_8821C)
#define BIT_SET_EIFS_8821C(x, v) (BIT_CLEAR_EIFS_8821C(x) | BIT_EIFS_8821C(v))
/* 2 REG_RPFM_MAP0_8821C */
#define BIT_MGT_RPFM15EN_8821C BIT(15)
#define BIT_MGT_RPFM14EN_8821C BIT(14)
#define BIT_MGT_RPFM13EN_8821C BIT(13)
#define BIT_MGT_RPFM12EN_8821C BIT(12)
#define BIT_MGT_RPFM11EN_8821C BIT(11)
#define BIT_MGT_RPFM10EN_8821C BIT(10)
#define BIT_MGT_RPFM9EN_8821C BIT(9)
#define BIT_MGT_RPFM8EN_8821C BIT(8)
#define BIT_MGT_RPFM7EN_8821C BIT(7)
#define BIT_MGT_RPFM6EN_8821C BIT(6)
#define BIT_MGT_RPFM5EN_8821C BIT(5)
#define BIT_MGT_RPFM4EN_8821C BIT(4)
#define BIT_MGT_RPFM3EN_8821C BIT(3)
#define BIT_MGT_RPFM2EN_8821C BIT(2)
#define BIT_MGT_RPFM1EN_8821C BIT(1)
#define BIT_MGT_RPFM0EN_8821C BIT(0)
/* 2 REG_RPFM_MAP1_V1_8821C */
#define BIT_DATA_RPFM15EN_8821C BIT(15)
#define BIT_DATA_RPFM14EN_8821C BIT(14)
#define BIT_DATA_RPFM13EN_8821C BIT(13)
#define BIT_DATA_RPFM12EN_8821C BIT(12)
#define BIT_DATA_RPFM11EN_8821C BIT(11)
#define BIT_DATA_RPFM10EN_8821C BIT(10)
#define BIT_DATA_RPFM9EN_8821C BIT(9)
#define BIT_DATA_RPFM8EN_8821C BIT(8)
#define BIT_DATA_RPFM7EN_8821C BIT(7)
#define BIT_DATA_RPFM6EN_8821C BIT(6)
#define BIT_DATA_RPFM5EN_8821C BIT(5)
#define BIT_DATA_RPFM4EN_8821C BIT(4)
#define BIT_DATA_RPFM3EN_8821C BIT(3)
#define BIT_DATA_RPFM2EN_8821C BIT(2)
#define BIT_DATA_RPFM1EN_8821C BIT(1)
#define BIT_DATA_RPFM0EN_8821C BIT(0)
/* 2 REG_RPFM_CAM_CMD_8821C (RX PAYLOAD FRAME MASK CAM COMMAND REGISTER) */
#define BIT_RPFM_CAM_POLLING_8821C BIT(31)
#define BIT_RPFM_CAM_CLR_8821C BIT(30)
#define BIT_RPFM_CAM_WE_8821C BIT(16)
#define BIT_SHIFT_RPFM_CAM_ADDR_8821C 0
#define BIT_MASK_RPFM_CAM_ADDR_8821C 0x7f
#define BIT_RPFM_CAM_ADDR_8821C(x) \
(((x) & BIT_MASK_RPFM_CAM_ADDR_8821C) << BIT_SHIFT_RPFM_CAM_ADDR_8821C)
#define BITS_RPFM_CAM_ADDR_8821C \
(BIT_MASK_RPFM_CAM_ADDR_8821C << BIT_SHIFT_RPFM_CAM_ADDR_8821C)
#define BIT_CLEAR_RPFM_CAM_ADDR_8821C(x) ((x) & (~BITS_RPFM_CAM_ADDR_8821C))
#define BIT_GET_RPFM_CAM_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_ADDR_8821C) & BIT_MASK_RPFM_CAM_ADDR_8821C)
#define BIT_SET_RPFM_CAM_ADDR_8821C(x, v) \
(BIT_CLEAR_RPFM_CAM_ADDR_8821C(x) | BIT_RPFM_CAM_ADDR_8821C(v))
/* 2 REG_RPFM_CAM_RWD_8821C (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_RPFM_CAM_RWD_8821C 0
#define BIT_MASK_RPFM_CAM_RWD_8821C 0xffffffffL
#define BIT_RPFM_CAM_RWD_8821C(x) \
(((x) & BIT_MASK_RPFM_CAM_RWD_8821C) << BIT_SHIFT_RPFM_CAM_RWD_8821C)
#define BITS_RPFM_CAM_RWD_8821C \
(BIT_MASK_RPFM_CAM_RWD_8821C << BIT_SHIFT_RPFM_CAM_RWD_8821C)
#define BIT_CLEAR_RPFM_CAM_RWD_8821C(x) ((x) & (~BITS_RPFM_CAM_RWD_8821C))
#define BIT_GET_RPFM_CAM_RWD_8821C(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_RWD_8821C) & BIT_MASK_RPFM_CAM_RWD_8821C)
#define BIT_SET_RPFM_CAM_RWD_8821C(x, v) \
(BIT_CLEAR_RPFM_CAM_RWD_8821C(x) | BIT_RPFM_CAM_RWD_8821C(v))
/* 2 REG_NAV_CTRL_8821C (NAV CONTROL REGISTER) */
#define BIT_SHIFT_NAV_UPPER_8821C 16
#define BIT_MASK_NAV_UPPER_8821C 0xff
#define BIT_NAV_UPPER_8821C(x) \
(((x) & BIT_MASK_NAV_UPPER_8821C) << BIT_SHIFT_NAV_UPPER_8821C)
#define BITS_NAV_UPPER_8821C \
(BIT_MASK_NAV_UPPER_8821C << BIT_SHIFT_NAV_UPPER_8821C)
#define BIT_CLEAR_NAV_UPPER_8821C(x) ((x) & (~BITS_NAV_UPPER_8821C))
#define BIT_GET_NAV_UPPER_8821C(x) \
(((x) >> BIT_SHIFT_NAV_UPPER_8821C) & BIT_MASK_NAV_UPPER_8821C)
#define BIT_SET_NAV_UPPER_8821C(x, v) \
(BIT_CLEAR_NAV_UPPER_8821C(x) | BIT_NAV_UPPER_8821C(v))
#define BIT_SHIFT_RXMYRTS_NAV_8821C 8
#define BIT_MASK_RXMYRTS_NAV_8821C 0xf
#define BIT_RXMYRTS_NAV_8821C(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_8821C) << BIT_SHIFT_RXMYRTS_NAV_8821C)
#define BITS_RXMYRTS_NAV_8821C \
(BIT_MASK_RXMYRTS_NAV_8821C << BIT_SHIFT_RXMYRTS_NAV_8821C)
#define BIT_CLEAR_RXMYRTS_NAV_8821C(x) ((x) & (~BITS_RXMYRTS_NAV_8821C))
#define BIT_GET_RXMYRTS_NAV_8821C(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_8821C) & BIT_MASK_RXMYRTS_NAV_8821C)
#define BIT_SET_RXMYRTS_NAV_8821C(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_8821C(x) | BIT_RXMYRTS_NAV_8821C(v))
#define BIT_SHIFT_RTSRST_8821C 0
#define BIT_MASK_RTSRST_8821C 0xff
#define BIT_RTSRST_8821C(x) \
(((x) & BIT_MASK_RTSRST_8821C) << BIT_SHIFT_RTSRST_8821C)
#define BITS_RTSRST_8821C (BIT_MASK_RTSRST_8821C << BIT_SHIFT_RTSRST_8821C)
#define BIT_CLEAR_RTSRST_8821C(x) ((x) & (~BITS_RTSRST_8821C))
#define BIT_GET_RTSRST_8821C(x) \
(((x) >> BIT_SHIFT_RTSRST_8821C) & BIT_MASK_RTSRST_8821C)
#define BIT_SET_RTSRST_8821C(x, v) \
(BIT_CLEAR_RTSRST_8821C(x) | BIT_RTSRST_8821C(v))
/* 2 REG_BACAMCMD_8821C (BLOCK ACK CAM COMMAND REGISTER) */
#define BIT_BACAM_POLL_8821C BIT(31)
#define BIT_BACAM_RST_8821C BIT(17)
#define BIT_BACAM_RW_8821C BIT(16)
#define BIT_SHIFT_TXSBM_8821C 14
#define BIT_MASK_TXSBM_8821C 0x3
#define BIT_TXSBM_8821C(x) \
(((x) & BIT_MASK_TXSBM_8821C) << BIT_SHIFT_TXSBM_8821C)
#define BITS_TXSBM_8821C (BIT_MASK_TXSBM_8821C << BIT_SHIFT_TXSBM_8821C)
#define BIT_CLEAR_TXSBM_8821C(x) ((x) & (~BITS_TXSBM_8821C))
#define BIT_GET_TXSBM_8821C(x) \
(((x) >> BIT_SHIFT_TXSBM_8821C) & BIT_MASK_TXSBM_8821C)
#define BIT_SET_TXSBM_8821C(x, v) \
(BIT_CLEAR_TXSBM_8821C(x) | BIT_TXSBM_8821C(v))
#define BIT_SHIFT_BACAM_ADDR_8821C 0
#define BIT_MASK_BACAM_ADDR_8821C 0x3f
#define BIT_BACAM_ADDR_8821C(x) \
(((x) & BIT_MASK_BACAM_ADDR_8821C) << BIT_SHIFT_BACAM_ADDR_8821C)
#define BITS_BACAM_ADDR_8821C \
(BIT_MASK_BACAM_ADDR_8821C << BIT_SHIFT_BACAM_ADDR_8821C)
#define BIT_CLEAR_BACAM_ADDR_8821C(x) ((x) & (~BITS_BACAM_ADDR_8821C))
#define BIT_GET_BACAM_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_BACAM_ADDR_8821C) & BIT_MASK_BACAM_ADDR_8821C)
#define BIT_SET_BACAM_ADDR_8821C(x, v) \
(BIT_CLEAR_BACAM_ADDR_8821C(x) | BIT_BACAM_ADDR_8821C(v))
/* 2 REG_BACAMCONTENT_8821C (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_L_8821C 0
#define BIT_MASK_BA_CONTENT_L_8821C 0xffffffffL
#define BIT_BA_CONTENT_L_8821C(x) \
(((x) & BIT_MASK_BA_CONTENT_L_8821C) << BIT_SHIFT_BA_CONTENT_L_8821C)
#define BITS_BA_CONTENT_L_8821C \
(BIT_MASK_BA_CONTENT_L_8821C << BIT_SHIFT_BA_CONTENT_L_8821C)
#define BIT_CLEAR_BA_CONTENT_L_8821C(x) ((x) & (~BITS_BA_CONTENT_L_8821C))
#define BIT_GET_BA_CONTENT_L_8821C(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_L_8821C) & BIT_MASK_BA_CONTENT_L_8821C)
#define BIT_SET_BA_CONTENT_L_8821C(x, v) \
(BIT_CLEAR_BA_CONTENT_L_8821C(x) | BIT_BA_CONTENT_L_8821C(v))
/* 2 REG_BACAMCONTENT_H_8821C (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_H_8821C 0
#define BIT_MASK_BA_CONTENT_H_8821C 0xffffffffL
#define BIT_BA_CONTENT_H_8821C(x) \
(((x) & BIT_MASK_BA_CONTENT_H_8821C) << BIT_SHIFT_BA_CONTENT_H_8821C)
#define BITS_BA_CONTENT_H_8821C \
(BIT_MASK_BA_CONTENT_H_8821C << BIT_SHIFT_BA_CONTENT_H_8821C)
#define BIT_CLEAR_BA_CONTENT_H_8821C(x) ((x) & (~BITS_BA_CONTENT_H_8821C))
#define BIT_GET_BA_CONTENT_H_8821C(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_H_8821C) & BIT_MASK_BA_CONTENT_H_8821C)
#define BIT_SET_BA_CONTENT_H_8821C(x, v) \
(BIT_CLEAR_BA_CONTENT_H_8821C(x) | BIT_BA_CONTENT_H_8821C(v))
/* 2 REG_LBDLY_8821C (LOOPBACK DELAY REGISTER) */
#define BIT_SHIFT_LBDLY_8821C 0
#define BIT_MASK_LBDLY_8821C 0x1f
#define BIT_LBDLY_8821C(x) \
(((x) & BIT_MASK_LBDLY_8821C) << BIT_SHIFT_LBDLY_8821C)
#define BITS_LBDLY_8821C (BIT_MASK_LBDLY_8821C << BIT_SHIFT_LBDLY_8821C)
#define BIT_CLEAR_LBDLY_8821C(x) ((x) & (~BITS_LBDLY_8821C))
#define BIT_GET_LBDLY_8821C(x) \
(((x) >> BIT_SHIFT_LBDLY_8821C) & BIT_MASK_LBDLY_8821C)
#define BIT_SET_LBDLY_8821C(x, v) \
(BIT_CLEAR_LBDLY_8821C(x) | BIT_LBDLY_8821C(v))
/* 2 REG_WMAC_BACAM_RPMEN_8821C */
#define BIT_SHIFT_BITMAP_SSNBK_COUNTER_8821C 2
#define BIT_MASK_BITMAP_SSNBK_COUNTER_8821C 0x3f
#define BIT_BITMAP_SSNBK_COUNTER_8821C(x) \
(((x) & BIT_MASK_BITMAP_SSNBK_COUNTER_8821C) \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8821C)
#define BITS_BITMAP_SSNBK_COUNTER_8821C \
(BIT_MASK_BITMAP_SSNBK_COUNTER_8821C \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8821C)
#define BIT_CLEAR_BITMAP_SSNBK_COUNTER_8821C(x) \
((x) & (~BITS_BITMAP_SSNBK_COUNTER_8821C))
#define BIT_GET_BITMAP_SSNBK_COUNTER_8821C(x) \
(((x) >> BIT_SHIFT_BITMAP_SSNBK_COUNTER_8821C) & \
BIT_MASK_BITMAP_SSNBK_COUNTER_8821C)
#define BIT_SET_BITMAP_SSNBK_COUNTER_8821C(x, v) \
(BIT_CLEAR_BITMAP_SSNBK_COUNTER_8821C(x) | \
BIT_BITMAP_SSNBK_COUNTER_8821C(v))
#define BIT_BITMAP_EN_8821C BIT(1)
#define BIT_WMAC_BACAM_RPMEN_8821C BIT(0)
/* 2 REG_TX_RX_8821C STATUS */
#define BIT_SHIFT_RXPKT_TYPE_8821C 2
#define BIT_MASK_RXPKT_TYPE_8821C 0x3f
#define BIT_RXPKT_TYPE_8821C(x) \
(((x) & BIT_MASK_RXPKT_TYPE_8821C) << BIT_SHIFT_RXPKT_TYPE_8821C)
#define BITS_RXPKT_TYPE_8821C \
(BIT_MASK_RXPKT_TYPE_8821C << BIT_SHIFT_RXPKT_TYPE_8821C)
#define BIT_CLEAR_RXPKT_TYPE_8821C(x) ((x) & (~BITS_RXPKT_TYPE_8821C))
#define BIT_GET_RXPKT_TYPE_8821C(x) \
(((x) >> BIT_SHIFT_RXPKT_TYPE_8821C) & BIT_MASK_RXPKT_TYPE_8821C)
#define BIT_SET_RXPKT_TYPE_8821C(x, v) \
(BIT_CLEAR_RXPKT_TYPE_8821C(x) | BIT_RXPKT_TYPE_8821C(v))
#define BIT_TXACT_IND_8821C BIT(1)
#define BIT_RXACT_IND_8821C BIT(0)
/* 2 REG_WMAC_BITMAP_CTL_8821C */
#define BIT_BITMAP_VO_8821C BIT(7)
#define BIT_BITMAP_VI_8821C BIT(6)
#define BIT_BITMAP_BE_8821C BIT(5)
#define BIT_BITMAP_BK_8821C BIT(4)
#define BIT_SHIFT_BITMAP_CONDITION_8821C 2
#define BIT_MASK_BITMAP_CONDITION_8821C 0x3
#define BIT_BITMAP_CONDITION_8821C(x) \
(((x) & BIT_MASK_BITMAP_CONDITION_8821C) \
<< BIT_SHIFT_BITMAP_CONDITION_8821C)
#define BITS_BITMAP_CONDITION_8821C \
(BIT_MASK_BITMAP_CONDITION_8821C << BIT_SHIFT_BITMAP_CONDITION_8821C)
#define BIT_CLEAR_BITMAP_CONDITION_8821C(x) \
((x) & (~BITS_BITMAP_CONDITION_8821C))
#define BIT_GET_BITMAP_CONDITION_8821C(x) \
(((x) >> BIT_SHIFT_BITMAP_CONDITION_8821C) & \
BIT_MASK_BITMAP_CONDITION_8821C)
#define BIT_SET_BITMAP_CONDITION_8821C(x, v) \
(BIT_CLEAR_BITMAP_CONDITION_8821C(x) | BIT_BITMAP_CONDITION_8821C(v))
#define BIT_BITMAP_SSNBK_COUNTER_CLR_8821C BIT(1)
#define BIT_BITMAP_FORCE_8821C BIT(0)
/* 2 REG_RXERR_RPT_8821C (RX ERROR REPORT REGISTER) */
#define BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8821C 28
#define BIT_MASK_RXERR_RPT_SEL_V1_3_0_8821C 0xf
#define BIT_RXERR_RPT_SEL_V1_3_0_8821C(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL_V1_3_0_8821C) \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8821C)
#define BITS_RXERR_RPT_SEL_V1_3_0_8821C \
(BIT_MASK_RXERR_RPT_SEL_V1_3_0_8821C \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8821C)
#define BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8821C(x) \
((x) & (~BITS_RXERR_RPT_SEL_V1_3_0_8821C))
#define BIT_GET_RXERR_RPT_SEL_V1_3_0_8821C(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8821C) & \
BIT_MASK_RXERR_RPT_SEL_V1_3_0_8821C)
#define BIT_SET_RXERR_RPT_SEL_V1_3_0_8821C(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8821C(x) | \
BIT_RXERR_RPT_SEL_V1_3_0_8821C(v))
#define BIT_RXERR_RPT_RST_8821C BIT(27)
#define BIT_RXERR_RPT_SEL_V1_4_8821C BIT(26)
#define BIT_W1S_8821C BIT(23)
#define BIT_UD_SELECT_BSSID_8821C BIT(22)
#define BIT_SHIFT_UD_SUB_TYPE_8821C 18
#define BIT_MASK_UD_SUB_TYPE_8821C 0xf
#define BIT_UD_SUB_TYPE_8821C(x) \
(((x) & BIT_MASK_UD_SUB_TYPE_8821C) << BIT_SHIFT_UD_SUB_TYPE_8821C)
#define BITS_UD_SUB_TYPE_8821C \
(BIT_MASK_UD_SUB_TYPE_8821C << BIT_SHIFT_UD_SUB_TYPE_8821C)
#define BIT_CLEAR_UD_SUB_TYPE_8821C(x) ((x) & (~BITS_UD_SUB_TYPE_8821C))
#define BIT_GET_UD_SUB_TYPE_8821C(x) \
(((x) >> BIT_SHIFT_UD_SUB_TYPE_8821C) & BIT_MASK_UD_SUB_TYPE_8821C)
#define BIT_SET_UD_SUB_TYPE_8821C(x, v) \
(BIT_CLEAR_UD_SUB_TYPE_8821C(x) | BIT_UD_SUB_TYPE_8821C(v))
#define BIT_SHIFT_UD_TYPE_8821C 16
#define BIT_MASK_UD_TYPE_8821C 0x3
#define BIT_UD_TYPE_8821C(x) \
(((x) & BIT_MASK_UD_TYPE_8821C) << BIT_SHIFT_UD_TYPE_8821C)
#define BITS_UD_TYPE_8821C (BIT_MASK_UD_TYPE_8821C << BIT_SHIFT_UD_TYPE_8821C)
#define BIT_CLEAR_UD_TYPE_8821C(x) ((x) & (~BITS_UD_TYPE_8821C))
#define BIT_GET_UD_TYPE_8821C(x) \
(((x) >> BIT_SHIFT_UD_TYPE_8821C) & BIT_MASK_UD_TYPE_8821C)
#define BIT_SET_UD_TYPE_8821C(x, v) \
(BIT_CLEAR_UD_TYPE_8821C(x) | BIT_UD_TYPE_8821C(v))
#define BIT_SHIFT_RPT_COUNTER_8821C 0
#define BIT_MASK_RPT_COUNTER_8821C 0xffff
#define BIT_RPT_COUNTER_8821C(x) \
(((x) & BIT_MASK_RPT_COUNTER_8821C) << BIT_SHIFT_RPT_COUNTER_8821C)
#define BITS_RPT_COUNTER_8821C \
(BIT_MASK_RPT_COUNTER_8821C << BIT_SHIFT_RPT_COUNTER_8821C)
#define BIT_CLEAR_RPT_COUNTER_8821C(x) ((x) & (~BITS_RPT_COUNTER_8821C))
#define BIT_GET_RPT_COUNTER_8821C(x) \
(((x) >> BIT_SHIFT_RPT_COUNTER_8821C) & BIT_MASK_RPT_COUNTER_8821C)
#define BIT_SET_RPT_COUNTER_8821C(x, v) \
(BIT_CLEAR_RPT_COUNTER_8821C(x) | BIT_RPT_COUNTER_8821C(v))
/* 2 REG_WMAC_TRXPTCL_CTL_8821C (WMAC TX/RX PROTOCOL CONTROL REGISTER) */
#define BIT_EN_TXCTS_INTXOP_8821C BIT(32)
#define BIT_BLK_EDCA_BBSLP_8821C BIT(31)
#define BIT_BLK_EDCA_BBSBY_8821C BIT(30)
#define BIT_ACKTO_BLOCK_SCH_EN_8821C BIT(27)
#define BIT_EIFS_BLOCK_SCH_EN_8821C BIT(26)
#define BIT_PLCPCHK_RST_EIFS_8821C BIT(25)
#define BIT_CCA_RST_EIFS_8821C BIT(24)
#define BIT_DIS_UPD_MYRXPKTNAV_8821C BIT(23)
#define BIT_EARLY_TXBA_8821C BIT(22)
#define BIT_SHIFT_RESP_CHNBUSY_8821C 20
#define BIT_MASK_RESP_CHNBUSY_8821C 0x3
#define BIT_RESP_CHNBUSY_8821C(x) \
(((x) & BIT_MASK_RESP_CHNBUSY_8821C) << BIT_SHIFT_RESP_CHNBUSY_8821C)
#define BITS_RESP_CHNBUSY_8821C \
(BIT_MASK_RESP_CHNBUSY_8821C << BIT_SHIFT_RESP_CHNBUSY_8821C)
#define BIT_CLEAR_RESP_CHNBUSY_8821C(x) ((x) & (~BITS_RESP_CHNBUSY_8821C))
#define BIT_GET_RESP_CHNBUSY_8821C(x) \
(((x) >> BIT_SHIFT_RESP_CHNBUSY_8821C) & BIT_MASK_RESP_CHNBUSY_8821C)
#define BIT_SET_RESP_CHNBUSY_8821C(x, v) \
(BIT_CLEAR_RESP_CHNBUSY_8821C(x) | BIT_RESP_CHNBUSY_8821C(v))
#define BIT_RESP_DCTS_EN_8821C BIT(19)
#define BIT_RESP_DCFE_EN_8821C BIT(18)
#define BIT_RESP_SPLCPEN_8821C BIT(17)
#define BIT_RESP_SGIEN_8821C BIT(16)
#define BIT_RESP_LDPC_EN_8821C BIT(15)
#define BIT_DIS_RESP_ACKINCCA_8821C BIT(14)
#define BIT_DIS_RESP_CTSINCCA_8821C BIT(13)
#define BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8821C 10
#define BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8821C 0x7
#define BIT_R_WMAC_SECOND_CCA_TIMER_8821C(x) \
(((x) & BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8821C) \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8821C)
#define BITS_R_WMAC_SECOND_CCA_TIMER_8821C \
(BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8821C \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8821C)
#define BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8821C(x) \
((x) & (~BITS_R_WMAC_SECOND_CCA_TIMER_8821C))
#define BIT_GET_R_WMAC_SECOND_CCA_TIMER_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8821C) & \
BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8821C)
#define BIT_SET_R_WMAC_SECOND_CCA_TIMER_8821C(x, v) \
(BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8821C(x) | \
BIT_R_WMAC_SECOND_CCA_TIMER_8821C(v))
#define BIT_SHIFT_RFMOD_8821C 7
#define BIT_MASK_RFMOD_8821C 0x3
#define BIT_RFMOD_8821C(x) \
(((x) & BIT_MASK_RFMOD_8821C) << BIT_SHIFT_RFMOD_8821C)
#define BITS_RFMOD_8821C (BIT_MASK_RFMOD_8821C << BIT_SHIFT_RFMOD_8821C)
#define BIT_CLEAR_RFMOD_8821C(x) ((x) & (~BITS_RFMOD_8821C))
#define BIT_GET_RFMOD_8821C(x) \
(((x) >> BIT_SHIFT_RFMOD_8821C) & BIT_MASK_RFMOD_8821C)
#define BIT_SET_RFMOD_8821C(x, v) \
(BIT_CLEAR_RFMOD_8821C(x) | BIT_RFMOD_8821C(v))
#define BIT_SHIFT_RESP_CTS_DYNBW_SEL_8821C 5
#define BIT_MASK_RESP_CTS_DYNBW_SEL_8821C 0x3
#define BIT_RESP_CTS_DYNBW_SEL_8821C(x) \
(((x) & BIT_MASK_RESP_CTS_DYNBW_SEL_8821C) \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8821C)
#define BITS_RESP_CTS_DYNBW_SEL_8821C \
(BIT_MASK_RESP_CTS_DYNBW_SEL_8821C \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8821C)
#define BIT_CLEAR_RESP_CTS_DYNBW_SEL_8821C(x) \
((x) & (~BITS_RESP_CTS_DYNBW_SEL_8821C))
#define BIT_GET_RESP_CTS_DYNBW_SEL_8821C(x) \
(((x) >> BIT_SHIFT_RESP_CTS_DYNBW_SEL_8821C) & \
BIT_MASK_RESP_CTS_DYNBW_SEL_8821C)
#define BIT_SET_RESP_CTS_DYNBW_SEL_8821C(x, v) \
(BIT_CLEAR_RESP_CTS_DYNBW_SEL_8821C(x) | \
BIT_RESP_CTS_DYNBW_SEL_8821C(v))
#define BIT_DLY_TX_WAIT_RXANTSEL_8821C BIT(4)
#define BIT_TXRESP_BY_RXANTSEL_8821C BIT(3)
#define BIT_SHIFT_ORIG_DCTS_CHK_8821C 0
#define BIT_MASK_ORIG_DCTS_CHK_8821C 0x3
#define BIT_ORIG_DCTS_CHK_8821C(x) \
(((x) & BIT_MASK_ORIG_DCTS_CHK_8821C) << BIT_SHIFT_ORIG_DCTS_CHK_8821C)
#define BITS_ORIG_DCTS_CHK_8821C \
(BIT_MASK_ORIG_DCTS_CHK_8821C << BIT_SHIFT_ORIG_DCTS_CHK_8821C)
#define BIT_CLEAR_ORIG_DCTS_CHK_8821C(x) ((x) & (~BITS_ORIG_DCTS_CHK_8821C))
#define BIT_GET_ORIG_DCTS_CHK_8821C(x) \
(((x) >> BIT_SHIFT_ORIG_DCTS_CHK_8821C) & BIT_MASK_ORIG_DCTS_CHK_8821C)
#define BIT_SET_ORIG_DCTS_CHK_8821C(x, v) \
(BIT_CLEAR_ORIG_DCTS_CHK_8821C(x) | BIT_ORIG_DCTS_CHK_8821C(v))
/* 2 REG_WMAC_TRXPTCL_CTL_H_8821C */
#define BIT_SHIFT_ACKBA_TYPSEL_8821C 28
#define BIT_MASK_ACKBA_TYPSEL_8821C 0xf
#define BIT_ACKBA_TYPSEL_8821C(x) \
(((x) & BIT_MASK_ACKBA_TYPSEL_8821C) << BIT_SHIFT_ACKBA_TYPSEL_8821C)
#define BITS_ACKBA_TYPSEL_8821C \
(BIT_MASK_ACKBA_TYPSEL_8821C << BIT_SHIFT_ACKBA_TYPSEL_8821C)
#define BIT_CLEAR_ACKBA_TYPSEL_8821C(x) ((x) & (~BITS_ACKBA_TYPSEL_8821C))
#define BIT_GET_ACKBA_TYPSEL_8821C(x) \
(((x) >> BIT_SHIFT_ACKBA_TYPSEL_8821C) & BIT_MASK_ACKBA_TYPSEL_8821C)
#define BIT_SET_ACKBA_TYPSEL_8821C(x, v) \
(BIT_CLEAR_ACKBA_TYPSEL_8821C(x) | BIT_ACKBA_TYPSEL_8821C(v))
#define BIT_SHIFT_ACKBA_ACKPCHK_8821C 24
#define BIT_MASK_ACKBA_ACKPCHK_8821C 0xf
#define BIT_ACKBA_ACKPCHK_8821C(x) \
(((x) & BIT_MASK_ACKBA_ACKPCHK_8821C) << BIT_SHIFT_ACKBA_ACKPCHK_8821C)
#define BITS_ACKBA_ACKPCHK_8821C \
(BIT_MASK_ACKBA_ACKPCHK_8821C << BIT_SHIFT_ACKBA_ACKPCHK_8821C)
#define BIT_CLEAR_ACKBA_ACKPCHK_8821C(x) ((x) & (~BITS_ACKBA_ACKPCHK_8821C))
#define BIT_GET_ACKBA_ACKPCHK_8821C(x) \
(((x) >> BIT_SHIFT_ACKBA_ACKPCHK_8821C) & BIT_MASK_ACKBA_ACKPCHK_8821C)
#define BIT_SET_ACKBA_ACKPCHK_8821C(x, v) \
(BIT_CLEAR_ACKBA_ACKPCHK_8821C(x) | BIT_ACKBA_ACKPCHK_8821C(v))
#define BIT_SHIFT_ACKBAR_TYPESEL_8821C 16
#define BIT_MASK_ACKBAR_TYPESEL_8821C 0xff
#define BIT_ACKBAR_TYPESEL_8821C(x) \
(((x) & BIT_MASK_ACKBAR_TYPESEL_8821C) \
<< BIT_SHIFT_ACKBAR_TYPESEL_8821C)
#define BITS_ACKBAR_TYPESEL_8821C \
(BIT_MASK_ACKBAR_TYPESEL_8821C << BIT_SHIFT_ACKBAR_TYPESEL_8821C)
#define BIT_CLEAR_ACKBAR_TYPESEL_8821C(x) ((x) & (~BITS_ACKBAR_TYPESEL_8821C))
#define BIT_GET_ACKBAR_TYPESEL_8821C(x) \
(((x) >> BIT_SHIFT_ACKBAR_TYPESEL_8821C) & \
BIT_MASK_ACKBAR_TYPESEL_8821C)
#define BIT_SET_ACKBAR_TYPESEL_8821C(x, v) \
(BIT_CLEAR_ACKBAR_TYPESEL_8821C(x) | BIT_ACKBAR_TYPESEL_8821C(v))
#define BIT_SHIFT_ACKBAR_ACKPCHK_8821C 12
#define BIT_MASK_ACKBAR_ACKPCHK_8821C 0xf
#define BIT_ACKBAR_ACKPCHK_8821C(x) \
(((x) & BIT_MASK_ACKBAR_ACKPCHK_8821C) \
<< BIT_SHIFT_ACKBAR_ACKPCHK_8821C)
#define BITS_ACKBAR_ACKPCHK_8821C \
(BIT_MASK_ACKBAR_ACKPCHK_8821C << BIT_SHIFT_ACKBAR_ACKPCHK_8821C)
#define BIT_CLEAR_ACKBAR_ACKPCHK_8821C(x) ((x) & (~BITS_ACKBAR_ACKPCHK_8821C))
#define BIT_GET_ACKBAR_ACKPCHK_8821C(x) \
(((x) >> BIT_SHIFT_ACKBAR_ACKPCHK_8821C) & \
BIT_MASK_ACKBAR_ACKPCHK_8821C)
#define BIT_SET_ACKBAR_ACKPCHK_8821C(x, v) \
(BIT_CLEAR_ACKBAR_ACKPCHK_8821C(x) | BIT_ACKBAR_ACKPCHK_8821C(v))
#define BIT_RXBA_IGNOREA2_V1_8821C BIT(10)
#define BIT_EN_SAVE_ALL_TXOPADDR_V1_8821C BIT(9)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV_V1_8821C BIT(8)
#define BIT_DIS_TXBA_AMPDUFCSERR_V1_8821C BIT(7)
#define BIT_DIS_TXBA_RXBARINFULL_V1_8821C BIT(6)
#define BIT_DIS_TXCFE_INFULL_V1_8821C BIT(5)
#define BIT_DIS_TXCTS_INFULL_V1_8821C BIT(4)
#define BIT_EN_TXACKBA_IN_TX_RDG_V1_8821C BIT(3)
#define BIT_EN_TXACKBA_IN_TXOP_V1_8821C BIT(2)
#define BIT_EN_TXCTS_IN_RXNAV_V1_8821C BIT(1)
#define BIT_EN_TXCTS_INTXOP_V1_8821C BIT(0)
/* 2 REG_CAMCMD_8821C (CAM COMMAND REGISTER) */
#define BIT_SECCAM_POLLING_8821C BIT(31)
#define BIT_SECCAM_CLR_8821C BIT(30)
#define BIT_MFBCAM_CLR_8821C BIT(29)
#define BIT_SECCAM_WE_8821C BIT(16)
#define BIT_SHIFT_SECCAM_ADDR_V2_8821C 0
#define BIT_MASK_SECCAM_ADDR_V2_8821C 0x3ff
#define BIT_SECCAM_ADDR_V2_8821C(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V2_8821C) \
<< BIT_SHIFT_SECCAM_ADDR_V2_8821C)
#define BITS_SECCAM_ADDR_V2_8821C \
(BIT_MASK_SECCAM_ADDR_V2_8821C << BIT_SHIFT_SECCAM_ADDR_V2_8821C)
#define BIT_CLEAR_SECCAM_ADDR_V2_8821C(x) ((x) & (~BITS_SECCAM_ADDR_V2_8821C))
#define BIT_GET_SECCAM_ADDR_V2_8821C(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V2_8821C) & \
BIT_MASK_SECCAM_ADDR_V2_8821C)
#define BIT_SET_SECCAM_ADDR_V2_8821C(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V2_8821C(x) | BIT_SECCAM_ADDR_V2_8821C(v))
/* 2 REG_CAMWRITE_8821C (CAM WRITE REGISTER) */
#define BIT_SHIFT_CAMW_DATA_8821C 0
#define BIT_MASK_CAMW_DATA_8821C 0xffffffffL
#define BIT_CAMW_DATA_8821C(x) \
(((x) & BIT_MASK_CAMW_DATA_8821C) << BIT_SHIFT_CAMW_DATA_8821C)
#define BITS_CAMW_DATA_8821C \
(BIT_MASK_CAMW_DATA_8821C << BIT_SHIFT_CAMW_DATA_8821C)
#define BIT_CLEAR_CAMW_DATA_8821C(x) ((x) & (~BITS_CAMW_DATA_8821C))
#define BIT_GET_CAMW_DATA_8821C(x) \
(((x) >> BIT_SHIFT_CAMW_DATA_8821C) & BIT_MASK_CAMW_DATA_8821C)
#define BIT_SET_CAMW_DATA_8821C(x, v) \
(BIT_CLEAR_CAMW_DATA_8821C(x) | BIT_CAMW_DATA_8821C(v))
/* 2 REG_CAMREAD_8821C (CAM READ REGISTER) */
#define BIT_SHIFT_CAMR_DATA_8821C 0
#define BIT_MASK_CAMR_DATA_8821C 0xffffffffL
#define BIT_CAMR_DATA_8821C(x) \
(((x) & BIT_MASK_CAMR_DATA_8821C) << BIT_SHIFT_CAMR_DATA_8821C)
#define BITS_CAMR_DATA_8821C \
(BIT_MASK_CAMR_DATA_8821C << BIT_SHIFT_CAMR_DATA_8821C)
#define BIT_CLEAR_CAMR_DATA_8821C(x) ((x) & (~BITS_CAMR_DATA_8821C))
#define BIT_GET_CAMR_DATA_8821C(x) \
(((x) >> BIT_SHIFT_CAMR_DATA_8821C) & BIT_MASK_CAMR_DATA_8821C)
#define BIT_SET_CAMR_DATA_8821C(x, v) \
(BIT_CLEAR_CAMR_DATA_8821C(x) | BIT_CAMR_DATA_8821C(v))
/* 2 REG_CAMDBG_8821C (CAM DEBUG REGISTER) */
#define BIT_SECCAM_INFO_8821C BIT(31)
#define BIT_SEC_KEYFOUND_8821C BIT(15)
#define BIT_SHIFT_CAMDBG_SEC_TYPE_8821C 12
#define BIT_MASK_CAMDBG_SEC_TYPE_8821C 0x7
#define BIT_CAMDBG_SEC_TYPE_8821C(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE_8821C) \
<< BIT_SHIFT_CAMDBG_SEC_TYPE_8821C)
#define BITS_CAMDBG_SEC_TYPE_8821C \
(BIT_MASK_CAMDBG_SEC_TYPE_8821C << BIT_SHIFT_CAMDBG_SEC_TYPE_8821C)
#define BIT_CLEAR_CAMDBG_SEC_TYPE_8821C(x) ((x) & (~BITS_CAMDBG_SEC_TYPE_8821C))
#define BIT_GET_CAMDBG_SEC_TYPE_8821C(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE_8821C) & \
BIT_MASK_CAMDBG_SEC_TYPE_8821C)
#define BIT_SET_CAMDBG_SEC_TYPE_8821C(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE_8821C(x) | BIT_CAMDBG_SEC_TYPE_8821C(v))
#define BIT_CAMDBG_EXT_SECTYPE_8821C BIT(11)
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8821C 5
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_8821C 0x1f
#define BIT_CAMDBG_MIC_KEY_IDX_8821C(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_8821C) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8821C)
#define BITS_CAMDBG_MIC_KEY_IDX_8821C \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_8821C \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8821C)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8821C(x) \
((x) & (~BITS_CAMDBG_MIC_KEY_IDX_8821C))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_8821C(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8821C) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_8821C)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_8821C(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8821C(x) | \
BIT_CAMDBG_MIC_KEY_IDX_8821C(v))
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8821C 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_8821C 0x1f
#define BIT_CAMDBG_SEC_KEY_IDX_8821C(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_8821C) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8821C)
#define BITS_CAMDBG_SEC_KEY_IDX_8821C \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_8821C \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8821C)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8821C(x) \
((x) & (~BITS_CAMDBG_SEC_KEY_IDX_8821C))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_8821C(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8821C) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_8821C)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_8821C(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8821C(x) | \
BIT_CAMDBG_SEC_KEY_IDX_8821C(v))
/* 2 REG_SECCFG_8821C (SECURITY CONFIGURATION REGISTER) */
#define BIT_DIS_GCLK_WAPI_8821C BIT(15)
#define BIT_DIS_GCLK_AES_8821C BIT(14)
#define BIT_DIS_GCLK_TKIP_8821C BIT(13)
#define BIT_AES_SEL_QC_1_8821C BIT(12)
#define BIT_AES_SEL_QC_0_8821C BIT(11)
#define BIT_CHK_BMC_8821C BIT(9)
#define BIT_CHK_KEYID_8821C BIT(8)
#define BIT_RXBCUSEDK_8821C BIT(7)
#define BIT_TXBCUSEDK_8821C BIT(6)
#define BIT_NOSKMC_8821C BIT(5)
#define BIT_SKBYA2_8821C BIT(4)
#define BIT_RXDEC_8821C BIT(3)
#define BIT_TXENC_8821C BIT(2)
#define BIT_RXUHUSEDK_8821C BIT(1)
#define BIT_TXUHUSEDK_8821C BIT(0)
/* 2 REG_RXFILTER_CATEGORY_1_8821C */
#define BIT_SHIFT_RXFILTER_CATEGORY_1_8821C 0
#define BIT_MASK_RXFILTER_CATEGORY_1_8821C 0xff
#define BIT_RXFILTER_CATEGORY_1_8821C(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_1_8821C) \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8821C)
#define BITS_RXFILTER_CATEGORY_1_8821C \
(BIT_MASK_RXFILTER_CATEGORY_1_8821C \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8821C)
#define BIT_CLEAR_RXFILTER_CATEGORY_1_8821C(x) \
((x) & (~BITS_RXFILTER_CATEGORY_1_8821C))
#define BIT_GET_RXFILTER_CATEGORY_1_8821C(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_1_8821C) & \
BIT_MASK_RXFILTER_CATEGORY_1_8821C)
#define BIT_SET_RXFILTER_CATEGORY_1_8821C(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_1_8821C(x) | \
BIT_RXFILTER_CATEGORY_1_8821C(v))
/* 2 REG_RXFILTER_ACTION_1_8821C */
#define BIT_SHIFT_RXFILTER_ACTION_1_8821C 0
#define BIT_MASK_RXFILTER_ACTION_1_8821C 0xff
#define BIT_RXFILTER_ACTION_1_8821C(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_1_8821C) \
<< BIT_SHIFT_RXFILTER_ACTION_1_8821C)
#define BITS_RXFILTER_ACTION_1_8821C \
(BIT_MASK_RXFILTER_ACTION_1_8821C << BIT_SHIFT_RXFILTER_ACTION_1_8821C)
#define BIT_CLEAR_RXFILTER_ACTION_1_8821C(x) \
((x) & (~BITS_RXFILTER_ACTION_1_8821C))
#define BIT_GET_RXFILTER_ACTION_1_8821C(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_1_8821C) & \
BIT_MASK_RXFILTER_ACTION_1_8821C)
#define BIT_SET_RXFILTER_ACTION_1_8821C(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_1_8821C(x) | BIT_RXFILTER_ACTION_1_8821C(v))
/* 2 REG_RXFILTER_CATEGORY_2_8821C */
#define BIT_SHIFT_RXFILTER_CATEGORY_2_8821C 0
#define BIT_MASK_RXFILTER_CATEGORY_2_8821C 0xff
#define BIT_RXFILTER_CATEGORY_2_8821C(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_2_8821C) \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8821C)
#define BITS_RXFILTER_CATEGORY_2_8821C \
(BIT_MASK_RXFILTER_CATEGORY_2_8821C \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8821C)
#define BIT_CLEAR_RXFILTER_CATEGORY_2_8821C(x) \
((x) & (~BITS_RXFILTER_CATEGORY_2_8821C))
#define BIT_GET_RXFILTER_CATEGORY_2_8821C(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_2_8821C) & \
BIT_MASK_RXFILTER_CATEGORY_2_8821C)
#define BIT_SET_RXFILTER_CATEGORY_2_8821C(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_2_8821C(x) | \
BIT_RXFILTER_CATEGORY_2_8821C(v))
/* 2 REG_RXFILTER_ACTION_2_8821C */
#define BIT_SHIFT_RXFILTER_ACTION_2_8821C 0
#define BIT_MASK_RXFILTER_ACTION_2_8821C 0xff
#define BIT_RXFILTER_ACTION_2_8821C(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_2_8821C) \
<< BIT_SHIFT_RXFILTER_ACTION_2_8821C)
#define BITS_RXFILTER_ACTION_2_8821C \
(BIT_MASK_RXFILTER_ACTION_2_8821C << BIT_SHIFT_RXFILTER_ACTION_2_8821C)
#define BIT_CLEAR_RXFILTER_ACTION_2_8821C(x) \
((x) & (~BITS_RXFILTER_ACTION_2_8821C))
#define BIT_GET_RXFILTER_ACTION_2_8821C(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_2_8821C) & \
BIT_MASK_RXFILTER_ACTION_2_8821C)
#define BIT_SET_RXFILTER_ACTION_2_8821C(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_2_8821C(x) | BIT_RXFILTER_ACTION_2_8821C(v))
/* 2 REG_RXFILTER_CATEGORY_3_8821C */
#define BIT_SHIFT_RXFILTER_CATEGORY_3_8821C 0
#define BIT_MASK_RXFILTER_CATEGORY_3_8821C 0xff
#define BIT_RXFILTER_CATEGORY_3_8821C(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_3_8821C) \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8821C)
#define BITS_RXFILTER_CATEGORY_3_8821C \
(BIT_MASK_RXFILTER_CATEGORY_3_8821C \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8821C)
#define BIT_CLEAR_RXFILTER_CATEGORY_3_8821C(x) \
((x) & (~BITS_RXFILTER_CATEGORY_3_8821C))
#define BIT_GET_RXFILTER_CATEGORY_3_8821C(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_3_8821C) & \
BIT_MASK_RXFILTER_CATEGORY_3_8821C)
#define BIT_SET_RXFILTER_CATEGORY_3_8821C(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_3_8821C(x) | \
BIT_RXFILTER_CATEGORY_3_8821C(v))
/* 2 REG_RXFILTER_ACTION_3_8821C */
#define BIT_SHIFT_RXFILTER_ACTION_3_8821C 0
#define BIT_MASK_RXFILTER_ACTION_3_8821C 0xff
#define BIT_RXFILTER_ACTION_3_8821C(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_3_8821C) \
<< BIT_SHIFT_RXFILTER_ACTION_3_8821C)
#define BITS_RXFILTER_ACTION_3_8821C \
(BIT_MASK_RXFILTER_ACTION_3_8821C << BIT_SHIFT_RXFILTER_ACTION_3_8821C)
#define BIT_CLEAR_RXFILTER_ACTION_3_8821C(x) \
((x) & (~BITS_RXFILTER_ACTION_3_8821C))
#define BIT_GET_RXFILTER_ACTION_3_8821C(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_3_8821C) & \
BIT_MASK_RXFILTER_ACTION_3_8821C)
#define BIT_SET_RXFILTER_ACTION_3_8821C(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_3_8821C(x) | BIT_RXFILTER_ACTION_3_8821C(v))
/* 2 REG_RXFLTMAP3_8821C (RX FILTER MAP GROUP 3) */
#define BIT_MGTFLT15EN_FW_8821C BIT(15)
#define BIT_MGTFLT14EN_FW_8821C BIT(14)
#define BIT_MGTFLT13EN_FW_8821C BIT(13)
#define BIT_MGTFLT12EN_FW_8821C BIT(12)
#define BIT_MGTFLT11EN_FW_8821C BIT(11)
#define BIT_MGTFLT10EN_FW_8821C BIT(10)
#define BIT_MGTFLT9EN_FW_8821C BIT(9)
#define BIT_MGTFLT8EN_FW_8821C BIT(8)
#define BIT_MGTFLT7EN_FW_8821C BIT(7)
#define BIT_MGTFLT6EN_FW_8821C BIT(6)
#define BIT_MGTFLT5EN_FW_8821C BIT(5)
#define BIT_MGTFLT4EN_FW_8821C BIT(4)
#define BIT_MGTFLT3EN_FW_8821C BIT(3)
#define BIT_MGTFLT2EN_FW_8821C BIT(2)
#define BIT_MGTFLT1EN_FW_8821C BIT(1)
#define BIT_MGTFLT0EN_FW_8821C BIT(0)
/* 2 REG_RXFLTMAP4_8821C (RX FILTER MAP GROUP 4) */
#define BIT_CTRLFLT15EN_FW_8821C BIT(15)
#define BIT_CTRLFLT14EN_FW_8821C BIT(14)
#define BIT_CTRLFLT13EN_FW_8821C BIT(13)
#define BIT_CTRLFLT12EN_FW_8821C BIT(12)
#define BIT_CTRLFLT11EN_FW_8821C BIT(11)
#define BIT_CTRLFLT10EN_FW_8821C BIT(10)
#define BIT_CTRLFLT9EN_FW_8821C BIT(9)
#define BIT_CTRLFLT8EN_FW_8821C BIT(8)
#define BIT_CTRLFLT7EN_FW_8821C BIT(7)
#define BIT_CTRLFLT6EN_FW_8821C BIT(6)
#define BIT_CTRLFLT5EN_FW_8821C BIT(5)
#define BIT_CTRLFLT4EN_FW_8821C BIT(4)
#define BIT_CTRLFLT3EN_FW_8821C BIT(3)
#define BIT_CTRLFLT2EN_FW_8821C BIT(2)
#define BIT_CTRLFLT1EN_FW_8821C BIT(1)
#define BIT_CTRLFLT0EN_FW_8821C BIT(0)
/* 2 REG_RXFLTMAP5_8821C (RX FILTER MAP GROUP 5) */
#define BIT_DATAFLT15EN_FW_8821C BIT(15)
#define BIT_DATAFLT14EN_FW_8821C BIT(14)
#define BIT_DATAFLT13EN_FW_8821C BIT(13)
#define BIT_DATAFLT12EN_FW_8821C BIT(12)
#define BIT_DATAFLT11EN_FW_8821C BIT(11)
#define BIT_DATAFLT10EN_FW_8821C BIT(10)
#define BIT_DATAFLT9EN_FW_8821C BIT(9)
#define BIT_DATAFLT8EN_FW_8821C BIT(8)
#define BIT_DATAFLT7EN_FW_8821C BIT(7)
#define BIT_DATAFLT6EN_FW_8821C BIT(6)
#define BIT_DATAFLT5EN_FW_8821C BIT(5)
#define BIT_DATAFLT4EN_FW_8821C BIT(4)
#define BIT_DATAFLT3EN_FW_8821C BIT(3)
#define BIT_DATAFLT2EN_FW_8821C BIT(2)
#define BIT_DATAFLT1EN_FW_8821C BIT(1)
#define BIT_DATAFLT0EN_FW_8821C BIT(0)
/* 2 REG_RXFLTMAP6_8821C (RX FILTER MAP GROUP 6) */
#define BIT_ACTIONFLT15EN_FW_8821C BIT(15)
#define BIT_ACTIONFLT14EN_FW_8821C BIT(14)
#define BIT_ACTIONFLT13EN_FW_8821C BIT(13)
#define BIT_ACTIONFLT12EN_FW_8821C BIT(12)
#define BIT_ACTIONFLT11EN_FW_8821C BIT(11)
#define BIT_ACTIONFLT10EN_FW_8821C BIT(10)
#define BIT_ACTIONFLT9EN_FW_8821C BIT(9)
#define BIT_ACTIONFLT8EN_FW_8821C BIT(8)
#define BIT_ACTIONFLT7EN_FW_8821C BIT(7)
#define BIT_ACTIONFLT6EN_FW_8821C BIT(6)
#define BIT_ACTIONFLT5EN_FW_8821C BIT(5)
#define BIT_ACTIONFLT4EN_FW_8821C BIT(4)
#define BIT_ACTIONFLT3EN_FW_8821C BIT(3)
#define BIT_ACTIONFLT2EN_FW_8821C BIT(2)
#define BIT_ACTIONFLT1EN_FW_8821C BIT(1)
#define BIT_ACTIONFLT0EN_FW_8821C BIT(0)
/* 2 REG_WOW_CTRL_8821C (WAKE ON WLAN CONTROL REGISTER) */
#define BIT_SHIFT_PSF_BSSIDSEL_B2B1_8821C 6
#define BIT_MASK_PSF_BSSIDSEL_B2B1_8821C 0x3
#define BIT_PSF_BSSIDSEL_B2B1_8821C(x) \
(((x) & BIT_MASK_PSF_BSSIDSEL_B2B1_8821C) \
<< BIT_SHIFT_PSF_BSSIDSEL_B2B1_8821C)
#define BITS_PSF_BSSIDSEL_B2B1_8821C \
(BIT_MASK_PSF_BSSIDSEL_B2B1_8821C << BIT_SHIFT_PSF_BSSIDSEL_B2B1_8821C)
#define BIT_CLEAR_PSF_BSSIDSEL_B2B1_8821C(x) \
((x) & (~BITS_PSF_BSSIDSEL_B2B1_8821C))
#define BIT_GET_PSF_BSSIDSEL_B2B1_8821C(x) \
(((x) >> BIT_SHIFT_PSF_BSSIDSEL_B2B1_8821C) & \
BIT_MASK_PSF_BSSIDSEL_B2B1_8821C)
#define BIT_SET_PSF_BSSIDSEL_B2B1_8821C(x, v) \
(BIT_CLEAR_PSF_BSSIDSEL_B2B1_8821C(x) | BIT_PSF_BSSIDSEL_B2B1_8821C(v))
#define BIT_WOWHCI_8821C BIT(5)
#define BIT_PSF_BSSIDSEL_B0_8821C BIT(4)
#define BIT_UWF_8821C BIT(3)
#define BIT_MAGIC_8821C BIT(2)
#define BIT_WOWEN_8821C BIT(1)
#define BIT_FORCE_WAKEUP_8821C BIT(0)
/* 2 REG_NAN_RX_TSF_FILTER_8821C(NAN_RX_TSF_ADDRESS_FILTER) */
#define BIT_CHK_TSF_TA_8821C BIT(2)
#define BIT_CHK_TSF_CBSSID_8821C BIT(1)
#define BIT_CHK_TSF_EN_8821C BIT(0)
/* 2 REG_PS_RX_INFO_8821C (POWER SAVE RX INFORMATION REGISTER) */
#define BIT_SHIFT_PORTSEL__PS_RX_INFO_8821C 5
#define BIT_MASK_PORTSEL__PS_RX_INFO_8821C 0x7
#define BIT_PORTSEL__PS_RX_INFO_8821C(x) \
(((x) & BIT_MASK_PORTSEL__PS_RX_INFO_8821C) \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8821C)
#define BITS_PORTSEL__PS_RX_INFO_8821C \
(BIT_MASK_PORTSEL__PS_RX_INFO_8821C \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8821C)
#define BIT_CLEAR_PORTSEL__PS_RX_INFO_8821C(x) \
((x) & (~BITS_PORTSEL__PS_RX_INFO_8821C))
#define BIT_GET_PORTSEL__PS_RX_INFO_8821C(x) \
(((x) >> BIT_SHIFT_PORTSEL__PS_RX_INFO_8821C) & \
BIT_MASK_PORTSEL__PS_RX_INFO_8821C)
#define BIT_SET_PORTSEL__PS_RX_INFO_8821C(x, v) \
(BIT_CLEAR_PORTSEL__PS_RX_INFO_8821C(x) | \
BIT_PORTSEL__PS_RX_INFO_8821C(v))
#define BIT_RXCTRLIN0_8821C BIT(4)
#define BIT_RXMGTIN0_8821C BIT(3)
#define BIT_RXDATAIN2_8821C BIT(2)
#define BIT_RXDATAIN1_8821C BIT(1)
#define BIT_RXDATAIN0_8821C BIT(0)
/* 2 REG_WMMPS_UAPSD_TID_8821C (WMM POWER SAVE UAPSD TID REGISTER) */
#define BIT_WMMPS_UAPSD_TID7_8821C BIT(7)
#define BIT_WMMPS_UAPSD_TID6_8821C BIT(6)
#define BIT_WMMPS_UAPSD_TID5_8821C BIT(5)
#define BIT_WMMPS_UAPSD_TID4_8821C BIT(4)
#define BIT_WMMPS_UAPSD_TID3_8821C BIT(3)
#define BIT_WMMPS_UAPSD_TID2_8821C BIT(2)
#define BIT_WMMPS_UAPSD_TID1_8821C BIT(1)
#define BIT_WMMPS_UAPSD_TID0_8821C BIT(0)
/* 2 REG_LPNAV_CTRL_8821C (LOW POWER NAV CONTROL REGISTER) */
#define BIT_LPNAV_EN_8821C BIT(31)
#define BIT_SHIFT_LPNAV_EARLY_8821C 16
#define BIT_MASK_LPNAV_EARLY_8821C 0x7fff
#define BIT_LPNAV_EARLY_8821C(x) \
(((x) & BIT_MASK_LPNAV_EARLY_8821C) << BIT_SHIFT_LPNAV_EARLY_8821C)
#define BITS_LPNAV_EARLY_8821C \
(BIT_MASK_LPNAV_EARLY_8821C << BIT_SHIFT_LPNAV_EARLY_8821C)
#define BIT_CLEAR_LPNAV_EARLY_8821C(x) ((x) & (~BITS_LPNAV_EARLY_8821C))
#define BIT_GET_LPNAV_EARLY_8821C(x) \
(((x) >> BIT_SHIFT_LPNAV_EARLY_8821C) & BIT_MASK_LPNAV_EARLY_8821C)
#define BIT_SET_LPNAV_EARLY_8821C(x, v) \
(BIT_CLEAR_LPNAV_EARLY_8821C(x) | BIT_LPNAV_EARLY_8821C(v))
#define BIT_SHIFT_LPNAV_TH_8821C 0
#define BIT_MASK_LPNAV_TH_8821C 0xffff
#define BIT_LPNAV_TH_8821C(x) \
(((x) & BIT_MASK_LPNAV_TH_8821C) << BIT_SHIFT_LPNAV_TH_8821C)
#define BITS_LPNAV_TH_8821C \
(BIT_MASK_LPNAV_TH_8821C << BIT_SHIFT_LPNAV_TH_8821C)
#define BIT_CLEAR_LPNAV_TH_8821C(x) ((x) & (~BITS_LPNAV_TH_8821C))
#define BIT_GET_LPNAV_TH_8821C(x) \
(((x) >> BIT_SHIFT_LPNAV_TH_8821C) & BIT_MASK_LPNAV_TH_8821C)
#define BIT_SET_LPNAV_TH_8821C(x, v) \
(BIT_CLEAR_LPNAV_TH_8821C(x) | BIT_LPNAV_TH_8821C(v))
/* 2 REG_WKFMCAM_CMD_8821C (WAKEUP FRAME CAM COMMAND REGISTER) */
#define BIT_WKFCAM_POLLING_V1_8821C BIT(31)
#define BIT_WKFCAM_CLR_V1_8821C BIT(30)
#define BIT_WKFCAM_WE_8821C BIT(16)
#define BIT_SHIFT_WKFCAM_ADDR_V2_8821C 8
#define BIT_MASK_WKFCAM_ADDR_V2_8821C 0xff
#define BIT_WKFCAM_ADDR_V2_8821C(x) \
(((x) & BIT_MASK_WKFCAM_ADDR_V2_8821C) \
<< BIT_SHIFT_WKFCAM_ADDR_V2_8821C)
#define BITS_WKFCAM_ADDR_V2_8821C \
(BIT_MASK_WKFCAM_ADDR_V2_8821C << BIT_SHIFT_WKFCAM_ADDR_V2_8821C)
#define BIT_CLEAR_WKFCAM_ADDR_V2_8821C(x) ((x) & (~BITS_WKFCAM_ADDR_V2_8821C))
#define BIT_GET_WKFCAM_ADDR_V2_8821C(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR_V2_8821C) & \
BIT_MASK_WKFCAM_ADDR_V2_8821C)
#define BIT_SET_WKFCAM_ADDR_V2_8821C(x, v) \
(BIT_CLEAR_WKFCAM_ADDR_V2_8821C(x) | BIT_WKFCAM_ADDR_V2_8821C(v))
#define BIT_SHIFT_WKFCAM_CAM_NUM_V1_8821C 0
#define BIT_MASK_WKFCAM_CAM_NUM_V1_8821C 0xff
#define BIT_WKFCAM_CAM_NUM_V1_8821C(x) \
(((x) & BIT_MASK_WKFCAM_CAM_NUM_V1_8821C) \
<< BIT_SHIFT_WKFCAM_CAM_NUM_V1_8821C)
#define BITS_WKFCAM_CAM_NUM_V1_8821C \
(BIT_MASK_WKFCAM_CAM_NUM_V1_8821C << BIT_SHIFT_WKFCAM_CAM_NUM_V1_8821C)
#define BIT_CLEAR_WKFCAM_CAM_NUM_V1_8821C(x) \
((x) & (~BITS_WKFCAM_CAM_NUM_V1_8821C))
#define BIT_GET_WKFCAM_CAM_NUM_V1_8821C(x) \
(((x) >> BIT_SHIFT_WKFCAM_CAM_NUM_V1_8821C) & \
BIT_MASK_WKFCAM_CAM_NUM_V1_8821C)
#define BIT_SET_WKFCAM_CAM_NUM_V1_8821C(x, v) \
(BIT_CLEAR_WKFCAM_CAM_NUM_V1_8821C(x) | BIT_WKFCAM_CAM_NUM_V1_8821C(v))
/* 2 REG_WKFMCAM_RWD_8821C (WAKEUP FRAME READ/WRITE DATA) */
#define BIT_SHIFT_WKFMCAM_RWD_8821C 0
#define BIT_MASK_WKFMCAM_RWD_8821C 0xffffffffL
#define BIT_WKFMCAM_RWD_8821C(x) \
(((x) & BIT_MASK_WKFMCAM_RWD_8821C) << BIT_SHIFT_WKFMCAM_RWD_8821C)
#define BITS_WKFMCAM_RWD_8821C \
(BIT_MASK_WKFMCAM_RWD_8821C << BIT_SHIFT_WKFMCAM_RWD_8821C)
#define BIT_CLEAR_WKFMCAM_RWD_8821C(x) ((x) & (~BITS_WKFMCAM_RWD_8821C))
#define BIT_GET_WKFMCAM_RWD_8821C(x) \
(((x) >> BIT_SHIFT_WKFMCAM_RWD_8821C) & BIT_MASK_WKFMCAM_RWD_8821C)
#define BIT_SET_WKFMCAM_RWD_8821C(x, v) \
(BIT_CLEAR_WKFMCAM_RWD_8821C(x) | BIT_WKFMCAM_RWD_8821C(v))
/* 2 REG_RXFLTMAP0_8821C (RX FILTER MAP GROUP 0) */
#define BIT_MGTFLT15EN_8821C BIT(15)
#define BIT_MGTFLT14EN_8821C BIT(14)
#define BIT_MGTFLT13EN_8821C BIT(13)
#define BIT_MGTFLT12EN_8821C BIT(12)
#define BIT_MGTFLT11EN_8821C BIT(11)
#define BIT_MGTFLT10EN_8821C BIT(10)
#define BIT_MGTFLT9EN_8821C BIT(9)
#define BIT_MGTFLT8EN_8821C BIT(8)
#define BIT_MGTFLT7EN_8821C BIT(7)
#define BIT_MGTFLT6EN_8821C BIT(6)
#define BIT_MGTFLT5EN_8821C BIT(5)
#define BIT_MGTFLT4EN_8821C BIT(4)
#define BIT_MGTFLT3EN_8821C BIT(3)
#define BIT_MGTFLT2EN_8821C BIT(2)
#define BIT_MGTFLT1EN_8821C BIT(1)
#define BIT_MGTFLT0EN_8821C BIT(0)
/* 2 REG_RXFLTMAP1_8821C (RX FILTER MAP GROUP 1) */
#define BIT_CTRLFLT15EN_8821C BIT(15)
#define BIT_CTRLFLT14EN_8821C BIT(14)
#define BIT_CTRLFLT13EN_8821C BIT(13)
#define BIT_CTRLFLT12EN_8821C BIT(12)
#define BIT_CTRLFLT11EN_8821C BIT(11)
#define BIT_CTRLFLT10EN_8821C BIT(10)
#define BIT_CTRLFLT9EN_8821C BIT(9)
#define BIT_CTRLFLT8EN_8821C BIT(8)
#define BIT_CTRLFLT7EN_8821C BIT(7)
#define BIT_CTRLFLT6EN_8821C BIT(6)
#define BIT_CTRLFLT5EN_8821C BIT(5)
#define BIT_CTRLFLT4EN_8821C BIT(4)
#define BIT_CTRLFLT3EN_8821C BIT(3)
#define BIT_CTRLFLT2EN_8821C BIT(2)
#define BIT_CTRLFLT1EN_8821C BIT(1)
#define BIT_CTRLFLT0EN_8821C BIT(0)
/* 2 REG_RXFLTMAP2_8821C (RX FILTER MAP GROUP 2) */
#define BIT_DATAFLT15EN_8821C BIT(15)
#define BIT_DATAFLT14EN_8821C BIT(14)
#define BIT_DATAFLT13EN_8821C BIT(13)
#define BIT_DATAFLT12EN_8821C BIT(12)
#define BIT_DATAFLT11EN_8821C BIT(11)
#define BIT_DATAFLT10EN_8821C BIT(10)
#define BIT_DATAFLT9EN_8821C BIT(9)
#define BIT_DATAFLT8EN_8821C BIT(8)
#define BIT_DATAFLT7EN_8821C BIT(7)
#define BIT_DATAFLT6EN_8821C BIT(6)
#define BIT_DATAFLT5EN_8821C BIT(5)
#define BIT_DATAFLT4EN_8821C BIT(4)
#define BIT_DATAFLT3EN_8821C BIT(3)
#define BIT_DATAFLT2EN_8821C BIT(2)
#define BIT_DATAFLT1EN_8821C BIT(1)
#define BIT_DATAFLT0EN_8821C BIT(0)
/* 2 REG_RSVD_8821C */
/* 2 REG_BCN_PSR_RPT_8821C (BEACON PARSER REPORT REGISTER) */
#define BIT_SHIFT_DTIM_CNT_8821C 24
#define BIT_MASK_DTIM_CNT_8821C 0xff
#define BIT_DTIM_CNT_8821C(x) \
(((x) & BIT_MASK_DTIM_CNT_8821C) << BIT_SHIFT_DTIM_CNT_8821C)
#define BITS_DTIM_CNT_8821C \
(BIT_MASK_DTIM_CNT_8821C << BIT_SHIFT_DTIM_CNT_8821C)
#define BIT_CLEAR_DTIM_CNT_8821C(x) ((x) & (~BITS_DTIM_CNT_8821C))
#define BIT_GET_DTIM_CNT_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT_8821C) & BIT_MASK_DTIM_CNT_8821C)
#define BIT_SET_DTIM_CNT_8821C(x, v) \
(BIT_CLEAR_DTIM_CNT_8821C(x) | BIT_DTIM_CNT_8821C(v))
#define BIT_SHIFT_DTIM_PERIOD_8821C 16
#define BIT_MASK_DTIM_PERIOD_8821C 0xff
#define BIT_DTIM_PERIOD_8821C(x) \
(((x) & BIT_MASK_DTIM_PERIOD_8821C) << BIT_SHIFT_DTIM_PERIOD_8821C)
#define BITS_DTIM_PERIOD_8821C \
(BIT_MASK_DTIM_PERIOD_8821C << BIT_SHIFT_DTIM_PERIOD_8821C)
#define BIT_CLEAR_DTIM_PERIOD_8821C(x) ((x) & (~BITS_DTIM_PERIOD_8821C))
#define BIT_GET_DTIM_PERIOD_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD_8821C) & BIT_MASK_DTIM_PERIOD_8821C)
#define BIT_SET_DTIM_PERIOD_8821C(x, v) \
(BIT_CLEAR_DTIM_PERIOD_8821C(x) | BIT_DTIM_PERIOD_8821C(v))
#define BIT_DTIM_8821C BIT(15)
#define BIT_TIM_8821C BIT(14)
#define BIT_RPT_VALID_8821C BIT(13)
#define BIT_SHIFT_PS_AID_0_8821C 0
#define BIT_MASK_PS_AID_0_8821C 0x7ff
#define BIT_PS_AID_0_8821C(x) \
(((x) & BIT_MASK_PS_AID_0_8821C) << BIT_SHIFT_PS_AID_0_8821C)
#define BITS_PS_AID_0_8821C \
(BIT_MASK_PS_AID_0_8821C << BIT_SHIFT_PS_AID_0_8821C)
#define BIT_CLEAR_PS_AID_0_8821C(x) ((x) & (~BITS_PS_AID_0_8821C))
#define BIT_GET_PS_AID_0_8821C(x) \
(((x) >> BIT_SHIFT_PS_AID_0_8821C) & BIT_MASK_PS_AID_0_8821C)
#define BIT_SET_PS_AID_0_8821C(x, v) \
(BIT_CLEAR_PS_AID_0_8821C(x) | BIT_PS_AID_0_8821C(v))
/* 2 REG_FLC_RPC_8821C (FW LPS CONDITION -- RX PKT COUNTER) */
#define BIT_SHIFT_FLC_RPC_8821C 0
#define BIT_MASK_FLC_RPC_8821C 0xff
#define BIT_FLC_RPC_8821C(x) \
(((x) & BIT_MASK_FLC_RPC_8821C) << BIT_SHIFT_FLC_RPC_8821C)
#define BITS_FLC_RPC_8821C (BIT_MASK_FLC_RPC_8821C << BIT_SHIFT_FLC_RPC_8821C)
#define BIT_CLEAR_FLC_RPC_8821C(x) ((x) & (~BITS_FLC_RPC_8821C))
#define BIT_GET_FLC_RPC_8821C(x) \
(((x) >> BIT_SHIFT_FLC_RPC_8821C) & BIT_MASK_FLC_RPC_8821C)
#define BIT_SET_FLC_RPC_8821C(x, v) \
(BIT_CLEAR_FLC_RPC_8821C(x) | BIT_FLC_RPC_8821C(v))
/* 2 REG_FLC_RPCT_8821C (FLC_RPC THRESHOLD) */
#define BIT_SHIFT_FLC_RPCT_8821C 0
#define BIT_MASK_FLC_RPCT_8821C 0xff
#define BIT_FLC_RPCT_8821C(x) \
(((x) & BIT_MASK_FLC_RPCT_8821C) << BIT_SHIFT_FLC_RPCT_8821C)
#define BITS_FLC_RPCT_8821C \
(BIT_MASK_FLC_RPCT_8821C << BIT_SHIFT_FLC_RPCT_8821C)
#define BIT_CLEAR_FLC_RPCT_8821C(x) ((x) & (~BITS_FLC_RPCT_8821C))
#define BIT_GET_FLC_RPCT_8821C(x) \
(((x) >> BIT_SHIFT_FLC_RPCT_8821C) & BIT_MASK_FLC_RPCT_8821C)
#define BIT_SET_FLC_RPCT_8821C(x, v) \
(BIT_CLEAR_FLC_RPCT_8821C(x) | BIT_FLC_RPCT_8821C(v))
/* 2 REG_FLC_PTS_8821C (PKT TYPE SELECTION OF FLC_RPC T) */
#define BIT_CMF_8821C BIT(2)
#define BIT_CCF_8821C BIT(1)
#define BIT_CDF_8821C BIT(0)
/* 2 REG_FLC_TRPC_8821C (TIMER OF FLC_RPC) */
#define BIT_FLC_RPCT_V1_8821C BIT(7)
#define BIT_MODE_8821C BIT(6)
#define BIT_SHIFT_TRPCD_8821C 0
#define BIT_MASK_TRPCD_8821C 0x3f
#define BIT_TRPCD_8821C(x) \
(((x) & BIT_MASK_TRPCD_8821C) << BIT_SHIFT_TRPCD_8821C)
#define BITS_TRPCD_8821C (BIT_MASK_TRPCD_8821C << BIT_SHIFT_TRPCD_8821C)
#define BIT_CLEAR_TRPCD_8821C(x) ((x) & (~BITS_TRPCD_8821C))
#define BIT_GET_TRPCD_8821C(x) \
(((x) >> BIT_SHIFT_TRPCD_8821C) & BIT_MASK_TRPCD_8821C)
#define BIT_SET_TRPCD_8821C(x, v) \
(BIT_CLEAR_TRPCD_8821C(x) | BIT_TRPCD_8821C(v))
/* 2 REG_RXPKTMON_CTRL_8821C */
#define BIT_SHIFT_RXBKQPKT_SEQ_8821C 20
#define BIT_MASK_RXBKQPKT_SEQ_8821C 0xf
#define BIT_RXBKQPKT_SEQ_8821C(x) \
(((x) & BIT_MASK_RXBKQPKT_SEQ_8821C) << BIT_SHIFT_RXBKQPKT_SEQ_8821C)
#define BITS_RXBKQPKT_SEQ_8821C \
(BIT_MASK_RXBKQPKT_SEQ_8821C << BIT_SHIFT_RXBKQPKT_SEQ_8821C)
#define BIT_CLEAR_RXBKQPKT_SEQ_8821C(x) ((x) & (~BITS_RXBKQPKT_SEQ_8821C))
#define BIT_GET_RXBKQPKT_SEQ_8821C(x) \
(((x) >> BIT_SHIFT_RXBKQPKT_SEQ_8821C) & BIT_MASK_RXBKQPKT_SEQ_8821C)
#define BIT_SET_RXBKQPKT_SEQ_8821C(x, v) \
(BIT_CLEAR_RXBKQPKT_SEQ_8821C(x) | BIT_RXBKQPKT_SEQ_8821C(v))
#define BIT_SHIFT_RXBEQPKT_SEQ_8821C 16
#define BIT_MASK_RXBEQPKT_SEQ_8821C 0xf
#define BIT_RXBEQPKT_SEQ_8821C(x) \
(((x) & BIT_MASK_RXBEQPKT_SEQ_8821C) << BIT_SHIFT_RXBEQPKT_SEQ_8821C)
#define BITS_RXBEQPKT_SEQ_8821C \
(BIT_MASK_RXBEQPKT_SEQ_8821C << BIT_SHIFT_RXBEQPKT_SEQ_8821C)
#define BIT_CLEAR_RXBEQPKT_SEQ_8821C(x) ((x) & (~BITS_RXBEQPKT_SEQ_8821C))
#define BIT_GET_RXBEQPKT_SEQ_8821C(x) \
(((x) >> BIT_SHIFT_RXBEQPKT_SEQ_8821C) & BIT_MASK_RXBEQPKT_SEQ_8821C)
#define BIT_SET_RXBEQPKT_SEQ_8821C(x, v) \
(BIT_CLEAR_RXBEQPKT_SEQ_8821C(x) | BIT_RXBEQPKT_SEQ_8821C(v))
#define BIT_SHIFT_RXVIQPKT_SEQ_8821C 12
#define BIT_MASK_RXVIQPKT_SEQ_8821C 0xf
#define BIT_RXVIQPKT_SEQ_8821C(x) \
(((x) & BIT_MASK_RXVIQPKT_SEQ_8821C) << BIT_SHIFT_RXVIQPKT_SEQ_8821C)
#define BITS_RXVIQPKT_SEQ_8821C \
(BIT_MASK_RXVIQPKT_SEQ_8821C << BIT_SHIFT_RXVIQPKT_SEQ_8821C)
#define BIT_CLEAR_RXVIQPKT_SEQ_8821C(x) ((x) & (~BITS_RXVIQPKT_SEQ_8821C))
#define BIT_GET_RXVIQPKT_SEQ_8821C(x) \
(((x) >> BIT_SHIFT_RXVIQPKT_SEQ_8821C) & BIT_MASK_RXVIQPKT_SEQ_8821C)
#define BIT_SET_RXVIQPKT_SEQ_8821C(x, v) \
(BIT_CLEAR_RXVIQPKT_SEQ_8821C(x) | BIT_RXVIQPKT_SEQ_8821C(v))
#define BIT_SHIFT_RXVOQPKT_SEQ_8821C 8
#define BIT_MASK_RXVOQPKT_SEQ_8821C 0xf
#define BIT_RXVOQPKT_SEQ_8821C(x) \
(((x) & BIT_MASK_RXVOQPKT_SEQ_8821C) << BIT_SHIFT_RXVOQPKT_SEQ_8821C)
#define BITS_RXVOQPKT_SEQ_8821C \
(BIT_MASK_RXVOQPKT_SEQ_8821C << BIT_SHIFT_RXVOQPKT_SEQ_8821C)
#define BIT_CLEAR_RXVOQPKT_SEQ_8821C(x) ((x) & (~BITS_RXVOQPKT_SEQ_8821C))
#define BIT_GET_RXVOQPKT_SEQ_8821C(x) \
(((x) >> BIT_SHIFT_RXVOQPKT_SEQ_8821C) & BIT_MASK_RXVOQPKT_SEQ_8821C)
#define BIT_SET_RXVOQPKT_SEQ_8821C(x, v) \
(BIT_CLEAR_RXVOQPKT_SEQ_8821C(x) | BIT_RXVOQPKT_SEQ_8821C(v))
#define BIT_RXBKQPKT_ERR_8821C BIT(7)
#define BIT_RXBEQPKT_ERR_8821C BIT(6)
#define BIT_RXVIQPKT_ERR_8821C BIT(5)
#define BIT_RXVOQPKT_ERR_8821C BIT(4)
#define BIT_RXDMA_MON_EN_8821C BIT(2)
#define BIT_RXPKT_MON_RST_8821C BIT(1)
#define BIT_RXPKT_MON_EN_8821C BIT(0)
/* 2 REG_STATE_MON_8821C */
#define BIT_SHIFT_STATE_SEL_8821C 24
#define BIT_MASK_STATE_SEL_8821C 0x1f
#define BIT_STATE_SEL_8821C(x) \
(((x) & BIT_MASK_STATE_SEL_8821C) << BIT_SHIFT_STATE_SEL_8821C)
#define BITS_STATE_SEL_8821C \
(BIT_MASK_STATE_SEL_8821C << BIT_SHIFT_STATE_SEL_8821C)
#define BIT_CLEAR_STATE_SEL_8821C(x) ((x) & (~BITS_STATE_SEL_8821C))
#define BIT_GET_STATE_SEL_8821C(x) \
(((x) >> BIT_SHIFT_STATE_SEL_8821C) & BIT_MASK_STATE_SEL_8821C)
#define BIT_SET_STATE_SEL_8821C(x, v) \
(BIT_CLEAR_STATE_SEL_8821C(x) | BIT_STATE_SEL_8821C(v))
#define BIT_SHIFT_STATE_INFO_8821C 8
#define BIT_MASK_STATE_INFO_8821C 0xff
#define BIT_STATE_INFO_8821C(x) \
(((x) & BIT_MASK_STATE_INFO_8821C) << BIT_SHIFT_STATE_INFO_8821C)
#define BITS_STATE_INFO_8821C \
(BIT_MASK_STATE_INFO_8821C << BIT_SHIFT_STATE_INFO_8821C)
#define BIT_CLEAR_STATE_INFO_8821C(x) ((x) & (~BITS_STATE_INFO_8821C))
#define BIT_GET_STATE_INFO_8821C(x) \
(((x) >> BIT_SHIFT_STATE_INFO_8821C) & BIT_MASK_STATE_INFO_8821C)
#define BIT_SET_STATE_INFO_8821C(x, v) \
(BIT_CLEAR_STATE_INFO_8821C(x) | BIT_STATE_INFO_8821C(v))
#define BIT_UPD_NXT_STATE_8821C BIT(7)
#define BIT_SHIFT_CUR_STATE_8821C 0
#define BIT_MASK_CUR_STATE_8821C 0x7f
#define BIT_CUR_STATE_8821C(x) \
(((x) & BIT_MASK_CUR_STATE_8821C) << BIT_SHIFT_CUR_STATE_8821C)
#define BITS_CUR_STATE_8821C \
(BIT_MASK_CUR_STATE_8821C << BIT_SHIFT_CUR_STATE_8821C)
#define BIT_CLEAR_CUR_STATE_8821C(x) ((x) & (~BITS_CUR_STATE_8821C))
#define BIT_GET_CUR_STATE_8821C(x) \
(((x) >> BIT_SHIFT_CUR_STATE_8821C) & BIT_MASK_CUR_STATE_8821C)
#define BIT_SET_CUR_STATE_8821C(x, v) \
(BIT_CLEAR_CUR_STATE_8821C(x) | BIT_CUR_STATE_8821C(v))
/* 2 REG_ERROR_MON_8821C */
#define BIT_MACRX_ERR_1_8821C BIT(17)
#define BIT_MACRX_ERR_0_8821C BIT(16)
#define BIT_MACTX_ERR_3_8821C BIT(3)
#define BIT_MACTX_ERR_2_8821C BIT(2)
#define BIT_MACTX_ERR_1_8821C BIT(1)
#define BIT_MACTX_ERR_0_8821C BIT(0)
/* 2 REG_SEARCH_MACID_8821C */
#define BIT_EN_TXRPTBUF_CLK_8821C BIT(31)
#define BIT_SHIFT_INFO_INDEX_OFFSET_8821C 16
#define BIT_MASK_INFO_INDEX_OFFSET_8821C 0x1fff
#define BIT_INFO_INDEX_OFFSET_8821C(x) \
(((x) & BIT_MASK_INFO_INDEX_OFFSET_8821C) \
<< BIT_SHIFT_INFO_INDEX_OFFSET_8821C)
#define BITS_INFO_INDEX_OFFSET_8821C \
(BIT_MASK_INFO_INDEX_OFFSET_8821C << BIT_SHIFT_INFO_INDEX_OFFSET_8821C)
#define BIT_CLEAR_INFO_INDEX_OFFSET_8821C(x) \
((x) & (~BITS_INFO_INDEX_OFFSET_8821C))
#define BIT_GET_INFO_INDEX_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_INFO_INDEX_OFFSET_8821C) & \
BIT_MASK_INFO_INDEX_OFFSET_8821C)
#define BIT_SET_INFO_INDEX_OFFSET_8821C(x, v) \
(BIT_CLEAR_INFO_INDEX_OFFSET_8821C(x) | BIT_INFO_INDEX_OFFSET_8821C(v))
#define BIT_WMAC_SRCH_FIFOFULL_8821C BIT(15)
#define BIT_DIS_INFOSRCH_8821C BIT(14)
#define BIT_DISABLE_B0_8821C BIT(13)
#define BIT_SHIFT_INFO_ADDR_OFFSET_8821C 0
#define BIT_MASK_INFO_ADDR_OFFSET_8821C 0x1fff
#define BIT_INFO_ADDR_OFFSET_8821C(x) \
(((x) & BIT_MASK_INFO_ADDR_OFFSET_8821C) \
<< BIT_SHIFT_INFO_ADDR_OFFSET_8821C)
#define BITS_INFO_ADDR_OFFSET_8821C \
(BIT_MASK_INFO_ADDR_OFFSET_8821C << BIT_SHIFT_INFO_ADDR_OFFSET_8821C)
#define BIT_CLEAR_INFO_ADDR_OFFSET_8821C(x) \
((x) & (~BITS_INFO_ADDR_OFFSET_8821C))
#define BIT_GET_INFO_ADDR_OFFSET_8821C(x) \
(((x) >> BIT_SHIFT_INFO_ADDR_OFFSET_8821C) & \
BIT_MASK_INFO_ADDR_OFFSET_8821C)
#define BIT_SET_INFO_ADDR_OFFSET_8821C(x, v) \
(BIT_CLEAR_INFO_ADDR_OFFSET_8821C(x) | BIT_INFO_ADDR_OFFSET_8821C(v))
/* 2 REG_BT_COEX_TABLE_8821C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_COEX_TABLE_1_8821C 0
#define BIT_MASK_COEX_TABLE_1_8821C 0xffffffffL
#define BIT_COEX_TABLE_1_8821C(x) \
(((x) & BIT_MASK_COEX_TABLE_1_8821C) << BIT_SHIFT_COEX_TABLE_1_8821C)
#define BITS_COEX_TABLE_1_8821C \
(BIT_MASK_COEX_TABLE_1_8821C << BIT_SHIFT_COEX_TABLE_1_8821C)
#define BIT_CLEAR_COEX_TABLE_1_8821C(x) ((x) & (~BITS_COEX_TABLE_1_8821C))
#define BIT_GET_COEX_TABLE_1_8821C(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_1_8821C) & BIT_MASK_COEX_TABLE_1_8821C)
#define BIT_SET_COEX_TABLE_1_8821C(x, v) \
(BIT_CLEAR_COEX_TABLE_1_8821C(x) | BIT_COEX_TABLE_1_8821C(v))
/* 2 REG_BT_COEX_TABLE2_8821C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_COEX_TABLE_2_8821C 0
#define BIT_MASK_COEX_TABLE_2_8821C 0xffffffffL
#define BIT_COEX_TABLE_2_8821C(x) \
(((x) & BIT_MASK_COEX_TABLE_2_8821C) << BIT_SHIFT_COEX_TABLE_2_8821C)
#define BITS_COEX_TABLE_2_8821C \
(BIT_MASK_COEX_TABLE_2_8821C << BIT_SHIFT_COEX_TABLE_2_8821C)
#define BIT_CLEAR_COEX_TABLE_2_8821C(x) ((x) & (~BITS_COEX_TABLE_2_8821C))
#define BIT_GET_COEX_TABLE_2_8821C(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_2_8821C) & BIT_MASK_COEX_TABLE_2_8821C)
#define BIT_SET_COEX_TABLE_2_8821C(x, v) \
(BIT_CLEAR_COEX_TABLE_2_8821C(x) | BIT_COEX_TABLE_2_8821C(v))
/* 2 REG_BT_COEX_BREAK_TABLE_8821C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_BREAK_TABLE_2_8821C 16
#define BIT_MASK_BREAK_TABLE_2_8821C 0xffff
#define BIT_BREAK_TABLE_2_8821C(x) \
(((x) & BIT_MASK_BREAK_TABLE_2_8821C) << BIT_SHIFT_BREAK_TABLE_2_8821C)
#define BITS_BREAK_TABLE_2_8821C \
(BIT_MASK_BREAK_TABLE_2_8821C << BIT_SHIFT_BREAK_TABLE_2_8821C)
#define BIT_CLEAR_BREAK_TABLE_2_8821C(x) ((x) & (~BITS_BREAK_TABLE_2_8821C))
#define BIT_GET_BREAK_TABLE_2_8821C(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_2_8821C) & BIT_MASK_BREAK_TABLE_2_8821C)
#define BIT_SET_BREAK_TABLE_2_8821C(x, v) \
(BIT_CLEAR_BREAK_TABLE_2_8821C(x) | BIT_BREAK_TABLE_2_8821C(v))
#define BIT_SHIFT_BREAK_TABLE_1_8821C 0
#define BIT_MASK_BREAK_TABLE_1_8821C 0xffff
#define BIT_BREAK_TABLE_1_8821C(x) \
(((x) & BIT_MASK_BREAK_TABLE_1_8821C) << BIT_SHIFT_BREAK_TABLE_1_8821C)
#define BITS_BREAK_TABLE_1_8821C \
(BIT_MASK_BREAK_TABLE_1_8821C << BIT_SHIFT_BREAK_TABLE_1_8821C)
#define BIT_CLEAR_BREAK_TABLE_1_8821C(x) ((x) & (~BITS_BREAK_TABLE_1_8821C))
#define BIT_GET_BREAK_TABLE_1_8821C(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_1_8821C) & BIT_MASK_BREAK_TABLE_1_8821C)
#define BIT_SET_BREAK_TABLE_1_8821C(x, v) \
(BIT_CLEAR_BREAK_TABLE_1_8821C(x) | BIT_BREAK_TABLE_1_8821C(v))
/* 2 REG_BT_COEX_TABLE_H_8821C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_PRI_MASK_RX_RESP_V1_8821C BIT(30)
#define BIT_PRI_MASK_RXOFDM_V1_8821C BIT(29)
#define BIT_PRI_MASK_RXCCK_V1_8821C BIT(28)
#define BIT_SHIFT_PRI_MASK_TXAC_8821C 21
#define BIT_MASK_PRI_MASK_TXAC_8821C 0x7f
#define BIT_PRI_MASK_TXAC_8821C(x) \
(((x) & BIT_MASK_PRI_MASK_TXAC_8821C) << BIT_SHIFT_PRI_MASK_TXAC_8821C)
#define BITS_PRI_MASK_TXAC_8821C \
(BIT_MASK_PRI_MASK_TXAC_8821C << BIT_SHIFT_PRI_MASK_TXAC_8821C)
#define BIT_CLEAR_PRI_MASK_TXAC_8821C(x) ((x) & (~BITS_PRI_MASK_TXAC_8821C))
#define BIT_GET_PRI_MASK_TXAC_8821C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TXAC_8821C) & BIT_MASK_PRI_MASK_TXAC_8821C)
#define BIT_SET_PRI_MASK_TXAC_8821C(x, v) \
(BIT_CLEAR_PRI_MASK_TXAC_8821C(x) | BIT_PRI_MASK_TXAC_8821C(v))
#define BIT_SHIFT_PRI_MASK_NAV_8821C 13
#define BIT_MASK_PRI_MASK_NAV_8821C 0xff
#define BIT_PRI_MASK_NAV_8821C(x) \
(((x) & BIT_MASK_PRI_MASK_NAV_8821C) << BIT_SHIFT_PRI_MASK_NAV_8821C)
#define BITS_PRI_MASK_NAV_8821C \
(BIT_MASK_PRI_MASK_NAV_8821C << BIT_SHIFT_PRI_MASK_NAV_8821C)
#define BIT_CLEAR_PRI_MASK_NAV_8821C(x) ((x) & (~BITS_PRI_MASK_NAV_8821C))
#define BIT_GET_PRI_MASK_NAV_8821C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NAV_8821C) & BIT_MASK_PRI_MASK_NAV_8821C)
#define BIT_SET_PRI_MASK_NAV_8821C(x, v) \
(BIT_CLEAR_PRI_MASK_NAV_8821C(x) | BIT_PRI_MASK_NAV_8821C(v))
#define BIT_PRI_MASK_CCK_V1_8821C BIT(12)
#define BIT_PRI_MASK_OFDM_V1_8821C BIT(11)
#define BIT_PRI_MASK_RTY_V1_8821C BIT(10)
#define BIT_SHIFT_PRI_MASK_NUM_8821C 6
#define BIT_MASK_PRI_MASK_NUM_8821C 0xf
#define BIT_PRI_MASK_NUM_8821C(x) \
(((x) & BIT_MASK_PRI_MASK_NUM_8821C) << BIT_SHIFT_PRI_MASK_NUM_8821C)
#define BITS_PRI_MASK_NUM_8821C \
(BIT_MASK_PRI_MASK_NUM_8821C << BIT_SHIFT_PRI_MASK_NUM_8821C)
#define BIT_CLEAR_PRI_MASK_NUM_8821C(x) ((x) & (~BITS_PRI_MASK_NUM_8821C))
#define BIT_GET_PRI_MASK_NUM_8821C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NUM_8821C) & BIT_MASK_PRI_MASK_NUM_8821C)
#define BIT_SET_PRI_MASK_NUM_8821C(x, v) \
(BIT_CLEAR_PRI_MASK_NUM_8821C(x) | BIT_PRI_MASK_NUM_8821C(v))
#define BIT_SHIFT_PRI_MASK_TYPE_8821C 2
#define BIT_MASK_PRI_MASK_TYPE_8821C 0xf
#define BIT_PRI_MASK_TYPE_8821C(x) \
(((x) & BIT_MASK_PRI_MASK_TYPE_8821C) << BIT_SHIFT_PRI_MASK_TYPE_8821C)
#define BITS_PRI_MASK_TYPE_8821C \
(BIT_MASK_PRI_MASK_TYPE_8821C << BIT_SHIFT_PRI_MASK_TYPE_8821C)
#define BIT_CLEAR_PRI_MASK_TYPE_8821C(x) ((x) & (~BITS_PRI_MASK_TYPE_8821C))
#define BIT_GET_PRI_MASK_TYPE_8821C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TYPE_8821C) & BIT_MASK_PRI_MASK_TYPE_8821C)
#define BIT_SET_PRI_MASK_TYPE_8821C(x, v) \
(BIT_CLEAR_PRI_MASK_TYPE_8821C(x) | BIT_PRI_MASK_TYPE_8821C(v))
#define BIT_OOB_V1_8821C BIT(1)
#define BIT_ANT_SEL_V1_8821C BIT(0)
/* 2 REG_RXCMD_0_8821C */
#define BIT_RXCMD_EN_8821C BIT(31)
#define BIT_SHIFT_RXCMD_INFO_8821C 0
#define BIT_MASK_RXCMD_INFO_8821C 0x7fffffffL
#define BIT_RXCMD_INFO_8821C(x) \
(((x) & BIT_MASK_RXCMD_INFO_8821C) << BIT_SHIFT_RXCMD_INFO_8821C)
#define BITS_RXCMD_INFO_8821C \
(BIT_MASK_RXCMD_INFO_8821C << BIT_SHIFT_RXCMD_INFO_8821C)
#define BIT_CLEAR_RXCMD_INFO_8821C(x) ((x) & (~BITS_RXCMD_INFO_8821C))
#define BIT_GET_RXCMD_INFO_8821C(x) \
(((x) >> BIT_SHIFT_RXCMD_INFO_8821C) & BIT_MASK_RXCMD_INFO_8821C)
#define BIT_SET_RXCMD_INFO_8821C(x, v) \
(BIT_CLEAR_RXCMD_INFO_8821C(x) | BIT_RXCMD_INFO_8821C(v))
/* 2 REG_RXCMD_1_8821C */
#define BIT_SHIFT_CSI_RADDR_LATCH_8821C 24
#define BIT_MASK_CSI_RADDR_LATCH_8821C 0xff
#define BIT_CSI_RADDR_LATCH_8821C(x) \
(((x) & BIT_MASK_CSI_RADDR_LATCH_8821C) \
<< BIT_SHIFT_CSI_RADDR_LATCH_8821C)
#define BITS_CSI_RADDR_LATCH_8821C \
(BIT_MASK_CSI_RADDR_LATCH_8821C << BIT_SHIFT_CSI_RADDR_LATCH_8821C)
#define BIT_CLEAR_CSI_RADDR_LATCH_8821C(x) ((x) & (~BITS_CSI_RADDR_LATCH_8821C))
#define BIT_GET_CSI_RADDR_LATCH_8821C(x) \
(((x) >> BIT_SHIFT_CSI_RADDR_LATCH_8821C) & \
BIT_MASK_CSI_RADDR_LATCH_8821C)
#define BIT_SET_CSI_RADDR_LATCH_8821C(x, v) \
(BIT_CLEAR_CSI_RADDR_LATCH_8821C(x) | BIT_CSI_RADDR_LATCH_8821C(v))
#define BIT_SHIFT_CSI_WADDR_LATCH_8821C 16
#define BIT_MASK_CSI_WADDR_LATCH_8821C 0xff
#define BIT_CSI_WADDR_LATCH_8821C(x) \
(((x) & BIT_MASK_CSI_WADDR_LATCH_8821C) \
<< BIT_SHIFT_CSI_WADDR_LATCH_8821C)
#define BITS_CSI_WADDR_LATCH_8821C \
(BIT_MASK_CSI_WADDR_LATCH_8821C << BIT_SHIFT_CSI_WADDR_LATCH_8821C)
#define BIT_CLEAR_CSI_WADDR_LATCH_8821C(x) ((x) & (~BITS_CSI_WADDR_LATCH_8821C))
#define BIT_GET_CSI_WADDR_LATCH_8821C(x) \
(((x) >> BIT_SHIFT_CSI_WADDR_LATCH_8821C) & \
BIT_MASK_CSI_WADDR_LATCH_8821C)
#define BIT_SET_CSI_WADDR_LATCH_8821C(x, v) \
(BIT_CLEAR_CSI_WADDR_LATCH_8821C(x) | BIT_CSI_WADDR_LATCH_8821C(v))
#define BIT_SHIFT_RXCMD_PRD_8821C 0
#define BIT_MASK_RXCMD_PRD_8821C 0xffff
#define BIT_RXCMD_PRD_8821C(x) \
(((x) & BIT_MASK_RXCMD_PRD_8821C) << BIT_SHIFT_RXCMD_PRD_8821C)
#define BITS_RXCMD_PRD_8821C \
(BIT_MASK_RXCMD_PRD_8821C << BIT_SHIFT_RXCMD_PRD_8821C)
#define BIT_CLEAR_RXCMD_PRD_8821C(x) ((x) & (~BITS_RXCMD_PRD_8821C))
#define BIT_GET_RXCMD_PRD_8821C(x) \
(((x) >> BIT_SHIFT_RXCMD_PRD_8821C) & BIT_MASK_RXCMD_PRD_8821C)
#define BIT_SET_RXCMD_PRD_8821C(x, v) \
(BIT_CLEAR_RXCMD_PRD_8821C(x) | BIT_RXCMD_PRD_8821C(v))
/* 2 REG_WMAC_RESP_TXINFO_8821C (RESPONSE TXINFO REGISTER) */
#define BIT_SHIFT_WMAC_RESP_MFB_8821C 25
#define BIT_MASK_WMAC_RESP_MFB_8821C 0x7f
#define BIT_WMAC_RESP_MFB_8821C(x) \
(((x) & BIT_MASK_WMAC_RESP_MFB_8821C) << BIT_SHIFT_WMAC_RESP_MFB_8821C)
#define BITS_WMAC_RESP_MFB_8821C \
(BIT_MASK_WMAC_RESP_MFB_8821C << BIT_SHIFT_WMAC_RESP_MFB_8821C)
#define BIT_CLEAR_WMAC_RESP_MFB_8821C(x) ((x) & (~BITS_WMAC_RESP_MFB_8821C))
#define BIT_GET_WMAC_RESP_MFB_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_MFB_8821C) & BIT_MASK_WMAC_RESP_MFB_8821C)
#define BIT_SET_WMAC_RESP_MFB_8821C(x, v) \
(BIT_CLEAR_WMAC_RESP_MFB_8821C(x) | BIT_WMAC_RESP_MFB_8821C(v))
#define BIT_SHIFT_WMAC_ANTINF_SEL_8821C 23
#define BIT_MASK_WMAC_ANTINF_SEL_8821C 0x3
#define BIT_WMAC_ANTINF_SEL_8821C(x) \
(((x) & BIT_MASK_WMAC_ANTINF_SEL_8821C) \
<< BIT_SHIFT_WMAC_ANTINF_SEL_8821C)
#define BITS_WMAC_ANTINF_SEL_8821C \
(BIT_MASK_WMAC_ANTINF_SEL_8821C << BIT_SHIFT_WMAC_ANTINF_SEL_8821C)
#define BIT_CLEAR_WMAC_ANTINF_SEL_8821C(x) ((x) & (~BITS_WMAC_ANTINF_SEL_8821C))
#define BIT_GET_WMAC_ANTINF_SEL_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_ANTINF_SEL_8821C) & \
BIT_MASK_WMAC_ANTINF_SEL_8821C)
#define BIT_SET_WMAC_ANTINF_SEL_8821C(x, v) \
(BIT_CLEAR_WMAC_ANTINF_SEL_8821C(x) | BIT_WMAC_ANTINF_SEL_8821C(v))
#define BIT_SHIFT_WMAC_ANTSEL_SEL_8821C 21
#define BIT_MASK_WMAC_ANTSEL_SEL_8821C 0x3
#define BIT_WMAC_ANTSEL_SEL_8821C(x) \
(((x) & BIT_MASK_WMAC_ANTSEL_SEL_8821C) \
<< BIT_SHIFT_WMAC_ANTSEL_SEL_8821C)
#define BITS_WMAC_ANTSEL_SEL_8821C \
(BIT_MASK_WMAC_ANTSEL_SEL_8821C << BIT_SHIFT_WMAC_ANTSEL_SEL_8821C)
#define BIT_CLEAR_WMAC_ANTSEL_SEL_8821C(x) ((x) & (~BITS_WMAC_ANTSEL_SEL_8821C))
#define BIT_GET_WMAC_ANTSEL_SEL_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_ANTSEL_SEL_8821C) & \
BIT_MASK_WMAC_ANTSEL_SEL_8821C)
#define BIT_SET_WMAC_ANTSEL_SEL_8821C(x, v) \
(BIT_CLEAR_WMAC_ANTSEL_SEL_8821C(x) | BIT_WMAC_ANTSEL_SEL_8821C(v))
#define BIT_SHIFT_R_WMAC_RESP_TXPOWER_8821C 18
#define BIT_MASK_R_WMAC_RESP_TXPOWER_8821C 0x7
#define BIT_R_WMAC_RESP_TXPOWER_8821C(x) \
(((x) & BIT_MASK_R_WMAC_RESP_TXPOWER_8821C) \
<< BIT_SHIFT_R_WMAC_RESP_TXPOWER_8821C)
#define BITS_R_WMAC_RESP_TXPOWER_8821C \
(BIT_MASK_R_WMAC_RESP_TXPOWER_8821C \
<< BIT_SHIFT_R_WMAC_RESP_TXPOWER_8821C)
#define BIT_CLEAR_R_WMAC_RESP_TXPOWER_8821C(x) \
((x) & (~BITS_R_WMAC_RESP_TXPOWER_8821C))
#define BIT_GET_R_WMAC_RESP_TXPOWER_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RESP_TXPOWER_8821C) & \
BIT_MASK_R_WMAC_RESP_TXPOWER_8821C)
#define BIT_SET_R_WMAC_RESP_TXPOWER_8821C(x, v) \
(BIT_CLEAR_R_WMAC_RESP_TXPOWER_8821C(x) | \
BIT_R_WMAC_RESP_TXPOWER_8821C(v))
#define BIT_SHIFT_WMAC_RESP_TXANT_8821C 0
#define BIT_MASK_WMAC_RESP_TXANT_8821C 0x3ffff
#define BIT_WMAC_RESP_TXANT_8821C(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT_8821C) \
<< BIT_SHIFT_WMAC_RESP_TXANT_8821C)
#define BITS_WMAC_RESP_TXANT_8821C \
(BIT_MASK_WMAC_RESP_TXANT_8821C << BIT_SHIFT_WMAC_RESP_TXANT_8821C)
#define BIT_CLEAR_WMAC_RESP_TXANT_8821C(x) ((x) & (~BITS_WMAC_RESP_TXANT_8821C))
#define BIT_GET_WMAC_RESP_TXANT_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT_8821C) & \
BIT_MASK_WMAC_RESP_TXANT_8821C)
#define BIT_SET_WMAC_RESP_TXANT_8821C(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT_8821C(x) | BIT_WMAC_RESP_TXANT_8821C(v))
/* 2 REG_BBPSF_CTRL_8821C */
#define BIT_CTL_IDLE_CLR_CSI_RPT_8821C BIT(31)
#define BIT_WMAC_USE_NDPARATE_8821C BIT(30)
#define BIT_SHIFT_WMAC_CSI_RATE_8821C 24
#define BIT_MASK_WMAC_CSI_RATE_8821C 0x3f
#define BIT_WMAC_CSI_RATE_8821C(x) \
(((x) & BIT_MASK_WMAC_CSI_RATE_8821C) << BIT_SHIFT_WMAC_CSI_RATE_8821C)
#define BITS_WMAC_CSI_RATE_8821C \
(BIT_MASK_WMAC_CSI_RATE_8821C << BIT_SHIFT_WMAC_CSI_RATE_8821C)
#define BIT_CLEAR_WMAC_CSI_RATE_8821C(x) ((x) & (~BITS_WMAC_CSI_RATE_8821C))
#define BIT_GET_WMAC_CSI_RATE_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RATE_8821C) & BIT_MASK_WMAC_CSI_RATE_8821C)
#define BIT_SET_WMAC_CSI_RATE_8821C(x, v) \
(BIT_CLEAR_WMAC_CSI_RATE_8821C(x) | BIT_WMAC_CSI_RATE_8821C(v))
#define BIT_SHIFT_WMAC_RESP_TXRATE_8821C 16
#define BIT_MASK_WMAC_RESP_TXRATE_8821C 0xff
#define BIT_WMAC_RESP_TXRATE_8821C(x) \
(((x) & BIT_MASK_WMAC_RESP_TXRATE_8821C) \
<< BIT_SHIFT_WMAC_RESP_TXRATE_8821C)
#define BITS_WMAC_RESP_TXRATE_8821C \
(BIT_MASK_WMAC_RESP_TXRATE_8821C << BIT_SHIFT_WMAC_RESP_TXRATE_8821C)
#define BIT_CLEAR_WMAC_RESP_TXRATE_8821C(x) \
((x) & (~BITS_WMAC_RESP_TXRATE_8821C))
#define BIT_GET_WMAC_RESP_TXRATE_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXRATE_8821C) & \
BIT_MASK_WMAC_RESP_TXRATE_8821C)
#define BIT_SET_WMAC_RESP_TXRATE_8821C(x, v) \
(BIT_CLEAR_WMAC_RESP_TXRATE_8821C(x) | BIT_WMAC_RESP_TXRATE_8821C(v))
#define BIT_CSI_FORCE_RATE_EN_8821C BIT(15)
#define BIT_SHIFT_CSI_RSC_8821C 13
#define BIT_MASK_CSI_RSC_8821C 0x3
#define BIT_CSI_RSC_8821C(x) \
(((x) & BIT_MASK_CSI_RSC_8821C) << BIT_SHIFT_CSI_RSC_8821C)
#define BITS_CSI_RSC_8821C (BIT_MASK_CSI_RSC_8821C << BIT_SHIFT_CSI_RSC_8821C)
#define BIT_CLEAR_CSI_RSC_8821C(x) ((x) & (~BITS_CSI_RSC_8821C))
#define BIT_GET_CSI_RSC_8821C(x) \
(((x) >> BIT_SHIFT_CSI_RSC_8821C) & BIT_MASK_CSI_RSC_8821C)
#define BIT_SET_CSI_RSC_8821C(x, v) \
(BIT_CLEAR_CSI_RSC_8821C(x) | BIT_CSI_RSC_8821C(v))
#define BIT_CSI_GID_SEL_8821C BIT(12)
#define BIT_RDCSIMD_FLAG_TRIG_SEL_8821C BIT(11)
#define BIT_NDPVLD_POS_RST_FFPTR_DIS_V1_8821C BIT(10)
#define BIT_NDPVLD_PROTECT_RDRDY_DIS_8821C BIT(9)
#define BIT_RDCSI_EMPTY_APPZERO_8821C BIT(8)
#define BIT_BBPSF_MPDUCHKEN_8821C BIT(5)
#define BIT_BBPSF_MHCHKEN_8821C BIT(4)
#define BIT_BBPSF_ERRCHKEN_8821C BIT(3)
#define BIT_SHIFT_BBPSF_ERRTHR_8821C 0
#define BIT_MASK_BBPSF_ERRTHR_8821C 0x7
#define BIT_BBPSF_ERRTHR_8821C(x) \
(((x) & BIT_MASK_BBPSF_ERRTHR_8821C) << BIT_SHIFT_BBPSF_ERRTHR_8821C)
#define BITS_BBPSF_ERRTHR_8821C \
(BIT_MASK_BBPSF_ERRTHR_8821C << BIT_SHIFT_BBPSF_ERRTHR_8821C)
#define BIT_CLEAR_BBPSF_ERRTHR_8821C(x) ((x) & (~BITS_BBPSF_ERRTHR_8821C))
#define BIT_GET_BBPSF_ERRTHR_8821C(x) \
(((x) >> BIT_SHIFT_BBPSF_ERRTHR_8821C) & BIT_MASK_BBPSF_ERRTHR_8821C)
#define BIT_SET_BBPSF_ERRTHR_8821C(x, v) \
(BIT_CLEAR_BBPSF_ERRTHR_8821C(x) | BIT_BBPSF_ERRTHR_8821C(v))
/* 2 REG_P2P_RX_BCN_NOA_8821C (P2P RX BEACON NOA REGISTER) */
#define BIT_NOA_PARSER_EN_8821C BIT(15)
#define BIT_BSSID_SEL_8821C BIT(14)
#define BIT_SHIFT_P2P_OUI_TYPE_8821C 0
#define BIT_MASK_P2P_OUI_TYPE_8821C 0xff
#define BIT_P2P_OUI_TYPE_8821C(x) \
(((x) & BIT_MASK_P2P_OUI_TYPE_8821C) << BIT_SHIFT_P2P_OUI_TYPE_8821C)
#define BITS_P2P_OUI_TYPE_8821C \
(BIT_MASK_P2P_OUI_TYPE_8821C << BIT_SHIFT_P2P_OUI_TYPE_8821C)
#define BIT_CLEAR_P2P_OUI_TYPE_8821C(x) ((x) & (~BITS_P2P_OUI_TYPE_8821C))
#define BIT_GET_P2P_OUI_TYPE_8821C(x) \
(((x) >> BIT_SHIFT_P2P_OUI_TYPE_8821C) & BIT_MASK_P2P_OUI_TYPE_8821C)
#define BIT_SET_P2P_OUI_TYPE_8821C(x, v) \
(BIT_CLEAR_P2P_OUI_TYPE_8821C(x) | BIT_P2P_OUI_TYPE_8821C(v))
/* 2 REG_RSVD_8821C */
/* 2 REG_ASSOCIATED_BFMER0_INFO_8821C (ASSOCIATED BEAMFORMER0 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8821C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8821C 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0_V1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8821C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8821C)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_V1_8821C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8821C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8821C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1_8821C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_V1_8821C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_V1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8821C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8821C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_V1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1_8821C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_V1_8821C(v))
/* 2 REG_ASSOCIATED_BFMER0_INFO_H_8821C */
#define BIT_SHIFT_R_WMAC_TXCSI_AID0_8821C 16
#define BIT_MASK_R_WMAC_TXCSI_AID0_8821C 0x1ff
#define BIT_R_WMAC_TXCSI_AID0_8821C(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID0_8821C) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID0_8821C)
#define BITS_R_WMAC_TXCSI_AID0_8821C \
(BIT_MASK_R_WMAC_TXCSI_AID0_8821C << BIT_SHIFT_R_WMAC_TXCSI_AID0_8821C)
#define BIT_CLEAR_R_WMAC_TXCSI_AID0_8821C(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID0_8821C))
#define BIT_GET_R_WMAC_TXCSI_AID0_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID0_8821C) & \
BIT_MASK_R_WMAC_TXCSI_AID0_8821C)
#define BIT_SET_R_WMAC_TXCSI_AID0_8821C(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID0_8821C(x) | BIT_R_WMAC_TXCSI_AID0_8821C(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8821C(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_8821C (ASSOCIATED BEAMFORMER1 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8821C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8821C 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_V1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8821C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8821C)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_V1_8821C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8821C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8821C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1_8821C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_V1_8821C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_V1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8821C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8821C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_V1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1_8821C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_V1_8821C(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_H_8821C */
#define BIT_SHIFT_R_WMAC_TXCSI_AID1_8821C 16
#define BIT_MASK_R_WMAC_TXCSI_AID1_8821C 0x1ff
#define BIT_R_WMAC_TXCSI_AID1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID1_8821C) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID1_8821C)
#define BITS_R_WMAC_TXCSI_AID1_8821C \
(BIT_MASK_R_WMAC_TXCSI_AID1_8821C << BIT_SHIFT_R_WMAC_TXCSI_AID1_8821C)
#define BIT_CLEAR_R_WMAC_TXCSI_AID1_8821C(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID1_8821C))
#define BIT_GET_R_WMAC_TXCSI_AID1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID1_8821C) & \
BIT_MASK_R_WMAC_TXCSI_AID1_8821C)
#define BIT_SET_R_WMAC_TXCSI_AID1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID1_8821C(x) | BIT_R_WMAC_TXCSI_AID1_8821C(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8821C(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW20_8821C (TX CSI REPORT PARAMETER REGISTER) */
#define BIT_SHIFT_R_WMAC_BFINFO_20M_1_8821C 16
#define BIT_MASK_R_WMAC_BFINFO_20M_1_8821C 0xfff
#define BIT_R_WMAC_BFINFO_20M_1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_1_8821C) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8821C)
#define BITS_R_WMAC_BFINFO_20M_1_8821C \
(BIT_MASK_R_WMAC_BFINFO_20M_1_8821C \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8821C)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_1_8821C(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_1_8821C))
#define BIT_GET_R_WMAC_BFINFO_20M_1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_1_8821C) & \
BIT_MASK_R_WMAC_BFINFO_20M_1_8821C)
#define BIT_SET_R_WMAC_BFINFO_20M_1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_1_8821C(x) | \
BIT_R_WMAC_BFINFO_20M_1_8821C(v))
#define BIT_SHIFT_R_WMAC_BFINFO_20M_0_8821C 0
#define BIT_MASK_R_WMAC_BFINFO_20M_0_8821C 0xfff
#define BIT_R_WMAC_BFINFO_20M_0_8821C(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_0_8821C) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8821C)
#define BITS_R_WMAC_BFINFO_20M_0_8821C \
(BIT_MASK_R_WMAC_BFINFO_20M_0_8821C \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8821C)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_0_8821C(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_0_8821C))
#define BIT_GET_R_WMAC_BFINFO_20M_0_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_0_8821C) & \
BIT_MASK_R_WMAC_BFINFO_20M_0_8821C)
#define BIT_SET_R_WMAC_BFINFO_20M_0_8821C(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_0_8821C(x) | \
BIT_R_WMAC_BFINFO_20M_0_8821C(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW40_8821C (TX CSI REPORT PARAMETER_BW40 REGISTER) */
#define BIT_SHIFT_WMAC_RESP_ANTCD_8821C 0
#define BIT_MASK_WMAC_RESP_ANTCD_8821C 0xf
#define BIT_WMAC_RESP_ANTCD_8821C(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTCD_8821C) \
<< BIT_SHIFT_WMAC_RESP_ANTCD_8821C)
#define BITS_WMAC_RESP_ANTCD_8821C \
(BIT_MASK_WMAC_RESP_ANTCD_8821C << BIT_SHIFT_WMAC_RESP_ANTCD_8821C)
#define BIT_CLEAR_WMAC_RESP_ANTCD_8821C(x) ((x) & (~BITS_WMAC_RESP_ANTCD_8821C))
#define BIT_GET_WMAC_RESP_ANTCD_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTCD_8821C) & \
BIT_MASK_WMAC_RESP_ANTCD_8821C)
#define BIT_SET_WMAC_RESP_ANTCD_8821C(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTCD_8821C(x) | BIT_WMAC_RESP_ANTCD_8821C(v))
/* 2 REG_RSVD_8821C */
/* 2 REG_BCN_PSR_RPT2_8821C (BEACON PARSER REPORT REGISTER2) */
#define BIT_SHIFT_DTIM_CNT2_8821C 24
#define BIT_MASK_DTIM_CNT2_8821C 0xff
#define BIT_DTIM_CNT2_8821C(x) \
(((x) & BIT_MASK_DTIM_CNT2_8821C) << BIT_SHIFT_DTIM_CNT2_8821C)
#define BITS_DTIM_CNT2_8821C \
(BIT_MASK_DTIM_CNT2_8821C << BIT_SHIFT_DTIM_CNT2_8821C)
#define BIT_CLEAR_DTIM_CNT2_8821C(x) ((x) & (~BITS_DTIM_CNT2_8821C))
#define BIT_GET_DTIM_CNT2_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT2_8821C) & BIT_MASK_DTIM_CNT2_8821C)
#define BIT_SET_DTIM_CNT2_8821C(x, v) \
(BIT_CLEAR_DTIM_CNT2_8821C(x) | BIT_DTIM_CNT2_8821C(v))
#define BIT_SHIFT_DTIM_PERIOD2_8821C 16
#define BIT_MASK_DTIM_PERIOD2_8821C 0xff
#define BIT_DTIM_PERIOD2_8821C(x) \
(((x) & BIT_MASK_DTIM_PERIOD2_8821C) << BIT_SHIFT_DTIM_PERIOD2_8821C)
#define BITS_DTIM_PERIOD2_8821C \
(BIT_MASK_DTIM_PERIOD2_8821C << BIT_SHIFT_DTIM_PERIOD2_8821C)
#define BIT_CLEAR_DTIM_PERIOD2_8821C(x) ((x) & (~BITS_DTIM_PERIOD2_8821C))
#define BIT_GET_DTIM_PERIOD2_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD2_8821C) & BIT_MASK_DTIM_PERIOD2_8821C)
#define BIT_SET_DTIM_PERIOD2_8821C(x, v) \
(BIT_CLEAR_DTIM_PERIOD2_8821C(x) | BIT_DTIM_PERIOD2_8821C(v))
#define BIT_DTIM2_8821C BIT(15)
#define BIT_TIM2_8821C BIT(14)
#define BIT_SHIFT_PS_AID_2_8821C 0
#define BIT_MASK_PS_AID_2_8821C 0x7ff
#define BIT_PS_AID_2_8821C(x) \
(((x) & BIT_MASK_PS_AID_2_8821C) << BIT_SHIFT_PS_AID_2_8821C)
#define BITS_PS_AID_2_8821C \
(BIT_MASK_PS_AID_2_8821C << BIT_SHIFT_PS_AID_2_8821C)
#define BIT_CLEAR_PS_AID_2_8821C(x) ((x) & (~BITS_PS_AID_2_8821C))
#define BIT_GET_PS_AID_2_8821C(x) \
(((x) >> BIT_SHIFT_PS_AID_2_8821C) & BIT_MASK_PS_AID_2_8821C)
#define BIT_SET_PS_AID_2_8821C(x, v) \
(BIT_CLEAR_PS_AID_2_8821C(x) | BIT_PS_AID_2_8821C(v))
/* 2 REG_BCN_PSR_RPT3_8821C (BEACON PARSER REPORT REGISTER3) */
#define BIT_SHIFT_DTIM_CNT3_8821C 24
#define BIT_MASK_DTIM_CNT3_8821C 0xff
#define BIT_DTIM_CNT3_8821C(x) \
(((x) & BIT_MASK_DTIM_CNT3_8821C) << BIT_SHIFT_DTIM_CNT3_8821C)
#define BITS_DTIM_CNT3_8821C \
(BIT_MASK_DTIM_CNT3_8821C << BIT_SHIFT_DTIM_CNT3_8821C)
#define BIT_CLEAR_DTIM_CNT3_8821C(x) ((x) & (~BITS_DTIM_CNT3_8821C))
#define BIT_GET_DTIM_CNT3_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT3_8821C) & BIT_MASK_DTIM_CNT3_8821C)
#define BIT_SET_DTIM_CNT3_8821C(x, v) \
(BIT_CLEAR_DTIM_CNT3_8821C(x) | BIT_DTIM_CNT3_8821C(v))
#define BIT_SHIFT_DTIM_PERIOD3_8821C 16
#define BIT_MASK_DTIM_PERIOD3_8821C 0xff
#define BIT_DTIM_PERIOD3_8821C(x) \
(((x) & BIT_MASK_DTIM_PERIOD3_8821C) << BIT_SHIFT_DTIM_PERIOD3_8821C)
#define BITS_DTIM_PERIOD3_8821C \
(BIT_MASK_DTIM_PERIOD3_8821C << BIT_SHIFT_DTIM_PERIOD3_8821C)
#define BIT_CLEAR_DTIM_PERIOD3_8821C(x) ((x) & (~BITS_DTIM_PERIOD3_8821C))
#define BIT_GET_DTIM_PERIOD3_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD3_8821C) & BIT_MASK_DTIM_PERIOD3_8821C)
#define BIT_SET_DTIM_PERIOD3_8821C(x, v) \
(BIT_CLEAR_DTIM_PERIOD3_8821C(x) | BIT_DTIM_PERIOD3_8821C(v))
#define BIT_DTIM3_8821C BIT(15)
#define BIT_TIM3_8821C BIT(14)
#define BIT_SHIFT_PS_AID_3_8821C 0
#define BIT_MASK_PS_AID_3_8821C 0x7ff
#define BIT_PS_AID_3_8821C(x) \
(((x) & BIT_MASK_PS_AID_3_8821C) << BIT_SHIFT_PS_AID_3_8821C)
#define BITS_PS_AID_3_8821C \
(BIT_MASK_PS_AID_3_8821C << BIT_SHIFT_PS_AID_3_8821C)
#define BIT_CLEAR_PS_AID_3_8821C(x) ((x) & (~BITS_PS_AID_3_8821C))
#define BIT_GET_PS_AID_3_8821C(x) \
(((x) >> BIT_SHIFT_PS_AID_3_8821C) & BIT_MASK_PS_AID_3_8821C)
#define BIT_SET_PS_AID_3_8821C(x, v) \
(BIT_CLEAR_PS_AID_3_8821C(x) | BIT_PS_AID_3_8821C(v))
/* 2 REG_BCN_PSR_RPT4_8821C (BEACON PARSER REPORT REGISTER4) */
#define BIT_SHIFT_DTIM_CNT4_8821C 24
#define BIT_MASK_DTIM_CNT4_8821C 0xff
#define BIT_DTIM_CNT4_8821C(x) \
(((x) & BIT_MASK_DTIM_CNT4_8821C) << BIT_SHIFT_DTIM_CNT4_8821C)
#define BITS_DTIM_CNT4_8821C \
(BIT_MASK_DTIM_CNT4_8821C << BIT_SHIFT_DTIM_CNT4_8821C)
#define BIT_CLEAR_DTIM_CNT4_8821C(x) ((x) & (~BITS_DTIM_CNT4_8821C))
#define BIT_GET_DTIM_CNT4_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT4_8821C) & BIT_MASK_DTIM_CNT4_8821C)
#define BIT_SET_DTIM_CNT4_8821C(x, v) \
(BIT_CLEAR_DTIM_CNT4_8821C(x) | BIT_DTIM_CNT4_8821C(v))
#define BIT_SHIFT_DTIM_PERIOD4_8821C 16
#define BIT_MASK_DTIM_PERIOD4_8821C 0xff
#define BIT_DTIM_PERIOD4_8821C(x) \
(((x) & BIT_MASK_DTIM_PERIOD4_8821C) << BIT_SHIFT_DTIM_PERIOD4_8821C)
#define BITS_DTIM_PERIOD4_8821C \
(BIT_MASK_DTIM_PERIOD4_8821C << BIT_SHIFT_DTIM_PERIOD4_8821C)
#define BIT_CLEAR_DTIM_PERIOD4_8821C(x) ((x) & (~BITS_DTIM_PERIOD4_8821C))
#define BIT_GET_DTIM_PERIOD4_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD4_8821C) & BIT_MASK_DTIM_PERIOD4_8821C)
#define BIT_SET_DTIM_PERIOD4_8821C(x, v) \
(BIT_CLEAR_DTIM_PERIOD4_8821C(x) | BIT_DTIM_PERIOD4_8821C(v))
#define BIT_DTIM4_8821C BIT(15)
#define BIT_TIM4_8821C BIT(14)
#define BIT_SHIFT_PS_AID_4_8821C 0
#define BIT_MASK_PS_AID_4_8821C 0x7ff
#define BIT_PS_AID_4_8821C(x) \
(((x) & BIT_MASK_PS_AID_4_8821C) << BIT_SHIFT_PS_AID_4_8821C)
#define BITS_PS_AID_4_8821C \
(BIT_MASK_PS_AID_4_8821C << BIT_SHIFT_PS_AID_4_8821C)
#define BIT_CLEAR_PS_AID_4_8821C(x) ((x) & (~BITS_PS_AID_4_8821C))
#define BIT_GET_PS_AID_4_8821C(x) \
(((x) >> BIT_SHIFT_PS_AID_4_8821C) & BIT_MASK_PS_AID_4_8821C)
#define BIT_SET_PS_AID_4_8821C(x, v) \
(BIT_CLEAR_PS_AID_4_8821C(x) | BIT_PS_AID_4_8821C(v))
/* 2 REG_A1_ADDR_MASK_8821C (A1 ADDR MASK REGISTER) */
#define BIT_SHIFT_A1_ADDR_MASK_8821C 0
#define BIT_MASK_A1_ADDR_MASK_8821C 0xffffffffL
#define BIT_A1_ADDR_MASK_8821C(x) \
(((x) & BIT_MASK_A1_ADDR_MASK_8821C) << BIT_SHIFT_A1_ADDR_MASK_8821C)
#define BITS_A1_ADDR_MASK_8821C \
(BIT_MASK_A1_ADDR_MASK_8821C << BIT_SHIFT_A1_ADDR_MASK_8821C)
#define BIT_CLEAR_A1_ADDR_MASK_8821C(x) ((x) & (~BITS_A1_ADDR_MASK_8821C))
#define BIT_GET_A1_ADDR_MASK_8821C(x) \
(((x) >> BIT_SHIFT_A1_ADDR_MASK_8821C) & BIT_MASK_A1_ADDR_MASK_8821C)
#define BIT_SET_A1_ADDR_MASK_8821C(x, v) \
(BIT_CLEAR_A1_ADDR_MASK_8821C(x) | BIT_A1_ADDR_MASK_8821C(v))
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_MACID2_8821C (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_V1_8821C 0
#define BIT_MASK_MACID2_V1_8821C 0xffffffffL
#define BIT_MACID2_V1_8821C(x) \
(((x) & BIT_MASK_MACID2_V1_8821C) << BIT_SHIFT_MACID2_V1_8821C)
#define BITS_MACID2_V1_8821C \
(BIT_MASK_MACID2_V1_8821C << BIT_SHIFT_MACID2_V1_8821C)
#define BIT_CLEAR_MACID2_V1_8821C(x) ((x) & (~BITS_MACID2_V1_8821C))
#define BIT_GET_MACID2_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID2_V1_8821C) & BIT_MASK_MACID2_V1_8821C)
#define BIT_SET_MACID2_V1_8821C(x, v) \
(BIT_CLEAR_MACID2_V1_8821C(x) | BIT_MACID2_V1_8821C(v))
/* 2 REG_MACID2_H_8821C (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_H_V1_8821C 0
#define BIT_MASK_MACID2_H_V1_8821C 0xffff
#define BIT_MACID2_H_V1_8821C(x) \
(((x) & BIT_MASK_MACID2_H_V1_8821C) << BIT_SHIFT_MACID2_H_V1_8821C)
#define BITS_MACID2_H_V1_8821C \
(BIT_MASK_MACID2_H_V1_8821C << BIT_SHIFT_MACID2_H_V1_8821C)
#define BIT_CLEAR_MACID2_H_V1_8821C(x) ((x) & (~BITS_MACID2_H_V1_8821C))
#define BIT_GET_MACID2_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID2_H_V1_8821C) & BIT_MASK_MACID2_H_V1_8821C)
#define BIT_SET_MACID2_H_V1_8821C(x, v) \
(BIT_CLEAR_MACID2_H_V1_8821C(x) | BIT_MACID2_H_V1_8821C(v))
/* 2 REG_BSSID2_8821C (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_V1_8821C 0
#define BIT_MASK_BSSID2_V1_8821C 0xffffffffL
#define BIT_BSSID2_V1_8821C(x) \
(((x) & BIT_MASK_BSSID2_V1_8821C) << BIT_SHIFT_BSSID2_V1_8821C)
#define BITS_BSSID2_V1_8821C \
(BIT_MASK_BSSID2_V1_8821C << BIT_SHIFT_BSSID2_V1_8821C)
#define BIT_CLEAR_BSSID2_V1_8821C(x) ((x) & (~BITS_BSSID2_V1_8821C))
#define BIT_GET_BSSID2_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID2_V1_8821C) & BIT_MASK_BSSID2_V1_8821C)
#define BIT_SET_BSSID2_V1_8821C(x, v) \
(BIT_CLEAR_BSSID2_V1_8821C(x) | BIT_BSSID2_V1_8821C(v))
/* 2 REG_BSSID2_H_8821C (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_H_V1_8821C 0
#define BIT_MASK_BSSID2_H_V1_8821C 0xffff
#define BIT_BSSID2_H_V1_8821C(x) \
(((x) & BIT_MASK_BSSID2_H_V1_8821C) << BIT_SHIFT_BSSID2_H_V1_8821C)
#define BITS_BSSID2_H_V1_8821C \
(BIT_MASK_BSSID2_H_V1_8821C << BIT_SHIFT_BSSID2_H_V1_8821C)
#define BIT_CLEAR_BSSID2_H_V1_8821C(x) ((x) & (~BITS_BSSID2_H_V1_8821C))
#define BIT_GET_BSSID2_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID2_H_V1_8821C) & BIT_MASK_BSSID2_H_V1_8821C)
#define BIT_SET_BSSID2_H_V1_8821C(x, v) \
(BIT_CLEAR_BSSID2_H_V1_8821C(x) | BIT_BSSID2_H_V1_8821C(v))
/* 2 REG_MACID3_8821C (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_V1_8821C 0
#define BIT_MASK_MACID3_V1_8821C 0xffffffffL
#define BIT_MACID3_V1_8821C(x) \
(((x) & BIT_MASK_MACID3_V1_8821C) << BIT_SHIFT_MACID3_V1_8821C)
#define BITS_MACID3_V1_8821C \
(BIT_MASK_MACID3_V1_8821C << BIT_SHIFT_MACID3_V1_8821C)
#define BIT_CLEAR_MACID3_V1_8821C(x) ((x) & (~BITS_MACID3_V1_8821C))
#define BIT_GET_MACID3_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID3_V1_8821C) & BIT_MASK_MACID3_V1_8821C)
#define BIT_SET_MACID3_V1_8821C(x, v) \
(BIT_CLEAR_MACID3_V1_8821C(x) | BIT_MACID3_V1_8821C(v))
/* 2 REG_MACID3_H_8821C (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_H_V1_8821C 0
#define BIT_MASK_MACID3_H_V1_8821C 0xffff
#define BIT_MACID3_H_V1_8821C(x) \
(((x) & BIT_MASK_MACID3_H_V1_8821C) << BIT_SHIFT_MACID3_H_V1_8821C)
#define BITS_MACID3_H_V1_8821C \
(BIT_MASK_MACID3_H_V1_8821C << BIT_SHIFT_MACID3_H_V1_8821C)
#define BIT_CLEAR_MACID3_H_V1_8821C(x) ((x) & (~BITS_MACID3_H_V1_8821C))
#define BIT_GET_MACID3_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID3_H_V1_8821C) & BIT_MASK_MACID3_H_V1_8821C)
#define BIT_SET_MACID3_H_V1_8821C(x, v) \
(BIT_CLEAR_MACID3_H_V1_8821C(x) | BIT_MACID3_H_V1_8821C(v))
/* 2 REG_BSSID3_8821C (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_V1_8821C 0
#define BIT_MASK_BSSID3_V1_8821C 0xffffffffL
#define BIT_BSSID3_V1_8821C(x) \
(((x) & BIT_MASK_BSSID3_V1_8821C) << BIT_SHIFT_BSSID3_V1_8821C)
#define BITS_BSSID3_V1_8821C \
(BIT_MASK_BSSID3_V1_8821C << BIT_SHIFT_BSSID3_V1_8821C)
#define BIT_CLEAR_BSSID3_V1_8821C(x) ((x) & (~BITS_BSSID3_V1_8821C))
#define BIT_GET_BSSID3_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID3_V1_8821C) & BIT_MASK_BSSID3_V1_8821C)
#define BIT_SET_BSSID3_V1_8821C(x, v) \
(BIT_CLEAR_BSSID3_V1_8821C(x) | BIT_BSSID3_V1_8821C(v))
/* 2 REG_BSSID3_H_8821C (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_H_V1_8821C 0
#define BIT_MASK_BSSID3_H_V1_8821C 0xffff
#define BIT_BSSID3_H_V1_8821C(x) \
(((x) & BIT_MASK_BSSID3_H_V1_8821C) << BIT_SHIFT_BSSID3_H_V1_8821C)
#define BITS_BSSID3_H_V1_8821C \
(BIT_MASK_BSSID3_H_V1_8821C << BIT_SHIFT_BSSID3_H_V1_8821C)
#define BIT_CLEAR_BSSID3_H_V1_8821C(x) ((x) & (~BITS_BSSID3_H_V1_8821C))
#define BIT_GET_BSSID3_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID3_H_V1_8821C) & BIT_MASK_BSSID3_H_V1_8821C)
#define BIT_SET_BSSID3_H_V1_8821C(x, v) \
(BIT_CLEAR_BSSID3_H_V1_8821C(x) | BIT_BSSID3_H_V1_8821C(v))
/* 2 REG_MACID4_8821C (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_V1_8821C 0
#define BIT_MASK_MACID4_V1_8821C 0xffffffffL
#define BIT_MACID4_V1_8821C(x) \
(((x) & BIT_MASK_MACID4_V1_8821C) << BIT_SHIFT_MACID4_V1_8821C)
#define BITS_MACID4_V1_8821C \
(BIT_MASK_MACID4_V1_8821C << BIT_SHIFT_MACID4_V1_8821C)
#define BIT_CLEAR_MACID4_V1_8821C(x) ((x) & (~BITS_MACID4_V1_8821C))
#define BIT_GET_MACID4_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID4_V1_8821C) & BIT_MASK_MACID4_V1_8821C)
#define BIT_SET_MACID4_V1_8821C(x, v) \
(BIT_CLEAR_MACID4_V1_8821C(x) | BIT_MACID4_V1_8821C(v))
/* 2 REG_MACID4_H_8821C (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_H_V1_8821C 0
#define BIT_MASK_MACID4_H_V1_8821C 0xffff
#define BIT_MACID4_H_V1_8821C(x) \
(((x) & BIT_MASK_MACID4_H_V1_8821C) << BIT_SHIFT_MACID4_H_V1_8821C)
#define BITS_MACID4_H_V1_8821C \
(BIT_MASK_MACID4_H_V1_8821C << BIT_SHIFT_MACID4_H_V1_8821C)
#define BIT_CLEAR_MACID4_H_V1_8821C(x) ((x) & (~BITS_MACID4_H_V1_8821C))
#define BIT_GET_MACID4_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_MACID4_H_V1_8821C) & BIT_MASK_MACID4_H_V1_8821C)
#define BIT_SET_MACID4_H_V1_8821C(x, v) \
(BIT_CLEAR_MACID4_H_V1_8821C(x) | BIT_MACID4_H_V1_8821C(v))
/* 2 REG_BSSID4_8821C (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_V1_8821C 0
#define BIT_MASK_BSSID4_V1_8821C 0xffffffffL
#define BIT_BSSID4_V1_8821C(x) \
(((x) & BIT_MASK_BSSID4_V1_8821C) << BIT_SHIFT_BSSID4_V1_8821C)
#define BITS_BSSID4_V1_8821C \
(BIT_MASK_BSSID4_V1_8821C << BIT_SHIFT_BSSID4_V1_8821C)
#define BIT_CLEAR_BSSID4_V1_8821C(x) ((x) & (~BITS_BSSID4_V1_8821C))
#define BIT_GET_BSSID4_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID4_V1_8821C) & BIT_MASK_BSSID4_V1_8821C)
#define BIT_SET_BSSID4_V1_8821C(x, v) \
(BIT_CLEAR_BSSID4_V1_8821C(x) | BIT_BSSID4_V1_8821C(v))
/* 2 REG_BSSID4_H_8821C (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_H_V1_8821C 0
#define BIT_MASK_BSSID4_H_V1_8821C 0xffff
#define BIT_BSSID4_H_V1_8821C(x) \
(((x) & BIT_MASK_BSSID4_H_V1_8821C) << BIT_SHIFT_BSSID4_H_V1_8821C)
#define BITS_BSSID4_H_V1_8821C \
(BIT_MASK_BSSID4_H_V1_8821C << BIT_SHIFT_BSSID4_H_V1_8821C)
#define BIT_CLEAR_BSSID4_H_V1_8821C(x) ((x) & (~BITS_BSSID4_H_V1_8821C))
#define BIT_GET_BSSID4_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID4_H_V1_8821C) & BIT_MASK_BSSID4_H_V1_8821C)
#define BIT_SET_BSSID4_H_V1_8821C(x, v) \
(BIT_CLEAR_BSSID4_H_V1_8821C(x) | BIT_BSSID4_H_V1_8821C(v))
/* 2 REG_NOA_REPORT_8821C */
/* 2 REG_NOA_REPORT_1_8821C */
/* 2 REG_NOA_REPORT_2_8821C */
/* 2 REG_NOA_REPORT_3_8821C */
/* 2 REG_PWRBIT_SETTING_8821C */
#define BIT_CLI3_PWRBIT_OW_EN_8821C BIT(7)
#define BIT_CLI3_PWR_ST_8821C BIT(6)
#define BIT_CLI2_PWRBIT_OW_EN_8821C BIT(5)
#define BIT_CLI2_PWR_ST_8821C BIT(4)
#define BIT_CLI1_PWRBIT_OW_EN_8821C BIT(3)
#define BIT_CLI1_PWR_ST_8821C BIT(2)
#define BIT_CLI0_PWRBIT_OW_EN_8821C BIT(1)
#define BIT_CLI0_PWR_ST_8821C BIT(0)
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_MU_BF_OPTION_8821C */
#define BIT_WMAC_RESP_NONSTA1_DIS_8821C BIT(7)
#define BIT_WMAC_TXMU_ACKPOLICY_EN_8821C BIT(6)
#define BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8821C 4
#define BIT_MASK_WMAC_TXMU_ACKPOLICY_8821C 0x3
#define BIT_WMAC_TXMU_ACKPOLICY_8821C(x) \
(((x) & BIT_MASK_WMAC_TXMU_ACKPOLICY_8821C) \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8821C)
#define BITS_WMAC_TXMU_ACKPOLICY_8821C \
(BIT_MASK_WMAC_TXMU_ACKPOLICY_8821C \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8821C)
#define BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8821C(x) \
((x) & (~BITS_WMAC_TXMU_ACKPOLICY_8821C))
#define BIT_GET_WMAC_TXMU_ACKPOLICY_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8821C) & \
BIT_MASK_WMAC_TXMU_ACKPOLICY_8821C)
#define BIT_SET_WMAC_TXMU_ACKPOLICY_8821C(x, v) \
(BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8821C(x) | \
BIT_WMAC_TXMU_ACKPOLICY_8821C(v))
#define BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8821C 1
#define BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8821C 0x7
#define BIT_WMAC_MU_BFEE_PORT_SEL_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8821C)
#define BITS_WMAC_MU_BFEE_PORT_SEL_8821C \
(BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8821C \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE_PORT_SEL_8821C))
#define BIT_GET_WMAC_MU_BFEE_PORT_SEL_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8821C) & \
BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8821C)
#define BIT_SET_WMAC_MU_BFEE_PORT_SEL_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8821C(x) | \
BIT_WMAC_MU_BFEE_PORT_SEL_8821C(v))
#define BIT_WMAC_MU_BFEE_DIS_8821C BIT(0)
/* 2 REG_WMAC_PAUSE_BB_CLR_TH_8821C */
#define BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8821C 0
#define BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8821C 0xff
#define BIT_WMAC_PAUSE_BB_CLR_TH_8821C(x) \
(((x) & BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8821C) \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8821C)
#define BITS_WMAC_PAUSE_BB_CLR_TH_8821C \
(BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8821C \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8821C)
#define BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8821C(x) \
((x) & (~BITS_WMAC_PAUSE_BB_CLR_TH_8821C))
#define BIT_GET_WMAC_PAUSE_BB_CLR_TH_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8821C) & \
BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8821C)
#define BIT_SET_WMAC_PAUSE_BB_CLR_TH_8821C(x, v) \
(BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8821C(x) | \
BIT_WMAC_PAUSE_BB_CLR_TH_8821C(v))
/* 2 REG_WMAC_MU_ARB_8821C */
#define BIT_WMAC_ARB_HW_ADAPT_EN_8821C BIT(7)
#define BIT_WMAC_ARB_SW_EN_8821C BIT(6)
#define BIT_SHIFT_WMAC_ARB_SW_STATE_8821C 0
#define BIT_MASK_WMAC_ARB_SW_STATE_8821C 0x3f
#define BIT_WMAC_ARB_SW_STATE_8821C(x) \
(((x) & BIT_MASK_WMAC_ARB_SW_STATE_8821C) \
<< BIT_SHIFT_WMAC_ARB_SW_STATE_8821C)
#define BITS_WMAC_ARB_SW_STATE_8821C \
(BIT_MASK_WMAC_ARB_SW_STATE_8821C << BIT_SHIFT_WMAC_ARB_SW_STATE_8821C)
#define BIT_CLEAR_WMAC_ARB_SW_STATE_8821C(x) \
((x) & (~BITS_WMAC_ARB_SW_STATE_8821C))
#define BIT_GET_WMAC_ARB_SW_STATE_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_ARB_SW_STATE_8821C) & \
BIT_MASK_WMAC_ARB_SW_STATE_8821C)
#define BIT_SET_WMAC_ARB_SW_STATE_8821C(x, v) \
(BIT_CLEAR_WMAC_ARB_SW_STATE_8821C(x) | BIT_WMAC_ARB_SW_STATE_8821C(v))
/* 2 REG_WMAC_MU_OPTION_8821C */
#define BIT_SHIFT_WMAC_MU_DBGSEL_8821C 5
#define BIT_MASK_WMAC_MU_DBGSEL_8821C 0x3
#define BIT_WMAC_MU_DBGSEL_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_DBGSEL_8821C) \
<< BIT_SHIFT_WMAC_MU_DBGSEL_8821C)
#define BITS_WMAC_MU_DBGSEL_8821C \
(BIT_MASK_WMAC_MU_DBGSEL_8821C << BIT_SHIFT_WMAC_MU_DBGSEL_8821C)
#define BIT_CLEAR_WMAC_MU_DBGSEL_8821C(x) ((x) & (~BITS_WMAC_MU_DBGSEL_8821C))
#define BIT_GET_WMAC_MU_DBGSEL_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_DBGSEL_8821C) & \
BIT_MASK_WMAC_MU_DBGSEL_8821C)
#define BIT_SET_WMAC_MU_DBGSEL_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_DBGSEL_8821C(x) | BIT_WMAC_MU_DBGSEL_8821C(v))
#define BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8821C 0
#define BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8821C 0x1f
#define BIT_WMAC_MU_CPRD_TIMEOUT_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8821C) \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8821C)
#define BITS_WMAC_MU_CPRD_TIMEOUT_8821C \
(BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8821C \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8821C)
#define BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT_8821C(x) \
((x) & (~BITS_WMAC_MU_CPRD_TIMEOUT_8821C))
#define BIT_GET_WMAC_MU_CPRD_TIMEOUT_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8821C) & \
BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8821C)
#define BIT_SET_WMAC_MU_CPRD_TIMEOUT_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT_8821C(x) | \
BIT_WMAC_MU_CPRD_TIMEOUT_8821C(v))
/* 2 REG_WMAC_MU_BF_CTL_8821C */
#define BIT_WMAC_INVLD_BFPRT_CHK_8821C BIT(15)
#define BIT_WMAC_RETXBFRPTSEQ_UPD_8821C BIT(14)
#define BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8821C 12
#define BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8821C 0x3
#define BIT_WMAC_MU_BFRPTSEG_SEL_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8821C) \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8821C)
#define BITS_WMAC_MU_BFRPTSEG_SEL_8821C \
(BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8821C \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8821C)
#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8821C(x) \
((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL_8821C))
#define BIT_GET_WMAC_MU_BFRPTSEG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8821C) & \
BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8821C)
#define BIT_SET_WMAC_MU_BFRPTSEG_SEL_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8821C(x) | \
BIT_WMAC_MU_BFRPTSEG_SEL_8821C(v))
#define BIT_SHIFT_WMAC_MU_BF_MYAID_8821C 0
#define BIT_MASK_WMAC_MU_BF_MYAID_8821C 0xfff
#define BIT_WMAC_MU_BF_MYAID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BF_MYAID_8821C) \
<< BIT_SHIFT_WMAC_MU_BF_MYAID_8821C)
#define BITS_WMAC_MU_BF_MYAID_8821C \
(BIT_MASK_WMAC_MU_BF_MYAID_8821C << BIT_SHIFT_WMAC_MU_BF_MYAID_8821C)
#define BIT_CLEAR_WMAC_MU_BF_MYAID_8821C(x) \
((x) & (~BITS_WMAC_MU_BF_MYAID_8821C))
#define BIT_GET_WMAC_MU_BF_MYAID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BF_MYAID_8821C) & \
BIT_MASK_WMAC_MU_BF_MYAID_8821C)
#define BIT_SET_WMAC_MU_BF_MYAID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BF_MYAID_8821C(x) | BIT_WMAC_MU_BF_MYAID_8821C(v))
/* 2 REG_WMAC_MU_BFRPT_PARA_8821C */
#define BIT_SHIFT_BFRPT_PARA_USERID_SEL_8821C 12
#define BIT_MASK_BFRPT_PARA_USERID_SEL_8821C 0x7
#define BIT_BFRPT_PARA_USERID_SEL_8821C(x) \
(((x) & BIT_MASK_BFRPT_PARA_USERID_SEL_8821C) \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_8821C)
#define BITS_BFRPT_PARA_USERID_SEL_8821C \
(BIT_MASK_BFRPT_PARA_USERID_SEL_8821C \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_8821C)
#define BIT_CLEAR_BFRPT_PARA_USERID_SEL_8821C(x) \
((x) & (~BITS_BFRPT_PARA_USERID_SEL_8821C))
#define BIT_GET_BFRPT_PARA_USERID_SEL_8821C(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_USERID_SEL_8821C) & \
BIT_MASK_BFRPT_PARA_USERID_SEL_8821C)
#define BIT_SET_BFRPT_PARA_USERID_SEL_8821C(x, v) \
(BIT_CLEAR_BFRPT_PARA_USERID_SEL_8821C(x) | \
BIT_BFRPT_PARA_USERID_SEL_8821C(v))
#define BIT_SHIFT_BFRPT_PARA_8821C 0
#define BIT_MASK_BFRPT_PARA_8821C 0xfff
#define BIT_BFRPT_PARA_8821C(x) \
(((x) & BIT_MASK_BFRPT_PARA_8821C) << BIT_SHIFT_BFRPT_PARA_8821C)
#define BITS_BFRPT_PARA_8821C \
(BIT_MASK_BFRPT_PARA_8821C << BIT_SHIFT_BFRPT_PARA_8821C)
#define BIT_CLEAR_BFRPT_PARA_8821C(x) ((x) & (~BITS_BFRPT_PARA_8821C))
#define BIT_GET_BFRPT_PARA_8821C(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_8821C) & BIT_MASK_BFRPT_PARA_8821C)
#define BIT_SET_BFRPT_PARA_8821C(x, v) \
(BIT_CLEAR_BFRPT_PARA_8821C(x) | BIT_BFRPT_PARA_8821C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2_8821C */
#define BIT_STATUS_BFEE2_8821C BIT(10)
#define BIT_WMAC_MU_BFEE2_EN_8821C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE2_AID_8821C 0
#define BIT_MASK_WMAC_MU_BFEE2_AID_8821C 0x1ff
#define BIT_WMAC_MU_BFEE2_AID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE2_AID_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE2_AID_8821C)
#define BITS_WMAC_MU_BFEE2_AID_8821C \
(BIT_MASK_WMAC_MU_BFEE2_AID_8821C << BIT_SHIFT_WMAC_MU_BFEE2_AID_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE2_AID_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE2_AID_8821C))
#define BIT_GET_WMAC_MU_BFEE2_AID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE2_AID_8821C) & \
BIT_MASK_WMAC_MU_BFEE2_AID_8821C)
#define BIT_SET_WMAC_MU_BFEE2_AID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE2_AID_8821C(x) | BIT_WMAC_MU_BFEE2_AID_8821C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3_8821C */
#define BIT_STATUS_BFEE3_8821C BIT(10)
#define BIT_WMAC_MU_BFEE3_EN_8821C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE3_AID_8821C 0
#define BIT_MASK_WMAC_MU_BFEE3_AID_8821C 0x1ff
#define BIT_WMAC_MU_BFEE3_AID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE3_AID_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE3_AID_8821C)
#define BITS_WMAC_MU_BFEE3_AID_8821C \
(BIT_MASK_WMAC_MU_BFEE3_AID_8821C << BIT_SHIFT_WMAC_MU_BFEE3_AID_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE3_AID_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE3_AID_8821C))
#define BIT_GET_WMAC_MU_BFEE3_AID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE3_AID_8821C) & \
BIT_MASK_WMAC_MU_BFEE3_AID_8821C)
#define BIT_SET_WMAC_MU_BFEE3_AID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE3_AID_8821C(x) | BIT_WMAC_MU_BFEE3_AID_8821C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE4_8821C */
#define BIT_STATUS_BFEE4_8821C BIT(10)
#define BIT_WMAC_MU_BFEE4_EN_8821C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE4_AID_8821C 0
#define BIT_MASK_WMAC_MU_BFEE4_AID_8821C 0x1ff
#define BIT_WMAC_MU_BFEE4_AID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE4_AID_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE4_AID_8821C)
#define BITS_WMAC_MU_BFEE4_AID_8821C \
(BIT_MASK_WMAC_MU_BFEE4_AID_8821C << BIT_SHIFT_WMAC_MU_BFEE4_AID_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE4_AID_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE4_AID_8821C))
#define BIT_GET_WMAC_MU_BFEE4_AID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE4_AID_8821C) & \
BIT_MASK_WMAC_MU_BFEE4_AID_8821C)
#define BIT_SET_WMAC_MU_BFEE4_AID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE4_AID_8821C(x) | BIT_WMAC_MU_BFEE4_AID_8821C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5_8821C */
#define BIT_BIT_STATUS_BFEE5_8821C BIT(10)
#define BIT_WMAC_MU_BFEE5_EN_8821C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE5_AID_8821C 0
#define BIT_MASK_WMAC_MU_BFEE5_AID_8821C 0x1ff
#define BIT_WMAC_MU_BFEE5_AID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE5_AID_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE5_AID_8821C)
#define BITS_WMAC_MU_BFEE5_AID_8821C \
(BIT_MASK_WMAC_MU_BFEE5_AID_8821C << BIT_SHIFT_WMAC_MU_BFEE5_AID_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE5_AID_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE5_AID_8821C))
#define BIT_GET_WMAC_MU_BFEE5_AID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE5_AID_8821C) & \
BIT_MASK_WMAC_MU_BFEE5_AID_8821C)
#define BIT_SET_WMAC_MU_BFEE5_AID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE5_AID_8821C(x) | BIT_WMAC_MU_BFEE5_AID_8821C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE6_8821C */
#define BIT_STATUS_BFEE6_8821C BIT(10)
#define BIT_WMAC_MU_BFEE6_EN_8821C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE6_AID_8821C 0
#define BIT_MASK_WMAC_MU_BFEE6_AID_8821C 0x1ff
#define BIT_WMAC_MU_BFEE6_AID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE6_AID_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE6_AID_8821C)
#define BITS_WMAC_MU_BFEE6_AID_8821C \
(BIT_MASK_WMAC_MU_BFEE6_AID_8821C << BIT_SHIFT_WMAC_MU_BFEE6_AID_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE6_AID_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE6_AID_8821C))
#define BIT_GET_WMAC_MU_BFEE6_AID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE6_AID_8821C) & \
BIT_MASK_WMAC_MU_BFEE6_AID_8821C)
#define BIT_SET_WMAC_MU_BFEE6_AID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE6_AID_8821C(x) | BIT_WMAC_MU_BFEE6_AID_8821C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7_8821C */
#define BIT_STATUS_BFEE7_8821C BIT(10)
#define BIT_WMAC_MU_BFEE7_EN_8821C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE7_AID_8821C 0
#define BIT_MASK_WMAC_MU_BFEE7_AID_8821C 0x1ff
#define BIT_WMAC_MU_BFEE7_AID_8821C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE7_AID_8821C) \
<< BIT_SHIFT_WMAC_MU_BFEE7_AID_8821C)
#define BITS_WMAC_MU_BFEE7_AID_8821C \
(BIT_MASK_WMAC_MU_BFEE7_AID_8821C << BIT_SHIFT_WMAC_MU_BFEE7_AID_8821C)
#define BIT_CLEAR_WMAC_MU_BFEE7_AID_8821C(x) \
((x) & (~BITS_WMAC_MU_BFEE7_AID_8821C))
#define BIT_GET_WMAC_MU_BFEE7_AID_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE7_AID_8821C) & \
BIT_MASK_WMAC_MU_BFEE7_AID_8821C)
#define BIT_SET_WMAC_MU_BFEE7_AID_8821C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE7_AID_8821C(x) | BIT_WMAC_MU_BFEE7_AID_8821C(v))
/* 2 REG_WMAC_BB_STOP_RX_COUNTER_8821C */
#define BIT_RST_ALL_COUNTER_8821C BIT(31)
#define BIT_SHIFT_ABORT_RX_VBON_COUNTER_8821C 16
#define BIT_MASK_ABORT_RX_VBON_COUNTER_8821C 0xff
#define BIT_ABORT_RX_VBON_COUNTER_8821C(x) \
(((x) & BIT_MASK_ABORT_RX_VBON_COUNTER_8821C) \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8821C)
#define BITS_ABORT_RX_VBON_COUNTER_8821C \
(BIT_MASK_ABORT_RX_VBON_COUNTER_8821C \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8821C)
#define BIT_CLEAR_ABORT_RX_VBON_COUNTER_8821C(x) \
((x) & (~BITS_ABORT_RX_VBON_COUNTER_8821C))
#define BIT_GET_ABORT_RX_VBON_COUNTER_8821C(x) \
(((x) >> BIT_SHIFT_ABORT_RX_VBON_COUNTER_8821C) & \
BIT_MASK_ABORT_RX_VBON_COUNTER_8821C)
#define BIT_SET_ABORT_RX_VBON_COUNTER_8821C(x, v) \
(BIT_CLEAR_ABORT_RX_VBON_COUNTER_8821C(x) | \
BIT_ABORT_RX_VBON_COUNTER_8821C(v))
#define BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8821C 8
#define BIT_MASK_ABORT_RX_RDRDY_COUNTER_8821C 0xff
#define BIT_ABORT_RX_RDRDY_COUNTER_8821C(x) \
(((x) & BIT_MASK_ABORT_RX_RDRDY_COUNTER_8821C) \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8821C)
#define BITS_ABORT_RX_RDRDY_COUNTER_8821C \
(BIT_MASK_ABORT_RX_RDRDY_COUNTER_8821C \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8821C)
#define BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8821C(x) \
((x) & (~BITS_ABORT_RX_RDRDY_COUNTER_8821C))
#define BIT_GET_ABORT_RX_RDRDY_COUNTER_8821C(x) \
(((x) >> BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8821C) & \
BIT_MASK_ABORT_RX_RDRDY_COUNTER_8821C)
#define BIT_SET_ABORT_RX_RDRDY_COUNTER_8821C(x, v) \
(BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8821C(x) | \
BIT_ABORT_RX_RDRDY_COUNTER_8821C(v))
#define BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8821C 0
#define BIT_MASK_VBON_EARLY_FALLING_COUNTER_8821C 0xff
#define BIT_VBON_EARLY_FALLING_COUNTER_8821C(x) \
(((x) & BIT_MASK_VBON_EARLY_FALLING_COUNTER_8821C) \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8821C)
#define BITS_VBON_EARLY_FALLING_COUNTER_8821C \
(BIT_MASK_VBON_EARLY_FALLING_COUNTER_8821C \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8821C)
#define BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8821C(x) \
((x) & (~BITS_VBON_EARLY_FALLING_COUNTER_8821C))
#define BIT_GET_VBON_EARLY_FALLING_COUNTER_8821C(x) \
(((x) >> BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8821C) & \
BIT_MASK_VBON_EARLY_FALLING_COUNTER_8821C)
#define BIT_SET_VBON_EARLY_FALLING_COUNTER_8821C(x, v) \
(BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8821C(x) | \
BIT_VBON_EARLY_FALLING_COUNTER_8821C(v))
/* 2 REG_WMAC_PLCP_MONITOR_8821C */
#define BIT_WMAC_PLCP_TRX_SEL_8821C BIT(31)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8821C 28
#define BIT_MASK_WMAC_PLCP_RDSIG_SEL_8821C 0x7
#define BIT_WMAC_PLCP_RDSIG_SEL_8821C(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_SEL_8821C) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8821C)
#define BITS_WMAC_PLCP_RDSIG_SEL_8821C \
(BIT_MASK_WMAC_PLCP_RDSIG_SEL_8821C \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8821C)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8821C(x) \
((x) & (~BITS_WMAC_PLCP_RDSIG_SEL_8821C))
#define BIT_GET_WMAC_PLCP_RDSIG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8821C) & \
BIT_MASK_WMAC_PLCP_RDSIG_SEL_8821C)
#define BIT_SET_WMAC_PLCP_RDSIG_SEL_8821C(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8821C(x) | \
BIT_WMAC_PLCP_RDSIG_SEL_8821C(v))
#define BIT_SHIFT_WMAC_RATE_IDX_8821C 24
#define BIT_MASK_WMAC_RATE_IDX_8821C 0xf
#define BIT_WMAC_RATE_IDX_8821C(x) \
(((x) & BIT_MASK_WMAC_RATE_IDX_8821C) << BIT_SHIFT_WMAC_RATE_IDX_8821C)
#define BITS_WMAC_RATE_IDX_8821C \
(BIT_MASK_WMAC_RATE_IDX_8821C << BIT_SHIFT_WMAC_RATE_IDX_8821C)
#define BIT_CLEAR_WMAC_RATE_IDX_8821C(x) ((x) & (~BITS_WMAC_RATE_IDX_8821C))
#define BIT_GET_WMAC_RATE_IDX_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_RATE_IDX_8821C) & BIT_MASK_WMAC_RATE_IDX_8821C)
#define BIT_SET_WMAC_RATE_IDX_8821C(x, v) \
(BIT_CLEAR_WMAC_RATE_IDX_8821C(x) | BIT_WMAC_RATE_IDX_8821C(v))
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8821C 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8821C 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8821C(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8821C) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8821C)
#define BITS_WMAC_PLCP_RDSIG_8821C \
(BIT_MASK_WMAC_PLCP_RDSIG_8821C << BIT_SHIFT_WMAC_PLCP_RDSIG_8821C)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8821C(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8821C))
#define BIT_GET_WMAC_PLCP_RDSIG_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8821C) & \
BIT_MASK_WMAC_PLCP_RDSIG_8821C)
#define BIT_SET_WMAC_PLCP_RDSIG_8821C(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8821C(x) | BIT_WMAC_PLCP_RDSIG_8821C(v))
/* 2 REG_WMAC_PLCP_MONITOR_MUTX_8821C */
#define BIT_WMAC_MUTX_IDX_8821C BIT(24)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8821C 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8821C 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8821C(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8821C) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8821C)
#define BITS_WMAC_PLCP_RDSIG_8821C \
(BIT_MASK_WMAC_PLCP_RDSIG_8821C << BIT_SHIFT_WMAC_PLCP_RDSIG_8821C)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8821C(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8821C))
#define BIT_GET_WMAC_PLCP_RDSIG_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8821C) & \
BIT_MASK_WMAC_PLCP_RDSIG_8821C)
#define BIT_SET_WMAC_PLCP_RDSIG_8821C(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8821C(x) | BIT_WMAC_PLCP_RDSIG_8821C(v))
/* 2 REG_RSVD_8821C */
/* 2 REG_TRANSMIT_ADDRSS_0_8821C (TA0 REGISTER) */
#define BIT_SHIFT_TA0_V1_8821C 0
#define BIT_MASK_TA0_V1_8821C 0xffffffffL
#define BIT_TA0_V1_8821C(x) \
(((x) & BIT_MASK_TA0_V1_8821C) << BIT_SHIFT_TA0_V1_8821C)
#define BITS_TA0_V1_8821C (BIT_MASK_TA0_V1_8821C << BIT_SHIFT_TA0_V1_8821C)
#define BIT_CLEAR_TA0_V1_8821C(x) ((x) & (~BITS_TA0_V1_8821C))
#define BIT_GET_TA0_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA0_V1_8821C) & BIT_MASK_TA0_V1_8821C)
#define BIT_SET_TA0_V1_8821C(x, v) \
(BIT_CLEAR_TA0_V1_8821C(x) | BIT_TA0_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_0_H_8821C (TA0 REGISTER) */
#define BIT_SHIFT_TA0_H_V1_8821C 0
#define BIT_MASK_TA0_H_V1_8821C 0xffff
#define BIT_TA0_H_V1_8821C(x) \
(((x) & BIT_MASK_TA0_H_V1_8821C) << BIT_SHIFT_TA0_H_V1_8821C)
#define BITS_TA0_H_V1_8821C \
(BIT_MASK_TA0_H_V1_8821C << BIT_SHIFT_TA0_H_V1_8821C)
#define BIT_CLEAR_TA0_H_V1_8821C(x) ((x) & (~BITS_TA0_H_V1_8821C))
#define BIT_GET_TA0_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA0_H_V1_8821C) & BIT_MASK_TA0_H_V1_8821C)
#define BIT_SET_TA0_H_V1_8821C(x, v) \
(BIT_CLEAR_TA0_H_V1_8821C(x) | BIT_TA0_H_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_1_8821C (TA1 REGISTER) */
#define BIT_SHIFT_TA1_V1_8821C 0
#define BIT_MASK_TA1_V1_8821C 0xffffffffL
#define BIT_TA1_V1_8821C(x) \
(((x) & BIT_MASK_TA1_V1_8821C) << BIT_SHIFT_TA1_V1_8821C)
#define BITS_TA1_V1_8821C (BIT_MASK_TA1_V1_8821C << BIT_SHIFT_TA1_V1_8821C)
#define BIT_CLEAR_TA1_V1_8821C(x) ((x) & (~BITS_TA1_V1_8821C))
#define BIT_GET_TA1_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA1_V1_8821C) & BIT_MASK_TA1_V1_8821C)
#define BIT_SET_TA1_V1_8821C(x, v) \
(BIT_CLEAR_TA1_V1_8821C(x) | BIT_TA1_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_1_H_8821C (TA1 REGISTER) */
#define BIT_SHIFT_TA1_H_V1_8821C 0
#define BIT_MASK_TA1_H_V1_8821C 0xffff
#define BIT_TA1_H_V1_8821C(x) \
(((x) & BIT_MASK_TA1_H_V1_8821C) << BIT_SHIFT_TA1_H_V1_8821C)
#define BITS_TA1_H_V1_8821C \
(BIT_MASK_TA1_H_V1_8821C << BIT_SHIFT_TA1_H_V1_8821C)
#define BIT_CLEAR_TA1_H_V1_8821C(x) ((x) & (~BITS_TA1_H_V1_8821C))
#define BIT_GET_TA1_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA1_H_V1_8821C) & BIT_MASK_TA1_H_V1_8821C)
#define BIT_SET_TA1_H_V1_8821C(x, v) \
(BIT_CLEAR_TA1_H_V1_8821C(x) | BIT_TA1_H_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_2_8821C (TA2 REGISTER) */
#define BIT_SHIFT_TA2_V1_8821C 0
#define BIT_MASK_TA2_V1_8821C 0xffffffffL
#define BIT_TA2_V1_8821C(x) \
(((x) & BIT_MASK_TA2_V1_8821C) << BIT_SHIFT_TA2_V1_8821C)
#define BITS_TA2_V1_8821C (BIT_MASK_TA2_V1_8821C << BIT_SHIFT_TA2_V1_8821C)
#define BIT_CLEAR_TA2_V1_8821C(x) ((x) & (~BITS_TA2_V1_8821C))
#define BIT_GET_TA2_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA2_V1_8821C) & BIT_MASK_TA2_V1_8821C)
#define BIT_SET_TA2_V1_8821C(x, v) \
(BIT_CLEAR_TA2_V1_8821C(x) | BIT_TA2_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_2_H_8821C (TA2 REGISTER) */
#define BIT_SHIFT_TA2_H_V1_8821C 0
#define BIT_MASK_TA2_H_V1_8821C 0xffff
#define BIT_TA2_H_V1_8821C(x) \
(((x) & BIT_MASK_TA2_H_V1_8821C) << BIT_SHIFT_TA2_H_V1_8821C)
#define BITS_TA2_H_V1_8821C \
(BIT_MASK_TA2_H_V1_8821C << BIT_SHIFT_TA2_H_V1_8821C)
#define BIT_CLEAR_TA2_H_V1_8821C(x) ((x) & (~BITS_TA2_H_V1_8821C))
#define BIT_GET_TA2_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA2_H_V1_8821C) & BIT_MASK_TA2_H_V1_8821C)
#define BIT_SET_TA2_H_V1_8821C(x, v) \
(BIT_CLEAR_TA2_H_V1_8821C(x) | BIT_TA2_H_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_3_8821C (TA3 REGISTER) */
#define BIT_SHIFT_TA2_V1_8821C 0
#define BIT_MASK_TA2_V1_8821C 0xffffffffL
#define BIT_TA2_V1_8821C(x) \
(((x) & BIT_MASK_TA2_V1_8821C) << BIT_SHIFT_TA2_V1_8821C)
#define BITS_TA2_V1_8821C (BIT_MASK_TA2_V1_8821C << BIT_SHIFT_TA2_V1_8821C)
#define BIT_CLEAR_TA2_V1_8821C(x) ((x) & (~BITS_TA2_V1_8821C))
#define BIT_GET_TA2_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA2_V1_8821C) & BIT_MASK_TA2_V1_8821C)
#define BIT_SET_TA2_V1_8821C(x, v) \
(BIT_CLEAR_TA2_V1_8821C(x) | BIT_TA2_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_3_H_8821C (TA3 REGISTER) */
#define BIT_SHIFT_TA3_H_V1_8821C 0
#define BIT_MASK_TA3_H_V1_8821C 0xffff
#define BIT_TA3_H_V1_8821C(x) \
(((x) & BIT_MASK_TA3_H_V1_8821C) << BIT_SHIFT_TA3_H_V1_8821C)
#define BITS_TA3_H_V1_8821C \
(BIT_MASK_TA3_H_V1_8821C << BIT_SHIFT_TA3_H_V1_8821C)
#define BIT_CLEAR_TA3_H_V1_8821C(x) ((x) & (~BITS_TA3_H_V1_8821C))
#define BIT_GET_TA3_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA3_H_V1_8821C) & BIT_MASK_TA3_H_V1_8821C)
#define BIT_SET_TA3_H_V1_8821C(x, v) \
(BIT_CLEAR_TA3_H_V1_8821C(x) | BIT_TA3_H_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_4_8821C (TA4 REGISTER) */
#define BIT_SHIFT_TA4_V1_8821C 0
#define BIT_MASK_TA4_V1_8821C 0xffffffffL
#define BIT_TA4_V1_8821C(x) \
(((x) & BIT_MASK_TA4_V1_8821C) << BIT_SHIFT_TA4_V1_8821C)
#define BITS_TA4_V1_8821C (BIT_MASK_TA4_V1_8821C << BIT_SHIFT_TA4_V1_8821C)
#define BIT_CLEAR_TA4_V1_8821C(x) ((x) & (~BITS_TA4_V1_8821C))
#define BIT_GET_TA4_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA4_V1_8821C) & BIT_MASK_TA4_V1_8821C)
#define BIT_SET_TA4_V1_8821C(x, v) \
(BIT_CLEAR_TA4_V1_8821C(x) | BIT_TA4_V1_8821C(v))
/* 2 REG_TRANSMIT_ADDRSS_4_H_8821C (TA4 REGISTER) */
#define BIT_SHIFT_TA4_H_V1_8821C 0
#define BIT_MASK_TA4_H_V1_8821C 0xffff
#define BIT_TA4_H_V1_8821C(x) \
(((x) & BIT_MASK_TA4_H_V1_8821C) << BIT_SHIFT_TA4_H_V1_8821C)
#define BITS_TA4_H_V1_8821C \
(BIT_MASK_TA4_H_V1_8821C << BIT_SHIFT_TA4_H_V1_8821C)
#define BIT_CLEAR_TA4_H_V1_8821C(x) ((x) & (~BITS_TA4_H_V1_8821C))
#define BIT_GET_TA4_H_V1_8821C(x) \
(((x) >> BIT_SHIFT_TA4_H_V1_8821C) & BIT_MASK_TA4_H_V1_8821C)
#define BIT_SET_TA4_H_V1_8821C(x, v) \
(BIT_CLEAR_TA4_H_V1_8821C(x) | BIT_TA4_H_V1_8821C(v))
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_RSVD_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_MACID1_8821C */
#define BIT_SHIFT_MACID1_0_8821C 0
#define BIT_MASK_MACID1_0_8821C 0xffffffffL
#define BIT_MACID1_0_8821C(x) \
(((x) & BIT_MASK_MACID1_0_8821C) << BIT_SHIFT_MACID1_0_8821C)
#define BITS_MACID1_0_8821C \
(BIT_MASK_MACID1_0_8821C << BIT_SHIFT_MACID1_0_8821C)
#define BIT_CLEAR_MACID1_0_8821C(x) ((x) & (~BITS_MACID1_0_8821C))
#define BIT_GET_MACID1_0_8821C(x) \
(((x) >> BIT_SHIFT_MACID1_0_8821C) & BIT_MASK_MACID1_0_8821C)
#define BIT_SET_MACID1_0_8821C(x, v) \
(BIT_CLEAR_MACID1_0_8821C(x) | BIT_MACID1_0_8821C(v))
/* 2 REG_MACID1_1_8821C */
#define BIT_SHIFT_MACID1_1_8821C 0
#define BIT_MASK_MACID1_1_8821C 0xffff
#define BIT_MACID1_1_8821C(x) \
(((x) & BIT_MASK_MACID1_1_8821C) << BIT_SHIFT_MACID1_1_8821C)
#define BITS_MACID1_1_8821C \
(BIT_MASK_MACID1_1_8821C << BIT_SHIFT_MACID1_1_8821C)
#define BIT_CLEAR_MACID1_1_8821C(x) ((x) & (~BITS_MACID1_1_8821C))
#define BIT_GET_MACID1_1_8821C(x) \
(((x) >> BIT_SHIFT_MACID1_1_8821C) & BIT_MASK_MACID1_1_8821C)
#define BIT_SET_MACID1_1_8821C(x, v) \
(BIT_CLEAR_MACID1_1_8821C(x) | BIT_MACID1_1_8821C(v))
/* 2 REG_BSSID1_8821C */
#define BIT_SHIFT_BSSID1_0_8821C 0
#define BIT_MASK_BSSID1_0_8821C 0xffffffffL
#define BIT_BSSID1_0_8821C(x) \
(((x) & BIT_MASK_BSSID1_0_8821C) << BIT_SHIFT_BSSID1_0_8821C)
#define BITS_BSSID1_0_8821C \
(BIT_MASK_BSSID1_0_8821C << BIT_SHIFT_BSSID1_0_8821C)
#define BIT_CLEAR_BSSID1_0_8821C(x) ((x) & (~BITS_BSSID1_0_8821C))
#define BIT_GET_BSSID1_0_8821C(x) \
(((x) >> BIT_SHIFT_BSSID1_0_8821C) & BIT_MASK_BSSID1_0_8821C)
#define BIT_SET_BSSID1_0_8821C(x, v) \
(BIT_CLEAR_BSSID1_0_8821C(x) | BIT_BSSID1_0_8821C(v))
/* 2 REG_BSSID1_1_8821C */
#define BIT_SHIFT_BSSID1_1_8821C 0
#define BIT_MASK_BSSID1_1_8821C 0xffff
#define BIT_BSSID1_1_8821C(x) \
(((x) & BIT_MASK_BSSID1_1_8821C) << BIT_SHIFT_BSSID1_1_8821C)
#define BITS_BSSID1_1_8821C \
(BIT_MASK_BSSID1_1_8821C << BIT_SHIFT_BSSID1_1_8821C)
#define BIT_CLEAR_BSSID1_1_8821C(x) ((x) & (~BITS_BSSID1_1_8821C))
#define BIT_GET_BSSID1_1_8821C(x) \
(((x) >> BIT_SHIFT_BSSID1_1_8821C) & BIT_MASK_BSSID1_1_8821C)
#define BIT_SET_BSSID1_1_8821C(x, v) \
(BIT_CLEAR_BSSID1_1_8821C(x) | BIT_BSSID1_1_8821C(v))
/* 2 REG_BCN_PSR_RPT1_8821C */
#define BIT_SHIFT_DTIM_CNT1_8821C 24
#define BIT_MASK_DTIM_CNT1_8821C 0xff
#define BIT_DTIM_CNT1_8821C(x) \
(((x) & BIT_MASK_DTIM_CNT1_8821C) << BIT_SHIFT_DTIM_CNT1_8821C)
#define BITS_DTIM_CNT1_8821C \
(BIT_MASK_DTIM_CNT1_8821C << BIT_SHIFT_DTIM_CNT1_8821C)
#define BIT_CLEAR_DTIM_CNT1_8821C(x) ((x) & (~BITS_DTIM_CNT1_8821C))
#define BIT_GET_DTIM_CNT1_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT1_8821C) & BIT_MASK_DTIM_CNT1_8821C)
#define BIT_SET_DTIM_CNT1_8821C(x, v) \
(BIT_CLEAR_DTIM_CNT1_8821C(x) | BIT_DTIM_CNT1_8821C(v))
#define BIT_SHIFT_DTIM_PERIOD1_8821C 16
#define BIT_MASK_DTIM_PERIOD1_8821C 0xff
#define BIT_DTIM_PERIOD1_8821C(x) \
(((x) & BIT_MASK_DTIM_PERIOD1_8821C) << BIT_SHIFT_DTIM_PERIOD1_8821C)
#define BITS_DTIM_PERIOD1_8821C \
(BIT_MASK_DTIM_PERIOD1_8821C << BIT_SHIFT_DTIM_PERIOD1_8821C)
#define BIT_CLEAR_DTIM_PERIOD1_8821C(x) ((x) & (~BITS_DTIM_PERIOD1_8821C))
#define BIT_GET_DTIM_PERIOD1_8821C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD1_8821C) & BIT_MASK_DTIM_PERIOD1_8821C)
#define BIT_SET_DTIM_PERIOD1_8821C(x, v) \
(BIT_CLEAR_DTIM_PERIOD1_8821C(x) | BIT_DTIM_PERIOD1_8821C(v))
#define BIT_DTIM1_8821C BIT(15)
#define BIT_TIM1_8821C BIT(14)
#define BIT_SHIFT_PS_AID_1_8821C 0
#define BIT_MASK_PS_AID_1_8821C 0x7ff
#define BIT_PS_AID_1_8821C(x) \
(((x) & BIT_MASK_PS_AID_1_8821C) << BIT_SHIFT_PS_AID_1_8821C)
#define BITS_PS_AID_1_8821C \
(BIT_MASK_PS_AID_1_8821C << BIT_SHIFT_PS_AID_1_8821C)
#define BIT_CLEAR_PS_AID_1_8821C(x) ((x) & (~BITS_PS_AID_1_8821C))
#define BIT_GET_PS_AID_1_8821C(x) \
(((x) >> BIT_SHIFT_PS_AID_1_8821C) & BIT_MASK_PS_AID_1_8821C)
#define BIT_SET_PS_AID_1_8821C(x, v) \
(BIT_CLEAR_PS_AID_1_8821C(x) | BIT_PS_AID_1_8821C(v))
/* 2 REG_ASSOCIATED_BFMEE_SEL_8821C */
#define BIT_TXUSER_ID1_8821C BIT(25)
#define BIT_SHIFT_AID1_8821C 16
#define BIT_MASK_AID1_8821C 0x1ff
#define BIT_AID1_8821C(x) (((x) & BIT_MASK_AID1_8821C) << BIT_SHIFT_AID1_8821C)
#define BITS_AID1_8821C (BIT_MASK_AID1_8821C << BIT_SHIFT_AID1_8821C)
#define BIT_CLEAR_AID1_8821C(x) ((x) & (~BITS_AID1_8821C))
#define BIT_GET_AID1_8821C(x) \
(((x) >> BIT_SHIFT_AID1_8821C) & BIT_MASK_AID1_8821C)
#define BIT_SET_AID1_8821C(x, v) (BIT_CLEAR_AID1_8821C(x) | BIT_AID1_8821C(v))
#define BIT_TXUSER_ID0_8821C BIT(9)
#define BIT_SHIFT_AID0_8821C 0
#define BIT_MASK_AID0_8821C 0x1ff
#define BIT_AID0_8821C(x) (((x) & BIT_MASK_AID0_8821C) << BIT_SHIFT_AID0_8821C)
#define BITS_AID0_8821C (BIT_MASK_AID0_8821C << BIT_SHIFT_AID0_8821C)
#define BIT_CLEAR_AID0_8821C(x) ((x) & (~BITS_AID0_8821C))
#define BIT_GET_AID0_8821C(x) \
(((x) >> BIT_SHIFT_AID0_8821C) & BIT_MASK_AID0_8821C)
#define BIT_SET_AID0_8821C(x, v) (BIT_CLEAR_AID0_8821C(x) | BIT_AID0_8821C(v))
/* 2 REG_SND_PTCL_CTRL_8821C */
#define BIT_SHIFT_NDP_RX_STANDBY_TIMER_8821C 24
#define BIT_MASK_NDP_RX_STANDBY_TIMER_8821C 0xff
#define BIT_NDP_RX_STANDBY_TIMER_8821C(x) \
(((x) & BIT_MASK_NDP_RX_STANDBY_TIMER_8821C) \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8821C)
#define BITS_NDP_RX_STANDBY_TIMER_8821C \
(BIT_MASK_NDP_RX_STANDBY_TIMER_8821C \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8821C)
#define BIT_CLEAR_NDP_RX_STANDBY_TIMER_8821C(x) \
((x) & (~BITS_NDP_RX_STANDBY_TIMER_8821C))
#define BIT_GET_NDP_RX_STANDBY_TIMER_8821C(x) \
(((x) >> BIT_SHIFT_NDP_RX_STANDBY_TIMER_8821C) & \
BIT_MASK_NDP_RX_STANDBY_TIMER_8821C)
#define BIT_SET_NDP_RX_STANDBY_TIMER_8821C(x, v) \
(BIT_CLEAR_NDP_RX_STANDBY_TIMER_8821C(x) | \
BIT_NDP_RX_STANDBY_TIMER_8821C(v))
#define BIT_SHIFT_CSI_RPT_OFFSET_HT_8821C 16
#define BIT_MASK_CSI_RPT_OFFSET_HT_8821C 0xff
#define BIT_CSI_RPT_OFFSET_HT_8821C(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT_8821C) \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_8821C)
#define BITS_CSI_RPT_OFFSET_HT_8821C \
(BIT_MASK_CSI_RPT_OFFSET_HT_8821C << BIT_SHIFT_CSI_RPT_OFFSET_HT_8821C)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT_8821C(x) \
((x) & (~BITS_CSI_RPT_OFFSET_HT_8821C))
#define BIT_GET_CSI_RPT_OFFSET_HT_8821C(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT_8821C) & \
BIT_MASK_CSI_RPT_OFFSET_HT_8821C)
#define BIT_SET_CSI_RPT_OFFSET_HT_8821C(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT_8821C(x) | BIT_CSI_RPT_OFFSET_HT_8821C(v))
#define BIT_SHIFT_R_WMAC_VHT_CATEGORY_8821C 8
#define BIT_MASK_R_WMAC_VHT_CATEGORY_8821C 0xff
#define BIT_R_WMAC_VHT_CATEGORY_8821C(x) \
(((x) & BIT_MASK_R_WMAC_VHT_CATEGORY_8821C) \
<< BIT_SHIFT_R_WMAC_VHT_CATEGORY_8821C)
#define BITS_R_WMAC_VHT_CATEGORY_8821C \
(BIT_MASK_R_WMAC_VHT_CATEGORY_8821C \
<< BIT_SHIFT_R_WMAC_VHT_CATEGORY_8821C)
#define BIT_CLEAR_R_WMAC_VHT_CATEGORY_8821C(x) \
((x) & (~BITS_R_WMAC_VHT_CATEGORY_8821C))
#define BIT_GET_R_WMAC_VHT_CATEGORY_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_VHT_CATEGORY_8821C) & \
BIT_MASK_R_WMAC_VHT_CATEGORY_8821C)
#define BIT_SET_R_WMAC_VHT_CATEGORY_8821C(x, v) \
(BIT_CLEAR_R_WMAC_VHT_CATEGORY_8821C(x) | \
BIT_R_WMAC_VHT_CATEGORY_8821C(v))
#define BIT_R_WMAC_USE_NSTS_8821C BIT(7)
#define BIT_R_DISABLE_CHECK_VHTSIGB_CRC_8821C BIT(6)
#define BIT_R_DISABLE_CHECK_VHTSIGA_CRC_8821C BIT(5)
#define BIT_R_WMAC_BFPARAM_SEL_8821C BIT(4)
#define BIT_R_WMAC_CSISEQ_SEL_8821C BIT(3)
#define BIT_R_WMAC_CSI_WITHHTC_EN_8821C BIT(2)
#define BIT_R_WMAC_HT_NDPA_EN_8821C BIT(1)
#define BIT_R_WMAC_VHT_NDPA_EN_8821C BIT(0)
/* 2 REG_RX_CSI_RPT_INFO_8821C */
/* 2 REG_NS_ARP_CTRL_8821C */
#define BIT_R_WMAC_NSARP_RSPEN_8821C BIT(15)
#define BIT_R_WMAC_NSARP_RARP_8821C BIT(9)
#define BIT_R_WMAC_NSARP_RIPV6_8821C BIT(8)
#define BIT_SHIFT_R_WMAC_NSARP_MODEN_8821C 6
#define BIT_MASK_R_WMAC_NSARP_MODEN_8821C 0x3
#define BIT_R_WMAC_NSARP_MODEN_8821C(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_MODEN_8821C) \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8821C)
#define BITS_R_WMAC_NSARP_MODEN_8821C \
(BIT_MASK_R_WMAC_NSARP_MODEN_8821C \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8821C)
#define BIT_CLEAR_R_WMAC_NSARP_MODEN_8821C(x) \
((x) & (~BITS_R_WMAC_NSARP_MODEN_8821C))
#define BIT_GET_R_WMAC_NSARP_MODEN_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_MODEN_8821C) & \
BIT_MASK_R_WMAC_NSARP_MODEN_8821C)
#define BIT_SET_R_WMAC_NSARP_MODEN_8821C(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_MODEN_8821C(x) | \
BIT_R_WMAC_NSARP_MODEN_8821C(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8821C 4
#define BIT_MASK_R_WMAC_NSARP_RSPFTP_8821C 0x3
#define BIT_R_WMAC_NSARP_RSPFTP_8821C(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPFTP_8821C) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8821C)
#define BITS_R_WMAC_NSARP_RSPFTP_8821C \
(BIT_MASK_R_WMAC_NSARP_RSPFTP_8821C \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8821C)
#define BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8821C(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPFTP_8821C))
#define BIT_GET_R_WMAC_NSARP_RSPFTP_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8821C) & \
BIT_MASK_R_WMAC_NSARP_RSPFTP_8821C)
#define BIT_SET_R_WMAC_NSARP_RSPFTP_8821C(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8821C(x) | \
BIT_R_WMAC_NSARP_RSPFTP_8821C(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8821C 0
#define BIT_MASK_R_WMAC_NSARP_RSPSEC_8821C 0xf
#define BIT_R_WMAC_NSARP_RSPSEC_8821C(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPSEC_8821C) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8821C)
#define BITS_R_WMAC_NSARP_RSPSEC_8821C \
(BIT_MASK_R_WMAC_NSARP_RSPSEC_8821C \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8821C)
#define BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8821C(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPSEC_8821C))
#define BIT_GET_R_WMAC_NSARP_RSPSEC_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8821C) & \
BIT_MASK_R_WMAC_NSARP_RSPSEC_8821C)
#define BIT_SET_R_WMAC_NSARP_RSPSEC_8821C(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8821C(x) | \
BIT_R_WMAC_NSARP_RSPSEC_8821C(v))
/* 2 REG_NS_ARP_INFO_8821C */
#define BIT_REQ_IS_MCNS_8821C BIT(23)
#define BIT_REQ_IS_UCNS_8821C BIT(22)
#define BIT_REQ_IS_USNS_8821C BIT(21)
#define BIT_REQ_IS_ARP_8821C BIT(20)
#define BIT_EXPRSP_MH_WITHQC_8821C BIT(19)
#define BIT_SHIFT_EXPRSP_SECTYPE_8821C 16
#define BIT_MASK_EXPRSP_SECTYPE_8821C 0x7
#define BIT_EXPRSP_SECTYPE_8821C(x) \
(((x) & BIT_MASK_EXPRSP_SECTYPE_8821C) \
<< BIT_SHIFT_EXPRSP_SECTYPE_8821C)
#define BITS_EXPRSP_SECTYPE_8821C \
(BIT_MASK_EXPRSP_SECTYPE_8821C << BIT_SHIFT_EXPRSP_SECTYPE_8821C)
#define BIT_CLEAR_EXPRSP_SECTYPE_8821C(x) ((x) & (~BITS_EXPRSP_SECTYPE_8821C))
#define BIT_GET_EXPRSP_SECTYPE_8821C(x) \
(((x) >> BIT_SHIFT_EXPRSP_SECTYPE_8821C) & \
BIT_MASK_EXPRSP_SECTYPE_8821C)
#define BIT_SET_EXPRSP_SECTYPE_8821C(x, v) \
(BIT_CLEAR_EXPRSP_SECTYPE_8821C(x) | BIT_EXPRSP_SECTYPE_8821C(v))
#define BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8821C 8
#define BIT_MASK_EXPRSP_CHKSM_7_TO_0_8821C 0xff
#define BIT_EXPRSP_CHKSM_7_TO_0_8821C(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_7_TO_0_8821C) \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8821C)
#define BITS_EXPRSP_CHKSM_7_TO_0_8821C \
(BIT_MASK_EXPRSP_CHKSM_7_TO_0_8821C \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8821C)
#define BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8821C(x) \
((x) & (~BITS_EXPRSP_CHKSM_7_TO_0_8821C))
#define BIT_GET_EXPRSP_CHKSM_7_TO_0_8821C(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8821C) & \
BIT_MASK_EXPRSP_CHKSM_7_TO_0_8821C)
#define BIT_SET_EXPRSP_CHKSM_7_TO_0_8821C(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8821C(x) | \
BIT_EXPRSP_CHKSM_7_TO_0_8821C(v))
#define BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8821C 0
#define BIT_MASK_EXPRSP_CHKSM_15_TO_8_8821C 0xff
#define BIT_EXPRSP_CHKSM_15_TO_8_8821C(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_15_TO_8_8821C) \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8821C)
#define BITS_EXPRSP_CHKSM_15_TO_8_8821C \
(BIT_MASK_EXPRSP_CHKSM_15_TO_8_8821C \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8821C)
#define BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8821C(x) \
((x) & (~BITS_EXPRSP_CHKSM_15_TO_8_8821C))
#define BIT_GET_EXPRSP_CHKSM_15_TO_8_8821C(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8821C) & \
BIT_MASK_EXPRSP_CHKSM_15_TO_8_8821C)
#define BIT_SET_EXPRSP_CHKSM_15_TO_8_8821C(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8821C(x) | \
BIT_EXPRSP_CHKSM_15_TO_8_8821C(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_V1_8821C */
#define BIT_SHIFT_WMAC_ARPIP_8821C 0
#define BIT_MASK_WMAC_ARPIP_8821C 0xffffffffL
#define BIT_WMAC_ARPIP_8821C(x) \
(((x) & BIT_MASK_WMAC_ARPIP_8821C) << BIT_SHIFT_WMAC_ARPIP_8821C)
#define BITS_WMAC_ARPIP_8821C \
(BIT_MASK_WMAC_ARPIP_8821C << BIT_SHIFT_WMAC_ARPIP_8821C)
#define BIT_CLEAR_WMAC_ARPIP_8821C(x) ((x) & (~BITS_WMAC_ARPIP_8821C))
#define BIT_GET_WMAC_ARPIP_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_ARPIP_8821C) & BIT_MASK_WMAC_ARPIP_8821C)
#define BIT_SET_WMAC_ARPIP_8821C(x, v) \
(BIT_CLEAR_WMAC_ARPIP_8821C(x) | BIT_WMAC_ARPIP_8821C(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_8821C */
#define BIT_SHIFT_BEAMFORMING_INFO_8821C 0
#define BIT_MASK_BEAMFORMING_INFO_8821C 0xffffffffL
#define BIT_BEAMFORMING_INFO_8821C(x) \
(((x) & BIT_MASK_BEAMFORMING_INFO_8821C) \
<< BIT_SHIFT_BEAMFORMING_INFO_8821C)
#define BITS_BEAMFORMING_INFO_8821C \
(BIT_MASK_BEAMFORMING_INFO_8821C << BIT_SHIFT_BEAMFORMING_INFO_8821C)
#define BIT_CLEAR_BEAMFORMING_INFO_8821C(x) \
((x) & (~BITS_BEAMFORMING_INFO_8821C))
#define BIT_GET_BEAMFORMING_INFO_8821C(x) \
(((x) >> BIT_SHIFT_BEAMFORMING_INFO_8821C) & \
BIT_MASK_BEAMFORMING_INFO_8821C)
#define BIT_SET_BEAMFORMING_INFO_8821C(x, v) \
(BIT_CLEAR_BEAMFORMING_INFO_8821C(x) | BIT_BEAMFORMING_INFO_8821C(v))
/* 2 REG_IPV6_8821C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8821C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8821C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_0_8821C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8821C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8821C)
#define BITS_R_WMAC_IPV6_MYIPAD_0_8821C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8821C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8821C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0_8821C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_0_8821C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_0_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8821C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8821C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_0_8821C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0_8821C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_0_8821C(v))
/* 2 REG_IPV6_1_8821C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8821C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8821C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8821C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8821C)
#define BITS_R_WMAC_IPV6_MYIPAD_1_8821C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8821C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8821C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1_8821C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_1_8821C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8821C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8821C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1_8821C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_1_8821C(v))
/* 2 REG_IPV6_2_8821C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8821C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8821C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_2_8821C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8821C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8821C)
#define BITS_R_WMAC_IPV6_MYIPAD_2_8821C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8821C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8821C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2_8821C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_2_8821C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_2_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8821C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8821C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_2_8821C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2_8821C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_2_8821C(v))
/* 2 REG_IPV6_3_8821C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8821C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8821C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_3_8821C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8821C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8821C)
#define BITS_R_WMAC_IPV6_MYIPAD_3_8821C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8821C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8821C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3_8821C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_3_8821C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_3_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8821C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8821C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_3_8821C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3_8821C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_3_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG_8821C */
#define BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8821C 4
#define BIT_MASK_R_WMAC_CTX_SUBTYPE_8821C 0xf
#define BIT_R_WMAC_CTX_SUBTYPE_8821C(x) \
(((x) & BIT_MASK_R_WMAC_CTX_SUBTYPE_8821C) \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8821C)
#define BITS_R_WMAC_CTX_SUBTYPE_8821C \
(BIT_MASK_R_WMAC_CTX_SUBTYPE_8821C \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8821C)
#define BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8821C(x) \
((x) & (~BITS_R_WMAC_CTX_SUBTYPE_8821C))
#define BIT_GET_R_WMAC_CTX_SUBTYPE_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8821C) & \
BIT_MASK_R_WMAC_CTX_SUBTYPE_8821C)
#define BIT_SET_R_WMAC_CTX_SUBTYPE_8821C(x, v) \
(BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8821C(x) | \
BIT_R_WMAC_CTX_SUBTYPE_8821C(v))
#define BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8821C 0
#define BIT_MASK_R_WMAC_RTX_SUBTYPE_8821C 0xf
#define BIT_R_WMAC_RTX_SUBTYPE_8821C(x) \
(((x) & BIT_MASK_R_WMAC_RTX_SUBTYPE_8821C) \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8821C)
#define BITS_R_WMAC_RTX_SUBTYPE_8821C \
(BIT_MASK_R_WMAC_RTX_SUBTYPE_8821C \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8821C)
#define BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8821C(x) \
((x) & (~BITS_R_WMAC_RTX_SUBTYPE_8821C))
#define BIT_GET_R_WMAC_RTX_SUBTYPE_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8821C) & \
BIT_MASK_R_WMAC_RTX_SUBTYPE_8821C)
#define BIT_SET_R_WMAC_RTX_SUBTYPE_8821C(x, v) \
(BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8821C(x) | \
BIT_R_WMAC_RTX_SUBTYPE_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_WMAC_SWAES_CFG_8821C */
/* 2 REG_BT_COEX_V2_8821C */
#define BIT_GNT_BT_POLARITY_8821C BIT(12)
#define BIT_GNT_BT_BYPASS_PRIORITY_8821C BIT(8)
#define BIT_SHIFT_TIMER_8821C 0
#define BIT_MASK_TIMER_8821C 0xff
#define BIT_TIMER_8821C(x) \
(((x) & BIT_MASK_TIMER_8821C) << BIT_SHIFT_TIMER_8821C)
#define BITS_TIMER_8821C (BIT_MASK_TIMER_8821C << BIT_SHIFT_TIMER_8821C)
#define BIT_CLEAR_TIMER_8821C(x) ((x) & (~BITS_TIMER_8821C))
#define BIT_GET_TIMER_8821C(x) \
(((x) >> BIT_SHIFT_TIMER_8821C) & BIT_MASK_TIMER_8821C)
#define BIT_SET_TIMER_8821C(x, v) \
(BIT_CLEAR_TIMER_8821C(x) | BIT_TIMER_8821C(v))
/* 2 REG_BT_COEX_8821C */
#define BIT_R_GNT_BT_RFC_SW_8821C BIT(12)
#define BIT_R_GNT_BT_RFC_SW_EN_8821C BIT(11)
#define BIT_R_GNT_BT_BB_SW_8821C BIT(10)
#define BIT_R_GNT_BT_BB_SW_EN_8821C BIT(9)
#define BIT_R_BT_CNT_THREN_8821C BIT(8)
#define BIT_SHIFT_R_BT_CNT_THR_8821C 0
#define BIT_MASK_R_BT_CNT_THR_8821C 0xff
#define BIT_R_BT_CNT_THR_8821C(x) \
(((x) & BIT_MASK_R_BT_CNT_THR_8821C) << BIT_SHIFT_R_BT_CNT_THR_8821C)
#define BITS_R_BT_CNT_THR_8821C \
(BIT_MASK_R_BT_CNT_THR_8821C << BIT_SHIFT_R_BT_CNT_THR_8821C)
#define BIT_CLEAR_R_BT_CNT_THR_8821C(x) ((x) & (~BITS_R_BT_CNT_THR_8821C))
#define BIT_GET_R_BT_CNT_THR_8821C(x) \
(((x) >> BIT_SHIFT_R_BT_CNT_THR_8821C) & BIT_MASK_R_BT_CNT_THR_8821C)
#define BIT_SET_R_BT_CNT_THR_8821C(x, v) \
(BIT_CLEAR_R_BT_CNT_THR_8821C(x) | BIT_R_BT_CNT_THR_8821C(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_8821C */
#define BIT_SHIFT_RXMYRTS_NAV_V1_8821C 8
#define BIT_MASK_RXMYRTS_NAV_V1_8821C 0xff
#define BIT_RXMYRTS_NAV_V1_8821C(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_V1_8821C) \
<< BIT_SHIFT_RXMYRTS_NAV_V1_8821C)
#define BITS_RXMYRTS_NAV_V1_8821C \
(BIT_MASK_RXMYRTS_NAV_V1_8821C << BIT_SHIFT_RXMYRTS_NAV_V1_8821C)
#define BIT_CLEAR_RXMYRTS_NAV_V1_8821C(x) ((x) & (~BITS_RXMYRTS_NAV_V1_8821C))
#define BIT_GET_RXMYRTS_NAV_V1_8821C(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_V1_8821C) & \
BIT_MASK_RXMYRTS_NAV_V1_8821C)
#define BIT_SET_RXMYRTS_NAV_V1_8821C(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_V1_8821C(x) | BIT_RXMYRTS_NAV_V1_8821C(v))
#define BIT_SHIFT_RTSRST_V1_8821C 0
#define BIT_MASK_RTSRST_V1_8821C 0xff
#define BIT_RTSRST_V1_8821C(x) \
(((x) & BIT_MASK_RTSRST_V1_8821C) << BIT_SHIFT_RTSRST_V1_8821C)
#define BITS_RTSRST_V1_8821C \
(BIT_MASK_RTSRST_V1_8821C << BIT_SHIFT_RTSRST_V1_8821C)
#define BIT_CLEAR_RTSRST_V1_8821C(x) ((x) & (~BITS_RTSRST_V1_8821C))
#define BIT_GET_RTSRST_V1_8821C(x) \
(((x) >> BIT_SHIFT_RTSRST_V1_8821C) & BIT_MASK_RTSRST_V1_8821C)
#define BIT_SET_RTSRST_V1_8821C(x, v) \
(BIT_CLEAR_RTSRST_V1_8821C(x) | BIT_RTSRST_V1_8821C(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_1_8821C */
#define BIT_WLRX_TER_BY_CTL_1_8821C BIT(11)
#define BIT_WLRX_TER_BY_AD_1_8821C BIT(10)
#define BIT_ANT_DIVERSITY_SEL_1_8821C BIT(9)
#define BIT_ANTSEL_FOR_BT_CTRL_EN_1_8821C BIT(8)
#define BIT_WLACT_LOW_GNTWL_EN_1_8821C BIT(2)
#define BIT_WLACT_HIGH_GNTBT_EN_1_8821C BIT(1)
#define BIT_NAV_UPPER_1_V1_8821C BIT(0)
/* 2 REG_BT_COEX_ENHANCED_INTR_CTRL_8821C */
#define BIT_SHIFT_BT_STAT_DELAY_8821C 12
#define BIT_MASK_BT_STAT_DELAY_8821C 0xf
#define BIT_BT_STAT_DELAY_8821C(x) \
(((x) & BIT_MASK_BT_STAT_DELAY_8821C) << BIT_SHIFT_BT_STAT_DELAY_8821C)
#define BITS_BT_STAT_DELAY_8821C \
(BIT_MASK_BT_STAT_DELAY_8821C << BIT_SHIFT_BT_STAT_DELAY_8821C)
#define BIT_CLEAR_BT_STAT_DELAY_8821C(x) ((x) & (~BITS_BT_STAT_DELAY_8821C))
#define BIT_GET_BT_STAT_DELAY_8821C(x) \
(((x) >> BIT_SHIFT_BT_STAT_DELAY_8821C) & BIT_MASK_BT_STAT_DELAY_8821C)
#define BIT_SET_BT_STAT_DELAY_8821C(x, v) \
(BIT_CLEAR_BT_STAT_DELAY_8821C(x) | BIT_BT_STAT_DELAY_8821C(v))
#define BIT_SHIFT_BT_TRX_INIT_DETECT_8821C 8
#define BIT_MASK_BT_TRX_INIT_DETECT_8821C 0xf
#define BIT_BT_TRX_INIT_DETECT_8821C(x) \
(((x) & BIT_MASK_BT_TRX_INIT_DETECT_8821C) \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8821C)
#define BITS_BT_TRX_INIT_DETECT_8821C \
(BIT_MASK_BT_TRX_INIT_DETECT_8821C \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8821C)
#define BIT_CLEAR_BT_TRX_INIT_DETECT_8821C(x) \
((x) & (~BITS_BT_TRX_INIT_DETECT_8821C))
#define BIT_GET_BT_TRX_INIT_DETECT_8821C(x) \
(((x) >> BIT_SHIFT_BT_TRX_INIT_DETECT_8821C) & \
BIT_MASK_BT_TRX_INIT_DETECT_8821C)
#define BIT_SET_BT_TRX_INIT_DETECT_8821C(x, v) \
(BIT_CLEAR_BT_TRX_INIT_DETECT_8821C(x) | \
BIT_BT_TRX_INIT_DETECT_8821C(v))
#define BIT_SHIFT_BT_PRI_DETECT_TO_8821C 4
#define BIT_MASK_BT_PRI_DETECT_TO_8821C 0xf
#define BIT_BT_PRI_DETECT_TO_8821C(x) \
(((x) & BIT_MASK_BT_PRI_DETECT_TO_8821C) \
<< BIT_SHIFT_BT_PRI_DETECT_TO_8821C)
#define BITS_BT_PRI_DETECT_TO_8821C \
(BIT_MASK_BT_PRI_DETECT_TO_8821C << BIT_SHIFT_BT_PRI_DETECT_TO_8821C)
#define BIT_CLEAR_BT_PRI_DETECT_TO_8821C(x) \
((x) & (~BITS_BT_PRI_DETECT_TO_8821C))
#define BIT_GET_BT_PRI_DETECT_TO_8821C(x) \
(((x) >> BIT_SHIFT_BT_PRI_DETECT_TO_8821C) & \
BIT_MASK_BT_PRI_DETECT_TO_8821C)
#define BIT_SET_BT_PRI_DETECT_TO_8821C(x, v) \
(BIT_CLEAR_BT_PRI_DETECT_TO_8821C(x) | BIT_BT_PRI_DETECT_TO_8821C(v))
#define BIT_R_GRANTALL_WLMASK_8821C BIT(3)
#define BIT_STATIS_BT_EN_8821C BIT(2)
#define BIT_WL_ACT_MASK_ENABLE_8821C BIT(1)
#define BIT_ENHANCED_BT_8821C BIT(0)
/* 2 REG_BT_ACT_STATISTICS_8821C */
#define BIT_SHIFT_STATIS_BT_HI_RX_8821C 16
#define BIT_MASK_STATIS_BT_HI_RX_8821C 0xffff
#define BIT_STATIS_BT_HI_RX_8821C(x) \
(((x) & BIT_MASK_STATIS_BT_HI_RX_8821C) \
<< BIT_SHIFT_STATIS_BT_HI_RX_8821C)
#define BITS_STATIS_BT_HI_RX_8821C \
(BIT_MASK_STATIS_BT_HI_RX_8821C << BIT_SHIFT_STATIS_BT_HI_RX_8821C)
#define BIT_CLEAR_STATIS_BT_HI_RX_8821C(x) ((x) & (~BITS_STATIS_BT_HI_RX_8821C))
#define BIT_GET_STATIS_BT_HI_RX_8821C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_RX_8821C) & \
BIT_MASK_STATIS_BT_HI_RX_8821C)
#define BIT_SET_STATIS_BT_HI_RX_8821C(x, v) \
(BIT_CLEAR_STATIS_BT_HI_RX_8821C(x) | BIT_STATIS_BT_HI_RX_8821C(v))
#define BIT_SHIFT_STATIS_BT_HI_TX_8821C 0
#define BIT_MASK_STATIS_BT_HI_TX_8821C 0xffff
#define BIT_STATIS_BT_HI_TX_8821C(x) \
(((x) & BIT_MASK_STATIS_BT_HI_TX_8821C) \
<< BIT_SHIFT_STATIS_BT_HI_TX_8821C)
#define BITS_STATIS_BT_HI_TX_8821C \
(BIT_MASK_STATIS_BT_HI_TX_8821C << BIT_SHIFT_STATIS_BT_HI_TX_8821C)
#define BIT_CLEAR_STATIS_BT_HI_TX_8821C(x) ((x) & (~BITS_STATIS_BT_HI_TX_8821C))
#define BIT_GET_STATIS_BT_HI_TX_8821C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_TX_8821C) & \
BIT_MASK_STATIS_BT_HI_TX_8821C)
#define BIT_SET_STATIS_BT_HI_TX_8821C(x, v) \
(BIT_CLEAR_STATIS_BT_HI_TX_8821C(x) | BIT_STATIS_BT_HI_TX_8821C(v))
/* 2 REG_BT_ACT_STATISTICS_1_8821C */
#define BIT_SHIFT_STATIS_BT_LO_RX_1_8821C 16
#define BIT_MASK_STATIS_BT_LO_RX_1_8821C 0xffff
#define BIT_STATIS_BT_LO_RX_1_8821C(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX_1_8821C) \
<< BIT_SHIFT_STATIS_BT_LO_RX_1_8821C)
#define BITS_STATIS_BT_LO_RX_1_8821C \
(BIT_MASK_STATIS_BT_LO_RX_1_8821C << BIT_SHIFT_STATIS_BT_LO_RX_1_8821C)
#define BIT_CLEAR_STATIS_BT_LO_RX_1_8821C(x) \
((x) & (~BITS_STATIS_BT_LO_RX_1_8821C))
#define BIT_GET_STATIS_BT_LO_RX_1_8821C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX_1_8821C) & \
BIT_MASK_STATIS_BT_LO_RX_1_8821C)
#define BIT_SET_STATIS_BT_LO_RX_1_8821C(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX_1_8821C(x) | BIT_STATIS_BT_LO_RX_1_8821C(v))
#define BIT_SHIFT_STATIS_BT_LO_TX_1_8821C 0
#define BIT_MASK_STATIS_BT_LO_TX_1_8821C 0xffff
#define BIT_STATIS_BT_LO_TX_1_8821C(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX_1_8821C) \
<< BIT_SHIFT_STATIS_BT_LO_TX_1_8821C)
#define BITS_STATIS_BT_LO_TX_1_8821C \
(BIT_MASK_STATIS_BT_LO_TX_1_8821C << BIT_SHIFT_STATIS_BT_LO_TX_1_8821C)
#define BIT_CLEAR_STATIS_BT_LO_TX_1_8821C(x) \
((x) & (~BITS_STATIS_BT_LO_TX_1_8821C))
#define BIT_GET_STATIS_BT_LO_TX_1_8821C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX_1_8821C) & \
BIT_MASK_STATIS_BT_LO_TX_1_8821C)
#define BIT_SET_STATIS_BT_LO_TX_1_8821C(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX_1_8821C(x) | BIT_STATIS_BT_LO_TX_1_8821C(v))
/* 2 REG_BT_STATISTICS_CONTROL_REGISTER_8821C */
#define BIT_SHIFT_R_BT_CMD_RPT_8821C 16
#define BIT_MASK_R_BT_CMD_RPT_8821C 0xffff
#define BIT_R_BT_CMD_RPT_8821C(x) \
(((x) & BIT_MASK_R_BT_CMD_RPT_8821C) << BIT_SHIFT_R_BT_CMD_RPT_8821C)
#define BITS_R_BT_CMD_RPT_8821C \
(BIT_MASK_R_BT_CMD_RPT_8821C << BIT_SHIFT_R_BT_CMD_RPT_8821C)
#define BIT_CLEAR_R_BT_CMD_RPT_8821C(x) ((x) & (~BITS_R_BT_CMD_RPT_8821C))
#define BIT_GET_R_BT_CMD_RPT_8821C(x) \
(((x) >> BIT_SHIFT_R_BT_CMD_RPT_8821C) & BIT_MASK_R_BT_CMD_RPT_8821C)
#define BIT_SET_R_BT_CMD_RPT_8821C(x, v) \
(BIT_CLEAR_R_BT_CMD_RPT_8821C(x) | BIT_R_BT_CMD_RPT_8821C(v))
#define BIT_SHIFT_R_RPT_FROM_BT_8821C 8
#define BIT_MASK_R_RPT_FROM_BT_8821C 0xff
#define BIT_R_RPT_FROM_BT_8821C(x) \
(((x) & BIT_MASK_R_RPT_FROM_BT_8821C) << BIT_SHIFT_R_RPT_FROM_BT_8821C)
#define BITS_R_RPT_FROM_BT_8821C \
(BIT_MASK_R_RPT_FROM_BT_8821C << BIT_SHIFT_R_RPT_FROM_BT_8821C)
#define BIT_CLEAR_R_RPT_FROM_BT_8821C(x) ((x) & (~BITS_R_RPT_FROM_BT_8821C))
#define BIT_GET_R_RPT_FROM_BT_8821C(x) \
(((x) >> BIT_SHIFT_R_RPT_FROM_BT_8821C) & BIT_MASK_R_RPT_FROM_BT_8821C)
#define BIT_SET_R_RPT_FROM_BT_8821C(x, v) \
(BIT_CLEAR_R_RPT_FROM_BT_8821C(x) | BIT_R_RPT_FROM_BT_8821C(v))
#define BIT_SHIFT_BT_HID_ISR_SET_8821C 6
#define BIT_MASK_BT_HID_ISR_SET_8821C 0x3
#define BIT_BT_HID_ISR_SET_8821C(x) \
(((x) & BIT_MASK_BT_HID_ISR_SET_8821C) \
<< BIT_SHIFT_BT_HID_ISR_SET_8821C)
#define BITS_BT_HID_ISR_SET_8821C \
(BIT_MASK_BT_HID_ISR_SET_8821C << BIT_SHIFT_BT_HID_ISR_SET_8821C)
#define BIT_CLEAR_BT_HID_ISR_SET_8821C(x) ((x) & (~BITS_BT_HID_ISR_SET_8821C))
#define BIT_GET_BT_HID_ISR_SET_8821C(x) \
(((x) >> BIT_SHIFT_BT_HID_ISR_SET_8821C) & \
BIT_MASK_BT_HID_ISR_SET_8821C)
#define BIT_SET_BT_HID_ISR_SET_8821C(x, v) \
(BIT_CLEAR_BT_HID_ISR_SET_8821C(x) | BIT_BT_HID_ISR_SET_8821C(v))
#define BIT_TDMA_BT_START_NOTIFY_8821C BIT(5)
#define BIT_ENABLE_TDMA_FW_MODE_8821C BIT(4)
#define BIT_ENABLE_PTA_TDMA_MODE_8821C BIT(3)
#define BIT_ENABLE_COEXIST_TAB_IN_TDMA_8821C BIT(2)
#define BIT_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA_8821C BIT(1)
#define BIT_RTK_BT_ENABLE_8821C BIT(0)
/* 2 REG_BT_STATUS_REPORT_REGISTER_8821C */
#define BIT_SHIFT_BT_PROFILE_8821C 24
#define BIT_MASK_BT_PROFILE_8821C 0xff
#define BIT_BT_PROFILE_8821C(x) \
(((x) & BIT_MASK_BT_PROFILE_8821C) << BIT_SHIFT_BT_PROFILE_8821C)
#define BITS_BT_PROFILE_8821C \
(BIT_MASK_BT_PROFILE_8821C << BIT_SHIFT_BT_PROFILE_8821C)
#define BIT_CLEAR_BT_PROFILE_8821C(x) ((x) & (~BITS_BT_PROFILE_8821C))
#define BIT_GET_BT_PROFILE_8821C(x) \
(((x) >> BIT_SHIFT_BT_PROFILE_8821C) & BIT_MASK_BT_PROFILE_8821C)
#define BIT_SET_BT_PROFILE_8821C(x, v) \
(BIT_CLEAR_BT_PROFILE_8821C(x) | BIT_BT_PROFILE_8821C(v))
#define BIT_SHIFT_BT_POWER_8821C 16
#define BIT_MASK_BT_POWER_8821C 0xff
#define BIT_BT_POWER_8821C(x) \
(((x) & BIT_MASK_BT_POWER_8821C) << BIT_SHIFT_BT_POWER_8821C)
#define BITS_BT_POWER_8821C \
(BIT_MASK_BT_POWER_8821C << BIT_SHIFT_BT_POWER_8821C)
#define BIT_CLEAR_BT_POWER_8821C(x) ((x) & (~BITS_BT_POWER_8821C))
#define BIT_GET_BT_POWER_8821C(x) \
(((x) >> BIT_SHIFT_BT_POWER_8821C) & BIT_MASK_BT_POWER_8821C)
#define BIT_SET_BT_POWER_8821C(x, v) \
(BIT_CLEAR_BT_POWER_8821C(x) | BIT_BT_POWER_8821C(v))
#define BIT_SHIFT_BT_PREDECT_STATUS_8821C 8
#define BIT_MASK_BT_PREDECT_STATUS_8821C 0xff
#define BIT_BT_PREDECT_STATUS_8821C(x) \
(((x) & BIT_MASK_BT_PREDECT_STATUS_8821C) \
<< BIT_SHIFT_BT_PREDECT_STATUS_8821C)
#define BITS_BT_PREDECT_STATUS_8821C \
(BIT_MASK_BT_PREDECT_STATUS_8821C << BIT_SHIFT_BT_PREDECT_STATUS_8821C)
#define BIT_CLEAR_BT_PREDECT_STATUS_8821C(x) \
((x) & (~BITS_BT_PREDECT_STATUS_8821C))
#define BIT_GET_BT_PREDECT_STATUS_8821C(x) \
(((x) >> BIT_SHIFT_BT_PREDECT_STATUS_8821C) & \
BIT_MASK_BT_PREDECT_STATUS_8821C)
#define BIT_SET_BT_PREDECT_STATUS_8821C(x, v) \
(BIT_CLEAR_BT_PREDECT_STATUS_8821C(x) | BIT_BT_PREDECT_STATUS_8821C(v))
#define BIT_SHIFT_BT_CMD_INFO_8821C 0
#define BIT_MASK_BT_CMD_INFO_8821C 0xff
#define BIT_BT_CMD_INFO_8821C(x) \
(((x) & BIT_MASK_BT_CMD_INFO_8821C) << BIT_SHIFT_BT_CMD_INFO_8821C)
#define BITS_BT_CMD_INFO_8821C \
(BIT_MASK_BT_CMD_INFO_8821C << BIT_SHIFT_BT_CMD_INFO_8821C)
#define BIT_CLEAR_BT_CMD_INFO_8821C(x) ((x) & (~BITS_BT_CMD_INFO_8821C))
#define BIT_GET_BT_CMD_INFO_8821C(x) \
(((x) >> BIT_SHIFT_BT_CMD_INFO_8821C) & BIT_MASK_BT_CMD_INFO_8821C)
#define BIT_SET_BT_CMD_INFO_8821C(x, v) \
(BIT_CLEAR_BT_CMD_INFO_8821C(x) | BIT_BT_CMD_INFO_8821C(v))
/* 2 REG_BT_INTERRUPT_CONTROL_REGISTER_8821C */
#define BIT_EN_MAC_NULL_PKT_NOTIFY_8821C BIT(31)
#define BIT_EN_WLAN_RPT_AND_BT_QUERY_8821C BIT(30)
#define BIT_EN_BT_STSTUS_RPT_8821C BIT(29)
#define BIT_EN_BT_POWER_8821C BIT(28)
#define BIT_EN_BT_CHANNEL_8821C BIT(27)
#define BIT_EN_BT_SLOT_CHANGE_8821C BIT(26)
#define BIT_EN_BT_PROFILE_OR_HID_8821C BIT(25)
#define BIT_WLAN_RPT_NOTIFY_8821C BIT(24)
#define BIT_SHIFT_WLAN_RPT_DATA_8821C 16
#define BIT_MASK_WLAN_RPT_DATA_8821C 0xff
#define BIT_WLAN_RPT_DATA_8821C(x) \
(((x) & BIT_MASK_WLAN_RPT_DATA_8821C) << BIT_SHIFT_WLAN_RPT_DATA_8821C)
#define BITS_WLAN_RPT_DATA_8821C \
(BIT_MASK_WLAN_RPT_DATA_8821C << BIT_SHIFT_WLAN_RPT_DATA_8821C)
#define BIT_CLEAR_WLAN_RPT_DATA_8821C(x) ((x) & (~BITS_WLAN_RPT_DATA_8821C))
#define BIT_GET_WLAN_RPT_DATA_8821C(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_DATA_8821C) & BIT_MASK_WLAN_RPT_DATA_8821C)
#define BIT_SET_WLAN_RPT_DATA_8821C(x, v) \
(BIT_CLEAR_WLAN_RPT_DATA_8821C(x) | BIT_WLAN_RPT_DATA_8821C(v))
#define BIT_SHIFT_CMD_ID_8821C 8
#define BIT_MASK_CMD_ID_8821C 0xff
#define BIT_CMD_ID_8821C(x) \
(((x) & BIT_MASK_CMD_ID_8821C) << BIT_SHIFT_CMD_ID_8821C)
#define BITS_CMD_ID_8821C (BIT_MASK_CMD_ID_8821C << BIT_SHIFT_CMD_ID_8821C)
#define BIT_CLEAR_CMD_ID_8821C(x) ((x) & (~BITS_CMD_ID_8821C))
#define BIT_GET_CMD_ID_8821C(x) \
(((x) >> BIT_SHIFT_CMD_ID_8821C) & BIT_MASK_CMD_ID_8821C)
#define BIT_SET_CMD_ID_8821C(x, v) \
(BIT_CLEAR_CMD_ID_8821C(x) | BIT_CMD_ID_8821C(v))
#define BIT_SHIFT_BT_DATA_8821C 0
#define BIT_MASK_BT_DATA_8821C 0xff
#define BIT_BT_DATA_8821C(x) \
(((x) & BIT_MASK_BT_DATA_8821C) << BIT_SHIFT_BT_DATA_8821C)
#define BITS_BT_DATA_8821C (BIT_MASK_BT_DATA_8821C << BIT_SHIFT_BT_DATA_8821C)
#define BIT_CLEAR_BT_DATA_8821C(x) ((x) & (~BITS_BT_DATA_8821C))
#define BIT_GET_BT_DATA_8821C(x) \
(((x) >> BIT_SHIFT_BT_DATA_8821C) & BIT_MASK_BT_DATA_8821C)
#define BIT_SET_BT_DATA_8821C(x, v) \
(BIT_CLEAR_BT_DATA_8821C(x) | BIT_BT_DATA_8821C(v))
/* 2 REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8821C */
#define BIT_SHIFT_WLAN_RPT_TO_8821C 0
#define BIT_MASK_WLAN_RPT_TO_8821C 0xff
#define BIT_WLAN_RPT_TO_8821C(x) \
(((x) & BIT_MASK_WLAN_RPT_TO_8821C) << BIT_SHIFT_WLAN_RPT_TO_8821C)
#define BITS_WLAN_RPT_TO_8821C \
(BIT_MASK_WLAN_RPT_TO_8821C << BIT_SHIFT_WLAN_RPT_TO_8821C)
#define BIT_CLEAR_WLAN_RPT_TO_8821C(x) ((x) & (~BITS_WLAN_RPT_TO_8821C))
#define BIT_GET_WLAN_RPT_TO_8821C(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_TO_8821C) & BIT_MASK_WLAN_RPT_TO_8821C)
#define BIT_SET_WLAN_RPT_TO_8821C(x, v) \
(BIT_CLEAR_WLAN_RPT_TO_8821C(x) | BIT_WLAN_RPT_TO_8821C(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8821C */
#define BIT_SHIFT_ISOLATION_CHK_0_8821C 1
#define BIT_MASK_ISOLATION_CHK_0_8821C 0x7fffff
#define BIT_ISOLATION_CHK_0_8821C(x) \
(((x) & BIT_MASK_ISOLATION_CHK_0_8821C) \
<< BIT_SHIFT_ISOLATION_CHK_0_8821C)
#define BITS_ISOLATION_CHK_0_8821C \
(BIT_MASK_ISOLATION_CHK_0_8821C << BIT_SHIFT_ISOLATION_CHK_0_8821C)
#define BIT_CLEAR_ISOLATION_CHK_0_8821C(x) ((x) & (~BITS_ISOLATION_CHK_0_8821C))
#define BIT_GET_ISOLATION_CHK_0_8821C(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_0_8821C) & \
BIT_MASK_ISOLATION_CHK_0_8821C)
#define BIT_SET_ISOLATION_CHK_0_8821C(x, v) \
(BIT_CLEAR_ISOLATION_CHK_0_8821C(x) | BIT_ISOLATION_CHK_0_8821C(v))
#define BIT_ISOLATION_EN_8821C BIT(0)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8821C */
#define BIT_SHIFT_ISOLATION_CHK_1_8821C 0
#define BIT_MASK_ISOLATION_CHK_1_8821C 0xffffffffL
#define BIT_ISOLATION_CHK_1_8821C(x) \
(((x) & BIT_MASK_ISOLATION_CHK_1_8821C) \
<< BIT_SHIFT_ISOLATION_CHK_1_8821C)
#define BITS_ISOLATION_CHK_1_8821C \
(BIT_MASK_ISOLATION_CHK_1_8821C << BIT_SHIFT_ISOLATION_CHK_1_8821C)
#define BIT_CLEAR_ISOLATION_CHK_1_8821C(x) ((x) & (~BITS_ISOLATION_CHK_1_8821C))
#define BIT_GET_ISOLATION_CHK_1_8821C(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_1_8821C) & \
BIT_MASK_ISOLATION_CHK_1_8821C)
#define BIT_SET_ISOLATION_CHK_1_8821C(x, v) \
(BIT_CLEAR_ISOLATION_CHK_1_8821C(x) | BIT_ISOLATION_CHK_1_8821C(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8821C */
#define BIT_SHIFT_ISOLATION_CHK_2_8821C 0
#define BIT_MASK_ISOLATION_CHK_2_8821C 0xffffff
#define BIT_ISOLATION_CHK_2_8821C(x) \
(((x) & BIT_MASK_ISOLATION_CHK_2_8821C) \
<< BIT_SHIFT_ISOLATION_CHK_2_8821C)
#define BITS_ISOLATION_CHK_2_8821C \
(BIT_MASK_ISOLATION_CHK_2_8821C << BIT_SHIFT_ISOLATION_CHK_2_8821C)
#define BIT_CLEAR_ISOLATION_CHK_2_8821C(x) ((x) & (~BITS_ISOLATION_CHK_2_8821C))
#define BIT_GET_ISOLATION_CHK_2_8821C(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_2_8821C) & \
BIT_MASK_ISOLATION_CHK_2_8821C)
#define BIT_SET_ISOLATION_CHK_2_8821C(x, v) \
(BIT_CLEAR_ISOLATION_CHK_2_8821C(x) | BIT_ISOLATION_CHK_2_8821C(v))
/* 2 REG_BT_INTERRUPT_STATUS_REGISTER_8821C */
#define BIT_BT_HID_ISR_8821C BIT(7)
#define BIT_BT_QUERY_ISR_8821C BIT(6)
#define BIT_MAC_NULL_PKT_NOTIFY_ISR_8821C BIT(5)
#define BIT_WLAN_RPT_ISR_8821C BIT(4)
#define BIT_BT_POWER_ISR_8821C BIT(3)
#define BIT_BT_CHANNEL_ISR_8821C BIT(2)
#define BIT_BT_SLOT_CHANGE_ISR_8821C BIT(1)
#define BIT_BT_PROFILE_ISR_8821C BIT(0)
/* 2 REG_BT_TDMA_TIME_REGISTER_8821C */
#define BIT_SHIFT_BT_TIME_8821C 6
#define BIT_MASK_BT_TIME_8821C 0x3ffffff
#define BIT_BT_TIME_8821C(x) \
(((x) & BIT_MASK_BT_TIME_8821C) << BIT_SHIFT_BT_TIME_8821C)
#define BITS_BT_TIME_8821C (BIT_MASK_BT_TIME_8821C << BIT_SHIFT_BT_TIME_8821C)
#define BIT_CLEAR_BT_TIME_8821C(x) ((x) & (~BITS_BT_TIME_8821C))
#define BIT_GET_BT_TIME_8821C(x) \
(((x) >> BIT_SHIFT_BT_TIME_8821C) & BIT_MASK_BT_TIME_8821C)
#define BIT_SET_BT_TIME_8821C(x, v) \
(BIT_CLEAR_BT_TIME_8821C(x) | BIT_BT_TIME_8821C(v))
#define BIT_SHIFT_BT_RPT_SAMPLE_RATE_8821C 0
#define BIT_MASK_BT_RPT_SAMPLE_RATE_8821C 0x3f
#define BIT_BT_RPT_SAMPLE_RATE_8821C(x) \
(((x) & BIT_MASK_BT_RPT_SAMPLE_RATE_8821C) \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8821C)
#define BITS_BT_RPT_SAMPLE_RATE_8821C \
(BIT_MASK_BT_RPT_SAMPLE_RATE_8821C \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8821C)
#define BIT_CLEAR_BT_RPT_SAMPLE_RATE_8821C(x) \
((x) & (~BITS_BT_RPT_SAMPLE_RATE_8821C))
#define BIT_GET_BT_RPT_SAMPLE_RATE_8821C(x) \
(((x) >> BIT_SHIFT_BT_RPT_SAMPLE_RATE_8821C) & \
BIT_MASK_BT_RPT_SAMPLE_RATE_8821C)
#define BIT_SET_BT_RPT_SAMPLE_RATE_8821C(x, v) \
(BIT_CLEAR_BT_RPT_SAMPLE_RATE_8821C(x) | \
BIT_BT_RPT_SAMPLE_RATE_8821C(v))
/* 2 REG_BT_ACT_REGISTER_8821C */
#define BIT_SHIFT_BT_EISR_EN_8821C 16
#define BIT_MASK_BT_EISR_EN_8821C 0xff
#define BIT_BT_EISR_EN_8821C(x) \
(((x) & BIT_MASK_BT_EISR_EN_8821C) << BIT_SHIFT_BT_EISR_EN_8821C)
#define BITS_BT_EISR_EN_8821C \
(BIT_MASK_BT_EISR_EN_8821C << BIT_SHIFT_BT_EISR_EN_8821C)
#define BIT_CLEAR_BT_EISR_EN_8821C(x) ((x) & (~BITS_BT_EISR_EN_8821C))
#define BIT_GET_BT_EISR_EN_8821C(x) \
(((x) >> BIT_SHIFT_BT_EISR_EN_8821C) & BIT_MASK_BT_EISR_EN_8821C)
#define BIT_SET_BT_EISR_EN_8821C(x, v) \
(BIT_CLEAR_BT_EISR_EN_8821C(x) | BIT_BT_EISR_EN_8821C(v))
#define BIT_BT_ACT_FALLING_ISR_8821C BIT(10)
#define BIT_BT_ACT_RISING_ISR_8821C BIT(9)
#define BIT_TDMA_TO_ISR_8821C BIT(8)
#define BIT_SHIFT_BT_CH_8821C 0
#define BIT_MASK_BT_CH_8821C 0xff
#define BIT_BT_CH_8821C(x) \
(((x) & BIT_MASK_BT_CH_8821C) << BIT_SHIFT_BT_CH_8821C)
#define BITS_BT_CH_8821C (BIT_MASK_BT_CH_8821C << BIT_SHIFT_BT_CH_8821C)
#define BIT_CLEAR_BT_CH_8821C(x) ((x) & (~BITS_BT_CH_8821C))
#define BIT_GET_BT_CH_8821C(x) \
(((x) >> BIT_SHIFT_BT_CH_8821C) & BIT_MASK_BT_CH_8821C)
#define BIT_SET_BT_CH_8821C(x, v) \
(BIT_CLEAR_BT_CH_8821C(x) | BIT_BT_CH_8821C(v))
/* 2 REG_OBFF_CTRL_BASIC_8821C */
#define BIT_OBFF_EN_V1_8821C BIT(31)
#define BIT_SHIFT_OBFF_STATE_V1_8821C 28
#define BIT_MASK_OBFF_STATE_V1_8821C 0x3
#define BIT_OBFF_STATE_V1_8821C(x) \
(((x) & BIT_MASK_OBFF_STATE_V1_8821C) << BIT_SHIFT_OBFF_STATE_V1_8821C)
#define BITS_OBFF_STATE_V1_8821C \
(BIT_MASK_OBFF_STATE_V1_8821C << BIT_SHIFT_OBFF_STATE_V1_8821C)
#define BIT_CLEAR_OBFF_STATE_V1_8821C(x) ((x) & (~BITS_OBFF_STATE_V1_8821C))
#define BIT_GET_OBFF_STATE_V1_8821C(x) \
(((x) >> BIT_SHIFT_OBFF_STATE_V1_8821C) & BIT_MASK_OBFF_STATE_V1_8821C)
#define BIT_SET_OBFF_STATE_V1_8821C(x, v) \
(BIT_CLEAR_OBFF_STATE_V1_8821C(x) | BIT_OBFF_STATE_V1_8821C(v))
#define BIT_OBFF_ACT_RXDMA_EN_8821C BIT(27)
#define BIT_OBFF_BLOCK_INT_EN_8821C BIT(26)
#define BIT_OBFF_AUTOACT_EN_8821C BIT(25)
#define BIT_OBFF_AUTOIDLE_EN_8821C BIT(24)
#define BIT_SHIFT_WAKE_MAX_PLS_8821C 20
#define BIT_MASK_WAKE_MAX_PLS_8821C 0x7
#define BIT_WAKE_MAX_PLS_8821C(x) \
(((x) & BIT_MASK_WAKE_MAX_PLS_8821C) << BIT_SHIFT_WAKE_MAX_PLS_8821C)
#define BITS_WAKE_MAX_PLS_8821C \
(BIT_MASK_WAKE_MAX_PLS_8821C << BIT_SHIFT_WAKE_MAX_PLS_8821C)
#define BIT_CLEAR_WAKE_MAX_PLS_8821C(x) ((x) & (~BITS_WAKE_MAX_PLS_8821C))
#define BIT_GET_WAKE_MAX_PLS_8821C(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_PLS_8821C) & BIT_MASK_WAKE_MAX_PLS_8821C)
#define BIT_SET_WAKE_MAX_PLS_8821C(x, v) \
(BIT_CLEAR_WAKE_MAX_PLS_8821C(x) | BIT_WAKE_MAX_PLS_8821C(v))
#define BIT_SHIFT_WAKE_MIN_PLS_8821C 16
#define BIT_MASK_WAKE_MIN_PLS_8821C 0x7
#define BIT_WAKE_MIN_PLS_8821C(x) \
(((x) & BIT_MASK_WAKE_MIN_PLS_8821C) << BIT_SHIFT_WAKE_MIN_PLS_8821C)
#define BITS_WAKE_MIN_PLS_8821C \
(BIT_MASK_WAKE_MIN_PLS_8821C << BIT_SHIFT_WAKE_MIN_PLS_8821C)
#define BIT_CLEAR_WAKE_MIN_PLS_8821C(x) ((x) & (~BITS_WAKE_MIN_PLS_8821C))
#define BIT_GET_WAKE_MIN_PLS_8821C(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_PLS_8821C) & BIT_MASK_WAKE_MIN_PLS_8821C)
#define BIT_SET_WAKE_MIN_PLS_8821C(x, v) \
(BIT_CLEAR_WAKE_MIN_PLS_8821C(x) | BIT_WAKE_MIN_PLS_8821C(v))
#define BIT_SHIFT_WAKE_MAX_F2F_8821C 12
#define BIT_MASK_WAKE_MAX_F2F_8821C 0x7
#define BIT_WAKE_MAX_F2F_8821C(x) \
(((x) & BIT_MASK_WAKE_MAX_F2F_8821C) << BIT_SHIFT_WAKE_MAX_F2F_8821C)
#define BITS_WAKE_MAX_F2F_8821C \
(BIT_MASK_WAKE_MAX_F2F_8821C << BIT_SHIFT_WAKE_MAX_F2F_8821C)
#define BIT_CLEAR_WAKE_MAX_F2F_8821C(x) ((x) & (~BITS_WAKE_MAX_F2F_8821C))
#define BIT_GET_WAKE_MAX_F2F_8821C(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_F2F_8821C) & BIT_MASK_WAKE_MAX_F2F_8821C)
#define BIT_SET_WAKE_MAX_F2F_8821C(x, v) \
(BIT_CLEAR_WAKE_MAX_F2F_8821C(x) | BIT_WAKE_MAX_F2F_8821C(v))
#define BIT_SHIFT_WAKE_MIN_F2F_8821C 8
#define BIT_MASK_WAKE_MIN_F2F_8821C 0x7
#define BIT_WAKE_MIN_F2F_8821C(x) \
(((x) & BIT_MASK_WAKE_MIN_F2F_8821C) << BIT_SHIFT_WAKE_MIN_F2F_8821C)
#define BITS_WAKE_MIN_F2F_8821C \
(BIT_MASK_WAKE_MIN_F2F_8821C << BIT_SHIFT_WAKE_MIN_F2F_8821C)
#define BIT_CLEAR_WAKE_MIN_F2F_8821C(x) ((x) & (~BITS_WAKE_MIN_F2F_8821C))
#define BIT_GET_WAKE_MIN_F2F_8821C(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_F2F_8821C) & BIT_MASK_WAKE_MIN_F2F_8821C)
#define BIT_SET_WAKE_MIN_F2F_8821C(x, v) \
(BIT_CLEAR_WAKE_MIN_F2F_8821C(x) | BIT_WAKE_MIN_F2F_8821C(v))
#define BIT_APP_CPU_ACT_V1_8821C BIT(3)
#define BIT_APP_OBFF_V1_8821C BIT(2)
#define BIT_APP_IDLE_V1_8821C BIT(1)
#define BIT_APP_INIT_V1_8821C BIT(0)
/* 2 REG_OBFF_CTRL2_TIMER_8821C */
#define BIT_SHIFT_RX_HIGH_TIMER_IDX_8821C 24
#define BIT_MASK_RX_HIGH_TIMER_IDX_8821C 0x7
#define BIT_RX_HIGH_TIMER_IDX_8821C(x) \
(((x) & BIT_MASK_RX_HIGH_TIMER_IDX_8821C) \
<< BIT_SHIFT_RX_HIGH_TIMER_IDX_8821C)
#define BITS_RX_HIGH_TIMER_IDX_8821C \
(BIT_MASK_RX_HIGH_TIMER_IDX_8821C << BIT_SHIFT_RX_HIGH_TIMER_IDX_8821C)
#define BIT_CLEAR_RX_HIGH_TIMER_IDX_8821C(x) \
((x) & (~BITS_RX_HIGH_TIMER_IDX_8821C))
#define BIT_GET_RX_HIGH_TIMER_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TIMER_IDX_8821C) & \
BIT_MASK_RX_HIGH_TIMER_IDX_8821C)
#define BIT_SET_RX_HIGH_TIMER_IDX_8821C(x, v) \
(BIT_CLEAR_RX_HIGH_TIMER_IDX_8821C(x) | BIT_RX_HIGH_TIMER_IDX_8821C(v))
#define BIT_SHIFT_RX_MED_TIMER_IDX_8821C 16
#define BIT_MASK_RX_MED_TIMER_IDX_8821C 0x7
#define BIT_RX_MED_TIMER_IDX_8821C(x) \
(((x) & BIT_MASK_RX_MED_TIMER_IDX_8821C) \
<< BIT_SHIFT_RX_MED_TIMER_IDX_8821C)
#define BITS_RX_MED_TIMER_IDX_8821C \
(BIT_MASK_RX_MED_TIMER_IDX_8821C << BIT_SHIFT_RX_MED_TIMER_IDX_8821C)
#define BIT_CLEAR_RX_MED_TIMER_IDX_8821C(x) \
((x) & (~BITS_RX_MED_TIMER_IDX_8821C))
#define BIT_GET_RX_MED_TIMER_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_MED_TIMER_IDX_8821C) & \
BIT_MASK_RX_MED_TIMER_IDX_8821C)
#define BIT_SET_RX_MED_TIMER_IDX_8821C(x, v) \
(BIT_CLEAR_RX_MED_TIMER_IDX_8821C(x) | BIT_RX_MED_TIMER_IDX_8821C(v))
#define BIT_SHIFT_RX_LOW_TIMER_IDX_8821C 8
#define BIT_MASK_RX_LOW_TIMER_IDX_8821C 0x7
#define BIT_RX_LOW_TIMER_IDX_8821C(x) \
(((x) & BIT_MASK_RX_LOW_TIMER_IDX_8821C) \
<< BIT_SHIFT_RX_LOW_TIMER_IDX_8821C)
#define BITS_RX_LOW_TIMER_IDX_8821C \
(BIT_MASK_RX_LOW_TIMER_IDX_8821C << BIT_SHIFT_RX_LOW_TIMER_IDX_8821C)
#define BIT_CLEAR_RX_LOW_TIMER_IDX_8821C(x) \
((x) & (~BITS_RX_LOW_TIMER_IDX_8821C))
#define BIT_GET_RX_LOW_TIMER_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_LOW_TIMER_IDX_8821C) & \
BIT_MASK_RX_LOW_TIMER_IDX_8821C)
#define BIT_SET_RX_LOW_TIMER_IDX_8821C(x, v) \
(BIT_CLEAR_RX_LOW_TIMER_IDX_8821C(x) | BIT_RX_LOW_TIMER_IDX_8821C(v))
#define BIT_SHIFT_OBFF_INT_TIMER_IDX_8821C 0
#define BIT_MASK_OBFF_INT_TIMER_IDX_8821C 0x7
#define BIT_OBFF_INT_TIMER_IDX_8821C(x) \
(((x) & BIT_MASK_OBFF_INT_TIMER_IDX_8821C) \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8821C)
#define BITS_OBFF_INT_TIMER_IDX_8821C \
(BIT_MASK_OBFF_INT_TIMER_IDX_8821C \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8821C)
#define BIT_CLEAR_OBFF_INT_TIMER_IDX_8821C(x) \
((x) & (~BITS_OBFF_INT_TIMER_IDX_8821C))
#define BIT_GET_OBFF_INT_TIMER_IDX_8821C(x) \
(((x) >> BIT_SHIFT_OBFF_INT_TIMER_IDX_8821C) & \
BIT_MASK_OBFF_INT_TIMER_IDX_8821C)
#define BIT_SET_OBFF_INT_TIMER_IDX_8821C(x, v) \
(BIT_CLEAR_OBFF_INT_TIMER_IDX_8821C(x) | \
BIT_OBFF_INT_TIMER_IDX_8821C(v))
/* 2 REG_LTR_CTRL_BASIC_8821C */
#define BIT_LTR_EN_V1_8821C BIT(31)
#define BIT_LTR_HW_EN_V1_8821C BIT(30)
#define BIT_LRT_ACT_CTS_EN_8821C BIT(29)
#define BIT_LTR_ACT_RXPKT_EN_8821C BIT(28)
#define BIT_LTR_ACT_RXDMA_EN_8821C BIT(27)
#define BIT_LTR_IDLE_NO_SNOOP_8821C BIT(26)
#define BIT_SPDUP_MGTPKT_8821C BIT(25)
#define BIT_RX_AGG_EN_8821C BIT(24)
#define BIT_APP_LTR_ACT_8821C BIT(23)
#define BIT_APP_LTR_IDLE_8821C BIT(22)
#define BIT_SHIFT_HIGH_RATE_TRIG_SEL_8821C 20
#define BIT_MASK_HIGH_RATE_TRIG_SEL_8821C 0x3
#define BIT_HIGH_RATE_TRIG_SEL_8821C(x) \
(((x) & BIT_MASK_HIGH_RATE_TRIG_SEL_8821C) \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8821C)
#define BITS_HIGH_RATE_TRIG_SEL_8821C \
(BIT_MASK_HIGH_RATE_TRIG_SEL_8821C \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8821C)
#define BIT_CLEAR_HIGH_RATE_TRIG_SEL_8821C(x) \
((x) & (~BITS_HIGH_RATE_TRIG_SEL_8821C))
#define BIT_GET_HIGH_RATE_TRIG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_TRIG_SEL_8821C) & \
BIT_MASK_HIGH_RATE_TRIG_SEL_8821C)
#define BIT_SET_HIGH_RATE_TRIG_SEL_8821C(x, v) \
(BIT_CLEAR_HIGH_RATE_TRIG_SEL_8821C(x) | \
BIT_HIGH_RATE_TRIG_SEL_8821C(v))
#define BIT_SHIFT_MED_RATE_TRIG_SEL_8821C 18
#define BIT_MASK_MED_RATE_TRIG_SEL_8821C 0x3
#define BIT_MED_RATE_TRIG_SEL_8821C(x) \
(((x) & BIT_MASK_MED_RATE_TRIG_SEL_8821C) \
<< BIT_SHIFT_MED_RATE_TRIG_SEL_8821C)
#define BITS_MED_RATE_TRIG_SEL_8821C \
(BIT_MASK_MED_RATE_TRIG_SEL_8821C << BIT_SHIFT_MED_RATE_TRIG_SEL_8821C)
#define BIT_CLEAR_MED_RATE_TRIG_SEL_8821C(x) \
((x) & (~BITS_MED_RATE_TRIG_SEL_8821C))
#define BIT_GET_MED_RATE_TRIG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_MED_RATE_TRIG_SEL_8821C) & \
BIT_MASK_MED_RATE_TRIG_SEL_8821C)
#define BIT_SET_MED_RATE_TRIG_SEL_8821C(x, v) \
(BIT_CLEAR_MED_RATE_TRIG_SEL_8821C(x) | BIT_MED_RATE_TRIG_SEL_8821C(v))
#define BIT_SHIFT_LOW_RATE_TRIG_SEL_8821C 16
#define BIT_MASK_LOW_RATE_TRIG_SEL_8821C 0x3
#define BIT_LOW_RATE_TRIG_SEL_8821C(x) \
(((x) & BIT_MASK_LOW_RATE_TRIG_SEL_8821C) \
<< BIT_SHIFT_LOW_RATE_TRIG_SEL_8821C)
#define BITS_LOW_RATE_TRIG_SEL_8821C \
(BIT_MASK_LOW_RATE_TRIG_SEL_8821C << BIT_SHIFT_LOW_RATE_TRIG_SEL_8821C)
#define BIT_CLEAR_LOW_RATE_TRIG_SEL_8821C(x) \
((x) & (~BITS_LOW_RATE_TRIG_SEL_8821C))
#define BIT_GET_LOW_RATE_TRIG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_LOW_RATE_TRIG_SEL_8821C) & \
BIT_MASK_LOW_RATE_TRIG_SEL_8821C)
#define BIT_SET_LOW_RATE_TRIG_SEL_8821C(x, v) \
(BIT_CLEAR_LOW_RATE_TRIG_SEL_8821C(x) | BIT_LOW_RATE_TRIG_SEL_8821C(v))
#define BIT_SHIFT_HIGH_RATE_BD_IDX_8821C 8
#define BIT_MASK_HIGH_RATE_BD_IDX_8821C 0x7f
#define BIT_HIGH_RATE_BD_IDX_8821C(x) \
(((x) & BIT_MASK_HIGH_RATE_BD_IDX_8821C) \
<< BIT_SHIFT_HIGH_RATE_BD_IDX_8821C)
#define BITS_HIGH_RATE_BD_IDX_8821C \
(BIT_MASK_HIGH_RATE_BD_IDX_8821C << BIT_SHIFT_HIGH_RATE_BD_IDX_8821C)
#define BIT_CLEAR_HIGH_RATE_BD_IDX_8821C(x) \
((x) & (~BITS_HIGH_RATE_BD_IDX_8821C))
#define BIT_GET_HIGH_RATE_BD_IDX_8821C(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_BD_IDX_8821C) & \
BIT_MASK_HIGH_RATE_BD_IDX_8821C)
#define BIT_SET_HIGH_RATE_BD_IDX_8821C(x, v) \
(BIT_CLEAR_HIGH_RATE_BD_IDX_8821C(x) | BIT_HIGH_RATE_BD_IDX_8821C(v))
#define BIT_SHIFT_LOW_RATE_BD_IDX_8821C 0
#define BIT_MASK_LOW_RATE_BD_IDX_8821C 0x7f
#define BIT_LOW_RATE_BD_IDX_8821C(x) \
(((x) & BIT_MASK_LOW_RATE_BD_IDX_8821C) \
<< BIT_SHIFT_LOW_RATE_BD_IDX_8821C)
#define BITS_LOW_RATE_BD_IDX_8821C \
(BIT_MASK_LOW_RATE_BD_IDX_8821C << BIT_SHIFT_LOW_RATE_BD_IDX_8821C)
#define BIT_CLEAR_LOW_RATE_BD_IDX_8821C(x) ((x) & (~BITS_LOW_RATE_BD_IDX_8821C))
#define BIT_GET_LOW_RATE_BD_IDX_8821C(x) \
(((x) >> BIT_SHIFT_LOW_RATE_BD_IDX_8821C) & \
BIT_MASK_LOW_RATE_BD_IDX_8821C)
#define BIT_SET_LOW_RATE_BD_IDX_8821C(x, v) \
(BIT_CLEAR_LOW_RATE_BD_IDX_8821C(x) | BIT_LOW_RATE_BD_IDX_8821C(v))
/* 2 REG_LTR_CTRL2_TIMER_THRESHOLD_8821C */
#define BIT_SHIFT_RX_EMPTY_TIMER_IDX_8821C 24
#define BIT_MASK_RX_EMPTY_TIMER_IDX_8821C 0x7
#define BIT_RX_EMPTY_TIMER_IDX_8821C(x) \
(((x) & BIT_MASK_RX_EMPTY_TIMER_IDX_8821C) \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8821C)
#define BITS_RX_EMPTY_TIMER_IDX_8821C \
(BIT_MASK_RX_EMPTY_TIMER_IDX_8821C \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8821C)
#define BIT_CLEAR_RX_EMPTY_TIMER_IDX_8821C(x) \
((x) & (~BITS_RX_EMPTY_TIMER_IDX_8821C))
#define BIT_GET_RX_EMPTY_TIMER_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_EMPTY_TIMER_IDX_8821C) & \
BIT_MASK_RX_EMPTY_TIMER_IDX_8821C)
#define BIT_SET_RX_EMPTY_TIMER_IDX_8821C(x, v) \
(BIT_CLEAR_RX_EMPTY_TIMER_IDX_8821C(x) | \
BIT_RX_EMPTY_TIMER_IDX_8821C(v))
#define BIT_SHIFT_RX_AFULL_TH_IDX_8821C 20
#define BIT_MASK_RX_AFULL_TH_IDX_8821C 0x7
#define BIT_RX_AFULL_TH_IDX_8821C(x) \
(((x) & BIT_MASK_RX_AFULL_TH_IDX_8821C) \
<< BIT_SHIFT_RX_AFULL_TH_IDX_8821C)
#define BITS_RX_AFULL_TH_IDX_8821C \
(BIT_MASK_RX_AFULL_TH_IDX_8821C << BIT_SHIFT_RX_AFULL_TH_IDX_8821C)
#define BIT_CLEAR_RX_AFULL_TH_IDX_8821C(x) ((x) & (~BITS_RX_AFULL_TH_IDX_8821C))
#define BIT_GET_RX_AFULL_TH_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_AFULL_TH_IDX_8821C) & \
BIT_MASK_RX_AFULL_TH_IDX_8821C)
#define BIT_SET_RX_AFULL_TH_IDX_8821C(x, v) \
(BIT_CLEAR_RX_AFULL_TH_IDX_8821C(x) | BIT_RX_AFULL_TH_IDX_8821C(v))
#define BIT_SHIFT_RX_HIGH_TH_IDX_8821C 16
#define BIT_MASK_RX_HIGH_TH_IDX_8821C 0x7
#define BIT_RX_HIGH_TH_IDX_8821C(x) \
(((x) & BIT_MASK_RX_HIGH_TH_IDX_8821C) \
<< BIT_SHIFT_RX_HIGH_TH_IDX_8821C)
#define BITS_RX_HIGH_TH_IDX_8821C \
(BIT_MASK_RX_HIGH_TH_IDX_8821C << BIT_SHIFT_RX_HIGH_TH_IDX_8821C)
#define BIT_CLEAR_RX_HIGH_TH_IDX_8821C(x) ((x) & (~BITS_RX_HIGH_TH_IDX_8821C))
#define BIT_GET_RX_HIGH_TH_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TH_IDX_8821C) & \
BIT_MASK_RX_HIGH_TH_IDX_8821C)
#define BIT_SET_RX_HIGH_TH_IDX_8821C(x, v) \
(BIT_CLEAR_RX_HIGH_TH_IDX_8821C(x) | BIT_RX_HIGH_TH_IDX_8821C(v))
#define BIT_SHIFT_RX_MED_TH_IDX_8821C 12
#define BIT_MASK_RX_MED_TH_IDX_8821C 0x7
#define BIT_RX_MED_TH_IDX_8821C(x) \
(((x) & BIT_MASK_RX_MED_TH_IDX_8821C) << BIT_SHIFT_RX_MED_TH_IDX_8821C)
#define BITS_RX_MED_TH_IDX_8821C \
(BIT_MASK_RX_MED_TH_IDX_8821C << BIT_SHIFT_RX_MED_TH_IDX_8821C)
#define BIT_CLEAR_RX_MED_TH_IDX_8821C(x) ((x) & (~BITS_RX_MED_TH_IDX_8821C))
#define BIT_GET_RX_MED_TH_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_MED_TH_IDX_8821C) & BIT_MASK_RX_MED_TH_IDX_8821C)
#define BIT_SET_RX_MED_TH_IDX_8821C(x, v) \
(BIT_CLEAR_RX_MED_TH_IDX_8821C(x) | BIT_RX_MED_TH_IDX_8821C(v))
#define BIT_SHIFT_RX_LOW_TH_IDX_8821C 8
#define BIT_MASK_RX_LOW_TH_IDX_8821C 0x7
#define BIT_RX_LOW_TH_IDX_8821C(x) \
(((x) & BIT_MASK_RX_LOW_TH_IDX_8821C) << BIT_SHIFT_RX_LOW_TH_IDX_8821C)
#define BITS_RX_LOW_TH_IDX_8821C \
(BIT_MASK_RX_LOW_TH_IDX_8821C << BIT_SHIFT_RX_LOW_TH_IDX_8821C)
#define BIT_CLEAR_RX_LOW_TH_IDX_8821C(x) ((x) & (~BITS_RX_LOW_TH_IDX_8821C))
#define BIT_GET_RX_LOW_TH_IDX_8821C(x) \
(((x) >> BIT_SHIFT_RX_LOW_TH_IDX_8821C) & BIT_MASK_RX_LOW_TH_IDX_8821C)
#define BIT_SET_RX_LOW_TH_IDX_8821C(x, v) \
(BIT_CLEAR_RX_LOW_TH_IDX_8821C(x) | BIT_RX_LOW_TH_IDX_8821C(v))
#define BIT_SHIFT_LTR_SPACE_IDX_8821C 4
#define BIT_MASK_LTR_SPACE_IDX_8821C 0x3
#define BIT_LTR_SPACE_IDX_8821C(x) \
(((x) & BIT_MASK_LTR_SPACE_IDX_8821C) << BIT_SHIFT_LTR_SPACE_IDX_8821C)
#define BITS_LTR_SPACE_IDX_8821C \
(BIT_MASK_LTR_SPACE_IDX_8821C << BIT_SHIFT_LTR_SPACE_IDX_8821C)
#define BIT_CLEAR_LTR_SPACE_IDX_8821C(x) ((x) & (~BITS_LTR_SPACE_IDX_8821C))
#define BIT_GET_LTR_SPACE_IDX_8821C(x) \
(((x) >> BIT_SHIFT_LTR_SPACE_IDX_8821C) & BIT_MASK_LTR_SPACE_IDX_8821C)
#define BIT_SET_LTR_SPACE_IDX_8821C(x, v) \
(BIT_CLEAR_LTR_SPACE_IDX_8821C(x) | BIT_LTR_SPACE_IDX_8821C(v))
#define BIT_SHIFT_LTR_IDLE_TIMER_IDX_8821C 0
#define BIT_MASK_LTR_IDLE_TIMER_IDX_8821C 0x7
#define BIT_LTR_IDLE_TIMER_IDX_8821C(x) \
(((x) & BIT_MASK_LTR_IDLE_TIMER_IDX_8821C) \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8821C)
#define BITS_LTR_IDLE_TIMER_IDX_8821C \
(BIT_MASK_LTR_IDLE_TIMER_IDX_8821C \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8821C)
#define BIT_CLEAR_LTR_IDLE_TIMER_IDX_8821C(x) \
((x) & (~BITS_LTR_IDLE_TIMER_IDX_8821C))
#define BIT_GET_LTR_IDLE_TIMER_IDX_8821C(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_TIMER_IDX_8821C) & \
BIT_MASK_LTR_IDLE_TIMER_IDX_8821C)
#define BIT_SET_LTR_IDLE_TIMER_IDX_8821C(x, v) \
(BIT_CLEAR_LTR_IDLE_TIMER_IDX_8821C(x) | \
BIT_LTR_IDLE_TIMER_IDX_8821C(v))
/* 2 REG_LTR_IDLE_LATENCY_V1_8821C */
#define BIT_SHIFT_LTR_IDLE_L_8821C 0
#define BIT_MASK_LTR_IDLE_L_8821C 0xffffffffL
#define BIT_LTR_IDLE_L_8821C(x) \
(((x) & BIT_MASK_LTR_IDLE_L_8821C) << BIT_SHIFT_LTR_IDLE_L_8821C)
#define BITS_LTR_IDLE_L_8821C \
(BIT_MASK_LTR_IDLE_L_8821C << BIT_SHIFT_LTR_IDLE_L_8821C)
#define BIT_CLEAR_LTR_IDLE_L_8821C(x) ((x) & (~BITS_LTR_IDLE_L_8821C))
#define BIT_GET_LTR_IDLE_L_8821C(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_L_8821C) & BIT_MASK_LTR_IDLE_L_8821C)
#define BIT_SET_LTR_IDLE_L_8821C(x, v) \
(BIT_CLEAR_LTR_IDLE_L_8821C(x) | BIT_LTR_IDLE_L_8821C(v))
/* 2 REG_LTR_ACTIVE_LATENCY_V1_8821C */
#define BIT_SHIFT_LTR_ACT_L_8821C 0
#define BIT_MASK_LTR_ACT_L_8821C 0xffffffffL
#define BIT_LTR_ACT_L_8821C(x) \
(((x) & BIT_MASK_LTR_ACT_L_8821C) << BIT_SHIFT_LTR_ACT_L_8821C)
#define BITS_LTR_ACT_L_8821C \
(BIT_MASK_LTR_ACT_L_8821C << BIT_SHIFT_LTR_ACT_L_8821C)
#define BIT_CLEAR_LTR_ACT_L_8821C(x) ((x) & (~BITS_LTR_ACT_L_8821C))
#define BIT_GET_LTR_ACT_L_8821C(x) \
(((x) >> BIT_SHIFT_LTR_ACT_L_8821C) & BIT_MASK_LTR_ACT_L_8821C)
#define BIT_SET_LTR_ACT_L_8821C(x, v) \
(BIT_CLEAR_LTR_ACT_L_8821C(x) | BIT_LTR_ACT_L_8821C(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_8821C */
#define BIT_SHIFT_TRAIN_STA_ADDR_0_8821C 0
#define BIT_MASK_TRAIN_STA_ADDR_0_8821C 0xffffffffL
#define BIT_TRAIN_STA_ADDR_0_8821C(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_0_8821C) \
<< BIT_SHIFT_TRAIN_STA_ADDR_0_8821C)
#define BITS_TRAIN_STA_ADDR_0_8821C \
(BIT_MASK_TRAIN_STA_ADDR_0_8821C << BIT_SHIFT_TRAIN_STA_ADDR_0_8821C)
#define BIT_CLEAR_TRAIN_STA_ADDR_0_8821C(x) \
((x) & (~BITS_TRAIN_STA_ADDR_0_8821C))
#define BIT_GET_TRAIN_STA_ADDR_0_8821C(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_0_8821C) & \
BIT_MASK_TRAIN_STA_ADDR_0_8821C)
#define BIT_SET_TRAIN_STA_ADDR_0_8821C(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_0_8821C(x) | BIT_TRAIN_STA_ADDR_0_8821C(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_1_8821C */
#define BIT_APPEND_MACID_IN_RESP_EN_1_8821C BIT(18)
#define BIT_ADDR2_MATCH_EN_1_8821C BIT(17)
#define BIT_ANTTRN_EN_1_8821C BIT(16)
#define BIT_SHIFT_TRAIN_STA_ADDR_1_8821C 0
#define BIT_MASK_TRAIN_STA_ADDR_1_8821C 0xffff
#define BIT_TRAIN_STA_ADDR_1_8821C(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_1_8821C) \
<< BIT_SHIFT_TRAIN_STA_ADDR_1_8821C)
#define BITS_TRAIN_STA_ADDR_1_8821C \
(BIT_MASK_TRAIN_STA_ADDR_1_8821C << BIT_SHIFT_TRAIN_STA_ADDR_1_8821C)
#define BIT_CLEAR_TRAIN_STA_ADDR_1_8821C(x) \
((x) & (~BITS_TRAIN_STA_ADDR_1_8821C))
#define BIT_GET_TRAIN_STA_ADDR_1_8821C(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_1_8821C) & \
BIT_MASK_TRAIN_STA_ADDR_1_8821C)
#define BIT_SET_TRAIN_STA_ADDR_1_8821C(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_1_8821C(x) | BIT_TRAIN_STA_ADDR_1_8821C(v))
/* 2 REG_WMAC_PKTCNT_RWD_8821C */
#define BIT_SHIFT_PKTCNT_BSSIDMAP_8821C 4
#define BIT_MASK_PKTCNT_BSSIDMAP_8821C 0xf
#define BIT_PKTCNT_BSSIDMAP_8821C(x) \
(((x) & BIT_MASK_PKTCNT_BSSIDMAP_8821C) \
<< BIT_SHIFT_PKTCNT_BSSIDMAP_8821C)
#define BITS_PKTCNT_BSSIDMAP_8821C \
(BIT_MASK_PKTCNT_BSSIDMAP_8821C << BIT_SHIFT_PKTCNT_BSSIDMAP_8821C)
#define BIT_CLEAR_PKTCNT_BSSIDMAP_8821C(x) ((x) & (~BITS_PKTCNT_BSSIDMAP_8821C))
#define BIT_GET_PKTCNT_BSSIDMAP_8821C(x) \
(((x) >> BIT_SHIFT_PKTCNT_BSSIDMAP_8821C) & \
BIT_MASK_PKTCNT_BSSIDMAP_8821C)
#define BIT_SET_PKTCNT_BSSIDMAP_8821C(x, v) \
(BIT_CLEAR_PKTCNT_BSSIDMAP_8821C(x) | BIT_PKTCNT_BSSIDMAP_8821C(v))
#define BIT_PKTCNT_CNTRST_8821C BIT(1)
#define BIT_PKTCNT_CNTEN_8821C BIT(0)
/* 2 REG_WMAC_PKTCNT_CTRL_8821C */
#define BIT_WMAC_PKTCNT_TRST_8821C BIT(9)
#define BIT_WMAC_PKTCNT_FEN_8821C BIT(8)
#define BIT_SHIFT_WMAC_PKTCNT_CFGAD_8821C 0
#define BIT_MASK_WMAC_PKTCNT_CFGAD_8821C 0xff
#define BIT_WMAC_PKTCNT_CFGAD_8821C(x) \
(((x) & BIT_MASK_WMAC_PKTCNT_CFGAD_8821C) \
<< BIT_SHIFT_WMAC_PKTCNT_CFGAD_8821C)
#define BITS_WMAC_PKTCNT_CFGAD_8821C \
(BIT_MASK_WMAC_PKTCNT_CFGAD_8821C << BIT_SHIFT_WMAC_PKTCNT_CFGAD_8821C)
#define BIT_CLEAR_WMAC_PKTCNT_CFGAD_8821C(x) \
((x) & (~BITS_WMAC_PKTCNT_CFGAD_8821C))
#define BIT_GET_WMAC_PKTCNT_CFGAD_8821C(x) \
(((x) >> BIT_SHIFT_WMAC_PKTCNT_CFGAD_8821C) & \
BIT_MASK_WMAC_PKTCNT_CFGAD_8821C)
#define BIT_SET_WMAC_PKTCNT_CFGAD_8821C(x, v) \
(BIT_CLEAR_WMAC_PKTCNT_CFGAD_8821C(x) | BIT_WMAC_PKTCNT_CFGAD_8821C(v))
/* 2 REG_IQ_DUMP_8821C */
#define BIT_SHIFT_DUMP_OK_ADDR_8821C 16
#define BIT_MASK_DUMP_OK_ADDR_8821C 0xffff
#define BIT_DUMP_OK_ADDR_8821C(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR_8821C) << BIT_SHIFT_DUMP_OK_ADDR_8821C)
#define BITS_DUMP_OK_ADDR_8821C \
(BIT_MASK_DUMP_OK_ADDR_8821C << BIT_SHIFT_DUMP_OK_ADDR_8821C)
#define BIT_CLEAR_DUMP_OK_ADDR_8821C(x) ((x) & (~BITS_DUMP_OK_ADDR_8821C))
#define BIT_GET_DUMP_OK_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR_8821C) & BIT_MASK_DUMP_OK_ADDR_8821C)
#define BIT_SET_DUMP_OK_ADDR_8821C(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR_8821C(x) | BIT_DUMP_OK_ADDR_8821C(v))
#define BIT_SHIFT_R_TRIG_TIME_SEL_8821C 8
#define BIT_MASK_R_TRIG_TIME_SEL_8821C 0x7f
#define BIT_R_TRIG_TIME_SEL_8821C(x) \
(((x) & BIT_MASK_R_TRIG_TIME_SEL_8821C) \
<< BIT_SHIFT_R_TRIG_TIME_SEL_8821C)
#define BITS_R_TRIG_TIME_SEL_8821C \
(BIT_MASK_R_TRIG_TIME_SEL_8821C << BIT_SHIFT_R_TRIG_TIME_SEL_8821C)
#define BIT_CLEAR_R_TRIG_TIME_SEL_8821C(x) ((x) & (~BITS_R_TRIG_TIME_SEL_8821C))
#define BIT_GET_R_TRIG_TIME_SEL_8821C(x) \
(((x) >> BIT_SHIFT_R_TRIG_TIME_SEL_8821C) & \
BIT_MASK_R_TRIG_TIME_SEL_8821C)
#define BIT_SET_R_TRIG_TIME_SEL_8821C(x, v) \
(BIT_CLEAR_R_TRIG_TIME_SEL_8821C(x) | BIT_R_TRIG_TIME_SEL_8821C(v))
#define BIT_SHIFT_R_MAC_TRIG_SEL_8821C 6
#define BIT_MASK_R_MAC_TRIG_SEL_8821C 0x3
#define BIT_R_MAC_TRIG_SEL_8821C(x) \
(((x) & BIT_MASK_R_MAC_TRIG_SEL_8821C) \
<< BIT_SHIFT_R_MAC_TRIG_SEL_8821C)
#define BITS_R_MAC_TRIG_SEL_8821C \
(BIT_MASK_R_MAC_TRIG_SEL_8821C << BIT_SHIFT_R_MAC_TRIG_SEL_8821C)
#define BIT_CLEAR_R_MAC_TRIG_SEL_8821C(x) ((x) & (~BITS_R_MAC_TRIG_SEL_8821C))
#define BIT_GET_R_MAC_TRIG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_R_MAC_TRIG_SEL_8821C) & \
BIT_MASK_R_MAC_TRIG_SEL_8821C)
#define BIT_SET_R_MAC_TRIG_SEL_8821C(x, v) \
(BIT_CLEAR_R_MAC_TRIG_SEL_8821C(x) | BIT_R_MAC_TRIG_SEL_8821C(v))
#define BIT_MAC_TRIG_REG_8821C BIT(5)
#define BIT_SHIFT_R_LEVEL_PULSE_SEL_8821C 3
#define BIT_MASK_R_LEVEL_PULSE_SEL_8821C 0x3
#define BIT_R_LEVEL_PULSE_SEL_8821C(x) \
(((x) & BIT_MASK_R_LEVEL_PULSE_SEL_8821C) \
<< BIT_SHIFT_R_LEVEL_PULSE_SEL_8821C)
#define BITS_R_LEVEL_PULSE_SEL_8821C \
(BIT_MASK_R_LEVEL_PULSE_SEL_8821C << BIT_SHIFT_R_LEVEL_PULSE_SEL_8821C)
#define BIT_CLEAR_R_LEVEL_PULSE_SEL_8821C(x) \
((x) & (~BITS_R_LEVEL_PULSE_SEL_8821C))
#define BIT_GET_R_LEVEL_PULSE_SEL_8821C(x) \
(((x) >> BIT_SHIFT_R_LEVEL_PULSE_SEL_8821C) & \
BIT_MASK_R_LEVEL_PULSE_SEL_8821C)
#define BIT_SET_R_LEVEL_PULSE_SEL_8821C(x, v) \
(BIT_CLEAR_R_LEVEL_PULSE_SEL_8821C(x) | BIT_R_LEVEL_PULSE_SEL_8821C(v))
#define BIT_EN_LA_MAC_8821C BIT(2)
#define BIT_R_EN_IQDUMP_8821C BIT(1)
#define BIT_R_IQDATA_DUMP_8821C BIT(0)
/* 2 REG_IQ_DUMP_1_8821C */
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8821C 0
#define BIT_MASK_R_WMAC_MASK_LA_MAC_1_8821C 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC_1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC_1_8821C) \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8821C)
#define BITS_R_WMAC_MASK_LA_MAC_1_8821C \
(BIT_MASK_R_WMAC_MASK_LA_MAC_1_8821C \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8821C)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC_1_8821C(x) \
((x) & (~BITS_R_WMAC_MASK_LA_MAC_1_8821C))
#define BIT_GET_R_WMAC_MASK_LA_MAC_1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8821C) & \
BIT_MASK_R_WMAC_MASK_LA_MAC_1_8821C)
#define BIT_SET_R_WMAC_MASK_LA_MAC_1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC_1_8821C(x) | \
BIT_R_WMAC_MASK_LA_MAC_1_8821C(v))
/* 2 REG_IQ_DUMP_2_8821C */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8821C 0
#define BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8821C 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC_2_8821C(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8821C) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8821C)
#define BITS_R_WMAC_MATCH_REF_MAC_2_8821C \
(BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8821C \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8821C)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2_8821C(x) \
((x) & (~BITS_R_WMAC_MATCH_REF_MAC_2_8821C))
#define BIT_GET_R_WMAC_MATCH_REF_MAC_2_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8821C) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8821C)
#define BIT_SET_R_WMAC_MATCH_REF_MAC_2_8821C(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2_8821C(x) | \
BIT_R_WMAC_MATCH_REF_MAC_2_8821C(v))
/* 2 REG_WMAC_FTM_CTL_8821C */
#define BIT_RXFTM_TXACK_SC_8821C BIT(6)
#define BIT_RXFTM_TXACK_BW_8821C BIT(5)
#define BIT_RXFTM_EN_8821C BIT(3)
#define BIT_RXFTMREQ_BYDRV_8821C BIT(2)
#define BIT_RXFTMREQ_EN_8821C BIT(1)
#define BIT_FTM_EN_8821C BIT(0)
/* 2 REG_WMAC_IQ_MDPK_FUNC_8821C */
/* 2 REG_WMAC_OPTION_FUNCTION_8821C */
#define BIT_SHIFT_R_OFDM_LEN_8821C 26
#define BIT_MASK_R_OFDM_LEN_8821C 0x3f
#define BIT_R_OFDM_LEN_8821C(x) \
(((x) & BIT_MASK_R_OFDM_LEN_8821C) << BIT_SHIFT_R_OFDM_LEN_8821C)
#define BITS_R_OFDM_LEN_8821C \
(BIT_MASK_R_OFDM_LEN_8821C << BIT_SHIFT_R_OFDM_LEN_8821C)
#define BIT_CLEAR_R_OFDM_LEN_8821C(x) ((x) & (~BITS_R_OFDM_LEN_8821C))
#define BIT_GET_R_OFDM_LEN_8821C(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN_8821C) & BIT_MASK_R_OFDM_LEN_8821C)
#define BIT_SET_R_OFDM_LEN_8821C(x, v) \
(BIT_CLEAR_R_OFDM_LEN_8821C(x) | BIT_R_OFDM_LEN_8821C(v))
#define BIT_SHIFT_R_CCK_LEN_8821C 0
#define BIT_MASK_R_CCK_LEN_8821C 0xffff
#define BIT_R_CCK_LEN_8821C(x) \
(((x) & BIT_MASK_R_CCK_LEN_8821C) << BIT_SHIFT_R_CCK_LEN_8821C)
#define BITS_R_CCK_LEN_8821C \
(BIT_MASK_R_CCK_LEN_8821C << BIT_SHIFT_R_CCK_LEN_8821C)
#define BIT_CLEAR_R_CCK_LEN_8821C(x) ((x) & (~BITS_R_CCK_LEN_8821C))
#define BIT_GET_R_CCK_LEN_8821C(x) \
(((x) >> BIT_SHIFT_R_CCK_LEN_8821C) & BIT_MASK_R_CCK_LEN_8821C)
#define BIT_SET_R_CCK_LEN_8821C(x, v) \
(BIT_CLEAR_R_CCK_LEN_8821C(x) | BIT_R_CCK_LEN_8821C(v))
/* 2 REG_WMAC_OPTION_FUNCTION_1_8821C */
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8821C 24
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8821C 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH_1_8821C(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8821C) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8821C)
#define BITS_R_WMAC_RXFIFO_FULL_TH_1_8821C \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8821C \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8821C)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1_8821C(x) \
((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH_1_8821C))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH_1_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8821C) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8821C)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH_1_8821C(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1_8821C(x) | \
BIT_R_WMAC_RXFIFO_FULL_TH_1_8821C(v))
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC_1_8821C BIT(23)
#define BIT_R_WMAC_RXRST_DLY_1_8821C BIT(22)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP_1_8821C BIT(21)
#define BIT_R_WMAC_SRCH_TXRPT_UA1_1_8821C BIT(20)
#define BIT_R_WMAC_SRCH_TXRPT_TYPE_1_8821C BIT(19)
#define BIT_R_WMAC_NDP_RST_1_8821C BIT(18)
#define BIT_R_WMAC_POWINT_EN_1_8821C BIT(17)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT_1_8821C BIT(16)
#define BIT_R_WMAC_SRCH_TXRPT_MID_1_8821C BIT(15)
#define BIT_R_WMAC_PFIN_TOEN_1_8821C BIT(14)
#define BIT_R_WMAC_FIL_SECERR_1_8821C BIT(13)
#define BIT_R_WMAC_FIL_CTLPKTLEN_1_8821C BIT(12)
#define BIT_R_WMAC_FIL_FCTYPE_1_8821C BIT(11)
#define BIT_R_WMAC_FIL_FCPROVER_1_8821C BIT(10)
#define BIT_R_WMAC_PHYSTS_SNIF_1_8821C BIT(9)
#define BIT_R_WMAC_PHYSTS_PLCP_1_8821C BIT(8)
#define BIT_R_MAC_TCR_VBONF_RD_1_8821C BIT(7)
#define BIT_R_WMAC_TCR_MPAR_NDP_1_8821C BIT(6)
#define BIT_R_WMAC_NDP_FILTER_1_8821C BIT(5)
#define BIT_R_WMAC_RXLEN_SEL_1_8821C BIT(4)
#define BIT_R_WMAC_RXLEN_SEL1_1_8821C BIT(3)
#define BIT_R_OFDM_FILTER_1_8821C BIT(2)
#define BIT_R_WMAC_CHK_OFDM_LEN_1_8821C BIT(1)
#define BIT_R_WMAC_CHK_CCK_LEN_1_8821C BIT(0)
/* 2 REG_WMAC_OPTION_FUNCTION_2_8821C */
#define BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8821C 0
#define BIT_MASK_R_WMAC_RX_FIL_LEN_2_8821C 0xffff
#define BIT_R_WMAC_RX_FIL_LEN_2_8821C(x) \
(((x) & BIT_MASK_R_WMAC_RX_FIL_LEN_2_8821C) \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8821C)
#define BITS_R_WMAC_RX_FIL_LEN_2_8821C \
(BIT_MASK_R_WMAC_RX_FIL_LEN_2_8821C \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8821C)
#define BIT_CLEAR_R_WMAC_RX_FIL_LEN_2_8821C(x) \
((x) & (~BITS_R_WMAC_RX_FIL_LEN_2_8821C))
#define BIT_GET_R_WMAC_RX_FIL_LEN_2_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8821C) & \
BIT_MASK_R_WMAC_RX_FIL_LEN_2_8821C)
#define BIT_SET_R_WMAC_RX_FIL_LEN_2_8821C(x, v) \
(BIT_CLEAR_R_WMAC_RX_FIL_LEN_2_8821C(x) | \
BIT_R_WMAC_RX_FIL_LEN_2_8821C(v))
/* 2 REG_RX_FILTER_FUNCTION_8821C */
#define BIT_R_WMAC_MHRDDY_LATCH_8821C BIT(14)
#define BIT_R_WMAC_MHRDDY_CLR_8821C BIT(13)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY1_8821C BIT(12)
#define BIT_WMAC_DIS_VHT_PLCP_CHK_MU_8821C BIT(11)
#define BIT_R_CHK_DELIMIT_LEN_8821C BIT(10)
#define BIT_R_REAPTER_ADDR_MATCH_8821C BIT(9)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY_8821C BIT(8)
#define BIT_R_LATCH_MACHRDY_8821C BIT(7)
#define BIT_R_WMAC_RXFIL_REND_8821C BIT(6)
#define BIT_R_WMAC_MPDURDY_CLR_8821C BIT(5)
#define BIT_R_WMAC_CLRRXSEC_8821C BIT(4)
#define BIT_R_WMAC_RXFIL_RDEL_8821C BIT(3)
#define BIT_R_WMAC_RXFIL_FCSE_8821C BIT(2)
#define BIT_R_WMAC_RXFIL_MESH_DEL_8821C BIT(1)
#define BIT_R_WMAC_RXFIL_MASKM_8821C BIT(0)
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NDP_SIG_8821C */
#define BIT_SHIFT_R_WMAC_TXNDP_SIGB_8821C 0
#define BIT_MASK_R_WMAC_TXNDP_SIGB_8821C 0x1fffff
#define BIT_R_WMAC_TXNDP_SIGB_8821C(x) \
(((x) & BIT_MASK_R_WMAC_TXNDP_SIGB_8821C) \
<< BIT_SHIFT_R_WMAC_TXNDP_SIGB_8821C)
#define BITS_R_WMAC_TXNDP_SIGB_8821C \
(BIT_MASK_R_WMAC_TXNDP_SIGB_8821C << BIT_SHIFT_R_WMAC_TXNDP_SIGB_8821C)
#define BIT_CLEAR_R_WMAC_TXNDP_SIGB_8821C(x) \
((x) & (~BITS_R_WMAC_TXNDP_SIGB_8821C))
#define BIT_GET_R_WMAC_TXNDP_SIGB_8821C(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXNDP_SIGB_8821C) & \
BIT_MASK_R_WMAC_TXNDP_SIGB_8821C)
#define BIT_SET_R_WMAC_TXNDP_SIGB_8821C(x, v) \
(BIT_CLEAR_R_WMAC_TXNDP_SIGB_8821C(x) | BIT_R_WMAC_TXNDP_SIGB_8821C(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_8821C */
#define BIT_SHIFT_R_MAC_DBG_SHIFT_8821C 8
#define BIT_MASK_R_MAC_DBG_SHIFT_8821C 0x7
#define BIT_R_MAC_DBG_SHIFT_8821C(x) \
(((x) & BIT_MASK_R_MAC_DBG_SHIFT_8821C) \
<< BIT_SHIFT_R_MAC_DBG_SHIFT_8821C)
#define BITS_R_MAC_DBG_SHIFT_8821C \
(BIT_MASK_R_MAC_DBG_SHIFT_8821C << BIT_SHIFT_R_MAC_DBG_SHIFT_8821C)
#define BIT_CLEAR_R_MAC_DBG_SHIFT_8821C(x) ((x) & (~BITS_R_MAC_DBG_SHIFT_8821C))
#define BIT_GET_R_MAC_DBG_SHIFT_8821C(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SHIFT_8821C) & \
BIT_MASK_R_MAC_DBG_SHIFT_8821C)
#define BIT_SET_R_MAC_DBG_SHIFT_8821C(x, v) \
(BIT_CLEAR_R_MAC_DBG_SHIFT_8821C(x) | BIT_R_MAC_DBG_SHIFT_8821C(v))
#define BIT_SHIFT_R_MAC_DBG_SEL_8821C 0
#define BIT_MASK_R_MAC_DBG_SEL_8821C 0x3
#define BIT_R_MAC_DBG_SEL_8821C(x) \
(((x) & BIT_MASK_R_MAC_DBG_SEL_8821C) << BIT_SHIFT_R_MAC_DBG_SEL_8821C)
#define BITS_R_MAC_DBG_SEL_8821C \
(BIT_MASK_R_MAC_DBG_SEL_8821C << BIT_SHIFT_R_MAC_DBG_SEL_8821C)
#define BIT_CLEAR_R_MAC_DBG_SEL_8821C(x) ((x) & (~BITS_R_MAC_DBG_SEL_8821C))
#define BIT_GET_R_MAC_DBG_SEL_8821C(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SEL_8821C) & BIT_MASK_R_MAC_DBG_SEL_8821C)
#define BIT_SET_R_MAC_DBG_SEL_8821C(x, v) \
(BIT_CLEAR_R_MAC_DBG_SEL_8821C(x) | BIT_R_MAC_DBG_SEL_8821C(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_1_8821C */
#define BIT_SHIFT_R_MAC_DEBUG_1_8821C 0
#define BIT_MASK_R_MAC_DEBUG_1_8821C 0xffffffffL
#define BIT_R_MAC_DEBUG_1_8821C(x) \
(((x) & BIT_MASK_R_MAC_DEBUG_1_8821C) << BIT_SHIFT_R_MAC_DEBUG_1_8821C)
#define BITS_R_MAC_DEBUG_1_8821C \
(BIT_MASK_R_MAC_DEBUG_1_8821C << BIT_SHIFT_R_MAC_DEBUG_1_8821C)
#define BIT_CLEAR_R_MAC_DEBUG_1_8821C(x) ((x) & (~BITS_R_MAC_DEBUG_1_8821C))
#define BIT_GET_R_MAC_DEBUG_1_8821C(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG_1_8821C) & BIT_MASK_R_MAC_DEBUG_1_8821C)
#define BIT_SET_R_MAC_DEBUG_1_8821C(x, v) \
(BIT_CLEAR_R_MAC_DEBUG_1_8821C(x) | BIT_R_MAC_DEBUG_1_8821C(v))
/* 2 REG_WSEC_OPTION_8821C */
#define BIT_RXDEC_BM_MGNT_8821C BIT(22)
#define BIT_TXENC_BM_MGNT_8821C BIT(21)
#define BIT_RXDEC_UNI_MGNT_8821C BIT(20)
#define BIT_TXENC_UNI_MGNT_8821C BIT(19)
/* 2 REG_RTS_ADDRESS_0_8821C */
/* 2 REG_RTS_ADDRESS_0_1_8821C */
/* 2 REG_RTS_ADDRESS_1_8821C */
/* 2 REG_RTS_ADDRESS_1_1_8821C */
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8821C */
#define BIT_LTECOEX_ACCESS_START_V1_8821C BIT(31)
#define BIT_LTECOEX_WRITE_MODE_V1_8821C BIT(30)
#define BIT_LTECOEX_READY_BIT_V1_8821C BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN_V1_8821C 16
#define BIT_MASK_WRITE_BYTE_EN_V1_8821C 0xf
#define BIT_WRITE_BYTE_EN_V1_8821C(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN_V1_8821C) \
<< BIT_SHIFT_WRITE_BYTE_EN_V1_8821C)
#define BITS_WRITE_BYTE_EN_V1_8821C \
(BIT_MASK_WRITE_BYTE_EN_V1_8821C << BIT_SHIFT_WRITE_BYTE_EN_V1_8821C)
#define BIT_CLEAR_WRITE_BYTE_EN_V1_8821C(x) \
((x) & (~BITS_WRITE_BYTE_EN_V1_8821C))
#define BIT_GET_WRITE_BYTE_EN_V1_8821C(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN_V1_8821C) & \
BIT_MASK_WRITE_BYTE_EN_V1_8821C)
#define BIT_SET_WRITE_BYTE_EN_V1_8821C(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN_V1_8821C(x) | BIT_WRITE_BYTE_EN_V1_8821C(v))
#define BIT_SHIFT_LTECOEX_REG_ADDR_V1_8821C 0
#define BIT_MASK_LTECOEX_REG_ADDR_V1_8821C 0xffff
#define BIT_LTECOEX_REG_ADDR_V1_8821C(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR_V1_8821C) \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8821C)
#define BITS_LTECOEX_REG_ADDR_V1_8821C \
(BIT_MASK_LTECOEX_REG_ADDR_V1_8821C \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8821C)
#define BIT_CLEAR_LTECOEX_REG_ADDR_V1_8821C(x) \
((x) & (~BITS_LTECOEX_REG_ADDR_V1_8821C))
#define BIT_GET_LTECOEX_REG_ADDR_V1_8821C(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR_V1_8821C) & \
BIT_MASK_LTECOEX_REG_ADDR_V1_8821C)
#define BIT_SET_LTECOEX_REG_ADDR_V1_8821C(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR_V1_8821C(x) | \
BIT_LTECOEX_REG_ADDR_V1_8821C(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8821C */
#define BIT_SHIFT_LTECOEX_W_DATA_V1_8821C 0
#define BIT_MASK_LTECOEX_W_DATA_V1_8821C 0xffffffffL
#define BIT_LTECOEX_W_DATA_V1_8821C(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA_V1_8821C) \
<< BIT_SHIFT_LTECOEX_W_DATA_V1_8821C)
#define BITS_LTECOEX_W_DATA_V1_8821C \
(BIT_MASK_LTECOEX_W_DATA_V1_8821C << BIT_SHIFT_LTECOEX_W_DATA_V1_8821C)
#define BIT_CLEAR_LTECOEX_W_DATA_V1_8821C(x) \
((x) & (~BITS_LTECOEX_W_DATA_V1_8821C))
#define BIT_GET_LTECOEX_W_DATA_V1_8821C(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA_V1_8821C) & \
BIT_MASK_LTECOEX_W_DATA_V1_8821C)
#define BIT_SET_LTECOEX_W_DATA_V1_8821C(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA_V1_8821C(x) | BIT_LTECOEX_W_DATA_V1_8821C(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8821C */
#define BIT_SHIFT_LTECOEX_R_DATA_V1_8821C 0
#define BIT_MASK_LTECOEX_R_DATA_V1_8821C 0xffffffffL
#define BIT_LTECOEX_R_DATA_V1_8821C(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA_V1_8821C) \
<< BIT_SHIFT_LTECOEX_R_DATA_V1_8821C)
#define BITS_LTECOEX_R_DATA_V1_8821C \
(BIT_MASK_LTECOEX_R_DATA_V1_8821C << BIT_SHIFT_LTECOEX_R_DATA_V1_8821C)
#define BIT_CLEAR_LTECOEX_R_DATA_V1_8821C(x) \
((x) & (~BITS_LTECOEX_R_DATA_V1_8821C))
#define BIT_GET_LTECOEX_R_DATA_V1_8821C(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA_V1_8821C) & \
BIT_MASK_LTECOEX_R_DATA_V1_8821C)
#define BIT_SET_LTECOEX_R_DATA_V1_8821C(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA_V1_8821C(x) | BIT_LTECOEX_R_DATA_V1_8821C(v))
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_NOT_VALID_8821C */
/* 2 REG_SDIO_TX_CTRL_8821C */
#define BIT_SHIFT_SDIO_INT_TIMEOUT_8821C 16
#define BIT_MASK_SDIO_INT_TIMEOUT_8821C 0xffff
#define BIT_SDIO_INT_TIMEOUT_8821C(x) \
(((x) & BIT_MASK_SDIO_INT_TIMEOUT_8821C) \
<< BIT_SHIFT_SDIO_INT_TIMEOUT_8821C)
#define BITS_SDIO_INT_TIMEOUT_8821C \
(BIT_MASK_SDIO_INT_TIMEOUT_8821C << BIT_SHIFT_SDIO_INT_TIMEOUT_8821C)
#define BIT_CLEAR_SDIO_INT_TIMEOUT_8821C(x) \
((x) & (~BITS_SDIO_INT_TIMEOUT_8821C))
#define BIT_GET_SDIO_INT_TIMEOUT_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_INT_TIMEOUT_8821C) & \
BIT_MASK_SDIO_INT_TIMEOUT_8821C)
#define BIT_SET_SDIO_INT_TIMEOUT_8821C(x, v) \
(BIT_CLEAR_SDIO_INT_TIMEOUT_8821C(x) | BIT_SDIO_INT_TIMEOUT_8821C(v))
#define BIT_IO_ERR_STATUS_8821C BIT(15)
#define BIT_REPLY_ERRCRC_IN_DATA_8821C BIT(9)
#define BIT_EN_CMD53_OVERLAP_8821C BIT(8)
#define BIT_REPLY_ERR_IN_R5_8821C BIT(7)
#define BIT_R18A_EN_8821C BIT(6)
#define BIT_SDIO_CMD_FORCE_VLD_8821C BIT(5)
#define BIT_INIT_CMD_EN_8821C BIT(4)
#define BIT_EN_RXDMA_MASK_INT_8821C BIT(2)
#define BIT_EN_MASK_TIMER_8821C BIT(1)
#define BIT_CMD_ERR_STOP_INT_EN_8821C BIT(0)
/* 2 REG_SDIO_HIMR_8821C */
#define BIT_SDIO_CRCERR_MSK_8821C BIT(31)
#define BIT_SDIO_HSISR3_IND_MSK_8821C BIT(30)
#define BIT_SDIO_HSISR2_IND_MSK_8821C BIT(29)
#define BIT_SDIO_HEISR_IND_MSK_8821C BIT(28)
#define BIT_SDIO_CTWEND_MSK_8821C BIT(27)
#define BIT_SDIO_ATIMEND_E_MSK_8821C BIT(26)
#define BIT_SDIIO_ATIMEND_MSK_8821C BIT(25)
#define BIT_SDIO_OCPINT_MSK_8821C BIT(24)
#define BIT_SDIO_PSTIMEOUT_MSK_8821C BIT(23)
#define BIT_SDIO_GTINT4_MSK_8821C BIT(22)
#define BIT_SDIO_GTINT3_MSK_8821C BIT(21)
#define BIT_SDIO_HSISR_IND_MSK_8821C BIT(20)
#define BIT_SDIO_CPWM2_MSK_8821C BIT(19)
#define BIT_SDIO_CPWM1_MSK_8821C BIT(18)
#define BIT_SDIO_C2HCMD_INT_MSK_8821C BIT(17)
#define BIT_SDIO_BCNERLY_INT_MSK_8821C BIT(16)
#define BIT_SDIO_TXBCNERR_MSK_8821C BIT(7)
#define BIT_SDIO_TXBCNOK_MSK_8821C BIT(6)
#define BIT_SDIO_RXFOVW_MSK_8821C BIT(5)
#define BIT_SDIO_TXFOVW_MSK_8821C BIT(4)
#define BIT_SDIO_RXERR_MSK_8821C BIT(3)
#define BIT_SDIO_TXERR_MSK_8821C BIT(2)
#define BIT_SDIO_AVAL_MSK_8821C BIT(1)
#define BIT_RX_REQUEST_MSK_8821C BIT(0)
/* 2 REG_SDIO_HISR_8821C */
#define BIT_SDIO_CRCERR_8821C BIT(31)
#define BIT_SDIO_HSISR3_IND_8821C BIT(30)
#define BIT_SDIO_HSISR2_IND_8821C BIT(29)
#define BIT_SDIO_HEISR_IND_8821C BIT(28)
#define BIT_SDIO_CTWEND_8821C BIT(27)
#define BIT_SDIO_ATIMEND_E_8821C BIT(26)
#define BIT_SDIO_ATIMEND_8821C BIT(25)
#define BIT_SDIO_OCPINT_8821C BIT(24)
#define BIT_SDIO_PSTIMEOUT_8821C BIT(23)
#define BIT_SDIO_GTINT4_8821C BIT(22)
#define BIT_SDIO_GTINT3_8821C BIT(21)
#define BIT_SDIO_HSISR_IND_8821C BIT(20)
#define BIT_SDIO_CPWM2_8821C BIT(19)
#define BIT_SDIO_CPWM1_8821C BIT(18)
#define BIT_SDIO_C2HCMD_INT_8821C BIT(17)
#define BIT_SDIO_BCNERLY_INT_8821C BIT(16)
#define BIT_SDIO_TXBCNERR_8821C BIT(7)
#define BIT_SDIO_TXBCNOK_8821C BIT(6)
#define BIT_SDIO_RXFOVW_8821C BIT(5)
#define BIT_SDIO_TXFOVW_8821C BIT(4)
#define BIT_SDIO_RXERR_8821C BIT(3)
#define BIT_SDIO_TXERR_8821C BIT(2)
#define BIT_SDIO_AVAL_8821C BIT(1)
#define BIT_RX_REQUEST_8821C BIT(0)
/* 2 REG_SDIO_RX_REQ_LEN_8821C */
#define BIT_SHIFT_RX_REQ_LEN_V1_8821C 0
#define BIT_MASK_RX_REQ_LEN_V1_8821C 0x3ffff
#define BIT_RX_REQ_LEN_V1_8821C(x) \
(((x) & BIT_MASK_RX_REQ_LEN_V1_8821C) << BIT_SHIFT_RX_REQ_LEN_V1_8821C)
#define BITS_RX_REQ_LEN_V1_8821C \
(BIT_MASK_RX_REQ_LEN_V1_8821C << BIT_SHIFT_RX_REQ_LEN_V1_8821C)
#define BIT_CLEAR_RX_REQ_LEN_V1_8821C(x) ((x) & (~BITS_RX_REQ_LEN_V1_8821C))
#define BIT_GET_RX_REQ_LEN_V1_8821C(x) \
(((x) >> BIT_SHIFT_RX_REQ_LEN_V1_8821C) & BIT_MASK_RX_REQ_LEN_V1_8821C)
#define BIT_SET_RX_REQ_LEN_V1_8821C(x, v) \
(BIT_CLEAR_RX_REQ_LEN_V1_8821C(x) | BIT_RX_REQ_LEN_V1_8821C(v))
/* 2 REG_SDIO_FREE_TXPG_SEQ_V1_8821C */
#define BIT_SHIFT_FREE_TXPG_SEQ_8821C 0
#define BIT_MASK_FREE_TXPG_SEQ_8821C 0xff
#define BIT_FREE_TXPG_SEQ_8821C(x) \
(((x) & BIT_MASK_FREE_TXPG_SEQ_8821C) << BIT_SHIFT_FREE_TXPG_SEQ_8821C)
#define BITS_FREE_TXPG_SEQ_8821C \
(BIT_MASK_FREE_TXPG_SEQ_8821C << BIT_SHIFT_FREE_TXPG_SEQ_8821C)
#define BIT_CLEAR_FREE_TXPG_SEQ_8821C(x) ((x) & (~BITS_FREE_TXPG_SEQ_8821C))
#define BIT_GET_FREE_TXPG_SEQ_8821C(x) \
(((x) >> BIT_SHIFT_FREE_TXPG_SEQ_8821C) & BIT_MASK_FREE_TXPG_SEQ_8821C)
#define BIT_SET_FREE_TXPG_SEQ_8821C(x, v) \
(BIT_CLEAR_FREE_TXPG_SEQ_8821C(x) | BIT_FREE_TXPG_SEQ_8821C(v))
/* 2 REG_SDIO_FREE_TXPG_8821C */
#define BIT_SHIFT_MID_FREEPG_V1_8821C 16
#define BIT_MASK_MID_FREEPG_V1_8821C 0xfff
#define BIT_MID_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_MID_FREEPG_V1_8821C) << BIT_SHIFT_MID_FREEPG_V1_8821C)
#define BITS_MID_FREEPG_V1_8821C \
(BIT_MASK_MID_FREEPG_V1_8821C << BIT_SHIFT_MID_FREEPG_V1_8821C)
#define BIT_CLEAR_MID_FREEPG_V1_8821C(x) ((x) & (~BITS_MID_FREEPG_V1_8821C))
#define BIT_GET_MID_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_MID_FREEPG_V1_8821C) & BIT_MASK_MID_FREEPG_V1_8821C)
#define BIT_SET_MID_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_MID_FREEPG_V1_8821C(x) | BIT_MID_FREEPG_V1_8821C(v))
#define BIT_SHIFT_HIQ_FREEPG_V1_8821C 0
#define BIT_MASK_HIQ_FREEPG_V1_8821C 0xfff
#define BIT_HIQ_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_HIQ_FREEPG_V1_8821C) << BIT_SHIFT_HIQ_FREEPG_V1_8821C)
#define BITS_HIQ_FREEPG_V1_8821C \
(BIT_MASK_HIQ_FREEPG_V1_8821C << BIT_SHIFT_HIQ_FREEPG_V1_8821C)
#define BIT_CLEAR_HIQ_FREEPG_V1_8821C(x) ((x) & (~BITS_HIQ_FREEPG_V1_8821C))
#define BIT_GET_HIQ_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_HIQ_FREEPG_V1_8821C) & BIT_MASK_HIQ_FREEPG_V1_8821C)
#define BIT_SET_HIQ_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_HIQ_FREEPG_V1_8821C(x) | BIT_HIQ_FREEPG_V1_8821C(v))
/* 2 REG_SDIO_FREE_TXPG2_8821C */
#define BIT_SHIFT_PUB_FREEPG_V1_8821C 16
#define BIT_MASK_PUB_FREEPG_V1_8821C 0xfff
#define BIT_PUB_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_PUB_FREEPG_V1_8821C) << BIT_SHIFT_PUB_FREEPG_V1_8821C)
#define BITS_PUB_FREEPG_V1_8821C \
(BIT_MASK_PUB_FREEPG_V1_8821C << BIT_SHIFT_PUB_FREEPG_V1_8821C)
#define BIT_CLEAR_PUB_FREEPG_V1_8821C(x) ((x) & (~BITS_PUB_FREEPG_V1_8821C))
#define BIT_GET_PUB_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_PUB_FREEPG_V1_8821C) & BIT_MASK_PUB_FREEPG_V1_8821C)
#define BIT_SET_PUB_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_PUB_FREEPG_V1_8821C(x) | BIT_PUB_FREEPG_V1_8821C(v))
#define BIT_SHIFT_LOW_FREEPG_V1_8821C 0
#define BIT_MASK_LOW_FREEPG_V1_8821C 0xfff
#define BIT_LOW_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_LOW_FREEPG_V1_8821C) << BIT_SHIFT_LOW_FREEPG_V1_8821C)
#define BITS_LOW_FREEPG_V1_8821C \
(BIT_MASK_LOW_FREEPG_V1_8821C << BIT_SHIFT_LOW_FREEPG_V1_8821C)
#define BIT_CLEAR_LOW_FREEPG_V1_8821C(x) ((x) & (~BITS_LOW_FREEPG_V1_8821C))
#define BIT_GET_LOW_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_LOW_FREEPG_V1_8821C) & BIT_MASK_LOW_FREEPG_V1_8821C)
#define BIT_SET_LOW_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_LOW_FREEPG_V1_8821C(x) | BIT_LOW_FREEPG_V1_8821C(v))
/* 2 REG_SDIO_OQT_FREE_TXPG_V1_8821C */
#define BIT_SHIFT_NOAC_OQT_FREEPG_V1_8821C 24
#define BIT_MASK_NOAC_OQT_FREEPG_V1_8821C 0xff
#define BIT_NOAC_OQT_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_NOAC_OQT_FREEPG_V1_8821C) \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8821C)
#define BITS_NOAC_OQT_FREEPG_V1_8821C \
(BIT_MASK_NOAC_OQT_FREEPG_V1_8821C \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8821C)
#define BIT_CLEAR_NOAC_OQT_FREEPG_V1_8821C(x) \
((x) & (~BITS_NOAC_OQT_FREEPG_V1_8821C))
#define BIT_GET_NOAC_OQT_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_NOAC_OQT_FREEPG_V1_8821C) & \
BIT_MASK_NOAC_OQT_FREEPG_V1_8821C)
#define BIT_SET_NOAC_OQT_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_NOAC_OQT_FREEPG_V1_8821C(x) | \
BIT_NOAC_OQT_FREEPG_V1_8821C(v))
#define BIT_SHIFT_AC_OQT_FREEPG_V1_8821C 16
#define BIT_MASK_AC_OQT_FREEPG_V1_8821C 0xff
#define BIT_AC_OQT_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_AC_OQT_FREEPG_V1_8821C) \
<< BIT_SHIFT_AC_OQT_FREEPG_V1_8821C)
#define BITS_AC_OQT_FREEPG_V1_8821C \
(BIT_MASK_AC_OQT_FREEPG_V1_8821C << BIT_SHIFT_AC_OQT_FREEPG_V1_8821C)
#define BIT_CLEAR_AC_OQT_FREEPG_V1_8821C(x) \
((x) & (~BITS_AC_OQT_FREEPG_V1_8821C))
#define BIT_GET_AC_OQT_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_AC_OQT_FREEPG_V1_8821C) & \
BIT_MASK_AC_OQT_FREEPG_V1_8821C)
#define BIT_SET_AC_OQT_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_AC_OQT_FREEPG_V1_8821C(x) | BIT_AC_OQT_FREEPG_V1_8821C(v))
#define BIT_SHIFT_EXQ_FREEPG_V1_8821C 0
#define BIT_MASK_EXQ_FREEPG_V1_8821C 0xfff
#define BIT_EXQ_FREEPG_V1_8821C(x) \
(((x) & BIT_MASK_EXQ_FREEPG_V1_8821C) << BIT_SHIFT_EXQ_FREEPG_V1_8821C)
#define BITS_EXQ_FREEPG_V1_8821C \
(BIT_MASK_EXQ_FREEPG_V1_8821C << BIT_SHIFT_EXQ_FREEPG_V1_8821C)
#define BIT_CLEAR_EXQ_FREEPG_V1_8821C(x) ((x) & (~BITS_EXQ_FREEPG_V1_8821C))
#define BIT_GET_EXQ_FREEPG_V1_8821C(x) \
(((x) >> BIT_SHIFT_EXQ_FREEPG_V1_8821C) & BIT_MASK_EXQ_FREEPG_V1_8821C)
#define BIT_SET_EXQ_FREEPG_V1_8821C(x, v) \
(BIT_CLEAR_EXQ_FREEPG_V1_8821C(x) | BIT_EXQ_FREEPG_V1_8821C(v))
/* 2 REG_SDIO_HTSFR_INFO_8821C */
#define BIT_SHIFT_HTSFR1_8821C 16
#define BIT_MASK_HTSFR1_8821C 0xffff
#define BIT_HTSFR1_8821C(x) \
(((x) & BIT_MASK_HTSFR1_8821C) << BIT_SHIFT_HTSFR1_8821C)
#define BITS_HTSFR1_8821C (BIT_MASK_HTSFR1_8821C << BIT_SHIFT_HTSFR1_8821C)
#define BIT_CLEAR_HTSFR1_8821C(x) ((x) & (~BITS_HTSFR1_8821C))
#define BIT_GET_HTSFR1_8821C(x) \
(((x) >> BIT_SHIFT_HTSFR1_8821C) & BIT_MASK_HTSFR1_8821C)
#define BIT_SET_HTSFR1_8821C(x, v) \
(BIT_CLEAR_HTSFR1_8821C(x) | BIT_HTSFR1_8821C(v))
#define BIT_SHIFT_HTSFR0_8821C 0
#define BIT_MASK_HTSFR0_8821C 0xffff
#define BIT_HTSFR0_8821C(x) \
(((x) & BIT_MASK_HTSFR0_8821C) << BIT_SHIFT_HTSFR0_8821C)
#define BITS_HTSFR0_8821C (BIT_MASK_HTSFR0_8821C << BIT_SHIFT_HTSFR0_8821C)
#define BIT_CLEAR_HTSFR0_8821C(x) ((x) & (~BITS_HTSFR0_8821C))
#define BIT_GET_HTSFR0_8821C(x) \
(((x) >> BIT_SHIFT_HTSFR0_8821C) & BIT_MASK_HTSFR0_8821C)
#define BIT_SET_HTSFR0_8821C(x, v) \
(BIT_CLEAR_HTSFR0_8821C(x) | BIT_HTSFR0_8821C(v))
/* 2 REG_SDIO_HCPWM1_V2_8821C */
#define BIT_TOGGLE_8821C BIT(7)
#define BIT_CUR_PS_8821C BIT(0)
/* 2 REG_SDIO_HCPWM2_V2_8821C */
/* 2 REG_SDIO_INDIRECT_REG_CFG_8821C */
#define BIT_INDIRECT_REG_RDY_8821C BIT(20)
#define BIT_INDIRECT_REG_R_8821C BIT(19)
#define BIT_INDIRECT_REG_W_8821C BIT(18)
#define BIT_SHIFT_INDIRECT_REG_SIZE_8821C 16
#define BIT_MASK_INDIRECT_REG_SIZE_8821C 0x3
#define BIT_INDIRECT_REG_SIZE_8821C(x) \
(((x) & BIT_MASK_INDIRECT_REG_SIZE_8821C) \
<< BIT_SHIFT_INDIRECT_REG_SIZE_8821C)
#define BITS_INDIRECT_REG_SIZE_8821C \
(BIT_MASK_INDIRECT_REG_SIZE_8821C << BIT_SHIFT_INDIRECT_REG_SIZE_8821C)
#define BIT_CLEAR_INDIRECT_REG_SIZE_8821C(x) \
((x) & (~BITS_INDIRECT_REG_SIZE_8821C))
#define BIT_GET_INDIRECT_REG_SIZE_8821C(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_SIZE_8821C) & \
BIT_MASK_INDIRECT_REG_SIZE_8821C)
#define BIT_SET_INDIRECT_REG_SIZE_8821C(x, v) \
(BIT_CLEAR_INDIRECT_REG_SIZE_8821C(x) | BIT_INDIRECT_REG_SIZE_8821C(v))
#define BIT_SHIFT_INDIRECT_REG_ADDR_8821C 0
#define BIT_MASK_INDIRECT_REG_ADDR_8821C 0xffff
#define BIT_INDIRECT_REG_ADDR_8821C(x) \
(((x) & BIT_MASK_INDIRECT_REG_ADDR_8821C) \
<< BIT_SHIFT_INDIRECT_REG_ADDR_8821C)
#define BITS_INDIRECT_REG_ADDR_8821C \
(BIT_MASK_INDIRECT_REG_ADDR_8821C << BIT_SHIFT_INDIRECT_REG_ADDR_8821C)
#define BIT_CLEAR_INDIRECT_REG_ADDR_8821C(x) \
((x) & (~BITS_INDIRECT_REG_ADDR_8821C))
#define BIT_GET_INDIRECT_REG_ADDR_8821C(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_ADDR_8821C) & \
BIT_MASK_INDIRECT_REG_ADDR_8821C)
#define BIT_SET_INDIRECT_REG_ADDR_8821C(x, v) \
(BIT_CLEAR_INDIRECT_REG_ADDR_8821C(x) | BIT_INDIRECT_REG_ADDR_8821C(v))
/* 2 REG_SDIO_INDIRECT_REG_DATA_8821C */
#define BIT_SHIFT_INDIRECT_REG_DATA_8821C 0
#define BIT_MASK_INDIRECT_REG_DATA_8821C 0xffffffffL
#define BIT_INDIRECT_REG_DATA_8821C(x) \
(((x) & BIT_MASK_INDIRECT_REG_DATA_8821C) \
<< BIT_SHIFT_INDIRECT_REG_DATA_8821C)
#define BITS_INDIRECT_REG_DATA_8821C \
(BIT_MASK_INDIRECT_REG_DATA_8821C << BIT_SHIFT_INDIRECT_REG_DATA_8821C)
#define BIT_CLEAR_INDIRECT_REG_DATA_8821C(x) \
((x) & (~BITS_INDIRECT_REG_DATA_8821C))
#define BIT_GET_INDIRECT_REG_DATA_8821C(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_DATA_8821C) & \
BIT_MASK_INDIRECT_REG_DATA_8821C)
#define BIT_SET_INDIRECT_REG_DATA_8821C(x, v) \
(BIT_CLEAR_INDIRECT_REG_DATA_8821C(x) | BIT_INDIRECT_REG_DATA_8821C(v))
/* 2 REG_SDIO_H2C_8821C */
#define BIT_SHIFT_SDIO_H2C_MSG_8821C 0
#define BIT_MASK_SDIO_H2C_MSG_8821C 0xffffffffL
#define BIT_SDIO_H2C_MSG_8821C(x) \
(((x) & BIT_MASK_SDIO_H2C_MSG_8821C) << BIT_SHIFT_SDIO_H2C_MSG_8821C)
#define BITS_SDIO_H2C_MSG_8821C \
(BIT_MASK_SDIO_H2C_MSG_8821C << BIT_SHIFT_SDIO_H2C_MSG_8821C)
#define BIT_CLEAR_SDIO_H2C_MSG_8821C(x) ((x) & (~BITS_SDIO_H2C_MSG_8821C))
#define BIT_GET_SDIO_H2C_MSG_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_H2C_MSG_8821C) & BIT_MASK_SDIO_H2C_MSG_8821C)
#define BIT_SET_SDIO_H2C_MSG_8821C(x, v) \
(BIT_CLEAR_SDIO_H2C_MSG_8821C(x) | BIT_SDIO_H2C_MSG_8821C(v))
/* 2 REG_SDIO_C2H_8821C */
#define BIT_SHIFT_SDIO_C2H_MSG_8821C 0
#define BIT_MASK_SDIO_C2H_MSG_8821C 0xffffffffL
#define BIT_SDIO_C2H_MSG_8821C(x) \
(((x) & BIT_MASK_SDIO_C2H_MSG_8821C) << BIT_SHIFT_SDIO_C2H_MSG_8821C)
#define BITS_SDIO_C2H_MSG_8821C \
(BIT_MASK_SDIO_C2H_MSG_8821C << BIT_SHIFT_SDIO_C2H_MSG_8821C)
#define BIT_CLEAR_SDIO_C2H_MSG_8821C(x) ((x) & (~BITS_SDIO_C2H_MSG_8821C))
#define BIT_GET_SDIO_C2H_MSG_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_C2H_MSG_8821C) & BIT_MASK_SDIO_C2H_MSG_8821C)
#define BIT_SET_SDIO_C2H_MSG_8821C(x, v) \
(BIT_CLEAR_SDIO_C2H_MSG_8821C(x) | BIT_SDIO_C2H_MSG_8821C(v))
/* 2 REG_SDIO_HRPWM1_8821C */
#define BIT_TOGGLE_8821C BIT(7)
#define BIT_ACK_8821C BIT(6)
#define BIT_REQ_PS_8821C BIT(0)
/* 2 REG_SDIO_HRPWM2_8821C */
/* 2 REG_SDIO_HPS_CLKR_8821C */
/* 2 REG_SDIO_BUS_CTRL_8821C */
#define BIT_PAD_CLK_XHGE_EN_8821C BIT(3)
#define BIT_INTER_CLK_EN_8821C BIT(2)
#define BIT_EN_RPT_TXCRC_8821C BIT(1)
#define BIT_DIS_RXDMA_STS_8821C BIT(0)
/* 2 REG_SDIO_HSUS_CTRL_8821C */
#define BIT_INTR_CTRL_8821C BIT(4)
#define BIT_SDIO_VOLTAGE_8821C BIT(3)
#define BIT_BYPASS_INIT_8821C BIT(2)
#define BIT_HCI_RESUME_RDY_8821C BIT(1)
#define BIT_HCI_SUS_REQ_8821C BIT(0)
/* 2 REG_SDIO_RESPONSE_TIMER_8821C */
#define BIT_SHIFT_CMDIN_2RESP_TIMER_8821C 0
#define BIT_MASK_CMDIN_2RESP_TIMER_8821C 0xffff
#define BIT_CMDIN_2RESP_TIMER_8821C(x) \
(((x) & BIT_MASK_CMDIN_2RESP_TIMER_8821C) \
<< BIT_SHIFT_CMDIN_2RESP_TIMER_8821C)
#define BITS_CMDIN_2RESP_TIMER_8821C \
(BIT_MASK_CMDIN_2RESP_TIMER_8821C << BIT_SHIFT_CMDIN_2RESP_TIMER_8821C)
#define BIT_CLEAR_CMDIN_2RESP_TIMER_8821C(x) \
((x) & (~BITS_CMDIN_2RESP_TIMER_8821C))
#define BIT_GET_CMDIN_2RESP_TIMER_8821C(x) \
(((x) >> BIT_SHIFT_CMDIN_2RESP_TIMER_8821C) & \
BIT_MASK_CMDIN_2RESP_TIMER_8821C)
#define BIT_SET_CMDIN_2RESP_TIMER_8821C(x, v) \
(BIT_CLEAR_CMDIN_2RESP_TIMER_8821C(x) | BIT_CMDIN_2RESP_TIMER_8821C(v))
/* 2 REG_SDIO_CMD_CRC_8821C */
#define BIT_SHIFT_SDIO_CMD_CRC_V1_8821C 0
#define BIT_MASK_SDIO_CMD_CRC_V1_8821C 0xff
#define BIT_SDIO_CMD_CRC_V1_8821C(x) \
(((x) & BIT_MASK_SDIO_CMD_CRC_V1_8821C) \
<< BIT_SHIFT_SDIO_CMD_CRC_V1_8821C)
#define BITS_SDIO_CMD_CRC_V1_8821C \
(BIT_MASK_SDIO_CMD_CRC_V1_8821C << BIT_SHIFT_SDIO_CMD_CRC_V1_8821C)
#define BIT_CLEAR_SDIO_CMD_CRC_V1_8821C(x) ((x) & (~BITS_SDIO_CMD_CRC_V1_8821C))
#define BIT_GET_SDIO_CMD_CRC_V1_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_CRC_V1_8821C) & \
BIT_MASK_SDIO_CMD_CRC_V1_8821C)
#define BIT_SET_SDIO_CMD_CRC_V1_8821C(x, v) \
(BIT_CLEAR_SDIO_CMD_CRC_V1_8821C(x) | BIT_SDIO_CMD_CRC_V1_8821C(v))
/* 2 REG_SDIO_HSISR_8821C */
#define BIT_DRV_WLAN_INT_CLR_8821C BIT(1)
#define BIT_DRV_WLAN_INT_8821C BIT(0)
/* 2 REG_SDIO_ERR_RPT_8821C */
#define BIT_HR_FF_OVF_8821C BIT(6)
#define BIT_HR_FF_UDN_8821C BIT(5)
#define BIT_TXDMA_BUSY_ERR_8821C BIT(4)
#define BIT_TXDMA_VLD_ERR_8821C BIT(3)
#define BIT_QSEL_UNKNOWN_ERR_8821C BIT(2)
#define BIT_QSEL_MIS_ERR_8821C BIT(1)
#define BIT_SDIO_OVERRD_ERR_8821C BIT(0)
/* 2 REG_SDIO_CMD_ERRCNT_8821C */
#define BIT_SHIFT_CMD_CRC_ERR_CNT_8821C 0
#define BIT_MASK_CMD_CRC_ERR_CNT_8821C 0xff
#define BIT_CMD_CRC_ERR_CNT_8821C(x) \
(((x) & BIT_MASK_CMD_CRC_ERR_CNT_8821C) \
<< BIT_SHIFT_CMD_CRC_ERR_CNT_8821C)
#define BITS_CMD_CRC_ERR_CNT_8821C \
(BIT_MASK_CMD_CRC_ERR_CNT_8821C << BIT_SHIFT_CMD_CRC_ERR_CNT_8821C)
#define BIT_CLEAR_CMD_CRC_ERR_CNT_8821C(x) ((x) & (~BITS_CMD_CRC_ERR_CNT_8821C))
#define BIT_GET_CMD_CRC_ERR_CNT_8821C(x) \
(((x) >> BIT_SHIFT_CMD_CRC_ERR_CNT_8821C) & \
BIT_MASK_CMD_CRC_ERR_CNT_8821C)
#define BIT_SET_CMD_CRC_ERR_CNT_8821C(x, v) \
(BIT_CLEAR_CMD_CRC_ERR_CNT_8821C(x) | BIT_CMD_CRC_ERR_CNT_8821C(v))
/* 2 REG_SDIO_DATA_ERRCNT_8821C */
#define BIT_SHIFT_DATA_CRC_ERR_CNT_8821C 0
#define BIT_MASK_DATA_CRC_ERR_CNT_8821C 0xff
#define BIT_DATA_CRC_ERR_CNT_8821C(x) \
(((x) & BIT_MASK_DATA_CRC_ERR_CNT_8821C) \
<< BIT_SHIFT_DATA_CRC_ERR_CNT_8821C)
#define BITS_DATA_CRC_ERR_CNT_8821C \
(BIT_MASK_DATA_CRC_ERR_CNT_8821C << BIT_SHIFT_DATA_CRC_ERR_CNT_8821C)
#define BIT_CLEAR_DATA_CRC_ERR_CNT_8821C(x) \
((x) & (~BITS_DATA_CRC_ERR_CNT_8821C))
#define BIT_GET_DATA_CRC_ERR_CNT_8821C(x) \
(((x) >> BIT_SHIFT_DATA_CRC_ERR_CNT_8821C) & \
BIT_MASK_DATA_CRC_ERR_CNT_8821C)
#define BIT_SET_DATA_CRC_ERR_CNT_8821C(x, v) \
(BIT_CLEAR_DATA_CRC_ERR_CNT_8821C(x) | BIT_DATA_CRC_ERR_CNT_8821C(v))
/* 2 REG_SDIO_CMD_ERR_CONTENT_8821C */
#define BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8821C 0
#define BIT_MASK_SDIO_CMD_ERR_CONTENT_8821C 0xffffffffffL
#define BIT_SDIO_CMD_ERR_CONTENT_8821C(x) \
(((x) & BIT_MASK_SDIO_CMD_ERR_CONTENT_8821C) \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8821C)
#define BITS_SDIO_CMD_ERR_CONTENT_8821C \
(BIT_MASK_SDIO_CMD_ERR_CONTENT_8821C \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8821C)
#define BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8821C(x) \
((x) & (~BITS_SDIO_CMD_ERR_CONTENT_8821C))
#define BIT_GET_SDIO_CMD_ERR_CONTENT_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8821C) & \
BIT_MASK_SDIO_CMD_ERR_CONTENT_8821C)
#define BIT_SET_SDIO_CMD_ERR_CONTENT_8821C(x, v) \
(BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8821C(x) | \
BIT_SDIO_CMD_ERR_CONTENT_8821C(v))
/* 2 REG_SDIO_CRC_ERR_IDX_8821C */
#define BIT_D3_CRC_ERR_8821C BIT(4)
#define BIT_D2_CRC_ERR_8821C BIT(3)
#define BIT_D1_CRC_ERR_8821C BIT(2)
#define BIT_D0_CRC_ERR_8821C BIT(1)
#define BIT_CMD_CRC_ERR_8821C BIT(0)
/* 2 REG_SDIO_DATA_CRC_8821C */
#define BIT_SHIFT_SDIO_DATA_CRC_8821C 0
#define BIT_MASK_SDIO_DATA_CRC_8821C 0xffff
#define BIT_SDIO_DATA_CRC_8821C(x) \
(((x) & BIT_MASK_SDIO_DATA_CRC_8821C) << BIT_SHIFT_SDIO_DATA_CRC_8821C)
#define BITS_SDIO_DATA_CRC_8821C \
(BIT_MASK_SDIO_DATA_CRC_8821C << BIT_SHIFT_SDIO_DATA_CRC_8821C)
#define BIT_CLEAR_SDIO_DATA_CRC_8821C(x) ((x) & (~BITS_SDIO_DATA_CRC_8821C))
#define BIT_GET_SDIO_DATA_CRC_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_CRC_8821C) & BIT_MASK_SDIO_DATA_CRC_8821C)
#define BIT_SET_SDIO_DATA_CRC_8821C(x, v) \
(BIT_CLEAR_SDIO_DATA_CRC_8821C(x) | BIT_SDIO_DATA_CRC_8821C(v))
/* 2 REG_SDIO_DATA_REPLY_TIME_8821C */
#define BIT_SHIFT_SDIO_DATA_REPLY_TIME_8821C 0
#define BIT_MASK_SDIO_DATA_REPLY_TIME_8821C 0x7
#define BIT_SDIO_DATA_REPLY_TIME_8821C(x) \
(((x) & BIT_MASK_SDIO_DATA_REPLY_TIME_8821C) \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME_8821C)
#define BITS_SDIO_DATA_REPLY_TIME_8821C \
(BIT_MASK_SDIO_DATA_REPLY_TIME_8821C \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME_8821C)
#define BIT_CLEAR_SDIO_DATA_REPLY_TIME_8821C(x) \
((x) & (~BITS_SDIO_DATA_REPLY_TIME_8821C))
#define BIT_GET_SDIO_DATA_REPLY_TIME_8821C(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_REPLY_TIME_8821C) & \
BIT_MASK_SDIO_DATA_REPLY_TIME_8821C)
#define BIT_SET_SDIO_DATA_REPLY_TIME_8821C(x, v) \
(BIT_CLEAR_SDIO_DATA_REPLY_TIME_8821C(x) | \
BIT_SDIO_DATA_REPLY_TIME_8821C(v))
#endif
================================================
FILE: hal/halmac/halmac_bit_8822b.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_BIT_8822B_H
#define __INC_HALMAC_BIT_8822B_H
#define CPU_OPT_WIDTH 0x1F
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SYS_ISO_CTRL_8822B */
#define BIT_PWC_EV12V_8822B BIT(15)
#define BIT_PWC_EV25V_8822B BIT(14)
#define BIT_PA33V_EN_8822B BIT(13)
#define BIT_PA12V_EN_8822B BIT(12)
#define BIT_UA33V_EN_8822B BIT(11)
#define BIT_UA12V_EN_8822B BIT(10)
#define BIT_ISO_RFDIO_8822B BIT(9)
#define BIT_ISO_EB2CORE_8822B BIT(8)
#define BIT_ISO_DIOE_8822B BIT(7)
#define BIT_ISO_WLPON2PP_8822B BIT(6)
#define BIT_ISO_IP2MAC_WA2PP_8822B BIT(5)
#define BIT_ISO_PD2CORE_8822B BIT(4)
#define BIT_ISO_PA2PCIE_8822B BIT(3)
#define BIT_ISO_UD2CORE_8822B BIT(2)
#define BIT_ISO_UA2USB_8822B BIT(1)
#define BIT_ISO_WD2PP_8822B BIT(0)
/* 2 REG_SYS_FUNC_EN_8822B */
#define BIT_FEN_MREGEN_8822B BIT(15)
#define BIT_FEN_HWPDN_8822B BIT(14)
#define BIT_EN_25_1_8822B BIT(13)
#define BIT_FEN_ELDR_8822B BIT(12)
#define BIT_FEN_DCORE_8822B BIT(11)
#define BIT_FEN_CPUEN_8822B BIT(10)
#define BIT_FEN_DIOE_8822B BIT(9)
#define BIT_FEN_PCIED_8822B BIT(8)
#define BIT_FEN_PPLL_8822B BIT(7)
#define BIT_FEN_PCIEA_8822B BIT(6)
#define BIT_FEN_DIO_PCIE_8822B BIT(5)
#define BIT_FEN_USBD_8822B BIT(4)
#define BIT_FEN_UPLL_8822B BIT(3)
#define BIT_FEN_USBA_8822B BIT(2)
#define BIT_FEN_BB_GLB_RSTN_8822B BIT(1)
#define BIT_FEN_BBRSTB_8822B BIT(0)
/* 2 REG_SYS_PW_CTRL_8822B */
#define BIT_SOP_EABM_8822B BIT(31)
#define BIT_SOP_ACKF_8822B BIT(30)
#define BIT_SOP_ERCK_8822B BIT(29)
#define BIT_SOP_ESWR_8822B BIT(28)
#define BIT_SOP_PWMM_8822B BIT(27)
#define BIT_SOP_EECK_8822B BIT(26)
#define BIT_SOP_EXTL_8822B BIT(24)
#define BIT_SYM_OP_RING_12M_8822B BIT(22)
#define BIT_ROP_SWPR_8822B BIT(21)
#define BIT_DIS_HW_LPLDM_8822B BIT(20)
#define BIT_OPT_SWRST_WLMCU_8822B BIT(19)
#define BIT_RDY_SYSPWR_8822B BIT(17)
#define BIT_EN_WLON_8822B BIT(16)
#define BIT_APDM_HPDN_8822B BIT(15)
#define BIT_AFSM_PCIE_SUS_EN_8822B BIT(12)
#define BIT_AFSM_WLSUS_EN_8822B BIT(11)
#define BIT_APFM_SWLPS_8822B BIT(10)
#define BIT_APFM_OFFMAC_8822B BIT(9)
#define BIT_APFN_ONMAC_8822B BIT(8)
#define BIT_CHIP_PDN_EN_8822B BIT(7)
#define BIT_RDY_MACDIS_8822B BIT(6)
#define BIT_RING_CLK_12M_EN_8822B BIT(4)
#define BIT_PFM_WOWL_8822B BIT(3)
#define BIT_PFM_LDKP_8822B BIT(2)
#define BIT_WL_HCI_ALD_8822B BIT(1)
#define BIT_PFM_LDALL_8822B BIT(0)
/* 2 REG_SYS_CLK_CTRL_8822B */
#define BIT_LDO_DUMMY_8822B BIT(15)
#define BIT_CPU_CLK_EN_8822B BIT(14)
#define BIT_SYMREG_CLK_EN_8822B BIT(13)
#define BIT_HCI_CLK_EN_8822B BIT(12)
#define BIT_MAC_CLK_EN_8822B BIT(11)
#define BIT_SEC_CLK_EN_8822B BIT(10)
#define BIT_PHY_SSC_RSTB_8822B BIT(9)
#define BIT_EXT_32K_EN_8822B BIT(8)
#define BIT_WL_CLK_TEST_8822B BIT(7)
#define BIT_OP_SPS_PWM_EN_8822B BIT(6)
#define BIT_LOADER_CLK_EN_8822B BIT(5)
#define BIT_MACSLP_8822B BIT(4)
#define BIT_WAKEPAD_EN_8822B BIT(3)
#define BIT_ROMD16V_EN_8822B BIT(2)
#define BIT_CKANA12M_EN_8822B BIT(1)
#define BIT_CNTD16V_EN_8822B BIT(0)
/* 2 REG_SYS_EEPROM_CTRL_8822B */
#define BIT_SHIFT_VPDIDX_8822B 8
#define BIT_MASK_VPDIDX_8822B 0xff
#define BIT_VPDIDX_8822B(x) \
(((x) & BIT_MASK_VPDIDX_8822B) << BIT_SHIFT_VPDIDX_8822B)
#define BITS_VPDIDX_8822B (BIT_MASK_VPDIDX_8822B << BIT_SHIFT_VPDIDX_8822B)
#define BIT_CLEAR_VPDIDX_8822B(x) ((x) & (~BITS_VPDIDX_8822B))
#define BIT_GET_VPDIDX_8822B(x) \
(((x) >> BIT_SHIFT_VPDIDX_8822B) & BIT_MASK_VPDIDX_8822B)
#define BIT_SET_VPDIDX_8822B(x, v) \
(BIT_CLEAR_VPDIDX_8822B(x) | BIT_VPDIDX_8822B(v))
#define BIT_SHIFT_EEM1_0_8822B 6
#define BIT_MASK_EEM1_0_8822B 0x3
#define BIT_EEM1_0_8822B(x) \
(((x) & BIT_MASK_EEM1_0_8822B) << BIT_SHIFT_EEM1_0_8822B)
#define BITS_EEM1_0_8822B (BIT_MASK_EEM1_0_8822B << BIT_SHIFT_EEM1_0_8822B)
#define BIT_CLEAR_EEM1_0_8822B(x) ((x) & (~BITS_EEM1_0_8822B))
#define BIT_GET_EEM1_0_8822B(x) \
(((x) >> BIT_SHIFT_EEM1_0_8822B) & BIT_MASK_EEM1_0_8822B)
#define BIT_SET_EEM1_0_8822B(x, v) \
(BIT_CLEAR_EEM1_0_8822B(x) | BIT_EEM1_0_8822B(v))
#define BIT_AUTOLOAD_SUS_8822B BIT(5)
#define BIT_EERPOMSEL_8822B BIT(4)
#define BIT_EECS_V1_8822B BIT(3)
#define BIT_EESK_V1_8822B BIT(2)
#define BIT_EEDI_V1_8822B BIT(1)
#define BIT_EEDO_V1_8822B BIT(0)
/* 2 REG_EE_VPD_8822B */
#define BIT_SHIFT_VPD_DATA_8822B 0
#define BIT_MASK_VPD_DATA_8822B 0xffffffffL
#define BIT_VPD_DATA_8822B(x) \
(((x) & BIT_MASK_VPD_DATA_8822B) << BIT_SHIFT_VPD_DATA_8822B)
#define BITS_VPD_DATA_8822B \
(BIT_MASK_VPD_DATA_8822B << BIT_SHIFT_VPD_DATA_8822B)
#define BIT_CLEAR_VPD_DATA_8822B(x) ((x) & (~BITS_VPD_DATA_8822B))
#define BIT_GET_VPD_DATA_8822B(x) \
(((x) >> BIT_SHIFT_VPD_DATA_8822B) & BIT_MASK_VPD_DATA_8822B)
#define BIT_SET_VPD_DATA_8822B(x, v) \
(BIT_CLEAR_VPD_DATA_8822B(x) | BIT_VPD_DATA_8822B(v))
/* 2 REG_SYS_SWR_CTRL1_8822B */
#define BIT_C2_L_BIT0_8822B BIT(31)
#define BIT_SHIFT_C1_L_8822B 29
#define BIT_MASK_C1_L_8822B 0x3
#define BIT_C1_L_8822B(x) (((x) & BIT_MASK_C1_L_8822B) << BIT_SHIFT_C1_L_8822B)
#define BITS_C1_L_8822B (BIT_MASK_C1_L_8822B << BIT_SHIFT_C1_L_8822B)
#define BIT_CLEAR_C1_L_8822B(x) ((x) & (~BITS_C1_L_8822B))
#define BIT_GET_C1_L_8822B(x) \
(((x) >> BIT_SHIFT_C1_L_8822B) & BIT_MASK_C1_L_8822B)
#define BIT_SET_C1_L_8822B(x, v) (BIT_CLEAR_C1_L_8822B(x) | BIT_C1_L_8822B(v))
#define BIT_SHIFT_REG_FREQ_L_8822B 25
#define BIT_MASK_REG_FREQ_L_8822B 0x7
#define BIT_REG_FREQ_L_8822B(x) \
(((x) & BIT_MASK_REG_FREQ_L_8822B) << BIT_SHIFT_REG_FREQ_L_8822B)
#define BITS_REG_FREQ_L_8822B \
(BIT_MASK_REG_FREQ_L_8822B << BIT_SHIFT_REG_FREQ_L_8822B)
#define BIT_CLEAR_REG_FREQ_L_8822B(x) ((x) & (~BITS_REG_FREQ_L_8822B))
#define BIT_GET_REG_FREQ_L_8822B(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L_8822B) & BIT_MASK_REG_FREQ_L_8822B)
#define BIT_SET_REG_FREQ_L_8822B(x, v) \
(BIT_CLEAR_REG_FREQ_L_8822B(x) | BIT_REG_FREQ_L_8822B(v))
#define BIT_REG_EN_DUTY_8822B BIT(24)
#define BIT_SHIFT_REG_MODE_8822B 22
#define BIT_MASK_REG_MODE_8822B 0x3
#define BIT_REG_MODE_8822B(x) \
(((x) & BIT_MASK_REG_MODE_8822B) << BIT_SHIFT_REG_MODE_8822B)
#define BITS_REG_MODE_8822B \
(BIT_MASK_REG_MODE_8822B << BIT_SHIFT_REG_MODE_8822B)
#define BIT_CLEAR_REG_MODE_8822B(x) ((x) & (~BITS_REG_MODE_8822B))
#define BIT_GET_REG_MODE_8822B(x) \
(((x) >> BIT_SHIFT_REG_MODE_8822B) & BIT_MASK_REG_MODE_8822B)
#define BIT_SET_REG_MODE_8822B(x, v) \
(BIT_CLEAR_REG_MODE_8822B(x) | BIT_REG_MODE_8822B(v))
#define BIT_REG_EN_SP_8822B BIT(21)
#define BIT_REG_AUTO_L_8822B BIT(20)
#define BIT_SW18_SELD_BIT0_8822B BIT(19)
#define BIT_SW18_POWOCP_8822B BIT(18)
#define BIT_SHIFT_OCP_L1_8822B 15
#define BIT_MASK_OCP_L1_8822B 0x7
#define BIT_OCP_L1_8822B(x) \
(((x) & BIT_MASK_OCP_L1_8822B) << BIT_SHIFT_OCP_L1_8822B)
#define BITS_OCP_L1_8822B (BIT_MASK_OCP_L1_8822B << BIT_SHIFT_OCP_L1_8822B)
#define BIT_CLEAR_OCP_L1_8822B(x) ((x) & (~BITS_OCP_L1_8822B))
#define BIT_GET_OCP_L1_8822B(x) \
(((x) >> BIT_SHIFT_OCP_L1_8822B) & BIT_MASK_OCP_L1_8822B)
#define BIT_SET_OCP_L1_8822B(x, v) \
(BIT_CLEAR_OCP_L1_8822B(x) | BIT_OCP_L1_8822B(v))
#define BIT_SHIFT_CF_L_8822B 13
#define BIT_MASK_CF_L_8822B 0x3
#define BIT_CF_L_8822B(x) (((x) & BIT_MASK_CF_L_8822B) << BIT_SHIFT_CF_L_8822B)
#define BITS_CF_L_8822B (BIT_MASK_CF_L_8822B << BIT_SHIFT_CF_L_8822B)
#define BIT_CLEAR_CF_L_8822B(x) ((x) & (~BITS_CF_L_8822B))
#define BIT_GET_CF_L_8822B(x) \
(((x) >> BIT_SHIFT_CF_L_8822B) & BIT_MASK_CF_L_8822B)
#define BIT_SET_CF_L_8822B(x, v) (BIT_CLEAR_CF_L_8822B(x) | BIT_CF_L_8822B(v))
#define BIT_SW18_FPWM_8822B BIT(11)
#define BIT_SW18_SWEN_8822B BIT(9)
#define BIT_SW18_LDEN_8822B BIT(8)
#define BIT_MAC_ID_EN_8822B BIT(7)
#define BIT_AFE_BGEN_8822B BIT(0)
/* 2 REG_SYS_SWR_CTRL2_8822B */
#define BIT_POW_ZCD_L_8822B BIT(31)
#define BIT_AUTOZCD_L_8822B BIT(30)
#define BIT_SHIFT_REG_DELAY_8822B 28
#define BIT_MASK_REG_DELAY_8822B 0x3
#define BIT_REG_DELAY_8822B(x) \
(((x) & BIT_MASK_REG_DELAY_8822B) << BIT_SHIFT_REG_DELAY_8822B)
#define BITS_REG_DELAY_8822B \
(BIT_MASK_REG_DELAY_8822B << BIT_SHIFT_REG_DELAY_8822B)
#define BIT_CLEAR_REG_DELAY_8822B(x) ((x) & (~BITS_REG_DELAY_8822B))
#define BIT_GET_REG_DELAY_8822B(x) \
(((x) >> BIT_SHIFT_REG_DELAY_8822B) & BIT_MASK_REG_DELAY_8822B)
#define BIT_SET_REG_DELAY_8822B(x, v) \
(BIT_CLEAR_REG_DELAY_8822B(x) | BIT_REG_DELAY_8822B(v))
#define BIT_SHIFT_V15ADJ_L1_V1_8822B 24
#define BIT_MASK_V15ADJ_L1_V1_8822B 0x7
#define BIT_V15ADJ_L1_V1_8822B(x) \
(((x) & BIT_MASK_V15ADJ_L1_V1_8822B) << BIT_SHIFT_V15ADJ_L1_V1_8822B)
#define BITS_V15ADJ_L1_V1_8822B \
(BIT_MASK_V15ADJ_L1_V1_8822B << BIT_SHIFT_V15ADJ_L1_V1_8822B)
#define BIT_CLEAR_V15ADJ_L1_V1_8822B(x) ((x) & (~BITS_V15ADJ_L1_V1_8822B))
#define BIT_GET_V15ADJ_L1_V1_8822B(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_V1_8822B) & BIT_MASK_V15ADJ_L1_V1_8822B)
#define BIT_SET_V15ADJ_L1_V1_8822B(x, v) \
(BIT_CLEAR_V15ADJ_L1_V1_8822B(x) | BIT_V15ADJ_L1_V1_8822B(v))
#define BIT_SHIFT_VOL_L1_V1_8822B 20
#define BIT_MASK_VOL_L1_V1_8822B 0xf
#define BIT_VOL_L1_V1_8822B(x) \
(((x) & BIT_MASK_VOL_L1_V1_8822B) << BIT_SHIFT_VOL_L1_V1_8822B)
#define BITS_VOL_L1_V1_8822B \
(BIT_MASK_VOL_L1_V1_8822B << BIT_SHIFT_VOL_L1_V1_8822B)
#define BIT_CLEAR_VOL_L1_V1_8822B(x) ((x) & (~BITS_VOL_L1_V1_8822B))
#define BIT_GET_VOL_L1_V1_8822B(x) \
(((x) >> BIT_SHIFT_VOL_L1_V1_8822B) & BIT_MASK_VOL_L1_V1_8822B)
#define BIT_SET_VOL_L1_V1_8822B(x, v) \
(BIT_CLEAR_VOL_L1_V1_8822B(x) | BIT_VOL_L1_V1_8822B(v))
#define BIT_SHIFT_IN_L1_V1_8822B 17
#define BIT_MASK_IN_L1_V1_8822B 0x7
#define BIT_IN_L1_V1_8822B(x) \
(((x) & BIT_MASK_IN_L1_V1_8822B) << BIT_SHIFT_IN_L1_V1_8822B)
#define BITS_IN_L1_V1_8822B \
(BIT_MASK_IN_L1_V1_8822B << BIT_SHIFT_IN_L1_V1_8822B)
#define BIT_CLEAR_IN_L1_V1_8822B(x) ((x) & (~BITS_IN_L1_V1_8822B))
#define BIT_GET_IN_L1_V1_8822B(x) \
(((x) >> BIT_SHIFT_IN_L1_V1_8822B) & BIT_MASK_IN_L1_V1_8822B)
#define BIT_SET_IN_L1_V1_8822B(x, v) \
(BIT_CLEAR_IN_L1_V1_8822B(x) | BIT_IN_L1_V1_8822B(v))
#define BIT_SHIFT_TBOX_L1_8822B 15
#define BIT_MASK_TBOX_L1_8822B 0x3
#define BIT_TBOX_L1_8822B(x) \
(((x) & BIT_MASK_TBOX_L1_8822B) << BIT_SHIFT_TBOX_L1_8822B)
#define BITS_TBOX_L1_8822B (BIT_MASK_TBOX_L1_8822B << BIT_SHIFT_TBOX_L1_8822B)
#define BIT_CLEAR_TBOX_L1_8822B(x) ((x) & (~BITS_TBOX_L1_8822B))
#define BIT_GET_TBOX_L1_8822B(x) \
(((x) >> BIT_SHIFT_TBOX_L1_8822B) & BIT_MASK_TBOX_L1_8822B)
#define BIT_SET_TBOX_L1_8822B(x, v) \
(BIT_CLEAR_TBOX_L1_8822B(x) | BIT_TBOX_L1_8822B(v))
#define BIT_SW18_SEL_8822B BIT(13)
/* 2 REG_NOT_VALID_8822B */
#define BIT_SW18_SD_8822B BIT(10)
#define BIT_SHIFT_R3_L_8822B 7
#define BIT_MASK_R3_L_8822B 0x3
#define BIT_R3_L_8822B(x) (((x) & BIT_MASK_R3_L_8822B) << BIT_SHIFT_R3_L_8822B)
#define BITS_R3_L_8822B (BIT_MASK_R3_L_8822B << BIT_SHIFT_R3_L_8822B)
#define BIT_CLEAR_R3_L_8822B(x) ((x) & (~BITS_R3_L_8822B))
#define BIT_GET_R3_L_8822B(x) \
(((x) >> BIT_SHIFT_R3_L_8822B) & BIT_MASK_R3_L_8822B)
#define BIT_SET_R3_L_8822B(x, v) (BIT_CLEAR_R3_L_8822B(x) | BIT_R3_L_8822B(v))
#define BIT_SHIFT_SW18_R2_8822B 5
#define BIT_MASK_SW18_R2_8822B 0x3
#define BIT_SW18_R2_8822B(x) \
(((x) & BIT_MASK_SW18_R2_8822B) << BIT_SHIFT_SW18_R2_8822B)
#define BITS_SW18_R2_8822B (BIT_MASK_SW18_R2_8822B << BIT_SHIFT_SW18_R2_8822B)
#define BIT_CLEAR_SW18_R2_8822B(x) ((x) & (~BITS_SW18_R2_8822B))
#define BIT_GET_SW18_R2_8822B(x) \
(((x) >> BIT_SHIFT_SW18_R2_8822B) & BIT_MASK_SW18_R2_8822B)
#define BIT_SET_SW18_R2_8822B(x, v) \
(BIT_CLEAR_SW18_R2_8822B(x) | BIT_SW18_R2_8822B(v))
#define BIT_SHIFT_SW18_R1_8822B 3
#define BIT_MASK_SW18_R1_8822B 0x3
#define BIT_SW18_R1_8822B(x) \
(((x) & BIT_MASK_SW18_R1_8822B) << BIT_SHIFT_SW18_R1_8822B)
#define BITS_SW18_R1_8822B (BIT_MASK_SW18_R1_8822B << BIT_SHIFT_SW18_R1_8822B)
#define BIT_CLEAR_SW18_R1_8822B(x) ((x) & (~BITS_SW18_R1_8822B))
#define BIT_GET_SW18_R1_8822B(x) \
(((x) >> BIT_SHIFT_SW18_R1_8822B) & BIT_MASK_SW18_R1_8822B)
#define BIT_SET_SW18_R1_8822B(x, v) \
(BIT_CLEAR_SW18_R1_8822B(x) | BIT_SW18_R1_8822B(v))
#define BIT_SHIFT_C3_L_C3_8822B 1
#define BIT_MASK_C3_L_C3_8822B 0x3
#define BIT_C3_L_C3_8822B(x) \
(((x) & BIT_MASK_C3_L_C3_8822B) << BIT_SHIFT_C3_L_C3_8822B)
#define BITS_C3_L_C3_8822B (BIT_MASK_C3_L_C3_8822B << BIT_SHIFT_C3_L_C3_8822B)
#define BIT_CLEAR_C3_L_C3_8822B(x) ((x) & (~BITS_C3_L_C3_8822B))
#define BIT_GET_C3_L_C3_8822B(x) \
(((x) >> BIT_SHIFT_C3_L_C3_8822B) & BIT_MASK_C3_L_C3_8822B)
#define BIT_SET_C3_L_C3_8822B(x, v) \
(BIT_CLEAR_C3_L_C3_8822B(x) | BIT_C3_L_C3_8822B(v))
#define BIT_C2_L_BIT1_8822B BIT(0)
/* 2 REG_SYS_SWR_CTRL3_8822B */
#define BIT_SPS18_OCP_DIS_8822B BIT(31)
#define BIT_SHIFT_SPS18_OCP_TH_8822B 16
#define BIT_MASK_SPS18_OCP_TH_8822B 0x7fff
#define BIT_SPS18_OCP_TH_8822B(x) \
(((x) & BIT_MASK_SPS18_OCP_TH_8822B) << BIT_SHIFT_SPS18_OCP_TH_8822B)
#define BITS_SPS18_OCP_TH_8822B \
(BIT_MASK_SPS18_OCP_TH_8822B << BIT_SHIFT_SPS18_OCP_TH_8822B)
#define BIT_CLEAR_SPS18_OCP_TH_8822B(x) ((x) & (~BITS_SPS18_OCP_TH_8822B))
#define BIT_GET_SPS18_OCP_TH_8822B(x) \
(((x) >> BIT_SHIFT_SPS18_OCP_TH_8822B) & BIT_MASK_SPS18_OCP_TH_8822B)
#define BIT_SET_SPS18_OCP_TH_8822B(x, v) \
(BIT_CLEAR_SPS18_OCP_TH_8822B(x) | BIT_SPS18_OCP_TH_8822B(v))
#define BIT_SHIFT_OCP_WINDOW_8822B 0
#define BIT_MASK_OCP_WINDOW_8822B 0xffff
#define BIT_OCP_WINDOW_8822B(x) \
(((x) & BIT_MASK_OCP_WINDOW_8822B) << BIT_SHIFT_OCP_WINDOW_8822B)
#define BITS_OCP_WINDOW_8822B \
(BIT_MASK_OCP_WINDOW_8822B << BIT_SHIFT_OCP_WINDOW_8822B)
#define BIT_CLEAR_OCP_WINDOW_8822B(x) ((x) & (~BITS_OCP_WINDOW_8822B))
#define BIT_GET_OCP_WINDOW_8822B(x) \
(((x) >> BIT_SHIFT_OCP_WINDOW_8822B) & BIT_MASK_OCP_WINDOW_8822B)
#define BIT_SET_OCP_WINDOW_8822B(x, v) \
(BIT_CLEAR_OCP_WINDOW_8822B(x) | BIT_OCP_WINDOW_8822B(v))
/* 2 REG_RSV_CTRL_8822B */
#define BIT_HREG_DBG_8822B BIT(23)
#define BIT_WLMCUIOIF_8822B BIT(8)
#define BIT_LOCK_ALL_EN_8822B BIT(7)
#define BIT_R_DIS_PRST_8822B BIT(6)
#define BIT_WLOCK_1C_B6_8822B BIT(5)
#define BIT_WLOCK_40_8822B BIT(4)
#define BIT_WLOCK_08_8822B BIT(3)
#define BIT_WLOCK_04_8822B BIT(2)
#define BIT_WLOCK_00_8822B BIT(1)
#define BIT_WLOCK_ALL_8822B BIT(0)
/* 2 REG_RF_CTRL_8822B */
#define BIT_RF_SDMRSTB_8822B BIT(2)
#define BIT_RF_RSTB_8822B BIT(1)
#define BIT_RF_EN_8822B BIT(0)
/* 2 REG_AFE_LDO_CTRL_8822B */
#define BIT_SHIFT_LPLDH12_RSV_8822B 29
#define BIT_MASK_LPLDH12_RSV_8822B 0x7
#define BIT_LPLDH12_RSV_8822B(x) \
(((x) & BIT_MASK_LPLDH12_RSV_8822B) << BIT_SHIFT_LPLDH12_RSV_8822B)
#define BITS_LPLDH12_RSV_8822B \
(BIT_MASK_LPLDH12_RSV_8822B << BIT_SHIFT_LPLDH12_RSV_8822B)
#define BIT_CLEAR_LPLDH12_RSV_8822B(x) ((x) & (~BITS_LPLDH12_RSV_8822B))
#define BIT_GET_LPLDH12_RSV_8822B(x) \
(((x) >> BIT_SHIFT_LPLDH12_RSV_8822B) & BIT_MASK_LPLDH12_RSV_8822B)
#define BIT_SET_LPLDH12_RSV_8822B(x, v) \
(BIT_CLEAR_LPLDH12_RSV_8822B(x) | BIT_LPLDH12_RSV_8822B(v))
#define BIT_LPLDH12_SLP_8822B BIT(28)
#define BIT_SHIFT_LPLDH12_VADJ_8822B 24
#define BIT_MASK_LPLDH12_VADJ_8822B 0xf
#define BIT_LPLDH12_VADJ_8822B(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_8822B) << BIT_SHIFT_LPLDH12_VADJ_8822B)
#define BITS_LPLDH12_VADJ_8822B \
(BIT_MASK_LPLDH12_VADJ_8822B << BIT_SHIFT_LPLDH12_VADJ_8822B)
#define BIT_CLEAR_LPLDH12_VADJ_8822B(x) ((x) & (~BITS_LPLDH12_VADJ_8822B))
#define BIT_GET_LPLDH12_VADJ_8822B(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_8822B) & BIT_MASK_LPLDH12_VADJ_8822B)
#define BIT_SET_LPLDH12_VADJ_8822B(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_8822B(x) | BIT_LPLDH12_VADJ_8822B(v))
#define BIT_LDH12_EN_8822B BIT(16)
#define BIT_WLBBOFF_BIG_PWC_EN_8822B BIT(14)
#define BIT_WLBBOFF_SMALL_PWC_EN_8822B BIT(13)
#define BIT_WLMACOFF_BIG_PWC_EN_8822B BIT(12)
#define BIT_WLPON_PWC_EN_8822B BIT(11)
#define BIT_POW_REGU_P1_8822B BIT(10)
#define BIT_LDOV12W_EN_8822B BIT(8)
#define BIT_EX_XTAL_DRV_DIGI_8822B BIT(7)
#define BIT_EX_XTAL_DRV_USB_8822B BIT(6)
#define BIT_EX_XTAL_DRV_AFE_8822B BIT(5)
#define BIT_EX_XTAL_DRV_RF2_8822B BIT(4)
#define BIT_EX_XTAL_DRV_RF1_8822B BIT(3)
#define BIT_POW_REGU_P0_8822B BIT(2)
/* 2 REG_NOT_VALID_8822B */
#define BIT_POW_PLL_LDO_8822B BIT(0)
/* 2 REG_AFE_CTRL1_8822B */
#define BIT_AGPIO_GPE_8822B BIT(31)
#define BIT_SHIFT_XTAL_CAP_XI_8822B 25
#define BIT_MASK_XTAL_CAP_XI_8822B 0x3f
#define BIT_XTAL_CAP_XI_8822B(x) \
(((x) & BIT_MASK_XTAL_CAP_XI_8822B) << BIT_SHIFT_XTAL_CAP_XI_8822B)
#define BITS_XTAL_CAP_XI_8822B \
(BIT_MASK_XTAL_CAP_XI_8822B << BIT_SHIFT_XTAL_CAP_XI_8822B)
#define BIT_CLEAR_XTAL_CAP_XI_8822B(x) ((x) & (~BITS_XTAL_CAP_XI_8822B))
#define BIT_GET_XTAL_CAP_XI_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XI_8822B) & BIT_MASK_XTAL_CAP_XI_8822B)
#define BIT_SET_XTAL_CAP_XI_8822B(x, v) \
(BIT_CLEAR_XTAL_CAP_XI_8822B(x) | BIT_XTAL_CAP_XI_8822B(v))
#define BIT_SHIFT_XTAL_DRV_DIGI_8822B 23
#define BIT_MASK_XTAL_DRV_DIGI_8822B 0x3
#define BIT_XTAL_DRV_DIGI_8822B(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_8822B) << BIT_SHIFT_XTAL_DRV_DIGI_8822B)
#define BITS_XTAL_DRV_DIGI_8822B \
(BIT_MASK_XTAL_DRV_DIGI_8822B << BIT_SHIFT_XTAL_DRV_DIGI_8822B)
#define BIT_CLEAR_XTAL_DRV_DIGI_8822B(x) ((x) & (~BITS_XTAL_DRV_DIGI_8822B))
#define BIT_GET_XTAL_DRV_DIGI_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_8822B) & BIT_MASK_XTAL_DRV_DIGI_8822B)
#define BIT_SET_XTAL_DRV_DIGI_8822B(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_8822B(x) | BIT_XTAL_DRV_DIGI_8822B(v))
#define BIT_XTAL_DRV_USB_BIT1_8822B BIT(22)
#define BIT_SHIFT_MAC_CLK_SEL_8822B 20
#define BIT_MASK_MAC_CLK_SEL_8822B 0x3
#define BIT_MAC_CLK_SEL_8822B(x) \
(((x) & BIT_MASK_MAC_CLK_SEL_8822B) << BIT_SHIFT_MAC_CLK_SEL_8822B)
#define BITS_MAC_CLK_SEL_8822B \
(BIT_MASK_MAC_CLK_SEL_8822B << BIT_SHIFT_MAC_CLK_SEL_8822B)
#define BIT_CLEAR_MAC_CLK_SEL_8822B(x) ((x) & (~BITS_MAC_CLK_SEL_8822B))
#define BIT_GET_MAC_CLK_SEL_8822B(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL_8822B) & BIT_MASK_MAC_CLK_SEL_8822B)
#define BIT_SET_MAC_CLK_SEL_8822B(x, v) \
(BIT_CLEAR_MAC_CLK_SEL_8822B(x) | BIT_MAC_CLK_SEL_8822B(v))
#define BIT_XTAL_DRV_USB_BIT0_8822B BIT(19)
#define BIT_SHIFT_XTAL_DRV_AFE_8822B 17
#define BIT_MASK_XTAL_DRV_AFE_8822B 0x3
#define BIT_XTAL_DRV_AFE_8822B(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_8822B) << BIT_SHIFT_XTAL_DRV_AFE_8822B)
#define BITS_XTAL_DRV_AFE_8822B \
(BIT_MASK_XTAL_DRV_AFE_8822B << BIT_SHIFT_XTAL_DRV_AFE_8822B)
#define BIT_CLEAR_XTAL_DRV_AFE_8822B(x) ((x) & (~BITS_XTAL_DRV_AFE_8822B))
#define BIT_GET_XTAL_DRV_AFE_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_8822B) & BIT_MASK_XTAL_DRV_AFE_8822B)
#define BIT_SET_XTAL_DRV_AFE_8822B(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_8822B(x) | BIT_XTAL_DRV_AFE_8822B(v))
#define BIT_SHIFT_XTAL_DRV_RF2_8822B 15
#define BIT_MASK_XTAL_DRV_RF2_8822B 0x3
#define BIT_XTAL_DRV_RF2_8822B(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_8822B) << BIT_SHIFT_XTAL_DRV_RF2_8822B)
#define BITS_XTAL_DRV_RF2_8822B \
(BIT_MASK_XTAL_DRV_RF2_8822B << BIT_SHIFT_XTAL_DRV_RF2_8822B)
#define BIT_CLEAR_XTAL_DRV_RF2_8822B(x) ((x) & (~BITS_XTAL_DRV_RF2_8822B))
#define BIT_GET_XTAL_DRV_RF2_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_8822B) & BIT_MASK_XTAL_DRV_RF2_8822B)
#define BIT_SET_XTAL_DRV_RF2_8822B(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_8822B(x) | BIT_XTAL_DRV_RF2_8822B(v))
#define BIT_SHIFT_XTAL_DRV_RF1_8822B 13
#define BIT_MASK_XTAL_DRV_RF1_8822B 0x3
#define BIT_XTAL_DRV_RF1_8822B(x) \
(((x) & BIT_MASK_XTAL_DRV_RF1_8822B) << BIT_SHIFT_XTAL_DRV_RF1_8822B)
#define BITS_XTAL_DRV_RF1_8822B \
(BIT_MASK_XTAL_DRV_RF1_8822B << BIT_SHIFT_XTAL_DRV_RF1_8822B)
#define BIT_CLEAR_XTAL_DRV_RF1_8822B(x) ((x) & (~BITS_XTAL_DRV_RF1_8822B))
#define BIT_GET_XTAL_DRV_RF1_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF1_8822B) & BIT_MASK_XTAL_DRV_RF1_8822B)
#define BIT_SET_XTAL_DRV_RF1_8822B(x, v) \
(BIT_CLEAR_XTAL_DRV_RF1_8822B(x) | BIT_XTAL_DRV_RF1_8822B(v))
#define BIT_XTAL_DELAY_DIGI_8822B BIT(12)
#define BIT_XTAL_DELAY_USB_8822B BIT(11)
#define BIT_XTAL_DELAY_AFE_8822B BIT(10)
#define BIT_SHIFT_XTAL_LDO_VREF_8822B 7
#define BIT_MASK_XTAL_LDO_VREF_8822B 0x7
#define BIT_XTAL_LDO_VREF_8822B(x) \
(((x) & BIT_MASK_XTAL_LDO_VREF_8822B) << BIT_SHIFT_XTAL_LDO_VREF_8822B)
#define BITS_XTAL_LDO_VREF_8822B \
(BIT_MASK_XTAL_LDO_VREF_8822B << BIT_SHIFT_XTAL_LDO_VREF_8822B)
#define BIT_CLEAR_XTAL_LDO_VREF_8822B(x) ((x) & (~BITS_XTAL_LDO_VREF_8822B))
#define BIT_GET_XTAL_LDO_VREF_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_VREF_8822B) & BIT_MASK_XTAL_LDO_VREF_8822B)
#define BIT_SET_XTAL_LDO_VREF_8822B(x, v) \
(BIT_CLEAR_XTAL_LDO_VREF_8822B(x) | BIT_XTAL_LDO_VREF_8822B(v))
#define BIT_XTAL_XQSEL_RF_8822B BIT(6)
#define BIT_XTAL_XQSEL_8822B BIT(5)
#define BIT_SHIFT_XTAL_GMN_V2_8822B 3
#define BIT_MASK_XTAL_GMN_V2_8822B 0x3
#define BIT_XTAL_GMN_V2_8822B(x) \
(((x) & BIT_MASK_XTAL_GMN_V2_8822B) << BIT_SHIFT_XTAL_GMN_V2_8822B)
#define BITS_XTAL_GMN_V2_8822B \
(BIT_MASK_XTAL_GMN_V2_8822B << BIT_SHIFT_XTAL_GMN_V2_8822B)
#define BIT_CLEAR_XTAL_GMN_V2_8822B(x) ((x) & (~BITS_XTAL_GMN_V2_8822B))
#define BIT_GET_XTAL_GMN_V2_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V2_8822B) & BIT_MASK_XTAL_GMN_V2_8822B)
#define BIT_SET_XTAL_GMN_V2_8822B(x, v) \
(BIT_CLEAR_XTAL_GMN_V2_8822B(x) | BIT_XTAL_GMN_V2_8822B(v))
#define BIT_SHIFT_XTAL_GMP_V2_8822B 1
#define BIT_MASK_XTAL_GMP_V2_8822B 0x3
#define BIT_XTAL_GMP_V2_8822B(x) \
(((x) & BIT_MASK_XTAL_GMP_V2_8822B) << BIT_SHIFT_XTAL_GMP_V2_8822B)
#define BITS_XTAL_GMP_V2_8822B \
(BIT_MASK_XTAL_GMP_V2_8822B << BIT_SHIFT_XTAL_GMP_V2_8822B)
#define BIT_CLEAR_XTAL_GMP_V2_8822B(x) ((x) & (~BITS_XTAL_GMP_V2_8822B))
#define BIT_GET_XTAL_GMP_V2_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V2_8822B) & BIT_MASK_XTAL_GMP_V2_8822B)
#define BIT_SET_XTAL_GMP_V2_8822B(x, v) \
(BIT_CLEAR_XTAL_GMP_V2_8822B(x) | BIT_XTAL_GMP_V2_8822B(v))
#define BIT_XTAL_EN_8822B BIT(0)
/* 2 REG_AFE_CTRL2_8822B */
#define BIT_SHIFT_REG_C3_V4_8822B 30
#define BIT_MASK_REG_C3_V4_8822B 0x3
#define BIT_REG_C3_V4_8822B(x) \
(((x) & BIT_MASK_REG_C3_V4_8822B) << BIT_SHIFT_REG_C3_V4_8822B)
#define BITS_REG_C3_V4_8822B \
(BIT_MASK_REG_C3_V4_8822B << BIT_SHIFT_REG_C3_V4_8822B)
#define BIT_CLEAR_REG_C3_V4_8822B(x) ((x) & (~BITS_REG_C3_V4_8822B))
#define BIT_GET_REG_C3_V4_8822B(x) \
(((x) >> BIT_SHIFT_REG_C3_V4_8822B) & BIT_MASK_REG_C3_V4_8822B)
#define BIT_SET_REG_C3_V4_8822B(x, v) \
(BIT_CLEAR_REG_C3_V4_8822B(x) | BIT_REG_C3_V4_8822B(v))
#define BIT_REG_CP_BIT1_8822B BIT(29)
#define BIT_SHIFT_REG_RS_V4_8822B 26
#define BIT_MASK_REG_RS_V4_8822B 0x7
#define BIT_REG_RS_V4_8822B(x) \
(((x) & BIT_MASK_REG_RS_V4_8822B) << BIT_SHIFT_REG_RS_V4_8822B)
#define BITS_REG_RS_V4_8822B \
(BIT_MASK_REG_RS_V4_8822B << BIT_SHIFT_REG_RS_V4_8822B)
#define BIT_CLEAR_REG_RS_V4_8822B(x) ((x) & (~BITS_REG_RS_V4_8822B))
#define BIT_GET_REG_RS_V4_8822B(x) \
(((x) >> BIT_SHIFT_REG_RS_V4_8822B) & BIT_MASK_REG_RS_V4_8822B)
#define BIT_SET_REG_RS_V4_8822B(x, v) \
(BIT_CLEAR_REG_RS_V4_8822B(x) | BIT_REG_RS_V4_8822B(v))
#define BIT_SHIFT_REG__CS_8822B 24
#define BIT_MASK_REG__CS_8822B 0x3
#define BIT_REG__CS_8822B(x) \
(((x) & BIT_MASK_REG__CS_8822B) << BIT_SHIFT_REG__CS_8822B)
#define BITS_REG__CS_8822B (BIT_MASK_REG__CS_8822B << BIT_SHIFT_REG__CS_8822B)
#define BIT_CLEAR_REG__CS_8822B(x) ((x) & (~BITS_REG__CS_8822B))
#define BIT_GET_REG__CS_8822B(x) \
(((x) >> BIT_SHIFT_REG__CS_8822B) & BIT_MASK_REG__CS_8822B)
#define BIT_SET_REG__CS_8822B(x, v) \
(BIT_CLEAR_REG__CS_8822B(x) | BIT_REG__CS_8822B(v))
#define BIT_SHIFT_REG_CP_OFFSET_8822B 21
#define BIT_MASK_REG_CP_OFFSET_8822B 0x7
#define BIT_REG_CP_OFFSET_8822B(x) \
(((x) & BIT_MASK_REG_CP_OFFSET_8822B) << BIT_SHIFT_REG_CP_OFFSET_8822B)
#define BITS_REG_CP_OFFSET_8822B \
(BIT_MASK_REG_CP_OFFSET_8822B << BIT_SHIFT_REG_CP_OFFSET_8822B)
#define BIT_CLEAR_REG_CP_OFFSET_8822B(x) ((x) & (~BITS_REG_CP_OFFSET_8822B))
#define BIT_GET_REG_CP_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_REG_CP_OFFSET_8822B) & BIT_MASK_REG_CP_OFFSET_8822B)
#define BIT_SET_REG_CP_OFFSET_8822B(x, v) \
(BIT_CLEAR_REG_CP_OFFSET_8822B(x) | BIT_REG_CP_OFFSET_8822B(v))
#define BIT_SHIFT_CP_BIAS_8822B 18
#define BIT_MASK_CP_BIAS_8822B 0x7
#define BIT_CP_BIAS_8822B(x) \
(((x) & BIT_MASK_CP_BIAS_8822B) << BIT_SHIFT_CP_BIAS_8822B)
#define BITS_CP_BIAS_8822B (BIT_MASK_CP_BIAS_8822B << BIT_SHIFT_CP_BIAS_8822B)
#define BIT_CLEAR_CP_BIAS_8822B(x) ((x) & (~BITS_CP_BIAS_8822B))
#define BIT_GET_CP_BIAS_8822B(x) \
(((x) >> BIT_SHIFT_CP_BIAS_8822B) & BIT_MASK_CP_BIAS_8822B)
#define BIT_SET_CP_BIAS_8822B(x, v) \
(BIT_CLEAR_CP_BIAS_8822B(x) | BIT_CP_BIAS_8822B(v))
#define BIT_REG_IDOUBLE_V2_8822B BIT(17)
#define BIT_EN_SYN_8822B BIT(16)
#define BIT_SHIFT_MCCO_8822B 14
#define BIT_MASK_MCCO_8822B 0x3
#define BIT_MCCO_8822B(x) (((x) & BIT_MASK_MCCO_8822B) << BIT_SHIFT_MCCO_8822B)
#define BITS_MCCO_8822B (BIT_MASK_MCCO_8822B << BIT_SHIFT_MCCO_8822B)
#define BIT_CLEAR_MCCO_8822B(x) ((x) & (~BITS_MCCO_8822B))
#define BIT_GET_MCCO_8822B(x) \
(((x) >> BIT_SHIFT_MCCO_8822B) & BIT_MASK_MCCO_8822B)
#define BIT_SET_MCCO_8822B(x, v) (BIT_CLEAR_MCCO_8822B(x) | BIT_MCCO_8822B(v))
#define BIT_SHIFT_REG_LDO_SEL_8822B 12
#define BIT_MASK_REG_LDO_SEL_8822B 0x3
#define BIT_REG_LDO_SEL_8822B(x) \
(((x) & BIT_MASK_REG_LDO_SEL_8822B) << BIT_SHIFT_REG_LDO_SEL_8822B)
#define BITS_REG_LDO_SEL_8822B \
(BIT_MASK_REG_LDO_SEL_8822B << BIT_SHIFT_REG_LDO_SEL_8822B)
#define BIT_CLEAR_REG_LDO_SEL_8822B(x) ((x) & (~BITS_REG_LDO_SEL_8822B))
#define BIT_GET_REG_LDO_SEL_8822B(x) \
(((x) >> BIT_SHIFT_REG_LDO_SEL_8822B) & BIT_MASK_REG_LDO_SEL_8822B)
#define BIT_SET_REG_LDO_SEL_8822B(x, v) \
(BIT_CLEAR_REG_LDO_SEL_8822B(x) | BIT_REG_LDO_SEL_8822B(v))
#define BIT_REG_KVCO_V2_8822B BIT(10)
#define BIT_AGPIO_GPO_8822B BIT(9)
#define BIT_SHIFT_AGPIO_DRV_8822B 7
#define BIT_MASK_AGPIO_DRV_8822B 0x3
#define BIT_AGPIO_DRV_8822B(x) \
(((x) & BIT_MASK_AGPIO_DRV_8822B) << BIT_SHIFT_AGPIO_DRV_8822B)
#define BITS_AGPIO_DRV_8822B \
(BIT_MASK_AGPIO_DRV_8822B << BIT_SHIFT_AGPIO_DRV_8822B)
#define BIT_CLEAR_AGPIO_DRV_8822B(x) ((x) & (~BITS_AGPIO_DRV_8822B))
#define BIT_GET_AGPIO_DRV_8822B(x) \
(((x) >> BIT_SHIFT_AGPIO_DRV_8822B) & BIT_MASK_AGPIO_DRV_8822B)
#define BIT_SET_AGPIO_DRV_8822B(x, v) \
(BIT_CLEAR_AGPIO_DRV_8822B(x) | BIT_AGPIO_DRV_8822B(v))
#define BIT_SHIFT_XTAL_CAP_XO_8822B 1
#define BIT_MASK_XTAL_CAP_XO_8822B 0x3f
#define BIT_XTAL_CAP_XO_8822B(x) \
(((x) & BIT_MASK_XTAL_CAP_XO_8822B) << BIT_SHIFT_XTAL_CAP_XO_8822B)
#define BITS_XTAL_CAP_XO_8822B \
(BIT_MASK_XTAL_CAP_XO_8822B << BIT_SHIFT_XTAL_CAP_XO_8822B)
#define BIT_CLEAR_XTAL_CAP_XO_8822B(x) ((x) & (~BITS_XTAL_CAP_XO_8822B))
#define BIT_GET_XTAL_CAP_XO_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_CAP_XO_8822B) & BIT_MASK_XTAL_CAP_XO_8822B)
#define BIT_SET_XTAL_CAP_XO_8822B(x, v) \
(BIT_CLEAR_XTAL_CAP_XO_8822B(x) | BIT_XTAL_CAP_XO_8822B(v))
#define BIT_POW_PLL_8822B BIT(0)
/* 2 REG_AFE_CTRL3_8822B */
#define BIT_SHIFT_PS_8822B 7
#define BIT_MASK_PS_8822B 0x7
#define BIT_PS_8822B(x) (((x) & BIT_MASK_PS_8822B) << BIT_SHIFT_PS_8822B)
#define BITS_PS_8822B (BIT_MASK_PS_8822B << BIT_SHIFT_PS_8822B)
#define BIT_CLEAR_PS_8822B(x) ((x) & (~BITS_PS_8822B))
#define BIT_GET_PS_8822B(x) (((x) >> BIT_SHIFT_PS_8822B) & BIT_MASK_PS_8822B)
#define BIT_SET_PS_8822B(x, v) (BIT_CLEAR_PS_8822B(x) | BIT_PS_8822B(v))
#define BIT_PSEN_8822B BIT(6)
#define BIT_DOGENB_8822B BIT(5)
#define BIT_REG_MBIAS_8822B BIT(4)
#define BIT_SHIFT_REG_R3_V4_8822B 1
#define BIT_MASK_REG_R3_V4_8822B 0x7
#define BIT_REG_R3_V4_8822B(x) \
(((x) & BIT_MASK_REG_R3_V4_8822B) << BIT_SHIFT_REG_R3_V4_8822B)
#define BITS_REG_R3_V4_8822B \
(BIT_MASK_REG_R3_V4_8822B << BIT_SHIFT_REG_R3_V4_8822B)
#define BIT_CLEAR_REG_R3_V4_8822B(x) ((x) & (~BITS_REG_R3_V4_8822B))
#define BIT_GET_REG_R3_V4_8822B(x) \
(((x) >> BIT_SHIFT_REG_R3_V4_8822B) & BIT_MASK_REG_R3_V4_8822B)
#define BIT_SET_REG_R3_V4_8822B(x, v) \
(BIT_CLEAR_REG_R3_V4_8822B(x) | BIT_REG_R3_V4_8822B(v))
#define BIT_REG_CP_BIT0_8822B BIT(0)
/* 2 REG_EFUSE_CTRL_8822B */
#define BIT_EF_FLAG_8822B BIT(31)
#define BIT_SHIFT_EF_PGPD_8822B 28
#define BIT_MASK_EF_PGPD_8822B 0x7
#define BIT_EF_PGPD_8822B(x) \
(((x) & BIT_MASK_EF_PGPD_8822B) << BIT_SHIFT_EF_PGPD_8822B)
#define BITS_EF_PGPD_8822B (BIT_MASK_EF_PGPD_8822B << BIT_SHIFT_EF_PGPD_8822B)
#define BIT_CLEAR_EF_PGPD_8822B(x) ((x) & (~BITS_EF_PGPD_8822B))
#define BIT_GET_EF_PGPD_8822B(x) \
(((x) >> BIT_SHIFT_EF_PGPD_8822B) & BIT_MASK_EF_PGPD_8822B)
#define BIT_SET_EF_PGPD_8822B(x, v) \
(BIT_CLEAR_EF_PGPD_8822B(x) | BIT_EF_PGPD_8822B(v))
#define BIT_SHIFT_EF_RDT_8822B 24
#define BIT_MASK_EF_RDT_8822B 0xf
#define BIT_EF_RDT_8822B(x) \
(((x) & BIT_MASK_EF_RDT_8822B) << BIT_SHIFT_EF_RDT_8822B)
#define BITS_EF_RDT_8822B (BIT_MASK_EF_RDT_8822B << BIT_SHIFT_EF_RDT_8822B)
#define BIT_CLEAR_EF_RDT_8822B(x) ((x) & (~BITS_EF_RDT_8822B))
#define BIT_GET_EF_RDT_8822B(x) \
(((x) >> BIT_SHIFT_EF_RDT_8822B) & BIT_MASK_EF_RDT_8822B)
#define BIT_SET_EF_RDT_8822B(x, v) \
(BIT_CLEAR_EF_RDT_8822B(x) | BIT_EF_RDT_8822B(v))
#define BIT_SHIFT_EF_PGTS_8822B 20
#define BIT_MASK_EF_PGTS_8822B 0xf
#define BIT_EF_PGTS_8822B(x) \
(((x) & BIT_MASK_EF_PGTS_8822B) << BIT_SHIFT_EF_PGTS_8822B)
#define BITS_EF_PGTS_8822B (BIT_MASK_EF_PGTS_8822B << BIT_SHIFT_EF_PGTS_8822B)
#define BIT_CLEAR_EF_PGTS_8822B(x) ((x) & (~BITS_EF_PGTS_8822B))
#define BIT_GET_EF_PGTS_8822B(x) \
(((x) >> BIT_SHIFT_EF_PGTS_8822B) & BIT_MASK_EF_PGTS_8822B)
#define BIT_SET_EF_PGTS_8822B(x, v) \
(BIT_CLEAR_EF_PGTS_8822B(x) | BIT_EF_PGTS_8822B(v))
#define BIT_EF_PDWN_8822B BIT(19)
#define BIT_EF_ALDEN_8822B BIT(18)
#define BIT_SHIFT_EF_ADDR_8822B 8
#define BIT_MASK_EF_ADDR_8822B 0x3ff
#define BIT_EF_ADDR_8822B(x) \
(((x) & BIT_MASK_EF_ADDR_8822B) << BIT_SHIFT_EF_ADDR_8822B)
#define BITS_EF_ADDR_8822B (BIT_MASK_EF_ADDR_8822B << BIT_SHIFT_EF_ADDR_8822B)
#define BIT_CLEAR_EF_ADDR_8822B(x) ((x) & (~BITS_EF_ADDR_8822B))
#define BIT_GET_EF_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_EF_ADDR_8822B) & BIT_MASK_EF_ADDR_8822B)
#define BIT_SET_EF_ADDR_8822B(x, v) \
(BIT_CLEAR_EF_ADDR_8822B(x) | BIT_EF_ADDR_8822B(v))
#define BIT_SHIFT_EF_DATA_8822B 0
#define BIT_MASK_EF_DATA_8822B 0xff
#define BIT_EF_DATA_8822B(x) \
(((x) & BIT_MASK_EF_DATA_8822B) << BIT_SHIFT_EF_DATA_8822B)
#define BITS_EF_DATA_8822B (BIT_MASK_EF_DATA_8822B << BIT_SHIFT_EF_DATA_8822B)
#define BIT_CLEAR_EF_DATA_8822B(x) ((x) & (~BITS_EF_DATA_8822B))
#define BIT_GET_EF_DATA_8822B(x) \
(((x) >> BIT_SHIFT_EF_DATA_8822B) & BIT_MASK_EF_DATA_8822B)
#define BIT_SET_EF_DATA_8822B(x, v) \
(BIT_CLEAR_EF_DATA_8822B(x) | BIT_EF_DATA_8822B(v))
/* 2 REG_LDO_EFUSE_CTRL_8822B */
#define BIT_LDOE25_EN_8822B BIT(31)
#define BIT_SHIFT_LDOE25_V12ADJ_L_8822B 27
#define BIT_MASK_LDOE25_V12ADJ_L_8822B 0xf
#define BIT_LDOE25_V12ADJ_L_8822B(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L_8822B) \
<< BIT_SHIFT_LDOE25_V12ADJ_L_8822B)
#define BITS_LDOE25_V12ADJ_L_8822B \
(BIT_MASK_LDOE25_V12ADJ_L_8822B << BIT_SHIFT_LDOE25_V12ADJ_L_8822B)
#define BIT_CLEAR_LDOE25_V12ADJ_L_8822B(x) ((x) & (~BITS_LDOE25_V12ADJ_L_8822B))
#define BIT_GET_LDOE25_V12ADJ_L_8822B(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L_8822B) & \
BIT_MASK_LDOE25_V12ADJ_L_8822B)
#define BIT_SET_LDOE25_V12ADJ_L_8822B(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L_8822B(x) | BIT_LDOE25_V12ADJ_L_8822B(v))
#define BIT_EF_CRES_SEL_8822B BIT(26)
#define BIT_SHIFT_EF_SCAN_START_V1_8822B 16
#define BIT_MASK_EF_SCAN_START_V1_8822B 0x3ff
#define BIT_EF_SCAN_START_V1_8822B(x) \
(((x) & BIT_MASK_EF_SCAN_START_V1_8822B) \
<< BIT_SHIFT_EF_SCAN_START_V1_8822B)
#define BITS_EF_SCAN_START_V1_8822B \
(BIT_MASK_EF_SCAN_START_V1_8822B << BIT_SHIFT_EF_SCAN_START_V1_8822B)
#define BIT_CLEAR_EF_SCAN_START_V1_8822B(x) \
((x) & (~BITS_EF_SCAN_START_V1_8822B))
#define BIT_GET_EF_SCAN_START_V1_8822B(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START_V1_8822B) & \
BIT_MASK_EF_SCAN_START_V1_8822B)
#define BIT_SET_EF_SCAN_START_V1_8822B(x, v) \
(BIT_CLEAR_EF_SCAN_START_V1_8822B(x) | BIT_EF_SCAN_START_V1_8822B(v))
#define BIT_SHIFT_EF_SCAN_END_8822B 12
#define BIT_MASK_EF_SCAN_END_8822B 0xf
#define BIT_EF_SCAN_END_8822B(x) \
(((x) & BIT_MASK_EF_SCAN_END_8822B) << BIT_SHIFT_EF_SCAN_END_8822B)
#define BITS_EF_SCAN_END_8822B \
(BIT_MASK_EF_SCAN_END_8822B << BIT_SHIFT_EF_SCAN_END_8822B)
#define BIT_CLEAR_EF_SCAN_END_8822B(x) ((x) & (~BITS_EF_SCAN_END_8822B))
#define BIT_GET_EF_SCAN_END_8822B(x) \
(((x) >> BIT_SHIFT_EF_SCAN_END_8822B) & BIT_MASK_EF_SCAN_END_8822B)
#define BIT_SET_EF_SCAN_END_8822B(x, v) \
(BIT_CLEAR_EF_SCAN_END_8822B(x) | BIT_EF_SCAN_END_8822B(v))
#define BIT_EF_PD_DIS_8822B BIT(11)
#define BIT_SHIFT_EF_CELL_SEL_8822B 8
#define BIT_MASK_EF_CELL_SEL_8822B 0x3
#define BIT_EF_CELL_SEL_8822B(x) \
(((x) & BIT_MASK_EF_CELL_SEL_8822B) << BIT_SHIFT_EF_CELL_SEL_8822B)
#define BITS_EF_CELL_SEL_8822B \
(BIT_MASK_EF_CELL_SEL_8822B << BIT_SHIFT_EF_CELL_SEL_8822B)
#define BIT_CLEAR_EF_CELL_SEL_8822B(x) ((x) & (~BITS_EF_CELL_SEL_8822B))
#define BIT_GET_EF_CELL_SEL_8822B(x) \
(((x) >> BIT_SHIFT_EF_CELL_SEL_8822B) & BIT_MASK_EF_CELL_SEL_8822B)
#define BIT_SET_EF_CELL_SEL_8822B(x, v) \
(BIT_CLEAR_EF_CELL_SEL_8822B(x) | BIT_EF_CELL_SEL_8822B(v))
#define BIT_EF_TRPT_8822B BIT(7)
#define BIT_SHIFT_EF_TTHD_8822B 0
#define BIT_MASK_EF_TTHD_8822B 0x7f
#define BIT_EF_TTHD_8822B(x) \
(((x) & BIT_MASK_EF_TTHD_8822B) << BIT_SHIFT_EF_TTHD_8822B)
#define BITS_EF_TTHD_8822B (BIT_MASK_EF_TTHD_8822B << BIT_SHIFT_EF_TTHD_8822B)
#define BIT_CLEAR_EF_TTHD_8822B(x) ((x) & (~BITS_EF_TTHD_8822B))
#define BIT_GET_EF_TTHD_8822B(x) \
(((x) >> BIT_SHIFT_EF_TTHD_8822B) & BIT_MASK_EF_TTHD_8822B)
#define BIT_SET_EF_TTHD_8822B(x, v) \
(BIT_CLEAR_EF_TTHD_8822B(x) | BIT_EF_TTHD_8822B(v))
/* 2 REG_PWR_OPTION_CTRL_8822B */
#define BIT_SHIFT_DBG_SEL_V1_8822B 16
#define BIT_MASK_DBG_SEL_V1_8822B 0xff
#define BIT_DBG_SEL_V1_8822B(x) \
(((x) & BIT_MASK_DBG_SEL_V1_8822B) << BIT_SHIFT_DBG_SEL_V1_8822B)
#define BITS_DBG_SEL_V1_8822B \
(BIT_MASK_DBG_SEL_V1_8822B << BIT_SHIFT_DBG_SEL_V1_8822B)
#define BIT_CLEAR_DBG_SEL_V1_8822B(x) ((x) & (~BITS_DBG_SEL_V1_8822B))
#define BIT_GET_DBG_SEL_V1_8822B(x) \
(((x) >> BIT_SHIFT_DBG_SEL_V1_8822B) & BIT_MASK_DBG_SEL_V1_8822B)
#define BIT_SET_DBG_SEL_V1_8822B(x, v) \
(BIT_CLEAR_DBG_SEL_V1_8822B(x) | BIT_DBG_SEL_V1_8822B(v))
#define BIT_SHIFT_DBG_SEL_BYTE_8822B 14
#define BIT_MASK_DBG_SEL_BYTE_8822B 0x3
#define BIT_DBG_SEL_BYTE_8822B(x) \
(((x) & BIT_MASK_DBG_SEL_BYTE_8822B) << BIT_SHIFT_DBG_SEL_BYTE_8822B)
#define BITS_DBG_SEL_BYTE_8822B \
(BIT_MASK_DBG_SEL_BYTE_8822B << BIT_SHIFT_DBG_SEL_BYTE_8822B)
#define BIT_CLEAR_DBG_SEL_BYTE_8822B(x) ((x) & (~BITS_DBG_SEL_BYTE_8822B))
#define BIT_GET_DBG_SEL_BYTE_8822B(x) \
(((x) >> BIT_SHIFT_DBG_SEL_BYTE_8822B) & BIT_MASK_DBG_SEL_BYTE_8822B)
#define BIT_SET_DBG_SEL_BYTE_8822B(x, v) \
(BIT_CLEAR_DBG_SEL_BYTE_8822B(x) | BIT_DBG_SEL_BYTE_8822B(v))
#define BIT_SHIFT_STD_L1_V1_8822B 12
#define BIT_MASK_STD_L1_V1_8822B 0x3
#define BIT_STD_L1_V1_8822B(x) \
(((x) & BIT_MASK_STD_L1_V1_8822B) << BIT_SHIFT_STD_L1_V1_8822B)
#define BITS_STD_L1_V1_8822B \
(BIT_MASK_STD_L1_V1_8822B << BIT_SHIFT_STD_L1_V1_8822B)
#define BIT_CLEAR_STD_L1_V1_8822B(x) ((x) & (~BITS_STD_L1_V1_8822B))
#define BIT_GET_STD_L1_V1_8822B(x) \
(((x) >> BIT_SHIFT_STD_L1_V1_8822B) & BIT_MASK_STD_L1_V1_8822B)
#define BIT_SET_STD_L1_V1_8822B(x, v) \
(BIT_CLEAR_STD_L1_V1_8822B(x) | BIT_STD_L1_V1_8822B(v))
#define BIT_SYSON_DBG_PAD_E2_8822B BIT(11)
#define BIT_SYSON_LED_PAD_E2_8822B BIT(10)
#define BIT_SYSON_GPEE_PAD_E2_8822B BIT(9)
#define BIT_SYSON_PCI_PAD_E2_8822B BIT(8)
#define BIT_AUTO_SW_LDO_VOL_EN_8822B BIT(7)
#define BIT_SHIFT_SYSON_SPS0WWV_WT_8822B 4
#define BIT_MASK_SYSON_SPS0WWV_WT_8822B 0x3
#define BIT_SYSON_SPS0WWV_WT_8822B(x) \
(((x) & BIT_MASK_SYSON_SPS0WWV_WT_8822B) \
<< BIT_SHIFT_SYSON_SPS0WWV_WT_8822B)
#define BITS_SYSON_SPS0WWV_WT_8822B \
(BIT_MASK_SYSON_SPS0WWV_WT_8822B << BIT_SHIFT_SYSON_SPS0WWV_WT_8822B)
#define BIT_CLEAR_SYSON_SPS0WWV_WT_8822B(x) \
((x) & (~BITS_SYSON_SPS0WWV_WT_8822B))
#define BIT_GET_SYSON_SPS0WWV_WT_8822B(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0WWV_WT_8822B) & \
BIT_MASK_SYSON_SPS0WWV_WT_8822B)
#define BIT_SET_SYSON_SPS0WWV_WT_8822B(x, v) \
(BIT_CLEAR_SYSON_SPS0WWV_WT_8822B(x) | BIT_SYSON_SPS0WWV_WT_8822B(v))
#define BIT_SHIFT_SYSON_SPS0LDO_WT_8822B 2
#define BIT_MASK_SYSON_SPS0LDO_WT_8822B 0x3
#define BIT_SYSON_SPS0LDO_WT_8822B(x) \
(((x) & BIT_MASK_SYSON_SPS0LDO_WT_8822B) \
<< BIT_SHIFT_SYSON_SPS0LDO_WT_8822B)
#define BITS_SYSON_SPS0LDO_WT_8822B \
(BIT_MASK_SYSON_SPS0LDO_WT_8822B << BIT_SHIFT_SYSON_SPS0LDO_WT_8822B)
#define BIT_CLEAR_SYSON_SPS0LDO_WT_8822B(x) \
((x) & (~BITS_SYSON_SPS0LDO_WT_8822B))
#define BIT_GET_SYSON_SPS0LDO_WT_8822B(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0LDO_WT_8822B) & \
BIT_MASK_SYSON_SPS0LDO_WT_8822B)
#define BIT_SET_SYSON_SPS0LDO_WT_8822B(x, v) \
(BIT_CLEAR_SYSON_SPS0LDO_WT_8822B(x) | BIT_SYSON_SPS0LDO_WT_8822B(v))
#define BIT_SHIFT_SYSON_RCLK_SCALE_8822B 0
#define BIT_MASK_SYSON_RCLK_SCALE_8822B 0x3
#define BIT_SYSON_RCLK_SCALE_8822B(x) \
(((x) & BIT_MASK_SYSON_RCLK_SCALE_8822B) \
<< BIT_SHIFT_SYSON_RCLK_SCALE_8822B)
#define BITS_SYSON_RCLK_SCALE_8822B \
(BIT_MASK_SYSON_RCLK_SCALE_8822B << BIT_SHIFT_SYSON_RCLK_SCALE_8822B)
#define BIT_CLEAR_SYSON_RCLK_SCALE_8822B(x) \
((x) & (~BITS_SYSON_RCLK_SCALE_8822B))
#define BIT_GET_SYSON_RCLK_SCALE_8822B(x) \
(((x) >> BIT_SHIFT_SYSON_RCLK_SCALE_8822B) & \
BIT_MASK_SYSON_RCLK_SCALE_8822B)
#define BIT_SET_SYSON_RCLK_SCALE_8822B(x, v) \
(BIT_CLEAR_SYSON_RCLK_SCALE_8822B(x) | BIT_SYSON_RCLK_SCALE_8822B(v))
/* 2 REG_CAL_TIMER_8822B */
#define BIT_SHIFT_MATCH_CNT_8822B 8
#define BIT_MASK_MATCH_CNT_8822B 0xff
#define BIT_MATCH_CNT_8822B(x) \
(((x) & BIT_MASK_MATCH_CNT_8822B) << BIT_SHIFT_MATCH_CNT_8822B)
#define BITS_MATCH_CNT_8822B \
(BIT_MASK_MATCH_CNT_8822B << BIT_SHIFT_MATCH_CNT_8822B)
#define BIT_CLEAR_MATCH_CNT_8822B(x) ((x) & (~BITS_MATCH_CNT_8822B))
#define BIT_GET_MATCH_CNT_8822B(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8822B) & BIT_MASK_MATCH_CNT_8822B)
#define BIT_SET_MATCH_CNT_8822B(x, v) \
(BIT_CLEAR_MATCH_CNT_8822B(x) | BIT_MATCH_CNT_8822B(v))
#define BIT_SHIFT_CAL_SCAL_8822B 0
#define BIT_MASK_CAL_SCAL_8822B 0xff
#define BIT_CAL_SCAL_8822B(x) \
(((x) & BIT_MASK_CAL_SCAL_8822B) << BIT_SHIFT_CAL_SCAL_8822B)
#define BITS_CAL_SCAL_8822B \
(BIT_MASK_CAL_SCAL_8822B << BIT_SHIFT_CAL_SCAL_8822B)
#define BIT_CLEAR_CAL_SCAL_8822B(x) ((x) & (~BITS_CAL_SCAL_8822B))
#define BIT_GET_CAL_SCAL_8822B(x) \
(((x) >> BIT_SHIFT_CAL_SCAL_8822B) & BIT_MASK_CAL_SCAL_8822B)
#define BIT_SET_CAL_SCAL_8822B(x, v) \
(BIT_CLEAR_CAL_SCAL_8822B(x) | BIT_CAL_SCAL_8822B(v))
/* 2 REG_ACLK_MON_8822B */
#define BIT_SHIFT_RCLK_MON_8822B 5
#define BIT_MASK_RCLK_MON_8822B 0x7ff
#define BIT_RCLK_MON_8822B(x) \
(((x) & BIT_MASK_RCLK_MON_8822B) << BIT_SHIFT_RCLK_MON_8822B)
#define BITS_RCLK_MON_8822B \
(BIT_MASK_RCLK_MON_8822B << BIT_SHIFT_RCLK_MON_8822B)
#define BIT_CLEAR_RCLK_MON_8822B(x) ((x) & (~BITS_RCLK_MON_8822B))
#define BIT_GET_RCLK_MON_8822B(x) \
(((x) >> BIT_SHIFT_RCLK_MON_8822B) & BIT_MASK_RCLK_MON_8822B)
#define BIT_SET_RCLK_MON_8822B(x, v) \
(BIT_CLEAR_RCLK_MON_8822B(x) | BIT_RCLK_MON_8822B(v))
#define BIT_CAL_EN_8822B BIT(4)
#define BIT_SHIFT_DPSTU_8822B 2
#define BIT_MASK_DPSTU_8822B 0x3
#define BIT_DPSTU_8822B(x) \
(((x) & BIT_MASK_DPSTU_8822B) << BIT_SHIFT_DPSTU_8822B)
#define BITS_DPSTU_8822B (BIT_MASK_DPSTU_8822B << BIT_SHIFT_DPSTU_8822B)
#define BIT_CLEAR_DPSTU_8822B(x) ((x) & (~BITS_DPSTU_8822B))
#define BIT_GET_DPSTU_8822B(x) \
(((x) >> BIT_SHIFT_DPSTU_8822B) & BIT_MASK_DPSTU_8822B)
#define BIT_SET_DPSTU_8822B(x, v) \
(BIT_CLEAR_DPSTU_8822B(x) | BIT_DPSTU_8822B(v))
#define BIT_SUS_16X_8822B BIT(1)
/* 2 REG_GPIO_MUXCFG_8822B */
#define BIT_FSPI_EN_8822B BIT(19)
#define BIT_WL_RTS_EXT_32K_SEL_8822B BIT(18)
#define BIT_WLGP_SPI_EN_8822B BIT(16)
#define BIT_SIC_LBK_8822B BIT(15)
#define BIT_ENHTP_8822B BIT(14)
#define BIT_ENSIC_8822B BIT(12)
#define BIT_SIC_SWRST_8822B BIT(11)
#define BIT_PO_WIFI_PTA_PINS_8822B BIT(10)
#define BIT_PO_BT_PTA_PINS_8822B BIT(9)
#define BIT_ENUART_8822B BIT(8)
#define BIT_SHIFT_BTMODE_8822B 6
#define BIT_MASK_BTMODE_8822B 0x3
#define BIT_BTMODE_8822B(x) \
(((x) & BIT_MASK_BTMODE_8822B) << BIT_SHIFT_BTMODE_8822B)
#define BITS_BTMODE_8822B (BIT_MASK_BTMODE_8822B << BIT_SHIFT_BTMODE_8822B)
#define BIT_CLEAR_BTMODE_8822B(x) ((x) & (~BITS_BTMODE_8822B))
#define BIT_GET_BTMODE_8822B(x) \
(((x) >> BIT_SHIFT_BTMODE_8822B) & BIT_MASK_BTMODE_8822B)
#define BIT_SET_BTMODE_8822B(x, v) \
(BIT_CLEAR_BTMODE_8822B(x) | BIT_BTMODE_8822B(v))
#define BIT_ENBT_8822B BIT(5)
#define BIT_EROM_EN_8822B BIT(4)
#define BIT_WLRFE_6_7_EN_8822B BIT(3)
#define BIT_WLRFE_4_5_EN_8822B BIT(2)
#define BIT_SHIFT_GPIOSEL_8822B 0
#define BIT_MASK_GPIOSEL_8822B 0x3
#define BIT_GPIOSEL_8822B(x) \
(((x) & BIT_MASK_GPIOSEL_8822B) << BIT_SHIFT_GPIOSEL_8822B)
#define BITS_GPIOSEL_8822B (BIT_MASK_GPIOSEL_8822B << BIT_SHIFT_GPIOSEL_8822B)
#define BIT_CLEAR_GPIOSEL_8822B(x) ((x) & (~BITS_GPIOSEL_8822B))
#define BIT_GET_GPIOSEL_8822B(x) \
(((x) >> BIT_SHIFT_GPIOSEL_8822B) & BIT_MASK_GPIOSEL_8822B)
#define BIT_SET_GPIOSEL_8822B(x, v) \
(BIT_CLEAR_GPIOSEL_8822B(x) | BIT_GPIOSEL_8822B(v))
/* 2 REG_GPIO_PIN_CTRL_8822B */
#define BIT_SHIFT_GPIO_MOD_7_TO_0_8822B 24
#define BIT_MASK_GPIO_MOD_7_TO_0_8822B 0xff
#define BIT_GPIO_MOD_7_TO_0_8822B(x) \
(((x) & BIT_MASK_GPIO_MOD_7_TO_0_8822B) \
<< BIT_SHIFT_GPIO_MOD_7_TO_0_8822B)
#define BITS_GPIO_MOD_7_TO_0_8822B \
(BIT_MASK_GPIO_MOD_7_TO_0_8822B << BIT_SHIFT_GPIO_MOD_7_TO_0_8822B)
#define BIT_CLEAR_GPIO_MOD_7_TO_0_8822B(x) ((x) & (~BITS_GPIO_MOD_7_TO_0_8822B))
#define BIT_GET_GPIO_MOD_7_TO_0_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_7_TO_0_8822B) & \
BIT_MASK_GPIO_MOD_7_TO_0_8822B)
#define BIT_SET_GPIO_MOD_7_TO_0_8822B(x, v) \
(BIT_CLEAR_GPIO_MOD_7_TO_0_8822B(x) | BIT_GPIO_MOD_7_TO_0_8822B(v))
#define BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822B 16
#define BIT_MASK_GPIO_IO_SEL_7_TO_0_8822B 0xff
#define BIT_GPIO_IO_SEL_7_TO_0_8822B(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_7_TO_0_8822B) \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822B)
#define BITS_GPIO_IO_SEL_7_TO_0_8822B \
(BIT_MASK_GPIO_IO_SEL_7_TO_0_8822B \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822B)
#define BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8822B(x) \
((x) & (~BITS_GPIO_IO_SEL_7_TO_0_8822B))
#define BIT_GET_GPIO_IO_SEL_7_TO_0_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822B) & \
BIT_MASK_GPIO_IO_SEL_7_TO_0_8822B)
#define BIT_SET_GPIO_IO_SEL_7_TO_0_8822B(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8822B(x) | \
BIT_GPIO_IO_SEL_7_TO_0_8822B(v))
#define BIT_SHIFT_GPIO_OUT_7_TO_0_8822B 8
#define BIT_MASK_GPIO_OUT_7_TO_0_8822B 0xff
#define BIT_GPIO_OUT_7_TO_0_8822B(x) \
(((x) & BIT_MASK_GPIO_OUT_7_TO_0_8822B) \
<< BIT_SHIFT_GPIO_OUT_7_TO_0_8822B)
#define BITS_GPIO_OUT_7_TO_0_8822B \
(BIT_MASK_GPIO_OUT_7_TO_0_8822B << BIT_SHIFT_GPIO_OUT_7_TO_0_8822B)
#define BIT_CLEAR_GPIO_OUT_7_TO_0_8822B(x) ((x) & (~BITS_GPIO_OUT_7_TO_0_8822B))
#define BIT_GET_GPIO_OUT_7_TO_0_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_7_TO_0_8822B) & \
BIT_MASK_GPIO_OUT_7_TO_0_8822B)
#define BIT_SET_GPIO_OUT_7_TO_0_8822B(x, v) \
(BIT_CLEAR_GPIO_OUT_7_TO_0_8822B(x) | BIT_GPIO_OUT_7_TO_0_8822B(v))
#define BIT_SHIFT_GPIO_IN_7_TO_0_8822B 0
#define BIT_MASK_GPIO_IN_7_TO_0_8822B 0xff
#define BIT_GPIO_IN_7_TO_0_8822B(x) \
(((x) & BIT_MASK_GPIO_IN_7_TO_0_8822B) \
<< BIT_SHIFT_GPIO_IN_7_TO_0_8822B)
#define BITS_GPIO_IN_7_TO_0_8822B \
(BIT_MASK_GPIO_IN_7_TO_0_8822B << BIT_SHIFT_GPIO_IN_7_TO_0_8822B)
#define BIT_CLEAR_GPIO_IN_7_TO_0_8822B(x) ((x) & (~BITS_GPIO_IN_7_TO_0_8822B))
#define BIT_GET_GPIO_IN_7_TO_0_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_IN_7_TO_0_8822B) & \
BIT_MASK_GPIO_IN_7_TO_0_8822B)
#define BIT_SET_GPIO_IN_7_TO_0_8822B(x, v) \
(BIT_CLEAR_GPIO_IN_7_TO_0_8822B(x) | BIT_GPIO_IN_7_TO_0_8822B(v))
/* 2 REG_GPIO_INTM_8822B */
#define BIT_SHIFT_MUXDBG_SEL_8822B 30
#define BIT_MASK_MUXDBG_SEL_8822B 0x3
#define BIT_MUXDBG_SEL_8822B(x) \
(((x) & BIT_MASK_MUXDBG_SEL_8822B) << BIT_SHIFT_MUXDBG_SEL_8822B)
#define BITS_MUXDBG_SEL_8822B \
(BIT_MASK_MUXDBG_SEL_8822B << BIT_SHIFT_MUXDBG_SEL_8822B)
#define BIT_CLEAR_MUXDBG_SEL_8822B(x) ((x) & (~BITS_MUXDBG_SEL_8822B))
#define BIT_GET_MUXDBG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL_8822B) & BIT_MASK_MUXDBG_SEL_8822B)
#define BIT_SET_MUXDBG_SEL_8822B(x, v) \
(BIT_CLEAR_MUXDBG_SEL_8822B(x) | BIT_MUXDBG_SEL_8822B(v))
#define BIT_EXTWOL_SEL_8822B BIT(17)
#define BIT_EXTWOL_EN_8822B BIT(16)
#define BIT_GPIOF_INT_MD_8822B BIT(15)
#define BIT_GPIOE_INT_MD_8822B BIT(14)
#define BIT_GPIOD_INT_MD_8822B BIT(13)
#define BIT_GPIOF_INT_MD_8822B BIT(15)
#define BIT_GPIOE_INT_MD_8822B BIT(14)
#define BIT_GPIOD_INT_MD_8822B BIT(13)
#define BIT_GPIOC_INT_MD_8822B BIT(12)
#define BIT_GPIOB_INT_MD_8822B BIT(11)
#define BIT_GPIOA_INT_MD_8822B BIT(10)
#define BIT_GPIO9_INT_MD_8822B BIT(9)
#define BIT_GPIO8_INT_MD_8822B BIT(8)
#define BIT_GPIO7_INT_MD_8822B BIT(7)
#define BIT_GPIO6_INT_MD_8822B BIT(6)
#define BIT_GPIO5_INT_MD_8822B BIT(5)
#define BIT_GPIO4_INT_MD_8822B BIT(4)
#define BIT_GPIO3_INT_MD_8822B BIT(3)
#define BIT_GPIO2_INT_MD_8822B BIT(2)
#define BIT_GPIO1_INT_MD_8822B BIT(1)
#define BIT_GPIO0_INT_MD_8822B BIT(0)
/* 2 REG_LED_CFG_8822B */
#define BIT_GPIO3_WL_CTRL_EN_8822B BIT(27)
#define BIT_LNAON_SEL_EN_8822B BIT(26)
#define BIT_PAPE_SEL_EN_8822B BIT(25)
#define BIT_DPDT_WLBT_SEL_8822B BIT(24)
#define BIT_DPDT_SEL_EN_8822B BIT(23)
#define BIT_GPIO13_14_WL_CTRL_EN_8822B BIT(22)
#define BIT_GPIO13_14_WL_CTRL_EN_8822B BIT(22)
#define BIT_LED2DIS_8822B BIT(21)
#define BIT_LED2PL_8822B BIT(20)
#define BIT_LED2SV_8822B BIT(19)
#define BIT_SHIFT_LED2CM_8822B 16
#define BIT_MASK_LED2CM_8822B 0x7
#define BIT_LED2CM_8822B(x) \
(((x) & BIT_MASK_LED2CM_8822B) << BIT_SHIFT_LED2CM_8822B)
#define BITS_LED2CM_8822B (BIT_MASK_LED2CM_8822B << BIT_SHIFT_LED2CM_8822B)
#define BIT_CLEAR_LED2CM_8822B(x) ((x) & (~BITS_LED2CM_8822B))
#define BIT_GET_LED2CM_8822B(x) \
(((x) >> BIT_SHIFT_LED2CM_8822B) & BIT_MASK_LED2CM_8822B)
#define BIT_SET_LED2CM_8822B(x, v) \
(BIT_CLEAR_LED2CM_8822B(x) | BIT_LED2CM_8822B(v))
#define BIT_LED1DIS_8822B BIT(15)
#define BIT_LED1PL_8822B BIT(12)
#define BIT_LED1SV_8822B BIT(11)
#define BIT_SHIFT_LED1CM_8822B 8
#define BIT_MASK_LED1CM_8822B 0x7
#define BIT_LED1CM_8822B(x) \
(((x) & BIT_MASK_LED1CM_8822B) << BIT_SHIFT_LED1CM_8822B)
#define BITS_LED1CM_8822B (BIT_MASK_LED1CM_8822B << BIT_SHIFT_LED1CM_8822B)
#define BIT_CLEAR_LED1CM_8822B(x) ((x) & (~BITS_LED1CM_8822B))
#define BIT_GET_LED1CM_8822B(x) \
(((x) >> BIT_SHIFT_LED1CM_8822B) & BIT_MASK_LED1CM_8822B)
#define BIT_SET_LED1CM_8822B(x, v) \
(BIT_CLEAR_LED1CM_8822B(x) | BIT_LED1CM_8822B(v))
#define BIT_LED0DIS_8822B BIT(7)
#define BIT_SHIFT_AFE_LDO_SWR_CHECK_8822B 5
#define BIT_MASK_AFE_LDO_SWR_CHECK_8822B 0x3
#define BIT_AFE_LDO_SWR_CHECK_8822B(x) \
(((x) & BIT_MASK_AFE_LDO_SWR_CHECK_8822B) \
<< BIT_SHIFT_AFE_LDO_SWR_CHECK_8822B)
#define BITS_AFE_LDO_SWR_CHECK_8822B \
(BIT_MASK_AFE_LDO_SWR_CHECK_8822B << BIT_SHIFT_AFE_LDO_SWR_CHECK_8822B)
#define BIT_CLEAR_AFE_LDO_SWR_CHECK_8822B(x) \
((x) & (~BITS_AFE_LDO_SWR_CHECK_8822B))
#define BIT_GET_AFE_LDO_SWR_CHECK_8822B(x) \
(((x) >> BIT_SHIFT_AFE_LDO_SWR_CHECK_8822B) & \
BIT_MASK_AFE_LDO_SWR_CHECK_8822B)
#define BIT_SET_AFE_LDO_SWR_CHECK_8822B(x, v) \
(BIT_CLEAR_AFE_LDO_SWR_CHECK_8822B(x) | BIT_AFE_LDO_SWR_CHECK_8822B(v))
#define BIT_LED0PL_8822B BIT(4)
#define BIT_LED0SV_8822B BIT(3)
#define BIT_SHIFT_LED0CM_8822B 0
#define BIT_MASK_LED0CM_8822B 0x7
#define BIT_LED0CM_8822B(x) \
(((x) & BIT_MASK_LED0CM_8822B) << BIT_SHIFT_LED0CM_8822B)
#define BITS_LED0CM_8822B (BIT_MASK_LED0CM_8822B << BIT_SHIFT_LED0CM_8822B)
#define BIT_CLEAR_LED0CM_8822B(x) ((x) & (~BITS_LED0CM_8822B))
#define BIT_GET_LED0CM_8822B(x) \
(((x) >> BIT_SHIFT_LED0CM_8822B) & BIT_MASK_LED0CM_8822B)
#define BIT_SET_LED0CM_8822B(x, v) \
(BIT_CLEAR_LED0CM_8822B(x) | BIT_LED0CM_8822B(v))
/* 2 REG_FSIMR_8822B */
#define BIT_FS_PDNINT_EN_8822B BIT(31)
#define BIT_NFC_INT_PAD_EN_8822B BIT(30)
#define BIT_FS_SPS_OCP_INT_EN_8822B BIT(29)
#define BIT_FS_PWMERR_INT_EN_8822B BIT(28)
#define BIT_FS_GPIOF_INT_EN_8822B BIT(27)
#define BIT_FS_GPIOE_INT_EN_8822B BIT(26)
#define BIT_FS_GPIOD_INT_EN_8822B BIT(25)
#define BIT_FS_GPIOC_INT_EN_8822B BIT(24)
#define BIT_FS_GPIOB_INT_EN_8822B BIT(23)
#define BIT_FS_GPIOA_INT_EN_8822B BIT(22)
#define BIT_FS_GPIO9_INT_EN_8822B BIT(21)
#define BIT_FS_GPIO8_INT_EN_8822B BIT(20)
#define BIT_FS_GPIO7_INT_EN_8822B BIT(19)
#define BIT_FS_GPIO6_INT_EN_8822B BIT(18)
#define BIT_FS_GPIO5_INT_EN_8822B BIT(17)
#define BIT_FS_GPIO4_INT_EN_8822B BIT(16)
#define BIT_FS_GPIO3_INT_EN_8822B BIT(15)
#define BIT_FS_GPIO2_INT_EN_8822B BIT(14)
#define BIT_FS_GPIO1_INT_EN_8822B BIT(13)
#define BIT_FS_GPIO0_INT_EN_8822B BIT(12)
#define BIT_FS_HCI_SUS_EN_8822B BIT(11)
#define BIT_FS_HCI_RES_EN_8822B BIT(10)
#define BIT_FS_HCI_RESET_EN_8822B BIT(9)
#define BIT_FS_BTON_STS_UPDATE_MSK_EN_8822B BIT(7)
#define BIT_ACT2RECOVERY_INT_EN_V1_8822B BIT(6)
#define BIT_GEN1GEN2_SWITCH_8822B BIT(5)
#define BIT_HCI_TXDMA_REQ_HIMR_8822B BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_MAK_8822B BIT(3)
#define BIT_FS_32K_ENTER_SETTING_MAK_8822B BIT(2)
#define BIT_FS_USB_LPMRSM_MSK_8822B BIT(1)
#define BIT_FS_USB_LPMINT_MSK_8822B BIT(0)
/* 2 REG_FSISR_8822B */
#define BIT_FS_PDNINT_8822B BIT(31)
#define BIT_FS_SPS_OCP_INT_8822B BIT(29)
#define BIT_FS_PWMERR_INT_8822B BIT(28)
#define BIT_FS_GPIOF_INT_8822B BIT(27)
#define BIT_FS_GPIOE_INT_8822B BIT(26)
#define BIT_FS_GPIOD_INT_8822B BIT(25)
#define BIT_FS_GPIOC_INT_8822B BIT(24)
#define BIT_FS_GPIOB_INT_8822B BIT(23)
#define BIT_FS_GPIOA_INT_8822B BIT(22)
#define BIT_FS_GPIO9_INT_8822B BIT(21)
#define BIT_FS_GPIO8_INT_8822B BIT(20)
#define BIT_FS_GPIO7_INT_8822B BIT(19)
#define BIT_FS_GPIO6_INT_8822B BIT(18)
#define BIT_FS_GPIO5_INT_8822B BIT(17)
#define BIT_FS_GPIO4_INT_8822B BIT(16)
#define BIT_FS_GPIO3_INT_8822B BIT(15)
#define BIT_FS_GPIO2_INT_8822B BIT(14)
#define BIT_FS_GPIO1_INT_8822B BIT(13)
#define BIT_FS_GPIO0_INT_8822B BIT(12)
#define BIT_FS_HCI_SUS_INT_8822B BIT(11)
#define BIT_FS_HCI_RES_INT_8822B BIT(10)
#define BIT_FS_HCI_RESET_INT_8822B BIT(9)
#define BIT_ACT2RECOVERY_8822B BIT(6)
#define BIT_GEN1GEN2_SWITCH_8822B BIT(5)
#define BIT_HCI_TXDMA_REQ_HISR_8822B BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_INT_8822B BIT(3)
#define BIT_FS_32K_ENTER_SETTING_INT_8822B BIT(2)
#define BIT_FS_USB_LPMRSM_INT_8822B BIT(1)
#define BIT_FS_USB_LPMINT_INT_8822B BIT(0)
/* 2 REG_HSIMR_8822B */
#define BIT_GPIOF_INT_EN_8822B BIT(31)
#define BIT_GPIOE_INT_EN_8822B BIT(30)
#define BIT_GPIOD_INT_EN_8822B BIT(29)
#define BIT_GPIOC_INT_EN_8822B BIT(28)
#define BIT_GPIOB_INT_EN_8822B BIT(27)
#define BIT_GPIOA_INT_EN_8822B BIT(26)
#define BIT_GPIO9_INT_EN_8822B BIT(25)
#define BIT_GPIO8_INT_EN_8822B BIT(24)
#define BIT_GPIO7_INT_EN_8822B BIT(23)
#define BIT_GPIO6_INT_EN_8822B BIT(22)
#define BIT_GPIO5_INT_EN_8822B BIT(21)
#define BIT_GPIO4_INT_EN_8822B BIT(20)
#define BIT_GPIO3_INT_EN_8822B BIT(19)
#define BIT_GPIO2_INT_EN_V1_8822B BIT(18)
#define BIT_GPIO1_INT_EN_8822B BIT(17)
#define BIT_GPIO0_INT_EN_8822B BIT(16)
#define BIT_PDNINT_EN_8822B BIT(7)
#define BIT_RON_INT_EN_8822B BIT(6)
#define BIT_SPS_OCP_INT_EN_8822B BIT(5)
#define BIT_GPIO15_0_INT_EN_8822B BIT(0)
/* 2 REG_HSISR_8822B */
#define BIT_GPIOF_INT_8822B BIT(31)
#define BIT_GPIOE_INT_8822B BIT(30)
#define BIT_GPIOD_INT_8822B BIT(29)
#define BIT_GPIOC_INT_8822B BIT(28)
#define BIT_GPIOB_INT_8822B BIT(27)
#define BIT_GPIOA_INT_8822B BIT(26)
#define BIT_GPIO9_INT_8822B BIT(25)
#define BIT_GPIO8_INT_8822B BIT(24)
#define BIT_GPIO7_INT_8822B BIT(23)
#define BIT_GPIO6_INT_8822B BIT(22)
#define BIT_GPIO5_INT_8822B BIT(21)
#define BIT_GPIO4_INT_8822B BIT(20)
#define BIT_GPIO3_INT_8822B BIT(19)
#define BIT_GPIO2_INT_V1_8822B BIT(18)
#define BIT_GPIO1_INT_8822B BIT(17)
#define BIT_GPIO0_INT_8822B BIT(16)
#define BIT_PDNINT_8822B BIT(7)
#define BIT_RON_INT_8822B BIT(6)
#define BIT_SPS_OCP_INT_8822B BIT(5)
#define BIT_GPIO15_0_INT_8822B BIT(0)
/* 2 REG_GPIO_EXT_CTRL_8822B */
#define BIT_SHIFT_GPIO_MOD_15_TO_8_8822B 24
#define BIT_MASK_GPIO_MOD_15_TO_8_8822B 0xff
#define BIT_GPIO_MOD_15_TO_8_8822B(x) \
(((x) & BIT_MASK_GPIO_MOD_15_TO_8_8822B) \
<< BIT_SHIFT_GPIO_MOD_15_TO_8_8822B)
#define BITS_GPIO_MOD_15_TO_8_8822B \
(BIT_MASK_GPIO_MOD_15_TO_8_8822B << BIT_SHIFT_GPIO_MOD_15_TO_8_8822B)
#define BIT_CLEAR_GPIO_MOD_15_TO_8_8822B(x) \
((x) & (~BITS_GPIO_MOD_15_TO_8_8822B))
#define BIT_GET_GPIO_MOD_15_TO_8_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_15_TO_8_8822B) & \
BIT_MASK_GPIO_MOD_15_TO_8_8822B)
#define BIT_SET_GPIO_MOD_15_TO_8_8822B(x, v) \
(BIT_CLEAR_GPIO_MOD_15_TO_8_8822B(x) | BIT_GPIO_MOD_15_TO_8_8822B(v))
#define BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822B 16
#define BIT_MASK_GPIO_IO_SEL_15_TO_8_8822B 0xff
#define BIT_GPIO_IO_SEL_15_TO_8_8822B(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_15_TO_8_8822B) \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822B)
#define BITS_GPIO_IO_SEL_15_TO_8_8822B \
(BIT_MASK_GPIO_IO_SEL_15_TO_8_8822B \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822B)
#define BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8822B(x) \
((x) & (~BITS_GPIO_IO_SEL_15_TO_8_8822B))
#define BIT_GET_GPIO_IO_SEL_15_TO_8_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822B) & \
BIT_MASK_GPIO_IO_SEL_15_TO_8_8822B)
#define BIT_SET_GPIO_IO_SEL_15_TO_8_8822B(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8822B(x) | \
BIT_GPIO_IO_SEL_15_TO_8_8822B(v))
#define BIT_SHIFT_GPIO_OUT_15_TO_8_8822B 8
#define BIT_MASK_GPIO_OUT_15_TO_8_8822B 0xff
#define BIT_GPIO_OUT_15_TO_8_8822B(x) \
(((x) & BIT_MASK_GPIO_OUT_15_TO_8_8822B) \
<< BIT_SHIFT_GPIO_OUT_15_TO_8_8822B)
#define BITS_GPIO_OUT_15_TO_8_8822B \
(BIT_MASK_GPIO_OUT_15_TO_8_8822B << BIT_SHIFT_GPIO_OUT_15_TO_8_8822B)
#define BIT_CLEAR_GPIO_OUT_15_TO_8_8822B(x) \
((x) & (~BITS_GPIO_OUT_15_TO_8_8822B))
#define BIT_GET_GPIO_OUT_15_TO_8_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_15_TO_8_8822B) & \
BIT_MASK_GPIO_OUT_15_TO_8_8822B)
#define BIT_SET_GPIO_OUT_15_TO_8_8822B(x, v) \
(BIT_CLEAR_GPIO_OUT_15_TO_8_8822B(x) | BIT_GPIO_OUT_15_TO_8_8822B(v))
#define BIT_SHIFT_GPIO_IN_15_TO_8_8822B 0
#define BIT_MASK_GPIO_IN_15_TO_8_8822B 0xff
#define BIT_GPIO_IN_15_TO_8_8822B(x) \
(((x) & BIT_MASK_GPIO_IN_15_TO_8_8822B) \
<< BIT_SHIFT_GPIO_IN_15_TO_8_8822B)
#define BITS_GPIO_IN_15_TO_8_8822B \
(BIT_MASK_GPIO_IN_15_TO_8_8822B << BIT_SHIFT_GPIO_IN_15_TO_8_8822B)
#define BIT_CLEAR_GPIO_IN_15_TO_8_8822B(x) ((x) & (~BITS_GPIO_IN_15_TO_8_8822B))
#define BIT_GET_GPIO_IN_15_TO_8_8822B(x) \
(((x) >> BIT_SHIFT_GPIO_IN_15_TO_8_8822B) & \
BIT_MASK_GPIO_IN_15_TO_8_8822B)
#define BIT_SET_GPIO_IN_15_TO_8_8822B(x, v) \
(BIT_CLEAR_GPIO_IN_15_TO_8_8822B(x) | BIT_GPIO_IN_15_TO_8_8822B(v))
/* 2 REG_PAD_CTRL1_8822B */
#define BIT_PAPE_WLBT_SEL_8822B BIT(29)
#define BIT_LNAON_WLBT_SEL_8822B BIT(28)
#define BIT_BTGP_GPG3_FEN_8822B BIT(26)
#define BIT_BTGP_GPG2_FEN_8822B BIT(25)
#define BIT_BTGP_JTAG_EN_8822B BIT(24)
#define BIT_XTAL_CLK_EXTARNAL_EN_8822B BIT(23)
#define BIT_BTGP_UART0_EN_8822B BIT(22)
#define BIT_BTGP_UART1_EN_8822B BIT(21)
#define BIT_BTGP_SPI_EN_8822B BIT(20)
#define BIT_BTGP_GPIO_E2_8822B BIT(19)
#define BIT_BTGP_GPIO_EN_8822B BIT(18)
#define BIT_SHIFT_BTGP_GPIO_SL_8822B 16
#define BIT_MASK_BTGP_GPIO_SL_8822B 0x3
#define BIT_BTGP_GPIO_SL_8822B(x) \
(((x) & BIT_MASK_BTGP_GPIO_SL_8822B) << BIT_SHIFT_BTGP_GPIO_SL_8822B)
#define BITS_BTGP_GPIO_SL_8822B \
(BIT_MASK_BTGP_GPIO_SL_8822B << BIT_SHIFT_BTGP_GPIO_SL_8822B)
#define BIT_CLEAR_BTGP_GPIO_SL_8822B(x) ((x) & (~BITS_BTGP_GPIO_SL_8822B))
#define BIT_GET_BTGP_GPIO_SL_8822B(x) \
(((x) >> BIT_SHIFT_BTGP_GPIO_SL_8822B) & BIT_MASK_BTGP_GPIO_SL_8822B)
#define BIT_SET_BTGP_GPIO_SL_8822B(x, v) \
(BIT_CLEAR_BTGP_GPIO_SL_8822B(x) | BIT_BTGP_GPIO_SL_8822B(v))
#define BIT_PAD_SDIO_SR_8822B BIT(14)
#define BIT_GPIO14_OUTPUT_PL_8822B BIT(13)
#define BIT_HOST_WAKE_PAD_PULL_EN_8822B BIT(12)
#define BIT_HOST_WAKE_PAD_SL_8822B BIT(11)
#define BIT_PAD_LNAON_SR_8822B BIT(10)
#define BIT_PAD_LNAON_E2_8822B BIT(9)
#define BIT_SW_LNAON_G_SEL_DATA_8822B BIT(8)
#define BIT_SW_LNAON_A_SEL_DATA_8822B BIT(7)
#define BIT_PAD_PAPE_SR_8822B BIT(6)
#define BIT_PAD_PAPE_E2_8822B BIT(5)
#define BIT_SW_PAPE_G_SEL_DATA_8822B BIT(4)
#define BIT_SW_PAPE_A_SEL_DATA_8822B BIT(3)
#define BIT_PAD_DPDT_SR_8822B BIT(2)
#define BIT_PAD_DPDT_PAD_E2_8822B BIT(1)
#define BIT_SW_DPDT_SEL_DATA_8822B BIT(0)
/* 2 REG_WL_BT_PWR_CTRL_8822B */
#define BIT_ISO_BD2PP_8822B BIT(31)
#define BIT_LDOV12B_EN_8822B BIT(30)
#define BIT_CKEN_BTGPS_8822B BIT(29)
#define BIT_FEN_BTGPS_8822B BIT(28)
#define BIT_BTCPU_BOOTSEL_8822B BIT(27)
#define BIT_SPI_SPEEDUP_8822B BIT(26)
#define BIT_DEVWAKE_PAD_TYPE_SEL_8822B BIT(24)
#define BIT_CLKREQ_PAD_TYPE_SEL_8822B BIT(23)
#define BIT_ISO_BTPON2PP_8822B BIT(22)
#define BIT_BT_HWROF_EN_8822B BIT(19)
#define BIT_BT_FUNC_EN_8822B BIT(18)
#define BIT_BT_HWPDN_SL_8822B BIT(17)
#define BIT_BT_DISN_EN_8822B BIT(16)
#define BIT_BT_PDN_PULL_EN_8822B BIT(15)
#define BIT_WL_PDN_PULL_EN_8822B BIT(14)
#define BIT_EXTERNAL_REQUEST_PL_8822B BIT(13)
#define BIT_GPIO0_2_3_PULL_LOW_EN_8822B BIT(12)
#define BIT_ISO_BA2PP_8822B BIT(11)
#define BIT_BT_AFE_LDO_EN_8822B BIT(10)
#define BIT_BT_AFE_PLL_EN_8822B BIT(9)
#define BIT_BT_DIG_CLK_EN_8822B BIT(8)
#define BIT_WL_DRV_EXIST_IDX_8822B BIT(5)
#define BIT_DOP_EHPAD_8822B BIT(4)
#define BIT_WL_HWROF_EN_8822B BIT(3)
#define BIT_WL_FUNC_EN_8822B BIT(2)
#define BIT_WL_HWPDN_SL_8822B BIT(1)
#define BIT_WL_HWPDN_EN_8822B BIT(0)
/* 2 REG_SDM_DEBUG_8822B */
#define BIT_SHIFT_WLCLK_PHASE_8822B 0
#define BIT_MASK_WLCLK_PHASE_8822B 0x1f
#define BIT_WLCLK_PHASE_8822B(x) \
(((x) & BIT_MASK_WLCLK_PHASE_8822B) << BIT_SHIFT_WLCLK_PHASE_8822B)
#define BITS_WLCLK_PHASE_8822B \
(BIT_MASK_WLCLK_PHASE_8822B << BIT_SHIFT_WLCLK_PHASE_8822B)
#define BIT_CLEAR_WLCLK_PHASE_8822B(x) ((x) & (~BITS_WLCLK_PHASE_8822B))
#define BIT_GET_WLCLK_PHASE_8822B(x) \
(((x) >> BIT_SHIFT_WLCLK_PHASE_8822B) & BIT_MASK_WLCLK_PHASE_8822B)
#define BIT_SET_WLCLK_PHASE_8822B(x, v) \
(BIT_CLEAR_WLCLK_PHASE_8822B(x) | BIT_WLCLK_PHASE_8822B(v))
/* 2 REG_SYS_SDIO_CTRL_8822B */
#define BIT_DBG_GNT_WL_BT_8822B BIT(27)
#define BIT_LTE_MUX_CTRL_PATH_8822B BIT(26)
#define BIT_LTE_COEX_UART_8822B BIT(25)
#define BIT_3W_LTE_WL_GPIO_8822B BIT(24)
#define BIT_SDIO_INT_POLARITY_8822B BIT(19)
#define BIT_SDIO_INT_8822B BIT(18)
#define BIT_SDIO_OFF_EN_8822B BIT(17)
#define BIT_SDIO_ON_EN_8822B BIT(16)
#define BIT_PCIE_WAIT_TIMEOUT_EVENT_8822B BIT(10)
#define BIT_PCIE_WAIT_TIME_8822B BIT(9)
#define BIT_MPCIE_REFCLK_XTAL_SEL_8822B BIT(8)
#define BIT_SHIFT_SI_AUTHORIZATION_8822B 0
#define BIT_MASK_SI_AUTHORIZATION_8822B 0xff
#define BIT_SI_AUTHORIZATION_8822B(x) \
(((x) & BIT_MASK_SI_AUTHORIZATION_8822B) \
<< BIT_SHIFT_SI_AUTHORIZATION_8822B)
#define BITS_SI_AUTHORIZATION_8822B \
(BIT_MASK_SI_AUTHORIZATION_8822B << BIT_SHIFT_SI_AUTHORIZATION_8822B)
#define BIT_CLEAR_SI_AUTHORIZATION_8822B(x) \
((x) & (~BITS_SI_AUTHORIZATION_8822B))
#define BIT_GET_SI_AUTHORIZATION_8822B(x) \
(((x) >> BIT_SHIFT_SI_AUTHORIZATION_8822B) & \
BIT_MASK_SI_AUTHORIZATION_8822B)
#define BIT_SET_SI_AUTHORIZATION_8822B(x, v) \
(BIT_CLEAR_SI_AUTHORIZATION_8822B(x) | BIT_SI_AUTHORIZATION_8822B(v))
/* 2 REG_HCI_OPT_CTRL_8822B */
#define BIT_SHIFT_TSFT_SEL_8822B 29
#define BIT_MASK_TSFT_SEL_8822B 0x7
#define BIT_TSFT_SEL_8822B(x) \
(((x) & BIT_MASK_TSFT_SEL_8822B) << BIT_SHIFT_TSFT_SEL_8822B)
#define BITS_TSFT_SEL_8822B \
(BIT_MASK_TSFT_SEL_8822B << BIT_SHIFT_TSFT_SEL_8822B)
#define BIT_CLEAR_TSFT_SEL_8822B(x) ((x) & (~BITS_TSFT_SEL_8822B))
#define BIT_GET_TSFT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_8822B) & BIT_MASK_TSFT_SEL_8822B)
#define BIT_SET_TSFT_SEL_8822B(x, v) \
(BIT_CLEAR_TSFT_SEL_8822B(x) | BIT_TSFT_SEL_8822B(v))
#define BIT_USB_HOST_PWR_OFF_EN_8822B BIT(12)
#define BIT_SYM_LPS_BLOCK_EN_8822B BIT(11)
#define BIT_USB_LPM_ACT_EN_8822B BIT(10)
#define BIT_USB_LPM_NY_8822B BIT(9)
#define BIT_USB_SUS_DIS_8822B BIT(8)
#define BIT_SHIFT_SDIO_PAD_E_8822B 5
#define BIT_MASK_SDIO_PAD_E_8822B 0x7
#define BIT_SDIO_PAD_E_8822B(x) \
(((x) & BIT_MASK_SDIO_PAD_E_8822B) << BIT_SHIFT_SDIO_PAD_E_8822B)
#define BITS_SDIO_PAD_E_8822B \
(BIT_MASK_SDIO_PAD_E_8822B << BIT_SHIFT_SDIO_PAD_E_8822B)
#define BIT_CLEAR_SDIO_PAD_E_8822B(x) ((x) & (~BITS_SDIO_PAD_E_8822B))
#define BIT_GET_SDIO_PAD_E_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_PAD_E_8822B) & BIT_MASK_SDIO_PAD_E_8822B)
#define BIT_SET_SDIO_PAD_E_8822B(x, v) \
(BIT_CLEAR_SDIO_PAD_E_8822B(x) | BIT_SDIO_PAD_E_8822B(v))
#define BIT_USB_LPPLL_EN_8822B BIT(4)
#define BIT_ROP_SW15_8822B BIT(2)
#define BIT_PCI_CKRDY_OPT_8822B BIT(1)
#define BIT_PCI_VAUX_EN_8822B BIT(0)
/* 2 REG_AFE_CTRL4_8822B */
/* 2 REG_LDO_SWR_CTRL_8822B */
#define BIT_ZCD_HW_AUTO_EN_8822B BIT(27)
#define BIT_ZCD_REGSEL_8822B BIT(26)
#define BIT_SHIFT_AUTO_ZCD_IN_CODE_8822B 21
#define BIT_MASK_AUTO_ZCD_IN_CODE_8822B 0x1f
#define BIT_AUTO_ZCD_IN_CODE_8822B(x) \
(((x) & BIT_MASK_AUTO_ZCD_IN_CODE_8822B) \
<< BIT_SHIFT_AUTO_ZCD_IN_CODE_8822B)
#define BITS_AUTO_ZCD_IN_CODE_8822B \
(BIT_MASK_AUTO_ZCD_IN_CODE_8822B << BIT_SHIFT_AUTO_ZCD_IN_CODE_8822B)
#define BIT_CLEAR_AUTO_ZCD_IN_CODE_8822B(x) \
((x) & (~BITS_AUTO_ZCD_IN_CODE_8822B))
#define BIT_GET_AUTO_ZCD_IN_CODE_8822B(x) \
(((x) >> BIT_SHIFT_AUTO_ZCD_IN_CODE_8822B) & \
BIT_MASK_AUTO_ZCD_IN_CODE_8822B)
#define BIT_SET_AUTO_ZCD_IN_CODE_8822B(x, v) \
(BIT_CLEAR_AUTO_ZCD_IN_CODE_8822B(x) | BIT_AUTO_ZCD_IN_CODE_8822B(v))
#define BIT_SHIFT_ZCD_CODE_IN_L_8822B 16
#define BIT_MASK_ZCD_CODE_IN_L_8822B 0x1f
#define BIT_ZCD_CODE_IN_L_8822B(x) \
(((x) & BIT_MASK_ZCD_CODE_IN_L_8822B) << BIT_SHIFT_ZCD_CODE_IN_L_8822B)
#define BITS_ZCD_CODE_IN_L_8822B \
(BIT_MASK_ZCD_CODE_IN_L_8822B << BIT_SHIFT_ZCD_CODE_IN_L_8822B)
#define BIT_CLEAR_ZCD_CODE_IN_L_8822B(x) ((x) & (~BITS_ZCD_CODE_IN_L_8822B))
#define BIT_GET_ZCD_CODE_IN_L_8822B(x) \
(((x) >> BIT_SHIFT_ZCD_CODE_IN_L_8822B) & BIT_MASK_ZCD_CODE_IN_L_8822B)
#define BIT_SET_ZCD_CODE_IN_L_8822B(x, v) \
(BIT_CLEAR_ZCD_CODE_IN_L_8822B(x) | BIT_ZCD_CODE_IN_L_8822B(v))
#define BIT_SHIFT_LDO_HV5_DUMMY_8822B 14
#define BIT_MASK_LDO_HV5_DUMMY_8822B 0x3
#define BIT_LDO_HV5_DUMMY_8822B(x) \
(((x) & BIT_MASK_LDO_HV5_DUMMY_8822B) << BIT_SHIFT_LDO_HV5_DUMMY_8822B)
#define BITS_LDO_HV5_DUMMY_8822B \
(BIT_MASK_LDO_HV5_DUMMY_8822B << BIT_SHIFT_LDO_HV5_DUMMY_8822B)
#define BIT_CLEAR_LDO_HV5_DUMMY_8822B(x) ((x) & (~BITS_LDO_HV5_DUMMY_8822B))
#define BIT_GET_LDO_HV5_DUMMY_8822B(x) \
(((x) >> BIT_SHIFT_LDO_HV5_DUMMY_8822B) & BIT_MASK_LDO_HV5_DUMMY_8822B)
#define BIT_SET_LDO_HV5_DUMMY_8822B(x, v) \
(BIT_CLEAR_LDO_HV5_DUMMY_8822B(x) | BIT_LDO_HV5_DUMMY_8822B(v))
#define BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8822B 12
#define BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8822B 0x3
#define BIT_REG_VTUNE33_BIT0_TO_BIT1_8822B(x) \
(((x) & BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8822B) \
<< BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8822B)
#define BITS_REG_VTUNE33_BIT0_TO_BIT1_8822B \
(BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8822B \
<< BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8822B)
#define BIT_CLEAR_REG_VTUNE33_BIT0_TO_BIT1_8822B(x) \
((x) & (~BITS_REG_VTUNE33_BIT0_TO_BIT1_8822B))
#define BIT_GET_REG_VTUNE33_BIT0_TO_BIT1_8822B(x) \
(((x) >> BIT_SHIFT_REG_VTUNE33_BIT0_TO_BIT1_8822B) & \
BIT_MASK_REG_VTUNE33_BIT0_TO_BIT1_8822B)
#define BIT_SET_REG_VTUNE33_BIT0_TO_BIT1_8822B(x, v) \
(BIT_CLEAR_REG_VTUNE33_BIT0_TO_BIT1_8822B(x) | \
BIT_REG_VTUNE33_BIT0_TO_BIT1_8822B(v))
#define BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8822B 10
#define BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8822B 0x3
#define BIT_REG_STANDBY33_BIT0_TO_BIT1_8822B(x) \
(((x) & BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8822B) \
<< BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8822B)
#define BITS_REG_STANDBY33_BIT0_TO_BIT1_8822B \
(BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8822B \
<< BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8822B)
#define BIT_CLEAR_REG_STANDBY33_BIT0_TO_BIT1_8822B(x) \
((x) & (~BITS_REG_STANDBY33_BIT0_TO_BIT1_8822B))
#define BIT_GET_REG_STANDBY33_BIT0_TO_BIT1_8822B(x) \
(((x) >> BIT_SHIFT_REG_STANDBY33_BIT0_TO_BIT1_8822B) & \
BIT_MASK_REG_STANDBY33_BIT0_TO_BIT1_8822B)
#define BIT_SET_REG_STANDBY33_BIT0_TO_BIT1_8822B(x, v) \
(BIT_CLEAR_REG_STANDBY33_BIT0_TO_BIT1_8822B(x) | \
BIT_REG_STANDBY33_BIT0_TO_BIT1_8822B(v))
#define BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8822B 8
#define BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8822B 0x3
#define BIT_REG_LOAD33_BIT0_TO_BIT1_8822B(x) \
(((x) & BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8822B) \
<< BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8822B)
#define BITS_REG_LOAD33_BIT0_TO_BIT1_8822B \
(BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8822B \
<< BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8822B)
#define BIT_CLEAR_REG_LOAD33_BIT0_TO_BIT1_8822B(x) \
((x) & (~BITS_REG_LOAD33_BIT0_TO_BIT1_8822B))
#define BIT_GET_REG_LOAD33_BIT0_TO_BIT1_8822B(x) \
(((x) >> BIT_SHIFT_REG_LOAD33_BIT0_TO_BIT1_8822B) & \
BIT_MASK_REG_LOAD33_BIT0_TO_BIT1_8822B)
#define BIT_SET_REG_LOAD33_BIT0_TO_BIT1_8822B(x, v) \
(BIT_CLEAR_REG_LOAD33_BIT0_TO_BIT1_8822B(x) | \
BIT_REG_LOAD33_BIT0_TO_BIT1_8822B(v))
#define BIT_REG_BYPASS_L_8822B BIT(7)
#define BIT_REG_LDOF_L_8822B BIT(6)
#define BIT_REG_TYPE_L_V1_8822B BIT(5)
#define BIT_ARENB_L_8822B BIT(3)
#define BIT_SHIFT_CFC_L_8822B 1
#define BIT_MASK_CFC_L_8822B 0x3
#define BIT_CFC_L_8822B(x) \
(((x) & BIT_MASK_CFC_L_8822B) << BIT_SHIFT_CFC_L_8822B)
#define BITS_CFC_L_8822B (BIT_MASK_CFC_L_8822B << BIT_SHIFT_CFC_L_8822B)
#define BIT_CLEAR_CFC_L_8822B(x) ((x) & (~BITS_CFC_L_8822B))
#define BIT_GET_CFC_L_8822B(x) \
(((x) >> BIT_SHIFT_CFC_L_8822B) & BIT_MASK_CFC_L_8822B)
#define BIT_SET_CFC_L_8822B(x, v) \
(BIT_CLEAR_CFC_L_8822B(x) | BIT_CFC_L_8822B(v))
#define BIT_REG_OCPS_L_V1_8822B BIT(0)
/* 2 REG_MCUFW_CTRL_8822B */
#define BIT_SHIFT_RPWM_8822B 24
#define BIT_MASK_RPWM_8822B 0xff
#define BIT_RPWM_8822B(x) (((x) & BIT_MASK_RPWM_8822B) << BIT_SHIFT_RPWM_8822B)
#define BITS_RPWM_8822B (BIT_MASK_RPWM_8822B << BIT_SHIFT_RPWM_8822B)
#define BIT_CLEAR_RPWM_8822B(x) ((x) & (~BITS_RPWM_8822B))
#define BIT_GET_RPWM_8822B(x) \
(((x) >> BIT_SHIFT_RPWM_8822B) & BIT_MASK_RPWM_8822B)
#define BIT_SET_RPWM_8822B(x, v) (BIT_CLEAR_RPWM_8822B(x) | BIT_RPWM_8822B(v))
#define BIT_ANA_PORT_EN_8822B BIT(22)
#define BIT_MAC_PORT_EN_8822B BIT(21)
#define BIT_BOOT_FSPI_EN_8822B BIT(20)
#define BIT_ROM_DLEN_8822B BIT(19)
#define BIT_SHIFT_ROM_PGE_8822B 16
#define BIT_MASK_ROM_PGE_8822B 0x7
#define BIT_ROM_PGE_8822B(x) \
(((x) & BIT_MASK_ROM_PGE_8822B) << BIT_SHIFT_ROM_PGE_8822B)
#define BITS_ROM_PGE_8822B (BIT_MASK_ROM_PGE_8822B << BIT_SHIFT_ROM_PGE_8822B)
#define BIT_CLEAR_ROM_PGE_8822B(x) ((x) & (~BITS_ROM_PGE_8822B))
#define BIT_GET_ROM_PGE_8822B(x) \
(((x) >> BIT_SHIFT_ROM_PGE_8822B) & BIT_MASK_ROM_PGE_8822B)
#define BIT_SET_ROM_PGE_8822B(x, v) \
(BIT_CLEAR_ROM_PGE_8822B(x) | BIT_ROM_PGE_8822B(v))
#define BIT_FW_INIT_RDY_8822B BIT(15)
#define BIT_FW_DW_RDY_8822B BIT(14)
#define BIT_SHIFT_CPU_CLK_SEL_8822B 12
#define BIT_MASK_CPU_CLK_SEL_8822B 0x3
#define BIT_CPU_CLK_SEL_8822B(x) \
(((x) & BIT_MASK_CPU_CLK_SEL_8822B) << BIT_SHIFT_CPU_CLK_SEL_8822B)
#define BITS_CPU_CLK_SEL_8822B \
(BIT_MASK_CPU_CLK_SEL_8822B << BIT_SHIFT_CPU_CLK_SEL_8822B)
#define BIT_CLEAR_CPU_CLK_SEL_8822B(x) ((x) & (~BITS_CPU_CLK_SEL_8822B))
#define BIT_GET_CPU_CLK_SEL_8822B(x) \
(((x) >> BIT_SHIFT_CPU_CLK_SEL_8822B) & BIT_MASK_CPU_CLK_SEL_8822B)
#define BIT_SET_CPU_CLK_SEL_8822B(x, v) \
(BIT_CLEAR_CPU_CLK_SEL_8822B(x) | BIT_CPU_CLK_SEL_8822B(v))
#define BIT_CCLK_CHG_MASK_8822B BIT(11)
#define BIT_EMEM__TXBUF_CHKSUM_OK_8822B BIT(10)
#define BIT_EMEM_TXBUF_DW_RDY_8822B BIT(9)
#define BIT_EMEM_CHKSUM_OK_8822B BIT(8)
#define BIT_EMEM_DW_OK_8822B BIT(7)
#define BIT_DMEM_CHKSUM_OK_8822B BIT(6)
#define BIT_DMEM_DW_OK_8822B BIT(5)
#define BIT_IMEM_CHKSUM_OK_8822B BIT(4)
#define BIT_IMEM_DW_OK_8822B BIT(3)
#define BIT_IMEM_BOOT_LOAD_CHKSUM_OK_8822B BIT(2)
#define BIT_IMEM_BOOT_LOAD_DW_OK_8822B BIT(1)
#define BIT_MCUFWDL_EN_8822B BIT(0)
/* 2 REG_MCU_TST_CFG_8822B */
#define BIT_SHIFT_C2H_MSG_8822B 0
#define BIT_MASK_C2H_MSG_8822B 0xffff
#define BIT_C2H_MSG_8822B(x) \
(((x) & BIT_MASK_C2H_MSG_8822B) << BIT_SHIFT_C2H_MSG_8822B)
#define BITS_C2H_MSG_8822B (BIT_MASK_C2H_MSG_8822B << BIT_SHIFT_C2H_MSG_8822B)
#define BIT_CLEAR_C2H_MSG_8822B(x) ((x) & (~BITS_C2H_MSG_8822B))
#define BIT_GET_C2H_MSG_8822B(x) \
(((x) >> BIT_SHIFT_C2H_MSG_8822B) & BIT_MASK_C2H_MSG_8822B)
#define BIT_SET_C2H_MSG_8822B(x, v) \
(BIT_CLEAR_C2H_MSG_8822B(x) | BIT_C2H_MSG_8822B(v))
/* 2 REG_HMEBOX_E0_E1_8822B */
#define BIT_SHIFT_HOST_MSG_E1_8822B 16
#define BIT_MASK_HOST_MSG_E1_8822B 0xffff
#define BIT_HOST_MSG_E1_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_E1_8822B) << BIT_SHIFT_HOST_MSG_E1_8822B)
#define BITS_HOST_MSG_E1_8822B \
(BIT_MASK_HOST_MSG_E1_8822B << BIT_SHIFT_HOST_MSG_E1_8822B)
#define BIT_CLEAR_HOST_MSG_E1_8822B(x) ((x) & (~BITS_HOST_MSG_E1_8822B))
#define BIT_GET_HOST_MSG_E1_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E1_8822B) & BIT_MASK_HOST_MSG_E1_8822B)
#define BIT_SET_HOST_MSG_E1_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_E1_8822B(x) | BIT_HOST_MSG_E1_8822B(v))
#define BIT_SHIFT_HOST_MSG_E0_8822B 0
#define BIT_MASK_HOST_MSG_E0_8822B 0xffff
#define BIT_HOST_MSG_E0_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_E0_8822B) << BIT_SHIFT_HOST_MSG_E0_8822B)
#define BITS_HOST_MSG_E0_8822B \
(BIT_MASK_HOST_MSG_E0_8822B << BIT_SHIFT_HOST_MSG_E0_8822B)
#define BIT_CLEAR_HOST_MSG_E0_8822B(x) ((x) & (~BITS_HOST_MSG_E0_8822B))
#define BIT_GET_HOST_MSG_E0_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E0_8822B) & BIT_MASK_HOST_MSG_E0_8822B)
#define BIT_SET_HOST_MSG_E0_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_E0_8822B(x) | BIT_HOST_MSG_E0_8822B(v))
/* 2 REG_HMEBOX_E2_E3_8822B */
#define BIT_SHIFT_HOST_MSG_E3_8822B 16
#define BIT_MASK_HOST_MSG_E3_8822B 0xffff
#define BIT_HOST_MSG_E3_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_E3_8822B) << BIT_SHIFT_HOST_MSG_E3_8822B)
#define BITS_HOST_MSG_E3_8822B \
(BIT_MASK_HOST_MSG_E3_8822B << BIT_SHIFT_HOST_MSG_E3_8822B)
#define BIT_CLEAR_HOST_MSG_E3_8822B(x) ((x) & (~BITS_HOST_MSG_E3_8822B))
#define BIT_GET_HOST_MSG_E3_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E3_8822B) & BIT_MASK_HOST_MSG_E3_8822B)
#define BIT_SET_HOST_MSG_E3_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_E3_8822B(x) | BIT_HOST_MSG_E3_8822B(v))
#define BIT_SHIFT_HOST_MSG_E2_8822B 0
#define BIT_MASK_HOST_MSG_E2_8822B 0xffff
#define BIT_HOST_MSG_E2_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_E2_8822B) << BIT_SHIFT_HOST_MSG_E2_8822B)
#define BITS_HOST_MSG_E2_8822B \
(BIT_MASK_HOST_MSG_E2_8822B << BIT_SHIFT_HOST_MSG_E2_8822B)
#define BIT_CLEAR_HOST_MSG_E2_8822B(x) ((x) & (~BITS_HOST_MSG_E2_8822B))
#define BIT_GET_HOST_MSG_E2_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E2_8822B) & BIT_MASK_HOST_MSG_E2_8822B)
#define BIT_SET_HOST_MSG_E2_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_E2_8822B(x) | BIT_HOST_MSG_E2_8822B(v))
/* 2 REG_WLLPS_CTRL_8822B */
#define BIT_WLLPSOP_EABM_8822B BIT(31)
#define BIT_WLLPSOP_ACKF_8822B BIT(30)
#define BIT_WLLPSOP_DLDM_8822B BIT(29)
#define BIT_WLLPSOP_ESWR_8822B BIT(28)
#define BIT_WLLPSOP_PWMM_8822B BIT(27)
#define BIT_WLLPSOP_EECK_8822B BIT(26)
#define BIT_WLLPSOP_WLMACOFF_8822B BIT(25)
#define BIT_WLLPSOP_EXTAL_8822B BIT(24)
#define BIT_WL_SYNPON_VOLTSPDN_8822B BIT(23)
#define BIT_WLLPSOP_WLBBOFF_8822B BIT(22)
#define BIT_WLLPSOP_WLMEM_DS_8822B BIT(21)
#define BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822B 12
#define BIT_MASK_LPLDH12_VADJ_STEP_DN_8822B 0xf
#define BIT_LPLDH12_VADJ_STEP_DN_8822B(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_STEP_DN_8822B) \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822B)
#define BITS_LPLDH12_VADJ_STEP_DN_8822B \
(BIT_MASK_LPLDH12_VADJ_STEP_DN_8822B \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822B)
#define BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8822B(x) \
((x) & (~BITS_LPLDH12_VADJ_STEP_DN_8822B))
#define BIT_GET_LPLDH12_VADJ_STEP_DN_8822B(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822B) & \
BIT_MASK_LPLDH12_VADJ_STEP_DN_8822B)
#define BIT_SET_LPLDH12_VADJ_STEP_DN_8822B(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8822B(x) | \
BIT_LPLDH12_VADJ_STEP_DN_8822B(v))
#define BIT_SHIFT_V15ADJ_L1_STEP_DN_8822B 8
#define BIT_MASK_V15ADJ_L1_STEP_DN_8822B 0x7
#define BIT_V15ADJ_L1_STEP_DN_8822B(x) \
(((x) & BIT_MASK_V15ADJ_L1_STEP_DN_8822B) \
<< BIT_SHIFT_V15ADJ_L1_STEP_DN_8822B)
#define BITS_V15ADJ_L1_STEP_DN_8822B \
(BIT_MASK_V15ADJ_L1_STEP_DN_8822B << BIT_SHIFT_V15ADJ_L1_STEP_DN_8822B)
#define BIT_CLEAR_V15ADJ_L1_STEP_DN_8822B(x) \
((x) & (~BITS_V15ADJ_L1_STEP_DN_8822B))
#define BIT_GET_V15ADJ_L1_STEP_DN_8822B(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_STEP_DN_8822B) & \
BIT_MASK_V15ADJ_L1_STEP_DN_8822B)
#define BIT_SET_V15ADJ_L1_STEP_DN_8822B(x, v) \
(BIT_CLEAR_V15ADJ_L1_STEP_DN_8822B(x) | BIT_V15ADJ_L1_STEP_DN_8822B(v))
#define BIT_REGU_32K_CLK_EN_8822B BIT(1)
#define BIT_WL_LPS_EN_8822B BIT(0)
/* 2 REG_AFE_CTRL5_8822B */
#define BIT_BB_DBG_SEL_AFE_SDM_BIT0_8822B BIT(31)
#define BIT_ORDER_SDM_8822B BIT(30)
#define BIT_RFE_SEL_SDM_8822B BIT(29)
#define BIT_SHIFT_REF_SEL_8822B 25
#define BIT_MASK_REF_SEL_8822B 0xf
#define BIT_REF_SEL_8822B(x) \
(((x) & BIT_MASK_REF_SEL_8822B) << BIT_SHIFT_REF_SEL_8822B)
#define BITS_REF_SEL_8822B (BIT_MASK_REF_SEL_8822B << BIT_SHIFT_REF_SEL_8822B)
#define BIT_CLEAR_REF_SEL_8822B(x) ((x) & (~BITS_REF_SEL_8822B))
#define BIT_GET_REF_SEL_8822B(x) \
(((x) >> BIT_SHIFT_REF_SEL_8822B) & BIT_MASK_REF_SEL_8822B)
#define BIT_SET_REF_SEL_8822B(x, v) \
(BIT_CLEAR_REF_SEL_8822B(x) | BIT_REF_SEL_8822B(v))
#define BIT_SHIFT_F0F_SDM_8822B 12
#define BIT_MASK_F0F_SDM_8822B 0x1fff
#define BIT_F0F_SDM_8822B(x) \
(((x) & BIT_MASK_F0F_SDM_8822B) << BIT_SHIFT_F0F_SDM_8822B)
#define BITS_F0F_SDM_8822B (BIT_MASK_F0F_SDM_8822B << BIT_SHIFT_F0F_SDM_8822B)
#define BIT_CLEAR_F0F_SDM_8822B(x) ((x) & (~BITS_F0F_SDM_8822B))
#define BIT_GET_F0F_SDM_8822B(x) \
(((x) >> BIT_SHIFT_F0F_SDM_8822B) & BIT_MASK_F0F_SDM_8822B)
#define BIT_SET_F0F_SDM_8822B(x, v) \
(BIT_CLEAR_F0F_SDM_8822B(x) | BIT_F0F_SDM_8822B(v))
#define BIT_SHIFT_F0N_SDM_8822B 9
#define BIT_MASK_F0N_SDM_8822B 0x7
#define BIT_F0N_SDM_8822B(x) \
(((x) & BIT_MASK_F0N_SDM_8822B) << BIT_SHIFT_F0N_SDM_8822B)
#define BITS_F0N_SDM_8822B (BIT_MASK_F0N_SDM_8822B << BIT_SHIFT_F0N_SDM_8822B)
#define BIT_CLEAR_F0N_SDM_8822B(x) ((x) & (~BITS_F0N_SDM_8822B))
#define BIT_GET_F0N_SDM_8822B(x) \
(((x) >> BIT_SHIFT_F0N_SDM_8822B) & BIT_MASK_F0N_SDM_8822B)
#define BIT_SET_F0N_SDM_8822B(x, v) \
(BIT_CLEAR_F0N_SDM_8822B(x) | BIT_F0N_SDM_8822B(v))
#define BIT_SHIFT_DIVN_SDM_8822B 3
#define BIT_MASK_DIVN_SDM_8822B 0x3f
#define BIT_DIVN_SDM_8822B(x) \
(((x) & BIT_MASK_DIVN_SDM_8822B) << BIT_SHIFT_DIVN_SDM_8822B)
#define BITS_DIVN_SDM_8822B \
(BIT_MASK_DIVN_SDM_8822B << BIT_SHIFT_DIVN_SDM_8822B)
#define BIT_CLEAR_DIVN_SDM_8822B(x) ((x) & (~BITS_DIVN_SDM_8822B))
#define BIT_GET_DIVN_SDM_8822B(x) \
(((x) >> BIT_SHIFT_DIVN_SDM_8822B) & BIT_MASK_DIVN_SDM_8822B)
#define BIT_SET_DIVN_SDM_8822B(x, v) \
(BIT_CLEAR_DIVN_SDM_8822B(x) | BIT_DIVN_SDM_8822B(v))
/* 2 REG_GPIO_DEBOUNCE_CTRL_8822B */
#define BIT_WLGP_DBC1EN_8822B BIT(15)
#define BIT_SHIFT_WLGP_DBC1_8822B 8
#define BIT_MASK_WLGP_DBC1_8822B 0xf
#define BIT_WLGP_DBC1_8822B(x) \
(((x) & BIT_MASK_WLGP_DBC1_8822B) << BIT_SHIFT_WLGP_DBC1_8822B)
#define BITS_WLGP_DBC1_8822B \
(BIT_MASK_WLGP_DBC1_8822B << BIT_SHIFT_WLGP_DBC1_8822B)
#define BIT_CLEAR_WLGP_DBC1_8822B(x) ((x) & (~BITS_WLGP_DBC1_8822B))
#define BIT_GET_WLGP_DBC1_8822B(x) \
(((x) >> BIT_SHIFT_WLGP_DBC1_8822B) & BIT_MASK_WLGP_DBC1_8822B)
#define BIT_SET_WLGP_DBC1_8822B(x, v) \
(BIT_CLEAR_WLGP_DBC1_8822B(x) | BIT_WLGP_DBC1_8822B(v))
#define BIT_WLGP_DBC0EN_8822B BIT(7)
#define BIT_SHIFT_WLGP_DBC0_8822B 0
#define BIT_MASK_WLGP_DBC0_8822B 0xf
#define BIT_WLGP_DBC0_8822B(x) \
(((x) & BIT_MASK_WLGP_DBC0_8822B) << BIT_SHIFT_WLGP_DBC0_8822B)
#define BITS_WLGP_DBC0_8822B \
(BIT_MASK_WLGP_DBC0_8822B << BIT_SHIFT_WLGP_DBC0_8822B)
#define BIT_CLEAR_WLGP_DBC0_8822B(x) ((x) & (~BITS_WLGP_DBC0_8822B))
#define BIT_GET_WLGP_DBC0_8822B(x) \
(((x) >> BIT_SHIFT_WLGP_DBC0_8822B) & BIT_MASK_WLGP_DBC0_8822B)
#define BIT_SET_WLGP_DBC0_8822B(x, v) \
(BIT_CLEAR_WLGP_DBC0_8822B(x) | BIT_WLGP_DBC0_8822B(v))
/* 2 REG_RPWM2_8822B */
#define BIT_SHIFT_RPWM2_8822B 16
#define BIT_MASK_RPWM2_8822B 0xffff
#define BIT_RPWM2_8822B(x) \
(((x) & BIT_MASK_RPWM2_8822B) << BIT_SHIFT_RPWM2_8822B)
#define BITS_RPWM2_8822B (BIT_MASK_RPWM2_8822B << BIT_SHIFT_RPWM2_8822B)
#define BIT_CLEAR_RPWM2_8822B(x) ((x) & (~BITS_RPWM2_8822B))
#define BIT_GET_RPWM2_8822B(x) \
(((x) >> BIT_SHIFT_RPWM2_8822B) & BIT_MASK_RPWM2_8822B)
#define BIT_SET_RPWM2_8822B(x, v) \
(BIT_CLEAR_RPWM2_8822B(x) | BIT_RPWM2_8822B(v))
/* 2 REG_SYSON_FSM_MON_8822B */
#define BIT_SHIFT_FSM_MON_SEL_8822B 24
#define BIT_MASK_FSM_MON_SEL_8822B 0x7
#define BIT_FSM_MON_SEL_8822B(x) \
(((x) & BIT_MASK_FSM_MON_SEL_8822B) << BIT_SHIFT_FSM_MON_SEL_8822B)
#define BITS_FSM_MON_SEL_8822B \
(BIT_MASK_FSM_MON_SEL_8822B << BIT_SHIFT_FSM_MON_SEL_8822B)
#define BIT_CLEAR_FSM_MON_SEL_8822B(x) ((x) & (~BITS_FSM_MON_SEL_8822B))
#define BIT_GET_FSM_MON_SEL_8822B(x) \
(((x) >> BIT_SHIFT_FSM_MON_SEL_8822B) & BIT_MASK_FSM_MON_SEL_8822B)
#define BIT_SET_FSM_MON_SEL_8822B(x, v) \
(BIT_CLEAR_FSM_MON_SEL_8822B(x) | BIT_FSM_MON_SEL_8822B(v))
#define BIT_DOP_ELDO_8822B BIT(23)
#define BIT_FSM_MON_UPD_8822B BIT(15)
#define BIT_SHIFT_FSM_PAR_8822B 0
#define BIT_MASK_FSM_PAR_8822B 0x7fff
#define BIT_FSM_PAR_8822B(x) \
(((x) & BIT_MASK_FSM_PAR_8822B) << BIT_SHIFT_FSM_PAR_8822B)
#define BITS_FSM_PAR_8822B (BIT_MASK_FSM_PAR_8822B << BIT_SHIFT_FSM_PAR_8822B)
#define BIT_CLEAR_FSM_PAR_8822B(x) ((x) & (~BITS_FSM_PAR_8822B))
#define BIT_GET_FSM_PAR_8822B(x) \
(((x) >> BIT_SHIFT_FSM_PAR_8822B) & BIT_MASK_FSM_PAR_8822B)
#define BIT_SET_FSM_PAR_8822B(x, v) \
(BIT_CLEAR_FSM_PAR_8822B(x) | BIT_FSM_PAR_8822B(v))
/* 2 REG_AFE_CTRL6_8822B */
#define BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B 0
#define BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B 0x7
#define BIT_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B(x) \
(((x) & BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B) \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B)
#define BITS_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B \
(BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B \
<< BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B)
#define BIT_CLEAR_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B(x) \
((x) & (~BITS_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B))
#define BIT_GET_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B(x) \
(((x) >> BIT_SHIFT_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B) & \
BIT_MASK_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B)
#define BIT_SET_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B(x, v) \
(BIT_CLEAR_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B(x) | \
BIT_BB_DBG_SEL_AFE_SDM_BIT3_1_8822B(v))
/* 2 REG_PMC_DBG_CTRL1_8822B */
#define BIT_BT_INT_EN_8822B BIT(31)
#define BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822B 16
#define BIT_MASK_RD_WR_WIFI_BT_INFO_8822B 0x7fff
#define BIT_RD_WR_WIFI_BT_INFO_8822B(x) \
(((x) & BIT_MASK_RD_WR_WIFI_BT_INFO_8822B) \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822B)
#define BITS_RD_WR_WIFI_BT_INFO_8822B \
(BIT_MASK_RD_WR_WIFI_BT_INFO_8822B \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822B)
#define BIT_CLEAR_RD_WR_WIFI_BT_INFO_8822B(x) \
((x) & (~BITS_RD_WR_WIFI_BT_INFO_8822B))
#define BIT_GET_RD_WR_WIFI_BT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822B) & \
BIT_MASK_RD_WR_WIFI_BT_INFO_8822B)
#define BIT_SET_RD_WR_WIFI_BT_INFO_8822B(x, v) \
(BIT_CLEAR_RD_WR_WIFI_BT_INFO_8822B(x) | \
BIT_RD_WR_WIFI_BT_INFO_8822B(v))
#define BIT_PMC_WR_OVF_8822B BIT(8)
#define BIT_SHIFT_WLPMC_ERRINT_8822B 0
#define BIT_MASK_WLPMC_ERRINT_8822B 0xff
#define BIT_WLPMC_ERRINT_8822B(x) \
(((x) & BIT_MASK_WLPMC_ERRINT_8822B) << BIT_SHIFT_WLPMC_ERRINT_8822B)
#define BITS_WLPMC_ERRINT_8822B \
(BIT_MASK_WLPMC_ERRINT_8822B << BIT_SHIFT_WLPMC_ERRINT_8822B)
#define BIT_CLEAR_WLPMC_ERRINT_8822B(x) ((x) & (~BITS_WLPMC_ERRINT_8822B))
#define BIT_GET_WLPMC_ERRINT_8822B(x) \
(((x) >> BIT_SHIFT_WLPMC_ERRINT_8822B) & BIT_MASK_WLPMC_ERRINT_8822B)
#define BIT_SET_WLPMC_ERRINT_8822B(x, v) \
(BIT_CLEAR_WLPMC_ERRINT_8822B(x) | BIT_WLPMC_ERRINT_8822B(v))
/* 2 REG_AFE_CTRL7_8822B */
#define BIT_SHIFT_SEL_V_8822B 30
#define BIT_MASK_SEL_V_8822B 0x3
#define BIT_SEL_V_8822B(x) \
(((x) & BIT_MASK_SEL_V_8822B) << BIT_SHIFT_SEL_V_8822B)
#define BITS_SEL_V_8822B (BIT_MASK_SEL_V_8822B << BIT_SHIFT_SEL_V_8822B)
#define BIT_CLEAR_SEL_V_8822B(x) ((x) & (~BITS_SEL_V_8822B))
#define BIT_GET_SEL_V_8822B(x) \
(((x) >> BIT_SHIFT_SEL_V_8822B) & BIT_MASK_SEL_V_8822B)
#define BIT_SET_SEL_V_8822B(x, v) \
(BIT_CLEAR_SEL_V_8822B(x) | BIT_SEL_V_8822B(v))
#define BIT_SEL_LDO_PC_8822B BIT(29)
#define BIT_SHIFT_CK_MON_SEL_8822B 26
#define BIT_MASK_CK_MON_SEL_8822B 0x7
#define BIT_CK_MON_SEL_8822B(x) \
(((x) & BIT_MASK_CK_MON_SEL_8822B) << BIT_SHIFT_CK_MON_SEL_8822B)
#define BITS_CK_MON_SEL_8822B \
(BIT_MASK_CK_MON_SEL_8822B << BIT_SHIFT_CK_MON_SEL_8822B)
#define BIT_CLEAR_CK_MON_SEL_8822B(x) ((x) & (~BITS_CK_MON_SEL_8822B))
#define BIT_GET_CK_MON_SEL_8822B(x) \
(((x) >> BIT_SHIFT_CK_MON_SEL_8822B) & BIT_MASK_CK_MON_SEL_8822B)
#define BIT_SET_CK_MON_SEL_8822B(x, v) \
(BIT_CLEAR_CK_MON_SEL_8822B(x) | BIT_CK_MON_SEL_8822B(v))
#define BIT_CK_MON_EN_8822B BIT(25)
#define BIT_FREF_EDGE_8822B BIT(24)
#define BIT_CK320M_EN_8822B BIT(23)
#define BIT_CK_5M_EN_8822B BIT(22)
#define BIT_TESTEN_8822B BIT(21)
/* 2 REG_HIMR0_8822B */
#define BIT_TIMEOUT_INTERRUPT2_MASK_8822B BIT(31)
#define BIT_TIMEOUT_INTERRUTP1_MASK_8822B BIT(30)
#define BIT_PSTIMEOUT_MSK_8822B BIT(29)
#define BIT_GTINT4_MSK_8822B BIT(28)
#define BIT_GTINT3_MSK_8822B BIT(27)
#define BIT_TXBCN0ERR_MSK_8822B BIT(26)
#define BIT_TXBCN0OK_MSK_8822B BIT(25)
#define BIT_TSF_BIT32_TOGGLE_MSK_8822B BIT(24)
#define BIT_BCNDMAINT0_MSK_8822B BIT(20)
#define BIT_BCNDERR0_MSK_8822B BIT(16)
#define BIT_HSISR_IND_ON_INT_MSK_8822B BIT(15)
#define BIT_HISR3_IND_INT_MSK_8822B BIT(14)
#define BIT_HISR2_IND_INT_MSK_8822B BIT(13)
#define BIT_HISR1_IND_MSK_8822B BIT(11)
#define BIT_C2HCMD_MSK_8822B BIT(10)
#define BIT_CPWM2_MSK_8822B BIT(9)
#define BIT_CPWM_MSK_8822B BIT(8)
#define BIT_HIGHDOK_MSK_8822B BIT(7)
#define BIT_MGTDOK_MSK_8822B BIT(6)
#define BIT_BKDOK_MSK_8822B BIT(5)
#define BIT_BEDOK_MSK_8822B BIT(4)
#define BIT_VIDOK_MSK_8822B BIT(3)
#define BIT_VODOK_MSK_8822B BIT(2)
#define BIT_RDU_MSK_8822B BIT(1)
#define BIT_RXOK_MSK_8822B BIT(0)
/* 2 REG_HISR0_8822B */
#define BIT_PSTIMEOUT2_8822B BIT(31)
#define BIT_PSTIMEOUT1_8822B BIT(30)
#define BIT_PSTIMEOUT_8822B BIT(29)
#define BIT_GTINT4_8822B BIT(28)
#define BIT_GTINT3_8822B BIT(27)
#define BIT_TXBCN0ERR_8822B BIT(26)
#define BIT_TXBCN0OK_8822B BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8822B BIT(24)
#define BIT_BCNDMAINT0_8822B BIT(20)
#define BIT_BCNDERR0_8822B BIT(16)
#define BIT_HSISR_IND_ON_INT_8822B BIT(15)
#define BIT_HISR3_IND_INT_8822B BIT(14)
#define BIT_HISR2_IND_INT_8822B BIT(13)
#define BIT_HISR1_IND_INT_8822B BIT(11)
#define BIT_C2HCMD_8822B BIT(10)
#define BIT_CPWM2_8822B BIT(9)
#define BIT_CPWM_8822B BIT(8)
#define BIT_HIGHDOK_8822B BIT(7)
#define BIT_MGTDOK_8822B BIT(6)
#define BIT_BKDOK_8822B BIT(5)
#define BIT_BEDOK_8822B BIT(4)
#define BIT_VIDOK_8822B BIT(3)
#define BIT_VODOK_8822B BIT(2)
#define BIT_RDU_8822B BIT(1)
#define BIT_RXOK_8822B BIT(0)
/* 2 REG_HIMR1_8822B */
#define BIT_TXFIFO_TH_INT_8822B BIT(30)
#define BIT_BTON_STS_UPDATE_MASK_8822B BIT(29)
#define BIT_BCNDMAINT7__MSK_8822B BIT(27)
#define BIT_BCNDMAINT6__MSK_8822B BIT(26)
#define BIT_BCNDMAINT5__MSK_8822B BIT(25)
#define BIT_BCNDMAINT4__MSK_8822B BIT(24)
#define BIT_BCNDMAINT3_MSK_8822B BIT(23)
#define BIT_BCNDMAINT2_MSK_8822B BIT(22)
#define BIT_BCNDMAINT1_MSK_8822B BIT(21)
#define BIT_BCNDERR7_MSK_8822B BIT(20)
#define BIT_BCNDERR6_MSK_8822B BIT(19)
#define BIT_BCNDERR5_MSK_8822B BIT(18)
#define BIT_BCNDERR4_MSK_8822B BIT(17)
#define BIT_BCNDERR3_MSK_8822B BIT(16)
#define BIT_BCNDERR2_MSK_8822B BIT(15)
#define BIT_BCNDERR1_MSK_8822B BIT(14)
#define BIT_ATIMEND_E_V1_MSK_8822B BIT(12)
#define BIT_TXERR_MSK_8822B BIT(11)
#define BIT_RXERR_MSK_8822B BIT(10)
#define BIT_TXFOVW_MSK_8822B BIT(9)
#define BIT_FOVW_MSK_8822B BIT(8)
#define BIT_CPU_MGQ_TXDONE_MSK_8822B BIT(5)
#define BIT_PS_TIMER_C_MSK_8822B BIT(4)
#define BIT_PS_TIMER_B_MSK_8822B BIT(3)
#define BIT_PS_TIMER_A_MSK_8822B BIT(2)
#define BIT_CPUMGQ_TX_TIMER_MSK_8822B BIT(1)
/* 2 REG_HISR1_8822B */
#define BIT_TXFIFO_TH_INT_8822B BIT(30)
#define BIT_BTON_STS_UPDATE_INT_8822B BIT(29)
#define BIT_BCNDMAINT7_8822B BIT(27)
#define BIT_BCNDMAINT6_8822B BIT(26)
#define BIT_BCNDMAINT5_8822B BIT(25)
#define BIT_BCNDMAINT4_8822B BIT(24)
#define BIT_BCNDMAINT3_8822B BIT(23)
#define BIT_BCNDMAINT2_8822B BIT(22)
#define BIT_BCNDMAINT1_8822B BIT(21)
#define BIT_BCNDERR7_8822B BIT(20)
#define BIT_BCNDERR6_8822B BIT(19)
#define BIT_BCNDERR5_8822B BIT(18)
#define BIT_BCNDERR4_8822B BIT(17)
#define BIT_BCNDERR3_8822B BIT(16)
#define BIT_BCNDERR2_8822B BIT(15)
#define BIT_BCNDERR1_8822B BIT(14)
#define BIT_ATIMEND_E_V1_INT_8822B BIT(12)
#define BIT_TXERR_INT_8822B BIT(11)
#define BIT_RXERR_INT_8822B BIT(10)
#define BIT_TXFOVW_8822B BIT(9)
#define BIT_FOVW_8822B BIT(8)
#define BIT_CPU_MGQ_TXDONE_8822B BIT(5)
#define BIT_PS_TIMER_C_8822B BIT(4)
#define BIT_PS_TIMER_B_8822B BIT(3)
#define BIT_PS_TIMER_A_8822B BIT(2)
#define BIT_CPUMGQ_TX_TIMER_8822B BIT(1)
/* 2 REG_DBG_PORT_SEL_8822B */
#define BIT_SHIFT_DEBUG_ST_8822B 0
#define BIT_MASK_DEBUG_ST_8822B 0xffffffffL
#define BIT_DEBUG_ST_8822B(x) \
(((x) & BIT_MASK_DEBUG_ST_8822B) << BIT_SHIFT_DEBUG_ST_8822B)
#define BITS_DEBUG_ST_8822B \
(BIT_MASK_DEBUG_ST_8822B << BIT_SHIFT_DEBUG_ST_8822B)
#define BIT_CLEAR_DEBUG_ST_8822B(x) ((x) & (~BITS_DEBUG_ST_8822B))
#define BIT_GET_DEBUG_ST_8822B(x) \
(((x) >> BIT_SHIFT_DEBUG_ST_8822B) & BIT_MASK_DEBUG_ST_8822B)
#define BIT_SET_DEBUG_ST_8822B(x, v) \
(BIT_CLEAR_DEBUG_ST_8822B(x) | BIT_DEBUG_ST_8822B(v))
/* 2 REG_PAD_CTRL2_8822B */
#define BIT_USB3_USB2_TRANSITION_8822B BIT(20)
#define BIT_SHIFT_USB23_SW_MODE_V1_8822B 18
#define BIT_MASK_USB23_SW_MODE_V1_8822B 0x3
#define BIT_USB23_SW_MODE_V1_8822B(x) \
(((x) & BIT_MASK_USB23_SW_MODE_V1_8822B) \
<< BIT_SHIFT_USB23_SW_MODE_V1_8822B)
#define BITS_USB23_SW_MODE_V1_8822B \
(BIT_MASK_USB23_SW_MODE_V1_8822B << BIT_SHIFT_USB23_SW_MODE_V1_8822B)
#define BIT_CLEAR_USB23_SW_MODE_V1_8822B(x) \
((x) & (~BITS_USB23_SW_MODE_V1_8822B))
#define BIT_GET_USB23_SW_MODE_V1_8822B(x) \
(((x) >> BIT_SHIFT_USB23_SW_MODE_V1_8822B) & \
BIT_MASK_USB23_SW_MODE_V1_8822B)
#define BIT_SET_USB23_SW_MODE_V1_8822B(x, v) \
(BIT_CLEAR_USB23_SW_MODE_V1_8822B(x) | BIT_USB23_SW_MODE_V1_8822B(v))
#define BIT_NO_PDN_CHIPOFF_V1_8822B BIT(17)
#define BIT_RSM_EN_V1_8822B BIT(16)
#define BIT_SHIFT_MATCH_CNT_8822B 8
#define BIT_MASK_MATCH_CNT_8822B 0xff
#define BIT_MATCH_CNT_8822B(x) \
(((x) & BIT_MASK_MATCH_CNT_8822B) << BIT_SHIFT_MATCH_CNT_8822B)
#define BITS_MATCH_CNT_8822B \
(BIT_MASK_MATCH_CNT_8822B << BIT_SHIFT_MATCH_CNT_8822B)
#define BIT_CLEAR_MATCH_CNT_8822B(x) ((x) & (~BITS_MATCH_CNT_8822B))
#define BIT_GET_MATCH_CNT_8822B(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8822B) & BIT_MASK_MATCH_CNT_8822B)
#define BIT_SET_MATCH_CNT_8822B(x, v) \
(BIT_CLEAR_MATCH_CNT_8822B(x) | BIT_MATCH_CNT_8822B(v))
#define BIT_LD_B12V_EN_8822B BIT(7)
#define BIT_EECS_IOSEL_V1_8822B BIT(6)
#define BIT_EECS_DATA_O_V1_8822B BIT(5)
#define BIT_EECS_DATA_I_V1_8822B BIT(4)
#define BIT_EESK_IOSEL_V1_8822B BIT(2)
#define BIT_EESK_DATA_O_V1_8822B BIT(1)
#define BIT_EESK_DATA_I_V1_8822B BIT(0)
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_PMC_DBG_CTRL2_8822B */
#define BIT_SHIFT_EFUSE_BURN_GNT_8822B 24
#define BIT_MASK_EFUSE_BURN_GNT_8822B 0xff
#define BIT_EFUSE_BURN_GNT_8822B(x) \
(((x) & BIT_MASK_EFUSE_BURN_GNT_8822B) \
<< BIT_SHIFT_EFUSE_BURN_GNT_8822B)
#define BITS_EFUSE_BURN_GNT_8822B \
(BIT_MASK_EFUSE_BURN_GNT_8822B << BIT_SHIFT_EFUSE_BURN_GNT_8822B)
#define BIT_CLEAR_EFUSE_BURN_GNT_8822B(x) ((x) & (~BITS_EFUSE_BURN_GNT_8822B))
#define BIT_GET_EFUSE_BURN_GNT_8822B(x) \
(((x) >> BIT_SHIFT_EFUSE_BURN_GNT_8822B) & \
BIT_MASK_EFUSE_BURN_GNT_8822B)
#define BIT_SET_EFUSE_BURN_GNT_8822B(x, v) \
(BIT_CLEAR_EFUSE_BURN_GNT_8822B(x) | BIT_EFUSE_BURN_GNT_8822B(v))
#define BIT_STOP_WL_PMC_8822B BIT(9)
#define BIT_STOP_SYM_PMC_8822B BIT(8)
#define BIT_REG_RST_WLPMC_8822B BIT(5)
#define BIT_REG_RST_PD12N_8822B BIT(4)
#define BIT_SYSON_DIS_WLREG_WRMSK_8822B BIT(3)
#define BIT_SYSON_DIS_PMCREG_WRMSK_8822B BIT(2)
#define BIT_SHIFT_SYSON_REG_ARB_8822B 0
#define BIT_MASK_SYSON_REG_ARB_8822B 0x3
#define BIT_SYSON_REG_ARB_8822B(x) \
(((x) & BIT_MASK_SYSON_REG_ARB_8822B) << BIT_SHIFT_SYSON_REG_ARB_8822B)
#define BITS_SYSON_REG_ARB_8822B \
(BIT_MASK_SYSON_REG_ARB_8822B << BIT_SHIFT_SYSON_REG_ARB_8822B)
#define BIT_CLEAR_SYSON_REG_ARB_8822B(x) ((x) & (~BITS_SYSON_REG_ARB_8822B))
#define BIT_GET_SYSON_REG_ARB_8822B(x) \
(((x) >> BIT_SHIFT_SYSON_REG_ARB_8822B) & BIT_MASK_SYSON_REG_ARB_8822B)
#define BIT_SET_SYSON_REG_ARB_8822B(x, v) \
(BIT_CLEAR_SYSON_REG_ARB_8822B(x) | BIT_SYSON_REG_ARB_8822B(v))
/* 2 REG_BIST_CTRL_8822B */
#define BIT_BIST_USB_DIS_8822B BIT(27)
#define BIT_BIST_PCI_DIS_8822B BIT(26)
#define BIT_BIST_BT_DIS_8822B BIT(25)
#define BIT_BIST_WL_DIS_8822B BIT(24)
#define BIT_SHIFT_BIST_RPT_SEL_8822B 16
#define BIT_MASK_BIST_RPT_SEL_8822B 0xf
#define BIT_BIST_RPT_SEL_8822B(x) \
(((x) & BIT_MASK_BIST_RPT_SEL_8822B) << BIT_SHIFT_BIST_RPT_SEL_8822B)
#define BITS_BIST_RPT_SEL_8822B \
(BIT_MASK_BIST_RPT_SEL_8822B << BIT_SHIFT_BIST_RPT_SEL_8822B)
#define BIT_CLEAR_BIST_RPT_SEL_8822B(x) ((x) & (~BITS_BIST_RPT_SEL_8822B))
#define BIT_GET_BIST_RPT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_BIST_RPT_SEL_8822B) & BIT_MASK_BIST_RPT_SEL_8822B)
#define BIT_SET_BIST_RPT_SEL_8822B(x, v) \
(BIT_CLEAR_BIST_RPT_SEL_8822B(x) | BIT_BIST_RPT_SEL_8822B(v))
#define BIT_BIST_RESUME_PS_8822B BIT(4)
#define BIT_BIST_RESUME_8822B BIT(3)
#define BIT_BIST_NORMAL_8822B BIT(2)
#define BIT_BIST_RSTN_8822B BIT(1)
#define BIT_BIST_CLK_EN_8822B BIT(0)
/* 2 REG_BIST_RPT_8822B */
#define BIT_SHIFT_MBIST_REPORT_8822B 0
#define BIT_MASK_MBIST_REPORT_8822B 0xffffffffL
#define BIT_MBIST_REPORT_8822B(x) \
(((x) & BIT_MASK_MBIST_REPORT_8822B) << BIT_SHIFT_MBIST_REPORT_8822B)
#define BITS_MBIST_REPORT_8822B \
(BIT_MASK_MBIST_REPORT_8822B << BIT_SHIFT_MBIST_REPORT_8822B)
#define BIT_CLEAR_MBIST_REPORT_8822B(x) ((x) & (~BITS_MBIST_REPORT_8822B))
#define BIT_GET_MBIST_REPORT_8822B(x) \
(((x) >> BIT_SHIFT_MBIST_REPORT_8822B) & BIT_MASK_MBIST_REPORT_8822B)
#define BIT_SET_MBIST_REPORT_8822B(x, v) \
(BIT_CLEAR_MBIST_REPORT_8822B(x) | BIT_MBIST_REPORT_8822B(v))
/* 2 REG_MEM_CTRL_8822B */
#define BIT_UMEM_RME_8822B BIT(31)
#define BIT_SHIFT_BT_SPRAM_8822B 28
#define BIT_MASK_BT_SPRAM_8822B 0x3
#define BIT_BT_SPRAM_8822B(x) \
(((x) & BIT_MASK_BT_SPRAM_8822B) << BIT_SHIFT_BT_SPRAM_8822B)
#define BITS_BT_SPRAM_8822B \
(BIT_MASK_BT_SPRAM_8822B << BIT_SHIFT_BT_SPRAM_8822B)
#define BIT_CLEAR_BT_SPRAM_8822B(x) ((x) & (~BITS_BT_SPRAM_8822B))
#define BIT_GET_BT_SPRAM_8822B(x) \
(((x) >> BIT_SHIFT_BT_SPRAM_8822B) & BIT_MASK_BT_SPRAM_8822B)
#define BIT_SET_BT_SPRAM_8822B(x, v) \
(BIT_CLEAR_BT_SPRAM_8822B(x) | BIT_BT_SPRAM_8822B(v))
#define BIT_SHIFT_BT_ROM_8822B 24
#define BIT_MASK_BT_ROM_8822B 0xf
#define BIT_BT_ROM_8822B(x) \
(((x) & BIT_MASK_BT_ROM_8822B) << BIT_SHIFT_BT_ROM_8822B)
#define BITS_BT_ROM_8822B (BIT_MASK_BT_ROM_8822B << BIT_SHIFT_BT_ROM_8822B)
#define BIT_CLEAR_BT_ROM_8822B(x) ((x) & (~BITS_BT_ROM_8822B))
#define BIT_GET_BT_ROM_8822B(x) \
(((x) >> BIT_SHIFT_BT_ROM_8822B) & BIT_MASK_BT_ROM_8822B)
#define BIT_SET_BT_ROM_8822B(x, v) \
(BIT_CLEAR_BT_ROM_8822B(x) | BIT_BT_ROM_8822B(v))
#define BIT_SHIFT_PCI_DPRAM_8822B 10
#define BIT_MASK_PCI_DPRAM_8822B 0x3
#define BIT_PCI_DPRAM_8822B(x) \
(((x) & BIT_MASK_PCI_DPRAM_8822B) << BIT_SHIFT_PCI_DPRAM_8822B)
#define BITS_PCI_DPRAM_8822B \
(BIT_MASK_PCI_DPRAM_8822B << BIT_SHIFT_PCI_DPRAM_8822B)
#define BIT_CLEAR_PCI_DPRAM_8822B(x) ((x) & (~BITS_PCI_DPRAM_8822B))
#define BIT_GET_PCI_DPRAM_8822B(x) \
(((x) >> BIT_SHIFT_PCI_DPRAM_8822B) & BIT_MASK_PCI_DPRAM_8822B)
#define BIT_SET_PCI_DPRAM_8822B(x, v) \
(BIT_CLEAR_PCI_DPRAM_8822B(x) | BIT_PCI_DPRAM_8822B(v))
#define BIT_SHIFT_PCI_SPRAM_8822B 8
#define BIT_MASK_PCI_SPRAM_8822B 0x3
#define BIT_PCI_SPRAM_8822B(x) \
(((x) & BIT_MASK_PCI_SPRAM_8822B) << BIT_SHIFT_PCI_SPRAM_8822B)
#define BITS_PCI_SPRAM_8822B \
(BIT_MASK_PCI_SPRAM_8822B << BIT_SHIFT_PCI_SPRAM_8822B)
#define BIT_CLEAR_PCI_SPRAM_8822B(x) ((x) & (~BITS_PCI_SPRAM_8822B))
#define BIT_GET_PCI_SPRAM_8822B(x) \
(((x) >> BIT_SHIFT_PCI_SPRAM_8822B) & BIT_MASK_PCI_SPRAM_8822B)
#define BIT_SET_PCI_SPRAM_8822B(x, v) \
(BIT_CLEAR_PCI_SPRAM_8822B(x) | BIT_PCI_SPRAM_8822B(v))
#define BIT_SHIFT_USB_SPRAM_8822B 6
#define BIT_MASK_USB_SPRAM_8822B 0x3
#define BIT_USB_SPRAM_8822B(x) \
(((x) & BIT_MASK_USB_SPRAM_8822B) << BIT_SHIFT_USB_SPRAM_8822B)
#define BITS_USB_SPRAM_8822B \
(BIT_MASK_USB_SPRAM_8822B << BIT_SHIFT_USB_SPRAM_8822B)
#define BIT_CLEAR_USB_SPRAM_8822B(x) ((x) & (~BITS_USB_SPRAM_8822B))
#define BIT_GET_USB_SPRAM_8822B(x) \
(((x) >> BIT_SHIFT_USB_SPRAM_8822B) & BIT_MASK_USB_SPRAM_8822B)
#define BIT_SET_USB_SPRAM_8822B(x, v) \
(BIT_CLEAR_USB_SPRAM_8822B(x) | BIT_USB_SPRAM_8822B(v))
#define BIT_SHIFT_USB_SPRF_8822B 4
#define BIT_MASK_USB_SPRF_8822B 0x3
#define BIT_USB_SPRF_8822B(x) \
(((x) & BIT_MASK_USB_SPRF_8822B) << BIT_SHIFT_USB_SPRF_8822B)
#define BITS_USB_SPRF_8822B \
(BIT_MASK_USB_SPRF_8822B << BIT_SHIFT_USB_SPRF_8822B)
#define BIT_CLEAR_USB_SPRF_8822B(x) ((x) & (~BITS_USB_SPRF_8822B))
#define BIT_GET_USB_SPRF_8822B(x) \
(((x) >> BIT_SHIFT_USB_SPRF_8822B) & BIT_MASK_USB_SPRF_8822B)
#define BIT_SET_USB_SPRF_8822B(x, v) \
(BIT_CLEAR_USB_SPRF_8822B(x) | BIT_USB_SPRF_8822B(v))
#define BIT_SHIFT_MCU_ROM_8822B 0
#define BIT_MASK_MCU_ROM_8822B 0xf
#define BIT_MCU_ROM_8822B(x) \
(((x) & BIT_MASK_MCU_ROM_8822B) << BIT_SHIFT_MCU_ROM_8822B)
#define BITS_MCU_ROM_8822B (BIT_MASK_MCU_ROM_8822B << BIT_SHIFT_MCU_ROM_8822B)
#define BIT_CLEAR_MCU_ROM_8822B(x) ((x) & (~BITS_MCU_ROM_8822B))
#define BIT_GET_MCU_ROM_8822B(x) \
(((x) >> BIT_SHIFT_MCU_ROM_8822B) & BIT_MASK_MCU_ROM_8822B)
#define BIT_SET_MCU_ROM_8822B(x, v) \
(BIT_CLEAR_MCU_ROM_8822B(x) | BIT_MCU_ROM_8822B(v))
/* 2 REG_AFE_CTRL8_8822B */
#define BIT_SYN_AGPIO_8822B BIT(20)
#define BIT_XTAL_LP_8822B BIT(4)
#define BIT_XTAL_GM_SEP_8822B BIT(3)
#define BIT_SHIFT_XTAL_SEL_TOK_8822B 0
#define BIT_MASK_XTAL_SEL_TOK_8822B 0x7
#define BIT_XTAL_SEL_TOK_8822B(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_8822B) << BIT_SHIFT_XTAL_SEL_TOK_8822B)
#define BITS_XTAL_SEL_TOK_8822B \
(BIT_MASK_XTAL_SEL_TOK_8822B << BIT_SHIFT_XTAL_SEL_TOK_8822B)
#define BIT_CLEAR_XTAL_SEL_TOK_8822B(x) ((x) & (~BITS_XTAL_SEL_TOK_8822B))
#define BIT_GET_XTAL_SEL_TOK_8822B(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_8822B) & BIT_MASK_XTAL_SEL_TOK_8822B)
#define BIT_SET_XTAL_SEL_TOK_8822B(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_8822B(x) | BIT_XTAL_SEL_TOK_8822B(v))
/* 2 REG_USB_SIE_INTF_8822B */
#define BIT_RD_SEL_8822B BIT(31)
#define BIT_USB_SIE_INTF_WE_V1_8822B BIT(30)
#define BIT_USB_SIE_INTF_BYIOREG_V1_8822B BIT(29)
#define BIT_USB_SIE_SELECT_8822B BIT(28)
#define BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822B 16
#define BIT_MASK_USB_SIE_INTF_ADDR_V1_8822B 0x1ff
#define BIT_USB_SIE_INTF_ADDR_V1_8822B(x) \
(((x) & BIT_MASK_USB_SIE_INTF_ADDR_V1_8822B) \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822B)
#define BITS_USB_SIE_INTF_ADDR_V1_8822B \
(BIT_MASK_USB_SIE_INTF_ADDR_V1_8822B \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822B)
#define BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8822B(x) \
((x) & (~BITS_USB_SIE_INTF_ADDR_V1_8822B))
#define BIT_GET_USB_SIE_INTF_ADDR_V1_8822B(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822B) & \
BIT_MASK_USB_SIE_INTF_ADDR_V1_8822B)
#define BIT_SET_USB_SIE_INTF_ADDR_V1_8822B(x, v) \
(BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8822B(x) | \
BIT_USB_SIE_INTF_ADDR_V1_8822B(v))
#define BIT_SHIFT_USB_SIE_INTF_RD_8822B 8
#define BIT_MASK_USB_SIE_INTF_RD_8822B 0xff
#define BIT_USB_SIE_INTF_RD_8822B(x) \
(((x) & BIT_MASK_USB_SIE_INTF_RD_8822B) \
<< BIT_SHIFT_USB_SIE_INTF_RD_8822B)
#define BITS_USB_SIE_INTF_RD_8822B \
(BIT_MASK_USB_SIE_INTF_RD_8822B << BIT_SHIFT_USB_SIE_INTF_RD_8822B)
#define BIT_CLEAR_USB_SIE_INTF_RD_8822B(x) ((x) & (~BITS_USB_SIE_INTF_RD_8822B))
#define BIT_GET_USB_SIE_INTF_RD_8822B(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_RD_8822B) & \
BIT_MASK_USB_SIE_INTF_RD_8822B)
#define BIT_SET_USB_SIE_INTF_RD_8822B(x, v) \
(BIT_CLEAR_USB_SIE_INTF_RD_8822B(x) | BIT_USB_SIE_INTF_RD_8822B(v))
#define BIT_SHIFT_USB_SIE_INTF_WD_8822B 0
#define BIT_MASK_USB_SIE_INTF_WD_8822B 0xff
#define BIT_USB_SIE_INTF_WD_8822B(x) \
(((x) & BIT_MASK_USB_SIE_INTF_WD_8822B) \
<< BIT_SHIFT_USB_SIE_INTF_WD_8822B)
#define BITS_USB_SIE_INTF_WD_8822B \
(BIT_MASK_USB_SIE_INTF_WD_8822B << BIT_SHIFT_USB_SIE_INTF_WD_8822B)
#define BIT_CLEAR_USB_SIE_INTF_WD_8822B(x) ((x) & (~BITS_USB_SIE_INTF_WD_8822B))
#define BIT_GET_USB_SIE_INTF_WD_8822B(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_WD_8822B) & \
BIT_MASK_USB_SIE_INTF_WD_8822B)
#define BIT_SET_USB_SIE_INTF_WD_8822B(x, v) \
(BIT_CLEAR_USB_SIE_INTF_WD_8822B(x) | BIT_USB_SIE_INTF_WD_8822B(v))
/* 2 REG_PCIE_MIO_INTF_8822B */
#define BIT_PCIE_MIO_BYIOREG_8822B BIT(13)
#define BIT_PCIE_MIO_RE_8822B BIT(12)
#define BIT_SHIFT_PCIE_MIO_WE_8822B 8
#define BIT_MASK_PCIE_MIO_WE_8822B 0xf
#define BIT_PCIE_MIO_WE_8822B(x) \
(((x) & BIT_MASK_PCIE_MIO_WE_8822B) << BIT_SHIFT_PCIE_MIO_WE_8822B)
#define BITS_PCIE_MIO_WE_8822B \
(BIT_MASK_PCIE_MIO_WE_8822B << BIT_SHIFT_PCIE_MIO_WE_8822B)
#define BIT_CLEAR_PCIE_MIO_WE_8822B(x) ((x) & (~BITS_PCIE_MIO_WE_8822B))
#define BIT_GET_PCIE_MIO_WE_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_WE_8822B) & BIT_MASK_PCIE_MIO_WE_8822B)
#define BIT_SET_PCIE_MIO_WE_8822B(x, v) \
(BIT_CLEAR_PCIE_MIO_WE_8822B(x) | BIT_PCIE_MIO_WE_8822B(v))
#define BIT_SHIFT_PCIE_MIO_ADDR_8822B 0
#define BIT_MASK_PCIE_MIO_ADDR_8822B 0xff
#define BIT_PCIE_MIO_ADDR_8822B(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_8822B) << BIT_SHIFT_PCIE_MIO_ADDR_8822B)
#define BITS_PCIE_MIO_ADDR_8822B \
(BIT_MASK_PCIE_MIO_ADDR_8822B << BIT_SHIFT_PCIE_MIO_ADDR_8822B)
#define BIT_CLEAR_PCIE_MIO_ADDR_8822B(x) ((x) & (~BITS_PCIE_MIO_ADDR_8822B))
#define BIT_GET_PCIE_MIO_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_8822B) & BIT_MASK_PCIE_MIO_ADDR_8822B)
#define BIT_SET_PCIE_MIO_ADDR_8822B(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_8822B(x) | BIT_PCIE_MIO_ADDR_8822B(v))
/* 2 REG_PCIE_MIO_INTD_8822B */
#define BIT_SHIFT_PCIE_MIO_DATA_8822B 0
#define BIT_MASK_PCIE_MIO_DATA_8822B 0xffffffffL
#define BIT_PCIE_MIO_DATA_8822B(x) \
(((x) & BIT_MASK_PCIE_MIO_DATA_8822B) << BIT_SHIFT_PCIE_MIO_DATA_8822B)
#define BITS_PCIE_MIO_DATA_8822B \
(BIT_MASK_PCIE_MIO_DATA_8822B << BIT_SHIFT_PCIE_MIO_DATA_8822B)
#define BIT_CLEAR_PCIE_MIO_DATA_8822B(x) ((x) & (~BITS_PCIE_MIO_DATA_8822B))
#define BIT_GET_PCIE_MIO_DATA_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_DATA_8822B) & BIT_MASK_PCIE_MIO_DATA_8822B)
#define BIT_SET_PCIE_MIO_DATA_8822B(x, v) \
(BIT_CLEAR_PCIE_MIO_DATA_8822B(x) | BIT_PCIE_MIO_DATA_8822B(v))
/* 2 REG_WLRF1_8822B */
#define BIT_SHIFT_WLRF1_CTRL_8822B 24
#define BIT_MASK_WLRF1_CTRL_8822B 0xff
#define BIT_WLRF1_CTRL_8822B(x) \
(((x) & BIT_MASK_WLRF1_CTRL_8822B) << BIT_SHIFT_WLRF1_CTRL_8822B)
#define BITS_WLRF1_CTRL_8822B \
(BIT_MASK_WLRF1_CTRL_8822B << BIT_SHIFT_WLRF1_CTRL_8822B)
#define BIT_CLEAR_WLRF1_CTRL_8822B(x) ((x) & (~BITS_WLRF1_CTRL_8822B))
#define BIT_GET_WLRF1_CTRL_8822B(x) \
(((x) >> BIT_SHIFT_WLRF1_CTRL_8822B) & BIT_MASK_WLRF1_CTRL_8822B)
#define BIT_SET_WLRF1_CTRL_8822B(x, v) \
(BIT_CLEAR_WLRF1_CTRL_8822B(x) | BIT_WLRF1_CTRL_8822B(v))
/* 2 REG_SYS_CFG1_8822B */
#define BIT_SHIFT_TRP_ICFG_8822B 28
#define BIT_MASK_TRP_ICFG_8822B 0xf
#define BIT_TRP_ICFG_8822B(x) \
(((x) & BIT_MASK_TRP_ICFG_8822B) << BIT_SHIFT_TRP_ICFG_8822B)
#define BITS_TRP_ICFG_8822B \
(BIT_MASK_TRP_ICFG_8822B << BIT_SHIFT_TRP_ICFG_8822B)
#define BIT_CLEAR_TRP_ICFG_8822B(x) ((x) & (~BITS_TRP_ICFG_8822B))
#define BIT_GET_TRP_ICFG_8822B(x) \
(((x) >> BIT_SHIFT_TRP_ICFG_8822B) & BIT_MASK_TRP_ICFG_8822B)
#define BIT_SET_TRP_ICFG_8822B(x, v) \
(BIT_CLEAR_TRP_ICFG_8822B(x) | BIT_TRP_ICFG_8822B(v))
#define BIT_RF_TYPE_ID_8822B BIT(27)
#define BIT_BD_HCI_SEL_8822B BIT(26)
#define BIT_BD_PKG_SEL_8822B BIT(25)
#define BIT_SPSLDO_SEL_8822B BIT(24)
#define BIT_RTL_ID_8822B BIT(23)
#define BIT_PAD_HWPD_IDN_8822B BIT(22)
#define BIT_TESTMODE_8822B BIT(20)
#define BIT_SHIFT_VENDOR_ID_8822B 16
#define BIT_MASK_VENDOR_ID_8822B 0xf
#define BIT_VENDOR_ID_8822B(x) \
(((x) & BIT_MASK_VENDOR_ID_8822B) << BIT_SHIFT_VENDOR_ID_8822B)
#define BITS_VENDOR_ID_8822B \
(BIT_MASK_VENDOR_ID_8822B << BIT_SHIFT_VENDOR_ID_8822B)
#define BIT_CLEAR_VENDOR_ID_8822B(x) ((x) & (~BITS_VENDOR_ID_8822B))
#define BIT_GET_VENDOR_ID_8822B(x) \
(((x) >> BIT_SHIFT_VENDOR_ID_8822B) & BIT_MASK_VENDOR_ID_8822B)
#define BIT_SET_VENDOR_ID_8822B(x, v) \
(BIT_CLEAR_VENDOR_ID_8822B(x) | BIT_VENDOR_ID_8822B(v))
#define BIT_SHIFT_CHIP_VER_8822B 12
#define BIT_MASK_CHIP_VER_8822B 0xf
#define BIT_CHIP_VER_8822B(x) \
(((x) & BIT_MASK_CHIP_VER_8822B) << BIT_SHIFT_CHIP_VER_8822B)
#define BITS_CHIP_VER_8822B \
(BIT_MASK_CHIP_VER_8822B << BIT_SHIFT_CHIP_VER_8822B)
#define BIT_CLEAR_CHIP_VER_8822B(x) ((x) & (~BITS_CHIP_VER_8822B))
#define BIT_GET_CHIP_VER_8822B(x) \
(((x) >> BIT_SHIFT_CHIP_VER_8822B) & BIT_MASK_CHIP_VER_8822B)
#define BIT_SET_CHIP_VER_8822B(x, v) \
(BIT_CLEAR_CHIP_VER_8822B(x) | BIT_CHIP_VER_8822B(v))
#define BIT_BD_MAC3_8822B BIT(11)
#define BIT_BD_MAC1_8822B BIT(10)
#define BIT_BD_MAC2_8822B BIT(9)
#define BIT_SIC_IDLE_8822B BIT(8)
#define BIT_SW_OFFLOAD_EN_8822B BIT(7)
#define BIT_OCP_SHUTDN_8822B BIT(6)
#define BIT_V15_VLD_8822B BIT(5)
#define BIT_PCIRSTB_8822B BIT(4)
#define BIT_PCLK_VLD_8822B BIT(3)
#define BIT_UCLK_VLD_8822B BIT(2)
#define BIT_ACLK_VLD_8822B BIT(1)
#define BIT_XCLK_VLD_8822B BIT(0)
/* 2 REG_SYS_STATUS1_8822B */
#define BIT_SHIFT_RF_RL_ID_8822B 28
#define BIT_MASK_RF_RL_ID_8822B 0xf
#define BIT_RF_RL_ID_8822B(x) \
(((x) & BIT_MASK_RF_RL_ID_8822B) << BIT_SHIFT_RF_RL_ID_8822B)
#define BITS_RF_RL_ID_8822B \
(BIT_MASK_RF_RL_ID_8822B << BIT_SHIFT_RF_RL_ID_8822B)
#define BIT_CLEAR_RF_RL_ID_8822B(x) ((x) & (~BITS_RF_RL_ID_8822B))
#define BIT_GET_RF_RL_ID_8822B(x) \
(((x) >> BIT_SHIFT_RF_RL_ID_8822B) & BIT_MASK_RF_RL_ID_8822B)
#define BIT_SET_RF_RL_ID_8822B(x, v) \
(BIT_CLEAR_RF_RL_ID_8822B(x) | BIT_RF_RL_ID_8822B(v))
#define BIT_HPHY_ICFG_8822B BIT(19)
#define BIT_SHIFT_SEL_0XC0_8822B 16
#define BIT_MASK_SEL_0XC0_8822B 0x3
#define BIT_SEL_0XC0_8822B(x) \
(((x) & BIT_MASK_SEL_0XC0_8822B) << BIT_SHIFT_SEL_0XC0_8822B)
#define BITS_SEL_0XC0_8822B \
(BIT_MASK_SEL_0XC0_8822B << BIT_SHIFT_SEL_0XC0_8822B)
#define BIT_CLEAR_SEL_0XC0_8822B(x) ((x) & (~BITS_SEL_0XC0_8822B))
#define BIT_GET_SEL_0XC0_8822B(x) \
(((x) >> BIT_SHIFT_SEL_0XC0_8822B) & BIT_MASK_SEL_0XC0_8822B)
#define BIT_SET_SEL_0XC0_8822B(x, v) \
(BIT_CLEAR_SEL_0XC0_8822B(x) | BIT_SEL_0XC0_8822B(v))
#define BIT_SHIFT_HCI_SEL_V3_8822B 12
#define BIT_MASK_HCI_SEL_V3_8822B 0x7
#define BIT_HCI_SEL_V3_8822B(x) \
(((x) & BIT_MASK_HCI_SEL_V3_8822B) << BIT_SHIFT_HCI_SEL_V3_8822B)
#define BITS_HCI_SEL_V3_8822B \
(BIT_MASK_HCI_SEL_V3_8822B << BIT_SHIFT_HCI_SEL_V3_8822B)
#define BIT_CLEAR_HCI_SEL_V3_8822B(x) ((x) & (~BITS_HCI_SEL_V3_8822B))
#define BIT_GET_HCI_SEL_V3_8822B(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V3_8822B) & BIT_MASK_HCI_SEL_V3_8822B)
#define BIT_SET_HCI_SEL_V3_8822B(x, v) \
(BIT_CLEAR_HCI_SEL_V3_8822B(x) | BIT_HCI_SEL_V3_8822B(v))
#define BIT_USB_OPERATION_MODE_8822B BIT(10)
#define BIT_BT_PDN_8822B BIT(9)
#define BIT_AUTO_WLPON_8822B BIT(8)
#define BIT_WL_MODE_8822B BIT(7)
#define BIT_PKG_SEL_HCI_8822B BIT(6)
#define BIT_SHIFT_PAD_HCI_SEL_V1_8822B 3
#define BIT_MASK_PAD_HCI_SEL_V1_8822B 0x7
#define BIT_PAD_HCI_SEL_V1_8822B(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_V1_8822B) \
<< BIT_SHIFT_PAD_HCI_SEL_V1_8822B)
#define BITS_PAD_HCI_SEL_V1_8822B \
(BIT_MASK_PAD_HCI_SEL_V1_8822B << BIT_SHIFT_PAD_HCI_SEL_V1_8822B)
#define BIT_CLEAR_PAD_HCI_SEL_V1_8822B(x) ((x) & (~BITS_PAD_HCI_SEL_V1_8822B))
#define BIT_GET_PAD_HCI_SEL_V1_8822B(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_V1_8822B) & \
BIT_MASK_PAD_HCI_SEL_V1_8822B)
#define BIT_SET_PAD_HCI_SEL_V1_8822B(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_V1_8822B(x) | BIT_PAD_HCI_SEL_V1_8822B(v))
#define BIT_SHIFT_EFS_HCI_SEL_V1_8822B 0
#define BIT_MASK_EFS_HCI_SEL_V1_8822B 0x7
#define BIT_EFS_HCI_SEL_V1_8822B(x) \
(((x) & BIT_MASK_EFS_HCI_SEL_V1_8822B) \
<< BIT_SHIFT_EFS_HCI_SEL_V1_8822B)
#define BITS_EFS_HCI_SEL_V1_8822B \
(BIT_MASK_EFS_HCI_SEL_V1_8822B << BIT_SHIFT_EFS_HCI_SEL_V1_8822B)
#define BIT_CLEAR_EFS_HCI_SEL_V1_8822B(x) ((x) & (~BITS_EFS_HCI_SEL_V1_8822B))
#define BIT_GET_EFS_HCI_SEL_V1_8822B(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL_V1_8822B) & \
BIT_MASK_EFS_HCI_SEL_V1_8822B)
#define BIT_SET_EFS_HCI_SEL_V1_8822B(x, v) \
(BIT_CLEAR_EFS_HCI_SEL_V1_8822B(x) | BIT_EFS_HCI_SEL_V1_8822B(v))
/* 2 REG_SYS_STATUS2_8822B */
#define BIT_SIO_ALDN_8822B BIT(19)
#define BIT_USB_ALDN_8822B BIT(18)
#define BIT_PCI_ALDN_8822B BIT(17)
#define BIT_SYS_ALDN_8822B BIT(16)
#define BIT_SHIFT_EPVID1_8822B 8
#define BIT_MASK_EPVID1_8822B 0xff
#define BIT_EPVID1_8822B(x) \
(((x) & BIT_MASK_EPVID1_8822B) << BIT_SHIFT_EPVID1_8822B)
#define BITS_EPVID1_8822B (BIT_MASK_EPVID1_8822B << BIT_SHIFT_EPVID1_8822B)
#define BIT_CLEAR_EPVID1_8822B(x) ((x) & (~BITS_EPVID1_8822B))
#define BIT_GET_EPVID1_8822B(x) \
(((x) >> BIT_SHIFT_EPVID1_8822B) & BIT_MASK_EPVID1_8822B)
#define BIT_SET_EPVID1_8822B(x, v) \
(BIT_CLEAR_EPVID1_8822B(x) | BIT_EPVID1_8822B(v))
#define BIT_SHIFT_EPVID0_8822B 0
#define BIT_MASK_EPVID0_8822B 0xff
#define BIT_EPVID0_8822B(x) \
(((x) & BIT_MASK_EPVID0_8822B) << BIT_SHIFT_EPVID0_8822B)
#define BITS_EPVID0_8822B (BIT_MASK_EPVID0_8822B << BIT_SHIFT_EPVID0_8822B)
#define BIT_CLEAR_EPVID0_8822B(x) ((x) & (~BITS_EPVID0_8822B))
#define BIT_GET_EPVID0_8822B(x) \
(((x) >> BIT_SHIFT_EPVID0_8822B) & BIT_MASK_EPVID0_8822B)
#define BIT_SET_EPVID0_8822B(x, v) \
(BIT_CLEAR_EPVID0_8822B(x) | BIT_EPVID0_8822B(v))
/* 2 REG_SYS_CFG2_8822B */
#define BIT_HCI_SEL_EMBEDDED_8822B BIT(8)
#define BIT_SHIFT_HW_ID_8822B 0
#define BIT_MASK_HW_ID_8822B 0xff
#define BIT_HW_ID_8822B(x) \
(((x) & BIT_MASK_HW_ID_8822B) << BIT_SHIFT_HW_ID_8822B)
#define BITS_HW_ID_8822B (BIT_MASK_HW_ID_8822B << BIT_SHIFT_HW_ID_8822B)
#define BIT_CLEAR_HW_ID_8822B(x) ((x) & (~BITS_HW_ID_8822B))
#define BIT_GET_HW_ID_8822B(x) \
(((x) >> BIT_SHIFT_HW_ID_8822B) & BIT_MASK_HW_ID_8822B)
#define BIT_SET_HW_ID_8822B(x, v) \
(BIT_CLEAR_HW_ID_8822B(x) | BIT_HW_ID_8822B(v))
/* 2 REG_SYS_CFG3_8822B */
#define BIT_PWC_MA33V_8822B BIT(15)
#define BIT_PWC_MA12V_8822B BIT(14)
#define BIT_PWC_MD12V_8822B BIT(13)
#define BIT_PWC_PD12V_8822B BIT(12)
#define BIT_PWC_UD12V_8822B BIT(11)
#define BIT_ISO_MA2MD_8822B BIT(1)
#define BIT_ISO_MD2PP_8822B BIT(0)
/* 2 REG_SYS_CFG4_8822B */
/* 2 REG_SYS_CFG5_8822B */
#define BIT_LPS_STATUS_8822B BIT(3)
#define BIT_HCI_TXDMA_BUSY_8822B BIT(2)
#define BIT_HCI_TXDMA_ALLOW_8822B BIT(1)
#define BIT_FW_CTRL_HCI_TXDMA_EN_8822B BIT(0)
/* 2 REG_CPU_DMEM_CON_8822B */
#define BIT_WDT_OPT_IOWRAPPER_8822B BIT(19)
#define BIT_ANA_PORT_IDLE_8822B BIT(18)
#define BIT_MAC_PORT_IDLE_8822B BIT(17)
#define BIT_WL_PLATFORM_RST_8822B BIT(16)
#define BIT_WL_SECURITY_CLK_8822B BIT(15)
#define BIT_SHIFT_CPU_DMEM_CON_8822B 0
#define BIT_MASK_CPU_DMEM_CON_8822B 0xff
#define BIT_CPU_DMEM_CON_8822B(x) \
(((x) & BIT_MASK_CPU_DMEM_CON_8822B) << BIT_SHIFT_CPU_DMEM_CON_8822B)
#define BITS_CPU_DMEM_CON_8822B \
(BIT_MASK_CPU_DMEM_CON_8822B << BIT_SHIFT_CPU_DMEM_CON_8822B)
#define BIT_CLEAR_CPU_DMEM_CON_8822B(x) ((x) & (~BITS_CPU_DMEM_CON_8822B))
#define BIT_GET_CPU_DMEM_CON_8822B(x) \
(((x) >> BIT_SHIFT_CPU_DMEM_CON_8822B) & BIT_MASK_CPU_DMEM_CON_8822B)
#define BIT_SET_CPU_DMEM_CON_8822B(x, v) \
(BIT_CLEAR_CPU_DMEM_CON_8822B(x) | BIT_CPU_DMEM_CON_8822B(v))
/* 2 REG_BOOT_REASON_8822B */
#define BIT_SHIFT_BOOT_REASON_V1_8822B 0
#define BIT_MASK_BOOT_REASON_V1_8822B 0x7
#define BIT_BOOT_REASON_V1_8822B(x) \
(((x) & BIT_MASK_BOOT_REASON_V1_8822B) \
<< BIT_SHIFT_BOOT_REASON_V1_8822B)
#define BITS_BOOT_REASON_V1_8822B \
(BIT_MASK_BOOT_REASON_V1_8822B << BIT_SHIFT_BOOT_REASON_V1_8822B)
#define BIT_CLEAR_BOOT_REASON_V1_8822B(x) ((x) & (~BITS_BOOT_REASON_V1_8822B))
#define BIT_GET_BOOT_REASON_V1_8822B(x) \
(((x) >> BIT_SHIFT_BOOT_REASON_V1_8822B) & \
BIT_MASK_BOOT_REASON_V1_8822B)
#define BIT_SET_BOOT_REASON_V1_8822B(x, v) \
(BIT_CLEAR_BOOT_REASON_V1_8822B(x) | BIT_BOOT_REASON_V1_8822B(v))
/* 2 REG_NFCPAD_CTRL_8822B */
#define BIT_PAD_SHUTDW_8822B BIT(18)
#define BIT_SYSON_NFC_PAD_8822B BIT(17)
#define BIT_NFC_INT_PAD_CTRL_8822B BIT(16)
#define BIT_NFC_RFDIS_PAD_CTRL_8822B BIT(15)
#define BIT_NFC_CLK_PAD_CTRL_8822B BIT(14)
#define BIT_NFC_DATA_PAD_CTRL_8822B BIT(13)
#define BIT_NFC_PAD_PULL_CTRL_8822B BIT(12)
#define BIT_SHIFT_NFCPAD_IO_SEL_8822B 8
#define BIT_MASK_NFCPAD_IO_SEL_8822B 0xf
#define BIT_NFCPAD_IO_SEL_8822B(x) \
(((x) & BIT_MASK_NFCPAD_IO_SEL_8822B) << BIT_SHIFT_NFCPAD_IO_SEL_8822B)
#define BITS_NFCPAD_IO_SEL_8822B \
(BIT_MASK_NFCPAD_IO_SEL_8822B << BIT_SHIFT_NFCPAD_IO_SEL_8822B)
#define BIT_CLEAR_NFCPAD_IO_SEL_8822B(x) ((x) & (~BITS_NFCPAD_IO_SEL_8822B))
#define BIT_GET_NFCPAD_IO_SEL_8822B(x) \
(((x) >> BIT_SHIFT_NFCPAD_IO_SEL_8822B) & BIT_MASK_NFCPAD_IO_SEL_8822B)
#define BIT_SET_NFCPAD_IO_SEL_8822B(x, v) \
(BIT_CLEAR_NFCPAD_IO_SEL_8822B(x) | BIT_NFCPAD_IO_SEL_8822B(v))
#define BIT_SHIFT_NFCPAD_OUT_8822B 4
#define BIT_MASK_NFCPAD_OUT_8822B 0xf
#define BIT_NFCPAD_OUT_8822B(x) \
(((x) & BIT_MASK_NFCPAD_OUT_8822B) << BIT_SHIFT_NFCPAD_OUT_8822B)
#define BITS_NFCPAD_OUT_8822B \
(BIT_MASK_NFCPAD_OUT_8822B << BIT_SHIFT_NFCPAD_OUT_8822B)
#define BIT_CLEAR_NFCPAD_OUT_8822B(x) ((x) & (~BITS_NFCPAD_OUT_8822B))
#define BIT_GET_NFCPAD_OUT_8822B(x) \
(((x) >> BIT_SHIFT_NFCPAD_OUT_8822B) & BIT_MASK_NFCPAD_OUT_8822B)
#define BIT_SET_NFCPAD_OUT_8822B(x, v) \
(BIT_CLEAR_NFCPAD_OUT_8822B(x) | BIT_NFCPAD_OUT_8822B(v))
#define BIT_SHIFT_NFCPAD_IN_8822B 0
#define BIT_MASK_NFCPAD_IN_8822B 0xf
#define BIT_NFCPAD_IN_8822B(x) \
(((x) & BIT_MASK_NFCPAD_IN_8822B) << BIT_SHIFT_NFCPAD_IN_8822B)
#define BITS_NFCPAD_IN_8822B \
(BIT_MASK_NFCPAD_IN_8822B << BIT_SHIFT_NFCPAD_IN_8822B)
#define BIT_CLEAR_NFCPAD_IN_8822B(x) ((x) & (~BITS_NFCPAD_IN_8822B))
#define BIT_GET_NFCPAD_IN_8822B(x) \
(((x) >> BIT_SHIFT_NFCPAD_IN_8822B) & BIT_MASK_NFCPAD_IN_8822B)
#define BIT_SET_NFCPAD_IN_8822B(x, v) \
(BIT_CLEAR_NFCPAD_IN_8822B(x) | BIT_NFCPAD_IN_8822B(v))
/* 2 REG_HIMR2_8822B */
#define BIT_BCNDMAINT_P4_MSK_8822B BIT(31)
#define BIT_BCNDMAINT_P3_MSK_8822B BIT(30)
#define BIT_BCNDMAINT_P2_MSK_8822B BIT(29)
#define BIT_BCNDMAINT_P1_MSK_8822B BIT(28)
#define BIT_ATIMEND7_MSK_8822B BIT(22)
#define BIT_ATIMEND6_MSK_8822B BIT(21)
#define BIT_ATIMEND5_MSK_8822B BIT(20)
#define BIT_ATIMEND4_MSK_8822B BIT(19)
#define BIT_ATIMEND3_MSK_8822B BIT(18)
#define BIT_ATIMEND2_MSK_8822B BIT(17)
#define BIT_ATIMEND1_MSK_8822B BIT(16)
#define BIT_TXBCN7OK_MSK_8822B BIT(14)
#define BIT_TXBCN6OK_MSK_8822B BIT(13)
#define BIT_TXBCN5OK_MSK_8822B BIT(12)
#define BIT_TXBCN4OK_MSK_8822B BIT(11)
#define BIT_TXBCN3OK_MSK_8822B BIT(10)
#define BIT_TXBCN2OK_MSK_8822B BIT(9)
#define BIT_TXBCN1OK_MSK_V1_8822B BIT(8)
#define BIT_TXBCN7ERR_MSK_8822B BIT(6)
#define BIT_TXBCN6ERR_MSK_8822B BIT(5)
#define BIT_TXBCN5ERR_MSK_8822B BIT(4)
#define BIT_TXBCN4ERR_MSK_8822B BIT(3)
#define BIT_TXBCN3ERR_MSK_8822B BIT(2)
#define BIT_TXBCN2ERR_MSK_8822B BIT(1)
#define BIT_TXBCN1ERR_MSK_V1_8822B BIT(0)
/* 2 REG_HISR2_8822B */
#define BIT_BCNDMAINT_P4_8822B BIT(31)
#define BIT_BCNDMAINT_P3_8822B BIT(30)
#define BIT_BCNDMAINT_P2_8822B BIT(29)
#define BIT_BCNDMAINT_P1_8822B BIT(28)
#define BIT_ATIMEND7_8822B BIT(22)
#define BIT_ATIMEND6_8822B BIT(21)
#define BIT_ATIMEND5_8822B BIT(20)
#define BIT_ATIMEND4_8822B BIT(19)
#define BIT_ATIMEND3_8822B BIT(18)
#define BIT_ATIMEND2_8822B BIT(17)
#define BIT_ATIMEND1_8822B BIT(16)
#define BIT_TXBCN7OK_8822B BIT(14)
#define BIT_TXBCN6OK_8822B BIT(13)
#define BIT_TXBCN5OK_8822B BIT(12)
#define BIT_TXBCN4OK_8822B BIT(11)
#define BIT_TXBCN3OK_8822B BIT(10)
#define BIT_TXBCN2OK_8822B BIT(9)
#define BIT_TXBCN1OK_8822B BIT(8)
#define BIT_TXBCN7ERR_8822B BIT(6)
#define BIT_TXBCN6ERR_8822B BIT(5)
#define BIT_TXBCN5ERR_8822B BIT(4)
#define BIT_TXBCN4ERR_8822B BIT(3)
#define BIT_TXBCN3ERR_8822B BIT(2)
#define BIT_TXBCN2ERR_8822B BIT(1)
#define BIT_TXBCN1ERR_8822B BIT(0)
/* 2 REG_HIMR3_8822B */
#define BIT_WDT_PLATFORM_INT_MSK_8822B BIT(18)
#define BIT_WDT_CPU_INT_MSK_8822B BIT(17)
#define BIT_SETH2CDOK_MASK_8822B BIT(16)
#define BIT_H2C_CMD_FULL_MASK_8822B BIT(15)
#define BIT_PWR_INT_127_MASK_8822B BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_MASK_8822B BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_MASK_8822B BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_MASK_8822B BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_MAS_8822B BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_MASK_8822B BIT(9)
#define BIT_PWR_INT_127_MASK_V1_8822B BIT(8)
#define BIT_PWR_INT_126TO96_MASK_8822B BIT(7)
#define BIT_PWR_INT_95TO64_MASK_8822B BIT(6)
#define BIT_PWR_INT_63TO32_MASK_8822B BIT(5)
#define BIT_PWR_INT_31TO0_MASK_8822B BIT(4)
#define BIT_DDMA0_LP_INT_MSK_8822B BIT(1)
#define BIT_DDMA0_HP_INT_MSK_8822B BIT(0)
/* 2 REG_HISR3_8822B */
#define BIT_WDT_PLATFORM_INT_8822B BIT(18)
#define BIT_WDT_CPU_INT_8822B BIT(17)
#define BIT_SETH2CDOK_8822B BIT(16)
#define BIT_H2C_CMD_FULL_8822B BIT(15)
#define BIT_PWR_INT_127_8822B BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8822B BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8822B BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8822B BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8822B BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8822B BIT(9)
#define BIT_PWR_INT_127_V1_8822B BIT(8)
#define BIT_PWR_INT_126TO96_8822B BIT(7)
#define BIT_PWR_INT_95TO64_8822B BIT(6)
#define BIT_PWR_INT_63TO32_8822B BIT(5)
#define BIT_PWR_INT_31TO0_8822B BIT(4)
#define BIT_DDMA0_LP_INT_8822B BIT(1)
#define BIT_DDMA0_HP_INT_8822B BIT(0)
/* 2 REG_SW_MDIO_8822B */
#define BIT_DIS_TIMEOUT_IO_8822B BIT(24)
/* 2 REG_SW_FLUSH_8822B */
#define BIT_FLUSH_HOLDN_EN_8822B BIT(25)
#define BIT_FLUSH_WR_EN_8822B BIT(24)
#define BIT_SW_FLASH_CONTROL_8822B BIT(23)
#define BIT_SW_FLASH_WEN_E_8822B BIT(19)
#define BIT_SW_FLASH_HOLDN_E_8822B BIT(18)
#define BIT_SW_FLASH_SO_E_8822B BIT(17)
#define BIT_SW_FLASH_SI_E_8822B BIT(16)
#define BIT_SW_FLASH_SK_O_8822B BIT(13)
#define BIT_SW_FLASH_CEN_O_8822B BIT(12)
#define BIT_SW_FLASH_WEN_O_8822B BIT(11)
#define BIT_SW_FLASH_HOLDN_O_8822B BIT(10)
#define BIT_SW_FLASH_SO_O_8822B BIT(9)
#define BIT_SW_FLASH_SI_O_8822B BIT(8)
#define BIT_SW_FLASH_WEN_I_8822B BIT(3)
#define BIT_SW_FLASH_HOLDN_I_8822B BIT(2)
#define BIT_SW_FLASH_SO_I_8822B BIT(1)
#define BIT_SW_FLASH_SI_I_8822B BIT(0)
/* 2 REG_H2C_PKT_READADDR_8822B */
#define BIT_SHIFT_H2C_PKT_READADDR_8822B 0
#define BIT_MASK_H2C_PKT_READADDR_8822B 0x3ffff
#define BIT_H2C_PKT_READADDR_8822B(x) \
(((x) & BIT_MASK_H2C_PKT_READADDR_8822B) \
<< BIT_SHIFT_H2C_PKT_READADDR_8822B)
#define BITS_H2C_PKT_READADDR_8822B \
(BIT_MASK_H2C_PKT_READADDR_8822B << BIT_SHIFT_H2C_PKT_READADDR_8822B)
#define BIT_CLEAR_H2C_PKT_READADDR_8822B(x) \
((x) & (~BITS_H2C_PKT_READADDR_8822B))
#define BIT_GET_H2C_PKT_READADDR_8822B(x) \
(((x) >> BIT_SHIFT_H2C_PKT_READADDR_8822B) & \
BIT_MASK_H2C_PKT_READADDR_8822B)
#define BIT_SET_H2C_PKT_READADDR_8822B(x, v) \
(BIT_CLEAR_H2C_PKT_READADDR_8822B(x) | BIT_H2C_PKT_READADDR_8822B(v))
/* 2 REG_H2C_PKT_WRITEADDR_8822B */
#define BIT_SHIFT_H2C_PKT_WRITEADDR_8822B 0
#define BIT_MASK_H2C_PKT_WRITEADDR_8822B 0x3ffff
#define BIT_H2C_PKT_WRITEADDR_8822B(x) \
(((x) & BIT_MASK_H2C_PKT_WRITEADDR_8822B) \
<< BIT_SHIFT_H2C_PKT_WRITEADDR_8822B)
#define BITS_H2C_PKT_WRITEADDR_8822B \
(BIT_MASK_H2C_PKT_WRITEADDR_8822B << BIT_SHIFT_H2C_PKT_WRITEADDR_8822B)
#define BIT_CLEAR_H2C_PKT_WRITEADDR_8822B(x) \
((x) & (~BITS_H2C_PKT_WRITEADDR_8822B))
#define BIT_GET_H2C_PKT_WRITEADDR_8822B(x) \
(((x) >> BIT_SHIFT_H2C_PKT_WRITEADDR_8822B) & \
BIT_MASK_H2C_PKT_WRITEADDR_8822B)
#define BIT_SET_H2C_PKT_WRITEADDR_8822B(x, v) \
(BIT_CLEAR_H2C_PKT_WRITEADDR_8822B(x) | BIT_H2C_PKT_WRITEADDR_8822B(v))
/* 2 REG_MEM_PWR_CRTL_8822B */
#define BIT_MEM_BB_SD_8822B BIT(17)
#define BIT_MEM_BB_DS_8822B BIT(16)
#define BIT_MEM_BT_DS_8822B BIT(10)
#define BIT_MEM_SDIO_LS_8822B BIT(9)
#define BIT_MEM_SDIO_DS_8822B BIT(8)
#define BIT_MEM_USB_LS_8822B BIT(7)
#define BIT_MEM_USB_DS_8822B BIT(6)
#define BIT_MEM_PCI_LS_8822B BIT(5)
#define BIT_MEM_PCI_DS_8822B BIT(4)
#define BIT_MEM_WLMAC_LS_8822B BIT(3)
#define BIT_MEM_WLMAC_DS_8822B BIT(2)
#define BIT_MEM_WLMCU_LS_8822B BIT(1)
#define BIT_MEM_WLMCU_DS_8822B BIT(0)
/* 2 REG_FW_DBG0_8822B */
#define BIT_SHIFT_FW_DBG0_8822B 0
#define BIT_MASK_FW_DBG0_8822B 0xffffffffL
#define BIT_FW_DBG0_8822B(x) \
(((x) & BIT_MASK_FW_DBG0_8822B) << BIT_SHIFT_FW_DBG0_8822B)
#define BITS_FW_DBG0_8822B (BIT_MASK_FW_DBG0_8822B << BIT_SHIFT_FW_DBG0_8822B)
#define BIT_CLEAR_FW_DBG0_8822B(x) ((x) & (~BITS_FW_DBG0_8822B))
#define BIT_GET_FW_DBG0_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG0_8822B) & BIT_MASK_FW_DBG0_8822B)
#define BIT_SET_FW_DBG0_8822B(x, v) \
(BIT_CLEAR_FW_DBG0_8822B(x) | BIT_FW_DBG0_8822B(v))
/* 2 REG_FW_DBG1_8822B */
#define BIT_SHIFT_FW_DBG1_8822B 0
#define BIT_MASK_FW_DBG1_8822B 0xffffffffL
#define BIT_FW_DBG1_8822B(x) \
(((x) & BIT_MASK_FW_DBG1_8822B) << BIT_SHIFT_FW_DBG1_8822B)
#define BITS_FW_DBG1_8822B (BIT_MASK_FW_DBG1_8822B << BIT_SHIFT_FW_DBG1_8822B)
#define BIT_CLEAR_FW_DBG1_8822B(x) ((x) & (~BITS_FW_DBG1_8822B))
#define BIT_GET_FW_DBG1_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG1_8822B) & BIT_MASK_FW_DBG1_8822B)
#define BIT_SET_FW_DBG1_8822B(x, v) \
(BIT_CLEAR_FW_DBG1_8822B(x) | BIT_FW_DBG1_8822B(v))
/* 2 REG_FW_DBG2_8822B */
#define BIT_SHIFT_FW_DBG2_8822B 0
#define BIT_MASK_FW_DBG2_8822B 0xffffffffL
#define BIT_FW_DBG2_8822B(x) \
(((x) & BIT_MASK_FW_DBG2_8822B) << BIT_SHIFT_FW_DBG2_8822B)
#define BITS_FW_DBG2_8822B (BIT_MASK_FW_DBG2_8822B << BIT_SHIFT_FW_DBG2_8822B)
#define BIT_CLEAR_FW_DBG2_8822B(x) ((x) & (~BITS_FW_DBG2_8822B))
#define BIT_GET_FW_DBG2_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG2_8822B) & BIT_MASK_FW_DBG2_8822B)
#define BIT_SET_FW_DBG2_8822B(x, v) \
(BIT_CLEAR_FW_DBG2_8822B(x) | BIT_FW_DBG2_8822B(v))
/* 2 REG_FW_DBG3_8822B */
#define BIT_SHIFT_FW_DBG3_8822B 0
#define BIT_MASK_FW_DBG3_8822B 0xffffffffL
#define BIT_FW_DBG3_8822B(x) \
(((x) & BIT_MASK_FW_DBG3_8822B) << BIT_SHIFT_FW_DBG3_8822B)
#define BITS_FW_DBG3_8822B (BIT_MASK_FW_DBG3_8822B << BIT_SHIFT_FW_DBG3_8822B)
#define BIT_CLEAR_FW_DBG3_8822B(x) ((x) & (~BITS_FW_DBG3_8822B))
#define BIT_GET_FW_DBG3_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG3_8822B) & BIT_MASK_FW_DBG3_8822B)
#define BIT_SET_FW_DBG3_8822B(x, v) \
(BIT_CLEAR_FW_DBG3_8822B(x) | BIT_FW_DBG3_8822B(v))
/* 2 REG_FW_DBG4_8822B */
#define BIT_SHIFT_FW_DBG4_8822B 0
#define BIT_MASK_FW_DBG4_8822B 0xffffffffL
#define BIT_FW_DBG4_8822B(x) \
(((x) & BIT_MASK_FW_DBG4_8822B) << BIT_SHIFT_FW_DBG4_8822B)
#define BITS_FW_DBG4_8822B (BIT_MASK_FW_DBG4_8822B << BIT_SHIFT_FW_DBG4_8822B)
#define BIT_CLEAR_FW_DBG4_8822B(x) ((x) & (~BITS_FW_DBG4_8822B))
#define BIT_GET_FW_DBG4_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG4_8822B) & BIT_MASK_FW_DBG4_8822B)
#define BIT_SET_FW_DBG4_8822B(x, v) \
(BIT_CLEAR_FW_DBG4_8822B(x) | BIT_FW_DBG4_8822B(v))
/* 2 REG_FW_DBG5_8822B */
#define BIT_SHIFT_FW_DBG5_8822B 0
#define BIT_MASK_FW_DBG5_8822B 0xffffffffL
#define BIT_FW_DBG5_8822B(x) \
(((x) & BIT_MASK_FW_DBG5_8822B) << BIT_SHIFT_FW_DBG5_8822B)
#define BITS_FW_DBG5_8822B (BIT_MASK_FW_DBG5_8822B << BIT_SHIFT_FW_DBG5_8822B)
#define BIT_CLEAR_FW_DBG5_8822B(x) ((x) & (~BITS_FW_DBG5_8822B))
#define BIT_GET_FW_DBG5_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG5_8822B) & BIT_MASK_FW_DBG5_8822B)
#define BIT_SET_FW_DBG5_8822B(x, v) \
(BIT_CLEAR_FW_DBG5_8822B(x) | BIT_FW_DBG5_8822B(v))
/* 2 REG_FW_DBG6_8822B */
#define BIT_SHIFT_FW_DBG6_8822B 0
#define BIT_MASK_FW_DBG6_8822B 0xffffffffL
#define BIT_FW_DBG6_8822B(x) \
(((x) & BIT_MASK_FW_DBG6_8822B) << BIT_SHIFT_FW_DBG6_8822B)
#define BITS_FW_DBG6_8822B (BIT_MASK_FW_DBG6_8822B << BIT_SHIFT_FW_DBG6_8822B)
#define BIT_CLEAR_FW_DBG6_8822B(x) ((x) & (~BITS_FW_DBG6_8822B))
#define BIT_GET_FW_DBG6_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG6_8822B) & BIT_MASK_FW_DBG6_8822B)
#define BIT_SET_FW_DBG6_8822B(x, v) \
(BIT_CLEAR_FW_DBG6_8822B(x) | BIT_FW_DBG6_8822B(v))
/* 2 REG_FW_DBG7_8822B */
#define BIT_SHIFT_FW_DBG7_8822B 0
#define BIT_MASK_FW_DBG7_8822B 0xffffffffL
#define BIT_FW_DBG7_8822B(x) \
(((x) & BIT_MASK_FW_DBG7_8822B) << BIT_SHIFT_FW_DBG7_8822B)
#define BITS_FW_DBG7_8822B (BIT_MASK_FW_DBG7_8822B << BIT_SHIFT_FW_DBG7_8822B)
#define BIT_CLEAR_FW_DBG7_8822B(x) ((x) & (~BITS_FW_DBG7_8822B))
#define BIT_GET_FW_DBG7_8822B(x) \
(((x) >> BIT_SHIFT_FW_DBG7_8822B) & BIT_MASK_FW_DBG7_8822B)
#define BIT_SET_FW_DBG7_8822B(x, v) \
(BIT_CLEAR_FW_DBG7_8822B(x) | BIT_FW_DBG7_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_CR_8822B */
#define BIT_SHIFT_LBMODE_8822B 24
#define BIT_MASK_LBMODE_8822B 0x1f
#define BIT_LBMODE_8822B(x) \
(((x) & BIT_MASK_LBMODE_8822B) << BIT_SHIFT_LBMODE_8822B)
#define BITS_LBMODE_8822B (BIT_MASK_LBMODE_8822B << BIT_SHIFT_LBMODE_8822B)
#define BIT_CLEAR_LBMODE_8822B(x) ((x) & (~BITS_LBMODE_8822B))
#define BIT_GET_LBMODE_8822B(x) \
(((x) >> BIT_SHIFT_LBMODE_8822B) & BIT_MASK_LBMODE_8822B)
#define BIT_SET_LBMODE_8822B(x, v) \
(BIT_CLEAR_LBMODE_8822B(x) | BIT_LBMODE_8822B(v))
#define BIT_SHIFT_NETYPE1_8822B 18
#define BIT_MASK_NETYPE1_8822B 0x3
#define BIT_NETYPE1_8822B(x) \
(((x) & BIT_MASK_NETYPE1_8822B) << BIT_SHIFT_NETYPE1_8822B)
#define BITS_NETYPE1_8822B (BIT_MASK_NETYPE1_8822B << BIT_SHIFT_NETYPE1_8822B)
#define BIT_CLEAR_NETYPE1_8822B(x) ((x) & (~BITS_NETYPE1_8822B))
#define BIT_GET_NETYPE1_8822B(x) \
(((x) >> BIT_SHIFT_NETYPE1_8822B) & BIT_MASK_NETYPE1_8822B)
#define BIT_SET_NETYPE1_8822B(x, v) \
(BIT_CLEAR_NETYPE1_8822B(x) | BIT_NETYPE1_8822B(v))
#define BIT_SHIFT_NETYPE0_8822B 16
#define BIT_MASK_NETYPE0_8822B 0x3
#define BIT_NETYPE0_8822B(x) \
(((x) & BIT_MASK_NETYPE0_8822B) << BIT_SHIFT_NETYPE0_8822B)
#define BITS_NETYPE0_8822B (BIT_MASK_NETYPE0_8822B << BIT_SHIFT_NETYPE0_8822B)
#define BIT_CLEAR_NETYPE0_8822B(x) ((x) & (~BITS_NETYPE0_8822B))
#define BIT_GET_NETYPE0_8822B(x) \
(((x) >> BIT_SHIFT_NETYPE0_8822B) & BIT_MASK_NETYPE0_8822B)
#define BIT_SET_NETYPE0_8822B(x, v) \
(BIT_CLEAR_NETYPE0_8822B(x) | BIT_NETYPE0_8822B(v))
#define BIT_I2C_MAILBOX_EN_8822B BIT(12)
#define BIT_SHCUT_EN_8822B BIT(11)
#define BIT_32K_CAL_TMR_EN_8822B BIT(10)
#define BIT_MAC_SEC_EN_8822B BIT(9)
#define BIT_ENSWBCN_8822B BIT(8)
#define BIT_MACRXEN_8822B BIT(7)
#define BIT_MACTXEN_8822B BIT(6)
#define BIT_SCHEDULE_EN_8822B BIT(5)
#define BIT_PROTOCOL_EN_8822B BIT(4)
#define BIT_RXDMA_EN_8822B BIT(3)
#define BIT_TXDMA_EN_8822B BIT(2)
#define BIT_HCI_RXDMA_EN_8822B BIT(1)
#define BIT_HCI_TXDMA_EN_8822B BIT(0)
/* 2 REG_TSF_CLK_STATE_8822B */
#define BIT_TSF_CLK_STABLE_8822B BIT(15)
/* 2 REG_TXDMA_PQ_MAP_8822B */
#define BIT_SHIFT_TXDMA_HIQ_MAP_8822B 14
#define BIT_MASK_TXDMA_HIQ_MAP_8822B 0x3
#define BIT_TXDMA_HIQ_MAP_8822B(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP_8822B) << BIT_SHIFT_TXDMA_HIQ_MAP_8822B)
#define BITS_TXDMA_HIQ_MAP_8822B \
(BIT_MASK_TXDMA_HIQ_MAP_8822B << BIT_SHIFT_TXDMA_HIQ_MAP_8822B)
#define BIT_CLEAR_TXDMA_HIQ_MAP_8822B(x) ((x) & (~BITS_TXDMA_HIQ_MAP_8822B))
#define BIT_GET_TXDMA_HIQ_MAP_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP_8822B) & BIT_MASK_TXDMA_HIQ_MAP_8822B)
#define BIT_SET_TXDMA_HIQ_MAP_8822B(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP_8822B(x) | BIT_TXDMA_HIQ_MAP_8822B(v))
#define BIT_SHIFT_TXDMA_MGQ_MAP_8822B 12
#define BIT_MASK_TXDMA_MGQ_MAP_8822B 0x3
#define BIT_TXDMA_MGQ_MAP_8822B(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP_8822B) << BIT_SHIFT_TXDMA_MGQ_MAP_8822B)
#define BITS_TXDMA_MGQ_MAP_8822B \
(BIT_MASK_TXDMA_MGQ_MAP_8822B << BIT_SHIFT_TXDMA_MGQ_MAP_8822B)
#define BIT_CLEAR_TXDMA_MGQ_MAP_8822B(x) ((x) & (~BITS_TXDMA_MGQ_MAP_8822B))
#define BIT_GET_TXDMA_MGQ_MAP_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP_8822B) & BIT_MASK_TXDMA_MGQ_MAP_8822B)
#define BIT_SET_TXDMA_MGQ_MAP_8822B(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP_8822B(x) | BIT_TXDMA_MGQ_MAP_8822B(v))
#define BIT_SHIFT_TXDMA_BKQ_MAP_8822B 10
#define BIT_MASK_TXDMA_BKQ_MAP_8822B 0x3
#define BIT_TXDMA_BKQ_MAP_8822B(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP_8822B) << BIT_SHIFT_TXDMA_BKQ_MAP_8822B)
#define BITS_TXDMA_BKQ_MAP_8822B \
(BIT_MASK_TXDMA_BKQ_MAP_8822B << BIT_SHIFT_TXDMA_BKQ_MAP_8822B)
#define BIT_CLEAR_TXDMA_BKQ_MAP_8822B(x) ((x) & (~BITS_TXDMA_BKQ_MAP_8822B))
#define BIT_GET_TXDMA_BKQ_MAP_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP_8822B) & BIT_MASK_TXDMA_BKQ_MAP_8822B)
#define BIT_SET_TXDMA_BKQ_MAP_8822B(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP_8822B(x) | BIT_TXDMA_BKQ_MAP_8822B(v))
#define BIT_SHIFT_TXDMA_BEQ_MAP_8822B 8
#define BIT_MASK_TXDMA_BEQ_MAP_8822B 0x3
#define BIT_TXDMA_BEQ_MAP_8822B(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP_8822B) << BIT_SHIFT_TXDMA_BEQ_MAP_8822B)
#define BITS_TXDMA_BEQ_MAP_8822B \
(BIT_MASK_TXDMA_BEQ_MAP_8822B << BIT_SHIFT_TXDMA_BEQ_MAP_8822B)
#define BIT_CLEAR_TXDMA_BEQ_MAP_8822B(x) ((x) & (~BITS_TXDMA_BEQ_MAP_8822B))
#define BIT_GET_TXDMA_BEQ_MAP_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP_8822B) & BIT_MASK_TXDMA_BEQ_MAP_8822B)
#define BIT_SET_TXDMA_BEQ_MAP_8822B(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP_8822B(x) | BIT_TXDMA_BEQ_MAP_8822B(v))
#define BIT_SHIFT_TXDMA_VIQ_MAP_8822B 6
#define BIT_MASK_TXDMA_VIQ_MAP_8822B 0x3
#define BIT_TXDMA_VIQ_MAP_8822B(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP_8822B) << BIT_SHIFT_TXDMA_VIQ_MAP_8822B)
#define BITS_TXDMA_VIQ_MAP_8822B \
(BIT_MASK_TXDMA_VIQ_MAP_8822B << BIT_SHIFT_TXDMA_VIQ_MAP_8822B)
#define BIT_CLEAR_TXDMA_VIQ_MAP_8822B(x) ((x) & (~BITS_TXDMA_VIQ_MAP_8822B))
#define BIT_GET_TXDMA_VIQ_MAP_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP_8822B) & BIT_MASK_TXDMA_VIQ_MAP_8822B)
#define BIT_SET_TXDMA_VIQ_MAP_8822B(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP_8822B(x) | BIT_TXDMA_VIQ_MAP_8822B(v))
#define BIT_SHIFT_TXDMA_VOQ_MAP_8822B 4
#define BIT_MASK_TXDMA_VOQ_MAP_8822B 0x3
#define BIT_TXDMA_VOQ_MAP_8822B(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP_8822B) << BIT_SHIFT_TXDMA_VOQ_MAP_8822B)
#define BITS_TXDMA_VOQ_MAP_8822B \
(BIT_MASK_TXDMA_VOQ_MAP_8822B << BIT_SHIFT_TXDMA_VOQ_MAP_8822B)
#define BIT_CLEAR_TXDMA_VOQ_MAP_8822B(x) ((x) & (~BITS_TXDMA_VOQ_MAP_8822B))
#define BIT_GET_TXDMA_VOQ_MAP_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP_8822B) & BIT_MASK_TXDMA_VOQ_MAP_8822B)
#define BIT_SET_TXDMA_VOQ_MAP_8822B(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP_8822B(x) | BIT_TXDMA_VOQ_MAP_8822B(v))
#define BIT_RXDMA_AGG_EN_8822B BIT(2)
#define BIT_RXSHFT_EN_8822B BIT(1)
#define BIT_RXDMA_ARBBW_EN_8822B BIT(0)
/* 2 REG_TRXFF_BNDY_8822B */
#define BIT_SHIFT_RXFFOVFL_RSV_V2_8822B 8
#define BIT_MASK_RXFFOVFL_RSV_V2_8822B 0xf
#define BIT_RXFFOVFL_RSV_V2_8822B(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V2_8822B) \
<< BIT_SHIFT_RXFFOVFL_RSV_V2_8822B)
#define BITS_RXFFOVFL_RSV_V2_8822B \
(BIT_MASK_RXFFOVFL_RSV_V2_8822B << BIT_SHIFT_RXFFOVFL_RSV_V2_8822B)
#define BIT_CLEAR_RXFFOVFL_RSV_V2_8822B(x) ((x) & (~BITS_RXFFOVFL_RSV_V2_8822B))
#define BIT_GET_RXFFOVFL_RSV_V2_8822B(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V2_8822B) & \
BIT_MASK_RXFFOVFL_RSV_V2_8822B)
#define BIT_SET_RXFFOVFL_RSV_V2_8822B(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V2_8822B(x) | BIT_RXFFOVFL_RSV_V2_8822B(v))
#define BIT_SHIFT_TXPKTBUF_PGBNDY_8822B 0
#define BIT_MASK_TXPKTBUF_PGBNDY_8822B 0xff
#define BIT_TXPKTBUF_PGBNDY_8822B(x) \
(((x) & BIT_MASK_TXPKTBUF_PGBNDY_8822B) \
<< BIT_SHIFT_TXPKTBUF_PGBNDY_8822B)
#define BITS_TXPKTBUF_PGBNDY_8822B \
(BIT_MASK_TXPKTBUF_PGBNDY_8822B << BIT_SHIFT_TXPKTBUF_PGBNDY_8822B)
#define BIT_CLEAR_TXPKTBUF_PGBNDY_8822B(x) ((x) & (~BITS_TXPKTBUF_PGBNDY_8822B))
#define BIT_GET_TXPKTBUF_PGBNDY_8822B(x) \
(((x) >> BIT_SHIFT_TXPKTBUF_PGBNDY_8822B) & \
BIT_MASK_TXPKTBUF_PGBNDY_8822B)
#define BIT_SET_TXPKTBUF_PGBNDY_8822B(x, v) \
(BIT_CLEAR_TXPKTBUF_PGBNDY_8822B(x) | BIT_TXPKTBUF_PGBNDY_8822B(v))
/* 2 REG_PTA_I2C_MBOX_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_I2C_M_STATUS_8822B 8
#define BIT_MASK_I2C_M_STATUS_8822B 0xf
#define BIT_I2C_M_STATUS_8822B(x) \
(((x) & BIT_MASK_I2C_M_STATUS_8822B) << BIT_SHIFT_I2C_M_STATUS_8822B)
#define BITS_I2C_M_STATUS_8822B \
(BIT_MASK_I2C_M_STATUS_8822B << BIT_SHIFT_I2C_M_STATUS_8822B)
#define BIT_CLEAR_I2C_M_STATUS_8822B(x) ((x) & (~BITS_I2C_M_STATUS_8822B))
#define BIT_GET_I2C_M_STATUS_8822B(x) \
(((x) >> BIT_SHIFT_I2C_M_STATUS_8822B) & BIT_MASK_I2C_M_STATUS_8822B)
#define BIT_SET_I2C_M_STATUS_8822B(x, v) \
(BIT_CLEAR_I2C_M_STATUS_8822B(x) | BIT_I2C_M_STATUS_8822B(v))
#define BIT_SHIFT_I2C_M_BUS_GNT_FW_8822B 4
#define BIT_MASK_I2C_M_BUS_GNT_FW_8822B 0x7
#define BIT_I2C_M_BUS_GNT_FW_8822B(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT_FW_8822B) \
<< BIT_SHIFT_I2C_M_BUS_GNT_FW_8822B)
#define BITS_I2C_M_BUS_GNT_FW_8822B \
(BIT_MASK_I2C_M_BUS_GNT_FW_8822B << BIT_SHIFT_I2C_M_BUS_GNT_FW_8822B)
#define BIT_CLEAR_I2C_M_BUS_GNT_FW_8822B(x) \
((x) & (~BITS_I2C_M_BUS_GNT_FW_8822B))
#define BIT_GET_I2C_M_BUS_GNT_FW_8822B(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT_FW_8822B) & \
BIT_MASK_I2C_M_BUS_GNT_FW_8822B)
#define BIT_SET_I2C_M_BUS_GNT_FW_8822B(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT_FW_8822B(x) | BIT_I2C_M_BUS_GNT_FW_8822B(v))
#define BIT_I2C_M_GNT_FW_8822B BIT(3)
#define BIT_SHIFT_I2C_M_SPEED_8822B 1
#define BIT_MASK_I2C_M_SPEED_8822B 0x3
#define BIT_I2C_M_SPEED_8822B(x) \
(((x) & BIT_MASK_I2C_M_SPEED_8822B) << BIT_SHIFT_I2C_M_SPEED_8822B)
#define BITS_I2C_M_SPEED_8822B \
(BIT_MASK_I2C_M_SPEED_8822B << BIT_SHIFT_I2C_M_SPEED_8822B)
#define BIT_CLEAR_I2C_M_SPEED_8822B(x) ((x) & (~BITS_I2C_M_SPEED_8822B))
#define BIT_GET_I2C_M_SPEED_8822B(x) \
(((x) >> BIT_SHIFT_I2C_M_SPEED_8822B) & BIT_MASK_I2C_M_SPEED_8822B)
#define BIT_SET_I2C_M_SPEED_8822B(x, v) \
(BIT_CLEAR_I2C_M_SPEED_8822B(x) | BIT_I2C_M_SPEED_8822B(v))
#define BIT_I2C_M_UNLOCK_8822B BIT(0)
/* 2 REG_RXFF_BNDY_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_RXFF0_BNDY_V2_8822B 0
#define BIT_MASK_RXFF0_BNDY_V2_8822B 0x3ffff
#define BIT_RXFF0_BNDY_V2_8822B(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V2_8822B) << BIT_SHIFT_RXFF0_BNDY_V2_8822B)
#define BITS_RXFF0_BNDY_V2_8822B \
(BIT_MASK_RXFF0_BNDY_V2_8822B << BIT_SHIFT_RXFF0_BNDY_V2_8822B)
#define BIT_CLEAR_RXFF0_BNDY_V2_8822B(x) ((x) & (~BITS_RXFF0_BNDY_V2_8822B))
#define BIT_GET_RXFF0_BNDY_V2_8822B(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V2_8822B) & BIT_MASK_RXFF0_BNDY_V2_8822B)
#define BIT_SET_RXFF0_BNDY_V2_8822B(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V2_8822B(x) | BIT_RXFF0_BNDY_V2_8822B(v))
/* 2 REG_FE1IMR_8822B */
#define BIT_FS_RXDMA2_DONE_INT_EN_8822B BIT(28)
#define BIT_FS_RXDONE3_INT_EN_8822B BIT(27)
#define BIT_FS_RXDONE2_INT_EN_8822B BIT(26)
#define BIT_FS_RX_BCN_P4_INT_EN_8822B BIT(25)
#define BIT_FS_RX_BCN_P3_INT_EN_8822B BIT(24)
#define BIT_FS_RX_BCN_P2_INT_EN_8822B BIT(23)
#define BIT_FS_RX_BCN_P1_INT_EN_8822B BIT(22)
#define BIT_FS_RX_BCN_P0_INT_EN_8822B BIT(21)
#define BIT_FS_RX_UMD0_INT_EN_8822B BIT(20)
#define BIT_FS_RX_UMD1_INT_EN_8822B BIT(19)
#define BIT_FS_RX_BMD0_INT_EN_8822B BIT(18)
#define BIT_FS_RX_BMD1_INT_EN_8822B BIT(17)
#define BIT_FS_RXDONE_INT_EN_8822B BIT(16)
#define BIT_FS_WWLAN_INT_EN_8822B BIT(15)
#define BIT_FS_SOUND_DONE_INT_EN_8822B BIT(14)
#define BIT_FS_LP_STBY_INT_EN_8822B BIT(13)
#define BIT_FS_TRL_MTR_INT_EN_8822B BIT(12)
#define BIT_FS_BF1_PRETO_INT_EN_8822B BIT(11)
#define BIT_FS_BF0_PRETO_INT_EN_8822B BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_EN_8822B BIT(9)
#define BIT_FS_LTE_COEX_EN_8822B BIT(6)
#define BIT_FS_WLACTOFF_INT_EN_8822B BIT(5)
#define BIT_FS_WLACTON_INT_EN_8822B BIT(4)
#define BIT_FS_BTCMD_INT_EN_8822B BIT(3)
#define BIT_FS_REG_MAILBOX_TO_I2C_INT_EN_8822B BIT(2)
#define BIT_FS_TRPC_TO_INT_EN_V1_8822B BIT(1)
#define BIT_FS_RPC_O_T_INT_EN_V1_8822B BIT(0)
/* 2 REG_FE1ISR_8822B */
#define BIT_FS_RXDMA2_DONE_INT_8822B BIT(28)
#define BIT_FS_RXDONE3_INT_8822B BIT(27)
#define BIT_FS_RXDONE2_INT_8822B BIT(26)
#define BIT_FS_RX_BCN_P4_INT_8822B BIT(25)
#define BIT_FS_RX_BCN_P3_INT_8822B BIT(24)
#define BIT_FS_RX_BCN_P2_INT_8822B BIT(23)
#define BIT_FS_RX_BCN_P1_INT_8822B BIT(22)
#define BIT_FS_RX_BCN_P0_INT_8822B BIT(21)
#define BIT_FS_RX_UMD0_INT_8822B BIT(20)
#define BIT_FS_RX_UMD1_INT_8822B BIT(19)
#define BIT_FS_RX_BMD0_INT_8822B BIT(18)
#define BIT_FS_RX_BMD1_INT_8822B BIT(17)
#define BIT_FS_RXDONE_INT_8822B BIT(16)
#define BIT_FS_WWLAN_INT_8822B BIT(15)
#define BIT_FS_SOUND_DONE_INT_8822B BIT(14)
#define BIT_FS_LP_STBY_INT_8822B BIT(13)
#define BIT_FS_TRL_MTR_INT_8822B BIT(12)
#define BIT_FS_BF1_PRETO_INT_8822B BIT(11)
#define BIT_FS_BF0_PRETO_INT_8822B BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_8822B BIT(9)
#define BIT_FS_LTE_COEX_INT_8822B BIT(6)
#define BIT_FS_WLACTOFF_INT_8822B BIT(5)
#define BIT_FS_WLACTON_INT_8822B BIT(4)
#define BIT_FS_BCN_RX_INT_INT_8822B BIT(3)
#define BIT_FS_MAILBOX_TO_I2C_INT_8822B BIT(2)
#define BIT_FS_TRPC_TO_INT_8822B BIT(1)
#define BIT_FS_RPC_O_T_INT_8822B BIT(0)
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_CPWM_8822B */
#define BIT_CPWM_TOGGLING_8822B BIT(31)
#define BIT_SHIFT_CPWM_MOD_8822B 24
#define BIT_MASK_CPWM_MOD_8822B 0x7f
#define BIT_CPWM_MOD_8822B(x) \
(((x) & BIT_MASK_CPWM_MOD_8822B) << BIT_SHIFT_CPWM_MOD_8822B)
#define BITS_CPWM_MOD_8822B \
(BIT_MASK_CPWM_MOD_8822B << BIT_SHIFT_CPWM_MOD_8822B)
#define BIT_CLEAR_CPWM_MOD_8822B(x) ((x) & (~BITS_CPWM_MOD_8822B))
#define BIT_GET_CPWM_MOD_8822B(x) \
(((x) >> BIT_SHIFT_CPWM_MOD_8822B) & BIT_MASK_CPWM_MOD_8822B)
#define BIT_SET_CPWM_MOD_8822B(x, v) \
(BIT_CLEAR_CPWM_MOD_8822B(x) | BIT_CPWM_MOD_8822B(v))
/* 2 REG_FWIMR_8822B */
#define BIT_FS_TXBCNOK_MB7_INT_EN_8822B BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_EN_8822B BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_EN_8822B BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_EN_8822B BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_EN_8822B BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_EN_8822B BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_EN_8822B BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_EN_8822B BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_EN_8822B BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_EN_8822B BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_EN_8822B BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_EN_8822B BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_EN_8822B BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_EN_8822B BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_EN_8822B BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_EN_8822B BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_EN_8822B BIT(15)
#define BIT_SIFS_OVERSPEC_INT_EN_8822B BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_EN_8822B BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_EN_8822B BIT(12)
#define BIT_FS_CPUMGQ_ERR_INT_EN_8822B BIT(11)
#define BIT_FS_DDMA0_LP_INT_EN_8822B BIT(9)
#define BIT_FS_DDMA0_HP_INT_EN_8822B BIT(8)
#define BIT_FS_TRXRPT_INT_EN_8822B BIT(7)
#define BIT_FS_C2H_W_READY_INT_EN_8822B BIT(6)
#define BIT_FS_HRCV_INT_EN_8822B BIT(5)
#define BIT_FS_H2CCMD_INT_EN_8822B BIT(4)
#define BIT_FS_TXPKTIN_INT_EN_8822B BIT(3)
#define BIT_FS_ERRORHDL_INT_EN_8822B BIT(2)
#define BIT_FS_TXCCX_INT_EN_8822B BIT(1)
#define BIT_FS_TXCLOSE_INT_EN_8822B BIT(0)
/* 2 REG_FWISR_8822B */
#define BIT_FS_TXBCNOK_MB7_INT_8822B BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_8822B BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_8822B BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_8822B BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_8822B BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_8822B BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_8822B BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_8822B BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_8822B BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_8822B BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_8822B BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_8822B BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_8822B BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_8822B BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_8822B BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_8822B BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_8822B BIT(15)
#define BIT_SIFS_OVERSPEC_INT_8822B BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_8822B BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_8822B BIT(12)
#define BIT_FS_CPUMGQ_ERR_INT_8822B BIT(11)
#define BIT_FS_DDMA0_LP_INT_8822B BIT(9)
#define BIT_FS_DDMA0_HP_INT_8822B BIT(8)
#define BIT_FS_TRXRPT_INT_8822B BIT(7)
#define BIT_FS_C2H_W_READY_INT_8822B BIT(6)
#define BIT_FS_HRCV_INT_8822B BIT(5)
#define BIT_FS_H2CCMD_INT_8822B BIT(4)
#define BIT_FS_TXPKTIN_INT_8822B BIT(3)
#define BIT_FS_ERRORHDL_INT_8822B BIT(2)
#define BIT_FS_TXCCX_INT_8822B BIT(1)
#define BIT_FS_TXCLOSE_INT_8822B BIT(0)
/* 2 REG_FTIMR_8822B */
#define BIT_PS_TIMER_C_EARLY_INT_EN_8822B BIT(23)
#define BIT_PS_TIMER_B_EARLY_INT_EN_8822B BIT(22)
#define BIT_PS_TIMER_A_EARLY_INT_EN_8822B BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_EN_8822B BIT(20)
#define BIT_PS_TIMER_C_INT_EN_8822B BIT(19)
#define BIT_PS_TIMER_B_INT_EN_8822B BIT(18)
#define BIT_PS_TIMER_A_INT_EN_8822B BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_EN_8822B BIT(16)
#define BIT_FS_PS_TIMEOUT2_EN_8822B BIT(15)
#define BIT_FS_PS_TIMEOUT1_EN_8822B BIT(14)
#define BIT_FS_PS_TIMEOUT0_EN_8822B BIT(13)
#define BIT_FS_GTINT8_EN_8822B BIT(8)
#define BIT_FS_GTINT7_EN_8822B BIT(7)
#define BIT_FS_GTINT6_EN_8822B BIT(6)
#define BIT_FS_GTINT5_EN_8822B BIT(5)
#define BIT_FS_GTINT4_EN_8822B BIT(4)
#define BIT_FS_GTINT3_EN_8822B BIT(3)
#define BIT_FS_GTINT2_EN_8822B BIT(2)
#define BIT_FS_GTINT1_EN_8822B BIT(1)
#define BIT_FS_GTINT0_EN_8822B BIT(0)
/* 2 REG_FTISR_8822B */
#define BIT_PS_TIMER_C_EARLY__INT_8822B BIT(23)
#define BIT_PS_TIMER_B_EARLY__INT_8822B BIT(22)
#define BIT_PS_TIMER_A_EARLY__INT_8822B BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_8822B BIT(20)
#define BIT_PS_TIMER_C_INT_8822B BIT(19)
#define BIT_PS_TIMER_B_INT_8822B BIT(18)
#define BIT_PS_TIMER_A_INT_8822B BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_8822B BIT(16)
#define BIT_FS_PS_TIMEOUT2_INT_8822B BIT(15)
#define BIT_FS_PS_TIMEOUT1_INT_8822B BIT(14)
#define BIT_FS_PS_TIMEOUT0_INT_8822B BIT(13)
#define BIT_FS_GTINT8_INT_8822B BIT(8)
#define BIT_FS_GTINT7_INT_8822B BIT(7)
#define BIT_FS_GTINT6_INT_8822B BIT(6)
#define BIT_FS_GTINT5_INT_8822B BIT(5)
#define BIT_FS_GTINT4_INT_8822B BIT(4)
#define BIT_FS_GTINT3_INT_8822B BIT(3)
#define BIT_FS_GTINT2_INT_8822B BIT(2)
#define BIT_FS_GTINT1_INT_8822B BIT(1)
#define BIT_FS_GTINT0_INT_8822B BIT(0)
/* 2 REG_PKTBUF_DBG_CTRL_8822B */
#define BIT_SHIFT_PKTBUF_WRITE_EN_8822B 24
#define BIT_MASK_PKTBUF_WRITE_EN_8822B 0xff
#define BIT_PKTBUF_WRITE_EN_8822B(x) \
(((x) & BIT_MASK_PKTBUF_WRITE_EN_8822B) \
<< BIT_SHIFT_PKTBUF_WRITE_EN_8822B)
#define BITS_PKTBUF_WRITE_EN_8822B \
(BIT_MASK_PKTBUF_WRITE_EN_8822B << BIT_SHIFT_PKTBUF_WRITE_EN_8822B)
#define BIT_CLEAR_PKTBUF_WRITE_EN_8822B(x) ((x) & (~BITS_PKTBUF_WRITE_EN_8822B))
#define BIT_GET_PKTBUF_WRITE_EN_8822B(x) \
(((x) >> BIT_SHIFT_PKTBUF_WRITE_EN_8822B) & \
BIT_MASK_PKTBUF_WRITE_EN_8822B)
#define BIT_SET_PKTBUF_WRITE_EN_8822B(x, v) \
(BIT_CLEAR_PKTBUF_WRITE_EN_8822B(x) | BIT_PKTBUF_WRITE_EN_8822B(v))
#define BIT_TXRPTBUF_DBG_8822B BIT(23)
/* 2 REG_NOT_VALID_8822B */
#define BIT_TXPKTBUF_DBG_V2_8822B BIT(20)
#define BIT_RXPKTBUF_DBG_8822B BIT(16)
#define BIT_SHIFT_PKTBUF_DBG_ADDR_8822B 0
#define BIT_MASK_PKTBUF_DBG_ADDR_8822B 0x1fff
#define BIT_PKTBUF_DBG_ADDR_8822B(x) \
(((x) & BIT_MASK_PKTBUF_DBG_ADDR_8822B) \
<< BIT_SHIFT_PKTBUF_DBG_ADDR_8822B)
#define BITS_PKTBUF_DBG_ADDR_8822B \
(BIT_MASK_PKTBUF_DBG_ADDR_8822B << BIT_SHIFT_PKTBUF_DBG_ADDR_8822B)
#define BIT_CLEAR_PKTBUF_DBG_ADDR_8822B(x) ((x) & (~BITS_PKTBUF_DBG_ADDR_8822B))
#define BIT_GET_PKTBUF_DBG_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_ADDR_8822B) & \
BIT_MASK_PKTBUF_DBG_ADDR_8822B)
#define BIT_SET_PKTBUF_DBG_ADDR_8822B(x, v) \
(BIT_CLEAR_PKTBUF_DBG_ADDR_8822B(x) | BIT_PKTBUF_DBG_ADDR_8822B(v))
/* 2 REG_PKTBUF_DBG_DATA_L_8822B */
#define BIT_SHIFT_PKTBUF_DBG_DATA_L_8822B 0
#define BIT_MASK_PKTBUF_DBG_DATA_L_8822B 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_L_8822B(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_L_8822B) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_L_8822B)
#define BITS_PKTBUF_DBG_DATA_L_8822B \
(BIT_MASK_PKTBUF_DBG_DATA_L_8822B << BIT_SHIFT_PKTBUF_DBG_DATA_L_8822B)
#define BIT_CLEAR_PKTBUF_DBG_DATA_L_8822B(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_L_8822B))
#define BIT_GET_PKTBUF_DBG_DATA_L_8822B(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_L_8822B) & \
BIT_MASK_PKTBUF_DBG_DATA_L_8822B)
#define BIT_SET_PKTBUF_DBG_DATA_L_8822B(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_L_8822B(x) | BIT_PKTBUF_DBG_DATA_L_8822B(v))
/* 2 REG_PKTBUF_DBG_DATA_H_8822B */
#define BIT_SHIFT_PKTBUF_DBG_DATA_H_8822B 0
#define BIT_MASK_PKTBUF_DBG_DATA_H_8822B 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_H_8822B(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_H_8822B) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_H_8822B)
#define BITS_PKTBUF_DBG_DATA_H_8822B \
(BIT_MASK_PKTBUF_DBG_DATA_H_8822B << BIT_SHIFT_PKTBUF_DBG_DATA_H_8822B)
#define BIT_CLEAR_PKTBUF_DBG_DATA_H_8822B(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_H_8822B))
#define BIT_GET_PKTBUF_DBG_DATA_H_8822B(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_H_8822B) & \
BIT_MASK_PKTBUF_DBG_DATA_H_8822B)
#define BIT_SET_PKTBUF_DBG_DATA_H_8822B(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_H_8822B(x) | BIT_PKTBUF_DBG_DATA_H_8822B(v))
/* 2 REG_CPWM2_8822B */
#define BIT_SHIFT_L0S_TO_RCVY_NUM_8822B 16
#define BIT_MASK_L0S_TO_RCVY_NUM_8822B 0xff
#define BIT_L0S_TO_RCVY_NUM_8822B(x) \
(((x) & BIT_MASK_L0S_TO_RCVY_NUM_8822B) \
<< BIT_SHIFT_L0S_TO_RCVY_NUM_8822B)
#define BITS_L0S_TO_RCVY_NUM_8822B \
(BIT_MASK_L0S_TO_RCVY_NUM_8822B << BIT_SHIFT_L0S_TO_RCVY_NUM_8822B)
#define BIT_CLEAR_L0S_TO_RCVY_NUM_8822B(x) ((x) & (~BITS_L0S_TO_RCVY_NUM_8822B))
#define BIT_GET_L0S_TO_RCVY_NUM_8822B(x) \
(((x) >> BIT_SHIFT_L0S_TO_RCVY_NUM_8822B) & \
BIT_MASK_L0S_TO_RCVY_NUM_8822B)
#define BIT_SET_L0S_TO_RCVY_NUM_8822B(x, v) \
(BIT_CLEAR_L0S_TO_RCVY_NUM_8822B(x) | BIT_L0S_TO_RCVY_NUM_8822B(v))
#define BIT_CPWM2_TOGGLING_8822B BIT(15)
#define BIT_SHIFT_CPWM2_MOD_8822B 0
#define BIT_MASK_CPWM2_MOD_8822B 0x7fff
#define BIT_CPWM2_MOD_8822B(x) \
(((x) & BIT_MASK_CPWM2_MOD_8822B) << BIT_SHIFT_CPWM2_MOD_8822B)
#define BITS_CPWM2_MOD_8822B \
(BIT_MASK_CPWM2_MOD_8822B << BIT_SHIFT_CPWM2_MOD_8822B)
#define BIT_CLEAR_CPWM2_MOD_8822B(x) ((x) & (~BITS_CPWM2_MOD_8822B))
#define BIT_GET_CPWM2_MOD_8822B(x) \
(((x) >> BIT_SHIFT_CPWM2_MOD_8822B) & BIT_MASK_CPWM2_MOD_8822B)
#define BIT_SET_CPWM2_MOD_8822B(x, v) \
(BIT_CLEAR_CPWM2_MOD_8822B(x) | BIT_CPWM2_MOD_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_TC0_CTRL_8822B */
#define BIT_TC0INT_EN_8822B BIT(26)
#define BIT_TC0MODE_8822B BIT(25)
#define BIT_TC0EN_8822B BIT(24)
#define BIT_SHIFT_TC0DATA_8822B 0
#define BIT_MASK_TC0DATA_8822B 0xffffff
#define BIT_TC0DATA_8822B(x) \
(((x) & BIT_MASK_TC0DATA_8822B) << BIT_SHIFT_TC0DATA_8822B)
#define BITS_TC0DATA_8822B (BIT_MASK_TC0DATA_8822B << BIT_SHIFT_TC0DATA_8822B)
#define BIT_CLEAR_TC0DATA_8822B(x) ((x) & (~BITS_TC0DATA_8822B))
#define BIT_GET_TC0DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC0DATA_8822B) & BIT_MASK_TC0DATA_8822B)
#define BIT_SET_TC0DATA_8822B(x, v) \
(BIT_CLEAR_TC0DATA_8822B(x) | BIT_TC0DATA_8822B(v))
/* 2 REG_TC1_CTRL_8822B */
#define BIT_TC1INT_EN_8822B BIT(26)
#define BIT_TC1MODE_8822B BIT(25)
#define BIT_TC1EN_8822B BIT(24)
#define BIT_SHIFT_TC1DATA_8822B 0
#define BIT_MASK_TC1DATA_8822B 0xffffff
#define BIT_TC1DATA_8822B(x) \
(((x) & BIT_MASK_TC1DATA_8822B) << BIT_SHIFT_TC1DATA_8822B)
#define BITS_TC1DATA_8822B (BIT_MASK_TC1DATA_8822B << BIT_SHIFT_TC1DATA_8822B)
#define BIT_CLEAR_TC1DATA_8822B(x) ((x) & (~BITS_TC1DATA_8822B))
#define BIT_GET_TC1DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC1DATA_8822B) & BIT_MASK_TC1DATA_8822B)
#define BIT_SET_TC1DATA_8822B(x, v) \
(BIT_CLEAR_TC1DATA_8822B(x) | BIT_TC1DATA_8822B(v))
/* 2 REG_TC2_CTRL_8822B */
#define BIT_TC2INT_EN_8822B BIT(26)
#define BIT_TC2MODE_8822B BIT(25)
#define BIT_TC2EN_8822B BIT(24)
#define BIT_SHIFT_TC2DATA_8822B 0
#define BIT_MASK_TC2DATA_8822B 0xffffff
#define BIT_TC2DATA_8822B(x) \
(((x) & BIT_MASK_TC2DATA_8822B) << BIT_SHIFT_TC2DATA_8822B)
#define BITS_TC2DATA_8822B (BIT_MASK_TC2DATA_8822B << BIT_SHIFT_TC2DATA_8822B)
#define BIT_CLEAR_TC2DATA_8822B(x) ((x) & (~BITS_TC2DATA_8822B))
#define BIT_GET_TC2DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC2DATA_8822B) & BIT_MASK_TC2DATA_8822B)
#define BIT_SET_TC2DATA_8822B(x, v) \
(BIT_CLEAR_TC2DATA_8822B(x) | BIT_TC2DATA_8822B(v))
/* 2 REG_TC3_CTRL_8822B */
#define BIT_TC3INT_EN_8822B BIT(26)
#define BIT_TC3MODE_8822B BIT(25)
#define BIT_TC3EN_8822B BIT(24)
#define BIT_SHIFT_TC3DATA_8822B 0
#define BIT_MASK_TC3DATA_8822B 0xffffff
#define BIT_TC3DATA_8822B(x) \
(((x) & BIT_MASK_TC3DATA_8822B) << BIT_SHIFT_TC3DATA_8822B)
#define BITS_TC3DATA_8822B (BIT_MASK_TC3DATA_8822B << BIT_SHIFT_TC3DATA_8822B)
#define BIT_CLEAR_TC3DATA_8822B(x) ((x) & (~BITS_TC3DATA_8822B))
#define BIT_GET_TC3DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC3DATA_8822B) & BIT_MASK_TC3DATA_8822B)
#define BIT_SET_TC3DATA_8822B(x, v) \
(BIT_CLEAR_TC3DATA_8822B(x) | BIT_TC3DATA_8822B(v))
/* 2 REG_TC4_CTRL_8822B */
#define BIT_TC4INT_EN_8822B BIT(26)
#define BIT_TC4MODE_8822B BIT(25)
#define BIT_TC4EN_8822B BIT(24)
#define BIT_SHIFT_TC4DATA_8822B 0
#define BIT_MASK_TC4DATA_8822B 0xffffff
#define BIT_TC4DATA_8822B(x) \
(((x) & BIT_MASK_TC4DATA_8822B) << BIT_SHIFT_TC4DATA_8822B)
#define BITS_TC4DATA_8822B (BIT_MASK_TC4DATA_8822B << BIT_SHIFT_TC4DATA_8822B)
#define BIT_CLEAR_TC4DATA_8822B(x) ((x) & (~BITS_TC4DATA_8822B))
#define BIT_GET_TC4DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC4DATA_8822B) & BIT_MASK_TC4DATA_8822B)
#define BIT_SET_TC4DATA_8822B(x, v) \
(BIT_CLEAR_TC4DATA_8822B(x) | BIT_TC4DATA_8822B(v))
/* 2 REG_TCUNIT_BASE_8822B */
#define BIT_SHIFT_TCUNIT_BASE_8822B 0
#define BIT_MASK_TCUNIT_BASE_8822B 0x3fff
#define BIT_TCUNIT_BASE_8822B(x) \
(((x) & BIT_MASK_TCUNIT_BASE_8822B) << BIT_SHIFT_TCUNIT_BASE_8822B)
#define BITS_TCUNIT_BASE_8822B \
(BIT_MASK_TCUNIT_BASE_8822B << BIT_SHIFT_TCUNIT_BASE_8822B)
#define BIT_CLEAR_TCUNIT_BASE_8822B(x) ((x) & (~BITS_TCUNIT_BASE_8822B))
#define BIT_GET_TCUNIT_BASE_8822B(x) \
(((x) >> BIT_SHIFT_TCUNIT_BASE_8822B) & BIT_MASK_TCUNIT_BASE_8822B)
#define BIT_SET_TCUNIT_BASE_8822B(x, v) \
(BIT_CLEAR_TCUNIT_BASE_8822B(x) | BIT_TCUNIT_BASE_8822B(v))
/* 2 REG_TC5_CTRL_8822B */
#define BIT_TC5INT_EN_8822B BIT(26)
#define BIT_TC5MODE_8822B BIT(25)
#define BIT_TC5EN_8822B BIT(24)
#define BIT_SHIFT_TC5DATA_8822B 0
#define BIT_MASK_TC5DATA_8822B 0xffffff
#define BIT_TC5DATA_8822B(x) \
(((x) & BIT_MASK_TC5DATA_8822B) << BIT_SHIFT_TC5DATA_8822B)
#define BITS_TC5DATA_8822B (BIT_MASK_TC5DATA_8822B << BIT_SHIFT_TC5DATA_8822B)
#define BIT_CLEAR_TC5DATA_8822B(x) ((x) & (~BITS_TC5DATA_8822B))
#define BIT_GET_TC5DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC5DATA_8822B) & BIT_MASK_TC5DATA_8822B)
#define BIT_SET_TC5DATA_8822B(x, v) \
(BIT_CLEAR_TC5DATA_8822B(x) | BIT_TC5DATA_8822B(v))
/* 2 REG_TC6_CTRL_8822B */
#define BIT_TC6INT_EN_8822B BIT(26)
#define BIT_TC6MODE_8822B BIT(25)
#define BIT_TC6EN_8822B BIT(24)
#define BIT_SHIFT_TC6DATA_8822B 0
#define BIT_MASK_TC6DATA_8822B 0xffffff
#define BIT_TC6DATA_8822B(x) \
(((x) & BIT_MASK_TC6DATA_8822B) << BIT_SHIFT_TC6DATA_8822B)
#define BITS_TC6DATA_8822B (BIT_MASK_TC6DATA_8822B << BIT_SHIFT_TC6DATA_8822B)
#define BIT_CLEAR_TC6DATA_8822B(x) ((x) & (~BITS_TC6DATA_8822B))
#define BIT_GET_TC6DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC6DATA_8822B) & BIT_MASK_TC6DATA_8822B)
#define BIT_SET_TC6DATA_8822B(x, v) \
(BIT_CLEAR_TC6DATA_8822B(x) | BIT_TC6DATA_8822B(v))
/* 2 REG_MBIST_FAIL_8822B */
#define BIT_SHIFT_8051_MBIST_FAIL_8822B 26
#define BIT_MASK_8051_MBIST_FAIL_8822B 0x7
#define BIT_8051_MBIST_FAIL_8822B(x) \
(((x) & BIT_MASK_8051_MBIST_FAIL_8822B) \
<< BIT_SHIFT_8051_MBIST_FAIL_8822B)
#define BITS_8051_MBIST_FAIL_8822B \
(BIT_MASK_8051_MBIST_FAIL_8822B << BIT_SHIFT_8051_MBIST_FAIL_8822B)
#define BIT_CLEAR_8051_MBIST_FAIL_8822B(x) ((x) & (~BITS_8051_MBIST_FAIL_8822B))
#define BIT_GET_8051_MBIST_FAIL_8822B(x) \
(((x) >> BIT_SHIFT_8051_MBIST_FAIL_8822B) & \
BIT_MASK_8051_MBIST_FAIL_8822B)
#define BIT_SET_8051_MBIST_FAIL_8822B(x, v) \
(BIT_CLEAR_8051_MBIST_FAIL_8822B(x) | BIT_8051_MBIST_FAIL_8822B(v))
#define BIT_SHIFT_USB_MBIST_FAIL_8822B 24
#define BIT_MASK_USB_MBIST_FAIL_8822B 0x3
#define BIT_USB_MBIST_FAIL_8822B(x) \
(((x) & BIT_MASK_USB_MBIST_FAIL_8822B) \
<< BIT_SHIFT_USB_MBIST_FAIL_8822B)
#define BITS_USB_MBIST_FAIL_8822B \
(BIT_MASK_USB_MBIST_FAIL_8822B << BIT_SHIFT_USB_MBIST_FAIL_8822B)
#define BIT_CLEAR_USB_MBIST_FAIL_8822B(x) ((x) & (~BITS_USB_MBIST_FAIL_8822B))
#define BIT_GET_USB_MBIST_FAIL_8822B(x) \
(((x) >> BIT_SHIFT_USB_MBIST_FAIL_8822B) & \
BIT_MASK_USB_MBIST_FAIL_8822B)
#define BIT_SET_USB_MBIST_FAIL_8822B(x, v) \
(BIT_CLEAR_USB_MBIST_FAIL_8822B(x) | BIT_USB_MBIST_FAIL_8822B(v))
#define BIT_SHIFT_PCIE_MBIST_FAIL_8822B 16
#define BIT_MASK_PCIE_MBIST_FAIL_8822B 0x3f
#define BIT_PCIE_MBIST_FAIL_8822B(x) \
(((x) & BIT_MASK_PCIE_MBIST_FAIL_8822B) \
<< BIT_SHIFT_PCIE_MBIST_FAIL_8822B)
#define BITS_PCIE_MBIST_FAIL_8822B \
(BIT_MASK_PCIE_MBIST_FAIL_8822B << BIT_SHIFT_PCIE_MBIST_FAIL_8822B)
#define BIT_CLEAR_PCIE_MBIST_FAIL_8822B(x) ((x) & (~BITS_PCIE_MBIST_FAIL_8822B))
#define BIT_GET_PCIE_MBIST_FAIL_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_FAIL_8822B) & \
BIT_MASK_PCIE_MBIST_FAIL_8822B)
#define BIT_SET_PCIE_MBIST_FAIL_8822B(x, v) \
(BIT_CLEAR_PCIE_MBIST_FAIL_8822B(x) | BIT_PCIE_MBIST_FAIL_8822B(v))
#define BIT_SHIFT_MAC_MBIST_FAIL_8822B 0
#define BIT_MASK_MAC_MBIST_FAIL_8822B 0xfff
#define BIT_MAC_MBIST_FAIL_8822B(x) \
(((x) & BIT_MASK_MAC_MBIST_FAIL_8822B) \
<< BIT_SHIFT_MAC_MBIST_FAIL_8822B)
#define BITS_MAC_MBIST_FAIL_8822B \
(BIT_MASK_MAC_MBIST_FAIL_8822B << BIT_SHIFT_MAC_MBIST_FAIL_8822B)
#define BIT_CLEAR_MAC_MBIST_FAIL_8822B(x) ((x) & (~BITS_MAC_MBIST_FAIL_8822B))
#define BIT_GET_MAC_MBIST_FAIL_8822B(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_FAIL_8822B) & \
BIT_MASK_MAC_MBIST_FAIL_8822B)
#define BIT_SET_MAC_MBIST_FAIL_8822B(x, v) \
(BIT_CLEAR_MAC_MBIST_FAIL_8822B(x) | BIT_MAC_MBIST_FAIL_8822B(v))
/* 2 REG_MBIST_START_PAUSE_8822B */
#define BIT_SHIFT_8051_MBIST_START_PAUSE_8822B 26
#define BIT_MASK_8051_MBIST_START_PAUSE_8822B 0x7
#define BIT_8051_MBIST_START_PAUSE_8822B(x) \
(((x) & BIT_MASK_8051_MBIST_START_PAUSE_8822B) \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_8822B)
#define BITS_8051_MBIST_START_PAUSE_8822B \
(BIT_MASK_8051_MBIST_START_PAUSE_8822B \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_8822B)
#define BIT_CLEAR_8051_MBIST_START_PAUSE_8822B(x) \
((x) & (~BITS_8051_MBIST_START_PAUSE_8822B))
#define BIT_GET_8051_MBIST_START_PAUSE_8822B(x) \
(((x) >> BIT_SHIFT_8051_MBIST_START_PAUSE_8822B) & \
BIT_MASK_8051_MBIST_START_PAUSE_8822B)
#define BIT_SET_8051_MBIST_START_PAUSE_8822B(x, v) \
(BIT_CLEAR_8051_MBIST_START_PAUSE_8822B(x) | \
BIT_8051_MBIST_START_PAUSE_8822B(v))
#define BIT_SHIFT_USB_MBIST_START_PAUSE_8822B 24
#define BIT_MASK_USB_MBIST_START_PAUSE_8822B 0x3
#define BIT_USB_MBIST_START_PAUSE_8822B(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE_8822B) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_8822B)
#define BITS_USB_MBIST_START_PAUSE_8822B \
(BIT_MASK_USB_MBIST_START_PAUSE_8822B \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_8822B)
#define BIT_CLEAR_USB_MBIST_START_PAUSE_8822B(x) \
((x) & (~BITS_USB_MBIST_START_PAUSE_8822B))
#define BIT_GET_USB_MBIST_START_PAUSE_8822B(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE_8822B) & \
BIT_MASK_USB_MBIST_START_PAUSE_8822B)
#define BIT_SET_USB_MBIST_START_PAUSE_8822B(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE_8822B(x) | \
BIT_USB_MBIST_START_PAUSE_8822B(v))
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE_8822B 16
#define BIT_MASK_PCIE_MBIST_START_PAUSE_8822B 0x3f
#define BIT_PCIE_MBIST_START_PAUSE_8822B(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE_8822B) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_8822B)
#define BITS_PCIE_MBIST_START_PAUSE_8822B \
(BIT_MASK_PCIE_MBIST_START_PAUSE_8822B \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_8822B)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE_8822B(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE_8822B))
#define BIT_GET_PCIE_MBIST_START_PAUSE_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE_8822B) & \
BIT_MASK_PCIE_MBIST_START_PAUSE_8822B)
#define BIT_SET_PCIE_MBIST_START_PAUSE_8822B(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE_8822B(x) | \
BIT_PCIE_MBIST_START_PAUSE_8822B(v))
#define BIT_SHIFT_MAC_MBIST_START_PAUSE_8822B 0
#define BIT_MASK_MAC_MBIST_START_PAUSE_8822B 0xfff
#define BIT_MAC_MBIST_START_PAUSE_8822B(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE_8822B) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_8822B)
#define BITS_MAC_MBIST_START_PAUSE_8822B \
(BIT_MASK_MAC_MBIST_START_PAUSE_8822B \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_8822B)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE_8822B(x) \
((x) & (~BITS_MAC_MBIST_START_PAUSE_8822B))
#define BIT_GET_MAC_MBIST_START_PAUSE_8822B(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE_8822B) & \
BIT_MASK_MAC_MBIST_START_PAUSE_8822B)
#define BIT_SET_MAC_MBIST_START_PAUSE_8822B(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE_8822B(x) | \
BIT_MAC_MBIST_START_PAUSE_8822B(v))
/* 2 REG_MBIST_DONE_8822B */
#define BIT_SHIFT_8051_MBIST_DONE_8822B 26
#define BIT_MASK_8051_MBIST_DONE_8822B 0x7
#define BIT_8051_MBIST_DONE_8822B(x) \
(((x) & BIT_MASK_8051_MBIST_DONE_8822B) \
<< BIT_SHIFT_8051_MBIST_DONE_8822B)
#define BITS_8051_MBIST_DONE_8822B \
(BIT_MASK_8051_MBIST_DONE_8822B << BIT_SHIFT_8051_MBIST_DONE_8822B)
#define BIT_CLEAR_8051_MBIST_DONE_8822B(x) ((x) & (~BITS_8051_MBIST_DONE_8822B))
#define BIT_GET_8051_MBIST_DONE_8822B(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DONE_8822B) & \
BIT_MASK_8051_MBIST_DONE_8822B)
#define BIT_SET_8051_MBIST_DONE_8822B(x, v) \
(BIT_CLEAR_8051_MBIST_DONE_8822B(x) | BIT_8051_MBIST_DONE_8822B(v))
#define BIT_SHIFT_USB_MBIST_DONE_8822B 24
#define BIT_MASK_USB_MBIST_DONE_8822B 0x3
#define BIT_USB_MBIST_DONE_8822B(x) \
(((x) & BIT_MASK_USB_MBIST_DONE_8822B) \
<< BIT_SHIFT_USB_MBIST_DONE_8822B)
#define BITS_USB_MBIST_DONE_8822B \
(BIT_MASK_USB_MBIST_DONE_8822B << BIT_SHIFT_USB_MBIST_DONE_8822B)
#define BIT_CLEAR_USB_MBIST_DONE_8822B(x) ((x) & (~BITS_USB_MBIST_DONE_8822B))
#define BIT_GET_USB_MBIST_DONE_8822B(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE_8822B) & \
BIT_MASK_USB_MBIST_DONE_8822B)
#define BIT_SET_USB_MBIST_DONE_8822B(x, v) \
(BIT_CLEAR_USB_MBIST_DONE_8822B(x) | BIT_USB_MBIST_DONE_8822B(v))
#define BIT_SHIFT_PCIE_MBIST_DONE_8822B 16
#define BIT_MASK_PCIE_MBIST_DONE_8822B 0x3f
#define BIT_PCIE_MBIST_DONE_8822B(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE_8822B) \
<< BIT_SHIFT_PCIE_MBIST_DONE_8822B)
#define BITS_PCIE_MBIST_DONE_8822B \
(BIT_MASK_PCIE_MBIST_DONE_8822B << BIT_SHIFT_PCIE_MBIST_DONE_8822B)
#define BIT_CLEAR_PCIE_MBIST_DONE_8822B(x) ((x) & (~BITS_PCIE_MBIST_DONE_8822B))
#define BIT_GET_PCIE_MBIST_DONE_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE_8822B) & \
BIT_MASK_PCIE_MBIST_DONE_8822B)
#define BIT_SET_PCIE_MBIST_DONE_8822B(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE_8822B(x) | BIT_PCIE_MBIST_DONE_8822B(v))
#define BIT_SHIFT_MAC_MBIST_DONE_8822B 0
#define BIT_MASK_MAC_MBIST_DONE_8822B 0xfff
#define BIT_MAC_MBIST_DONE_8822B(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE_8822B) \
<< BIT_SHIFT_MAC_MBIST_DONE_8822B)
#define BITS_MAC_MBIST_DONE_8822B \
(BIT_MASK_MAC_MBIST_DONE_8822B << BIT_SHIFT_MAC_MBIST_DONE_8822B)
#define BIT_CLEAR_MAC_MBIST_DONE_8822B(x) ((x) & (~BITS_MAC_MBIST_DONE_8822B))
#define BIT_GET_MAC_MBIST_DONE_8822B(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE_8822B) & \
BIT_MASK_MAC_MBIST_DONE_8822B)
#define BIT_SET_MAC_MBIST_DONE_8822B(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE_8822B(x) | BIT_MAC_MBIST_DONE_8822B(v))
/* 2 REG_MBIST_FAIL_NRML_8822B */
#define BIT_SHIFT_MBIST_FAIL_NRML_8822B 0
#define BIT_MASK_MBIST_FAIL_NRML_8822B 0xffffffffL
#define BIT_MBIST_FAIL_NRML_8822B(x) \
(((x) & BIT_MASK_MBIST_FAIL_NRML_8822B) \
<< BIT_SHIFT_MBIST_FAIL_NRML_8822B)
#define BITS_MBIST_FAIL_NRML_8822B \
(BIT_MASK_MBIST_FAIL_NRML_8822B << BIT_SHIFT_MBIST_FAIL_NRML_8822B)
#define BIT_CLEAR_MBIST_FAIL_NRML_8822B(x) ((x) & (~BITS_MBIST_FAIL_NRML_8822B))
#define BIT_GET_MBIST_FAIL_NRML_8822B(x) \
(((x) >> BIT_SHIFT_MBIST_FAIL_NRML_8822B) & \
BIT_MASK_MBIST_FAIL_NRML_8822B)
#define BIT_SET_MBIST_FAIL_NRML_8822B(x, v) \
(BIT_CLEAR_MBIST_FAIL_NRML_8822B(x) | BIT_MBIST_FAIL_NRML_8822B(v))
/* 2 REG_AES_DECRPT_DATA_8822B */
#define BIT_SHIFT_IPS_CFG_ADDR_8822B 0
#define BIT_MASK_IPS_CFG_ADDR_8822B 0xff
#define BIT_IPS_CFG_ADDR_8822B(x) \
(((x) & BIT_MASK_IPS_CFG_ADDR_8822B) << BIT_SHIFT_IPS_CFG_ADDR_8822B)
#define BITS_IPS_CFG_ADDR_8822B \
(BIT_MASK_IPS_CFG_ADDR_8822B << BIT_SHIFT_IPS_CFG_ADDR_8822B)
#define BIT_CLEAR_IPS_CFG_ADDR_8822B(x) ((x) & (~BITS_IPS_CFG_ADDR_8822B))
#define BIT_GET_IPS_CFG_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_IPS_CFG_ADDR_8822B) & BIT_MASK_IPS_CFG_ADDR_8822B)
#define BIT_SET_IPS_CFG_ADDR_8822B(x, v) \
(BIT_CLEAR_IPS_CFG_ADDR_8822B(x) | BIT_IPS_CFG_ADDR_8822B(v))
/* 2 REG_AES_DECRPT_CFG_8822B */
#define BIT_SHIFT_IPS_CFG_DATA_8822B 0
#define BIT_MASK_IPS_CFG_DATA_8822B 0xffffffffL
#define BIT_IPS_CFG_DATA_8822B(x) \
(((x) & BIT_MASK_IPS_CFG_DATA_8822B) << BIT_SHIFT_IPS_CFG_DATA_8822B)
#define BITS_IPS_CFG_DATA_8822B \
(BIT_MASK_IPS_CFG_DATA_8822B << BIT_SHIFT_IPS_CFG_DATA_8822B)
#define BIT_CLEAR_IPS_CFG_DATA_8822B(x) ((x) & (~BITS_IPS_CFG_DATA_8822B))
#define BIT_GET_IPS_CFG_DATA_8822B(x) \
(((x) >> BIT_SHIFT_IPS_CFG_DATA_8822B) & BIT_MASK_IPS_CFG_DATA_8822B)
#define BIT_SET_IPS_CFG_DATA_8822B(x, v) \
(BIT_CLEAR_IPS_CFG_DATA_8822B(x) | BIT_IPS_CFG_DATA_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_TMETER_8822B */
#define BIT_TEMP_VALID_8822B BIT(31)
#define BIT_SHIFT_TEMP_VALUE_8822B 24
#define BIT_MASK_TEMP_VALUE_8822B 0x3f
#define BIT_TEMP_VALUE_8822B(x) \
(((x) & BIT_MASK_TEMP_VALUE_8822B) << BIT_SHIFT_TEMP_VALUE_8822B)
#define BITS_TEMP_VALUE_8822B \
(BIT_MASK_TEMP_VALUE_8822B << BIT_SHIFT_TEMP_VALUE_8822B)
#define BIT_CLEAR_TEMP_VALUE_8822B(x) ((x) & (~BITS_TEMP_VALUE_8822B))
#define BIT_GET_TEMP_VALUE_8822B(x) \
(((x) >> BIT_SHIFT_TEMP_VALUE_8822B) & BIT_MASK_TEMP_VALUE_8822B)
#define BIT_SET_TEMP_VALUE_8822B(x, v) \
(BIT_CLEAR_TEMP_VALUE_8822B(x) | BIT_TEMP_VALUE_8822B(v))
#define BIT_SHIFT_REG_TMETER_TIMER_8822B 8
#define BIT_MASK_REG_TMETER_TIMER_8822B 0xfff
#define BIT_REG_TMETER_TIMER_8822B(x) \
(((x) & BIT_MASK_REG_TMETER_TIMER_8822B) \
<< BIT_SHIFT_REG_TMETER_TIMER_8822B)
#define BITS_REG_TMETER_TIMER_8822B \
(BIT_MASK_REG_TMETER_TIMER_8822B << BIT_SHIFT_REG_TMETER_TIMER_8822B)
#define BIT_CLEAR_REG_TMETER_TIMER_8822B(x) \
((x) & (~BITS_REG_TMETER_TIMER_8822B))
#define BIT_GET_REG_TMETER_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_REG_TMETER_TIMER_8822B) & \
BIT_MASK_REG_TMETER_TIMER_8822B)
#define BIT_SET_REG_TMETER_TIMER_8822B(x, v) \
(BIT_CLEAR_REG_TMETER_TIMER_8822B(x) | BIT_REG_TMETER_TIMER_8822B(v))
#define BIT_SHIFT_REG_TEMP_DELTA_8822B 2
#define BIT_MASK_REG_TEMP_DELTA_8822B 0x3f
#define BIT_REG_TEMP_DELTA_8822B(x) \
(((x) & BIT_MASK_REG_TEMP_DELTA_8822B) \
<< BIT_SHIFT_REG_TEMP_DELTA_8822B)
#define BITS_REG_TEMP_DELTA_8822B \
(BIT_MASK_REG_TEMP_DELTA_8822B << BIT_SHIFT_REG_TEMP_DELTA_8822B)
#define BIT_CLEAR_REG_TEMP_DELTA_8822B(x) ((x) & (~BITS_REG_TEMP_DELTA_8822B))
#define BIT_GET_REG_TEMP_DELTA_8822B(x) \
(((x) >> BIT_SHIFT_REG_TEMP_DELTA_8822B) & \
BIT_MASK_REG_TEMP_DELTA_8822B)
#define BIT_SET_REG_TEMP_DELTA_8822B(x, v) \
(BIT_CLEAR_REG_TEMP_DELTA_8822B(x) | BIT_REG_TEMP_DELTA_8822B(v))
#define BIT_REG_TMETER_EN_8822B BIT(0)
/* 2 REG_OSC_32K_CTRL_8822B */
#define BIT_SHIFT_OSC_32K_CLKGEN_0_8822B 16
#define BIT_MASK_OSC_32K_CLKGEN_0_8822B 0xffff
#define BIT_OSC_32K_CLKGEN_0_8822B(x) \
(((x) & BIT_MASK_OSC_32K_CLKGEN_0_8822B) \
<< BIT_SHIFT_OSC_32K_CLKGEN_0_8822B)
#define BITS_OSC_32K_CLKGEN_0_8822B \
(BIT_MASK_OSC_32K_CLKGEN_0_8822B << BIT_SHIFT_OSC_32K_CLKGEN_0_8822B)
#define BIT_CLEAR_OSC_32K_CLKGEN_0_8822B(x) \
((x) & (~BITS_OSC_32K_CLKGEN_0_8822B))
#define BIT_GET_OSC_32K_CLKGEN_0_8822B(x) \
(((x) >> BIT_SHIFT_OSC_32K_CLKGEN_0_8822B) & \
BIT_MASK_OSC_32K_CLKGEN_0_8822B)
#define BIT_SET_OSC_32K_CLKGEN_0_8822B(x, v) \
(BIT_CLEAR_OSC_32K_CLKGEN_0_8822B(x) | BIT_OSC_32K_CLKGEN_0_8822B(v))
#define BIT_SHIFT_OSC_32K_RES_COMP_8822B 4
#define BIT_MASK_OSC_32K_RES_COMP_8822B 0x3
#define BIT_OSC_32K_RES_COMP_8822B(x) \
(((x) & BIT_MASK_OSC_32K_RES_COMP_8822B) \
<< BIT_SHIFT_OSC_32K_RES_COMP_8822B)
#define BITS_OSC_32K_RES_COMP_8822B \
(BIT_MASK_OSC_32K_RES_COMP_8822B << BIT_SHIFT_OSC_32K_RES_COMP_8822B)
#define BIT_CLEAR_OSC_32K_RES_COMP_8822B(x) \
((x) & (~BITS_OSC_32K_RES_COMP_8822B))
#define BIT_GET_OSC_32K_RES_COMP_8822B(x) \
(((x) >> BIT_SHIFT_OSC_32K_RES_COMP_8822B) & \
BIT_MASK_OSC_32K_RES_COMP_8822B)
#define BIT_SET_OSC_32K_RES_COMP_8822B(x, v) \
(BIT_CLEAR_OSC_32K_RES_COMP_8822B(x) | BIT_OSC_32K_RES_COMP_8822B(v))
#define BIT_OSC_32K_OUT_SEL_8822B BIT(3)
#define BIT_ISO_WL_2_OSC_32K_8822B BIT(1)
#define BIT_POW_CKGEN_8822B BIT(0)
/* 2 REG_32K_CAL_REG1_8822B */
#define BIT_CAL_32K_REG_WR_8822B BIT(31)
#define BIT_CAL_32K_DBG_SEL_8822B BIT(22)
#define BIT_SHIFT_CAL_32K_REG_ADDR_8822B 16
#define BIT_MASK_CAL_32K_REG_ADDR_8822B 0x3f
#define BIT_CAL_32K_REG_ADDR_8822B(x) \
(((x) & BIT_MASK_CAL_32K_REG_ADDR_8822B) \
<< BIT_SHIFT_CAL_32K_REG_ADDR_8822B)
#define BITS_CAL_32K_REG_ADDR_8822B \
(BIT_MASK_CAL_32K_REG_ADDR_8822B << BIT_SHIFT_CAL_32K_REG_ADDR_8822B)
#define BIT_CLEAR_CAL_32K_REG_ADDR_8822B(x) \
((x) & (~BITS_CAL_32K_REG_ADDR_8822B))
#define BIT_GET_CAL_32K_REG_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_ADDR_8822B) & \
BIT_MASK_CAL_32K_REG_ADDR_8822B)
#define BIT_SET_CAL_32K_REG_ADDR_8822B(x, v) \
(BIT_CLEAR_CAL_32K_REG_ADDR_8822B(x) | BIT_CAL_32K_REG_ADDR_8822B(v))
#define BIT_SHIFT_CAL_32K_REG_DATA_8822B 0
#define BIT_MASK_CAL_32K_REG_DATA_8822B 0xffff
#define BIT_CAL_32K_REG_DATA_8822B(x) \
(((x) & BIT_MASK_CAL_32K_REG_DATA_8822B) \
<< BIT_SHIFT_CAL_32K_REG_DATA_8822B)
#define BITS_CAL_32K_REG_DATA_8822B \
(BIT_MASK_CAL_32K_REG_DATA_8822B << BIT_SHIFT_CAL_32K_REG_DATA_8822B)
#define BIT_CLEAR_CAL_32K_REG_DATA_8822B(x) \
((x) & (~BITS_CAL_32K_REG_DATA_8822B))
#define BIT_GET_CAL_32K_REG_DATA_8822B(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_DATA_8822B) & \
BIT_MASK_CAL_32K_REG_DATA_8822B)
#define BIT_SET_CAL_32K_REG_DATA_8822B(x, v) \
(BIT_CLEAR_CAL_32K_REG_DATA_8822B(x) | BIT_CAL_32K_REG_DATA_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_C2HEVT_8822B */
#define BIT_SHIFT_C2HEVT_MSG_V1_8822B 0
#define BIT_MASK_C2HEVT_MSG_V1_8822B 0xffffffffL
#define BIT_C2HEVT_MSG_V1_8822B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_V1_8822B) << BIT_SHIFT_C2HEVT_MSG_V1_8822B)
#define BITS_C2HEVT_MSG_V1_8822B \
(BIT_MASK_C2HEVT_MSG_V1_8822B << BIT_SHIFT_C2HEVT_MSG_V1_8822B)
#define BIT_CLEAR_C2HEVT_MSG_V1_8822B(x) ((x) & (~BITS_C2HEVT_MSG_V1_8822B))
#define BIT_GET_C2HEVT_MSG_V1_8822B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_V1_8822B) & BIT_MASK_C2HEVT_MSG_V1_8822B)
#define BIT_SET_C2HEVT_MSG_V1_8822B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_V1_8822B(x) | BIT_C2HEVT_MSG_V1_8822B(v))
/* 2 REG_C2HEVT_1_8822B */
#define BIT_SHIFT_C2HEVT_MSG_1_8822B 0
#define BIT_MASK_C2HEVT_MSG_1_8822B 0xffffffffL
#define BIT_C2HEVT_MSG_1_8822B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_1_8822B) << BIT_SHIFT_C2HEVT_MSG_1_8822B)
#define BITS_C2HEVT_MSG_1_8822B \
(BIT_MASK_C2HEVT_MSG_1_8822B << BIT_SHIFT_C2HEVT_MSG_1_8822B)
#define BIT_CLEAR_C2HEVT_MSG_1_8822B(x) ((x) & (~BITS_C2HEVT_MSG_1_8822B))
#define BIT_GET_C2HEVT_MSG_1_8822B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_1_8822B) & BIT_MASK_C2HEVT_MSG_1_8822B)
#define BIT_SET_C2HEVT_MSG_1_8822B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_1_8822B(x) | BIT_C2HEVT_MSG_1_8822B(v))
/* 2 REG_C2HEVT_2_8822B */
#define BIT_SHIFT_C2HEVT_MSG_2_8822B 0
#define BIT_MASK_C2HEVT_MSG_2_8822B 0xffffffffL
#define BIT_C2HEVT_MSG_2_8822B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_2_8822B) << BIT_SHIFT_C2HEVT_MSG_2_8822B)
#define BITS_C2HEVT_MSG_2_8822B \
(BIT_MASK_C2HEVT_MSG_2_8822B << BIT_SHIFT_C2HEVT_MSG_2_8822B)
#define BIT_CLEAR_C2HEVT_MSG_2_8822B(x) ((x) & (~BITS_C2HEVT_MSG_2_8822B))
#define BIT_GET_C2HEVT_MSG_2_8822B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_2_8822B) & BIT_MASK_C2HEVT_MSG_2_8822B)
#define BIT_SET_C2HEVT_MSG_2_8822B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_2_8822B(x) | BIT_C2HEVT_MSG_2_8822B(v))
/* 2 REG_C2HEVT_3_8822B */
#define BIT_SHIFT_C2HEVT_MSG_3_8822B 0
#define BIT_MASK_C2HEVT_MSG_3_8822B 0xffffffffL
#define BIT_C2HEVT_MSG_3_8822B(x) \
(((x) & BIT_MASK_C2HEVT_MSG_3_8822B) << BIT_SHIFT_C2HEVT_MSG_3_8822B)
#define BITS_C2HEVT_MSG_3_8822B \
(BIT_MASK_C2HEVT_MSG_3_8822B << BIT_SHIFT_C2HEVT_MSG_3_8822B)
#define BIT_CLEAR_C2HEVT_MSG_3_8822B(x) ((x) & (~BITS_C2HEVT_MSG_3_8822B))
#define BIT_GET_C2HEVT_MSG_3_8822B(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_3_8822B) & BIT_MASK_C2HEVT_MSG_3_8822B)
#define BIT_SET_C2HEVT_MSG_3_8822B(x, v) \
(BIT_CLEAR_C2HEVT_MSG_3_8822B(x) | BIT_C2HEVT_MSG_3_8822B(v))
/* 2 REG_SW_DEFINED_PAGE1_8822B */
#define BIT_SHIFT_SW_DEFINED_PAGE1_8822B 0
#define BIT_MASK_SW_DEFINED_PAGE1_8822B 0xffffffffffffffffL
#define BIT_SW_DEFINED_PAGE1_8822B(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1_8822B) \
<< BIT_SHIFT_SW_DEFINED_PAGE1_8822B)
#define BITS_SW_DEFINED_PAGE1_8822B \
(BIT_MASK_SW_DEFINED_PAGE1_8822B << BIT_SHIFT_SW_DEFINED_PAGE1_8822B)
#define BIT_CLEAR_SW_DEFINED_PAGE1_8822B(x) \
((x) & (~BITS_SW_DEFINED_PAGE1_8822B))
#define BIT_GET_SW_DEFINED_PAGE1_8822B(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1_8822B) & \
BIT_MASK_SW_DEFINED_PAGE1_8822B)
#define BIT_SET_SW_DEFINED_PAGE1_8822B(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1_8822B(x) | BIT_SW_DEFINED_PAGE1_8822B(v))
/* 2 REG_MCUTST_I_8822B */
#define BIT_SHIFT_MCUDMSG_I_8822B 0
#define BIT_MASK_MCUDMSG_I_8822B 0xffffffffL
#define BIT_MCUDMSG_I_8822B(x) \
(((x) & BIT_MASK_MCUDMSG_I_8822B) << BIT_SHIFT_MCUDMSG_I_8822B)
#define BITS_MCUDMSG_I_8822B \
(BIT_MASK_MCUDMSG_I_8822B << BIT_SHIFT_MCUDMSG_I_8822B)
#define BIT_CLEAR_MCUDMSG_I_8822B(x) ((x) & (~BITS_MCUDMSG_I_8822B))
#define BIT_GET_MCUDMSG_I_8822B(x) \
(((x) >> BIT_SHIFT_MCUDMSG_I_8822B) & BIT_MASK_MCUDMSG_I_8822B)
#define BIT_SET_MCUDMSG_I_8822B(x, v) \
(BIT_CLEAR_MCUDMSG_I_8822B(x) | BIT_MCUDMSG_I_8822B(v))
/* 2 REG_MCUTST_II_8822B */
#define BIT_SHIFT_MCUDMSG_II_8822B 0
#define BIT_MASK_MCUDMSG_II_8822B 0xffffffffL
#define BIT_MCUDMSG_II_8822B(x) \
(((x) & BIT_MASK_MCUDMSG_II_8822B) << BIT_SHIFT_MCUDMSG_II_8822B)
#define BITS_MCUDMSG_II_8822B \
(BIT_MASK_MCUDMSG_II_8822B << BIT_SHIFT_MCUDMSG_II_8822B)
#define BIT_CLEAR_MCUDMSG_II_8822B(x) ((x) & (~BITS_MCUDMSG_II_8822B))
#define BIT_GET_MCUDMSG_II_8822B(x) \
(((x) >> BIT_SHIFT_MCUDMSG_II_8822B) & BIT_MASK_MCUDMSG_II_8822B)
#define BIT_SET_MCUDMSG_II_8822B(x, v) \
(BIT_CLEAR_MCUDMSG_II_8822B(x) | BIT_MCUDMSG_II_8822B(v))
/* 2 REG_FMETHR_8822B */
#define BIT_FMSG_INT_8822B BIT(31)
#define BIT_SHIFT_FW_MSG_8822B 0
#define BIT_MASK_FW_MSG_8822B 0xffffffffL
#define BIT_FW_MSG_8822B(x) \
(((x) & BIT_MASK_FW_MSG_8822B) << BIT_SHIFT_FW_MSG_8822B)
#define BITS_FW_MSG_8822B (BIT_MASK_FW_MSG_8822B << BIT_SHIFT_FW_MSG_8822B)
#define BIT_CLEAR_FW_MSG_8822B(x) ((x) & (~BITS_FW_MSG_8822B))
#define BIT_GET_FW_MSG_8822B(x) \
(((x) >> BIT_SHIFT_FW_MSG_8822B) & BIT_MASK_FW_MSG_8822B)
#define BIT_SET_FW_MSG_8822B(x, v) \
(BIT_CLEAR_FW_MSG_8822B(x) | BIT_FW_MSG_8822B(v))
/* 2 REG_HMETFR_8822B */
#define BIT_SHIFT_HRCV_MSG_8822B 24
#define BIT_MASK_HRCV_MSG_8822B 0xff
#define BIT_HRCV_MSG_8822B(x) \
(((x) & BIT_MASK_HRCV_MSG_8822B) << BIT_SHIFT_HRCV_MSG_8822B)
#define BITS_HRCV_MSG_8822B \
(BIT_MASK_HRCV_MSG_8822B << BIT_SHIFT_HRCV_MSG_8822B)
#define BIT_CLEAR_HRCV_MSG_8822B(x) ((x) & (~BITS_HRCV_MSG_8822B))
#define BIT_GET_HRCV_MSG_8822B(x) \
(((x) >> BIT_SHIFT_HRCV_MSG_8822B) & BIT_MASK_HRCV_MSG_8822B)
#define BIT_SET_HRCV_MSG_8822B(x, v) \
(BIT_CLEAR_HRCV_MSG_8822B(x) | BIT_HRCV_MSG_8822B(v))
#define BIT_INT_BOX3_8822B BIT(3)
#define BIT_INT_BOX2_8822B BIT(2)
#define BIT_INT_BOX1_8822B BIT(1)
#define BIT_INT_BOX0_8822B BIT(0)
/* 2 REG_HMEBOX0_8822B */
#define BIT_SHIFT_HOST_MSG_0_8822B 0
#define BIT_MASK_HOST_MSG_0_8822B 0xffffffffL
#define BIT_HOST_MSG_0_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_0_8822B) << BIT_SHIFT_HOST_MSG_0_8822B)
#define BITS_HOST_MSG_0_8822B \
(BIT_MASK_HOST_MSG_0_8822B << BIT_SHIFT_HOST_MSG_0_8822B)
#define BIT_CLEAR_HOST_MSG_0_8822B(x) ((x) & (~BITS_HOST_MSG_0_8822B))
#define BIT_GET_HOST_MSG_0_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_0_8822B) & BIT_MASK_HOST_MSG_0_8822B)
#define BIT_SET_HOST_MSG_0_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_0_8822B(x) | BIT_HOST_MSG_0_8822B(v))
/* 2 REG_HMEBOX1_8822B */
#define BIT_SHIFT_HOST_MSG_1_8822B 0
#define BIT_MASK_HOST_MSG_1_8822B 0xffffffffL
#define BIT_HOST_MSG_1_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_1_8822B) << BIT_SHIFT_HOST_MSG_1_8822B)
#define BITS_HOST_MSG_1_8822B \
(BIT_MASK_HOST_MSG_1_8822B << BIT_SHIFT_HOST_MSG_1_8822B)
#define BIT_CLEAR_HOST_MSG_1_8822B(x) ((x) & (~BITS_HOST_MSG_1_8822B))
#define BIT_GET_HOST_MSG_1_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_1_8822B) & BIT_MASK_HOST_MSG_1_8822B)
#define BIT_SET_HOST_MSG_1_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_1_8822B(x) | BIT_HOST_MSG_1_8822B(v))
/* 2 REG_HMEBOX2_8822B */
#define BIT_SHIFT_HOST_MSG_2_8822B 0
#define BIT_MASK_HOST_MSG_2_8822B 0xffffffffL
#define BIT_HOST_MSG_2_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_2_8822B) << BIT_SHIFT_HOST_MSG_2_8822B)
#define BITS_HOST_MSG_2_8822B \
(BIT_MASK_HOST_MSG_2_8822B << BIT_SHIFT_HOST_MSG_2_8822B)
#define BIT_CLEAR_HOST_MSG_2_8822B(x) ((x) & (~BITS_HOST_MSG_2_8822B))
#define BIT_GET_HOST_MSG_2_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_2_8822B) & BIT_MASK_HOST_MSG_2_8822B)
#define BIT_SET_HOST_MSG_2_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_2_8822B(x) | BIT_HOST_MSG_2_8822B(v))
/* 2 REG_HMEBOX3_8822B */
#define BIT_SHIFT_HOST_MSG_3_8822B 0
#define BIT_MASK_HOST_MSG_3_8822B 0xffffffffL
#define BIT_HOST_MSG_3_8822B(x) \
(((x) & BIT_MASK_HOST_MSG_3_8822B) << BIT_SHIFT_HOST_MSG_3_8822B)
#define BITS_HOST_MSG_3_8822B \
(BIT_MASK_HOST_MSG_3_8822B << BIT_SHIFT_HOST_MSG_3_8822B)
#define BIT_CLEAR_HOST_MSG_3_8822B(x) ((x) & (~BITS_HOST_MSG_3_8822B))
#define BIT_GET_HOST_MSG_3_8822B(x) \
(((x) >> BIT_SHIFT_HOST_MSG_3_8822B) & BIT_MASK_HOST_MSG_3_8822B)
#define BIT_SET_HOST_MSG_3_8822B(x, v) \
(BIT_CLEAR_HOST_MSG_3_8822B(x) | BIT_HOST_MSG_3_8822B(v))
/* 2 REG_LLT_INIT_8822B */
#define BIT_SHIFT_LLTE_RWM_8822B 30
#define BIT_MASK_LLTE_RWM_8822B 0x3
#define BIT_LLTE_RWM_8822B(x) \
(((x) & BIT_MASK_LLTE_RWM_8822B) << BIT_SHIFT_LLTE_RWM_8822B)
#define BITS_LLTE_RWM_8822B \
(BIT_MASK_LLTE_RWM_8822B << BIT_SHIFT_LLTE_RWM_8822B)
#define BIT_CLEAR_LLTE_RWM_8822B(x) ((x) & (~BITS_LLTE_RWM_8822B))
#define BIT_GET_LLTE_RWM_8822B(x) \
(((x) >> BIT_SHIFT_LLTE_RWM_8822B) & BIT_MASK_LLTE_RWM_8822B)
#define BIT_SET_LLTE_RWM_8822B(x, v) \
(BIT_CLEAR_LLTE_RWM_8822B(x) | BIT_LLTE_RWM_8822B(v))
#define BIT_SHIFT_LLTINI_PDATA_V1_8822B 16
#define BIT_MASK_LLTINI_PDATA_V1_8822B 0xfff
#define BIT_LLTINI_PDATA_V1_8822B(x) \
(((x) & BIT_MASK_LLTINI_PDATA_V1_8822B) \
<< BIT_SHIFT_LLTINI_PDATA_V1_8822B)
#define BITS_LLTINI_PDATA_V1_8822B \
(BIT_MASK_LLTINI_PDATA_V1_8822B << BIT_SHIFT_LLTINI_PDATA_V1_8822B)
#define BIT_CLEAR_LLTINI_PDATA_V1_8822B(x) ((x) & (~BITS_LLTINI_PDATA_V1_8822B))
#define BIT_GET_LLTINI_PDATA_V1_8822B(x) \
(((x) >> BIT_SHIFT_LLTINI_PDATA_V1_8822B) & \
BIT_MASK_LLTINI_PDATA_V1_8822B)
#define BIT_SET_LLTINI_PDATA_V1_8822B(x, v) \
(BIT_CLEAR_LLTINI_PDATA_V1_8822B(x) | BIT_LLTINI_PDATA_V1_8822B(v))
#define BIT_SHIFT_LLTINI_HDATA_V1_8822B 0
#define BIT_MASK_LLTINI_HDATA_V1_8822B 0xfff
#define BIT_LLTINI_HDATA_V1_8822B(x) \
(((x) & BIT_MASK_LLTINI_HDATA_V1_8822B) \
<< BIT_SHIFT_LLTINI_HDATA_V1_8822B)
#define BITS_LLTINI_HDATA_V1_8822B \
(BIT_MASK_LLTINI_HDATA_V1_8822B << BIT_SHIFT_LLTINI_HDATA_V1_8822B)
#define BIT_CLEAR_LLTINI_HDATA_V1_8822B(x) ((x) & (~BITS_LLTINI_HDATA_V1_8822B))
#define BIT_GET_LLTINI_HDATA_V1_8822B(x) \
(((x) >> BIT_SHIFT_LLTINI_HDATA_V1_8822B) & \
BIT_MASK_LLTINI_HDATA_V1_8822B)
#define BIT_SET_LLTINI_HDATA_V1_8822B(x, v) \
(BIT_CLEAR_LLTINI_HDATA_V1_8822B(x) | BIT_LLTINI_HDATA_V1_8822B(v))
/* 2 REG_LLT_INIT_ADDR_8822B */
#define BIT_SHIFT_LLTINI_ADDR_V1_8822B 0
#define BIT_MASK_LLTINI_ADDR_V1_8822B 0xfff
#define BIT_LLTINI_ADDR_V1_8822B(x) \
(((x) & BIT_MASK_LLTINI_ADDR_V1_8822B) \
<< BIT_SHIFT_LLTINI_ADDR_V1_8822B)
#define BITS_LLTINI_ADDR_V1_8822B \
(BIT_MASK_LLTINI_ADDR_V1_8822B << BIT_SHIFT_LLTINI_ADDR_V1_8822B)
#define BIT_CLEAR_LLTINI_ADDR_V1_8822B(x) ((x) & (~BITS_LLTINI_ADDR_V1_8822B))
#define BIT_GET_LLTINI_ADDR_V1_8822B(x) \
(((x) >> BIT_SHIFT_LLTINI_ADDR_V1_8822B) & \
BIT_MASK_LLTINI_ADDR_V1_8822B)
#define BIT_SET_LLTINI_ADDR_V1_8822B(x, v) \
(BIT_CLEAR_LLTINI_ADDR_V1_8822B(x) | BIT_LLTINI_ADDR_V1_8822B(v))
/* 2 REG_BB_ACCESS_CTRL_8822B */
#define BIT_SHIFT_BB_WRITE_READ_8822B 30
#define BIT_MASK_BB_WRITE_READ_8822B 0x3
#define BIT_BB_WRITE_READ_8822B(x) \
(((x) & BIT_MASK_BB_WRITE_READ_8822B) << BIT_SHIFT_BB_WRITE_READ_8822B)
#define BITS_BB_WRITE_READ_8822B \
(BIT_MASK_BB_WRITE_READ_8822B << BIT_SHIFT_BB_WRITE_READ_8822B)
#define BIT_CLEAR_BB_WRITE_READ_8822B(x) ((x) & (~BITS_BB_WRITE_READ_8822B))
#define BIT_GET_BB_WRITE_READ_8822B(x) \
(((x) >> BIT_SHIFT_BB_WRITE_READ_8822B) & BIT_MASK_BB_WRITE_READ_8822B)
#define BIT_SET_BB_WRITE_READ_8822B(x, v) \
(BIT_CLEAR_BB_WRITE_READ_8822B(x) | BIT_BB_WRITE_READ_8822B(v))
#define BIT_SHIFT_BB_WRITE_EN_8822B 12
#define BIT_MASK_BB_WRITE_EN_8822B 0xf
#define BIT_BB_WRITE_EN_8822B(x) \
(((x) & BIT_MASK_BB_WRITE_EN_8822B) << BIT_SHIFT_BB_WRITE_EN_8822B)
#define BITS_BB_WRITE_EN_8822B \
(BIT_MASK_BB_WRITE_EN_8822B << BIT_SHIFT_BB_WRITE_EN_8822B)
#define BIT_CLEAR_BB_WRITE_EN_8822B(x) ((x) & (~BITS_BB_WRITE_EN_8822B))
#define BIT_GET_BB_WRITE_EN_8822B(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN_8822B) & BIT_MASK_BB_WRITE_EN_8822B)
#define BIT_SET_BB_WRITE_EN_8822B(x, v) \
(BIT_CLEAR_BB_WRITE_EN_8822B(x) | BIT_BB_WRITE_EN_8822B(v))
#define BIT_SHIFT_BB_ADDR_8822B 2
#define BIT_MASK_BB_ADDR_8822B 0x1ff
#define BIT_BB_ADDR_8822B(x) \
(((x) & BIT_MASK_BB_ADDR_8822B) << BIT_SHIFT_BB_ADDR_8822B)
#define BITS_BB_ADDR_8822B (BIT_MASK_BB_ADDR_8822B << BIT_SHIFT_BB_ADDR_8822B)
#define BIT_CLEAR_BB_ADDR_8822B(x) ((x) & (~BITS_BB_ADDR_8822B))
#define BIT_GET_BB_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_BB_ADDR_8822B) & BIT_MASK_BB_ADDR_8822B)
#define BIT_SET_BB_ADDR_8822B(x, v) \
(BIT_CLEAR_BB_ADDR_8822B(x) | BIT_BB_ADDR_8822B(v))
#define BIT_BB_ERRACC_8822B BIT(0)
/* 2 REG_BB_ACCESS_DATA_8822B */
#define BIT_SHIFT_BB_DATA_8822B 0
#define BIT_MASK_BB_DATA_8822B 0xffffffffL
#define BIT_BB_DATA_8822B(x) \
(((x) & BIT_MASK_BB_DATA_8822B) << BIT_SHIFT_BB_DATA_8822B)
#define BITS_BB_DATA_8822B (BIT_MASK_BB_DATA_8822B << BIT_SHIFT_BB_DATA_8822B)
#define BIT_CLEAR_BB_DATA_8822B(x) ((x) & (~BITS_BB_DATA_8822B))
#define BIT_GET_BB_DATA_8822B(x) \
(((x) >> BIT_SHIFT_BB_DATA_8822B) & BIT_MASK_BB_DATA_8822B)
#define BIT_SET_BB_DATA_8822B(x, v) \
(BIT_CLEAR_BB_DATA_8822B(x) | BIT_BB_DATA_8822B(v))
/* 2 REG_HMEBOX_E0_8822B */
#define BIT_SHIFT_HMEBOX_E0_8822B 0
#define BIT_MASK_HMEBOX_E0_8822B 0xffffffffL
#define BIT_HMEBOX_E0_8822B(x) \
(((x) & BIT_MASK_HMEBOX_E0_8822B) << BIT_SHIFT_HMEBOX_E0_8822B)
#define BITS_HMEBOX_E0_8822B \
(BIT_MASK_HMEBOX_E0_8822B << BIT_SHIFT_HMEBOX_E0_8822B)
#define BIT_CLEAR_HMEBOX_E0_8822B(x) ((x) & (~BITS_HMEBOX_E0_8822B))
#define BIT_GET_HMEBOX_E0_8822B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E0_8822B) & BIT_MASK_HMEBOX_E0_8822B)
#define BIT_SET_HMEBOX_E0_8822B(x, v) \
(BIT_CLEAR_HMEBOX_E0_8822B(x) | BIT_HMEBOX_E0_8822B(v))
/* 2 REG_HMEBOX_E1_8822B */
#define BIT_SHIFT_HMEBOX_E1_8822B 0
#define BIT_MASK_HMEBOX_E1_8822B 0xffffffffL
#define BIT_HMEBOX_E1_8822B(x) \
(((x) & BIT_MASK_HMEBOX_E1_8822B) << BIT_SHIFT_HMEBOX_E1_8822B)
#define BITS_HMEBOX_E1_8822B \
(BIT_MASK_HMEBOX_E1_8822B << BIT_SHIFT_HMEBOX_E1_8822B)
#define BIT_CLEAR_HMEBOX_E1_8822B(x) ((x) & (~BITS_HMEBOX_E1_8822B))
#define BIT_GET_HMEBOX_E1_8822B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E1_8822B) & BIT_MASK_HMEBOX_E1_8822B)
#define BIT_SET_HMEBOX_E1_8822B(x, v) \
(BIT_CLEAR_HMEBOX_E1_8822B(x) | BIT_HMEBOX_E1_8822B(v))
/* 2 REG_HMEBOX_E2_8822B */
#define BIT_SHIFT_HMEBOX_E2_8822B 0
#define BIT_MASK_HMEBOX_E2_8822B 0xffffffffL
#define BIT_HMEBOX_E2_8822B(x) \
(((x) & BIT_MASK_HMEBOX_E2_8822B) << BIT_SHIFT_HMEBOX_E2_8822B)
#define BITS_HMEBOX_E2_8822B \
(BIT_MASK_HMEBOX_E2_8822B << BIT_SHIFT_HMEBOX_E2_8822B)
#define BIT_CLEAR_HMEBOX_E2_8822B(x) ((x) & (~BITS_HMEBOX_E2_8822B))
#define BIT_GET_HMEBOX_E2_8822B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E2_8822B) & BIT_MASK_HMEBOX_E2_8822B)
#define BIT_SET_HMEBOX_E2_8822B(x, v) \
(BIT_CLEAR_HMEBOX_E2_8822B(x) | BIT_HMEBOX_E2_8822B(v))
/* 2 REG_HMEBOX_E3_8822B */
#define BIT_SHIFT_HMEBOX_E3_8822B 0
#define BIT_MASK_HMEBOX_E3_8822B 0xffffffffL
#define BIT_HMEBOX_E3_8822B(x) \
(((x) & BIT_MASK_HMEBOX_E3_8822B) << BIT_SHIFT_HMEBOX_E3_8822B)
#define BITS_HMEBOX_E3_8822B \
(BIT_MASK_HMEBOX_E3_8822B << BIT_SHIFT_HMEBOX_E3_8822B)
#define BIT_CLEAR_HMEBOX_E3_8822B(x) ((x) & (~BITS_HMEBOX_E3_8822B))
#define BIT_GET_HMEBOX_E3_8822B(x) \
(((x) >> BIT_SHIFT_HMEBOX_E3_8822B) & BIT_MASK_HMEBOX_E3_8822B)
#define BIT_SET_HMEBOX_E3_8822B(x, v) \
(BIT_CLEAR_HMEBOX_E3_8822B(x) | BIT_HMEBOX_E3_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_CR_EXT_8822B */
#define BIT_SHIFT_PHY_REQ_DELAY_8822B 24
#define BIT_MASK_PHY_REQ_DELAY_8822B 0xf
#define BIT_PHY_REQ_DELAY_8822B(x) \
(((x) & BIT_MASK_PHY_REQ_DELAY_8822B) << BIT_SHIFT_PHY_REQ_DELAY_8822B)
#define BITS_PHY_REQ_DELAY_8822B \
(BIT_MASK_PHY_REQ_DELAY_8822B << BIT_SHIFT_PHY_REQ_DELAY_8822B)
#define BIT_CLEAR_PHY_REQ_DELAY_8822B(x) ((x) & (~BITS_PHY_REQ_DELAY_8822B))
#define BIT_GET_PHY_REQ_DELAY_8822B(x) \
(((x) >> BIT_SHIFT_PHY_REQ_DELAY_8822B) & BIT_MASK_PHY_REQ_DELAY_8822B)
#define BIT_SET_PHY_REQ_DELAY_8822B(x, v) \
(BIT_CLEAR_PHY_REQ_DELAY_8822B(x) | BIT_PHY_REQ_DELAY_8822B(v))
#define BIT_SPD_DOWN_8822B BIT(16)
#define BIT_SHIFT_NETYPE4_8822B 4
#define BIT_MASK_NETYPE4_8822B 0x3
#define BIT_NETYPE4_8822B(x) \
(((x) & BIT_MASK_NETYPE4_8822B) << BIT_SHIFT_NETYPE4_8822B)
#define BITS_NETYPE4_8822B (BIT_MASK_NETYPE4_8822B << BIT_SHIFT_NETYPE4_8822B)
#define BIT_CLEAR_NETYPE4_8822B(x) ((x) & (~BITS_NETYPE4_8822B))
#define BIT_GET_NETYPE4_8822B(x) \
(((x) >> BIT_SHIFT_NETYPE4_8822B) & BIT_MASK_NETYPE4_8822B)
#define BIT_SET_NETYPE4_8822B(x, v) \
(BIT_CLEAR_NETYPE4_8822B(x) | BIT_NETYPE4_8822B(v))
#define BIT_SHIFT_NETYPE3_8822B 2
#define BIT_MASK_NETYPE3_8822B 0x3
#define BIT_NETYPE3_8822B(x) \
(((x) & BIT_MASK_NETYPE3_8822B) << BIT_SHIFT_NETYPE3_8822B)
#define BITS_NETYPE3_8822B (BIT_MASK_NETYPE3_8822B << BIT_SHIFT_NETYPE3_8822B)
#define BIT_CLEAR_NETYPE3_8822B(x) ((x) & (~BITS_NETYPE3_8822B))
#define BIT_GET_NETYPE3_8822B(x) \
(((x) >> BIT_SHIFT_NETYPE3_8822B) & BIT_MASK_NETYPE3_8822B)
#define BIT_SET_NETYPE3_8822B(x, v) \
(BIT_CLEAR_NETYPE3_8822B(x) | BIT_NETYPE3_8822B(v))
#define BIT_SHIFT_NETYPE2_8822B 0
#define BIT_MASK_NETYPE2_8822B 0x3
#define BIT_NETYPE2_8822B(x) \
(((x) & BIT_MASK_NETYPE2_8822B) << BIT_SHIFT_NETYPE2_8822B)
#define BITS_NETYPE2_8822B (BIT_MASK_NETYPE2_8822B << BIT_SHIFT_NETYPE2_8822B)
#define BIT_CLEAR_NETYPE2_8822B(x) ((x) & (~BITS_NETYPE2_8822B))
#define BIT_GET_NETYPE2_8822B(x) \
(((x) >> BIT_SHIFT_NETYPE2_8822B) & BIT_MASK_NETYPE2_8822B)
#define BIT_SET_NETYPE2_8822B(x, v) \
(BIT_CLEAR_NETYPE2_8822B(x) | BIT_NETYPE2_8822B(v))
/* 2 REG_FWFF_8822B */
#define BIT_SHIFT_PKTNUM_TH_V1_8822B 24
#define BIT_MASK_PKTNUM_TH_V1_8822B 0xff
#define BIT_PKTNUM_TH_V1_8822B(x) \
(((x) & BIT_MASK_PKTNUM_TH_V1_8822B) << BIT_SHIFT_PKTNUM_TH_V1_8822B)
#define BITS_PKTNUM_TH_V1_8822B \
(BIT_MASK_PKTNUM_TH_V1_8822B << BIT_SHIFT_PKTNUM_TH_V1_8822B)
#define BIT_CLEAR_PKTNUM_TH_V1_8822B(x) ((x) & (~BITS_PKTNUM_TH_V1_8822B))
#define BIT_GET_PKTNUM_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V1_8822B) & BIT_MASK_PKTNUM_TH_V1_8822B)
#define BIT_SET_PKTNUM_TH_V1_8822B(x, v) \
(BIT_CLEAR_PKTNUM_TH_V1_8822B(x) | BIT_PKTNUM_TH_V1_8822B(v))
#define BIT_SHIFT_TIMER_TH_8822B 16
#define BIT_MASK_TIMER_TH_8822B 0xff
#define BIT_TIMER_TH_8822B(x) \
(((x) & BIT_MASK_TIMER_TH_8822B) << BIT_SHIFT_TIMER_TH_8822B)
#define BITS_TIMER_TH_8822B \
(BIT_MASK_TIMER_TH_8822B << BIT_SHIFT_TIMER_TH_8822B)
#define BIT_CLEAR_TIMER_TH_8822B(x) ((x) & (~BITS_TIMER_TH_8822B))
#define BIT_GET_TIMER_TH_8822B(x) \
(((x) >> BIT_SHIFT_TIMER_TH_8822B) & BIT_MASK_TIMER_TH_8822B)
#define BIT_SET_TIMER_TH_8822B(x, v) \
(BIT_CLEAR_TIMER_TH_8822B(x) | BIT_TIMER_TH_8822B(v))
#define BIT_SHIFT_RXPKT1ENADDR_8822B 0
#define BIT_MASK_RXPKT1ENADDR_8822B 0xffff
#define BIT_RXPKT1ENADDR_8822B(x) \
(((x) & BIT_MASK_RXPKT1ENADDR_8822B) << BIT_SHIFT_RXPKT1ENADDR_8822B)
#define BITS_RXPKT1ENADDR_8822B \
(BIT_MASK_RXPKT1ENADDR_8822B << BIT_SHIFT_RXPKT1ENADDR_8822B)
#define BIT_CLEAR_RXPKT1ENADDR_8822B(x) ((x) & (~BITS_RXPKT1ENADDR_8822B))
#define BIT_GET_RXPKT1ENADDR_8822B(x) \
(((x) >> BIT_SHIFT_RXPKT1ENADDR_8822B) & BIT_MASK_RXPKT1ENADDR_8822B)
#define BIT_SET_RXPKT1ENADDR_8822B(x, v) \
(BIT_CLEAR_RXPKT1ENADDR_8822B(x) | BIT_RXPKT1ENADDR_8822B(v))
/* 2 REG_RXFF_PTR_V1_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_RXFF0_RDPTR_V2_8822B 0
#define BIT_MASK_RXFF0_RDPTR_V2_8822B 0x3ffff
#define BIT_RXFF0_RDPTR_V2_8822B(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V2_8822B) \
<< BIT_SHIFT_RXFF0_RDPTR_V2_8822B)
#define BITS_RXFF0_RDPTR_V2_8822B \
(BIT_MASK_RXFF0_RDPTR_V2_8822B << BIT_SHIFT_RXFF0_RDPTR_V2_8822B)
#define BIT_CLEAR_RXFF0_RDPTR_V2_8822B(x) ((x) & (~BITS_RXFF0_RDPTR_V2_8822B))
#define BIT_GET_RXFF0_RDPTR_V2_8822B(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V2_8822B) & \
BIT_MASK_RXFF0_RDPTR_V2_8822B)
#define BIT_SET_RXFF0_RDPTR_V2_8822B(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V2_8822B(x) | BIT_RXFF0_RDPTR_V2_8822B(v))
/* 2 REG_RXFF_WTR_V1_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_RXFF0_WTPTR_V2_8822B 0
#define BIT_MASK_RXFF0_WTPTR_V2_8822B 0x3ffff
#define BIT_RXFF0_WTPTR_V2_8822B(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V2_8822B) \
<< BIT_SHIFT_RXFF0_WTPTR_V2_8822B)
#define BITS_RXFF0_WTPTR_V2_8822B \
(BIT_MASK_RXFF0_WTPTR_V2_8822B << BIT_SHIFT_RXFF0_WTPTR_V2_8822B)
#define BIT_CLEAR_RXFF0_WTPTR_V2_8822B(x) ((x) & (~BITS_RXFF0_WTPTR_V2_8822B))
#define BIT_GET_RXFF0_WTPTR_V2_8822B(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V2_8822B) & \
BIT_MASK_RXFF0_WTPTR_V2_8822B)
#define BIT_SET_RXFF0_WTPTR_V2_8822B(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V2_8822B(x) | BIT_RXFF0_WTPTR_V2_8822B(v))
/* 2 REG_FE2IMR_8822B */
#define BIT__FE4ISR__IND_MSK_8822B BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_EN_8822B BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_EN_8822B BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_EN_8822B BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_EN_8822B BIT(25)
#define BIT_FS_TXSC_VODONE_INT_EN_8822B BIT(24)
#define BIT_FS_ATIM_MB7_INT_EN_8822B BIT(23)
#define BIT_FS_ATIM_MB6_INT_EN_8822B BIT(22)
#define BIT_FS_ATIM_MB5_INT_EN_8822B BIT(21)
#define BIT_FS_ATIM_MB4_INT_EN_8822B BIT(20)
#define BIT_FS_ATIM_MB3_INT_EN_8822B BIT(19)
#define BIT_FS_ATIM_MB2_INT_EN_8822B BIT(18)
#define BIT_FS_ATIM_MB1_INT_EN_8822B BIT(17)
#define BIT_FS_ATIM_MB0_INT_EN_8822B BIT(16)
#define BIT_FS_TBTT4INT_EN_8822B BIT(11)
#define BIT_FS_TBTT3INT_EN_8822B BIT(10)
#define BIT_FS_TBTT2INT_EN_8822B BIT(9)
#define BIT_FS_TBTT1INT_EN_8822B BIT(8)
#define BIT_FS_TBTT0_MB7INT_EN_8822B BIT(7)
#define BIT_FS_TBTT0_MB6INT_EN_8822B BIT(6)
#define BIT_FS_TBTT0_MB5INT_EN_8822B BIT(5)
#define BIT_FS_TBTT0_MB4INT_EN_8822B BIT(4)
#define BIT_FS_TBTT0_MB3INT_EN_8822B BIT(3)
#define BIT_FS_TBTT0_MB2INT_EN_8822B BIT(2)
#define BIT_FS_TBTT0_MB1INT_EN_8822B BIT(1)
#define BIT_FS_TBTT0_INT_EN_8822B BIT(0)
/* 2 REG_FE2ISR_8822B */
#define BIT__FE4ISR__IND_INT_8822B BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_8822B BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_8822B BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_8822B BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_8822B BIT(25)
#define BIT_FS_TXSC_VODONE_INT_8822B BIT(24)
#define BIT_FS_ATIM_MB7_INT_8822B BIT(23)
#define BIT_FS_ATIM_MB6_INT_8822B BIT(22)
#define BIT_FS_ATIM_MB5_INT_8822B BIT(21)
#define BIT_FS_ATIM_MB4_INT_8822B BIT(20)
#define BIT_FS_ATIM_MB3_INT_8822B BIT(19)
#define BIT_FS_ATIM_MB2_INT_8822B BIT(18)
#define BIT_FS_ATIM_MB1_INT_8822B BIT(17)
#define BIT_FS_ATIM_MB0_INT_8822B BIT(16)
#define BIT_FS_TBTT4INT_8822B BIT(11)
#define BIT_FS_TBTT3INT_8822B BIT(10)
#define BIT_FS_TBTT2INT_8822B BIT(9)
#define BIT_FS_TBTT1INT_8822B BIT(8)
#define BIT_FS_TBTT0_MB7INT_8822B BIT(7)
#define BIT_FS_TBTT0_MB6INT_8822B BIT(6)
#define BIT_FS_TBTT0_MB5INT_8822B BIT(5)
#define BIT_FS_TBTT0_MB4INT_8822B BIT(4)
#define BIT_FS_TBTT0_MB3INT_8822B BIT(3)
#define BIT_FS_TBTT0_MB2INT_8822B BIT(2)
#define BIT_FS_TBTT0_MB1INT_8822B BIT(1)
#define BIT_FS_TBTT0_INT_8822B BIT(0)
/* 2 REG_FE3IMR_8822B */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT__EN_8822B BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT__EN_8822B BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT__EN_8822B BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT__EN_8822B BIT(28)
#define BIT_FS_BCNDMA4_INT_EN_8822B BIT(27)
#define BIT_FS_BCNDMA3_INT_EN_8822B BIT(26)
#define BIT_FS_BCNDMA2_INT_EN_8822B BIT(25)
#define BIT_FS_BCNDMA1_INT_EN_8822B BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_EN_8822B BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_EN_8822B BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_EN_8822B BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_EN_8822B BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_EN_8822B BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_EN_8822B BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_EN_8822B BIT(17)
#define BIT_FS_BCNDMA0_INT_EN_8822B BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT__EN_8822B BIT(15)
#define BIT_FS_BCNERLY4_INT_EN_8822B BIT(11)
#define BIT_FS_BCNERLY3_INT_EN_8822B BIT(10)
#define BIT_FS_BCNERLY2_INT_EN_8822B BIT(9)
#define BIT_FS_BCNERLY1_INT_EN_8822B BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_EN_8822B BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_EN_8822B BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_EN_8822B BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_EN_8822B BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_EN_8822B BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_EN_8822B BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_EN_8822B BIT(1)
#define BIT_FS_BCNERLY0_INT_EN_8822B BIT(0)
/* 2 REG_FE3ISR_8822B */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT_8822B BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT_8822B BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT_8822B BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT_8822B BIT(28)
#define BIT_FS_BCNDMA4_INT_8822B BIT(27)
#define BIT_FS_BCNDMA3_INT_8822B BIT(26)
#define BIT_FS_BCNDMA2_INT_8822B BIT(25)
#define BIT_FS_BCNDMA1_INT_8822B BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_8822B BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_8822B BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_8822B BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_8822B BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_8822B BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_8822B BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_8822B BIT(17)
#define BIT_FS_BCNDMA0_INT_8822B BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT_8822B BIT(15)
#define BIT_FS_BCNERLY4_INT_8822B BIT(11)
#define BIT_FS_BCNERLY3_INT_8822B BIT(10)
#define BIT_FS_BCNERLY2_INT_8822B BIT(9)
#define BIT_FS_BCNERLY1_INT_8822B BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_8822B BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_8822B BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_8822B BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_8822B BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_8822B BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_8822B BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_8822B BIT(1)
#define BIT_FS_BCNERLY0_INT_8822B BIT(0)
/* 2 REG_FE4IMR_8822B */
#define BIT_FS_CLI3_TXPKTIN_INT_EN_8822B BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_EN_8822B BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_EN_8822B BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_EN_8822B BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_EN_8822B BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_EN_8822B BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_EN_8822B BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_EN_8822B BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_EN_8822B BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_EN_8822B BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_EN_8822B BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_EN_8822B BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_EN_8822B BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_EN_8822B BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_EN_8822B BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_EN_8822B BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_EN_8822B BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_EN_8822B BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_EN_8822B BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_EN_8822B BIT(0)
/* 2 REG_FE4ISR_8822B */
#define BIT_FS_CLI3_TXPKTIN_INT_8822B BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_8822B BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_8822B BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_8822B BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_8822B BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_8822B BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_8822B BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_8822B BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_8822B BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_8822B BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_8822B BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_8822B BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_8822B BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_8822B BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_8822B BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_8822B BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_8822B BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_8822B BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_8822B BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_8822B BIT(0)
/* 2 REG_FT1IMR_8822B */
#define BIT__FT2ISR__IND_MSK_8822B BIT(30)
#define BIT_FTM_PTT_INT_EN_8822B BIT(29)
#define BIT_RXFTMREQ_INT_EN_8822B BIT(28)
#define BIT_RXFTM_INT_EN_8822B BIT(27)
#define BIT_TXFTM_INT_EN_8822B BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_EN_8822B BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_EN_8822B BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_EN_8822B BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_EN_8822B BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_EN_8822B BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_EN_8822B BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_EN_8822B BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_EN_8822B BIT(18)
#define BIT_FS_CTWEND2_INT_EN_8822B BIT(17)
#define BIT_FS_CTWEND1_INT_EN_8822B BIT(16)
#define BIT_FS_CTWEND0_INT_EN_8822B BIT(15)
#define BIT_FS_TX_NULL1_INT_EN_8822B BIT(14)
#define BIT_FS_TX_NULL0_INT_EN_8822B BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_EN_8822B BIT(12)
#define BIT_FS_P2P_RFON2_INT_EN_8822B BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_EN_8822B BIT(10)
#define BIT_FS_P2P_RFON1_INT_EN_8822B BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_EN_8822B BIT(8)
#define BIT_FS_P2P_RFON0_INT_EN_8822B BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_EN_8822B BIT(6)
#define BIT_FS_RX_UAPSDMD1_EN_8822B BIT(5)
#define BIT_FS_RX_UAPSDMD0_EN_8822B BIT(4)
#define BIT_FS_TRIGGER_PKT_EN_8822B BIT(3)
#define BIT_FS_EOSP_INT_EN_8822B BIT(2)
#define BIT_FS_RPWM2_INT_EN_8822B BIT(1)
#define BIT_FS_RPWM_INT_EN_8822B BIT(0)
/* 2 REG_FT1ISR_8822B */
#define BIT__FT2ISR__IND_INT_8822B BIT(30)
#define BIT_FTM_PTT_INT_8822B BIT(29)
#define BIT_RXFTMREQ_INT_8822B BIT(28)
#define BIT_RXFTM_INT_8822B BIT(27)
#define BIT_TXFTM_INT_8822B BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_8822B BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_8822B BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_8822B BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_8822B BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_8822B BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_8822B BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_8822B BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_8822B BIT(18)
#define BIT_FS_CTWEND2_INT_8822B BIT(17)
#define BIT_FS_CTWEND1_INT_8822B BIT(16)
#define BIT_FS_CTWEND0_INT_8822B BIT(15)
#define BIT_FS_TX_NULL1_INT_8822B BIT(14)
#define BIT_FS_TX_NULL0_INT_8822B BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_INT_8822B BIT(12)
#define BIT_FS_P2P_RFON2_INT_8822B BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_8822B BIT(10)
#define BIT_FS_P2P_RFON1_INT_8822B BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_8822B BIT(8)
#define BIT_FS_P2P_RFON0_INT_8822B BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_8822B BIT(6)
#define BIT_FS_RX_UAPSDMD1_INT_8822B BIT(5)
#define BIT_FS_RX_UAPSDMD0_INT_8822B BIT(4)
#define BIT_FS_TRIGGER_PKT_INT_8822B BIT(3)
#define BIT_FS_EOSP_INT_8822B BIT(2)
#define BIT_FS_RPWM2_INT_8822B BIT(1)
#define BIT_FS_RPWM_INT_8822B BIT(0)
/* 2 REG_SPWR0_8822B */
#define BIT_SHIFT_MID_31TO0_8822B 0
#define BIT_MASK_MID_31TO0_8822B 0xffffffffL
#define BIT_MID_31TO0_8822B(x) \
(((x) & BIT_MASK_MID_31TO0_8822B) << BIT_SHIFT_MID_31TO0_8822B)
#define BITS_MID_31TO0_8822B \
(BIT_MASK_MID_31TO0_8822B << BIT_SHIFT_MID_31TO0_8822B)
#define BIT_CLEAR_MID_31TO0_8822B(x) ((x) & (~BITS_MID_31TO0_8822B))
#define BIT_GET_MID_31TO0_8822B(x) \
(((x) >> BIT_SHIFT_MID_31TO0_8822B) & BIT_MASK_MID_31TO0_8822B)
#define BIT_SET_MID_31TO0_8822B(x, v) \
(BIT_CLEAR_MID_31TO0_8822B(x) | BIT_MID_31TO0_8822B(v))
/* 2 REG_SPWR1_8822B */
#define BIT_SHIFT_MID_63TO32_8822B 0
#define BIT_MASK_MID_63TO32_8822B 0xffffffffL
#define BIT_MID_63TO32_8822B(x) \
(((x) & BIT_MASK_MID_63TO32_8822B) << BIT_SHIFT_MID_63TO32_8822B)
#define BITS_MID_63TO32_8822B \
(BIT_MASK_MID_63TO32_8822B << BIT_SHIFT_MID_63TO32_8822B)
#define BIT_CLEAR_MID_63TO32_8822B(x) ((x) & (~BITS_MID_63TO32_8822B))
#define BIT_GET_MID_63TO32_8822B(x) \
(((x) >> BIT_SHIFT_MID_63TO32_8822B) & BIT_MASK_MID_63TO32_8822B)
#define BIT_SET_MID_63TO32_8822B(x, v) \
(BIT_CLEAR_MID_63TO32_8822B(x) | BIT_MID_63TO32_8822B(v))
/* 2 REG_SPWR2_8822B */
#define BIT_SHIFT_MID_95O64_8822B 0
#define BIT_MASK_MID_95O64_8822B 0xffffffffL
#define BIT_MID_95O64_8822B(x) \
(((x) & BIT_MASK_MID_95O64_8822B) << BIT_SHIFT_MID_95O64_8822B)
#define BITS_MID_95O64_8822B \
(BIT_MASK_MID_95O64_8822B << BIT_SHIFT_MID_95O64_8822B)
#define BIT_CLEAR_MID_95O64_8822B(x) ((x) & (~BITS_MID_95O64_8822B))
#define BIT_GET_MID_95O64_8822B(x) \
(((x) >> BIT_SHIFT_MID_95O64_8822B) & BIT_MASK_MID_95O64_8822B)
#define BIT_SET_MID_95O64_8822B(x, v) \
(BIT_CLEAR_MID_95O64_8822B(x) | BIT_MID_95O64_8822B(v))
/* 2 REG_SPWR3_8822B */
#define BIT_SHIFT_MID_127TO96_8822B 0
#define BIT_MASK_MID_127TO96_8822B 0xffffffffL
#define BIT_MID_127TO96_8822B(x) \
(((x) & BIT_MASK_MID_127TO96_8822B) << BIT_SHIFT_MID_127TO96_8822B)
#define BITS_MID_127TO96_8822B \
(BIT_MASK_MID_127TO96_8822B << BIT_SHIFT_MID_127TO96_8822B)
#define BIT_CLEAR_MID_127TO96_8822B(x) ((x) & (~BITS_MID_127TO96_8822B))
#define BIT_GET_MID_127TO96_8822B(x) \
(((x) >> BIT_SHIFT_MID_127TO96_8822B) & BIT_MASK_MID_127TO96_8822B)
#define BIT_SET_MID_127TO96_8822B(x, v) \
(BIT_CLEAR_MID_127TO96_8822B(x) | BIT_MID_127TO96_8822B(v))
/* 2 REG_POWSEQ_8822B */
#define BIT_SHIFT_SEQNUM_MID_8822B 16
#define BIT_MASK_SEQNUM_MID_8822B 0xffff
#define BIT_SEQNUM_MID_8822B(x) \
(((x) & BIT_MASK_SEQNUM_MID_8822B) << BIT_SHIFT_SEQNUM_MID_8822B)
#define BITS_SEQNUM_MID_8822B \
(BIT_MASK_SEQNUM_MID_8822B << BIT_SHIFT_SEQNUM_MID_8822B)
#define BIT_CLEAR_SEQNUM_MID_8822B(x) ((x) & (~BITS_SEQNUM_MID_8822B))
#define BIT_GET_SEQNUM_MID_8822B(x) \
(((x) >> BIT_SHIFT_SEQNUM_MID_8822B) & BIT_MASK_SEQNUM_MID_8822B)
#define BIT_SET_SEQNUM_MID_8822B(x, v) \
(BIT_CLEAR_SEQNUM_MID_8822B(x) | BIT_SEQNUM_MID_8822B(v))
#define BIT_SHIFT_REF_MID_8822B 0
#define BIT_MASK_REF_MID_8822B 0x7f
#define BIT_REF_MID_8822B(x) \
(((x) & BIT_MASK_REF_MID_8822B) << BIT_SHIFT_REF_MID_8822B)
#define BITS_REF_MID_8822B (BIT_MASK_REF_MID_8822B << BIT_SHIFT_REF_MID_8822B)
#define BIT_CLEAR_REF_MID_8822B(x) ((x) & (~BITS_REF_MID_8822B))
#define BIT_GET_REF_MID_8822B(x) \
(((x) >> BIT_SHIFT_REF_MID_8822B) & BIT_MASK_REF_MID_8822B)
#define BIT_SET_REF_MID_8822B(x, v) \
(BIT_CLEAR_REF_MID_8822B(x) | BIT_REF_MID_8822B(v))
/* 2 REG_TC7_CTRL_V1_8822B */
#define BIT_TC7INT_EN_8822B BIT(26)
#define BIT_TC7MODE_8822B BIT(25)
#define BIT_TC7EN_8822B BIT(24)
#define BIT_SHIFT_TC7DATA_8822B 0
#define BIT_MASK_TC7DATA_8822B 0xffffff
#define BIT_TC7DATA_8822B(x) \
(((x) & BIT_MASK_TC7DATA_8822B) << BIT_SHIFT_TC7DATA_8822B)
#define BITS_TC7DATA_8822B (BIT_MASK_TC7DATA_8822B << BIT_SHIFT_TC7DATA_8822B)
#define BIT_CLEAR_TC7DATA_8822B(x) ((x) & (~BITS_TC7DATA_8822B))
#define BIT_GET_TC7DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC7DATA_8822B) & BIT_MASK_TC7DATA_8822B)
#define BIT_SET_TC7DATA_8822B(x, v) \
(BIT_CLEAR_TC7DATA_8822B(x) | BIT_TC7DATA_8822B(v))
/* 2 REG_TC8_CTRL_V1_8822B */
#define BIT_TC8INT_EN_8822B BIT(26)
#define BIT_TC8MODE_8822B BIT(25)
#define BIT_TC8EN_8822B BIT(24)
#define BIT_SHIFT_TC8DATA_8822B 0
#define BIT_MASK_TC8DATA_8822B 0xffffff
#define BIT_TC8DATA_8822B(x) \
(((x) & BIT_MASK_TC8DATA_8822B) << BIT_SHIFT_TC8DATA_8822B)
#define BITS_TC8DATA_8822B (BIT_MASK_TC8DATA_8822B << BIT_SHIFT_TC8DATA_8822B)
#define BIT_CLEAR_TC8DATA_8822B(x) ((x) & (~BITS_TC8DATA_8822B))
#define BIT_GET_TC8DATA_8822B(x) \
(((x) >> BIT_SHIFT_TC8DATA_8822B) & BIT_MASK_TC8DATA_8822B)
#define BIT_SET_TC8DATA_8822B(x, v) \
(BIT_CLEAR_TC8DATA_8822B(x) | BIT_TC8DATA_8822B(v))
/* 2 REG_FT2IMR_8822B */
#define BIT_FS_CLI3_RX_UAPSDMD1_EN_8822B BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_EN_8822B BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_EN_8822B BIT(29)
#define BIT_FS_CLI3_EOSP_INT_EN_8822B BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_EN_8822B BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_EN_8822B BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_EN_8822B BIT(25)
#define BIT_FS_CLI2_EOSP_INT_EN_8822B BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_EN_8822B BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_EN_8822B BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_EN_8822B BIT(21)
#define BIT_FS_CLI1_EOSP_INT_EN_8822B BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_EN_8822B BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_EN_8822B BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_EN_8822B BIT(17)
#define BIT_FS_CLI0_EOSP_INT_EN_8822B BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_EN_8822B BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_EN_8822B BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_EN_8822B BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_EN_8822B BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_EN_8822B BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_EN_8822B BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_EN_8822B BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_EN_8822B BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_EN_8822B BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_EN_8822B BIT(0)
/* 2 REG_FT2ISR_8822B */
#define BIT_FS_CLI3_RX_UAPSDMD1_INT_8822B BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_INT_8822B BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_INT_8822B BIT(29)
#define BIT_FS_CLI3_EOSP_INT_8822B BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_INT_8822B BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_INT_8822B BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_INT_8822B BIT(25)
#define BIT_FS_CLI2_EOSP_INT_8822B BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_INT_8822B BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_INT_8822B BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_INT_8822B BIT(21)
#define BIT_FS_CLI1_EOSP_INT_8822B BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_INT_8822B BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_INT_8822B BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_INT_8822B BIT(17)
#define BIT_FS_CLI0_EOSP_INT_8822B BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_INT_8822B BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_INT_8822B BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_8822B BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_8822B BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_8822B BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_8822B BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_8822B BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_8822B BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_8822B BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_8822B BIT(0)
/* 2 REG_MSG2_8822B */
#define BIT_SHIFT_FW_MSG2_8822B 0
#define BIT_MASK_FW_MSG2_8822B 0xffffffffL
#define BIT_FW_MSG2_8822B(x) \
(((x) & BIT_MASK_FW_MSG2_8822B) << BIT_SHIFT_FW_MSG2_8822B)
#define BITS_FW_MSG2_8822B (BIT_MASK_FW_MSG2_8822B << BIT_SHIFT_FW_MSG2_8822B)
#define BIT_CLEAR_FW_MSG2_8822B(x) ((x) & (~BITS_FW_MSG2_8822B))
#define BIT_GET_FW_MSG2_8822B(x) \
(((x) >> BIT_SHIFT_FW_MSG2_8822B) & BIT_MASK_FW_MSG2_8822B)
#define BIT_SET_FW_MSG2_8822B(x, v) \
(BIT_CLEAR_FW_MSG2_8822B(x) | BIT_FW_MSG2_8822B(v))
/* 2 REG_MSG3_8822B */
#define BIT_SHIFT_FW_MSG3_8822B 0
#define BIT_MASK_FW_MSG3_8822B 0xffffffffL
#define BIT_FW_MSG3_8822B(x) \
(((x) & BIT_MASK_FW_MSG3_8822B) << BIT_SHIFT_FW_MSG3_8822B)
#define BITS_FW_MSG3_8822B (BIT_MASK_FW_MSG3_8822B << BIT_SHIFT_FW_MSG3_8822B)
#define BIT_CLEAR_FW_MSG3_8822B(x) ((x) & (~BITS_FW_MSG3_8822B))
#define BIT_GET_FW_MSG3_8822B(x) \
(((x) >> BIT_SHIFT_FW_MSG3_8822B) & BIT_MASK_FW_MSG3_8822B)
#define BIT_SET_FW_MSG3_8822B(x, v) \
(BIT_CLEAR_FW_MSG3_8822B(x) | BIT_FW_MSG3_8822B(v))
/* 2 REG_MSG4_8822B */
#define BIT_SHIFT_FW_MSG4_8822B 0
#define BIT_MASK_FW_MSG4_8822B 0xffffffffL
#define BIT_FW_MSG4_8822B(x) \
(((x) & BIT_MASK_FW_MSG4_8822B) << BIT_SHIFT_FW_MSG4_8822B)
#define BITS_FW_MSG4_8822B (BIT_MASK_FW_MSG4_8822B << BIT_SHIFT_FW_MSG4_8822B)
#define BIT_CLEAR_FW_MSG4_8822B(x) ((x) & (~BITS_FW_MSG4_8822B))
#define BIT_GET_FW_MSG4_8822B(x) \
(((x) >> BIT_SHIFT_FW_MSG4_8822B) & BIT_MASK_FW_MSG4_8822B)
#define BIT_SET_FW_MSG4_8822B(x, v) \
(BIT_CLEAR_FW_MSG4_8822B(x) | BIT_FW_MSG4_8822B(v))
/* 2 REG_MSG5_8822B */
#define BIT_SHIFT_FW_MSG5_8822B 0
#define BIT_MASK_FW_MSG5_8822B 0xffffffffL
#define BIT_FW_MSG5_8822B(x) \
(((x) & BIT_MASK_FW_MSG5_8822B) << BIT_SHIFT_FW_MSG5_8822B)
#define BITS_FW_MSG5_8822B (BIT_MASK_FW_MSG5_8822B << BIT_SHIFT_FW_MSG5_8822B)
#define BIT_CLEAR_FW_MSG5_8822B(x) ((x) & (~BITS_FW_MSG5_8822B))
#define BIT_GET_FW_MSG5_8822B(x) \
(((x) >> BIT_SHIFT_FW_MSG5_8822B) & BIT_MASK_FW_MSG5_8822B)
#define BIT_SET_FW_MSG5_8822B(x, v) \
(BIT_CLEAR_FW_MSG5_8822B(x) | BIT_FW_MSG5_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_FIFOPAGE_CTRL_1_8822B */
#define BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822B 16
#define BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822B 0xff
#define BIT_TX_OQT_HE_FREE_SPACE_V1_8822B(x) \
(((x) & BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822B) \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822B)
#define BITS_TX_OQT_HE_FREE_SPACE_V1_8822B \
(BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822B \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822B)
#define BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8822B(x) \
((x) & (~BITS_TX_OQT_HE_FREE_SPACE_V1_8822B))
#define BIT_GET_TX_OQT_HE_FREE_SPACE_V1_8822B(x) \
(((x) >> BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822B) & \
BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822B)
#define BIT_SET_TX_OQT_HE_FREE_SPACE_V1_8822B(x, v) \
(BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8822B(x) | \
BIT_TX_OQT_HE_FREE_SPACE_V1_8822B(v))
#define BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822B 0
#define BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822B 0xff
#define BIT_TX_OQT_NL_FREE_SPACE_V1_8822B(x) \
(((x) & BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822B) \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822B)
#define BITS_TX_OQT_NL_FREE_SPACE_V1_8822B \
(BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822B \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822B)
#define BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8822B(x) \
((x) & (~BITS_TX_OQT_NL_FREE_SPACE_V1_8822B))
#define BIT_GET_TX_OQT_NL_FREE_SPACE_V1_8822B(x) \
(((x) >> BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822B) & \
BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822B)
#define BIT_SET_TX_OQT_NL_FREE_SPACE_V1_8822B(x, v) \
(BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8822B(x) | \
BIT_TX_OQT_NL_FREE_SPACE_V1_8822B(v))
/* 2 REG_FIFOPAGE_CTRL_2_8822B */
#define BIT_BCN_VALID_1_V1_8822B BIT(31)
#define BIT_SHIFT_BCN_HEAD_1_V1_8822B 16
#define BIT_MASK_BCN_HEAD_1_V1_8822B 0xfff
#define BIT_BCN_HEAD_1_V1_8822B(x) \
(((x) & BIT_MASK_BCN_HEAD_1_V1_8822B) << BIT_SHIFT_BCN_HEAD_1_V1_8822B)
#define BITS_BCN_HEAD_1_V1_8822B \
(BIT_MASK_BCN_HEAD_1_V1_8822B << BIT_SHIFT_BCN_HEAD_1_V1_8822B)
#define BIT_CLEAR_BCN_HEAD_1_V1_8822B(x) ((x) & (~BITS_BCN_HEAD_1_V1_8822B))
#define BIT_GET_BCN_HEAD_1_V1_8822B(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_1_V1_8822B) & BIT_MASK_BCN_HEAD_1_V1_8822B)
#define BIT_SET_BCN_HEAD_1_V1_8822B(x, v) \
(BIT_CLEAR_BCN_HEAD_1_V1_8822B(x) | BIT_BCN_HEAD_1_V1_8822B(v))
#define BIT_BCN_VALID_V1_8822B BIT(15)
#define BIT_SHIFT_BCN_HEAD_V1_8822B 0
#define BIT_MASK_BCN_HEAD_V1_8822B 0xfff
#define BIT_BCN_HEAD_V1_8822B(x) \
(((x) & BIT_MASK_BCN_HEAD_V1_8822B) << BIT_SHIFT_BCN_HEAD_V1_8822B)
#define BITS_BCN_HEAD_V1_8822B \
(BIT_MASK_BCN_HEAD_V1_8822B << BIT_SHIFT_BCN_HEAD_V1_8822B)
#define BIT_CLEAR_BCN_HEAD_V1_8822B(x) ((x) & (~BITS_BCN_HEAD_V1_8822B))
#define BIT_GET_BCN_HEAD_V1_8822B(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_V1_8822B) & BIT_MASK_BCN_HEAD_V1_8822B)
#define BIT_SET_BCN_HEAD_V1_8822B(x, v) \
(BIT_CLEAR_BCN_HEAD_V1_8822B(x) | BIT_BCN_HEAD_V1_8822B(v))
/* 2 REG_AUTO_LLT_V1_8822B */
#define BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B 24
#define BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B 0xff
#define BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B(x) \
(((x) & BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B) \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B)
#define BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B \
(BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B \
<< BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B)
#define BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B(x) \
((x) & (~BITS_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B))
#define BIT_GET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B) & \
BIT_MASK_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B)
#define BIT_SET_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B(x, v) \
(BIT_CLEAR_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B(x) | \
BIT_MAX_TX_PKT_FOR_USB_AND_SDIO_V1_8822B(v))
#define BIT_SHIFT_LLT_FREE_PAGE_V1_8822B 8
#define BIT_MASK_LLT_FREE_PAGE_V1_8822B 0xffff
#define BIT_LLT_FREE_PAGE_V1_8822B(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V1_8822B) \
<< BIT_SHIFT_LLT_FREE_PAGE_V1_8822B)
#define BITS_LLT_FREE_PAGE_V1_8822B \
(BIT_MASK_LLT_FREE_PAGE_V1_8822B << BIT_SHIFT_LLT_FREE_PAGE_V1_8822B)
#define BIT_CLEAR_LLT_FREE_PAGE_V1_8822B(x) \
((x) & (~BITS_LLT_FREE_PAGE_V1_8822B))
#define BIT_GET_LLT_FREE_PAGE_V1_8822B(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V1_8822B) & \
BIT_MASK_LLT_FREE_PAGE_V1_8822B)
#define BIT_SET_LLT_FREE_PAGE_V1_8822B(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V1_8822B(x) | BIT_LLT_FREE_PAGE_V1_8822B(v))
#define BIT_SHIFT_BLK_DESC_NUM_8822B 4
#define BIT_MASK_BLK_DESC_NUM_8822B 0xf
#define BIT_BLK_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_BLK_DESC_NUM_8822B) << BIT_SHIFT_BLK_DESC_NUM_8822B)
#define BITS_BLK_DESC_NUM_8822B \
(BIT_MASK_BLK_DESC_NUM_8822B << BIT_SHIFT_BLK_DESC_NUM_8822B)
#define BIT_CLEAR_BLK_DESC_NUM_8822B(x) ((x) & (~BITS_BLK_DESC_NUM_8822B))
#define BIT_GET_BLK_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_BLK_DESC_NUM_8822B) & BIT_MASK_BLK_DESC_NUM_8822B)
#define BIT_SET_BLK_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_BLK_DESC_NUM_8822B(x) | BIT_BLK_DESC_NUM_8822B(v))
#define BIT_R_BCN_HEAD_SEL_8822B BIT(3)
#define BIT_R_EN_BCN_SW_HEAD_SEL_8822B BIT(2)
#define BIT_LLT_DBG_SEL_8822B BIT(1)
#define BIT_AUTO_INIT_LLT_V1_8822B BIT(0)
/* 2 REG_TXDMA_OFFSET_CHK_8822B */
#define BIT_EM_CHKSUM_FIN_8822B BIT(31)
#define BIT_EMN_PCIE_DMA_MOD_8822B BIT(30)
#define BIT_EN_TXQUE_CLR_8822B BIT(29)
#define BIT_EN_PCIE_FIFO_MODE_8822B BIT(28)
#define BIT_SHIFT_PG_UNDER_TH_V1_8822B 16
#define BIT_MASK_PG_UNDER_TH_V1_8822B 0xfff
#define BIT_PG_UNDER_TH_V1_8822B(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V1_8822B) \
<< BIT_SHIFT_PG_UNDER_TH_V1_8822B)
#define BITS_PG_UNDER_TH_V1_8822B \
(BIT_MASK_PG_UNDER_TH_V1_8822B << BIT_SHIFT_PG_UNDER_TH_V1_8822B)
#define BIT_CLEAR_PG_UNDER_TH_V1_8822B(x) ((x) & (~BITS_PG_UNDER_TH_V1_8822B))
#define BIT_GET_PG_UNDER_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V1_8822B) & \
BIT_MASK_PG_UNDER_TH_V1_8822B)
#define BIT_SET_PG_UNDER_TH_V1_8822B(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V1_8822B(x) | BIT_PG_UNDER_TH_V1_8822B(v))
#define BIT_RESTORE_H2C_ADDRESS_8822B BIT(15)
#define BIT_SDIO_TXDESC_CHKSUM_EN_8822B BIT(13)
#define BIT_RST_RDPTR_8822B BIT(12)
#define BIT_RST_WRPTR_8822B BIT(11)
#define BIT_CHK_PG_TH_EN_8822B BIT(10)
#define BIT_DROP_DATA_EN_8822B BIT(9)
#define BIT_CHECK_OFFSET_EN_8822B BIT(8)
#define BIT_SHIFT_CHECK_OFFSET_8822B 0
#define BIT_MASK_CHECK_OFFSET_8822B 0xff
#define BIT_CHECK_OFFSET_8822B(x) \
(((x) & BIT_MASK_CHECK_OFFSET_8822B) << BIT_SHIFT_CHECK_OFFSET_8822B)
#define BITS_CHECK_OFFSET_8822B \
(BIT_MASK_CHECK_OFFSET_8822B << BIT_SHIFT_CHECK_OFFSET_8822B)
#define BIT_CLEAR_CHECK_OFFSET_8822B(x) ((x) & (~BITS_CHECK_OFFSET_8822B))
#define BIT_GET_CHECK_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_CHECK_OFFSET_8822B) & BIT_MASK_CHECK_OFFSET_8822B)
#define BIT_SET_CHECK_OFFSET_8822B(x, v) \
(BIT_CLEAR_CHECK_OFFSET_8822B(x) | BIT_CHECK_OFFSET_8822B(v))
/* 2 REG_TXDMA_STATUS_8822B */
#define BIT_HI_OQT_UDN_8822B BIT(17)
#define BIT_HI_OQT_OVF_8822B BIT(16)
#define BIT_PAYLOAD_CHKSUM_ERR_8822B BIT(15)
#define BIT_PAYLOAD_UDN_8822B BIT(14)
#define BIT_PAYLOAD_OVF_8822B BIT(13)
#define BIT_DSC_CHKSUM_FAIL_8822B BIT(12)
#define BIT_UNKNOWN_QSEL_8822B BIT(11)
#define BIT_EP_QSEL_DIFF_8822B BIT(10)
#define BIT_TX_OFFS_UNMATCH_8822B BIT(9)
#define BIT_TXOQT_UDN_8822B BIT(8)
#define BIT_TXOQT_OVF_8822B BIT(7)
#define BIT_TXDMA_SFF_UDN_8822B BIT(6)
#define BIT_TXDMA_SFF_OVF_8822B BIT(5)
#define BIT_LLT_NULL_PG_8822B BIT(4)
#define BIT_PAGE_UDN_8822B BIT(3)
#define BIT_PAGE_OVF_8822B BIT(2)
#define BIT_TXFF_PG_UDN_8822B BIT(1)
#define BIT_TXFF_PG_OVF_8822B BIT(0)
/* 2 REG_TX_DMA_DBG_8822B */
/* 2 REG_TQPNT1_8822B */
#define BIT_SHIFT_HPQ_HIGH_TH_V1_8822B 16
#define BIT_MASK_HPQ_HIGH_TH_V1_8822B 0xfff
#define BIT_HPQ_HIGH_TH_V1_8822B(x) \
(((x) & BIT_MASK_HPQ_HIGH_TH_V1_8822B) \
<< BIT_SHIFT_HPQ_HIGH_TH_V1_8822B)
#define BITS_HPQ_HIGH_TH_V1_8822B \
(BIT_MASK_HPQ_HIGH_TH_V1_8822B << BIT_SHIFT_HPQ_HIGH_TH_V1_8822B)
#define BIT_CLEAR_HPQ_HIGH_TH_V1_8822B(x) ((x) & (~BITS_HPQ_HIGH_TH_V1_8822B))
#define BIT_GET_HPQ_HIGH_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_HPQ_HIGH_TH_V1_8822B) & \
BIT_MASK_HPQ_HIGH_TH_V1_8822B)
#define BIT_SET_HPQ_HIGH_TH_V1_8822B(x, v) \
(BIT_CLEAR_HPQ_HIGH_TH_V1_8822B(x) | BIT_HPQ_HIGH_TH_V1_8822B(v))
#define BIT_SHIFT_HPQ_LOW_TH_V1_8822B 0
#define BIT_MASK_HPQ_LOW_TH_V1_8822B 0xfff
#define BIT_HPQ_LOW_TH_V1_8822B(x) \
(((x) & BIT_MASK_HPQ_LOW_TH_V1_8822B) << BIT_SHIFT_HPQ_LOW_TH_V1_8822B)
#define BITS_HPQ_LOW_TH_V1_8822B \
(BIT_MASK_HPQ_LOW_TH_V1_8822B << BIT_SHIFT_HPQ_LOW_TH_V1_8822B)
#define BIT_CLEAR_HPQ_LOW_TH_V1_8822B(x) ((x) & (~BITS_HPQ_LOW_TH_V1_8822B))
#define BIT_GET_HPQ_LOW_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_HPQ_LOW_TH_V1_8822B) & BIT_MASK_HPQ_LOW_TH_V1_8822B)
#define BIT_SET_HPQ_LOW_TH_V1_8822B(x, v) \
(BIT_CLEAR_HPQ_LOW_TH_V1_8822B(x) | BIT_HPQ_LOW_TH_V1_8822B(v))
/* 2 REG_TQPNT2_8822B */
#define BIT_SHIFT_NPQ_HIGH_TH_V1_8822B 16
#define BIT_MASK_NPQ_HIGH_TH_V1_8822B 0xfff
#define BIT_NPQ_HIGH_TH_V1_8822B(x) \
(((x) & BIT_MASK_NPQ_HIGH_TH_V1_8822B) \
<< BIT_SHIFT_NPQ_HIGH_TH_V1_8822B)
#define BITS_NPQ_HIGH_TH_V1_8822B \
(BIT_MASK_NPQ_HIGH_TH_V1_8822B << BIT_SHIFT_NPQ_HIGH_TH_V1_8822B)
#define BIT_CLEAR_NPQ_HIGH_TH_V1_8822B(x) ((x) & (~BITS_NPQ_HIGH_TH_V1_8822B))
#define BIT_GET_NPQ_HIGH_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_NPQ_HIGH_TH_V1_8822B) & \
BIT_MASK_NPQ_HIGH_TH_V1_8822B)
#define BIT_SET_NPQ_HIGH_TH_V1_8822B(x, v) \
(BIT_CLEAR_NPQ_HIGH_TH_V1_8822B(x) | BIT_NPQ_HIGH_TH_V1_8822B(v))
#define BIT_SHIFT_NPQ_LOW_TH_V1_8822B 0
#define BIT_MASK_NPQ_LOW_TH_V1_8822B 0xfff
#define BIT_NPQ_LOW_TH_V1_8822B(x) \
(((x) & BIT_MASK_NPQ_LOW_TH_V1_8822B) << BIT_SHIFT_NPQ_LOW_TH_V1_8822B)
#define BITS_NPQ_LOW_TH_V1_8822B \
(BIT_MASK_NPQ_LOW_TH_V1_8822B << BIT_SHIFT_NPQ_LOW_TH_V1_8822B)
#define BIT_CLEAR_NPQ_LOW_TH_V1_8822B(x) ((x) & (~BITS_NPQ_LOW_TH_V1_8822B))
#define BIT_GET_NPQ_LOW_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_NPQ_LOW_TH_V1_8822B) & BIT_MASK_NPQ_LOW_TH_V1_8822B)
#define BIT_SET_NPQ_LOW_TH_V1_8822B(x, v) \
(BIT_CLEAR_NPQ_LOW_TH_V1_8822B(x) | BIT_NPQ_LOW_TH_V1_8822B(v))
/* 2 REG_TQPNT3_8822B */
#define BIT_SHIFT_LPQ_HIGH_TH_V1_8822B 16
#define BIT_MASK_LPQ_HIGH_TH_V1_8822B 0xfff
#define BIT_LPQ_HIGH_TH_V1_8822B(x) \
(((x) & BIT_MASK_LPQ_HIGH_TH_V1_8822B) \
<< BIT_SHIFT_LPQ_HIGH_TH_V1_8822B)
#define BITS_LPQ_HIGH_TH_V1_8822B \
(BIT_MASK_LPQ_HIGH_TH_V1_8822B << BIT_SHIFT_LPQ_HIGH_TH_V1_8822B)
#define BIT_CLEAR_LPQ_HIGH_TH_V1_8822B(x) ((x) & (~BITS_LPQ_HIGH_TH_V1_8822B))
#define BIT_GET_LPQ_HIGH_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_LPQ_HIGH_TH_V1_8822B) & \
BIT_MASK_LPQ_HIGH_TH_V1_8822B)
#define BIT_SET_LPQ_HIGH_TH_V1_8822B(x, v) \
(BIT_CLEAR_LPQ_HIGH_TH_V1_8822B(x) | BIT_LPQ_HIGH_TH_V1_8822B(v))
#define BIT_SHIFT_LPQ_LOW_TH_V1_8822B 0
#define BIT_MASK_LPQ_LOW_TH_V1_8822B 0xfff
#define BIT_LPQ_LOW_TH_V1_8822B(x) \
(((x) & BIT_MASK_LPQ_LOW_TH_V1_8822B) << BIT_SHIFT_LPQ_LOW_TH_V1_8822B)
#define BITS_LPQ_LOW_TH_V1_8822B \
(BIT_MASK_LPQ_LOW_TH_V1_8822B << BIT_SHIFT_LPQ_LOW_TH_V1_8822B)
#define BIT_CLEAR_LPQ_LOW_TH_V1_8822B(x) ((x) & (~BITS_LPQ_LOW_TH_V1_8822B))
#define BIT_GET_LPQ_LOW_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_LPQ_LOW_TH_V1_8822B) & BIT_MASK_LPQ_LOW_TH_V1_8822B)
#define BIT_SET_LPQ_LOW_TH_V1_8822B(x, v) \
(BIT_CLEAR_LPQ_LOW_TH_V1_8822B(x) | BIT_LPQ_LOW_TH_V1_8822B(v))
/* 2 REG_TQPNT4_8822B */
#define BIT_SHIFT_EXQ_HIGH_TH_V1_8822B 16
#define BIT_MASK_EXQ_HIGH_TH_V1_8822B 0xfff
#define BIT_EXQ_HIGH_TH_V1_8822B(x) \
(((x) & BIT_MASK_EXQ_HIGH_TH_V1_8822B) \
<< BIT_SHIFT_EXQ_HIGH_TH_V1_8822B)
#define BITS_EXQ_HIGH_TH_V1_8822B \
(BIT_MASK_EXQ_HIGH_TH_V1_8822B << BIT_SHIFT_EXQ_HIGH_TH_V1_8822B)
#define BIT_CLEAR_EXQ_HIGH_TH_V1_8822B(x) ((x) & (~BITS_EXQ_HIGH_TH_V1_8822B))
#define BIT_GET_EXQ_HIGH_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_EXQ_HIGH_TH_V1_8822B) & \
BIT_MASK_EXQ_HIGH_TH_V1_8822B)
#define BIT_SET_EXQ_HIGH_TH_V1_8822B(x, v) \
(BIT_CLEAR_EXQ_HIGH_TH_V1_8822B(x) | BIT_EXQ_HIGH_TH_V1_8822B(v))
#define BIT_SHIFT_EXQ_LOW_TH_V1_8822B 0
#define BIT_MASK_EXQ_LOW_TH_V1_8822B 0xfff
#define BIT_EXQ_LOW_TH_V1_8822B(x) \
(((x) & BIT_MASK_EXQ_LOW_TH_V1_8822B) << BIT_SHIFT_EXQ_LOW_TH_V1_8822B)
#define BITS_EXQ_LOW_TH_V1_8822B \
(BIT_MASK_EXQ_LOW_TH_V1_8822B << BIT_SHIFT_EXQ_LOW_TH_V1_8822B)
#define BIT_CLEAR_EXQ_LOW_TH_V1_8822B(x) ((x) & (~BITS_EXQ_LOW_TH_V1_8822B))
#define BIT_GET_EXQ_LOW_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_EXQ_LOW_TH_V1_8822B) & BIT_MASK_EXQ_LOW_TH_V1_8822B)
#define BIT_SET_EXQ_LOW_TH_V1_8822B(x, v) \
(BIT_CLEAR_EXQ_LOW_TH_V1_8822B(x) | BIT_EXQ_LOW_TH_V1_8822B(v))
/* 2 REG_RQPN_CTRL_1_8822B */
#define BIT_SHIFT_TXPKTNUM_H_8822B 16
#define BIT_MASK_TXPKTNUM_H_8822B 0xffff
#define BIT_TXPKTNUM_H_8822B(x) \
(((x) & BIT_MASK_TXPKTNUM_H_8822B) << BIT_SHIFT_TXPKTNUM_H_8822B)
#define BITS_TXPKTNUM_H_8822B \
(BIT_MASK_TXPKTNUM_H_8822B << BIT_SHIFT_TXPKTNUM_H_8822B)
#define BIT_CLEAR_TXPKTNUM_H_8822B(x) ((x) & (~BITS_TXPKTNUM_H_8822B))
#define BIT_GET_TXPKTNUM_H_8822B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_8822B) & BIT_MASK_TXPKTNUM_H_8822B)
#define BIT_SET_TXPKTNUM_H_8822B(x, v) \
(BIT_CLEAR_TXPKTNUM_H_8822B(x) | BIT_TXPKTNUM_H_8822B(v))
#define BIT_SHIFT_TXPKTNUM_V2_8822B 0
#define BIT_MASK_TXPKTNUM_V2_8822B 0xffff
#define BIT_TXPKTNUM_V2_8822B(x) \
(((x) & BIT_MASK_TXPKTNUM_V2_8822B) << BIT_SHIFT_TXPKTNUM_V2_8822B)
#define BITS_TXPKTNUM_V2_8822B \
(BIT_MASK_TXPKTNUM_V2_8822B << BIT_SHIFT_TXPKTNUM_V2_8822B)
#define BIT_CLEAR_TXPKTNUM_V2_8822B(x) ((x) & (~BITS_TXPKTNUM_V2_8822B))
#define BIT_GET_TXPKTNUM_V2_8822B(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_V2_8822B) & BIT_MASK_TXPKTNUM_V2_8822B)
#define BIT_SET_TXPKTNUM_V2_8822B(x, v) \
(BIT_CLEAR_TXPKTNUM_V2_8822B(x) | BIT_TXPKTNUM_V2_8822B(v))
/* 2 REG_RQPN_CTRL_2_8822B */
#define BIT_LD_RQPN_8822B BIT(31)
#define BIT_EXQ_PUBLIC_DIS_V1_8822B BIT(19)
#define BIT_NPQ_PUBLIC_DIS_V1_8822B BIT(18)
#define BIT_LPQ_PUBLIC_DIS_V1_8822B BIT(17)
#define BIT_HPQ_PUBLIC_DIS_V1_8822B BIT(16)
/* 2 REG_FIFOPAGE_INFO_1_8822B */
#define BIT_SHIFT_HPQ_AVAL_PG_V1_8822B 16
#define BIT_MASK_HPQ_AVAL_PG_V1_8822B 0xfff
#define BIT_HPQ_AVAL_PG_V1_8822B(x) \
(((x) & BIT_MASK_HPQ_AVAL_PG_V1_8822B) \
<< BIT_SHIFT_HPQ_AVAL_PG_V1_8822B)
#define BITS_HPQ_AVAL_PG_V1_8822B \
(BIT_MASK_HPQ_AVAL_PG_V1_8822B << BIT_SHIFT_HPQ_AVAL_PG_V1_8822B)
#define BIT_CLEAR_HPQ_AVAL_PG_V1_8822B(x) ((x) & (~BITS_HPQ_AVAL_PG_V1_8822B))
#define BIT_GET_HPQ_AVAL_PG_V1_8822B(x) \
(((x) >> BIT_SHIFT_HPQ_AVAL_PG_V1_8822B) & \
BIT_MASK_HPQ_AVAL_PG_V1_8822B)
#define BIT_SET_HPQ_AVAL_PG_V1_8822B(x, v) \
(BIT_CLEAR_HPQ_AVAL_PG_V1_8822B(x) | BIT_HPQ_AVAL_PG_V1_8822B(v))
#define BIT_SHIFT_HPQ_V1_8822B 0
#define BIT_MASK_HPQ_V1_8822B 0xfff
#define BIT_HPQ_V1_8822B(x) \
(((x) & BIT_MASK_HPQ_V1_8822B) << BIT_SHIFT_HPQ_V1_8822B)
#define BITS_HPQ_V1_8822B (BIT_MASK_HPQ_V1_8822B << BIT_SHIFT_HPQ_V1_8822B)
#define BIT_CLEAR_HPQ_V1_8822B(x) ((x) & (~BITS_HPQ_V1_8822B))
#define BIT_GET_HPQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_HPQ_V1_8822B) & BIT_MASK_HPQ_V1_8822B)
#define BIT_SET_HPQ_V1_8822B(x, v) \
(BIT_CLEAR_HPQ_V1_8822B(x) | BIT_HPQ_V1_8822B(v))
/* 2 REG_FIFOPAGE_INFO_2_8822B */
#define BIT_SHIFT_LPQ_AVAL_PG_V1_8822B 16
#define BIT_MASK_LPQ_AVAL_PG_V1_8822B 0xfff
#define BIT_LPQ_AVAL_PG_V1_8822B(x) \
(((x) & BIT_MASK_LPQ_AVAL_PG_V1_8822B) \
<< BIT_SHIFT_LPQ_AVAL_PG_V1_8822B)
#define BITS_LPQ_AVAL_PG_V1_8822B \
(BIT_MASK_LPQ_AVAL_PG_V1_8822B << BIT_SHIFT_LPQ_AVAL_PG_V1_8822B)
#define BIT_CLEAR_LPQ_AVAL_PG_V1_8822B(x) ((x) & (~BITS_LPQ_AVAL_PG_V1_8822B))
#define BIT_GET_LPQ_AVAL_PG_V1_8822B(x) \
(((x) >> BIT_SHIFT_LPQ_AVAL_PG_V1_8822B) & \
BIT_MASK_LPQ_AVAL_PG_V1_8822B)
#define BIT_SET_LPQ_AVAL_PG_V1_8822B(x, v) \
(BIT_CLEAR_LPQ_AVAL_PG_V1_8822B(x) | BIT_LPQ_AVAL_PG_V1_8822B(v))
#define BIT_SHIFT_LPQ_V1_8822B 0
#define BIT_MASK_LPQ_V1_8822B 0xfff
#define BIT_LPQ_V1_8822B(x) \
(((x) & BIT_MASK_LPQ_V1_8822B) << BIT_SHIFT_LPQ_V1_8822B)
#define BITS_LPQ_V1_8822B (BIT_MASK_LPQ_V1_8822B << BIT_SHIFT_LPQ_V1_8822B)
#define BIT_CLEAR_LPQ_V1_8822B(x) ((x) & (~BITS_LPQ_V1_8822B))
#define BIT_GET_LPQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_LPQ_V1_8822B) & BIT_MASK_LPQ_V1_8822B)
#define BIT_SET_LPQ_V1_8822B(x, v) \
(BIT_CLEAR_LPQ_V1_8822B(x) | BIT_LPQ_V1_8822B(v))
/* 2 REG_FIFOPAGE_INFO_3_8822B */
#define BIT_SHIFT_NPQ_AVAL_PG_V1_8822B 16
#define BIT_MASK_NPQ_AVAL_PG_V1_8822B 0xfff
#define BIT_NPQ_AVAL_PG_V1_8822B(x) \
(((x) & BIT_MASK_NPQ_AVAL_PG_V1_8822B) \
<< BIT_SHIFT_NPQ_AVAL_PG_V1_8822B)
#define BITS_NPQ_AVAL_PG_V1_8822B \
(BIT_MASK_NPQ_AVAL_PG_V1_8822B << BIT_SHIFT_NPQ_AVAL_PG_V1_8822B)
#define BIT_CLEAR_NPQ_AVAL_PG_V1_8822B(x) ((x) & (~BITS_NPQ_AVAL_PG_V1_8822B))
#define BIT_GET_NPQ_AVAL_PG_V1_8822B(x) \
(((x) >> BIT_SHIFT_NPQ_AVAL_PG_V1_8822B) & \
BIT_MASK_NPQ_AVAL_PG_V1_8822B)
#define BIT_SET_NPQ_AVAL_PG_V1_8822B(x, v) \
(BIT_CLEAR_NPQ_AVAL_PG_V1_8822B(x) | BIT_NPQ_AVAL_PG_V1_8822B(v))
#define BIT_SHIFT_NPQ_V1_8822B 0
#define BIT_MASK_NPQ_V1_8822B 0xfff
#define BIT_NPQ_V1_8822B(x) \
(((x) & BIT_MASK_NPQ_V1_8822B) << BIT_SHIFT_NPQ_V1_8822B)
#define BITS_NPQ_V1_8822B (BIT_MASK_NPQ_V1_8822B << BIT_SHIFT_NPQ_V1_8822B)
#define BIT_CLEAR_NPQ_V1_8822B(x) ((x) & (~BITS_NPQ_V1_8822B))
#define BIT_GET_NPQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_NPQ_V1_8822B) & BIT_MASK_NPQ_V1_8822B)
#define BIT_SET_NPQ_V1_8822B(x, v) \
(BIT_CLEAR_NPQ_V1_8822B(x) | BIT_NPQ_V1_8822B(v))
/* 2 REG_FIFOPAGE_INFO_4_8822B */
#define BIT_SHIFT_EXQ_AVAL_PG_V1_8822B 16
#define BIT_MASK_EXQ_AVAL_PG_V1_8822B 0xfff
#define BIT_EXQ_AVAL_PG_V1_8822B(x) \
(((x) & BIT_MASK_EXQ_AVAL_PG_V1_8822B) \
<< BIT_SHIFT_EXQ_AVAL_PG_V1_8822B)
#define BITS_EXQ_AVAL_PG_V1_8822B \
(BIT_MASK_EXQ_AVAL_PG_V1_8822B << BIT_SHIFT_EXQ_AVAL_PG_V1_8822B)
#define BIT_CLEAR_EXQ_AVAL_PG_V1_8822B(x) ((x) & (~BITS_EXQ_AVAL_PG_V1_8822B))
#define BIT_GET_EXQ_AVAL_PG_V1_8822B(x) \
(((x) >> BIT_SHIFT_EXQ_AVAL_PG_V1_8822B) & \
BIT_MASK_EXQ_AVAL_PG_V1_8822B)
#define BIT_SET_EXQ_AVAL_PG_V1_8822B(x, v) \
(BIT_CLEAR_EXQ_AVAL_PG_V1_8822B(x) | BIT_EXQ_AVAL_PG_V1_8822B(v))
#define BIT_SHIFT_EXQ_V1_8822B 0
#define BIT_MASK_EXQ_V1_8822B 0xfff
#define BIT_EXQ_V1_8822B(x) \
(((x) & BIT_MASK_EXQ_V1_8822B) << BIT_SHIFT_EXQ_V1_8822B)
#define BITS_EXQ_V1_8822B (BIT_MASK_EXQ_V1_8822B << BIT_SHIFT_EXQ_V1_8822B)
#define BIT_CLEAR_EXQ_V1_8822B(x) ((x) & (~BITS_EXQ_V1_8822B))
#define BIT_GET_EXQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_EXQ_V1_8822B) & BIT_MASK_EXQ_V1_8822B)
#define BIT_SET_EXQ_V1_8822B(x, v) \
(BIT_CLEAR_EXQ_V1_8822B(x) | BIT_EXQ_V1_8822B(v))
/* 2 REG_FIFOPAGE_INFO_5_8822B */
#define BIT_SHIFT_PUBQ_AVAL_PG_V1_8822B 16
#define BIT_MASK_PUBQ_AVAL_PG_V1_8822B 0xfff
#define BIT_PUBQ_AVAL_PG_V1_8822B(x) \
(((x) & BIT_MASK_PUBQ_AVAL_PG_V1_8822B) \
<< BIT_SHIFT_PUBQ_AVAL_PG_V1_8822B)
#define BITS_PUBQ_AVAL_PG_V1_8822B \
(BIT_MASK_PUBQ_AVAL_PG_V1_8822B << BIT_SHIFT_PUBQ_AVAL_PG_V1_8822B)
#define BIT_CLEAR_PUBQ_AVAL_PG_V1_8822B(x) ((x) & (~BITS_PUBQ_AVAL_PG_V1_8822B))
#define BIT_GET_PUBQ_AVAL_PG_V1_8822B(x) \
(((x) >> BIT_SHIFT_PUBQ_AVAL_PG_V1_8822B) & \
BIT_MASK_PUBQ_AVAL_PG_V1_8822B)
#define BIT_SET_PUBQ_AVAL_PG_V1_8822B(x, v) \
(BIT_CLEAR_PUBQ_AVAL_PG_V1_8822B(x) | BIT_PUBQ_AVAL_PG_V1_8822B(v))
#define BIT_SHIFT_PUBQ_V1_8822B 0
#define BIT_MASK_PUBQ_V1_8822B 0xfff
#define BIT_PUBQ_V1_8822B(x) \
(((x) & BIT_MASK_PUBQ_V1_8822B) << BIT_SHIFT_PUBQ_V1_8822B)
#define BITS_PUBQ_V1_8822B (BIT_MASK_PUBQ_V1_8822B << BIT_SHIFT_PUBQ_V1_8822B)
#define BIT_CLEAR_PUBQ_V1_8822B(x) ((x) & (~BITS_PUBQ_V1_8822B))
#define BIT_GET_PUBQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_PUBQ_V1_8822B) & BIT_MASK_PUBQ_V1_8822B)
#define BIT_SET_PUBQ_V1_8822B(x, v) \
(BIT_CLEAR_PUBQ_V1_8822B(x) | BIT_PUBQ_V1_8822B(v))
/* 2 REG_H2C_HEAD_8822B */
#define BIT_SHIFT_H2C_HEAD_8822B 0
#define BIT_MASK_H2C_HEAD_8822B 0x3ffff
#define BIT_H2C_HEAD_8822B(x) \
(((x) & BIT_MASK_H2C_HEAD_8822B) << BIT_SHIFT_H2C_HEAD_8822B)
#define BITS_H2C_HEAD_8822B \
(BIT_MASK_H2C_HEAD_8822B << BIT_SHIFT_H2C_HEAD_8822B)
#define BIT_CLEAR_H2C_HEAD_8822B(x) ((x) & (~BITS_H2C_HEAD_8822B))
#define BIT_GET_H2C_HEAD_8822B(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_8822B) & BIT_MASK_H2C_HEAD_8822B)
#define BIT_SET_H2C_HEAD_8822B(x, v) \
(BIT_CLEAR_H2C_HEAD_8822B(x) | BIT_H2C_HEAD_8822B(v))
/* 2 REG_H2C_TAIL_8822B */
#define BIT_SHIFT_H2C_TAIL_8822B 0
#define BIT_MASK_H2C_TAIL_8822B 0x3ffff
#define BIT_H2C_TAIL_8822B(x) \
(((x) & BIT_MASK_H2C_TAIL_8822B) << BIT_SHIFT_H2C_TAIL_8822B)
#define BITS_H2C_TAIL_8822B \
(BIT_MASK_H2C_TAIL_8822B << BIT_SHIFT_H2C_TAIL_8822B)
#define BIT_CLEAR_H2C_TAIL_8822B(x) ((x) & (~BITS_H2C_TAIL_8822B))
#define BIT_GET_H2C_TAIL_8822B(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_8822B) & BIT_MASK_H2C_TAIL_8822B)
#define BIT_SET_H2C_TAIL_8822B(x, v) \
(BIT_CLEAR_H2C_TAIL_8822B(x) | BIT_H2C_TAIL_8822B(v))
/* 2 REG_H2C_READ_ADDR_8822B */
#define BIT_SHIFT_H2C_READ_ADDR_8822B 0
#define BIT_MASK_H2C_READ_ADDR_8822B 0x3ffff
#define BIT_H2C_READ_ADDR_8822B(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_8822B) << BIT_SHIFT_H2C_READ_ADDR_8822B)
#define BITS_H2C_READ_ADDR_8822B \
(BIT_MASK_H2C_READ_ADDR_8822B << BIT_SHIFT_H2C_READ_ADDR_8822B)
#define BIT_CLEAR_H2C_READ_ADDR_8822B(x) ((x) & (~BITS_H2C_READ_ADDR_8822B))
#define BIT_GET_H2C_READ_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_8822B) & BIT_MASK_H2C_READ_ADDR_8822B)
#define BIT_SET_H2C_READ_ADDR_8822B(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_8822B(x) | BIT_H2C_READ_ADDR_8822B(v))
/* 2 REG_H2C_WR_ADDR_8822B */
#define BIT_SHIFT_H2C_WR_ADDR_8822B 0
#define BIT_MASK_H2C_WR_ADDR_8822B 0x3ffff
#define BIT_H2C_WR_ADDR_8822B(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_8822B) << BIT_SHIFT_H2C_WR_ADDR_8822B)
#define BITS_H2C_WR_ADDR_8822B \
(BIT_MASK_H2C_WR_ADDR_8822B << BIT_SHIFT_H2C_WR_ADDR_8822B)
#define BIT_CLEAR_H2C_WR_ADDR_8822B(x) ((x) & (~BITS_H2C_WR_ADDR_8822B))
#define BIT_GET_H2C_WR_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_8822B) & BIT_MASK_H2C_WR_ADDR_8822B)
#define BIT_SET_H2C_WR_ADDR_8822B(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_8822B(x) | BIT_H2C_WR_ADDR_8822B(v))
/* 2 REG_H2C_INFO_8822B */
#define BIT_H2C_SPACE_VLD_8822B BIT(3)
#define BIT_H2C_WR_ADDR_RST_8822B BIT(2)
#define BIT_SHIFT_H2C_LEN_SEL_8822B 0
#define BIT_MASK_H2C_LEN_SEL_8822B 0x3
#define BIT_H2C_LEN_SEL_8822B(x) \
(((x) & BIT_MASK_H2C_LEN_SEL_8822B) << BIT_SHIFT_H2C_LEN_SEL_8822B)
#define BITS_H2C_LEN_SEL_8822B \
(BIT_MASK_H2C_LEN_SEL_8822B << BIT_SHIFT_H2C_LEN_SEL_8822B)
#define BIT_CLEAR_H2C_LEN_SEL_8822B(x) ((x) & (~BITS_H2C_LEN_SEL_8822B))
#define BIT_GET_H2C_LEN_SEL_8822B(x) \
(((x) >> BIT_SHIFT_H2C_LEN_SEL_8822B) & BIT_MASK_H2C_LEN_SEL_8822B)
#define BIT_SET_H2C_LEN_SEL_8822B(x, v) \
(BIT_CLEAR_H2C_LEN_SEL_8822B(x) | BIT_H2C_LEN_SEL_8822B(v))
/* 2 REG_RXDMA_AGG_PG_TH_8822B */
#define BIT_USB_RXDMA_AGG_EN_8822B BIT(31)
#define BIT_EN_PRE_CALC_8822B BIT(29)
#define BIT_RXAGG_SW_EN_8822B BIT(28)
#define BIT_RXAGG_SW_TRIG_8822B BIT(27)
#define BIT_SHIFT_PKT_NUM_WOL_8822B 16
#define BIT_MASK_PKT_NUM_WOL_8822B 0xff
#define BIT_PKT_NUM_WOL_8822B(x) \
(((x) & BIT_MASK_PKT_NUM_WOL_8822B) << BIT_SHIFT_PKT_NUM_WOL_8822B)
#define BITS_PKT_NUM_WOL_8822B \
(BIT_MASK_PKT_NUM_WOL_8822B << BIT_SHIFT_PKT_NUM_WOL_8822B)
#define BIT_CLEAR_PKT_NUM_WOL_8822B(x) ((x) & (~BITS_PKT_NUM_WOL_8822B))
#define BIT_GET_PKT_NUM_WOL_8822B(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL_8822B) & BIT_MASK_PKT_NUM_WOL_8822B)
#define BIT_SET_PKT_NUM_WOL_8822B(x, v) \
(BIT_CLEAR_PKT_NUM_WOL_8822B(x) | BIT_PKT_NUM_WOL_8822B(v))
#define BIT_SHIFT_DMA_AGG_TO_V1_8822B 8
#define BIT_MASK_DMA_AGG_TO_V1_8822B 0xff
#define BIT_DMA_AGG_TO_V1_8822B(x) \
(((x) & BIT_MASK_DMA_AGG_TO_V1_8822B) << BIT_SHIFT_DMA_AGG_TO_V1_8822B)
#define BITS_DMA_AGG_TO_V1_8822B \
(BIT_MASK_DMA_AGG_TO_V1_8822B << BIT_SHIFT_DMA_AGG_TO_V1_8822B)
#define BIT_CLEAR_DMA_AGG_TO_V1_8822B(x) ((x) & (~BITS_DMA_AGG_TO_V1_8822B))
#define BIT_GET_DMA_AGG_TO_V1_8822B(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO_V1_8822B) & BIT_MASK_DMA_AGG_TO_V1_8822B)
#define BIT_SET_DMA_AGG_TO_V1_8822B(x, v) \
(BIT_CLEAR_DMA_AGG_TO_V1_8822B(x) | BIT_DMA_AGG_TO_V1_8822B(v))
#define BIT_SHIFT_RXDMA_AGG_PG_TH_8822B 0
#define BIT_MASK_RXDMA_AGG_PG_TH_8822B 0xff
#define BIT_RXDMA_AGG_PG_TH_8822B(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_8822B) \
<< BIT_SHIFT_RXDMA_AGG_PG_TH_8822B)
#define BITS_RXDMA_AGG_PG_TH_8822B \
(BIT_MASK_RXDMA_AGG_PG_TH_8822B << BIT_SHIFT_RXDMA_AGG_PG_TH_8822B)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_8822B(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_8822B))
#define BIT_GET_RXDMA_AGG_PG_TH_8822B(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_8822B) & \
BIT_MASK_RXDMA_AGG_PG_TH_8822B)
#define BIT_SET_RXDMA_AGG_PG_TH_8822B(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_8822B(x) | BIT_RXDMA_AGG_PG_TH_8822B(v))
/* 2 REG_RXPKT_NUM_8822B */
#define BIT_SHIFT_RXPKT_NUM_8822B 24
#define BIT_MASK_RXPKT_NUM_8822B 0xff
#define BIT_RXPKT_NUM_8822B(x) \
(((x) & BIT_MASK_RXPKT_NUM_8822B) << BIT_SHIFT_RXPKT_NUM_8822B)
#define BITS_RXPKT_NUM_8822B \
(BIT_MASK_RXPKT_NUM_8822B << BIT_SHIFT_RXPKT_NUM_8822B)
#define BIT_CLEAR_RXPKT_NUM_8822B(x) ((x) & (~BITS_RXPKT_NUM_8822B))
#define BIT_GET_RXPKT_NUM_8822B(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_8822B) & BIT_MASK_RXPKT_NUM_8822B)
#define BIT_SET_RXPKT_NUM_8822B(x, v) \
(BIT_CLEAR_RXPKT_NUM_8822B(x) | BIT_RXPKT_NUM_8822B(v))
#define BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822B 20
#define BIT_MASK_FW_UPD_RDPTR19_TO_16_8822B 0xf
#define BIT_FW_UPD_RDPTR19_TO_16_8822B(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR19_TO_16_8822B) \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822B)
#define BITS_FW_UPD_RDPTR19_TO_16_8822B \
(BIT_MASK_FW_UPD_RDPTR19_TO_16_8822B \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822B)
#define BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8822B(x) \
((x) & (~BITS_FW_UPD_RDPTR19_TO_16_8822B))
#define BIT_GET_FW_UPD_RDPTR19_TO_16_8822B(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822B) & \
BIT_MASK_FW_UPD_RDPTR19_TO_16_8822B)
#define BIT_SET_FW_UPD_RDPTR19_TO_16_8822B(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8822B(x) | \
BIT_FW_UPD_RDPTR19_TO_16_8822B(v))
#define BIT_RXDMA_REQ_8822B BIT(19)
#define BIT_RW_RELEASE_EN_8822B BIT(18)
#define BIT_RXDMA_IDLE_8822B BIT(17)
#define BIT_RXPKT_RELEASE_POLL_8822B BIT(16)
#define BIT_SHIFT_FW_UPD_RDPTR_8822B 0
#define BIT_MASK_FW_UPD_RDPTR_8822B 0xffff
#define BIT_FW_UPD_RDPTR_8822B(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR_8822B) << BIT_SHIFT_FW_UPD_RDPTR_8822B)
#define BITS_FW_UPD_RDPTR_8822B \
(BIT_MASK_FW_UPD_RDPTR_8822B << BIT_SHIFT_FW_UPD_RDPTR_8822B)
#define BIT_CLEAR_FW_UPD_RDPTR_8822B(x) ((x) & (~BITS_FW_UPD_RDPTR_8822B))
#define BIT_GET_FW_UPD_RDPTR_8822B(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR_8822B) & BIT_MASK_FW_UPD_RDPTR_8822B)
#define BIT_SET_FW_UPD_RDPTR_8822B(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR_8822B(x) | BIT_FW_UPD_RDPTR_8822B(v))
/* 2 REG_RXDMA_STATUS_8822B */
#define BIT_C2H_PKT_OVF_8822B BIT(7)
#define BIT_AGG_CONFGI_ISSUE_8822B BIT(6)
#define BIT_FW_POLL_ISSUE_8822B BIT(5)
#define BIT_RX_DATA_UDN_8822B BIT(4)
#define BIT_RX_SFF_UDN_8822B BIT(3)
#define BIT_RX_SFF_OVF_8822B BIT(2)
#define BIT_RXPKT_OVF_8822B BIT(0)
/* 2 REG_RXDMA_DPR_8822B */
#define BIT_SHIFT_RDE_DEBUG_8822B 0
#define BIT_MASK_RDE_DEBUG_8822B 0xffffffffL
#define BIT_RDE_DEBUG_8822B(x) \
(((x) & BIT_MASK_RDE_DEBUG_8822B) << BIT_SHIFT_RDE_DEBUG_8822B)
#define BITS_RDE_DEBUG_8822B \
(BIT_MASK_RDE_DEBUG_8822B << BIT_SHIFT_RDE_DEBUG_8822B)
#define BIT_CLEAR_RDE_DEBUG_8822B(x) ((x) & (~BITS_RDE_DEBUG_8822B))
#define BIT_GET_RDE_DEBUG_8822B(x) \
(((x) >> BIT_SHIFT_RDE_DEBUG_8822B) & BIT_MASK_RDE_DEBUG_8822B)
#define BIT_SET_RDE_DEBUG_8822B(x, v) \
(BIT_CLEAR_RDE_DEBUG_8822B(x) | BIT_RDE_DEBUG_8822B(v))
/* 2 REG_RXDMA_MODE_8822B */
#define BIT_SHIFT_PKTNUM_TH_V2_8822B 24
#define BIT_MASK_PKTNUM_TH_V2_8822B 0x1f
#define BIT_PKTNUM_TH_V2_8822B(x) \
(((x) & BIT_MASK_PKTNUM_TH_V2_8822B) << BIT_SHIFT_PKTNUM_TH_V2_8822B)
#define BITS_PKTNUM_TH_V2_8822B \
(BIT_MASK_PKTNUM_TH_V2_8822B << BIT_SHIFT_PKTNUM_TH_V2_8822B)
#define BIT_CLEAR_PKTNUM_TH_V2_8822B(x) ((x) & (~BITS_PKTNUM_TH_V2_8822B))
#define BIT_GET_PKTNUM_TH_V2_8822B(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V2_8822B) & BIT_MASK_PKTNUM_TH_V2_8822B)
#define BIT_SET_PKTNUM_TH_V2_8822B(x, v) \
(BIT_CLEAR_PKTNUM_TH_V2_8822B(x) | BIT_PKTNUM_TH_V2_8822B(v))
#define BIT_TXBA_BREAK_USBAGG_8822B BIT(23)
#define BIT_SHIFT_PKTLEN_PARA_8822B 16
#define BIT_MASK_PKTLEN_PARA_8822B 0x7
#define BIT_PKTLEN_PARA_8822B(x) \
(((x) & BIT_MASK_PKTLEN_PARA_8822B) << BIT_SHIFT_PKTLEN_PARA_8822B)
#define BITS_PKTLEN_PARA_8822B \
(BIT_MASK_PKTLEN_PARA_8822B << BIT_SHIFT_PKTLEN_PARA_8822B)
#define BIT_CLEAR_PKTLEN_PARA_8822B(x) ((x) & (~BITS_PKTLEN_PARA_8822B))
#define BIT_GET_PKTLEN_PARA_8822B(x) \
(((x) >> BIT_SHIFT_PKTLEN_PARA_8822B) & BIT_MASK_PKTLEN_PARA_8822B)
#define BIT_SET_PKTLEN_PARA_8822B(x, v) \
(BIT_CLEAR_PKTLEN_PARA_8822B(x) | BIT_PKTLEN_PARA_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_BURST_SIZE_8822B 4
#define BIT_MASK_BURST_SIZE_8822B 0x3
#define BIT_BURST_SIZE_8822B(x) \
(((x) & BIT_MASK_BURST_SIZE_8822B) << BIT_SHIFT_BURST_SIZE_8822B)
#define BITS_BURST_SIZE_8822B \
(BIT_MASK_BURST_SIZE_8822B << BIT_SHIFT_BURST_SIZE_8822B)
#define BIT_CLEAR_BURST_SIZE_8822B(x) ((x) & (~BITS_BURST_SIZE_8822B))
#define BIT_GET_BURST_SIZE_8822B(x) \
(((x) >> BIT_SHIFT_BURST_SIZE_8822B) & BIT_MASK_BURST_SIZE_8822B)
#define BIT_SET_BURST_SIZE_8822B(x, v) \
(BIT_CLEAR_BURST_SIZE_8822B(x) | BIT_BURST_SIZE_8822B(v))
#define BIT_SHIFT_BURST_CNT_8822B 2
#define BIT_MASK_BURST_CNT_8822B 0x3
#define BIT_BURST_CNT_8822B(x) \
(((x) & BIT_MASK_BURST_CNT_8822B) << BIT_SHIFT_BURST_CNT_8822B)
#define BITS_BURST_CNT_8822B \
(BIT_MASK_BURST_CNT_8822B << BIT_SHIFT_BURST_CNT_8822B)
#define BIT_CLEAR_BURST_CNT_8822B(x) ((x) & (~BITS_BURST_CNT_8822B))
#define BIT_GET_BURST_CNT_8822B(x) \
(((x) >> BIT_SHIFT_BURST_CNT_8822B) & BIT_MASK_BURST_CNT_8822B)
#define BIT_SET_BURST_CNT_8822B(x, v) \
(BIT_CLEAR_BURST_CNT_8822B(x) | BIT_BURST_CNT_8822B(v))
#define BIT_DMA_MODE_8822B BIT(1)
/* 2 REG_C2H_PKT_8822B */
#define BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822B 24
#define BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822B 0xf
#define BIT_R_C2H_STR_ADDR_16_TO_19_8822B(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822B) \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822B)
#define BITS_R_C2H_STR_ADDR_16_TO_19_8822B \
(BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822B \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822B)
#define BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8822B(x) \
((x) & (~BITS_R_C2H_STR_ADDR_16_TO_19_8822B))
#define BIT_GET_R_C2H_STR_ADDR_16_TO_19_8822B(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822B) & \
BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822B)
#define BIT_SET_R_C2H_STR_ADDR_16_TO_19_8822B(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8822B(x) | \
BIT_R_C2H_STR_ADDR_16_TO_19_8822B(v))
#define BIT_R_C2H_PKT_REQ_8822B BIT(16)
#define BIT_SHIFT_R_C2H_STR_ADDR_8822B 0
#define BIT_MASK_R_C2H_STR_ADDR_8822B 0xffff
#define BIT_R_C2H_STR_ADDR_8822B(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_8822B) \
<< BIT_SHIFT_R_C2H_STR_ADDR_8822B)
#define BITS_R_C2H_STR_ADDR_8822B \
(BIT_MASK_R_C2H_STR_ADDR_8822B << BIT_SHIFT_R_C2H_STR_ADDR_8822B)
#define BIT_CLEAR_R_C2H_STR_ADDR_8822B(x) ((x) & (~BITS_R_C2H_STR_ADDR_8822B))
#define BIT_GET_R_C2H_STR_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_8822B) & \
BIT_MASK_R_C2H_STR_ADDR_8822B)
#define BIT_SET_R_C2H_STR_ADDR_8822B(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_8822B(x) | BIT_R_C2H_STR_ADDR_8822B(v))
/* 2 REG_FWFF_C2H_8822B */
#define BIT_SHIFT_C2H_DMA_ADDR_8822B 0
#define BIT_MASK_C2H_DMA_ADDR_8822B 0x3ffff
#define BIT_C2H_DMA_ADDR_8822B(x) \
(((x) & BIT_MASK_C2H_DMA_ADDR_8822B) << BIT_SHIFT_C2H_DMA_ADDR_8822B)
#define BITS_C2H_DMA_ADDR_8822B \
(BIT_MASK_C2H_DMA_ADDR_8822B << BIT_SHIFT_C2H_DMA_ADDR_8822B)
#define BIT_CLEAR_C2H_DMA_ADDR_8822B(x) ((x) & (~BITS_C2H_DMA_ADDR_8822B))
#define BIT_GET_C2H_DMA_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_C2H_DMA_ADDR_8822B) & BIT_MASK_C2H_DMA_ADDR_8822B)
#define BIT_SET_C2H_DMA_ADDR_8822B(x, v) \
(BIT_CLEAR_C2H_DMA_ADDR_8822B(x) | BIT_C2H_DMA_ADDR_8822B(v))
/* 2 REG_FWFF_CTRL_8822B */
#define BIT_FWFF_DMAPKT_REQ_8822B BIT(31)
#define BIT_SHIFT_FWFF_DMA_PKT_NUM_8822B 16
#define BIT_MASK_FWFF_DMA_PKT_NUM_8822B 0xff
#define BIT_FWFF_DMA_PKT_NUM_8822B(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM_8822B) \
<< BIT_SHIFT_FWFF_DMA_PKT_NUM_8822B)
#define BITS_FWFF_DMA_PKT_NUM_8822B \
(BIT_MASK_FWFF_DMA_PKT_NUM_8822B << BIT_SHIFT_FWFF_DMA_PKT_NUM_8822B)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM_8822B(x) \
((x) & (~BITS_FWFF_DMA_PKT_NUM_8822B))
#define BIT_GET_FWFF_DMA_PKT_NUM_8822B(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM_8822B) & \
BIT_MASK_FWFF_DMA_PKT_NUM_8822B)
#define BIT_SET_FWFF_DMA_PKT_NUM_8822B(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM_8822B(x) | BIT_FWFF_DMA_PKT_NUM_8822B(v))
#define BIT_SHIFT_FWFF_STR_ADDR_8822B 0
#define BIT_MASK_FWFF_STR_ADDR_8822B 0xffff
#define BIT_FWFF_STR_ADDR_8822B(x) \
(((x) & BIT_MASK_FWFF_STR_ADDR_8822B) << BIT_SHIFT_FWFF_STR_ADDR_8822B)
#define BITS_FWFF_STR_ADDR_8822B \
(BIT_MASK_FWFF_STR_ADDR_8822B << BIT_SHIFT_FWFF_STR_ADDR_8822B)
#define BIT_CLEAR_FWFF_STR_ADDR_8822B(x) ((x) & (~BITS_FWFF_STR_ADDR_8822B))
#define BIT_GET_FWFF_STR_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_FWFF_STR_ADDR_8822B) & BIT_MASK_FWFF_STR_ADDR_8822B)
#define BIT_SET_FWFF_STR_ADDR_8822B(x, v) \
(BIT_CLEAR_FWFF_STR_ADDR_8822B(x) | BIT_FWFF_STR_ADDR_8822B(v))
/* 2 REG_FWFF_PKT_INFO_8822B */
#define BIT_SHIFT_FWFF_PKT_QUEUED_8822B 16
#define BIT_MASK_FWFF_PKT_QUEUED_8822B 0xff
#define BIT_FWFF_PKT_QUEUED_8822B(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED_8822B) \
<< BIT_SHIFT_FWFF_PKT_QUEUED_8822B)
#define BITS_FWFF_PKT_QUEUED_8822B \
(BIT_MASK_FWFF_PKT_QUEUED_8822B << BIT_SHIFT_FWFF_PKT_QUEUED_8822B)
#define BIT_CLEAR_FWFF_PKT_QUEUED_8822B(x) ((x) & (~BITS_FWFF_PKT_QUEUED_8822B))
#define BIT_GET_FWFF_PKT_QUEUED_8822B(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED_8822B) & \
BIT_MASK_FWFF_PKT_QUEUED_8822B)
#define BIT_SET_FWFF_PKT_QUEUED_8822B(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED_8822B(x) | BIT_FWFF_PKT_QUEUED_8822B(v))
#define BIT_SHIFT_FWFF_PKT_STR_ADDR_8822B 0
#define BIT_MASK_FWFF_PKT_STR_ADDR_8822B 0xffff
#define BIT_FWFF_PKT_STR_ADDR_8822B(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR_8822B) \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_8822B)
#define BITS_FWFF_PKT_STR_ADDR_8822B \
(BIT_MASK_FWFF_PKT_STR_ADDR_8822B << BIT_SHIFT_FWFF_PKT_STR_ADDR_8822B)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR_8822B(x) \
((x) & (~BITS_FWFF_PKT_STR_ADDR_8822B))
#define BIT_GET_FWFF_PKT_STR_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR_8822B) & \
BIT_MASK_FWFF_PKT_STR_ADDR_8822B)
#define BIT_SET_FWFF_PKT_STR_ADDR_8822B(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR_8822B(x) | BIT_FWFF_PKT_STR_ADDR_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_DDMA_CH0SA_8822B */
#define BIT_SHIFT_DDMACH0_SA_8822B 0
#define BIT_MASK_DDMACH0_SA_8822B 0xffffffffL
#define BIT_DDMACH0_SA_8822B(x) \
(((x) & BIT_MASK_DDMACH0_SA_8822B) << BIT_SHIFT_DDMACH0_SA_8822B)
#define BITS_DDMACH0_SA_8822B \
(BIT_MASK_DDMACH0_SA_8822B << BIT_SHIFT_DDMACH0_SA_8822B)
#define BIT_CLEAR_DDMACH0_SA_8822B(x) ((x) & (~BITS_DDMACH0_SA_8822B))
#define BIT_GET_DDMACH0_SA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH0_SA_8822B) & BIT_MASK_DDMACH0_SA_8822B)
#define BIT_SET_DDMACH0_SA_8822B(x, v) \
(BIT_CLEAR_DDMACH0_SA_8822B(x) | BIT_DDMACH0_SA_8822B(v))
/* 2 REG_DDMA_CH0DA_8822B */
#define BIT_SHIFT_DDMACH0_DA_8822B 0
#define BIT_MASK_DDMACH0_DA_8822B 0xffffffffL
#define BIT_DDMACH0_DA_8822B(x) \
(((x) & BIT_MASK_DDMACH0_DA_8822B) << BIT_SHIFT_DDMACH0_DA_8822B)
#define BITS_DDMACH0_DA_8822B \
(BIT_MASK_DDMACH0_DA_8822B << BIT_SHIFT_DDMACH0_DA_8822B)
#define BIT_CLEAR_DDMACH0_DA_8822B(x) ((x) & (~BITS_DDMACH0_DA_8822B))
#define BIT_GET_DDMACH0_DA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH0_DA_8822B) & BIT_MASK_DDMACH0_DA_8822B)
#define BIT_SET_DDMACH0_DA_8822B(x, v) \
(BIT_CLEAR_DDMACH0_DA_8822B(x) | BIT_DDMACH0_DA_8822B(v))
/* 2 REG_DDMA_CH0CTRL_8822B */
#define BIT_DDMACH0_OWN_8822B BIT(31)
#define BIT_DDMACH0_IDMEM_ERR_8822B BIT(30)
#define BIT_DDMACH0_CHKSUM_EN_8822B BIT(29)
#define BIT_DDMACH0_DA_W_DISABLE_8822B BIT(28)
#define BIT_DDMACH0_CHKSUM_STS_8822B BIT(27)
#define BIT_DDMACH0_DDMA_MODE_8822B BIT(26)
#define BIT_DDMACH0_RESET_CHKSUM_STS_8822B BIT(25)
#define BIT_DDMACH0_CHKSUM_CONT_8822B BIT(24)
#define BIT_SHIFT_DDMACH0_DLEN_8822B 0
#define BIT_MASK_DDMACH0_DLEN_8822B 0x3ffff
#define BIT_DDMACH0_DLEN_8822B(x) \
(((x) & BIT_MASK_DDMACH0_DLEN_8822B) << BIT_SHIFT_DDMACH0_DLEN_8822B)
#define BITS_DDMACH0_DLEN_8822B \
(BIT_MASK_DDMACH0_DLEN_8822B << BIT_SHIFT_DDMACH0_DLEN_8822B)
#define BIT_CLEAR_DDMACH0_DLEN_8822B(x) ((x) & (~BITS_DDMACH0_DLEN_8822B))
#define BIT_GET_DDMACH0_DLEN_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH0_DLEN_8822B) & BIT_MASK_DDMACH0_DLEN_8822B)
#define BIT_SET_DDMACH0_DLEN_8822B(x, v) \
(BIT_CLEAR_DDMACH0_DLEN_8822B(x) | BIT_DDMACH0_DLEN_8822B(v))
/* 2 REG_DDMA_CH1SA_8822B */
#define BIT_SHIFT_DDMACH1_SA_8822B 0
#define BIT_MASK_DDMACH1_SA_8822B 0xffffffffL
#define BIT_DDMACH1_SA_8822B(x) \
(((x) & BIT_MASK_DDMACH1_SA_8822B) << BIT_SHIFT_DDMACH1_SA_8822B)
#define BITS_DDMACH1_SA_8822B \
(BIT_MASK_DDMACH1_SA_8822B << BIT_SHIFT_DDMACH1_SA_8822B)
#define BIT_CLEAR_DDMACH1_SA_8822B(x) ((x) & (~BITS_DDMACH1_SA_8822B))
#define BIT_GET_DDMACH1_SA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH1_SA_8822B) & BIT_MASK_DDMACH1_SA_8822B)
#define BIT_SET_DDMACH1_SA_8822B(x, v) \
(BIT_CLEAR_DDMACH1_SA_8822B(x) | BIT_DDMACH1_SA_8822B(v))
/* 2 REG_DDMA_CH1DA_8822B */
#define BIT_SHIFT_DDMACH1_DA_8822B 0
#define BIT_MASK_DDMACH1_DA_8822B 0xffffffffL
#define BIT_DDMACH1_DA_8822B(x) \
(((x) & BIT_MASK_DDMACH1_DA_8822B) << BIT_SHIFT_DDMACH1_DA_8822B)
#define BITS_DDMACH1_DA_8822B \
(BIT_MASK_DDMACH1_DA_8822B << BIT_SHIFT_DDMACH1_DA_8822B)
#define BIT_CLEAR_DDMACH1_DA_8822B(x) ((x) & (~BITS_DDMACH1_DA_8822B))
#define BIT_GET_DDMACH1_DA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH1_DA_8822B) & BIT_MASK_DDMACH1_DA_8822B)
#define BIT_SET_DDMACH1_DA_8822B(x, v) \
(BIT_CLEAR_DDMACH1_DA_8822B(x) | BIT_DDMACH1_DA_8822B(v))
/* 2 REG_DDMA_CH1CTRL_8822B */
#define BIT_DDMACH1_OWN_8822B BIT(31)
#define BIT_DDMACH1_IDMEM_ERR_8822B BIT(30)
#define BIT_DDMACH1_CHKSUM_EN_8822B BIT(29)
#define BIT_DDMACH1_DA_W_DISABLE_8822B BIT(28)
#define BIT_DDMACH1_CHKSUM_STS_8822B BIT(27)
#define BIT_DDMACH1_DDMA_MODE_8822B BIT(26)
#define BIT_DDMACH1_RESET_CHKSUM_STS_8822B BIT(25)
#define BIT_DDMACH1_CHKSUM_CONT_8822B BIT(24)
#define BIT_SHIFT_DDMACH1_DLEN_8822B 0
#define BIT_MASK_DDMACH1_DLEN_8822B 0x3ffff
#define BIT_DDMACH1_DLEN_8822B(x) \
(((x) & BIT_MASK_DDMACH1_DLEN_8822B) << BIT_SHIFT_DDMACH1_DLEN_8822B)
#define BITS_DDMACH1_DLEN_8822B \
(BIT_MASK_DDMACH1_DLEN_8822B << BIT_SHIFT_DDMACH1_DLEN_8822B)
#define BIT_CLEAR_DDMACH1_DLEN_8822B(x) ((x) & (~BITS_DDMACH1_DLEN_8822B))
#define BIT_GET_DDMACH1_DLEN_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH1_DLEN_8822B) & BIT_MASK_DDMACH1_DLEN_8822B)
#define BIT_SET_DDMACH1_DLEN_8822B(x, v) \
(BIT_CLEAR_DDMACH1_DLEN_8822B(x) | BIT_DDMACH1_DLEN_8822B(v))
/* 2 REG_DDMA_CH2SA_8822B */
#define BIT_SHIFT_DDMACH2_SA_8822B 0
#define BIT_MASK_DDMACH2_SA_8822B 0xffffffffL
#define BIT_DDMACH2_SA_8822B(x) \
(((x) & BIT_MASK_DDMACH2_SA_8822B) << BIT_SHIFT_DDMACH2_SA_8822B)
#define BITS_DDMACH2_SA_8822B \
(BIT_MASK_DDMACH2_SA_8822B << BIT_SHIFT_DDMACH2_SA_8822B)
#define BIT_CLEAR_DDMACH2_SA_8822B(x) ((x) & (~BITS_DDMACH2_SA_8822B))
#define BIT_GET_DDMACH2_SA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH2_SA_8822B) & BIT_MASK_DDMACH2_SA_8822B)
#define BIT_SET_DDMACH2_SA_8822B(x, v) \
(BIT_CLEAR_DDMACH2_SA_8822B(x) | BIT_DDMACH2_SA_8822B(v))
/* 2 REG_DDMA_CH2DA_8822B */
#define BIT_SHIFT_DDMACH2_DA_8822B 0
#define BIT_MASK_DDMACH2_DA_8822B 0xffffffffL
#define BIT_DDMACH2_DA_8822B(x) \
(((x) & BIT_MASK_DDMACH2_DA_8822B) << BIT_SHIFT_DDMACH2_DA_8822B)
#define BITS_DDMACH2_DA_8822B \
(BIT_MASK_DDMACH2_DA_8822B << BIT_SHIFT_DDMACH2_DA_8822B)
#define BIT_CLEAR_DDMACH2_DA_8822B(x) ((x) & (~BITS_DDMACH2_DA_8822B))
#define BIT_GET_DDMACH2_DA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH2_DA_8822B) & BIT_MASK_DDMACH2_DA_8822B)
#define BIT_SET_DDMACH2_DA_8822B(x, v) \
(BIT_CLEAR_DDMACH2_DA_8822B(x) | BIT_DDMACH2_DA_8822B(v))
/* 2 REG_DDMA_CH2CTRL_8822B */
#define BIT_DDMACH2_OWN_8822B BIT(31)
#define BIT_DDMACH2_IDMEM_ERR_8822B BIT(30)
#define BIT_DDMACH2_CHKSUM_EN_8822B BIT(29)
#define BIT_DDMACH2_DA_W_DISABLE_8822B BIT(28)
#define BIT_DDMACH2_CHKSUM_STS_8822B BIT(27)
#define BIT_DDMACH2_DDMA_MODE_8822B BIT(26)
#define BIT_DDMACH2_RESET_CHKSUM_STS_8822B BIT(25)
#define BIT_DDMACH2_CHKSUM_CONT_8822B BIT(24)
#define BIT_SHIFT_DDMACH2_DLEN_8822B 0
#define BIT_MASK_DDMACH2_DLEN_8822B 0x3ffff
#define BIT_DDMACH2_DLEN_8822B(x) \
(((x) & BIT_MASK_DDMACH2_DLEN_8822B) << BIT_SHIFT_DDMACH2_DLEN_8822B)
#define BITS_DDMACH2_DLEN_8822B \
(BIT_MASK_DDMACH2_DLEN_8822B << BIT_SHIFT_DDMACH2_DLEN_8822B)
#define BIT_CLEAR_DDMACH2_DLEN_8822B(x) ((x) & (~BITS_DDMACH2_DLEN_8822B))
#define BIT_GET_DDMACH2_DLEN_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH2_DLEN_8822B) & BIT_MASK_DDMACH2_DLEN_8822B)
#define BIT_SET_DDMACH2_DLEN_8822B(x, v) \
(BIT_CLEAR_DDMACH2_DLEN_8822B(x) | BIT_DDMACH2_DLEN_8822B(v))
/* 2 REG_DDMA_CH3SA_8822B */
#define BIT_SHIFT_DDMACH3_SA_8822B 0
#define BIT_MASK_DDMACH3_SA_8822B 0xffffffffL
#define BIT_DDMACH3_SA_8822B(x) \
(((x) & BIT_MASK_DDMACH3_SA_8822B) << BIT_SHIFT_DDMACH3_SA_8822B)
#define BITS_DDMACH3_SA_8822B \
(BIT_MASK_DDMACH3_SA_8822B << BIT_SHIFT_DDMACH3_SA_8822B)
#define BIT_CLEAR_DDMACH3_SA_8822B(x) ((x) & (~BITS_DDMACH3_SA_8822B))
#define BIT_GET_DDMACH3_SA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH3_SA_8822B) & BIT_MASK_DDMACH3_SA_8822B)
#define BIT_SET_DDMACH3_SA_8822B(x, v) \
(BIT_CLEAR_DDMACH3_SA_8822B(x) | BIT_DDMACH3_SA_8822B(v))
/* 2 REG_DDMA_CH3DA_8822B */
#define BIT_SHIFT_DDMACH3_DA_8822B 0
#define BIT_MASK_DDMACH3_DA_8822B 0xffffffffL
#define BIT_DDMACH3_DA_8822B(x) \
(((x) & BIT_MASK_DDMACH3_DA_8822B) << BIT_SHIFT_DDMACH3_DA_8822B)
#define BITS_DDMACH3_DA_8822B \
(BIT_MASK_DDMACH3_DA_8822B << BIT_SHIFT_DDMACH3_DA_8822B)
#define BIT_CLEAR_DDMACH3_DA_8822B(x) ((x) & (~BITS_DDMACH3_DA_8822B))
#define BIT_GET_DDMACH3_DA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH3_DA_8822B) & BIT_MASK_DDMACH3_DA_8822B)
#define BIT_SET_DDMACH3_DA_8822B(x, v) \
(BIT_CLEAR_DDMACH3_DA_8822B(x) | BIT_DDMACH3_DA_8822B(v))
/* 2 REG_DDMA_CH3CTRL_8822B */
#define BIT_DDMACH3_OWN_8822B BIT(31)
#define BIT_DDMACH3_IDMEM_ERR_8822B BIT(30)
#define BIT_DDMACH3_CHKSUM_EN_8822B BIT(29)
#define BIT_DDMACH3_DA_W_DISABLE_8822B BIT(28)
#define BIT_DDMACH3_CHKSUM_STS_8822B BIT(27)
#define BIT_DDMACH3_DDMA_MODE_8822B BIT(26)
#define BIT_DDMACH3_RESET_CHKSUM_STS_8822B BIT(25)
#define BIT_DDMACH3_CHKSUM_CONT_8822B BIT(24)
#define BIT_SHIFT_DDMACH3_DLEN_8822B 0
#define BIT_MASK_DDMACH3_DLEN_8822B 0x3ffff
#define BIT_DDMACH3_DLEN_8822B(x) \
(((x) & BIT_MASK_DDMACH3_DLEN_8822B) << BIT_SHIFT_DDMACH3_DLEN_8822B)
#define BITS_DDMACH3_DLEN_8822B \
(BIT_MASK_DDMACH3_DLEN_8822B << BIT_SHIFT_DDMACH3_DLEN_8822B)
#define BIT_CLEAR_DDMACH3_DLEN_8822B(x) ((x) & (~BITS_DDMACH3_DLEN_8822B))
#define BIT_GET_DDMACH3_DLEN_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH3_DLEN_8822B) & BIT_MASK_DDMACH3_DLEN_8822B)
#define BIT_SET_DDMACH3_DLEN_8822B(x, v) \
(BIT_CLEAR_DDMACH3_DLEN_8822B(x) | BIT_DDMACH3_DLEN_8822B(v))
/* 2 REG_DDMA_CH4SA_8822B */
#define BIT_SHIFT_DDMACH4_SA_8822B 0
#define BIT_MASK_DDMACH4_SA_8822B 0xffffffffL
#define BIT_DDMACH4_SA_8822B(x) \
(((x) & BIT_MASK_DDMACH4_SA_8822B) << BIT_SHIFT_DDMACH4_SA_8822B)
#define BITS_DDMACH4_SA_8822B \
(BIT_MASK_DDMACH4_SA_8822B << BIT_SHIFT_DDMACH4_SA_8822B)
#define BIT_CLEAR_DDMACH4_SA_8822B(x) ((x) & (~BITS_DDMACH4_SA_8822B))
#define BIT_GET_DDMACH4_SA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH4_SA_8822B) & BIT_MASK_DDMACH4_SA_8822B)
#define BIT_SET_DDMACH4_SA_8822B(x, v) \
(BIT_CLEAR_DDMACH4_SA_8822B(x) | BIT_DDMACH4_SA_8822B(v))
/* 2 REG_DDMA_CH4DA_8822B */
#define BIT_SHIFT_DDMACH4_DA_8822B 0
#define BIT_MASK_DDMACH4_DA_8822B 0xffffffffL
#define BIT_DDMACH4_DA_8822B(x) \
(((x) & BIT_MASK_DDMACH4_DA_8822B) << BIT_SHIFT_DDMACH4_DA_8822B)
#define BITS_DDMACH4_DA_8822B \
(BIT_MASK_DDMACH4_DA_8822B << BIT_SHIFT_DDMACH4_DA_8822B)
#define BIT_CLEAR_DDMACH4_DA_8822B(x) ((x) & (~BITS_DDMACH4_DA_8822B))
#define BIT_GET_DDMACH4_DA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH4_DA_8822B) & BIT_MASK_DDMACH4_DA_8822B)
#define BIT_SET_DDMACH4_DA_8822B(x, v) \
(BIT_CLEAR_DDMACH4_DA_8822B(x) | BIT_DDMACH4_DA_8822B(v))
/* 2 REG_DDMA_CH4CTRL_8822B */
#define BIT_DDMACH4_OWN_8822B BIT(31)
#define BIT_DDMACH4_IDMEM_ERR_8822B BIT(30)
#define BIT_DDMACH4_CHKSUM_EN_8822B BIT(29)
#define BIT_DDMACH4_DA_W_DISABLE_8822B BIT(28)
#define BIT_DDMACH4_CHKSUM_STS_8822B BIT(27)
#define BIT_DDMACH4_DDMA_MODE_8822B BIT(26)
#define BIT_DDMACH4_RESET_CHKSUM_STS_8822B BIT(25)
#define BIT_DDMACH4_CHKSUM_CONT_8822B BIT(24)
#define BIT_SHIFT_DDMACH4_DLEN_8822B 0
#define BIT_MASK_DDMACH4_DLEN_8822B 0x3ffff
#define BIT_DDMACH4_DLEN_8822B(x) \
(((x) & BIT_MASK_DDMACH4_DLEN_8822B) << BIT_SHIFT_DDMACH4_DLEN_8822B)
#define BITS_DDMACH4_DLEN_8822B \
(BIT_MASK_DDMACH4_DLEN_8822B << BIT_SHIFT_DDMACH4_DLEN_8822B)
#define BIT_CLEAR_DDMACH4_DLEN_8822B(x) ((x) & (~BITS_DDMACH4_DLEN_8822B))
#define BIT_GET_DDMACH4_DLEN_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH4_DLEN_8822B) & BIT_MASK_DDMACH4_DLEN_8822B)
#define BIT_SET_DDMACH4_DLEN_8822B(x, v) \
(BIT_CLEAR_DDMACH4_DLEN_8822B(x) | BIT_DDMACH4_DLEN_8822B(v))
/* 2 REG_DDMA_CH5SA_8822B */
#define BIT_SHIFT_DDMACH5_SA_8822B 0
#define BIT_MASK_DDMACH5_SA_8822B 0xffffffffL
#define BIT_DDMACH5_SA_8822B(x) \
(((x) & BIT_MASK_DDMACH5_SA_8822B) << BIT_SHIFT_DDMACH5_SA_8822B)
#define BITS_DDMACH5_SA_8822B \
(BIT_MASK_DDMACH5_SA_8822B << BIT_SHIFT_DDMACH5_SA_8822B)
#define BIT_CLEAR_DDMACH5_SA_8822B(x) ((x) & (~BITS_DDMACH5_SA_8822B))
#define BIT_GET_DDMACH5_SA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH5_SA_8822B) & BIT_MASK_DDMACH5_SA_8822B)
#define BIT_SET_DDMACH5_SA_8822B(x, v) \
(BIT_CLEAR_DDMACH5_SA_8822B(x) | BIT_DDMACH5_SA_8822B(v))
/* 2 REG_DDMA_CH5DA_8822B */
#define BIT_SHIFT_DDMACH5_DA_8822B 0
#define BIT_MASK_DDMACH5_DA_8822B 0xffffffffL
#define BIT_DDMACH5_DA_8822B(x) \
(((x) & BIT_MASK_DDMACH5_DA_8822B) << BIT_SHIFT_DDMACH5_DA_8822B)
#define BITS_DDMACH5_DA_8822B \
(BIT_MASK_DDMACH5_DA_8822B << BIT_SHIFT_DDMACH5_DA_8822B)
#define BIT_CLEAR_DDMACH5_DA_8822B(x) ((x) & (~BITS_DDMACH5_DA_8822B))
#define BIT_GET_DDMACH5_DA_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH5_DA_8822B) & BIT_MASK_DDMACH5_DA_8822B)
#define BIT_SET_DDMACH5_DA_8822B(x, v) \
(BIT_CLEAR_DDMACH5_DA_8822B(x) | BIT_DDMACH5_DA_8822B(v))
/* 2 REG_REG_DDMA_CH5CTRL_8822B */
#define BIT_DDMACH5_OWN_8822B BIT(31)
#define BIT_DDMACH5_IDMEM_ERR_8822B BIT(30)
#define BIT_DDMACH5_CHKSUM_EN_8822B BIT(29)
#define BIT_DDMACH5_DA_W_DISABLE_8822B BIT(28)
#define BIT_DDMACH5_CHKSUM_STS_8822B BIT(27)
#define BIT_DDMACH5_DDMA_MODE_8822B BIT(26)
#define BIT_DDMACH5_RESET_CHKSUM_STS_8822B BIT(25)
#define BIT_DDMACH5_CHKSUM_CONT_8822B BIT(24)
#define BIT_SHIFT_DDMACH5_DLEN_8822B 0
#define BIT_MASK_DDMACH5_DLEN_8822B 0x3ffff
#define BIT_DDMACH5_DLEN_8822B(x) \
(((x) & BIT_MASK_DDMACH5_DLEN_8822B) << BIT_SHIFT_DDMACH5_DLEN_8822B)
#define BITS_DDMACH5_DLEN_8822B \
(BIT_MASK_DDMACH5_DLEN_8822B << BIT_SHIFT_DDMACH5_DLEN_8822B)
#define BIT_CLEAR_DDMACH5_DLEN_8822B(x) ((x) & (~BITS_DDMACH5_DLEN_8822B))
#define BIT_GET_DDMACH5_DLEN_8822B(x) \
(((x) >> BIT_SHIFT_DDMACH5_DLEN_8822B) & BIT_MASK_DDMACH5_DLEN_8822B)
#define BIT_SET_DDMACH5_DLEN_8822B(x, v) \
(BIT_CLEAR_DDMACH5_DLEN_8822B(x) | BIT_DDMACH5_DLEN_8822B(v))
/* 2 REG_DDMA_INT_MSK_8822B */
#define BIT_DDMACH5_MSK_8822B BIT(5)
#define BIT_DDMACH4_MSK_8822B BIT(4)
#define BIT_DDMACH3_MSK_8822B BIT(3)
#define BIT_DDMACH2_MSK_8822B BIT(2)
#define BIT_DDMACH1_MSK_8822B BIT(1)
#define BIT_DDMACH0_MSK_8822B BIT(0)
/* 2 REG_DDMA_CHSTATUS_8822B */
#define BIT_DDMACH5_BUSY_8822B BIT(5)
#define BIT_DDMACH4_BUSY_8822B BIT(4)
#define BIT_DDMACH3_BUSY_8822B BIT(3)
#define BIT_DDMACH2_BUSY_8822B BIT(2)
#define BIT_DDMACH1_BUSY_8822B BIT(1)
#define BIT_DDMACH0_BUSY_8822B BIT(0)
/* 2 REG_DDMA_CHKSUM_8822B */
#define BIT_SHIFT_IDDMA0_CHKSUM_8822B 0
#define BIT_MASK_IDDMA0_CHKSUM_8822B 0xffff
#define BIT_IDDMA0_CHKSUM_8822B(x) \
(((x) & BIT_MASK_IDDMA0_CHKSUM_8822B) << BIT_SHIFT_IDDMA0_CHKSUM_8822B)
#define BITS_IDDMA0_CHKSUM_8822B \
(BIT_MASK_IDDMA0_CHKSUM_8822B << BIT_SHIFT_IDDMA0_CHKSUM_8822B)
#define BIT_CLEAR_IDDMA0_CHKSUM_8822B(x) ((x) & (~BITS_IDDMA0_CHKSUM_8822B))
#define BIT_GET_IDDMA0_CHKSUM_8822B(x) \
(((x) >> BIT_SHIFT_IDDMA0_CHKSUM_8822B) & BIT_MASK_IDDMA0_CHKSUM_8822B)
#define BIT_SET_IDDMA0_CHKSUM_8822B(x, v) \
(BIT_CLEAR_IDDMA0_CHKSUM_8822B(x) | BIT_IDDMA0_CHKSUM_8822B(v))
/* 2 REG_DDMA_MONITOR_8822B */
#define BIT_IDDMA0_PERMU_UNDERFLOW_8822B BIT(14)
#define BIT_IDDMA0_FIFO_UNDERFLOW_8822B BIT(13)
#define BIT_IDDMA0_FIFO_OVERFLOW_8822B BIT(12)
#define BIT_CH5_ERR_8822B BIT(5)
#define BIT_CH4_ERR_8822B BIT(4)
#define BIT_CH3_ERR_8822B BIT(3)
#define BIT_CH2_ERR_8822B BIT(2)
#define BIT_CH1_ERR_8822B BIT(1)
#define BIT_CH0_ERR_8822B BIT(0)
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_PCIE_CTRL_8822B */
#define BIT_PCIEIO_PERSTB_SEL_8822B BIT(31)
#define BIT_SHIFT_PCIE_MAX_RXDMA_8822B 28
#define BIT_MASK_PCIE_MAX_RXDMA_8822B 0x7
#define BIT_PCIE_MAX_RXDMA_8822B(x) \
(((x) & BIT_MASK_PCIE_MAX_RXDMA_8822B) \
<< BIT_SHIFT_PCIE_MAX_RXDMA_8822B)
#define BITS_PCIE_MAX_RXDMA_8822B \
(BIT_MASK_PCIE_MAX_RXDMA_8822B << BIT_SHIFT_PCIE_MAX_RXDMA_8822B)
#define BIT_CLEAR_PCIE_MAX_RXDMA_8822B(x) ((x) & (~BITS_PCIE_MAX_RXDMA_8822B))
#define BIT_GET_PCIE_MAX_RXDMA_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_RXDMA_8822B) & \
BIT_MASK_PCIE_MAX_RXDMA_8822B)
#define BIT_SET_PCIE_MAX_RXDMA_8822B(x, v) \
(BIT_CLEAR_PCIE_MAX_RXDMA_8822B(x) | BIT_PCIE_MAX_RXDMA_8822B(v))
#define BIT_MULRW_8822B BIT(27)
#define BIT_SHIFT_PCIE_MAX_TXDMA_8822B 24
#define BIT_MASK_PCIE_MAX_TXDMA_8822B 0x7
#define BIT_PCIE_MAX_TXDMA_8822B(x) \
(((x) & BIT_MASK_PCIE_MAX_TXDMA_8822B) \
<< BIT_SHIFT_PCIE_MAX_TXDMA_8822B)
#define BITS_PCIE_MAX_TXDMA_8822B \
(BIT_MASK_PCIE_MAX_TXDMA_8822B << BIT_SHIFT_PCIE_MAX_TXDMA_8822B)
#define BIT_CLEAR_PCIE_MAX_TXDMA_8822B(x) ((x) & (~BITS_PCIE_MAX_TXDMA_8822B))
#define BIT_GET_PCIE_MAX_TXDMA_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_TXDMA_8822B) & \
BIT_MASK_PCIE_MAX_TXDMA_8822B)
#define BIT_SET_PCIE_MAX_TXDMA_8822B(x, v) \
(BIT_CLEAR_PCIE_MAX_TXDMA_8822B(x) | BIT_PCIE_MAX_TXDMA_8822B(v))
#define BIT_EN_CPL_TIMEOUT_PS_8822B BIT(22)
#define BIT_REG_TXDMA_FAIL_PS_8822B BIT(21)
#define BIT_PCIE_RST_TRXDMA_INTF_8822B BIT(20)
#define BIT_EN_HWENTR_L1_8822B BIT(19)
#define BIT_EN_ADV_CLKGATE_8822B BIT(18)
#define BIT_PCIE_EN_SWENT_L23_8822B BIT(17)
#define BIT_PCIE_EN_HWEXT_L1_8822B BIT(16)
#define BIT_RX_CLOSE_EN_8822B BIT(15)
#define BIT_STOP_BCNQ_8822B BIT(14)
#define BIT_STOP_MGQ_8822B BIT(13)
#define BIT_STOP_VOQ_8822B BIT(12)
#define BIT_STOP_VIQ_8822B BIT(11)
#define BIT_STOP_BEQ_8822B BIT(10)
#define BIT_STOP_BKQ_8822B BIT(9)
#define BIT_STOP_RXQ_8822B BIT(8)
#define BIT_STOP_HI7Q_8822B BIT(7)
#define BIT_STOP_HI6Q_8822B BIT(6)
#define BIT_STOP_HI5Q_8822B BIT(5)
#define BIT_STOP_HI4Q_8822B BIT(4)
#define BIT_STOP_HI3Q_8822B BIT(3)
#define BIT_STOP_HI2Q_8822B BIT(2)
#define BIT_STOP_HI1Q_8822B BIT(1)
#define BIT_STOP_HI0Q_8822B BIT(0)
/* 2 REG_INT_MIG_8822B */
#define BIT_SHIFT_TXTTIMER_MATCH_NUM_8822B 28
#define BIT_MASK_TXTTIMER_MATCH_NUM_8822B 0xf
#define BIT_TXTTIMER_MATCH_NUM_8822B(x) \
(((x) & BIT_MASK_TXTTIMER_MATCH_NUM_8822B) \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8822B)
#define BITS_TXTTIMER_MATCH_NUM_8822B \
(BIT_MASK_TXTTIMER_MATCH_NUM_8822B \
<< BIT_SHIFT_TXTTIMER_MATCH_NUM_8822B)
#define BIT_CLEAR_TXTTIMER_MATCH_NUM_8822B(x) \
((x) & (~BITS_TXTTIMER_MATCH_NUM_8822B))
#define BIT_GET_TXTTIMER_MATCH_NUM_8822B(x) \
(((x) >> BIT_SHIFT_TXTTIMER_MATCH_NUM_8822B) & \
BIT_MASK_TXTTIMER_MATCH_NUM_8822B)
#define BIT_SET_TXTTIMER_MATCH_NUM_8822B(x, v) \
(BIT_CLEAR_TXTTIMER_MATCH_NUM_8822B(x) | \
BIT_TXTTIMER_MATCH_NUM_8822B(v))
#define BIT_SHIFT_TXPKT_NUM_MATCH_8822B 24
#define BIT_MASK_TXPKT_NUM_MATCH_8822B 0xf
#define BIT_TXPKT_NUM_MATCH_8822B(x) \
(((x) & BIT_MASK_TXPKT_NUM_MATCH_8822B) \
<< BIT_SHIFT_TXPKT_NUM_MATCH_8822B)
#define BITS_TXPKT_NUM_MATCH_8822B \
(BIT_MASK_TXPKT_NUM_MATCH_8822B << BIT_SHIFT_TXPKT_NUM_MATCH_8822B)
#define BIT_CLEAR_TXPKT_NUM_MATCH_8822B(x) ((x) & (~BITS_TXPKT_NUM_MATCH_8822B))
#define BIT_GET_TXPKT_NUM_MATCH_8822B(x) \
(((x) >> BIT_SHIFT_TXPKT_NUM_MATCH_8822B) & \
BIT_MASK_TXPKT_NUM_MATCH_8822B)
#define BIT_SET_TXPKT_NUM_MATCH_8822B(x, v) \
(BIT_CLEAR_TXPKT_NUM_MATCH_8822B(x) | BIT_TXPKT_NUM_MATCH_8822B(v))
#define BIT_SHIFT_RXTTIMER_MATCH_NUM_8822B 20
#define BIT_MASK_RXTTIMER_MATCH_NUM_8822B 0xf
#define BIT_RXTTIMER_MATCH_NUM_8822B(x) \
(((x) & BIT_MASK_RXTTIMER_MATCH_NUM_8822B) \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8822B)
#define BITS_RXTTIMER_MATCH_NUM_8822B \
(BIT_MASK_RXTTIMER_MATCH_NUM_8822B \
<< BIT_SHIFT_RXTTIMER_MATCH_NUM_8822B)
#define BIT_CLEAR_RXTTIMER_MATCH_NUM_8822B(x) \
((x) & (~BITS_RXTTIMER_MATCH_NUM_8822B))
#define BIT_GET_RXTTIMER_MATCH_NUM_8822B(x) \
(((x) >> BIT_SHIFT_RXTTIMER_MATCH_NUM_8822B) & \
BIT_MASK_RXTTIMER_MATCH_NUM_8822B)
#define BIT_SET_RXTTIMER_MATCH_NUM_8822B(x, v) \
(BIT_CLEAR_RXTTIMER_MATCH_NUM_8822B(x) | \
BIT_RXTTIMER_MATCH_NUM_8822B(v))
#define BIT_SHIFT_RXPKT_NUM_MATCH_8822B 16
#define BIT_MASK_RXPKT_NUM_MATCH_8822B 0xf
#define BIT_RXPKT_NUM_MATCH_8822B(x) \
(((x) & BIT_MASK_RXPKT_NUM_MATCH_8822B) \
<< BIT_SHIFT_RXPKT_NUM_MATCH_8822B)
#define BITS_RXPKT_NUM_MATCH_8822B \
(BIT_MASK_RXPKT_NUM_MATCH_8822B << BIT_SHIFT_RXPKT_NUM_MATCH_8822B)
#define BIT_CLEAR_RXPKT_NUM_MATCH_8822B(x) ((x) & (~BITS_RXPKT_NUM_MATCH_8822B))
#define BIT_GET_RXPKT_NUM_MATCH_8822B(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_MATCH_8822B) & \
BIT_MASK_RXPKT_NUM_MATCH_8822B)
#define BIT_SET_RXPKT_NUM_MATCH_8822B(x, v) \
(BIT_CLEAR_RXPKT_NUM_MATCH_8822B(x) | BIT_RXPKT_NUM_MATCH_8822B(v))
#define BIT_SHIFT_MIGRATE_TIMER_8822B 0
#define BIT_MASK_MIGRATE_TIMER_8822B 0xffff
#define BIT_MIGRATE_TIMER_8822B(x) \
(((x) & BIT_MASK_MIGRATE_TIMER_8822B) << BIT_SHIFT_MIGRATE_TIMER_8822B)
#define BITS_MIGRATE_TIMER_8822B \
(BIT_MASK_MIGRATE_TIMER_8822B << BIT_SHIFT_MIGRATE_TIMER_8822B)
#define BIT_CLEAR_MIGRATE_TIMER_8822B(x) ((x) & (~BITS_MIGRATE_TIMER_8822B))
#define BIT_GET_MIGRATE_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_MIGRATE_TIMER_8822B) & BIT_MASK_MIGRATE_TIMER_8822B)
#define BIT_SET_MIGRATE_TIMER_8822B(x, v) \
(BIT_CLEAR_MIGRATE_TIMER_8822B(x) | BIT_MIGRATE_TIMER_8822B(v))
/* 2 REG_BCNQ_TXBD_DESA_8822B */
#define BIT_SHIFT_BCNQ_TXBD_DESA_8822B 0
#define BIT_MASK_BCNQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_BCNQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_BCNQ_TXBD_DESA_8822B) \
<< BIT_SHIFT_BCNQ_TXBD_DESA_8822B)
#define BITS_BCNQ_TXBD_DESA_8822B \
(BIT_MASK_BCNQ_TXBD_DESA_8822B << BIT_SHIFT_BCNQ_TXBD_DESA_8822B)
#define BIT_CLEAR_BCNQ_TXBD_DESA_8822B(x) ((x) & (~BITS_BCNQ_TXBD_DESA_8822B))
#define BIT_GET_BCNQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_BCNQ_TXBD_DESA_8822B) & \
BIT_MASK_BCNQ_TXBD_DESA_8822B)
#define BIT_SET_BCNQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_BCNQ_TXBD_DESA_8822B(x) | BIT_BCNQ_TXBD_DESA_8822B(v))
/* 2 REG_MGQ_TXBD_DESA_8822B */
#define BIT_SHIFT_MGQ_TXBD_DESA_8822B 0
#define BIT_MASK_MGQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_MGQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_MGQ_TXBD_DESA_8822B) << BIT_SHIFT_MGQ_TXBD_DESA_8822B)
#define BITS_MGQ_TXBD_DESA_8822B \
(BIT_MASK_MGQ_TXBD_DESA_8822B << BIT_SHIFT_MGQ_TXBD_DESA_8822B)
#define BIT_CLEAR_MGQ_TXBD_DESA_8822B(x) ((x) & (~BITS_MGQ_TXBD_DESA_8822B))
#define BIT_GET_MGQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_TXBD_DESA_8822B) & BIT_MASK_MGQ_TXBD_DESA_8822B)
#define BIT_SET_MGQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_MGQ_TXBD_DESA_8822B(x) | BIT_MGQ_TXBD_DESA_8822B(v))
/* 2 REG_VOQ_TXBD_DESA_8822B */
#define BIT_SHIFT_VOQ_TXBD_DESA_8822B 0
#define BIT_MASK_VOQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_VOQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_VOQ_TXBD_DESA_8822B) << BIT_SHIFT_VOQ_TXBD_DESA_8822B)
#define BITS_VOQ_TXBD_DESA_8822B \
(BIT_MASK_VOQ_TXBD_DESA_8822B << BIT_SHIFT_VOQ_TXBD_DESA_8822B)
#define BIT_CLEAR_VOQ_TXBD_DESA_8822B(x) ((x) & (~BITS_VOQ_TXBD_DESA_8822B))
#define BIT_GET_VOQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_VOQ_TXBD_DESA_8822B) & BIT_MASK_VOQ_TXBD_DESA_8822B)
#define BIT_SET_VOQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_VOQ_TXBD_DESA_8822B(x) | BIT_VOQ_TXBD_DESA_8822B(v))
/* 2 REG_VIQ_TXBD_DESA_8822B */
#define BIT_SHIFT_VIQ_TXBD_DESA_8822B 0
#define BIT_MASK_VIQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_VIQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_VIQ_TXBD_DESA_8822B) << BIT_SHIFT_VIQ_TXBD_DESA_8822B)
#define BITS_VIQ_TXBD_DESA_8822B \
(BIT_MASK_VIQ_TXBD_DESA_8822B << BIT_SHIFT_VIQ_TXBD_DESA_8822B)
#define BIT_CLEAR_VIQ_TXBD_DESA_8822B(x) ((x) & (~BITS_VIQ_TXBD_DESA_8822B))
#define BIT_GET_VIQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_VIQ_TXBD_DESA_8822B) & BIT_MASK_VIQ_TXBD_DESA_8822B)
#define BIT_SET_VIQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_VIQ_TXBD_DESA_8822B(x) | BIT_VIQ_TXBD_DESA_8822B(v))
/* 2 REG_BEQ_TXBD_DESA_8822B */
#define BIT_SHIFT_BEQ_TXBD_DESA_8822B 0
#define BIT_MASK_BEQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_BEQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_BEQ_TXBD_DESA_8822B) << BIT_SHIFT_BEQ_TXBD_DESA_8822B)
#define BITS_BEQ_TXBD_DESA_8822B \
(BIT_MASK_BEQ_TXBD_DESA_8822B << BIT_SHIFT_BEQ_TXBD_DESA_8822B)
#define BIT_CLEAR_BEQ_TXBD_DESA_8822B(x) ((x) & (~BITS_BEQ_TXBD_DESA_8822B))
#define BIT_GET_BEQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_BEQ_TXBD_DESA_8822B) & BIT_MASK_BEQ_TXBD_DESA_8822B)
#define BIT_SET_BEQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_BEQ_TXBD_DESA_8822B(x) | BIT_BEQ_TXBD_DESA_8822B(v))
/* 2 REG_BKQ_TXBD_DESA_8822B */
#define BIT_SHIFT_BKQ_TXBD_DESA_8822B 0
#define BIT_MASK_BKQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_BKQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_BKQ_TXBD_DESA_8822B) << BIT_SHIFT_BKQ_TXBD_DESA_8822B)
#define BITS_BKQ_TXBD_DESA_8822B \
(BIT_MASK_BKQ_TXBD_DESA_8822B << BIT_SHIFT_BKQ_TXBD_DESA_8822B)
#define BIT_CLEAR_BKQ_TXBD_DESA_8822B(x) ((x) & (~BITS_BKQ_TXBD_DESA_8822B))
#define BIT_GET_BKQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_BKQ_TXBD_DESA_8822B) & BIT_MASK_BKQ_TXBD_DESA_8822B)
#define BIT_SET_BKQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_BKQ_TXBD_DESA_8822B(x) | BIT_BKQ_TXBD_DESA_8822B(v))
/* 2 REG_RXQ_RXBD_DESA_8822B */
#define BIT_SHIFT_RXQ_RXBD_DESA_8822B 0
#define BIT_MASK_RXQ_RXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_RXQ_RXBD_DESA_8822B(x) \
(((x) & BIT_MASK_RXQ_RXBD_DESA_8822B) << BIT_SHIFT_RXQ_RXBD_DESA_8822B)
#define BITS_RXQ_RXBD_DESA_8822B \
(BIT_MASK_RXQ_RXBD_DESA_8822B << BIT_SHIFT_RXQ_RXBD_DESA_8822B)
#define BIT_CLEAR_RXQ_RXBD_DESA_8822B(x) ((x) & (~BITS_RXQ_RXBD_DESA_8822B))
#define BIT_GET_RXQ_RXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_RXQ_RXBD_DESA_8822B) & BIT_MASK_RXQ_RXBD_DESA_8822B)
#define BIT_SET_RXQ_RXBD_DESA_8822B(x, v) \
(BIT_CLEAR_RXQ_RXBD_DESA_8822B(x) | BIT_RXQ_RXBD_DESA_8822B(v))
/* 2 REG_HI0Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI0Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI0Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI0Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI0Q_TXBD_DESA_8822B)
#define BITS_HI0Q_TXBD_DESA_8822B \
(BIT_MASK_HI0Q_TXBD_DESA_8822B << BIT_SHIFT_HI0Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI0Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI0Q_TXBD_DESA_8822B))
#define BIT_GET_HI0Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_8822B) & \
BIT_MASK_HI0Q_TXBD_DESA_8822B)
#define BIT_SET_HI0Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_8822B(x) | BIT_HI0Q_TXBD_DESA_8822B(v))
/* 2 REG_HI1Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI1Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI1Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI1Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI1Q_TXBD_DESA_8822B)
#define BITS_HI1Q_TXBD_DESA_8822B \
(BIT_MASK_HI1Q_TXBD_DESA_8822B << BIT_SHIFT_HI1Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI1Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI1Q_TXBD_DESA_8822B))
#define BIT_GET_HI1Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_8822B) & \
BIT_MASK_HI1Q_TXBD_DESA_8822B)
#define BIT_SET_HI1Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_8822B(x) | BIT_HI1Q_TXBD_DESA_8822B(v))
/* 2 REG_HI2Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI2Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI2Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI2Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI2Q_TXBD_DESA_8822B)
#define BITS_HI2Q_TXBD_DESA_8822B \
(BIT_MASK_HI2Q_TXBD_DESA_8822B << BIT_SHIFT_HI2Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI2Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI2Q_TXBD_DESA_8822B))
#define BIT_GET_HI2Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_8822B) & \
BIT_MASK_HI2Q_TXBD_DESA_8822B)
#define BIT_SET_HI2Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_8822B(x) | BIT_HI2Q_TXBD_DESA_8822B(v))
/* 2 REG_HI3Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI3Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI3Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI3Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI3Q_TXBD_DESA_8822B)
#define BITS_HI3Q_TXBD_DESA_8822B \
(BIT_MASK_HI3Q_TXBD_DESA_8822B << BIT_SHIFT_HI3Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI3Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI3Q_TXBD_DESA_8822B))
#define BIT_GET_HI3Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_8822B) & \
BIT_MASK_HI3Q_TXBD_DESA_8822B)
#define BIT_SET_HI3Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_8822B(x) | BIT_HI3Q_TXBD_DESA_8822B(v))
/* 2 REG_HI4Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI4Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI4Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI4Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI4Q_TXBD_DESA_8822B)
#define BITS_HI4Q_TXBD_DESA_8822B \
(BIT_MASK_HI4Q_TXBD_DESA_8822B << BIT_SHIFT_HI4Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI4Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI4Q_TXBD_DESA_8822B))
#define BIT_GET_HI4Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_8822B) & \
BIT_MASK_HI4Q_TXBD_DESA_8822B)
#define BIT_SET_HI4Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_8822B(x) | BIT_HI4Q_TXBD_DESA_8822B(v))
/* 2 REG_HI5Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI5Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI5Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI5Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI5Q_TXBD_DESA_8822B)
#define BITS_HI5Q_TXBD_DESA_8822B \
(BIT_MASK_HI5Q_TXBD_DESA_8822B << BIT_SHIFT_HI5Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI5Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI5Q_TXBD_DESA_8822B))
#define BIT_GET_HI5Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_8822B) & \
BIT_MASK_HI5Q_TXBD_DESA_8822B)
#define BIT_SET_HI5Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_8822B(x) | BIT_HI5Q_TXBD_DESA_8822B(v))
/* 2 REG_HI6Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI6Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI6Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI6Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI6Q_TXBD_DESA_8822B)
#define BITS_HI6Q_TXBD_DESA_8822B \
(BIT_MASK_HI6Q_TXBD_DESA_8822B << BIT_SHIFT_HI6Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI6Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI6Q_TXBD_DESA_8822B))
#define BIT_GET_HI6Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_8822B) & \
BIT_MASK_HI6Q_TXBD_DESA_8822B)
#define BIT_SET_HI6Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_8822B(x) | BIT_HI6Q_TXBD_DESA_8822B(v))
/* 2 REG_HI7Q_TXBD_DESA_8822B */
#define BIT_SHIFT_HI7Q_TXBD_DESA_8822B 0
#define BIT_MASK_HI7Q_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_HI7Q_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_8822B) \
<< BIT_SHIFT_HI7Q_TXBD_DESA_8822B)
#define BITS_HI7Q_TXBD_DESA_8822B \
(BIT_MASK_HI7Q_TXBD_DESA_8822B << BIT_SHIFT_HI7Q_TXBD_DESA_8822B)
#define BIT_CLEAR_HI7Q_TXBD_DESA_8822B(x) ((x) & (~BITS_HI7Q_TXBD_DESA_8822B))
#define BIT_GET_HI7Q_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_8822B) & \
BIT_MASK_HI7Q_TXBD_DESA_8822B)
#define BIT_SET_HI7Q_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_8822B(x) | BIT_HI7Q_TXBD_DESA_8822B(v))
/* 2 REG_MGQ_TXBD_NUM_8822B */
#define BIT_PCIE_MGQ_FLAG_8822B BIT(14)
#define BIT_SHIFT_MGQ_DESC_MODE_8822B 12
#define BIT_MASK_MGQ_DESC_MODE_8822B 0x3
#define BIT_MGQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_MGQ_DESC_MODE_8822B) << BIT_SHIFT_MGQ_DESC_MODE_8822B)
#define BITS_MGQ_DESC_MODE_8822B \
(BIT_MASK_MGQ_DESC_MODE_8822B << BIT_SHIFT_MGQ_DESC_MODE_8822B)
#define BIT_CLEAR_MGQ_DESC_MODE_8822B(x) ((x) & (~BITS_MGQ_DESC_MODE_8822B))
#define BIT_GET_MGQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_MODE_8822B) & BIT_MASK_MGQ_DESC_MODE_8822B)
#define BIT_SET_MGQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_MGQ_DESC_MODE_8822B(x) | BIT_MGQ_DESC_MODE_8822B(v))
#define BIT_SHIFT_MGQ_DESC_NUM_8822B 0
#define BIT_MASK_MGQ_DESC_NUM_8822B 0xfff
#define BIT_MGQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_MGQ_DESC_NUM_8822B) << BIT_SHIFT_MGQ_DESC_NUM_8822B)
#define BITS_MGQ_DESC_NUM_8822B \
(BIT_MASK_MGQ_DESC_NUM_8822B << BIT_SHIFT_MGQ_DESC_NUM_8822B)
#define BIT_CLEAR_MGQ_DESC_NUM_8822B(x) ((x) & (~BITS_MGQ_DESC_NUM_8822B))
#define BIT_GET_MGQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_NUM_8822B) & BIT_MASK_MGQ_DESC_NUM_8822B)
#define BIT_SET_MGQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_MGQ_DESC_NUM_8822B(x) | BIT_MGQ_DESC_NUM_8822B(v))
/* 2 REG_RX_RXBD_NUM_8822B */
#define BIT_SYS_32_64_8822B BIT(15)
#define BIT_SHIFT_BCNQ_DESC_MODE_8822B 13
#define BIT_MASK_BCNQ_DESC_MODE_8822B 0x3
#define BIT_BCNQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_BCNQ_DESC_MODE_8822B) \
<< BIT_SHIFT_BCNQ_DESC_MODE_8822B)
#define BITS_BCNQ_DESC_MODE_8822B \
(BIT_MASK_BCNQ_DESC_MODE_8822B << BIT_SHIFT_BCNQ_DESC_MODE_8822B)
#define BIT_CLEAR_BCNQ_DESC_MODE_8822B(x) ((x) & (~BITS_BCNQ_DESC_MODE_8822B))
#define BIT_GET_BCNQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_BCNQ_DESC_MODE_8822B) & \
BIT_MASK_BCNQ_DESC_MODE_8822B)
#define BIT_SET_BCNQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_BCNQ_DESC_MODE_8822B(x) | BIT_BCNQ_DESC_MODE_8822B(v))
#define BIT_PCIE_BCNQ_FLAG_8822B BIT(12)
#define BIT_SHIFT_RXQ_DESC_NUM_8822B 0
#define BIT_MASK_RXQ_DESC_NUM_8822B 0xfff
#define BIT_RXQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_RXQ_DESC_NUM_8822B) << BIT_SHIFT_RXQ_DESC_NUM_8822B)
#define BITS_RXQ_DESC_NUM_8822B \
(BIT_MASK_RXQ_DESC_NUM_8822B << BIT_SHIFT_RXQ_DESC_NUM_8822B)
#define BIT_CLEAR_RXQ_DESC_NUM_8822B(x) ((x) & (~BITS_RXQ_DESC_NUM_8822B))
#define BIT_GET_RXQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_RXQ_DESC_NUM_8822B) & BIT_MASK_RXQ_DESC_NUM_8822B)
#define BIT_SET_RXQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_RXQ_DESC_NUM_8822B(x) | BIT_RXQ_DESC_NUM_8822B(v))
/* 2 REG_VOQ_TXBD_NUM_8822B */
#define BIT_PCIE_VOQ_FLAG_8822B BIT(14)
#define BIT_SHIFT_VOQ_DESC_MODE_8822B 12
#define BIT_MASK_VOQ_DESC_MODE_8822B 0x3
#define BIT_VOQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_VOQ_DESC_MODE_8822B) << BIT_SHIFT_VOQ_DESC_MODE_8822B)
#define BITS_VOQ_DESC_MODE_8822B \
(BIT_MASK_VOQ_DESC_MODE_8822B << BIT_SHIFT_VOQ_DESC_MODE_8822B)
#define BIT_CLEAR_VOQ_DESC_MODE_8822B(x) ((x) & (~BITS_VOQ_DESC_MODE_8822B))
#define BIT_GET_VOQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_MODE_8822B) & BIT_MASK_VOQ_DESC_MODE_8822B)
#define BIT_SET_VOQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_VOQ_DESC_MODE_8822B(x) | BIT_VOQ_DESC_MODE_8822B(v))
#define BIT_SHIFT_VOQ_DESC_NUM_8822B 0
#define BIT_MASK_VOQ_DESC_NUM_8822B 0xfff
#define BIT_VOQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_VOQ_DESC_NUM_8822B) << BIT_SHIFT_VOQ_DESC_NUM_8822B)
#define BITS_VOQ_DESC_NUM_8822B \
(BIT_MASK_VOQ_DESC_NUM_8822B << BIT_SHIFT_VOQ_DESC_NUM_8822B)
#define BIT_CLEAR_VOQ_DESC_NUM_8822B(x) ((x) & (~BITS_VOQ_DESC_NUM_8822B))
#define BIT_GET_VOQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_NUM_8822B) & BIT_MASK_VOQ_DESC_NUM_8822B)
#define BIT_SET_VOQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_VOQ_DESC_NUM_8822B(x) | BIT_VOQ_DESC_NUM_8822B(v))
/* 2 REG_VIQ_TXBD_NUM_8822B */
#define BIT_PCIE_VIQ_FLAG_8822B BIT(14)
#define BIT_SHIFT_VIQ_DESC_MODE_8822B 12
#define BIT_MASK_VIQ_DESC_MODE_8822B 0x3
#define BIT_VIQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_VIQ_DESC_MODE_8822B) << BIT_SHIFT_VIQ_DESC_MODE_8822B)
#define BITS_VIQ_DESC_MODE_8822B \
(BIT_MASK_VIQ_DESC_MODE_8822B << BIT_SHIFT_VIQ_DESC_MODE_8822B)
#define BIT_CLEAR_VIQ_DESC_MODE_8822B(x) ((x) & (~BITS_VIQ_DESC_MODE_8822B))
#define BIT_GET_VIQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_MODE_8822B) & BIT_MASK_VIQ_DESC_MODE_8822B)
#define BIT_SET_VIQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_VIQ_DESC_MODE_8822B(x) | BIT_VIQ_DESC_MODE_8822B(v))
#define BIT_SHIFT_VIQ_DESC_NUM_8822B 0
#define BIT_MASK_VIQ_DESC_NUM_8822B 0xfff
#define BIT_VIQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_VIQ_DESC_NUM_8822B) << BIT_SHIFT_VIQ_DESC_NUM_8822B)
#define BITS_VIQ_DESC_NUM_8822B \
(BIT_MASK_VIQ_DESC_NUM_8822B << BIT_SHIFT_VIQ_DESC_NUM_8822B)
#define BIT_CLEAR_VIQ_DESC_NUM_8822B(x) ((x) & (~BITS_VIQ_DESC_NUM_8822B))
#define BIT_GET_VIQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_NUM_8822B) & BIT_MASK_VIQ_DESC_NUM_8822B)
#define BIT_SET_VIQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_VIQ_DESC_NUM_8822B(x) | BIT_VIQ_DESC_NUM_8822B(v))
/* 2 REG_BEQ_TXBD_NUM_8822B */
#define BIT_PCIE_BEQ_FLAG_8822B BIT(14)
#define BIT_SHIFT_BEQ_DESC_MODE_8822B 12
#define BIT_MASK_BEQ_DESC_MODE_8822B 0x3
#define BIT_BEQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_BEQ_DESC_MODE_8822B) << BIT_SHIFT_BEQ_DESC_MODE_8822B)
#define BITS_BEQ_DESC_MODE_8822B \
(BIT_MASK_BEQ_DESC_MODE_8822B << BIT_SHIFT_BEQ_DESC_MODE_8822B)
#define BIT_CLEAR_BEQ_DESC_MODE_8822B(x) ((x) & (~BITS_BEQ_DESC_MODE_8822B))
#define BIT_GET_BEQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_MODE_8822B) & BIT_MASK_BEQ_DESC_MODE_8822B)
#define BIT_SET_BEQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_BEQ_DESC_MODE_8822B(x) | BIT_BEQ_DESC_MODE_8822B(v))
#define BIT_SHIFT_BEQ_DESC_NUM_8822B 0
#define BIT_MASK_BEQ_DESC_NUM_8822B 0xfff
#define BIT_BEQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_BEQ_DESC_NUM_8822B) << BIT_SHIFT_BEQ_DESC_NUM_8822B)
#define BITS_BEQ_DESC_NUM_8822B \
(BIT_MASK_BEQ_DESC_NUM_8822B << BIT_SHIFT_BEQ_DESC_NUM_8822B)
#define BIT_CLEAR_BEQ_DESC_NUM_8822B(x) ((x) & (~BITS_BEQ_DESC_NUM_8822B))
#define BIT_GET_BEQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_NUM_8822B) & BIT_MASK_BEQ_DESC_NUM_8822B)
#define BIT_SET_BEQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_BEQ_DESC_NUM_8822B(x) | BIT_BEQ_DESC_NUM_8822B(v))
/* 2 REG_BKQ_TXBD_NUM_8822B */
#define BIT_PCIE_BKQ_FLAG_8822B BIT(14)
#define BIT_SHIFT_BKQ_DESC_MODE_8822B 12
#define BIT_MASK_BKQ_DESC_MODE_8822B 0x3
#define BIT_BKQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_BKQ_DESC_MODE_8822B) << BIT_SHIFT_BKQ_DESC_MODE_8822B)
#define BITS_BKQ_DESC_MODE_8822B \
(BIT_MASK_BKQ_DESC_MODE_8822B << BIT_SHIFT_BKQ_DESC_MODE_8822B)
#define BIT_CLEAR_BKQ_DESC_MODE_8822B(x) ((x) & (~BITS_BKQ_DESC_MODE_8822B))
#define BIT_GET_BKQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_MODE_8822B) & BIT_MASK_BKQ_DESC_MODE_8822B)
#define BIT_SET_BKQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_BKQ_DESC_MODE_8822B(x) | BIT_BKQ_DESC_MODE_8822B(v))
#define BIT_SHIFT_BKQ_DESC_NUM_8822B 0
#define BIT_MASK_BKQ_DESC_NUM_8822B 0xfff
#define BIT_BKQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_BKQ_DESC_NUM_8822B) << BIT_SHIFT_BKQ_DESC_NUM_8822B)
#define BITS_BKQ_DESC_NUM_8822B \
(BIT_MASK_BKQ_DESC_NUM_8822B << BIT_SHIFT_BKQ_DESC_NUM_8822B)
#define BIT_CLEAR_BKQ_DESC_NUM_8822B(x) ((x) & (~BITS_BKQ_DESC_NUM_8822B))
#define BIT_GET_BKQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_NUM_8822B) & BIT_MASK_BKQ_DESC_NUM_8822B)
#define BIT_SET_BKQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_BKQ_DESC_NUM_8822B(x) | BIT_BKQ_DESC_NUM_8822B(v))
/* 2 REG_HI0Q_TXBD_NUM_8822B */
#define BIT_HI0Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI0Q_DESC_MODE_8822B 12
#define BIT_MASK_HI0Q_DESC_MODE_8822B 0x3
#define BIT_HI0Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI0Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI0Q_DESC_MODE_8822B)
#define BITS_HI0Q_DESC_MODE_8822B \
(BIT_MASK_HI0Q_DESC_MODE_8822B << BIT_SHIFT_HI0Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI0Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI0Q_DESC_MODE_8822B))
#define BIT_GET_HI0Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_MODE_8822B) & \
BIT_MASK_HI0Q_DESC_MODE_8822B)
#define BIT_SET_HI0Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI0Q_DESC_MODE_8822B(x) | BIT_HI0Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI0Q_DESC_NUM_8822B 0
#define BIT_MASK_HI0Q_DESC_NUM_8822B 0xfff
#define BIT_HI0Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI0Q_DESC_NUM_8822B) << BIT_SHIFT_HI0Q_DESC_NUM_8822B)
#define BITS_HI0Q_DESC_NUM_8822B \
(BIT_MASK_HI0Q_DESC_NUM_8822B << BIT_SHIFT_HI0Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI0Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI0Q_DESC_NUM_8822B))
#define BIT_GET_HI0Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_NUM_8822B) & BIT_MASK_HI0Q_DESC_NUM_8822B)
#define BIT_SET_HI0Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI0Q_DESC_NUM_8822B(x) | BIT_HI0Q_DESC_NUM_8822B(v))
/* 2 REG_HI1Q_TXBD_NUM_8822B */
#define BIT_HI1Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI1Q_DESC_MODE_8822B 12
#define BIT_MASK_HI1Q_DESC_MODE_8822B 0x3
#define BIT_HI1Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI1Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI1Q_DESC_MODE_8822B)
#define BITS_HI1Q_DESC_MODE_8822B \
(BIT_MASK_HI1Q_DESC_MODE_8822B << BIT_SHIFT_HI1Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI1Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI1Q_DESC_MODE_8822B))
#define BIT_GET_HI1Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_MODE_8822B) & \
BIT_MASK_HI1Q_DESC_MODE_8822B)
#define BIT_SET_HI1Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI1Q_DESC_MODE_8822B(x) | BIT_HI1Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI1Q_DESC_NUM_8822B 0
#define BIT_MASK_HI1Q_DESC_NUM_8822B 0xfff
#define BIT_HI1Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI1Q_DESC_NUM_8822B) << BIT_SHIFT_HI1Q_DESC_NUM_8822B)
#define BITS_HI1Q_DESC_NUM_8822B \
(BIT_MASK_HI1Q_DESC_NUM_8822B << BIT_SHIFT_HI1Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI1Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI1Q_DESC_NUM_8822B))
#define BIT_GET_HI1Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_NUM_8822B) & BIT_MASK_HI1Q_DESC_NUM_8822B)
#define BIT_SET_HI1Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI1Q_DESC_NUM_8822B(x) | BIT_HI1Q_DESC_NUM_8822B(v))
/* 2 REG_HI2Q_TXBD_NUM_8822B */
#define BIT_HI2Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI2Q_DESC_MODE_8822B 12
#define BIT_MASK_HI2Q_DESC_MODE_8822B 0x3
#define BIT_HI2Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI2Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI2Q_DESC_MODE_8822B)
#define BITS_HI2Q_DESC_MODE_8822B \
(BIT_MASK_HI2Q_DESC_MODE_8822B << BIT_SHIFT_HI2Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI2Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI2Q_DESC_MODE_8822B))
#define BIT_GET_HI2Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_MODE_8822B) & \
BIT_MASK_HI2Q_DESC_MODE_8822B)
#define BIT_SET_HI2Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI2Q_DESC_MODE_8822B(x) | BIT_HI2Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI2Q_DESC_NUM_8822B 0
#define BIT_MASK_HI2Q_DESC_NUM_8822B 0xfff
#define BIT_HI2Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI2Q_DESC_NUM_8822B) << BIT_SHIFT_HI2Q_DESC_NUM_8822B)
#define BITS_HI2Q_DESC_NUM_8822B \
(BIT_MASK_HI2Q_DESC_NUM_8822B << BIT_SHIFT_HI2Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI2Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI2Q_DESC_NUM_8822B))
#define BIT_GET_HI2Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_NUM_8822B) & BIT_MASK_HI2Q_DESC_NUM_8822B)
#define BIT_SET_HI2Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI2Q_DESC_NUM_8822B(x) | BIT_HI2Q_DESC_NUM_8822B(v))
/* 2 REG_HI3Q_TXBD_NUM_8822B */
#define BIT_HI3Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI3Q_DESC_MODE_8822B 12
#define BIT_MASK_HI3Q_DESC_MODE_8822B 0x3
#define BIT_HI3Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI3Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI3Q_DESC_MODE_8822B)
#define BITS_HI3Q_DESC_MODE_8822B \
(BIT_MASK_HI3Q_DESC_MODE_8822B << BIT_SHIFT_HI3Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI3Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI3Q_DESC_MODE_8822B))
#define BIT_GET_HI3Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_MODE_8822B) & \
BIT_MASK_HI3Q_DESC_MODE_8822B)
#define BIT_SET_HI3Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI3Q_DESC_MODE_8822B(x) | BIT_HI3Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI3Q_DESC_NUM_8822B 0
#define BIT_MASK_HI3Q_DESC_NUM_8822B 0xfff
#define BIT_HI3Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI3Q_DESC_NUM_8822B) << BIT_SHIFT_HI3Q_DESC_NUM_8822B)
#define BITS_HI3Q_DESC_NUM_8822B \
(BIT_MASK_HI3Q_DESC_NUM_8822B << BIT_SHIFT_HI3Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI3Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI3Q_DESC_NUM_8822B))
#define BIT_GET_HI3Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_NUM_8822B) & BIT_MASK_HI3Q_DESC_NUM_8822B)
#define BIT_SET_HI3Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI3Q_DESC_NUM_8822B(x) | BIT_HI3Q_DESC_NUM_8822B(v))
/* 2 REG_HI4Q_TXBD_NUM_8822B */
#define BIT_HI4Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI4Q_DESC_MODE_8822B 12
#define BIT_MASK_HI4Q_DESC_MODE_8822B 0x3
#define BIT_HI4Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI4Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI4Q_DESC_MODE_8822B)
#define BITS_HI4Q_DESC_MODE_8822B \
(BIT_MASK_HI4Q_DESC_MODE_8822B << BIT_SHIFT_HI4Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI4Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI4Q_DESC_MODE_8822B))
#define BIT_GET_HI4Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_MODE_8822B) & \
BIT_MASK_HI4Q_DESC_MODE_8822B)
#define BIT_SET_HI4Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI4Q_DESC_MODE_8822B(x) | BIT_HI4Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI4Q_DESC_NUM_8822B 0
#define BIT_MASK_HI4Q_DESC_NUM_8822B 0xfff
#define BIT_HI4Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI4Q_DESC_NUM_8822B) << BIT_SHIFT_HI4Q_DESC_NUM_8822B)
#define BITS_HI4Q_DESC_NUM_8822B \
(BIT_MASK_HI4Q_DESC_NUM_8822B << BIT_SHIFT_HI4Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI4Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI4Q_DESC_NUM_8822B))
#define BIT_GET_HI4Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_NUM_8822B) & BIT_MASK_HI4Q_DESC_NUM_8822B)
#define BIT_SET_HI4Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI4Q_DESC_NUM_8822B(x) | BIT_HI4Q_DESC_NUM_8822B(v))
/* 2 REG_HI5Q_TXBD_NUM_8822B */
#define BIT_HI5Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI5Q_DESC_MODE_8822B 12
#define BIT_MASK_HI5Q_DESC_MODE_8822B 0x3
#define BIT_HI5Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI5Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI5Q_DESC_MODE_8822B)
#define BITS_HI5Q_DESC_MODE_8822B \
(BIT_MASK_HI5Q_DESC_MODE_8822B << BIT_SHIFT_HI5Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI5Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI5Q_DESC_MODE_8822B))
#define BIT_GET_HI5Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_MODE_8822B) & \
BIT_MASK_HI5Q_DESC_MODE_8822B)
#define BIT_SET_HI5Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI5Q_DESC_MODE_8822B(x) | BIT_HI5Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI5Q_DESC_NUM_8822B 0
#define BIT_MASK_HI5Q_DESC_NUM_8822B 0xfff
#define BIT_HI5Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI5Q_DESC_NUM_8822B) << BIT_SHIFT_HI5Q_DESC_NUM_8822B)
#define BITS_HI5Q_DESC_NUM_8822B \
(BIT_MASK_HI5Q_DESC_NUM_8822B << BIT_SHIFT_HI5Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI5Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI5Q_DESC_NUM_8822B))
#define BIT_GET_HI5Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_NUM_8822B) & BIT_MASK_HI5Q_DESC_NUM_8822B)
#define BIT_SET_HI5Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI5Q_DESC_NUM_8822B(x) | BIT_HI5Q_DESC_NUM_8822B(v))
/* 2 REG_HI6Q_TXBD_NUM_8822B */
#define BIT_HI6Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI6Q_DESC_MODE_8822B 12
#define BIT_MASK_HI6Q_DESC_MODE_8822B 0x3
#define BIT_HI6Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI6Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI6Q_DESC_MODE_8822B)
#define BITS_HI6Q_DESC_MODE_8822B \
(BIT_MASK_HI6Q_DESC_MODE_8822B << BIT_SHIFT_HI6Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI6Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI6Q_DESC_MODE_8822B))
#define BIT_GET_HI6Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_MODE_8822B) & \
BIT_MASK_HI6Q_DESC_MODE_8822B)
#define BIT_SET_HI6Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI6Q_DESC_MODE_8822B(x) | BIT_HI6Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI6Q_DESC_NUM_8822B 0
#define BIT_MASK_HI6Q_DESC_NUM_8822B 0xfff
#define BIT_HI6Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI6Q_DESC_NUM_8822B) << BIT_SHIFT_HI6Q_DESC_NUM_8822B)
#define BITS_HI6Q_DESC_NUM_8822B \
(BIT_MASK_HI6Q_DESC_NUM_8822B << BIT_SHIFT_HI6Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI6Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI6Q_DESC_NUM_8822B))
#define BIT_GET_HI6Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_NUM_8822B) & BIT_MASK_HI6Q_DESC_NUM_8822B)
#define BIT_SET_HI6Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI6Q_DESC_NUM_8822B(x) | BIT_HI6Q_DESC_NUM_8822B(v))
/* 2 REG_HI7Q_TXBD_NUM_8822B */
#define BIT_HI7Q_FLAG_8822B BIT(14)
#define BIT_SHIFT_HI7Q_DESC_MODE_8822B 12
#define BIT_MASK_HI7Q_DESC_MODE_8822B 0x3
#define BIT_HI7Q_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_HI7Q_DESC_MODE_8822B) \
<< BIT_SHIFT_HI7Q_DESC_MODE_8822B)
#define BITS_HI7Q_DESC_MODE_8822B \
(BIT_MASK_HI7Q_DESC_MODE_8822B << BIT_SHIFT_HI7Q_DESC_MODE_8822B)
#define BIT_CLEAR_HI7Q_DESC_MODE_8822B(x) ((x) & (~BITS_HI7Q_DESC_MODE_8822B))
#define BIT_GET_HI7Q_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_MODE_8822B) & \
BIT_MASK_HI7Q_DESC_MODE_8822B)
#define BIT_SET_HI7Q_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_HI7Q_DESC_MODE_8822B(x) | BIT_HI7Q_DESC_MODE_8822B(v))
#define BIT_SHIFT_HI7Q_DESC_NUM_8822B 0
#define BIT_MASK_HI7Q_DESC_NUM_8822B 0xfff
#define BIT_HI7Q_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_HI7Q_DESC_NUM_8822B) << BIT_SHIFT_HI7Q_DESC_NUM_8822B)
#define BITS_HI7Q_DESC_NUM_8822B \
(BIT_MASK_HI7Q_DESC_NUM_8822B << BIT_SHIFT_HI7Q_DESC_NUM_8822B)
#define BIT_CLEAR_HI7Q_DESC_NUM_8822B(x) ((x) & (~BITS_HI7Q_DESC_NUM_8822B))
#define BIT_GET_HI7Q_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_NUM_8822B) & BIT_MASK_HI7Q_DESC_NUM_8822B)
#define BIT_SET_HI7Q_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_HI7Q_DESC_NUM_8822B(x) | BIT_HI7Q_DESC_NUM_8822B(v))
/* 2 REG_TSFTIMER_HCI_8822B */
#define BIT_SHIFT_TSFT2_HCI_8822B 16
#define BIT_MASK_TSFT2_HCI_8822B 0xffff
#define BIT_TSFT2_HCI_8822B(x) \
(((x) & BIT_MASK_TSFT2_HCI_8822B) << BIT_SHIFT_TSFT2_HCI_8822B)
#define BITS_TSFT2_HCI_8822B \
(BIT_MASK_TSFT2_HCI_8822B << BIT_SHIFT_TSFT2_HCI_8822B)
#define BIT_CLEAR_TSFT2_HCI_8822B(x) ((x) & (~BITS_TSFT2_HCI_8822B))
#define BIT_GET_TSFT2_HCI_8822B(x) \
(((x) >> BIT_SHIFT_TSFT2_HCI_8822B) & BIT_MASK_TSFT2_HCI_8822B)
#define BIT_SET_TSFT2_HCI_8822B(x, v) \
(BIT_CLEAR_TSFT2_HCI_8822B(x) | BIT_TSFT2_HCI_8822B(v))
#define BIT_SHIFT_TSFT1_HCI_8822B 0
#define BIT_MASK_TSFT1_HCI_8822B 0xffff
#define BIT_TSFT1_HCI_8822B(x) \
(((x) & BIT_MASK_TSFT1_HCI_8822B) << BIT_SHIFT_TSFT1_HCI_8822B)
#define BITS_TSFT1_HCI_8822B \
(BIT_MASK_TSFT1_HCI_8822B << BIT_SHIFT_TSFT1_HCI_8822B)
#define BIT_CLEAR_TSFT1_HCI_8822B(x) ((x) & (~BITS_TSFT1_HCI_8822B))
#define BIT_GET_TSFT1_HCI_8822B(x) \
(((x) >> BIT_SHIFT_TSFT1_HCI_8822B) & BIT_MASK_TSFT1_HCI_8822B)
#define BIT_SET_TSFT1_HCI_8822B(x, v) \
(BIT_CLEAR_TSFT1_HCI_8822B(x) | BIT_TSFT1_HCI_8822B(v))
/* 2 REG_BD_RWPTR_CLR_8822B */
#define BIT_CLR_HI7Q_HW_IDX_8822B BIT(29)
#define BIT_CLR_HI6Q_HW_IDX_8822B BIT(28)
#define BIT_CLR_HI5Q_HW_IDX_8822B BIT(27)
#define BIT_CLR_HI4Q_HW_IDX_8822B BIT(26)
#define BIT_CLR_HI3Q_HW_IDX_8822B BIT(25)
#define BIT_CLR_HI2Q_HW_IDX_8822B BIT(24)
#define BIT_CLR_HI1Q_HW_IDX_8822B BIT(23)
#define BIT_CLR_HI0Q_HW_IDX_8822B BIT(22)
#define BIT_CLR_BKQ_HW_IDX_8822B BIT(21)
#define BIT_CLR_BEQ_HW_IDX_8822B BIT(20)
#define BIT_CLR_VIQ_HW_IDX_8822B BIT(19)
#define BIT_CLR_VOQ_HW_IDX_8822B BIT(18)
#define BIT_CLR_MGQ_HW_IDX_8822B BIT(17)
#define BIT_CLR_RXQ_HW_IDX_8822B BIT(16)
#define BIT_CLR_HI7Q_HOST_IDX_8822B BIT(13)
#define BIT_CLR_HI6Q_HOST_IDX_8822B BIT(12)
#define BIT_CLR_HI5Q_HOST_IDX_8822B BIT(11)
#define BIT_CLR_HI4Q_HOST_IDX_8822B BIT(10)
#define BIT_CLR_HI3Q_HOST_IDX_8822B BIT(9)
#define BIT_CLR_HI2Q_HOST_IDX_8822B BIT(8)
#define BIT_CLR_HI1Q_HOST_IDX_8822B BIT(7)
#define BIT_CLR_HI0Q_HOST_IDX_8822B BIT(6)
#define BIT_CLR_BKQ_HOST_IDX_8822B BIT(5)
#define BIT_CLR_BEQ_HOST_IDX_8822B BIT(4)
#define BIT_CLR_VIQ_HOST_IDX_8822B BIT(3)
#define BIT_CLR_VOQ_HOST_IDX_8822B BIT(2)
#define BIT_CLR_MGQ_HOST_IDX_8822B BIT(1)
#define BIT_CLR_RXQ_HOST_IDX_8822B BIT(0)
/* 2 REG_VOQ_TXBD_IDX_8822B */
#define BIT_SHIFT_VOQ_HW_IDX_8822B 16
#define BIT_MASK_VOQ_HW_IDX_8822B 0xfff
#define BIT_VOQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_VOQ_HW_IDX_8822B) << BIT_SHIFT_VOQ_HW_IDX_8822B)
#define BITS_VOQ_HW_IDX_8822B \
(BIT_MASK_VOQ_HW_IDX_8822B << BIT_SHIFT_VOQ_HW_IDX_8822B)
#define BIT_CLEAR_VOQ_HW_IDX_8822B(x) ((x) & (~BITS_VOQ_HW_IDX_8822B))
#define BIT_GET_VOQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_VOQ_HW_IDX_8822B) & BIT_MASK_VOQ_HW_IDX_8822B)
#define BIT_SET_VOQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_VOQ_HW_IDX_8822B(x) | BIT_VOQ_HW_IDX_8822B(v))
#define BIT_SHIFT_VOQ_HOST_IDX_8822B 0
#define BIT_MASK_VOQ_HOST_IDX_8822B 0xfff
#define BIT_VOQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_VOQ_HOST_IDX_8822B) << BIT_SHIFT_VOQ_HOST_IDX_8822B)
#define BITS_VOQ_HOST_IDX_8822B \
(BIT_MASK_VOQ_HOST_IDX_8822B << BIT_SHIFT_VOQ_HOST_IDX_8822B)
#define BIT_CLEAR_VOQ_HOST_IDX_8822B(x) ((x) & (~BITS_VOQ_HOST_IDX_8822B))
#define BIT_GET_VOQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_VOQ_HOST_IDX_8822B) & BIT_MASK_VOQ_HOST_IDX_8822B)
#define BIT_SET_VOQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_VOQ_HOST_IDX_8822B(x) | BIT_VOQ_HOST_IDX_8822B(v))
/* 2 REG_VIQ_TXBD_IDX_8822B */
#define BIT_SHIFT_VIQ_HW_IDX_8822B 16
#define BIT_MASK_VIQ_HW_IDX_8822B 0xfff
#define BIT_VIQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_VIQ_HW_IDX_8822B) << BIT_SHIFT_VIQ_HW_IDX_8822B)
#define BITS_VIQ_HW_IDX_8822B \
(BIT_MASK_VIQ_HW_IDX_8822B << BIT_SHIFT_VIQ_HW_IDX_8822B)
#define BIT_CLEAR_VIQ_HW_IDX_8822B(x) ((x) & (~BITS_VIQ_HW_IDX_8822B))
#define BIT_GET_VIQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_VIQ_HW_IDX_8822B) & BIT_MASK_VIQ_HW_IDX_8822B)
#define BIT_SET_VIQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_VIQ_HW_IDX_8822B(x) | BIT_VIQ_HW_IDX_8822B(v))
#define BIT_SHIFT_VIQ_HOST_IDX_8822B 0
#define BIT_MASK_VIQ_HOST_IDX_8822B 0xfff
#define BIT_VIQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_VIQ_HOST_IDX_8822B) << BIT_SHIFT_VIQ_HOST_IDX_8822B)
#define BITS_VIQ_HOST_IDX_8822B \
(BIT_MASK_VIQ_HOST_IDX_8822B << BIT_SHIFT_VIQ_HOST_IDX_8822B)
#define BIT_CLEAR_VIQ_HOST_IDX_8822B(x) ((x) & (~BITS_VIQ_HOST_IDX_8822B))
#define BIT_GET_VIQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_VIQ_HOST_IDX_8822B) & BIT_MASK_VIQ_HOST_IDX_8822B)
#define BIT_SET_VIQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_VIQ_HOST_IDX_8822B(x) | BIT_VIQ_HOST_IDX_8822B(v))
/* 2 REG_BEQ_TXBD_IDX_8822B */
#define BIT_SHIFT_BEQ_HW_IDX_8822B 16
#define BIT_MASK_BEQ_HW_IDX_8822B 0xfff
#define BIT_BEQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_BEQ_HW_IDX_8822B) << BIT_SHIFT_BEQ_HW_IDX_8822B)
#define BITS_BEQ_HW_IDX_8822B \
(BIT_MASK_BEQ_HW_IDX_8822B << BIT_SHIFT_BEQ_HW_IDX_8822B)
#define BIT_CLEAR_BEQ_HW_IDX_8822B(x) ((x) & (~BITS_BEQ_HW_IDX_8822B))
#define BIT_GET_BEQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_BEQ_HW_IDX_8822B) & BIT_MASK_BEQ_HW_IDX_8822B)
#define BIT_SET_BEQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_BEQ_HW_IDX_8822B(x) | BIT_BEQ_HW_IDX_8822B(v))
#define BIT_SHIFT_BEQ_HOST_IDX_8822B 0
#define BIT_MASK_BEQ_HOST_IDX_8822B 0xfff
#define BIT_BEQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_BEQ_HOST_IDX_8822B) << BIT_SHIFT_BEQ_HOST_IDX_8822B)
#define BITS_BEQ_HOST_IDX_8822B \
(BIT_MASK_BEQ_HOST_IDX_8822B << BIT_SHIFT_BEQ_HOST_IDX_8822B)
#define BIT_CLEAR_BEQ_HOST_IDX_8822B(x) ((x) & (~BITS_BEQ_HOST_IDX_8822B))
#define BIT_GET_BEQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_BEQ_HOST_IDX_8822B) & BIT_MASK_BEQ_HOST_IDX_8822B)
#define BIT_SET_BEQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_BEQ_HOST_IDX_8822B(x) | BIT_BEQ_HOST_IDX_8822B(v))
/* 2 REG_BKQ_TXBD_IDX_8822B */
#define BIT_SHIFT_BKQ_HW_IDX_8822B 16
#define BIT_MASK_BKQ_HW_IDX_8822B 0xfff
#define BIT_BKQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_BKQ_HW_IDX_8822B) << BIT_SHIFT_BKQ_HW_IDX_8822B)
#define BITS_BKQ_HW_IDX_8822B \
(BIT_MASK_BKQ_HW_IDX_8822B << BIT_SHIFT_BKQ_HW_IDX_8822B)
#define BIT_CLEAR_BKQ_HW_IDX_8822B(x) ((x) & (~BITS_BKQ_HW_IDX_8822B))
#define BIT_GET_BKQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_BKQ_HW_IDX_8822B) & BIT_MASK_BKQ_HW_IDX_8822B)
#define BIT_SET_BKQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_BKQ_HW_IDX_8822B(x) | BIT_BKQ_HW_IDX_8822B(v))
#define BIT_SHIFT_BKQ_HOST_IDX_8822B 0
#define BIT_MASK_BKQ_HOST_IDX_8822B 0xfff
#define BIT_BKQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_BKQ_HOST_IDX_8822B) << BIT_SHIFT_BKQ_HOST_IDX_8822B)
#define BITS_BKQ_HOST_IDX_8822B \
(BIT_MASK_BKQ_HOST_IDX_8822B << BIT_SHIFT_BKQ_HOST_IDX_8822B)
#define BIT_CLEAR_BKQ_HOST_IDX_8822B(x) ((x) & (~BITS_BKQ_HOST_IDX_8822B))
#define BIT_GET_BKQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_BKQ_HOST_IDX_8822B) & BIT_MASK_BKQ_HOST_IDX_8822B)
#define BIT_SET_BKQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_BKQ_HOST_IDX_8822B(x) | BIT_BKQ_HOST_IDX_8822B(v))
/* 2 REG_MGQ_TXBD_IDX_8822B */
#define BIT_SHIFT_MGQ_HW_IDX_8822B 16
#define BIT_MASK_MGQ_HW_IDX_8822B 0xfff
#define BIT_MGQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_MGQ_HW_IDX_8822B) << BIT_SHIFT_MGQ_HW_IDX_8822B)
#define BITS_MGQ_HW_IDX_8822B \
(BIT_MASK_MGQ_HW_IDX_8822B << BIT_SHIFT_MGQ_HW_IDX_8822B)
#define BIT_CLEAR_MGQ_HW_IDX_8822B(x) ((x) & (~BITS_MGQ_HW_IDX_8822B))
#define BIT_GET_MGQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_HW_IDX_8822B) & BIT_MASK_MGQ_HW_IDX_8822B)
#define BIT_SET_MGQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_MGQ_HW_IDX_8822B(x) | BIT_MGQ_HW_IDX_8822B(v))
#define BIT_SHIFT_MGQ_HOST_IDX_8822B 0
#define BIT_MASK_MGQ_HOST_IDX_8822B 0xfff
#define BIT_MGQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_MGQ_HOST_IDX_8822B) << BIT_SHIFT_MGQ_HOST_IDX_8822B)
#define BITS_MGQ_HOST_IDX_8822B \
(BIT_MASK_MGQ_HOST_IDX_8822B << BIT_SHIFT_MGQ_HOST_IDX_8822B)
#define BIT_CLEAR_MGQ_HOST_IDX_8822B(x) ((x) & (~BITS_MGQ_HOST_IDX_8822B))
#define BIT_GET_MGQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_HOST_IDX_8822B) & BIT_MASK_MGQ_HOST_IDX_8822B)
#define BIT_SET_MGQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_MGQ_HOST_IDX_8822B(x) | BIT_MGQ_HOST_IDX_8822B(v))
/* 2 REG_RXQ_RXBD_IDX_8822B */
#define BIT_SHIFT_RXQ_HW_IDX_8822B 16
#define BIT_MASK_RXQ_HW_IDX_8822B 0xfff
#define BIT_RXQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_RXQ_HW_IDX_8822B) << BIT_SHIFT_RXQ_HW_IDX_8822B)
#define BITS_RXQ_HW_IDX_8822B \
(BIT_MASK_RXQ_HW_IDX_8822B << BIT_SHIFT_RXQ_HW_IDX_8822B)
#define BIT_CLEAR_RXQ_HW_IDX_8822B(x) ((x) & (~BITS_RXQ_HW_IDX_8822B))
#define BIT_GET_RXQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RXQ_HW_IDX_8822B) & BIT_MASK_RXQ_HW_IDX_8822B)
#define BIT_SET_RXQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_RXQ_HW_IDX_8822B(x) | BIT_RXQ_HW_IDX_8822B(v))
#define BIT_SHIFT_RXQ_HOST_IDX_8822B 0
#define BIT_MASK_RXQ_HOST_IDX_8822B 0xfff
#define BIT_RXQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_RXQ_HOST_IDX_8822B) << BIT_SHIFT_RXQ_HOST_IDX_8822B)
#define BITS_RXQ_HOST_IDX_8822B \
(BIT_MASK_RXQ_HOST_IDX_8822B << BIT_SHIFT_RXQ_HOST_IDX_8822B)
#define BIT_CLEAR_RXQ_HOST_IDX_8822B(x) ((x) & (~BITS_RXQ_HOST_IDX_8822B))
#define BIT_GET_RXQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RXQ_HOST_IDX_8822B) & BIT_MASK_RXQ_HOST_IDX_8822B)
#define BIT_SET_RXQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_RXQ_HOST_IDX_8822B(x) | BIT_RXQ_HOST_IDX_8822B(v))
/* 2 REG_HI0Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI0Q_HW_IDX_8822B 16
#define BIT_MASK_HI0Q_HW_IDX_8822B 0xfff
#define BIT_HI0Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI0Q_HW_IDX_8822B) << BIT_SHIFT_HI0Q_HW_IDX_8822B)
#define BITS_HI0Q_HW_IDX_8822B \
(BIT_MASK_HI0Q_HW_IDX_8822B << BIT_SHIFT_HI0Q_HW_IDX_8822B)
#define BIT_CLEAR_HI0Q_HW_IDX_8822B(x) ((x) & (~BITS_HI0Q_HW_IDX_8822B))
#define BIT_GET_HI0Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI0Q_HW_IDX_8822B) & BIT_MASK_HI0Q_HW_IDX_8822B)
#define BIT_SET_HI0Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI0Q_HW_IDX_8822B(x) | BIT_HI0Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI0Q_HOST_IDX_8822B 0
#define BIT_MASK_HI0Q_HOST_IDX_8822B 0xfff
#define BIT_HI0Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI0Q_HOST_IDX_8822B) << BIT_SHIFT_HI0Q_HOST_IDX_8822B)
#define BITS_HI0Q_HOST_IDX_8822B \
(BIT_MASK_HI0Q_HOST_IDX_8822B << BIT_SHIFT_HI0Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI0Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI0Q_HOST_IDX_8822B))
#define BIT_GET_HI0Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI0Q_HOST_IDX_8822B) & BIT_MASK_HI0Q_HOST_IDX_8822B)
#define BIT_SET_HI0Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI0Q_HOST_IDX_8822B(x) | BIT_HI0Q_HOST_IDX_8822B(v))
/* 2 REG_HI1Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI1Q_HW_IDX_8822B 16
#define BIT_MASK_HI1Q_HW_IDX_8822B 0xfff
#define BIT_HI1Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI1Q_HW_IDX_8822B) << BIT_SHIFT_HI1Q_HW_IDX_8822B)
#define BITS_HI1Q_HW_IDX_8822B \
(BIT_MASK_HI1Q_HW_IDX_8822B << BIT_SHIFT_HI1Q_HW_IDX_8822B)
#define BIT_CLEAR_HI1Q_HW_IDX_8822B(x) ((x) & (~BITS_HI1Q_HW_IDX_8822B))
#define BIT_GET_HI1Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI1Q_HW_IDX_8822B) & BIT_MASK_HI1Q_HW_IDX_8822B)
#define BIT_SET_HI1Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI1Q_HW_IDX_8822B(x) | BIT_HI1Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI1Q_HOST_IDX_8822B 0
#define BIT_MASK_HI1Q_HOST_IDX_8822B 0xfff
#define BIT_HI1Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI1Q_HOST_IDX_8822B) << BIT_SHIFT_HI1Q_HOST_IDX_8822B)
#define BITS_HI1Q_HOST_IDX_8822B \
(BIT_MASK_HI1Q_HOST_IDX_8822B << BIT_SHIFT_HI1Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI1Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI1Q_HOST_IDX_8822B))
#define BIT_GET_HI1Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI1Q_HOST_IDX_8822B) & BIT_MASK_HI1Q_HOST_IDX_8822B)
#define BIT_SET_HI1Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI1Q_HOST_IDX_8822B(x) | BIT_HI1Q_HOST_IDX_8822B(v))
/* 2 REG_HI2Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI2Q_HW_IDX_8822B 16
#define BIT_MASK_HI2Q_HW_IDX_8822B 0xfff
#define BIT_HI2Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI2Q_HW_IDX_8822B) << BIT_SHIFT_HI2Q_HW_IDX_8822B)
#define BITS_HI2Q_HW_IDX_8822B \
(BIT_MASK_HI2Q_HW_IDX_8822B << BIT_SHIFT_HI2Q_HW_IDX_8822B)
#define BIT_CLEAR_HI2Q_HW_IDX_8822B(x) ((x) & (~BITS_HI2Q_HW_IDX_8822B))
#define BIT_GET_HI2Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI2Q_HW_IDX_8822B) & BIT_MASK_HI2Q_HW_IDX_8822B)
#define BIT_SET_HI2Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI2Q_HW_IDX_8822B(x) | BIT_HI2Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI2Q_HOST_IDX_8822B 0
#define BIT_MASK_HI2Q_HOST_IDX_8822B 0xfff
#define BIT_HI2Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI2Q_HOST_IDX_8822B) << BIT_SHIFT_HI2Q_HOST_IDX_8822B)
#define BITS_HI2Q_HOST_IDX_8822B \
(BIT_MASK_HI2Q_HOST_IDX_8822B << BIT_SHIFT_HI2Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI2Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI2Q_HOST_IDX_8822B))
#define BIT_GET_HI2Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI2Q_HOST_IDX_8822B) & BIT_MASK_HI2Q_HOST_IDX_8822B)
#define BIT_SET_HI2Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI2Q_HOST_IDX_8822B(x) | BIT_HI2Q_HOST_IDX_8822B(v))
/* 2 REG_HI3Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI3Q_HW_IDX_8822B 16
#define BIT_MASK_HI3Q_HW_IDX_8822B 0xfff
#define BIT_HI3Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI3Q_HW_IDX_8822B) << BIT_SHIFT_HI3Q_HW_IDX_8822B)
#define BITS_HI3Q_HW_IDX_8822B \
(BIT_MASK_HI3Q_HW_IDX_8822B << BIT_SHIFT_HI3Q_HW_IDX_8822B)
#define BIT_CLEAR_HI3Q_HW_IDX_8822B(x) ((x) & (~BITS_HI3Q_HW_IDX_8822B))
#define BIT_GET_HI3Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI3Q_HW_IDX_8822B) & BIT_MASK_HI3Q_HW_IDX_8822B)
#define BIT_SET_HI3Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI3Q_HW_IDX_8822B(x) | BIT_HI3Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI3Q_HOST_IDX_8822B 0
#define BIT_MASK_HI3Q_HOST_IDX_8822B 0xfff
#define BIT_HI3Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI3Q_HOST_IDX_8822B) << BIT_SHIFT_HI3Q_HOST_IDX_8822B)
#define BITS_HI3Q_HOST_IDX_8822B \
(BIT_MASK_HI3Q_HOST_IDX_8822B << BIT_SHIFT_HI3Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI3Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI3Q_HOST_IDX_8822B))
#define BIT_GET_HI3Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI3Q_HOST_IDX_8822B) & BIT_MASK_HI3Q_HOST_IDX_8822B)
#define BIT_SET_HI3Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI3Q_HOST_IDX_8822B(x) | BIT_HI3Q_HOST_IDX_8822B(v))
/* 2 REG_HI4Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI4Q_HW_IDX_8822B 16
#define BIT_MASK_HI4Q_HW_IDX_8822B 0xfff
#define BIT_HI4Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI4Q_HW_IDX_8822B) << BIT_SHIFT_HI4Q_HW_IDX_8822B)
#define BITS_HI4Q_HW_IDX_8822B \
(BIT_MASK_HI4Q_HW_IDX_8822B << BIT_SHIFT_HI4Q_HW_IDX_8822B)
#define BIT_CLEAR_HI4Q_HW_IDX_8822B(x) ((x) & (~BITS_HI4Q_HW_IDX_8822B))
#define BIT_GET_HI4Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI4Q_HW_IDX_8822B) & BIT_MASK_HI4Q_HW_IDX_8822B)
#define BIT_SET_HI4Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI4Q_HW_IDX_8822B(x) | BIT_HI4Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI4Q_HOST_IDX_8822B 0
#define BIT_MASK_HI4Q_HOST_IDX_8822B 0xfff
#define BIT_HI4Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI4Q_HOST_IDX_8822B) << BIT_SHIFT_HI4Q_HOST_IDX_8822B)
#define BITS_HI4Q_HOST_IDX_8822B \
(BIT_MASK_HI4Q_HOST_IDX_8822B << BIT_SHIFT_HI4Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI4Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI4Q_HOST_IDX_8822B))
#define BIT_GET_HI4Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI4Q_HOST_IDX_8822B) & BIT_MASK_HI4Q_HOST_IDX_8822B)
#define BIT_SET_HI4Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI4Q_HOST_IDX_8822B(x) | BIT_HI4Q_HOST_IDX_8822B(v))
/* 2 REG_HI5Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI5Q_HW_IDX_8822B 16
#define BIT_MASK_HI5Q_HW_IDX_8822B 0xfff
#define BIT_HI5Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI5Q_HW_IDX_8822B) << BIT_SHIFT_HI5Q_HW_IDX_8822B)
#define BITS_HI5Q_HW_IDX_8822B \
(BIT_MASK_HI5Q_HW_IDX_8822B << BIT_SHIFT_HI5Q_HW_IDX_8822B)
#define BIT_CLEAR_HI5Q_HW_IDX_8822B(x) ((x) & (~BITS_HI5Q_HW_IDX_8822B))
#define BIT_GET_HI5Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI5Q_HW_IDX_8822B) & BIT_MASK_HI5Q_HW_IDX_8822B)
#define BIT_SET_HI5Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI5Q_HW_IDX_8822B(x) | BIT_HI5Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI5Q_HOST_IDX_8822B 0
#define BIT_MASK_HI5Q_HOST_IDX_8822B 0xfff
#define BIT_HI5Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI5Q_HOST_IDX_8822B) << BIT_SHIFT_HI5Q_HOST_IDX_8822B)
#define BITS_HI5Q_HOST_IDX_8822B \
(BIT_MASK_HI5Q_HOST_IDX_8822B << BIT_SHIFT_HI5Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI5Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI5Q_HOST_IDX_8822B))
#define BIT_GET_HI5Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI5Q_HOST_IDX_8822B) & BIT_MASK_HI5Q_HOST_IDX_8822B)
#define BIT_SET_HI5Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI5Q_HOST_IDX_8822B(x) | BIT_HI5Q_HOST_IDX_8822B(v))
/* 2 REG_HI6Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI6Q_HW_IDX_8822B 16
#define BIT_MASK_HI6Q_HW_IDX_8822B 0xfff
#define BIT_HI6Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI6Q_HW_IDX_8822B) << BIT_SHIFT_HI6Q_HW_IDX_8822B)
#define BITS_HI6Q_HW_IDX_8822B \
(BIT_MASK_HI6Q_HW_IDX_8822B << BIT_SHIFT_HI6Q_HW_IDX_8822B)
#define BIT_CLEAR_HI6Q_HW_IDX_8822B(x) ((x) & (~BITS_HI6Q_HW_IDX_8822B))
#define BIT_GET_HI6Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI6Q_HW_IDX_8822B) & BIT_MASK_HI6Q_HW_IDX_8822B)
#define BIT_SET_HI6Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI6Q_HW_IDX_8822B(x) | BIT_HI6Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI6Q_HOST_IDX_8822B 0
#define BIT_MASK_HI6Q_HOST_IDX_8822B 0xfff
#define BIT_HI6Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI6Q_HOST_IDX_8822B) << BIT_SHIFT_HI6Q_HOST_IDX_8822B)
#define BITS_HI6Q_HOST_IDX_8822B \
(BIT_MASK_HI6Q_HOST_IDX_8822B << BIT_SHIFT_HI6Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI6Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI6Q_HOST_IDX_8822B))
#define BIT_GET_HI6Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI6Q_HOST_IDX_8822B) & BIT_MASK_HI6Q_HOST_IDX_8822B)
#define BIT_SET_HI6Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI6Q_HOST_IDX_8822B(x) | BIT_HI6Q_HOST_IDX_8822B(v))
/* 2 REG_HI7Q_TXBD_IDX_8822B */
#define BIT_SHIFT_HI7Q_HW_IDX_8822B 16
#define BIT_MASK_HI7Q_HW_IDX_8822B 0xfff
#define BIT_HI7Q_HW_IDX_8822B(x) \
(((x) & BIT_MASK_HI7Q_HW_IDX_8822B) << BIT_SHIFT_HI7Q_HW_IDX_8822B)
#define BITS_HI7Q_HW_IDX_8822B \
(BIT_MASK_HI7Q_HW_IDX_8822B << BIT_SHIFT_HI7Q_HW_IDX_8822B)
#define BIT_CLEAR_HI7Q_HW_IDX_8822B(x) ((x) & (~BITS_HI7Q_HW_IDX_8822B))
#define BIT_GET_HI7Q_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI7Q_HW_IDX_8822B) & BIT_MASK_HI7Q_HW_IDX_8822B)
#define BIT_SET_HI7Q_HW_IDX_8822B(x, v) \
(BIT_CLEAR_HI7Q_HW_IDX_8822B(x) | BIT_HI7Q_HW_IDX_8822B(v))
#define BIT_SHIFT_HI7Q_HOST_IDX_8822B 0
#define BIT_MASK_HI7Q_HOST_IDX_8822B 0xfff
#define BIT_HI7Q_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_HI7Q_HOST_IDX_8822B) << BIT_SHIFT_HI7Q_HOST_IDX_8822B)
#define BITS_HI7Q_HOST_IDX_8822B \
(BIT_MASK_HI7Q_HOST_IDX_8822B << BIT_SHIFT_HI7Q_HOST_IDX_8822B)
#define BIT_CLEAR_HI7Q_HOST_IDX_8822B(x) ((x) & (~BITS_HI7Q_HOST_IDX_8822B))
#define BIT_GET_HI7Q_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HI7Q_HOST_IDX_8822B) & BIT_MASK_HI7Q_HOST_IDX_8822B)
#define BIT_SET_HI7Q_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_HI7Q_HOST_IDX_8822B(x) | BIT_HI7Q_HOST_IDX_8822B(v))
/* 2 REG_DBG_SEL_V1_8822B */
#define BIT_SHIFT_DBG_SEL_8822B 0
#define BIT_MASK_DBG_SEL_8822B 0xff
#define BIT_DBG_SEL_8822B(x) \
(((x) & BIT_MASK_DBG_SEL_8822B) << BIT_SHIFT_DBG_SEL_8822B)
#define BITS_DBG_SEL_8822B (BIT_MASK_DBG_SEL_8822B << BIT_SHIFT_DBG_SEL_8822B)
#define BIT_CLEAR_DBG_SEL_8822B(x) ((x) & (~BITS_DBG_SEL_8822B))
#define BIT_GET_DBG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_DBG_SEL_8822B) & BIT_MASK_DBG_SEL_8822B)
#define BIT_SET_DBG_SEL_8822B(x, v) \
(BIT_CLEAR_DBG_SEL_8822B(x) | BIT_DBG_SEL_8822B(v))
/* 2 REG_PCIE_HRPWM1_V1_8822B */
#define BIT_SHIFT_PCIE_HRPWM_8822B 0
#define BIT_MASK_PCIE_HRPWM_8822B 0xff
#define BIT_PCIE_HRPWM_8822B(x) \
(((x) & BIT_MASK_PCIE_HRPWM_8822B) << BIT_SHIFT_PCIE_HRPWM_8822B)
#define BITS_PCIE_HRPWM_8822B \
(BIT_MASK_PCIE_HRPWM_8822B << BIT_SHIFT_PCIE_HRPWM_8822B)
#define BIT_CLEAR_PCIE_HRPWM_8822B(x) ((x) & (~BITS_PCIE_HRPWM_8822B))
#define BIT_GET_PCIE_HRPWM_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM_8822B) & BIT_MASK_PCIE_HRPWM_8822B)
#define BIT_SET_PCIE_HRPWM_8822B(x, v) \
(BIT_CLEAR_PCIE_HRPWM_8822B(x) | BIT_PCIE_HRPWM_8822B(v))
/* 2 REG_PCIE_HCPWM1_V1_8822B */
#define BIT_SHIFT_PCIE_HCPWM_8822B 0
#define BIT_MASK_PCIE_HCPWM_8822B 0xff
#define BIT_PCIE_HCPWM_8822B(x) \
(((x) & BIT_MASK_PCIE_HCPWM_8822B) << BIT_SHIFT_PCIE_HCPWM_8822B)
#define BITS_PCIE_HCPWM_8822B \
(BIT_MASK_PCIE_HCPWM_8822B << BIT_SHIFT_PCIE_HCPWM_8822B)
#define BIT_CLEAR_PCIE_HCPWM_8822B(x) ((x) & (~BITS_PCIE_HCPWM_8822B))
#define BIT_GET_PCIE_HCPWM_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM_8822B) & BIT_MASK_PCIE_HCPWM_8822B)
#define BIT_SET_PCIE_HCPWM_8822B(x, v) \
(BIT_CLEAR_PCIE_HCPWM_8822B(x) | BIT_PCIE_HCPWM_8822B(v))
/* 2 REG_PCIE_CTRL2_8822B */
#define BIT_DIS_TXDMA_PRE_8822B BIT(7)
#define BIT_DIS_RXDMA_PRE_8822B BIT(6)
#define BIT_SHIFT_HPS_CLKR_PCIE_8822B 4
#define BIT_MASK_HPS_CLKR_PCIE_8822B 0x3
#define BIT_HPS_CLKR_PCIE_8822B(x) \
(((x) & BIT_MASK_HPS_CLKR_PCIE_8822B) << BIT_SHIFT_HPS_CLKR_PCIE_8822B)
#define BITS_HPS_CLKR_PCIE_8822B \
(BIT_MASK_HPS_CLKR_PCIE_8822B << BIT_SHIFT_HPS_CLKR_PCIE_8822B)
#define BIT_CLEAR_HPS_CLKR_PCIE_8822B(x) ((x) & (~BITS_HPS_CLKR_PCIE_8822B))
#define BIT_GET_HPS_CLKR_PCIE_8822B(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_PCIE_8822B) & BIT_MASK_HPS_CLKR_PCIE_8822B)
#define BIT_SET_HPS_CLKR_PCIE_8822B(x, v) \
(BIT_CLEAR_HPS_CLKR_PCIE_8822B(x) | BIT_HPS_CLKR_PCIE_8822B(v))
#define BIT_PCIE_INT_8822B BIT(3)
#define BIT_TXFLAG_EXIT_L1_EN_8822B BIT(2)
#define BIT_EN_RXDMA_ALIGN_8822B BIT(1)
#define BIT_EN_TXDMA_ALIGN_8822B BIT(0)
/* 2 REG_PCIE_HRPWM2_V1_8822B */
#define BIT_SHIFT_PCIE_HRPWM2_8822B 0
#define BIT_MASK_PCIE_HRPWM2_8822B 0xffff
#define BIT_PCIE_HRPWM2_8822B(x) \
(((x) & BIT_MASK_PCIE_HRPWM2_8822B) << BIT_SHIFT_PCIE_HRPWM2_8822B)
#define BITS_PCIE_HRPWM2_8822B \
(BIT_MASK_PCIE_HRPWM2_8822B << BIT_SHIFT_PCIE_HRPWM2_8822B)
#define BIT_CLEAR_PCIE_HRPWM2_8822B(x) ((x) & (~BITS_PCIE_HRPWM2_8822B))
#define BIT_GET_PCIE_HRPWM2_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM2_8822B) & BIT_MASK_PCIE_HRPWM2_8822B)
#define BIT_SET_PCIE_HRPWM2_8822B(x, v) \
(BIT_CLEAR_PCIE_HRPWM2_8822B(x) | BIT_PCIE_HRPWM2_8822B(v))
/* 2 REG_PCIE_HCPWM2_V1_8822B */
#define BIT_SHIFT_PCIE_HCPWM2_8822B 0
#define BIT_MASK_PCIE_HCPWM2_8822B 0xffff
#define BIT_PCIE_HCPWM2_8822B(x) \
(((x) & BIT_MASK_PCIE_HCPWM2_8822B) << BIT_SHIFT_PCIE_HCPWM2_8822B)
#define BITS_PCIE_HCPWM2_8822B \
(BIT_MASK_PCIE_HCPWM2_8822B << BIT_SHIFT_PCIE_HCPWM2_8822B)
#define BIT_CLEAR_PCIE_HCPWM2_8822B(x) ((x) & (~BITS_PCIE_HCPWM2_8822B))
#define BIT_GET_PCIE_HCPWM2_8822B(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM2_8822B) & BIT_MASK_PCIE_HCPWM2_8822B)
#define BIT_SET_PCIE_HCPWM2_8822B(x, v) \
(BIT_CLEAR_PCIE_HCPWM2_8822B(x) | BIT_PCIE_HCPWM2_8822B(v))
/* 2 REG_PCIE_H2C_MSG_V1_8822B */
#define BIT_SHIFT_DRV2FW_INFO_8822B 0
#define BIT_MASK_DRV2FW_INFO_8822B 0xffffffffL
#define BIT_DRV2FW_INFO_8822B(x) \
(((x) & BIT_MASK_DRV2FW_INFO_8822B) << BIT_SHIFT_DRV2FW_INFO_8822B)
#define BITS_DRV2FW_INFO_8822B \
(BIT_MASK_DRV2FW_INFO_8822B << BIT_SHIFT_DRV2FW_INFO_8822B)
#define BIT_CLEAR_DRV2FW_INFO_8822B(x) ((x) & (~BITS_DRV2FW_INFO_8822B))
#define BIT_GET_DRV2FW_INFO_8822B(x) \
(((x) >> BIT_SHIFT_DRV2FW_INFO_8822B) & BIT_MASK_DRV2FW_INFO_8822B)
#define BIT_SET_DRV2FW_INFO_8822B(x, v) \
(BIT_CLEAR_DRV2FW_INFO_8822B(x) | BIT_DRV2FW_INFO_8822B(v))
/* 2 REG_PCIE_C2H_MSG_V1_8822B */
#define BIT_SHIFT_HCI_PCIE_C2H_MSG_8822B 0
#define BIT_MASK_HCI_PCIE_C2H_MSG_8822B 0xffffffffL
#define BIT_HCI_PCIE_C2H_MSG_8822B(x) \
(((x) & BIT_MASK_HCI_PCIE_C2H_MSG_8822B) \
<< BIT_SHIFT_HCI_PCIE_C2H_MSG_8822B)
#define BITS_HCI_PCIE_C2H_MSG_8822B \
(BIT_MASK_HCI_PCIE_C2H_MSG_8822B << BIT_SHIFT_HCI_PCIE_C2H_MSG_8822B)
#define BIT_CLEAR_HCI_PCIE_C2H_MSG_8822B(x) \
((x) & (~BITS_HCI_PCIE_C2H_MSG_8822B))
#define BIT_GET_HCI_PCIE_C2H_MSG_8822B(x) \
(((x) >> BIT_SHIFT_HCI_PCIE_C2H_MSG_8822B) & \
BIT_MASK_HCI_PCIE_C2H_MSG_8822B)
#define BIT_SET_HCI_PCIE_C2H_MSG_8822B(x, v) \
(BIT_CLEAR_HCI_PCIE_C2H_MSG_8822B(x) | BIT_HCI_PCIE_C2H_MSG_8822B(v))
/* 2 REG_DBI_WDATA_V1_8822B */
#define BIT_SHIFT_DBI_WDATA_8822B 0
#define BIT_MASK_DBI_WDATA_8822B 0xffffffffL
#define BIT_DBI_WDATA_8822B(x) \
(((x) & BIT_MASK_DBI_WDATA_8822B) << BIT_SHIFT_DBI_WDATA_8822B)
#define BITS_DBI_WDATA_8822B \
(BIT_MASK_DBI_WDATA_8822B << BIT_SHIFT_DBI_WDATA_8822B)
#define BIT_CLEAR_DBI_WDATA_8822B(x) ((x) & (~BITS_DBI_WDATA_8822B))
#define BIT_GET_DBI_WDATA_8822B(x) \
(((x) >> BIT_SHIFT_DBI_WDATA_8822B) & BIT_MASK_DBI_WDATA_8822B)
#define BIT_SET_DBI_WDATA_8822B(x, v) \
(BIT_CLEAR_DBI_WDATA_8822B(x) | BIT_DBI_WDATA_8822B(v))
/* 2 REG_DBI_RDATA_V1_8822B */
#define BIT_SHIFT_DBI_RDATA_8822B 0
#define BIT_MASK_DBI_RDATA_8822B 0xffffffffL
#define BIT_DBI_RDATA_8822B(x) \
(((x) & BIT_MASK_DBI_RDATA_8822B) << BIT_SHIFT_DBI_RDATA_8822B)
#define BITS_DBI_RDATA_8822B \
(BIT_MASK_DBI_RDATA_8822B << BIT_SHIFT_DBI_RDATA_8822B)
#define BIT_CLEAR_DBI_RDATA_8822B(x) ((x) & (~BITS_DBI_RDATA_8822B))
#define BIT_GET_DBI_RDATA_8822B(x) \
(((x) >> BIT_SHIFT_DBI_RDATA_8822B) & BIT_MASK_DBI_RDATA_8822B)
#define BIT_SET_DBI_RDATA_8822B(x, v) \
(BIT_CLEAR_DBI_RDATA_8822B(x) | BIT_DBI_RDATA_8822B(v))
/* 2 REG_DBI_FLAG_V1_8822B */
#define BIT_EN_STUCK_DBG_8822B BIT(26)
#define BIT_RX_STUCK_8822B BIT(25)
#define BIT_TX_STUCK_8822B BIT(24)
#define BIT_DBI_RFLAG_8822B BIT(17)
#define BIT_DBI_WFLAG_8822B BIT(16)
#define BIT_SHIFT_DBI_WREN_8822B 12
#define BIT_MASK_DBI_WREN_8822B 0xf
#define BIT_DBI_WREN_8822B(x) \
(((x) & BIT_MASK_DBI_WREN_8822B) << BIT_SHIFT_DBI_WREN_8822B)
#define BITS_DBI_WREN_8822B \
(BIT_MASK_DBI_WREN_8822B << BIT_SHIFT_DBI_WREN_8822B)
#define BIT_CLEAR_DBI_WREN_8822B(x) ((x) & (~BITS_DBI_WREN_8822B))
#define BIT_GET_DBI_WREN_8822B(x) \
(((x) >> BIT_SHIFT_DBI_WREN_8822B) & BIT_MASK_DBI_WREN_8822B)
#define BIT_SET_DBI_WREN_8822B(x, v) \
(BIT_CLEAR_DBI_WREN_8822B(x) | BIT_DBI_WREN_8822B(v))
#define BIT_SHIFT_DBI_ADDR_8822B 0
#define BIT_MASK_DBI_ADDR_8822B 0xfff
#define BIT_DBI_ADDR_8822B(x) \
(((x) & BIT_MASK_DBI_ADDR_8822B) << BIT_SHIFT_DBI_ADDR_8822B)
#define BITS_DBI_ADDR_8822B \
(BIT_MASK_DBI_ADDR_8822B << BIT_SHIFT_DBI_ADDR_8822B)
#define BIT_CLEAR_DBI_ADDR_8822B(x) ((x) & (~BITS_DBI_ADDR_8822B))
#define BIT_GET_DBI_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_DBI_ADDR_8822B) & BIT_MASK_DBI_ADDR_8822B)
#define BIT_SET_DBI_ADDR_8822B(x, v) \
(BIT_CLEAR_DBI_ADDR_8822B(x) | BIT_DBI_ADDR_8822B(v))
/* 2 REG_MDIO_V1_8822B */
#define BIT_SHIFT_MDIO_RDATA_8822B 16
#define BIT_MASK_MDIO_RDATA_8822B 0xffff
#define BIT_MDIO_RDATA_8822B(x) \
(((x) & BIT_MASK_MDIO_RDATA_8822B) << BIT_SHIFT_MDIO_RDATA_8822B)
#define BITS_MDIO_RDATA_8822B \
(BIT_MASK_MDIO_RDATA_8822B << BIT_SHIFT_MDIO_RDATA_8822B)
#define BIT_CLEAR_MDIO_RDATA_8822B(x) ((x) & (~BITS_MDIO_RDATA_8822B))
#define BIT_GET_MDIO_RDATA_8822B(x) \
(((x) >> BIT_SHIFT_MDIO_RDATA_8822B) & BIT_MASK_MDIO_RDATA_8822B)
#define BIT_SET_MDIO_RDATA_8822B(x, v) \
(BIT_CLEAR_MDIO_RDATA_8822B(x) | BIT_MDIO_RDATA_8822B(v))
#define BIT_SHIFT_MDIO_WDATA_8822B 0
#define BIT_MASK_MDIO_WDATA_8822B 0xffff
#define BIT_MDIO_WDATA_8822B(x) \
(((x) & BIT_MASK_MDIO_WDATA_8822B) << BIT_SHIFT_MDIO_WDATA_8822B)
#define BITS_MDIO_WDATA_8822B \
(BIT_MASK_MDIO_WDATA_8822B << BIT_SHIFT_MDIO_WDATA_8822B)
#define BIT_CLEAR_MDIO_WDATA_8822B(x) ((x) & (~BITS_MDIO_WDATA_8822B))
#define BIT_GET_MDIO_WDATA_8822B(x) \
(((x) >> BIT_SHIFT_MDIO_WDATA_8822B) & BIT_MASK_MDIO_WDATA_8822B)
#define BIT_SET_MDIO_WDATA_8822B(x, v) \
(BIT_CLEAR_MDIO_WDATA_8822B(x) | BIT_MDIO_WDATA_8822B(v))
/* 2 REG_PCIE_MIX_CFG_8822B */
#define BIT_SHIFT_MDIO_PHY_ADDR_8822B 24
#define BIT_MASK_MDIO_PHY_ADDR_8822B 0x1f
#define BIT_MDIO_PHY_ADDR_8822B(x) \
(((x) & BIT_MASK_MDIO_PHY_ADDR_8822B) << BIT_SHIFT_MDIO_PHY_ADDR_8822B)
#define BITS_MDIO_PHY_ADDR_8822B \
(BIT_MASK_MDIO_PHY_ADDR_8822B << BIT_SHIFT_MDIO_PHY_ADDR_8822B)
#define BIT_CLEAR_MDIO_PHY_ADDR_8822B(x) ((x) & (~BITS_MDIO_PHY_ADDR_8822B))
#define BIT_GET_MDIO_PHY_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_MDIO_PHY_ADDR_8822B) & BIT_MASK_MDIO_PHY_ADDR_8822B)
#define BIT_SET_MDIO_PHY_ADDR_8822B(x, v) \
(BIT_CLEAR_MDIO_PHY_ADDR_8822B(x) | BIT_MDIO_PHY_ADDR_8822B(v))
#define BIT_SHIFT_WATCH_DOG_RECORD_V1_8822B 10
#define BIT_MASK_WATCH_DOG_RECORD_V1_8822B 0x3fff
#define BIT_WATCH_DOG_RECORD_V1_8822B(x) \
(((x) & BIT_MASK_WATCH_DOG_RECORD_V1_8822B) \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8822B)
#define BITS_WATCH_DOG_RECORD_V1_8822B \
(BIT_MASK_WATCH_DOG_RECORD_V1_8822B \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8822B)
#define BIT_CLEAR_WATCH_DOG_RECORD_V1_8822B(x) \
((x) & (~BITS_WATCH_DOG_RECORD_V1_8822B))
#define BIT_GET_WATCH_DOG_RECORD_V1_8822B(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_RECORD_V1_8822B) & \
BIT_MASK_WATCH_DOG_RECORD_V1_8822B)
#define BIT_SET_WATCH_DOG_RECORD_V1_8822B(x, v) \
(BIT_CLEAR_WATCH_DOG_RECORD_V1_8822B(x) | \
BIT_WATCH_DOG_RECORD_V1_8822B(v))
#define BIT_R_IO_TIMEOUT_FLAG_V1_8822B BIT(9)
#define BIT_EN_WATCH_DOG_8822B BIT(8)
#define BIT_ECRC_EN_V1_8822B BIT(7)
#define BIT_MDIO_RFLAG_V1_8822B BIT(6)
#define BIT_MDIO_WFLAG_V1_8822B BIT(5)
#define BIT_SHIFT_MDIO_REG_ADDR_V1_8822B 0
#define BIT_MASK_MDIO_REG_ADDR_V1_8822B 0x1f
#define BIT_MDIO_REG_ADDR_V1_8822B(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR_V1_8822B) \
<< BIT_SHIFT_MDIO_REG_ADDR_V1_8822B)
#define BITS_MDIO_REG_ADDR_V1_8822B \
(BIT_MASK_MDIO_REG_ADDR_V1_8822B << BIT_SHIFT_MDIO_REG_ADDR_V1_8822B)
#define BIT_CLEAR_MDIO_REG_ADDR_V1_8822B(x) \
((x) & (~BITS_MDIO_REG_ADDR_V1_8822B))
#define BIT_GET_MDIO_REG_ADDR_V1_8822B(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR_V1_8822B) & \
BIT_MASK_MDIO_REG_ADDR_V1_8822B)
#define BIT_SET_MDIO_REG_ADDR_V1_8822B(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR_V1_8822B(x) | BIT_MDIO_REG_ADDR_V1_8822B(v))
/* 2 REG_HCI_MIX_CFG_8822B */
#define BIT_HOST_GEN2_SUPPORT_8822B BIT(20)
#define BIT_SHIFT_TXDMA_ERR_FLAG_8822B 16
#define BIT_MASK_TXDMA_ERR_FLAG_8822B 0xf
#define BIT_TXDMA_ERR_FLAG_8822B(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG_8822B) \
<< BIT_SHIFT_TXDMA_ERR_FLAG_8822B)
#define BITS_TXDMA_ERR_FLAG_8822B \
(BIT_MASK_TXDMA_ERR_FLAG_8822B << BIT_SHIFT_TXDMA_ERR_FLAG_8822B)
#define BIT_CLEAR_TXDMA_ERR_FLAG_8822B(x) ((x) & (~BITS_TXDMA_ERR_FLAG_8822B))
#define BIT_GET_TXDMA_ERR_FLAG_8822B(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG_8822B) & \
BIT_MASK_TXDMA_ERR_FLAG_8822B)
#define BIT_SET_TXDMA_ERR_FLAG_8822B(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG_8822B(x) | BIT_TXDMA_ERR_FLAG_8822B(v))
#define BIT_SHIFT_EARLY_MODE_SEL_8822B 12
#define BIT_MASK_EARLY_MODE_SEL_8822B 0xf
#define BIT_EARLY_MODE_SEL_8822B(x) \
(((x) & BIT_MASK_EARLY_MODE_SEL_8822B) \
<< BIT_SHIFT_EARLY_MODE_SEL_8822B)
#define BITS_EARLY_MODE_SEL_8822B \
(BIT_MASK_EARLY_MODE_SEL_8822B << BIT_SHIFT_EARLY_MODE_SEL_8822B)
#define BIT_CLEAR_EARLY_MODE_SEL_8822B(x) ((x) & (~BITS_EARLY_MODE_SEL_8822B))
#define BIT_GET_EARLY_MODE_SEL_8822B(x) \
(((x) >> BIT_SHIFT_EARLY_MODE_SEL_8822B) & \
BIT_MASK_EARLY_MODE_SEL_8822B)
#define BIT_SET_EARLY_MODE_SEL_8822B(x, v) \
(BIT_CLEAR_EARLY_MODE_SEL_8822B(x) | BIT_EARLY_MODE_SEL_8822B(v))
#define BIT_EPHY_RX50_EN_8822B BIT(11)
#define BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822B 8
#define BIT_MASK_MSI_TIMEOUT_ID_V1_8822B 0x7
#define BIT_MSI_TIMEOUT_ID_V1_8822B(x) \
(((x) & BIT_MASK_MSI_TIMEOUT_ID_V1_8822B) \
<< BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822B)
#define BITS_MSI_TIMEOUT_ID_V1_8822B \
(BIT_MASK_MSI_TIMEOUT_ID_V1_8822B << BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822B)
#define BIT_CLEAR_MSI_TIMEOUT_ID_V1_8822B(x) \
((x) & (~BITS_MSI_TIMEOUT_ID_V1_8822B))
#define BIT_GET_MSI_TIMEOUT_ID_V1_8822B(x) \
(((x) >> BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822B) & \
BIT_MASK_MSI_TIMEOUT_ID_V1_8822B)
#define BIT_SET_MSI_TIMEOUT_ID_V1_8822B(x, v) \
(BIT_CLEAR_MSI_TIMEOUT_ID_V1_8822B(x) | BIT_MSI_TIMEOUT_ID_V1_8822B(v))
#define BIT_RADDR_RD_8822B BIT(7)
#define BIT_EN_MUL_TAG_8822B BIT(6)
#define BIT_EN_EARLY_MODE_8822B BIT(5)
#define BIT_L0S_LINK_OFF_8822B BIT(4)
#define BIT_ACT_LINK_OFF_8822B BIT(3)
#define BIT_EN_SLOW_MAC_TX_8822B BIT(2)
#define BIT_EN_SLOW_MAC_RX_8822B BIT(1)
/* 2 REG_STC_INT_CS_8822B(PCIE STATE CHANGE INTERRUPT CONTROL AND STATUS) */
#define BIT_STC_INT_EN_8822B BIT(31)
#define BIT_SHIFT_STC_INT_FLAG_8822B 16
#define BIT_MASK_STC_INT_FLAG_8822B 0xff
#define BIT_STC_INT_FLAG_8822B(x) \
(((x) & BIT_MASK_STC_INT_FLAG_8822B) << BIT_SHIFT_STC_INT_FLAG_8822B)
#define BITS_STC_INT_FLAG_8822B \
(BIT_MASK_STC_INT_FLAG_8822B << BIT_SHIFT_STC_INT_FLAG_8822B)
#define BIT_CLEAR_STC_INT_FLAG_8822B(x) ((x) & (~BITS_STC_INT_FLAG_8822B))
#define BIT_GET_STC_INT_FLAG_8822B(x) \
(((x) >> BIT_SHIFT_STC_INT_FLAG_8822B) & BIT_MASK_STC_INT_FLAG_8822B)
#define BIT_SET_STC_INT_FLAG_8822B(x, v) \
(BIT_CLEAR_STC_INT_FLAG_8822B(x) | BIT_STC_INT_FLAG_8822B(v))
#define BIT_SHIFT_STC_INT_IDX_8822B 8
#define BIT_MASK_STC_INT_IDX_8822B 0x7
#define BIT_STC_INT_IDX_8822B(x) \
(((x) & BIT_MASK_STC_INT_IDX_8822B) << BIT_SHIFT_STC_INT_IDX_8822B)
#define BITS_STC_INT_IDX_8822B \
(BIT_MASK_STC_INT_IDX_8822B << BIT_SHIFT_STC_INT_IDX_8822B)
#define BIT_CLEAR_STC_INT_IDX_8822B(x) ((x) & (~BITS_STC_INT_IDX_8822B))
#define BIT_GET_STC_INT_IDX_8822B(x) \
(((x) >> BIT_SHIFT_STC_INT_IDX_8822B) & BIT_MASK_STC_INT_IDX_8822B)
#define BIT_SET_STC_INT_IDX_8822B(x, v) \
(BIT_CLEAR_STC_INT_IDX_8822B(x) | BIT_STC_INT_IDX_8822B(v))
#define BIT_SHIFT_STC_INT_REALTIME_CS_8822B 0
#define BIT_MASK_STC_INT_REALTIME_CS_8822B 0x3f
#define BIT_STC_INT_REALTIME_CS_8822B(x) \
(((x) & BIT_MASK_STC_INT_REALTIME_CS_8822B) \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8822B)
#define BITS_STC_INT_REALTIME_CS_8822B \
(BIT_MASK_STC_INT_REALTIME_CS_8822B \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8822B)
#define BIT_CLEAR_STC_INT_REALTIME_CS_8822B(x) \
((x) & (~BITS_STC_INT_REALTIME_CS_8822B))
#define BIT_GET_STC_INT_REALTIME_CS_8822B(x) \
(((x) >> BIT_SHIFT_STC_INT_REALTIME_CS_8822B) & \
BIT_MASK_STC_INT_REALTIME_CS_8822B)
#define BIT_SET_STC_INT_REALTIME_CS_8822B(x, v) \
(BIT_CLEAR_STC_INT_REALTIME_CS_8822B(x) | \
BIT_STC_INT_REALTIME_CS_8822B(v))
/* 2 REG_ST_INT_CFG_8822B(PCIE STATE CHANGE INTERRUPT CONFIGURATION) */
#define BIT_STC_INT_GRP_EN_8822B BIT(31)
#define BIT_SHIFT_STC_INT_EXPECT_LS_8822B 8
#define BIT_MASK_STC_INT_EXPECT_LS_8822B 0x3f
#define BIT_STC_INT_EXPECT_LS_8822B(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_LS_8822B) \
<< BIT_SHIFT_STC_INT_EXPECT_LS_8822B)
#define BITS_STC_INT_EXPECT_LS_8822B \
(BIT_MASK_STC_INT_EXPECT_LS_8822B << BIT_SHIFT_STC_INT_EXPECT_LS_8822B)
#define BIT_CLEAR_STC_INT_EXPECT_LS_8822B(x) \
((x) & (~BITS_STC_INT_EXPECT_LS_8822B))
#define BIT_GET_STC_INT_EXPECT_LS_8822B(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_LS_8822B) & \
BIT_MASK_STC_INT_EXPECT_LS_8822B)
#define BIT_SET_STC_INT_EXPECT_LS_8822B(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_LS_8822B(x) | BIT_STC_INT_EXPECT_LS_8822B(v))
#define BIT_SHIFT_STC_INT_EXPECT_CS_8822B 0
#define BIT_MASK_STC_INT_EXPECT_CS_8822B 0x3f
#define BIT_STC_INT_EXPECT_CS_8822B(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_CS_8822B) \
<< BIT_SHIFT_STC_INT_EXPECT_CS_8822B)
#define BITS_STC_INT_EXPECT_CS_8822B \
(BIT_MASK_STC_INT_EXPECT_CS_8822B << BIT_SHIFT_STC_INT_EXPECT_CS_8822B)
#define BIT_CLEAR_STC_INT_EXPECT_CS_8822B(x) \
((x) & (~BITS_STC_INT_EXPECT_CS_8822B))
#define BIT_GET_STC_INT_EXPECT_CS_8822B(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_CS_8822B) & \
BIT_MASK_STC_INT_EXPECT_CS_8822B)
#define BIT_SET_STC_INT_EXPECT_CS_8822B(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_CS_8822B(x) | BIT_STC_INT_EXPECT_CS_8822B(v))
/* 2 REG_CMU_DLY_CTRL_8822B(PCIE PHY CLOCK MGT UNIT DELAY CONTROL ) */
#define BIT_CMU_DLY_EN_8822B BIT(31)
#define BIT_CMU_DLY_MODE_8822B BIT(30)
#define BIT_SHIFT_CMU_DLY_PRE_DIV_8822B 0
#define BIT_MASK_CMU_DLY_PRE_DIV_8822B 0xff
#define BIT_CMU_DLY_PRE_DIV_8822B(x) \
(((x) & BIT_MASK_CMU_DLY_PRE_DIV_8822B) \
<< BIT_SHIFT_CMU_DLY_PRE_DIV_8822B)
#define BITS_CMU_DLY_PRE_DIV_8822B \
(BIT_MASK_CMU_DLY_PRE_DIV_8822B << BIT_SHIFT_CMU_DLY_PRE_DIV_8822B)
#define BIT_CLEAR_CMU_DLY_PRE_DIV_8822B(x) ((x) & (~BITS_CMU_DLY_PRE_DIV_8822B))
#define BIT_GET_CMU_DLY_PRE_DIV_8822B(x) \
(((x) >> BIT_SHIFT_CMU_DLY_PRE_DIV_8822B) & \
BIT_MASK_CMU_DLY_PRE_DIV_8822B)
#define BIT_SET_CMU_DLY_PRE_DIV_8822B(x, v) \
(BIT_CLEAR_CMU_DLY_PRE_DIV_8822B(x) | BIT_CMU_DLY_PRE_DIV_8822B(v))
/* 2 REG_CMU_DLY_CFG_8822B(PCIE PHY CLOCK MGT UNIT DELAY CONFIGURATION ) */
#define BIT_SHIFT_CMU_DLY_LTR_A2I_8822B 24
#define BIT_MASK_CMU_DLY_LTR_A2I_8822B 0xff
#define BIT_CMU_DLY_LTR_A2I_8822B(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_A2I_8822B) \
<< BIT_SHIFT_CMU_DLY_LTR_A2I_8822B)
#define BITS_CMU_DLY_LTR_A2I_8822B \
(BIT_MASK_CMU_DLY_LTR_A2I_8822B << BIT_SHIFT_CMU_DLY_LTR_A2I_8822B)
#define BIT_CLEAR_CMU_DLY_LTR_A2I_8822B(x) ((x) & (~BITS_CMU_DLY_LTR_A2I_8822B))
#define BIT_GET_CMU_DLY_LTR_A2I_8822B(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_A2I_8822B) & \
BIT_MASK_CMU_DLY_LTR_A2I_8822B)
#define BIT_SET_CMU_DLY_LTR_A2I_8822B(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_A2I_8822B(x) | BIT_CMU_DLY_LTR_A2I_8822B(v))
#define BIT_SHIFT_CMU_DLY_LTR_I2A_8822B 16
#define BIT_MASK_CMU_DLY_LTR_I2A_8822B 0xff
#define BIT_CMU_DLY_LTR_I2A_8822B(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_I2A_8822B) \
<< BIT_SHIFT_CMU_DLY_LTR_I2A_8822B)
#define BITS_CMU_DLY_LTR_I2A_8822B \
(BIT_MASK_CMU_DLY_LTR_I2A_8822B << BIT_SHIFT_CMU_DLY_LTR_I2A_8822B)
#define BIT_CLEAR_CMU_DLY_LTR_I2A_8822B(x) ((x) & (~BITS_CMU_DLY_LTR_I2A_8822B))
#define BIT_GET_CMU_DLY_LTR_I2A_8822B(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_I2A_8822B) & \
BIT_MASK_CMU_DLY_LTR_I2A_8822B)
#define BIT_SET_CMU_DLY_LTR_I2A_8822B(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_I2A_8822B(x) | BIT_CMU_DLY_LTR_I2A_8822B(v))
#define BIT_SHIFT_CMU_DLY_LTR_IDLE_8822B 8
#define BIT_MASK_CMU_DLY_LTR_IDLE_8822B 0xff
#define BIT_CMU_DLY_LTR_IDLE_8822B(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_IDLE_8822B) \
<< BIT_SHIFT_CMU_DLY_LTR_IDLE_8822B)
#define BITS_CMU_DLY_LTR_IDLE_8822B \
(BIT_MASK_CMU_DLY_LTR_IDLE_8822B << BIT_SHIFT_CMU_DLY_LTR_IDLE_8822B)
#define BIT_CLEAR_CMU_DLY_LTR_IDLE_8822B(x) \
((x) & (~BITS_CMU_DLY_LTR_IDLE_8822B))
#define BIT_GET_CMU_DLY_LTR_IDLE_8822B(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_IDLE_8822B) & \
BIT_MASK_CMU_DLY_LTR_IDLE_8822B)
#define BIT_SET_CMU_DLY_LTR_IDLE_8822B(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_IDLE_8822B(x) | BIT_CMU_DLY_LTR_IDLE_8822B(v))
#define BIT_SHIFT_CMU_DLY_LTR_ACT_8822B 0
#define BIT_MASK_CMU_DLY_LTR_ACT_8822B 0xff
#define BIT_CMU_DLY_LTR_ACT_8822B(x) \
(((x) & BIT_MASK_CMU_DLY_LTR_ACT_8822B) \
<< BIT_SHIFT_CMU_DLY_LTR_ACT_8822B)
#define BITS_CMU_DLY_LTR_ACT_8822B \
(BIT_MASK_CMU_DLY_LTR_ACT_8822B << BIT_SHIFT_CMU_DLY_LTR_ACT_8822B)
#define BIT_CLEAR_CMU_DLY_LTR_ACT_8822B(x) ((x) & (~BITS_CMU_DLY_LTR_ACT_8822B))
#define BIT_GET_CMU_DLY_LTR_ACT_8822B(x) \
(((x) >> BIT_SHIFT_CMU_DLY_LTR_ACT_8822B) & \
BIT_MASK_CMU_DLY_LTR_ACT_8822B)
#define BIT_SET_CMU_DLY_LTR_ACT_8822B(x, v) \
(BIT_CLEAR_CMU_DLY_LTR_ACT_8822B(x) | BIT_CMU_DLY_LTR_ACT_8822B(v))
/* 2 REG_H2CQ_TXBD_DESA_8822B */
#define BIT_SHIFT_H2CQ_TXBD_DESA_8822B 0
#define BIT_MASK_H2CQ_TXBD_DESA_8822B 0xffffffffffffffffL
#define BIT_H2CQ_TXBD_DESA_8822B(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_8822B) \
<< BIT_SHIFT_H2CQ_TXBD_DESA_8822B)
#define BITS_H2CQ_TXBD_DESA_8822B \
(BIT_MASK_H2CQ_TXBD_DESA_8822B << BIT_SHIFT_H2CQ_TXBD_DESA_8822B)
#define BIT_CLEAR_H2CQ_TXBD_DESA_8822B(x) ((x) & (~BITS_H2CQ_TXBD_DESA_8822B))
#define BIT_GET_H2CQ_TXBD_DESA_8822B(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_8822B) & \
BIT_MASK_H2CQ_TXBD_DESA_8822B)
#define BIT_SET_H2CQ_TXBD_DESA_8822B(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_8822B(x) | BIT_H2CQ_TXBD_DESA_8822B(v))
/* 2 REG_H2CQ_TXBD_NUM_8822B */
#define BIT_PCIE_H2CQ_FLAG_8822B BIT(14)
#define BIT_SHIFT_H2CQ_DESC_MODE_8822B 12
#define BIT_MASK_H2CQ_DESC_MODE_8822B 0x3
#define BIT_H2CQ_DESC_MODE_8822B(x) \
(((x) & BIT_MASK_H2CQ_DESC_MODE_8822B) \
<< BIT_SHIFT_H2CQ_DESC_MODE_8822B)
#define BITS_H2CQ_DESC_MODE_8822B \
(BIT_MASK_H2CQ_DESC_MODE_8822B << BIT_SHIFT_H2CQ_DESC_MODE_8822B)
#define BIT_CLEAR_H2CQ_DESC_MODE_8822B(x) ((x) & (~BITS_H2CQ_DESC_MODE_8822B))
#define BIT_GET_H2CQ_DESC_MODE_8822B(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_MODE_8822B) & \
BIT_MASK_H2CQ_DESC_MODE_8822B)
#define BIT_SET_H2CQ_DESC_MODE_8822B(x, v) \
(BIT_CLEAR_H2CQ_DESC_MODE_8822B(x) | BIT_H2CQ_DESC_MODE_8822B(v))
#define BIT_SHIFT_H2CQ_DESC_NUM_8822B 0
#define BIT_MASK_H2CQ_DESC_NUM_8822B 0xfff
#define BIT_H2CQ_DESC_NUM_8822B(x) \
(((x) & BIT_MASK_H2CQ_DESC_NUM_8822B) << BIT_SHIFT_H2CQ_DESC_NUM_8822B)
#define BITS_H2CQ_DESC_NUM_8822B \
(BIT_MASK_H2CQ_DESC_NUM_8822B << BIT_SHIFT_H2CQ_DESC_NUM_8822B)
#define BIT_CLEAR_H2CQ_DESC_NUM_8822B(x) ((x) & (~BITS_H2CQ_DESC_NUM_8822B))
#define BIT_GET_H2CQ_DESC_NUM_8822B(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_NUM_8822B) & BIT_MASK_H2CQ_DESC_NUM_8822B)
#define BIT_SET_H2CQ_DESC_NUM_8822B(x, v) \
(BIT_CLEAR_H2CQ_DESC_NUM_8822B(x) | BIT_H2CQ_DESC_NUM_8822B(v))
/* 2 REG_H2CQ_TXBD_IDX_8822B */
#define BIT_SHIFT_H2CQ_HW_IDX_8822B 16
#define BIT_MASK_H2CQ_HW_IDX_8822B 0xfff
#define BIT_H2CQ_HW_IDX_8822B(x) \
(((x) & BIT_MASK_H2CQ_HW_IDX_8822B) << BIT_SHIFT_H2CQ_HW_IDX_8822B)
#define BITS_H2CQ_HW_IDX_8822B \
(BIT_MASK_H2CQ_HW_IDX_8822B << BIT_SHIFT_H2CQ_HW_IDX_8822B)
#define BIT_CLEAR_H2CQ_HW_IDX_8822B(x) ((x) & (~BITS_H2CQ_HW_IDX_8822B))
#define BIT_GET_H2CQ_HW_IDX_8822B(x) \
(((x) >> BIT_SHIFT_H2CQ_HW_IDX_8822B) & BIT_MASK_H2CQ_HW_IDX_8822B)
#define BIT_SET_H2CQ_HW_IDX_8822B(x, v) \
(BIT_CLEAR_H2CQ_HW_IDX_8822B(x) | BIT_H2CQ_HW_IDX_8822B(v))
#define BIT_SHIFT_H2CQ_HOST_IDX_8822B 0
#define BIT_MASK_H2CQ_HOST_IDX_8822B 0xfff
#define BIT_H2CQ_HOST_IDX_8822B(x) \
(((x) & BIT_MASK_H2CQ_HOST_IDX_8822B) << BIT_SHIFT_H2CQ_HOST_IDX_8822B)
#define BITS_H2CQ_HOST_IDX_8822B \
(BIT_MASK_H2CQ_HOST_IDX_8822B << BIT_SHIFT_H2CQ_HOST_IDX_8822B)
#define BIT_CLEAR_H2CQ_HOST_IDX_8822B(x) ((x) & (~BITS_H2CQ_HOST_IDX_8822B))
#define BIT_GET_H2CQ_HOST_IDX_8822B(x) \
(((x) >> BIT_SHIFT_H2CQ_HOST_IDX_8822B) & BIT_MASK_H2CQ_HOST_IDX_8822B)
#define BIT_SET_H2CQ_HOST_IDX_8822B(x, v) \
(BIT_CLEAR_H2CQ_HOST_IDX_8822B(x) | BIT_H2CQ_HOST_IDX_8822B(v))
/* 2 REG_H2CQ_CSR_8822B[31:0] (H2CQ CONTROL AND STATUS) */
#define BIT_H2CQ_FULL_8822B BIT(31)
#define BIT_CLR_H2CQ_HOST_IDX_8822B BIT(16)
#define BIT_CLR_H2CQ_HW_IDX_8822B BIT(8)
#define BIT_STOP_H2CQ_8822B BIT(0)
/* 2 REG_CHANGE_PCIE_SPEED_8822B */
#define BIT_CHANGE_PCIE_SPEED_8822B BIT(18)
#define BIT_SHIFT_GEN1_GEN2_8822B 16
#define BIT_MASK_GEN1_GEN2_8822B 0x3
#define BIT_GEN1_GEN2_8822B(x) \
(((x) & BIT_MASK_GEN1_GEN2_8822B) << BIT_SHIFT_GEN1_GEN2_8822B)
#define BITS_GEN1_GEN2_8822B \
(BIT_MASK_GEN1_GEN2_8822B << BIT_SHIFT_GEN1_GEN2_8822B)
#define BIT_CLEAR_GEN1_GEN2_8822B(x) ((x) & (~BITS_GEN1_GEN2_8822B))
#define BIT_GET_GEN1_GEN2_8822B(x) \
(((x) >> BIT_SHIFT_GEN1_GEN2_8822B) & BIT_MASK_GEN1_GEN2_8822B)
#define BIT_SET_GEN1_GEN2_8822B(x, v) \
(BIT_CLEAR_GEN1_GEN2_8822B(x) | BIT_GEN1_GEN2_8822B(v))
#define BIT_SHIFT_RXDMA_ERROR_COUNTER_8822B 8
#define BIT_MASK_RXDMA_ERROR_COUNTER_8822B 0xff
#define BIT_RXDMA_ERROR_COUNTER_8822B(x) \
(((x) & BIT_MASK_RXDMA_ERROR_COUNTER_8822B) \
<< BIT_SHIFT_RXDMA_ERROR_COUNTER_8822B)
#define BITS_RXDMA_ERROR_COUNTER_8822B \
(BIT_MASK_RXDMA_ERROR_COUNTER_8822B \
<< BIT_SHIFT_RXDMA_ERROR_COUNTER_8822B)
#define BIT_CLEAR_RXDMA_ERROR_COUNTER_8822B(x) \
((x) & (~BITS_RXDMA_ERROR_COUNTER_8822B))
#define BIT_GET_RXDMA_ERROR_COUNTER_8822B(x) \
(((x) >> BIT_SHIFT_RXDMA_ERROR_COUNTER_8822B) & \
BIT_MASK_RXDMA_ERROR_COUNTER_8822B)
#define BIT_SET_RXDMA_ERROR_COUNTER_8822B(x, v) \
(BIT_CLEAR_RXDMA_ERROR_COUNTER_8822B(x) | \
BIT_RXDMA_ERROR_COUNTER_8822B(v))
#define BIT_TXDMA_ERROR_HANDLE_STATUS_8822B BIT(7)
#define BIT_TXDMA_ERROR_PULSE_8822B BIT(6)
#define BIT_TXDMA_STUCK_ERROR_HANDLE_ENABLE_8822B BIT(5)
#define BIT_TXDMA_RETURN_ERROR_ENABLE_8822B BIT(4)
#define BIT_RXDMA_ERROR_HANDLE_STATUS_8822B BIT(3)
#define BIT_SHIFT_AUTO_HANG_RELEASE_8822B 0
#define BIT_MASK_AUTO_HANG_RELEASE_8822B 0x7
#define BIT_AUTO_HANG_RELEASE_8822B(x) \
(((x) & BIT_MASK_AUTO_HANG_RELEASE_8822B) \
<< BIT_SHIFT_AUTO_HANG_RELEASE_8822B)
#define BITS_AUTO_HANG_RELEASE_8822B \
(BIT_MASK_AUTO_HANG_RELEASE_8822B << BIT_SHIFT_AUTO_HANG_RELEASE_8822B)
#define BIT_CLEAR_AUTO_HANG_RELEASE_8822B(x) \
((x) & (~BITS_AUTO_HANG_RELEASE_8822B))
#define BIT_GET_AUTO_HANG_RELEASE_8822B(x) \
(((x) >> BIT_SHIFT_AUTO_HANG_RELEASE_8822B) & \
BIT_MASK_AUTO_HANG_RELEASE_8822B)
#define BIT_SET_AUTO_HANG_RELEASE_8822B(x, v) \
(BIT_CLEAR_AUTO_HANG_RELEASE_8822B(x) | BIT_AUTO_HANG_RELEASE_8822B(v))
/* 2 REG_OLD_DEHANG_8822B */
#define BIT_OLD_DEHANG_8822B BIT(1)
/* 2 REG_Q0_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q0_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q0_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q0_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q0_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q0_V1_8822B)
#define BITS_QUEUEMACID_Q0_V1_8822B \
(BIT_MASK_QUEUEMACID_Q0_V1_8822B << BIT_SHIFT_QUEUEMACID_Q0_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q0_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q0_V1_8822B))
#define BIT_GET_QUEUEMACID_Q0_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q0_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q0_V1_8822B)
#define BIT_SET_QUEUEMACID_Q0_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q0_V1_8822B(x) | BIT_QUEUEMACID_Q0_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q0_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q0_V1_8822B 0x3
#define BIT_QUEUEAC_Q0_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q0_V1_8822B) << BIT_SHIFT_QUEUEAC_Q0_V1_8822B)
#define BITS_QUEUEAC_Q0_V1_8822B \
(BIT_MASK_QUEUEAC_Q0_V1_8822B << BIT_SHIFT_QUEUEAC_Q0_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q0_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q0_V1_8822B))
#define BIT_GET_QUEUEAC_Q0_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q0_V1_8822B) & BIT_MASK_QUEUEAC_Q0_V1_8822B)
#define BIT_SET_QUEUEAC_Q0_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q0_V1_8822B(x) | BIT_QUEUEAC_Q0_V1_8822B(v))
#define BIT_TIDEMPTY_Q0_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q0_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q0_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q0_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q0_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q0_V2_8822B)
#define BITS_TAIL_PKT_Q0_V2_8822B \
(BIT_MASK_TAIL_PKT_Q0_V2_8822B << BIT_SHIFT_TAIL_PKT_Q0_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q0_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q0_V2_8822B))
#define BIT_GET_TAIL_PKT_Q0_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q0_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q0_V2_8822B)
#define BIT_SET_TAIL_PKT_Q0_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q0_V2_8822B(x) | BIT_TAIL_PKT_Q0_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q0_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q0_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q0_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q0_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q0_V1_8822B)
#define BITS_HEAD_PKT_Q0_V1_8822B \
(BIT_MASK_HEAD_PKT_Q0_V1_8822B << BIT_SHIFT_HEAD_PKT_Q0_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q0_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q0_V1_8822B))
#define BIT_GET_HEAD_PKT_Q0_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q0_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q0_V1_8822B)
#define BIT_SET_HEAD_PKT_Q0_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q0_V1_8822B(x) | BIT_HEAD_PKT_Q0_V1_8822B(v))
/* 2 REG_Q1_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q1_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q1_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q1_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q1_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q1_V1_8822B)
#define BITS_QUEUEMACID_Q1_V1_8822B \
(BIT_MASK_QUEUEMACID_Q1_V1_8822B << BIT_SHIFT_QUEUEMACID_Q1_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q1_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q1_V1_8822B))
#define BIT_GET_QUEUEMACID_Q1_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q1_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q1_V1_8822B)
#define BIT_SET_QUEUEMACID_Q1_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q1_V1_8822B(x) | BIT_QUEUEMACID_Q1_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q1_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q1_V1_8822B 0x3
#define BIT_QUEUEAC_Q1_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q1_V1_8822B) << BIT_SHIFT_QUEUEAC_Q1_V1_8822B)
#define BITS_QUEUEAC_Q1_V1_8822B \
(BIT_MASK_QUEUEAC_Q1_V1_8822B << BIT_SHIFT_QUEUEAC_Q1_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q1_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q1_V1_8822B))
#define BIT_GET_QUEUEAC_Q1_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q1_V1_8822B) & BIT_MASK_QUEUEAC_Q1_V1_8822B)
#define BIT_SET_QUEUEAC_Q1_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q1_V1_8822B(x) | BIT_QUEUEAC_Q1_V1_8822B(v))
#define BIT_TIDEMPTY_Q1_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q1_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q1_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q1_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q1_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q1_V2_8822B)
#define BITS_TAIL_PKT_Q1_V2_8822B \
(BIT_MASK_TAIL_PKT_Q1_V2_8822B << BIT_SHIFT_TAIL_PKT_Q1_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q1_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q1_V2_8822B))
#define BIT_GET_TAIL_PKT_Q1_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q1_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q1_V2_8822B)
#define BIT_SET_TAIL_PKT_Q1_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q1_V2_8822B(x) | BIT_TAIL_PKT_Q1_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q1_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q1_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q1_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q1_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q1_V1_8822B)
#define BITS_HEAD_PKT_Q1_V1_8822B \
(BIT_MASK_HEAD_PKT_Q1_V1_8822B << BIT_SHIFT_HEAD_PKT_Q1_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q1_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q1_V1_8822B))
#define BIT_GET_HEAD_PKT_Q1_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q1_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q1_V1_8822B)
#define BIT_SET_HEAD_PKT_Q1_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q1_V1_8822B(x) | BIT_HEAD_PKT_Q1_V1_8822B(v))
/* 2 REG_Q2_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q2_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q2_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q2_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q2_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q2_V1_8822B)
#define BITS_QUEUEMACID_Q2_V1_8822B \
(BIT_MASK_QUEUEMACID_Q2_V1_8822B << BIT_SHIFT_QUEUEMACID_Q2_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q2_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q2_V1_8822B))
#define BIT_GET_QUEUEMACID_Q2_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q2_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q2_V1_8822B)
#define BIT_SET_QUEUEMACID_Q2_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q2_V1_8822B(x) | BIT_QUEUEMACID_Q2_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q2_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q2_V1_8822B 0x3
#define BIT_QUEUEAC_Q2_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q2_V1_8822B) << BIT_SHIFT_QUEUEAC_Q2_V1_8822B)
#define BITS_QUEUEAC_Q2_V1_8822B \
(BIT_MASK_QUEUEAC_Q2_V1_8822B << BIT_SHIFT_QUEUEAC_Q2_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q2_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q2_V1_8822B))
#define BIT_GET_QUEUEAC_Q2_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q2_V1_8822B) & BIT_MASK_QUEUEAC_Q2_V1_8822B)
#define BIT_SET_QUEUEAC_Q2_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q2_V1_8822B(x) | BIT_QUEUEAC_Q2_V1_8822B(v))
#define BIT_TIDEMPTY_Q2_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q2_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q2_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q2_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q2_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q2_V2_8822B)
#define BITS_TAIL_PKT_Q2_V2_8822B \
(BIT_MASK_TAIL_PKT_Q2_V2_8822B << BIT_SHIFT_TAIL_PKT_Q2_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q2_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q2_V2_8822B))
#define BIT_GET_TAIL_PKT_Q2_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q2_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q2_V2_8822B)
#define BIT_SET_TAIL_PKT_Q2_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q2_V2_8822B(x) | BIT_TAIL_PKT_Q2_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q2_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q2_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q2_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q2_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q2_V1_8822B)
#define BITS_HEAD_PKT_Q2_V1_8822B \
(BIT_MASK_HEAD_PKT_Q2_V1_8822B << BIT_SHIFT_HEAD_PKT_Q2_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q2_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q2_V1_8822B))
#define BIT_GET_HEAD_PKT_Q2_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q2_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q2_V1_8822B)
#define BIT_SET_HEAD_PKT_Q2_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q2_V1_8822B(x) | BIT_HEAD_PKT_Q2_V1_8822B(v))
/* 2 REG_Q3_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q3_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q3_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q3_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q3_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q3_V1_8822B)
#define BITS_QUEUEMACID_Q3_V1_8822B \
(BIT_MASK_QUEUEMACID_Q3_V1_8822B << BIT_SHIFT_QUEUEMACID_Q3_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q3_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q3_V1_8822B))
#define BIT_GET_QUEUEMACID_Q3_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q3_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q3_V1_8822B)
#define BIT_SET_QUEUEMACID_Q3_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q3_V1_8822B(x) | BIT_QUEUEMACID_Q3_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q3_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q3_V1_8822B 0x3
#define BIT_QUEUEAC_Q3_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q3_V1_8822B) << BIT_SHIFT_QUEUEAC_Q3_V1_8822B)
#define BITS_QUEUEAC_Q3_V1_8822B \
(BIT_MASK_QUEUEAC_Q3_V1_8822B << BIT_SHIFT_QUEUEAC_Q3_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q3_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q3_V1_8822B))
#define BIT_GET_QUEUEAC_Q3_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q3_V1_8822B) & BIT_MASK_QUEUEAC_Q3_V1_8822B)
#define BIT_SET_QUEUEAC_Q3_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q3_V1_8822B(x) | BIT_QUEUEAC_Q3_V1_8822B(v))
#define BIT_TIDEMPTY_Q3_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q3_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q3_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q3_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q3_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q3_V2_8822B)
#define BITS_TAIL_PKT_Q3_V2_8822B \
(BIT_MASK_TAIL_PKT_Q3_V2_8822B << BIT_SHIFT_TAIL_PKT_Q3_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q3_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q3_V2_8822B))
#define BIT_GET_TAIL_PKT_Q3_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q3_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q3_V2_8822B)
#define BIT_SET_TAIL_PKT_Q3_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q3_V2_8822B(x) | BIT_TAIL_PKT_Q3_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q3_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q3_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q3_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q3_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q3_V1_8822B)
#define BITS_HEAD_PKT_Q3_V1_8822B \
(BIT_MASK_HEAD_PKT_Q3_V1_8822B << BIT_SHIFT_HEAD_PKT_Q3_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q3_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q3_V1_8822B))
#define BIT_GET_HEAD_PKT_Q3_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q3_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q3_V1_8822B)
#define BIT_SET_HEAD_PKT_Q3_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q3_V1_8822B(x) | BIT_HEAD_PKT_Q3_V1_8822B(v))
/* 2 REG_MGQ_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_MGQ_V1_8822B 25
#define BIT_MASK_QUEUEMACID_MGQ_V1_8822B 0x7f
#define BIT_QUEUEMACID_MGQ_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_MGQ_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_MGQ_V1_8822B)
#define BITS_QUEUEMACID_MGQ_V1_8822B \
(BIT_MASK_QUEUEMACID_MGQ_V1_8822B << BIT_SHIFT_QUEUEMACID_MGQ_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_MGQ_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_MGQ_V1_8822B))
#define BIT_GET_QUEUEMACID_MGQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_MGQ_V1_8822B) & \
BIT_MASK_QUEUEMACID_MGQ_V1_8822B)
#define BIT_SET_QUEUEMACID_MGQ_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_MGQ_V1_8822B(x) | BIT_QUEUEMACID_MGQ_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_MGQ_V1_8822B 23
#define BIT_MASK_QUEUEAC_MGQ_V1_8822B 0x3
#define BIT_QUEUEAC_MGQ_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_MGQ_V1_8822B) \
<< BIT_SHIFT_QUEUEAC_MGQ_V1_8822B)
#define BITS_QUEUEAC_MGQ_V1_8822B \
(BIT_MASK_QUEUEAC_MGQ_V1_8822B << BIT_SHIFT_QUEUEAC_MGQ_V1_8822B)
#define BIT_CLEAR_QUEUEAC_MGQ_V1_8822B(x) ((x) & (~BITS_QUEUEAC_MGQ_V1_8822B))
#define BIT_GET_QUEUEAC_MGQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_MGQ_V1_8822B) & \
BIT_MASK_QUEUEAC_MGQ_V1_8822B)
#define BIT_SET_QUEUEAC_MGQ_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_MGQ_V1_8822B(x) | BIT_QUEUEAC_MGQ_V1_8822B(v))
#define BIT_TIDEMPTY_MGQ_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_MGQ_V2_8822B 11
#define BIT_MASK_TAIL_PKT_MGQ_V2_8822B 0x7ff
#define BIT_TAIL_PKT_MGQ_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_MGQ_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_MGQ_V2_8822B)
#define BITS_TAIL_PKT_MGQ_V2_8822B \
(BIT_MASK_TAIL_PKT_MGQ_V2_8822B << BIT_SHIFT_TAIL_PKT_MGQ_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_MGQ_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_MGQ_V2_8822B))
#define BIT_GET_TAIL_PKT_MGQ_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_MGQ_V2_8822B) & \
BIT_MASK_TAIL_PKT_MGQ_V2_8822B)
#define BIT_SET_TAIL_PKT_MGQ_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_MGQ_V2_8822B(x) | BIT_TAIL_PKT_MGQ_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_MGQ_V1_8822B 0
#define BIT_MASK_HEAD_PKT_MGQ_V1_8822B 0x7ff
#define BIT_HEAD_PKT_MGQ_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_MGQ_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_MGQ_V1_8822B)
#define BITS_HEAD_PKT_MGQ_V1_8822B \
(BIT_MASK_HEAD_PKT_MGQ_V1_8822B << BIT_SHIFT_HEAD_PKT_MGQ_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_MGQ_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_MGQ_V1_8822B))
#define BIT_GET_HEAD_PKT_MGQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_MGQ_V1_8822B) & \
BIT_MASK_HEAD_PKT_MGQ_V1_8822B)
#define BIT_SET_HEAD_PKT_MGQ_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_MGQ_V1_8822B(x) | BIT_HEAD_PKT_MGQ_V1_8822B(v))
/* 2 REG_HIQ_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_HIQ_V1_8822B 25
#define BIT_MASK_QUEUEMACID_HIQ_V1_8822B 0x7f
#define BIT_QUEUEMACID_HIQ_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_HIQ_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_HIQ_V1_8822B)
#define BITS_QUEUEMACID_HIQ_V1_8822B \
(BIT_MASK_QUEUEMACID_HIQ_V1_8822B << BIT_SHIFT_QUEUEMACID_HIQ_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_HIQ_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_HIQ_V1_8822B))
#define BIT_GET_QUEUEMACID_HIQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_HIQ_V1_8822B) & \
BIT_MASK_QUEUEMACID_HIQ_V1_8822B)
#define BIT_SET_QUEUEMACID_HIQ_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_HIQ_V1_8822B(x) | BIT_QUEUEMACID_HIQ_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_HIQ_V1_8822B 23
#define BIT_MASK_QUEUEAC_HIQ_V1_8822B 0x3
#define BIT_QUEUEAC_HIQ_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_HIQ_V1_8822B) \
<< BIT_SHIFT_QUEUEAC_HIQ_V1_8822B)
#define BITS_QUEUEAC_HIQ_V1_8822B \
(BIT_MASK_QUEUEAC_HIQ_V1_8822B << BIT_SHIFT_QUEUEAC_HIQ_V1_8822B)
#define BIT_CLEAR_QUEUEAC_HIQ_V1_8822B(x) ((x) & (~BITS_QUEUEAC_HIQ_V1_8822B))
#define BIT_GET_QUEUEAC_HIQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_HIQ_V1_8822B) & \
BIT_MASK_QUEUEAC_HIQ_V1_8822B)
#define BIT_SET_QUEUEAC_HIQ_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_HIQ_V1_8822B(x) | BIT_QUEUEAC_HIQ_V1_8822B(v))
#define BIT_TIDEMPTY_HIQ_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_HIQ_V2_8822B 11
#define BIT_MASK_TAIL_PKT_HIQ_V2_8822B 0x7ff
#define BIT_TAIL_PKT_HIQ_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_HIQ_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_HIQ_V2_8822B)
#define BITS_TAIL_PKT_HIQ_V2_8822B \
(BIT_MASK_TAIL_PKT_HIQ_V2_8822B << BIT_SHIFT_TAIL_PKT_HIQ_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_HIQ_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_HIQ_V2_8822B))
#define BIT_GET_TAIL_PKT_HIQ_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_HIQ_V2_8822B) & \
BIT_MASK_TAIL_PKT_HIQ_V2_8822B)
#define BIT_SET_TAIL_PKT_HIQ_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_HIQ_V2_8822B(x) | BIT_TAIL_PKT_HIQ_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_HIQ_V1_8822B 0
#define BIT_MASK_HEAD_PKT_HIQ_V1_8822B 0x7ff
#define BIT_HEAD_PKT_HIQ_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_HIQ_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_HIQ_V1_8822B)
#define BITS_HEAD_PKT_HIQ_V1_8822B \
(BIT_MASK_HEAD_PKT_HIQ_V1_8822B << BIT_SHIFT_HEAD_PKT_HIQ_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_HIQ_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_HIQ_V1_8822B))
#define BIT_GET_HEAD_PKT_HIQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_HIQ_V1_8822B) & \
BIT_MASK_HEAD_PKT_HIQ_V1_8822B)
#define BIT_SET_HEAD_PKT_HIQ_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_HIQ_V1_8822B(x) | BIT_HEAD_PKT_HIQ_V1_8822B(v))
/* 2 REG_BCNQ_INFO_8822B */
#define BIT_SHIFT_BCNQ_HEAD_PG_V1_8822B 0
#define BIT_MASK_BCNQ_HEAD_PG_V1_8822B 0xfff
#define BIT_BCNQ_HEAD_PG_V1_8822B(x) \
(((x) & BIT_MASK_BCNQ_HEAD_PG_V1_8822B) \
<< BIT_SHIFT_BCNQ_HEAD_PG_V1_8822B)
#define BITS_BCNQ_HEAD_PG_V1_8822B \
(BIT_MASK_BCNQ_HEAD_PG_V1_8822B << BIT_SHIFT_BCNQ_HEAD_PG_V1_8822B)
#define BIT_CLEAR_BCNQ_HEAD_PG_V1_8822B(x) ((x) & (~BITS_BCNQ_HEAD_PG_V1_8822B))
#define BIT_GET_BCNQ_HEAD_PG_V1_8822B(x) \
(((x) >> BIT_SHIFT_BCNQ_HEAD_PG_V1_8822B) & \
BIT_MASK_BCNQ_HEAD_PG_V1_8822B)
#define BIT_SET_BCNQ_HEAD_PG_V1_8822B(x, v) \
(BIT_CLEAR_BCNQ_HEAD_PG_V1_8822B(x) | BIT_BCNQ_HEAD_PG_V1_8822B(v))
/* 2 REG_TXPKT_EMPTY_8822B */
#define BIT_BCNQ_EMPTY_8822B BIT(11)
#define BIT_HQQ_EMPTY_8822B BIT(10)
#define BIT_MQQ_EMPTY_8822B BIT(9)
#define BIT_MGQ_CPU_EMPTY_8822B BIT(8)
#define BIT_AC7Q_EMPTY_8822B BIT(7)
#define BIT_AC6Q_EMPTY_8822B BIT(6)
#define BIT_AC5Q_EMPTY_8822B BIT(5)
#define BIT_AC4Q_EMPTY_8822B BIT(4)
#define BIT_AC3Q_EMPTY_8822B BIT(3)
#define BIT_AC2Q_EMPTY_8822B BIT(2)
#define BIT_AC1Q_EMPTY_8822B BIT(1)
#define BIT_AC0Q_EMPTY_8822B BIT(0)
/* 2 REG_CPU_MGQ_INFO_8822B */
#define BIT_BCN1_POLL_8822B BIT(30)
#define BIT_CPUMGT_POLL_8822B BIT(29)
#define BIT_BCN_POLL_8822B BIT(28)
#define BIT_CPUMGQ_FW_NUM_V1_8822B BIT(12)
#define BIT_SHIFT_FW_FREE_TAIL_V1_8822B 0
#define BIT_MASK_FW_FREE_TAIL_V1_8822B 0xfff
#define BIT_FW_FREE_TAIL_V1_8822B(x) \
(((x) & BIT_MASK_FW_FREE_TAIL_V1_8822B) \
<< BIT_SHIFT_FW_FREE_TAIL_V1_8822B)
#define BITS_FW_FREE_TAIL_V1_8822B \
(BIT_MASK_FW_FREE_TAIL_V1_8822B << BIT_SHIFT_FW_FREE_TAIL_V1_8822B)
#define BIT_CLEAR_FW_FREE_TAIL_V1_8822B(x) ((x) & (~BITS_FW_FREE_TAIL_V1_8822B))
#define BIT_GET_FW_FREE_TAIL_V1_8822B(x) \
(((x) >> BIT_SHIFT_FW_FREE_TAIL_V1_8822B) & \
BIT_MASK_FW_FREE_TAIL_V1_8822B)
#define BIT_SET_FW_FREE_TAIL_V1_8822B(x, v) \
(BIT_CLEAR_FW_FREE_TAIL_V1_8822B(x) | BIT_FW_FREE_TAIL_V1_8822B(v))
/* 2 REG_FWHW_TXQ_CTRL_8822B */
#define BIT_RTS_LIMIT_IN_OFDM_8822B BIT(23)
#define BIT_EN_BCNQ_DL_8822B BIT(22)
#define BIT_EN_RD_RESP_NAV_BK_8822B BIT(21)
#define BIT_EN_WR_FREE_TAIL_8822B BIT(20)
#define BIT_SHIFT_EN_QUEUE_RPT_8822B 8
#define BIT_MASK_EN_QUEUE_RPT_8822B 0xff
#define BIT_EN_QUEUE_RPT_8822B(x) \
(((x) & BIT_MASK_EN_QUEUE_RPT_8822B) << BIT_SHIFT_EN_QUEUE_RPT_8822B)
#define BITS_EN_QUEUE_RPT_8822B \
(BIT_MASK_EN_QUEUE_RPT_8822B << BIT_SHIFT_EN_QUEUE_RPT_8822B)
#define BIT_CLEAR_EN_QUEUE_RPT_8822B(x) ((x) & (~BITS_EN_QUEUE_RPT_8822B))
#define BIT_GET_EN_QUEUE_RPT_8822B(x) \
(((x) >> BIT_SHIFT_EN_QUEUE_RPT_8822B) & BIT_MASK_EN_QUEUE_RPT_8822B)
#define BIT_SET_EN_QUEUE_RPT_8822B(x, v) \
(BIT_CLEAR_EN_QUEUE_RPT_8822B(x) | BIT_EN_QUEUE_RPT_8822B(v))
#define BIT_EN_RTY_BK_8822B BIT(7)
#define BIT_EN_USE_INI_RAT_8822B BIT(6)
#define BIT_EN_RTS_NAV_BK_8822B BIT(5)
#define BIT_DIS_SSN_CHECK_8822B BIT(4)
#define BIT_MACID_MATCH_RTS_8822B BIT(3)
#define BIT_EN_BCN_TRXRPT_V1_8822B BIT(2)
#define BIT_EN_FTMACKRPT_8822B BIT(1)
#define BIT_EN_FTMRPT_8822B BIT(0)
/* 2 REG_DATAFB_SEL_8822B */
#define BIT_SHIFT__R_DATA_FALLBACK_SEL_8822B 0
#define BIT_MASK__R_DATA_FALLBACK_SEL_8822B 0x3
#define BIT__R_DATA_FALLBACK_SEL_8822B(x) \
(((x) & BIT_MASK__R_DATA_FALLBACK_SEL_8822B) \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8822B)
#define BITS__R_DATA_FALLBACK_SEL_8822B \
(BIT_MASK__R_DATA_FALLBACK_SEL_8822B \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8822B)
#define BIT_CLEAR__R_DATA_FALLBACK_SEL_8822B(x) \
((x) & (~BITS__R_DATA_FALLBACK_SEL_8822B))
#define BIT_GET__R_DATA_FALLBACK_SEL_8822B(x) \
(((x) >> BIT_SHIFT__R_DATA_FALLBACK_SEL_8822B) & \
BIT_MASK__R_DATA_FALLBACK_SEL_8822B)
#define BIT_SET__R_DATA_FALLBACK_SEL_8822B(x, v) \
(BIT_CLEAR__R_DATA_FALLBACK_SEL_8822B(x) | \
BIT__R_DATA_FALLBACK_SEL_8822B(v))
/* 2 REG_BCNQ_BDNY_V1_8822B */
#define BIT_SHIFT_BCNQ_PGBNDY_V1_8822B 0
#define BIT_MASK_BCNQ_PGBNDY_V1_8822B 0xfff
#define BIT_BCNQ_PGBNDY_V1_8822B(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_V1_8822B) \
<< BIT_SHIFT_BCNQ_PGBNDY_V1_8822B)
#define BITS_BCNQ_PGBNDY_V1_8822B \
(BIT_MASK_BCNQ_PGBNDY_V1_8822B << BIT_SHIFT_BCNQ_PGBNDY_V1_8822B)
#define BIT_CLEAR_BCNQ_PGBNDY_V1_8822B(x) ((x) & (~BITS_BCNQ_PGBNDY_V1_8822B))
#define BIT_GET_BCNQ_PGBNDY_V1_8822B(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_V1_8822B) & \
BIT_MASK_BCNQ_PGBNDY_V1_8822B)
#define BIT_SET_BCNQ_PGBNDY_V1_8822B(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_V1_8822B(x) | BIT_BCNQ_PGBNDY_V1_8822B(v))
/* 2 REG_LIFETIME_EN_8822B */
#define BIT_BT_INT_CPU_8822B BIT(7)
#define BIT_BT_INT_PTA_8822B BIT(6)
#define BIT_EN_CTRL_RTYBIT_8822B BIT(4)
#define BIT_LIFETIME_BK_EN_8822B BIT(3)
#define BIT_LIFETIME_BE_EN_8822B BIT(2)
#define BIT_LIFETIME_VI_EN_8822B BIT(1)
#define BIT_LIFETIME_VO_EN_8822B BIT(0)
/* 2 REG_SPEC_SIFS_8822B */
#define BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822B 8
#define BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822B 0xff
#define BIT_SPEC_SIFS_OFDM_PTCL_8822B(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822B) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822B)
#define BITS_SPEC_SIFS_OFDM_PTCL_8822B \
(BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822B \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822B)
#define BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8822B(x) \
((x) & (~BITS_SPEC_SIFS_OFDM_PTCL_8822B))
#define BIT_GET_SPEC_SIFS_OFDM_PTCL_8822B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822B) & \
BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822B)
#define BIT_SET_SPEC_SIFS_OFDM_PTCL_8822B(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8822B(x) | \
BIT_SPEC_SIFS_OFDM_PTCL_8822B(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822B 0
#define BIT_MASK_SPEC_SIFS_CCK_PTCL_8822B 0xff
#define BIT_SPEC_SIFS_CCK_PTCL_8822B(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_PTCL_8822B) \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822B)
#define BITS_SPEC_SIFS_CCK_PTCL_8822B \
(BIT_MASK_SPEC_SIFS_CCK_PTCL_8822B \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822B)
#define BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8822B(x) \
((x) & (~BITS_SPEC_SIFS_CCK_PTCL_8822B))
#define BIT_GET_SPEC_SIFS_CCK_PTCL_8822B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822B) & \
BIT_MASK_SPEC_SIFS_CCK_PTCL_8822B)
#define BIT_SET_SPEC_SIFS_CCK_PTCL_8822B(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8822B(x) | \
BIT_SPEC_SIFS_CCK_PTCL_8822B(v))
/* 2 REG_RETRY_LIMIT_8822B */
#define BIT_SHIFT_SRL_8822B 8
#define BIT_MASK_SRL_8822B 0x3f
#define BIT_SRL_8822B(x) (((x) & BIT_MASK_SRL_8822B) << BIT_SHIFT_SRL_8822B)
#define BITS_SRL_8822B (BIT_MASK_SRL_8822B << BIT_SHIFT_SRL_8822B)
#define BIT_CLEAR_SRL_8822B(x) ((x) & (~BITS_SRL_8822B))
#define BIT_GET_SRL_8822B(x) (((x) >> BIT_SHIFT_SRL_8822B) & BIT_MASK_SRL_8822B)
#define BIT_SET_SRL_8822B(x, v) (BIT_CLEAR_SRL_8822B(x) | BIT_SRL_8822B(v))
#define BIT_SHIFT_LRL_8822B 0
#define BIT_MASK_LRL_8822B 0x3f
#define BIT_LRL_8822B(x) (((x) & BIT_MASK_LRL_8822B) << BIT_SHIFT_LRL_8822B)
#define BITS_LRL_8822B (BIT_MASK_LRL_8822B << BIT_SHIFT_LRL_8822B)
#define BIT_CLEAR_LRL_8822B(x) ((x) & (~BITS_LRL_8822B))
#define BIT_GET_LRL_8822B(x) (((x) >> BIT_SHIFT_LRL_8822B) & BIT_MASK_LRL_8822B)
#define BIT_SET_LRL_8822B(x, v) (BIT_CLEAR_LRL_8822B(x) | BIT_LRL_8822B(v))
/* 2 REG_TXBF_CTRL_8822B */
#define BIT_R_ENABLE_NDPA_8822B BIT(31)
#define BIT_USE_NDPA_PARAMETER_8822B BIT(30)
#define BIT_R_PROP_TXBF_8822B BIT(29)
#define BIT_R_EN_NDPA_INT_8822B BIT(28)
#define BIT_R_TXBF1_80M_8822B BIT(27)
#define BIT_R_TXBF1_40M_8822B BIT(26)
#define BIT_R_TXBF1_20M_8822B BIT(25)
#define BIT_SHIFT_R_TXBF1_AID_8822B 16
#define BIT_MASK_R_TXBF1_AID_8822B 0x1ff
#define BIT_R_TXBF1_AID_8822B(x) \
(((x) & BIT_MASK_R_TXBF1_AID_8822B) << BIT_SHIFT_R_TXBF1_AID_8822B)
#define BITS_R_TXBF1_AID_8822B \
(BIT_MASK_R_TXBF1_AID_8822B << BIT_SHIFT_R_TXBF1_AID_8822B)
#define BIT_CLEAR_R_TXBF1_AID_8822B(x) ((x) & (~BITS_R_TXBF1_AID_8822B))
#define BIT_GET_R_TXBF1_AID_8822B(x) \
(((x) >> BIT_SHIFT_R_TXBF1_AID_8822B) & BIT_MASK_R_TXBF1_AID_8822B)
#define BIT_SET_R_TXBF1_AID_8822B(x, v) \
(BIT_CLEAR_R_TXBF1_AID_8822B(x) | BIT_R_TXBF1_AID_8822B(v))
#define BIT_DIS_NDP_BFEN_8822B BIT(15)
#define BIT_R_TXBCN_NOBLOCK_NDP_8822B BIT(14)
#define BIT_R_TXBF0_80M_8822B BIT(11)
#define BIT_R_TXBF0_40M_8822B BIT(10)
#define BIT_R_TXBF0_20M_8822B BIT(9)
#define BIT_SHIFT_R_TXBF0_AID_8822B 0
#define BIT_MASK_R_TXBF0_AID_8822B 0x1ff
#define BIT_R_TXBF0_AID_8822B(x) \
(((x) & BIT_MASK_R_TXBF0_AID_8822B) << BIT_SHIFT_R_TXBF0_AID_8822B)
#define BITS_R_TXBF0_AID_8822B \
(BIT_MASK_R_TXBF0_AID_8822B << BIT_SHIFT_R_TXBF0_AID_8822B)
#define BIT_CLEAR_R_TXBF0_AID_8822B(x) ((x) & (~BITS_R_TXBF0_AID_8822B))
#define BIT_GET_R_TXBF0_AID_8822B(x) \
(((x) >> BIT_SHIFT_R_TXBF0_AID_8822B) & BIT_MASK_R_TXBF0_AID_8822B)
#define BIT_SET_R_TXBF0_AID_8822B(x, v) \
(BIT_CLEAR_R_TXBF0_AID_8822B(x) | BIT_R_TXBF0_AID_8822B(v))
/* 2 REG_DARFRC_8822B */
#define BIT_SHIFT_DARF_RC8_8822B (56 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC8_8822B 0x1f
#define BIT_DARF_RC8_8822B(x) \
(((x) & BIT_MASK_DARF_RC8_8822B) << BIT_SHIFT_DARF_RC8_8822B)
#define BITS_DARF_RC8_8822B \
(BIT_MASK_DARF_RC8_8822B << BIT_SHIFT_DARF_RC8_8822B)
#define BIT_CLEAR_DARF_RC8_8822B(x) ((x) & (~BITS_DARF_RC8_8822B))
#define BIT_GET_DARF_RC8_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC8_8822B) & BIT_MASK_DARF_RC8_8822B)
#define BIT_SET_DARF_RC8_8822B(x, v) \
(BIT_CLEAR_DARF_RC8_8822B(x) | BIT_DARF_RC8_8822B(v))
#define BIT_SHIFT_DARF_RC7_8822B (48 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC7_8822B 0x1f
#define BIT_DARF_RC7_8822B(x) \
(((x) & BIT_MASK_DARF_RC7_8822B) << BIT_SHIFT_DARF_RC7_8822B)
#define BITS_DARF_RC7_8822B \
(BIT_MASK_DARF_RC7_8822B << BIT_SHIFT_DARF_RC7_8822B)
#define BIT_CLEAR_DARF_RC7_8822B(x) ((x) & (~BITS_DARF_RC7_8822B))
#define BIT_GET_DARF_RC7_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC7_8822B) & BIT_MASK_DARF_RC7_8822B)
#define BIT_SET_DARF_RC7_8822B(x, v) \
(BIT_CLEAR_DARF_RC7_8822B(x) | BIT_DARF_RC7_8822B(v))
#define BIT_SHIFT_DARF_RC6_8822B (40 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC6_8822B 0x1f
#define BIT_DARF_RC6_8822B(x) \
(((x) & BIT_MASK_DARF_RC6_8822B) << BIT_SHIFT_DARF_RC6_8822B)
#define BITS_DARF_RC6_8822B \
(BIT_MASK_DARF_RC6_8822B << BIT_SHIFT_DARF_RC6_8822B)
#define BIT_CLEAR_DARF_RC6_8822B(x) ((x) & (~BITS_DARF_RC6_8822B))
#define BIT_GET_DARF_RC6_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC6_8822B) & BIT_MASK_DARF_RC6_8822B)
#define BIT_SET_DARF_RC6_8822B(x, v) \
(BIT_CLEAR_DARF_RC6_8822B(x) | BIT_DARF_RC6_8822B(v))
#define BIT_SHIFT_DARF_RC5_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_DARF_RC5_8822B 0x1f
#define BIT_DARF_RC5_8822B(x) \
(((x) & BIT_MASK_DARF_RC5_8822B) << BIT_SHIFT_DARF_RC5_8822B)
#define BITS_DARF_RC5_8822B \
(BIT_MASK_DARF_RC5_8822B << BIT_SHIFT_DARF_RC5_8822B)
#define BIT_CLEAR_DARF_RC5_8822B(x) ((x) & (~BITS_DARF_RC5_8822B))
#define BIT_GET_DARF_RC5_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC5_8822B) & BIT_MASK_DARF_RC5_8822B)
#define BIT_SET_DARF_RC5_8822B(x, v) \
(BIT_CLEAR_DARF_RC5_8822B(x) | BIT_DARF_RC5_8822B(v))
#define BIT_SHIFT_DARF_RC4_8822B 24
#define BIT_MASK_DARF_RC4_8822B 0x1f
#define BIT_DARF_RC4_8822B(x) \
(((x) & BIT_MASK_DARF_RC4_8822B) << BIT_SHIFT_DARF_RC4_8822B)
#define BITS_DARF_RC4_8822B \
(BIT_MASK_DARF_RC4_8822B << BIT_SHIFT_DARF_RC4_8822B)
#define BIT_CLEAR_DARF_RC4_8822B(x) ((x) & (~BITS_DARF_RC4_8822B))
#define BIT_GET_DARF_RC4_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC4_8822B) & BIT_MASK_DARF_RC4_8822B)
#define BIT_SET_DARF_RC4_8822B(x, v) \
(BIT_CLEAR_DARF_RC4_8822B(x) | BIT_DARF_RC4_8822B(v))
#define BIT_SHIFT_DARF_RC3_8822B 16
#define BIT_MASK_DARF_RC3_8822B 0x1f
#define BIT_DARF_RC3_8822B(x) \
(((x) & BIT_MASK_DARF_RC3_8822B) << BIT_SHIFT_DARF_RC3_8822B)
#define BITS_DARF_RC3_8822B \
(BIT_MASK_DARF_RC3_8822B << BIT_SHIFT_DARF_RC3_8822B)
#define BIT_CLEAR_DARF_RC3_8822B(x) ((x) & (~BITS_DARF_RC3_8822B))
#define BIT_GET_DARF_RC3_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC3_8822B) & BIT_MASK_DARF_RC3_8822B)
#define BIT_SET_DARF_RC3_8822B(x, v) \
(BIT_CLEAR_DARF_RC3_8822B(x) | BIT_DARF_RC3_8822B(v))
#define BIT_SHIFT_DARF_RC2_8822B 8
#define BIT_MASK_DARF_RC2_8822B 0x1f
#define BIT_DARF_RC2_8822B(x) \
(((x) & BIT_MASK_DARF_RC2_8822B) << BIT_SHIFT_DARF_RC2_8822B)
#define BITS_DARF_RC2_8822B \
(BIT_MASK_DARF_RC2_8822B << BIT_SHIFT_DARF_RC2_8822B)
#define BIT_CLEAR_DARF_RC2_8822B(x) ((x) & (~BITS_DARF_RC2_8822B))
#define BIT_GET_DARF_RC2_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC2_8822B) & BIT_MASK_DARF_RC2_8822B)
#define BIT_SET_DARF_RC2_8822B(x, v) \
(BIT_CLEAR_DARF_RC2_8822B(x) | BIT_DARF_RC2_8822B(v))
#define BIT_SHIFT_DARF_RC1_8822B 0
#define BIT_MASK_DARF_RC1_8822B 0x1f
#define BIT_DARF_RC1_8822B(x) \
(((x) & BIT_MASK_DARF_RC1_8822B) << BIT_SHIFT_DARF_RC1_8822B)
#define BITS_DARF_RC1_8822B \
(BIT_MASK_DARF_RC1_8822B << BIT_SHIFT_DARF_RC1_8822B)
#define BIT_CLEAR_DARF_RC1_8822B(x) ((x) & (~BITS_DARF_RC1_8822B))
#define BIT_GET_DARF_RC1_8822B(x) \
(((x) >> BIT_SHIFT_DARF_RC1_8822B) & BIT_MASK_DARF_RC1_8822B)
#define BIT_SET_DARF_RC1_8822B(x, v) \
(BIT_CLEAR_DARF_RC1_8822B(x) | BIT_DARF_RC1_8822B(v))
/* 2 REG_RARFRC_8822B */
#define BIT_SHIFT_RARF_RC8_8822B (56 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC8_8822B 0x1f
#define BIT_RARF_RC8_8822B(x) \
(((x) & BIT_MASK_RARF_RC8_8822B) << BIT_SHIFT_RARF_RC8_8822B)
#define BITS_RARF_RC8_8822B \
(BIT_MASK_RARF_RC8_8822B << BIT_SHIFT_RARF_RC8_8822B)
#define BIT_CLEAR_RARF_RC8_8822B(x) ((x) & (~BITS_RARF_RC8_8822B))
#define BIT_GET_RARF_RC8_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC8_8822B) & BIT_MASK_RARF_RC8_8822B)
#define BIT_SET_RARF_RC8_8822B(x, v) \
(BIT_CLEAR_RARF_RC8_8822B(x) | BIT_RARF_RC8_8822B(v))
#define BIT_SHIFT_RARF_RC7_8822B (48 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC7_8822B 0x1f
#define BIT_RARF_RC7_8822B(x) \
(((x) & BIT_MASK_RARF_RC7_8822B) << BIT_SHIFT_RARF_RC7_8822B)
#define BITS_RARF_RC7_8822B \
(BIT_MASK_RARF_RC7_8822B << BIT_SHIFT_RARF_RC7_8822B)
#define BIT_CLEAR_RARF_RC7_8822B(x) ((x) & (~BITS_RARF_RC7_8822B))
#define BIT_GET_RARF_RC7_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC7_8822B) & BIT_MASK_RARF_RC7_8822B)
#define BIT_SET_RARF_RC7_8822B(x, v) \
(BIT_CLEAR_RARF_RC7_8822B(x) | BIT_RARF_RC7_8822B(v))
#define BIT_SHIFT_RARF_RC6_8822B (40 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC6_8822B 0x1f
#define BIT_RARF_RC6_8822B(x) \
(((x) & BIT_MASK_RARF_RC6_8822B) << BIT_SHIFT_RARF_RC6_8822B)
#define BITS_RARF_RC6_8822B \
(BIT_MASK_RARF_RC6_8822B << BIT_SHIFT_RARF_RC6_8822B)
#define BIT_CLEAR_RARF_RC6_8822B(x) ((x) & (~BITS_RARF_RC6_8822B))
#define BIT_GET_RARF_RC6_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC6_8822B) & BIT_MASK_RARF_RC6_8822B)
#define BIT_SET_RARF_RC6_8822B(x, v) \
(BIT_CLEAR_RARF_RC6_8822B(x) | BIT_RARF_RC6_8822B(v))
#define BIT_SHIFT_RARF_RC5_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_RARF_RC5_8822B 0x1f
#define BIT_RARF_RC5_8822B(x) \
(((x) & BIT_MASK_RARF_RC5_8822B) << BIT_SHIFT_RARF_RC5_8822B)
#define BITS_RARF_RC5_8822B \
(BIT_MASK_RARF_RC5_8822B << BIT_SHIFT_RARF_RC5_8822B)
#define BIT_CLEAR_RARF_RC5_8822B(x) ((x) & (~BITS_RARF_RC5_8822B))
#define BIT_GET_RARF_RC5_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC5_8822B) & BIT_MASK_RARF_RC5_8822B)
#define BIT_SET_RARF_RC5_8822B(x, v) \
(BIT_CLEAR_RARF_RC5_8822B(x) | BIT_RARF_RC5_8822B(v))
#define BIT_SHIFT_RARF_RC4_8822B 24
#define BIT_MASK_RARF_RC4_8822B 0x1f
#define BIT_RARF_RC4_8822B(x) \
(((x) & BIT_MASK_RARF_RC4_8822B) << BIT_SHIFT_RARF_RC4_8822B)
#define BITS_RARF_RC4_8822B \
(BIT_MASK_RARF_RC4_8822B << BIT_SHIFT_RARF_RC4_8822B)
#define BIT_CLEAR_RARF_RC4_8822B(x) ((x) & (~BITS_RARF_RC4_8822B))
#define BIT_GET_RARF_RC4_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC4_8822B) & BIT_MASK_RARF_RC4_8822B)
#define BIT_SET_RARF_RC4_8822B(x, v) \
(BIT_CLEAR_RARF_RC4_8822B(x) | BIT_RARF_RC4_8822B(v))
#define BIT_SHIFT_RARF_RC3_8822B 16
#define BIT_MASK_RARF_RC3_8822B 0x1f
#define BIT_RARF_RC3_8822B(x) \
(((x) & BIT_MASK_RARF_RC3_8822B) << BIT_SHIFT_RARF_RC3_8822B)
#define BITS_RARF_RC3_8822B \
(BIT_MASK_RARF_RC3_8822B << BIT_SHIFT_RARF_RC3_8822B)
#define BIT_CLEAR_RARF_RC3_8822B(x) ((x) & (~BITS_RARF_RC3_8822B))
#define BIT_GET_RARF_RC3_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC3_8822B) & BIT_MASK_RARF_RC3_8822B)
#define BIT_SET_RARF_RC3_8822B(x, v) \
(BIT_CLEAR_RARF_RC3_8822B(x) | BIT_RARF_RC3_8822B(v))
#define BIT_SHIFT_RARF_RC2_8822B 8
#define BIT_MASK_RARF_RC2_8822B 0x1f
#define BIT_RARF_RC2_8822B(x) \
(((x) & BIT_MASK_RARF_RC2_8822B) << BIT_SHIFT_RARF_RC2_8822B)
#define BITS_RARF_RC2_8822B \
(BIT_MASK_RARF_RC2_8822B << BIT_SHIFT_RARF_RC2_8822B)
#define BIT_CLEAR_RARF_RC2_8822B(x) ((x) & (~BITS_RARF_RC2_8822B))
#define BIT_GET_RARF_RC2_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC2_8822B) & BIT_MASK_RARF_RC2_8822B)
#define BIT_SET_RARF_RC2_8822B(x, v) \
(BIT_CLEAR_RARF_RC2_8822B(x) | BIT_RARF_RC2_8822B(v))
#define BIT_SHIFT_RARF_RC1_8822B 0
#define BIT_MASK_RARF_RC1_8822B 0x1f
#define BIT_RARF_RC1_8822B(x) \
(((x) & BIT_MASK_RARF_RC1_8822B) << BIT_SHIFT_RARF_RC1_8822B)
#define BITS_RARF_RC1_8822B \
(BIT_MASK_RARF_RC1_8822B << BIT_SHIFT_RARF_RC1_8822B)
#define BIT_CLEAR_RARF_RC1_8822B(x) ((x) & (~BITS_RARF_RC1_8822B))
#define BIT_GET_RARF_RC1_8822B(x) \
(((x) >> BIT_SHIFT_RARF_RC1_8822B) & BIT_MASK_RARF_RC1_8822B)
#define BIT_SET_RARF_RC1_8822B(x, v) \
(BIT_CLEAR_RARF_RC1_8822B(x) | BIT_RARF_RC1_8822B(v))
/* 2 REG_RRSR_8822B */
#define BIT_SHIFT_RRSR_RSC_8822B 21
#define BIT_MASK_RRSR_RSC_8822B 0x3
#define BIT_RRSR_RSC_8822B(x) \
(((x) & BIT_MASK_RRSR_RSC_8822B) << BIT_SHIFT_RRSR_RSC_8822B)
#define BITS_RRSR_RSC_8822B \
(BIT_MASK_RRSR_RSC_8822B << BIT_SHIFT_RRSR_RSC_8822B)
#define BIT_CLEAR_RRSR_RSC_8822B(x) ((x) & (~BITS_RRSR_RSC_8822B))
#define BIT_GET_RRSR_RSC_8822B(x) \
(((x) >> BIT_SHIFT_RRSR_RSC_8822B) & BIT_MASK_RRSR_RSC_8822B)
#define BIT_SET_RRSR_RSC_8822B(x, v) \
(BIT_CLEAR_RRSR_RSC_8822B(x) | BIT_RRSR_RSC_8822B(v))
#define BIT_RRSR_BW_8822B BIT(20)
#define BIT_SHIFT_RRSC_BITMAP_8822B 0
#define BIT_MASK_RRSC_BITMAP_8822B 0xfffff
#define BIT_RRSC_BITMAP_8822B(x) \
(((x) & BIT_MASK_RRSC_BITMAP_8822B) << BIT_SHIFT_RRSC_BITMAP_8822B)
#define BITS_RRSC_BITMAP_8822B \
(BIT_MASK_RRSC_BITMAP_8822B << BIT_SHIFT_RRSC_BITMAP_8822B)
#define BIT_CLEAR_RRSC_BITMAP_8822B(x) ((x) & (~BITS_RRSC_BITMAP_8822B))
#define BIT_GET_RRSC_BITMAP_8822B(x) \
(((x) >> BIT_SHIFT_RRSC_BITMAP_8822B) & BIT_MASK_RRSC_BITMAP_8822B)
#define BIT_SET_RRSC_BITMAP_8822B(x, v) \
(BIT_CLEAR_RRSC_BITMAP_8822B(x) | BIT_RRSC_BITMAP_8822B(v))
/* 2 REG_ARFR0_8822B */
#define BIT_SHIFT_ARFR0_V1_8822B 0
#define BIT_MASK_ARFR0_V1_8822B 0xffffffffffffffffL
#define BIT_ARFR0_V1_8822B(x) \
(((x) & BIT_MASK_ARFR0_V1_8822B) << BIT_SHIFT_ARFR0_V1_8822B)
#define BITS_ARFR0_V1_8822B \
(BIT_MASK_ARFR0_V1_8822B << BIT_SHIFT_ARFR0_V1_8822B)
#define BIT_CLEAR_ARFR0_V1_8822B(x) ((x) & (~BITS_ARFR0_V1_8822B))
#define BIT_GET_ARFR0_V1_8822B(x) \
(((x) >> BIT_SHIFT_ARFR0_V1_8822B) & BIT_MASK_ARFR0_V1_8822B)
#define BIT_SET_ARFR0_V1_8822B(x, v) \
(BIT_CLEAR_ARFR0_V1_8822B(x) | BIT_ARFR0_V1_8822B(v))
/* 2 REG_ARFR1_V1_8822B */
#define BIT_SHIFT_ARFR1_V1_8822B 0
#define BIT_MASK_ARFR1_V1_8822B 0xffffffffffffffffL
#define BIT_ARFR1_V1_8822B(x) \
(((x) & BIT_MASK_ARFR1_V1_8822B) << BIT_SHIFT_ARFR1_V1_8822B)
#define BITS_ARFR1_V1_8822B \
(BIT_MASK_ARFR1_V1_8822B << BIT_SHIFT_ARFR1_V1_8822B)
#define BIT_CLEAR_ARFR1_V1_8822B(x) ((x) & (~BITS_ARFR1_V1_8822B))
#define BIT_GET_ARFR1_V1_8822B(x) \
(((x) >> BIT_SHIFT_ARFR1_V1_8822B) & BIT_MASK_ARFR1_V1_8822B)
#define BIT_SET_ARFR1_V1_8822B(x, v) \
(BIT_CLEAR_ARFR1_V1_8822B(x) | BIT_ARFR1_V1_8822B(v))
/* 2 REG_CCK_CHECK_8822B */
#define BIT_CHECK_CCK_EN_8822B BIT(7)
#define BIT_EN_BCN_PKT_REL_8822B BIT(6)
#define BIT_BCN_PORT_SEL_8822B BIT(5)
#define BIT_MOREDATA_BYPASS_8822B BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_8822B BIT(3)
#define BIT_R_EN_SET_MOREDATA_8822B BIT(2)
#define BIT__R_DIS_CLEAR_MACID_RELEASE_8822B BIT(1)
#define BIT__R_MACID_RELEASE_EN_8822B BIT(0)
/* 2 REG_AMPDU_MAX_TIME_V1_8822B */
#define BIT_SHIFT_AMPDU_MAX_TIME_8822B 0
#define BIT_MASK_AMPDU_MAX_TIME_8822B 0xff
#define BIT_AMPDU_MAX_TIME_8822B(x) \
(((x) & BIT_MASK_AMPDU_MAX_TIME_8822B) \
<< BIT_SHIFT_AMPDU_MAX_TIME_8822B)
#define BITS_AMPDU_MAX_TIME_8822B \
(BIT_MASK_AMPDU_MAX_TIME_8822B << BIT_SHIFT_AMPDU_MAX_TIME_8822B)
#define BIT_CLEAR_AMPDU_MAX_TIME_8822B(x) ((x) & (~BITS_AMPDU_MAX_TIME_8822B))
#define BIT_GET_AMPDU_MAX_TIME_8822B(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_TIME_8822B) & \
BIT_MASK_AMPDU_MAX_TIME_8822B)
#define BIT_SET_AMPDU_MAX_TIME_8822B(x, v) \
(BIT_CLEAR_AMPDU_MAX_TIME_8822B(x) | BIT_AMPDU_MAX_TIME_8822B(v))
/* 2 REG_BCNQ1_BDNY_V1_8822B */
#define BIT_SHIFT_BCNQ1_PGBNDY_V1_8822B 0
#define BIT_MASK_BCNQ1_PGBNDY_V1_8822B 0xfff
#define BIT_BCNQ1_PGBNDY_V1_8822B(x) \
(((x) & BIT_MASK_BCNQ1_PGBNDY_V1_8822B) \
<< BIT_SHIFT_BCNQ1_PGBNDY_V1_8822B)
#define BITS_BCNQ1_PGBNDY_V1_8822B \
(BIT_MASK_BCNQ1_PGBNDY_V1_8822B << BIT_SHIFT_BCNQ1_PGBNDY_V1_8822B)
#define BIT_CLEAR_BCNQ1_PGBNDY_V1_8822B(x) ((x) & (~BITS_BCNQ1_PGBNDY_V1_8822B))
#define BIT_GET_BCNQ1_PGBNDY_V1_8822B(x) \
(((x) >> BIT_SHIFT_BCNQ1_PGBNDY_V1_8822B) & \
BIT_MASK_BCNQ1_PGBNDY_V1_8822B)
#define BIT_SET_BCNQ1_PGBNDY_V1_8822B(x, v) \
(BIT_CLEAR_BCNQ1_PGBNDY_V1_8822B(x) | BIT_BCNQ1_PGBNDY_V1_8822B(v))
/* 2 REG_AMPDU_MAX_LENGTH_8822B */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_8822B 0
#define BIT_MASK_AMPDU_MAX_LENGTH_8822B 0xffffffffL
#define BIT_AMPDU_MAX_LENGTH_8822B(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_8822B) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_8822B)
#define BITS_AMPDU_MAX_LENGTH_8822B \
(BIT_MASK_AMPDU_MAX_LENGTH_8822B << BIT_SHIFT_AMPDU_MAX_LENGTH_8822B)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_8822B(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_8822B))
#define BIT_GET_AMPDU_MAX_LENGTH_8822B(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_8822B) & \
BIT_MASK_AMPDU_MAX_LENGTH_8822B)
#define BIT_SET_AMPDU_MAX_LENGTH_8822B(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_8822B(x) | BIT_AMPDU_MAX_LENGTH_8822B(v))
/* 2 REG_ACQ_STOP_8822B */
#define BIT_AC7Q_STOP_8822B BIT(7)
#define BIT_AC6Q_STOP_8822B BIT(6)
#define BIT_AC5Q_STOP_8822B BIT(5)
#define BIT_AC4Q_STOP_8822B BIT(4)
#define BIT_AC3Q_STOP_8822B BIT(3)
#define BIT_AC2Q_STOP_8822B BIT(2)
#define BIT_AC1Q_STOP_8822B BIT(1)
#define BIT_AC0Q_STOP_8822B BIT(0)
/* 2 REG_NDPA_RATE_8822B */
#define BIT_SHIFT_R_NDPA_RATE_V1_8822B 0
#define BIT_MASK_R_NDPA_RATE_V1_8822B 0xff
#define BIT_R_NDPA_RATE_V1_8822B(x) \
(((x) & BIT_MASK_R_NDPA_RATE_V1_8822B) \
<< BIT_SHIFT_R_NDPA_RATE_V1_8822B)
#define BITS_R_NDPA_RATE_V1_8822B \
(BIT_MASK_R_NDPA_RATE_V1_8822B << BIT_SHIFT_R_NDPA_RATE_V1_8822B)
#define BIT_CLEAR_R_NDPA_RATE_V1_8822B(x) ((x) & (~BITS_R_NDPA_RATE_V1_8822B))
#define BIT_GET_R_NDPA_RATE_V1_8822B(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE_V1_8822B) & \
BIT_MASK_R_NDPA_RATE_V1_8822B)
#define BIT_SET_R_NDPA_RATE_V1_8822B(x, v) \
(BIT_CLEAR_R_NDPA_RATE_V1_8822B(x) | BIT_R_NDPA_RATE_V1_8822B(v))
/* 2 REG_TX_HANG_CTRL_8822B */
#define BIT_R_EN_GNT_BT_AWAKE_8822B BIT(3)
#define BIT_EN_EOF_V1_8822B BIT(2)
#define BIT_DIS_OQT_BLOCK_8822B BIT(1)
#define BIT_SEARCH_QUEUE_EN_8822B BIT(0)
/* 2 REG_NDPA_OPT_CTRL_8822B */
#define BIT_R_DIS_MACID_RELEASE_RTY_8822B BIT(5)
#define BIT_SHIFT_BW_SIGTA_8822B 3
#define BIT_MASK_BW_SIGTA_8822B 0x3
#define BIT_BW_SIGTA_8822B(x) \
(((x) & BIT_MASK_BW_SIGTA_8822B) << BIT_SHIFT_BW_SIGTA_8822B)
#define BITS_BW_SIGTA_8822B \
(BIT_MASK_BW_SIGTA_8822B << BIT_SHIFT_BW_SIGTA_8822B)
#define BIT_CLEAR_BW_SIGTA_8822B(x) ((x) & (~BITS_BW_SIGTA_8822B))
#define BIT_GET_BW_SIGTA_8822B(x) \
(((x) >> BIT_SHIFT_BW_SIGTA_8822B) & BIT_MASK_BW_SIGTA_8822B)
#define BIT_SET_BW_SIGTA_8822B(x, v) \
(BIT_CLEAR_BW_SIGTA_8822B(x) | BIT_BW_SIGTA_8822B(v))
#define BIT_EN_BAR_SIGTA_8822B BIT(2)
#define BIT_SHIFT_R_NDPA_BW_8822B 0
#define BIT_MASK_R_NDPA_BW_8822B 0x3
#define BIT_R_NDPA_BW_8822B(x) \
(((x) & BIT_MASK_R_NDPA_BW_8822B) << BIT_SHIFT_R_NDPA_BW_8822B)
#define BITS_R_NDPA_BW_8822B \
(BIT_MASK_R_NDPA_BW_8822B << BIT_SHIFT_R_NDPA_BW_8822B)
#define BIT_CLEAR_R_NDPA_BW_8822B(x) ((x) & (~BITS_R_NDPA_BW_8822B))
#define BIT_GET_R_NDPA_BW_8822B(x) \
(((x) >> BIT_SHIFT_R_NDPA_BW_8822B) & BIT_MASK_R_NDPA_BW_8822B)
#define BIT_SET_R_NDPA_BW_8822B(x, v) \
(BIT_CLEAR_R_NDPA_BW_8822B(x) | BIT_R_NDPA_BW_8822B(v))
/* 2 REG_RD_RESP_PKT_TH_8822B */
#define BIT_SHIFT_RD_RESP_PKT_TH_V1_8822B 0
#define BIT_MASK_RD_RESP_PKT_TH_V1_8822B 0x3f
#define BIT_RD_RESP_PKT_TH_V1_8822B(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH_V1_8822B) \
<< BIT_SHIFT_RD_RESP_PKT_TH_V1_8822B)
#define BITS_RD_RESP_PKT_TH_V1_8822B \
(BIT_MASK_RD_RESP_PKT_TH_V1_8822B << BIT_SHIFT_RD_RESP_PKT_TH_V1_8822B)
#define BIT_CLEAR_RD_RESP_PKT_TH_V1_8822B(x) \
((x) & (~BITS_RD_RESP_PKT_TH_V1_8822B))
#define BIT_GET_RD_RESP_PKT_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH_V1_8822B) & \
BIT_MASK_RD_RESP_PKT_TH_V1_8822B)
#define BIT_SET_RD_RESP_PKT_TH_V1_8822B(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH_V1_8822B(x) | BIT_RD_RESP_PKT_TH_V1_8822B(v))
/* 2 REG_CMDQ_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822B 25
#define BIT_MASK_QUEUEMACID_CMDQ_V1_8822B 0x7f
#define BIT_QUEUEMACID_CMDQ_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_CMDQ_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822B)
#define BITS_QUEUEMACID_CMDQ_V1_8822B \
(BIT_MASK_QUEUEMACID_CMDQ_V1_8822B \
<< BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_CMDQ_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_CMDQ_V1_8822B))
#define BIT_GET_QUEUEMACID_CMDQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822B) & \
BIT_MASK_QUEUEMACID_CMDQ_V1_8822B)
#define BIT_SET_QUEUEMACID_CMDQ_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_CMDQ_V1_8822B(x) | \
BIT_QUEUEMACID_CMDQ_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_CMDQ_V1_8822B 23
#define BIT_MASK_QUEUEAC_CMDQ_V1_8822B 0x3
#define BIT_QUEUEAC_CMDQ_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_CMDQ_V1_8822B) \
<< BIT_SHIFT_QUEUEAC_CMDQ_V1_8822B)
#define BITS_QUEUEAC_CMDQ_V1_8822B \
(BIT_MASK_QUEUEAC_CMDQ_V1_8822B << BIT_SHIFT_QUEUEAC_CMDQ_V1_8822B)
#define BIT_CLEAR_QUEUEAC_CMDQ_V1_8822B(x) ((x) & (~BITS_QUEUEAC_CMDQ_V1_8822B))
#define BIT_GET_QUEUEAC_CMDQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_CMDQ_V1_8822B) & \
BIT_MASK_QUEUEAC_CMDQ_V1_8822B)
#define BIT_SET_QUEUEAC_CMDQ_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_CMDQ_V1_8822B(x) | BIT_QUEUEAC_CMDQ_V1_8822B(v))
#define BIT_TIDEMPTY_CMDQ_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_CMDQ_V2_8822B 11
#define BIT_MASK_TAIL_PKT_CMDQ_V2_8822B 0x7ff
#define BIT_TAIL_PKT_CMDQ_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_CMDQ_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_CMDQ_V2_8822B)
#define BITS_TAIL_PKT_CMDQ_V2_8822B \
(BIT_MASK_TAIL_PKT_CMDQ_V2_8822B << BIT_SHIFT_TAIL_PKT_CMDQ_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_CMDQ_V2_8822B(x) \
((x) & (~BITS_TAIL_PKT_CMDQ_V2_8822B))
#define BIT_GET_TAIL_PKT_CMDQ_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_CMDQ_V2_8822B) & \
BIT_MASK_TAIL_PKT_CMDQ_V2_8822B)
#define BIT_SET_TAIL_PKT_CMDQ_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_CMDQ_V2_8822B(x) | BIT_TAIL_PKT_CMDQ_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822B 0
#define BIT_MASK_HEAD_PKT_CMDQ_V1_8822B 0x7ff
#define BIT_HEAD_PKT_CMDQ_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_CMDQ_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822B)
#define BITS_HEAD_PKT_CMDQ_V1_8822B \
(BIT_MASK_HEAD_PKT_CMDQ_V1_8822B << BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_CMDQ_V1_8822B(x) \
((x) & (~BITS_HEAD_PKT_CMDQ_V1_8822B))
#define BIT_GET_HEAD_PKT_CMDQ_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822B) & \
BIT_MASK_HEAD_PKT_CMDQ_V1_8822B)
#define BIT_SET_HEAD_PKT_CMDQ_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_CMDQ_V1_8822B(x) | BIT_HEAD_PKT_CMDQ_V1_8822B(v))
/* 2 REG_Q4_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q4_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q4_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q4_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q4_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q4_V1_8822B)
#define BITS_QUEUEMACID_Q4_V1_8822B \
(BIT_MASK_QUEUEMACID_Q4_V1_8822B << BIT_SHIFT_QUEUEMACID_Q4_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q4_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q4_V1_8822B))
#define BIT_GET_QUEUEMACID_Q4_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q4_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q4_V1_8822B)
#define BIT_SET_QUEUEMACID_Q4_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q4_V1_8822B(x) | BIT_QUEUEMACID_Q4_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q4_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q4_V1_8822B 0x3
#define BIT_QUEUEAC_Q4_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q4_V1_8822B) << BIT_SHIFT_QUEUEAC_Q4_V1_8822B)
#define BITS_QUEUEAC_Q4_V1_8822B \
(BIT_MASK_QUEUEAC_Q4_V1_8822B << BIT_SHIFT_QUEUEAC_Q4_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q4_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q4_V1_8822B))
#define BIT_GET_QUEUEAC_Q4_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q4_V1_8822B) & BIT_MASK_QUEUEAC_Q4_V1_8822B)
#define BIT_SET_QUEUEAC_Q4_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q4_V1_8822B(x) | BIT_QUEUEAC_Q4_V1_8822B(v))
#define BIT_TIDEMPTY_Q4_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q4_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q4_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q4_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q4_V2_8822B)
#define BITS_TAIL_PKT_Q4_V2_8822B \
(BIT_MASK_TAIL_PKT_Q4_V2_8822B << BIT_SHIFT_TAIL_PKT_Q4_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q4_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q4_V2_8822B))
#define BIT_GET_TAIL_PKT_Q4_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q4_V2_8822B)
#define BIT_SET_TAIL_PKT_Q4_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2_8822B(x) | BIT_TAIL_PKT_Q4_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q4_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q4_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q4_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q4_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q4_V1_8822B)
#define BITS_HEAD_PKT_Q4_V1_8822B \
(BIT_MASK_HEAD_PKT_Q4_V1_8822B << BIT_SHIFT_HEAD_PKT_Q4_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q4_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q4_V1_8822B))
#define BIT_GET_HEAD_PKT_Q4_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q4_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q4_V1_8822B)
#define BIT_SET_HEAD_PKT_Q4_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q4_V1_8822B(x) | BIT_HEAD_PKT_Q4_V1_8822B(v))
/* 2 REG_Q5_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q5_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q5_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q5_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q5_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q5_V1_8822B)
#define BITS_QUEUEMACID_Q5_V1_8822B \
(BIT_MASK_QUEUEMACID_Q5_V1_8822B << BIT_SHIFT_QUEUEMACID_Q5_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q5_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q5_V1_8822B))
#define BIT_GET_QUEUEMACID_Q5_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q5_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q5_V1_8822B)
#define BIT_SET_QUEUEMACID_Q5_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q5_V1_8822B(x) | BIT_QUEUEMACID_Q5_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q5_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q5_V1_8822B 0x3
#define BIT_QUEUEAC_Q5_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q5_V1_8822B) << BIT_SHIFT_QUEUEAC_Q5_V1_8822B)
#define BITS_QUEUEAC_Q5_V1_8822B \
(BIT_MASK_QUEUEAC_Q5_V1_8822B << BIT_SHIFT_QUEUEAC_Q5_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q5_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q5_V1_8822B))
#define BIT_GET_QUEUEAC_Q5_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q5_V1_8822B) & BIT_MASK_QUEUEAC_Q5_V1_8822B)
#define BIT_SET_QUEUEAC_Q5_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q5_V1_8822B(x) | BIT_QUEUEAC_Q5_V1_8822B(v))
#define BIT_TIDEMPTY_Q5_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q5_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q5_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q5_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q5_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q5_V2_8822B)
#define BITS_TAIL_PKT_Q5_V2_8822B \
(BIT_MASK_TAIL_PKT_Q5_V2_8822B << BIT_SHIFT_TAIL_PKT_Q5_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q5_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q5_V2_8822B))
#define BIT_GET_TAIL_PKT_Q5_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q5_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q5_V2_8822B)
#define BIT_SET_TAIL_PKT_Q5_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q5_V2_8822B(x) | BIT_TAIL_PKT_Q5_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q5_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q5_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q5_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q5_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q5_V1_8822B)
#define BITS_HEAD_PKT_Q5_V1_8822B \
(BIT_MASK_HEAD_PKT_Q5_V1_8822B << BIT_SHIFT_HEAD_PKT_Q5_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q5_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q5_V1_8822B))
#define BIT_GET_HEAD_PKT_Q5_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q5_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q5_V1_8822B)
#define BIT_SET_HEAD_PKT_Q5_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q5_V1_8822B(x) | BIT_HEAD_PKT_Q5_V1_8822B(v))
/* 2 REG_Q6_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q6_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q6_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q6_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q6_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q6_V1_8822B)
#define BITS_QUEUEMACID_Q6_V1_8822B \
(BIT_MASK_QUEUEMACID_Q6_V1_8822B << BIT_SHIFT_QUEUEMACID_Q6_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q6_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q6_V1_8822B))
#define BIT_GET_QUEUEMACID_Q6_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q6_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q6_V1_8822B)
#define BIT_SET_QUEUEMACID_Q6_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q6_V1_8822B(x) | BIT_QUEUEMACID_Q6_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q6_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q6_V1_8822B 0x3
#define BIT_QUEUEAC_Q6_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q6_V1_8822B) << BIT_SHIFT_QUEUEAC_Q6_V1_8822B)
#define BITS_QUEUEAC_Q6_V1_8822B \
(BIT_MASK_QUEUEAC_Q6_V1_8822B << BIT_SHIFT_QUEUEAC_Q6_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q6_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q6_V1_8822B))
#define BIT_GET_QUEUEAC_Q6_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q6_V1_8822B) & BIT_MASK_QUEUEAC_Q6_V1_8822B)
#define BIT_SET_QUEUEAC_Q6_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q6_V1_8822B(x) | BIT_QUEUEAC_Q6_V1_8822B(v))
#define BIT_TIDEMPTY_Q6_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q6_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q6_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q6_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q6_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q6_V2_8822B)
#define BITS_TAIL_PKT_Q6_V2_8822B \
(BIT_MASK_TAIL_PKT_Q6_V2_8822B << BIT_SHIFT_TAIL_PKT_Q6_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q6_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q6_V2_8822B))
#define BIT_GET_TAIL_PKT_Q6_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q6_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q6_V2_8822B)
#define BIT_SET_TAIL_PKT_Q6_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q6_V2_8822B(x) | BIT_TAIL_PKT_Q6_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q6_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q6_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q6_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q6_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q6_V1_8822B)
#define BITS_HEAD_PKT_Q6_V1_8822B \
(BIT_MASK_HEAD_PKT_Q6_V1_8822B << BIT_SHIFT_HEAD_PKT_Q6_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q6_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q6_V1_8822B))
#define BIT_GET_HEAD_PKT_Q6_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q6_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q6_V1_8822B)
#define BIT_SET_HEAD_PKT_Q6_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q6_V1_8822B(x) | BIT_HEAD_PKT_Q6_V1_8822B(v))
/* 2 REG_Q7_INFO_8822B */
#define BIT_SHIFT_QUEUEMACID_Q7_V1_8822B 25
#define BIT_MASK_QUEUEMACID_Q7_V1_8822B 0x7f
#define BIT_QUEUEMACID_Q7_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEMACID_Q7_V1_8822B) \
<< BIT_SHIFT_QUEUEMACID_Q7_V1_8822B)
#define BITS_QUEUEMACID_Q7_V1_8822B \
(BIT_MASK_QUEUEMACID_Q7_V1_8822B << BIT_SHIFT_QUEUEMACID_Q7_V1_8822B)
#define BIT_CLEAR_QUEUEMACID_Q7_V1_8822B(x) \
((x) & (~BITS_QUEUEMACID_Q7_V1_8822B))
#define BIT_GET_QUEUEMACID_Q7_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q7_V1_8822B) & \
BIT_MASK_QUEUEMACID_Q7_V1_8822B)
#define BIT_SET_QUEUEMACID_Q7_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEMACID_Q7_V1_8822B(x) | BIT_QUEUEMACID_Q7_V1_8822B(v))
#define BIT_SHIFT_QUEUEAC_Q7_V1_8822B 23
#define BIT_MASK_QUEUEAC_Q7_V1_8822B 0x3
#define BIT_QUEUEAC_Q7_V1_8822B(x) \
(((x) & BIT_MASK_QUEUEAC_Q7_V1_8822B) << BIT_SHIFT_QUEUEAC_Q7_V1_8822B)
#define BITS_QUEUEAC_Q7_V1_8822B \
(BIT_MASK_QUEUEAC_Q7_V1_8822B << BIT_SHIFT_QUEUEAC_Q7_V1_8822B)
#define BIT_CLEAR_QUEUEAC_Q7_V1_8822B(x) ((x) & (~BITS_QUEUEAC_Q7_V1_8822B))
#define BIT_GET_QUEUEAC_Q7_V1_8822B(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q7_V1_8822B) & BIT_MASK_QUEUEAC_Q7_V1_8822B)
#define BIT_SET_QUEUEAC_Q7_V1_8822B(x, v) \
(BIT_CLEAR_QUEUEAC_Q7_V1_8822B(x) | BIT_QUEUEAC_Q7_V1_8822B(v))
#define BIT_TIDEMPTY_Q7_V1_8822B BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q7_V2_8822B 11
#define BIT_MASK_TAIL_PKT_Q7_V2_8822B 0x7ff
#define BIT_TAIL_PKT_Q7_V2_8822B(x) \
(((x) & BIT_MASK_TAIL_PKT_Q7_V2_8822B) \
<< BIT_SHIFT_TAIL_PKT_Q7_V2_8822B)
#define BITS_TAIL_PKT_Q7_V2_8822B \
(BIT_MASK_TAIL_PKT_Q7_V2_8822B << BIT_SHIFT_TAIL_PKT_Q7_V2_8822B)
#define BIT_CLEAR_TAIL_PKT_Q7_V2_8822B(x) ((x) & (~BITS_TAIL_PKT_Q7_V2_8822B))
#define BIT_GET_TAIL_PKT_Q7_V2_8822B(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q7_V2_8822B) & \
BIT_MASK_TAIL_PKT_Q7_V2_8822B)
#define BIT_SET_TAIL_PKT_Q7_V2_8822B(x, v) \
(BIT_CLEAR_TAIL_PKT_Q7_V2_8822B(x) | BIT_TAIL_PKT_Q7_V2_8822B(v))
#define BIT_SHIFT_HEAD_PKT_Q7_V1_8822B 0
#define BIT_MASK_HEAD_PKT_Q7_V1_8822B 0x7ff
#define BIT_HEAD_PKT_Q7_V1_8822B(x) \
(((x) & BIT_MASK_HEAD_PKT_Q7_V1_8822B) \
<< BIT_SHIFT_HEAD_PKT_Q7_V1_8822B)
#define BITS_HEAD_PKT_Q7_V1_8822B \
(BIT_MASK_HEAD_PKT_Q7_V1_8822B << BIT_SHIFT_HEAD_PKT_Q7_V1_8822B)
#define BIT_CLEAR_HEAD_PKT_Q7_V1_8822B(x) ((x) & (~BITS_HEAD_PKT_Q7_V1_8822B))
#define BIT_GET_HEAD_PKT_Q7_V1_8822B(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q7_V1_8822B) & \
BIT_MASK_HEAD_PKT_Q7_V1_8822B)
#define BIT_SET_HEAD_PKT_Q7_V1_8822B(x, v) \
(BIT_CLEAR_HEAD_PKT_Q7_V1_8822B(x) | BIT_HEAD_PKT_Q7_V1_8822B(v))
/* 2 REG_WMAC_LBK_BUF_HD_V1_8822B */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822B 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822B 0xfff
#define BIT_WMAC_LBK_BUF_HEAD_V1_8822B(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822B) \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822B)
#define BITS_WMAC_LBK_BUF_HEAD_V1_8822B \
(BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822B \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822B)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8822B(x) \
((x) & (~BITS_WMAC_LBK_BUF_HEAD_V1_8822B))
#define BIT_GET_WMAC_LBK_BUF_HEAD_V1_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822B) & \
BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822B)
#define BIT_SET_WMAC_LBK_BUF_HEAD_V1_8822B(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8822B(x) | \
BIT_WMAC_LBK_BUF_HEAD_V1_8822B(v))
/* 2 REG_MGQ_BDNY_V1_8822B */
#define BIT_SHIFT_MGQ_PGBNDY_V1_8822B 0
#define BIT_MASK_MGQ_PGBNDY_V1_8822B 0xfff
#define BIT_MGQ_PGBNDY_V1_8822B(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V1_8822B) << BIT_SHIFT_MGQ_PGBNDY_V1_8822B)
#define BITS_MGQ_PGBNDY_V1_8822B \
(BIT_MASK_MGQ_PGBNDY_V1_8822B << BIT_SHIFT_MGQ_PGBNDY_V1_8822B)
#define BIT_CLEAR_MGQ_PGBNDY_V1_8822B(x) ((x) & (~BITS_MGQ_PGBNDY_V1_8822B))
#define BIT_GET_MGQ_PGBNDY_V1_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V1_8822B) & BIT_MASK_MGQ_PGBNDY_V1_8822B)
#define BIT_SET_MGQ_PGBNDY_V1_8822B(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V1_8822B(x) | BIT_MGQ_PGBNDY_V1_8822B(v))
/* 2 REG_TXRPT_CTRL_8822B */
#define BIT_SHIFT_TRXRPT_TIMER_TH_8822B 24
#define BIT_MASK_TRXRPT_TIMER_TH_8822B 0xff
#define BIT_TRXRPT_TIMER_TH_8822B(x) \
(((x) & BIT_MASK_TRXRPT_TIMER_TH_8822B) \
<< BIT_SHIFT_TRXRPT_TIMER_TH_8822B)
#define BITS_TRXRPT_TIMER_TH_8822B \
(BIT_MASK_TRXRPT_TIMER_TH_8822B << BIT_SHIFT_TRXRPT_TIMER_TH_8822B)
#define BIT_CLEAR_TRXRPT_TIMER_TH_8822B(x) ((x) & (~BITS_TRXRPT_TIMER_TH_8822B))
#define BIT_GET_TRXRPT_TIMER_TH_8822B(x) \
(((x) >> BIT_SHIFT_TRXRPT_TIMER_TH_8822B) & \
BIT_MASK_TRXRPT_TIMER_TH_8822B)
#define BIT_SET_TRXRPT_TIMER_TH_8822B(x, v) \
(BIT_CLEAR_TRXRPT_TIMER_TH_8822B(x) | BIT_TRXRPT_TIMER_TH_8822B(v))
#define BIT_SHIFT_TRXRPT_LEN_TH_8822B 16
#define BIT_MASK_TRXRPT_LEN_TH_8822B 0xff
#define BIT_TRXRPT_LEN_TH_8822B(x) \
(((x) & BIT_MASK_TRXRPT_LEN_TH_8822B) << BIT_SHIFT_TRXRPT_LEN_TH_8822B)
#define BITS_TRXRPT_LEN_TH_8822B \
(BIT_MASK_TRXRPT_LEN_TH_8822B << BIT_SHIFT_TRXRPT_LEN_TH_8822B)
#define BIT_CLEAR_TRXRPT_LEN_TH_8822B(x) ((x) & (~BITS_TRXRPT_LEN_TH_8822B))
#define BIT_GET_TRXRPT_LEN_TH_8822B(x) \
(((x) >> BIT_SHIFT_TRXRPT_LEN_TH_8822B) & BIT_MASK_TRXRPT_LEN_TH_8822B)
#define BIT_SET_TRXRPT_LEN_TH_8822B(x, v) \
(BIT_CLEAR_TRXRPT_LEN_TH_8822B(x) | BIT_TRXRPT_LEN_TH_8822B(v))
#define BIT_SHIFT_TRXRPT_READ_PTR_8822B 8
#define BIT_MASK_TRXRPT_READ_PTR_8822B 0xff
#define BIT_TRXRPT_READ_PTR_8822B(x) \
(((x) & BIT_MASK_TRXRPT_READ_PTR_8822B) \
<< BIT_SHIFT_TRXRPT_READ_PTR_8822B)
#define BITS_TRXRPT_READ_PTR_8822B \
(BIT_MASK_TRXRPT_READ_PTR_8822B << BIT_SHIFT_TRXRPT_READ_PTR_8822B)
#define BIT_CLEAR_TRXRPT_READ_PTR_8822B(x) ((x) & (~BITS_TRXRPT_READ_PTR_8822B))
#define BIT_GET_TRXRPT_READ_PTR_8822B(x) \
(((x) >> BIT_SHIFT_TRXRPT_READ_PTR_8822B) & \
BIT_MASK_TRXRPT_READ_PTR_8822B)
#define BIT_SET_TRXRPT_READ_PTR_8822B(x, v) \
(BIT_CLEAR_TRXRPT_READ_PTR_8822B(x) | BIT_TRXRPT_READ_PTR_8822B(v))
#define BIT_SHIFT_TRXRPT_WRITE_PTR_8822B 0
#define BIT_MASK_TRXRPT_WRITE_PTR_8822B 0xff
#define BIT_TRXRPT_WRITE_PTR_8822B(x) \
(((x) & BIT_MASK_TRXRPT_WRITE_PTR_8822B) \
<< BIT_SHIFT_TRXRPT_WRITE_PTR_8822B)
#define BITS_TRXRPT_WRITE_PTR_8822B \
(BIT_MASK_TRXRPT_WRITE_PTR_8822B << BIT_SHIFT_TRXRPT_WRITE_PTR_8822B)
#define BIT_CLEAR_TRXRPT_WRITE_PTR_8822B(x) \
((x) & (~BITS_TRXRPT_WRITE_PTR_8822B))
#define BIT_GET_TRXRPT_WRITE_PTR_8822B(x) \
(((x) >> BIT_SHIFT_TRXRPT_WRITE_PTR_8822B) & \
BIT_MASK_TRXRPT_WRITE_PTR_8822B)
#define BIT_SET_TRXRPT_WRITE_PTR_8822B(x, v) \
(BIT_CLEAR_TRXRPT_WRITE_PTR_8822B(x) | BIT_TRXRPT_WRITE_PTR_8822B(v))
/* 2 REG_INIRTS_RATE_SEL_8822B */
#define BIT_LEAG_RTS_BW_DUP_8822B BIT(5)
/* 2 REG_BASIC_CFEND_RATE_8822B */
#define BIT_SHIFT_BASIC_CFEND_RATE_8822B 0
#define BIT_MASK_BASIC_CFEND_RATE_8822B 0x1f
#define BIT_BASIC_CFEND_RATE_8822B(x) \
(((x) & BIT_MASK_BASIC_CFEND_RATE_8822B) \
<< BIT_SHIFT_BASIC_CFEND_RATE_8822B)
#define BITS_BASIC_CFEND_RATE_8822B \
(BIT_MASK_BASIC_CFEND_RATE_8822B << BIT_SHIFT_BASIC_CFEND_RATE_8822B)
#define BIT_CLEAR_BASIC_CFEND_RATE_8822B(x) \
((x) & (~BITS_BASIC_CFEND_RATE_8822B))
#define BIT_GET_BASIC_CFEND_RATE_8822B(x) \
(((x) >> BIT_SHIFT_BASIC_CFEND_RATE_8822B) & \
BIT_MASK_BASIC_CFEND_RATE_8822B)
#define BIT_SET_BASIC_CFEND_RATE_8822B(x, v) \
(BIT_CLEAR_BASIC_CFEND_RATE_8822B(x) | BIT_BASIC_CFEND_RATE_8822B(v))
/* 2 REG_STBC_CFEND_RATE_8822B */
#define BIT_SHIFT_STBC_CFEND_RATE_8822B 0
#define BIT_MASK_STBC_CFEND_RATE_8822B 0x1f
#define BIT_STBC_CFEND_RATE_8822B(x) \
(((x) & BIT_MASK_STBC_CFEND_RATE_8822B) \
<< BIT_SHIFT_STBC_CFEND_RATE_8822B)
#define BITS_STBC_CFEND_RATE_8822B \
(BIT_MASK_STBC_CFEND_RATE_8822B << BIT_SHIFT_STBC_CFEND_RATE_8822B)
#define BIT_CLEAR_STBC_CFEND_RATE_8822B(x) ((x) & (~BITS_STBC_CFEND_RATE_8822B))
#define BIT_GET_STBC_CFEND_RATE_8822B(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_RATE_8822B) & \
BIT_MASK_STBC_CFEND_RATE_8822B)
#define BIT_SET_STBC_CFEND_RATE_8822B(x, v) \
(BIT_CLEAR_STBC_CFEND_RATE_8822B(x) | BIT_STBC_CFEND_RATE_8822B(v))
/* 2 REG_DATA_SC_8822B */
#define BIT_SHIFT_TXSC_40M_8822B 4
#define BIT_MASK_TXSC_40M_8822B 0xf
#define BIT_TXSC_40M_8822B(x) \
(((x) & BIT_MASK_TXSC_40M_8822B) << BIT_SHIFT_TXSC_40M_8822B)
#define BITS_TXSC_40M_8822B \
(BIT_MASK_TXSC_40M_8822B << BIT_SHIFT_TXSC_40M_8822B)
#define BIT_CLEAR_TXSC_40M_8822B(x) ((x) & (~BITS_TXSC_40M_8822B))
#define BIT_GET_TXSC_40M_8822B(x) \
(((x) >> BIT_SHIFT_TXSC_40M_8822B) & BIT_MASK_TXSC_40M_8822B)
#define BIT_SET_TXSC_40M_8822B(x, v) \
(BIT_CLEAR_TXSC_40M_8822B(x) | BIT_TXSC_40M_8822B(v))
#define BIT_SHIFT_TXSC_20M_8822B 0
#define BIT_MASK_TXSC_20M_8822B 0xf
#define BIT_TXSC_20M_8822B(x) \
(((x) & BIT_MASK_TXSC_20M_8822B) << BIT_SHIFT_TXSC_20M_8822B)
#define BITS_TXSC_20M_8822B \
(BIT_MASK_TXSC_20M_8822B << BIT_SHIFT_TXSC_20M_8822B)
#define BIT_CLEAR_TXSC_20M_8822B(x) ((x) & (~BITS_TXSC_20M_8822B))
#define BIT_GET_TXSC_20M_8822B(x) \
(((x) >> BIT_SHIFT_TXSC_20M_8822B) & BIT_MASK_TXSC_20M_8822B)
#define BIT_SET_TXSC_20M_8822B(x, v) \
(BIT_CLEAR_TXSC_20M_8822B(x) | BIT_TXSC_20M_8822B(v))
/* 2 REG_MACID_SLEEP3_8822B */
#define BIT_SHIFT_MACID127_96_PKTSLEEP_8822B 0
#define BIT_MASK_MACID127_96_PKTSLEEP_8822B 0xffffffffL
#define BIT_MACID127_96_PKTSLEEP_8822B(x) \
(((x) & BIT_MASK_MACID127_96_PKTSLEEP_8822B) \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8822B)
#define BITS_MACID127_96_PKTSLEEP_8822B \
(BIT_MASK_MACID127_96_PKTSLEEP_8822B \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8822B)
#define BIT_CLEAR_MACID127_96_PKTSLEEP_8822B(x) \
((x) & (~BITS_MACID127_96_PKTSLEEP_8822B))
#define BIT_GET_MACID127_96_PKTSLEEP_8822B(x) \
(((x) >> BIT_SHIFT_MACID127_96_PKTSLEEP_8822B) & \
BIT_MASK_MACID127_96_PKTSLEEP_8822B)
#define BIT_SET_MACID127_96_PKTSLEEP_8822B(x, v) \
(BIT_CLEAR_MACID127_96_PKTSLEEP_8822B(x) | \
BIT_MACID127_96_PKTSLEEP_8822B(v))
/* 2 REG_MACID_SLEEP1_8822B */
#define BIT_SHIFT_MACID63_32_PKTSLEEP_8822B 0
#define BIT_MASK_MACID63_32_PKTSLEEP_8822B 0xffffffffL
#define BIT_MACID63_32_PKTSLEEP_8822B(x) \
(((x) & BIT_MASK_MACID63_32_PKTSLEEP_8822B) \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8822B)
#define BITS_MACID63_32_PKTSLEEP_8822B \
(BIT_MASK_MACID63_32_PKTSLEEP_8822B \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8822B)
#define BIT_CLEAR_MACID63_32_PKTSLEEP_8822B(x) \
((x) & (~BITS_MACID63_32_PKTSLEEP_8822B))
#define BIT_GET_MACID63_32_PKTSLEEP_8822B(x) \
(((x) >> BIT_SHIFT_MACID63_32_PKTSLEEP_8822B) & \
BIT_MASK_MACID63_32_PKTSLEEP_8822B)
#define BIT_SET_MACID63_32_PKTSLEEP_8822B(x, v) \
(BIT_CLEAR_MACID63_32_PKTSLEEP_8822B(x) | \
BIT_MACID63_32_PKTSLEEP_8822B(v))
/* 2 REG_ARFR2_V1_8822B */
#define BIT_SHIFT_ARFR2_V1_8822B 0
#define BIT_MASK_ARFR2_V1_8822B 0xffffffffffffffffL
#define BIT_ARFR2_V1_8822B(x) \
(((x) & BIT_MASK_ARFR2_V1_8822B) << BIT_SHIFT_ARFR2_V1_8822B)
#define BITS_ARFR2_V1_8822B \
(BIT_MASK_ARFR2_V1_8822B << BIT_SHIFT_ARFR2_V1_8822B)
#define BIT_CLEAR_ARFR2_V1_8822B(x) ((x) & (~BITS_ARFR2_V1_8822B))
#define BIT_GET_ARFR2_V1_8822B(x) \
(((x) >> BIT_SHIFT_ARFR2_V1_8822B) & BIT_MASK_ARFR2_V1_8822B)
#define BIT_SET_ARFR2_V1_8822B(x, v) \
(BIT_CLEAR_ARFR2_V1_8822B(x) | BIT_ARFR2_V1_8822B(v))
/* 2 REG_ARFR3_V1_8822B */
#define BIT_SHIFT_ARFR3_V1_8822B 0
#define BIT_MASK_ARFR3_V1_8822B 0xffffffffffffffffL
#define BIT_ARFR3_V1_8822B(x) \
(((x) & BIT_MASK_ARFR3_V1_8822B) << BIT_SHIFT_ARFR3_V1_8822B)
#define BITS_ARFR3_V1_8822B \
(BIT_MASK_ARFR3_V1_8822B << BIT_SHIFT_ARFR3_V1_8822B)
#define BIT_CLEAR_ARFR3_V1_8822B(x) ((x) & (~BITS_ARFR3_V1_8822B))
#define BIT_GET_ARFR3_V1_8822B(x) \
(((x) >> BIT_SHIFT_ARFR3_V1_8822B) & BIT_MASK_ARFR3_V1_8822B)
#define BIT_SET_ARFR3_V1_8822B(x, v) \
(BIT_CLEAR_ARFR3_V1_8822B(x) | BIT_ARFR3_V1_8822B(v))
/* 2 REG_ARFR4_8822B */
#define BIT_SHIFT_ARFR4_8822B 0
#define BIT_MASK_ARFR4_8822B 0xffffffffffffffffL
#define BIT_ARFR4_8822B(x) \
(((x) & BIT_MASK_ARFR4_8822B) << BIT_SHIFT_ARFR4_8822B)
#define BITS_ARFR4_8822B (BIT_MASK_ARFR4_8822B << BIT_SHIFT_ARFR4_8822B)
#define BIT_CLEAR_ARFR4_8822B(x) ((x) & (~BITS_ARFR4_8822B))
#define BIT_GET_ARFR4_8822B(x) \
(((x) >> BIT_SHIFT_ARFR4_8822B) & BIT_MASK_ARFR4_8822B)
#define BIT_SET_ARFR4_8822B(x, v) \
(BIT_CLEAR_ARFR4_8822B(x) | BIT_ARFR4_8822B(v))
/* 2 REG_ARFR5_8822B */
#define BIT_SHIFT_ARFR5_8822B 0
#define BIT_MASK_ARFR5_8822B 0xffffffffffffffffL
#define BIT_ARFR5_8822B(x) \
(((x) & BIT_MASK_ARFR5_8822B) << BIT_SHIFT_ARFR5_8822B)
#define BITS_ARFR5_8822B (BIT_MASK_ARFR5_8822B << BIT_SHIFT_ARFR5_8822B)
#define BIT_CLEAR_ARFR5_8822B(x) ((x) & (~BITS_ARFR5_8822B))
#define BIT_GET_ARFR5_8822B(x) \
(((x) >> BIT_SHIFT_ARFR5_8822B) & BIT_MASK_ARFR5_8822B)
#define BIT_SET_ARFR5_8822B(x, v) \
(BIT_CLEAR_ARFR5_8822B(x) | BIT_ARFR5_8822B(v))
/* 2 REG_TXRPT_START_OFFSET_8822B */
#define BIT_SHIFT_MACID_MURATE_OFFSET_8822B 24
#define BIT_MASK_MACID_MURATE_OFFSET_8822B 0xff
#define BIT_MACID_MURATE_OFFSET_8822B(x) \
(((x) & BIT_MASK_MACID_MURATE_OFFSET_8822B) \
<< BIT_SHIFT_MACID_MURATE_OFFSET_8822B)
#define BITS_MACID_MURATE_OFFSET_8822B \
(BIT_MASK_MACID_MURATE_OFFSET_8822B \
<< BIT_SHIFT_MACID_MURATE_OFFSET_8822B)
#define BIT_CLEAR_MACID_MURATE_OFFSET_8822B(x) \
((x) & (~BITS_MACID_MURATE_OFFSET_8822B))
#define BIT_GET_MACID_MURATE_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_MACID_MURATE_OFFSET_8822B) & \
BIT_MASK_MACID_MURATE_OFFSET_8822B)
#define BIT_SET_MACID_MURATE_OFFSET_8822B(x, v) \
(BIT_CLEAR_MACID_MURATE_OFFSET_8822B(x) | \
BIT_MACID_MURATE_OFFSET_8822B(v))
#define BIT_RPTFIFO_SIZE_OPT_8822B BIT(16)
#define BIT_SHIFT_MACID_CTRL_OFFSET_8822B 8
#define BIT_MASK_MACID_CTRL_OFFSET_8822B 0xff
#define BIT_MACID_CTRL_OFFSET_8822B(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET_8822B) \
<< BIT_SHIFT_MACID_CTRL_OFFSET_8822B)
#define BITS_MACID_CTRL_OFFSET_8822B \
(BIT_MASK_MACID_CTRL_OFFSET_8822B << BIT_SHIFT_MACID_CTRL_OFFSET_8822B)
#define BIT_CLEAR_MACID_CTRL_OFFSET_8822B(x) \
((x) & (~BITS_MACID_CTRL_OFFSET_8822B))
#define BIT_GET_MACID_CTRL_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET_8822B) & \
BIT_MASK_MACID_CTRL_OFFSET_8822B)
#define BIT_SET_MACID_CTRL_OFFSET_8822B(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET_8822B(x) | BIT_MACID_CTRL_OFFSET_8822B(v))
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822B 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET_8822B 0xff
#define BIT_AMPDU_TXRPT_OFFSET_8822B(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET_8822B) \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822B)
#define BITS_AMPDU_TXRPT_OFFSET_8822B \
(BIT_MASK_AMPDU_TXRPT_OFFSET_8822B \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822B)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET_8822B(x) \
((x) & (~BITS_AMPDU_TXRPT_OFFSET_8822B))
#define BIT_GET_AMPDU_TXRPT_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822B) & \
BIT_MASK_AMPDU_TXRPT_OFFSET_8822B)
#define BIT_SET_AMPDU_TXRPT_OFFSET_8822B(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET_8822B(x) | \
BIT_AMPDU_TXRPT_OFFSET_8822B(v))
/* 2 REG_POWER_STAGE1_8822B */
#define BIT_PTA_WL_PRI_MASK_CPU_MGQ_8822B BIT(31)
#define BIT_PTA_WL_PRI_MASK_BCNQ_8822B BIT(30)
#define BIT_PTA_WL_PRI_MASK_HIQ_8822B BIT(29)
#define BIT_PTA_WL_PRI_MASK_MGQ_8822B BIT(28)
#define BIT_PTA_WL_PRI_MASK_BK_8822B BIT(27)
#define BIT_PTA_WL_PRI_MASK_BE_8822B BIT(26)
#define BIT_PTA_WL_PRI_MASK_VI_8822B BIT(25)
#define BIT_PTA_WL_PRI_MASK_VO_8822B BIT(24)
#define BIT_SHIFT_POWER_STAGE1_8822B 0
#define BIT_MASK_POWER_STAGE1_8822B 0xffffff
#define BIT_POWER_STAGE1_8822B(x) \
(((x) & BIT_MASK_POWER_STAGE1_8822B) << BIT_SHIFT_POWER_STAGE1_8822B)
#define BITS_POWER_STAGE1_8822B \
(BIT_MASK_POWER_STAGE1_8822B << BIT_SHIFT_POWER_STAGE1_8822B)
#define BIT_CLEAR_POWER_STAGE1_8822B(x) ((x) & (~BITS_POWER_STAGE1_8822B))
#define BIT_GET_POWER_STAGE1_8822B(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1_8822B) & BIT_MASK_POWER_STAGE1_8822B)
#define BIT_SET_POWER_STAGE1_8822B(x, v) \
(BIT_CLEAR_POWER_STAGE1_8822B(x) | BIT_POWER_STAGE1_8822B(v))
/* 2 REG_POWER_STAGE2_8822B */
#define BIT__R_CTRL_PKT_POW_ADJ_8822B BIT(24)
#define BIT_SHIFT_POWER_STAGE2_8822B 0
#define BIT_MASK_POWER_STAGE2_8822B 0xffffff
#define BIT_POWER_STAGE2_8822B(x) \
(((x) & BIT_MASK_POWER_STAGE2_8822B) << BIT_SHIFT_POWER_STAGE2_8822B)
#define BITS_POWER_STAGE2_8822B \
(BIT_MASK_POWER_STAGE2_8822B << BIT_SHIFT_POWER_STAGE2_8822B)
#define BIT_CLEAR_POWER_STAGE2_8822B(x) ((x) & (~BITS_POWER_STAGE2_8822B))
#define BIT_GET_POWER_STAGE2_8822B(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2_8822B) & BIT_MASK_POWER_STAGE2_8822B)
#define BIT_SET_POWER_STAGE2_8822B(x, v) \
(BIT_CLEAR_POWER_STAGE2_8822B(x) | BIT_POWER_STAGE2_8822B(v))
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL_8822B */
#define BIT_SHIFT_PAD_NUM_THRES_8822B 24
#define BIT_MASK_PAD_NUM_THRES_8822B 0x3f
#define BIT_PAD_NUM_THRES_8822B(x) \
(((x) & BIT_MASK_PAD_NUM_THRES_8822B) << BIT_SHIFT_PAD_NUM_THRES_8822B)
#define BITS_PAD_NUM_THRES_8822B \
(BIT_MASK_PAD_NUM_THRES_8822B << BIT_SHIFT_PAD_NUM_THRES_8822B)
#define BIT_CLEAR_PAD_NUM_THRES_8822B(x) ((x) & (~BITS_PAD_NUM_THRES_8822B))
#define BIT_GET_PAD_NUM_THRES_8822B(x) \
(((x) >> BIT_SHIFT_PAD_NUM_THRES_8822B) & BIT_MASK_PAD_NUM_THRES_8822B)
#define BIT_SET_PAD_NUM_THRES_8822B(x, v) \
(BIT_CLEAR_PAD_NUM_THRES_8822B(x) | BIT_PAD_NUM_THRES_8822B(v))
#define BIT_R_DMA_THIS_QUEUE_BK_8822B BIT(23)
#define BIT_R_DMA_THIS_QUEUE_BE_8822B BIT(22)
#define BIT_R_DMA_THIS_QUEUE_VI_8822B BIT(21)
#define BIT_R_DMA_THIS_QUEUE_VO_8822B BIT(20)
#define BIT_SHIFT_R_TOTAL_LEN_TH_8822B 8
#define BIT_MASK_R_TOTAL_LEN_TH_8822B 0xfff
#define BIT_R_TOTAL_LEN_TH_8822B(x) \
(((x) & BIT_MASK_R_TOTAL_LEN_TH_8822B) \
<< BIT_SHIFT_R_TOTAL_LEN_TH_8822B)
#define BITS_R_TOTAL_LEN_TH_8822B \
(BIT_MASK_R_TOTAL_LEN_TH_8822B << BIT_SHIFT_R_TOTAL_LEN_TH_8822B)
#define BIT_CLEAR_R_TOTAL_LEN_TH_8822B(x) ((x) & (~BITS_R_TOTAL_LEN_TH_8822B))
#define BIT_GET_R_TOTAL_LEN_TH_8822B(x) \
(((x) >> BIT_SHIFT_R_TOTAL_LEN_TH_8822B) & \
BIT_MASK_R_TOTAL_LEN_TH_8822B)
#define BIT_SET_R_TOTAL_LEN_TH_8822B(x, v) \
(BIT_CLEAR_R_TOTAL_LEN_TH_8822B(x) | BIT_R_TOTAL_LEN_TH_8822B(v))
#define BIT_EN_NEW_EARLY_8822B BIT(7)
#define BIT_PRE_TX_CMD_8822B BIT(6)
#define BIT_SHIFT_NUM_SCL_EN_8822B 4
#define BIT_MASK_NUM_SCL_EN_8822B 0x3
#define BIT_NUM_SCL_EN_8822B(x) \
(((x) & BIT_MASK_NUM_SCL_EN_8822B) << BIT_SHIFT_NUM_SCL_EN_8822B)
#define BITS_NUM_SCL_EN_8822B \
(BIT_MASK_NUM_SCL_EN_8822B << BIT_SHIFT_NUM_SCL_EN_8822B)
#define BIT_CLEAR_NUM_SCL_EN_8822B(x) ((x) & (~BITS_NUM_SCL_EN_8822B))
#define BIT_GET_NUM_SCL_EN_8822B(x) \
(((x) >> BIT_SHIFT_NUM_SCL_EN_8822B) & BIT_MASK_NUM_SCL_EN_8822B)
#define BIT_SET_NUM_SCL_EN_8822B(x, v) \
(BIT_CLEAR_NUM_SCL_EN_8822B(x) | BIT_NUM_SCL_EN_8822B(v))
#define BIT_BK_EN_8822B BIT(3)
#define BIT_BE_EN_8822B BIT(2)
#define BIT_VI_EN_8822B BIT(1)
#define BIT_VO_EN_8822B BIT(0)
/* 2 REG_PKT_LIFE_TIME_8822B */
#define BIT_SHIFT_PKT_LIFTIME_BEBK_8822B 16
#define BIT_MASK_PKT_LIFTIME_BEBK_8822B 0xffff
#define BIT_PKT_LIFTIME_BEBK_8822B(x) \
(((x) & BIT_MASK_PKT_LIFTIME_BEBK_8822B) \
<< BIT_SHIFT_PKT_LIFTIME_BEBK_8822B)
#define BITS_PKT_LIFTIME_BEBK_8822B \
(BIT_MASK_PKT_LIFTIME_BEBK_8822B << BIT_SHIFT_PKT_LIFTIME_BEBK_8822B)
#define BIT_CLEAR_PKT_LIFTIME_BEBK_8822B(x) \
((x) & (~BITS_PKT_LIFTIME_BEBK_8822B))
#define BIT_GET_PKT_LIFTIME_BEBK_8822B(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_BEBK_8822B) & \
BIT_MASK_PKT_LIFTIME_BEBK_8822B)
#define BIT_SET_PKT_LIFTIME_BEBK_8822B(x, v) \
(BIT_CLEAR_PKT_LIFTIME_BEBK_8822B(x) | BIT_PKT_LIFTIME_BEBK_8822B(v))
#define BIT_SHIFT_PKT_LIFTIME_VOVI_8822B 0
#define BIT_MASK_PKT_LIFTIME_VOVI_8822B 0xffff
#define BIT_PKT_LIFTIME_VOVI_8822B(x) \
(((x) & BIT_MASK_PKT_LIFTIME_VOVI_8822B) \
<< BIT_SHIFT_PKT_LIFTIME_VOVI_8822B)
#define BITS_PKT_LIFTIME_VOVI_8822B \
(BIT_MASK_PKT_LIFTIME_VOVI_8822B << BIT_SHIFT_PKT_LIFTIME_VOVI_8822B)
#define BIT_CLEAR_PKT_LIFTIME_VOVI_8822B(x) \
((x) & (~BITS_PKT_LIFTIME_VOVI_8822B))
#define BIT_GET_PKT_LIFTIME_VOVI_8822B(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_VOVI_8822B) & \
BIT_MASK_PKT_LIFTIME_VOVI_8822B)
#define BIT_SET_PKT_LIFTIME_VOVI_8822B(x, v) \
(BIT_CLEAR_PKT_LIFTIME_VOVI_8822B(x) | BIT_PKT_LIFTIME_VOVI_8822B(v))
/* 2 REG_STBC_SETTING_8822B */
#define BIT_SHIFT_CDEND_TXTIME_L_8822B 4
#define BIT_MASK_CDEND_TXTIME_L_8822B 0xf
#define BIT_CDEND_TXTIME_L_8822B(x) \
(((x) & BIT_MASK_CDEND_TXTIME_L_8822B) \
<< BIT_SHIFT_CDEND_TXTIME_L_8822B)
#define BITS_CDEND_TXTIME_L_8822B \
(BIT_MASK_CDEND_TXTIME_L_8822B << BIT_SHIFT_CDEND_TXTIME_L_8822B)
#define BIT_CLEAR_CDEND_TXTIME_L_8822B(x) ((x) & (~BITS_CDEND_TXTIME_L_8822B))
#define BIT_GET_CDEND_TXTIME_L_8822B(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_L_8822B) & \
BIT_MASK_CDEND_TXTIME_L_8822B)
#define BIT_SET_CDEND_TXTIME_L_8822B(x, v) \
(BIT_CLEAR_CDEND_TXTIME_L_8822B(x) | BIT_CDEND_TXTIME_L_8822B(v))
#define BIT_SHIFT_NESS_8822B 2
#define BIT_MASK_NESS_8822B 0x3
#define BIT_NESS_8822B(x) (((x) & BIT_MASK_NESS_8822B) << BIT_SHIFT_NESS_8822B)
#define BITS_NESS_8822B (BIT_MASK_NESS_8822B << BIT_SHIFT_NESS_8822B)
#define BIT_CLEAR_NESS_8822B(x) ((x) & (~BITS_NESS_8822B))
#define BIT_GET_NESS_8822B(x) \
(((x) >> BIT_SHIFT_NESS_8822B) & BIT_MASK_NESS_8822B)
#define BIT_SET_NESS_8822B(x, v) (BIT_CLEAR_NESS_8822B(x) | BIT_NESS_8822B(v))
#define BIT_SHIFT_STBC_CFEND_8822B 0
#define BIT_MASK_STBC_CFEND_8822B 0x3
#define BIT_STBC_CFEND_8822B(x) \
(((x) & BIT_MASK_STBC_CFEND_8822B) << BIT_SHIFT_STBC_CFEND_8822B)
#define BITS_STBC_CFEND_8822B \
(BIT_MASK_STBC_CFEND_8822B << BIT_SHIFT_STBC_CFEND_8822B)
#define BIT_CLEAR_STBC_CFEND_8822B(x) ((x) & (~BITS_STBC_CFEND_8822B))
#define BIT_GET_STBC_CFEND_8822B(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_8822B) & BIT_MASK_STBC_CFEND_8822B)
#define BIT_SET_STBC_CFEND_8822B(x, v) \
(BIT_CLEAR_STBC_CFEND_8822B(x) | BIT_STBC_CFEND_8822B(v))
/* 2 REG_STBC_SETTING2_8822B */
#define BIT_SHIFT_CDEND_TXTIME_H_8822B 0
#define BIT_MASK_CDEND_TXTIME_H_8822B 0x1f
#define BIT_CDEND_TXTIME_H_8822B(x) \
(((x) & BIT_MASK_CDEND_TXTIME_H_8822B) \
<< BIT_SHIFT_CDEND_TXTIME_H_8822B)
#define BITS_CDEND_TXTIME_H_8822B \
(BIT_MASK_CDEND_TXTIME_H_8822B << BIT_SHIFT_CDEND_TXTIME_H_8822B)
#define BIT_CLEAR_CDEND_TXTIME_H_8822B(x) ((x) & (~BITS_CDEND_TXTIME_H_8822B))
#define BIT_GET_CDEND_TXTIME_H_8822B(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_H_8822B) & \
BIT_MASK_CDEND_TXTIME_H_8822B)
#define BIT_SET_CDEND_TXTIME_H_8822B(x, v) \
(BIT_CLEAR_CDEND_TXTIME_H_8822B(x) | BIT_CDEND_TXTIME_H_8822B(v))
/* 2 REG_QUEUE_CTRL_8822B */
#define BIT_PTA_EDCCA_EN_8822B BIT(5)
#define BIT_PTA_WL_TX_EN_8822B BIT(4)
#define BIT_R_USE_DATA_BW_8822B BIT(3)
#define BIT_TRI_PKT_INT_MODE1_8822B BIT(2)
#define BIT_TRI_PKT_INT_MODE0_8822B BIT(1)
#define BIT_ACQ_MODE_SEL_8822B BIT(0)
/* 2 REG_SINGLE_AMPDU_CTRL_8822B */
#define BIT_EN_SINGLE_APMDU_8822B BIT(7)
/* 2 REG_PROT_MODE_CTRL_8822B */
#define BIT_SHIFT_RTS_MAX_AGG_NUM_8822B 24
#define BIT_MASK_RTS_MAX_AGG_NUM_8822B 0x3f
#define BIT_RTS_MAX_AGG_NUM_8822B(x) \
(((x) & BIT_MASK_RTS_MAX_AGG_NUM_8822B) \
<< BIT_SHIFT_RTS_MAX_AGG_NUM_8822B)
#define BITS_RTS_MAX_AGG_NUM_8822B \
(BIT_MASK_RTS_MAX_AGG_NUM_8822B << BIT_SHIFT_RTS_MAX_AGG_NUM_8822B)
#define BIT_CLEAR_RTS_MAX_AGG_NUM_8822B(x) ((x) & (~BITS_RTS_MAX_AGG_NUM_8822B))
#define BIT_GET_RTS_MAX_AGG_NUM_8822B(x) \
(((x) >> BIT_SHIFT_RTS_MAX_AGG_NUM_8822B) & \
BIT_MASK_RTS_MAX_AGG_NUM_8822B)
#define BIT_SET_RTS_MAX_AGG_NUM_8822B(x, v) \
(BIT_CLEAR_RTS_MAX_AGG_NUM_8822B(x) | BIT_RTS_MAX_AGG_NUM_8822B(v))
#define BIT_SHIFT_MAX_AGG_NUM_8822B 16
#define BIT_MASK_MAX_AGG_NUM_8822B 0x3f
#define BIT_MAX_AGG_NUM_8822B(x) \
(((x) & BIT_MASK_MAX_AGG_NUM_8822B) << BIT_SHIFT_MAX_AGG_NUM_8822B)
#define BITS_MAX_AGG_NUM_8822B \
(BIT_MASK_MAX_AGG_NUM_8822B << BIT_SHIFT_MAX_AGG_NUM_8822B)
#define BIT_CLEAR_MAX_AGG_NUM_8822B(x) ((x) & (~BITS_MAX_AGG_NUM_8822B))
#define BIT_GET_MAX_AGG_NUM_8822B(x) \
(((x) >> BIT_SHIFT_MAX_AGG_NUM_8822B) & BIT_MASK_MAX_AGG_NUM_8822B)
#define BIT_SET_MAX_AGG_NUM_8822B(x, v) \
(BIT_CLEAR_MAX_AGG_NUM_8822B(x) | BIT_MAX_AGG_NUM_8822B(v))
#define BIT_SHIFT_RTS_TXTIME_TH_8822B 8
#define BIT_MASK_RTS_TXTIME_TH_8822B 0xff
#define BIT_RTS_TXTIME_TH_8822B(x) \
(((x) & BIT_MASK_RTS_TXTIME_TH_8822B) << BIT_SHIFT_RTS_TXTIME_TH_8822B)
#define BITS_RTS_TXTIME_TH_8822B \
(BIT_MASK_RTS_TXTIME_TH_8822B << BIT_SHIFT_RTS_TXTIME_TH_8822B)
#define BIT_CLEAR_RTS_TXTIME_TH_8822B(x) ((x) & (~BITS_RTS_TXTIME_TH_8822B))
#define BIT_GET_RTS_TXTIME_TH_8822B(x) \
(((x) >> BIT_SHIFT_RTS_TXTIME_TH_8822B) & BIT_MASK_RTS_TXTIME_TH_8822B)
#define BIT_SET_RTS_TXTIME_TH_8822B(x, v) \
(BIT_CLEAR_RTS_TXTIME_TH_8822B(x) | BIT_RTS_TXTIME_TH_8822B(v))
#define BIT_SHIFT_RTS_LEN_TH_8822B 0
#define BIT_MASK_RTS_LEN_TH_8822B 0xff
#define BIT_RTS_LEN_TH_8822B(x) \
(((x) & BIT_MASK_RTS_LEN_TH_8822B) << BIT_SHIFT_RTS_LEN_TH_8822B)
#define BITS_RTS_LEN_TH_8822B \
(BIT_MASK_RTS_LEN_TH_8822B << BIT_SHIFT_RTS_LEN_TH_8822B)
#define BIT_CLEAR_RTS_LEN_TH_8822B(x) ((x) & (~BITS_RTS_LEN_TH_8822B))
#define BIT_GET_RTS_LEN_TH_8822B(x) \
(((x) >> BIT_SHIFT_RTS_LEN_TH_8822B) & BIT_MASK_RTS_LEN_TH_8822B)
#define BIT_SET_RTS_LEN_TH_8822B(x, v) \
(BIT_CLEAR_RTS_LEN_TH_8822B(x) | BIT_RTS_LEN_TH_8822B(v))
/* 2 REG_BAR_MODE_CTRL_8822B */
#define BIT_SHIFT_BAR_RTY_LMT_8822B 16
#define BIT_MASK_BAR_RTY_LMT_8822B 0x3
#define BIT_BAR_RTY_LMT_8822B(x) \
(((x) & BIT_MASK_BAR_RTY_LMT_8822B) << BIT_SHIFT_BAR_RTY_LMT_8822B)
#define BITS_BAR_RTY_LMT_8822B \
(BIT_MASK_BAR_RTY_LMT_8822B << BIT_SHIFT_BAR_RTY_LMT_8822B)
#define BIT_CLEAR_BAR_RTY_LMT_8822B(x) ((x) & (~BITS_BAR_RTY_LMT_8822B))
#define BIT_GET_BAR_RTY_LMT_8822B(x) \
(((x) >> BIT_SHIFT_BAR_RTY_LMT_8822B) & BIT_MASK_BAR_RTY_LMT_8822B)
#define BIT_SET_BAR_RTY_LMT_8822B(x, v) \
(BIT_CLEAR_BAR_RTY_LMT_8822B(x) | BIT_BAR_RTY_LMT_8822B(v))
#define BIT_SHIFT_BAR_PKT_TXTIME_TH_8822B 8
#define BIT_MASK_BAR_PKT_TXTIME_TH_8822B 0xff
#define BIT_BAR_PKT_TXTIME_TH_8822B(x) \
(((x) & BIT_MASK_BAR_PKT_TXTIME_TH_8822B) \
<< BIT_SHIFT_BAR_PKT_TXTIME_TH_8822B)
#define BITS_BAR_PKT_TXTIME_TH_8822B \
(BIT_MASK_BAR_PKT_TXTIME_TH_8822B << BIT_SHIFT_BAR_PKT_TXTIME_TH_8822B)
#define BIT_CLEAR_BAR_PKT_TXTIME_TH_8822B(x) \
((x) & (~BITS_BAR_PKT_TXTIME_TH_8822B))
#define BIT_GET_BAR_PKT_TXTIME_TH_8822B(x) \
(((x) >> BIT_SHIFT_BAR_PKT_TXTIME_TH_8822B) & \
BIT_MASK_BAR_PKT_TXTIME_TH_8822B)
#define BIT_SET_BAR_PKT_TXTIME_TH_8822B(x, v) \
(BIT_CLEAR_BAR_PKT_TXTIME_TH_8822B(x) | BIT_BAR_PKT_TXTIME_TH_8822B(v))
#define BIT_BAR_EN_V1_8822B BIT(6)
#define BIT_SHIFT_BAR_PKTNUM_TH_V1_8822B 0
#define BIT_MASK_BAR_PKTNUM_TH_V1_8822B 0x3f
#define BIT_BAR_PKTNUM_TH_V1_8822B(x) \
(((x) & BIT_MASK_BAR_PKTNUM_TH_V1_8822B) \
<< BIT_SHIFT_BAR_PKTNUM_TH_V1_8822B)
#define BITS_BAR_PKTNUM_TH_V1_8822B \
(BIT_MASK_BAR_PKTNUM_TH_V1_8822B << BIT_SHIFT_BAR_PKTNUM_TH_V1_8822B)
#define BIT_CLEAR_BAR_PKTNUM_TH_V1_8822B(x) \
((x) & (~BITS_BAR_PKTNUM_TH_V1_8822B))
#define BIT_GET_BAR_PKTNUM_TH_V1_8822B(x) \
(((x) >> BIT_SHIFT_BAR_PKTNUM_TH_V1_8822B) & \
BIT_MASK_BAR_PKTNUM_TH_V1_8822B)
#define BIT_SET_BAR_PKTNUM_TH_V1_8822B(x, v) \
(BIT_CLEAR_BAR_PKTNUM_TH_V1_8822B(x) | BIT_BAR_PKTNUM_TH_V1_8822B(v))
/* 2 REG_RA_TRY_RATE_AGG_LMT_8822B */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822B 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822B 0x3f
#define BIT_RA_TRY_RATE_AGG_LMT_V1_8822B(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822B) \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822B)
#define BITS_RA_TRY_RATE_AGG_LMT_V1_8822B \
(BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822B \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822B)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8822B(x) \
((x) & (~BITS_RA_TRY_RATE_AGG_LMT_V1_8822B))
#define BIT_GET_RA_TRY_RATE_AGG_LMT_V1_8822B(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822B) & \
BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822B)
#define BIT_SET_RA_TRY_RATE_AGG_LMT_V1_8822B(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8822B(x) | \
BIT_RA_TRY_RATE_AGG_LMT_V1_8822B(v))
/* 2 REG_MACID_SLEEP2_8822B */
#define BIT_SHIFT_MACID95_64PKTSLEEP_8822B 0
#define BIT_MASK_MACID95_64PKTSLEEP_8822B 0xffffffffL
#define BIT_MACID95_64PKTSLEEP_8822B(x) \
(((x) & BIT_MASK_MACID95_64PKTSLEEP_8822B) \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8822B)
#define BITS_MACID95_64PKTSLEEP_8822B \
(BIT_MASK_MACID95_64PKTSLEEP_8822B \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8822B)
#define BIT_CLEAR_MACID95_64PKTSLEEP_8822B(x) \
((x) & (~BITS_MACID95_64PKTSLEEP_8822B))
#define BIT_GET_MACID95_64PKTSLEEP_8822B(x) \
(((x) >> BIT_SHIFT_MACID95_64PKTSLEEP_8822B) & \
BIT_MASK_MACID95_64PKTSLEEP_8822B)
#define BIT_SET_MACID95_64PKTSLEEP_8822B(x, v) \
(BIT_CLEAR_MACID95_64PKTSLEEP_8822B(x) | \
BIT_MACID95_64PKTSLEEP_8822B(v))
/* 2 REG_MACID_SLEEP_8822B */
#define BIT_SHIFT_MACID31_0_PKTSLEEP_8822B 0
#define BIT_MASK_MACID31_0_PKTSLEEP_8822B 0xffffffffL
#define BIT_MACID31_0_PKTSLEEP_8822B(x) \
(((x) & BIT_MASK_MACID31_0_PKTSLEEP_8822B) \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8822B)
#define BITS_MACID31_0_PKTSLEEP_8822B \
(BIT_MASK_MACID31_0_PKTSLEEP_8822B \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8822B)
#define BIT_CLEAR_MACID31_0_PKTSLEEP_8822B(x) \
((x) & (~BITS_MACID31_0_PKTSLEEP_8822B))
#define BIT_GET_MACID31_0_PKTSLEEP_8822B(x) \
(((x) >> BIT_SHIFT_MACID31_0_PKTSLEEP_8822B) & \
BIT_MASK_MACID31_0_PKTSLEEP_8822B)
#define BIT_SET_MACID31_0_PKTSLEEP_8822B(x, v) \
(BIT_CLEAR_MACID31_0_PKTSLEEP_8822B(x) | \
BIT_MACID31_0_PKTSLEEP_8822B(v))
/* 2 REG_HW_SEQ0_8822B */
#define BIT_SHIFT_HW_SSN_SEQ0_8822B 0
#define BIT_MASK_HW_SSN_SEQ0_8822B 0xfff
#define BIT_HW_SSN_SEQ0_8822B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ0_8822B) << BIT_SHIFT_HW_SSN_SEQ0_8822B)
#define BITS_HW_SSN_SEQ0_8822B \
(BIT_MASK_HW_SSN_SEQ0_8822B << BIT_SHIFT_HW_SSN_SEQ0_8822B)
#define BIT_CLEAR_HW_SSN_SEQ0_8822B(x) ((x) & (~BITS_HW_SSN_SEQ0_8822B))
#define BIT_GET_HW_SSN_SEQ0_8822B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ0_8822B) & BIT_MASK_HW_SSN_SEQ0_8822B)
#define BIT_SET_HW_SSN_SEQ0_8822B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ0_8822B(x) | BIT_HW_SSN_SEQ0_8822B(v))
/* 2 REG_HW_SEQ1_8822B */
#define BIT_SHIFT_HW_SSN_SEQ1_8822B 0
#define BIT_MASK_HW_SSN_SEQ1_8822B 0xfff
#define BIT_HW_SSN_SEQ1_8822B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ1_8822B) << BIT_SHIFT_HW_SSN_SEQ1_8822B)
#define BITS_HW_SSN_SEQ1_8822B \
(BIT_MASK_HW_SSN_SEQ1_8822B << BIT_SHIFT_HW_SSN_SEQ1_8822B)
#define BIT_CLEAR_HW_SSN_SEQ1_8822B(x) ((x) & (~BITS_HW_SSN_SEQ1_8822B))
#define BIT_GET_HW_SSN_SEQ1_8822B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ1_8822B) & BIT_MASK_HW_SSN_SEQ1_8822B)
#define BIT_SET_HW_SSN_SEQ1_8822B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ1_8822B(x) | BIT_HW_SSN_SEQ1_8822B(v))
/* 2 REG_HW_SEQ2_8822B */
#define BIT_SHIFT_HW_SSN_SEQ2_8822B 0
#define BIT_MASK_HW_SSN_SEQ2_8822B 0xfff
#define BIT_HW_SSN_SEQ2_8822B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ2_8822B) << BIT_SHIFT_HW_SSN_SEQ2_8822B)
#define BITS_HW_SSN_SEQ2_8822B \
(BIT_MASK_HW_SSN_SEQ2_8822B << BIT_SHIFT_HW_SSN_SEQ2_8822B)
#define BIT_CLEAR_HW_SSN_SEQ2_8822B(x) ((x) & (~BITS_HW_SSN_SEQ2_8822B))
#define BIT_GET_HW_SSN_SEQ2_8822B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ2_8822B) & BIT_MASK_HW_SSN_SEQ2_8822B)
#define BIT_SET_HW_SSN_SEQ2_8822B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ2_8822B(x) | BIT_HW_SSN_SEQ2_8822B(v))
/* 2 REG_HW_SEQ3_8822B */
#define BIT_SHIFT_HW_SSN_SEQ3_8822B 0
#define BIT_MASK_HW_SSN_SEQ3_8822B 0xfff
#define BIT_HW_SSN_SEQ3_8822B(x) \
(((x) & BIT_MASK_HW_SSN_SEQ3_8822B) << BIT_SHIFT_HW_SSN_SEQ3_8822B)
#define BITS_HW_SSN_SEQ3_8822B \
(BIT_MASK_HW_SSN_SEQ3_8822B << BIT_SHIFT_HW_SSN_SEQ3_8822B)
#define BIT_CLEAR_HW_SSN_SEQ3_8822B(x) ((x) & (~BITS_HW_SSN_SEQ3_8822B))
#define BIT_GET_HW_SSN_SEQ3_8822B(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ3_8822B) & BIT_MASK_HW_SSN_SEQ3_8822B)
#define BIT_SET_HW_SSN_SEQ3_8822B(x, v) \
(BIT_CLEAR_HW_SSN_SEQ3_8822B(x) | BIT_HW_SSN_SEQ3_8822B(v))
/* 2 REG_NULL_PKT_STATUS_V1_8822B */
#define BIT_SHIFT_PTCL_TOTAL_PG_V2_8822B 2
#define BIT_MASK_PTCL_TOTAL_PG_V2_8822B 0x3fff
#define BIT_PTCL_TOTAL_PG_V2_8822B(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V2_8822B) \
<< BIT_SHIFT_PTCL_TOTAL_PG_V2_8822B)
#define BITS_PTCL_TOTAL_PG_V2_8822B \
(BIT_MASK_PTCL_TOTAL_PG_V2_8822B << BIT_SHIFT_PTCL_TOTAL_PG_V2_8822B)
#define BIT_CLEAR_PTCL_TOTAL_PG_V2_8822B(x) \
((x) & (~BITS_PTCL_TOTAL_PG_V2_8822B))
#define BIT_GET_PTCL_TOTAL_PG_V2_8822B(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V2_8822B) & \
BIT_MASK_PTCL_TOTAL_PG_V2_8822B)
#define BIT_SET_PTCL_TOTAL_PG_V2_8822B(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V2_8822B(x) | BIT_PTCL_TOTAL_PG_V2_8822B(v))
#define BIT_TX_NULL_1_8822B BIT(1)
#define BIT_TX_NULL_0_8822B BIT(0)
/* 2 REG_PTCL_ERR_STATUS_8822B */
#define BIT_PTCL_RATE_TABLE_INVALID_8822B BIT(7)
#define BIT_FTM_T2R_ERROR_8822B BIT(6)
#define BIT_PTCL_ERR0_8822B BIT(5)
#define BIT_PTCL_ERR1_8822B BIT(4)
#define BIT_PTCL_ERR2_8822B BIT(3)
#define BIT_PTCL_ERR3_8822B BIT(2)
#define BIT_PTCL_ERR4_8822B BIT(1)
#define BIT_PTCL_ERR5_8822B BIT(0)
/* 2 REG_NULL_PKT_STATUS_EXTEND_8822B */
#define BIT_CLI3_TX_NULL_1_8822B BIT(7)
#define BIT_CLI3_TX_NULL_0_8822B BIT(6)
#define BIT_CLI2_TX_NULL_1_8822B BIT(5)
#define BIT_CLI2_TX_NULL_0_8822B BIT(4)
#define BIT_CLI1_TX_NULL_1_8822B BIT(3)
#define BIT_CLI1_TX_NULL_0_8822B BIT(2)
#define BIT_CLI0_TX_NULL_1_8822B BIT(1)
#define BIT_CLI0_TX_NULL_0_8822B BIT(0)
/* 2 REG_VIDEO_ENHANCEMENT_FUN_8822B */
#define BIT_VIDEO_JUST_DROP_8822B BIT(1)
#define BIT_VIDEO_ENHANCEMENT_FUN_EN_8822B BIT(0)
/* 2 REG_BT_POLLUTE_PKT_CNT_8822B */
#define BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822B 0
#define BIT_MASK_BT_POLLUTE_PKT_CNT_8822B 0xffff
#define BIT_BT_POLLUTE_PKT_CNT_8822B(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKT_CNT_8822B) \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822B)
#define BITS_BT_POLLUTE_PKT_CNT_8822B \
(BIT_MASK_BT_POLLUTE_PKT_CNT_8822B \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822B)
#define BIT_CLEAR_BT_POLLUTE_PKT_CNT_8822B(x) \
((x) & (~BITS_BT_POLLUTE_PKT_CNT_8822B))
#define BIT_GET_BT_POLLUTE_PKT_CNT_8822B(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822B) & \
BIT_MASK_BT_POLLUTE_PKT_CNT_8822B)
#define BIT_SET_BT_POLLUTE_PKT_CNT_8822B(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKT_CNT_8822B(x) | \
BIT_BT_POLLUTE_PKT_CNT_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_PTCL_DBG_8822B */
#define BIT_SHIFT_PTCL_DBG_8822B 0
#define BIT_MASK_PTCL_DBG_8822B 0xffffffffL
#define BIT_PTCL_DBG_8822B(x) \
(((x) & BIT_MASK_PTCL_DBG_8822B) << BIT_SHIFT_PTCL_DBG_8822B)
#define BITS_PTCL_DBG_8822B \
(BIT_MASK_PTCL_DBG_8822B << BIT_SHIFT_PTCL_DBG_8822B)
#define BIT_CLEAR_PTCL_DBG_8822B(x) ((x) & (~BITS_PTCL_DBG_8822B))
#define BIT_GET_PTCL_DBG_8822B(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_8822B) & BIT_MASK_PTCL_DBG_8822B)
#define BIT_SET_PTCL_DBG_8822B(x, v) \
(BIT_CLEAR_PTCL_DBG_8822B(x) | BIT_PTCL_DBG_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_CPUMGQ_TIMER_CTRL2_8822B */
#define BIT_SHIFT_TRI_HEAD_ADDR_8822B 16
#define BIT_MASK_TRI_HEAD_ADDR_8822B 0xfff
#define BIT_TRI_HEAD_ADDR_8822B(x) \
(((x) & BIT_MASK_TRI_HEAD_ADDR_8822B) << BIT_SHIFT_TRI_HEAD_ADDR_8822B)
#define BITS_TRI_HEAD_ADDR_8822B \
(BIT_MASK_TRI_HEAD_ADDR_8822B << BIT_SHIFT_TRI_HEAD_ADDR_8822B)
#define BIT_CLEAR_TRI_HEAD_ADDR_8822B(x) ((x) & (~BITS_TRI_HEAD_ADDR_8822B))
#define BIT_GET_TRI_HEAD_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_TRI_HEAD_ADDR_8822B) & BIT_MASK_TRI_HEAD_ADDR_8822B)
#define BIT_SET_TRI_HEAD_ADDR_8822B(x, v) \
(BIT_CLEAR_TRI_HEAD_ADDR_8822B(x) | BIT_TRI_HEAD_ADDR_8822B(v))
#define BIT_DROP_TH_EN_8822B BIT(8)
#define BIT_SHIFT_DROP_TH_8822B 0
#define BIT_MASK_DROP_TH_8822B 0xff
#define BIT_DROP_TH_8822B(x) \
(((x) & BIT_MASK_DROP_TH_8822B) << BIT_SHIFT_DROP_TH_8822B)
#define BITS_DROP_TH_8822B (BIT_MASK_DROP_TH_8822B << BIT_SHIFT_DROP_TH_8822B)
#define BIT_CLEAR_DROP_TH_8822B(x) ((x) & (~BITS_DROP_TH_8822B))
#define BIT_GET_DROP_TH_8822B(x) \
(((x) >> BIT_SHIFT_DROP_TH_8822B) & BIT_MASK_DROP_TH_8822B)
#define BIT_SET_DROP_TH_8822B(x, v) \
(BIT_CLEAR_DROP_TH_8822B(x) | BIT_DROP_TH_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_DUMMY_PAGE4_V1_8822B */
#define BIT_BCN_EN_EXTHWSEQ_8822B BIT(1)
#define BIT_BCN_EN_HWSEQ_8822B BIT(0)
/* 2 REG_MOREDATA_8822B */
#define BIT_MOREDATA_CTRL2_EN_V1_8822B BIT(3)
#define BIT_MOREDATA_CTRL1_EN_V1_8822B BIT(2)
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE_V1_8822B BIT(0)
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_Q0_Q1_INFO_8822B */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822B BIT(31)
#define BIT_SHIFT_GTAB_ID_8822B 28
#define BIT_MASK_GTAB_ID_8822B 0x7
#define BIT_GTAB_ID_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_8822B) << BIT_SHIFT_GTAB_ID_8822B)
#define BITS_GTAB_ID_8822B (BIT_MASK_GTAB_ID_8822B << BIT_SHIFT_GTAB_ID_8822B)
#define BIT_CLEAR_GTAB_ID_8822B(x) ((x) & (~BITS_GTAB_ID_8822B))
#define BIT_GET_GTAB_ID_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822B) & BIT_MASK_GTAB_ID_8822B)
#define BIT_SET_GTAB_ID_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_8822B(x) | BIT_GTAB_ID_8822B(v))
#define BIT_SHIFT_AC1_PKT_INFO_8822B 16
#define BIT_MASK_AC1_PKT_INFO_8822B 0xfff
#define BIT_AC1_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC1_PKT_INFO_8822B) << BIT_SHIFT_AC1_PKT_INFO_8822B)
#define BITS_AC1_PKT_INFO_8822B \
(BIT_MASK_AC1_PKT_INFO_8822B << BIT_SHIFT_AC1_PKT_INFO_8822B)
#define BIT_CLEAR_AC1_PKT_INFO_8822B(x) ((x) & (~BITS_AC1_PKT_INFO_8822B))
#define BIT_GET_AC1_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC1_PKT_INFO_8822B) & BIT_MASK_AC1_PKT_INFO_8822B)
#define BIT_SET_AC1_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC1_PKT_INFO_8822B(x) | BIT_AC1_PKT_INFO_8822B(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822B BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822B 12
#define BIT_MASK_GTAB_ID_V1_8822B 0x7
#define BIT_GTAB_ID_V1_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822B) << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BITS_GTAB_ID_V1_8822B \
(BIT_MASK_GTAB_ID_V1_8822B << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BIT_CLEAR_GTAB_ID_V1_8822B(x) ((x) & (~BITS_GTAB_ID_V1_8822B))
#define BIT_GET_GTAB_ID_V1_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822B) & BIT_MASK_GTAB_ID_V1_8822B)
#define BIT_SET_GTAB_ID_V1_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822B(x) | BIT_GTAB_ID_V1_8822B(v))
#define BIT_SHIFT_AC0_PKT_INFO_8822B 0
#define BIT_MASK_AC0_PKT_INFO_8822B 0xfff
#define BIT_AC0_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC0_PKT_INFO_8822B) << BIT_SHIFT_AC0_PKT_INFO_8822B)
#define BITS_AC0_PKT_INFO_8822B \
(BIT_MASK_AC0_PKT_INFO_8822B << BIT_SHIFT_AC0_PKT_INFO_8822B)
#define BIT_CLEAR_AC0_PKT_INFO_8822B(x) ((x) & (~BITS_AC0_PKT_INFO_8822B))
#define BIT_GET_AC0_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC0_PKT_INFO_8822B) & BIT_MASK_AC0_PKT_INFO_8822B)
#define BIT_SET_AC0_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC0_PKT_INFO_8822B(x) | BIT_AC0_PKT_INFO_8822B(v))
/* 2 REG_Q2_Q3_INFO_8822B */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822B BIT(31)
#define BIT_SHIFT_GTAB_ID_8822B 28
#define BIT_MASK_GTAB_ID_8822B 0x7
#define BIT_GTAB_ID_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_8822B) << BIT_SHIFT_GTAB_ID_8822B)
#define BITS_GTAB_ID_8822B (BIT_MASK_GTAB_ID_8822B << BIT_SHIFT_GTAB_ID_8822B)
#define BIT_CLEAR_GTAB_ID_8822B(x) ((x) & (~BITS_GTAB_ID_8822B))
#define BIT_GET_GTAB_ID_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822B) & BIT_MASK_GTAB_ID_8822B)
#define BIT_SET_GTAB_ID_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_8822B(x) | BIT_GTAB_ID_8822B(v))
#define BIT_SHIFT_AC3_PKT_INFO_8822B 16
#define BIT_MASK_AC3_PKT_INFO_8822B 0xfff
#define BIT_AC3_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC3_PKT_INFO_8822B) << BIT_SHIFT_AC3_PKT_INFO_8822B)
#define BITS_AC3_PKT_INFO_8822B \
(BIT_MASK_AC3_PKT_INFO_8822B << BIT_SHIFT_AC3_PKT_INFO_8822B)
#define BIT_CLEAR_AC3_PKT_INFO_8822B(x) ((x) & (~BITS_AC3_PKT_INFO_8822B))
#define BIT_GET_AC3_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC3_PKT_INFO_8822B) & BIT_MASK_AC3_PKT_INFO_8822B)
#define BIT_SET_AC3_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC3_PKT_INFO_8822B(x) | BIT_AC3_PKT_INFO_8822B(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822B BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822B 12
#define BIT_MASK_GTAB_ID_V1_8822B 0x7
#define BIT_GTAB_ID_V1_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822B) << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BITS_GTAB_ID_V1_8822B \
(BIT_MASK_GTAB_ID_V1_8822B << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BIT_CLEAR_GTAB_ID_V1_8822B(x) ((x) & (~BITS_GTAB_ID_V1_8822B))
#define BIT_GET_GTAB_ID_V1_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822B) & BIT_MASK_GTAB_ID_V1_8822B)
#define BIT_SET_GTAB_ID_V1_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822B(x) | BIT_GTAB_ID_V1_8822B(v))
#define BIT_SHIFT_AC2_PKT_INFO_8822B 0
#define BIT_MASK_AC2_PKT_INFO_8822B 0xfff
#define BIT_AC2_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC2_PKT_INFO_8822B) << BIT_SHIFT_AC2_PKT_INFO_8822B)
#define BITS_AC2_PKT_INFO_8822B \
(BIT_MASK_AC2_PKT_INFO_8822B << BIT_SHIFT_AC2_PKT_INFO_8822B)
#define BIT_CLEAR_AC2_PKT_INFO_8822B(x) ((x) & (~BITS_AC2_PKT_INFO_8822B))
#define BIT_GET_AC2_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC2_PKT_INFO_8822B) & BIT_MASK_AC2_PKT_INFO_8822B)
#define BIT_SET_AC2_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC2_PKT_INFO_8822B(x) | BIT_AC2_PKT_INFO_8822B(v))
/* 2 REG_Q4_Q5_INFO_8822B */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822B BIT(31)
#define BIT_SHIFT_GTAB_ID_8822B 28
#define BIT_MASK_GTAB_ID_8822B 0x7
#define BIT_GTAB_ID_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_8822B) << BIT_SHIFT_GTAB_ID_8822B)
#define BITS_GTAB_ID_8822B (BIT_MASK_GTAB_ID_8822B << BIT_SHIFT_GTAB_ID_8822B)
#define BIT_CLEAR_GTAB_ID_8822B(x) ((x) & (~BITS_GTAB_ID_8822B))
#define BIT_GET_GTAB_ID_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822B) & BIT_MASK_GTAB_ID_8822B)
#define BIT_SET_GTAB_ID_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_8822B(x) | BIT_GTAB_ID_8822B(v))
#define BIT_SHIFT_AC5_PKT_INFO_8822B 16
#define BIT_MASK_AC5_PKT_INFO_8822B 0xfff
#define BIT_AC5_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC5_PKT_INFO_8822B) << BIT_SHIFT_AC5_PKT_INFO_8822B)
#define BITS_AC5_PKT_INFO_8822B \
(BIT_MASK_AC5_PKT_INFO_8822B << BIT_SHIFT_AC5_PKT_INFO_8822B)
#define BIT_CLEAR_AC5_PKT_INFO_8822B(x) ((x) & (~BITS_AC5_PKT_INFO_8822B))
#define BIT_GET_AC5_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC5_PKT_INFO_8822B) & BIT_MASK_AC5_PKT_INFO_8822B)
#define BIT_SET_AC5_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC5_PKT_INFO_8822B(x) | BIT_AC5_PKT_INFO_8822B(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822B BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822B 12
#define BIT_MASK_GTAB_ID_V1_8822B 0x7
#define BIT_GTAB_ID_V1_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822B) << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BITS_GTAB_ID_V1_8822B \
(BIT_MASK_GTAB_ID_V1_8822B << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BIT_CLEAR_GTAB_ID_V1_8822B(x) ((x) & (~BITS_GTAB_ID_V1_8822B))
#define BIT_GET_GTAB_ID_V1_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822B) & BIT_MASK_GTAB_ID_V1_8822B)
#define BIT_SET_GTAB_ID_V1_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822B(x) | BIT_GTAB_ID_V1_8822B(v))
#define BIT_SHIFT_AC4_PKT_INFO_8822B 0
#define BIT_MASK_AC4_PKT_INFO_8822B 0xfff
#define BIT_AC4_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC4_PKT_INFO_8822B) << BIT_SHIFT_AC4_PKT_INFO_8822B)
#define BITS_AC4_PKT_INFO_8822B \
(BIT_MASK_AC4_PKT_INFO_8822B << BIT_SHIFT_AC4_PKT_INFO_8822B)
#define BIT_CLEAR_AC4_PKT_INFO_8822B(x) ((x) & (~BITS_AC4_PKT_INFO_8822B))
#define BIT_GET_AC4_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC4_PKT_INFO_8822B) & BIT_MASK_AC4_PKT_INFO_8822B)
#define BIT_SET_AC4_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC4_PKT_INFO_8822B(x) | BIT_AC4_PKT_INFO_8822B(v))
/* 2 REG_Q6_Q7_INFO_8822B */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822B BIT(31)
#define BIT_SHIFT_GTAB_ID_8822B 28
#define BIT_MASK_GTAB_ID_8822B 0x7
#define BIT_GTAB_ID_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_8822B) << BIT_SHIFT_GTAB_ID_8822B)
#define BITS_GTAB_ID_8822B (BIT_MASK_GTAB_ID_8822B << BIT_SHIFT_GTAB_ID_8822B)
#define BIT_CLEAR_GTAB_ID_8822B(x) ((x) & (~BITS_GTAB_ID_8822B))
#define BIT_GET_GTAB_ID_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822B) & BIT_MASK_GTAB_ID_8822B)
#define BIT_SET_GTAB_ID_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_8822B(x) | BIT_GTAB_ID_8822B(v))
#define BIT_SHIFT_AC7_PKT_INFO_8822B 16
#define BIT_MASK_AC7_PKT_INFO_8822B 0xfff
#define BIT_AC7_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC7_PKT_INFO_8822B) << BIT_SHIFT_AC7_PKT_INFO_8822B)
#define BITS_AC7_PKT_INFO_8822B \
(BIT_MASK_AC7_PKT_INFO_8822B << BIT_SHIFT_AC7_PKT_INFO_8822B)
#define BIT_CLEAR_AC7_PKT_INFO_8822B(x) ((x) & (~BITS_AC7_PKT_INFO_8822B))
#define BIT_GET_AC7_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC7_PKT_INFO_8822B) & BIT_MASK_AC7_PKT_INFO_8822B)
#define BIT_SET_AC7_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC7_PKT_INFO_8822B(x) | BIT_AC7_PKT_INFO_8822B(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822B BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822B 12
#define BIT_MASK_GTAB_ID_V1_8822B 0x7
#define BIT_GTAB_ID_V1_8822B(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822B) << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BITS_GTAB_ID_V1_8822B \
(BIT_MASK_GTAB_ID_V1_8822B << BIT_SHIFT_GTAB_ID_V1_8822B)
#define BIT_CLEAR_GTAB_ID_V1_8822B(x) ((x) & (~BITS_GTAB_ID_V1_8822B))
#define BIT_GET_GTAB_ID_V1_8822B(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822B) & BIT_MASK_GTAB_ID_V1_8822B)
#define BIT_SET_GTAB_ID_V1_8822B(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822B(x) | BIT_GTAB_ID_V1_8822B(v))
#define BIT_SHIFT_AC6_PKT_INFO_8822B 0
#define BIT_MASK_AC6_PKT_INFO_8822B 0xfff
#define BIT_AC6_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_AC6_PKT_INFO_8822B) << BIT_SHIFT_AC6_PKT_INFO_8822B)
#define BITS_AC6_PKT_INFO_8822B \
(BIT_MASK_AC6_PKT_INFO_8822B << BIT_SHIFT_AC6_PKT_INFO_8822B)
#define BIT_CLEAR_AC6_PKT_INFO_8822B(x) ((x) & (~BITS_AC6_PKT_INFO_8822B))
#define BIT_GET_AC6_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_AC6_PKT_INFO_8822B) & BIT_MASK_AC6_PKT_INFO_8822B)
#define BIT_SET_AC6_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_AC6_PKT_INFO_8822B(x) | BIT_AC6_PKT_INFO_8822B(v))
/* 2 REG_MGQ_HIQ_INFO_8822B */
#define BIT_SHIFT_HIQ_PKT_INFO_8822B 16
#define BIT_MASK_HIQ_PKT_INFO_8822B 0xfff
#define BIT_HIQ_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_HIQ_PKT_INFO_8822B) << BIT_SHIFT_HIQ_PKT_INFO_8822B)
#define BITS_HIQ_PKT_INFO_8822B \
(BIT_MASK_HIQ_PKT_INFO_8822B << BIT_SHIFT_HIQ_PKT_INFO_8822B)
#define BIT_CLEAR_HIQ_PKT_INFO_8822B(x) ((x) & (~BITS_HIQ_PKT_INFO_8822B))
#define BIT_GET_HIQ_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_HIQ_PKT_INFO_8822B) & BIT_MASK_HIQ_PKT_INFO_8822B)
#define BIT_SET_HIQ_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_HIQ_PKT_INFO_8822B(x) | BIT_HIQ_PKT_INFO_8822B(v))
#define BIT_SHIFT_MGQ_PKT_INFO_8822B 0
#define BIT_MASK_MGQ_PKT_INFO_8822B 0xfff
#define BIT_MGQ_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_MGQ_PKT_INFO_8822B) << BIT_SHIFT_MGQ_PKT_INFO_8822B)
#define BITS_MGQ_PKT_INFO_8822B \
(BIT_MASK_MGQ_PKT_INFO_8822B << BIT_SHIFT_MGQ_PKT_INFO_8822B)
#define BIT_CLEAR_MGQ_PKT_INFO_8822B(x) ((x) & (~BITS_MGQ_PKT_INFO_8822B))
#define BIT_GET_MGQ_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_MGQ_PKT_INFO_8822B) & BIT_MASK_MGQ_PKT_INFO_8822B)
#define BIT_SET_MGQ_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_MGQ_PKT_INFO_8822B(x) | BIT_MGQ_PKT_INFO_8822B(v))
/* 2 REG_CMDQ_BCNQ_INFO_8822B */
#define BIT_SHIFT_CMDQ_PKT_INFO_8822B 16
#define BIT_MASK_CMDQ_PKT_INFO_8822B 0xfff
#define BIT_CMDQ_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_CMDQ_PKT_INFO_8822B) << BIT_SHIFT_CMDQ_PKT_INFO_8822B)
#define BITS_CMDQ_PKT_INFO_8822B \
(BIT_MASK_CMDQ_PKT_INFO_8822B << BIT_SHIFT_CMDQ_PKT_INFO_8822B)
#define BIT_CLEAR_CMDQ_PKT_INFO_8822B(x) ((x) & (~BITS_CMDQ_PKT_INFO_8822B))
#define BIT_GET_CMDQ_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_CMDQ_PKT_INFO_8822B) & BIT_MASK_CMDQ_PKT_INFO_8822B)
#define BIT_SET_CMDQ_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_CMDQ_PKT_INFO_8822B(x) | BIT_CMDQ_PKT_INFO_8822B(v))
#define BIT_SHIFT_BCNQ_PKT_INFO_8822B 0
#define BIT_MASK_BCNQ_PKT_INFO_8822B 0xfff
#define BIT_BCNQ_PKT_INFO_8822B(x) \
(((x) & BIT_MASK_BCNQ_PKT_INFO_8822B) << BIT_SHIFT_BCNQ_PKT_INFO_8822B)
#define BITS_BCNQ_PKT_INFO_8822B \
(BIT_MASK_BCNQ_PKT_INFO_8822B << BIT_SHIFT_BCNQ_PKT_INFO_8822B)
#define BIT_CLEAR_BCNQ_PKT_INFO_8822B(x) ((x) & (~BITS_BCNQ_PKT_INFO_8822B))
#define BIT_GET_BCNQ_PKT_INFO_8822B(x) \
(((x) >> BIT_SHIFT_BCNQ_PKT_INFO_8822B) & BIT_MASK_BCNQ_PKT_INFO_8822B)
#define BIT_SET_BCNQ_PKT_INFO_8822B(x, v) \
(BIT_CLEAR_BCNQ_PKT_INFO_8822B(x) | BIT_BCNQ_PKT_INFO_8822B(v))
/* 2 REG_USEREG_SETTING_8822B */
#define BIT_NDPA_USEREG_8822B BIT(21)
#define BIT_SHIFT_RETRY_USEREG_8822B 19
#define BIT_MASK_RETRY_USEREG_8822B 0x3
#define BIT_RETRY_USEREG_8822B(x) \
(((x) & BIT_MASK_RETRY_USEREG_8822B) << BIT_SHIFT_RETRY_USEREG_8822B)
#define BITS_RETRY_USEREG_8822B \
(BIT_MASK_RETRY_USEREG_8822B << BIT_SHIFT_RETRY_USEREG_8822B)
#define BIT_CLEAR_RETRY_USEREG_8822B(x) ((x) & (~BITS_RETRY_USEREG_8822B))
#define BIT_GET_RETRY_USEREG_8822B(x) \
(((x) >> BIT_SHIFT_RETRY_USEREG_8822B) & BIT_MASK_RETRY_USEREG_8822B)
#define BIT_SET_RETRY_USEREG_8822B(x, v) \
(BIT_CLEAR_RETRY_USEREG_8822B(x) | BIT_RETRY_USEREG_8822B(v))
#define BIT_SHIFT_TRYPKT_USEREG_8822B 17
#define BIT_MASK_TRYPKT_USEREG_8822B 0x3
#define BIT_TRYPKT_USEREG_8822B(x) \
(((x) & BIT_MASK_TRYPKT_USEREG_8822B) << BIT_SHIFT_TRYPKT_USEREG_8822B)
#define BITS_TRYPKT_USEREG_8822B \
(BIT_MASK_TRYPKT_USEREG_8822B << BIT_SHIFT_TRYPKT_USEREG_8822B)
#define BIT_CLEAR_TRYPKT_USEREG_8822B(x) ((x) & (~BITS_TRYPKT_USEREG_8822B))
#define BIT_GET_TRYPKT_USEREG_8822B(x) \
(((x) >> BIT_SHIFT_TRYPKT_USEREG_8822B) & BIT_MASK_TRYPKT_USEREG_8822B)
#define BIT_SET_TRYPKT_USEREG_8822B(x, v) \
(BIT_CLEAR_TRYPKT_USEREG_8822B(x) | BIT_TRYPKT_USEREG_8822B(v))
#define BIT_CTLPKT_USEREG_8822B BIT(16)
/* 2 REG_AESIV_SETTING_8822B */
#define BIT_SHIFT_AESIV_OFFSET_8822B 0
#define BIT_MASK_AESIV_OFFSET_8822B 0xfff
#define BIT_AESIV_OFFSET_8822B(x) \
(((x) & BIT_MASK_AESIV_OFFSET_8822B) << BIT_SHIFT_AESIV_OFFSET_8822B)
#define BITS_AESIV_OFFSET_8822B \
(BIT_MASK_AESIV_OFFSET_8822B << BIT_SHIFT_AESIV_OFFSET_8822B)
#define BIT_CLEAR_AESIV_OFFSET_8822B(x) ((x) & (~BITS_AESIV_OFFSET_8822B))
#define BIT_GET_AESIV_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_AESIV_OFFSET_8822B) & BIT_MASK_AESIV_OFFSET_8822B)
#define BIT_SET_AESIV_OFFSET_8822B(x, v) \
(BIT_CLEAR_AESIV_OFFSET_8822B(x) | BIT_AESIV_OFFSET_8822B(v))
/* 2 REG_BF0_TIME_SETTING_8822B */
#define BIT_BF0_TIMER_SET_8822B BIT(31)
#define BIT_BF0_TIMER_CLR_8822B BIT(30)
#define BIT_BF0_UPDATE_EN_8822B BIT(29)
#define BIT_BF0_TIMER_EN_8822B BIT(28)
#define BIT_SHIFT_BF0_PRETIME_OVER_8822B 16
#define BIT_MASK_BF0_PRETIME_OVER_8822B 0xfff
#define BIT_BF0_PRETIME_OVER_8822B(x) \
(((x) & BIT_MASK_BF0_PRETIME_OVER_8822B) \
<< BIT_SHIFT_BF0_PRETIME_OVER_8822B)
#define BITS_BF0_PRETIME_OVER_8822B \
(BIT_MASK_BF0_PRETIME_OVER_8822B << BIT_SHIFT_BF0_PRETIME_OVER_8822B)
#define BIT_CLEAR_BF0_PRETIME_OVER_8822B(x) \
((x) & (~BITS_BF0_PRETIME_OVER_8822B))
#define BIT_GET_BF0_PRETIME_OVER_8822B(x) \
(((x) >> BIT_SHIFT_BF0_PRETIME_OVER_8822B) & \
BIT_MASK_BF0_PRETIME_OVER_8822B)
#define BIT_SET_BF0_PRETIME_OVER_8822B(x, v) \
(BIT_CLEAR_BF0_PRETIME_OVER_8822B(x) | BIT_BF0_PRETIME_OVER_8822B(v))
#define BIT_SHIFT_BF0_LIFETIME_8822B 0
#define BIT_MASK_BF0_LIFETIME_8822B 0xffff
#define BIT_BF0_LIFETIME_8822B(x) \
(((x) & BIT_MASK_BF0_LIFETIME_8822B) << BIT_SHIFT_BF0_LIFETIME_8822B)
#define BITS_BF0_LIFETIME_8822B \
(BIT_MASK_BF0_LIFETIME_8822B << BIT_SHIFT_BF0_LIFETIME_8822B)
#define BIT_CLEAR_BF0_LIFETIME_8822B(x) ((x) & (~BITS_BF0_LIFETIME_8822B))
#define BIT_GET_BF0_LIFETIME_8822B(x) \
(((x) >> BIT_SHIFT_BF0_LIFETIME_8822B) & BIT_MASK_BF0_LIFETIME_8822B)
#define BIT_SET_BF0_LIFETIME_8822B(x, v) \
(BIT_CLEAR_BF0_LIFETIME_8822B(x) | BIT_BF0_LIFETIME_8822B(v))
/* 2 REG_BF1_TIME_SETTING_8822B */
#define BIT_BF1_TIMER_SET_8822B BIT(31)
#define BIT_BF1_TIMER_CLR_8822B BIT(30)
#define BIT_BF1_UPDATE_EN_8822B BIT(29)
#define BIT_BF1_TIMER_EN_8822B BIT(28)
#define BIT_SHIFT_BF1_PRETIME_OVER_8822B 16
#define BIT_MASK_BF1_PRETIME_OVER_8822B 0xfff
#define BIT_BF1_PRETIME_OVER_8822B(x) \
(((x) & BIT_MASK_BF1_PRETIME_OVER_8822B) \
<< BIT_SHIFT_BF1_PRETIME_OVER_8822B)
#define BITS_BF1_PRETIME_OVER_8822B \
(BIT_MASK_BF1_PRETIME_OVER_8822B << BIT_SHIFT_BF1_PRETIME_OVER_8822B)
#define BIT_CLEAR_BF1_PRETIME_OVER_8822B(x) \
((x) & (~BITS_BF1_PRETIME_OVER_8822B))
#define BIT_GET_BF1_PRETIME_OVER_8822B(x) \
(((x) >> BIT_SHIFT_BF1_PRETIME_OVER_8822B) & \
BIT_MASK_BF1_PRETIME_OVER_8822B)
#define BIT_SET_BF1_PRETIME_OVER_8822B(x, v) \
(BIT_CLEAR_BF1_PRETIME_OVER_8822B(x) | BIT_BF1_PRETIME_OVER_8822B(v))
#define BIT_SHIFT_BF1_LIFETIME_8822B 0
#define BIT_MASK_BF1_LIFETIME_8822B 0xffff
#define BIT_BF1_LIFETIME_8822B(x) \
(((x) & BIT_MASK_BF1_LIFETIME_8822B) << BIT_SHIFT_BF1_LIFETIME_8822B)
#define BITS_BF1_LIFETIME_8822B \
(BIT_MASK_BF1_LIFETIME_8822B << BIT_SHIFT_BF1_LIFETIME_8822B)
#define BIT_CLEAR_BF1_LIFETIME_8822B(x) ((x) & (~BITS_BF1_LIFETIME_8822B))
#define BIT_GET_BF1_LIFETIME_8822B(x) \
(((x) >> BIT_SHIFT_BF1_LIFETIME_8822B) & BIT_MASK_BF1_LIFETIME_8822B)
#define BIT_SET_BF1_LIFETIME_8822B(x, v) \
(BIT_CLEAR_BF1_LIFETIME_8822B(x) | BIT_BF1_LIFETIME_8822B(v))
/* 2 REG_BF_TIMEOUT_EN_8822B */
#define BIT_EN_VHT_LDPC_8822B BIT(9)
#define BIT_EN_HT_LDPC_8822B BIT(8)
#define BIT_BF1_TIMEOUT_EN_8822B BIT(1)
#define BIT_BF0_TIMEOUT_EN_8822B BIT(0)
/* 2 REG_MACID_RELEASE0_8822B */
#define BIT_SHIFT_MACID31_0_RELEASE_8822B 0
#define BIT_MASK_MACID31_0_RELEASE_8822B 0xffffffffL
#define BIT_MACID31_0_RELEASE_8822B(x) \
(((x) & BIT_MASK_MACID31_0_RELEASE_8822B) \
<< BIT_SHIFT_MACID31_0_RELEASE_8822B)
#define BITS_MACID31_0_RELEASE_8822B \
(BIT_MASK_MACID31_0_RELEASE_8822B << BIT_SHIFT_MACID31_0_RELEASE_8822B)
#define BIT_CLEAR_MACID31_0_RELEASE_8822B(x) \
((x) & (~BITS_MACID31_0_RELEASE_8822B))
#define BIT_GET_MACID31_0_RELEASE_8822B(x) \
(((x) >> BIT_SHIFT_MACID31_0_RELEASE_8822B) & \
BIT_MASK_MACID31_0_RELEASE_8822B)
#define BIT_SET_MACID31_0_RELEASE_8822B(x, v) \
(BIT_CLEAR_MACID31_0_RELEASE_8822B(x) | BIT_MACID31_0_RELEASE_8822B(v))
/* 2 REG_MACID_RELEASE1_8822B */
#define BIT_SHIFT_MACID63_32_RELEASE_8822B 0
#define BIT_MASK_MACID63_32_RELEASE_8822B 0xffffffffL
#define BIT_MACID63_32_RELEASE_8822B(x) \
(((x) & BIT_MASK_MACID63_32_RELEASE_8822B) \
<< BIT_SHIFT_MACID63_32_RELEASE_8822B)
#define BITS_MACID63_32_RELEASE_8822B \
(BIT_MASK_MACID63_32_RELEASE_8822B \
<< BIT_SHIFT_MACID63_32_RELEASE_8822B)
#define BIT_CLEAR_MACID63_32_RELEASE_8822B(x) \
((x) & (~BITS_MACID63_32_RELEASE_8822B))
#define BIT_GET_MACID63_32_RELEASE_8822B(x) \
(((x) >> BIT_SHIFT_MACID63_32_RELEASE_8822B) & \
BIT_MASK_MACID63_32_RELEASE_8822B)
#define BIT_SET_MACID63_32_RELEASE_8822B(x, v) \
(BIT_CLEAR_MACID63_32_RELEASE_8822B(x) | \
BIT_MACID63_32_RELEASE_8822B(v))
/* 2 REG_MACID_RELEASE2_8822B */
#define BIT_SHIFT_MACID95_64_RELEASE_8822B 0
#define BIT_MASK_MACID95_64_RELEASE_8822B 0xffffffffL
#define BIT_MACID95_64_RELEASE_8822B(x) \
(((x) & BIT_MASK_MACID95_64_RELEASE_8822B) \
<< BIT_SHIFT_MACID95_64_RELEASE_8822B)
#define BITS_MACID95_64_RELEASE_8822B \
(BIT_MASK_MACID95_64_RELEASE_8822B \
<< BIT_SHIFT_MACID95_64_RELEASE_8822B)
#define BIT_CLEAR_MACID95_64_RELEASE_8822B(x) \
((x) & (~BITS_MACID95_64_RELEASE_8822B))
#define BIT_GET_MACID95_64_RELEASE_8822B(x) \
(((x) >> BIT_SHIFT_MACID95_64_RELEASE_8822B) & \
BIT_MASK_MACID95_64_RELEASE_8822B)
#define BIT_SET_MACID95_64_RELEASE_8822B(x, v) \
(BIT_CLEAR_MACID95_64_RELEASE_8822B(x) | \
BIT_MACID95_64_RELEASE_8822B(v))
/* 2 REG_MACID_RELEASE3_8822B */
#define BIT_SHIFT_MACID127_96_RELEASE_8822B 0
#define BIT_MASK_MACID127_96_RELEASE_8822B 0xffffffffL
#define BIT_MACID127_96_RELEASE_8822B(x) \
(((x) & BIT_MASK_MACID127_96_RELEASE_8822B) \
<< BIT_SHIFT_MACID127_96_RELEASE_8822B)
#define BITS_MACID127_96_RELEASE_8822B \
(BIT_MASK_MACID127_96_RELEASE_8822B \
<< BIT_SHIFT_MACID127_96_RELEASE_8822B)
#define BIT_CLEAR_MACID127_96_RELEASE_8822B(x) \
((x) & (~BITS_MACID127_96_RELEASE_8822B))
#define BIT_GET_MACID127_96_RELEASE_8822B(x) \
(((x) >> BIT_SHIFT_MACID127_96_RELEASE_8822B) & \
BIT_MASK_MACID127_96_RELEASE_8822B)
#define BIT_SET_MACID127_96_RELEASE_8822B(x, v) \
(BIT_CLEAR_MACID127_96_RELEASE_8822B(x) | \
BIT_MACID127_96_RELEASE_8822B(v))
/* 2 REG_MACID_RELEASE_SETTING_8822B */
#define BIT_MACID_VALUE_8822B BIT(7)
#define BIT_SHIFT_MACID_OFFSET_8822B 0
#define BIT_MASK_MACID_OFFSET_8822B 0x7f
#define BIT_MACID_OFFSET_8822B(x) \
(((x) & BIT_MASK_MACID_OFFSET_8822B) << BIT_SHIFT_MACID_OFFSET_8822B)
#define BITS_MACID_OFFSET_8822B \
(BIT_MASK_MACID_OFFSET_8822B << BIT_SHIFT_MACID_OFFSET_8822B)
#define BIT_CLEAR_MACID_OFFSET_8822B(x) ((x) & (~BITS_MACID_OFFSET_8822B))
#define BIT_GET_MACID_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_MACID_OFFSET_8822B) & BIT_MASK_MACID_OFFSET_8822B)
#define BIT_SET_MACID_OFFSET_8822B(x, v) \
(BIT_CLEAR_MACID_OFFSET_8822B(x) | BIT_MACID_OFFSET_8822B(v))
/* 2 REG_FAST_EDCA_VOVI_SETTING_8822B */
#define BIT_SHIFT_VI_FAST_EDCA_TO_8822B 24
#define BIT_MASK_VI_FAST_EDCA_TO_8822B 0xff
#define BIT_VI_FAST_EDCA_TO_8822B(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_TO_8822B) \
<< BIT_SHIFT_VI_FAST_EDCA_TO_8822B)
#define BITS_VI_FAST_EDCA_TO_8822B \
(BIT_MASK_VI_FAST_EDCA_TO_8822B << BIT_SHIFT_VI_FAST_EDCA_TO_8822B)
#define BIT_CLEAR_VI_FAST_EDCA_TO_8822B(x) ((x) & (~BITS_VI_FAST_EDCA_TO_8822B))
#define BIT_GET_VI_FAST_EDCA_TO_8822B(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_TO_8822B) & \
BIT_MASK_VI_FAST_EDCA_TO_8822B)
#define BIT_SET_VI_FAST_EDCA_TO_8822B(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_TO_8822B(x) | BIT_VI_FAST_EDCA_TO_8822B(v))
#define BIT_VI_THRESHOLD_SEL_8822B BIT(23)
#define BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822B 16
#define BIT_MASK_VI_FAST_EDCA_PKT_TH_8822B 0x7f
#define BIT_VI_FAST_EDCA_PKT_TH_8822B(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_PKT_TH_8822B) \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822B)
#define BITS_VI_FAST_EDCA_PKT_TH_8822B \
(BIT_MASK_VI_FAST_EDCA_PKT_TH_8822B \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822B)
#define BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8822B(x) \
((x) & (~BITS_VI_FAST_EDCA_PKT_TH_8822B))
#define BIT_GET_VI_FAST_EDCA_PKT_TH_8822B(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822B) & \
BIT_MASK_VI_FAST_EDCA_PKT_TH_8822B)
#define BIT_SET_VI_FAST_EDCA_PKT_TH_8822B(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8822B(x) | \
BIT_VI_FAST_EDCA_PKT_TH_8822B(v))
#define BIT_SHIFT_VO_FAST_EDCA_TO_8822B 8
#define BIT_MASK_VO_FAST_EDCA_TO_8822B 0xff
#define BIT_VO_FAST_EDCA_TO_8822B(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO_8822B) \
<< BIT_SHIFT_VO_FAST_EDCA_TO_8822B)
#define BITS_VO_FAST_EDCA_TO_8822B \
(BIT_MASK_VO_FAST_EDCA_TO_8822B << BIT_SHIFT_VO_FAST_EDCA_TO_8822B)
#define BIT_CLEAR_VO_FAST_EDCA_TO_8822B(x) ((x) & (~BITS_VO_FAST_EDCA_TO_8822B))
#define BIT_GET_VO_FAST_EDCA_TO_8822B(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO_8822B) & \
BIT_MASK_VO_FAST_EDCA_TO_8822B)
#define BIT_SET_VO_FAST_EDCA_TO_8822B(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO_8822B(x) | BIT_VO_FAST_EDCA_TO_8822B(v))
#define BIT_VO_THRESHOLD_SEL_8822B BIT(7)
#define BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822B 0
#define BIT_MASK_VO_FAST_EDCA_PKT_TH_8822B 0x7f
#define BIT_VO_FAST_EDCA_PKT_TH_8822B(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_PKT_TH_8822B) \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822B)
#define BITS_VO_FAST_EDCA_PKT_TH_8822B \
(BIT_MASK_VO_FAST_EDCA_PKT_TH_8822B \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822B)
#define BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8822B(x) \
((x) & (~BITS_VO_FAST_EDCA_PKT_TH_8822B))
#define BIT_GET_VO_FAST_EDCA_PKT_TH_8822B(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822B) & \
BIT_MASK_VO_FAST_EDCA_PKT_TH_8822B)
#define BIT_SET_VO_FAST_EDCA_PKT_TH_8822B(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8822B(x) | \
BIT_VO_FAST_EDCA_PKT_TH_8822B(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING_8822B */
#define BIT_SHIFT_BK_FAST_EDCA_TO_8822B 24
#define BIT_MASK_BK_FAST_EDCA_TO_8822B 0xff
#define BIT_BK_FAST_EDCA_TO_8822B(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_TO_8822B) \
<< BIT_SHIFT_BK_FAST_EDCA_TO_8822B)
#define BITS_BK_FAST_EDCA_TO_8822B \
(BIT_MASK_BK_FAST_EDCA_TO_8822B << BIT_SHIFT_BK_FAST_EDCA_TO_8822B)
#define BIT_CLEAR_BK_FAST_EDCA_TO_8822B(x) ((x) & (~BITS_BK_FAST_EDCA_TO_8822B))
#define BIT_GET_BK_FAST_EDCA_TO_8822B(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_TO_8822B) & \
BIT_MASK_BK_FAST_EDCA_TO_8822B)
#define BIT_SET_BK_FAST_EDCA_TO_8822B(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_TO_8822B(x) | BIT_BK_FAST_EDCA_TO_8822B(v))
#define BIT_BK_THRESHOLD_SEL_8822B BIT(23)
#define BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822B 16
#define BIT_MASK_BK_FAST_EDCA_PKT_TH_8822B 0x7f
#define BIT_BK_FAST_EDCA_PKT_TH_8822B(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_PKT_TH_8822B) \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822B)
#define BITS_BK_FAST_EDCA_PKT_TH_8822B \
(BIT_MASK_BK_FAST_EDCA_PKT_TH_8822B \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822B)
#define BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8822B(x) \
((x) & (~BITS_BK_FAST_EDCA_PKT_TH_8822B))
#define BIT_GET_BK_FAST_EDCA_PKT_TH_8822B(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822B) & \
BIT_MASK_BK_FAST_EDCA_PKT_TH_8822B)
#define BIT_SET_BK_FAST_EDCA_PKT_TH_8822B(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8822B(x) | \
BIT_BK_FAST_EDCA_PKT_TH_8822B(v))
#define BIT_SHIFT_BE_FAST_EDCA_TO_8822B 8
#define BIT_MASK_BE_FAST_EDCA_TO_8822B 0xff
#define BIT_BE_FAST_EDCA_TO_8822B(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO_8822B) \
<< BIT_SHIFT_BE_FAST_EDCA_TO_8822B)
#define BITS_BE_FAST_EDCA_TO_8822B \
(BIT_MASK_BE_FAST_EDCA_TO_8822B << BIT_SHIFT_BE_FAST_EDCA_TO_8822B)
#define BIT_CLEAR_BE_FAST_EDCA_TO_8822B(x) ((x) & (~BITS_BE_FAST_EDCA_TO_8822B))
#define BIT_GET_BE_FAST_EDCA_TO_8822B(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO_8822B) & \
BIT_MASK_BE_FAST_EDCA_TO_8822B)
#define BIT_SET_BE_FAST_EDCA_TO_8822B(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO_8822B(x) | BIT_BE_FAST_EDCA_TO_8822B(v))
#define BIT_BE_THRESHOLD_SEL_8822B BIT(7)
#define BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822B 0
#define BIT_MASK_BE_FAST_EDCA_PKT_TH_8822B 0x7f
#define BIT_BE_FAST_EDCA_PKT_TH_8822B(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_PKT_TH_8822B) \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822B)
#define BITS_BE_FAST_EDCA_PKT_TH_8822B \
(BIT_MASK_BE_FAST_EDCA_PKT_TH_8822B \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822B)
#define BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8822B(x) \
((x) & (~BITS_BE_FAST_EDCA_PKT_TH_8822B))
#define BIT_GET_BE_FAST_EDCA_PKT_TH_8822B(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822B) & \
BIT_MASK_BE_FAST_EDCA_PKT_TH_8822B)
#define BIT_SET_BE_FAST_EDCA_PKT_TH_8822B(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8822B(x) | \
BIT_BE_FAST_EDCA_PKT_TH_8822B(v))
/* 2 REG_MACID_DROP0_8822B */
#define BIT_SHIFT_MACID31_0_DROP_8822B 0
#define BIT_MASK_MACID31_0_DROP_8822B 0xffffffffL
#define BIT_MACID31_0_DROP_8822B(x) \
(((x) & BIT_MASK_MACID31_0_DROP_8822B) \
<< BIT_SHIFT_MACID31_0_DROP_8822B)
#define BITS_MACID31_0_DROP_8822B \
(BIT_MASK_MACID31_0_DROP_8822B << BIT_SHIFT_MACID31_0_DROP_8822B)
#define BIT_CLEAR_MACID31_0_DROP_8822B(x) ((x) & (~BITS_MACID31_0_DROP_8822B))
#define BIT_GET_MACID31_0_DROP_8822B(x) \
(((x) >> BIT_SHIFT_MACID31_0_DROP_8822B) & \
BIT_MASK_MACID31_0_DROP_8822B)
#define BIT_SET_MACID31_0_DROP_8822B(x, v) \
(BIT_CLEAR_MACID31_0_DROP_8822B(x) | BIT_MACID31_0_DROP_8822B(v))
/* 2 REG_MACID_DROP1_8822B */
#define BIT_SHIFT_MACID63_32_DROP_8822B 0
#define BIT_MASK_MACID63_32_DROP_8822B 0xffffffffL
#define BIT_MACID63_32_DROP_8822B(x) \
(((x) & BIT_MASK_MACID63_32_DROP_8822B) \
<< BIT_SHIFT_MACID63_32_DROP_8822B)
#define BITS_MACID63_32_DROP_8822B \
(BIT_MASK_MACID63_32_DROP_8822B << BIT_SHIFT_MACID63_32_DROP_8822B)
#define BIT_CLEAR_MACID63_32_DROP_8822B(x) ((x) & (~BITS_MACID63_32_DROP_8822B))
#define BIT_GET_MACID63_32_DROP_8822B(x) \
(((x) >> BIT_SHIFT_MACID63_32_DROP_8822B) & \
BIT_MASK_MACID63_32_DROP_8822B)
#define BIT_SET_MACID63_32_DROP_8822B(x, v) \
(BIT_CLEAR_MACID63_32_DROP_8822B(x) | BIT_MACID63_32_DROP_8822B(v))
/* 2 REG_MACID_DROP2_8822B */
#define BIT_SHIFT_MACID95_64_DROP_8822B 0
#define BIT_MASK_MACID95_64_DROP_8822B 0xffffffffL
#define BIT_MACID95_64_DROP_8822B(x) \
(((x) & BIT_MASK_MACID95_64_DROP_8822B) \
<< BIT_SHIFT_MACID95_64_DROP_8822B)
#define BITS_MACID95_64_DROP_8822B \
(BIT_MASK_MACID95_64_DROP_8822B << BIT_SHIFT_MACID95_64_DROP_8822B)
#define BIT_CLEAR_MACID95_64_DROP_8822B(x) ((x) & (~BITS_MACID95_64_DROP_8822B))
#define BIT_GET_MACID95_64_DROP_8822B(x) \
(((x) >> BIT_SHIFT_MACID95_64_DROP_8822B) & \
BIT_MASK_MACID95_64_DROP_8822B)
#define BIT_SET_MACID95_64_DROP_8822B(x, v) \
(BIT_CLEAR_MACID95_64_DROP_8822B(x) | BIT_MACID95_64_DROP_8822B(v))
/* 2 REG_MACID_DROP3_8822B */
#define BIT_SHIFT_MACID127_96_DROP_8822B 0
#define BIT_MASK_MACID127_96_DROP_8822B 0xffffffffL
#define BIT_MACID127_96_DROP_8822B(x) \
(((x) & BIT_MASK_MACID127_96_DROP_8822B) \
<< BIT_SHIFT_MACID127_96_DROP_8822B)
#define BITS_MACID127_96_DROP_8822B \
(BIT_MASK_MACID127_96_DROP_8822B << BIT_SHIFT_MACID127_96_DROP_8822B)
#define BIT_CLEAR_MACID127_96_DROP_8822B(x) \
((x) & (~BITS_MACID127_96_DROP_8822B))
#define BIT_GET_MACID127_96_DROP_8822B(x) \
(((x) >> BIT_SHIFT_MACID127_96_DROP_8822B) & \
BIT_MASK_MACID127_96_DROP_8822B)
#define BIT_SET_MACID127_96_DROP_8822B(x, v) \
(BIT_CLEAR_MACID127_96_DROP_8822B(x) | BIT_MACID127_96_DROP_8822B(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_0_8822B */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822B 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822B 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_0_8822B(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822B) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822B)
#define BITS_R_MACID_RELEASE_SUCCESS_0_8822B \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822B \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822B)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8822B(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_0_8822B))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_0_8822B(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822B) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822B)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_0_8822B(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8822B(x) | \
BIT_R_MACID_RELEASE_SUCCESS_0_8822B(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_1_8822B */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822B 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822B 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_1_8822B(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822B) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822B)
#define BITS_R_MACID_RELEASE_SUCCESS_1_8822B \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822B \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822B)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8822B(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_1_8822B))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_1_8822B(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822B) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822B)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_1_8822B(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8822B(x) | \
BIT_R_MACID_RELEASE_SUCCESS_1_8822B(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_2_8822B */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822B 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822B 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_2_8822B(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822B) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822B)
#define BITS_R_MACID_RELEASE_SUCCESS_2_8822B \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822B \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822B)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8822B(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_2_8822B))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_2_8822B(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822B) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822B)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_2_8822B(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8822B(x) | \
BIT_R_MACID_RELEASE_SUCCESS_2_8822B(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_3_8822B */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822B 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822B 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_3_8822B(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822B) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822B)
#define BITS_R_MACID_RELEASE_SUCCESS_3_8822B \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822B \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822B)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8822B(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_3_8822B))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_3_8822B(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822B) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822B)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_3_8822B(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8822B(x) | \
BIT_R_MACID_RELEASE_SUCCESS_3_8822B(v))
/* 2 REG_MGG_FIFO_CRTL_8822B */
#define BIT_R_MGG_FIFO_EN_8822B BIT(31)
#define BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8822B 28
#define BIT_MASK_R_MGG_FIFO_PG_SIZE_8822B 0x7
#define BIT_R_MGG_FIFO_PG_SIZE_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_PG_SIZE_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8822B)
#define BITS_R_MGG_FIFO_PG_SIZE_8822B \
(BIT_MASK_R_MGG_FIFO_PG_SIZE_8822B \
<< BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8822B)
#define BIT_CLEAR_R_MGG_FIFO_PG_SIZE_8822B(x) \
((x) & (~BITS_R_MGG_FIFO_PG_SIZE_8822B))
#define BIT_GET_R_MGG_FIFO_PG_SIZE_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_PG_SIZE_8822B) & \
BIT_MASK_R_MGG_FIFO_PG_SIZE_8822B)
#define BIT_SET_R_MGG_FIFO_PG_SIZE_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_PG_SIZE_8822B(x) | \
BIT_R_MGG_FIFO_PG_SIZE_8822B(v))
#define BIT_SHIFT_R_MGG_FIFO_START_PG_8822B 16
#define BIT_MASK_R_MGG_FIFO_START_PG_8822B 0xfff
#define BIT_R_MGG_FIFO_START_PG_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_START_PG_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_START_PG_8822B)
#define BITS_R_MGG_FIFO_START_PG_8822B \
(BIT_MASK_R_MGG_FIFO_START_PG_8822B \
<< BIT_SHIFT_R_MGG_FIFO_START_PG_8822B)
#define BIT_CLEAR_R_MGG_FIFO_START_PG_8822B(x) \
((x) & (~BITS_R_MGG_FIFO_START_PG_8822B))
#define BIT_GET_R_MGG_FIFO_START_PG_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_START_PG_8822B) & \
BIT_MASK_R_MGG_FIFO_START_PG_8822B)
#define BIT_SET_R_MGG_FIFO_START_PG_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_START_PG_8822B(x) | \
BIT_R_MGG_FIFO_START_PG_8822B(v))
#define BIT_SHIFT_R_MGG_FIFO_SIZE_8822B 14
#define BIT_MASK_R_MGG_FIFO_SIZE_8822B 0x3
#define BIT_R_MGG_FIFO_SIZE_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_SIZE_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_SIZE_8822B)
#define BITS_R_MGG_FIFO_SIZE_8822B \
(BIT_MASK_R_MGG_FIFO_SIZE_8822B << BIT_SHIFT_R_MGG_FIFO_SIZE_8822B)
#define BIT_CLEAR_R_MGG_FIFO_SIZE_8822B(x) ((x) & (~BITS_R_MGG_FIFO_SIZE_8822B))
#define BIT_GET_R_MGG_FIFO_SIZE_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_SIZE_8822B) & \
BIT_MASK_R_MGG_FIFO_SIZE_8822B)
#define BIT_SET_R_MGG_FIFO_SIZE_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_SIZE_8822B(x) | BIT_R_MGG_FIFO_SIZE_8822B(v))
#define BIT_R_MGG_FIFO_PAUSE_8822B BIT(13)
#define BIT_SHIFT_R_MGG_FIFO_RPTR_8822B 8
#define BIT_MASK_R_MGG_FIFO_RPTR_8822B 0x1f
#define BIT_R_MGG_FIFO_RPTR_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_RPTR_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_RPTR_8822B)
#define BITS_R_MGG_FIFO_RPTR_8822B \
(BIT_MASK_R_MGG_FIFO_RPTR_8822B << BIT_SHIFT_R_MGG_FIFO_RPTR_8822B)
#define BIT_CLEAR_R_MGG_FIFO_RPTR_8822B(x) ((x) & (~BITS_R_MGG_FIFO_RPTR_8822B))
#define BIT_GET_R_MGG_FIFO_RPTR_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_RPTR_8822B) & \
BIT_MASK_R_MGG_FIFO_RPTR_8822B)
#define BIT_SET_R_MGG_FIFO_RPTR_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_RPTR_8822B(x) | BIT_R_MGG_FIFO_RPTR_8822B(v))
#define BIT_R_MGG_FIFO_OV_8822B BIT(7)
#define BIT_R_MGG_FIFO_WPTR_ERROR_8822B BIT(6)
#define BIT_R_EN_CPU_LIFETIME_8822B BIT(5)
#define BIT_SHIFT_R_MGG_FIFO_WPTR_8822B 0
#define BIT_MASK_R_MGG_FIFO_WPTR_8822B 0x1f
#define BIT_R_MGG_FIFO_WPTR_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_WPTR_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_WPTR_8822B)
#define BITS_R_MGG_FIFO_WPTR_8822B \
(BIT_MASK_R_MGG_FIFO_WPTR_8822B << BIT_SHIFT_R_MGG_FIFO_WPTR_8822B)
#define BIT_CLEAR_R_MGG_FIFO_WPTR_8822B(x) ((x) & (~BITS_R_MGG_FIFO_WPTR_8822B))
#define BIT_GET_R_MGG_FIFO_WPTR_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_WPTR_8822B) & \
BIT_MASK_R_MGG_FIFO_WPTR_8822B)
#define BIT_SET_R_MGG_FIFO_WPTR_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_WPTR_8822B(x) | BIT_R_MGG_FIFO_WPTR_8822B(v))
/* 2 REG_MGG_FIFO_INT_8822B */
#define BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8822B 16
#define BIT_MASK_R_MGG_FIFO_INT_FLAG_8822B 0xffff
#define BIT_R_MGG_FIFO_INT_FLAG_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_INT_FLAG_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8822B)
#define BITS_R_MGG_FIFO_INT_FLAG_8822B \
(BIT_MASK_R_MGG_FIFO_INT_FLAG_8822B \
<< BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8822B)
#define BIT_CLEAR_R_MGG_FIFO_INT_FLAG_8822B(x) \
((x) & (~BITS_R_MGG_FIFO_INT_FLAG_8822B))
#define BIT_GET_R_MGG_FIFO_INT_FLAG_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_INT_FLAG_8822B) & \
BIT_MASK_R_MGG_FIFO_INT_FLAG_8822B)
#define BIT_SET_R_MGG_FIFO_INT_FLAG_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_INT_FLAG_8822B(x) | \
BIT_R_MGG_FIFO_INT_FLAG_8822B(v))
#define BIT_SHIFT_R_MGG_FIFO_INT_MASK_8822B 0
#define BIT_MASK_R_MGG_FIFO_INT_MASK_8822B 0xffff
#define BIT_R_MGG_FIFO_INT_MASK_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_INT_MASK_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_INT_MASK_8822B)
#define BITS_R_MGG_FIFO_INT_MASK_8822B \
(BIT_MASK_R_MGG_FIFO_INT_MASK_8822B \
<< BIT_SHIFT_R_MGG_FIFO_INT_MASK_8822B)
#define BIT_CLEAR_R_MGG_FIFO_INT_MASK_8822B(x) \
((x) & (~BITS_R_MGG_FIFO_INT_MASK_8822B))
#define BIT_GET_R_MGG_FIFO_INT_MASK_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_INT_MASK_8822B) & \
BIT_MASK_R_MGG_FIFO_INT_MASK_8822B)
#define BIT_SET_R_MGG_FIFO_INT_MASK_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_INT_MASK_8822B(x) | \
BIT_R_MGG_FIFO_INT_MASK_8822B(v))
/* 2 REG_MGG_FIFO_LIFETIME_8822B */
#define BIT_SHIFT_R_MGG_FIFO_LIFETIME_8822B 16
#define BIT_MASK_R_MGG_FIFO_LIFETIME_8822B 0xffff
#define BIT_R_MGG_FIFO_LIFETIME_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_LIFETIME_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_LIFETIME_8822B)
#define BITS_R_MGG_FIFO_LIFETIME_8822B \
(BIT_MASK_R_MGG_FIFO_LIFETIME_8822B \
<< BIT_SHIFT_R_MGG_FIFO_LIFETIME_8822B)
#define BIT_CLEAR_R_MGG_FIFO_LIFETIME_8822B(x) \
((x) & (~BITS_R_MGG_FIFO_LIFETIME_8822B))
#define BIT_GET_R_MGG_FIFO_LIFETIME_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_LIFETIME_8822B) & \
BIT_MASK_R_MGG_FIFO_LIFETIME_8822B)
#define BIT_SET_R_MGG_FIFO_LIFETIME_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_LIFETIME_8822B(x) | \
BIT_R_MGG_FIFO_LIFETIME_8822B(v))
#define BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8822B 0
#define BIT_MASK_R_MGG_FIFO_VALID_MAP_8822B 0xffff
#define BIT_R_MGG_FIFO_VALID_MAP_8822B(x) \
(((x) & BIT_MASK_R_MGG_FIFO_VALID_MAP_8822B) \
<< BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8822B)
#define BITS_R_MGG_FIFO_VALID_MAP_8822B \
(BIT_MASK_R_MGG_FIFO_VALID_MAP_8822B \
<< BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8822B)
#define BIT_CLEAR_R_MGG_FIFO_VALID_MAP_8822B(x) \
((x) & (~BITS_R_MGG_FIFO_VALID_MAP_8822B))
#define BIT_GET_R_MGG_FIFO_VALID_MAP_8822B(x) \
(((x) >> BIT_SHIFT_R_MGG_FIFO_VALID_MAP_8822B) & \
BIT_MASK_R_MGG_FIFO_VALID_MAP_8822B)
#define BIT_SET_R_MGG_FIFO_VALID_MAP_8822B(x, v) \
(BIT_CLEAR_R_MGG_FIFO_VALID_MAP_8822B(x) | \
BIT_R_MGG_FIFO_VALID_MAP_8822B(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B 0x7f
#define BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B)
#define BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B(x) | \
BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B(v))
/* 2 REG_SHCUT_SETTING_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SHCUT_LLC_ETH_TYPE0_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SHCUT_LLC_ETH_TYPE1_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SHCUT_LLC_OUI0_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SHCUT_LLC_OUI1_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SHCUT_LLC_OUI2_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SHCUT_LLC_OUI3_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_MU_TX_CTL_8822B */
#define BIT_R_EN_REVERS_GTAB_8822B BIT(6)
#define BIT_SHIFT_R_MU_TABLE_VALID_8822B 0
#define BIT_MASK_R_MU_TABLE_VALID_8822B 0x3f
#define BIT_R_MU_TABLE_VALID_8822B(x) \
(((x) & BIT_MASK_R_MU_TABLE_VALID_8822B) \
<< BIT_SHIFT_R_MU_TABLE_VALID_8822B)
#define BITS_R_MU_TABLE_VALID_8822B \
(BIT_MASK_R_MU_TABLE_VALID_8822B << BIT_SHIFT_R_MU_TABLE_VALID_8822B)
#define BIT_CLEAR_R_MU_TABLE_VALID_8822B(x) \
((x) & (~BITS_R_MU_TABLE_VALID_8822B))
#define BIT_GET_R_MU_TABLE_VALID_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_TABLE_VALID_8822B) & \
BIT_MASK_R_MU_TABLE_VALID_8822B)
#define BIT_SET_R_MU_TABLE_VALID_8822B(x, v) \
(BIT_CLEAR_R_MU_TABLE_VALID_8822B(x) | BIT_R_MU_TABLE_VALID_8822B(v))
/* 2 REG_MU_STA_GID_VLD_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_VALID_8822B 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BITS_R_MU_STA_GTAB_VALID_8822B \
(BIT_MASK_R_MU_STA_GTAB_VALID_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_VALID_8822B))
#define BIT_GET_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B) & \
BIT_MASK_R_MU_STA_GTAB_VALID_8822B)
#define BIT_SET_R_MU_STA_GTAB_VALID_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) | \
BIT_R_MU_STA_GTAB_VALID_8822B(v))
#define BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_VALID_8822B 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BITS_R_MU_STA_GTAB_VALID_8822B \
(BIT_MASK_R_MU_STA_GTAB_VALID_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_VALID_8822B))
#define BIT_GET_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B) & \
BIT_MASK_R_MU_STA_GTAB_VALID_8822B)
#define BIT_SET_R_MU_STA_GTAB_VALID_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) | \
BIT_R_MU_STA_GTAB_VALID_8822B(v))
/* 2 REG_MU_STA_USER_POS_INFO_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_8822B 0xffffffffffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BITS_R_MU_STA_GTAB_POSITION_8822B \
(BIT_MASK_R_MU_STA_GTAB_POSITION_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_8822B))
#define BIT_GET_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_SET_R_MU_STA_GTAB_POSITION_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) | \
BIT_R_MU_STA_GTAB_POSITION_8822B(v))
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_8822B 0xffffffffffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BITS_R_MU_STA_GTAB_POSITION_8822B \
(BIT_MASK_R_MU_STA_GTAB_POSITION_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_8822B))
#define BIT_GET_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_SET_R_MU_STA_GTAB_POSITION_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) | \
BIT_R_MU_STA_GTAB_POSITION_8822B(v))
/* 2 REG_MU_TRX_DBG_CNT_8822B */
#define BIT_MU_DNGCNT_RST_8822B BIT(20)
#define BIT_SHIFT_MU_DBGCNT_SEL_8822B 16
#define BIT_MASK_MU_DBGCNT_SEL_8822B 0xf
#define BIT_MU_DBGCNT_SEL_8822B(x) \
(((x) & BIT_MASK_MU_DBGCNT_SEL_8822B) << BIT_SHIFT_MU_DBGCNT_SEL_8822B)
#define BITS_MU_DBGCNT_SEL_8822B \
(BIT_MASK_MU_DBGCNT_SEL_8822B << BIT_SHIFT_MU_DBGCNT_SEL_8822B)
#define BIT_CLEAR_MU_DBGCNT_SEL_8822B(x) ((x) & (~BITS_MU_DBGCNT_SEL_8822B))
#define BIT_GET_MU_DBGCNT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_MU_DBGCNT_SEL_8822B) & BIT_MASK_MU_DBGCNT_SEL_8822B)
#define BIT_SET_MU_DBGCNT_SEL_8822B(x, v) \
(BIT_CLEAR_MU_DBGCNT_SEL_8822B(x) | BIT_MU_DBGCNT_SEL_8822B(v))
#define BIT_SHIFT_MU_DNGCNT_8822B 0
#define BIT_MASK_MU_DNGCNT_8822B 0xffff
#define BIT_MU_DNGCNT_8822B(x) \
(((x) & BIT_MASK_MU_DNGCNT_8822B) << BIT_SHIFT_MU_DNGCNT_8822B)
#define BITS_MU_DNGCNT_8822B \
(BIT_MASK_MU_DNGCNT_8822B << BIT_SHIFT_MU_DNGCNT_8822B)
#define BIT_CLEAR_MU_DNGCNT_8822B(x) ((x) & (~BITS_MU_DNGCNT_8822B))
#define BIT_GET_MU_DNGCNT_8822B(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_8822B) & BIT_MASK_MU_DNGCNT_8822B)
#define BIT_SET_MU_DNGCNT_8822B(x, v) \
(BIT_CLEAR_MU_DNGCNT_8822B(x) | BIT_MU_DNGCNT_8822B(v))
/* 2 REG_MU_TX_CTL_8822B */
#define BIT_R_EN_REVERS_GTAB_8822B BIT(6)
#define BIT_SHIFT_R_MU_TABLE_VALID_8822B 0
#define BIT_MASK_R_MU_TABLE_VALID_8822B 0x3f
#define BIT_R_MU_TABLE_VALID_8822B(x) \
(((x) & BIT_MASK_R_MU_TABLE_VALID_8822B) \
<< BIT_SHIFT_R_MU_TABLE_VALID_8822B)
#define BITS_R_MU_TABLE_VALID_8822B \
(BIT_MASK_R_MU_TABLE_VALID_8822B << BIT_SHIFT_R_MU_TABLE_VALID_8822B)
#define BIT_CLEAR_R_MU_TABLE_VALID_8822B(x) \
((x) & (~BITS_R_MU_TABLE_VALID_8822B))
#define BIT_GET_R_MU_TABLE_VALID_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_TABLE_VALID_8822B) & \
BIT_MASK_R_MU_TABLE_VALID_8822B)
#define BIT_SET_R_MU_TABLE_VALID_8822B(x, v) \
(BIT_CLEAR_R_MU_TABLE_VALID_8822B(x) | BIT_R_MU_TABLE_VALID_8822B(v))
/* 2 REG_MU_STA_GID_VLD_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_VALID_8822B 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BITS_R_MU_STA_GTAB_VALID_8822B \
(BIT_MASK_R_MU_STA_GTAB_VALID_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_VALID_8822B))
#define BIT_GET_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B) & \
BIT_MASK_R_MU_STA_GTAB_VALID_8822B)
#define BIT_SET_R_MU_STA_GTAB_VALID_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) | \
BIT_R_MU_STA_GTAB_VALID_8822B(v))
#define BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_VALID_8822B 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BITS_R_MU_STA_GTAB_VALID_8822B \
(BIT_MASK_R_MU_STA_GTAB_VALID_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_VALID_8822B))
#define BIT_GET_R_MU_STA_GTAB_VALID_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID_8822B) & \
BIT_MASK_R_MU_STA_GTAB_VALID_8822B)
#define BIT_SET_R_MU_STA_GTAB_VALID_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID_8822B(x) | \
BIT_R_MU_STA_GTAB_VALID_8822B(v))
/* 2 REG_MU_STA_USER_POS_INFO_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_8822B 0xffffffffffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BITS_R_MU_STA_GTAB_POSITION_8822B \
(BIT_MASK_R_MU_STA_GTAB_POSITION_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_8822B))
#define BIT_GET_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_SET_R_MU_STA_GTAB_POSITION_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) | \
BIT_R_MU_STA_GTAB_POSITION_8822B(v))
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_8822B 0xffffffffffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_8822B) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BITS_R_MU_STA_GTAB_POSITION_8822B \
(BIT_MASK_R_MU_STA_GTAB_POSITION_8822B \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_8822B))
#define BIT_GET_R_MU_STA_GTAB_POSITION_8822B(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_8822B) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_8822B)
#define BIT_SET_R_MU_STA_GTAB_POSITION_8822B(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_8822B(x) | \
BIT_R_MU_STA_GTAB_POSITION_8822B(v))
/* 2 REG_MU_TRX_DBG_CNT_8822B */
#define BIT_MU_DNGCNT_RST_8822B BIT(20)
#define BIT_SHIFT_MU_DBGCNT_SEL_8822B 16
#define BIT_MASK_MU_DBGCNT_SEL_8822B 0xf
#define BIT_MU_DBGCNT_SEL_8822B(x) \
(((x) & BIT_MASK_MU_DBGCNT_SEL_8822B) << BIT_SHIFT_MU_DBGCNT_SEL_8822B)
#define BITS_MU_DBGCNT_SEL_8822B \
(BIT_MASK_MU_DBGCNT_SEL_8822B << BIT_SHIFT_MU_DBGCNT_SEL_8822B)
#define BIT_CLEAR_MU_DBGCNT_SEL_8822B(x) ((x) & (~BITS_MU_DBGCNT_SEL_8822B))
#define BIT_GET_MU_DBGCNT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_MU_DBGCNT_SEL_8822B) & BIT_MASK_MU_DBGCNT_SEL_8822B)
#define BIT_SET_MU_DBGCNT_SEL_8822B(x, v) \
(BIT_CLEAR_MU_DBGCNT_SEL_8822B(x) | BIT_MU_DBGCNT_SEL_8822B(v))
#define BIT_SHIFT_MU_DNGCNT_8822B 0
#define BIT_MASK_MU_DNGCNT_8822B 0xffff
#define BIT_MU_DNGCNT_8822B(x) \
(((x) & BIT_MASK_MU_DNGCNT_8822B) << BIT_SHIFT_MU_DNGCNT_8822B)
#define BITS_MU_DNGCNT_8822B \
(BIT_MASK_MU_DNGCNT_8822B << BIT_SHIFT_MU_DNGCNT_8822B)
#define BIT_CLEAR_MU_DNGCNT_8822B(x) ((x) & (~BITS_MU_DNGCNT_8822B))
#define BIT_GET_MU_DNGCNT_8822B(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_8822B) & BIT_MASK_MU_DNGCNT_8822B)
#define BIT_SET_MU_DNGCNT_8822B(x, v) \
(BIT_CLEAR_MU_DNGCNT_8822B(x) | BIT_MU_DNGCNT_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_EDCA_VO_PARAM_8822B */
#define BIT_SHIFT_TXOPLIMIT_8822B 16
#define BIT_MASK_TXOPLIMIT_8822B 0x7ff
#define BIT_TXOPLIMIT_8822B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822B) << BIT_SHIFT_TXOPLIMIT_8822B)
#define BITS_TXOPLIMIT_8822B \
(BIT_MASK_TXOPLIMIT_8822B << BIT_SHIFT_TXOPLIMIT_8822B)
#define BIT_CLEAR_TXOPLIMIT_8822B(x) ((x) & (~BITS_TXOPLIMIT_8822B))
#define BIT_GET_TXOPLIMIT_8822B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822B) & BIT_MASK_TXOPLIMIT_8822B)
#define BIT_SET_TXOPLIMIT_8822B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822B(x) | BIT_TXOPLIMIT_8822B(v))
#define BIT_SHIFT_CW_8822B 8
#define BIT_MASK_CW_8822B 0xff
#define BIT_CW_8822B(x) (((x) & BIT_MASK_CW_8822B) << BIT_SHIFT_CW_8822B)
#define BITS_CW_8822B (BIT_MASK_CW_8822B << BIT_SHIFT_CW_8822B)
#define BIT_CLEAR_CW_8822B(x) ((x) & (~BITS_CW_8822B))
#define BIT_GET_CW_8822B(x) (((x) >> BIT_SHIFT_CW_8822B) & BIT_MASK_CW_8822B)
#define BIT_SET_CW_8822B(x, v) (BIT_CLEAR_CW_8822B(x) | BIT_CW_8822B(v))
#define BIT_SHIFT_AIFS_8822B 0
#define BIT_MASK_AIFS_8822B 0xff
#define BIT_AIFS_8822B(x) (((x) & BIT_MASK_AIFS_8822B) << BIT_SHIFT_AIFS_8822B)
#define BITS_AIFS_8822B (BIT_MASK_AIFS_8822B << BIT_SHIFT_AIFS_8822B)
#define BIT_CLEAR_AIFS_8822B(x) ((x) & (~BITS_AIFS_8822B))
#define BIT_GET_AIFS_8822B(x) \
(((x) >> BIT_SHIFT_AIFS_8822B) & BIT_MASK_AIFS_8822B)
#define BIT_SET_AIFS_8822B(x, v) (BIT_CLEAR_AIFS_8822B(x) | BIT_AIFS_8822B(v))
/* 2 REG_EDCA_VI_PARAM_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_TXOPLIMIT_8822B 16
#define BIT_MASK_TXOPLIMIT_8822B 0x7ff
#define BIT_TXOPLIMIT_8822B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822B) << BIT_SHIFT_TXOPLIMIT_8822B)
#define BITS_TXOPLIMIT_8822B \
(BIT_MASK_TXOPLIMIT_8822B << BIT_SHIFT_TXOPLIMIT_8822B)
#define BIT_CLEAR_TXOPLIMIT_8822B(x) ((x) & (~BITS_TXOPLIMIT_8822B))
#define BIT_GET_TXOPLIMIT_8822B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822B) & BIT_MASK_TXOPLIMIT_8822B)
#define BIT_SET_TXOPLIMIT_8822B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822B(x) | BIT_TXOPLIMIT_8822B(v))
#define BIT_SHIFT_CW_8822B 8
#define BIT_MASK_CW_8822B 0xff
#define BIT_CW_8822B(x) (((x) & BIT_MASK_CW_8822B) << BIT_SHIFT_CW_8822B)
#define BITS_CW_8822B (BIT_MASK_CW_8822B << BIT_SHIFT_CW_8822B)
#define BIT_CLEAR_CW_8822B(x) ((x) & (~BITS_CW_8822B))
#define BIT_GET_CW_8822B(x) (((x) >> BIT_SHIFT_CW_8822B) & BIT_MASK_CW_8822B)
#define BIT_SET_CW_8822B(x, v) (BIT_CLEAR_CW_8822B(x) | BIT_CW_8822B(v))
#define BIT_SHIFT_AIFS_8822B 0
#define BIT_MASK_AIFS_8822B 0xff
#define BIT_AIFS_8822B(x) (((x) & BIT_MASK_AIFS_8822B) << BIT_SHIFT_AIFS_8822B)
#define BITS_AIFS_8822B (BIT_MASK_AIFS_8822B << BIT_SHIFT_AIFS_8822B)
#define BIT_CLEAR_AIFS_8822B(x) ((x) & (~BITS_AIFS_8822B))
#define BIT_GET_AIFS_8822B(x) \
(((x) >> BIT_SHIFT_AIFS_8822B) & BIT_MASK_AIFS_8822B)
#define BIT_SET_AIFS_8822B(x, v) (BIT_CLEAR_AIFS_8822B(x) | BIT_AIFS_8822B(v))
/* 2 REG_EDCA_BE_PARAM_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_TXOPLIMIT_8822B 16
#define BIT_MASK_TXOPLIMIT_8822B 0x7ff
#define BIT_TXOPLIMIT_8822B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822B) << BIT_SHIFT_TXOPLIMIT_8822B)
#define BITS_TXOPLIMIT_8822B \
(BIT_MASK_TXOPLIMIT_8822B << BIT_SHIFT_TXOPLIMIT_8822B)
#define BIT_CLEAR_TXOPLIMIT_8822B(x) ((x) & (~BITS_TXOPLIMIT_8822B))
#define BIT_GET_TXOPLIMIT_8822B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822B) & BIT_MASK_TXOPLIMIT_8822B)
#define BIT_SET_TXOPLIMIT_8822B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822B(x) | BIT_TXOPLIMIT_8822B(v))
#define BIT_SHIFT_CW_8822B 8
#define BIT_MASK_CW_8822B 0xff
#define BIT_CW_8822B(x) (((x) & BIT_MASK_CW_8822B) << BIT_SHIFT_CW_8822B)
#define BITS_CW_8822B (BIT_MASK_CW_8822B << BIT_SHIFT_CW_8822B)
#define BIT_CLEAR_CW_8822B(x) ((x) & (~BITS_CW_8822B))
#define BIT_GET_CW_8822B(x) (((x) >> BIT_SHIFT_CW_8822B) & BIT_MASK_CW_8822B)
#define BIT_SET_CW_8822B(x, v) (BIT_CLEAR_CW_8822B(x) | BIT_CW_8822B(v))
#define BIT_SHIFT_AIFS_8822B 0
#define BIT_MASK_AIFS_8822B 0xff
#define BIT_AIFS_8822B(x) (((x) & BIT_MASK_AIFS_8822B) << BIT_SHIFT_AIFS_8822B)
#define BITS_AIFS_8822B (BIT_MASK_AIFS_8822B << BIT_SHIFT_AIFS_8822B)
#define BIT_CLEAR_AIFS_8822B(x) ((x) & (~BITS_AIFS_8822B))
#define BIT_GET_AIFS_8822B(x) \
(((x) >> BIT_SHIFT_AIFS_8822B) & BIT_MASK_AIFS_8822B)
#define BIT_SET_AIFS_8822B(x, v) (BIT_CLEAR_AIFS_8822B(x) | BIT_AIFS_8822B(v))
/* 2 REG_EDCA_BK_PARAM_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_TXOPLIMIT_8822B 16
#define BIT_MASK_TXOPLIMIT_8822B 0x7ff
#define BIT_TXOPLIMIT_8822B(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822B) << BIT_SHIFT_TXOPLIMIT_8822B)
#define BITS_TXOPLIMIT_8822B \
(BIT_MASK_TXOPLIMIT_8822B << BIT_SHIFT_TXOPLIMIT_8822B)
#define BIT_CLEAR_TXOPLIMIT_8822B(x) ((x) & (~BITS_TXOPLIMIT_8822B))
#define BIT_GET_TXOPLIMIT_8822B(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822B) & BIT_MASK_TXOPLIMIT_8822B)
#define BIT_SET_TXOPLIMIT_8822B(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822B(x) | BIT_TXOPLIMIT_8822B(v))
#define BIT_SHIFT_CW_8822B 8
#define BIT_MASK_CW_8822B 0xff
#define BIT_CW_8822B(x) (((x) & BIT_MASK_CW_8822B) << BIT_SHIFT_CW_8822B)
#define BITS_CW_8822B (BIT_MASK_CW_8822B << BIT_SHIFT_CW_8822B)
#define BIT_CLEAR_CW_8822B(x) ((x) & (~BITS_CW_8822B))
#define BIT_GET_CW_8822B(x) (((x) >> BIT_SHIFT_CW_8822B) & BIT_MASK_CW_8822B)
#define BIT_SET_CW_8822B(x, v) (BIT_CLEAR_CW_8822B(x) | BIT_CW_8822B(v))
#define BIT_SHIFT_AIFS_8822B 0
#define BIT_MASK_AIFS_8822B 0xff
#define BIT_AIFS_8822B(x) (((x) & BIT_MASK_AIFS_8822B) << BIT_SHIFT_AIFS_8822B)
#define BITS_AIFS_8822B (BIT_MASK_AIFS_8822B << BIT_SHIFT_AIFS_8822B)
#define BIT_CLEAR_AIFS_8822B(x) ((x) & (~BITS_AIFS_8822B))
#define BIT_GET_AIFS_8822B(x) \
(((x) >> BIT_SHIFT_AIFS_8822B) & BIT_MASK_AIFS_8822B)
#define BIT_SET_AIFS_8822B(x, v) (BIT_CLEAR_AIFS_8822B(x) | BIT_AIFS_8822B(v))
/* 2 REG_BCNTCFG_8822B */
#define BIT_SHIFT_BCNCW_MAX_8822B 12
#define BIT_MASK_BCNCW_MAX_8822B 0xf
#define BIT_BCNCW_MAX_8822B(x) \
(((x) & BIT_MASK_BCNCW_MAX_8822B) << BIT_SHIFT_BCNCW_MAX_8822B)
#define BITS_BCNCW_MAX_8822B \
(BIT_MASK_BCNCW_MAX_8822B << BIT_SHIFT_BCNCW_MAX_8822B)
#define BIT_CLEAR_BCNCW_MAX_8822B(x) ((x) & (~BITS_BCNCW_MAX_8822B))
#define BIT_GET_BCNCW_MAX_8822B(x) \
(((x) >> BIT_SHIFT_BCNCW_MAX_8822B) & BIT_MASK_BCNCW_MAX_8822B)
#define BIT_SET_BCNCW_MAX_8822B(x, v) \
(BIT_CLEAR_BCNCW_MAX_8822B(x) | BIT_BCNCW_MAX_8822B(v))
#define BIT_SHIFT_BCNCW_MIN_8822B 8
#define BIT_MASK_BCNCW_MIN_8822B 0xf
#define BIT_BCNCW_MIN_8822B(x) \
(((x) & BIT_MASK_BCNCW_MIN_8822B) << BIT_SHIFT_BCNCW_MIN_8822B)
#define BITS_BCNCW_MIN_8822B \
(BIT_MASK_BCNCW_MIN_8822B << BIT_SHIFT_BCNCW_MIN_8822B)
#define BIT_CLEAR_BCNCW_MIN_8822B(x) ((x) & (~BITS_BCNCW_MIN_8822B))
#define BIT_GET_BCNCW_MIN_8822B(x) \
(((x) >> BIT_SHIFT_BCNCW_MIN_8822B) & BIT_MASK_BCNCW_MIN_8822B)
#define BIT_SET_BCNCW_MIN_8822B(x, v) \
(BIT_CLEAR_BCNCW_MIN_8822B(x) | BIT_BCNCW_MIN_8822B(v))
#define BIT_SHIFT_BCNIFS_8822B 0
#define BIT_MASK_BCNIFS_8822B 0xff
#define BIT_BCNIFS_8822B(x) \
(((x) & BIT_MASK_BCNIFS_8822B) << BIT_SHIFT_BCNIFS_8822B)
#define BITS_BCNIFS_8822B (BIT_MASK_BCNIFS_8822B << BIT_SHIFT_BCNIFS_8822B)
#define BIT_CLEAR_BCNIFS_8822B(x) ((x) & (~BITS_BCNIFS_8822B))
#define BIT_GET_BCNIFS_8822B(x) \
(((x) >> BIT_SHIFT_BCNIFS_8822B) & BIT_MASK_BCNIFS_8822B)
#define BIT_SET_BCNIFS_8822B(x, v) \
(BIT_CLEAR_BCNIFS_8822B(x) | BIT_BCNIFS_8822B(v))
/* 2 REG_PIFS_8822B */
#define BIT_SHIFT_PIFS_8822B 0
#define BIT_MASK_PIFS_8822B 0xff
#define BIT_PIFS_8822B(x) (((x) & BIT_MASK_PIFS_8822B) << BIT_SHIFT_PIFS_8822B)
#define BITS_PIFS_8822B (BIT_MASK_PIFS_8822B << BIT_SHIFT_PIFS_8822B)
#define BIT_CLEAR_PIFS_8822B(x) ((x) & (~BITS_PIFS_8822B))
#define BIT_GET_PIFS_8822B(x) \
(((x) >> BIT_SHIFT_PIFS_8822B) & BIT_MASK_PIFS_8822B)
#define BIT_SET_PIFS_8822B(x, v) (BIT_CLEAR_PIFS_8822B(x) | BIT_PIFS_8822B(v))
/* 2 REG_RDG_PIFS_8822B */
#define BIT_SHIFT_RDG_PIFS_8822B 0
#define BIT_MASK_RDG_PIFS_8822B 0xff
#define BIT_RDG_PIFS_8822B(x) \
(((x) & BIT_MASK_RDG_PIFS_8822B) << BIT_SHIFT_RDG_PIFS_8822B)
#define BITS_RDG_PIFS_8822B \
(BIT_MASK_RDG_PIFS_8822B << BIT_SHIFT_RDG_PIFS_8822B)
#define BIT_CLEAR_RDG_PIFS_8822B(x) ((x) & (~BITS_RDG_PIFS_8822B))
#define BIT_GET_RDG_PIFS_8822B(x) \
(((x) >> BIT_SHIFT_RDG_PIFS_8822B) & BIT_MASK_RDG_PIFS_8822B)
#define BIT_SET_RDG_PIFS_8822B(x, v) \
(BIT_CLEAR_RDG_PIFS_8822B(x) | BIT_RDG_PIFS_8822B(v))
/* 2 REG_SIFS_8822B */
#define BIT_SHIFT_SIFS_OFDM_TRX_8822B 24
#define BIT_MASK_SIFS_OFDM_TRX_8822B 0xff
#define BIT_SIFS_OFDM_TRX_8822B(x) \
(((x) & BIT_MASK_SIFS_OFDM_TRX_8822B) << BIT_SHIFT_SIFS_OFDM_TRX_8822B)
#define BITS_SIFS_OFDM_TRX_8822B \
(BIT_MASK_SIFS_OFDM_TRX_8822B << BIT_SHIFT_SIFS_OFDM_TRX_8822B)
#define BIT_CLEAR_SIFS_OFDM_TRX_8822B(x) ((x) & (~BITS_SIFS_OFDM_TRX_8822B))
#define BIT_GET_SIFS_OFDM_TRX_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_TRX_8822B) & BIT_MASK_SIFS_OFDM_TRX_8822B)
#define BIT_SET_SIFS_OFDM_TRX_8822B(x, v) \
(BIT_CLEAR_SIFS_OFDM_TRX_8822B(x) | BIT_SIFS_OFDM_TRX_8822B(v))
#define BIT_SHIFT_SIFS_CCK_TRX_8822B 16
#define BIT_MASK_SIFS_CCK_TRX_8822B 0xff
#define BIT_SIFS_CCK_TRX_8822B(x) \
(((x) & BIT_MASK_SIFS_CCK_TRX_8822B) << BIT_SHIFT_SIFS_CCK_TRX_8822B)
#define BITS_SIFS_CCK_TRX_8822B \
(BIT_MASK_SIFS_CCK_TRX_8822B << BIT_SHIFT_SIFS_CCK_TRX_8822B)
#define BIT_CLEAR_SIFS_CCK_TRX_8822B(x) ((x) & (~BITS_SIFS_CCK_TRX_8822B))
#define BIT_GET_SIFS_CCK_TRX_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_TRX_8822B) & BIT_MASK_SIFS_CCK_TRX_8822B)
#define BIT_SET_SIFS_CCK_TRX_8822B(x, v) \
(BIT_CLEAR_SIFS_CCK_TRX_8822B(x) | BIT_SIFS_CCK_TRX_8822B(v))
#define BIT_SHIFT_SIFS_OFDM_CTX_8822B 8
#define BIT_MASK_SIFS_OFDM_CTX_8822B 0xff
#define BIT_SIFS_OFDM_CTX_8822B(x) \
(((x) & BIT_MASK_SIFS_OFDM_CTX_8822B) << BIT_SHIFT_SIFS_OFDM_CTX_8822B)
#define BITS_SIFS_OFDM_CTX_8822B \
(BIT_MASK_SIFS_OFDM_CTX_8822B << BIT_SHIFT_SIFS_OFDM_CTX_8822B)
#define BIT_CLEAR_SIFS_OFDM_CTX_8822B(x) ((x) & (~BITS_SIFS_OFDM_CTX_8822B))
#define BIT_GET_SIFS_OFDM_CTX_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_CTX_8822B) & BIT_MASK_SIFS_OFDM_CTX_8822B)
#define BIT_SET_SIFS_OFDM_CTX_8822B(x, v) \
(BIT_CLEAR_SIFS_OFDM_CTX_8822B(x) | BIT_SIFS_OFDM_CTX_8822B(v))
#define BIT_SHIFT_SIFS_CCK_CTX_8822B 0
#define BIT_MASK_SIFS_CCK_CTX_8822B 0xff
#define BIT_SIFS_CCK_CTX_8822B(x) \
(((x) & BIT_MASK_SIFS_CCK_CTX_8822B) << BIT_SHIFT_SIFS_CCK_CTX_8822B)
#define BITS_SIFS_CCK_CTX_8822B \
(BIT_MASK_SIFS_CCK_CTX_8822B << BIT_SHIFT_SIFS_CCK_CTX_8822B)
#define BIT_CLEAR_SIFS_CCK_CTX_8822B(x) ((x) & (~BITS_SIFS_CCK_CTX_8822B))
#define BIT_GET_SIFS_CCK_CTX_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_CTX_8822B) & BIT_MASK_SIFS_CCK_CTX_8822B)
#define BIT_SET_SIFS_CCK_CTX_8822B(x, v) \
(BIT_CLEAR_SIFS_CCK_CTX_8822B(x) | BIT_SIFS_CCK_CTX_8822B(v))
/* 2 REG_TSFTR_SYN_OFFSET_8822B */
#define BIT_SHIFT_TSFTR_SNC_OFFSET_8822B 0
#define BIT_MASK_TSFTR_SNC_OFFSET_8822B 0xffff
#define BIT_TSFTR_SNC_OFFSET_8822B(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET_8822B) \
<< BIT_SHIFT_TSFTR_SNC_OFFSET_8822B)
#define BITS_TSFTR_SNC_OFFSET_8822B \
(BIT_MASK_TSFTR_SNC_OFFSET_8822B << BIT_SHIFT_TSFTR_SNC_OFFSET_8822B)
#define BIT_CLEAR_TSFTR_SNC_OFFSET_8822B(x) \
((x) & (~BITS_TSFTR_SNC_OFFSET_8822B))
#define BIT_GET_TSFTR_SNC_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET_8822B) & \
BIT_MASK_TSFTR_SNC_OFFSET_8822B)
#define BIT_SET_TSFTR_SNC_OFFSET_8822B(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET_8822B(x) | BIT_TSFTR_SNC_OFFSET_8822B(v))
/* 2 REG_AGGR_BREAK_TIME_8822B */
#define BIT_SHIFT_AGGR_BK_TIME_8822B 0
#define BIT_MASK_AGGR_BK_TIME_8822B 0xff
#define BIT_AGGR_BK_TIME_8822B(x) \
(((x) & BIT_MASK_AGGR_BK_TIME_8822B) << BIT_SHIFT_AGGR_BK_TIME_8822B)
#define BITS_AGGR_BK_TIME_8822B \
(BIT_MASK_AGGR_BK_TIME_8822B << BIT_SHIFT_AGGR_BK_TIME_8822B)
#define BIT_CLEAR_AGGR_BK_TIME_8822B(x) ((x) & (~BITS_AGGR_BK_TIME_8822B))
#define BIT_GET_AGGR_BK_TIME_8822B(x) \
(((x) >> BIT_SHIFT_AGGR_BK_TIME_8822B) & BIT_MASK_AGGR_BK_TIME_8822B)
#define BIT_SET_AGGR_BK_TIME_8822B(x, v) \
(BIT_CLEAR_AGGR_BK_TIME_8822B(x) | BIT_AGGR_BK_TIME_8822B(v))
/* 2 REG_SLOT_8822B */
#define BIT_SHIFT_SLOT_8822B 0
#define BIT_MASK_SLOT_8822B 0xff
#define BIT_SLOT_8822B(x) (((x) & BIT_MASK_SLOT_8822B) << BIT_SHIFT_SLOT_8822B)
#define BITS_SLOT_8822B (BIT_MASK_SLOT_8822B << BIT_SHIFT_SLOT_8822B)
#define BIT_CLEAR_SLOT_8822B(x) ((x) & (~BITS_SLOT_8822B))
#define BIT_GET_SLOT_8822B(x) \
(((x) >> BIT_SHIFT_SLOT_8822B) & BIT_MASK_SLOT_8822B)
#define BIT_SET_SLOT_8822B(x, v) (BIT_CLEAR_SLOT_8822B(x) | BIT_SLOT_8822B(v))
/* 2 REG_TX_PTCL_CTRL_8822B */
#define BIT_DIS_EDCCA_8822B BIT(15)
#define BIT_DIS_CCA_8822B BIT(14)
#define BIT_LSIG_TXOP_TXCMD_NAV_8822B BIT(13)
#define BIT_SIFS_BK_EN_8822B BIT(12)
#define BIT_SHIFT_TXQ_NAV_MSK_8822B 8
#define BIT_MASK_TXQ_NAV_MSK_8822B 0xf
#define BIT_TXQ_NAV_MSK_8822B(x) \
(((x) & BIT_MASK_TXQ_NAV_MSK_8822B) << BIT_SHIFT_TXQ_NAV_MSK_8822B)
#define BITS_TXQ_NAV_MSK_8822B \
(BIT_MASK_TXQ_NAV_MSK_8822B << BIT_SHIFT_TXQ_NAV_MSK_8822B)
#define BIT_CLEAR_TXQ_NAV_MSK_8822B(x) ((x) & (~BITS_TXQ_NAV_MSK_8822B))
#define BIT_GET_TXQ_NAV_MSK_8822B(x) \
(((x) >> BIT_SHIFT_TXQ_NAV_MSK_8822B) & BIT_MASK_TXQ_NAV_MSK_8822B)
#define BIT_SET_TXQ_NAV_MSK_8822B(x, v) \
(BIT_CLEAR_TXQ_NAV_MSK_8822B(x) | BIT_TXQ_NAV_MSK_8822B(v))
#define BIT_DIS_CW_8822B BIT(7)
#define BIT_NAV_END_TXOP_8822B BIT(6)
#define BIT_RDG_END_TXOP_8822B BIT(5)
#define BIT_AC_INBCN_HOLD_8822B BIT(4)
#define BIT_MGTQ_TXOP_EN_8822B BIT(3)
#define BIT_MGTQ_RTSMF_EN_8822B BIT(2)
#define BIT_HIQ_RTSMF_EN_8822B BIT(1)
#define BIT_BCN_RTSMF_EN_8822B BIT(0)
/* 2 REG_TXPAUSE_8822B */
#define BIT_STOP_BCN_HI_MGT_8822B BIT(7)
#define BIT_MAC_STOPBCNQ_8822B BIT(6)
#define BIT_MAC_STOPHIQ_8822B BIT(5)
#define BIT_MAC_STOPMGQ_8822B BIT(4)
#define BIT_MAC_STOPBK_8822B BIT(3)
#define BIT_MAC_STOPBE_8822B BIT(2)
#define BIT_MAC_STOPVI_8822B BIT(1)
#define BIT_MAC_STOPVO_8822B BIT(0)
/* 2 REG_DIS_TXREQ_CLR_8822B */
#define BIT_DIS_BT_CCA_8822B BIT(7)
#define BIT_DIS_TXREQ_CLR_HI_8822B BIT(5)
#define BIT_DIS_TXREQ_CLR_MGQ_8822B BIT(4)
#define BIT_DIS_TXREQ_CLR_VO_8822B BIT(3)
#define BIT_DIS_TXREQ_CLR_VI_8822B BIT(2)
#define BIT_DIS_TXREQ_CLR_BE_8822B BIT(1)
#define BIT_DIS_TXREQ_CLR_BK_8822B BIT(0)
/* 2 REG_RD_CTRL_8822B */
#define BIT_EN_CLR_TXREQ_INCCA_8822B BIT(15)
#define BIT_DIS_TX_OVER_BCNQ_8822B BIT(14)
#define BIT_EN_BCNERR_INCCCA_8822B BIT(13)
#define BIT_EDCCA_MSK_CNTDOWN_EN_8822B BIT(11)
#define BIT_DIS_TXOP_CFE_8822B BIT(10)
#define BIT_DIS_LSIG_CFE_8822B BIT(9)
#define BIT_DIS_STBC_CFE_8822B BIT(8)
#define BIT_BKQ_RD_INIT_EN_8822B BIT(7)
#define BIT_BEQ_RD_INIT_EN_8822B BIT(6)
#define BIT_VIQ_RD_INIT_EN_8822B BIT(5)
#define BIT_VOQ_RD_INIT_EN_8822B BIT(4)
#define BIT_BKQ_RD_RESP_EN_8822B BIT(3)
#define BIT_BEQ_RD_RESP_EN_8822B BIT(2)
#define BIT_VIQ_RD_RESP_EN_8822B BIT(1)
#define BIT_VOQ_RD_RESP_EN_8822B BIT(0)
/* 2 REG_MBSSID_CTRL_8822B */
#define BIT_MBID_BCNQ7_EN_8822B BIT(7)
#define BIT_MBID_BCNQ6_EN_8822B BIT(6)
#define BIT_MBID_BCNQ5_EN_8822B BIT(5)
#define BIT_MBID_BCNQ4_EN_8822B BIT(4)
#define BIT_MBID_BCNQ3_EN_8822B BIT(3)
#define BIT_MBID_BCNQ2_EN_8822B BIT(2)
#define BIT_MBID_BCNQ1_EN_8822B BIT(1)
#define BIT_MBID_BCNQ0_EN_8822B BIT(0)
/* 2 REG_P2PPS_CTRL_8822B */
#define BIT_P2P_CTW_ALLSTASLEEP_8822B BIT(7)
#define BIT_P2P_OFF_DISTX_EN_8822B BIT(6)
#define BIT_PWR_MGT_EN_8822B BIT(5)
#define BIT_P2P_NOA1_EN_8822B BIT(2)
#define BIT_P2P_NOA0_EN_8822B BIT(1)
/* 2 REG_PKT_LIFETIME_CTRL_8822B */
#define BIT_EN_P2P_CTWND1_8822B BIT(23)
#define BIT_EN_BKF_CLR_TXREQ_8822B BIT(22)
#define BIT_EN_TSFBIT32_RST_P2P_8822B BIT(21)
#define BIT_EN_BCN_TX_BTCCA_8822B BIT(20)
#define BIT_DIS_PKT_TX_ATIM_8822B BIT(19)
#define BIT_DIS_BCN_DIS_CTN_8822B BIT(18)
#define BIT_EN_NAVEND_RST_TXOP_8822B BIT(17)
#define BIT_EN_FILTER_CCA_8822B BIT(16)
#define BIT_SHIFT_CCA_FILTER_THRS_8822B 8
#define BIT_MASK_CCA_FILTER_THRS_8822B 0xff
#define BIT_CCA_FILTER_THRS_8822B(x) \
(((x) & BIT_MASK_CCA_FILTER_THRS_8822B) \
<< BIT_SHIFT_CCA_FILTER_THRS_8822B)
#define BITS_CCA_FILTER_THRS_8822B \
(BIT_MASK_CCA_FILTER_THRS_8822B << BIT_SHIFT_CCA_FILTER_THRS_8822B)
#define BIT_CLEAR_CCA_FILTER_THRS_8822B(x) ((x) & (~BITS_CCA_FILTER_THRS_8822B))
#define BIT_GET_CCA_FILTER_THRS_8822B(x) \
(((x) >> BIT_SHIFT_CCA_FILTER_THRS_8822B) & \
BIT_MASK_CCA_FILTER_THRS_8822B)
#define BIT_SET_CCA_FILTER_THRS_8822B(x, v) \
(BIT_CLEAR_CCA_FILTER_THRS_8822B(x) | BIT_CCA_FILTER_THRS_8822B(v))
#define BIT_SHIFT_EDCCA_THRS_8822B 0
#define BIT_MASK_EDCCA_THRS_8822B 0xff
#define BIT_EDCCA_THRS_8822B(x) \
(((x) & BIT_MASK_EDCCA_THRS_8822B) << BIT_SHIFT_EDCCA_THRS_8822B)
#define BITS_EDCCA_THRS_8822B \
(BIT_MASK_EDCCA_THRS_8822B << BIT_SHIFT_EDCCA_THRS_8822B)
#define BIT_CLEAR_EDCCA_THRS_8822B(x) ((x) & (~BITS_EDCCA_THRS_8822B))
#define BIT_GET_EDCCA_THRS_8822B(x) \
(((x) >> BIT_SHIFT_EDCCA_THRS_8822B) & BIT_MASK_EDCCA_THRS_8822B)
#define BIT_SET_EDCCA_THRS_8822B(x, v) \
(BIT_CLEAR_EDCCA_THRS_8822B(x) | BIT_EDCCA_THRS_8822B(v))
/* 2 REG_P2PPS_SPEC_STATE_8822B */
#define BIT_SPEC_POWER_STATE_8822B BIT(7)
#define BIT_SPEC_CTWINDOW_ON_8822B BIT(6)
#define BIT_SPEC_BEACON_AREA_ON_8822B BIT(5)
#define BIT_SPEC_CTWIN_EARLY_DISTX_8822B BIT(4)
#define BIT_SPEC_NOA1_OFF_PERIOD_8822B BIT(3)
#define BIT_SPEC_FORCE_DOZE1_8822B BIT(2)
#define BIT_SPEC_NOA0_OFF_PERIOD_8822B BIT(1)
#define BIT_SPEC_FORCE_DOZE0_8822B BIT(0)
/* 2 REG_TXOP_LIMIT_CTRL_8822B */
#define BIT_SHIFT_TXOP_TBTT_CNT_8822B 24
#define BIT_MASK_TXOP_TBTT_CNT_8822B 0xff
#define BIT_TXOP_TBTT_CNT_8822B(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_8822B) << BIT_SHIFT_TXOP_TBTT_CNT_8822B)
#define BITS_TXOP_TBTT_CNT_8822B \
(BIT_MASK_TXOP_TBTT_CNT_8822B << BIT_SHIFT_TXOP_TBTT_CNT_8822B)
#define BIT_CLEAR_TXOP_TBTT_CNT_8822B(x) ((x) & (~BITS_TXOP_TBTT_CNT_8822B))
#define BIT_GET_TXOP_TBTT_CNT_8822B(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_8822B) & BIT_MASK_TXOP_TBTT_CNT_8822B)
#define BIT_SET_TXOP_TBTT_CNT_8822B(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_8822B(x) | BIT_TXOP_TBTT_CNT_8822B(v))
#define BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822B 20
#define BIT_MASK_TXOP_TBTT_CNT_SEL_8822B 0xf
#define BIT_TXOP_TBTT_CNT_SEL_8822B(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_SEL_8822B) \
<< BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822B)
#define BITS_TXOP_TBTT_CNT_SEL_8822B \
(BIT_MASK_TXOP_TBTT_CNT_SEL_8822B << BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822B)
#define BIT_CLEAR_TXOP_TBTT_CNT_SEL_8822B(x) \
((x) & (~BITS_TXOP_TBTT_CNT_SEL_8822B))
#define BIT_GET_TXOP_TBTT_CNT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822B) & \
BIT_MASK_TXOP_TBTT_CNT_SEL_8822B)
#define BIT_SET_TXOP_TBTT_CNT_SEL_8822B(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_SEL_8822B(x) | BIT_TXOP_TBTT_CNT_SEL_8822B(v))
#define BIT_SHIFT_TXOP_LMT_EN_8822B 16
#define BIT_MASK_TXOP_LMT_EN_8822B 0xf
#define BIT_TXOP_LMT_EN_8822B(x) \
(((x) & BIT_MASK_TXOP_LMT_EN_8822B) << BIT_SHIFT_TXOP_LMT_EN_8822B)
#define BITS_TXOP_LMT_EN_8822B \
(BIT_MASK_TXOP_LMT_EN_8822B << BIT_SHIFT_TXOP_LMT_EN_8822B)
#define BIT_CLEAR_TXOP_LMT_EN_8822B(x) ((x) & (~BITS_TXOP_LMT_EN_8822B))
#define BIT_GET_TXOP_LMT_EN_8822B(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_EN_8822B) & BIT_MASK_TXOP_LMT_EN_8822B)
#define BIT_SET_TXOP_LMT_EN_8822B(x, v) \
(BIT_CLEAR_TXOP_LMT_EN_8822B(x) | BIT_TXOP_LMT_EN_8822B(v))
#define BIT_SHIFT_TXOP_LMT_TX_TIME_8822B 8
#define BIT_MASK_TXOP_LMT_TX_TIME_8822B 0xff
#define BIT_TXOP_LMT_TX_TIME_8822B(x) \
(((x) & BIT_MASK_TXOP_LMT_TX_TIME_8822B) \
<< BIT_SHIFT_TXOP_LMT_TX_TIME_8822B)
#define BITS_TXOP_LMT_TX_TIME_8822B \
(BIT_MASK_TXOP_LMT_TX_TIME_8822B << BIT_SHIFT_TXOP_LMT_TX_TIME_8822B)
#define BIT_CLEAR_TXOP_LMT_TX_TIME_8822B(x) \
((x) & (~BITS_TXOP_LMT_TX_TIME_8822B))
#define BIT_GET_TXOP_LMT_TX_TIME_8822B(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_TX_TIME_8822B) & \
BIT_MASK_TXOP_LMT_TX_TIME_8822B)
#define BIT_SET_TXOP_LMT_TX_TIME_8822B(x, v) \
(BIT_CLEAR_TXOP_LMT_TX_TIME_8822B(x) | BIT_TXOP_LMT_TX_TIME_8822B(v))
#define BIT_TXOP_CNT_TRIGGER_RESET_8822B BIT(7)
#define BIT_SHIFT_TXOP_LMT_PKT_NUM_8822B 0
#define BIT_MASK_TXOP_LMT_PKT_NUM_8822B 0x3f
#define BIT_TXOP_LMT_PKT_NUM_8822B(x) \
(((x) & BIT_MASK_TXOP_LMT_PKT_NUM_8822B) \
<< BIT_SHIFT_TXOP_LMT_PKT_NUM_8822B)
#define BITS_TXOP_LMT_PKT_NUM_8822B \
(BIT_MASK_TXOP_LMT_PKT_NUM_8822B << BIT_SHIFT_TXOP_LMT_PKT_NUM_8822B)
#define BIT_CLEAR_TXOP_LMT_PKT_NUM_8822B(x) \
((x) & (~BITS_TXOP_LMT_PKT_NUM_8822B))
#define BIT_GET_TXOP_LMT_PKT_NUM_8822B(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_PKT_NUM_8822B) & \
BIT_MASK_TXOP_LMT_PKT_NUM_8822B)
#define BIT_SET_TXOP_LMT_PKT_NUM_8822B(x, v) \
(BIT_CLEAR_TXOP_LMT_PKT_NUM_8822B(x) | BIT_TXOP_LMT_PKT_NUM_8822B(v))
/* 2 REG_BAR_TX_CTRL_8822B */
/* 2 REG_P2PON_DIS_TXTIME_8822B */
#define BIT_SHIFT_P2PON_DIS_TXTIME_8822B 0
#define BIT_MASK_P2PON_DIS_TXTIME_8822B 0xff
#define BIT_P2PON_DIS_TXTIME_8822B(x) \
(((x) & BIT_MASK_P2PON_DIS_TXTIME_8822B) \
<< BIT_SHIFT_P2PON_DIS_TXTIME_8822B)
#define BITS_P2PON_DIS_TXTIME_8822B \
(BIT_MASK_P2PON_DIS_TXTIME_8822B << BIT_SHIFT_P2PON_DIS_TXTIME_8822B)
#define BIT_CLEAR_P2PON_DIS_TXTIME_8822B(x) \
((x) & (~BITS_P2PON_DIS_TXTIME_8822B))
#define BIT_GET_P2PON_DIS_TXTIME_8822B(x) \
(((x) >> BIT_SHIFT_P2PON_DIS_TXTIME_8822B) & \
BIT_MASK_P2PON_DIS_TXTIME_8822B)
#define BIT_SET_P2PON_DIS_TXTIME_8822B(x, v) \
(BIT_CLEAR_P2PON_DIS_TXTIME_8822B(x) | BIT_P2PON_DIS_TXTIME_8822B(v))
/* 2 REG_QUEUE_INCOL_THR_8822B */
#define BIT_SHIFT_BK_QUEUE_THR_8822B 24
#define BIT_MASK_BK_QUEUE_THR_8822B 0xff
#define BIT_BK_QUEUE_THR_8822B(x) \
(((x) & BIT_MASK_BK_QUEUE_THR_8822B) << BIT_SHIFT_BK_QUEUE_THR_8822B)
#define BITS_BK_QUEUE_THR_8822B \
(BIT_MASK_BK_QUEUE_THR_8822B << BIT_SHIFT_BK_QUEUE_THR_8822B)
#define BIT_CLEAR_BK_QUEUE_THR_8822B(x) ((x) & (~BITS_BK_QUEUE_THR_8822B))
#define BIT_GET_BK_QUEUE_THR_8822B(x) \
(((x) >> BIT_SHIFT_BK_QUEUE_THR_8822B) & BIT_MASK_BK_QUEUE_THR_8822B)
#define BIT_SET_BK_QUEUE_THR_8822B(x, v) \
(BIT_CLEAR_BK_QUEUE_THR_8822B(x) | BIT_BK_QUEUE_THR_8822B(v))
#define BIT_SHIFT_BE_QUEUE_THR_8822B 16
#define BIT_MASK_BE_QUEUE_THR_8822B 0xff
#define BIT_BE_QUEUE_THR_8822B(x) \
(((x) & BIT_MASK_BE_QUEUE_THR_8822B) << BIT_SHIFT_BE_QUEUE_THR_8822B)
#define BITS_BE_QUEUE_THR_8822B \
(BIT_MASK_BE_QUEUE_THR_8822B << BIT_SHIFT_BE_QUEUE_THR_8822B)
#define BIT_CLEAR_BE_QUEUE_THR_8822B(x) ((x) & (~BITS_BE_QUEUE_THR_8822B))
#define BIT_GET_BE_QUEUE_THR_8822B(x) \
(((x) >> BIT_SHIFT_BE_QUEUE_THR_8822B) & BIT_MASK_BE_QUEUE_THR_8822B)
#define BIT_SET_BE_QUEUE_THR_8822B(x, v) \
(BIT_CLEAR_BE_QUEUE_THR_8822B(x) | BIT_BE_QUEUE_THR_8822B(v))
#define BIT_SHIFT_VI_QUEUE_THR_8822B 8
#define BIT_MASK_VI_QUEUE_THR_8822B 0xff
#define BIT_VI_QUEUE_THR_8822B(x) \
(((x) & BIT_MASK_VI_QUEUE_THR_8822B) << BIT_SHIFT_VI_QUEUE_THR_8822B)
#define BITS_VI_QUEUE_THR_8822B \
(BIT_MASK_VI_QUEUE_THR_8822B << BIT_SHIFT_VI_QUEUE_THR_8822B)
#define BIT_CLEAR_VI_QUEUE_THR_8822B(x) ((x) & (~BITS_VI_QUEUE_THR_8822B))
#define BIT_GET_VI_QUEUE_THR_8822B(x) \
(((x) >> BIT_SHIFT_VI_QUEUE_THR_8822B) & BIT_MASK_VI_QUEUE_THR_8822B)
#define BIT_SET_VI_QUEUE_THR_8822B(x, v) \
(BIT_CLEAR_VI_QUEUE_THR_8822B(x) | BIT_VI_QUEUE_THR_8822B(v))
#define BIT_SHIFT_VO_QUEUE_THR_8822B 0
#define BIT_MASK_VO_QUEUE_THR_8822B 0xff
#define BIT_VO_QUEUE_THR_8822B(x) \
(((x) & BIT_MASK_VO_QUEUE_THR_8822B) << BIT_SHIFT_VO_QUEUE_THR_8822B)
#define BITS_VO_QUEUE_THR_8822B \
(BIT_MASK_VO_QUEUE_THR_8822B << BIT_SHIFT_VO_QUEUE_THR_8822B)
#define BIT_CLEAR_VO_QUEUE_THR_8822B(x) ((x) & (~BITS_VO_QUEUE_THR_8822B))
#define BIT_GET_VO_QUEUE_THR_8822B(x) \
(((x) >> BIT_SHIFT_VO_QUEUE_THR_8822B) & BIT_MASK_VO_QUEUE_THR_8822B)
#define BIT_SET_VO_QUEUE_THR_8822B(x, v) \
(BIT_CLEAR_VO_QUEUE_THR_8822B(x) | BIT_VO_QUEUE_THR_8822B(v))
/* 2 REG_QUEUE_INCOL_EN_8822B */
#define BIT_QUEUE_INCOL_EN_8822B BIT(16)
#define BIT_SHIFT_BE_TRIGGER_NUM_8822B 12
#define BIT_MASK_BE_TRIGGER_NUM_8822B 0xf
#define BIT_BE_TRIGGER_NUM_8822B(x) \
(((x) & BIT_MASK_BE_TRIGGER_NUM_8822B) \
<< BIT_SHIFT_BE_TRIGGER_NUM_8822B)
#define BITS_BE_TRIGGER_NUM_8822B \
(BIT_MASK_BE_TRIGGER_NUM_8822B << BIT_SHIFT_BE_TRIGGER_NUM_8822B)
#define BIT_CLEAR_BE_TRIGGER_NUM_8822B(x) ((x) & (~BITS_BE_TRIGGER_NUM_8822B))
#define BIT_GET_BE_TRIGGER_NUM_8822B(x) \
(((x) >> BIT_SHIFT_BE_TRIGGER_NUM_8822B) & \
BIT_MASK_BE_TRIGGER_NUM_8822B)
#define BIT_SET_BE_TRIGGER_NUM_8822B(x, v) \
(BIT_CLEAR_BE_TRIGGER_NUM_8822B(x) | BIT_BE_TRIGGER_NUM_8822B(v))
#define BIT_SHIFT_BK_TRIGGER_NUM_8822B 8
#define BIT_MASK_BK_TRIGGER_NUM_8822B 0xf
#define BIT_BK_TRIGGER_NUM_8822B(x) \
(((x) & BIT_MASK_BK_TRIGGER_NUM_8822B) \
<< BIT_SHIFT_BK_TRIGGER_NUM_8822B)
#define BITS_BK_TRIGGER_NUM_8822B \
(BIT_MASK_BK_TRIGGER_NUM_8822B << BIT_SHIFT_BK_TRIGGER_NUM_8822B)
#define BIT_CLEAR_BK_TRIGGER_NUM_8822B(x) ((x) & (~BITS_BK_TRIGGER_NUM_8822B))
#define BIT_GET_BK_TRIGGER_NUM_8822B(x) \
(((x) >> BIT_SHIFT_BK_TRIGGER_NUM_8822B) & \
BIT_MASK_BK_TRIGGER_NUM_8822B)
#define BIT_SET_BK_TRIGGER_NUM_8822B(x, v) \
(BIT_CLEAR_BK_TRIGGER_NUM_8822B(x) | BIT_BK_TRIGGER_NUM_8822B(v))
#define BIT_SHIFT_VI_TRIGGER_NUM_8822B 4
#define BIT_MASK_VI_TRIGGER_NUM_8822B 0xf
#define BIT_VI_TRIGGER_NUM_8822B(x) \
(((x) & BIT_MASK_VI_TRIGGER_NUM_8822B) \
<< BIT_SHIFT_VI_TRIGGER_NUM_8822B)
#define BITS_VI_TRIGGER_NUM_8822B \
(BIT_MASK_VI_TRIGGER_NUM_8822B << BIT_SHIFT_VI_TRIGGER_NUM_8822B)
#define BIT_CLEAR_VI_TRIGGER_NUM_8822B(x) ((x) & (~BITS_VI_TRIGGER_NUM_8822B))
#define BIT_GET_VI_TRIGGER_NUM_8822B(x) \
(((x) >> BIT_SHIFT_VI_TRIGGER_NUM_8822B) & \
BIT_MASK_VI_TRIGGER_NUM_8822B)
#define BIT_SET_VI_TRIGGER_NUM_8822B(x, v) \
(BIT_CLEAR_VI_TRIGGER_NUM_8822B(x) | BIT_VI_TRIGGER_NUM_8822B(v))
#define BIT_SHIFT_VO_TRIGGER_NUM_8822B 0
#define BIT_MASK_VO_TRIGGER_NUM_8822B 0xf
#define BIT_VO_TRIGGER_NUM_8822B(x) \
(((x) & BIT_MASK_VO_TRIGGER_NUM_8822B) \
<< BIT_SHIFT_VO_TRIGGER_NUM_8822B)
#define BITS_VO_TRIGGER_NUM_8822B \
(BIT_MASK_VO_TRIGGER_NUM_8822B << BIT_SHIFT_VO_TRIGGER_NUM_8822B)
#define BIT_CLEAR_VO_TRIGGER_NUM_8822B(x) ((x) & (~BITS_VO_TRIGGER_NUM_8822B))
#define BIT_GET_VO_TRIGGER_NUM_8822B(x) \
(((x) >> BIT_SHIFT_VO_TRIGGER_NUM_8822B) & \
BIT_MASK_VO_TRIGGER_NUM_8822B)
#define BIT_SET_VO_TRIGGER_NUM_8822B(x, v) \
(BIT_CLEAR_VO_TRIGGER_NUM_8822B(x) | BIT_VO_TRIGGER_NUM_8822B(v))
/* 2 REG_TBTT_PROHIBIT_8822B */
#define BIT_SHIFT_TBTT_HOLD_TIME_AP_8822B 8
#define BIT_MASK_TBTT_HOLD_TIME_AP_8822B 0xfff
#define BIT_TBTT_HOLD_TIME_AP_8822B(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_AP_8822B) \
<< BIT_SHIFT_TBTT_HOLD_TIME_AP_8822B)
#define BITS_TBTT_HOLD_TIME_AP_8822B \
(BIT_MASK_TBTT_HOLD_TIME_AP_8822B << BIT_SHIFT_TBTT_HOLD_TIME_AP_8822B)
#define BIT_CLEAR_TBTT_HOLD_TIME_AP_8822B(x) \
((x) & (~BITS_TBTT_HOLD_TIME_AP_8822B))
#define BIT_GET_TBTT_HOLD_TIME_AP_8822B(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_AP_8822B) & \
BIT_MASK_TBTT_HOLD_TIME_AP_8822B)
#define BIT_SET_TBTT_HOLD_TIME_AP_8822B(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_AP_8822B(x) | BIT_TBTT_HOLD_TIME_AP_8822B(v))
#define BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822B 0
#define BIT_MASK_TBTT_PROHIBIT_SETUP_8822B 0xf
#define BIT_TBTT_PROHIBIT_SETUP_8822B(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_SETUP_8822B) \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822B)
#define BITS_TBTT_PROHIBIT_SETUP_8822B \
(BIT_MASK_TBTT_PROHIBIT_SETUP_8822B \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822B)
#define BIT_CLEAR_TBTT_PROHIBIT_SETUP_8822B(x) \
((x) & (~BITS_TBTT_PROHIBIT_SETUP_8822B))
#define BIT_GET_TBTT_PROHIBIT_SETUP_8822B(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822B) & \
BIT_MASK_TBTT_PROHIBIT_SETUP_8822B)
#define BIT_SET_TBTT_PROHIBIT_SETUP_8822B(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_SETUP_8822B(x) | \
BIT_TBTT_PROHIBIT_SETUP_8822B(v))
/* 2 REG_P2PPS_STATE_8822B */
#define BIT_POWER_STATE_8822B BIT(7)
#define BIT_CTWINDOW_ON_8822B BIT(6)
#define BIT_BEACON_AREA_ON_8822B BIT(5)
#define BIT_CTWIN_EARLY_DISTX_8822B BIT(4)
#define BIT_NOA1_OFF_PERIOD_8822B BIT(3)
#define BIT_FORCE_DOZE1_8822B BIT(2)
#define BIT_NOA0_OFF_PERIOD_8822B BIT(1)
#define BIT_FORCE_DOZE0_8822B BIT(0)
/* 2 REG_RD_NAV_NXT_8822B */
#define BIT_SHIFT_RD_NAV_PROT_NXT_8822B 0
#define BIT_MASK_RD_NAV_PROT_NXT_8822B 0xffff
#define BIT_RD_NAV_PROT_NXT_8822B(x) \
(((x) & BIT_MASK_RD_NAV_PROT_NXT_8822B) \
<< BIT_SHIFT_RD_NAV_PROT_NXT_8822B)
#define BITS_RD_NAV_PROT_NXT_8822B \
(BIT_MASK_RD_NAV_PROT_NXT_8822B << BIT_SHIFT_RD_NAV_PROT_NXT_8822B)
#define BIT_CLEAR_RD_NAV_PROT_NXT_8822B(x) ((x) & (~BITS_RD_NAV_PROT_NXT_8822B))
#define BIT_GET_RD_NAV_PROT_NXT_8822B(x) \
(((x) >> BIT_SHIFT_RD_NAV_PROT_NXT_8822B) & \
BIT_MASK_RD_NAV_PROT_NXT_8822B)
#define BIT_SET_RD_NAV_PROT_NXT_8822B(x, v) \
(BIT_CLEAR_RD_NAV_PROT_NXT_8822B(x) | BIT_RD_NAV_PROT_NXT_8822B(v))
/* 2 REG_NAV_PROT_LEN_8822B */
#define BIT_SHIFT_NAV_PROT_LEN_8822B 0
#define BIT_MASK_NAV_PROT_LEN_8822B 0xffff
#define BIT_NAV_PROT_LEN_8822B(x) \
(((x) & BIT_MASK_NAV_PROT_LEN_8822B) << BIT_SHIFT_NAV_PROT_LEN_8822B)
#define BITS_NAV_PROT_LEN_8822B \
(BIT_MASK_NAV_PROT_LEN_8822B << BIT_SHIFT_NAV_PROT_LEN_8822B)
#define BIT_CLEAR_NAV_PROT_LEN_8822B(x) ((x) & (~BITS_NAV_PROT_LEN_8822B))
#define BIT_GET_NAV_PROT_LEN_8822B(x) \
(((x) >> BIT_SHIFT_NAV_PROT_LEN_8822B) & BIT_MASK_NAV_PROT_LEN_8822B)
#define BIT_SET_NAV_PROT_LEN_8822B(x, v) \
(BIT_CLEAR_NAV_PROT_LEN_8822B(x) | BIT_NAV_PROT_LEN_8822B(v))
/* 2 REG_BCN_CTRL_8822B */
#define BIT_DIS_RX_BSSID_FIT_8822B BIT(6)
#define BIT_P0_EN_TXBCN_RPT_8822B BIT(5)
#define BIT_DIS_TSF_UDT_8822B BIT(4)
#define BIT_EN_BCN_FUNCTION_8822B BIT(3)
#define BIT_P0_EN_RXBCN_RPT_8822B BIT(2)
#define BIT_EN_P2P_CTWINDOW_8822B BIT(1)
#define BIT_EN_P2P_BCNQ_AREA_8822B BIT(0)
/* 2 REG_BCN_CTRL_CLINT0_8822B */
#define BIT_CLI0_DIS_RX_BSSID_FIT_8822B BIT(6)
#define BIT_CLI0_DIS_TSF_UDT_8822B BIT(4)
#define BIT_CLI0_EN_BCN_FUNCTION_8822B BIT(3)
#define BIT_CLI0_EN_RXBCN_RPT_8822B BIT(2)
#define BIT_CLI0_ENP2P_CTWINDOW_8822B BIT(1)
#define BIT_CLI0_ENP2P_BCNQ_AREA_8822B BIT(0)
/* 2 REG_MBID_NUM_8822B */
#define BIT_EN_PRE_DL_BEACON_8822B BIT(3)
#define BIT_SHIFT_MBID_BCN_NUM_8822B 0
#define BIT_MASK_MBID_BCN_NUM_8822B 0x7
#define BIT_MBID_BCN_NUM_8822B(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_8822B) << BIT_SHIFT_MBID_BCN_NUM_8822B)
#define BITS_MBID_BCN_NUM_8822B \
(BIT_MASK_MBID_BCN_NUM_8822B << BIT_SHIFT_MBID_BCN_NUM_8822B)
#define BIT_CLEAR_MBID_BCN_NUM_8822B(x) ((x) & (~BITS_MBID_BCN_NUM_8822B))
#define BIT_GET_MBID_BCN_NUM_8822B(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_8822B) & BIT_MASK_MBID_BCN_NUM_8822B)
#define BIT_SET_MBID_BCN_NUM_8822B(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_8822B(x) | BIT_MBID_BCN_NUM_8822B(v))
/* 2 REG_DUAL_TSF_RST_8822B */
#define BIT_FREECNT_RST_8822B BIT(5)
#define BIT_TSFTR_CLI3_RST_8822B BIT(4)
#define BIT_TSFTR_CLI2_RST_8822B BIT(3)
#define BIT_TSFTR_CLI1_RST_8822B BIT(2)
#define BIT_TSFTR_CLI0_RST_8822B BIT(1)
#define BIT_TSFTR_RST_8822B BIT(0)
/* 2 REG_MBSSID_BCN_SPACE_8822B */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822B 28
#define BIT_MASK_BCN_TIMER_SEL_FWRD_8822B 0x7
#define BIT_BCN_TIMER_SEL_FWRD_8822B(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD_8822B) \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822B)
#define BITS_BCN_TIMER_SEL_FWRD_8822B \
(BIT_MASK_BCN_TIMER_SEL_FWRD_8822B \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822B)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD_8822B(x) \
((x) & (~BITS_BCN_TIMER_SEL_FWRD_8822B))
#define BIT_GET_BCN_TIMER_SEL_FWRD_8822B(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822B) & \
BIT_MASK_BCN_TIMER_SEL_FWRD_8822B)
#define BIT_SET_BCN_TIMER_SEL_FWRD_8822B(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD_8822B(x) | \
BIT_BCN_TIMER_SEL_FWRD_8822B(v))
#define BIT_SHIFT_BCN_SPACE_CLINT0_8822B 16
#define BIT_MASK_BCN_SPACE_CLINT0_8822B 0xfff
#define BIT_BCN_SPACE_CLINT0_8822B(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT0_8822B) \
<< BIT_SHIFT_BCN_SPACE_CLINT0_8822B)
#define BITS_BCN_SPACE_CLINT0_8822B \
(BIT_MASK_BCN_SPACE_CLINT0_8822B << BIT_SHIFT_BCN_SPACE_CLINT0_8822B)
#define BIT_CLEAR_BCN_SPACE_CLINT0_8822B(x) \
((x) & (~BITS_BCN_SPACE_CLINT0_8822B))
#define BIT_GET_BCN_SPACE_CLINT0_8822B(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT0_8822B) & \
BIT_MASK_BCN_SPACE_CLINT0_8822B)
#define BIT_SET_BCN_SPACE_CLINT0_8822B(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT0_8822B(x) | BIT_BCN_SPACE_CLINT0_8822B(v))
#define BIT_SHIFT_BCN_SPACE0_8822B 0
#define BIT_MASK_BCN_SPACE0_8822B 0xffff
#define BIT_BCN_SPACE0_8822B(x) \
(((x) & BIT_MASK_BCN_SPACE0_8822B) << BIT_SHIFT_BCN_SPACE0_8822B)
#define BITS_BCN_SPACE0_8822B \
(BIT_MASK_BCN_SPACE0_8822B << BIT_SHIFT_BCN_SPACE0_8822B)
#define BIT_CLEAR_BCN_SPACE0_8822B(x) ((x) & (~BITS_BCN_SPACE0_8822B))
#define BIT_GET_BCN_SPACE0_8822B(x) \
(((x) >> BIT_SHIFT_BCN_SPACE0_8822B) & BIT_MASK_BCN_SPACE0_8822B)
#define BIT_SET_BCN_SPACE0_8822B(x, v) \
(BIT_CLEAR_BCN_SPACE0_8822B(x) | BIT_BCN_SPACE0_8822B(v))
/* 2 REG_DRVERLYINT_8822B */
#define BIT_SHIFT_DRVERLYITV_8822B 0
#define BIT_MASK_DRVERLYITV_8822B 0xff
#define BIT_DRVERLYITV_8822B(x) \
(((x) & BIT_MASK_DRVERLYITV_8822B) << BIT_SHIFT_DRVERLYITV_8822B)
#define BITS_DRVERLYITV_8822B \
(BIT_MASK_DRVERLYITV_8822B << BIT_SHIFT_DRVERLYITV_8822B)
#define BIT_CLEAR_DRVERLYITV_8822B(x) ((x) & (~BITS_DRVERLYITV_8822B))
#define BIT_GET_DRVERLYITV_8822B(x) \
(((x) >> BIT_SHIFT_DRVERLYITV_8822B) & BIT_MASK_DRVERLYITV_8822B)
#define BIT_SET_DRVERLYITV_8822B(x, v) \
(BIT_CLEAR_DRVERLYITV_8822B(x) | BIT_DRVERLYITV_8822B(v))
/* 2 REG_BCNDMATIM_8822B */
#define BIT_SHIFT_BCNDMATIM_8822B 0
#define BIT_MASK_BCNDMATIM_8822B 0xff
#define BIT_BCNDMATIM_8822B(x) \
(((x) & BIT_MASK_BCNDMATIM_8822B) << BIT_SHIFT_BCNDMATIM_8822B)
#define BITS_BCNDMATIM_8822B \
(BIT_MASK_BCNDMATIM_8822B << BIT_SHIFT_BCNDMATIM_8822B)
#define BIT_CLEAR_BCNDMATIM_8822B(x) ((x) & (~BITS_BCNDMATIM_8822B))
#define BIT_GET_BCNDMATIM_8822B(x) \
(((x) >> BIT_SHIFT_BCNDMATIM_8822B) & BIT_MASK_BCNDMATIM_8822B)
#define BIT_SET_BCNDMATIM_8822B(x, v) \
(BIT_CLEAR_BCNDMATIM_8822B(x) | BIT_BCNDMATIM_8822B(v))
/* 2 REG_ATIMWND_8822B */
#define BIT_SHIFT_ATIMWND0_8822B 0
#define BIT_MASK_ATIMWND0_8822B 0xffff
#define BIT_ATIMWND0_8822B(x) \
(((x) & BIT_MASK_ATIMWND0_8822B) << BIT_SHIFT_ATIMWND0_8822B)
#define BITS_ATIMWND0_8822B \
(BIT_MASK_ATIMWND0_8822B << BIT_SHIFT_ATIMWND0_8822B)
#define BIT_CLEAR_ATIMWND0_8822B(x) ((x) & (~BITS_ATIMWND0_8822B))
#define BIT_GET_ATIMWND0_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND0_8822B) & BIT_MASK_ATIMWND0_8822B)
#define BIT_SET_ATIMWND0_8822B(x, v) \
(BIT_CLEAR_ATIMWND0_8822B(x) | BIT_ATIMWND0_8822B(v))
/* 2 REG_USTIME_TSF_8822B */
#define BIT_SHIFT_USTIME_TSF_V1_8822B 0
#define BIT_MASK_USTIME_TSF_V1_8822B 0xff
#define BIT_USTIME_TSF_V1_8822B(x) \
(((x) & BIT_MASK_USTIME_TSF_V1_8822B) << BIT_SHIFT_USTIME_TSF_V1_8822B)
#define BITS_USTIME_TSF_V1_8822B \
(BIT_MASK_USTIME_TSF_V1_8822B << BIT_SHIFT_USTIME_TSF_V1_8822B)
#define BIT_CLEAR_USTIME_TSF_V1_8822B(x) ((x) & (~BITS_USTIME_TSF_V1_8822B))
#define BIT_GET_USTIME_TSF_V1_8822B(x) \
(((x) >> BIT_SHIFT_USTIME_TSF_V1_8822B) & BIT_MASK_USTIME_TSF_V1_8822B)
#define BIT_SET_USTIME_TSF_V1_8822B(x, v) \
(BIT_CLEAR_USTIME_TSF_V1_8822B(x) | BIT_USTIME_TSF_V1_8822B(v))
/* 2 REG_BCN_MAX_ERR_8822B */
#define BIT_SHIFT_BCN_MAX_ERR_8822B 0
#define BIT_MASK_BCN_MAX_ERR_8822B 0xff
#define BIT_BCN_MAX_ERR_8822B(x) \
(((x) & BIT_MASK_BCN_MAX_ERR_8822B) << BIT_SHIFT_BCN_MAX_ERR_8822B)
#define BITS_BCN_MAX_ERR_8822B \
(BIT_MASK_BCN_MAX_ERR_8822B << BIT_SHIFT_BCN_MAX_ERR_8822B)
#define BIT_CLEAR_BCN_MAX_ERR_8822B(x) ((x) & (~BITS_BCN_MAX_ERR_8822B))
#define BIT_GET_BCN_MAX_ERR_8822B(x) \
(((x) >> BIT_SHIFT_BCN_MAX_ERR_8822B) & BIT_MASK_BCN_MAX_ERR_8822B)
#define BIT_SET_BCN_MAX_ERR_8822B(x, v) \
(BIT_CLEAR_BCN_MAX_ERR_8822B(x) | BIT_BCN_MAX_ERR_8822B(v))
/* 2 REG_RXTSF_OFFSET_CCK_8822B */
#define BIT_SHIFT_CCK_RXTSF_OFFSET_8822B 0
#define BIT_MASK_CCK_RXTSF_OFFSET_8822B 0xff
#define BIT_CCK_RXTSF_OFFSET_8822B(x) \
(((x) & BIT_MASK_CCK_RXTSF_OFFSET_8822B) \
<< BIT_SHIFT_CCK_RXTSF_OFFSET_8822B)
#define BITS_CCK_RXTSF_OFFSET_8822B \
(BIT_MASK_CCK_RXTSF_OFFSET_8822B << BIT_SHIFT_CCK_RXTSF_OFFSET_8822B)
#define BIT_CLEAR_CCK_RXTSF_OFFSET_8822B(x) \
((x) & (~BITS_CCK_RXTSF_OFFSET_8822B))
#define BIT_GET_CCK_RXTSF_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_CCK_RXTSF_OFFSET_8822B) & \
BIT_MASK_CCK_RXTSF_OFFSET_8822B)
#define BIT_SET_CCK_RXTSF_OFFSET_8822B(x, v) \
(BIT_CLEAR_CCK_RXTSF_OFFSET_8822B(x) | BIT_CCK_RXTSF_OFFSET_8822B(v))
/* 2 REG_RXTSF_OFFSET_OFDM_8822B */
#define BIT_SHIFT_OFDM_RXTSF_OFFSET_8822B 0
#define BIT_MASK_OFDM_RXTSF_OFFSET_8822B 0xff
#define BIT_OFDM_RXTSF_OFFSET_8822B(x) \
(((x) & BIT_MASK_OFDM_RXTSF_OFFSET_8822B) \
<< BIT_SHIFT_OFDM_RXTSF_OFFSET_8822B)
#define BITS_OFDM_RXTSF_OFFSET_8822B \
(BIT_MASK_OFDM_RXTSF_OFFSET_8822B << BIT_SHIFT_OFDM_RXTSF_OFFSET_8822B)
#define BIT_CLEAR_OFDM_RXTSF_OFFSET_8822B(x) \
((x) & (~BITS_OFDM_RXTSF_OFFSET_8822B))
#define BIT_GET_OFDM_RXTSF_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_OFDM_RXTSF_OFFSET_8822B) & \
BIT_MASK_OFDM_RXTSF_OFFSET_8822B)
#define BIT_SET_OFDM_RXTSF_OFFSET_8822B(x, v) \
(BIT_CLEAR_OFDM_RXTSF_OFFSET_8822B(x) | BIT_OFDM_RXTSF_OFFSET_8822B(v))
/* 2 REG_TSFTR_8822B */
#define BIT_SHIFT_TSF_TIMER_8822B 0
#define BIT_MASK_TSF_TIMER_8822B 0xffffffffffffffffL
#define BIT_TSF_TIMER_8822B(x) \
(((x) & BIT_MASK_TSF_TIMER_8822B) << BIT_SHIFT_TSF_TIMER_8822B)
#define BITS_TSF_TIMER_8822B \
(BIT_MASK_TSF_TIMER_8822B << BIT_SHIFT_TSF_TIMER_8822B)
#define BIT_CLEAR_TSF_TIMER_8822B(x) ((x) & (~BITS_TSF_TIMER_8822B))
#define BIT_GET_TSF_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_8822B) & BIT_MASK_TSF_TIMER_8822B)
#define BIT_SET_TSF_TIMER_8822B(x, v) \
(BIT_CLEAR_TSF_TIMER_8822B(x) | BIT_TSF_TIMER_8822B(v))
/* 2 REG_FREERUN_CNT_8822B */
#define BIT_SHIFT_FREERUN_CNT_8822B 0
#define BIT_MASK_FREERUN_CNT_8822B 0xffffffffffffffffL
#define BIT_FREERUN_CNT_8822B(x) \
(((x) & BIT_MASK_FREERUN_CNT_8822B) << BIT_SHIFT_FREERUN_CNT_8822B)
#define BITS_FREERUN_CNT_8822B \
(BIT_MASK_FREERUN_CNT_8822B << BIT_SHIFT_FREERUN_CNT_8822B)
#define BIT_CLEAR_FREERUN_CNT_8822B(x) ((x) & (~BITS_FREERUN_CNT_8822B))
#define BIT_GET_FREERUN_CNT_8822B(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_8822B) & BIT_MASK_FREERUN_CNT_8822B)
#define BIT_SET_FREERUN_CNT_8822B(x, v) \
(BIT_CLEAR_FREERUN_CNT_8822B(x) | BIT_FREERUN_CNT_8822B(v))
/* 2 REG_ATIMWND1_V1_8822B */
#define BIT_SHIFT_ATIMWND1_V1_8822B 0
#define BIT_MASK_ATIMWND1_V1_8822B 0xff
#define BIT_ATIMWND1_V1_8822B(x) \
(((x) & BIT_MASK_ATIMWND1_V1_8822B) << BIT_SHIFT_ATIMWND1_V1_8822B)
#define BITS_ATIMWND1_V1_8822B \
(BIT_MASK_ATIMWND1_V1_8822B << BIT_SHIFT_ATIMWND1_V1_8822B)
#define BIT_CLEAR_ATIMWND1_V1_8822B(x) ((x) & (~BITS_ATIMWND1_V1_8822B))
#define BIT_GET_ATIMWND1_V1_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND1_V1_8822B) & BIT_MASK_ATIMWND1_V1_8822B)
#define BIT_SET_ATIMWND1_V1_8822B(x, v) \
(BIT_CLEAR_ATIMWND1_V1_8822B(x) | BIT_ATIMWND1_V1_8822B(v))
/* 2 REG_TBTT_PROHIBIT_INFRA_8822B */
#define BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822B 0
#define BIT_MASK_TBTT_PROHIBIT_INFRA_8822B 0xff
#define BIT_TBTT_PROHIBIT_INFRA_8822B(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_INFRA_8822B) \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822B)
#define BITS_TBTT_PROHIBIT_INFRA_8822B \
(BIT_MASK_TBTT_PROHIBIT_INFRA_8822B \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822B)
#define BIT_CLEAR_TBTT_PROHIBIT_INFRA_8822B(x) \
((x) & (~BITS_TBTT_PROHIBIT_INFRA_8822B))
#define BIT_GET_TBTT_PROHIBIT_INFRA_8822B(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822B) & \
BIT_MASK_TBTT_PROHIBIT_INFRA_8822B)
#define BIT_SET_TBTT_PROHIBIT_INFRA_8822B(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_INFRA_8822B(x) | \
BIT_TBTT_PROHIBIT_INFRA_8822B(v))
/* 2 REG_CTWND_8822B */
#define BIT_SHIFT_CTWND_8822B 0
#define BIT_MASK_CTWND_8822B 0xff
#define BIT_CTWND_8822B(x) \
(((x) & BIT_MASK_CTWND_8822B) << BIT_SHIFT_CTWND_8822B)
#define BITS_CTWND_8822B (BIT_MASK_CTWND_8822B << BIT_SHIFT_CTWND_8822B)
#define BIT_CLEAR_CTWND_8822B(x) ((x) & (~BITS_CTWND_8822B))
#define BIT_GET_CTWND_8822B(x) \
(((x) >> BIT_SHIFT_CTWND_8822B) & BIT_MASK_CTWND_8822B)
#define BIT_SET_CTWND_8822B(x, v) \
(BIT_CLEAR_CTWND_8822B(x) | BIT_CTWND_8822B(v))
/* 2 REG_BCNIVLCUNT_8822B */
#define BIT_SHIFT_BCNIVLCUNT_8822B 0
#define BIT_MASK_BCNIVLCUNT_8822B 0x7f
#define BIT_BCNIVLCUNT_8822B(x) \
(((x) & BIT_MASK_BCNIVLCUNT_8822B) << BIT_SHIFT_BCNIVLCUNT_8822B)
#define BITS_BCNIVLCUNT_8822B \
(BIT_MASK_BCNIVLCUNT_8822B << BIT_SHIFT_BCNIVLCUNT_8822B)
#define BIT_CLEAR_BCNIVLCUNT_8822B(x) ((x) & (~BITS_BCNIVLCUNT_8822B))
#define BIT_GET_BCNIVLCUNT_8822B(x) \
(((x) >> BIT_SHIFT_BCNIVLCUNT_8822B) & BIT_MASK_BCNIVLCUNT_8822B)
#define BIT_SET_BCNIVLCUNT_8822B(x, v) \
(BIT_CLEAR_BCNIVLCUNT_8822B(x) | BIT_BCNIVLCUNT_8822B(v))
/* 2 REG_BCNDROPCTRL_8822B */
#define BIT_BEACON_DROP_EN_8822B BIT(7)
#define BIT_SHIFT_BEACON_DROP_IVL_8822B 0
#define BIT_MASK_BEACON_DROP_IVL_8822B 0x7f
#define BIT_BEACON_DROP_IVL_8822B(x) \
(((x) & BIT_MASK_BEACON_DROP_IVL_8822B) \
<< BIT_SHIFT_BEACON_DROP_IVL_8822B)
#define BITS_BEACON_DROP_IVL_8822B \
(BIT_MASK_BEACON_DROP_IVL_8822B << BIT_SHIFT_BEACON_DROP_IVL_8822B)
#define BIT_CLEAR_BEACON_DROP_IVL_8822B(x) ((x) & (~BITS_BEACON_DROP_IVL_8822B))
#define BIT_GET_BEACON_DROP_IVL_8822B(x) \
(((x) >> BIT_SHIFT_BEACON_DROP_IVL_8822B) & \
BIT_MASK_BEACON_DROP_IVL_8822B)
#define BIT_SET_BEACON_DROP_IVL_8822B(x, v) \
(BIT_CLEAR_BEACON_DROP_IVL_8822B(x) | BIT_BEACON_DROP_IVL_8822B(v))
/* 2 REG_HGQ_TIMEOUT_PERIOD_8822B */
#define BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822B 0
#define BIT_MASK_HGQ_TIMEOUT_PERIOD_8822B 0xff
#define BIT_HGQ_TIMEOUT_PERIOD_8822B(x) \
(((x) & BIT_MASK_HGQ_TIMEOUT_PERIOD_8822B) \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822B)
#define BITS_HGQ_TIMEOUT_PERIOD_8822B \
(BIT_MASK_HGQ_TIMEOUT_PERIOD_8822B \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822B)
#define BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8822B(x) \
((x) & (~BITS_HGQ_TIMEOUT_PERIOD_8822B))
#define BIT_GET_HGQ_TIMEOUT_PERIOD_8822B(x) \
(((x) >> BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822B) & \
BIT_MASK_HGQ_TIMEOUT_PERIOD_8822B)
#define BIT_SET_HGQ_TIMEOUT_PERIOD_8822B(x, v) \
(BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8822B(x) | \
BIT_HGQ_TIMEOUT_PERIOD_8822B(v))
/* 2 REG_TXCMD_TIMEOUT_PERIOD_8822B */
#define BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822B 0
#define BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822B 0xff
#define BIT_TXCMD_TIMEOUT_PERIOD_8822B(x) \
(((x) & BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822B) \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822B)
#define BITS_TXCMD_TIMEOUT_PERIOD_8822B \
(BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822B \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822B)
#define BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8822B(x) \
((x) & (~BITS_TXCMD_TIMEOUT_PERIOD_8822B))
#define BIT_GET_TXCMD_TIMEOUT_PERIOD_8822B(x) \
(((x) >> BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822B) & \
BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822B)
#define BIT_SET_TXCMD_TIMEOUT_PERIOD_8822B(x, v) \
(BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8822B(x) | \
BIT_TXCMD_TIMEOUT_PERIOD_8822B(v))
/* 2 REG_MISC_CTRL_8822B */
#define BIT_AUTO_SYNC_BY_TBTT_8822B BIT(6)
#define BIT_DIS_TRX_CAL_BCN_8822B BIT(5)
#define BIT_DIS_TX_CAL_TBTT_8822B BIT(4)
#define BIT_EN_FREECNT_8822B BIT(3)
#define BIT_BCN_AGGRESSION_8822B BIT(2)
#define BIT_SHIFT_DIS_SECONDARY_CCA_8822B 0
#define BIT_MASK_DIS_SECONDARY_CCA_8822B 0x3
#define BIT_DIS_SECONDARY_CCA_8822B(x) \
(((x) & BIT_MASK_DIS_SECONDARY_CCA_8822B) \
<< BIT_SHIFT_DIS_SECONDARY_CCA_8822B)
#define BITS_DIS_SECONDARY_CCA_8822B \
(BIT_MASK_DIS_SECONDARY_CCA_8822B << BIT_SHIFT_DIS_SECONDARY_CCA_8822B)
#define BIT_CLEAR_DIS_SECONDARY_CCA_8822B(x) \
((x) & (~BITS_DIS_SECONDARY_CCA_8822B))
#define BIT_GET_DIS_SECONDARY_CCA_8822B(x) \
(((x) >> BIT_SHIFT_DIS_SECONDARY_CCA_8822B) & \
BIT_MASK_DIS_SECONDARY_CCA_8822B)
#define BIT_SET_DIS_SECONDARY_CCA_8822B(x, v) \
(BIT_CLEAR_DIS_SECONDARY_CCA_8822B(x) | BIT_DIS_SECONDARY_CCA_8822B(v))
/* 2 REG_BCN_CTRL_CLINT1_8822B */
#define BIT_CLI1_DIS_RX_BSSID_FIT_8822B BIT(6)
#define BIT_CLI1_DIS_TSF_UDT_8822B BIT(4)
#define BIT_CLI1_EN_BCN_FUNCTION_8822B BIT(3)
#define BIT_CLI1_EN_RXBCN_RPT_8822B BIT(2)
#define BIT_CLI1_ENP2P_CTWINDOW_8822B BIT(1)
#define BIT_CLI1_ENP2P_BCNQ_AREA_8822B BIT(0)
/* 2 REG_BCN_CTRL_CLINT2_8822B */
#define BIT_CLI2_DIS_RX_BSSID_FIT_8822B BIT(6)
#define BIT_CLI2_DIS_TSF_UDT_8822B BIT(4)
#define BIT_CLI2_EN_BCN_FUNCTION_8822B BIT(3)
#define BIT_CLI2_EN_RXBCN_RPT_8822B BIT(2)
#define BIT_CLI2_ENP2P_CTWINDOW_8822B BIT(1)
#define BIT_CLI2_ENP2P_BCNQ_AREA_8822B BIT(0)
/* 2 REG_BCN_CTRL_CLINT3_8822B */
#define BIT_CLI3_DIS_RX_BSSID_FIT_8822B BIT(6)
#define BIT_CLI3_DIS_TSF_UDT_8822B BIT(4)
#define BIT_CLI3_EN_BCN_FUNCTION_8822B BIT(3)
#define BIT_CLI3_EN_RXBCN_RPT_8822B BIT(2)
#define BIT_CLI3_ENP2P_CTWINDOW_8822B BIT(1)
#define BIT_CLI3_ENP2P_BCNQ_AREA_8822B BIT(0)
/* 2 REG_EXTEND_CTRL_8822B */
#define BIT_EN_TSFBIT32_RST_P2P2_8822B BIT(5)
#define BIT_EN_TSFBIT32_RST_P2P1_8822B BIT(4)
#define BIT_SHIFT_PORT_SEL_8822B 0
#define BIT_MASK_PORT_SEL_8822B 0x7
#define BIT_PORT_SEL_8822B(x) \
(((x) & BIT_MASK_PORT_SEL_8822B) << BIT_SHIFT_PORT_SEL_8822B)
#define BITS_PORT_SEL_8822B \
(BIT_MASK_PORT_SEL_8822B << BIT_SHIFT_PORT_SEL_8822B)
#define BIT_CLEAR_PORT_SEL_8822B(x) ((x) & (~BITS_PORT_SEL_8822B))
#define BIT_GET_PORT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_PORT_SEL_8822B) & BIT_MASK_PORT_SEL_8822B)
#define BIT_SET_PORT_SEL_8822B(x, v) \
(BIT_CLEAR_PORT_SEL_8822B(x) | BIT_PORT_SEL_8822B(v))
/* 2 REG_P2PPS1_SPEC_STATE_8822B */
#define BIT_P2P1_SPEC_POWER_STATE_8822B BIT(7)
#define BIT_P2P1_SPEC_CTWINDOW_ON_8822B BIT(6)
#define BIT_P2P1_SPEC_BCN_AREA_ON_8822B BIT(5)
#define BIT_P2P1_SPEC_CTWIN_EARLY_DISTX_8822B BIT(4)
#define BIT_P2P1_SPEC_NOA1_OFF_PERIOD_8822B BIT(3)
#define BIT_P2P1_SPEC_FORCE_DOZE1_8822B BIT(2)
#define BIT_P2P1_SPEC_NOA0_OFF_PERIOD_8822B BIT(1)
#define BIT_P2P1_SPEC_FORCE_DOZE0_8822B BIT(0)
/* 2 REG_P2PPS1_STATE_8822B */
#define BIT_P2P1_POWER_STATE_8822B BIT(7)
#define BIT_P2P1_CTWINDOW_ON_8822B BIT(6)
#define BIT_P2P1_BEACON_AREA_ON_8822B BIT(5)
#define BIT_P2P1_CTWIN_EARLY_DISTX_8822B BIT(4)
#define BIT_P2P1_NOA1_OFF_PERIOD_8822B BIT(3)
#define BIT_P2P1_FORCE_DOZE1_8822B BIT(2)
#define BIT_P2P1_NOA0_OFF_PERIOD_8822B BIT(1)
#define BIT_P2P1_FORCE_DOZE0_8822B BIT(0)
/* 2 REG_P2PPS2_SPEC_STATE_8822B */
#define BIT_P2P2_SPEC_POWER_STATE_8822B BIT(7)
#define BIT_P2P2_SPEC_CTWINDOW_ON_8822B BIT(6)
#define BIT_P2P2_SPEC_BCN_AREA_ON_8822B BIT(5)
#define BIT_P2P2_SPEC_CTWIN_EARLY_DISTX_8822B BIT(4)
#define BIT_P2P2_SPEC_NOA1_OFF_PERIOD_8822B BIT(3)
#define BIT_P2P2_SPEC_FORCE_DOZE1_8822B BIT(2)
#define BIT_P2P2_SPEC_NOA0_OFF_PERIOD_8822B BIT(1)
#define BIT_P2P2_SPEC_FORCE_DOZE0_8822B BIT(0)
/* 2 REG_P2PPS2_STATE_8822B */
#define BIT_P2P2_POWER_STATE_8822B BIT(7)
#define BIT_P2P2_CTWINDOW_ON_8822B BIT(6)
#define BIT_P2P2_BEACON_AREA_ON_8822B BIT(5)
#define BIT_P2P2_CTWIN_EARLY_DISTX_8822B BIT(4)
#define BIT_P2P2_NOA1_OFF_PERIOD_8822B BIT(3)
#define BIT_P2P2_FORCE_DOZE1_8822B BIT(2)
#define BIT_P2P2_NOA0_OFF_PERIOD_8822B BIT(1)
#define BIT_P2P2_FORCE_DOZE0_8822B BIT(0)
/* 2 REG_PS_TIMER0_8822B */
#define BIT_SHIFT_PSTIMER0_INT_8822B 5
#define BIT_MASK_PSTIMER0_INT_8822B 0x7ffffff
#define BIT_PSTIMER0_INT_8822B(x) \
(((x) & BIT_MASK_PSTIMER0_INT_8822B) << BIT_SHIFT_PSTIMER0_INT_8822B)
#define BITS_PSTIMER0_INT_8822B \
(BIT_MASK_PSTIMER0_INT_8822B << BIT_SHIFT_PSTIMER0_INT_8822B)
#define BIT_CLEAR_PSTIMER0_INT_8822B(x) ((x) & (~BITS_PSTIMER0_INT_8822B))
#define BIT_GET_PSTIMER0_INT_8822B(x) \
(((x) >> BIT_SHIFT_PSTIMER0_INT_8822B) & BIT_MASK_PSTIMER0_INT_8822B)
#define BIT_SET_PSTIMER0_INT_8822B(x, v) \
(BIT_CLEAR_PSTIMER0_INT_8822B(x) | BIT_PSTIMER0_INT_8822B(v))
/* 2 REG_PS_TIMER1_8822B */
#define BIT_SHIFT_PSTIMER1_INT_8822B 5
#define BIT_MASK_PSTIMER1_INT_8822B 0x7ffffff
#define BIT_PSTIMER1_INT_8822B(x) \
(((x) & BIT_MASK_PSTIMER1_INT_8822B) << BIT_SHIFT_PSTIMER1_INT_8822B)
#define BITS_PSTIMER1_INT_8822B \
(BIT_MASK_PSTIMER1_INT_8822B << BIT_SHIFT_PSTIMER1_INT_8822B)
#define BIT_CLEAR_PSTIMER1_INT_8822B(x) ((x) & (~BITS_PSTIMER1_INT_8822B))
#define BIT_GET_PSTIMER1_INT_8822B(x) \
(((x) >> BIT_SHIFT_PSTIMER1_INT_8822B) & BIT_MASK_PSTIMER1_INT_8822B)
#define BIT_SET_PSTIMER1_INT_8822B(x, v) \
(BIT_CLEAR_PSTIMER1_INT_8822B(x) | BIT_PSTIMER1_INT_8822B(v))
/* 2 REG_PS_TIMER2_8822B */
#define BIT_SHIFT_PSTIMER2_INT_8822B 5
#define BIT_MASK_PSTIMER2_INT_8822B 0x7ffffff
#define BIT_PSTIMER2_INT_8822B(x) \
(((x) & BIT_MASK_PSTIMER2_INT_8822B) << BIT_SHIFT_PSTIMER2_INT_8822B)
#define BITS_PSTIMER2_INT_8822B \
(BIT_MASK_PSTIMER2_INT_8822B << BIT_SHIFT_PSTIMER2_INT_8822B)
#define BIT_CLEAR_PSTIMER2_INT_8822B(x) ((x) & (~BITS_PSTIMER2_INT_8822B))
#define BIT_GET_PSTIMER2_INT_8822B(x) \
(((x) >> BIT_SHIFT_PSTIMER2_INT_8822B) & BIT_MASK_PSTIMER2_INT_8822B)
#define BIT_SET_PSTIMER2_INT_8822B(x, v) \
(BIT_CLEAR_PSTIMER2_INT_8822B(x) | BIT_PSTIMER2_INT_8822B(v))
/* 2 REG_TBTT_CTN_AREA_8822B */
#define BIT_SHIFT_TBTT_CTN_AREA_8822B 0
#define BIT_MASK_TBTT_CTN_AREA_8822B 0xff
#define BIT_TBTT_CTN_AREA_8822B(x) \
(((x) & BIT_MASK_TBTT_CTN_AREA_8822B) << BIT_SHIFT_TBTT_CTN_AREA_8822B)
#define BITS_TBTT_CTN_AREA_8822B \
(BIT_MASK_TBTT_CTN_AREA_8822B << BIT_SHIFT_TBTT_CTN_AREA_8822B)
#define BIT_CLEAR_TBTT_CTN_AREA_8822B(x) ((x) & (~BITS_TBTT_CTN_AREA_8822B))
#define BIT_GET_TBTT_CTN_AREA_8822B(x) \
(((x) >> BIT_SHIFT_TBTT_CTN_AREA_8822B) & BIT_MASK_TBTT_CTN_AREA_8822B)
#define BIT_SET_TBTT_CTN_AREA_8822B(x, v) \
(BIT_CLEAR_TBTT_CTN_AREA_8822B(x) | BIT_TBTT_CTN_AREA_8822B(v))
/* 2 REG_FORCE_BCN_IFS_8822B */
#define BIT_SHIFT_FORCE_BCN_IFS_8822B 0
#define BIT_MASK_FORCE_BCN_IFS_8822B 0xff
#define BIT_FORCE_BCN_IFS_8822B(x) \
(((x) & BIT_MASK_FORCE_BCN_IFS_8822B) << BIT_SHIFT_FORCE_BCN_IFS_8822B)
#define BITS_FORCE_BCN_IFS_8822B \
(BIT_MASK_FORCE_BCN_IFS_8822B << BIT_SHIFT_FORCE_BCN_IFS_8822B)
#define BIT_CLEAR_FORCE_BCN_IFS_8822B(x) ((x) & (~BITS_FORCE_BCN_IFS_8822B))
#define BIT_GET_FORCE_BCN_IFS_8822B(x) \
(((x) >> BIT_SHIFT_FORCE_BCN_IFS_8822B) & BIT_MASK_FORCE_BCN_IFS_8822B)
#define BIT_SET_FORCE_BCN_IFS_8822B(x, v) \
(BIT_CLEAR_FORCE_BCN_IFS_8822B(x) | BIT_FORCE_BCN_IFS_8822B(v))
/* 2 REG_TXOP_MIN_8822B */
#define BIT_SHIFT_TXOP_MIN_8822B 0
#define BIT_MASK_TXOP_MIN_8822B 0x3fff
#define BIT_TXOP_MIN_8822B(x) \
(((x) & BIT_MASK_TXOP_MIN_8822B) << BIT_SHIFT_TXOP_MIN_8822B)
#define BITS_TXOP_MIN_8822B \
(BIT_MASK_TXOP_MIN_8822B << BIT_SHIFT_TXOP_MIN_8822B)
#define BIT_CLEAR_TXOP_MIN_8822B(x) ((x) & (~BITS_TXOP_MIN_8822B))
#define BIT_GET_TXOP_MIN_8822B(x) \
(((x) >> BIT_SHIFT_TXOP_MIN_8822B) & BIT_MASK_TXOP_MIN_8822B)
#define BIT_SET_TXOP_MIN_8822B(x, v) \
(BIT_CLEAR_TXOP_MIN_8822B(x) | BIT_TXOP_MIN_8822B(v))
/* 2 REG_PRE_BKF_TIME_8822B */
#define BIT_SHIFT_PRE_BKF_TIME_8822B 0
#define BIT_MASK_PRE_BKF_TIME_8822B 0xff
#define BIT_PRE_BKF_TIME_8822B(x) \
(((x) & BIT_MASK_PRE_BKF_TIME_8822B) << BIT_SHIFT_PRE_BKF_TIME_8822B)
#define BITS_PRE_BKF_TIME_8822B \
(BIT_MASK_PRE_BKF_TIME_8822B << BIT_SHIFT_PRE_BKF_TIME_8822B)
#define BIT_CLEAR_PRE_BKF_TIME_8822B(x) ((x) & (~BITS_PRE_BKF_TIME_8822B))
#define BIT_GET_PRE_BKF_TIME_8822B(x) \
(((x) >> BIT_SHIFT_PRE_BKF_TIME_8822B) & BIT_MASK_PRE_BKF_TIME_8822B)
#define BIT_SET_PRE_BKF_TIME_8822B(x, v) \
(BIT_CLEAR_PRE_BKF_TIME_8822B(x) | BIT_PRE_BKF_TIME_8822B(v))
/* 2 REG_CROSS_TXOP_CTRL_8822B */
#define BIT_DTIM_BYPASS_8822B BIT(2)
#define BIT_RTS_NAV_TXOP_8822B BIT(1)
#define BIT_NOT_CROSS_TXOP_8822B BIT(0)
/* 2 REG_ATIMWND2_8822B */
#define BIT_SHIFT_ATIMWND2_8822B 0
#define BIT_MASK_ATIMWND2_8822B 0xff
#define BIT_ATIMWND2_8822B(x) \
(((x) & BIT_MASK_ATIMWND2_8822B) << BIT_SHIFT_ATIMWND2_8822B)
#define BITS_ATIMWND2_8822B \
(BIT_MASK_ATIMWND2_8822B << BIT_SHIFT_ATIMWND2_8822B)
#define BIT_CLEAR_ATIMWND2_8822B(x) ((x) & (~BITS_ATIMWND2_8822B))
#define BIT_GET_ATIMWND2_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND2_8822B) & BIT_MASK_ATIMWND2_8822B)
#define BIT_SET_ATIMWND2_8822B(x, v) \
(BIT_CLEAR_ATIMWND2_8822B(x) | BIT_ATIMWND2_8822B(v))
/* 2 REG_ATIMWND3_8822B */
#define BIT_SHIFT_ATIMWND3_8822B 0
#define BIT_MASK_ATIMWND3_8822B 0xff
#define BIT_ATIMWND3_8822B(x) \
(((x) & BIT_MASK_ATIMWND3_8822B) << BIT_SHIFT_ATIMWND3_8822B)
#define BITS_ATIMWND3_8822B \
(BIT_MASK_ATIMWND3_8822B << BIT_SHIFT_ATIMWND3_8822B)
#define BIT_CLEAR_ATIMWND3_8822B(x) ((x) & (~BITS_ATIMWND3_8822B))
#define BIT_GET_ATIMWND3_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND3_8822B) & BIT_MASK_ATIMWND3_8822B)
#define BIT_SET_ATIMWND3_8822B(x, v) \
(BIT_CLEAR_ATIMWND3_8822B(x) | BIT_ATIMWND3_8822B(v))
/* 2 REG_ATIMWND4_8822B */
#define BIT_SHIFT_ATIMWND4_8822B 0
#define BIT_MASK_ATIMWND4_8822B 0xff
#define BIT_ATIMWND4_8822B(x) \
(((x) & BIT_MASK_ATIMWND4_8822B) << BIT_SHIFT_ATIMWND4_8822B)
#define BITS_ATIMWND4_8822B \
(BIT_MASK_ATIMWND4_8822B << BIT_SHIFT_ATIMWND4_8822B)
#define BIT_CLEAR_ATIMWND4_8822B(x) ((x) & (~BITS_ATIMWND4_8822B))
#define BIT_GET_ATIMWND4_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND4_8822B) & BIT_MASK_ATIMWND4_8822B)
#define BIT_SET_ATIMWND4_8822B(x, v) \
(BIT_CLEAR_ATIMWND4_8822B(x) | BIT_ATIMWND4_8822B(v))
/* 2 REG_ATIMWND5_8822B */
#define BIT_SHIFT_ATIMWND5_8822B 0
#define BIT_MASK_ATIMWND5_8822B 0xff
#define BIT_ATIMWND5_8822B(x) \
(((x) & BIT_MASK_ATIMWND5_8822B) << BIT_SHIFT_ATIMWND5_8822B)
#define BITS_ATIMWND5_8822B \
(BIT_MASK_ATIMWND5_8822B << BIT_SHIFT_ATIMWND5_8822B)
#define BIT_CLEAR_ATIMWND5_8822B(x) ((x) & (~BITS_ATIMWND5_8822B))
#define BIT_GET_ATIMWND5_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND5_8822B) & BIT_MASK_ATIMWND5_8822B)
#define BIT_SET_ATIMWND5_8822B(x, v) \
(BIT_CLEAR_ATIMWND5_8822B(x) | BIT_ATIMWND5_8822B(v))
/* 2 REG_ATIMWND6_8822B */
#define BIT_SHIFT_ATIMWND6_8822B 0
#define BIT_MASK_ATIMWND6_8822B 0xff
#define BIT_ATIMWND6_8822B(x) \
(((x) & BIT_MASK_ATIMWND6_8822B) << BIT_SHIFT_ATIMWND6_8822B)
#define BITS_ATIMWND6_8822B \
(BIT_MASK_ATIMWND6_8822B << BIT_SHIFT_ATIMWND6_8822B)
#define BIT_CLEAR_ATIMWND6_8822B(x) ((x) & (~BITS_ATIMWND6_8822B))
#define BIT_GET_ATIMWND6_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND6_8822B) & BIT_MASK_ATIMWND6_8822B)
#define BIT_SET_ATIMWND6_8822B(x, v) \
(BIT_CLEAR_ATIMWND6_8822B(x) | BIT_ATIMWND6_8822B(v))
/* 2 REG_ATIMWND7_8822B */
#define BIT_SHIFT_ATIMWND7_8822B 0
#define BIT_MASK_ATIMWND7_8822B 0xff
#define BIT_ATIMWND7_8822B(x) \
(((x) & BIT_MASK_ATIMWND7_8822B) << BIT_SHIFT_ATIMWND7_8822B)
#define BITS_ATIMWND7_8822B \
(BIT_MASK_ATIMWND7_8822B << BIT_SHIFT_ATIMWND7_8822B)
#define BIT_CLEAR_ATIMWND7_8822B(x) ((x) & (~BITS_ATIMWND7_8822B))
#define BIT_GET_ATIMWND7_8822B(x) \
(((x) >> BIT_SHIFT_ATIMWND7_8822B) & BIT_MASK_ATIMWND7_8822B)
#define BIT_SET_ATIMWND7_8822B(x, v) \
(BIT_CLEAR_ATIMWND7_8822B(x) | BIT_ATIMWND7_8822B(v))
/* 2 REG_ATIMUGT_8822B */
#define BIT_SHIFT_ATIM_URGENT_8822B 0
#define BIT_MASK_ATIM_URGENT_8822B 0xff
#define BIT_ATIM_URGENT_8822B(x) \
(((x) & BIT_MASK_ATIM_URGENT_8822B) << BIT_SHIFT_ATIM_URGENT_8822B)
#define BITS_ATIM_URGENT_8822B \
(BIT_MASK_ATIM_URGENT_8822B << BIT_SHIFT_ATIM_URGENT_8822B)
#define BIT_CLEAR_ATIM_URGENT_8822B(x) ((x) & (~BITS_ATIM_URGENT_8822B))
#define BIT_GET_ATIM_URGENT_8822B(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT_8822B) & BIT_MASK_ATIM_URGENT_8822B)
#define BIT_SET_ATIM_URGENT_8822B(x, v) \
(BIT_CLEAR_ATIM_URGENT_8822B(x) | BIT_ATIM_URGENT_8822B(v))
/* 2 REG_HIQ_NO_LMT_EN_8822B */
#define BIT_HIQ_NO_LMT_EN_VAP7_8822B BIT(7)
#define BIT_HIQ_NO_LMT_EN_VAP6_8822B BIT(6)
#define BIT_HIQ_NO_LMT_EN_VAP5_8822B BIT(5)
#define BIT_HIQ_NO_LMT_EN_VAP4_8822B BIT(4)
#define BIT_HIQ_NO_LMT_EN_VAP3_8822B BIT(3)
#define BIT_HIQ_NO_LMT_EN_VAP2_8822B BIT(2)
#define BIT_HIQ_NO_LMT_EN_VAP1_8822B BIT(1)
#define BIT_HIQ_NO_LMT_EN_ROOT_8822B BIT(0)
/* 2 REG_DTIM_COUNTER_ROOT_8822B */
#define BIT_SHIFT_DTIM_COUNT_ROOT_8822B 0
#define BIT_MASK_DTIM_COUNT_ROOT_8822B 0xff
#define BIT_DTIM_COUNT_ROOT_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_ROOT_8822B) \
<< BIT_SHIFT_DTIM_COUNT_ROOT_8822B)
#define BITS_DTIM_COUNT_ROOT_8822B \
(BIT_MASK_DTIM_COUNT_ROOT_8822B << BIT_SHIFT_DTIM_COUNT_ROOT_8822B)
#define BIT_CLEAR_DTIM_COUNT_ROOT_8822B(x) ((x) & (~BITS_DTIM_COUNT_ROOT_8822B))
#define BIT_GET_DTIM_COUNT_ROOT_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_ROOT_8822B) & \
BIT_MASK_DTIM_COUNT_ROOT_8822B)
#define BIT_SET_DTIM_COUNT_ROOT_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_ROOT_8822B(x) | BIT_DTIM_COUNT_ROOT_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP1_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP1_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP1_8822B 0xff
#define BIT_DTIM_COUNT_VAP1_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP1_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP1_8822B)
#define BITS_DTIM_COUNT_VAP1_8822B \
(BIT_MASK_DTIM_COUNT_VAP1_8822B << BIT_SHIFT_DTIM_COUNT_VAP1_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP1_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP1_8822B))
#define BIT_GET_DTIM_COUNT_VAP1_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP1_8822B) & \
BIT_MASK_DTIM_COUNT_VAP1_8822B)
#define BIT_SET_DTIM_COUNT_VAP1_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP1_8822B(x) | BIT_DTIM_COUNT_VAP1_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP2_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP2_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP2_8822B 0xff
#define BIT_DTIM_COUNT_VAP2_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP2_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP2_8822B)
#define BITS_DTIM_COUNT_VAP2_8822B \
(BIT_MASK_DTIM_COUNT_VAP2_8822B << BIT_SHIFT_DTIM_COUNT_VAP2_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP2_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP2_8822B))
#define BIT_GET_DTIM_COUNT_VAP2_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP2_8822B) & \
BIT_MASK_DTIM_COUNT_VAP2_8822B)
#define BIT_SET_DTIM_COUNT_VAP2_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP2_8822B(x) | BIT_DTIM_COUNT_VAP2_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP3_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP3_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP3_8822B 0xff
#define BIT_DTIM_COUNT_VAP3_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP3_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP3_8822B)
#define BITS_DTIM_COUNT_VAP3_8822B \
(BIT_MASK_DTIM_COUNT_VAP3_8822B << BIT_SHIFT_DTIM_COUNT_VAP3_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP3_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP3_8822B))
#define BIT_GET_DTIM_COUNT_VAP3_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP3_8822B) & \
BIT_MASK_DTIM_COUNT_VAP3_8822B)
#define BIT_SET_DTIM_COUNT_VAP3_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP3_8822B(x) | BIT_DTIM_COUNT_VAP3_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP4_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP4_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP4_8822B 0xff
#define BIT_DTIM_COUNT_VAP4_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP4_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP4_8822B)
#define BITS_DTIM_COUNT_VAP4_8822B \
(BIT_MASK_DTIM_COUNT_VAP4_8822B << BIT_SHIFT_DTIM_COUNT_VAP4_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP4_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP4_8822B))
#define BIT_GET_DTIM_COUNT_VAP4_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP4_8822B) & \
BIT_MASK_DTIM_COUNT_VAP4_8822B)
#define BIT_SET_DTIM_COUNT_VAP4_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP4_8822B(x) | BIT_DTIM_COUNT_VAP4_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP5_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP5_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP5_8822B 0xff
#define BIT_DTIM_COUNT_VAP5_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP5_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP5_8822B)
#define BITS_DTIM_COUNT_VAP5_8822B \
(BIT_MASK_DTIM_COUNT_VAP5_8822B << BIT_SHIFT_DTIM_COUNT_VAP5_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP5_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP5_8822B))
#define BIT_GET_DTIM_COUNT_VAP5_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP5_8822B) & \
BIT_MASK_DTIM_COUNT_VAP5_8822B)
#define BIT_SET_DTIM_COUNT_VAP5_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP5_8822B(x) | BIT_DTIM_COUNT_VAP5_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP6_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP6_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP6_8822B 0xff
#define BIT_DTIM_COUNT_VAP6_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP6_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP6_8822B)
#define BITS_DTIM_COUNT_VAP6_8822B \
(BIT_MASK_DTIM_COUNT_VAP6_8822B << BIT_SHIFT_DTIM_COUNT_VAP6_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP6_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP6_8822B))
#define BIT_GET_DTIM_COUNT_VAP6_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP6_8822B) & \
BIT_MASK_DTIM_COUNT_VAP6_8822B)
#define BIT_SET_DTIM_COUNT_VAP6_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP6_8822B(x) | BIT_DTIM_COUNT_VAP6_8822B(v))
/* 2 REG_DTIM_COUNTER_VAP7_8822B */
#define BIT_SHIFT_DTIM_COUNT_VAP7_8822B 0
#define BIT_MASK_DTIM_COUNT_VAP7_8822B 0xff
#define BIT_DTIM_COUNT_VAP7_8822B(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP7_8822B) \
<< BIT_SHIFT_DTIM_COUNT_VAP7_8822B)
#define BITS_DTIM_COUNT_VAP7_8822B \
(BIT_MASK_DTIM_COUNT_VAP7_8822B << BIT_SHIFT_DTIM_COUNT_VAP7_8822B)
#define BIT_CLEAR_DTIM_COUNT_VAP7_8822B(x) ((x) & (~BITS_DTIM_COUNT_VAP7_8822B))
#define BIT_GET_DTIM_COUNT_VAP7_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP7_8822B) & \
BIT_MASK_DTIM_COUNT_VAP7_8822B)
#define BIT_SET_DTIM_COUNT_VAP7_8822B(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP7_8822B(x) | BIT_DTIM_COUNT_VAP7_8822B(v))
/* 2 REG_DIS_ATIM_8822B */
#define BIT_DIS_ATIM_VAP7_8822B BIT(7)
#define BIT_DIS_ATIM_VAP6_8822B BIT(6)
#define BIT_DIS_ATIM_VAP5_8822B BIT(5)
#define BIT_DIS_ATIM_VAP4_8822B BIT(4)
#define BIT_DIS_ATIM_VAP3_8822B BIT(3)
#define BIT_DIS_ATIM_VAP2_8822B BIT(2)
#define BIT_DIS_ATIM_VAP1_8822B BIT(1)
#define BIT_DIS_ATIM_ROOT_8822B BIT(0)
/* 2 REG_EARLY_128US_8822B */
#define BIT_SHIFT_TSFT_SEL_TIMER1_8822B 3
#define BIT_MASK_TSFT_SEL_TIMER1_8822B 0x7
#define BIT_TSFT_SEL_TIMER1_8822B(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER1_8822B) \
<< BIT_SHIFT_TSFT_SEL_TIMER1_8822B)
#define BITS_TSFT_SEL_TIMER1_8822B \
(BIT_MASK_TSFT_SEL_TIMER1_8822B << BIT_SHIFT_TSFT_SEL_TIMER1_8822B)
#define BIT_CLEAR_TSFT_SEL_TIMER1_8822B(x) ((x) & (~BITS_TSFT_SEL_TIMER1_8822B))
#define BIT_GET_TSFT_SEL_TIMER1_8822B(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER1_8822B) & \
BIT_MASK_TSFT_SEL_TIMER1_8822B)
#define BIT_SET_TSFT_SEL_TIMER1_8822B(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER1_8822B(x) | BIT_TSFT_SEL_TIMER1_8822B(v))
#define BIT_SHIFT_EARLY_128US_8822B 0
#define BIT_MASK_EARLY_128US_8822B 0x7
#define BIT_EARLY_128US_8822B(x) \
(((x) & BIT_MASK_EARLY_128US_8822B) << BIT_SHIFT_EARLY_128US_8822B)
#define BITS_EARLY_128US_8822B \
(BIT_MASK_EARLY_128US_8822B << BIT_SHIFT_EARLY_128US_8822B)
#define BIT_CLEAR_EARLY_128US_8822B(x) ((x) & (~BITS_EARLY_128US_8822B))
#define BIT_GET_EARLY_128US_8822B(x) \
(((x) >> BIT_SHIFT_EARLY_128US_8822B) & BIT_MASK_EARLY_128US_8822B)
#define BIT_SET_EARLY_128US_8822B(x, v) \
(BIT_CLEAR_EARLY_128US_8822B(x) | BIT_EARLY_128US_8822B(v))
/* 2 REG_P2PPS1_CTRL_8822B */
#define BIT_P2P1_CTW_ALLSTASLEEP_8822B BIT(7)
#define BIT_P2P1_OFF_DISTX_EN_8822B BIT(6)
#define BIT_P2P1_PWR_MGT_EN_8822B BIT(5)
#define BIT_P2P1_NOA1_EN_8822B BIT(2)
#define BIT_P2P1_NOA0_EN_8822B BIT(1)
/* 2 REG_P2PPS2_CTRL_8822B */
#define BIT_P2P2_CTW_ALLSTASLEEP_8822B BIT(7)
#define BIT_P2P2_OFF_DISTX_EN_8822B BIT(6)
#define BIT_P2P2_PWR_MGT_EN_8822B BIT(5)
#define BIT_P2P2_NOA1_EN_8822B BIT(2)
#define BIT_P2P2_NOA0_EN_8822B BIT(1)
/* 2 REG_TIMER0_SRC_SEL_8822B */
#define BIT_SHIFT_SYNC_CLI_SEL_8822B 4
#define BIT_MASK_SYNC_CLI_SEL_8822B 0x7
#define BIT_SYNC_CLI_SEL_8822B(x) \
(((x) & BIT_MASK_SYNC_CLI_SEL_8822B) << BIT_SHIFT_SYNC_CLI_SEL_8822B)
#define BITS_SYNC_CLI_SEL_8822B \
(BIT_MASK_SYNC_CLI_SEL_8822B << BIT_SHIFT_SYNC_CLI_SEL_8822B)
#define BIT_CLEAR_SYNC_CLI_SEL_8822B(x) ((x) & (~BITS_SYNC_CLI_SEL_8822B))
#define BIT_GET_SYNC_CLI_SEL_8822B(x) \
(((x) >> BIT_SHIFT_SYNC_CLI_SEL_8822B) & BIT_MASK_SYNC_CLI_SEL_8822B)
#define BIT_SET_SYNC_CLI_SEL_8822B(x, v) \
(BIT_CLEAR_SYNC_CLI_SEL_8822B(x) | BIT_SYNC_CLI_SEL_8822B(v))
#define BIT_SHIFT_TSFT_SEL_TIMER0_8822B 0
#define BIT_MASK_TSFT_SEL_TIMER0_8822B 0x7
#define BIT_TSFT_SEL_TIMER0_8822B(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER0_8822B) \
<< BIT_SHIFT_TSFT_SEL_TIMER0_8822B)
#define BITS_TSFT_SEL_TIMER0_8822B \
(BIT_MASK_TSFT_SEL_TIMER0_8822B << BIT_SHIFT_TSFT_SEL_TIMER0_8822B)
#define BIT_CLEAR_TSFT_SEL_TIMER0_8822B(x) ((x) & (~BITS_TSFT_SEL_TIMER0_8822B))
#define BIT_GET_TSFT_SEL_TIMER0_8822B(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER0_8822B) & \
BIT_MASK_TSFT_SEL_TIMER0_8822B)
#define BIT_SET_TSFT_SEL_TIMER0_8822B(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER0_8822B(x) | BIT_TSFT_SEL_TIMER0_8822B(v))
/* 2 REG_NOA_UNIT_SEL_8822B */
#define BIT_SHIFT_NOA_UNIT2_SEL_8822B 8
#define BIT_MASK_NOA_UNIT2_SEL_8822B 0x7
#define BIT_NOA_UNIT2_SEL_8822B(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL_8822B) << BIT_SHIFT_NOA_UNIT2_SEL_8822B)
#define BITS_NOA_UNIT2_SEL_8822B \
(BIT_MASK_NOA_UNIT2_SEL_8822B << BIT_SHIFT_NOA_UNIT2_SEL_8822B)
#define BIT_CLEAR_NOA_UNIT2_SEL_8822B(x) ((x) & (~BITS_NOA_UNIT2_SEL_8822B))
#define BIT_GET_NOA_UNIT2_SEL_8822B(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL_8822B) & BIT_MASK_NOA_UNIT2_SEL_8822B)
#define BIT_SET_NOA_UNIT2_SEL_8822B(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL_8822B(x) | BIT_NOA_UNIT2_SEL_8822B(v))
#define BIT_SHIFT_NOA_UNIT1_SEL_8822B 4
#define BIT_MASK_NOA_UNIT1_SEL_8822B 0x7
#define BIT_NOA_UNIT1_SEL_8822B(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL_8822B) << BIT_SHIFT_NOA_UNIT1_SEL_8822B)
#define BITS_NOA_UNIT1_SEL_8822B \
(BIT_MASK_NOA_UNIT1_SEL_8822B << BIT_SHIFT_NOA_UNIT1_SEL_8822B)
#define BIT_CLEAR_NOA_UNIT1_SEL_8822B(x) ((x) & (~BITS_NOA_UNIT1_SEL_8822B))
#define BIT_GET_NOA_UNIT1_SEL_8822B(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL_8822B) & BIT_MASK_NOA_UNIT1_SEL_8822B)
#define BIT_SET_NOA_UNIT1_SEL_8822B(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL_8822B(x) | BIT_NOA_UNIT1_SEL_8822B(v))
#define BIT_SHIFT_NOA_UNIT0_SEL_8822B 0
#define BIT_MASK_NOA_UNIT0_SEL_8822B 0x7
#define BIT_NOA_UNIT0_SEL_8822B(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL_8822B) << BIT_SHIFT_NOA_UNIT0_SEL_8822B)
#define BITS_NOA_UNIT0_SEL_8822B \
(BIT_MASK_NOA_UNIT0_SEL_8822B << BIT_SHIFT_NOA_UNIT0_SEL_8822B)
#define BIT_CLEAR_NOA_UNIT0_SEL_8822B(x) ((x) & (~BITS_NOA_UNIT0_SEL_8822B))
#define BIT_GET_NOA_UNIT0_SEL_8822B(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL_8822B) & BIT_MASK_NOA_UNIT0_SEL_8822B)
#define BIT_SET_NOA_UNIT0_SEL_8822B(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL_8822B(x) | BIT_NOA_UNIT0_SEL_8822B(v))
/* 2 REG_P2POFF_DIS_TXTIME_8822B */
#define BIT_SHIFT_P2POFF_DIS_TXTIME_8822B 0
#define BIT_MASK_P2POFF_DIS_TXTIME_8822B 0xff
#define BIT_P2POFF_DIS_TXTIME_8822B(x) \
(((x) & BIT_MASK_P2POFF_DIS_TXTIME_8822B) \
<< BIT_SHIFT_P2POFF_DIS_TXTIME_8822B)
#define BITS_P2POFF_DIS_TXTIME_8822B \
(BIT_MASK_P2POFF_DIS_TXTIME_8822B << BIT_SHIFT_P2POFF_DIS_TXTIME_8822B)
#define BIT_CLEAR_P2POFF_DIS_TXTIME_8822B(x) \
((x) & (~BITS_P2POFF_DIS_TXTIME_8822B))
#define BIT_GET_P2POFF_DIS_TXTIME_8822B(x) \
(((x) >> BIT_SHIFT_P2POFF_DIS_TXTIME_8822B) & \
BIT_MASK_P2POFF_DIS_TXTIME_8822B)
#define BIT_SET_P2POFF_DIS_TXTIME_8822B(x, v) \
(BIT_CLEAR_P2POFF_DIS_TXTIME_8822B(x) | BIT_P2POFF_DIS_TXTIME_8822B(v))
/* 2 REG_MBSSID_BCN_SPACE2_8822B */
#define BIT_SHIFT_BCN_SPACE_CLINT2_8822B 16
#define BIT_MASK_BCN_SPACE_CLINT2_8822B 0xfff
#define BIT_BCN_SPACE_CLINT2_8822B(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT2_8822B) \
<< BIT_SHIFT_BCN_SPACE_CLINT2_8822B)
#define BITS_BCN_SPACE_CLINT2_8822B \
(BIT_MASK_BCN_SPACE_CLINT2_8822B << BIT_SHIFT_BCN_SPACE_CLINT2_8822B)
#define BIT_CLEAR_BCN_SPACE_CLINT2_8822B(x) \
((x) & (~BITS_BCN_SPACE_CLINT2_8822B))
#define BIT_GET_BCN_SPACE_CLINT2_8822B(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT2_8822B) & \
BIT_MASK_BCN_SPACE_CLINT2_8822B)
#define BIT_SET_BCN_SPACE_CLINT2_8822B(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT2_8822B(x) | BIT_BCN_SPACE_CLINT2_8822B(v))
#define BIT_SHIFT_BCN_SPACE_CLINT1_8822B 0
#define BIT_MASK_BCN_SPACE_CLINT1_8822B 0xfff
#define BIT_BCN_SPACE_CLINT1_8822B(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT1_8822B) \
<< BIT_SHIFT_BCN_SPACE_CLINT1_8822B)
#define BITS_BCN_SPACE_CLINT1_8822B \
(BIT_MASK_BCN_SPACE_CLINT1_8822B << BIT_SHIFT_BCN_SPACE_CLINT1_8822B)
#define BIT_CLEAR_BCN_SPACE_CLINT1_8822B(x) \
((x) & (~BITS_BCN_SPACE_CLINT1_8822B))
#define BIT_GET_BCN_SPACE_CLINT1_8822B(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT1_8822B) & \
BIT_MASK_BCN_SPACE_CLINT1_8822B)
#define BIT_SET_BCN_SPACE_CLINT1_8822B(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT1_8822B(x) | BIT_BCN_SPACE_CLINT1_8822B(v))
/* 2 REG_MBSSID_BCN_SPACE3_8822B */
#define BIT_SHIFT_SUB_BCN_SPACE_8822B 16
#define BIT_MASK_SUB_BCN_SPACE_8822B 0xff
#define BIT_SUB_BCN_SPACE_8822B(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE_8822B) << BIT_SHIFT_SUB_BCN_SPACE_8822B)
#define BITS_SUB_BCN_SPACE_8822B \
(BIT_MASK_SUB_BCN_SPACE_8822B << BIT_SHIFT_SUB_BCN_SPACE_8822B)
#define BIT_CLEAR_SUB_BCN_SPACE_8822B(x) ((x) & (~BITS_SUB_BCN_SPACE_8822B))
#define BIT_GET_SUB_BCN_SPACE_8822B(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE_8822B) & BIT_MASK_SUB_BCN_SPACE_8822B)
#define BIT_SET_SUB_BCN_SPACE_8822B(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE_8822B(x) | BIT_SUB_BCN_SPACE_8822B(v))
#define BIT_SHIFT_BCN_SPACE_CLINT3_8822B 0
#define BIT_MASK_BCN_SPACE_CLINT3_8822B 0xfff
#define BIT_BCN_SPACE_CLINT3_8822B(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT3_8822B) \
<< BIT_SHIFT_BCN_SPACE_CLINT3_8822B)
#define BITS_BCN_SPACE_CLINT3_8822B \
(BIT_MASK_BCN_SPACE_CLINT3_8822B << BIT_SHIFT_BCN_SPACE_CLINT3_8822B)
#define BIT_CLEAR_BCN_SPACE_CLINT3_8822B(x) \
((x) & (~BITS_BCN_SPACE_CLINT3_8822B))
#define BIT_GET_BCN_SPACE_CLINT3_8822B(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT3_8822B) & \
BIT_MASK_BCN_SPACE_CLINT3_8822B)
#define BIT_SET_BCN_SPACE_CLINT3_8822B(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT3_8822B(x) | BIT_BCN_SPACE_CLINT3_8822B(v))
/* 2 REG_ACMHWCTRL_8822B */
#define BIT_BEQ_ACM_STATUS_8822B BIT(7)
#define BIT_VIQ_ACM_STATUS_8822B BIT(6)
#define BIT_VOQ_ACM_STATUS_8822B BIT(5)
#define BIT_BEQ_ACM_EN_8822B BIT(3)
#define BIT_VIQ_ACM_EN_8822B BIT(2)
#define BIT_VOQ_ACM_EN_8822B BIT(1)
#define BIT_ACMHWEN_8822B BIT(0)
/* 2 REG_ACMRSTCTRL_8822B */
#define BIT_BE_ACM_RESET_USED_TIME_8822B BIT(2)
#define BIT_VI_ACM_RESET_USED_TIME_8822B BIT(1)
#define BIT_VO_ACM_RESET_USED_TIME_8822B BIT(0)
/* 2 REG_ACMAVG_8822B */
#define BIT_SHIFT_AVGPERIOD_8822B 0
#define BIT_MASK_AVGPERIOD_8822B 0xffff
#define BIT_AVGPERIOD_8822B(x) \
(((x) & BIT_MASK_AVGPERIOD_8822B) << BIT_SHIFT_AVGPERIOD_8822B)
#define BITS_AVGPERIOD_8822B \
(BIT_MASK_AVGPERIOD_8822B << BIT_SHIFT_AVGPERIOD_8822B)
#define BIT_CLEAR_AVGPERIOD_8822B(x) ((x) & (~BITS_AVGPERIOD_8822B))
#define BIT_GET_AVGPERIOD_8822B(x) \
(((x) >> BIT_SHIFT_AVGPERIOD_8822B) & BIT_MASK_AVGPERIOD_8822B)
#define BIT_SET_AVGPERIOD_8822B(x, v) \
(BIT_CLEAR_AVGPERIOD_8822B(x) | BIT_AVGPERIOD_8822B(v))
/* 2 REG_VO_ADMTIME_8822B */
#define BIT_SHIFT_VO_ADMITTED_TIME_8822B 0
#define BIT_MASK_VO_ADMITTED_TIME_8822B 0xffff
#define BIT_VO_ADMITTED_TIME_8822B(x) \
(((x) & BIT_MASK_VO_ADMITTED_TIME_8822B) \
<< BIT_SHIFT_VO_ADMITTED_TIME_8822B)
#define BITS_VO_ADMITTED_TIME_8822B \
(BIT_MASK_VO_ADMITTED_TIME_8822B << BIT_SHIFT_VO_ADMITTED_TIME_8822B)
#define BIT_CLEAR_VO_ADMITTED_TIME_8822B(x) \
((x) & (~BITS_VO_ADMITTED_TIME_8822B))
#define BIT_GET_VO_ADMITTED_TIME_8822B(x) \
(((x) >> BIT_SHIFT_VO_ADMITTED_TIME_8822B) & \
BIT_MASK_VO_ADMITTED_TIME_8822B)
#define BIT_SET_VO_ADMITTED_TIME_8822B(x, v) \
(BIT_CLEAR_VO_ADMITTED_TIME_8822B(x) | BIT_VO_ADMITTED_TIME_8822B(v))
/* 2 REG_VI_ADMTIME_8822B */
#define BIT_SHIFT_VI_ADMITTED_TIME_8822B 0
#define BIT_MASK_VI_ADMITTED_TIME_8822B 0xffff
#define BIT_VI_ADMITTED_TIME_8822B(x) \
(((x) & BIT_MASK_VI_ADMITTED_TIME_8822B) \
<< BIT_SHIFT_VI_ADMITTED_TIME_8822B)
#define BITS_VI_ADMITTED_TIME_8822B \
(BIT_MASK_VI_ADMITTED_TIME_8822B << BIT_SHIFT_VI_ADMITTED_TIME_8822B)
#define BIT_CLEAR_VI_ADMITTED_TIME_8822B(x) \
((x) & (~BITS_VI_ADMITTED_TIME_8822B))
#define BIT_GET_VI_ADMITTED_TIME_8822B(x) \
(((x) >> BIT_SHIFT_VI_ADMITTED_TIME_8822B) & \
BIT_MASK_VI_ADMITTED_TIME_8822B)
#define BIT_SET_VI_ADMITTED_TIME_8822B(x, v) \
(BIT_CLEAR_VI_ADMITTED_TIME_8822B(x) | BIT_VI_ADMITTED_TIME_8822B(v))
/* 2 REG_BE_ADMTIME_8822B */
#define BIT_SHIFT_BE_ADMITTED_TIME_8822B 0
#define BIT_MASK_BE_ADMITTED_TIME_8822B 0xffff
#define BIT_BE_ADMITTED_TIME_8822B(x) \
(((x) & BIT_MASK_BE_ADMITTED_TIME_8822B) \
<< BIT_SHIFT_BE_ADMITTED_TIME_8822B)
#define BITS_BE_ADMITTED_TIME_8822B \
(BIT_MASK_BE_ADMITTED_TIME_8822B << BIT_SHIFT_BE_ADMITTED_TIME_8822B)
#define BIT_CLEAR_BE_ADMITTED_TIME_8822B(x) \
((x) & (~BITS_BE_ADMITTED_TIME_8822B))
#define BIT_GET_BE_ADMITTED_TIME_8822B(x) \
(((x) >> BIT_SHIFT_BE_ADMITTED_TIME_8822B) & \
BIT_MASK_BE_ADMITTED_TIME_8822B)
#define BIT_SET_BE_ADMITTED_TIME_8822B(x, v) \
(BIT_CLEAR_BE_ADMITTED_TIME_8822B(x) | BIT_BE_ADMITTED_TIME_8822B(v))
/* 2 REG_EDCA_RANDOM_GEN_8822B */
#define BIT_SHIFT_RANDOM_GEN_8822B 0
#define BIT_MASK_RANDOM_GEN_8822B 0xffffff
#define BIT_RANDOM_GEN_8822B(x) \
(((x) & BIT_MASK_RANDOM_GEN_8822B) << BIT_SHIFT_RANDOM_GEN_8822B)
#define BITS_RANDOM_GEN_8822B \
(BIT_MASK_RANDOM_GEN_8822B << BIT_SHIFT_RANDOM_GEN_8822B)
#define BIT_CLEAR_RANDOM_GEN_8822B(x) ((x) & (~BITS_RANDOM_GEN_8822B))
#define BIT_GET_RANDOM_GEN_8822B(x) \
(((x) >> BIT_SHIFT_RANDOM_GEN_8822B) & BIT_MASK_RANDOM_GEN_8822B)
#define BIT_SET_RANDOM_GEN_8822B(x, v) \
(BIT_CLEAR_RANDOM_GEN_8822B(x) | BIT_RANDOM_GEN_8822B(v))
/* 2 REG_TXCMD_NOA_SEL_8822B */
#define BIT_SHIFT_NOA_SEL_V2_8822B 4
#define BIT_MASK_NOA_SEL_V2_8822B 0x7
#define BIT_NOA_SEL_V2_8822B(x) \
(((x) & BIT_MASK_NOA_SEL_V2_8822B) << BIT_SHIFT_NOA_SEL_V2_8822B)
#define BITS_NOA_SEL_V2_8822B \
(BIT_MASK_NOA_SEL_V2_8822B << BIT_SHIFT_NOA_SEL_V2_8822B)
#define BIT_CLEAR_NOA_SEL_V2_8822B(x) ((x) & (~BITS_NOA_SEL_V2_8822B))
#define BIT_GET_NOA_SEL_V2_8822B(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V2_8822B) & BIT_MASK_NOA_SEL_V2_8822B)
#define BIT_SET_NOA_SEL_V2_8822B(x, v) \
(BIT_CLEAR_NOA_SEL_V2_8822B(x) | BIT_NOA_SEL_V2_8822B(v))
#define BIT_SHIFT_TXCMD_SEG_SEL_8822B 0
#define BIT_MASK_TXCMD_SEG_SEL_8822B 0xf
#define BIT_TXCMD_SEG_SEL_8822B(x) \
(((x) & BIT_MASK_TXCMD_SEG_SEL_8822B) << BIT_SHIFT_TXCMD_SEG_SEL_8822B)
#define BITS_TXCMD_SEG_SEL_8822B \
(BIT_MASK_TXCMD_SEG_SEL_8822B << BIT_SHIFT_TXCMD_SEG_SEL_8822B)
#define BIT_CLEAR_TXCMD_SEG_SEL_8822B(x) ((x) & (~BITS_TXCMD_SEG_SEL_8822B))
#define BIT_GET_TXCMD_SEG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_TXCMD_SEG_SEL_8822B) & BIT_MASK_TXCMD_SEG_SEL_8822B)
#define BIT_SET_TXCMD_SEG_SEL_8822B(x, v) \
(BIT_CLEAR_TXCMD_SEG_SEL_8822B(x) | BIT_TXCMD_SEG_SEL_8822B(v))
/* 2 REG_NOA_PARAM_8822B */
#define BIT_SHIFT_NOA_COUNT_8822B (96 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_COUNT_8822B 0xff
#define BIT_NOA_COUNT_8822B(x) \
(((x) & BIT_MASK_NOA_COUNT_8822B) << BIT_SHIFT_NOA_COUNT_8822B)
#define BITS_NOA_COUNT_8822B \
(BIT_MASK_NOA_COUNT_8822B << BIT_SHIFT_NOA_COUNT_8822B)
#define BIT_CLEAR_NOA_COUNT_8822B(x) ((x) & (~BITS_NOA_COUNT_8822B))
#define BIT_GET_NOA_COUNT_8822B(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_8822B) & BIT_MASK_NOA_COUNT_8822B)
#define BIT_SET_NOA_COUNT_8822B(x, v) \
(BIT_CLEAR_NOA_COUNT_8822B(x) | BIT_NOA_COUNT_8822B(v))
#define BIT_SHIFT_NOA_START_TIME_8822B (64 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_START_TIME_8822B 0xffffffffL
#define BIT_NOA_START_TIME_8822B(x) \
(((x) & BIT_MASK_NOA_START_TIME_8822B) \
<< BIT_SHIFT_NOA_START_TIME_8822B)
#define BITS_NOA_START_TIME_8822B \
(BIT_MASK_NOA_START_TIME_8822B << BIT_SHIFT_NOA_START_TIME_8822B)
#define BIT_CLEAR_NOA_START_TIME_8822B(x) ((x) & (~BITS_NOA_START_TIME_8822B))
#define BIT_GET_NOA_START_TIME_8822B(x) \
(((x) >> BIT_SHIFT_NOA_START_TIME_8822B) & \
BIT_MASK_NOA_START_TIME_8822B)
#define BIT_SET_NOA_START_TIME_8822B(x, v) \
(BIT_CLEAR_NOA_START_TIME_8822B(x) | BIT_NOA_START_TIME_8822B(v))
#define BIT_SHIFT_NOA_INTERVAL_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_NOA_INTERVAL_8822B 0xffffffffL
#define BIT_NOA_INTERVAL_8822B(x) \
(((x) & BIT_MASK_NOA_INTERVAL_8822B) << BIT_SHIFT_NOA_INTERVAL_8822B)
#define BITS_NOA_INTERVAL_8822B \
(BIT_MASK_NOA_INTERVAL_8822B << BIT_SHIFT_NOA_INTERVAL_8822B)
#define BIT_CLEAR_NOA_INTERVAL_8822B(x) ((x) & (~BITS_NOA_INTERVAL_8822B))
#define BIT_GET_NOA_INTERVAL_8822B(x) \
(((x) >> BIT_SHIFT_NOA_INTERVAL_8822B) & BIT_MASK_NOA_INTERVAL_8822B)
#define BIT_SET_NOA_INTERVAL_8822B(x, v) \
(BIT_CLEAR_NOA_INTERVAL_8822B(x) | BIT_NOA_INTERVAL_8822B(v))
#define BIT_SHIFT_NOA_DURATION_8822B 0
#define BIT_MASK_NOA_DURATION_8822B 0xffffffffL
#define BIT_NOA_DURATION_8822B(x) \
(((x) & BIT_MASK_NOA_DURATION_8822B) << BIT_SHIFT_NOA_DURATION_8822B)
#define BITS_NOA_DURATION_8822B \
(BIT_MASK_NOA_DURATION_8822B << BIT_SHIFT_NOA_DURATION_8822B)
#define BIT_CLEAR_NOA_DURATION_8822B(x) ((x) & (~BITS_NOA_DURATION_8822B))
#define BIT_GET_NOA_DURATION_8822B(x) \
(((x) >> BIT_SHIFT_NOA_DURATION_8822B) & BIT_MASK_NOA_DURATION_8822B)
#define BIT_SET_NOA_DURATION_8822B(x, v) \
(BIT_CLEAR_NOA_DURATION_8822B(x) | BIT_NOA_DURATION_8822B(v))
/* 2 REG_P2P_RST_8822B */
#define BIT_P2P2_PWR_RST1_8822B BIT(5)
#define BIT_P2P2_PWR_RST0_8822B BIT(4)
#define BIT_P2P1_PWR_RST1_8822B BIT(3)
#define BIT_P2P1_PWR_RST0_8822B BIT(2)
#define BIT_P2P_PWR_RST1_V1_8822B BIT(1)
#define BIT_P2P_PWR_RST0_V1_8822B BIT(0)
/* 2 REG_SCHEDULER_RST_8822B */
#define BIT_SYNC_CLI_ONCE_RIGHT_NOW_8822B BIT(2)
#define BIT_SYNC_CLI_ONCE_BY_TBTT_8822B BIT(1)
#define BIT_SCHEDULER_RST_V1_8822B BIT(0)
/* 2 REG_SCH_TXCMD_8822B */
#define BIT_SHIFT_SCH_TXCMD_8822B 0
#define BIT_MASK_SCH_TXCMD_8822B 0xffffffffL
#define BIT_SCH_TXCMD_8822B(x) \
(((x) & BIT_MASK_SCH_TXCMD_8822B) << BIT_SHIFT_SCH_TXCMD_8822B)
#define BITS_SCH_TXCMD_8822B \
(BIT_MASK_SCH_TXCMD_8822B << BIT_SHIFT_SCH_TXCMD_8822B)
#define BIT_CLEAR_SCH_TXCMD_8822B(x) ((x) & (~BITS_SCH_TXCMD_8822B))
#define BIT_GET_SCH_TXCMD_8822B(x) \
(((x) >> BIT_SHIFT_SCH_TXCMD_8822B) & BIT_MASK_SCH_TXCMD_8822B)
#define BIT_SET_SCH_TXCMD_8822B(x, v) \
(BIT_CLEAR_SCH_TXCMD_8822B(x) | BIT_SCH_TXCMD_8822B(v))
/* 2 REG_PAGE5_DUMMY_8822B */
/* 2 REG_CPUMGQ_TX_TIMER_8822B */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822B 0
#define BIT_MASK_CPUMGQ_TX_TIMER_V1_8822B 0xffffffffL
#define BIT_CPUMGQ_TX_TIMER_V1_8822B(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_V1_8822B) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822B)
#define BITS_CPUMGQ_TX_TIMER_V1_8822B \
(BIT_MASK_CPUMGQ_TX_TIMER_V1_8822B \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822B)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8822B(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_V1_8822B))
#define BIT_GET_CPUMGQ_TX_TIMER_V1_8822B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822B) & \
BIT_MASK_CPUMGQ_TX_TIMER_V1_8822B)
#define BIT_SET_CPUMGQ_TX_TIMER_V1_8822B(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8822B(x) | \
BIT_CPUMGQ_TX_TIMER_V1_8822B(v))
/* 2 REG_PS_TIMER_A_8822B */
#define BIT_SHIFT_PS_TIMER_A_V1_8822B 0
#define BIT_MASK_PS_TIMER_A_V1_8822B 0xffffffffL
#define BIT_PS_TIMER_A_V1_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_A_V1_8822B) << BIT_SHIFT_PS_TIMER_A_V1_8822B)
#define BITS_PS_TIMER_A_V1_8822B \
(BIT_MASK_PS_TIMER_A_V1_8822B << BIT_SHIFT_PS_TIMER_A_V1_8822B)
#define BIT_CLEAR_PS_TIMER_A_V1_8822B(x) ((x) & (~BITS_PS_TIMER_A_V1_8822B))
#define BIT_GET_PS_TIMER_A_V1_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_V1_8822B) & BIT_MASK_PS_TIMER_A_V1_8822B)
#define BIT_SET_PS_TIMER_A_V1_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_A_V1_8822B(x) | BIT_PS_TIMER_A_V1_8822B(v))
/* 2 REG_PS_TIMER_B_8822B */
#define BIT_SHIFT_PS_TIMER_B_V1_8822B 0
#define BIT_MASK_PS_TIMER_B_V1_8822B 0xffffffffL
#define BIT_PS_TIMER_B_V1_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_B_V1_8822B) << BIT_SHIFT_PS_TIMER_B_V1_8822B)
#define BITS_PS_TIMER_B_V1_8822B \
(BIT_MASK_PS_TIMER_B_V1_8822B << BIT_SHIFT_PS_TIMER_B_V1_8822B)
#define BIT_CLEAR_PS_TIMER_B_V1_8822B(x) ((x) & (~BITS_PS_TIMER_B_V1_8822B))
#define BIT_GET_PS_TIMER_B_V1_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_V1_8822B) & BIT_MASK_PS_TIMER_B_V1_8822B)
#define BIT_SET_PS_TIMER_B_V1_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_B_V1_8822B(x) | BIT_PS_TIMER_B_V1_8822B(v))
/* 2 REG_PS_TIMER_C_8822B */
#define BIT_SHIFT_PS_TIMER_C_V1_8822B 0
#define BIT_MASK_PS_TIMER_C_V1_8822B 0xffffffffL
#define BIT_PS_TIMER_C_V1_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_C_V1_8822B) << BIT_SHIFT_PS_TIMER_C_V1_8822B)
#define BITS_PS_TIMER_C_V1_8822B \
(BIT_MASK_PS_TIMER_C_V1_8822B << BIT_SHIFT_PS_TIMER_C_V1_8822B)
#define BIT_CLEAR_PS_TIMER_C_V1_8822B(x) ((x) & (~BITS_PS_TIMER_C_V1_8822B))
#define BIT_GET_PS_TIMER_C_V1_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_V1_8822B) & BIT_MASK_PS_TIMER_C_V1_8822B)
#define BIT_SET_PS_TIMER_C_V1_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_C_V1_8822B(x) | BIT_PS_TIMER_C_V1_8822B(v))
/* 2 REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8822B */
#define BIT_CPUMGQ_TIMER_EN_8822B BIT(31)
#define BIT_CPUMGQ_TX_EN_8822B BIT(28)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822B 24
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822B 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL_8822B(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822B) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822B)
#define BITS_CPUMGQ_TIMER_TSF_SEL_8822B \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822B \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822B)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8822B(x) \
((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL_8822B))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL_8822B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822B) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822B)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL_8822B(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8822B(x) | \
BIT_CPUMGQ_TIMER_TSF_SEL_8822B(v))
#define BIT_PS_TIMER_C_EN_8822B BIT(23)
#define BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822B 16
#define BIT_MASK_PS_TIMER_C_TSF_SEL_8822B 0x7
#define BIT_PS_TIMER_C_TSF_SEL_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_C_TSF_SEL_8822B) \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822B)
#define BITS_PS_TIMER_C_TSF_SEL_8822B \
(BIT_MASK_PS_TIMER_C_TSF_SEL_8822B \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822B)
#define BIT_CLEAR_PS_TIMER_C_TSF_SEL_8822B(x) \
((x) & (~BITS_PS_TIMER_C_TSF_SEL_8822B))
#define BIT_GET_PS_TIMER_C_TSF_SEL_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822B) & \
BIT_MASK_PS_TIMER_C_TSF_SEL_8822B)
#define BIT_SET_PS_TIMER_C_TSF_SEL_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_C_TSF_SEL_8822B(x) | \
BIT_PS_TIMER_C_TSF_SEL_8822B(v))
#define BIT_PS_TIMER_B_EN_8822B BIT(15)
#define BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822B 8
#define BIT_MASK_PS_TIMER_B_TSF_SEL_8822B 0x7
#define BIT_PS_TIMER_B_TSF_SEL_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_B_TSF_SEL_8822B) \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822B)
#define BITS_PS_TIMER_B_TSF_SEL_8822B \
(BIT_MASK_PS_TIMER_B_TSF_SEL_8822B \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822B)
#define BIT_CLEAR_PS_TIMER_B_TSF_SEL_8822B(x) \
((x) & (~BITS_PS_TIMER_B_TSF_SEL_8822B))
#define BIT_GET_PS_TIMER_B_TSF_SEL_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822B) & \
BIT_MASK_PS_TIMER_B_TSF_SEL_8822B)
#define BIT_SET_PS_TIMER_B_TSF_SEL_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_B_TSF_SEL_8822B(x) | \
BIT_PS_TIMER_B_TSF_SEL_8822B(v))
#define BIT_PS_TIMER_A_EN_8822B BIT(7)
#define BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822B 0
#define BIT_MASK_PS_TIMER_A_TSF_SEL_8822B 0x7
#define BIT_PS_TIMER_A_TSF_SEL_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_A_TSF_SEL_8822B) \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822B)
#define BITS_PS_TIMER_A_TSF_SEL_8822B \
(BIT_MASK_PS_TIMER_A_TSF_SEL_8822B \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822B)
#define BIT_CLEAR_PS_TIMER_A_TSF_SEL_8822B(x) \
((x) & (~BITS_PS_TIMER_A_TSF_SEL_8822B))
#define BIT_GET_PS_TIMER_A_TSF_SEL_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822B) & \
BIT_MASK_PS_TIMER_A_TSF_SEL_8822B)
#define BIT_SET_PS_TIMER_A_TSF_SEL_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_A_TSF_SEL_8822B(x) | \
BIT_PS_TIMER_A_TSF_SEL_8822B(v))
/* 2 REG_CPUMGQ_TX_TIMER_EARLY_8822B */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822B 0
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822B 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY_8822B(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822B) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822B)
#define BITS_CPUMGQ_TX_TIMER_EARLY_8822B \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822B \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822B)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8822B(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY_8822B))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY_8822B(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822B) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822B)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY_8822B(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8822B(x) | \
BIT_CPUMGQ_TX_TIMER_EARLY_8822B(v))
/* 2 REG_PS_TIMER_A_EARLY_8822B */
#define BIT_SHIFT_PS_TIMER_A_EARLY_8822B 0
#define BIT_MASK_PS_TIMER_A_EARLY_8822B 0xff
#define BIT_PS_TIMER_A_EARLY_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_A_EARLY_8822B) \
<< BIT_SHIFT_PS_TIMER_A_EARLY_8822B)
#define BITS_PS_TIMER_A_EARLY_8822B \
(BIT_MASK_PS_TIMER_A_EARLY_8822B << BIT_SHIFT_PS_TIMER_A_EARLY_8822B)
#define BIT_CLEAR_PS_TIMER_A_EARLY_8822B(x) \
((x) & (~BITS_PS_TIMER_A_EARLY_8822B))
#define BIT_GET_PS_TIMER_A_EARLY_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_EARLY_8822B) & \
BIT_MASK_PS_TIMER_A_EARLY_8822B)
#define BIT_SET_PS_TIMER_A_EARLY_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_A_EARLY_8822B(x) | BIT_PS_TIMER_A_EARLY_8822B(v))
/* 2 REG_PS_TIMER_B_EARLY_8822B */
#define BIT_SHIFT_PS_TIMER_B_EARLY_8822B 0
#define BIT_MASK_PS_TIMER_B_EARLY_8822B 0xff
#define BIT_PS_TIMER_B_EARLY_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_B_EARLY_8822B) \
<< BIT_SHIFT_PS_TIMER_B_EARLY_8822B)
#define BITS_PS_TIMER_B_EARLY_8822B \
(BIT_MASK_PS_TIMER_B_EARLY_8822B << BIT_SHIFT_PS_TIMER_B_EARLY_8822B)
#define BIT_CLEAR_PS_TIMER_B_EARLY_8822B(x) \
((x) & (~BITS_PS_TIMER_B_EARLY_8822B))
#define BIT_GET_PS_TIMER_B_EARLY_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_EARLY_8822B) & \
BIT_MASK_PS_TIMER_B_EARLY_8822B)
#define BIT_SET_PS_TIMER_B_EARLY_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_B_EARLY_8822B(x) | BIT_PS_TIMER_B_EARLY_8822B(v))
/* 2 REG_PS_TIMER_C_EARLY_8822B */
#define BIT_SHIFT_PS_TIMER_C_EARLY_8822B 0
#define BIT_MASK_PS_TIMER_C_EARLY_8822B 0xff
#define BIT_PS_TIMER_C_EARLY_8822B(x) \
(((x) & BIT_MASK_PS_TIMER_C_EARLY_8822B) \
<< BIT_SHIFT_PS_TIMER_C_EARLY_8822B)
#define BITS_PS_TIMER_C_EARLY_8822B \
(BIT_MASK_PS_TIMER_C_EARLY_8822B << BIT_SHIFT_PS_TIMER_C_EARLY_8822B)
#define BIT_CLEAR_PS_TIMER_C_EARLY_8822B(x) \
((x) & (~BITS_PS_TIMER_C_EARLY_8822B))
#define BIT_GET_PS_TIMER_C_EARLY_8822B(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_EARLY_8822B) & \
BIT_MASK_PS_TIMER_C_EARLY_8822B)
#define BIT_SET_PS_TIMER_C_EARLY_8822B(x, v) \
(BIT_CLEAR_PS_TIMER_C_EARLY_8822B(x) | BIT_PS_TIMER_C_EARLY_8822B(v))
/* 2 REG_CPUMGQ_PARAMETER_8822B */
/* 2 REG_NOT_VALID_8822B */
#define BIT_MAC_STOP_CPUMGQ_8822B BIT(16)
#define BIT_SHIFT_CW_8822B 8
#define BIT_MASK_CW_8822B 0xff
#define BIT_CW_8822B(x) (((x) & BIT_MASK_CW_8822B) << BIT_SHIFT_CW_8822B)
#define BITS_CW_8822B (BIT_MASK_CW_8822B << BIT_SHIFT_CW_8822B)
#define BIT_CLEAR_CW_8822B(x) ((x) & (~BITS_CW_8822B))
#define BIT_GET_CW_8822B(x) (((x) >> BIT_SHIFT_CW_8822B) & BIT_MASK_CW_8822B)
#define BIT_SET_CW_8822B(x, v) (BIT_CLEAR_CW_8822B(x) | BIT_CW_8822B(v))
#define BIT_SHIFT_AIFS_8822B 0
#define BIT_MASK_AIFS_8822B 0xff
#define BIT_AIFS_8822B(x) (((x) & BIT_MASK_AIFS_8822B) << BIT_SHIFT_AIFS_8822B)
#define BITS_AIFS_8822B (BIT_MASK_AIFS_8822B << BIT_SHIFT_AIFS_8822B)
#define BIT_CLEAR_AIFS_8822B(x) ((x) & (~BITS_AIFS_8822B))
#define BIT_GET_AIFS_8822B(x) \
(((x) >> BIT_SHIFT_AIFS_8822B) & BIT_MASK_AIFS_8822B)
#define BIT_SET_AIFS_8822B(x, v) (BIT_CLEAR_AIFS_8822B(x) | BIT_AIFS_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_BWOPMODE_8822B (BW OPERATION MODE REGISTER) */
/* 2 REG_WMAC_FWPKT_CR_8822B */
#define BIT_FWEN_8822B BIT(7)
#define BIT_PHYSTS_PKT_CTRL_8822B BIT(6)
#define BIT_APPHDR_MIDSRCH_FAIL_8822B BIT(4)
#define BIT_FWPARSING_EN_8822B BIT(3)
#define BIT_SHIFT_APPEND_MHDR_LEN_8822B 0
#define BIT_MASK_APPEND_MHDR_LEN_8822B 0x7
#define BIT_APPEND_MHDR_LEN_8822B(x) \
(((x) & BIT_MASK_APPEND_MHDR_LEN_8822B) \
<< BIT_SHIFT_APPEND_MHDR_LEN_8822B)
#define BITS_APPEND_MHDR_LEN_8822B \
(BIT_MASK_APPEND_MHDR_LEN_8822B << BIT_SHIFT_APPEND_MHDR_LEN_8822B)
#define BIT_CLEAR_APPEND_MHDR_LEN_8822B(x) ((x) & (~BITS_APPEND_MHDR_LEN_8822B))
#define BIT_GET_APPEND_MHDR_LEN_8822B(x) \
(((x) >> BIT_SHIFT_APPEND_MHDR_LEN_8822B) & \
BIT_MASK_APPEND_MHDR_LEN_8822B)
#define BIT_SET_APPEND_MHDR_LEN_8822B(x, v) \
(BIT_CLEAR_APPEND_MHDR_LEN_8822B(x) | BIT_APPEND_MHDR_LEN_8822B(v))
/* 2 REG_WMAC_CR_8822B (WMAC CR AND APSD CONTROL REGISTER) */
#define BIT_IC_MACPHY_M_8822B BIT(0)
/* 2 REG_TCR_8822B (TRANSMISSION CONFIGURATION REGISTER) */
#define BIT_WMAC_EN_RTS_ADDR_8822B BIT(31)
#define BIT_WMAC_DISABLE_CCK_8822B BIT(30)
#define BIT_WMAC_RAW_LEN_8822B BIT(29)
#define BIT_WMAC_NOTX_IN_RXNDP_8822B BIT(28)
#define BIT_WMAC_EN_EOF_8822B BIT(27)
#define BIT_WMAC_BF_SEL_8822B BIT(26)
#define BIT_WMAC_ANTMODE_SEL_8822B BIT(25)
#define BIT_WMAC_TCRPWRMGT_HWCTL_8822B BIT(24)
#define BIT_WMAC_SMOOTH_VAL_8822B BIT(23)
#define BIT_FETCH_MPDU_AFTER_WSEC_RDY_8822B BIT(20)
#define BIT_WMAC_TCR_EN_20MST_8822B BIT(19)
#define BIT_WMAC_DIS_SIGTA_8822B BIT(18)
#define BIT_WMAC_DIS_A2B0_8822B BIT(17)
#define BIT_WMAC_MSK_SIGBCRC_8822B BIT(16)
#define BIT_WMAC_TCR_ERRSTEN_3_8822B BIT(15)
#define BIT_WMAC_TCR_ERRSTEN_2_8822B BIT(14)
#define BIT_WMAC_TCR_ERRSTEN_1_8822B BIT(13)
#define BIT_WMAC_TCR_ERRSTEN_0_8822B BIT(12)
#define BIT_WMAC_TCR_TXSK_PERPKT_8822B BIT(11)
#define BIT_ICV_8822B BIT(10)
#define BIT_CFEND_FORMAT_8822B BIT(9)
#define BIT_CRC_8822B BIT(8)
#define BIT_PWRBIT_OW_EN_8822B BIT(7)
#define BIT_PWR_ST_8822B BIT(6)
#define BIT_WMAC_TCR_UPD_TIMIE_8822B BIT(5)
#define BIT_WMAC_TCR_UPD_HGQMD_8822B BIT(4)
#define BIT_VHTSIGA1_TXPS_8822B BIT(3)
#define BIT_PAD_SEL_8822B BIT(2)
#define BIT_DIS_GCLK_8822B BIT(1)
/* 2 REG_RCR_8822B (RECEIVE CONFIGURATION REGISTER) */
#define BIT_APP_FCS_8822B BIT(31)
#define BIT_APP_MIC_8822B BIT(30)
#define BIT_APP_ICV_8822B BIT(29)
#define BIT_APP_PHYSTS_8822B BIT(28)
#define BIT_APP_BASSN_8822B BIT(27)
#define BIT_VHT_DACK_8822B BIT(26)
#define BIT_TCPOFLD_EN_8822B BIT(25)
#define BIT_ENMBID_8822B BIT(24)
#define BIT_LSIGEN_8822B BIT(23)
#define BIT_MFBEN_8822B BIT(22)
#define BIT_DISCHKPPDLLEN_8822B BIT(21)
#define BIT_PKTCTL_DLEN_8822B BIT(20)
#define BIT_TIM_PARSER_EN_8822B BIT(18)
#define BIT_BC_MD_EN_8822B BIT(17)
#define BIT_UC_MD_EN_8822B BIT(16)
#define BIT_RXSK_PERPKT_8822B BIT(15)
#define BIT_HTC_LOC_CTRL_8822B BIT(14)
#define BIT_RPFM_CAM_ENABLE_8822B BIT(12)
#define BIT_TA_BCN_8822B BIT(11)
#define BIT_DISDECMYPKT_8822B BIT(10)
#define BIT_AICV_8822B BIT(9)
#define BIT_ACRC32_8822B BIT(8)
#define BIT_CBSSID_BCN_8822B BIT(7)
#define BIT_CBSSID_DATA_8822B BIT(6)
#define BIT_APWRMGT_8822B BIT(5)
#define BIT_ADD3_8822B BIT(4)
#define BIT_AB_8822B BIT(3)
#define BIT_AM_8822B BIT(2)
#define BIT_APM_8822B BIT(1)
#define BIT_AAP_8822B BIT(0)
/* 2 REG_RX_DRVINFO_SZ_8822B (RX DRIVER INFO SIZE REGISTER) */
#define BIT_PHYSTS_PER_PKT_MODE_8822B BIT(7)
#define BIT_SHIFT_DRVINFO_SZ_V1_8822B 0
#define BIT_MASK_DRVINFO_SZ_V1_8822B 0xf
#define BIT_DRVINFO_SZ_V1_8822B(x) \
(((x) & BIT_MASK_DRVINFO_SZ_V1_8822B) << BIT_SHIFT_DRVINFO_SZ_V1_8822B)
#define BITS_DRVINFO_SZ_V1_8822B \
(BIT_MASK_DRVINFO_SZ_V1_8822B << BIT_SHIFT_DRVINFO_SZ_V1_8822B)
#define BIT_CLEAR_DRVINFO_SZ_V1_8822B(x) ((x) & (~BITS_DRVINFO_SZ_V1_8822B))
#define BIT_GET_DRVINFO_SZ_V1_8822B(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ_V1_8822B) & BIT_MASK_DRVINFO_SZ_V1_8822B)
#define BIT_SET_DRVINFO_SZ_V1_8822B(x, v) \
(BIT_CLEAR_DRVINFO_SZ_V1_8822B(x) | BIT_DRVINFO_SZ_V1_8822B(v))
/* 2 REG_RX_DLK_TIME_8822B (RX DEADLOCK TIME REGISTER) */
#define BIT_SHIFT_RX_DLK_TIME_8822B 0
#define BIT_MASK_RX_DLK_TIME_8822B 0xff
#define BIT_RX_DLK_TIME_8822B(x) \
(((x) & BIT_MASK_RX_DLK_TIME_8822B) << BIT_SHIFT_RX_DLK_TIME_8822B)
#define BITS_RX_DLK_TIME_8822B \
(BIT_MASK_RX_DLK_TIME_8822B << BIT_SHIFT_RX_DLK_TIME_8822B)
#define BIT_CLEAR_RX_DLK_TIME_8822B(x) ((x) & (~BITS_RX_DLK_TIME_8822B))
#define BIT_GET_RX_DLK_TIME_8822B(x) \
(((x) >> BIT_SHIFT_RX_DLK_TIME_8822B) & BIT_MASK_RX_DLK_TIME_8822B)
#define BIT_SET_RX_DLK_TIME_8822B(x, v) \
(BIT_CLEAR_RX_DLK_TIME_8822B(x) | BIT_RX_DLK_TIME_8822B(v))
/* 2 REG_RX_PKT_LIMIT_8822B (RX PACKET LENGTH LIMIT REGISTER) */
#define BIT_SHIFT_RXPKTLMT_8822B 0
#define BIT_MASK_RXPKTLMT_8822B 0x3f
#define BIT_RXPKTLMT_8822B(x) \
(((x) & BIT_MASK_RXPKTLMT_8822B) << BIT_SHIFT_RXPKTLMT_8822B)
#define BITS_RXPKTLMT_8822B \
(BIT_MASK_RXPKTLMT_8822B << BIT_SHIFT_RXPKTLMT_8822B)
#define BIT_CLEAR_RXPKTLMT_8822B(x) ((x) & (~BITS_RXPKTLMT_8822B))
#define BIT_GET_RXPKTLMT_8822B(x) \
(((x) >> BIT_SHIFT_RXPKTLMT_8822B) & BIT_MASK_RXPKTLMT_8822B)
#define BIT_SET_RXPKTLMT_8822B(x, v) \
(BIT_CLEAR_RXPKTLMT_8822B(x) | BIT_RXPKTLMT_8822B(v))
/* 2 REG_MACID_8822B (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_8822B 0
#define BIT_MASK_MACID_8822B 0xffffffffffffL
#define BIT_MACID_8822B(x) \
(((x) & BIT_MASK_MACID_8822B) << BIT_SHIFT_MACID_8822B)
#define BITS_MACID_8822B (BIT_MASK_MACID_8822B << BIT_SHIFT_MACID_8822B)
#define BIT_CLEAR_MACID_8822B(x) ((x) & (~BITS_MACID_8822B))
#define BIT_GET_MACID_8822B(x) \
(((x) >> BIT_SHIFT_MACID_8822B) & BIT_MASK_MACID_8822B)
#define BIT_SET_MACID_8822B(x, v) \
(BIT_CLEAR_MACID_8822B(x) | BIT_MACID_8822B(v))
/* 2 REG_BSSID_8822B (BSSID REGISTER) */
#define BIT_SHIFT_BSSID_8822B 0
#define BIT_MASK_BSSID_8822B 0xffffffffffffL
#define BIT_BSSID_8822B(x) \
(((x) & BIT_MASK_BSSID_8822B) << BIT_SHIFT_BSSID_8822B)
#define BITS_BSSID_8822B (BIT_MASK_BSSID_8822B << BIT_SHIFT_BSSID_8822B)
#define BIT_CLEAR_BSSID_8822B(x) ((x) & (~BITS_BSSID_8822B))
#define BIT_GET_BSSID_8822B(x) \
(((x) >> BIT_SHIFT_BSSID_8822B) & BIT_MASK_BSSID_8822B)
#define BIT_SET_BSSID_8822B(x, v) \
(BIT_CLEAR_BSSID_8822B(x) | BIT_BSSID_8822B(v))
/* 2 REG_MAR_8822B (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_8822B 0
#define BIT_MASK_MAR_8822B 0xffffffffffffffffL
#define BIT_MAR_8822B(x) (((x) & BIT_MASK_MAR_8822B) << BIT_SHIFT_MAR_8822B)
#define BITS_MAR_8822B (BIT_MASK_MAR_8822B << BIT_SHIFT_MAR_8822B)
#define BIT_CLEAR_MAR_8822B(x) ((x) & (~BITS_MAR_8822B))
#define BIT_GET_MAR_8822B(x) (((x) >> BIT_SHIFT_MAR_8822B) & BIT_MASK_MAR_8822B)
#define BIT_SET_MAR_8822B(x, v) (BIT_CLEAR_MAR_8822B(x) | BIT_MAR_8822B(v))
/* 2 REG_MBIDCAMCFG_1_8822B (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_SHIFT_MBIDCAM_RWDATA_L_8822B 0
#define BIT_MASK_MBIDCAM_RWDATA_L_8822B 0xffffffffL
#define BIT_MBIDCAM_RWDATA_L_8822B(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_L_8822B) \
<< BIT_SHIFT_MBIDCAM_RWDATA_L_8822B)
#define BITS_MBIDCAM_RWDATA_L_8822B \
(BIT_MASK_MBIDCAM_RWDATA_L_8822B << BIT_SHIFT_MBIDCAM_RWDATA_L_8822B)
#define BIT_CLEAR_MBIDCAM_RWDATA_L_8822B(x) \
((x) & (~BITS_MBIDCAM_RWDATA_L_8822B))
#define BIT_GET_MBIDCAM_RWDATA_L_8822B(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_L_8822B) & \
BIT_MASK_MBIDCAM_RWDATA_L_8822B)
#define BIT_SET_MBIDCAM_RWDATA_L_8822B(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_L_8822B(x) | BIT_MBIDCAM_RWDATA_L_8822B(v))
/* 2 REG_MBIDCAMCFG_2_8822B (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_MBIDCAM_POLL_8822B BIT(31)
#define BIT_MBIDCAM_WT_EN_8822B BIT(30)
#define BIT_SHIFT_MBIDCAM_ADDR_8822B 24
#define BIT_MASK_MBIDCAM_ADDR_8822B 0x1f
#define BIT_MBIDCAM_ADDR_8822B(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR_8822B) << BIT_SHIFT_MBIDCAM_ADDR_8822B)
#define BITS_MBIDCAM_ADDR_8822B \
(BIT_MASK_MBIDCAM_ADDR_8822B << BIT_SHIFT_MBIDCAM_ADDR_8822B)
#define BIT_CLEAR_MBIDCAM_ADDR_8822B(x) ((x) & (~BITS_MBIDCAM_ADDR_8822B))
#define BIT_GET_MBIDCAM_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR_8822B) & BIT_MASK_MBIDCAM_ADDR_8822B)
#define BIT_SET_MBIDCAM_ADDR_8822B(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR_8822B(x) | BIT_MBIDCAM_ADDR_8822B(v))
#define BIT_MBIDCAM_VALID_8822B BIT(23)
#define BIT_LSIC_TXOP_EN_8822B BIT(17)
#define BIT_CTS_EN_8822B BIT(16)
#define BIT_SHIFT_MBIDCAM_RWDATA_H_8822B 0
#define BIT_MASK_MBIDCAM_RWDATA_H_8822B 0xffff
#define BIT_MBIDCAM_RWDATA_H_8822B(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_H_8822B) \
<< BIT_SHIFT_MBIDCAM_RWDATA_H_8822B)
#define BITS_MBIDCAM_RWDATA_H_8822B \
(BIT_MASK_MBIDCAM_RWDATA_H_8822B << BIT_SHIFT_MBIDCAM_RWDATA_H_8822B)
#define BIT_CLEAR_MBIDCAM_RWDATA_H_8822B(x) \
((x) & (~BITS_MBIDCAM_RWDATA_H_8822B))
#define BIT_GET_MBIDCAM_RWDATA_H_8822B(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_H_8822B) & \
BIT_MASK_MBIDCAM_RWDATA_H_8822B)
#define BIT_SET_MBIDCAM_RWDATA_H_8822B(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_H_8822B(x) | BIT_MBIDCAM_RWDATA_H_8822B(v))
/* 2 REG_ZLD_NUM_8822B */
#define BIT_SHIFT_ZLD_NUM_8822B 0
#define BIT_MASK_ZLD_NUM_8822B 0xff
#define BIT_ZLD_NUM_8822B(x) \
(((x) & BIT_MASK_ZLD_NUM_8822B) << BIT_SHIFT_ZLD_NUM_8822B)
#define BITS_ZLD_NUM_8822B (BIT_MASK_ZLD_NUM_8822B << BIT_SHIFT_ZLD_NUM_8822B)
#define BIT_CLEAR_ZLD_NUM_8822B(x) ((x) & (~BITS_ZLD_NUM_8822B))
#define BIT_GET_ZLD_NUM_8822B(x) \
(((x) >> BIT_SHIFT_ZLD_NUM_8822B) & BIT_MASK_ZLD_NUM_8822B)
#define BIT_SET_ZLD_NUM_8822B(x, v) \
(BIT_CLEAR_ZLD_NUM_8822B(x) | BIT_ZLD_NUM_8822B(v))
/* 2 REG_UDF_THSD_8822B */
#define BIT_SHIFT_UDF_THSD_8822B 0
#define BIT_MASK_UDF_THSD_8822B 0xff
#define BIT_UDF_THSD_8822B(x) \
(((x) & BIT_MASK_UDF_THSD_8822B) << BIT_SHIFT_UDF_THSD_8822B)
#define BITS_UDF_THSD_8822B \
(BIT_MASK_UDF_THSD_8822B << BIT_SHIFT_UDF_THSD_8822B)
#define BIT_CLEAR_UDF_THSD_8822B(x) ((x) & (~BITS_UDF_THSD_8822B))
#define BIT_GET_UDF_THSD_8822B(x) \
(((x) >> BIT_SHIFT_UDF_THSD_8822B) & BIT_MASK_UDF_THSD_8822B)
#define BIT_SET_UDF_THSD_8822B(x, v) \
(BIT_CLEAR_UDF_THSD_8822B(x) | BIT_UDF_THSD_8822B(v))
/* 2 REG_WMAC_TCR_TSFT_OFS_8822B */
#define BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822B 0
#define BIT_MASK_WMAC_TCR_TSFT_OFS_8822B 0xffff
#define BIT_WMAC_TCR_TSFT_OFS_8822B(x) \
(((x) & BIT_MASK_WMAC_TCR_TSFT_OFS_8822B) \
<< BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822B)
#define BITS_WMAC_TCR_TSFT_OFS_8822B \
(BIT_MASK_WMAC_TCR_TSFT_OFS_8822B << BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822B)
#define BIT_CLEAR_WMAC_TCR_TSFT_OFS_8822B(x) \
((x) & (~BITS_WMAC_TCR_TSFT_OFS_8822B))
#define BIT_GET_WMAC_TCR_TSFT_OFS_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822B) & \
BIT_MASK_WMAC_TCR_TSFT_OFS_8822B)
#define BIT_SET_WMAC_TCR_TSFT_OFS_8822B(x, v) \
(BIT_CLEAR_WMAC_TCR_TSFT_OFS_8822B(x) | BIT_WMAC_TCR_TSFT_OFS_8822B(v))
/* 2 REG_MCU_TEST_2_V1_8822B */
#define BIT_SHIFT_MCU_RSVD_2_V1_8822B 0
#define BIT_MASK_MCU_RSVD_2_V1_8822B 0xffff
#define BIT_MCU_RSVD_2_V1_8822B(x) \
(((x) & BIT_MASK_MCU_RSVD_2_V1_8822B) << BIT_SHIFT_MCU_RSVD_2_V1_8822B)
#define BITS_MCU_RSVD_2_V1_8822B \
(BIT_MASK_MCU_RSVD_2_V1_8822B << BIT_SHIFT_MCU_RSVD_2_V1_8822B)
#define BIT_CLEAR_MCU_RSVD_2_V1_8822B(x) ((x) & (~BITS_MCU_RSVD_2_V1_8822B))
#define BIT_GET_MCU_RSVD_2_V1_8822B(x) \
(((x) >> BIT_SHIFT_MCU_RSVD_2_V1_8822B) & BIT_MASK_MCU_RSVD_2_V1_8822B)
#define BIT_SET_MCU_RSVD_2_V1_8822B(x, v) \
(BIT_CLEAR_MCU_RSVD_2_V1_8822B(x) | BIT_MCU_RSVD_2_V1_8822B(v))
/* 2 REG_WMAC_TXTIMEOUT_8822B */
#define BIT_SHIFT_WMAC_TXTIMEOUT_8822B 0
#define BIT_MASK_WMAC_TXTIMEOUT_8822B 0xff
#define BIT_WMAC_TXTIMEOUT_8822B(x) \
(((x) & BIT_MASK_WMAC_TXTIMEOUT_8822B) \
<< BIT_SHIFT_WMAC_TXTIMEOUT_8822B)
#define BITS_WMAC_TXTIMEOUT_8822B \
(BIT_MASK_WMAC_TXTIMEOUT_8822B << BIT_SHIFT_WMAC_TXTIMEOUT_8822B)
#define BIT_CLEAR_WMAC_TXTIMEOUT_8822B(x) ((x) & (~BITS_WMAC_TXTIMEOUT_8822B))
#define BIT_GET_WMAC_TXTIMEOUT_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_TXTIMEOUT_8822B) & \
BIT_MASK_WMAC_TXTIMEOUT_8822B)
#define BIT_SET_WMAC_TXTIMEOUT_8822B(x, v) \
(BIT_CLEAR_WMAC_TXTIMEOUT_8822B(x) | BIT_WMAC_TXTIMEOUT_8822B(v))
/* 2 REG_STMP_THSD_8822B */
#define BIT_SHIFT_STMP_THSD_8822B 0
#define BIT_MASK_STMP_THSD_8822B 0xff
#define BIT_STMP_THSD_8822B(x) \
(((x) & BIT_MASK_STMP_THSD_8822B) << BIT_SHIFT_STMP_THSD_8822B)
#define BITS_STMP_THSD_8822B \
(BIT_MASK_STMP_THSD_8822B << BIT_SHIFT_STMP_THSD_8822B)
#define BIT_CLEAR_STMP_THSD_8822B(x) ((x) & (~BITS_STMP_THSD_8822B))
#define BIT_GET_STMP_THSD_8822B(x) \
(((x) >> BIT_SHIFT_STMP_THSD_8822B) & BIT_MASK_STMP_THSD_8822B)
#define BIT_SET_STMP_THSD_8822B(x, v) \
(BIT_CLEAR_STMP_THSD_8822B(x) | BIT_STMP_THSD_8822B(v))
/* 2 REG_MAC_SPEC_SIFS_8822B (SPECIFICATION SIFS REGISTER) */
#define BIT_SHIFT_SPEC_SIFS_OFDM_8822B 8
#define BIT_MASK_SPEC_SIFS_OFDM_8822B 0xff
#define BIT_SPEC_SIFS_OFDM_8822B(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_8822B) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_8822B)
#define BITS_SPEC_SIFS_OFDM_8822B \
(BIT_MASK_SPEC_SIFS_OFDM_8822B << BIT_SHIFT_SPEC_SIFS_OFDM_8822B)
#define BIT_CLEAR_SPEC_SIFS_OFDM_8822B(x) ((x) & (~BITS_SPEC_SIFS_OFDM_8822B))
#define BIT_GET_SPEC_SIFS_OFDM_8822B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_8822B) & \
BIT_MASK_SPEC_SIFS_OFDM_8822B)
#define BIT_SET_SPEC_SIFS_OFDM_8822B(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_8822B(x) | BIT_SPEC_SIFS_OFDM_8822B(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_8822B 0
#define BIT_MASK_SPEC_SIFS_CCK_8822B 0xff
#define BIT_SPEC_SIFS_CCK_8822B(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_8822B) << BIT_SHIFT_SPEC_SIFS_CCK_8822B)
#define BITS_SPEC_SIFS_CCK_8822B \
(BIT_MASK_SPEC_SIFS_CCK_8822B << BIT_SHIFT_SPEC_SIFS_CCK_8822B)
#define BIT_CLEAR_SPEC_SIFS_CCK_8822B(x) ((x) & (~BITS_SPEC_SIFS_CCK_8822B))
#define BIT_GET_SPEC_SIFS_CCK_8822B(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_8822B) & BIT_MASK_SPEC_SIFS_CCK_8822B)
#define BIT_SET_SPEC_SIFS_CCK_8822B(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_8822B(x) | BIT_SPEC_SIFS_CCK_8822B(v))
/* 2 REG_USTIME_EDCA_8822B (US TIME TUNING FOR EDCA REGISTER) */
#define BIT_SHIFT_USTIME_EDCA_V1_8822B 0
#define BIT_MASK_USTIME_EDCA_V1_8822B 0x1ff
#define BIT_USTIME_EDCA_V1_8822B(x) \
(((x) & BIT_MASK_USTIME_EDCA_V1_8822B) \
<< BIT_SHIFT_USTIME_EDCA_V1_8822B)
#define BITS_USTIME_EDCA_V1_8822B \
(BIT_MASK_USTIME_EDCA_V1_8822B << BIT_SHIFT_USTIME_EDCA_V1_8822B)
#define BIT_CLEAR_USTIME_EDCA_V1_8822B(x) ((x) & (~BITS_USTIME_EDCA_V1_8822B))
#define BIT_GET_USTIME_EDCA_V1_8822B(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA_V1_8822B) & \
BIT_MASK_USTIME_EDCA_V1_8822B)
#define BIT_SET_USTIME_EDCA_V1_8822B(x, v) \
(BIT_CLEAR_USTIME_EDCA_V1_8822B(x) | BIT_USTIME_EDCA_V1_8822B(v))
/* 2 REG_RESP_SIFS_OFDM_8822B (RESPONSE SIFS FOR OFDM REGISTER) */
#define BIT_SHIFT_SIFS_R2T_OFDM_8822B 8
#define BIT_MASK_SIFS_R2T_OFDM_8822B 0xff
#define BIT_SIFS_R2T_OFDM_8822B(x) \
(((x) & BIT_MASK_SIFS_R2T_OFDM_8822B) << BIT_SHIFT_SIFS_R2T_OFDM_8822B)
#define BITS_SIFS_R2T_OFDM_8822B \
(BIT_MASK_SIFS_R2T_OFDM_8822B << BIT_SHIFT_SIFS_R2T_OFDM_8822B)
#define BIT_CLEAR_SIFS_R2T_OFDM_8822B(x) ((x) & (~BITS_SIFS_R2T_OFDM_8822B))
#define BIT_GET_SIFS_R2T_OFDM_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_OFDM_8822B) & BIT_MASK_SIFS_R2T_OFDM_8822B)
#define BIT_SET_SIFS_R2T_OFDM_8822B(x, v) \
(BIT_CLEAR_SIFS_R2T_OFDM_8822B(x) | BIT_SIFS_R2T_OFDM_8822B(v))
#define BIT_SHIFT_SIFS_T2T_OFDM_8822B 0
#define BIT_MASK_SIFS_T2T_OFDM_8822B 0xff
#define BIT_SIFS_T2T_OFDM_8822B(x) \
(((x) & BIT_MASK_SIFS_T2T_OFDM_8822B) << BIT_SHIFT_SIFS_T2T_OFDM_8822B)
#define BITS_SIFS_T2T_OFDM_8822B \
(BIT_MASK_SIFS_T2T_OFDM_8822B << BIT_SHIFT_SIFS_T2T_OFDM_8822B)
#define BIT_CLEAR_SIFS_T2T_OFDM_8822B(x) ((x) & (~BITS_SIFS_T2T_OFDM_8822B))
#define BIT_GET_SIFS_T2T_OFDM_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_OFDM_8822B) & BIT_MASK_SIFS_T2T_OFDM_8822B)
#define BIT_SET_SIFS_T2T_OFDM_8822B(x, v) \
(BIT_CLEAR_SIFS_T2T_OFDM_8822B(x) | BIT_SIFS_T2T_OFDM_8822B(v))
/* 2 REG_RESP_SIFS_CCK_8822B (RESPONSE SIFS FOR CCK REGISTER) */
#define BIT_SHIFT_SIFS_R2T_CCK_8822B 8
#define BIT_MASK_SIFS_R2T_CCK_8822B 0xff
#define BIT_SIFS_R2T_CCK_8822B(x) \
(((x) & BIT_MASK_SIFS_R2T_CCK_8822B) << BIT_SHIFT_SIFS_R2T_CCK_8822B)
#define BITS_SIFS_R2T_CCK_8822B \
(BIT_MASK_SIFS_R2T_CCK_8822B << BIT_SHIFT_SIFS_R2T_CCK_8822B)
#define BIT_CLEAR_SIFS_R2T_CCK_8822B(x) ((x) & (~BITS_SIFS_R2T_CCK_8822B))
#define BIT_GET_SIFS_R2T_CCK_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_CCK_8822B) & BIT_MASK_SIFS_R2T_CCK_8822B)
#define BIT_SET_SIFS_R2T_CCK_8822B(x, v) \
(BIT_CLEAR_SIFS_R2T_CCK_8822B(x) | BIT_SIFS_R2T_CCK_8822B(v))
#define BIT_SHIFT_SIFS_T2T_CCK_8822B 0
#define BIT_MASK_SIFS_T2T_CCK_8822B 0xff
#define BIT_SIFS_T2T_CCK_8822B(x) \
(((x) & BIT_MASK_SIFS_T2T_CCK_8822B) << BIT_SHIFT_SIFS_T2T_CCK_8822B)
#define BITS_SIFS_T2T_CCK_8822B \
(BIT_MASK_SIFS_T2T_CCK_8822B << BIT_SHIFT_SIFS_T2T_CCK_8822B)
#define BIT_CLEAR_SIFS_T2T_CCK_8822B(x) ((x) & (~BITS_SIFS_T2T_CCK_8822B))
#define BIT_GET_SIFS_T2T_CCK_8822B(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_CCK_8822B) & BIT_MASK_SIFS_T2T_CCK_8822B)
#define BIT_SET_SIFS_T2T_CCK_8822B(x, v) \
(BIT_CLEAR_SIFS_T2T_CCK_8822B(x) | BIT_SIFS_T2T_CCK_8822B(v))
/* 2 REG_EIFS_8822B (EIFS REGISTER) */
#define BIT_SHIFT_EIFS_8822B 0
#define BIT_MASK_EIFS_8822B 0xffff
#define BIT_EIFS_8822B(x) (((x) & BIT_MASK_EIFS_8822B) << BIT_SHIFT_EIFS_8822B)
#define BITS_EIFS_8822B (BIT_MASK_EIFS_8822B << BIT_SHIFT_EIFS_8822B)
#define BIT_CLEAR_EIFS_8822B(x) ((x) & (~BITS_EIFS_8822B))
#define BIT_GET_EIFS_8822B(x) \
(((x) >> BIT_SHIFT_EIFS_8822B) & BIT_MASK_EIFS_8822B)
#define BIT_SET_EIFS_8822B(x, v) (BIT_CLEAR_EIFS_8822B(x) | BIT_EIFS_8822B(v))
/* 2 REG_CTS2TO_8822B (CTS2 TIMEOUT REGISTER) */
#define BIT_SHIFT_CTS2TO_8822B 0
#define BIT_MASK_CTS2TO_8822B 0xff
#define BIT_CTS2TO_8822B(x) \
(((x) & BIT_MASK_CTS2TO_8822B) << BIT_SHIFT_CTS2TO_8822B)
#define BITS_CTS2TO_8822B (BIT_MASK_CTS2TO_8822B << BIT_SHIFT_CTS2TO_8822B)
#define BIT_CLEAR_CTS2TO_8822B(x) ((x) & (~BITS_CTS2TO_8822B))
#define BIT_GET_CTS2TO_8822B(x) \
(((x) >> BIT_SHIFT_CTS2TO_8822B) & BIT_MASK_CTS2TO_8822B)
#define BIT_SET_CTS2TO_8822B(x, v) \
(BIT_CLEAR_CTS2TO_8822B(x) | BIT_CTS2TO_8822B(v))
/* 2 REG_ACKTO_8822B (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_ACKTO_8822B 0
#define BIT_MASK_ACKTO_8822B 0xff
#define BIT_ACKTO_8822B(x) \
(((x) & BIT_MASK_ACKTO_8822B) << BIT_SHIFT_ACKTO_8822B)
#define BITS_ACKTO_8822B (BIT_MASK_ACKTO_8822B << BIT_SHIFT_ACKTO_8822B)
#define BIT_CLEAR_ACKTO_8822B(x) ((x) & (~BITS_ACKTO_8822B))
#define BIT_GET_ACKTO_8822B(x) \
(((x) >> BIT_SHIFT_ACKTO_8822B) & BIT_MASK_ACKTO_8822B)
#define BIT_SET_ACKTO_8822B(x, v) \
(BIT_CLEAR_ACKTO_8822B(x) | BIT_ACKTO_8822B(v))
/* 2 REG_NAV_CTRL_8822B (NAV CONTROL REGISTER) */
#define BIT_SHIFT_NAV_UPPER_8822B 16
#define BIT_MASK_NAV_UPPER_8822B 0xff
#define BIT_NAV_UPPER_8822B(x) \
(((x) & BIT_MASK_NAV_UPPER_8822B) << BIT_SHIFT_NAV_UPPER_8822B)
#define BITS_NAV_UPPER_8822B \
(BIT_MASK_NAV_UPPER_8822B << BIT_SHIFT_NAV_UPPER_8822B)
#define BIT_CLEAR_NAV_UPPER_8822B(x) ((x) & (~BITS_NAV_UPPER_8822B))
#define BIT_GET_NAV_UPPER_8822B(x) \
(((x) >> BIT_SHIFT_NAV_UPPER_8822B) & BIT_MASK_NAV_UPPER_8822B)
#define BIT_SET_NAV_UPPER_8822B(x, v) \
(BIT_CLEAR_NAV_UPPER_8822B(x) | BIT_NAV_UPPER_8822B(v))
#define BIT_SHIFT_RXMYRTS_NAV_8822B 8
#define BIT_MASK_RXMYRTS_NAV_8822B 0xf
#define BIT_RXMYRTS_NAV_8822B(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_8822B) << BIT_SHIFT_RXMYRTS_NAV_8822B)
#define BITS_RXMYRTS_NAV_8822B \
(BIT_MASK_RXMYRTS_NAV_8822B << BIT_SHIFT_RXMYRTS_NAV_8822B)
#define BIT_CLEAR_RXMYRTS_NAV_8822B(x) ((x) & (~BITS_RXMYRTS_NAV_8822B))
#define BIT_GET_RXMYRTS_NAV_8822B(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_8822B) & BIT_MASK_RXMYRTS_NAV_8822B)
#define BIT_SET_RXMYRTS_NAV_8822B(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_8822B(x) | BIT_RXMYRTS_NAV_8822B(v))
#define BIT_SHIFT_RTSRST_8822B 0
#define BIT_MASK_RTSRST_8822B 0xff
#define BIT_RTSRST_8822B(x) \
(((x) & BIT_MASK_RTSRST_8822B) << BIT_SHIFT_RTSRST_8822B)
#define BITS_RTSRST_8822B (BIT_MASK_RTSRST_8822B << BIT_SHIFT_RTSRST_8822B)
#define BIT_CLEAR_RTSRST_8822B(x) ((x) & (~BITS_RTSRST_8822B))
#define BIT_GET_RTSRST_8822B(x) \
(((x) >> BIT_SHIFT_RTSRST_8822B) & BIT_MASK_RTSRST_8822B)
#define BIT_SET_RTSRST_8822B(x, v) \
(BIT_CLEAR_RTSRST_8822B(x) | BIT_RTSRST_8822B(v))
/* 2 REG_BACAMCMD_8822B (BLOCK ACK CAM COMMAND REGISTER) */
#define BIT_BACAM_POLL_8822B BIT(31)
#define BIT_BACAM_RST_8822B BIT(17)
#define BIT_BACAM_RW_8822B BIT(16)
#define BIT_SHIFT_TXSBM_8822B 14
#define BIT_MASK_TXSBM_8822B 0x3
#define BIT_TXSBM_8822B(x) \
(((x) & BIT_MASK_TXSBM_8822B) << BIT_SHIFT_TXSBM_8822B)
#define BITS_TXSBM_8822B (BIT_MASK_TXSBM_8822B << BIT_SHIFT_TXSBM_8822B)
#define BIT_CLEAR_TXSBM_8822B(x) ((x) & (~BITS_TXSBM_8822B))
#define BIT_GET_TXSBM_8822B(x) \
(((x) >> BIT_SHIFT_TXSBM_8822B) & BIT_MASK_TXSBM_8822B)
#define BIT_SET_TXSBM_8822B(x, v) \
(BIT_CLEAR_TXSBM_8822B(x) | BIT_TXSBM_8822B(v))
#define BIT_SHIFT_BACAM_ADDR_8822B 0
#define BIT_MASK_BACAM_ADDR_8822B 0x3f
#define BIT_BACAM_ADDR_8822B(x) \
(((x) & BIT_MASK_BACAM_ADDR_8822B) << BIT_SHIFT_BACAM_ADDR_8822B)
#define BITS_BACAM_ADDR_8822B \
(BIT_MASK_BACAM_ADDR_8822B << BIT_SHIFT_BACAM_ADDR_8822B)
#define BIT_CLEAR_BACAM_ADDR_8822B(x) ((x) & (~BITS_BACAM_ADDR_8822B))
#define BIT_GET_BACAM_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_BACAM_ADDR_8822B) & BIT_MASK_BACAM_ADDR_8822B)
#define BIT_SET_BACAM_ADDR_8822B(x, v) \
(BIT_CLEAR_BACAM_ADDR_8822B(x) | BIT_BACAM_ADDR_8822B(v))
/* 2 REG_BACAMCONTENT_8822B (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_H_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_BA_CONTENT_H_8822B 0xffffffffL
#define BIT_BA_CONTENT_H_8822B(x) \
(((x) & BIT_MASK_BA_CONTENT_H_8822B) << BIT_SHIFT_BA_CONTENT_H_8822B)
#define BITS_BA_CONTENT_H_8822B \
(BIT_MASK_BA_CONTENT_H_8822B << BIT_SHIFT_BA_CONTENT_H_8822B)
#define BIT_CLEAR_BA_CONTENT_H_8822B(x) ((x) & (~BITS_BA_CONTENT_H_8822B))
#define BIT_GET_BA_CONTENT_H_8822B(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_H_8822B) & BIT_MASK_BA_CONTENT_H_8822B)
#define BIT_SET_BA_CONTENT_H_8822B(x, v) \
(BIT_CLEAR_BA_CONTENT_H_8822B(x) | BIT_BA_CONTENT_H_8822B(v))
#define BIT_SHIFT_BA_CONTENT_L_8822B 0
#define BIT_MASK_BA_CONTENT_L_8822B 0xffffffffL
#define BIT_BA_CONTENT_L_8822B(x) \
(((x) & BIT_MASK_BA_CONTENT_L_8822B) << BIT_SHIFT_BA_CONTENT_L_8822B)
#define BITS_BA_CONTENT_L_8822B \
(BIT_MASK_BA_CONTENT_L_8822B << BIT_SHIFT_BA_CONTENT_L_8822B)
#define BIT_CLEAR_BA_CONTENT_L_8822B(x) ((x) & (~BITS_BA_CONTENT_L_8822B))
#define BIT_GET_BA_CONTENT_L_8822B(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_L_8822B) & BIT_MASK_BA_CONTENT_L_8822B)
#define BIT_SET_BA_CONTENT_L_8822B(x, v) \
(BIT_CLEAR_BA_CONTENT_L_8822B(x) | BIT_BA_CONTENT_L_8822B(v))
/* 2 REG_WMAC_BITMAP_CTL_8822B */
#define BIT_BITMAP_VO_8822B BIT(7)
#define BIT_BITMAP_VI_8822B BIT(6)
#define BIT_BITMAP_BE_8822B BIT(5)
#define BIT_BITMAP_BK_8822B BIT(4)
#define BIT_SHIFT_BITMAP_CONDITION_8822B 2
#define BIT_MASK_BITMAP_CONDITION_8822B 0x3
#define BIT_BITMAP_CONDITION_8822B(x) \
(((x) & BIT_MASK_BITMAP_CONDITION_8822B) \
<< BIT_SHIFT_BITMAP_CONDITION_8822B)
#define BITS_BITMAP_CONDITION_8822B \
(BIT_MASK_BITMAP_CONDITION_8822B << BIT_SHIFT_BITMAP_CONDITION_8822B)
#define BIT_CLEAR_BITMAP_CONDITION_8822B(x) \
((x) & (~BITS_BITMAP_CONDITION_8822B))
#define BIT_GET_BITMAP_CONDITION_8822B(x) \
(((x) >> BIT_SHIFT_BITMAP_CONDITION_8822B) & \
BIT_MASK_BITMAP_CONDITION_8822B)
#define BIT_SET_BITMAP_CONDITION_8822B(x, v) \
(BIT_CLEAR_BITMAP_CONDITION_8822B(x) | BIT_BITMAP_CONDITION_8822B(v))
#define BIT_BITMAP_SSNBK_COUNTER_CLR_8822B BIT(1)
#define BIT_BITMAP_FORCE_8822B BIT(0)
/* 2 REG_TX_RX_8822B STATUS */
#define BIT_SHIFT_RXPKT_TYPE_8822B 2
#define BIT_MASK_RXPKT_TYPE_8822B 0x3f
#define BIT_RXPKT_TYPE_8822B(x) \
(((x) & BIT_MASK_RXPKT_TYPE_8822B) << BIT_SHIFT_RXPKT_TYPE_8822B)
#define BITS_RXPKT_TYPE_8822B \
(BIT_MASK_RXPKT_TYPE_8822B << BIT_SHIFT_RXPKT_TYPE_8822B)
#define BIT_CLEAR_RXPKT_TYPE_8822B(x) ((x) & (~BITS_RXPKT_TYPE_8822B))
#define BIT_GET_RXPKT_TYPE_8822B(x) \
(((x) >> BIT_SHIFT_RXPKT_TYPE_8822B) & BIT_MASK_RXPKT_TYPE_8822B)
#define BIT_SET_RXPKT_TYPE_8822B(x, v) \
(BIT_CLEAR_RXPKT_TYPE_8822B(x) | BIT_RXPKT_TYPE_8822B(v))
#define BIT_TXACT_IND_8822B BIT(1)
#define BIT_RXACT_IND_8822B BIT(0)
/* 2 REG_WMAC_BACAM_RPMEN_8822B */
#define BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822B 2
#define BIT_MASK_BITMAP_SSNBK_COUNTER_8822B 0x3f
#define BIT_BITMAP_SSNBK_COUNTER_8822B(x) \
(((x) & BIT_MASK_BITMAP_SSNBK_COUNTER_8822B) \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822B)
#define BITS_BITMAP_SSNBK_COUNTER_8822B \
(BIT_MASK_BITMAP_SSNBK_COUNTER_8822B \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822B)
#define BIT_CLEAR_BITMAP_SSNBK_COUNTER_8822B(x) \
((x) & (~BITS_BITMAP_SSNBK_COUNTER_8822B))
#define BIT_GET_BITMAP_SSNBK_COUNTER_8822B(x) \
(((x) >> BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822B) & \
BIT_MASK_BITMAP_SSNBK_COUNTER_8822B)
#define BIT_SET_BITMAP_SSNBK_COUNTER_8822B(x, v) \
(BIT_CLEAR_BITMAP_SSNBK_COUNTER_8822B(x) | \
BIT_BITMAP_SSNBK_COUNTER_8822B(v))
#define BIT_BITMAP_EN_8822B BIT(1)
#define BIT_WMAC_BACAM_RPMEN_8822B BIT(0)
/* 2 REG_LBDLY_8822B (LOOPBACK DELAY REGISTER) */
#define BIT_SHIFT_LBDLY_8822B 0
#define BIT_MASK_LBDLY_8822B 0x1f
#define BIT_LBDLY_8822B(x) \
(((x) & BIT_MASK_LBDLY_8822B) << BIT_SHIFT_LBDLY_8822B)
#define BITS_LBDLY_8822B (BIT_MASK_LBDLY_8822B << BIT_SHIFT_LBDLY_8822B)
#define BIT_CLEAR_LBDLY_8822B(x) ((x) & (~BITS_LBDLY_8822B))
#define BIT_GET_LBDLY_8822B(x) \
(((x) >> BIT_SHIFT_LBDLY_8822B) & BIT_MASK_LBDLY_8822B)
#define BIT_SET_LBDLY_8822B(x, v) \
(BIT_CLEAR_LBDLY_8822B(x) | BIT_LBDLY_8822B(v))
/* 2 REG_RXERR_RPT_8822B (RX ERROR REPORT REGISTER) */
#define BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822B 28
#define BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822B 0xf
#define BIT_RXERR_RPT_SEL_V1_3_0_8822B(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822B) \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822B)
#define BITS_RXERR_RPT_SEL_V1_3_0_8822B \
(BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822B \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822B)
#define BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8822B(x) \
((x) & (~BITS_RXERR_RPT_SEL_V1_3_0_8822B))
#define BIT_GET_RXERR_RPT_SEL_V1_3_0_8822B(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822B) & \
BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822B)
#define BIT_SET_RXERR_RPT_SEL_V1_3_0_8822B(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8822B(x) | \
BIT_RXERR_RPT_SEL_V1_3_0_8822B(v))
#define BIT_RXERR_RPT_RST_8822B BIT(27)
#define BIT_RXERR_RPT_SEL_V1_4_8822B BIT(26)
#define BIT_W1S_8822B BIT(23)
#define BIT_UD_SELECT_BSSID_8822B BIT(22)
#define BIT_SHIFT_UD_SUB_TYPE_8822B 18
#define BIT_MASK_UD_SUB_TYPE_8822B 0xf
#define BIT_UD_SUB_TYPE_8822B(x) \
(((x) & BIT_MASK_UD_SUB_TYPE_8822B) << BIT_SHIFT_UD_SUB_TYPE_8822B)
#define BITS_UD_SUB_TYPE_8822B \
(BIT_MASK_UD_SUB_TYPE_8822B << BIT_SHIFT_UD_SUB_TYPE_8822B)
#define BIT_CLEAR_UD_SUB_TYPE_8822B(x) ((x) & (~BITS_UD_SUB_TYPE_8822B))
#define BIT_GET_UD_SUB_TYPE_8822B(x) \
(((x) >> BIT_SHIFT_UD_SUB_TYPE_8822B) & BIT_MASK_UD_SUB_TYPE_8822B)
#define BIT_SET_UD_SUB_TYPE_8822B(x, v) \
(BIT_CLEAR_UD_SUB_TYPE_8822B(x) | BIT_UD_SUB_TYPE_8822B(v))
#define BIT_SHIFT_UD_TYPE_8822B 16
#define BIT_MASK_UD_TYPE_8822B 0x3
#define BIT_UD_TYPE_8822B(x) \
(((x) & BIT_MASK_UD_TYPE_8822B) << BIT_SHIFT_UD_TYPE_8822B)
#define BITS_UD_TYPE_8822B (BIT_MASK_UD_TYPE_8822B << BIT_SHIFT_UD_TYPE_8822B)
#define BIT_CLEAR_UD_TYPE_8822B(x) ((x) & (~BITS_UD_TYPE_8822B))
#define BIT_GET_UD_TYPE_8822B(x) \
(((x) >> BIT_SHIFT_UD_TYPE_8822B) & BIT_MASK_UD_TYPE_8822B)
#define BIT_SET_UD_TYPE_8822B(x, v) \
(BIT_CLEAR_UD_TYPE_8822B(x) | BIT_UD_TYPE_8822B(v))
#define BIT_SHIFT_RPT_COUNTER_8822B 0
#define BIT_MASK_RPT_COUNTER_8822B 0xffff
#define BIT_RPT_COUNTER_8822B(x) \
(((x) & BIT_MASK_RPT_COUNTER_8822B) << BIT_SHIFT_RPT_COUNTER_8822B)
#define BITS_RPT_COUNTER_8822B \
(BIT_MASK_RPT_COUNTER_8822B << BIT_SHIFT_RPT_COUNTER_8822B)
#define BIT_CLEAR_RPT_COUNTER_8822B(x) ((x) & (~BITS_RPT_COUNTER_8822B))
#define BIT_GET_RPT_COUNTER_8822B(x) \
(((x) >> BIT_SHIFT_RPT_COUNTER_8822B) & BIT_MASK_RPT_COUNTER_8822B)
#define BIT_SET_RPT_COUNTER_8822B(x, v) \
(BIT_CLEAR_RPT_COUNTER_8822B(x) | BIT_RPT_COUNTER_8822B(v))
/* 2 REG_WMAC_TRXPTCL_CTL_8822B (WMAC TX/RX PROTOCOL CONTROL REGISTER) */
#define BIT_SHIFT_ACKBA_TYPSEL_8822B (60 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBA_TYPSEL_8822B 0xf
#define BIT_ACKBA_TYPSEL_8822B(x) \
(((x) & BIT_MASK_ACKBA_TYPSEL_8822B) << BIT_SHIFT_ACKBA_TYPSEL_8822B)
#define BITS_ACKBA_TYPSEL_8822B \
(BIT_MASK_ACKBA_TYPSEL_8822B << BIT_SHIFT_ACKBA_TYPSEL_8822B)
#define BIT_CLEAR_ACKBA_TYPSEL_8822B(x) ((x) & (~BITS_ACKBA_TYPSEL_8822B))
#define BIT_GET_ACKBA_TYPSEL_8822B(x) \
(((x) >> BIT_SHIFT_ACKBA_TYPSEL_8822B) & BIT_MASK_ACKBA_TYPSEL_8822B)
#define BIT_SET_ACKBA_TYPSEL_8822B(x, v) \
(BIT_CLEAR_ACKBA_TYPSEL_8822B(x) | BIT_ACKBA_TYPSEL_8822B(v))
#define BIT_SHIFT_ACKBA_ACKPCHK_8822B (56 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBA_ACKPCHK_8822B 0xf
#define BIT_ACKBA_ACKPCHK_8822B(x) \
(((x) & BIT_MASK_ACKBA_ACKPCHK_8822B) << BIT_SHIFT_ACKBA_ACKPCHK_8822B)
#define BITS_ACKBA_ACKPCHK_8822B \
(BIT_MASK_ACKBA_ACKPCHK_8822B << BIT_SHIFT_ACKBA_ACKPCHK_8822B)
#define BIT_CLEAR_ACKBA_ACKPCHK_8822B(x) ((x) & (~BITS_ACKBA_ACKPCHK_8822B))
#define BIT_GET_ACKBA_ACKPCHK_8822B(x) \
(((x) >> BIT_SHIFT_ACKBA_ACKPCHK_8822B) & BIT_MASK_ACKBA_ACKPCHK_8822B)
#define BIT_SET_ACKBA_ACKPCHK_8822B(x, v) \
(BIT_CLEAR_ACKBA_ACKPCHK_8822B(x) | BIT_ACKBA_ACKPCHK_8822B(v))
#define BIT_SHIFT_ACKBAR_TYPESEL_8822B (48 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBAR_TYPESEL_8822B 0xff
#define BIT_ACKBAR_TYPESEL_8822B(x) \
(((x) & BIT_MASK_ACKBAR_TYPESEL_8822B) \
<< BIT_SHIFT_ACKBAR_TYPESEL_8822B)
#define BITS_ACKBAR_TYPESEL_8822B \
(BIT_MASK_ACKBAR_TYPESEL_8822B << BIT_SHIFT_ACKBAR_TYPESEL_8822B)
#define BIT_CLEAR_ACKBAR_TYPESEL_8822B(x) ((x) & (~BITS_ACKBAR_TYPESEL_8822B))
#define BIT_GET_ACKBAR_TYPESEL_8822B(x) \
(((x) >> BIT_SHIFT_ACKBAR_TYPESEL_8822B) & \
BIT_MASK_ACKBAR_TYPESEL_8822B)
#define BIT_SET_ACKBAR_TYPESEL_8822B(x, v) \
(BIT_CLEAR_ACKBAR_TYPESEL_8822B(x) | BIT_ACKBAR_TYPESEL_8822B(v))
#define BIT_SHIFT_ACKBAR_ACKPCHK_8822B (44 & CPU_OPT_WIDTH)
#define BIT_MASK_ACKBAR_ACKPCHK_8822B 0xf
#define BIT_ACKBAR_ACKPCHK_8822B(x) \
(((x) & BIT_MASK_ACKBAR_ACKPCHK_8822B) \
<< BIT_SHIFT_ACKBAR_ACKPCHK_8822B)
#define BITS_ACKBAR_ACKPCHK_8822B \
(BIT_MASK_ACKBAR_ACKPCHK_8822B << BIT_SHIFT_ACKBAR_ACKPCHK_8822B)
#define BIT_CLEAR_ACKBAR_ACKPCHK_8822B(x) ((x) & (~BITS_ACKBAR_ACKPCHK_8822B))
#define BIT_GET_ACKBAR_ACKPCHK_8822B(x) \
(((x) >> BIT_SHIFT_ACKBAR_ACKPCHK_8822B) & \
BIT_MASK_ACKBAR_ACKPCHK_8822B)
#define BIT_SET_ACKBAR_ACKPCHK_8822B(x, v) \
(BIT_CLEAR_ACKBAR_ACKPCHK_8822B(x) | BIT_ACKBAR_ACKPCHK_8822B(v))
#define BIT_RXBA_IGNOREA2_8822B BIT(42)
#define BIT_EN_SAVE_ALL_TXOPADDR_8822B BIT(41)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV_8822B BIT(40)
#define BIT_DIS_TXBA_AMPDUFCSERR_8822B BIT(39)
#define BIT_DIS_TXBA_RXBARINFULL_8822B BIT(38)
#define BIT_DIS_TXCFE_INFULL_8822B BIT(37)
#define BIT_DIS_TXCTS_INFULL_8822B BIT(36)
#define BIT_EN_TXACKBA_IN_TX_RDG_8822B BIT(35)
#define BIT_EN_TXACKBA_IN_TXOP_8822B BIT(34)
#define BIT_EN_TXCTS_IN_RXNAV_8822B BIT(33)
#define BIT_EN_TXCTS_INTXOP_8822B BIT(32)
#define BIT_BLK_EDCA_BBSLP_8822B BIT(31)
#define BIT_BLK_EDCA_BBSBY_8822B BIT(30)
#define BIT_ACKTO_BLOCK_SCH_EN_8822B BIT(27)
#define BIT_EIFS_BLOCK_SCH_EN_8822B BIT(26)
#define BIT_PLCPCHK_RST_EIFS_8822B BIT(25)
#define BIT_CCA_RST_EIFS_8822B BIT(24)
#define BIT_DIS_UPD_MYRXPKTNAV_8822B BIT(23)
#define BIT_EARLY_TXBA_8822B BIT(22)
#define BIT_SHIFT_RESP_CHNBUSY_8822B 20
#define BIT_MASK_RESP_CHNBUSY_8822B 0x3
#define BIT_RESP_CHNBUSY_8822B(x) \
(((x) & BIT_MASK_RESP_CHNBUSY_8822B) << BIT_SHIFT_RESP_CHNBUSY_8822B)
#define BITS_RESP_CHNBUSY_8822B \
(BIT_MASK_RESP_CHNBUSY_8822B << BIT_SHIFT_RESP_CHNBUSY_8822B)
#define BIT_CLEAR_RESP_CHNBUSY_8822B(x) ((x) & (~BITS_RESP_CHNBUSY_8822B))
#define BIT_GET_RESP_CHNBUSY_8822B(x) \
(((x) >> BIT_SHIFT_RESP_CHNBUSY_8822B) & BIT_MASK_RESP_CHNBUSY_8822B)
#define BIT_SET_RESP_CHNBUSY_8822B(x, v) \
(BIT_CLEAR_RESP_CHNBUSY_8822B(x) | BIT_RESP_CHNBUSY_8822B(v))
#define BIT_RESP_DCTS_EN_8822B BIT(19)
#define BIT_RESP_DCFE_EN_8822B BIT(18)
#define BIT_RESP_SPLCPEN_8822B BIT(17)
#define BIT_RESP_SGIEN_8822B BIT(16)
#define BIT_RESP_LDPC_EN_8822B BIT(15)
#define BIT_DIS_RESP_ACKINCCA_8822B BIT(14)
#define BIT_DIS_RESP_CTSINCCA_8822B BIT(13)
#define BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822B 10
#define BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822B 0x7
#define BIT_R_WMAC_SECOND_CCA_TIMER_8822B(x) \
(((x) & BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822B) \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822B)
#define BITS_R_WMAC_SECOND_CCA_TIMER_8822B \
(BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822B \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822B)
#define BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8822B(x) \
((x) & (~BITS_R_WMAC_SECOND_CCA_TIMER_8822B))
#define BIT_GET_R_WMAC_SECOND_CCA_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822B) & \
BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822B)
#define BIT_SET_R_WMAC_SECOND_CCA_TIMER_8822B(x, v) \
(BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8822B(x) | \
BIT_R_WMAC_SECOND_CCA_TIMER_8822B(v))
#define BIT_SHIFT_RFMOD_8822B 7
#define BIT_MASK_RFMOD_8822B 0x3
#define BIT_RFMOD_8822B(x) \
(((x) & BIT_MASK_RFMOD_8822B) << BIT_SHIFT_RFMOD_8822B)
#define BITS_RFMOD_8822B (BIT_MASK_RFMOD_8822B << BIT_SHIFT_RFMOD_8822B)
#define BIT_CLEAR_RFMOD_8822B(x) ((x) & (~BITS_RFMOD_8822B))
#define BIT_GET_RFMOD_8822B(x) \
(((x) >> BIT_SHIFT_RFMOD_8822B) & BIT_MASK_RFMOD_8822B)
#define BIT_SET_RFMOD_8822B(x, v) \
(BIT_CLEAR_RFMOD_8822B(x) | BIT_RFMOD_8822B(v))
#define BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822B 5
#define BIT_MASK_RESP_CTS_DYNBW_SEL_8822B 0x3
#define BIT_RESP_CTS_DYNBW_SEL_8822B(x) \
(((x) & BIT_MASK_RESP_CTS_DYNBW_SEL_8822B) \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822B)
#define BITS_RESP_CTS_DYNBW_SEL_8822B \
(BIT_MASK_RESP_CTS_DYNBW_SEL_8822B \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822B)
#define BIT_CLEAR_RESP_CTS_DYNBW_SEL_8822B(x) \
((x) & (~BITS_RESP_CTS_DYNBW_SEL_8822B))
#define BIT_GET_RESP_CTS_DYNBW_SEL_8822B(x) \
(((x) >> BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822B) & \
BIT_MASK_RESP_CTS_DYNBW_SEL_8822B)
#define BIT_SET_RESP_CTS_DYNBW_SEL_8822B(x, v) \
(BIT_CLEAR_RESP_CTS_DYNBW_SEL_8822B(x) | \
BIT_RESP_CTS_DYNBW_SEL_8822B(v))
#define BIT_DLY_TX_WAIT_RXANTSEL_8822B BIT(4)
#define BIT_TXRESP_BY_RXANTSEL_8822B BIT(3)
#define BIT_SHIFT_ORIG_DCTS_CHK_8822B 0
#define BIT_MASK_ORIG_DCTS_CHK_8822B 0x3
#define BIT_ORIG_DCTS_CHK_8822B(x) \
(((x) & BIT_MASK_ORIG_DCTS_CHK_8822B) << BIT_SHIFT_ORIG_DCTS_CHK_8822B)
#define BITS_ORIG_DCTS_CHK_8822B \
(BIT_MASK_ORIG_DCTS_CHK_8822B << BIT_SHIFT_ORIG_DCTS_CHK_8822B)
#define BIT_CLEAR_ORIG_DCTS_CHK_8822B(x) ((x) & (~BITS_ORIG_DCTS_CHK_8822B))
#define BIT_GET_ORIG_DCTS_CHK_8822B(x) \
(((x) >> BIT_SHIFT_ORIG_DCTS_CHK_8822B) & BIT_MASK_ORIG_DCTS_CHK_8822B)
#define BIT_SET_ORIG_DCTS_CHK_8822B(x, v) \
(BIT_CLEAR_ORIG_DCTS_CHK_8822B(x) | BIT_ORIG_DCTS_CHK_8822B(v))
/* 2 REG_CAMCMD_8822B (CAM COMMAND REGISTER) */
#define BIT_SECCAM_POLLING_8822B BIT(31)
#define BIT_SECCAM_CLR_8822B BIT(30)
#define BIT_MFBCAM_CLR_8822B BIT(29)
#define BIT_SECCAM_WE_8822B BIT(16)
#define BIT_SHIFT_SECCAM_ADDR_V2_8822B 0
#define BIT_MASK_SECCAM_ADDR_V2_8822B 0x3ff
#define BIT_SECCAM_ADDR_V2_8822B(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V2_8822B) \
<< BIT_SHIFT_SECCAM_ADDR_V2_8822B)
#define BITS_SECCAM_ADDR_V2_8822B \
(BIT_MASK_SECCAM_ADDR_V2_8822B << BIT_SHIFT_SECCAM_ADDR_V2_8822B)
#define BIT_CLEAR_SECCAM_ADDR_V2_8822B(x) ((x) & (~BITS_SECCAM_ADDR_V2_8822B))
#define BIT_GET_SECCAM_ADDR_V2_8822B(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V2_8822B) & \
BIT_MASK_SECCAM_ADDR_V2_8822B)
#define BIT_SET_SECCAM_ADDR_V2_8822B(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V2_8822B(x) | BIT_SECCAM_ADDR_V2_8822B(v))
/* 2 REG_CAMWRITE_8822B (CAM WRITE REGISTER) */
#define BIT_SHIFT_CAMW_DATA_8822B 0
#define BIT_MASK_CAMW_DATA_8822B 0xffffffffL
#define BIT_CAMW_DATA_8822B(x) \
(((x) & BIT_MASK_CAMW_DATA_8822B) << BIT_SHIFT_CAMW_DATA_8822B)
#define BITS_CAMW_DATA_8822B \
(BIT_MASK_CAMW_DATA_8822B << BIT_SHIFT_CAMW_DATA_8822B)
#define BIT_CLEAR_CAMW_DATA_8822B(x) ((x) & (~BITS_CAMW_DATA_8822B))
#define BIT_GET_CAMW_DATA_8822B(x) \
(((x) >> BIT_SHIFT_CAMW_DATA_8822B) & BIT_MASK_CAMW_DATA_8822B)
#define BIT_SET_CAMW_DATA_8822B(x, v) \
(BIT_CLEAR_CAMW_DATA_8822B(x) | BIT_CAMW_DATA_8822B(v))
/* 2 REG_CAMREAD_8822B (CAM READ REGISTER) */
#define BIT_SHIFT_CAMR_DATA_8822B 0
#define BIT_MASK_CAMR_DATA_8822B 0xffffffffL
#define BIT_CAMR_DATA_8822B(x) \
(((x) & BIT_MASK_CAMR_DATA_8822B) << BIT_SHIFT_CAMR_DATA_8822B)
#define BITS_CAMR_DATA_8822B \
(BIT_MASK_CAMR_DATA_8822B << BIT_SHIFT_CAMR_DATA_8822B)
#define BIT_CLEAR_CAMR_DATA_8822B(x) ((x) & (~BITS_CAMR_DATA_8822B))
#define BIT_GET_CAMR_DATA_8822B(x) \
(((x) >> BIT_SHIFT_CAMR_DATA_8822B) & BIT_MASK_CAMR_DATA_8822B)
#define BIT_SET_CAMR_DATA_8822B(x, v) \
(BIT_CLEAR_CAMR_DATA_8822B(x) | BIT_CAMR_DATA_8822B(v))
/* 2 REG_CAMDBG_8822B (CAM DEBUG REGISTER) */
#define BIT_SECCAM_INFO_8822B BIT(31)
#define BIT_SEC_KEYFOUND_8822B BIT(15)
#define BIT_SHIFT_CAMDBG_SEC_TYPE_8822B 12
#define BIT_MASK_CAMDBG_SEC_TYPE_8822B 0x7
#define BIT_CAMDBG_SEC_TYPE_8822B(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE_8822B) \
<< BIT_SHIFT_CAMDBG_SEC_TYPE_8822B)
#define BITS_CAMDBG_SEC_TYPE_8822B \
(BIT_MASK_CAMDBG_SEC_TYPE_8822B << BIT_SHIFT_CAMDBG_SEC_TYPE_8822B)
#define BIT_CLEAR_CAMDBG_SEC_TYPE_8822B(x) ((x) & (~BITS_CAMDBG_SEC_TYPE_8822B))
#define BIT_GET_CAMDBG_SEC_TYPE_8822B(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE_8822B) & \
BIT_MASK_CAMDBG_SEC_TYPE_8822B)
#define BIT_SET_CAMDBG_SEC_TYPE_8822B(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE_8822B(x) | BIT_CAMDBG_SEC_TYPE_8822B(v))
#define BIT_CAMDBG_EXT_SECTYPE_8822B BIT(11)
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822B 5
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_8822B 0x1f
#define BIT_CAMDBG_MIC_KEY_IDX_8822B(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_8822B) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822B)
#define BITS_CAMDBG_MIC_KEY_IDX_8822B \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_8822B \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822B)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8822B(x) \
((x) & (~BITS_CAMDBG_MIC_KEY_IDX_8822B))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_8822B(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822B) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_8822B)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_8822B(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8822B(x) | \
BIT_CAMDBG_MIC_KEY_IDX_8822B(v))
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822B 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_8822B 0x1f
#define BIT_CAMDBG_SEC_KEY_IDX_8822B(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_8822B) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822B)
#define BITS_CAMDBG_SEC_KEY_IDX_8822B \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_8822B \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822B)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8822B(x) \
((x) & (~BITS_CAMDBG_SEC_KEY_IDX_8822B))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_8822B(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822B) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_8822B)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_8822B(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8822B(x) | \
BIT_CAMDBG_SEC_KEY_IDX_8822B(v))
/* 2 REG_RXFILTER_ACTION_1_8822B */
#define BIT_SHIFT_RXFILTER_ACTION_1_8822B 0
#define BIT_MASK_RXFILTER_ACTION_1_8822B 0xff
#define BIT_RXFILTER_ACTION_1_8822B(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_1_8822B) \
<< BIT_SHIFT_RXFILTER_ACTION_1_8822B)
#define BITS_RXFILTER_ACTION_1_8822B \
(BIT_MASK_RXFILTER_ACTION_1_8822B << BIT_SHIFT_RXFILTER_ACTION_1_8822B)
#define BIT_CLEAR_RXFILTER_ACTION_1_8822B(x) \
((x) & (~BITS_RXFILTER_ACTION_1_8822B))
#define BIT_GET_RXFILTER_ACTION_1_8822B(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_1_8822B) & \
BIT_MASK_RXFILTER_ACTION_1_8822B)
#define BIT_SET_RXFILTER_ACTION_1_8822B(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_1_8822B(x) | BIT_RXFILTER_ACTION_1_8822B(v))
/* 2 REG_RXFILTER_CATEGORY_1_8822B */
#define BIT_SHIFT_RXFILTER_CATEGORY_1_8822B 0
#define BIT_MASK_RXFILTER_CATEGORY_1_8822B 0xff
#define BIT_RXFILTER_CATEGORY_1_8822B(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_1_8822B) \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8822B)
#define BITS_RXFILTER_CATEGORY_1_8822B \
(BIT_MASK_RXFILTER_CATEGORY_1_8822B \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8822B)
#define BIT_CLEAR_RXFILTER_CATEGORY_1_8822B(x) \
((x) & (~BITS_RXFILTER_CATEGORY_1_8822B))
#define BIT_GET_RXFILTER_CATEGORY_1_8822B(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_1_8822B) & \
BIT_MASK_RXFILTER_CATEGORY_1_8822B)
#define BIT_SET_RXFILTER_CATEGORY_1_8822B(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_1_8822B(x) | \
BIT_RXFILTER_CATEGORY_1_8822B(v))
/* 2 REG_SECCFG_8822B (SECURITY CONFIGURATION REGISTER) */
#define BIT_DIS_GCLK_WAPI_8822B BIT(15)
#define BIT_DIS_GCLK_AES_8822B BIT(14)
#define BIT_DIS_GCLK_TKIP_8822B BIT(13)
#define BIT_AES_SEL_QC_1_8822B BIT(12)
#define BIT_AES_SEL_QC_0_8822B BIT(11)
#define BIT_CHK_BMC_8822B BIT(9)
#define BIT_CHK_KEYID_8822B BIT(8)
#define BIT_RXBCUSEDK_8822B BIT(7)
#define BIT_TXBCUSEDK_8822B BIT(6)
#define BIT_NOSKMC_8822B BIT(5)
#define BIT_SKBYA2_8822B BIT(4)
#define BIT_RXDEC_8822B BIT(3)
#define BIT_TXENC_8822B BIT(2)
#define BIT_RXUHUSEDK_8822B BIT(1)
#define BIT_TXUHUSEDK_8822B BIT(0)
/* 2 REG_RXFILTER_ACTION_3_8822B */
#define BIT_SHIFT_RXFILTER_ACTION_3_8822B 0
#define BIT_MASK_RXFILTER_ACTION_3_8822B 0xff
#define BIT_RXFILTER_ACTION_3_8822B(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_3_8822B) \
<< BIT_SHIFT_RXFILTER_ACTION_3_8822B)
#define BITS_RXFILTER_ACTION_3_8822B \
(BIT_MASK_RXFILTER_ACTION_3_8822B << BIT_SHIFT_RXFILTER_ACTION_3_8822B)
#define BIT_CLEAR_RXFILTER_ACTION_3_8822B(x) \
((x) & (~BITS_RXFILTER_ACTION_3_8822B))
#define BIT_GET_RXFILTER_ACTION_3_8822B(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_3_8822B) & \
BIT_MASK_RXFILTER_ACTION_3_8822B)
#define BIT_SET_RXFILTER_ACTION_3_8822B(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_3_8822B(x) | BIT_RXFILTER_ACTION_3_8822B(v))
/* 2 REG_RXFILTER_CATEGORY_3_8822B */
#define BIT_SHIFT_RXFILTER_CATEGORY_3_8822B 0
#define BIT_MASK_RXFILTER_CATEGORY_3_8822B 0xff
#define BIT_RXFILTER_CATEGORY_3_8822B(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_3_8822B) \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8822B)
#define BITS_RXFILTER_CATEGORY_3_8822B \
(BIT_MASK_RXFILTER_CATEGORY_3_8822B \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8822B)
#define BIT_CLEAR_RXFILTER_CATEGORY_3_8822B(x) \
((x) & (~BITS_RXFILTER_CATEGORY_3_8822B))
#define BIT_GET_RXFILTER_CATEGORY_3_8822B(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_3_8822B) & \
BIT_MASK_RXFILTER_CATEGORY_3_8822B)
#define BIT_SET_RXFILTER_CATEGORY_3_8822B(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_3_8822B(x) | \
BIT_RXFILTER_CATEGORY_3_8822B(v))
/* 2 REG_RXFILTER_ACTION_2_8822B */
#define BIT_SHIFT_RXFILTER_ACTION_2_8822B 0
#define BIT_MASK_RXFILTER_ACTION_2_8822B 0xff
#define BIT_RXFILTER_ACTION_2_8822B(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_2_8822B) \
<< BIT_SHIFT_RXFILTER_ACTION_2_8822B)
#define BITS_RXFILTER_ACTION_2_8822B \
(BIT_MASK_RXFILTER_ACTION_2_8822B << BIT_SHIFT_RXFILTER_ACTION_2_8822B)
#define BIT_CLEAR_RXFILTER_ACTION_2_8822B(x) \
((x) & (~BITS_RXFILTER_ACTION_2_8822B))
#define BIT_GET_RXFILTER_ACTION_2_8822B(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_2_8822B) & \
BIT_MASK_RXFILTER_ACTION_2_8822B)
#define BIT_SET_RXFILTER_ACTION_2_8822B(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_2_8822B(x) | BIT_RXFILTER_ACTION_2_8822B(v))
/* 2 REG_RXFILTER_CATEGORY_2_8822B */
#define BIT_SHIFT_RXFILTER_CATEGORY_2_8822B 0
#define BIT_MASK_RXFILTER_CATEGORY_2_8822B 0xff
#define BIT_RXFILTER_CATEGORY_2_8822B(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_2_8822B) \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8822B)
#define BITS_RXFILTER_CATEGORY_2_8822B \
(BIT_MASK_RXFILTER_CATEGORY_2_8822B \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8822B)
#define BIT_CLEAR_RXFILTER_CATEGORY_2_8822B(x) \
((x) & (~BITS_RXFILTER_CATEGORY_2_8822B))
#define BIT_GET_RXFILTER_CATEGORY_2_8822B(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_2_8822B) & \
BIT_MASK_RXFILTER_CATEGORY_2_8822B)
#define BIT_SET_RXFILTER_CATEGORY_2_8822B(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_2_8822B(x) | \
BIT_RXFILTER_CATEGORY_2_8822B(v))
/* 2 REG_RXFLTMAP4_8822B (RX FILTER MAP GROUP 4) */
#define BIT_CTRLFLT15EN_FW_8822B BIT(15)
#define BIT_CTRLFLT14EN_FW_8822B BIT(14)
#define BIT_CTRLFLT13EN_FW_8822B BIT(13)
#define BIT_CTRLFLT12EN_FW_8822B BIT(12)
#define BIT_CTRLFLT11EN_FW_8822B BIT(11)
#define BIT_CTRLFLT10EN_FW_8822B BIT(10)
#define BIT_CTRLFLT9EN_FW_8822B BIT(9)
#define BIT_CTRLFLT8EN_FW_8822B BIT(8)
#define BIT_CTRLFLT7EN_FW_8822B BIT(7)
#define BIT_CTRLFLT6EN_FW_8822B BIT(6)
#define BIT_CTRLFLT5EN_FW_8822B BIT(5)
#define BIT_CTRLFLT4EN_FW_8822B BIT(4)
#define BIT_CTRLFLT3EN_FW_8822B BIT(3)
#define BIT_CTRLFLT2EN_FW_8822B BIT(2)
#define BIT_CTRLFLT1EN_FW_8822B BIT(1)
#define BIT_CTRLFLT0EN_FW_8822B BIT(0)
/* 2 REG_RXFLTMAP3_8822B (RX FILTER MAP GROUP 3) */
#define BIT_MGTFLT15EN_FW_8822B BIT(15)
#define BIT_MGTFLT14EN_FW_8822B BIT(14)
#define BIT_MGTFLT13EN_FW_8822B BIT(13)
#define BIT_MGTFLT12EN_FW_8822B BIT(12)
#define BIT_MGTFLT11EN_FW_8822B BIT(11)
#define BIT_MGTFLT10EN_FW_8822B BIT(10)
#define BIT_MGTFLT9EN_FW_8822B BIT(9)
#define BIT_MGTFLT8EN_FW_8822B BIT(8)
#define BIT_MGTFLT7EN_FW_8822B BIT(7)
#define BIT_MGTFLT6EN_FW_8822B BIT(6)
#define BIT_MGTFLT5EN_FW_8822B BIT(5)
#define BIT_MGTFLT4EN_FW_8822B BIT(4)
#define BIT_MGTFLT3EN_FW_8822B BIT(3)
#define BIT_MGTFLT2EN_FW_8822B BIT(2)
#define BIT_MGTFLT1EN_FW_8822B BIT(1)
#define BIT_MGTFLT0EN_FW_8822B BIT(0)
/* 2 REG_RXFLTMAP6_8822B (RX FILTER MAP GROUP 6) */
#define BIT_ACTIONFLT15EN_FW_8822B BIT(15)
#define BIT_ACTIONFLT14EN_FW_8822B BIT(14)
#define BIT_ACTIONFLT13EN_FW_8822B BIT(13)
#define BIT_ACTIONFLT12EN_FW_8822B BIT(12)
#define BIT_ACTIONFLT11EN_FW_8822B BIT(11)
#define BIT_ACTIONFLT10EN_FW_8822B BIT(10)
#define BIT_ACTIONFLT9EN_FW_8822B BIT(9)
#define BIT_ACTIONFLT8EN_FW_8822B BIT(8)
#define BIT_ACTIONFLT7EN_FW_8822B BIT(7)
#define BIT_ACTIONFLT6EN_FW_8822B BIT(6)
#define BIT_ACTIONFLT5EN_FW_8822B BIT(5)
#define BIT_ACTIONFLT4EN_FW_8822B BIT(4)
#define BIT_ACTIONFLT3EN_FW_8822B BIT(3)
#define BIT_ACTIONFLT2EN_FW_8822B BIT(2)
#define BIT_ACTIONFLT1EN_FW_8822B BIT(1)
#define BIT_ACTIONFLT0EN_FW_8822B BIT(0)
/* 2 REG_RXFLTMAP5_8822B (RX FILTER MAP GROUP 5) */
#define BIT_DATAFLT15EN_FW_8822B BIT(15)
#define BIT_DATAFLT14EN_FW_8822B BIT(14)
#define BIT_DATAFLT13EN_FW_8822B BIT(13)
#define BIT_DATAFLT12EN_FW_8822B BIT(12)
#define BIT_DATAFLT11EN_FW_8822B BIT(11)
#define BIT_DATAFLT10EN_FW_8822B BIT(10)
#define BIT_DATAFLT9EN_FW_8822B BIT(9)
#define BIT_DATAFLT8EN_FW_8822B BIT(8)
#define BIT_DATAFLT7EN_FW_8822B BIT(7)
#define BIT_DATAFLT6EN_FW_8822B BIT(6)
#define BIT_DATAFLT5EN_FW_8822B BIT(5)
#define BIT_DATAFLT4EN_FW_8822B BIT(4)
#define BIT_DATAFLT3EN_FW_8822B BIT(3)
#define BIT_DATAFLT2EN_FW_8822B BIT(2)
#define BIT_DATAFLT1EN_FW_8822B BIT(1)
#define BIT_DATAFLT0EN_FW_8822B BIT(0)
/* 2 REG_WMMPS_UAPSD_TID_8822B (WMM POWER SAVE UAPSD TID REGISTER) */
#define BIT_WMMPS_UAPSD_TID7_8822B BIT(7)
#define BIT_WMMPS_UAPSD_TID6_8822B BIT(6)
#define BIT_WMMPS_UAPSD_TID5_8822B BIT(5)
#define BIT_WMMPS_UAPSD_TID4_8822B BIT(4)
#define BIT_WMMPS_UAPSD_TID3_8822B BIT(3)
#define BIT_WMMPS_UAPSD_TID2_8822B BIT(2)
#define BIT_WMMPS_UAPSD_TID1_8822B BIT(1)
#define BIT_WMMPS_UAPSD_TID0_8822B BIT(0)
/* 2 REG_PS_RX_INFO_8822B (POWER SAVE RX INFORMATION REGISTER) */
#define BIT_SHIFT_PORTSEL__PS_RX_INFO_8822B 5
#define BIT_MASK_PORTSEL__PS_RX_INFO_8822B 0x7
#define BIT_PORTSEL__PS_RX_INFO_8822B(x) \
(((x) & BIT_MASK_PORTSEL__PS_RX_INFO_8822B) \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8822B)
#define BITS_PORTSEL__PS_RX_INFO_8822B \
(BIT_MASK_PORTSEL__PS_RX_INFO_8822B \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8822B)
#define BIT_CLEAR_PORTSEL__PS_RX_INFO_8822B(x) \
((x) & (~BITS_PORTSEL__PS_RX_INFO_8822B))
#define BIT_GET_PORTSEL__PS_RX_INFO_8822B(x) \
(((x) >> BIT_SHIFT_PORTSEL__PS_RX_INFO_8822B) & \
BIT_MASK_PORTSEL__PS_RX_INFO_8822B)
#define BIT_SET_PORTSEL__PS_RX_INFO_8822B(x, v) \
(BIT_CLEAR_PORTSEL__PS_RX_INFO_8822B(x) | \
BIT_PORTSEL__PS_RX_INFO_8822B(v))
#define BIT_RXCTRLIN0_8822B BIT(4)
#define BIT_RXMGTIN0_8822B BIT(3)
#define BIT_RXDATAIN2_8822B BIT(2)
#define BIT_RXDATAIN1_8822B BIT(1)
#define BIT_RXDATAIN0_8822B BIT(0)
/* 2 REG_NAN_RX_TSF_FILTER_8822B(NAN_RX_TSF_ADDRESS_FILTER) */
#define BIT_CHK_TSF_TA_8822B BIT(2)
#define BIT_CHK_TSF_CBSSID_8822B BIT(1)
#define BIT_CHK_TSF_EN_8822B BIT(0)
/* 2 REG_WOW_CTRL_8822B (WAKE ON WLAN CONTROL REGISTER) */
#define BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822B 6
#define BIT_MASK_PSF_BSSIDSEL_B2B1_8822B 0x3
#define BIT_PSF_BSSIDSEL_B2B1_8822B(x) \
(((x) & BIT_MASK_PSF_BSSIDSEL_B2B1_8822B) \
<< BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822B)
#define BITS_PSF_BSSIDSEL_B2B1_8822B \
(BIT_MASK_PSF_BSSIDSEL_B2B1_8822B << BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822B)
#define BIT_CLEAR_PSF_BSSIDSEL_B2B1_8822B(x) \
((x) & (~BITS_PSF_BSSIDSEL_B2B1_8822B))
#define BIT_GET_PSF_BSSIDSEL_B2B1_8822B(x) \
(((x) >> BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822B) & \
BIT_MASK_PSF_BSSIDSEL_B2B1_8822B)
#define BIT_SET_PSF_BSSIDSEL_B2B1_8822B(x, v) \
(BIT_CLEAR_PSF_BSSIDSEL_B2B1_8822B(x) | BIT_PSF_BSSIDSEL_B2B1_8822B(v))
#define BIT_WOWHCI_8822B BIT(5)
#define BIT_PSF_BSSIDSEL_B0_8822B BIT(4)
#define BIT_UWF_8822B BIT(3)
#define BIT_MAGIC_8822B BIT(2)
#define BIT_WOWEN_8822B BIT(1)
#define BIT_FORCE_WAKEUP_8822B BIT(0)
/* 2 REG_LPNAV_CTRL_8822B (LOW POWER NAV CONTROL REGISTER) */
#define BIT_LPNAV_EN_8822B BIT(31)
#define BIT_SHIFT_LPNAV_EARLY_8822B 16
#define BIT_MASK_LPNAV_EARLY_8822B 0x7fff
#define BIT_LPNAV_EARLY_8822B(x) \
(((x) & BIT_MASK_LPNAV_EARLY_8822B) << BIT_SHIFT_LPNAV_EARLY_8822B)
#define BITS_LPNAV_EARLY_8822B \
(BIT_MASK_LPNAV_EARLY_8822B << BIT_SHIFT_LPNAV_EARLY_8822B)
#define BIT_CLEAR_LPNAV_EARLY_8822B(x) ((x) & (~BITS_LPNAV_EARLY_8822B))
#define BIT_GET_LPNAV_EARLY_8822B(x) \
(((x) >> BIT_SHIFT_LPNAV_EARLY_8822B) & BIT_MASK_LPNAV_EARLY_8822B)
#define BIT_SET_LPNAV_EARLY_8822B(x, v) \
(BIT_CLEAR_LPNAV_EARLY_8822B(x) | BIT_LPNAV_EARLY_8822B(v))
#define BIT_SHIFT_LPNAV_TH_8822B 0
#define BIT_MASK_LPNAV_TH_8822B 0xffff
#define BIT_LPNAV_TH_8822B(x) \
(((x) & BIT_MASK_LPNAV_TH_8822B) << BIT_SHIFT_LPNAV_TH_8822B)
#define BITS_LPNAV_TH_8822B \
(BIT_MASK_LPNAV_TH_8822B << BIT_SHIFT_LPNAV_TH_8822B)
#define BIT_CLEAR_LPNAV_TH_8822B(x) ((x) & (~BITS_LPNAV_TH_8822B))
#define BIT_GET_LPNAV_TH_8822B(x) \
(((x) >> BIT_SHIFT_LPNAV_TH_8822B) & BIT_MASK_LPNAV_TH_8822B)
#define BIT_SET_LPNAV_TH_8822B(x, v) \
(BIT_CLEAR_LPNAV_TH_8822B(x) | BIT_LPNAV_TH_8822B(v))
/* 2 REG_WKFMCAM_CMD_8822B (WAKEUP FRAME CAM COMMAND REGISTER) */
#define BIT_WKFCAM_POLLING_V1_8822B BIT(31)
#define BIT_WKFCAM_CLR_V1_8822B BIT(30)
#define BIT_WKFCAM_WE_8822B BIT(16)
#define BIT_SHIFT_WKFCAM_ADDR_V2_8822B 8
#define BIT_MASK_WKFCAM_ADDR_V2_8822B 0xff
#define BIT_WKFCAM_ADDR_V2_8822B(x) \
(((x) & BIT_MASK_WKFCAM_ADDR_V2_8822B) \
<< BIT_SHIFT_WKFCAM_ADDR_V2_8822B)
#define BITS_WKFCAM_ADDR_V2_8822B \
(BIT_MASK_WKFCAM_ADDR_V2_8822B << BIT_SHIFT_WKFCAM_ADDR_V2_8822B)
#define BIT_CLEAR_WKFCAM_ADDR_V2_8822B(x) ((x) & (~BITS_WKFCAM_ADDR_V2_8822B))
#define BIT_GET_WKFCAM_ADDR_V2_8822B(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR_V2_8822B) & \
BIT_MASK_WKFCAM_ADDR_V2_8822B)
#define BIT_SET_WKFCAM_ADDR_V2_8822B(x, v) \
(BIT_CLEAR_WKFCAM_ADDR_V2_8822B(x) | BIT_WKFCAM_ADDR_V2_8822B(v))
#define BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822B 0
#define BIT_MASK_WKFCAM_CAM_NUM_V1_8822B 0xff
#define BIT_WKFCAM_CAM_NUM_V1_8822B(x) \
(((x) & BIT_MASK_WKFCAM_CAM_NUM_V1_8822B) \
<< BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822B)
#define BITS_WKFCAM_CAM_NUM_V1_8822B \
(BIT_MASK_WKFCAM_CAM_NUM_V1_8822B << BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822B)
#define BIT_CLEAR_WKFCAM_CAM_NUM_V1_8822B(x) \
((x) & (~BITS_WKFCAM_CAM_NUM_V1_8822B))
#define BIT_GET_WKFCAM_CAM_NUM_V1_8822B(x) \
(((x) >> BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822B) & \
BIT_MASK_WKFCAM_CAM_NUM_V1_8822B)
#define BIT_SET_WKFCAM_CAM_NUM_V1_8822B(x, v) \
(BIT_CLEAR_WKFCAM_CAM_NUM_V1_8822B(x) | BIT_WKFCAM_CAM_NUM_V1_8822B(v))
/* 2 REG_WKFMCAM_RWD_8822B (WAKEUP FRAME READ/WRITE DATA) */
#define BIT_SHIFT_WKFMCAM_RWD_8822B 0
#define BIT_MASK_WKFMCAM_RWD_8822B 0xffffffffL
#define BIT_WKFMCAM_RWD_8822B(x) \
(((x) & BIT_MASK_WKFMCAM_RWD_8822B) << BIT_SHIFT_WKFMCAM_RWD_8822B)
#define BITS_WKFMCAM_RWD_8822B \
(BIT_MASK_WKFMCAM_RWD_8822B << BIT_SHIFT_WKFMCAM_RWD_8822B)
#define BIT_CLEAR_WKFMCAM_RWD_8822B(x) ((x) & (~BITS_WKFMCAM_RWD_8822B))
#define BIT_GET_WKFMCAM_RWD_8822B(x) \
(((x) >> BIT_SHIFT_WKFMCAM_RWD_8822B) & BIT_MASK_WKFMCAM_RWD_8822B)
#define BIT_SET_WKFMCAM_RWD_8822B(x, v) \
(BIT_CLEAR_WKFMCAM_RWD_8822B(x) | BIT_WKFMCAM_RWD_8822B(v))
/* 2 REG_RXFLTMAP1_8822B (RX FILTER MAP GROUP 1) */
#define BIT_CTRLFLT15EN_8822B BIT(15)
#define BIT_CTRLFLT14EN_8822B BIT(14)
#define BIT_CTRLFLT13EN_8822B BIT(13)
#define BIT_CTRLFLT12EN_8822B BIT(12)
#define BIT_CTRLFLT11EN_8822B BIT(11)
#define BIT_CTRLFLT10EN_8822B BIT(10)
#define BIT_CTRLFLT9EN_8822B BIT(9)
#define BIT_CTRLFLT8EN_8822B BIT(8)
#define BIT_CTRLFLT7EN_8822B BIT(7)
#define BIT_CTRLFLT6EN_8822B BIT(6)
#define BIT_CTRLFLT5EN_8822B BIT(5)
#define BIT_CTRLFLT4EN_8822B BIT(4)
#define BIT_CTRLFLT3EN_8822B BIT(3)
#define BIT_CTRLFLT2EN_8822B BIT(2)
#define BIT_CTRLFLT1EN_8822B BIT(1)
#define BIT_CTRLFLT0EN_8822B BIT(0)
/* 2 REG_RXFLTMAP0_8822B (RX FILTER MAP GROUP 0) */
#define BIT_MGTFLT15EN_8822B BIT(15)
#define BIT_MGTFLT14EN_8822B BIT(14)
#define BIT_MGTFLT13EN_8822B BIT(13)
#define BIT_MGTFLT12EN_8822B BIT(12)
#define BIT_MGTFLT11EN_8822B BIT(11)
#define BIT_MGTFLT10EN_8822B BIT(10)
#define BIT_MGTFLT9EN_8822B BIT(9)
#define BIT_MGTFLT8EN_8822B BIT(8)
#define BIT_MGTFLT7EN_8822B BIT(7)
#define BIT_MGTFLT6EN_8822B BIT(6)
#define BIT_MGTFLT5EN_8822B BIT(5)
#define BIT_MGTFLT4EN_8822B BIT(4)
#define BIT_MGTFLT3EN_8822B BIT(3)
#define BIT_MGTFLT2EN_8822B BIT(2)
#define BIT_MGTFLT1EN_8822B BIT(1)
#define BIT_MGTFLT0EN_8822B BIT(0)
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_RXFLTMAP2_8822B (RX FILTER MAP GROUP 2) */
#define BIT_DATAFLT15EN_8822B BIT(15)
#define BIT_DATAFLT14EN_8822B BIT(14)
#define BIT_DATAFLT13EN_8822B BIT(13)
#define BIT_DATAFLT12EN_8822B BIT(12)
#define BIT_DATAFLT11EN_8822B BIT(11)
#define BIT_DATAFLT10EN_8822B BIT(10)
#define BIT_DATAFLT9EN_8822B BIT(9)
#define BIT_DATAFLT8EN_8822B BIT(8)
#define BIT_DATAFLT7EN_8822B BIT(7)
#define BIT_DATAFLT6EN_8822B BIT(6)
#define BIT_DATAFLT5EN_8822B BIT(5)
#define BIT_DATAFLT4EN_8822B BIT(4)
#define BIT_DATAFLT3EN_8822B BIT(3)
#define BIT_DATAFLT2EN_8822B BIT(2)
#define BIT_DATAFLT1EN_8822B BIT(1)
#define BIT_DATAFLT0EN_8822B BIT(0)
/* 2 REG_BCN_PSR_RPT_8822B (BEACON PARSER REPORT REGISTER) */
#define BIT_SHIFT_DTIM_CNT_8822B 24
#define BIT_MASK_DTIM_CNT_8822B 0xff
#define BIT_DTIM_CNT_8822B(x) \
(((x) & BIT_MASK_DTIM_CNT_8822B) << BIT_SHIFT_DTIM_CNT_8822B)
#define BITS_DTIM_CNT_8822B \
(BIT_MASK_DTIM_CNT_8822B << BIT_SHIFT_DTIM_CNT_8822B)
#define BIT_CLEAR_DTIM_CNT_8822B(x) ((x) & (~BITS_DTIM_CNT_8822B))
#define BIT_GET_DTIM_CNT_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT_8822B) & BIT_MASK_DTIM_CNT_8822B)
#define BIT_SET_DTIM_CNT_8822B(x, v) \
(BIT_CLEAR_DTIM_CNT_8822B(x) | BIT_DTIM_CNT_8822B(v))
#define BIT_SHIFT_DTIM_PERIOD_8822B 16
#define BIT_MASK_DTIM_PERIOD_8822B 0xff
#define BIT_DTIM_PERIOD_8822B(x) \
(((x) & BIT_MASK_DTIM_PERIOD_8822B) << BIT_SHIFT_DTIM_PERIOD_8822B)
#define BITS_DTIM_PERIOD_8822B \
(BIT_MASK_DTIM_PERIOD_8822B << BIT_SHIFT_DTIM_PERIOD_8822B)
#define BIT_CLEAR_DTIM_PERIOD_8822B(x) ((x) & (~BITS_DTIM_PERIOD_8822B))
#define BIT_GET_DTIM_PERIOD_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD_8822B) & BIT_MASK_DTIM_PERIOD_8822B)
#define BIT_SET_DTIM_PERIOD_8822B(x, v) \
(BIT_CLEAR_DTIM_PERIOD_8822B(x) | BIT_DTIM_PERIOD_8822B(v))
#define BIT_DTIM_8822B BIT(15)
#define BIT_TIM_8822B BIT(14)
#define BIT_SHIFT_PS_AID_0_8822B 0
#define BIT_MASK_PS_AID_0_8822B 0x7ff
#define BIT_PS_AID_0_8822B(x) \
(((x) & BIT_MASK_PS_AID_0_8822B) << BIT_SHIFT_PS_AID_0_8822B)
#define BITS_PS_AID_0_8822B \
(BIT_MASK_PS_AID_0_8822B << BIT_SHIFT_PS_AID_0_8822B)
#define BIT_CLEAR_PS_AID_0_8822B(x) ((x) & (~BITS_PS_AID_0_8822B))
#define BIT_GET_PS_AID_0_8822B(x) \
(((x) >> BIT_SHIFT_PS_AID_0_8822B) & BIT_MASK_PS_AID_0_8822B)
#define BIT_SET_PS_AID_0_8822B(x, v) \
(BIT_CLEAR_PS_AID_0_8822B(x) | BIT_PS_AID_0_8822B(v))
/* 2 REG_FLC_TRPC_8822B (TIMER OF FLC_RPC) */
#define BIT_FLC_RPCT_V1_8822B BIT(7)
#define BIT_MODE_8822B BIT(6)
#define BIT_SHIFT_TRPCD_8822B 0
#define BIT_MASK_TRPCD_8822B 0x3f
#define BIT_TRPCD_8822B(x) \
(((x) & BIT_MASK_TRPCD_8822B) << BIT_SHIFT_TRPCD_8822B)
#define BITS_TRPCD_8822B (BIT_MASK_TRPCD_8822B << BIT_SHIFT_TRPCD_8822B)
#define BIT_CLEAR_TRPCD_8822B(x) ((x) & (~BITS_TRPCD_8822B))
#define BIT_GET_TRPCD_8822B(x) \
(((x) >> BIT_SHIFT_TRPCD_8822B) & BIT_MASK_TRPCD_8822B)
#define BIT_SET_TRPCD_8822B(x, v) \
(BIT_CLEAR_TRPCD_8822B(x) | BIT_TRPCD_8822B(v))
/* 2 REG_FLC_PTS_8822B (PKT TYPE SELECTION OF FLC_RPC T) */
#define BIT_CMF_8822B BIT(2)
#define BIT_CCF_8822B BIT(1)
#define BIT_CDF_8822B BIT(0)
/* 2 REG_FLC_RPCT_8822B (FLC_RPC THRESHOLD) */
#define BIT_SHIFT_FLC_RPCT_8822B 0
#define BIT_MASK_FLC_RPCT_8822B 0xff
#define BIT_FLC_RPCT_8822B(x) \
(((x) & BIT_MASK_FLC_RPCT_8822B) << BIT_SHIFT_FLC_RPCT_8822B)
#define BITS_FLC_RPCT_8822B \
(BIT_MASK_FLC_RPCT_8822B << BIT_SHIFT_FLC_RPCT_8822B)
#define BIT_CLEAR_FLC_RPCT_8822B(x) ((x) & (~BITS_FLC_RPCT_8822B))
#define BIT_GET_FLC_RPCT_8822B(x) \
(((x) >> BIT_SHIFT_FLC_RPCT_8822B) & BIT_MASK_FLC_RPCT_8822B)
#define BIT_SET_FLC_RPCT_8822B(x, v) \
(BIT_CLEAR_FLC_RPCT_8822B(x) | BIT_FLC_RPCT_8822B(v))
/* 2 REG_FLC_RPC_8822B (FW LPS CONDITION -- RX PKT COUNTER) */
#define BIT_SHIFT_FLC_RPC_8822B 0
#define BIT_MASK_FLC_RPC_8822B 0xff
#define BIT_FLC_RPC_8822B(x) \
(((x) & BIT_MASK_FLC_RPC_8822B) << BIT_SHIFT_FLC_RPC_8822B)
#define BITS_FLC_RPC_8822B (BIT_MASK_FLC_RPC_8822B << BIT_SHIFT_FLC_RPC_8822B)
#define BIT_CLEAR_FLC_RPC_8822B(x) ((x) & (~BITS_FLC_RPC_8822B))
#define BIT_GET_FLC_RPC_8822B(x) \
(((x) >> BIT_SHIFT_FLC_RPC_8822B) & BIT_MASK_FLC_RPC_8822B)
#define BIT_SET_FLC_RPC_8822B(x, v) \
(BIT_CLEAR_FLC_RPC_8822B(x) | BIT_FLC_RPC_8822B(v))
/* 2 REG_RXPKTMON_CTRL_8822B */
#define BIT_SHIFT_RXBKQPKT_SEQ_8822B 20
#define BIT_MASK_RXBKQPKT_SEQ_8822B 0xf
#define BIT_RXBKQPKT_SEQ_8822B(x) \
(((x) & BIT_MASK_RXBKQPKT_SEQ_8822B) << BIT_SHIFT_RXBKQPKT_SEQ_8822B)
#define BITS_RXBKQPKT_SEQ_8822B \
(BIT_MASK_RXBKQPKT_SEQ_8822B << BIT_SHIFT_RXBKQPKT_SEQ_8822B)
#define BIT_CLEAR_RXBKQPKT_SEQ_8822B(x) ((x) & (~BITS_RXBKQPKT_SEQ_8822B))
#define BIT_GET_RXBKQPKT_SEQ_8822B(x) \
(((x) >> BIT_SHIFT_RXBKQPKT_SEQ_8822B) & BIT_MASK_RXBKQPKT_SEQ_8822B)
#define BIT_SET_RXBKQPKT_SEQ_8822B(x, v) \
(BIT_CLEAR_RXBKQPKT_SEQ_8822B(x) | BIT_RXBKQPKT_SEQ_8822B(v))
#define BIT_SHIFT_RXBEQPKT_SEQ_8822B 16
#define BIT_MASK_RXBEQPKT_SEQ_8822B 0xf
#define BIT_RXBEQPKT_SEQ_8822B(x) \
(((x) & BIT_MASK_RXBEQPKT_SEQ_8822B) << BIT_SHIFT_RXBEQPKT_SEQ_8822B)
#define BITS_RXBEQPKT_SEQ_8822B \
(BIT_MASK_RXBEQPKT_SEQ_8822B << BIT_SHIFT_RXBEQPKT_SEQ_8822B)
#define BIT_CLEAR_RXBEQPKT_SEQ_8822B(x) ((x) & (~BITS_RXBEQPKT_SEQ_8822B))
#define BIT_GET_RXBEQPKT_SEQ_8822B(x) \
(((x) >> BIT_SHIFT_RXBEQPKT_SEQ_8822B) & BIT_MASK_RXBEQPKT_SEQ_8822B)
#define BIT_SET_RXBEQPKT_SEQ_8822B(x, v) \
(BIT_CLEAR_RXBEQPKT_SEQ_8822B(x) | BIT_RXBEQPKT_SEQ_8822B(v))
#define BIT_SHIFT_RXVIQPKT_SEQ_8822B 12
#define BIT_MASK_RXVIQPKT_SEQ_8822B 0xf
#define BIT_RXVIQPKT_SEQ_8822B(x) \
(((x) & BIT_MASK_RXVIQPKT_SEQ_8822B) << BIT_SHIFT_RXVIQPKT_SEQ_8822B)
#define BITS_RXVIQPKT_SEQ_8822B \
(BIT_MASK_RXVIQPKT_SEQ_8822B << BIT_SHIFT_RXVIQPKT_SEQ_8822B)
#define BIT_CLEAR_RXVIQPKT_SEQ_8822B(x) ((x) & (~BITS_RXVIQPKT_SEQ_8822B))
#define BIT_GET_RXVIQPKT_SEQ_8822B(x) \
(((x) >> BIT_SHIFT_RXVIQPKT_SEQ_8822B) & BIT_MASK_RXVIQPKT_SEQ_8822B)
#define BIT_SET_RXVIQPKT_SEQ_8822B(x, v) \
(BIT_CLEAR_RXVIQPKT_SEQ_8822B(x) | BIT_RXVIQPKT_SEQ_8822B(v))
#define BIT_SHIFT_RXVOQPKT_SEQ_8822B 8
#define BIT_MASK_RXVOQPKT_SEQ_8822B 0xf
#define BIT_RXVOQPKT_SEQ_8822B(x) \
(((x) & BIT_MASK_RXVOQPKT_SEQ_8822B) << BIT_SHIFT_RXVOQPKT_SEQ_8822B)
#define BITS_RXVOQPKT_SEQ_8822B \
(BIT_MASK_RXVOQPKT_SEQ_8822B << BIT_SHIFT_RXVOQPKT_SEQ_8822B)
#define BIT_CLEAR_RXVOQPKT_SEQ_8822B(x) ((x) & (~BITS_RXVOQPKT_SEQ_8822B))
#define BIT_GET_RXVOQPKT_SEQ_8822B(x) \
(((x) >> BIT_SHIFT_RXVOQPKT_SEQ_8822B) & BIT_MASK_RXVOQPKT_SEQ_8822B)
#define BIT_SET_RXVOQPKT_SEQ_8822B(x, v) \
(BIT_CLEAR_RXVOQPKT_SEQ_8822B(x) | BIT_RXVOQPKT_SEQ_8822B(v))
#define BIT_RXBKQPKT_ERR_8822B BIT(7)
#define BIT_RXBEQPKT_ERR_8822B BIT(6)
#define BIT_RXVIQPKT_ERR_8822B BIT(5)
#define BIT_RXVOQPKT_ERR_8822B BIT(4)
#define BIT_RXDMA_MON_EN_8822B BIT(2)
#define BIT_RXPKT_MON_RST_8822B BIT(1)
#define BIT_RXPKT_MON_EN_8822B BIT(0)
/* 2 REG_STATE_MON_8822B */
#define BIT_SHIFT_STATE_SEL_8822B 24
#define BIT_MASK_STATE_SEL_8822B 0x1f
#define BIT_STATE_SEL_8822B(x) \
(((x) & BIT_MASK_STATE_SEL_8822B) << BIT_SHIFT_STATE_SEL_8822B)
#define BITS_STATE_SEL_8822B \
(BIT_MASK_STATE_SEL_8822B << BIT_SHIFT_STATE_SEL_8822B)
#define BIT_CLEAR_STATE_SEL_8822B(x) ((x) & (~BITS_STATE_SEL_8822B))
#define BIT_GET_STATE_SEL_8822B(x) \
(((x) >> BIT_SHIFT_STATE_SEL_8822B) & BIT_MASK_STATE_SEL_8822B)
#define BIT_SET_STATE_SEL_8822B(x, v) \
(BIT_CLEAR_STATE_SEL_8822B(x) | BIT_STATE_SEL_8822B(v))
#define BIT_SHIFT_STATE_INFO_8822B 8
#define BIT_MASK_STATE_INFO_8822B 0xff
#define BIT_STATE_INFO_8822B(x) \
(((x) & BIT_MASK_STATE_INFO_8822B) << BIT_SHIFT_STATE_INFO_8822B)
#define BITS_STATE_INFO_8822B \
(BIT_MASK_STATE_INFO_8822B << BIT_SHIFT_STATE_INFO_8822B)
#define BIT_CLEAR_STATE_INFO_8822B(x) ((x) & (~BITS_STATE_INFO_8822B))
#define BIT_GET_STATE_INFO_8822B(x) \
(((x) >> BIT_SHIFT_STATE_INFO_8822B) & BIT_MASK_STATE_INFO_8822B)
#define BIT_SET_STATE_INFO_8822B(x, v) \
(BIT_CLEAR_STATE_INFO_8822B(x) | BIT_STATE_INFO_8822B(v))
#define BIT_UPD_NXT_STATE_8822B BIT(7)
#define BIT_SHIFT_CUR_STATE_8822B 0
#define BIT_MASK_CUR_STATE_8822B 0x7f
#define BIT_CUR_STATE_8822B(x) \
(((x) & BIT_MASK_CUR_STATE_8822B) << BIT_SHIFT_CUR_STATE_8822B)
#define BITS_CUR_STATE_8822B \
(BIT_MASK_CUR_STATE_8822B << BIT_SHIFT_CUR_STATE_8822B)
#define BIT_CLEAR_CUR_STATE_8822B(x) ((x) & (~BITS_CUR_STATE_8822B))
#define BIT_GET_CUR_STATE_8822B(x) \
(((x) >> BIT_SHIFT_CUR_STATE_8822B) & BIT_MASK_CUR_STATE_8822B)
#define BIT_SET_CUR_STATE_8822B(x, v) \
(BIT_CLEAR_CUR_STATE_8822B(x) | BIT_CUR_STATE_8822B(v))
/* 2 REG_ERROR_MON_8822B */
#define BIT_MACRX_ERR_1_8822B BIT(17)
#define BIT_MACRX_ERR_0_8822B BIT(16)
#define BIT_MACTX_ERR_3_8822B BIT(3)
#define BIT_MACTX_ERR_2_8822B BIT(2)
#define BIT_MACTX_ERR_1_8822B BIT(1)
#define BIT_MACTX_ERR_0_8822B BIT(0)
/* 2 REG_SEARCH_MACID_8822B */
#define BIT_EN_TXRPTBUF_CLK_8822B BIT(31)
#define BIT_SHIFT_INFO_INDEX_OFFSET_8822B 16
#define BIT_MASK_INFO_INDEX_OFFSET_8822B 0x1fff
#define BIT_INFO_INDEX_OFFSET_8822B(x) \
(((x) & BIT_MASK_INFO_INDEX_OFFSET_8822B) \
<< BIT_SHIFT_INFO_INDEX_OFFSET_8822B)
#define BITS_INFO_INDEX_OFFSET_8822B \
(BIT_MASK_INFO_INDEX_OFFSET_8822B << BIT_SHIFT_INFO_INDEX_OFFSET_8822B)
#define BIT_CLEAR_INFO_INDEX_OFFSET_8822B(x) \
((x) & (~BITS_INFO_INDEX_OFFSET_8822B))
#define BIT_GET_INFO_INDEX_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_INFO_INDEX_OFFSET_8822B) & \
BIT_MASK_INFO_INDEX_OFFSET_8822B)
#define BIT_SET_INFO_INDEX_OFFSET_8822B(x, v) \
(BIT_CLEAR_INFO_INDEX_OFFSET_8822B(x) | BIT_INFO_INDEX_OFFSET_8822B(v))
#define BIT_WMAC_SRCH_FIFOFULL_8822B BIT(15)
#define BIT_DIS_INFOSRCH_8822B BIT(14)
#define BIT_DISABLE_B0_8822B BIT(13)
#define BIT_SHIFT_INFO_ADDR_OFFSET_8822B 0
#define BIT_MASK_INFO_ADDR_OFFSET_8822B 0x1fff
#define BIT_INFO_ADDR_OFFSET_8822B(x) \
(((x) & BIT_MASK_INFO_ADDR_OFFSET_8822B) \
<< BIT_SHIFT_INFO_ADDR_OFFSET_8822B)
#define BITS_INFO_ADDR_OFFSET_8822B \
(BIT_MASK_INFO_ADDR_OFFSET_8822B << BIT_SHIFT_INFO_ADDR_OFFSET_8822B)
#define BIT_CLEAR_INFO_ADDR_OFFSET_8822B(x) \
((x) & (~BITS_INFO_ADDR_OFFSET_8822B))
#define BIT_GET_INFO_ADDR_OFFSET_8822B(x) \
(((x) >> BIT_SHIFT_INFO_ADDR_OFFSET_8822B) & \
BIT_MASK_INFO_ADDR_OFFSET_8822B)
#define BIT_SET_INFO_ADDR_OFFSET_8822B(x, v) \
(BIT_CLEAR_INFO_ADDR_OFFSET_8822B(x) | BIT_INFO_ADDR_OFFSET_8822B(v))
/* 2 REG_BT_COEX_TABLE_8822B (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_PRI_MASK_RX_RESP_8822B BIT(126)
#define BIT_PRI_MASK_RXOFDM_8822B BIT(125)
#define BIT_PRI_MASK_RXCCK_8822B BIT(124)
#define BIT_SHIFT_PRI_MASK_TXAC_8822B (117 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_TXAC_8822B 0x7f
#define BIT_PRI_MASK_TXAC_8822B(x) \
(((x) & BIT_MASK_PRI_MASK_TXAC_8822B) << BIT_SHIFT_PRI_MASK_TXAC_8822B)
#define BITS_PRI_MASK_TXAC_8822B \
(BIT_MASK_PRI_MASK_TXAC_8822B << BIT_SHIFT_PRI_MASK_TXAC_8822B)
#define BIT_CLEAR_PRI_MASK_TXAC_8822B(x) ((x) & (~BITS_PRI_MASK_TXAC_8822B))
#define BIT_GET_PRI_MASK_TXAC_8822B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TXAC_8822B) & BIT_MASK_PRI_MASK_TXAC_8822B)
#define BIT_SET_PRI_MASK_TXAC_8822B(x, v) \
(BIT_CLEAR_PRI_MASK_TXAC_8822B(x) | BIT_PRI_MASK_TXAC_8822B(v))
#define BIT_SHIFT_PRI_MASK_NAV_8822B (109 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_NAV_8822B 0xff
#define BIT_PRI_MASK_NAV_8822B(x) \
(((x) & BIT_MASK_PRI_MASK_NAV_8822B) << BIT_SHIFT_PRI_MASK_NAV_8822B)
#define BITS_PRI_MASK_NAV_8822B \
(BIT_MASK_PRI_MASK_NAV_8822B << BIT_SHIFT_PRI_MASK_NAV_8822B)
#define BIT_CLEAR_PRI_MASK_NAV_8822B(x) ((x) & (~BITS_PRI_MASK_NAV_8822B))
#define BIT_GET_PRI_MASK_NAV_8822B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NAV_8822B) & BIT_MASK_PRI_MASK_NAV_8822B)
#define BIT_SET_PRI_MASK_NAV_8822B(x, v) \
(BIT_CLEAR_PRI_MASK_NAV_8822B(x) | BIT_PRI_MASK_NAV_8822B(v))
#define BIT_PRI_MASK_CCK_8822B BIT(108)
#define BIT_PRI_MASK_OFDM_8822B BIT(107)
#define BIT_PRI_MASK_RTY_8822B BIT(106)
#define BIT_SHIFT_PRI_MASK_NUM_8822B (102 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_NUM_8822B 0xf
#define BIT_PRI_MASK_NUM_8822B(x) \
(((x) & BIT_MASK_PRI_MASK_NUM_8822B) << BIT_SHIFT_PRI_MASK_NUM_8822B)
#define BITS_PRI_MASK_NUM_8822B \
(BIT_MASK_PRI_MASK_NUM_8822B << BIT_SHIFT_PRI_MASK_NUM_8822B)
#define BIT_CLEAR_PRI_MASK_NUM_8822B(x) ((x) & (~BITS_PRI_MASK_NUM_8822B))
#define BIT_GET_PRI_MASK_NUM_8822B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NUM_8822B) & BIT_MASK_PRI_MASK_NUM_8822B)
#define BIT_SET_PRI_MASK_NUM_8822B(x, v) \
(BIT_CLEAR_PRI_MASK_NUM_8822B(x) | BIT_PRI_MASK_NUM_8822B(v))
#define BIT_SHIFT_PRI_MASK_TYPE_8822B (98 & CPU_OPT_WIDTH)
#define BIT_MASK_PRI_MASK_TYPE_8822B 0xf
#define BIT_PRI_MASK_TYPE_8822B(x) \
(((x) & BIT_MASK_PRI_MASK_TYPE_8822B) << BIT_SHIFT_PRI_MASK_TYPE_8822B)
#define BITS_PRI_MASK_TYPE_8822B \
(BIT_MASK_PRI_MASK_TYPE_8822B << BIT_SHIFT_PRI_MASK_TYPE_8822B)
#define BIT_CLEAR_PRI_MASK_TYPE_8822B(x) ((x) & (~BITS_PRI_MASK_TYPE_8822B))
#define BIT_GET_PRI_MASK_TYPE_8822B(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TYPE_8822B) & BIT_MASK_PRI_MASK_TYPE_8822B)
#define BIT_SET_PRI_MASK_TYPE_8822B(x, v) \
(BIT_CLEAR_PRI_MASK_TYPE_8822B(x) | BIT_PRI_MASK_TYPE_8822B(v))
#define BIT_OOB_8822B BIT(97)
#define BIT_ANT_SEL_8822B BIT(96)
#define BIT_SHIFT_BREAK_TABLE_2_8822B (80 & CPU_OPT_WIDTH)
#define BIT_MASK_BREAK_TABLE_2_8822B 0xffff
#define BIT_BREAK_TABLE_2_8822B(x) \
(((x) & BIT_MASK_BREAK_TABLE_2_8822B) << BIT_SHIFT_BREAK_TABLE_2_8822B)
#define BITS_BREAK_TABLE_2_8822B \
(BIT_MASK_BREAK_TABLE_2_8822B << BIT_SHIFT_BREAK_TABLE_2_8822B)
#define BIT_CLEAR_BREAK_TABLE_2_8822B(x) ((x) & (~BITS_BREAK_TABLE_2_8822B))
#define BIT_GET_BREAK_TABLE_2_8822B(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_2_8822B) & BIT_MASK_BREAK_TABLE_2_8822B)
#define BIT_SET_BREAK_TABLE_2_8822B(x, v) \
(BIT_CLEAR_BREAK_TABLE_2_8822B(x) | BIT_BREAK_TABLE_2_8822B(v))
#define BIT_SHIFT_BREAK_TABLE_1_8822B (64 & CPU_OPT_WIDTH)
#define BIT_MASK_BREAK_TABLE_1_8822B 0xffff
#define BIT_BREAK_TABLE_1_8822B(x) \
(((x) & BIT_MASK_BREAK_TABLE_1_8822B) << BIT_SHIFT_BREAK_TABLE_1_8822B)
#define BITS_BREAK_TABLE_1_8822B \
(BIT_MASK_BREAK_TABLE_1_8822B << BIT_SHIFT_BREAK_TABLE_1_8822B)
#define BIT_CLEAR_BREAK_TABLE_1_8822B(x) ((x) & (~BITS_BREAK_TABLE_1_8822B))
#define BIT_GET_BREAK_TABLE_1_8822B(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_1_8822B) & BIT_MASK_BREAK_TABLE_1_8822B)
#define BIT_SET_BREAK_TABLE_1_8822B(x, v) \
(BIT_CLEAR_BREAK_TABLE_1_8822B(x) | BIT_BREAK_TABLE_1_8822B(v))
#define BIT_SHIFT_COEX_TABLE_2_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_COEX_TABLE_2_8822B 0xffffffffL
#define BIT_COEX_TABLE_2_8822B(x) \
(((x) & BIT_MASK_COEX_TABLE_2_8822B) << BIT_SHIFT_COEX_TABLE_2_8822B)
#define BITS_COEX_TABLE_2_8822B \
(BIT_MASK_COEX_TABLE_2_8822B << BIT_SHIFT_COEX_TABLE_2_8822B)
#define BIT_CLEAR_COEX_TABLE_2_8822B(x) ((x) & (~BITS_COEX_TABLE_2_8822B))
#define BIT_GET_COEX_TABLE_2_8822B(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_2_8822B) & BIT_MASK_COEX_TABLE_2_8822B)
#define BIT_SET_COEX_TABLE_2_8822B(x, v) \
(BIT_CLEAR_COEX_TABLE_2_8822B(x) | BIT_COEX_TABLE_2_8822B(v))
#define BIT_SHIFT_COEX_TABLE_1_8822B 0
#define BIT_MASK_COEX_TABLE_1_8822B 0xffffffffL
#define BIT_COEX_TABLE_1_8822B(x) \
(((x) & BIT_MASK_COEX_TABLE_1_8822B) << BIT_SHIFT_COEX_TABLE_1_8822B)
#define BITS_COEX_TABLE_1_8822B \
(BIT_MASK_COEX_TABLE_1_8822B << BIT_SHIFT_COEX_TABLE_1_8822B)
#define BIT_CLEAR_COEX_TABLE_1_8822B(x) ((x) & (~BITS_COEX_TABLE_1_8822B))
#define BIT_GET_COEX_TABLE_1_8822B(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_1_8822B) & BIT_MASK_COEX_TABLE_1_8822B)
#define BIT_SET_COEX_TABLE_1_8822B(x, v) \
(BIT_CLEAR_COEX_TABLE_1_8822B(x) | BIT_COEX_TABLE_1_8822B(v))
/* 2 REG_RXCMD_0_8822B */
#define BIT_RXCMD_EN_8822B BIT(31)
#define BIT_SHIFT_RXCMD_INFO_8822B 0
#define BIT_MASK_RXCMD_INFO_8822B 0x7fffffffL
#define BIT_RXCMD_INFO_8822B(x) \
(((x) & BIT_MASK_RXCMD_INFO_8822B) << BIT_SHIFT_RXCMD_INFO_8822B)
#define BITS_RXCMD_INFO_8822B \
(BIT_MASK_RXCMD_INFO_8822B << BIT_SHIFT_RXCMD_INFO_8822B)
#define BIT_CLEAR_RXCMD_INFO_8822B(x) ((x) & (~BITS_RXCMD_INFO_8822B))
#define BIT_GET_RXCMD_INFO_8822B(x) \
(((x) >> BIT_SHIFT_RXCMD_INFO_8822B) & BIT_MASK_RXCMD_INFO_8822B)
#define BIT_SET_RXCMD_INFO_8822B(x, v) \
(BIT_CLEAR_RXCMD_INFO_8822B(x) | BIT_RXCMD_INFO_8822B(v))
/* 2 REG_RXCMD_1_8822B */
#define BIT_SHIFT_RXCMD_PRD_8822B 0
#define BIT_MASK_RXCMD_PRD_8822B 0xffff
#define BIT_RXCMD_PRD_8822B(x) \
(((x) & BIT_MASK_RXCMD_PRD_8822B) << BIT_SHIFT_RXCMD_PRD_8822B)
#define BITS_RXCMD_PRD_8822B \
(BIT_MASK_RXCMD_PRD_8822B << BIT_SHIFT_RXCMD_PRD_8822B)
#define BIT_CLEAR_RXCMD_PRD_8822B(x) ((x) & (~BITS_RXCMD_PRD_8822B))
#define BIT_GET_RXCMD_PRD_8822B(x) \
(((x) >> BIT_SHIFT_RXCMD_PRD_8822B) & BIT_MASK_RXCMD_PRD_8822B)
#define BIT_SET_RXCMD_PRD_8822B(x, v) \
(BIT_CLEAR_RXCMD_PRD_8822B(x) | BIT_RXCMD_PRD_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_WMAC_RESP_TXINFO_8822B (RESPONSE TXINFO REGISTER) */
#define BIT_SHIFT_WMAC_RESP_MFB_8822B 25
#define BIT_MASK_WMAC_RESP_MFB_8822B 0x7f
#define BIT_WMAC_RESP_MFB_8822B(x) \
(((x) & BIT_MASK_WMAC_RESP_MFB_8822B) << BIT_SHIFT_WMAC_RESP_MFB_8822B)
#define BITS_WMAC_RESP_MFB_8822B \
(BIT_MASK_WMAC_RESP_MFB_8822B << BIT_SHIFT_WMAC_RESP_MFB_8822B)
#define BIT_CLEAR_WMAC_RESP_MFB_8822B(x) ((x) & (~BITS_WMAC_RESP_MFB_8822B))
#define BIT_GET_WMAC_RESP_MFB_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_MFB_8822B) & BIT_MASK_WMAC_RESP_MFB_8822B)
#define BIT_SET_WMAC_RESP_MFB_8822B(x, v) \
(BIT_CLEAR_WMAC_RESP_MFB_8822B(x) | BIT_WMAC_RESP_MFB_8822B(v))
#define BIT_SHIFT_WMAC_ANTINF_SEL_8822B 23
#define BIT_MASK_WMAC_ANTINF_SEL_8822B 0x3
#define BIT_WMAC_ANTINF_SEL_8822B(x) \
(((x) & BIT_MASK_WMAC_ANTINF_SEL_8822B) \
<< BIT_SHIFT_WMAC_ANTINF_SEL_8822B)
#define BITS_WMAC_ANTINF_SEL_8822B \
(BIT_MASK_WMAC_ANTINF_SEL_8822B << BIT_SHIFT_WMAC_ANTINF_SEL_8822B)
#define BIT_CLEAR_WMAC_ANTINF_SEL_8822B(x) ((x) & (~BITS_WMAC_ANTINF_SEL_8822B))
#define BIT_GET_WMAC_ANTINF_SEL_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_ANTINF_SEL_8822B) & \
BIT_MASK_WMAC_ANTINF_SEL_8822B)
#define BIT_SET_WMAC_ANTINF_SEL_8822B(x, v) \
(BIT_CLEAR_WMAC_ANTINF_SEL_8822B(x) | BIT_WMAC_ANTINF_SEL_8822B(v))
#define BIT_SHIFT_WMAC_ANTSEL_SEL_8822B 21
#define BIT_MASK_WMAC_ANTSEL_SEL_8822B 0x3
#define BIT_WMAC_ANTSEL_SEL_8822B(x) \
(((x) & BIT_MASK_WMAC_ANTSEL_SEL_8822B) \
<< BIT_SHIFT_WMAC_ANTSEL_SEL_8822B)
#define BITS_WMAC_ANTSEL_SEL_8822B \
(BIT_MASK_WMAC_ANTSEL_SEL_8822B << BIT_SHIFT_WMAC_ANTSEL_SEL_8822B)
#define BIT_CLEAR_WMAC_ANTSEL_SEL_8822B(x) ((x) & (~BITS_WMAC_ANTSEL_SEL_8822B))
#define BIT_GET_WMAC_ANTSEL_SEL_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_ANTSEL_SEL_8822B) & \
BIT_MASK_WMAC_ANTSEL_SEL_8822B)
#define BIT_SET_WMAC_ANTSEL_SEL_8822B(x, v) \
(BIT_CLEAR_WMAC_ANTSEL_SEL_8822B(x) | BIT_WMAC_ANTSEL_SEL_8822B(v))
#define BIT_SHIFT_R_WMAC_RESP_TXPOWER_8822B 18
#define BIT_MASK_R_WMAC_RESP_TXPOWER_8822B 0x7
#define BIT_R_WMAC_RESP_TXPOWER_8822B(x) \
(((x) & BIT_MASK_R_WMAC_RESP_TXPOWER_8822B) \
<< BIT_SHIFT_R_WMAC_RESP_TXPOWER_8822B)
#define BITS_R_WMAC_RESP_TXPOWER_8822B \
(BIT_MASK_R_WMAC_RESP_TXPOWER_8822B \
<< BIT_SHIFT_R_WMAC_RESP_TXPOWER_8822B)
#define BIT_CLEAR_R_WMAC_RESP_TXPOWER_8822B(x) \
((x) & (~BITS_R_WMAC_RESP_TXPOWER_8822B))
#define BIT_GET_R_WMAC_RESP_TXPOWER_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RESP_TXPOWER_8822B) & \
BIT_MASK_R_WMAC_RESP_TXPOWER_8822B)
#define BIT_SET_R_WMAC_RESP_TXPOWER_8822B(x, v) \
(BIT_CLEAR_R_WMAC_RESP_TXPOWER_8822B(x) | \
BIT_R_WMAC_RESP_TXPOWER_8822B(v))
#define BIT_SHIFT_WMAC_RESP_TXANT_8822B 0
#define BIT_MASK_WMAC_RESP_TXANT_8822B 0x3ffff
#define BIT_WMAC_RESP_TXANT_8822B(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT_8822B) \
<< BIT_SHIFT_WMAC_RESP_TXANT_8822B)
#define BITS_WMAC_RESP_TXANT_8822B \
(BIT_MASK_WMAC_RESP_TXANT_8822B << BIT_SHIFT_WMAC_RESP_TXANT_8822B)
#define BIT_CLEAR_WMAC_RESP_TXANT_8822B(x) ((x) & (~BITS_WMAC_RESP_TXANT_8822B))
#define BIT_GET_WMAC_RESP_TXANT_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT_8822B) & \
BIT_MASK_WMAC_RESP_TXANT_8822B)
#define BIT_SET_WMAC_RESP_TXANT_8822B(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT_8822B(x) | BIT_WMAC_RESP_TXANT_8822B(v))
/* 2 REG_BBPSF_CTRL_8822B */
#define BIT_CTL_IDLE_CLR_CSI_RPT_8822B BIT(31)
#define BIT_WMAC_USE_NDPARATE_8822B BIT(30)
#define BIT_SHIFT_WMAC_CSI_RATE_8822B 24
#define BIT_MASK_WMAC_CSI_RATE_8822B 0x3f
#define BIT_WMAC_CSI_RATE_8822B(x) \
(((x) & BIT_MASK_WMAC_CSI_RATE_8822B) << BIT_SHIFT_WMAC_CSI_RATE_8822B)
#define BITS_WMAC_CSI_RATE_8822B \
(BIT_MASK_WMAC_CSI_RATE_8822B << BIT_SHIFT_WMAC_CSI_RATE_8822B)
#define BIT_CLEAR_WMAC_CSI_RATE_8822B(x) ((x) & (~BITS_WMAC_CSI_RATE_8822B))
#define BIT_GET_WMAC_CSI_RATE_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RATE_8822B) & BIT_MASK_WMAC_CSI_RATE_8822B)
#define BIT_SET_WMAC_CSI_RATE_8822B(x, v) \
(BIT_CLEAR_WMAC_CSI_RATE_8822B(x) | BIT_WMAC_CSI_RATE_8822B(v))
#define BIT_SHIFT_WMAC_RESP_TXRATE_8822B 16
#define BIT_MASK_WMAC_RESP_TXRATE_8822B 0xff
#define BIT_WMAC_RESP_TXRATE_8822B(x) \
(((x) & BIT_MASK_WMAC_RESP_TXRATE_8822B) \
<< BIT_SHIFT_WMAC_RESP_TXRATE_8822B)
#define BITS_WMAC_RESP_TXRATE_8822B \
(BIT_MASK_WMAC_RESP_TXRATE_8822B << BIT_SHIFT_WMAC_RESP_TXRATE_8822B)
#define BIT_CLEAR_WMAC_RESP_TXRATE_8822B(x) \
((x) & (~BITS_WMAC_RESP_TXRATE_8822B))
#define BIT_GET_WMAC_RESP_TXRATE_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXRATE_8822B) & \
BIT_MASK_WMAC_RESP_TXRATE_8822B)
#define BIT_SET_WMAC_RESP_TXRATE_8822B(x, v) \
(BIT_CLEAR_WMAC_RESP_TXRATE_8822B(x) | BIT_WMAC_RESP_TXRATE_8822B(v))
#define BIT_BBPSF_MPDUCHKEN_8822B BIT(5)
#define BIT_BBPSF_MHCHKEN_8822B BIT(4)
#define BIT_BBPSF_ERRCHKEN_8822B BIT(3)
#define BIT_SHIFT_BBPSF_ERRTHR_8822B 0
#define BIT_MASK_BBPSF_ERRTHR_8822B 0x7
#define BIT_BBPSF_ERRTHR_8822B(x) \
(((x) & BIT_MASK_BBPSF_ERRTHR_8822B) << BIT_SHIFT_BBPSF_ERRTHR_8822B)
#define BITS_BBPSF_ERRTHR_8822B \
(BIT_MASK_BBPSF_ERRTHR_8822B << BIT_SHIFT_BBPSF_ERRTHR_8822B)
#define BIT_CLEAR_BBPSF_ERRTHR_8822B(x) ((x) & (~BITS_BBPSF_ERRTHR_8822B))
#define BIT_GET_BBPSF_ERRTHR_8822B(x) \
(((x) >> BIT_SHIFT_BBPSF_ERRTHR_8822B) & BIT_MASK_BBPSF_ERRTHR_8822B)
#define BIT_SET_BBPSF_ERRTHR_8822B(x, v) \
(BIT_CLEAR_BBPSF_ERRTHR_8822B(x) | BIT_BBPSF_ERRTHR_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_P2P_RX_BCN_NOA_8822B (P2P RX BEACON NOA REGISTER) */
#define BIT_NOA_PARSER_EN_8822B BIT(15)
#define BIT_BSSID_SEL_8822B BIT(14)
#define BIT_SHIFT_P2P_OUI_TYPE_8822B 0
#define BIT_MASK_P2P_OUI_TYPE_8822B 0xff
#define BIT_P2P_OUI_TYPE_8822B(x) \
(((x) & BIT_MASK_P2P_OUI_TYPE_8822B) << BIT_SHIFT_P2P_OUI_TYPE_8822B)
#define BITS_P2P_OUI_TYPE_8822B \
(BIT_MASK_P2P_OUI_TYPE_8822B << BIT_SHIFT_P2P_OUI_TYPE_8822B)
#define BIT_CLEAR_P2P_OUI_TYPE_8822B(x) ((x) & (~BITS_P2P_OUI_TYPE_8822B))
#define BIT_GET_P2P_OUI_TYPE_8822B(x) \
(((x) >> BIT_SHIFT_P2P_OUI_TYPE_8822B) & BIT_MASK_P2P_OUI_TYPE_8822B)
#define BIT_SET_P2P_OUI_TYPE_8822B(x, v) \
(BIT_CLEAR_P2P_OUI_TYPE_8822B(x) | BIT_P2P_OUI_TYPE_8822B(v))
/* 2 REG_ASSOCIATED_BFMER0_INFO_8822B (ASSOCIATED BEAMFORMER0 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_TXCSI_AID0_8822B (48 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_TXCSI_AID0_8822B 0x1ff
#define BIT_R_WMAC_TXCSI_AID0_8822B(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID0_8822B) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID0_8822B)
#define BITS_R_WMAC_TXCSI_AID0_8822B \
(BIT_MASK_R_WMAC_TXCSI_AID0_8822B << BIT_SHIFT_R_WMAC_TXCSI_AID0_8822B)
#define BIT_CLEAR_R_WMAC_TXCSI_AID0_8822B(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID0_8822B))
#define BIT_GET_R_WMAC_TXCSI_AID0_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID0_8822B) & \
BIT_MASK_R_WMAC_TXCSI_AID0_8822B)
#define BIT_SET_R_WMAC_TXCSI_AID0_8822B(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID0_8822B(x) | BIT_R_WMAC_TXCSI_AID0_8822B(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8822B 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8822B 0xffffffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0_8822B(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8822B) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8822B)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_8822B \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8822B \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8822B)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_8822B(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_8822B))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_8822B) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_8822B)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_8822B(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_8822B(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_8822B(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_8822B (ASSOCIATED BEAMFORMER1 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_TXCSI_AID1_8822B (48 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_TXCSI_AID1_8822B 0x1ff
#define BIT_R_WMAC_TXCSI_AID1_8822B(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID1_8822B) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID1_8822B)
#define BITS_R_WMAC_TXCSI_AID1_8822B \
(BIT_MASK_R_WMAC_TXCSI_AID1_8822B << BIT_SHIFT_R_WMAC_TXCSI_AID1_8822B)
#define BIT_CLEAR_R_WMAC_TXCSI_AID1_8822B(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID1_8822B))
#define BIT_GET_R_WMAC_TXCSI_AID1_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID1_8822B) & \
BIT_MASK_R_WMAC_TXCSI_AID1_8822B)
#define BIT_SET_R_WMAC_TXCSI_AID1_8822B(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID1_8822B(x) | BIT_R_WMAC_TXCSI_AID1_8822B(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8822B 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8822B 0xffffffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_8822B(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8822B) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8822B)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_8822B \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8822B \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8822B)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_8822B(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_8822B))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_8822B) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_8822B)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_8822B(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_8822B(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_8822B(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW20_8822B (TX CSI REPORT PARAMETER REGISTER) */
#define BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822B 16
#define BIT_MASK_R_WMAC_BFINFO_20M_1_8822B 0xfff
#define BIT_R_WMAC_BFINFO_20M_1_8822B(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_1_8822B) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822B)
#define BITS_R_WMAC_BFINFO_20M_1_8822B \
(BIT_MASK_R_WMAC_BFINFO_20M_1_8822B \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822B)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_1_8822B(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_1_8822B))
#define BIT_GET_R_WMAC_BFINFO_20M_1_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822B) & \
BIT_MASK_R_WMAC_BFINFO_20M_1_8822B)
#define BIT_SET_R_WMAC_BFINFO_20M_1_8822B(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_1_8822B(x) | \
BIT_R_WMAC_BFINFO_20M_1_8822B(v))
#define BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822B 0
#define BIT_MASK_R_WMAC_BFINFO_20M_0_8822B 0xfff
#define BIT_R_WMAC_BFINFO_20M_0_8822B(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_0_8822B) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822B)
#define BITS_R_WMAC_BFINFO_20M_0_8822B \
(BIT_MASK_R_WMAC_BFINFO_20M_0_8822B \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822B)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_0_8822B(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_0_8822B))
#define BIT_GET_R_WMAC_BFINFO_20M_0_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822B) & \
BIT_MASK_R_WMAC_BFINFO_20M_0_8822B)
#define BIT_SET_R_WMAC_BFINFO_20M_0_8822B(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_0_8822B(x) | \
BIT_R_WMAC_BFINFO_20M_0_8822B(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW40_8822B (TX CSI REPORT PARAMETER_BW40 REGISTER) */
#define BIT_SHIFT_WMAC_RESP_ANTCD_8822B 0
#define BIT_MASK_WMAC_RESP_ANTCD_8822B 0xf
#define BIT_WMAC_RESP_ANTCD_8822B(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTCD_8822B) \
<< BIT_SHIFT_WMAC_RESP_ANTCD_8822B)
#define BITS_WMAC_RESP_ANTCD_8822B \
(BIT_MASK_WMAC_RESP_ANTCD_8822B << BIT_SHIFT_WMAC_RESP_ANTCD_8822B)
#define BIT_CLEAR_WMAC_RESP_ANTCD_8822B(x) ((x) & (~BITS_WMAC_RESP_ANTCD_8822B))
#define BIT_GET_WMAC_RESP_ANTCD_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTCD_8822B) & \
BIT_MASK_WMAC_RESP_ANTCD_8822B)
#define BIT_SET_WMAC_RESP_ANTCD_8822B(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTCD_8822B(x) | BIT_WMAC_RESP_ANTCD_8822B(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW80_8822B (TX CSI REPORT PARAMETER_BW80 REGISTER) */
/* 2 REG_BCN_PSR_RPT2_8822B (BEACON PARSER REPORT REGISTER2) */
#define BIT_SHIFT_DTIM_CNT2_8822B 24
#define BIT_MASK_DTIM_CNT2_8822B 0xff
#define BIT_DTIM_CNT2_8822B(x) \
(((x) & BIT_MASK_DTIM_CNT2_8822B) << BIT_SHIFT_DTIM_CNT2_8822B)
#define BITS_DTIM_CNT2_8822B \
(BIT_MASK_DTIM_CNT2_8822B << BIT_SHIFT_DTIM_CNT2_8822B)
#define BIT_CLEAR_DTIM_CNT2_8822B(x) ((x) & (~BITS_DTIM_CNT2_8822B))
#define BIT_GET_DTIM_CNT2_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT2_8822B) & BIT_MASK_DTIM_CNT2_8822B)
#define BIT_SET_DTIM_CNT2_8822B(x, v) \
(BIT_CLEAR_DTIM_CNT2_8822B(x) | BIT_DTIM_CNT2_8822B(v))
#define BIT_SHIFT_DTIM_PERIOD2_8822B 16
#define BIT_MASK_DTIM_PERIOD2_8822B 0xff
#define BIT_DTIM_PERIOD2_8822B(x) \
(((x) & BIT_MASK_DTIM_PERIOD2_8822B) << BIT_SHIFT_DTIM_PERIOD2_8822B)
#define BITS_DTIM_PERIOD2_8822B \
(BIT_MASK_DTIM_PERIOD2_8822B << BIT_SHIFT_DTIM_PERIOD2_8822B)
#define BIT_CLEAR_DTIM_PERIOD2_8822B(x) ((x) & (~BITS_DTIM_PERIOD2_8822B))
#define BIT_GET_DTIM_PERIOD2_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD2_8822B) & BIT_MASK_DTIM_PERIOD2_8822B)
#define BIT_SET_DTIM_PERIOD2_8822B(x, v) \
(BIT_CLEAR_DTIM_PERIOD2_8822B(x) | BIT_DTIM_PERIOD2_8822B(v))
#define BIT_DTIM2_8822B BIT(15)
#define BIT_TIM2_8822B BIT(14)
#define BIT_SHIFT_PS_AID_2_8822B 0
#define BIT_MASK_PS_AID_2_8822B 0x7ff
#define BIT_PS_AID_2_8822B(x) \
(((x) & BIT_MASK_PS_AID_2_8822B) << BIT_SHIFT_PS_AID_2_8822B)
#define BITS_PS_AID_2_8822B \
(BIT_MASK_PS_AID_2_8822B << BIT_SHIFT_PS_AID_2_8822B)
#define BIT_CLEAR_PS_AID_2_8822B(x) ((x) & (~BITS_PS_AID_2_8822B))
#define BIT_GET_PS_AID_2_8822B(x) \
(((x) >> BIT_SHIFT_PS_AID_2_8822B) & BIT_MASK_PS_AID_2_8822B)
#define BIT_SET_PS_AID_2_8822B(x, v) \
(BIT_CLEAR_PS_AID_2_8822B(x) | BIT_PS_AID_2_8822B(v))
/* 2 REG_BCN_PSR_RPT3_8822B (BEACON PARSER REPORT REGISTER3) */
#define BIT_SHIFT_DTIM_CNT3_8822B 24
#define BIT_MASK_DTIM_CNT3_8822B 0xff
#define BIT_DTIM_CNT3_8822B(x) \
(((x) & BIT_MASK_DTIM_CNT3_8822B) << BIT_SHIFT_DTIM_CNT3_8822B)
#define BITS_DTIM_CNT3_8822B \
(BIT_MASK_DTIM_CNT3_8822B << BIT_SHIFT_DTIM_CNT3_8822B)
#define BIT_CLEAR_DTIM_CNT3_8822B(x) ((x) & (~BITS_DTIM_CNT3_8822B))
#define BIT_GET_DTIM_CNT3_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT3_8822B) & BIT_MASK_DTIM_CNT3_8822B)
#define BIT_SET_DTIM_CNT3_8822B(x, v) \
(BIT_CLEAR_DTIM_CNT3_8822B(x) | BIT_DTIM_CNT3_8822B(v))
#define BIT_SHIFT_DTIM_PERIOD3_8822B 16
#define BIT_MASK_DTIM_PERIOD3_8822B 0xff
#define BIT_DTIM_PERIOD3_8822B(x) \
(((x) & BIT_MASK_DTIM_PERIOD3_8822B) << BIT_SHIFT_DTIM_PERIOD3_8822B)
#define BITS_DTIM_PERIOD3_8822B \
(BIT_MASK_DTIM_PERIOD3_8822B << BIT_SHIFT_DTIM_PERIOD3_8822B)
#define BIT_CLEAR_DTIM_PERIOD3_8822B(x) ((x) & (~BITS_DTIM_PERIOD3_8822B))
#define BIT_GET_DTIM_PERIOD3_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD3_8822B) & BIT_MASK_DTIM_PERIOD3_8822B)
#define BIT_SET_DTIM_PERIOD3_8822B(x, v) \
(BIT_CLEAR_DTIM_PERIOD3_8822B(x) | BIT_DTIM_PERIOD3_8822B(v))
#define BIT_DTIM3_8822B BIT(15)
#define BIT_TIM3_8822B BIT(14)
#define BIT_SHIFT_PS_AID_3_8822B 0
#define BIT_MASK_PS_AID_3_8822B 0x7ff
#define BIT_PS_AID_3_8822B(x) \
(((x) & BIT_MASK_PS_AID_3_8822B) << BIT_SHIFT_PS_AID_3_8822B)
#define BITS_PS_AID_3_8822B \
(BIT_MASK_PS_AID_3_8822B << BIT_SHIFT_PS_AID_3_8822B)
#define BIT_CLEAR_PS_AID_3_8822B(x) ((x) & (~BITS_PS_AID_3_8822B))
#define BIT_GET_PS_AID_3_8822B(x) \
(((x) >> BIT_SHIFT_PS_AID_3_8822B) & BIT_MASK_PS_AID_3_8822B)
#define BIT_SET_PS_AID_3_8822B(x, v) \
(BIT_CLEAR_PS_AID_3_8822B(x) | BIT_PS_AID_3_8822B(v))
/* 2 REG_BCN_PSR_RPT4_8822B (BEACON PARSER REPORT REGISTER4) */
#define BIT_SHIFT_DTIM_CNT4_8822B 24
#define BIT_MASK_DTIM_CNT4_8822B 0xff
#define BIT_DTIM_CNT4_8822B(x) \
(((x) & BIT_MASK_DTIM_CNT4_8822B) << BIT_SHIFT_DTIM_CNT4_8822B)
#define BITS_DTIM_CNT4_8822B \
(BIT_MASK_DTIM_CNT4_8822B << BIT_SHIFT_DTIM_CNT4_8822B)
#define BIT_CLEAR_DTIM_CNT4_8822B(x) ((x) & (~BITS_DTIM_CNT4_8822B))
#define BIT_GET_DTIM_CNT4_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT4_8822B) & BIT_MASK_DTIM_CNT4_8822B)
#define BIT_SET_DTIM_CNT4_8822B(x, v) \
(BIT_CLEAR_DTIM_CNT4_8822B(x) | BIT_DTIM_CNT4_8822B(v))
#define BIT_SHIFT_DTIM_PERIOD4_8822B 16
#define BIT_MASK_DTIM_PERIOD4_8822B 0xff
#define BIT_DTIM_PERIOD4_8822B(x) \
(((x) & BIT_MASK_DTIM_PERIOD4_8822B) << BIT_SHIFT_DTIM_PERIOD4_8822B)
#define BITS_DTIM_PERIOD4_8822B \
(BIT_MASK_DTIM_PERIOD4_8822B << BIT_SHIFT_DTIM_PERIOD4_8822B)
#define BIT_CLEAR_DTIM_PERIOD4_8822B(x) ((x) & (~BITS_DTIM_PERIOD4_8822B))
#define BIT_GET_DTIM_PERIOD4_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD4_8822B) & BIT_MASK_DTIM_PERIOD4_8822B)
#define BIT_SET_DTIM_PERIOD4_8822B(x, v) \
(BIT_CLEAR_DTIM_PERIOD4_8822B(x) | BIT_DTIM_PERIOD4_8822B(v))
#define BIT_DTIM4_8822B BIT(15)
#define BIT_TIM4_8822B BIT(14)
#define BIT_SHIFT_PS_AID_4_8822B 0
#define BIT_MASK_PS_AID_4_8822B 0x7ff
#define BIT_PS_AID_4_8822B(x) \
(((x) & BIT_MASK_PS_AID_4_8822B) << BIT_SHIFT_PS_AID_4_8822B)
#define BITS_PS_AID_4_8822B \
(BIT_MASK_PS_AID_4_8822B << BIT_SHIFT_PS_AID_4_8822B)
#define BIT_CLEAR_PS_AID_4_8822B(x) ((x) & (~BITS_PS_AID_4_8822B))
#define BIT_GET_PS_AID_4_8822B(x) \
(((x) >> BIT_SHIFT_PS_AID_4_8822B) & BIT_MASK_PS_AID_4_8822B)
#define BIT_SET_PS_AID_4_8822B(x, v) \
(BIT_CLEAR_PS_AID_4_8822B(x) | BIT_PS_AID_4_8822B(v))
/* 2 REG_A1_ADDR_MASK_8822B (A1 ADDR MASK REGISTER) */
#define BIT_SHIFT_A1_ADDR_MASK_8822B 0
#define BIT_MASK_A1_ADDR_MASK_8822B 0xffffffffL
#define BIT_A1_ADDR_MASK_8822B(x) \
(((x) & BIT_MASK_A1_ADDR_MASK_8822B) << BIT_SHIFT_A1_ADDR_MASK_8822B)
#define BITS_A1_ADDR_MASK_8822B \
(BIT_MASK_A1_ADDR_MASK_8822B << BIT_SHIFT_A1_ADDR_MASK_8822B)
#define BIT_CLEAR_A1_ADDR_MASK_8822B(x) ((x) & (~BITS_A1_ADDR_MASK_8822B))
#define BIT_GET_A1_ADDR_MASK_8822B(x) \
(((x) >> BIT_SHIFT_A1_ADDR_MASK_8822B) & BIT_MASK_A1_ADDR_MASK_8822B)
#define BIT_SET_A1_ADDR_MASK_8822B(x, v) \
(BIT_CLEAR_A1_ADDR_MASK_8822B(x) | BIT_A1_ADDR_MASK_8822B(v))
/* 2 REG_MACID2_8822B (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_8822B 0
#define BIT_MASK_MACID2_8822B 0xffffffffffffL
#define BIT_MACID2_8822B(x) \
(((x) & BIT_MASK_MACID2_8822B) << BIT_SHIFT_MACID2_8822B)
#define BITS_MACID2_8822B (BIT_MASK_MACID2_8822B << BIT_SHIFT_MACID2_8822B)
#define BIT_CLEAR_MACID2_8822B(x) ((x) & (~BITS_MACID2_8822B))
#define BIT_GET_MACID2_8822B(x) \
(((x) >> BIT_SHIFT_MACID2_8822B) & BIT_MASK_MACID2_8822B)
#define BIT_SET_MACID2_8822B(x, v) \
(BIT_CLEAR_MACID2_8822B(x) | BIT_MACID2_8822B(v))
/* 2 REG_BSSID2_8822B (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_8822B 0
#define BIT_MASK_BSSID2_8822B 0xffffffffffffL
#define BIT_BSSID2_8822B(x) \
(((x) & BIT_MASK_BSSID2_8822B) << BIT_SHIFT_BSSID2_8822B)
#define BITS_BSSID2_8822B (BIT_MASK_BSSID2_8822B << BIT_SHIFT_BSSID2_8822B)
#define BIT_CLEAR_BSSID2_8822B(x) ((x) & (~BITS_BSSID2_8822B))
#define BIT_GET_BSSID2_8822B(x) \
(((x) >> BIT_SHIFT_BSSID2_8822B) & BIT_MASK_BSSID2_8822B)
#define BIT_SET_BSSID2_8822B(x, v) \
(BIT_CLEAR_BSSID2_8822B(x) | BIT_BSSID2_8822B(v))
/* 2 REG_MACID3_8822B (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_8822B 0
#define BIT_MASK_MACID3_8822B 0xffffffffffffL
#define BIT_MACID3_8822B(x) \
(((x) & BIT_MASK_MACID3_8822B) << BIT_SHIFT_MACID3_8822B)
#define BITS_MACID3_8822B (BIT_MASK_MACID3_8822B << BIT_SHIFT_MACID3_8822B)
#define BIT_CLEAR_MACID3_8822B(x) ((x) & (~BITS_MACID3_8822B))
#define BIT_GET_MACID3_8822B(x) \
(((x) >> BIT_SHIFT_MACID3_8822B) & BIT_MASK_MACID3_8822B)
#define BIT_SET_MACID3_8822B(x, v) \
(BIT_CLEAR_MACID3_8822B(x) | BIT_MACID3_8822B(v))
/* 2 REG_BSSID3_8822B (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_8822B 0
#define BIT_MASK_BSSID3_8822B 0xffffffffffffL
#define BIT_BSSID3_8822B(x) \
(((x) & BIT_MASK_BSSID3_8822B) << BIT_SHIFT_BSSID3_8822B)
#define BITS_BSSID3_8822B (BIT_MASK_BSSID3_8822B << BIT_SHIFT_BSSID3_8822B)
#define BIT_CLEAR_BSSID3_8822B(x) ((x) & (~BITS_BSSID3_8822B))
#define BIT_GET_BSSID3_8822B(x) \
(((x) >> BIT_SHIFT_BSSID3_8822B) & BIT_MASK_BSSID3_8822B)
#define BIT_SET_BSSID3_8822B(x, v) \
(BIT_CLEAR_BSSID3_8822B(x) | BIT_BSSID3_8822B(v))
/* 2 REG_MACID4_8822B (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_8822B 0
#define BIT_MASK_MACID4_8822B 0xffffffffffffL
#define BIT_MACID4_8822B(x) \
(((x) & BIT_MASK_MACID4_8822B) << BIT_SHIFT_MACID4_8822B)
#define BITS_MACID4_8822B (BIT_MASK_MACID4_8822B << BIT_SHIFT_MACID4_8822B)
#define BIT_CLEAR_MACID4_8822B(x) ((x) & (~BITS_MACID4_8822B))
#define BIT_GET_MACID4_8822B(x) \
(((x) >> BIT_SHIFT_MACID4_8822B) & BIT_MASK_MACID4_8822B)
#define BIT_SET_MACID4_8822B(x, v) \
(BIT_CLEAR_MACID4_8822B(x) | BIT_MACID4_8822B(v))
/* 2 REG_BSSID4_8822B (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_8822B 0
#define BIT_MASK_BSSID4_8822B 0xffffffffffffL
#define BIT_BSSID4_8822B(x) \
(((x) & BIT_MASK_BSSID4_8822B) << BIT_SHIFT_BSSID4_8822B)
#define BITS_BSSID4_8822B (BIT_MASK_BSSID4_8822B << BIT_SHIFT_BSSID4_8822B)
#define BIT_CLEAR_BSSID4_8822B(x) ((x) & (~BITS_BSSID4_8822B))
#define BIT_GET_BSSID4_8822B(x) \
(((x) >> BIT_SHIFT_BSSID4_8822B) & BIT_MASK_BSSID4_8822B)
#define BIT_SET_BSSID4_8822B(x, v) \
(BIT_CLEAR_BSSID4_8822B(x) | BIT_BSSID4_8822B(v))
/* 2 REG_NOA_REPORT_8822B */
/* 2 REG_PWRBIT_SETTING_8822B */
#define BIT_CLI3_PWRBIT_OW_EN_8822B BIT(7)
#define BIT_CLI3_PWR_ST_8822B BIT(6)
#define BIT_CLI2_PWRBIT_OW_EN_8822B BIT(5)
#define BIT_CLI2_PWR_ST_8822B BIT(4)
#define BIT_CLI1_PWRBIT_OW_EN_8822B BIT(3)
#define BIT_CLI1_PWR_ST_8822B BIT(2)
#define BIT_CLI0_PWRBIT_OW_EN_8822B BIT(1)
#define BIT_CLI0_PWR_ST_8822B BIT(0)
/* 2 REG_WMAC_MU_BF_OPTION_8822B */
#define BIT_WMAC_RESP_NONSTA1_DIS_8822B BIT(7)
#define BIT_BIT_WMAC_TXMU_ACKPOLICY_EN_8822B BIT(6)
#define BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822B 4
#define BIT_MASK_WMAC_TXMU_ACKPOLICY_8822B 0x3
#define BIT_WMAC_TXMU_ACKPOLICY_8822B(x) \
(((x) & BIT_MASK_WMAC_TXMU_ACKPOLICY_8822B) \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822B)
#define BITS_WMAC_TXMU_ACKPOLICY_8822B \
(BIT_MASK_WMAC_TXMU_ACKPOLICY_8822B \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822B)
#define BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8822B(x) \
((x) & (~BITS_WMAC_TXMU_ACKPOLICY_8822B))
#define BIT_GET_WMAC_TXMU_ACKPOLICY_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822B) & \
BIT_MASK_WMAC_TXMU_ACKPOLICY_8822B)
#define BIT_SET_WMAC_TXMU_ACKPOLICY_8822B(x, v) \
(BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8822B(x) | \
BIT_WMAC_TXMU_ACKPOLICY_8822B(v))
#define BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822B 1
#define BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822B 0x7
#define BIT_WMAC_MU_BFEE_PORT_SEL_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822B)
#define BITS_WMAC_MU_BFEE_PORT_SEL_8822B \
(BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822B \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE_PORT_SEL_8822B))
#define BIT_GET_WMAC_MU_BFEE_PORT_SEL_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822B) & \
BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822B)
#define BIT_SET_WMAC_MU_BFEE_PORT_SEL_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8822B(x) | \
BIT_WMAC_MU_BFEE_PORT_SEL_8822B(v))
#define BIT_WMAC_MU_BFEE_DIS_8822B BIT(0)
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822B 0
#define BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822B 0xff
#define BIT_WMAC_PAUSE_BB_CLR_TH_8822B(x) \
(((x) & BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822B) \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822B)
#define BITS_WMAC_PAUSE_BB_CLR_TH_8822B \
(BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822B \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822B)
#define BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8822B(x) \
((x) & (~BITS_WMAC_PAUSE_BB_CLR_TH_8822B))
#define BIT_GET_WMAC_PAUSE_BB_CLR_TH_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822B) & \
BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822B)
#define BIT_SET_WMAC_PAUSE_BB_CLR_TH_8822B(x, v) \
(BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8822B(x) | \
BIT_WMAC_PAUSE_BB_CLR_TH_8822B(v))
/* 2 REG_WMAC_MU_ARB_8822B */
#define BIT_WMAC_ARB_HW_ADAPT_EN_8822B BIT(7)
#define BIT_WMAC_ARB_SW_EN_8822B BIT(6)
#define BIT_SHIFT_WMAC_ARB_SW_STATE_8822B 0
#define BIT_MASK_WMAC_ARB_SW_STATE_8822B 0x3f
#define BIT_WMAC_ARB_SW_STATE_8822B(x) \
(((x) & BIT_MASK_WMAC_ARB_SW_STATE_8822B) \
<< BIT_SHIFT_WMAC_ARB_SW_STATE_8822B)
#define BITS_WMAC_ARB_SW_STATE_8822B \
(BIT_MASK_WMAC_ARB_SW_STATE_8822B << BIT_SHIFT_WMAC_ARB_SW_STATE_8822B)
#define BIT_CLEAR_WMAC_ARB_SW_STATE_8822B(x) \
((x) & (~BITS_WMAC_ARB_SW_STATE_8822B))
#define BIT_GET_WMAC_ARB_SW_STATE_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_ARB_SW_STATE_8822B) & \
BIT_MASK_WMAC_ARB_SW_STATE_8822B)
#define BIT_SET_WMAC_ARB_SW_STATE_8822B(x, v) \
(BIT_CLEAR_WMAC_ARB_SW_STATE_8822B(x) | BIT_WMAC_ARB_SW_STATE_8822B(v))
/* 2 REG_WMAC_MU_OPTION_8822B */
#define BIT_SHIFT_WMAC_MU_DBGSEL_8822B 5
#define BIT_MASK_WMAC_MU_DBGSEL_8822B 0x3
#define BIT_WMAC_MU_DBGSEL_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_DBGSEL_8822B) \
<< BIT_SHIFT_WMAC_MU_DBGSEL_8822B)
#define BITS_WMAC_MU_DBGSEL_8822B \
(BIT_MASK_WMAC_MU_DBGSEL_8822B << BIT_SHIFT_WMAC_MU_DBGSEL_8822B)
#define BIT_CLEAR_WMAC_MU_DBGSEL_8822B(x) ((x) & (~BITS_WMAC_MU_DBGSEL_8822B))
#define BIT_GET_WMAC_MU_DBGSEL_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_DBGSEL_8822B) & \
BIT_MASK_WMAC_MU_DBGSEL_8822B)
#define BIT_SET_WMAC_MU_DBGSEL_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_DBGSEL_8822B(x) | BIT_WMAC_MU_DBGSEL_8822B(v))
#define BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8822B 0
#define BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8822B 0x1f
#define BIT_WMAC_MU_CPRD_TIMEOUT_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8822B) \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8822B)
#define BITS_WMAC_MU_CPRD_TIMEOUT_8822B \
(BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8822B \
<< BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8822B)
#define BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT_8822B(x) \
((x) & (~BITS_WMAC_MU_CPRD_TIMEOUT_8822B))
#define BIT_GET_WMAC_MU_CPRD_TIMEOUT_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_CPRD_TIMEOUT_8822B) & \
BIT_MASK_WMAC_MU_CPRD_TIMEOUT_8822B)
#define BIT_SET_WMAC_MU_CPRD_TIMEOUT_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_CPRD_TIMEOUT_8822B(x) | \
BIT_WMAC_MU_CPRD_TIMEOUT_8822B(v))
/* 2 REG_WMAC_MU_BF_CTL_8822B */
#define BIT_WMAC_INVLD_BFPRT_CHK_8822B BIT(15)
#define BIT_WMAC_RETXBFRPTSEQ_UPD_8822B BIT(14)
#define BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822B 12
#define BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822B 0x3
#define BIT_WMAC_MU_BFRPTSEG_SEL_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822B) \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822B)
#define BITS_WMAC_MU_BFRPTSEG_SEL_8822B \
(BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822B \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822B)
#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8822B(x) \
((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL_8822B))
#define BIT_GET_WMAC_MU_BFRPTSEG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822B) & \
BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822B)
#define BIT_SET_WMAC_MU_BFRPTSEG_SEL_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8822B(x) | \
BIT_WMAC_MU_BFRPTSEG_SEL_8822B(v))
#define BIT_SHIFT_WMAC_MU_BF_MYAID_8822B 0
#define BIT_MASK_WMAC_MU_BF_MYAID_8822B 0xfff
#define BIT_WMAC_MU_BF_MYAID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BF_MYAID_8822B) \
<< BIT_SHIFT_WMAC_MU_BF_MYAID_8822B)
#define BITS_WMAC_MU_BF_MYAID_8822B \
(BIT_MASK_WMAC_MU_BF_MYAID_8822B << BIT_SHIFT_WMAC_MU_BF_MYAID_8822B)
#define BIT_CLEAR_WMAC_MU_BF_MYAID_8822B(x) \
((x) & (~BITS_WMAC_MU_BF_MYAID_8822B))
#define BIT_GET_WMAC_MU_BF_MYAID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BF_MYAID_8822B) & \
BIT_MASK_WMAC_MU_BF_MYAID_8822B)
#define BIT_SET_WMAC_MU_BF_MYAID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BF_MYAID_8822B(x) | BIT_WMAC_MU_BF_MYAID_8822B(v))
/* 2 REG_WMAC_MU_BFRPT_PARA_8822B */
#define BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL_8822B 12
#define BIT_MASK_BIT_BFRPT_PARA_USERID_SEL_8822B 0x7
#define BIT_BIT_BFRPT_PARA_USERID_SEL_8822B(x) \
(((x) & BIT_MASK_BIT_BFRPT_PARA_USERID_SEL_8822B) \
<< BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL_8822B)
#define BITS_BIT_BFRPT_PARA_USERID_SEL_8822B \
(BIT_MASK_BIT_BFRPT_PARA_USERID_SEL_8822B \
<< BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL_8822B)
#define BIT_CLEAR_BIT_BFRPT_PARA_USERID_SEL_8822B(x) \
((x) & (~BITS_BIT_BFRPT_PARA_USERID_SEL_8822B))
#define BIT_GET_BIT_BFRPT_PARA_USERID_SEL_8822B(x) \
(((x) >> BIT_SHIFT_BIT_BFRPT_PARA_USERID_SEL_8822B) & \
BIT_MASK_BIT_BFRPT_PARA_USERID_SEL_8822B)
#define BIT_SET_BIT_BFRPT_PARA_USERID_SEL_8822B(x, v) \
(BIT_CLEAR_BIT_BFRPT_PARA_USERID_SEL_8822B(x) | \
BIT_BIT_BFRPT_PARA_USERID_SEL_8822B(v))
#define BIT_SHIFT_BFRPT_PARA_8822B 0
#define BIT_MASK_BFRPT_PARA_8822B 0xfff
#define BIT_BFRPT_PARA_8822B(x) \
(((x) & BIT_MASK_BFRPT_PARA_8822B) << BIT_SHIFT_BFRPT_PARA_8822B)
#define BITS_BFRPT_PARA_8822B \
(BIT_MASK_BFRPT_PARA_8822B << BIT_SHIFT_BFRPT_PARA_8822B)
#define BIT_CLEAR_BFRPT_PARA_8822B(x) ((x) & (~BITS_BFRPT_PARA_8822B))
#define BIT_GET_BFRPT_PARA_8822B(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_8822B) & BIT_MASK_BFRPT_PARA_8822B)
#define BIT_SET_BFRPT_PARA_8822B(x, v) \
(BIT_CLEAR_BFRPT_PARA_8822B(x) | BIT_BFRPT_PARA_8822B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B */
#define BIT_STATUS_BFEE2_8822B BIT(10)
#define BIT_WMAC_MU_BFEE2_EN_8822B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE2_AID_8822B 0
#define BIT_MASK_WMAC_MU_BFEE2_AID_8822B 0x1ff
#define BIT_WMAC_MU_BFEE2_AID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE2_AID_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE2_AID_8822B)
#define BITS_WMAC_MU_BFEE2_AID_8822B \
(BIT_MASK_WMAC_MU_BFEE2_AID_8822B << BIT_SHIFT_WMAC_MU_BFEE2_AID_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE2_AID_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE2_AID_8822B))
#define BIT_GET_WMAC_MU_BFEE2_AID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE2_AID_8822B) & \
BIT_MASK_WMAC_MU_BFEE2_AID_8822B)
#define BIT_SET_WMAC_MU_BFEE2_AID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE2_AID_8822B(x) | BIT_WMAC_MU_BFEE2_AID_8822B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3_8822B */
#define BIT_STATUS_BFEE3_8822B BIT(10)
#define BIT_WMAC_MU_BFEE3_EN_8822B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE3_AID_8822B 0
#define BIT_MASK_WMAC_MU_BFEE3_AID_8822B 0x1ff
#define BIT_WMAC_MU_BFEE3_AID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE3_AID_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE3_AID_8822B)
#define BITS_WMAC_MU_BFEE3_AID_8822B \
(BIT_MASK_WMAC_MU_BFEE3_AID_8822B << BIT_SHIFT_WMAC_MU_BFEE3_AID_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE3_AID_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE3_AID_8822B))
#define BIT_GET_WMAC_MU_BFEE3_AID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE3_AID_8822B) & \
BIT_MASK_WMAC_MU_BFEE3_AID_8822B)
#define BIT_SET_WMAC_MU_BFEE3_AID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE3_AID_8822B(x) | BIT_WMAC_MU_BFEE3_AID_8822B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE4_8822B */
#define BIT_STATUS_BFEE4_8822B BIT(10)
#define BIT_WMAC_MU_BFEE4_EN_8822B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE4_AID_8822B 0
#define BIT_MASK_WMAC_MU_BFEE4_AID_8822B 0x1ff
#define BIT_WMAC_MU_BFEE4_AID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE4_AID_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE4_AID_8822B)
#define BITS_WMAC_MU_BFEE4_AID_8822B \
(BIT_MASK_WMAC_MU_BFEE4_AID_8822B << BIT_SHIFT_WMAC_MU_BFEE4_AID_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE4_AID_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE4_AID_8822B))
#define BIT_GET_WMAC_MU_BFEE4_AID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE4_AID_8822B) & \
BIT_MASK_WMAC_MU_BFEE4_AID_8822B)
#define BIT_SET_WMAC_MU_BFEE4_AID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE4_AID_8822B(x) | BIT_WMAC_MU_BFEE4_AID_8822B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5_8822B */
#define BIT_STATUS_BFEE5_8822B BIT(10)
#define BIT_WMAC_MU_BFEE5_EN_8822B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE5_AID_8822B 0
#define BIT_MASK_WMAC_MU_BFEE5_AID_8822B 0x1ff
#define BIT_WMAC_MU_BFEE5_AID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE5_AID_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE5_AID_8822B)
#define BITS_WMAC_MU_BFEE5_AID_8822B \
(BIT_MASK_WMAC_MU_BFEE5_AID_8822B << BIT_SHIFT_WMAC_MU_BFEE5_AID_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE5_AID_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE5_AID_8822B))
#define BIT_GET_WMAC_MU_BFEE5_AID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE5_AID_8822B) & \
BIT_MASK_WMAC_MU_BFEE5_AID_8822B)
#define BIT_SET_WMAC_MU_BFEE5_AID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE5_AID_8822B(x) | BIT_WMAC_MU_BFEE5_AID_8822B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE6_8822B */
#define BIT_STATUS_BFEE6_8822B BIT(10)
#define BIT_WMAC_MU_BFEE6_EN_8822B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE6_AID_8822B 0
#define BIT_MASK_WMAC_MU_BFEE6_AID_8822B 0x1ff
#define BIT_WMAC_MU_BFEE6_AID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE6_AID_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE6_AID_8822B)
#define BITS_WMAC_MU_BFEE6_AID_8822B \
(BIT_MASK_WMAC_MU_BFEE6_AID_8822B << BIT_SHIFT_WMAC_MU_BFEE6_AID_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE6_AID_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE6_AID_8822B))
#define BIT_GET_WMAC_MU_BFEE6_AID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE6_AID_8822B) & \
BIT_MASK_WMAC_MU_BFEE6_AID_8822B)
#define BIT_SET_WMAC_MU_BFEE6_AID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE6_AID_8822B(x) | BIT_WMAC_MU_BFEE6_AID_8822B(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7_8822B */
#define BIT_STATUS_BFEE7_8822B BIT(10)
#define BIT_WMAC_MU_BFEE7_EN_8822B BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE7_AID_8822B 0
#define BIT_MASK_WMAC_MU_BFEE7_AID_8822B 0x1ff
#define BIT_WMAC_MU_BFEE7_AID_8822B(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE7_AID_8822B) \
<< BIT_SHIFT_WMAC_MU_BFEE7_AID_8822B)
#define BITS_WMAC_MU_BFEE7_AID_8822B \
(BIT_MASK_WMAC_MU_BFEE7_AID_8822B << BIT_SHIFT_WMAC_MU_BFEE7_AID_8822B)
#define BIT_CLEAR_WMAC_MU_BFEE7_AID_8822B(x) \
((x) & (~BITS_WMAC_MU_BFEE7_AID_8822B))
#define BIT_GET_WMAC_MU_BFEE7_AID_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE7_AID_8822B) & \
BIT_MASK_WMAC_MU_BFEE7_AID_8822B)
#define BIT_SET_WMAC_MU_BFEE7_AID_8822B(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE7_AID_8822B(x) | BIT_WMAC_MU_BFEE7_AID_8822B(v))
/* 2 REG_NOT_VALID_8822B */
#define BIT_RST_ALL_COUNTER_8822B BIT(31)
#define BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822B 16
#define BIT_MASK_ABORT_RX_VBON_COUNTER_8822B 0xff
#define BIT_ABORT_RX_VBON_COUNTER_8822B(x) \
(((x) & BIT_MASK_ABORT_RX_VBON_COUNTER_8822B) \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822B)
#define BITS_ABORT_RX_VBON_COUNTER_8822B \
(BIT_MASK_ABORT_RX_VBON_COUNTER_8822B \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822B)
#define BIT_CLEAR_ABORT_RX_VBON_COUNTER_8822B(x) \
((x) & (~BITS_ABORT_RX_VBON_COUNTER_8822B))
#define BIT_GET_ABORT_RX_VBON_COUNTER_8822B(x) \
(((x) >> BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822B) & \
BIT_MASK_ABORT_RX_VBON_COUNTER_8822B)
#define BIT_SET_ABORT_RX_VBON_COUNTER_8822B(x, v) \
(BIT_CLEAR_ABORT_RX_VBON_COUNTER_8822B(x) | \
BIT_ABORT_RX_VBON_COUNTER_8822B(v))
#define BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822B 8
#define BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822B 0xff
#define BIT_ABORT_RX_RDRDY_COUNTER_8822B(x) \
(((x) & BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822B) \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822B)
#define BITS_ABORT_RX_RDRDY_COUNTER_8822B \
(BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822B \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822B)
#define BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8822B(x) \
((x) & (~BITS_ABORT_RX_RDRDY_COUNTER_8822B))
#define BIT_GET_ABORT_RX_RDRDY_COUNTER_8822B(x) \
(((x) >> BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822B) & \
BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822B)
#define BIT_SET_ABORT_RX_RDRDY_COUNTER_8822B(x, v) \
(BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8822B(x) | \
BIT_ABORT_RX_RDRDY_COUNTER_8822B(v))
#define BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822B 0
#define BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822B 0xff
#define BIT_VBON_EARLY_FALLING_COUNTER_8822B(x) \
(((x) & BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822B) \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822B)
#define BITS_VBON_EARLY_FALLING_COUNTER_8822B \
(BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822B \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822B)
#define BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8822B(x) \
((x) & (~BITS_VBON_EARLY_FALLING_COUNTER_8822B))
#define BIT_GET_VBON_EARLY_FALLING_COUNTER_8822B(x) \
(((x) >> BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822B) & \
BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822B)
#define BIT_SET_VBON_EARLY_FALLING_COUNTER_8822B(x, v) \
(BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8822B(x) | \
BIT_VBON_EARLY_FALLING_COUNTER_8822B(v))
/* 2 REG_NOT_VALID_8822B */
#define BIT_WMAC_PLCP_TRX_SEL_8822B BIT(31)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822B 28
#define BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822B 0x7
#define BIT_WMAC_PLCP_RDSIG_SEL_8822B(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822B) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822B)
#define BITS_WMAC_PLCP_RDSIG_SEL_8822B \
(BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822B \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822B)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8822B(x) \
((x) & (~BITS_WMAC_PLCP_RDSIG_SEL_8822B))
#define BIT_GET_WMAC_PLCP_RDSIG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822B) & \
BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822B)
#define BIT_SET_WMAC_PLCP_RDSIG_SEL_8822B(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8822B(x) | \
BIT_WMAC_PLCP_RDSIG_SEL_8822B(v))
#define BIT_SHIFT_WMAC_RATE_IDX_8822B 24
#define BIT_MASK_WMAC_RATE_IDX_8822B 0xf
#define BIT_WMAC_RATE_IDX_8822B(x) \
(((x) & BIT_MASK_WMAC_RATE_IDX_8822B) << BIT_SHIFT_WMAC_RATE_IDX_8822B)
#define BITS_WMAC_RATE_IDX_8822B \
(BIT_MASK_WMAC_RATE_IDX_8822B << BIT_SHIFT_WMAC_RATE_IDX_8822B)
#define BIT_CLEAR_WMAC_RATE_IDX_8822B(x) ((x) & (~BITS_WMAC_RATE_IDX_8822B))
#define BIT_GET_WMAC_RATE_IDX_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_RATE_IDX_8822B) & BIT_MASK_WMAC_RATE_IDX_8822B)
#define BIT_SET_WMAC_RATE_IDX_8822B(x, v) \
(BIT_CLEAR_WMAC_RATE_IDX_8822B(x) | BIT_WMAC_RATE_IDX_8822B(v))
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8822B 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8822B 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8822B(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8822B) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8822B)
#define BITS_WMAC_PLCP_RDSIG_8822B \
(BIT_MASK_WMAC_PLCP_RDSIG_8822B << BIT_SHIFT_WMAC_PLCP_RDSIG_8822B)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8822B(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8822B))
#define BIT_GET_WMAC_PLCP_RDSIG_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8822B) & \
BIT_MASK_WMAC_PLCP_RDSIG_8822B)
#define BIT_SET_WMAC_PLCP_RDSIG_8822B(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8822B(x) | BIT_WMAC_PLCP_RDSIG_8822B(v))
/* 2 REG_NOT_VALID_8822B */
#define BIT_WMAC_MUTX_IDX_8822B BIT(24)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8822B 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8822B 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8822B(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8822B) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8822B)
#define BITS_WMAC_PLCP_RDSIG_8822B \
(BIT_MASK_WMAC_PLCP_RDSIG_8822B << BIT_SHIFT_WMAC_PLCP_RDSIG_8822B)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8822B(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8822B))
#define BIT_GET_WMAC_PLCP_RDSIG_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8822B) & \
BIT_MASK_WMAC_PLCP_RDSIG_8822B)
#define BIT_SET_WMAC_PLCP_RDSIG_8822B(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8822B(x) | BIT_WMAC_PLCP_RDSIG_8822B(v))
/* 2 REG_TRANSMIT_ADDRSS_0_8822B (TA0 REGISTER) */
#define BIT_SHIFT_TA0_8822B 0
#define BIT_MASK_TA0_8822B 0xffffffffffffL
#define BIT_TA0_8822B(x) (((x) & BIT_MASK_TA0_8822B) << BIT_SHIFT_TA0_8822B)
#define BITS_TA0_8822B (BIT_MASK_TA0_8822B << BIT_SHIFT_TA0_8822B)
#define BIT_CLEAR_TA0_8822B(x) ((x) & (~BITS_TA0_8822B))
#define BIT_GET_TA0_8822B(x) (((x) >> BIT_SHIFT_TA0_8822B) & BIT_MASK_TA0_8822B)
#define BIT_SET_TA0_8822B(x, v) (BIT_CLEAR_TA0_8822B(x) | BIT_TA0_8822B(v))
/* 2 REG_TRANSMIT_ADDRSS_1_8822B (TA1 REGISTER) */
#define BIT_SHIFT_TA1_8822B 0
#define BIT_MASK_TA1_8822B 0xffffffffffffL
#define BIT_TA1_8822B(x) (((x) & BIT_MASK_TA1_8822B) << BIT_SHIFT_TA1_8822B)
#define BITS_TA1_8822B (BIT_MASK_TA1_8822B << BIT_SHIFT_TA1_8822B)
#define BIT_CLEAR_TA1_8822B(x) ((x) & (~BITS_TA1_8822B))
#define BIT_GET_TA1_8822B(x) (((x) >> BIT_SHIFT_TA1_8822B) & BIT_MASK_TA1_8822B)
#define BIT_SET_TA1_8822B(x, v) (BIT_CLEAR_TA1_8822B(x) | BIT_TA1_8822B(v))
/* 2 REG_TRANSMIT_ADDRSS_2_8822B (TA2 REGISTER) */
#define BIT_SHIFT_TA2_8822B 0
#define BIT_MASK_TA2_8822B 0xffffffffffffL
#define BIT_TA2_8822B(x) (((x) & BIT_MASK_TA2_8822B) << BIT_SHIFT_TA2_8822B)
#define BITS_TA2_8822B (BIT_MASK_TA2_8822B << BIT_SHIFT_TA2_8822B)
#define BIT_CLEAR_TA2_8822B(x) ((x) & (~BITS_TA2_8822B))
#define BIT_GET_TA2_8822B(x) (((x) >> BIT_SHIFT_TA2_8822B) & BIT_MASK_TA2_8822B)
#define BIT_SET_TA2_8822B(x, v) (BIT_CLEAR_TA2_8822B(x) | BIT_TA2_8822B(v))
/* 2 REG_TRANSMIT_ADDRSS_3_8822B (TA3 REGISTER) */
#define BIT_SHIFT_TA3_8822B 0
#define BIT_MASK_TA3_8822B 0xffffffffffffL
#define BIT_TA3_8822B(x) (((x) & BIT_MASK_TA3_8822B) << BIT_SHIFT_TA3_8822B)
#define BITS_TA3_8822B (BIT_MASK_TA3_8822B << BIT_SHIFT_TA3_8822B)
#define BIT_CLEAR_TA3_8822B(x) ((x) & (~BITS_TA3_8822B))
#define BIT_GET_TA3_8822B(x) (((x) >> BIT_SHIFT_TA3_8822B) & BIT_MASK_TA3_8822B)
#define BIT_SET_TA3_8822B(x, v) (BIT_CLEAR_TA3_8822B(x) | BIT_TA3_8822B(v))
/* 2 REG_TRANSMIT_ADDRSS_4_8822B (TA4 REGISTER) */
#define BIT_SHIFT_TA4_8822B 0
#define BIT_MASK_TA4_8822B 0xffffffffffffL
#define BIT_TA4_8822B(x) (((x) & BIT_MASK_TA4_8822B) << BIT_SHIFT_TA4_8822B)
#define BITS_TA4_8822B (BIT_MASK_TA4_8822B << BIT_SHIFT_TA4_8822B)
#define BIT_CLEAR_TA4_8822B(x) ((x) & (~BITS_TA4_8822B))
#define BIT_GET_TA4_8822B(x) (((x) >> BIT_SHIFT_TA4_8822B) & BIT_MASK_TA4_8822B)
#define BIT_SET_TA4_8822B(x, v) (BIT_CLEAR_TA4_8822B(x) | BIT_TA4_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_MACID1_8822B */
#define BIT_SHIFT_MACID1_8822B 0
#define BIT_MASK_MACID1_8822B 0xffffffffffffL
#define BIT_MACID1_8822B(x) \
(((x) & BIT_MASK_MACID1_8822B) << BIT_SHIFT_MACID1_8822B)
#define BITS_MACID1_8822B (BIT_MASK_MACID1_8822B << BIT_SHIFT_MACID1_8822B)
#define BIT_CLEAR_MACID1_8822B(x) ((x) & (~BITS_MACID1_8822B))
#define BIT_GET_MACID1_8822B(x) \
(((x) >> BIT_SHIFT_MACID1_8822B) & BIT_MASK_MACID1_8822B)
#define BIT_SET_MACID1_8822B(x, v) \
(BIT_CLEAR_MACID1_8822B(x) | BIT_MACID1_8822B(v))
/* 2 REG_BSSID1_8822B */
#define BIT_SHIFT_BSSID1_8822B 0
#define BIT_MASK_BSSID1_8822B 0xffffffffffffL
#define BIT_BSSID1_8822B(x) \
(((x) & BIT_MASK_BSSID1_8822B) << BIT_SHIFT_BSSID1_8822B)
#define BITS_BSSID1_8822B (BIT_MASK_BSSID1_8822B << BIT_SHIFT_BSSID1_8822B)
#define BIT_CLEAR_BSSID1_8822B(x) ((x) & (~BITS_BSSID1_8822B))
#define BIT_GET_BSSID1_8822B(x) \
(((x) >> BIT_SHIFT_BSSID1_8822B) & BIT_MASK_BSSID1_8822B)
#define BIT_SET_BSSID1_8822B(x, v) \
(BIT_CLEAR_BSSID1_8822B(x) | BIT_BSSID1_8822B(v))
/* 2 REG_BCN_PSR_RPT1_8822B */
#define BIT_SHIFT_DTIM_CNT1_8822B 24
#define BIT_MASK_DTIM_CNT1_8822B 0xff
#define BIT_DTIM_CNT1_8822B(x) \
(((x) & BIT_MASK_DTIM_CNT1_8822B) << BIT_SHIFT_DTIM_CNT1_8822B)
#define BITS_DTIM_CNT1_8822B \
(BIT_MASK_DTIM_CNT1_8822B << BIT_SHIFT_DTIM_CNT1_8822B)
#define BIT_CLEAR_DTIM_CNT1_8822B(x) ((x) & (~BITS_DTIM_CNT1_8822B))
#define BIT_GET_DTIM_CNT1_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_CNT1_8822B) & BIT_MASK_DTIM_CNT1_8822B)
#define BIT_SET_DTIM_CNT1_8822B(x, v) \
(BIT_CLEAR_DTIM_CNT1_8822B(x) | BIT_DTIM_CNT1_8822B(v))
#define BIT_SHIFT_DTIM_PERIOD1_8822B 16
#define BIT_MASK_DTIM_PERIOD1_8822B 0xff
#define BIT_DTIM_PERIOD1_8822B(x) \
(((x) & BIT_MASK_DTIM_PERIOD1_8822B) << BIT_SHIFT_DTIM_PERIOD1_8822B)
#define BITS_DTIM_PERIOD1_8822B \
(BIT_MASK_DTIM_PERIOD1_8822B << BIT_SHIFT_DTIM_PERIOD1_8822B)
#define BIT_CLEAR_DTIM_PERIOD1_8822B(x) ((x) & (~BITS_DTIM_PERIOD1_8822B))
#define BIT_GET_DTIM_PERIOD1_8822B(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD1_8822B) & BIT_MASK_DTIM_PERIOD1_8822B)
#define BIT_SET_DTIM_PERIOD1_8822B(x, v) \
(BIT_CLEAR_DTIM_PERIOD1_8822B(x) | BIT_DTIM_PERIOD1_8822B(v))
#define BIT_DTIM1_8822B BIT(15)
#define BIT_TIM1_8822B BIT(14)
#define BIT_SHIFT_PS_AID_1_8822B 0
#define BIT_MASK_PS_AID_1_8822B 0x7ff
#define BIT_PS_AID_1_8822B(x) \
(((x) & BIT_MASK_PS_AID_1_8822B) << BIT_SHIFT_PS_AID_1_8822B)
#define BITS_PS_AID_1_8822B \
(BIT_MASK_PS_AID_1_8822B << BIT_SHIFT_PS_AID_1_8822B)
#define BIT_CLEAR_PS_AID_1_8822B(x) ((x) & (~BITS_PS_AID_1_8822B))
#define BIT_GET_PS_AID_1_8822B(x) \
(((x) >> BIT_SHIFT_PS_AID_1_8822B) & BIT_MASK_PS_AID_1_8822B)
#define BIT_SET_PS_AID_1_8822B(x, v) \
(BIT_CLEAR_PS_AID_1_8822B(x) | BIT_PS_AID_1_8822B(v))
/* 2 REG_ASSOCIATED_BFMEE_SEL_8822B */
#define BIT_TXUSER_ID1_8822B BIT(25)
#define BIT_SHIFT_AID1_8822B 16
#define BIT_MASK_AID1_8822B 0x1ff
#define BIT_AID1_8822B(x) (((x) & BIT_MASK_AID1_8822B) << BIT_SHIFT_AID1_8822B)
#define BITS_AID1_8822B (BIT_MASK_AID1_8822B << BIT_SHIFT_AID1_8822B)
#define BIT_CLEAR_AID1_8822B(x) ((x) & (~BITS_AID1_8822B))
#define BIT_GET_AID1_8822B(x) \
(((x) >> BIT_SHIFT_AID1_8822B) & BIT_MASK_AID1_8822B)
#define BIT_SET_AID1_8822B(x, v) (BIT_CLEAR_AID1_8822B(x) | BIT_AID1_8822B(v))
#define BIT_TXUSER_ID0_8822B BIT(9)
#define BIT_SHIFT_AID0_8822B 0
#define BIT_MASK_AID0_8822B 0x1ff
#define BIT_AID0_8822B(x) (((x) & BIT_MASK_AID0_8822B) << BIT_SHIFT_AID0_8822B)
#define BITS_AID0_8822B (BIT_MASK_AID0_8822B << BIT_SHIFT_AID0_8822B)
#define BIT_CLEAR_AID0_8822B(x) ((x) & (~BITS_AID0_8822B))
#define BIT_GET_AID0_8822B(x) \
(((x) >> BIT_SHIFT_AID0_8822B) & BIT_MASK_AID0_8822B)
#define BIT_SET_AID0_8822B(x, v) (BIT_CLEAR_AID0_8822B(x) | BIT_AID0_8822B(v))
/* 2 REG_SND_PTCL_CTRL_8822B */
#define BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822B 24
#define BIT_MASK_NDP_RX_STANDBY_TIMER_8822B 0xff
#define BIT_NDP_RX_STANDBY_TIMER_8822B(x) \
(((x) & BIT_MASK_NDP_RX_STANDBY_TIMER_8822B) \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822B)
#define BITS_NDP_RX_STANDBY_TIMER_8822B \
(BIT_MASK_NDP_RX_STANDBY_TIMER_8822B \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822B)
#define BIT_CLEAR_NDP_RX_STANDBY_TIMER_8822B(x) \
((x) & (~BITS_NDP_RX_STANDBY_TIMER_8822B))
#define BIT_GET_NDP_RX_STANDBY_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822B) & \
BIT_MASK_NDP_RX_STANDBY_TIMER_8822B)
#define BIT_SET_NDP_RX_STANDBY_TIMER_8822B(x, v) \
(BIT_CLEAR_NDP_RX_STANDBY_TIMER_8822B(x) | \
BIT_NDP_RX_STANDBY_TIMER_8822B(v))
#define BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822B 16
#define BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822B 0x3f
#define BIT_CSI_RPT_OFFSET_HT_V1_8822B(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822B) \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822B)
#define BITS_CSI_RPT_OFFSET_HT_V1_8822B \
(BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822B \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822B)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT_V1_8822B(x) \
((x) & (~BITS_CSI_RPT_OFFSET_HT_V1_8822B))
#define BIT_GET_CSI_RPT_OFFSET_HT_V1_8822B(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822B) & \
BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822B)
#define BIT_SET_CSI_RPT_OFFSET_HT_V1_8822B(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT_V1_8822B(x) | \
BIT_CSI_RPT_OFFSET_HT_V1_8822B(v))
#define BIT_VHTNDP_RPTPOLL_CSI_STR_OFFSET_SEL_8822B BIT(15)
#define BIT_NDPVLD_POS_RST_FFPTR_DIS_8822B BIT(14)
#define BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8822B 8
#define BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8822B 0x3f
#define BIT_R_CSI_RPT_OFFSET_VHT_V1_8822B(x) \
(((x) & BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8822B) \
<< BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8822B)
#define BITS_R_CSI_RPT_OFFSET_VHT_V1_8822B \
(BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8822B \
<< BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8822B)
#define BIT_CLEAR_R_CSI_RPT_OFFSET_VHT_V1_8822B(x) \
((x) & (~BITS_R_CSI_RPT_OFFSET_VHT_V1_8822B))
#define BIT_GET_R_CSI_RPT_OFFSET_VHT_V1_8822B(x) \
(((x) >> BIT_SHIFT_R_CSI_RPT_OFFSET_VHT_V1_8822B) & \
BIT_MASK_R_CSI_RPT_OFFSET_VHT_V1_8822B)
#define BIT_SET_R_CSI_RPT_OFFSET_VHT_V1_8822B(x, v) \
(BIT_CLEAR_R_CSI_RPT_OFFSET_VHT_V1_8822B(x) | \
BIT_R_CSI_RPT_OFFSET_VHT_V1_8822B(v))
#define BIT_R_WMAC_USE_NSTS_8822B BIT(7)
#define BIT_R_DISABLE_CHECK_VHTSIGB_CRC_8822B BIT(6)
#define BIT_R_DISABLE_CHECK_VHTSIGA_CRC_8822B BIT(5)
#define BIT_R_WMAC_BFPARAM_SEL_8822B BIT(4)
#define BIT_R_WMAC_CSISEQ_SEL_8822B BIT(3)
#define BIT_R_WMAC_CSI_WITHHTC_EN_8822B BIT(2)
#define BIT_R_WMAC_HT_NDPA_EN_8822B BIT(1)
#define BIT_R_WMAC_VHT_NDPA_EN_8822B BIT(0)
/* 2 REG_RX_CSI_RPT_INFO_8822B */
/* 2 REG_NS_ARP_CTRL_8822B */
#define BIT_R_WMAC_NSARP_RSPEN_8822B BIT(15)
#define BIT_R_WMAC_NSARP_RARP_8822B BIT(9)
#define BIT_R_WMAC_NSARP_RIPV6_8822B BIT(8)
#define BIT_SHIFT_R_WMAC_NSARP_MODEN_8822B 6
#define BIT_MASK_R_WMAC_NSARP_MODEN_8822B 0x3
#define BIT_R_WMAC_NSARP_MODEN_8822B(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_MODEN_8822B) \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8822B)
#define BITS_R_WMAC_NSARP_MODEN_8822B \
(BIT_MASK_R_WMAC_NSARP_MODEN_8822B \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8822B)
#define BIT_CLEAR_R_WMAC_NSARP_MODEN_8822B(x) \
((x) & (~BITS_R_WMAC_NSARP_MODEN_8822B))
#define BIT_GET_R_WMAC_NSARP_MODEN_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_MODEN_8822B) & \
BIT_MASK_R_WMAC_NSARP_MODEN_8822B)
#define BIT_SET_R_WMAC_NSARP_MODEN_8822B(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_MODEN_8822B(x) | \
BIT_R_WMAC_NSARP_MODEN_8822B(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822B 4
#define BIT_MASK_R_WMAC_NSARP_RSPFTP_8822B 0x3
#define BIT_R_WMAC_NSARP_RSPFTP_8822B(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPFTP_8822B) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822B)
#define BITS_R_WMAC_NSARP_RSPFTP_8822B \
(BIT_MASK_R_WMAC_NSARP_RSPFTP_8822B \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822B)
#define BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8822B(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPFTP_8822B))
#define BIT_GET_R_WMAC_NSARP_RSPFTP_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822B) & \
BIT_MASK_R_WMAC_NSARP_RSPFTP_8822B)
#define BIT_SET_R_WMAC_NSARP_RSPFTP_8822B(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8822B(x) | \
BIT_R_WMAC_NSARP_RSPFTP_8822B(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822B 0
#define BIT_MASK_R_WMAC_NSARP_RSPSEC_8822B 0xf
#define BIT_R_WMAC_NSARP_RSPSEC_8822B(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPSEC_8822B) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822B)
#define BITS_R_WMAC_NSARP_RSPSEC_8822B \
(BIT_MASK_R_WMAC_NSARP_RSPSEC_8822B \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822B)
#define BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8822B(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPSEC_8822B))
#define BIT_GET_R_WMAC_NSARP_RSPSEC_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822B) & \
BIT_MASK_R_WMAC_NSARP_RSPSEC_8822B)
#define BIT_SET_R_WMAC_NSARP_RSPSEC_8822B(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8822B(x) | \
BIT_R_WMAC_NSARP_RSPSEC_8822B(v))
/* 2 REG_NS_ARP_INFO_8822B */
#define BIT_REQ_IS_MCNS_8822B BIT(23)
#define BIT_REQ_IS_UCNS_8822B BIT(22)
#define BIT_REQ_IS_USNS_8822B BIT(21)
#define BIT_REQ_IS_ARP_8822B BIT(20)
#define BIT_EXPRSP_MH_WITHQC_8822B BIT(19)
#define BIT_SHIFT_EXPRSP_SECTYPE_8822B 16
#define BIT_MASK_EXPRSP_SECTYPE_8822B 0x7
#define BIT_EXPRSP_SECTYPE_8822B(x) \
(((x) & BIT_MASK_EXPRSP_SECTYPE_8822B) \
<< BIT_SHIFT_EXPRSP_SECTYPE_8822B)
#define BITS_EXPRSP_SECTYPE_8822B \
(BIT_MASK_EXPRSP_SECTYPE_8822B << BIT_SHIFT_EXPRSP_SECTYPE_8822B)
#define BIT_CLEAR_EXPRSP_SECTYPE_8822B(x) ((x) & (~BITS_EXPRSP_SECTYPE_8822B))
#define BIT_GET_EXPRSP_SECTYPE_8822B(x) \
(((x) >> BIT_SHIFT_EXPRSP_SECTYPE_8822B) & \
BIT_MASK_EXPRSP_SECTYPE_8822B)
#define BIT_SET_EXPRSP_SECTYPE_8822B(x, v) \
(BIT_CLEAR_EXPRSP_SECTYPE_8822B(x) | BIT_EXPRSP_SECTYPE_8822B(v))
#define BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822B 8
#define BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822B 0xff
#define BIT_EXPRSP_CHKSM_7_TO_0_8822B(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822B) \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822B)
#define BITS_EXPRSP_CHKSM_7_TO_0_8822B \
(BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822B \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822B)
#define BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8822B(x) \
((x) & (~BITS_EXPRSP_CHKSM_7_TO_0_8822B))
#define BIT_GET_EXPRSP_CHKSM_7_TO_0_8822B(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822B) & \
BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822B)
#define BIT_SET_EXPRSP_CHKSM_7_TO_0_8822B(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8822B(x) | \
BIT_EXPRSP_CHKSM_7_TO_0_8822B(v))
#define BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822B 0
#define BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822B 0xff
#define BIT_EXPRSP_CHKSM_15_TO_8_8822B(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822B) \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822B)
#define BITS_EXPRSP_CHKSM_15_TO_8_8822B \
(BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822B \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822B)
#define BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8822B(x) \
((x) & (~BITS_EXPRSP_CHKSM_15_TO_8_8822B))
#define BIT_GET_EXPRSP_CHKSM_15_TO_8_8822B(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822B) & \
BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822B)
#define BIT_SET_EXPRSP_CHKSM_15_TO_8_8822B(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8822B(x) | \
BIT_EXPRSP_CHKSM_15_TO_8_8822B(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_V1_8822B */
#define BIT_SHIFT_WMAC_ARPIP_8822B 0
#define BIT_MASK_WMAC_ARPIP_8822B 0xffffffffL
#define BIT_WMAC_ARPIP_8822B(x) \
(((x) & BIT_MASK_WMAC_ARPIP_8822B) << BIT_SHIFT_WMAC_ARPIP_8822B)
#define BITS_WMAC_ARPIP_8822B \
(BIT_MASK_WMAC_ARPIP_8822B << BIT_SHIFT_WMAC_ARPIP_8822B)
#define BIT_CLEAR_WMAC_ARPIP_8822B(x) ((x) & (~BITS_WMAC_ARPIP_8822B))
#define BIT_GET_WMAC_ARPIP_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_ARPIP_8822B) & BIT_MASK_WMAC_ARPIP_8822B)
#define BIT_SET_WMAC_ARPIP_8822B(x, v) \
(BIT_CLEAR_WMAC_ARPIP_8822B(x) | BIT_WMAC_ARPIP_8822B(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_8822B */
#define BIT_SHIFT_BEAMFORMING_INFO_8822B 0
#define BIT_MASK_BEAMFORMING_INFO_8822B 0xffffffffL
#define BIT_BEAMFORMING_INFO_8822B(x) \
(((x) & BIT_MASK_BEAMFORMING_INFO_8822B) \
<< BIT_SHIFT_BEAMFORMING_INFO_8822B)
#define BITS_BEAMFORMING_INFO_8822B \
(BIT_MASK_BEAMFORMING_INFO_8822B << BIT_SHIFT_BEAMFORMING_INFO_8822B)
#define BIT_CLEAR_BEAMFORMING_INFO_8822B(x) \
((x) & (~BITS_BEAMFORMING_INFO_8822B))
#define BIT_GET_BEAMFORMING_INFO_8822B(x) \
(((x) >> BIT_SHIFT_BEAMFORMING_INFO_8822B) & \
BIT_MASK_BEAMFORMING_INFO_8822B)
#define BIT_SET_BEAMFORMING_INFO_8822B(x, v) \
(BIT_CLEAR_BEAMFORMING_INFO_8822B(x) | BIT_BEAMFORMING_INFO_8822B(v))
/* 2 REG_NOT_VALID_8822B */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_8822B 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_8822B 0xffffffffffffffffffffffffffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_8822B(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_8822B) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_8822B)
#define BITS_R_WMAC_IPV6_MYIPAD_8822B \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_8822B \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_8822B)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_8822B(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_8822B))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_8822B) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_8822B)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_8822B(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_8822B(x) | \
BIT_R_WMAC_IPV6_MYIPAD_8822B(v))
/* 2 REG_RSVD_0X740_8822B */
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG_8822B */
#define BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822B 4
#define BIT_MASK_R_WMAC_CTX_SUBTYPE_8822B 0xf
#define BIT_R_WMAC_CTX_SUBTYPE_8822B(x) \
(((x) & BIT_MASK_R_WMAC_CTX_SUBTYPE_8822B) \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822B)
#define BITS_R_WMAC_CTX_SUBTYPE_8822B \
(BIT_MASK_R_WMAC_CTX_SUBTYPE_8822B \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822B)
#define BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8822B(x) \
((x) & (~BITS_R_WMAC_CTX_SUBTYPE_8822B))
#define BIT_GET_R_WMAC_CTX_SUBTYPE_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822B) & \
BIT_MASK_R_WMAC_CTX_SUBTYPE_8822B)
#define BIT_SET_R_WMAC_CTX_SUBTYPE_8822B(x, v) \
(BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8822B(x) | \
BIT_R_WMAC_CTX_SUBTYPE_8822B(v))
#define BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822B 0
#define BIT_MASK_R_WMAC_RTX_SUBTYPE_8822B 0xf
#define BIT_R_WMAC_RTX_SUBTYPE_8822B(x) \
(((x) & BIT_MASK_R_WMAC_RTX_SUBTYPE_8822B) \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822B)
#define BITS_R_WMAC_RTX_SUBTYPE_8822B \
(BIT_MASK_R_WMAC_RTX_SUBTYPE_8822B \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822B)
#define BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8822B(x) \
((x) & (~BITS_R_WMAC_RTX_SUBTYPE_8822B))
#define BIT_GET_R_WMAC_RTX_SUBTYPE_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822B) & \
BIT_MASK_R_WMAC_RTX_SUBTYPE_8822B)
#define BIT_SET_R_WMAC_RTX_SUBTYPE_8822B(x, v) \
(BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8822B(x) | \
BIT_R_WMAC_RTX_SUBTYPE_8822B(v))
/* 2 REG_WMAC_SWAES_CFG_8822B */
/* 2 REG_BT_COEX_V2_8822B */
#define BIT_GNT_BT_POLARITY_8822B BIT(12)
#define BIT_GNT_BT_BYPASS_PRIORITY_8822B BIT(8)
#define BIT_SHIFT_TIMER_8822B 0
#define BIT_MASK_TIMER_8822B 0xff
#define BIT_TIMER_8822B(x) \
(((x) & BIT_MASK_TIMER_8822B) << BIT_SHIFT_TIMER_8822B)
#define BITS_TIMER_8822B (BIT_MASK_TIMER_8822B << BIT_SHIFT_TIMER_8822B)
#define BIT_CLEAR_TIMER_8822B(x) ((x) & (~BITS_TIMER_8822B))
#define BIT_GET_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_TIMER_8822B) & BIT_MASK_TIMER_8822B)
#define BIT_SET_TIMER_8822B(x, v) \
(BIT_CLEAR_TIMER_8822B(x) | BIT_TIMER_8822B(v))
/* 2 REG_BT_COEX_8822B */
#define BIT_R_GNT_BT_RFC_SW_8822B BIT(12)
#define BIT_R_GNT_BT_RFC_SW_EN_8822B BIT(11)
#define BIT_R_GNT_BT_BB_SW_8822B BIT(10)
#define BIT_R_GNT_BT_BB_SW_EN_8822B BIT(9)
#define BIT_R_BT_CNT_THREN_8822B BIT(8)
#define BIT_SHIFT_R_BT_CNT_THR_8822B 0
#define BIT_MASK_R_BT_CNT_THR_8822B 0xff
#define BIT_R_BT_CNT_THR_8822B(x) \
(((x) & BIT_MASK_R_BT_CNT_THR_8822B) << BIT_SHIFT_R_BT_CNT_THR_8822B)
#define BITS_R_BT_CNT_THR_8822B \
(BIT_MASK_R_BT_CNT_THR_8822B << BIT_SHIFT_R_BT_CNT_THR_8822B)
#define BIT_CLEAR_R_BT_CNT_THR_8822B(x) ((x) & (~BITS_R_BT_CNT_THR_8822B))
#define BIT_GET_R_BT_CNT_THR_8822B(x) \
(((x) >> BIT_SHIFT_R_BT_CNT_THR_8822B) & BIT_MASK_R_BT_CNT_THR_8822B)
#define BIT_SET_R_BT_CNT_THR_8822B(x, v) \
(BIT_CLEAR_R_BT_CNT_THR_8822B(x) | BIT_R_BT_CNT_THR_8822B(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_8822B */
#define BIT_WLRX_TER_BY_CTL_8822B BIT(43)
#define BIT_WLRX_TER_BY_AD_8822B BIT(42)
#define BIT_ANT_DIVERSITY_SEL_8822B BIT(41)
#define BIT_ANTSEL_FOR_BT_CTRL_EN_8822B BIT(40)
#define BIT_WLACT_LOW_GNTWL_EN_8822B BIT(34)
#define BIT_WLACT_HIGH_GNTBT_EN_8822B BIT(33)
#define BIT_NAV_UPPER_V1_8822B BIT(32)
#define BIT_SHIFT_RXMYRTS_NAV_V1_8822B 8
#define BIT_MASK_RXMYRTS_NAV_V1_8822B 0xff
#define BIT_RXMYRTS_NAV_V1_8822B(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_V1_8822B) \
<< BIT_SHIFT_RXMYRTS_NAV_V1_8822B)
#define BITS_RXMYRTS_NAV_V1_8822B \
(BIT_MASK_RXMYRTS_NAV_V1_8822B << BIT_SHIFT_RXMYRTS_NAV_V1_8822B)
#define BIT_CLEAR_RXMYRTS_NAV_V1_8822B(x) ((x) & (~BITS_RXMYRTS_NAV_V1_8822B))
#define BIT_GET_RXMYRTS_NAV_V1_8822B(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_V1_8822B) & \
BIT_MASK_RXMYRTS_NAV_V1_8822B)
#define BIT_SET_RXMYRTS_NAV_V1_8822B(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_V1_8822B(x) | BIT_RXMYRTS_NAV_V1_8822B(v))
#define BIT_SHIFT_RTSRST_V1_8822B 0
#define BIT_MASK_RTSRST_V1_8822B 0xff
#define BIT_RTSRST_V1_8822B(x) \
(((x) & BIT_MASK_RTSRST_V1_8822B) << BIT_SHIFT_RTSRST_V1_8822B)
#define BITS_RTSRST_V1_8822B \
(BIT_MASK_RTSRST_V1_8822B << BIT_SHIFT_RTSRST_V1_8822B)
#define BIT_CLEAR_RTSRST_V1_8822B(x) ((x) & (~BITS_RTSRST_V1_8822B))
#define BIT_GET_RTSRST_V1_8822B(x) \
(((x) >> BIT_SHIFT_RTSRST_V1_8822B) & BIT_MASK_RTSRST_V1_8822B)
#define BIT_SET_RTSRST_V1_8822B(x, v) \
(BIT_CLEAR_RTSRST_V1_8822B(x) | BIT_RTSRST_V1_8822B(v))
/* 2 REG_BT_COEX_ENHANCED_INTR_CTRL_8822B */
#define BIT_SHIFT_BT_STAT_DELAY_8822B 12
#define BIT_MASK_BT_STAT_DELAY_8822B 0xf
#define BIT_BT_STAT_DELAY_8822B(x) \
(((x) & BIT_MASK_BT_STAT_DELAY_8822B) << BIT_SHIFT_BT_STAT_DELAY_8822B)
#define BITS_BT_STAT_DELAY_8822B \
(BIT_MASK_BT_STAT_DELAY_8822B << BIT_SHIFT_BT_STAT_DELAY_8822B)
#define BIT_CLEAR_BT_STAT_DELAY_8822B(x) ((x) & (~BITS_BT_STAT_DELAY_8822B))
#define BIT_GET_BT_STAT_DELAY_8822B(x) \
(((x) >> BIT_SHIFT_BT_STAT_DELAY_8822B) & BIT_MASK_BT_STAT_DELAY_8822B)
#define BIT_SET_BT_STAT_DELAY_8822B(x, v) \
(BIT_CLEAR_BT_STAT_DELAY_8822B(x) | BIT_BT_STAT_DELAY_8822B(v))
#define BIT_SHIFT_BT_TRX_INIT_DETECT_8822B 8
#define BIT_MASK_BT_TRX_INIT_DETECT_8822B 0xf
#define BIT_BT_TRX_INIT_DETECT_8822B(x) \
(((x) & BIT_MASK_BT_TRX_INIT_DETECT_8822B) \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8822B)
#define BITS_BT_TRX_INIT_DETECT_8822B \
(BIT_MASK_BT_TRX_INIT_DETECT_8822B \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8822B)
#define BIT_CLEAR_BT_TRX_INIT_DETECT_8822B(x) \
((x) & (~BITS_BT_TRX_INIT_DETECT_8822B))
#define BIT_GET_BT_TRX_INIT_DETECT_8822B(x) \
(((x) >> BIT_SHIFT_BT_TRX_INIT_DETECT_8822B) & \
BIT_MASK_BT_TRX_INIT_DETECT_8822B)
#define BIT_SET_BT_TRX_INIT_DETECT_8822B(x, v) \
(BIT_CLEAR_BT_TRX_INIT_DETECT_8822B(x) | \
BIT_BT_TRX_INIT_DETECT_8822B(v))
#define BIT_SHIFT_BT_PRI_DETECT_TO_8822B 4
#define BIT_MASK_BT_PRI_DETECT_TO_8822B 0xf
#define BIT_BT_PRI_DETECT_TO_8822B(x) \
(((x) & BIT_MASK_BT_PRI_DETECT_TO_8822B) \
<< BIT_SHIFT_BT_PRI_DETECT_TO_8822B)
#define BITS_BT_PRI_DETECT_TO_8822B \
(BIT_MASK_BT_PRI_DETECT_TO_8822B << BIT_SHIFT_BT_PRI_DETECT_TO_8822B)
#define BIT_CLEAR_BT_PRI_DETECT_TO_8822B(x) \
((x) & (~BITS_BT_PRI_DETECT_TO_8822B))
#define BIT_GET_BT_PRI_DETECT_TO_8822B(x) \
(((x) >> BIT_SHIFT_BT_PRI_DETECT_TO_8822B) & \
BIT_MASK_BT_PRI_DETECT_TO_8822B)
#define BIT_SET_BT_PRI_DETECT_TO_8822B(x, v) \
(BIT_CLEAR_BT_PRI_DETECT_TO_8822B(x) | BIT_BT_PRI_DETECT_TO_8822B(v))
#define BIT_R_GRANTALL_WLMASK_8822B BIT(3)
#define BIT_STATIS_BT_EN_8822B BIT(2)
#define BIT_WL_ACT_MASK_ENABLE_8822B BIT(1)
#define BIT_ENHANCED_BT_8822B BIT(0)
/* 2 REG_BT_ACT_STATISTICS_8822B */
#define BIT_SHIFT_STATIS_BT_LO_RX_8822B (48 & CPU_OPT_WIDTH)
#define BIT_MASK_STATIS_BT_LO_RX_8822B 0xffff
#define BIT_STATIS_BT_LO_RX_8822B(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX_8822B) \
<< BIT_SHIFT_STATIS_BT_LO_RX_8822B)
#define BITS_STATIS_BT_LO_RX_8822B \
(BIT_MASK_STATIS_BT_LO_RX_8822B << BIT_SHIFT_STATIS_BT_LO_RX_8822B)
#define BIT_CLEAR_STATIS_BT_LO_RX_8822B(x) ((x) & (~BITS_STATIS_BT_LO_RX_8822B))
#define BIT_GET_STATIS_BT_LO_RX_8822B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX_8822B) & \
BIT_MASK_STATIS_BT_LO_RX_8822B)
#define BIT_SET_STATIS_BT_LO_RX_8822B(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX_8822B(x) | BIT_STATIS_BT_LO_RX_8822B(v))
#define BIT_SHIFT_STATIS_BT_LO_TX_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_STATIS_BT_LO_TX_8822B 0xffff
#define BIT_STATIS_BT_LO_TX_8822B(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX_8822B) \
<< BIT_SHIFT_STATIS_BT_LO_TX_8822B)
#define BITS_STATIS_BT_LO_TX_8822B \
(BIT_MASK_STATIS_BT_LO_TX_8822B << BIT_SHIFT_STATIS_BT_LO_TX_8822B)
#define BIT_CLEAR_STATIS_BT_LO_TX_8822B(x) ((x) & (~BITS_STATIS_BT_LO_TX_8822B))
#define BIT_GET_STATIS_BT_LO_TX_8822B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX_8822B) & \
BIT_MASK_STATIS_BT_LO_TX_8822B)
#define BIT_SET_STATIS_BT_LO_TX_8822B(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX_8822B(x) | BIT_STATIS_BT_LO_TX_8822B(v))
#define BIT_SHIFT_STATIS_BT_HI_RX_8822B 16
#define BIT_MASK_STATIS_BT_HI_RX_8822B 0xffff
#define BIT_STATIS_BT_HI_RX_8822B(x) \
(((x) & BIT_MASK_STATIS_BT_HI_RX_8822B) \
<< BIT_SHIFT_STATIS_BT_HI_RX_8822B)
#define BITS_STATIS_BT_HI_RX_8822B \
(BIT_MASK_STATIS_BT_HI_RX_8822B << BIT_SHIFT_STATIS_BT_HI_RX_8822B)
#define BIT_CLEAR_STATIS_BT_HI_RX_8822B(x) ((x) & (~BITS_STATIS_BT_HI_RX_8822B))
#define BIT_GET_STATIS_BT_HI_RX_8822B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_RX_8822B) & \
BIT_MASK_STATIS_BT_HI_RX_8822B)
#define BIT_SET_STATIS_BT_HI_RX_8822B(x, v) \
(BIT_CLEAR_STATIS_BT_HI_RX_8822B(x) | BIT_STATIS_BT_HI_RX_8822B(v))
#define BIT_SHIFT_STATIS_BT_HI_TX_8822B 0
#define BIT_MASK_STATIS_BT_HI_TX_8822B 0xffff
#define BIT_STATIS_BT_HI_TX_8822B(x) \
(((x) & BIT_MASK_STATIS_BT_HI_TX_8822B) \
<< BIT_SHIFT_STATIS_BT_HI_TX_8822B)
#define BITS_STATIS_BT_HI_TX_8822B \
(BIT_MASK_STATIS_BT_HI_TX_8822B << BIT_SHIFT_STATIS_BT_HI_TX_8822B)
#define BIT_CLEAR_STATIS_BT_HI_TX_8822B(x) ((x) & (~BITS_STATIS_BT_HI_TX_8822B))
#define BIT_GET_STATIS_BT_HI_TX_8822B(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_TX_8822B) & \
BIT_MASK_STATIS_BT_HI_TX_8822B)
#define BIT_SET_STATIS_BT_HI_TX_8822B(x, v) \
(BIT_CLEAR_STATIS_BT_HI_TX_8822B(x) | BIT_STATIS_BT_HI_TX_8822B(v))
/* 2 REG_BT_STATISTICS_CONTROL_REGISTER_8822B */
#define BIT_SHIFT_R_BT_CMD_RPT_8822B 16
#define BIT_MASK_R_BT_CMD_RPT_8822B 0xffff
#define BIT_R_BT_CMD_RPT_8822B(x) \
(((x) & BIT_MASK_R_BT_CMD_RPT_8822B) << BIT_SHIFT_R_BT_CMD_RPT_8822B)
#define BITS_R_BT_CMD_RPT_8822B \
(BIT_MASK_R_BT_CMD_RPT_8822B << BIT_SHIFT_R_BT_CMD_RPT_8822B)
#define BIT_CLEAR_R_BT_CMD_RPT_8822B(x) ((x) & (~BITS_R_BT_CMD_RPT_8822B))
#define BIT_GET_R_BT_CMD_RPT_8822B(x) \
(((x) >> BIT_SHIFT_R_BT_CMD_RPT_8822B) & BIT_MASK_R_BT_CMD_RPT_8822B)
#define BIT_SET_R_BT_CMD_RPT_8822B(x, v) \
(BIT_CLEAR_R_BT_CMD_RPT_8822B(x) | BIT_R_BT_CMD_RPT_8822B(v))
#define BIT_SHIFT_R_RPT_FROM_BT_8822B 8
#define BIT_MASK_R_RPT_FROM_BT_8822B 0xff
#define BIT_R_RPT_FROM_BT_8822B(x) \
(((x) & BIT_MASK_R_RPT_FROM_BT_8822B) << BIT_SHIFT_R_RPT_FROM_BT_8822B)
#define BITS_R_RPT_FROM_BT_8822B \
(BIT_MASK_R_RPT_FROM_BT_8822B << BIT_SHIFT_R_RPT_FROM_BT_8822B)
#define BIT_CLEAR_R_RPT_FROM_BT_8822B(x) ((x) & (~BITS_R_RPT_FROM_BT_8822B))
#define BIT_GET_R_RPT_FROM_BT_8822B(x) \
(((x) >> BIT_SHIFT_R_RPT_FROM_BT_8822B) & BIT_MASK_R_RPT_FROM_BT_8822B)
#define BIT_SET_R_RPT_FROM_BT_8822B(x, v) \
(BIT_CLEAR_R_RPT_FROM_BT_8822B(x) | BIT_R_RPT_FROM_BT_8822B(v))
#define BIT_SHIFT_BT_HID_ISR_SET_8822B 6
#define BIT_MASK_BT_HID_ISR_SET_8822B 0x3
#define BIT_BT_HID_ISR_SET_8822B(x) \
(((x) & BIT_MASK_BT_HID_ISR_SET_8822B) \
<< BIT_SHIFT_BT_HID_ISR_SET_8822B)
#define BITS_BT_HID_ISR_SET_8822B \
(BIT_MASK_BT_HID_ISR_SET_8822B << BIT_SHIFT_BT_HID_ISR_SET_8822B)
#define BIT_CLEAR_BT_HID_ISR_SET_8822B(x) ((x) & (~BITS_BT_HID_ISR_SET_8822B))
#define BIT_GET_BT_HID_ISR_SET_8822B(x) \
(((x) >> BIT_SHIFT_BT_HID_ISR_SET_8822B) & \
BIT_MASK_BT_HID_ISR_SET_8822B)
#define BIT_SET_BT_HID_ISR_SET_8822B(x, v) \
(BIT_CLEAR_BT_HID_ISR_SET_8822B(x) | BIT_BT_HID_ISR_SET_8822B(v))
#define BIT_TDMA_BT_START_NOTIFY_8822B BIT(5)
#define BIT_ENABLE_TDMA_FW_MODE_8822B BIT(4)
#define BIT_ENABLE_PTA_TDMA_MODE_8822B BIT(3)
#define BIT_ENABLE_COEXIST_TAB_IN_TDMA_8822B BIT(2)
#define BIT_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA_8822B BIT(1)
#define BIT_RTK_BT_ENABLE_8822B BIT(0)
/* 2 REG_BT_STATUS_REPORT_REGISTER_8822B */
#define BIT_SHIFT_BT_PROFILE_8822B 24
#define BIT_MASK_BT_PROFILE_8822B 0xff
#define BIT_BT_PROFILE_8822B(x) \
(((x) & BIT_MASK_BT_PROFILE_8822B) << BIT_SHIFT_BT_PROFILE_8822B)
#define BITS_BT_PROFILE_8822B \
(BIT_MASK_BT_PROFILE_8822B << BIT_SHIFT_BT_PROFILE_8822B)
#define BIT_CLEAR_BT_PROFILE_8822B(x) ((x) & (~BITS_BT_PROFILE_8822B))
#define BIT_GET_BT_PROFILE_8822B(x) \
(((x) >> BIT_SHIFT_BT_PROFILE_8822B) & BIT_MASK_BT_PROFILE_8822B)
#define BIT_SET_BT_PROFILE_8822B(x, v) \
(BIT_CLEAR_BT_PROFILE_8822B(x) | BIT_BT_PROFILE_8822B(v))
#define BIT_SHIFT_BT_POWER_8822B 16
#define BIT_MASK_BT_POWER_8822B 0xff
#define BIT_BT_POWER_8822B(x) \
(((x) & BIT_MASK_BT_POWER_8822B) << BIT_SHIFT_BT_POWER_8822B)
#define BITS_BT_POWER_8822B \
(BIT_MASK_BT_POWER_8822B << BIT_SHIFT_BT_POWER_8822B)
#define BIT_CLEAR_BT_POWER_8822B(x) ((x) & (~BITS_BT_POWER_8822B))
#define BIT_GET_BT_POWER_8822B(x) \
(((x) >> BIT_SHIFT_BT_POWER_8822B) & BIT_MASK_BT_POWER_8822B)
#define BIT_SET_BT_POWER_8822B(x, v) \
(BIT_CLEAR_BT_POWER_8822B(x) | BIT_BT_POWER_8822B(v))
#define BIT_SHIFT_BT_PREDECT_STATUS_8822B 8
#define BIT_MASK_BT_PREDECT_STATUS_8822B 0xff
#define BIT_BT_PREDECT_STATUS_8822B(x) \
(((x) & BIT_MASK_BT_PREDECT_STATUS_8822B) \
<< BIT_SHIFT_BT_PREDECT_STATUS_8822B)
#define BITS_BT_PREDECT_STATUS_8822B \
(BIT_MASK_BT_PREDECT_STATUS_8822B << BIT_SHIFT_BT_PREDECT_STATUS_8822B)
#define BIT_CLEAR_BT_PREDECT_STATUS_8822B(x) \
((x) & (~BITS_BT_PREDECT_STATUS_8822B))
#define BIT_GET_BT_PREDECT_STATUS_8822B(x) \
(((x) >> BIT_SHIFT_BT_PREDECT_STATUS_8822B) & \
BIT_MASK_BT_PREDECT_STATUS_8822B)
#define BIT_SET_BT_PREDECT_STATUS_8822B(x, v) \
(BIT_CLEAR_BT_PREDECT_STATUS_8822B(x) | BIT_BT_PREDECT_STATUS_8822B(v))
#define BIT_SHIFT_BT_CMD_INFO_8822B 0
#define BIT_MASK_BT_CMD_INFO_8822B 0xff
#define BIT_BT_CMD_INFO_8822B(x) \
(((x) & BIT_MASK_BT_CMD_INFO_8822B) << BIT_SHIFT_BT_CMD_INFO_8822B)
#define BITS_BT_CMD_INFO_8822B \
(BIT_MASK_BT_CMD_INFO_8822B << BIT_SHIFT_BT_CMD_INFO_8822B)
#define BIT_CLEAR_BT_CMD_INFO_8822B(x) ((x) & (~BITS_BT_CMD_INFO_8822B))
#define BIT_GET_BT_CMD_INFO_8822B(x) \
(((x) >> BIT_SHIFT_BT_CMD_INFO_8822B) & BIT_MASK_BT_CMD_INFO_8822B)
#define BIT_SET_BT_CMD_INFO_8822B(x, v) \
(BIT_CLEAR_BT_CMD_INFO_8822B(x) | BIT_BT_CMD_INFO_8822B(v))
/* 2 REG_BT_INTERRUPT_CONTROL_REGISTER_8822B */
#define BIT_EN_MAC_NULL_PKT_NOTIFY_8822B BIT(31)
#define BIT_EN_WLAN_RPT_AND_BT_QUERY_8822B BIT(30)
#define BIT_EN_BT_STSTUS_RPT_8822B BIT(29)
#define BIT_EN_BT_POWER_8822B BIT(28)
#define BIT_EN_BT_CHANNEL_8822B BIT(27)
#define BIT_EN_BT_SLOT_CHANGE_8822B BIT(26)
#define BIT_EN_BT_PROFILE_OR_HID_8822B BIT(25)
#define BIT_WLAN_RPT_NOTIFY_8822B BIT(24)
#define BIT_SHIFT_WLAN_RPT_DATA_8822B 16
#define BIT_MASK_WLAN_RPT_DATA_8822B 0xff
#define BIT_WLAN_RPT_DATA_8822B(x) \
(((x) & BIT_MASK_WLAN_RPT_DATA_8822B) << BIT_SHIFT_WLAN_RPT_DATA_8822B)
#define BITS_WLAN_RPT_DATA_8822B \
(BIT_MASK_WLAN_RPT_DATA_8822B << BIT_SHIFT_WLAN_RPT_DATA_8822B)
#define BIT_CLEAR_WLAN_RPT_DATA_8822B(x) ((x) & (~BITS_WLAN_RPT_DATA_8822B))
#define BIT_GET_WLAN_RPT_DATA_8822B(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_DATA_8822B) & BIT_MASK_WLAN_RPT_DATA_8822B)
#define BIT_SET_WLAN_RPT_DATA_8822B(x, v) \
(BIT_CLEAR_WLAN_RPT_DATA_8822B(x) | BIT_WLAN_RPT_DATA_8822B(v))
#define BIT_SHIFT_CMD_ID_8822B 8
#define BIT_MASK_CMD_ID_8822B 0xff
#define BIT_CMD_ID_8822B(x) \
(((x) & BIT_MASK_CMD_ID_8822B) << BIT_SHIFT_CMD_ID_8822B)
#define BITS_CMD_ID_8822B (BIT_MASK_CMD_ID_8822B << BIT_SHIFT_CMD_ID_8822B)
#define BIT_CLEAR_CMD_ID_8822B(x) ((x) & (~BITS_CMD_ID_8822B))
#define BIT_GET_CMD_ID_8822B(x) \
(((x) >> BIT_SHIFT_CMD_ID_8822B) & BIT_MASK_CMD_ID_8822B)
#define BIT_SET_CMD_ID_8822B(x, v) \
(BIT_CLEAR_CMD_ID_8822B(x) | BIT_CMD_ID_8822B(v))
#define BIT_SHIFT_BT_DATA_8822B 0
#define BIT_MASK_BT_DATA_8822B 0xff
#define BIT_BT_DATA_8822B(x) \
(((x) & BIT_MASK_BT_DATA_8822B) << BIT_SHIFT_BT_DATA_8822B)
#define BITS_BT_DATA_8822B (BIT_MASK_BT_DATA_8822B << BIT_SHIFT_BT_DATA_8822B)
#define BIT_CLEAR_BT_DATA_8822B(x) ((x) & (~BITS_BT_DATA_8822B))
#define BIT_GET_BT_DATA_8822B(x) \
(((x) >> BIT_SHIFT_BT_DATA_8822B) & BIT_MASK_BT_DATA_8822B)
#define BIT_SET_BT_DATA_8822B(x, v) \
(BIT_CLEAR_BT_DATA_8822B(x) | BIT_BT_DATA_8822B(v))
/* 2 REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8822B */
#define BIT_SHIFT_WLAN_RPT_TO_8822B 0
#define BIT_MASK_WLAN_RPT_TO_8822B 0xff
#define BIT_WLAN_RPT_TO_8822B(x) \
(((x) & BIT_MASK_WLAN_RPT_TO_8822B) << BIT_SHIFT_WLAN_RPT_TO_8822B)
#define BITS_WLAN_RPT_TO_8822B \
(BIT_MASK_WLAN_RPT_TO_8822B << BIT_SHIFT_WLAN_RPT_TO_8822B)
#define BIT_CLEAR_WLAN_RPT_TO_8822B(x) ((x) & (~BITS_WLAN_RPT_TO_8822B))
#define BIT_GET_WLAN_RPT_TO_8822B(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_TO_8822B) & BIT_MASK_WLAN_RPT_TO_8822B)
#define BIT_SET_WLAN_RPT_TO_8822B(x, v) \
(BIT_CLEAR_WLAN_RPT_TO_8822B(x) | BIT_WLAN_RPT_TO_8822B(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8822B */
#define BIT_SHIFT_ISOLATION_CHK_8822B 1
#define BIT_MASK_ISOLATION_CHK_8822B 0x7fffffffffffffffffffL
#define BIT_ISOLATION_CHK_8822B(x) \
(((x) & BIT_MASK_ISOLATION_CHK_8822B) << BIT_SHIFT_ISOLATION_CHK_8822B)
#define BITS_ISOLATION_CHK_8822B \
(BIT_MASK_ISOLATION_CHK_8822B << BIT_SHIFT_ISOLATION_CHK_8822B)
#define BIT_CLEAR_ISOLATION_CHK_8822B(x) ((x) & (~BITS_ISOLATION_CHK_8822B))
#define BIT_GET_ISOLATION_CHK_8822B(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_8822B) & BIT_MASK_ISOLATION_CHK_8822B)
#define BIT_SET_ISOLATION_CHK_8822B(x, v) \
(BIT_CLEAR_ISOLATION_CHK_8822B(x) | BIT_ISOLATION_CHK_8822B(v))
#define BIT_ISOLATION_EN_8822B BIT(0)
/* 2 REG_BT_INTERRUPT_STATUS_REGISTER_8822B */
#define BIT_BT_HID_ISR_8822B BIT(7)
#define BIT_BT_QUERY_ISR_8822B BIT(6)
#define BIT_MAC_NULL_PKT_NOTIFY_ISR_8822B BIT(5)
#define BIT_WLAN_RPT_ISR_8822B BIT(4)
#define BIT_BT_POWER_ISR_8822B BIT(3)
#define BIT_BT_CHANNEL_ISR_8822B BIT(2)
#define BIT_BT_SLOT_CHANGE_ISR_8822B BIT(1)
#define BIT_BT_PROFILE_ISR_8822B BIT(0)
/* 2 REG_BT_TDMA_TIME_REGISTER_8822B */
#define BIT_SHIFT_BT_TIME_8822B 6
#define BIT_MASK_BT_TIME_8822B 0x3ffffff
#define BIT_BT_TIME_8822B(x) \
(((x) & BIT_MASK_BT_TIME_8822B) << BIT_SHIFT_BT_TIME_8822B)
#define BITS_BT_TIME_8822B (BIT_MASK_BT_TIME_8822B << BIT_SHIFT_BT_TIME_8822B)
#define BIT_CLEAR_BT_TIME_8822B(x) ((x) & (~BITS_BT_TIME_8822B))
#define BIT_GET_BT_TIME_8822B(x) \
(((x) >> BIT_SHIFT_BT_TIME_8822B) & BIT_MASK_BT_TIME_8822B)
#define BIT_SET_BT_TIME_8822B(x, v) \
(BIT_CLEAR_BT_TIME_8822B(x) | BIT_BT_TIME_8822B(v))
#define BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822B 0
#define BIT_MASK_BT_RPT_SAMPLE_RATE_8822B 0x3f
#define BIT_BT_RPT_SAMPLE_RATE_8822B(x) \
(((x) & BIT_MASK_BT_RPT_SAMPLE_RATE_8822B) \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822B)
#define BITS_BT_RPT_SAMPLE_RATE_8822B \
(BIT_MASK_BT_RPT_SAMPLE_RATE_8822B \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822B)
#define BIT_CLEAR_BT_RPT_SAMPLE_RATE_8822B(x) \
((x) & (~BITS_BT_RPT_SAMPLE_RATE_8822B))
#define BIT_GET_BT_RPT_SAMPLE_RATE_8822B(x) \
(((x) >> BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822B) & \
BIT_MASK_BT_RPT_SAMPLE_RATE_8822B)
#define BIT_SET_BT_RPT_SAMPLE_RATE_8822B(x, v) \
(BIT_CLEAR_BT_RPT_SAMPLE_RATE_8822B(x) | \
BIT_BT_RPT_SAMPLE_RATE_8822B(v))
/* 2 REG_BT_ACT_REGISTER_8822B */
#define BIT_SHIFT_BT_EISR_EN_8822B 16
#define BIT_MASK_BT_EISR_EN_8822B 0xff
#define BIT_BT_EISR_EN_8822B(x) \
(((x) & BIT_MASK_BT_EISR_EN_8822B) << BIT_SHIFT_BT_EISR_EN_8822B)
#define BITS_BT_EISR_EN_8822B \
(BIT_MASK_BT_EISR_EN_8822B << BIT_SHIFT_BT_EISR_EN_8822B)
#define BIT_CLEAR_BT_EISR_EN_8822B(x) ((x) & (~BITS_BT_EISR_EN_8822B))
#define BIT_GET_BT_EISR_EN_8822B(x) \
(((x) >> BIT_SHIFT_BT_EISR_EN_8822B) & BIT_MASK_BT_EISR_EN_8822B)
#define BIT_SET_BT_EISR_EN_8822B(x, v) \
(BIT_CLEAR_BT_EISR_EN_8822B(x) | BIT_BT_EISR_EN_8822B(v))
#define BIT_BT_ACT_FALLING_ISR_8822B BIT(10)
#define BIT_BT_ACT_RISING_ISR_8822B BIT(9)
#define BIT_TDMA_TO_ISR_8822B BIT(8)
#define BIT_SHIFT_BT_CH_8822B 0
#define BIT_MASK_BT_CH_8822B 0xff
#define BIT_BT_CH_8822B(x) \
(((x) & BIT_MASK_BT_CH_8822B) << BIT_SHIFT_BT_CH_8822B)
#define BITS_BT_CH_8822B (BIT_MASK_BT_CH_8822B << BIT_SHIFT_BT_CH_8822B)
#define BIT_CLEAR_BT_CH_8822B(x) ((x) & (~BITS_BT_CH_8822B))
#define BIT_GET_BT_CH_8822B(x) \
(((x) >> BIT_SHIFT_BT_CH_8822B) & BIT_MASK_BT_CH_8822B)
#define BIT_SET_BT_CH_8822B(x, v) \
(BIT_CLEAR_BT_CH_8822B(x) | BIT_BT_CH_8822B(v))
/* 2 REG_OBFF_CTRL_BASIC_8822B */
#define BIT_OBFF_EN_V1_8822B BIT(31)
#define BIT_SHIFT_OBFF_STATE_V1_8822B 28
#define BIT_MASK_OBFF_STATE_V1_8822B 0x3
#define BIT_OBFF_STATE_V1_8822B(x) \
(((x) & BIT_MASK_OBFF_STATE_V1_8822B) << BIT_SHIFT_OBFF_STATE_V1_8822B)
#define BITS_OBFF_STATE_V1_8822B \
(BIT_MASK_OBFF_STATE_V1_8822B << BIT_SHIFT_OBFF_STATE_V1_8822B)
#define BIT_CLEAR_OBFF_STATE_V1_8822B(x) ((x) & (~BITS_OBFF_STATE_V1_8822B))
#define BIT_GET_OBFF_STATE_V1_8822B(x) \
(((x) >> BIT_SHIFT_OBFF_STATE_V1_8822B) & BIT_MASK_OBFF_STATE_V1_8822B)
#define BIT_SET_OBFF_STATE_V1_8822B(x, v) \
(BIT_CLEAR_OBFF_STATE_V1_8822B(x) | BIT_OBFF_STATE_V1_8822B(v))
#define BIT_OBFF_ACT_RXDMA_EN_8822B BIT(27)
#define BIT_OBFF_BLOCK_INT_EN_8822B BIT(26)
#define BIT_OBFF_AUTOACT_EN_8822B BIT(25)
#define BIT_OBFF_AUTOIDLE_EN_8822B BIT(24)
#define BIT_SHIFT_WAKE_MAX_PLS_8822B 20
#define BIT_MASK_WAKE_MAX_PLS_8822B 0x7
#define BIT_WAKE_MAX_PLS_8822B(x) \
(((x) & BIT_MASK_WAKE_MAX_PLS_8822B) << BIT_SHIFT_WAKE_MAX_PLS_8822B)
#define BITS_WAKE_MAX_PLS_8822B \
(BIT_MASK_WAKE_MAX_PLS_8822B << BIT_SHIFT_WAKE_MAX_PLS_8822B)
#define BIT_CLEAR_WAKE_MAX_PLS_8822B(x) ((x) & (~BITS_WAKE_MAX_PLS_8822B))
#define BIT_GET_WAKE_MAX_PLS_8822B(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_PLS_8822B) & BIT_MASK_WAKE_MAX_PLS_8822B)
#define BIT_SET_WAKE_MAX_PLS_8822B(x, v) \
(BIT_CLEAR_WAKE_MAX_PLS_8822B(x) | BIT_WAKE_MAX_PLS_8822B(v))
#define BIT_SHIFT_WAKE_MIN_PLS_8822B 16
#define BIT_MASK_WAKE_MIN_PLS_8822B 0x7
#define BIT_WAKE_MIN_PLS_8822B(x) \
(((x) & BIT_MASK_WAKE_MIN_PLS_8822B) << BIT_SHIFT_WAKE_MIN_PLS_8822B)
#define BITS_WAKE_MIN_PLS_8822B \
(BIT_MASK_WAKE_MIN_PLS_8822B << BIT_SHIFT_WAKE_MIN_PLS_8822B)
#define BIT_CLEAR_WAKE_MIN_PLS_8822B(x) ((x) & (~BITS_WAKE_MIN_PLS_8822B))
#define BIT_GET_WAKE_MIN_PLS_8822B(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_PLS_8822B) & BIT_MASK_WAKE_MIN_PLS_8822B)
#define BIT_SET_WAKE_MIN_PLS_8822B(x, v) \
(BIT_CLEAR_WAKE_MIN_PLS_8822B(x) | BIT_WAKE_MIN_PLS_8822B(v))
#define BIT_SHIFT_WAKE_MAX_F2F_8822B 12
#define BIT_MASK_WAKE_MAX_F2F_8822B 0x7
#define BIT_WAKE_MAX_F2F_8822B(x) \
(((x) & BIT_MASK_WAKE_MAX_F2F_8822B) << BIT_SHIFT_WAKE_MAX_F2F_8822B)
#define BITS_WAKE_MAX_F2F_8822B \
(BIT_MASK_WAKE_MAX_F2F_8822B << BIT_SHIFT_WAKE_MAX_F2F_8822B)
#define BIT_CLEAR_WAKE_MAX_F2F_8822B(x) ((x) & (~BITS_WAKE_MAX_F2F_8822B))
#define BIT_GET_WAKE_MAX_F2F_8822B(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_F2F_8822B) & BIT_MASK_WAKE_MAX_F2F_8822B)
#define BIT_SET_WAKE_MAX_F2F_8822B(x, v) \
(BIT_CLEAR_WAKE_MAX_F2F_8822B(x) | BIT_WAKE_MAX_F2F_8822B(v))
#define BIT_SHIFT_WAKE_MIN_F2F_8822B 8
#define BIT_MASK_WAKE_MIN_F2F_8822B 0x7
#define BIT_WAKE_MIN_F2F_8822B(x) \
(((x) & BIT_MASK_WAKE_MIN_F2F_8822B) << BIT_SHIFT_WAKE_MIN_F2F_8822B)
#define BITS_WAKE_MIN_F2F_8822B \
(BIT_MASK_WAKE_MIN_F2F_8822B << BIT_SHIFT_WAKE_MIN_F2F_8822B)
#define BIT_CLEAR_WAKE_MIN_F2F_8822B(x) ((x) & (~BITS_WAKE_MIN_F2F_8822B))
#define BIT_GET_WAKE_MIN_F2F_8822B(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_F2F_8822B) & BIT_MASK_WAKE_MIN_F2F_8822B)
#define BIT_SET_WAKE_MIN_F2F_8822B(x, v) \
(BIT_CLEAR_WAKE_MIN_F2F_8822B(x) | BIT_WAKE_MIN_F2F_8822B(v))
#define BIT_APP_CPU_ACT_V1_8822B BIT(3)
#define BIT_APP_OBFF_V1_8822B BIT(2)
#define BIT_APP_IDLE_V1_8822B BIT(1)
#define BIT_APP_INIT_V1_8822B BIT(0)
/* 2 REG_OBFF_CTRL2_TIMER_8822B */
#define BIT_SHIFT_RX_HIGH_TIMER_IDX_8822B 24
#define BIT_MASK_RX_HIGH_TIMER_IDX_8822B 0x7
#define BIT_RX_HIGH_TIMER_IDX_8822B(x) \
(((x) & BIT_MASK_RX_HIGH_TIMER_IDX_8822B) \
<< BIT_SHIFT_RX_HIGH_TIMER_IDX_8822B)
#define BITS_RX_HIGH_TIMER_IDX_8822B \
(BIT_MASK_RX_HIGH_TIMER_IDX_8822B << BIT_SHIFT_RX_HIGH_TIMER_IDX_8822B)
#define BIT_CLEAR_RX_HIGH_TIMER_IDX_8822B(x) \
((x) & (~BITS_RX_HIGH_TIMER_IDX_8822B))
#define BIT_GET_RX_HIGH_TIMER_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TIMER_IDX_8822B) & \
BIT_MASK_RX_HIGH_TIMER_IDX_8822B)
#define BIT_SET_RX_HIGH_TIMER_IDX_8822B(x, v) \
(BIT_CLEAR_RX_HIGH_TIMER_IDX_8822B(x) | BIT_RX_HIGH_TIMER_IDX_8822B(v))
#define BIT_SHIFT_RX_MED_TIMER_IDX_8822B 16
#define BIT_MASK_RX_MED_TIMER_IDX_8822B 0x7
#define BIT_RX_MED_TIMER_IDX_8822B(x) \
(((x) & BIT_MASK_RX_MED_TIMER_IDX_8822B) \
<< BIT_SHIFT_RX_MED_TIMER_IDX_8822B)
#define BITS_RX_MED_TIMER_IDX_8822B \
(BIT_MASK_RX_MED_TIMER_IDX_8822B << BIT_SHIFT_RX_MED_TIMER_IDX_8822B)
#define BIT_CLEAR_RX_MED_TIMER_IDX_8822B(x) \
((x) & (~BITS_RX_MED_TIMER_IDX_8822B))
#define BIT_GET_RX_MED_TIMER_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_MED_TIMER_IDX_8822B) & \
BIT_MASK_RX_MED_TIMER_IDX_8822B)
#define BIT_SET_RX_MED_TIMER_IDX_8822B(x, v) \
(BIT_CLEAR_RX_MED_TIMER_IDX_8822B(x) | BIT_RX_MED_TIMER_IDX_8822B(v))
#define BIT_SHIFT_RX_LOW_TIMER_IDX_8822B 8
#define BIT_MASK_RX_LOW_TIMER_IDX_8822B 0x7
#define BIT_RX_LOW_TIMER_IDX_8822B(x) \
(((x) & BIT_MASK_RX_LOW_TIMER_IDX_8822B) \
<< BIT_SHIFT_RX_LOW_TIMER_IDX_8822B)
#define BITS_RX_LOW_TIMER_IDX_8822B \
(BIT_MASK_RX_LOW_TIMER_IDX_8822B << BIT_SHIFT_RX_LOW_TIMER_IDX_8822B)
#define BIT_CLEAR_RX_LOW_TIMER_IDX_8822B(x) \
((x) & (~BITS_RX_LOW_TIMER_IDX_8822B))
#define BIT_GET_RX_LOW_TIMER_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_LOW_TIMER_IDX_8822B) & \
BIT_MASK_RX_LOW_TIMER_IDX_8822B)
#define BIT_SET_RX_LOW_TIMER_IDX_8822B(x, v) \
(BIT_CLEAR_RX_LOW_TIMER_IDX_8822B(x) | BIT_RX_LOW_TIMER_IDX_8822B(v))
#define BIT_SHIFT_OBFF_INT_TIMER_IDX_8822B 0
#define BIT_MASK_OBFF_INT_TIMER_IDX_8822B 0x7
#define BIT_OBFF_INT_TIMER_IDX_8822B(x) \
(((x) & BIT_MASK_OBFF_INT_TIMER_IDX_8822B) \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8822B)
#define BITS_OBFF_INT_TIMER_IDX_8822B \
(BIT_MASK_OBFF_INT_TIMER_IDX_8822B \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8822B)
#define BIT_CLEAR_OBFF_INT_TIMER_IDX_8822B(x) \
((x) & (~BITS_OBFF_INT_TIMER_IDX_8822B))
#define BIT_GET_OBFF_INT_TIMER_IDX_8822B(x) \
(((x) >> BIT_SHIFT_OBFF_INT_TIMER_IDX_8822B) & \
BIT_MASK_OBFF_INT_TIMER_IDX_8822B)
#define BIT_SET_OBFF_INT_TIMER_IDX_8822B(x, v) \
(BIT_CLEAR_OBFF_INT_TIMER_IDX_8822B(x) | \
BIT_OBFF_INT_TIMER_IDX_8822B(v))
/* 2 REG_LTR_CTRL_BASIC_8822B */
#define BIT_LTR_EN_V1_8822B BIT(31)
#define BIT_LTR_HW_EN_V1_8822B BIT(30)
#define BIT_LRT_ACT_CTS_EN_8822B BIT(29)
#define BIT_LTR_ACT_RXPKT_EN_8822B BIT(28)
#define BIT_LTR_ACT_RXDMA_EN_8822B BIT(27)
#define BIT_LTR_IDLE_NO_SNOOP_8822B BIT(26)
#define BIT_SPDUP_MGTPKT_8822B BIT(25)
#define BIT_RX_AGG_EN_8822B BIT(24)
#define BIT_APP_LTR_ACT_8822B BIT(23)
#define BIT_APP_LTR_IDLE_8822B BIT(22)
#define BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822B 20
#define BIT_MASK_HIGH_RATE_TRIG_SEL_8822B 0x3
#define BIT_HIGH_RATE_TRIG_SEL_8822B(x) \
(((x) & BIT_MASK_HIGH_RATE_TRIG_SEL_8822B) \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822B)
#define BITS_HIGH_RATE_TRIG_SEL_8822B \
(BIT_MASK_HIGH_RATE_TRIG_SEL_8822B \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822B)
#define BIT_CLEAR_HIGH_RATE_TRIG_SEL_8822B(x) \
((x) & (~BITS_HIGH_RATE_TRIG_SEL_8822B))
#define BIT_GET_HIGH_RATE_TRIG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822B) & \
BIT_MASK_HIGH_RATE_TRIG_SEL_8822B)
#define BIT_SET_HIGH_RATE_TRIG_SEL_8822B(x, v) \
(BIT_CLEAR_HIGH_RATE_TRIG_SEL_8822B(x) | \
BIT_HIGH_RATE_TRIG_SEL_8822B(v))
#define BIT_SHIFT_MED_RATE_TRIG_SEL_8822B 18
#define BIT_MASK_MED_RATE_TRIG_SEL_8822B 0x3
#define BIT_MED_RATE_TRIG_SEL_8822B(x) \
(((x) & BIT_MASK_MED_RATE_TRIG_SEL_8822B) \
<< BIT_SHIFT_MED_RATE_TRIG_SEL_8822B)
#define BITS_MED_RATE_TRIG_SEL_8822B \
(BIT_MASK_MED_RATE_TRIG_SEL_8822B << BIT_SHIFT_MED_RATE_TRIG_SEL_8822B)
#define BIT_CLEAR_MED_RATE_TRIG_SEL_8822B(x) \
((x) & (~BITS_MED_RATE_TRIG_SEL_8822B))
#define BIT_GET_MED_RATE_TRIG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_MED_RATE_TRIG_SEL_8822B) & \
BIT_MASK_MED_RATE_TRIG_SEL_8822B)
#define BIT_SET_MED_RATE_TRIG_SEL_8822B(x, v) \
(BIT_CLEAR_MED_RATE_TRIG_SEL_8822B(x) | BIT_MED_RATE_TRIG_SEL_8822B(v))
#define BIT_SHIFT_LOW_RATE_TRIG_SEL_8822B 16
#define BIT_MASK_LOW_RATE_TRIG_SEL_8822B 0x3
#define BIT_LOW_RATE_TRIG_SEL_8822B(x) \
(((x) & BIT_MASK_LOW_RATE_TRIG_SEL_8822B) \
<< BIT_SHIFT_LOW_RATE_TRIG_SEL_8822B)
#define BITS_LOW_RATE_TRIG_SEL_8822B \
(BIT_MASK_LOW_RATE_TRIG_SEL_8822B << BIT_SHIFT_LOW_RATE_TRIG_SEL_8822B)
#define BIT_CLEAR_LOW_RATE_TRIG_SEL_8822B(x) \
((x) & (~BITS_LOW_RATE_TRIG_SEL_8822B))
#define BIT_GET_LOW_RATE_TRIG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_LOW_RATE_TRIG_SEL_8822B) & \
BIT_MASK_LOW_RATE_TRIG_SEL_8822B)
#define BIT_SET_LOW_RATE_TRIG_SEL_8822B(x, v) \
(BIT_CLEAR_LOW_RATE_TRIG_SEL_8822B(x) | BIT_LOW_RATE_TRIG_SEL_8822B(v))
#define BIT_SHIFT_HIGH_RATE_BD_IDX_8822B 8
#define BIT_MASK_HIGH_RATE_BD_IDX_8822B 0x7f
#define BIT_HIGH_RATE_BD_IDX_8822B(x) \
(((x) & BIT_MASK_HIGH_RATE_BD_IDX_8822B) \
<< BIT_SHIFT_HIGH_RATE_BD_IDX_8822B)
#define BITS_HIGH_RATE_BD_IDX_8822B \
(BIT_MASK_HIGH_RATE_BD_IDX_8822B << BIT_SHIFT_HIGH_RATE_BD_IDX_8822B)
#define BIT_CLEAR_HIGH_RATE_BD_IDX_8822B(x) \
((x) & (~BITS_HIGH_RATE_BD_IDX_8822B))
#define BIT_GET_HIGH_RATE_BD_IDX_8822B(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_BD_IDX_8822B) & \
BIT_MASK_HIGH_RATE_BD_IDX_8822B)
#define BIT_SET_HIGH_RATE_BD_IDX_8822B(x, v) \
(BIT_CLEAR_HIGH_RATE_BD_IDX_8822B(x) | BIT_HIGH_RATE_BD_IDX_8822B(v))
#define BIT_SHIFT_LOW_RATE_BD_IDX_8822B 0
#define BIT_MASK_LOW_RATE_BD_IDX_8822B 0x7f
#define BIT_LOW_RATE_BD_IDX_8822B(x) \
(((x) & BIT_MASK_LOW_RATE_BD_IDX_8822B) \
<< BIT_SHIFT_LOW_RATE_BD_IDX_8822B)
#define BITS_LOW_RATE_BD_IDX_8822B \
(BIT_MASK_LOW_RATE_BD_IDX_8822B << BIT_SHIFT_LOW_RATE_BD_IDX_8822B)
#define BIT_CLEAR_LOW_RATE_BD_IDX_8822B(x) ((x) & (~BITS_LOW_RATE_BD_IDX_8822B))
#define BIT_GET_LOW_RATE_BD_IDX_8822B(x) \
(((x) >> BIT_SHIFT_LOW_RATE_BD_IDX_8822B) & \
BIT_MASK_LOW_RATE_BD_IDX_8822B)
#define BIT_SET_LOW_RATE_BD_IDX_8822B(x, v) \
(BIT_CLEAR_LOW_RATE_BD_IDX_8822B(x) | BIT_LOW_RATE_BD_IDX_8822B(v))
/* 2 REG_LTR_CTRL2_TIMER_THRESHOLD_8822B */
#define BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822B 24
#define BIT_MASK_RX_EMPTY_TIMER_IDX_8822B 0x7
#define BIT_RX_EMPTY_TIMER_IDX_8822B(x) \
(((x) & BIT_MASK_RX_EMPTY_TIMER_IDX_8822B) \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822B)
#define BITS_RX_EMPTY_TIMER_IDX_8822B \
(BIT_MASK_RX_EMPTY_TIMER_IDX_8822B \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822B)
#define BIT_CLEAR_RX_EMPTY_TIMER_IDX_8822B(x) \
((x) & (~BITS_RX_EMPTY_TIMER_IDX_8822B))
#define BIT_GET_RX_EMPTY_TIMER_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822B) & \
BIT_MASK_RX_EMPTY_TIMER_IDX_8822B)
#define BIT_SET_RX_EMPTY_TIMER_IDX_8822B(x, v) \
(BIT_CLEAR_RX_EMPTY_TIMER_IDX_8822B(x) | \
BIT_RX_EMPTY_TIMER_IDX_8822B(v))
#define BIT_SHIFT_RX_AFULL_TH_IDX_8822B 20
#define BIT_MASK_RX_AFULL_TH_IDX_8822B 0x7
#define BIT_RX_AFULL_TH_IDX_8822B(x) \
(((x) & BIT_MASK_RX_AFULL_TH_IDX_8822B) \
<< BIT_SHIFT_RX_AFULL_TH_IDX_8822B)
#define BITS_RX_AFULL_TH_IDX_8822B \
(BIT_MASK_RX_AFULL_TH_IDX_8822B << BIT_SHIFT_RX_AFULL_TH_IDX_8822B)
#define BIT_CLEAR_RX_AFULL_TH_IDX_8822B(x) ((x) & (~BITS_RX_AFULL_TH_IDX_8822B))
#define BIT_GET_RX_AFULL_TH_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_AFULL_TH_IDX_8822B) & \
BIT_MASK_RX_AFULL_TH_IDX_8822B)
#define BIT_SET_RX_AFULL_TH_IDX_8822B(x, v) \
(BIT_CLEAR_RX_AFULL_TH_IDX_8822B(x) | BIT_RX_AFULL_TH_IDX_8822B(v))
#define BIT_SHIFT_RX_HIGH_TH_IDX_8822B 16
#define BIT_MASK_RX_HIGH_TH_IDX_8822B 0x7
#define BIT_RX_HIGH_TH_IDX_8822B(x) \
(((x) & BIT_MASK_RX_HIGH_TH_IDX_8822B) \
<< BIT_SHIFT_RX_HIGH_TH_IDX_8822B)
#define BITS_RX_HIGH_TH_IDX_8822B \
(BIT_MASK_RX_HIGH_TH_IDX_8822B << BIT_SHIFT_RX_HIGH_TH_IDX_8822B)
#define BIT_CLEAR_RX_HIGH_TH_IDX_8822B(x) ((x) & (~BITS_RX_HIGH_TH_IDX_8822B))
#define BIT_GET_RX_HIGH_TH_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TH_IDX_8822B) & \
BIT_MASK_RX_HIGH_TH_IDX_8822B)
#define BIT_SET_RX_HIGH_TH_IDX_8822B(x, v) \
(BIT_CLEAR_RX_HIGH_TH_IDX_8822B(x) | BIT_RX_HIGH_TH_IDX_8822B(v))
#define BIT_SHIFT_RX_MED_TH_IDX_8822B 12
#define BIT_MASK_RX_MED_TH_IDX_8822B 0x7
#define BIT_RX_MED_TH_IDX_8822B(x) \
(((x) & BIT_MASK_RX_MED_TH_IDX_8822B) << BIT_SHIFT_RX_MED_TH_IDX_8822B)
#define BITS_RX_MED_TH_IDX_8822B \
(BIT_MASK_RX_MED_TH_IDX_8822B << BIT_SHIFT_RX_MED_TH_IDX_8822B)
#define BIT_CLEAR_RX_MED_TH_IDX_8822B(x) ((x) & (~BITS_RX_MED_TH_IDX_8822B))
#define BIT_GET_RX_MED_TH_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_MED_TH_IDX_8822B) & BIT_MASK_RX_MED_TH_IDX_8822B)
#define BIT_SET_RX_MED_TH_IDX_8822B(x, v) \
(BIT_CLEAR_RX_MED_TH_IDX_8822B(x) | BIT_RX_MED_TH_IDX_8822B(v))
#define BIT_SHIFT_RX_LOW_TH_IDX_8822B 8
#define BIT_MASK_RX_LOW_TH_IDX_8822B 0x7
#define BIT_RX_LOW_TH_IDX_8822B(x) \
(((x) & BIT_MASK_RX_LOW_TH_IDX_8822B) << BIT_SHIFT_RX_LOW_TH_IDX_8822B)
#define BITS_RX_LOW_TH_IDX_8822B \
(BIT_MASK_RX_LOW_TH_IDX_8822B << BIT_SHIFT_RX_LOW_TH_IDX_8822B)
#define BIT_CLEAR_RX_LOW_TH_IDX_8822B(x) ((x) & (~BITS_RX_LOW_TH_IDX_8822B))
#define BIT_GET_RX_LOW_TH_IDX_8822B(x) \
(((x) >> BIT_SHIFT_RX_LOW_TH_IDX_8822B) & BIT_MASK_RX_LOW_TH_IDX_8822B)
#define BIT_SET_RX_LOW_TH_IDX_8822B(x, v) \
(BIT_CLEAR_RX_LOW_TH_IDX_8822B(x) | BIT_RX_LOW_TH_IDX_8822B(v))
#define BIT_SHIFT_LTR_SPACE_IDX_8822B 4
#define BIT_MASK_LTR_SPACE_IDX_8822B 0x3
#define BIT_LTR_SPACE_IDX_8822B(x) \
(((x) & BIT_MASK_LTR_SPACE_IDX_8822B) << BIT_SHIFT_LTR_SPACE_IDX_8822B)
#define BITS_LTR_SPACE_IDX_8822B \
(BIT_MASK_LTR_SPACE_IDX_8822B << BIT_SHIFT_LTR_SPACE_IDX_8822B)
#define BIT_CLEAR_LTR_SPACE_IDX_8822B(x) ((x) & (~BITS_LTR_SPACE_IDX_8822B))
#define BIT_GET_LTR_SPACE_IDX_8822B(x) \
(((x) >> BIT_SHIFT_LTR_SPACE_IDX_8822B) & BIT_MASK_LTR_SPACE_IDX_8822B)
#define BIT_SET_LTR_SPACE_IDX_8822B(x, v) \
(BIT_CLEAR_LTR_SPACE_IDX_8822B(x) | BIT_LTR_SPACE_IDX_8822B(v))
#define BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822B 0
#define BIT_MASK_LTR_IDLE_TIMER_IDX_8822B 0x7
#define BIT_LTR_IDLE_TIMER_IDX_8822B(x) \
(((x) & BIT_MASK_LTR_IDLE_TIMER_IDX_8822B) \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822B)
#define BITS_LTR_IDLE_TIMER_IDX_8822B \
(BIT_MASK_LTR_IDLE_TIMER_IDX_8822B \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822B)
#define BIT_CLEAR_LTR_IDLE_TIMER_IDX_8822B(x) \
((x) & (~BITS_LTR_IDLE_TIMER_IDX_8822B))
#define BIT_GET_LTR_IDLE_TIMER_IDX_8822B(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822B) & \
BIT_MASK_LTR_IDLE_TIMER_IDX_8822B)
#define BIT_SET_LTR_IDLE_TIMER_IDX_8822B(x, v) \
(BIT_CLEAR_LTR_IDLE_TIMER_IDX_8822B(x) | \
BIT_LTR_IDLE_TIMER_IDX_8822B(v))
/* 2 REG_LTR_IDLE_LATENCY_V1_8822B */
#define BIT_SHIFT_LTR_IDLE_L_8822B 0
#define BIT_MASK_LTR_IDLE_L_8822B 0xffffffffL
#define BIT_LTR_IDLE_L_8822B(x) \
(((x) & BIT_MASK_LTR_IDLE_L_8822B) << BIT_SHIFT_LTR_IDLE_L_8822B)
#define BITS_LTR_IDLE_L_8822B \
(BIT_MASK_LTR_IDLE_L_8822B << BIT_SHIFT_LTR_IDLE_L_8822B)
#define BIT_CLEAR_LTR_IDLE_L_8822B(x) ((x) & (~BITS_LTR_IDLE_L_8822B))
#define BIT_GET_LTR_IDLE_L_8822B(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_L_8822B) & BIT_MASK_LTR_IDLE_L_8822B)
#define BIT_SET_LTR_IDLE_L_8822B(x, v) \
(BIT_CLEAR_LTR_IDLE_L_8822B(x) | BIT_LTR_IDLE_L_8822B(v))
/* 2 REG_LTR_ACTIVE_LATENCY_V1_8822B */
#define BIT_SHIFT_LTR_ACT_L_8822B 0
#define BIT_MASK_LTR_ACT_L_8822B 0xffffffffL
#define BIT_LTR_ACT_L_8822B(x) \
(((x) & BIT_MASK_LTR_ACT_L_8822B) << BIT_SHIFT_LTR_ACT_L_8822B)
#define BITS_LTR_ACT_L_8822B \
(BIT_MASK_LTR_ACT_L_8822B << BIT_SHIFT_LTR_ACT_L_8822B)
#define BIT_CLEAR_LTR_ACT_L_8822B(x) ((x) & (~BITS_LTR_ACT_L_8822B))
#define BIT_GET_LTR_ACT_L_8822B(x) \
(((x) >> BIT_SHIFT_LTR_ACT_L_8822B) & BIT_MASK_LTR_ACT_L_8822B)
#define BIT_SET_LTR_ACT_L_8822B(x, v) \
(BIT_CLEAR_LTR_ACT_L_8822B(x) | BIT_LTR_ACT_L_8822B(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_8822B */
#define BIT_APPEND_MACID_IN_RESP_EN_8822B BIT(50)
#define BIT_ADDR2_MATCH_EN_8822B BIT(49)
#define BIT_ANTTRN_EN_8822B BIT(48)
#define BIT_SHIFT_TRAIN_STA_ADDR_8822B 0
#define BIT_MASK_TRAIN_STA_ADDR_8822B 0xffffffffffffL
#define BIT_TRAIN_STA_ADDR_8822B(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_8822B) \
<< BIT_SHIFT_TRAIN_STA_ADDR_8822B)
#define BITS_TRAIN_STA_ADDR_8822B \
(BIT_MASK_TRAIN_STA_ADDR_8822B << BIT_SHIFT_TRAIN_STA_ADDR_8822B)
#define BIT_CLEAR_TRAIN_STA_ADDR_8822B(x) ((x) & (~BITS_TRAIN_STA_ADDR_8822B))
#define BIT_GET_TRAIN_STA_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_8822B) & \
BIT_MASK_TRAIN_STA_ADDR_8822B)
#define BIT_SET_TRAIN_STA_ADDR_8822B(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_8822B(x) | BIT_TRAIN_STA_ADDR_8822B(v))
/* 2 REG_RSVD_0X7B4_8822B */
/* 2 REG_WMAC_PKTCNT_RWD_8822B */
#define BIT_SHIFT_PKTCNT_BSSIDMAP_8822B 4
#define BIT_MASK_PKTCNT_BSSIDMAP_8822B 0xf
#define BIT_PKTCNT_BSSIDMAP_8822B(x) \
(((x) & BIT_MASK_PKTCNT_BSSIDMAP_8822B) \
<< BIT_SHIFT_PKTCNT_BSSIDMAP_8822B)
#define BITS_PKTCNT_BSSIDMAP_8822B \
(BIT_MASK_PKTCNT_BSSIDMAP_8822B << BIT_SHIFT_PKTCNT_BSSIDMAP_8822B)
#define BIT_CLEAR_PKTCNT_BSSIDMAP_8822B(x) ((x) & (~BITS_PKTCNT_BSSIDMAP_8822B))
#define BIT_GET_PKTCNT_BSSIDMAP_8822B(x) \
(((x) >> BIT_SHIFT_PKTCNT_BSSIDMAP_8822B) & \
BIT_MASK_PKTCNT_BSSIDMAP_8822B)
#define BIT_SET_PKTCNT_BSSIDMAP_8822B(x, v) \
(BIT_CLEAR_PKTCNT_BSSIDMAP_8822B(x) | BIT_PKTCNT_BSSIDMAP_8822B(v))
#define BIT_PKTCNT_CNTRST_8822B BIT(1)
#define BIT_PKTCNT_CNTEN_8822B BIT(0)
/* 2 REG_WMAC_PKTCNT_CTRL_8822B */
#define BIT_WMAC_PKTCNT_TRST_8822B BIT(9)
#define BIT_WMAC_PKTCNT_FEN_8822B BIT(8)
#define BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822B 0
#define BIT_MASK_WMAC_PKTCNT_CFGAD_8822B 0xff
#define BIT_WMAC_PKTCNT_CFGAD_8822B(x) \
(((x) & BIT_MASK_WMAC_PKTCNT_CFGAD_8822B) \
<< BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822B)
#define BITS_WMAC_PKTCNT_CFGAD_8822B \
(BIT_MASK_WMAC_PKTCNT_CFGAD_8822B << BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822B)
#define BIT_CLEAR_WMAC_PKTCNT_CFGAD_8822B(x) \
((x) & (~BITS_WMAC_PKTCNT_CFGAD_8822B))
#define BIT_GET_WMAC_PKTCNT_CFGAD_8822B(x) \
(((x) >> BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822B) & \
BIT_MASK_WMAC_PKTCNT_CFGAD_8822B)
#define BIT_SET_WMAC_PKTCNT_CFGAD_8822B(x, v) \
(BIT_CLEAR_WMAC_PKTCNT_CFGAD_8822B(x) | BIT_WMAC_PKTCNT_CFGAD_8822B(v))
/* 2 REG_IQ_DUMP_8822B */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8822B (64 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_MATCH_REF_MAC_8822B 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC_8822B(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC_8822B) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8822B)
#define BITS_R_WMAC_MATCH_REF_MAC_8822B \
(BIT_MASK_R_WMAC_MATCH_REF_MAC_8822B \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8822B)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC_8822B(x) \
((x) & (~BITS_R_WMAC_MATCH_REF_MAC_8822B))
#define BIT_GET_R_WMAC_MATCH_REF_MAC_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC_8822B) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC_8822B)
#define BIT_SET_R_WMAC_MATCH_REF_MAC_8822B(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC_8822B(x) | \
BIT_R_WMAC_MATCH_REF_MAC_8822B(v))
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_MASK_LA_MAC_8822B 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC_8822B(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC_8822B) \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_8822B)
#define BITS_R_WMAC_MASK_LA_MAC_8822B \
(BIT_MASK_R_WMAC_MASK_LA_MAC_8822B \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_8822B)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC_8822B(x) \
((x) & (~BITS_R_WMAC_MASK_LA_MAC_8822B))
#define BIT_GET_R_WMAC_MASK_LA_MAC_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC_8822B) & \
BIT_MASK_R_WMAC_MASK_LA_MAC_8822B)
#define BIT_SET_R_WMAC_MASK_LA_MAC_8822B(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC_8822B(x) | \
BIT_R_WMAC_MASK_LA_MAC_8822B(v))
#define BIT_SHIFT_DUMP_OK_ADDR_8822B 16
#define BIT_MASK_DUMP_OK_ADDR_8822B 0xffff
#define BIT_DUMP_OK_ADDR_8822B(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR_8822B) << BIT_SHIFT_DUMP_OK_ADDR_8822B)
#define BITS_DUMP_OK_ADDR_8822B \
(BIT_MASK_DUMP_OK_ADDR_8822B << BIT_SHIFT_DUMP_OK_ADDR_8822B)
#define BIT_CLEAR_DUMP_OK_ADDR_8822B(x) ((x) & (~BITS_DUMP_OK_ADDR_8822B))
#define BIT_GET_DUMP_OK_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR_8822B) & BIT_MASK_DUMP_OK_ADDR_8822B)
#define BIT_SET_DUMP_OK_ADDR_8822B(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR_8822B(x) | BIT_DUMP_OK_ADDR_8822B(v))
#define BIT_SHIFT_R_TRIG_TIME_SEL_8822B 8
#define BIT_MASK_R_TRIG_TIME_SEL_8822B 0x7f
#define BIT_R_TRIG_TIME_SEL_8822B(x) \
(((x) & BIT_MASK_R_TRIG_TIME_SEL_8822B) \
<< BIT_SHIFT_R_TRIG_TIME_SEL_8822B)
#define BITS_R_TRIG_TIME_SEL_8822B \
(BIT_MASK_R_TRIG_TIME_SEL_8822B << BIT_SHIFT_R_TRIG_TIME_SEL_8822B)
#define BIT_CLEAR_R_TRIG_TIME_SEL_8822B(x) ((x) & (~BITS_R_TRIG_TIME_SEL_8822B))
#define BIT_GET_R_TRIG_TIME_SEL_8822B(x) \
(((x) >> BIT_SHIFT_R_TRIG_TIME_SEL_8822B) & \
BIT_MASK_R_TRIG_TIME_SEL_8822B)
#define BIT_SET_R_TRIG_TIME_SEL_8822B(x, v) \
(BIT_CLEAR_R_TRIG_TIME_SEL_8822B(x) | BIT_R_TRIG_TIME_SEL_8822B(v))
#define BIT_SHIFT_R_MAC_TRIG_SEL_8822B 6
#define BIT_MASK_R_MAC_TRIG_SEL_8822B 0x3
#define BIT_R_MAC_TRIG_SEL_8822B(x) \
(((x) & BIT_MASK_R_MAC_TRIG_SEL_8822B) \
<< BIT_SHIFT_R_MAC_TRIG_SEL_8822B)
#define BITS_R_MAC_TRIG_SEL_8822B \
(BIT_MASK_R_MAC_TRIG_SEL_8822B << BIT_SHIFT_R_MAC_TRIG_SEL_8822B)
#define BIT_CLEAR_R_MAC_TRIG_SEL_8822B(x) ((x) & (~BITS_R_MAC_TRIG_SEL_8822B))
#define BIT_GET_R_MAC_TRIG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_R_MAC_TRIG_SEL_8822B) & \
BIT_MASK_R_MAC_TRIG_SEL_8822B)
#define BIT_SET_R_MAC_TRIG_SEL_8822B(x, v) \
(BIT_CLEAR_R_MAC_TRIG_SEL_8822B(x) | BIT_R_MAC_TRIG_SEL_8822B(v))
#define BIT_MAC_TRIG_REG_8822B BIT(5)
#define BIT_SHIFT_R_LEVEL_PULSE_SEL_8822B 3
#define BIT_MASK_R_LEVEL_PULSE_SEL_8822B 0x3
#define BIT_R_LEVEL_PULSE_SEL_8822B(x) \
(((x) & BIT_MASK_R_LEVEL_PULSE_SEL_8822B) \
<< BIT_SHIFT_R_LEVEL_PULSE_SEL_8822B)
#define BITS_R_LEVEL_PULSE_SEL_8822B \
(BIT_MASK_R_LEVEL_PULSE_SEL_8822B << BIT_SHIFT_R_LEVEL_PULSE_SEL_8822B)
#define BIT_CLEAR_R_LEVEL_PULSE_SEL_8822B(x) \
((x) & (~BITS_R_LEVEL_PULSE_SEL_8822B))
#define BIT_GET_R_LEVEL_PULSE_SEL_8822B(x) \
(((x) >> BIT_SHIFT_R_LEVEL_PULSE_SEL_8822B) & \
BIT_MASK_R_LEVEL_PULSE_SEL_8822B)
#define BIT_SET_R_LEVEL_PULSE_SEL_8822B(x, v) \
(BIT_CLEAR_R_LEVEL_PULSE_SEL_8822B(x) | BIT_R_LEVEL_PULSE_SEL_8822B(v))
#define BIT_EN_LA_MAC_8822B BIT(2)
#define BIT_R_EN_IQDUMP_8822B BIT(1)
#define BIT_R_IQDATA_DUMP_8822B BIT(0)
/* 2 REG_WMAC_FTM_CTL_8822B */
#define BIT_RXFTM_TXACK_SC_8822B BIT(6)
#define BIT_RXFTM_TXACK_BW_8822B BIT(5)
#define BIT_RXFTM_EN_8822B BIT(3)
#define BIT_RXFTMREQ_BYDRV_8822B BIT(2)
#define BIT_RXFTMREQ_EN_8822B BIT(1)
#define BIT_FTM_EN_8822B BIT(0)
/* 2 REG_WMAC_IQ_MDPK_FUNC_8822B */
/* 2 REG_WMAC_OPTION_FUNCTION_8822B */
#define BIT_SHIFT_R_WMAC_RX_FIL_LEN_8822B (64 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_RX_FIL_LEN_8822B 0xffff
#define BIT_R_WMAC_RX_FIL_LEN_8822B(x) \
(((x) & BIT_MASK_R_WMAC_RX_FIL_LEN_8822B) \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_8822B)
#define BITS_R_WMAC_RX_FIL_LEN_8822B \
(BIT_MASK_R_WMAC_RX_FIL_LEN_8822B << BIT_SHIFT_R_WMAC_RX_FIL_LEN_8822B)
#define BIT_CLEAR_R_WMAC_RX_FIL_LEN_8822B(x) \
((x) & (~BITS_R_WMAC_RX_FIL_LEN_8822B))
#define BIT_GET_R_WMAC_RX_FIL_LEN_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RX_FIL_LEN_8822B) & \
BIT_MASK_R_WMAC_RX_FIL_LEN_8822B)
#define BIT_SET_R_WMAC_RX_FIL_LEN_8822B(x, v) \
(BIT_CLEAR_R_WMAC_RX_FIL_LEN_8822B(x) | BIT_R_WMAC_RX_FIL_LEN_8822B(v))
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8822B (56 & CPU_OPT_WIDTH)
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8822B 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH_8822B(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8822B) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8822B)
#define BITS_R_WMAC_RXFIFO_FULL_TH_8822B \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8822B \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8822B)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_8822B(x) \
((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH_8822B))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_8822B) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH_8822B)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH_8822B(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_8822B(x) | \
BIT_R_WMAC_RXFIFO_FULL_TH_8822B(v))
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC_8822B BIT(55)
#define BIT_R_WMAC_RXRST_DLY_8822B BIT(54)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP_8822B BIT(53)
#define BIT_R_WMAC_SRCH_TXRPT_UA1_8822B BIT(52)
#define BIT_R_WMAC_SRCH_TXRPT_TYPE_8822B BIT(51)
#define BIT_R_WMAC_NDP_RST_8822B BIT(50)
#define BIT_R_WMAC_POWINT_EN_8822B BIT(49)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT_8822B BIT(48)
#define BIT_R_WMAC_SRCH_TXRPT_MID_8822B BIT(47)
#define BIT_R_WMAC_PFIN_TOEN_8822B BIT(46)
#define BIT_R_WMAC_FIL_SECERR_8822B BIT(45)
#define BIT_R_WMAC_FIL_CTLPKTLEN_8822B BIT(44)
#define BIT_R_WMAC_FIL_FCTYPE_8822B BIT(43)
#define BIT_R_WMAC_FIL_FCPROVER_8822B BIT(42)
#define BIT_R_WMAC_PHYSTS_SNIF_8822B BIT(41)
#define BIT_R_WMAC_PHYSTS_PLCP_8822B BIT(40)
#define BIT_R_MAC_TCR_VBONF_RD_8822B BIT(39)
#define BIT_R_WMAC_TCR_MPAR_NDP_8822B BIT(38)
#define BIT_R_WMAC_NDP_FILTER_8822B BIT(37)
#define BIT_R_WMAC_RXLEN_SEL_8822B BIT(36)
#define BIT_R_WMAC_RXLEN_SEL1_8822B BIT(35)
#define BIT_R_OFDM_FILTER_8822B BIT(34)
#define BIT_R_WMAC_CHK_OFDM_LEN_8822B BIT(33)
#define BIT_R_WMAC_CHK_CCK_LEN_8822B BIT(32)
#define BIT_SHIFT_R_OFDM_LEN_8822B 26
#define BIT_MASK_R_OFDM_LEN_8822B 0x3f
#define BIT_R_OFDM_LEN_8822B(x) \
(((x) & BIT_MASK_R_OFDM_LEN_8822B) << BIT_SHIFT_R_OFDM_LEN_8822B)
#define BITS_R_OFDM_LEN_8822B \
(BIT_MASK_R_OFDM_LEN_8822B << BIT_SHIFT_R_OFDM_LEN_8822B)
#define BIT_CLEAR_R_OFDM_LEN_8822B(x) ((x) & (~BITS_R_OFDM_LEN_8822B))
#define BIT_GET_R_OFDM_LEN_8822B(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN_8822B) & BIT_MASK_R_OFDM_LEN_8822B)
#define BIT_SET_R_OFDM_LEN_8822B(x, v) \
(BIT_CLEAR_R_OFDM_LEN_8822B(x) | BIT_R_OFDM_LEN_8822B(v))
#define BIT_SHIFT_R_CCK_LEN_8822B 0
#define BIT_MASK_R_CCK_LEN_8822B 0xffff
#define BIT_R_CCK_LEN_8822B(x) \
(((x) & BIT_MASK_R_CCK_LEN_8822B) << BIT_SHIFT_R_CCK_LEN_8822B)
#define BITS_R_CCK_LEN_8822B \
(BIT_MASK_R_CCK_LEN_8822B << BIT_SHIFT_R_CCK_LEN_8822B)
#define BIT_CLEAR_R_CCK_LEN_8822B(x) ((x) & (~BITS_R_CCK_LEN_8822B))
#define BIT_GET_R_CCK_LEN_8822B(x) \
(((x) >> BIT_SHIFT_R_CCK_LEN_8822B) & BIT_MASK_R_CCK_LEN_8822B)
#define BIT_SET_R_CCK_LEN_8822B(x, v) \
(BIT_CLEAR_R_CCK_LEN_8822B(x) | BIT_R_CCK_LEN_8822B(v))
/* 2 REG_RX_FILTER_FUNCTION_8822B */
#define BIT_R_WMAC_MHRDDY_LATCH_8822B BIT(14)
#define BIT_R_WMAC_MHRDDY_CLR_8822B BIT(13)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY1_8822B BIT(12)
#define BIT_WMAC_DIS_VHT_PLCP_CHK_MU_8822B BIT(11)
#define BIT_R_CHK_DELIMIT_LEN_8822B BIT(10)
#define BIT_R_REAPTER_ADDR_MATCH_8822B BIT(9)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY_8822B BIT(8)
#define BIT_R_LATCH_MACHRDY_8822B BIT(7)
#define BIT_R_WMAC_RXFIL_REND_8822B BIT(6)
#define BIT_R_WMAC_MPDURDY_CLR_8822B BIT(5)
#define BIT_R_WMAC_CLRRXSEC_8822B BIT(4)
#define BIT_R_WMAC_RXFIL_RDEL_8822B BIT(3)
#define BIT_R_WMAC_RXFIL_FCSE_8822B BIT(2)
#define BIT_R_WMAC_RXFIL_MESH_DEL_8822B BIT(1)
#define BIT_R_WMAC_RXFIL_MASKM_8822B BIT(0)
/* 2 REG_NDP_SIG_8822B */
#define BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822B 0
#define BIT_MASK_R_WMAC_TXNDP_SIGB_8822B 0x1fffff
#define BIT_R_WMAC_TXNDP_SIGB_8822B(x) \
(((x) & BIT_MASK_R_WMAC_TXNDP_SIGB_8822B) \
<< BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822B)
#define BITS_R_WMAC_TXNDP_SIGB_8822B \
(BIT_MASK_R_WMAC_TXNDP_SIGB_8822B << BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822B)
#define BIT_CLEAR_R_WMAC_TXNDP_SIGB_8822B(x) \
((x) & (~BITS_R_WMAC_TXNDP_SIGB_8822B))
#define BIT_GET_R_WMAC_TXNDP_SIGB_8822B(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822B) & \
BIT_MASK_R_WMAC_TXNDP_SIGB_8822B)
#define BIT_SET_R_WMAC_TXNDP_SIGB_8822B(x, v) \
(BIT_CLEAR_R_WMAC_TXNDP_SIGB_8822B(x) | BIT_R_WMAC_TXNDP_SIGB_8822B(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_8822B */
#define BIT_SHIFT_R_MAC_DEBUG_8822B (32 & CPU_OPT_WIDTH)
#define BIT_MASK_R_MAC_DEBUG_8822B 0xffffffffL
#define BIT_R_MAC_DEBUG_8822B(x) \
(((x) & BIT_MASK_R_MAC_DEBUG_8822B) << BIT_SHIFT_R_MAC_DEBUG_8822B)
#define BITS_R_MAC_DEBUG_8822B \
(BIT_MASK_R_MAC_DEBUG_8822B << BIT_SHIFT_R_MAC_DEBUG_8822B)
#define BIT_CLEAR_R_MAC_DEBUG_8822B(x) ((x) & (~BITS_R_MAC_DEBUG_8822B))
#define BIT_GET_R_MAC_DEBUG_8822B(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG_8822B) & BIT_MASK_R_MAC_DEBUG_8822B)
#define BIT_SET_R_MAC_DEBUG_8822B(x, v) \
(BIT_CLEAR_R_MAC_DEBUG_8822B(x) | BIT_R_MAC_DEBUG_8822B(v))
#define BIT_SHIFT_R_MAC_DBG_SHIFT_8822B 8
#define BIT_MASK_R_MAC_DBG_SHIFT_8822B 0x7
#define BIT_R_MAC_DBG_SHIFT_8822B(x) \
(((x) & BIT_MASK_R_MAC_DBG_SHIFT_8822B) \
<< BIT_SHIFT_R_MAC_DBG_SHIFT_8822B)
#define BITS_R_MAC_DBG_SHIFT_8822B \
(BIT_MASK_R_MAC_DBG_SHIFT_8822B << BIT_SHIFT_R_MAC_DBG_SHIFT_8822B)
#define BIT_CLEAR_R_MAC_DBG_SHIFT_8822B(x) ((x) & (~BITS_R_MAC_DBG_SHIFT_8822B))
#define BIT_GET_R_MAC_DBG_SHIFT_8822B(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SHIFT_8822B) & \
BIT_MASK_R_MAC_DBG_SHIFT_8822B)
#define BIT_SET_R_MAC_DBG_SHIFT_8822B(x, v) \
(BIT_CLEAR_R_MAC_DBG_SHIFT_8822B(x) | BIT_R_MAC_DBG_SHIFT_8822B(v))
#define BIT_SHIFT_R_MAC_DBG_SEL_8822B 0
#define BIT_MASK_R_MAC_DBG_SEL_8822B 0x3
#define BIT_R_MAC_DBG_SEL_8822B(x) \
(((x) & BIT_MASK_R_MAC_DBG_SEL_8822B) << BIT_SHIFT_R_MAC_DBG_SEL_8822B)
#define BITS_R_MAC_DBG_SEL_8822B \
(BIT_MASK_R_MAC_DBG_SEL_8822B << BIT_SHIFT_R_MAC_DBG_SEL_8822B)
#define BIT_CLEAR_R_MAC_DBG_SEL_8822B(x) ((x) & (~BITS_R_MAC_DBG_SEL_8822B))
#define BIT_GET_R_MAC_DBG_SEL_8822B(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SEL_8822B) & BIT_MASK_R_MAC_DBG_SEL_8822B)
#define BIT_SET_R_MAC_DBG_SEL_8822B(x, v) \
(BIT_CLEAR_R_MAC_DBG_SEL_8822B(x) | BIT_R_MAC_DBG_SEL_8822B(v))
/* 2 REG_RTS_ADDRESS_0_8822B */
/* 2 REG_RTS_ADDRESS_1_8822B */
/* 2 REG_RPFM_MAP1_8822B */
#define BIT_DATA_RPFM15EN_8822B BIT(15)
#define BIT_DATA_RPFM14EN_8822B BIT(14)
#define BIT_DATA_RPFM13EN_8822B BIT(13)
#define BIT_DATA_RPFM12EN_8822B BIT(12)
#define BIT_DATA_RPFM11EN_8822B BIT(11)
#define BIT_DATA_RPFM10EN_8822B BIT(10)
#define BIT_DATA_RPFM9EN_8822B BIT(9)
#define BIT_DATA_RPFM8EN_8822B BIT(8)
#define BIT_DATA_RPFM7EN_8822B BIT(7)
#define BIT_DATA_RPFM6EN_8822B BIT(6)
#define BIT_DATA_RPFM5EN_8822B BIT(5)
#define BIT_DATA_RPFM4EN_8822B BIT(4)
#define BIT_DATA_RPFM3EN_8822B BIT(3)
#define BIT_DATA_RPFM2EN_8822B BIT(2)
#define BIT_DATA_RPFM1EN_8822B BIT(1)
#define BIT_DATA_RPFM0EN_8822B BIT(0)
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8822B */
#define BIT_LTECOEX_ACCESS_START_V1_8822B BIT(31)
#define BIT_LTECOEX_WRITE_MODE_V1_8822B BIT(30)
#define BIT_LTECOEX_READY_BIT_V1_8822B BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN_V1_8822B 16
#define BIT_MASK_WRITE_BYTE_EN_V1_8822B 0xf
#define BIT_WRITE_BYTE_EN_V1_8822B(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN_V1_8822B) \
<< BIT_SHIFT_WRITE_BYTE_EN_V1_8822B)
#define BITS_WRITE_BYTE_EN_V1_8822B \
(BIT_MASK_WRITE_BYTE_EN_V1_8822B << BIT_SHIFT_WRITE_BYTE_EN_V1_8822B)
#define BIT_CLEAR_WRITE_BYTE_EN_V1_8822B(x) \
((x) & (~BITS_WRITE_BYTE_EN_V1_8822B))
#define BIT_GET_WRITE_BYTE_EN_V1_8822B(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN_V1_8822B) & \
BIT_MASK_WRITE_BYTE_EN_V1_8822B)
#define BIT_SET_WRITE_BYTE_EN_V1_8822B(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN_V1_8822B(x) | BIT_WRITE_BYTE_EN_V1_8822B(v))
#define BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822B 0
#define BIT_MASK_LTECOEX_REG_ADDR_V1_8822B 0xffff
#define BIT_LTECOEX_REG_ADDR_V1_8822B(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR_V1_8822B) \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822B)
#define BITS_LTECOEX_REG_ADDR_V1_8822B \
(BIT_MASK_LTECOEX_REG_ADDR_V1_8822B \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822B)
#define BIT_CLEAR_LTECOEX_REG_ADDR_V1_8822B(x) \
((x) & (~BITS_LTECOEX_REG_ADDR_V1_8822B))
#define BIT_GET_LTECOEX_REG_ADDR_V1_8822B(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822B) & \
BIT_MASK_LTECOEX_REG_ADDR_V1_8822B)
#define BIT_SET_LTECOEX_REG_ADDR_V1_8822B(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR_V1_8822B(x) | \
BIT_LTECOEX_REG_ADDR_V1_8822B(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8822B */
#define BIT_SHIFT_LTECOEX_W_DATA_V1_8822B 0
#define BIT_MASK_LTECOEX_W_DATA_V1_8822B 0xffffffffL
#define BIT_LTECOEX_W_DATA_V1_8822B(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA_V1_8822B) \
<< BIT_SHIFT_LTECOEX_W_DATA_V1_8822B)
#define BITS_LTECOEX_W_DATA_V1_8822B \
(BIT_MASK_LTECOEX_W_DATA_V1_8822B << BIT_SHIFT_LTECOEX_W_DATA_V1_8822B)
#define BIT_CLEAR_LTECOEX_W_DATA_V1_8822B(x) \
((x) & (~BITS_LTECOEX_W_DATA_V1_8822B))
#define BIT_GET_LTECOEX_W_DATA_V1_8822B(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA_V1_8822B) & \
BIT_MASK_LTECOEX_W_DATA_V1_8822B)
#define BIT_SET_LTECOEX_W_DATA_V1_8822B(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA_V1_8822B(x) | BIT_LTECOEX_W_DATA_V1_8822B(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8822B */
#define BIT_SHIFT_LTECOEX_R_DATA_V1_8822B 0
#define BIT_MASK_LTECOEX_R_DATA_V1_8822B 0xffffffffL
#define BIT_LTECOEX_R_DATA_V1_8822B(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA_V1_8822B) \
<< BIT_SHIFT_LTECOEX_R_DATA_V1_8822B)
#define BITS_LTECOEX_R_DATA_V1_8822B \
(BIT_MASK_LTECOEX_R_DATA_V1_8822B << BIT_SHIFT_LTECOEX_R_DATA_V1_8822B)
#define BIT_CLEAR_LTECOEX_R_DATA_V1_8822B(x) \
((x) & (~BITS_LTECOEX_R_DATA_V1_8822B))
#define BIT_GET_LTECOEX_R_DATA_V1_8822B(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA_V1_8822B) & \
BIT_MASK_LTECOEX_R_DATA_V1_8822B)
#define BIT_SET_LTECOEX_R_DATA_V1_8822B(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA_V1_8822B(x) | BIT_LTECOEX_R_DATA_V1_8822B(v))
/* 2 REG_NOT_VALID_8822B */
/* 2 REG_SDIO_TX_CTRL_8822B */
#define BIT_SHIFT_SDIO_INT_TIMEOUT_8822B 16
#define BIT_MASK_SDIO_INT_TIMEOUT_8822B 0xffff
#define BIT_SDIO_INT_TIMEOUT_8822B(x) \
(((x) & BIT_MASK_SDIO_INT_TIMEOUT_8822B) \
<< BIT_SHIFT_SDIO_INT_TIMEOUT_8822B)
#define BITS_SDIO_INT_TIMEOUT_8822B \
(BIT_MASK_SDIO_INT_TIMEOUT_8822B << BIT_SHIFT_SDIO_INT_TIMEOUT_8822B)
#define BIT_CLEAR_SDIO_INT_TIMEOUT_8822B(x) \
((x) & (~BITS_SDIO_INT_TIMEOUT_8822B))
#define BIT_GET_SDIO_INT_TIMEOUT_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_INT_TIMEOUT_8822B) & \
BIT_MASK_SDIO_INT_TIMEOUT_8822B)
#define BIT_SET_SDIO_INT_TIMEOUT_8822B(x, v) \
(BIT_CLEAR_SDIO_INT_TIMEOUT_8822B(x) | BIT_SDIO_INT_TIMEOUT_8822B(v))
#define BIT_IO_ERR_STATUS_8822B BIT(15)
#define BIT_REPLY_ERRCRC_IN_DATA_8822B BIT(9)
#define BIT_EN_CMD53_OVERLAP_8822B BIT(8)
#define BIT_REPLY_ERR_IN_R5_8822B BIT(7)
#define BIT_R18A_EN_8822B BIT(6)
#define BIT_SDIO_CMD_FORCE_VLD_8822B BIT(5)
#define BIT_INIT_CMD_EN_8822B BIT(4)
#define BIT_EN_RXDMA_MASK_INT_8822B BIT(2)
#define BIT_EN_MASK_TIMER_8822B BIT(1)
#define BIT_CMD_ERR_STOP_INT_EN_8822B BIT(0)
/* 2 REG_SDIO_HIMR_8822B */
#define BIT_SDIO_CRCERR_MSK_8822B BIT(31)
#define BIT_SDIO_HSISR3_IND_MSK_8822B BIT(30)
#define BIT_SDIO_HSISR2_IND_MSK_8822B BIT(29)
#define BIT_SDIO_HEISR_IND_MSK_8822B BIT(28)
#define BIT_SDIO_CTWEND_MSK_8822B BIT(27)
#define BIT_SDIO_ATIMEND_E_MSK_8822B BIT(26)
#define BIT_SDIIO_ATIMEND_MSK_8822B BIT(25)
#define BIT_SDIO_OCPINT_MSK_8822B BIT(24)
#define BIT_SDIO_PSTIMEOUT_MSK_8822B BIT(23)
#define BIT_SDIO_GTINT4_MSK_8822B BIT(22)
#define BIT_SDIO_GTINT3_MSK_8822B BIT(21)
#define BIT_SDIO_HSISR_IND_MSK_8822B BIT(20)
#define BIT_SDIO_CPWM2_MSK_8822B BIT(19)
#define BIT_SDIO_CPWM1_MSK_8822B BIT(18)
#define BIT_SDIO_C2HCMD_INT_MSK_8822B BIT(17)
#define BIT_SDIO_BCNERLY_INT_MSK_8822B BIT(16)
#define BIT_SDIO_TXBCNERR_MSK_8822B BIT(7)
#define BIT_SDIO_TXBCNOK_MSK_8822B BIT(6)
#define BIT_SDIO_RXFOVW_MSK_8822B BIT(5)
#define BIT_SDIO_TXFOVW_MSK_8822B BIT(4)
#define BIT_SDIO_RXERR_MSK_8822B BIT(3)
#define BIT_SDIO_TXERR_MSK_8822B BIT(2)
#define BIT_SDIO_AVAL_MSK_8822B BIT(1)
#define BIT_RX_REQUEST_MSK_8822B BIT(0)
/* 2 REG_SDIO_HISR_8822B */
#define BIT_SDIO_CRCERR_8822B BIT(31)
#define BIT_SDIO_HSISR3_IND_8822B BIT(30)
#define BIT_SDIO_HSISR2_IND_8822B BIT(29)
#define BIT_SDIO_HEISR_IND_8822B BIT(28)
#define BIT_SDIO_CTWEND_8822B BIT(27)
#define BIT_SDIO_ATIMEND_E_8822B BIT(26)
#define BIT_SDIO_ATIMEND_8822B BIT(25)
#define BIT_SDIO_OCPINT_8822B BIT(24)
#define BIT_SDIO_PSTIMEOUT_8822B BIT(23)
#define BIT_SDIO_GTINT4_8822B BIT(22)
#define BIT_SDIO_GTINT3_8822B BIT(21)
#define BIT_SDIO_HSISR_IND_8822B BIT(20)
#define BIT_SDIO_CPWM2_8822B BIT(19)
#define BIT_SDIO_CPWM1_8822B BIT(18)
#define BIT_SDIO_C2HCMD_INT_8822B BIT(17)
#define BIT_SDIO_BCNERLY_INT_8822B BIT(16)
#define BIT_SDIO_TXBCNERR_8822B BIT(7)
#define BIT_SDIO_TXBCNOK_8822B BIT(6)
#define BIT_SDIO_RXFOVW_8822B BIT(5)
#define BIT_SDIO_TXFOVW_8822B BIT(4)
#define BIT_SDIO_RXERR_8822B BIT(3)
#define BIT_SDIO_TXERR_8822B BIT(2)
#define BIT_SDIO_AVAL_8822B BIT(1)
#define BIT_RX_REQUEST_8822B BIT(0)
/* 2 REG_SDIO_RX_REQ_LEN_8822B */
#define BIT_SHIFT_RX_REQ_LEN_V1_8822B 0
#define BIT_MASK_RX_REQ_LEN_V1_8822B 0x3ffff
#define BIT_RX_REQ_LEN_V1_8822B(x) \
(((x) & BIT_MASK_RX_REQ_LEN_V1_8822B) << BIT_SHIFT_RX_REQ_LEN_V1_8822B)
#define BITS_RX_REQ_LEN_V1_8822B \
(BIT_MASK_RX_REQ_LEN_V1_8822B << BIT_SHIFT_RX_REQ_LEN_V1_8822B)
#define BIT_CLEAR_RX_REQ_LEN_V1_8822B(x) ((x) & (~BITS_RX_REQ_LEN_V1_8822B))
#define BIT_GET_RX_REQ_LEN_V1_8822B(x) \
(((x) >> BIT_SHIFT_RX_REQ_LEN_V1_8822B) & BIT_MASK_RX_REQ_LEN_V1_8822B)
#define BIT_SET_RX_REQ_LEN_V1_8822B(x, v) \
(BIT_CLEAR_RX_REQ_LEN_V1_8822B(x) | BIT_RX_REQ_LEN_V1_8822B(v))
/* 2 REG_SDIO_FREE_TXPG_SEQ_V1_8822B */
#define BIT_SHIFT_FREE_TXPG_SEQ_8822B 0
#define BIT_MASK_FREE_TXPG_SEQ_8822B 0xff
#define BIT_FREE_TXPG_SEQ_8822B(x) \
(((x) & BIT_MASK_FREE_TXPG_SEQ_8822B) << BIT_SHIFT_FREE_TXPG_SEQ_8822B)
#define BITS_FREE_TXPG_SEQ_8822B \
(BIT_MASK_FREE_TXPG_SEQ_8822B << BIT_SHIFT_FREE_TXPG_SEQ_8822B)
#define BIT_CLEAR_FREE_TXPG_SEQ_8822B(x) ((x) & (~BITS_FREE_TXPG_SEQ_8822B))
#define BIT_GET_FREE_TXPG_SEQ_8822B(x) \
(((x) >> BIT_SHIFT_FREE_TXPG_SEQ_8822B) & BIT_MASK_FREE_TXPG_SEQ_8822B)
#define BIT_SET_FREE_TXPG_SEQ_8822B(x, v) \
(BIT_CLEAR_FREE_TXPG_SEQ_8822B(x) | BIT_FREE_TXPG_SEQ_8822B(v))
/* 2 REG_SDIO_FREE_TXPG_8822B */
#define BIT_SHIFT_MID_FREEPG_V1_8822B 16
#define BIT_MASK_MID_FREEPG_V1_8822B 0xfff
#define BIT_MID_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_MID_FREEPG_V1_8822B) << BIT_SHIFT_MID_FREEPG_V1_8822B)
#define BITS_MID_FREEPG_V1_8822B \
(BIT_MASK_MID_FREEPG_V1_8822B << BIT_SHIFT_MID_FREEPG_V1_8822B)
#define BIT_CLEAR_MID_FREEPG_V1_8822B(x) ((x) & (~BITS_MID_FREEPG_V1_8822B))
#define BIT_GET_MID_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_MID_FREEPG_V1_8822B) & BIT_MASK_MID_FREEPG_V1_8822B)
#define BIT_SET_MID_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_MID_FREEPG_V1_8822B(x) | BIT_MID_FREEPG_V1_8822B(v))
#define BIT_SHIFT_HIQ_FREEPG_V1_8822B 0
#define BIT_MASK_HIQ_FREEPG_V1_8822B 0xfff
#define BIT_HIQ_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_HIQ_FREEPG_V1_8822B) << BIT_SHIFT_HIQ_FREEPG_V1_8822B)
#define BITS_HIQ_FREEPG_V1_8822B \
(BIT_MASK_HIQ_FREEPG_V1_8822B << BIT_SHIFT_HIQ_FREEPG_V1_8822B)
#define BIT_CLEAR_HIQ_FREEPG_V1_8822B(x) ((x) & (~BITS_HIQ_FREEPG_V1_8822B))
#define BIT_GET_HIQ_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_HIQ_FREEPG_V1_8822B) & BIT_MASK_HIQ_FREEPG_V1_8822B)
#define BIT_SET_HIQ_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_HIQ_FREEPG_V1_8822B(x) | BIT_HIQ_FREEPG_V1_8822B(v))
/* 2 REG_SDIO_FREE_TXPG2_8822B */
#define BIT_SHIFT_PUB_FREEPG_V1_8822B 16
#define BIT_MASK_PUB_FREEPG_V1_8822B 0xfff
#define BIT_PUB_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_PUB_FREEPG_V1_8822B) << BIT_SHIFT_PUB_FREEPG_V1_8822B)
#define BITS_PUB_FREEPG_V1_8822B \
(BIT_MASK_PUB_FREEPG_V1_8822B << BIT_SHIFT_PUB_FREEPG_V1_8822B)
#define BIT_CLEAR_PUB_FREEPG_V1_8822B(x) ((x) & (~BITS_PUB_FREEPG_V1_8822B))
#define BIT_GET_PUB_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_PUB_FREEPG_V1_8822B) & BIT_MASK_PUB_FREEPG_V1_8822B)
#define BIT_SET_PUB_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_PUB_FREEPG_V1_8822B(x) | BIT_PUB_FREEPG_V1_8822B(v))
#define BIT_SHIFT_LOW_FREEPG_V1_8822B 0
#define BIT_MASK_LOW_FREEPG_V1_8822B 0xfff
#define BIT_LOW_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_LOW_FREEPG_V1_8822B) << BIT_SHIFT_LOW_FREEPG_V1_8822B)
#define BITS_LOW_FREEPG_V1_8822B \
(BIT_MASK_LOW_FREEPG_V1_8822B << BIT_SHIFT_LOW_FREEPG_V1_8822B)
#define BIT_CLEAR_LOW_FREEPG_V1_8822B(x) ((x) & (~BITS_LOW_FREEPG_V1_8822B))
#define BIT_GET_LOW_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_LOW_FREEPG_V1_8822B) & BIT_MASK_LOW_FREEPG_V1_8822B)
#define BIT_SET_LOW_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_LOW_FREEPG_V1_8822B(x) | BIT_LOW_FREEPG_V1_8822B(v))
/* 2 REG_SDIO_OQT_FREE_TXPG_V1_8822B */
#define BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822B 24
#define BIT_MASK_NOAC_OQT_FREEPG_V1_8822B 0xff
#define BIT_NOAC_OQT_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_NOAC_OQT_FREEPG_V1_8822B) \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822B)
#define BITS_NOAC_OQT_FREEPG_V1_8822B \
(BIT_MASK_NOAC_OQT_FREEPG_V1_8822B \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822B)
#define BIT_CLEAR_NOAC_OQT_FREEPG_V1_8822B(x) \
((x) & (~BITS_NOAC_OQT_FREEPG_V1_8822B))
#define BIT_GET_NOAC_OQT_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822B) & \
BIT_MASK_NOAC_OQT_FREEPG_V1_8822B)
#define BIT_SET_NOAC_OQT_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_NOAC_OQT_FREEPG_V1_8822B(x) | \
BIT_NOAC_OQT_FREEPG_V1_8822B(v))
#define BIT_SHIFT_AC_OQT_FREEPG_V1_8822B 16
#define BIT_MASK_AC_OQT_FREEPG_V1_8822B 0xff
#define BIT_AC_OQT_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_AC_OQT_FREEPG_V1_8822B) \
<< BIT_SHIFT_AC_OQT_FREEPG_V1_8822B)
#define BITS_AC_OQT_FREEPG_V1_8822B \
(BIT_MASK_AC_OQT_FREEPG_V1_8822B << BIT_SHIFT_AC_OQT_FREEPG_V1_8822B)
#define BIT_CLEAR_AC_OQT_FREEPG_V1_8822B(x) \
((x) & (~BITS_AC_OQT_FREEPG_V1_8822B))
#define BIT_GET_AC_OQT_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_AC_OQT_FREEPG_V1_8822B) & \
BIT_MASK_AC_OQT_FREEPG_V1_8822B)
#define BIT_SET_AC_OQT_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_AC_OQT_FREEPG_V1_8822B(x) | BIT_AC_OQT_FREEPG_V1_8822B(v))
#define BIT_SHIFT_EXQ_FREEPG_V1_8822B 0
#define BIT_MASK_EXQ_FREEPG_V1_8822B 0xfff
#define BIT_EXQ_FREEPG_V1_8822B(x) \
(((x) & BIT_MASK_EXQ_FREEPG_V1_8822B) << BIT_SHIFT_EXQ_FREEPG_V1_8822B)
#define BITS_EXQ_FREEPG_V1_8822B \
(BIT_MASK_EXQ_FREEPG_V1_8822B << BIT_SHIFT_EXQ_FREEPG_V1_8822B)
#define BIT_CLEAR_EXQ_FREEPG_V1_8822B(x) ((x) & (~BITS_EXQ_FREEPG_V1_8822B))
#define BIT_GET_EXQ_FREEPG_V1_8822B(x) \
(((x) >> BIT_SHIFT_EXQ_FREEPG_V1_8822B) & BIT_MASK_EXQ_FREEPG_V1_8822B)
#define BIT_SET_EXQ_FREEPG_V1_8822B(x, v) \
(BIT_CLEAR_EXQ_FREEPG_V1_8822B(x) | BIT_EXQ_FREEPG_V1_8822B(v))
/* 2 REG_SDIO_HTSFR_INFO_8822B */
#define BIT_SHIFT_HTSFR1_8822B 16
#define BIT_MASK_HTSFR1_8822B 0xffff
#define BIT_HTSFR1_8822B(x) \
(((x) & BIT_MASK_HTSFR1_8822B) << BIT_SHIFT_HTSFR1_8822B)
#define BITS_HTSFR1_8822B (BIT_MASK_HTSFR1_8822B << BIT_SHIFT_HTSFR1_8822B)
#define BIT_CLEAR_HTSFR1_8822B(x) ((x) & (~BITS_HTSFR1_8822B))
#define BIT_GET_HTSFR1_8822B(x) \
(((x) >> BIT_SHIFT_HTSFR1_8822B) & BIT_MASK_HTSFR1_8822B)
#define BIT_SET_HTSFR1_8822B(x, v) \
(BIT_CLEAR_HTSFR1_8822B(x) | BIT_HTSFR1_8822B(v))
#define BIT_SHIFT_HTSFR0_8822B 0
#define BIT_MASK_HTSFR0_8822B 0xffff
#define BIT_HTSFR0_8822B(x) \
(((x) & BIT_MASK_HTSFR0_8822B) << BIT_SHIFT_HTSFR0_8822B)
#define BITS_HTSFR0_8822B (BIT_MASK_HTSFR0_8822B << BIT_SHIFT_HTSFR0_8822B)
#define BIT_CLEAR_HTSFR0_8822B(x) ((x) & (~BITS_HTSFR0_8822B))
#define BIT_GET_HTSFR0_8822B(x) \
(((x) >> BIT_SHIFT_HTSFR0_8822B) & BIT_MASK_HTSFR0_8822B)
#define BIT_SET_HTSFR0_8822B(x, v) \
(BIT_CLEAR_HTSFR0_8822B(x) | BIT_HTSFR0_8822B(v))
/* 2 REG_SDIO_HCPWM1_V2_8822B */
#define BIT_TOGGLE_8822B BIT(7)
#define BIT_CUR_PS_8822B BIT(0)
/* 2 REG_SDIO_HCPWM2_V2_8822B */
/* 2 REG_SDIO_INDIRECT_REG_CFG_8822B */
#define BIT_INDIRECT_REG_RDY_8822B BIT(20)
#define BIT_INDIRECT_REG_R_8822B BIT(19)
#define BIT_INDIRECT_REG_W_8822B BIT(18)
#define BIT_SHIFT_INDIRECT_REG_SIZE_8822B 16
#define BIT_MASK_INDIRECT_REG_SIZE_8822B 0x3
#define BIT_INDIRECT_REG_SIZE_8822B(x) \
(((x) & BIT_MASK_INDIRECT_REG_SIZE_8822B) \
<< BIT_SHIFT_INDIRECT_REG_SIZE_8822B)
#define BITS_INDIRECT_REG_SIZE_8822B \
(BIT_MASK_INDIRECT_REG_SIZE_8822B << BIT_SHIFT_INDIRECT_REG_SIZE_8822B)
#define BIT_CLEAR_INDIRECT_REG_SIZE_8822B(x) \
((x) & (~BITS_INDIRECT_REG_SIZE_8822B))
#define BIT_GET_INDIRECT_REG_SIZE_8822B(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_SIZE_8822B) & \
BIT_MASK_INDIRECT_REG_SIZE_8822B)
#define BIT_SET_INDIRECT_REG_SIZE_8822B(x, v) \
(BIT_CLEAR_INDIRECT_REG_SIZE_8822B(x) | BIT_INDIRECT_REG_SIZE_8822B(v))
#define BIT_SHIFT_INDIRECT_REG_ADDR_8822B 0
#define BIT_MASK_INDIRECT_REG_ADDR_8822B 0xffff
#define BIT_INDIRECT_REG_ADDR_8822B(x) \
(((x) & BIT_MASK_INDIRECT_REG_ADDR_8822B) \
<< BIT_SHIFT_INDIRECT_REG_ADDR_8822B)
#define BITS_INDIRECT_REG_ADDR_8822B \
(BIT_MASK_INDIRECT_REG_ADDR_8822B << BIT_SHIFT_INDIRECT_REG_ADDR_8822B)
#define BIT_CLEAR_INDIRECT_REG_ADDR_8822B(x) \
((x) & (~BITS_INDIRECT_REG_ADDR_8822B))
#define BIT_GET_INDIRECT_REG_ADDR_8822B(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_ADDR_8822B) & \
BIT_MASK_INDIRECT_REG_ADDR_8822B)
#define BIT_SET_INDIRECT_REG_ADDR_8822B(x, v) \
(BIT_CLEAR_INDIRECT_REG_ADDR_8822B(x) | BIT_INDIRECT_REG_ADDR_8822B(v))
/* 2 REG_SDIO_INDIRECT_REG_DATA_8822B */
#define BIT_SHIFT_INDIRECT_REG_DATA_8822B 0
#define BIT_MASK_INDIRECT_REG_DATA_8822B 0xffffffffL
#define BIT_INDIRECT_REG_DATA_8822B(x) \
(((x) & BIT_MASK_INDIRECT_REG_DATA_8822B) \
<< BIT_SHIFT_INDIRECT_REG_DATA_8822B)
#define BITS_INDIRECT_REG_DATA_8822B \
(BIT_MASK_INDIRECT_REG_DATA_8822B << BIT_SHIFT_INDIRECT_REG_DATA_8822B)
#define BIT_CLEAR_INDIRECT_REG_DATA_8822B(x) \
((x) & (~BITS_INDIRECT_REG_DATA_8822B))
#define BIT_GET_INDIRECT_REG_DATA_8822B(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_DATA_8822B) & \
BIT_MASK_INDIRECT_REG_DATA_8822B)
#define BIT_SET_INDIRECT_REG_DATA_8822B(x, v) \
(BIT_CLEAR_INDIRECT_REG_DATA_8822B(x) | BIT_INDIRECT_REG_DATA_8822B(v))
/* 2 REG_SDIO_H2C_8822B */
#define BIT_SHIFT_SDIO_H2C_MSG_8822B 0
#define BIT_MASK_SDIO_H2C_MSG_8822B 0xffffffffL
#define BIT_SDIO_H2C_MSG_8822B(x) \
(((x) & BIT_MASK_SDIO_H2C_MSG_8822B) << BIT_SHIFT_SDIO_H2C_MSG_8822B)
#define BITS_SDIO_H2C_MSG_8822B \
(BIT_MASK_SDIO_H2C_MSG_8822B << BIT_SHIFT_SDIO_H2C_MSG_8822B)
#define BIT_CLEAR_SDIO_H2C_MSG_8822B(x) ((x) & (~BITS_SDIO_H2C_MSG_8822B))
#define BIT_GET_SDIO_H2C_MSG_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_H2C_MSG_8822B) & BIT_MASK_SDIO_H2C_MSG_8822B)
#define BIT_SET_SDIO_H2C_MSG_8822B(x, v) \
(BIT_CLEAR_SDIO_H2C_MSG_8822B(x) | BIT_SDIO_H2C_MSG_8822B(v))
/* 2 REG_SDIO_C2H_8822B */
#define BIT_SHIFT_SDIO_C2H_MSG_8822B 0
#define BIT_MASK_SDIO_C2H_MSG_8822B 0xffffffffL
#define BIT_SDIO_C2H_MSG_8822B(x) \
(((x) & BIT_MASK_SDIO_C2H_MSG_8822B) << BIT_SHIFT_SDIO_C2H_MSG_8822B)
#define BITS_SDIO_C2H_MSG_8822B \
(BIT_MASK_SDIO_C2H_MSG_8822B << BIT_SHIFT_SDIO_C2H_MSG_8822B)
#define BIT_CLEAR_SDIO_C2H_MSG_8822B(x) ((x) & (~BITS_SDIO_C2H_MSG_8822B))
#define BIT_GET_SDIO_C2H_MSG_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_C2H_MSG_8822B) & BIT_MASK_SDIO_C2H_MSG_8822B)
#define BIT_SET_SDIO_C2H_MSG_8822B(x, v) \
(BIT_CLEAR_SDIO_C2H_MSG_8822B(x) | BIT_SDIO_C2H_MSG_8822B(v))
/* 2 REG_SDIO_HRPWM1_8822B */
#define BIT_TOGGLE_8822B BIT(7)
#define BIT_ACK_8822B BIT(6)
#define BIT_REQ_PS_8822B BIT(0)
/* 2 REG_SDIO_HRPWM2_8822B */
/* 2 REG_SDIO_HPS_CLKR_8822B */
/* 2 REG_SDIO_BUS_CTRL_8822B */
#define BIT_PAD_CLK_XHGE_EN_8822B BIT(3)
#define BIT_INTER_CLK_EN_8822B BIT(2)
#define BIT_EN_RPT_TXCRC_8822B BIT(1)
#define BIT_DIS_RXDMA_STS_8822B BIT(0)
/* 2 REG_SDIO_HSUS_CTRL_8822B */
#define BIT_INTR_CTRL_8822B BIT(4)
#define BIT_SDIO_VOLTAGE_8822B BIT(3)
#define BIT_BYPASS_INIT_8822B BIT(2)
#define BIT_HCI_RESUME_RDY_8822B BIT(1)
#define BIT_HCI_SUS_REQ_8822B BIT(0)
/* 2 REG_SDIO_RESPONSE_TIMER_8822B */
#define BIT_SHIFT_CMDIN_2RESP_TIMER_8822B 0
#define BIT_MASK_CMDIN_2RESP_TIMER_8822B 0xffff
#define BIT_CMDIN_2RESP_TIMER_8822B(x) \
(((x) & BIT_MASK_CMDIN_2RESP_TIMER_8822B) \
<< BIT_SHIFT_CMDIN_2RESP_TIMER_8822B)
#define BITS_CMDIN_2RESP_TIMER_8822B \
(BIT_MASK_CMDIN_2RESP_TIMER_8822B << BIT_SHIFT_CMDIN_2RESP_TIMER_8822B)
#define BIT_CLEAR_CMDIN_2RESP_TIMER_8822B(x) \
((x) & (~BITS_CMDIN_2RESP_TIMER_8822B))
#define BIT_GET_CMDIN_2RESP_TIMER_8822B(x) \
(((x) >> BIT_SHIFT_CMDIN_2RESP_TIMER_8822B) & \
BIT_MASK_CMDIN_2RESP_TIMER_8822B)
#define BIT_SET_CMDIN_2RESP_TIMER_8822B(x, v) \
(BIT_CLEAR_CMDIN_2RESP_TIMER_8822B(x) | BIT_CMDIN_2RESP_TIMER_8822B(v))
/* 2 REG_SDIO_CMD_CRC_8822B */
#define BIT_SHIFT_SDIO_CMD_CRC_V1_8822B 0
#define BIT_MASK_SDIO_CMD_CRC_V1_8822B 0xff
#define BIT_SDIO_CMD_CRC_V1_8822B(x) \
(((x) & BIT_MASK_SDIO_CMD_CRC_V1_8822B) \
<< BIT_SHIFT_SDIO_CMD_CRC_V1_8822B)
#define BITS_SDIO_CMD_CRC_V1_8822B \
(BIT_MASK_SDIO_CMD_CRC_V1_8822B << BIT_SHIFT_SDIO_CMD_CRC_V1_8822B)
#define BIT_CLEAR_SDIO_CMD_CRC_V1_8822B(x) ((x) & (~BITS_SDIO_CMD_CRC_V1_8822B))
#define BIT_GET_SDIO_CMD_CRC_V1_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_CRC_V1_8822B) & \
BIT_MASK_SDIO_CMD_CRC_V1_8822B)
#define BIT_SET_SDIO_CMD_CRC_V1_8822B(x, v) \
(BIT_CLEAR_SDIO_CMD_CRC_V1_8822B(x) | BIT_SDIO_CMD_CRC_V1_8822B(v))
/* 2 REG_SDIO_HSISR_8822B */
#define BIT_DRV_WLAN_INT_CLR_8822B BIT(1)
#define BIT_DRV_WLAN_INT_8822B BIT(0)
/* 2 REG_SDIO_ERR_RPT_8822B */
#define BIT_HR_FF_OVF_8822B BIT(6)
#define BIT_HR_FF_UDN_8822B BIT(5)
#define BIT_TXDMA_BUSY_ERR_8822B BIT(4)
#define BIT_TXDMA_VLD_ERR_8822B BIT(3)
#define BIT_QSEL_UNKNOWN_ERR_8822B BIT(2)
#define BIT_QSEL_MIS_ERR_8822B BIT(1)
#define BIT_SDIO_OVERRD_ERR_8822B BIT(0)
/* 2 REG_SDIO_CMD_ERRCNT_8822B */
#define BIT_SHIFT_CMD_CRC_ERR_CNT_8822B 0
#define BIT_MASK_CMD_CRC_ERR_CNT_8822B 0xff
#define BIT_CMD_CRC_ERR_CNT_8822B(x) \
(((x) & BIT_MASK_CMD_CRC_ERR_CNT_8822B) \
<< BIT_SHIFT_CMD_CRC_ERR_CNT_8822B)
#define BITS_CMD_CRC_ERR_CNT_8822B \
(BIT_MASK_CMD_CRC_ERR_CNT_8822B << BIT_SHIFT_CMD_CRC_ERR_CNT_8822B)
#define BIT_CLEAR_CMD_CRC_ERR_CNT_8822B(x) ((x) & (~BITS_CMD_CRC_ERR_CNT_8822B))
#define BIT_GET_CMD_CRC_ERR_CNT_8822B(x) \
(((x) >> BIT_SHIFT_CMD_CRC_ERR_CNT_8822B) & \
BIT_MASK_CMD_CRC_ERR_CNT_8822B)
#define BIT_SET_CMD_CRC_ERR_CNT_8822B(x, v) \
(BIT_CLEAR_CMD_CRC_ERR_CNT_8822B(x) | BIT_CMD_CRC_ERR_CNT_8822B(v))
/* 2 REG_SDIO_DATA_ERRCNT_8822B */
#define BIT_SHIFT_DATA_CRC_ERR_CNT_8822B 0
#define BIT_MASK_DATA_CRC_ERR_CNT_8822B 0xff
#define BIT_DATA_CRC_ERR_CNT_8822B(x) \
(((x) & BIT_MASK_DATA_CRC_ERR_CNT_8822B) \
<< BIT_SHIFT_DATA_CRC_ERR_CNT_8822B)
#define BITS_DATA_CRC_ERR_CNT_8822B \
(BIT_MASK_DATA_CRC_ERR_CNT_8822B << BIT_SHIFT_DATA_CRC_ERR_CNT_8822B)
#define BIT_CLEAR_DATA_CRC_ERR_CNT_8822B(x) \
((x) & (~BITS_DATA_CRC_ERR_CNT_8822B))
#define BIT_GET_DATA_CRC_ERR_CNT_8822B(x) \
(((x) >> BIT_SHIFT_DATA_CRC_ERR_CNT_8822B) & \
BIT_MASK_DATA_CRC_ERR_CNT_8822B)
#define BIT_SET_DATA_CRC_ERR_CNT_8822B(x, v) \
(BIT_CLEAR_DATA_CRC_ERR_CNT_8822B(x) | BIT_DATA_CRC_ERR_CNT_8822B(v))
/* 2 REG_SDIO_CMD_ERR_CONTENT_8822B */
#define BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822B 0
#define BIT_MASK_SDIO_CMD_ERR_CONTENT_8822B 0xffffffffffL
#define BIT_SDIO_CMD_ERR_CONTENT_8822B(x) \
(((x) & BIT_MASK_SDIO_CMD_ERR_CONTENT_8822B) \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822B)
#define BITS_SDIO_CMD_ERR_CONTENT_8822B \
(BIT_MASK_SDIO_CMD_ERR_CONTENT_8822B \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822B)
#define BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8822B(x) \
((x) & (~BITS_SDIO_CMD_ERR_CONTENT_8822B))
#define BIT_GET_SDIO_CMD_ERR_CONTENT_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822B) & \
BIT_MASK_SDIO_CMD_ERR_CONTENT_8822B)
#define BIT_SET_SDIO_CMD_ERR_CONTENT_8822B(x, v) \
(BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8822B(x) | \
BIT_SDIO_CMD_ERR_CONTENT_8822B(v))
/* 2 REG_SDIO_CRC_ERR_IDX_8822B */
#define BIT_D3_CRC_ERR_8822B BIT(4)
#define BIT_D2_CRC_ERR_8822B BIT(3)
#define BIT_D1_CRC_ERR_8822B BIT(2)
#define BIT_D0_CRC_ERR_8822B BIT(1)
#define BIT_CMD_CRC_ERR_8822B BIT(0)
/* 2 REG_SDIO_DATA_CRC_8822B */
#define BIT_SHIFT_SDIO_DATA_CRC_8822B 0
#define BIT_MASK_SDIO_DATA_CRC_8822B 0xffff
#define BIT_SDIO_DATA_CRC_8822B(x) \
(((x) & BIT_MASK_SDIO_DATA_CRC_8822B) << BIT_SHIFT_SDIO_DATA_CRC_8822B)
#define BITS_SDIO_DATA_CRC_8822B \
(BIT_MASK_SDIO_DATA_CRC_8822B << BIT_SHIFT_SDIO_DATA_CRC_8822B)
#define BIT_CLEAR_SDIO_DATA_CRC_8822B(x) ((x) & (~BITS_SDIO_DATA_CRC_8822B))
#define BIT_GET_SDIO_DATA_CRC_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_CRC_8822B) & BIT_MASK_SDIO_DATA_CRC_8822B)
#define BIT_SET_SDIO_DATA_CRC_8822B(x, v) \
(BIT_CLEAR_SDIO_DATA_CRC_8822B(x) | BIT_SDIO_DATA_CRC_8822B(v))
/* 2 REG_SDIO_DATA_REPLY_TIME_8822B */
#define BIT_SHIFT_SDIO_DATA_REPLY_TIME_8822B 0
#define BIT_MASK_SDIO_DATA_REPLY_TIME_8822B 0x7
#define BIT_SDIO_DATA_REPLY_TIME_8822B(x) \
(((x) & BIT_MASK_SDIO_DATA_REPLY_TIME_8822B) \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME_8822B)
#define BITS_SDIO_DATA_REPLY_TIME_8822B \
(BIT_MASK_SDIO_DATA_REPLY_TIME_8822B \
<< BIT_SHIFT_SDIO_DATA_REPLY_TIME_8822B)
#define BIT_CLEAR_SDIO_DATA_REPLY_TIME_8822B(x) \
((x) & (~BITS_SDIO_DATA_REPLY_TIME_8822B))
#define BIT_GET_SDIO_DATA_REPLY_TIME_8822B(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_REPLY_TIME_8822B) & \
BIT_MASK_SDIO_DATA_REPLY_TIME_8822B)
#define BIT_SET_SDIO_DATA_REPLY_TIME_8822B(x, v) \
(BIT_CLEAR_SDIO_DATA_REPLY_TIME_8822B(x) | \
BIT_SDIO_DATA_REPLY_TIME_8822B(v))
#endif
================================================
FILE: hal/halmac/halmac_bit_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_BIT_8822C_H
#define __INC_HALMAC_BIT_8822C_H
#define CPU_OPT_WIDTH 0x1F
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SYS_ISO_CTRL_8822C */
#define BIT_PWC_EV12V_8822C BIT(15)
/* 2 REG_NOT_VALID_8822C */
#define BIT_PA33V_EN_8822C BIT(13)
#define BIT_PA12V_EN_8822C BIT(12)
#define BIT_UA33V_EN_8822C BIT(11)
#define BIT_UA12V_EN_8822C BIT(10)
#define BIT_ISO_RFDIO_8822C BIT(9)
#define BIT_ISO_EB2CORE_8822C BIT(8)
#define BIT_ISO_DIOE_8822C BIT(7)
#define BIT_ISO_WLPON2PP_8822C BIT(6)
#define BIT_ISO_IP2MAC_WA2PP_8822C BIT(5)
#define BIT_ISO_PD2CORE_8822C BIT(4)
#define BIT_ISO_PA2PCIE_8822C BIT(3)
#define BIT_ISO_UD2CORE_8822C BIT(2)
#define BIT_ISO_UA2USB_8822C BIT(1)
#define BIT_ISO_WD2PP_8822C BIT(0)
/* 2 REG_SYS_FUNC_EN_8822C */
#define BIT_FEN_MREGEN_8822C BIT(15)
#define BIT_FEN_HWPDN_8822C BIT(14)
/* 2 REG_NOT_VALID_8822C */
#define BIT_FEN_ELDR_8822C BIT(12)
#define BIT_FEN_DCORE_8822C BIT(11)
#define BIT_FEN_CPUEN_8822C BIT(10)
#define BIT_FEN_DIOE_8822C BIT(9)
#define BIT_FEN_PCIED_8822C BIT(8)
#define BIT_FEN_PPLL_8822C BIT(7)
#define BIT_FEN_PCIEA_8822C BIT(6)
#define BIT_FEN_DIO_PCIE_8822C BIT(5)
#define BIT_FEN_USBD_8822C BIT(4)
#define BIT_FEN_UPLL_8822C BIT(3)
#define BIT_FEN_USBA_8822C BIT(2)
#define BIT_FEN_BB_GLB_RSTN_8822C BIT(1)
#define BIT_FEN_BBRSTB_8822C BIT(0)
/* 2 REG_SYS_PW_CTRL_8822C */
#define BIT_SOP_EABM_8822C BIT(31)
#define BIT_SOP_ACKF_8822C BIT(30)
#define BIT_SOP_ERCK_8822C BIT(29)
#define BIT_SOP_ESWR_8822C BIT(28)
#define BIT_SOP_PWMM_8822C BIT(27)
#define BIT_SOP_EECK_8822C BIT(26)
#define BIT_SOP_ANA_CLK_DIVISION_2_8822C BIT(25)
#define BIT_SOP_EXTL_8822C BIT(24)
#define BIT_SYM_OP_RING_12M_8822C BIT(22)
#define BIT_ROP_SWPR_8822C BIT(21)
#define BIT_DIS_HW_LPLDM_8822C BIT(20)
#define BIT_OPT_SWRST_WLMCU_8822C BIT(19)
#define BIT_RDY_SYSPWR_8822C BIT(17)
#define BIT_EN_WLON_8822C BIT(16)
#define BIT_APDM_HPDN_8822C BIT(15)
#define BIT_AFSM_PCIE_SUS_EN_8822C BIT(12)
#define BIT_AFSM_WLSUS_EN_8822C BIT(11)
#define BIT_APFM_SWLPS_8822C BIT(10)
#define BIT_APFM_OFFMAC_8822C BIT(9)
#define BIT_APFN_ONMAC_8822C BIT(8)
#define BIT_CHIP_PDN_EN_8822C BIT(7)
#define BIT_RDY_MACDIS_8822C BIT(6)
/* 2 REG_NOT_VALID_8822C */
#define BIT_PFM_WOWL_8822C BIT(3)
#define BIT_PFM_LDKP_8822C BIT(2)
#define BIT_WL_HCI_ALD_8822C BIT(1)
#define BIT_PFM_LDALL_8822C BIT(0)
/* 2 REG_SYS_CLK_CTRL_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_CPU_CLK_EN_8822C BIT(14)
#define BIT_SYMREG_CLK_EN_8822C BIT(13)
#define BIT_HCI_CLK_EN_8822C BIT(12)
#define BIT_MAC_CLK_EN_8822C BIT(11)
#define BIT_SEC_CLK_EN_8822C BIT(10)
#define BIT_PHY_SSC_RSTB_8822C BIT(9)
#define BIT_EXT_32K_EN_8822C BIT(8)
#define BIT_WL_CLK_TEST_8822C BIT(7)
#define BIT_OP_SPS_PWM_EN_8822C BIT(6)
#define BIT_LOADER_CLK_EN_8822C BIT(5)
#define BIT_MACSLP_8822C BIT(4)
#define BIT_WAKEPAD_EN_8822C BIT(3)
#define BIT_ROMD16V_EN_8822C BIT(2)
#define BIT_ANA_CLK_DIVISION_2_8822C BIT(1)
#define BIT_CNTD16V_EN_8822C BIT(0)
/* 2 REG_SYS_EEPROM_CTRL_8822C */
#define BIT_SHIFT_VPDIDX_8822C 8
#define BIT_MASK_VPDIDX_8822C 0xff
#define BIT_VPDIDX_8822C(x) \
(((x) & BIT_MASK_VPDIDX_8822C) << BIT_SHIFT_VPDIDX_8822C)
#define BITS_VPDIDX_8822C (BIT_MASK_VPDIDX_8822C << BIT_SHIFT_VPDIDX_8822C)
#define BIT_CLEAR_VPDIDX_8822C(x) ((x) & (~BITS_VPDIDX_8822C))
#define BIT_GET_VPDIDX_8822C(x) \
(((x) >> BIT_SHIFT_VPDIDX_8822C) & BIT_MASK_VPDIDX_8822C)
#define BIT_SET_VPDIDX_8822C(x, v) \
(BIT_CLEAR_VPDIDX_8822C(x) | BIT_VPDIDX_8822C(v))
#define BIT_SHIFT_EEM1_0_8822C 6
#define BIT_MASK_EEM1_0_8822C 0x3
#define BIT_EEM1_0_8822C(x) \
(((x) & BIT_MASK_EEM1_0_8822C) << BIT_SHIFT_EEM1_0_8822C)
#define BITS_EEM1_0_8822C (BIT_MASK_EEM1_0_8822C << BIT_SHIFT_EEM1_0_8822C)
#define BIT_CLEAR_EEM1_0_8822C(x) ((x) & (~BITS_EEM1_0_8822C))
#define BIT_GET_EEM1_0_8822C(x) \
(((x) >> BIT_SHIFT_EEM1_0_8822C) & BIT_MASK_EEM1_0_8822C)
#define BIT_SET_EEM1_0_8822C(x, v) \
(BIT_CLEAR_EEM1_0_8822C(x) | BIT_EEM1_0_8822C(v))
#define BIT_AUTOLOAD_SUS_8822C BIT(5)
#define BIT_EERPOMSEL_8822C BIT(4)
#define BIT_EECS_V1_8822C BIT(3)
#define BIT_EESK_V1_8822C BIT(2)
#define BIT_EEDI_V1_8822C BIT(1)
#define BIT_EEDO_V1_8822C BIT(0)
/* 2 REG_EE_VPD_8822C */
#define BIT_SHIFT_VPD_DATA_8822C 0
#define BIT_MASK_VPD_DATA_8822C 0xffffffffL
#define BIT_VPD_DATA_8822C(x) \
(((x) & BIT_MASK_VPD_DATA_8822C) << BIT_SHIFT_VPD_DATA_8822C)
#define BITS_VPD_DATA_8822C \
(BIT_MASK_VPD_DATA_8822C << BIT_SHIFT_VPD_DATA_8822C)
#define BIT_CLEAR_VPD_DATA_8822C(x) ((x) & (~BITS_VPD_DATA_8822C))
#define BIT_GET_VPD_DATA_8822C(x) \
(((x) >> BIT_SHIFT_VPD_DATA_8822C) & BIT_MASK_VPD_DATA_8822C)
#define BIT_SET_VPD_DATA_8822C(x, v) \
(BIT_CLEAR_VPD_DATA_8822C(x) | BIT_VPD_DATA_8822C(v))
/* 2 REG_SYS_SWR_CTRL1_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_HW_AUTO_CTRL_EXT_SWR_8822C BIT(9)
#define BIT_USE_INTERNAL_SWR_AND_LDO_8822C BIT(8)
#define BIT_MAC_ID_EN_8822C BIT(7)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SYS_SWR_CTRL2_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SW18_SEL_8822C BIT(13)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SW18_SD_8822C BIT(10)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SYS_SWR_CTRL3_8822C */
#define BIT_SPS18_OCP_DIS_8822C BIT(31)
#define BIT_SHIFT_SPS18_OCP_TH_8822C 16
#define BIT_MASK_SPS18_OCP_TH_8822C 0x7fff
#define BIT_SPS18_OCP_TH_8822C(x) \
(((x) & BIT_MASK_SPS18_OCP_TH_8822C) << BIT_SHIFT_SPS18_OCP_TH_8822C)
#define BITS_SPS18_OCP_TH_8822C \
(BIT_MASK_SPS18_OCP_TH_8822C << BIT_SHIFT_SPS18_OCP_TH_8822C)
#define BIT_CLEAR_SPS18_OCP_TH_8822C(x) ((x) & (~BITS_SPS18_OCP_TH_8822C))
#define BIT_GET_SPS18_OCP_TH_8822C(x) \
(((x) >> BIT_SHIFT_SPS18_OCP_TH_8822C) & BIT_MASK_SPS18_OCP_TH_8822C)
#define BIT_SET_SPS18_OCP_TH_8822C(x, v) \
(BIT_CLEAR_SPS18_OCP_TH_8822C(x) | BIT_SPS18_OCP_TH_8822C(v))
#define BIT_SHIFT_OCP_WINDOW_8822C 0
#define BIT_MASK_OCP_WINDOW_8822C 0xffff
#define BIT_OCP_WINDOW_8822C(x) \
(((x) & BIT_MASK_OCP_WINDOW_8822C) << BIT_SHIFT_OCP_WINDOW_8822C)
#define BITS_OCP_WINDOW_8822C \
(BIT_MASK_OCP_WINDOW_8822C << BIT_SHIFT_OCP_WINDOW_8822C)
#define BIT_CLEAR_OCP_WINDOW_8822C(x) ((x) & (~BITS_OCP_WINDOW_8822C))
#define BIT_GET_OCP_WINDOW_8822C(x) \
(((x) >> BIT_SHIFT_OCP_WINDOW_8822C) & BIT_MASK_OCP_WINDOW_8822C)
#define BIT_SET_OCP_WINDOW_8822C(x, v) \
(BIT_CLEAR_OCP_WINDOW_8822C(x) | BIT_OCP_WINDOW_8822C(v))
/* 2 REG_RSV_CTRL_8822C */
#define BIT_HREG_DBG_8822C BIT(23)
#define BIT_WLMCUIOIF_8822C BIT(8)
#define BIT_LOCK_ALL_EN_8822C BIT(7)
#define BIT_R_DIS_PRST_8822C BIT(6)
#define BIT_WLOCK_1C_B6_8822C BIT(5)
#define BIT_WLOCK_40_8822C BIT(4)
#define BIT_WLOCK_08_8822C BIT(3)
#define BIT_WLOCK_04_8822C BIT(2)
#define BIT_WLOCK_00_8822C BIT(1)
#define BIT_WLOCK_ALL_8822C BIT(0)
/* 2 REG_RF_CTRL_8822C */
#define BIT_RF_SDMRSTB_8822C BIT(2)
#define BIT_RF_RSTB_8822C BIT(1)
#define BIT_RF_EN_8822C BIT(0)
/* 2 REG_AFE_LDO_CTRL_8822C */
#define BIT_R_SYM_WLPON_EMEM1_EN_8822C BIT(31)
#define BIT_R_SYM_WLPON_EMEM0_EN_8822C BIT(30)
#define BIT_R_SYM_WLPOFF_P4EN_8822C BIT(28)
#define BIT_R_SYM_WLPOFF_P3EN_8822C BIT(27)
#define BIT_R_SYM_WLPOFF_P2EN_8822C BIT(26)
#define BIT_R_SYM_WLPOFF_P1EN_8822C BIT(25)
#define BIT_R_SYM_WLPOFF_EN_8822C BIT(24)
#define BIT_R_SYM_WLPON_P3EN_8822C BIT(21)
#define BIT_R_SYM_WLPON_P2EN_8822C BIT(20)
#define BIT_R_SYM_WLPON_P1EN_8822C BIT(19)
#define BIT_R_SYM_WLPON_EN_8822C BIT(18)
#define BIT_R_SYM_LDOV12D_STBY_8822C BIT(16)
#define BIT_R_SYM_WLBBOFF1_P4_EN_8822C BIT(9)
#define BIT_R_SYM_WLBBOFF1_P3_EN_8822C BIT(8)
#define BIT_R_SYM_WLBBOFF1_P2_EN_8822C BIT(7)
#define BIT_R_SYM_WLBBOFF1_P1_EN_8822C BIT(6)
#define BIT_R_SYM_WLBBOFF_P4_EN_8822C BIT(4)
#define BIT_R_SYM_WLBBOFF_P3_EN_8822C BIT(3)
#define BIT_R_SYM_WLBBOFF_P2_EN_8822C BIT(2)
#define BIT_R_SYM_WLBBOFF_P1_EN_8822C BIT(1)
#define BIT_R_SYM_WLBBOFF_EN_8822C BIT(0)
/* 2 REG_AFE_CTRL1_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_MAC_CLK_SEL_8822C 20
#define BIT_MASK_MAC_CLK_SEL_8822C 0x3
#define BIT_MAC_CLK_SEL_8822C(x) \
(((x) & BIT_MASK_MAC_CLK_SEL_8822C) << BIT_SHIFT_MAC_CLK_SEL_8822C)
#define BITS_MAC_CLK_SEL_8822C \
(BIT_MASK_MAC_CLK_SEL_8822C << BIT_SHIFT_MAC_CLK_SEL_8822C)
#define BIT_CLEAR_MAC_CLK_SEL_8822C(x) ((x) & (~BITS_MAC_CLK_SEL_8822C))
#define BIT_GET_MAC_CLK_SEL_8822C(x) \
(((x) >> BIT_SHIFT_MAC_CLK_SEL_8822C) & BIT_MASK_MAC_CLK_SEL_8822C)
#define BIT_SET_MAC_CLK_SEL_8822C(x, v) \
(BIT_CLEAR_MAC_CLK_SEL_8822C(x) | BIT_MAC_CLK_SEL_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ANAPARSW_POW_MAC_8822C */
#define BIT_POW_LDO15_8822C BIT(2)
#define BIT_POW_SW_8822C BIT(1)
#define BIT_POW_LDO14_8822C BIT(0)
/* 2 REG_ANAPARLDO_POW_MAC_8822C */
#define BIT_LDOE25_POW_L_8822C BIT(0)
/* 2 REG_ANAPAR_POW_MAC_8822C */
#define BIT_DUMMY_V4_8822C BIT(7)
#define BIT_DUMMY_V3_8822C BIT(6)
#define BIT_DUMMY_V2_8822C BIT(5)
#define BIT_DUMMY_V1_8822C BIT(4)
#define BIT_POW_PC_LDO_PORT1_8822C BIT(3)
#define BIT_POW_PC_LDO_PORT0_8822C BIT(2)
#define BIT_POW_PLL_V1_8822C BIT(1)
#define BIT_POW_POWER_CUT_POW_LDO_8822C BIT(0)
/* 2 REG_ANAPAR_POW_XTAL_8822C */
#define BIT_POW_XTAL_8822C BIT(1)
#define BIT_POW_BG_8822C BIT(0)
/* 2 REG_ANAPARLDO_MAC_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_REG_STANDBY_L_8822C BIT(19)
#define BIT_PD_REGU_L_8822C BIT(18)
#define BIT_EN_PC_BT_L_8822C BIT(17)
#define BIT_SHIFT_REG_LDOADJ_L_8822C 13
#define BIT_MASK_REG_LDOADJ_L_8822C 0xf
#define BIT_REG_LDOADJ_L_8822C(x) \
(((x) & BIT_MASK_REG_LDOADJ_L_8822C) << BIT_SHIFT_REG_LDOADJ_L_8822C)
#define BITS_REG_LDOADJ_L_8822C \
(BIT_MASK_REG_LDOADJ_L_8822C << BIT_SHIFT_REG_LDOADJ_L_8822C)
#define BIT_CLEAR_REG_LDOADJ_L_8822C(x) ((x) & (~BITS_REG_LDOADJ_L_8822C))
#define BIT_GET_REG_LDOADJ_L_8822C(x) \
(((x) >> BIT_SHIFT_REG_LDOADJ_L_8822C) & BIT_MASK_REG_LDOADJ_L_8822C)
#define BIT_SET_REG_LDOADJ_L_8822C(x, v) \
(BIT_CLEAR_REG_LDOADJ_L_8822C(x) | BIT_REG_LDOADJ_L_8822C(v))
#define BIT_CK12M_EN_8822C BIT(11)
#define BIT_CK12M_SEL_8822C BIT(10)
#define BIT_EN_25_L_8822C BIT(9)
#define BIT_EN_SLEEP_8822C BIT(8)
#define BIT_SHIFT_LDOH12_V12ADJ_L_8822C 4
#define BIT_MASK_LDOH12_V12ADJ_L_8822C 0xf
#define BIT_LDOH12_V12ADJ_L_8822C(x) \
(((x) & BIT_MASK_LDOH12_V12ADJ_L_8822C) \
<< BIT_SHIFT_LDOH12_V12ADJ_L_8822C)
#define BITS_LDOH12_V12ADJ_L_8822C \
(BIT_MASK_LDOH12_V12ADJ_L_8822C << BIT_SHIFT_LDOH12_V12ADJ_L_8822C)
#define BIT_CLEAR_LDOH12_V12ADJ_L_8822C(x) ((x) & (~BITS_LDOH12_V12ADJ_L_8822C))
#define BIT_GET_LDOH12_V12ADJ_L_8822C(x) \
(((x) >> BIT_SHIFT_LDOH12_V12ADJ_L_8822C) & \
BIT_MASK_LDOH12_V12ADJ_L_8822C)
#define BIT_SET_LDOH12_V12ADJ_L_8822C(x, v) \
(BIT_CLEAR_LDOH12_V12ADJ_L_8822C(x) | BIT_LDOH12_V12ADJ_L_8822C(v))
#define BIT_SHIFT_LDOE25_V12ADJ_L_V1_8822C 0
#define BIT_MASK_LDOE25_V12ADJ_L_V1_8822C 0xf
#define BIT_LDOE25_V12ADJ_L_V1_8822C(x) \
(((x) & BIT_MASK_LDOE25_V12ADJ_L_V1_8822C) \
<< BIT_SHIFT_LDOE25_V12ADJ_L_V1_8822C)
#define BITS_LDOE25_V12ADJ_L_V1_8822C \
(BIT_MASK_LDOE25_V12ADJ_L_V1_8822C \
<< BIT_SHIFT_LDOE25_V12ADJ_L_V1_8822C)
#define BIT_CLEAR_LDOE25_V12ADJ_L_V1_8822C(x) \
((x) & (~BITS_LDOE25_V12ADJ_L_V1_8822C))
#define BIT_GET_LDOE25_V12ADJ_L_V1_8822C(x) \
(((x) >> BIT_SHIFT_LDOE25_V12ADJ_L_V1_8822C) & \
BIT_MASK_LDOE25_V12ADJ_L_V1_8822C)
#define BIT_SET_LDOE25_V12ADJ_L_V1_8822C(x, v) \
(BIT_CLEAR_LDOE25_V12ADJ_L_V1_8822C(x) | \
BIT_LDOE25_V12ADJ_L_V1_8822C(v))
/* 2 REG_EFUSE_CTRL_8822C */
#define BIT_EF_FLAG_8822C BIT(31)
#define BIT_SHIFT_EF_PGPD_8822C 28
#define BIT_MASK_EF_PGPD_8822C 0x7
#define BIT_EF_PGPD_8822C(x) \
(((x) & BIT_MASK_EF_PGPD_8822C) << BIT_SHIFT_EF_PGPD_8822C)
#define BITS_EF_PGPD_8822C (BIT_MASK_EF_PGPD_8822C << BIT_SHIFT_EF_PGPD_8822C)
#define BIT_CLEAR_EF_PGPD_8822C(x) ((x) & (~BITS_EF_PGPD_8822C))
#define BIT_GET_EF_PGPD_8822C(x) \
(((x) >> BIT_SHIFT_EF_PGPD_8822C) & BIT_MASK_EF_PGPD_8822C)
#define BIT_SET_EF_PGPD_8822C(x, v) \
(BIT_CLEAR_EF_PGPD_8822C(x) | BIT_EF_PGPD_8822C(v))
#define BIT_SHIFT_EF_RDT_8822C 24
#define BIT_MASK_EF_RDT_8822C 0xf
#define BIT_EF_RDT_8822C(x) \
(((x) & BIT_MASK_EF_RDT_8822C) << BIT_SHIFT_EF_RDT_8822C)
#define BITS_EF_RDT_8822C (BIT_MASK_EF_RDT_8822C << BIT_SHIFT_EF_RDT_8822C)
#define BIT_CLEAR_EF_RDT_8822C(x) ((x) & (~BITS_EF_RDT_8822C))
#define BIT_GET_EF_RDT_8822C(x) \
(((x) >> BIT_SHIFT_EF_RDT_8822C) & BIT_MASK_EF_RDT_8822C)
#define BIT_SET_EF_RDT_8822C(x, v) \
(BIT_CLEAR_EF_RDT_8822C(x) | BIT_EF_RDT_8822C(v))
#define BIT_SHIFT_EF_PGTS_8822C 20
#define BIT_MASK_EF_PGTS_8822C 0xf
#define BIT_EF_PGTS_8822C(x) \
(((x) & BIT_MASK_EF_PGTS_8822C) << BIT_SHIFT_EF_PGTS_8822C)
#define BITS_EF_PGTS_8822C (BIT_MASK_EF_PGTS_8822C << BIT_SHIFT_EF_PGTS_8822C)
#define BIT_CLEAR_EF_PGTS_8822C(x) ((x) & (~BITS_EF_PGTS_8822C))
#define BIT_GET_EF_PGTS_8822C(x) \
(((x) >> BIT_SHIFT_EF_PGTS_8822C) & BIT_MASK_EF_PGTS_8822C)
#define BIT_SET_EF_PGTS_8822C(x, v) \
(BIT_CLEAR_EF_PGTS_8822C(x) | BIT_EF_PGTS_8822C(v))
#define BIT_EF_PDWN_8822C BIT(19)
#define BIT_EF_ALDEN_8822C BIT(18)
#define BIT_SHIFT_EF_ADDR_8822C 8
#define BIT_MASK_EF_ADDR_8822C 0x3ff
#define BIT_EF_ADDR_8822C(x) \
(((x) & BIT_MASK_EF_ADDR_8822C) << BIT_SHIFT_EF_ADDR_8822C)
#define BITS_EF_ADDR_8822C (BIT_MASK_EF_ADDR_8822C << BIT_SHIFT_EF_ADDR_8822C)
#define BIT_CLEAR_EF_ADDR_8822C(x) ((x) & (~BITS_EF_ADDR_8822C))
#define BIT_GET_EF_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_EF_ADDR_8822C) & BIT_MASK_EF_ADDR_8822C)
#define BIT_SET_EF_ADDR_8822C(x, v) \
(BIT_CLEAR_EF_ADDR_8822C(x) | BIT_EF_ADDR_8822C(v))
#define BIT_SHIFT_EF_DATA_8822C 0
#define BIT_MASK_EF_DATA_8822C 0xff
#define BIT_EF_DATA_8822C(x) \
(((x) & BIT_MASK_EF_DATA_8822C) << BIT_SHIFT_EF_DATA_8822C)
#define BITS_EF_DATA_8822C (BIT_MASK_EF_DATA_8822C << BIT_SHIFT_EF_DATA_8822C)
#define BIT_CLEAR_EF_DATA_8822C(x) ((x) & (~BITS_EF_DATA_8822C))
#define BIT_GET_EF_DATA_8822C(x) \
(((x) >> BIT_SHIFT_EF_DATA_8822C) & BIT_MASK_EF_DATA_8822C)
#define BIT_SET_EF_DATA_8822C(x, v) \
(BIT_CLEAR_EF_DATA_8822C(x) | BIT_EF_DATA_8822C(v))
/* 2 REG_LDO_EFUSE_CTRL_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_EF_CRES_SEL_8822C BIT(26)
#define BIT_SHIFT_EF_SCAN_START_V1_8822C 16
#define BIT_MASK_EF_SCAN_START_V1_8822C 0x3ff
#define BIT_EF_SCAN_START_V1_8822C(x) \
(((x) & BIT_MASK_EF_SCAN_START_V1_8822C) \
<< BIT_SHIFT_EF_SCAN_START_V1_8822C)
#define BITS_EF_SCAN_START_V1_8822C \
(BIT_MASK_EF_SCAN_START_V1_8822C << BIT_SHIFT_EF_SCAN_START_V1_8822C)
#define BIT_CLEAR_EF_SCAN_START_V1_8822C(x) \
((x) & (~BITS_EF_SCAN_START_V1_8822C))
#define BIT_GET_EF_SCAN_START_V1_8822C(x) \
(((x) >> BIT_SHIFT_EF_SCAN_START_V1_8822C) & \
BIT_MASK_EF_SCAN_START_V1_8822C)
#define BIT_SET_EF_SCAN_START_V1_8822C(x, v) \
(BIT_CLEAR_EF_SCAN_START_V1_8822C(x) | BIT_EF_SCAN_START_V1_8822C(v))
#define BIT_SHIFT_EF_SCAN_END_8822C 12
#define BIT_MASK_EF_SCAN_END_8822C 0xf
#define BIT_EF_SCAN_END_8822C(x) \
(((x) & BIT_MASK_EF_SCAN_END_8822C) << BIT_SHIFT_EF_SCAN_END_8822C)
#define BITS_EF_SCAN_END_8822C \
(BIT_MASK_EF_SCAN_END_8822C << BIT_SHIFT_EF_SCAN_END_8822C)
#define BIT_CLEAR_EF_SCAN_END_8822C(x) ((x) & (~BITS_EF_SCAN_END_8822C))
#define BIT_GET_EF_SCAN_END_8822C(x) \
(((x) >> BIT_SHIFT_EF_SCAN_END_8822C) & BIT_MASK_EF_SCAN_END_8822C)
#define BIT_SET_EF_SCAN_END_8822C(x, v) \
(BIT_CLEAR_EF_SCAN_END_8822C(x) | BIT_EF_SCAN_END_8822C(v))
#define BIT_EF_PD_DIS_8822C BIT(11)
#define BIT_SHIFT_EF_CELL_SEL_8822C 8
#define BIT_MASK_EF_CELL_SEL_8822C 0x3
#define BIT_EF_CELL_SEL_8822C(x) \
(((x) & BIT_MASK_EF_CELL_SEL_8822C) << BIT_SHIFT_EF_CELL_SEL_8822C)
#define BITS_EF_CELL_SEL_8822C \
(BIT_MASK_EF_CELL_SEL_8822C << BIT_SHIFT_EF_CELL_SEL_8822C)
#define BIT_CLEAR_EF_CELL_SEL_8822C(x) ((x) & (~BITS_EF_CELL_SEL_8822C))
#define BIT_GET_EF_CELL_SEL_8822C(x) \
(((x) >> BIT_SHIFT_EF_CELL_SEL_8822C) & BIT_MASK_EF_CELL_SEL_8822C)
#define BIT_SET_EF_CELL_SEL_8822C(x, v) \
(BIT_CLEAR_EF_CELL_SEL_8822C(x) | BIT_EF_CELL_SEL_8822C(v))
#define BIT_EF_TRPT_8822C BIT(7)
#define BIT_SHIFT_EF_TTHD_8822C 0
#define BIT_MASK_EF_TTHD_8822C 0x7f
#define BIT_EF_TTHD_8822C(x) \
(((x) & BIT_MASK_EF_TTHD_8822C) << BIT_SHIFT_EF_TTHD_8822C)
#define BITS_EF_TTHD_8822C (BIT_MASK_EF_TTHD_8822C << BIT_SHIFT_EF_TTHD_8822C)
#define BIT_CLEAR_EF_TTHD_8822C(x) ((x) & (~BITS_EF_TTHD_8822C))
#define BIT_GET_EF_TTHD_8822C(x) \
(((x) >> BIT_SHIFT_EF_TTHD_8822C) & BIT_MASK_EF_TTHD_8822C)
#define BIT_SET_EF_TTHD_8822C(x, v) \
(BIT_CLEAR_EF_TTHD_8822C(x) | BIT_EF_TTHD_8822C(v))
/* 2 REG_PWR_OPTION_CTRL_8822C */
#define BIT_SHIFT_DBG_SEL_V1_8822C 16
#define BIT_MASK_DBG_SEL_V1_8822C 0xff
#define BIT_DBG_SEL_V1_8822C(x) \
(((x) & BIT_MASK_DBG_SEL_V1_8822C) << BIT_SHIFT_DBG_SEL_V1_8822C)
#define BITS_DBG_SEL_V1_8822C \
(BIT_MASK_DBG_SEL_V1_8822C << BIT_SHIFT_DBG_SEL_V1_8822C)
#define BIT_CLEAR_DBG_SEL_V1_8822C(x) ((x) & (~BITS_DBG_SEL_V1_8822C))
#define BIT_GET_DBG_SEL_V1_8822C(x) \
(((x) >> BIT_SHIFT_DBG_SEL_V1_8822C) & BIT_MASK_DBG_SEL_V1_8822C)
#define BIT_SET_DBG_SEL_V1_8822C(x, v) \
(BIT_CLEAR_DBG_SEL_V1_8822C(x) | BIT_DBG_SEL_V1_8822C(v))
#define BIT_SHIFT_DBG_SEL_BYTE_8822C 14
#define BIT_MASK_DBG_SEL_BYTE_8822C 0x3
#define BIT_DBG_SEL_BYTE_8822C(x) \
(((x) & BIT_MASK_DBG_SEL_BYTE_8822C) << BIT_SHIFT_DBG_SEL_BYTE_8822C)
#define BITS_DBG_SEL_BYTE_8822C \
(BIT_MASK_DBG_SEL_BYTE_8822C << BIT_SHIFT_DBG_SEL_BYTE_8822C)
#define BIT_CLEAR_DBG_SEL_BYTE_8822C(x) ((x) & (~BITS_DBG_SEL_BYTE_8822C))
#define BIT_GET_DBG_SEL_BYTE_8822C(x) \
(((x) >> BIT_SHIFT_DBG_SEL_BYTE_8822C) & BIT_MASK_DBG_SEL_BYTE_8822C)
#define BIT_SET_DBG_SEL_BYTE_8822C(x, v) \
(BIT_CLEAR_DBG_SEL_BYTE_8822C(x) | BIT_DBG_SEL_BYTE_8822C(v))
/* 2 REG_NOT_VALID_8822C */
#define BIT_SYSON_DBG_PAD_E2_8822C BIT(11)
#define BIT_SYSON_LED_PAD_E2_8822C BIT(10)
#define BIT_SYSON_GPEE_PAD_E2_8822C BIT(9)
#define BIT_SYSON_PCI_PAD_E2_8822C BIT(8)
#define BIT_AUTO_SW_LDO_VOL_EN_8822C BIT(7)
#define BIT_SHIFT_SYSON_SPS0WWV_WT_8822C 4
#define BIT_MASK_SYSON_SPS0WWV_WT_8822C 0x3
#define BIT_SYSON_SPS0WWV_WT_8822C(x) \
(((x) & BIT_MASK_SYSON_SPS0WWV_WT_8822C) \
<< BIT_SHIFT_SYSON_SPS0WWV_WT_8822C)
#define BITS_SYSON_SPS0WWV_WT_8822C \
(BIT_MASK_SYSON_SPS0WWV_WT_8822C << BIT_SHIFT_SYSON_SPS0WWV_WT_8822C)
#define BIT_CLEAR_SYSON_SPS0WWV_WT_8822C(x) \
((x) & (~BITS_SYSON_SPS0WWV_WT_8822C))
#define BIT_GET_SYSON_SPS0WWV_WT_8822C(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0WWV_WT_8822C) & \
BIT_MASK_SYSON_SPS0WWV_WT_8822C)
#define BIT_SET_SYSON_SPS0WWV_WT_8822C(x, v) \
(BIT_CLEAR_SYSON_SPS0WWV_WT_8822C(x) | BIT_SYSON_SPS0WWV_WT_8822C(v))
#define BIT_SHIFT_SYSON_SPS0LDO_WT_8822C 2
#define BIT_MASK_SYSON_SPS0LDO_WT_8822C 0x3
#define BIT_SYSON_SPS0LDO_WT_8822C(x) \
(((x) & BIT_MASK_SYSON_SPS0LDO_WT_8822C) \
<< BIT_SHIFT_SYSON_SPS0LDO_WT_8822C)
#define BITS_SYSON_SPS0LDO_WT_8822C \
(BIT_MASK_SYSON_SPS0LDO_WT_8822C << BIT_SHIFT_SYSON_SPS0LDO_WT_8822C)
#define BIT_CLEAR_SYSON_SPS0LDO_WT_8822C(x) \
((x) & (~BITS_SYSON_SPS0LDO_WT_8822C))
#define BIT_GET_SYSON_SPS0LDO_WT_8822C(x) \
(((x) >> BIT_SHIFT_SYSON_SPS0LDO_WT_8822C) & \
BIT_MASK_SYSON_SPS0LDO_WT_8822C)
#define BIT_SET_SYSON_SPS0LDO_WT_8822C(x, v) \
(BIT_CLEAR_SYSON_SPS0LDO_WT_8822C(x) | BIT_SYSON_SPS0LDO_WT_8822C(v))
#define BIT_SHIFT_SYSON_RCLK_SCALE_8822C 0
#define BIT_MASK_SYSON_RCLK_SCALE_8822C 0x3
#define BIT_SYSON_RCLK_SCALE_8822C(x) \
(((x) & BIT_MASK_SYSON_RCLK_SCALE_8822C) \
<< BIT_SHIFT_SYSON_RCLK_SCALE_8822C)
#define BITS_SYSON_RCLK_SCALE_8822C \
(BIT_MASK_SYSON_RCLK_SCALE_8822C << BIT_SHIFT_SYSON_RCLK_SCALE_8822C)
#define BIT_CLEAR_SYSON_RCLK_SCALE_8822C(x) \
((x) & (~BITS_SYSON_RCLK_SCALE_8822C))
#define BIT_GET_SYSON_RCLK_SCALE_8822C(x) \
(((x) >> BIT_SHIFT_SYSON_RCLK_SCALE_8822C) & \
BIT_MASK_SYSON_RCLK_SCALE_8822C)
#define BIT_SET_SYSON_RCLK_SCALE_8822C(x, v) \
(BIT_CLEAR_SYSON_RCLK_SCALE_8822C(x) | BIT_SYSON_RCLK_SCALE_8822C(v))
/* 2 REG_CAL_TIMER_8822C */
#define BIT_SHIFT_MATCH_CNT_8822C 8
#define BIT_MASK_MATCH_CNT_8822C 0xff
#define BIT_MATCH_CNT_8822C(x) \
(((x) & BIT_MASK_MATCH_CNT_8822C) << BIT_SHIFT_MATCH_CNT_8822C)
#define BITS_MATCH_CNT_8822C \
(BIT_MASK_MATCH_CNT_8822C << BIT_SHIFT_MATCH_CNT_8822C)
#define BIT_CLEAR_MATCH_CNT_8822C(x) ((x) & (~BITS_MATCH_CNT_8822C))
#define BIT_GET_MATCH_CNT_8822C(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8822C) & BIT_MASK_MATCH_CNT_8822C)
#define BIT_SET_MATCH_CNT_8822C(x, v) \
(BIT_CLEAR_MATCH_CNT_8822C(x) | BIT_MATCH_CNT_8822C(v))
#define BIT_SHIFT_CAL_SCAL_8822C 0
#define BIT_MASK_CAL_SCAL_8822C 0xff
#define BIT_CAL_SCAL_8822C(x) \
(((x) & BIT_MASK_CAL_SCAL_8822C) << BIT_SHIFT_CAL_SCAL_8822C)
#define BITS_CAL_SCAL_8822C \
(BIT_MASK_CAL_SCAL_8822C << BIT_SHIFT_CAL_SCAL_8822C)
#define BIT_CLEAR_CAL_SCAL_8822C(x) ((x) & (~BITS_CAL_SCAL_8822C))
#define BIT_GET_CAL_SCAL_8822C(x) \
(((x) >> BIT_SHIFT_CAL_SCAL_8822C) & BIT_MASK_CAL_SCAL_8822C)
#define BIT_SET_CAL_SCAL_8822C(x, v) \
(BIT_CLEAR_CAL_SCAL_8822C(x) | BIT_CAL_SCAL_8822C(v))
/* 2 REG_ACLK_MON_8822C */
#define BIT_SHIFT_RCLK_MON_8822C 5
#define BIT_MASK_RCLK_MON_8822C 0x7ff
#define BIT_RCLK_MON_8822C(x) \
(((x) & BIT_MASK_RCLK_MON_8822C) << BIT_SHIFT_RCLK_MON_8822C)
#define BITS_RCLK_MON_8822C \
(BIT_MASK_RCLK_MON_8822C << BIT_SHIFT_RCLK_MON_8822C)
#define BIT_CLEAR_RCLK_MON_8822C(x) ((x) & (~BITS_RCLK_MON_8822C))
#define BIT_GET_RCLK_MON_8822C(x) \
(((x) >> BIT_SHIFT_RCLK_MON_8822C) & BIT_MASK_RCLK_MON_8822C)
#define BIT_SET_RCLK_MON_8822C(x, v) \
(BIT_CLEAR_RCLK_MON_8822C(x) | BIT_RCLK_MON_8822C(v))
#define BIT_CAL_EN_8822C BIT(4)
#define BIT_SHIFT_DPSTU_8822C 2
#define BIT_MASK_DPSTU_8822C 0x3
#define BIT_DPSTU_8822C(x) \
(((x) & BIT_MASK_DPSTU_8822C) << BIT_SHIFT_DPSTU_8822C)
#define BITS_DPSTU_8822C (BIT_MASK_DPSTU_8822C << BIT_SHIFT_DPSTU_8822C)
#define BIT_CLEAR_DPSTU_8822C(x) ((x) & (~BITS_DPSTU_8822C))
#define BIT_GET_DPSTU_8822C(x) \
(((x) >> BIT_SHIFT_DPSTU_8822C) & BIT_MASK_DPSTU_8822C)
#define BIT_SET_DPSTU_8822C(x, v) \
(BIT_CLEAR_DPSTU_8822C(x) | BIT_DPSTU_8822C(v))
#define BIT_SUS_16X_8822C BIT(1)
/* 2 REG_GPIO_MUXCFG_2_8822C */
#define BIT_SOUT_GPIO8_8822C BIT(7)
#define BIT_SOUT_GPIO5_8822C BIT(6)
#define BIT_RFE_CTRL_5_GPIO14_V1_8822C BIT(5)
#define BIT_RFE_CTRL_10_GPIO13_V1_8822C BIT(4)
#define BIT_RFE_CTRL_11_GPIO4_V1_8822C BIT(3)
#define BIT_RFE_CTRL_5_GPIO14_8822C BIT(2)
#define BIT_RFE_CTRL_10_GPIO13_8822C BIT(1)
#define BIT_RFE_CTRL_11_GPIO4_8822C BIT(0)
/* 2 REG_GPIO_MUXCFG_8822C */
#define BIT_RFE_CTRL_3_GPIO12_8822C BIT(31)
#define BIT_BT_RFE_CTRL_5_GPIO12_8822C BIT(30)
#define BIT_S0_TRSW_GPIO12_8822C BIT(29)
#define BIT_RFE_CTRL_9_GPIO13_8822C BIT(28)
#define BIT_RFE_CTRL_9_GPIO12_8822C BIT(27)
#define BIT_RFE_CTRL_8_GPIO4_8822C BIT(26)
#define BIT_BT_RFE_CTRL_1_GPIO13_8822C BIT(25)
#define BIT_BT_RFE_CTRL_1_GPIO12_8822C BIT(24)
#define BIT_BT_RFE_CTRL_0_GPIO4_8822C BIT(23)
#define BIT_ANTSW_GPIO13_8822C BIT(22)
#define BIT_ANTSW_GPIO12_8822C BIT(21)
#define BIT_ANTSWB_GPIO4_8822C BIT(20)
#define BIT_FSPI_EN_8822C BIT(19)
#define BIT_WL_RTS_EXT_32K_SEL_8822C BIT(18)
#define BIT_WLBT_DPDT_SEL_EN_8822C BIT(17)
#define BIT_WLBT_LNAON_SEL_EN_8822C BIT(16)
#define BIT_SIC_LBK_8822C BIT(15)
#define BIT_ENHTP_8822C BIT(14)
#define BIT_BT_AOD_GPIO3_8822C BIT(13)
#define BIT_ENSIC_8822C BIT(12)
#define BIT_SIC_SWRST_8822C BIT(11)
#define BIT_PO_WIFI_PTA_PINS_8822C BIT(10)
#define BIT_PO_BT_PTA_PINS_8822C BIT(9)
#define BIT_ENUART_8822C BIT(8)
#define BIT_SHIFT_BTMODE_8822C 6
#define BIT_MASK_BTMODE_8822C 0x3
#define BIT_BTMODE_8822C(x) \
(((x) & BIT_MASK_BTMODE_8822C) << BIT_SHIFT_BTMODE_8822C)
#define BITS_BTMODE_8822C (BIT_MASK_BTMODE_8822C << BIT_SHIFT_BTMODE_8822C)
#define BIT_CLEAR_BTMODE_8822C(x) ((x) & (~BITS_BTMODE_8822C))
#define BIT_GET_BTMODE_8822C(x) \
(((x) >> BIT_SHIFT_BTMODE_8822C) & BIT_MASK_BTMODE_8822C)
#define BIT_SET_BTMODE_8822C(x, v) \
(BIT_CLEAR_BTMODE_8822C(x) | BIT_BTMODE_8822C(v))
#define BIT_ENBT_8822C BIT(5)
#define BIT_EROM_EN_8822C BIT(4)
#define BIT_WLRFE_6_7_EN_8822C BIT(3)
#define BIT_WLRFE_4_5_EN_8822C BIT(2)
#define BIT_SHIFT_GPIOSEL_8822C 0
#define BIT_MASK_GPIOSEL_8822C 0x3
#define BIT_GPIOSEL_8822C(x) \
(((x) & BIT_MASK_GPIOSEL_8822C) << BIT_SHIFT_GPIOSEL_8822C)
#define BITS_GPIOSEL_8822C (BIT_MASK_GPIOSEL_8822C << BIT_SHIFT_GPIOSEL_8822C)
#define BIT_CLEAR_GPIOSEL_8822C(x) ((x) & (~BITS_GPIOSEL_8822C))
#define BIT_GET_GPIOSEL_8822C(x) \
(((x) >> BIT_SHIFT_GPIOSEL_8822C) & BIT_MASK_GPIOSEL_8822C)
#define BIT_SET_GPIOSEL_8822C(x, v) \
(BIT_CLEAR_GPIOSEL_8822C(x) | BIT_GPIOSEL_8822C(v))
/* 2 REG_GPIO_PIN_CTRL_8822C */
#define BIT_SHIFT_GPIO_MOD_7_TO_0_8822C 24
#define BIT_MASK_GPIO_MOD_7_TO_0_8822C 0xff
#define BIT_GPIO_MOD_7_TO_0_8822C(x) \
(((x) & BIT_MASK_GPIO_MOD_7_TO_0_8822C) \
<< BIT_SHIFT_GPIO_MOD_7_TO_0_8822C)
#define BITS_GPIO_MOD_7_TO_0_8822C \
(BIT_MASK_GPIO_MOD_7_TO_0_8822C << BIT_SHIFT_GPIO_MOD_7_TO_0_8822C)
#define BIT_CLEAR_GPIO_MOD_7_TO_0_8822C(x) ((x) & (~BITS_GPIO_MOD_7_TO_0_8822C))
#define BIT_GET_GPIO_MOD_7_TO_0_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_7_TO_0_8822C) & \
BIT_MASK_GPIO_MOD_7_TO_0_8822C)
#define BIT_SET_GPIO_MOD_7_TO_0_8822C(x, v) \
(BIT_CLEAR_GPIO_MOD_7_TO_0_8822C(x) | BIT_GPIO_MOD_7_TO_0_8822C(v))
#define BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822C 16
#define BIT_MASK_GPIO_IO_SEL_7_TO_0_8822C 0xff
#define BIT_GPIO_IO_SEL_7_TO_0_8822C(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_7_TO_0_8822C) \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822C)
#define BITS_GPIO_IO_SEL_7_TO_0_8822C \
(BIT_MASK_GPIO_IO_SEL_7_TO_0_8822C \
<< BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822C)
#define BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8822C(x) \
((x) & (~BITS_GPIO_IO_SEL_7_TO_0_8822C))
#define BIT_GET_GPIO_IO_SEL_7_TO_0_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_7_TO_0_8822C) & \
BIT_MASK_GPIO_IO_SEL_7_TO_0_8822C)
#define BIT_SET_GPIO_IO_SEL_7_TO_0_8822C(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_7_TO_0_8822C(x) | \
BIT_GPIO_IO_SEL_7_TO_0_8822C(v))
#define BIT_SHIFT_GPIO_OUT_7_TO_0_8822C 8
#define BIT_MASK_GPIO_OUT_7_TO_0_8822C 0xff
#define BIT_GPIO_OUT_7_TO_0_8822C(x) \
(((x) & BIT_MASK_GPIO_OUT_7_TO_0_8822C) \
<< BIT_SHIFT_GPIO_OUT_7_TO_0_8822C)
#define BITS_GPIO_OUT_7_TO_0_8822C \
(BIT_MASK_GPIO_OUT_7_TO_0_8822C << BIT_SHIFT_GPIO_OUT_7_TO_0_8822C)
#define BIT_CLEAR_GPIO_OUT_7_TO_0_8822C(x) ((x) & (~BITS_GPIO_OUT_7_TO_0_8822C))
#define BIT_GET_GPIO_OUT_7_TO_0_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_7_TO_0_8822C) & \
BIT_MASK_GPIO_OUT_7_TO_0_8822C)
#define BIT_SET_GPIO_OUT_7_TO_0_8822C(x, v) \
(BIT_CLEAR_GPIO_OUT_7_TO_0_8822C(x) | BIT_GPIO_OUT_7_TO_0_8822C(v))
#define BIT_SHIFT_GPIO_IN_7_TO_0_8822C 0
#define BIT_MASK_GPIO_IN_7_TO_0_8822C 0xff
#define BIT_GPIO_IN_7_TO_0_8822C(x) \
(((x) & BIT_MASK_GPIO_IN_7_TO_0_8822C) \
<< BIT_SHIFT_GPIO_IN_7_TO_0_8822C)
#define BITS_GPIO_IN_7_TO_0_8822C \
(BIT_MASK_GPIO_IN_7_TO_0_8822C << BIT_SHIFT_GPIO_IN_7_TO_0_8822C)
#define BIT_CLEAR_GPIO_IN_7_TO_0_8822C(x) ((x) & (~BITS_GPIO_IN_7_TO_0_8822C))
#define BIT_GET_GPIO_IN_7_TO_0_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_IN_7_TO_0_8822C) & \
BIT_MASK_GPIO_IN_7_TO_0_8822C)
#define BIT_SET_GPIO_IN_7_TO_0_8822C(x, v) \
(BIT_CLEAR_GPIO_IN_7_TO_0_8822C(x) | BIT_GPIO_IN_7_TO_0_8822C(v))
/* 2 REG_GPIO_INTM_8822C */
#define BIT_SHIFT_MUXDBG_SEL_8822C 30
#define BIT_MASK_MUXDBG_SEL_8822C 0x3
#define BIT_MUXDBG_SEL_8822C(x) \
(((x) & BIT_MASK_MUXDBG_SEL_8822C) << BIT_SHIFT_MUXDBG_SEL_8822C)
#define BITS_MUXDBG_SEL_8822C \
(BIT_MASK_MUXDBG_SEL_8822C << BIT_SHIFT_MUXDBG_SEL_8822C)
#define BIT_CLEAR_MUXDBG_SEL_8822C(x) ((x) & (~BITS_MUXDBG_SEL_8822C))
#define BIT_GET_MUXDBG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_MUXDBG_SEL_8822C) & BIT_MASK_MUXDBG_SEL_8822C)
#define BIT_SET_MUXDBG_SEL_8822C(x, v) \
(BIT_CLEAR_MUXDBG_SEL_8822C(x) | BIT_MUXDBG_SEL_8822C(v))
#define BIT_EXTWOL_SEL_8822C BIT(17)
#define BIT_EXTWOL_EN_8822C BIT(16)
#define BIT_GPIOF_INT_MD_8822C BIT(15)
#define BIT_GPIOE_INT_MD_8822C BIT(14)
#define BIT_GPIOD_INT_MD_8822C BIT(13)
#define BIT_GPIOF_INT_MD_8822C BIT(15)
#define BIT_GPIOE_INT_MD_8822C BIT(14)
#define BIT_GPIOD_INT_MD_8822C BIT(13)
#define BIT_GPIOC_INT_MD_8822C BIT(12)
#define BIT_GPIOB_INT_MD_8822C BIT(11)
#define BIT_GPIOA_INT_MD_8822C BIT(10)
#define BIT_GPIO9_INT_MD_8822C BIT(9)
#define BIT_GPIO8_INT_MD_8822C BIT(8)
#define BIT_GPIO7_INT_MD_8822C BIT(7)
#define BIT_GPIO6_INT_MD_8822C BIT(6)
#define BIT_GPIO5_INT_MD_8822C BIT(5)
#define BIT_GPIO4_INT_MD_8822C BIT(4)
#define BIT_GPIO3_INT_MD_8822C BIT(3)
#define BIT_GPIO2_INT_MD_8822C BIT(2)
#define BIT_GPIO1_INT_MD_8822C BIT(1)
#define BIT_GPIO0_INT_MD_8822C BIT(0)
/* 2 REG_LED_CFG_8822C */
#define BIT_MAILBOX_1WIRE_GPIO_CFG_8822C BIT(31)
#define BIT_BT_RF_GPIO_CFG_8822C BIT(30)
#define BIT_BT_SDIO_INT_GPIO_CFG_8822C BIT(29)
#define BIT_MAILBOX_3WIRE_GPIO_CFG_8822C BIT(28)
#define BIT_WLBT_PAPE_SEL_EN_8822C BIT(27)
#define BIT_LNAON_SEL_EN_8822C BIT(26)
#define BIT_PAPE_SEL_EN_8822C BIT(25)
#define BIT_DPDT_WLBT_SEL_8822C BIT(24)
#define BIT_DPDT_SEL_EN_8822C BIT(23)
#define BIT_GPIO13_14_WL_CTRL_EN_8822C BIT(22)
#define BIT_LED2DIS_8822C BIT(21)
#define BIT_LED2PL_8822C BIT(20)
#define BIT_LED2SV_8822C BIT(19)
#define BIT_SHIFT_LED2CM_8822C 16
#define BIT_MASK_LED2CM_8822C 0x7
#define BIT_LED2CM_8822C(x) \
(((x) & BIT_MASK_LED2CM_8822C) << BIT_SHIFT_LED2CM_8822C)
#define BITS_LED2CM_8822C (BIT_MASK_LED2CM_8822C << BIT_SHIFT_LED2CM_8822C)
#define BIT_CLEAR_LED2CM_8822C(x) ((x) & (~BITS_LED2CM_8822C))
#define BIT_GET_LED2CM_8822C(x) \
(((x) >> BIT_SHIFT_LED2CM_8822C) & BIT_MASK_LED2CM_8822C)
#define BIT_SET_LED2CM_8822C(x, v) \
(BIT_CLEAR_LED2CM_8822C(x) | BIT_LED2CM_8822C(v))
#define BIT_LED1DIS_8822C BIT(15)
#define BIT_LED1PL_8822C BIT(12)
#define BIT_LED1SV_8822C BIT(11)
#define BIT_SHIFT_LED1CM_8822C 8
#define BIT_MASK_LED1CM_8822C 0x7
#define BIT_LED1CM_8822C(x) \
(((x) & BIT_MASK_LED1CM_8822C) << BIT_SHIFT_LED1CM_8822C)
#define BITS_LED1CM_8822C (BIT_MASK_LED1CM_8822C << BIT_SHIFT_LED1CM_8822C)
#define BIT_CLEAR_LED1CM_8822C(x) ((x) & (~BITS_LED1CM_8822C))
#define BIT_GET_LED1CM_8822C(x) \
(((x) >> BIT_SHIFT_LED1CM_8822C) & BIT_MASK_LED1CM_8822C)
#define BIT_SET_LED1CM_8822C(x, v) \
(BIT_CLEAR_LED1CM_8822C(x) | BIT_LED1CM_8822C(v))
#define BIT_LED0DIS_8822C BIT(7)
#define BIT_SHIFT_AFE_LDO_SWR_CHECK_8822C 5
#define BIT_MASK_AFE_LDO_SWR_CHECK_8822C 0x3
#define BIT_AFE_LDO_SWR_CHECK_8822C(x) \
(((x) & BIT_MASK_AFE_LDO_SWR_CHECK_8822C) \
<< BIT_SHIFT_AFE_LDO_SWR_CHECK_8822C)
#define BITS_AFE_LDO_SWR_CHECK_8822C \
(BIT_MASK_AFE_LDO_SWR_CHECK_8822C << BIT_SHIFT_AFE_LDO_SWR_CHECK_8822C)
#define BIT_CLEAR_AFE_LDO_SWR_CHECK_8822C(x) \
((x) & (~BITS_AFE_LDO_SWR_CHECK_8822C))
#define BIT_GET_AFE_LDO_SWR_CHECK_8822C(x) \
(((x) >> BIT_SHIFT_AFE_LDO_SWR_CHECK_8822C) & \
BIT_MASK_AFE_LDO_SWR_CHECK_8822C)
#define BIT_SET_AFE_LDO_SWR_CHECK_8822C(x, v) \
(BIT_CLEAR_AFE_LDO_SWR_CHECK_8822C(x) | BIT_AFE_LDO_SWR_CHECK_8822C(v))
#define BIT_LED0PL_8822C BIT(4)
#define BIT_LED0SV_8822C BIT(3)
#define BIT_SHIFT_LED0CM_8822C 0
#define BIT_MASK_LED0CM_8822C 0x7
#define BIT_LED0CM_8822C(x) \
(((x) & BIT_MASK_LED0CM_8822C) << BIT_SHIFT_LED0CM_8822C)
#define BITS_LED0CM_8822C (BIT_MASK_LED0CM_8822C << BIT_SHIFT_LED0CM_8822C)
#define BIT_CLEAR_LED0CM_8822C(x) ((x) & (~BITS_LED0CM_8822C))
#define BIT_GET_LED0CM_8822C(x) \
(((x) >> BIT_SHIFT_LED0CM_8822C) & BIT_MASK_LED0CM_8822C)
#define BIT_SET_LED0CM_8822C(x, v) \
(BIT_CLEAR_LED0CM_8822C(x) | BIT_LED0CM_8822C(v))
/* 2 REG_FSIMR_8822C */
#define BIT_FS_PDNINT_EN_8822C BIT(31)
#define BIT_FS_SPS_OCP_INT_EN_8822C BIT(29)
#define BIT_FS_PWMERR_INT_EN_8822C BIT(28)
#define BIT_FS_GPIOF_INT_EN_8822C BIT(27)
#define BIT_FS_GPIOE_INT_EN_8822C BIT(26)
#define BIT_FS_GPIOD_INT_EN_8822C BIT(25)
#define BIT_FS_GPIOC_INT_EN_8822C BIT(24)
#define BIT_FS_GPIOB_INT_EN_8822C BIT(23)
#define BIT_FS_GPIOA_INT_EN_8822C BIT(22)
#define BIT_FS_GPIO9_INT_EN_8822C BIT(21)
#define BIT_FS_GPIO8_INT_EN_8822C BIT(20)
#define BIT_FS_GPIO7_INT_EN_8822C BIT(19)
#define BIT_FS_GPIO6_INT_EN_8822C BIT(18)
#define BIT_FS_GPIO5_INT_EN_8822C BIT(17)
#define BIT_FS_GPIO4_INT_EN_8822C BIT(16)
#define BIT_FS_GPIO3_INT_EN_8822C BIT(15)
#define BIT_FS_GPIO2_INT_EN_8822C BIT(14)
#define BIT_FS_GPIO1_INT_EN_8822C BIT(13)
#define BIT_FS_GPIO0_INT_EN_8822C BIT(12)
#define BIT_FS_HCI_SUS_EN_8822C BIT(11)
#define BIT_FS_HCI_RES_EN_8822C BIT(10)
#define BIT_FS_HCI_RESET_EN_8822C BIT(9)
#define BIT_USB_SCSI_CMD_EN_8822C BIT(8)
#define BIT_FS_BTON_STS_UPDATE_MSK_EN_8822C BIT(7)
#define BIT_ACT2RECOVERY_INT_EN_V1_8822C BIT(6)
#define BIT_GEN1GEN2_SWITCH_8822C BIT(5)
#define BIT_HCI_TXDMA_REQ_HIMR_8822C BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_MAK_8822C BIT(3)
#define BIT_FS_32K_ENTER_SETTING_MAK_8822C BIT(2)
#define BIT_FS_USB_LPMRSM_MSK_8822C BIT(1)
#define BIT_FS_USB_LPMINT_MSK_8822C BIT(0)
/* 2 REG_FSISR_8822C */
#define BIT_FS_PDNINT_8822C BIT(31)
#define BIT_FS_SPS_OCP_INT_8822C BIT(29)
#define BIT_FS_PWMERR_INT_8822C BIT(28)
#define BIT_FS_GPIOF_INT_8822C BIT(27)
#define BIT_FS_GPIOE_INT_8822C BIT(26)
#define BIT_FS_GPIOD_INT_8822C BIT(25)
#define BIT_FS_GPIOC_INT_8822C BIT(24)
#define BIT_FS_GPIOB_INT_8822C BIT(23)
#define BIT_FS_GPIOA_INT_8822C BIT(22)
#define BIT_FS_GPIO9_INT_8822C BIT(21)
#define BIT_FS_GPIO8_INT_8822C BIT(20)
#define BIT_FS_GPIO7_INT_8822C BIT(19)
#define BIT_FS_GPIO6_INT_8822C BIT(18)
#define BIT_FS_GPIO5_INT_8822C BIT(17)
#define BIT_FS_GPIO4_INT_8822C BIT(16)
#define BIT_FS_GPIO3_INT_8822C BIT(15)
#define BIT_FS_GPIO2_INT_8822C BIT(14)
#define BIT_FS_GPIO1_INT_8822C BIT(13)
#define BIT_FS_GPIO0_INT_8822C BIT(12)
#define BIT_FS_HCI_SUS_INT_8822C BIT(11)
#define BIT_FS_HCI_RES_INT_8822C BIT(10)
#define BIT_FS_HCI_RESET_INT_8822C BIT(9)
#define BIT_USB_SCSI_CMD_INT_8822C BIT(8)
#define BIT_ACT2RECOVERY_8822C BIT(6)
#define BIT_GEN1GEN2_SWITCH_8822C BIT(5)
#define BIT_HCI_TXDMA_REQ_HISR_8822C BIT(4)
#define BIT_FS_32K_LEAVE_SETTING_INT_8822C BIT(3)
#define BIT_FS_32K_ENTER_SETTING_INT_8822C BIT(2)
#define BIT_FS_USB_LPMRSM_INT_8822C BIT(1)
#define BIT_FS_USB_LPMINT_INT_8822C BIT(0)
/* 2 REG_HSIMR_8822C */
#define BIT_GPIOF_INT_EN_8822C BIT(31)
#define BIT_GPIOE_INT_EN_8822C BIT(30)
#define BIT_GPIOD_INT_EN_8822C BIT(29)
#define BIT_GPIOC_INT_EN_8822C BIT(28)
#define BIT_GPIOB_INT_EN_8822C BIT(27)
#define BIT_GPIOA_INT_EN_8822C BIT(26)
#define BIT_GPIO9_INT_EN_8822C BIT(25)
#define BIT_GPIO8_INT_EN_8822C BIT(24)
#define BIT_GPIO7_INT_EN_8822C BIT(23)
#define BIT_GPIO6_INT_EN_8822C BIT(22)
#define BIT_GPIO5_INT_EN_8822C BIT(21)
#define BIT_GPIO4_INT_EN_8822C BIT(20)
#define BIT_GPIO3_INT_EN_8822C BIT(19)
#define BIT_GPIO2_INT_EN_V1_8822C BIT(18)
#define BIT_GPIO1_INT_EN_8822C BIT(17)
#define BIT_GPIO0_INT_EN_8822C BIT(16)
#define BIT_PDNINT_EN_8822C BIT(7)
#define BIT_RON_INT_EN_8822C BIT(6)
#define BIT_SPS_OCP_INT_EN_8822C BIT(5)
#define BIT_GPIO15_0_INT_EN_8822C BIT(0)
/* 2 REG_HSISR_8822C */
#define BIT_GPIOF_INT_8822C BIT(31)
#define BIT_GPIOE_INT_8822C BIT(30)
#define BIT_GPIOD_INT_8822C BIT(29)
#define BIT_GPIOC_INT_8822C BIT(28)
#define BIT_GPIOB_INT_8822C BIT(27)
#define BIT_GPIOA_INT_8822C BIT(26)
#define BIT_GPIO9_INT_8822C BIT(25)
#define BIT_GPIO8_INT_8822C BIT(24)
#define BIT_GPIO7_INT_8822C BIT(23)
#define BIT_GPIO6_INT_8822C BIT(22)
#define BIT_GPIO5_INT_8822C BIT(21)
#define BIT_GPIO4_INT_8822C BIT(20)
#define BIT_GPIO3_INT_8822C BIT(19)
#define BIT_GPIO2_INT_V1_8822C BIT(18)
#define BIT_GPIO1_INT_8822C BIT(17)
#define BIT_GPIO0_INT_8822C BIT(16)
#define BIT_PDNINT_8822C BIT(7)
#define BIT_RON_INT_8822C BIT(6)
#define BIT_SPS_OCP_INT_8822C BIT(5)
#define BIT_GPIO15_0_INT_8822C BIT(0)
/* 2 REG_GPIO_EXT_CTRL_8822C */
#define BIT_SHIFT_GPIO_MOD_15_TO_8_8822C 24
#define BIT_MASK_GPIO_MOD_15_TO_8_8822C 0xff
#define BIT_GPIO_MOD_15_TO_8_8822C(x) \
(((x) & BIT_MASK_GPIO_MOD_15_TO_8_8822C) \
<< BIT_SHIFT_GPIO_MOD_15_TO_8_8822C)
#define BITS_GPIO_MOD_15_TO_8_8822C \
(BIT_MASK_GPIO_MOD_15_TO_8_8822C << BIT_SHIFT_GPIO_MOD_15_TO_8_8822C)
#define BIT_CLEAR_GPIO_MOD_15_TO_8_8822C(x) \
((x) & (~BITS_GPIO_MOD_15_TO_8_8822C))
#define BIT_GET_GPIO_MOD_15_TO_8_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_MOD_15_TO_8_8822C) & \
BIT_MASK_GPIO_MOD_15_TO_8_8822C)
#define BIT_SET_GPIO_MOD_15_TO_8_8822C(x, v) \
(BIT_CLEAR_GPIO_MOD_15_TO_8_8822C(x) | BIT_GPIO_MOD_15_TO_8_8822C(v))
#define BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822C 16
#define BIT_MASK_GPIO_IO_SEL_15_TO_8_8822C 0xff
#define BIT_GPIO_IO_SEL_15_TO_8_8822C(x) \
(((x) & BIT_MASK_GPIO_IO_SEL_15_TO_8_8822C) \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822C)
#define BITS_GPIO_IO_SEL_15_TO_8_8822C \
(BIT_MASK_GPIO_IO_SEL_15_TO_8_8822C \
<< BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822C)
#define BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8822C(x) \
((x) & (~BITS_GPIO_IO_SEL_15_TO_8_8822C))
#define BIT_GET_GPIO_IO_SEL_15_TO_8_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_IO_SEL_15_TO_8_8822C) & \
BIT_MASK_GPIO_IO_SEL_15_TO_8_8822C)
#define BIT_SET_GPIO_IO_SEL_15_TO_8_8822C(x, v) \
(BIT_CLEAR_GPIO_IO_SEL_15_TO_8_8822C(x) | \
BIT_GPIO_IO_SEL_15_TO_8_8822C(v))
#define BIT_SHIFT_GPIO_OUT_15_TO_8_8822C 8
#define BIT_MASK_GPIO_OUT_15_TO_8_8822C 0xff
#define BIT_GPIO_OUT_15_TO_8_8822C(x) \
(((x) & BIT_MASK_GPIO_OUT_15_TO_8_8822C) \
<< BIT_SHIFT_GPIO_OUT_15_TO_8_8822C)
#define BITS_GPIO_OUT_15_TO_8_8822C \
(BIT_MASK_GPIO_OUT_15_TO_8_8822C << BIT_SHIFT_GPIO_OUT_15_TO_8_8822C)
#define BIT_CLEAR_GPIO_OUT_15_TO_8_8822C(x) \
((x) & (~BITS_GPIO_OUT_15_TO_8_8822C))
#define BIT_GET_GPIO_OUT_15_TO_8_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_OUT_15_TO_8_8822C) & \
BIT_MASK_GPIO_OUT_15_TO_8_8822C)
#define BIT_SET_GPIO_OUT_15_TO_8_8822C(x, v) \
(BIT_CLEAR_GPIO_OUT_15_TO_8_8822C(x) | BIT_GPIO_OUT_15_TO_8_8822C(v))
#define BIT_SHIFT_GPIO_IN_15_TO_8_8822C 0
#define BIT_MASK_GPIO_IN_15_TO_8_8822C 0xff
#define BIT_GPIO_IN_15_TO_8_8822C(x) \
(((x) & BIT_MASK_GPIO_IN_15_TO_8_8822C) \
<< BIT_SHIFT_GPIO_IN_15_TO_8_8822C)
#define BITS_GPIO_IN_15_TO_8_8822C \
(BIT_MASK_GPIO_IN_15_TO_8_8822C << BIT_SHIFT_GPIO_IN_15_TO_8_8822C)
#define BIT_CLEAR_GPIO_IN_15_TO_8_8822C(x) ((x) & (~BITS_GPIO_IN_15_TO_8_8822C))
#define BIT_GET_GPIO_IN_15_TO_8_8822C(x) \
(((x) >> BIT_SHIFT_GPIO_IN_15_TO_8_8822C) & \
BIT_MASK_GPIO_IN_15_TO_8_8822C)
#define BIT_SET_GPIO_IN_15_TO_8_8822C(x, v) \
(BIT_CLEAR_GPIO_IN_15_TO_8_8822C(x) | BIT_GPIO_IN_15_TO_8_8822C(v))
/* 2 REG_PAD_CTRL1_8822C */
#define BIT_PAPE_WLBT_SEL_8822C BIT(29)
#define BIT_LNAON_WLBT_SEL_8822C BIT(28)
#define BIT_BT_BQB_GPIO_SEL_8822C BIT(27)
#define BIT_BTGP_GPG3_FEN_8822C BIT(26)
#define BIT_BTGP_GPG2_FEN_8822C BIT(25)
#define BIT_BTGP_JTAG_EN_8822C BIT(24)
#define BIT_XTAL_CLK_EXTARNAL_EN_8822C BIT(23)
#define BIT_BTGP_UART0_EN_8822C BIT(22)
#define BIT_BTGP_UART1_EN_8822C BIT(21)
#define BIT_BTGP_SPI_EN_8822C BIT(20)
#define BIT_BTGP_GPIO_E2_8822C BIT(19)
#define BIT_BTGP_GPIO_EN_8822C BIT(18)
#define BIT_SHIFT_BTGP_GPIO_SL_8822C 16
#define BIT_MASK_BTGP_GPIO_SL_8822C 0x3
#define BIT_BTGP_GPIO_SL_8822C(x) \
(((x) & BIT_MASK_BTGP_GPIO_SL_8822C) << BIT_SHIFT_BTGP_GPIO_SL_8822C)
#define BITS_BTGP_GPIO_SL_8822C \
(BIT_MASK_BTGP_GPIO_SL_8822C << BIT_SHIFT_BTGP_GPIO_SL_8822C)
#define BIT_CLEAR_BTGP_GPIO_SL_8822C(x) ((x) & (~BITS_BTGP_GPIO_SL_8822C))
#define BIT_GET_BTGP_GPIO_SL_8822C(x) \
(((x) >> BIT_SHIFT_BTGP_GPIO_SL_8822C) & BIT_MASK_BTGP_GPIO_SL_8822C)
#define BIT_SET_BTGP_GPIO_SL_8822C(x, v) \
(BIT_CLEAR_BTGP_GPIO_SL_8822C(x) | BIT_BTGP_GPIO_SL_8822C(v))
#define BIT_PAD_SDIO_SR_8822C BIT(14)
#define BIT_GPIO14_OUTPUT_PL_8822C BIT(13)
#define BIT_HOST_WAKE_PAD_PULL_EN_8822C BIT(12)
#define BIT_HOST_WAKE_PAD_SL_8822C BIT(11)
#define BIT_PAD_LNAON_SR_8822C BIT(10)
#define BIT_PAD_LNAON_E2_8822C BIT(9)
#define BIT_SW_LNAON_G_SEL_DATA_8822C BIT(8)
#define BIT_SW_LNAON_A_SEL_DATA_8822C BIT(7)
#define BIT_PAD_PAPE_SR_8822C BIT(6)
#define BIT_PAD_PAPE_E2_8822C BIT(5)
#define BIT_SW_PAPE_G_SEL_DATA_8822C BIT(4)
#define BIT_SW_PAPE_A_SEL_DATA_8822C BIT(3)
#define BIT_PAD_DPDT_SR_8822C BIT(2)
#define BIT_PAD_DPDT_PAD_E2_8822C BIT(1)
#define BIT_SW_DPDT_SEL_DATA_8822C BIT(0)
/* 2 REG_WL_BT_PWR_CTRL_8822C */
#define BIT_ISO_BD2PP_8822C BIT(31)
#define BIT_LDOV12B_EN_8822C BIT(30)
#define BIT_CKEN_BTGPS_8822C BIT(29)
#define BIT_FEN_BTGPS_8822C BIT(28)
#define BIT_BTCPU_BOOTSEL_8822C BIT(27)
#define BIT_SPI_SPEEDUP_8822C BIT(26)
#define BIT_BT_LDO_MODE_8822C BIT(25)
#define BIT_DEVWAKE_PAD_TYPE_SEL_8822C BIT(24)
#define BIT_CLKREQ_PAD_TYPE_SEL_8822C BIT(23)
#define BIT_ISO_BTPON2PP_8822C BIT(22)
#define BIT_BT_HWROF_EN_8822C BIT(19)
#define BIT_BT_FUNC_EN_8822C BIT(18)
#define BIT_BT_HWPDN_SL_8822C BIT(17)
#define BIT_BT_DISN_EN_8822C BIT(16)
#define BIT_BT_PDN_PULL_EN_8822C BIT(15)
#define BIT_WL_PDN_PULL_EN_8822C BIT(14)
#define BIT_EXTERNAL_REQUEST_PL_8822C BIT(13)
#define BIT_GPIO0_2_3_PULL_LOW_EN_8822C BIT(12)
#define BIT_ISO_BA2PP_8822C BIT(11)
#define BIT_BT_AFE_LDO_EN_8822C BIT(10)
#define BIT_BT_AFE_PLL_EN_8822C BIT(9)
#define BIT_BT_DIG_CLK_EN_8822C BIT(8)
#define BIT_WLAN_32K_SEL_8822C BIT(6)
#define BIT_WL_DRV_EXIST_IDX_8822C BIT(5)
#define BIT_DOP_EHPAD_8822C BIT(4)
#define BIT_WL_HWROF_EN_8822C BIT(3)
#define BIT_WL_FUNC_EN_8822C BIT(2)
#define BIT_WL_HWPDN_SL_8822C BIT(1)
#define BIT_WL_HWPDN_EN_8822C BIT(0)
/* 2 REG_SDM_DEBUG_8822C */
#define BIT_GPIO_IE_V18_8822C BIT(10)
#define BIT_PCIE_IE_V18_8822C BIT(9)
#define BIT_UART_IE_V18_8822C BIT(8)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_WLCLK_PHASE_8822C 0
#define BIT_MASK_WLCLK_PHASE_8822C 0x1f
#define BIT_WLCLK_PHASE_8822C(x) \
(((x) & BIT_MASK_WLCLK_PHASE_8822C) << BIT_SHIFT_WLCLK_PHASE_8822C)
#define BITS_WLCLK_PHASE_8822C \
(BIT_MASK_WLCLK_PHASE_8822C << BIT_SHIFT_WLCLK_PHASE_8822C)
#define BIT_CLEAR_WLCLK_PHASE_8822C(x) ((x) & (~BITS_WLCLK_PHASE_8822C))
#define BIT_GET_WLCLK_PHASE_8822C(x) \
(((x) >> BIT_SHIFT_WLCLK_PHASE_8822C) & BIT_MASK_WLCLK_PHASE_8822C)
#define BIT_SET_WLCLK_PHASE_8822C(x, v) \
(BIT_CLEAR_WLCLK_PHASE_8822C(x) | BIT_WLCLK_PHASE_8822C(v))
/* 2 REG_SYS_SDIO_CTRL_8822C */
#define BIT_DBG_GNT_WL_BT_8822C BIT(27)
#define BIT_LTE_MUX_CTRL_PATH_8822C BIT(26)
#define BIT_LTE_COEX_UART_8822C BIT(25)
#define BIT_3W_LTE_WL_GPIO_8822C BIT(24)
#define BIT_SDIO_INT_POLARITY_8822C BIT(19)
#define BIT_SDIO_INT_8822C BIT(18)
#define BIT_SDIO_OFF_EN_8822C BIT(17)
#define BIT_SDIO_ON_EN_8822C BIT(16)
#define BIT_PCIE_FORCE_PWR_NGAT_8822C BIT(13)
#define BIT_PCIE_CALIB_EN_V1_8822C BIT(12)
#define BIT_PAGE3_AUXCLK_GATE_8822C BIT(11)
#define BIT_PCIE_WAIT_TIMEOUT_EVENT_8822C BIT(10)
#define BIT_PCIE_WAIT_TIME_8822C BIT(9)
#define BIT_MPCIE_REFCLK_XTAL_SEL_8822C BIT(8)
#define BIT_BT_CTRL_USB_PWR_BACKDOOR_8822C BIT(5)
#define BIT_USB_D_STATE_HOLD_8822C BIT(4)
#define BIT_REG_FORCE_DP_8822C BIT(3)
#define BIT_REG_DP_MODE_8822C BIT(2)
#define BIT_RES_USB_MASS_STORAGE_DESC_8822C BIT(1)
#define BIT_USB_WAIT_TIME_8822C BIT(0)
/* 2 REG_HCI_OPT_CTRL_8822C */
#define BIT_SHIFT_TSFT_SEL_8822C 29
#define BIT_MASK_TSFT_SEL_8822C 0x7
#define BIT_TSFT_SEL_8822C(x) \
(((x) & BIT_MASK_TSFT_SEL_8822C) << BIT_SHIFT_TSFT_SEL_8822C)
#define BITS_TSFT_SEL_8822C \
(BIT_MASK_TSFT_SEL_8822C << BIT_SHIFT_TSFT_SEL_8822C)
#define BIT_CLEAR_TSFT_SEL_8822C(x) ((x) & (~BITS_TSFT_SEL_8822C))
#define BIT_GET_TSFT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_8822C) & BIT_MASK_TSFT_SEL_8822C)
#define BIT_SET_TSFT_SEL_8822C(x, v) \
(BIT_CLEAR_TSFT_SEL_8822C(x) | BIT_TSFT_SEL_8822C(v))
#define BIT_SDIO_PAD_E5_8822C BIT(18)
#define BIT_USB_HOST_PWR_OFF_EN_8822C BIT(12)
#define BIT_SYM_LPS_BLOCK_EN_8822C BIT(11)
#define BIT_USB_LPM_ACT_EN_8822C BIT(10)
#define BIT_USB_LPM_NY_8822C BIT(9)
#define BIT_USB_SUS_DIS_8822C BIT(8)
#define BIT_SHIFT_SDIO_PAD_E_8822C 5
#define BIT_MASK_SDIO_PAD_E_8822C 0x7
#define BIT_SDIO_PAD_E_8822C(x) \
(((x) & BIT_MASK_SDIO_PAD_E_8822C) << BIT_SHIFT_SDIO_PAD_E_8822C)
#define BITS_SDIO_PAD_E_8822C \
(BIT_MASK_SDIO_PAD_E_8822C << BIT_SHIFT_SDIO_PAD_E_8822C)
#define BIT_CLEAR_SDIO_PAD_E_8822C(x) ((x) & (~BITS_SDIO_PAD_E_8822C))
#define BIT_GET_SDIO_PAD_E_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_PAD_E_8822C) & BIT_MASK_SDIO_PAD_E_8822C)
#define BIT_SET_SDIO_PAD_E_8822C(x, v) \
(BIT_CLEAR_SDIO_PAD_E_8822C(x) | BIT_SDIO_PAD_E_8822C(v))
#define BIT_USB_LPPLL_EN_8822C BIT(4)
#define BIT_USB1_1_USB2_0_DECISION_8822C BIT(3)
#define BIT_ROP_SW15_8822C BIT(2)
#define BIT_PCI_CKRDY_OPT_8822C BIT(1)
#define BIT_PCI_VAUX_EN_8822C BIT(0)
/* 2 REG_HCI_BG_CTRL_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_IBX_EN_VALUE_8822C BIT(9)
#define BIT_IB_EN_VALUE_8822C BIT(8)
/* 2 REG_NOT_VALID_8822C */
#define BIT_FORCED_IB_EN_8822C BIT(4)
#define BIT_EN_REGBG_8822C BIT(3)
#define BIT_REG_BG_LPF_8822C BIT(2)
#define BIT_SHIFT_REG_BG_8822C 0
#define BIT_MASK_REG_BG_8822C 0x3
#define BIT_REG_BG_8822C(x) \
(((x) & BIT_MASK_REG_BG_8822C) << BIT_SHIFT_REG_BG_8822C)
#define BITS_REG_BG_8822C (BIT_MASK_REG_BG_8822C << BIT_SHIFT_REG_BG_8822C)
#define BIT_CLEAR_REG_BG_8822C(x) ((x) & (~BITS_REG_BG_8822C))
#define BIT_GET_REG_BG_8822C(x) \
(((x) >> BIT_SHIFT_REG_BG_8822C) & BIT_MASK_REG_BG_8822C)
#define BIT_SET_REG_BG_8822C(x, v) \
(BIT_CLEAR_REG_BG_8822C(x) | BIT_REG_BG_8822C(v))
/* 2 REG_HCI_LDO_CTRL_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_EN_LW_PWR_8822C BIT(6)
#define BIT_EN_REGU_8822C BIT(5)
#define BIT_EN_PC_8822C BIT(4)
#define BIT_SHIFT_REG_VADJ_8822C 0
#define BIT_MASK_REG_VADJ_8822C 0xf
#define BIT_REG_VADJ_8822C(x) \
(((x) & BIT_MASK_REG_VADJ_8822C) << BIT_SHIFT_REG_VADJ_8822C)
#define BITS_REG_VADJ_8822C \
(BIT_MASK_REG_VADJ_8822C << BIT_SHIFT_REG_VADJ_8822C)
#define BIT_CLEAR_REG_VADJ_8822C(x) ((x) & (~BITS_REG_VADJ_8822C))
#define BIT_GET_REG_VADJ_8822C(x) \
(((x) >> BIT_SHIFT_REG_VADJ_8822C) & BIT_MASK_REG_VADJ_8822C)
#define BIT_SET_REG_VADJ_8822C(x, v) \
(BIT_CLEAR_REG_VADJ_8822C(x) | BIT_REG_VADJ_8822C(v))
/* 2 REG_LDO_SWR_CTRL_8822C */
#define BIT_EXT_SWR_CTRL_EN_8822C BIT(31)
#define BIT_ZCD_HW_AUTO_EN_8822C BIT(27)
#define BIT_ZCD_REGSEL_8822C BIT(26)
#define BIT_SHIFT_AUTO_ZCD_IN_CODE_8822C 21
#define BIT_MASK_AUTO_ZCD_IN_CODE_8822C 0x1f
#define BIT_AUTO_ZCD_IN_CODE_8822C(x) \
(((x) & BIT_MASK_AUTO_ZCD_IN_CODE_8822C) \
<< BIT_SHIFT_AUTO_ZCD_IN_CODE_8822C)
#define BITS_AUTO_ZCD_IN_CODE_8822C \
(BIT_MASK_AUTO_ZCD_IN_CODE_8822C << BIT_SHIFT_AUTO_ZCD_IN_CODE_8822C)
#define BIT_CLEAR_AUTO_ZCD_IN_CODE_8822C(x) \
((x) & (~BITS_AUTO_ZCD_IN_CODE_8822C))
#define BIT_GET_AUTO_ZCD_IN_CODE_8822C(x) \
(((x) >> BIT_SHIFT_AUTO_ZCD_IN_CODE_8822C) & \
BIT_MASK_AUTO_ZCD_IN_CODE_8822C)
#define BIT_SET_AUTO_ZCD_IN_CODE_8822C(x, v) \
(BIT_CLEAR_AUTO_ZCD_IN_CODE_8822C(x) | BIT_AUTO_ZCD_IN_CODE_8822C(v))
#define BIT_SHIFT_ZCD_CODE_IN_L_8822C 16
#define BIT_MASK_ZCD_CODE_IN_L_8822C 0x1f
#define BIT_ZCD_CODE_IN_L_8822C(x) \
(((x) & BIT_MASK_ZCD_CODE_IN_L_8822C) << BIT_SHIFT_ZCD_CODE_IN_L_8822C)
#define BITS_ZCD_CODE_IN_L_8822C \
(BIT_MASK_ZCD_CODE_IN_L_8822C << BIT_SHIFT_ZCD_CODE_IN_L_8822C)
#define BIT_CLEAR_ZCD_CODE_IN_L_8822C(x) ((x) & (~BITS_ZCD_CODE_IN_L_8822C))
#define BIT_GET_ZCD_CODE_IN_L_8822C(x) \
(((x) >> BIT_SHIFT_ZCD_CODE_IN_L_8822C) & BIT_MASK_ZCD_CODE_IN_L_8822C)
#define BIT_SET_ZCD_CODE_IN_L_8822C(x, v) \
(BIT_CLEAR_ZCD_CODE_IN_L_8822C(x) | BIT_ZCD_CODE_IN_L_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_MCUFW_CTRL_8822C */
#define BIT_SHIFT_RPWM_8822C 24
#define BIT_MASK_RPWM_8822C 0xff
#define BIT_RPWM_8822C(x) (((x) & BIT_MASK_RPWM_8822C) << BIT_SHIFT_RPWM_8822C)
#define BITS_RPWM_8822C (BIT_MASK_RPWM_8822C << BIT_SHIFT_RPWM_8822C)
#define BIT_CLEAR_RPWM_8822C(x) ((x) & (~BITS_RPWM_8822C))
#define BIT_GET_RPWM_8822C(x) \
(((x) >> BIT_SHIFT_RPWM_8822C) & BIT_MASK_RPWM_8822C)
#define BIT_SET_RPWM_8822C(x, v) (BIT_CLEAR_RPWM_8822C(x) | BIT_RPWM_8822C(v))
#define BIT_ANA_PORT_EN_8822C BIT(22)
#define BIT_MAC_PORT_EN_8822C BIT(21)
#define BIT_BOOT_FSPI_EN_8822C BIT(20)
#define BIT_ROM_DLEN_8822C BIT(19)
#define BIT_SHIFT_ROM_PGE_8822C 16
#define BIT_MASK_ROM_PGE_8822C 0x7
#define BIT_ROM_PGE_8822C(x) \
(((x) & BIT_MASK_ROM_PGE_8822C) << BIT_SHIFT_ROM_PGE_8822C)
#define BITS_ROM_PGE_8822C (BIT_MASK_ROM_PGE_8822C << BIT_SHIFT_ROM_PGE_8822C)
#define BIT_CLEAR_ROM_PGE_8822C(x) ((x) & (~BITS_ROM_PGE_8822C))
#define BIT_GET_ROM_PGE_8822C(x) \
(((x) >> BIT_SHIFT_ROM_PGE_8822C) & BIT_MASK_ROM_PGE_8822C)
#define BIT_SET_ROM_PGE_8822C(x, v) \
(BIT_CLEAR_ROM_PGE_8822C(x) | BIT_ROM_PGE_8822C(v))
#define BIT_FW_INIT_RDY_8822C BIT(15)
#define BIT_FW_DW_RDY_8822C BIT(14)
#define BIT_SHIFT_CPU_CLK_SEL_8822C 12
#define BIT_MASK_CPU_CLK_SEL_8822C 0x3
#define BIT_CPU_CLK_SEL_8822C(x) \
(((x) & BIT_MASK_CPU_CLK_SEL_8822C) << BIT_SHIFT_CPU_CLK_SEL_8822C)
#define BITS_CPU_CLK_SEL_8822C \
(BIT_MASK_CPU_CLK_SEL_8822C << BIT_SHIFT_CPU_CLK_SEL_8822C)
#define BIT_CLEAR_CPU_CLK_SEL_8822C(x) ((x) & (~BITS_CPU_CLK_SEL_8822C))
#define BIT_GET_CPU_CLK_SEL_8822C(x) \
(((x) >> BIT_SHIFT_CPU_CLK_SEL_8822C) & BIT_MASK_CPU_CLK_SEL_8822C)
#define BIT_SET_CPU_CLK_SEL_8822C(x, v) \
(BIT_CLEAR_CPU_CLK_SEL_8822C(x) | BIT_CPU_CLK_SEL_8822C(v))
#define BIT_CCLK_CHG_MASK_8822C BIT(11)
#define BIT_EMEM__TXBUF_CHKSUM_OK_8822C BIT(10)
#define BIT_EMEM_TXBUF_DW_RDY_8822C BIT(9)
#define BIT_EMEM_CHKSUM_OK_8822C BIT(8)
#define BIT_EMEM_DW_OK_8822C BIT(7)
#define BIT_DMEM_CHKSUM_OK_8822C BIT(6)
#define BIT_DMEM_DW_OK_8822C BIT(5)
#define BIT_IMEM_CHKSUM_OK_8822C BIT(4)
#define BIT_IMEM_DW_OK_8822C BIT(3)
#define BIT_IMEM_BOOT_LOAD_CHKSUM_OK_8822C BIT(2)
#define BIT_IMEM_BOOT_LOAD_DW_OK_8822C BIT(1)
#define BIT_MCUFWDL_EN_8822C BIT(0)
/* 2 REG_MCU_TST_CFG_8822C */
#define BIT_SHIFT_LBKTST_8822C 0
#define BIT_MASK_LBKTST_8822C 0xffff
#define BIT_LBKTST_8822C(x) \
(((x) & BIT_MASK_LBKTST_8822C) << BIT_SHIFT_LBKTST_8822C)
#define BITS_LBKTST_8822C (BIT_MASK_LBKTST_8822C << BIT_SHIFT_LBKTST_8822C)
#define BIT_CLEAR_LBKTST_8822C(x) ((x) & (~BITS_LBKTST_8822C))
#define BIT_GET_LBKTST_8822C(x) \
(((x) >> BIT_SHIFT_LBKTST_8822C) & BIT_MASK_LBKTST_8822C)
#define BIT_SET_LBKTST_8822C(x, v) \
(BIT_CLEAR_LBKTST_8822C(x) | BIT_LBKTST_8822C(v))
/* 2 REG_HMEBOX_E0_E1_8822C */
#define BIT_SHIFT_HOST_MSG_E1_8822C 16
#define BIT_MASK_HOST_MSG_E1_8822C 0xffff
#define BIT_HOST_MSG_E1_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_E1_8822C) << BIT_SHIFT_HOST_MSG_E1_8822C)
#define BITS_HOST_MSG_E1_8822C \
(BIT_MASK_HOST_MSG_E1_8822C << BIT_SHIFT_HOST_MSG_E1_8822C)
#define BIT_CLEAR_HOST_MSG_E1_8822C(x) ((x) & (~BITS_HOST_MSG_E1_8822C))
#define BIT_GET_HOST_MSG_E1_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E1_8822C) & BIT_MASK_HOST_MSG_E1_8822C)
#define BIT_SET_HOST_MSG_E1_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_E1_8822C(x) | BIT_HOST_MSG_E1_8822C(v))
#define BIT_SHIFT_HOST_MSG_E0_8822C 0
#define BIT_MASK_HOST_MSG_E0_8822C 0xffff
#define BIT_HOST_MSG_E0_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_E0_8822C) << BIT_SHIFT_HOST_MSG_E0_8822C)
#define BITS_HOST_MSG_E0_8822C \
(BIT_MASK_HOST_MSG_E0_8822C << BIT_SHIFT_HOST_MSG_E0_8822C)
#define BIT_CLEAR_HOST_MSG_E0_8822C(x) ((x) & (~BITS_HOST_MSG_E0_8822C))
#define BIT_GET_HOST_MSG_E0_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E0_8822C) & BIT_MASK_HOST_MSG_E0_8822C)
#define BIT_SET_HOST_MSG_E0_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_E0_8822C(x) | BIT_HOST_MSG_E0_8822C(v))
/* 2 REG_HMEBOX_E2_E3_8822C */
#define BIT_SHIFT_HOST_MSG_E3_8822C 16
#define BIT_MASK_HOST_MSG_E3_8822C 0xffff
#define BIT_HOST_MSG_E3_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_E3_8822C) << BIT_SHIFT_HOST_MSG_E3_8822C)
#define BITS_HOST_MSG_E3_8822C \
(BIT_MASK_HOST_MSG_E3_8822C << BIT_SHIFT_HOST_MSG_E3_8822C)
#define BIT_CLEAR_HOST_MSG_E3_8822C(x) ((x) & (~BITS_HOST_MSG_E3_8822C))
#define BIT_GET_HOST_MSG_E3_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E3_8822C) & BIT_MASK_HOST_MSG_E3_8822C)
#define BIT_SET_HOST_MSG_E3_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_E3_8822C(x) | BIT_HOST_MSG_E3_8822C(v))
#define BIT_SHIFT_HOST_MSG_E2_8822C 0
#define BIT_MASK_HOST_MSG_E2_8822C 0xffff
#define BIT_HOST_MSG_E2_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_E2_8822C) << BIT_SHIFT_HOST_MSG_E2_8822C)
#define BITS_HOST_MSG_E2_8822C \
(BIT_MASK_HOST_MSG_E2_8822C << BIT_SHIFT_HOST_MSG_E2_8822C)
#define BIT_CLEAR_HOST_MSG_E2_8822C(x) ((x) & (~BITS_HOST_MSG_E2_8822C))
#define BIT_GET_HOST_MSG_E2_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_E2_8822C) & BIT_MASK_HOST_MSG_E2_8822C)
#define BIT_SET_HOST_MSG_E2_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_E2_8822C(x) | BIT_HOST_MSG_E2_8822C(v))
/* 2 REG_WLLPS_CTRL_8822C */
#define BIT_WLLPSOP_EABM_8822C BIT(31)
#define BIT_WLLPSOP_ACKF_8822C BIT(30)
#define BIT_WLLPSOP_DLDM_8822C BIT(29)
#define BIT_WLLPSOP_ESWR_8822C BIT(28)
#define BIT_WLLPSOP_PWMM_8822C BIT(27)
#define BIT_WLLPSOP_EECK_8822C BIT(26)
#define BIT_WLLPSOP_WLMACOFF_8822C BIT(25)
#define BIT_WLLPSOP_EXTAL_8822C BIT(24)
#define BIT_WL_SYNPON_VOLTSPDN_8822C BIT(23)
#define BIT_WLLPSOP_WLBBOFF_8822C BIT(22)
#define BIT_WLLPSOP_WLMEM_DS_8822C BIT(21)
#define BIT_WLLPSOP_LDO_WAIT_TIME_8822C BIT(20)
#define BIT_WLLPSOP_ANA_CLK_DIVISION_2_8822C BIT(19)
#define BIT_AFE_BCN_8822C BIT(18)
#define BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822C 12
#define BIT_MASK_LPLDH12_VADJ_STEP_DN_8822C 0xf
#define BIT_LPLDH12_VADJ_STEP_DN_8822C(x) \
(((x) & BIT_MASK_LPLDH12_VADJ_STEP_DN_8822C) \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822C)
#define BITS_LPLDH12_VADJ_STEP_DN_8822C \
(BIT_MASK_LPLDH12_VADJ_STEP_DN_8822C \
<< BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822C)
#define BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8822C(x) \
((x) & (~BITS_LPLDH12_VADJ_STEP_DN_8822C))
#define BIT_GET_LPLDH12_VADJ_STEP_DN_8822C(x) \
(((x) >> BIT_SHIFT_LPLDH12_VADJ_STEP_DN_8822C) & \
BIT_MASK_LPLDH12_VADJ_STEP_DN_8822C)
#define BIT_SET_LPLDH12_VADJ_STEP_DN_8822C(x, v) \
(BIT_CLEAR_LPLDH12_VADJ_STEP_DN_8822C(x) | \
BIT_LPLDH12_VADJ_STEP_DN_8822C(v))
#define BIT_SHIFT_V15ADJ_L1_STEP_DN_V1_8822C 8
#define BIT_MASK_V15ADJ_L1_STEP_DN_V1_8822C 0xf
#define BIT_V15ADJ_L1_STEP_DN_V1_8822C(x) \
(((x) & BIT_MASK_V15ADJ_L1_STEP_DN_V1_8822C) \
<< BIT_SHIFT_V15ADJ_L1_STEP_DN_V1_8822C)
#define BITS_V15ADJ_L1_STEP_DN_V1_8822C \
(BIT_MASK_V15ADJ_L1_STEP_DN_V1_8822C \
<< BIT_SHIFT_V15ADJ_L1_STEP_DN_V1_8822C)
#define BIT_CLEAR_V15ADJ_L1_STEP_DN_V1_8822C(x) \
((x) & (~BITS_V15ADJ_L1_STEP_DN_V1_8822C))
#define BIT_GET_V15ADJ_L1_STEP_DN_V1_8822C(x) \
(((x) >> BIT_SHIFT_V15ADJ_L1_STEP_DN_V1_8822C) & \
BIT_MASK_V15ADJ_L1_STEP_DN_V1_8822C)
#define BIT_SET_V15ADJ_L1_STEP_DN_V1_8822C(x, v) \
(BIT_CLEAR_V15ADJ_L1_STEP_DN_V1_8822C(x) | \
BIT_V15ADJ_L1_STEP_DN_V1_8822C(v))
#define BIT_FORCE_LEAVE_LPS_8822C BIT(3)
#define BIT_SW_AFE_MODE_8822C BIT(2)
#define BIT_REGU_32K_CLK_EN_8822C BIT(1)
#define BIT_WL_LPS_EN_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_GPIO_DEBOUNCE_CTRL_8822C */
#define BIT_WLGP_DBC1EN_8822C BIT(15)
#define BIT_SHIFT_WLGP_DBC1_8822C 8
#define BIT_MASK_WLGP_DBC1_8822C 0xf
#define BIT_WLGP_DBC1_8822C(x) \
(((x) & BIT_MASK_WLGP_DBC1_8822C) << BIT_SHIFT_WLGP_DBC1_8822C)
#define BITS_WLGP_DBC1_8822C \
(BIT_MASK_WLGP_DBC1_8822C << BIT_SHIFT_WLGP_DBC1_8822C)
#define BIT_CLEAR_WLGP_DBC1_8822C(x) ((x) & (~BITS_WLGP_DBC1_8822C))
#define BIT_GET_WLGP_DBC1_8822C(x) \
(((x) >> BIT_SHIFT_WLGP_DBC1_8822C) & BIT_MASK_WLGP_DBC1_8822C)
#define BIT_SET_WLGP_DBC1_8822C(x, v) \
(BIT_CLEAR_WLGP_DBC1_8822C(x) | BIT_WLGP_DBC1_8822C(v))
#define BIT_WLGP_DBC0EN_8822C BIT(7)
#define BIT_SHIFT_WLGP_DBC0_8822C 0
#define BIT_MASK_WLGP_DBC0_8822C 0xf
#define BIT_WLGP_DBC0_8822C(x) \
(((x) & BIT_MASK_WLGP_DBC0_8822C) << BIT_SHIFT_WLGP_DBC0_8822C)
#define BITS_WLGP_DBC0_8822C \
(BIT_MASK_WLGP_DBC0_8822C << BIT_SHIFT_WLGP_DBC0_8822C)
#define BIT_CLEAR_WLGP_DBC0_8822C(x) ((x) & (~BITS_WLGP_DBC0_8822C))
#define BIT_GET_WLGP_DBC0_8822C(x) \
(((x) >> BIT_SHIFT_WLGP_DBC0_8822C) & BIT_MASK_WLGP_DBC0_8822C)
#define BIT_SET_WLGP_DBC0_8822C(x, v) \
(BIT_CLEAR_WLGP_DBC0_8822C(x) | BIT_WLGP_DBC0_8822C(v))
/* 2 REG_RPWM2_8822C */
#define BIT_SHIFT_RPWM2_8822C 16
#define BIT_MASK_RPWM2_8822C 0xffff
#define BIT_RPWM2_8822C(x) \
(((x) & BIT_MASK_RPWM2_8822C) << BIT_SHIFT_RPWM2_8822C)
#define BITS_RPWM2_8822C (BIT_MASK_RPWM2_8822C << BIT_SHIFT_RPWM2_8822C)
#define BIT_CLEAR_RPWM2_8822C(x) ((x) & (~BITS_RPWM2_8822C))
#define BIT_GET_RPWM2_8822C(x) \
(((x) >> BIT_SHIFT_RPWM2_8822C) & BIT_MASK_RPWM2_8822C)
#define BIT_SET_RPWM2_8822C(x, v) \
(BIT_CLEAR_RPWM2_8822C(x) | BIT_RPWM2_8822C(v))
/* 2 REG_SYSON_FSM_MON_8822C */
#define BIT_SHIFT_FSM_MON_SEL_8822C 24
#define BIT_MASK_FSM_MON_SEL_8822C 0x7
#define BIT_FSM_MON_SEL_8822C(x) \
(((x) & BIT_MASK_FSM_MON_SEL_8822C) << BIT_SHIFT_FSM_MON_SEL_8822C)
#define BITS_FSM_MON_SEL_8822C \
(BIT_MASK_FSM_MON_SEL_8822C << BIT_SHIFT_FSM_MON_SEL_8822C)
#define BIT_CLEAR_FSM_MON_SEL_8822C(x) ((x) & (~BITS_FSM_MON_SEL_8822C))
#define BIT_GET_FSM_MON_SEL_8822C(x) \
(((x) >> BIT_SHIFT_FSM_MON_SEL_8822C) & BIT_MASK_FSM_MON_SEL_8822C)
#define BIT_SET_FSM_MON_SEL_8822C(x, v) \
(BIT_CLEAR_FSM_MON_SEL_8822C(x) | BIT_FSM_MON_SEL_8822C(v))
#define BIT_DOP_ELDO_8822C BIT(23)
#define BIT_FSM_MON_UPD_8822C BIT(15)
#define BIT_SHIFT_FSM_PAR_8822C 0
#define BIT_MASK_FSM_PAR_8822C 0x7fff
#define BIT_FSM_PAR_8822C(x) \
(((x) & BIT_MASK_FSM_PAR_8822C) << BIT_SHIFT_FSM_PAR_8822C)
#define BITS_FSM_PAR_8822C (BIT_MASK_FSM_PAR_8822C << BIT_SHIFT_FSM_PAR_8822C)
#define BIT_CLEAR_FSM_PAR_8822C(x) ((x) & (~BITS_FSM_PAR_8822C))
#define BIT_GET_FSM_PAR_8822C(x) \
(((x) >> BIT_SHIFT_FSM_PAR_8822C) & BIT_MASK_FSM_PAR_8822C)
#define BIT_SET_FSM_PAR_8822C(x, v) \
(BIT_CLEAR_FSM_PAR_8822C(x) | BIT_FSM_PAR_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_PMC_DBG_CTRL1_8822C */
#define BIT_BT_INT_EN_8822C BIT(31)
#define BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822C 16
#define BIT_MASK_RD_WR_WIFI_BT_INFO_8822C 0x7fff
#define BIT_RD_WR_WIFI_BT_INFO_8822C(x) \
(((x) & BIT_MASK_RD_WR_WIFI_BT_INFO_8822C) \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822C)
#define BITS_RD_WR_WIFI_BT_INFO_8822C \
(BIT_MASK_RD_WR_WIFI_BT_INFO_8822C \
<< BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822C)
#define BIT_CLEAR_RD_WR_WIFI_BT_INFO_8822C(x) \
((x) & (~BITS_RD_WR_WIFI_BT_INFO_8822C))
#define BIT_GET_RD_WR_WIFI_BT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_RD_WR_WIFI_BT_INFO_8822C) & \
BIT_MASK_RD_WR_WIFI_BT_INFO_8822C)
#define BIT_SET_RD_WR_WIFI_BT_INFO_8822C(x, v) \
(BIT_CLEAR_RD_WR_WIFI_BT_INFO_8822C(x) | \
BIT_RD_WR_WIFI_BT_INFO_8822C(v))
#define BIT_PMC_WR_OVF_8822C BIT(8)
#define BIT_SHIFT_WLPMC_ERRINT_8822C 0
#define BIT_MASK_WLPMC_ERRINT_8822C 0xff
#define BIT_WLPMC_ERRINT_8822C(x) \
(((x) & BIT_MASK_WLPMC_ERRINT_8822C) << BIT_SHIFT_WLPMC_ERRINT_8822C)
#define BITS_WLPMC_ERRINT_8822C \
(BIT_MASK_WLPMC_ERRINT_8822C << BIT_SHIFT_WLPMC_ERRINT_8822C)
#define BIT_CLEAR_WLPMC_ERRINT_8822C(x) ((x) & (~BITS_WLPMC_ERRINT_8822C))
#define BIT_GET_WLPMC_ERRINT_8822C(x) \
(((x) >> BIT_SHIFT_WLPMC_ERRINT_8822C) & BIT_MASK_WLPMC_ERRINT_8822C)
#define BIT_SET_WLPMC_ERRINT_8822C(x, v) \
(BIT_CLEAR_WLPMC_ERRINT_8822C(x) | BIT_WLPMC_ERRINT_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_HIMR0_8822C */
#define BIT_TIMEOUT_INTERRUPT2_MASK_8822C BIT(31)
#define BIT_TIMEOUT_INTERRUTP1_MASK_8822C BIT(30)
#define BIT_PSTIMEOUT_MSK_8822C BIT(29)
#define BIT_GTINT4_MSK_8822C BIT(28)
#define BIT_GTINT3_MSK_8822C BIT(27)
#define BIT_TXBCN0ERR_MSK_8822C BIT(26)
#define BIT_TXBCN0OK_MSK_8822C BIT(25)
#define BIT_TSF_BIT32_TOGGLE_MSK_8822C BIT(24)
#define BIT_BCNDMAINT0_MSK_8822C BIT(20)
#define BIT_BCNDERR0_MSK_8822C BIT(16)
#define BIT_HSISR_IND_ON_INT_MSK_8822C BIT(15)
#define BIT_BCNDMAINT_E_MSK_8822C BIT(14)
#define BIT_CTWEND_MSK_8822C BIT(12)
#define BIT_HISR1_IND_MSK_8822C BIT(11)
#define BIT_C2HCMD_MSK_8822C BIT(10)
#define BIT_CPWM2_MSK_8822C BIT(9)
#define BIT_CPWM_MSK_8822C BIT(8)
#define BIT_HIGHDOK_MSK_8822C BIT(7)
#define BIT_MGTDOK_MSK_8822C BIT(6)
#define BIT_BKDOK_MSK_8822C BIT(5)
#define BIT_BEDOK_MSK_8822C BIT(4)
#define BIT_VIDOK_MSK_8822C BIT(3)
#define BIT_VODOK_MSK_8822C BIT(2)
#define BIT_RDU_MSK_8822C BIT(1)
#define BIT_RXOK_MSK_8822C BIT(0)
/* 2 REG_HISR0_8822C */
#define BIT_PSTIMEOUT2_8822C BIT(31)
#define BIT_PSTIMEOUT1_8822C BIT(30)
#define BIT_PSTIMEOUT_8822C BIT(29)
#define BIT_GTINT4_8822C BIT(28)
#define BIT_GTINT3_8822C BIT(27)
#define BIT_TXBCN0ERR_8822C BIT(26)
#define BIT_TXBCN0OK_8822C BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8822C BIT(24)
#define BIT_BCNDMAINT0_8822C BIT(20)
#define BIT_BCNDERR0_8822C BIT(16)
#define BIT_HSISR_IND_ON_INT_8822C BIT(15)
#define BIT_BCNDMAINT_E_8822C BIT(14)
#define BIT_CTWEND_8822C BIT(12)
#define BIT_HISR1_IND_INT_8822C BIT(11)
#define BIT_C2HCMD_8822C BIT(10)
#define BIT_CPWM2_8822C BIT(9)
#define BIT_CPWM_8822C BIT(8)
#define BIT_HIGHDOK_8822C BIT(7)
#define BIT_MGTDOK_8822C BIT(6)
#define BIT_BKDOK_8822C BIT(5)
#define BIT_BEDOK_8822C BIT(4)
#define BIT_VIDOK_8822C BIT(3)
#define BIT_VODOK_8822C BIT(2)
#define BIT_RDU_8822C BIT(1)
#define BIT_RXOK_8822C BIT(0)
/* 2 REG_HIMR1_8822C */
#define BIT_TXFIFO_TH_INT_8822C BIT(30)
#define BIT_BTON_STS_UPDATE_MASK_8822C BIT(29)
#define BIT_MCU_ERR_MASK_8822C BIT(28)
#define BIT_BCNDMAINT7__MSK_8822C BIT(27)
#define BIT_BCNDMAINT6__MSK_8822C BIT(26)
#define BIT_BCNDMAINT5__MSK_8822C BIT(25)
#define BIT_BCNDMAINT4__MSK_8822C BIT(24)
#define BIT_BCNDMAINT3_MSK_8822C BIT(23)
#define BIT_BCNDMAINT2_MSK_8822C BIT(22)
#define BIT_BCNDMAINT1_MSK_8822C BIT(21)
#define BIT_BCNDERR7_MSK_8822C BIT(20)
#define BIT_BCNDERR6_MSK_8822C BIT(19)
#define BIT_BCNDERR5_MSK_8822C BIT(18)
#define BIT_BCNDERR4_MSK_8822C BIT(17)
#define BIT_BCNDERR3_MSK_8822C BIT(16)
#define BIT_BCNDERR2_MSK_8822C BIT(15)
#define BIT_BCNDERR1_MSK_8822C BIT(14)
#define BIT_ATIMEND_E_MSK_8822C BIT(13)
#define BIT_ATIMEND__MSK_8822C BIT(12)
#define BIT_TXERR_MSK_8822C BIT(11)
#define BIT_RXERR_MSK_8822C BIT(10)
#define BIT_TXFOVW_MSK_8822C BIT(9)
#define BIT_FOVW_MSK_8822C BIT(8)
#define BIT_CPU_MGQ_TXDONE_MSK_8822C BIT(5)
#define BIT_PS_TIMER_C_MSK_8822C BIT(4)
#define BIT_PS_TIMER_B_MSK_8822C BIT(3)
#define BIT_PS_TIMER_A_MSK_8822C BIT(2)
#define BIT_CPUMGQ_TX_TIMER_MSK_8822C BIT(1)
/* 2 REG_HISR1_8822C */
#define BIT_TXFIFO_TH_INT_8822C BIT(30)
#define BIT_BTON_STS_UPDATE_INT_8822C BIT(29)
#define BIT_MCU_ERR_8822C BIT(28)
#define BIT_BCNDMAINT7_8822C BIT(27)
#define BIT_BCNDMAINT6_8822C BIT(26)
#define BIT_BCNDMAINT5_8822C BIT(25)
#define BIT_BCNDMAINT4_8822C BIT(24)
#define BIT_BCNDMAINT3_8822C BIT(23)
#define BIT_BCNDMAINT2_8822C BIT(22)
#define BIT_BCNDMAINT1_8822C BIT(21)
#define BIT_BCNDERR7_8822C BIT(20)
#define BIT_BCNDERR6_8822C BIT(19)
#define BIT_BCNDERR5_8822C BIT(18)
#define BIT_BCNDERR4_8822C BIT(17)
#define BIT_BCNDERR3_8822C BIT(16)
#define BIT_BCNDERR2_8822C BIT(15)
#define BIT_BCNDERR1_8822C BIT(14)
#define BIT_ATIMEND_E_8822C BIT(13)
#define BIT_ATIMEND_8822C BIT(12)
#define BIT_TXERR_INT_8822C BIT(11)
#define BIT_RXERR_INT_8822C BIT(10)
#define BIT_TXFOVW_8822C BIT(9)
#define BIT_FOVW_8822C BIT(8)
/* 2 REG_NOT_VALID_8822C */
#define BIT_CPU_MGQ_TXDONE_8822C BIT(5)
#define BIT_PS_TIMER_C_8822C BIT(4)
#define BIT_PS_TIMER_B_8822C BIT(3)
#define BIT_PS_TIMER_A_8822C BIT(2)
#define BIT_CPUMGQ_TX_TIMER_8822C BIT(1)
/* 2 REG_DBG_PORT_SEL_8822C */
#define BIT_SHIFT_DEBUG_ST_8822C 0
#define BIT_MASK_DEBUG_ST_8822C 0xffffffffL
#define BIT_DEBUG_ST_8822C(x) \
(((x) & BIT_MASK_DEBUG_ST_8822C) << BIT_SHIFT_DEBUG_ST_8822C)
#define BITS_DEBUG_ST_8822C \
(BIT_MASK_DEBUG_ST_8822C << BIT_SHIFT_DEBUG_ST_8822C)
#define BIT_CLEAR_DEBUG_ST_8822C(x) ((x) & (~BITS_DEBUG_ST_8822C))
#define BIT_GET_DEBUG_ST_8822C(x) \
(((x) >> BIT_SHIFT_DEBUG_ST_8822C) & BIT_MASK_DEBUG_ST_8822C)
#define BIT_SET_DEBUG_ST_8822C(x, v) \
(BIT_CLEAR_DEBUG_ST_8822C(x) | BIT_DEBUG_ST_8822C(v))
/* 2 REG_PAD_CTRL2_8822C */
#define BIT_USB3_USB2_TRANSITION_8822C BIT(20)
#define BIT_SHIFT_USB23_SW_MODE_V1_8822C 18
#define BIT_MASK_USB23_SW_MODE_V1_8822C 0x3
#define BIT_USB23_SW_MODE_V1_8822C(x) \
(((x) & BIT_MASK_USB23_SW_MODE_V1_8822C) \
<< BIT_SHIFT_USB23_SW_MODE_V1_8822C)
#define BITS_USB23_SW_MODE_V1_8822C \
(BIT_MASK_USB23_SW_MODE_V1_8822C << BIT_SHIFT_USB23_SW_MODE_V1_8822C)
#define BIT_CLEAR_USB23_SW_MODE_V1_8822C(x) \
((x) & (~BITS_USB23_SW_MODE_V1_8822C))
#define BIT_GET_USB23_SW_MODE_V1_8822C(x) \
(((x) >> BIT_SHIFT_USB23_SW_MODE_V1_8822C) & \
BIT_MASK_USB23_SW_MODE_V1_8822C)
#define BIT_SET_USB23_SW_MODE_V1_8822C(x, v) \
(BIT_CLEAR_USB23_SW_MODE_V1_8822C(x) | BIT_USB23_SW_MODE_V1_8822C(v))
#define BIT_NO_PDN_CHIPOFF_V1_8822C BIT(17)
#define BIT_RSM_EN_V1_8822C BIT(16)
#define BIT_SHIFT_MATCH_CNT_8822C 8
#define BIT_MASK_MATCH_CNT_8822C 0xff
#define BIT_MATCH_CNT_8822C(x) \
(((x) & BIT_MASK_MATCH_CNT_8822C) << BIT_SHIFT_MATCH_CNT_8822C)
#define BITS_MATCH_CNT_8822C \
(BIT_MASK_MATCH_CNT_8822C << BIT_SHIFT_MATCH_CNT_8822C)
#define BIT_CLEAR_MATCH_CNT_8822C(x) ((x) & (~BITS_MATCH_CNT_8822C))
#define BIT_GET_MATCH_CNT_8822C(x) \
(((x) >> BIT_SHIFT_MATCH_CNT_8822C) & BIT_MASK_MATCH_CNT_8822C)
#define BIT_SET_MATCH_CNT_8822C(x, v) \
(BIT_CLEAR_MATCH_CNT_8822C(x) | BIT_MATCH_CNT_8822C(v))
#define BIT_LD_B12V_EN_8822C BIT(7)
#define BIT_EECS_IOSEL_V1_8822C BIT(6)
#define BIT_EECS_DATA_O_V1_8822C BIT(5)
#define BIT_EECS_DATA_I_V1_8822C BIT(4)
#define BIT_EESK_IOSEL_V1_8822C BIT(2)
#define BIT_EESK_DATA_O_V1_8822C BIT(1)
#define BIT_EESK_DATA_I_V1_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_PMC_DBG_CTRL2_8822C */
#define BIT_SHIFT_EFUSE_BURN_GNT_8822C 24
#define BIT_MASK_EFUSE_BURN_GNT_8822C 0xff
#define BIT_EFUSE_BURN_GNT_8822C(x) \
(((x) & BIT_MASK_EFUSE_BURN_GNT_8822C) \
<< BIT_SHIFT_EFUSE_BURN_GNT_8822C)
#define BITS_EFUSE_BURN_GNT_8822C \
(BIT_MASK_EFUSE_BURN_GNT_8822C << BIT_SHIFT_EFUSE_BURN_GNT_8822C)
#define BIT_CLEAR_EFUSE_BURN_GNT_8822C(x) ((x) & (~BITS_EFUSE_BURN_GNT_8822C))
#define BIT_GET_EFUSE_BURN_GNT_8822C(x) \
(((x) >> BIT_SHIFT_EFUSE_BURN_GNT_8822C) & \
BIT_MASK_EFUSE_BURN_GNT_8822C)
#define BIT_SET_EFUSE_BURN_GNT_8822C(x, v) \
(BIT_CLEAR_EFUSE_BURN_GNT_8822C(x) | BIT_EFUSE_BURN_GNT_8822C(v))
#define BIT_STOP_WL_PMC_8822C BIT(9)
#define BIT_STOP_SYM_PMC_8822C BIT(8)
#define BIT_BT_ACCESS_WL_PAGE0_8822C BIT(6)
#define BIT_REG_RST_WLPMC_8822C BIT(5)
#define BIT_REG_RST_PD12N_8822C BIT(4)
#define BIT_SYSON_DIS_WLREG_WRMSK_8822C BIT(3)
#define BIT_SYSON_DIS_PMCREG_WRMSK_8822C BIT(2)
#define BIT_SHIFT_SYSON_REG_ARB_8822C 0
#define BIT_MASK_SYSON_REG_ARB_8822C 0x3
#define BIT_SYSON_REG_ARB_8822C(x) \
(((x) & BIT_MASK_SYSON_REG_ARB_8822C) << BIT_SHIFT_SYSON_REG_ARB_8822C)
#define BITS_SYSON_REG_ARB_8822C \
(BIT_MASK_SYSON_REG_ARB_8822C << BIT_SHIFT_SYSON_REG_ARB_8822C)
#define BIT_CLEAR_SYSON_REG_ARB_8822C(x) ((x) & (~BITS_SYSON_REG_ARB_8822C))
#define BIT_GET_SYSON_REG_ARB_8822C(x) \
(((x) >> BIT_SHIFT_SYSON_REG_ARB_8822C) & BIT_MASK_SYSON_REG_ARB_8822C)
#define BIT_SET_SYSON_REG_ARB_8822C(x, v) \
(BIT_CLEAR_SYSON_REG_ARB_8822C(x) | BIT_SYSON_REG_ARB_8822C(v))
/* 2 REG_BIST_CTRL_8822C */
#define BIT_BIST_USB_DIS_8822C BIT(27)
#define BIT_BIST_PCI_DIS_8822C BIT(26)
#define BIT_BIST_BT_DIS_8822C BIT(25)
#define BIT_BIST_WL_DIS_8822C BIT(24)
#define BIT_SHIFT_BIST_RPT_SEL_8822C 16
#define BIT_MASK_BIST_RPT_SEL_8822C 0xf
#define BIT_BIST_RPT_SEL_8822C(x) \
(((x) & BIT_MASK_BIST_RPT_SEL_8822C) << BIT_SHIFT_BIST_RPT_SEL_8822C)
#define BITS_BIST_RPT_SEL_8822C \
(BIT_MASK_BIST_RPT_SEL_8822C << BIT_SHIFT_BIST_RPT_SEL_8822C)
#define BIT_CLEAR_BIST_RPT_SEL_8822C(x) ((x) & (~BITS_BIST_RPT_SEL_8822C))
#define BIT_GET_BIST_RPT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_BIST_RPT_SEL_8822C) & BIT_MASK_BIST_RPT_SEL_8822C)
#define BIT_SET_BIST_RPT_SEL_8822C(x, v) \
(BIT_CLEAR_BIST_RPT_SEL_8822C(x) | BIT_BIST_RPT_SEL_8822C(v))
#define BIT_BIST_RESUME_PS_8822C BIT(4)
#define BIT_BIST_RESUME_8822C BIT(3)
#define BIT_BIST_NORMAL_8822C BIT(2)
#define BIT_BIST_RSTN_8822C BIT(1)
#define BIT_BIST_CLK_EN_8822C BIT(0)
/* 2 REG_BIST_RPT_8822C */
#define BIT_SHIFT_MBIST_REPORT_8822C 0
#define BIT_MASK_MBIST_REPORT_8822C 0xffffffffL
#define BIT_MBIST_REPORT_8822C(x) \
(((x) & BIT_MASK_MBIST_REPORT_8822C) << BIT_SHIFT_MBIST_REPORT_8822C)
#define BITS_MBIST_REPORT_8822C \
(BIT_MASK_MBIST_REPORT_8822C << BIT_SHIFT_MBIST_REPORT_8822C)
#define BIT_CLEAR_MBIST_REPORT_8822C(x) ((x) & (~BITS_MBIST_REPORT_8822C))
#define BIT_GET_MBIST_REPORT_8822C(x) \
(((x) >> BIT_SHIFT_MBIST_REPORT_8822C) & BIT_MASK_MBIST_REPORT_8822C)
#define BIT_SET_MBIST_REPORT_8822C(x, v) \
(BIT_CLEAR_MBIST_REPORT_8822C(x) | BIT_MBIST_REPORT_8822C(v))
/* 2 REG_MEM_CTRL_8822C */
#define BIT_UMEM_RME_8822C BIT(31)
#define BIT_SHIFT_BT_SPRAM_8822C 28
#define BIT_MASK_BT_SPRAM_8822C 0x3
#define BIT_BT_SPRAM_8822C(x) \
(((x) & BIT_MASK_BT_SPRAM_8822C) << BIT_SHIFT_BT_SPRAM_8822C)
#define BITS_BT_SPRAM_8822C \
(BIT_MASK_BT_SPRAM_8822C << BIT_SHIFT_BT_SPRAM_8822C)
#define BIT_CLEAR_BT_SPRAM_8822C(x) ((x) & (~BITS_BT_SPRAM_8822C))
#define BIT_GET_BT_SPRAM_8822C(x) \
(((x) >> BIT_SHIFT_BT_SPRAM_8822C) & BIT_MASK_BT_SPRAM_8822C)
#define BIT_SET_BT_SPRAM_8822C(x, v) \
(BIT_CLEAR_BT_SPRAM_8822C(x) | BIT_BT_SPRAM_8822C(v))
#define BIT_SHIFT_BT_ROM_8822C 24
#define BIT_MASK_BT_ROM_8822C 0xf
#define BIT_BT_ROM_8822C(x) \
(((x) & BIT_MASK_BT_ROM_8822C) << BIT_SHIFT_BT_ROM_8822C)
#define BITS_BT_ROM_8822C (BIT_MASK_BT_ROM_8822C << BIT_SHIFT_BT_ROM_8822C)
#define BIT_CLEAR_BT_ROM_8822C(x) ((x) & (~BITS_BT_ROM_8822C))
#define BIT_GET_BT_ROM_8822C(x) \
(((x) >> BIT_SHIFT_BT_ROM_8822C) & BIT_MASK_BT_ROM_8822C)
#define BIT_SET_BT_ROM_8822C(x, v) \
(BIT_CLEAR_BT_ROM_8822C(x) | BIT_BT_ROM_8822C(v))
#define BIT_SHIFT_PCI_DPRAM_8822C 10
#define BIT_MASK_PCI_DPRAM_8822C 0x3
#define BIT_PCI_DPRAM_8822C(x) \
(((x) & BIT_MASK_PCI_DPRAM_8822C) << BIT_SHIFT_PCI_DPRAM_8822C)
#define BITS_PCI_DPRAM_8822C \
(BIT_MASK_PCI_DPRAM_8822C << BIT_SHIFT_PCI_DPRAM_8822C)
#define BIT_CLEAR_PCI_DPRAM_8822C(x) ((x) & (~BITS_PCI_DPRAM_8822C))
#define BIT_GET_PCI_DPRAM_8822C(x) \
(((x) >> BIT_SHIFT_PCI_DPRAM_8822C) & BIT_MASK_PCI_DPRAM_8822C)
#define BIT_SET_PCI_DPRAM_8822C(x, v) \
(BIT_CLEAR_PCI_DPRAM_8822C(x) | BIT_PCI_DPRAM_8822C(v))
#define BIT_SHIFT_PCI_SPRAM_8822C 8
#define BIT_MASK_PCI_SPRAM_8822C 0x3
#define BIT_PCI_SPRAM_8822C(x) \
(((x) & BIT_MASK_PCI_SPRAM_8822C) << BIT_SHIFT_PCI_SPRAM_8822C)
#define BITS_PCI_SPRAM_8822C \
(BIT_MASK_PCI_SPRAM_8822C << BIT_SHIFT_PCI_SPRAM_8822C)
#define BIT_CLEAR_PCI_SPRAM_8822C(x) ((x) & (~BITS_PCI_SPRAM_8822C))
#define BIT_GET_PCI_SPRAM_8822C(x) \
(((x) >> BIT_SHIFT_PCI_SPRAM_8822C) & BIT_MASK_PCI_SPRAM_8822C)
#define BIT_SET_PCI_SPRAM_8822C(x, v) \
(BIT_CLEAR_PCI_SPRAM_8822C(x) | BIT_PCI_SPRAM_8822C(v))
#define BIT_SHIFT_USB_SPRAM_8822C 6
#define BIT_MASK_USB_SPRAM_8822C 0x3
#define BIT_USB_SPRAM_8822C(x) \
(((x) & BIT_MASK_USB_SPRAM_8822C) << BIT_SHIFT_USB_SPRAM_8822C)
#define BITS_USB_SPRAM_8822C \
(BIT_MASK_USB_SPRAM_8822C << BIT_SHIFT_USB_SPRAM_8822C)
#define BIT_CLEAR_USB_SPRAM_8822C(x) ((x) & (~BITS_USB_SPRAM_8822C))
#define BIT_GET_USB_SPRAM_8822C(x) \
(((x) >> BIT_SHIFT_USB_SPRAM_8822C) & BIT_MASK_USB_SPRAM_8822C)
#define BIT_SET_USB_SPRAM_8822C(x, v) \
(BIT_CLEAR_USB_SPRAM_8822C(x) | BIT_USB_SPRAM_8822C(v))
#define BIT_SHIFT_USB_SPRF_8822C 4
#define BIT_MASK_USB_SPRF_8822C 0x3
#define BIT_USB_SPRF_8822C(x) \
(((x) & BIT_MASK_USB_SPRF_8822C) << BIT_SHIFT_USB_SPRF_8822C)
#define BITS_USB_SPRF_8822C \
(BIT_MASK_USB_SPRF_8822C << BIT_SHIFT_USB_SPRF_8822C)
#define BIT_CLEAR_USB_SPRF_8822C(x) ((x) & (~BITS_USB_SPRF_8822C))
#define BIT_GET_USB_SPRF_8822C(x) \
(((x) >> BIT_SHIFT_USB_SPRF_8822C) & BIT_MASK_USB_SPRF_8822C)
#define BIT_SET_USB_SPRF_8822C(x, v) \
(BIT_CLEAR_USB_SPRF_8822C(x) | BIT_USB_SPRF_8822C(v))
#define BIT_SHIFT_MCU_ROM_8822C 0
#define BIT_MASK_MCU_ROM_8822C 0xf
#define BIT_MCU_ROM_8822C(x) \
(((x) & BIT_MASK_MCU_ROM_8822C) << BIT_SHIFT_MCU_ROM_8822C)
#define BITS_MCU_ROM_8822C (BIT_MASK_MCU_ROM_8822C << BIT_SHIFT_MCU_ROM_8822C)
#define BIT_CLEAR_MCU_ROM_8822C(x) ((x) & (~BITS_MCU_ROM_8822C))
#define BIT_GET_MCU_ROM_8822C(x) \
(((x) >> BIT_SHIFT_MCU_ROM_8822C) & BIT_MASK_MCU_ROM_8822C)
#define BIT_SET_MCU_ROM_8822C(x, v) \
(BIT_CLEAR_MCU_ROM_8822C(x) | BIT_MCU_ROM_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_USB_SIE_INTF_8822C */
#define BIT_RD_SEL_8822C BIT(31)
#define BIT_USB_SIE_INTF_WE_V1_8822C BIT(30)
#define BIT_USB_SIE_INTF_BYIOREG_V1_8822C BIT(29)
#define BIT_USB_SIE_SELECT_8822C BIT(28)
#define BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822C 16
#define BIT_MASK_USB_SIE_INTF_ADDR_V1_8822C 0x1ff
#define BIT_USB_SIE_INTF_ADDR_V1_8822C(x) \
(((x) & BIT_MASK_USB_SIE_INTF_ADDR_V1_8822C) \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822C)
#define BITS_USB_SIE_INTF_ADDR_V1_8822C \
(BIT_MASK_USB_SIE_INTF_ADDR_V1_8822C \
<< BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822C)
#define BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8822C(x) \
((x) & (~BITS_USB_SIE_INTF_ADDR_V1_8822C))
#define BIT_GET_USB_SIE_INTF_ADDR_V1_8822C(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_ADDR_V1_8822C) & \
BIT_MASK_USB_SIE_INTF_ADDR_V1_8822C)
#define BIT_SET_USB_SIE_INTF_ADDR_V1_8822C(x, v) \
(BIT_CLEAR_USB_SIE_INTF_ADDR_V1_8822C(x) | \
BIT_USB_SIE_INTF_ADDR_V1_8822C(v))
#define BIT_SHIFT_USB_SIE_INTF_RD_8822C 8
#define BIT_MASK_USB_SIE_INTF_RD_8822C 0xff
#define BIT_USB_SIE_INTF_RD_8822C(x) \
(((x) & BIT_MASK_USB_SIE_INTF_RD_8822C) \
<< BIT_SHIFT_USB_SIE_INTF_RD_8822C)
#define BITS_USB_SIE_INTF_RD_8822C \
(BIT_MASK_USB_SIE_INTF_RD_8822C << BIT_SHIFT_USB_SIE_INTF_RD_8822C)
#define BIT_CLEAR_USB_SIE_INTF_RD_8822C(x) ((x) & (~BITS_USB_SIE_INTF_RD_8822C))
#define BIT_GET_USB_SIE_INTF_RD_8822C(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_RD_8822C) & \
BIT_MASK_USB_SIE_INTF_RD_8822C)
#define BIT_SET_USB_SIE_INTF_RD_8822C(x, v) \
(BIT_CLEAR_USB_SIE_INTF_RD_8822C(x) | BIT_USB_SIE_INTF_RD_8822C(v))
#define BIT_SHIFT_USB_SIE_INTF_WD_8822C 0
#define BIT_MASK_USB_SIE_INTF_WD_8822C 0xff
#define BIT_USB_SIE_INTF_WD_8822C(x) \
(((x) & BIT_MASK_USB_SIE_INTF_WD_8822C) \
<< BIT_SHIFT_USB_SIE_INTF_WD_8822C)
#define BITS_USB_SIE_INTF_WD_8822C \
(BIT_MASK_USB_SIE_INTF_WD_8822C << BIT_SHIFT_USB_SIE_INTF_WD_8822C)
#define BIT_CLEAR_USB_SIE_INTF_WD_8822C(x) ((x) & (~BITS_USB_SIE_INTF_WD_8822C))
#define BIT_GET_USB_SIE_INTF_WD_8822C(x) \
(((x) >> BIT_SHIFT_USB_SIE_INTF_WD_8822C) & \
BIT_MASK_USB_SIE_INTF_WD_8822C)
#define BIT_SET_USB_SIE_INTF_WD_8822C(x, v) \
(BIT_CLEAR_USB_SIE_INTF_WD_8822C(x) | BIT_USB_SIE_INTF_WD_8822C(v))
/* 2 REG_PCIE_MIO_INTF_8822C */
#define BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8822C 16
#define BIT_MASK_PCIE_MIO_ADDR_PAGE_8822C 0x3
#define BIT_PCIE_MIO_ADDR_PAGE_8822C(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_PAGE_8822C) \
<< BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8822C)
#define BITS_PCIE_MIO_ADDR_PAGE_8822C \
(BIT_MASK_PCIE_MIO_ADDR_PAGE_8822C \
<< BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8822C)
#define BIT_CLEAR_PCIE_MIO_ADDR_PAGE_8822C(x) \
((x) & (~BITS_PCIE_MIO_ADDR_PAGE_8822C))
#define BIT_GET_PCIE_MIO_ADDR_PAGE_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_PAGE_8822C) & \
BIT_MASK_PCIE_MIO_ADDR_PAGE_8822C)
#define BIT_SET_PCIE_MIO_ADDR_PAGE_8822C(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_PAGE_8822C(x) | \
BIT_PCIE_MIO_ADDR_PAGE_8822C(v))
#define BIT_PCIE_MIO_BYIOREG_8822C BIT(13)
#define BIT_PCIE_MIO_RE_8822C BIT(12)
#define BIT_SHIFT_PCIE_MIO_WE_8822C 8
#define BIT_MASK_PCIE_MIO_WE_8822C 0xf
#define BIT_PCIE_MIO_WE_8822C(x) \
(((x) & BIT_MASK_PCIE_MIO_WE_8822C) << BIT_SHIFT_PCIE_MIO_WE_8822C)
#define BITS_PCIE_MIO_WE_8822C \
(BIT_MASK_PCIE_MIO_WE_8822C << BIT_SHIFT_PCIE_MIO_WE_8822C)
#define BIT_CLEAR_PCIE_MIO_WE_8822C(x) ((x) & (~BITS_PCIE_MIO_WE_8822C))
#define BIT_GET_PCIE_MIO_WE_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_WE_8822C) & BIT_MASK_PCIE_MIO_WE_8822C)
#define BIT_SET_PCIE_MIO_WE_8822C(x, v) \
(BIT_CLEAR_PCIE_MIO_WE_8822C(x) | BIT_PCIE_MIO_WE_8822C(v))
#define BIT_SHIFT_PCIE_MIO_ADDR_8822C 0
#define BIT_MASK_PCIE_MIO_ADDR_8822C 0xff
#define BIT_PCIE_MIO_ADDR_8822C(x) \
(((x) & BIT_MASK_PCIE_MIO_ADDR_8822C) << BIT_SHIFT_PCIE_MIO_ADDR_8822C)
#define BITS_PCIE_MIO_ADDR_8822C \
(BIT_MASK_PCIE_MIO_ADDR_8822C << BIT_SHIFT_PCIE_MIO_ADDR_8822C)
#define BIT_CLEAR_PCIE_MIO_ADDR_8822C(x) ((x) & (~BITS_PCIE_MIO_ADDR_8822C))
#define BIT_GET_PCIE_MIO_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_ADDR_8822C) & BIT_MASK_PCIE_MIO_ADDR_8822C)
#define BIT_SET_PCIE_MIO_ADDR_8822C(x, v) \
(BIT_CLEAR_PCIE_MIO_ADDR_8822C(x) | BIT_PCIE_MIO_ADDR_8822C(v))
/* 2 REG_PCIE_MIO_INTD_8822C */
#define BIT_SHIFT_PCIE_MIO_DATA_8822C 0
#define BIT_MASK_PCIE_MIO_DATA_8822C 0xffffffffL
#define BIT_PCIE_MIO_DATA_8822C(x) \
(((x) & BIT_MASK_PCIE_MIO_DATA_8822C) << BIT_SHIFT_PCIE_MIO_DATA_8822C)
#define BITS_PCIE_MIO_DATA_8822C \
(BIT_MASK_PCIE_MIO_DATA_8822C << BIT_SHIFT_PCIE_MIO_DATA_8822C)
#define BIT_CLEAR_PCIE_MIO_DATA_8822C(x) ((x) & (~BITS_PCIE_MIO_DATA_8822C))
#define BIT_GET_PCIE_MIO_DATA_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MIO_DATA_8822C) & BIT_MASK_PCIE_MIO_DATA_8822C)
#define BIT_SET_PCIE_MIO_DATA_8822C(x, v) \
(BIT_CLEAR_PCIE_MIO_DATA_8822C(x) | BIT_PCIE_MIO_DATA_8822C(v))
/* 2 REG_WLRF1_8822C */
#define BIT_SHIFT_WLRF1_CTRL_8822C 24
#define BIT_MASK_WLRF1_CTRL_8822C 0xff
#define BIT_WLRF1_CTRL_8822C(x) \
(((x) & BIT_MASK_WLRF1_CTRL_8822C) << BIT_SHIFT_WLRF1_CTRL_8822C)
#define BITS_WLRF1_CTRL_8822C \
(BIT_MASK_WLRF1_CTRL_8822C << BIT_SHIFT_WLRF1_CTRL_8822C)
#define BIT_CLEAR_WLRF1_CTRL_8822C(x) ((x) & (~BITS_WLRF1_CTRL_8822C))
#define BIT_GET_WLRF1_CTRL_8822C(x) \
(((x) >> BIT_SHIFT_WLRF1_CTRL_8822C) & BIT_MASK_WLRF1_CTRL_8822C)
#define BIT_SET_WLRF1_CTRL_8822C(x, v) \
(BIT_CLEAR_WLRF1_CTRL_8822C(x) | BIT_WLRF1_CTRL_8822C(v))
/* 2 REG_SYS_CFG1_8822C */
#define BIT_SHIFT_TRP_ICFG_8822C 28
#define BIT_MASK_TRP_ICFG_8822C 0xf
#define BIT_TRP_ICFG_8822C(x) \
(((x) & BIT_MASK_TRP_ICFG_8822C) << BIT_SHIFT_TRP_ICFG_8822C)
#define BITS_TRP_ICFG_8822C \
(BIT_MASK_TRP_ICFG_8822C << BIT_SHIFT_TRP_ICFG_8822C)
#define BIT_CLEAR_TRP_ICFG_8822C(x) ((x) & (~BITS_TRP_ICFG_8822C))
#define BIT_GET_TRP_ICFG_8822C(x) \
(((x) >> BIT_SHIFT_TRP_ICFG_8822C) & BIT_MASK_TRP_ICFG_8822C)
#define BIT_SET_TRP_ICFG_8822C(x, v) \
(BIT_CLEAR_TRP_ICFG_8822C(x) | BIT_TRP_ICFG_8822C(v))
#define BIT_RF_TYPE_ID_8822C BIT(27)
#define BIT_BD_HCI_SEL_8822C BIT(26)
#define BIT_BD_PKG_SEL_8822C BIT(25)
#define BIT_INTERNAL_EXTERNAL_SWR_8822C BIT(24)
#define BIT_RTL_ID_8822C BIT(23)
#define BIT_PAD_HWPD_IDN_8822C BIT(22)
#define BIT_TESTMODE_8822C BIT(20)
#define BIT_SHIFT_VENDOR_ID_8822C 16
#define BIT_MASK_VENDOR_ID_8822C 0xf
#define BIT_VENDOR_ID_8822C(x) \
(((x) & BIT_MASK_VENDOR_ID_8822C) << BIT_SHIFT_VENDOR_ID_8822C)
#define BITS_VENDOR_ID_8822C \
(BIT_MASK_VENDOR_ID_8822C << BIT_SHIFT_VENDOR_ID_8822C)
#define BIT_CLEAR_VENDOR_ID_8822C(x) ((x) & (~BITS_VENDOR_ID_8822C))
#define BIT_GET_VENDOR_ID_8822C(x) \
(((x) >> BIT_SHIFT_VENDOR_ID_8822C) & BIT_MASK_VENDOR_ID_8822C)
#define BIT_SET_VENDOR_ID_8822C(x, v) \
(BIT_CLEAR_VENDOR_ID_8822C(x) | BIT_VENDOR_ID_8822C(v))
#define BIT_SHIFT_CHIP_VER_8822C 12
#define BIT_MASK_CHIP_VER_8822C 0xf
#define BIT_CHIP_VER_8822C(x) \
(((x) & BIT_MASK_CHIP_VER_8822C) << BIT_SHIFT_CHIP_VER_8822C)
#define BITS_CHIP_VER_8822C \
(BIT_MASK_CHIP_VER_8822C << BIT_SHIFT_CHIP_VER_8822C)
#define BIT_CLEAR_CHIP_VER_8822C(x) ((x) & (~BITS_CHIP_VER_8822C))
#define BIT_GET_CHIP_VER_8822C(x) \
(((x) >> BIT_SHIFT_CHIP_VER_8822C) & BIT_MASK_CHIP_VER_8822C)
#define BIT_SET_CHIP_VER_8822C(x, v) \
(BIT_CLEAR_CHIP_VER_8822C(x) | BIT_CHIP_VER_8822C(v))
#define BIT_BD_MAC3_8822C BIT(11)
#define BIT_BD_MAC1_8822C BIT(10)
#define BIT_BD_MAC2_8822C BIT(9)
#define BIT_SIC_IDLE_8822C BIT(8)
#define BIT_SW_OFFLOAD_EN_8822C BIT(7)
#define BIT_OCP_SHUTDN_8822C BIT(6)
#define BIT_V15_VLD_8822C BIT(5)
#define BIT_PCIRSTB_8822C BIT(4)
#define BIT_PCLK_VLD_8822C BIT(3)
#define BIT_UCLK_VLD_8822C BIT(2)
#define BIT_ACLK_VLD_8822C BIT(1)
#define BIT_XCLK_VLD_8822C BIT(0)
/* 2 REG_SYS_STATUS1_8822C */
#define BIT_SHIFT_RF_RL_ID_8822C 28
#define BIT_MASK_RF_RL_ID_8822C 0xf
#define BIT_RF_RL_ID_8822C(x) \
(((x) & BIT_MASK_RF_RL_ID_8822C) << BIT_SHIFT_RF_RL_ID_8822C)
#define BITS_RF_RL_ID_8822C \
(BIT_MASK_RF_RL_ID_8822C << BIT_SHIFT_RF_RL_ID_8822C)
#define BIT_CLEAR_RF_RL_ID_8822C(x) ((x) & (~BITS_RF_RL_ID_8822C))
#define BIT_GET_RF_RL_ID_8822C(x) \
(((x) >> BIT_SHIFT_RF_RL_ID_8822C) & BIT_MASK_RF_RL_ID_8822C)
#define BIT_SET_RF_RL_ID_8822C(x, v) \
(BIT_CLEAR_RF_RL_ID_8822C(x) | BIT_RF_RL_ID_8822C(v))
#define BIT_HPHY_ICFG_8822C BIT(19)
#define BIT_SHIFT_SEL_0XC0_8822C 16
#define BIT_MASK_SEL_0XC0_8822C 0x3
#define BIT_SEL_0XC0_8822C(x) \
(((x) & BIT_MASK_SEL_0XC0_8822C) << BIT_SHIFT_SEL_0XC0_8822C)
#define BITS_SEL_0XC0_8822C \
(BIT_MASK_SEL_0XC0_8822C << BIT_SHIFT_SEL_0XC0_8822C)
#define BIT_CLEAR_SEL_0XC0_8822C(x) ((x) & (~BITS_SEL_0XC0_8822C))
#define BIT_GET_SEL_0XC0_8822C(x) \
(((x) >> BIT_SHIFT_SEL_0XC0_8822C) & BIT_MASK_SEL_0XC0_8822C)
#define BIT_SET_SEL_0XC0_8822C(x, v) \
(BIT_CLEAR_SEL_0XC0_8822C(x) | BIT_SEL_0XC0_8822C(v))
#define BIT_SHIFT_HCI_SEL_V4_8822C 12
#define BIT_MASK_HCI_SEL_V4_8822C 0x3
#define BIT_HCI_SEL_V4_8822C(x) \
(((x) & BIT_MASK_HCI_SEL_V4_8822C) << BIT_SHIFT_HCI_SEL_V4_8822C)
#define BITS_HCI_SEL_V4_8822C \
(BIT_MASK_HCI_SEL_V4_8822C << BIT_SHIFT_HCI_SEL_V4_8822C)
#define BIT_CLEAR_HCI_SEL_V4_8822C(x) ((x) & (~BITS_HCI_SEL_V4_8822C))
#define BIT_GET_HCI_SEL_V4_8822C(x) \
(((x) >> BIT_SHIFT_HCI_SEL_V4_8822C) & BIT_MASK_HCI_SEL_V4_8822C)
#define BIT_SET_HCI_SEL_V4_8822C(x, v) \
(BIT_CLEAR_HCI_SEL_V4_8822C(x) | BIT_HCI_SEL_V4_8822C(v))
#define BIT_USB_OPERATION_MODE_8822C BIT(10)
#define BIT_BT_PDN_8822C BIT(9)
#define BIT_AUTO_WLPON_8822C BIT(8)
#define BIT_WL_MODE_8822C BIT(7)
#define BIT_PKG_SEL_HCI_8822C BIT(6)
#define BIT_SHIFT_PAD_HCI_SEL_V2_8822C 3
#define BIT_MASK_PAD_HCI_SEL_V2_8822C 0x3
#define BIT_PAD_HCI_SEL_V2_8822C(x) \
(((x) & BIT_MASK_PAD_HCI_SEL_V2_8822C) \
<< BIT_SHIFT_PAD_HCI_SEL_V2_8822C)
#define BITS_PAD_HCI_SEL_V2_8822C \
(BIT_MASK_PAD_HCI_SEL_V2_8822C << BIT_SHIFT_PAD_HCI_SEL_V2_8822C)
#define BIT_CLEAR_PAD_HCI_SEL_V2_8822C(x) ((x) & (~BITS_PAD_HCI_SEL_V2_8822C))
#define BIT_GET_PAD_HCI_SEL_V2_8822C(x) \
(((x) >> BIT_SHIFT_PAD_HCI_SEL_V2_8822C) & \
BIT_MASK_PAD_HCI_SEL_V2_8822C)
#define BIT_SET_PAD_HCI_SEL_V2_8822C(x, v) \
(BIT_CLEAR_PAD_HCI_SEL_V2_8822C(x) | BIT_PAD_HCI_SEL_V2_8822C(v))
#define BIT_SHIFT_EFS_HCI_SEL_V1_8822C 0
#define BIT_MASK_EFS_HCI_SEL_V1_8822C 0x7
#define BIT_EFS_HCI_SEL_V1_8822C(x) \
(((x) & BIT_MASK_EFS_HCI_SEL_V1_8822C) \
<< BIT_SHIFT_EFS_HCI_SEL_V1_8822C)
#define BITS_EFS_HCI_SEL_V1_8822C \
(BIT_MASK_EFS_HCI_SEL_V1_8822C << BIT_SHIFT_EFS_HCI_SEL_V1_8822C)
#define BIT_CLEAR_EFS_HCI_SEL_V1_8822C(x) ((x) & (~BITS_EFS_HCI_SEL_V1_8822C))
#define BIT_GET_EFS_HCI_SEL_V1_8822C(x) \
(((x) >> BIT_SHIFT_EFS_HCI_SEL_V1_8822C) & \
BIT_MASK_EFS_HCI_SEL_V1_8822C)
#define BIT_SET_EFS_HCI_SEL_V1_8822C(x, v) \
(BIT_CLEAR_EFS_HCI_SEL_V1_8822C(x) | BIT_EFS_HCI_SEL_V1_8822C(v))
/* 2 REG_SYS_STATUS2_8822C */
#define BIT_HIOE_ON_TIMEOUT_8822C BIT(23)
#define BIT_SIC_ON_TIMEOUT_8822C BIT(22)
#define BIT_CPU_ON_TIMEOUT_8822C BIT(21)
#define BIT_HCI_ON_TIMEOUT_8822C BIT(20)
#define BIT_SIO_ALDN_8822C BIT(19)
#define BIT_USB_ALDN_8822C BIT(18)
#define BIT_PCI_ALDN_8822C BIT(17)
#define BIT_SYS_ALDN_8822C BIT(16)
#define BIT_SHIFT_EPVID1_8822C 8
#define BIT_MASK_EPVID1_8822C 0xff
#define BIT_EPVID1_8822C(x) \
(((x) & BIT_MASK_EPVID1_8822C) << BIT_SHIFT_EPVID1_8822C)
#define BITS_EPVID1_8822C (BIT_MASK_EPVID1_8822C << BIT_SHIFT_EPVID1_8822C)
#define BIT_CLEAR_EPVID1_8822C(x) ((x) & (~BITS_EPVID1_8822C))
#define BIT_GET_EPVID1_8822C(x) \
(((x) >> BIT_SHIFT_EPVID1_8822C) & BIT_MASK_EPVID1_8822C)
#define BIT_SET_EPVID1_8822C(x, v) \
(BIT_CLEAR_EPVID1_8822C(x) | BIT_EPVID1_8822C(v))
#define BIT_SHIFT_EPVID0_8822C 0
#define BIT_MASK_EPVID0_8822C 0xff
#define BIT_EPVID0_8822C(x) \
(((x) & BIT_MASK_EPVID0_8822C) << BIT_SHIFT_EPVID0_8822C)
#define BITS_EPVID0_8822C (BIT_MASK_EPVID0_8822C << BIT_SHIFT_EPVID0_8822C)
#define BIT_CLEAR_EPVID0_8822C(x) ((x) & (~BITS_EPVID0_8822C))
#define BIT_GET_EPVID0_8822C(x) \
(((x) >> BIT_SHIFT_EPVID0_8822C) & BIT_MASK_EPVID0_8822C)
#define BIT_SET_EPVID0_8822C(x, v) \
(BIT_CLEAR_EPVID0_8822C(x) | BIT_EPVID0_8822C(v))
/* 2 REG_SYS_CFG2_8822C */
#define BIT_HCI_SEL_EMBEDDED_8822C BIT(8)
#define BIT_SHIFT_HW_ID_8822C 0
#define BIT_MASK_HW_ID_8822C 0xff
#define BIT_HW_ID_8822C(x) \
(((x) & BIT_MASK_HW_ID_8822C) << BIT_SHIFT_HW_ID_8822C)
#define BITS_HW_ID_8822C (BIT_MASK_HW_ID_8822C << BIT_SHIFT_HW_ID_8822C)
#define BIT_CLEAR_HW_ID_8822C(x) ((x) & (~BITS_HW_ID_8822C))
#define BIT_GET_HW_ID_8822C(x) \
(((x) >> BIT_SHIFT_HW_ID_8822C) & BIT_MASK_HW_ID_8822C)
#define BIT_SET_HW_ID_8822C(x, v) \
(BIT_CLEAR_HW_ID_8822C(x) | BIT_HW_ID_8822C(v))
/* 2 REG_SYS_CFG3_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ANAPARSW_MAC_0_8822C */
#define BIT_OCP_L_8822C BIT(31)
#define BIT_POWOCP_L_8822C BIT(30)
#define BIT_SHIFT_CF_L_V2_8822C 28
#define BIT_MASK_CF_L_V2_8822C 0x3
#define BIT_CF_L_V2_8822C(x) \
(((x) & BIT_MASK_CF_L_V2_8822C) << BIT_SHIFT_CF_L_V2_8822C)
#define BITS_CF_L_V2_8822C (BIT_MASK_CF_L_V2_8822C << BIT_SHIFT_CF_L_V2_8822C)
#define BIT_CLEAR_CF_L_V2_8822C(x) ((x) & (~BITS_CF_L_V2_8822C))
#define BIT_GET_CF_L_V2_8822C(x) \
(((x) >> BIT_SHIFT_CF_L_V2_8822C) & BIT_MASK_CF_L_V2_8822C)
#define BIT_SET_CF_L_V2_8822C(x, v) \
(BIT_CLEAR_CF_L_V2_8822C(x) | BIT_CF_L_V2_8822C(v))
#define BIT_SHIFT_CFC_L_V2_8822C 26
#define BIT_MASK_CFC_L_V2_8822C 0x3
#define BIT_CFC_L_V2_8822C(x) \
(((x) & BIT_MASK_CFC_L_V2_8822C) << BIT_SHIFT_CFC_L_V2_8822C)
#define BITS_CFC_L_V2_8822C \
(BIT_MASK_CFC_L_V2_8822C << BIT_SHIFT_CFC_L_V2_8822C)
#define BIT_CLEAR_CFC_L_V2_8822C(x) ((x) & (~BITS_CFC_L_V2_8822C))
#define BIT_GET_CFC_L_V2_8822C(x) \
(((x) >> BIT_SHIFT_CFC_L_V2_8822C) & BIT_MASK_CFC_L_V2_8822C)
#define BIT_SET_CFC_L_V2_8822C(x, v) \
(BIT_CLEAR_CFC_L_V2_8822C(x) | BIT_CFC_L_V2_8822C(v))
#define BIT_SHIFT_R3_L_V2_8822C 24
#define BIT_MASK_R3_L_V2_8822C 0x3
#define BIT_R3_L_V2_8822C(x) \
(((x) & BIT_MASK_R3_L_V2_8822C) << BIT_SHIFT_R3_L_V2_8822C)
#define BITS_R3_L_V2_8822C (BIT_MASK_R3_L_V2_8822C << BIT_SHIFT_R3_L_V2_8822C)
#define BIT_CLEAR_R3_L_V2_8822C(x) ((x) & (~BITS_R3_L_V2_8822C))
#define BIT_GET_R3_L_V2_8822C(x) \
(((x) >> BIT_SHIFT_R3_L_V2_8822C) & BIT_MASK_R3_L_V2_8822C)
#define BIT_SET_R3_L_V2_8822C(x, v) \
(BIT_CLEAR_R3_L_V2_8822C(x) | BIT_R3_L_V2_8822C(v))
#define BIT_SHIFT_R2_L_8822C 22
#define BIT_MASK_R2_L_8822C 0x3
#define BIT_R2_L_8822C(x) (((x) & BIT_MASK_R2_L_8822C) << BIT_SHIFT_R2_L_8822C)
#define BITS_R2_L_8822C (BIT_MASK_R2_L_8822C << BIT_SHIFT_R2_L_8822C)
#define BIT_CLEAR_R2_L_8822C(x) ((x) & (~BITS_R2_L_8822C))
#define BIT_GET_R2_L_8822C(x) \
(((x) >> BIT_SHIFT_R2_L_8822C) & BIT_MASK_R2_L_8822C)
#define BIT_SET_R2_L_8822C(x, v) (BIT_CLEAR_R2_L_8822C(x) | BIT_R2_L_8822C(v))
#define BIT_SHIFT_R1_L_8822C 20
#define BIT_MASK_R1_L_8822C 0x3
#define BIT_R1_L_8822C(x) (((x) & BIT_MASK_R1_L_8822C) << BIT_SHIFT_R1_L_8822C)
#define BITS_R1_L_8822C (BIT_MASK_R1_L_8822C << BIT_SHIFT_R1_L_8822C)
#define BIT_CLEAR_R1_L_8822C(x) ((x) & (~BITS_R1_L_8822C))
#define BIT_GET_R1_L_8822C(x) \
(((x) >> BIT_SHIFT_R1_L_8822C) & BIT_MASK_R1_L_8822C)
#define BIT_SET_R1_L_8822C(x, v) (BIT_CLEAR_R1_L_8822C(x) | BIT_R1_L_8822C(v))
#define BIT_SHIFT_C3_L_8822C 18
#define BIT_MASK_C3_L_8822C 0x3
#define BIT_C3_L_8822C(x) (((x) & BIT_MASK_C3_L_8822C) << BIT_SHIFT_C3_L_8822C)
#define BITS_C3_L_8822C (BIT_MASK_C3_L_8822C << BIT_SHIFT_C3_L_8822C)
#define BIT_CLEAR_C3_L_8822C(x) ((x) & (~BITS_C3_L_8822C))
#define BIT_GET_C3_L_8822C(x) \
(((x) >> BIT_SHIFT_C3_L_8822C) & BIT_MASK_C3_L_8822C)
#define BIT_SET_C3_L_8822C(x, v) (BIT_CLEAR_C3_L_8822C(x) | BIT_C3_L_8822C(v))
#define BIT_SHIFT_C2_L_8822C 16
#define BIT_MASK_C2_L_8822C 0x3
#define BIT_C2_L_8822C(x) (((x) & BIT_MASK_C2_L_8822C) << BIT_SHIFT_C2_L_8822C)
#define BITS_C2_L_8822C (BIT_MASK_C2_L_8822C << BIT_SHIFT_C2_L_8822C)
#define BIT_CLEAR_C2_L_8822C(x) ((x) & (~BITS_C2_L_8822C))
#define BIT_GET_C2_L_8822C(x) \
(((x) >> BIT_SHIFT_C2_L_8822C) & BIT_MASK_C2_L_8822C)
#define BIT_SET_C2_L_8822C(x, v) (BIT_CLEAR_C2_L_8822C(x) | BIT_C2_L_8822C(v))
#define BIT_SHIFT_C1_L_V2_8822C 14
#define BIT_MASK_C1_L_V2_8822C 0x3
#define BIT_C1_L_V2_8822C(x) \
(((x) & BIT_MASK_C1_L_V2_8822C) << BIT_SHIFT_C1_L_V2_8822C)
#define BITS_C1_L_V2_8822C (BIT_MASK_C1_L_V2_8822C << BIT_SHIFT_C1_L_V2_8822C)
#define BIT_CLEAR_C1_L_V2_8822C(x) ((x) & (~BITS_C1_L_V2_8822C))
#define BIT_GET_C1_L_V2_8822C(x) \
(((x) >> BIT_SHIFT_C1_L_V2_8822C) & BIT_MASK_C1_L_V2_8822C)
#define BIT_SET_C1_L_V2_8822C(x, v) \
(BIT_CLEAR_C1_L_V2_8822C(x) | BIT_C1_L_V2_8822C(v))
#define BIT_REG_OCPS_L_V2_8822C BIT(13)
#define BIT_REG_PWM_L_8822C BIT(12)
#define BIT_SHIFT_V15ADJ_L_8822C 9
#define BIT_MASK_V15ADJ_L_8822C 0x7
#define BIT_V15ADJ_L_8822C(x) \
(((x) & BIT_MASK_V15ADJ_L_8822C) << BIT_SHIFT_V15ADJ_L_8822C)
#define BITS_V15ADJ_L_8822C \
(BIT_MASK_V15ADJ_L_8822C << BIT_SHIFT_V15ADJ_L_8822C)
#define BIT_CLEAR_V15ADJ_L_8822C(x) ((x) & (~BITS_V15ADJ_L_8822C))
#define BIT_GET_V15ADJ_L_8822C(x) \
(((x) >> BIT_SHIFT_V15ADJ_L_8822C) & BIT_MASK_V15ADJ_L_8822C)
#define BIT_SET_V15ADJ_L_8822C(x, v) \
(BIT_CLEAR_V15ADJ_L_8822C(x) | BIT_V15ADJ_L_8822C(v))
#define BIT_SHIFT_IN_L_8822C 6
#define BIT_MASK_IN_L_8822C 0x7
#define BIT_IN_L_8822C(x) (((x) & BIT_MASK_IN_L_8822C) << BIT_SHIFT_IN_L_8822C)
#define BITS_IN_L_8822C (BIT_MASK_IN_L_8822C << BIT_SHIFT_IN_L_8822C)
#define BIT_CLEAR_IN_L_8822C(x) ((x) & (~BITS_IN_L_8822C))
#define BIT_GET_IN_L_8822C(x) \
(((x) >> BIT_SHIFT_IN_L_8822C) & BIT_MASK_IN_L_8822C)
#define BIT_SET_IN_L_8822C(x, v) (BIT_CLEAR_IN_L_8822C(x) | BIT_IN_L_8822C(v))
#define BIT_SHIFT_STD_L_8822C 4
#define BIT_MASK_STD_L_8822C 0x3
#define BIT_STD_L_8822C(x) \
(((x) & BIT_MASK_STD_L_8822C) << BIT_SHIFT_STD_L_8822C)
#define BITS_STD_L_8822C (BIT_MASK_STD_L_8822C << BIT_SHIFT_STD_L_8822C)
#define BIT_CLEAR_STD_L_8822C(x) ((x) & (~BITS_STD_L_8822C))
#define BIT_GET_STD_L_8822C(x) \
(((x) >> BIT_SHIFT_STD_L_8822C) & BIT_MASK_STD_L_8822C)
#define BIT_SET_STD_L_8822C(x, v) \
(BIT_CLEAR_STD_L_8822C(x) | BIT_STD_L_8822C(v))
#define BIT_SHIFT_VOL_L_8822C 0
#define BIT_MASK_VOL_L_8822C 0xf
#define BIT_VOL_L_8822C(x) \
(((x) & BIT_MASK_VOL_L_8822C) << BIT_SHIFT_VOL_L_8822C)
#define BITS_VOL_L_8822C (BIT_MASK_VOL_L_8822C << BIT_SHIFT_VOL_L_8822C)
#define BIT_CLEAR_VOL_L_8822C(x) ((x) & (~BITS_VOL_L_8822C))
#define BIT_GET_VOL_L_8822C(x) \
(((x) >> BIT_SHIFT_VOL_L_8822C) & BIT_MASK_VOL_L_8822C)
#define BIT_SET_VOL_L_8822C(x, v) \
(BIT_CLEAR_VOL_L_8822C(x) | BIT_VOL_L_8822C(v))
/* 2 REG_ANAPARSW_MAC_1_8822C */
#define BIT_SHIFT_OCP_L_PFM_8822C 29
#define BIT_MASK_OCP_L_PFM_8822C 0x7
#define BIT_OCP_L_PFM_8822C(x) \
(((x) & BIT_MASK_OCP_L_PFM_8822C) << BIT_SHIFT_OCP_L_PFM_8822C)
#define BITS_OCP_L_PFM_8822C \
(BIT_MASK_OCP_L_PFM_8822C << BIT_SHIFT_OCP_L_PFM_8822C)
#define BIT_CLEAR_OCP_L_PFM_8822C(x) ((x) & (~BITS_OCP_L_PFM_8822C))
#define BIT_GET_OCP_L_PFM_8822C(x) \
(((x) >> BIT_SHIFT_OCP_L_PFM_8822C) & BIT_MASK_OCP_L_PFM_8822C)
#define BIT_SET_OCP_L_PFM_8822C(x, v) \
(BIT_CLEAR_OCP_L_PFM_8822C(x) | BIT_OCP_L_PFM_8822C(v))
#define BIT_SHIFT_CFC_L_PFM_8822C 27
#define BIT_MASK_CFC_L_PFM_8822C 0x3
#define BIT_CFC_L_PFM_8822C(x) \
(((x) & BIT_MASK_CFC_L_PFM_8822C) << BIT_SHIFT_CFC_L_PFM_8822C)
#define BITS_CFC_L_PFM_8822C \
(BIT_MASK_CFC_L_PFM_8822C << BIT_SHIFT_CFC_L_PFM_8822C)
#define BIT_CLEAR_CFC_L_PFM_8822C(x) ((x) & (~BITS_CFC_L_PFM_8822C))
#define BIT_GET_CFC_L_PFM_8822C(x) \
(((x) >> BIT_SHIFT_CFC_L_PFM_8822C) & BIT_MASK_CFC_L_PFM_8822C)
#define BIT_SET_CFC_L_PFM_8822C(x, v) \
(BIT_CLEAR_CFC_L_PFM_8822C(x) | BIT_CFC_L_PFM_8822C(v))
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_REG_FREQ_L_V1_8822C 20
#define BIT_MASK_REG_FREQ_L_V1_8822C 0x7
#define BIT_REG_FREQ_L_V1_8822C(x) \
(((x) & BIT_MASK_REG_FREQ_L_V1_8822C) << BIT_SHIFT_REG_FREQ_L_V1_8822C)
#define BITS_REG_FREQ_L_V1_8822C \
(BIT_MASK_REG_FREQ_L_V1_8822C << BIT_SHIFT_REG_FREQ_L_V1_8822C)
#define BIT_CLEAR_REG_FREQ_L_V1_8822C(x) ((x) & (~BITS_REG_FREQ_L_V1_8822C))
#define BIT_GET_REG_FREQ_L_V1_8822C(x) \
(((x) >> BIT_SHIFT_REG_FREQ_L_V1_8822C) & BIT_MASK_REG_FREQ_L_V1_8822C)
#define BIT_SET_REG_FREQ_L_V1_8822C(x, v) \
(BIT_CLEAR_REG_FREQ_L_V1_8822C(x) | BIT_REG_FREQ_L_V1_8822C(v))
#define BIT_EN_DUTY_8822C BIT(19)
#define BIT_SHIFT_REG_MODE_V2_8822C 17
#define BIT_MASK_REG_MODE_V2_8822C 0x3
#define BIT_REG_MODE_V2_8822C(x) \
(((x) & BIT_MASK_REG_MODE_V2_8822C) << BIT_SHIFT_REG_MODE_V2_8822C)
#define BITS_REG_MODE_V2_8822C \
(BIT_MASK_REG_MODE_V2_8822C << BIT_SHIFT_REG_MODE_V2_8822C)
#define BIT_CLEAR_REG_MODE_V2_8822C(x) ((x) & (~BITS_REG_MODE_V2_8822C))
#define BIT_GET_REG_MODE_V2_8822C(x) \
(((x) >> BIT_SHIFT_REG_MODE_V2_8822C) & BIT_MASK_REG_MODE_V2_8822C)
#define BIT_SET_REG_MODE_V2_8822C(x, v) \
(BIT_CLEAR_REG_MODE_V2_8822C(x) | BIT_REG_MODE_V2_8822C(v))
#define BIT_EN_SP_8822C BIT(16)
#define BIT_REG_AUTO_L_V2_8822C BIT(15)
#define BIT_REG_LDOF_L_V2_8822C BIT(14)
#define BIT_REG_TYPE_L_V2_8822C BIT(13)
#define BIT_VO15_V1P05_H_8822C BIT(12)
#define BIT_ARENB_L_V2_8822C BIT(11)
#define BIT_SHIFT_TBOX_L1_V2_8822C 9
#define BIT_MASK_TBOX_L1_V2_8822C 0x3
#define BIT_TBOX_L1_V2_8822C(x) \
(((x) & BIT_MASK_TBOX_L1_V2_8822C) << BIT_SHIFT_TBOX_L1_V2_8822C)
#define BITS_TBOX_L1_V2_8822C \
(BIT_MASK_TBOX_L1_V2_8822C << BIT_SHIFT_TBOX_L1_V2_8822C)
#define BIT_CLEAR_TBOX_L1_V2_8822C(x) ((x) & (~BITS_TBOX_L1_V2_8822C))
#define BIT_GET_TBOX_L1_V2_8822C(x) \
(((x) >> BIT_SHIFT_TBOX_L1_V2_8822C) & BIT_MASK_TBOX_L1_V2_8822C)
#define BIT_SET_TBOX_L1_V2_8822C(x, v) \
(BIT_CLEAR_TBOX_L1_V2_8822C(x) | BIT_TBOX_L1_V2_8822C(v))
#define BIT_SHIFT_REG_DELAY_L_8822C 7
#define BIT_MASK_REG_DELAY_L_8822C 0x3
#define BIT_REG_DELAY_L_8822C(x) \
(((x) & BIT_MASK_REG_DELAY_L_8822C) << BIT_SHIFT_REG_DELAY_L_8822C)
#define BITS_REG_DELAY_L_8822C \
(BIT_MASK_REG_DELAY_L_8822C << BIT_SHIFT_REG_DELAY_L_8822C)
#define BIT_CLEAR_REG_DELAY_L_8822C(x) ((x) & (~BITS_REG_DELAY_L_8822C))
#define BIT_GET_REG_DELAY_L_8822C(x) \
(((x) >> BIT_SHIFT_REG_DELAY_L_8822C) & BIT_MASK_REG_DELAY_L_8822C)
#define BIT_SET_REG_DELAY_L_8822C(x, v) \
(BIT_CLEAR_REG_DELAY_L_8822C(x) | BIT_REG_DELAY_L_8822C(v))
#define BIT_REG_CLAMP_D_L_8822C BIT(6)
#define BIT_REG_BYPASS_L_V2_8822C BIT(5)
#define BIT_REG_AUTOZCD_L_8822C BIT(4)
#define BIT_POW_ZCD_L_V2_8822C BIT(3)
#define BIT_REG_HALF_L_8822C BIT(2)
#define BIT_SHIFT_OCP_L_V2_8822C 0
#define BIT_MASK_OCP_L_V2_8822C 0x3
#define BIT_OCP_L_V2_8822C(x) \
(((x) & BIT_MASK_OCP_L_V2_8822C) << BIT_SHIFT_OCP_L_V2_8822C)
#define BITS_OCP_L_V2_8822C \
(BIT_MASK_OCP_L_V2_8822C << BIT_SHIFT_OCP_L_V2_8822C)
#define BIT_CLEAR_OCP_L_V2_8822C(x) ((x) & (~BITS_OCP_L_V2_8822C))
#define BIT_GET_OCP_L_V2_8822C(x) \
(((x) >> BIT_SHIFT_OCP_L_V2_8822C) & BIT_MASK_OCP_L_V2_8822C)
#define BIT_SET_OCP_L_V2_8822C(x, v) \
(BIT_CLEAR_OCP_L_V2_8822C(x) | BIT_OCP_L_V2_8822C(v))
/* 2 REG_ANAPAR_MAC_0_8822C */
#define BIT_SHIFT_REG_LPF_R3_8822C 29
#define BIT_MASK_REG_LPF_R3_8822C 0x7
#define BIT_REG_LPF_R3_8822C(x) \
(((x) & BIT_MASK_REG_LPF_R3_8822C) << BIT_SHIFT_REG_LPF_R3_8822C)
#define BITS_REG_LPF_R3_8822C \
(BIT_MASK_REG_LPF_R3_8822C << BIT_SHIFT_REG_LPF_R3_8822C)
#define BIT_CLEAR_REG_LPF_R3_8822C(x) ((x) & (~BITS_REG_LPF_R3_8822C))
#define BIT_GET_REG_LPF_R3_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_R3_8822C) & BIT_MASK_REG_LPF_R3_8822C)
#define BIT_SET_REG_LPF_R3_8822C(x, v) \
(BIT_CLEAR_REG_LPF_R3_8822C(x) | BIT_REG_LPF_R3_8822C(v))
#define BIT_SHIFT_REG_LPF_R2_8822C 24
#define BIT_MASK_REG_LPF_R2_8822C 0x1f
#define BIT_REG_LPF_R2_8822C(x) \
(((x) & BIT_MASK_REG_LPF_R2_8822C) << BIT_SHIFT_REG_LPF_R2_8822C)
#define BITS_REG_LPF_R2_8822C \
(BIT_MASK_REG_LPF_R2_8822C << BIT_SHIFT_REG_LPF_R2_8822C)
#define BIT_CLEAR_REG_LPF_R2_8822C(x) ((x) & (~BITS_REG_LPF_R2_8822C))
#define BIT_GET_REG_LPF_R2_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_R2_8822C) & BIT_MASK_REG_LPF_R2_8822C)
#define BIT_SET_REG_LPF_R2_8822C(x, v) \
(BIT_CLEAR_REG_LPF_R2_8822C(x) | BIT_REG_LPF_R2_8822C(v))
#define BIT_SHIFT_REG_LPF_C3_8822C 21
#define BIT_MASK_REG_LPF_C3_8822C 0x7
#define BIT_REG_LPF_C3_8822C(x) \
(((x) & BIT_MASK_REG_LPF_C3_8822C) << BIT_SHIFT_REG_LPF_C3_8822C)
#define BITS_REG_LPF_C3_8822C \
(BIT_MASK_REG_LPF_C3_8822C << BIT_SHIFT_REG_LPF_C3_8822C)
#define BIT_CLEAR_REG_LPF_C3_8822C(x) ((x) & (~BITS_REG_LPF_C3_8822C))
#define BIT_GET_REG_LPF_C3_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_C3_8822C) & BIT_MASK_REG_LPF_C3_8822C)
#define BIT_SET_REG_LPF_C3_8822C(x, v) \
(BIT_CLEAR_REG_LPF_C3_8822C(x) | BIT_REG_LPF_C3_8822C(v))
#define BIT_SHIFT_REG_LPF_C2_8822C 18
#define BIT_MASK_REG_LPF_C2_8822C 0x7
#define BIT_REG_LPF_C2_8822C(x) \
(((x) & BIT_MASK_REG_LPF_C2_8822C) << BIT_SHIFT_REG_LPF_C2_8822C)
#define BITS_REG_LPF_C2_8822C \
(BIT_MASK_REG_LPF_C2_8822C << BIT_SHIFT_REG_LPF_C2_8822C)
#define BIT_CLEAR_REG_LPF_C2_8822C(x) ((x) & (~BITS_REG_LPF_C2_8822C))
#define BIT_GET_REG_LPF_C2_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_C2_8822C) & BIT_MASK_REG_LPF_C2_8822C)
#define BIT_SET_REG_LPF_C2_8822C(x, v) \
(BIT_CLEAR_REG_LPF_C2_8822C(x) | BIT_REG_LPF_C2_8822C(v))
#define BIT_SHIFT_REG_LPF_C1_8822C 15
#define BIT_MASK_REG_LPF_C1_8822C 0x7
#define BIT_REG_LPF_C1_8822C(x) \
(((x) & BIT_MASK_REG_LPF_C1_8822C) << BIT_SHIFT_REG_LPF_C1_8822C)
#define BITS_REG_LPF_C1_8822C \
(BIT_MASK_REG_LPF_C1_8822C << BIT_SHIFT_REG_LPF_C1_8822C)
#define BIT_CLEAR_REG_LPF_C1_8822C(x) ((x) & (~BITS_REG_LPF_C1_8822C))
#define BIT_GET_REG_LPF_C1_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_C1_8822C) & BIT_MASK_REG_LPF_C1_8822C)
#define BIT_SET_REG_LPF_C1_8822C(x, v) \
(BIT_CLEAR_REG_LPF_C1_8822C(x) | BIT_REG_LPF_C1_8822C(v))
#define BIT_SHIFT_REG_LDO_SEL_V1_8822C 13
#define BIT_MASK_REG_LDO_SEL_V1_8822C 0x3
#define BIT_REG_LDO_SEL_V1_8822C(x) \
(((x) & BIT_MASK_REG_LDO_SEL_V1_8822C) \
<< BIT_SHIFT_REG_LDO_SEL_V1_8822C)
#define BITS_REG_LDO_SEL_V1_8822C \
(BIT_MASK_REG_LDO_SEL_V1_8822C << BIT_SHIFT_REG_LDO_SEL_V1_8822C)
#define BIT_CLEAR_REG_LDO_SEL_V1_8822C(x) ((x) & (~BITS_REG_LDO_SEL_V1_8822C))
#define BIT_GET_REG_LDO_SEL_V1_8822C(x) \
(((x) >> BIT_SHIFT_REG_LDO_SEL_V1_8822C) & \
BIT_MASK_REG_LDO_SEL_V1_8822C)
#define BIT_SET_REG_LDO_SEL_V1_8822C(x, v) \
(BIT_CLEAR_REG_LDO_SEL_V1_8822C(x) | BIT_REG_LDO_SEL_V1_8822C(v))
#define BIT_REG_CP_ICPX2_8822C BIT(12)
#define BIT_SHIFT_REG_CP_ICP_SEL_FAST_8822C 9
#define BIT_MASK_REG_CP_ICP_SEL_FAST_8822C 0x7
#define BIT_REG_CP_ICP_SEL_FAST_8822C(x) \
(((x) & BIT_MASK_REG_CP_ICP_SEL_FAST_8822C) \
<< BIT_SHIFT_REG_CP_ICP_SEL_FAST_8822C)
#define BITS_REG_CP_ICP_SEL_FAST_8822C \
(BIT_MASK_REG_CP_ICP_SEL_FAST_8822C \
<< BIT_SHIFT_REG_CP_ICP_SEL_FAST_8822C)
#define BIT_CLEAR_REG_CP_ICP_SEL_FAST_8822C(x) \
((x) & (~BITS_REG_CP_ICP_SEL_FAST_8822C))
#define BIT_GET_REG_CP_ICP_SEL_FAST_8822C(x) \
(((x) >> BIT_SHIFT_REG_CP_ICP_SEL_FAST_8822C) & \
BIT_MASK_REG_CP_ICP_SEL_FAST_8822C)
#define BIT_SET_REG_CP_ICP_SEL_FAST_8822C(x, v) \
(BIT_CLEAR_REG_CP_ICP_SEL_FAST_8822C(x) | \
BIT_REG_CP_ICP_SEL_FAST_8822C(v))
#define BIT_SHIFT_REG_CP_ICP_SEL_8822C 6
#define BIT_MASK_REG_CP_ICP_SEL_8822C 0x7
#define BIT_REG_CP_ICP_SEL_8822C(x) \
(((x) & BIT_MASK_REG_CP_ICP_SEL_8822C) \
<< BIT_SHIFT_REG_CP_ICP_SEL_8822C)
#define BITS_REG_CP_ICP_SEL_8822C \
(BIT_MASK_REG_CP_ICP_SEL_8822C << BIT_SHIFT_REG_CP_ICP_SEL_8822C)
#define BIT_CLEAR_REG_CP_ICP_SEL_8822C(x) ((x) & (~BITS_REG_CP_ICP_SEL_8822C))
#define BIT_GET_REG_CP_ICP_SEL_8822C(x) \
(((x) >> BIT_SHIFT_REG_CP_ICP_SEL_8822C) & \
BIT_MASK_REG_CP_ICP_SEL_8822C)
#define BIT_SET_REG_CP_ICP_SEL_8822C(x, v) \
(BIT_CLEAR_REG_CP_ICP_SEL_8822C(x) | BIT_REG_CP_ICP_SEL_8822C(v))
#define BIT_SHIFT_REG_IB_PI_8822C 4
#define BIT_MASK_REG_IB_PI_8822C 0x3
#define BIT_REG_IB_PI_8822C(x) \
(((x) & BIT_MASK_REG_IB_PI_8822C) << BIT_SHIFT_REG_IB_PI_8822C)
#define BITS_REG_IB_PI_8822C \
(BIT_MASK_REG_IB_PI_8822C << BIT_SHIFT_REG_IB_PI_8822C)
#define BIT_CLEAR_REG_IB_PI_8822C(x) ((x) & (~BITS_REG_IB_PI_8822C))
#define BIT_GET_REG_IB_PI_8822C(x) \
(((x) >> BIT_SHIFT_REG_IB_PI_8822C) & BIT_MASK_REG_IB_PI_8822C)
#define BIT_SET_REG_IB_PI_8822C(x, v) \
(BIT_CLEAR_REG_IB_PI_8822C(x) | BIT_REG_IB_PI_8822C(v))
#define BIT_LDO2PWRCUT_8822C BIT(3)
#define BIT_VPULSE_LDO_8822C BIT(2)
#define BIT_SHIFT_LDO_VSEL_8822C 0
#define BIT_MASK_LDO_VSEL_8822C 0x3
#define BIT_LDO_VSEL_8822C(x) \
(((x) & BIT_MASK_LDO_VSEL_8822C) << BIT_SHIFT_LDO_VSEL_8822C)
#define BITS_LDO_VSEL_8822C \
(BIT_MASK_LDO_VSEL_8822C << BIT_SHIFT_LDO_VSEL_8822C)
#define BIT_CLEAR_LDO_VSEL_8822C(x) ((x) & (~BITS_LDO_VSEL_8822C))
#define BIT_GET_LDO_VSEL_8822C(x) \
(((x) >> BIT_SHIFT_LDO_VSEL_8822C) & BIT_MASK_LDO_VSEL_8822C)
#define BIT_SET_LDO_VSEL_8822C(x, v) \
(BIT_CLEAR_LDO_VSEL_8822C(x) | BIT_LDO_VSEL_8822C(v))
/* 2 REG_ANAPAR_MAC_1_8822C */
#define BIT_SHIFT_REG_CK_MON_SEL_8822C 29
#define BIT_MASK_REG_CK_MON_SEL_8822C 0x7
#define BIT_REG_CK_MON_SEL_8822C(x) \
(((x) & BIT_MASK_REG_CK_MON_SEL_8822C) \
<< BIT_SHIFT_REG_CK_MON_SEL_8822C)
#define BITS_REG_CK_MON_SEL_8822C \
(BIT_MASK_REG_CK_MON_SEL_8822C << BIT_SHIFT_REG_CK_MON_SEL_8822C)
#define BIT_CLEAR_REG_CK_MON_SEL_8822C(x) ((x) & (~BITS_REG_CK_MON_SEL_8822C))
#define BIT_GET_REG_CK_MON_SEL_8822C(x) \
(((x) >> BIT_SHIFT_REG_CK_MON_SEL_8822C) & \
BIT_MASK_REG_CK_MON_SEL_8822C)
#define BIT_SET_REG_CK_MON_SEL_8822C(x, v) \
(BIT_CLEAR_REG_CK_MON_SEL_8822C(x) | BIT_REG_CK_MON_SEL_8822C(v))
#define BIT_REG_CK_MON_EN_8822C BIT(28)
#define BIT_REG_XTAL_FREQ_SEL_8822C BIT(27)
#define BIT_REG_XTAL_EDGE_SEL_8822C BIT(26)
#define BIT_REG_VCO_KVCO_8822C BIT(25)
#define BIT_REG_SDM_EDGE_SEL_8822C BIT(24)
#define BIT_REG_SDM_CK_SEL_8822C BIT(23)
#define BIT_REG_SDM_CK_GATED_8822C BIT(22)
#define BIT_REG_PFD_RESET_GATED_8822C BIT(21)
#define BIT_SHIFT_REG_LPF_R3_FAST_8822C 16
#define BIT_MASK_REG_LPF_R3_FAST_8822C 0x1f
#define BIT_REG_LPF_R3_FAST_8822C(x) \
(((x) & BIT_MASK_REG_LPF_R3_FAST_8822C) \
<< BIT_SHIFT_REG_LPF_R3_FAST_8822C)
#define BITS_REG_LPF_R3_FAST_8822C \
(BIT_MASK_REG_LPF_R3_FAST_8822C << BIT_SHIFT_REG_LPF_R3_FAST_8822C)
#define BIT_CLEAR_REG_LPF_R3_FAST_8822C(x) ((x) & (~BITS_REG_LPF_R3_FAST_8822C))
#define BIT_GET_REG_LPF_R3_FAST_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_R3_FAST_8822C) & \
BIT_MASK_REG_LPF_R3_FAST_8822C)
#define BIT_SET_REG_LPF_R3_FAST_8822C(x, v) \
(BIT_CLEAR_REG_LPF_R3_FAST_8822C(x) | BIT_REG_LPF_R3_FAST_8822C(v))
#define BIT_SHIFT_REG_LPF_R2_FAST_8822C 11
#define BIT_MASK_REG_LPF_R2_FAST_8822C 0x1f
#define BIT_REG_LPF_R2_FAST_8822C(x) \
(((x) & BIT_MASK_REG_LPF_R2_FAST_8822C) \
<< BIT_SHIFT_REG_LPF_R2_FAST_8822C)
#define BITS_REG_LPF_R2_FAST_8822C \
(BIT_MASK_REG_LPF_R2_FAST_8822C << BIT_SHIFT_REG_LPF_R2_FAST_8822C)
#define BIT_CLEAR_REG_LPF_R2_FAST_8822C(x) ((x) & (~BITS_REG_LPF_R2_FAST_8822C))
#define BIT_GET_REG_LPF_R2_FAST_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_R2_FAST_8822C) & \
BIT_MASK_REG_LPF_R2_FAST_8822C)
#define BIT_SET_REG_LPF_R2_FAST_8822C(x, v) \
(BIT_CLEAR_REG_LPF_R2_FAST_8822C(x) | BIT_REG_LPF_R2_FAST_8822C(v))
#define BIT_SHIFT_REG_LPF_C3_FAST_8822C 8
#define BIT_MASK_REG_LPF_C3_FAST_8822C 0x7
#define BIT_REG_LPF_C3_FAST_8822C(x) \
(((x) & BIT_MASK_REG_LPF_C3_FAST_8822C) \
<< BIT_SHIFT_REG_LPF_C3_FAST_8822C)
#define BITS_REG_LPF_C3_FAST_8822C \
(BIT_MASK_REG_LPF_C3_FAST_8822C << BIT_SHIFT_REG_LPF_C3_FAST_8822C)
#define BIT_CLEAR_REG_LPF_C3_FAST_8822C(x) ((x) & (~BITS_REG_LPF_C3_FAST_8822C))
#define BIT_GET_REG_LPF_C3_FAST_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_C3_FAST_8822C) & \
BIT_MASK_REG_LPF_C3_FAST_8822C)
#define BIT_SET_REG_LPF_C3_FAST_8822C(x, v) \
(BIT_CLEAR_REG_LPF_C3_FAST_8822C(x) | BIT_REG_LPF_C3_FAST_8822C(v))
#define BIT_SHIFT_REG_LPF_C2_FAST_8822C 5
#define BIT_MASK_REG_LPF_C2_FAST_8822C 0x7
#define BIT_REG_LPF_C2_FAST_8822C(x) \
(((x) & BIT_MASK_REG_LPF_C2_FAST_8822C) \
<< BIT_SHIFT_REG_LPF_C2_FAST_8822C)
#define BITS_REG_LPF_C2_FAST_8822C \
(BIT_MASK_REG_LPF_C2_FAST_8822C << BIT_SHIFT_REG_LPF_C2_FAST_8822C)
#define BIT_CLEAR_REG_LPF_C2_FAST_8822C(x) ((x) & (~BITS_REG_LPF_C2_FAST_8822C))
#define BIT_GET_REG_LPF_C2_FAST_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_C2_FAST_8822C) & \
BIT_MASK_REG_LPF_C2_FAST_8822C)
#define BIT_SET_REG_LPF_C2_FAST_8822C(x, v) \
(BIT_CLEAR_REG_LPF_C2_FAST_8822C(x) | BIT_REG_LPF_C2_FAST_8822C(v))
#define BIT_SHIFT_REG_LPF_C1_FAST_8822C 2
#define BIT_MASK_REG_LPF_C1_FAST_8822C 0x7
#define BIT_REG_LPF_C1_FAST_8822C(x) \
(((x) & BIT_MASK_REG_LPF_C1_FAST_8822C) \
<< BIT_SHIFT_REG_LPF_C1_FAST_8822C)
#define BITS_REG_LPF_C1_FAST_8822C \
(BIT_MASK_REG_LPF_C1_FAST_8822C << BIT_SHIFT_REG_LPF_C1_FAST_8822C)
#define BIT_CLEAR_REG_LPF_C1_FAST_8822C(x) ((x) & (~BITS_REG_LPF_C1_FAST_8822C))
#define BIT_GET_REG_LPF_C1_FAST_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_C1_FAST_8822C) & \
BIT_MASK_REG_LPF_C1_FAST_8822C)
#define BIT_SET_REG_LPF_C1_FAST_8822C(x, v) \
(BIT_CLEAR_REG_LPF_C1_FAST_8822C(x) | BIT_REG_LPF_C1_FAST_8822C(v))
#define BIT_SHIFT_REG_LPF_R3_V1_8822C 0
#define BIT_MASK_REG_LPF_R3_V1_8822C 0x3
#define BIT_REG_LPF_R3_V1_8822C(x) \
(((x) & BIT_MASK_REG_LPF_R3_V1_8822C) << BIT_SHIFT_REG_LPF_R3_V1_8822C)
#define BITS_REG_LPF_R3_V1_8822C \
(BIT_MASK_REG_LPF_R3_V1_8822C << BIT_SHIFT_REG_LPF_R3_V1_8822C)
#define BIT_CLEAR_REG_LPF_R3_V1_8822C(x) ((x) & (~BITS_REG_LPF_R3_V1_8822C))
#define BIT_GET_REG_LPF_R3_V1_8822C(x) \
(((x) >> BIT_SHIFT_REG_LPF_R3_V1_8822C) & BIT_MASK_REG_LPF_R3_V1_8822C)
#define BIT_SET_REG_LPF_R3_V1_8822C(x, v) \
(BIT_CLEAR_REG_LPF_R3_V1_8822C(x) | BIT_REG_LPF_R3_V1_8822C(v))
/* 2 REG_ANAPAR_MAC_2_8822C */
#define BIT_SHIFT_AGPIO_DRV_V1_8822C 30
#define BIT_MASK_AGPIO_DRV_V1_8822C 0x3
#define BIT_AGPIO_DRV_V1_8822C(x) \
(((x) & BIT_MASK_AGPIO_DRV_V1_8822C) << BIT_SHIFT_AGPIO_DRV_V1_8822C)
#define BITS_AGPIO_DRV_V1_8822C \
(BIT_MASK_AGPIO_DRV_V1_8822C << BIT_SHIFT_AGPIO_DRV_V1_8822C)
#define BIT_CLEAR_AGPIO_DRV_V1_8822C(x) ((x) & (~BITS_AGPIO_DRV_V1_8822C))
#define BIT_GET_AGPIO_DRV_V1_8822C(x) \
(((x) >> BIT_SHIFT_AGPIO_DRV_V1_8822C) & BIT_MASK_AGPIO_DRV_V1_8822C)
#define BIT_SET_AGPIO_DRV_V1_8822C(x, v) \
(BIT_CLEAR_AGPIO_DRV_V1_8822C(x) | BIT_AGPIO_DRV_V1_8822C(v))
#define BIT_AGPIO_GPO_V1_8822C BIT(29)
#define BIT_AGPIO_GPE_V1_8822C BIT(28)
#define BIT_SEL_CLK_8822C BIT(27)
#define BIT_SHIFT_LS_XTAL_SEL_8822C 23
#define BIT_MASK_LS_XTAL_SEL_8822C 0xf
#define BIT_LS_XTAL_SEL_8822C(x) \
(((x) & BIT_MASK_LS_XTAL_SEL_8822C) << BIT_SHIFT_LS_XTAL_SEL_8822C)
#define BITS_LS_XTAL_SEL_8822C \
(BIT_MASK_LS_XTAL_SEL_8822C << BIT_SHIFT_LS_XTAL_SEL_8822C)
#define BIT_CLEAR_LS_XTAL_SEL_8822C(x) ((x) & (~BITS_LS_XTAL_SEL_8822C))
#define BIT_GET_LS_XTAL_SEL_8822C(x) \
(((x) >> BIT_SHIFT_LS_XTAL_SEL_8822C) & BIT_MASK_LS_XTAL_SEL_8822C)
#define BIT_SET_LS_XTAL_SEL_8822C(x, v) \
(BIT_CLEAR_LS_XTAL_SEL_8822C(x) | BIT_LS_XTAL_SEL_8822C(v))
#define BIT_LS_SDM_ORDER_V1_8822C BIT(22)
#define BIT_LS_DELAY_PH_8822C BIT(21)
#define BIT_DIVIDER_SEL_8822C BIT(20)
#define BIT_SHIFT_PCODE_8822C 15
#define BIT_MASK_PCODE_8822C 0x1f
#define BIT_PCODE_8822C(x) \
(((x) & BIT_MASK_PCODE_8822C) << BIT_SHIFT_PCODE_8822C)
#define BITS_PCODE_8822C (BIT_MASK_PCODE_8822C << BIT_SHIFT_PCODE_8822C)
#define BIT_CLEAR_PCODE_8822C(x) ((x) & (~BITS_PCODE_8822C))
#define BIT_GET_PCODE_8822C(x) \
(((x) >> BIT_SHIFT_PCODE_8822C) & BIT_MASK_PCODE_8822C)
#define BIT_SET_PCODE_8822C(x, v) \
(BIT_CLEAR_PCODE_8822C(x) | BIT_PCODE_8822C(v))
#define BIT_SHIFT_NCODE_8822C 7
#define BIT_MASK_NCODE_8822C 0xff
#define BIT_NCODE_8822C(x) \
(((x) & BIT_MASK_NCODE_8822C) << BIT_SHIFT_NCODE_8822C)
#define BITS_NCODE_8822C (BIT_MASK_NCODE_8822C << BIT_SHIFT_NCODE_8822C)
#define BIT_CLEAR_NCODE_8822C(x) ((x) & (~BITS_NCODE_8822C))
#define BIT_GET_NCODE_8822C(x) \
(((x) >> BIT_SHIFT_NCODE_8822C) & BIT_MASK_NCODE_8822C)
#define BIT_SET_NCODE_8822C(x, v) \
(BIT_CLEAR_NCODE_8822C(x) | BIT_NCODE_8822C(v))
#define BIT_REG_BEACON_8822C BIT(6)
#define BIT_REG_MBIASE_8822C BIT(5)
#define BIT_SHIFT_REG_FAST_SEL_8822C 3
#define BIT_MASK_REG_FAST_SEL_8822C 0x3
#define BIT_REG_FAST_SEL_8822C(x) \
(((x) & BIT_MASK_REG_FAST_SEL_8822C) << BIT_SHIFT_REG_FAST_SEL_8822C)
#define BITS_REG_FAST_SEL_8822C \
(BIT_MASK_REG_FAST_SEL_8822C << BIT_SHIFT_REG_FAST_SEL_8822C)
#define BIT_CLEAR_REG_FAST_SEL_8822C(x) ((x) & (~BITS_REG_FAST_SEL_8822C))
#define BIT_GET_REG_FAST_SEL_8822C(x) \
(((x) >> BIT_SHIFT_REG_FAST_SEL_8822C) & BIT_MASK_REG_FAST_SEL_8822C)
#define BIT_SET_REG_FAST_SEL_8822C(x, v) \
(BIT_CLEAR_REG_FAST_SEL_8822C(x) | BIT_REG_FAST_SEL_8822C(v))
#define BIT_REG_CK960M_EN_8822C BIT(2)
#define BIT_REG_CK320M_EN_8822C BIT(1)
#define BIT_REG_CK_5M_EN_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ANAPAR_XTAL_0_8822C */
#define BIT_XTAL_SC_LPS_8822C BIT(31)
#define BIT_SHIFT_XTAL_SC_INIT_8822C 24
#define BIT_MASK_XTAL_SC_INIT_8822C 0x7f
#define BIT_XTAL_SC_INIT_8822C(x) \
(((x) & BIT_MASK_XTAL_SC_INIT_8822C) << BIT_SHIFT_XTAL_SC_INIT_8822C)
#define BITS_XTAL_SC_INIT_8822C \
(BIT_MASK_XTAL_SC_INIT_8822C << BIT_SHIFT_XTAL_SC_INIT_8822C)
#define BIT_CLEAR_XTAL_SC_INIT_8822C(x) ((x) & (~BITS_XTAL_SC_INIT_8822C))
#define BIT_GET_XTAL_SC_INIT_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_SC_INIT_8822C) & BIT_MASK_XTAL_SC_INIT_8822C)
#define BIT_SET_XTAL_SC_INIT_8822C(x, v) \
(BIT_CLEAR_XTAL_SC_INIT_8822C(x) | BIT_XTAL_SC_INIT_8822C(v))
#define BIT_SHIFT_XTAL_SC_XO_8822C 17
#define BIT_MASK_XTAL_SC_XO_8822C 0x7f
#define BIT_XTAL_SC_XO_8822C(x) \
(((x) & BIT_MASK_XTAL_SC_XO_8822C) << BIT_SHIFT_XTAL_SC_XO_8822C)
#define BITS_XTAL_SC_XO_8822C \
(BIT_MASK_XTAL_SC_XO_8822C << BIT_SHIFT_XTAL_SC_XO_8822C)
#define BIT_CLEAR_XTAL_SC_XO_8822C(x) ((x) & (~BITS_XTAL_SC_XO_8822C))
#define BIT_GET_XTAL_SC_XO_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XO_8822C) & BIT_MASK_XTAL_SC_XO_8822C)
#define BIT_SET_XTAL_SC_XO_8822C(x, v) \
(BIT_CLEAR_XTAL_SC_XO_8822C(x) | BIT_XTAL_SC_XO_8822C(v))
#define BIT_SHIFT_XTAL_SC_XI_8822C 10
#define BIT_MASK_XTAL_SC_XI_8822C 0x7f
#define BIT_XTAL_SC_XI_8822C(x) \
(((x) & BIT_MASK_XTAL_SC_XI_8822C) << BIT_SHIFT_XTAL_SC_XI_8822C)
#define BITS_XTAL_SC_XI_8822C \
(BIT_MASK_XTAL_SC_XI_8822C << BIT_SHIFT_XTAL_SC_XI_8822C)
#define BIT_CLEAR_XTAL_SC_XI_8822C(x) ((x) & (~BITS_XTAL_SC_XI_8822C))
#define BIT_GET_XTAL_SC_XI_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_SC_XI_8822C) & BIT_MASK_XTAL_SC_XI_8822C)
#define BIT_SET_XTAL_SC_XI_8822C(x, v) \
(BIT_CLEAR_XTAL_SC_XI_8822C(x) | BIT_XTAL_SC_XI_8822C(v))
#define BIT_SHIFT_XTAL_GMN_V3_8822C 5
#define BIT_MASK_XTAL_GMN_V3_8822C 0x1f
#define BIT_XTAL_GMN_V3_8822C(x) \
(((x) & BIT_MASK_XTAL_GMN_V3_8822C) << BIT_SHIFT_XTAL_GMN_V3_8822C)
#define BITS_XTAL_GMN_V3_8822C \
(BIT_MASK_XTAL_GMN_V3_8822C << BIT_SHIFT_XTAL_GMN_V3_8822C)
#define BIT_CLEAR_XTAL_GMN_V3_8822C(x) ((x) & (~BITS_XTAL_GMN_V3_8822C))
#define BIT_GET_XTAL_GMN_V3_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_GMN_V3_8822C) & BIT_MASK_XTAL_GMN_V3_8822C)
#define BIT_SET_XTAL_GMN_V3_8822C(x, v) \
(BIT_CLEAR_XTAL_GMN_V3_8822C(x) | BIT_XTAL_GMN_V3_8822C(v))
#define BIT_SHIFT_XTAL_GMP_V3_8822C 0
#define BIT_MASK_XTAL_GMP_V3_8822C 0x1f
#define BIT_XTAL_GMP_V3_8822C(x) \
(((x) & BIT_MASK_XTAL_GMP_V3_8822C) << BIT_SHIFT_XTAL_GMP_V3_8822C)
#define BITS_XTAL_GMP_V3_8822C \
(BIT_MASK_XTAL_GMP_V3_8822C << BIT_SHIFT_XTAL_GMP_V3_8822C)
#define BIT_CLEAR_XTAL_GMP_V3_8822C(x) ((x) & (~BITS_XTAL_GMP_V3_8822C))
#define BIT_GET_XTAL_GMP_V3_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_GMP_V3_8822C) & BIT_MASK_XTAL_GMP_V3_8822C)
#define BIT_SET_XTAL_GMP_V3_8822C(x, v) \
(BIT_CLEAR_XTAL_GMP_V3_8822C(x) | BIT_XTAL_GMP_V3_8822C(v))
/* 2 REG_ANAPAR_XTAL_1_8822C */
#define BIT_XTAL_SEL_TOK_V1_8822C BIT(31)
#define BIT_XTAL_DELAY_DIGI_V2_8822C BIT(30)
#define BIT_XTAL_DELAY_USB_V2_8822C BIT(29)
#define BIT_XTAL_DELAY_AFE_V2_8822C BIT(28)
#define BIT_SHIFT_XTAL_DRV_DIGI_V2_8822C 26
#define BIT_MASK_XTAL_DRV_DIGI_V2_8822C 0x3
#define BIT_XTAL_DRV_DIGI_V2_8822C(x) \
(((x) & BIT_MASK_XTAL_DRV_DIGI_V2_8822C) \
<< BIT_SHIFT_XTAL_DRV_DIGI_V2_8822C)
#define BITS_XTAL_DRV_DIGI_V2_8822C \
(BIT_MASK_XTAL_DRV_DIGI_V2_8822C << BIT_SHIFT_XTAL_DRV_DIGI_V2_8822C)
#define BIT_CLEAR_XTAL_DRV_DIGI_V2_8822C(x) \
((x) & (~BITS_XTAL_DRV_DIGI_V2_8822C))
#define BIT_GET_XTAL_DRV_DIGI_V2_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_DIGI_V2_8822C) & \
BIT_MASK_XTAL_DRV_DIGI_V2_8822C)
#define BIT_SET_XTAL_DRV_DIGI_V2_8822C(x, v) \
(BIT_CLEAR_XTAL_DRV_DIGI_V2_8822C(x) | BIT_XTAL_DRV_DIGI_V2_8822C(v))
#define BIT_EN_XTAL_DRV_LPS_8822C BIT(25)
#define BIT_EN_XTAL_DRV_DIGI_V2_8822C BIT(24)
#define BIT_SHIFT_XTAL_DRV_USB_8822C 22
#define BIT_MASK_XTAL_DRV_USB_8822C 0x3
#define BIT_XTAL_DRV_USB_8822C(x) \
(((x) & BIT_MASK_XTAL_DRV_USB_8822C) << BIT_SHIFT_XTAL_DRV_USB_8822C)
#define BITS_XTAL_DRV_USB_8822C \
(BIT_MASK_XTAL_DRV_USB_8822C << BIT_SHIFT_XTAL_DRV_USB_8822C)
#define BIT_CLEAR_XTAL_DRV_USB_8822C(x) ((x) & (~BITS_XTAL_DRV_USB_8822C))
#define BIT_GET_XTAL_DRV_USB_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_USB_8822C) & BIT_MASK_XTAL_DRV_USB_8822C)
#define BIT_SET_XTAL_DRV_USB_8822C(x, v) \
(BIT_CLEAR_XTAL_DRV_USB_8822C(x) | BIT_XTAL_DRV_USB_8822C(v))
#define BIT_EN_XTAL_DRV_USB_8822C BIT(21)
#define BIT_SHIFT_XTAL_DRV_AFE_V2_8822C 19
#define BIT_MASK_XTAL_DRV_AFE_V2_8822C 0x3
#define BIT_XTAL_DRV_AFE_V2_8822C(x) \
(((x) & BIT_MASK_XTAL_DRV_AFE_V2_8822C) \
<< BIT_SHIFT_XTAL_DRV_AFE_V2_8822C)
#define BITS_XTAL_DRV_AFE_V2_8822C \
(BIT_MASK_XTAL_DRV_AFE_V2_8822C << BIT_SHIFT_XTAL_DRV_AFE_V2_8822C)
#define BIT_CLEAR_XTAL_DRV_AFE_V2_8822C(x) ((x) & (~BITS_XTAL_DRV_AFE_V2_8822C))
#define BIT_GET_XTAL_DRV_AFE_V2_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_AFE_V2_8822C) & \
BIT_MASK_XTAL_DRV_AFE_V2_8822C)
#define BIT_SET_XTAL_DRV_AFE_V2_8822C(x, v) \
(BIT_CLEAR_XTAL_DRV_AFE_V2_8822C(x) | BIT_XTAL_DRV_AFE_V2_8822C(v))
#define BIT_EN_XTAL_DRV_AFE_8822C BIT(18)
#define BIT_SHIFT_XTAL_DRV_RF2_V2_8822C 16
#define BIT_MASK_XTAL_DRV_RF2_V2_8822C 0x3
#define BIT_XTAL_DRV_RF2_V2_8822C(x) \
(((x) & BIT_MASK_XTAL_DRV_RF2_V2_8822C) \
<< BIT_SHIFT_XTAL_DRV_RF2_V2_8822C)
#define BITS_XTAL_DRV_RF2_V2_8822C \
(BIT_MASK_XTAL_DRV_RF2_V2_8822C << BIT_SHIFT_XTAL_DRV_RF2_V2_8822C)
#define BIT_CLEAR_XTAL_DRV_RF2_V2_8822C(x) ((x) & (~BITS_XTAL_DRV_RF2_V2_8822C))
#define BIT_GET_XTAL_DRV_RF2_V2_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF2_V2_8822C) & \
BIT_MASK_XTAL_DRV_RF2_V2_8822C)
#define BIT_SET_XTAL_DRV_RF2_V2_8822C(x, v) \
(BIT_CLEAR_XTAL_DRV_RF2_V2_8822C(x) | BIT_XTAL_DRV_RF2_V2_8822C(v))
#define BIT_EN_XTAL_DRV_RF2_8822C BIT(15)
#define BIT_SHIFT_XTAL_DRV_RF1_8822C 13
#define BIT_MASK_XTAL_DRV_RF1_8822C 0x3
#define BIT_XTAL_DRV_RF1_8822C(x) \
(((x) & BIT_MASK_XTAL_DRV_RF1_8822C) << BIT_SHIFT_XTAL_DRV_RF1_8822C)
#define BITS_XTAL_DRV_RF1_8822C \
(BIT_MASK_XTAL_DRV_RF1_8822C << BIT_SHIFT_XTAL_DRV_RF1_8822C)
#define BIT_CLEAR_XTAL_DRV_RF1_8822C(x) ((x) & (~BITS_XTAL_DRV_RF1_8822C))
#define BIT_GET_XTAL_DRV_RF1_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_DRV_RF1_8822C) & BIT_MASK_XTAL_DRV_RF1_8822C)
#define BIT_SET_XTAL_DRV_RF1_8822C(x, v) \
(BIT_CLEAR_XTAL_DRV_RF1_8822C(x) | BIT_XTAL_DRV_RF1_8822C(v))
#define BIT_EN_XTAL_DRV_RF1_8822C BIT(12)
#define BIT_XTAL_DRV_RF_LATCH_V4_8822C BIT(11)
#define BIT_XTAL_GM_SEP_V3_8822C BIT(10)
#define BIT_XQSEL_RF_AWAKE_V3_8822C BIT(9)
#define BIT_XQSEL_RF_INITIAL_V3_8822C BIT(8)
#define BIT_XQSEL_V2_8822C BIT(7)
#define BIT_GATED_XTAL_OK0_V2_8822C BIT(6)
#define BIT_SHIFT_XTAL_SC_LPS_V2_8822C 0
#define BIT_MASK_XTAL_SC_LPS_V2_8822C 0x3f
#define BIT_XTAL_SC_LPS_V2_8822C(x) \
(((x) & BIT_MASK_XTAL_SC_LPS_V2_8822C) \
<< BIT_SHIFT_XTAL_SC_LPS_V2_8822C)
#define BITS_XTAL_SC_LPS_V2_8822C \
(BIT_MASK_XTAL_SC_LPS_V2_8822C << BIT_SHIFT_XTAL_SC_LPS_V2_8822C)
#define BIT_CLEAR_XTAL_SC_LPS_V2_8822C(x) ((x) & (~BITS_XTAL_SC_LPS_V2_8822C))
#define BIT_GET_XTAL_SC_LPS_V2_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_SC_LPS_V2_8822C) & \
BIT_MASK_XTAL_SC_LPS_V2_8822C)
#define BIT_SET_XTAL_SC_LPS_V2_8822C(x, v) \
(BIT_CLEAR_XTAL_SC_LPS_V2_8822C(x) | BIT_XTAL_SC_LPS_V2_8822C(v))
/* 2 REG_ANAPAR_XTAL_2_8822C */
#define BIT_XTAL_AAC_CAP_8822C BIT(31)
#define BIT_SHIFT_XTAL_PDSW_8822C 29
#define BIT_MASK_XTAL_PDSW_8822C 0x3
#define BIT_XTAL_PDSW_8822C(x) \
(((x) & BIT_MASK_XTAL_PDSW_8822C) << BIT_SHIFT_XTAL_PDSW_8822C)
#define BITS_XTAL_PDSW_8822C \
(BIT_MASK_XTAL_PDSW_8822C << BIT_SHIFT_XTAL_PDSW_8822C)
#define BIT_CLEAR_XTAL_PDSW_8822C(x) ((x) & (~BITS_XTAL_PDSW_8822C))
#define BIT_GET_XTAL_PDSW_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_PDSW_8822C) & BIT_MASK_XTAL_PDSW_8822C)
#define BIT_SET_XTAL_PDSW_8822C(x, v) \
(BIT_CLEAR_XTAL_PDSW_8822C(x) | BIT_XTAL_PDSW_8822C(v))
#define BIT_SHIFT_XTAL_LPS_BUF_VB_8822C 27
#define BIT_MASK_XTAL_LPS_BUF_VB_8822C 0x3
#define BIT_XTAL_LPS_BUF_VB_8822C(x) \
(((x) & BIT_MASK_XTAL_LPS_BUF_VB_8822C) \
<< BIT_SHIFT_XTAL_LPS_BUF_VB_8822C)
#define BITS_XTAL_LPS_BUF_VB_8822C \
(BIT_MASK_XTAL_LPS_BUF_VB_8822C << BIT_SHIFT_XTAL_LPS_BUF_VB_8822C)
#define BIT_CLEAR_XTAL_LPS_BUF_VB_8822C(x) ((x) & (~BITS_XTAL_LPS_BUF_VB_8822C))
#define BIT_GET_XTAL_LPS_BUF_VB_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_LPS_BUF_VB_8822C) & \
BIT_MASK_XTAL_LPS_BUF_VB_8822C)
#define BIT_SET_XTAL_LPS_BUF_VB_8822C(x, v) \
(BIT_CLEAR_XTAL_LPS_BUF_VB_8822C(x) | BIT_XTAL_LPS_BUF_VB_8822C(v))
#define BIT_XTAL_PDCK_MANU_8822C BIT(26)
#define BIT_XTAL_PDCK_OK_MANU_8822C BIT(25)
#define BIT_SHIFT_XTAL_VREF_SEL_8822C 20
#define BIT_MASK_XTAL_VREF_SEL_8822C 0x1f
#define BIT_XTAL_VREF_SEL_8822C(x) \
(((x) & BIT_MASK_XTAL_VREF_SEL_8822C) << BIT_SHIFT_XTAL_VREF_SEL_8822C)
#define BITS_XTAL_VREF_SEL_8822C \
(BIT_MASK_XTAL_VREF_SEL_8822C << BIT_SHIFT_XTAL_VREF_SEL_8822C)
#define BIT_CLEAR_XTAL_VREF_SEL_8822C(x) ((x) & (~BITS_XTAL_VREF_SEL_8822C))
#define BIT_GET_XTAL_VREF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_VREF_SEL_8822C) & BIT_MASK_XTAL_VREF_SEL_8822C)
#define BIT_SET_XTAL_VREF_SEL_8822C(x, v) \
(BIT_CLEAR_XTAL_VREF_SEL_8822C(x) | BIT_XTAL_VREF_SEL_8822C(v))
#define BIT_EN_XTAL_PDCK_VREF_8822C BIT(19)
#define BIT_XTAL_SEL_PWR_V1_8822C BIT(18)
#define BIT_XTAL_LPS_DIVISOR_8822C BIT(17)
#define BIT_XTAL_CKDIGI_SEL_8822C BIT(16)
#define BIT_EN_XTAL_LPS_CLK_8822C BIT(15)
#define BIT_EN_XTAL_SCHMITT_8822C BIT(14)
#define BIT_XTAL_PK_SEL_OFFSET_8822C BIT(13)
#define BIT_SHIFT_XTAL_MANU_PK_SEL_8822C 11
#define BIT_MASK_XTAL_MANU_PK_SEL_8822C 0x3
#define BIT_XTAL_MANU_PK_SEL_8822C(x) \
(((x) & BIT_MASK_XTAL_MANU_PK_SEL_8822C) \
<< BIT_SHIFT_XTAL_MANU_PK_SEL_8822C)
#define BITS_XTAL_MANU_PK_SEL_8822C \
(BIT_MASK_XTAL_MANU_PK_SEL_8822C << BIT_SHIFT_XTAL_MANU_PK_SEL_8822C)
#define BIT_CLEAR_XTAL_MANU_PK_SEL_8822C(x) \
((x) & (~BITS_XTAL_MANU_PK_SEL_8822C))
#define BIT_GET_XTAL_MANU_PK_SEL_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_MANU_PK_SEL_8822C) & \
BIT_MASK_XTAL_MANU_PK_SEL_8822C)
#define BIT_SET_XTAL_MANU_PK_SEL_8822C(x, v) \
(BIT_CLEAR_XTAL_MANU_PK_SEL_8822C(x) | BIT_XTAL_MANU_PK_SEL_8822C(v))
#define BIT_XTAL_AACK_PK_MANU_8822C BIT(10)
#define BIT_EN_XTAL_AAC_PKDET_V1_8822C BIT(9)
#define BIT_EN_XTAL_AAC_GM_V1_8822C BIT(8)
#define BIT_XTAL_LDO_OPVB_SEL_8822C BIT(7)
#define BIT_XTAL_LDO_NC_8822C BIT(6)
#define BIT_SHIFT_XTAL_LDO_VREF_V2_8822C 3
#define BIT_MASK_XTAL_LDO_VREF_V2_8822C 0x7
#define BIT_XTAL_LDO_VREF_V2_8822C(x) \
(((x) & BIT_MASK_XTAL_LDO_VREF_V2_8822C) \
<< BIT_SHIFT_XTAL_LDO_VREF_V2_8822C)
#define BITS_XTAL_LDO_VREF_V2_8822C \
(BIT_MASK_XTAL_LDO_VREF_V2_8822C << BIT_SHIFT_XTAL_LDO_VREF_V2_8822C)
#define BIT_CLEAR_XTAL_LDO_VREF_V2_8822C(x) \
((x) & (~BITS_XTAL_LDO_VREF_V2_8822C))
#define BIT_GET_XTAL_LDO_VREF_V2_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_VREF_V2_8822C) & \
BIT_MASK_XTAL_LDO_VREF_V2_8822C)
#define BIT_SET_XTAL_LDO_VREF_V2_8822C(x, v) \
(BIT_CLEAR_XTAL_LDO_VREF_V2_8822C(x) | BIT_XTAL_LDO_VREF_V2_8822C(v))
#define BIT_XTAL_LPMODE_V1_8822C BIT(2)
#define BIT_SHIFT_XTAL_SEL_TOK_V3_8822C 0
#define BIT_MASK_XTAL_SEL_TOK_V3_8822C 0x3
#define BIT_XTAL_SEL_TOK_V3_8822C(x) \
(((x) & BIT_MASK_XTAL_SEL_TOK_V3_8822C) \
<< BIT_SHIFT_XTAL_SEL_TOK_V3_8822C)
#define BITS_XTAL_SEL_TOK_V3_8822C \
(BIT_MASK_XTAL_SEL_TOK_V3_8822C << BIT_SHIFT_XTAL_SEL_TOK_V3_8822C)
#define BIT_CLEAR_XTAL_SEL_TOK_V3_8822C(x) ((x) & (~BITS_XTAL_SEL_TOK_V3_8822C))
#define BIT_GET_XTAL_SEL_TOK_V3_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_SEL_TOK_V3_8822C) & \
BIT_MASK_XTAL_SEL_TOK_V3_8822C)
#define BIT_SET_XTAL_SEL_TOK_V3_8822C(x, v) \
(BIT_CLEAR_XTAL_SEL_TOK_V3_8822C(x) | BIT_XTAL_SEL_TOK_V3_8822C(v))
/* 2 REG_ANAPAR_XTAL_3_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_XTAL_DUMMY_V1_8822C 7
#define BIT_MASK_XTAL_DUMMY_V1_8822C 0x3f
#define BIT_XTAL_DUMMY_V1_8822C(x) \
(((x) & BIT_MASK_XTAL_DUMMY_V1_8822C) << BIT_SHIFT_XTAL_DUMMY_V1_8822C)
#define BITS_XTAL_DUMMY_V1_8822C \
(BIT_MASK_XTAL_DUMMY_V1_8822C << BIT_SHIFT_XTAL_DUMMY_V1_8822C)
#define BIT_CLEAR_XTAL_DUMMY_V1_8822C(x) ((x) & (~BITS_XTAL_DUMMY_V1_8822C))
#define BIT_GET_XTAL_DUMMY_V1_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_DUMMY_V1_8822C) & BIT_MASK_XTAL_DUMMY_V1_8822C)
#define BIT_SET_XTAL_DUMMY_V1_8822C(x, v) \
(BIT_CLEAR_XTAL_DUMMY_V1_8822C(x) | BIT_XTAL_DUMMY_V1_8822C(v))
#define BIT_XTAL_EN_LNBUF_8822C BIT(6)
#define BIT_XTAL__AAC_TIE_MID_8822C BIT(5)
#define BIT_SHIFT_XTAL_AAC_OPCUR_8822C 3
#define BIT_MASK_XTAL_AAC_OPCUR_8822C 0x3
#define BIT_XTAL_AAC_OPCUR_8822C(x) \
(((x) & BIT_MASK_XTAL_AAC_OPCUR_8822C) \
<< BIT_SHIFT_XTAL_AAC_OPCUR_8822C)
#define BITS_XTAL_AAC_OPCUR_8822C \
(BIT_MASK_XTAL_AAC_OPCUR_8822C << BIT_SHIFT_XTAL_AAC_OPCUR_8822C)
#define BIT_CLEAR_XTAL_AAC_OPCUR_8822C(x) ((x) & (~BITS_XTAL_AAC_OPCUR_8822C))
#define BIT_GET_XTAL_AAC_OPCUR_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_AAC_OPCUR_8822C) & \
BIT_MASK_XTAL_AAC_OPCUR_8822C)
#define BIT_SET_XTAL_AAC_OPCUR_8822C(x, v) \
(BIT_CLEAR_XTAL_AAC_OPCUR_8822C(x) | BIT_XTAL_AAC_OPCUR_8822C(v))
#define BIT_SHIFT_XTAL_AAC_IOFFSET_8822C 1
#define BIT_MASK_XTAL_AAC_IOFFSET_8822C 0x3
#define BIT_XTAL_AAC_IOFFSET_8822C(x) \
(((x) & BIT_MASK_XTAL_AAC_IOFFSET_8822C) \
<< BIT_SHIFT_XTAL_AAC_IOFFSET_8822C)
#define BITS_XTAL_AAC_IOFFSET_8822C \
(BIT_MASK_XTAL_AAC_IOFFSET_8822C << BIT_SHIFT_XTAL_AAC_IOFFSET_8822C)
#define BIT_CLEAR_XTAL_AAC_IOFFSET_8822C(x) \
((x) & (~BITS_XTAL_AAC_IOFFSET_8822C))
#define BIT_GET_XTAL_AAC_IOFFSET_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_AAC_IOFFSET_8822C) & \
BIT_MASK_XTAL_AAC_IOFFSET_8822C)
#define BIT_SET_XTAL_AAC_IOFFSET_8822C(x, v) \
(BIT_CLEAR_XTAL_AAC_IOFFSET_8822C(x) | BIT_XTAL_AAC_IOFFSET_8822C(v))
#define BIT_XTAL_AAC_CAP_V1_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ANAPAR_XTAL_AACK_0_8822C */
#define BIT_XAAC_LPOW_8822C BIT(31)
#define BIT_SHIFT_AAC_MODE_8822C 29
#define BIT_MASK_AAC_MODE_8822C 0x3
#define BIT_AAC_MODE_8822C(x) \
(((x) & BIT_MASK_AAC_MODE_8822C) << BIT_SHIFT_AAC_MODE_8822C)
#define BITS_AAC_MODE_8822C \
(BIT_MASK_AAC_MODE_8822C << BIT_SHIFT_AAC_MODE_8822C)
#define BIT_CLEAR_AAC_MODE_8822C(x) ((x) & (~BITS_AAC_MODE_8822C))
#define BIT_GET_AAC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_AAC_MODE_8822C) & BIT_MASK_AAC_MODE_8822C)
#define BIT_SET_AAC_MODE_8822C(x, v) \
(BIT_CLEAR_AAC_MODE_8822C(x) | BIT_AAC_MODE_8822C(v))
#define BIT_EN_XTAL_AAC_TRIG_8822C BIT(28)
#define BIT_EN_XTAL_AAC_8822C BIT(27)
#define BIT_EN_XTAL_AAC_DIGI_8822C BIT(26)
#define BIT_SHIFT_GM_MANUAL_8822C 21
#define BIT_MASK_GM_MANUAL_8822C 0x1f
#define BIT_GM_MANUAL_8822C(x) \
(((x) & BIT_MASK_GM_MANUAL_8822C) << BIT_SHIFT_GM_MANUAL_8822C)
#define BITS_GM_MANUAL_8822C \
(BIT_MASK_GM_MANUAL_8822C << BIT_SHIFT_GM_MANUAL_8822C)
#define BIT_CLEAR_GM_MANUAL_8822C(x) ((x) & (~BITS_GM_MANUAL_8822C))
#define BIT_GET_GM_MANUAL_8822C(x) \
(((x) >> BIT_SHIFT_GM_MANUAL_8822C) & BIT_MASK_GM_MANUAL_8822C)
#define BIT_SET_GM_MANUAL_8822C(x, v) \
(BIT_CLEAR_GM_MANUAL_8822C(x) | BIT_GM_MANUAL_8822C(v))
#define BIT_SHIFT_GM_STUP_8822C 16
#define BIT_MASK_GM_STUP_8822C 0x1f
#define BIT_GM_STUP_8822C(x) \
(((x) & BIT_MASK_GM_STUP_8822C) << BIT_SHIFT_GM_STUP_8822C)
#define BITS_GM_STUP_8822C (BIT_MASK_GM_STUP_8822C << BIT_SHIFT_GM_STUP_8822C)
#define BIT_CLEAR_GM_STUP_8822C(x) ((x) & (~BITS_GM_STUP_8822C))
#define BIT_GET_GM_STUP_8822C(x) \
(((x) >> BIT_SHIFT_GM_STUP_8822C) & BIT_MASK_GM_STUP_8822C)
#define BIT_SET_GM_STUP_8822C(x, v) \
(BIT_CLEAR_GM_STUP_8822C(x) | BIT_GM_STUP_8822C(v))
#define BIT_SHIFT_XTAL_CK_SET_8822C 13
#define BIT_MASK_XTAL_CK_SET_8822C 0x7
#define BIT_XTAL_CK_SET_8822C(x) \
(((x) & BIT_MASK_XTAL_CK_SET_8822C) << BIT_SHIFT_XTAL_CK_SET_8822C)
#define BITS_XTAL_CK_SET_8822C \
(BIT_MASK_XTAL_CK_SET_8822C << BIT_SHIFT_XTAL_CK_SET_8822C)
#define BIT_CLEAR_XTAL_CK_SET_8822C(x) ((x) & (~BITS_XTAL_CK_SET_8822C))
#define BIT_GET_XTAL_CK_SET_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_CK_SET_8822C) & BIT_MASK_XTAL_CK_SET_8822C)
#define BIT_SET_XTAL_CK_SET_8822C(x, v) \
(BIT_CLEAR_XTAL_CK_SET_8822C(x) | BIT_XTAL_CK_SET_8822C(v))
#define BIT_SHIFT_GM_INIT_8822C 8
#define BIT_MASK_GM_INIT_8822C 0x1f
#define BIT_GM_INIT_8822C(x) \
(((x) & BIT_MASK_GM_INIT_8822C) << BIT_SHIFT_GM_INIT_8822C)
#define BITS_GM_INIT_8822C (BIT_MASK_GM_INIT_8822C << BIT_SHIFT_GM_INIT_8822C)
#define BIT_CLEAR_GM_INIT_8822C(x) ((x) & (~BITS_GM_INIT_8822C))
#define BIT_GET_GM_INIT_8822C(x) \
(((x) >> BIT_SHIFT_GM_INIT_8822C) & BIT_MASK_GM_INIT_8822C)
#define BIT_SET_GM_INIT_8822C(x, v) \
(BIT_CLEAR_GM_INIT_8822C(x) | BIT_GM_INIT_8822C(v))
#define BIT_GM_STEP_8822C BIT(7)
#define BIT_SHIFT_XAAC_GM_OFFSET_8822C 2
#define BIT_MASK_XAAC_GM_OFFSET_8822C 0x1f
#define BIT_XAAC_GM_OFFSET_8822C(x) \
(((x) & BIT_MASK_XAAC_GM_OFFSET_8822C) \
<< BIT_SHIFT_XAAC_GM_OFFSET_8822C)
#define BITS_XAAC_GM_OFFSET_8822C \
(BIT_MASK_XAAC_GM_OFFSET_8822C << BIT_SHIFT_XAAC_GM_OFFSET_8822C)
#define BIT_CLEAR_XAAC_GM_OFFSET_8822C(x) ((x) & (~BITS_XAAC_GM_OFFSET_8822C))
#define BIT_GET_XAAC_GM_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_XAAC_GM_OFFSET_8822C) & \
BIT_MASK_XAAC_GM_OFFSET_8822C)
#define BIT_SET_XAAC_GM_OFFSET_8822C(x, v) \
(BIT_CLEAR_XAAC_GM_OFFSET_8822C(x) | BIT_XAAC_GM_OFFSET_8822C(v))
#define BIT_OFFSET_PLUS_8822C BIT(1)
#define BIT_RESET_N_8822C BIT(0)
/* 2 REG_ANAPAR_XTAL_AACK_1_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_PK_END_AR_8822C 3
#define BIT_MASK_PK_END_AR_8822C 0x3
#define BIT_PK_END_AR_8822C(x) \
(((x) & BIT_MASK_PK_END_AR_8822C) << BIT_SHIFT_PK_END_AR_8822C)
#define BITS_PK_END_AR_8822C \
(BIT_MASK_PK_END_AR_8822C << BIT_SHIFT_PK_END_AR_8822C)
#define BIT_CLEAR_PK_END_AR_8822C(x) ((x) & (~BITS_PK_END_AR_8822C))
#define BIT_GET_PK_END_AR_8822C(x) \
(((x) >> BIT_SHIFT_PK_END_AR_8822C) & BIT_MASK_PK_END_AR_8822C)
#define BIT_SET_PK_END_AR_8822C(x, v) \
(BIT_CLEAR_PK_END_AR_8822C(x) | BIT_PK_END_AR_8822C(v))
#define BIT_SHIFT_PK_START_AR_8822C 1
#define BIT_MASK_PK_START_AR_8822C 0x3
#define BIT_PK_START_AR_8822C(x) \
(((x) & BIT_MASK_PK_START_AR_8822C) << BIT_SHIFT_PK_START_AR_8822C)
#define BITS_PK_START_AR_8822C \
(BIT_MASK_PK_START_AR_8822C << BIT_SHIFT_PK_START_AR_8822C)
#define BIT_CLEAR_PK_START_AR_8822C(x) ((x) & (~BITS_PK_START_AR_8822C))
#define BIT_GET_PK_START_AR_8822C(x) \
(((x) >> BIT_SHIFT_PK_START_AR_8822C) & BIT_MASK_PK_START_AR_8822C)
#define BIT_SET_PK_START_AR_8822C(x, v) \
(BIT_CLEAR_PK_START_AR_8822C(x) | BIT_PK_START_AR_8822C(v))
#define BIT_XAAC_LUT_MANUAL_EN_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ANAPAR_XTAL_MODE_DECODER_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_XTAL_LDO_LPS_8822C 21
#define BIT_MASK_XTAL_LDO_LPS_8822C 0x7
#define BIT_XTAL_LDO_LPS_8822C(x) \
(((x) & BIT_MASK_XTAL_LDO_LPS_8822C) << BIT_SHIFT_XTAL_LDO_LPS_8822C)
#define BITS_XTAL_LDO_LPS_8822C \
(BIT_MASK_XTAL_LDO_LPS_8822C << BIT_SHIFT_XTAL_LDO_LPS_8822C)
#define BIT_CLEAR_XTAL_LDO_LPS_8822C(x) ((x) & (~BITS_XTAL_LDO_LPS_8822C))
#define BIT_GET_XTAL_LDO_LPS_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_LPS_8822C) & BIT_MASK_XTAL_LDO_LPS_8822C)
#define BIT_SET_XTAL_LDO_LPS_8822C(x, v) \
(BIT_CLEAR_XTAL_LDO_LPS_8822C(x) | BIT_XTAL_LDO_LPS_8822C(v))
#define BIT_SHIFT_XTAL_WAIT_CYC_8822C 15
#define BIT_MASK_XTAL_WAIT_CYC_8822C 0x3f
#define BIT_XTAL_WAIT_CYC_8822C(x) \
(((x) & BIT_MASK_XTAL_WAIT_CYC_8822C) << BIT_SHIFT_XTAL_WAIT_CYC_8822C)
#define BITS_XTAL_WAIT_CYC_8822C \
(BIT_MASK_XTAL_WAIT_CYC_8822C << BIT_SHIFT_XTAL_WAIT_CYC_8822C)
#define BIT_CLEAR_XTAL_WAIT_CYC_8822C(x) ((x) & (~BITS_XTAL_WAIT_CYC_8822C))
#define BIT_GET_XTAL_WAIT_CYC_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_WAIT_CYC_8822C) & BIT_MASK_XTAL_WAIT_CYC_8822C)
#define BIT_SET_XTAL_WAIT_CYC_8822C(x, v) \
(BIT_CLEAR_XTAL_WAIT_CYC_8822C(x) | BIT_XTAL_WAIT_CYC_8822C(v))
#define BIT_SHIFT_XTAL_LDO_OK_8822C 12
#define BIT_MASK_XTAL_LDO_OK_8822C 0x7
#define BIT_XTAL_LDO_OK_8822C(x) \
(((x) & BIT_MASK_XTAL_LDO_OK_8822C) << BIT_SHIFT_XTAL_LDO_OK_8822C)
#define BITS_XTAL_LDO_OK_8822C \
(BIT_MASK_XTAL_LDO_OK_8822C << BIT_SHIFT_XTAL_LDO_OK_8822C)
#define BIT_CLEAR_XTAL_LDO_OK_8822C(x) ((x) & (~BITS_XTAL_LDO_OK_8822C))
#define BIT_GET_XTAL_LDO_OK_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_LDO_OK_8822C) & BIT_MASK_XTAL_LDO_OK_8822C)
#define BIT_SET_XTAL_LDO_OK_8822C(x, v) \
(BIT_CLEAR_XTAL_LDO_OK_8822C(x) | BIT_XTAL_LDO_OK_8822C(v))
#define BIT_XTAL_MD_LPOW_8822C BIT(11)
#define BIT_SHIFT_XTAL_OV_RATIO_8822C 9
#define BIT_MASK_XTAL_OV_RATIO_8822C 0x3
#define BIT_XTAL_OV_RATIO_8822C(x) \
(((x) & BIT_MASK_XTAL_OV_RATIO_8822C) << BIT_SHIFT_XTAL_OV_RATIO_8822C)
#define BITS_XTAL_OV_RATIO_8822C \
(BIT_MASK_XTAL_OV_RATIO_8822C << BIT_SHIFT_XTAL_OV_RATIO_8822C)
#define BIT_CLEAR_XTAL_OV_RATIO_8822C(x) ((x) & (~BITS_XTAL_OV_RATIO_8822C))
#define BIT_GET_XTAL_OV_RATIO_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_OV_RATIO_8822C) & BIT_MASK_XTAL_OV_RATIO_8822C)
#define BIT_SET_XTAL_OV_RATIO_8822C(x, v) \
(BIT_CLEAR_XTAL_OV_RATIO_8822C(x) | BIT_XTAL_OV_RATIO_8822C(v))
#define BIT_SHIFT_XTAL_OV_UNIT_8822C 6
#define BIT_MASK_XTAL_OV_UNIT_8822C 0x7
#define BIT_XTAL_OV_UNIT_8822C(x) \
(((x) & BIT_MASK_XTAL_OV_UNIT_8822C) << BIT_SHIFT_XTAL_OV_UNIT_8822C)
#define BITS_XTAL_OV_UNIT_8822C \
(BIT_MASK_XTAL_OV_UNIT_8822C << BIT_SHIFT_XTAL_OV_UNIT_8822C)
#define BIT_CLEAR_XTAL_OV_UNIT_8822C(x) ((x) & (~BITS_XTAL_OV_UNIT_8822C))
#define BIT_GET_XTAL_OV_UNIT_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_OV_UNIT_8822C) & BIT_MASK_XTAL_OV_UNIT_8822C)
#define BIT_SET_XTAL_OV_UNIT_8822C(x, v) \
(BIT_CLEAR_XTAL_OV_UNIT_8822C(x) | BIT_XTAL_OV_UNIT_8822C(v))
#define BIT_SHIFT_XTAL_MODE_MANUAL_8822C 4
#define BIT_MASK_XTAL_MODE_MANUAL_8822C 0x3
#define BIT_XTAL_MODE_MANUAL_8822C(x) \
(((x) & BIT_MASK_XTAL_MODE_MANUAL_8822C) \
<< BIT_SHIFT_XTAL_MODE_MANUAL_8822C)
#define BITS_XTAL_MODE_MANUAL_8822C \
(BIT_MASK_XTAL_MODE_MANUAL_8822C << BIT_SHIFT_XTAL_MODE_MANUAL_8822C)
#define BIT_CLEAR_XTAL_MODE_MANUAL_8822C(x) \
((x) & (~BITS_XTAL_MODE_MANUAL_8822C))
#define BIT_GET_XTAL_MODE_MANUAL_8822C(x) \
(((x) >> BIT_SHIFT_XTAL_MODE_MANUAL_8822C) & \
BIT_MASK_XTAL_MODE_MANUAL_8822C)
#define BIT_SET_XTAL_MODE_MANUAL_8822C(x, v) \
(BIT_CLEAR_XTAL_MODE_MANUAL_8822C(x) | BIT_XTAL_MODE_MANUAL_8822C(v))
#define BIT_XTAL_MANU_SEL_8822C BIT(3)
/* 2 REG_NOT_VALID_8822C */
#define BIT_XTAL_MODE_8822C BIT(1)
#define BIT_RESET_N_DECODER_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SYS_CFG5_8822C */
#define BIT_LPS_STATUS_8822C BIT(3)
#define BIT_HCI_TXDMA_BUSY_8822C BIT(2)
#define BIT_HCI_TXDMA_ALLOW_8822C BIT(1)
#define BIT_FW_CTRL_HCI_TXDMA_EN_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_CPU_DMEM_CON_8822C */
#define BIT_WDT_AUTO_MODE_8822C BIT(22)
#define BIT_WDT_PLATFORM_EN_8822C BIT(21)
#define BIT_WDT_CPU_EN_8822C BIT(20)
#define BIT_WDT_OPT_IOWRAPPER_8822C BIT(19)
#define BIT_ANA_PORT_IDLE_8822C BIT(18)
#define BIT_MAC_PORT_IDLE_8822C BIT(17)
#define BIT_WL_PLATFORM_RST_8822C BIT(16)
#define BIT_WL_SECURITY_CLK_8822C BIT(15)
#define BIT_DDMA_EN_8822C BIT(8)
#define BIT_SHIFT_CPU_DMEM_CON_8822C 0
#define BIT_MASK_CPU_DMEM_CON_8822C 0xff
#define BIT_CPU_DMEM_CON_8822C(x) \
(((x) & BIT_MASK_CPU_DMEM_CON_8822C) << BIT_SHIFT_CPU_DMEM_CON_8822C)
#define BITS_CPU_DMEM_CON_8822C \
(BIT_MASK_CPU_DMEM_CON_8822C << BIT_SHIFT_CPU_DMEM_CON_8822C)
#define BIT_CLEAR_CPU_DMEM_CON_8822C(x) ((x) & (~BITS_CPU_DMEM_CON_8822C))
#define BIT_GET_CPU_DMEM_CON_8822C(x) \
(((x) >> BIT_SHIFT_CPU_DMEM_CON_8822C) & BIT_MASK_CPU_DMEM_CON_8822C)
#define BIT_SET_CPU_DMEM_CON_8822C(x, v) \
(BIT_CLEAR_CPU_DMEM_CON_8822C(x) | BIT_CPU_DMEM_CON_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_BOOT_REASON_8822C */
#define BIT_SHIFT_BOOT_REASON_V1_8822C 0
#define BIT_MASK_BOOT_REASON_V1_8822C 0x7
#define BIT_BOOT_REASON_V1_8822C(x) \
(((x) & BIT_MASK_BOOT_REASON_V1_8822C) \
<< BIT_SHIFT_BOOT_REASON_V1_8822C)
#define BITS_BOOT_REASON_V1_8822C \
(BIT_MASK_BOOT_REASON_V1_8822C << BIT_SHIFT_BOOT_REASON_V1_8822C)
#define BIT_CLEAR_BOOT_REASON_V1_8822C(x) ((x) & (~BITS_BOOT_REASON_V1_8822C))
#define BIT_GET_BOOT_REASON_V1_8822C(x) \
(((x) >> BIT_SHIFT_BOOT_REASON_V1_8822C) & \
BIT_MASK_BOOT_REASON_V1_8822C)
#define BIT_SET_BOOT_REASON_V1_8822C(x, v) \
(BIT_CLEAR_BOOT_REASON_V1_8822C(x) | BIT_BOOT_REASON_V1_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_HIMR2_8822C */
#define BIT_BCNDMAINT_P4_MSK_8822C BIT(31)
#define BIT_BCNDMAINT_P3_MSK_8822C BIT(30)
#define BIT_BCNDMAINT_P2_MSK_8822C BIT(29)
#define BIT_BCNDMAINT_P1_MSK_8822C BIT(28)
#define BIT_ATIMEND7_MSK_8822C BIT(22)
#define BIT_ATIMEND6_MSK_8822C BIT(21)
#define BIT_ATIMEND5_MSK_8822C BIT(20)
#define BIT_ATIMEND4_MSK_8822C BIT(19)
#define BIT_ATIMEND3_MSK_8822C BIT(18)
#define BIT_ATIMEND2_MSK_8822C BIT(17)
#define BIT_ATIMEND1_MSK_8822C BIT(16)
#define BIT_TXBCN7OK_MSK_8822C BIT(14)
#define BIT_TXBCN6OK_MSK_8822C BIT(13)
#define BIT_TXBCN5OK_MSK_8822C BIT(12)
#define BIT_TXBCN4OK_MSK_8822C BIT(11)
#define BIT_TXBCN3OK_MSK_8822C BIT(10)
#define BIT_TXBCN2OK_MSK_8822C BIT(9)
#define BIT_TXBCN1OK_MSK_V1_8822C BIT(8)
#define BIT_TXBCN7ERR_MSK_8822C BIT(6)
#define BIT_TXBCN6ERR_MSK_8822C BIT(5)
#define BIT_TXBCN5ERR_MSK_8822C BIT(4)
#define BIT_TXBCN4ERR_MSK_8822C BIT(3)
#define BIT_TXBCN3ERR_MSK_8822C BIT(2)
#define BIT_TXBCN2ERR_MSK_8822C BIT(1)
#define BIT_TXBCN1ERR_MSK_V1_8822C BIT(0)
/* 2 REG_HISR2_8822C */
#define BIT_BCNDMAINT_P4_8822C BIT(31)
#define BIT_BCNDMAINT_P3_8822C BIT(30)
#define BIT_BCNDMAINT_P2_8822C BIT(29)
#define BIT_BCNDMAINT_P1_8822C BIT(28)
#define BIT_ATIMEND7_8822C BIT(22)
#define BIT_ATIMEND6_8822C BIT(21)
#define BIT_ATIMEND5_8822C BIT(20)
#define BIT_ATIMEND4_8822C BIT(19)
#define BIT_ATIMEND3_8822C BIT(18)
#define BIT_ATIMEND2_8822C BIT(17)
#define BIT_ATIMEND1_8822C BIT(16)
#define BIT_TXBCN7OK_8822C BIT(14)
#define BIT_TXBCN6OK_8822C BIT(13)
#define BIT_TXBCN5OK_8822C BIT(12)
#define BIT_TXBCN4OK_8822C BIT(11)
#define BIT_TXBCN3OK_8822C BIT(10)
#define BIT_TXBCN2OK_8822C BIT(9)
#define BIT_TXBCN1OK_8822C BIT(8)
#define BIT_TXBCN7ERR_8822C BIT(6)
#define BIT_TXBCN6ERR_8822C BIT(5)
#define BIT_TXBCN5ERR_8822C BIT(4)
#define BIT_TXBCN4ERR_8822C BIT(3)
#define BIT_TXBCN3ERR_8822C BIT(2)
#define BIT_TXBCN2ERR_8822C BIT(1)
#define BIT_TXBCN1ERR_8822C BIT(0)
/* 2 REG_HIMR3_8822C */
#define BIT_WDT_PLATFORM_INT_MSK_8822C BIT(18)
#define BIT_WDT_CPU_INT_MSK_8822C BIT(17)
#define BIT_SETH2CDOK_MASK_8822C BIT(16)
#define BIT_H2C_CMD_FULL_MASK_8822C BIT(15)
#define BIT_PWR_INT_127_MASK_8822C BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_MASK_8822C BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_MASK_8822C BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_MASK_8822C BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_MAS_8822C BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_MASK_8822C BIT(9)
#define BIT_PWR_INT_127_MASK_V1_8822C BIT(8)
#define BIT_PWR_INT_126TO96_MASK_8822C BIT(7)
#define BIT_PWR_INT_95TO64_MASK_8822C BIT(6)
#define BIT_PWR_INT_63TO32_MASK_8822C BIT(5)
#define BIT_PWR_INT_31TO0_MASK_8822C BIT(4)
#define BIT_RX_DMA_STUCK_MSK_8822C BIT(3)
#define BIT_TX_DMA_STUCK_MSK_8822C BIT(2)
#define BIT_DDMA0_LP_INT_MSK_8822C BIT(1)
#define BIT_DDMA0_HP_INT_MSK_8822C BIT(0)
/* 2 REG_HISR3_8822C */
#define BIT_WDT_PLATFORM_INT_8822C BIT(18)
#define BIT_WDT_CPU_INT_8822C BIT(17)
#define BIT_SETH2CDOK_8822C BIT(16)
#define BIT_H2C_CMD_FULL_8822C BIT(15)
#define BIT_PWR_INT_127_8822C BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8822C BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8822C BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8822C BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8822C BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8822C BIT(9)
#define BIT_PWR_INT_127_V1_8822C BIT(8)
#define BIT_PWR_INT_126TO96_8822C BIT(7)
#define BIT_PWR_INT_95TO64_8822C BIT(6)
#define BIT_PWR_INT_63TO32_8822C BIT(5)
#define BIT_PWR_INT_31TO0_8822C BIT(4)
#define BIT_RX_DMA_STUCK_8822C BIT(3)
#define BIT_TX_DMA_STUCK_8822C BIT(2)
#define BIT_DDMA0_LP_INT_8822C BIT(1)
#define BIT_DDMA0_HP_INT_8822C BIT(0)
/* 2 REG_SW_MDIO_8822C */
#define BIT_DIS_TIMEOUT_IO_8822C BIT(24)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_H2C_PKT_READADDR_8822C */
#define BIT_SHIFT_H2C_PKT_READADDR_8822C 0
#define BIT_MASK_H2C_PKT_READADDR_8822C 0x3ffff
#define BIT_H2C_PKT_READADDR_8822C(x) \
(((x) & BIT_MASK_H2C_PKT_READADDR_8822C) \
<< BIT_SHIFT_H2C_PKT_READADDR_8822C)
#define BITS_H2C_PKT_READADDR_8822C \
(BIT_MASK_H2C_PKT_READADDR_8822C << BIT_SHIFT_H2C_PKT_READADDR_8822C)
#define BIT_CLEAR_H2C_PKT_READADDR_8822C(x) \
((x) & (~BITS_H2C_PKT_READADDR_8822C))
#define BIT_GET_H2C_PKT_READADDR_8822C(x) \
(((x) >> BIT_SHIFT_H2C_PKT_READADDR_8822C) & \
BIT_MASK_H2C_PKT_READADDR_8822C)
#define BIT_SET_H2C_PKT_READADDR_8822C(x, v) \
(BIT_CLEAR_H2C_PKT_READADDR_8822C(x) | BIT_H2C_PKT_READADDR_8822C(v))
/* 2 REG_H2C_PKT_WRITEADDR_8822C */
#define BIT_SHIFT_H2C_PKT_WRITEADDR_8822C 0
#define BIT_MASK_H2C_PKT_WRITEADDR_8822C 0x3ffff
#define BIT_H2C_PKT_WRITEADDR_8822C(x) \
(((x) & BIT_MASK_H2C_PKT_WRITEADDR_8822C) \
<< BIT_SHIFT_H2C_PKT_WRITEADDR_8822C)
#define BITS_H2C_PKT_WRITEADDR_8822C \
(BIT_MASK_H2C_PKT_WRITEADDR_8822C << BIT_SHIFT_H2C_PKT_WRITEADDR_8822C)
#define BIT_CLEAR_H2C_PKT_WRITEADDR_8822C(x) \
((x) & (~BITS_H2C_PKT_WRITEADDR_8822C))
#define BIT_GET_H2C_PKT_WRITEADDR_8822C(x) \
(((x) >> BIT_SHIFT_H2C_PKT_WRITEADDR_8822C) & \
BIT_MASK_H2C_PKT_WRITEADDR_8822C)
#define BIT_SET_H2C_PKT_WRITEADDR_8822C(x, v) \
(BIT_CLEAR_H2C_PKT_WRITEADDR_8822C(x) | BIT_H2C_PKT_WRITEADDR_8822C(v))
/* 2 REG_MEM_PWR_CRTL_8822C */
#define BIT_MEM_BB_SD_8822C BIT(17)
#define BIT_MEM_BB_DS_8822C BIT(16)
#define BIT_MEM_BT_DS_8822C BIT(10)
#define BIT_MEM_SDIO_LS_8822C BIT(9)
#define BIT_MEM_SDIO_DS_8822C BIT(8)
#define BIT_MEM_USB_LS_8822C BIT(7)
#define BIT_MEM_USB_DS_8822C BIT(6)
#define BIT_MEM_PCI_LS_8822C BIT(5)
#define BIT_MEM_PCI_DS_8822C BIT(4)
#define BIT_MEM_WLMAC_LS_8822C BIT(3)
#define BIT_MEM_WLMAC_DS_8822C BIT(2)
#define BIT_MEM_WLMCU_LS_8822C BIT(1)
#define BIT_MEM_WLMCU_DS_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_FW_DBG6_8822C */
#define BIT_SHIFT_FW_DBG6_8822C 0
#define BIT_MASK_FW_DBG6_8822C 0xffffffffL
#define BIT_FW_DBG6_8822C(x) \
(((x) & BIT_MASK_FW_DBG6_8822C) << BIT_SHIFT_FW_DBG6_8822C)
#define BITS_FW_DBG6_8822C (BIT_MASK_FW_DBG6_8822C << BIT_SHIFT_FW_DBG6_8822C)
#define BIT_CLEAR_FW_DBG6_8822C(x) ((x) & (~BITS_FW_DBG6_8822C))
#define BIT_GET_FW_DBG6_8822C(x) \
(((x) >> BIT_SHIFT_FW_DBG6_8822C) & BIT_MASK_FW_DBG6_8822C)
#define BIT_SET_FW_DBG6_8822C(x, v) \
(BIT_CLEAR_FW_DBG6_8822C(x) | BIT_FW_DBG6_8822C(v))
/* 2 REG_FW_DBG7_8822C */
#define BIT_SHIFT_FW_DBG7_8822C 0
#define BIT_MASK_FW_DBG7_8822C 0xffffffffL
#define BIT_FW_DBG7_8822C(x) \
(((x) & BIT_MASK_FW_DBG7_8822C) << BIT_SHIFT_FW_DBG7_8822C)
#define BITS_FW_DBG7_8822C (BIT_MASK_FW_DBG7_8822C << BIT_SHIFT_FW_DBG7_8822C)
#define BIT_CLEAR_FW_DBG7_8822C(x) ((x) & (~BITS_FW_DBG7_8822C))
#define BIT_GET_FW_DBG7_8822C(x) \
(((x) >> BIT_SHIFT_FW_DBG7_8822C) & BIT_MASK_FW_DBG7_8822C)
#define BIT_SET_FW_DBG7_8822C(x, v) \
(BIT_CLEAR_FW_DBG7_8822C(x) | BIT_FW_DBG7_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_CR_8822C */
#define BIT_SHIFT_LBMODE_8822C 24
#define BIT_MASK_LBMODE_8822C 0x1f
#define BIT_LBMODE_8822C(x) \
(((x) & BIT_MASK_LBMODE_8822C) << BIT_SHIFT_LBMODE_8822C)
#define BITS_LBMODE_8822C (BIT_MASK_LBMODE_8822C << BIT_SHIFT_LBMODE_8822C)
#define BIT_CLEAR_LBMODE_8822C(x) ((x) & (~BITS_LBMODE_8822C))
#define BIT_GET_LBMODE_8822C(x) \
(((x) >> BIT_SHIFT_LBMODE_8822C) & BIT_MASK_LBMODE_8822C)
#define BIT_SET_LBMODE_8822C(x, v) \
(BIT_CLEAR_LBMODE_8822C(x) | BIT_LBMODE_8822C(v))
#define BIT_SHIFT_NETYPE1_8822C 18
#define BIT_MASK_NETYPE1_8822C 0x3
#define BIT_NETYPE1_8822C(x) \
(((x) & BIT_MASK_NETYPE1_8822C) << BIT_SHIFT_NETYPE1_8822C)
#define BITS_NETYPE1_8822C (BIT_MASK_NETYPE1_8822C << BIT_SHIFT_NETYPE1_8822C)
#define BIT_CLEAR_NETYPE1_8822C(x) ((x) & (~BITS_NETYPE1_8822C))
#define BIT_GET_NETYPE1_8822C(x) \
(((x) >> BIT_SHIFT_NETYPE1_8822C) & BIT_MASK_NETYPE1_8822C)
#define BIT_SET_NETYPE1_8822C(x, v) \
(BIT_CLEAR_NETYPE1_8822C(x) | BIT_NETYPE1_8822C(v))
#define BIT_SHIFT_NETYPE0_8822C 16
#define BIT_MASK_NETYPE0_8822C 0x3
#define BIT_NETYPE0_8822C(x) \
(((x) & BIT_MASK_NETYPE0_8822C) << BIT_SHIFT_NETYPE0_8822C)
#define BITS_NETYPE0_8822C (BIT_MASK_NETYPE0_8822C << BIT_SHIFT_NETYPE0_8822C)
#define BIT_CLEAR_NETYPE0_8822C(x) ((x) & (~BITS_NETYPE0_8822C))
#define BIT_GET_NETYPE0_8822C(x) \
(((x) >> BIT_SHIFT_NETYPE0_8822C) & BIT_MASK_NETYPE0_8822C)
#define BIT_SET_NETYPE0_8822C(x, v) \
(BIT_CLEAR_NETYPE0_8822C(x) | BIT_NETYPE0_8822C(v))
#define BIT_COUNTER_STS_EN_8822C BIT(13)
#define BIT_I2C_MAILBOX_EN_8822C BIT(12)
#define BIT_SHCUT_EN_8822C BIT(11)
#define BIT_32K_CAL_TMR_EN_8822C BIT(10)
#define BIT_MAC_SEC_EN_8822C BIT(9)
#define BIT_ENSWBCN_8822C BIT(8)
#define BIT_MACRXEN_8822C BIT(7)
#define BIT_MACTXEN_8822C BIT(6)
#define BIT_SCHEDULE_EN_8822C BIT(5)
#define BIT_PROTOCOL_EN_8822C BIT(4)
#define BIT_RXDMA_EN_8822C BIT(3)
#define BIT_TXDMA_EN_8822C BIT(2)
#define BIT_HCI_RXDMA_EN_8822C BIT(1)
#define BIT_HCI_TXDMA_EN_8822C BIT(0)
/* 2 REG_PG_SIZE_8822C */
#define BIT_SHIFT_DBG_FIFO_SEL_8822C 16
#define BIT_MASK_DBG_FIFO_SEL_8822C 0xff
#define BIT_DBG_FIFO_SEL_8822C(x) \
(((x) & BIT_MASK_DBG_FIFO_SEL_8822C) << BIT_SHIFT_DBG_FIFO_SEL_8822C)
#define BITS_DBG_FIFO_SEL_8822C \
(BIT_MASK_DBG_FIFO_SEL_8822C << BIT_SHIFT_DBG_FIFO_SEL_8822C)
#define BIT_CLEAR_DBG_FIFO_SEL_8822C(x) ((x) & (~BITS_DBG_FIFO_SEL_8822C))
#define BIT_GET_DBG_FIFO_SEL_8822C(x) \
(((x) >> BIT_SHIFT_DBG_FIFO_SEL_8822C) & BIT_MASK_DBG_FIFO_SEL_8822C)
#define BIT_SET_DBG_FIFO_SEL_8822C(x, v) \
(BIT_CLEAR_DBG_FIFO_SEL_8822C(x) | BIT_DBG_FIFO_SEL_8822C(v))
/* 2 REG_PKT_BUFF_ACCESS_CTRL_8822C */
#define BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8822C 0
#define BIT_MASK_PKT_BUFF_ACCESS_CTRL_8822C 0xff
#define BIT_PKT_BUFF_ACCESS_CTRL_8822C(x) \
(((x) & BIT_MASK_PKT_BUFF_ACCESS_CTRL_8822C) \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8822C)
#define BITS_PKT_BUFF_ACCESS_CTRL_8822C \
(BIT_MASK_PKT_BUFF_ACCESS_CTRL_8822C \
<< BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8822C)
#define BIT_CLEAR_PKT_BUFF_ACCESS_CTRL_8822C(x) \
((x) & (~BITS_PKT_BUFF_ACCESS_CTRL_8822C))
#define BIT_GET_PKT_BUFF_ACCESS_CTRL_8822C(x) \
(((x) >> BIT_SHIFT_PKT_BUFF_ACCESS_CTRL_8822C) & \
BIT_MASK_PKT_BUFF_ACCESS_CTRL_8822C)
#define BIT_SET_PKT_BUFF_ACCESS_CTRL_8822C(x, v) \
(BIT_CLEAR_PKT_BUFF_ACCESS_CTRL_8822C(x) | \
BIT_PKT_BUFF_ACCESS_CTRL_8822C(v))
/* 2 REG_TSF_CLK_STATE_8822C */
#define BIT_TSF_CLK_STABLE_8822C BIT(15)
/* 2 REG_TXDMA_PQ_MAP_8822C */
#define BIT_CSI_BW_EN_8822C BIT(31)
#define BIT_SHIFT_TXDMA_H2C_MAP_8822C 16
#define BIT_MASK_TXDMA_H2C_MAP_8822C 0x3
#define BIT_TXDMA_H2C_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_H2C_MAP_8822C) << BIT_SHIFT_TXDMA_H2C_MAP_8822C)
#define BITS_TXDMA_H2C_MAP_8822C \
(BIT_MASK_TXDMA_H2C_MAP_8822C << BIT_SHIFT_TXDMA_H2C_MAP_8822C)
#define BIT_CLEAR_TXDMA_H2C_MAP_8822C(x) ((x) & (~BITS_TXDMA_H2C_MAP_8822C))
#define BIT_GET_TXDMA_H2C_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_H2C_MAP_8822C) & BIT_MASK_TXDMA_H2C_MAP_8822C)
#define BIT_SET_TXDMA_H2C_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_H2C_MAP_8822C(x) | BIT_TXDMA_H2C_MAP_8822C(v))
#define BIT_SHIFT_TXDMA_HIQ_MAP_8822C 14
#define BIT_MASK_TXDMA_HIQ_MAP_8822C 0x3
#define BIT_TXDMA_HIQ_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_HIQ_MAP_8822C) << BIT_SHIFT_TXDMA_HIQ_MAP_8822C)
#define BITS_TXDMA_HIQ_MAP_8822C \
(BIT_MASK_TXDMA_HIQ_MAP_8822C << BIT_SHIFT_TXDMA_HIQ_MAP_8822C)
#define BIT_CLEAR_TXDMA_HIQ_MAP_8822C(x) ((x) & (~BITS_TXDMA_HIQ_MAP_8822C))
#define BIT_GET_TXDMA_HIQ_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_HIQ_MAP_8822C) & BIT_MASK_TXDMA_HIQ_MAP_8822C)
#define BIT_SET_TXDMA_HIQ_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_HIQ_MAP_8822C(x) | BIT_TXDMA_HIQ_MAP_8822C(v))
#define BIT_SHIFT_TXDMA_MGQ_MAP_8822C 12
#define BIT_MASK_TXDMA_MGQ_MAP_8822C 0x3
#define BIT_TXDMA_MGQ_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_MGQ_MAP_8822C) << BIT_SHIFT_TXDMA_MGQ_MAP_8822C)
#define BITS_TXDMA_MGQ_MAP_8822C \
(BIT_MASK_TXDMA_MGQ_MAP_8822C << BIT_SHIFT_TXDMA_MGQ_MAP_8822C)
#define BIT_CLEAR_TXDMA_MGQ_MAP_8822C(x) ((x) & (~BITS_TXDMA_MGQ_MAP_8822C))
#define BIT_GET_TXDMA_MGQ_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_MGQ_MAP_8822C) & BIT_MASK_TXDMA_MGQ_MAP_8822C)
#define BIT_SET_TXDMA_MGQ_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_MGQ_MAP_8822C(x) | BIT_TXDMA_MGQ_MAP_8822C(v))
#define BIT_SHIFT_TXDMA_BKQ_MAP_8822C 10
#define BIT_MASK_TXDMA_BKQ_MAP_8822C 0x3
#define BIT_TXDMA_BKQ_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_BKQ_MAP_8822C) << BIT_SHIFT_TXDMA_BKQ_MAP_8822C)
#define BITS_TXDMA_BKQ_MAP_8822C \
(BIT_MASK_TXDMA_BKQ_MAP_8822C << BIT_SHIFT_TXDMA_BKQ_MAP_8822C)
#define BIT_CLEAR_TXDMA_BKQ_MAP_8822C(x) ((x) & (~BITS_TXDMA_BKQ_MAP_8822C))
#define BIT_GET_TXDMA_BKQ_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_BKQ_MAP_8822C) & BIT_MASK_TXDMA_BKQ_MAP_8822C)
#define BIT_SET_TXDMA_BKQ_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_BKQ_MAP_8822C(x) | BIT_TXDMA_BKQ_MAP_8822C(v))
#define BIT_SHIFT_TXDMA_BEQ_MAP_8822C 8
#define BIT_MASK_TXDMA_BEQ_MAP_8822C 0x3
#define BIT_TXDMA_BEQ_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_BEQ_MAP_8822C) << BIT_SHIFT_TXDMA_BEQ_MAP_8822C)
#define BITS_TXDMA_BEQ_MAP_8822C \
(BIT_MASK_TXDMA_BEQ_MAP_8822C << BIT_SHIFT_TXDMA_BEQ_MAP_8822C)
#define BIT_CLEAR_TXDMA_BEQ_MAP_8822C(x) ((x) & (~BITS_TXDMA_BEQ_MAP_8822C))
#define BIT_GET_TXDMA_BEQ_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_BEQ_MAP_8822C) & BIT_MASK_TXDMA_BEQ_MAP_8822C)
#define BIT_SET_TXDMA_BEQ_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_BEQ_MAP_8822C(x) | BIT_TXDMA_BEQ_MAP_8822C(v))
#define BIT_SHIFT_TXDMA_VIQ_MAP_8822C 6
#define BIT_MASK_TXDMA_VIQ_MAP_8822C 0x3
#define BIT_TXDMA_VIQ_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_VIQ_MAP_8822C) << BIT_SHIFT_TXDMA_VIQ_MAP_8822C)
#define BITS_TXDMA_VIQ_MAP_8822C \
(BIT_MASK_TXDMA_VIQ_MAP_8822C << BIT_SHIFT_TXDMA_VIQ_MAP_8822C)
#define BIT_CLEAR_TXDMA_VIQ_MAP_8822C(x) ((x) & (~BITS_TXDMA_VIQ_MAP_8822C))
#define BIT_GET_TXDMA_VIQ_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_VIQ_MAP_8822C) & BIT_MASK_TXDMA_VIQ_MAP_8822C)
#define BIT_SET_TXDMA_VIQ_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_VIQ_MAP_8822C(x) | BIT_TXDMA_VIQ_MAP_8822C(v))
#define BIT_SHIFT_TXDMA_VOQ_MAP_8822C 4
#define BIT_MASK_TXDMA_VOQ_MAP_8822C 0x3
#define BIT_TXDMA_VOQ_MAP_8822C(x) \
(((x) & BIT_MASK_TXDMA_VOQ_MAP_8822C) << BIT_SHIFT_TXDMA_VOQ_MAP_8822C)
#define BITS_TXDMA_VOQ_MAP_8822C \
(BIT_MASK_TXDMA_VOQ_MAP_8822C << BIT_SHIFT_TXDMA_VOQ_MAP_8822C)
#define BIT_CLEAR_TXDMA_VOQ_MAP_8822C(x) ((x) & (~BITS_TXDMA_VOQ_MAP_8822C))
#define BIT_GET_TXDMA_VOQ_MAP_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_VOQ_MAP_8822C) & BIT_MASK_TXDMA_VOQ_MAP_8822C)
#define BIT_SET_TXDMA_VOQ_MAP_8822C(x, v) \
(BIT_CLEAR_TXDMA_VOQ_MAP_8822C(x) | BIT_TXDMA_VOQ_MAP_8822C(v))
#define BIT_TXDMA_BW_EN_8822C BIT(3)
#define BIT_RXDMA_AGG_EN_8822C BIT(2)
#define BIT_RXSHFT_EN_8822C BIT(1)
#define BIT_RXDMA_ARBBW_EN_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_TRXFF_BNDY_8822C */
#define BIT_SHIFT_FWFFOVFL_RSV_8822C 16
#define BIT_MASK_FWFFOVFL_RSV_8822C 0xf
#define BIT_FWFFOVFL_RSV_8822C(x) \
(((x) & BIT_MASK_FWFFOVFL_RSV_8822C) << BIT_SHIFT_FWFFOVFL_RSV_8822C)
#define BITS_FWFFOVFL_RSV_8822C \
(BIT_MASK_FWFFOVFL_RSV_8822C << BIT_SHIFT_FWFFOVFL_RSV_8822C)
#define BIT_CLEAR_FWFFOVFL_RSV_8822C(x) ((x) & (~BITS_FWFFOVFL_RSV_8822C))
#define BIT_GET_FWFFOVFL_RSV_8822C(x) \
(((x) >> BIT_SHIFT_FWFFOVFL_RSV_8822C) & BIT_MASK_FWFFOVFL_RSV_8822C)
#define BIT_SET_FWFFOVFL_RSV_8822C(x, v) \
(BIT_CLEAR_FWFFOVFL_RSV_8822C(x) | BIT_FWFFOVFL_RSV_8822C(v))
#define BIT_SHIFT_RXFFOVFL_RSV_V2_8822C 8
#define BIT_MASK_RXFFOVFL_RSV_V2_8822C 0xf
#define BIT_RXFFOVFL_RSV_V2_8822C(x) \
(((x) & BIT_MASK_RXFFOVFL_RSV_V2_8822C) \
<< BIT_SHIFT_RXFFOVFL_RSV_V2_8822C)
#define BITS_RXFFOVFL_RSV_V2_8822C \
(BIT_MASK_RXFFOVFL_RSV_V2_8822C << BIT_SHIFT_RXFFOVFL_RSV_V2_8822C)
#define BIT_CLEAR_RXFFOVFL_RSV_V2_8822C(x) ((x) & (~BITS_RXFFOVFL_RSV_V2_8822C))
#define BIT_GET_RXFFOVFL_RSV_V2_8822C(x) \
(((x) >> BIT_SHIFT_RXFFOVFL_RSV_V2_8822C) & \
BIT_MASK_RXFFOVFL_RSV_V2_8822C)
#define BIT_SET_RXFFOVFL_RSV_V2_8822C(x, v) \
(BIT_CLEAR_RXFFOVFL_RSV_V2_8822C(x) | BIT_RXFFOVFL_RSV_V2_8822C(v))
/* 2 REG_PTA_I2C_MBOX_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_I2C_M_STATUS_8822C 8
#define BIT_MASK_I2C_M_STATUS_8822C 0xf
#define BIT_I2C_M_STATUS_8822C(x) \
(((x) & BIT_MASK_I2C_M_STATUS_8822C) << BIT_SHIFT_I2C_M_STATUS_8822C)
#define BITS_I2C_M_STATUS_8822C \
(BIT_MASK_I2C_M_STATUS_8822C << BIT_SHIFT_I2C_M_STATUS_8822C)
#define BIT_CLEAR_I2C_M_STATUS_8822C(x) ((x) & (~BITS_I2C_M_STATUS_8822C))
#define BIT_GET_I2C_M_STATUS_8822C(x) \
(((x) >> BIT_SHIFT_I2C_M_STATUS_8822C) & BIT_MASK_I2C_M_STATUS_8822C)
#define BIT_SET_I2C_M_STATUS_8822C(x, v) \
(BIT_CLEAR_I2C_M_STATUS_8822C(x) | BIT_I2C_M_STATUS_8822C(v))
#define BIT_SHIFT_I2C_M_BUS_GNT_FW_8822C 4
#define BIT_MASK_I2C_M_BUS_GNT_FW_8822C 0x7
#define BIT_I2C_M_BUS_GNT_FW_8822C(x) \
(((x) & BIT_MASK_I2C_M_BUS_GNT_FW_8822C) \
<< BIT_SHIFT_I2C_M_BUS_GNT_FW_8822C)
#define BITS_I2C_M_BUS_GNT_FW_8822C \
(BIT_MASK_I2C_M_BUS_GNT_FW_8822C << BIT_SHIFT_I2C_M_BUS_GNT_FW_8822C)
#define BIT_CLEAR_I2C_M_BUS_GNT_FW_8822C(x) \
((x) & (~BITS_I2C_M_BUS_GNT_FW_8822C))
#define BIT_GET_I2C_M_BUS_GNT_FW_8822C(x) \
(((x) >> BIT_SHIFT_I2C_M_BUS_GNT_FW_8822C) & \
BIT_MASK_I2C_M_BUS_GNT_FW_8822C)
#define BIT_SET_I2C_M_BUS_GNT_FW_8822C(x, v) \
(BIT_CLEAR_I2C_M_BUS_GNT_FW_8822C(x) | BIT_I2C_M_BUS_GNT_FW_8822C(v))
#define BIT_I2C_M_GNT_FW_8822C BIT(3)
#define BIT_SHIFT_I2C_M_SPEED_8822C 1
#define BIT_MASK_I2C_M_SPEED_8822C 0x3
#define BIT_I2C_M_SPEED_8822C(x) \
(((x) & BIT_MASK_I2C_M_SPEED_8822C) << BIT_SHIFT_I2C_M_SPEED_8822C)
#define BITS_I2C_M_SPEED_8822C \
(BIT_MASK_I2C_M_SPEED_8822C << BIT_SHIFT_I2C_M_SPEED_8822C)
#define BIT_CLEAR_I2C_M_SPEED_8822C(x) ((x) & (~BITS_I2C_M_SPEED_8822C))
#define BIT_GET_I2C_M_SPEED_8822C(x) \
(((x) >> BIT_SHIFT_I2C_M_SPEED_8822C) & BIT_MASK_I2C_M_SPEED_8822C)
#define BIT_SET_I2C_M_SPEED_8822C(x, v) \
(BIT_CLEAR_I2C_M_SPEED_8822C(x) | BIT_I2C_M_SPEED_8822C(v))
#define BIT_I2C_M_UNLOCK_8822C BIT(0)
/* 2 REG_RXFF_BNDY_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_RXFF0_BNDY_V2_8822C 0
#define BIT_MASK_RXFF0_BNDY_V2_8822C 0x3ffff
#define BIT_RXFF0_BNDY_V2_8822C(x) \
(((x) & BIT_MASK_RXFF0_BNDY_V2_8822C) << BIT_SHIFT_RXFF0_BNDY_V2_8822C)
#define BITS_RXFF0_BNDY_V2_8822C \
(BIT_MASK_RXFF0_BNDY_V2_8822C << BIT_SHIFT_RXFF0_BNDY_V2_8822C)
#define BIT_CLEAR_RXFF0_BNDY_V2_8822C(x) ((x) & (~BITS_RXFF0_BNDY_V2_8822C))
#define BIT_GET_RXFF0_BNDY_V2_8822C(x) \
(((x) >> BIT_SHIFT_RXFF0_BNDY_V2_8822C) & BIT_MASK_RXFF0_BNDY_V2_8822C)
#define BIT_SET_RXFF0_BNDY_V2_8822C(x, v) \
(BIT_CLEAR_RXFF0_BNDY_V2_8822C(x) | BIT_RXFF0_BNDY_V2_8822C(v))
/* 2 REG_FE1IMR_8822C */
#define BIT_FS_SW_PLL_LEAVE_32K_INT_EN_8822C BIT(31)
#define BIT_FS_FWFF_FULL_INT_EN_8822C BIT(30)
#define BIT_FS_BB_STOP_RX_INT_EN_8822C BIT(29)
#define BIT_FS_RXDMA2_DONE_INT_EN_8822C BIT(28)
#define BIT_FS_RXDONE2_INT_EN_8822C BIT(26)
#define BIT_FS_RX_BCN_P4_INT_EN_8822C BIT(25)
#define BIT_FS_RX_BCN_P3_INT_EN_8822C BIT(24)
#define BIT_FS_RX_BCN_P2_INT_EN_8822C BIT(23)
#define BIT_FS_RX_BCN_P1_INT_EN_8822C BIT(22)
#define BIT_FS_RX_BCN_P0_INT_EN_8822C BIT(21)
#define BIT_FS_RX_UMD0_INT_EN_8822C BIT(20)
#define BIT_FS_RX_UMD1_INT_EN_8822C BIT(19)
#define BIT_FS_RX_BMD0_INT_EN_8822C BIT(18)
#define BIT_FS_RX_BMD1_INT_EN_8822C BIT(17)
#define BIT_FS_RXDONE_INT_EN_8822C BIT(16)
#define BIT_FS_WWLAN_INT_EN_8822C BIT(15)
#define BIT_FS_SOUND_DONE_INT_EN_8822C BIT(14)
#define BIT_FS_BF1_PRETO_INT_EN_8822C BIT(11)
#define BIT_FS_BF0_PRETO_INT_EN_8822C BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_EN_8822C BIT(9)
#define BIT_FS_PRETX_ERRHLD_INT_EN_8822C BIT(8)
#define BIT_FS_LTE_COEX_EN_8822C BIT(6)
#define BIT_FS_WLACTOFF_INT_EN_8822C BIT(5)
#define BIT_FS_WLACTON_INT_EN_8822C BIT(4)
#define BIT_FS_BTCMD_INT_EN_8822C BIT(3)
#define BIT_FS_REG_MAILBOX_TO_I2C_INT_EN_8822C BIT(2)
#define BIT_FS_TRPC_TO_INT_EN_V1_8822C BIT(1)
#define BIT_FS_RPC_O_T_INT_EN_V1_8822C BIT(0)
/* 2 REG_FE1ISR_8822C */
#define BIT_FS_SW_PLL_LEAVE_32K_INT_8822C BIT(31)
#define BIT_FS_FS_FWFF_FULL_INT_8822C BIT(30)
#define BIT_FS_BB_STOP_RX_INT_8822C BIT(29)
#define BIT_FS_RXDMA2_DONE_INT_8822C BIT(28)
#define BIT_FS_RXDONE2_INT_8822C BIT(26)
#define BIT_FS_RX_BCN_P4_INT_8822C BIT(25)
#define BIT_FS_RX_BCN_P3_INT_8822C BIT(24)
#define BIT_FS_RX_BCN_P2_INT_8822C BIT(23)
#define BIT_FS_RX_BCN_P1_INT_8822C BIT(22)
#define BIT_FS_RX_BCN_P0_INT_8822C BIT(21)
#define BIT_FS_RX_UMD0_INT_8822C BIT(20)
#define BIT_FS_RX_UMD1_INT_8822C BIT(19)
#define BIT_FS_RX_BMD0_INT_8822C BIT(18)
#define BIT_FS_RX_BMD1_INT_8822C BIT(17)
#define BIT_FS_RXDONE_INT_8822C BIT(16)
#define BIT_FS_WWLAN_INT_8822C BIT(15)
#define BIT_FS_SOUND_DONE_INT_8822C BIT(14)
#define BIT_FS_BF1_PRETO_INT_8822C BIT(11)
#define BIT_FS_BF0_PRETO_INT_8822C BIT(10)
#define BIT_FS_PTCL_RELEASE_MACID_INT_8822C BIT(9)
#define BIT_FS_PRETX_ERRHLD_INT_8822C BIT(8)
#define BIT_FS_LTE_COEX_INT_8822C BIT(6)
#define BIT_FS_WLACTOFF_INT_8822C BIT(5)
#define BIT_FS_WLACTON_INT_8822C BIT(4)
#define BIT_FS_BCN_RX_INT_INT_8822C BIT(3)
#define BIT_FS_MAILBOX_TO_I2C_INT_8822C BIT(2)
#define BIT_FS_TRPC_TO_INT_8822C BIT(1)
#define BIT_FS_RPC_O_T_INT_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_CPWM_8822C */
#define BIT_CPWM_TOGGLING_8822C BIT(31)
#define BIT_SHIFT_CPWM_MOD_8822C 24
#define BIT_MASK_CPWM_MOD_8822C 0x7f
#define BIT_CPWM_MOD_8822C(x) \
(((x) & BIT_MASK_CPWM_MOD_8822C) << BIT_SHIFT_CPWM_MOD_8822C)
#define BITS_CPWM_MOD_8822C \
(BIT_MASK_CPWM_MOD_8822C << BIT_SHIFT_CPWM_MOD_8822C)
#define BIT_CLEAR_CPWM_MOD_8822C(x) ((x) & (~BITS_CPWM_MOD_8822C))
#define BIT_GET_CPWM_MOD_8822C(x) \
(((x) >> BIT_SHIFT_CPWM_MOD_8822C) & BIT_MASK_CPWM_MOD_8822C)
#define BIT_SET_CPWM_MOD_8822C(x, v) \
(BIT_CLEAR_CPWM_MOD_8822C(x) | BIT_CPWM_MOD_8822C(v))
/* 2 REG_FWIMR_8822C */
#define BIT_FS_TXBCNOK_MB7_INT_EN_8822C BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_EN_8822C BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_EN_8822C BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_EN_8822C BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_EN_8822C BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_EN_8822C BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_EN_8822C BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_EN_8822C BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_EN_8822C BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_EN_8822C BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_EN_8822C BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_EN_8822C BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_EN_8822C BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_EN_8822C BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_EN_8822C BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_EN_8822C BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_EN_8822C BIT(15)
#define BIT_SIFS_OVERSPEC_INT_EN_8822C BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_EN_8822C BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_EN_8822C BIT(12)
#define BIT_FS_CPUMGQ_ERR_INT_EN_8822C BIT(11)
#define BIT_FS_DDMA0_LP_INT_EN_8822C BIT(9)
#define BIT_FS_DDMA0_HP_INT_EN_8822C BIT(8)
#define BIT_FS_TRXRPT_INT_EN_8822C BIT(7)
#define BIT_FS_C2H_W_READY_INT_EN_8822C BIT(6)
#define BIT_FS_HRCV_INT_EN_8822C BIT(5)
#define BIT_FS_H2CCMD_INT_EN_8822C BIT(4)
#define BIT_FS_TXPKTIN_INT_EN_8822C BIT(3)
#define BIT_FS_ERRORHDL_INT_EN_8822C BIT(2)
#define BIT_FS_TXCCX_INT_EN_8822C BIT(1)
#define BIT_FS_TXCLOSE_INT_EN_8822C BIT(0)
/* 2 REG_FWISR_8822C */
#define BIT_FS_TXBCNOK_MB7_INT_8822C BIT(31)
#define BIT_FS_TXBCNOK_MB6_INT_8822C BIT(30)
#define BIT_FS_TXBCNOK_MB5_INT_8822C BIT(29)
#define BIT_FS_TXBCNOK_MB4_INT_8822C BIT(28)
#define BIT_FS_TXBCNOK_MB3_INT_8822C BIT(27)
#define BIT_FS_TXBCNOK_MB2_INT_8822C BIT(26)
#define BIT_FS_TXBCNOK_MB1_INT_8822C BIT(25)
#define BIT_FS_TXBCNOK_MB0_INT_8822C BIT(24)
#define BIT_FS_TXBCNERR_MB7_INT_8822C BIT(23)
#define BIT_FS_TXBCNERR_MB6_INT_8822C BIT(22)
#define BIT_FS_TXBCNERR_MB5_INT_8822C BIT(21)
#define BIT_FS_TXBCNERR_MB4_INT_8822C BIT(20)
#define BIT_FS_TXBCNERR_MB3_INT_8822C BIT(19)
#define BIT_FS_TXBCNERR_MB2_INT_8822C BIT(18)
#define BIT_FS_TXBCNERR_MB1_INT_8822C BIT(17)
#define BIT_FS_TXBCNERR_MB0_INT_8822C BIT(16)
#define BIT_CPU_MGQ_TXDONE_INT_8822C BIT(15)
#define BIT_SIFS_OVERSPEC_INT_8822C BIT(14)
#define BIT_FS_MGNTQ_RPTR_RELEASE_INT_8822C BIT(13)
#define BIT_FS_MGNTQFF_TO_INT_8822C BIT(12)
#define BIT_FS_CPUMGQ_ERR_INT_8822C BIT(11)
#define BIT_FS_DDMA0_LP_INT_8822C BIT(9)
#define BIT_FS_DDMA0_HP_INT_8822C BIT(8)
#define BIT_FS_TRXRPT_INT_8822C BIT(7)
#define BIT_FS_C2H_W_READY_INT_8822C BIT(6)
#define BIT_FS_HRCV_INT_8822C BIT(5)
#define BIT_FS_H2CCMD_INT_8822C BIT(4)
#define BIT_FS_TXPKTIN_INT_8822C BIT(3)
#define BIT_FS_ERRORHDL_INT_8822C BIT(2)
#define BIT_FS_TXCCX_INT_8822C BIT(1)
#define BIT_FS_TXCLOSE_INT_8822C BIT(0)
/* 2 REG_FTIMR_8822C */
#define BIT_PS_TIMER_C_EARLY_INT_EN_8822C BIT(23)
#define BIT_PS_TIMER_B_EARLY_INT_EN_8822C BIT(22)
#define BIT_PS_TIMER_A_EARLY_INT_EN_8822C BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_EN_8822C BIT(20)
#define BIT_PS_TIMER_C_INT_EN_8822C BIT(19)
#define BIT_PS_TIMER_B_INT_EN_8822C BIT(18)
#define BIT_PS_TIMER_A_INT_EN_8822C BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_EN_8822C BIT(16)
#define BIT_FS_PS_TIMEOUT2_EN_8822C BIT(15)
#define BIT_FS_PS_TIMEOUT1_EN_8822C BIT(14)
#define BIT_FS_PS_TIMEOUT0_EN_8822C BIT(13)
#define BIT_FS_GTINT8_EN_8822C BIT(8)
#define BIT_FS_GTINT7_EN_8822C BIT(7)
#define BIT_FS_GTINT6_EN_8822C BIT(6)
#define BIT_FS_GTINT5_EN_8822C BIT(5)
#define BIT_FS_GTINT4_EN_8822C BIT(4)
#define BIT_FS_GTINT3_EN_8822C BIT(3)
#define BIT_FS_GTINT2_EN_8822C BIT(2)
#define BIT_FS_GTINT1_EN_8822C BIT(1)
#define BIT_FS_GTINT0_EN_8822C BIT(0)
/* 2 REG_FTISR_8822C */
#define BIT_PS_TIMER_C_EARLY__INT_8822C BIT(23)
#define BIT_PS_TIMER_B_EARLY__INT_8822C BIT(22)
#define BIT_PS_TIMER_A_EARLY__INT_8822C BIT(21)
#define BIT_CPUMGQ_TX_TIMER_EARLY_INT_8822C BIT(20)
#define BIT_PS_TIMER_C_INT_8822C BIT(19)
#define BIT_PS_TIMER_B_INT_8822C BIT(18)
#define BIT_PS_TIMER_A_INT_8822C BIT(17)
#define BIT_CPUMGQ_TX_TIMER_INT_8822C BIT(16)
#define BIT_FS_PS_TIMEOUT2_INT_8822C BIT(15)
#define BIT_FS_PS_TIMEOUT1_INT_8822C BIT(14)
#define BIT_FS_PS_TIMEOUT0_INT_8822C BIT(13)
#define BIT_FS_GTINT8_INT_8822C BIT(8)
#define BIT_FS_GTINT7_INT_8822C BIT(7)
#define BIT_FS_GTINT6_INT_8822C BIT(6)
#define BIT_FS_GTINT5_INT_8822C BIT(5)
#define BIT_FS_GTINT4_INT_8822C BIT(4)
#define BIT_FS_GTINT3_INT_8822C BIT(3)
#define BIT_FS_GTINT2_INT_8822C BIT(2)
#define BIT_FS_GTINT1_INT_8822C BIT(1)
#define BIT_FS_GTINT0_INT_8822C BIT(0)
/* 2 REG_PKTBUF_DBG_CTRL_8822C */
#define BIT_SHIFT_PKTBUF_WRITE_EN_8822C 24
#define BIT_MASK_PKTBUF_WRITE_EN_8822C 0xff
#define BIT_PKTBUF_WRITE_EN_8822C(x) \
(((x) & BIT_MASK_PKTBUF_WRITE_EN_8822C) \
<< BIT_SHIFT_PKTBUF_WRITE_EN_8822C)
#define BITS_PKTBUF_WRITE_EN_8822C \
(BIT_MASK_PKTBUF_WRITE_EN_8822C << BIT_SHIFT_PKTBUF_WRITE_EN_8822C)
#define BIT_CLEAR_PKTBUF_WRITE_EN_8822C(x) ((x) & (~BITS_PKTBUF_WRITE_EN_8822C))
#define BIT_GET_PKTBUF_WRITE_EN_8822C(x) \
(((x) >> BIT_SHIFT_PKTBUF_WRITE_EN_8822C) & \
BIT_MASK_PKTBUF_WRITE_EN_8822C)
#define BIT_SET_PKTBUF_WRITE_EN_8822C(x, v) \
(BIT_CLEAR_PKTBUF_WRITE_EN_8822C(x) | BIT_PKTBUF_WRITE_EN_8822C(v))
#define BIT_TXRPTBUF_DBG_8822C BIT(23)
/* 2 REG_NOT_VALID_8822C */
#define BIT_TXPKTBUF_DBG_V2_8822C BIT(20)
#define BIT_RXPKTBUF_DBG_8822C BIT(16)
#define BIT_SHIFT_PKTBUF_DBG_ADDR_8822C 0
#define BIT_MASK_PKTBUF_DBG_ADDR_8822C 0x1fff
#define BIT_PKTBUF_DBG_ADDR_8822C(x) \
(((x) & BIT_MASK_PKTBUF_DBG_ADDR_8822C) \
<< BIT_SHIFT_PKTBUF_DBG_ADDR_8822C)
#define BITS_PKTBUF_DBG_ADDR_8822C \
(BIT_MASK_PKTBUF_DBG_ADDR_8822C << BIT_SHIFT_PKTBUF_DBG_ADDR_8822C)
#define BIT_CLEAR_PKTBUF_DBG_ADDR_8822C(x) ((x) & (~BITS_PKTBUF_DBG_ADDR_8822C))
#define BIT_GET_PKTBUF_DBG_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_ADDR_8822C) & \
BIT_MASK_PKTBUF_DBG_ADDR_8822C)
#define BIT_SET_PKTBUF_DBG_ADDR_8822C(x, v) \
(BIT_CLEAR_PKTBUF_DBG_ADDR_8822C(x) | BIT_PKTBUF_DBG_ADDR_8822C(v))
/* 2 REG_PKTBUF_DBG_DATA_L_8822C */
#define BIT_SHIFT_PKTBUF_DBG_DATA_L_8822C 0
#define BIT_MASK_PKTBUF_DBG_DATA_L_8822C 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_L_8822C(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_L_8822C) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_L_8822C)
#define BITS_PKTBUF_DBG_DATA_L_8822C \
(BIT_MASK_PKTBUF_DBG_DATA_L_8822C << BIT_SHIFT_PKTBUF_DBG_DATA_L_8822C)
#define BIT_CLEAR_PKTBUF_DBG_DATA_L_8822C(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_L_8822C))
#define BIT_GET_PKTBUF_DBG_DATA_L_8822C(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_L_8822C) & \
BIT_MASK_PKTBUF_DBG_DATA_L_8822C)
#define BIT_SET_PKTBUF_DBG_DATA_L_8822C(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_L_8822C(x) | BIT_PKTBUF_DBG_DATA_L_8822C(v))
/* 2 REG_PKTBUF_DBG_DATA_H_8822C */
#define BIT_SHIFT_PKTBUF_DBG_DATA_H_8822C 0
#define BIT_MASK_PKTBUF_DBG_DATA_H_8822C 0xffffffffL
#define BIT_PKTBUF_DBG_DATA_H_8822C(x) \
(((x) & BIT_MASK_PKTBUF_DBG_DATA_H_8822C) \
<< BIT_SHIFT_PKTBUF_DBG_DATA_H_8822C)
#define BITS_PKTBUF_DBG_DATA_H_8822C \
(BIT_MASK_PKTBUF_DBG_DATA_H_8822C << BIT_SHIFT_PKTBUF_DBG_DATA_H_8822C)
#define BIT_CLEAR_PKTBUF_DBG_DATA_H_8822C(x) \
((x) & (~BITS_PKTBUF_DBG_DATA_H_8822C))
#define BIT_GET_PKTBUF_DBG_DATA_H_8822C(x) \
(((x) >> BIT_SHIFT_PKTBUF_DBG_DATA_H_8822C) & \
BIT_MASK_PKTBUF_DBG_DATA_H_8822C)
#define BIT_SET_PKTBUF_DBG_DATA_H_8822C(x, v) \
(BIT_CLEAR_PKTBUF_DBG_DATA_H_8822C(x) | BIT_PKTBUF_DBG_DATA_H_8822C(v))
/* 2 REG_CPWM2_8822C */
#define BIT_SHIFT_L0S_TO_RCVY_NUM_8822C 16
#define BIT_MASK_L0S_TO_RCVY_NUM_8822C 0xff
#define BIT_L0S_TO_RCVY_NUM_8822C(x) \
(((x) & BIT_MASK_L0S_TO_RCVY_NUM_8822C) \
<< BIT_SHIFT_L0S_TO_RCVY_NUM_8822C)
#define BITS_L0S_TO_RCVY_NUM_8822C \
(BIT_MASK_L0S_TO_RCVY_NUM_8822C << BIT_SHIFT_L0S_TO_RCVY_NUM_8822C)
#define BIT_CLEAR_L0S_TO_RCVY_NUM_8822C(x) ((x) & (~BITS_L0S_TO_RCVY_NUM_8822C))
#define BIT_GET_L0S_TO_RCVY_NUM_8822C(x) \
(((x) >> BIT_SHIFT_L0S_TO_RCVY_NUM_8822C) & \
BIT_MASK_L0S_TO_RCVY_NUM_8822C)
#define BIT_SET_L0S_TO_RCVY_NUM_8822C(x, v) \
(BIT_CLEAR_L0S_TO_RCVY_NUM_8822C(x) | BIT_L0S_TO_RCVY_NUM_8822C(v))
#define BIT_CPWM2_TOGGLING_8822C BIT(15)
#define BIT_SHIFT_CPWM2_MOD_8822C 0
#define BIT_MASK_CPWM2_MOD_8822C 0x7fff
#define BIT_CPWM2_MOD_8822C(x) \
(((x) & BIT_MASK_CPWM2_MOD_8822C) << BIT_SHIFT_CPWM2_MOD_8822C)
#define BITS_CPWM2_MOD_8822C \
(BIT_MASK_CPWM2_MOD_8822C << BIT_SHIFT_CPWM2_MOD_8822C)
#define BIT_CLEAR_CPWM2_MOD_8822C(x) ((x) & (~BITS_CPWM2_MOD_8822C))
#define BIT_GET_CPWM2_MOD_8822C(x) \
(((x) >> BIT_SHIFT_CPWM2_MOD_8822C) & BIT_MASK_CPWM2_MOD_8822C)
#define BIT_SET_CPWM2_MOD_8822C(x, v) \
(BIT_CLEAR_CPWM2_MOD_8822C(x) | BIT_CPWM2_MOD_8822C(v))
/* 2 REG_TC0_CTRL_8822C */
#define BIT_TC0INT_EN_8822C BIT(26)
#define BIT_TC0MODE_8822C BIT(25)
#define BIT_TC0EN_8822C BIT(24)
#define BIT_SHIFT_TC0DATA_8822C 0
#define BIT_MASK_TC0DATA_8822C 0xffffff
#define BIT_TC0DATA_8822C(x) \
(((x) & BIT_MASK_TC0DATA_8822C) << BIT_SHIFT_TC0DATA_8822C)
#define BITS_TC0DATA_8822C (BIT_MASK_TC0DATA_8822C << BIT_SHIFT_TC0DATA_8822C)
#define BIT_CLEAR_TC0DATA_8822C(x) ((x) & (~BITS_TC0DATA_8822C))
#define BIT_GET_TC0DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC0DATA_8822C) & BIT_MASK_TC0DATA_8822C)
#define BIT_SET_TC0DATA_8822C(x, v) \
(BIT_CLEAR_TC0DATA_8822C(x) | BIT_TC0DATA_8822C(v))
/* 2 REG_TC1_CTRL_8822C */
#define BIT_TC1INT_EN_8822C BIT(26)
#define BIT_TC1MODE_8822C BIT(25)
#define BIT_TC1EN_8822C BIT(24)
#define BIT_SHIFT_TC1DATA_8822C 0
#define BIT_MASK_TC1DATA_8822C 0xffffff
#define BIT_TC1DATA_8822C(x) \
(((x) & BIT_MASK_TC1DATA_8822C) << BIT_SHIFT_TC1DATA_8822C)
#define BITS_TC1DATA_8822C (BIT_MASK_TC1DATA_8822C << BIT_SHIFT_TC1DATA_8822C)
#define BIT_CLEAR_TC1DATA_8822C(x) ((x) & (~BITS_TC1DATA_8822C))
#define BIT_GET_TC1DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC1DATA_8822C) & BIT_MASK_TC1DATA_8822C)
#define BIT_SET_TC1DATA_8822C(x, v) \
(BIT_CLEAR_TC1DATA_8822C(x) | BIT_TC1DATA_8822C(v))
/* 2 REG_TC2_CTRL_8822C */
#define BIT_TC2INT_EN_8822C BIT(26)
#define BIT_TC2MODE_8822C BIT(25)
#define BIT_TC2EN_8822C BIT(24)
#define BIT_SHIFT_TC2DATA_8822C 0
#define BIT_MASK_TC2DATA_8822C 0xffffff
#define BIT_TC2DATA_8822C(x) \
(((x) & BIT_MASK_TC2DATA_8822C) << BIT_SHIFT_TC2DATA_8822C)
#define BITS_TC2DATA_8822C (BIT_MASK_TC2DATA_8822C << BIT_SHIFT_TC2DATA_8822C)
#define BIT_CLEAR_TC2DATA_8822C(x) ((x) & (~BITS_TC2DATA_8822C))
#define BIT_GET_TC2DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC2DATA_8822C) & BIT_MASK_TC2DATA_8822C)
#define BIT_SET_TC2DATA_8822C(x, v) \
(BIT_CLEAR_TC2DATA_8822C(x) | BIT_TC2DATA_8822C(v))
/* 2 REG_TC3_CTRL_8822C */
#define BIT_TC3INT_EN_8822C BIT(26)
#define BIT_TC3MODE_8822C BIT(25)
#define BIT_TC3EN_8822C BIT(24)
#define BIT_SHIFT_TC3DATA_8822C 0
#define BIT_MASK_TC3DATA_8822C 0xffffff
#define BIT_TC3DATA_8822C(x) \
(((x) & BIT_MASK_TC3DATA_8822C) << BIT_SHIFT_TC3DATA_8822C)
#define BITS_TC3DATA_8822C (BIT_MASK_TC3DATA_8822C << BIT_SHIFT_TC3DATA_8822C)
#define BIT_CLEAR_TC3DATA_8822C(x) ((x) & (~BITS_TC3DATA_8822C))
#define BIT_GET_TC3DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC3DATA_8822C) & BIT_MASK_TC3DATA_8822C)
#define BIT_SET_TC3DATA_8822C(x, v) \
(BIT_CLEAR_TC3DATA_8822C(x) | BIT_TC3DATA_8822C(v))
/* 2 REG_TC4_CTRL_8822C */
#define BIT_TC4INT_EN_8822C BIT(26)
#define BIT_TC4MODE_8822C BIT(25)
#define BIT_TC4EN_8822C BIT(24)
#define BIT_SHIFT_TC4DATA_8822C 0
#define BIT_MASK_TC4DATA_8822C 0xffffff
#define BIT_TC4DATA_8822C(x) \
(((x) & BIT_MASK_TC4DATA_8822C) << BIT_SHIFT_TC4DATA_8822C)
#define BITS_TC4DATA_8822C (BIT_MASK_TC4DATA_8822C << BIT_SHIFT_TC4DATA_8822C)
#define BIT_CLEAR_TC4DATA_8822C(x) ((x) & (~BITS_TC4DATA_8822C))
#define BIT_GET_TC4DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC4DATA_8822C) & BIT_MASK_TC4DATA_8822C)
#define BIT_SET_TC4DATA_8822C(x, v) \
(BIT_CLEAR_TC4DATA_8822C(x) | BIT_TC4DATA_8822C(v))
/* 2 REG_TCUNIT_BASE_8822C */
#define BIT_SHIFT_TCUNIT_BASE_8822C 0
#define BIT_MASK_TCUNIT_BASE_8822C 0x3fff
#define BIT_TCUNIT_BASE_8822C(x) \
(((x) & BIT_MASK_TCUNIT_BASE_8822C) << BIT_SHIFT_TCUNIT_BASE_8822C)
#define BITS_TCUNIT_BASE_8822C \
(BIT_MASK_TCUNIT_BASE_8822C << BIT_SHIFT_TCUNIT_BASE_8822C)
#define BIT_CLEAR_TCUNIT_BASE_8822C(x) ((x) & (~BITS_TCUNIT_BASE_8822C))
#define BIT_GET_TCUNIT_BASE_8822C(x) \
(((x) >> BIT_SHIFT_TCUNIT_BASE_8822C) & BIT_MASK_TCUNIT_BASE_8822C)
#define BIT_SET_TCUNIT_BASE_8822C(x, v) \
(BIT_CLEAR_TCUNIT_BASE_8822C(x) | BIT_TCUNIT_BASE_8822C(v))
/* 2 REG_TC5_CTRL_8822C */
#define BIT_TC5INT_EN_8822C BIT(26)
#define BIT_TC5MODE_8822C BIT(25)
#define BIT_TC5EN_8822C BIT(24)
#define BIT_SHIFT_TC5DATA_8822C 0
#define BIT_MASK_TC5DATA_8822C 0xffffff
#define BIT_TC5DATA_8822C(x) \
(((x) & BIT_MASK_TC5DATA_8822C) << BIT_SHIFT_TC5DATA_8822C)
#define BITS_TC5DATA_8822C (BIT_MASK_TC5DATA_8822C << BIT_SHIFT_TC5DATA_8822C)
#define BIT_CLEAR_TC5DATA_8822C(x) ((x) & (~BITS_TC5DATA_8822C))
#define BIT_GET_TC5DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC5DATA_8822C) & BIT_MASK_TC5DATA_8822C)
#define BIT_SET_TC5DATA_8822C(x, v) \
(BIT_CLEAR_TC5DATA_8822C(x) | BIT_TC5DATA_8822C(v))
/* 2 REG_TC6_CTRL_8822C */
#define BIT_TC6INT_EN_8822C BIT(26)
#define BIT_TC6MODE_8822C BIT(25)
#define BIT_TC6EN_8822C BIT(24)
#define BIT_SHIFT_TC6DATA_8822C 0
#define BIT_MASK_TC6DATA_8822C 0xffffff
#define BIT_TC6DATA_8822C(x) \
(((x) & BIT_MASK_TC6DATA_8822C) << BIT_SHIFT_TC6DATA_8822C)
#define BITS_TC6DATA_8822C (BIT_MASK_TC6DATA_8822C << BIT_SHIFT_TC6DATA_8822C)
#define BIT_CLEAR_TC6DATA_8822C(x) ((x) & (~BITS_TC6DATA_8822C))
#define BIT_GET_TC6DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC6DATA_8822C) & BIT_MASK_TC6DATA_8822C)
#define BIT_SET_TC6DATA_8822C(x, v) \
(BIT_CLEAR_TC6DATA_8822C(x) | BIT_TC6DATA_8822C(v))
/* 2 REG_MBIST_DRF_FAIL_8822C */
#define BIT_SHIFT_8051_MBIST_DRF_FAIL_8822C 26
#define BIT_MASK_8051_MBIST_DRF_FAIL_8822C 0x3f
#define BIT_8051_MBIST_DRF_FAIL_8822C(x) \
(((x) & BIT_MASK_8051_MBIST_DRF_FAIL_8822C) \
<< BIT_SHIFT_8051_MBIST_DRF_FAIL_8822C)
#define BITS_8051_MBIST_DRF_FAIL_8822C \
(BIT_MASK_8051_MBIST_DRF_FAIL_8822C \
<< BIT_SHIFT_8051_MBIST_DRF_FAIL_8822C)
#define BIT_CLEAR_8051_MBIST_DRF_FAIL_8822C(x) \
((x) & (~BITS_8051_MBIST_DRF_FAIL_8822C))
#define BIT_GET_8051_MBIST_DRF_FAIL_8822C(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DRF_FAIL_8822C) & \
BIT_MASK_8051_MBIST_DRF_FAIL_8822C)
#define BIT_SET_8051_MBIST_DRF_FAIL_8822C(x, v) \
(BIT_CLEAR_8051_MBIST_DRF_FAIL_8822C(x) | \
BIT_8051_MBIST_DRF_FAIL_8822C(v))
#define BIT_SHIFT_USB_MBIST_DRF_FAIL_8822C 24
#define BIT_MASK_USB_MBIST_DRF_FAIL_8822C 0x3
#define BIT_USB_MBIST_DRF_FAIL_8822C(x) \
(((x) & BIT_MASK_USB_MBIST_DRF_FAIL_8822C) \
<< BIT_SHIFT_USB_MBIST_DRF_FAIL_8822C)
#define BITS_USB_MBIST_DRF_FAIL_8822C \
(BIT_MASK_USB_MBIST_DRF_FAIL_8822C \
<< BIT_SHIFT_USB_MBIST_DRF_FAIL_8822C)
#define BIT_CLEAR_USB_MBIST_DRF_FAIL_8822C(x) \
((x) & (~BITS_USB_MBIST_DRF_FAIL_8822C))
#define BIT_GET_USB_MBIST_DRF_FAIL_8822C(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DRF_FAIL_8822C) & \
BIT_MASK_USB_MBIST_DRF_FAIL_8822C)
#define BIT_SET_USB_MBIST_DRF_FAIL_8822C(x, v) \
(BIT_CLEAR_USB_MBIST_DRF_FAIL_8822C(x) | \
BIT_USB_MBIST_DRF_FAIL_8822C(v))
#define BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8822C 18
#define BIT_MASK_PCIE_MBIST_DRF_FAIL_8822C 0x3f
#define BIT_PCIE_MBIST_DRF_FAIL_8822C(x) \
(((x) & BIT_MASK_PCIE_MBIST_DRF_FAIL_8822C) \
<< BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8822C)
#define BITS_PCIE_MBIST_DRF_FAIL_8822C \
(BIT_MASK_PCIE_MBIST_DRF_FAIL_8822C \
<< BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8822C)
#define BIT_CLEAR_PCIE_MBIST_DRF_FAIL_8822C(x) \
((x) & (~BITS_PCIE_MBIST_DRF_FAIL_8822C))
#define BIT_GET_PCIE_MBIST_DRF_FAIL_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DRF_FAIL_8822C) & \
BIT_MASK_PCIE_MBIST_DRF_FAIL_8822C)
#define BIT_SET_PCIE_MBIST_DRF_FAIL_8822C(x, v) \
(BIT_CLEAR_PCIE_MBIST_DRF_FAIL_8822C(x) | \
BIT_PCIE_MBIST_DRF_FAIL_8822C(v))
#define BIT_SHIFT_MAC_MBIST_DRF_FAIL_8822C 0
#define BIT_MASK_MAC_MBIST_DRF_FAIL_8822C 0x3ffff
#define BIT_MAC_MBIST_DRF_FAIL_8822C(x) \
(((x) & BIT_MASK_MAC_MBIST_DRF_FAIL_8822C) \
<< BIT_SHIFT_MAC_MBIST_DRF_FAIL_8822C)
#define BITS_MAC_MBIST_DRF_FAIL_8822C \
(BIT_MASK_MAC_MBIST_DRF_FAIL_8822C \
<< BIT_SHIFT_MAC_MBIST_DRF_FAIL_8822C)
#define BIT_CLEAR_MAC_MBIST_DRF_FAIL_8822C(x) \
((x) & (~BITS_MAC_MBIST_DRF_FAIL_8822C))
#define BIT_GET_MAC_MBIST_DRF_FAIL_8822C(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DRF_FAIL_8822C) & \
BIT_MASK_MAC_MBIST_DRF_FAIL_8822C)
#define BIT_SET_MAC_MBIST_DRF_FAIL_8822C(x, v) \
(BIT_CLEAR_MAC_MBIST_DRF_FAIL_8822C(x) | \
BIT_MAC_MBIST_DRF_FAIL_8822C(v))
/* 2 REG_MBIST_START_PAUSE_8822C */
#define BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8822C 26
#define BIT_MASK_8051_MBIST_START_PAUSE_V1_8822C 0x3f
#define BIT_8051_MBIST_START_PAUSE_V1_8822C(x) \
(((x) & BIT_MASK_8051_MBIST_START_PAUSE_V1_8822C) \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8822C)
#define BITS_8051_MBIST_START_PAUSE_V1_8822C \
(BIT_MASK_8051_MBIST_START_PAUSE_V1_8822C \
<< BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8822C)
#define BIT_CLEAR_8051_MBIST_START_PAUSE_V1_8822C(x) \
((x) & (~BITS_8051_MBIST_START_PAUSE_V1_8822C))
#define BIT_GET_8051_MBIST_START_PAUSE_V1_8822C(x) \
(((x) >> BIT_SHIFT_8051_MBIST_START_PAUSE_V1_8822C) & \
BIT_MASK_8051_MBIST_START_PAUSE_V1_8822C)
#define BIT_SET_8051_MBIST_START_PAUSE_V1_8822C(x, v) \
(BIT_CLEAR_8051_MBIST_START_PAUSE_V1_8822C(x) | \
BIT_8051_MBIST_START_PAUSE_V1_8822C(v))
#define BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8822C 24
#define BIT_MASK_USB_MBIST_START_PAUSE_V1_8822C 0x3
#define BIT_USB_MBIST_START_PAUSE_V1_8822C(x) \
(((x) & BIT_MASK_USB_MBIST_START_PAUSE_V1_8822C) \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8822C)
#define BITS_USB_MBIST_START_PAUSE_V1_8822C \
(BIT_MASK_USB_MBIST_START_PAUSE_V1_8822C \
<< BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8822C)
#define BIT_CLEAR_USB_MBIST_START_PAUSE_V1_8822C(x) \
((x) & (~BITS_USB_MBIST_START_PAUSE_V1_8822C))
#define BIT_GET_USB_MBIST_START_PAUSE_V1_8822C(x) \
(((x) >> BIT_SHIFT_USB_MBIST_START_PAUSE_V1_8822C) & \
BIT_MASK_USB_MBIST_START_PAUSE_V1_8822C)
#define BIT_SET_USB_MBIST_START_PAUSE_V1_8822C(x, v) \
(BIT_CLEAR_USB_MBIST_START_PAUSE_V1_8822C(x) | \
BIT_USB_MBIST_START_PAUSE_V1_8822C(v))
#define BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8822C 18
#define BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8822C 0x3f
#define BIT_PCIE_MBIST_START_PAUSE_V1_8822C(x) \
(((x) & BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8822C) \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8822C)
#define BITS_PCIE_MBIST_START_PAUSE_V1_8822C \
(BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8822C \
<< BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8822C)
#define BIT_CLEAR_PCIE_MBIST_START_PAUSE_V1_8822C(x) \
((x) & (~BITS_PCIE_MBIST_START_PAUSE_V1_8822C))
#define BIT_GET_PCIE_MBIST_START_PAUSE_V1_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_START_PAUSE_V1_8822C) & \
BIT_MASK_PCIE_MBIST_START_PAUSE_V1_8822C)
#define BIT_SET_PCIE_MBIST_START_PAUSE_V1_8822C(x, v) \
(BIT_CLEAR_PCIE_MBIST_START_PAUSE_V1_8822C(x) | \
BIT_PCIE_MBIST_START_PAUSE_V1_8822C(v))
#define BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8822C 0
#define BIT_MASK_MAC_MBIST_START_PAUSE_V1_8822C 0x3ffff
#define BIT_MAC_MBIST_START_PAUSE_V1_8822C(x) \
(((x) & BIT_MASK_MAC_MBIST_START_PAUSE_V1_8822C) \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8822C)
#define BITS_MAC_MBIST_START_PAUSE_V1_8822C \
(BIT_MASK_MAC_MBIST_START_PAUSE_V1_8822C \
<< BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8822C)
#define BIT_CLEAR_MAC_MBIST_START_PAUSE_V1_8822C(x) \
((x) & (~BITS_MAC_MBIST_START_PAUSE_V1_8822C))
#define BIT_GET_MAC_MBIST_START_PAUSE_V1_8822C(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_START_PAUSE_V1_8822C) & \
BIT_MASK_MAC_MBIST_START_PAUSE_V1_8822C)
#define BIT_SET_MAC_MBIST_START_PAUSE_V1_8822C(x, v) \
(BIT_CLEAR_MAC_MBIST_START_PAUSE_V1_8822C(x) | \
BIT_MAC_MBIST_START_PAUSE_V1_8822C(v))
/* 2 REG_MBIST_DONE_8822C */
#define BIT_SHIFT_8051_MBIST_DONE_V1_8822C 26
#define BIT_MASK_8051_MBIST_DONE_V1_8822C 0x3f
#define BIT_8051_MBIST_DONE_V1_8822C(x) \
(((x) & BIT_MASK_8051_MBIST_DONE_V1_8822C) \
<< BIT_SHIFT_8051_MBIST_DONE_V1_8822C)
#define BITS_8051_MBIST_DONE_V1_8822C \
(BIT_MASK_8051_MBIST_DONE_V1_8822C \
<< BIT_SHIFT_8051_MBIST_DONE_V1_8822C)
#define BIT_CLEAR_8051_MBIST_DONE_V1_8822C(x) \
((x) & (~BITS_8051_MBIST_DONE_V1_8822C))
#define BIT_GET_8051_MBIST_DONE_V1_8822C(x) \
(((x) >> BIT_SHIFT_8051_MBIST_DONE_V1_8822C) & \
BIT_MASK_8051_MBIST_DONE_V1_8822C)
#define BIT_SET_8051_MBIST_DONE_V1_8822C(x, v) \
(BIT_CLEAR_8051_MBIST_DONE_V1_8822C(x) | \
BIT_8051_MBIST_DONE_V1_8822C(v))
#define BIT_SHIFT_USB_MBIST_DONE_V1_8822C 24
#define BIT_MASK_USB_MBIST_DONE_V1_8822C 0x3
#define BIT_USB_MBIST_DONE_V1_8822C(x) \
(((x) & BIT_MASK_USB_MBIST_DONE_V1_8822C) \
<< BIT_SHIFT_USB_MBIST_DONE_V1_8822C)
#define BITS_USB_MBIST_DONE_V1_8822C \
(BIT_MASK_USB_MBIST_DONE_V1_8822C << BIT_SHIFT_USB_MBIST_DONE_V1_8822C)
#define BIT_CLEAR_USB_MBIST_DONE_V1_8822C(x) \
((x) & (~BITS_USB_MBIST_DONE_V1_8822C))
#define BIT_GET_USB_MBIST_DONE_V1_8822C(x) \
(((x) >> BIT_SHIFT_USB_MBIST_DONE_V1_8822C) & \
BIT_MASK_USB_MBIST_DONE_V1_8822C)
#define BIT_SET_USB_MBIST_DONE_V1_8822C(x, v) \
(BIT_CLEAR_USB_MBIST_DONE_V1_8822C(x) | BIT_USB_MBIST_DONE_V1_8822C(v))
#define BIT_SHIFT_PCIE_MBIST_DONE_V1_8822C 18
#define BIT_MASK_PCIE_MBIST_DONE_V1_8822C 0x3f
#define BIT_PCIE_MBIST_DONE_V1_8822C(x) \
(((x) & BIT_MASK_PCIE_MBIST_DONE_V1_8822C) \
<< BIT_SHIFT_PCIE_MBIST_DONE_V1_8822C)
#define BITS_PCIE_MBIST_DONE_V1_8822C \
(BIT_MASK_PCIE_MBIST_DONE_V1_8822C \
<< BIT_SHIFT_PCIE_MBIST_DONE_V1_8822C)
#define BIT_CLEAR_PCIE_MBIST_DONE_V1_8822C(x) \
((x) & (~BITS_PCIE_MBIST_DONE_V1_8822C))
#define BIT_GET_PCIE_MBIST_DONE_V1_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MBIST_DONE_V1_8822C) & \
BIT_MASK_PCIE_MBIST_DONE_V1_8822C)
#define BIT_SET_PCIE_MBIST_DONE_V1_8822C(x, v) \
(BIT_CLEAR_PCIE_MBIST_DONE_V1_8822C(x) | \
BIT_PCIE_MBIST_DONE_V1_8822C(v))
#define BIT_SHIFT_MAC_MBIST_DONE_V1_8822C 0
#define BIT_MASK_MAC_MBIST_DONE_V1_8822C 0x3ffff
#define BIT_MAC_MBIST_DONE_V1_8822C(x) \
(((x) & BIT_MASK_MAC_MBIST_DONE_V1_8822C) \
<< BIT_SHIFT_MAC_MBIST_DONE_V1_8822C)
#define BITS_MAC_MBIST_DONE_V1_8822C \
(BIT_MASK_MAC_MBIST_DONE_V1_8822C << BIT_SHIFT_MAC_MBIST_DONE_V1_8822C)
#define BIT_CLEAR_MAC_MBIST_DONE_V1_8822C(x) \
((x) & (~BITS_MAC_MBIST_DONE_V1_8822C))
#define BIT_GET_MAC_MBIST_DONE_V1_8822C(x) \
(((x) >> BIT_SHIFT_MAC_MBIST_DONE_V1_8822C) & \
BIT_MASK_MAC_MBIST_DONE_V1_8822C)
#define BIT_SET_MAC_MBIST_DONE_V1_8822C(x, v) \
(BIT_CLEAR_MAC_MBIST_DONE_V1_8822C(x) | BIT_MAC_MBIST_DONE_V1_8822C(v))
/* 2 REG_MBIST_READ_BIST_RPT_8822C */
#define BIT_SHIFT_MBIST_READ_BIST_RPT_8822C 0
#define BIT_MASK_MBIST_READ_BIST_RPT_8822C 0xffffffffL
#define BIT_MBIST_READ_BIST_RPT_8822C(x) \
(((x) & BIT_MASK_MBIST_READ_BIST_RPT_8822C) \
<< BIT_SHIFT_MBIST_READ_BIST_RPT_8822C)
#define BITS_MBIST_READ_BIST_RPT_8822C \
(BIT_MASK_MBIST_READ_BIST_RPT_8822C \
<< BIT_SHIFT_MBIST_READ_BIST_RPT_8822C)
#define BIT_CLEAR_MBIST_READ_BIST_RPT_8822C(x) \
((x) & (~BITS_MBIST_READ_BIST_RPT_8822C))
#define BIT_GET_MBIST_READ_BIST_RPT_8822C(x) \
(((x) >> BIT_SHIFT_MBIST_READ_BIST_RPT_8822C) & \
BIT_MASK_MBIST_READ_BIST_RPT_8822C)
#define BIT_SET_MBIST_READ_BIST_RPT_8822C(x, v) \
(BIT_CLEAR_MBIST_READ_BIST_RPT_8822C(x) | \
BIT_MBIST_READ_BIST_RPT_8822C(v))
/* 2 REG_AES_DECRPT_DATA_8822C */
#define BIT_SHIFT_IPS_CFG_ADDR_8822C 0
#define BIT_MASK_IPS_CFG_ADDR_8822C 0xff
#define BIT_IPS_CFG_ADDR_8822C(x) \
(((x) & BIT_MASK_IPS_CFG_ADDR_8822C) << BIT_SHIFT_IPS_CFG_ADDR_8822C)
#define BITS_IPS_CFG_ADDR_8822C \
(BIT_MASK_IPS_CFG_ADDR_8822C << BIT_SHIFT_IPS_CFG_ADDR_8822C)
#define BIT_CLEAR_IPS_CFG_ADDR_8822C(x) ((x) & (~BITS_IPS_CFG_ADDR_8822C))
#define BIT_GET_IPS_CFG_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_IPS_CFG_ADDR_8822C) & BIT_MASK_IPS_CFG_ADDR_8822C)
#define BIT_SET_IPS_CFG_ADDR_8822C(x, v) \
(BIT_CLEAR_IPS_CFG_ADDR_8822C(x) | BIT_IPS_CFG_ADDR_8822C(v))
/* 2 REG_AES_DECRPT_CFG_8822C */
#define BIT_SHIFT_IPS_CFG_DATA_8822C 0
#define BIT_MASK_IPS_CFG_DATA_8822C 0xffffffffL
#define BIT_IPS_CFG_DATA_8822C(x) \
(((x) & BIT_MASK_IPS_CFG_DATA_8822C) << BIT_SHIFT_IPS_CFG_DATA_8822C)
#define BITS_IPS_CFG_DATA_8822C \
(BIT_MASK_IPS_CFG_DATA_8822C << BIT_SHIFT_IPS_CFG_DATA_8822C)
#define BIT_CLEAR_IPS_CFG_DATA_8822C(x) ((x) & (~BITS_IPS_CFG_DATA_8822C))
#define BIT_GET_IPS_CFG_DATA_8822C(x) \
(((x) >> BIT_SHIFT_IPS_CFG_DATA_8822C) & BIT_MASK_IPS_CFG_DATA_8822C)
#define BIT_SET_IPS_CFG_DATA_8822C(x, v) \
(BIT_CLEAR_IPS_CFG_DATA_8822C(x) | BIT_IPS_CFG_DATA_8822C(v))
/* 2 REG_HIOE_CTRL_8822C */
#define BIT_HIOE_CFG_FILE_LOC_SEL_8822C BIT(31)
#define BIT_HIOE_WRITE_REQ_8822C BIT(30)
#define BIT_HIOE_READ_REQ_8822C BIT(29)
#define BIT_INST_FORMAT_ERR_8822C BIT(25)
#define BIT_OP_TIMEOUT_ERR_8822C BIT(24)
#define BIT_SHIFT_HIOE_OP_TIMEOUT_8822C 16
#define BIT_MASK_HIOE_OP_TIMEOUT_8822C 0xff
#define BIT_HIOE_OP_TIMEOUT_8822C(x) \
(((x) & BIT_MASK_HIOE_OP_TIMEOUT_8822C) \
<< BIT_SHIFT_HIOE_OP_TIMEOUT_8822C)
#define BITS_HIOE_OP_TIMEOUT_8822C \
(BIT_MASK_HIOE_OP_TIMEOUT_8822C << BIT_SHIFT_HIOE_OP_TIMEOUT_8822C)
#define BIT_CLEAR_HIOE_OP_TIMEOUT_8822C(x) ((x) & (~BITS_HIOE_OP_TIMEOUT_8822C))
#define BIT_GET_HIOE_OP_TIMEOUT_8822C(x) \
(((x) >> BIT_SHIFT_HIOE_OP_TIMEOUT_8822C) & \
BIT_MASK_HIOE_OP_TIMEOUT_8822C)
#define BIT_SET_HIOE_OP_TIMEOUT_8822C(x, v) \
(BIT_CLEAR_HIOE_OP_TIMEOUT_8822C(x) | BIT_HIOE_OP_TIMEOUT_8822C(v))
#define BIT_SHIFT_BITDATA_CHECKSUM_8822C 0
#define BIT_MASK_BITDATA_CHECKSUM_8822C 0xffff
#define BIT_BITDATA_CHECKSUM_8822C(x) \
(((x) & BIT_MASK_BITDATA_CHECKSUM_8822C) \
<< BIT_SHIFT_BITDATA_CHECKSUM_8822C)
#define BITS_BITDATA_CHECKSUM_8822C \
(BIT_MASK_BITDATA_CHECKSUM_8822C << BIT_SHIFT_BITDATA_CHECKSUM_8822C)
#define BIT_CLEAR_BITDATA_CHECKSUM_8822C(x) \
((x) & (~BITS_BITDATA_CHECKSUM_8822C))
#define BIT_GET_BITDATA_CHECKSUM_8822C(x) \
(((x) >> BIT_SHIFT_BITDATA_CHECKSUM_8822C) & \
BIT_MASK_BITDATA_CHECKSUM_8822C)
#define BIT_SET_BITDATA_CHECKSUM_8822C(x, v) \
(BIT_CLEAR_BITDATA_CHECKSUM_8822C(x) | BIT_BITDATA_CHECKSUM_8822C(v))
/* 2 REG_HIOE_CFG_FILE_8822C */
#define BIT_SHIFT_TXBF_END_ADDR_8822C 16
#define BIT_MASK_TXBF_END_ADDR_8822C 0xffff
#define BIT_TXBF_END_ADDR_8822C(x) \
(((x) & BIT_MASK_TXBF_END_ADDR_8822C) << BIT_SHIFT_TXBF_END_ADDR_8822C)
#define BITS_TXBF_END_ADDR_8822C \
(BIT_MASK_TXBF_END_ADDR_8822C << BIT_SHIFT_TXBF_END_ADDR_8822C)
#define BIT_CLEAR_TXBF_END_ADDR_8822C(x) ((x) & (~BITS_TXBF_END_ADDR_8822C))
#define BIT_GET_TXBF_END_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_TXBF_END_ADDR_8822C) & BIT_MASK_TXBF_END_ADDR_8822C)
#define BIT_SET_TXBF_END_ADDR_8822C(x, v) \
(BIT_CLEAR_TXBF_END_ADDR_8822C(x) | BIT_TXBF_END_ADDR_8822C(v))
#define BIT_SHIFT_TXBF_STR_ADDR_8822C 0
#define BIT_MASK_TXBF_STR_ADDR_8822C 0xffff
#define BIT_TXBF_STR_ADDR_8822C(x) \
(((x) & BIT_MASK_TXBF_STR_ADDR_8822C) << BIT_SHIFT_TXBF_STR_ADDR_8822C)
#define BITS_TXBF_STR_ADDR_8822C \
(BIT_MASK_TXBF_STR_ADDR_8822C << BIT_SHIFT_TXBF_STR_ADDR_8822C)
#define BIT_CLEAR_TXBF_STR_ADDR_8822C(x) ((x) & (~BITS_TXBF_STR_ADDR_8822C))
#define BIT_GET_TXBF_STR_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_TXBF_STR_ADDR_8822C) & BIT_MASK_TXBF_STR_ADDR_8822C)
#define BIT_SET_TXBF_STR_ADDR_8822C(x, v) \
(BIT_CLEAR_TXBF_STR_ADDR_8822C(x) | BIT_TXBF_STR_ADDR_8822C(v))
/* 2 REG_TMETER_8822C */
#define BIT_TEMP_VALID_8822C BIT(31)
#define BIT_SHIFT_TEMP_VALUE_8822C 24
#define BIT_MASK_TEMP_VALUE_8822C 0x3f
#define BIT_TEMP_VALUE_8822C(x) \
(((x) & BIT_MASK_TEMP_VALUE_8822C) << BIT_SHIFT_TEMP_VALUE_8822C)
#define BITS_TEMP_VALUE_8822C \
(BIT_MASK_TEMP_VALUE_8822C << BIT_SHIFT_TEMP_VALUE_8822C)
#define BIT_CLEAR_TEMP_VALUE_8822C(x) ((x) & (~BITS_TEMP_VALUE_8822C))
#define BIT_GET_TEMP_VALUE_8822C(x) \
(((x) >> BIT_SHIFT_TEMP_VALUE_8822C) & BIT_MASK_TEMP_VALUE_8822C)
#define BIT_SET_TEMP_VALUE_8822C(x, v) \
(BIT_CLEAR_TEMP_VALUE_8822C(x) | BIT_TEMP_VALUE_8822C(v))
#define BIT_SHIFT_REG_TMETER_TIMER_8822C 8
#define BIT_MASK_REG_TMETER_TIMER_8822C 0xfff
#define BIT_REG_TMETER_TIMER_8822C(x) \
(((x) & BIT_MASK_REG_TMETER_TIMER_8822C) \
<< BIT_SHIFT_REG_TMETER_TIMER_8822C)
#define BITS_REG_TMETER_TIMER_8822C \
(BIT_MASK_REG_TMETER_TIMER_8822C << BIT_SHIFT_REG_TMETER_TIMER_8822C)
#define BIT_CLEAR_REG_TMETER_TIMER_8822C(x) \
((x) & (~BITS_REG_TMETER_TIMER_8822C))
#define BIT_GET_REG_TMETER_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_REG_TMETER_TIMER_8822C) & \
BIT_MASK_REG_TMETER_TIMER_8822C)
#define BIT_SET_REG_TMETER_TIMER_8822C(x, v) \
(BIT_CLEAR_REG_TMETER_TIMER_8822C(x) | BIT_REG_TMETER_TIMER_8822C(v))
#define BIT_SHIFT_REG_TEMP_DELTA_8822C 2
#define BIT_MASK_REG_TEMP_DELTA_8822C 0x3f
#define BIT_REG_TEMP_DELTA_8822C(x) \
(((x) & BIT_MASK_REG_TEMP_DELTA_8822C) \
<< BIT_SHIFT_REG_TEMP_DELTA_8822C)
#define BITS_REG_TEMP_DELTA_8822C \
(BIT_MASK_REG_TEMP_DELTA_8822C << BIT_SHIFT_REG_TEMP_DELTA_8822C)
#define BIT_CLEAR_REG_TEMP_DELTA_8822C(x) ((x) & (~BITS_REG_TEMP_DELTA_8822C))
#define BIT_GET_REG_TEMP_DELTA_8822C(x) \
(((x) >> BIT_SHIFT_REG_TEMP_DELTA_8822C) & \
BIT_MASK_REG_TEMP_DELTA_8822C)
#define BIT_SET_REG_TEMP_DELTA_8822C(x, v) \
(BIT_CLEAR_REG_TEMP_DELTA_8822C(x) | BIT_REG_TEMP_DELTA_8822C(v))
#define BIT_REG_TMETER_EN_8822C BIT(0)
/* 2 REG_OSC_32K_CTRL_8822C */
#define BIT_SHIFT_OSC_32K_CLKGEN_0_8822C 16
#define BIT_MASK_OSC_32K_CLKGEN_0_8822C 0xffff
#define BIT_OSC_32K_CLKGEN_0_8822C(x) \
(((x) & BIT_MASK_OSC_32K_CLKGEN_0_8822C) \
<< BIT_SHIFT_OSC_32K_CLKGEN_0_8822C)
#define BITS_OSC_32K_CLKGEN_0_8822C \
(BIT_MASK_OSC_32K_CLKGEN_0_8822C << BIT_SHIFT_OSC_32K_CLKGEN_0_8822C)
#define BIT_CLEAR_OSC_32K_CLKGEN_0_8822C(x) \
((x) & (~BITS_OSC_32K_CLKGEN_0_8822C))
#define BIT_GET_OSC_32K_CLKGEN_0_8822C(x) \
(((x) >> BIT_SHIFT_OSC_32K_CLKGEN_0_8822C) & \
BIT_MASK_OSC_32K_CLKGEN_0_8822C)
#define BIT_SET_OSC_32K_CLKGEN_0_8822C(x, v) \
(BIT_CLEAR_OSC_32K_CLKGEN_0_8822C(x) | BIT_OSC_32K_CLKGEN_0_8822C(v))
#define BIT_SHIFT_OSC_32K_RES_COMP_8822C 4
#define BIT_MASK_OSC_32K_RES_COMP_8822C 0x3
#define BIT_OSC_32K_RES_COMP_8822C(x) \
(((x) & BIT_MASK_OSC_32K_RES_COMP_8822C) \
<< BIT_SHIFT_OSC_32K_RES_COMP_8822C)
#define BITS_OSC_32K_RES_COMP_8822C \
(BIT_MASK_OSC_32K_RES_COMP_8822C << BIT_SHIFT_OSC_32K_RES_COMP_8822C)
#define BIT_CLEAR_OSC_32K_RES_COMP_8822C(x) \
((x) & (~BITS_OSC_32K_RES_COMP_8822C))
#define BIT_GET_OSC_32K_RES_COMP_8822C(x) \
(((x) >> BIT_SHIFT_OSC_32K_RES_COMP_8822C) & \
BIT_MASK_OSC_32K_RES_COMP_8822C)
#define BIT_SET_OSC_32K_RES_COMP_8822C(x, v) \
(BIT_CLEAR_OSC_32K_RES_COMP_8822C(x) | BIT_OSC_32K_RES_COMP_8822C(v))
#define BIT_OSC_32K_OUT_SEL_8822C BIT(3)
#define BIT_ISO_WL_2_OSC_32K_8822C BIT(1)
#define BIT_POW_CKGEN_8822C BIT(0)
/* 2 REG_32K_CAL_REG1_8822C */
#define BIT_CAL_32K_REG_WR_8822C BIT(31)
#define BIT_CAL_32K_DBG_SEL_8822C BIT(22)
#define BIT_SHIFT_CAL_32K_REG_ADDR_8822C 16
#define BIT_MASK_CAL_32K_REG_ADDR_8822C 0x3f
#define BIT_CAL_32K_REG_ADDR_8822C(x) \
(((x) & BIT_MASK_CAL_32K_REG_ADDR_8822C) \
<< BIT_SHIFT_CAL_32K_REG_ADDR_8822C)
#define BITS_CAL_32K_REG_ADDR_8822C \
(BIT_MASK_CAL_32K_REG_ADDR_8822C << BIT_SHIFT_CAL_32K_REG_ADDR_8822C)
#define BIT_CLEAR_CAL_32K_REG_ADDR_8822C(x) \
((x) & (~BITS_CAL_32K_REG_ADDR_8822C))
#define BIT_GET_CAL_32K_REG_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_ADDR_8822C) & \
BIT_MASK_CAL_32K_REG_ADDR_8822C)
#define BIT_SET_CAL_32K_REG_ADDR_8822C(x, v) \
(BIT_CLEAR_CAL_32K_REG_ADDR_8822C(x) | BIT_CAL_32K_REG_ADDR_8822C(v))
#define BIT_SHIFT_CAL_32K_REG_DATA_8822C 0
#define BIT_MASK_CAL_32K_REG_DATA_8822C 0xffff
#define BIT_CAL_32K_REG_DATA_8822C(x) \
(((x) & BIT_MASK_CAL_32K_REG_DATA_8822C) \
<< BIT_SHIFT_CAL_32K_REG_DATA_8822C)
#define BITS_CAL_32K_REG_DATA_8822C \
(BIT_MASK_CAL_32K_REG_DATA_8822C << BIT_SHIFT_CAL_32K_REG_DATA_8822C)
#define BIT_CLEAR_CAL_32K_REG_DATA_8822C(x) \
((x) & (~BITS_CAL_32K_REG_DATA_8822C))
#define BIT_GET_CAL_32K_REG_DATA_8822C(x) \
(((x) >> BIT_SHIFT_CAL_32K_REG_DATA_8822C) & \
BIT_MASK_CAL_32K_REG_DATA_8822C)
#define BIT_SET_CAL_32K_REG_DATA_8822C(x, v) \
(BIT_CLEAR_CAL_32K_REG_DATA_8822C(x) | BIT_CAL_32K_REG_DATA_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_C2HEVT_8822C */
#define BIT_SHIFT_C2HEVT_MSG_V1_8822C 0
#define BIT_MASK_C2HEVT_MSG_V1_8822C 0xffffffffL
#define BIT_C2HEVT_MSG_V1_8822C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_V1_8822C) << BIT_SHIFT_C2HEVT_MSG_V1_8822C)
#define BITS_C2HEVT_MSG_V1_8822C \
(BIT_MASK_C2HEVT_MSG_V1_8822C << BIT_SHIFT_C2HEVT_MSG_V1_8822C)
#define BIT_CLEAR_C2HEVT_MSG_V1_8822C(x) ((x) & (~BITS_C2HEVT_MSG_V1_8822C))
#define BIT_GET_C2HEVT_MSG_V1_8822C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_V1_8822C) & BIT_MASK_C2HEVT_MSG_V1_8822C)
#define BIT_SET_C2HEVT_MSG_V1_8822C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_V1_8822C(x) | BIT_C2HEVT_MSG_V1_8822C(v))
/* 2 REG_C2HEVT_1_8822C */
#define BIT_SHIFT_C2HEVT_MSG_1_8822C 0
#define BIT_MASK_C2HEVT_MSG_1_8822C 0xffffffffL
#define BIT_C2HEVT_MSG_1_8822C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_1_8822C) << BIT_SHIFT_C2HEVT_MSG_1_8822C)
#define BITS_C2HEVT_MSG_1_8822C \
(BIT_MASK_C2HEVT_MSG_1_8822C << BIT_SHIFT_C2HEVT_MSG_1_8822C)
#define BIT_CLEAR_C2HEVT_MSG_1_8822C(x) ((x) & (~BITS_C2HEVT_MSG_1_8822C))
#define BIT_GET_C2HEVT_MSG_1_8822C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_1_8822C) & BIT_MASK_C2HEVT_MSG_1_8822C)
#define BIT_SET_C2HEVT_MSG_1_8822C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_1_8822C(x) | BIT_C2HEVT_MSG_1_8822C(v))
/* 2 REG_C2HEVT_2_8822C */
#define BIT_SHIFT_C2HEVT_MSG_2_8822C 0
#define BIT_MASK_C2HEVT_MSG_2_8822C 0xffffffffL
#define BIT_C2HEVT_MSG_2_8822C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_2_8822C) << BIT_SHIFT_C2HEVT_MSG_2_8822C)
#define BITS_C2HEVT_MSG_2_8822C \
(BIT_MASK_C2HEVT_MSG_2_8822C << BIT_SHIFT_C2HEVT_MSG_2_8822C)
#define BIT_CLEAR_C2HEVT_MSG_2_8822C(x) ((x) & (~BITS_C2HEVT_MSG_2_8822C))
#define BIT_GET_C2HEVT_MSG_2_8822C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_2_8822C) & BIT_MASK_C2HEVT_MSG_2_8822C)
#define BIT_SET_C2HEVT_MSG_2_8822C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_2_8822C(x) | BIT_C2HEVT_MSG_2_8822C(v))
/* 2 REG_C2HEVT_3_8822C */
#define BIT_SHIFT_C2HEVT_MSG_3_8822C 0
#define BIT_MASK_C2HEVT_MSG_3_8822C 0xffffffffL
#define BIT_C2HEVT_MSG_3_8822C(x) \
(((x) & BIT_MASK_C2HEVT_MSG_3_8822C) << BIT_SHIFT_C2HEVT_MSG_3_8822C)
#define BITS_C2HEVT_MSG_3_8822C \
(BIT_MASK_C2HEVT_MSG_3_8822C << BIT_SHIFT_C2HEVT_MSG_3_8822C)
#define BIT_CLEAR_C2HEVT_MSG_3_8822C(x) ((x) & (~BITS_C2HEVT_MSG_3_8822C))
#define BIT_GET_C2HEVT_MSG_3_8822C(x) \
(((x) >> BIT_SHIFT_C2HEVT_MSG_3_8822C) & BIT_MASK_C2HEVT_MSG_3_8822C)
#define BIT_SET_C2HEVT_MSG_3_8822C(x, v) \
(BIT_CLEAR_C2HEVT_MSG_3_8822C(x) | BIT_C2HEVT_MSG_3_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SW_DEFINED_PAGE1_8822C */
#define BIT_SHIFT_SW_DEFINED_PAGE1_V1_8822C 0
#define BIT_MASK_SW_DEFINED_PAGE1_V1_8822C 0xffffffffL
#define BIT_SW_DEFINED_PAGE1_V1_8822C(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE1_V1_8822C) \
<< BIT_SHIFT_SW_DEFINED_PAGE1_V1_8822C)
#define BITS_SW_DEFINED_PAGE1_V1_8822C \
(BIT_MASK_SW_DEFINED_PAGE1_V1_8822C \
<< BIT_SHIFT_SW_DEFINED_PAGE1_V1_8822C)
#define BIT_CLEAR_SW_DEFINED_PAGE1_V1_8822C(x) \
((x) & (~BITS_SW_DEFINED_PAGE1_V1_8822C))
#define BIT_GET_SW_DEFINED_PAGE1_V1_8822C(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE1_V1_8822C) & \
BIT_MASK_SW_DEFINED_PAGE1_V1_8822C)
#define BIT_SET_SW_DEFINED_PAGE1_V1_8822C(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE1_V1_8822C(x) | \
BIT_SW_DEFINED_PAGE1_V1_8822C(v))
/* 2 REG_SW_DEFINED_PAGE2_8822C */
#define BIT_SHIFT_SW_DEFINED_PAGE2_8822C 0
#define BIT_MASK_SW_DEFINED_PAGE2_8822C 0xffffffffL
#define BIT_SW_DEFINED_PAGE2_8822C(x) \
(((x) & BIT_MASK_SW_DEFINED_PAGE2_8822C) \
<< BIT_SHIFT_SW_DEFINED_PAGE2_8822C)
#define BITS_SW_DEFINED_PAGE2_8822C \
(BIT_MASK_SW_DEFINED_PAGE2_8822C << BIT_SHIFT_SW_DEFINED_PAGE2_8822C)
#define BIT_CLEAR_SW_DEFINED_PAGE2_8822C(x) \
((x) & (~BITS_SW_DEFINED_PAGE2_8822C))
#define BIT_GET_SW_DEFINED_PAGE2_8822C(x) \
(((x) >> BIT_SHIFT_SW_DEFINED_PAGE2_8822C) & \
BIT_MASK_SW_DEFINED_PAGE2_8822C)
#define BIT_SET_SW_DEFINED_PAGE2_8822C(x, v) \
(BIT_CLEAR_SW_DEFINED_PAGE2_8822C(x) | BIT_SW_DEFINED_PAGE2_8822C(v))
/* 2 REG_MCUTST_I_8822C */
#define BIT_SHIFT_MCUDMSG_I_8822C 0
#define BIT_MASK_MCUDMSG_I_8822C 0xffffffffL
#define BIT_MCUDMSG_I_8822C(x) \
(((x) & BIT_MASK_MCUDMSG_I_8822C) << BIT_SHIFT_MCUDMSG_I_8822C)
#define BITS_MCUDMSG_I_8822C \
(BIT_MASK_MCUDMSG_I_8822C << BIT_SHIFT_MCUDMSG_I_8822C)
#define BIT_CLEAR_MCUDMSG_I_8822C(x) ((x) & (~BITS_MCUDMSG_I_8822C))
#define BIT_GET_MCUDMSG_I_8822C(x) \
(((x) >> BIT_SHIFT_MCUDMSG_I_8822C) & BIT_MASK_MCUDMSG_I_8822C)
#define BIT_SET_MCUDMSG_I_8822C(x, v) \
(BIT_CLEAR_MCUDMSG_I_8822C(x) | BIT_MCUDMSG_I_8822C(v))
/* 2 REG_MCUTST_II_8822C */
#define BIT_SHIFT_MCUDMSG_II_8822C 0
#define BIT_MASK_MCUDMSG_II_8822C 0xffffffffL
#define BIT_MCUDMSG_II_8822C(x) \
(((x) & BIT_MASK_MCUDMSG_II_8822C) << BIT_SHIFT_MCUDMSG_II_8822C)
#define BITS_MCUDMSG_II_8822C \
(BIT_MASK_MCUDMSG_II_8822C << BIT_SHIFT_MCUDMSG_II_8822C)
#define BIT_CLEAR_MCUDMSG_II_8822C(x) ((x) & (~BITS_MCUDMSG_II_8822C))
#define BIT_GET_MCUDMSG_II_8822C(x) \
(((x) >> BIT_SHIFT_MCUDMSG_II_8822C) & BIT_MASK_MCUDMSG_II_8822C)
#define BIT_SET_MCUDMSG_II_8822C(x, v) \
(BIT_CLEAR_MCUDMSG_II_8822C(x) | BIT_MCUDMSG_II_8822C(v))
/* 2 REG_FMETHR_8822C */
#define BIT_FMSG_INT_8822C BIT(31)
#define BIT_SHIFT_FW_MSG_8822C 0
#define BIT_MASK_FW_MSG_8822C 0xffffffffL
#define BIT_FW_MSG_8822C(x) \
(((x) & BIT_MASK_FW_MSG_8822C) << BIT_SHIFT_FW_MSG_8822C)
#define BITS_FW_MSG_8822C (BIT_MASK_FW_MSG_8822C << BIT_SHIFT_FW_MSG_8822C)
#define BIT_CLEAR_FW_MSG_8822C(x) ((x) & (~BITS_FW_MSG_8822C))
#define BIT_GET_FW_MSG_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG_8822C) & BIT_MASK_FW_MSG_8822C)
#define BIT_SET_FW_MSG_8822C(x, v) \
(BIT_CLEAR_FW_MSG_8822C(x) | BIT_FW_MSG_8822C(v))
/* 2 REG_HMETFR_8822C */
#define BIT_SHIFT_HRCV_MSG_8822C 24
#define BIT_MASK_HRCV_MSG_8822C 0xff
#define BIT_HRCV_MSG_8822C(x) \
(((x) & BIT_MASK_HRCV_MSG_8822C) << BIT_SHIFT_HRCV_MSG_8822C)
#define BITS_HRCV_MSG_8822C \
(BIT_MASK_HRCV_MSG_8822C << BIT_SHIFT_HRCV_MSG_8822C)
#define BIT_CLEAR_HRCV_MSG_8822C(x) ((x) & (~BITS_HRCV_MSG_8822C))
#define BIT_GET_HRCV_MSG_8822C(x) \
(((x) >> BIT_SHIFT_HRCV_MSG_8822C) & BIT_MASK_HRCV_MSG_8822C)
#define BIT_SET_HRCV_MSG_8822C(x, v) \
(BIT_CLEAR_HRCV_MSG_8822C(x) | BIT_HRCV_MSG_8822C(v))
#define BIT_INT_BOX3_8822C BIT(3)
#define BIT_INT_BOX2_8822C BIT(2)
#define BIT_INT_BOX1_8822C BIT(1)
#define BIT_INT_BOX0_8822C BIT(0)
/* 2 REG_HMEBOX0_8822C */
#define BIT_SHIFT_HOST_MSG_0_8822C 0
#define BIT_MASK_HOST_MSG_0_8822C 0xffffffffL
#define BIT_HOST_MSG_0_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_0_8822C) << BIT_SHIFT_HOST_MSG_0_8822C)
#define BITS_HOST_MSG_0_8822C \
(BIT_MASK_HOST_MSG_0_8822C << BIT_SHIFT_HOST_MSG_0_8822C)
#define BIT_CLEAR_HOST_MSG_0_8822C(x) ((x) & (~BITS_HOST_MSG_0_8822C))
#define BIT_GET_HOST_MSG_0_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_0_8822C) & BIT_MASK_HOST_MSG_0_8822C)
#define BIT_SET_HOST_MSG_0_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_0_8822C(x) | BIT_HOST_MSG_0_8822C(v))
/* 2 REG_HMEBOX1_8822C */
#define BIT_SHIFT_HOST_MSG_1_8822C 0
#define BIT_MASK_HOST_MSG_1_8822C 0xffffffffL
#define BIT_HOST_MSG_1_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_1_8822C) << BIT_SHIFT_HOST_MSG_1_8822C)
#define BITS_HOST_MSG_1_8822C \
(BIT_MASK_HOST_MSG_1_8822C << BIT_SHIFT_HOST_MSG_1_8822C)
#define BIT_CLEAR_HOST_MSG_1_8822C(x) ((x) & (~BITS_HOST_MSG_1_8822C))
#define BIT_GET_HOST_MSG_1_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_1_8822C) & BIT_MASK_HOST_MSG_1_8822C)
#define BIT_SET_HOST_MSG_1_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_1_8822C(x) | BIT_HOST_MSG_1_8822C(v))
/* 2 REG_HMEBOX2_8822C */
#define BIT_SHIFT_HOST_MSG_2_8822C 0
#define BIT_MASK_HOST_MSG_2_8822C 0xffffffffL
#define BIT_HOST_MSG_2_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_2_8822C) << BIT_SHIFT_HOST_MSG_2_8822C)
#define BITS_HOST_MSG_2_8822C \
(BIT_MASK_HOST_MSG_2_8822C << BIT_SHIFT_HOST_MSG_2_8822C)
#define BIT_CLEAR_HOST_MSG_2_8822C(x) ((x) & (~BITS_HOST_MSG_2_8822C))
#define BIT_GET_HOST_MSG_2_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_2_8822C) & BIT_MASK_HOST_MSG_2_8822C)
#define BIT_SET_HOST_MSG_2_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_2_8822C(x) | BIT_HOST_MSG_2_8822C(v))
/* 2 REG_HMEBOX3_8822C */
#define BIT_SHIFT_HOST_MSG_3_8822C 0
#define BIT_MASK_HOST_MSG_3_8822C 0xffffffffL
#define BIT_HOST_MSG_3_8822C(x) \
(((x) & BIT_MASK_HOST_MSG_3_8822C) << BIT_SHIFT_HOST_MSG_3_8822C)
#define BITS_HOST_MSG_3_8822C \
(BIT_MASK_HOST_MSG_3_8822C << BIT_SHIFT_HOST_MSG_3_8822C)
#define BIT_CLEAR_HOST_MSG_3_8822C(x) ((x) & (~BITS_HOST_MSG_3_8822C))
#define BIT_GET_HOST_MSG_3_8822C(x) \
(((x) >> BIT_SHIFT_HOST_MSG_3_8822C) & BIT_MASK_HOST_MSG_3_8822C)
#define BIT_SET_HOST_MSG_3_8822C(x, v) \
(BIT_CLEAR_HOST_MSG_3_8822C(x) | BIT_HOST_MSG_3_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_BB_ACCESS_CTRL_8822C */
#define BIT_SHIFT_BB_WRITE_READ_8822C 30
#define BIT_MASK_BB_WRITE_READ_8822C 0x3
#define BIT_BB_WRITE_READ_8822C(x) \
(((x) & BIT_MASK_BB_WRITE_READ_8822C) << BIT_SHIFT_BB_WRITE_READ_8822C)
#define BITS_BB_WRITE_READ_8822C \
(BIT_MASK_BB_WRITE_READ_8822C << BIT_SHIFT_BB_WRITE_READ_8822C)
#define BIT_CLEAR_BB_WRITE_READ_8822C(x) ((x) & (~BITS_BB_WRITE_READ_8822C))
#define BIT_GET_BB_WRITE_READ_8822C(x) \
(((x) >> BIT_SHIFT_BB_WRITE_READ_8822C) & BIT_MASK_BB_WRITE_READ_8822C)
#define BIT_SET_BB_WRITE_READ_8822C(x, v) \
(BIT_CLEAR_BB_WRITE_READ_8822C(x) | BIT_BB_WRITE_READ_8822C(v))
#define BIT_SHIFT_BB_WRITE_EN_8822C 12
#define BIT_MASK_BB_WRITE_EN_8822C 0xf
#define BIT_BB_WRITE_EN_8822C(x) \
(((x) & BIT_MASK_BB_WRITE_EN_8822C) << BIT_SHIFT_BB_WRITE_EN_8822C)
#define BITS_BB_WRITE_EN_8822C \
(BIT_MASK_BB_WRITE_EN_8822C << BIT_SHIFT_BB_WRITE_EN_8822C)
#define BIT_CLEAR_BB_WRITE_EN_8822C(x) ((x) & (~BITS_BB_WRITE_EN_8822C))
#define BIT_GET_BB_WRITE_EN_8822C(x) \
(((x) >> BIT_SHIFT_BB_WRITE_EN_8822C) & BIT_MASK_BB_WRITE_EN_8822C)
#define BIT_SET_BB_WRITE_EN_8822C(x, v) \
(BIT_CLEAR_BB_WRITE_EN_8822C(x) | BIT_BB_WRITE_EN_8822C(v))
#define BIT_SHIFT_BB_ADDR_8822C 2
#define BIT_MASK_BB_ADDR_8822C 0x1ff
#define BIT_BB_ADDR_8822C(x) \
(((x) & BIT_MASK_BB_ADDR_8822C) << BIT_SHIFT_BB_ADDR_8822C)
#define BITS_BB_ADDR_8822C (BIT_MASK_BB_ADDR_8822C << BIT_SHIFT_BB_ADDR_8822C)
#define BIT_CLEAR_BB_ADDR_8822C(x) ((x) & (~BITS_BB_ADDR_8822C))
#define BIT_GET_BB_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_BB_ADDR_8822C) & BIT_MASK_BB_ADDR_8822C)
#define BIT_SET_BB_ADDR_8822C(x, v) \
(BIT_CLEAR_BB_ADDR_8822C(x) | BIT_BB_ADDR_8822C(v))
#define BIT_BB_ERRACC_8822C BIT(0)
/* 2 REG_BB_ACCESS_DATA_8822C */
#define BIT_SHIFT_BB_DATA_8822C 0
#define BIT_MASK_BB_DATA_8822C 0xffffffffL
#define BIT_BB_DATA_8822C(x) \
(((x) & BIT_MASK_BB_DATA_8822C) << BIT_SHIFT_BB_DATA_8822C)
#define BITS_BB_DATA_8822C (BIT_MASK_BB_DATA_8822C << BIT_SHIFT_BB_DATA_8822C)
#define BIT_CLEAR_BB_DATA_8822C(x) ((x) & (~BITS_BB_DATA_8822C))
#define BIT_GET_BB_DATA_8822C(x) \
(((x) >> BIT_SHIFT_BB_DATA_8822C) & BIT_MASK_BB_DATA_8822C)
#define BIT_SET_BB_DATA_8822C(x, v) \
(BIT_CLEAR_BB_DATA_8822C(x) | BIT_BB_DATA_8822C(v))
/* 2 REG_HMEBOX_E0_8822C */
#define BIT_SHIFT_HMEBOX_E0_8822C 0
#define BIT_MASK_HMEBOX_E0_8822C 0xffffffffL
#define BIT_HMEBOX_E0_8822C(x) \
(((x) & BIT_MASK_HMEBOX_E0_8822C) << BIT_SHIFT_HMEBOX_E0_8822C)
#define BITS_HMEBOX_E0_8822C \
(BIT_MASK_HMEBOX_E0_8822C << BIT_SHIFT_HMEBOX_E0_8822C)
#define BIT_CLEAR_HMEBOX_E0_8822C(x) ((x) & (~BITS_HMEBOX_E0_8822C))
#define BIT_GET_HMEBOX_E0_8822C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E0_8822C) & BIT_MASK_HMEBOX_E0_8822C)
#define BIT_SET_HMEBOX_E0_8822C(x, v) \
(BIT_CLEAR_HMEBOX_E0_8822C(x) | BIT_HMEBOX_E0_8822C(v))
/* 2 REG_HMEBOX_E1_8822C */
#define BIT_SHIFT_HMEBOX_E1_8822C 0
#define BIT_MASK_HMEBOX_E1_8822C 0xffffffffL
#define BIT_HMEBOX_E1_8822C(x) \
(((x) & BIT_MASK_HMEBOX_E1_8822C) << BIT_SHIFT_HMEBOX_E1_8822C)
#define BITS_HMEBOX_E1_8822C \
(BIT_MASK_HMEBOX_E1_8822C << BIT_SHIFT_HMEBOX_E1_8822C)
#define BIT_CLEAR_HMEBOX_E1_8822C(x) ((x) & (~BITS_HMEBOX_E1_8822C))
#define BIT_GET_HMEBOX_E1_8822C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E1_8822C) & BIT_MASK_HMEBOX_E1_8822C)
#define BIT_SET_HMEBOX_E1_8822C(x, v) \
(BIT_CLEAR_HMEBOX_E1_8822C(x) | BIT_HMEBOX_E1_8822C(v))
/* 2 REG_HMEBOX_E2_8822C */
#define BIT_SHIFT_HMEBOX_E2_8822C 0
#define BIT_MASK_HMEBOX_E2_8822C 0xffffffffL
#define BIT_HMEBOX_E2_8822C(x) \
(((x) & BIT_MASK_HMEBOX_E2_8822C) << BIT_SHIFT_HMEBOX_E2_8822C)
#define BITS_HMEBOX_E2_8822C \
(BIT_MASK_HMEBOX_E2_8822C << BIT_SHIFT_HMEBOX_E2_8822C)
#define BIT_CLEAR_HMEBOX_E2_8822C(x) ((x) & (~BITS_HMEBOX_E2_8822C))
#define BIT_GET_HMEBOX_E2_8822C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E2_8822C) & BIT_MASK_HMEBOX_E2_8822C)
#define BIT_SET_HMEBOX_E2_8822C(x, v) \
(BIT_CLEAR_HMEBOX_E2_8822C(x) | BIT_HMEBOX_E2_8822C(v))
/* 2 REG_HMEBOX_E3_8822C */
#define BIT_SHIFT_HMEBOX_E3_8822C 0
#define BIT_MASK_HMEBOX_E3_8822C 0xffffffffL
#define BIT_HMEBOX_E3_8822C(x) \
(((x) & BIT_MASK_HMEBOX_E3_8822C) << BIT_SHIFT_HMEBOX_E3_8822C)
#define BITS_HMEBOX_E3_8822C \
(BIT_MASK_HMEBOX_E3_8822C << BIT_SHIFT_HMEBOX_E3_8822C)
#define BIT_CLEAR_HMEBOX_E3_8822C(x) ((x) & (~BITS_HMEBOX_E3_8822C))
#define BIT_GET_HMEBOX_E3_8822C(x) \
(((x) >> BIT_SHIFT_HMEBOX_E3_8822C) & BIT_MASK_HMEBOX_E3_8822C)
#define BIT_SET_HMEBOX_E3_8822C(x, v) \
(BIT_CLEAR_HMEBOX_E3_8822C(x) | BIT_HMEBOX_E3_8822C(v))
/* 2 REG_CR_EXT_8822C */
#define BIT_SHIFT_PHY_REQ_DELAY_8822C 24
#define BIT_MASK_PHY_REQ_DELAY_8822C 0xf
#define BIT_PHY_REQ_DELAY_8822C(x) \
(((x) & BIT_MASK_PHY_REQ_DELAY_8822C) << BIT_SHIFT_PHY_REQ_DELAY_8822C)
#define BITS_PHY_REQ_DELAY_8822C \
(BIT_MASK_PHY_REQ_DELAY_8822C << BIT_SHIFT_PHY_REQ_DELAY_8822C)
#define BIT_CLEAR_PHY_REQ_DELAY_8822C(x) ((x) & (~BITS_PHY_REQ_DELAY_8822C))
#define BIT_GET_PHY_REQ_DELAY_8822C(x) \
(((x) >> BIT_SHIFT_PHY_REQ_DELAY_8822C) & BIT_MASK_PHY_REQ_DELAY_8822C)
#define BIT_SET_PHY_REQ_DELAY_8822C(x, v) \
(BIT_CLEAR_PHY_REQ_DELAY_8822C(x) | BIT_PHY_REQ_DELAY_8822C(v))
/* 2 REG_NOT_VALID_8822C */
#define BIT_SPD_DOWN_8822C BIT(16)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_NETYPE4_8822C 4
#define BIT_MASK_NETYPE4_8822C 0x3
#define BIT_NETYPE4_8822C(x) \
(((x) & BIT_MASK_NETYPE4_8822C) << BIT_SHIFT_NETYPE4_8822C)
#define BITS_NETYPE4_8822C (BIT_MASK_NETYPE4_8822C << BIT_SHIFT_NETYPE4_8822C)
#define BIT_CLEAR_NETYPE4_8822C(x) ((x) & (~BITS_NETYPE4_8822C))
#define BIT_GET_NETYPE4_8822C(x) \
(((x) >> BIT_SHIFT_NETYPE4_8822C) & BIT_MASK_NETYPE4_8822C)
#define BIT_SET_NETYPE4_8822C(x, v) \
(BIT_CLEAR_NETYPE4_8822C(x) | BIT_NETYPE4_8822C(v))
#define BIT_SHIFT_NETYPE3_8822C 2
#define BIT_MASK_NETYPE3_8822C 0x3
#define BIT_NETYPE3_8822C(x) \
(((x) & BIT_MASK_NETYPE3_8822C) << BIT_SHIFT_NETYPE3_8822C)
#define BITS_NETYPE3_8822C (BIT_MASK_NETYPE3_8822C << BIT_SHIFT_NETYPE3_8822C)
#define BIT_CLEAR_NETYPE3_8822C(x) ((x) & (~BITS_NETYPE3_8822C))
#define BIT_GET_NETYPE3_8822C(x) \
(((x) >> BIT_SHIFT_NETYPE3_8822C) & BIT_MASK_NETYPE3_8822C)
#define BIT_SET_NETYPE3_8822C(x, v) \
(BIT_CLEAR_NETYPE3_8822C(x) | BIT_NETYPE3_8822C(v))
#define BIT_SHIFT_NETYPE2_8822C 0
#define BIT_MASK_NETYPE2_8822C 0x3
#define BIT_NETYPE2_8822C(x) \
(((x) & BIT_MASK_NETYPE2_8822C) << BIT_SHIFT_NETYPE2_8822C)
#define BITS_NETYPE2_8822C (BIT_MASK_NETYPE2_8822C << BIT_SHIFT_NETYPE2_8822C)
#define BIT_CLEAR_NETYPE2_8822C(x) ((x) & (~BITS_NETYPE2_8822C))
#define BIT_GET_NETYPE2_8822C(x) \
(((x) >> BIT_SHIFT_NETYPE2_8822C) & BIT_MASK_NETYPE2_8822C)
#define BIT_SET_NETYPE2_8822C(x, v) \
(BIT_CLEAR_NETYPE2_8822C(x) | BIT_NETYPE2_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_FWFF_8822C */
#define BIT_SHIFT_PKTNUM_TH_V1_8822C 24
#define BIT_MASK_PKTNUM_TH_V1_8822C 0xff
#define BIT_PKTNUM_TH_V1_8822C(x) \
(((x) & BIT_MASK_PKTNUM_TH_V1_8822C) << BIT_SHIFT_PKTNUM_TH_V1_8822C)
#define BITS_PKTNUM_TH_V1_8822C \
(BIT_MASK_PKTNUM_TH_V1_8822C << BIT_SHIFT_PKTNUM_TH_V1_8822C)
#define BIT_CLEAR_PKTNUM_TH_V1_8822C(x) ((x) & (~BITS_PKTNUM_TH_V1_8822C))
#define BIT_GET_PKTNUM_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V1_8822C) & BIT_MASK_PKTNUM_TH_V1_8822C)
#define BIT_SET_PKTNUM_TH_V1_8822C(x, v) \
(BIT_CLEAR_PKTNUM_TH_V1_8822C(x) | BIT_PKTNUM_TH_V1_8822C(v))
#define BIT_SHIFT_TIMER_TH_8822C 16
#define BIT_MASK_TIMER_TH_8822C 0xff
#define BIT_TIMER_TH_8822C(x) \
(((x) & BIT_MASK_TIMER_TH_8822C) << BIT_SHIFT_TIMER_TH_8822C)
#define BITS_TIMER_TH_8822C \
(BIT_MASK_TIMER_TH_8822C << BIT_SHIFT_TIMER_TH_8822C)
#define BIT_CLEAR_TIMER_TH_8822C(x) ((x) & (~BITS_TIMER_TH_8822C))
#define BIT_GET_TIMER_TH_8822C(x) \
(((x) >> BIT_SHIFT_TIMER_TH_8822C) & BIT_MASK_TIMER_TH_8822C)
#define BIT_SET_TIMER_TH_8822C(x, v) \
(BIT_CLEAR_TIMER_TH_8822C(x) | BIT_TIMER_TH_8822C(v))
#define BIT_SHIFT_RXPKT1ENADDR_8822C 0
#define BIT_MASK_RXPKT1ENADDR_8822C 0xffff
#define BIT_RXPKT1ENADDR_8822C(x) \
(((x) & BIT_MASK_RXPKT1ENADDR_8822C) << BIT_SHIFT_RXPKT1ENADDR_8822C)
#define BITS_RXPKT1ENADDR_8822C \
(BIT_MASK_RXPKT1ENADDR_8822C << BIT_SHIFT_RXPKT1ENADDR_8822C)
#define BIT_CLEAR_RXPKT1ENADDR_8822C(x) ((x) & (~BITS_RXPKT1ENADDR_8822C))
#define BIT_GET_RXPKT1ENADDR_8822C(x) \
(((x) >> BIT_SHIFT_RXPKT1ENADDR_8822C) & BIT_MASK_RXPKT1ENADDR_8822C)
#define BIT_SET_RXPKT1ENADDR_8822C(x, v) \
(BIT_CLEAR_RXPKT1ENADDR_8822C(x) | BIT_RXPKT1ENADDR_8822C(v))
/* 2 REG_RXFF_PTR_V1_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_RXFF0_RDPTR_V2_8822C 0
#define BIT_MASK_RXFF0_RDPTR_V2_8822C 0x3ffff
#define BIT_RXFF0_RDPTR_V2_8822C(x) \
(((x) & BIT_MASK_RXFF0_RDPTR_V2_8822C) \
<< BIT_SHIFT_RXFF0_RDPTR_V2_8822C)
#define BITS_RXFF0_RDPTR_V2_8822C \
(BIT_MASK_RXFF0_RDPTR_V2_8822C << BIT_SHIFT_RXFF0_RDPTR_V2_8822C)
#define BIT_CLEAR_RXFF0_RDPTR_V2_8822C(x) ((x) & (~BITS_RXFF0_RDPTR_V2_8822C))
#define BIT_GET_RXFF0_RDPTR_V2_8822C(x) \
(((x) >> BIT_SHIFT_RXFF0_RDPTR_V2_8822C) & \
BIT_MASK_RXFF0_RDPTR_V2_8822C)
#define BIT_SET_RXFF0_RDPTR_V2_8822C(x, v) \
(BIT_CLEAR_RXFF0_RDPTR_V2_8822C(x) | BIT_RXFF0_RDPTR_V2_8822C(v))
/* 2 REG_RXFF_WTR_V1_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_RXFF0_WTPTR_V2_8822C 0
#define BIT_MASK_RXFF0_WTPTR_V2_8822C 0x3ffff
#define BIT_RXFF0_WTPTR_V2_8822C(x) \
(((x) & BIT_MASK_RXFF0_WTPTR_V2_8822C) \
<< BIT_SHIFT_RXFF0_WTPTR_V2_8822C)
#define BITS_RXFF0_WTPTR_V2_8822C \
(BIT_MASK_RXFF0_WTPTR_V2_8822C << BIT_SHIFT_RXFF0_WTPTR_V2_8822C)
#define BIT_CLEAR_RXFF0_WTPTR_V2_8822C(x) ((x) & (~BITS_RXFF0_WTPTR_V2_8822C))
#define BIT_GET_RXFF0_WTPTR_V2_8822C(x) \
(((x) >> BIT_SHIFT_RXFF0_WTPTR_V2_8822C) & \
BIT_MASK_RXFF0_WTPTR_V2_8822C)
#define BIT_SET_RXFF0_WTPTR_V2_8822C(x, v) \
(BIT_CLEAR_RXFF0_WTPTR_V2_8822C(x) | BIT_RXFF0_WTPTR_V2_8822C(v))
/* 2 REG_FE2IMR_8822C */
#define BIT__FE4ISR__IND_MSK_8822C BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_EN_8822C BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_EN_8822C BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_EN_8822C BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_EN_8822C BIT(25)
#define BIT_FS_TXSC_VODONE_INT_EN_8822C BIT(24)
#define BIT_FS_ATIM_MB7_INT_EN_8822C BIT(23)
#define BIT_FS_ATIM_MB6_INT_EN_8822C BIT(22)
#define BIT_FS_ATIM_MB5_INT_EN_8822C BIT(21)
#define BIT_FS_ATIM_MB4_INT_EN_8822C BIT(20)
#define BIT_FS_ATIM_MB3_INT_EN_8822C BIT(19)
#define BIT_FS_ATIM_MB2_INT_EN_8822C BIT(18)
#define BIT_FS_ATIM_MB1_INT_EN_8822C BIT(17)
#define BIT_FS_ATIM_MB0_INT_EN_8822C BIT(16)
#define BIT_FS_TBTT4INT_EN_8822C BIT(11)
#define BIT_FS_TBTT3INT_EN_8822C BIT(10)
#define BIT_FS_TBTT2INT_EN_8822C BIT(9)
#define BIT_FS_TBTT1INT_EN_8822C BIT(8)
#define BIT_FS_TBTT0_MB7INT_EN_8822C BIT(7)
#define BIT_FS_TBTT0_MB6INT_EN_8822C BIT(6)
#define BIT_FS_TBTT0_MB5INT_EN_8822C BIT(5)
#define BIT_FS_TBTT0_MB4INT_EN_8822C BIT(4)
#define BIT_FS_TBTT0_MB3INT_EN_8822C BIT(3)
#define BIT_FS_TBTT0_MB2INT_EN_8822C BIT(2)
#define BIT_FS_TBTT0_MB1INT_EN_8822C BIT(1)
#define BIT_FS_TBTT0_INT_EN_8822C BIT(0)
/* 2 REG_FE2ISR_8822C */
#define BIT__FE4ISR__IND_INT_8822C BIT(29)
#define BIT_FS_TXSC_DESC_DONE_INT_8822C BIT(28)
#define BIT_FS_TXSC_BKDONE_INT_8822C BIT(27)
#define BIT_FS_TXSC_BEDONE_INT_8822C BIT(26)
#define BIT_FS_TXSC_VIDONE_INT_8822C BIT(25)
#define BIT_FS_TXSC_VODONE_INT_8822C BIT(24)
#define BIT_FS_ATIM_MB7_INT_8822C BIT(23)
#define BIT_FS_ATIM_MB6_INT_8822C BIT(22)
#define BIT_FS_ATIM_MB5_INT_8822C BIT(21)
#define BIT_FS_ATIM_MB4_INT_8822C BIT(20)
#define BIT_FS_ATIM_MB3_INT_8822C BIT(19)
#define BIT_FS_ATIM_MB2_INT_8822C BIT(18)
#define BIT_FS_ATIM_MB1_INT_8822C BIT(17)
#define BIT_FS_ATIM_MB0_INT_8822C BIT(16)
#define BIT_FS_TBTT4INT_8822C BIT(11)
#define BIT_FS_TBTT3INT_8822C BIT(10)
#define BIT_FS_TBTT2INT_8822C BIT(9)
#define BIT_FS_TBTT1INT_8822C BIT(8)
#define BIT_FS_TBTT0_MB7INT_8822C BIT(7)
#define BIT_FS_TBTT0_MB6INT_8822C BIT(6)
#define BIT_FS_TBTT0_MB5INT_8822C BIT(5)
#define BIT_FS_TBTT0_MB4INT_8822C BIT(4)
#define BIT_FS_TBTT0_MB3INT_8822C BIT(3)
#define BIT_FS_TBTT0_MB2INT_8822C BIT(2)
#define BIT_FS_TBTT0_MB1INT_8822C BIT(1)
#define BIT_FS_TBTT0_INT_8822C BIT(0)
/* 2 REG_FE3IMR_8822C */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT__EN_8822C BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT__EN_8822C BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT__EN_8822C BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT__EN_8822C BIT(28)
#define BIT_FS_BCNDMA4_INT_EN_8822C BIT(27)
#define BIT_FS_BCNDMA3_INT_EN_8822C BIT(26)
#define BIT_FS_BCNDMA2_INT_EN_8822C BIT(25)
#define BIT_FS_BCNDMA1_INT_EN_8822C BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_EN_8822C BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_EN_8822C BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_EN_8822C BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_EN_8822C BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_EN_8822C BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_EN_8822C BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_EN_8822C BIT(17)
#define BIT_FS_BCNDMA0_INT_EN_8822C BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT__EN_8822C BIT(15)
#define BIT_FS_BCNERLY4_INT_EN_8822C BIT(11)
#define BIT_FS_BCNERLY3_INT_EN_8822C BIT(10)
#define BIT_FS_BCNERLY2_INT_EN_8822C BIT(9)
#define BIT_FS_BCNERLY1_INT_EN_8822C BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_EN_8822C BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_EN_8822C BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_EN_8822C BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_EN_8822C BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_EN_8822C BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_EN_8822C BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_EN_8822C BIT(1)
#define BIT_FS_BCNERLY0_INT_EN_8822C BIT(0)
/* 2 REG_FE3ISR_8822C */
#define BIT_FS_CLI3_MTI_BCNIVLEAR_INT_8822C BIT(31)
#define BIT_FS_CLI2_MTI_BCNIVLEAR_INT_8822C BIT(30)
#define BIT_FS_CLI1_MTI_BCNIVLEAR_INT_8822C BIT(29)
#define BIT_FS_CLI0_MTI_BCNIVLEAR_INT_8822C BIT(28)
#define BIT_FS_BCNDMA4_INT_8822C BIT(27)
#define BIT_FS_BCNDMA3_INT_8822C BIT(26)
#define BIT_FS_BCNDMA2_INT_8822C BIT(25)
#define BIT_FS_BCNDMA1_INT_8822C BIT(24)
#define BIT_FS_BCNDMA0_MB7_INT_8822C BIT(23)
#define BIT_FS_BCNDMA0_MB6_INT_8822C BIT(22)
#define BIT_FS_BCNDMA0_MB5_INT_8822C BIT(21)
#define BIT_FS_BCNDMA0_MB4_INT_8822C BIT(20)
#define BIT_FS_BCNDMA0_MB3_INT_8822C BIT(19)
#define BIT_FS_BCNDMA0_MB2_INT_8822C BIT(18)
#define BIT_FS_BCNDMA0_MB1_INT_8822C BIT(17)
#define BIT_FS_BCNDMA0_INT_8822C BIT(16)
#define BIT_FS_MTI_BCNIVLEAR_INT_8822C BIT(15)
#define BIT_FS_BCNERLY4_INT_8822C BIT(11)
#define BIT_FS_BCNERLY3_INT_8822C BIT(10)
#define BIT_FS_BCNERLY2_INT_8822C BIT(9)
#define BIT_FS_BCNERLY1_INT_8822C BIT(8)
#define BIT_FS_BCNERLY0_MB7INT_8822C BIT(7)
#define BIT_FS_BCNERLY0_MB6INT_8822C BIT(6)
#define BIT_FS_BCNERLY0_MB5INT_8822C BIT(5)
#define BIT_FS_BCNERLY0_MB4INT_8822C BIT(4)
#define BIT_FS_BCNERLY0_MB3INT_8822C BIT(3)
#define BIT_FS_BCNERLY0_MB2INT_8822C BIT(2)
#define BIT_FS_BCNERLY0_MB1INT_8822C BIT(1)
#define BIT_FS_BCNERLY0_INT_8822C BIT(0)
/* 2 REG_FE4IMR_8822C */
#define BIT_FS_CLI3_TXPKTIN_INT_EN_8822C BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_EN_8822C BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_EN_8822C BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_EN_8822C BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_EN_8822C BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_EN_8822C BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_EN_8822C BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_EN_8822C BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_EN_8822C BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_EN_8822C BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_EN_8822C BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_EN_8822C BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_EN_8822C BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_EN_8822C BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_EN_8822C BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_EN_8822C BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_EN_8822C BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_EN_8822C BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_EN_8822C BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_EN_8822C BIT(0)
/* 2 REG_FE4ISR_8822C */
#define BIT_FS_CLI3_TXPKTIN_INT_8822C BIT(19)
#define BIT_FS_CLI2_TXPKTIN_INT_8822C BIT(18)
#define BIT_FS_CLI1_TXPKTIN_INT_8822C BIT(17)
#define BIT_FS_CLI0_TXPKTIN_INT_8822C BIT(16)
#define BIT_FS_CLI3_RX_UMD0_INT_8822C BIT(15)
#define BIT_FS_CLI3_RX_UMD1_INT_8822C BIT(14)
#define BIT_FS_CLI3_RX_BMD0_INT_8822C BIT(13)
#define BIT_FS_CLI3_RX_BMD1_INT_8822C BIT(12)
#define BIT_FS_CLI2_RX_UMD0_INT_8822C BIT(11)
#define BIT_FS_CLI2_RX_UMD1_INT_8822C BIT(10)
#define BIT_FS_CLI2_RX_BMD0_INT_8822C BIT(9)
#define BIT_FS_CLI2_RX_BMD1_INT_8822C BIT(8)
#define BIT_FS_CLI1_RX_UMD0_INT_8822C BIT(7)
#define BIT_FS_CLI1_RX_UMD1_INT_8822C BIT(6)
#define BIT_FS_CLI1_RX_BMD0_INT_8822C BIT(5)
#define BIT_FS_CLI1_RX_BMD1_INT_8822C BIT(4)
#define BIT_FS_CLI0_RX_UMD0_INT_8822C BIT(3)
#define BIT_FS_CLI0_RX_UMD1_INT_8822C BIT(2)
#define BIT_FS_CLI0_RX_BMD0_INT_8822C BIT(1)
#define BIT_FS_CLI0_RX_BMD1_INT_8822C BIT(0)
/* 2 REG_FT1IMR_8822C */
#define BIT__FT2ISR__IND_MSK_8822C BIT(30)
#define BIT_FTM_PTT_INT_EN_8822C BIT(29)
#define BIT_RXFTMREQ_INT_EN_8822C BIT(28)
#define BIT_RXFTM_INT_EN_8822C BIT(27)
#define BIT_TXFTM_INT_EN_8822C BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_EN_8822C BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_EN_8822C BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_EN_8822C BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_EN_8822C BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_EN_8822C BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_EN_8822C BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_EN_8822C BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_EN_8822C BIT(18)
#define BIT_FS_CTWEND2_INT_EN_8822C BIT(17)
#define BIT_FS_CTWEND1_INT_EN_8822C BIT(16)
#define BIT_FS_CTWEND0_INT_EN_8822C BIT(15)
#define BIT_FS_TX_NULL1_INT_EN_8822C BIT(14)
#define BIT_FS_TX_NULL0_INT_EN_8822C BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_EN_8822C BIT(12)
#define BIT_FS_P2P_RFON2_INT_EN_8822C BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_EN_8822C BIT(10)
#define BIT_FS_P2P_RFON1_INT_EN_8822C BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_EN_8822C BIT(8)
#define BIT_FS_P2P_RFON0_INT_EN_8822C BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_EN_8822C BIT(6)
#define BIT_FS_RX_UAPSDMD1_EN_8822C BIT(5)
#define BIT_FS_RX_UAPSDMD0_EN_8822C BIT(4)
#define BIT_FS_TRIGGER_PKT_EN_8822C BIT(3)
#define BIT_FS_EOSP_INT_EN_8822C BIT(2)
#define BIT_FS_RPWM2_INT_EN_8822C BIT(1)
#define BIT_FS_RPWM_INT_EN_8822C BIT(0)
/* 2 REG_FT1ISR_8822C */
#define BIT__FT2ISR__IND_INT_8822C BIT(30)
#define BIT_FTM_PTT_INT_8822C BIT(29)
#define BIT_RXFTMREQ_INT_8822C BIT(28)
#define BIT_RXFTM_INT_8822C BIT(27)
#define BIT_TXFTM_INT_8822C BIT(26)
#define BIT_FS_H2C_CMD_OK_INT_8822C BIT(25)
#define BIT_FS_H2C_CMD_FULL_INT_8822C BIT(24)
#define BIT_FS_MACID_PWRCHANGE5_INT_8822C BIT(23)
#define BIT_FS_MACID_PWRCHANGE4_INT_8822C BIT(22)
#define BIT_FS_MACID_PWRCHANGE3_INT_8822C BIT(21)
#define BIT_FS_MACID_PWRCHANGE2_INT_8822C BIT(20)
#define BIT_FS_MACID_PWRCHANGE1_INT_8822C BIT(19)
#define BIT_FS_MACID_PWRCHANGE0_INT_8822C BIT(18)
#define BIT_FS_CTWEND2_INT_8822C BIT(17)
#define BIT_FS_CTWEND1_INT_8822C BIT(16)
#define BIT_FS_CTWEND0_INT_8822C BIT(15)
#define BIT_FS_TX_NULL1_INT_8822C BIT(14)
#define BIT_FS_TX_NULL0_INT_8822C BIT(13)
#define BIT_FS_TSF_BIT32_TOGGLE_INT_8822C BIT(12)
#define BIT_FS_P2P_RFON2_INT_8822C BIT(11)
#define BIT_FS_P2P_RFOFF2_INT_8822C BIT(10)
#define BIT_FS_P2P_RFON1_INT_8822C BIT(9)
#define BIT_FS_P2P_RFOFF1_INT_8822C BIT(8)
#define BIT_FS_P2P_RFON0_INT_8822C BIT(7)
#define BIT_FS_P2P_RFOFF0_INT_8822C BIT(6)
#define BIT_FS_RX_UAPSDMD1_INT_8822C BIT(5)
#define BIT_FS_RX_UAPSDMD0_INT_8822C BIT(4)
#define BIT_FS_TRIGGER_PKT_INT_8822C BIT(3)
#define BIT_FS_EOSP_INT_8822C BIT(2)
#define BIT_FS_RPWM2_INT_8822C BIT(1)
#define BIT_FS_RPWM_INT_8822C BIT(0)
/* 2 REG_SPWR0_8822C */
#define BIT_SHIFT_MID_31TO0_8822C 0
#define BIT_MASK_MID_31TO0_8822C 0xffffffffL
#define BIT_MID_31TO0_8822C(x) \
(((x) & BIT_MASK_MID_31TO0_8822C) << BIT_SHIFT_MID_31TO0_8822C)
#define BITS_MID_31TO0_8822C \
(BIT_MASK_MID_31TO0_8822C << BIT_SHIFT_MID_31TO0_8822C)
#define BIT_CLEAR_MID_31TO0_8822C(x) ((x) & (~BITS_MID_31TO0_8822C))
#define BIT_GET_MID_31TO0_8822C(x) \
(((x) >> BIT_SHIFT_MID_31TO0_8822C) & BIT_MASK_MID_31TO0_8822C)
#define BIT_SET_MID_31TO0_8822C(x, v) \
(BIT_CLEAR_MID_31TO0_8822C(x) | BIT_MID_31TO0_8822C(v))
/* 2 REG_SPWR1_8822C */
#define BIT_SHIFT_MID_63TO32_8822C 0
#define BIT_MASK_MID_63TO32_8822C 0xffffffffL
#define BIT_MID_63TO32_8822C(x) \
(((x) & BIT_MASK_MID_63TO32_8822C) << BIT_SHIFT_MID_63TO32_8822C)
#define BITS_MID_63TO32_8822C \
(BIT_MASK_MID_63TO32_8822C << BIT_SHIFT_MID_63TO32_8822C)
#define BIT_CLEAR_MID_63TO32_8822C(x) ((x) & (~BITS_MID_63TO32_8822C))
#define BIT_GET_MID_63TO32_8822C(x) \
(((x) >> BIT_SHIFT_MID_63TO32_8822C) & BIT_MASK_MID_63TO32_8822C)
#define BIT_SET_MID_63TO32_8822C(x, v) \
(BIT_CLEAR_MID_63TO32_8822C(x) | BIT_MID_63TO32_8822C(v))
/* 2 REG_SPWR2_8822C */
#define BIT_SHIFT_MID_95O64_8822C 0
#define BIT_MASK_MID_95O64_8822C 0xffffffffL
#define BIT_MID_95O64_8822C(x) \
(((x) & BIT_MASK_MID_95O64_8822C) << BIT_SHIFT_MID_95O64_8822C)
#define BITS_MID_95O64_8822C \
(BIT_MASK_MID_95O64_8822C << BIT_SHIFT_MID_95O64_8822C)
#define BIT_CLEAR_MID_95O64_8822C(x) ((x) & (~BITS_MID_95O64_8822C))
#define BIT_GET_MID_95O64_8822C(x) \
(((x) >> BIT_SHIFT_MID_95O64_8822C) & BIT_MASK_MID_95O64_8822C)
#define BIT_SET_MID_95O64_8822C(x, v) \
(BIT_CLEAR_MID_95O64_8822C(x) | BIT_MID_95O64_8822C(v))
/* 2 REG_SPWR3_8822C */
#define BIT_SHIFT_MID_127TO96_8822C 0
#define BIT_MASK_MID_127TO96_8822C 0xffffffffL
#define BIT_MID_127TO96_8822C(x) \
(((x) & BIT_MASK_MID_127TO96_8822C) << BIT_SHIFT_MID_127TO96_8822C)
#define BITS_MID_127TO96_8822C \
(BIT_MASK_MID_127TO96_8822C << BIT_SHIFT_MID_127TO96_8822C)
#define BIT_CLEAR_MID_127TO96_8822C(x) ((x) & (~BITS_MID_127TO96_8822C))
#define BIT_GET_MID_127TO96_8822C(x) \
(((x) >> BIT_SHIFT_MID_127TO96_8822C) & BIT_MASK_MID_127TO96_8822C)
#define BIT_SET_MID_127TO96_8822C(x, v) \
(BIT_CLEAR_MID_127TO96_8822C(x) | BIT_MID_127TO96_8822C(v))
/* 2 REG_POWSEQ_8822C */
#define BIT_SHIFT_SEQNUM_MID_8822C 16
#define BIT_MASK_SEQNUM_MID_8822C 0xffff
#define BIT_SEQNUM_MID_8822C(x) \
(((x) & BIT_MASK_SEQNUM_MID_8822C) << BIT_SHIFT_SEQNUM_MID_8822C)
#define BITS_SEQNUM_MID_8822C \
(BIT_MASK_SEQNUM_MID_8822C << BIT_SHIFT_SEQNUM_MID_8822C)
#define BIT_CLEAR_SEQNUM_MID_8822C(x) ((x) & (~BITS_SEQNUM_MID_8822C))
#define BIT_GET_SEQNUM_MID_8822C(x) \
(((x) >> BIT_SHIFT_SEQNUM_MID_8822C) & BIT_MASK_SEQNUM_MID_8822C)
#define BIT_SET_SEQNUM_MID_8822C(x, v) \
(BIT_CLEAR_SEQNUM_MID_8822C(x) | BIT_SEQNUM_MID_8822C(v))
#define BIT_SHIFT_REF_MID_8822C 0
#define BIT_MASK_REF_MID_8822C 0x7f
#define BIT_REF_MID_8822C(x) \
(((x) & BIT_MASK_REF_MID_8822C) << BIT_SHIFT_REF_MID_8822C)
#define BITS_REF_MID_8822C (BIT_MASK_REF_MID_8822C << BIT_SHIFT_REF_MID_8822C)
#define BIT_CLEAR_REF_MID_8822C(x) ((x) & (~BITS_REF_MID_8822C))
#define BIT_GET_REF_MID_8822C(x) \
(((x) >> BIT_SHIFT_REF_MID_8822C) & BIT_MASK_REF_MID_8822C)
#define BIT_SET_REF_MID_8822C(x, v) \
(BIT_CLEAR_REF_MID_8822C(x) | BIT_REF_MID_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_TC7_CTRL_V1_8822C */
#define BIT_TC7INT_EN_8822C BIT(26)
#define BIT_TC7MODE_8822C BIT(25)
#define BIT_TC7EN_8822C BIT(24)
#define BIT_SHIFT_TC7DATA_8822C 0
#define BIT_MASK_TC7DATA_8822C 0xffffff
#define BIT_TC7DATA_8822C(x) \
(((x) & BIT_MASK_TC7DATA_8822C) << BIT_SHIFT_TC7DATA_8822C)
#define BITS_TC7DATA_8822C (BIT_MASK_TC7DATA_8822C << BIT_SHIFT_TC7DATA_8822C)
#define BIT_CLEAR_TC7DATA_8822C(x) ((x) & (~BITS_TC7DATA_8822C))
#define BIT_GET_TC7DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC7DATA_8822C) & BIT_MASK_TC7DATA_8822C)
#define BIT_SET_TC7DATA_8822C(x, v) \
(BIT_CLEAR_TC7DATA_8822C(x) | BIT_TC7DATA_8822C(v))
/* 2 REG_TC8_CTRL_V1_8822C */
#define BIT_TC8INT_EN_8822C BIT(26)
#define BIT_TC8MODE_8822C BIT(25)
#define BIT_TC8EN_8822C BIT(24)
#define BIT_SHIFT_TC8DATA_8822C 0
#define BIT_MASK_TC8DATA_8822C 0xffffff
#define BIT_TC8DATA_8822C(x) \
(((x) & BIT_MASK_TC8DATA_8822C) << BIT_SHIFT_TC8DATA_8822C)
#define BITS_TC8DATA_8822C (BIT_MASK_TC8DATA_8822C << BIT_SHIFT_TC8DATA_8822C)
#define BIT_CLEAR_TC8DATA_8822C(x) ((x) & (~BITS_TC8DATA_8822C))
#define BIT_GET_TC8DATA_8822C(x) \
(((x) >> BIT_SHIFT_TC8DATA_8822C) & BIT_MASK_TC8DATA_8822C)
#define BIT_SET_TC8DATA_8822C(x, v) \
(BIT_CLEAR_TC8DATA_8822C(x) | BIT_TC8DATA_8822C(v))
/* 2 REG_RX_BCN_TBTT_ITVL0_8822C */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8822C 24
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8822C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT2_8822C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8822C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8822C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT2_8822C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8822C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8822C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2_8822C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT2_8822C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT2_8822C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT2_8822C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT2_8822C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT2_8822C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT2_8822C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT2_8822C(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8822C 16
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8822C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT1_8822C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8822C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8822C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT1_8822C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8822C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8822C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1_8822C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT1_8822C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT1_8822C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT1_8822C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT1_8822C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT1_8822C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT1_8822C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT1_8822C(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8822C 8
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8822C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT0_8822C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8822C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8822C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT0_8822C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8822C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8822C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0_8822C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT0_8822C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT0_8822C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT0_8822C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT0_8822C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT0_8822C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT0_8822C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT0_8822C(v))
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8822C 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8822C 0xff
#define BIT_RX_BCN_TBTT_ITVL_PORT0_8822C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8822C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8822C)
#define BITS_RX_BCN_TBTT_ITVL_PORT0_8822C \
(BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8822C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8822C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0_8822C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_PORT0_8822C))
#define BIT_GET_RX_BCN_TBTT_ITVL_PORT0_8822C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_PORT0_8822C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_PORT0_8822C)
#define BIT_SET_RX_BCN_TBTT_ITVL_PORT0_8822C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_PORT0_8822C(x) | \
BIT_RX_BCN_TBTT_ITVL_PORT0_8822C(v))
/* 2 REG_RX_BCN_TBTT_ITVL1_8822C */
#define BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8822C 0
#define BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8822C 0xff
#define BIT_RX_BCN_TBTT_ITVL_CLIENT3_8822C(x) \
(((x) & BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8822C) \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8822C)
#define BITS_RX_BCN_TBTT_ITVL_CLIENT3_8822C \
(BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8822C \
<< BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8822C)
#define BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3_8822C(x) \
((x) & (~BITS_RX_BCN_TBTT_ITVL_CLIENT3_8822C))
#define BIT_GET_RX_BCN_TBTT_ITVL_CLIENT3_8822C(x) \
(((x) >> BIT_SHIFT_RX_BCN_TBTT_ITVL_CLIENT3_8822C) & \
BIT_MASK_RX_BCN_TBTT_ITVL_CLIENT3_8822C)
#define BIT_SET_RX_BCN_TBTT_ITVL_CLIENT3_8822C(x, v) \
(BIT_CLEAR_RX_BCN_TBTT_ITVL_CLIENT3_8822C(x) | \
BIT_RX_BCN_TBTT_ITVL_CLIENT3_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_IO_WRAP_ERR_FLAG_8822C */
#define BIT_IO_WRAP_ERR_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SPEED_SENSOR_8822C */
#define BIT_DSS_1_RST_N_8822C BIT(31)
#define BIT_DSS_1_SPEED_EN_8822C BIT(30)
#define BIT_DSS_1_WIRE_SEL_8822C BIT(29)
#define BIT_DSS_ENCLK_8822C BIT(28)
#define BIT_SHIFT_DSS_1_RO_SEL_8822C 24
#define BIT_MASK_DSS_1_RO_SEL_8822C 0x7
#define BIT_DSS_1_RO_SEL_8822C(x) \
(((x) & BIT_MASK_DSS_1_RO_SEL_8822C) << BIT_SHIFT_DSS_1_RO_SEL_8822C)
#define BITS_DSS_1_RO_SEL_8822C \
(BIT_MASK_DSS_1_RO_SEL_8822C << BIT_SHIFT_DSS_1_RO_SEL_8822C)
#define BIT_CLEAR_DSS_1_RO_SEL_8822C(x) ((x) & (~BITS_DSS_1_RO_SEL_8822C))
#define BIT_GET_DSS_1_RO_SEL_8822C(x) \
(((x) >> BIT_SHIFT_DSS_1_RO_SEL_8822C) & BIT_MASK_DSS_1_RO_SEL_8822C)
#define BIT_SET_DSS_1_RO_SEL_8822C(x, v) \
(BIT_CLEAR_DSS_1_RO_SEL_8822C(x) | BIT_DSS_1_RO_SEL_8822C(v))
#define BIT_SHIFT_DSS_1_DATA_IN_8822C 0
#define BIT_MASK_DSS_1_DATA_IN_8822C 0xfffff
#define BIT_DSS_1_DATA_IN_8822C(x) \
(((x) & BIT_MASK_DSS_1_DATA_IN_8822C) << BIT_SHIFT_DSS_1_DATA_IN_8822C)
#define BITS_DSS_1_DATA_IN_8822C \
(BIT_MASK_DSS_1_DATA_IN_8822C << BIT_SHIFT_DSS_1_DATA_IN_8822C)
#define BIT_CLEAR_DSS_1_DATA_IN_8822C(x) ((x) & (~BITS_DSS_1_DATA_IN_8822C))
#define BIT_GET_DSS_1_DATA_IN_8822C(x) \
(((x) >> BIT_SHIFT_DSS_1_DATA_IN_8822C) & BIT_MASK_DSS_1_DATA_IN_8822C)
#define BIT_SET_DSS_1_DATA_IN_8822C(x, v) \
(BIT_CLEAR_DSS_1_DATA_IN_8822C(x) | BIT_DSS_1_DATA_IN_8822C(v))
/* 2 REG_SPEED_SENSOR1_8822C */
#define BIT_DSS_1_READY_8822C BIT(31)
#define BIT_DSS_1_WSORT_GO_8822C BIT(30)
#define BIT_SHIFT_DSS_1_COUNT_OUT_8822C 0
#define BIT_MASK_DSS_1_COUNT_OUT_8822C 0xfffff
#define BIT_DSS_1_COUNT_OUT_8822C(x) \
(((x) & BIT_MASK_DSS_1_COUNT_OUT_8822C) \
<< BIT_SHIFT_DSS_1_COUNT_OUT_8822C)
#define BITS_DSS_1_COUNT_OUT_8822C \
(BIT_MASK_DSS_1_COUNT_OUT_8822C << BIT_SHIFT_DSS_1_COUNT_OUT_8822C)
#define BIT_CLEAR_DSS_1_COUNT_OUT_8822C(x) ((x) & (~BITS_DSS_1_COUNT_OUT_8822C))
#define BIT_GET_DSS_1_COUNT_OUT_8822C(x) \
(((x) >> BIT_SHIFT_DSS_1_COUNT_OUT_8822C) & \
BIT_MASK_DSS_1_COUNT_OUT_8822C)
#define BIT_SET_DSS_1_COUNT_OUT_8822C(x, v) \
(BIT_CLEAR_DSS_1_COUNT_OUT_8822C(x) | BIT_DSS_1_COUNT_OUT_8822C(v))
/* 2 REG_SPEED_SENSOR2_8822C */
#define BIT_DSS_2_RST_N_8822C BIT(31)
#define BIT_DSS_2_SPEED_EN_8822C BIT(30)
#define BIT_DSS_2_WIRE_SEL_8822C BIT(29)
#define BIT_DSS_ENCLK_8822C BIT(28)
#define BIT_SHIFT_DSS_2_RO_SEL_8822C 24
#define BIT_MASK_DSS_2_RO_SEL_8822C 0x7
#define BIT_DSS_2_RO_SEL_8822C(x) \
(((x) & BIT_MASK_DSS_2_RO_SEL_8822C) << BIT_SHIFT_DSS_2_RO_SEL_8822C)
#define BITS_DSS_2_RO_SEL_8822C \
(BIT_MASK_DSS_2_RO_SEL_8822C << BIT_SHIFT_DSS_2_RO_SEL_8822C)
#define BIT_CLEAR_DSS_2_RO_SEL_8822C(x) ((x) & (~BITS_DSS_2_RO_SEL_8822C))
#define BIT_GET_DSS_2_RO_SEL_8822C(x) \
(((x) >> BIT_SHIFT_DSS_2_RO_SEL_8822C) & BIT_MASK_DSS_2_RO_SEL_8822C)
#define BIT_SET_DSS_2_RO_SEL_8822C(x, v) \
(BIT_CLEAR_DSS_2_RO_SEL_8822C(x) | BIT_DSS_2_RO_SEL_8822C(v))
#define BIT_SHIFT_DSS_2_DATA_IN_8822C 0
#define BIT_MASK_DSS_2_DATA_IN_8822C 0xfffff
#define BIT_DSS_2_DATA_IN_8822C(x) \
(((x) & BIT_MASK_DSS_2_DATA_IN_8822C) << BIT_SHIFT_DSS_2_DATA_IN_8822C)
#define BITS_DSS_2_DATA_IN_8822C \
(BIT_MASK_DSS_2_DATA_IN_8822C << BIT_SHIFT_DSS_2_DATA_IN_8822C)
#define BIT_CLEAR_DSS_2_DATA_IN_8822C(x) ((x) & (~BITS_DSS_2_DATA_IN_8822C))
#define BIT_GET_DSS_2_DATA_IN_8822C(x) \
(((x) >> BIT_SHIFT_DSS_2_DATA_IN_8822C) & BIT_MASK_DSS_2_DATA_IN_8822C)
#define BIT_SET_DSS_2_DATA_IN_8822C(x, v) \
(BIT_CLEAR_DSS_2_DATA_IN_8822C(x) | BIT_DSS_2_DATA_IN_8822C(v))
/* 2 REG_SPEED_SENSOR3_8822C */
#define BIT_DSS_2_READY_8822C BIT(31)
#define BIT_DSS_2_WSORT_GO_8822C BIT(30)
#define BIT_SHIFT_DSS_2_COUNT_OUT_8822C 0
#define BIT_MASK_DSS_2_COUNT_OUT_8822C 0xfffff
#define BIT_DSS_2_COUNT_OUT_8822C(x) \
(((x) & BIT_MASK_DSS_2_COUNT_OUT_8822C) \
<< BIT_SHIFT_DSS_2_COUNT_OUT_8822C)
#define BITS_DSS_2_COUNT_OUT_8822C \
(BIT_MASK_DSS_2_COUNT_OUT_8822C << BIT_SHIFT_DSS_2_COUNT_OUT_8822C)
#define BIT_CLEAR_DSS_2_COUNT_OUT_8822C(x) ((x) & (~BITS_DSS_2_COUNT_OUT_8822C))
#define BIT_GET_DSS_2_COUNT_OUT_8822C(x) \
(((x) >> BIT_SHIFT_DSS_2_COUNT_OUT_8822C) & \
BIT_MASK_DSS_2_COUNT_OUT_8822C)
#define BIT_SET_DSS_2_COUNT_OUT_8822C(x, v) \
(BIT_CLEAR_DSS_2_COUNT_OUT_8822C(x) | BIT_DSS_2_COUNT_OUT_8822C(v))
/* 2 REG_SPEED_SENSOR4_8822C */
#define BIT_DSS_3_RST_N_8822C BIT(31)
#define BIT_DSS_3_SPEED_EN_8822C BIT(30)
#define BIT_DSS_3_WIRE_SEL_8822C BIT(29)
#define BIT_DSS_ENCLK_8822C BIT(28)
#define BIT_SHIFT_DSS_3_RO_SEL_8822C 24
#define BIT_MASK_DSS_3_RO_SEL_8822C 0x7
#define BIT_DSS_3_RO_SEL_8822C(x) \
(((x) & BIT_MASK_DSS_3_RO_SEL_8822C) << BIT_SHIFT_DSS_3_RO_SEL_8822C)
#define BITS_DSS_3_RO_SEL_8822C \
(BIT_MASK_DSS_3_RO_SEL_8822C << BIT_SHIFT_DSS_3_RO_SEL_8822C)
#define BIT_CLEAR_DSS_3_RO_SEL_8822C(x) ((x) & (~BITS_DSS_3_RO_SEL_8822C))
#define BIT_GET_DSS_3_RO_SEL_8822C(x) \
(((x) >> BIT_SHIFT_DSS_3_RO_SEL_8822C) & BIT_MASK_DSS_3_RO_SEL_8822C)
#define BIT_SET_DSS_3_RO_SEL_8822C(x, v) \
(BIT_CLEAR_DSS_3_RO_SEL_8822C(x) | BIT_DSS_3_RO_SEL_8822C(v))
#define BIT_SHIFT_DSS_3_DATA_IN_8822C 0
#define BIT_MASK_DSS_3_DATA_IN_8822C 0xfffff
#define BIT_DSS_3_DATA_IN_8822C(x) \
(((x) & BIT_MASK_DSS_3_DATA_IN_8822C) << BIT_SHIFT_DSS_3_DATA_IN_8822C)
#define BITS_DSS_3_DATA_IN_8822C \
(BIT_MASK_DSS_3_DATA_IN_8822C << BIT_SHIFT_DSS_3_DATA_IN_8822C)
#define BIT_CLEAR_DSS_3_DATA_IN_8822C(x) ((x) & (~BITS_DSS_3_DATA_IN_8822C))
#define BIT_GET_DSS_3_DATA_IN_8822C(x) \
(((x) >> BIT_SHIFT_DSS_3_DATA_IN_8822C) & BIT_MASK_DSS_3_DATA_IN_8822C)
#define BIT_SET_DSS_3_DATA_IN_8822C(x, v) \
(BIT_CLEAR_DSS_3_DATA_IN_8822C(x) | BIT_DSS_3_DATA_IN_8822C(v))
/* 2 REG_SPEED_SENSOR5_8822C */
#define BIT_DSS_3_READY_8822C BIT(31)
#define BIT_DSS_3_WSORT_GO_8822C BIT(30)
#define BIT_SHIFT_DSS_3_COUNT_OUT_8822C 0
#define BIT_MASK_DSS_3_COUNT_OUT_8822C 0xfffff
#define BIT_DSS_3_COUNT_OUT_8822C(x) \
(((x) & BIT_MASK_DSS_3_COUNT_OUT_8822C) \
<< BIT_SHIFT_DSS_3_COUNT_OUT_8822C)
#define BITS_DSS_3_COUNT_OUT_8822C \
(BIT_MASK_DSS_3_COUNT_OUT_8822C << BIT_SHIFT_DSS_3_COUNT_OUT_8822C)
#define BIT_CLEAR_DSS_3_COUNT_OUT_8822C(x) ((x) & (~BITS_DSS_3_COUNT_OUT_8822C))
#define BIT_GET_DSS_3_COUNT_OUT_8822C(x) \
(((x) >> BIT_SHIFT_DSS_3_COUNT_OUT_8822C) & \
BIT_MASK_DSS_3_COUNT_OUT_8822C)
#define BIT_SET_DSS_3_COUNT_OUT_8822C(x, v) \
(BIT_CLEAR_DSS_3_COUNT_OUT_8822C(x) | BIT_DSS_3_COUNT_OUT_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_COUNTER_CTRL_8822C */
#define BIT_SHIFT_COUNTER_BASE_8822C 16
#define BIT_MASK_COUNTER_BASE_8822C 0x1fff
#define BIT_COUNTER_BASE_8822C(x) \
(((x) & BIT_MASK_COUNTER_BASE_8822C) << BIT_SHIFT_COUNTER_BASE_8822C)
#define BITS_COUNTER_BASE_8822C \
(BIT_MASK_COUNTER_BASE_8822C << BIT_SHIFT_COUNTER_BASE_8822C)
#define BIT_CLEAR_COUNTER_BASE_8822C(x) ((x) & (~BITS_COUNTER_BASE_8822C))
#define BIT_GET_COUNTER_BASE_8822C(x) \
(((x) >> BIT_SHIFT_COUNTER_BASE_8822C) & BIT_MASK_COUNTER_BASE_8822C)
#define BIT_SET_COUNTER_BASE_8822C(x, v) \
(BIT_CLEAR_COUNTER_BASE_8822C(x) | BIT_COUNTER_BASE_8822C(v))
#define BIT_EN_RTS_REQ_8822C BIT(9)
#define BIT_EN_EDCA_REQ_8822C BIT(8)
#define BIT_EN_PTCL_REQ_8822C BIT(7)
#define BIT_EN_SCH_REQ_8822C BIT(6)
#define BIT_USB_COUNT_EN_8822C BIT(5)
#define BIT_PCIE_COUNT_EN_8822C BIT(4)
#define BIT_RQPN_COUNT_EN_8822C BIT(3)
#define BIT_RDE_COUNT_EN_8822C BIT(2)
#define BIT_TDE_COUNT_EN_8822C BIT(1)
#define BIT_DISABLE_COUNTER_8822C BIT(0)
/* 2 REG_COUNTER_THRESHOLD_8822C */
#define BIT_SEL_ALL_MACID_8822C BIT(31)
#define BIT_SHIFT_COUNTER_MACID_8822C 24
#define BIT_MASK_COUNTER_MACID_8822C 0x7f
#define BIT_COUNTER_MACID_8822C(x) \
(((x) & BIT_MASK_COUNTER_MACID_8822C) << BIT_SHIFT_COUNTER_MACID_8822C)
#define BITS_COUNTER_MACID_8822C \
(BIT_MASK_COUNTER_MACID_8822C << BIT_SHIFT_COUNTER_MACID_8822C)
#define BIT_CLEAR_COUNTER_MACID_8822C(x) ((x) & (~BITS_COUNTER_MACID_8822C))
#define BIT_GET_COUNTER_MACID_8822C(x) \
(((x) >> BIT_SHIFT_COUNTER_MACID_8822C) & BIT_MASK_COUNTER_MACID_8822C)
#define BIT_SET_COUNTER_MACID_8822C(x, v) \
(BIT_CLEAR_COUNTER_MACID_8822C(x) | BIT_COUNTER_MACID_8822C(v))
#define BIT_SHIFT_AGG_VALUE2_8822C 16
#define BIT_MASK_AGG_VALUE2_8822C 0x7f
#define BIT_AGG_VALUE2_8822C(x) \
(((x) & BIT_MASK_AGG_VALUE2_8822C) << BIT_SHIFT_AGG_VALUE2_8822C)
#define BITS_AGG_VALUE2_8822C \
(BIT_MASK_AGG_VALUE2_8822C << BIT_SHIFT_AGG_VALUE2_8822C)
#define BIT_CLEAR_AGG_VALUE2_8822C(x) ((x) & (~BITS_AGG_VALUE2_8822C))
#define BIT_GET_AGG_VALUE2_8822C(x) \
(((x) >> BIT_SHIFT_AGG_VALUE2_8822C) & BIT_MASK_AGG_VALUE2_8822C)
#define BIT_SET_AGG_VALUE2_8822C(x, v) \
(BIT_CLEAR_AGG_VALUE2_8822C(x) | BIT_AGG_VALUE2_8822C(v))
#define BIT_SHIFT_AGG_VALUE1_8822C 8
#define BIT_MASK_AGG_VALUE1_8822C 0x7f
#define BIT_AGG_VALUE1_8822C(x) \
(((x) & BIT_MASK_AGG_VALUE1_8822C) << BIT_SHIFT_AGG_VALUE1_8822C)
#define BITS_AGG_VALUE1_8822C \
(BIT_MASK_AGG_VALUE1_8822C << BIT_SHIFT_AGG_VALUE1_8822C)
#define BIT_CLEAR_AGG_VALUE1_8822C(x) ((x) & (~BITS_AGG_VALUE1_8822C))
#define BIT_GET_AGG_VALUE1_8822C(x) \
(((x) >> BIT_SHIFT_AGG_VALUE1_8822C) & BIT_MASK_AGG_VALUE1_8822C)
#define BIT_SET_AGG_VALUE1_8822C(x, v) \
(BIT_CLEAR_AGG_VALUE1_8822C(x) | BIT_AGG_VALUE1_8822C(v))
#define BIT_SHIFT_AGG_VALUE0_8822C 0
#define BIT_MASK_AGG_VALUE0_8822C 0x7f
#define BIT_AGG_VALUE0_8822C(x) \
(((x) & BIT_MASK_AGG_VALUE0_8822C) << BIT_SHIFT_AGG_VALUE0_8822C)
#define BITS_AGG_VALUE0_8822C \
(BIT_MASK_AGG_VALUE0_8822C << BIT_SHIFT_AGG_VALUE0_8822C)
#define BIT_CLEAR_AGG_VALUE0_8822C(x) ((x) & (~BITS_AGG_VALUE0_8822C))
#define BIT_GET_AGG_VALUE0_8822C(x) \
(((x) >> BIT_SHIFT_AGG_VALUE0_8822C) & BIT_MASK_AGG_VALUE0_8822C)
#define BIT_SET_AGG_VALUE0_8822C(x, v) \
(BIT_CLEAR_AGG_VALUE0_8822C(x) | BIT_AGG_VALUE0_8822C(v))
/* 2 REG_COUNTER_SET_8822C */
#define BIT_SHIFT_REQUEST_RESET_8822C 16
#define BIT_MASK_REQUEST_RESET_8822C 0xffff
#define BIT_REQUEST_RESET_8822C(x) \
(((x) & BIT_MASK_REQUEST_RESET_8822C) << BIT_SHIFT_REQUEST_RESET_8822C)
#define BITS_REQUEST_RESET_8822C \
(BIT_MASK_REQUEST_RESET_8822C << BIT_SHIFT_REQUEST_RESET_8822C)
#define BIT_CLEAR_REQUEST_RESET_8822C(x) ((x) & (~BITS_REQUEST_RESET_8822C))
#define BIT_GET_REQUEST_RESET_8822C(x) \
(((x) >> BIT_SHIFT_REQUEST_RESET_8822C) & BIT_MASK_REQUEST_RESET_8822C)
#define BIT_SET_REQUEST_RESET_8822C(x, v) \
(BIT_CLEAR_REQUEST_RESET_8822C(x) | BIT_REQUEST_RESET_8822C(v))
#define BIT_SHIFT_REQUEST_START_8822C 0
#define BIT_MASK_REQUEST_START_8822C 0xffff
#define BIT_REQUEST_START_8822C(x) \
(((x) & BIT_MASK_REQUEST_START_8822C) << BIT_SHIFT_REQUEST_START_8822C)
#define BITS_REQUEST_START_8822C \
(BIT_MASK_REQUEST_START_8822C << BIT_SHIFT_REQUEST_START_8822C)
#define BIT_CLEAR_REQUEST_START_8822C(x) ((x) & (~BITS_REQUEST_START_8822C))
#define BIT_GET_REQUEST_START_8822C(x) \
(((x) >> BIT_SHIFT_REQUEST_START_8822C) & BIT_MASK_REQUEST_START_8822C)
#define BIT_SET_REQUEST_START_8822C(x, v) \
(BIT_CLEAR_REQUEST_START_8822C(x) | BIT_REQUEST_START_8822C(v))
/* 2 REG_COUNTER_OVERFLOW_8822C */
#define BIT_SHIFT_CNT_OVF_REG_8822C 0
#define BIT_MASK_CNT_OVF_REG_8822C 0xffff
#define BIT_CNT_OVF_REG_8822C(x) \
(((x) & BIT_MASK_CNT_OVF_REG_8822C) << BIT_SHIFT_CNT_OVF_REG_8822C)
#define BITS_CNT_OVF_REG_8822C \
(BIT_MASK_CNT_OVF_REG_8822C << BIT_SHIFT_CNT_OVF_REG_8822C)
#define BIT_CLEAR_CNT_OVF_REG_8822C(x) ((x) & (~BITS_CNT_OVF_REG_8822C))
#define BIT_GET_CNT_OVF_REG_8822C(x) \
(((x) >> BIT_SHIFT_CNT_OVF_REG_8822C) & BIT_MASK_CNT_OVF_REG_8822C)
#define BIT_SET_CNT_OVF_REG_8822C(x, v) \
(BIT_CLEAR_CNT_OVF_REG_8822C(x) | BIT_CNT_OVF_REG_8822C(v))
/* 2 REG_TXDMA_LEN_THRESHOLD_8822C */
#define BIT_SHIFT_TDE_LEN_TH1_8822C 16
#define BIT_MASK_TDE_LEN_TH1_8822C 0xffff
#define BIT_TDE_LEN_TH1_8822C(x) \
(((x) & BIT_MASK_TDE_LEN_TH1_8822C) << BIT_SHIFT_TDE_LEN_TH1_8822C)
#define BITS_TDE_LEN_TH1_8822C \
(BIT_MASK_TDE_LEN_TH1_8822C << BIT_SHIFT_TDE_LEN_TH1_8822C)
#define BIT_CLEAR_TDE_LEN_TH1_8822C(x) ((x) & (~BITS_TDE_LEN_TH1_8822C))
#define BIT_GET_TDE_LEN_TH1_8822C(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH1_8822C) & BIT_MASK_TDE_LEN_TH1_8822C)
#define BIT_SET_TDE_LEN_TH1_8822C(x, v) \
(BIT_CLEAR_TDE_LEN_TH1_8822C(x) | BIT_TDE_LEN_TH1_8822C(v))
#define BIT_SHIFT_TDE_LEN_TH0_8822C 0
#define BIT_MASK_TDE_LEN_TH0_8822C 0xffff
#define BIT_TDE_LEN_TH0_8822C(x) \
(((x) & BIT_MASK_TDE_LEN_TH0_8822C) << BIT_SHIFT_TDE_LEN_TH0_8822C)
#define BITS_TDE_LEN_TH0_8822C \
(BIT_MASK_TDE_LEN_TH0_8822C << BIT_SHIFT_TDE_LEN_TH0_8822C)
#define BIT_CLEAR_TDE_LEN_TH0_8822C(x) ((x) & (~BITS_TDE_LEN_TH0_8822C))
#define BIT_GET_TDE_LEN_TH0_8822C(x) \
(((x) >> BIT_SHIFT_TDE_LEN_TH0_8822C) & BIT_MASK_TDE_LEN_TH0_8822C)
#define BIT_SET_TDE_LEN_TH0_8822C(x, v) \
(BIT_CLEAR_TDE_LEN_TH0_8822C(x) | BIT_TDE_LEN_TH0_8822C(v))
/* 2 REG_RXDMA_LEN_THRESHOLD_8822C */
#define BIT_SHIFT_RDE_LEN_TH1_8822C 16
#define BIT_MASK_RDE_LEN_TH1_8822C 0xffff
#define BIT_RDE_LEN_TH1_8822C(x) \
(((x) & BIT_MASK_RDE_LEN_TH1_8822C) << BIT_SHIFT_RDE_LEN_TH1_8822C)
#define BITS_RDE_LEN_TH1_8822C \
(BIT_MASK_RDE_LEN_TH1_8822C << BIT_SHIFT_RDE_LEN_TH1_8822C)
#define BIT_CLEAR_RDE_LEN_TH1_8822C(x) ((x) & (~BITS_RDE_LEN_TH1_8822C))
#define BIT_GET_RDE_LEN_TH1_8822C(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH1_8822C) & BIT_MASK_RDE_LEN_TH1_8822C)
#define BIT_SET_RDE_LEN_TH1_8822C(x, v) \
(BIT_CLEAR_RDE_LEN_TH1_8822C(x) | BIT_RDE_LEN_TH1_8822C(v))
#define BIT_SHIFT_RDE_LEN_TH0_8822C 0
#define BIT_MASK_RDE_LEN_TH0_8822C 0xffff
#define BIT_RDE_LEN_TH0_8822C(x) \
(((x) & BIT_MASK_RDE_LEN_TH0_8822C) << BIT_SHIFT_RDE_LEN_TH0_8822C)
#define BITS_RDE_LEN_TH0_8822C \
(BIT_MASK_RDE_LEN_TH0_8822C << BIT_SHIFT_RDE_LEN_TH0_8822C)
#define BIT_CLEAR_RDE_LEN_TH0_8822C(x) ((x) & (~BITS_RDE_LEN_TH0_8822C))
#define BIT_GET_RDE_LEN_TH0_8822C(x) \
(((x) >> BIT_SHIFT_RDE_LEN_TH0_8822C) & BIT_MASK_RDE_LEN_TH0_8822C)
#define BIT_SET_RDE_LEN_TH0_8822C(x, v) \
(BIT_CLEAR_RDE_LEN_TH0_8822C(x) | BIT_RDE_LEN_TH0_8822C(v))
/* 2 REG_PCIE_EXEC_TIME_THRESHOLD_8822C */
#define BIT_SHIFT_COUNT_INT_SEL_8822C 16
#define BIT_MASK_COUNT_INT_SEL_8822C 0x3
#define BIT_COUNT_INT_SEL_8822C(x) \
(((x) & BIT_MASK_COUNT_INT_SEL_8822C) << BIT_SHIFT_COUNT_INT_SEL_8822C)
#define BITS_COUNT_INT_SEL_8822C \
(BIT_MASK_COUNT_INT_SEL_8822C << BIT_SHIFT_COUNT_INT_SEL_8822C)
#define BIT_CLEAR_COUNT_INT_SEL_8822C(x) ((x) & (~BITS_COUNT_INT_SEL_8822C))
#define BIT_GET_COUNT_INT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_COUNT_INT_SEL_8822C) & BIT_MASK_COUNT_INT_SEL_8822C)
#define BIT_SET_COUNT_INT_SEL_8822C(x, v) \
(BIT_CLEAR_COUNT_INT_SEL_8822C(x) | BIT_COUNT_INT_SEL_8822C(v))
#define BIT_SHIFT_EXEC_TIME_TH_8822C 0
#define BIT_MASK_EXEC_TIME_TH_8822C 0xffff
#define BIT_EXEC_TIME_TH_8822C(x) \
(((x) & BIT_MASK_EXEC_TIME_TH_8822C) << BIT_SHIFT_EXEC_TIME_TH_8822C)
#define BITS_EXEC_TIME_TH_8822C \
(BIT_MASK_EXEC_TIME_TH_8822C << BIT_SHIFT_EXEC_TIME_TH_8822C)
#define BIT_CLEAR_EXEC_TIME_TH_8822C(x) ((x) & (~BITS_EXEC_TIME_TH_8822C))
#define BIT_GET_EXEC_TIME_TH_8822C(x) \
(((x) >> BIT_SHIFT_EXEC_TIME_TH_8822C) & BIT_MASK_EXEC_TIME_TH_8822C)
#define BIT_SET_EXEC_TIME_TH_8822C(x, v) \
(BIT_CLEAR_EXEC_TIME_TH_8822C(x) | BIT_EXEC_TIME_TH_8822C(v))
/* 2 REG_FT2IMR_8822C */
#define BIT_FS_CLI3_RX_UAPSDMD1_EN_8822C BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_EN_8822C BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_EN_8822C BIT(29)
#define BIT_FS_CLI3_EOSP_INT_EN_8822C BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_EN_8822C BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_EN_8822C BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_EN_8822C BIT(25)
#define BIT_FS_CLI2_EOSP_INT_EN_8822C BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_EN_8822C BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_EN_8822C BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_EN_8822C BIT(21)
#define BIT_FS_CLI1_EOSP_INT_EN_8822C BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_EN_8822C BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_EN_8822C BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_EN_8822C BIT(17)
#define BIT_FS_CLI0_EOSP_INT_EN_8822C BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_EN_8822C BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_EN_8822C BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_EN_8822C BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_EN_8822C BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_EN_8822C BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_EN_8822C BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_EN_8822C BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_EN_8822C BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_EN_8822C BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_EN_8822C BIT(0)
/* 2 REG_FT2ISR_8822C */
#define BIT_FS_CLI3_RX_UAPSDMD1_INT_8822C BIT(31)
#define BIT_FS_CLI3_RX_UAPSDMD0_INT_8822C BIT(30)
#define BIT_FS_CLI3_TRIGGER_PKT_INT_8822C BIT(29)
#define BIT_FS_CLI3_EOSP_INT_8822C BIT(28)
#define BIT_FS_CLI2_RX_UAPSDMD1_INT_8822C BIT(27)
#define BIT_FS_CLI2_RX_UAPSDMD0_INT_8822C BIT(26)
#define BIT_FS_CLI2_TRIGGER_PKT_INT_8822C BIT(25)
#define BIT_FS_CLI2_EOSP_INT_8822C BIT(24)
#define BIT_FS_CLI1_RX_UAPSDMD1_INT_8822C BIT(23)
#define BIT_FS_CLI1_RX_UAPSDMD0_INT_8822C BIT(22)
#define BIT_FS_CLI1_TRIGGER_PKT_INT_8822C BIT(21)
#define BIT_FS_CLI1_EOSP_INT_8822C BIT(20)
#define BIT_FS_CLI0_RX_UAPSDMD1_INT_8822C BIT(19)
#define BIT_FS_CLI0_RX_UAPSDMD0_INT_8822C BIT(18)
#define BIT_FS_CLI0_TRIGGER_PKT_INT_8822C BIT(17)
#define BIT_FS_CLI0_EOSP_INT_8822C BIT(16)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P2_INT_8822C BIT(9)
#define BIT_FS_TSF_BIT32_TOGGLE_P2P1_INT_8822C BIT(8)
#define BIT_FS_CLI3_TX_NULL1_INT_8822C BIT(7)
#define BIT_FS_CLI3_TX_NULL0_INT_8822C BIT(6)
#define BIT_FS_CLI2_TX_NULL1_INT_8822C BIT(5)
#define BIT_FS_CLI2_TX_NULL0_INT_8822C BIT(4)
#define BIT_FS_CLI1_TX_NULL1_INT_8822C BIT(3)
#define BIT_FS_CLI1_TX_NULL0_INT_8822C BIT(2)
#define BIT_FS_CLI0_TX_NULL1_INT_8822C BIT(1)
#define BIT_FS_CLI0_TX_NULL0_INT_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_MSG2_8822C */
#define BIT_SHIFT_FW_MSG2_8822C 0
#define BIT_MASK_FW_MSG2_8822C 0xffffffffL
#define BIT_FW_MSG2_8822C(x) \
(((x) & BIT_MASK_FW_MSG2_8822C) << BIT_SHIFT_FW_MSG2_8822C)
#define BITS_FW_MSG2_8822C (BIT_MASK_FW_MSG2_8822C << BIT_SHIFT_FW_MSG2_8822C)
#define BIT_CLEAR_FW_MSG2_8822C(x) ((x) & (~BITS_FW_MSG2_8822C))
#define BIT_GET_FW_MSG2_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG2_8822C) & BIT_MASK_FW_MSG2_8822C)
#define BIT_SET_FW_MSG2_8822C(x, v) \
(BIT_CLEAR_FW_MSG2_8822C(x) | BIT_FW_MSG2_8822C(v))
/* 2 REG_MSG3_8822C */
#define BIT_SHIFT_FW_MSG3_8822C 0
#define BIT_MASK_FW_MSG3_8822C 0xffffffffL
#define BIT_FW_MSG3_8822C(x) \
(((x) & BIT_MASK_FW_MSG3_8822C) << BIT_SHIFT_FW_MSG3_8822C)
#define BITS_FW_MSG3_8822C (BIT_MASK_FW_MSG3_8822C << BIT_SHIFT_FW_MSG3_8822C)
#define BIT_CLEAR_FW_MSG3_8822C(x) ((x) & (~BITS_FW_MSG3_8822C))
#define BIT_GET_FW_MSG3_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG3_8822C) & BIT_MASK_FW_MSG3_8822C)
#define BIT_SET_FW_MSG3_8822C(x, v) \
(BIT_CLEAR_FW_MSG3_8822C(x) | BIT_FW_MSG3_8822C(v))
/* 2 REG_MSG4_8822C */
#define BIT_SHIFT_FW_MSG4_8822C 0
#define BIT_MASK_FW_MSG4_8822C 0xffffffffL
#define BIT_FW_MSG4_8822C(x) \
(((x) & BIT_MASK_FW_MSG4_8822C) << BIT_SHIFT_FW_MSG4_8822C)
#define BITS_FW_MSG4_8822C (BIT_MASK_FW_MSG4_8822C << BIT_SHIFT_FW_MSG4_8822C)
#define BIT_CLEAR_FW_MSG4_8822C(x) ((x) & (~BITS_FW_MSG4_8822C))
#define BIT_GET_FW_MSG4_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG4_8822C) & BIT_MASK_FW_MSG4_8822C)
#define BIT_SET_FW_MSG4_8822C(x, v) \
(BIT_CLEAR_FW_MSG4_8822C(x) | BIT_FW_MSG4_8822C(v))
/* 2 REG_MSG5_8822C */
#define BIT_SHIFT_FW_MSG5_8822C 0
#define BIT_MASK_FW_MSG5_8822C 0xffffffffL
#define BIT_FW_MSG5_8822C(x) \
(((x) & BIT_MASK_FW_MSG5_8822C) << BIT_SHIFT_FW_MSG5_8822C)
#define BITS_FW_MSG5_8822C (BIT_MASK_FW_MSG5_8822C << BIT_SHIFT_FW_MSG5_8822C)
#define BIT_CLEAR_FW_MSG5_8822C(x) ((x) & (~BITS_FW_MSG5_8822C))
#define BIT_GET_FW_MSG5_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG5_8822C) & BIT_MASK_FW_MSG5_8822C)
#define BIT_SET_FW_MSG5_8822C(x, v) \
(BIT_CLEAR_FW_MSG5_8822C(x) | BIT_FW_MSG5_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_FIFOPAGE_CTRL_1_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822C 16
#define BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822C 0xff
#define BIT_TX_OQT_HE_FREE_SPACE_V1_8822C(x) \
(((x) & BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822C) \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822C)
#define BITS_TX_OQT_HE_FREE_SPACE_V1_8822C \
(BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822C \
<< BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822C)
#define BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8822C(x) \
((x) & (~BITS_TX_OQT_HE_FREE_SPACE_V1_8822C))
#define BIT_GET_TX_OQT_HE_FREE_SPACE_V1_8822C(x) \
(((x) >> BIT_SHIFT_TX_OQT_HE_FREE_SPACE_V1_8822C) & \
BIT_MASK_TX_OQT_HE_FREE_SPACE_V1_8822C)
#define BIT_SET_TX_OQT_HE_FREE_SPACE_V1_8822C(x, v) \
(BIT_CLEAR_TX_OQT_HE_FREE_SPACE_V1_8822C(x) | \
BIT_TX_OQT_HE_FREE_SPACE_V1_8822C(v))
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822C 0
#define BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822C 0xff
#define BIT_TX_OQT_NL_FREE_SPACE_V1_8822C(x) \
(((x) & BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822C) \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822C)
#define BITS_TX_OQT_NL_FREE_SPACE_V1_8822C \
(BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822C \
<< BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822C)
#define BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8822C(x) \
((x) & (~BITS_TX_OQT_NL_FREE_SPACE_V1_8822C))
#define BIT_GET_TX_OQT_NL_FREE_SPACE_V1_8822C(x) \
(((x) >> BIT_SHIFT_TX_OQT_NL_FREE_SPACE_V1_8822C) & \
BIT_MASK_TX_OQT_NL_FREE_SPACE_V1_8822C)
#define BIT_SET_TX_OQT_NL_FREE_SPACE_V1_8822C(x, v) \
(BIT_CLEAR_TX_OQT_NL_FREE_SPACE_V1_8822C(x) | \
BIT_TX_OQT_NL_FREE_SPACE_V1_8822C(v))
/* 2 REG_FIFOPAGE_CTRL_2_8822C */
#define BIT_BCN_VALID_1_V1_8822C BIT(31)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_BCN_HEAD_1_V1_8822C 16
#define BIT_MASK_BCN_HEAD_1_V1_8822C 0xfff
#define BIT_BCN_HEAD_1_V1_8822C(x) \
(((x) & BIT_MASK_BCN_HEAD_1_V1_8822C) << BIT_SHIFT_BCN_HEAD_1_V1_8822C)
#define BITS_BCN_HEAD_1_V1_8822C \
(BIT_MASK_BCN_HEAD_1_V1_8822C << BIT_SHIFT_BCN_HEAD_1_V1_8822C)
#define BIT_CLEAR_BCN_HEAD_1_V1_8822C(x) ((x) & (~BITS_BCN_HEAD_1_V1_8822C))
#define BIT_GET_BCN_HEAD_1_V1_8822C(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_1_V1_8822C) & BIT_MASK_BCN_HEAD_1_V1_8822C)
#define BIT_SET_BCN_HEAD_1_V1_8822C(x, v) \
(BIT_CLEAR_BCN_HEAD_1_V1_8822C(x) | BIT_BCN_HEAD_1_V1_8822C(v))
#define BIT_BCN_VALID_V1_8822C BIT(15)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_BCN_HEAD_V1_8822C 0
#define BIT_MASK_BCN_HEAD_V1_8822C 0xfff
#define BIT_BCN_HEAD_V1_8822C(x) \
(((x) & BIT_MASK_BCN_HEAD_V1_8822C) << BIT_SHIFT_BCN_HEAD_V1_8822C)
#define BITS_BCN_HEAD_V1_8822C \
(BIT_MASK_BCN_HEAD_V1_8822C << BIT_SHIFT_BCN_HEAD_V1_8822C)
#define BIT_CLEAR_BCN_HEAD_V1_8822C(x) ((x) & (~BITS_BCN_HEAD_V1_8822C))
#define BIT_GET_BCN_HEAD_V1_8822C(x) \
(((x) >> BIT_SHIFT_BCN_HEAD_V1_8822C) & BIT_MASK_BCN_HEAD_V1_8822C)
#define BIT_SET_BCN_HEAD_V1_8822C(x, v) \
(BIT_CLEAR_BCN_HEAD_V1_8822C(x) | BIT_BCN_HEAD_V1_8822C(v))
/* 2 REG_AUTO_LLT_V1_8822C */
#define BIT_SHIFT_MAX_TX_PKT_V1_8822C 24
#define BIT_MASK_MAX_TX_PKT_V1_8822C 0xff
#define BIT_MAX_TX_PKT_V1_8822C(x) \
(((x) & BIT_MASK_MAX_TX_PKT_V1_8822C) << BIT_SHIFT_MAX_TX_PKT_V1_8822C)
#define BITS_MAX_TX_PKT_V1_8822C \
(BIT_MASK_MAX_TX_PKT_V1_8822C << BIT_SHIFT_MAX_TX_PKT_V1_8822C)
#define BIT_CLEAR_MAX_TX_PKT_V1_8822C(x) ((x) & (~BITS_MAX_TX_PKT_V1_8822C))
#define BIT_GET_MAX_TX_PKT_V1_8822C(x) \
(((x) >> BIT_SHIFT_MAX_TX_PKT_V1_8822C) & BIT_MASK_MAX_TX_PKT_V1_8822C)
#define BIT_SET_MAX_TX_PKT_V1_8822C(x, v) \
(BIT_CLEAR_MAX_TX_PKT_V1_8822C(x) | BIT_MAX_TX_PKT_V1_8822C(v))
#define BIT_TDE_ERROR_STOP_V1_8822C BIT(23)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_LLT_FREE_PAGE_V2_8822C 8
#define BIT_MASK_LLT_FREE_PAGE_V2_8822C 0xfff
#define BIT_LLT_FREE_PAGE_V2_8822C(x) \
(((x) & BIT_MASK_LLT_FREE_PAGE_V2_8822C) \
<< BIT_SHIFT_LLT_FREE_PAGE_V2_8822C)
#define BITS_LLT_FREE_PAGE_V2_8822C \
(BIT_MASK_LLT_FREE_PAGE_V2_8822C << BIT_SHIFT_LLT_FREE_PAGE_V2_8822C)
#define BIT_CLEAR_LLT_FREE_PAGE_V2_8822C(x) \
((x) & (~BITS_LLT_FREE_PAGE_V2_8822C))
#define BIT_GET_LLT_FREE_PAGE_V2_8822C(x) \
(((x) >> BIT_SHIFT_LLT_FREE_PAGE_V2_8822C) & \
BIT_MASK_LLT_FREE_PAGE_V2_8822C)
#define BIT_SET_LLT_FREE_PAGE_V2_8822C(x, v) \
(BIT_CLEAR_LLT_FREE_PAGE_V2_8822C(x) | BIT_LLT_FREE_PAGE_V2_8822C(v))
#define BIT_SHIFT_BLK_DESC_NUM_8822C 4
#define BIT_MASK_BLK_DESC_NUM_8822C 0xf
#define BIT_BLK_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_BLK_DESC_NUM_8822C) << BIT_SHIFT_BLK_DESC_NUM_8822C)
#define BITS_BLK_DESC_NUM_8822C \
(BIT_MASK_BLK_DESC_NUM_8822C << BIT_SHIFT_BLK_DESC_NUM_8822C)
#define BIT_CLEAR_BLK_DESC_NUM_8822C(x) ((x) & (~BITS_BLK_DESC_NUM_8822C))
#define BIT_GET_BLK_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_BLK_DESC_NUM_8822C) & BIT_MASK_BLK_DESC_NUM_8822C)
#define BIT_SET_BLK_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_BLK_DESC_NUM_8822C(x) | BIT_BLK_DESC_NUM_8822C(v))
#define BIT_R_BCN_HEAD_SEL_8822C BIT(3)
#define BIT_R_EN_BCN_SW_HEAD_SEL_8822C BIT(2)
#define BIT_LLT_DBG_SEL_8822C BIT(1)
#define BIT_AUTO_INIT_LLT_V1_8822C BIT(0)
/* 2 REG_TXDMA_OFFSET_CHK_8822C */
#define BIT_EM_CHKSUM_FIN_8822C BIT(31)
#define BIT_EMN_PCIE_DMA_MOD_8822C BIT(30)
#define BIT_EN_TXQUE_CLR_8822C BIT(29)
#define BIT_EN_PCIE_FIFO_MODE_8822C BIT(28)
#define BIT_SHIFT_PG_UNDER_TH_V1_8822C 16
#define BIT_MASK_PG_UNDER_TH_V1_8822C 0xfff
#define BIT_PG_UNDER_TH_V1_8822C(x) \
(((x) & BIT_MASK_PG_UNDER_TH_V1_8822C) \
<< BIT_SHIFT_PG_UNDER_TH_V1_8822C)
#define BITS_PG_UNDER_TH_V1_8822C \
(BIT_MASK_PG_UNDER_TH_V1_8822C << BIT_SHIFT_PG_UNDER_TH_V1_8822C)
#define BIT_CLEAR_PG_UNDER_TH_V1_8822C(x) ((x) & (~BITS_PG_UNDER_TH_V1_8822C))
#define BIT_GET_PG_UNDER_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_PG_UNDER_TH_V1_8822C) & \
BIT_MASK_PG_UNDER_TH_V1_8822C)
#define BIT_SET_PG_UNDER_TH_V1_8822C(x, v) \
(BIT_CLEAR_PG_UNDER_TH_V1_8822C(x) | BIT_PG_UNDER_TH_V1_8822C(v))
#define BIT_R_EN_RESET_RESTORE_H2C_8822C BIT(15)
#define BIT_SDIO_TDE_FINISH_8822C BIT(14)
#define BIT_SDIO_TXDESC_CHKSUM_EN_8822C BIT(13)
#define BIT_RST_RDPTR_8822C BIT(12)
#define BIT_RST_WRPTR_8822C BIT(11)
#define BIT_CHK_PG_TH_EN_8822C BIT(10)
#define BIT_DROP_DATA_EN_8822C BIT(9)
#define BIT_CHECK_OFFSET_EN_8822C BIT(8)
#define BIT_SHIFT_CHECK_OFFSET_8822C 0
#define BIT_MASK_CHECK_OFFSET_8822C 0xff
#define BIT_CHECK_OFFSET_8822C(x) \
(((x) & BIT_MASK_CHECK_OFFSET_8822C) << BIT_SHIFT_CHECK_OFFSET_8822C)
#define BITS_CHECK_OFFSET_8822C \
(BIT_MASK_CHECK_OFFSET_8822C << BIT_SHIFT_CHECK_OFFSET_8822C)
#define BIT_CLEAR_CHECK_OFFSET_8822C(x) ((x) & (~BITS_CHECK_OFFSET_8822C))
#define BIT_GET_CHECK_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_CHECK_OFFSET_8822C) & BIT_MASK_CHECK_OFFSET_8822C)
#define BIT_SET_CHECK_OFFSET_8822C(x, v) \
(BIT_CLEAR_CHECK_OFFSET_8822C(x) | BIT_CHECK_OFFSET_8822C(v))
/* 2 REG_TXDMA_STATUS_8822C */
#define BIT_TXPKTBUF_REQ_ERR_8822C BIT(18)
#define BIT_HI_OQT_UDN_8822C BIT(17)
#define BIT_HI_OQT_OVF_8822C BIT(16)
#define BIT_PAYLOAD_CHKSUM_ERR_8822C BIT(15)
#define BIT_PAYLOAD_UDN_8822C BIT(14)
#define BIT_PAYLOAD_OVF_8822C BIT(13)
#define BIT_DSC_CHKSUM_FAIL_8822C BIT(12)
#define BIT_UNKNOWN_QSEL_8822C BIT(11)
#define BIT_EP_QSEL_DIFF_8822C BIT(10)
#define BIT_TX_OFFS_UNMATCH_8822C BIT(9)
#define BIT_TXOQT_UDN_8822C BIT(8)
#define BIT_TXOQT_OVF_8822C BIT(7)
#define BIT_TXDMA_SFF_UDN_8822C BIT(6)
#define BIT_TXDMA_SFF_OVF_8822C BIT(5)
#define BIT_LLT_NULL_PG_8822C BIT(4)
#define BIT_PAGE_UDN_8822C BIT(3)
#define BIT_PAGE_OVF_8822C BIT(2)
#define BIT_TXFF_PG_UDN_8822C BIT(1)
#define BIT_TXFF_PG_OVF_8822C BIT(0)
/* 2 REG_TX_DMA_DBG_8822C */
/* 2 REG_TQPNT1_8822C */
#define BIT_HPQ_INT_EN_8822C BIT(31)
#define BIT_SHIFT_HPQ_HIGH_TH_V1_8822C 16
#define BIT_MASK_HPQ_HIGH_TH_V1_8822C 0xfff
#define BIT_HPQ_HIGH_TH_V1_8822C(x) \
(((x) & BIT_MASK_HPQ_HIGH_TH_V1_8822C) \
<< BIT_SHIFT_HPQ_HIGH_TH_V1_8822C)
#define BITS_HPQ_HIGH_TH_V1_8822C \
(BIT_MASK_HPQ_HIGH_TH_V1_8822C << BIT_SHIFT_HPQ_HIGH_TH_V1_8822C)
#define BIT_CLEAR_HPQ_HIGH_TH_V1_8822C(x) ((x) & (~BITS_HPQ_HIGH_TH_V1_8822C))
#define BIT_GET_HPQ_HIGH_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_HPQ_HIGH_TH_V1_8822C) & \
BIT_MASK_HPQ_HIGH_TH_V1_8822C)
#define BIT_SET_HPQ_HIGH_TH_V1_8822C(x, v) \
(BIT_CLEAR_HPQ_HIGH_TH_V1_8822C(x) | BIT_HPQ_HIGH_TH_V1_8822C(v))
#define BIT_SHIFT_HPQ_LOW_TH_V1_8822C 0
#define BIT_MASK_HPQ_LOW_TH_V1_8822C 0xfff
#define BIT_HPQ_LOW_TH_V1_8822C(x) \
(((x) & BIT_MASK_HPQ_LOW_TH_V1_8822C) << BIT_SHIFT_HPQ_LOW_TH_V1_8822C)
#define BITS_HPQ_LOW_TH_V1_8822C \
(BIT_MASK_HPQ_LOW_TH_V1_8822C << BIT_SHIFT_HPQ_LOW_TH_V1_8822C)
#define BIT_CLEAR_HPQ_LOW_TH_V1_8822C(x) ((x) & (~BITS_HPQ_LOW_TH_V1_8822C))
#define BIT_GET_HPQ_LOW_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_HPQ_LOW_TH_V1_8822C) & BIT_MASK_HPQ_LOW_TH_V1_8822C)
#define BIT_SET_HPQ_LOW_TH_V1_8822C(x, v) \
(BIT_CLEAR_HPQ_LOW_TH_V1_8822C(x) | BIT_HPQ_LOW_TH_V1_8822C(v))
/* 2 REG_TQPNT2_8822C */
#define BIT_NPQ_INT_EN_8822C BIT(31)
#define BIT_SHIFT_NPQ_HIGH_TH_V1_8822C 16
#define BIT_MASK_NPQ_HIGH_TH_V1_8822C 0xfff
#define BIT_NPQ_HIGH_TH_V1_8822C(x) \
(((x) & BIT_MASK_NPQ_HIGH_TH_V1_8822C) \
<< BIT_SHIFT_NPQ_HIGH_TH_V1_8822C)
#define BITS_NPQ_HIGH_TH_V1_8822C \
(BIT_MASK_NPQ_HIGH_TH_V1_8822C << BIT_SHIFT_NPQ_HIGH_TH_V1_8822C)
#define BIT_CLEAR_NPQ_HIGH_TH_V1_8822C(x) ((x) & (~BITS_NPQ_HIGH_TH_V1_8822C))
#define BIT_GET_NPQ_HIGH_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_NPQ_HIGH_TH_V1_8822C) & \
BIT_MASK_NPQ_HIGH_TH_V1_8822C)
#define BIT_SET_NPQ_HIGH_TH_V1_8822C(x, v) \
(BIT_CLEAR_NPQ_HIGH_TH_V1_8822C(x) | BIT_NPQ_HIGH_TH_V1_8822C(v))
#define BIT_SHIFT_NPQ_LOW_TH_V1_8822C 0
#define BIT_MASK_NPQ_LOW_TH_V1_8822C 0xfff
#define BIT_NPQ_LOW_TH_V1_8822C(x) \
(((x) & BIT_MASK_NPQ_LOW_TH_V1_8822C) << BIT_SHIFT_NPQ_LOW_TH_V1_8822C)
#define BITS_NPQ_LOW_TH_V1_8822C \
(BIT_MASK_NPQ_LOW_TH_V1_8822C << BIT_SHIFT_NPQ_LOW_TH_V1_8822C)
#define BIT_CLEAR_NPQ_LOW_TH_V1_8822C(x) ((x) & (~BITS_NPQ_LOW_TH_V1_8822C))
#define BIT_GET_NPQ_LOW_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_NPQ_LOW_TH_V1_8822C) & BIT_MASK_NPQ_LOW_TH_V1_8822C)
#define BIT_SET_NPQ_LOW_TH_V1_8822C(x, v) \
(BIT_CLEAR_NPQ_LOW_TH_V1_8822C(x) | BIT_NPQ_LOW_TH_V1_8822C(v))
/* 2 REG_TQPNT3_8822C */
#define BIT_LPQ_INT_EN_8822C BIT(31)
#define BIT_SHIFT_LPQ_HIGH_TH_V1_8822C 16
#define BIT_MASK_LPQ_HIGH_TH_V1_8822C 0xfff
#define BIT_LPQ_HIGH_TH_V1_8822C(x) \
(((x) & BIT_MASK_LPQ_HIGH_TH_V1_8822C) \
<< BIT_SHIFT_LPQ_HIGH_TH_V1_8822C)
#define BITS_LPQ_HIGH_TH_V1_8822C \
(BIT_MASK_LPQ_HIGH_TH_V1_8822C << BIT_SHIFT_LPQ_HIGH_TH_V1_8822C)
#define BIT_CLEAR_LPQ_HIGH_TH_V1_8822C(x) ((x) & (~BITS_LPQ_HIGH_TH_V1_8822C))
#define BIT_GET_LPQ_HIGH_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_LPQ_HIGH_TH_V1_8822C) & \
BIT_MASK_LPQ_HIGH_TH_V1_8822C)
#define BIT_SET_LPQ_HIGH_TH_V1_8822C(x, v) \
(BIT_CLEAR_LPQ_HIGH_TH_V1_8822C(x) | BIT_LPQ_HIGH_TH_V1_8822C(v))
#define BIT_SHIFT_LPQ_LOW_TH_V1_8822C 0
#define BIT_MASK_LPQ_LOW_TH_V1_8822C 0xfff
#define BIT_LPQ_LOW_TH_V1_8822C(x) \
(((x) & BIT_MASK_LPQ_LOW_TH_V1_8822C) << BIT_SHIFT_LPQ_LOW_TH_V1_8822C)
#define BITS_LPQ_LOW_TH_V1_8822C \
(BIT_MASK_LPQ_LOW_TH_V1_8822C << BIT_SHIFT_LPQ_LOW_TH_V1_8822C)
#define BIT_CLEAR_LPQ_LOW_TH_V1_8822C(x) ((x) & (~BITS_LPQ_LOW_TH_V1_8822C))
#define BIT_GET_LPQ_LOW_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_LPQ_LOW_TH_V1_8822C) & BIT_MASK_LPQ_LOW_TH_V1_8822C)
#define BIT_SET_LPQ_LOW_TH_V1_8822C(x, v) \
(BIT_CLEAR_LPQ_LOW_TH_V1_8822C(x) | BIT_LPQ_LOW_TH_V1_8822C(v))
/* 2 REG_TQPNT4_8822C */
#define BIT_EXQ_INT_EN_8822C BIT(31)
#define BIT_SHIFT_EXQ_HIGH_TH_V1_8822C 16
#define BIT_MASK_EXQ_HIGH_TH_V1_8822C 0xfff
#define BIT_EXQ_HIGH_TH_V1_8822C(x) \
(((x) & BIT_MASK_EXQ_HIGH_TH_V1_8822C) \
<< BIT_SHIFT_EXQ_HIGH_TH_V1_8822C)
#define BITS_EXQ_HIGH_TH_V1_8822C \
(BIT_MASK_EXQ_HIGH_TH_V1_8822C << BIT_SHIFT_EXQ_HIGH_TH_V1_8822C)
#define BIT_CLEAR_EXQ_HIGH_TH_V1_8822C(x) ((x) & (~BITS_EXQ_HIGH_TH_V1_8822C))
#define BIT_GET_EXQ_HIGH_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_EXQ_HIGH_TH_V1_8822C) & \
BIT_MASK_EXQ_HIGH_TH_V1_8822C)
#define BIT_SET_EXQ_HIGH_TH_V1_8822C(x, v) \
(BIT_CLEAR_EXQ_HIGH_TH_V1_8822C(x) | BIT_EXQ_HIGH_TH_V1_8822C(v))
#define BIT_SHIFT_EXQ_LOW_TH_V1_8822C 0
#define BIT_MASK_EXQ_LOW_TH_V1_8822C 0xfff
#define BIT_EXQ_LOW_TH_V1_8822C(x) \
(((x) & BIT_MASK_EXQ_LOW_TH_V1_8822C) << BIT_SHIFT_EXQ_LOW_TH_V1_8822C)
#define BITS_EXQ_LOW_TH_V1_8822C \
(BIT_MASK_EXQ_LOW_TH_V1_8822C << BIT_SHIFT_EXQ_LOW_TH_V1_8822C)
#define BIT_CLEAR_EXQ_LOW_TH_V1_8822C(x) ((x) & (~BITS_EXQ_LOW_TH_V1_8822C))
#define BIT_GET_EXQ_LOW_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_EXQ_LOW_TH_V1_8822C) & BIT_MASK_EXQ_LOW_TH_V1_8822C)
#define BIT_SET_EXQ_LOW_TH_V1_8822C(x, v) \
(BIT_CLEAR_EXQ_LOW_TH_V1_8822C(x) | BIT_EXQ_LOW_TH_V1_8822C(v))
/* 2 REG_RQPN_CTRL_1_8822C */
#define BIT_SHIFT_TXPKTNUM_H_V2_8822C 16
#define BIT_MASK_TXPKTNUM_H_V2_8822C 0xfff
#define BIT_TXPKTNUM_H_V2_8822C(x) \
(((x) & BIT_MASK_TXPKTNUM_H_V2_8822C) << BIT_SHIFT_TXPKTNUM_H_V2_8822C)
#define BITS_TXPKTNUM_H_V2_8822C \
(BIT_MASK_TXPKTNUM_H_V2_8822C << BIT_SHIFT_TXPKTNUM_H_V2_8822C)
#define BIT_CLEAR_TXPKTNUM_H_V2_8822C(x) ((x) & (~BITS_TXPKTNUM_H_V2_8822C))
#define BIT_GET_TXPKTNUM_H_V2_8822C(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_H_V2_8822C) & BIT_MASK_TXPKTNUM_H_V2_8822C)
#define BIT_SET_TXPKTNUM_H_V2_8822C(x, v) \
(BIT_CLEAR_TXPKTNUM_H_V2_8822C(x) | BIT_TXPKTNUM_H_V2_8822C(v))
#define BIT_SHIFT_TXPKTNUM_V3_8822C 0
#define BIT_MASK_TXPKTNUM_V3_8822C 0xfff
#define BIT_TXPKTNUM_V3_8822C(x) \
(((x) & BIT_MASK_TXPKTNUM_V3_8822C) << BIT_SHIFT_TXPKTNUM_V3_8822C)
#define BITS_TXPKTNUM_V3_8822C \
(BIT_MASK_TXPKTNUM_V3_8822C << BIT_SHIFT_TXPKTNUM_V3_8822C)
#define BIT_CLEAR_TXPKTNUM_V3_8822C(x) ((x) & (~BITS_TXPKTNUM_V3_8822C))
#define BIT_GET_TXPKTNUM_V3_8822C(x) \
(((x) >> BIT_SHIFT_TXPKTNUM_V3_8822C) & BIT_MASK_TXPKTNUM_V3_8822C)
#define BIT_SET_TXPKTNUM_V3_8822C(x, v) \
(BIT_CLEAR_TXPKTNUM_V3_8822C(x) | BIT_TXPKTNUM_V3_8822C(v))
/* 2 REG_RQPN_CTRL_2_8822C */
#define BIT_LD_RQPN_8822C BIT(31)
#define BIT_EXQ_PUBLIC_DIS_V1_8822C BIT(19)
#define BIT_NPQ_PUBLIC_DIS_V1_8822C BIT(18)
#define BIT_LPQ_PUBLIC_DIS_V1_8822C BIT(17)
#define BIT_HPQ_PUBLIC_DIS_V1_8822C BIT(16)
#define BIT_SDIO_TXAGG_ALIGN_ADJUST_EN_8822C BIT(15)
#define BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8822C 0
#define BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8822C 0xfff
#define BIT_SDIO_TXAGG_ALIGN_SIZE_8822C(x) \
(((x) & BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8822C) \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8822C)
#define BITS_SDIO_TXAGG_ALIGN_SIZE_8822C \
(BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8822C \
<< BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8822C)
#define BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_8822C(x) \
((x) & (~BITS_SDIO_TXAGG_ALIGN_SIZE_8822C))
#define BIT_GET_SDIO_TXAGG_ALIGN_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_TXAGG_ALIGN_SIZE_8822C) & \
BIT_MASK_SDIO_TXAGG_ALIGN_SIZE_8822C)
#define BIT_SET_SDIO_TXAGG_ALIGN_SIZE_8822C(x, v) \
(BIT_CLEAR_SDIO_TXAGG_ALIGN_SIZE_8822C(x) | \
BIT_SDIO_TXAGG_ALIGN_SIZE_8822C(v))
/* 2 REG_FIFOPAGE_INFO_1_8822C */
#define BIT_SHIFT_HPQ_AVAL_PG_V1_8822C 16
#define BIT_MASK_HPQ_AVAL_PG_V1_8822C 0xfff
#define BIT_HPQ_AVAL_PG_V1_8822C(x) \
(((x) & BIT_MASK_HPQ_AVAL_PG_V1_8822C) \
<< BIT_SHIFT_HPQ_AVAL_PG_V1_8822C)
#define BITS_HPQ_AVAL_PG_V1_8822C \
(BIT_MASK_HPQ_AVAL_PG_V1_8822C << BIT_SHIFT_HPQ_AVAL_PG_V1_8822C)
#define BIT_CLEAR_HPQ_AVAL_PG_V1_8822C(x) ((x) & (~BITS_HPQ_AVAL_PG_V1_8822C))
#define BIT_GET_HPQ_AVAL_PG_V1_8822C(x) \
(((x) >> BIT_SHIFT_HPQ_AVAL_PG_V1_8822C) & \
BIT_MASK_HPQ_AVAL_PG_V1_8822C)
#define BIT_SET_HPQ_AVAL_PG_V1_8822C(x, v) \
(BIT_CLEAR_HPQ_AVAL_PG_V1_8822C(x) | BIT_HPQ_AVAL_PG_V1_8822C(v))
#define BIT_SHIFT_HPQ_V1_8822C 0
#define BIT_MASK_HPQ_V1_8822C 0xfff
#define BIT_HPQ_V1_8822C(x) \
(((x) & BIT_MASK_HPQ_V1_8822C) << BIT_SHIFT_HPQ_V1_8822C)
#define BITS_HPQ_V1_8822C (BIT_MASK_HPQ_V1_8822C << BIT_SHIFT_HPQ_V1_8822C)
#define BIT_CLEAR_HPQ_V1_8822C(x) ((x) & (~BITS_HPQ_V1_8822C))
#define BIT_GET_HPQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_HPQ_V1_8822C) & BIT_MASK_HPQ_V1_8822C)
#define BIT_SET_HPQ_V1_8822C(x, v) \
(BIT_CLEAR_HPQ_V1_8822C(x) | BIT_HPQ_V1_8822C(v))
/* 2 REG_FIFOPAGE_INFO_2_8822C */
#define BIT_SHIFT_LPQ_AVAL_PG_V1_8822C 16
#define BIT_MASK_LPQ_AVAL_PG_V1_8822C 0xfff
#define BIT_LPQ_AVAL_PG_V1_8822C(x) \
(((x) & BIT_MASK_LPQ_AVAL_PG_V1_8822C) \
<< BIT_SHIFT_LPQ_AVAL_PG_V1_8822C)
#define BITS_LPQ_AVAL_PG_V1_8822C \
(BIT_MASK_LPQ_AVAL_PG_V1_8822C << BIT_SHIFT_LPQ_AVAL_PG_V1_8822C)
#define BIT_CLEAR_LPQ_AVAL_PG_V1_8822C(x) ((x) & (~BITS_LPQ_AVAL_PG_V1_8822C))
#define BIT_GET_LPQ_AVAL_PG_V1_8822C(x) \
(((x) >> BIT_SHIFT_LPQ_AVAL_PG_V1_8822C) & \
BIT_MASK_LPQ_AVAL_PG_V1_8822C)
#define BIT_SET_LPQ_AVAL_PG_V1_8822C(x, v) \
(BIT_CLEAR_LPQ_AVAL_PG_V1_8822C(x) | BIT_LPQ_AVAL_PG_V1_8822C(v))
#define BIT_SHIFT_LPQ_V1_8822C 0
#define BIT_MASK_LPQ_V1_8822C 0xfff
#define BIT_LPQ_V1_8822C(x) \
(((x) & BIT_MASK_LPQ_V1_8822C) << BIT_SHIFT_LPQ_V1_8822C)
#define BITS_LPQ_V1_8822C (BIT_MASK_LPQ_V1_8822C << BIT_SHIFT_LPQ_V1_8822C)
#define BIT_CLEAR_LPQ_V1_8822C(x) ((x) & (~BITS_LPQ_V1_8822C))
#define BIT_GET_LPQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_LPQ_V1_8822C) & BIT_MASK_LPQ_V1_8822C)
#define BIT_SET_LPQ_V1_8822C(x, v) \
(BIT_CLEAR_LPQ_V1_8822C(x) | BIT_LPQ_V1_8822C(v))
/* 2 REG_FIFOPAGE_INFO_3_8822C */
#define BIT_SHIFT_NPQ_AVAL_PG_V1_8822C 16
#define BIT_MASK_NPQ_AVAL_PG_V1_8822C 0xfff
#define BIT_NPQ_AVAL_PG_V1_8822C(x) \
(((x) & BIT_MASK_NPQ_AVAL_PG_V1_8822C) \
<< BIT_SHIFT_NPQ_AVAL_PG_V1_8822C)
#define BITS_NPQ_AVAL_PG_V1_8822C \
(BIT_MASK_NPQ_AVAL_PG_V1_8822C << BIT_SHIFT_NPQ_AVAL_PG_V1_8822C)
#define BIT_CLEAR_NPQ_AVAL_PG_V1_8822C(x) ((x) & (~BITS_NPQ_AVAL_PG_V1_8822C))
#define BIT_GET_NPQ_AVAL_PG_V1_8822C(x) \
(((x) >> BIT_SHIFT_NPQ_AVAL_PG_V1_8822C) & \
BIT_MASK_NPQ_AVAL_PG_V1_8822C)
#define BIT_SET_NPQ_AVAL_PG_V1_8822C(x, v) \
(BIT_CLEAR_NPQ_AVAL_PG_V1_8822C(x) | BIT_NPQ_AVAL_PG_V1_8822C(v))
#define BIT_SHIFT_NPQ_V1_8822C 0
#define BIT_MASK_NPQ_V1_8822C 0xfff
#define BIT_NPQ_V1_8822C(x) \
(((x) & BIT_MASK_NPQ_V1_8822C) << BIT_SHIFT_NPQ_V1_8822C)
#define BITS_NPQ_V1_8822C (BIT_MASK_NPQ_V1_8822C << BIT_SHIFT_NPQ_V1_8822C)
#define BIT_CLEAR_NPQ_V1_8822C(x) ((x) & (~BITS_NPQ_V1_8822C))
#define BIT_GET_NPQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_NPQ_V1_8822C) & BIT_MASK_NPQ_V1_8822C)
#define BIT_SET_NPQ_V1_8822C(x, v) \
(BIT_CLEAR_NPQ_V1_8822C(x) | BIT_NPQ_V1_8822C(v))
/* 2 REG_FIFOPAGE_INFO_4_8822C */
#define BIT_SHIFT_EXQ_AVAL_PG_V1_8822C 16
#define BIT_MASK_EXQ_AVAL_PG_V1_8822C 0xfff
#define BIT_EXQ_AVAL_PG_V1_8822C(x) \
(((x) & BIT_MASK_EXQ_AVAL_PG_V1_8822C) \
<< BIT_SHIFT_EXQ_AVAL_PG_V1_8822C)
#define BITS_EXQ_AVAL_PG_V1_8822C \
(BIT_MASK_EXQ_AVAL_PG_V1_8822C << BIT_SHIFT_EXQ_AVAL_PG_V1_8822C)
#define BIT_CLEAR_EXQ_AVAL_PG_V1_8822C(x) ((x) & (~BITS_EXQ_AVAL_PG_V1_8822C))
#define BIT_GET_EXQ_AVAL_PG_V1_8822C(x) \
(((x) >> BIT_SHIFT_EXQ_AVAL_PG_V1_8822C) & \
BIT_MASK_EXQ_AVAL_PG_V1_8822C)
#define BIT_SET_EXQ_AVAL_PG_V1_8822C(x, v) \
(BIT_CLEAR_EXQ_AVAL_PG_V1_8822C(x) | BIT_EXQ_AVAL_PG_V1_8822C(v))
#define BIT_SHIFT_EXQ_V1_8822C 0
#define BIT_MASK_EXQ_V1_8822C 0xfff
#define BIT_EXQ_V1_8822C(x) \
(((x) & BIT_MASK_EXQ_V1_8822C) << BIT_SHIFT_EXQ_V1_8822C)
#define BITS_EXQ_V1_8822C (BIT_MASK_EXQ_V1_8822C << BIT_SHIFT_EXQ_V1_8822C)
#define BIT_CLEAR_EXQ_V1_8822C(x) ((x) & (~BITS_EXQ_V1_8822C))
#define BIT_GET_EXQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_EXQ_V1_8822C) & BIT_MASK_EXQ_V1_8822C)
#define BIT_SET_EXQ_V1_8822C(x, v) \
(BIT_CLEAR_EXQ_V1_8822C(x) | BIT_EXQ_V1_8822C(v))
/* 2 REG_FIFOPAGE_INFO_5_8822C */
#define BIT_SHIFT_PUBQ_AVAL_PG_V1_8822C 16
#define BIT_MASK_PUBQ_AVAL_PG_V1_8822C 0xfff
#define BIT_PUBQ_AVAL_PG_V1_8822C(x) \
(((x) & BIT_MASK_PUBQ_AVAL_PG_V1_8822C) \
<< BIT_SHIFT_PUBQ_AVAL_PG_V1_8822C)
#define BITS_PUBQ_AVAL_PG_V1_8822C \
(BIT_MASK_PUBQ_AVAL_PG_V1_8822C << BIT_SHIFT_PUBQ_AVAL_PG_V1_8822C)
#define BIT_CLEAR_PUBQ_AVAL_PG_V1_8822C(x) ((x) & (~BITS_PUBQ_AVAL_PG_V1_8822C))
#define BIT_GET_PUBQ_AVAL_PG_V1_8822C(x) \
(((x) >> BIT_SHIFT_PUBQ_AVAL_PG_V1_8822C) & \
BIT_MASK_PUBQ_AVAL_PG_V1_8822C)
#define BIT_SET_PUBQ_AVAL_PG_V1_8822C(x, v) \
(BIT_CLEAR_PUBQ_AVAL_PG_V1_8822C(x) | BIT_PUBQ_AVAL_PG_V1_8822C(v))
#define BIT_SHIFT_PUBQ_V1_8822C 0
#define BIT_MASK_PUBQ_V1_8822C 0xfff
#define BIT_PUBQ_V1_8822C(x) \
(((x) & BIT_MASK_PUBQ_V1_8822C) << BIT_SHIFT_PUBQ_V1_8822C)
#define BITS_PUBQ_V1_8822C (BIT_MASK_PUBQ_V1_8822C << BIT_SHIFT_PUBQ_V1_8822C)
#define BIT_CLEAR_PUBQ_V1_8822C(x) ((x) & (~BITS_PUBQ_V1_8822C))
#define BIT_GET_PUBQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_PUBQ_V1_8822C) & BIT_MASK_PUBQ_V1_8822C)
#define BIT_SET_PUBQ_V1_8822C(x, v) \
(BIT_CLEAR_PUBQ_V1_8822C(x) | BIT_PUBQ_V1_8822C(v))
/* 2 REG_H2C_HEAD_8822C */
#define BIT_SHIFT_H2C_HEAD_8822C 0
#define BIT_MASK_H2C_HEAD_8822C 0x3ffff
#define BIT_H2C_HEAD_8822C(x) \
(((x) & BIT_MASK_H2C_HEAD_8822C) << BIT_SHIFT_H2C_HEAD_8822C)
#define BITS_H2C_HEAD_8822C \
(BIT_MASK_H2C_HEAD_8822C << BIT_SHIFT_H2C_HEAD_8822C)
#define BIT_CLEAR_H2C_HEAD_8822C(x) ((x) & (~BITS_H2C_HEAD_8822C))
#define BIT_GET_H2C_HEAD_8822C(x) \
(((x) >> BIT_SHIFT_H2C_HEAD_8822C) & BIT_MASK_H2C_HEAD_8822C)
#define BIT_SET_H2C_HEAD_8822C(x, v) \
(BIT_CLEAR_H2C_HEAD_8822C(x) | BIT_H2C_HEAD_8822C(v))
/* 2 REG_H2C_TAIL_8822C */
#define BIT_SHIFT_H2C_TAIL_8822C 0
#define BIT_MASK_H2C_TAIL_8822C 0x3ffff
#define BIT_H2C_TAIL_8822C(x) \
(((x) & BIT_MASK_H2C_TAIL_8822C) << BIT_SHIFT_H2C_TAIL_8822C)
#define BITS_H2C_TAIL_8822C \
(BIT_MASK_H2C_TAIL_8822C << BIT_SHIFT_H2C_TAIL_8822C)
#define BIT_CLEAR_H2C_TAIL_8822C(x) ((x) & (~BITS_H2C_TAIL_8822C))
#define BIT_GET_H2C_TAIL_8822C(x) \
(((x) >> BIT_SHIFT_H2C_TAIL_8822C) & BIT_MASK_H2C_TAIL_8822C)
#define BIT_SET_H2C_TAIL_8822C(x, v) \
(BIT_CLEAR_H2C_TAIL_8822C(x) | BIT_H2C_TAIL_8822C(v))
/* 2 REG_H2C_READ_ADDR_8822C */
#define BIT_SHIFT_H2C_READ_ADDR_8822C 0
#define BIT_MASK_H2C_READ_ADDR_8822C 0x3ffff
#define BIT_H2C_READ_ADDR_8822C(x) \
(((x) & BIT_MASK_H2C_READ_ADDR_8822C) << BIT_SHIFT_H2C_READ_ADDR_8822C)
#define BITS_H2C_READ_ADDR_8822C \
(BIT_MASK_H2C_READ_ADDR_8822C << BIT_SHIFT_H2C_READ_ADDR_8822C)
#define BIT_CLEAR_H2C_READ_ADDR_8822C(x) ((x) & (~BITS_H2C_READ_ADDR_8822C))
#define BIT_GET_H2C_READ_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_H2C_READ_ADDR_8822C) & BIT_MASK_H2C_READ_ADDR_8822C)
#define BIT_SET_H2C_READ_ADDR_8822C(x, v) \
(BIT_CLEAR_H2C_READ_ADDR_8822C(x) | BIT_H2C_READ_ADDR_8822C(v))
/* 2 REG_H2C_WR_ADDR_8822C */
#define BIT_SHIFT_H2C_WR_ADDR_8822C 0
#define BIT_MASK_H2C_WR_ADDR_8822C 0x3ffff
#define BIT_H2C_WR_ADDR_8822C(x) \
(((x) & BIT_MASK_H2C_WR_ADDR_8822C) << BIT_SHIFT_H2C_WR_ADDR_8822C)
#define BITS_H2C_WR_ADDR_8822C \
(BIT_MASK_H2C_WR_ADDR_8822C << BIT_SHIFT_H2C_WR_ADDR_8822C)
#define BIT_CLEAR_H2C_WR_ADDR_8822C(x) ((x) & (~BITS_H2C_WR_ADDR_8822C))
#define BIT_GET_H2C_WR_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_H2C_WR_ADDR_8822C) & BIT_MASK_H2C_WR_ADDR_8822C)
#define BIT_SET_H2C_WR_ADDR_8822C(x, v) \
(BIT_CLEAR_H2C_WR_ADDR_8822C(x) | BIT_H2C_WR_ADDR_8822C(v))
/* 2 REG_H2C_INFO_8822C */
#define BIT_H2C_SPACE_VLD_8822C BIT(3)
#define BIT_H2C_WR_ADDR_RST_8822C BIT(2)
#define BIT_SHIFT_H2C_LEN_SEL_8822C 0
#define BIT_MASK_H2C_LEN_SEL_8822C 0x3
#define BIT_H2C_LEN_SEL_8822C(x) \
(((x) & BIT_MASK_H2C_LEN_SEL_8822C) << BIT_SHIFT_H2C_LEN_SEL_8822C)
#define BITS_H2C_LEN_SEL_8822C \
(BIT_MASK_H2C_LEN_SEL_8822C << BIT_SHIFT_H2C_LEN_SEL_8822C)
#define BIT_CLEAR_H2C_LEN_SEL_8822C(x) ((x) & (~BITS_H2C_LEN_SEL_8822C))
#define BIT_GET_H2C_LEN_SEL_8822C(x) \
(((x) >> BIT_SHIFT_H2C_LEN_SEL_8822C) & BIT_MASK_H2C_LEN_SEL_8822C)
#define BIT_SET_H2C_LEN_SEL_8822C(x, v) \
(BIT_CLEAR_H2C_LEN_SEL_8822C(x) | BIT_H2C_LEN_SEL_8822C(v))
/* 2 REG_PGSUB_CNT_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_RST_PGSUB_CNT_8822C BIT(1)
#define BIT_PGSUB_CNT_EN_8822C BIT(0)
/* 2 REG_PGSUB_H_8822C */
#define BIT_SHIFT_HPQ_PGSUB_CNT_8822C 0
#define BIT_MASK_HPQ_PGSUB_CNT_8822C 0xffffffffL
#define BIT_HPQ_PGSUB_CNT_8822C(x) \
(((x) & BIT_MASK_HPQ_PGSUB_CNT_8822C) << BIT_SHIFT_HPQ_PGSUB_CNT_8822C)
#define BITS_HPQ_PGSUB_CNT_8822C \
(BIT_MASK_HPQ_PGSUB_CNT_8822C << BIT_SHIFT_HPQ_PGSUB_CNT_8822C)
#define BIT_CLEAR_HPQ_PGSUB_CNT_8822C(x) ((x) & (~BITS_HPQ_PGSUB_CNT_8822C))
#define BIT_GET_HPQ_PGSUB_CNT_8822C(x) \
(((x) >> BIT_SHIFT_HPQ_PGSUB_CNT_8822C) & BIT_MASK_HPQ_PGSUB_CNT_8822C)
#define BIT_SET_HPQ_PGSUB_CNT_8822C(x, v) \
(BIT_CLEAR_HPQ_PGSUB_CNT_8822C(x) | BIT_HPQ_PGSUB_CNT_8822C(v))
/* 2 REG_PGSUB_N_8822C */
#define BIT_SHIFT_NPQ_PGSUB_CNT_8822C 0
#define BIT_MASK_NPQ_PGSUB_CNT_8822C 0xffffffffL
#define BIT_NPQ_PGSUB_CNT_8822C(x) \
(((x) & BIT_MASK_NPQ_PGSUB_CNT_8822C) << BIT_SHIFT_NPQ_PGSUB_CNT_8822C)
#define BITS_NPQ_PGSUB_CNT_8822C \
(BIT_MASK_NPQ_PGSUB_CNT_8822C << BIT_SHIFT_NPQ_PGSUB_CNT_8822C)
#define BIT_CLEAR_NPQ_PGSUB_CNT_8822C(x) ((x) & (~BITS_NPQ_PGSUB_CNT_8822C))
#define BIT_GET_NPQ_PGSUB_CNT_8822C(x) \
(((x) >> BIT_SHIFT_NPQ_PGSUB_CNT_8822C) & BIT_MASK_NPQ_PGSUB_CNT_8822C)
#define BIT_SET_NPQ_PGSUB_CNT_8822C(x, v) \
(BIT_CLEAR_NPQ_PGSUB_CNT_8822C(x) | BIT_NPQ_PGSUB_CNT_8822C(v))
/* 2 REG_PGSUB_L_8822C */
#define BIT_SHIFT_LPQ_PGSUB_CNT_8822C 0
#define BIT_MASK_LPQ_PGSUB_CNT_8822C 0xffffffffL
#define BIT_LPQ_PGSUB_CNT_8822C(x) \
(((x) & BIT_MASK_LPQ_PGSUB_CNT_8822C) << BIT_SHIFT_LPQ_PGSUB_CNT_8822C)
#define BITS_LPQ_PGSUB_CNT_8822C \
(BIT_MASK_LPQ_PGSUB_CNT_8822C << BIT_SHIFT_LPQ_PGSUB_CNT_8822C)
#define BIT_CLEAR_LPQ_PGSUB_CNT_8822C(x) ((x) & (~BITS_LPQ_PGSUB_CNT_8822C))
#define BIT_GET_LPQ_PGSUB_CNT_8822C(x) \
(((x) >> BIT_SHIFT_LPQ_PGSUB_CNT_8822C) & BIT_MASK_LPQ_PGSUB_CNT_8822C)
#define BIT_SET_LPQ_PGSUB_CNT_8822C(x, v) \
(BIT_CLEAR_LPQ_PGSUB_CNT_8822C(x) | BIT_LPQ_PGSUB_CNT_8822C(v))
/* 2 REG_PGSUB_E_8822C */
#define BIT_SHIFT_EPQ_PGSUB_CNT_8822C 0
#define BIT_MASK_EPQ_PGSUB_CNT_8822C 0xffffffffL
#define BIT_EPQ_PGSUB_CNT_8822C(x) \
(((x) & BIT_MASK_EPQ_PGSUB_CNT_8822C) << BIT_SHIFT_EPQ_PGSUB_CNT_8822C)
#define BITS_EPQ_PGSUB_CNT_8822C \
(BIT_MASK_EPQ_PGSUB_CNT_8822C << BIT_SHIFT_EPQ_PGSUB_CNT_8822C)
#define BIT_CLEAR_EPQ_PGSUB_CNT_8822C(x) ((x) & (~BITS_EPQ_PGSUB_CNT_8822C))
#define BIT_GET_EPQ_PGSUB_CNT_8822C(x) \
(((x) >> BIT_SHIFT_EPQ_PGSUB_CNT_8822C) & BIT_MASK_EPQ_PGSUB_CNT_8822C)
#define BIT_SET_EPQ_PGSUB_CNT_8822C(x, v) \
(BIT_CLEAR_EPQ_PGSUB_CNT_8822C(x) | BIT_EPQ_PGSUB_CNT_8822C(v))
/* 2 REG_RXDMA_AGG_PG_TH_8822C */
#define BIT_USB_RXDMA_AGG_EN_8822C BIT(31)
#define BIT_EN_FW_ADD_8822C BIT(30)
#define BIT_EN_PRE_CALC_8822C BIT(29)
#define BIT_RXAGG_SW_EN_8822C BIT(28)
#define BIT_RXAGG_SW_TRIG_8822C BIT(27)
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_DMA_AGG_TO_V1_8822C 8
#define BIT_MASK_DMA_AGG_TO_V1_8822C 0xff
#define BIT_DMA_AGG_TO_V1_8822C(x) \
(((x) & BIT_MASK_DMA_AGG_TO_V1_8822C) << BIT_SHIFT_DMA_AGG_TO_V1_8822C)
#define BITS_DMA_AGG_TO_V1_8822C \
(BIT_MASK_DMA_AGG_TO_V1_8822C << BIT_SHIFT_DMA_AGG_TO_V1_8822C)
#define BIT_CLEAR_DMA_AGG_TO_V1_8822C(x) ((x) & (~BITS_DMA_AGG_TO_V1_8822C))
#define BIT_GET_DMA_AGG_TO_V1_8822C(x) \
(((x) >> BIT_SHIFT_DMA_AGG_TO_V1_8822C) & BIT_MASK_DMA_AGG_TO_V1_8822C)
#define BIT_SET_DMA_AGG_TO_V1_8822C(x, v) \
(BIT_CLEAR_DMA_AGG_TO_V1_8822C(x) | BIT_DMA_AGG_TO_V1_8822C(v))
#define BIT_SHIFT_RXDMA_AGG_PG_TH_8822C 0
#define BIT_MASK_RXDMA_AGG_PG_TH_8822C 0xff
#define BIT_RXDMA_AGG_PG_TH_8822C(x) \
(((x) & BIT_MASK_RXDMA_AGG_PG_TH_8822C) \
<< BIT_SHIFT_RXDMA_AGG_PG_TH_8822C)
#define BITS_RXDMA_AGG_PG_TH_8822C \
(BIT_MASK_RXDMA_AGG_PG_TH_8822C << BIT_SHIFT_RXDMA_AGG_PG_TH_8822C)
#define BIT_CLEAR_RXDMA_AGG_PG_TH_8822C(x) ((x) & (~BITS_RXDMA_AGG_PG_TH_8822C))
#define BIT_GET_RXDMA_AGG_PG_TH_8822C(x) \
(((x) >> BIT_SHIFT_RXDMA_AGG_PG_TH_8822C) & \
BIT_MASK_RXDMA_AGG_PG_TH_8822C)
#define BIT_SET_RXDMA_AGG_PG_TH_8822C(x, v) \
(BIT_CLEAR_RXDMA_AGG_PG_TH_8822C(x) | BIT_RXDMA_AGG_PG_TH_8822C(v))
/* 2 REG_RXPKT_NUM_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822C 20
#define BIT_MASK_FW_UPD_RDPTR19_TO_16_8822C 0xf
#define BIT_FW_UPD_RDPTR19_TO_16_8822C(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR19_TO_16_8822C) \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822C)
#define BITS_FW_UPD_RDPTR19_TO_16_8822C \
(BIT_MASK_FW_UPD_RDPTR19_TO_16_8822C \
<< BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822C)
#define BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8822C(x) \
((x) & (~BITS_FW_UPD_RDPTR19_TO_16_8822C))
#define BIT_GET_FW_UPD_RDPTR19_TO_16_8822C(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR19_TO_16_8822C) & \
BIT_MASK_FW_UPD_RDPTR19_TO_16_8822C)
#define BIT_SET_FW_UPD_RDPTR19_TO_16_8822C(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR19_TO_16_8822C(x) | \
BIT_FW_UPD_RDPTR19_TO_16_8822C(v))
#define BIT_RXDMA_REQ_8822C BIT(19)
#define BIT_RW_RELEASE_EN_8822C BIT(18)
#define BIT_RXDMA_IDLE_8822C BIT(17)
#define BIT_RXPKT_RELEASE_POLL_8822C BIT(16)
#define BIT_SHIFT_FW_UPD_RDPTR_8822C 0
#define BIT_MASK_FW_UPD_RDPTR_8822C 0xffff
#define BIT_FW_UPD_RDPTR_8822C(x) \
(((x) & BIT_MASK_FW_UPD_RDPTR_8822C) << BIT_SHIFT_FW_UPD_RDPTR_8822C)
#define BITS_FW_UPD_RDPTR_8822C \
(BIT_MASK_FW_UPD_RDPTR_8822C << BIT_SHIFT_FW_UPD_RDPTR_8822C)
#define BIT_CLEAR_FW_UPD_RDPTR_8822C(x) ((x) & (~BITS_FW_UPD_RDPTR_8822C))
#define BIT_GET_FW_UPD_RDPTR_8822C(x) \
(((x) >> BIT_SHIFT_FW_UPD_RDPTR_8822C) & BIT_MASK_FW_UPD_RDPTR_8822C)
#define BIT_SET_FW_UPD_RDPTR_8822C(x, v) \
(BIT_CLEAR_FW_UPD_RDPTR_8822C(x) | BIT_FW_UPD_RDPTR_8822C(v))
/* 2 REG_RXDMA_STATUS_8822C */
#define BIT_C2H_PKT_OVF_8822C BIT(7)
#define BIT_AGG_CONFGI_ISSUE_8822C BIT(6)
#define BIT_FW_POLL_ISSUE_8822C BIT(5)
#define BIT_RX_DATA_UDN_8822C BIT(4)
#define BIT_RX_SFF_UDN_8822C BIT(3)
#define BIT_RX_SFF_OVF_8822C BIT(2)
#define BIT_RXPKT_OVF_8822C BIT(0)
/* 2 REG_RXDMA_DPR_8822C */
#define BIT_SHIFT_RDE_DEBUG_8822C 0
#define BIT_MASK_RDE_DEBUG_8822C 0xffffffffL
#define BIT_RDE_DEBUG_8822C(x) \
(((x) & BIT_MASK_RDE_DEBUG_8822C) << BIT_SHIFT_RDE_DEBUG_8822C)
#define BITS_RDE_DEBUG_8822C \
(BIT_MASK_RDE_DEBUG_8822C << BIT_SHIFT_RDE_DEBUG_8822C)
#define BIT_CLEAR_RDE_DEBUG_8822C(x) ((x) & (~BITS_RDE_DEBUG_8822C))
#define BIT_GET_RDE_DEBUG_8822C(x) \
(((x) >> BIT_SHIFT_RDE_DEBUG_8822C) & BIT_MASK_RDE_DEBUG_8822C)
#define BIT_SET_RDE_DEBUG_8822C(x, v) \
(BIT_CLEAR_RDE_DEBUG_8822C(x) | BIT_RDE_DEBUG_8822C(v))
/* 2 REG_RXDMA_MODE_8822C */
#define BIT_SHIFT_PKTNUM_TH_V2_8822C 24
#define BIT_MASK_PKTNUM_TH_V2_8822C 0x1f
#define BIT_PKTNUM_TH_V2_8822C(x) \
(((x) & BIT_MASK_PKTNUM_TH_V2_8822C) << BIT_SHIFT_PKTNUM_TH_V2_8822C)
#define BITS_PKTNUM_TH_V2_8822C \
(BIT_MASK_PKTNUM_TH_V2_8822C << BIT_SHIFT_PKTNUM_TH_V2_8822C)
#define BIT_CLEAR_PKTNUM_TH_V2_8822C(x) ((x) & (~BITS_PKTNUM_TH_V2_8822C))
#define BIT_GET_PKTNUM_TH_V2_8822C(x) \
(((x) >> BIT_SHIFT_PKTNUM_TH_V2_8822C) & BIT_MASK_PKTNUM_TH_V2_8822C)
#define BIT_SET_PKTNUM_TH_V2_8822C(x, v) \
(BIT_CLEAR_PKTNUM_TH_V2_8822C(x) | BIT_PKTNUM_TH_V2_8822C(v))
#define BIT_TXBA_BREAK_USBAGG_8822C BIT(23)
#define BIT_SHIFT_PKTLEN_PARA_8822C 16
#define BIT_MASK_PKTLEN_PARA_8822C 0x7
#define BIT_PKTLEN_PARA_8822C(x) \
(((x) & BIT_MASK_PKTLEN_PARA_8822C) << BIT_SHIFT_PKTLEN_PARA_8822C)
#define BITS_PKTLEN_PARA_8822C \
(BIT_MASK_PKTLEN_PARA_8822C << BIT_SHIFT_PKTLEN_PARA_8822C)
#define BIT_CLEAR_PKTLEN_PARA_8822C(x) ((x) & (~BITS_PKTLEN_PARA_8822C))
#define BIT_GET_PKTLEN_PARA_8822C(x) \
(((x) >> BIT_SHIFT_PKTLEN_PARA_8822C) & BIT_MASK_PKTLEN_PARA_8822C)
#define BIT_SET_PKTLEN_PARA_8822C(x, v) \
(BIT_CLEAR_PKTLEN_PARA_8822C(x) | BIT_PKTLEN_PARA_8822C(v))
#define BIT_RX_DBG_SEL_8822C BIT(7)
#define BIT_EN_SPD_8822C BIT(6)
#define BIT_SHIFT_BURST_SIZE_8822C 4
#define BIT_MASK_BURST_SIZE_8822C 0x3
#define BIT_BURST_SIZE_8822C(x) \
(((x) & BIT_MASK_BURST_SIZE_8822C) << BIT_SHIFT_BURST_SIZE_8822C)
#define BITS_BURST_SIZE_8822C \
(BIT_MASK_BURST_SIZE_8822C << BIT_SHIFT_BURST_SIZE_8822C)
#define BIT_CLEAR_BURST_SIZE_8822C(x) ((x) & (~BITS_BURST_SIZE_8822C))
#define BIT_GET_BURST_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_BURST_SIZE_8822C) & BIT_MASK_BURST_SIZE_8822C)
#define BIT_SET_BURST_SIZE_8822C(x, v) \
(BIT_CLEAR_BURST_SIZE_8822C(x) | BIT_BURST_SIZE_8822C(v))
#define BIT_SHIFT_BURST_CNT_8822C 2
#define BIT_MASK_BURST_CNT_8822C 0x3
#define BIT_BURST_CNT_8822C(x) \
(((x) & BIT_MASK_BURST_CNT_8822C) << BIT_SHIFT_BURST_CNT_8822C)
#define BITS_BURST_CNT_8822C \
(BIT_MASK_BURST_CNT_8822C << BIT_SHIFT_BURST_CNT_8822C)
#define BIT_CLEAR_BURST_CNT_8822C(x) ((x) & (~BITS_BURST_CNT_8822C))
#define BIT_GET_BURST_CNT_8822C(x) \
(((x) >> BIT_SHIFT_BURST_CNT_8822C) & BIT_MASK_BURST_CNT_8822C)
#define BIT_SET_BURST_CNT_8822C(x, v) \
(BIT_CLEAR_BURST_CNT_8822C(x) | BIT_BURST_CNT_8822C(v))
#define BIT_DMA_MODE_8822C BIT(1)
/* 2 REG_C2H_PKT_8822C */
#define BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822C 24
#define BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822C 0xf
#define BIT_R_C2H_STR_ADDR_16_TO_19_8822C(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822C) \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822C)
#define BITS_R_C2H_STR_ADDR_16_TO_19_8822C \
(BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822C \
<< BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822C)
#define BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8822C(x) \
((x) & (~BITS_R_C2H_STR_ADDR_16_TO_19_8822C))
#define BIT_GET_R_C2H_STR_ADDR_16_TO_19_8822C(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_16_TO_19_8822C) & \
BIT_MASK_R_C2H_STR_ADDR_16_TO_19_8822C)
#define BIT_SET_R_C2H_STR_ADDR_16_TO_19_8822C(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_16_TO_19_8822C(x) | \
BIT_R_C2H_STR_ADDR_16_TO_19_8822C(v))
#define BIT_R_C2H_PKT_REQ_8822C BIT(16)
#define BIT_SHIFT_R_C2H_STR_ADDR_8822C 0
#define BIT_MASK_R_C2H_STR_ADDR_8822C 0xffff
#define BIT_R_C2H_STR_ADDR_8822C(x) \
(((x) & BIT_MASK_R_C2H_STR_ADDR_8822C) \
<< BIT_SHIFT_R_C2H_STR_ADDR_8822C)
#define BITS_R_C2H_STR_ADDR_8822C \
(BIT_MASK_R_C2H_STR_ADDR_8822C << BIT_SHIFT_R_C2H_STR_ADDR_8822C)
#define BIT_CLEAR_R_C2H_STR_ADDR_8822C(x) ((x) & (~BITS_R_C2H_STR_ADDR_8822C))
#define BIT_GET_R_C2H_STR_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_R_C2H_STR_ADDR_8822C) & \
BIT_MASK_R_C2H_STR_ADDR_8822C)
#define BIT_SET_R_C2H_STR_ADDR_8822C(x, v) \
(BIT_CLEAR_R_C2H_STR_ADDR_8822C(x) | BIT_R_C2H_STR_ADDR_8822C(v))
/* 2 REG_FWFF_C2H_8822C */
#define BIT_SHIFT_C2H_DMA_ADDR_8822C 0
#define BIT_MASK_C2H_DMA_ADDR_8822C 0x3ffff
#define BIT_C2H_DMA_ADDR_8822C(x) \
(((x) & BIT_MASK_C2H_DMA_ADDR_8822C) << BIT_SHIFT_C2H_DMA_ADDR_8822C)
#define BITS_C2H_DMA_ADDR_8822C \
(BIT_MASK_C2H_DMA_ADDR_8822C << BIT_SHIFT_C2H_DMA_ADDR_8822C)
#define BIT_CLEAR_C2H_DMA_ADDR_8822C(x) ((x) & (~BITS_C2H_DMA_ADDR_8822C))
#define BIT_GET_C2H_DMA_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_C2H_DMA_ADDR_8822C) & BIT_MASK_C2H_DMA_ADDR_8822C)
#define BIT_SET_C2H_DMA_ADDR_8822C(x, v) \
(BIT_CLEAR_C2H_DMA_ADDR_8822C(x) | BIT_C2H_DMA_ADDR_8822C(v))
/* 2 REG_FWFF_CTRL_8822C */
#define BIT_FWFF_DMAPKT_REQ_8822C BIT(31)
#define BIT_SHIFT_FWFF_DMA_PKT_NUM_8822C 16
#define BIT_MASK_FWFF_DMA_PKT_NUM_8822C 0xff
#define BIT_FWFF_DMA_PKT_NUM_8822C(x) \
(((x) & BIT_MASK_FWFF_DMA_PKT_NUM_8822C) \
<< BIT_SHIFT_FWFF_DMA_PKT_NUM_8822C)
#define BITS_FWFF_DMA_PKT_NUM_8822C \
(BIT_MASK_FWFF_DMA_PKT_NUM_8822C << BIT_SHIFT_FWFF_DMA_PKT_NUM_8822C)
#define BIT_CLEAR_FWFF_DMA_PKT_NUM_8822C(x) \
((x) & (~BITS_FWFF_DMA_PKT_NUM_8822C))
#define BIT_GET_FWFF_DMA_PKT_NUM_8822C(x) \
(((x) >> BIT_SHIFT_FWFF_DMA_PKT_NUM_8822C) & \
BIT_MASK_FWFF_DMA_PKT_NUM_8822C)
#define BIT_SET_FWFF_DMA_PKT_NUM_8822C(x, v) \
(BIT_CLEAR_FWFF_DMA_PKT_NUM_8822C(x) | BIT_FWFF_DMA_PKT_NUM_8822C(v))
#define BIT_SHIFT_FWFF_STR_ADDR_8822C 0
#define BIT_MASK_FWFF_STR_ADDR_8822C 0xffff
#define BIT_FWFF_STR_ADDR_8822C(x) \
(((x) & BIT_MASK_FWFF_STR_ADDR_8822C) << BIT_SHIFT_FWFF_STR_ADDR_8822C)
#define BITS_FWFF_STR_ADDR_8822C \
(BIT_MASK_FWFF_STR_ADDR_8822C << BIT_SHIFT_FWFF_STR_ADDR_8822C)
#define BIT_CLEAR_FWFF_STR_ADDR_8822C(x) ((x) & (~BITS_FWFF_STR_ADDR_8822C))
#define BIT_GET_FWFF_STR_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_FWFF_STR_ADDR_8822C) & BIT_MASK_FWFF_STR_ADDR_8822C)
#define BIT_SET_FWFF_STR_ADDR_8822C(x, v) \
(BIT_CLEAR_FWFF_STR_ADDR_8822C(x) | BIT_FWFF_STR_ADDR_8822C(v))
/* 2 REG_FWFF_PKT_INFO_8822C */
#define BIT_SHIFT_FWFF_PKT_QUEUED_8822C 16
#define BIT_MASK_FWFF_PKT_QUEUED_8822C 0xff
#define BIT_FWFF_PKT_QUEUED_8822C(x) \
(((x) & BIT_MASK_FWFF_PKT_QUEUED_8822C) \
<< BIT_SHIFT_FWFF_PKT_QUEUED_8822C)
#define BITS_FWFF_PKT_QUEUED_8822C \
(BIT_MASK_FWFF_PKT_QUEUED_8822C << BIT_SHIFT_FWFF_PKT_QUEUED_8822C)
#define BIT_CLEAR_FWFF_PKT_QUEUED_8822C(x) ((x) & (~BITS_FWFF_PKT_QUEUED_8822C))
#define BIT_GET_FWFF_PKT_QUEUED_8822C(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_QUEUED_8822C) & \
BIT_MASK_FWFF_PKT_QUEUED_8822C)
#define BIT_SET_FWFF_PKT_QUEUED_8822C(x, v) \
(BIT_CLEAR_FWFF_PKT_QUEUED_8822C(x) | BIT_FWFF_PKT_QUEUED_8822C(v))
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_FWFF_PKT_STR_ADDR_V2_8822C 0
#define BIT_MASK_FWFF_PKT_STR_ADDR_V2_8822C 0x3fff
#define BIT_FWFF_PKT_STR_ADDR_V2_8822C(x) \
(((x) & BIT_MASK_FWFF_PKT_STR_ADDR_V2_8822C) \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_V2_8822C)
#define BITS_FWFF_PKT_STR_ADDR_V2_8822C \
(BIT_MASK_FWFF_PKT_STR_ADDR_V2_8822C \
<< BIT_SHIFT_FWFF_PKT_STR_ADDR_V2_8822C)
#define BIT_CLEAR_FWFF_PKT_STR_ADDR_V2_8822C(x) \
((x) & (~BITS_FWFF_PKT_STR_ADDR_V2_8822C))
#define BIT_GET_FWFF_PKT_STR_ADDR_V2_8822C(x) \
(((x) >> BIT_SHIFT_FWFF_PKT_STR_ADDR_V2_8822C) & \
BIT_MASK_FWFF_PKT_STR_ADDR_V2_8822C)
#define BIT_SET_FWFF_PKT_STR_ADDR_V2_8822C(x, v) \
(BIT_CLEAR_FWFF_PKT_STR_ADDR_V2_8822C(x) | \
BIT_FWFF_PKT_STR_ADDR_V2_8822C(v))
/* 2 REG_RXPKTNUM_8822C */
#define BIT_SHIFT_PKT_NUM_WOL_V1_8822C 16
#define BIT_MASK_PKT_NUM_WOL_V1_8822C 0xffff
#define BIT_PKT_NUM_WOL_V1_8822C(x) \
(((x) & BIT_MASK_PKT_NUM_WOL_V1_8822C) \
<< BIT_SHIFT_PKT_NUM_WOL_V1_8822C)
#define BITS_PKT_NUM_WOL_V1_8822C \
(BIT_MASK_PKT_NUM_WOL_V1_8822C << BIT_SHIFT_PKT_NUM_WOL_V1_8822C)
#define BIT_CLEAR_PKT_NUM_WOL_V1_8822C(x) ((x) & (~BITS_PKT_NUM_WOL_V1_8822C))
#define BIT_GET_PKT_NUM_WOL_V1_8822C(x) \
(((x) >> BIT_SHIFT_PKT_NUM_WOL_V1_8822C) & \
BIT_MASK_PKT_NUM_WOL_V1_8822C)
#define BIT_SET_PKT_NUM_WOL_V1_8822C(x, v) \
(BIT_CLEAR_PKT_NUM_WOL_V1_8822C(x) | BIT_PKT_NUM_WOL_V1_8822C(v))
#define BIT_SHIFT_RXPKT_NUM_V1_8822C 0
#define BIT_MASK_RXPKT_NUM_V1_8822C 0xffff
#define BIT_RXPKT_NUM_V1_8822C(x) \
(((x) & BIT_MASK_RXPKT_NUM_V1_8822C) << BIT_SHIFT_RXPKT_NUM_V1_8822C)
#define BITS_RXPKT_NUM_V1_8822C \
(BIT_MASK_RXPKT_NUM_V1_8822C << BIT_SHIFT_RXPKT_NUM_V1_8822C)
#define BIT_CLEAR_RXPKT_NUM_V1_8822C(x) ((x) & (~BITS_RXPKT_NUM_V1_8822C))
#define BIT_GET_RXPKT_NUM_V1_8822C(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_V1_8822C) & BIT_MASK_RXPKT_NUM_V1_8822C)
#define BIT_SET_RXPKT_NUM_V1_8822C(x, v) \
(BIT_CLEAR_RXPKT_NUM_V1_8822C(x) | BIT_RXPKT_NUM_V1_8822C(v))
/* 2 REG_RXPKTNUM_TH_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_RXPKT_NUM_TH_8822C 0
#define BIT_MASK_RXPKT_NUM_TH_8822C 0xff
#define BIT_RXPKT_NUM_TH_8822C(x) \
(((x) & BIT_MASK_RXPKT_NUM_TH_8822C) << BIT_SHIFT_RXPKT_NUM_TH_8822C)
#define BITS_RXPKT_NUM_TH_8822C \
(BIT_MASK_RXPKT_NUM_TH_8822C << BIT_SHIFT_RXPKT_NUM_TH_8822C)
#define BIT_CLEAR_RXPKT_NUM_TH_8822C(x) ((x) & (~BITS_RXPKT_NUM_TH_8822C))
#define BIT_GET_RXPKT_NUM_TH_8822C(x) \
(((x) >> BIT_SHIFT_RXPKT_NUM_TH_8822C) & BIT_MASK_RXPKT_NUM_TH_8822C)
#define BIT_SET_RXPKT_NUM_TH_8822C(x, v) \
(BIT_CLEAR_RXPKT_NUM_TH_8822C(x) | BIT_RXPKT_NUM_TH_8822C(v))
/* 2 REG_FW_MSG1_8822C */
#define BIT_SHIFT_FW_MSG_REG1_8822C 0
#define BIT_MASK_FW_MSG_REG1_8822C 0xffffffffL
#define BIT_FW_MSG_REG1_8822C(x) \
(((x) & BIT_MASK_FW_MSG_REG1_8822C) << BIT_SHIFT_FW_MSG_REG1_8822C)
#define BITS_FW_MSG_REG1_8822C \
(BIT_MASK_FW_MSG_REG1_8822C << BIT_SHIFT_FW_MSG_REG1_8822C)
#define BIT_CLEAR_FW_MSG_REG1_8822C(x) ((x) & (~BITS_FW_MSG_REG1_8822C))
#define BIT_GET_FW_MSG_REG1_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG1_8822C) & BIT_MASK_FW_MSG_REG1_8822C)
#define BIT_SET_FW_MSG_REG1_8822C(x, v) \
(BIT_CLEAR_FW_MSG_REG1_8822C(x) | BIT_FW_MSG_REG1_8822C(v))
/* 2 REG_FW_MSG2_8822C */
#define BIT_SHIFT_FW_MSG_REG2_8822C 0
#define BIT_MASK_FW_MSG_REG2_8822C 0xffffffffL
#define BIT_FW_MSG_REG2_8822C(x) \
(((x) & BIT_MASK_FW_MSG_REG2_8822C) << BIT_SHIFT_FW_MSG_REG2_8822C)
#define BITS_FW_MSG_REG2_8822C \
(BIT_MASK_FW_MSG_REG2_8822C << BIT_SHIFT_FW_MSG_REG2_8822C)
#define BIT_CLEAR_FW_MSG_REG2_8822C(x) ((x) & (~BITS_FW_MSG_REG2_8822C))
#define BIT_GET_FW_MSG_REG2_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG2_8822C) & BIT_MASK_FW_MSG_REG2_8822C)
#define BIT_SET_FW_MSG_REG2_8822C(x, v) \
(BIT_CLEAR_FW_MSG_REG2_8822C(x) | BIT_FW_MSG_REG2_8822C(v))
/* 2 REG_FW_MSG3_8822C */
#define BIT_SHIFT_FW_MSG_REG3_8822C 0
#define BIT_MASK_FW_MSG_REG3_8822C 0xffffffffL
#define BIT_FW_MSG_REG3_8822C(x) \
(((x) & BIT_MASK_FW_MSG_REG3_8822C) << BIT_SHIFT_FW_MSG_REG3_8822C)
#define BITS_FW_MSG_REG3_8822C \
(BIT_MASK_FW_MSG_REG3_8822C << BIT_SHIFT_FW_MSG_REG3_8822C)
#define BIT_CLEAR_FW_MSG_REG3_8822C(x) ((x) & (~BITS_FW_MSG_REG3_8822C))
#define BIT_GET_FW_MSG_REG3_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG3_8822C) & BIT_MASK_FW_MSG_REG3_8822C)
#define BIT_SET_FW_MSG_REG3_8822C(x, v) \
(BIT_CLEAR_FW_MSG_REG3_8822C(x) | BIT_FW_MSG_REG3_8822C(v))
/* 2 REG_FW_MSG4_8822C */
#define BIT_SHIFT_FW_MSG_REG4_8822C 0
#define BIT_MASK_FW_MSG_REG4_8822C 0xffffffffL
#define BIT_FW_MSG_REG4_8822C(x) \
(((x) & BIT_MASK_FW_MSG_REG4_8822C) << BIT_SHIFT_FW_MSG_REG4_8822C)
#define BITS_FW_MSG_REG4_8822C \
(BIT_MASK_FW_MSG_REG4_8822C << BIT_SHIFT_FW_MSG_REG4_8822C)
#define BIT_CLEAR_FW_MSG_REG4_8822C(x) ((x) & (~BITS_FW_MSG_REG4_8822C))
#define BIT_GET_FW_MSG_REG4_8822C(x) \
(((x) >> BIT_SHIFT_FW_MSG_REG4_8822C) & BIT_MASK_FW_MSG_REG4_8822C)
#define BIT_SET_FW_MSG_REG4_8822C(x, v) \
(BIT_CLEAR_FW_MSG_REG4_8822C(x) | BIT_FW_MSG_REG4_8822C(v))
/* 2 REG_DDMA_CH0SA_8822C */
#define BIT_SHIFT_DDMACH0_SA_8822C 0
#define BIT_MASK_DDMACH0_SA_8822C 0xffffffffL
#define BIT_DDMACH0_SA_8822C(x) \
(((x) & BIT_MASK_DDMACH0_SA_8822C) << BIT_SHIFT_DDMACH0_SA_8822C)
#define BITS_DDMACH0_SA_8822C \
(BIT_MASK_DDMACH0_SA_8822C << BIT_SHIFT_DDMACH0_SA_8822C)
#define BIT_CLEAR_DDMACH0_SA_8822C(x) ((x) & (~BITS_DDMACH0_SA_8822C))
#define BIT_GET_DDMACH0_SA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH0_SA_8822C) & BIT_MASK_DDMACH0_SA_8822C)
#define BIT_SET_DDMACH0_SA_8822C(x, v) \
(BIT_CLEAR_DDMACH0_SA_8822C(x) | BIT_DDMACH0_SA_8822C(v))
/* 2 REG_DDMA_CH0DA_8822C */
#define BIT_SHIFT_DDMACH0_DA_8822C 0
#define BIT_MASK_DDMACH0_DA_8822C 0xffffffffL
#define BIT_DDMACH0_DA_8822C(x) \
(((x) & BIT_MASK_DDMACH0_DA_8822C) << BIT_SHIFT_DDMACH0_DA_8822C)
#define BITS_DDMACH0_DA_8822C \
(BIT_MASK_DDMACH0_DA_8822C << BIT_SHIFT_DDMACH0_DA_8822C)
#define BIT_CLEAR_DDMACH0_DA_8822C(x) ((x) & (~BITS_DDMACH0_DA_8822C))
#define BIT_GET_DDMACH0_DA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH0_DA_8822C) & BIT_MASK_DDMACH0_DA_8822C)
#define BIT_SET_DDMACH0_DA_8822C(x, v) \
(BIT_CLEAR_DDMACH0_DA_8822C(x) | BIT_DDMACH0_DA_8822C(v))
/* 2 REG_DDMA_CH0CTRL_8822C */
#define BIT_DDMACH0_OWN_8822C BIT(31)
#define BIT_DDMACH0_IDMEM_ERR_8822C BIT(30)
#define BIT_DDMACH0_CHKSUM_EN_8822C BIT(29)
#define BIT_DDMACH0_DA_W_DISABLE_8822C BIT(28)
#define BIT_DDMACH0_CHKSUM_STS_8822C BIT(27)
#define BIT_DDMACH0_DDMA_MODE_8822C BIT(26)
#define BIT_DDMACH0_RESET_CHKSUM_STS_8822C BIT(25)
#define BIT_DDMACH0_CHKSUM_CONT_8822C BIT(24)
#define BIT_SHIFT_DDMACH0_DLEN_8822C 0
#define BIT_MASK_DDMACH0_DLEN_8822C 0x3ffff
#define BIT_DDMACH0_DLEN_8822C(x) \
(((x) & BIT_MASK_DDMACH0_DLEN_8822C) << BIT_SHIFT_DDMACH0_DLEN_8822C)
#define BITS_DDMACH0_DLEN_8822C \
(BIT_MASK_DDMACH0_DLEN_8822C << BIT_SHIFT_DDMACH0_DLEN_8822C)
#define BIT_CLEAR_DDMACH0_DLEN_8822C(x) ((x) & (~BITS_DDMACH0_DLEN_8822C))
#define BIT_GET_DDMACH0_DLEN_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH0_DLEN_8822C) & BIT_MASK_DDMACH0_DLEN_8822C)
#define BIT_SET_DDMACH0_DLEN_8822C(x, v) \
(BIT_CLEAR_DDMACH0_DLEN_8822C(x) | BIT_DDMACH0_DLEN_8822C(v))
/* 2 REG_DDMA_CH1SA_8822C */
#define BIT_SHIFT_DDMACH1_SA_8822C 0
#define BIT_MASK_DDMACH1_SA_8822C 0xffffffffL
#define BIT_DDMACH1_SA_8822C(x) \
(((x) & BIT_MASK_DDMACH1_SA_8822C) << BIT_SHIFT_DDMACH1_SA_8822C)
#define BITS_DDMACH1_SA_8822C \
(BIT_MASK_DDMACH1_SA_8822C << BIT_SHIFT_DDMACH1_SA_8822C)
#define BIT_CLEAR_DDMACH1_SA_8822C(x) ((x) & (~BITS_DDMACH1_SA_8822C))
#define BIT_GET_DDMACH1_SA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH1_SA_8822C) & BIT_MASK_DDMACH1_SA_8822C)
#define BIT_SET_DDMACH1_SA_8822C(x, v) \
(BIT_CLEAR_DDMACH1_SA_8822C(x) | BIT_DDMACH1_SA_8822C(v))
/* 2 REG_DDMA_CH1DA_8822C */
#define BIT_SHIFT_DDMACH1_DA_8822C 0
#define BIT_MASK_DDMACH1_DA_8822C 0xffffffffL
#define BIT_DDMACH1_DA_8822C(x) \
(((x) & BIT_MASK_DDMACH1_DA_8822C) << BIT_SHIFT_DDMACH1_DA_8822C)
#define BITS_DDMACH1_DA_8822C \
(BIT_MASK_DDMACH1_DA_8822C << BIT_SHIFT_DDMACH1_DA_8822C)
#define BIT_CLEAR_DDMACH1_DA_8822C(x) ((x) & (~BITS_DDMACH1_DA_8822C))
#define BIT_GET_DDMACH1_DA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH1_DA_8822C) & BIT_MASK_DDMACH1_DA_8822C)
#define BIT_SET_DDMACH1_DA_8822C(x, v) \
(BIT_CLEAR_DDMACH1_DA_8822C(x) | BIT_DDMACH1_DA_8822C(v))
/* 2 REG_DDMA_CH1CTRL_8822C */
#define BIT_DDMACH1_OWN_8822C BIT(31)
#define BIT_DDMACH1_IDMEM_ERR_8822C BIT(30)
#define BIT_DDMACH1_CHKSUM_EN_8822C BIT(29)
#define BIT_DDMACH1_DA_W_DISABLE_8822C BIT(28)
#define BIT_DDMACH1_CHKSUM_STS_8822C BIT(27)
#define BIT_DDMACH1_DDMA_MODE_8822C BIT(26)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_DDMACH1_DLEN_8822C 0
#define BIT_MASK_DDMACH1_DLEN_8822C 0x3ffff
#define BIT_DDMACH1_DLEN_8822C(x) \
(((x) & BIT_MASK_DDMACH1_DLEN_8822C) << BIT_SHIFT_DDMACH1_DLEN_8822C)
#define BITS_DDMACH1_DLEN_8822C \
(BIT_MASK_DDMACH1_DLEN_8822C << BIT_SHIFT_DDMACH1_DLEN_8822C)
#define BIT_CLEAR_DDMACH1_DLEN_8822C(x) ((x) & (~BITS_DDMACH1_DLEN_8822C))
#define BIT_GET_DDMACH1_DLEN_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH1_DLEN_8822C) & BIT_MASK_DDMACH1_DLEN_8822C)
#define BIT_SET_DDMACH1_DLEN_8822C(x, v) \
(BIT_CLEAR_DDMACH1_DLEN_8822C(x) | BIT_DDMACH1_DLEN_8822C(v))
/* 2 REG_DDMA_CH2SA_8822C */
#define BIT_SHIFT_DDMACH2_SA_8822C 0
#define BIT_MASK_DDMACH2_SA_8822C 0xffffffffL
#define BIT_DDMACH2_SA_8822C(x) \
(((x) & BIT_MASK_DDMACH2_SA_8822C) << BIT_SHIFT_DDMACH2_SA_8822C)
#define BITS_DDMACH2_SA_8822C \
(BIT_MASK_DDMACH2_SA_8822C << BIT_SHIFT_DDMACH2_SA_8822C)
#define BIT_CLEAR_DDMACH2_SA_8822C(x) ((x) & (~BITS_DDMACH2_SA_8822C))
#define BIT_GET_DDMACH2_SA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH2_SA_8822C) & BIT_MASK_DDMACH2_SA_8822C)
#define BIT_SET_DDMACH2_SA_8822C(x, v) \
(BIT_CLEAR_DDMACH2_SA_8822C(x) | BIT_DDMACH2_SA_8822C(v))
/* 2 REG_DDMA_CH2DA_8822C */
#define BIT_SHIFT_DDMACH2_DA_8822C 0
#define BIT_MASK_DDMACH2_DA_8822C 0xffffffffL
#define BIT_DDMACH2_DA_8822C(x) \
(((x) & BIT_MASK_DDMACH2_DA_8822C) << BIT_SHIFT_DDMACH2_DA_8822C)
#define BITS_DDMACH2_DA_8822C \
(BIT_MASK_DDMACH2_DA_8822C << BIT_SHIFT_DDMACH2_DA_8822C)
#define BIT_CLEAR_DDMACH2_DA_8822C(x) ((x) & (~BITS_DDMACH2_DA_8822C))
#define BIT_GET_DDMACH2_DA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH2_DA_8822C) & BIT_MASK_DDMACH2_DA_8822C)
#define BIT_SET_DDMACH2_DA_8822C(x, v) \
(BIT_CLEAR_DDMACH2_DA_8822C(x) | BIT_DDMACH2_DA_8822C(v))
/* 2 REG_DDMA_CH2CTRL_8822C */
#define BIT_DDMACH2_OWN_8822C BIT(31)
#define BIT_DDMACH2_IDMEM_ERR_8822C BIT(30)
#define BIT_DDMACH2_CHKSUM_EN_8822C BIT(29)
#define BIT_DDMACH2_DA_W_DISABLE_8822C BIT(28)
#define BIT_DDMACH2_CHKSUM_STS_8822C BIT(27)
#define BIT_DDMACH2_DDMA_MODE_8822C BIT(26)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_DDMACH2_DLEN_8822C 0
#define BIT_MASK_DDMACH2_DLEN_8822C 0x3ffff
#define BIT_DDMACH2_DLEN_8822C(x) \
(((x) & BIT_MASK_DDMACH2_DLEN_8822C) << BIT_SHIFT_DDMACH2_DLEN_8822C)
#define BITS_DDMACH2_DLEN_8822C \
(BIT_MASK_DDMACH2_DLEN_8822C << BIT_SHIFT_DDMACH2_DLEN_8822C)
#define BIT_CLEAR_DDMACH2_DLEN_8822C(x) ((x) & (~BITS_DDMACH2_DLEN_8822C))
#define BIT_GET_DDMACH2_DLEN_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH2_DLEN_8822C) & BIT_MASK_DDMACH2_DLEN_8822C)
#define BIT_SET_DDMACH2_DLEN_8822C(x, v) \
(BIT_CLEAR_DDMACH2_DLEN_8822C(x) | BIT_DDMACH2_DLEN_8822C(v))
/* 2 REG_DDMA_CH3SA_8822C */
#define BIT_SHIFT_DDMACH3_SA_8822C 0
#define BIT_MASK_DDMACH3_SA_8822C 0xffffffffL
#define BIT_DDMACH3_SA_8822C(x) \
(((x) & BIT_MASK_DDMACH3_SA_8822C) << BIT_SHIFT_DDMACH3_SA_8822C)
#define BITS_DDMACH3_SA_8822C \
(BIT_MASK_DDMACH3_SA_8822C << BIT_SHIFT_DDMACH3_SA_8822C)
#define BIT_CLEAR_DDMACH3_SA_8822C(x) ((x) & (~BITS_DDMACH3_SA_8822C))
#define BIT_GET_DDMACH3_SA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH3_SA_8822C) & BIT_MASK_DDMACH3_SA_8822C)
#define BIT_SET_DDMACH3_SA_8822C(x, v) \
(BIT_CLEAR_DDMACH3_SA_8822C(x) | BIT_DDMACH3_SA_8822C(v))
/* 2 REG_DDMA_CH3DA_8822C */
#define BIT_SHIFT_DDMACH3_DA_8822C 0
#define BIT_MASK_DDMACH3_DA_8822C 0xffffffffL
#define BIT_DDMACH3_DA_8822C(x) \
(((x) & BIT_MASK_DDMACH3_DA_8822C) << BIT_SHIFT_DDMACH3_DA_8822C)
#define BITS_DDMACH3_DA_8822C \
(BIT_MASK_DDMACH3_DA_8822C << BIT_SHIFT_DDMACH3_DA_8822C)
#define BIT_CLEAR_DDMACH3_DA_8822C(x) ((x) & (~BITS_DDMACH3_DA_8822C))
#define BIT_GET_DDMACH3_DA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH3_DA_8822C) & BIT_MASK_DDMACH3_DA_8822C)
#define BIT_SET_DDMACH3_DA_8822C(x, v) \
(BIT_CLEAR_DDMACH3_DA_8822C(x) | BIT_DDMACH3_DA_8822C(v))
/* 2 REG_DDMA_CH3CTRL_8822C */
#define BIT_DDMACH3_OWN_8822C BIT(31)
#define BIT_DDMACH3_IDMEM_ERR_8822C BIT(30)
#define BIT_DDMACH3_CHKSUM_EN_8822C BIT(29)
#define BIT_DDMACH3_DA_W_DISABLE_8822C BIT(28)
#define BIT_DDMACH3_CHKSUM_STS_8822C BIT(27)
#define BIT_DDMACH3_DDMA_MODE_8822C BIT(26)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_DDMACH3_DLEN_8822C 0
#define BIT_MASK_DDMACH3_DLEN_8822C 0x3ffff
#define BIT_DDMACH3_DLEN_8822C(x) \
(((x) & BIT_MASK_DDMACH3_DLEN_8822C) << BIT_SHIFT_DDMACH3_DLEN_8822C)
#define BITS_DDMACH3_DLEN_8822C \
(BIT_MASK_DDMACH3_DLEN_8822C << BIT_SHIFT_DDMACH3_DLEN_8822C)
#define BIT_CLEAR_DDMACH3_DLEN_8822C(x) ((x) & (~BITS_DDMACH3_DLEN_8822C))
#define BIT_GET_DDMACH3_DLEN_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH3_DLEN_8822C) & BIT_MASK_DDMACH3_DLEN_8822C)
#define BIT_SET_DDMACH3_DLEN_8822C(x, v) \
(BIT_CLEAR_DDMACH3_DLEN_8822C(x) | BIT_DDMACH3_DLEN_8822C(v))
/* 2 REG_DDMA_CH4SA_8822C */
#define BIT_SHIFT_DDMACH4_SA_8822C 0
#define BIT_MASK_DDMACH4_SA_8822C 0xffffffffL
#define BIT_DDMACH4_SA_8822C(x) \
(((x) & BIT_MASK_DDMACH4_SA_8822C) << BIT_SHIFT_DDMACH4_SA_8822C)
#define BITS_DDMACH4_SA_8822C \
(BIT_MASK_DDMACH4_SA_8822C << BIT_SHIFT_DDMACH4_SA_8822C)
#define BIT_CLEAR_DDMACH4_SA_8822C(x) ((x) & (~BITS_DDMACH4_SA_8822C))
#define BIT_GET_DDMACH4_SA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH4_SA_8822C) & BIT_MASK_DDMACH4_SA_8822C)
#define BIT_SET_DDMACH4_SA_8822C(x, v) \
(BIT_CLEAR_DDMACH4_SA_8822C(x) | BIT_DDMACH4_SA_8822C(v))
/* 2 REG_DDMA_CH4DA_8822C */
#define BIT_SHIFT_DDMACH4_DA_8822C 0
#define BIT_MASK_DDMACH4_DA_8822C 0xffffffffL
#define BIT_DDMACH4_DA_8822C(x) \
(((x) & BIT_MASK_DDMACH4_DA_8822C) << BIT_SHIFT_DDMACH4_DA_8822C)
#define BITS_DDMACH4_DA_8822C \
(BIT_MASK_DDMACH4_DA_8822C << BIT_SHIFT_DDMACH4_DA_8822C)
#define BIT_CLEAR_DDMACH4_DA_8822C(x) ((x) & (~BITS_DDMACH4_DA_8822C))
#define BIT_GET_DDMACH4_DA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH4_DA_8822C) & BIT_MASK_DDMACH4_DA_8822C)
#define BIT_SET_DDMACH4_DA_8822C(x, v) \
(BIT_CLEAR_DDMACH4_DA_8822C(x) | BIT_DDMACH4_DA_8822C(v))
/* 2 REG_DDMA_CH4CTRL_8822C */
#define BIT_DDMACH4_OWN_8822C BIT(31)
#define BIT_DDMACH4_IDMEM_ERR_8822C BIT(30)
#define BIT_DDMACH4_CHKSUM_EN_8822C BIT(29)
#define BIT_DDMACH4_DA_W_DISABLE_8822C BIT(28)
#define BIT_DDMACH4_CHKSUM_STS_8822C BIT(27)
#define BIT_DDMACH4_DDMA_MODE_8822C BIT(26)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_DDMACH4_DLEN_8822C 0
#define BIT_MASK_DDMACH4_DLEN_8822C 0x3ffff
#define BIT_DDMACH4_DLEN_8822C(x) \
(((x) & BIT_MASK_DDMACH4_DLEN_8822C) << BIT_SHIFT_DDMACH4_DLEN_8822C)
#define BITS_DDMACH4_DLEN_8822C \
(BIT_MASK_DDMACH4_DLEN_8822C << BIT_SHIFT_DDMACH4_DLEN_8822C)
#define BIT_CLEAR_DDMACH4_DLEN_8822C(x) ((x) & (~BITS_DDMACH4_DLEN_8822C))
#define BIT_GET_DDMACH4_DLEN_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH4_DLEN_8822C) & BIT_MASK_DDMACH4_DLEN_8822C)
#define BIT_SET_DDMACH4_DLEN_8822C(x, v) \
(BIT_CLEAR_DDMACH4_DLEN_8822C(x) | BIT_DDMACH4_DLEN_8822C(v))
/* 2 REG_DDMA_CH5SA_8822C */
#define BIT_SHIFT_DDMACH5_SA_8822C 0
#define BIT_MASK_DDMACH5_SA_8822C 0xffffffffL
#define BIT_DDMACH5_SA_8822C(x) \
(((x) & BIT_MASK_DDMACH5_SA_8822C) << BIT_SHIFT_DDMACH5_SA_8822C)
#define BITS_DDMACH5_SA_8822C \
(BIT_MASK_DDMACH5_SA_8822C << BIT_SHIFT_DDMACH5_SA_8822C)
#define BIT_CLEAR_DDMACH5_SA_8822C(x) ((x) & (~BITS_DDMACH5_SA_8822C))
#define BIT_GET_DDMACH5_SA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH5_SA_8822C) & BIT_MASK_DDMACH5_SA_8822C)
#define BIT_SET_DDMACH5_SA_8822C(x, v) \
(BIT_CLEAR_DDMACH5_SA_8822C(x) | BIT_DDMACH5_SA_8822C(v))
/* 2 REG_DDMA_CH5DA_8822C */
#define BIT_SHIFT_DDMACH5_DA_8822C 0
#define BIT_MASK_DDMACH5_DA_8822C 0xffffffffL
#define BIT_DDMACH5_DA_8822C(x) \
(((x) & BIT_MASK_DDMACH5_DA_8822C) << BIT_SHIFT_DDMACH5_DA_8822C)
#define BITS_DDMACH5_DA_8822C \
(BIT_MASK_DDMACH5_DA_8822C << BIT_SHIFT_DDMACH5_DA_8822C)
#define BIT_CLEAR_DDMACH5_DA_8822C(x) ((x) & (~BITS_DDMACH5_DA_8822C))
#define BIT_GET_DDMACH5_DA_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH5_DA_8822C) & BIT_MASK_DDMACH5_DA_8822C)
#define BIT_SET_DDMACH5_DA_8822C(x, v) \
(BIT_CLEAR_DDMACH5_DA_8822C(x) | BIT_DDMACH5_DA_8822C(v))
/* 2 REG_DDMA_CH5CTRL_8822C */
#define BIT_DDMACH5_OWN_8822C BIT(31)
#define BIT_DDMACH5_IDMEM_ERR_8822C BIT(30)
#define BIT_DDMACH5_CHKSUM_EN_8822C BIT(29)
#define BIT_DDMACH5_DA_W_DISABLE_8822C BIT(28)
#define BIT_DDMACH5_CHKSUM_STS_8822C BIT(27)
#define BIT_DDMACH5_DDMA_MODE_8822C BIT(26)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_DDMACH5_DLEN_8822C 0
#define BIT_MASK_DDMACH5_DLEN_8822C 0x3ffff
#define BIT_DDMACH5_DLEN_8822C(x) \
(((x) & BIT_MASK_DDMACH5_DLEN_8822C) << BIT_SHIFT_DDMACH5_DLEN_8822C)
#define BITS_DDMACH5_DLEN_8822C \
(BIT_MASK_DDMACH5_DLEN_8822C << BIT_SHIFT_DDMACH5_DLEN_8822C)
#define BIT_CLEAR_DDMACH5_DLEN_8822C(x) ((x) & (~BITS_DDMACH5_DLEN_8822C))
#define BIT_GET_DDMACH5_DLEN_8822C(x) \
(((x) >> BIT_SHIFT_DDMACH5_DLEN_8822C) & BIT_MASK_DDMACH5_DLEN_8822C)
#define BIT_SET_DDMACH5_DLEN_8822C(x, v) \
(BIT_CLEAR_DDMACH5_DLEN_8822C(x) | BIT_DDMACH5_DLEN_8822C(v))
/* 2 REG_DDMA_INT_MSK_8822C */
#define BIT_DDMACH5_MSK_8822C BIT(5)
#define BIT_DDMACH4_MSK_8822C BIT(4)
#define BIT_DDMACH3_MSK_8822C BIT(3)
#define BIT_DDMACH2_MSK_8822C BIT(2)
#define BIT_DDMACH1_MSK_8822C BIT(1)
#define BIT_DDMACH0_MSK_8822C BIT(0)
/* 2 REG_DDMA_CHSTATUS_8822C */
#define BIT_DDMACH5_BUSY_8822C BIT(5)
#define BIT_DDMACH4_BUSY_8822C BIT(4)
#define BIT_DDMACH3_BUSY_8822C BIT(3)
#define BIT_DDMACH2_BUSY_8822C BIT(2)
#define BIT_DDMACH1_BUSY_8822C BIT(1)
#define BIT_DDMACH0_BUSY_8822C BIT(0)
/* 2 REG_DDMA_CHKSUM_8822C */
#define BIT_SHIFT_IDDMA0_CHKSUM_8822C 0
#define BIT_MASK_IDDMA0_CHKSUM_8822C 0xffff
#define BIT_IDDMA0_CHKSUM_8822C(x) \
(((x) & BIT_MASK_IDDMA0_CHKSUM_8822C) << BIT_SHIFT_IDDMA0_CHKSUM_8822C)
#define BITS_IDDMA0_CHKSUM_8822C \
(BIT_MASK_IDDMA0_CHKSUM_8822C << BIT_SHIFT_IDDMA0_CHKSUM_8822C)
#define BIT_CLEAR_IDDMA0_CHKSUM_8822C(x) ((x) & (~BITS_IDDMA0_CHKSUM_8822C))
#define BIT_GET_IDDMA0_CHKSUM_8822C(x) \
(((x) >> BIT_SHIFT_IDDMA0_CHKSUM_8822C) & BIT_MASK_IDDMA0_CHKSUM_8822C)
#define BIT_SET_IDDMA0_CHKSUM_8822C(x, v) \
(BIT_CLEAR_IDDMA0_CHKSUM_8822C(x) | BIT_IDDMA0_CHKSUM_8822C(v))
/* 2 REG_DDMA_MONITOR_8822C */
#define BIT_IDDMA0_PERMU_UNDERFLOW_8822C BIT(14)
#define BIT_IDDMA0_FIFO_UNDERFLOW_8822C BIT(13)
#define BIT_IDDMA0_FIFO_OVERFLOW_8822C BIT(12)
#define BIT_CH5_ERR_8822C BIT(5)
#define BIT_CH4_ERR_8822C BIT(4)
#define BIT_CH3_ERR_8822C BIT(3)
#define BIT_CH2_ERR_8822C BIT(2)
#define BIT_CH1_ERR_8822C BIT(1)
#define BIT_CH0_ERR_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_PCIE_CTRL_8822C */
#define BIT_PCIEIO_PERSTB_SEL_8822C BIT(31)
#define BIT_SHIFT_PCIE_MAX_RXDMA_8822C 28
#define BIT_MASK_PCIE_MAX_RXDMA_8822C 0x7
#define BIT_PCIE_MAX_RXDMA_8822C(x) \
(((x) & BIT_MASK_PCIE_MAX_RXDMA_8822C) \
<< BIT_SHIFT_PCIE_MAX_RXDMA_8822C)
#define BITS_PCIE_MAX_RXDMA_8822C \
(BIT_MASK_PCIE_MAX_RXDMA_8822C << BIT_SHIFT_PCIE_MAX_RXDMA_8822C)
#define BIT_CLEAR_PCIE_MAX_RXDMA_8822C(x) ((x) & (~BITS_PCIE_MAX_RXDMA_8822C))
#define BIT_GET_PCIE_MAX_RXDMA_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_RXDMA_8822C) & \
BIT_MASK_PCIE_MAX_RXDMA_8822C)
#define BIT_SET_PCIE_MAX_RXDMA_8822C(x, v) \
(BIT_CLEAR_PCIE_MAX_RXDMA_8822C(x) | BIT_PCIE_MAX_RXDMA_8822C(v))
#define BIT_SHIFT_PCIE_MAX_TXDMA_8822C 24
#define BIT_MASK_PCIE_MAX_TXDMA_8822C 0x7
#define BIT_PCIE_MAX_TXDMA_8822C(x) \
(((x) & BIT_MASK_PCIE_MAX_TXDMA_8822C) \
<< BIT_SHIFT_PCIE_MAX_TXDMA_8822C)
#define BITS_PCIE_MAX_TXDMA_8822C \
(BIT_MASK_PCIE_MAX_TXDMA_8822C << BIT_SHIFT_PCIE_MAX_TXDMA_8822C)
#define BIT_CLEAR_PCIE_MAX_TXDMA_8822C(x) ((x) & (~BITS_PCIE_MAX_TXDMA_8822C))
#define BIT_GET_PCIE_MAX_TXDMA_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_MAX_TXDMA_8822C) & \
BIT_MASK_PCIE_MAX_TXDMA_8822C)
#define BIT_SET_PCIE_MAX_TXDMA_8822C(x, v) \
(BIT_CLEAR_PCIE_MAX_TXDMA_8822C(x) | BIT_PCIE_MAX_TXDMA_8822C(v))
#define BIT_EN_CPL_TIMEOUT_PS_8822C BIT(22)
#define BIT_REG_TXDMA_FAIL_PS_8822C BIT(21)
#define BIT_PCIE_RST_TRXDMA_INTF_8822C BIT(20)
#define BIT_EN_HWENTR_L1_8822C BIT(19)
#define BIT_EN_ADV_CLKGATE_8822C BIT(18)
#define BIT_PCIE_EN_SWENT_L23_8822C BIT(17)
#define BIT_PCIE_EN_HWEXT_L1_8822C BIT(16)
#define BIT_RX_CLOSE_EN_8822C BIT(15)
#define BIT_STOP_BCNQ_8822C BIT(14)
#define BIT_STOP_MGQ_8822C BIT(13)
#define BIT_STOP_VOQ_8822C BIT(12)
#define BIT_STOP_VIQ_8822C BIT(11)
#define BIT_STOP_BEQ_8822C BIT(10)
#define BIT_STOP_BKQ_8822C BIT(9)
#define BIT_STOP_RXQ_8822C BIT(8)
#define BIT_STOP_HI7Q_8822C BIT(7)
#define BIT_STOP_HI6Q_8822C BIT(6)
#define BIT_STOP_HI5Q_8822C BIT(5)
#define BIT_STOP_HI4Q_8822C BIT(4)
#define BIT_STOP_HI3Q_8822C BIT(3)
#define BIT_STOP_HI2Q_8822C BIT(2)
#define BIT_STOP_HI1Q_8822C BIT(1)
#define BIT_STOP_HI0Q_8822C BIT(0)
/* 2 REG_INT_MIG_8822C */
#define BIT_SHIFT_TRXCOUNTER_MATCH_8822C 24
#define BIT_MASK_TRXCOUNTER_MATCH_8822C 0xff
#define BIT_TRXCOUNTER_MATCH_8822C(x) \
(((x) & BIT_MASK_TRXCOUNTER_MATCH_8822C) \
<< BIT_SHIFT_TRXCOUNTER_MATCH_8822C)
#define BITS_TRXCOUNTER_MATCH_8822C \
(BIT_MASK_TRXCOUNTER_MATCH_8822C << BIT_SHIFT_TRXCOUNTER_MATCH_8822C)
#define BIT_CLEAR_TRXCOUNTER_MATCH_8822C(x) \
((x) & (~BITS_TRXCOUNTER_MATCH_8822C))
#define BIT_GET_TRXCOUNTER_MATCH_8822C(x) \
(((x) >> BIT_SHIFT_TRXCOUNTER_MATCH_8822C) & \
BIT_MASK_TRXCOUNTER_MATCH_8822C)
#define BIT_SET_TRXCOUNTER_MATCH_8822C(x, v) \
(BIT_CLEAR_TRXCOUNTER_MATCH_8822C(x) | BIT_TRXCOUNTER_MATCH_8822C(v))
#define BIT_SHIFT_TRXTIMER_MATCH_8822C 16
#define BIT_MASK_TRXTIMER_MATCH_8822C 0xff
#define BIT_TRXTIMER_MATCH_8822C(x) \
(((x) & BIT_MASK_TRXTIMER_MATCH_8822C) \
<< BIT_SHIFT_TRXTIMER_MATCH_8822C)
#define BITS_TRXTIMER_MATCH_8822C \
(BIT_MASK_TRXTIMER_MATCH_8822C << BIT_SHIFT_TRXTIMER_MATCH_8822C)
#define BIT_CLEAR_TRXTIMER_MATCH_8822C(x) ((x) & (~BITS_TRXTIMER_MATCH_8822C))
#define BIT_GET_TRXTIMER_MATCH_8822C(x) \
(((x) >> BIT_SHIFT_TRXTIMER_MATCH_8822C) & \
BIT_MASK_TRXTIMER_MATCH_8822C)
#define BIT_SET_TRXTIMER_MATCH_8822C(x, v) \
(BIT_CLEAR_TRXTIMER_MATCH_8822C(x) | BIT_TRXTIMER_MATCH_8822C(v))
#define BIT_SHIFT_TRXTIMER_UNIT_8822C 0
#define BIT_MASK_TRXTIMER_UNIT_8822C 0x3
#define BIT_TRXTIMER_UNIT_8822C(x) \
(((x) & BIT_MASK_TRXTIMER_UNIT_8822C) << BIT_SHIFT_TRXTIMER_UNIT_8822C)
#define BITS_TRXTIMER_UNIT_8822C \
(BIT_MASK_TRXTIMER_UNIT_8822C << BIT_SHIFT_TRXTIMER_UNIT_8822C)
#define BIT_CLEAR_TRXTIMER_UNIT_8822C(x) ((x) & (~BITS_TRXTIMER_UNIT_8822C))
#define BIT_GET_TRXTIMER_UNIT_8822C(x) \
(((x) >> BIT_SHIFT_TRXTIMER_UNIT_8822C) & BIT_MASK_TRXTIMER_UNIT_8822C)
#define BIT_SET_TRXTIMER_UNIT_8822C(x, v) \
(BIT_CLEAR_TRXTIMER_UNIT_8822C(x) | BIT_TRXTIMER_UNIT_8822C(v))
/* 2 REG_BCNQ_TXBD_DESA_8822C */
#define BIT_SHIFT_BCNQ_TXBD_DESA_8822C 0
#define BIT_MASK_BCNQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_BCNQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_BCNQ_TXBD_DESA_8822C) \
<< BIT_SHIFT_BCNQ_TXBD_DESA_8822C)
#define BITS_BCNQ_TXBD_DESA_8822C \
(BIT_MASK_BCNQ_TXBD_DESA_8822C << BIT_SHIFT_BCNQ_TXBD_DESA_8822C)
#define BIT_CLEAR_BCNQ_TXBD_DESA_8822C(x) ((x) & (~BITS_BCNQ_TXBD_DESA_8822C))
#define BIT_GET_BCNQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_BCNQ_TXBD_DESA_8822C) & \
BIT_MASK_BCNQ_TXBD_DESA_8822C)
#define BIT_SET_BCNQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_BCNQ_TXBD_DESA_8822C(x) | BIT_BCNQ_TXBD_DESA_8822C(v))
/* 2 REG_MGQ_TXBD_DESA_8822C */
#define BIT_SHIFT_MGQ_TXBD_DESA_8822C 0
#define BIT_MASK_MGQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_MGQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_MGQ_TXBD_DESA_8822C) << BIT_SHIFT_MGQ_TXBD_DESA_8822C)
#define BITS_MGQ_TXBD_DESA_8822C \
(BIT_MASK_MGQ_TXBD_DESA_8822C << BIT_SHIFT_MGQ_TXBD_DESA_8822C)
#define BIT_CLEAR_MGQ_TXBD_DESA_8822C(x) ((x) & (~BITS_MGQ_TXBD_DESA_8822C))
#define BIT_GET_MGQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_TXBD_DESA_8822C) & BIT_MASK_MGQ_TXBD_DESA_8822C)
#define BIT_SET_MGQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_MGQ_TXBD_DESA_8822C(x) | BIT_MGQ_TXBD_DESA_8822C(v))
/* 2 REG_VOQ_TXBD_DESA_8822C */
#define BIT_SHIFT_VOQ_TXBD_DESA_8822C 0
#define BIT_MASK_VOQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_VOQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_VOQ_TXBD_DESA_8822C) << BIT_SHIFT_VOQ_TXBD_DESA_8822C)
#define BITS_VOQ_TXBD_DESA_8822C \
(BIT_MASK_VOQ_TXBD_DESA_8822C << BIT_SHIFT_VOQ_TXBD_DESA_8822C)
#define BIT_CLEAR_VOQ_TXBD_DESA_8822C(x) ((x) & (~BITS_VOQ_TXBD_DESA_8822C))
#define BIT_GET_VOQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_VOQ_TXBD_DESA_8822C) & BIT_MASK_VOQ_TXBD_DESA_8822C)
#define BIT_SET_VOQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_VOQ_TXBD_DESA_8822C(x) | BIT_VOQ_TXBD_DESA_8822C(v))
/* 2 REG_VIQ_TXBD_DESA_8822C */
#define BIT_SHIFT_VIQ_TXBD_DESA_8822C 0
#define BIT_MASK_VIQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_VIQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_VIQ_TXBD_DESA_8822C) << BIT_SHIFT_VIQ_TXBD_DESA_8822C)
#define BITS_VIQ_TXBD_DESA_8822C \
(BIT_MASK_VIQ_TXBD_DESA_8822C << BIT_SHIFT_VIQ_TXBD_DESA_8822C)
#define BIT_CLEAR_VIQ_TXBD_DESA_8822C(x) ((x) & (~BITS_VIQ_TXBD_DESA_8822C))
#define BIT_GET_VIQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_VIQ_TXBD_DESA_8822C) & BIT_MASK_VIQ_TXBD_DESA_8822C)
#define BIT_SET_VIQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_VIQ_TXBD_DESA_8822C(x) | BIT_VIQ_TXBD_DESA_8822C(v))
/* 2 REG_BEQ_TXBD_DESA_8822C */
#define BIT_SHIFT_BEQ_TXBD_DESA_8822C 0
#define BIT_MASK_BEQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_BEQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_BEQ_TXBD_DESA_8822C) << BIT_SHIFT_BEQ_TXBD_DESA_8822C)
#define BITS_BEQ_TXBD_DESA_8822C \
(BIT_MASK_BEQ_TXBD_DESA_8822C << BIT_SHIFT_BEQ_TXBD_DESA_8822C)
#define BIT_CLEAR_BEQ_TXBD_DESA_8822C(x) ((x) & (~BITS_BEQ_TXBD_DESA_8822C))
#define BIT_GET_BEQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_BEQ_TXBD_DESA_8822C) & BIT_MASK_BEQ_TXBD_DESA_8822C)
#define BIT_SET_BEQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_BEQ_TXBD_DESA_8822C(x) | BIT_BEQ_TXBD_DESA_8822C(v))
/* 2 REG_BKQ_TXBD_DESA_8822C */
#define BIT_SHIFT_BKQ_TXBD_DESA_8822C 0
#define BIT_MASK_BKQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_BKQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_BKQ_TXBD_DESA_8822C) << BIT_SHIFT_BKQ_TXBD_DESA_8822C)
#define BITS_BKQ_TXBD_DESA_8822C \
(BIT_MASK_BKQ_TXBD_DESA_8822C << BIT_SHIFT_BKQ_TXBD_DESA_8822C)
#define BIT_CLEAR_BKQ_TXBD_DESA_8822C(x) ((x) & (~BITS_BKQ_TXBD_DESA_8822C))
#define BIT_GET_BKQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_BKQ_TXBD_DESA_8822C) & BIT_MASK_BKQ_TXBD_DESA_8822C)
#define BIT_SET_BKQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_BKQ_TXBD_DESA_8822C(x) | BIT_BKQ_TXBD_DESA_8822C(v))
/* 2 REG_RXQ_RXBD_DESA_8822C */
#define BIT_SHIFT_RXQ_RXBD_DESA_8822C 0
#define BIT_MASK_RXQ_RXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_RXQ_RXBD_DESA_8822C(x) \
(((x) & BIT_MASK_RXQ_RXBD_DESA_8822C) << BIT_SHIFT_RXQ_RXBD_DESA_8822C)
#define BITS_RXQ_RXBD_DESA_8822C \
(BIT_MASK_RXQ_RXBD_DESA_8822C << BIT_SHIFT_RXQ_RXBD_DESA_8822C)
#define BIT_CLEAR_RXQ_RXBD_DESA_8822C(x) ((x) & (~BITS_RXQ_RXBD_DESA_8822C))
#define BIT_GET_RXQ_RXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_RXQ_RXBD_DESA_8822C) & BIT_MASK_RXQ_RXBD_DESA_8822C)
#define BIT_SET_RXQ_RXBD_DESA_8822C(x, v) \
(BIT_CLEAR_RXQ_RXBD_DESA_8822C(x) | BIT_RXQ_RXBD_DESA_8822C(v))
/* 2 REG_HI0Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI0Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI0Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI0Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI0Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI0Q_TXBD_DESA_8822C)
#define BITS_HI0Q_TXBD_DESA_8822C \
(BIT_MASK_HI0Q_TXBD_DESA_8822C << BIT_SHIFT_HI0Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI0Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI0Q_TXBD_DESA_8822C))
#define BIT_GET_HI0Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI0Q_TXBD_DESA_8822C) & \
BIT_MASK_HI0Q_TXBD_DESA_8822C)
#define BIT_SET_HI0Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI0Q_TXBD_DESA_8822C(x) | BIT_HI0Q_TXBD_DESA_8822C(v))
/* 2 REG_HI1Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI1Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI1Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI1Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI1Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI1Q_TXBD_DESA_8822C)
#define BITS_HI1Q_TXBD_DESA_8822C \
(BIT_MASK_HI1Q_TXBD_DESA_8822C << BIT_SHIFT_HI1Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI1Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI1Q_TXBD_DESA_8822C))
#define BIT_GET_HI1Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI1Q_TXBD_DESA_8822C) & \
BIT_MASK_HI1Q_TXBD_DESA_8822C)
#define BIT_SET_HI1Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI1Q_TXBD_DESA_8822C(x) | BIT_HI1Q_TXBD_DESA_8822C(v))
/* 2 REG_HI2Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI2Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI2Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI2Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI2Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI2Q_TXBD_DESA_8822C)
#define BITS_HI2Q_TXBD_DESA_8822C \
(BIT_MASK_HI2Q_TXBD_DESA_8822C << BIT_SHIFT_HI2Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI2Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI2Q_TXBD_DESA_8822C))
#define BIT_GET_HI2Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI2Q_TXBD_DESA_8822C) & \
BIT_MASK_HI2Q_TXBD_DESA_8822C)
#define BIT_SET_HI2Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI2Q_TXBD_DESA_8822C(x) | BIT_HI2Q_TXBD_DESA_8822C(v))
/* 2 REG_HI3Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI3Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI3Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI3Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI3Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI3Q_TXBD_DESA_8822C)
#define BITS_HI3Q_TXBD_DESA_8822C \
(BIT_MASK_HI3Q_TXBD_DESA_8822C << BIT_SHIFT_HI3Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI3Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI3Q_TXBD_DESA_8822C))
#define BIT_GET_HI3Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI3Q_TXBD_DESA_8822C) & \
BIT_MASK_HI3Q_TXBD_DESA_8822C)
#define BIT_SET_HI3Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI3Q_TXBD_DESA_8822C(x) | BIT_HI3Q_TXBD_DESA_8822C(v))
/* 2 REG_HI4Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI4Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI4Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI4Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI4Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI4Q_TXBD_DESA_8822C)
#define BITS_HI4Q_TXBD_DESA_8822C \
(BIT_MASK_HI4Q_TXBD_DESA_8822C << BIT_SHIFT_HI4Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI4Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI4Q_TXBD_DESA_8822C))
#define BIT_GET_HI4Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI4Q_TXBD_DESA_8822C) & \
BIT_MASK_HI4Q_TXBD_DESA_8822C)
#define BIT_SET_HI4Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI4Q_TXBD_DESA_8822C(x) | BIT_HI4Q_TXBD_DESA_8822C(v))
/* 2 REG_HI5Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI5Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI5Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI5Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI5Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI5Q_TXBD_DESA_8822C)
#define BITS_HI5Q_TXBD_DESA_8822C \
(BIT_MASK_HI5Q_TXBD_DESA_8822C << BIT_SHIFT_HI5Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI5Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI5Q_TXBD_DESA_8822C))
#define BIT_GET_HI5Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI5Q_TXBD_DESA_8822C) & \
BIT_MASK_HI5Q_TXBD_DESA_8822C)
#define BIT_SET_HI5Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI5Q_TXBD_DESA_8822C(x) | BIT_HI5Q_TXBD_DESA_8822C(v))
/* 2 REG_HI6Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI6Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI6Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI6Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI6Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI6Q_TXBD_DESA_8822C)
#define BITS_HI6Q_TXBD_DESA_8822C \
(BIT_MASK_HI6Q_TXBD_DESA_8822C << BIT_SHIFT_HI6Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI6Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI6Q_TXBD_DESA_8822C))
#define BIT_GET_HI6Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI6Q_TXBD_DESA_8822C) & \
BIT_MASK_HI6Q_TXBD_DESA_8822C)
#define BIT_SET_HI6Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI6Q_TXBD_DESA_8822C(x) | BIT_HI6Q_TXBD_DESA_8822C(v))
/* 2 REG_HI7Q_TXBD_DESA_8822C */
#define BIT_SHIFT_HI7Q_TXBD_DESA_8822C 0
#define BIT_MASK_HI7Q_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_HI7Q_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_HI7Q_TXBD_DESA_8822C) \
<< BIT_SHIFT_HI7Q_TXBD_DESA_8822C)
#define BITS_HI7Q_TXBD_DESA_8822C \
(BIT_MASK_HI7Q_TXBD_DESA_8822C << BIT_SHIFT_HI7Q_TXBD_DESA_8822C)
#define BIT_CLEAR_HI7Q_TXBD_DESA_8822C(x) ((x) & (~BITS_HI7Q_TXBD_DESA_8822C))
#define BIT_GET_HI7Q_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_HI7Q_TXBD_DESA_8822C) & \
BIT_MASK_HI7Q_TXBD_DESA_8822C)
#define BIT_SET_HI7Q_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_HI7Q_TXBD_DESA_8822C(x) | BIT_HI7Q_TXBD_DESA_8822C(v))
/* 2 REG_MGQ_TXBD_NUM_8822C */
#define BIT_PCIE_MGQ_FLAG_8822C BIT(14)
#define BIT_SHIFT_MGQ_DESC_MODE_8822C 12
#define BIT_MASK_MGQ_DESC_MODE_8822C 0x3
#define BIT_MGQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_MGQ_DESC_MODE_8822C) << BIT_SHIFT_MGQ_DESC_MODE_8822C)
#define BITS_MGQ_DESC_MODE_8822C \
(BIT_MASK_MGQ_DESC_MODE_8822C << BIT_SHIFT_MGQ_DESC_MODE_8822C)
#define BIT_CLEAR_MGQ_DESC_MODE_8822C(x) ((x) & (~BITS_MGQ_DESC_MODE_8822C))
#define BIT_GET_MGQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_MODE_8822C) & BIT_MASK_MGQ_DESC_MODE_8822C)
#define BIT_SET_MGQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_MGQ_DESC_MODE_8822C(x) | BIT_MGQ_DESC_MODE_8822C(v))
#define BIT_SHIFT_MGQ_DESC_NUM_8822C 0
#define BIT_MASK_MGQ_DESC_NUM_8822C 0xfff
#define BIT_MGQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_MGQ_DESC_NUM_8822C) << BIT_SHIFT_MGQ_DESC_NUM_8822C)
#define BITS_MGQ_DESC_NUM_8822C \
(BIT_MASK_MGQ_DESC_NUM_8822C << BIT_SHIFT_MGQ_DESC_NUM_8822C)
#define BIT_CLEAR_MGQ_DESC_NUM_8822C(x) ((x) & (~BITS_MGQ_DESC_NUM_8822C))
#define BIT_GET_MGQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_DESC_NUM_8822C) & BIT_MASK_MGQ_DESC_NUM_8822C)
#define BIT_SET_MGQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_MGQ_DESC_NUM_8822C(x) | BIT_MGQ_DESC_NUM_8822C(v))
/* 2 REG_RX_RXBD_NUM_8822C */
#define BIT_SYS_32_64_8822C BIT(15)
#define BIT_SHIFT_BCNQ_DESC_MODE_8822C 13
#define BIT_MASK_BCNQ_DESC_MODE_8822C 0x3
#define BIT_BCNQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_BCNQ_DESC_MODE_8822C) \
<< BIT_SHIFT_BCNQ_DESC_MODE_8822C)
#define BITS_BCNQ_DESC_MODE_8822C \
(BIT_MASK_BCNQ_DESC_MODE_8822C << BIT_SHIFT_BCNQ_DESC_MODE_8822C)
#define BIT_CLEAR_BCNQ_DESC_MODE_8822C(x) ((x) & (~BITS_BCNQ_DESC_MODE_8822C))
#define BIT_GET_BCNQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_BCNQ_DESC_MODE_8822C) & \
BIT_MASK_BCNQ_DESC_MODE_8822C)
#define BIT_SET_BCNQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_BCNQ_DESC_MODE_8822C(x) | BIT_BCNQ_DESC_MODE_8822C(v))
#define BIT_PCIE_BCNQ_FLAG_8822C BIT(12)
#define BIT_SHIFT_RXQ_DESC_NUM_8822C 0
#define BIT_MASK_RXQ_DESC_NUM_8822C 0xfff
#define BIT_RXQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_RXQ_DESC_NUM_8822C) << BIT_SHIFT_RXQ_DESC_NUM_8822C)
#define BITS_RXQ_DESC_NUM_8822C \
(BIT_MASK_RXQ_DESC_NUM_8822C << BIT_SHIFT_RXQ_DESC_NUM_8822C)
#define BIT_CLEAR_RXQ_DESC_NUM_8822C(x) ((x) & (~BITS_RXQ_DESC_NUM_8822C))
#define BIT_GET_RXQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_RXQ_DESC_NUM_8822C) & BIT_MASK_RXQ_DESC_NUM_8822C)
#define BIT_SET_RXQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_RXQ_DESC_NUM_8822C(x) | BIT_RXQ_DESC_NUM_8822C(v))
/* 2 REG_VOQ_TXBD_NUM_8822C */
#define BIT_PCIE_VOQ_FLAG_8822C BIT(14)
#define BIT_SHIFT_VOQ_DESC_MODE_8822C 12
#define BIT_MASK_VOQ_DESC_MODE_8822C 0x3
#define BIT_VOQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_VOQ_DESC_MODE_8822C) << BIT_SHIFT_VOQ_DESC_MODE_8822C)
#define BITS_VOQ_DESC_MODE_8822C \
(BIT_MASK_VOQ_DESC_MODE_8822C << BIT_SHIFT_VOQ_DESC_MODE_8822C)
#define BIT_CLEAR_VOQ_DESC_MODE_8822C(x) ((x) & (~BITS_VOQ_DESC_MODE_8822C))
#define BIT_GET_VOQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_MODE_8822C) & BIT_MASK_VOQ_DESC_MODE_8822C)
#define BIT_SET_VOQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_VOQ_DESC_MODE_8822C(x) | BIT_VOQ_DESC_MODE_8822C(v))
#define BIT_SHIFT_VOQ_DESC_NUM_8822C 0
#define BIT_MASK_VOQ_DESC_NUM_8822C 0xfff
#define BIT_VOQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_VOQ_DESC_NUM_8822C) << BIT_SHIFT_VOQ_DESC_NUM_8822C)
#define BITS_VOQ_DESC_NUM_8822C \
(BIT_MASK_VOQ_DESC_NUM_8822C << BIT_SHIFT_VOQ_DESC_NUM_8822C)
#define BIT_CLEAR_VOQ_DESC_NUM_8822C(x) ((x) & (~BITS_VOQ_DESC_NUM_8822C))
#define BIT_GET_VOQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_VOQ_DESC_NUM_8822C) & BIT_MASK_VOQ_DESC_NUM_8822C)
#define BIT_SET_VOQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_VOQ_DESC_NUM_8822C(x) | BIT_VOQ_DESC_NUM_8822C(v))
/* 2 REG_VIQ_TXBD_NUM_8822C */
#define BIT_PCIE_VIQ_FLAG_8822C BIT(14)
#define BIT_SHIFT_VIQ_DESC_MODE_8822C 12
#define BIT_MASK_VIQ_DESC_MODE_8822C 0x3
#define BIT_VIQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_VIQ_DESC_MODE_8822C) << BIT_SHIFT_VIQ_DESC_MODE_8822C)
#define BITS_VIQ_DESC_MODE_8822C \
(BIT_MASK_VIQ_DESC_MODE_8822C << BIT_SHIFT_VIQ_DESC_MODE_8822C)
#define BIT_CLEAR_VIQ_DESC_MODE_8822C(x) ((x) & (~BITS_VIQ_DESC_MODE_8822C))
#define BIT_GET_VIQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_MODE_8822C) & BIT_MASK_VIQ_DESC_MODE_8822C)
#define BIT_SET_VIQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_VIQ_DESC_MODE_8822C(x) | BIT_VIQ_DESC_MODE_8822C(v))
#define BIT_SHIFT_VIQ_DESC_NUM_8822C 0
#define BIT_MASK_VIQ_DESC_NUM_8822C 0xfff
#define BIT_VIQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_VIQ_DESC_NUM_8822C) << BIT_SHIFT_VIQ_DESC_NUM_8822C)
#define BITS_VIQ_DESC_NUM_8822C \
(BIT_MASK_VIQ_DESC_NUM_8822C << BIT_SHIFT_VIQ_DESC_NUM_8822C)
#define BIT_CLEAR_VIQ_DESC_NUM_8822C(x) ((x) & (~BITS_VIQ_DESC_NUM_8822C))
#define BIT_GET_VIQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_VIQ_DESC_NUM_8822C) & BIT_MASK_VIQ_DESC_NUM_8822C)
#define BIT_SET_VIQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_VIQ_DESC_NUM_8822C(x) | BIT_VIQ_DESC_NUM_8822C(v))
/* 2 REG_BEQ_TXBD_NUM_8822C */
#define BIT_PCIE_BEQ_FLAG_8822C BIT(14)
#define BIT_SHIFT_BEQ_DESC_MODE_8822C 12
#define BIT_MASK_BEQ_DESC_MODE_8822C 0x3
#define BIT_BEQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_BEQ_DESC_MODE_8822C) << BIT_SHIFT_BEQ_DESC_MODE_8822C)
#define BITS_BEQ_DESC_MODE_8822C \
(BIT_MASK_BEQ_DESC_MODE_8822C << BIT_SHIFT_BEQ_DESC_MODE_8822C)
#define BIT_CLEAR_BEQ_DESC_MODE_8822C(x) ((x) & (~BITS_BEQ_DESC_MODE_8822C))
#define BIT_GET_BEQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_MODE_8822C) & BIT_MASK_BEQ_DESC_MODE_8822C)
#define BIT_SET_BEQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_BEQ_DESC_MODE_8822C(x) | BIT_BEQ_DESC_MODE_8822C(v))
#define BIT_SHIFT_BEQ_DESC_NUM_8822C 0
#define BIT_MASK_BEQ_DESC_NUM_8822C 0xfff
#define BIT_BEQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_BEQ_DESC_NUM_8822C) << BIT_SHIFT_BEQ_DESC_NUM_8822C)
#define BITS_BEQ_DESC_NUM_8822C \
(BIT_MASK_BEQ_DESC_NUM_8822C << BIT_SHIFT_BEQ_DESC_NUM_8822C)
#define BIT_CLEAR_BEQ_DESC_NUM_8822C(x) ((x) & (~BITS_BEQ_DESC_NUM_8822C))
#define BIT_GET_BEQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_BEQ_DESC_NUM_8822C) & BIT_MASK_BEQ_DESC_NUM_8822C)
#define BIT_SET_BEQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_BEQ_DESC_NUM_8822C(x) | BIT_BEQ_DESC_NUM_8822C(v))
/* 2 REG_BKQ_TXBD_NUM_8822C */
#define BIT_PCIE_BKQ_FLAG_8822C BIT(14)
#define BIT_SHIFT_BKQ_DESC_MODE_8822C 12
#define BIT_MASK_BKQ_DESC_MODE_8822C 0x3
#define BIT_BKQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_BKQ_DESC_MODE_8822C) << BIT_SHIFT_BKQ_DESC_MODE_8822C)
#define BITS_BKQ_DESC_MODE_8822C \
(BIT_MASK_BKQ_DESC_MODE_8822C << BIT_SHIFT_BKQ_DESC_MODE_8822C)
#define BIT_CLEAR_BKQ_DESC_MODE_8822C(x) ((x) & (~BITS_BKQ_DESC_MODE_8822C))
#define BIT_GET_BKQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_MODE_8822C) & BIT_MASK_BKQ_DESC_MODE_8822C)
#define BIT_SET_BKQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_BKQ_DESC_MODE_8822C(x) | BIT_BKQ_DESC_MODE_8822C(v))
#define BIT_SHIFT_BKQ_DESC_NUM_8822C 0
#define BIT_MASK_BKQ_DESC_NUM_8822C 0xfff
#define BIT_BKQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_BKQ_DESC_NUM_8822C) << BIT_SHIFT_BKQ_DESC_NUM_8822C)
#define BITS_BKQ_DESC_NUM_8822C \
(BIT_MASK_BKQ_DESC_NUM_8822C << BIT_SHIFT_BKQ_DESC_NUM_8822C)
#define BIT_CLEAR_BKQ_DESC_NUM_8822C(x) ((x) & (~BITS_BKQ_DESC_NUM_8822C))
#define BIT_GET_BKQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_BKQ_DESC_NUM_8822C) & BIT_MASK_BKQ_DESC_NUM_8822C)
#define BIT_SET_BKQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_BKQ_DESC_NUM_8822C(x) | BIT_BKQ_DESC_NUM_8822C(v))
/* 2 REG_HI0Q_TXBD_NUM_8822C */
#define BIT_HI0Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI0Q_DESC_MODE_8822C 12
#define BIT_MASK_HI0Q_DESC_MODE_8822C 0x3
#define BIT_HI0Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI0Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI0Q_DESC_MODE_8822C)
#define BITS_HI0Q_DESC_MODE_8822C \
(BIT_MASK_HI0Q_DESC_MODE_8822C << BIT_SHIFT_HI0Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI0Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI0Q_DESC_MODE_8822C))
#define BIT_GET_HI0Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_MODE_8822C) & \
BIT_MASK_HI0Q_DESC_MODE_8822C)
#define BIT_SET_HI0Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI0Q_DESC_MODE_8822C(x) | BIT_HI0Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI0Q_DESC_NUM_8822C 0
#define BIT_MASK_HI0Q_DESC_NUM_8822C 0xfff
#define BIT_HI0Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI0Q_DESC_NUM_8822C) << BIT_SHIFT_HI0Q_DESC_NUM_8822C)
#define BITS_HI0Q_DESC_NUM_8822C \
(BIT_MASK_HI0Q_DESC_NUM_8822C << BIT_SHIFT_HI0Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI0Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI0Q_DESC_NUM_8822C))
#define BIT_GET_HI0Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI0Q_DESC_NUM_8822C) & BIT_MASK_HI0Q_DESC_NUM_8822C)
#define BIT_SET_HI0Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI0Q_DESC_NUM_8822C(x) | BIT_HI0Q_DESC_NUM_8822C(v))
/* 2 REG_HI1Q_TXBD_NUM_8822C */
#define BIT_HI1Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI1Q_DESC_MODE_8822C 12
#define BIT_MASK_HI1Q_DESC_MODE_8822C 0x3
#define BIT_HI1Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI1Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI1Q_DESC_MODE_8822C)
#define BITS_HI1Q_DESC_MODE_8822C \
(BIT_MASK_HI1Q_DESC_MODE_8822C << BIT_SHIFT_HI1Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI1Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI1Q_DESC_MODE_8822C))
#define BIT_GET_HI1Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_MODE_8822C) & \
BIT_MASK_HI1Q_DESC_MODE_8822C)
#define BIT_SET_HI1Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI1Q_DESC_MODE_8822C(x) | BIT_HI1Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI1Q_DESC_NUM_8822C 0
#define BIT_MASK_HI1Q_DESC_NUM_8822C 0xfff
#define BIT_HI1Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI1Q_DESC_NUM_8822C) << BIT_SHIFT_HI1Q_DESC_NUM_8822C)
#define BITS_HI1Q_DESC_NUM_8822C \
(BIT_MASK_HI1Q_DESC_NUM_8822C << BIT_SHIFT_HI1Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI1Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI1Q_DESC_NUM_8822C))
#define BIT_GET_HI1Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI1Q_DESC_NUM_8822C) & BIT_MASK_HI1Q_DESC_NUM_8822C)
#define BIT_SET_HI1Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI1Q_DESC_NUM_8822C(x) | BIT_HI1Q_DESC_NUM_8822C(v))
/* 2 REG_HI2Q_TXBD_NUM_8822C */
#define BIT_HI2Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI2Q_DESC_MODE_8822C 12
#define BIT_MASK_HI2Q_DESC_MODE_8822C 0x3
#define BIT_HI2Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI2Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI2Q_DESC_MODE_8822C)
#define BITS_HI2Q_DESC_MODE_8822C \
(BIT_MASK_HI2Q_DESC_MODE_8822C << BIT_SHIFT_HI2Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI2Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI2Q_DESC_MODE_8822C))
#define BIT_GET_HI2Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_MODE_8822C) & \
BIT_MASK_HI2Q_DESC_MODE_8822C)
#define BIT_SET_HI2Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI2Q_DESC_MODE_8822C(x) | BIT_HI2Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI2Q_DESC_NUM_8822C 0
#define BIT_MASK_HI2Q_DESC_NUM_8822C 0xfff
#define BIT_HI2Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI2Q_DESC_NUM_8822C) << BIT_SHIFT_HI2Q_DESC_NUM_8822C)
#define BITS_HI2Q_DESC_NUM_8822C \
(BIT_MASK_HI2Q_DESC_NUM_8822C << BIT_SHIFT_HI2Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI2Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI2Q_DESC_NUM_8822C))
#define BIT_GET_HI2Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI2Q_DESC_NUM_8822C) & BIT_MASK_HI2Q_DESC_NUM_8822C)
#define BIT_SET_HI2Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI2Q_DESC_NUM_8822C(x) | BIT_HI2Q_DESC_NUM_8822C(v))
/* 2 REG_HI3Q_TXBD_NUM_8822C */
#define BIT_HI3Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI3Q_DESC_MODE_8822C 12
#define BIT_MASK_HI3Q_DESC_MODE_8822C 0x3
#define BIT_HI3Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI3Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI3Q_DESC_MODE_8822C)
#define BITS_HI3Q_DESC_MODE_8822C \
(BIT_MASK_HI3Q_DESC_MODE_8822C << BIT_SHIFT_HI3Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI3Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI3Q_DESC_MODE_8822C))
#define BIT_GET_HI3Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_MODE_8822C) & \
BIT_MASK_HI3Q_DESC_MODE_8822C)
#define BIT_SET_HI3Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI3Q_DESC_MODE_8822C(x) | BIT_HI3Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI3Q_DESC_NUM_8822C 0
#define BIT_MASK_HI3Q_DESC_NUM_8822C 0xfff
#define BIT_HI3Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI3Q_DESC_NUM_8822C) << BIT_SHIFT_HI3Q_DESC_NUM_8822C)
#define BITS_HI3Q_DESC_NUM_8822C \
(BIT_MASK_HI3Q_DESC_NUM_8822C << BIT_SHIFT_HI3Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI3Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI3Q_DESC_NUM_8822C))
#define BIT_GET_HI3Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI3Q_DESC_NUM_8822C) & BIT_MASK_HI3Q_DESC_NUM_8822C)
#define BIT_SET_HI3Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI3Q_DESC_NUM_8822C(x) | BIT_HI3Q_DESC_NUM_8822C(v))
/* 2 REG_HI4Q_TXBD_NUM_8822C */
#define BIT_HI4Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI4Q_DESC_MODE_8822C 12
#define BIT_MASK_HI4Q_DESC_MODE_8822C 0x3
#define BIT_HI4Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI4Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI4Q_DESC_MODE_8822C)
#define BITS_HI4Q_DESC_MODE_8822C \
(BIT_MASK_HI4Q_DESC_MODE_8822C << BIT_SHIFT_HI4Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI4Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI4Q_DESC_MODE_8822C))
#define BIT_GET_HI4Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_MODE_8822C) & \
BIT_MASK_HI4Q_DESC_MODE_8822C)
#define BIT_SET_HI4Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI4Q_DESC_MODE_8822C(x) | BIT_HI4Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI4Q_DESC_NUM_8822C 0
#define BIT_MASK_HI4Q_DESC_NUM_8822C 0xfff
#define BIT_HI4Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI4Q_DESC_NUM_8822C) << BIT_SHIFT_HI4Q_DESC_NUM_8822C)
#define BITS_HI4Q_DESC_NUM_8822C \
(BIT_MASK_HI4Q_DESC_NUM_8822C << BIT_SHIFT_HI4Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI4Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI4Q_DESC_NUM_8822C))
#define BIT_GET_HI4Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI4Q_DESC_NUM_8822C) & BIT_MASK_HI4Q_DESC_NUM_8822C)
#define BIT_SET_HI4Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI4Q_DESC_NUM_8822C(x) | BIT_HI4Q_DESC_NUM_8822C(v))
/* 2 REG_HI5Q_TXBD_NUM_8822C */
#define BIT_HI5Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI5Q_DESC_MODE_8822C 12
#define BIT_MASK_HI5Q_DESC_MODE_8822C 0x3
#define BIT_HI5Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI5Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI5Q_DESC_MODE_8822C)
#define BITS_HI5Q_DESC_MODE_8822C \
(BIT_MASK_HI5Q_DESC_MODE_8822C << BIT_SHIFT_HI5Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI5Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI5Q_DESC_MODE_8822C))
#define BIT_GET_HI5Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_MODE_8822C) & \
BIT_MASK_HI5Q_DESC_MODE_8822C)
#define BIT_SET_HI5Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI5Q_DESC_MODE_8822C(x) | BIT_HI5Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI5Q_DESC_NUM_8822C 0
#define BIT_MASK_HI5Q_DESC_NUM_8822C 0xfff
#define BIT_HI5Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI5Q_DESC_NUM_8822C) << BIT_SHIFT_HI5Q_DESC_NUM_8822C)
#define BITS_HI5Q_DESC_NUM_8822C \
(BIT_MASK_HI5Q_DESC_NUM_8822C << BIT_SHIFT_HI5Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI5Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI5Q_DESC_NUM_8822C))
#define BIT_GET_HI5Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI5Q_DESC_NUM_8822C) & BIT_MASK_HI5Q_DESC_NUM_8822C)
#define BIT_SET_HI5Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI5Q_DESC_NUM_8822C(x) | BIT_HI5Q_DESC_NUM_8822C(v))
/* 2 REG_HI6Q_TXBD_NUM_8822C */
#define BIT_HI6Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI6Q_DESC_MODE_8822C 12
#define BIT_MASK_HI6Q_DESC_MODE_8822C 0x3
#define BIT_HI6Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI6Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI6Q_DESC_MODE_8822C)
#define BITS_HI6Q_DESC_MODE_8822C \
(BIT_MASK_HI6Q_DESC_MODE_8822C << BIT_SHIFT_HI6Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI6Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI6Q_DESC_MODE_8822C))
#define BIT_GET_HI6Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_MODE_8822C) & \
BIT_MASK_HI6Q_DESC_MODE_8822C)
#define BIT_SET_HI6Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI6Q_DESC_MODE_8822C(x) | BIT_HI6Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI6Q_DESC_NUM_8822C 0
#define BIT_MASK_HI6Q_DESC_NUM_8822C 0xfff
#define BIT_HI6Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI6Q_DESC_NUM_8822C) << BIT_SHIFT_HI6Q_DESC_NUM_8822C)
#define BITS_HI6Q_DESC_NUM_8822C \
(BIT_MASK_HI6Q_DESC_NUM_8822C << BIT_SHIFT_HI6Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI6Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI6Q_DESC_NUM_8822C))
#define BIT_GET_HI6Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI6Q_DESC_NUM_8822C) & BIT_MASK_HI6Q_DESC_NUM_8822C)
#define BIT_SET_HI6Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI6Q_DESC_NUM_8822C(x) | BIT_HI6Q_DESC_NUM_8822C(v))
/* 2 REG_HI7Q_TXBD_NUM_8822C */
#define BIT_HI7Q_FLAG_8822C BIT(14)
#define BIT_SHIFT_HI7Q_DESC_MODE_8822C 12
#define BIT_MASK_HI7Q_DESC_MODE_8822C 0x3
#define BIT_HI7Q_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_HI7Q_DESC_MODE_8822C) \
<< BIT_SHIFT_HI7Q_DESC_MODE_8822C)
#define BITS_HI7Q_DESC_MODE_8822C \
(BIT_MASK_HI7Q_DESC_MODE_8822C << BIT_SHIFT_HI7Q_DESC_MODE_8822C)
#define BIT_CLEAR_HI7Q_DESC_MODE_8822C(x) ((x) & (~BITS_HI7Q_DESC_MODE_8822C))
#define BIT_GET_HI7Q_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_MODE_8822C) & \
BIT_MASK_HI7Q_DESC_MODE_8822C)
#define BIT_SET_HI7Q_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_HI7Q_DESC_MODE_8822C(x) | BIT_HI7Q_DESC_MODE_8822C(v))
#define BIT_SHIFT_HI7Q_DESC_NUM_8822C 0
#define BIT_MASK_HI7Q_DESC_NUM_8822C 0xfff
#define BIT_HI7Q_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_HI7Q_DESC_NUM_8822C) << BIT_SHIFT_HI7Q_DESC_NUM_8822C)
#define BITS_HI7Q_DESC_NUM_8822C \
(BIT_MASK_HI7Q_DESC_NUM_8822C << BIT_SHIFT_HI7Q_DESC_NUM_8822C)
#define BIT_CLEAR_HI7Q_DESC_NUM_8822C(x) ((x) & (~BITS_HI7Q_DESC_NUM_8822C))
#define BIT_GET_HI7Q_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_HI7Q_DESC_NUM_8822C) & BIT_MASK_HI7Q_DESC_NUM_8822C)
#define BIT_SET_HI7Q_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_HI7Q_DESC_NUM_8822C(x) | BIT_HI7Q_DESC_NUM_8822C(v))
/* 2 REG_TSFTIMER_HCI_8822C */
#define BIT_SHIFT_TSFT2_HCI_8822C 16
#define BIT_MASK_TSFT2_HCI_8822C 0xffff
#define BIT_TSFT2_HCI_8822C(x) \
(((x) & BIT_MASK_TSFT2_HCI_8822C) << BIT_SHIFT_TSFT2_HCI_8822C)
#define BITS_TSFT2_HCI_8822C \
(BIT_MASK_TSFT2_HCI_8822C << BIT_SHIFT_TSFT2_HCI_8822C)
#define BIT_CLEAR_TSFT2_HCI_8822C(x) ((x) & (~BITS_TSFT2_HCI_8822C))
#define BIT_GET_TSFT2_HCI_8822C(x) \
(((x) >> BIT_SHIFT_TSFT2_HCI_8822C) & BIT_MASK_TSFT2_HCI_8822C)
#define BIT_SET_TSFT2_HCI_8822C(x, v) \
(BIT_CLEAR_TSFT2_HCI_8822C(x) | BIT_TSFT2_HCI_8822C(v))
#define BIT_SHIFT_TSFT1_HCI_8822C 0
#define BIT_MASK_TSFT1_HCI_8822C 0xffff
#define BIT_TSFT1_HCI_8822C(x) \
(((x) & BIT_MASK_TSFT1_HCI_8822C) << BIT_SHIFT_TSFT1_HCI_8822C)
#define BITS_TSFT1_HCI_8822C \
(BIT_MASK_TSFT1_HCI_8822C << BIT_SHIFT_TSFT1_HCI_8822C)
#define BIT_CLEAR_TSFT1_HCI_8822C(x) ((x) & (~BITS_TSFT1_HCI_8822C))
#define BIT_GET_TSFT1_HCI_8822C(x) \
(((x) >> BIT_SHIFT_TSFT1_HCI_8822C) & BIT_MASK_TSFT1_HCI_8822C)
#define BIT_SET_TSFT1_HCI_8822C(x, v) \
(BIT_CLEAR_TSFT1_HCI_8822C(x) | BIT_TSFT1_HCI_8822C(v))
/* 2 REG_BD_RWPTR_CLR_8822C */
#define BIT_CLR_HI7Q_HW_IDX_8822C BIT(29)
#define BIT_CLR_HI6Q_HW_IDX_8822C BIT(28)
#define BIT_CLR_HI5Q_HW_IDX_8822C BIT(27)
#define BIT_CLR_HI4Q_HW_IDX_8822C BIT(26)
#define BIT_CLR_HI3Q_HW_IDX_8822C BIT(25)
#define BIT_CLR_HI2Q_HW_IDX_8822C BIT(24)
#define BIT_CLR_HI1Q_HW_IDX_8822C BIT(23)
#define BIT_CLR_HI0Q_HW_IDX_8822C BIT(22)
#define BIT_CLR_BKQ_HW_IDX_8822C BIT(21)
#define BIT_CLR_BEQ_HW_IDX_8822C BIT(20)
#define BIT_CLR_VIQ_HW_IDX_8822C BIT(19)
#define BIT_CLR_VOQ_HW_IDX_8822C BIT(18)
#define BIT_CLR_MGQ_HW_IDX_8822C BIT(17)
#define BIT_CLR_RXQ_HW_IDX_8822C BIT(16)
#define BIT_CLR_HI7Q_HOST_IDX_8822C BIT(13)
#define BIT_CLR_HI6Q_HOST_IDX_8822C BIT(12)
#define BIT_CLR_HI5Q_HOST_IDX_8822C BIT(11)
#define BIT_CLR_HI4Q_HOST_IDX_8822C BIT(10)
#define BIT_CLR_HI3Q_HOST_IDX_8822C BIT(9)
#define BIT_CLR_HI2Q_HOST_IDX_8822C BIT(8)
#define BIT_CLR_HI1Q_HOST_IDX_8822C BIT(7)
#define BIT_CLR_HI0Q_HOST_IDX_8822C BIT(6)
#define BIT_CLR_BKQ_HOST_IDX_8822C BIT(5)
#define BIT_CLR_BEQ_HOST_IDX_8822C BIT(4)
#define BIT_CLR_VIQ_HOST_IDX_8822C BIT(3)
#define BIT_CLR_VOQ_HOST_IDX_8822C BIT(2)
#define BIT_CLR_MGQ_HOST_IDX_8822C BIT(1)
#define BIT_CLR_RXQ_HOST_IDX_8822C BIT(0)
/* 2 REG_VOQ_TXBD_IDX_8822C */
#define BIT_SHIFT_VOQ_HW_IDX_8822C 16
#define BIT_MASK_VOQ_HW_IDX_8822C 0xfff
#define BIT_VOQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_VOQ_HW_IDX_8822C) << BIT_SHIFT_VOQ_HW_IDX_8822C)
#define BITS_VOQ_HW_IDX_8822C \
(BIT_MASK_VOQ_HW_IDX_8822C << BIT_SHIFT_VOQ_HW_IDX_8822C)
#define BIT_CLEAR_VOQ_HW_IDX_8822C(x) ((x) & (~BITS_VOQ_HW_IDX_8822C))
#define BIT_GET_VOQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_VOQ_HW_IDX_8822C) & BIT_MASK_VOQ_HW_IDX_8822C)
#define BIT_SET_VOQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_VOQ_HW_IDX_8822C(x) | BIT_VOQ_HW_IDX_8822C(v))
#define BIT_SHIFT_VOQ_HOST_IDX_8822C 0
#define BIT_MASK_VOQ_HOST_IDX_8822C 0xfff
#define BIT_VOQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_VOQ_HOST_IDX_8822C) << BIT_SHIFT_VOQ_HOST_IDX_8822C)
#define BITS_VOQ_HOST_IDX_8822C \
(BIT_MASK_VOQ_HOST_IDX_8822C << BIT_SHIFT_VOQ_HOST_IDX_8822C)
#define BIT_CLEAR_VOQ_HOST_IDX_8822C(x) ((x) & (~BITS_VOQ_HOST_IDX_8822C))
#define BIT_GET_VOQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_VOQ_HOST_IDX_8822C) & BIT_MASK_VOQ_HOST_IDX_8822C)
#define BIT_SET_VOQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_VOQ_HOST_IDX_8822C(x) | BIT_VOQ_HOST_IDX_8822C(v))
/* 2 REG_VIQ_TXBD_IDX_8822C */
#define BIT_SHIFT_VIQ_HW_IDX_8822C 16
#define BIT_MASK_VIQ_HW_IDX_8822C 0xfff
#define BIT_VIQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_VIQ_HW_IDX_8822C) << BIT_SHIFT_VIQ_HW_IDX_8822C)
#define BITS_VIQ_HW_IDX_8822C \
(BIT_MASK_VIQ_HW_IDX_8822C << BIT_SHIFT_VIQ_HW_IDX_8822C)
#define BIT_CLEAR_VIQ_HW_IDX_8822C(x) ((x) & (~BITS_VIQ_HW_IDX_8822C))
#define BIT_GET_VIQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_VIQ_HW_IDX_8822C) & BIT_MASK_VIQ_HW_IDX_8822C)
#define BIT_SET_VIQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_VIQ_HW_IDX_8822C(x) | BIT_VIQ_HW_IDX_8822C(v))
#define BIT_SHIFT_VIQ_HOST_IDX_8822C 0
#define BIT_MASK_VIQ_HOST_IDX_8822C 0xfff
#define BIT_VIQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_VIQ_HOST_IDX_8822C) << BIT_SHIFT_VIQ_HOST_IDX_8822C)
#define BITS_VIQ_HOST_IDX_8822C \
(BIT_MASK_VIQ_HOST_IDX_8822C << BIT_SHIFT_VIQ_HOST_IDX_8822C)
#define BIT_CLEAR_VIQ_HOST_IDX_8822C(x) ((x) & (~BITS_VIQ_HOST_IDX_8822C))
#define BIT_GET_VIQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_VIQ_HOST_IDX_8822C) & BIT_MASK_VIQ_HOST_IDX_8822C)
#define BIT_SET_VIQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_VIQ_HOST_IDX_8822C(x) | BIT_VIQ_HOST_IDX_8822C(v))
/* 2 REG_BEQ_TXBD_IDX_8822C */
#define BIT_SHIFT_BEQ_HW_IDX_8822C 16
#define BIT_MASK_BEQ_HW_IDX_8822C 0xfff
#define BIT_BEQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_BEQ_HW_IDX_8822C) << BIT_SHIFT_BEQ_HW_IDX_8822C)
#define BITS_BEQ_HW_IDX_8822C \
(BIT_MASK_BEQ_HW_IDX_8822C << BIT_SHIFT_BEQ_HW_IDX_8822C)
#define BIT_CLEAR_BEQ_HW_IDX_8822C(x) ((x) & (~BITS_BEQ_HW_IDX_8822C))
#define BIT_GET_BEQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_BEQ_HW_IDX_8822C) & BIT_MASK_BEQ_HW_IDX_8822C)
#define BIT_SET_BEQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_BEQ_HW_IDX_8822C(x) | BIT_BEQ_HW_IDX_8822C(v))
#define BIT_SHIFT_BEQ_HOST_IDX_8822C 0
#define BIT_MASK_BEQ_HOST_IDX_8822C 0xfff
#define BIT_BEQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_BEQ_HOST_IDX_8822C) << BIT_SHIFT_BEQ_HOST_IDX_8822C)
#define BITS_BEQ_HOST_IDX_8822C \
(BIT_MASK_BEQ_HOST_IDX_8822C << BIT_SHIFT_BEQ_HOST_IDX_8822C)
#define BIT_CLEAR_BEQ_HOST_IDX_8822C(x) ((x) & (~BITS_BEQ_HOST_IDX_8822C))
#define BIT_GET_BEQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_BEQ_HOST_IDX_8822C) & BIT_MASK_BEQ_HOST_IDX_8822C)
#define BIT_SET_BEQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_BEQ_HOST_IDX_8822C(x) | BIT_BEQ_HOST_IDX_8822C(v))
/* 2 REG_BKQ_TXBD_IDX_8822C */
#define BIT_SHIFT_BKQ_HW_IDX_8822C 16
#define BIT_MASK_BKQ_HW_IDX_8822C 0xfff
#define BIT_BKQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_BKQ_HW_IDX_8822C) << BIT_SHIFT_BKQ_HW_IDX_8822C)
#define BITS_BKQ_HW_IDX_8822C \
(BIT_MASK_BKQ_HW_IDX_8822C << BIT_SHIFT_BKQ_HW_IDX_8822C)
#define BIT_CLEAR_BKQ_HW_IDX_8822C(x) ((x) & (~BITS_BKQ_HW_IDX_8822C))
#define BIT_GET_BKQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_BKQ_HW_IDX_8822C) & BIT_MASK_BKQ_HW_IDX_8822C)
#define BIT_SET_BKQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_BKQ_HW_IDX_8822C(x) | BIT_BKQ_HW_IDX_8822C(v))
#define BIT_SHIFT_BKQ_HOST_IDX_8822C 0
#define BIT_MASK_BKQ_HOST_IDX_8822C 0xfff
#define BIT_BKQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_BKQ_HOST_IDX_8822C) << BIT_SHIFT_BKQ_HOST_IDX_8822C)
#define BITS_BKQ_HOST_IDX_8822C \
(BIT_MASK_BKQ_HOST_IDX_8822C << BIT_SHIFT_BKQ_HOST_IDX_8822C)
#define BIT_CLEAR_BKQ_HOST_IDX_8822C(x) ((x) & (~BITS_BKQ_HOST_IDX_8822C))
#define BIT_GET_BKQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_BKQ_HOST_IDX_8822C) & BIT_MASK_BKQ_HOST_IDX_8822C)
#define BIT_SET_BKQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_BKQ_HOST_IDX_8822C(x) | BIT_BKQ_HOST_IDX_8822C(v))
/* 2 REG_MGQ_TXBD_IDX_8822C */
#define BIT_SHIFT_MGQ_HW_IDX_8822C 16
#define BIT_MASK_MGQ_HW_IDX_8822C 0xfff
#define BIT_MGQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_MGQ_HW_IDX_8822C) << BIT_SHIFT_MGQ_HW_IDX_8822C)
#define BITS_MGQ_HW_IDX_8822C \
(BIT_MASK_MGQ_HW_IDX_8822C << BIT_SHIFT_MGQ_HW_IDX_8822C)
#define BIT_CLEAR_MGQ_HW_IDX_8822C(x) ((x) & (~BITS_MGQ_HW_IDX_8822C))
#define BIT_GET_MGQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_HW_IDX_8822C) & BIT_MASK_MGQ_HW_IDX_8822C)
#define BIT_SET_MGQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_MGQ_HW_IDX_8822C(x) | BIT_MGQ_HW_IDX_8822C(v))
#define BIT_SHIFT_MGQ_HOST_IDX_8822C 0
#define BIT_MASK_MGQ_HOST_IDX_8822C 0xfff
#define BIT_MGQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_MGQ_HOST_IDX_8822C) << BIT_SHIFT_MGQ_HOST_IDX_8822C)
#define BITS_MGQ_HOST_IDX_8822C \
(BIT_MASK_MGQ_HOST_IDX_8822C << BIT_SHIFT_MGQ_HOST_IDX_8822C)
#define BIT_CLEAR_MGQ_HOST_IDX_8822C(x) ((x) & (~BITS_MGQ_HOST_IDX_8822C))
#define BIT_GET_MGQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_HOST_IDX_8822C) & BIT_MASK_MGQ_HOST_IDX_8822C)
#define BIT_SET_MGQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_MGQ_HOST_IDX_8822C(x) | BIT_MGQ_HOST_IDX_8822C(v))
/* 2 REG_RXQ_RXBD_IDX_8822C */
#define BIT_SHIFT_RXQ_HW_IDX_8822C 16
#define BIT_MASK_RXQ_HW_IDX_8822C 0xfff
#define BIT_RXQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_RXQ_HW_IDX_8822C) << BIT_SHIFT_RXQ_HW_IDX_8822C)
#define BITS_RXQ_HW_IDX_8822C \
(BIT_MASK_RXQ_HW_IDX_8822C << BIT_SHIFT_RXQ_HW_IDX_8822C)
#define BIT_CLEAR_RXQ_HW_IDX_8822C(x) ((x) & (~BITS_RXQ_HW_IDX_8822C))
#define BIT_GET_RXQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RXQ_HW_IDX_8822C) & BIT_MASK_RXQ_HW_IDX_8822C)
#define BIT_SET_RXQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_RXQ_HW_IDX_8822C(x) | BIT_RXQ_HW_IDX_8822C(v))
#define BIT_SHIFT_RXQ_HOST_IDX_8822C 0
#define BIT_MASK_RXQ_HOST_IDX_8822C 0xfff
#define BIT_RXQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_RXQ_HOST_IDX_8822C) << BIT_SHIFT_RXQ_HOST_IDX_8822C)
#define BITS_RXQ_HOST_IDX_8822C \
(BIT_MASK_RXQ_HOST_IDX_8822C << BIT_SHIFT_RXQ_HOST_IDX_8822C)
#define BIT_CLEAR_RXQ_HOST_IDX_8822C(x) ((x) & (~BITS_RXQ_HOST_IDX_8822C))
#define BIT_GET_RXQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RXQ_HOST_IDX_8822C) & BIT_MASK_RXQ_HOST_IDX_8822C)
#define BIT_SET_RXQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_RXQ_HOST_IDX_8822C(x) | BIT_RXQ_HOST_IDX_8822C(v))
/* 2 REG_HI0Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI0Q_HW_IDX_8822C 16
#define BIT_MASK_HI0Q_HW_IDX_8822C 0xfff
#define BIT_HI0Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI0Q_HW_IDX_8822C) << BIT_SHIFT_HI0Q_HW_IDX_8822C)
#define BITS_HI0Q_HW_IDX_8822C \
(BIT_MASK_HI0Q_HW_IDX_8822C << BIT_SHIFT_HI0Q_HW_IDX_8822C)
#define BIT_CLEAR_HI0Q_HW_IDX_8822C(x) ((x) & (~BITS_HI0Q_HW_IDX_8822C))
#define BIT_GET_HI0Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI0Q_HW_IDX_8822C) & BIT_MASK_HI0Q_HW_IDX_8822C)
#define BIT_SET_HI0Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI0Q_HW_IDX_8822C(x) | BIT_HI0Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI0Q_HOST_IDX_8822C 0
#define BIT_MASK_HI0Q_HOST_IDX_8822C 0xfff
#define BIT_HI0Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI0Q_HOST_IDX_8822C) << BIT_SHIFT_HI0Q_HOST_IDX_8822C)
#define BITS_HI0Q_HOST_IDX_8822C \
(BIT_MASK_HI0Q_HOST_IDX_8822C << BIT_SHIFT_HI0Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI0Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI0Q_HOST_IDX_8822C))
#define BIT_GET_HI0Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI0Q_HOST_IDX_8822C) & BIT_MASK_HI0Q_HOST_IDX_8822C)
#define BIT_SET_HI0Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI0Q_HOST_IDX_8822C(x) | BIT_HI0Q_HOST_IDX_8822C(v))
/* 2 REG_HI1Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI1Q_HW_IDX_8822C 16
#define BIT_MASK_HI1Q_HW_IDX_8822C 0xfff
#define BIT_HI1Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI1Q_HW_IDX_8822C) << BIT_SHIFT_HI1Q_HW_IDX_8822C)
#define BITS_HI1Q_HW_IDX_8822C \
(BIT_MASK_HI1Q_HW_IDX_8822C << BIT_SHIFT_HI1Q_HW_IDX_8822C)
#define BIT_CLEAR_HI1Q_HW_IDX_8822C(x) ((x) & (~BITS_HI1Q_HW_IDX_8822C))
#define BIT_GET_HI1Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI1Q_HW_IDX_8822C) & BIT_MASK_HI1Q_HW_IDX_8822C)
#define BIT_SET_HI1Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI1Q_HW_IDX_8822C(x) | BIT_HI1Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI1Q_HOST_IDX_8822C 0
#define BIT_MASK_HI1Q_HOST_IDX_8822C 0xfff
#define BIT_HI1Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI1Q_HOST_IDX_8822C) << BIT_SHIFT_HI1Q_HOST_IDX_8822C)
#define BITS_HI1Q_HOST_IDX_8822C \
(BIT_MASK_HI1Q_HOST_IDX_8822C << BIT_SHIFT_HI1Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI1Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI1Q_HOST_IDX_8822C))
#define BIT_GET_HI1Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI1Q_HOST_IDX_8822C) & BIT_MASK_HI1Q_HOST_IDX_8822C)
#define BIT_SET_HI1Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI1Q_HOST_IDX_8822C(x) | BIT_HI1Q_HOST_IDX_8822C(v))
/* 2 REG_HI2Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI2Q_HW_IDX_8822C 16
#define BIT_MASK_HI2Q_HW_IDX_8822C 0xfff
#define BIT_HI2Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI2Q_HW_IDX_8822C) << BIT_SHIFT_HI2Q_HW_IDX_8822C)
#define BITS_HI2Q_HW_IDX_8822C \
(BIT_MASK_HI2Q_HW_IDX_8822C << BIT_SHIFT_HI2Q_HW_IDX_8822C)
#define BIT_CLEAR_HI2Q_HW_IDX_8822C(x) ((x) & (~BITS_HI2Q_HW_IDX_8822C))
#define BIT_GET_HI2Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI2Q_HW_IDX_8822C) & BIT_MASK_HI2Q_HW_IDX_8822C)
#define BIT_SET_HI2Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI2Q_HW_IDX_8822C(x) | BIT_HI2Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI2Q_HOST_IDX_8822C 0
#define BIT_MASK_HI2Q_HOST_IDX_8822C 0xfff
#define BIT_HI2Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI2Q_HOST_IDX_8822C) << BIT_SHIFT_HI2Q_HOST_IDX_8822C)
#define BITS_HI2Q_HOST_IDX_8822C \
(BIT_MASK_HI2Q_HOST_IDX_8822C << BIT_SHIFT_HI2Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI2Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI2Q_HOST_IDX_8822C))
#define BIT_GET_HI2Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI2Q_HOST_IDX_8822C) & BIT_MASK_HI2Q_HOST_IDX_8822C)
#define BIT_SET_HI2Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI2Q_HOST_IDX_8822C(x) | BIT_HI2Q_HOST_IDX_8822C(v))
/* 2 REG_HI3Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI3Q_HW_IDX_8822C 16
#define BIT_MASK_HI3Q_HW_IDX_8822C 0xfff
#define BIT_HI3Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI3Q_HW_IDX_8822C) << BIT_SHIFT_HI3Q_HW_IDX_8822C)
#define BITS_HI3Q_HW_IDX_8822C \
(BIT_MASK_HI3Q_HW_IDX_8822C << BIT_SHIFT_HI3Q_HW_IDX_8822C)
#define BIT_CLEAR_HI3Q_HW_IDX_8822C(x) ((x) & (~BITS_HI3Q_HW_IDX_8822C))
#define BIT_GET_HI3Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI3Q_HW_IDX_8822C) & BIT_MASK_HI3Q_HW_IDX_8822C)
#define BIT_SET_HI3Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI3Q_HW_IDX_8822C(x) | BIT_HI3Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI3Q_HOST_IDX_8822C 0
#define BIT_MASK_HI3Q_HOST_IDX_8822C 0xfff
#define BIT_HI3Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI3Q_HOST_IDX_8822C) << BIT_SHIFT_HI3Q_HOST_IDX_8822C)
#define BITS_HI3Q_HOST_IDX_8822C \
(BIT_MASK_HI3Q_HOST_IDX_8822C << BIT_SHIFT_HI3Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI3Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI3Q_HOST_IDX_8822C))
#define BIT_GET_HI3Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI3Q_HOST_IDX_8822C) & BIT_MASK_HI3Q_HOST_IDX_8822C)
#define BIT_SET_HI3Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI3Q_HOST_IDX_8822C(x) | BIT_HI3Q_HOST_IDX_8822C(v))
/* 2 REG_HI4Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI4Q_HW_IDX_8822C 16
#define BIT_MASK_HI4Q_HW_IDX_8822C 0xfff
#define BIT_HI4Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI4Q_HW_IDX_8822C) << BIT_SHIFT_HI4Q_HW_IDX_8822C)
#define BITS_HI4Q_HW_IDX_8822C \
(BIT_MASK_HI4Q_HW_IDX_8822C << BIT_SHIFT_HI4Q_HW_IDX_8822C)
#define BIT_CLEAR_HI4Q_HW_IDX_8822C(x) ((x) & (~BITS_HI4Q_HW_IDX_8822C))
#define BIT_GET_HI4Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI4Q_HW_IDX_8822C) & BIT_MASK_HI4Q_HW_IDX_8822C)
#define BIT_SET_HI4Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI4Q_HW_IDX_8822C(x) | BIT_HI4Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI4Q_HOST_IDX_8822C 0
#define BIT_MASK_HI4Q_HOST_IDX_8822C 0xfff
#define BIT_HI4Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI4Q_HOST_IDX_8822C) << BIT_SHIFT_HI4Q_HOST_IDX_8822C)
#define BITS_HI4Q_HOST_IDX_8822C \
(BIT_MASK_HI4Q_HOST_IDX_8822C << BIT_SHIFT_HI4Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI4Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI4Q_HOST_IDX_8822C))
#define BIT_GET_HI4Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI4Q_HOST_IDX_8822C) & BIT_MASK_HI4Q_HOST_IDX_8822C)
#define BIT_SET_HI4Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI4Q_HOST_IDX_8822C(x) | BIT_HI4Q_HOST_IDX_8822C(v))
/* 2 REG_HI5Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI5Q_HW_IDX_8822C 16
#define BIT_MASK_HI5Q_HW_IDX_8822C 0xfff
#define BIT_HI5Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI5Q_HW_IDX_8822C) << BIT_SHIFT_HI5Q_HW_IDX_8822C)
#define BITS_HI5Q_HW_IDX_8822C \
(BIT_MASK_HI5Q_HW_IDX_8822C << BIT_SHIFT_HI5Q_HW_IDX_8822C)
#define BIT_CLEAR_HI5Q_HW_IDX_8822C(x) ((x) & (~BITS_HI5Q_HW_IDX_8822C))
#define BIT_GET_HI5Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI5Q_HW_IDX_8822C) & BIT_MASK_HI5Q_HW_IDX_8822C)
#define BIT_SET_HI5Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI5Q_HW_IDX_8822C(x) | BIT_HI5Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI5Q_HOST_IDX_8822C 0
#define BIT_MASK_HI5Q_HOST_IDX_8822C 0xfff
#define BIT_HI5Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI5Q_HOST_IDX_8822C) << BIT_SHIFT_HI5Q_HOST_IDX_8822C)
#define BITS_HI5Q_HOST_IDX_8822C \
(BIT_MASK_HI5Q_HOST_IDX_8822C << BIT_SHIFT_HI5Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI5Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI5Q_HOST_IDX_8822C))
#define BIT_GET_HI5Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI5Q_HOST_IDX_8822C) & BIT_MASK_HI5Q_HOST_IDX_8822C)
#define BIT_SET_HI5Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI5Q_HOST_IDX_8822C(x) | BIT_HI5Q_HOST_IDX_8822C(v))
/* 2 REG_HI6Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI6Q_HW_IDX_8822C 16
#define BIT_MASK_HI6Q_HW_IDX_8822C 0xfff
#define BIT_HI6Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI6Q_HW_IDX_8822C) << BIT_SHIFT_HI6Q_HW_IDX_8822C)
#define BITS_HI6Q_HW_IDX_8822C \
(BIT_MASK_HI6Q_HW_IDX_8822C << BIT_SHIFT_HI6Q_HW_IDX_8822C)
#define BIT_CLEAR_HI6Q_HW_IDX_8822C(x) ((x) & (~BITS_HI6Q_HW_IDX_8822C))
#define BIT_GET_HI6Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI6Q_HW_IDX_8822C) & BIT_MASK_HI6Q_HW_IDX_8822C)
#define BIT_SET_HI6Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI6Q_HW_IDX_8822C(x) | BIT_HI6Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI6Q_HOST_IDX_8822C 0
#define BIT_MASK_HI6Q_HOST_IDX_8822C 0xfff
#define BIT_HI6Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI6Q_HOST_IDX_8822C) << BIT_SHIFT_HI6Q_HOST_IDX_8822C)
#define BITS_HI6Q_HOST_IDX_8822C \
(BIT_MASK_HI6Q_HOST_IDX_8822C << BIT_SHIFT_HI6Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI6Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI6Q_HOST_IDX_8822C))
#define BIT_GET_HI6Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI6Q_HOST_IDX_8822C) & BIT_MASK_HI6Q_HOST_IDX_8822C)
#define BIT_SET_HI6Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI6Q_HOST_IDX_8822C(x) | BIT_HI6Q_HOST_IDX_8822C(v))
/* 2 REG_HI7Q_TXBD_IDX_8822C */
#define BIT_SHIFT_HI7Q_HW_IDX_8822C 16
#define BIT_MASK_HI7Q_HW_IDX_8822C 0xfff
#define BIT_HI7Q_HW_IDX_8822C(x) \
(((x) & BIT_MASK_HI7Q_HW_IDX_8822C) << BIT_SHIFT_HI7Q_HW_IDX_8822C)
#define BITS_HI7Q_HW_IDX_8822C \
(BIT_MASK_HI7Q_HW_IDX_8822C << BIT_SHIFT_HI7Q_HW_IDX_8822C)
#define BIT_CLEAR_HI7Q_HW_IDX_8822C(x) ((x) & (~BITS_HI7Q_HW_IDX_8822C))
#define BIT_GET_HI7Q_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI7Q_HW_IDX_8822C) & BIT_MASK_HI7Q_HW_IDX_8822C)
#define BIT_SET_HI7Q_HW_IDX_8822C(x, v) \
(BIT_CLEAR_HI7Q_HW_IDX_8822C(x) | BIT_HI7Q_HW_IDX_8822C(v))
#define BIT_SHIFT_HI7Q_HOST_IDX_8822C 0
#define BIT_MASK_HI7Q_HOST_IDX_8822C 0xfff
#define BIT_HI7Q_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_HI7Q_HOST_IDX_8822C) << BIT_SHIFT_HI7Q_HOST_IDX_8822C)
#define BITS_HI7Q_HOST_IDX_8822C \
(BIT_MASK_HI7Q_HOST_IDX_8822C << BIT_SHIFT_HI7Q_HOST_IDX_8822C)
#define BIT_CLEAR_HI7Q_HOST_IDX_8822C(x) ((x) & (~BITS_HI7Q_HOST_IDX_8822C))
#define BIT_GET_HI7Q_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HI7Q_HOST_IDX_8822C) & BIT_MASK_HI7Q_HOST_IDX_8822C)
#define BIT_SET_HI7Q_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_HI7Q_HOST_IDX_8822C(x) | BIT_HI7Q_HOST_IDX_8822C(v))
/* 2 REG_DBG_SEL_V1_8822C */
#define BIT_SHIFT_DBG_SEL_8822C 0
#define BIT_MASK_DBG_SEL_8822C 0xff
#define BIT_DBG_SEL_8822C(x) \
(((x) & BIT_MASK_DBG_SEL_8822C) << BIT_SHIFT_DBG_SEL_8822C)
#define BITS_DBG_SEL_8822C (BIT_MASK_DBG_SEL_8822C << BIT_SHIFT_DBG_SEL_8822C)
#define BIT_CLEAR_DBG_SEL_8822C(x) ((x) & (~BITS_DBG_SEL_8822C))
#define BIT_GET_DBG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_DBG_SEL_8822C) & BIT_MASK_DBG_SEL_8822C)
#define BIT_SET_DBG_SEL_8822C(x, v) \
(BIT_CLEAR_DBG_SEL_8822C(x) | BIT_DBG_SEL_8822C(v))
/* 2 REG_PCIE_HRPWM1_V1_8822C */
#define BIT_SHIFT_PCIE_HRPWM_8822C 0
#define BIT_MASK_PCIE_HRPWM_8822C 0xff
#define BIT_PCIE_HRPWM_8822C(x) \
(((x) & BIT_MASK_PCIE_HRPWM_8822C) << BIT_SHIFT_PCIE_HRPWM_8822C)
#define BITS_PCIE_HRPWM_8822C \
(BIT_MASK_PCIE_HRPWM_8822C << BIT_SHIFT_PCIE_HRPWM_8822C)
#define BIT_CLEAR_PCIE_HRPWM_8822C(x) ((x) & (~BITS_PCIE_HRPWM_8822C))
#define BIT_GET_PCIE_HRPWM_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM_8822C) & BIT_MASK_PCIE_HRPWM_8822C)
#define BIT_SET_PCIE_HRPWM_8822C(x, v) \
(BIT_CLEAR_PCIE_HRPWM_8822C(x) | BIT_PCIE_HRPWM_8822C(v))
/* 2 REG_PCIE_HCPWM1_V1_8822C */
#define BIT_SHIFT_PCIE_HCPWM_8822C 0
#define BIT_MASK_PCIE_HCPWM_8822C 0xff
#define BIT_PCIE_HCPWM_8822C(x) \
(((x) & BIT_MASK_PCIE_HCPWM_8822C) << BIT_SHIFT_PCIE_HCPWM_8822C)
#define BITS_PCIE_HCPWM_8822C \
(BIT_MASK_PCIE_HCPWM_8822C << BIT_SHIFT_PCIE_HCPWM_8822C)
#define BIT_CLEAR_PCIE_HCPWM_8822C(x) ((x) & (~BITS_PCIE_HCPWM_8822C))
#define BIT_GET_PCIE_HCPWM_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM_8822C) & BIT_MASK_PCIE_HCPWM_8822C)
#define BIT_SET_PCIE_HCPWM_8822C(x, v) \
(BIT_CLEAR_PCIE_HCPWM_8822C(x) | BIT_PCIE_HCPWM_8822C(v))
/* 2 REG_PCIE_CTRL2_8822C */
#define BIT_DIS_TXDMA_PRE_8822C BIT(7)
#define BIT_DIS_RXDMA_PRE_8822C BIT(6)
#define BIT_SHIFT_HPS_CLKR_PCIE_8822C 4
#define BIT_MASK_HPS_CLKR_PCIE_8822C 0x3
#define BIT_HPS_CLKR_PCIE_8822C(x) \
(((x) & BIT_MASK_HPS_CLKR_PCIE_8822C) << BIT_SHIFT_HPS_CLKR_PCIE_8822C)
#define BITS_HPS_CLKR_PCIE_8822C \
(BIT_MASK_HPS_CLKR_PCIE_8822C << BIT_SHIFT_HPS_CLKR_PCIE_8822C)
#define BIT_CLEAR_HPS_CLKR_PCIE_8822C(x) ((x) & (~BITS_HPS_CLKR_PCIE_8822C))
#define BIT_GET_HPS_CLKR_PCIE_8822C(x) \
(((x) >> BIT_SHIFT_HPS_CLKR_PCIE_8822C) & BIT_MASK_HPS_CLKR_PCIE_8822C)
#define BIT_SET_HPS_CLKR_PCIE_8822C(x, v) \
(BIT_CLEAR_HPS_CLKR_PCIE_8822C(x) | BIT_HPS_CLKR_PCIE_8822C(v))
#define BIT_PCIE_INT_8822C BIT(3)
#define BIT_TXFLAG_EXIT_L1_EN_8822C BIT(2)
#define BIT_EN_RXDMA_ALIGN_8822C BIT(1)
#define BIT_EN_TXDMA_ALIGN_8822C BIT(0)
/* 2 REG_PCIE_HRPWM2_V1_8822C */
#define BIT_SHIFT_PCIE_HRPWM2_8822C 0
#define BIT_MASK_PCIE_HRPWM2_8822C 0xffff
#define BIT_PCIE_HRPWM2_8822C(x) \
(((x) & BIT_MASK_PCIE_HRPWM2_8822C) << BIT_SHIFT_PCIE_HRPWM2_8822C)
#define BITS_PCIE_HRPWM2_8822C \
(BIT_MASK_PCIE_HRPWM2_8822C << BIT_SHIFT_PCIE_HRPWM2_8822C)
#define BIT_CLEAR_PCIE_HRPWM2_8822C(x) ((x) & (~BITS_PCIE_HRPWM2_8822C))
#define BIT_GET_PCIE_HRPWM2_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_HRPWM2_8822C) & BIT_MASK_PCIE_HRPWM2_8822C)
#define BIT_SET_PCIE_HRPWM2_8822C(x, v) \
(BIT_CLEAR_PCIE_HRPWM2_8822C(x) | BIT_PCIE_HRPWM2_8822C(v))
/* 2 REG_PCIE_HCPWM2_V1_8822C */
#define BIT_SHIFT_PCIE_HCPWM2_8822C 0
#define BIT_MASK_PCIE_HCPWM2_8822C 0xffff
#define BIT_PCIE_HCPWM2_8822C(x) \
(((x) & BIT_MASK_PCIE_HCPWM2_8822C) << BIT_SHIFT_PCIE_HCPWM2_8822C)
#define BITS_PCIE_HCPWM2_8822C \
(BIT_MASK_PCIE_HCPWM2_8822C << BIT_SHIFT_PCIE_HCPWM2_8822C)
#define BIT_CLEAR_PCIE_HCPWM2_8822C(x) ((x) & (~BITS_PCIE_HCPWM2_8822C))
#define BIT_GET_PCIE_HCPWM2_8822C(x) \
(((x) >> BIT_SHIFT_PCIE_HCPWM2_8822C) & BIT_MASK_PCIE_HCPWM2_8822C)
#define BIT_SET_PCIE_HCPWM2_8822C(x, v) \
(BIT_CLEAR_PCIE_HCPWM2_8822C(x) | BIT_PCIE_HCPWM2_8822C(v))
/* 2 REG_PCIE_H2C_MSG_V1_8822C */
#define BIT_SHIFT_DRV2FW_INFO_8822C 0
#define BIT_MASK_DRV2FW_INFO_8822C 0xffffffffL
#define BIT_DRV2FW_INFO_8822C(x) \
(((x) & BIT_MASK_DRV2FW_INFO_8822C) << BIT_SHIFT_DRV2FW_INFO_8822C)
#define BITS_DRV2FW_INFO_8822C \
(BIT_MASK_DRV2FW_INFO_8822C << BIT_SHIFT_DRV2FW_INFO_8822C)
#define BIT_CLEAR_DRV2FW_INFO_8822C(x) ((x) & (~BITS_DRV2FW_INFO_8822C))
#define BIT_GET_DRV2FW_INFO_8822C(x) \
(((x) >> BIT_SHIFT_DRV2FW_INFO_8822C) & BIT_MASK_DRV2FW_INFO_8822C)
#define BIT_SET_DRV2FW_INFO_8822C(x, v) \
(BIT_CLEAR_DRV2FW_INFO_8822C(x) | BIT_DRV2FW_INFO_8822C(v))
/* 2 REG_PCIE_C2H_MSG_V1_8822C */
#define BIT_SHIFT_HCI_PCIE_C2H_MSG_8822C 0
#define BIT_MASK_HCI_PCIE_C2H_MSG_8822C 0xffffffffL
#define BIT_HCI_PCIE_C2H_MSG_8822C(x) \
(((x) & BIT_MASK_HCI_PCIE_C2H_MSG_8822C) \
<< BIT_SHIFT_HCI_PCIE_C2H_MSG_8822C)
#define BITS_HCI_PCIE_C2H_MSG_8822C \
(BIT_MASK_HCI_PCIE_C2H_MSG_8822C << BIT_SHIFT_HCI_PCIE_C2H_MSG_8822C)
#define BIT_CLEAR_HCI_PCIE_C2H_MSG_8822C(x) \
((x) & (~BITS_HCI_PCIE_C2H_MSG_8822C))
#define BIT_GET_HCI_PCIE_C2H_MSG_8822C(x) \
(((x) >> BIT_SHIFT_HCI_PCIE_C2H_MSG_8822C) & \
BIT_MASK_HCI_PCIE_C2H_MSG_8822C)
#define BIT_SET_HCI_PCIE_C2H_MSG_8822C(x, v) \
(BIT_CLEAR_HCI_PCIE_C2H_MSG_8822C(x) | BIT_HCI_PCIE_C2H_MSG_8822C(v))
/* 2 REG_DBI_WDATA_V1_8822C */
#define BIT_SHIFT_DBI_WDATA_8822C 0
#define BIT_MASK_DBI_WDATA_8822C 0xffffffffL
#define BIT_DBI_WDATA_8822C(x) \
(((x) & BIT_MASK_DBI_WDATA_8822C) << BIT_SHIFT_DBI_WDATA_8822C)
#define BITS_DBI_WDATA_8822C \
(BIT_MASK_DBI_WDATA_8822C << BIT_SHIFT_DBI_WDATA_8822C)
#define BIT_CLEAR_DBI_WDATA_8822C(x) ((x) & (~BITS_DBI_WDATA_8822C))
#define BIT_GET_DBI_WDATA_8822C(x) \
(((x) >> BIT_SHIFT_DBI_WDATA_8822C) & BIT_MASK_DBI_WDATA_8822C)
#define BIT_SET_DBI_WDATA_8822C(x, v) \
(BIT_CLEAR_DBI_WDATA_8822C(x) | BIT_DBI_WDATA_8822C(v))
/* 2 REG_DBI_RDATA_V1_8822C */
#define BIT_SHIFT_DBI_RDATA_8822C 0
#define BIT_MASK_DBI_RDATA_8822C 0xffffffffL
#define BIT_DBI_RDATA_8822C(x) \
(((x) & BIT_MASK_DBI_RDATA_8822C) << BIT_SHIFT_DBI_RDATA_8822C)
#define BITS_DBI_RDATA_8822C \
(BIT_MASK_DBI_RDATA_8822C << BIT_SHIFT_DBI_RDATA_8822C)
#define BIT_CLEAR_DBI_RDATA_8822C(x) ((x) & (~BITS_DBI_RDATA_8822C))
#define BIT_GET_DBI_RDATA_8822C(x) \
(((x) >> BIT_SHIFT_DBI_RDATA_8822C) & BIT_MASK_DBI_RDATA_8822C)
#define BIT_SET_DBI_RDATA_8822C(x, v) \
(BIT_CLEAR_DBI_RDATA_8822C(x) | BIT_DBI_RDATA_8822C(v))
/* 2 REG_DBI_FLAG_V1_8822C */
#define BIT_EN_STUCK_DBG_8822C BIT(26)
#define BIT_RX_STUCK_8822C BIT(25)
#define BIT_TX_STUCK_8822C BIT(24)
#define BIT_DBI_RFLAG_8822C BIT(17)
#define BIT_DBI_WFLAG_8822C BIT(16)
#define BIT_SHIFT_DBI_WREN_8822C 12
#define BIT_MASK_DBI_WREN_8822C 0xf
#define BIT_DBI_WREN_8822C(x) \
(((x) & BIT_MASK_DBI_WREN_8822C) << BIT_SHIFT_DBI_WREN_8822C)
#define BITS_DBI_WREN_8822C \
(BIT_MASK_DBI_WREN_8822C << BIT_SHIFT_DBI_WREN_8822C)
#define BIT_CLEAR_DBI_WREN_8822C(x) ((x) & (~BITS_DBI_WREN_8822C))
#define BIT_GET_DBI_WREN_8822C(x) \
(((x) >> BIT_SHIFT_DBI_WREN_8822C) & BIT_MASK_DBI_WREN_8822C)
#define BIT_SET_DBI_WREN_8822C(x, v) \
(BIT_CLEAR_DBI_WREN_8822C(x) | BIT_DBI_WREN_8822C(v))
#define BIT_SHIFT_DBI_ADDR_8822C 0
#define BIT_MASK_DBI_ADDR_8822C 0xfff
#define BIT_DBI_ADDR_8822C(x) \
(((x) & BIT_MASK_DBI_ADDR_8822C) << BIT_SHIFT_DBI_ADDR_8822C)
#define BITS_DBI_ADDR_8822C \
(BIT_MASK_DBI_ADDR_8822C << BIT_SHIFT_DBI_ADDR_8822C)
#define BIT_CLEAR_DBI_ADDR_8822C(x) ((x) & (~BITS_DBI_ADDR_8822C))
#define BIT_GET_DBI_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_DBI_ADDR_8822C) & BIT_MASK_DBI_ADDR_8822C)
#define BIT_SET_DBI_ADDR_8822C(x, v) \
(BIT_CLEAR_DBI_ADDR_8822C(x) | BIT_DBI_ADDR_8822C(v))
/* 2 REG_MDIO_V1_8822C */
#define BIT_SHIFT_MDIO_RDATA_8822C 16
#define BIT_MASK_MDIO_RDATA_8822C 0xffff
#define BIT_MDIO_RDATA_8822C(x) \
(((x) & BIT_MASK_MDIO_RDATA_8822C) << BIT_SHIFT_MDIO_RDATA_8822C)
#define BITS_MDIO_RDATA_8822C \
(BIT_MASK_MDIO_RDATA_8822C << BIT_SHIFT_MDIO_RDATA_8822C)
#define BIT_CLEAR_MDIO_RDATA_8822C(x) ((x) & (~BITS_MDIO_RDATA_8822C))
#define BIT_GET_MDIO_RDATA_8822C(x) \
(((x) >> BIT_SHIFT_MDIO_RDATA_8822C) & BIT_MASK_MDIO_RDATA_8822C)
#define BIT_SET_MDIO_RDATA_8822C(x, v) \
(BIT_CLEAR_MDIO_RDATA_8822C(x) | BIT_MDIO_RDATA_8822C(v))
#define BIT_SHIFT_MDIO_WDATA_8822C 0
#define BIT_MASK_MDIO_WDATA_8822C 0xffff
#define BIT_MDIO_WDATA_8822C(x) \
(((x) & BIT_MASK_MDIO_WDATA_8822C) << BIT_SHIFT_MDIO_WDATA_8822C)
#define BITS_MDIO_WDATA_8822C \
(BIT_MASK_MDIO_WDATA_8822C << BIT_SHIFT_MDIO_WDATA_8822C)
#define BIT_CLEAR_MDIO_WDATA_8822C(x) ((x) & (~BITS_MDIO_WDATA_8822C))
#define BIT_GET_MDIO_WDATA_8822C(x) \
(((x) >> BIT_SHIFT_MDIO_WDATA_8822C) & BIT_MASK_MDIO_WDATA_8822C)
#define BIT_SET_MDIO_WDATA_8822C(x, v) \
(BIT_CLEAR_MDIO_WDATA_8822C(x) | BIT_MDIO_WDATA_8822C(v))
/* 2 REG_PCIE_MIX_CFG_8822C */
#define BIT_SHIFT_MDIO_PHY_ADDR_8822C 24
#define BIT_MASK_MDIO_PHY_ADDR_8822C 0x1f
#define BIT_MDIO_PHY_ADDR_8822C(x) \
(((x) & BIT_MASK_MDIO_PHY_ADDR_8822C) << BIT_SHIFT_MDIO_PHY_ADDR_8822C)
#define BITS_MDIO_PHY_ADDR_8822C \
(BIT_MASK_MDIO_PHY_ADDR_8822C << BIT_SHIFT_MDIO_PHY_ADDR_8822C)
#define BIT_CLEAR_MDIO_PHY_ADDR_8822C(x) ((x) & (~BITS_MDIO_PHY_ADDR_8822C))
#define BIT_GET_MDIO_PHY_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_MDIO_PHY_ADDR_8822C) & BIT_MASK_MDIO_PHY_ADDR_8822C)
#define BIT_SET_MDIO_PHY_ADDR_8822C(x, v) \
(BIT_CLEAR_MDIO_PHY_ADDR_8822C(x) | BIT_MDIO_PHY_ADDR_8822C(v))
#define BIT_SHIFT_WATCH_DOG_RECORD_V1_8822C 10
#define BIT_MASK_WATCH_DOG_RECORD_V1_8822C 0x3fff
#define BIT_WATCH_DOG_RECORD_V1_8822C(x) \
(((x) & BIT_MASK_WATCH_DOG_RECORD_V1_8822C) \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8822C)
#define BITS_WATCH_DOG_RECORD_V1_8822C \
(BIT_MASK_WATCH_DOG_RECORD_V1_8822C \
<< BIT_SHIFT_WATCH_DOG_RECORD_V1_8822C)
#define BIT_CLEAR_WATCH_DOG_RECORD_V1_8822C(x) \
((x) & (~BITS_WATCH_DOG_RECORD_V1_8822C))
#define BIT_GET_WATCH_DOG_RECORD_V1_8822C(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_RECORD_V1_8822C) & \
BIT_MASK_WATCH_DOG_RECORD_V1_8822C)
#define BIT_SET_WATCH_DOG_RECORD_V1_8822C(x, v) \
(BIT_CLEAR_WATCH_DOG_RECORD_V1_8822C(x) | \
BIT_WATCH_DOG_RECORD_V1_8822C(v))
#define BIT_R_IO_TIMEOUT_FLAG_V1_8822C BIT(9)
#define BIT_EN_WATCH_DOG_8822C BIT(8)
#define BIT_ECRC_EN_V1_8822C BIT(7)
#define BIT_MDIO_RFLAG_V1_8822C BIT(6)
#define BIT_MDIO_WFLAG_V1_8822C BIT(5)
#define BIT_SHIFT_MDIO_REG_ADDR_V1_8822C 0
#define BIT_MASK_MDIO_REG_ADDR_V1_8822C 0x1f
#define BIT_MDIO_REG_ADDR_V1_8822C(x) \
(((x) & BIT_MASK_MDIO_REG_ADDR_V1_8822C) \
<< BIT_SHIFT_MDIO_REG_ADDR_V1_8822C)
#define BITS_MDIO_REG_ADDR_V1_8822C \
(BIT_MASK_MDIO_REG_ADDR_V1_8822C << BIT_SHIFT_MDIO_REG_ADDR_V1_8822C)
#define BIT_CLEAR_MDIO_REG_ADDR_V1_8822C(x) \
((x) & (~BITS_MDIO_REG_ADDR_V1_8822C))
#define BIT_GET_MDIO_REG_ADDR_V1_8822C(x) \
(((x) >> BIT_SHIFT_MDIO_REG_ADDR_V1_8822C) & \
BIT_MASK_MDIO_REG_ADDR_V1_8822C)
#define BIT_SET_MDIO_REG_ADDR_V1_8822C(x, v) \
(BIT_CLEAR_MDIO_REG_ADDR_V1_8822C(x) | BIT_MDIO_REG_ADDR_V1_8822C(v))
/* 2 REG_HCI_MIX_CFG_8822C */
#define BIT_SHIFT_WATCH_DOG_TIMER_8822C 28
#define BIT_MASK_WATCH_DOG_TIMER_8822C 0xf
#define BIT_WATCH_DOG_TIMER_8822C(x) \
(((x) & BIT_MASK_WATCH_DOG_TIMER_8822C) \
<< BIT_SHIFT_WATCH_DOG_TIMER_8822C)
#define BITS_WATCH_DOG_TIMER_8822C \
(BIT_MASK_WATCH_DOG_TIMER_8822C << BIT_SHIFT_WATCH_DOG_TIMER_8822C)
#define BIT_CLEAR_WATCH_DOG_TIMER_8822C(x) ((x) & (~BITS_WATCH_DOG_TIMER_8822C))
#define BIT_GET_WATCH_DOG_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_WATCH_DOG_TIMER_8822C) & \
BIT_MASK_WATCH_DOG_TIMER_8822C)
#define BIT_SET_WATCH_DOG_TIMER_8822C(x, v) \
(BIT_CLEAR_WATCH_DOG_TIMER_8822C(x) | BIT_WATCH_DOG_TIMER_8822C(v))
#define BIT_EN_ALIGN_MTU_8822C BIT(23)
#define BIT_SHIFT_LATENCY_CONTROL_8822C 21
#define BIT_MASK_LATENCY_CONTROL_8822C 0x3
#define BIT_LATENCY_CONTROL_8822C(x) \
(((x) & BIT_MASK_LATENCY_CONTROL_8822C) \
<< BIT_SHIFT_LATENCY_CONTROL_8822C)
#define BITS_LATENCY_CONTROL_8822C \
(BIT_MASK_LATENCY_CONTROL_8822C << BIT_SHIFT_LATENCY_CONTROL_8822C)
#define BIT_CLEAR_LATENCY_CONTROL_8822C(x) ((x) & (~BITS_LATENCY_CONTROL_8822C))
#define BIT_GET_LATENCY_CONTROL_8822C(x) \
(((x) >> BIT_SHIFT_LATENCY_CONTROL_8822C) & \
BIT_MASK_LATENCY_CONTROL_8822C)
#define BIT_SET_LATENCY_CONTROL_8822C(x, v) \
(BIT_CLEAR_LATENCY_CONTROL_8822C(x) | BIT_LATENCY_CONTROL_8822C(v))
#define BIT_HOST_GEN2_SUPPORT_8822C BIT(20)
#define BIT_SHIFT_TXDMA_ERR_FLAG_V1_8822C 15
#define BIT_MASK_TXDMA_ERR_FLAG_V1_8822C 0x1f
#define BIT_TXDMA_ERR_FLAG_V1_8822C(x) \
(((x) & BIT_MASK_TXDMA_ERR_FLAG_V1_8822C) \
<< BIT_SHIFT_TXDMA_ERR_FLAG_V1_8822C)
#define BITS_TXDMA_ERR_FLAG_V1_8822C \
(BIT_MASK_TXDMA_ERR_FLAG_V1_8822C << BIT_SHIFT_TXDMA_ERR_FLAG_V1_8822C)
#define BIT_CLEAR_TXDMA_ERR_FLAG_V1_8822C(x) \
((x) & (~BITS_TXDMA_ERR_FLAG_V1_8822C))
#define BIT_GET_TXDMA_ERR_FLAG_V1_8822C(x) \
(((x) >> BIT_SHIFT_TXDMA_ERR_FLAG_V1_8822C) & \
BIT_MASK_TXDMA_ERR_FLAG_V1_8822C)
#define BIT_SET_TXDMA_ERR_FLAG_V1_8822C(x, v) \
(BIT_CLEAR_TXDMA_ERR_FLAG_V1_8822C(x) | BIT_TXDMA_ERR_FLAG_V1_8822C(v))
#define BIT_EPHY_RX50_EN_8822C BIT(11)
#define BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822C 8
#define BIT_MASK_MSI_TIMEOUT_ID_V1_8822C 0x7
#define BIT_MSI_TIMEOUT_ID_V1_8822C(x) \
(((x) & BIT_MASK_MSI_TIMEOUT_ID_V1_8822C) \
<< BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822C)
#define BITS_MSI_TIMEOUT_ID_V1_8822C \
(BIT_MASK_MSI_TIMEOUT_ID_V1_8822C << BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822C)
#define BIT_CLEAR_MSI_TIMEOUT_ID_V1_8822C(x) \
((x) & (~BITS_MSI_TIMEOUT_ID_V1_8822C))
#define BIT_GET_MSI_TIMEOUT_ID_V1_8822C(x) \
(((x) >> BIT_SHIFT_MSI_TIMEOUT_ID_V1_8822C) & \
BIT_MASK_MSI_TIMEOUT_ID_V1_8822C)
#define BIT_SET_MSI_TIMEOUT_ID_V1_8822C(x, v) \
(BIT_CLEAR_MSI_TIMEOUT_ID_V1_8822C(x) | BIT_MSI_TIMEOUT_ID_V1_8822C(v))
#define BIT_RADDR_RD_8822C BIT(7)
#define BIT_L1OFF_PWR_OFF_EN_8822C BIT(6)
#define BIT_L0S_LINK_OFF_8822C BIT(4)
#define BIT_ACT_LINK_OFF_8822C BIT(3)
#define BIT_EN_SLOW_MAC_TX_8822C BIT(2)
#define BIT_EN_SLOW_MAC_RX_8822C BIT(1)
#define BIT_EN_SLOW_MAC_HW_8822C BIT(0)
/* 2 REG_STC_INT_CS_8822C(PCIE STATE CHANGE INTERRUPT CONTROL AND STATUS) */
#define BIT_STC_INT_EN_8822C BIT(31)
#define BIT_SHIFT_STC_INT_FLAG_8822C 16
#define BIT_MASK_STC_INT_FLAG_8822C 0xff
#define BIT_STC_INT_FLAG_8822C(x) \
(((x) & BIT_MASK_STC_INT_FLAG_8822C) << BIT_SHIFT_STC_INT_FLAG_8822C)
#define BITS_STC_INT_FLAG_8822C \
(BIT_MASK_STC_INT_FLAG_8822C << BIT_SHIFT_STC_INT_FLAG_8822C)
#define BIT_CLEAR_STC_INT_FLAG_8822C(x) ((x) & (~BITS_STC_INT_FLAG_8822C))
#define BIT_GET_STC_INT_FLAG_8822C(x) \
(((x) >> BIT_SHIFT_STC_INT_FLAG_8822C) & BIT_MASK_STC_INT_FLAG_8822C)
#define BIT_SET_STC_INT_FLAG_8822C(x, v) \
(BIT_CLEAR_STC_INT_FLAG_8822C(x) | BIT_STC_INT_FLAG_8822C(v))
#define BIT_SHIFT_STC_INT_IDX_8822C 8
#define BIT_MASK_STC_INT_IDX_8822C 0x7
#define BIT_STC_INT_IDX_8822C(x) \
(((x) & BIT_MASK_STC_INT_IDX_8822C) << BIT_SHIFT_STC_INT_IDX_8822C)
#define BITS_STC_INT_IDX_8822C \
(BIT_MASK_STC_INT_IDX_8822C << BIT_SHIFT_STC_INT_IDX_8822C)
#define BIT_CLEAR_STC_INT_IDX_8822C(x) ((x) & (~BITS_STC_INT_IDX_8822C))
#define BIT_GET_STC_INT_IDX_8822C(x) \
(((x) >> BIT_SHIFT_STC_INT_IDX_8822C) & BIT_MASK_STC_INT_IDX_8822C)
#define BIT_SET_STC_INT_IDX_8822C(x, v) \
(BIT_CLEAR_STC_INT_IDX_8822C(x) | BIT_STC_INT_IDX_8822C(v))
#define BIT_SHIFT_STC_INT_REALTIME_CS_8822C 0
#define BIT_MASK_STC_INT_REALTIME_CS_8822C 0x3f
#define BIT_STC_INT_REALTIME_CS_8822C(x) \
(((x) & BIT_MASK_STC_INT_REALTIME_CS_8822C) \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8822C)
#define BITS_STC_INT_REALTIME_CS_8822C \
(BIT_MASK_STC_INT_REALTIME_CS_8822C \
<< BIT_SHIFT_STC_INT_REALTIME_CS_8822C)
#define BIT_CLEAR_STC_INT_REALTIME_CS_8822C(x) \
((x) & (~BITS_STC_INT_REALTIME_CS_8822C))
#define BIT_GET_STC_INT_REALTIME_CS_8822C(x) \
(((x) >> BIT_SHIFT_STC_INT_REALTIME_CS_8822C) & \
BIT_MASK_STC_INT_REALTIME_CS_8822C)
#define BIT_SET_STC_INT_REALTIME_CS_8822C(x, v) \
(BIT_CLEAR_STC_INT_REALTIME_CS_8822C(x) | \
BIT_STC_INT_REALTIME_CS_8822C(v))
#define BIT_STC_INT_GRP_EN_8822C BIT(31)
#define BIT_SHIFT_STC_INT_EXPECT_LS_8822C 8
#define BIT_MASK_STC_INT_EXPECT_LS_8822C 0x3f
#define BIT_STC_INT_EXPECT_LS_8822C(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_LS_8822C) \
<< BIT_SHIFT_STC_INT_EXPECT_LS_8822C)
#define BITS_STC_INT_EXPECT_LS_8822C \
(BIT_MASK_STC_INT_EXPECT_LS_8822C << BIT_SHIFT_STC_INT_EXPECT_LS_8822C)
#define BIT_CLEAR_STC_INT_EXPECT_LS_8822C(x) \
((x) & (~BITS_STC_INT_EXPECT_LS_8822C))
#define BIT_GET_STC_INT_EXPECT_LS_8822C(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_LS_8822C) & \
BIT_MASK_STC_INT_EXPECT_LS_8822C)
#define BIT_SET_STC_INT_EXPECT_LS_8822C(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_LS_8822C(x) | BIT_STC_INT_EXPECT_LS_8822C(v))
#define BIT_SHIFT_STC_INT_EXPECT_CS_8822C 0
#define BIT_MASK_STC_INT_EXPECT_CS_8822C 0x3f
#define BIT_STC_INT_EXPECT_CS_8822C(x) \
(((x) & BIT_MASK_STC_INT_EXPECT_CS_8822C) \
<< BIT_SHIFT_STC_INT_EXPECT_CS_8822C)
#define BITS_STC_INT_EXPECT_CS_8822C \
(BIT_MASK_STC_INT_EXPECT_CS_8822C << BIT_SHIFT_STC_INT_EXPECT_CS_8822C)
#define BIT_CLEAR_STC_INT_EXPECT_CS_8822C(x) \
((x) & (~BITS_STC_INT_EXPECT_CS_8822C))
#define BIT_GET_STC_INT_EXPECT_CS_8822C(x) \
(((x) >> BIT_SHIFT_STC_INT_EXPECT_CS_8822C) & \
BIT_MASK_STC_INT_EXPECT_CS_8822C)
#define BIT_SET_STC_INT_EXPECT_CS_8822C(x, v) \
(BIT_CLEAR_STC_INT_EXPECT_CS_8822C(x) | BIT_STC_INT_EXPECT_CS_8822C(v))
/* 2 REG_H2CQ_TXBD_DESA_8822C */
#define BIT_SHIFT_H2CQ_TXBD_DESA_8822C 0
#define BIT_MASK_H2CQ_TXBD_DESA_8822C 0xffffffffffffffffL
#define BIT_H2CQ_TXBD_DESA_8822C(x) \
(((x) & BIT_MASK_H2CQ_TXBD_DESA_8822C) \
<< BIT_SHIFT_H2CQ_TXBD_DESA_8822C)
#define BITS_H2CQ_TXBD_DESA_8822C \
(BIT_MASK_H2CQ_TXBD_DESA_8822C << BIT_SHIFT_H2CQ_TXBD_DESA_8822C)
#define BIT_CLEAR_H2CQ_TXBD_DESA_8822C(x) ((x) & (~BITS_H2CQ_TXBD_DESA_8822C))
#define BIT_GET_H2CQ_TXBD_DESA_8822C(x) \
(((x) >> BIT_SHIFT_H2CQ_TXBD_DESA_8822C) & \
BIT_MASK_H2CQ_TXBD_DESA_8822C)
#define BIT_SET_H2CQ_TXBD_DESA_8822C(x, v) \
(BIT_CLEAR_H2CQ_TXBD_DESA_8822C(x) | BIT_H2CQ_TXBD_DESA_8822C(v))
/* 2 REG_H2CQ_TXBD_NUM_8822C */
#define BIT_PCIE_H2CQ_FLAG_8822C BIT(14)
#define BIT_SHIFT_H2CQ_DESC_MODE_8822C 12
#define BIT_MASK_H2CQ_DESC_MODE_8822C 0x3
#define BIT_H2CQ_DESC_MODE_8822C(x) \
(((x) & BIT_MASK_H2CQ_DESC_MODE_8822C) \
<< BIT_SHIFT_H2CQ_DESC_MODE_8822C)
#define BITS_H2CQ_DESC_MODE_8822C \
(BIT_MASK_H2CQ_DESC_MODE_8822C << BIT_SHIFT_H2CQ_DESC_MODE_8822C)
#define BIT_CLEAR_H2CQ_DESC_MODE_8822C(x) ((x) & (~BITS_H2CQ_DESC_MODE_8822C))
#define BIT_GET_H2CQ_DESC_MODE_8822C(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_MODE_8822C) & \
BIT_MASK_H2CQ_DESC_MODE_8822C)
#define BIT_SET_H2CQ_DESC_MODE_8822C(x, v) \
(BIT_CLEAR_H2CQ_DESC_MODE_8822C(x) | BIT_H2CQ_DESC_MODE_8822C(v))
#define BIT_SHIFT_H2CQ_DESC_NUM_8822C 0
#define BIT_MASK_H2CQ_DESC_NUM_8822C 0xfff
#define BIT_H2CQ_DESC_NUM_8822C(x) \
(((x) & BIT_MASK_H2CQ_DESC_NUM_8822C) << BIT_SHIFT_H2CQ_DESC_NUM_8822C)
#define BITS_H2CQ_DESC_NUM_8822C \
(BIT_MASK_H2CQ_DESC_NUM_8822C << BIT_SHIFT_H2CQ_DESC_NUM_8822C)
#define BIT_CLEAR_H2CQ_DESC_NUM_8822C(x) ((x) & (~BITS_H2CQ_DESC_NUM_8822C))
#define BIT_GET_H2CQ_DESC_NUM_8822C(x) \
(((x) >> BIT_SHIFT_H2CQ_DESC_NUM_8822C) & BIT_MASK_H2CQ_DESC_NUM_8822C)
#define BIT_SET_H2CQ_DESC_NUM_8822C(x, v) \
(BIT_CLEAR_H2CQ_DESC_NUM_8822C(x) | BIT_H2CQ_DESC_NUM_8822C(v))
/* 2 REG_H2CQ_TXBD_IDX_8822C */
#define BIT_SHIFT_H2CQ_HW_IDX_8822C 16
#define BIT_MASK_H2CQ_HW_IDX_8822C 0xfff
#define BIT_H2CQ_HW_IDX_8822C(x) \
(((x) & BIT_MASK_H2CQ_HW_IDX_8822C) << BIT_SHIFT_H2CQ_HW_IDX_8822C)
#define BITS_H2CQ_HW_IDX_8822C \
(BIT_MASK_H2CQ_HW_IDX_8822C << BIT_SHIFT_H2CQ_HW_IDX_8822C)
#define BIT_CLEAR_H2CQ_HW_IDX_8822C(x) ((x) & (~BITS_H2CQ_HW_IDX_8822C))
#define BIT_GET_H2CQ_HW_IDX_8822C(x) \
(((x) >> BIT_SHIFT_H2CQ_HW_IDX_8822C) & BIT_MASK_H2CQ_HW_IDX_8822C)
#define BIT_SET_H2CQ_HW_IDX_8822C(x, v) \
(BIT_CLEAR_H2CQ_HW_IDX_8822C(x) | BIT_H2CQ_HW_IDX_8822C(v))
#define BIT_SHIFT_H2CQ_HOST_IDX_8822C 0
#define BIT_MASK_H2CQ_HOST_IDX_8822C 0xfff
#define BIT_H2CQ_HOST_IDX_8822C(x) \
(((x) & BIT_MASK_H2CQ_HOST_IDX_8822C) << BIT_SHIFT_H2CQ_HOST_IDX_8822C)
#define BITS_H2CQ_HOST_IDX_8822C \
(BIT_MASK_H2CQ_HOST_IDX_8822C << BIT_SHIFT_H2CQ_HOST_IDX_8822C)
#define BIT_CLEAR_H2CQ_HOST_IDX_8822C(x) ((x) & (~BITS_H2CQ_HOST_IDX_8822C))
#define BIT_GET_H2CQ_HOST_IDX_8822C(x) \
(((x) >> BIT_SHIFT_H2CQ_HOST_IDX_8822C) & BIT_MASK_H2CQ_HOST_IDX_8822C)
#define BIT_SET_H2CQ_HOST_IDX_8822C(x, v) \
(BIT_CLEAR_H2CQ_HOST_IDX_8822C(x) | BIT_H2CQ_HOST_IDX_8822C(v))
/* 2 REG_H2CQ_CSR_8822C[31:0] (H2CQ CONTROL AND STATUS) */
#define BIT_H2CQ_FULL_8822C BIT(31)
#define BIT_CLR_H2CQ_HOST_IDX_8822C BIT(16)
#define BIT_CLR_H2CQ_HW_IDX_8822C BIT(8)
#define BIT_STOP_H2CQ_8822C BIT(0)
/* 2 REG_CHANGE_PCIE_SPEED_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_RXDMA_ERR_CNT_8822C 8
#define BIT_MASK_RXDMA_ERR_CNT_8822C 0xff
#define BIT_RXDMA_ERR_CNT_8822C(x) \
(((x) & BIT_MASK_RXDMA_ERR_CNT_8822C) << BIT_SHIFT_RXDMA_ERR_CNT_8822C)
#define BITS_RXDMA_ERR_CNT_8822C \
(BIT_MASK_RXDMA_ERR_CNT_8822C << BIT_SHIFT_RXDMA_ERR_CNT_8822C)
#define BIT_CLEAR_RXDMA_ERR_CNT_8822C(x) ((x) & (~BITS_RXDMA_ERR_CNT_8822C))
#define BIT_GET_RXDMA_ERR_CNT_8822C(x) \
(((x) >> BIT_SHIFT_RXDMA_ERR_CNT_8822C) & BIT_MASK_RXDMA_ERR_CNT_8822C)
#define BIT_SET_RXDMA_ERR_CNT_8822C(x, v) \
(BIT_CLEAR_RXDMA_ERR_CNT_8822C(x) | BIT_RXDMA_ERR_CNT_8822C(v))
#define BIT_TXDMA_ERR_HANDLE_REQ_8822C BIT(7)
#define BIT_TXDMA_ERROR_PS_8822C BIT(6)
#define BIT_EN_TXDMA_STUCK_ERR_HANDLE_8822C BIT(5)
#define BIT_EN_TXDMA_RTN_ERR_HANDLE_8822C BIT(4)
#define BIT_RXDMA_ERR_HANDLE_REQ_8822C BIT(3)
#define BIT_RXDMA_ERROR_PS_8822C BIT(2)
#define BIT_EN_RXDMA_STUCK_ERR_HANDLE_8822C BIT(1)
#define BIT_EN_RXDMA_RTN_ERR_HANDLE_8822C BIT(0)
/* 2 REG_DEBUG_STATE1_8822C */
#define BIT_SHIFT_DEBUG_STATE1_8822C 0
#define BIT_MASK_DEBUG_STATE1_8822C 0xffffffffL
#define BIT_DEBUG_STATE1_8822C(x) \
(((x) & BIT_MASK_DEBUG_STATE1_8822C) << BIT_SHIFT_DEBUG_STATE1_8822C)
#define BITS_DEBUG_STATE1_8822C \
(BIT_MASK_DEBUG_STATE1_8822C << BIT_SHIFT_DEBUG_STATE1_8822C)
#define BIT_CLEAR_DEBUG_STATE1_8822C(x) ((x) & (~BITS_DEBUG_STATE1_8822C))
#define BIT_GET_DEBUG_STATE1_8822C(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE1_8822C) & BIT_MASK_DEBUG_STATE1_8822C)
#define BIT_SET_DEBUG_STATE1_8822C(x, v) \
(BIT_CLEAR_DEBUG_STATE1_8822C(x) | BIT_DEBUG_STATE1_8822C(v))
/* 2 REG_DEBUG_STATE2_8822C */
#define BIT_SHIFT_DEBUG_STATE2_8822C 0
#define BIT_MASK_DEBUG_STATE2_8822C 0xffffffffL
#define BIT_DEBUG_STATE2_8822C(x) \
(((x) & BIT_MASK_DEBUG_STATE2_8822C) << BIT_SHIFT_DEBUG_STATE2_8822C)
#define BITS_DEBUG_STATE2_8822C \
(BIT_MASK_DEBUG_STATE2_8822C << BIT_SHIFT_DEBUG_STATE2_8822C)
#define BIT_CLEAR_DEBUG_STATE2_8822C(x) ((x) & (~BITS_DEBUG_STATE2_8822C))
#define BIT_GET_DEBUG_STATE2_8822C(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE2_8822C) & BIT_MASK_DEBUG_STATE2_8822C)
#define BIT_SET_DEBUG_STATE2_8822C(x, v) \
(BIT_CLEAR_DEBUG_STATE2_8822C(x) | BIT_DEBUG_STATE2_8822C(v))
/* 2 REG_DEBUG_STATE3_8822C */
#define BIT_SHIFT_DEBUG_STATE3_8822C 0
#define BIT_MASK_DEBUG_STATE3_8822C 0xffffffffL
#define BIT_DEBUG_STATE3_8822C(x) \
(((x) & BIT_MASK_DEBUG_STATE3_8822C) << BIT_SHIFT_DEBUG_STATE3_8822C)
#define BITS_DEBUG_STATE3_8822C \
(BIT_MASK_DEBUG_STATE3_8822C << BIT_SHIFT_DEBUG_STATE3_8822C)
#define BIT_CLEAR_DEBUG_STATE3_8822C(x) ((x) & (~BITS_DEBUG_STATE3_8822C))
#define BIT_GET_DEBUG_STATE3_8822C(x) \
(((x) >> BIT_SHIFT_DEBUG_STATE3_8822C) & BIT_MASK_DEBUG_STATE3_8822C)
#define BIT_SET_DEBUG_STATE3_8822C(x, v) \
(BIT_CLEAR_DEBUG_STATE3_8822C(x) | BIT_DEBUG_STATE3_8822C(v))
/* 2 REG_CHNL_DMA_CFG_V1_8822C */
#define BIT_TXHCI_EN_V1_8822C BIT(26)
#define BIT_TXHCI_IDLE_V1_8822C BIT(25)
#define BIT_DMA_PRI_EN_V1_8822C BIT(24)
/* 2 REG_PCIE_HISR0_V1_8822C */
#define BIT_PSTIMER_2_8822C BIT(31)
#define BIT_PSTIMER_1_8822C BIT(30)
#define BIT_PSTIMER_0_8822C BIT(29)
#define BIT_GTINT4_8822C BIT(28)
#define BIT_GTINT3_8822C BIT(27)
#define BIT_TXBCN0ERR_8822C BIT(26)
#define BIT_TXBCN0OK_8822C BIT(25)
#define BIT_TSF_BIT32_TOGGLE_8822C BIT(24)
#define BIT_TXDMA_START_INT_8822C BIT(23)
#define BIT_TXDMA_STOP_INT_8822C BIT(22)
#define BIT_HISR7_IND_8822C BIT(21)
#define BIT_BCNDMAINT0_8822C BIT(20)
#define BIT_HISR6_IND_8822C BIT(19)
#define BIT_HISR5_IND_8822C BIT(18)
#define BIT_HISR4_IND_8822C BIT(17)
#define BIT_BCNDERR0_8822C BIT(16)
#define BIT_HSISR_IND_ON_INT_8822C BIT(15)
#define BIT_HISR3_IND_8822C BIT(14)
#define BIT_HISR2_IND_8822C BIT(13)
#define BIT_HISR1_IND_8822C BIT(11)
#define BIT_C2HCMD_8822C BIT(10)
#define BIT_CPWM2_8822C BIT(9)
#define BIT_CPWM_8822C BIT(8)
#define BIT_TXDMAOK_CHANNEL15_8822C BIT(7)
#define BIT_TXDMAOK_CHANNEL14_8822C BIT(6)
#define BIT_TXDMAOK_CHANNEL3_8822C BIT(5)
#define BIT_TXDMAOK_CHANNEL2_8822C BIT(4)
#define BIT_TXDMAOK_CHANNEL1_8822C BIT(3)
#define BIT_TXDMAOK_CHANNEL0_8822C BIT(2)
#define BIT_RDU_8822C BIT(1)
#define BIT_RXOK_8822C BIT(0)
/* 2 REG_PCIE_HISR1_V1_8822C */
#define BIT_PRE_TX_ERR_INT_8822C BIT(31)
#define BIT_TXFIFO_TH_INT_8822C BIT(30)
#define BIT_BTON_STS_UPDATE_INT_8822C BIT(29)
#define BIT_BCNDMAINT7_8822C BIT(27)
#define BIT_BCNDMAINT6_8822C BIT(26)
#define BIT_BCNDMAINT5_8822C BIT(25)
#define BIT_BCNDMAINT4_8822C BIT(24)
#define BIT_BCNDMAINT3_8822C BIT(23)
#define BIT_BCNDMAINT2_8822C BIT(22)
#define BIT_BCNDMAINT1_8822C BIT(21)
#define BIT_BCNDERR7_8822C BIT(20)
#define BIT_BCNDERR6_8822C BIT(19)
#define BIT_BCNDERR5_8822C BIT(18)
#define BIT_BCNDERR4_8822C BIT(17)
#define BIT_BCNDERR3_8822C BIT(16)
#define BIT_BCNDERR2_8822C BIT(15)
#define BIT_BCNDERR1_8822C BIT(14)
#define BIT_ATIMEND_8822C BIT(12)
#define BIT_TXERR_INT_8822C BIT(11)
#define BIT_RXERR_INT_8822C BIT(10)
#define BIT_TXFOVW_8822C BIT(9)
#define BIT_FOVW_8822C BIT(8)
#define BIT_CPU_MGQ_EARLY_INT_8822C BIT(6)
#define BIT_CPU_MGQ_TXDONE_8822C BIT(5)
#define BIT_PSTIMER_5_8822C BIT(4)
#define BIT_PSTIMER_4_8822C BIT(3)
#define BIT_PSTIMER_3_8822C BIT(2)
#define BIT_CPUMGQ_TX_TIMER_8822C BIT(1)
#define BIT_BB_STOPRX_INT_8822C BIT(0)
/* 2 REG_PCIE_HISR2_V1_8822C */
#define BIT_BCNDMAINT_P4_8822C BIT(31)
#define BIT_BCNDMAINT_P3_8822C BIT(30)
#define BIT_BCNDMAINT_P2_8822C BIT(29)
#define BIT_BCNDMAINT_P1_8822C BIT(28)
#define BIT_SCH_PHY_TXOP_SIFS_INT_8822C BIT(23)
#define BIT_ATIMEND7_8822C BIT(22)
#define BIT_ATIMEND6_8822C BIT(21)
#define BIT_ATIMEND5_8822C BIT(20)
#define BIT_ATIMEND4_8822C BIT(19)
#define BIT_ATIMEND3_8822C BIT(18)
#define BIT_ATIMEND2_8822C BIT(17)
#define BIT_ATIMEND1_8822C BIT(16)
#define BIT_TXBCN7OK_8822C BIT(14)
#define BIT_TXBCN6OK_8822C BIT(13)
#define BIT_TXBCN5OK_8822C BIT(12)
#define BIT_TXBCN4OK_8822C BIT(11)
#define BIT_TXBCN3OK_8822C BIT(10)
#define BIT_TXBCN2OK_8822C BIT(9)
#define BIT_TXBCN1OK_8822C BIT(8)
#define BIT_TXBCN7ERR_8822C BIT(6)
#define BIT_TXBCN6ERR_8822C BIT(5)
#define BIT_TXBCN5ERR_8822C BIT(4)
#define BIT_TXBCN4ERR_8822C BIT(3)
#define BIT_TXBCN3ERR_8822C BIT(2)
#define BIT_TXBCN2ERR_8822C BIT(1)
#define BIT_TXBCN1ERR_8822C BIT(0)
/* 2 REG_PCIE_HISR3_V1_8822C */
#define BIT_GTINT12_8822C BIT(24)
#define BIT_GTINT11_8822C BIT(23)
#define BIT_GTINT10_8822C BIT(22)
#define BIT_GTINT9_8822C BIT(21)
#define BIT_RX_DESC_BUF_FULL_8822C BIT(20)
#define BIT_CPHY_LDO_OCP_DET_INT_8822C BIT(19)
#define BIT_WDT_PLATFORM_INT_8822C BIT(18)
#define BIT_WDT_CPU_INT_8822C BIT(17)
#define BIT_SETH2CDOK_8822C BIT(16)
#define BIT_H2C_CMD_FULL_8822C BIT(15)
#define BIT_PKT_TRANS_ERR_8822C BIT(14)
#define BIT_TXSHORTCUT_TXDESUPDATEOK_8822C BIT(13)
#define BIT_TXSHORTCUT_BKUPDATEOK_8822C BIT(12)
#define BIT_TXSHORTCUT_BEUPDATEOK_8822C BIT(11)
#define BIT_TXSHORTCUT_VIUPDATEOK_8822C BIT(10)
#define BIT_TXSHORTCUT_VOUPDATEOK_8822C BIT(9)
#define BIT_SEARCH_FAIL_8822C BIT(8)
#define BIT_PWR_INT_127TO96_8822C BIT(7)
#define BIT_PWR_INT_95TO64_8822C BIT(6)
#define BIT_PWR_INT_63TO32_8822C BIT(5)
#define BIT_PWR_INT_31TO0_8822C BIT(4)
#define BIT_RX_DMA_STUCK_8822C BIT(3)
#define BIT_TX_DMA_STUCK_8822C BIT(2)
#define BIT_DDMA0_LP_INT_8822C BIT(1)
#define BIT_DDMA0_HP_INT_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_Q0_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q0_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q0_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q0_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q0_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q0_V1_8822C)
#define BITS_QUEUEMACID_Q0_V1_8822C \
(BIT_MASK_QUEUEMACID_Q0_V1_8822C << BIT_SHIFT_QUEUEMACID_Q0_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q0_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q0_V1_8822C))
#define BIT_GET_QUEUEMACID_Q0_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q0_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q0_V1_8822C)
#define BIT_SET_QUEUEMACID_Q0_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q0_V1_8822C(x) | BIT_QUEUEMACID_Q0_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q0_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q0_V1_8822C 0x3
#define BIT_QUEUEAC_Q0_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q0_V1_8822C) << BIT_SHIFT_QUEUEAC_Q0_V1_8822C)
#define BITS_QUEUEAC_Q0_V1_8822C \
(BIT_MASK_QUEUEAC_Q0_V1_8822C << BIT_SHIFT_QUEUEAC_Q0_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q0_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q0_V1_8822C))
#define BIT_GET_QUEUEAC_Q0_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q0_V1_8822C) & BIT_MASK_QUEUEAC_Q0_V1_8822C)
#define BIT_SET_QUEUEAC_Q0_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q0_V1_8822C(x) | BIT_QUEUEAC_Q0_V1_8822C(v))
#define BIT_TIDEMPTY_Q0_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q0_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q0_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q0_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q0_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q0_V2_8822C)
#define BITS_TAIL_PKT_Q0_V2_8822C \
(BIT_MASK_TAIL_PKT_Q0_V2_8822C << BIT_SHIFT_TAIL_PKT_Q0_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q0_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q0_V2_8822C))
#define BIT_GET_TAIL_PKT_Q0_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q0_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q0_V2_8822C)
#define BIT_SET_TAIL_PKT_Q0_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q0_V2_8822C(x) | BIT_TAIL_PKT_Q0_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q0_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q0_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q0_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q0_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q0_V1_8822C)
#define BITS_HEAD_PKT_Q0_V1_8822C \
(BIT_MASK_HEAD_PKT_Q0_V1_8822C << BIT_SHIFT_HEAD_PKT_Q0_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q0_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q0_V1_8822C))
#define BIT_GET_HEAD_PKT_Q0_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q0_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q0_V1_8822C)
#define BIT_SET_HEAD_PKT_Q0_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q0_V1_8822C(x) | BIT_HEAD_PKT_Q0_V1_8822C(v))
/* 2 REG_Q1_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q1_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q1_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q1_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q1_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q1_V1_8822C)
#define BITS_QUEUEMACID_Q1_V1_8822C \
(BIT_MASK_QUEUEMACID_Q1_V1_8822C << BIT_SHIFT_QUEUEMACID_Q1_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q1_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q1_V1_8822C))
#define BIT_GET_QUEUEMACID_Q1_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q1_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q1_V1_8822C)
#define BIT_SET_QUEUEMACID_Q1_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q1_V1_8822C(x) | BIT_QUEUEMACID_Q1_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q1_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q1_V1_8822C 0x3
#define BIT_QUEUEAC_Q1_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q1_V1_8822C) << BIT_SHIFT_QUEUEAC_Q1_V1_8822C)
#define BITS_QUEUEAC_Q1_V1_8822C \
(BIT_MASK_QUEUEAC_Q1_V1_8822C << BIT_SHIFT_QUEUEAC_Q1_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q1_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q1_V1_8822C))
#define BIT_GET_QUEUEAC_Q1_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q1_V1_8822C) & BIT_MASK_QUEUEAC_Q1_V1_8822C)
#define BIT_SET_QUEUEAC_Q1_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q1_V1_8822C(x) | BIT_QUEUEAC_Q1_V1_8822C(v))
#define BIT_TIDEMPTY_Q1_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q1_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q1_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q1_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q1_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q1_V2_8822C)
#define BITS_TAIL_PKT_Q1_V2_8822C \
(BIT_MASK_TAIL_PKT_Q1_V2_8822C << BIT_SHIFT_TAIL_PKT_Q1_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q1_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q1_V2_8822C))
#define BIT_GET_TAIL_PKT_Q1_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q1_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q1_V2_8822C)
#define BIT_SET_TAIL_PKT_Q1_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q1_V2_8822C(x) | BIT_TAIL_PKT_Q1_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q1_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q1_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q1_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q1_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q1_V1_8822C)
#define BITS_HEAD_PKT_Q1_V1_8822C \
(BIT_MASK_HEAD_PKT_Q1_V1_8822C << BIT_SHIFT_HEAD_PKT_Q1_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q1_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q1_V1_8822C))
#define BIT_GET_HEAD_PKT_Q1_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q1_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q1_V1_8822C)
#define BIT_SET_HEAD_PKT_Q1_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q1_V1_8822C(x) | BIT_HEAD_PKT_Q1_V1_8822C(v))
/* 2 REG_Q2_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q2_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q2_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q2_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q2_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q2_V1_8822C)
#define BITS_QUEUEMACID_Q2_V1_8822C \
(BIT_MASK_QUEUEMACID_Q2_V1_8822C << BIT_SHIFT_QUEUEMACID_Q2_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q2_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q2_V1_8822C))
#define BIT_GET_QUEUEMACID_Q2_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q2_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q2_V1_8822C)
#define BIT_SET_QUEUEMACID_Q2_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q2_V1_8822C(x) | BIT_QUEUEMACID_Q2_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q2_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q2_V1_8822C 0x3
#define BIT_QUEUEAC_Q2_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q2_V1_8822C) << BIT_SHIFT_QUEUEAC_Q2_V1_8822C)
#define BITS_QUEUEAC_Q2_V1_8822C \
(BIT_MASK_QUEUEAC_Q2_V1_8822C << BIT_SHIFT_QUEUEAC_Q2_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q2_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q2_V1_8822C))
#define BIT_GET_QUEUEAC_Q2_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q2_V1_8822C) & BIT_MASK_QUEUEAC_Q2_V1_8822C)
#define BIT_SET_QUEUEAC_Q2_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q2_V1_8822C(x) | BIT_QUEUEAC_Q2_V1_8822C(v))
#define BIT_TIDEMPTY_Q2_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q2_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q2_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q2_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q2_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q2_V2_8822C)
#define BITS_TAIL_PKT_Q2_V2_8822C \
(BIT_MASK_TAIL_PKT_Q2_V2_8822C << BIT_SHIFT_TAIL_PKT_Q2_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q2_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q2_V2_8822C))
#define BIT_GET_TAIL_PKT_Q2_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q2_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q2_V2_8822C)
#define BIT_SET_TAIL_PKT_Q2_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q2_V2_8822C(x) | BIT_TAIL_PKT_Q2_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q2_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q2_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q2_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q2_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q2_V1_8822C)
#define BITS_HEAD_PKT_Q2_V1_8822C \
(BIT_MASK_HEAD_PKT_Q2_V1_8822C << BIT_SHIFT_HEAD_PKT_Q2_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q2_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q2_V1_8822C))
#define BIT_GET_HEAD_PKT_Q2_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q2_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q2_V1_8822C)
#define BIT_SET_HEAD_PKT_Q2_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q2_V1_8822C(x) | BIT_HEAD_PKT_Q2_V1_8822C(v))
/* 2 REG_Q3_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q3_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q3_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q3_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q3_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q3_V1_8822C)
#define BITS_QUEUEMACID_Q3_V1_8822C \
(BIT_MASK_QUEUEMACID_Q3_V1_8822C << BIT_SHIFT_QUEUEMACID_Q3_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q3_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q3_V1_8822C))
#define BIT_GET_QUEUEMACID_Q3_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q3_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q3_V1_8822C)
#define BIT_SET_QUEUEMACID_Q3_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q3_V1_8822C(x) | BIT_QUEUEMACID_Q3_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q3_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q3_V1_8822C 0x3
#define BIT_QUEUEAC_Q3_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q3_V1_8822C) << BIT_SHIFT_QUEUEAC_Q3_V1_8822C)
#define BITS_QUEUEAC_Q3_V1_8822C \
(BIT_MASK_QUEUEAC_Q3_V1_8822C << BIT_SHIFT_QUEUEAC_Q3_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q3_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q3_V1_8822C))
#define BIT_GET_QUEUEAC_Q3_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q3_V1_8822C) & BIT_MASK_QUEUEAC_Q3_V1_8822C)
#define BIT_SET_QUEUEAC_Q3_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q3_V1_8822C(x) | BIT_QUEUEAC_Q3_V1_8822C(v))
#define BIT_TIDEMPTY_Q3_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q3_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q3_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q3_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q3_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q3_V2_8822C)
#define BITS_TAIL_PKT_Q3_V2_8822C \
(BIT_MASK_TAIL_PKT_Q3_V2_8822C << BIT_SHIFT_TAIL_PKT_Q3_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q3_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q3_V2_8822C))
#define BIT_GET_TAIL_PKT_Q3_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q3_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q3_V2_8822C)
#define BIT_SET_TAIL_PKT_Q3_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q3_V2_8822C(x) | BIT_TAIL_PKT_Q3_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q3_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q3_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q3_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q3_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q3_V1_8822C)
#define BITS_HEAD_PKT_Q3_V1_8822C \
(BIT_MASK_HEAD_PKT_Q3_V1_8822C << BIT_SHIFT_HEAD_PKT_Q3_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q3_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q3_V1_8822C))
#define BIT_GET_HEAD_PKT_Q3_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q3_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q3_V1_8822C)
#define BIT_SET_HEAD_PKT_Q3_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q3_V1_8822C(x) | BIT_HEAD_PKT_Q3_V1_8822C(v))
/* 2 REG_MGQ_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_MGQ_V1_8822C 25
#define BIT_MASK_QUEUEMACID_MGQ_V1_8822C 0x7f
#define BIT_QUEUEMACID_MGQ_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_MGQ_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_MGQ_V1_8822C)
#define BITS_QUEUEMACID_MGQ_V1_8822C \
(BIT_MASK_QUEUEMACID_MGQ_V1_8822C << BIT_SHIFT_QUEUEMACID_MGQ_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_MGQ_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_MGQ_V1_8822C))
#define BIT_GET_QUEUEMACID_MGQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_MGQ_V1_8822C) & \
BIT_MASK_QUEUEMACID_MGQ_V1_8822C)
#define BIT_SET_QUEUEMACID_MGQ_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_MGQ_V1_8822C(x) | BIT_QUEUEMACID_MGQ_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_MGQ_V1_8822C 23
#define BIT_MASK_QUEUEAC_MGQ_V1_8822C 0x3
#define BIT_QUEUEAC_MGQ_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_MGQ_V1_8822C) \
<< BIT_SHIFT_QUEUEAC_MGQ_V1_8822C)
#define BITS_QUEUEAC_MGQ_V1_8822C \
(BIT_MASK_QUEUEAC_MGQ_V1_8822C << BIT_SHIFT_QUEUEAC_MGQ_V1_8822C)
#define BIT_CLEAR_QUEUEAC_MGQ_V1_8822C(x) ((x) & (~BITS_QUEUEAC_MGQ_V1_8822C))
#define BIT_GET_QUEUEAC_MGQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_MGQ_V1_8822C) & \
BIT_MASK_QUEUEAC_MGQ_V1_8822C)
#define BIT_SET_QUEUEAC_MGQ_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_MGQ_V1_8822C(x) | BIT_QUEUEAC_MGQ_V1_8822C(v))
#define BIT_TIDEMPTY_MGQ_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_MGQ_V2_8822C 11
#define BIT_MASK_TAIL_PKT_MGQ_V2_8822C 0x7ff
#define BIT_TAIL_PKT_MGQ_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_MGQ_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_MGQ_V2_8822C)
#define BITS_TAIL_PKT_MGQ_V2_8822C \
(BIT_MASK_TAIL_PKT_MGQ_V2_8822C << BIT_SHIFT_TAIL_PKT_MGQ_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_MGQ_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_MGQ_V2_8822C))
#define BIT_GET_TAIL_PKT_MGQ_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_MGQ_V2_8822C) & \
BIT_MASK_TAIL_PKT_MGQ_V2_8822C)
#define BIT_SET_TAIL_PKT_MGQ_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_MGQ_V2_8822C(x) | BIT_TAIL_PKT_MGQ_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_MGQ_V1_8822C 0
#define BIT_MASK_HEAD_PKT_MGQ_V1_8822C 0x7ff
#define BIT_HEAD_PKT_MGQ_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_MGQ_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_MGQ_V1_8822C)
#define BITS_HEAD_PKT_MGQ_V1_8822C \
(BIT_MASK_HEAD_PKT_MGQ_V1_8822C << BIT_SHIFT_HEAD_PKT_MGQ_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_MGQ_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_MGQ_V1_8822C))
#define BIT_GET_HEAD_PKT_MGQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_MGQ_V1_8822C) & \
BIT_MASK_HEAD_PKT_MGQ_V1_8822C)
#define BIT_SET_HEAD_PKT_MGQ_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_MGQ_V1_8822C(x) | BIT_HEAD_PKT_MGQ_V1_8822C(v))
/* 2 REG_HIQ_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_HIQ_V1_8822C 25
#define BIT_MASK_QUEUEMACID_HIQ_V1_8822C 0x7f
#define BIT_QUEUEMACID_HIQ_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_HIQ_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_HIQ_V1_8822C)
#define BITS_QUEUEMACID_HIQ_V1_8822C \
(BIT_MASK_QUEUEMACID_HIQ_V1_8822C << BIT_SHIFT_QUEUEMACID_HIQ_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_HIQ_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_HIQ_V1_8822C))
#define BIT_GET_QUEUEMACID_HIQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_HIQ_V1_8822C) & \
BIT_MASK_QUEUEMACID_HIQ_V1_8822C)
#define BIT_SET_QUEUEMACID_HIQ_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_HIQ_V1_8822C(x) | BIT_QUEUEMACID_HIQ_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_HIQ_V1_8822C 23
#define BIT_MASK_QUEUEAC_HIQ_V1_8822C 0x3
#define BIT_QUEUEAC_HIQ_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_HIQ_V1_8822C) \
<< BIT_SHIFT_QUEUEAC_HIQ_V1_8822C)
#define BITS_QUEUEAC_HIQ_V1_8822C \
(BIT_MASK_QUEUEAC_HIQ_V1_8822C << BIT_SHIFT_QUEUEAC_HIQ_V1_8822C)
#define BIT_CLEAR_QUEUEAC_HIQ_V1_8822C(x) ((x) & (~BITS_QUEUEAC_HIQ_V1_8822C))
#define BIT_GET_QUEUEAC_HIQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_HIQ_V1_8822C) & \
BIT_MASK_QUEUEAC_HIQ_V1_8822C)
#define BIT_SET_QUEUEAC_HIQ_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_HIQ_V1_8822C(x) | BIT_QUEUEAC_HIQ_V1_8822C(v))
#define BIT_TIDEMPTY_HIQ_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_HIQ_V2_8822C 11
#define BIT_MASK_TAIL_PKT_HIQ_V2_8822C 0x7ff
#define BIT_TAIL_PKT_HIQ_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_HIQ_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_HIQ_V2_8822C)
#define BITS_TAIL_PKT_HIQ_V2_8822C \
(BIT_MASK_TAIL_PKT_HIQ_V2_8822C << BIT_SHIFT_TAIL_PKT_HIQ_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_HIQ_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_HIQ_V2_8822C))
#define BIT_GET_TAIL_PKT_HIQ_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_HIQ_V2_8822C) & \
BIT_MASK_TAIL_PKT_HIQ_V2_8822C)
#define BIT_SET_TAIL_PKT_HIQ_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_HIQ_V2_8822C(x) | BIT_TAIL_PKT_HIQ_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_HIQ_V1_8822C 0
#define BIT_MASK_HEAD_PKT_HIQ_V1_8822C 0x7ff
#define BIT_HEAD_PKT_HIQ_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_HIQ_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_HIQ_V1_8822C)
#define BITS_HEAD_PKT_HIQ_V1_8822C \
(BIT_MASK_HEAD_PKT_HIQ_V1_8822C << BIT_SHIFT_HEAD_PKT_HIQ_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_HIQ_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_HIQ_V1_8822C))
#define BIT_GET_HEAD_PKT_HIQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_HIQ_V1_8822C) & \
BIT_MASK_HEAD_PKT_HIQ_V1_8822C)
#define BIT_SET_HEAD_PKT_HIQ_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_HIQ_V1_8822C(x) | BIT_HEAD_PKT_HIQ_V1_8822C(v))
/* 2 REG_BCNQ_INFO_8822C */
#define BIT_SHIFT_BCNQ_HEAD_PG_V1_8822C 0
#define BIT_MASK_BCNQ_HEAD_PG_V1_8822C 0xfff
#define BIT_BCNQ_HEAD_PG_V1_8822C(x) \
(((x) & BIT_MASK_BCNQ_HEAD_PG_V1_8822C) \
<< BIT_SHIFT_BCNQ_HEAD_PG_V1_8822C)
#define BITS_BCNQ_HEAD_PG_V1_8822C \
(BIT_MASK_BCNQ_HEAD_PG_V1_8822C << BIT_SHIFT_BCNQ_HEAD_PG_V1_8822C)
#define BIT_CLEAR_BCNQ_HEAD_PG_V1_8822C(x) ((x) & (~BITS_BCNQ_HEAD_PG_V1_8822C))
#define BIT_GET_BCNQ_HEAD_PG_V1_8822C(x) \
(((x) >> BIT_SHIFT_BCNQ_HEAD_PG_V1_8822C) & \
BIT_MASK_BCNQ_HEAD_PG_V1_8822C)
#define BIT_SET_BCNQ_HEAD_PG_V1_8822C(x, v) \
(BIT_CLEAR_BCNQ_HEAD_PG_V1_8822C(x) | BIT_BCNQ_HEAD_PG_V1_8822C(v))
/* 2 REG_TXPKT_EMPTY_8822C */
#define BIT_BCNQ_EMPTY_8822C BIT(11)
#define BIT_HQQ_EMPTY_8822C BIT(10)
#define BIT_MQQ_EMPTY_8822C BIT(9)
#define BIT_MGQ_CPU_EMPTY_8822C BIT(8)
#define BIT_AC7Q_EMPTY_8822C BIT(7)
#define BIT_AC6Q_EMPTY_8822C BIT(6)
#define BIT_AC5Q_EMPTY_8822C BIT(5)
#define BIT_AC4Q_EMPTY_8822C BIT(4)
#define BIT_AC3Q_EMPTY_8822C BIT(3)
#define BIT_AC2Q_EMPTY_8822C BIT(2)
#define BIT_AC1Q_EMPTY_8822C BIT(1)
#define BIT_AC0Q_EMPTY_8822C BIT(0)
/* 2 REG_CPU_MGQ_INFO_8822C */
#define BIT_BCN1_POLL_8822C BIT(30)
#define BIT_CPUMGT_POLL_8822C BIT(29)
#define BIT_BCN_POLL_8822C BIT(28)
#define BIT_CPUMGQ_FW_NUM_V1_8822C BIT(12)
#define BIT_SHIFT_FW_FREE_TAIL_V1_8822C 0
#define BIT_MASK_FW_FREE_TAIL_V1_8822C 0xfff
#define BIT_FW_FREE_TAIL_V1_8822C(x) \
(((x) & BIT_MASK_FW_FREE_TAIL_V1_8822C) \
<< BIT_SHIFT_FW_FREE_TAIL_V1_8822C)
#define BITS_FW_FREE_TAIL_V1_8822C \
(BIT_MASK_FW_FREE_TAIL_V1_8822C << BIT_SHIFT_FW_FREE_TAIL_V1_8822C)
#define BIT_CLEAR_FW_FREE_TAIL_V1_8822C(x) ((x) & (~BITS_FW_FREE_TAIL_V1_8822C))
#define BIT_GET_FW_FREE_TAIL_V1_8822C(x) \
(((x) >> BIT_SHIFT_FW_FREE_TAIL_V1_8822C) & \
BIT_MASK_FW_FREE_TAIL_V1_8822C)
#define BIT_SET_FW_FREE_TAIL_V1_8822C(x, v) \
(BIT_CLEAR_FW_FREE_TAIL_V1_8822C(x) | BIT_FW_FREE_TAIL_V1_8822C(v))
/* 2 REG_FWHW_TXQ_CTRL_8822C */
#define BIT_RTS_LIMIT_IN_OFDM_8822C BIT(23)
#define BIT_EN_BCNQ_DL_8822C BIT(22)
#define BIT_EN_RD_RESP_NAV_BK_8822C BIT(21)
#define BIT_EN_WR_FREE_TAIL_8822C BIT(20)
#define BIT_NOTXRPT_USERATE_EN_8822C BIT(19)
#define BIT_DIS_TXFAIL_RPT_8822C BIT(18)
#define BIT_FTM_TIMEOUT_BYPASS_8822C BIT(16)
#define BIT_SHIFT_EN_QUEUE_RPT_8822C 8
#define BIT_MASK_EN_QUEUE_RPT_8822C 0xff
#define BIT_EN_QUEUE_RPT_8822C(x) \
(((x) & BIT_MASK_EN_QUEUE_RPT_8822C) << BIT_SHIFT_EN_QUEUE_RPT_8822C)
#define BITS_EN_QUEUE_RPT_8822C \
(BIT_MASK_EN_QUEUE_RPT_8822C << BIT_SHIFT_EN_QUEUE_RPT_8822C)
#define BIT_CLEAR_EN_QUEUE_RPT_8822C(x) ((x) & (~BITS_EN_QUEUE_RPT_8822C))
#define BIT_GET_EN_QUEUE_RPT_8822C(x) \
(((x) >> BIT_SHIFT_EN_QUEUE_RPT_8822C) & BIT_MASK_EN_QUEUE_RPT_8822C)
#define BIT_SET_EN_QUEUE_RPT_8822C(x, v) \
(BIT_CLEAR_EN_QUEUE_RPT_8822C(x) | BIT_EN_QUEUE_RPT_8822C(v))
#define BIT_EN_RTY_BK_8822C BIT(7)
#define BIT_EN_USE_INI_RAT_8822C BIT(6)
#define BIT_EN_RTS_NAV_BK_8822C BIT(5)
#define BIT_DIS_SSN_CHECK_8822C BIT(4)
#define BIT_MACID_MATCH_RTS_8822C BIT(3)
#define BIT_EN_BCN_TRXRPT_V1_8822C BIT(2)
#define BIT_R_EN_FTMRPT_V1_8822C BIT(1)
#define BIT_R_BMC_NAV_PROTECT_8822C BIT(0)
/* 2 REG_DATAFB_SEL_8822C */
#define BIT_BROADCAST_RTY_EN_8822C BIT(3)
#define BIT_EN_RTY_BK_COD_8822C BIT(2)
#define BIT_SHIFT__R_DATA_FALLBACK_SEL_8822C 0
#define BIT_MASK__R_DATA_FALLBACK_SEL_8822C 0x3
#define BIT__R_DATA_FALLBACK_SEL_8822C(x) \
(((x) & BIT_MASK__R_DATA_FALLBACK_SEL_8822C) \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8822C)
#define BITS__R_DATA_FALLBACK_SEL_8822C \
(BIT_MASK__R_DATA_FALLBACK_SEL_8822C \
<< BIT_SHIFT__R_DATA_FALLBACK_SEL_8822C)
#define BIT_CLEAR__R_DATA_FALLBACK_SEL_8822C(x) \
((x) & (~BITS__R_DATA_FALLBACK_SEL_8822C))
#define BIT_GET__R_DATA_FALLBACK_SEL_8822C(x) \
(((x) >> BIT_SHIFT__R_DATA_FALLBACK_SEL_8822C) & \
BIT_MASK__R_DATA_FALLBACK_SEL_8822C)
#define BIT_SET__R_DATA_FALLBACK_SEL_8822C(x, v) \
(BIT_CLEAR__R_DATA_FALLBACK_SEL_8822C(x) | \
BIT__R_DATA_FALLBACK_SEL_8822C(v))
/* 2 REG_BCNQ_BDNY_V1_8822C */
#define BIT_SHIFT_BCNQ_PGBNDY_V1_8822C 0
#define BIT_MASK_BCNQ_PGBNDY_V1_8822C 0xfff
#define BIT_BCNQ_PGBNDY_V1_8822C(x) \
(((x) & BIT_MASK_BCNQ_PGBNDY_V1_8822C) \
<< BIT_SHIFT_BCNQ_PGBNDY_V1_8822C)
#define BITS_BCNQ_PGBNDY_V1_8822C \
(BIT_MASK_BCNQ_PGBNDY_V1_8822C << BIT_SHIFT_BCNQ_PGBNDY_V1_8822C)
#define BIT_CLEAR_BCNQ_PGBNDY_V1_8822C(x) ((x) & (~BITS_BCNQ_PGBNDY_V1_8822C))
#define BIT_GET_BCNQ_PGBNDY_V1_8822C(x) \
(((x) >> BIT_SHIFT_BCNQ_PGBNDY_V1_8822C) & \
BIT_MASK_BCNQ_PGBNDY_V1_8822C)
#define BIT_SET_BCNQ_PGBNDY_V1_8822C(x, v) \
(BIT_CLEAR_BCNQ_PGBNDY_V1_8822C(x) | BIT_BCNQ_PGBNDY_V1_8822C(v))
/* 2 REG_LIFETIME_EN_8822C */
#define BIT_BT_INT_CPU_8822C BIT(7)
#define BIT_BT_INT_PTA_8822C BIT(6)
#define BIT_EN_CTRL_RTYBIT_8822C BIT(4)
#define BIT_LIFETIME_BK_EN_8822C BIT(3)
#define BIT_LIFETIME_BE_EN_8822C BIT(2)
#define BIT_LIFETIME_VI_EN_8822C BIT(1)
#define BIT_LIFETIME_VO_EN_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SPEC_SIFS_8822C */
#define BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822C 8
#define BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822C 0xff
#define BIT_SPEC_SIFS_OFDM_PTCL_8822C(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822C) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822C)
#define BITS_SPEC_SIFS_OFDM_PTCL_8822C \
(BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822C \
<< BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822C)
#define BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8822C(x) \
((x) & (~BITS_SPEC_SIFS_OFDM_PTCL_8822C))
#define BIT_GET_SPEC_SIFS_OFDM_PTCL_8822C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_PTCL_8822C) & \
BIT_MASK_SPEC_SIFS_OFDM_PTCL_8822C)
#define BIT_SET_SPEC_SIFS_OFDM_PTCL_8822C(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_PTCL_8822C(x) | \
BIT_SPEC_SIFS_OFDM_PTCL_8822C(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822C 0
#define BIT_MASK_SPEC_SIFS_CCK_PTCL_8822C 0xff
#define BIT_SPEC_SIFS_CCK_PTCL_8822C(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_PTCL_8822C) \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822C)
#define BITS_SPEC_SIFS_CCK_PTCL_8822C \
(BIT_MASK_SPEC_SIFS_CCK_PTCL_8822C \
<< BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822C)
#define BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8822C(x) \
((x) & (~BITS_SPEC_SIFS_CCK_PTCL_8822C))
#define BIT_GET_SPEC_SIFS_CCK_PTCL_8822C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_PTCL_8822C) & \
BIT_MASK_SPEC_SIFS_CCK_PTCL_8822C)
#define BIT_SET_SPEC_SIFS_CCK_PTCL_8822C(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_PTCL_8822C(x) | \
BIT_SPEC_SIFS_CCK_PTCL_8822C(v))
/* 2 REG_RETRY_LIMIT_8822C */
#define BIT_SHIFT_SRL_8822C 8
#define BIT_MASK_SRL_8822C 0x3f
#define BIT_SRL_8822C(x) (((x) & BIT_MASK_SRL_8822C) << BIT_SHIFT_SRL_8822C)
#define BITS_SRL_8822C (BIT_MASK_SRL_8822C << BIT_SHIFT_SRL_8822C)
#define BIT_CLEAR_SRL_8822C(x) ((x) & (~BITS_SRL_8822C))
#define BIT_GET_SRL_8822C(x) (((x) >> BIT_SHIFT_SRL_8822C) & BIT_MASK_SRL_8822C)
#define BIT_SET_SRL_8822C(x, v) (BIT_CLEAR_SRL_8822C(x) | BIT_SRL_8822C(v))
#define BIT_SHIFT_LRL_8822C 0
#define BIT_MASK_LRL_8822C 0x3f
#define BIT_LRL_8822C(x) (((x) & BIT_MASK_LRL_8822C) << BIT_SHIFT_LRL_8822C)
#define BITS_LRL_8822C (BIT_MASK_LRL_8822C << BIT_SHIFT_LRL_8822C)
#define BIT_CLEAR_LRL_8822C(x) ((x) & (~BITS_LRL_8822C))
#define BIT_GET_LRL_8822C(x) (((x) >> BIT_SHIFT_LRL_8822C) & BIT_MASK_LRL_8822C)
#define BIT_SET_LRL_8822C(x, v) (BIT_CLEAR_LRL_8822C(x) | BIT_LRL_8822C(v))
/* 2 REG_TXBF_CTRL_8822C */
#define BIT_R_ENABLE_NDPA_8822C BIT(31)
#define BIT_USE_NDPA_PARAMETER_8822C BIT(30)
#define BIT_R_PROP_TXBF_8822C BIT(29)
#define BIT_R_EN_NDPA_INT_8822C BIT(28)
#define BIT_R_TXBF1_80M_8822C BIT(27)
#define BIT_R_TXBF1_40M_8822C BIT(26)
#define BIT_R_TXBF1_20M_8822C BIT(25)
#define BIT_SHIFT_R_TXBF1_AID_8822C 16
#define BIT_MASK_R_TXBF1_AID_8822C 0x1ff
#define BIT_R_TXBF1_AID_8822C(x) \
(((x) & BIT_MASK_R_TXBF1_AID_8822C) << BIT_SHIFT_R_TXBF1_AID_8822C)
#define BITS_R_TXBF1_AID_8822C \
(BIT_MASK_R_TXBF1_AID_8822C << BIT_SHIFT_R_TXBF1_AID_8822C)
#define BIT_CLEAR_R_TXBF1_AID_8822C(x) ((x) & (~BITS_R_TXBF1_AID_8822C))
#define BIT_GET_R_TXBF1_AID_8822C(x) \
(((x) >> BIT_SHIFT_R_TXBF1_AID_8822C) & BIT_MASK_R_TXBF1_AID_8822C)
#define BIT_SET_R_TXBF1_AID_8822C(x, v) \
(BIT_CLEAR_R_TXBF1_AID_8822C(x) | BIT_R_TXBF1_AID_8822C(v))
#define BIT_DIS_NDP_BFEN_8822C BIT(15)
#define BIT_R_TXBCN_NOBLOCK_NDP_8822C BIT(14)
#define BIT_R_TXBF0_80M_8822C BIT(11)
#define BIT_R_TXBF0_40M_8822C BIT(10)
#define BIT_R_TXBF0_20M_8822C BIT(9)
#define BIT_SHIFT_R_TXBF0_AID_8822C 0
#define BIT_MASK_R_TXBF0_AID_8822C 0x1ff
#define BIT_R_TXBF0_AID_8822C(x) \
(((x) & BIT_MASK_R_TXBF0_AID_8822C) << BIT_SHIFT_R_TXBF0_AID_8822C)
#define BITS_R_TXBF0_AID_8822C \
(BIT_MASK_R_TXBF0_AID_8822C << BIT_SHIFT_R_TXBF0_AID_8822C)
#define BIT_CLEAR_R_TXBF0_AID_8822C(x) ((x) & (~BITS_R_TXBF0_AID_8822C))
#define BIT_GET_R_TXBF0_AID_8822C(x) \
(((x) >> BIT_SHIFT_R_TXBF0_AID_8822C) & BIT_MASK_R_TXBF0_AID_8822C)
#define BIT_SET_R_TXBF0_AID_8822C(x, v) \
(BIT_CLEAR_R_TXBF0_AID_8822C(x) | BIT_R_TXBF0_AID_8822C(v))
/* 2 REG_DARFRC_8822C */
#define BIT_SHIFT_DARF_RC4_8822C 24
#define BIT_MASK_DARF_RC4_8822C 0x1f
#define BIT_DARF_RC4_8822C(x) \
(((x) & BIT_MASK_DARF_RC4_8822C) << BIT_SHIFT_DARF_RC4_8822C)
#define BITS_DARF_RC4_8822C \
(BIT_MASK_DARF_RC4_8822C << BIT_SHIFT_DARF_RC4_8822C)
#define BIT_CLEAR_DARF_RC4_8822C(x) ((x) & (~BITS_DARF_RC4_8822C))
#define BIT_GET_DARF_RC4_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC4_8822C) & BIT_MASK_DARF_RC4_8822C)
#define BIT_SET_DARF_RC4_8822C(x, v) \
(BIT_CLEAR_DARF_RC4_8822C(x) | BIT_DARF_RC4_8822C(v))
#define BIT_SHIFT_DARF_RC3_8822C 16
#define BIT_MASK_DARF_RC3_8822C 0x1f
#define BIT_DARF_RC3_8822C(x) \
(((x) & BIT_MASK_DARF_RC3_8822C) << BIT_SHIFT_DARF_RC3_8822C)
#define BITS_DARF_RC3_8822C \
(BIT_MASK_DARF_RC3_8822C << BIT_SHIFT_DARF_RC3_8822C)
#define BIT_CLEAR_DARF_RC3_8822C(x) ((x) & (~BITS_DARF_RC3_8822C))
#define BIT_GET_DARF_RC3_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC3_8822C) & BIT_MASK_DARF_RC3_8822C)
#define BIT_SET_DARF_RC3_8822C(x, v) \
(BIT_CLEAR_DARF_RC3_8822C(x) | BIT_DARF_RC3_8822C(v))
#define BIT_SHIFT_DARF_RC2_8822C 8
#define BIT_MASK_DARF_RC2_8822C 0x1f
#define BIT_DARF_RC2_8822C(x) \
(((x) & BIT_MASK_DARF_RC2_8822C) << BIT_SHIFT_DARF_RC2_8822C)
#define BITS_DARF_RC2_8822C \
(BIT_MASK_DARF_RC2_8822C << BIT_SHIFT_DARF_RC2_8822C)
#define BIT_CLEAR_DARF_RC2_8822C(x) ((x) & (~BITS_DARF_RC2_8822C))
#define BIT_GET_DARF_RC2_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC2_8822C) & BIT_MASK_DARF_RC2_8822C)
#define BIT_SET_DARF_RC2_8822C(x, v) \
(BIT_CLEAR_DARF_RC2_8822C(x) | BIT_DARF_RC2_8822C(v))
#define BIT_SHIFT_DARF_RC1_8822C 0
#define BIT_MASK_DARF_RC1_8822C 0x1f
#define BIT_DARF_RC1_8822C(x) \
(((x) & BIT_MASK_DARF_RC1_8822C) << BIT_SHIFT_DARF_RC1_8822C)
#define BITS_DARF_RC1_8822C \
(BIT_MASK_DARF_RC1_8822C << BIT_SHIFT_DARF_RC1_8822C)
#define BIT_CLEAR_DARF_RC1_8822C(x) ((x) & (~BITS_DARF_RC1_8822C))
#define BIT_GET_DARF_RC1_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC1_8822C) & BIT_MASK_DARF_RC1_8822C)
#define BIT_SET_DARF_RC1_8822C(x, v) \
(BIT_CLEAR_DARF_RC1_8822C(x) | BIT_DARF_RC1_8822C(v))
/* 2 REG_DARFRCH_8822C */
#define BIT_SHIFT_DARF_RC8_V1_8822C 24
#define BIT_MASK_DARF_RC8_V1_8822C 0x1f
#define BIT_DARF_RC8_V1_8822C(x) \
(((x) & BIT_MASK_DARF_RC8_V1_8822C) << BIT_SHIFT_DARF_RC8_V1_8822C)
#define BITS_DARF_RC8_V1_8822C \
(BIT_MASK_DARF_RC8_V1_8822C << BIT_SHIFT_DARF_RC8_V1_8822C)
#define BIT_CLEAR_DARF_RC8_V1_8822C(x) ((x) & (~BITS_DARF_RC8_V1_8822C))
#define BIT_GET_DARF_RC8_V1_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC8_V1_8822C) & BIT_MASK_DARF_RC8_V1_8822C)
#define BIT_SET_DARF_RC8_V1_8822C(x, v) \
(BIT_CLEAR_DARF_RC8_V1_8822C(x) | BIT_DARF_RC8_V1_8822C(v))
#define BIT_SHIFT_DARF_RC7_V1_8822C 16
#define BIT_MASK_DARF_RC7_V1_8822C 0x1f
#define BIT_DARF_RC7_V1_8822C(x) \
(((x) & BIT_MASK_DARF_RC7_V1_8822C) << BIT_SHIFT_DARF_RC7_V1_8822C)
#define BITS_DARF_RC7_V1_8822C \
(BIT_MASK_DARF_RC7_V1_8822C << BIT_SHIFT_DARF_RC7_V1_8822C)
#define BIT_CLEAR_DARF_RC7_V1_8822C(x) ((x) & (~BITS_DARF_RC7_V1_8822C))
#define BIT_GET_DARF_RC7_V1_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC7_V1_8822C) & BIT_MASK_DARF_RC7_V1_8822C)
#define BIT_SET_DARF_RC7_V1_8822C(x, v) \
(BIT_CLEAR_DARF_RC7_V1_8822C(x) | BIT_DARF_RC7_V1_8822C(v))
#define BIT_SHIFT_DARF_RC6_V1_8822C 8
#define BIT_MASK_DARF_RC6_V1_8822C 0x1f
#define BIT_DARF_RC6_V1_8822C(x) \
(((x) & BIT_MASK_DARF_RC6_V1_8822C) << BIT_SHIFT_DARF_RC6_V1_8822C)
#define BITS_DARF_RC6_V1_8822C \
(BIT_MASK_DARF_RC6_V1_8822C << BIT_SHIFT_DARF_RC6_V1_8822C)
#define BIT_CLEAR_DARF_RC6_V1_8822C(x) ((x) & (~BITS_DARF_RC6_V1_8822C))
#define BIT_GET_DARF_RC6_V1_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC6_V1_8822C) & BIT_MASK_DARF_RC6_V1_8822C)
#define BIT_SET_DARF_RC6_V1_8822C(x, v) \
(BIT_CLEAR_DARF_RC6_V1_8822C(x) | BIT_DARF_RC6_V1_8822C(v))
#define BIT_SHIFT_DARF_RC5_V1_8822C 0
#define BIT_MASK_DARF_RC5_V1_8822C 0x1f
#define BIT_DARF_RC5_V1_8822C(x) \
(((x) & BIT_MASK_DARF_RC5_V1_8822C) << BIT_SHIFT_DARF_RC5_V1_8822C)
#define BITS_DARF_RC5_V1_8822C \
(BIT_MASK_DARF_RC5_V1_8822C << BIT_SHIFT_DARF_RC5_V1_8822C)
#define BIT_CLEAR_DARF_RC5_V1_8822C(x) ((x) & (~BITS_DARF_RC5_V1_8822C))
#define BIT_GET_DARF_RC5_V1_8822C(x) \
(((x) >> BIT_SHIFT_DARF_RC5_V1_8822C) & BIT_MASK_DARF_RC5_V1_8822C)
#define BIT_SET_DARF_RC5_V1_8822C(x, v) \
(BIT_CLEAR_DARF_RC5_V1_8822C(x) | BIT_DARF_RC5_V1_8822C(v))
/* 2 REG_RARFRC_8822C */
#define BIT_SHIFT_RARF_RC4_8822C 24
#define BIT_MASK_RARF_RC4_8822C 0x1f
#define BIT_RARF_RC4_8822C(x) \
(((x) & BIT_MASK_RARF_RC4_8822C) << BIT_SHIFT_RARF_RC4_8822C)
#define BITS_RARF_RC4_8822C \
(BIT_MASK_RARF_RC4_8822C << BIT_SHIFT_RARF_RC4_8822C)
#define BIT_CLEAR_RARF_RC4_8822C(x) ((x) & (~BITS_RARF_RC4_8822C))
#define BIT_GET_RARF_RC4_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC4_8822C) & BIT_MASK_RARF_RC4_8822C)
#define BIT_SET_RARF_RC4_8822C(x, v) \
(BIT_CLEAR_RARF_RC4_8822C(x) | BIT_RARF_RC4_8822C(v))
#define BIT_SHIFT_RARF_RC3_8822C 16
#define BIT_MASK_RARF_RC3_8822C 0x1f
#define BIT_RARF_RC3_8822C(x) \
(((x) & BIT_MASK_RARF_RC3_8822C) << BIT_SHIFT_RARF_RC3_8822C)
#define BITS_RARF_RC3_8822C \
(BIT_MASK_RARF_RC3_8822C << BIT_SHIFT_RARF_RC3_8822C)
#define BIT_CLEAR_RARF_RC3_8822C(x) ((x) & (~BITS_RARF_RC3_8822C))
#define BIT_GET_RARF_RC3_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC3_8822C) & BIT_MASK_RARF_RC3_8822C)
#define BIT_SET_RARF_RC3_8822C(x, v) \
(BIT_CLEAR_RARF_RC3_8822C(x) | BIT_RARF_RC3_8822C(v))
#define BIT_SHIFT_RARF_RC2_8822C 8
#define BIT_MASK_RARF_RC2_8822C 0x1f
#define BIT_RARF_RC2_8822C(x) \
(((x) & BIT_MASK_RARF_RC2_8822C) << BIT_SHIFT_RARF_RC2_8822C)
#define BITS_RARF_RC2_8822C \
(BIT_MASK_RARF_RC2_8822C << BIT_SHIFT_RARF_RC2_8822C)
#define BIT_CLEAR_RARF_RC2_8822C(x) ((x) & (~BITS_RARF_RC2_8822C))
#define BIT_GET_RARF_RC2_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC2_8822C) & BIT_MASK_RARF_RC2_8822C)
#define BIT_SET_RARF_RC2_8822C(x, v) \
(BIT_CLEAR_RARF_RC2_8822C(x) | BIT_RARF_RC2_8822C(v))
#define BIT_SHIFT_RARF_RC1_8822C 0
#define BIT_MASK_RARF_RC1_8822C 0x1f
#define BIT_RARF_RC1_8822C(x) \
(((x) & BIT_MASK_RARF_RC1_8822C) << BIT_SHIFT_RARF_RC1_8822C)
#define BITS_RARF_RC1_8822C \
(BIT_MASK_RARF_RC1_8822C << BIT_SHIFT_RARF_RC1_8822C)
#define BIT_CLEAR_RARF_RC1_8822C(x) ((x) & (~BITS_RARF_RC1_8822C))
#define BIT_GET_RARF_RC1_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC1_8822C) & BIT_MASK_RARF_RC1_8822C)
#define BIT_SET_RARF_RC1_8822C(x, v) \
(BIT_CLEAR_RARF_RC1_8822C(x) | BIT_RARF_RC1_8822C(v))
/* 2 REG_RARFRCH_8822C */
#define BIT_SHIFT_RARF_RC8_V1_8822C 24
#define BIT_MASK_RARF_RC8_V1_8822C 0x1f
#define BIT_RARF_RC8_V1_8822C(x) \
(((x) & BIT_MASK_RARF_RC8_V1_8822C) << BIT_SHIFT_RARF_RC8_V1_8822C)
#define BITS_RARF_RC8_V1_8822C \
(BIT_MASK_RARF_RC8_V1_8822C << BIT_SHIFT_RARF_RC8_V1_8822C)
#define BIT_CLEAR_RARF_RC8_V1_8822C(x) ((x) & (~BITS_RARF_RC8_V1_8822C))
#define BIT_GET_RARF_RC8_V1_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC8_V1_8822C) & BIT_MASK_RARF_RC8_V1_8822C)
#define BIT_SET_RARF_RC8_V1_8822C(x, v) \
(BIT_CLEAR_RARF_RC8_V1_8822C(x) | BIT_RARF_RC8_V1_8822C(v))
#define BIT_SHIFT_RARF_RC7_V1_8822C 16
#define BIT_MASK_RARF_RC7_V1_8822C 0x1f
#define BIT_RARF_RC7_V1_8822C(x) \
(((x) & BIT_MASK_RARF_RC7_V1_8822C) << BIT_SHIFT_RARF_RC7_V1_8822C)
#define BITS_RARF_RC7_V1_8822C \
(BIT_MASK_RARF_RC7_V1_8822C << BIT_SHIFT_RARF_RC7_V1_8822C)
#define BIT_CLEAR_RARF_RC7_V1_8822C(x) ((x) & (~BITS_RARF_RC7_V1_8822C))
#define BIT_GET_RARF_RC7_V1_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC7_V1_8822C) & BIT_MASK_RARF_RC7_V1_8822C)
#define BIT_SET_RARF_RC7_V1_8822C(x, v) \
(BIT_CLEAR_RARF_RC7_V1_8822C(x) | BIT_RARF_RC7_V1_8822C(v))
#define BIT_SHIFT_RARF_RC6_V1_8822C 8
#define BIT_MASK_RARF_RC6_V1_8822C 0x1f
#define BIT_RARF_RC6_V1_8822C(x) \
(((x) & BIT_MASK_RARF_RC6_V1_8822C) << BIT_SHIFT_RARF_RC6_V1_8822C)
#define BITS_RARF_RC6_V1_8822C \
(BIT_MASK_RARF_RC6_V1_8822C << BIT_SHIFT_RARF_RC6_V1_8822C)
#define BIT_CLEAR_RARF_RC6_V1_8822C(x) ((x) & (~BITS_RARF_RC6_V1_8822C))
#define BIT_GET_RARF_RC6_V1_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC6_V1_8822C) & BIT_MASK_RARF_RC6_V1_8822C)
#define BIT_SET_RARF_RC6_V1_8822C(x, v) \
(BIT_CLEAR_RARF_RC6_V1_8822C(x) | BIT_RARF_RC6_V1_8822C(v))
#define BIT_SHIFT_RARF_RC5_V1_8822C 0
#define BIT_MASK_RARF_RC5_V1_8822C 0x1f
#define BIT_RARF_RC5_V1_8822C(x) \
(((x) & BIT_MASK_RARF_RC5_V1_8822C) << BIT_SHIFT_RARF_RC5_V1_8822C)
#define BITS_RARF_RC5_V1_8822C \
(BIT_MASK_RARF_RC5_V1_8822C << BIT_SHIFT_RARF_RC5_V1_8822C)
#define BIT_CLEAR_RARF_RC5_V1_8822C(x) ((x) & (~BITS_RARF_RC5_V1_8822C))
#define BIT_GET_RARF_RC5_V1_8822C(x) \
(((x) >> BIT_SHIFT_RARF_RC5_V1_8822C) & BIT_MASK_RARF_RC5_V1_8822C)
#define BIT_SET_RARF_RC5_V1_8822C(x, v) \
(BIT_CLEAR_RARF_RC5_V1_8822C(x) | BIT_RARF_RC5_V1_8822C(v))
/* 2 REG_RRSR_8822C */
#define BIT_SHIFT_RRSR_RSC_8822C 21
#define BIT_MASK_RRSR_RSC_8822C 0x3
#define BIT_RRSR_RSC_8822C(x) \
(((x) & BIT_MASK_RRSR_RSC_8822C) << BIT_SHIFT_RRSR_RSC_8822C)
#define BITS_RRSR_RSC_8822C \
(BIT_MASK_RRSR_RSC_8822C << BIT_SHIFT_RRSR_RSC_8822C)
#define BIT_CLEAR_RRSR_RSC_8822C(x) ((x) & (~BITS_RRSR_RSC_8822C))
#define BIT_GET_RRSR_RSC_8822C(x) \
(((x) >> BIT_SHIFT_RRSR_RSC_8822C) & BIT_MASK_RRSR_RSC_8822C)
#define BIT_SET_RRSR_RSC_8822C(x, v) \
(BIT_CLEAR_RRSR_RSC_8822C(x) | BIT_RRSR_RSC_8822C(v))
#define BIT_SHIFT_RRSC_BITMAP_8822C 0
#define BIT_MASK_RRSC_BITMAP_8822C 0xfffff
#define BIT_RRSC_BITMAP_8822C(x) \
(((x) & BIT_MASK_RRSC_BITMAP_8822C) << BIT_SHIFT_RRSC_BITMAP_8822C)
#define BITS_RRSC_BITMAP_8822C \
(BIT_MASK_RRSC_BITMAP_8822C << BIT_SHIFT_RRSC_BITMAP_8822C)
#define BIT_CLEAR_RRSC_BITMAP_8822C(x) ((x) & (~BITS_RRSC_BITMAP_8822C))
#define BIT_GET_RRSC_BITMAP_8822C(x) \
(((x) >> BIT_SHIFT_RRSC_BITMAP_8822C) & BIT_MASK_RRSC_BITMAP_8822C)
#define BIT_SET_RRSC_BITMAP_8822C(x, v) \
(BIT_CLEAR_RRSC_BITMAP_8822C(x) | BIT_RRSC_BITMAP_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ARFR0_8822C */
#define BIT_SHIFT_ARFRL0_8822C 0
#define BIT_MASK_ARFRL0_8822C 0xffffffffL
#define BIT_ARFRL0_8822C(x) \
(((x) & BIT_MASK_ARFRL0_8822C) << BIT_SHIFT_ARFRL0_8822C)
#define BITS_ARFRL0_8822C (BIT_MASK_ARFRL0_8822C << BIT_SHIFT_ARFRL0_8822C)
#define BIT_CLEAR_ARFRL0_8822C(x) ((x) & (~BITS_ARFRL0_8822C))
#define BIT_GET_ARFRL0_8822C(x) \
(((x) >> BIT_SHIFT_ARFRL0_8822C) & BIT_MASK_ARFRL0_8822C)
#define BIT_SET_ARFRL0_8822C(x, v) \
(BIT_CLEAR_ARFRL0_8822C(x) | BIT_ARFRL0_8822C(v))
/* 2 REG_ARFRH0_8822C */
#define BIT_SHIFT_ARFRH0_8822C 0
#define BIT_MASK_ARFRH0_8822C 0xffffffffL
#define BIT_ARFRH0_8822C(x) \
(((x) & BIT_MASK_ARFRH0_8822C) << BIT_SHIFT_ARFRH0_8822C)
#define BITS_ARFRH0_8822C (BIT_MASK_ARFRH0_8822C << BIT_SHIFT_ARFRH0_8822C)
#define BIT_CLEAR_ARFRH0_8822C(x) ((x) & (~BITS_ARFRH0_8822C))
#define BIT_GET_ARFRH0_8822C(x) \
(((x) >> BIT_SHIFT_ARFRH0_8822C) & BIT_MASK_ARFRH0_8822C)
#define BIT_SET_ARFRH0_8822C(x, v) \
(BIT_CLEAR_ARFRH0_8822C(x) | BIT_ARFRH0_8822C(v))
/* 2 REG_ARFR1_V1_8822C */
#define BIT_SHIFT_ARFRL1_8822C 0
#define BIT_MASK_ARFRL1_8822C 0xffffffffL
#define BIT_ARFRL1_8822C(x) \
(((x) & BIT_MASK_ARFRL1_8822C) << BIT_SHIFT_ARFRL1_8822C)
#define BITS_ARFRL1_8822C (BIT_MASK_ARFRL1_8822C << BIT_SHIFT_ARFRL1_8822C)
#define BIT_CLEAR_ARFRL1_8822C(x) ((x) & (~BITS_ARFRL1_8822C))
#define BIT_GET_ARFRL1_8822C(x) \
(((x) >> BIT_SHIFT_ARFRL1_8822C) & BIT_MASK_ARFRL1_8822C)
#define BIT_SET_ARFRL1_8822C(x, v) \
(BIT_CLEAR_ARFRL1_8822C(x) | BIT_ARFRL1_8822C(v))
/* 2 REG_ARFRH1_V1_8822C */
#define BIT_SHIFT_ARFRH1_8822C 0
#define BIT_MASK_ARFRH1_8822C 0xffffffffL
#define BIT_ARFRH1_8822C(x) \
(((x) & BIT_MASK_ARFRH1_8822C) << BIT_SHIFT_ARFRH1_8822C)
#define BITS_ARFRH1_8822C (BIT_MASK_ARFRH1_8822C << BIT_SHIFT_ARFRH1_8822C)
#define BIT_CLEAR_ARFRH1_8822C(x) ((x) & (~BITS_ARFRH1_8822C))
#define BIT_GET_ARFRH1_8822C(x) \
(((x) >> BIT_SHIFT_ARFRH1_8822C) & BIT_MASK_ARFRH1_8822C)
#define BIT_SET_ARFRH1_8822C(x, v) \
(BIT_CLEAR_ARFRH1_8822C(x) | BIT_ARFRH1_8822C(v))
/* 2 REG_CCK_CHECK_8822C */
#define BIT_CHECK_CCK_EN_8822C BIT(7)
#define BIT_EN_BCN_PKT_REL_8822C BIT(6)
#define BIT_BCN_PORT_SEL_8822C BIT(5)
#define BIT_MOREDATA_BYPASS_8822C BIT(4)
#define BIT_EN_CLR_CMD_REL_BCN_PKT_8822C BIT(3)
#define BIT_R_EN_SET_MOREDATA_8822C BIT(2)
#define BIT__R_DIS_CLEAR_MACID_RELEASE_8822C BIT(1)
#define BIT__R_MACID_RELEASE_EN_8822C BIT(0)
/* 2 REG_AMPDU_MAX_TIME_V1_8822C */
#define BIT_SHIFT_AMPDU_MAX_TIME_8822C 0
#define BIT_MASK_AMPDU_MAX_TIME_8822C 0xff
#define BIT_AMPDU_MAX_TIME_8822C(x) \
(((x) & BIT_MASK_AMPDU_MAX_TIME_8822C) \
<< BIT_SHIFT_AMPDU_MAX_TIME_8822C)
#define BITS_AMPDU_MAX_TIME_8822C \
(BIT_MASK_AMPDU_MAX_TIME_8822C << BIT_SHIFT_AMPDU_MAX_TIME_8822C)
#define BIT_CLEAR_AMPDU_MAX_TIME_8822C(x) ((x) & (~BITS_AMPDU_MAX_TIME_8822C))
#define BIT_GET_AMPDU_MAX_TIME_8822C(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_TIME_8822C) & \
BIT_MASK_AMPDU_MAX_TIME_8822C)
#define BIT_SET_AMPDU_MAX_TIME_8822C(x, v) \
(BIT_CLEAR_AMPDU_MAX_TIME_8822C(x) | BIT_AMPDU_MAX_TIME_8822C(v))
/* 2 REG_BCNQ1_BDNY_V1_8822C */
#define BIT_SHIFT_BCNQ1_PGBNDY_V1_8822C 0
#define BIT_MASK_BCNQ1_PGBNDY_V1_8822C 0xfff
#define BIT_BCNQ1_PGBNDY_V1_8822C(x) \
(((x) & BIT_MASK_BCNQ1_PGBNDY_V1_8822C) \
<< BIT_SHIFT_BCNQ1_PGBNDY_V1_8822C)
#define BITS_BCNQ1_PGBNDY_V1_8822C \
(BIT_MASK_BCNQ1_PGBNDY_V1_8822C << BIT_SHIFT_BCNQ1_PGBNDY_V1_8822C)
#define BIT_CLEAR_BCNQ1_PGBNDY_V1_8822C(x) ((x) & (~BITS_BCNQ1_PGBNDY_V1_8822C))
#define BIT_GET_BCNQ1_PGBNDY_V1_8822C(x) \
(((x) >> BIT_SHIFT_BCNQ1_PGBNDY_V1_8822C) & \
BIT_MASK_BCNQ1_PGBNDY_V1_8822C)
#define BIT_SET_BCNQ1_PGBNDY_V1_8822C(x, v) \
(BIT_CLEAR_BCNQ1_PGBNDY_V1_8822C(x) | BIT_BCNQ1_PGBNDY_V1_8822C(v))
/* 2 REG_AMPDU_MAX_LENGTH_HT_8822C */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8822C 0
#define BIT_MASK_AMPDU_MAX_LENGTH_HT_8822C 0xffff
#define BIT_AMPDU_MAX_LENGTH_HT_8822C(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_HT_8822C) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8822C)
#define BITS_AMPDU_MAX_LENGTH_HT_8822C \
(BIT_MASK_AMPDU_MAX_LENGTH_HT_8822C \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8822C)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_HT_8822C(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_HT_8822C))
#define BIT_GET_AMPDU_MAX_LENGTH_HT_8822C(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_HT_8822C) & \
BIT_MASK_AMPDU_MAX_LENGTH_HT_8822C)
#define BIT_SET_AMPDU_MAX_LENGTH_HT_8822C(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_HT_8822C(x) | \
BIT_AMPDU_MAX_LENGTH_HT_8822C(v))
/* 2 REG_ACQ_STOP_8822C */
#define BIT_AC7Q_STOP_8822C BIT(7)
#define BIT_AC6Q_STOP_8822C BIT(6)
#define BIT_AC5Q_STOP_8822C BIT(5)
#define BIT_AC4Q_STOP_8822C BIT(4)
#define BIT_AC3Q_STOP_8822C BIT(3)
#define BIT_AC2Q_STOP_8822C BIT(2)
#define BIT_AC1Q_STOP_8822C BIT(1)
#define BIT_AC0Q_STOP_8822C BIT(0)
/* 2 REG_NDPA_RATE_8822C */
#define BIT_SHIFT_R_NDPA_RATE_V1_8822C 0
#define BIT_MASK_R_NDPA_RATE_V1_8822C 0xff
#define BIT_R_NDPA_RATE_V1_8822C(x) \
(((x) & BIT_MASK_R_NDPA_RATE_V1_8822C) \
<< BIT_SHIFT_R_NDPA_RATE_V1_8822C)
#define BITS_R_NDPA_RATE_V1_8822C \
(BIT_MASK_R_NDPA_RATE_V1_8822C << BIT_SHIFT_R_NDPA_RATE_V1_8822C)
#define BIT_CLEAR_R_NDPA_RATE_V1_8822C(x) ((x) & (~BITS_R_NDPA_RATE_V1_8822C))
#define BIT_GET_R_NDPA_RATE_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_NDPA_RATE_V1_8822C) & \
BIT_MASK_R_NDPA_RATE_V1_8822C)
#define BIT_SET_R_NDPA_RATE_V1_8822C(x, v) \
(BIT_CLEAR_R_NDPA_RATE_V1_8822C(x) | BIT_R_NDPA_RATE_V1_8822C(v))
/* 2 REG_TX_HANG_CTRL_8822C */
#define BIT_R_EN_GNT_BT_AWAKE_8822C BIT(3)
#define BIT_EN_EOF_V1_8822C BIT(2)
#define BIT_DIS_OQT_BLOCK_8822C BIT(1)
#define BIT_SEARCH_QUEUE_EN_8822C BIT(0)
/* 2 REG_NDPA_OPT_CTRL_8822C */
#define BIT_R_DIS_MACID_RELEASE_RTY_8822C BIT(5)
#define BIT_SHIFT_BW_SIGTA_8822C 3
#define BIT_MASK_BW_SIGTA_8822C 0x3
#define BIT_BW_SIGTA_8822C(x) \
(((x) & BIT_MASK_BW_SIGTA_8822C) << BIT_SHIFT_BW_SIGTA_8822C)
#define BITS_BW_SIGTA_8822C \
(BIT_MASK_BW_SIGTA_8822C << BIT_SHIFT_BW_SIGTA_8822C)
#define BIT_CLEAR_BW_SIGTA_8822C(x) ((x) & (~BITS_BW_SIGTA_8822C))
#define BIT_GET_BW_SIGTA_8822C(x) \
(((x) >> BIT_SHIFT_BW_SIGTA_8822C) & BIT_MASK_BW_SIGTA_8822C)
#define BIT_SET_BW_SIGTA_8822C(x, v) \
(BIT_CLEAR_BW_SIGTA_8822C(x) | BIT_BW_SIGTA_8822C(v))
#define BIT_EN_BAR_SIGTA_8822C BIT(2)
#define BIT_SHIFT_R_NDPA_BW_8822C 0
#define BIT_MASK_R_NDPA_BW_8822C 0x3
#define BIT_R_NDPA_BW_8822C(x) \
(((x) & BIT_MASK_R_NDPA_BW_8822C) << BIT_SHIFT_R_NDPA_BW_8822C)
#define BITS_R_NDPA_BW_8822C \
(BIT_MASK_R_NDPA_BW_8822C << BIT_SHIFT_R_NDPA_BW_8822C)
#define BIT_CLEAR_R_NDPA_BW_8822C(x) ((x) & (~BITS_R_NDPA_BW_8822C))
#define BIT_GET_R_NDPA_BW_8822C(x) \
(((x) >> BIT_SHIFT_R_NDPA_BW_8822C) & BIT_MASK_R_NDPA_BW_8822C)
#define BIT_SET_R_NDPA_BW_8822C(x, v) \
(BIT_CLEAR_R_NDPA_BW_8822C(x) | BIT_R_NDPA_BW_8822C(v))
/* 2 REG_AMPDU_MAX_LENGTH_VHT_8822C */
#define BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1_8822C 0
#define BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1_8822C 0xfffff
#define BIT_AMPDU_MAX_LENGTH_VHT_V1_8822C(x) \
(((x) & BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1_8822C) \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1_8822C)
#define BITS_AMPDU_MAX_LENGTH_VHT_V1_8822C \
(BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1_8822C \
<< BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1_8822C)
#define BIT_CLEAR_AMPDU_MAX_LENGTH_VHT_V1_8822C(x) \
((x) & (~BITS_AMPDU_MAX_LENGTH_VHT_V1_8822C))
#define BIT_GET_AMPDU_MAX_LENGTH_VHT_V1_8822C(x) \
(((x) >> BIT_SHIFT_AMPDU_MAX_LENGTH_VHT_V1_8822C) & \
BIT_MASK_AMPDU_MAX_LENGTH_VHT_V1_8822C)
#define BIT_SET_AMPDU_MAX_LENGTH_VHT_V1_8822C(x, v) \
(BIT_CLEAR_AMPDU_MAX_LENGTH_VHT_V1_8822C(x) | \
BIT_AMPDU_MAX_LENGTH_VHT_V1_8822C(v))
/* 2 REG_RD_RESP_PKT_TH_8822C */
#define BIT_SHIFT_RD_RESP_PKT_TH_V1_8822C 0
#define BIT_MASK_RD_RESP_PKT_TH_V1_8822C 0x3f
#define BIT_RD_RESP_PKT_TH_V1_8822C(x) \
(((x) & BIT_MASK_RD_RESP_PKT_TH_V1_8822C) \
<< BIT_SHIFT_RD_RESP_PKT_TH_V1_8822C)
#define BITS_RD_RESP_PKT_TH_V1_8822C \
(BIT_MASK_RD_RESP_PKT_TH_V1_8822C << BIT_SHIFT_RD_RESP_PKT_TH_V1_8822C)
#define BIT_CLEAR_RD_RESP_PKT_TH_V1_8822C(x) \
((x) & (~BITS_RD_RESP_PKT_TH_V1_8822C))
#define BIT_GET_RD_RESP_PKT_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_RD_RESP_PKT_TH_V1_8822C) & \
BIT_MASK_RD_RESP_PKT_TH_V1_8822C)
#define BIT_SET_RD_RESP_PKT_TH_V1_8822C(x, v) \
(BIT_CLEAR_RD_RESP_PKT_TH_V1_8822C(x) | BIT_RD_RESP_PKT_TH_V1_8822C(v))
/* 2 REG_CMDQ_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822C 25
#define BIT_MASK_QUEUEMACID_CMDQ_V1_8822C 0x7f
#define BIT_QUEUEMACID_CMDQ_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_CMDQ_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822C)
#define BITS_QUEUEMACID_CMDQ_V1_8822C \
(BIT_MASK_QUEUEMACID_CMDQ_V1_8822C \
<< BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_CMDQ_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_CMDQ_V1_8822C))
#define BIT_GET_QUEUEMACID_CMDQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_CMDQ_V1_8822C) & \
BIT_MASK_QUEUEMACID_CMDQ_V1_8822C)
#define BIT_SET_QUEUEMACID_CMDQ_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_CMDQ_V1_8822C(x) | \
BIT_QUEUEMACID_CMDQ_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_CMDQ_V1_8822C 23
#define BIT_MASK_QUEUEAC_CMDQ_V1_8822C 0x3
#define BIT_QUEUEAC_CMDQ_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_CMDQ_V1_8822C) \
<< BIT_SHIFT_QUEUEAC_CMDQ_V1_8822C)
#define BITS_QUEUEAC_CMDQ_V1_8822C \
(BIT_MASK_QUEUEAC_CMDQ_V1_8822C << BIT_SHIFT_QUEUEAC_CMDQ_V1_8822C)
#define BIT_CLEAR_QUEUEAC_CMDQ_V1_8822C(x) ((x) & (~BITS_QUEUEAC_CMDQ_V1_8822C))
#define BIT_GET_QUEUEAC_CMDQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_CMDQ_V1_8822C) & \
BIT_MASK_QUEUEAC_CMDQ_V1_8822C)
#define BIT_SET_QUEUEAC_CMDQ_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_CMDQ_V1_8822C(x) | BIT_QUEUEAC_CMDQ_V1_8822C(v))
#define BIT_TIDEMPTY_CMDQ_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q4_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q4_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q4_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q4_V2_8822C)
#define BITS_TAIL_PKT_Q4_V2_8822C \
(BIT_MASK_TAIL_PKT_Q4_V2_8822C << BIT_SHIFT_TAIL_PKT_Q4_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q4_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q4_V2_8822C))
#define BIT_GET_TAIL_PKT_Q4_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q4_V2_8822C)
#define BIT_SET_TAIL_PKT_Q4_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2_8822C(x) | BIT_TAIL_PKT_Q4_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822C 0
#define BIT_MASK_HEAD_PKT_CMDQ_V1_8822C 0x7ff
#define BIT_HEAD_PKT_CMDQ_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_CMDQ_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822C)
#define BITS_HEAD_PKT_CMDQ_V1_8822C \
(BIT_MASK_HEAD_PKT_CMDQ_V1_8822C << BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_CMDQ_V1_8822C(x) \
((x) & (~BITS_HEAD_PKT_CMDQ_V1_8822C))
#define BIT_GET_HEAD_PKT_CMDQ_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_CMDQ_V1_8822C) & \
BIT_MASK_HEAD_PKT_CMDQ_V1_8822C)
#define BIT_SET_HEAD_PKT_CMDQ_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_CMDQ_V1_8822C(x) | BIT_HEAD_PKT_CMDQ_V1_8822C(v))
/* 2 REG_Q4_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q4_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q4_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q4_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q4_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q4_V1_8822C)
#define BITS_QUEUEMACID_Q4_V1_8822C \
(BIT_MASK_QUEUEMACID_Q4_V1_8822C << BIT_SHIFT_QUEUEMACID_Q4_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q4_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q4_V1_8822C))
#define BIT_GET_QUEUEMACID_Q4_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q4_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q4_V1_8822C)
#define BIT_SET_QUEUEMACID_Q4_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q4_V1_8822C(x) | BIT_QUEUEMACID_Q4_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q4_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q4_V1_8822C 0x3
#define BIT_QUEUEAC_Q4_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q4_V1_8822C) << BIT_SHIFT_QUEUEAC_Q4_V1_8822C)
#define BITS_QUEUEAC_Q4_V1_8822C \
(BIT_MASK_QUEUEAC_Q4_V1_8822C << BIT_SHIFT_QUEUEAC_Q4_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q4_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q4_V1_8822C))
#define BIT_GET_QUEUEAC_Q4_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q4_V1_8822C) & BIT_MASK_QUEUEAC_Q4_V1_8822C)
#define BIT_SET_QUEUEAC_Q4_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q4_V1_8822C(x) | BIT_QUEUEAC_Q4_V1_8822C(v))
#define BIT_TIDEMPTY_Q4_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q4_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q4_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q4_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q4_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q4_V2_8822C)
#define BITS_TAIL_PKT_Q4_V2_8822C \
(BIT_MASK_TAIL_PKT_Q4_V2_8822C << BIT_SHIFT_TAIL_PKT_Q4_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q4_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q4_V2_8822C))
#define BIT_GET_TAIL_PKT_Q4_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q4_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q4_V2_8822C)
#define BIT_SET_TAIL_PKT_Q4_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q4_V2_8822C(x) | BIT_TAIL_PKT_Q4_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q4_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q4_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q4_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q4_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q4_V1_8822C)
#define BITS_HEAD_PKT_Q4_V1_8822C \
(BIT_MASK_HEAD_PKT_Q4_V1_8822C << BIT_SHIFT_HEAD_PKT_Q4_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q4_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q4_V1_8822C))
#define BIT_GET_HEAD_PKT_Q4_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q4_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q4_V1_8822C)
#define BIT_SET_HEAD_PKT_Q4_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q4_V1_8822C(x) | BIT_HEAD_PKT_Q4_V1_8822C(v))
/* 2 REG_Q5_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q5_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q5_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q5_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q5_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q5_V1_8822C)
#define BITS_QUEUEMACID_Q5_V1_8822C \
(BIT_MASK_QUEUEMACID_Q5_V1_8822C << BIT_SHIFT_QUEUEMACID_Q5_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q5_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q5_V1_8822C))
#define BIT_GET_QUEUEMACID_Q5_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q5_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q5_V1_8822C)
#define BIT_SET_QUEUEMACID_Q5_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q5_V1_8822C(x) | BIT_QUEUEMACID_Q5_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q5_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q5_V1_8822C 0x3
#define BIT_QUEUEAC_Q5_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q5_V1_8822C) << BIT_SHIFT_QUEUEAC_Q5_V1_8822C)
#define BITS_QUEUEAC_Q5_V1_8822C \
(BIT_MASK_QUEUEAC_Q5_V1_8822C << BIT_SHIFT_QUEUEAC_Q5_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q5_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q5_V1_8822C))
#define BIT_GET_QUEUEAC_Q5_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q5_V1_8822C) & BIT_MASK_QUEUEAC_Q5_V1_8822C)
#define BIT_SET_QUEUEAC_Q5_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q5_V1_8822C(x) | BIT_QUEUEAC_Q5_V1_8822C(v))
#define BIT_TIDEMPTY_Q5_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q5_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q5_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q5_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q5_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q5_V2_8822C)
#define BITS_TAIL_PKT_Q5_V2_8822C \
(BIT_MASK_TAIL_PKT_Q5_V2_8822C << BIT_SHIFT_TAIL_PKT_Q5_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q5_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q5_V2_8822C))
#define BIT_GET_TAIL_PKT_Q5_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q5_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q5_V2_8822C)
#define BIT_SET_TAIL_PKT_Q5_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q5_V2_8822C(x) | BIT_TAIL_PKT_Q5_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q5_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q5_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q5_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q5_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q5_V1_8822C)
#define BITS_HEAD_PKT_Q5_V1_8822C \
(BIT_MASK_HEAD_PKT_Q5_V1_8822C << BIT_SHIFT_HEAD_PKT_Q5_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q5_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q5_V1_8822C))
#define BIT_GET_HEAD_PKT_Q5_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q5_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q5_V1_8822C)
#define BIT_SET_HEAD_PKT_Q5_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q5_V1_8822C(x) | BIT_HEAD_PKT_Q5_V1_8822C(v))
/* 2 REG_Q6_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q6_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q6_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q6_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q6_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q6_V1_8822C)
#define BITS_QUEUEMACID_Q6_V1_8822C \
(BIT_MASK_QUEUEMACID_Q6_V1_8822C << BIT_SHIFT_QUEUEMACID_Q6_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q6_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q6_V1_8822C))
#define BIT_GET_QUEUEMACID_Q6_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q6_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q6_V1_8822C)
#define BIT_SET_QUEUEMACID_Q6_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q6_V1_8822C(x) | BIT_QUEUEMACID_Q6_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q6_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q6_V1_8822C 0x3
#define BIT_QUEUEAC_Q6_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q6_V1_8822C) << BIT_SHIFT_QUEUEAC_Q6_V1_8822C)
#define BITS_QUEUEAC_Q6_V1_8822C \
(BIT_MASK_QUEUEAC_Q6_V1_8822C << BIT_SHIFT_QUEUEAC_Q6_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q6_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q6_V1_8822C))
#define BIT_GET_QUEUEAC_Q6_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q6_V1_8822C) & BIT_MASK_QUEUEAC_Q6_V1_8822C)
#define BIT_SET_QUEUEAC_Q6_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q6_V1_8822C(x) | BIT_QUEUEAC_Q6_V1_8822C(v))
#define BIT_TIDEMPTY_Q6_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q6_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q6_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q6_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q6_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q6_V2_8822C)
#define BITS_TAIL_PKT_Q6_V2_8822C \
(BIT_MASK_TAIL_PKT_Q6_V2_8822C << BIT_SHIFT_TAIL_PKT_Q6_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q6_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q6_V2_8822C))
#define BIT_GET_TAIL_PKT_Q6_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q6_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q6_V2_8822C)
#define BIT_SET_TAIL_PKT_Q6_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q6_V2_8822C(x) | BIT_TAIL_PKT_Q6_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q6_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q6_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q6_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q6_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q6_V1_8822C)
#define BITS_HEAD_PKT_Q6_V1_8822C \
(BIT_MASK_HEAD_PKT_Q6_V1_8822C << BIT_SHIFT_HEAD_PKT_Q6_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q6_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q6_V1_8822C))
#define BIT_GET_HEAD_PKT_Q6_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q6_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q6_V1_8822C)
#define BIT_SET_HEAD_PKT_Q6_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q6_V1_8822C(x) | BIT_HEAD_PKT_Q6_V1_8822C(v))
/* 2 REG_Q7_INFO_8822C */
#define BIT_SHIFT_QUEUEMACID_Q7_V1_8822C 25
#define BIT_MASK_QUEUEMACID_Q7_V1_8822C 0x7f
#define BIT_QUEUEMACID_Q7_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEMACID_Q7_V1_8822C) \
<< BIT_SHIFT_QUEUEMACID_Q7_V1_8822C)
#define BITS_QUEUEMACID_Q7_V1_8822C \
(BIT_MASK_QUEUEMACID_Q7_V1_8822C << BIT_SHIFT_QUEUEMACID_Q7_V1_8822C)
#define BIT_CLEAR_QUEUEMACID_Q7_V1_8822C(x) \
((x) & (~BITS_QUEUEMACID_Q7_V1_8822C))
#define BIT_GET_QUEUEMACID_Q7_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEMACID_Q7_V1_8822C) & \
BIT_MASK_QUEUEMACID_Q7_V1_8822C)
#define BIT_SET_QUEUEMACID_Q7_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEMACID_Q7_V1_8822C(x) | BIT_QUEUEMACID_Q7_V1_8822C(v))
#define BIT_SHIFT_QUEUEAC_Q7_V1_8822C 23
#define BIT_MASK_QUEUEAC_Q7_V1_8822C 0x3
#define BIT_QUEUEAC_Q7_V1_8822C(x) \
(((x) & BIT_MASK_QUEUEAC_Q7_V1_8822C) << BIT_SHIFT_QUEUEAC_Q7_V1_8822C)
#define BITS_QUEUEAC_Q7_V1_8822C \
(BIT_MASK_QUEUEAC_Q7_V1_8822C << BIT_SHIFT_QUEUEAC_Q7_V1_8822C)
#define BIT_CLEAR_QUEUEAC_Q7_V1_8822C(x) ((x) & (~BITS_QUEUEAC_Q7_V1_8822C))
#define BIT_GET_QUEUEAC_Q7_V1_8822C(x) \
(((x) >> BIT_SHIFT_QUEUEAC_Q7_V1_8822C) & BIT_MASK_QUEUEAC_Q7_V1_8822C)
#define BIT_SET_QUEUEAC_Q7_V1_8822C(x, v) \
(BIT_CLEAR_QUEUEAC_Q7_V1_8822C(x) | BIT_QUEUEAC_Q7_V1_8822C(v))
#define BIT_TIDEMPTY_Q7_V1_8822C BIT(22)
#define BIT_SHIFT_TAIL_PKT_Q7_V2_8822C 11
#define BIT_MASK_TAIL_PKT_Q7_V2_8822C 0x7ff
#define BIT_TAIL_PKT_Q7_V2_8822C(x) \
(((x) & BIT_MASK_TAIL_PKT_Q7_V2_8822C) \
<< BIT_SHIFT_TAIL_PKT_Q7_V2_8822C)
#define BITS_TAIL_PKT_Q7_V2_8822C \
(BIT_MASK_TAIL_PKT_Q7_V2_8822C << BIT_SHIFT_TAIL_PKT_Q7_V2_8822C)
#define BIT_CLEAR_TAIL_PKT_Q7_V2_8822C(x) ((x) & (~BITS_TAIL_PKT_Q7_V2_8822C))
#define BIT_GET_TAIL_PKT_Q7_V2_8822C(x) \
(((x) >> BIT_SHIFT_TAIL_PKT_Q7_V2_8822C) & \
BIT_MASK_TAIL_PKT_Q7_V2_8822C)
#define BIT_SET_TAIL_PKT_Q7_V2_8822C(x, v) \
(BIT_CLEAR_TAIL_PKT_Q7_V2_8822C(x) | BIT_TAIL_PKT_Q7_V2_8822C(v))
#define BIT_SHIFT_HEAD_PKT_Q7_V1_8822C 0
#define BIT_MASK_HEAD_PKT_Q7_V1_8822C 0x7ff
#define BIT_HEAD_PKT_Q7_V1_8822C(x) \
(((x) & BIT_MASK_HEAD_PKT_Q7_V1_8822C) \
<< BIT_SHIFT_HEAD_PKT_Q7_V1_8822C)
#define BITS_HEAD_PKT_Q7_V1_8822C \
(BIT_MASK_HEAD_PKT_Q7_V1_8822C << BIT_SHIFT_HEAD_PKT_Q7_V1_8822C)
#define BIT_CLEAR_HEAD_PKT_Q7_V1_8822C(x) ((x) & (~BITS_HEAD_PKT_Q7_V1_8822C))
#define BIT_GET_HEAD_PKT_Q7_V1_8822C(x) \
(((x) >> BIT_SHIFT_HEAD_PKT_Q7_V1_8822C) & \
BIT_MASK_HEAD_PKT_Q7_V1_8822C)
#define BIT_SET_HEAD_PKT_Q7_V1_8822C(x, v) \
(BIT_CLEAR_HEAD_PKT_Q7_V1_8822C(x) | BIT_HEAD_PKT_Q7_V1_8822C(v))
/* 2 REG_WMAC_LBK_BUF_HD_V1_8822C */
#define BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822C 0
#define BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822C 0xfff
#define BIT_WMAC_LBK_BUF_HEAD_V1_8822C(x) \
(((x) & BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822C) \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822C)
#define BITS_WMAC_LBK_BUF_HEAD_V1_8822C \
(BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822C \
<< BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822C)
#define BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8822C(x) \
((x) & (~BITS_WMAC_LBK_BUF_HEAD_V1_8822C))
#define BIT_GET_WMAC_LBK_BUF_HEAD_V1_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_LBK_BUF_HEAD_V1_8822C) & \
BIT_MASK_WMAC_LBK_BUF_HEAD_V1_8822C)
#define BIT_SET_WMAC_LBK_BUF_HEAD_V1_8822C(x, v) \
(BIT_CLEAR_WMAC_LBK_BUF_HEAD_V1_8822C(x) | \
BIT_WMAC_LBK_BUF_HEAD_V1_8822C(v))
/* 2 REG_MGQ_BDNY_V1_8822C */
#define BIT_SHIFT_MGQ_PGBNDY_V1_8822C 0
#define BIT_MASK_MGQ_PGBNDY_V1_8822C 0xfff
#define BIT_MGQ_PGBNDY_V1_8822C(x) \
(((x) & BIT_MASK_MGQ_PGBNDY_V1_8822C) << BIT_SHIFT_MGQ_PGBNDY_V1_8822C)
#define BITS_MGQ_PGBNDY_V1_8822C \
(BIT_MASK_MGQ_PGBNDY_V1_8822C << BIT_SHIFT_MGQ_PGBNDY_V1_8822C)
#define BIT_CLEAR_MGQ_PGBNDY_V1_8822C(x) ((x) & (~BITS_MGQ_PGBNDY_V1_8822C))
#define BIT_GET_MGQ_PGBNDY_V1_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_PGBNDY_V1_8822C) & BIT_MASK_MGQ_PGBNDY_V1_8822C)
#define BIT_SET_MGQ_PGBNDY_V1_8822C(x, v) \
(BIT_CLEAR_MGQ_PGBNDY_V1_8822C(x) | BIT_MGQ_PGBNDY_V1_8822C(v))
/* 2 REG_TXRPT_CTRL_8822C */
#define BIT_SHIFT_TRXRPT_TIMER_TH_8822C 24
#define BIT_MASK_TRXRPT_TIMER_TH_8822C 0xff
#define BIT_TRXRPT_TIMER_TH_8822C(x) \
(((x) & BIT_MASK_TRXRPT_TIMER_TH_8822C) \
<< BIT_SHIFT_TRXRPT_TIMER_TH_8822C)
#define BITS_TRXRPT_TIMER_TH_8822C \
(BIT_MASK_TRXRPT_TIMER_TH_8822C << BIT_SHIFT_TRXRPT_TIMER_TH_8822C)
#define BIT_CLEAR_TRXRPT_TIMER_TH_8822C(x) ((x) & (~BITS_TRXRPT_TIMER_TH_8822C))
#define BIT_GET_TRXRPT_TIMER_TH_8822C(x) \
(((x) >> BIT_SHIFT_TRXRPT_TIMER_TH_8822C) & \
BIT_MASK_TRXRPT_TIMER_TH_8822C)
#define BIT_SET_TRXRPT_TIMER_TH_8822C(x, v) \
(BIT_CLEAR_TRXRPT_TIMER_TH_8822C(x) | BIT_TRXRPT_TIMER_TH_8822C(v))
#define BIT_SHIFT_TRXRPT_LEN_TH_8822C 16
#define BIT_MASK_TRXRPT_LEN_TH_8822C 0xff
#define BIT_TRXRPT_LEN_TH_8822C(x) \
(((x) & BIT_MASK_TRXRPT_LEN_TH_8822C) << BIT_SHIFT_TRXRPT_LEN_TH_8822C)
#define BITS_TRXRPT_LEN_TH_8822C \
(BIT_MASK_TRXRPT_LEN_TH_8822C << BIT_SHIFT_TRXRPT_LEN_TH_8822C)
#define BIT_CLEAR_TRXRPT_LEN_TH_8822C(x) ((x) & (~BITS_TRXRPT_LEN_TH_8822C))
#define BIT_GET_TRXRPT_LEN_TH_8822C(x) \
(((x) >> BIT_SHIFT_TRXRPT_LEN_TH_8822C) & BIT_MASK_TRXRPT_LEN_TH_8822C)
#define BIT_SET_TRXRPT_LEN_TH_8822C(x, v) \
(BIT_CLEAR_TRXRPT_LEN_TH_8822C(x) | BIT_TRXRPT_LEN_TH_8822C(v))
#define BIT_SHIFT_TRXRPT_READ_PTR_8822C 8
#define BIT_MASK_TRXRPT_READ_PTR_8822C 0xff
#define BIT_TRXRPT_READ_PTR_8822C(x) \
(((x) & BIT_MASK_TRXRPT_READ_PTR_8822C) \
<< BIT_SHIFT_TRXRPT_READ_PTR_8822C)
#define BITS_TRXRPT_READ_PTR_8822C \
(BIT_MASK_TRXRPT_READ_PTR_8822C << BIT_SHIFT_TRXRPT_READ_PTR_8822C)
#define BIT_CLEAR_TRXRPT_READ_PTR_8822C(x) ((x) & (~BITS_TRXRPT_READ_PTR_8822C))
#define BIT_GET_TRXRPT_READ_PTR_8822C(x) \
(((x) >> BIT_SHIFT_TRXRPT_READ_PTR_8822C) & \
BIT_MASK_TRXRPT_READ_PTR_8822C)
#define BIT_SET_TRXRPT_READ_PTR_8822C(x, v) \
(BIT_CLEAR_TRXRPT_READ_PTR_8822C(x) | BIT_TRXRPT_READ_PTR_8822C(v))
#define BIT_SHIFT_TRXRPT_WRITE_PTR_8822C 0
#define BIT_MASK_TRXRPT_WRITE_PTR_8822C 0xff
#define BIT_TRXRPT_WRITE_PTR_8822C(x) \
(((x) & BIT_MASK_TRXRPT_WRITE_PTR_8822C) \
<< BIT_SHIFT_TRXRPT_WRITE_PTR_8822C)
#define BITS_TRXRPT_WRITE_PTR_8822C \
(BIT_MASK_TRXRPT_WRITE_PTR_8822C << BIT_SHIFT_TRXRPT_WRITE_PTR_8822C)
#define BIT_CLEAR_TRXRPT_WRITE_PTR_8822C(x) \
((x) & (~BITS_TRXRPT_WRITE_PTR_8822C))
#define BIT_GET_TRXRPT_WRITE_PTR_8822C(x) \
(((x) >> BIT_SHIFT_TRXRPT_WRITE_PTR_8822C) & \
BIT_MASK_TRXRPT_WRITE_PTR_8822C)
#define BIT_SET_TRXRPT_WRITE_PTR_8822C(x, v) \
(BIT_CLEAR_TRXRPT_WRITE_PTR_8822C(x) | BIT_TRXRPT_WRITE_PTR_8822C(v))
/* 2 REG_INIRTS_RATE_SEL_8822C */
#define BIT_LEAG_RTS_BW_DUP_8822C BIT(5)
/* 2 REG_BASIC_CFEND_RATE_8822C */
#define BIT_SHIFT_BASIC_CFEND_RATE_8822C 0
#define BIT_MASK_BASIC_CFEND_RATE_8822C 0x1f
#define BIT_BASIC_CFEND_RATE_8822C(x) \
(((x) & BIT_MASK_BASIC_CFEND_RATE_8822C) \
<< BIT_SHIFT_BASIC_CFEND_RATE_8822C)
#define BITS_BASIC_CFEND_RATE_8822C \
(BIT_MASK_BASIC_CFEND_RATE_8822C << BIT_SHIFT_BASIC_CFEND_RATE_8822C)
#define BIT_CLEAR_BASIC_CFEND_RATE_8822C(x) \
((x) & (~BITS_BASIC_CFEND_RATE_8822C))
#define BIT_GET_BASIC_CFEND_RATE_8822C(x) \
(((x) >> BIT_SHIFT_BASIC_CFEND_RATE_8822C) & \
BIT_MASK_BASIC_CFEND_RATE_8822C)
#define BIT_SET_BASIC_CFEND_RATE_8822C(x, v) \
(BIT_CLEAR_BASIC_CFEND_RATE_8822C(x) | BIT_BASIC_CFEND_RATE_8822C(v))
/* 2 REG_STBC_CFEND_RATE_8822C */
#define BIT_SHIFT_STBC_CFEND_RATE_8822C 0
#define BIT_MASK_STBC_CFEND_RATE_8822C 0x1f
#define BIT_STBC_CFEND_RATE_8822C(x) \
(((x) & BIT_MASK_STBC_CFEND_RATE_8822C) \
<< BIT_SHIFT_STBC_CFEND_RATE_8822C)
#define BITS_STBC_CFEND_RATE_8822C \
(BIT_MASK_STBC_CFEND_RATE_8822C << BIT_SHIFT_STBC_CFEND_RATE_8822C)
#define BIT_CLEAR_STBC_CFEND_RATE_8822C(x) ((x) & (~BITS_STBC_CFEND_RATE_8822C))
#define BIT_GET_STBC_CFEND_RATE_8822C(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_RATE_8822C) & \
BIT_MASK_STBC_CFEND_RATE_8822C)
#define BIT_SET_STBC_CFEND_RATE_8822C(x, v) \
(BIT_CLEAR_STBC_CFEND_RATE_8822C(x) | BIT_STBC_CFEND_RATE_8822C(v))
/* 2 REG_DATA_SC_8822C */
#define BIT_SHIFT_TXSC_40M_8822C 4
#define BIT_MASK_TXSC_40M_8822C 0xf
#define BIT_TXSC_40M_8822C(x) \
(((x) & BIT_MASK_TXSC_40M_8822C) << BIT_SHIFT_TXSC_40M_8822C)
#define BITS_TXSC_40M_8822C \
(BIT_MASK_TXSC_40M_8822C << BIT_SHIFT_TXSC_40M_8822C)
#define BIT_CLEAR_TXSC_40M_8822C(x) ((x) & (~BITS_TXSC_40M_8822C))
#define BIT_GET_TXSC_40M_8822C(x) \
(((x) >> BIT_SHIFT_TXSC_40M_8822C) & BIT_MASK_TXSC_40M_8822C)
#define BIT_SET_TXSC_40M_8822C(x, v) \
(BIT_CLEAR_TXSC_40M_8822C(x) | BIT_TXSC_40M_8822C(v))
#define BIT_SHIFT_TXSC_20M_8822C 0
#define BIT_MASK_TXSC_20M_8822C 0xf
#define BIT_TXSC_20M_8822C(x) \
(((x) & BIT_MASK_TXSC_20M_8822C) << BIT_SHIFT_TXSC_20M_8822C)
#define BITS_TXSC_20M_8822C \
(BIT_MASK_TXSC_20M_8822C << BIT_SHIFT_TXSC_20M_8822C)
#define BIT_CLEAR_TXSC_20M_8822C(x) ((x) & (~BITS_TXSC_20M_8822C))
#define BIT_GET_TXSC_20M_8822C(x) \
(((x) >> BIT_SHIFT_TXSC_20M_8822C) & BIT_MASK_TXSC_20M_8822C)
#define BIT_SET_TXSC_20M_8822C(x, v) \
(BIT_CLEAR_TXSC_20M_8822C(x) | BIT_TXSC_20M_8822C(v))
/* 2 REG_MACID_SLEEP3_8822C */
#define BIT_SHIFT_MACID127_96_PKTSLEEP_8822C 0
#define BIT_MASK_MACID127_96_PKTSLEEP_8822C 0xffffffffL
#define BIT_MACID127_96_PKTSLEEP_8822C(x) \
(((x) & BIT_MASK_MACID127_96_PKTSLEEP_8822C) \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8822C)
#define BITS_MACID127_96_PKTSLEEP_8822C \
(BIT_MASK_MACID127_96_PKTSLEEP_8822C \
<< BIT_SHIFT_MACID127_96_PKTSLEEP_8822C)
#define BIT_CLEAR_MACID127_96_PKTSLEEP_8822C(x) \
((x) & (~BITS_MACID127_96_PKTSLEEP_8822C))
#define BIT_GET_MACID127_96_PKTSLEEP_8822C(x) \
(((x) >> BIT_SHIFT_MACID127_96_PKTSLEEP_8822C) & \
BIT_MASK_MACID127_96_PKTSLEEP_8822C)
#define BIT_SET_MACID127_96_PKTSLEEP_8822C(x, v) \
(BIT_CLEAR_MACID127_96_PKTSLEEP_8822C(x) | \
BIT_MACID127_96_PKTSLEEP_8822C(v))
/* 2 REG_MACID_SLEEP1_8822C */
#define BIT_SHIFT_MACID63_32_PKTSLEEP_8822C 0
#define BIT_MASK_MACID63_32_PKTSLEEP_8822C 0xffffffffL
#define BIT_MACID63_32_PKTSLEEP_8822C(x) \
(((x) & BIT_MASK_MACID63_32_PKTSLEEP_8822C) \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8822C)
#define BITS_MACID63_32_PKTSLEEP_8822C \
(BIT_MASK_MACID63_32_PKTSLEEP_8822C \
<< BIT_SHIFT_MACID63_32_PKTSLEEP_8822C)
#define BIT_CLEAR_MACID63_32_PKTSLEEP_8822C(x) \
((x) & (~BITS_MACID63_32_PKTSLEEP_8822C))
#define BIT_GET_MACID63_32_PKTSLEEP_8822C(x) \
(((x) >> BIT_SHIFT_MACID63_32_PKTSLEEP_8822C) & \
BIT_MASK_MACID63_32_PKTSLEEP_8822C)
#define BIT_SET_MACID63_32_PKTSLEEP_8822C(x, v) \
(BIT_CLEAR_MACID63_32_PKTSLEEP_8822C(x) | \
BIT_MACID63_32_PKTSLEEP_8822C(v))
/* 2 REG_ARFR2_V1_8822C */
#define BIT_SHIFT_ARFRL2_8822C 0
#define BIT_MASK_ARFRL2_8822C 0xffffffffL
#define BIT_ARFRL2_8822C(x) \
(((x) & BIT_MASK_ARFRL2_8822C) << BIT_SHIFT_ARFRL2_8822C)
#define BITS_ARFRL2_8822C (BIT_MASK_ARFRL2_8822C << BIT_SHIFT_ARFRL2_8822C)
#define BIT_CLEAR_ARFRL2_8822C(x) ((x) & (~BITS_ARFRL2_8822C))
#define BIT_GET_ARFRL2_8822C(x) \
(((x) >> BIT_SHIFT_ARFRL2_8822C) & BIT_MASK_ARFRL2_8822C)
#define BIT_SET_ARFRL2_8822C(x, v) \
(BIT_CLEAR_ARFRL2_8822C(x) | BIT_ARFRL2_8822C(v))
/* 2 REG_ARFRH2_V1_8822C */
#define BIT_SHIFT_ARFRH2_8822C 0
#define BIT_MASK_ARFRH2_8822C 0xffffffffL
#define BIT_ARFRH2_8822C(x) \
(((x) & BIT_MASK_ARFRH2_8822C) << BIT_SHIFT_ARFRH2_8822C)
#define BITS_ARFRH2_8822C (BIT_MASK_ARFRH2_8822C << BIT_SHIFT_ARFRH2_8822C)
#define BIT_CLEAR_ARFRH2_8822C(x) ((x) & (~BITS_ARFRH2_8822C))
#define BIT_GET_ARFRH2_8822C(x) \
(((x) >> BIT_SHIFT_ARFRH2_8822C) & BIT_MASK_ARFRH2_8822C)
#define BIT_SET_ARFRH2_8822C(x, v) \
(BIT_CLEAR_ARFRH2_8822C(x) | BIT_ARFRH2_8822C(v))
/* 2 REG_ARFR3_V1_8822C */
#define BIT_SHIFT_ARFRL3_8822C 0
#define BIT_MASK_ARFRL3_8822C 0xffffffffL
#define BIT_ARFRL3_8822C(x) \
(((x) & BIT_MASK_ARFRL3_8822C) << BIT_SHIFT_ARFRL3_8822C)
#define BITS_ARFRL3_8822C (BIT_MASK_ARFRL3_8822C << BIT_SHIFT_ARFRL3_8822C)
#define BIT_CLEAR_ARFRL3_8822C(x) ((x) & (~BITS_ARFRL3_8822C))
#define BIT_GET_ARFRL3_8822C(x) \
(((x) >> BIT_SHIFT_ARFRL3_8822C) & BIT_MASK_ARFRL3_8822C)
#define BIT_SET_ARFRL3_8822C(x, v) \
(BIT_CLEAR_ARFRL3_8822C(x) | BIT_ARFRL3_8822C(v))
/* 2 REG_ARFRH3_V1_8822C */
#define BIT_SHIFT_ARFRH3_8822C 0
#define BIT_MASK_ARFRH3_8822C 0xffffffffL
#define BIT_ARFRH3_8822C(x) \
(((x) & BIT_MASK_ARFRH3_8822C) << BIT_SHIFT_ARFRH3_8822C)
#define BITS_ARFRH3_8822C (BIT_MASK_ARFRH3_8822C << BIT_SHIFT_ARFRH3_8822C)
#define BIT_CLEAR_ARFRH3_8822C(x) ((x) & (~BITS_ARFRH3_8822C))
#define BIT_GET_ARFRH3_8822C(x) \
(((x) >> BIT_SHIFT_ARFRH3_8822C) & BIT_MASK_ARFRH3_8822C)
#define BIT_SET_ARFRH3_8822C(x, v) \
(BIT_CLEAR_ARFRH3_8822C(x) | BIT_ARFRH3_8822C(v))
/* 2 REG_ARFR4_8822C */
#define BIT_SHIFT_ARFRL4_8822C 0
#define BIT_MASK_ARFRL4_8822C 0xffffffffL
#define BIT_ARFRL4_8822C(x) \
(((x) & BIT_MASK_ARFRL4_8822C) << BIT_SHIFT_ARFRL4_8822C)
#define BITS_ARFRL4_8822C (BIT_MASK_ARFRL4_8822C << BIT_SHIFT_ARFRL4_8822C)
#define BIT_CLEAR_ARFRL4_8822C(x) ((x) & (~BITS_ARFRL4_8822C))
#define BIT_GET_ARFRL4_8822C(x) \
(((x) >> BIT_SHIFT_ARFRL4_8822C) & BIT_MASK_ARFRL4_8822C)
#define BIT_SET_ARFRL4_8822C(x, v) \
(BIT_CLEAR_ARFRL4_8822C(x) | BIT_ARFRL4_8822C(v))
/* 2 REG_ARFRH4_8822C */
#define BIT_SHIFT_ARFRH4_8822C 0
#define BIT_MASK_ARFRH4_8822C 0xffffffffL
#define BIT_ARFRH4_8822C(x) \
(((x) & BIT_MASK_ARFRH4_8822C) << BIT_SHIFT_ARFRH4_8822C)
#define BITS_ARFRH4_8822C (BIT_MASK_ARFRH4_8822C << BIT_SHIFT_ARFRH4_8822C)
#define BIT_CLEAR_ARFRH4_8822C(x) ((x) & (~BITS_ARFRH4_8822C))
#define BIT_GET_ARFRH4_8822C(x) \
(((x) >> BIT_SHIFT_ARFRH4_8822C) & BIT_MASK_ARFRH4_8822C)
#define BIT_SET_ARFRH4_8822C(x, v) \
(BIT_CLEAR_ARFRH4_8822C(x) | BIT_ARFRH4_8822C(v))
/* 2 REG_ARFR5_8822C */
#define BIT_SHIFT_ARFRL5_8822C 0
#define BIT_MASK_ARFRL5_8822C 0xffffffffL
#define BIT_ARFRL5_8822C(x) \
(((x) & BIT_MASK_ARFRL5_8822C) << BIT_SHIFT_ARFRL5_8822C)
#define BITS_ARFRL5_8822C (BIT_MASK_ARFRL5_8822C << BIT_SHIFT_ARFRL5_8822C)
#define BIT_CLEAR_ARFRL5_8822C(x) ((x) & (~BITS_ARFRL5_8822C))
#define BIT_GET_ARFRL5_8822C(x) \
(((x) >> BIT_SHIFT_ARFRL5_8822C) & BIT_MASK_ARFRL5_8822C)
#define BIT_SET_ARFRL5_8822C(x, v) \
(BIT_CLEAR_ARFRL5_8822C(x) | BIT_ARFRL5_8822C(v))
/* 2 REG_ARFRH5_8822C */
#define BIT_SHIFT_ARFRH5_8822C 0
#define BIT_MASK_ARFRH5_8822C 0xffffffffL
#define BIT_ARFRH5_8822C(x) \
(((x) & BIT_MASK_ARFRH5_8822C) << BIT_SHIFT_ARFRH5_8822C)
#define BITS_ARFRH5_8822C (BIT_MASK_ARFRH5_8822C << BIT_SHIFT_ARFRH5_8822C)
#define BIT_CLEAR_ARFRH5_8822C(x) ((x) & (~BITS_ARFRH5_8822C))
#define BIT_GET_ARFRH5_8822C(x) \
(((x) >> BIT_SHIFT_ARFRH5_8822C) & BIT_MASK_ARFRH5_8822C)
#define BIT_SET_ARFRH5_8822C(x, v) \
(BIT_CLEAR_ARFRH5_8822C(x) | BIT_ARFRH5_8822C(v))
/* 2 REG_TXRPT_START_OFFSET_8822C */
#define BIT_SHIFT_MACID_MURATE_OFFSET_8822C 24
#define BIT_MASK_MACID_MURATE_OFFSET_8822C 0xff
#define BIT_MACID_MURATE_OFFSET_8822C(x) \
(((x) & BIT_MASK_MACID_MURATE_OFFSET_8822C) \
<< BIT_SHIFT_MACID_MURATE_OFFSET_8822C)
#define BITS_MACID_MURATE_OFFSET_8822C \
(BIT_MASK_MACID_MURATE_OFFSET_8822C \
<< BIT_SHIFT_MACID_MURATE_OFFSET_8822C)
#define BIT_CLEAR_MACID_MURATE_OFFSET_8822C(x) \
((x) & (~BITS_MACID_MURATE_OFFSET_8822C))
#define BIT_GET_MACID_MURATE_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_MACID_MURATE_OFFSET_8822C) & \
BIT_MASK_MACID_MURATE_OFFSET_8822C)
#define BIT_SET_MACID_MURATE_OFFSET_8822C(x, v) \
(BIT_CLEAR_MACID_MURATE_OFFSET_8822C(x) | \
BIT_MACID_MURATE_OFFSET_8822C(v))
#define BIT_SHIFT_TXRPT_MISS_COUNT_8822C 17
#define BIT_MASK_TXRPT_MISS_COUNT_8822C 0x7
#define BIT_TXRPT_MISS_COUNT_8822C(x) \
(((x) & BIT_MASK_TXRPT_MISS_COUNT_8822C) \
<< BIT_SHIFT_TXRPT_MISS_COUNT_8822C)
#define BITS_TXRPT_MISS_COUNT_8822C \
(BIT_MASK_TXRPT_MISS_COUNT_8822C << BIT_SHIFT_TXRPT_MISS_COUNT_8822C)
#define BIT_CLEAR_TXRPT_MISS_COUNT_8822C(x) \
((x) & (~BITS_TXRPT_MISS_COUNT_8822C))
#define BIT_GET_TXRPT_MISS_COUNT_8822C(x) \
(((x) >> BIT_SHIFT_TXRPT_MISS_COUNT_8822C) & \
BIT_MASK_TXRPT_MISS_COUNT_8822C)
#define BIT_SET_TXRPT_MISS_COUNT_8822C(x, v) \
(BIT_CLEAR_TXRPT_MISS_COUNT_8822C(x) | BIT_TXRPT_MISS_COUNT_8822C(v))
#define BIT_RPTFIFO_SIZE_OPT_8822C BIT(16)
#define BIT_SHIFT_MACID_CTRL_OFFSET_8822C 8
#define BIT_MASK_MACID_CTRL_OFFSET_8822C 0xff
#define BIT_MACID_CTRL_OFFSET_8822C(x) \
(((x) & BIT_MASK_MACID_CTRL_OFFSET_8822C) \
<< BIT_SHIFT_MACID_CTRL_OFFSET_8822C)
#define BITS_MACID_CTRL_OFFSET_8822C \
(BIT_MASK_MACID_CTRL_OFFSET_8822C << BIT_SHIFT_MACID_CTRL_OFFSET_8822C)
#define BIT_CLEAR_MACID_CTRL_OFFSET_8822C(x) \
((x) & (~BITS_MACID_CTRL_OFFSET_8822C))
#define BIT_GET_MACID_CTRL_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_MACID_CTRL_OFFSET_8822C) & \
BIT_MASK_MACID_CTRL_OFFSET_8822C)
#define BIT_SET_MACID_CTRL_OFFSET_8822C(x, v) \
(BIT_CLEAR_MACID_CTRL_OFFSET_8822C(x) | BIT_MACID_CTRL_OFFSET_8822C(v))
#define BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822C 0
#define BIT_MASK_AMPDU_TXRPT_OFFSET_8822C 0xff
#define BIT_AMPDU_TXRPT_OFFSET_8822C(x) \
(((x) & BIT_MASK_AMPDU_TXRPT_OFFSET_8822C) \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822C)
#define BITS_AMPDU_TXRPT_OFFSET_8822C \
(BIT_MASK_AMPDU_TXRPT_OFFSET_8822C \
<< BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822C)
#define BIT_CLEAR_AMPDU_TXRPT_OFFSET_8822C(x) \
((x) & (~BITS_AMPDU_TXRPT_OFFSET_8822C))
#define BIT_GET_AMPDU_TXRPT_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_AMPDU_TXRPT_OFFSET_8822C) & \
BIT_MASK_AMPDU_TXRPT_OFFSET_8822C)
#define BIT_SET_AMPDU_TXRPT_OFFSET_8822C(x, v) \
(BIT_CLEAR_AMPDU_TXRPT_OFFSET_8822C(x) | \
BIT_AMPDU_TXRPT_OFFSET_8822C(v))
/* 2 REG_POWER_STAGE1_8822C */
#define BIT_PTA_WL_PRI_MASK_CPU_MGQ_8822C BIT(31)
#define BIT_PTA_WL_PRI_MASK_BCNQ_8822C BIT(30)
#define BIT_PTA_WL_PRI_MASK_HIQ_8822C BIT(29)
#define BIT_PTA_WL_PRI_MASK_MGQ_8822C BIT(28)
#define BIT_PTA_WL_PRI_MASK_BK_8822C BIT(27)
#define BIT_PTA_WL_PRI_MASK_BE_8822C BIT(26)
#define BIT_PTA_WL_PRI_MASK_VI_8822C BIT(25)
#define BIT_PTA_WL_PRI_MASK_VO_8822C BIT(24)
#define BIT_SHIFT_POWER_STAGE1_8822C 0
#define BIT_MASK_POWER_STAGE1_8822C 0xffffff
#define BIT_POWER_STAGE1_8822C(x) \
(((x) & BIT_MASK_POWER_STAGE1_8822C) << BIT_SHIFT_POWER_STAGE1_8822C)
#define BITS_POWER_STAGE1_8822C \
(BIT_MASK_POWER_STAGE1_8822C << BIT_SHIFT_POWER_STAGE1_8822C)
#define BIT_CLEAR_POWER_STAGE1_8822C(x) ((x) & (~BITS_POWER_STAGE1_8822C))
#define BIT_GET_POWER_STAGE1_8822C(x) \
(((x) >> BIT_SHIFT_POWER_STAGE1_8822C) & BIT_MASK_POWER_STAGE1_8822C)
#define BIT_SET_POWER_STAGE1_8822C(x, v) \
(BIT_CLEAR_POWER_STAGE1_8822C(x) | BIT_POWER_STAGE1_8822C(v))
/* 2 REG_POWER_STAGE2_8822C */
#define BIT__R_CTRL_PKT_POW_ADJ_8822C BIT(24)
#define BIT_SHIFT_POWER_STAGE2_8822C 0
#define BIT_MASK_POWER_STAGE2_8822C 0xffffff
#define BIT_POWER_STAGE2_8822C(x) \
(((x) & BIT_MASK_POWER_STAGE2_8822C) << BIT_SHIFT_POWER_STAGE2_8822C)
#define BITS_POWER_STAGE2_8822C \
(BIT_MASK_POWER_STAGE2_8822C << BIT_SHIFT_POWER_STAGE2_8822C)
#define BIT_CLEAR_POWER_STAGE2_8822C(x) ((x) & (~BITS_POWER_STAGE2_8822C))
#define BIT_GET_POWER_STAGE2_8822C(x) \
(((x) >> BIT_SHIFT_POWER_STAGE2_8822C) & BIT_MASK_POWER_STAGE2_8822C)
#define BIT_SET_POWER_STAGE2_8822C(x, v) \
(BIT_CLEAR_POWER_STAGE2_8822C(x) | BIT_POWER_STAGE2_8822C(v))
/* 2 REG_SW_AMPDU_BURST_MODE_CTRL_8822C */
#define BIT_SHIFT_PAD_NUM_THRES_8822C 24
#define BIT_MASK_PAD_NUM_THRES_8822C 0x3f
#define BIT_PAD_NUM_THRES_8822C(x) \
(((x) & BIT_MASK_PAD_NUM_THRES_8822C) << BIT_SHIFT_PAD_NUM_THRES_8822C)
#define BITS_PAD_NUM_THRES_8822C \
(BIT_MASK_PAD_NUM_THRES_8822C << BIT_SHIFT_PAD_NUM_THRES_8822C)
#define BIT_CLEAR_PAD_NUM_THRES_8822C(x) ((x) & (~BITS_PAD_NUM_THRES_8822C))
#define BIT_GET_PAD_NUM_THRES_8822C(x) \
(((x) >> BIT_SHIFT_PAD_NUM_THRES_8822C) & BIT_MASK_PAD_NUM_THRES_8822C)
#define BIT_SET_PAD_NUM_THRES_8822C(x, v) \
(BIT_CLEAR_PAD_NUM_THRES_8822C(x) | BIT_PAD_NUM_THRES_8822C(v))
#define BIT_R_DMA_THIS_QUEUE_BK_8822C BIT(23)
#define BIT_R_DMA_THIS_QUEUE_BE_8822C BIT(22)
#define BIT_R_DMA_THIS_QUEUE_VI_8822C BIT(21)
#define BIT_R_DMA_THIS_QUEUE_VO_8822C BIT(20)
#define BIT_SHIFT_R_TOTAL_LEN_TH_8822C 8
#define BIT_MASK_R_TOTAL_LEN_TH_8822C 0xfff
#define BIT_R_TOTAL_LEN_TH_8822C(x) \
(((x) & BIT_MASK_R_TOTAL_LEN_TH_8822C) \
<< BIT_SHIFT_R_TOTAL_LEN_TH_8822C)
#define BITS_R_TOTAL_LEN_TH_8822C \
(BIT_MASK_R_TOTAL_LEN_TH_8822C << BIT_SHIFT_R_TOTAL_LEN_TH_8822C)
#define BIT_CLEAR_R_TOTAL_LEN_TH_8822C(x) ((x) & (~BITS_R_TOTAL_LEN_TH_8822C))
#define BIT_GET_R_TOTAL_LEN_TH_8822C(x) \
(((x) >> BIT_SHIFT_R_TOTAL_LEN_TH_8822C) & \
BIT_MASK_R_TOTAL_LEN_TH_8822C)
#define BIT_SET_R_TOTAL_LEN_TH_8822C(x, v) \
(BIT_CLEAR_R_TOTAL_LEN_TH_8822C(x) | BIT_R_TOTAL_LEN_TH_8822C(v))
#define BIT_EN_NEW_EARLY_8822C BIT(7)
#define BIT_PRE_TX_CMD_8822C BIT(6)
#define BIT_SHIFT_NUM_SCL_EN_8822C 4
#define BIT_MASK_NUM_SCL_EN_8822C 0x3
#define BIT_NUM_SCL_EN_8822C(x) \
(((x) & BIT_MASK_NUM_SCL_EN_8822C) << BIT_SHIFT_NUM_SCL_EN_8822C)
#define BITS_NUM_SCL_EN_8822C \
(BIT_MASK_NUM_SCL_EN_8822C << BIT_SHIFT_NUM_SCL_EN_8822C)
#define BIT_CLEAR_NUM_SCL_EN_8822C(x) ((x) & (~BITS_NUM_SCL_EN_8822C))
#define BIT_GET_NUM_SCL_EN_8822C(x) \
(((x) >> BIT_SHIFT_NUM_SCL_EN_8822C) & BIT_MASK_NUM_SCL_EN_8822C)
#define BIT_SET_NUM_SCL_EN_8822C(x, v) \
(BIT_CLEAR_NUM_SCL_EN_8822C(x) | BIT_NUM_SCL_EN_8822C(v))
#define BIT_BK_EN_8822C BIT(3)
#define BIT_BE_EN_8822C BIT(2)
#define BIT_VI_EN_8822C BIT(1)
#define BIT_VO_EN_8822C BIT(0)
/* 2 REG_PKT_LIFE_TIME_8822C */
#define BIT_SHIFT_PKT_LIFTIME_BEBK_8822C 16
#define BIT_MASK_PKT_LIFTIME_BEBK_8822C 0xffff
#define BIT_PKT_LIFTIME_BEBK_8822C(x) \
(((x) & BIT_MASK_PKT_LIFTIME_BEBK_8822C) \
<< BIT_SHIFT_PKT_LIFTIME_BEBK_8822C)
#define BITS_PKT_LIFTIME_BEBK_8822C \
(BIT_MASK_PKT_LIFTIME_BEBK_8822C << BIT_SHIFT_PKT_LIFTIME_BEBK_8822C)
#define BIT_CLEAR_PKT_LIFTIME_BEBK_8822C(x) \
((x) & (~BITS_PKT_LIFTIME_BEBK_8822C))
#define BIT_GET_PKT_LIFTIME_BEBK_8822C(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_BEBK_8822C) & \
BIT_MASK_PKT_LIFTIME_BEBK_8822C)
#define BIT_SET_PKT_LIFTIME_BEBK_8822C(x, v) \
(BIT_CLEAR_PKT_LIFTIME_BEBK_8822C(x) | BIT_PKT_LIFTIME_BEBK_8822C(v))
#define BIT_SHIFT_PKT_LIFTIME_VOVI_8822C 0
#define BIT_MASK_PKT_LIFTIME_VOVI_8822C 0xffff
#define BIT_PKT_LIFTIME_VOVI_8822C(x) \
(((x) & BIT_MASK_PKT_LIFTIME_VOVI_8822C) \
<< BIT_SHIFT_PKT_LIFTIME_VOVI_8822C)
#define BITS_PKT_LIFTIME_VOVI_8822C \
(BIT_MASK_PKT_LIFTIME_VOVI_8822C << BIT_SHIFT_PKT_LIFTIME_VOVI_8822C)
#define BIT_CLEAR_PKT_LIFTIME_VOVI_8822C(x) \
((x) & (~BITS_PKT_LIFTIME_VOVI_8822C))
#define BIT_GET_PKT_LIFTIME_VOVI_8822C(x) \
(((x) >> BIT_SHIFT_PKT_LIFTIME_VOVI_8822C) & \
BIT_MASK_PKT_LIFTIME_VOVI_8822C)
#define BIT_SET_PKT_LIFTIME_VOVI_8822C(x, v) \
(BIT_CLEAR_PKT_LIFTIME_VOVI_8822C(x) | BIT_PKT_LIFTIME_VOVI_8822C(v))
/* 2 REG_STBC_SETTING_8822C */
#define BIT_SHIFT_CDEND_TXTIME_L_8822C 4
#define BIT_MASK_CDEND_TXTIME_L_8822C 0xf
#define BIT_CDEND_TXTIME_L_8822C(x) \
(((x) & BIT_MASK_CDEND_TXTIME_L_8822C) \
<< BIT_SHIFT_CDEND_TXTIME_L_8822C)
#define BITS_CDEND_TXTIME_L_8822C \
(BIT_MASK_CDEND_TXTIME_L_8822C << BIT_SHIFT_CDEND_TXTIME_L_8822C)
#define BIT_CLEAR_CDEND_TXTIME_L_8822C(x) ((x) & (~BITS_CDEND_TXTIME_L_8822C))
#define BIT_GET_CDEND_TXTIME_L_8822C(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_L_8822C) & \
BIT_MASK_CDEND_TXTIME_L_8822C)
#define BIT_SET_CDEND_TXTIME_L_8822C(x, v) \
(BIT_CLEAR_CDEND_TXTIME_L_8822C(x) | BIT_CDEND_TXTIME_L_8822C(v))
#define BIT_SHIFT_NESS_8822C 2
#define BIT_MASK_NESS_8822C 0x3
#define BIT_NESS_8822C(x) (((x) & BIT_MASK_NESS_8822C) << BIT_SHIFT_NESS_8822C)
#define BITS_NESS_8822C (BIT_MASK_NESS_8822C << BIT_SHIFT_NESS_8822C)
#define BIT_CLEAR_NESS_8822C(x) ((x) & (~BITS_NESS_8822C))
#define BIT_GET_NESS_8822C(x) \
(((x) >> BIT_SHIFT_NESS_8822C) & BIT_MASK_NESS_8822C)
#define BIT_SET_NESS_8822C(x, v) (BIT_CLEAR_NESS_8822C(x) | BIT_NESS_8822C(v))
#define BIT_SHIFT_STBC_CFEND_8822C 0
#define BIT_MASK_STBC_CFEND_8822C 0x3
#define BIT_STBC_CFEND_8822C(x) \
(((x) & BIT_MASK_STBC_CFEND_8822C) << BIT_SHIFT_STBC_CFEND_8822C)
#define BITS_STBC_CFEND_8822C \
(BIT_MASK_STBC_CFEND_8822C << BIT_SHIFT_STBC_CFEND_8822C)
#define BIT_CLEAR_STBC_CFEND_8822C(x) ((x) & (~BITS_STBC_CFEND_8822C))
#define BIT_GET_STBC_CFEND_8822C(x) \
(((x) >> BIT_SHIFT_STBC_CFEND_8822C) & BIT_MASK_STBC_CFEND_8822C)
#define BIT_SET_STBC_CFEND_8822C(x, v) \
(BIT_CLEAR_STBC_CFEND_8822C(x) | BIT_STBC_CFEND_8822C(v))
/* 2 REG_STBC_SETTING2_8822C */
#define BIT_SHIFT_CDEND_TXTIME_H_8822C 0
#define BIT_MASK_CDEND_TXTIME_H_8822C 0x1f
#define BIT_CDEND_TXTIME_H_8822C(x) \
(((x) & BIT_MASK_CDEND_TXTIME_H_8822C) \
<< BIT_SHIFT_CDEND_TXTIME_H_8822C)
#define BITS_CDEND_TXTIME_H_8822C \
(BIT_MASK_CDEND_TXTIME_H_8822C << BIT_SHIFT_CDEND_TXTIME_H_8822C)
#define BIT_CLEAR_CDEND_TXTIME_H_8822C(x) ((x) & (~BITS_CDEND_TXTIME_H_8822C))
#define BIT_GET_CDEND_TXTIME_H_8822C(x) \
(((x) >> BIT_SHIFT_CDEND_TXTIME_H_8822C) & \
BIT_MASK_CDEND_TXTIME_H_8822C)
#define BIT_SET_CDEND_TXTIME_H_8822C(x, v) \
(BIT_CLEAR_CDEND_TXTIME_H_8822C(x) | BIT_CDEND_TXTIME_H_8822C(v))
/* 2 REG_QUEUE_CTRL_8822C */
#define BIT_FORCE_RND_PRI_8822C BIT(6)
#define BIT_PTA_EDCCA_EN_8822C BIT(5)
#define BIT_PTA_WL_TX_EN_8822C BIT(4)
#define BIT_R_USE_DATA_BW_8822C BIT(3)
#define BIT_TRI_PKT_INT_MODE1_8822C BIT(2)
#define BIT_TRI_PKT_INT_MODE0_8822C BIT(1)
#define BIT_ACQ_MODE_SEL_8822C BIT(0)
/* 2 REG_SINGLE_AMPDU_CTRL_8822C */
#define BIT_EN_SINGLE_APMDU_8822C BIT(7)
#define BIT_SHIFT_SNDTX_MAXTIME_8822C 0
#define BIT_MASK_SNDTX_MAXTIME_8822C 0x7f
#define BIT_SNDTX_MAXTIME_8822C(x) \
(((x) & BIT_MASK_SNDTX_MAXTIME_8822C) << BIT_SHIFT_SNDTX_MAXTIME_8822C)
#define BITS_SNDTX_MAXTIME_8822C \
(BIT_MASK_SNDTX_MAXTIME_8822C << BIT_SHIFT_SNDTX_MAXTIME_8822C)
#define BIT_CLEAR_SNDTX_MAXTIME_8822C(x) ((x) & (~BITS_SNDTX_MAXTIME_8822C))
#define BIT_GET_SNDTX_MAXTIME_8822C(x) \
(((x) >> BIT_SHIFT_SNDTX_MAXTIME_8822C) & BIT_MASK_SNDTX_MAXTIME_8822C)
#define BIT_SET_SNDTX_MAXTIME_8822C(x, v) \
(BIT_CLEAR_SNDTX_MAXTIME_8822C(x) | BIT_SNDTX_MAXTIME_8822C(v))
/* 2 REG_PROT_MODE_CTRL_8822C */
#define BIT_SND_SIFS_TXDATA_8822C BIT(31)
#define BIT_TX_SND_MATCH_MACID_8822C BIT(30)
#define BIT_SHIFT_RTS_MAX_AGG_NUM_8822C 24
#define BIT_MASK_RTS_MAX_AGG_NUM_8822C 0x3f
#define BIT_RTS_MAX_AGG_NUM_8822C(x) \
(((x) & BIT_MASK_RTS_MAX_AGG_NUM_8822C) \
<< BIT_SHIFT_RTS_MAX_AGG_NUM_8822C)
#define BITS_RTS_MAX_AGG_NUM_8822C \
(BIT_MASK_RTS_MAX_AGG_NUM_8822C << BIT_SHIFT_RTS_MAX_AGG_NUM_8822C)
#define BIT_CLEAR_RTS_MAX_AGG_NUM_8822C(x) ((x) & (~BITS_RTS_MAX_AGG_NUM_8822C))
#define BIT_GET_RTS_MAX_AGG_NUM_8822C(x) \
(((x) >> BIT_SHIFT_RTS_MAX_AGG_NUM_8822C) & \
BIT_MASK_RTS_MAX_AGG_NUM_8822C)
#define BIT_SET_RTS_MAX_AGG_NUM_8822C(x, v) \
(BIT_CLEAR_RTS_MAX_AGG_NUM_8822C(x) | BIT_RTS_MAX_AGG_NUM_8822C(v))
#define BIT_SHIFT_MAX_AGG_NUM_8822C 16
#define BIT_MASK_MAX_AGG_NUM_8822C 0x3f
#define BIT_MAX_AGG_NUM_8822C(x) \
(((x) & BIT_MASK_MAX_AGG_NUM_8822C) << BIT_SHIFT_MAX_AGG_NUM_8822C)
#define BITS_MAX_AGG_NUM_8822C \
(BIT_MASK_MAX_AGG_NUM_8822C << BIT_SHIFT_MAX_AGG_NUM_8822C)
#define BIT_CLEAR_MAX_AGG_NUM_8822C(x) ((x) & (~BITS_MAX_AGG_NUM_8822C))
#define BIT_GET_MAX_AGG_NUM_8822C(x) \
(((x) >> BIT_SHIFT_MAX_AGG_NUM_8822C) & BIT_MASK_MAX_AGG_NUM_8822C)
#define BIT_SET_MAX_AGG_NUM_8822C(x, v) \
(BIT_CLEAR_MAX_AGG_NUM_8822C(x) | BIT_MAX_AGG_NUM_8822C(v))
#define BIT_SHIFT_RTS_TXTIME_TH_8822C 8
#define BIT_MASK_RTS_TXTIME_TH_8822C 0xff
#define BIT_RTS_TXTIME_TH_8822C(x) \
(((x) & BIT_MASK_RTS_TXTIME_TH_8822C) << BIT_SHIFT_RTS_TXTIME_TH_8822C)
#define BITS_RTS_TXTIME_TH_8822C \
(BIT_MASK_RTS_TXTIME_TH_8822C << BIT_SHIFT_RTS_TXTIME_TH_8822C)
#define BIT_CLEAR_RTS_TXTIME_TH_8822C(x) ((x) & (~BITS_RTS_TXTIME_TH_8822C))
#define BIT_GET_RTS_TXTIME_TH_8822C(x) \
(((x) >> BIT_SHIFT_RTS_TXTIME_TH_8822C) & BIT_MASK_RTS_TXTIME_TH_8822C)
#define BIT_SET_RTS_TXTIME_TH_8822C(x, v) \
(BIT_CLEAR_RTS_TXTIME_TH_8822C(x) | BIT_RTS_TXTIME_TH_8822C(v))
#define BIT_SHIFT_RTS_LEN_TH_8822C 0
#define BIT_MASK_RTS_LEN_TH_8822C 0xff
#define BIT_RTS_LEN_TH_8822C(x) \
(((x) & BIT_MASK_RTS_LEN_TH_8822C) << BIT_SHIFT_RTS_LEN_TH_8822C)
#define BITS_RTS_LEN_TH_8822C \
(BIT_MASK_RTS_LEN_TH_8822C << BIT_SHIFT_RTS_LEN_TH_8822C)
#define BIT_CLEAR_RTS_LEN_TH_8822C(x) ((x) & (~BITS_RTS_LEN_TH_8822C))
#define BIT_GET_RTS_LEN_TH_8822C(x) \
(((x) >> BIT_SHIFT_RTS_LEN_TH_8822C) & BIT_MASK_RTS_LEN_TH_8822C)
#define BIT_SET_RTS_LEN_TH_8822C(x, v) \
(BIT_CLEAR_RTS_LEN_TH_8822C(x) | BIT_RTS_LEN_TH_8822C(v))
/* 2 REG_BAR_MODE_CTRL_8822C */
#define BIT_SHIFT_BAR_RTY_LMT_8822C 16
#define BIT_MASK_BAR_RTY_LMT_8822C 0x3
#define BIT_BAR_RTY_LMT_8822C(x) \
(((x) & BIT_MASK_BAR_RTY_LMT_8822C) << BIT_SHIFT_BAR_RTY_LMT_8822C)
#define BITS_BAR_RTY_LMT_8822C \
(BIT_MASK_BAR_RTY_LMT_8822C << BIT_SHIFT_BAR_RTY_LMT_8822C)
#define BIT_CLEAR_BAR_RTY_LMT_8822C(x) ((x) & (~BITS_BAR_RTY_LMT_8822C))
#define BIT_GET_BAR_RTY_LMT_8822C(x) \
(((x) >> BIT_SHIFT_BAR_RTY_LMT_8822C) & BIT_MASK_BAR_RTY_LMT_8822C)
#define BIT_SET_BAR_RTY_LMT_8822C(x, v) \
(BIT_CLEAR_BAR_RTY_LMT_8822C(x) | BIT_BAR_RTY_LMT_8822C(v))
#define BIT_SHIFT_BAR_PKT_TXTIME_TH_8822C 8
#define BIT_MASK_BAR_PKT_TXTIME_TH_8822C 0xff
#define BIT_BAR_PKT_TXTIME_TH_8822C(x) \
(((x) & BIT_MASK_BAR_PKT_TXTIME_TH_8822C) \
<< BIT_SHIFT_BAR_PKT_TXTIME_TH_8822C)
#define BITS_BAR_PKT_TXTIME_TH_8822C \
(BIT_MASK_BAR_PKT_TXTIME_TH_8822C << BIT_SHIFT_BAR_PKT_TXTIME_TH_8822C)
#define BIT_CLEAR_BAR_PKT_TXTIME_TH_8822C(x) \
((x) & (~BITS_BAR_PKT_TXTIME_TH_8822C))
#define BIT_GET_BAR_PKT_TXTIME_TH_8822C(x) \
(((x) >> BIT_SHIFT_BAR_PKT_TXTIME_TH_8822C) & \
BIT_MASK_BAR_PKT_TXTIME_TH_8822C)
#define BIT_SET_BAR_PKT_TXTIME_TH_8822C(x, v) \
(BIT_CLEAR_BAR_PKT_TXTIME_TH_8822C(x) | BIT_BAR_PKT_TXTIME_TH_8822C(v))
#define BIT_BAR_EN_V1_8822C BIT(6)
#define BIT_SHIFT_BAR_PKTNUM_TH_V1_8822C 0
#define BIT_MASK_BAR_PKTNUM_TH_V1_8822C 0x3f
#define BIT_BAR_PKTNUM_TH_V1_8822C(x) \
(((x) & BIT_MASK_BAR_PKTNUM_TH_V1_8822C) \
<< BIT_SHIFT_BAR_PKTNUM_TH_V1_8822C)
#define BITS_BAR_PKTNUM_TH_V1_8822C \
(BIT_MASK_BAR_PKTNUM_TH_V1_8822C << BIT_SHIFT_BAR_PKTNUM_TH_V1_8822C)
#define BIT_CLEAR_BAR_PKTNUM_TH_V1_8822C(x) \
((x) & (~BITS_BAR_PKTNUM_TH_V1_8822C))
#define BIT_GET_BAR_PKTNUM_TH_V1_8822C(x) \
(((x) >> BIT_SHIFT_BAR_PKTNUM_TH_V1_8822C) & \
BIT_MASK_BAR_PKTNUM_TH_V1_8822C)
#define BIT_SET_BAR_PKTNUM_TH_V1_8822C(x, v) \
(BIT_CLEAR_BAR_PKTNUM_TH_V1_8822C(x) | BIT_BAR_PKTNUM_TH_V1_8822C(v))
/* 2 REG_RA_TRY_RATE_AGG_LMT_8822C */
#define BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822C 0
#define BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822C 0x3f
#define BIT_RA_TRY_RATE_AGG_LMT_V1_8822C(x) \
(((x) & BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822C) \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822C)
#define BITS_RA_TRY_RATE_AGG_LMT_V1_8822C \
(BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822C \
<< BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822C)
#define BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8822C(x) \
((x) & (~BITS_RA_TRY_RATE_AGG_LMT_V1_8822C))
#define BIT_GET_RA_TRY_RATE_AGG_LMT_V1_8822C(x) \
(((x) >> BIT_SHIFT_RA_TRY_RATE_AGG_LMT_V1_8822C) & \
BIT_MASK_RA_TRY_RATE_AGG_LMT_V1_8822C)
#define BIT_SET_RA_TRY_RATE_AGG_LMT_V1_8822C(x, v) \
(BIT_CLEAR_RA_TRY_RATE_AGG_LMT_V1_8822C(x) | \
BIT_RA_TRY_RATE_AGG_LMT_V1_8822C(v))
/* 2 REG_MACID_SLEEP2_8822C */
#define BIT_SHIFT_MACID95_64PKTSLEEP_8822C 0
#define BIT_MASK_MACID95_64PKTSLEEP_8822C 0xffffffffL
#define BIT_MACID95_64PKTSLEEP_8822C(x) \
(((x) & BIT_MASK_MACID95_64PKTSLEEP_8822C) \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8822C)
#define BITS_MACID95_64PKTSLEEP_8822C \
(BIT_MASK_MACID95_64PKTSLEEP_8822C \
<< BIT_SHIFT_MACID95_64PKTSLEEP_8822C)
#define BIT_CLEAR_MACID95_64PKTSLEEP_8822C(x) \
((x) & (~BITS_MACID95_64PKTSLEEP_8822C))
#define BIT_GET_MACID95_64PKTSLEEP_8822C(x) \
(((x) >> BIT_SHIFT_MACID95_64PKTSLEEP_8822C) & \
BIT_MASK_MACID95_64PKTSLEEP_8822C)
#define BIT_SET_MACID95_64PKTSLEEP_8822C(x, v) \
(BIT_CLEAR_MACID95_64PKTSLEEP_8822C(x) | \
BIT_MACID95_64PKTSLEEP_8822C(v))
/* 2 REG_MACID_SLEEP_8822C */
#define BIT_SHIFT_MACID31_0_PKTSLEEP_8822C 0
#define BIT_MASK_MACID31_0_PKTSLEEP_8822C 0xffffffffL
#define BIT_MACID31_0_PKTSLEEP_8822C(x) \
(((x) & BIT_MASK_MACID31_0_PKTSLEEP_8822C) \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8822C)
#define BITS_MACID31_0_PKTSLEEP_8822C \
(BIT_MASK_MACID31_0_PKTSLEEP_8822C \
<< BIT_SHIFT_MACID31_0_PKTSLEEP_8822C)
#define BIT_CLEAR_MACID31_0_PKTSLEEP_8822C(x) \
((x) & (~BITS_MACID31_0_PKTSLEEP_8822C))
#define BIT_GET_MACID31_0_PKTSLEEP_8822C(x) \
(((x) >> BIT_SHIFT_MACID31_0_PKTSLEEP_8822C) & \
BIT_MASK_MACID31_0_PKTSLEEP_8822C)
#define BIT_SET_MACID31_0_PKTSLEEP_8822C(x, v) \
(BIT_CLEAR_MACID31_0_PKTSLEEP_8822C(x) | \
BIT_MACID31_0_PKTSLEEP_8822C(v))
/* 2 REG_HW_SEQ0_8822C */
#define BIT_SHIFT_HW_SSN_SEQ0_8822C 0
#define BIT_MASK_HW_SSN_SEQ0_8822C 0xfff
#define BIT_HW_SSN_SEQ0_8822C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ0_8822C) << BIT_SHIFT_HW_SSN_SEQ0_8822C)
#define BITS_HW_SSN_SEQ0_8822C \
(BIT_MASK_HW_SSN_SEQ0_8822C << BIT_SHIFT_HW_SSN_SEQ0_8822C)
#define BIT_CLEAR_HW_SSN_SEQ0_8822C(x) ((x) & (~BITS_HW_SSN_SEQ0_8822C))
#define BIT_GET_HW_SSN_SEQ0_8822C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ0_8822C) & BIT_MASK_HW_SSN_SEQ0_8822C)
#define BIT_SET_HW_SSN_SEQ0_8822C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ0_8822C(x) | BIT_HW_SSN_SEQ0_8822C(v))
/* 2 REG_HW_SEQ1_8822C */
#define BIT_SHIFT_HW_SSN_SEQ1_8822C 0
#define BIT_MASK_HW_SSN_SEQ1_8822C 0xfff
#define BIT_HW_SSN_SEQ1_8822C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ1_8822C) << BIT_SHIFT_HW_SSN_SEQ1_8822C)
#define BITS_HW_SSN_SEQ1_8822C \
(BIT_MASK_HW_SSN_SEQ1_8822C << BIT_SHIFT_HW_SSN_SEQ1_8822C)
#define BIT_CLEAR_HW_SSN_SEQ1_8822C(x) ((x) & (~BITS_HW_SSN_SEQ1_8822C))
#define BIT_GET_HW_SSN_SEQ1_8822C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ1_8822C) & BIT_MASK_HW_SSN_SEQ1_8822C)
#define BIT_SET_HW_SSN_SEQ1_8822C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ1_8822C(x) | BIT_HW_SSN_SEQ1_8822C(v))
/* 2 REG_HW_SEQ2_8822C */
#define BIT_SHIFT_HW_SSN_SEQ2_8822C 0
#define BIT_MASK_HW_SSN_SEQ2_8822C 0xfff
#define BIT_HW_SSN_SEQ2_8822C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ2_8822C) << BIT_SHIFT_HW_SSN_SEQ2_8822C)
#define BITS_HW_SSN_SEQ2_8822C \
(BIT_MASK_HW_SSN_SEQ2_8822C << BIT_SHIFT_HW_SSN_SEQ2_8822C)
#define BIT_CLEAR_HW_SSN_SEQ2_8822C(x) ((x) & (~BITS_HW_SSN_SEQ2_8822C))
#define BIT_GET_HW_SSN_SEQ2_8822C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ2_8822C) & BIT_MASK_HW_SSN_SEQ2_8822C)
#define BIT_SET_HW_SSN_SEQ2_8822C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ2_8822C(x) | BIT_HW_SSN_SEQ2_8822C(v))
/* 2 REG_HW_SEQ3_8822C */
#define BIT_SHIFT_CSI_HWSEQ_SEL_8822C 12
#define BIT_MASK_CSI_HWSEQ_SEL_8822C 0x3
#define BIT_CSI_HWSEQ_SEL_8822C(x) \
(((x) & BIT_MASK_CSI_HWSEQ_SEL_8822C) << BIT_SHIFT_CSI_HWSEQ_SEL_8822C)
#define BITS_CSI_HWSEQ_SEL_8822C \
(BIT_MASK_CSI_HWSEQ_SEL_8822C << BIT_SHIFT_CSI_HWSEQ_SEL_8822C)
#define BIT_CLEAR_CSI_HWSEQ_SEL_8822C(x) ((x) & (~BITS_CSI_HWSEQ_SEL_8822C))
#define BIT_GET_CSI_HWSEQ_SEL_8822C(x) \
(((x) >> BIT_SHIFT_CSI_HWSEQ_SEL_8822C) & BIT_MASK_CSI_HWSEQ_SEL_8822C)
#define BIT_SET_CSI_HWSEQ_SEL_8822C(x, v) \
(BIT_CLEAR_CSI_HWSEQ_SEL_8822C(x) | BIT_CSI_HWSEQ_SEL_8822C(v))
#define BIT_SHIFT_HW_SSN_SEQ3_8822C 0
#define BIT_MASK_HW_SSN_SEQ3_8822C 0xfff
#define BIT_HW_SSN_SEQ3_8822C(x) \
(((x) & BIT_MASK_HW_SSN_SEQ3_8822C) << BIT_SHIFT_HW_SSN_SEQ3_8822C)
#define BITS_HW_SSN_SEQ3_8822C \
(BIT_MASK_HW_SSN_SEQ3_8822C << BIT_SHIFT_HW_SSN_SEQ3_8822C)
#define BIT_CLEAR_HW_SSN_SEQ3_8822C(x) ((x) & (~BITS_HW_SSN_SEQ3_8822C))
#define BIT_GET_HW_SSN_SEQ3_8822C(x) \
(((x) >> BIT_SHIFT_HW_SSN_SEQ3_8822C) & BIT_MASK_HW_SSN_SEQ3_8822C)
#define BIT_SET_HW_SSN_SEQ3_8822C(x, v) \
(BIT_CLEAR_HW_SSN_SEQ3_8822C(x) | BIT_HW_SSN_SEQ3_8822C(v))
/* 2 REG_NULL_PKT_STATUS_V1_8822C */
#define BIT_SHIFT_PTCL_TOTAL_PG_V2_8822C 2
#define BIT_MASK_PTCL_TOTAL_PG_V2_8822C 0x3fff
#define BIT_PTCL_TOTAL_PG_V2_8822C(x) \
(((x) & BIT_MASK_PTCL_TOTAL_PG_V2_8822C) \
<< BIT_SHIFT_PTCL_TOTAL_PG_V2_8822C)
#define BITS_PTCL_TOTAL_PG_V2_8822C \
(BIT_MASK_PTCL_TOTAL_PG_V2_8822C << BIT_SHIFT_PTCL_TOTAL_PG_V2_8822C)
#define BIT_CLEAR_PTCL_TOTAL_PG_V2_8822C(x) \
((x) & (~BITS_PTCL_TOTAL_PG_V2_8822C))
#define BIT_GET_PTCL_TOTAL_PG_V2_8822C(x) \
(((x) >> BIT_SHIFT_PTCL_TOTAL_PG_V2_8822C) & \
BIT_MASK_PTCL_TOTAL_PG_V2_8822C)
#define BIT_SET_PTCL_TOTAL_PG_V2_8822C(x, v) \
(BIT_CLEAR_PTCL_TOTAL_PG_V2_8822C(x) | BIT_PTCL_TOTAL_PG_V2_8822C(v))
#define BIT_TX_NULL_1_8822C BIT(1)
#define BIT_TX_NULL_0_8822C BIT(0)
/* 2 REG_PTCL_ERR_STATUS_8822C */
#define BIT_PTCL_RATE_TABLE_INVALID_8822C BIT(7)
#define BIT_FTM_T2R_ERROR_8822C BIT(6)
#define BIT_PTCL_ERR0_8822C BIT(5)
#define BIT_PTCL_ERR1_8822C BIT(4)
#define BIT_PTCL_ERR2_8822C BIT(3)
#define BIT_PTCL_ERR3_8822C BIT(2)
#define BIT_PTCL_ERR4_8822C BIT(1)
#define BIT_PTCL_ERR5_8822C BIT(0)
/* 2 REG_NULL_PKT_STATUS_EXTEND_8822C */
#define BIT_CLI3_TX_NULL_1_8822C BIT(7)
#define BIT_CLI3_TX_NULL_0_8822C BIT(6)
#define BIT_CLI2_TX_NULL_1_8822C BIT(5)
#define BIT_CLI2_TX_NULL_0_8822C BIT(4)
#define BIT_CLI1_TX_NULL_1_8822C BIT(3)
#define BIT_CLI1_TX_NULL_0_8822C BIT(2)
#define BIT_CLI0_TX_NULL_1_8822C BIT(1)
#define BIT_CLI0_TX_NULL_0_8822C BIT(0)
/* 2 REG_HQMGQ_DROP_8822C */
#define BIT_HIQ_DROP_8822C BIT(7)
#define BIT_MGQ_DROP_8822C BIT(6)
#define BIT_CLR_HGQ_REQ_BLOCK_8822C BIT(5)
/* 2 REG_PRECNT_CTRL_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_EN_PRECNT_8822C BIT(11)
#define BIT_SHIFT_PRECNT_TH_8822C 0
#define BIT_MASK_PRECNT_TH_8822C 0x7ff
#define BIT_PRECNT_TH_8822C(x) \
(((x) & BIT_MASK_PRECNT_TH_8822C) << BIT_SHIFT_PRECNT_TH_8822C)
#define BITS_PRECNT_TH_8822C \
(BIT_MASK_PRECNT_TH_8822C << BIT_SHIFT_PRECNT_TH_8822C)
#define BIT_CLEAR_PRECNT_TH_8822C(x) ((x) & (~BITS_PRECNT_TH_8822C))
#define BIT_GET_PRECNT_TH_8822C(x) \
(((x) >> BIT_SHIFT_PRECNT_TH_8822C) & BIT_MASK_PRECNT_TH_8822C)
#define BIT_SET_PRECNT_TH_8822C(x, v) \
(BIT_CLEAR_PRECNT_TH_8822C(x) | BIT_PRECNT_TH_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_BT_POLLUTE_PKT_CNT_8822C */
#define BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822C 0
#define BIT_MASK_BT_POLLUTE_PKT_CNT_8822C 0xffff
#define BIT_BT_POLLUTE_PKT_CNT_8822C(x) \
(((x) & BIT_MASK_BT_POLLUTE_PKT_CNT_8822C) \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822C)
#define BITS_BT_POLLUTE_PKT_CNT_8822C \
(BIT_MASK_BT_POLLUTE_PKT_CNT_8822C \
<< BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822C)
#define BIT_CLEAR_BT_POLLUTE_PKT_CNT_8822C(x) \
((x) & (~BITS_BT_POLLUTE_PKT_CNT_8822C))
#define BIT_GET_BT_POLLUTE_PKT_CNT_8822C(x) \
(((x) >> BIT_SHIFT_BT_POLLUTE_PKT_CNT_8822C) & \
BIT_MASK_BT_POLLUTE_PKT_CNT_8822C)
#define BIT_SET_BT_POLLUTE_PKT_CNT_8822C(x, v) \
(BIT_CLEAR_BT_POLLUTE_PKT_CNT_8822C(x) | \
BIT_BT_POLLUTE_PKT_CNT_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_PTCL_DBG_8822C */
#define BIT_SHIFT_PTCL_DBG_8822C 0
#define BIT_MASK_PTCL_DBG_8822C 0xffffffffL
#define BIT_PTCL_DBG_8822C(x) \
(((x) & BIT_MASK_PTCL_DBG_8822C) << BIT_SHIFT_PTCL_DBG_8822C)
#define BITS_PTCL_DBG_8822C \
(BIT_MASK_PTCL_DBG_8822C << BIT_SHIFT_PTCL_DBG_8822C)
#define BIT_CLEAR_PTCL_DBG_8822C(x) ((x) & (~BITS_PTCL_DBG_8822C))
#define BIT_GET_PTCL_DBG_8822C(x) \
(((x) >> BIT_SHIFT_PTCL_DBG_8822C) & BIT_MASK_PTCL_DBG_8822C)
#define BIT_SET_PTCL_DBG_8822C(x, v) \
(BIT_CLEAR_PTCL_DBG_8822C(x) | BIT_PTCL_DBG_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_CPUMGQ_TIMER_CTRL2_8822C */
#define BIT_SHIFT_TRI_HEAD_ADDR_8822C 16
#define BIT_MASK_TRI_HEAD_ADDR_8822C 0xfff
#define BIT_TRI_HEAD_ADDR_8822C(x) \
(((x) & BIT_MASK_TRI_HEAD_ADDR_8822C) << BIT_SHIFT_TRI_HEAD_ADDR_8822C)
#define BITS_TRI_HEAD_ADDR_8822C \
(BIT_MASK_TRI_HEAD_ADDR_8822C << BIT_SHIFT_TRI_HEAD_ADDR_8822C)
#define BIT_CLEAR_TRI_HEAD_ADDR_8822C(x) ((x) & (~BITS_TRI_HEAD_ADDR_8822C))
#define BIT_GET_TRI_HEAD_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_TRI_HEAD_ADDR_8822C) & BIT_MASK_TRI_HEAD_ADDR_8822C)
#define BIT_SET_TRI_HEAD_ADDR_8822C(x, v) \
(BIT_CLEAR_TRI_HEAD_ADDR_8822C(x) | BIT_TRI_HEAD_ADDR_8822C(v))
#define BIT_DROP_TH_EN_8822C BIT(8)
#define BIT_SHIFT_DROP_TH_8822C 0
#define BIT_MASK_DROP_TH_8822C 0xff
#define BIT_DROP_TH_8822C(x) \
(((x) & BIT_MASK_DROP_TH_8822C) << BIT_SHIFT_DROP_TH_8822C)
#define BITS_DROP_TH_8822C (BIT_MASK_DROP_TH_8822C << BIT_SHIFT_DROP_TH_8822C)
#define BIT_CLEAR_DROP_TH_8822C(x) ((x) & (~BITS_DROP_TH_8822C))
#define BIT_GET_DROP_TH_8822C(x) \
(((x) >> BIT_SHIFT_DROP_TH_8822C) & BIT_MASK_DROP_TH_8822C)
#define BIT_SET_DROP_TH_8822C(x, v) \
(BIT_CLEAR_DROP_TH_8822C(x) | BIT_DROP_TH_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_DUMMY_PAGE4_V1_8822C */
/* 2 REG_MOREDATA_8822C */
#define BIT_MOREDATA_CTRL2_EN_V1_8822C BIT(3)
#define BIT_MOREDATA_CTRL1_EN_V1_8822C BIT(2)
#define BIT_PKTIN_MOREDATA_REPLACE_ENABLE_V1_8822C BIT(0)
/* 2 REG_Q0_Q1_INFO_8822C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822C BIT(31)
#define BIT_SHIFT_GTAB_ID_8822C 28
#define BIT_MASK_GTAB_ID_8822C 0x7
#define BIT_GTAB_ID_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_8822C) << BIT_SHIFT_GTAB_ID_8822C)
#define BITS_GTAB_ID_8822C (BIT_MASK_GTAB_ID_8822C << BIT_SHIFT_GTAB_ID_8822C)
#define BIT_CLEAR_GTAB_ID_8822C(x) ((x) & (~BITS_GTAB_ID_8822C))
#define BIT_GET_GTAB_ID_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822C) & BIT_MASK_GTAB_ID_8822C)
#define BIT_SET_GTAB_ID_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_8822C(x) | BIT_GTAB_ID_8822C(v))
#define BIT_SHIFT_AC1_PKT_INFO_8822C 16
#define BIT_MASK_AC1_PKT_INFO_8822C 0xfff
#define BIT_AC1_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC1_PKT_INFO_8822C) << BIT_SHIFT_AC1_PKT_INFO_8822C)
#define BITS_AC1_PKT_INFO_8822C \
(BIT_MASK_AC1_PKT_INFO_8822C << BIT_SHIFT_AC1_PKT_INFO_8822C)
#define BIT_CLEAR_AC1_PKT_INFO_8822C(x) ((x) & (~BITS_AC1_PKT_INFO_8822C))
#define BIT_GET_AC1_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC1_PKT_INFO_8822C) & BIT_MASK_AC1_PKT_INFO_8822C)
#define BIT_SET_AC1_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC1_PKT_INFO_8822C(x) | BIT_AC1_PKT_INFO_8822C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822C 12
#define BIT_MASK_GTAB_ID_V1_8822C 0x7
#define BIT_GTAB_ID_V1_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822C) << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BITS_GTAB_ID_V1_8822C \
(BIT_MASK_GTAB_ID_V1_8822C << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BIT_CLEAR_GTAB_ID_V1_8822C(x) ((x) & (~BITS_GTAB_ID_V1_8822C))
#define BIT_GET_GTAB_ID_V1_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822C) & BIT_MASK_GTAB_ID_V1_8822C)
#define BIT_SET_GTAB_ID_V1_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822C(x) | BIT_GTAB_ID_V1_8822C(v))
#define BIT_SHIFT_AC0_PKT_INFO_8822C 0
#define BIT_MASK_AC0_PKT_INFO_8822C 0xfff
#define BIT_AC0_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC0_PKT_INFO_8822C) << BIT_SHIFT_AC0_PKT_INFO_8822C)
#define BITS_AC0_PKT_INFO_8822C \
(BIT_MASK_AC0_PKT_INFO_8822C << BIT_SHIFT_AC0_PKT_INFO_8822C)
#define BIT_CLEAR_AC0_PKT_INFO_8822C(x) ((x) & (~BITS_AC0_PKT_INFO_8822C))
#define BIT_GET_AC0_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC0_PKT_INFO_8822C) & BIT_MASK_AC0_PKT_INFO_8822C)
#define BIT_SET_AC0_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC0_PKT_INFO_8822C(x) | BIT_AC0_PKT_INFO_8822C(v))
/* 2 REG_Q2_Q3_INFO_8822C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822C BIT(31)
#define BIT_SHIFT_GTAB_ID_8822C 28
#define BIT_MASK_GTAB_ID_8822C 0x7
#define BIT_GTAB_ID_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_8822C) << BIT_SHIFT_GTAB_ID_8822C)
#define BITS_GTAB_ID_8822C (BIT_MASK_GTAB_ID_8822C << BIT_SHIFT_GTAB_ID_8822C)
#define BIT_CLEAR_GTAB_ID_8822C(x) ((x) & (~BITS_GTAB_ID_8822C))
#define BIT_GET_GTAB_ID_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822C) & BIT_MASK_GTAB_ID_8822C)
#define BIT_SET_GTAB_ID_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_8822C(x) | BIT_GTAB_ID_8822C(v))
#define BIT_SHIFT_AC3_PKT_INFO_8822C 16
#define BIT_MASK_AC3_PKT_INFO_8822C 0xfff
#define BIT_AC3_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC3_PKT_INFO_8822C) << BIT_SHIFT_AC3_PKT_INFO_8822C)
#define BITS_AC3_PKT_INFO_8822C \
(BIT_MASK_AC3_PKT_INFO_8822C << BIT_SHIFT_AC3_PKT_INFO_8822C)
#define BIT_CLEAR_AC3_PKT_INFO_8822C(x) ((x) & (~BITS_AC3_PKT_INFO_8822C))
#define BIT_GET_AC3_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC3_PKT_INFO_8822C) & BIT_MASK_AC3_PKT_INFO_8822C)
#define BIT_SET_AC3_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC3_PKT_INFO_8822C(x) | BIT_AC3_PKT_INFO_8822C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822C 12
#define BIT_MASK_GTAB_ID_V1_8822C 0x7
#define BIT_GTAB_ID_V1_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822C) << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BITS_GTAB_ID_V1_8822C \
(BIT_MASK_GTAB_ID_V1_8822C << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BIT_CLEAR_GTAB_ID_V1_8822C(x) ((x) & (~BITS_GTAB_ID_V1_8822C))
#define BIT_GET_GTAB_ID_V1_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822C) & BIT_MASK_GTAB_ID_V1_8822C)
#define BIT_SET_GTAB_ID_V1_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822C(x) | BIT_GTAB_ID_V1_8822C(v))
#define BIT_SHIFT_AC2_PKT_INFO_8822C 0
#define BIT_MASK_AC2_PKT_INFO_8822C 0xfff
#define BIT_AC2_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC2_PKT_INFO_8822C) << BIT_SHIFT_AC2_PKT_INFO_8822C)
#define BITS_AC2_PKT_INFO_8822C \
(BIT_MASK_AC2_PKT_INFO_8822C << BIT_SHIFT_AC2_PKT_INFO_8822C)
#define BIT_CLEAR_AC2_PKT_INFO_8822C(x) ((x) & (~BITS_AC2_PKT_INFO_8822C))
#define BIT_GET_AC2_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC2_PKT_INFO_8822C) & BIT_MASK_AC2_PKT_INFO_8822C)
#define BIT_SET_AC2_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC2_PKT_INFO_8822C(x) | BIT_AC2_PKT_INFO_8822C(v))
/* 2 REG_Q4_Q5_INFO_8822C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822C BIT(31)
#define BIT_SHIFT_GTAB_ID_8822C 28
#define BIT_MASK_GTAB_ID_8822C 0x7
#define BIT_GTAB_ID_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_8822C) << BIT_SHIFT_GTAB_ID_8822C)
#define BITS_GTAB_ID_8822C (BIT_MASK_GTAB_ID_8822C << BIT_SHIFT_GTAB_ID_8822C)
#define BIT_CLEAR_GTAB_ID_8822C(x) ((x) & (~BITS_GTAB_ID_8822C))
#define BIT_GET_GTAB_ID_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822C) & BIT_MASK_GTAB_ID_8822C)
#define BIT_SET_GTAB_ID_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_8822C(x) | BIT_GTAB_ID_8822C(v))
#define BIT_SHIFT_AC5_PKT_INFO_8822C 16
#define BIT_MASK_AC5_PKT_INFO_8822C 0xfff
#define BIT_AC5_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC5_PKT_INFO_8822C) << BIT_SHIFT_AC5_PKT_INFO_8822C)
#define BITS_AC5_PKT_INFO_8822C \
(BIT_MASK_AC5_PKT_INFO_8822C << BIT_SHIFT_AC5_PKT_INFO_8822C)
#define BIT_CLEAR_AC5_PKT_INFO_8822C(x) ((x) & (~BITS_AC5_PKT_INFO_8822C))
#define BIT_GET_AC5_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC5_PKT_INFO_8822C) & BIT_MASK_AC5_PKT_INFO_8822C)
#define BIT_SET_AC5_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC5_PKT_INFO_8822C(x) | BIT_AC5_PKT_INFO_8822C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822C 12
#define BIT_MASK_GTAB_ID_V1_8822C 0x7
#define BIT_GTAB_ID_V1_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822C) << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BITS_GTAB_ID_V1_8822C \
(BIT_MASK_GTAB_ID_V1_8822C << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BIT_CLEAR_GTAB_ID_V1_8822C(x) ((x) & (~BITS_GTAB_ID_V1_8822C))
#define BIT_GET_GTAB_ID_V1_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822C) & BIT_MASK_GTAB_ID_V1_8822C)
#define BIT_SET_GTAB_ID_V1_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822C(x) | BIT_GTAB_ID_V1_8822C(v))
#define BIT_SHIFT_AC4_PKT_INFO_8822C 0
#define BIT_MASK_AC4_PKT_INFO_8822C 0xfff
#define BIT_AC4_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC4_PKT_INFO_8822C) << BIT_SHIFT_AC4_PKT_INFO_8822C)
#define BITS_AC4_PKT_INFO_8822C \
(BIT_MASK_AC4_PKT_INFO_8822C << BIT_SHIFT_AC4_PKT_INFO_8822C)
#define BIT_CLEAR_AC4_PKT_INFO_8822C(x) ((x) & (~BITS_AC4_PKT_INFO_8822C))
#define BIT_GET_AC4_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC4_PKT_INFO_8822C) & BIT_MASK_AC4_PKT_INFO_8822C)
#define BIT_SET_AC4_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC4_PKT_INFO_8822C(x) | BIT_AC4_PKT_INFO_8822C(v))
/* 2 REG_Q6_Q7_INFO_8822C */
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_8822C BIT(31)
#define BIT_SHIFT_GTAB_ID_8822C 28
#define BIT_MASK_GTAB_ID_8822C 0x7
#define BIT_GTAB_ID_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_8822C) << BIT_SHIFT_GTAB_ID_8822C)
#define BITS_GTAB_ID_8822C (BIT_MASK_GTAB_ID_8822C << BIT_SHIFT_GTAB_ID_8822C)
#define BIT_CLEAR_GTAB_ID_8822C(x) ((x) & (~BITS_GTAB_ID_8822C))
#define BIT_GET_GTAB_ID_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_8822C) & BIT_MASK_GTAB_ID_8822C)
#define BIT_SET_GTAB_ID_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_8822C(x) | BIT_GTAB_ID_8822C(v))
#define BIT_SHIFT_AC7_PKT_INFO_8822C 16
#define BIT_MASK_AC7_PKT_INFO_8822C 0xfff
#define BIT_AC7_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC7_PKT_INFO_8822C) << BIT_SHIFT_AC7_PKT_INFO_8822C)
#define BITS_AC7_PKT_INFO_8822C \
(BIT_MASK_AC7_PKT_INFO_8822C << BIT_SHIFT_AC7_PKT_INFO_8822C)
#define BIT_CLEAR_AC7_PKT_INFO_8822C(x) ((x) & (~BITS_AC7_PKT_INFO_8822C))
#define BIT_GET_AC7_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC7_PKT_INFO_8822C) & BIT_MASK_AC7_PKT_INFO_8822C)
#define BIT_SET_AC7_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC7_PKT_INFO_8822C(x) | BIT_AC7_PKT_INFO_8822C(v))
#define BIT_QUEUE_MACID_AC_NOT_THE_SAME_V1_8822C BIT(15)
#define BIT_SHIFT_GTAB_ID_V1_8822C 12
#define BIT_MASK_GTAB_ID_V1_8822C 0x7
#define BIT_GTAB_ID_V1_8822C(x) \
(((x) & BIT_MASK_GTAB_ID_V1_8822C) << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BITS_GTAB_ID_V1_8822C \
(BIT_MASK_GTAB_ID_V1_8822C << BIT_SHIFT_GTAB_ID_V1_8822C)
#define BIT_CLEAR_GTAB_ID_V1_8822C(x) ((x) & (~BITS_GTAB_ID_V1_8822C))
#define BIT_GET_GTAB_ID_V1_8822C(x) \
(((x) >> BIT_SHIFT_GTAB_ID_V1_8822C) & BIT_MASK_GTAB_ID_V1_8822C)
#define BIT_SET_GTAB_ID_V1_8822C(x, v) \
(BIT_CLEAR_GTAB_ID_V1_8822C(x) | BIT_GTAB_ID_V1_8822C(v))
#define BIT_SHIFT_AC6_PKT_INFO_8822C 0
#define BIT_MASK_AC6_PKT_INFO_8822C 0xfff
#define BIT_AC6_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_AC6_PKT_INFO_8822C) << BIT_SHIFT_AC6_PKT_INFO_8822C)
#define BITS_AC6_PKT_INFO_8822C \
(BIT_MASK_AC6_PKT_INFO_8822C << BIT_SHIFT_AC6_PKT_INFO_8822C)
#define BIT_CLEAR_AC6_PKT_INFO_8822C(x) ((x) & (~BITS_AC6_PKT_INFO_8822C))
#define BIT_GET_AC6_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_AC6_PKT_INFO_8822C) & BIT_MASK_AC6_PKT_INFO_8822C)
#define BIT_SET_AC6_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_AC6_PKT_INFO_8822C(x) | BIT_AC6_PKT_INFO_8822C(v))
/* 2 REG_MGQ_HIQ_INFO_8822C */
#define BIT_SHIFT_HIQ_PKT_INFO_8822C 16
#define BIT_MASK_HIQ_PKT_INFO_8822C 0xfff
#define BIT_HIQ_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_HIQ_PKT_INFO_8822C) << BIT_SHIFT_HIQ_PKT_INFO_8822C)
#define BITS_HIQ_PKT_INFO_8822C \
(BIT_MASK_HIQ_PKT_INFO_8822C << BIT_SHIFT_HIQ_PKT_INFO_8822C)
#define BIT_CLEAR_HIQ_PKT_INFO_8822C(x) ((x) & (~BITS_HIQ_PKT_INFO_8822C))
#define BIT_GET_HIQ_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_HIQ_PKT_INFO_8822C) & BIT_MASK_HIQ_PKT_INFO_8822C)
#define BIT_SET_HIQ_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_HIQ_PKT_INFO_8822C(x) | BIT_HIQ_PKT_INFO_8822C(v))
#define BIT_SHIFT_MGQ_PKT_INFO_8822C 0
#define BIT_MASK_MGQ_PKT_INFO_8822C 0xfff
#define BIT_MGQ_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_MGQ_PKT_INFO_8822C) << BIT_SHIFT_MGQ_PKT_INFO_8822C)
#define BITS_MGQ_PKT_INFO_8822C \
(BIT_MASK_MGQ_PKT_INFO_8822C << BIT_SHIFT_MGQ_PKT_INFO_8822C)
#define BIT_CLEAR_MGQ_PKT_INFO_8822C(x) ((x) & (~BITS_MGQ_PKT_INFO_8822C))
#define BIT_GET_MGQ_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_PKT_INFO_8822C) & BIT_MASK_MGQ_PKT_INFO_8822C)
#define BIT_SET_MGQ_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_MGQ_PKT_INFO_8822C(x) | BIT_MGQ_PKT_INFO_8822C(v))
/* 2 REG_CMDQ_BCNQ_INFO_8822C */
#define BIT_SHIFT_CMDQ_PKT_INFO_8822C 16
#define BIT_MASK_CMDQ_PKT_INFO_8822C 0xfff
#define BIT_CMDQ_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_CMDQ_PKT_INFO_8822C) << BIT_SHIFT_CMDQ_PKT_INFO_8822C)
#define BITS_CMDQ_PKT_INFO_8822C \
(BIT_MASK_CMDQ_PKT_INFO_8822C << BIT_SHIFT_CMDQ_PKT_INFO_8822C)
#define BIT_CLEAR_CMDQ_PKT_INFO_8822C(x) ((x) & (~BITS_CMDQ_PKT_INFO_8822C))
#define BIT_GET_CMDQ_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_CMDQ_PKT_INFO_8822C) & BIT_MASK_CMDQ_PKT_INFO_8822C)
#define BIT_SET_CMDQ_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_CMDQ_PKT_INFO_8822C(x) | BIT_CMDQ_PKT_INFO_8822C(v))
#define BIT_SHIFT_BCNQ_PKT_INFO_8822C 0
#define BIT_MASK_BCNQ_PKT_INFO_8822C 0xfff
#define BIT_BCNQ_PKT_INFO_8822C(x) \
(((x) & BIT_MASK_BCNQ_PKT_INFO_8822C) << BIT_SHIFT_BCNQ_PKT_INFO_8822C)
#define BITS_BCNQ_PKT_INFO_8822C \
(BIT_MASK_BCNQ_PKT_INFO_8822C << BIT_SHIFT_BCNQ_PKT_INFO_8822C)
#define BIT_CLEAR_BCNQ_PKT_INFO_8822C(x) ((x) & (~BITS_BCNQ_PKT_INFO_8822C))
#define BIT_GET_BCNQ_PKT_INFO_8822C(x) \
(((x) >> BIT_SHIFT_BCNQ_PKT_INFO_8822C) & BIT_MASK_BCNQ_PKT_INFO_8822C)
#define BIT_SET_BCNQ_PKT_INFO_8822C(x, v) \
(BIT_CLEAR_BCNQ_PKT_INFO_8822C(x) | BIT_BCNQ_PKT_INFO_8822C(v))
/* 2 REG_LOOPBACK_OPTION_8822C */
#define BIT_LOOPACK_FAST_EDCA_EN_8822C BIT(24)
/* 2 REG_AESIV_SETTING_8822C */
#define BIT_SHIFT_AESIV_OFFSET_8822C 0
#define BIT_MASK_AESIV_OFFSET_8822C 0xfff
#define BIT_AESIV_OFFSET_8822C(x) \
(((x) & BIT_MASK_AESIV_OFFSET_8822C) << BIT_SHIFT_AESIV_OFFSET_8822C)
#define BITS_AESIV_OFFSET_8822C \
(BIT_MASK_AESIV_OFFSET_8822C << BIT_SHIFT_AESIV_OFFSET_8822C)
#define BIT_CLEAR_AESIV_OFFSET_8822C(x) ((x) & (~BITS_AESIV_OFFSET_8822C))
#define BIT_GET_AESIV_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_AESIV_OFFSET_8822C) & BIT_MASK_AESIV_OFFSET_8822C)
#define BIT_SET_AESIV_OFFSET_8822C(x, v) \
(BIT_CLEAR_AESIV_OFFSET_8822C(x) | BIT_AESIV_OFFSET_8822C(v))
/* 2 REG_BF0_TIME_SETTING_8822C */
#define BIT_BF0_TIMER_SET_8822C BIT(31)
#define BIT_BF0_TIMER_CLR_8822C BIT(30)
#define BIT_BF0_UPDATE_EN_8822C BIT(29)
#define BIT_BF0_TIMER_EN_8822C BIT(28)
#define BIT_SHIFT_BF0_PRETIME_OVER_8822C 16
#define BIT_MASK_BF0_PRETIME_OVER_8822C 0xfff
#define BIT_BF0_PRETIME_OVER_8822C(x) \
(((x) & BIT_MASK_BF0_PRETIME_OVER_8822C) \
<< BIT_SHIFT_BF0_PRETIME_OVER_8822C)
#define BITS_BF0_PRETIME_OVER_8822C \
(BIT_MASK_BF0_PRETIME_OVER_8822C << BIT_SHIFT_BF0_PRETIME_OVER_8822C)
#define BIT_CLEAR_BF0_PRETIME_OVER_8822C(x) \
((x) & (~BITS_BF0_PRETIME_OVER_8822C))
#define BIT_GET_BF0_PRETIME_OVER_8822C(x) \
(((x) >> BIT_SHIFT_BF0_PRETIME_OVER_8822C) & \
BIT_MASK_BF0_PRETIME_OVER_8822C)
#define BIT_SET_BF0_PRETIME_OVER_8822C(x, v) \
(BIT_CLEAR_BF0_PRETIME_OVER_8822C(x) | BIT_BF0_PRETIME_OVER_8822C(v))
#define BIT_SHIFT_BF0_LIFETIME_8822C 0
#define BIT_MASK_BF0_LIFETIME_8822C 0xffff
#define BIT_BF0_LIFETIME_8822C(x) \
(((x) & BIT_MASK_BF0_LIFETIME_8822C) << BIT_SHIFT_BF0_LIFETIME_8822C)
#define BITS_BF0_LIFETIME_8822C \
(BIT_MASK_BF0_LIFETIME_8822C << BIT_SHIFT_BF0_LIFETIME_8822C)
#define BIT_CLEAR_BF0_LIFETIME_8822C(x) ((x) & (~BITS_BF0_LIFETIME_8822C))
#define BIT_GET_BF0_LIFETIME_8822C(x) \
(((x) >> BIT_SHIFT_BF0_LIFETIME_8822C) & BIT_MASK_BF0_LIFETIME_8822C)
#define BIT_SET_BF0_LIFETIME_8822C(x, v) \
(BIT_CLEAR_BF0_LIFETIME_8822C(x) | BIT_BF0_LIFETIME_8822C(v))
/* 2 REG_BF1_TIME_SETTING_8822C */
#define BIT_BF1_TIMER_SET_8822C BIT(31)
#define BIT_BF1_TIMER_CLR_8822C BIT(30)
#define BIT_BF1_UPDATE_EN_8822C BIT(29)
#define BIT_BF1_TIMER_EN_8822C BIT(28)
#define BIT_SHIFT_BF1_PRETIME_OVER_8822C 16
#define BIT_MASK_BF1_PRETIME_OVER_8822C 0xfff
#define BIT_BF1_PRETIME_OVER_8822C(x) \
(((x) & BIT_MASK_BF1_PRETIME_OVER_8822C) \
<< BIT_SHIFT_BF1_PRETIME_OVER_8822C)
#define BITS_BF1_PRETIME_OVER_8822C \
(BIT_MASK_BF1_PRETIME_OVER_8822C << BIT_SHIFT_BF1_PRETIME_OVER_8822C)
#define BIT_CLEAR_BF1_PRETIME_OVER_8822C(x) \
((x) & (~BITS_BF1_PRETIME_OVER_8822C))
#define BIT_GET_BF1_PRETIME_OVER_8822C(x) \
(((x) >> BIT_SHIFT_BF1_PRETIME_OVER_8822C) & \
BIT_MASK_BF1_PRETIME_OVER_8822C)
#define BIT_SET_BF1_PRETIME_OVER_8822C(x, v) \
(BIT_CLEAR_BF1_PRETIME_OVER_8822C(x) | BIT_BF1_PRETIME_OVER_8822C(v))
#define BIT_SHIFT_BF1_LIFETIME_8822C 0
#define BIT_MASK_BF1_LIFETIME_8822C 0xffff
#define BIT_BF1_LIFETIME_8822C(x) \
(((x) & BIT_MASK_BF1_LIFETIME_8822C) << BIT_SHIFT_BF1_LIFETIME_8822C)
#define BITS_BF1_LIFETIME_8822C \
(BIT_MASK_BF1_LIFETIME_8822C << BIT_SHIFT_BF1_LIFETIME_8822C)
#define BIT_CLEAR_BF1_LIFETIME_8822C(x) ((x) & (~BITS_BF1_LIFETIME_8822C))
#define BIT_GET_BF1_LIFETIME_8822C(x) \
(((x) >> BIT_SHIFT_BF1_LIFETIME_8822C) & BIT_MASK_BF1_LIFETIME_8822C)
#define BIT_SET_BF1_LIFETIME_8822C(x, v) \
(BIT_CLEAR_BF1_LIFETIME_8822C(x) | BIT_BF1_LIFETIME_8822C(v))
/* 2 REG_BF_TIMEOUT_EN_8822C */
#define BIT_EN_VHT_LDPC_8822C BIT(9)
#define BIT_EN_HT_LDPC_8822C BIT(8)
#define BIT_BF1_TIMEOUT_EN_8822C BIT(1)
#define BIT_BF0_TIMEOUT_EN_8822C BIT(0)
/* 2 REG_MACID_RELEASE0_8822C */
#define BIT_SHIFT_MACID31_0_RELEASE_8822C 0
#define BIT_MASK_MACID31_0_RELEASE_8822C 0xffffffffL
#define BIT_MACID31_0_RELEASE_8822C(x) \
(((x) & BIT_MASK_MACID31_0_RELEASE_8822C) \
<< BIT_SHIFT_MACID31_0_RELEASE_8822C)
#define BITS_MACID31_0_RELEASE_8822C \
(BIT_MASK_MACID31_0_RELEASE_8822C << BIT_SHIFT_MACID31_0_RELEASE_8822C)
#define BIT_CLEAR_MACID31_0_RELEASE_8822C(x) \
((x) & (~BITS_MACID31_0_RELEASE_8822C))
#define BIT_GET_MACID31_0_RELEASE_8822C(x) \
(((x) >> BIT_SHIFT_MACID31_0_RELEASE_8822C) & \
BIT_MASK_MACID31_0_RELEASE_8822C)
#define BIT_SET_MACID31_0_RELEASE_8822C(x, v) \
(BIT_CLEAR_MACID31_0_RELEASE_8822C(x) | BIT_MACID31_0_RELEASE_8822C(v))
/* 2 REG_MACID_RELEASE1_8822C */
#define BIT_SHIFT_MACID63_32_RELEASE_8822C 0
#define BIT_MASK_MACID63_32_RELEASE_8822C 0xffffffffL
#define BIT_MACID63_32_RELEASE_8822C(x) \
(((x) & BIT_MASK_MACID63_32_RELEASE_8822C) \
<< BIT_SHIFT_MACID63_32_RELEASE_8822C)
#define BITS_MACID63_32_RELEASE_8822C \
(BIT_MASK_MACID63_32_RELEASE_8822C \
<< BIT_SHIFT_MACID63_32_RELEASE_8822C)
#define BIT_CLEAR_MACID63_32_RELEASE_8822C(x) \
((x) & (~BITS_MACID63_32_RELEASE_8822C))
#define BIT_GET_MACID63_32_RELEASE_8822C(x) \
(((x) >> BIT_SHIFT_MACID63_32_RELEASE_8822C) & \
BIT_MASK_MACID63_32_RELEASE_8822C)
#define BIT_SET_MACID63_32_RELEASE_8822C(x, v) \
(BIT_CLEAR_MACID63_32_RELEASE_8822C(x) | \
BIT_MACID63_32_RELEASE_8822C(v))
/* 2 REG_MACID_RELEASE2_8822C */
#define BIT_SHIFT_MACID95_64_RELEASE_8822C 0
#define BIT_MASK_MACID95_64_RELEASE_8822C 0xffffffffL
#define BIT_MACID95_64_RELEASE_8822C(x) \
(((x) & BIT_MASK_MACID95_64_RELEASE_8822C) \
<< BIT_SHIFT_MACID95_64_RELEASE_8822C)
#define BITS_MACID95_64_RELEASE_8822C \
(BIT_MASK_MACID95_64_RELEASE_8822C \
<< BIT_SHIFT_MACID95_64_RELEASE_8822C)
#define BIT_CLEAR_MACID95_64_RELEASE_8822C(x) \
((x) & (~BITS_MACID95_64_RELEASE_8822C))
#define BIT_GET_MACID95_64_RELEASE_8822C(x) \
(((x) >> BIT_SHIFT_MACID95_64_RELEASE_8822C) & \
BIT_MASK_MACID95_64_RELEASE_8822C)
#define BIT_SET_MACID95_64_RELEASE_8822C(x, v) \
(BIT_CLEAR_MACID95_64_RELEASE_8822C(x) | \
BIT_MACID95_64_RELEASE_8822C(v))
/* 2 REG_MACID_RELEASE3_8822C */
#define BIT_SHIFT_MACID127_96_RELEASE_8822C 0
#define BIT_MASK_MACID127_96_RELEASE_8822C 0xffffffffL
#define BIT_MACID127_96_RELEASE_8822C(x) \
(((x) & BIT_MASK_MACID127_96_RELEASE_8822C) \
<< BIT_SHIFT_MACID127_96_RELEASE_8822C)
#define BITS_MACID127_96_RELEASE_8822C \
(BIT_MASK_MACID127_96_RELEASE_8822C \
<< BIT_SHIFT_MACID127_96_RELEASE_8822C)
#define BIT_CLEAR_MACID127_96_RELEASE_8822C(x) \
((x) & (~BITS_MACID127_96_RELEASE_8822C))
#define BIT_GET_MACID127_96_RELEASE_8822C(x) \
(((x) >> BIT_SHIFT_MACID127_96_RELEASE_8822C) & \
BIT_MASK_MACID127_96_RELEASE_8822C)
#define BIT_SET_MACID127_96_RELEASE_8822C(x, v) \
(BIT_CLEAR_MACID127_96_RELEASE_8822C(x) | \
BIT_MACID127_96_RELEASE_8822C(v))
/* 2 REG_MACID_RELEASE_SETTING_8822C */
#define BIT_MACID_VALUE_8822C BIT(7)
#define BIT_SHIFT_MACID_OFFSET_8822C 0
#define BIT_MASK_MACID_OFFSET_8822C 0x7f
#define BIT_MACID_OFFSET_8822C(x) \
(((x) & BIT_MASK_MACID_OFFSET_8822C) << BIT_SHIFT_MACID_OFFSET_8822C)
#define BITS_MACID_OFFSET_8822C \
(BIT_MASK_MACID_OFFSET_8822C << BIT_SHIFT_MACID_OFFSET_8822C)
#define BIT_CLEAR_MACID_OFFSET_8822C(x) ((x) & (~BITS_MACID_OFFSET_8822C))
#define BIT_GET_MACID_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_MACID_OFFSET_8822C) & BIT_MASK_MACID_OFFSET_8822C)
#define BIT_SET_MACID_OFFSET_8822C(x, v) \
(BIT_CLEAR_MACID_OFFSET_8822C(x) | BIT_MACID_OFFSET_8822C(v))
/* 2 REG_FAST_EDCA_VOVI_SETTING_8822C */
#define BIT_SHIFT_VI_FAST_EDCA_TO_8822C 24
#define BIT_MASK_VI_FAST_EDCA_TO_8822C 0xff
#define BIT_VI_FAST_EDCA_TO_8822C(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_TO_8822C) \
<< BIT_SHIFT_VI_FAST_EDCA_TO_8822C)
#define BITS_VI_FAST_EDCA_TO_8822C \
(BIT_MASK_VI_FAST_EDCA_TO_8822C << BIT_SHIFT_VI_FAST_EDCA_TO_8822C)
#define BIT_CLEAR_VI_FAST_EDCA_TO_8822C(x) ((x) & (~BITS_VI_FAST_EDCA_TO_8822C))
#define BIT_GET_VI_FAST_EDCA_TO_8822C(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_TO_8822C) & \
BIT_MASK_VI_FAST_EDCA_TO_8822C)
#define BIT_SET_VI_FAST_EDCA_TO_8822C(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_TO_8822C(x) | BIT_VI_FAST_EDCA_TO_8822C(v))
#define BIT_VI_THRESHOLD_SEL_8822C BIT(23)
#define BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822C 16
#define BIT_MASK_VI_FAST_EDCA_PKT_TH_8822C 0x7f
#define BIT_VI_FAST_EDCA_PKT_TH_8822C(x) \
(((x) & BIT_MASK_VI_FAST_EDCA_PKT_TH_8822C) \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822C)
#define BITS_VI_FAST_EDCA_PKT_TH_8822C \
(BIT_MASK_VI_FAST_EDCA_PKT_TH_8822C \
<< BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822C)
#define BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8822C(x) \
((x) & (~BITS_VI_FAST_EDCA_PKT_TH_8822C))
#define BIT_GET_VI_FAST_EDCA_PKT_TH_8822C(x) \
(((x) >> BIT_SHIFT_VI_FAST_EDCA_PKT_TH_8822C) & \
BIT_MASK_VI_FAST_EDCA_PKT_TH_8822C)
#define BIT_SET_VI_FAST_EDCA_PKT_TH_8822C(x, v) \
(BIT_CLEAR_VI_FAST_EDCA_PKT_TH_8822C(x) | \
BIT_VI_FAST_EDCA_PKT_TH_8822C(v))
#define BIT_SHIFT_VO_FAST_EDCA_TO_8822C 8
#define BIT_MASK_VO_FAST_EDCA_TO_8822C 0xff
#define BIT_VO_FAST_EDCA_TO_8822C(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_TO_8822C) \
<< BIT_SHIFT_VO_FAST_EDCA_TO_8822C)
#define BITS_VO_FAST_EDCA_TO_8822C \
(BIT_MASK_VO_FAST_EDCA_TO_8822C << BIT_SHIFT_VO_FAST_EDCA_TO_8822C)
#define BIT_CLEAR_VO_FAST_EDCA_TO_8822C(x) ((x) & (~BITS_VO_FAST_EDCA_TO_8822C))
#define BIT_GET_VO_FAST_EDCA_TO_8822C(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_TO_8822C) & \
BIT_MASK_VO_FAST_EDCA_TO_8822C)
#define BIT_SET_VO_FAST_EDCA_TO_8822C(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_TO_8822C(x) | BIT_VO_FAST_EDCA_TO_8822C(v))
#define BIT_VO_THRESHOLD_SEL_8822C BIT(7)
#define BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822C 0
#define BIT_MASK_VO_FAST_EDCA_PKT_TH_8822C 0x7f
#define BIT_VO_FAST_EDCA_PKT_TH_8822C(x) \
(((x) & BIT_MASK_VO_FAST_EDCA_PKT_TH_8822C) \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822C)
#define BITS_VO_FAST_EDCA_PKT_TH_8822C \
(BIT_MASK_VO_FAST_EDCA_PKT_TH_8822C \
<< BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822C)
#define BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8822C(x) \
((x) & (~BITS_VO_FAST_EDCA_PKT_TH_8822C))
#define BIT_GET_VO_FAST_EDCA_PKT_TH_8822C(x) \
(((x) >> BIT_SHIFT_VO_FAST_EDCA_PKT_TH_8822C) & \
BIT_MASK_VO_FAST_EDCA_PKT_TH_8822C)
#define BIT_SET_VO_FAST_EDCA_PKT_TH_8822C(x, v) \
(BIT_CLEAR_VO_FAST_EDCA_PKT_TH_8822C(x) | \
BIT_VO_FAST_EDCA_PKT_TH_8822C(v))
/* 2 REG_FAST_EDCA_BEBK_SETTING_8822C */
#define BIT_SHIFT_BK_FAST_EDCA_TO_8822C 24
#define BIT_MASK_BK_FAST_EDCA_TO_8822C 0xff
#define BIT_BK_FAST_EDCA_TO_8822C(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_TO_8822C) \
<< BIT_SHIFT_BK_FAST_EDCA_TO_8822C)
#define BITS_BK_FAST_EDCA_TO_8822C \
(BIT_MASK_BK_FAST_EDCA_TO_8822C << BIT_SHIFT_BK_FAST_EDCA_TO_8822C)
#define BIT_CLEAR_BK_FAST_EDCA_TO_8822C(x) ((x) & (~BITS_BK_FAST_EDCA_TO_8822C))
#define BIT_GET_BK_FAST_EDCA_TO_8822C(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_TO_8822C) & \
BIT_MASK_BK_FAST_EDCA_TO_8822C)
#define BIT_SET_BK_FAST_EDCA_TO_8822C(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_TO_8822C(x) | BIT_BK_FAST_EDCA_TO_8822C(v))
#define BIT_BK_THRESHOLD_SEL_8822C BIT(23)
#define BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822C 16
#define BIT_MASK_BK_FAST_EDCA_PKT_TH_8822C 0x7f
#define BIT_BK_FAST_EDCA_PKT_TH_8822C(x) \
(((x) & BIT_MASK_BK_FAST_EDCA_PKT_TH_8822C) \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822C)
#define BITS_BK_FAST_EDCA_PKT_TH_8822C \
(BIT_MASK_BK_FAST_EDCA_PKT_TH_8822C \
<< BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822C)
#define BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8822C(x) \
((x) & (~BITS_BK_FAST_EDCA_PKT_TH_8822C))
#define BIT_GET_BK_FAST_EDCA_PKT_TH_8822C(x) \
(((x) >> BIT_SHIFT_BK_FAST_EDCA_PKT_TH_8822C) & \
BIT_MASK_BK_FAST_EDCA_PKT_TH_8822C)
#define BIT_SET_BK_FAST_EDCA_PKT_TH_8822C(x, v) \
(BIT_CLEAR_BK_FAST_EDCA_PKT_TH_8822C(x) | \
BIT_BK_FAST_EDCA_PKT_TH_8822C(v))
#define BIT_SHIFT_BE_FAST_EDCA_TO_8822C 8
#define BIT_MASK_BE_FAST_EDCA_TO_8822C 0xff
#define BIT_BE_FAST_EDCA_TO_8822C(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_TO_8822C) \
<< BIT_SHIFT_BE_FAST_EDCA_TO_8822C)
#define BITS_BE_FAST_EDCA_TO_8822C \
(BIT_MASK_BE_FAST_EDCA_TO_8822C << BIT_SHIFT_BE_FAST_EDCA_TO_8822C)
#define BIT_CLEAR_BE_FAST_EDCA_TO_8822C(x) ((x) & (~BITS_BE_FAST_EDCA_TO_8822C))
#define BIT_GET_BE_FAST_EDCA_TO_8822C(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_TO_8822C) & \
BIT_MASK_BE_FAST_EDCA_TO_8822C)
#define BIT_SET_BE_FAST_EDCA_TO_8822C(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_TO_8822C(x) | BIT_BE_FAST_EDCA_TO_8822C(v))
#define BIT_BE_THRESHOLD_SEL_8822C BIT(7)
#define BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822C 0
#define BIT_MASK_BE_FAST_EDCA_PKT_TH_8822C 0x7f
#define BIT_BE_FAST_EDCA_PKT_TH_8822C(x) \
(((x) & BIT_MASK_BE_FAST_EDCA_PKT_TH_8822C) \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822C)
#define BITS_BE_FAST_EDCA_PKT_TH_8822C \
(BIT_MASK_BE_FAST_EDCA_PKT_TH_8822C \
<< BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822C)
#define BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8822C(x) \
((x) & (~BITS_BE_FAST_EDCA_PKT_TH_8822C))
#define BIT_GET_BE_FAST_EDCA_PKT_TH_8822C(x) \
(((x) >> BIT_SHIFT_BE_FAST_EDCA_PKT_TH_8822C) & \
BIT_MASK_BE_FAST_EDCA_PKT_TH_8822C)
#define BIT_SET_BE_FAST_EDCA_PKT_TH_8822C(x, v) \
(BIT_CLEAR_BE_FAST_EDCA_PKT_TH_8822C(x) | \
BIT_BE_FAST_EDCA_PKT_TH_8822C(v))
/* 2 REG_MACID_DROP0_8822C */
#define BIT_SHIFT_MACID31_0_DROP_8822C 0
#define BIT_MASK_MACID31_0_DROP_8822C 0xffffffffL
#define BIT_MACID31_0_DROP_8822C(x) \
(((x) & BIT_MASK_MACID31_0_DROP_8822C) \
<< BIT_SHIFT_MACID31_0_DROP_8822C)
#define BITS_MACID31_0_DROP_8822C \
(BIT_MASK_MACID31_0_DROP_8822C << BIT_SHIFT_MACID31_0_DROP_8822C)
#define BIT_CLEAR_MACID31_0_DROP_8822C(x) ((x) & (~BITS_MACID31_0_DROP_8822C))
#define BIT_GET_MACID31_0_DROP_8822C(x) \
(((x) >> BIT_SHIFT_MACID31_0_DROP_8822C) & \
BIT_MASK_MACID31_0_DROP_8822C)
#define BIT_SET_MACID31_0_DROP_8822C(x, v) \
(BIT_CLEAR_MACID31_0_DROP_8822C(x) | BIT_MACID31_0_DROP_8822C(v))
/* 2 REG_MACID_DROP1_8822C */
#define BIT_SHIFT_MACID63_32_DROP_8822C 0
#define BIT_MASK_MACID63_32_DROP_8822C 0xffffffffL
#define BIT_MACID63_32_DROP_8822C(x) \
(((x) & BIT_MASK_MACID63_32_DROP_8822C) \
<< BIT_SHIFT_MACID63_32_DROP_8822C)
#define BITS_MACID63_32_DROP_8822C \
(BIT_MASK_MACID63_32_DROP_8822C << BIT_SHIFT_MACID63_32_DROP_8822C)
#define BIT_CLEAR_MACID63_32_DROP_8822C(x) ((x) & (~BITS_MACID63_32_DROP_8822C))
#define BIT_GET_MACID63_32_DROP_8822C(x) \
(((x) >> BIT_SHIFT_MACID63_32_DROP_8822C) & \
BIT_MASK_MACID63_32_DROP_8822C)
#define BIT_SET_MACID63_32_DROP_8822C(x, v) \
(BIT_CLEAR_MACID63_32_DROP_8822C(x) | BIT_MACID63_32_DROP_8822C(v))
/* 2 REG_MACID_DROP2_8822C */
#define BIT_SHIFT_MACID95_64_DROP_8822C 0
#define BIT_MASK_MACID95_64_DROP_8822C 0xffffffffL
#define BIT_MACID95_64_DROP_8822C(x) \
(((x) & BIT_MASK_MACID95_64_DROP_8822C) \
<< BIT_SHIFT_MACID95_64_DROP_8822C)
#define BITS_MACID95_64_DROP_8822C \
(BIT_MASK_MACID95_64_DROP_8822C << BIT_SHIFT_MACID95_64_DROP_8822C)
#define BIT_CLEAR_MACID95_64_DROP_8822C(x) ((x) & (~BITS_MACID95_64_DROP_8822C))
#define BIT_GET_MACID95_64_DROP_8822C(x) \
(((x) >> BIT_SHIFT_MACID95_64_DROP_8822C) & \
BIT_MASK_MACID95_64_DROP_8822C)
#define BIT_SET_MACID95_64_DROP_8822C(x, v) \
(BIT_CLEAR_MACID95_64_DROP_8822C(x) | BIT_MACID95_64_DROP_8822C(v))
/* 2 REG_MACID_DROP3_8822C */
#define BIT_SHIFT_MACID127_96_DROP_8822C 0
#define BIT_MASK_MACID127_96_DROP_8822C 0xffffffffL
#define BIT_MACID127_96_DROP_8822C(x) \
(((x) & BIT_MASK_MACID127_96_DROP_8822C) \
<< BIT_SHIFT_MACID127_96_DROP_8822C)
#define BITS_MACID127_96_DROP_8822C \
(BIT_MASK_MACID127_96_DROP_8822C << BIT_SHIFT_MACID127_96_DROP_8822C)
#define BIT_CLEAR_MACID127_96_DROP_8822C(x) \
((x) & (~BITS_MACID127_96_DROP_8822C))
#define BIT_GET_MACID127_96_DROP_8822C(x) \
(((x) >> BIT_SHIFT_MACID127_96_DROP_8822C) & \
BIT_MASK_MACID127_96_DROP_8822C)
#define BIT_SET_MACID127_96_DROP_8822C(x, v) \
(BIT_CLEAR_MACID127_96_DROP_8822C(x) | BIT_MACID127_96_DROP_8822C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_0_8822C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_0_8822C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822C)
#define BITS_R_MACID_RELEASE_SUCCESS_0_8822C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8822C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_0_8822C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_0_8822C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_0_8822C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_0_8822C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_0_8822C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_0_8822C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_0_8822C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_1_8822C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_1_8822C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822C)
#define BITS_R_MACID_RELEASE_SUCCESS_1_8822C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8822C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_1_8822C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_1_8822C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_1_8822C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_1_8822C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_1_8822C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_1_8822C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_1_8822C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_2_8822C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_2_8822C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822C)
#define BITS_R_MACID_RELEASE_SUCCESS_2_8822C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8822C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_2_8822C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_2_8822C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_2_8822C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_2_8822C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_2_8822C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_2_8822C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_2_8822C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_3_8822C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822C 0xffffffffL
#define BIT_R_MACID_RELEASE_SUCCESS_3_8822C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822C)
#define BITS_R_MACID_RELEASE_SUCCESS_3_8822C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8822C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_3_8822C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_3_8822C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_3_8822C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_3_8822C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_3_8822C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_3_8822C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_3_8822C(v))
/* 2 REG_MGQ_FIFO_WRITE_POINTER_8822C */
#define BIT_MGQ_FIFO_OV_8822C BIT(7)
#define BIT_MGQ_FIFO_WPTR_ERROR_8822C BIT(6)
#define BIT_EN_MGQ_FIFO_LIFETIME_8822C BIT(5)
#define BIT_SHIFT_MGQ_FIFO_WPTR_8822C 0
#define BIT_MASK_MGQ_FIFO_WPTR_8822C 0x1f
#define BIT_MGQ_FIFO_WPTR_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_WPTR_8822C) << BIT_SHIFT_MGQ_FIFO_WPTR_8822C)
#define BITS_MGQ_FIFO_WPTR_8822C \
(BIT_MASK_MGQ_FIFO_WPTR_8822C << BIT_SHIFT_MGQ_FIFO_WPTR_8822C)
#define BIT_CLEAR_MGQ_FIFO_WPTR_8822C(x) ((x) & (~BITS_MGQ_FIFO_WPTR_8822C))
#define BIT_GET_MGQ_FIFO_WPTR_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_WPTR_8822C) & BIT_MASK_MGQ_FIFO_WPTR_8822C)
#define BIT_SET_MGQ_FIFO_WPTR_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_WPTR_8822C(x) | BIT_MGQ_FIFO_WPTR_8822C(v))
/* 2 REG_MGQ_FIFO_READ_POINTER_8822C */
#define BIT_SHIFT_MGQ_FIFO_SIZE_8822C 14
#define BIT_MASK_MGQ_FIFO_SIZE_8822C 0x3
#define BIT_MGQ_FIFO_SIZE_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_SIZE_8822C) << BIT_SHIFT_MGQ_FIFO_SIZE_8822C)
#define BITS_MGQ_FIFO_SIZE_8822C \
(BIT_MASK_MGQ_FIFO_SIZE_8822C << BIT_SHIFT_MGQ_FIFO_SIZE_8822C)
#define BIT_CLEAR_MGQ_FIFO_SIZE_8822C(x) ((x) & (~BITS_MGQ_FIFO_SIZE_8822C))
#define BIT_GET_MGQ_FIFO_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_SIZE_8822C) & BIT_MASK_MGQ_FIFO_SIZE_8822C)
#define BIT_SET_MGQ_FIFO_SIZE_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_SIZE_8822C(x) | BIT_MGQ_FIFO_SIZE_8822C(v))
#define BIT_MGQ_FIFO_PAUSE_8822C BIT(13)
#define BIT_SHIFT_MGQ_FIFO_RPTR_8822C 8
#define BIT_MASK_MGQ_FIFO_RPTR_8822C 0x1f
#define BIT_MGQ_FIFO_RPTR_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_RPTR_8822C) << BIT_SHIFT_MGQ_FIFO_RPTR_8822C)
#define BITS_MGQ_FIFO_RPTR_8822C \
(BIT_MASK_MGQ_FIFO_RPTR_8822C << BIT_SHIFT_MGQ_FIFO_RPTR_8822C)
#define BIT_CLEAR_MGQ_FIFO_RPTR_8822C(x) ((x) & (~BITS_MGQ_FIFO_RPTR_8822C))
#define BIT_GET_MGQ_FIFO_RPTR_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_RPTR_8822C) & BIT_MASK_MGQ_FIFO_RPTR_8822C)
#define BIT_SET_MGQ_FIFO_RPTR_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_RPTR_8822C(x) | BIT_MGQ_FIFO_RPTR_8822C(v))
/* 2 REG_MGQ_FIFO_ENABLE_8822C */
#define BIT_MGQ_FIFO_EN_8822C BIT(15)
#define BIT_SHIFT_MGQ_FIFO_PG_SIZE_8822C 12
#define BIT_MASK_MGQ_FIFO_PG_SIZE_8822C 0x7
#define BIT_MGQ_FIFO_PG_SIZE_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_PG_SIZE_8822C) \
<< BIT_SHIFT_MGQ_FIFO_PG_SIZE_8822C)
#define BITS_MGQ_FIFO_PG_SIZE_8822C \
(BIT_MASK_MGQ_FIFO_PG_SIZE_8822C << BIT_SHIFT_MGQ_FIFO_PG_SIZE_8822C)
#define BIT_CLEAR_MGQ_FIFO_PG_SIZE_8822C(x) \
((x) & (~BITS_MGQ_FIFO_PG_SIZE_8822C))
#define BIT_GET_MGQ_FIFO_PG_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PG_SIZE_8822C) & \
BIT_MASK_MGQ_FIFO_PG_SIZE_8822C)
#define BIT_SET_MGQ_FIFO_PG_SIZE_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_PG_SIZE_8822C(x) | BIT_MGQ_FIFO_PG_SIZE_8822C(v))
#define BIT_SHIFT_MGQ_FIFO_START_PG_8822C 0
#define BIT_MASK_MGQ_FIFO_START_PG_8822C 0xfff
#define BIT_MGQ_FIFO_START_PG_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_START_PG_8822C) \
<< BIT_SHIFT_MGQ_FIFO_START_PG_8822C)
#define BITS_MGQ_FIFO_START_PG_8822C \
(BIT_MASK_MGQ_FIFO_START_PG_8822C << BIT_SHIFT_MGQ_FIFO_START_PG_8822C)
#define BIT_CLEAR_MGQ_FIFO_START_PG_8822C(x) \
((x) & (~BITS_MGQ_FIFO_START_PG_8822C))
#define BIT_GET_MGQ_FIFO_START_PG_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_START_PG_8822C) & \
BIT_MASK_MGQ_FIFO_START_PG_8822C)
#define BIT_SET_MGQ_FIFO_START_PG_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_START_PG_8822C(x) | BIT_MGQ_FIFO_START_PG_8822C(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_MASK_8822C */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8822C 0
#define BIT_MASK_MGQ_FIFO_REL_INT_MASK_8822C 0xffff
#define BIT_MGQ_FIFO_REL_INT_MASK_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_MASK_8822C) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8822C)
#define BITS_MGQ_FIFO_REL_INT_MASK_8822C \
(BIT_MASK_MGQ_FIFO_REL_INT_MASK_8822C \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8822C)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_MASK_8822C(x) \
((x) & (~BITS_MGQ_FIFO_REL_INT_MASK_8822C))
#define BIT_GET_MGQ_FIFO_REL_INT_MASK_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_MASK_8822C) & \
BIT_MASK_MGQ_FIFO_REL_INT_MASK_8822C)
#define BIT_SET_MGQ_FIFO_REL_INT_MASK_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_MASK_8822C(x) | \
BIT_MGQ_FIFO_REL_INT_MASK_8822C(v))
/* 2 REG_MGQ_FIFO_RELEASE_INT_FLAG_8822C */
#define BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8822C 0
#define BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8822C 0xffff
#define BIT_MGQ_FIFO_REL_INT_FLAG_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8822C) \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8822C)
#define BITS_MGQ_FIFO_REL_INT_FLAG_8822C \
(BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8822C \
<< BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8822C)
#define BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG_8822C(x) \
((x) & (~BITS_MGQ_FIFO_REL_INT_FLAG_8822C))
#define BIT_GET_MGQ_FIFO_REL_INT_FLAG_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_REL_INT_FLAG_8822C) & \
BIT_MASK_MGQ_FIFO_REL_INT_FLAG_8822C)
#define BIT_SET_MGQ_FIFO_REL_INT_FLAG_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_REL_INT_FLAG_8822C(x) | \
BIT_MGQ_FIFO_REL_INT_FLAG_8822C(v))
/* 2 REG_MGQ_FIFO_VALID_MAP_8822C */
#define BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8822C 0
#define BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8822C 0xffff
#define BIT_MGQ_FIFO_PKT_VALID_MAP_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8822C) \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8822C)
#define BITS_MGQ_FIFO_PKT_VALID_MAP_8822C \
(BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8822C \
<< BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8822C)
#define BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP_8822C(x) \
((x) & (~BITS_MGQ_FIFO_PKT_VALID_MAP_8822C))
#define BIT_GET_MGQ_FIFO_PKT_VALID_MAP_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_PKT_VALID_MAP_8822C) & \
BIT_MASK_MGQ_FIFO_PKT_VALID_MAP_8822C)
#define BIT_SET_MGQ_FIFO_PKT_VALID_MAP_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_PKT_VALID_MAP_8822C(x) | \
BIT_MGQ_FIFO_PKT_VALID_MAP_8822C(v))
/* 2 REG_MGQ_FIFO_LIFETIME_8822C */
#define BIT_SHIFT_MGQ_FIFO_LIFETIME_8822C 0
#define BIT_MASK_MGQ_FIFO_LIFETIME_8822C 0xffff
#define BIT_MGQ_FIFO_LIFETIME_8822C(x) \
(((x) & BIT_MASK_MGQ_FIFO_LIFETIME_8822C) \
<< BIT_SHIFT_MGQ_FIFO_LIFETIME_8822C)
#define BITS_MGQ_FIFO_LIFETIME_8822C \
(BIT_MASK_MGQ_FIFO_LIFETIME_8822C << BIT_SHIFT_MGQ_FIFO_LIFETIME_8822C)
#define BIT_CLEAR_MGQ_FIFO_LIFETIME_8822C(x) \
((x) & (~BITS_MGQ_FIFO_LIFETIME_8822C))
#define BIT_GET_MGQ_FIFO_LIFETIME_8822C(x) \
(((x) >> BIT_SHIFT_MGQ_FIFO_LIFETIME_8822C) & \
BIT_MASK_MGQ_FIFO_LIFETIME_8822C)
#define BIT_SET_MGQ_FIFO_LIFETIME_8822C(x, v) \
(BIT_CLEAR_MGQ_FIFO_LIFETIME_8822C(x) | BIT_MGQ_FIFO_LIFETIME_8822C(v))
/* 2 REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C */
#define BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C 0
#define BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C 0x7f
#define BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C(x) \
(((x) & BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C) \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C)
#define BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C \
(BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C \
<< BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C)
#define BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C(x) \
((x) & (~BITS_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C))
#define BIT_GET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C) & \
BIT_MASK_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C)
#define BIT_SET_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C(x, v) \
(BIT_CLEAR_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C(x) | \
BIT_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C(v))
/* 2 REG_SHCUT_SETTING_8822C */
/* 2 REG_SHCUT_LLC_ETH_TYPE0_8822C */
/* 2 REG_SHCUT_LLC_ETH_TYPE1_8822C */
/* 2 REG_SHCUT_LLC_OUI0_8822C */
/* 2 REG_SHCUT_LLC_OUI1_8822C */
/* 2 REG_SHCUT_LLC_OUI2_8822C */
/* 2 REG_MU_TX_CTL_8822C */
#define BIT_R_MU_P1_WAIT_STATE_EN_8822C BIT(16)
#define BIT_SHIFT_R_MU_RL_8822C 12
#define BIT_MASK_R_MU_RL_8822C 0xf
#define BIT_R_MU_RL_8822C(x) \
(((x) & BIT_MASK_R_MU_RL_8822C) << BIT_SHIFT_R_MU_RL_8822C)
#define BITS_R_MU_RL_8822C (BIT_MASK_R_MU_RL_8822C << BIT_SHIFT_R_MU_RL_8822C)
#define BIT_CLEAR_R_MU_RL_8822C(x) ((x) & (~BITS_R_MU_RL_8822C))
#define BIT_GET_R_MU_RL_8822C(x) \
(((x) >> BIT_SHIFT_R_MU_RL_8822C) & BIT_MASK_R_MU_RL_8822C)
#define BIT_SET_R_MU_RL_8822C(x, v) \
(BIT_CLEAR_R_MU_RL_8822C(x) | BIT_R_MU_RL_8822C(v))
#define BIT_R_FORCE_P1_RATEDOWN_8822C BIT(11)
#define BIT_SHIFT_R_MU_TAB_SEL_8822C 8
#define BIT_MASK_R_MU_TAB_SEL_8822C 0x7
#define BIT_R_MU_TAB_SEL_8822C(x) \
(((x) & BIT_MASK_R_MU_TAB_SEL_8822C) << BIT_SHIFT_R_MU_TAB_SEL_8822C)
#define BITS_R_MU_TAB_SEL_8822C \
(BIT_MASK_R_MU_TAB_SEL_8822C << BIT_SHIFT_R_MU_TAB_SEL_8822C)
#define BIT_CLEAR_R_MU_TAB_SEL_8822C(x) ((x) & (~BITS_R_MU_TAB_SEL_8822C))
#define BIT_GET_R_MU_TAB_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_MU_TAB_SEL_8822C) & BIT_MASK_R_MU_TAB_SEL_8822C)
#define BIT_SET_R_MU_TAB_SEL_8822C(x, v) \
(BIT_CLEAR_R_MU_TAB_SEL_8822C(x) | BIT_R_MU_TAB_SEL_8822C(v))
#define BIT_R_EN_MU_MIMO_8822C BIT(7)
#define BIT_R_EN_REVERS_GTAB_8822C BIT(6)
#define BIT_SHIFT_R_MU_TABLE_VALID_8822C 0
#define BIT_MASK_R_MU_TABLE_VALID_8822C 0x3f
#define BIT_R_MU_TABLE_VALID_8822C(x) \
(((x) & BIT_MASK_R_MU_TABLE_VALID_8822C) \
<< BIT_SHIFT_R_MU_TABLE_VALID_8822C)
#define BITS_R_MU_TABLE_VALID_8822C \
(BIT_MASK_R_MU_TABLE_VALID_8822C << BIT_SHIFT_R_MU_TABLE_VALID_8822C)
#define BIT_CLEAR_R_MU_TABLE_VALID_8822C(x) \
((x) & (~BITS_R_MU_TABLE_VALID_8822C))
#define BIT_GET_R_MU_TABLE_VALID_8822C(x) \
(((x) >> BIT_SHIFT_R_MU_TABLE_VALID_8822C) & \
BIT_MASK_R_MU_TABLE_VALID_8822C)
#define BIT_SET_R_MU_TABLE_VALID_8822C(x, v) \
(BIT_CLEAR_R_MU_TABLE_VALID_8822C(x) | BIT_R_MU_TABLE_VALID_8822C(v))
/* 2 REG_MU_STA_GID_VLD_8822C */
#define BIT_SHIFT_R_MU_STA_GTAB_VALID_8822C 0
#define BIT_MASK_R_MU_STA_GTAB_VALID_8822C 0xffffffffL
#define BIT_R_MU_STA_GTAB_VALID_8822C(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_VALID_8822C) \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822C)
#define BITS_R_MU_STA_GTAB_VALID_8822C \
(BIT_MASK_R_MU_STA_GTAB_VALID_8822C \
<< BIT_SHIFT_R_MU_STA_GTAB_VALID_8822C)
#define BIT_CLEAR_R_MU_STA_GTAB_VALID_8822C(x) \
((x) & (~BITS_R_MU_STA_GTAB_VALID_8822C))
#define BIT_GET_R_MU_STA_GTAB_VALID_8822C(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_VALID_8822C) & \
BIT_MASK_R_MU_STA_GTAB_VALID_8822C)
#define BIT_SET_R_MU_STA_GTAB_VALID_8822C(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_VALID_8822C(x) | \
BIT_R_MU_STA_GTAB_VALID_8822C(v))
/* 2 REG_MU_STA_USER_POS_INFO_8822C */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8822C 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_L_8822C 0xffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_L_8822C(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_L_8822C) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8822C)
#define BITS_R_MU_STA_GTAB_POSITION_L_8822C \
(BIT_MASK_R_MU_STA_GTAB_POSITION_L_8822C \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8822C)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_L_8822C(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_L_8822C))
#define BIT_GET_R_MU_STA_GTAB_POSITION_L_8822C(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_L_8822C) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_L_8822C)
#define BIT_SET_R_MU_STA_GTAB_POSITION_L_8822C(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_L_8822C(x) | \
BIT_R_MU_STA_GTAB_POSITION_L_8822C(v))
/* 2 REG_MU_STA_USER_POS_INFO_H_8822C */
#define BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8822C 0
#define BIT_MASK_R_MU_STA_GTAB_POSITION_H_8822C 0xffffffffL
#define BIT_R_MU_STA_GTAB_POSITION_H_8822C(x) \
(((x) & BIT_MASK_R_MU_STA_GTAB_POSITION_H_8822C) \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8822C)
#define BITS_R_MU_STA_GTAB_POSITION_H_8822C \
(BIT_MASK_R_MU_STA_GTAB_POSITION_H_8822C \
<< BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8822C)
#define BIT_CLEAR_R_MU_STA_GTAB_POSITION_H_8822C(x) \
((x) & (~BITS_R_MU_STA_GTAB_POSITION_H_8822C))
#define BIT_GET_R_MU_STA_GTAB_POSITION_H_8822C(x) \
(((x) >> BIT_SHIFT_R_MU_STA_GTAB_POSITION_H_8822C) & \
BIT_MASK_R_MU_STA_GTAB_POSITION_H_8822C)
#define BIT_SET_R_MU_STA_GTAB_POSITION_H_8822C(x, v) \
(BIT_CLEAR_R_MU_STA_GTAB_POSITION_H_8822C(x) | \
BIT_R_MU_STA_GTAB_POSITION_H_8822C(v))
/* 2 REG_CHNL_INFO_CTRL_8822C */
#define BIT_CHNL_REF_RXNAV_8822C BIT(7)
#define BIT_CHNL_REF_VBON_8822C BIT(6)
#define BIT_CHNL_REF_EDCA_8822C BIT(5)
#define BIT_CHNL_REF_CCA_8822C BIT(4)
#define BIT_RST_CHNL_BUSY_8822C BIT(3)
#define BIT_RST_CHNL_IDLE_8822C BIT(2)
#define BIT_CHNL_INFO_RST_8822C BIT(1)
#define BIT_ATM_AIRTIME_EN_8822C BIT(0)
/* 2 REG_CHNL_IDLE_TIME_8822C */
#define BIT_SHIFT_CHNL_IDLE_TIME_8822C 0
#define BIT_MASK_CHNL_IDLE_TIME_8822C 0xffffffffL
#define BIT_CHNL_IDLE_TIME_8822C(x) \
(((x) & BIT_MASK_CHNL_IDLE_TIME_8822C) \
<< BIT_SHIFT_CHNL_IDLE_TIME_8822C)
#define BITS_CHNL_IDLE_TIME_8822C \
(BIT_MASK_CHNL_IDLE_TIME_8822C << BIT_SHIFT_CHNL_IDLE_TIME_8822C)
#define BIT_CLEAR_CHNL_IDLE_TIME_8822C(x) ((x) & (~BITS_CHNL_IDLE_TIME_8822C))
#define BIT_GET_CHNL_IDLE_TIME_8822C(x) \
(((x) >> BIT_SHIFT_CHNL_IDLE_TIME_8822C) & \
BIT_MASK_CHNL_IDLE_TIME_8822C)
#define BIT_SET_CHNL_IDLE_TIME_8822C(x, v) \
(BIT_CLEAR_CHNL_IDLE_TIME_8822C(x) | BIT_CHNL_IDLE_TIME_8822C(v))
/* 2 REG_CHNL_BUSY_TIME_8822C */
#define BIT_SHIFT_CHNL_BUSY_TIME_8822C 0
#define BIT_MASK_CHNL_BUSY_TIME_8822C 0xffffffffL
#define BIT_CHNL_BUSY_TIME_8822C(x) \
(((x) & BIT_MASK_CHNL_BUSY_TIME_8822C) \
<< BIT_SHIFT_CHNL_BUSY_TIME_8822C)
#define BITS_CHNL_BUSY_TIME_8822C \
(BIT_MASK_CHNL_BUSY_TIME_8822C << BIT_SHIFT_CHNL_BUSY_TIME_8822C)
#define BIT_CLEAR_CHNL_BUSY_TIME_8822C(x) ((x) & (~BITS_CHNL_BUSY_TIME_8822C))
#define BIT_GET_CHNL_BUSY_TIME_8822C(x) \
(((x) >> BIT_SHIFT_CHNL_BUSY_TIME_8822C) & \
BIT_MASK_CHNL_BUSY_TIME_8822C)
#define BIT_SET_CHNL_BUSY_TIME_8822C(x, v) \
(BIT_CLEAR_CHNL_BUSY_TIME_8822C(x) | BIT_CHNL_BUSY_TIME_8822C(v))
/* 2 REG_MU_TRX_DBG_CNT_V1_8822C */
#define BIT_MU_DNGCNT_RST_8822C BIT(20)
#define BIT_SHIFT_MU_DNGCNT_SEL_8822C 16
#define BIT_MASK_MU_DNGCNT_SEL_8822C 0xf
#define BIT_MU_DNGCNT_SEL_8822C(x) \
(((x) & BIT_MASK_MU_DNGCNT_SEL_8822C) << BIT_SHIFT_MU_DNGCNT_SEL_8822C)
#define BITS_MU_DNGCNT_SEL_8822C \
(BIT_MASK_MU_DNGCNT_SEL_8822C << BIT_SHIFT_MU_DNGCNT_SEL_8822C)
#define BIT_CLEAR_MU_DNGCNT_SEL_8822C(x) ((x) & (~BITS_MU_DNGCNT_SEL_8822C))
#define BIT_GET_MU_DNGCNT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_SEL_8822C) & BIT_MASK_MU_DNGCNT_SEL_8822C)
#define BIT_SET_MU_DNGCNT_SEL_8822C(x, v) \
(BIT_CLEAR_MU_DNGCNT_SEL_8822C(x) | BIT_MU_DNGCNT_SEL_8822C(v))
#define BIT_SHIFT_MU_DNGCNT_8822C 0
#define BIT_MASK_MU_DNGCNT_8822C 0xffff
#define BIT_MU_DNGCNT_8822C(x) \
(((x) & BIT_MASK_MU_DNGCNT_8822C) << BIT_SHIFT_MU_DNGCNT_8822C)
#define BITS_MU_DNGCNT_8822C \
(BIT_MASK_MU_DNGCNT_8822C << BIT_SHIFT_MU_DNGCNT_8822C)
#define BIT_CLEAR_MU_DNGCNT_8822C(x) ((x) & (~BITS_MU_DNGCNT_8822C))
#define BIT_GET_MU_DNGCNT_8822C(x) \
(((x) >> BIT_SHIFT_MU_DNGCNT_8822C) & BIT_MASK_MU_DNGCNT_8822C)
#define BIT_SET_MU_DNGCNT_8822C(x, v) \
(BIT_CLEAR_MU_DNGCNT_8822C(x) | BIT_MU_DNGCNT_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_EDCA_VO_PARAM_8822C */
#define BIT_SHIFT_TXOPLIMIT_8822C 16
#define BIT_MASK_TXOPLIMIT_8822C 0x7ff
#define BIT_TXOPLIMIT_8822C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822C) << BIT_SHIFT_TXOPLIMIT_8822C)
#define BITS_TXOPLIMIT_8822C \
(BIT_MASK_TXOPLIMIT_8822C << BIT_SHIFT_TXOPLIMIT_8822C)
#define BIT_CLEAR_TXOPLIMIT_8822C(x) ((x) & (~BITS_TXOPLIMIT_8822C))
#define BIT_GET_TXOPLIMIT_8822C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822C) & BIT_MASK_TXOPLIMIT_8822C)
#define BIT_SET_TXOPLIMIT_8822C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822C(x) | BIT_TXOPLIMIT_8822C(v))
#define BIT_SHIFT_CW_8822C 8
#define BIT_MASK_CW_8822C 0xff
#define BIT_CW_8822C(x) (((x) & BIT_MASK_CW_8822C) << BIT_SHIFT_CW_8822C)
#define BITS_CW_8822C (BIT_MASK_CW_8822C << BIT_SHIFT_CW_8822C)
#define BIT_CLEAR_CW_8822C(x) ((x) & (~BITS_CW_8822C))
#define BIT_GET_CW_8822C(x) (((x) >> BIT_SHIFT_CW_8822C) & BIT_MASK_CW_8822C)
#define BIT_SET_CW_8822C(x, v) (BIT_CLEAR_CW_8822C(x) | BIT_CW_8822C(v))
#define BIT_SHIFT_AIFS_8822C 0
#define BIT_MASK_AIFS_8822C 0xff
#define BIT_AIFS_8822C(x) (((x) & BIT_MASK_AIFS_8822C) << BIT_SHIFT_AIFS_8822C)
#define BITS_AIFS_8822C (BIT_MASK_AIFS_8822C << BIT_SHIFT_AIFS_8822C)
#define BIT_CLEAR_AIFS_8822C(x) ((x) & (~BITS_AIFS_8822C))
#define BIT_GET_AIFS_8822C(x) \
(((x) >> BIT_SHIFT_AIFS_8822C) & BIT_MASK_AIFS_8822C)
#define BIT_SET_AIFS_8822C(x, v) (BIT_CLEAR_AIFS_8822C(x) | BIT_AIFS_8822C(v))
/* 2 REG_EDCA_VI_PARAM_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_TXOPLIMIT_8822C 16
#define BIT_MASK_TXOPLIMIT_8822C 0x7ff
#define BIT_TXOPLIMIT_8822C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822C) << BIT_SHIFT_TXOPLIMIT_8822C)
#define BITS_TXOPLIMIT_8822C \
(BIT_MASK_TXOPLIMIT_8822C << BIT_SHIFT_TXOPLIMIT_8822C)
#define BIT_CLEAR_TXOPLIMIT_8822C(x) ((x) & (~BITS_TXOPLIMIT_8822C))
#define BIT_GET_TXOPLIMIT_8822C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822C) & BIT_MASK_TXOPLIMIT_8822C)
#define BIT_SET_TXOPLIMIT_8822C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822C(x) | BIT_TXOPLIMIT_8822C(v))
#define BIT_SHIFT_CW_8822C 8
#define BIT_MASK_CW_8822C 0xff
#define BIT_CW_8822C(x) (((x) & BIT_MASK_CW_8822C) << BIT_SHIFT_CW_8822C)
#define BITS_CW_8822C (BIT_MASK_CW_8822C << BIT_SHIFT_CW_8822C)
#define BIT_CLEAR_CW_8822C(x) ((x) & (~BITS_CW_8822C))
#define BIT_GET_CW_8822C(x) (((x) >> BIT_SHIFT_CW_8822C) & BIT_MASK_CW_8822C)
#define BIT_SET_CW_8822C(x, v) (BIT_CLEAR_CW_8822C(x) | BIT_CW_8822C(v))
#define BIT_SHIFT_AIFS_8822C 0
#define BIT_MASK_AIFS_8822C 0xff
#define BIT_AIFS_8822C(x) (((x) & BIT_MASK_AIFS_8822C) << BIT_SHIFT_AIFS_8822C)
#define BITS_AIFS_8822C (BIT_MASK_AIFS_8822C << BIT_SHIFT_AIFS_8822C)
#define BIT_CLEAR_AIFS_8822C(x) ((x) & (~BITS_AIFS_8822C))
#define BIT_GET_AIFS_8822C(x) \
(((x) >> BIT_SHIFT_AIFS_8822C) & BIT_MASK_AIFS_8822C)
#define BIT_SET_AIFS_8822C(x, v) (BIT_CLEAR_AIFS_8822C(x) | BIT_AIFS_8822C(v))
/* 2 REG_EDCA_BE_PARAM_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_TXOPLIMIT_8822C 16
#define BIT_MASK_TXOPLIMIT_8822C 0x7ff
#define BIT_TXOPLIMIT_8822C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822C) << BIT_SHIFT_TXOPLIMIT_8822C)
#define BITS_TXOPLIMIT_8822C \
(BIT_MASK_TXOPLIMIT_8822C << BIT_SHIFT_TXOPLIMIT_8822C)
#define BIT_CLEAR_TXOPLIMIT_8822C(x) ((x) & (~BITS_TXOPLIMIT_8822C))
#define BIT_GET_TXOPLIMIT_8822C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822C) & BIT_MASK_TXOPLIMIT_8822C)
#define BIT_SET_TXOPLIMIT_8822C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822C(x) | BIT_TXOPLIMIT_8822C(v))
#define BIT_SHIFT_CW_8822C 8
#define BIT_MASK_CW_8822C 0xff
#define BIT_CW_8822C(x) (((x) & BIT_MASK_CW_8822C) << BIT_SHIFT_CW_8822C)
#define BITS_CW_8822C (BIT_MASK_CW_8822C << BIT_SHIFT_CW_8822C)
#define BIT_CLEAR_CW_8822C(x) ((x) & (~BITS_CW_8822C))
#define BIT_GET_CW_8822C(x) (((x) >> BIT_SHIFT_CW_8822C) & BIT_MASK_CW_8822C)
#define BIT_SET_CW_8822C(x, v) (BIT_CLEAR_CW_8822C(x) | BIT_CW_8822C(v))
#define BIT_SHIFT_AIFS_8822C 0
#define BIT_MASK_AIFS_8822C 0xff
#define BIT_AIFS_8822C(x) (((x) & BIT_MASK_AIFS_8822C) << BIT_SHIFT_AIFS_8822C)
#define BITS_AIFS_8822C (BIT_MASK_AIFS_8822C << BIT_SHIFT_AIFS_8822C)
#define BIT_CLEAR_AIFS_8822C(x) ((x) & (~BITS_AIFS_8822C))
#define BIT_GET_AIFS_8822C(x) \
(((x) >> BIT_SHIFT_AIFS_8822C) & BIT_MASK_AIFS_8822C)
#define BIT_SET_AIFS_8822C(x, v) (BIT_CLEAR_AIFS_8822C(x) | BIT_AIFS_8822C(v))
/* 2 REG_EDCA_BK_PARAM_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_TXOPLIMIT_8822C 16
#define BIT_MASK_TXOPLIMIT_8822C 0x7ff
#define BIT_TXOPLIMIT_8822C(x) \
(((x) & BIT_MASK_TXOPLIMIT_8822C) << BIT_SHIFT_TXOPLIMIT_8822C)
#define BITS_TXOPLIMIT_8822C \
(BIT_MASK_TXOPLIMIT_8822C << BIT_SHIFT_TXOPLIMIT_8822C)
#define BIT_CLEAR_TXOPLIMIT_8822C(x) ((x) & (~BITS_TXOPLIMIT_8822C))
#define BIT_GET_TXOPLIMIT_8822C(x) \
(((x) >> BIT_SHIFT_TXOPLIMIT_8822C) & BIT_MASK_TXOPLIMIT_8822C)
#define BIT_SET_TXOPLIMIT_8822C(x, v) \
(BIT_CLEAR_TXOPLIMIT_8822C(x) | BIT_TXOPLIMIT_8822C(v))
#define BIT_SHIFT_CW_8822C 8
#define BIT_MASK_CW_8822C 0xff
#define BIT_CW_8822C(x) (((x) & BIT_MASK_CW_8822C) << BIT_SHIFT_CW_8822C)
#define BITS_CW_8822C (BIT_MASK_CW_8822C << BIT_SHIFT_CW_8822C)
#define BIT_CLEAR_CW_8822C(x) ((x) & (~BITS_CW_8822C))
#define BIT_GET_CW_8822C(x) (((x) >> BIT_SHIFT_CW_8822C) & BIT_MASK_CW_8822C)
#define BIT_SET_CW_8822C(x, v) (BIT_CLEAR_CW_8822C(x) | BIT_CW_8822C(v))
#define BIT_SHIFT_AIFS_8822C 0
#define BIT_MASK_AIFS_8822C 0xff
#define BIT_AIFS_8822C(x) (((x) & BIT_MASK_AIFS_8822C) << BIT_SHIFT_AIFS_8822C)
#define BITS_AIFS_8822C (BIT_MASK_AIFS_8822C << BIT_SHIFT_AIFS_8822C)
#define BIT_CLEAR_AIFS_8822C(x) ((x) & (~BITS_AIFS_8822C))
#define BIT_GET_AIFS_8822C(x) \
(((x) >> BIT_SHIFT_AIFS_8822C) & BIT_MASK_AIFS_8822C)
#define BIT_SET_AIFS_8822C(x, v) (BIT_CLEAR_AIFS_8822C(x) | BIT_AIFS_8822C(v))
/* 2 REG_BCNTCFG_8822C */
#define BIT_SHIFT_BCNCW_MAX_8822C 12
#define BIT_MASK_BCNCW_MAX_8822C 0xf
#define BIT_BCNCW_MAX_8822C(x) \
(((x) & BIT_MASK_BCNCW_MAX_8822C) << BIT_SHIFT_BCNCW_MAX_8822C)
#define BITS_BCNCW_MAX_8822C \
(BIT_MASK_BCNCW_MAX_8822C << BIT_SHIFT_BCNCW_MAX_8822C)
#define BIT_CLEAR_BCNCW_MAX_8822C(x) ((x) & (~BITS_BCNCW_MAX_8822C))
#define BIT_GET_BCNCW_MAX_8822C(x) \
(((x) >> BIT_SHIFT_BCNCW_MAX_8822C) & BIT_MASK_BCNCW_MAX_8822C)
#define BIT_SET_BCNCW_MAX_8822C(x, v) \
(BIT_CLEAR_BCNCW_MAX_8822C(x) | BIT_BCNCW_MAX_8822C(v))
#define BIT_SHIFT_BCNCW_MIN_8822C 8
#define BIT_MASK_BCNCW_MIN_8822C 0xf
#define BIT_BCNCW_MIN_8822C(x) \
(((x) & BIT_MASK_BCNCW_MIN_8822C) << BIT_SHIFT_BCNCW_MIN_8822C)
#define BITS_BCNCW_MIN_8822C \
(BIT_MASK_BCNCW_MIN_8822C << BIT_SHIFT_BCNCW_MIN_8822C)
#define BIT_CLEAR_BCNCW_MIN_8822C(x) ((x) & (~BITS_BCNCW_MIN_8822C))
#define BIT_GET_BCNCW_MIN_8822C(x) \
(((x) >> BIT_SHIFT_BCNCW_MIN_8822C) & BIT_MASK_BCNCW_MIN_8822C)
#define BIT_SET_BCNCW_MIN_8822C(x, v) \
(BIT_CLEAR_BCNCW_MIN_8822C(x) | BIT_BCNCW_MIN_8822C(v))
#define BIT_SHIFT_BCNIFS_8822C 0
#define BIT_MASK_BCNIFS_8822C 0xff
#define BIT_BCNIFS_8822C(x) \
(((x) & BIT_MASK_BCNIFS_8822C) << BIT_SHIFT_BCNIFS_8822C)
#define BITS_BCNIFS_8822C (BIT_MASK_BCNIFS_8822C << BIT_SHIFT_BCNIFS_8822C)
#define BIT_CLEAR_BCNIFS_8822C(x) ((x) & (~BITS_BCNIFS_8822C))
#define BIT_GET_BCNIFS_8822C(x) \
(((x) >> BIT_SHIFT_BCNIFS_8822C) & BIT_MASK_BCNIFS_8822C)
#define BIT_SET_BCNIFS_8822C(x, v) \
(BIT_CLEAR_BCNIFS_8822C(x) | BIT_BCNIFS_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_PIFS_8822C */
#define BIT_SHIFT_PIFS_8822C 0
#define BIT_MASK_PIFS_8822C 0xff
#define BIT_PIFS_8822C(x) (((x) & BIT_MASK_PIFS_8822C) << BIT_SHIFT_PIFS_8822C)
#define BITS_PIFS_8822C (BIT_MASK_PIFS_8822C << BIT_SHIFT_PIFS_8822C)
#define BIT_CLEAR_PIFS_8822C(x) ((x) & (~BITS_PIFS_8822C))
#define BIT_GET_PIFS_8822C(x) \
(((x) >> BIT_SHIFT_PIFS_8822C) & BIT_MASK_PIFS_8822C)
#define BIT_SET_PIFS_8822C(x, v) (BIT_CLEAR_PIFS_8822C(x) | BIT_PIFS_8822C(v))
/* 2 REG_RDG_PIFS_8822C */
#define BIT_SHIFT_RDG_PIFS_8822C 0
#define BIT_MASK_RDG_PIFS_8822C 0xff
#define BIT_RDG_PIFS_8822C(x) \
(((x) & BIT_MASK_RDG_PIFS_8822C) << BIT_SHIFT_RDG_PIFS_8822C)
#define BITS_RDG_PIFS_8822C \
(BIT_MASK_RDG_PIFS_8822C << BIT_SHIFT_RDG_PIFS_8822C)
#define BIT_CLEAR_RDG_PIFS_8822C(x) ((x) & (~BITS_RDG_PIFS_8822C))
#define BIT_GET_RDG_PIFS_8822C(x) \
(((x) >> BIT_SHIFT_RDG_PIFS_8822C) & BIT_MASK_RDG_PIFS_8822C)
#define BIT_SET_RDG_PIFS_8822C(x, v) \
(BIT_CLEAR_RDG_PIFS_8822C(x) | BIT_RDG_PIFS_8822C(v))
/* 2 REG_SIFS_8822C */
#define BIT_SHIFT_SIFS_OFDM_TRX_8822C 24
#define BIT_MASK_SIFS_OFDM_TRX_8822C 0xff
#define BIT_SIFS_OFDM_TRX_8822C(x) \
(((x) & BIT_MASK_SIFS_OFDM_TRX_8822C) << BIT_SHIFT_SIFS_OFDM_TRX_8822C)
#define BITS_SIFS_OFDM_TRX_8822C \
(BIT_MASK_SIFS_OFDM_TRX_8822C << BIT_SHIFT_SIFS_OFDM_TRX_8822C)
#define BIT_CLEAR_SIFS_OFDM_TRX_8822C(x) ((x) & (~BITS_SIFS_OFDM_TRX_8822C))
#define BIT_GET_SIFS_OFDM_TRX_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_TRX_8822C) & BIT_MASK_SIFS_OFDM_TRX_8822C)
#define BIT_SET_SIFS_OFDM_TRX_8822C(x, v) \
(BIT_CLEAR_SIFS_OFDM_TRX_8822C(x) | BIT_SIFS_OFDM_TRX_8822C(v))
#define BIT_SHIFT_SIFS_CCK_TRX_8822C 16
#define BIT_MASK_SIFS_CCK_TRX_8822C 0xff
#define BIT_SIFS_CCK_TRX_8822C(x) \
(((x) & BIT_MASK_SIFS_CCK_TRX_8822C) << BIT_SHIFT_SIFS_CCK_TRX_8822C)
#define BITS_SIFS_CCK_TRX_8822C \
(BIT_MASK_SIFS_CCK_TRX_8822C << BIT_SHIFT_SIFS_CCK_TRX_8822C)
#define BIT_CLEAR_SIFS_CCK_TRX_8822C(x) ((x) & (~BITS_SIFS_CCK_TRX_8822C))
#define BIT_GET_SIFS_CCK_TRX_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_TRX_8822C) & BIT_MASK_SIFS_CCK_TRX_8822C)
#define BIT_SET_SIFS_CCK_TRX_8822C(x, v) \
(BIT_CLEAR_SIFS_CCK_TRX_8822C(x) | BIT_SIFS_CCK_TRX_8822C(v))
#define BIT_SHIFT_SIFS_OFDM_CTX_8822C 8
#define BIT_MASK_SIFS_OFDM_CTX_8822C 0xff
#define BIT_SIFS_OFDM_CTX_8822C(x) \
(((x) & BIT_MASK_SIFS_OFDM_CTX_8822C) << BIT_SHIFT_SIFS_OFDM_CTX_8822C)
#define BITS_SIFS_OFDM_CTX_8822C \
(BIT_MASK_SIFS_OFDM_CTX_8822C << BIT_SHIFT_SIFS_OFDM_CTX_8822C)
#define BIT_CLEAR_SIFS_OFDM_CTX_8822C(x) ((x) & (~BITS_SIFS_OFDM_CTX_8822C))
#define BIT_GET_SIFS_OFDM_CTX_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_OFDM_CTX_8822C) & BIT_MASK_SIFS_OFDM_CTX_8822C)
#define BIT_SET_SIFS_OFDM_CTX_8822C(x, v) \
(BIT_CLEAR_SIFS_OFDM_CTX_8822C(x) | BIT_SIFS_OFDM_CTX_8822C(v))
#define BIT_SHIFT_SIFS_CCK_CTX_8822C 0
#define BIT_MASK_SIFS_CCK_CTX_8822C 0xff
#define BIT_SIFS_CCK_CTX_8822C(x) \
(((x) & BIT_MASK_SIFS_CCK_CTX_8822C) << BIT_SHIFT_SIFS_CCK_CTX_8822C)
#define BITS_SIFS_CCK_CTX_8822C \
(BIT_MASK_SIFS_CCK_CTX_8822C << BIT_SHIFT_SIFS_CCK_CTX_8822C)
#define BIT_CLEAR_SIFS_CCK_CTX_8822C(x) ((x) & (~BITS_SIFS_CCK_CTX_8822C))
#define BIT_GET_SIFS_CCK_CTX_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_CCK_CTX_8822C) & BIT_MASK_SIFS_CCK_CTX_8822C)
#define BIT_SET_SIFS_CCK_CTX_8822C(x, v) \
(BIT_CLEAR_SIFS_CCK_CTX_8822C(x) | BIT_SIFS_CCK_CTX_8822C(v))
/* 2 REG_TSFTR_SYN_OFFSET_8822C */
#define BIT_SHIFT_TSFTR_SNC_OFFSET_8822C 0
#define BIT_MASK_TSFTR_SNC_OFFSET_8822C 0xffff
#define BIT_TSFTR_SNC_OFFSET_8822C(x) \
(((x) & BIT_MASK_TSFTR_SNC_OFFSET_8822C) \
<< BIT_SHIFT_TSFTR_SNC_OFFSET_8822C)
#define BITS_TSFTR_SNC_OFFSET_8822C \
(BIT_MASK_TSFTR_SNC_OFFSET_8822C << BIT_SHIFT_TSFTR_SNC_OFFSET_8822C)
#define BIT_CLEAR_TSFTR_SNC_OFFSET_8822C(x) \
((x) & (~BITS_TSFTR_SNC_OFFSET_8822C))
#define BIT_GET_TSFTR_SNC_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_TSFTR_SNC_OFFSET_8822C) & \
BIT_MASK_TSFTR_SNC_OFFSET_8822C)
#define BIT_SET_TSFTR_SNC_OFFSET_8822C(x, v) \
(BIT_CLEAR_TSFTR_SNC_OFFSET_8822C(x) | BIT_TSFTR_SNC_OFFSET_8822C(v))
/* 2 REG_AGGR_BREAK_TIME_8822C */
#define BIT_SHIFT_AGGR_BK_TIME_8822C 0
#define BIT_MASK_AGGR_BK_TIME_8822C 0xff
#define BIT_AGGR_BK_TIME_8822C(x) \
(((x) & BIT_MASK_AGGR_BK_TIME_8822C) << BIT_SHIFT_AGGR_BK_TIME_8822C)
#define BITS_AGGR_BK_TIME_8822C \
(BIT_MASK_AGGR_BK_TIME_8822C << BIT_SHIFT_AGGR_BK_TIME_8822C)
#define BIT_CLEAR_AGGR_BK_TIME_8822C(x) ((x) & (~BITS_AGGR_BK_TIME_8822C))
#define BIT_GET_AGGR_BK_TIME_8822C(x) \
(((x) >> BIT_SHIFT_AGGR_BK_TIME_8822C) & BIT_MASK_AGGR_BK_TIME_8822C)
#define BIT_SET_AGGR_BK_TIME_8822C(x, v) \
(BIT_CLEAR_AGGR_BK_TIME_8822C(x) | BIT_AGGR_BK_TIME_8822C(v))
/* 2 REG_SLOT_8822C */
#define BIT_SHIFT_SLOT_8822C 0
#define BIT_MASK_SLOT_8822C 0xff
#define BIT_SLOT_8822C(x) (((x) & BIT_MASK_SLOT_8822C) << BIT_SHIFT_SLOT_8822C)
#define BITS_SLOT_8822C (BIT_MASK_SLOT_8822C << BIT_SHIFT_SLOT_8822C)
#define BIT_CLEAR_SLOT_8822C(x) ((x) & (~BITS_SLOT_8822C))
#define BIT_GET_SLOT_8822C(x) \
(((x) >> BIT_SHIFT_SLOT_8822C) & BIT_MASK_SLOT_8822C)
#define BIT_SET_SLOT_8822C(x, v) (BIT_CLEAR_SLOT_8822C(x) | BIT_SLOT_8822C(v))
/* 2 REG_NOA_ON_ERLY_TIME_8822C */
#define BIT_SHIFT__NOA_ON_ERLY_TIME_8822C 0
#define BIT_MASK__NOA_ON_ERLY_TIME_8822C 0xff
#define BIT__NOA_ON_ERLY_TIME_8822C(x) \
(((x) & BIT_MASK__NOA_ON_ERLY_TIME_8822C) \
<< BIT_SHIFT__NOA_ON_ERLY_TIME_8822C)
#define BITS__NOA_ON_ERLY_TIME_8822C \
(BIT_MASK__NOA_ON_ERLY_TIME_8822C << BIT_SHIFT__NOA_ON_ERLY_TIME_8822C)
#define BIT_CLEAR__NOA_ON_ERLY_TIME_8822C(x) \
((x) & (~BITS__NOA_ON_ERLY_TIME_8822C))
#define BIT_GET__NOA_ON_ERLY_TIME_8822C(x) \
(((x) >> BIT_SHIFT__NOA_ON_ERLY_TIME_8822C) & \
BIT_MASK__NOA_ON_ERLY_TIME_8822C)
#define BIT_SET__NOA_ON_ERLY_TIME_8822C(x, v) \
(BIT_CLEAR__NOA_ON_ERLY_TIME_8822C(x) | BIT__NOA_ON_ERLY_TIME_8822C(v))
/* 2 REG_NOA_OFF_ERLY_TIME_8822C */
#define BIT_SHIFT__NOA_OFF_ERLY_TIME_8822C 0
#define BIT_MASK__NOA_OFF_ERLY_TIME_8822C 0xff
#define BIT__NOA_OFF_ERLY_TIME_8822C(x) \
(((x) & BIT_MASK__NOA_OFF_ERLY_TIME_8822C) \
<< BIT_SHIFT__NOA_OFF_ERLY_TIME_8822C)
#define BITS__NOA_OFF_ERLY_TIME_8822C \
(BIT_MASK__NOA_OFF_ERLY_TIME_8822C \
<< BIT_SHIFT__NOA_OFF_ERLY_TIME_8822C)
#define BIT_CLEAR__NOA_OFF_ERLY_TIME_8822C(x) \
((x) & (~BITS__NOA_OFF_ERLY_TIME_8822C))
#define BIT_GET__NOA_OFF_ERLY_TIME_8822C(x) \
(((x) >> BIT_SHIFT__NOA_OFF_ERLY_TIME_8822C) & \
BIT_MASK__NOA_OFF_ERLY_TIME_8822C)
#define BIT_SET__NOA_OFF_ERLY_TIME_8822C(x, v) \
(BIT_CLEAR__NOA_OFF_ERLY_TIME_8822C(x) | \
BIT__NOA_OFF_ERLY_TIME_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_TX_PTCL_CTRL_8822C */
#define BIT_DIS_EDCCA_8822C BIT(15)
#define BIT_DIS_CCA_8822C BIT(14)
#define BIT_LSIG_TXOP_TXCMD_NAV_8822C BIT(13)
#define BIT_SIFS_BK_EN_8822C BIT(12)
#define BIT_SHIFT_TXQ_NAV_MSK_8822C 8
#define BIT_MASK_TXQ_NAV_MSK_8822C 0xf
#define BIT_TXQ_NAV_MSK_8822C(x) \
(((x) & BIT_MASK_TXQ_NAV_MSK_8822C) << BIT_SHIFT_TXQ_NAV_MSK_8822C)
#define BITS_TXQ_NAV_MSK_8822C \
(BIT_MASK_TXQ_NAV_MSK_8822C << BIT_SHIFT_TXQ_NAV_MSK_8822C)
#define BIT_CLEAR_TXQ_NAV_MSK_8822C(x) ((x) & (~BITS_TXQ_NAV_MSK_8822C))
#define BIT_GET_TXQ_NAV_MSK_8822C(x) \
(((x) >> BIT_SHIFT_TXQ_NAV_MSK_8822C) & BIT_MASK_TXQ_NAV_MSK_8822C)
#define BIT_SET_TXQ_NAV_MSK_8822C(x, v) \
(BIT_CLEAR_TXQ_NAV_MSK_8822C(x) | BIT_TXQ_NAV_MSK_8822C(v))
#define BIT_DIS_CW_8822C BIT(7)
#define BIT_NAV_END_TXOP_8822C BIT(6)
#define BIT_RDG_END_TXOP_8822C BIT(5)
#define BIT_AC_INBCN_HOLD_8822C BIT(4)
#define BIT_MGTQ_TXOP_EN_8822C BIT(3)
#define BIT_MGTQ_RTSMF_EN_8822C BIT(2)
#define BIT_HIQ_RTSMF_EN_8822C BIT(1)
#define BIT_BCN_RTSMF_EN_8822C BIT(0)
/* 2 REG_TXPAUSE_8822C */
#define BIT_STOP_BCN_HI_MGT_8822C BIT(7)
#define BIT_MAC_STOPBCNQ_8822C BIT(6)
#define BIT_MAC_STOPHIQ_8822C BIT(5)
#define BIT_MAC_STOPMGQ_8822C BIT(4)
#define BIT_MAC_STOPBK_8822C BIT(3)
#define BIT_MAC_STOPBE_8822C BIT(2)
#define BIT_MAC_STOPVI_8822C BIT(1)
#define BIT_MAC_STOPVO_8822C BIT(0)
/* 2 REG_DIS_TXREQ_CLR_8822C */
#define BIT_DIS_BT_CCA_8822C BIT(7)
#define BIT_DIS_TXREQ_CLR_HI_8822C BIT(5)
#define BIT_DIS_TXREQ_CLR_MGQ_8822C BIT(4)
#define BIT_DIS_TXREQ_CLR_VO_8822C BIT(3)
#define BIT_DIS_TXREQ_CLR_VI_8822C BIT(2)
#define BIT_DIS_TXREQ_CLR_BE_8822C BIT(1)
#define BIT_DIS_TXREQ_CLR_BK_8822C BIT(0)
/* 2 REG_RD_CTRL_8822C */
#define BIT_EN_CLR_TXREQ_INCCA_8822C BIT(15)
#define BIT_DIS_TX_OVER_BCNQ_8822C BIT(14)
#define BIT_EN_BCNERR_INCCCA_8822C BIT(13)
#define BIT_EDCCA_MSK_CNTDOWN_EN_8822C BIT(11)
#define BIT_DIS_TXOP_CFE_8822C BIT(10)
#define BIT_DIS_LSIG_CFE_8822C BIT(9)
#define BIT_DIS_STBC_CFE_8822C BIT(8)
#define BIT_BKQ_RD_INIT_EN_8822C BIT(7)
#define BIT_BEQ_RD_INIT_EN_8822C BIT(6)
#define BIT_VIQ_RD_INIT_EN_8822C BIT(5)
#define BIT_VOQ_RD_INIT_EN_8822C BIT(4)
#define BIT_BKQ_RD_RESP_EN_8822C BIT(3)
#define BIT_BEQ_RD_RESP_EN_8822C BIT(2)
#define BIT_VIQ_RD_RESP_EN_8822C BIT(1)
#define BIT_VOQ_RD_RESP_EN_8822C BIT(0)
/* 2 REG_MBSSID_CTRL_8822C */
#define BIT_MBID_BCNQ7_EN_8822C BIT(7)
#define BIT_MBID_BCNQ6_EN_8822C BIT(6)
#define BIT_MBID_BCNQ5_EN_8822C BIT(5)
#define BIT_MBID_BCNQ4_EN_8822C BIT(4)
#define BIT_MBID_BCNQ3_EN_8822C BIT(3)
#define BIT_MBID_BCNQ2_EN_8822C BIT(2)
#define BIT_MBID_BCNQ1_EN_8822C BIT(1)
#define BIT_MBID_BCNQ0_EN_8822C BIT(0)
/* 2 REG_P2PPS_CTRL_8822C */
#define BIT_P2P_CTW_ALLSTASLEEP_8822C BIT(7)
#define BIT_P2P_OFF_DISTX_EN_8822C BIT(6)
#define BIT_PWR_MGT_EN_8822C BIT(5)
#define BIT_P2P_NOA1_EN_8822C BIT(2)
#define BIT_P2P_NOA0_EN_8822C BIT(1)
/* 2 REG_PKT_LIFETIME_CTRL_8822C */
#define BIT_EN_P2P_CTWND1_8822C BIT(23)
#define BIT_EN_BKF_CLR_TXREQ_8822C BIT(22)
#define BIT_EN_TSFBIT32_RST_P2P_8822C BIT(21)
#define BIT_EN_BCN_TX_BTCCA_8822C BIT(20)
#define BIT_DIS_PKT_TX_ATIM_8822C BIT(19)
#define BIT_DIS_BCN_DIS_CTN_8822C BIT(18)
#define BIT_EN_NAVEND_RST_TXOP_8822C BIT(17)
#define BIT_EN_FILTER_CCA_8822C BIT(16)
#define BIT_SHIFT_CCA_FILTER_THRS_8822C 8
#define BIT_MASK_CCA_FILTER_THRS_8822C 0xff
#define BIT_CCA_FILTER_THRS_8822C(x) \
(((x) & BIT_MASK_CCA_FILTER_THRS_8822C) \
<< BIT_SHIFT_CCA_FILTER_THRS_8822C)
#define BITS_CCA_FILTER_THRS_8822C \
(BIT_MASK_CCA_FILTER_THRS_8822C << BIT_SHIFT_CCA_FILTER_THRS_8822C)
#define BIT_CLEAR_CCA_FILTER_THRS_8822C(x) ((x) & (~BITS_CCA_FILTER_THRS_8822C))
#define BIT_GET_CCA_FILTER_THRS_8822C(x) \
(((x) >> BIT_SHIFT_CCA_FILTER_THRS_8822C) & \
BIT_MASK_CCA_FILTER_THRS_8822C)
#define BIT_SET_CCA_FILTER_THRS_8822C(x, v) \
(BIT_CLEAR_CCA_FILTER_THRS_8822C(x) | BIT_CCA_FILTER_THRS_8822C(v))
#define BIT_SHIFT_EDCCA_THRS_8822C 0
#define BIT_MASK_EDCCA_THRS_8822C 0xff
#define BIT_EDCCA_THRS_8822C(x) \
(((x) & BIT_MASK_EDCCA_THRS_8822C) << BIT_SHIFT_EDCCA_THRS_8822C)
#define BITS_EDCCA_THRS_8822C \
(BIT_MASK_EDCCA_THRS_8822C << BIT_SHIFT_EDCCA_THRS_8822C)
#define BIT_CLEAR_EDCCA_THRS_8822C(x) ((x) & (~BITS_EDCCA_THRS_8822C))
#define BIT_GET_EDCCA_THRS_8822C(x) \
(((x) >> BIT_SHIFT_EDCCA_THRS_8822C) & BIT_MASK_EDCCA_THRS_8822C)
#define BIT_SET_EDCCA_THRS_8822C(x, v) \
(BIT_CLEAR_EDCCA_THRS_8822C(x) | BIT_EDCCA_THRS_8822C(v))
/* 2 REG_P2PPS_SPEC_STATE_8822C */
#define BIT_SPEC_POWER_STATE_8822C BIT(7)
#define BIT_SPEC_CTWINDOW_ON_8822C BIT(6)
#define BIT_SPEC_BEACON_AREA_ON_8822C BIT(5)
#define BIT_SPEC_CTWIN_EARLY_DISTX_8822C BIT(4)
#define BIT_SPEC_NOA1_OFF_PERIOD_8822C BIT(3)
#define BIT_SPEC_FORCE_DOZE1_8822C BIT(2)
#define BIT_SPEC_NOA0_OFF_PERIOD_8822C BIT(1)
#define BIT_SPEC_FORCE_DOZE0_8822C BIT(0)
/* 2 REG_TXOP_LIMIT_CTRL_8822C */
#define BIT_SHIFT_TXOP_TBTT_CNT_8822C 24
#define BIT_MASK_TXOP_TBTT_CNT_8822C 0xff
#define BIT_TXOP_TBTT_CNT_8822C(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_8822C) << BIT_SHIFT_TXOP_TBTT_CNT_8822C)
#define BITS_TXOP_TBTT_CNT_8822C \
(BIT_MASK_TXOP_TBTT_CNT_8822C << BIT_SHIFT_TXOP_TBTT_CNT_8822C)
#define BIT_CLEAR_TXOP_TBTT_CNT_8822C(x) ((x) & (~BITS_TXOP_TBTT_CNT_8822C))
#define BIT_GET_TXOP_TBTT_CNT_8822C(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_8822C) & BIT_MASK_TXOP_TBTT_CNT_8822C)
#define BIT_SET_TXOP_TBTT_CNT_8822C(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_8822C(x) | BIT_TXOP_TBTT_CNT_8822C(v))
#define BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822C 20
#define BIT_MASK_TXOP_TBTT_CNT_SEL_8822C 0xf
#define BIT_TXOP_TBTT_CNT_SEL_8822C(x) \
(((x) & BIT_MASK_TXOP_TBTT_CNT_SEL_8822C) \
<< BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822C)
#define BITS_TXOP_TBTT_CNT_SEL_8822C \
(BIT_MASK_TXOP_TBTT_CNT_SEL_8822C << BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822C)
#define BIT_CLEAR_TXOP_TBTT_CNT_SEL_8822C(x) \
((x) & (~BITS_TXOP_TBTT_CNT_SEL_8822C))
#define BIT_GET_TXOP_TBTT_CNT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_TXOP_TBTT_CNT_SEL_8822C) & \
BIT_MASK_TXOP_TBTT_CNT_SEL_8822C)
#define BIT_SET_TXOP_TBTT_CNT_SEL_8822C(x, v) \
(BIT_CLEAR_TXOP_TBTT_CNT_SEL_8822C(x) | BIT_TXOP_TBTT_CNT_SEL_8822C(v))
#define BIT_SHIFT_TXOP_LMT_EN_8822C 16
#define BIT_MASK_TXOP_LMT_EN_8822C 0xf
#define BIT_TXOP_LMT_EN_8822C(x) \
(((x) & BIT_MASK_TXOP_LMT_EN_8822C) << BIT_SHIFT_TXOP_LMT_EN_8822C)
#define BITS_TXOP_LMT_EN_8822C \
(BIT_MASK_TXOP_LMT_EN_8822C << BIT_SHIFT_TXOP_LMT_EN_8822C)
#define BIT_CLEAR_TXOP_LMT_EN_8822C(x) ((x) & (~BITS_TXOP_LMT_EN_8822C))
#define BIT_GET_TXOP_LMT_EN_8822C(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_EN_8822C) & BIT_MASK_TXOP_LMT_EN_8822C)
#define BIT_SET_TXOP_LMT_EN_8822C(x, v) \
(BIT_CLEAR_TXOP_LMT_EN_8822C(x) | BIT_TXOP_LMT_EN_8822C(v))
#define BIT_SHIFT_TXOP_LMT_TX_TIME_8822C 8
#define BIT_MASK_TXOP_LMT_TX_TIME_8822C 0xff
#define BIT_TXOP_LMT_TX_TIME_8822C(x) \
(((x) & BIT_MASK_TXOP_LMT_TX_TIME_8822C) \
<< BIT_SHIFT_TXOP_LMT_TX_TIME_8822C)
#define BITS_TXOP_LMT_TX_TIME_8822C \
(BIT_MASK_TXOP_LMT_TX_TIME_8822C << BIT_SHIFT_TXOP_LMT_TX_TIME_8822C)
#define BIT_CLEAR_TXOP_LMT_TX_TIME_8822C(x) \
((x) & (~BITS_TXOP_LMT_TX_TIME_8822C))
#define BIT_GET_TXOP_LMT_TX_TIME_8822C(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_TX_TIME_8822C) & \
BIT_MASK_TXOP_LMT_TX_TIME_8822C)
#define BIT_SET_TXOP_LMT_TX_TIME_8822C(x, v) \
(BIT_CLEAR_TXOP_LMT_TX_TIME_8822C(x) | BIT_TXOP_LMT_TX_TIME_8822C(v))
#define BIT_TXOP_CNT_TRIGGER_RESET_8822C BIT(7)
#define BIT_SHIFT_TXOP_LMT_PKT_NUM_8822C 0
#define BIT_MASK_TXOP_LMT_PKT_NUM_8822C 0x3f
#define BIT_TXOP_LMT_PKT_NUM_8822C(x) \
(((x) & BIT_MASK_TXOP_LMT_PKT_NUM_8822C) \
<< BIT_SHIFT_TXOP_LMT_PKT_NUM_8822C)
#define BITS_TXOP_LMT_PKT_NUM_8822C \
(BIT_MASK_TXOP_LMT_PKT_NUM_8822C << BIT_SHIFT_TXOP_LMT_PKT_NUM_8822C)
#define BIT_CLEAR_TXOP_LMT_PKT_NUM_8822C(x) \
((x) & (~BITS_TXOP_LMT_PKT_NUM_8822C))
#define BIT_GET_TXOP_LMT_PKT_NUM_8822C(x) \
(((x) >> BIT_SHIFT_TXOP_LMT_PKT_NUM_8822C) & \
BIT_MASK_TXOP_LMT_PKT_NUM_8822C)
#define BIT_SET_TXOP_LMT_PKT_NUM_8822C(x, v) \
(BIT_CLEAR_TXOP_LMT_PKT_NUM_8822C(x) | BIT_TXOP_LMT_PKT_NUM_8822C(v))
/* 2 REG_BAR_TX_CTRL_8822C */
/* 2 REG_P2PON_DIS_TXTIME_8822C */
#define BIT_SHIFT_P2PON_DIS_TXTIME_8822C 0
#define BIT_MASK_P2PON_DIS_TXTIME_8822C 0xff
#define BIT_P2PON_DIS_TXTIME_8822C(x) \
(((x) & BIT_MASK_P2PON_DIS_TXTIME_8822C) \
<< BIT_SHIFT_P2PON_DIS_TXTIME_8822C)
#define BITS_P2PON_DIS_TXTIME_8822C \
(BIT_MASK_P2PON_DIS_TXTIME_8822C << BIT_SHIFT_P2PON_DIS_TXTIME_8822C)
#define BIT_CLEAR_P2PON_DIS_TXTIME_8822C(x) \
((x) & (~BITS_P2PON_DIS_TXTIME_8822C))
#define BIT_GET_P2PON_DIS_TXTIME_8822C(x) \
(((x) >> BIT_SHIFT_P2PON_DIS_TXTIME_8822C) & \
BIT_MASK_P2PON_DIS_TXTIME_8822C)
#define BIT_SET_P2PON_DIS_TXTIME_8822C(x, v) \
(BIT_CLEAR_P2PON_DIS_TXTIME_8822C(x) | BIT_P2PON_DIS_TXTIME_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_CCA_TXEN_CNT_8822C */
#define BIT_ENABLE_STOP_UPDATE_NAV_8822C BIT(21)
#define BIT_ENABLE_GEN_RANDON_SLOT_TX_8822C BIT(20)
#define BIT_ENABLE_RANDOM_SHIFT_TX_8822C BIT(19)
#define BIT_ENABLE_EDCA_REF_FUNCTION_8822C BIT(18)
#define BIT_CCA_TXEN_CNT_SWITCH_8822C BIT(17)
#define BIT_CCA_TXEN_CNT_EN_8822C BIT(16)
#define BIT_SHIFT_CCA_TXEN_BIG_CNT_8822C 8
#define BIT_MASK_CCA_TXEN_BIG_CNT_8822C 0xff
#define BIT_CCA_TXEN_BIG_CNT_8822C(x) \
(((x) & BIT_MASK_CCA_TXEN_BIG_CNT_8822C) \
<< BIT_SHIFT_CCA_TXEN_BIG_CNT_8822C)
#define BITS_CCA_TXEN_BIG_CNT_8822C \
(BIT_MASK_CCA_TXEN_BIG_CNT_8822C << BIT_SHIFT_CCA_TXEN_BIG_CNT_8822C)
#define BIT_CLEAR_CCA_TXEN_BIG_CNT_8822C(x) \
((x) & (~BITS_CCA_TXEN_BIG_CNT_8822C))
#define BIT_GET_CCA_TXEN_BIG_CNT_8822C(x) \
(((x) >> BIT_SHIFT_CCA_TXEN_BIG_CNT_8822C) & \
BIT_MASK_CCA_TXEN_BIG_CNT_8822C)
#define BIT_SET_CCA_TXEN_BIG_CNT_8822C(x, v) \
(BIT_CLEAR_CCA_TXEN_BIG_CNT_8822C(x) | BIT_CCA_TXEN_BIG_CNT_8822C(v))
#define BIT_SHIFT_CCA_TXEN_SMALL_CNT_8822C 0
#define BIT_MASK_CCA_TXEN_SMALL_CNT_8822C 0xff
#define BIT_CCA_TXEN_SMALL_CNT_8822C(x) \
(((x) & BIT_MASK_CCA_TXEN_SMALL_CNT_8822C) \
<< BIT_SHIFT_CCA_TXEN_SMALL_CNT_8822C)
#define BITS_CCA_TXEN_SMALL_CNT_8822C \
(BIT_MASK_CCA_TXEN_SMALL_CNT_8822C \
<< BIT_SHIFT_CCA_TXEN_SMALL_CNT_8822C)
#define BIT_CLEAR_CCA_TXEN_SMALL_CNT_8822C(x) \
((x) & (~BITS_CCA_TXEN_SMALL_CNT_8822C))
#define BIT_GET_CCA_TXEN_SMALL_CNT_8822C(x) \
(((x) >> BIT_SHIFT_CCA_TXEN_SMALL_CNT_8822C) & \
BIT_MASK_CCA_TXEN_SMALL_CNT_8822C)
#define BIT_SET_CCA_TXEN_SMALL_CNT_8822C(x, v) \
(BIT_CLEAR_CCA_TXEN_SMALL_CNT_8822C(x) | \
BIT_CCA_TXEN_SMALL_CNT_8822C(v))
/* 2 REG_MAX_INTER_COLLISION_8822C */
#define BIT_SHIFT_MAX_INTER_COLLISION_BK_8822C 24
#define BIT_MASK_MAX_INTER_COLLISION_BK_8822C 0xff
#define BIT_MAX_INTER_COLLISION_BK_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_BK_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_BK_8822C)
#define BITS_MAX_INTER_COLLISION_BK_8822C \
(BIT_MASK_MAX_INTER_COLLISION_BK_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_BK_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_BK_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_BK_8822C))
#define BIT_GET_MAX_INTER_COLLISION_BK_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_BK_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_BK_8822C)
#define BIT_SET_MAX_INTER_COLLISION_BK_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_BK_8822C(x) | \
BIT_MAX_INTER_COLLISION_BK_8822C(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_BE_8822C 16
#define BIT_MASK_MAX_INTER_COLLISION_BE_8822C 0xff
#define BIT_MAX_INTER_COLLISION_BE_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_BE_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_BE_8822C)
#define BITS_MAX_INTER_COLLISION_BE_8822C \
(BIT_MASK_MAX_INTER_COLLISION_BE_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_BE_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_BE_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_BE_8822C))
#define BIT_GET_MAX_INTER_COLLISION_BE_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_BE_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_BE_8822C)
#define BIT_SET_MAX_INTER_COLLISION_BE_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_BE_8822C(x) | \
BIT_MAX_INTER_COLLISION_BE_8822C(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_VI_8822C 8
#define BIT_MASK_MAX_INTER_COLLISION_VI_8822C 0xff
#define BIT_MAX_INTER_COLLISION_VI_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_VI_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_VI_8822C)
#define BITS_MAX_INTER_COLLISION_VI_8822C \
(BIT_MASK_MAX_INTER_COLLISION_VI_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_VI_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_VI_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_VI_8822C))
#define BIT_GET_MAX_INTER_COLLISION_VI_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_VI_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_VI_8822C)
#define BIT_SET_MAX_INTER_COLLISION_VI_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_VI_8822C(x) | \
BIT_MAX_INTER_COLLISION_VI_8822C(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_VO_8822C 0
#define BIT_MASK_MAX_INTER_COLLISION_VO_8822C 0xff
#define BIT_MAX_INTER_COLLISION_VO_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_VO_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_VO_8822C)
#define BITS_MAX_INTER_COLLISION_VO_8822C \
(BIT_MASK_MAX_INTER_COLLISION_VO_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_VO_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_VO_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_VO_8822C))
#define BIT_GET_MAX_INTER_COLLISION_VO_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_VO_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_VO_8822C)
#define BIT_SET_MAX_INTER_COLLISION_VO_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_VO_8822C(x) | \
BIT_MAX_INTER_COLLISION_VO_8822C(v))
/* 2 REG_MAX_INTER_COLLISION_CNT_8822C */
#define BIT_MAX_INTER_COLLISION_EN_8822C BIT(16)
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8822C 12
#define BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8822C 0xf
#define BIT_MAX_INTER_COLLISION_CNT_BK_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8822C)
#define BITS_MAX_INTER_COLLISION_CNT_BK_8822C \
(BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_BK_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_BK_8822C))
#define BIT_GET_MAX_INTER_COLLISION_CNT_BK_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_BK_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_BK_8822C)
#define BIT_SET_MAX_INTER_COLLISION_CNT_BK_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_BK_8822C(x) | \
BIT_MAX_INTER_COLLISION_CNT_BK_8822C(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8822C 8
#define BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8822C 0xf
#define BIT_MAX_INTER_COLLISION_CNT_BE_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8822C)
#define BITS_MAX_INTER_COLLISION_CNT_BE_8822C \
(BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_BE_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_BE_8822C))
#define BIT_GET_MAX_INTER_COLLISION_CNT_BE_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_BE_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_BE_8822C)
#define BIT_SET_MAX_INTER_COLLISION_CNT_BE_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_BE_8822C(x) | \
BIT_MAX_INTER_COLLISION_CNT_BE_8822C(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8822C 4
#define BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8822C 0xf
#define BIT_MAX_INTER_COLLISION_CNT_VI_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8822C)
#define BITS_MAX_INTER_COLLISION_CNT_VI_8822C \
(BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_VI_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_VI_8822C))
#define BIT_GET_MAX_INTER_COLLISION_CNT_VI_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_VI_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_VI_8822C)
#define BIT_SET_MAX_INTER_COLLISION_CNT_VI_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_VI_8822C(x) | \
BIT_MAX_INTER_COLLISION_CNT_VI_8822C(v))
#define BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8822C 0
#define BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8822C 0xf
#define BIT_MAX_INTER_COLLISION_CNT_VO_8822C(x) \
(((x) & BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8822C) \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8822C)
#define BITS_MAX_INTER_COLLISION_CNT_VO_8822C \
(BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8822C \
<< BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8822C)
#define BIT_CLEAR_MAX_INTER_COLLISION_CNT_VO_8822C(x) \
((x) & (~BITS_MAX_INTER_COLLISION_CNT_VO_8822C))
#define BIT_GET_MAX_INTER_COLLISION_CNT_VO_8822C(x) \
(((x) >> BIT_SHIFT_MAX_INTER_COLLISION_CNT_VO_8822C) & \
BIT_MASK_MAX_INTER_COLLISION_CNT_VO_8822C)
#define BIT_SET_MAX_INTER_COLLISION_CNT_VO_8822C(x, v) \
(BIT_CLEAR_MAX_INTER_COLLISION_CNT_VO_8822C(x) | \
BIT_MAX_INTER_COLLISION_CNT_VO_8822C(v))
/* 2 REG_TBTT_PROHIBIT_8822C */
#define BIT_SHIFT_TBTT_HOLD_TIME_AP_8822C 8
#define BIT_MASK_TBTT_HOLD_TIME_AP_8822C 0xfff
#define BIT_TBTT_HOLD_TIME_AP_8822C(x) \
(((x) & BIT_MASK_TBTT_HOLD_TIME_AP_8822C) \
<< BIT_SHIFT_TBTT_HOLD_TIME_AP_8822C)
#define BITS_TBTT_HOLD_TIME_AP_8822C \
(BIT_MASK_TBTT_HOLD_TIME_AP_8822C << BIT_SHIFT_TBTT_HOLD_TIME_AP_8822C)
#define BIT_CLEAR_TBTT_HOLD_TIME_AP_8822C(x) \
((x) & (~BITS_TBTT_HOLD_TIME_AP_8822C))
#define BIT_GET_TBTT_HOLD_TIME_AP_8822C(x) \
(((x) >> BIT_SHIFT_TBTT_HOLD_TIME_AP_8822C) & \
BIT_MASK_TBTT_HOLD_TIME_AP_8822C)
#define BIT_SET_TBTT_HOLD_TIME_AP_8822C(x, v) \
(BIT_CLEAR_TBTT_HOLD_TIME_AP_8822C(x) | BIT_TBTT_HOLD_TIME_AP_8822C(v))
#define BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822C 0
#define BIT_MASK_TBTT_PROHIBIT_SETUP_8822C 0xf
#define BIT_TBTT_PROHIBIT_SETUP_8822C(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_SETUP_8822C) \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822C)
#define BITS_TBTT_PROHIBIT_SETUP_8822C \
(BIT_MASK_TBTT_PROHIBIT_SETUP_8822C \
<< BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822C)
#define BIT_CLEAR_TBTT_PROHIBIT_SETUP_8822C(x) \
((x) & (~BITS_TBTT_PROHIBIT_SETUP_8822C))
#define BIT_GET_TBTT_PROHIBIT_SETUP_8822C(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_SETUP_8822C) & \
BIT_MASK_TBTT_PROHIBIT_SETUP_8822C)
#define BIT_SET_TBTT_PROHIBIT_SETUP_8822C(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_SETUP_8822C(x) | \
BIT_TBTT_PROHIBIT_SETUP_8822C(v))
/* 2 REG_P2PPS_STATE_8822C */
#define BIT_POWER_STATE_8822C BIT(7)
#define BIT_CTWINDOW_ON_8822C BIT(6)
#define BIT_BEACON_AREA_ON_8822C BIT(5)
#define BIT_CTWIN_EARLY_DISTX_8822C BIT(4)
#define BIT_NOA1_OFF_PERIOD_8822C BIT(3)
#define BIT_FORCE_DOZE1_8822C BIT(2)
#define BIT_NOA0_OFF_PERIOD_8822C BIT(1)
#define BIT_FORCE_DOZE0_8822C BIT(0)
/* 2 REG_RD_NAV_NXT_8822C */
#define BIT_SHIFT_RD_NAV_PROT_NXT_8822C 0
#define BIT_MASK_RD_NAV_PROT_NXT_8822C 0xffff
#define BIT_RD_NAV_PROT_NXT_8822C(x) \
(((x) & BIT_MASK_RD_NAV_PROT_NXT_8822C) \
<< BIT_SHIFT_RD_NAV_PROT_NXT_8822C)
#define BITS_RD_NAV_PROT_NXT_8822C \
(BIT_MASK_RD_NAV_PROT_NXT_8822C << BIT_SHIFT_RD_NAV_PROT_NXT_8822C)
#define BIT_CLEAR_RD_NAV_PROT_NXT_8822C(x) ((x) & (~BITS_RD_NAV_PROT_NXT_8822C))
#define BIT_GET_RD_NAV_PROT_NXT_8822C(x) \
(((x) >> BIT_SHIFT_RD_NAV_PROT_NXT_8822C) & \
BIT_MASK_RD_NAV_PROT_NXT_8822C)
#define BIT_SET_RD_NAV_PROT_NXT_8822C(x, v) \
(BIT_CLEAR_RD_NAV_PROT_NXT_8822C(x) | BIT_RD_NAV_PROT_NXT_8822C(v))
/* 2 REG_NAV_PROT_LEN_8822C */
#define BIT_SHIFT_NAV_PROT_LEN_8822C 0
#define BIT_MASK_NAV_PROT_LEN_8822C 0xffff
#define BIT_NAV_PROT_LEN_8822C(x) \
(((x) & BIT_MASK_NAV_PROT_LEN_8822C) << BIT_SHIFT_NAV_PROT_LEN_8822C)
#define BITS_NAV_PROT_LEN_8822C \
(BIT_MASK_NAV_PROT_LEN_8822C << BIT_SHIFT_NAV_PROT_LEN_8822C)
#define BIT_CLEAR_NAV_PROT_LEN_8822C(x) ((x) & (~BITS_NAV_PROT_LEN_8822C))
#define BIT_GET_NAV_PROT_LEN_8822C(x) \
(((x) >> BIT_SHIFT_NAV_PROT_LEN_8822C) & BIT_MASK_NAV_PROT_LEN_8822C)
#define BIT_SET_NAV_PROT_LEN_8822C(x, v) \
(BIT_CLEAR_NAV_PROT_LEN_8822C(x) | BIT_NAV_PROT_LEN_8822C(v))
/* 2 REG_FTM_PTT_8822C */
#define BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8822C 22
#define BIT_MASK_FTM_PTT_TSF_R2T_SEL_8822C 0x7
#define BIT_FTM_PTT_TSF_R2T_SEL_8822C(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_R2T_SEL_8822C) \
<< BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8822C)
#define BITS_FTM_PTT_TSF_R2T_SEL_8822C \
(BIT_MASK_FTM_PTT_TSF_R2T_SEL_8822C \
<< BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8822C)
#define BIT_CLEAR_FTM_PTT_TSF_R2T_SEL_8822C(x) \
((x) & (~BITS_FTM_PTT_TSF_R2T_SEL_8822C))
#define BIT_GET_FTM_PTT_TSF_R2T_SEL_8822C(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_R2T_SEL_8822C) & \
BIT_MASK_FTM_PTT_TSF_R2T_SEL_8822C)
#define BIT_SET_FTM_PTT_TSF_R2T_SEL_8822C(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_R2T_SEL_8822C(x) | \
BIT_FTM_PTT_TSF_R2T_SEL_8822C(v))
#define BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8822C 19
#define BIT_MASK_FTM_PTT_TSF_T2R_SEL_8822C 0x7
#define BIT_FTM_PTT_TSF_T2R_SEL_8822C(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_T2R_SEL_8822C) \
<< BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8822C)
#define BITS_FTM_PTT_TSF_T2R_SEL_8822C \
(BIT_MASK_FTM_PTT_TSF_T2R_SEL_8822C \
<< BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8822C)
#define BIT_CLEAR_FTM_PTT_TSF_T2R_SEL_8822C(x) \
((x) & (~BITS_FTM_PTT_TSF_T2R_SEL_8822C))
#define BIT_GET_FTM_PTT_TSF_T2R_SEL_8822C(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_T2R_SEL_8822C) & \
BIT_MASK_FTM_PTT_TSF_T2R_SEL_8822C)
#define BIT_SET_FTM_PTT_TSF_T2R_SEL_8822C(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_T2R_SEL_8822C(x) | \
BIT_FTM_PTT_TSF_T2R_SEL_8822C(v))
#define BIT_SHIFT_FTM_PTT_TSF_SEL_8822C 16
#define BIT_MASK_FTM_PTT_TSF_SEL_8822C 0x7
#define BIT_FTM_PTT_TSF_SEL_8822C(x) \
(((x) & BIT_MASK_FTM_PTT_TSF_SEL_8822C) \
<< BIT_SHIFT_FTM_PTT_TSF_SEL_8822C)
#define BITS_FTM_PTT_TSF_SEL_8822C \
(BIT_MASK_FTM_PTT_TSF_SEL_8822C << BIT_SHIFT_FTM_PTT_TSF_SEL_8822C)
#define BIT_CLEAR_FTM_PTT_TSF_SEL_8822C(x) ((x) & (~BITS_FTM_PTT_TSF_SEL_8822C))
#define BIT_GET_FTM_PTT_TSF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_FTM_PTT_TSF_SEL_8822C) & \
BIT_MASK_FTM_PTT_TSF_SEL_8822C)
#define BIT_SET_FTM_PTT_TSF_SEL_8822C(x, v) \
(BIT_CLEAR_FTM_PTT_TSF_SEL_8822C(x) | BIT_FTM_PTT_TSF_SEL_8822C(v))
#define BIT_SHIFT_FTM_PTT_VALUE_8822C 0
#define BIT_MASK_FTM_PTT_VALUE_8822C 0xffff
#define BIT_FTM_PTT_VALUE_8822C(x) \
(((x) & BIT_MASK_FTM_PTT_VALUE_8822C) << BIT_SHIFT_FTM_PTT_VALUE_8822C)
#define BITS_FTM_PTT_VALUE_8822C \
(BIT_MASK_FTM_PTT_VALUE_8822C << BIT_SHIFT_FTM_PTT_VALUE_8822C)
#define BIT_CLEAR_FTM_PTT_VALUE_8822C(x) ((x) & (~BITS_FTM_PTT_VALUE_8822C))
#define BIT_GET_FTM_PTT_VALUE_8822C(x) \
(((x) >> BIT_SHIFT_FTM_PTT_VALUE_8822C) & BIT_MASK_FTM_PTT_VALUE_8822C)
#define BIT_SET_FTM_PTT_VALUE_8822C(x, v) \
(BIT_CLEAR_FTM_PTT_VALUE_8822C(x) | BIT_FTM_PTT_VALUE_8822C(v))
/* 2 REG_FTM_TSF_8822C */
#define BIT_SHIFT_FTM_T2_TSF_8822C 16
#define BIT_MASK_FTM_T2_TSF_8822C 0xffff
#define BIT_FTM_T2_TSF_8822C(x) \
(((x) & BIT_MASK_FTM_T2_TSF_8822C) << BIT_SHIFT_FTM_T2_TSF_8822C)
#define BITS_FTM_T2_TSF_8822C \
(BIT_MASK_FTM_T2_TSF_8822C << BIT_SHIFT_FTM_T2_TSF_8822C)
#define BIT_CLEAR_FTM_T2_TSF_8822C(x) ((x) & (~BITS_FTM_T2_TSF_8822C))
#define BIT_GET_FTM_T2_TSF_8822C(x) \
(((x) >> BIT_SHIFT_FTM_T2_TSF_8822C) & BIT_MASK_FTM_T2_TSF_8822C)
#define BIT_SET_FTM_T2_TSF_8822C(x, v) \
(BIT_CLEAR_FTM_T2_TSF_8822C(x) | BIT_FTM_T2_TSF_8822C(v))
#define BIT_SHIFT_FTM_T1_TSF_8822C 0
#define BIT_MASK_FTM_T1_TSF_8822C 0xffff
#define BIT_FTM_T1_TSF_8822C(x) \
(((x) & BIT_MASK_FTM_T1_TSF_8822C) << BIT_SHIFT_FTM_T1_TSF_8822C)
#define BITS_FTM_T1_TSF_8822C \
(BIT_MASK_FTM_T1_TSF_8822C << BIT_SHIFT_FTM_T1_TSF_8822C)
#define BIT_CLEAR_FTM_T1_TSF_8822C(x) ((x) & (~BITS_FTM_T1_TSF_8822C))
#define BIT_GET_FTM_T1_TSF_8822C(x) \
(((x) >> BIT_SHIFT_FTM_T1_TSF_8822C) & BIT_MASK_FTM_T1_TSF_8822C)
#define BIT_SET_FTM_T1_TSF_8822C(x, v) \
(BIT_CLEAR_FTM_T1_TSF_8822C(x) | BIT_FTM_T1_TSF_8822C(v))
/* 2 REG_BCN_CTRL_8822C */
#define BIT_DIS_RX_BSSID_FIT_8822C BIT(6)
#define BIT_P0_EN_TXBCN_RPT_8822C BIT(5)
#define BIT_DIS_TSF_UDT_8822C BIT(4)
#define BIT_EN_BCN_FUNCTION_8822C BIT(3)
#define BIT_P0_EN_RXBCN_RPT_8822C BIT(2)
#define BIT_EN_P2P_CTWINDOW_8822C BIT(1)
#define BIT_EN_P2P_BCNQ_AREA_8822C BIT(0)
/* 2 REG_BCN_CTRL_CLINT0_8822C */
#define BIT_CLI0_DIS_RX_BSSID_FIT_8822C BIT(6)
#define BIT_CLI0_DIS_TSF_UDT_8822C BIT(4)
#define BIT_CLI0_EN_BCN_FUNCTION_8822C BIT(3)
#define BIT_CLI0_EN_RXBCN_RPT_8822C BIT(2)
#define BIT_CLI0_ENP2P_CTWINDOW_8822C BIT(1)
#define BIT_CLI0_ENP2P_BCNQ_AREA_8822C BIT(0)
/* 2 REG_MBID_NUM_8822C */
#define BIT_EN_PRE_DL_BEACON_8822C BIT(3)
#define BIT_SHIFT_MBID_BCN_NUM_8822C 0
#define BIT_MASK_MBID_BCN_NUM_8822C 0x7
#define BIT_MBID_BCN_NUM_8822C(x) \
(((x) & BIT_MASK_MBID_BCN_NUM_8822C) << BIT_SHIFT_MBID_BCN_NUM_8822C)
#define BITS_MBID_BCN_NUM_8822C \
(BIT_MASK_MBID_BCN_NUM_8822C << BIT_SHIFT_MBID_BCN_NUM_8822C)
#define BIT_CLEAR_MBID_BCN_NUM_8822C(x) ((x) & (~BITS_MBID_BCN_NUM_8822C))
#define BIT_GET_MBID_BCN_NUM_8822C(x) \
(((x) >> BIT_SHIFT_MBID_BCN_NUM_8822C) & BIT_MASK_MBID_BCN_NUM_8822C)
#define BIT_SET_MBID_BCN_NUM_8822C(x, v) \
(BIT_CLEAR_MBID_BCN_NUM_8822C(x) | BIT_MBID_BCN_NUM_8822C(v))
/* 2 REG_DUAL_TSF_RST_8822C */
#define BIT_FREECNT_RST_8822C BIT(5)
#define BIT_TSFTR_CLI3_RST_8822C BIT(4)
#define BIT_TSFTR_CLI2_RST_8822C BIT(3)
#define BIT_TSFTR_CLI1_RST_8822C BIT(2)
#define BIT_TSFTR_CLI0_RST_8822C BIT(1)
#define BIT_TSFTR_RST_8822C BIT(0)
/* 2 REG_MBSSID_BCN_SPACE_8822C */
#define BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822C 28
#define BIT_MASK_BCN_TIMER_SEL_FWRD_8822C 0x7
#define BIT_BCN_TIMER_SEL_FWRD_8822C(x) \
(((x) & BIT_MASK_BCN_TIMER_SEL_FWRD_8822C) \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822C)
#define BITS_BCN_TIMER_SEL_FWRD_8822C \
(BIT_MASK_BCN_TIMER_SEL_FWRD_8822C \
<< BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822C)
#define BIT_CLEAR_BCN_TIMER_SEL_FWRD_8822C(x) \
((x) & (~BITS_BCN_TIMER_SEL_FWRD_8822C))
#define BIT_GET_BCN_TIMER_SEL_FWRD_8822C(x) \
(((x) >> BIT_SHIFT_BCN_TIMER_SEL_FWRD_8822C) & \
BIT_MASK_BCN_TIMER_SEL_FWRD_8822C)
#define BIT_SET_BCN_TIMER_SEL_FWRD_8822C(x, v) \
(BIT_CLEAR_BCN_TIMER_SEL_FWRD_8822C(x) | \
BIT_BCN_TIMER_SEL_FWRD_8822C(v))
#define BIT_SHIFT_BCN_SPACE_CLINT0_8822C 16
#define BIT_MASK_BCN_SPACE_CLINT0_8822C 0xfff
#define BIT_BCN_SPACE_CLINT0_8822C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT0_8822C) \
<< BIT_SHIFT_BCN_SPACE_CLINT0_8822C)
#define BITS_BCN_SPACE_CLINT0_8822C \
(BIT_MASK_BCN_SPACE_CLINT0_8822C << BIT_SHIFT_BCN_SPACE_CLINT0_8822C)
#define BIT_CLEAR_BCN_SPACE_CLINT0_8822C(x) \
((x) & (~BITS_BCN_SPACE_CLINT0_8822C))
#define BIT_GET_BCN_SPACE_CLINT0_8822C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT0_8822C) & \
BIT_MASK_BCN_SPACE_CLINT0_8822C)
#define BIT_SET_BCN_SPACE_CLINT0_8822C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT0_8822C(x) | BIT_BCN_SPACE_CLINT0_8822C(v))
#define BIT_SHIFT_BCN_SPACE0_8822C 0
#define BIT_MASK_BCN_SPACE0_8822C 0xffff
#define BIT_BCN_SPACE0_8822C(x) \
(((x) & BIT_MASK_BCN_SPACE0_8822C) << BIT_SHIFT_BCN_SPACE0_8822C)
#define BITS_BCN_SPACE0_8822C \
(BIT_MASK_BCN_SPACE0_8822C << BIT_SHIFT_BCN_SPACE0_8822C)
#define BIT_CLEAR_BCN_SPACE0_8822C(x) ((x) & (~BITS_BCN_SPACE0_8822C))
#define BIT_GET_BCN_SPACE0_8822C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE0_8822C) & BIT_MASK_BCN_SPACE0_8822C)
#define BIT_SET_BCN_SPACE0_8822C(x, v) \
(BIT_CLEAR_BCN_SPACE0_8822C(x) | BIT_BCN_SPACE0_8822C(v))
/* 2 REG_DRVERLYINT_8822C */
#define BIT_SHIFT_DRVERLYITV_8822C 0
#define BIT_MASK_DRVERLYITV_8822C 0xff
#define BIT_DRVERLYITV_8822C(x) \
(((x) & BIT_MASK_DRVERLYITV_8822C) << BIT_SHIFT_DRVERLYITV_8822C)
#define BITS_DRVERLYITV_8822C \
(BIT_MASK_DRVERLYITV_8822C << BIT_SHIFT_DRVERLYITV_8822C)
#define BIT_CLEAR_DRVERLYITV_8822C(x) ((x) & (~BITS_DRVERLYITV_8822C))
#define BIT_GET_DRVERLYITV_8822C(x) \
(((x) >> BIT_SHIFT_DRVERLYITV_8822C) & BIT_MASK_DRVERLYITV_8822C)
#define BIT_SET_DRVERLYITV_8822C(x, v) \
(BIT_CLEAR_DRVERLYITV_8822C(x) | BIT_DRVERLYITV_8822C(v))
/* 2 REG_BCNDMATIM_8822C */
#define BIT_SHIFT_BCNDMATIM_8822C 0
#define BIT_MASK_BCNDMATIM_8822C 0xff
#define BIT_BCNDMATIM_8822C(x) \
(((x) & BIT_MASK_BCNDMATIM_8822C) << BIT_SHIFT_BCNDMATIM_8822C)
#define BITS_BCNDMATIM_8822C \
(BIT_MASK_BCNDMATIM_8822C << BIT_SHIFT_BCNDMATIM_8822C)
#define BIT_CLEAR_BCNDMATIM_8822C(x) ((x) & (~BITS_BCNDMATIM_8822C))
#define BIT_GET_BCNDMATIM_8822C(x) \
(((x) >> BIT_SHIFT_BCNDMATIM_8822C) & BIT_MASK_BCNDMATIM_8822C)
#define BIT_SET_BCNDMATIM_8822C(x, v) \
(BIT_CLEAR_BCNDMATIM_8822C(x) | BIT_BCNDMATIM_8822C(v))
/* 2 REG_ATIMWND_8822C */
#define BIT_SHIFT_ATIMWND0_8822C 0
#define BIT_MASK_ATIMWND0_8822C 0xffff
#define BIT_ATIMWND0_8822C(x) \
(((x) & BIT_MASK_ATIMWND0_8822C) << BIT_SHIFT_ATIMWND0_8822C)
#define BITS_ATIMWND0_8822C \
(BIT_MASK_ATIMWND0_8822C << BIT_SHIFT_ATIMWND0_8822C)
#define BIT_CLEAR_ATIMWND0_8822C(x) ((x) & (~BITS_ATIMWND0_8822C))
#define BIT_GET_ATIMWND0_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND0_8822C) & BIT_MASK_ATIMWND0_8822C)
#define BIT_SET_ATIMWND0_8822C(x, v) \
(BIT_CLEAR_ATIMWND0_8822C(x) | BIT_ATIMWND0_8822C(v))
/* 2 REG_USTIME_TSF_8822C */
#define BIT_SHIFT_USTIME_TSF_V1_8822C 0
#define BIT_MASK_USTIME_TSF_V1_8822C 0xff
#define BIT_USTIME_TSF_V1_8822C(x) \
(((x) & BIT_MASK_USTIME_TSF_V1_8822C) << BIT_SHIFT_USTIME_TSF_V1_8822C)
#define BITS_USTIME_TSF_V1_8822C \
(BIT_MASK_USTIME_TSF_V1_8822C << BIT_SHIFT_USTIME_TSF_V1_8822C)
#define BIT_CLEAR_USTIME_TSF_V1_8822C(x) ((x) & (~BITS_USTIME_TSF_V1_8822C))
#define BIT_GET_USTIME_TSF_V1_8822C(x) \
(((x) >> BIT_SHIFT_USTIME_TSF_V1_8822C) & BIT_MASK_USTIME_TSF_V1_8822C)
#define BIT_SET_USTIME_TSF_V1_8822C(x, v) \
(BIT_CLEAR_USTIME_TSF_V1_8822C(x) | BIT_USTIME_TSF_V1_8822C(v))
/* 2 REG_BCN_MAX_ERR_8822C */
#define BIT_SHIFT_BCN_MAX_ERR_8822C 0
#define BIT_MASK_BCN_MAX_ERR_8822C 0xff
#define BIT_BCN_MAX_ERR_8822C(x) \
(((x) & BIT_MASK_BCN_MAX_ERR_8822C) << BIT_SHIFT_BCN_MAX_ERR_8822C)
#define BITS_BCN_MAX_ERR_8822C \
(BIT_MASK_BCN_MAX_ERR_8822C << BIT_SHIFT_BCN_MAX_ERR_8822C)
#define BIT_CLEAR_BCN_MAX_ERR_8822C(x) ((x) & (~BITS_BCN_MAX_ERR_8822C))
#define BIT_GET_BCN_MAX_ERR_8822C(x) \
(((x) >> BIT_SHIFT_BCN_MAX_ERR_8822C) & BIT_MASK_BCN_MAX_ERR_8822C)
#define BIT_SET_BCN_MAX_ERR_8822C(x, v) \
(BIT_CLEAR_BCN_MAX_ERR_8822C(x) | BIT_BCN_MAX_ERR_8822C(v))
/* 2 REG_RXTSF_OFFSET_CCK_8822C */
#define BIT_SHIFT_CCK_RXTSF_OFFSET_8822C 0
#define BIT_MASK_CCK_RXTSF_OFFSET_8822C 0xff
#define BIT_CCK_RXTSF_OFFSET_8822C(x) \
(((x) & BIT_MASK_CCK_RXTSF_OFFSET_8822C) \
<< BIT_SHIFT_CCK_RXTSF_OFFSET_8822C)
#define BITS_CCK_RXTSF_OFFSET_8822C \
(BIT_MASK_CCK_RXTSF_OFFSET_8822C << BIT_SHIFT_CCK_RXTSF_OFFSET_8822C)
#define BIT_CLEAR_CCK_RXTSF_OFFSET_8822C(x) \
((x) & (~BITS_CCK_RXTSF_OFFSET_8822C))
#define BIT_GET_CCK_RXTSF_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_CCK_RXTSF_OFFSET_8822C) & \
BIT_MASK_CCK_RXTSF_OFFSET_8822C)
#define BIT_SET_CCK_RXTSF_OFFSET_8822C(x, v) \
(BIT_CLEAR_CCK_RXTSF_OFFSET_8822C(x) | BIT_CCK_RXTSF_OFFSET_8822C(v))
/* 2 REG_RXTSF_OFFSET_OFDM_8822C */
#define BIT_SHIFT_OFDM_RXTSF_OFFSET_8822C 0
#define BIT_MASK_OFDM_RXTSF_OFFSET_8822C 0xff
#define BIT_OFDM_RXTSF_OFFSET_8822C(x) \
(((x) & BIT_MASK_OFDM_RXTSF_OFFSET_8822C) \
<< BIT_SHIFT_OFDM_RXTSF_OFFSET_8822C)
#define BITS_OFDM_RXTSF_OFFSET_8822C \
(BIT_MASK_OFDM_RXTSF_OFFSET_8822C << BIT_SHIFT_OFDM_RXTSF_OFFSET_8822C)
#define BIT_CLEAR_OFDM_RXTSF_OFFSET_8822C(x) \
((x) & (~BITS_OFDM_RXTSF_OFFSET_8822C))
#define BIT_GET_OFDM_RXTSF_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_OFDM_RXTSF_OFFSET_8822C) & \
BIT_MASK_OFDM_RXTSF_OFFSET_8822C)
#define BIT_SET_OFDM_RXTSF_OFFSET_8822C(x, v) \
(BIT_CLEAR_OFDM_RXTSF_OFFSET_8822C(x) | BIT_OFDM_RXTSF_OFFSET_8822C(v))
/* 2 REG_TSFTR_8822C */
#define BIT_SHIFT_TSF_TIMER_V1_8822C 0
#define BIT_MASK_TSF_TIMER_V1_8822C 0xffffffffL
#define BIT_TSF_TIMER_V1_8822C(x) \
(((x) & BIT_MASK_TSF_TIMER_V1_8822C) << BIT_SHIFT_TSF_TIMER_V1_8822C)
#define BITS_TSF_TIMER_V1_8822C \
(BIT_MASK_TSF_TIMER_V1_8822C << BIT_SHIFT_TSF_TIMER_V1_8822C)
#define BIT_CLEAR_TSF_TIMER_V1_8822C(x) ((x) & (~BITS_TSF_TIMER_V1_8822C))
#define BIT_GET_TSF_TIMER_V1_8822C(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_V1_8822C) & BIT_MASK_TSF_TIMER_V1_8822C)
#define BIT_SET_TSF_TIMER_V1_8822C(x, v) \
(BIT_CLEAR_TSF_TIMER_V1_8822C(x) | BIT_TSF_TIMER_V1_8822C(v))
/* 2 REG_TSFTR_1_8822C */
#define BIT_SHIFT_TSF_TIMER_V2_8822C 0
#define BIT_MASK_TSF_TIMER_V2_8822C 0xffffffffL
#define BIT_TSF_TIMER_V2_8822C(x) \
(((x) & BIT_MASK_TSF_TIMER_V2_8822C) << BIT_SHIFT_TSF_TIMER_V2_8822C)
#define BITS_TSF_TIMER_V2_8822C \
(BIT_MASK_TSF_TIMER_V2_8822C << BIT_SHIFT_TSF_TIMER_V2_8822C)
#define BIT_CLEAR_TSF_TIMER_V2_8822C(x) ((x) & (~BITS_TSF_TIMER_V2_8822C))
#define BIT_GET_TSF_TIMER_V2_8822C(x) \
(((x) >> BIT_SHIFT_TSF_TIMER_V2_8822C) & BIT_MASK_TSF_TIMER_V2_8822C)
#define BIT_SET_TSF_TIMER_V2_8822C(x, v) \
(BIT_CLEAR_TSF_TIMER_V2_8822C(x) | BIT_TSF_TIMER_V2_8822C(v))
/* 2 REG_FREERUN_CNT_8822C */
#define BIT_SHIFT_FREERUN_CNT_V1_8822C 0
#define BIT_MASK_FREERUN_CNT_V1_8822C 0xffffffffL
#define BIT_FREERUN_CNT_V1_8822C(x) \
(((x) & BIT_MASK_FREERUN_CNT_V1_8822C) \
<< BIT_SHIFT_FREERUN_CNT_V1_8822C)
#define BITS_FREERUN_CNT_V1_8822C \
(BIT_MASK_FREERUN_CNT_V1_8822C << BIT_SHIFT_FREERUN_CNT_V1_8822C)
#define BIT_CLEAR_FREERUN_CNT_V1_8822C(x) ((x) & (~BITS_FREERUN_CNT_V1_8822C))
#define BIT_GET_FREERUN_CNT_V1_8822C(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_V1_8822C) & \
BIT_MASK_FREERUN_CNT_V1_8822C)
#define BIT_SET_FREERUN_CNT_V1_8822C(x, v) \
(BIT_CLEAR_FREERUN_CNT_V1_8822C(x) | BIT_FREERUN_CNT_V1_8822C(v))
/* 2 REG_FREERUN_CNT_1_8822C */
#define BIT_SHIFT_FREERUN_CNT_V2_8822C 0
#define BIT_MASK_FREERUN_CNT_V2_8822C 0xffffffffL
#define BIT_FREERUN_CNT_V2_8822C(x) \
(((x) & BIT_MASK_FREERUN_CNT_V2_8822C) \
<< BIT_SHIFT_FREERUN_CNT_V2_8822C)
#define BITS_FREERUN_CNT_V2_8822C \
(BIT_MASK_FREERUN_CNT_V2_8822C << BIT_SHIFT_FREERUN_CNT_V2_8822C)
#define BIT_CLEAR_FREERUN_CNT_V2_8822C(x) ((x) & (~BITS_FREERUN_CNT_V2_8822C))
#define BIT_GET_FREERUN_CNT_V2_8822C(x) \
(((x) >> BIT_SHIFT_FREERUN_CNT_V2_8822C) & \
BIT_MASK_FREERUN_CNT_V2_8822C)
#define BIT_SET_FREERUN_CNT_V2_8822C(x, v) \
(BIT_CLEAR_FREERUN_CNT_V2_8822C(x) | BIT_FREERUN_CNT_V2_8822C(v))
/* 2 REG_ATIMWND1_V1_8822C */
#define BIT_SHIFT_ATIMWND1_V1_8822C 0
#define BIT_MASK_ATIMWND1_V1_8822C 0xff
#define BIT_ATIMWND1_V1_8822C(x) \
(((x) & BIT_MASK_ATIMWND1_V1_8822C) << BIT_SHIFT_ATIMWND1_V1_8822C)
#define BITS_ATIMWND1_V1_8822C \
(BIT_MASK_ATIMWND1_V1_8822C << BIT_SHIFT_ATIMWND1_V1_8822C)
#define BIT_CLEAR_ATIMWND1_V1_8822C(x) ((x) & (~BITS_ATIMWND1_V1_8822C))
#define BIT_GET_ATIMWND1_V1_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND1_V1_8822C) & BIT_MASK_ATIMWND1_V1_8822C)
#define BIT_SET_ATIMWND1_V1_8822C(x, v) \
(BIT_CLEAR_ATIMWND1_V1_8822C(x) | BIT_ATIMWND1_V1_8822C(v))
/* 2 REG_TBTT_PROHIBIT_INFRA_8822C */
#define BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822C 0
#define BIT_MASK_TBTT_PROHIBIT_INFRA_8822C 0xff
#define BIT_TBTT_PROHIBIT_INFRA_8822C(x) \
(((x) & BIT_MASK_TBTT_PROHIBIT_INFRA_8822C) \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822C)
#define BITS_TBTT_PROHIBIT_INFRA_8822C \
(BIT_MASK_TBTT_PROHIBIT_INFRA_8822C \
<< BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822C)
#define BIT_CLEAR_TBTT_PROHIBIT_INFRA_8822C(x) \
((x) & (~BITS_TBTT_PROHIBIT_INFRA_8822C))
#define BIT_GET_TBTT_PROHIBIT_INFRA_8822C(x) \
(((x) >> BIT_SHIFT_TBTT_PROHIBIT_INFRA_8822C) & \
BIT_MASK_TBTT_PROHIBIT_INFRA_8822C)
#define BIT_SET_TBTT_PROHIBIT_INFRA_8822C(x, v) \
(BIT_CLEAR_TBTT_PROHIBIT_INFRA_8822C(x) | \
BIT_TBTT_PROHIBIT_INFRA_8822C(v))
/* 2 REG_CTWND_8822C */
#define BIT_SHIFT_CTWND_8822C 0
#define BIT_MASK_CTWND_8822C 0xff
#define BIT_CTWND_8822C(x) \
(((x) & BIT_MASK_CTWND_8822C) << BIT_SHIFT_CTWND_8822C)
#define BITS_CTWND_8822C (BIT_MASK_CTWND_8822C << BIT_SHIFT_CTWND_8822C)
#define BIT_CLEAR_CTWND_8822C(x) ((x) & (~BITS_CTWND_8822C))
#define BIT_GET_CTWND_8822C(x) \
(((x) >> BIT_SHIFT_CTWND_8822C) & BIT_MASK_CTWND_8822C)
#define BIT_SET_CTWND_8822C(x, v) \
(BIT_CLEAR_CTWND_8822C(x) | BIT_CTWND_8822C(v))
/* 2 REG_BCNIVLCUNT_8822C */
#define BIT_SHIFT_BCNIVLCUNT_8822C 0
#define BIT_MASK_BCNIVLCUNT_8822C 0x7f
#define BIT_BCNIVLCUNT_8822C(x) \
(((x) & BIT_MASK_BCNIVLCUNT_8822C) << BIT_SHIFT_BCNIVLCUNT_8822C)
#define BITS_BCNIVLCUNT_8822C \
(BIT_MASK_BCNIVLCUNT_8822C << BIT_SHIFT_BCNIVLCUNT_8822C)
#define BIT_CLEAR_BCNIVLCUNT_8822C(x) ((x) & (~BITS_BCNIVLCUNT_8822C))
#define BIT_GET_BCNIVLCUNT_8822C(x) \
(((x) >> BIT_SHIFT_BCNIVLCUNT_8822C) & BIT_MASK_BCNIVLCUNT_8822C)
#define BIT_SET_BCNIVLCUNT_8822C(x, v) \
(BIT_CLEAR_BCNIVLCUNT_8822C(x) | BIT_BCNIVLCUNT_8822C(v))
/* 2 REG_BCNDROPCTRL_8822C */
#define BIT_BEACON_DROP_EN_8822C BIT(7)
#define BIT_SHIFT_BEACON_DROP_IVL_8822C 0
#define BIT_MASK_BEACON_DROP_IVL_8822C 0x7f
#define BIT_BEACON_DROP_IVL_8822C(x) \
(((x) & BIT_MASK_BEACON_DROP_IVL_8822C) \
<< BIT_SHIFT_BEACON_DROP_IVL_8822C)
#define BITS_BEACON_DROP_IVL_8822C \
(BIT_MASK_BEACON_DROP_IVL_8822C << BIT_SHIFT_BEACON_DROP_IVL_8822C)
#define BIT_CLEAR_BEACON_DROP_IVL_8822C(x) ((x) & (~BITS_BEACON_DROP_IVL_8822C))
#define BIT_GET_BEACON_DROP_IVL_8822C(x) \
(((x) >> BIT_SHIFT_BEACON_DROP_IVL_8822C) & \
BIT_MASK_BEACON_DROP_IVL_8822C)
#define BIT_SET_BEACON_DROP_IVL_8822C(x, v) \
(BIT_CLEAR_BEACON_DROP_IVL_8822C(x) | BIT_BEACON_DROP_IVL_8822C(v))
/* 2 REG_HGQ_TIMEOUT_PERIOD_8822C */
#define BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822C 0
#define BIT_MASK_HGQ_TIMEOUT_PERIOD_8822C 0xff
#define BIT_HGQ_TIMEOUT_PERIOD_8822C(x) \
(((x) & BIT_MASK_HGQ_TIMEOUT_PERIOD_8822C) \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822C)
#define BITS_HGQ_TIMEOUT_PERIOD_8822C \
(BIT_MASK_HGQ_TIMEOUT_PERIOD_8822C \
<< BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822C)
#define BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8822C(x) \
((x) & (~BITS_HGQ_TIMEOUT_PERIOD_8822C))
#define BIT_GET_HGQ_TIMEOUT_PERIOD_8822C(x) \
(((x) >> BIT_SHIFT_HGQ_TIMEOUT_PERIOD_8822C) & \
BIT_MASK_HGQ_TIMEOUT_PERIOD_8822C)
#define BIT_SET_HGQ_TIMEOUT_PERIOD_8822C(x, v) \
(BIT_CLEAR_HGQ_TIMEOUT_PERIOD_8822C(x) | \
BIT_HGQ_TIMEOUT_PERIOD_8822C(v))
/* 2 REG_TXCMD_TIMEOUT_PERIOD_8822C */
#define BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822C 0
#define BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822C 0xff
#define BIT_TXCMD_TIMEOUT_PERIOD_8822C(x) \
(((x) & BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822C) \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822C)
#define BITS_TXCMD_TIMEOUT_PERIOD_8822C \
(BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822C \
<< BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822C)
#define BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8822C(x) \
((x) & (~BITS_TXCMD_TIMEOUT_PERIOD_8822C))
#define BIT_GET_TXCMD_TIMEOUT_PERIOD_8822C(x) \
(((x) >> BIT_SHIFT_TXCMD_TIMEOUT_PERIOD_8822C) & \
BIT_MASK_TXCMD_TIMEOUT_PERIOD_8822C)
#define BIT_SET_TXCMD_TIMEOUT_PERIOD_8822C(x, v) \
(BIT_CLEAR_TXCMD_TIMEOUT_PERIOD_8822C(x) | \
BIT_TXCMD_TIMEOUT_PERIOD_8822C(v))
/* 2 REG_MISC_CTRL_8822C */
#define BIT_DIS_MARK_TSF_US_V2_8822C BIT(7)
#define BIT_AUTO_SYNC_BY_TBTT_8822C BIT(6)
#define BIT_DIS_TRX_CAL_BCN_8822C BIT(5)
#define BIT_DIS_TX_CAL_TBTT_8822C BIT(4)
#define BIT_EN_FREECNT_8822C BIT(3)
#define BIT_BCN_AGGRESSION_8822C BIT(2)
#define BIT_SHIFT_DIS_SECONDARY_CCA_8822C 0
#define BIT_MASK_DIS_SECONDARY_CCA_8822C 0x3
#define BIT_DIS_SECONDARY_CCA_8822C(x) \
(((x) & BIT_MASK_DIS_SECONDARY_CCA_8822C) \
<< BIT_SHIFT_DIS_SECONDARY_CCA_8822C)
#define BITS_DIS_SECONDARY_CCA_8822C \
(BIT_MASK_DIS_SECONDARY_CCA_8822C << BIT_SHIFT_DIS_SECONDARY_CCA_8822C)
#define BIT_CLEAR_DIS_SECONDARY_CCA_8822C(x) \
((x) & (~BITS_DIS_SECONDARY_CCA_8822C))
#define BIT_GET_DIS_SECONDARY_CCA_8822C(x) \
(((x) >> BIT_SHIFT_DIS_SECONDARY_CCA_8822C) & \
BIT_MASK_DIS_SECONDARY_CCA_8822C)
#define BIT_SET_DIS_SECONDARY_CCA_8822C(x, v) \
(BIT_CLEAR_DIS_SECONDARY_CCA_8822C(x) | BIT_DIS_SECONDARY_CCA_8822C(v))
/* 2 REG_BCN_CTRL_CLINT1_8822C */
#define BIT_CLI1_DIS_RX_BSSID_FIT_8822C BIT(6)
#define BIT_CLI1_DIS_TSF_UDT_8822C BIT(4)
#define BIT_CLI1_EN_BCN_FUNCTION_8822C BIT(3)
#define BIT_CLI1_EN_RXBCN_RPT_8822C BIT(2)
#define BIT_CLI1_ENP2P_CTWINDOW_8822C BIT(1)
#define BIT_CLI1_ENP2P_BCNQ_AREA_8822C BIT(0)
/* 2 REG_BCN_CTRL_CLINT2_8822C */
#define BIT_CLI2_DIS_RX_BSSID_FIT_8822C BIT(6)
#define BIT_CLI2_DIS_TSF_UDT_8822C BIT(4)
#define BIT_CLI2_EN_BCN_FUNCTION_8822C BIT(3)
#define BIT_CLI2_EN_RXBCN_RPT_8822C BIT(2)
#define BIT_CLI2_ENP2P_CTWINDOW_8822C BIT(1)
#define BIT_CLI2_ENP2P_BCNQ_AREA_8822C BIT(0)
/* 2 REG_BCN_CTRL_CLINT3_8822C */
#define BIT_CLI3_DIS_RX_BSSID_FIT_8822C BIT(6)
#define BIT_CLI3_DIS_TSF_UDT_8822C BIT(4)
#define BIT_CLI3_EN_BCN_FUNCTION_8822C BIT(3)
#define BIT_CLI3_EN_RXBCN_RPT_8822C BIT(2)
#define BIT_CLI3_ENP2P_CTWINDOW_8822C BIT(1)
#define BIT_CLI3_ENP2P_BCNQ_AREA_8822C BIT(0)
/* 2 REG_EXTEND_CTRL_8822C */
#define BIT_EN_TSFBIT32_RST_P2P2_8822C BIT(5)
#define BIT_EN_TSFBIT32_RST_P2P1_8822C BIT(4)
#define BIT_SHIFT_PORT_SEL_8822C 0
#define BIT_MASK_PORT_SEL_8822C 0x7
#define BIT_PORT_SEL_8822C(x) \
(((x) & BIT_MASK_PORT_SEL_8822C) << BIT_SHIFT_PORT_SEL_8822C)
#define BITS_PORT_SEL_8822C \
(BIT_MASK_PORT_SEL_8822C << BIT_SHIFT_PORT_SEL_8822C)
#define BIT_CLEAR_PORT_SEL_8822C(x) ((x) & (~BITS_PORT_SEL_8822C))
#define BIT_GET_PORT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_PORT_SEL_8822C) & BIT_MASK_PORT_SEL_8822C)
#define BIT_SET_PORT_SEL_8822C(x, v) \
(BIT_CLEAR_PORT_SEL_8822C(x) | BIT_PORT_SEL_8822C(v))
/* 2 REG_P2PPS1_SPEC_STATE_8822C */
#define BIT_P2P1_SPEC_POWER_STATE_8822C BIT(7)
#define BIT_P2P1_SPEC_CTWINDOW_ON_8822C BIT(6)
#define BIT_P2P1_SPEC_BCN_AREA_ON_8822C BIT(5)
#define BIT_P2P1_SPEC_CTWIN_EARLY_DISTX_8822C BIT(4)
#define BIT_P2P1_SPEC_NOA1_OFF_PERIOD_8822C BIT(3)
#define BIT_P2P1_SPEC_FORCE_DOZE1_8822C BIT(2)
#define BIT_P2P1_SPEC_NOA0_OFF_PERIOD_8822C BIT(1)
#define BIT_P2P1_SPEC_FORCE_DOZE0_8822C BIT(0)
/* 2 REG_P2PPS1_STATE_8822C */
#define BIT_P2P1_POWER_STATE_8822C BIT(7)
#define BIT_P2P1_CTWINDOW_ON_8822C BIT(6)
#define BIT_P2P1_BEACON_AREA_ON_8822C BIT(5)
#define BIT_P2P1_CTWIN_EARLY_DISTX_8822C BIT(4)
#define BIT_P2P1_NOA1_OFF_PERIOD_8822C BIT(3)
#define BIT_P2P1_FORCE_DOZE1_8822C BIT(2)
#define BIT_P2P1_NOA0_OFF_PERIOD_8822C BIT(1)
#define BIT_P2P1_FORCE_DOZE0_8822C BIT(0)
/* 2 REG_P2PPS2_SPEC_STATE_8822C */
#define BIT_P2P2_SPEC_POWER_STATE_8822C BIT(7)
#define BIT_P2P2_SPEC_CTWINDOW_ON_8822C BIT(6)
#define BIT_P2P2_SPEC_BCN_AREA_ON_8822C BIT(5)
#define BIT_P2P2_SPEC_CTWIN_EARLY_DISTX_8822C BIT(4)
#define BIT_P2P2_SPEC_NOA1_OFF_PERIOD_8822C BIT(3)
#define BIT_P2P2_SPEC_FORCE_DOZE1_8822C BIT(2)
#define BIT_P2P2_SPEC_NOA0_OFF_PERIOD_8822C BIT(1)
#define BIT_P2P2_SPEC_FORCE_DOZE0_8822C BIT(0)
/* 2 REG_P2PPS2_STATE_8822C */
#define BIT_P2P2_POWER_STATE_8822C BIT(7)
#define BIT_P2P2_CTWINDOW_ON_8822C BIT(6)
#define BIT_P2P2_BEACON_AREA_ON_8822C BIT(5)
#define BIT_P2P2_CTWIN_EARLY_DISTX_8822C BIT(4)
#define BIT_P2P2_NOA1_OFF_PERIOD_8822C BIT(3)
#define BIT_P2P2_FORCE_DOZE1_8822C BIT(2)
#define BIT_P2P2_NOA0_OFF_PERIOD_8822C BIT(1)
#define BIT_P2P2_FORCE_DOZE0_8822C BIT(0)
/* 2 REG_PS_TIMER0_8822C */
#define BIT_SHIFT_PSTIMER0_INT_8822C 5
#define BIT_MASK_PSTIMER0_INT_8822C 0x7ffffff
#define BIT_PSTIMER0_INT_8822C(x) \
(((x) & BIT_MASK_PSTIMER0_INT_8822C) << BIT_SHIFT_PSTIMER0_INT_8822C)
#define BITS_PSTIMER0_INT_8822C \
(BIT_MASK_PSTIMER0_INT_8822C << BIT_SHIFT_PSTIMER0_INT_8822C)
#define BIT_CLEAR_PSTIMER0_INT_8822C(x) ((x) & (~BITS_PSTIMER0_INT_8822C))
#define BIT_GET_PSTIMER0_INT_8822C(x) \
(((x) >> BIT_SHIFT_PSTIMER0_INT_8822C) & BIT_MASK_PSTIMER0_INT_8822C)
#define BIT_SET_PSTIMER0_INT_8822C(x, v) \
(BIT_CLEAR_PSTIMER0_INT_8822C(x) | BIT_PSTIMER0_INT_8822C(v))
/* 2 REG_PS_TIMER1_8822C */
#define BIT_SHIFT_PSTIMER1_INT_8822C 5
#define BIT_MASK_PSTIMER1_INT_8822C 0x7ffffff
#define BIT_PSTIMER1_INT_8822C(x) \
(((x) & BIT_MASK_PSTIMER1_INT_8822C) << BIT_SHIFT_PSTIMER1_INT_8822C)
#define BITS_PSTIMER1_INT_8822C \
(BIT_MASK_PSTIMER1_INT_8822C << BIT_SHIFT_PSTIMER1_INT_8822C)
#define BIT_CLEAR_PSTIMER1_INT_8822C(x) ((x) & (~BITS_PSTIMER1_INT_8822C))
#define BIT_GET_PSTIMER1_INT_8822C(x) \
(((x) >> BIT_SHIFT_PSTIMER1_INT_8822C) & BIT_MASK_PSTIMER1_INT_8822C)
#define BIT_SET_PSTIMER1_INT_8822C(x, v) \
(BIT_CLEAR_PSTIMER1_INT_8822C(x) | BIT_PSTIMER1_INT_8822C(v))
/* 2 REG_PS_TIMER2_8822C */
#define BIT_SHIFT_PSTIMER2_INT_8822C 5
#define BIT_MASK_PSTIMER2_INT_8822C 0x7ffffff
#define BIT_PSTIMER2_INT_8822C(x) \
(((x) & BIT_MASK_PSTIMER2_INT_8822C) << BIT_SHIFT_PSTIMER2_INT_8822C)
#define BITS_PSTIMER2_INT_8822C \
(BIT_MASK_PSTIMER2_INT_8822C << BIT_SHIFT_PSTIMER2_INT_8822C)
#define BIT_CLEAR_PSTIMER2_INT_8822C(x) ((x) & (~BITS_PSTIMER2_INT_8822C))
#define BIT_GET_PSTIMER2_INT_8822C(x) \
(((x) >> BIT_SHIFT_PSTIMER2_INT_8822C) & BIT_MASK_PSTIMER2_INT_8822C)
#define BIT_SET_PSTIMER2_INT_8822C(x, v) \
(BIT_CLEAR_PSTIMER2_INT_8822C(x) | BIT_PSTIMER2_INT_8822C(v))
/* 2 REG_TBTT_CTN_AREA_8822C */
#define BIT_SHIFT_TBTT_CTN_AREA_8822C 0
#define BIT_MASK_TBTT_CTN_AREA_8822C 0xff
#define BIT_TBTT_CTN_AREA_8822C(x) \
(((x) & BIT_MASK_TBTT_CTN_AREA_8822C) << BIT_SHIFT_TBTT_CTN_AREA_8822C)
#define BITS_TBTT_CTN_AREA_8822C \
(BIT_MASK_TBTT_CTN_AREA_8822C << BIT_SHIFT_TBTT_CTN_AREA_8822C)
#define BIT_CLEAR_TBTT_CTN_AREA_8822C(x) ((x) & (~BITS_TBTT_CTN_AREA_8822C))
#define BIT_GET_TBTT_CTN_AREA_8822C(x) \
(((x) >> BIT_SHIFT_TBTT_CTN_AREA_8822C) & BIT_MASK_TBTT_CTN_AREA_8822C)
#define BIT_SET_TBTT_CTN_AREA_8822C(x, v) \
(BIT_CLEAR_TBTT_CTN_AREA_8822C(x) | BIT_TBTT_CTN_AREA_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_FORCE_BCN_IFS_8822C */
#define BIT_SHIFT_FORCE_BCN_IFS_8822C 0
#define BIT_MASK_FORCE_BCN_IFS_8822C 0xff
#define BIT_FORCE_BCN_IFS_8822C(x) \
(((x) & BIT_MASK_FORCE_BCN_IFS_8822C) << BIT_SHIFT_FORCE_BCN_IFS_8822C)
#define BITS_FORCE_BCN_IFS_8822C \
(BIT_MASK_FORCE_BCN_IFS_8822C << BIT_SHIFT_FORCE_BCN_IFS_8822C)
#define BIT_CLEAR_FORCE_BCN_IFS_8822C(x) ((x) & (~BITS_FORCE_BCN_IFS_8822C))
#define BIT_GET_FORCE_BCN_IFS_8822C(x) \
(((x) >> BIT_SHIFT_FORCE_BCN_IFS_8822C) & BIT_MASK_FORCE_BCN_IFS_8822C)
#define BIT_SET_FORCE_BCN_IFS_8822C(x, v) \
(BIT_CLEAR_FORCE_BCN_IFS_8822C(x) | BIT_FORCE_BCN_IFS_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_TXOP_MIN_8822C */
#define BIT_HIQ_NAV_BREAK_EN_8822C BIT(15)
#define BIT_MGQ_NAV_BREAK_EN_8822C BIT(14)
#define BIT_SHIFT_TXOP_MIN_8822C 0
#define BIT_MASK_TXOP_MIN_8822C 0x3fff
#define BIT_TXOP_MIN_8822C(x) \
(((x) & BIT_MASK_TXOP_MIN_8822C) << BIT_SHIFT_TXOP_MIN_8822C)
#define BITS_TXOP_MIN_8822C \
(BIT_MASK_TXOP_MIN_8822C << BIT_SHIFT_TXOP_MIN_8822C)
#define BIT_CLEAR_TXOP_MIN_8822C(x) ((x) & (~BITS_TXOP_MIN_8822C))
#define BIT_GET_TXOP_MIN_8822C(x) \
(((x) >> BIT_SHIFT_TXOP_MIN_8822C) & BIT_MASK_TXOP_MIN_8822C)
#define BIT_SET_TXOP_MIN_8822C(x, v) \
(BIT_CLEAR_TXOP_MIN_8822C(x) | BIT_TXOP_MIN_8822C(v))
/* 2 REG_PRE_BKF_TIME_8822C */
#define BIT_SHIFT_PRE_BKF_TIME_8822C 0
#define BIT_MASK_PRE_BKF_TIME_8822C 0xff
#define BIT_PRE_BKF_TIME_8822C(x) \
(((x) & BIT_MASK_PRE_BKF_TIME_8822C) << BIT_SHIFT_PRE_BKF_TIME_8822C)
#define BITS_PRE_BKF_TIME_8822C \
(BIT_MASK_PRE_BKF_TIME_8822C << BIT_SHIFT_PRE_BKF_TIME_8822C)
#define BIT_CLEAR_PRE_BKF_TIME_8822C(x) ((x) & (~BITS_PRE_BKF_TIME_8822C))
#define BIT_GET_PRE_BKF_TIME_8822C(x) \
(((x) >> BIT_SHIFT_PRE_BKF_TIME_8822C) & BIT_MASK_PRE_BKF_TIME_8822C)
#define BIT_SET_PRE_BKF_TIME_8822C(x, v) \
(BIT_CLEAR_PRE_BKF_TIME_8822C(x) | BIT_PRE_BKF_TIME_8822C(v))
/* 2 REG_CROSS_TXOP_CTRL_8822C */
#define BIT_TXFAIL_BREACK_TXOP_EN_8822C BIT(3)
#define BIT_DTIM_BYPASS_8822C BIT(2)
#define BIT_RTS_NAV_TXOP_8822C BIT(1)
#define BIT_NOT_CROSS_TXOP_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_RX_TBTT_SHIFT_V1_8822C */
#define BIT_RX_TBTT_SHIFT_RW_FLAG_V1_8822C BIT(31)
#define BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1_8822C 16
#define BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1_8822C 0xfff
#define BIT_RX_TBTT_SHIFT_OFFSET_V1_8822C(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1_8822C) \
<< BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1_8822C)
#define BITS_RX_TBTT_SHIFT_OFFSET_V1_8822C \
(BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1_8822C \
<< BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1_8822C)
#define BIT_CLEAR_RX_TBTT_SHIFT_OFFSET_V1_8822C(x) \
((x) & (~BITS_RX_TBTT_SHIFT_OFFSET_V1_8822C))
#define BIT_GET_RX_TBTT_SHIFT_OFFSET_V1_8822C(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_OFFSET_V1_8822C) & \
BIT_MASK_RX_TBTT_SHIFT_OFFSET_V1_8822C)
#define BIT_SET_RX_TBTT_SHIFT_OFFSET_V1_8822C(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_OFFSET_V1_8822C(x) | \
BIT_RX_TBTT_SHIFT_OFFSET_V1_8822C(v))
#define BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1_8822C 8
#define BIT_MASK_RX_TBTT_SHIFT_SEL_V1_8822C 0x7
#define BIT_RX_TBTT_SHIFT_SEL_V1_8822C(x) \
(((x) & BIT_MASK_RX_TBTT_SHIFT_SEL_V1_8822C) \
<< BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1_8822C)
#define BITS_RX_TBTT_SHIFT_SEL_V1_8822C \
(BIT_MASK_RX_TBTT_SHIFT_SEL_V1_8822C \
<< BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1_8822C)
#define BIT_CLEAR_RX_TBTT_SHIFT_SEL_V1_8822C(x) \
((x) & (~BITS_RX_TBTT_SHIFT_SEL_V1_8822C))
#define BIT_GET_RX_TBTT_SHIFT_SEL_V1_8822C(x) \
(((x) >> BIT_SHIFT_RX_TBTT_SHIFT_SEL_V1_8822C) & \
BIT_MASK_RX_TBTT_SHIFT_SEL_V1_8822C)
#define BIT_SET_RX_TBTT_SHIFT_SEL_V1_8822C(x, v) \
(BIT_CLEAR_RX_TBTT_SHIFT_SEL_V1_8822C(x) | \
BIT_RX_TBTT_SHIFT_SEL_V1_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_ATIMWND2_8822C */
#define BIT_SHIFT_ATIMWND2_8822C 0
#define BIT_MASK_ATIMWND2_8822C 0xff
#define BIT_ATIMWND2_8822C(x) \
(((x) & BIT_MASK_ATIMWND2_8822C) << BIT_SHIFT_ATIMWND2_8822C)
#define BITS_ATIMWND2_8822C \
(BIT_MASK_ATIMWND2_8822C << BIT_SHIFT_ATIMWND2_8822C)
#define BIT_CLEAR_ATIMWND2_8822C(x) ((x) & (~BITS_ATIMWND2_8822C))
#define BIT_GET_ATIMWND2_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND2_8822C) & BIT_MASK_ATIMWND2_8822C)
#define BIT_SET_ATIMWND2_8822C(x, v) \
(BIT_CLEAR_ATIMWND2_8822C(x) | BIT_ATIMWND2_8822C(v))
/* 2 REG_ATIMWND3_8822C */
#define BIT_SHIFT_ATIMWND3_8822C 0
#define BIT_MASK_ATIMWND3_8822C 0xff
#define BIT_ATIMWND3_8822C(x) \
(((x) & BIT_MASK_ATIMWND3_8822C) << BIT_SHIFT_ATIMWND3_8822C)
#define BITS_ATIMWND3_8822C \
(BIT_MASK_ATIMWND3_8822C << BIT_SHIFT_ATIMWND3_8822C)
#define BIT_CLEAR_ATIMWND3_8822C(x) ((x) & (~BITS_ATIMWND3_8822C))
#define BIT_GET_ATIMWND3_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND3_8822C) & BIT_MASK_ATIMWND3_8822C)
#define BIT_SET_ATIMWND3_8822C(x, v) \
(BIT_CLEAR_ATIMWND3_8822C(x) | BIT_ATIMWND3_8822C(v))
/* 2 REG_ATIMWND4_8822C */
#define BIT_SHIFT_ATIMWND4_8822C 0
#define BIT_MASK_ATIMWND4_8822C 0xff
#define BIT_ATIMWND4_8822C(x) \
(((x) & BIT_MASK_ATIMWND4_8822C) << BIT_SHIFT_ATIMWND4_8822C)
#define BITS_ATIMWND4_8822C \
(BIT_MASK_ATIMWND4_8822C << BIT_SHIFT_ATIMWND4_8822C)
#define BIT_CLEAR_ATIMWND4_8822C(x) ((x) & (~BITS_ATIMWND4_8822C))
#define BIT_GET_ATIMWND4_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND4_8822C) & BIT_MASK_ATIMWND4_8822C)
#define BIT_SET_ATIMWND4_8822C(x, v) \
(BIT_CLEAR_ATIMWND4_8822C(x) | BIT_ATIMWND4_8822C(v))
/* 2 REG_ATIMWND5_8822C */
#define BIT_SHIFT_ATIMWND5_8822C 0
#define BIT_MASK_ATIMWND5_8822C 0xff
#define BIT_ATIMWND5_8822C(x) \
(((x) & BIT_MASK_ATIMWND5_8822C) << BIT_SHIFT_ATIMWND5_8822C)
#define BITS_ATIMWND5_8822C \
(BIT_MASK_ATIMWND5_8822C << BIT_SHIFT_ATIMWND5_8822C)
#define BIT_CLEAR_ATIMWND5_8822C(x) ((x) & (~BITS_ATIMWND5_8822C))
#define BIT_GET_ATIMWND5_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND5_8822C) & BIT_MASK_ATIMWND5_8822C)
#define BIT_SET_ATIMWND5_8822C(x, v) \
(BIT_CLEAR_ATIMWND5_8822C(x) | BIT_ATIMWND5_8822C(v))
/* 2 REG_ATIMWND6_8822C */
#define BIT_SHIFT_ATIMWND6_8822C 0
#define BIT_MASK_ATIMWND6_8822C 0xff
#define BIT_ATIMWND6_8822C(x) \
(((x) & BIT_MASK_ATIMWND6_8822C) << BIT_SHIFT_ATIMWND6_8822C)
#define BITS_ATIMWND6_8822C \
(BIT_MASK_ATIMWND6_8822C << BIT_SHIFT_ATIMWND6_8822C)
#define BIT_CLEAR_ATIMWND6_8822C(x) ((x) & (~BITS_ATIMWND6_8822C))
#define BIT_GET_ATIMWND6_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND6_8822C) & BIT_MASK_ATIMWND6_8822C)
#define BIT_SET_ATIMWND6_8822C(x, v) \
(BIT_CLEAR_ATIMWND6_8822C(x) | BIT_ATIMWND6_8822C(v))
/* 2 REG_ATIMWND7_8822C */
#define BIT_SHIFT_ATIMWND7_8822C 0
#define BIT_MASK_ATIMWND7_8822C 0xff
#define BIT_ATIMWND7_8822C(x) \
(((x) & BIT_MASK_ATIMWND7_8822C) << BIT_SHIFT_ATIMWND7_8822C)
#define BITS_ATIMWND7_8822C \
(BIT_MASK_ATIMWND7_8822C << BIT_SHIFT_ATIMWND7_8822C)
#define BIT_CLEAR_ATIMWND7_8822C(x) ((x) & (~BITS_ATIMWND7_8822C))
#define BIT_GET_ATIMWND7_8822C(x) \
(((x) >> BIT_SHIFT_ATIMWND7_8822C) & BIT_MASK_ATIMWND7_8822C)
#define BIT_SET_ATIMWND7_8822C(x, v) \
(BIT_CLEAR_ATIMWND7_8822C(x) | BIT_ATIMWND7_8822C(v))
/* 2 REG_ATIMUGT_8822C */
#define BIT_SHIFT_ATIM_URGENT_8822C 0
#define BIT_MASK_ATIM_URGENT_8822C 0xff
#define BIT_ATIM_URGENT_8822C(x) \
(((x) & BIT_MASK_ATIM_URGENT_8822C) << BIT_SHIFT_ATIM_URGENT_8822C)
#define BITS_ATIM_URGENT_8822C \
(BIT_MASK_ATIM_URGENT_8822C << BIT_SHIFT_ATIM_URGENT_8822C)
#define BIT_CLEAR_ATIM_URGENT_8822C(x) ((x) & (~BITS_ATIM_URGENT_8822C))
#define BIT_GET_ATIM_URGENT_8822C(x) \
(((x) >> BIT_SHIFT_ATIM_URGENT_8822C) & BIT_MASK_ATIM_URGENT_8822C)
#define BIT_SET_ATIM_URGENT_8822C(x, v) \
(BIT_CLEAR_ATIM_URGENT_8822C(x) | BIT_ATIM_URGENT_8822C(v))
/* 2 REG_HIQ_NO_LMT_EN_8822C */
#define BIT_HIQ_NO_LMT_EN_VAP7_8822C BIT(7)
#define BIT_HIQ_NO_LMT_EN_VAP6_8822C BIT(6)
#define BIT_HIQ_NO_LMT_EN_VAP5_8822C BIT(5)
#define BIT_HIQ_NO_LMT_EN_VAP4_8822C BIT(4)
#define BIT_HIQ_NO_LMT_EN_VAP3_8822C BIT(3)
#define BIT_HIQ_NO_LMT_EN_VAP2_8822C BIT(2)
#define BIT_HIQ_NO_LMT_EN_VAP1_8822C BIT(1)
#define BIT_HIQ_NO_LMT_EN_ROOT_8822C BIT(0)
/* 2 REG_DTIM_COUNTER_ROOT_8822C */
#define BIT_SHIFT_DTIM_COUNT_ROOT_8822C 0
#define BIT_MASK_DTIM_COUNT_ROOT_8822C 0xff
#define BIT_DTIM_COUNT_ROOT_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_ROOT_8822C) \
<< BIT_SHIFT_DTIM_COUNT_ROOT_8822C)
#define BITS_DTIM_COUNT_ROOT_8822C \
(BIT_MASK_DTIM_COUNT_ROOT_8822C << BIT_SHIFT_DTIM_COUNT_ROOT_8822C)
#define BIT_CLEAR_DTIM_COUNT_ROOT_8822C(x) ((x) & (~BITS_DTIM_COUNT_ROOT_8822C))
#define BIT_GET_DTIM_COUNT_ROOT_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_ROOT_8822C) & \
BIT_MASK_DTIM_COUNT_ROOT_8822C)
#define BIT_SET_DTIM_COUNT_ROOT_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_ROOT_8822C(x) | BIT_DTIM_COUNT_ROOT_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP1_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP1_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP1_8822C 0xff
#define BIT_DTIM_COUNT_VAP1_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP1_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP1_8822C)
#define BITS_DTIM_COUNT_VAP1_8822C \
(BIT_MASK_DTIM_COUNT_VAP1_8822C << BIT_SHIFT_DTIM_COUNT_VAP1_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP1_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP1_8822C))
#define BIT_GET_DTIM_COUNT_VAP1_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP1_8822C) & \
BIT_MASK_DTIM_COUNT_VAP1_8822C)
#define BIT_SET_DTIM_COUNT_VAP1_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP1_8822C(x) | BIT_DTIM_COUNT_VAP1_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP2_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP2_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP2_8822C 0xff
#define BIT_DTIM_COUNT_VAP2_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP2_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP2_8822C)
#define BITS_DTIM_COUNT_VAP2_8822C \
(BIT_MASK_DTIM_COUNT_VAP2_8822C << BIT_SHIFT_DTIM_COUNT_VAP2_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP2_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP2_8822C))
#define BIT_GET_DTIM_COUNT_VAP2_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP2_8822C) & \
BIT_MASK_DTIM_COUNT_VAP2_8822C)
#define BIT_SET_DTIM_COUNT_VAP2_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP2_8822C(x) | BIT_DTIM_COUNT_VAP2_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP3_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP3_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP3_8822C 0xff
#define BIT_DTIM_COUNT_VAP3_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP3_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP3_8822C)
#define BITS_DTIM_COUNT_VAP3_8822C \
(BIT_MASK_DTIM_COUNT_VAP3_8822C << BIT_SHIFT_DTIM_COUNT_VAP3_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP3_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP3_8822C))
#define BIT_GET_DTIM_COUNT_VAP3_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP3_8822C) & \
BIT_MASK_DTIM_COUNT_VAP3_8822C)
#define BIT_SET_DTIM_COUNT_VAP3_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP3_8822C(x) | BIT_DTIM_COUNT_VAP3_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP4_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP4_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP4_8822C 0xff
#define BIT_DTIM_COUNT_VAP4_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP4_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP4_8822C)
#define BITS_DTIM_COUNT_VAP4_8822C \
(BIT_MASK_DTIM_COUNT_VAP4_8822C << BIT_SHIFT_DTIM_COUNT_VAP4_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP4_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP4_8822C))
#define BIT_GET_DTIM_COUNT_VAP4_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP4_8822C) & \
BIT_MASK_DTIM_COUNT_VAP4_8822C)
#define BIT_SET_DTIM_COUNT_VAP4_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP4_8822C(x) | BIT_DTIM_COUNT_VAP4_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP5_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP5_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP5_8822C 0xff
#define BIT_DTIM_COUNT_VAP5_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP5_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP5_8822C)
#define BITS_DTIM_COUNT_VAP5_8822C \
(BIT_MASK_DTIM_COUNT_VAP5_8822C << BIT_SHIFT_DTIM_COUNT_VAP5_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP5_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP5_8822C))
#define BIT_GET_DTIM_COUNT_VAP5_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP5_8822C) & \
BIT_MASK_DTIM_COUNT_VAP5_8822C)
#define BIT_SET_DTIM_COUNT_VAP5_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP5_8822C(x) | BIT_DTIM_COUNT_VAP5_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP6_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP6_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP6_8822C 0xff
#define BIT_DTIM_COUNT_VAP6_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP6_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP6_8822C)
#define BITS_DTIM_COUNT_VAP6_8822C \
(BIT_MASK_DTIM_COUNT_VAP6_8822C << BIT_SHIFT_DTIM_COUNT_VAP6_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP6_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP6_8822C))
#define BIT_GET_DTIM_COUNT_VAP6_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP6_8822C) & \
BIT_MASK_DTIM_COUNT_VAP6_8822C)
#define BIT_SET_DTIM_COUNT_VAP6_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP6_8822C(x) | BIT_DTIM_COUNT_VAP6_8822C(v))
/* 2 REG_DTIM_COUNTER_VAP7_8822C */
#define BIT_SHIFT_DTIM_COUNT_VAP7_8822C 0
#define BIT_MASK_DTIM_COUNT_VAP7_8822C 0xff
#define BIT_DTIM_COUNT_VAP7_8822C(x) \
(((x) & BIT_MASK_DTIM_COUNT_VAP7_8822C) \
<< BIT_SHIFT_DTIM_COUNT_VAP7_8822C)
#define BITS_DTIM_COUNT_VAP7_8822C \
(BIT_MASK_DTIM_COUNT_VAP7_8822C << BIT_SHIFT_DTIM_COUNT_VAP7_8822C)
#define BIT_CLEAR_DTIM_COUNT_VAP7_8822C(x) ((x) & (~BITS_DTIM_COUNT_VAP7_8822C))
#define BIT_GET_DTIM_COUNT_VAP7_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_COUNT_VAP7_8822C) & \
BIT_MASK_DTIM_COUNT_VAP7_8822C)
#define BIT_SET_DTIM_COUNT_VAP7_8822C(x, v) \
(BIT_CLEAR_DTIM_COUNT_VAP7_8822C(x) | BIT_DTIM_COUNT_VAP7_8822C(v))
/* 2 REG_DIS_ATIM_8822C */
#define BIT_DIS_ATIM_VAP7_8822C BIT(7)
#define BIT_DIS_ATIM_VAP6_8822C BIT(6)
#define BIT_DIS_ATIM_VAP5_8822C BIT(5)
#define BIT_DIS_ATIM_VAP4_8822C BIT(4)
#define BIT_DIS_ATIM_VAP3_8822C BIT(3)
#define BIT_DIS_ATIM_VAP2_8822C BIT(2)
#define BIT_DIS_ATIM_VAP1_8822C BIT(1)
#define BIT_DIS_ATIM_ROOT_8822C BIT(0)
/* 2 REG_EARLY_128US_8822C */
#define BIT_SHIFT_TSFT_SEL_TIMER1_8822C 3
#define BIT_MASK_TSFT_SEL_TIMER1_8822C 0x7
#define BIT_TSFT_SEL_TIMER1_8822C(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER1_8822C) \
<< BIT_SHIFT_TSFT_SEL_TIMER1_8822C)
#define BITS_TSFT_SEL_TIMER1_8822C \
(BIT_MASK_TSFT_SEL_TIMER1_8822C << BIT_SHIFT_TSFT_SEL_TIMER1_8822C)
#define BIT_CLEAR_TSFT_SEL_TIMER1_8822C(x) ((x) & (~BITS_TSFT_SEL_TIMER1_8822C))
#define BIT_GET_TSFT_SEL_TIMER1_8822C(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER1_8822C) & \
BIT_MASK_TSFT_SEL_TIMER1_8822C)
#define BIT_SET_TSFT_SEL_TIMER1_8822C(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER1_8822C(x) | BIT_TSFT_SEL_TIMER1_8822C(v))
#define BIT_SHIFT_EARLY_128US_8822C 0
#define BIT_MASK_EARLY_128US_8822C 0x7
#define BIT_EARLY_128US_8822C(x) \
(((x) & BIT_MASK_EARLY_128US_8822C) << BIT_SHIFT_EARLY_128US_8822C)
#define BITS_EARLY_128US_8822C \
(BIT_MASK_EARLY_128US_8822C << BIT_SHIFT_EARLY_128US_8822C)
#define BIT_CLEAR_EARLY_128US_8822C(x) ((x) & (~BITS_EARLY_128US_8822C))
#define BIT_GET_EARLY_128US_8822C(x) \
(((x) >> BIT_SHIFT_EARLY_128US_8822C) & BIT_MASK_EARLY_128US_8822C)
#define BIT_SET_EARLY_128US_8822C(x, v) \
(BIT_CLEAR_EARLY_128US_8822C(x) | BIT_EARLY_128US_8822C(v))
/* 2 REG_P2PPS1_CTRL_8822C */
#define BIT_P2P1_CTW_ALLSTASLEEP_8822C BIT(7)
#define BIT_P2P1_OFF_DISTX_EN_8822C BIT(6)
#define BIT_P2P1_PWR_MGT_EN_8822C BIT(5)
#define BIT_P2P1_NOA1_EN_8822C BIT(2)
#define BIT_P2P1_NOA0_EN_8822C BIT(1)
/* 2 REG_P2PPS2_CTRL_8822C */
#define BIT_P2P2_CTW_ALLSTASLEEP_8822C BIT(7)
#define BIT_P2P2_OFF_DISTX_EN_8822C BIT(6)
#define BIT_P2P2_PWR_MGT_EN_8822C BIT(5)
#define BIT_P2P2_NOA1_EN_8822C BIT(2)
#define BIT_P2P2_NOA0_EN_8822C BIT(1)
/* 2 REG_TIMER0_SRC_SEL_8822C */
#define BIT_SHIFT_SYNC_CLI_SEL_8822C 4
#define BIT_MASK_SYNC_CLI_SEL_8822C 0x7
#define BIT_SYNC_CLI_SEL_8822C(x) \
(((x) & BIT_MASK_SYNC_CLI_SEL_8822C) << BIT_SHIFT_SYNC_CLI_SEL_8822C)
#define BITS_SYNC_CLI_SEL_8822C \
(BIT_MASK_SYNC_CLI_SEL_8822C << BIT_SHIFT_SYNC_CLI_SEL_8822C)
#define BIT_CLEAR_SYNC_CLI_SEL_8822C(x) ((x) & (~BITS_SYNC_CLI_SEL_8822C))
#define BIT_GET_SYNC_CLI_SEL_8822C(x) \
(((x) >> BIT_SHIFT_SYNC_CLI_SEL_8822C) & BIT_MASK_SYNC_CLI_SEL_8822C)
#define BIT_SET_SYNC_CLI_SEL_8822C(x, v) \
(BIT_CLEAR_SYNC_CLI_SEL_8822C(x) | BIT_SYNC_CLI_SEL_8822C(v))
#define BIT_SHIFT_TSFT_SEL_TIMER0_8822C 0
#define BIT_MASK_TSFT_SEL_TIMER0_8822C 0x7
#define BIT_TSFT_SEL_TIMER0_8822C(x) \
(((x) & BIT_MASK_TSFT_SEL_TIMER0_8822C) \
<< BIT_SHIFT_TSFT_SEL_TIMER0_8822C)
#define BITS_TSFT_SEL_TIMER0_8822C \
(BIT_MASK_TSFT_SEL_TIMER0_8822C << BIT_SHIFT_TSFT_SEL_TIMER0_8822C)
#define BIT_CLEAR_TSFT_SEL_TIMER0_8822C(x) ((x) & (~BITS_TSFT_SEL_TIMER0_8822C))
#define BIT_GET_TSFT_SEL_TIMER0_8822C(x) \
(((x) >> BIT_SHIFT_TSFT_SEL_TIMER0_8822C) & \
BIT_MASK_TSFT_SEL_TIMER0_8822C)
#define BIT_SET_TSFT_SEL_TIMER0_8822C(x, v) \
(BIT_CLEAR_TSFT_SEL_TIMER0_8822C(x) | BIT_TSFT_SEL_TIMER0_8822C(v))
/* 2 REG_NOA_UNIT_SEL_8822C */
#define BIT_SHIFT_NOA_UNIT2_SEL_8822C 8
#define BIT_MASK_NOA_UNIT2_SEL_8822C 0x7
#define BIT_NOA_UNIT2_SEL_8822C(x) \
(((x) & BIT_MASK_NOA_UNIT2_SEL_8822C) << BIT_SHIFT_NOA_UNIT2_SEL_8822C)
#define BITS_NOA_UNIT2_SEL_8822C \
(BIT_MASK_NOA_UNIT2_SEL_8822C << BIT_SHIFT_NOA_UNIT2_SEL_8822C)
#define BIT_CLEAR_NOA_UNIT2_SEL_8822C(x) ((x) & (~BITS_NOA_UNIT2_SEL_8822C))
#define BIT_GET_NOA_UNIT2_SEL_8822C(x) \
(((x) >> BIT_SHIFT_NOA_UNIT2_SEL_8822C) & BIT_MASK_NOA_UNIT2_SEL_8822C)
#define BIT_SET_NOA_UNIT2_SEL_8822C(x, v) \
(BIT_CLEAR_NOA_UNIT2_SEL_8822C(x) | BIT_NOA_UNIT2_SEL_8822C(v))
#define BIT_SHIFT_NOA_UNIT1_SEL_8822C 4
#define BIT_MASK_NOA_UNIT1_SEL_8822C 0x7
#define BIT_NOA_UNIT1_SEL_8822C(x) \
(((x) & BIT_MASK_NOA_UNIT1_SEL_8822C) << BIT_SHIFT_NOA_UNIT1_SEL_8822C)
#define BITS_NOA_UNIT1_SEL_8822C \
(BIT_MASK_NOA_UNIT1_SEL_8822C << BIT_SHIFT_NOA_UNIT1_SEL_8822C)
#define BIT_CLEAR_NOA_UNIT1_SEL_8822C(x) ((x) & (~BITS_NOA_UNIT1_SEL_8822C))
#define BIT_GET_NOA_UNIT1_SEL_8822C(x) \
(((x) >> BIT_SHIFT_NOA_UNIT1_SEL_8822C) & BIT_MASK_NOA_UNIT1_SEL_8822C)
#define BIT_SET_NOA_UNIT1_SEL_8822C(x, v) \
(BIT_CLEAR_NOA_UNIT1_SEL_8822C(x) | BIT_NOA_UNIT1_SEL_8822C(v))
#define BIT_SHIFT_NOA_UNIT0_SEL_8822C 0
#define BIT_MASK_NOA_UNIT0_SEL_8822C 0x7
#define BIT_NOA_UNIT0_SEL_8822C(x) \
(((x) & BIT_MASK_NOA_UNIT0_SEL_8822C) << BIT_SHIFT_NOA_UNIT0_SEL_8822C)
#define BITS_NOA_UNIT0_SEL_8822C \
(BIT_MASK_NOA_UNIT0_SEL_8822C << BIT_SHIFT_NOA_UNIT0_SEL_8822C)
#define BIT_CLEAR_NOA_UNIT0_SEL_8822C(x) ((x) & (~BITS_NOA_UNIT0_SEL_8822C))
#define BIT_GET_NOA_UNIT0_SEL_8822C(x) \
(((x) >> BIT_SHIFT_NOA_UNIT0_SEL_8822C) & BIT_MASK_NOA_UNIT0_SEL_8822C)
#define BIT_SET_NOA_UNIT0_SEL_8822C(x, v) \
(BIT_CLEAR_NOA_UNIT0_SEL_8822C(x) | BIT_NOA_UNIT0_SEL_8822C(v))
/* 2 REG_P2POFF_DIS_TXTIME_8822C */
#define BIT_SHIFT_P2POFF_DIS_TXTIME_8822C 0
#define BIT_MASK_P2POFF_DIS_TXTIME_8822C 0xff
#define BIT_P2POFF_DIS_TXTIME_8822C(x) \
(((x) & BIT_MASK_P2POFF_DIS_TXTIME_8822C) \
<< BIT_SHIFT_P2POFF_DIS_TXTIME_8822C)
#define BITS_P2POFF_DIS_TXTIME_8822C \
(BIT_MASK_P2POFF_DIS_TXTIME_8822C << BIT_SHIFT_P2POFF_DIS_TXTIME_8822C)
#define BIT_CLEAR_P2POFF_DIS_TXTIME_8822C(x) \
((x) & (~BITS_P2POFF_DIS_TXTIME_8822C))
#define BIT_GET_P2POFF_DIS_TXTIME_8822C(x) \
(((x) >> BIT_SHIFT_P2POFF_DIS_TXTIME_8822C) & \
BIT_MASK_P2POFF_DIS_TXTIME_8822C)
#define BIT_SET_P2POFF_DIS_TXTIME_8822C(x, v) \
(BIT_CLEAR_P2POFF_DIS_TXTIME_8822C(x) | BIT_P2POFF_DIS_TXTIME_8822C(v))
/* 2 REG_MBSSID_BCN_SPACE2_8822C */
#define BIT_SHIFT_BCN_SPACE_CLINT2_8822C 16
#define BIT_MASK_BCN_SPACE_CLINT2_8822C 0xfff
#define BIT_BCN_SPACE_CLINT2_8822C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT2_8822C) \
<< BIT_SHIFT_BCN_SPACE_CLINT2_8822C)
#define BITS_BCN_SPACE_CLINT2_8822C \
(BIT_MASK_BCN_SPACE_CLINT2_8822C << BIT_SHIFT_BCN_SPACE_CLINT2_8822C)
#define BIT_CLEAR_BCN_SPACE_CLINT2_8822C(x) \
((x) & (~BITS_BCN_SPACE_CLINT2_8822C))
#define BIT_GET_BCN_SPACE_CLINT2_8822C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT2_8822C) & \
BIT_MASK_BCN_SPACE_CLINT2_8822C)
#define BIT_SET_BCN_SPACE_CLINT2_8822C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT2_8822C(x) | BIT_BCN_SPACE_CLINT2_8822C(v))
#define BIT_SHIFT_BCN_SPACE_CLINT1_8822C 0
#define BIT_MASK_BCN_SPACE_CLINT1_8822C 0xfff
#define BIT_BCN_SPACE_CLINT1_8822C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT1_8822C) \
<< BIT_SHIFT_BCN_SPACE_CLINT1_8822C)
#define BITS_BCN_SPACE_CLINT1_8822C \
(BIT_MASK_BCN_SPACE_CLINT1_8822C << BIT_SHIFT_BCN_SPACE_CLINT1_8822C)
#define BIT_CLEAR_BCN_SPACE_CLINT1_8822C(x) \
((x) & (~BITS_BCN_SPACE_CLINT1_8822C))
#define BIT_GET_BCN_SPACE_CLINT1_8822C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT1_8822C) & \
BIT_MASK_BCN_SPACE_CLINT1_8822C)
#define BIT_SET_BCN_SPACE_CLINT1_8822C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT1_8822C(x) | BIT_BCN_SPACE_CLINT1_8822C(v))
/* 2 REG_MBSSID_BCN_SPACE3_8822C */
#define BIT_SHIFT_SUB_BCN_SPACE_8822C 16
#define BIT_MASK_SUB_BCN_SPACE_8822C 0xff
#define BIT_SUB_BCN_SPACE_8822C(x) \
(((x) & BIT_MASK_SUB_BCN_SPACE_8822C) << BIT_SHIFT_SUB_BCN_SPACE_8822C)
#define BITS_SUB_BCN_SPACE_8822C \
(BIT_MASK_SUB_BCN_SPACE_8822C << BIT_SHIFT_SUB_BCN_SPACE_8822C)
#define BIT_CLEAR_SUB_BCN_SPACE_8822C(x) ((x) & (~BITS_SUB_BCN_SPACE_8822C))
#define BIT_GET_SUB_BCN_SPACE_8822C(x) \
(((x) >> BIT_SHIFT_SUB_BCN_SPACE_8822C) & BIT_MASK_SUB_BCN_SPACE_8822C)
#define BIT_SET_SUB_BCN_SPACE_8822C(x, v) \
(BIT_CLEAR_SUB_BCN_SPACE_8822C(x) | BIT_SUB_BCN_SPACE_8822C(v))
#define BIT_SHIFT_BCN_SPACE_CLINT3_8822C 0
#define BIT_MASK_BCN_SPACE_CLINT3_8822C 0xfff
#define BIT_BCN_SPACE_CLINT3_8822C(x) \
(((x) & BIT_MASK_BCN_SPACE_CLINT3_8822C) \
<< BIT_SHIFT_BCN_SPACE_CLINT3_8822C)
#define BITS_BCN_SPACE_CLINT3_8822C \
(BIT_MASK_BCN_SPACE_CLINT3_8822C << BIT_SHIFT_BCN_SPACE_CLINT3_8822C)
#define BIT_CLEAR_BCN_SPACE_CLINT3_8822C(x) \
((x) & (~BITS_BCN_SPACE_CLINT3_8822C))
#define BIT_GET_BCN_SPACE_CLINT3_8822C(x) \
(((x) >> BIT_SHIFT_BCN_SPACE_CLINT3_8822C) & \
BIT_MASK_BCN_SPACE_CLINT3_8822C)
#define BIT_SET_BCN_SPACE_CLINT3_8822C(x, v) \
(BIT_CLEAR_BCN_SPACE_CLINT3_8822C(x) | BIT_BCN_SPACE_CLINT3_8822C(v))
/* 2 REG_ACMHWCTRL_8822C */
#define BIT_BEQ_ACM_STATUS_8822C BIT(7)
#define BIT_VIQ_ACM_STATUS_8822C BIT(6)
#define BIT_VOQ_ACM_STATUS_8822C BIT(5)
#define BIT_BEQ_ACM_EN_8822C BIT(3)
#define BIT_VIQ_ACM_EN_8822C BIT(2)
#define BIT_VOQ_ACM_EN_8822C BIT(1)
#define BIT_ACMHWEN_8822C BIT(0)
/* 2 REG_ACMRSTCTRL_8822C */
#define BIT_BE_ACM_RESET_USED_TIME_8822C BIT(2)
#define BIT_VI_ACM_RESET_USED_TIME_8822C BIT(1)
#define BIT_VO_ACM_RESET_USED_TIME_8822C BIT(0)
/* 2 REG_ACMAVG_8822C */
#define BIT_SHIFT_AVGPERIOD_8822C 0
#define BIT_MASK_AVGPERIOD_8822C 0xffff
#define BIT_AVGPERIOD_8822C(x) \
(((x) & BIT_MASK_AVGPERIOD_8822C) << BIT_SHIFT_AVGPERIOD_8822C)
#define BITS_AVGPERIOD_8822C \
(BIT_MASK_AVGPERIOD_8822C << BIT_SHIFT_AVGPERIOD_8822C)
#define BIT_CLEAR_AVGPERIOD_8822C(x) ((x) & (~BITS_AVGPERIOD_8822C))
#define BIT_GET_AVGPERIOD_8822C(x) \
(((x) >> BIT_SHIFT_AVGPERIOD_8822C) & BIT_MASK_AVGPERIOD_8822C)
#define BIT_SET_AVGPERIOD_8822C(x, v) \
(BIT_CLEAR_AVGPERIOD_8822C(x) | BIT_AVGPERIOD_8822C(v))
/* 2 REG_VO_ADMTIME_8822C */
#define BIT_SHIFT_VO_ADMITTED_TIME_8822C 0
#define BIT_MASK_VO_ADMITTED_TIME_8822C 0xffff
#define BIT_VO_ADMITTED_TIME_8822C(x) \
(((x) & BIT_MASK_VO_ADMITTED_TIME_8822C) \
<< BIT_SHIFT_VO_ADMITTED_TIME_8822C)
#define BITS_VO_ADMITTED_TIME_8822C \
(BIT_MASK_VO_ADMITTED_TIME_8822C << BIT_SHIFT_VO_ADMITTED_TIME_8822C)
#define BIT_CLEAR_VO_ADMITTED_TIME_8822C(x) \
((x) & (~BITS_VO_ADMITTED_TIME_8822C))
#define BIT_GET_VO_ADMITTED_TIME_8822C(x) \
(((x) >> BIT_SHIFT_VO_ADMITTED_TIME_8822C) & \
BIT_MASK_VO_ADMITTED_TIME_8822C)
#define BIT_SET_VO_ADMITTED_TIME_8822C(x, v) \
(BIT_CLEAR_VO_ADMITTED_TIME_8822C(x) | BIT_VO_ADMITTED_TIME_8822C(v))
/* 2 REG_VI_ADMTIME_8822C */
#define BIT_SHIFT_VI_ADMITTED_TIME_8822C 0
#define BIT_MASK_VI_ADMITTED_TIME_8822C 0xffff
#define BIT_VI_ADMITTED_TIME_8822C(x) \
(((x) & BIT_MASK_VI_ADMITTED_TIME_8822C) \
<< BIT_SHIFT_VI_ADMITTED_TIME_8822C)
#define BITS_VI_ADMITTED_TIME_8822C \
(BIT_MASK_VI_ADMITTED_TIME_8822C << BIT_SHIFT_VI_ADMITTED_TIME_8822C)
#define BIT_CLEAR_VI_ADMITTED_TIME_8822C(x) \
((x) & (~BITS_VI_ADMITTED_TIME_8822C))
#define BIT_GET_VI_ADMITTED_TIME_8822C(x) \
(((x) >> BIT_SHIFT_VI_ADMITTED_TIME_8822C) & \
BIT_MASK_VI_ADMITTED_TIME_8822C)
#define BIT_SET_VI_ADMITTED_TIME_8822C(x, v) \
(BIT_CLEAR_VI_ADMITTED_TIME_8822C(x) | BIT_VI_ADMITTED_TIME_8822C(v))
/* 2 REG_BE_ADMTIME_8822C */
#define BIT_SHIFT_BE_ADMITTED_TIME_8822C 0
#define BIT_MASK_BE_ADMITTED_TIME_8822C 0xffff
#define BIT_BE_ADMITTED_TIME_8822C(x) \
(((x) & BIT_MASK_BE_ADMITTED_TIME_8822C) \
<< BIT_SHIFT_BE_ADMITTED_TIME_8822C)
#define BITS_BE_ADMITTED_TIME_8822C \
(BIT_MASK_BE_ADMITTED_TIME_8822C << BIT_SHIFT_BE_ADMITTED_TIME_8822C)
#define BIT_CLEAR_BE_ADMITTED_TIME_8822C(x) \
((x) & (~BITS_BE_ADMITTED_TIME_8822C))
#define BIT_GET_BE_ADMITTED_TIME_8822C(x) \
(((x) >> BIT_SHIFT_BE_ADMITTED_TIME_8822C) & \
BIT_MASK_BE_ADMITTED_TIME_8822C)
#define BIT_SET_BE_ADMITTED_TIME_8822C(x, v) \
(BIT_CLEAR_BE_ADMITTED_TIME_8822C(x) | BIT_BE_ADMITTED_TIME_8822C(v))
/* 2 REG_MAC_HEADER_NAV_OFFSET_8822C */
#define BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8822C 0
#define BIT_MASK_MAC_HEADER_NAV_OFFSET_8822C 0xff
#define BIT_MAC_HEADER_NAV_OFFSET_8822C(x) \
(((x) & BIT_MASK_MAC_HEADER_NAV_OFFSET_8822C) \
<< BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8822C)
#define BITS_MAC_HEADER_NAV_OFFSET_8822C \
(BIT_MASK_MAC_HEADER_NAV_OFFSET_8822C \
<< BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8822C)
#define BIT_CLEAR_MAC_HEADER_NAV_OFFSET_8822C(x) \
((x) & (~BITS_MAC_HEADER_NAV_OFFSET_8822C))
#define BIT_GET_MAC_HEADER_NAV_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_MAC_HEADER_NAV_OFFSET_8822C) & \
BIT_MASK_MAC_HEADER_NAV_OFFSET_8822C)
#define BIT_SET_MAC_HEADER_NAV_OFFSET_8822C(x, v) \
(BIT_CLEAR_MAC_HEADER_NAV_OFFSET_8822C(x) | \
BIT_MAC_HEADER_NAV_OFFSET_8822C(v))
/* 2 REG_DIS_NDPA_NAV_CHECK_8822C */
#define BIT_CHG_POWER_BCN_AREA_V1_8822C BIT(1)
#define BIT_DIS_NDPA_NAV_CHECK_8822C BIT(0)
/* 2 REG_EDCA_RANDOM_GEN_8822C */
#define BIT_SHIFT_RANDOM_GEN_8822C 0
#define BIT_MASK_RANDOM_GEN_8822C 0xffffff
#define BIT_RANDOM_GEN_8822C(x) \
(((x) & BIT_MASK_RANDOM_GEN_8822C) << BIT_SHIFT_RANDOM_GEN_8822C)
#define BITS_RANDOM_GEN_8822C \
(BIT_MASK_RANDOM_GEN_8822C << BIT_SHIFT_RANDOM_GEN_8822C)
#define BIT_CLEAR_RANDOM_GEN_8822C(x) ((x) & (~BITS_RANDOM_GEN_8822C))
#define BIT_GET_RANDOM_GEN_8822C(x) \
(((x) >> BIT_SHIFT_RANDOM_GEN_8822C) & BIT_MASK_RANDOM_GEN_8822C)
#define BIT_SET_RANDOM_GEN_8822C(x, v) \
(BIT_CLEAR_RANDOM_GEN_8822C(x) | BIT_RANDOM_GEN_8822C(v))
/* 2 REG_TXCMD_NOA_SEL_8822C */
#define BIT_SHIFT_NOA_SEL_V2_8822C 4
#define BIT_MASK_NOA_SEL_V2_8822C 0x7
#define BIT_NOA_SEL_V2_8822C(x) \
(((x) & BIT_MASK_NOA_SEL_V2_8822C) << BIT_SHIFT_NOA_SEL_V2_8822C)
#define BITS_NOA_SEL_V2_8822C \
(BIT_MASK_NOA_SEL_V2_8822C << BIT_SHIFT_NOA_SEL_V2_8822C)
#define BIT_CLEAR_NOA_SEL_V2_8822C(x) ((x) & (~BITS_NOA_SEL_V2_8822C))
#define BIT_GET_NOA_SEL_V2_8822C(x) \
(((x) >> BIT_SHIFT_NOA_SEL_V2_8822C) & BIT_MASK_NOA_SEL_V2_8822C)
#define BIT_SET_NOA_SEL_V2_8822C(x, v) \
(BIT_CLEAR_NOA_SEL_V2_8822C(x) | BIT_NOA_SEL_V2_8822C(v))
#define BIT_SHIFT_TXCMD_SEG_SEL_8822C 0
#define BIT_MASK_TXCMD_SEG_SEL_8822C 0xf
#define BIT_TXCMD_SEG_SEL_8822C(x) \
(((x) & BIT_MASK_TXCMD_SEG_SEL_8822C) << BIT_SHIFT_TXCMD_SEG_SEL_8822C)
#define BITS_TXCMD_SEG_SEL_8822C \
(BIT_MASK_TXCMD_SEG_SEL_8822C << BIT_SHIFT_TXCMD_SEG_SEL_8822C)
#define BIT_CLEAR_TXCMD_SEG_SEL_8822C(x) ((x) & (~BITS_TXCMD_SEG_SEL_8822C))
#define BIT_GET_TXCMD_SEG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_TXCMD_SEG_SEL_8822C) & BIT_MASK_TXCMD_SEG_SEL_8822C)
#define BIT_SET_TXCMD_SEG_SEL_8822C(x, v) \
(BIT_CLEAR_TXCMD_SEG_SEL_8822C(x) | BIT_TXCMD_SEG_SEL_8822C(v))
/* 2 REG_32K_CLK_SEL_8822C */
#define BIT_R_BCNERR_CNT_EN_8822C BIT(20)
#define BIT_SHIFT_R_BCNERR_PORT_SEL_8822C 16
#define BIT_MASK_R_BCNERR_PORT_SEL_8822C 0x7
#define BIT_R_BCNERR_PORT_SEL_8822C(x) \
(((x) & BIT_MASK_R_BCNERR_PORT_SEL_8822C) \
<< BIT_SHIFT_R_BCNERR_PORT_SEL_8822C)
#define BITS_R_BCNERR_PORT_SEL_8822C \
(BIT_MASK_R_BCNERR_PORT_SEL_8822C << BIT_SHIFT_R_BCNERR_PORT_SEL_8822C)
#define BIT_CLEAR_R_BCNERR_PORT_SEL_8822C(x) \
((x) & (~BITS_R_BCNERR_PORT_SEL_8822C))
#define BIT_GET_R_BCNERR_PORT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_BCNERR_PORT_SEL_8822C) & \
BIT_MASK_R_BCNERR_PORT_SEL_8822C)
#define BIT_SET_R_BCNERR_PORT_SEL_8822C(x, v) \
(BIT_CLEAR_R_BCNERR_PORT_SEL_8822C(x) | BIT_R_BCNERR_PORT_SEL_8822C(v))
#define BIT_SHIFT_R_TXPAUSE1_8822C 8
#define BIT_MASK_R_TXPAUSE1_8822C 0xff
#define BIT_R_TXPAUSE1_8822C(x) \
(((x) & BIT_MASK_R_TXPAUSE1_8822C) << BIT_SHIFT_R_TXPAUSE1_8822C)
#define BITS_R_TXPAUSE1_8822C \
(BIT_MASK_R_TXPAUSE1_8822C << BIT_SHIFT_R_TXPAUSE1_8822C)
#define BIT_CLEAR_R_TXPAUSE1_8822C(x) ((x) & (~BITS_R_TXPAUSE1_8822C))
#define BIT_GET_R_TXPAUSE1_8822C(x) \
(((x) >> BIT_SHIFT_R_TXPAUSE1_8822C) & BIT_MASK_R_TXPAUSE1_8822C)
#define BIT_SET_R_TXPAUSE1_8822C(x, v) \
(BIT_CLEAR_R_TXPAUSE1_8822C(x) | BIT_R_TXPAUSE1_8822C(v))
#define BIT_SLEEP_32K_EN_V1_8822C BIT(2)
#define BIT_SHIFT_BW_CFG_8822C 0
#define BIT_MASK_BW_CFG_8822C 0x3
#define BIT_BW_CFG_8822C(x) \
(((x) & BIT_MASK_BW_CFG_8822C) << BIT_SHIFT_BW_CFG_8822C)
#define BITS_BW_CFG_8822C (BIT_MASK_BW_CFG_8822C << BIT_SHIFT_BW_CFG_8822C)
#define BIT_CLEAR_BW_CFG_8822C(x) ((x) & (~BITS_BW_CFG_8822C))
#define BIT_GET_BW_CFG_8822C(x) \
(((x) >> BIT_SHIFT_BW_CFG_8822C) & BIT_MASK_BW_CFG_8822C)
#define BIT_SET_BW_CFG_8822C(x, v) \
(BIT_CLEAR_BW_CFG_8822C(x) | BIT_BW_CFG_8822C(v))
/* 2 REG_EARLYINT_ADJUST_8822C */
#define BIT_SHIFT_RXBCN_TIMER_8822C 16
#define BIT_MASK_RXBCN_TIMER_8822C 0xffff
#define BIT_RXBCN_TIMER_8822C(x) \
(((x) & BIT_MASK_RXBCN_TIMER_8822C) << BIT_SHIFT_RXBCN_TIMER_8822C)
#define BITS_RXBCN_TIMER_8822C \
(BIT_MASK_RXBCN_TIMER_8822C << BIT_SHIFT_RXBCN_TIMER_8822C)
#define BIT_CLEAR_RXBCN_TIMER_8822C(x) ((x) & (~BITS_RXBCN_TIMER_8822C))
#define BIT_GET_RXBCN_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_RXBCN_TIMER_8822C) & BIT_MASK_RXBCN_TIMER_8822C)
#define BIT_SET_RXBCN_TIMER_8822C(x, v) \
(BIT_CLEAR_RXBCN_TIMER_8822C(x) | BIT_RXBCN_TIMER_8822C(v))
#define BIT_SHIFT_R_ERLYINTADJ_8822C 0
#define BIT_MASK_R_ERLYINTADJ_8822C 0xffff
#define BIT_R_ERLYINTADJ_8822C(x) \
(((x) & BIT_MASK_R_ERLYINTADJ_8822C) << BIT_SHIFT_R_ERLYINTADJ_8822C)
#define BITS_R_ERLYINTADJ_8822C \
(BIT_MASK_R_ERLYINTADJ_8822C << BIT_SHIFT_R_ERLYINTADJ_8822C)
#define BIT_CLEAR_R_ERLYINTADJ_8822C(x) ((x) & (~BITS_R_ERLYINTADJ_8822C))
#define BIT_GET_R_ERLYINTADJ_8822C(x) \
(((x) >> BIT_SHIFT_R_ERLYINTADJ_8822C) & BIT_MASK_R_ERLYINTADJ_8822C)
#define BIT_SET_R_ERLYINTADJ_8822C(x, v) \
(BIT_CLEAR_R_ERLYINTADJ_8822C(x) | BIT_R_ERLYINTADJ_8822C(v))
/* 2 REG_BCNERR_CNT_8822C */
#define BIT_SHIFT_BCNERR_CNT_OTHERS_8822C 24
#define BIT_MASK_BCNERR_CNT_OTHERS_8822C 0xff
#define BIT_BCNERR_CNT_OTHERS_8822C(x) \
(((x) & BIT_MASK_BCNERR_CNT_OTHERS_8822C) \
<< BIT_SHIFT_BCNERR_CNT_OTHERS_8822C)
#define BITS_BCNERR_CNT_OTHERS_8822C \
(BIT_MASK_BCNERR_CNT_OTHERS_8822C << BIT_SHIFT_BCNERR_CNT_OTHERS_8822C)
#define BIT_CLEAR_BCNERR_CNT_OTHERS_8822C(x) \
((x) & (~BITS_BCNERR_CNT_OTHERS_8822C))
#define BIT_GET_BCNERR_CNT_OTHERS_8822C(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_OTHERS_8822C) & \
BIT_MASK_BCNERR_CNT_OTHERS_8822C)
#define BIT_SET_BCNERR_CNT_OTHERS_8822C(x, v) \
(BIT_CLEAR_BCNERR_CNT_OTHERS_8822C(x) | BIT_BCNERR_CNT_OTHERS_8822C(v))
#define BIT_SHIFT_BCNERR_CNT_INVALID_8822C 16
#define BIT_MASK_BCNERR_CNT_INVALID_8822C 0xff
#define BIT_BCNERR_CNT_INVALID_8822C(x) \
(((x) & BIT_MASK_BCNERR_CNT_INVALID_8822C) \
<< BIT_SHIFT_BCNERR_CNT_INVALID_8822C)
#define BITS_BCNERR_CNT_INVALID_8822C \
(BIT_MASK_BCNERR_CNT_INVALID_8822C \
<< BIT_SHIFT_BCNERR_CNT_INVALID_8822C)
#define BIT_CLEAR_BCNERR_CNT_INVALID_8822C(x) \
((x) & (~BITS_BCNERR_CNT_INVALID_8822C))
#define BIT_GET_BCNERR_CNT_INVALID_8822C(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_INVALID_8822C) & \
BIT_MASK_BCNERR_CNT_INVALID_8822C)
#define BIT_SET_BCNERR_CNT_INVALID_8822C(x, v) \
(BIT_CLEAR_BCNERR_CNT_INVALID_8822C(x) | \
BIT_BCNERR_CNT_INVALID_8822C(v))
#define BIT_SHIFT_BCNERR_CNT_MAC_8822C 8
#define BIT_MASK_BCNERR_CNT_MAC_8822C 0xff
#define BIT_BCNERR_CNT_MAC_8822C(x) \
(((x) & BIT_MASK_BCNERR_CNT_MAC_8822C) \
<< BIT_SHIFT_BCNERR_CNT_MAC_8822C)
#define BITS_BCNERR_CNT_MAC_8822C \
(BIT_MASK_BCNERR_CNT_MAC_8822C << BIT_SHIFT_BCNERR_CNT_MAC_8822C)
#define BIT_CLEAR_BCNERR_CNT_MAC_8822C(x) ((x) & (~BITS_BCNERR_CNT_MAC_8822C))
#define BIT_GET_BCNERR_CNT_MAC_8822C(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_MAC_8822C) & \
BIT_MASK_BCNERR_CNT_MAC_8822C)
#define BIT_SET_BCNERR_CNT_MAC_8822C(x, v) \
(BIT_CLEAR_BCNERR_CNT_MAC_8822C(x) | BIT_BCNERR_CNT_MAC_8822C(v))
#define BIT_SHIFT_BCNERR_CNT_CCA_8822C 0
#define BIT_MASK_BCNERR_CNT_CCA_8822C 0xff
#define BIT_BCNERR_CNT_CCA_8822C(x) \
(((x) & BIT_MASK_BCNERR_CNT_CCA_8822C) \
<< BIT_SHIFT_BCNERR_CNT_CCA_8822C)
#define BITS_BCNERR_CNT_CCA_8822C \
(BIT_MASK_BCNERR_CNT_CCA_8822C << BIT_SHIFT_BCNERR_CNT_CCA_8822C)
#define BIT_CLEAR_BCNERR_CNT_CCA_8822C(x) ((x) & (~BITS_BCNERR_CNT_CCA_8822C))
#define BIT_GET_BCNERR_CNT_CCA_8822C(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_CCA_8822C) & \
BIT_MASK_BCNERR_CNT_CCA_8822C)
#define BIT_SET_BCNERR_CNT_CCA_8822C(x, v) \
(BIT_CLEAR_BCNERR_CNT_CCA_8822C(x) | BIT_BCNERR_CNT_CCA_8822C(v))
/* 2 REG_BCNERR_CNT_2_8822C */
#define BIT_SHIFT_BCNERR_CNT_EDCCA_8822C 0
#define BIT_MASK_BCNERR_CNT_EDCCA_8822C 0xff
#define BIT_BCNERR_CNT_EDCCA_8822C(x) \
(((x) & BIT_MASK_BCNERR_CNT_EDCCA_8822C) \
<< BIT_SHIFT_BCNERR_CNT_EDCCA_8822C)
#define BITS_BCNERR_CNT_EDCCA_8822C \
(BIT_MASK_BCNERR_CNT_EDCCA_8822C << BIT_SHIFT_BCNERR_CNT_EDCCA_8822C)
#define BIT_CLEAR_BCNERR_CNT_EDCCA_8822C(x) \
((x) & (~BITS_BCNERR_CNT_EDCCA_8822C))
#define BIT_GET_BCNERR_CNT_EDCCA_8822C(x) \
(((x) >> BIT_SHIFT_BCNERR_CNT_EDCCA_8822C) & \
BIT_MASK_BCNERR_CNT_EDCCA_8822C)
#define BIT_SET_BCNERR_CNT_EDCCA_8822C(x, v) \
(BIT_CLEAR_BCNERR_CNT_EDCCA_8822C(x) | BIT_BCNERR_CNT_EDCCA_8822C(v))
/* 2 REG_NOA_PARAM_8822C */
#define BIT_SHIFT_NOA_DURATION_V1_8822C 0
#define BIT_MASK_NOA_DURATION_V1_8822C 0xffffffffL
#define BIT_NOA_DURATION_V1_8822C(x) \
(((x) & BIT_MASK_NOA_DURATION_V1_8822C) \
<< BIT_SHIFT_NOA_DURATION_V1_8822C)
#define BITS_NOA_DURATION_V1_8822C \
(BIT_MASK_NOA_DURATION_V1_8822C << BIT_SHIFT_NOA_DURATION_V1_8822C)
#define BIT_CLEAR_NOA_DURATION_V1_8822C(x) ((x) & (~BITS_NOA_DURATION_V1_8822C))
#define BIT_GET_NOA_DURATION_V1_8822C(x) \
(((x) >> BIT_SHIFT_NOA_DURATION_V1_8822C) & \
BIT_MASK_NOA_DURATION_V1_8822C)
#define BIT_SET_NOA_DURATION_V1_8822C(x, v) \
(BIT_CLEAR_NOA_DURATION_V1_8822C(x) | BIT_NOA_DURATION_V1_8822C(v))
/* 2 REG_NOA_PARAM_1_8822C */
#define BIT_SHIFT_NOA_INTERVAL_V1_8822C 0
#define BIT_MASK_NOA_INTERVAL_V1_8822C 0xffffffffL
#define BIT_NOA_INTERVAL_V1_8822C(x) \
(((x) & BIT_MASK_NOA_INTERVAL_V1_8822C) \
<< BIT_SHIFT_NOA_INTERVAL_V1_8822C)
#define BITS_NOA_INTERVAL_V1_8822C \
(BIT_MASK_NOA_INTERVAL_V1_8822C << BIT_SHIFT_NOA_INTERVAL_V1_8822C)
#define BIT_CLEAR_NOA_INTERVAL_V1_8822C(x) ((x) & (~BITS_NOA_INTERVAL_V1_8822C))
#define BIT_GET_NOA_INTERVAL_V1_8822C(x) \
(((x) >> BIT_SHIFT_NOA_INTERVAL_V1_8822C) & \
BIT_MASK_NOA_INTERVAL_V1_8822C)
#define BIT_SET_NOA_INTERVAL_V1_8822C(x, v) \
(BIT_CLEAR_NOA_INTERVAL_V1_8822C(x) | BIT_NOA_INTERVAL_V1_8822C(v))
/* 2 REG_NOA_PARAM_2_8822C */
#define BIT_SHIFT_NOA_START_TIME_V1_8822C 0
#define BIT_MASK_NOA_START_TIME_V1_8822C 0xffffffffL
#define BIT_NOA_START_TIME_V1_8822C(x) \
(((x) & BIT_MASK_NOA_START_TIME_V1_8822C) \
<< BIT_SHIFT_NOA_START_TIME_V1_8822C)
#define BITS_NOA_START_TIME_V1_8822C \
(BIT_MASK_NOA_START_TIME_V1_8822C << BIT_SHIFT_NOA_START_TIME_V1_8822C)
#define BIT_CLEAR_NOA_START_TIME_V1_8822C(x) \
((x) & (~BITS_NOA_START_TIME_V1_8822C))
#define BIT_GET_NOA_START_TIME_V1_8822C(x) \
(((x) >> BIT_SHIFT_NOA_START_TIME_V1_8822C) & \
BIT_MASK_NOA_START_TIME_V1_8822C)
#define BIT_SET_NOA_START_TIME_V1_8822C(x, v) \
(BIT_CLEAR_NOA_START_TIME_V1_8822C(x) | BIT_NOA_START_TIME_V1_8822C(v))
/* 2 REG_NOA_PARAM_3_8822C */
#define BIT_SHIFT_NOA_COUNT_V1_8822C 0
#define BIT_MASK_NOA_COUNT_V1_8822C 0xffffffffL
#define BIT_NOA_COUNT_V1_8822C(x) \
(((x) & BIT_MASK_NOA_COUNT_V1_8822C) << BIT_SHIFT_NOA_COUNT_V1_8822C)
#define BITS_NOA_COUNT_V1_8822C \
(BIT_MASK_NOA_COUNT_V1_8822C << BIT_SHIFT_NOA_COUNT_V1_8822C)
#define BIT_CLEAR_NOA_COUNT_V1_8822C(x) ((x) & (~BITS_NOA_COUNT_V1_8822C))
#define BIT_GET_NOA_COUNT_V1_8822C(x) \
(((x) >> BIT_SHIFT_NOA_COUNT_V1_8822C) & BIT_MASK_NOA_COUNT_V1_8822C)
#define BIT_SET_NOA_COUNT_V1_8822C(x, v) \
(BIT_CLEAR_NOA_COUNT_V1_8822C(x) | BIT_NOA_COUNT_V1_8822C(v))
/* 2 REG_P2P_RST_8822C */
#define BIT_P2P2_PWR_RST1_8822C BIT(5)
#define BIT_P2P2_PWR_RST0_8822C BIT(4)
#define BIT_P2P1_PWR_RST1_8822C BIT(3)
#define BIT_P2P1_PWR_RST0_8822C BIT(2)
#define BIT_P2P_PWR_RST1_V1_8822C BIT(1)
#define BIT_P2P_PWR_RST0_V1_8822C BIT(0)
/* 2 REG_SCHEDULER_RST_8822C */
#define BIT_SYNC_CLI_ONCE_RIGHT_NOW_8822C BIT(2)
#define BIT_SYNC_CLI_ONCE_BY_TBTT_8822C BIT(1)
#define BIT_SCHEDULER_RST_V1_8822C BIT(0)
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SCH_DBG_VALUE_8822C */
#define BIT_SHIFT_SCH_DBG_VALUE_8822C 0
#define BIT_MASK_SCH_DBG_VALUE_8822C 0xffffffffL
#define BIT_SCH_DBG_VALUE_8822C(x) \
(((x) & BIT_MASK_SCH_DBG_VALUE_8822C) << BIT_SHIFT_SCH_DBG_VALUE_8822C)
#define BITS_SCH_DBG_VALUE_8822C \
(BIT_MASK_SCH_DBG_VALUE_8822C << BIT_SHIFT_SCH_DBG_VALUE_8822C)
#define BIT_CLEAR_SCH_DBG_VALUE_8822C(x) ((x) & (~BITS_SCH_DBG_VALUE_8822C))
#define BIT_GET_SCH_DBG_VALUE_8822C(x) \
(((x) >> BIT_SHIFT_SCH_DBG_VALUE_8822C) & BIT_MASK_SCH_DBG_VALUE_8822C)
#define BIT_SET_SCH_DBG_VALUE_8822C(x, v) \
(BIT_CLEAR_SCH_DBG_VALUE_8822C(x) | BIT_SCH_DBG_VALUE_8822C(v))
/* 2 REG_SCH_TXCMD_8822C */
#define BIT_SHIFT_SCH_TXCMD_8822C 0
#define BIT_MASK_SCH_TXCMD_8822C 0xffffffffL
#define BIT_SCH_TXCMD_8822C(x) \
(((x) & BIT_MASK_SCH_TXCMD_8822C) << BIT_SHIFT_SCH_TXCMD_8822C)
#define BITS_SCH_TXCMD_8822C \
(BIT_MASK_SCH_TXCMD_8822C << BIT_SHIFT_SCH_TXCMD_8822C)
#define BIT_CLEAR_SCH_TXCMD_8822C(x) ((x) & (~BITS_SCH_TXCMD_8822C))
#define BIT_GET_SCH_TXCMD_8822C(x) \
(((x) >> BIT_SHIFT_SCH_TXCMD_8822C) & BIT_MASK_SCH_TXCMD_8822C)
#define BIT_SET_SCH_TXCMD_8822C(x, v) \
(BIT_CLEAR_SCH_TXCMD_8822C(x) | BIT_SCH_TXCMD_8822C(v))
/* 2 REG_PAGE5_DUMMY_8822C */
/* 2 REG_CPUMGQ_TX_TIMER_8822C */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822C 0
#define BIT_MASK_CPUMGQ_TX_TIMER_V1_8822C 0xffffffffL
#define BIT_CPUMGQ_TX_TIMER_V1_8822C(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_V1_8822C) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822C)
#define BITS_CPUMGQ_TX_TIMER_V1_8822C \
(BIT_MASK_CPUMGQ_TX_TIMER_V1_8822C \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822C)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8822C(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_V1_8822C))
#define BIT_GET_CPUMGQ_TX_TIMER_V1_8822C(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_V1_8822C) & \
BIT_MASK_CPUMGQ_TX_TIMER_V1_8822C)
#define BIT_SET_CPUMGQ_TX_TIMER_V1_8822C(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_V1_8822C(x) | \
BIT_CPUMGQ_TX_TIMER_V1_8822C(v))
/* 2 REG_PS_TIMER_A_8822C */
#define BIT_SHIFT_PS_TIMER_A_V1_8822C 0
#define BIT_MASK_PS_TIMER_A_V1_8822C 0xffffffffL
#define BIT_PS_TIMER_A_V1_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_A_V1_8822C) << BIT_SHIFT_PS_TIMER_A_V1_8822C)
#define BITS_PS_TIMER_A_V1_8822C \
(BIT_MASK_PS_TIMER_A_V1_8822C << BIT_SHIFT_PS_TIMER_A_V1_8822C)
#define BIT_CLEAR_PS_TIMER_A_V1_8822C(x) ((x) & (~BITS_PS_TIMER_A_V1_8822C))
#define BIT_GET_PS_TIMER_A_V1_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_V1_8822C) & BIT_MASK_PS_TIMER_A_V1_8822C)
#define BIT_SET_PS_TIMER_A_V1_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_A_V1_8822C(x) | BIT_PS_TIMER_A_V1_8822C(v))
/* 2 REG_PS_TIMER_B_8822C */
#define BIT_SHIFT_PS_TIMER_B_V1_8822C 0
#define BIT_MASK_PS_TIMER_B_V1_8822C 0xffffffffL
#define BIT_PS_TIMER_B_V1_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_B_V1_8822C) << BIT_SHIFT_PS_TIMER_B_V1_8822C)
#define BITS_PS_TIMER_B_V1_8822C \
(BIT_MASK_PS_TIMER_B_V1_8822C << BIT_SHIFT_PS_TIMER_B_V1_8822C)
#define BIT_CLEAR_PS_TIMER_B_V1_8822C(x) ((x) & (~BITS_PS_TIMER_B_V1_8822C))
#define BIT_GET_PS_TIMER_B_V1_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_V1_8822C) & BIT_MASK_PS_TIMER_B_V1_8822C)
#define BIT_SET_PS_TIMER_B_V1_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_B_V1_8822C(x) | BIT_PS_TIMER_B_V1_8822C(v))
/* 2 REG_PS_TIMER_C_8822C */
#define BIT_SHIFT_PS_TIMER_C_V1_8822C 0
#define BIT_MASK_PS_TIMER_C_V1_8822C 0xffffffffL
#define BIT_PS_TIMER_C_V1_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_C_V1_8822C) << BIT_SHIFT_PS_TIMER_C_V1_8822C)
#define BITS_PS_TIMER_C_V1_8822C \
(BIT_MASK_PS_TIMER_C_V1_8822C << BIT_SHIFT_PS_TIMER_C_V1_8822C)
#define BIT_CLEAR_PS_TIMER_C_V1_8822C(x) ((x) & (~BITS_PS_TIMER_C_V1_8822C))
#define BIT_GET_PS_TIMER_C_V1_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_V1_8822C) & BIT_MASK_PS_TIMER_C_V1_8822C)
#define BIT_SET_PS_TIMER_C_V1_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_C_V1_8822C(x) | BIT_PS_TIMER_C_V1_8822C(v))
/* 2 REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8822C */
#define BIT_CPUMGQ_TIMER_EN_8822C BIT(31)
#define BIT_CPUMGQ_TX_EN_8822C BIT(28)
#define BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822C 24
#define BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822C 0x7
#define BIT_CPUMGQ_TIMER_TSF_SEL_8822C(x) \
(((x) & BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822C) \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822C)
#define BITS_CPUMGQ_TIMER_TSF_SEL_8822C \
(BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822C \
<< BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822C)
#define BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8822C(x) \
((x) & (~BITS_CPUMGQ_TIMER_TSF_SEL_8822C))
#define BIT_GET_CPUMGQ_TIMER_TSF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TIMER_TSF_SEL_8822C) & \
BIT_MASK_CPUMGQ_TIMER_TSF_SEL_8822C)
#define BIT_SET_CPUMGQ_TIMER_TSF_SEL_8822C(x, v) \
(BIT_CLEAR_CPUMGQ_TIMER_TSF_SEL_8822C(x) | \
BIT_CPUMGQ_TIMER_TSF_SEL_8822C(v))
#define BIT_PS_TIMER_C_EN_8822C BIT(23)
#define BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822C 16
#define BIT_MASK_PS_TIMER_C_TSF_SEL_8822C 0x7
#define BIT_PS_TIMER_C_TSF_SEL_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_C_TSF_SEL_8822C) \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822C)
#define BITS_PS_TIMER_C_TSF_SEL_8822C \
(BIT_MASK_PS_TIMER_C_TSF_SEL_8822C \
<< BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822C)
#define BIT_CLEAR_PS_TIMER_C_TSF_SEL_8822C(x) \
((x) & (~BITS_PS_TIMER_C_TSF_SEL_8822C))
#define BIT_GET_PS_TIMER_C_TSF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_TSF_SEL_8822C) & \
BIT_MASK_PS_TIMER_C_TSF_SEL_8822C)
#define BIT_SET_PS_TIMER_C_TSF_SEL_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_C_TSF_SEL_8822C(x) | \
BIT_PS_TIMER_C_TSF_SEL_8822C(v))
#define BIT_PS_TIMER_B_EN_8822C BIT(15)
#define BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822C 8
#define BIT_MASK_PS_TIMER_B_TSF_SEL_8822C 0x7
#define BIT_PS_TIMER_B_TSF_SEL_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_B_TSF_SEL_8822C) \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822C)
#define BITS_PS_TIMER_B_TSF_SEL_8822C \
(BIT_MASK_PS_TIMER_B_TSF_SEL_8822C \
<< BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822C)
#define BIT_CLEAR_PS_TIMER_B_TSF_SEL_8822C(x) \
((x) & (~BITS_PS_TIMER_B_TSF_SEL_8822C))
#define BIT_GET_PS_TIMER_B_TSF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_TSF_SEL_8822C) & \
BIT_MASK_PS_TIMER_B_TSF_SEL_8822C)
#define BIT_SET_PS_TIMER_B_TSF_SEL_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_B_TSF_SEL_8822C(x) | \
BIT_PS_TIMER_B_TSF_SEL_8822C(v))
#define BIT_PS_TIMER_A_EN_8822C BIT(7)
#define BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822C 0
#define BIT_MASK_PS_TIMER_A_TSF_SEL_8822C 0x7
#define BIT_PS_TIMER_A_TSF_SEL_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_A_TSF_SEL_8822C) \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822C)
#define BITS_PS_TIMER_A_TSF_SEL_8822C \
(BIT_MASK_PS_TIMER_A_TSF_SEL_8822C \
<< BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822C)
#define BIT_CLEAR_PS_TIMER_A_TSF_SEL_8822C(x) \
((x) & (~BITS_PS_TIMER_A_TSF_SEL_8822C))
#define BIT_GET_PS_TIMER_A_TSF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_TSF_SEL_8822C) & \
BIT_MASK_PS_TIMER_A_TSF_SEL_8822C)
#define BIT_SET_PS_TIMER_A_TSF_SEL_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_A_TSF_SEL_8822C(x) | \
BIT_PS_TIMER_A_TSF_SEL_8822C(v))
/* 2 REG_CPUMGQ_TX_TIMER_EARLY_8822C */
#define BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822C 0
#define BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822C 0xff
#define BIT_CPUMGQ_TX_TIMER_EARLY_8822C(x) \
(((x) & BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822C) \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822C)
#define BITS_CPUMGQ_TX_TIMER_EARLY_8822C \
(BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822C \
<< BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822C)
#define BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8822C(x) \
((x) & (~BITS_CPUMGQ_TX_TIMER_EARLY_8822C))
#define BIT_GET_CPUMGQ_TX_TIMER_EARLY_8822C(x) \
(((x) >> BIT_SHIFT_CPUMGQ_TX_TIMER_EARLY_8822C) & \
BIT_MASK_CPUMGQ_TX_TIMER_EARLY_8822C)
#define BIT_SET_CPUMGQ_TX_TIMER_EARLY_8822C(x, v) \
(BIT_CLEAR_CPUMGQ_TX_TIMER_EARLY_8822C(x) | \
BIT_CPUMGQ_TX_TIMER_EARLY_8822C(v))
/* 2 REG_PS_TIMER_A_EARLY_8822C */
#define BIT_SHIFT_PS_TIMER_A_EARLY_8822C 0
#define BIT_MASK_PS_TIMER_A_EARLY_8822C 0xff
#define BIT_PS_TIMER_A_EARLY_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_A_EARLY_8822C) \
<< BIT_SHIFT_PS_TIMER_A_EARLY_8822C)
#define BITS_PS_TIMER_A_EARLY_8822C \
(BIT_MASK_PS_TIMER_A_EARLY_8822C << BIT_SHIFT_PS_TIMER_A_EARLY_8822C)
#define BIT_CLEAR_PS_TIMER_A_EARLY_8822C(x) \
((x) & (~BITS_PS_TIMER_A_EARLY_8822C))
#define BIT_GET_PS_TIMER_A_EARLY_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_A_EARLY_8822C) & \
BIT_MASK_PS_TIMER_A_EARLY_8822C)
#define BIT_SET_PS_TIMER_A_EARLY_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_A_EARLY_8822C(x) | BIT_PS_TIMER_A_EARLY_8822C(v))
/* 2 REG_PS_TIMER_B_EARLY_8822C */
#define BIT_SHIFT_PS_TIMER_B_EARLY_8822C 0
#define BIT_MASK_PS_TIMER_B_EARLY_8822C 0xff
#define BIT_PS_TIMER_B_EARLY_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_B_EARLY_8822C) \
<< BIT_SHIFT_PS_TIMER_B_EARLY_8822C)
#define BITS_PS_TIMER_B_EARLY_8822C \
(BIT_MASK_PS_TIMER_B_EARLY_8822C << BIT_SHIFT_PS_TIMER_B_EARLY_8822C)
#define BIT_CLEAR_PS_TIMER_B_EARLY_8822C(x) \
((x) & (~BITS_PS_TIMER_B_EARLY_8822C))
#define BIT_GET_PS_TIMER_B_EARLY_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_B_EARLY_8822C) & \
BIT_MASK_PS_TIMER_B_EARLY_8822C)
#define BIT_SET_PS_TIMER_B_EARLY_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_B_EARLY_8822C(x) | BIT_PS_TIMER_B_EARLY_8822C(v))
/* 2 REG_PS_TIMER_C_EARLY_8822C */
#define BIT_SHIFT_PS_TIMER_C_EARLY_8822C 0
#define BIT_MASK_PS_TIMER_C_EARLY_8822C 0xff
#define BIT_PS_TIMER_C_EARLY_8822C(x) \
(((x) & BIT_MASK_PS_TIMER_C_EARLY_8822C) \
<< BIT_SHIFT_PS_TIMER_C_EARLY_8822C)
#define BITS_PS_TIMER_C_EARLY_8822C \
(BIT_MASK_PS_TIMER_C_EARLY_8822C << BIT_SHIFT_PS_TIMER_C_EARLY_8822C)
#define BIT_CLEAR_PS_TIMER_C_EARLY_8822C(x) \
((x) & (~BITS_PS_TIMER_C_EARLY_8822C))
#define BIT_GET_PS_TIMER_C_EARLY_8822C(x) \
(((x) >> BIT_SHIFT_PS_TIMER_C_EARLY_8822C) & \
BIT_MASK_PS_TIMER_C_EARLY_8822C)
#define BIT_SET_PS_TIMER_C_EARLY_8822C(x, v) \
(BIT_CLEAR_PS_TIMER_C_EARLY_8822C(x) | BIT_PS_TIMER_C_EARLY_8822C(v))
/* 2 REG_CPUMGQ_PARAMETER_8822C */
/* 2 REG_NOT_VALID_8822C */
#define BIT_MAC_STOP_CPUMGQ_8822C BIT(16)
#define BIT_SHIFT_CW_8822C 8
#define BIT_MASK_CW_8822C 0xff
#define BIT_CW_8822C(x) (((x) & BIT_MASK_CW_8822C) << BIT_SHIFT_CW_8822C)
#define BITS_CW_8822C (BIT_MASK_CW_8822C << BIT_SHIFT_CW_8822C)
#define BIT_CLEAR_CW_8822C(x) ((x) & (~BITS_CW_8822C))
#define BIT_GET_CW_8822C(x) (((x) >> BIT_SHIFT_CW_8822C) & BIT_MASK_CW_8822C)
#define BIT_SET_CW_8822C(x, v) (BIT_CLEAR_CW_8822C(x) | BIT_CW_8822C(v))
#define BIT_SHIFT_AIFS_8822C 0
#define BIT_MASK_AIFS_8822C 0xff
#define BIT_AIFS_8822C(x) (((x) & BIT_MASK_AIFS_8822C) << BIT_SHIFT_AIFS_8822C)
#define BITS_AIFS_8822C (BIT_MASK_AIFS_8822C << BIT_SHIFT_AIFS_8822C)
#define BIT_CLEAR_AIFS_8822C(x) ((x) & (~BITS_AIFS_8822C))
#define BIT_GET_AIFS_8822C(x) \
(((x) >> BIT_SHIFT_AIFS_8822C) & BIT_MASK_AIFS_8822C)
#define BIT_SET_AIFS_8822C(x, v) (BIT_CLEAR_AIFS_8822C(x) | BIT_AIFS_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_TSF_SYNC_ADJ_8822C */
#define BIT_SHIFT_R_P0_TSFT_ADJ_VAL_8822C 16
#define BIT_MASK_R_P0_TSFT_ADJ_VAL_8822C 0xffff
#define BIT_R_P0_TSFT_ADJ_VAL_8822C(x) \
(((x) & BIT_MASK_R_P0_TSFT_ADJ_VAL_8822C) \
<< BIT_SHIFT_R_P0_TSFT_ADJ_VAL_8822C)
#define BITS_R_P0_TSFT_ADJ_VAL_8822C \
(BIT_MASK_R_P0_TSFT_ADJ_VAL_8822C << BIT_SHIFT_R_P0_TSFT_ADJ_VAL_8822C)
#define BIT_CLEAR_R_P0_TSFT_ADJ_VAL_8822C(x) \
((x) & (~BITS_R_P0_TSFT_ADJ_VAL_8822C))
#define BIT_GET_R_P0_TSFT_ADJ_VAL_8822C(x) \
(((x) >> BIT_SHIFT_R_P0_TSFT_ADJ_VAL_8822C) & \
BIT_MASK_R_P0_TSFT_ADJ_VAL_8822C)
#define BIT_SET_R_P0_TSFT_ADJ_VAL_8822C(x, v) \
(BIT_CLEAR_R_P0_TSFT_ADJ_VAL_8822C(x) | BIT_R_P0_TSFT_ADJ_VAL_8822C(v))
#define BIT_R_X_COMP_Y_OVER_8822C BIT(8)
#define BIT_SHIFT_R_X_SYNC_SEL_8822C 3
#define BIT_MASK_R_X_SYNC_SEL_8822C 0x7
#define BIT_R_X_SYNC_SEL_8822C(x) \
(((x) & BIT_MASK_R_X_SYNC_SEL_8822C) << BIT_SHIFT_R_X_SYNC_SEL_8822C)
#define BITS_R_X_SYNC_SEL_8822C \
(BIT_MASK_R_X_SYNC_SEL_8822C << BIT_SHIFT_R_X_SYNC_SEL_8822C)
#define BIT_CLEAR_R_X_SYNC_SEL_8822C(x) ((x) & (~BITS_R_X_SYNC_SEL_8822C))
#define BIT_GET_R_X_SYNC_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_X_SYNC_SEL_8822C) & BIT_MASK_R_X_SYNC_SEL_8822C)
#define BIT_SET_R_X_SYNC_SEL_8822C(x, v) \
(BIT_CLEAR_R_X_SYNC_SEL_8822C(x) | BIT_R_X_SYNC_SEL_8822C(v))
#define BIT_SHIFT_R_SYNC_Y_SEL_8822C 0
#define BIT_MASK_R_SYNC_Y_SEL_8822C 0x7
#define BIT_R_SYNC_Y_SEL_8822C(x) \
(((x) & BIT_MASK_R_SYNC_Y_SEL_8822C) << BIT_SHIFT_R_SYNC_Y_SEL_8822C)
#define BITS_R_SYNC_Y_SEL_8822C \
(BIT_MASK_R_SYNC_Y_SEL_8822C << BIT_SHIFT_R_SYNC_Y_SEL_8822C)
#define BIT_CLEAR_R_SYNC_Y_SEL_8822C(x) ((x) & (~BITS_R_SYNC_Y_SEL_8822C))
#define BIT_GET_R_SYNC_Y_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_SYNC_Y_SEL_8822C) & BIT_MASK_R_SYNC_Y_SEL_8822C)
#define BIT_SET_R_SYNC_Y_SEL_8822C(x, v) \
(BIT_CLEAR_R_SYNC_Y_SEL_8822C(x) | BIT_R_SYNC_Y_SEL_8822C(v))
/* 2 REG_TSF_ADJ_VLAUE_8822C */
#define BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL_8822C 16
#define BIT_MASK_R_CLI1_TSFT_ADJ_VAL_8822C 0xffff
#define BIT_R_CLI1_TSFT_ADJ_VAL_8822C(x) \
(((x) & BIT_MASK_R_CLI1_TSFT_ADJ_VAL_8822C) \
<< BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL_8822C)
#define BITS_R_CLI1_TSFT_ADJ_VAL_8822C \
(BIT_MASK_R_CLI1_TSFT_ADJ_VAL_8822C \
<< BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL_8822C)
#define BIT_CLEAR_R_CLI1_TSFT_ADJ_VAL_8822C(x) \
((x) & (~BITS_R_CLI1_TSFT_ADJ_VAL_8822C))
#define BIT_GET_R_CLI1_TSFT_ADJ_VAL_8822C(x) \
(((x) >> BIT_SHIFT_R_CLI1_TSFT_ADJ_VAL_8822C) & \
BIT_MASK_R_CLI1_TSFT_ADJ_VAL_8822C)
#define BIT_SET_R_CLI1_TSFT_ADJ_VAL_8822C(x, v) \
(BIT_CLEAR_R_CLI1_TSFT_ADJ_VAL_8822C(x) | \
BIT_R_CLI1_TSFT_ADJ_VAL_8822C(v))
#define BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL_8822C 0
#define BIT_MASK_R_CLI0_TSFT_ADJ_VAL_8822C 0xffff
#define BIT_R_CLI0_TSFT_ADJ_VAL_8822C(x) \
(((x) & BIT_MASK_R_CLI0_TSFT_ADJ_VAL_8822C) \
<< BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL_8822C)
#define BITS_R_CLI0_TSFT_ADJ_VAL_8822C \
(BIT_MASK_R_CLI0_TSFT_ADJ_VAL_8822C \
<< BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL_8822C)
#define BIT_CLEAR_R_CLI0_TSFT_ADJ_VAL_8822C(x) \
((x) & (~BITS_R_CLI0_TSFT_ADJ_VAL_8822C))
#define BIT_GET_R_CLI0_TSFT_ADJ_VAL_8822C(x) \
(((x) >> BIT_SHIFT_R_CLI0_TSFT_ADJ_VAL_8822C) & \
BIT_MASK_R_CLI0_TSFT_ADJ_VAL_8822C)
#define BIT_SET_R_CLI0_TSFT_ADJ_VAL_8822C(x, v) \
(BIT_CLEAR_R_CLI0_TSFT_ADJ_VAL_8822C(x) | \
BIT_R_CLI0_TSFT_ADJ_VAL_8822C(v))
/* 2 REG_TSF_ADJ_VLAUE_2_8822C */
#define BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL_8822C 16
#define BIT_MASK_R_CLI3_TSFT_ADJ_VAL_8822C 0xffff
#define BIT_R_CLI3_TSFT_ADJ_VAL_8822C(x) \
(((x) & BIT_MASK_R_CLI3_TSFT_ADJ_VAL_8822C) \
<< BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL_8822C)
#define BITS_R_CLI3_TSFT_ADJ_VAL_8822C \
(BIT_MASK_R_CLI3_TSFT_ADJ_VAL_8822C \
<< BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL_8822C)
#define BIT_CLEAR_R_CLI3_TSFT_ADJ_VAL_8822C(x) \
((x) & (~BITS_R_CLI3_TSFT_ADJ_VAL_8822C))
#define BIT_GET_R_CLI3_TSFT_ADJ_VAL_8822C(x) \
(((x) >> BIT_SHIFT_R_CLI3_TSFT_ADJ_VAL_8822C) & \
BIT_MASK_R_CLI3_TSFT_ADJ_VAL_8822C)
#define BIT_SET_R_CLI3_TSFT_ADJ_VAL_8822C(x, v) \
(BIT_CLEAR_R_CLI3_TSFT_ADJ_VAL_8822C(x) | \
BIT_R_CLI3_TSFT_ADJ_VAL_8822C(v))
#define BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL_8822C 0
#define BIT_MASK_R_CLI2_TSFT_ADJ_VAL_8822C 0xffff
#define BIT_R_CLI2_TSFT_ADJ_VAL_8822C(x) \
(((x) & BIT_MASK_R_CLI2_TSFT_ADJ_VAL_8822C) \
<< BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL_8822C)
#define BITS_R_CLI2_TSFT_ADJ_VAL_8822C \
(BIT_MASK_R_CLI2_TSFT_ADJ_VAL_8822C \
<< BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL_8822C)
#define BIT_CLEAR_R_CLI2_TSFT_ADJ_VAL_8822C(x) \
((x) & (~BITS_R_CLI2_TSFT_ADJ_VAL_8822C))
#define BIT_GET_R_CLI2_TSFT_ADJ_VAL_8822C(x) \
(((x) >> BIT_SHIFT_R_CLI2_TSFT_ADJ_VAL_8822C) & \
BIT_MASK_R_CLI2_TSFT_ADJ_VAL_8822C)
#define BIT_SET_R_CLI2_TSFT_ADJ_VAL_8822C(x, v) \
(BIT_CLEAR_R_CLI2_TSFT_ADJ_VAL_8822C(x) | \
BIT_R_CLI2_TSFT_ADJ_VAL_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_P2PPS_HW_AUTO_PAUSE_CTRL_8822C */
#define BIT_P2PPS_NOA_STOP_TX_HANG_8822C BIT(31)
#define BIT_P2PPS_MACID_PAUSE_EN_8822C BIT(11)
#define BIT_P2PPS__MGQ_PAUSE_8822C BIT(10)
#define BIT_P2PPS__HIQ_PAUSE_8822C BIT(9)
#define BIT_P2PPS__BCNQ_PAUSE_8822C BIT(8)
#define BIT_SHIFT_P2PPS_MACID_PAUSE_8822C 0
#define BIT_MASK_P2PPS_MACID_PAUSE_8822C 0xff
#define BIT_P2PPS_MACID_PAUSE_8822C(x) \
(((x) & BIT_MASK_P2PPS_MACID_PAUSE_8822C) \
<< BIT_SHIFT_P2PPS_MACID_PAUSE_8822C)
#define BITS_P2PPS_MACID_PAUSE_8822C \
(BIT_MASK_P2PPS_MACID_PAUSE_8822C << BIT_SHIFT_P2PPS_MACID_PAUSE_8822C)
#define BIT_CLEAR_P2PPS_MACID_PAUSE_8822C(x) \
((x) & (~BITS_P2PPS_MACID_PAUSE_8822C))
#define BIT_GET_P2PPS_MACID_PAUSE_8822C(x) \
(((x) >> BIT_SHIFT_P2PPS_MACID_PAUSE_8822C) & \
BIT_MASK_P2PPS_MACID_PAUSE_8822C)
#define BIT_SET_P2PPS_MACID_PAUSE_8822C(x, v) \
(BIT_CLEAR_P2PPS_MACID_PAUSE_8822C(x) | BIT_P2PPS_MACID_PAUSE_8822C(v))
/* 2 REG_P2PPS1_HW_AUTO_PAUSE_CTRL_8822C */
#define BIT_P2PPS1_NOA_STOP_TX_HANG_8822C BIT(31)
#define BIT_P2PPS1_MACID_PAUSE_EN_8822C BIT(11)
#define BIT_P2PPS1__MGQ_PAUSE_8822C BIT(10)
#define BIT_P2PPS1__HIQ_PAUSE_8822C BIT(9)
#define BIT_P2PPS1__BCNQ_PAUSE_8822C BIT(8)
#define BIT_SHIFT_P2PPS1_MACID_PAUSE_8822C 0
#define BIT_MASK_P2PPS1_MACID_PAUSE_8822C 0xff
#define BIT_P2PPS1_MACID_PAUSE_8822C(x) \
(((x) & BIT_MASK_P2PPS1_MACID_PAUSE_8822C) \
<< BIT_SHIFT_P2PPS1_MACID_PAUSE_8822C)
#define BITS_P2PPS1_MACID_PAUSE_8822C \
(BIT_MASK_P2PPS1_MACID_PAUSE_8822C \
<< BIT_SHIFT_P2PPS1_MACID_PAUSE_8822C)
#define BIT_CLEAR_P2PPS1_MACID_PAUSE_8822C(x) \
((x) & (~BITS_P2PPS1_MACID_PAUSE_8822C))
#define BIT_GET_P2PPS1_MACID_PAUSE_8822C(x) \
(((x) >> BIT_SHIFT_P2PPS1_MACID_PAUSE_8822C) & \
BIT_MASK_P2PPS1_MACID_PAUSE_8822C)
#define BIT_SET_P2PPS1_MACID_PAUSE_8822C(x, v) \
(BIT_CLEAR_P2PPS1_MACID_PAUSE_8822C(x) | \
BIT_P2PPS1_MACID_PAUSE_8822C(v))
/* 2 REG_P2PPS2_HW_AUTO_PAUSE_CTRL_8822C */
#define BIT_P2PPS2_NOA_STOP_TX_HANG_8822C BIT(31)
#define BIT_P2PPS2_MACID_PAUSE_EN_8822C BIT(11)
#define BIT_P2PPS2__MGQ_PAUSE_8822C BIT(10)
#define BIT_P2PPS2__HIQ_PAUSE_8822C BIT(9)
#define BIT_P2PPS2__BCNQ_PAUSE_8822C BIT(8)
#define BIT_SHIFT_P2PPS2_MACID_PAUSE_8822C 0
#define BIT_MASK_P2PPS2_MACID_PAUSE_8822C 0xff
#define BIT_P2PPS2_MACID_PAUSE_8822C(x) \
(((x) & BIT_MASK_P2PPS2_MACID_PAUSE_8822C) \
<< BIT_SHIFT_P2PPS2_MACID_PAUSE_8822C)
#define BITS_P2PPS2_MACID_PAUSE_8822C \
(BIT_MASK_P2PPS2_MACID_PAUSE_8822C \
<< BIT_SHIFT_P2PPS2_MACID_PAUSE_8822C)
#define BIT_CLEAR_P2PPS2_MACID_PAUSE_8822C(x) \
((x) & (~BITS_P2PPS2_MACID_PAUSE_8822C))
#define BIT_GET_P2PPS2_MACID_PAUSE_8822C(x) \
(((x) >> BIT_SHIFT_P2PPS2_MACID_PAUSE_8822C) & \
BIT_MASK_P2PPS2_MACID_PAUSE_8822C)
#define BIT_SET_P2PPS2_MACID_PAUSE_8822C(x, v) \
(BIT_CLEAR_P2PPS2_MACID_PAUSE_8822C(x) | \
BIT_P2PPS2_MACID_PAUSE_8822C(v))
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_SCHEDULER_COUNTER_8822C */
#define BIT_SHIFT__SCHEDULER_COUNTER_8822C 16
#define BIT_MASK__SCHEDULER_COUNTER_8822C 0xffff
#define BIT__SCHEDULER_COUNTER_8822C(x) \
(((x) & BIT_MASK__SCHEDULER_COUNTER_8822C) \
<< BIT_SHIFT__SCHEDULER_COUNTER_8822C)
#define BITS__SCHEDULER_COUNTER_8822C \
(BIT_MASK__SCHEDULER_COUNTER_8822C \
<< BIT_SHIFT__SCHEDULER_COUNTER_8822C)
#define BIT_CLEAR__SCHEDULER_COUNTER_8822C(x) \
((x) & (~BITS__SCHEDULER_COUNTER_8822C))
#define BIT_GET__SCHEDULER_COUNTER_8822C(x) \
(((x) >> BIT_SHIFT__SCHEDULER_COUNTER_8822C) & \
BIT_MASK__SCHEDULER_COUNTER_8822C)
#define BIT_SET__SCHEDULER_COUNTER_8822C(x, v) \
(BIT_CLEAR__SCHEDULER_COUNTER_8822C(x) | \
BIT__SCHEDULER_COUNTER_8822C(v))
#define BIT__SCHEDULER_COUNTER_RST_8822C BIT(8)
#define BIT_SHIFT_SCHEDULER_COUNTER_SEL_8822C 0
#define BIT_MASK_SCHEDULER_COUNTER_SEL_8822C 0xff
#define BIT_SCHEDULER_COUNTER_SEL_8822C(x) \
(((x) & BIT_MASK_SCHEDULER_COUNTER_SEL_8822C) \
<< BIT_SHIFT_SCHEDULER_COUNTER_SEL_8822C)
#define BITS_SCHEDULER_COUNTER_SEL_8822C \
(BIT_MASK_SCHEDULER_COUNTER_SEL_8822C \
<< BIT_SHIFT_SCHEDULER_COUNTER_SEL_8822C)
#define BIT_CLEAR_SCHEDULER_COUNTER_SEL_8822C(x) \
((x) & (~BITS_SCHEDULER_COUNTER_SEL_8822C))
#define BIT_GET_SCHEDULER_COUNTER_SEL_8822C(x) \
(((x) >> BIT_SHIFT_SCHEDULER_COUNTER_SEL_8822C) & \
BIT_MASK_SCHEDULER_COUNTER_SEL_8822C)
#define BIT_SET_SCHEDULER_COUNTER_SEL_8822C(x, v) \
(BIT_CLEAR_SCHEDULER_COUNTER_SEL_8822C(x) | \
BIT_SCHEDULER_COUNTER_SEL_8822C(v))
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_WMAC_CR_8822C (WMAC CR AND APSD CONTROL REGISTER) */
#define BIT_IC_MACPHY_M_8822C BIT(0)
/* 2 REG_WMAC_FWPKT_CR_8822C */
#define BIT_FWEN_8822C BIT(7)
#define BIT_PHYSTS_PKT_CTRL_8822C BIT(6)
#define BIT_APPHDR_MIDSRCH_FAIL_8822C BIT(4)
#define BIT_FWPARSING_EN_8822C BIT(3)
#define BIT_SHIFT_APPEND_MHDR_LEN_8822C 0
#define BIT_MASK_APPEND_MHDR_LEN_8822C 0x7
#define BIT_APPEND_MHDR_LEN_8822C(x) \
(((x) & BIT_MASK_APPEND_MHDR_LEN_8822C) \
<< BIT_SHIFT_APPEND_MHDR_LEN_8822C)
#define BITS_APPEND_MHDR_LEN_8822C \
(BIT_MASK_APPEND_MHDR_LEN_8822C << BIT_SHIFT_APPEND_MHDR_LEN_8822C)
#define BIT_CLEAR_APPEND_MHDR_LEN_8822C(x) ((x) & (~BITS_APPEND_MHDR_LEN_8822C))
#define BIT_GET_APPEND_MHDR_LEN_8822C(x) \
(((x) >> BIT_SHIFT_APPEND_MHDR_LEN_8822C) & \
BIT_MASK_APPEND_MHDR_LEN_8822C)
#define BIT_SET_APPEND_MHDR_LEN_8822C(x, v) \
(BIT_CLEAR_APPEND_MHDR_LEN_8822C(x) | BIT_APPEND_MHDR_LEN_8822C(v))
/* 2 REG_FW_STS_FILTER_8822C */
#define BIT_DATA_FW_STS_FILTER_8822C BIT(2)
#define BIT_CTRL_FW_STS_FILTER_8822C BIT(1)
#define BIT_MGNT_FW_STS_FILTER_8822C BIT(0)
/* 2 REG_RSVD_8822C */
/* 2 REG_TCR_8822C (TRANSMISSION CONFIGURATION REGISTER) */
#define BIT_WMAC_EN_RTS_ADDR_8822C BIT(31)
#define BIT_WMAC_DISABLE_CCK_8822C BIT(30)
#define BIT_WMAC_RAW_LEN_8822C BIT(29)
#define BIT_WMAC_NOTX_IN_RXNDP_8822C BIT(28)
#define BIT_WMAC_EN_EOF_8822C BIT(27)
#define BIT_WMAC_BF_SEL_8822C BIT(26)
#define BIT_WMAC_ANTMODE_SEL_8822C BIT(25)
#define BIT_WMAC_TCRPWRMGT_HWCTL_8822C BIT(24)
#define BIT_WMAC_SMOOTH_VAL_8822C BIT(23)
#define BIT_WMAC_EN_SCRAM_INC_8822C BIT(22)
#define BIT_UNDERFLOWEN_CMPLEN_SEL_8822C BIT(21)
#define BIT_FETCH_MPDU_AFTER_WSEC_RDY_8822C BIT(20)
#define BIT_WMAC_TCR_EN_20MST_8822C BIT(19)
#define BIT_WMAC_DIS_SIGTA_8822C BIT(18)
#define BIT_WMAC_DIS_A2B0_8822C BIT(17)
#define BIT_WMAC_MSK_SIGBCRC_8822C BIT(16)
#define BIT_WMAC_TCR_ERRSTEN_3_8822C BIT(15)
#define BIT_WMAC_TCR_ERRSTEN_2_8822C BIT(14)
#define BIT_WMAC_TCR_ERRSTEN_1_8822C BIT(13)
#define BIT_WMAC_TCR_ERRSTEN_0_8822C BIT(12)
#define BIT_WMAC_TCR_TXSK_PERPKT_8822C BIT(11)
#define BIT_ICV_8822C BIT(10)
#define BIT_CFEND_FORMAT_8822C BIT(9)
#define BIT_CRC_8822C BIT(8)
#define BIT_WMAC_TCRPWRMGT_HWDATA_EN_8822C BIT(7)
#define BIT_PWR_ST_8822C BIT(6)
#define BIT_WMAC_TCR_UPD_TIMIE_8822C BIT(5)
#define BIT_WMAC_TCR_UPD_HGQMD_8822C BIT(4)
#define BIT_VHTSIGA1_TXPS_8822C BIT(3)
#define BIT_PAD_SEL_8822C BIT(2)
#define BIT_DIS_GCLK_8822C BIT(1)
#define BIT_WMAC_TCRPWRMGT_HWACT_EN_8822C BIT(0)
/* 2 REG_RCR_8822C (RECEIVE CONFIGURATION REGISTER) */
#define BIT_APP_FCS_8822C BIT(31)
#define BIT_APP_MIC_8822C BIT(30)
#define BIT_APP_ICV_8822C BIT(29)
#define BIT_APP_PHYSTS_8822C BIT(28)
#define BIT_APP_BASSN_8822C BIT(27)
#define BIT_VHT_DACK_8822C BIT(26)
#define BIT_TCPOFLD_EN_8822C BIT(25)
#define BIT_ENMBID_8822C BIT(24)
#define BIT_LSIGEN_8822C BIT(23)
#define BIT_MFBEN_8822C BIT(22)
#define BIT_DISCHKPPDLLEN_8822C BIT(21)
#define BIT_PKTCTL_DLEN_8822C BIT(20)
#define BIT_DISGCLK_8822C BIT(19)
#define BIT_TIM_PARSER_EN_8822C BIT(18)
#define BIT_BC_MD_EN_8822C BIT(17)
#define BIT_UC_MD_EN_8822C BIT(16)
#define BIT_RXSK_PERPKT_8822C BIT(15)
#define BIT_HTC_LOC_CTRL_8822C BIT(14)
#define BIT_ACK_WITH_CBSSID_DATA_OPTION_8822C BIT(13)
#define BIT_RPFM_CAM_ENABLE_8822C BIT(12)
#define BIT_TA_BCN_8822C BIT(11)
#define BIT_DISDECMYPKT_8822C BIT(10)
#define BIT_AICV_8822C BIT(9)
#define BIT_ACRC32_8822C BIT(8)
#define BIT_CBSSID_BCN_8822C BIT(7)
#define BIT_CBSSID_DATA_8822C BIT(6)
#define BIT_APWRMGT_8822C BIT(5)
#define BIT_ADD3_8822C BIT(4)
#define BIT_AB_8822C BIT(3)
#define BIT_AM_8822C BIT(2)
#define BIT_APM_8822C BIT(1)
#define BIT_AAP_8822C BIT(0)
/* 2 REG_RX_PKT_LIMIT_8822C (RX PACKET LENGTH LIMIT REGISTER) */
#define BIT_SHIFT_RXPKTLMT_8822C 0
#define BIT_MASK_RXPKTLMT_8822C 0x3f
#define BIT_RXPKTLMT_8822C(x) \
(((x) & BIT_MASK_RXPKTLMT_8822C) << BIT_SHIFT_RXPKTLMT_8822C)
#define BITS_RXPKTLMT_8822C \
(BIT_MASK_RXPKTLMT_8822C << BIT_SHIFT_RXPKTLMT_8822C)
#define BIT_CLEAR_RXPKTLMT_8822C(x) ((x) & (~BITS_RXPKTLMT_8822C))
#define BIT_GET_RXPKTLMT_8822C(x) \
(((x) >> BIT_SHIFT_RXPKTLMT_8822C) & BIT_MASK_RXPKTLMT_8822C)
#define BIT_SET_RXPKTLMT_8822C(x, v) \
(BIT_CLEAR_RXPKTLMT_8822C(x) | BIT_RXPKTLMT_8822C(v))
/* 2 REG_RX_DLK_TIME_8822C (RX DEADLOCK TIME REGISTER) */
#define BIT_SHIFT_RX_DLK_TIME_8822C 0
#define BIT_MASK_RX_DLK_TIME_8822C 0xff
#define BIT_RX_DLK_TIME_8822C(x) \
(((x) & BIT_MASK_RX_DLK_TIME_8822C) << BIT_SHIFT_RX_DLK_TIME_8822C)
#define BITS_RX_DLK_TIME_8822C \
(BIT_MASK_RX_DLK_TIME_8822C << BIT_SHIFT_RX_DLK_TIME_8822C)
#define BIT_CLEAR_RX_DLK_TIME_8822C(x) ((x) & (~BITS_RX_DLK_TIME_8822C))
#define BIT_GET_RX_DLK_TIME_8822C(x) \
(((x) >> BIT_SHIFT_RX_DLK_TIME_8822C) & BIT_MASK_RX_DLK_TIME_8822C)
#define BIT_SET_RX_DLK_TIME_8822C(x, v) \
(BIT_CLEAR_RX_DLK_TIME_8822C(x) | BIT_RX_DLK_TIME_8822C(v))
/* 2 REG_RSVD_8822C */
/* 2 REG_RX_DRVINFO_SZ_8822C (RX DRIVER INFO SIZE REGISTER) */
#define BIT_PHYSTS_PER_PKT_MODE_8822C BIT(7)
#define BIT_SHIFT_DRVINFO_SZ_V1_8822C 0
#define BIT_MASK_DRVINFO_SZ_V1_8822C 0xf
#define BIT_DRVINFO_SZ_V1_8822C(x) \
(((x) & BIT_MASK_DRVINFO_SZ_V1_8822C) << BIT_SHIFT_DRVINFO_SZ_V1_8822C)
#define BITS_DRVINFO_SZ_V1_8822C \
(BIT_MASK_DRVINFO_SZ_V1_8822C << BIT_SHIFT_DRVINFO_SZ_V1_8822C)
#define BIT_CLEAR_DRVINFO_SZ_V1_8822C(x) ((x) & (~BITS_DRVINFO_SZ_V1_8822C))
#define BIT_GET_DRVINFO_SZ_V1_8822C(x) \
(((x) >> BIT_SHIFT_DRVINFO_SZ_V1_8822C) & BIT_MASK_DRVINFO_SZ_V1_8822C)
#define BIT_SET_DRVINFO_SZ_V1_8822C(x, v) \
(BIT_CLEAR_DRVINFO_SZ_V1_8822C(x) | BIT_DRVINFO_SZ_V1_8822C(v))
/* 2 REG_MACID_8822C (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_V1_8822C 0
#define BIT_MASK_MACID_V1_8822C 0xffffffffL
#define BIT_MACID_V1_8822C(x) \
(((x) & BIT_MASK_MACID_V1_8822C) << BIT_SHIFT_MACID_V1_8822C)
#define BITS_MACID_V1_8822C \
(BIT_MASK_MACID_V1_8822C << BIT_SHIFT_MACID_V1_8822C)
#define BIT_CLEAR_MACID_V1_8822C(x) ((x) & (~BITS_MACID_V1_8822C))
#define BIT_GET_MACID_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID_V1_8822C) & BIT_MASK_MACID_V1_8822C)
#define BIT_SET_MACID_V1_8822C(x, v) \
(BIT_CLEAR_MACID_V1_8822C(x) | BIT_MACID_V1_8822C(v))
/* 2 REG_MACID_H_8822C (MAC ID REGISTER) */
#define BIT_SHIFT_MACID_H_V1_8822C 0
#define BIT_MASK_MACID_H_V1_8822C 0xffff
#define BIT_MACID_H_V1_8822C(x) \
(((x) & BIT_MASK_MACID_H_V1_8822C) << BIT_SHIFT_MACID_H_V1_8822C)
#define BITS_MACID_H_V1_8822C \
(BIT_MASK_MACID_H_V1_8822C << BIT_SHIFT_MACID_H_V1_8822C)
#define BIT_CLEAR_MACID_H_V1_8822C(x) ((x) & (~BITS_MACID_H_V1_8822C))
#define BIT_GET_MACID_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID_H_V1_8822C) & BIT_MASK_MACID_H_V1_8822C)
#define BIT_SET_MACID_H_V1_8822C(x, v) \
(BIT_CLEAR_MACID_H_V1_8822C(x) | BIT_MACID_H_V1_8822C(v))
/* 2 REG_BSSID_8822C (BSSID REGISTER) */
#define BIT_SHIFT_BSSID_V1_8822C 0
#define BIT_MASK_BSSID_V1_8822C 0xffffffffL
#define BIT_BSSID_V1_8822C(x) \
(((x) & BIT_MASK_BSSID_V1_8822C) << BIT_SHIFT_BSSID_V1_8822C)
#define BITS_BSSID_V1_8822C \
(BIT_MASK_BSSID_V1_8822C << BIT_SHIFT_BSSID_V1_8822C)
#define BIT_CLEAR_BSSID_V1_8822C(x) ((x) & (~BITS_BSSID_V1_8822C))
#define BIT_GET_BSSID_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID_V1_8822C) & BIT_MASK_BSSID_V1_8822C)
#define BIT_SET_BSSID_V1_8822C(x, v) \
(BIT_CLEAR_BSSID_V1_8822C(x) | BIT_BSSID_V1_8822C(v))
/* 2 REG_BSSID_H_8822C (BSSID REGISTER) */
/* 2 REG_NOT_VALID_8822C */
#define BIT_SHIFT_BSSID_H_V1_8822C 0
#define BIT_MASK_BSSID_H_V1_8822C 0xffff
#define BIT_BSSID_H_V1_8822C(x) \
(((x) & BIT_MASK_BSSID_H_V1_8822C) << BIT_SHIFT_BSSID_H_V1_8822C)
#define BITS_BSSID_H_V1_8822C \
(BIT_MASK_BSSID_H_V1_8822C << BIT_SHIFT_BSSID_H_V1_8822C)
#define BIT_CLEAR_BSSID_H_V1_8822C(x) ((x) & (~BITS_BSSID_H_V1_8822C))
#define BIT_GET_BSSID_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID_H_V1_8822C) & BIT_MASK_BSSID_H_V1_8822C)
#define BIT_SET_BSSID_H_V1_8822C(x, v) \
(BIT_CLEAR_BSSID_H_V1_8822C(x) | BIT_BSSID_H_V1_8822C(v))
/* 2 REG_MAR_8822C (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_V1_8822C 0
#define BIT_MASK_MAR_V1_8822C 0xffffffffL
#define BIT_MAR_V1_8822C(x) \
(((x) & BIT_MASK_MAR_V1_8822C) << BIT_SHIFT_MAR_V1_8822C)
#define BITS_MAR_V1_8822C (BIT_MASK_MAR_V1_8822C << BIT_SHIFT_MAR_V1_8822C)
#define BIT_CLEAR_MAR_V1_8822C(x) ((x) & (~BITS_MAR_V1_8822C))
#define BIT_GET_MAR_V1_8822C(x) \
(((x) >> BIT_SHIFT_MAR_V1_8822C) & BIT_MASK_MAR_V1_8822C)
#define BIT_SET_MAR_V1_8822C(x, v) \
(BIT_CLEAR_MAR_V1_8822C(x) | BIT_MAR_V1_8822C(v))
/* 2 REG_MAR_H_8822C (MULTICAST ADDRESS REGISTER) */
#define BIT_SHIFT_MAR_H_V1_8822C 0
#define BIT_MASK_MAR_H_V1_8822C 0xffffffffL
#define BIT_MAR_H_V1_8822C(x) \
(((x) & BIT_MASK_MAR_H_V1_8822C) << BIT_SHIFT_MAR_H_V1_8822C)
#define BITS_MAR_H_V1_8822C \
(BIT_MASK_MAR_H_V1_8822C << BIT_SHIFT_MAR_H_V1_8822C)
#define BIT_CLEAR_MAR_H_V1_8822C(x) ((x) & (~BITS_MAR_H_V1_8822C))
#define BIT_GET_MAR_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_MAR_H_V1_8822C) & BIT_MASK_MAR_H_V1_8822C)
#define BIT_SET_MAR_H_V1_8822C(x, v) \
(BIT_CLEAR_MAR_H_V1_8822C(x) | BIT_MAR_H_V1_8822C(v))
/* 2 REG_MBIDCAMCFG_1_8822C (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_SHIFT_MBIDCAM_RWDATA_L_8822C 0
#define BIT_MASK_MBIDCAM_RWDATA_L_8822C 0xffffffffL
#define BIT_MBIDCAM_RWDATA_L_8822C(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_L_8822C) \
<< BIT_SHIFT_MBIDCAM_RWDATA_L_8822C)
#define BITS_MBIDCAM_RWDATA_L_8822C \
(BIT_MASK_MBIDCAM_RWDATA_L_8822C << BIT_SHIFT_MBIDCAM_RWDATA_L_8822C)
#define BIT_CLEAR_MBIDCAM_RWDATA_L_8822C(x) \
((x) & (~BITS_MBIDCAM_RWDATA_L_8822C))
#define BIT_GET_MBIDCAM_RWDATA_L_8822C(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_L_8822C) & \
BIT_MASK_MBIDCAM_RWDATA_L_8822C)
#define BIT_SET_MBIDCAM_RWDATA_L_8822C(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_L_8822C(x) | BIT_MBIDCAM_RWDATA_L_8822C(v))
/* 2 REG_MBIDCAMCFG_2_8822C (MBSSID CAM CONFIGURATION REGISTER) */
#define BIT_MBIDCAM_POLL_8822C BIT(31)
#define BIT_MBIDCAM_WT_EN_8822C BIT(30)
#define BIT_SHIFT_MBIDCAM_ADDR_V1_8822C 24
#define BIT_MASK_MBIDCAM_ADDR_V1_8822C 0x3f
#define BIT_MBIDCAM_ADDR_V1_8822C(x) \
(((x) & BIT_MASK_MBIDCAM_ADDR_V1_8822C) \
<< BIT_SHIFT_MBIDCAM_ADDR_V1_8822C)
#define BITS_MBIDCAM_ADDR_V1_8822C \
(BIT_MASK_MBIDCAM_ADDR_V1_8822C << BIT_SHIFT_MBIDCAM_ADDR_V1_8822C)
#define BIT_CLEAR_MBIDCAM_ADDR_V1_8822C(x) ((x) & (~BITS_MBIDCAM_ADDR_V1_8822C))
#define BIT_GET_MBIDCAM_ADDR_V1_8822C(x) \
(((x) >> BIT_SHIFT_MBIDCAM_ADDR_V1_8822C) & \
BIT_MASK_MBIDCAM_ADDR_V1_8822C)
#define BIT_SET_MBIDCAM_ADDR_V1_8822C(x, v) \
(BIT_CLEAR_MBIDCAM_ADDR_V1_8822C(x) | BIT_MBIDCAM_ADDR_V1_8822C(v))
#define BIT_MBIDCAM_VALID_8822C BIT(23)
#define BIT_LSIC_TXOP_EN_8822C BIT(17)
#define BIT_CTS_EN_8822C BIT(16)
#define BIT_SHIFT_MBIDCAM_RWDATA_H_8822C 0
#define BIT_MASK_MBIDCAM_RWDATA_H_8822C 0xffff
#define BIT_MBIDCAM_RWDATA_H_8822C(x) \
(((x) & BIT_MASK_MBIDCAM_RWDATA_H_8822C) \
<< BIT_SHIFT_MBIDCAM_RWDATA_H_8822C)
#define BITS_MBIDCAM_RWDATA_H_8822C \
(BIT_MASK_MBIDCAM_RWDATA_H_8822C << BIT_SHIFT_MBIDCAM_RWDATA_H_8822C)
#define BIT_CLEAR_MBIDCAM_RWDATA_H_8822C(x) \
((x) & (~BITS_MBIDCAM_RWDATA_H_8822C))
#define BIT_GET_MBIDCAM_RWDATA_H_8822C(x) \
(((x) >> BIT_SHIFT_MBIDCAM_RWDATA_H_8822C) & \
BIT_MASK_MBIDCAM_RWDATA_H_8822C)
#define BIT_SET_MBIDCAM_RWDATA_H_8822C(x, v) \
(BIT_CLEAR_MBIDCAM_RWDATA_H_8822C(x) | BIT_MBIDCAM_RWDATA_H_8822C(v))
/* 2 REG_WMAC_TCR_TSFT_OFS_8822C */
#define BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822C 0
#define BIT_MASK_WMAC_TCR_TSFT_OFS_8822C 0xffff
#define BIT_WMAC_TCR_TSFT_OFS_8822C(x) \
(((x) & BIT_MASK_WMAC_TCR_TSFT_OFS_8822C) \
<< BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822C)
#define BITS_WMAC_TCR_TSFT_OFS_8822C \
(BIT_MASK_WMAC_TCR_TSFT_OFS_8822C << BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822C)
#define BIT_CLEAR_WMAC_TCR_TSFT_OFS_8822C(x) \
((x) & (~BITS_WMAC_TCR_TSFT_OFS_8822C))
#define BIT_GET_WMAC_TCR_TSFT_OFS_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_TCR_TSFT_OFS_8822C) & \
BIT_MASK_WMAC_TCR_TSFT_OFS_8822C)
#define BIT_SET_WMAC_TCR_TSFT_OFS_8822C(x, v) \
(BIT_CLEAR_WMAC_TCR_TSFT_OFS_8822C(x) | BIT_WMAC_TCR_TSFT_OFS_8822C(v))
/* 2 REG_UDF_THSD_8822C */
#define BIT_UDF_THSD_V1_8822C BIT(7)
#define BIT_SHIFT_UDF_THSD_VALUE_8822C 0
#define BIT_MASK_UDF_THSD_VALUE_8822C 0x7f
#define BIT_UDF_THSD_VALUE_8822C(x) \
(((x) & BIT_MASK_UDF_THSD_VALUE_8822C) \
<< BIT_SHIFT_UDF_THSD_VALUE_8822C)
#define BITS_UDF_THSD_VALUE_8822C \
(BIT_MASK_UDF_THSD_VALUE_8822C << BIT_SHIFT_UDF_THSD_VALUE_8822C)
#define BIT_CLEAR_UDF_THSD_VALUE_8822C(x) ((x) & (~BITS_UDF_THSD_VALUE_8822C))
#define BIT_GET_UDF_THSD_VALUE_8822C(x) \
(((x) >> BIT_SHIFT_UDF_THSD_VALUE_8822C) & \
BIT_MASK_UDF_THSD_VALUE_8822C)
#define BIT_SET_UDF_THSD_VALUE_8822C(x, v) \
(BIT_CLEAR_UDF_THSD_VALUE_8822C(x) | BIT_UDF_THSD_VALUE_8822C(v))
/* 2 REG_ZLD_NUM_8822C */
#define BIT_SHIFT_ZLD_NUM_8822C 0
#define BIT_MASK_ZLD_NUM_8822C 0xff
#define BIT_ZLD_NUM_8822C(x) \
(((x) & BIT_MASK_ZLD_NUM_8822C) << BIT_SHIFT_ZLD_NUM_8822C)
#define BITS_ZLD_NUM_8822C (BIT_MASK_ZLD_NUM_8822C << BIT_SHIFT_ZLD_NUM_8822C)
#define BIT_CLEAR_ZLD_NUM_8822C(x) ((x) & (~BITS_ZLD_NUM_8822C))
#define BIT_GET_ZLD_NUM_8822C(x) \
(((x) >> BIT_SHIFT_ZLD_NUM_8822C) & BIT_MASK_ZLD_NUM_8822C)
#define BIT_SET_ZLD_NUM_8822C(x, v) \
(BIT_CLEAR_ZLD_NUM_8822C(x) | BIT_ZLD_NUM_8822C(v))
/* 2 REG_STMP_THSD_8822C */
#define BIT_SHIFT_STMP_THSD_8822C 0
#define BIT_MASK_STMP_THSD_8822C 0xff
#define BIT_STMP_THSD_8822C(x) \
(((x) & BIT_MASK_STMP_THSD_8822C) << BIT_SHIFT_STMP_THSD_8822C)
#define BITS_STMP_THSD_8822C \
(BIT_MASK_STMP_THSD_8822C << BIT_SHIFT_STMP_THSD_8822C)
#define BIT_CLEAR_STMP_THSD_8822C(x) ((x) & (~BITS_STMP_THSD_8822C))
#define BIT_GET_STMP_THSD_8822C(x) \
(((x) >> BIT_SHIFT_STMP_THSD_8822C) & BIT_MASK_STMP_THSD_8822C)
#define BIT_SET_STMP_THSD_8822C(x, v) \
(BIT_CLEAR_STMP_THSD_8822C(x) | BIT_STMP_THSD_8822C(v))
/* 2 REG_WMAC_TXTIMEOUT_8822C */
#define BIT_SHIFT_WMAC_TXTIMEOUT_8822C 0
#define BIT_MASK_WMAC_TXTIMEOUT_8822C 0xff
#define BIT_WMAC_TXTIMEOUT_8822C(x) \
(((x) & BIT_MASK_WMAC_TXTIMEOUT_8822C) \
<< BIT_SHIFT_WMAC_TXTIMEOUT_8822C)
#define BITS_WMAC_TXTIMEOUT_8822C \
(BIT_MASK_WMAC_TXTIMEOUT_8822C << BIT_SHIFT_WMAC_TXTIMEOUT_8822C)
#define BIT_CLEAR_WMAC_TXTIMEOUT_8822C(x) ((x) & (~BITS_WMAC_TXTIMEOUT_8822C))
#define BIT_GET_WMAC_TXTIMEOUT_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_TXTIMEOUT_8822C) & \
BIT_MASK_WMAC_TXTIMEOUT_8822C)
#define BIT_SET_WMAC_TXTIMEOUT_8822C(x, v) \
(BIT_CLEAR_WMAC_TXTIMEOUT_8822C(x) | BIT_WMAC_TXTIMEOUT_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_USTIME_EDCA_8822C (US TIME TUNING FOR EDCA REGISTER) */
#define BIT_SHIFT_USTIME_EDCA_8822C 0
#define BIT_MASK_USTIME_EDCA_8822C 0xff
#define BIT_USTIME_EDCA_8822C(x) \
(((x) & BIT_MASK_USTIME_EDCA_8822C) << BIT_SHIFT_USTIME_EDCA_8822C)
#define BITS_USTIME_EDCA_8822C \
(BIT_MASK_USTIME_EDCA_8822C << BIT_SHIFT_USTIME_EDCA_8822C)
#define BIT_CLEAR_USTIME_EDCA_8822C(x) ((x) & (~BITS_USTIME_EDCA_8822C))
#define BIT_GET_USTIME_EDCA_8822C(x) \
(((x) >> BIT_SHIFT_USTIME_EDCA_8822C) & BIT_MASK_USTIME_EDCA_8822C)
#define BIT_SET_USTIME_EDCA_8822C(x, v) \
(BIT_CLEAR_USTIME_EDCA_8822C(x) | BIT_USTIME_EDCA_8822C(v))
/* 2 REG_ACKTO_CCK_8822C (ACK TIMEOUT REGISTER FOR CCK RATE) */
#define BIT_SHIFT_ACKTO_CCK_8822C 0
#define BIT_MASK_ACKTO_CCK_8822C 0xff
#define BIT_ACKTO_CCK_8822C(x) \
(((x) & BIT_MASK_ACKTO_CCK_8822C) << BIT_SHIFT_ACKTO_CCK_8822C)
#define BITS_ACKTO_CCK_8822C \
(BIT_MASK_ACKTO_CCK_8822C << BIT_SHIFT_ACKTO_CCK_8822C)
#define BIT_CLEAR_ACKTO_CCK_8822C(x) ((x) & (~BITS_ACKTO_CCK_8822C))
#define BIT_GET_ACKTO_CCK_8822C(x) \
(((x) >> BIT_SHIFT_ACKTO_CCK_8822C) & BIT_MASK_ACKTO_CCK_8822C)
#define BIT_SET_ACKTO_CCK_8822C(x, v) \
(BIT_CLEAR_ACKTO_CCK_8822C(x) | BIT_ACKTO_CCK_8822C(v))
/* 2 REG_MAC_SPEC_SIFS_8822C (SPECIFICATION SIFS REGISTER) */
#define BIT_SHIFT_SPEC_SIFS_OFDM_8822C 8
#define BIT_MASK_SPEC_SIFS_OFDM_8822C 0xff
#define BIT_SPEC_SIFS_OFDM_8822C(x) \
(((x) & BIT_MASK_SPEC_SIFS_OFDM_8822C) \
<< BIT_SHIFT_SPEC_SIFS_OFDM_8822C)
#define BITS_SPEC_SIFS_OFDM_8822C \
(BIT_MASK_SPEC_SIFS_OFDM_8822C << BIT_SHIFT_SPEC_SIFS_OFDM_8822C)
#define BIT_CLEAR_SPEC_SIFS_OFDM_8822C(x) ((x) & (~BITS_SPEC_SIFS_OFDM_8822C))
#define BIT_GET_SPEC_SIFS_OFDM_8822C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_OFDM_8822C) & \
BIT_MASK_SPEC_SIFS_OFDM_8822C)
#define BIT_SET_SPEC_SIFS_OFDM_8822C(x, v) \
(BIT_CLEAR_SPEC_SIFS_OFDM_8822C(x) | BIT_SPEC_SIFS_OFDM_8822C(v))
#define BIT_SHIFT_SPEC_SIFS_CCK_8822C 0
#define BIT_MASK_SPEC_SIFS_CCK_8822C 0xff
#define BIT_SPEC_SIFS_CCK_8822C(x) \
(((x) & BIT_MASK_SPEC_SIFS_CCK_8822C) << BIT_SHIFT_SPEC_SIFS_CCK_8822C)
#define BITS_SPEC_SIFS_CCK_8822C \
(BIT_MASK_SPEC_SIFS_CCK_8822C << BIT_SHIFT_SPEC_SIFS_CCK_8822C)
#define BIT_CLEAR_SPEC_SIFS_CCK_8822C(x) ((x) & (~BITS_SPEC_SIFS_CCK_8822C))
#define BIT_GET_SPEC_SIFS_CCK_8822C(x) \
(((x) >> BIT_SHIFT_SPEC_SIFS_CCK_8822C) & BIT_MASK_SPEC_SIFS_CCK_8822C)
#define BIT_SET_SPEC_SIFS_CCK_8822C(x, v) \
(BIT_CLEAR_SPEC_SIFS_CCK_8822C(x) | BIT_SPEC_SIFS_CCK_8822C(v))
/* 2 REG_RESP_SIFS_CCK_8822C (RESPONSE SIFS FOR CCK REGISTER) */
#define BIT_SHIFT_SIFS_R2T_CCK_8822C 8
#define BIT_MASK_SIFS_R2T_CCK_8822C 0xff
#define BIT_SIFS_R2T_CCK_8822C(x) \
(((x) & BIT_MASK_SIFS_R2T_CCK_8822C) << BIT_SHIFT_SIFS_R2T_CCK_8822C)
#define BITS_SIFS_R2T_CCK_8822C \
(BIT_MASK_SIFS_R2T_CCK_8822C << BIT_SHIFT_SIFS_R2T_CCK_8822C)
#define BIT_CLEAR_SIFS_R2T_CCK_8822C(x) ((x) & (~BITS_SIFS_R2T_CCK_8822C))
#define BIT_GET_SIFS_R2T_CCK_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_CCK_8822C) & BIT_MASK_SIFS_R2T_CCK_8822C)
#define BIT_SET_SIFS_R2T_CCK_8822C(x, v) \
(BIT_CLEAR_SIFS_R2T_CCK_8822C(x) | BIT_SIFS_R2T_CCK_8822C(v))
#define BIT_SHIFT_SIFS_T2T_CCK_8822C 0
#define BIT_MASK_SIFS_T2T_CCK_8822C 0xff
#define BIT_SIFS_T2T_CCK_8822C(x) \
(((x) & BIT_MASK_SIFS_T2T_CCK_8822C) << BIT_SHIFT_SIFS_T2T_CCK_8822C)
#define BITS_SIFS_T2T_CCK_8822C \
(BIT_MASK_SIFS_T2T_CCK_8822C << BIT_SHIFT_SIFS_T2T_CCK_8822C)
#define BIT_CLEAR_SIFS_T2T_CCK_8822C(x) ((x) & (~BITS_SIFS_T2T_CCK_8822C))
#define BIT_GET_SIFS_T2T_CCK_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_CCK_8822C) & BIT_MASK_SIFS_T2T_CCK_8822C)
#define BIT_SET_SIFS_T2T_CCK_8822C(x, v) \
(BIT_CLEAR_SIFS_T2T_CCK_8822C(x) | BIT_SIFS_T2T_CCK_8822C(v))
/* 2 REG_RESP_SIFS_OFDM_8822C (RESPONSE SIFS FOR OFDM REGISTER) */
#define BIT_SHIFT_SIFS_R2T_OFDM_8822C 8
#define BIT_MASK_SIFS_R2T_OFDM_8822C 0xff
#define BIT_SIFS_R2T_OFDM_8822C(x) \
(((x) & BIT_MASK_SIFS_R2T_OFDM_8822C) << BIT_SHIFT_SIFS_R2T_OFDM_8822C)
#define BITS_SIFS_R2T_OFDM_8822C \
(BIT_MASK_SIFS_R2T_OFDM_8822C << BIT_SHIFT_SIFS_R2T_OFDM_8822C)
#define BIT_CLEAR_SIFS_R2T_OFDM_8822C(x) ((x) & (~BITS_SIFS_R2T_OFDM_8822C))
#define BIT_GET_SIFS_R2T_OFDM_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_R2T_OFDM_8822C) & BIT_MASK_SIFS_R2T_OFDM_8822C)
#define BIT_SET_SIFS_R2T_OFDM_8822C(x, v) \
(BIT_CLEAR_SIFS_R2T_OFDM_8822C(x) | BIT_SIFS_R2T_OFDM_8822C(v))
#define BIT_SHIFT_SIFS_T2T_OFDM_8822C 0
#define BIT_MASK_SIFS_T2T_OFDM_8822C 0xff
#define BIT_SIFS_T2T_OFDM_8822C(x) \
(((x) & BIT_MASK_SIFS_T2T_OFDM_8822C) << BIT_SHIFT_SIFS_T2T_OFDM_8822C)
#define BITS_SIFS_T2T_OFDM_8822C \
(BIT_MASK_SIFS_T2T_OFDM_8822C << BIT_SHIFT_SIFS_T2T_OFDM_8822C)
#define BIT_CLEAR_SIFS_T2T_OFDM_8822C(x) ((x) & (~BITS_SIFS_T2T_OFDM_8822C))
#define BIT_GET_SIFS_T2T_OFDM_8822C(x) \
(((x) >> BIT_SHIFT_SIFS_T2T_OFDM_8822C) & BIT_MASK_SIFS_T2T_OFDM_8822C)
#define BIT_SET_SIFS_T2T_OFDM_8822C(x, v) \
(BIT_CLEAR_SIFS_T2T_OFDM_8822C(x) | BIT_SIFS_T2T_OFDM_8822C(v))
/* 2 REG_ACKTO_8822C (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_ACKTO_8822C 0
#define BIT_MASK_ACKTO_8822C 0xff
#define BIT_ACKTO_8822C(x) \
(((x) & BIT_MASK_ACKTO_8822C) << BIT_SHIFT_ACKTO_8822C)
#define BITS_ACKTO_8822C (BIT_MASK_ACKTO_8822C << BIT_SHIFT_ACKTO_8822C)
#define BIT_CLEAR_ACKTO_8822C(x) ((x) & (~BITS_ACKTO_8822C))
#define BIT_GET_ACKTO_8822C(x) \
(((x) >> BIT_SHIFT_ACKTO_8822C) & BIT_MASK_ACKTO_8822C)
#define BIT_SET_ACKTO_8822C(x, v) \
(BIT_CLEAR_ACKTO_8822C(x) | BIT_ACKTO_8822C(v))
/* 2 REG_CTS2TO_8822C (CTS2 TIMEOUT REGISTER) */
#define BIT_SHIFT_CTS2TO_8822C 0
#define BIT_MASK_CTS2TO_8822C 0xff
#define BIT_CTS2TO_8822C(x) \
(((x) & BIT_MASK_CTS2TO_8822C) << BIT_SHIFT_CTS2TO_8822C)
#define BITS_CTS2TO_8822C (BIT_MASK_CTS2TO_8822C << BIT_SHIFT_CTS2TO_8822C)
#define BIT_CLEAR_CTS2TO_8822C(x) ((x) & (~BITS_CTS2TO_8822C))
#define BIT_GET_CTS2TO_8822C(x) \
(((x) >> BIT_SHIFT_CTS2TO_8822C) & BIT_MASK_CTS2TO_8822C)
#define BIT_SET_CTS2TO_8822C(x, v) \
(BIT_CLEAR_CTS2TO_8822C(x) | BIT_CTS2TO_8822C(v))
/* 2 REG_EIFS_8822C (EIFS REGISTER) */
#define BIT_SHIFT_EIFS_8822C 0
#define BIT_MASK_EIFS_8822C 0xffff
#define BIT_EIFS_8822C(x) (((x) & BIT_MASK_EIFS_8822C) << BIT_SHIFT_EIFS_8822C)
#define BITS_EIFS_8822C (BIT_MASK_EIFS_8822C << BIT_SHIFT_EIFS_8822C)
#define BIT_CLEAR_EIFS_8822C(x) ((x) & (~BITS_EIFS_8822C))
#define BIT_GET_EIFS_8822C(x) \
(((x) >> BIT_SHIFT_EIFS_8822C) & BIT_MASK_EIFS_8822C)
#define BIT_SET_EIFS_8822C(x, v) (BIT_CLEAR_EIFS_8822C(x) | BIT_EIFS_8822C(v))
/* 2 REG_RPFM_MAP0_8822C */
#define BIT_MGT_RPFM15EN_8822C BIT(15)
#define BIT_MGT_RPFM14EN_8822C BIT(14)
#define BIT_MGT_RPFM13EN_8822C BIT(13)
#define BIT_MGT_RPFM12EN_8822C BIT(12)
#define BIT_MGT_RPFM11EN_8822C BIT(11)
#define BIT_MGT_RPFM10EN_8822C BIT(10)
#define BIT_MGT_RPFM9EN_8822C BIT(9)
#define BIT_MGT_RPFM8EN_8822C BIT(8)
#define BIT_MGT_RPFM7EN_8822C BIT(7)
#define BIT_MGT_RPFM6EN_8822C BIT(6)
#define BIT_MGT_RPFM5EN_8822C BIT(5)
#define BIT_MGT_RPFM4EN_8822C BIT(4)
#define BIT_MGT_RPFM3EN_8822C BIT(3)
#define BIT_MGT_RPFM2EN_8822C BIT(2)
#define BIT_MGT_RPFM1EN_8822C BIT(1)
#define BIT_MGT_RPFM0EN_8822C BIT(0)
/* 2 REG_RPFM_MAP1_V1_8822C */
#define BIT_DATA_RPFM15EN_8822C BIT(15)
#define BIT_DATA_RPFM14EN_8822C BIT(14)
#define BIT_DATA_RPFM13EN_8822C BIT(13)
#define BIT_DATA_RPFM12EN_8822C BIT(12)
#define BIT_DATA_RPFM11EN_8822C BIT(11)
#define BIT_DATA_RPFM10EN_8822C BIT(10)
#define BIT_DATA_RPFM9EN_8822C BIT(9)
#define BIT_DATA_RPFM8EN_8822C BIT(8)
#define BIT_DATA_RPFM7EN_8822C BIT(7)
#define BIT_DATA_RPFM6EN_8822C BIT(6)
#define BIT_DATA_RPFM5EN_8822C BIT(5)
#define BIT_DATA_RPFM4EN_8822C BIT(4)
#define BIT_DATA_RPFM3EN_8822C BIT(3)
#define BIT_DATA_RPFM2EN_8822C BIT(2)
#define BIT_DATA_RPFM1EN_8822C BIT(1)
#define BIT_DATA_RPFM0EN_8822C BIT(0)
/* 2 REG_RPFM_CAM_CMD_8822C (RX PAYLOAD FRAME MASK CAM COMMAND REGISTER) */
#define BIT_RPFM_CAM_POLLING_8822C BIT(31)
#define BIT_RPFM_CAM_CLR_8822C BIT(30)
#define BIT_RPFM_CAM_WE_8822C BIT(16)
#define BIT_SHIFT_RPFM_CAM_ADDR_8822C 0
#define BIT_MASK_RPFM_CAM_ADDR_8822C 0x7f
#define BIT_RPFM_CAM_ADDR_8822C(x) \
(((x) & BIT_MASK_RPFM_CAM_ADDR_8822C) << BIT_SHIFT_RPFM_CAM_ADDR_8822C)
#define BITS_RPFM_CAM_ADDR_8822C \
(BIT_MASK_RPFM_CAM_ADDR_8822C << BIT_SHIFT_RPFM_CAM_ADDR_8822C)
#define BIT_CLEAR_RPFM_CAM_ADDR_8822C(x) ((x) & (~BITS_RPFM_CAM_ADDR_8822C))
#define BIT_GET_RPFM_CAM_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_ADDR_8822C) & BIT_MASK_RPFM_CAM_ADDR_8822C)
#define BIT_SET_RPFM_CAM_ADDR_8822C(x, v) \
(BIT_CLEAR_RPFM_CAM_ADDR_8822C(x) | BIT_RPFM_CAM_ADDR_8822C(v))
/* 2 REG_RPFM_CAM_RWD_8822C (ACK TIMEOUT REGISTER) */
#define BIT_SHIFT_RPFM_CAM_RWD_8822C 0
#define BIT_MASK_RPFM_CAM_RWD_8822C 0xffffffffL
#define BIT_RPFM_CAM_RWD_8822C(x) \
(((x) & BIT_MASK_RPFM_CAM_RWD_8822C) << BIT_SHIFT_RPFM_CAM_RWD_8822C)
#define BITS_RPFM_CAM_RWD_8822C \
(BIT_MASK_RPFM_CAM_RWD_8822C << BIT_SHIFT_RPFM_CAM_RWD_8822C)
#define BIT_CLEAR_RPFM_CAM_RWD_8822C(x) ((x) & (~BITS_RPFM_CAM_RWD_8822C))
#define BIT_GET_RPFM_CAM_RWD_8822C(x) \
(((x) >> BIT_SHIFT_RPFM_CAM_RWD_8822C) & BIT_MASK_RPFM_CAM_RWD_8822C)
#define BIT_SET_RPFM_CAM_RWD_8822C(x, v) \
(BIT_CLEAR_RPFM_CAM_RWD_8822C(x) | BIT_RPFM_CAM_RWD_8822C(v))
/* 2 REG_NAV_CTRL_8822C (NAV CONTROL REGISTER) */
#define BIT_SHIFT_NAV_UPPER_8822C 16
#define BIT_MASK_NAV_UPPER_8822C 0xff
#define BIT_NAV_UPPER_8822C(x) \
(((x) & BIT_MASK_NAV_UPPER_8822C) << BIT_SHIFT_NAV_UPPER_8822C)
#define BITS_NAV_UPPER_8822C \
(BIT_MASK_NAV_UPPER_8822C << BIT_SHIFT_NAV_UPPER_8822C)
#define BIT_CLEAR_NAV_UPPER_8822C(x) ((x) & (~BITS_NAV_UPPER_8822C))
#define BIT_GET_NAV_UPPER_8822C(x) \
(((x) >> BIT_SHIFT_NAV_UPPER_8822C) & BIT_MASK_NAV_UPPER_8822C)
#define BIT_SET_NAV_UPPER_8822C(x, v) \
(BIT_CLEAR_NAV_UPPER_8822C(x) | BIT_NAV_UPPER_8822C(v))
#define BIT_SHIFT_RXMYRTS_NAV_8822C 8
#define BIT_MASK_RXMYRTS_NAV_8822C 0xf
#define BIT_RXMYRTS_NAV_8822C(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_8822C) << BIT_SHIFT_RXMYRTS_NAV_8822C)
#define BITS_RXMYRTS_NAV_8822C \
(BIT_MASK_RXMYRTS_NAV_8822C << BIT_SHIFT_RXMYRTS_NAV_8822C)
#define BIT_CLEAR_RXMYRTS_NAV_8822C(x) ((x) & (~BITS_RXMYRTS_NAV_8822C))
#define BIT_GET_RXMYRTS_NAV_8822C(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_8822C) & BIT_MASK_RXMYRTS_NAV_8822C)
#define BIT_SET_RXMYRTS_NAV_8822C(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_8822C(x) | BIT_RXMYRTS_NAV_8822C(v))
#define BIT_SHIFT_RTSRST_8822C 0
#define BIT_MASK_RTSRST_8822C 0xff
#define BIT_RTSRST_8822C(x) \
(((x) & BIT_MASK_RTSRST_8822C) << BIT_SHIFT_RTSRST_8822C)
#define BITS_RTSRST_8822C (BIT_MASK_RTSRST_8822C << BIT_SHIFT_RTSRST_8822C)
#define BIT_CLEAR_RTSRST_8822C(x) ((x) & (~BITS_RTSRST_8822C))
#define BIT_GET_RTSRST_8822C(x) \
(((x) >> BIT_SHIFT_RTSRST_8822C) & BIT_MASK_RTSRST_8822C)
#define BIT_SET_RTSRST_8822C(x, v) \
(BIT_CLEAR_RTSRST_8822C(x) | BIT_RTSRST_8822C(v))
/* 2 REG_BACAMCMD_8822C (BLOCK ACK CAM COMMAND REGISTER) */
#define BIT_BACAM_POLL_8822C BIT(31)
#define BIT_BACAM_RST_8822C BIT(17)
#define BIT_BACAM_RW_8822C BIT(16)
#define BIT_SHIFT_TXSBM_8822C 14
#define BIT_MASK_TXSBM_8822C 0x3
#define BIT_TXSBM_8822C(x) \
(((x) & BIT_MASK_TXSBM_8822C) << BIT_SHIFT_TXSBM_8822C)
#define BITS_TXSBM_8822C (BIT_MASK_TXSBM_8822C << BIT_SHIFT_TXSBM_8822C)
#define BIT_CLEAR_TXSBM_8822C(x) ((x) & (~BITS_TXSBM_8822C))
#define BIT_GET_TXSBM_8822C(x) \
(((x) >> BIT_SHIFT_TXSBM_8822C) & BIT_MASK_TXSBM_8822C)
#define BIT_SET_TXSBM_8822C(x, v) \
(BIT_CLEAR_TXSBM_8822C(x) | BIT_TXSBM_8822C(v))
#define BIT_SHIFT_BACAM_ADDR_8822C 0
#define BIT_MASK_BACAM_ADDR_8822C 0x3f
#define BIT_BACAM_ADDR_8822C(x) \
(((x) & BIT_MASK_BACAM_ADDR_8822C) << BIT_SHIFT_BACAM_ADDR_8822C)
#define BITS_BACAM_ADDR_8822C \
(BIT_MASK_BACAM_ADDR_8822C << BIT_SHIFT_BACAM_ADDR_8822C)
#define BIT_CLEAR_BACAM_ADDR_8822C(x) ((x) & (~BITS_BACAM_ADDR_8822C))
#define BIT_GET_BACAM_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_BACAM_ADDR_8822C) & BIT_MASK_BACAM_ADDR_8822C)
#define BIT_SET_BACAM_ADDR_8822C(x, v) \
(BIT_CLEAR_BACAM_ADDR_8822C(x) | BIT_BACAM_ADDR_8822C(v))
/* 2 REG_BACAMCONTENT_8822C (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_L_8822C 0
#define BIT_MASK_BA_CONTENT_L_8822C 0xffffffffL
#define BIT_BA_CONTENT_L_8822C(x) \
(((x) & BIT_MASK_BA_CONTENT_L_8822C) << BIT_SHIFT_BA_CONTENT_L_8822C)
#define BITS_BA_CONTENT_L_8822C \
(BIT_MASK_BA_CONTENT_L_8822C << BIT_SHIFT_BA_CONTENT_L_8822C)
#define BIT_CLEAR_BA_CONTENT_L_8822C(x) ((x) & (~BITS_BA_CONTENT_L_8822C))
#define BIT_GET_BA_CONTENT_L_8822C(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_L_8822C) & BIT_MASK_BA_CONTENT_L_8822C)
#define BIT_SET_BA_CONTENT_L_8822C(x, v) \
(BIT_CLEAR_BA_CONTENT_L_8822C(x) | BIT_BA_CONTENT_L_8822C(v))
/* 2 REG_BACAMCONTENT_H_8822C (BLOCK ACK CAM CONTENT REGISTER) */
#define BIT_SHIFT_BA_CONTENT_H_8822C 0
#define BIT_MASK_BA_CONTENT_H_8822C 0xffffffffL
#define BIT_BA_CONTENT_H_8822C(x) \
(((x) & BIT_MASK_BA_CONTENT_H_8822C) << BIT_SHIFT_BA_CONTENT_H_8822C)
#define BITS_BA_CONTENT_H_8822C \
(BIT_MASK_BA_CONTENT_H_8822C << BIT_SHIFT_BA_CONTENT_H_8822C)
#define BIT_CLEAR_BA_CONTENT_H_8822C(x) ((x) & (~BITS_BA_CONTENT_H_8822C))
#define BIT_GET_BA_CONTENT_H_8822C(x) \
(((x) >> BIT_SHIFT_BA_CONTENT_H_8822C) & BIT_MASK_BA_CONTENT_H_8822C)
#define BIT_SET_BA_CONTENT_H_8822C(x, v) \
(BIT_CLEAR_BA_CONTENT_H_8822C(x) | BIT_BA_CONTENT_H_8822C(v))
/* 2 REG_LBDLY_8822C (LOOPBACK DELAY REGISTER) */
#define BIT_SHIFT_LBDLY_8822C 0
#define BIT_MASK_LBDLY_8822C 0x1f
#define BIT_LBDLY_8822C(x) \
(((x) & BIT_MASK_LBDLY_8822C) << BIT_SHIFT_LBDLY_8822C)
#define BITS_LBDLY_8822C (BIT_MASK_LBDLY_8822C << BIT_SHIFT_LBDLY_8822C)
#define BIT_CLEAR_LBDLY_8822C(x) ((x) & (~BITS_LBDLY_8822C))
#define BIT_GET_LBDLY_8822C(x) \
(((x) >> BIT_SHIFT_LBDLY_8822C) & BIT_MASK_LBDLY_8822C)
#define BIT_SET_LBDLY_8822C(x, v) \
(BIT_CLEAR_LBDLY_8822C(x) | BIT_LBDLY_8822C(v))
/* 2 REG_WMAC_BACAM_RPMEN_8822C */
#define BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822C 2
#define BIT_MASK_BITMAP_SSNBK_COUNTER_8822C 0x3f
#define BIT_BITMAP_SSNBK_COUNTER_8822C(x) \
(((x) & BIT_MASK_BITMAP_SSNBK_COUNTER_8822C) \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822C)
#define BITS_BITMAP_SSNBK_COUNTER_8822C \
(BIT_MASK_BITMAP_SSNBK_COUNTER_8822C \
<< BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822C)
#define BIT_CLEAR_BITMAP_SSNBK_COUNTER_8822C(x) \
((x) & (~BITS_BITMAP_SSNBK_COUNTER_8822C))
#define BIT_GET_BITMAP_SSNBK_COUNTER_8822C(x) \
(((x) >> BIT_SHIFT_BITMAP_SSNBK_COUNTER_8822C) & \
BIT_MASK_BITMAP_SSNBK_COUNTER_8822C)
#define BIT_SET_BITMAP_SSNBK_COUNTER_8822C(x, v) \
(BIT_CLEAR_BITMAP_SSNBK_COUNTER_8822C(x) | \
BIT_BITMAP_SSNBK_COUNTER_8822C(v))
#define BIT_BITMAP_EN_8822C BIT(1)
#define BIT_WMAC_BACAM_RPMEN_8822C BIT(0)
/* 2 REG_TX_RX_8822C STATUS */
#define BIT_SHIFT_RXPKT_TYPE_8822C 2
#define BIT_MASK_RXPKT_TYPE_8822C 0x3f
#define BIT_RXPKT_TYPE_8822C(x) \
(((x) & BIT_MASK_RXPKT_TYPE_8822C) << BIT_SHIFT_RXPKT_TYPE_8822C)
#define BITS_RXPKT_TYPE_8822C \
(BIT_MASK_RXPKT_TYPE_8822C << BIT_SHIFT_RXPKT_TYPE_8822C)
#define BIT_CLEAR_RXPKT_TYPE_8822C(x) ((x) & (~BITS_RXPKT_TYPE_8822C))
#define BIT_GET_RXPKT_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_RXPKT_TYPE_8822C) & BIT_MASK_RXPKT_TYPE_8822C)
#define BIT_SET_RXPKT_TYPE_8822C(x, v) \
(BIT_CLEAR_RXPKT_TYPE_8822C(x) | BIT_RXPKT_TYPE_8822C(v))
#define BIT_TXACT_IND_8822C BIT(1)
#define BIT_RXACT_IND_8822C BIT(0)
/* 2 REG_WMAC_BITMAP_CTL_8822C */
#define BIT_BITMAP_VO_8822C BIT(7)
#define BIT_BITMAP_VI_8822C BIT(6)
#define BIT_BITMAP_BE_8822C BIT(5)
#define BIT_BITMAP_BK_8822C BIT(4)
#define BIT_SHIFT_BITMAP_CONDITION_8822C 2
#define BIT_MASK_BITMAP_CONDITION_8822C 0x3
#define BIT_BITMAP_CONDITION_8822C(x) \
(((x) & BIT_MASK_BITMAP_CONDITION_8822C) \
<< BIT_SHIFT_BITMAP_CONDITION_8822C)
#define BITS_BITMAP_CONDITION_8822C \
(BIT_MASK_BITMAP_CONDITION_8822C << BIT_SHIFT_BITMAP_CONDITION_8822C)
#define BIT_CLEAR_BITMAP_CONDITION_8822C(x) \
((x) & (~BITS_BITMAP_CONDITION_8822C))
#define BIT_GET_BITMAP_CONDITION_8822C(x) \
(((x) >> BIT_SHIFT_BITMAP_CONDITION_8822C) & \
BIT_MASK_BITMAP_CONDITION_8822C)
#define BIT_SET_BITMAP_CONDITION_8822C(x, v) \
(BIT_CLEAR_BITMAP_CONDITION_8822C(x) | BIT_BITMAP_CONDITION_8822C(v))
#define BIT_BITMAP_SSNBK_COUNTER_CLR_8822C BIT(1)
#define BIT_BITMAP_FORCE_8822C BIT(0)
/* 2 REG_RXERR_RPT_8822C (RX ERROR REPORT REGISTER) */
#define BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822C 28
#define BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822C 0xf
#define BIT_RXERR_RPT_SEL_V1_3_0_8822C(x) \
(((x) & BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822C) \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822C)
#define BITS_RXERR_RPT_SEL_V1_3_0_8822C \
(BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822C \
<< BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822C)
#define BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8822C(x) \
((x) & (~BITS_RXERR_RPT_SEL_V1_3_0_8822C))
#define BIT_GET_RXERR_RPT_SEL_V1_3_0_8822C(x) \
(((x) >> BIT_SHIFT_RXERR_RPT_SEL_V1_3_0_8822C) & \
BIT_MASK_RXERR_RPT_SEL_V1_3_0_8822C)
#define BIT_SET_RXERR_RPT_SEL_V1_3_0_8822C(x, v) \
(BIT_CLEAR_RXERR_RPT_SEL_V1_3_0_8822C(x) | \
BIT_RXERR_RPT_SEL_V1_3_0_8822C(v))
#define BIT_RXERR_RPT_RST_8822C BIT(27)
#define BIT_RXERR_RPT_SEL_V1_4_8822C BIT(26)
#define BIT_SHIFT_UD_SELECT_BSSID_2_1_8822C 24
#define BIT_MASK_UD_SELECT_BSSID_2_1_8822C 0x3
#define BIT_UD_SELECT_BSSID_2_1_8822C(x) \
(((x) & BIT_MASK_UD_SELECT_BSSID_2_1_8822C) \
<< BIT_SHIFT_UD_SELECT_BSSID_2_1_8822C)
#define BITS_UD_SELECT_BSSID_2_1_8822C \
(BIT_MASK_UD_SELECT_BSSID_2_1_8822C \
<< BIT_SHIFT_UD_SELECT_BSSID_2_1_8822C)
#define BIT_CLEAR_UD_SELECT_BSSID_2_1_8822C(x) \
((x) & (~BITS_UD_SELECT_BSSID_2_1_8822C))
#define BIT_GET_UD_SELECT_BSSID_2_1_8822C(x) \
(((x) >> BIT_SHIFT_UD_SELECT_BSSID_2_1_8822C) & \
BIT_MASK_UD_SELECT_BSSID_2_1_8822C)
#define BIT_SET_UD_SELECT_BSSID_2_1_8822C(x, v) \
(BIT_CLEAR_UD_SELECT_BSSID_2_1_8822C(x) | \
BIT_UD_SELECT_BSSID_2_1_8822C(v))
#define BIT_W1S_8822C BIT(23)
#define BIT_UD_SELECT_BSSID_0_8822C BIT(22)
#define BIT_SHIFT_UD_SUB_TYPE_8822C 18
#define BIT_MASK_UD_SUB_TYPE_8822C 0xf
#define BIT_UD_SUB_TYPE_8822C(x) \
(((x) & BIT_MASK_UD_SUB_TYPE_8822C) << BIT_SHIFT_UD_SUB_TYPE_8822C)
#define BITS_UD_SUB_TYPE_8822C \
(BIT_MASK_UD_SUB_TYPE_8822C << BIT_SHIFT_UD_SUB_TYPE_8822C)
#define BIT_CLEAR_UD_SUB_TYPE_8822C(x) ((x) & (~BITS_UD_SUB_TYPE_8822C))
#define BIT_GET_UD_SUB_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_UD_SUB_TYPE_8822C) & BIT_MASK_UD_SUB_TYPE_8822C)
#define BIT_SET_UD_SUB_TYPE_8822C(x, v) \
(BIT_CLEAR_UD_SUB_TYPE_8822C(x) | BIT_UD_SUB_TYPE_8822C(v))
#define BIT_SHIFT_UD_TYPE_8822C 16
#define BIT_MASK_UD_TYPE_8822C 0x3
#define BIT_UD_TYPE_8822C(x) \
(((x) & BIT_MASK_UD_TYPE_8822C) << BIT_SHIFT_UD_TYPE_8822C)
#define BITS_UD_TYPE_8822C (BIT_MASK_UD_TYPE_8822C << BIT_SHIFT_UD_TYPE_8822C)
#define BIT_CLEAR_UD_TYPE_8822C(x) ((x) & (~BITS_UD_TYPE_8822C))
#define BIT_GET_UD_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_UD_TYPE_8822C) & BIT_MASK_UD_TYPE_8822C)
#define BIT_SET_UD_TYPE_8822C(x, v) \
(BIT_CLEAR_UD_TYPE_8822C(x) | BIT_UD_TYPE_8822C(v))
#define BIT_SHIFT_RPT_COUNTER_8822C 0
#define BIT_MASK_RPT_COUNTER_8822C 0xffff
#define BIT_RPT_COUNTER_8822C(x) \
(((x) & BIT_MASK_RPT_COUNTER_8822C) << BIT_SHIFT_RPT_COUNTER_8822C)
#define BITS_RPT_COUNTER_8822C \
(BIT_MASK_RPT_COUNTER_8822C << BIT_SHIFT_RPT_COUNTER_8822C)
#define BIT_CLEAR_RPT_COUNTER_8822C(x) ((x) & (~BITS_RPT_COUNTER_8822C))
#define BIT_GET_RPT_COUNTER_8822C(x) \
(((x) >> BIT_SHIFT_RPT_COUNTER_8822C) & BIT_MASK_RPT_COUNTER_8822C)
#define BIT_SET_RPT_COUNTER_8822C(x, v) \
(BIT_CLEAR_RPT_COUNTER_8822C(x) | BIT_RPT_COUNTER_8822C(v))
/* 2 REG_WMAC_TRXPTCL_CTL_8822C (WMAC TX/RX PROTOCOL CONTROL REGISTER) */
#define BIT_ACKTO_BLOCK_SCH_EN_8822C BIT(27)
#define BIT_EIFS_BLOCK_SCH_EN_8822C BIT(26)
#define BIT_PLCPCHK_RST_EIFS_8822C BIT(25)
#define BIT_CCA_RST_EIFS_8822C BIT(24)
#define BIT_DIS_UPD_MYRXPKTNAV_8822C BIT(23)
#define BIT_EARLY_TXBA_8822C BIT(22)
#define BIT_SHIFT_RESP_CHNBUSY_8822C 20
#define BIT_MASK_RESP_CHNBUSY_8822C 0x3
#define BIT_RESP_CHNBUSY_8822C(x) \
(((x) & BIT_MASK_RESP_CHNBUSY_8822C) << BIT_SHIFT_RESP_CHNBUSY_8822C)
#define BITS_RESP_CHNBUSY_8822C \
(BIT_MASK_RESP_CHNBUSY_8822C << BIT_SHIFT_RESP_CHNBUSY_8822C)
#define BIT_CLEAR_RESP_CHNBUSY_8822C(x) ((x) & (~BITS_RESP_CHNBUSY_8822C))
#define BIT_GET_RESP_CHNBUSY_8822C(x) \
(((x) >> BIT_SHIFT_RESP_CHNBUSY_8822C) & BIT_MASK_RESP_CHNBUSY_8822C)
#define BIT_SET_RESP_CHNBUSY_8822C(x, v) \
(BIT_CLEAR_RESP_CHNBUSY_8822C(x) | BIT_RESP_CHNBUSY_8822C(v))
#define BIT_RESP_DCTS_EN_8822C BIT(19)
#define BIT_RESP_DCFE_EN_8822C BIT(18)
#define BIT_RESP_SPLCPEN_8822C BIT(17)
#define BIT_RESP_SGIEN_8822C BIT(16)
#define BIT_RESP_LDPC_EN_8822C BIT(15)
#define BIT_DIS_RESP_ACKINCCA_8822C BIT(14)
#define BIT_DIS_RESP_CTSINCCA_8822C BIT(13)
#define BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822C 10
#define BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822C 0x7
#define BIT_R_WMAC_SECOND_CCA_TIMER_8822C(x) \
(((x) & BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822C) \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822C)
#define BITS_R_WMAC_SECOND_CCA_TIMER_8822C \
(BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822C \
<< BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822C)
#define BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8822C(x) \
((x) & (~BITS_R_WMAC_SECOND_CCA_TIMER_8822C))
#define BIT_GET_R_WMAC_SECOND_CCA_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SECOND_CCA_TIMER_8822C) & \
BIT_MASK_R_WMAC_SECOND_CCA_TIMER_8822C)
#define BIT_SET_R_WMAC_SECOND_CCA_TIMER_8822C(x, v) \
(BIT_CLEAR_R_WMAC_SECOND_CCA_TIMER_8822C(x) | \
BIT_R_WMAC_SECOND_CCA_TIMER_8822C(v))
#define BIT_SHIFT_RFMOD_8822C 7
#define BIT_MASK_RFMOD_8822C 0x3
#define BIT_RFMOD_8822C(x) \
(((x) & BIT_MASK_RFMOD_8822C) << BIT_SHIFT_RFMOD_8822C)
#define BITS_RFMOD_8822C (BIT_MASK_RFMOD_8822C << BIT_SHIFT_RFMOD_8822C)
#define BIT_CLEAR_RFMOD_8822C(x) ((x) & (~BITS_RFMOD_8822C))
#define BIT_GET_RFMOD_8822C(x) \
(((x) >> BIT_SHIFT_RFMOD_8822C) & BIT_MASK_RFMOD_8822C)
#define BIT_SET_RFMOD_8822C(x, v) \
(BIT_CLEAR_RFMOD_8822C(x) | BIT_RFMOD_8822C(v))
#define BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822C 5
#define BIT_MASK_RESP_CTS_DYNBW_SEL_8822C 0x3
#define BIT_RESP_CTS_DYNBW_SEL_8822C(x) \
(((x) & BIT_MASK_RESP_CTS_DYNBW_SEL_8822C) \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822C)
#define BITS_RESP_CTS_DYNBW_SEL_8822C \
(BIT_MASK_RESP_CTS_DYNBW_SEL_8822C \
<< BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822C)
#define BIT_CLEAR_RESP_CTS_DYNBW_SEL_8822C(x) \
((x) & (~BITS_RESP_CTS_DYNBW_SEL_8822C))
#define BIT_GET_RESP_CTS_DYNBW_SEL_8822C(x) \
(((x) >> BIT_SHIFT_RESP_CTS_DYNBW_SEL_8822C) & \
BIT_MASK_RESP_CTS_DYNBW_SEL_8822C)
#define BIT_SET_RESP_CTS_DYNBW_SEL_8822C(x, v) \
(BIT_CLEAR_RESP_CTS_DYNBW_SEL_8822C(x) | \
BIT_RESP_CTS_DYNBW_SEL_8822C(v))
#define BIT_DLY_TX_WAIT_RXANTSEL_8822C BIT(4)
#define BIT_TXRESP_BY_RXANTSEL_8822C BIT(3)
#define BIT_SHIFT_ORIG_DCTS_CHK_8822C 0
#define BIT_MASK_ORIG_DCTS_CHK_8822C 0x3
#define BIT_ORIG_DCTS_CHK_8822C(x) \
(((x) & BIT_MASK_ORIG_DCTS_CHK_8822C) << BIT_SHIFT_ORIG_DCTS_CHK_8822C)
#define BITS_ORIG_DCTS_CHK_8822C \
(BIT_MASK_ORIG_DCTS_CHK_8822C << BIT_SHIFT_ORIG_DCTS_CHK_8822C)
#define BIT_CLEAR_ORIG_DCTS_CHK_8822C(x) ((x) & (~BITS_ORIG_DCTS_CHK_8822C))
#define BIT_GET_ORIG_DCTS_CHK_8822C(x) \
(((x) >> BIT_SHIFT_ORIG_DCTS_CHK_8822C) & BIT_MASK_ORIG_DCTS_CHK_8822C)
#define BIT_SET_ORIG_DCTS_CHK_8822C(x, v) \
(BIT_CLEAR_ORIG_DCTS_CHK_8822C(x) | BIT_ORIG_DCTS_CHK_8822C(v))
/* 2 REG_WMAC_TRXPTCL_CTL_H_8822C */
#define BIT_SHIFT_ACKBA_TYPSEL_8822C 28
#define BIT_MASK_ACKBA_TYPSEL_8822C 0xf
#define BIT_ACKBA_TYPSEL_8822C(x) \
(((x) & BIT_MASK_ACKBA_TYPSEL_8822C) << BIT_SHIFT_ACKBA_TYPSEL_8822C)
#define BITS_ACKBA_TYPSEL_8822C \
(BIT_MASK_ACKBA_TYPSEL_8822C << BIT_SHIFT_ACKBA_TYPSEL_8822C)
#define BIT_CLEAR_ACKBA_TYPSEL_8822C(x) ((x) & (~BITS_ACKBA_TYPSEL_8822C))
#define BIT_GET_ACKBA_TYPSEL_8822C(x) \
(((x) >> BIT_SHIFT_ACKBA_TYPSEL_8822C) & BIT_MASK_ACKBA_TYPSEL_8822C)
#define BIT_SET_ACKBA_TYPSEL_8822C(x, v) \
(BIT_CLEAR_ACKBA_TYPSEL_8822C(x) | BIT_ACKBA_TYPSEL_8822C(v))
#define BIT_SHIFT_ACKBA_ACKPCHK_8822C 24
#define BIT_MASK_ACKBA_ACKPCHK_8822C 0xf
#define BIT_ACKBA_ACKPCHK_8822C(x) \
(((x) & BIT_MASK_ACKBA_ACKPCHK_8822C) << BIT_SHIFT_ACKBA_ACKPCHK_8822C)
#define BITS_ACKBA_ACKPCHK_8822C \
(BIT_MASK_ACKBA_ACKPCHK_8822C << BIT_SHIFT_ACKBA_ACKPCHK_8822C)
#define BIT_CLEAR_ACKBA_ACKPCHK_8822C(x) ((x) & (~BITS_ACKBA_ACKPCHK_8822C))
#define BIT_GET_ACKBA_ACKPCHK_8822C(x) \
(((x) >> BIT_SHIFT_ACKBA_ACKPCHK_8822C) & BIT_MASK_ACKBA_ACKPCHK_8822C)
#define BIT_SET_ACKBA_ACKPCHK_8822C(x, v) \
(BIT_CLEAR_ACKBA_ACKPCHK_8822C(x) | BIT_ACKBA_ACKPCHK_8822C(v))
#define BIT_SHIFT_ACKBAR_TYPESEL_8822C 16
#define BIT_MASK_ACKBAR_TYPESEL_8822C 0xff
#define BIT_ACKBAR_TYPESEL_8822C(x) \
(((x) & BIT_MASK_ACKBAR_TYPESEL_8822C) \
<< BIT_SHIFT_ACKBAR_TYPESEL_8822C)
#define BITS_ACKBAR_TYPESEL_8822C \
(BIT_MASK_ACKBAR_TYPESEL_8822C << BIT_SHIFT_ACKBAR_TYPESEL_8822C)
#define BIT_CLEAR_ACKBAR_TYPESEL_8822C(x) ((x) & (~BITS_ACKBAR_TYPESEL_8822C))
#define BIT_GET_ACKBAR_TYPESEL_8822C(x) \
(((x) >> BIT_SHIFT_ACKBAR_TYPESEL_8822C) & \
BIT_MASK_ACKBAR_TYPESEL_8822C)
#define BIT_SET_ACKBAR_TYPESEL_8822C(x, v) \
(BIT_CLEAR_ACKBAR_TYPESEL_8822C(x) | BIT_ACKBAR_TYPESEL_8822C(v))
#define BIT_SHIFT_ACKBAR_ACKPCHK_8822C 12
#define BIT_MASK_ACKBAR_ACKPCHK_8822C 0xf
#define BIT_ACKBAR_ACKPCHK_8822C(x) \
(((x) & BIT_MASK_ACKBAR_ACKPCHK_8822C) \
<< BIT_SHIFT_ACKBAR_ACKPCHK_8822C)
#define BITS_ACKBAR_ACKPCHK_8822C \
(BIT_MASK_ACKBAR_ACKPCHK_8822C << BIT_SHIFT_ACKBAR_ACKPCHK_8822C)
#define BIT_CLEAR_ACKBAR_ACKPCHK_8822C(x) ((x) & (~BITS_ACKBAR_ACKPCHK_8822C))
#define BIT_GET_ACKBAR_ACKPCHK_8822C(x) \
(((x) >> BIT_SHIFT_ACKBAR_ACKPCHK_8822C) & \
BIT_MASK_ACKBAR_ACKPCHK_8822C)
#define BIT_SET_ACKBAR_ACKPCHK_8822C(x, v) \
(BIT_CLEAR_ACKBAR_ACKPCHK_8822C(x) | BIT_ACKBAR_ACKPCHK_8822C(v))
#define BIT_RXBA_IGNOREA2_V1_8822C BIT(10)
#define BIT_EN_SAVE_ALL_TXOPADDR_V1_8822C BIT(9)
#define BIT_EN_TXCTS_TO_TXOPOWNER_INRXNAV_V1_8822C BIT(8)
#define BIT_DIS_TXBA_AMPDUFCSERR_V1_8822C BIT(7)
#define BIT_DIS_TXBA_RXBARINFULL_V1_8822C BIT(6)
#define BIT_DIS_TXCFE_INFULL_V1_8822C BIT(5)
#define BIT_DIS_TXCTS_INFULL_V1_8822C BIT(4)
#define BIT_EN_TXACKBA_IN_TX_RDG_V1_8822C BIT(3)
#define BIT_EN_TXACKBA_IN_TXOP_V1_8822C BIT(2)
#define BIT_EN_TXCTS_IN_RXNAV_V1_8822C BIT(1)
#define BIT_EN_TXCTS_INTXOP_V1_8822C BIT(0)
/* 2 REG_CAMCMD_8822C (CAM COMMAND REGISTER) */
#define BIT_SECCAM_POLLING_8822C BIT(31)
#define BIT_SECCAM_CLR_8822C BIT(30)
#define BIT_SECCAM_WE_8822C BIT(16)
#define BIT_SHIFT_SECCAM_ADDR_V2_8822C 0
#define BIT_MASK_SECCAM_ADDR_V2_8822C 0x3ff
#define BIT_SECCAM_ADDR_V2_8822C(x) \
(((x) & BIT_MASK_SECCAM_ADDR_V2_8822C) \
<< BIT_SHIFT_SECCAM_ADDR_V2_8822C)
#define BITS_SECCAM_ADDR_V2_8822C \
(BIT_MASK_SECCAM_ADDR_V2_8822C << BIT_SHIFT_SECCAM_ADDR_V2_8822C)
#define BIT_CLEAR_SECCAM_ADDR_V2_8822C(x) ((x) & (~BITS_SECCAM_ADDR_V2_8822C))
#define BIT_GET_SECCAM_ADDR_V2_8822C(x) \
(((x) >> BIT_SHIFT_SECCAM_ADDR_V2_8822C) & \
BIT_MASK_SECCAM_ADDR_V2_8822C)
#define BIT_SET_SECCAM_ADDR_V2_8822C(x, v) \
(BIT_CLEAR_SECCAM_ADDR_V2_8822C(x) | BIT_SECCAM_ADDR_V2_8822C(v))
/* 2 REG_CAMWRITE_8822C (CAM WRITE REGISTER) */
#define BIT_SHIFT_CAMW_DATA_8822C 0
#define BIT_MASK_CAMW_DATA_8822C 0xffffffffL
#define BIT_CAMW_DATA_8822C(x) \
(((x) & BIT_MASK_CAMW_DATA_8822C) << BIT_SHIFT_CAMW_DATA_8822C)
#define BITS_CAMW_DATA_8822C \
(BIT_MASK_CAMW_DATA_8822C << BIT_SHIFT_CAMW_DATA_8822C)
#define BIT_CLEAR_CAMW_DATA_8822C(x) ((x) & (~BITS_CAMW_DATA_8822C))
#define BIT_GET_CAMW_DATA_8822C(x) \
(((x) >> BIT_SHIFT_CAMW_DATA_8822C) & BIT_MASK_CAMW_DATA_8822C)
#define BIT_SET_CAMW_DATA_8822C(x, v) \
(BIT_CLEAR_CAMW_DATA_8822C(x) | BIT_CAMW_DATA_8822C(v))
/* 2 REG_CAMREAD_8822C (CAM READ REGISTER) */
#define BIT_SHIFT_CAMR_DATA_8822C 0
#define BIT_MASK_CAMR_DATA_8822C 0xffffffffL
#define BIT_CAMR_DATA_8822C(x) \
(((x) & BIT_MASK_CAMR_DATA_8822C) << BIT_SHIFT_CAMR_DATA_8822C)
#define BITS_CAMR_DATA_8822C \
(BIT_MASK_CAMR_DATA_8822C << BIT_SHIFT_CAMR_DATA_8822C)
#define BIT_CLEAR_CAMR_DATA_8822C(x) ((x) & (~BITS_CAMR_DATA_8822C))
#define BIT_GET_CAMR_DATA_8822C(x) \
(((x) >> BIT_SHIFT_CAMR_DATA_8822C) & BIT_MASK_CAMR_DATA_8822C)
#define BIT_SET_CAMR_DATA_8822C(x, v) \
(BIT_CLEAR_CAMR_DATA_8822C(x) | BIT_CAMR_DATA_8822C(v))
/* 2 REG_CAMDBG_8822C (CAM DEBUG REGISTER) */
#define BIT_SECCAM_INFO_8822C BIT(31)
#define BIT_SEC_KEYFOUND_8822C BIT(15)
#define BIT_SHIFT_CAMDBG_SEC_TYPE_8822C 12
#define BIT_MASK_CAMDBG_SEC_TYPE_8822C 0x7
#define BIT_CAMDBG_SEC_TYPE_8822C(x) \
(((x) & BIT_MASK_CAMDBG_SEC_TYPE_8822C) \
<< BIT_SHIFT_CAMDBG_SEC_TYPE_8822C)
#define BITS_CAMDBG_SEC_TYPE_8822C \
(BIT_MASK_CAMDBG_SEC_TYPE_8822C << BIT_SHIFT_CAMDBG_SEC_TYPE_8822C)
#define BIT_CLEAR_CAMDBG_SEC_TYPE_8822C(x) ((x) & (~BITS_CAMDBG_SEC_TYPE_8822C))
#define BIT_GET_CAMDBG_SEC_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_TYPE_8822C) & \
BIT_MASK_CAMDBG_SEC_TYPE_8822C)
#define BIT_SET_CAMDBG_SEC_TYPE_8822C(x, v) \
(BIT_CLEAR_CAMDBG_SEC_TYPE_8822C(x) | BIT_CAMDBG_SEC_TYPE_8822C(v))
#define BIT_CAMDBG_EXT_SECTYPE_8822C BIT(11)
#define BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822C 5
#define BIT_MASK_CAMDBG_MIC_KEY_IDX_8822C 0x1f
#define BIT_CAMDBG_MIC_KEY_IDX_8822C(x) \
(((x) & BIT_MASK_CAMDBG_MIC_KEY_IDX_8822C) \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822C)
#define BITS_CAMDBG_MIC_KEY_IDX_8822C \
(BIT_MASK_CAMDBG_MIC_KEY_IDX_8822C \
<< BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822C)
#define BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8822C(x) \
((x) & (~BITS_CAMDBG_MIC_KEY_IDX_8822C))
#define BIT_GET_CAMDBG_MIC_KEY_IDX_8822C(x) \
(((x) >> BIT_SHIFT_CAMDBG_MIC_KEY_IDX_8822C) & \
BIT_MASK_CAMDBG_MIC_KEY_IDX_8822C)
#define BIT_SET_CAMDBG_MIC_KEY_IDX_8822C(x, v) \
(BIT_CLEAR_CAMDBG_MIC_KEY_IDX_8822C(x) | \
BIT_CAMDBG_MIC_KEY_IDX_8822C(v))
#define BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822C 0
#define BIT_MASK_CAMDBG_SEC_KEY_IDX_8822C 0x1f
#define BIT_CAMDBG_SEC_KEY_IDX_8822C(x) \
(((x) & BIT_MASK_CAMDBG_SEC_KEY_IDX_8822C) \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822C)
#define BITS_CAMDBG_SEC_KEY_IDX_8822C \
(BIT_MASK_CAMDBG_SEC_KEY_IDX_8822C \
<< BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822C)
#define BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8822C(x) \
((x) & (~BITS_CAMDBG_SEC_KEY_IDX_8822C))
#define BIT_GET_CAMDBG_SEC_KEY_IDX_8822C(x) \
(((x) >> BIT_SHIFT_CAMDBG_SEC_KEY_IDX_8822C) & \
BIT_MASK_CAMDBG_SEC_KEY_IDX_8822C)
#define BIT_SET_CAMDBG_SEC_KEY_IDX_8822C(x, v) \
(BIT_CLEAR_CAMDBG_SEC_KEY_IDX_8822C(x) | \
BIT_CAMDBG_SEC_KEY_IDX_8822C(v))
/* 2 REG_SECCFG_8822C (SECURITY CONFIGURATION REGISTER) */
#define BIT_DIS_GCLK_WAPI_8822C BIT(15)
#define BIT_DIS_GCLK_AES_8822C BIT(14)
#define BIT_DIS_GCLK_TKIP_8822C BIT(13)
#define BIT_AES_SEL_QC_1_8822C BIT(12)
#define BIT_AES_SEL_QC_0_8822C BIT(11)
#define BIT_CHK_BMC_8822C BIT(9)
#define BIT_CHK_KEYID_8822C BIT(8)
#define BIT_RXBCUSEDK_8822C BIT(7)
#define BIT_TXBCUSEDK_8822C BIT(6)
#define BIT_NOSKMC_8822C BIT(5)
#define BIT_SKBYA2_8822C BIT(4)
#define BIT_RXDEC_8822C BIT(3)
#define BIT_TXENC_8822C BIT(2)
#define BIT_RXUHUSEDK_8822C BIT(1)
#define BIT_TXUHUSEDK_8822C BIT(0)
/* 2 REG_RXFILTER_CATEGORY_1_8822C */
#define BIT_SHIFT_RXFILTER_CATEGORY_1_8822C 0
#define BIT_MASK_RXFILTER_CATEGORY_1_8822C 0xff
#define BIT_RXFILTER_CATEGORY_1_8822C(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_1_8822C) \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8822C)
#define BITS_RXFILTER_CATEGORY_1_8822C \
(BIT_MASK_RXFILTER_CATEGORY_1_8822C \
<< BIT_SHIFT_RXFILTER_CATEGORY_1_8822C)
#define BIT_CLEAR_RXFILTER_CATEGORY_1_8822C(x) \
((x) & (~BITS_RXFILTER_CATEGORY_1_8822C))
#define BIT_GET_RXFILTER_CATEGORY_1_8822C(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_1_8822C) & \
BIT_MASK_RXFILTER_CATEGORY_1_8822C)
#define BIT_SET_RXFILTER_CATEGORY_1_8822C(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_1_8822C(x) | \
BIT_RXFILTER_CATEGORY_1_8822C(v))
/* 2 REG_RXFILTER_ACTION_1_8822C */
#define BIT_SHIFT_RXFILTER_ACTION_1_8822C 0
#define BIT_MASK_RXFILTER_ACTION_1_8822C 0xff
#define BIT_RXFILTER_ACTION_1_8822C(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_1_8822C) \
<< BIT_SHIFT_RXFILTER_ACTION_1_8822C)
#define BITS_RXFILTER_ACTION_1_8822C \
(BIT_MASK_RXFILTER_ACTION_1_8822C << BIT_SHIFT_RXFILTER_ACTION_1_8822C)
#define BIT_CLEAR_RXFILTER_ACTION_1_8822C(x) \
((x) & (~BITS_RXFILTER_ACTION_1_8822C))
#define BIT_GET_RXFILTER_ACTION_1_8822C(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_1_8822C) & \
BIT_MASK_RXFILTER_ACTION_1_8822C)
#define BIT_SET_RXFILTER_ACTION_1_8822C(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_1_8822C(x) | BIT_RXFILTER_ACTION_1_8822C(v))
/* 2 REG_RXFILTER_CATEGORY_2_8822C */
#define BIT_SHIFT_RXFILTER_CATEGORY_2_8822C 0
#define BIT_MASK_RXFILTER_CATEGORY_2_8822C 0xff
#define BIT_RXFILTER_CATEGORY_2_8822C(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_2_8822C) \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8822C)
#define BITS_RXFILTER_CATEGORY_2_8822C \
(BIT_MASK_RXFILTER_CATEGORY_2_8822C \
<< BIT_SHIFT_RXFILTER_CATEGORY_2_8822C)
#define BIT_CLEAR_RXFILTER_CATEGORY_2_8822C(x) \
((x) & (~BITS_RXFILTER_CATEGORY_2_8822C))
#define BIT_GET_RXFILTER_CATEGORY_2_8822C(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_2_8822C) & \
BIT_MASK_RXFILTER_CATEGORY_2_8822C)
#define BIT_SET_RXFILTER_CATEGORY_2_8822C(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_2_8822C(x) | \
BIT_RXFILTER_CATEGORY_2_8822C(v))
/* 2 REG_RXFILTER_ACTION_2_8822C */
#define BIT_SHIFT_RXFILTER_ACTION_2_8822C 0
#define BIT_MASK_RXFILTER_ACTION_2_8822C 0xff
#define BIT_RXFILTER_ACTION_2_8822C(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_2_8822C) \
<< BIT_SHIFT_RXFILTER_ACTION_2_8822C)
#define BITS_RXFILTER_ACTION_2_8822C \
(BIT_MASK_RXFILTER_ACTION_2_8822C << BIT_SHIFT_RXFILTER_ACTION_2_8822C)
#define BIT_CLEAR_RXFILTER_ACTION_2_8822C(x) \
((x) & (~BITS_RXFILTER_ACTION_2_8822C))
#define BIT_GET_RXFILTER_ACTION_2_8822C(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_2_8822C) & \
BIT_MASK_RXFILTER_ACTION_2_8822C)
#define BIT_SET_RXFILTER_ACTION_2_8822C(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_2_8822C(x) | BIT_RXFILTER_ACTION_2_8822C(v))
/* 2 REG_RXFILTER_CATEGORY_3_8822C */
#define BIT_SHIFT_RXFILTER_CATEGORY_3_8822C 0
#define BIT_MASK_RXFILTER_CATEGORY_3_8822C 0xff
#define BIT_RXFILTER_CATEGORY_3_8822C(x) \
(((x) & BIT_MASK_RXFILTER_CATEGORY_3_8822C) \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8822C)
#define BITS_RXFILTER_CATEGORY_3_8822C \
(BIT_MASK_RXFILTER_CATEGORY_3_8822C \
<< BIT_SHIFT_RXFILTER_CATEGORY_3_8822C)
#define BIT_CLEAR_RXFILTER_CATEGORY_3_8822C(x) \
((x) & (~BITS_RXFILTER_CATEGORY_3_8822C))
#define BIT_GET_RXFILTER_CATEGORY_3_8822C(x) \
(((x) >> BIT_SHIFT_RXFILTER_CATEGORY_3_8822C) & \
BIT_MASK_RXFILTER_CATEGORY_3_8822C)
#define BIT_SET_RXFILTER_CATEGORY_3_8822C(x, v) \
(BIT_CLEAR_RXFILTER_CATEGORY_3_8822C(x) | \
BIT_RXFILTER_CATEGORY_3_8822C(v))
/* 2 REG_RXFILTER_ACTION_3_8822C */
#define BIT_SHIFT_RXFILTER_ACTION_3_8822C 0
#define BIT_MASK_RXFILTER_ACTION_3_8822C 0xff
#define BIT_RXFILTER_ACTION_3_8822C(x) \
(((x) & BIT_MASK_RXFILTER_ACTION_3_8822C) \
<< BIT_SHIFT_RXFILTER_ACTION_3_8822C)
#define BITS_RXFILTER_ACTION_3_8822C \
(BIT_MASK_RXFILTER_ACTION_3_8822C << BIT_SHIFT_RXFILTER_ACTION_3_8822C)
#define BIT_CLEAR_RXFILTER_ACTION_3_8822C(x) \
((x) & (~BITS_RXFILTER_ACTION_3_8822C))
#define BIT_GET_RXFILTER_ACTION_3_8822C(x) \
(((x) >> BIT_SHIFT_RXFILTER_ACTION_3_8822C) & \
BIT_MASK_RXFILTER_ACTION_3_8822C)
#define BIT_SET_RXFILTER_ACTION_3_8822C(x, v) \
(BIT_CLEAR_RXFILTER_ACTION_3_8822C(x) | BIT_RXFILTER_ACTION_3_8822C(v))
/* 2 REG_RXFLTMAP3_8822C (RX FILTER MAP GROUP 3) */
#define BIT_MGTFLT15EN_FW_8822C BIT(15)
#define BIT_MGTFLT14EN_FW_8822C BIT(14)
#define BIT_MGTFLT13EN_FW_8822C BIT(13)
#define BIT_MGTFLT12EN_FW_8822C BIT(12)
#define BIT_MGTFLT11EN_FW_8822C BIT(11)
#define BIT_MGTFLT10EN_FW_8822C BIT(10)
#define BIT_MGTFLT9EN_FW_8822C BIT(9)
#define BIT_MGTFLT8EN_FW_8822C BIT(8)
#define BIT_MGTFLT7EN_FW_8822C BIT(7)
#define BIT_MGTFLT6EN_FW_8822C BIT(6)
#define BIT_MGTFLT5EN_FW_8822C BIT(5)
#define BIT_MGTFLT4EN_FW_8822C BIT(4)
#define BIT_MGTFLT3EN_FW_8822C BIT(3)
#define BIT_MGTFLT2EN_FW_8822C BIT(2)
#define BIT_MGTFLT1EN_FW_8822C BIT(1)
#define BIT_MGTFLT0EN_FW_8822C BIT(0)
/* 2 REG_RXFLTMAP4_8822C (RX FILTER MAP GROUP 4) */
#define BIT_CTRLFLT15EN_FW_8822C BIT(15)
#define BIT_CTRLFLT14EN_FW_8822C BIT(14)
#define BIT_CTRLFLT13EN_FW_8822C BIT(13)
#define BIT_CTRLFLT12EN_FW_8822C BIT(12)
#define BIT_CTRLFLT11EN_FW_8822C BIT(11)
#define BIT_CTRLFLT10EN_FW_8822C BIT(10)
#define BIT_CTRLFLT9EN_FW_8822C BIT(9)
#define BIT_CTRLFLT8EN_FW_8822C BIT(8)
#define BIT_CTRLFLT7EN_FW_8822C BIT(7)
#define BIT_CTRLFLT6EN_FW_8822C BIT(6)
#define BIT_CTRLFLT5EN_FW_8822C BIT(5)
#define BIT_CTRLFLT4EN_FW_8822C BIT(4)
#define BIT_CTRLFLT3EN_FW_8822C BIT(3)
#define BIT_CTRLFLT2EN_FW_8822C BIT(2)
#define BIT_CTRLFLT1EN_FW_8822C BIT(1)
#define BIT_CTRLFLT0EN_FW_8822C BIT(0)
/* 2 REG_RXFLTMAP5_8822C (RX FILTER MAP GROUP 5) */
#define BIT_DATAFLT15EN_FW_8822C BIT(15)
#define BIT_DATAFLT14EN_FW_8822C BIT(14)
#define BIT_DATAFLT13EN_FW_8822C BIT(13)
#define BIT_DATAFLT12EN_FW_8822C BIT(12)
#define BIT_DATAFLT11EN_FW_8822C BIT(11)
#define BIT_DATAFLT10EN_FW_8822C BIT(10)
#define BIT_DATAFLT9EN_FW_8822C BIT(9)
#define BIT_DATAFLT8EN_FW_8822C BIT(8)
#define BIT_DATAFLT7EN_FW_8822C BIT(7)
#define BIT_DATAFLT6EN_FW_8822C BIT(6)
#define BIT_DATAFLT5EN_FW_8822C BIT(5)
#define BIT_DATAFLT4EN_FW_8822C BIT(4)
#define BIT_DATAFLT3EN_FW_8822C BIT(3)
#define BIT_DATAFLT2EN_FW_8822C BIT(2)
#define BIT_DATAFLT1EN_FW_8822C BIT(1)
#define BIT_DATAFLT0EN_FW_8822C BIT(0)
/* 2 REG_RXFLTMAP6_8822C (RX FILTER MAP GROUP 6) */
#define BIT_ACTIONFLT15EN_FW_8822C BIT(15)
#define BIT_ACTIONFLT14EN_FW_8822C BIT(14)
#define BIT_ACTIONFLT13EN_FW_8822C BIT(13)
#define BIT_ACTIONFLT12EN_FW_8822C BIT(12)
#define BIT_ACTIONFLT11EN_FW_8822C BIT(11)
#define BIT_ACTIONFLT10EN_FW_8822C BIT(10)
#define BIT_ACTIONFLT9EN_FW_8822C BIT(9)
#define BIT_ACTIONFLT8EN_FW_8822C BIT(8)
#define BIT_ACTIONFLT7EN_FW_8822C BIT(7)
#define BIT_ACTIONFLT6EN_FW_8822C BIT(6)
#define BIT_ACTIONFLT5EN_FW_8822C BIT(5)
#define BIT_ACTIONFLT4EN_FW_8822C BIT(4)
#define BIT_ACTIONFLT3EN_FW_8822C BIT(3)
#define BIT_ACTIONFLT2EN_FW_8822C BIT(2)
#define BIT_ACTIONFLT1EN_FW_8822C BIT(1)
#define BIT_ACTIONFLT0EN_FW_8822C BIT(0)
/* 2 REG_WOW_CTRL_8822C (WAKE ON WLAN CONTROL REGISTER) */
#define BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822C 6
#define BIT_MASK_PSF_BSSIDSEL_B2B1_8822C 0x3
#define BIT_PSF_BSSIDSEL_B2B1_8822C(x) \
(((x) & BIT_MASK_PSF_BSSIDSEL_B2B1_8822C) \
<< BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822C)
#define BITS_PSF_BSSIDSEL_B2B1_8822C \
(BIT_MASK_PSF_BSSIDSEL_B2B1_8822C << BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822C)
#define BIT_CLEAR_PSF_BSSIDSEL_B2B1_8822C(x) \
((x) & (~BITS_PSF_BSSIDSEL_B2B1_8822C))
#define BIT_GET_PSF_BSSIDSEL_B2B1_8822C(x) \
(((x) >> BIT_SHIFT_PSF_BSSIDSEL_B2B1_8822C) & \
BIT_MASK_PSF_BSSIDSEL_B2B1_8822C)
#define BIT_SET_PSF_BSSIDSEL_B2B1_8822C(x, v) \
(BIT_CLEAR_PSF_BSSIDSEL_B2B1_8822C(x) | BIT_PSF_BSSIDSEL_B2B1_8822C(v))
#define BIT_WOWHCI_8822C BIT(5)
#define BIT_PSF_BSSIDSEL_B0_8822C BIT(4)
#define BIT_UWF_8822C BIT(3)
#define BIT_MAGIC_8822C BIT(2)
#define BIT_WOWEN_8822C BIT(1)
#define BIT_FORCE_WAKEUP_8822C BIT(0)
/* 2 REG_NAN_RX_TSF_FILTER_8822C(NAN_RX_TSF_ADDRESS_FILTER) */
#define BIT_CHK_TSF_TA_8822C BIT(2)
#define BIT_CHK_TSF_CBSSID_8822C BIT(1)
#define BIT_CHK_TSF_EN_8822C BIT(0)
/* 2 REG_PS_RX_INFO_8822C (POWER SAVE RX INFORMATION REGISTER) */
#define BIT_SHIFT_PORTSEL__PS_RX_INFO_8822C 5
#define BIT_MASK_PORTSEL__PS_RX_INFO_8822C 0x7
#define BIT_PORTSEL__PS_RX_INFO_8822C(x) \
(((x) & BIT_MASK_PORTSEL__PS_RX_INFO_8822C) \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8822C)
#define BITS_PORTSEL__PS_RX_INFO_8822C \
(BIT_MASK_PORTSEL__PS_RX_INFO_8822C \
<< BIT_SHIFT_PORTSEL__PS_RX_INFO_8822C)
#define BIT_CLEAR_PORTSEL__PS_RX_INFO_8822C(x) \
((x) & (~BITS_PORTSEL__PS_RX_INFO_8822C))
#define BIT_GET_PORTSEL__PS_RX_INFO_8822C(x) \
(((x) >> BIT_SHIFT_PORTSEL__PS_RX_INFO_8822C) & \
BIT_MASK_PORTSEL__PS_RX_INFO_8822C)
#define BIT_SET_PORTSEL__PS_RX_INFO_8822C(x, v) \
(BIT_CLEAR_PORTSEL__PS_RX_INFO_8822C(x) | \
BIT_PORTSEL__PS_RX_INFO_8822C(v))
#define BIT_RXCTRLIN0_8822C BIT(4)
#define BIT_RXMGTIN0_8822C BIT(3)
#define BIT_RXDATAIN2_8822C BIT(2)
#define BIT_RXDATAIN1_8822C BIT(1)
#define BIT_RXDATAIN0_8822C BIT(0)
/* 2 REG_WMMPS_UAPSD_TID_8822C (WMM POWER SAVE UAPSD TID REGISTER) */
#define BIT_WMMPS_UAPSD_TID7_8822C BIT(7)
#define BIT_WMMPS_UAPSD_TID6_8822C BIT(6)
#define BIT_WMMPS_UAPSD_TID5_8822C BIT(5)
#define BIT_WMMPS_UAPSD_TID4_8822C BIT(4)
#define BIT_WMMPS_UAPSD_TID3_8822C BIT(3)
#define BIT_WMMPS_UAPSD_TID2_8822C BIT(2)
#define BIT_WMMPS_UAPSD_TID1_8822C BIT(1)
#define BIT_WMMPS_UAPSD_TID0_8822C BIT(0)
/* 2 REG_LPNAV_CTRL_8822C (LOW POWER NAV CONTROL REGISTER) */
/* 2 REG_WKFMCAM_CMD_8822C (WAKEUP FRAME CAM COMMAND REGISTER) */
#define BIT_WKFCAM_POLLING_V1_8822C BIT(31)
#define BIT_WKFCAM_CLR_V1_8822C BIT(30)
#define BIT_WKFCAM_WE_8822C BIT(16)
#define BIT_SHIFT_WKFCAM_ADDR_V2_8822C 8
#define BIT_MASK_WKFCAM_ADDR_V2_8822C 0xff
#define BIT_WKFCAM_ADDR_V2_8822C(x) \
(((x) & BIT_MASK_WKFCAM_ADDR_V2_8822C) \
<< BIT_SHIFT_WKFCAM_ADDR_V2_8822C)
#define BITS_WKFCAM_ADDR_V2_8822C \
(BIT_MASK_WKFCAM_ADDR_V2_8822C << BIT_SHIFT_WKFCAM_ADDR_V2_8822C)
#define BIT_CLEAR_WKFCAM_ADDR_V2_8822C(x) ((x) & (~BITS_WKFCAM_ADDR_V2_8822C))
#define BIT_GET_WKFCAM_ADDR_V2_8822C(x) \
(((x) >> BIT_SHIFT_WKFCAM_ADDR_V2_8822C) & \
BIT_MASK_WKFCAM_ADDR_V2_8822C)
#define BIT_SET_WKFCAM_ADDR_V2_8822C(x, v) \
(BIT_CLEAR_WKFCAM_ADDR_V2_8822C(x) | BIT_WKFCAM_ADDR_V2_8822C(v))
#define BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822C 0
#define BIT_MASK_WKFCAM_CAM_NUM_V1_8822C 0xff
#define BIT_WKFCAM_CAM_NUM_V1_8822C(x) \
(((x) & BIT_MASK_WKFCAM_CAM_NUM_V1_8822C) \
<< BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822C)
#define BITS_WKFCAM_CAM_NUM_V1_8822C \
(BIT_MASK_WKFCAM_CAM_NUM_V1_8822C << BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822C)
#define BIT_CLEAR_WKFCAM_CAM_NUM_V1_8822C(x) \
((x) & (~BITS_WKFCAM_CAM_NUM_V1_8822C))
#define BIT_GET_WKFCAM_CAM_NUM_V1_8822C(x) \
(((x) >> BIT_SHIFT_WKFCAM_CAM_NUM_V1_8822C) & \
BIT_MASK_WKFCAM_CAM_NUM_V1_8822C)
#define BIT_SET_WKFCAM_CAM_NUM_V1_8822C(x, v) \
(BIT_CLEAR_WKFCAM_CAM_NUM_V1_8822C(x) | BIT_WKFCAM_CAM_NUM_V1_8822C(v))
/* 2 REG_WKFMCAM_RWD_8822C (WAKEUP FRAME READ/WRITE DATA) */
#define BIT_SHIFT_WKFMCAM_RWD_8822C 0
#define BIT_MASK_WKFMCAM_RWD_8822C 0xffffffffL
#define BIT_WKFMCAM_RWD_8822C(x) \
(((x) & BIT_MASK_WKFMCAM_RWD_8822C) << BIT_SHIFT_WKFMCAM_RWD_8822C)
#define BITS_WKFMCAM_RWD_8822C \
(BIT_MASK_WKFMCAM_RWD_8822C << BIT_SHIFT_WKFMCAM_RWD_8822C)
#define BIT_CLEAR_WKFMCAM_RWD_8822C(x) ((x) & (~BITS_WKFMCAM_RWD_8822C))
#define BIT_GET_WKFMCAM_RWD_8822C(x) \
(((x) >> BIT_SHIFT_WKFMCAM_RWD_8822C) & BIT_MASK_WKFMCAM_RWD_8822C)
#define BIT_SET_WKFMCAM_RWD_8822C(x, v) \
(BIT_CLEAR_WKFMCAM_RWD_8822C(x) | BIT_WKFMCAM_RWD_8822C(v))
/* 2 REG_RXFLTMAP0_8822C (RX FILTER MAP GROUP 0) */
#define BIT_MGTFLT15EN_8822C BIT(15)
#define BIT_MGTFLT14EN_8822C BIT(14)
#define BIT_MGTFLT13EN_8822C BIT(13)
#define BIT_MGTFLT12EN_8822C BIT(12)
#define BIT_MGTFLT11EN_8822C BIT(11)
#define BIT_MGTFLT10EN_8822C BIT(10)
#define BIT_MGTFLT9EN_8822C BIT(9)
#define BIT_MGTFLT8EN_8822C BIT(8)
#define BIT_MGTFLT7EN_8822C BIT(7)
#define BIT_MGTFLT6EN_8822C BIT(6)
#define BIT_MGTFLT5EN_8822C BIT(5)
#define BIT_MGTFLT4EN_8822C BIT(4)
#define BIT_MGTFLT3EN_8822C BIT(3)
#define BIT_MGTFLT2EN_8822C BIT(2)
#define BIT_MGTFLT1EN_8822C BIT(1)
#define BIT_MGTFLT0EN_8822C BIT(0)
/* 2 REG_RXFLTMAP1_8822C (RX FILTER MAP GROUP 1) */
#define BIT_CTRLFLT15EN_8822C BIT(15)
#define BIT_CTRLFLT14EN_8822C BIT(14)
#define BIT_CTRLFLT13EN_8822C BIT(13)
#define BIT_CTRLFLT12EN_8822C BIT(12)
#define BIT_CTRLFLT11EN_8822C BIT(11)
#define BIT_CTRLFLT10EN_8822C BIT(10)
#define BIT_CTRLFLT9EN_8822C BIT(9)
#define BIT_CTRLFLT8EN_8822C BIT(8)
#define BIT_CTRLFLT7EN_8822C BIT(7)
#define BIT_CTRLFLT6EN_8822C BIT(6)
#define BIT_CTRLFLT5EN_8822C BIT(5)
#define BIT_CTRLFLT4EN_8822C BIT(4)
#define BIT_CTRLFLT3EN_8822C BIT(3)
#define BIT_CTRLFLT2EN_8822C BIT(2)
#define BIT_CTRLFLT1EN_8822C BIT(1)
#define BIT_CTRLFLT0EN_8822C BIT(0)
/* 2 REG_RXFLTMAP2_8822C (RX FILTER MAP GROUP 2) */
#define BIT_DATAFLT15EN_8822C BIT(15)
#define BIT_DATAFLT14EN_8822C BIT(14)
#define BIT_DATAFLT13EN_8822C BIT(13)
#define BIT_DATAFLT12EN_8822C BIT(12)
#define BIT_DATAFLT11EN_8822C BIT(11)
#define BIT_DATAFLT10EN_8822C BIT(10)
#define BIT_DATAFLT9EN_8822C BIT(9)
#define BIT_DATAFLT8EN_8822C BIT(8)
#define BIT_DATAFLT7EN_8822C BIT(7)
#define BIT_DATAFLT6EN_8822C BIT(6)
#define BIT_DATAFLT5EN_8822C BIT(5)
#define BIT_DATAFLT4EN_8822C BIT(4)
#define BIT_DATAFLT3EN_8822C BIT(3)
#define BIT_DATAFLT2EN_8822C BIT(2)
#define BIT_DATAFLT1EN_8822C BIT(1)
#define BIT_DATAFLT0EN_8822C BIT(0)
/* 2 REG_RSVD_8822C */
/* 2 REG_BCN_PSR_RPT_8822C (BEACON PARSER REPORT REGISTER) */
#define BIT_SHIFT_DTIM_CNT_8822C 24
#define BIT_MASK_DTIM_CNT_8822C 0xff
#define BIT_DTIM_CNT_8822C(x) \
(((x) & BIT_MASK_DTIM_CNT_8822C) << BIT_SHIFT_DTIM_CNT_8822C)
#define BITS_DTIM_CNT_8822C \
(BIT_MASK_DTIM_CNT_8822C << BIT_SHIFT_DTIM_CNT_8822C)
#define BIT_CLEAR_DTIM_CNT_8822C(x) ((x) & (~BITS_DTIM_CNT_8822C))
#define BIT_GET_DTIM_CNT_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT_8822C) & BIT_MASK_DTIM_CNT_8822C)
#define BIT_SET_DTIM_CNT_8822C(x, v) \
(BIT_CLEAR_DTIM_CNT_8822C(x) | BIT_DTIM_CNT_8822C(v))
#define BIT_SHIFT_DTIM_PERIOD_8822C 16
#define BIT_MASK_DTIM_PERIOD_8822C 0xff
#define BIT_DTIM_PERIOD_8822C(x) \
(((x) & BIT_MASK_DTIM_PERIOD_8822C) << BIT_SHIFT_DTIM_PERIOD_8822C)
#define BITS_DTIM_PERIOD_8822C \
(BIT_MASK_DTIM_PERIOD_8822C << BIT_SHIFT_DTIM_PERIOD_8822C)
#define BIT_CLEAR_DTIM_PERIOD_8822C(x) ((x) & (~BITS_DTIM_PERIOD_8822C))
#define BIT_GET_DTIM_PERIOD_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD_8822C) & BIT_MASK_DTIM_PERIOD_8822C)
#define BIT_SET_DTIM_PERIOD_8822C(x, v) \
(BIT_CLEAR_DTIM_PERIOD_8822C(x) | BIT_DTIM_PERIOD_8822C(v))
#define BIT_DTIM_8822C BIT(15)
#define BIT_TIM_8822C BIT(14)
#define BIT_RPT_VALID_8822C BIT(13)
#define BIT_SHIFT_PS_AID_0_8822C 0
#define BIT_MASK_PS_AID_0_8822C 0x7ff
#define BIT_PS_AID_0_8822C(x) \
(((x) & BIT_MASK_PS_AID_0_8822C) << BIT_SHIFT_PS_AID_0_8822C)
#define BITS_PS_AID_0_8822C \
(BIT_MASK_PS_AID_0_8822C << BIT_SHIFT_PS_AID_0_8822C)
#define BIT_CLEAR_PS_AID_0_8822C(x) ((x) & (~BITS_PS_AID_0_8822C))
#define BIT_GET_PS_AID_0_8822C(x) \
(((x) >> BIT_SHIFT_PS_AID_0_8822C) & BIT_MASK_PS_AID_0_8822C)
#define BIT_SET_PS_AID_0_8822C(x, v) \
(BIT_CLEAR_PS_AID_0_8822C(x) | BIT_PS_AID_0_8822C(v))
/* 2 REG_FLC_RPC_8822C (FW LPS CONDITION -- RX PKT COUNTER) */
#define BIT_SHIFT_FLC_RPC_8822C 0
#define BIT_MASK_FLC_RPC_8822C 0xff
#define BIT_FLC_RPC_8822C(x) \
(((x) & BIT_MASK_FLC_RPC_8822C) << BIT_SHIFT_FLC_RPC_8822C)
#define BITS_FLC_RPC_8822C (BIT_MASK_FLC_RPC_8822C << BIT_SHIFT_FLC_RPC_8822C)
#define BIT_CLEAR_FLC_RPC_8822C(x) ((x) & (~BITS_FLC_RPC_8822C))
#define BIT_GET_FLC_RPC_8822C(x) \
(((x) >> BIT_SHIFT_FLC_RPC_8822C) & BIT_MASK_FLC_RPC_8822C)
#define BIT_SET_FLC_RPC_8822C(x, v) \
(BIT_CLEAR_FLC_RPC_8822C(x) | BIT_FLC_RPC_8822C(v))
/* 2 REG_FLC_RPCT_8822C (FLC_RPC THRESHOLD) */
#define BIT_SHIFT_FLC_RPCT_8822C 0
#define BIT_MASK_FLC_RPCT_8822C 0xff
#define BIT_FLC_RPCT_8822C(x) \
(((x) & BIT_MASK_FLC_RPCT_8822C) << BIT_SHIFT_FLC_RPCT_8822C)
#define BITS_FLC_RPCT_8822C \
(BIT_MASK_FLC_RPCT_8822C << BIT_SHIFT_FLC_RPCT_8822C)
#define BIT_CLEAR_FLC_RPCT_8822C(x) ((x) & (~BITS_FLC_RPCT_8822C))
#define BIT_GET_FLC_RPCT_8822C(x) \
(((x) >> BIT_SHIFT_FLC_RPCT_8822C) & BIT_MASK_FLC_RPCT_8822C)
#define BIT_SET_FLC_RPCT_8822C(x, v) \
(BIT_CLEAR_FLC_RPCT_8822C(x) | BIT_FLC_RPCT_8822C(v))
/* 2 REG_FLC_PTS_8822C (PKT TYPE SELECTION OF FLC_RPC T) */
#define BIT_CMF_8822C BIT(2)
#define BIT_CCF_8822C BIT(1)
#define BIT_CDF_8822C BIT(0)
/* 2 REG_FLC_TRPC_8822C (TIMER OF FLC_RPC) */
#define BIT_FLC_RPCT_V1_8822C BIT(7)
#define BIT_MODE_8822C BIT(6)
#define BIT_SHIFT_TRPCD_8822C 0
#define BIT_MASK_TRPCD_8822C 0x3f
#define BIT_TRPCD_8822C(x) \
(((x) & BIT_MASK_TRPCD_8822C) << BIT_SHIFT_TRPCD_8822C)
#define BITS_TRPCD_8822C (BIT_MASK_TRPCD_8822C << BIT_SHIFT_TRPCD_8822C)
#define BIT_CLEAR_TRPCD_8822C(x) ((x) & (~BITS_TRPCD_8822C))
#define BIT_GET_TRPCD_8822C(x) \
(((x) >> BIT_SHIFT_TRPCD_8822C) & BIT_MASK_TRPCD_8822C)
#define BIT_SET_TRPCD_8822C(x, v) \
(BIT_CLEAR_TRPCD_8822C(x) | BIT_TRPCD_8822C(v))
/* 2 REG_RXPKTMON_CTRL_8822C */
#define BIT_SHIFT_RXBKQPKT_SEQ_8822C 20
#define BIT_MASK_RXBKQPKT_SEQ_8822C 0xf
#define BIT_RXBKQPKT_SEQ_8822C(x) \
(((x) & BIT_MASK_RXBKQPKT_SEQ_8822C) << BIT_SHIFT_RXBKQPKT_SEQ_8822C)
#define BITS_RXBKQPKT_SEQ_8822C \
(BIT_MASK_RXBKQPKT_SEQ_8822C << BIT_SHIFT_RXBKQPKT_SEQ_8822C)
#define BIT_CLEAR_RXBKQPKT_SEQ_8822C(x) ((x) & (~BITS_RXBKQPKT_SEQ_8822C))
#define BIT_GET_RXBKQPKT_SEQ_8822C(x) \
(((x) >> BIT_SHIFT_RXBKQPKT_SEQ_8822C) & BIT_MASK_RXBKQPKT_SEQ_8822C)
#define BIT_SET_RXBKQPKT_SEQ_8822C(x, v) \
(BIT_CLEAR_RXBKQPKT_SEQ_8822C(x) | BIT_RXBKQPKT_SEQ_8822C(v))
#define BIT_SHIFT_RXBEQPKT_SEQ_8822C 16
#define BIT_MASK_RXBEQPKT_SEQ_8822C 0xf
#define BIT_RXBEQPKT_SEQ_8822C(x) \
(((x) & BIT_MASK_RXBEQPKT_SEQ_8822C) << BIT_SHIFT_RXBEQPKT_SEQ_8822C)
#define BITS_RXBEQPKT_SEQ_8822C \
(BIT_MASK_RXBEQPKT_SEQ_8822C << BIT_SHIFT_RXBEQPKT_SEQ_8822C)
#define BIT_CLEAR_RXBEQPKT_SEQ_8822C(x) ((x) & (~BITS_RXBEQPKT_SEQ_8822C))
#define BIT_GET_RXBEQPKT_SEQ_8822C(x) \
(((x) >> BIT_SHIFT_RXBEQPKT_SEQ_8822C) & BIT_MASK_RXBEQPKT_SEQ_8822C)
#define BIT_SET_RXBEQPKT_SEQ_8822C(x, v) \
(BIT_CLEAR_RXBEQPKT_SEQ_8822C(x) | BIT_RXBEQPKT_SEQ_8822C(v))
#define BIT_SHIFT_RXVIQPKT_SEQ_8822C 12
#define BIT_MASK_RXVIQPKT_SEQ_8822C 0xf
#define BIT_RXVIQPKT_SEQ_8822C(x) \
(((x) & BIT_MASK_RXVIQPKT_SEQ_8822C) << BIT_SHIFT_RXVIQPKT_SEQ_8822C)
#define BITS_RXVIQPKT_SEQ_8822C \
(BIT_MASK_RXVIQPKT_SEQ_8822C << BIT_SHIFT_RXVIQPKT_SEQ_8822C)
#define BIT_CLEAR_RXVIQPKT_SEQ_8822C(x) ((x) & (~BITS_RXVIQPKT_SEQ_8822C))
#define BIT_GET_RXVIQPKT_SEQ_8822C(x) \
(((x) >> BIT_SHIFT_RXVIQPKT_SEQ_8822C) & BIT_MASK_RXVIQPKT_SEQ_8822C)
#define BIT_SET_RXVIQPKT_SEQ_8822C(x, v) \
(BIT_CLEAR_RXVIQPKT_SEQ_8822C(x) | BIT_RXVIQPKT_SEQ_8822C(v))
#define BIT_SHIFT_RXVOQPKT_SEQ_8822C 8
#define BIT_MASK_RXVOQPKT_SEQ_8822C 0xf
#define BIT_RXVOQPKT_SEQ_8822C(x) \
(((x) & BIT_MASK_RXVOQPKT_SEQ_8822C) << BIT_SHIFT_RXVOQPKT_SEQ_8822C)
#define BITS_RXVOQPKT_SEQ_8822C \
(BIT_MASK_RXVOQPKT_SEQ_8822C << BIT_SHIFT_RXVOQPKT_SEQ_8822C)
#define BIT_CLEAR_RXVOQPKT_SEQ_8822C(x) ((x) & (~BITS_RXVOQPKT_SEQ_8822C))
#define BIT_GET_RXVOQPKT_SEQ_8822C(x) \
(((x) >> BIT_SHIFT_RXVOQPKT_SEQ_8822C) & BIT_MASK_RXVOQPKT_SEQ_8822C)
#define BIT_SET_RXVOQPKT_SEQ_8822C(x, v) \
(BIT_CLEAR_RXVOQPKT_SEQ_8822C(x) | BIT_RXVOQPKT_SEQ_8822C(v))
#define BIT_RXBKQPKT_ERR_8822C BIT(7)
#define BIT_RXBEQPKT_ERR_8822C BIT(6)
#define BIT_RXVIQPKT_ERR_8822C BIT(5)
#define BIT_RXVOQPKT_ERR_8822C BIT(4)
#define BIT_RXDMA_MON_EN_8822C BIT(2)
#define BIT_RXPKT_MON_RST_8822C BIT(1)
#define BIT_RXPKT_MON_EN_8822C BIT(0)
/* 2 REG_STATE_MON_8822C */
#define BIT_SHIFT_STATE_SEL_8822C 24
#define BIT_MASK_STATE_SEL_8822C 0x1f
#define BIT_STATE_SEL_8822C(x) \
(((x) & BIT_MASK_STATE_SEL_8822C) << BIT_SHIFT_STATE_SEL_8822C)
#define BITS_STATE_SEL_8822C \
(BIT_MASK_STATE_SEL_8822C << BIT_SHIFT_STATE_SEL_8822C)
#define BIT_CLEAR_STATE_SEL_8822C(x) ((x) & (~BITS_STATE_SEL_8822C))
#define BIT_GET_STATE_SEL_8822C(x) \
(((x) >> BIT_SHIFT_STATE_SEL_8822C) & BIT_MASK_STATE_SEL_8822C)
#define BIT_SET_STATE_SEL_8822C(x, v) \
(BIT_CLEAR_STATE_SEL_8822C(x) | BIT_STATE_SEL_8822C(v))
#define BIT_SHIFT_STATE_INFO_8822C 8
#define BIT_MASK_STATE_INFO_8822C 0xff
#define BIT_STATE_INFO_8822C(x) \
(((x) & BIT_MASK_STATE_INFO_8822C) << BIT_SHIFT_STATE_INFO_8822C)
#define BITS_STATE_INFO_8822C \
(BIT_MASK_STATE_INFO_8822C << BIT_SHIFT_STATE_INFO_8822C)
#define BIT_CLEAR_STATE_INFO_8822C(x) ((x) & (~BITS_STATE_INFO_8822C))
#define BIT_GET_STATE_INFO_8822C(x) \
(((x) >> BIT_SHIFT_STATE_INFO_8822C) & BIT_MASK_STATE_INFO_8822C)
#define BIT_SET_STATE_INFO_8822C(x, v) \
(BIT_CLEAR_STATE_INFO_8822C(x) | BIT_STATE_INFO_8822C(v))
#define BIT_UPD_NXT_STATE_8822C BIT(7)
#define BIT_SHIFT_CUR_STATE_8822C 0
#define BIT_MASK_CUR_STATE_8822C 0x7f
#define BIT_CUR_STATE_8822C(x) \
(((x) & BIT_MASK_CUR_STATE_8822C) << BIT_SHIFT_CUR_STATE_8822C)
#define BITS_CUR_STATE_8822C \
(BIT_MASK_CUR_STATE_8822C << BIT_SHIFT_CUR_STATE_8822C)
#define BIT_CLEAR_CUR_STATE_8822C(x) ((x) & (~BITS_CUR_STATE_8822C))
#define BIT_GET_CUR_STATE_8822C(x) \
(((x) >> BIT_SHIFT_CUR_STATE_8822C) & BIT_MASK_CUR_STATE_8822C)
#define BIT_SET_CUR_STATE_8822C(x, v) \
(BIT_CLEAR_CUR_STATE_8822C(x) | BIT_CUR_STATE_8822C(v))
/* 2 REG_ERROR_MON_8822C */
#define BIT_CSIRPT_LEN_BB_MORE_THAN_MAC_8822C BIT(23)
#define BIT_CSI_CHKSUM_ERROR_8822C BIT(22)
#define BIT_MACRX_ERR_4_8822C BIT(20)
#define BIT_MACRX_ERR_3_8822C BIT(19)
#define BIT_MACRX_ERR_2_8822C BIT(18)
#define BIT_MACRX_ERR_1_8822C BIT(17)
#define BIT_MACRX_ERR_0_8822C BIT(16)
#define BIT_WMAC_PRETX_ERRHDL_EN_8822C BIT(15)
#define BIT_MACTX_ERR_5_8822C BIT(5)
#define BIT_MACTX_ERR_4_8822C BIT(4)
#define BIT_MACTX_ERR_3_8822C BIT(3)
#define BIT_MACTX_ERR_2_8822C BIT(2)
#define BIT_MACTX_ERR_1_8822C BIT(1)
#define BIT_MACTX_ERR_0_8822C BIT(0)
/* 2 REG_SEARCH_MACID_8822C */
#define BIT_EN_TXRPTBUF_CLK_8822C BIT(31)
#define BIT_SHIFT_INFO_INDEX_OFFSET_8822C 16
#define BIT_MASK_INFO_INDEX_OFFSET_8822C 0x1fff
#define BIT_INFO_INDEX_OFFSET_8822C(x) \
(((x) & BIT_MASK_INFO_INDEX_OFFSET_8822C) \
<< BIT_SHIFT_INFO_INDEX_OFFSET_8822C)
#define BITS_INFO_INDEX_OFFSET_8822C \
(BIT_MASK_INFO_INDEX_OFFSET_8822C << BIT_SHIFT_INFO_INDEX_OFFSET_8822C)
#define BIT_CLEAR_INFO_INDEX_OFFSET_8822C(x) \
((x) & (~BITS_INFO_INDEX_OFFSET_8822C))
#define BIT_GET_INFO_INDEX_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_INFO_INDEX_OFFSET_8822C) & \
BIT_MASK_INFO_INDEX_OFFSET_8822C)
#define BIT_SET_INFO_INDEX_OFFSET_8822C(x, v) \
(BIT_CLEAR_INFO_INDEX_OFFSET_8822C(x) | BIT_INFO_INDEX_OFFSET_8822C(v))
#define BIT_WMAC_SRCH_FIFOFULL_8822C BIT(15)
#define BIT_DIS_INFOSRCH_8822C BIT(14)
#define BIT_SHIFT_INFO_ADDR_OFFSET_8822C 0
#define BIT_MASK_INFO_ADDR_OFFSET_8822C 0x1fff
#define BIT_INFO_ADDR_OFFSET_8822C(x) \
(((x) & BIT_MASK_INFO_ADDR_OFFSET_8822C) \
<< BIT_SHIFT_INFO_ADDR_OFFSET_8822C)
#define BITS_INFO_ADDR_OFFSET_8822C \
(BIT_MASK_INFO_ADDR_OFFSET_8822C << BIT_SHIFT_INFO_ADDR_OFFSET_8822C)
#define BIT_CLEAR_INFO_ADDR_OFFSET_8822C(x) \
((x) & (~BITS_INFO_ADDR_OFFSET_8822C))
#define BIT_GET_INFO_ADDR_OFFSET_8822C(x) \
(((x) >> BIT_SHIFT_INFO_ADDR_OFFSET_8822C) & \
BIT_MASK_INFO_ADDR_OFFSET_8822C)
#define BIT_SET_INFO_ADDR_OFFSET_8822C(x, v) \
(BIT_CLEAR_INFO_ADDR_OFFSET_8822C(x) | BIT_INFO_ADDR_OFFSET_8822C(v))
/* 2 REG_BT_COEX_TABLE_8822C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_COEX_TABLE_1_8822C 0
#define BIT_MASK_COEX_TABLE_1_8822C 0xffffffffL
#define BIT_COEX_TABLE_1_8822C(x) \
(((x) & BIT_MASK_COEX_TABLE_1_8822C) << BIT_SHIFT_COEX_TABLE_1_8822C)
#define BITS_COEX_TABLE_1_8822C \
(BIT_MASK_COEX_TABLE_1_8822C << BIT_SHIFT_COEX_TABLE_1_8822C)
#define BIT_CLEAR_COEX_TABLE_1_8822C(x) ((x) & (~BITS_COEX_TABLE_1_8822C))
#define BIT_GET_COEX_TABLE_1_8822C(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_1_8822C) & BIT_MASK_COEX_TABLE_1_8822C)
#define BIT_SET_COEX_TABLE_1_8822C(x, v) \
(BIT_CLEAR_COEX_TABLE_1_8822C(x) | BIT_COEX_TABLE_1_8822C(v))
/* 2 REG_BT_COEX_TABLE2_8822C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_COEX_TABLE_2_8822C 0
#define BIT_MASK_COEX_TABLE_2_8822C 0xffffffffL
#define BIT_COEX_TABLE_2_8822C(x) \
(((x) & BIT_MASK_COEX_TABLE_2_8822C) << BIT_SHIFT_COEX_TABLE_2_8822C)
#define BITS_COEX_TABLE_2_8822C \
(BIT_MASK_COEX_TABLE_2_8822C << BIT_SHIFT_COEX_TABLE_2_8822C)
#define BIT_CLEAR_COEX_TABLE_2_8822C(x) ((x) & (~BITS_COEX_TABLE_2_8822C))
#define BIT_GET_COEX_TABLE_2_8822C(x) \
(((x) >> BIT_SHIFT_COEX_TABLE_2_8822C) & BIT_MASK_COEX_TABLE_2_8822C)
#define BIT_SET_COEX_TABLE_2_8822C(x, v) \
(BIT_CLEAR_COEX_TABLE_2_8822C(x) | BIT_COEX_TABLE_2_8822C(v))
/* 2 REG_BT_COEX_BREAK_TABLE_8822C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_SHIFT_BREAK_TABLE_2_8822C 16
#define BIT_MASK_BREAK_TABLE_2_8822C 0xffff
#define BIT_BREAK_TABLE_2_8822C(x) \
(((x) & BIT_MASK_BREAK_TABLE_2_8822C) << BIT_SHIFT_BREAK_TABLE_2_8822C)
#define BITS_BREAK_TABLE_2_8822C \
(BIT_MASK_BREAK_TABLE_2_8822C << BIT_SHIFT_BREAK_TABLE_2_8822C)
#define BIT_CLEAR_BREAK_TABLE_2_8822C(x) ((x) & (~BITS_BREAK_TABLE_2_8822C))
#define BIT_GET_BREAK_TABLE_2_8822C(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_2_8822C) & BIT_MASK_BREAK_TABLE_2_8822C)
#define BIT_SET_BREAK_TABLE_2_8822C(x, v) \
(BIT_CLEAR_BREAK_TABLE_2_8822C(x) | BIT_BREAK_TABLE_2_8822C(v))
#define BIT_SHIFT_BREAK_TABLE_1_8822C 0
#define BIT_MASK_BREAK_TABLE_1_8822C 0xffff
#define BIT_BREAK_TABLE_1_8822C(x) \
(((x) & BIT_MASK_BREAK_TABLE_1_8822C) << BIT_SHIFT_BREAK_TABLE_1_8822C)
#define BITS_BREAK_TABLE_1_8822C \
(BIT_MASK_BREAK_TABLE_1_8822C << BIT_SHIFT_BREAK_TABLE_1_8822C)
#define BIT_CLEAR_BREAK_TABLE_1_8822C(x) ((x) & (~BITS_BREAK_TABLE_1_8822C))
#define BIT_GET_BREAK_TABLE_1_8822C(x) \
(((x) >> BIT_SHIFT_BREAK_TABLE_1_8822C) & BIT_MASK_BREAK_TABLE_1_8822C)
#define BIT_SET_BREAK_TABLE_1_8822C(x, v) \
(BIT_CLEAR_BREAK_TABLE_1_8822C(x) | BIT_BREAK_TABLE_1_8822C(v))
/* 2 REG_BT_COEX_TABLE_H_8822C (BT-COEXISTENCE CONTROL REGISTER) */
#define BIT_PRI_MASK_RX_RESP_V1_8822C BIT(30)
#define BIT_PRI_MASK_RXOFDM_V1_8822C BIT(29)
#define BIT_PRI_MASK_RXCCK_V1_8822C BIT(28)
#define BIT_SHIFT_PRI_MASK_TXAC_8822C 21
#define BIT_MASK_PRI_MASK_TXAC_8822C 0x7f
#define BIT_PRI_MASK_TXAC_8822C(x) \
(((x) & BIT_MASK_PRI_MASK_TXAC_8822C) << BIT_SHIFT_PRI_MASK_TXAC_8822C)
#define BITS_PRI_MASK_TXAC_8822C \
(BIT_MASK_PRI_MASK_TXAC_8822C << BIT_SHIFT_PRI_MASK_TXAC_8822C)
#define BIT_CLEAR_PRI_MASK_TXAC_8822C(x) ((x) & (~BITS_PRI_MASK_TXAC_8822C))
#define BIT_GET_PRI_MASK_TXAC_8822C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TXAC_8822C) & BIT_MASK_PRI_MASK_TXAC_8822C)
#define BIT_SET_PRI_MASK_TXAC_8822C(x, v) \
(BIT_CLEAR_PRI_MASK_TXAC_8822C(x) | BIT_PRI_MASK_TXAC_8822C(v))
#define BIT_SHIFT_PRI_MASK_NAV_8822C 13
#define BIT_MASK_PRI_MASK_NAV_8822C 0xff
#define BIT_PRI_MASK_NAV_8822C(x) \
(((x) & BIT_MASK_PRI_MASK_NAV_8822C) << BIT_SHIFT_PRI_MASK_NAV_8822C)
#define BITS_PRI_MASK_NAV_8822C \
(BIT_MASK_PRI_MASK_NAV_8822C << BIT_SHIFT_PRI_MASK_NAV_8822C)
#define BIT_CLEAR_PRI_MASK_NAV_8822C(x) ((x) & (~BITS_PRI_MASK_NAV_8822C))
#define BIT_GET_PRI_MASK_NAV_8822C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NAV_8822C) & BIT_MASK_PRI_MASK_NAV_8822C)
#define BIT_SET_PRI_MASK_NAV_8822C(x, v) \
(BIT_CLEAR_PRI_MASK_NAV_8822C(x) | BIT_PRI_MASK_NAV_8822C(v))
#define BIT_PRI_MASK_CCK_V1_8822C BIT(12)
#define BIT_PRI_MASK_OFDM_V1_8822C BIT(11)
#define BIT_PRI_MASK_RTY_V1_8822C BIT(10)
#define BIT_SHIFT_PRI_MASK_NUM_8822C 6
#define BIT_MASK_PRI_MASK_NUM_8822C 0xf
#define BIT_PRI_MASK_NUM_8822C(x) \
(((x) & BIT_MASK_PRI_MASK_NUM_8822C) << BIT_SHIFT_PRI_MASK_NUM_8822C)
#define BITS_PRI_MASK_NUM_8822C \
(BIT_MASK_PRI_MASK_NUM_8822C << BIT_SHIFT_PRI_MASK_NUM_8822C)
#define BIT_CLEAR_PRI_MASK_NUM_8822C(x) ((x) & (~BITS_PRI_MASK_NUM_8822C))
#define BIT_GET_PRI_MASK_NUM_8822C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_NUM_8822C) & BIT_MASK_PRI_MASK_NUM_8822C)
#define BIT_SET_PRI_MASK_NUM_8822C(x, v) \
(BIT_CLEAR_PRI_MASK_NUM_8822C(x) | BIT_PRI_MASK_NUM_8822C(v))
#define BIT_SHIFT_PRI_MASK_TYPE_8822C 2
#define BIT_MASK_PRI_MASK_TYPE_8822C 0xf
#define BIT_PRI_MASK_TYPE_8822C(x) \
(((x) & BIT_MASK_PRI_MASK_TYPE_8822C) << BIT_SHIFT_PRI_MASK_TYPE_8822C)
#define BITS_PRI_MASK_TYPE_8822C \
(BIT_MASK_PRI_MASK_TYPE_8822C << BIT_SHIFT_PRI_MASK_TYPE_8822C)
#define BIT_CLEAR_PRI_MASK_TYPE_8822C(x) ((x) & (~BITS_PRI_MASK_TYPE_8822C))
#define BIT_GET_PRI_MASK_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_PRI_MASK_TYPE_8822C) & BIT_MASK_PRI_MASK_TYPE_8822C)
#define BIT_SET_PRI_MASK_TYPE_8822C(x, v) \
(BIT_CLEAR_PRI_MASK_TYPE_8822C(x) | BIT_PRI_MASK_TYPE_8822C(v))
#define BIT_OOB_V1_8822C BIT(1)
#define BIT_ANT_SEL_V1_8822C BIT(0)
/* 2 REG_RXCMD_0_8822C */
#define BIT_RXCMD_EN_8822C BIT(31)
#define BIT_SHIFT_RXCMD_INFO_8822C 0
#define BIT_MASK_RXCMD_INFO_8822C 0x7fffffffL
#define BIT_RXCMD_INFO_8822C(x) \
(((x) & BIT_MASK_RXCMD_INFO_8822C) << BIT_SHIFT_RXCMD_INFO_8822C)
#define BITS_RXCMD_INFO_8822C \
(BIT_MASK_RXCMD_INFO_8822C << BIT_SHIFT_RXCMD_INFO_8822C)
#define BIT_CLEAR_RXCMD_INFO_8822C(x) ((x) & (~BITS_RXCMD_INFO_8822C))
#define BIT_GET_RXCMD_INFO_8822C(x) \
(((x) >> BIT_SHIFT_RXCMD_INFO_8822C) & BIT_MASK_RXCMD_INFO_8822C)
#define BIT_SET_RXCMD_INFO_8822C(x, v) \
(BIT_CLEAR_RXCMD_INFO_8822C(x) | BIT_RXCMD_INFO_8822C(v))
/* 2 REG_RXCMD_1_8822C */
#define BIT_SHIFT_RXCMD_PRD_8822C 0
#define BIT_MASK_RXCMD_PRD_8822C 0xffff
#define BIT_RXCMD_PRD_8822C(x) \
(((x) & BIT_MASK_RXCMD_PRD_8822C) << BIT_SHIFT_RXCMD_PRD_8822C)
#define BITS_RXCMD_PRD_8822C \
(BIT_MASK_RXCMD_PRD_8822C << BIT_SHIFT_RXCMD_PRD_8822C)
#define BIT_CLEAR_RXCMD_PRD_8822C(x) ((x) & (~BITS_RXCMD_PRD_8822C))
#define BIT_GET_RXCMD_PRD_8822C(x) \
(((x) >> BIT_SHIFT_RXCMD_PRD_8822C) & BIT_MASK_RXCMD_PRD_8822C)
#define BIT_SET_RXCMD_PRD_8822C(x, v) \
(BIT_CLEAR_RXCMD_PRD_8822C(x) | BIT_RXCMD_PRD_8822C(v))
/* 2 REG_WMAC_RESP_TXINFO_8822C (RESPONSE TXINFO REGISTER) */
#define BIT_SHIFT_WMAC_RESP_MFB_8822C 25
#define BIT_MASK_WMAC_RESP_MFB_8822C 0x7f
#define BIT_WMAC_RESP_MFB_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_MFB_8822C) << BIT_SHIFT_WMAC_RESP_MFB_8822C)
#define BITS_WMAC_RESP_MFB_8822C \
(BIT_MASK_WMAC_RESP_MFB_8822C << BIT_SHIFT_WMAC_RESP_MFB_8822C)
#define BIT_CLEAR_WMAC_RESP_MFB_8822C(x) ((x) & (~BITS_WMAC_RESP_MFB_8822C))
#define BIT_GET_WMAC_RESP_MFB_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_MFB_8822C) & BIT_MASK_WMAC_RESP_MFB_8822C)
#define BIT_SET_WMAC_RESP_MFB_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_MFB_8822C(x) | BIT_WMAC_RESP_MFB_8822C(v))
#define BIT_SHIFT_WMAC_ANTINF_SEL_8822C 23
#define BIT_MASK_WMAC_ANTINF_SEL_8822C 0x3
#define BIT_WMAC_ANTINF_SEL_8822C(x) \
(((x) & BIT_MASK_WMAC_ANTINF_SEL_8822C) \
<< BIT_SHIFT_WMAC_ANTINF_SEL_8822C)
#define BITS_WMAC_ANTINF_SEL_8822C \
(BIT_MASK_WMAC_ANTINF_SEL_8822C << BIT_SHIFT_WMAC_ANTINF_SEL_8822C)
#define BIT_CLEAR_WMAC_ANTINF_SEL_8822C(x) ((x) & (~BITS_WMAC_ANTINF_SEL_8822C))
#define BIT_GET_WMAC_ANTINF_SEL_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_ANTINF_SEL_8822C) & \
BIT_MASK_WMAC_ANTINF_SEL_8822C)
#define BIT_SET_WMAC_ANTINF_SEL_8822C(x, v) \
(BIT_CLEAR_WMAC_ANTINF_SEL_8822C(x) | BIT_WMAC_ANTINF_SEL_8822C(v))
#define BIT_SHIFT_WMAC_ANTSEL_SEL_8822C 21
#define BIT_MASK_WMAC_ANTSEL_SEL_8822C 0x3
#define BIT_WMAC_ANTSEL_SEL_8822C(x) \
(((x) & BIT_MASK_WMAC_ANTSEL_SEL_8822C) \
<< BIT_SHIFT_WMAC_ANTSEL_SEL_8822C)
#define BITS_WMAC_ANTSEL_SEL_8822C \
(BIT_MASK_WMAC_ANTSEL_SEL_8822C << BIT_SHIFT_WMAC_ANTSEL_SEL_8822C)
#define BIT_CLEAR_WMAC_ANTSEL_SEL_8822C(x) ((x) & (~BITS_WMAC_ANTSEL_SEL_8822C))
#define BIT_GET_WMAC_ANTSEL_SEL_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_ANTSEL_SEL_8822C) & \
BIT_MASK_WMAC_ANTSEL_SEL_8822C)
#define BIT_SET_WMAC_ANTSEL_SEL_8822C(x, v) \
(BIT_CLEAR_WMAC_ANTSEL_SEL_8822C(x) | BIT_WMAC_ANTSEL_SEL_8822C(v))
#define BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C 18
#define BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C 0x3
#define BIT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C) \
<< BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C)
#define BITS_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C \
(BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C \
<< BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C)
#define BIT_CLEAR_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C(x) \
((x) & (~BITS_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C))
#define BIT_GET_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C) & \
BIT_MASK_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C)
#define BIT_SET_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C(x) | \
BIT_WMAC_RESP_TXPOWER_OFFSET_TYPE_8822C(v))
#define BIT_SHIFT_WMAC_RESP_TXANT_V1_8822C 6
#define BIT_MASK_WMAC_RESP_TXANT_V1_8822C 0xfff
#define BIT_WMAC_RESP_TXANT_V1_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_TXANT_V1_8822C) \
<< BIT_SHIFT_WMAC_RESP_TXANT_V1_8822C)
#define BITS_WMAC_RESP_TXANT_V1_8822C \
(BIT_MASK_WMAC_RESP_TXANT_V1_8822C \
<< BIT_SHIFT_WMAC_RESP_TXANT_V1_8822C)
#define BIT_CLEAR_WMAC_RESP_TXANT_V1_8822C(x) \
((x) & (~BITS_WMAC_RESP_TXANT_V1_8822C))
#define BIT_GET_WMAC_RESP_TXANT_V1_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXANT_V1_8822C) & \
BIT_MASK_WMAC_RESP_TXANT_V1_8822C)
#define BIT_SET_WMAC_RESP_TXANT_V1_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_TXANT_V1_8822C(x) | \
BIT_WMAC_RESP_TXANT_V1_8822C(v))
/* 2 REG_BBPSF_CTRL_8822C */
#define BIT_CTL_IDLE_CLR_CSI_RPT_8822C BIT(31)
#define BIT_WMAC_USE_NDPARATE_8822C BIT(30)
#define BIT_SHIFT_WMAC_CSI_RATE_8822C 24
#define BIT_MASK_WMAC_CSI_RATE_8822C 0x3f
#define BIT_WMAC_CSI_RATE_8822C(x) \
(((x) & BIT_MASK_WMAC_CSI_RATE_8822C) << BIT_SHIFT_WMAC_CSI_RATE_8822C)
#define BITS_WMAC_CSI_RATE_8822C \
(BIT_MASK_WMAC_CSI_RATE_8822C << BIT_SHIFT_WMAC_CSI_RATE_8822C)
#define BIT_CLEAR_WMAC_CSI_RATE_8822C(x) ((x) & (~BITS_WMAC_CSI_RATE_8822C))
#define BIT_GET_WMAC_CSI_RATE_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_CSI_RATE_8822C) & BIT_MASK_WMAC_CSI_RATE_8822C)
#define BIT_SET_WMAC_CSI_RATE_8822C(x, v) \
(BIT_CLEAR_WMAC_CSI_RATE_8822C(x) | BIT_WMAC_CSI_RATE_8822C(v))
#define BIT_SHIFT_WMAC_RESP_TXRATE_8822C 16
#define BIT_MASK_WMAC_RESP_TXRATE_8822C 0xff
#define BIT_WMAC_RESP_TXRATE_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_TXRATE_8822C) \
<< BIT_SHIFT_WMAC_RESP_TXRATE_8822C)
#define BITS_WMAC_RESP_TXRATE_8822C \
(BIT_MASK_WMAC_RESP_TXRATE_8822C << BIT_SHIFT_WMAC_RESP_TXRATE_8822C)
#define BIT_CLEAR_WMAC_RESP_TXRATE_8822C(x) \
((x) & (~BITS_WMAC_RESP_TXRATE_8822C))
#define BIT_GET_WMAC_RESP_TXRATE_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_TXRATE_8822C) & \
BIT_MASK_WMAC_RESP_TXRATE_8822C)
#define BIT_SET_WMAC_RESP_TXRATE_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_TXRATE_8822C(x) | BIT_WMAC_RESP_TXRATE_8822C(v))
#define BIT_SHIFT_CSI_RSC_8822C 13
#define BIT_MASK_CSI_RSC_8822C 0x3
#define BIT_CSI_RSC_8822C(x) \
(((x) & BIT_MASK_CSI_RSC_8822C) << BIT_SHIFT_CSI_RSC_8822C)
#define BITS_CSI_RSC_8822C (BIT_MASK_CSI_RSC_8822C << BIT_SHIFT_CSI_RSC_8822C)
#define BIT_CLEAR_CSI_RSC_8822C(x) ((x) & (~BITS_CSI_RSC_8822C))
#define BIT_GET_CSI_RSC_8822C(x) \
(((x) >> BIT_SHIFT_CSI_RSC_8822C) & BIT_MASK_CSI_RSC_8822C)
#define BIT_SET_CSI_RSC_8822C(x, v) \
(BIT_CLEAR_CSI_RSC_8822C(x) | BIT_CSI_RSC_8822C(v))
#define BIT_CSI_GID_SEL_8822C BIT(12)
#define BIT_NDPVLD_PROTECT_RDRDY_DIS_8822C BIT(9)
#define BIT_RDCSI_EMPTY_APPZERO_8822C BIT(8)
#define BIT_CSI_RATE_FB_EN_8822C BIT(7)
#define BIT_RXFIFO_WRPTR_WO_CHKSUM_8822C BIT(6)
/* 2 REG_P2P_RX_BCN_NOA_8822C (P2P RX BEACON NOA REGISTER) */
#define BIT_NOA_PARSER_EN_8822C BIT(15)
#define BIT_SHIFT_BSSID_SEL_V1_8822C 12
#define BIT_MASK_BSSID_SEL_V1_8822C 0x7
#define BIT_BSSID_SEL_V1_8822C(x) \
(((x) & BIT_MASK_BSSID_SEL_V1_8822C) << BIT_SHIFT_BSSID_SEL_V1_8822C)
#define BITS_BSSID_SEL_V1_8822C \
(BIT_MASK_BSSID_SEL_V1_8822C << BIT_SHIFT_BSSID_SEL_V1_8822C)
#define BIT_CLEAR_BSSID_SEL_V1_8822C(x) ((x) & (~BITS_BSSID_SEL_V1_8822C))
#define BIT_GET_BSSID_SEL_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID_SEL_V1_8822C) & BIT_MASK_BSSID_SEL_V1_8822C)
#define BIT_SET_BSSID_SEL_V1_8822C(x, v) \
(BIT_CLEAR_BSSID_SEL_V1_8822C(x) | BIT_BSSID_SEL_V1_8822C(v))
#define BIT_SHIFT_P2P_OUI_TYPE_8822C 0
#define BIT_MASK_P2P_OUI_TYPE_8822C 0xff
#define BIT_P2P_OUI_TYPE_8822C(x) \
(((x) & BIT_MASK_P2P_OUI_TYPE_8822C) << BIT_SHIFT_P2P_OUI_TYPE_8822C)
#define BITS_P2P_OUI_TYPE_8822C \
(BIT_MASK_P2P_OUI_TYPE_8822C << BIT_SHIFT_P2P_OUI_TYPE_8822C)
#define BIT_CLEAR_P2P_OUI_TYPE_8822C(x) ((x) & (~BITS_P2P_OUI_TYPE_8822C))
#define BIT_GET_P2P_OUI_TYPE_8822C(x) \
(((x) >> BIT_SHIFT_P2P_OUI_TYPE_8822C) & BIT_MASK_P2P_OUI_TYPE_8822C)
#define BIT_SET_P2P_OUI_TYPE_8822C(x, v) \
(BIT_CLEAR_P2P_OUI_TYPE_8822C(x) | BIT_P2P_OUI_TYPE_8822C(v))
/* 2 REG_RSVD_8822C */
/* 2 REG_ASSOCIATED_BFMER0_INFO_8822C (ASSOCIATED BEAMFORMER0 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8822C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8822C 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R0_V1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8822C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8822C)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_V1_8822C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8822C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8822C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1_8822C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_V1_8822C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_V1_8822C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_V1_8822C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_V1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_V1_8822C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_V1_8822C(v))
/* 2 REG_ASSOCIATED_BFMER0_INFO_H_8822C */
#define BIT_SHIFT_R_WMAC_TXCSI_AID0_8822C 16
#define BIT_MASK_R_WMAC_TXCSI_AID0_8822C 0x1ff
#define BIT_R_WMAC_TXCSI_AID0_8822C(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID0_8822C) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID0_8822C)
#define BITS_R_WMAC_TXCSI_AID0_8822C \
(BIT_MASK_R_WMAC_TXCSI_AID0_8822C << BIT_SHIFT_R_WMAC_TXCSI_AID0_8822C)
#define BIT_CLEAR_R_WMAC_TXCSI_AID0_8822C(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID0_8822C))
#define BIT_GET_R_WMAC_TXCSI_AID0_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID0_8822C) & \
BIT_MASK_R_WMAC_TXCSI_AID0_8822C)
#define BIT_SET_R_WMAC_TXCSI_AID0_8822C(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID0_8822C(x) | BIT_R_WMAC_TXCSI_AID0_8822C(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C)
#define BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R0_H_V1_8822C(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_8822C (ASSOCIATED BEAMFORMER1 INFO REGISTER) */
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8822C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8822C 0xffffffffL
#define BIT_R_WMAC_SOUNDING_RXADD_R1_V1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8822C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8822C)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_V1_8822C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8822C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8822C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1_8822C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_V1_8822C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_V1_8822C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_V1_8822C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_V1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_V1_8822C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_V1_8822C(v))
/* 2 REG_ASSOCIATED_BFMER1_INFO_H_8822C */
#define BIT_SHIFT_R_WMAC_TXCSI_AID1_8822C 16
#define BIT_MASK_R_WMAC_TXCSI_AID1_8822C 0x1ff
#define BIT_R_WMAC_TXCSI_AID1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_TXCSI_AID1_8822C) \
<< BIT_SHIFT_R_WMAC_TXCSI_AID1_8822C)
#define BITS_R_WMAC_TXCSI_AID1_8822C \
(BIT_MASK_R_WMAC_TXCSI_AID1_8822C << BIT_SHIFT_R_WMAC_TXCSI_AID1_8822C)
#define BIT_CLEAR_R_WMAC_TXCSI_AID1_8822C(x) \
((x) & (~BITS_R_WMAC_TXCSI_AID1_8822C))
#define BIT_GET_R_WMAC_TXCSI_AID1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXCSI_AID1_8822C) & \
BIT_MASK_R_WMAC_TXCSI_AID1_8822C)
#define BIT_SET_R_WMAC_TXCSI_AID1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_TXCSI_AID1_8822C(x) | BIT_R_WMAC_TXCSI_AID1_8822C(v))
#define BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C 0
#define BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C 0xffff
#define BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C) \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C)
#define BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C \
(BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C \
<< BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C)
#define BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C(x) \
((x) & (~BITS_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C))
#define BIT_GET_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C) & \
BIT_MASK_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C)
#define BIT_SET_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C(x) | \
BIT_R_WMAC_SOUNDING_RXADD_R1_H_V1_8822C(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW20_8822C (TX CSI REPORT PARAMETER REGISTER) */
#define BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822C 16
#define BIT_MASK_R_WMAC_BFINFO_20M_1_8822C 0xfff
#define BIT_R_WMAC_BFINFO_20M_1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_1_8822C) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822C)
#define BITS_R_WMAC_BFINFO_20M_1_8822C \
(BIT_MASK_R_WMAC_BFINFO_20M_1_8822C \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822C)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_1_8822C(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_1_8822C))
#define BIT_GET_R_WMAC_BFINFO_20M_1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_1_8822C) & \
BIT_MASK_R_WMAC_BFINFO_20M_1_8822C)
#define BIT_SET_R_WMAC_BFINFO_20M_1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_1_8822C(x) | \
BIT_R_WMAC_BFINFO_20M_1_8822C(v))
#define BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822C 0
#define BIT_MASK_R_WMAC_BFINFO_20M_0_8822C 0xfff
#define BIT_R_WMAC_BFINFO_20M_0_8822C(x) \
(((x) & BIT_MASK_R_WMAC_BFINFO_20M_0_8822C) \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822C)
#define BITS_R_WMAC_BFINFO_20M_0_8822C \
(BIT_MASK_R_WMAC_BFINFO_20M_0_8822C \
<< BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822C)
#define BIT_CLEAR_R_WMAC_BFINFO_20M_0_8822C(x) \
((x) & (~BITS_R_WMAC_BFINFO_20M_0_8822C))
#define BIT_GET_R_WMAC_BFINFO_20M_0_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_BFINFO_20M_0_8822C) & \
BIT_MASK_R_WMAC_BFINFO_20M_0_8822C)
#define BIT_SET_R_WMAC_BFINFO_20M_0_8822C(x, v) \
(BIT_CLEAR_R_WMAC_BFINFO_20M_0_8822C(x) | \
BIT_R_WMAC_BFINFO_20M_0_8822C(v))
/* 2 REG_TX_CSI_RPT_PARAM_BW40_8822C (TX CSI REPORT PARAMETER_BW40 REGISTER) */
#define BIT_SHIFT_WMAC_RESP_ANTD_8822C 12
#define BIT_MASK_WMAC_RESP_ANTD_8822C 0xf
#define BIT_WMAC_RESP_ANTD_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTD_8822C) \
<< BIT_SHIFT_WMAC_RESP_ANTD_8822C)
#define BITS_WMAC_RESP_ANTD_8822C \
(BIT_MASK_WMAC_RESP_ANTD_8822C << BIT_SHIFT_WMAC_RESP_ANTD_8822C)
#define BIT_CLEAR_WMAC_RESP_ANTD_8822C(x) ((x) & (~BITS_WMAC_RESP_ANTD_8822C))
#define BIT_GET_WMAC_RESP_ANTD_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTD_8822C) & \
BIT_MASK_WMAC_RESP_ANTD_8822C)
#define BIT_SET_WMAC_RESP_ANTD_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTD_8822C(x) | BIT_WMAC_RESP_ANTD_8822C(v))
#define BIT_SHIFT_WMAC_RESP_ANTC_8822C 8
#define BIT_MASK_WMAC_RESP_ANTC_8822C 0xf
#define BIT_WMAC_RESP_ANTC_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTC_8822C) \
<< BIT_SHIFT_WMAC_RESP_ANTC_8822C)
#define BITS_WMAC_RESP_ANTC_8822C \
(BIT_MASK_WMAC_RESP_ANTC_8822C << BIT_SHIFT_WMAC_RESP_ANTC_8822C)
#define BIT_CLEAR_WMAC_RESP_ANTC_8822C(x) ((x) & (~BITS_WMAC_RESP_ANTC_8822C))
#define BIT_GET_WMAC_RESP_ANTC_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTC_8822C) & \
BIT_MASK_WMAC_RESP_ANTC_8822C)
#define BIT_SET_WMAC_RESP_ANTC_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTC_8822C(x) | BIT_WMAC_RESP_ANTC_8822C(v))
#define BIT_SHIFT_WMAC_RESP_ANTB_8822C 4
#define BIT_MASK_WMAC_RESP_ANTB_8822C 0xf
#define BIT_WMAC_RESP_ANTB_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTB_8822C) \
<< BIT_SHIFT_WMAC_RESP_ANTB_8822C)
#define BITS_WMAC_RESP_ANTB_8822C \
(BIT_MASK_WMAC_RESP_ANTB_8822C << BIT_SHIFT_WMAC_RESP_ANTB_8822C)
#define BIT_CLEAR_WMAC_RESP_ANTB_8822C(x) ((x) & (~BITS_WMAC_RESP_ANTB_8822C))
#define BIT_GET_WMAC_RESP_ANTB_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTB_8822C) & \
BIT_MASK_WMAC_RESP_ANTB_8822C)
#define BIT_SET_WMAC_RESP_ANTB_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTB_8822C(x) | BIT_WMAC_RESP_ANTB_8822C(v))
#define BIT_SHIFT_WMAC_RESP_ANTA_8822C 0
#define BIT_MASK_WMAC_RESP_ANTA_8822C 0xf
#define BIT_WMAC_RESP_ANTA_8822C(x) \
(((x) & BIT_MASK_WMAC_RESP_ANTA_8822C) \
<< BIT_SHIFT_WMAC_RESP_ANTA_8822C)
#define BITS_WMAC_RESP_ANTA_8822C \
(BIT_MASK_WMAC_RESP_ANTA_8822C << BIT_SHIFT_WMAC_RESP_ANTA_8822C)
#define BIT_CLEAR_WMAC_RESP_ANTA_8822C(x) ((x) & (~BITS_WMAC_RESP_ANTA_8822C))
#define BIT_GET_WMAC_RESP_ANTA_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RESP_ANTA_8822C) & \
BIT_MASK_WMAC_RESP_ANTA_8822C)
#define BIT_SET_WMAC_RESP_ANTA_8822C(x, v) \
(BIT_CLEAR_WMAC_RESP_ANTA_8822C(x) | BIT_WMAC_RESP_ANTA_8822C(v))
/* 2 REG_CSI_PTR_8822C */
#define BIT_SHIFT_CSI_RADDR_LATCH_V2_8822C 16
#define BIT_MASK_CSI_RADDR_LATCH_V2_8822C 0xffff
#define BIT_CSI_RADDR_LATCH_V2_8822C(x) \
(((x) & BIT_MASK_CSI_RADDR_LATCH_V2_8822C) \
<< BIT_SHIFT_CSI_RADDR_LATCH_V2_8822C)
#define BITS_CSI_RADDR_LATCH_V2_8822C \
(BIT_MASK_CSI_RADDR_LATCH_V2_8822C \
<< BIT_SHIFT_CSI_RADDR_LATCH_V2_8822C)
#define BIT_CLEAR_CSI_RADDR_LATCH_V2_8822C(x) \
((x) & (~BITS_CSI_RADDR_LATCH_V2_8822C))
#define BIT_GET_CSI_RADDR_LATCH_V2_8822C(x) \
(((x) >> BIT_SHIFT_CSI_RADDR_LATCH_V2_8822C) & \
BIT_MASK_CSI_RADDR_LATCH_V2_8822C)
#define BIT_SET_CSI_RADDR_LATCH_V2_8822C(x, v) \
(BIT_CLEAR_CSI_RADDR_LATCH_V2_8822C(x) | \
BIT_CSI_RADDR_LATCH_V2_8822C(v))
#define BIT_SHIFT_CSI_WADDR_LATCH_V2_8822C 0
#define BIT_MASK_CSI_WADDR_LATCH_V2_8822C 0xffff
#define BIT_CSI_WADDR_LATCH_V2_8822C(x) \
(((x) & BIT_MASK_CSI_WADDR_LATCH_V2_8822C) \
<< BIT_SHIFT_CSI_WADDR_LATCH_V2_8822C)
#define BITS_CSI_WADDR_LATCH_V2_8822C \
(BIT_MASK_CSI_WADDR_LATCH_V2_8822C \
<< BIT_SHIFT_CSI_WADDR_LATCH_V2_8822C)
#define BIT_CLEAR_CSI_WADDR_LATCH_V2_8822C(x) \
((x) & (~BITS_CSI_WADDR_LATCH_V2_8822C))
#define BIT_GET_CSI_WADDR_LATCH_V2_8822C(x) \
(((x) >> BIT_SHIFT_CSI_WADDR_LATCH_V2_8822C) & \
BIT_MASK_CSI_WADDR_LATCH_V2_8822C)
#define BIT_SET_CSI_WADDR_LATCH_V2_8822C(x, v) \
(BIT_CLEAR_CSI_WADDR_LATCH_V2_8822C(x) | \
BIT_CSI_WADDR_LATCH_V2_8822C(v))
/* 2 REG_BCN_PSR_RPT2_8822C (BEACON PARSER REPORT REGISTER2) */
#define BIT_SHIFT_DTIM_CNT2_8822C 24
#define BIT_MASK_DTIM_CNT2_8822C 0xff
#define BIT_DTIM_CNT2_8822C(x) \
(((x) & BIT_MASK_DTIM_CNT2_8822C) << BIT_SHIFT_DTIM_CNT2_8822C)
#define BITS_DTIM_CNT2_8822C \
(BIT_MASK_DTIM_CNT2_8822C << BIT_SHIFT_DTIM_CNT2_8822C)
#define BIT_CLEAR_DTIM_CNT2_8822C(x) ((x) & (~BITS_DTIM_CNT2_8822C))
#define BIT_GET_DTIM_CNT2_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT2_8822C) & BIT_MASK_DTIM_CNT2_8822C)
#define BIT_SET_DTIM_CNT2_8822C(x, v) \
(BIT_CLEAR_DTIM_CNT2_8822C(x) | BIT_DTIM_CNT2_8822C(v))
#define BIT_SHIFT_DTIM_PERIOD2_8822C 16
#define BIT_MASK_DTIM_PERIOD2_8822C 0xff
#define BIT_DTIM_PERIOD2_8822C(x) \
(((x) & BIT_MASK_DTIM_PERIOD2_8822C) << BIT_SHIFT_DTIM_PERIOD2_8822C)
#define BITS_DTIM_PERIOD2_8822C \
(BIT_MASK_DTIM_PERIOD2_8822C << BIT_SHIFT_DTIM_PERIOD2_8822C)
#define BIT_CLEAR_DTIM_PERIOD2_8822C(x) ((x) & (~BITS_DTIM_PERIOD2_8822C))
#define BIT_GET_DTIM_PERIOD2_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD2_8822C) & BIT_MASK_DTIM_PERIOD2_8822C)
#define BIT_SET_DTIM_PERIOD2_8822C(x, v) \
(BIT_CLEAR_DTIM_PERIOD2_8822C(x) | BIT_DTIM_PERIOD2_8822C(v))
#define BIT_DTIM2_8822C BIT(15)
#define BIT_TIM2_8822C BIT(14)
#define BIT_RPT_VALID_8822C BIT(13)
#define BIT_SHIFT_PS_AID_2_8822C 0
#define BIT_MASK_PS_AID_2_8822C 0x7ff
#define BIT_PS_AID_2_8822C(x) \
(((x) & BIT_MASK_PS_AID_2_8822C) << BIT_SHIFT_PS_AID_2_8822C)
#define BITS_PS_AID_2_8822C \
(BIT_MASK_PS_AID_2_8822C << BIT_SHIFT_PS_AID_2_8822C)
#define BIT_CLEAR_PS_AID_2_8822C(x) ((x) & (~BITS_PS_AID_2_8822C))
#define BIT_GET_PS_AID_2_8822C(x) \
(((x) >> BIT_SHIFT_PS_AID_2_8822C) & BIT_MASK_PS_AID_2_8822C)
#define BIT_SET_PS_AID_2_8822C(x, v) \
(BIT_CLEAR_PS_AID_2_8822C(x) | BIT_PS_AID_2_8822C(v))
/* 2 REG_BCN_PSR_RPT3_8822C (BEACON PARSER REPORT REGISTER3) */
#define BIT_SHIFT_DTIM_CNT3_8822C 24
#define BIT_MASK_DTIM_CNT3_8822C 0xff
#define BIT_DTIM_CNT3_8822C(x) \
(((x) & BIT_MASK_DTIM_CNT3_8822C) << BIT_SHIFT_DTIM_CNT3_8822C)
#define BITS_DTIM_CNT3_8822C \
(BIT_MASK_DTIM_CNT3_8822C << BIT_SHIFT_DTIM_CNT3_8822C)
#define BIT_CLEAR_DTIM_CNT3_8822C(x) ((x) & (~BITS_DTIM_CNT3_8822C))
#define BIT_GET_DTIM_CNT3_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT3_8822C) & BIT_MASK_DTIM_CNT3_8822C)
#define BIT_SET_DTIM_CNT3_8822C(x, v) \
(BIT_CLEAR_DTIM_CNT3_8822C(x) | BIT_DTIM_CNT3_8822C(v))
#define BIT_SHIFT_DTIM_PERIOD3_8822C 16
#define BIT_MASK_DTIM_PERIOD3_8822C 0xff
#define BIT_DTIM_PERIOD3_8822C(x) \
(((x) & BIT_MASK_DTIM_PERIOD3_8822C) << BIT_SHIFT_DTIM_PERIOD3_8822C)
#define BITS_DTIM_PERIOD3_8822C \
(BIT_MASK_DTIM_PERIOD3_8822C << BIT_SHIFT_DTIM_PERIOD3_8822C)
#define BIT_CLEAR_DTIM_PERIOD3_8822C(x) ((x) & (~BITS_DTIM_PERIOD3_8822C))
#define BIT_GET_DTIM_PERIOD3_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD3_8822C) & BIT_MASK_DTIM_PERIOD3_8822C)
#define BIT_SET_DTIM_PERIOD3_8822C(x, v) \
(BIT_CLEAR_DTIM_PERIOD3_8822C(x) | BIT_DTIM_PERIOD3_8822C(v))
#define BIT_DTIM3_8822C BIT(15)
#define BIT_TIM3_8822C BIT(14)
#define BIT_RPT_VALID_8822C BIT(13)
#define BIT_SHIFT_PS_AID_3_8822C 0
#define BIT_MASK_PS_AID_3_8822C 0x7ff
#define BIT_PS_AID_3_8822C(x) \
(((x) & BIT_MASK_PS_AID_3_8822C) << BIT_SHIFT_PS_AID_3_8822C)
#define BITS_PS_AID_3_8822C \
(BIT_MASK_PS_AID_3_8822C << BIT_SHIFT_PS_AID_3_8822C)
#define BIT_CLEAR_PS_AID_3_8822C(x) ((x) & (~BITS_PS_AID_3_8822C))
#define BIT_GET_PS_AID_3_8822C(x) \
(((x) >> BIT_SHIFT_PS_AID_3_8822C) & BIT_MASK_PS_AID_3_8822C)
#define BIT_SET_PS_AID_3_8822C(x, v) \
(BIT_CLEAR_PS_AID_3_8822C(x) | BIT_PS_AID_3_8822C(v))
/* 2 REG_BCN_PSR_RPT4_8822C (BEACON PARSER REPORT REGISTER4) */
#define BIT_SHIFT_DTIM_CNT4_8822C 24
#define BIT_MASK_DTIM_CNT4_8822C 0xff
#define BIT_DTIM_CNT4_8822C(x) \
(((x) & BIT_MASK_DTIM_CNT4_8822C) << BIT_SHIFT_DTIM_CNT4_8822C)
#define BITS_DTIM_CNT4_8822C \
(BIT_MASK_DTIM_CNT4_8822C << BIT_SHIFT_DTIM_CNT4_8822C)
#define BIT_CLEAR_DTIM_CNT4_8822C(x) ((x) & (~BITS_DTIM_CNT4_8822C))
#define BIT_GET_DTIM_CNT4_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT4_8822C) & BIT_MASK_DTIM_CNT4_8822C)
#define BIT_SET_DTIM_CNT4_8822C(x, v) \
(BIT_CLEAR_DTIM_CNT4_8822C(x) | BIT_DTIM_CNT4_8822C(v))
#define BIT_SHIFT_DTIM_PERIOD4_8822C 16
#define BIT_MASK_DTIM_PERIOD4_8822C 0xff
#define BIT_DTIM_PERIOD4_8822C(x) \
(((x) & BIT_MASK_DTIM_PERIOD4_8822C) << BIT_SHIFT_DTIM_PERIOD4_8822C)
#define BITS_DTIM_PERIOD4_8822C \
(BIT_MASK_DTIM_PERIOD4_8822C << BIT_SHIFT_DTIM_PERIOD4_8822C)
#define BIT_CLEAR_DTIM_PERIOD4_8822C(x) ((x) & (~BITS_DTIM_PERIOD4_8822C))
#define BIT_GET_DTIM_PERIOD4_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD4_8822C) & BIT_MASK_DTIM_PERIOD4_8822C)
#define BIT_SET_DTIM_PERIOD4_8822C(x, v) \
(BIT_CLEAR_DTIM_PERIOD4_8822C(x) | BIT_DTIM_PERIOD4_8822C(v))
#define BIT_DTIM4_8822C BIT(15)
#define BIT_TIM4_8822C BIT(14)
#define BIT_RPT_VALID_8822C BIT(13)
#define BIT_SHIFT_PS_AID_4_8822C 0
#define BIT_MASK_PS_AID_4_8822C 0x7ff
#define BIT_PS_AID_4_8822C(x) \
(((x) & BIT_MASK_PS_AID_4_8822C) << BIT_SHIFT_PS_AID_4_8822C)
#define BITS_PS_AID_4_8822C \
(BIT_MASK_PS_AID_4_8822C << BIT_SHIFT_PS_AID_4_8822C)
#define BIT_CLEAR_PS_AID_4_8822C(x) ((x) & (~BITS_PS_AID_4_8822C))
#define BIT_GET_PS_AID_4_8822C(x) \
(((x) >> BIT_SHIFT_PS_AID_4_8822C) & BIT_MASK_PS_AID_4_8822C)
#define BIT_SET_PS_AID_4_8822C(x, v) \
(BIT_CLEAR_PS_AID_4_8822C(x) | BIT_PS_AID_4_8822C(v))
/* 2 REG_A1_ADDR_MASK_8822C (A1 ADDR MASK REGISTER) */
#define BIT_SHIFT_A1_ADDR_MASK_8822C 0
#define BIT_MASK_A1_ADDR_MASK_8822C 0xffffffffL
#define BIT_A1_ADDR_MASK_8822C(x) \
(((x) & BIT_MASK_A1_ADDR_MASK_8822C) << BIT_SHIFT_A1_ADDR_MASK_8822C)
#define BITS_A1_ADDR_MASK_8822C \
(BIT_MASK_A1_ADDR_MASK_8822C << BIT_SHIFT_A1_ADDR_MASK_8822C)
#define BIT_CLEAR_A1_ADDR_MASK_8822C(x) ((x) & (~BITS_A1_ADDR_MASK_8822C))
#define BIT_GET_A1_ADDR_MASK_8822C(x) \
(((x) >> BIT_SHIFT_A1_ADDR_MASK_8822C) & BIT_MASK_A1_ADDR_MASK_8822C)
#define BIT_SET_A1_ADDR_MASK_8822C(x, v) \
(BIT_CLEAR_A1_ADDR_MASK_8822C(x) | BIT_A1_ADDR_MASK_8822C(v))
/* 2 REG_RXPSF_CTRL_8822C */
#define BIT_RXGCK_FIFOTHR_EN_8822C BIT(28)
#define BIT_SHIFT_RXGCK_VHT_FIFOTHR_8822C 26
#define BIT_MASK_RXGCK_VHT_FIFOTHR_8822C 0x3
#define BIT_RXGCK_VHT_FIFOTHR_8822C(x) \
(((x) & BIT_MASK_RXGCK_VHT_FIFOTHR_8822C) \
<< BIT_SHIFT_RXGCK_VHT_FIFOTHR_8822C)
#define BITS_RXGCK_VHT_FIFOTHR_8822C \
(BIT_MASK_RXGCK_VHT_FIFOTHR_8822C << BIT_SHIFT_RXGCK_VHT_FIFOTHR_8822C)
#define BIT_CLEAR_RXGCK_VHT_FIFOTHR_8822C(x) \
((x) & (~BITS_RXGCK_VHT_FIFOTHR_8822C))
#define BIT_GET_RXGCK_VHT_FIFOTHR_8822C(x) \
(((x) >> BIT_SHIFT_RXGCK_VHT_FIFOTHR_8822C) & \
BIT_MASK_RXGCK_VHT_FIFOTHR_8822C)
#define BIT_SET_RXGCK_VHT_FIFOTHR_8822C(x, v) \
(BIT_CLEAR_RXGCK_VHT_FIFOTHR_8822C(x) | BIT_RXGCK_VHT_FIFOTHR_8822C(v))
#define BIT_SHIFT_RXGCK_HT_FIFOTHR_8822C 24
#define BIT_MASK_RXGCK_HT_FIFOTHR_8822C 0x3
#define BIT_RXGCK_HT_FIFOTHR_8822C(x) \
(((x) & BIT_MASK_RXGCK_HT_FIFOTHR_8822C) \
<< BIT_SHIFT_RXGCK_HT_FIFOTHR_8822C)
#define BITS_RXGCK_HT_FIFOTHR_8822C \
(BIT_MASK_RXGCK_HT_FIFOTHR_8822C << BIT_SHIFT_RXGCK_HT_FIFOTHR_8822C)
#define BIT_CLEAR_RXGCK_HT_FIFOTHR_8822C(x) \
((x) & (~BITS_RXGCK_HT_FIFOTHR_8822C))
#define BIT_GET_RXGCK_HT_FIFOTHR_8822C(x) \
(((x) >> BIT_SHIFT_RXGCK_HT_FIFOTHR_8822C) & \
BIT_MASK_RXGCK_HT_FIFOTHR_8822C)
#define BIT_SET_RXGCK_HT_FIFOTHR_8822C(x, v) \
(BIT_CLEAR_RXGCK_HT_FIFOTHR_8822C(x) | BIT_RXGCK_HT_FIFOTHR_8822C(v))
#define BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8822C 22
#define BIT_MASK_RXGCK_OFDM_FIFOTHR_8822C 0x3
#define BIT_RXGCK_OFDM_FIFOTHR_8822C(x) \
(((x) & BIT_MASK_RXGCK_OFDM_FIFOTHR_8822C) \
<< BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8822C)
#define BITS_RXGCK_OFDM_FIFOTHR_8822C \
(BIT_MASK_RXGCK_OFDM_FIFOTHR_8822C \
<< BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8822C)
#define BIT_CLEAR_RXGCK_OFDM_FIFOTHR_8822C(x) \
((x) & (~BITS_RXGCK_OFDM_FIFOTHR_8822C))
#define BIT_GET_RXGCK_OFDM_FIFOTHR_8822C(x) \
(((x) >> BIT_SHIFT_RXGCK_OFDM_FIFOTHR_8822C) & \
BIT_MASK_RXGCK_OFDM_FIFOTHR_8822C)
#define BIT_SET_RXGCK_OFDM_FIFOTHR_8822C(x, v) \
(BIT_CLEAR_RXGCK_OFDM_FIFOTHR_8822C(x) | \
BIT_RXGCK_OFDM_FIFOTHR_8822C(v))
#define BIT_SHIFT_RXGCK_CCK_FIFOTHR_8822C 20
#define BIT_MASK_RXGCK_CCK_FIFOTHR_8822C 0x3
#define BIT_RXGCK_CCK_FIFOTHR_8822C(x) \
(((x) & BIT_MASK_RXGCK_CCK_FIFOTHR_8822C) \
<< BIT_SHIFT_RXGCK_CCK_FIFOTHR_8822C)
#define BITS_RXGCK_CCK_FIFOTHR_8822C \
(BIT_MASK_RXGCK_CCK_FIFOTHR_8822C << BIT_SHIFT_RXGCK_CCK_FIFOTHR_8822C)
#define BIT_CLEAR_RXGCK_CCK_FIFOTHR_8822C(x) \
((x) & (~BITS_RXGCK_CCK_FIFOTHR_8822C))
#define BIT_GET_RXGCK_CCK_FIFOTHR_8822C(x) \
(((x) >> BIT_SHIFT_RXGCK_CCK_FIFOTHR_8822C) & \
BIT_MASK_RXGCK_CCK_FIFOTHR_8822C)
#define BIT_SET_RXGCK_CCK_FIFOTHR_8822C(x, v) \
(BIT_CLEAR_RXGCK_CCK_FIFOTHR_8822C(x) | BIT_RXGCK_CCK_FIFOTHR_8822C(v))
#define BIT_SHIFT_RXGCK_ENTRY_DELAY_8822C 17
#define BIT_MASK_RXGCK_ENTRY_DELAY_8822C 0x7
#define BIT_RXGCK_ENTRY_DELAY_8822C(x) \
(((x) & BIT_MASK_RXGCK_ENTRY_DELAY_8822C) \
<< BIT_SHIFT_RXGCK_ENTRY_DELAY_8822C)
#define BITS_RXGCK_ENTRY_DELAY_8822C \
(BIT_MASK_RXGCK_ENTRY_DELAY_8822C << BIT_SHIFT_RXGCK_ENTRY_DELAY_8822C)
#define BIT_CLEAR_RXGCK_ENTRY_DELAY_8822C(x) \
((x) & (~BITS_RXGCK_ENTRY_DELAY_8822C))
#define BIT_GET_RXGCK_ENTRY_DELAY_8822C(x) \
(((x) >> BIT_SHIFT_RXGCK_ENTRY_DELAY_8822C) & \
BIT_MASK_RXGCK_ENTRY_DELAY_8822C)
#define BIT_SET_RXGCK_ENTRY_DELAY_8822C(x, v) \
(BIT_CLEAR_RXGCK_ENTRY_DELAY_8822C(x) | BIT_RXGCK_ENTRY_DELAY_8822C(v))
#define BIT_RXGCK_OFDMCCA_EN_8822C BIT(16)
#define BIT_SHIFT_RXPSF_PKTLENTHR_8822C 13
#define BIT_MASK_RXPSF_PKTLENTHR_8822C 0x7
#define BIT_RXPSF_PKTLENTHR_8822C(x) \
(((x) & BIT_MASK_RXPSF_PKTLENTHR_8822C) \
<< BIT_SHIFT_RXPSF_PKTLENTHR_8822C)
#define BITS_RXPSF_PKTLENTHR_8822C \
(BIT_MASK_RXPSF_PKTLENTHR_8822C << BIT_SHIFT_RXPSF_PKTLENTHR_8822C)
#define BIT_CLEAR_RXPSF_PKTLENTHR_8822C(x) ((x) & (~BITS_RXPSF_PKTLENTHR_8822C))
#define BIT_GET_RXPSF_PKTLENTHR_8822C(x) \
(((x) >> BIT_SHIFT_RXPSF_PKTLENTHR_8822C) & \
BIT_MASK_RXPSF_PKTLENTHR_8822C)
#define BIT_SET_RXPSF_PKTLENTHR_8822C(x, v) \
(BIT_CLEAR_RXPSF_PKTLENTHR_8822C(x) | BIT_RXPSF_PKTLENTHR_8822C(v))
#define BIT_RXPSF_CTRLEN_8822C BIT(12)
#define BIT_RXPSF_VHTCHKEN_8822C BIT(11)
#define BIT_RXPSF_HTCHKEN_8822C BIT(10)
#define BIT_RXPSF_OFDMCHKEN_8822C BIT(9)
#define BIT_RXPSF_CCKCHKEN_8822C BIT(8)
#define BIT_RXPSF_OFDMRST_8822C BIT(7)
#define BIT_RXPSF_CCKRST_8822C BIT(6)
#define BIT_RXPSF_MHCHKEN_8822C BIT(5)
#define BIT_RXPSF_CONT_ERRCHKEN_8822C BIT(4)
#define BIT_RXPSF_ALL_ERRCHKEN_8822C BIT(3)
#define BIT_SHIFT_RXPSF_ERRTHR_8822C 0
#define BIT_MASK_RXPSF_ERRTHR_8822C 0x7
#define BIT_RXPSF_ERRTHR_8822C(x) \
(((x) & BIT_MASK_RXPSF_ERRTHR_8822C) << BIT_SHIFT_RXPSF_ERRTHR_8822C)
#define BITS_RXPSF_ERRTHR_8822C \
(BIT_MASK_RXPSF_ERRTHR_8822C << BIT_SHIFT_RXPSF_ERRTHR_8822C)
#define BIT_CLEAR_RXPSF_ERRTHR_8822C(x) ((x) & (~BITS_RXPSF_ERRTHR_8822C))
#define BIT_GET_RXPSF_ERRTHR_8822C(x) \
(((x) >> BIT_SHIFT_RXPSF_ERRTHR_8822C) & BIT_MASK_RXPSF_ERRTHR_8822C)
#define BIT_SET_RXPSF_ERRTHR_8822C(x, v) \
(BIT_CLEAR_RXPSF_ERRTHR_8822C(x) | BIT_RXPSF_ERRTHR_8822C(v))
/* 2 REG_RXPSF_TYPE_CTRL_8822C */
#define BIT_RXPSF_DATA15EN_8822C BIT(31)
#define BIT_RXPSF_DATA14EN_8822C BIT(30)
#define BIT_RXPSF_DATA13EN_8822C BIT(29)
#define BIT_RXPSF_DATA12EN_8822C BIT(28)
#define BIT_RXPSF_DATA11EN_8822C BIT(27)
#define BIT_RXPSF_DATA10EN_8822C BIT(26)
#define BIT_RXPSF_DATA9EN_8822C BIT(25)
#define BIT_RXPSF_DATA8EN_8822C BIT(24)
#define BIT_RXPSF_DATA7EN_8822C BIT(23)
#define BIT_RXPSF_DATA6EN_8822C BIT(22)
#define BIT_RXPSF_DATA5EN_8822C BIT(21)
#define BIT_RXPSF_DATA4EN_8822C BIT(20)
#define BIT_RXPSF_DATA3EN_8822C BIT(19)
#define BIT_RXPSF_DATA2EN_8822C BIT(18)
#define BIT_RXPSF_DATA1EN_8822C BIT(17)
#define BIT_RXPSF_DATA0EN_8822C BIT(16)
#define BIT_RXPSF_MGT15EN_8822C BIT(15)
#define BIT_RXPSF_MGT14EN_8822C BIT(14)
#define BIT_RXPSF_MGT13EN_8822C BIT(13)
#define BIT_RXPSF_MGT12EN_8822C BIT(12)
#define BIT_RXPSF_MGT11EN_8822C BIT(11)
#define BIT_RXPSF_MGT10EN_8822C BIT(10)
#define BIT_RXPSF_MGT9EN_8822C BIT(9)
#define BIT_RXPSF_MGT8EN_8822C BIT(8)
#define BIT_RXPSF_MGT7EN_8822C BIT(7)
#define BIT_RXPSF_MGT6EN_8822C BIT(6)
#define BIT_RXPSF_MGT5EN_8822C BIT(5)
#define BIT_RXPSF_MGT4EN_8822C BIT(4)
#define BIT_RXPSF_MGT3EN_8822C BIT(3)
#define BIT_RXPSF_MGT2EN_8822C BIT(2)
#define BIT_RXPSF_MGT1EN_8822C BIT(1)
#define BIT_RXPSF_MGT0EN_8822C BIT(0)
/* 2 REG_CAM_ACCESS_CTRL_8822C */
#define BIT_INDIRECT_ERR_8822C BIT(6)
#define BIT_DIRECT_ERR_8822C BIT(5)
#define BIT_DIR_ACCESS_EN_RX_BA_8822C BIT(4)
#define BIT_DIR_ACCESS_EN_MBSSIDCAM_8822C BIT(3)
#define BIT_DIR_ACCESS_EN_KEY_8822C BIT(2)
#define BIT_DIR_ACCESS_EN_WOWLAN_8822C BIT(1)
#define BIT_DIR_ACCESS_EN_FW_FILTER_8822C BIT(0)
/* 2 REG_HT_SND_REF_RATE_8822C */
#define BIT_SHIFT_WMAC_HT_CSI_RATE_8822C 0
#define BIT_MASK_WMAC_HT_CSI_RATE_8822C 0x3f
#define BIT_WMAC_HT_CSI_RATE_8822C(x) \
(((x) & BIT_MASK_WMAC_HT_CSI_RATE_8822C) \
<< BIT_SHIFT_WMAC_HT_CSI_RATE_8822C)
#define BITS_WMAC_HT_CSI_RATE_8822C \
(BIT_MASK_WMAC_HT_CSI_RATE_8822C << BIT_SHIFT_WMAC_HT_CSI_RATE_8822C)
#define BIT_CLEAR_WMAC_HT_CSI_RATE_8822C(x) \
((x) & (~BITS_WMAC_HT_CSI_RATE_8822C))
#define BIT_GET_WMAC_HT_CSI_RATE_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_HT_CSI_RATE_8822C) & \
BIT_MASK_WMAC_HT_CSI_RATE_8822C)
#define BIT_SET_WMAC_HT_CSI_RATE_8822C(x, v) \
(BIT_CLEAR_WMAC_HT_CSI_RATE_8822C(x) | BIT_WMAC_HT_CSI_RATE_8822C(v))
/* 2 REG_RSVD_8822C */
/* 2 REG_MACID2_8822C (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_V1_8822C 0
#define BIT_MASK_MACID2_V1_8822C 0xffffffffL
#define BIT_MACID2_V1_8822C(x) \
(((x) & BIT_MASK_MACID2_V1_8822C) << BIT_SHIFT_MACID2_V1_8822C)
#define BITS_MACID2_V1_8822C \
(BIT_MASK_MACID2_V1_8822C << BIT_SHIFT_MACID2_V1_8822C)
#define BIT_CLEAR_MACID2_V1_8822C(x) ((x) & (~BITS_MACID2_V1_8822C))
#define BIT_GET_MACID2_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID2_V1_8822C) & BIT_MASK_MACID2_V1_8822C)
#define BIT_SET_MACID2_V1_8822C(x, v) \
(BIT_CLEAR_MACID2_V1_8822C(x) | BIT_MACID2_V1_8822C(v))
/* 2 REG_MACID2_H_8822C (MAC ID2 REGISTER) */
#define BIT_SHIFT_MACID2_H_V1_8822C 0
#define BIT_MASK_MACID2_H_V1_8822C 0xffff
#define BIT_MACID2_H_V1_8822C(x) \
(((x) & BIT_MASK_MACID2_H_V1_8822C) << BIT_SHIFT_MACID2_H_V1_8822C)
#define BITS_MACID2_H_V1_8822C \
(BIT_MASK_MACID2_H_V1_8822C << BIT_SHIFT_MACID2_H_V1_8822C)
#define BIT_CLEAR_MACID2_H_V1_8822C(x) ((x) & (~BITS_MACID2_H_V1_8822C))
#define BIT_GET_MACID2_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID2_H_V1_8822C) & BIT_MASK_MACID2_H_V1_8822C)
#define BIT_SET_MACID2_H_V1_8822C(x, v) \
(BIT_CLEAR_MACID2_H_V1_8822C(x) | BIT_MACID2_H_V1_8822C(v))
/* 2 REG_BSSID2_8822C (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_V1_8822C 0
#define BIT_MASK_BSSID2_V1_8822C 0xffffffffL
#define BIT_BSSID2_V1_8822C(x) \
(((x) & BIT_MASK_BSSID2_V1_8822C) << BIT_SHIFT_BSSID2_V1_8822C)
#define BITS_BSSID2_V1_8822C \
(BIT_MASK_BSSID2_V1_8822C << BIT_SHIFT_BSSID2_V1_8822C)
#define BIT_CLEAR_BSSID2_V1_8822C(x) ((x) & (~BITS_BSSID2_V1_8822C))
#define BIT_GET_BSSID2_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID2_V1_8822C) & BIT_MASK_BSSID2_V1_8822C)
#define BIT_SET_BSSID2_V1_8822C(x, v) \
(BIT_CLEAR_BSSID2_V1_8822C(x) | BIT_BSSID2_V1_8822C(v))
/* 2 REG_BSSID2_H_8822C (BSSID2 REGISTER) */
#define BIT_SHIFT_BSSID2_H_V1_8822C 0
#define BIT_MASK_BSSID2_H_V1_8822C 0xffff
#define BIT_BSSID2_H_V1_8822C(x) \
(((x) & BIT_MASK_BSSID2_H_V1_8822C) << BIT_SHIFT_BSSID2_H_V1_8822C)
#define BITS_BSSID2_H_V1_8822C \
(BIT_MASK_BSSID2_H_V1_8822C << BIT_SHIFT_BSSID2_H_V1_8822C)
#define BIT_CLEAR_BSSID2_H_V1_8822C(x) ((x) & (~BITS_BSSID2_H_V1_8822C))
#define BIT_GET_BSSID2_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID2_H_V1_8822C) & BIT_MASK_BSSID2_H_V1_8822C)
#define BIT_SET_BSSID2_H_V1_8822C(x, v) \
(BIT_CLEAR_BSSID2_H_V1_8822C(x) | BIT_BSSID2_H_V1_8822C(v))
/* 2 REG_MACID3_8822C (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_V1_8822C 0
#define BIT_MASK_MACID3_V1_8822C 0xffffffffL
#define BIT_MACID3_V1_8822C(x) \
(((x) & BIT_MASK_MACID3_V1_8822C) << BIT_SHIFT_MACID3_V1_8822C)
#define BITS_MACID3_V1_8822C \
(BIT_MASK_MACID3_V1_8822C << BIT_SHIFT_MACID3_V1_8822C)
#define BIT_CLEAR_MACID3_V1_8822C(x) ((x) & (~BITS_MACID3_V1_8822C))
#define BIT_GET_MACID3_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID3_V1_8822C) & BIT_MASK_MACID3_V1_8822C)
#define BIT_SET_MACID3_V1_8822C(x, v) \
(BIT_CLEAR_MACID3_V1_8822C(x) | BIT_MACID3_V1_8822C(v))
/* 2 REG_MACID3_H_8822C (MAC ID3 REGISTER) */
#define BIT_SHIFT_MACID3_H_V1_8822C 0
#define BIT_MASK_MACID3_H_V1_8822C 0xffff
#define BIT_MACID3_H_V1_8822C(x) \
(((x) & BIT_MASK_MACID3_H_V1_8822C) << BIT_SHIFT_MACID3_H_V1_8822C)
#define BITS_MACID3_H_V1_8822C \
(BIT_MASK_MACID3_H_V1_8822C << BIT_SHIFT_MACID3_H_V1_8822C)
#define BIT_CLEAR_MACID3_H_V1_8822C(x) ((x) & (~BITS_MACID3_H_V1_8822C))
#define BIT_GET_MACID3_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID3_H_V1_8822C) & BIT_MASK_MACID3_H_V1_8822C)
#define BIT_SET_MACID3_H_V1_8822C(x, v) \
(BIT_CLEAR_MACID3_H_V1_8822C(x) | BIT_MACID3_H_V1_8822C(v))
/* 2 REG_BSSID3_8822C (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_V1_8822C 0
#define BIT_MASK_BSSID3_V1_8822C 0xffffffffL
#define BIT_BSSID3_V1_8822C(x) \
(((x) & BIT_MASK_BSSID3_V1_8822C) << BIT_SHIFT_BSSID3_V1_8822C)
#define BITS_BSSID3_V1_8822C \
(BIT_MASK_BSSID3_V1_8822C << BIT_SHIFT_BSSID3_V1_8822C)
#define BIT_CLEAR_BSSID3_V1_8822C(x) ((x) & (~BITS_BSSID3_V1_8822C))
#define BIT_GET_BSSID3_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID3_V1_8822C) & BIT_MASK_BSSID3_V1_8822C)
#define BIT_SET_BSSID3_V1_8822C(x, v) \
(BIT_CLEAR_BSSID3_V1_8822C(x) | BIT_BSSID3_V1_8822C(v))
/* 2 REG_BSSID3_H_8822C (BSSID3 REGISTER) */
#define BIT_SHIFT_BSSID3_H_V1_8822C 0
#define BIT_MASK_BSSID3_H_V1_8822C 0xffff
#define BIT_BSSID3_H_V1_8822C(x) \
(((x) & BIT_MASK_BSSID3_H_V1_8822C) << BIT_SHIFT_BSSID3_H_V1_8822C)
#define BITS_BSSID3_H_V1_8822C \
(BIT_MASK_BSSID3_H_V1_8822C << BIT_SHIFT_BSSID3_H_V1_8822C)
#define BIT_CLEAR_BSSID3_H_V1_8822C(x) ((x) & (~BITS_BSSID3_H_V1_8822C))
#define BIT_GET_BSSID3_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID3_H_V1_8822C) & BIT_MASK_BSSID3_H_V1_8822C)
#define BIT_SET_BSSID3_H_V1_8822C(x, v) \
(BIT_CLEAR_BSSID3_H_V1_8822C(x) | BIT_BSSID3_H_V1_8822C(v))
/* 2 REG_MACID4_8822C (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_V1_8822C 0
#define BIT_MASK_MACID4_V1_8822C 0xffffffffL
#define BIT_MACID4_V1_8822C(x) \
(((x) & BIT_MASK_MACID4_V1_8822C) << BIT_SHIFT_MACID4_V1_8822C)
#define BITS_MACID4_V1_8822C \
(BIT_MASK_MACID4_V1_8822C << BIT_SHIFT_MACID4_V1_8822C)
#define BIT_CLEAR_MACID4_V1_8822C(x) ((x) & (~BITS_MACID4_V1_8822C))
#define BIT_GET_MACID4_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID4_V1_8822C) & BIT_MASK_MACID4_V1_8822C)
#define BIT_SET_MACID4_V1_8822C(x, v) \
(BIT_CLEAR_MACID4_V1_8822C(x) | BIT_MACID4_V1_8822C(v))
/* 2 REG_MACID4_H_8822C (MAC ID4 REGISTER) */
#define BIT_SHIFT_MACID4_H_V1_8822C 0
#define BIT_MASK_MACID4_H_V1_8822C 0xffff
#define BIT_MACID4_H_V1_8822C(x) \
(((x) & BIT_MASK_MACID4_H_V1_8822C) << BIT_SHIFT_MACID4_H_V1_8822C)
#define BITS_MACID4_H_V1_8822C \
(BIT_MASK_MACID4_H_V1_8822C << BIT_SHIFT_MACID4_H_V1_8822C)
#define BIT_CLEAR_MACID4_H_V1_8822C(x) ((x) & (~BITS_MACID4_H_V1_8822C))
#define BIT_GET_MACID4_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_MACID4_H_V1_8822C) & BIT_MASK_MACID4_H_V1_8822C)
#define BIT_SET_MACID4_H_V1_8822C(x, v) \
(BIT_CLEAR_MACID4_H_V1_8822C(x) | BIT_MACID4_H_V1_8822C(v))
/* 2 REG_BSSID4_8822C (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_V1_8822C 0
#define BIT_MASK_BSSID4_V1_8822C 0xffffffffL
#define BIT_BSSID4_V1_8822C(x) \
(((x) & BIT_MASK_BSSID4_V1_8822C) << BIT_SHIFT_BSSID4_V1_8822C)
#define BITS_BSSID4_V1_8822C \
(BIT_MASK_BSSID4_V1_8822C << BIT_SHIFT_BSSID4_V1_8822C)
#define BIT_CLEAR_BSSID4_V1_8822C(x) ((x) & (~BITS_BSSID4_V1_8822C))
#define BIT_GET_BSSID4_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID4_V1_8822C) & BIT_MASK_BSSID4_V1_8822C)
#define BIT_SET_BSSID4_V1_8822C(x, v) \
(BIT_CLEAR_BSSID4_V1_8822C(x) | BIT_BSSID4_V1_8822C(v))
/* 2 REG_BSSID4_H_8822C (BSSID4 REGISTER) */
#define BIT_SHIFT_BSSID4_H_V1_8822C 0
#define BIT_MASK_BSSID4_H_V1_8822C 0xffff
#define BIT_BSSID4_H_V1_8822C(x) \
(((x) & BIT_MASK_BSSID4_H_V1_8822C) << BIT_SHIFT_BSSID4_H_V1_8822C)
#define BITS_BSSID4_H_V1_8822C \
(BIT_MASK_BSSID4_H_V1_8822C << BIT_SHIFT_BSSID4_H_V1_8822C)
#define BIT_CLEAR_BSSID4_H_V1_8822C(x) ((x) & (~BITS_BSSID4_H_V1_8822C))
#define BIT_GET_BSSID4_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID4_H_V1_8822C) & BIT_MASK_BSSID4_H_V1_8822C)
#define BIT_SET_BSSID4_H_V1_8822C(x, v) \
(BIT_CLEAR_BSSID4_H_V1_8822C(x) | BIT_BSSID4_H_V1_8822C(v))
/* 2 REG_NOA_REPORT_8822C */
/* 2 REG_NOA_REPORT_1_8822C */
/* 2 REG_NOA_REPORT_2_8822C */
/* 2 REG_NOA_REPORT_3_8822C */
/* 2 REG_PWRBIT_SETTING_8822C */
#define BIT_CLI3_WMAC_TCRPWRMGT_HWCTL_EN_8822C BIT(15)
#define BIT_CLI3_WMAC_TCRPWRMGT_HWDATA_EN_8822C BIT(14)
#define BIT_CLI3_WMAC_TCRPWRMGT_HWACT_EN_8822C BIT(13)
#define BIT_CLI3_PWR_ST_V1_8822C BIT(12)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWCTL_EN_8822C BIT(11)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWDATA_EN_8822C BIT(10)
#define BIT_CLI2_WMAC_TCRPWRMGT_HWACT_EN_8822C BIT(9)
#define BIT_CLI2_PWR_ST_V1_8822C BIT(8)
#define BIT_CLI1_WMAC_TCRPWRMGT_HWCTL_EN_8822C BIT(7)
#define BIT_CLI1_WMAC_TCRPWRMGT_HWDATA_EN_8822C BIT(6)
#define BIT_CLI1_WMAC_TCRPWRMGT_HWACT_EN_8822C BIT(5)
#define BIT_CLI1_PWR_ST_V1_8822C BIT(4)
#define BIT_CLI0_WMAC_TCRPWRMGT_HWCTL_EN_8822C BIT(3)
#define BIT_CLI0_WMAC_TCRPWRMGT_HWDATA_EN_8822C BIT(2)
#define BIT_CLI0_WMAC_TCRPWRMGT_HWACT_EN_8822C BIT(1)
#define BIT_CLI0_PWR_ST_V1_8822C BIT(0)
/* 2 REG_GENERAL_OPTION_8822C */
#define BIT_WMAC_RXRST_NDP_TIMEOUT_8822C BIT(11)
#define BIT_WMAC_NDP_STANDBY_WAIT_RXEND_8822C BIT(10)
#define BIT_DUMMY_FCS_READY_MASK_EN_8822C BIT(9)
#define BIT_RXFIFO_GNT_CUT_8822C BIT(8)
#define BIT_DUMMY_RXD_FCS_ERROR_MASK_EN_V1_8822C BIT(7)
#define BIT_WMAC_EXT_DBG_SEL_V1_8822C BIT(6)
#define BIT_WMAC_FIX_FIRST_MPDU_WITH_PHYSTS_8822C BIT(5)
#define BIT_RX_DMA_BYPASS_CHECK_DATABYPASS_CHECK_DATA_8822C BIT(4)
#define BIT_RX_DMA_BYPASS_CHECK_MGTBIT_RX_DMA_BYPASS_CHECK_MGT_8822C BIT(3)
#define BIT_TXSERV_FIELD_SEL_8822C BIT(2)
#define BIT_RXVHT_LEN_SEL_8822C BIT(1)
#define BIT_RXMIC_PROTECT_EN_8822C BIT(0)
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_CSI_RRSR_8822C */
#define BIT_CSI_LDPC_EN_8822C BIT(29)
#define BIT_CSI_STBC_EN_8822C BIT(28)
#define BIT_SHIFT_CSI_RRSC_BITMAP_8822C 4
#define BIT_MASK_CSI_RRSC_BITMAP_8822C 0xffffff
#define BIT_CSI_RRSC_BITMAP_8822C(x) \
(((x) & BIT_MASK_CSI_RRSC_BITMAP_8822C) \
<< BIT_SHIFT_CSI_RRSC_BITMAP_8822C)
#define BITS_CSI_RRSC_BITMAP_8822C \
(BIT_MASK_CSI_RRSC_BITMAP_8822C << BIT_SHIFT_CSI_RRSC_BITMAP_8822C)
#define BIT_CLEAR_CSI_RRSC_BITMAP_8822C(x) ((x) & (~BITS_CSI_RRSC_BITMAP_8822C))
#define BIT_GET_CSI_RRSC_BITMAP_8822C(x) \
(((x) >> BIT_SHIFT_CSI_RRSC_BITMAP_8822C) & \
BIT_MASK_CSI_RRSC_BITMAP_8822C)
#define BIT_SET_CSI_RRSC_BITMAP_8822C(x, v) \
(BIT_CLEAR_CSI_RRSC_BITMAP_8822C(x) | BIT_CSI_RRSC_BITMAP_8822C(v))
#define BIT_SHIFT_OFDM_LEN_TH_8822C 0
#define BIT_MASK_OFDM_LEN_TH_8822C 0xf
#define BIT_OFDM_LEN_TH_8822C(x) \
(((x) & BIT_MASK_OFDM_LEN_TH_8822C) << BIT_SHIFT_OFDM_LEN_TH_8822C)
#define BITS_OFDM_LEN_TH_8822C \
(BIT_MASK_OFDM_LEN_TH_8822C << BIT_SHIFT_OFDM_LEN_TH_8822C)
#define BIT_CLEAR_OFDM_LEN_TH_8822C(x) ((x) & (~BITS_OFDM_LEN_TH_8822C))
#define BIT_GET_OFDM_LEN_TH_8822C(x) \
(((x) >> BIT_SHIFT_OFDM_LEN_TH_8822C) & BIT_MASK_OFDM_LEN_TH_8822C)
#define BIT_SET_OFDM_LEN_TH_8822C(x, v) \
(BIT_CLEAR_OFDM_LEN_TH_8822C(x) | BIT_OFDM_LEN_TH_8822C(v))
/* 2 REG_MU_BF_OPTION_8822C */
#define BIT_WMAC_RESP_NONSTA1_DIS_8822C BIT(7)
#define BIT_WMAC_TXMU_ACKPOLICY_EN_8822C BIT(6)
#define BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822C 4
#define BIT_MASK_WMAC_TXMU_ACKPOLICY_8822C 0x3
#define BIT_WMAC_TXMU_ACKPOLICY_8822C(x) \
(((x) & BIT_MASK_WMAC_TXMU_ACKPOLICY_8822C) \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822C)
#define BITS_WMAC_TXMU_ACKPOLICY_8822C \
(BIT_MASK_WMAC_TXMU_ACKPOLICY_8822C \
<< BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822C)
#define BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8822C(x) \
((x) & (~BITS_WMAC_TXMU_ACKPOLICY_8822C))
#define BIT_GET_WMAC_TXMU_ACKPOLICY_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_TXMU_ACKPOLICY_8822C) & \
BIT_MASK_WMAC_TXMU_ACKPOLICY_8822C)
#define BIT_SET_WMAC_TXMU_ACKPOLICY_8822C(x, v) \
(BIT_CLEAR_WMAC_TXMU_ACKPOLICY_8822C(x) | \
BIT_WMAC_TXMU_ACKPOLICY_8822C(v))
#define BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822C 1
#define BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822C 0x7
#define BIT_WMAC_MU_BFEE_PORT_SEL_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822C)
#define BITS_WMAC_MU_BFEE_PORT_SEL_8822C \
(BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822C \
<< BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE_PORT_SEL_8822C))
#define BIT_GET_WMAC_MU_BFEE_PORT_SEL_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE_PORT_SEL_8822C) & \
BIT_MASK_WMAC_MU_BFEE_PORT_SEL_8822C)
#define BIT_SET_WMAC_MU_BFEE_PORT_SEL_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE_PORT_SEL_8822C(x) | \
BIT_WMAC_MU_BFEE_PORT_SEL_8822C(v))
#define BIT_WMAC_MU_BFEE_DIS_8822C BIT(0)
/* 2 REG_WMAC_PAUSE_BB_CLR_TH_8822C */
#define BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822C 0
#define BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822C 0xff
#define BIT_WMAC_PAUSE_BB_CLR_TH_8822C(x) \
(((x) & BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822C) \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822C)
#define BITS_WMAC_PAUSE_BB_CLR_TH_8822C \
(BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822C \
<< BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822C)
#define BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8822C(x) \
((x) & (~BITS_WMAC_PAUSE_BB_CLR_TH_8822C))
#define BIT_GET_WMAC_PAUSE_BB_CLR_TH_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_PAUSE_BB_CLR_TH_8822C) & \
BIT_MASK_WMAC_PAUSE_BB_CLR_TH_8822C)
#define BIT_SET_WMAC_PAUSE_BB_CLR_TH_8822C(x, v) \
(BIT_CLEAR_WMAC_PAUSE_BB_CLR_TH_8822C(x) | \
BIT_WMAC_PAUSE_BB_CLR_TH_8822C(v))
/* 2 REG__WMAC_MULBK_BUF_8822C */
#define BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8822C 0
#define BIT_MASK_WMAC_MULBK_PAGE_SIZE_8822C 0xff
#define BIT_WMAC_MULBK_PAGE_SIZE_8822C(x) \
(((x) & BIT_MASK_WMAC_MULBK_PAGE_SIZE_8822C) \
<< BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8822C)
#define BITS_WMAC_MULBK_PAGE_SIZE_8822C \
(BIT_MASK_WMAC_MULBK_PAGE_SIZE_8822C \
<< BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8822C)
#define BIT_CLEAR_WMAC_MULBK_PAGE_SIZE_8822C(x) \
((x) & (~BITS_WMAC_MULBK_PAGE_SIZE_8822C))
#define BIT_GET_WMAC_MULBK_PAGE_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MULBK_PAGE_SIZE_8822C) & \
BIT_MASK_WMAC_MULBK_PAGE_SIZE_8822C)
#define BIT_SET_WMAC_MULBK_PAGE_SIZE_8822C(x, v) \
(BIT_CLEAR_WMAC_MULBK_PAGE_SIZE_8822C(x) | \
BIT_WMAC_MULBK_PAGE_SIZE_8822C(v))
/* 2 REG_WMAC_MU_OPTION_8822C */
/* 2 REG_WMAC_MU_BF_CTL_8822C */
#define BIT_WMAC_INVLD_BFPRT_CHK_8822C BIT(15)
#define BIT_WMAC_RETXBFRPTSEQ_UPD_8822C BIT(14)
#define BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822C 12
#define BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822C 0x3
#define BIT_WMAC_MU_BFRPTSEG_SEL_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822C) \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822C)
#define BITS_WMAC_MU_BFRPTSEG_SEL_8822C \
(BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822C \
<< BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822C)
#define BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8822C(x) \
((x) & (~BITS_WMAC_MU_BFRPTSEG_SEL_8822C))
#define BIT_GET_WMAC_MU_BFRPTSEG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFRPTSEG_SEL_8822C) & \
BIT_MASK_WMAC_MU_BFRPTSEG_SEL_8822C)
#define BIT_SET_WMAC_MU_BFRPTSEG_SEL_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFRPTSEG_SEL_8822C(x) | \
BIT_WMAC_MU_BFRPTSEG_SEL_8822C(v))
#define BIT_SHIFT_WMAC_MU_BF_MYAID_8822C 0
#define BIT_MASK_WMAC_MU_BF_MYAID_8822C 0xfff
#define BIT_WMAC_MU_BF_MYAID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BF_MYAID_8822C) \
<< BIT_SHIFT_WMAC_MU_BF_MYAID_8822C)
#define BITS_WMAC_MU_BF_MYAID_8822C \
(BIT_MASK_WMAC_MU_BF_MYAID_8822C << BIT_SHIFT_WMAC_MU_BF_MYAID_8822C)
#define BIT_CLEAR_WMAC_MU_BF_MYAID_8822C(x) \
((x) & (~BITS_WMAC_MU_BF_MYAID_8822C))
#define BIT_GET_WMAC_MU_BF_MYAID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BF_MYAID_8822C) & \
BIT_MASK_WMAC_MU_BF_MYAID_8822C)
#define BIT_SET_WMAC_MU_BF_MYAID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BF_MYAID_8822C(x) | BIT_WMAC_MU_BF_MYAID_8822C(v))
/* 2 REG_WMAC_MU_BFRPT_PARA_8822C */
#define BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8822C 13
#define BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8822C 0x7
#define BIT_BFRPT_PARA_USERID_SEL_V1_8822C(x) \
(((x) & BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8822C) \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8822C)
#define BITS_BFRPT_PARA_USERID_SEL_V1_8822C \
(BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8822C \
<< BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8822C)
#define BIT_CLEAR_BFRPT_PARA_USERID_SEL_V1_8822C(x) \
((x) & (~BITS_BFRPT_PARA_USERID_SEL_V1_8822C))
#define BIT_GET_BFRPT_PARA_USERID_SEL_V1_8822C(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_USERID_SEL_V1_8822C) & \
BIT_MASK_BFRPT_PARA_USERID_SEL_V1_8822C)
#define BIT_SET_BFRPT_PARA_USERID_SEL_V1_8822C(x, v) \
(BIT_CLEAR_BFRPT_PARA_USERID_SEL_V1_8822C(x) | \
BIT_BFRPT_PARA_USERID_SEL_V1_8822C(v))
#define BIT_SHIFT_BFRPT_PARA_V1_8822C 0
#define BIT_MASK_BFRPT_PARA_V1_8822C 0x1fff
#define BIT_BFRPT_PARA_V1_8822C(x) \
(((x) & BIT_MASK_BFRPT_PARA_V1_8822C) << BIT_SHIFT_BFRPT_PARA_V1_8822C)
#define BITS_BFRPT_PARA_V1_8822C \
(BIT_MASK_BFRPT_PARA_V1_8822C << BIT_SHIFT_BFRPT_PARA_V1_8822C)
#define BIT_CLEAR_BFRPT_PARA_V1_8822C(x) ((x) & (~BITS_BFRPT_PARA_V1_8822C))
#define BIT_GET_BFRPT_PARA_V1_8822C(x) \
(((x) >> BIT_SHIFT_BFRPT_PARA_V1_8822C) & BIT_MASK_BFRPT_PARA_V1_8822C)
#define BIT_SET_BFRPT_PARA_V1_8822C(x, v) \
(BIT_CLEAR_BFRPT_PARA_V1_8822C(x) | BIT_BFRPT_PARA_V1_8822C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE2_8822C */
#define BIT_STATUS_BFEE2_8822C BIT(10)
#define BIT_WMAC_MU_BFEE2_EN_8822C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE2_AID_8822C 0
#define BIT_MASK_WMAC_MU_BFEE2_AID_8822C 0x1ff
#define BIT_WMAC_MU_BFEE2_AID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE2_AID_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE2_AID_8822C)
#define BITS_WMAC_MU_BFEE2_AID_8822C \
(BIT_MASK_WMAC_MU_BFEE2_AID_8822C << BIT_SHIFT_WMAC_MU_BFEE2_AID_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE2_AID_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE2_AID_8822C))
#define BIT_GET_WMAC_MU_BFEE2_AID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE2_AID_8822C) & \
BIT_MASK_WMAC_MU_BFEE2_AID_8822C)
#define BIT_SET_WMAC_MU_BFEE2_AID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE2_AID_8822C(x) | BIT_WMAC_MU_BFEE2_AID_8822C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE3_8822C */
#define BIT_STATUS_BFEE3_8822C BIT(10)
#define BIT_WMAC_MU_BFEE3_EN_8822C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE3_AID_8822C 0
#define BIT_MASK_WMAC_MU_BFEE3_AID_8822C 0x1ff
#define BIT_WMAC_MU_BFEE3_AID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE3_AID_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE3_AID_8822C)
#define BITS_WMAC_MU_BFEE3_AID_8822C \
(BIT_MASK_WMAC_MU_BFEE3_AID_8822C << BIT_SHIFT_WMAC_MU_BFEE3_AID_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE3_AID_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE3_AID_8822C))
#define BIT_GET_WMAC_MU_BFEE3_AID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE3_AID_8822C) & \
BIT_MASK_WMAC_MU_BFEE3_AID_8822C)
#define BIT_SET_WMAC_MU_BFEE3_AID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE3_AID_8822C(x) | BIT_WMAC_MU_BFEE3_AID_8822C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE4_8822C */
#define BIT_STATUS_BFEE4_8822C BIT(10)
#define BIT_WMAC_MU_BFEE4_EN_8822C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE4_AID_8822C 0
#define BIT_MASK_WMAC_MU_BFEE4_AID_8822C 0x1ff
#define BIT_WMAC_MU_BFEE4_AID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE4_AID_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE4_AID_8822C)
#define BITS_WMAC_MU_BFEE4_AID_8822C \
(BIT_MASK_WMAC_MU_BFEE4_AID_8822C << BIT_SHIFT_WMAC_MU_BFEE4_AID_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE4_AID_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE4_AID_8822C))
#define BIT_GET_WMAC_MU_BFEE4_AID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE4_AID_8822C) & \
BIT_MASK_WMAC_MU_BFEE4_AID_8822C)
#define BIT_SET_WMAC_MU_BFEE4_AID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE4_AID_8822C(x) | BIT_WMAC_MU_BFEE4_AID_8822C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE5_8822C */
#define BIT_BIT_STATUS_BFEE5_8822C BIT(10)
#define BIT_WMAC_MU_BFEE5_EN_8822C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE5_AID_8822C 0
#define BIT_MASK_WMAC_MU_BFEE5_AID_8822C 0x1ff
#define BIT_WMAC_MU_BFEE5_AID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE5_AID_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE5_AID_8822C)
#define BITS_WMAC_MU_BFEE5_AID_8822C \
(BIT_MASK_WMAC_MU_BFEE5_AID_8822C << BIT_SHIFT_WMAC_MU_BFEE5_AID_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE5_AID_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE5_AID_8822C))
#define BIT_GET_WMAC_MU_BFEE5_AID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE5_AID_8822C) & \
BIT_MASK_WMAC_MU_BFEE5_AID_8822C)
#define BIT_SET_WMAC_MU_BFEE5_AID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE5_AID_8822C(x) | BIT_WMAC_MU_BFEE5_AID_8822C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE6_8822C */
#define BIT_STATUS_BFEE6_8822C BIT(10)
#define BIT_WMAC_MU_BFEE6_EN_8822C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE6_AID_8822C 0
#define BIT_MASK_WMAC_MU_BFEE6_AID_8822C 0x1ff
#define BIT_WMAC_MU_BFEE6_AID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE6_AID_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE6_AID_8822C)
#define BITS_WMAC_MU_BFEE6_AID_8822C \
(BIT_MASK_WMAC_MU_BFEE6_AID_8822C << BIT_SHIFT_WMAC_MU_BFEE6_AID_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE6_AID_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE6_AID_8822C))
#define BIT_GET_WMAC_MU_BFEE6_AID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE6_AID_8822C) & \
BIT_MASK_WMAC_MU_BFEE6_AID_8822C)
#define BIT_SET_WMAC_MU_BFEE6_AID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE6_AID_8822C(x) | BIT_WMAC_MU_BFEE6_AID_8822C(v))
/* 2 REG_WMAC_ASSOCIATED_MU_BFMEE7_8822C */
#define BIT_STATUS_BFEE7_8822C BIT(10)
#define BIT_WMAC_MU_BFEE7_EN_8822C BIT(9)
#define BIT_SHIFT_WMAC_MU_BFEE7_AID_8822C 0
#define BIT_MASK_WMAC_MU_BFEE7_AID_8822C 0x1ff
#define BIT_WMAC_MU_BFEE7_AID_8822C(x) \
(((x) & BIT_MASK_WMAC_MU_BFEE7_AID_8822C) \
<< BIT_SHIFT_WMAC_MU_BFEE7_AID_8822C)
#define BITS_WMAC_MU_BFEE7_AID_8822C \
(BIT_MASK_WMAC_MU_BFEE7_AID_8822C << BIT_SHIFT_WMAC_MU_BFEE7_AID_8822C)
#define BIT_CLEAR_WMAC_MU_BFEE7_AID_8822C(x) \
((x) & (~BITS_WMAC_MU_BFEE7_AID_8822C))
#define BIT_GET_WMAC_MU_BFEE7_AID_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_MU_BFEE7_AID_8822C) & \
BIT_MASK_WMAC_MU_BFEE7_AID_8822C)
#define BIT_SET_WMAC_MU_BFEE7_AID_8822C(x, v) \
(BIT_CLEAR_WMAC_MU_BFEE7_AID_8822C(x) | BIT_WMAC_MU_BFEE7_AID_8822C(v))
/* 2 REG_WMAC_BB_STOP_RX_COUNTER_8822C */
#define BIT_RST_ALL_COUNTER_8822C BIT(31)
#define BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822C 16
#define BIT_MASK_ABORT_RX_VBON_COUNTER_8822C 0xff
#define BIT_ABORT_RX_VBON_COUNTER_8822C(x) \
(((x) & BIT_MASK_ABORT_RX_VBON_COUNTER_8822C) \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822C)
#define BITS_ABORT_RX_VBON_COUNTER_8822C \
(BIT_MASK_ABORT_RX_VBON_COUNTER_8822C \
<< BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822C)
#define BIT_CLEAR_ABORT_RX_VBON_COUNTER_8822C(x) \
((x) & (~BITS_ABORT_RX_VBON_COUNTER_8822C))
#define BIT_GET_ABORT_RX_VBON_COUNTER_8822C(x) \
(((x) >> BIT_SHIFT_ABORT_RX_VBON_COUNTER_8822C) & \
BIT_MASK_ABORT_RX_VBON_COUNTER_8822C)
#define BIT_SET_ABORT_RX_VBON_COUNTER_8822C(x, v) \
(BIT_CLEAR_ABORT_RX_VBON_COUNTER_8822C(x) | \
BIT_ABORT_RX_VBON_COUNTER_8822C(v))
#define BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822C 8
#define BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822C 0xff
#define BIT_ABORT_RX_RDRDY_COUNTER_8822C(x) \
(((x) & BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822C) \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822C)
#define BITS_ABORT_RX_RDRDY_COUNTER_8822C \
(BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822C \
<< BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822C)
#define BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8822C(x) \
((x) & (~BITS_ABORT_RX_RDRDY_COUNTER_8822C))
#define BIT_GET_ABORT_RX_RDRDY_COUNTER_8822C(x) \
(((x) >> BIT_SHIFT_ABORT_RX_RDRDY_COUNTER_8822C) & \
BIT_MASK_ABORT_RX_RDRDY_COUNTER_8822C)
#define BIT_SET_ABORT_RX_RDRDY_COUNTER_8822C(x, v) \
(BIT_CLEAR_ABORT_RX_RDRDY_COUNTER_8822C(x) | \
BIT_ABORT_RX_RDRDY_COUNTER_8822C(v))
#define BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822C 0
#define BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822C 0xff
#define BIT_VBON_EARLY_FALLING_COUNTER_8822C(x) \
(((x) & BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822C) \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822C)
#define BITS_VBON_EARLY_FALLING_COUNTER_8822C \
(BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822C \
<< BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822C)
#define BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8822C(x) \
((x) & (~BITS_VBON_EARLY_FALLING_COUNTER_8822C))
#define BIT_GET_VBON_EARLY_FALLING_COUNTER_8822C(x) \
(((x) >> BIT_SHIFT_VBON_EARLY_FALLING_COUNTER_8822C) & \
BIT_MASK_VBON_EARLY_FALLING_COUNTER_8822C)
#define BIT_SET_VBON_EARLY_FALLING_COUNTER_8822C(x, v) \
(BIT_CLEAR_VBON_EARLY_FALLING_COUNTER_8822C(x) | \
BIT_VBON_EARLY_FALLING_COUNTER_8822C(v))
/* 2 REG_WMAC_PLCP_MONITOR_8822C */
#define BIT_WMAC_PLCP_TRX_SEL_8822C BIT(31)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822C 28
#define BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822C 0x7
#define BIT_WMAC_PLCP_RDSIG_SEL_8822C(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822C) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822C)
#define BITS_WMAC_PLCP_RDSIG_SEL_8822C \
(BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822C \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822C)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8822C(x) \
((x) & (~BITS_WMAC_PLCP_RDSIG_SEL_8822C))
#define BIT_GET_WMAC_PLCP_RDSIG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_SEL_8822C) & \
BIT_MASK_WMAC_PLCP_RDSIG_SEL_8822C)
#define BIT_SET_WMAC_PLCP_RDSIG_SEL_8822C(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_SEL_8822C(x) | \
BIT_WMAC_PLCP_RDSIG_SEL_8822C(v))
#define BIT_SHIFT_WMAC_RATE_IDX_8822C 24
#define BIT_MASK_WMAC_RATE_IDX_8822C 0xf
#define BIT_WMAC_RATE_IDX_8822C(x) \
(((x) & BIT_MASK_WMAC_RATE_IDX_8822C) << BIT_SHIFT_WMAC_RATE_IDX_8822C)
#define BITS_WMAC_RATE_IDX_8822C \
(BIT_MASK_WMAC_RATE_IDX_8822C << BIT_SHIFT_WMAC_RATE_IDX_8822C)
#define BIT_CLEAR_WMAC_RATE_IDX_8822C(x) ((x) & (~BITS_WMAC_RATE_IDX_8822C))
#define BIT_GET_WMAC_RATE_IDX_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_RATE_IDX_8822C) & BIT_MASK_WMAC_RATE_IDX_8822C)
#define BIT_SET_WMAC_RATE_IDX_8822C(x, v) \
(BIT_CLEAR_WMAC_RATE_IDX_8822C(x) | BIT_WMAC_RATE_IDX_8822C(v))
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8822C 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8822C 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8822C(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8822C) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8822C)
#define BITS_WMAC_PLCP_RDSIG_8822C \
(BIT_MASK_WMAC_PLCP_RDSIG_8822C << BIT_SHIFT_WMAC_PLCP_RDSIG_8822C)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8822C(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8822C))
#define BIT_GET_WMAC_PLCP_RDSIG_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8822C) & \
BIT_MASK_WMAC_PLCP_RDSIG_8822C)
#define BIT_SET_WMAC_PLCP_RDSIG_8822C(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8822C(x) | BIT_WMAC_PLCP_RDSIG_8822C(v))
/* 2 REG_WMAC_PLCP_MONITOR_MUTX_8822C */
#define BIT_WMAC_MUTX_IDX_8822C BIT(24)
#define BIT_SHIFT_WMAC_PLCP_RDSIG_8822C 0
#define BIT_MASK_WMAC_PLCP_RDSIG_8822C 0xffffff
#define BIT_WMAC_PLCP_RDSIG_8822C(x) \
(((x) & BIT_MASK_WMAC_PLCP_RDSIG_8822C) \
<< BIT_SHIFT_WMAC_PLCP_RDSIG_8822C)
#define BITS_WMAC_PLCP_RDSIG_8822C \
(BIT_MASK_WMAC_PLCP_RDSIG_8822C << BIT_SHIFT_WMAC_PLCP_RDSIG_8822C)
#define BIT_CLEAR_WMAC_PLCP_RDSIG_8822C(x) ((x) & (~BITS_WMAC_PLCP_RDSIG_8822C))
#define BIT_GET_WMAC_PLCP_RDSIG_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_PLCP_RDSIG_8822C) & \
BIT_MASK_WMAC_PLCP_RDSIG_8822C)
#define BIT_SET_WMAC_PLCP_RDSIG_8822C(x, v) \
(BIT_CLEAR_WMAC_PLCP_RDSIG_8822C(x) | BIT_WMAC_PLCP_RDSIG_8822C(v))
/* 2 REG_WMAC_CSIDMA_CFG_8822C */
#define BIT_SHIFT_CSI_SEG_SIZE_8822C 16
#define BIT_MASK_CSI_SEG_SIZE_8822C 0xfff
#define BIT_CSI_SEG_SIZE_8822C(x) \
(((x) & BIT_MASK_CSI_SEG_SIZE_8822C) << BIT_SHIFT_CSI_SEG_SIZE_8822C)
#define BITS_CSI_SEG_SIZE_8822C \
(BIT_MASK_CSI_SEG_SIZE_8822C << BIT_SHIFT_CSI_SEG_SIZE_8822C)
#define BIT_CLEAR_CSI_SEG_SIZE_8822C(x) ((x) & (~BITS_CSI_SEG_SIZE_8822C))
#define BIT_GET_CSI_SEG_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_CSI_SEG_SIZE_8822C) & BIT_MASK_CSI_SEG_SIZE_8822C)
#define BIT_SET_CSI_SEG_SIZE_8822C(x, v) \
(BIT_CLEAR_CSI_SEG_SIZE_8822C(x) | BIT_CSI_SEG_SIZE_8822C(v))
#define BIT_SHIFT_CSI_START_PAGE_8822C 0
#define BIT_MASK_CSI_START_PAGE_8822C 0xfff
#define BIT_CSI_START_PAGE_8822C(x) \
(((x) & BIT_MASK_CSI_START_PAGE_8822C) \
<< BIT_SHIFT_CSI_START_PAGE_8822C)
#define BITS_CSI_START_PAGE_8822C \
(BIT_MASK_CSI_START_PAGE_8822C << BIT_SHIFT_CSI_START_PAGE_8822C)
#define BIT_CLEAR_CSI_START_PAGE_8822C(x) ((x) & (~BITS_CSI_START_PAGE_8822C))
#define BIT_GET_CSI_START_PAGE_8822C(x) \
(((x) >> BIT_SHIFT_CSI_START_PAGE_8822C) & \
BIT_MASK_CSI_START_PAGE_8822C)
#define BIT_SET_CSI_START_PAGE_8822C(x, v) \
(BIT_CLEAR_CSI_START_PAGE_8822C(x) | BIT_CSI_START_PAGE_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_0_8822C (TA0 REGISTER) */
#define BIT_SHIFT_TA0_V1_8822C 0
#define BIT_MASK_TA0_V1_8822C 0xffffffffL
#define BIT_TA0_V1_8822C(x) \
(((x) & BIT_MASK_TA0_V1_8822C) << BIT_SHIFT_TA0_V1_8822C)
#define BITS_TA0_V1_8822C (BIT_MASK_TA0_V1_8822C << BIT_SHIFT_TA0_V1_8822C)
#define BIT_CLEAR_TA0_V1_8822C(x) ((x) & (~BITS_TA0_V1_8822C))
#define BIT_GET_TA0_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA0_V1_8822C) & BIT_MASK_TA0_V1_8822C)
#define BIT_SET_TA0_V1_8822C(x, v) \
(BIT_CLEAR_TA0_V1_8822C(x) | BIT_TA0_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_0_H_8822C (TA0 REGISTER) */
#define BIT_SHIFT_TA0_H_V1_8822C 0
#define BIT_MASK_TA0_H_V1_8822C 0xffff
#define BIT_TA0_H_V1_8822C(x) \
(((x) & BIT_MASK_TA0_H_V1_8822C) << BIT_SHIFT_TA0_H_V1_8822C)
#define BITS_TA0_H_V1_8822C \
(BIT_MASK_TA0_H_V1_8822C << BIT_SHIFT_TA0_H_V1_8822C)
#define BIT_CLEAR_TA0_H_V1_8822C(x) ((x) & (~BITS_TA0_H_V1_8822C))
#define BIT_GET_TA0_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA0_H_V1_8822C) & BIT_MASK_TA0_H_V1_8822C)
#define BIT_SET_TA0_H_V1_8822C(x, v) \
(BIT_CLEAR_TA0_H_V1_8822C(x) | BIT_TA0_H_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_1_8822C (TA1 REGISTER) */
#define BIT_SHIFT_TA1_V1_8822C 0
#define BIT_MASK_TA1_V1_8822C 0xffffffffL
#define BIT_TA1_V1_8822C(x) \
(((x) & BIT_MASK_TA1_V1_8822C) << BIT_SHIFT_TA1_V1_8822C)
#define BITS_TA1_V1_8822C (BIT_MASK_TA1_V1_8822C << BIT_SHIFT_TA1_V1_8822C)
#define BIT_CLEAR_TA1_V1_8822C(x) ((x) & (~BITS_TA1_V1_8822C))
#define BIT_GET_TA1_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA1_V1_8822C) & BIT_MASK_TA1_V1_8822C)
#define BIT_SET_TA1_V1_8822C(x, v) \
(BIT_CLEAR_TA1_V1_8822C(x) | BIT_TA1_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_1_H_8822C (TA1 REGISTER) */
#define BIT_SHIFT_TA1_H_V1_8822C 0
#define BIT_MASK_TA1_H_V1_8822C 0xffff
#define BIT_TA1_H_V1_8822C(x) \
(((x) & BIT_MASK_TA1_H_V1_8822C) << BIT_SHIFT_TA1_H_V1_8822C)
#define BITS_TA1_H_V1_8822C \
(BIT_MASK_TA1_H_V1_8822C << BIT_SHIFT_TA1_H_V1_8822C)
#define BIT_CLEAR_TA1_H_V1_8822C(x) ((x) & (~BITS_TA1_H_V1_8822C))
#define BIT_GET_TA1_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA1_H_V1_8822C) & BIT_MASK_TA1_H_V1_8822C)
#define BIT_SET_TA1_H_V1_8822C(x, v) \
(BIT_CLEAR_TA1_H_V1_8822C(x) | BIT_TA1_H_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_2_8822C (TA2 REGISTER) */
#define BIT_SHIFT_TA2_V1_8822C 0
#define BIT_MASK_TA2_V1_8822C 0xffffffffL
#define BIT_TA2_V1_8822C(x) \
(((x) & BIT_MASK_TA2_V1_8822C) << BIT_SHIFT_TA2_V1_8822C)
#define BITS_TA2_V1_8822C (BIT_MASK_TA2_V1_8822C << BIT_SHIFT_TA2_V1_8822C)
#define BIT_CLEAR_TA2_V1_8822C(x) ((x) & (~BITS_TA2_V1_8822C))
#define BIT_GET_TA2_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA2_V1_8822C) & BIT_MASK_TA2_V1_8822C)
#define BIT_SET_TA2_V1_8822C(x, v) \
(BIT_CLEAR_TA2_V1_8822C(x) | BIT_TA2_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_2_H_8822C (TA2 REGISTER) */
#define BIT_SHIFT_TA2_H_V1_8822C 0
#define BIT_MASK_TA2_H_V1_8822C 0xffff
#define BIT_TA2_H_V1_8822C(x) \
(((x) & BIT_MASK_TA2_H_V1_8822C) << BIT_SHIFT_TA2_H_V1_8822C)
#define BITS_TA2_H_V1_8822C \
(BIT_MASK_TA2_H_V1_8822C << BIT_SHIFT_TA2_H_V1_8822C)
#define BIT_CLEAR_TA2_H_V1_8822C(x) ((x) & (~BITS_TA2_H_V1_8822C))
#define BIT_GET_TA2_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA2_H_V1_8822C) & BIT_MASK_TA2_H_V1_8822C)
#define BIT_SET_TA2_H_V1_8822C(x, v) \
(BIT_CLEAR_TA2_H_V1_8822C(x) | BIT_TA2_H_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_3_8822C (TA3 REGISTER) */
#define BIT_SHIFT_TA2_V1_8822C 0
#define BIT_MASK_TA2_V1_8822C 0xffffffffL
#define BIT_TA2_V1_8822C(x) \
(((x) & BIT_MASK_TA2_V1_8822C) << BIT_SHIFT_TA2_V1_8822C)
#define BITS_TA2_V1_8822C (BIT_MASK_TA2_V1_8822C << BIT_SHIFT_TA2_V1_8822C)
#define BIT_CLEAR_TA2_V1_8822C(x) ((x) & (~BITS_TA2_V1_8822C))
#define BIT_GET_TA2_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA2_V1_8822C) & BIT_MASK_TA2_V1_8822C)
#define BIT_SET_TA2_V1_8822C(x, v) \
(BIT_CLEAR_TA2_V1_8822C(x) | BIT_TA2_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_3_H_8822C (TA3 REGISTER) */
#define BIT_SHIFT_TA3_H_V1_8822C 0
#define BIT_MASK_TA3_H_V1_8822C 0xffff
#define BIT_TA3_H_V1_8822C(x) \
(((x) & BIT_MASK_TA3_H_V1_8822C) << BIT_SHIFT_TA3_H_V1_8822C)
#define BITS_TA3_H_V1_8822C \
(BIT_MASK_TA3_H_V1_8822C << BIT_SHIFT_TA3_H_V1_8822C)
#define BIT_CLEAR_TA3_H_V1_8822C(x) ((x) & (~BITS_TA3_H_V1_8822C))
#define BIT_GET_TA3_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA3_H_V1_8822C) & BIT_MASK_TA3_H_V1_8822C)
#define BIT_SET_TA3_H_V1_8822C(x, v) \
(BIT_CLEAR_TA3_H_V1_8822C(x) | BIT_TA3_H_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_4_8822C (TA4 REGISTER) */
#define BIT_SHIFT_TA4_V1_8822C 0
#define BIT_MASK_TA4_V1_8822C 0xffffffffL
#define BIT_TA4_V1_8822C(x) \
(((x) & BIT_MASK_TA4_V1_8822C) << BIT_SHIFT_TA4_V1_8822C)
#define BITS_TA4_V1_8822C (BIT_MASK_TA4_V1_8822C << BIT_SHIFT_TA4_V1_8822C)
#define BIT_CLEAR_TA4_V1_8822C(x) ((x) & (~BITS_TA4_V1_8822C))
#define BIT_GET_TA4_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA4_V1_8822C) & BIT_MASK_TA4_V1_8822C)
#define BIT_SET_TA4_V1_8822C(x, v) \
(BIT_CLEAR_TA4_V1_8822C(x) | BIT_TA4_V1_8822C(v))
/* 2 REG_TRANSMIT_ADDRSS_4_H_8822C (TA4 REGISTER) */
#define BIT_SHIFT_TA4_H_V1_8822C 0
#define BIT_MASK_TA4_H_V1_8822C 0xffff
#define BIT_TA4_H_V1_8822C(x) \
(((x) & BIT_MASK_TA4_H_V1_8822C) << BIT_SHIFT_TA4_H_V1_8822C)
#define BITS_TA4_H_V1_8822C \
(BIT_MASK_TA4_H_V1_8822C << BIT_SHIFT_TA4_H_V1_8822C)
#define BIT_CLEAR_TA4_H_V1_8822C(x) ((x) & (~BITS_TA4_H_V1_8822C))
#define BIT_GET_TA4_H_V1_8822C(x) \
(((x) >> BIT_SHIFT_TA4_H_V1_8822C) & BIT_MASK_TA4_H_V1_8822C)
#define BIT_SET_TA4_H_V1_8822C(x, v) \
(BIT_CLEAR_TA4_H_V1_8822C(x) | BIT_TA4_H_V1_8822C(v))
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_RSVD_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_MACID1_8822C */
#define BIT_SHIFT_MACID1_0_8822C 0
#define BIT_MASK_MACID1_0_8822C 0xffffffffL
#define BIT_MACID1_0_8822C(x) \
(((x) & BIT_MASK_MACID1_0_8822C) << BIT_SHIFT_MACID1_0_8822C)
#define BITS_MACID1_0_8822C \
(BIT_MASK_MACID1_0_8822C << BIT_SHIFT_MACID1_0_8822C)
#define BIT_CLEAR_MACID1_0_8822C(x) ((x) & (~BITS_MACID1_0_8822C))
#define BIT_GET_MACID1_0_8822C(x) \
(((x) >> BIT_SHIFT_MACID1_0_8822C) & BIT_MASK_MACID1_0_8822C)
#define BIT_SET_MACID1_0_8822C(x, v) \
(BIT_CLEAR_MACID1_0_8822C(x) | BIT_MACID1_0_8822C(v))
/* 2 REG_MACID1_1_8822C */
#define BIT_SHIFT_MACID1_1_8822C 0
#define BIT_MASK_MACID1_1_8822C 0xffff
#define BIT_MACID1_1_8822C(x) \
(((x) & BIT_MASK_MACID1_1_8822C) << BIT_SHIFT_MACID1_1_8822C)
#define BITS_MACID1_1_8822C \
(BIT_MASK_MACID1_1_8822C << BIT_SHIFT_MACID1_1_8822C)
#define BIT_CLEAR_MACID1_1_8822C(x) ((x) & (~BITS_MACID1_1_8822C))
#define BIT_GET_MACID1_1_8822C(x) \
(((x) >> BIT_SHIFT_MACID1_1_8822C) & BIT_MASK_MACID1_1_8822C)
#define BIT_SET_MACID1_1_8822C(x, v) \
(BIT_CLEAR_MACID1_1_8822C(x) | BIT_MACID1_1_8822C(v))
/* 2 REG_BSSID1_8822C */
#define BIT_SHIFT_BSSID1_0_8822C 0
#define BIT_MASK_BSSID1_0_8822C 0xffffffffL
#define BIT_BSSID1_0_8822C(x) \
(((x) & BIT_MASK_BSSID1_0_8822C) << BIT_SHIFT_BSSID1_0_8822C)
#define BITS_BSSID1_0_8822C \
(BIT_MASK_BSSID1_0_8822C << BIT_SHIFT_BSSID1_0_8822C)
#define BIT_CLEAR_BSSID1_0_8822C(x) ((x) & (~BITS_BSSID1_0_8822C))
#define BIT_GET_BSSID1_0_8822C(x) \
(((x) >> BIT_SHIFT_BSSID1_0_8822C) & BIT_MASK_BSSID1_0_8822C)
#define BIT_SET_BSSID1_0_8822C(x, v) \
(BIT_CLEAR_BSSID1_0_8822C(x) | BIT_BSSID1_0_8822C(v))
/* 2 REG_BSSID1_1_8822C */
#define BIT_SHIFT_BSSID1_1_8822C 0
#define BIT_MASK_BSSID1_1_8822C 0xffff
#define BIT_BSSID1_1_8822C(x) \
(((x) & BIT_MASK_BSSID1_1_8822C) << BIT_SHIFT_BSSID1_1_8822C)
#define BITS_BSSID1_1_8822C \
(BIT_MASK_BSSID1_1_8822C << BIT_SHIFT_BSSID1_1_8822C)
#define BIT_CLEAR_BSSID1_1_8822C(x) ((x) & (~BITS_BSSID1_1_8822C))
#define BIT_GET_BSSID1_1_8822C(x) \
(((x) >> BIT_SHIFT_BSSID1_1_8822C) & BIT_MASK_BSSID1_1_8822C)
#define BIT_SET_BSSID1_1_8822C(x, v) \
(BIT_CLEAR_BSSID1_1_8822C(x) | BIT_BSSID1_1_8822C(v))
/* 2 REG_BCN_PSR_RPT1_8822C */
#define BIT_SHIFT_DTIM_CNT1_8822C 24
#define BIT_MASK_DTIM_CNT1_8822C 0xff
#define BIT_DTIM_CNT1_8822C(x) \
(((x) & BIT_MASK_DTIM_CNT1_8822C) << BIT_SHIFT_DTIM_CNT1_8822C)
#define BITS_DTIM_CNT1_8822C \
(BIT_MASK_DTIM_CNT1_8822C << BIT_SHIFT_DTIM_CNT1_8822C)
#define BIT_CLEAR_DTIM_CNT1_8822C(x) ((x) & (~BITS_DTIM_CNT1_8822C))
#define BIT_GET_DTIM_CNT1_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_CNT1_8822C) & BIT_MASK_DTIM_CNT1_8822C)
#define BIT_SET_DTIM_CNT1_8822C(x, v) \
(BIT_CLEAR_DTIM_CNT1_8822C(x) | BIT_DTIM_CNT1_8822C(v))
#define BIT_SHIFT_DTIM_PERIOD1_8822C 16
#define BIT_MASK_DTIM_PERIOD1_8822C 0xff
#define BIT_DTIM_PERIOD1_8822C(x) \
(((x) & BIT_MASK_DTIM_PERIOD1_8822C) << BIT_SHIFT_DTIM_PERIOD1_8822C)
#define BITS_DTIM_PERIOD1_8822C \
(BIT_MASK_DTIM_PERIOD1_8822C << BIT_SHIFT_DTIM_PERIOD1_8822C)
#define BIT_CLEAR_DTIM_PERIOD1_8822C(x) ((x) & (~BITS_DTIM_PERIOD1_8822C))
#define BIT_GET_DTIM_PERIOD1_8822C(x) \
(((x) >> BIT_SHIFT_DTIM_PERIOD1_8822C) & BIT_MASK_DTIM_PERIOD1_8822C)
#define BIT_SET_DTIM_PERIOD1_8822C(x, v) \
(BIT_CLEAR_DTIM_PERIOD1_8822C(x) | BIT_DTIM_PERIOD1_8822C(v))
#define BIT_DTIM1_8822C BIT(15)
#define BIT_TIM1_8822C BIT(14)
#define BIT_BCN_VALID_V2_8822C BIT(13)
#define BIT_SHIFT_PS_AID_1_8822C 0
#define BIT_MASK_PS_AID_1_8822C 0x7ff
#define BIT_PS_AID_1_8822C(x) \
(((x) & BIT_MASK_PS_AID_1_8822C) << BIT_SHIFT_PS_AID_1_8822C)
#define BITS_PS_AID_1_8822C \
(BIT_MASK_PS_AID_1_8822C << BIT_SHIFT_PS_AID_1_8822C)
#define BIT_CLEAR_PS_AID_1_8822C(x) ((x) & (~BITS_PS_AID_1_8822C))
#define BIT_GET_PS_AID_1_8822C(x) \
(((x) >> BIT_SHIFT_PS_AID_1_8822C) & BIT_MASK_PS_AID_1_8822C)
#define BIT_SET_PS_AID_1_8822C(x, v) \
(BIT_CLEAR_PS_AID_1_8822C(x) | BIT_PS_AID_1_8822C(v))
/* 2 REG_ASSOCIATED_BFMEE_SEL_8822C */
#define BIT_TXUSER_ID1_8822C BIT(25)
#define BIT_SHIFT_AID1_8822C 16
#define BIT_MASK_AID1_8822C 0x1ff
#define BIT_AID1_8822C(x) (((x) & BIT_MASK_AID1_8822C) << BIT_SHIFT_AID1_8822C)
#define BITS_AID1_8822C (BIT_MASK_AID1_8822C << BIT_SHIFT_AID1_8822C)
#define BIT_CLEAR_AID1_8822C(x) ((x) & (~BITS_AID1_8822C))
#define BIT_GET_AID1_8822C(x) \
(((x) >> BIT_SHIFT_AID1_8822C) & BIT_MASK_AID1_8822C)
#define BIT_SET_AID1_8822C(x, v) (BIT_CLEAR_AID1_8822C(x) | BIT_AID1_8822C(v))
#define BIT_TXUSER_ID0_8822C BIT(9)
#define BIT_SHIFT_AID0_8822C 0
#define BIT_MASK_AID0_8822C 0x1ff
#define BIT_AID0_8822C(x) (((x) & BIT_MASK_AID0_8822C) << BIT_SHIFT_AID0_8822C)
#define BITS_AID0_8822C (BIT_MASK_AID0_8822C << BIT_SHIFT_AID0_8822C)
#define BIT_CLEAR_AID0_8822C(x) ((x) & (~BITS_AID0_8822C))
#define BIT_GET_AID0_8822C(x) \
(((x) >> BIT_SHIFT_AID0_8822C) & BIT_MASK_AID0_8822C)
#define BIT_SET_AID0_8822C(x, v) (BIT_CLEAR_AID0_8822C(x) | BIT_AID0_8822C(v))
/* 2 REG_SND_PTCL_CTRL_8822C */
#define BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822C 24
#define BIT_MASK_NDP_RX_STANDBY_TIMER_8822C 0xff
#define BIT_NDP_RX_STANDBY_TIMER_8822C(x) \
(((x) & BIT_MASK_NDP_RX_STANDBY_TIMER_8822C) \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822C)
#define BITS_NDP_RX_STANDBY_TIMER_8822C \
(BIT_MASK_NDP_RX_STANDBY_TIMER_8822C \
<< BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822C)
#define BIT_CLEAR_NDP_RX_STANDBY_TIMER_8822C(x) \
((x) & (~BITS_NDP_RX_STANDBY_TIMER_8822C))
#define BIT_GET_NDP_RX_STANDBY_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_NDP_RX_STANDBY_TIMER_8822C) & \
BIT_MASK_NDP_RX_STANDBY_TIMER_8822C)
#define BIT_SET_NDP_RX_STANDBY_TIMER_8822C(x, v) \
(BIT_CLEAR_NDP_RX_STANDBY_TIMER_8822C(x) | \
BIT_NDP_RX_STANDBY_TIMER_8822C(v))
#define BIT_R_WMAC_CHK_RPTPOLL_A2_DIS_8822C BIT(23)
#define BIT_R_WMAC_CHK_UCNDPA_A2_DIS_8822C BIT(22)
#define BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822C 16
#define BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822C 0x3f
#define BIT_CSI_RPT_OFFSET_HT_V1_8822C(x) \
(((x) & BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822C) \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822C)
#define BITS_CSI_RPT_OFFSET_HT_V1_8822C \
(BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822C \
<< BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822C)
#define BIT_CLEAR_CSI_RPT_OFFSET_HT_V1_8822C(x) \
((x) & (~BITS_CSI_RPT_OFFSET_HT_V1_8822C))
#define BIT_GET_CSI_RPT_OFFSET_HT_V1_8822C(x) \
(((x) >> BIT_SHIFT_CSI_RPT_OFFSET_HT_V1_8822C) & \
BIT_MASK_CSI_RPT_OFFSET_HT_V1_8822C)
#define BIT_SET_CSI_RPT_OFFSET_HT_V1_8822C(x, v) \
(BIT_CLEAR_CSI_RPT_OFFSET_HT_V1_8822C(x) | \
BIT_CSI_RPT_OFFSET_HT_V1_8822C(v))
#define BIT_R_WMAC_OFFSET_RPTPOLL_EN_8822C BIT(15)
#define BIT_R_WMAC_CSI_CHKSUM_DIS_8822C BIT(14)
#define BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1_8822C 8
#define BIT_MASK_R_WMAC_VHT_CATEGORY_V1_8822C 0x3f
#define BIT_R_WMAC_VHT_CATEGORY_V1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_VHT_CATEGORY_V1_8822C) \
<< BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1_8822C)
#define BITS_R_WMAC_VHT_CATEGORY_V1_8822C \
(BIT_MASK_R_WMAC_VHT_CATEGORY_V1_8822C \
<< BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1_8822C)
#define BIT_CLEAR_R_WMAC_VHT_CATEGORY_V1_8822C(x) \
((x) & (~BITS_R_WMAC_VHT_CATEGORY_V1_8822C))
#define BIT_GET_R_WMAC_VHT_CATEGORY_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_VHT_CATEGORY_V1_8822C) & \
BIT_MASK_R_WMAC_VHT_CATEGORY_V1_8822C)
#define BIT_SET_R_WMAC_VHT_CATEGORY_V1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_VHT_CATEGORY_V1_8822C(x) | \
BIT_R_WMAC_VHT_CATEGORY_V1_8822C(v))
#define BIT_R_WMAC_USE_NSTS_8822C BIT(7)
#define BIT_R_DISABLE_CHECK_VHTSIGB_CRC_8822C BIT(6)
#define BIT_R_DISABLE_CHECK_VHTSIGA_CRC_8822C BIT(5)
#define BIT_R_WMAC_BFPARAM_SEL_8822C BIT(4)
#define BIT_R_WMAC_CSISEQ_SEL_8822C BIT(3)
#define BIT_R_WMAC_CSI_WITHHTC_EN_8822C BIT(2)
#define BIT_R_WMAC_HT_NDPA_EN_8822C BIT(1)
#define BIT_R_WMAC_VHT_NDPA_EN_8822C BIT(0)
/* 2 REG_RX_CSI_RPT_INFO_8822C */
#define BIT_WRITE_ENABLE_8822C BIT(31)
#define BIT_WMAC_CHECK_SOUNDING_SEQ_8822C BIT(30)
#define BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8822C 1
#define BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8822C 0xffffff
#define BIT_VHTHT_MIMO_CTRL_FIELD_8822C(x) \
(((x) & BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8822C) \
<< BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8822C)
#define BITS_VHTHT_MIMO_CTRL_FIELD_8822C \
(BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8822C \
<< BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8822C)
#define BIT_CLEAR_VHTHT_MIMO_CTRL_FIELD_8822C(x) \
((x) & (~BITS_VHTHT_MIMO_CTRL_FIELD_8822C))
#define BIT_GET_VHTHT_MIMO_CTRL_FIELD_8822C(x) \
(((x) >> BIT_SHIFT_VHTHT_MIMO_CTRL_FIELD_8822C) & \
BIT_MASK_VHTHT_MIMO_CTRL_FIELD_8822C)
#define BIT_SET_VHTHT_MIMO_CTRL_FIELD_8822C(x, v) \
(BIT_CLEAR_VHTHT_MIMO_CTRL_FIELD_8822C(x) | \
BIT_VHTHT_MIMO_CTRL_FIELD_8822C(v))
#define BIT_CSI_INTERRUPT_STATUS_8822C BIT(0)
/* 2 REG_NS_ARP_CTRL_8822C */
#define BIT_R_WMAC_NSARP_RSPEN_8822C BIT(15)
#define BIT_R_WMAC_NSARP_RARP_8822C BIT(9)
#define BIT_R_WMAC_NSARP_RIPV6_8822C BIT(8)
#define BIT_SHIFT_R_WMAC_NSARP_MODEN_8822C 6
#define BIT_MASK_R_WMAC_NSARP_MODEN_8822C 0x3
#define BIT_R_WMAC_NSARP_MODEN_8822C(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_MODEN_8822C) \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8822C)
#define BITS_R_WMAC_NSARP_MODEN_8822C \
(BIT_MASK_R_WMAC_NSARP_MODEN_8822C \
<< BIT_SHIFT_R_WMAC_NSARP_MODEN_8822C)
#define BIT_CLEAR_R_WMAC_NSARP_MODEN_8822C(x) \
((x) & (~BITS_R_WMAC_NSARP_MODEN_8822C))
#define BIT_GET_R_WMAC_NSARP_MODEN_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_MODEN_8822C) & \
BIT_MASK_R_WMAC_NSARP_MODEN_8822C)
#define BIT_SET_R_WMAC_NSARP_MODEN_8822C(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_MODEN_8822C(x) | \
BIT_R_WMAC_NSARP_MODEN_8822C(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822C 4
#define BIT_MASK_R_WMAC_NSARP_RSPFTP_8822C 0x3
#define BIT_R_WMAC_NSARP_RSPFTP_8822C(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPFTP_8822C) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822C)
#define BITS_R_WMAC_NSARP_RSPFTP_8822C \
(BIT_MASK_R_WMAC_NSARP_RSPFTP_8822C \
<< BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822C)
#define BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8822C(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPFTP_8822C))
#define BIT_GET_R_WMAC_NSARP_RSPFTP_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPFTP_8822C) & \
BIT_MASK_R_WMAC_NSARP_RSPFTP_8822C)
#define BIT_SET_R_WMAC_NSARP_RSPFTP_8822C(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPFTP_8822C(x) | \
BIT_R_WMAC_NSARP_RSPFTP_8822C(v))
#define BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822C 0
#define BIT_MASK_R_WMAC_NSARP_RSPSEC_8822C 0xf
#define BIT_R_WMAC_NSARP_RSPSEC_8822C(x) \
(((x) & BIT_MASK_R_WMAC_NSARP_RSPSEC_8822C) \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822C)
#define BITS_R_WMAC_NSARP_RSPSEC_8822C \
(BIT_MASK_R_WMAC_NSARP_RSPSEC_8822C \
<< BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822C)
#define BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8822C(x) \
((x) & (~BITS_R_WMAC_NSARP_RSPSEC_8822C))
#define BIT_GET_R_WMAC_NSARP_RSPSEC_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_NSARP_RSPSEC_8822C) & \
BIT_MASK_R_WMAC_NSARP_RSPSEC_8822C)
#define BIT_SET_R_WMAC_NSARP_RSPSEC_8822C(x, v) \
(BIT_CLEAR_R_WMAC_NSARP_RSPSEC_8822C(x) | \
BIT_R_WMAC_NSARP_RSPSEC_8822C(v))
/* 2 REG_NS_ARP_INFO_8822C */
#define BIT_REQ_IS_MCNS_8822C BIT(23)
#define BIT_REQ_IS_UCNS_8822C BIT(22)
#define BIT_REQ_IS_USNS_8822C BIT(21)
#define BIT_REQ_IS_ARP_8822C BIT(20)
#define BIT_EXPRSP_MH_WITHQC_8822C BIT(19)
#define BIT_SHIFT_EXPRSP_SECTYPE_8822C 16
#define BIT_MASK_EXPRSP_SECTYPE_8822C 0x7
#define BIT_EXPRSP_SECTYPE_8822C(x) \
(((x) & BIT_MASK_EXPRSP_SECTYPE_8822C) \
<< BIT_SHIFT_EXPRSP_SECTYPE_8822C)
#define BITS_EXPRSP_SECTYPE_8822C \
(BIT_MASK_EXPRSP_SECTYPE_8822C << BIT_SHIFT_EXPRSP_SECTYPE_8822C)
#define BIT_CLEAR_EXPRSP_SECTYPE_8822C(x) ((x) & (~BITS_EXPRSP_SECTYPE_8822C))
#define BIT_GET_EXPRSP_SECTYPE_8822C(x) \
(((x) >> BIT_SHIFT_EXPRSP_SECTYPE_8822C) & \
BIT_MASK_EXPRSP_SECTYPE_8822C)
#define BIT_SET_EXPRSP_SECTYPE_8822C(x, v) \
(BIT_CLEAR_EXPRSP_SECTYPE_8822C(x) | BIT_EXPRSP_SECTYPE_8822C(v))
#define BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822C 8
#define BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822C 0xff
#define BIT_EXPRSP_CHKSM_7_TO_0_8822C(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822C) \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822C)
#define BITS_EXPRSP_CHKSM_7_TO_0_8822C \
(BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822C \
<< BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822C)
#define BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8822C(x) \
((x) & (~BITS_EXPRSP_CHKSM_7_TO_0_8822C))
#define BIT_GET_EXPRSP_CHKSM_7_TO_0_8822C(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_7_TO_0_8822C) & \
BIT_MASK_EXPRSP_CHKSM_7_TO_0_8822C)
#define BIT_SET_EXPRSP_CHKSM_7_TO_0_8822C(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_7_TO_0_8822C(x) | \
BIT_EXPRSP_CHKSM_7_TO_0_8822C(v))
#define BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822C 0
#define BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822C 0xff
#define BIT_EXPRSP_CHKSM_15_TO_8_8822C(x) \
(((x) & BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822C) \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822C)
#define BITS_EXPRSP_CHKSM_15_TO_8_8822C \
(BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822C \
<< BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822C)
#define BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8822C(x) \
((x) & (~BITS_EXPRSP_CHKSM_15_TO_8_8822C))
#define BIT_GET_EXPRSP_CHKSM_15_TO_8_8822C(x) \
(((x) >> BIT_SHIFT_EXPRSP_CHKSM_15_TO_8_8822C) & \
BIT_MASK_EXPRSP_CHKSM_15_TO_8_8822C)
#define BIT_SET_EXPRSP_CHKSM_15_TO_8_8822C(x, v) \
(BIT_CLEAR_EXPRSP_CHKSM_15_TO_8_8822C(x) | \
BIT_EXPRSP_CHKSM_15_TO_8_8822C(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_V1_8822C */
#define BIT_SHIFT_WMAC_ARPIP_8822C 0
#define BIT_MASK_WMAC_ARPIP_8822C 0xffffffffL
#define BIT_WMAC_ARPIP_8822C(x) \
(((x) & BIT_MASK_WMAC_ARPIP_8822C) << BIT_SHIFT_WMAC_ARPIP_8822C)
#define BITS_WMAC_ARPIP_8822C \
(BIT_MASK_WMAC_ARPIP_8822C << BIT_SHIFT_WMAC_ARPIP_8822C)
#define BIT_CLEAR_WMAC_ARPIP_8822C(x) ((x) & (~BITS_WMAC_ARPIP_8822C))
#define BIT_GET_WMAC_ARPIP_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_ARPIP_8822C) & BIT_MASK_WMAC_ARPIP_8822C)
#define BIT_SET_WMAC_ARPIP_8822C(x, v) \
(BIT_CLEAR_WMAC_ARPIP_8822C(x) | BIT_WMAC_ARPIP_8822C(v))
/* 2 REG_BEAMFORMING_INFO_NSARP_8822C */
#define BIT_SHIFT_UPD_BFMEE_USERID_8822C 13
#define BIT_MASK_UPD_BFMEE_USERID_8822C 0x7
#define BIT_UPD_BFMEE_USERID_8822C(x) \
(((x) & BIT_MASK_UPD_BFMEE_USERID_8822C) \
<< BIT_SHIFT_UPD_BFMEE_USERID_8822C)
#define BITS_UPD_BFMEE_USERID_8822C \
(BIT_MASK_UPD_BFMEE_USERID_8822C << BIT_SHIFT_UPD_BFMEE_USERID_8822C)
#define BIT_CLEAR_UPD_BFMEE_USERID_8822C(x) \
((x) & (~BITS_UPD_BFMEE_USERID_8822C))
#define BIT_GET_UPD_BFMEE_USERID_8822C(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_USERID_8822C) & \
BIT_MASK_UPD_BFMEE_USERID_8822C)
#define BIT_SET_UPD_BFMEE_USERID_8822C(x, v) \
(BIT_CLEAR_UPD_BFMEE_USERID_8822C(x) | BIT_UPD_BFMEE_USERID_8822C(v))
#define BIT_UPD_BFMEE_FBTP_8822C BIT(12)
#define BIT_SHIFT_UPD_BFMEE_BW_8822C 0
#define BIT_MASK_UPD_BFMEE_BW_8822C 0xfff
#define BIT_UPD_BFMEE_BW_8822C(x) \
(((x) & BIT_MASK_UPD_BFMEE_BW_8822C) << BIT_SHIFT_UPD_BFMEE_BW_8822C)
#define BITS_UPD_BFMEE_BW_8822C \
(BIT_MASK_UPD_BFMEE_BW_8822C << BIT_SHIFT_UPD_BFMEE_BW_8822C)
#define BIT_CLEAR_UPD_BFMEE_BW_8822C(x) ((x) & (~BITS_UPD_BFMEE_BW_8822C))
#define BIT_GET_UPD_BFMEE_BW_8822C(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_BW_8822C) & BIT_MASK_UPD_BFMEE_BW_8822C)
#define BIT_SET_UPD_BFMEE_BW_8822C(x, v) \
(BIT_CLEAR_UPD_BFMEE_BW_8822C(x) | BIT_UPD_BFMEE_BW_8822C(v))
#define BIT_SHIFT_UPD_BFMEE_CB_8822C 8
#define BIT_MASK_UPD_BFMEE_CB_8822C 0x3
#define BIT_UPD_BFMEE_CB_8822C(x) \
(((x) & BIT_MASK_UPD_BFMEE_CB_8822C) << BIT_SHIFT_UPD_BFMEE_CB_8822C)
#define BITS_UPD_BFMEE_CB_8822C \
(BIT_MASK_UPD_BFMEE_CB_8822C << BIT_SHIFT_UPD_BFMEE_CB_8822C)
#define BIT_CLEAR_UPD_BFMEE_CB_8822C(x) ((x) & (~BITS_UPD_BFMEE_CB_8822C))
#define BIT_GET_UPD_BFMEE_CB_8822C(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_CB_8822C) & BIT_MASK_UPD_BFMEE_CB_8822C)
#define BIT_SET_UPD_BFMEE_CB_8822C(x, v) \
(BIT_CLEAR_UPD_BFMEE_CB_8822C(x) | BIT_UPD_BFMEE_CB_8822C(v))
#define BIT_SHIFT_UPD_BFMEE_NG_8822C 6
#define BIT_MASK_UPD_BFMEE_NG_8822C 0x3
#define BIT_UPD_BFMEE_NG_8822C(x) \
(((x) & BIT_MASK_UPD_BFMEE_NG_8822C) << BIT_SHIFT_UPD_BFMEE_NG_8822C)
#define BITS_UPD_BFMEE_NG_8822C \
(BIT_MASK_UPD_BFMEE_NG_8822C << BIT_SHIFT_UPD_BFMEE_NG_8822C)
#define BIT_CLEAR_UPD_BFMEE_NG_8822C(x) ((x) & (~BITS_UPD_BFMEE_NG_8822C))
#define BIT_GET_UPD_BFMEE_NG_8822C(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_NG_8822C) & BIT_MASK_UPD_BFMEE_NG_8822C)
#define BIT_SET_UPD_BFMEE_NG_8822C(x, v) \
(BIT_CLEAR_UPD_BFMEE_NG_8822C(x) | BIT_UPD_BFMEE_NG_8822C(v))
#define BIT_SHIFT_UPD_BFMEE_NR_8822C 3
#define BIT_MASK_UPD_BFMEE_NR_8822C 0x7
#define BIT_UPD_BFMEE_NR_8822C(x) \
(((x) & BIT_MASK_UPD_BFMEE_NR_8822C) << BIT_SHIFT_UPD_BFMEE_NR_8822C)
#define BITS_UPD_BFMEE_NR_8822C \
(BIT_MASK_UPD_BFMEE_NR_8822C << BIT_SHIFT_UPD_BFMEE_NR_8822C)
#define BIT_CLEAR_UPD_BFMEE_NR_8822C(x) ((x) & (~BITS_UPD_BFMEE_NR_8822C))
#define BIT_GET_UPD_BFMEE_NR_8822C(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_NR_8822C) & BIT_MASK_UPD_BFMEE_NR_8822C)
#define BIT_SET_UPD_BFMEE_NR_8822C(x, v) \
(BIT_CLEAR_UPD_BFMEE_NR_8822C(x) | BIT_UPD_BFMEE_NR_8822C(v))
#define BIT_SHIFT_UPD_BFMEE_NC_8822C 0
#define BIT_MASK_UPD_BFMEE_NC_8822C 0x7
#define BIT_UPD_BFMEE_NC_8822C(x) \
(((x) & BIT_MASK_UPD_BFMEE_NC_8822C) << BIT_SHIFT_UPD_BFMEE_NC_8822C)
#define BITS_UPD_BFMEE_NC_8822C \
(BIT_MASK_UPD_BFMEE_NC_8822C << BIT_SHIFT_UPD_BFMEE_NC_8822C)
#define BIT_CLEAR_UPD_BFMEE_NC_8822C(x) ((x) & (~BITS_UPD_BFMEE_NC_8822C))
#define BIT_GET_UPD_BFMEE_NC_8822C(x) \
(((x) >> BIT_SHIFT_UPD_BFMEE_NC_8822C) & BIT_MASK_UPD_BFMEE_NC_8822C)
#define BIT_SET_UPD_BFMEE_NC_8822C(x, v) \
(BIT_CLEAR_UPD_BFMEE_NC_8822C(x) | BIT_UPD_BFMEE_NC_8822C(v))
/* 2 REG_IPV6_8822C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8822C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8822C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_0_8822C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8822C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8822C)
#define BITS_R_WMAC_IPV6_MYIPAD_0_8822C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8822C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8822C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0_8822C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_0_8822C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_0_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_0_8822C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_0_8822C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_0_8822C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_0_8822C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_0_8822C(v))
/* 2 REG_IPV6_1_8822C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8822C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8822C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8822C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8822C)
#define BITS_R_WMAC_IPV6_MYIPAD_1_8822C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8822C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8822C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1_8822C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_1_8822C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_1_8822C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_1_8822C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_1_8822C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_1_8822C(v))
/* 2 REG_IPV6_2_8822C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8822C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8822C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_2_8822C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8822C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8822C)
#define BITS_R_WMAC_IPV6_MYIPAD_2_8822C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8822C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8822C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2_8822C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_2_8822C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_2_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_2_8822C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_2_8822C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_2_8822C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_2_8822C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_2_8822C(v))
/* 2 REG_IPV6_3_8822C */
#define BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8822C 0
#define BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8822C 0xffffffffL
#define BIT_R_WMAC_IPV6_MYIPAD_3_8822C(x) \
(((x) & BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8822C) \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8822C)
#define BITS_R_WMAC_IPV6_MYIPAD_3_8822C \
(BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8822C \
<< BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8822C)
#define BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3_8822C(x) \
((x) & (~BITS_R_WMAC_IPV6_MYIPAD_3_8822C))
#define BIT_GET_R_WMAC_IPV6_MYIPAD_3_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_IPV6_MYIPAD_3_8822C) & \
BIT_MASK_R_WMAC_IPV6_MYIPAD_3_8822C)
#define BIT_SET_R_WMAC_IPV6_MYIPAD_3_8822C(x, v) \
(BIT_CLEAR_R_WMAC_IPV6_MYIPAD_3_8822C(x) | \
BIT_R_WMAC_IPV6_MYIPAD_3_8822C(v))
/* 2 REG_WMAC_RTX_CTX_SUBTYPE_CFG_8822C */
#define BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822C 4
#define BIT_MASK_R_WMAC_CTX_SUBTYPE_8822C 0xf
#define BIT_R_WMAC_CTX_SUBTYPE_8822C(x) \
(((x) & BIT_MASK_R_WMAC_CTX_SUBTYPE_8822C) \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822C)
#define BITS_R_WMAC_CTX_SUBTYPE_8822C \
(BIT_MASK_R_WMAC_CTX_SUBTYPE_8822C \
<< BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822C)
#define BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8822C(x) \
((x) & (~BITS_R_WMAC_CTX_SUBTYPE_8822C))
#define BIT_GET_R_WMAC_CTX_SUBTYPE_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_CTX_SUBTYPE_8822C) & \
BIT_MASK_R_WMAC_CTX_SUBTYPE_8822C)
#define BIT_SET_R_WMAC_CTX_SUBTYPE_8822C(x, v) \
(BIT_CLEAR_R_WMAC_CTX_SUBTYPE_8822C(x) | \
BIT_R_WMAC_CTX_SUBTYPE_8822C(v))
#define BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822C 0
#define BIT_MASK_R_WMAC_RTX_SUBTYPE_8822C 0xf
#define BIT_R_WMAC_RTX_SUBTYPE_8822C(x) \
(((x) & BIT_MASK_R_WMAC_RTX_SUBTYPE_8822C) \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822C)
#define BITS_R_WMAC_RTX_SUBTYPE_8822C \
(BIT_MASK_R_WMAC_RTX_SUBTYPE_8822C \
<< BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822C)
#define BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8822C(x) \
((x) & (~BITS_R_WMAC_RTX_SUBTYPE_8822C))
#define BIT_GET_R_WMAC_RTX_SUBTYPE_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RTX_SUBTYPE_8822C) & \
BIT_MASK_R_WMAC_RTX_SUBTYPE_8822C)
#define BIT_SET_R_WMAC_RTX_SUBTYPE_8822C(x, v) \
(BIT_CLEAR_R_WMAC_RTX_SUBTYPE_8822C(x) | \
BIT_R_WMAC_RTX_SUBTYPE_8822C(v))
/* 2 REG_WMAC_SWAES_DIO_B63_B32_8822C */
#define BIT_SHIFT_WMAC_SWAES_DIO_B63_B32_8822C 0
#define BIT_MASK_WMAC_SWAES_DIO_B63_B32_8822C 0xffffffffL
#define BIT_WMAC_SWAES_DIO_B63_B32_8822C(x) \
(((x) & BIT_MASK_WMAC_SWAES_DIO_B63_B32_8822C) \
<< BIT_SHIFT_WMAC_SWAES_DIO_B63_B32_8822C)
#define BITS_WMAC_SWAES_DIO_B63_B32_8822C \
(BIT_MASK_WMAC_SWAES_DIO_B63_B32_8822C \
<< BIT_SHIFT_WMAC_SWAES_DIO_B63_B32_8822C)
#define BIT_CLEAR_WMAC_SWAES_DIO_B63_B32_8822C(x) \
((x) & (~BITS_WMAC_SWAES_DIO_B63_B32_8822C))
#define BIT_GET_WMAC_SWAES_DIO_B63_B32_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_SWAES_DIO_B63_B32_8822C) & \
BIT_MASK_WMAC_SWAES_DIO_B63_B32_8822C)
#define BIT_SET_WMAC_SWAES_DIO_B63_B32_8822C(x, v) \
(BIT_CLEAR_WMAC_SWAES_DIO_B63_B32_8822C(x) | \
BIT_WMAC_SWAES_DIO_B63_B32_8822C(v))
/* 2 REG_WMAC_SWAES_DIO_B95_B64_8822C */
#define BIT_SHIFT_WMAC_SWAES_DIO_B95_B64_8822C 0
#define BIT_MASK_WMAC_SWAES_DIO_B95_B64_8822C 0xffffffffL
#define BIT_WMAC_SWAES_DIO_B95_B64_8822C(x) \
(((x) & BIT_MASK_WMAC_SWAES_DIO_B95_B64_8822C) \
<< BIT_SHIFT_WMAC_SWAES_DIO_B95_B64_8822C)
#define BITS_WMAC_SWAES_DIO_B95_B64_8822C \
(BIT_MASK_WMAC_SWAES_DIO_B95_B64_8822C \
<< BIT_SHIFT_WMAC_SWAES_DIO_B95_B64_8822C)
#define BIT_CLEAR_WMAC_SWAES_DIO_B95_B64_8822C(x) \
((x) & (~BITS_WMAC_SWAES_DIO_B95_B64_8822C))
#define BIT_GET_WMAC_SWAES_DIO_B95_B64_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_SWAES_DIO_B95_B64_8822C) & \
BIT_MASK_WMAC_SWAES_DIO_B95_B64_8822C)
#define BIT_SET_WMAC_SWAES_DIO_B95_B64_8822C(x, v) \
(BIT_CLEAR_WMAC_SWAES_DIO_B95_B64_8822C(x) | \
BIT_WMAC_SWAES_DIO_B95_B64_8822C(v))
/* 2 REG_WMAC_SWAES_DIO_B127_B96_8822C */
#define BIT_SHIFT_WMAC_SWAES_DIO_B127_B96_8822C 0
#define BIT_MASK_WMAC_SWAES_DIO_B127_B96_8822C 0xffffffffL
#define BIT_WMAC_SWAES_DIO_B127_B96_8822C(x) \
(((x) & BIT_MASK_WMAC_SWAES_DIO_B127_B96_8822C) \
<< BIT_SHIFT_WMAC_SWAES_DIO_B127_B96_8822C)
#define BITS_WMAC_SWAES_DIO_B127_B96_8822C \
(BIT_MASK_WMAC_SWAES_DIO_B127_B96_8822C \
<< BIT_SHIFT_WMAC_SWAES_DIO_B127_B96_8822C)
#define BIT_CLEAR_WMAC_SWAES_DIO_B127_B96_8822C(x) \
((x) & (~BITS_WMAC_SWAES_DIO_B127_B96_8822C))
#define BIT_GET_WMAC_SWAES_DIO_B127_B96_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_SWAES_DIO_B127_B96_8822C) & \
BIT_MASK_WMAC_SWAES_DIO_B127_B96_8822C)
#define BIT_SET_WMAC_SWAES_DIO_B127_B96_8822C(x, v) \
(BIT_CLEAR_WMAC_SWAES_DIO_B127_B96_8822C(x) | \
BIT_WMAC_SWAES_DIO_B127_B96_8822C(v))
/* 2 REG_WMAC_SWAES_CFG_8822C */
/* 2 REG_BT_COEX_V2_8822C */
#define BIT_GNT_BT_POLARITY_8822C BIT(12)
#define BIT_GNT_BT_BYPASS_PRIORITY_8822C BIT(8)
#define BIT_SHIFT_TIMER_8822C 0
#define BIT_MASK_TIMER_8822C 0xff
#define BIT_TIMER_8822C(x) \
(((x) & BIT_MASK_TIMER_8822C) << BIT_SHIFT_TIMER_8822C)
#define BITS_TIMER_8822C (BIT_MASK_TIMER_8822C << BIT_SHIFT_TIMER_8822C)
#define BIT_CLEAR_TIMER_8822C(x) ((x) & (~BITS_TIMER_8822C))
#define BIT_GET_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_TIMER_8822C) & BIT_MASK_TIMER_8822C)
#define BIT_SET_TIMER_8822C(x, v) \
(BIT_CLEAR_TIMER_8822C(x) | BIT_TIMER_8822C(v))
/* 2 REG_BT_COEX_8822C */
#define BIT_R_GNT_BT_RFC_SW_8822C BIT(12)
#define BIT_R_GNT_BT_RFC_SW_EN_8822C BIT(11)
#define BIT_R_GNT_BT_BB_SW_8822C BIT(10)
#define BIT_R_GNT_BT_BB_SW_EN_8822C BIT(9)
#define BIT_R_BT_CNT_THREN_8822C BIT(8)
#define BIT_SHIFT_R_BT_CNT_THR_8822C 0
#define BIT_MASK_R_BT_CNT_THR_8822C 0xff
#define BIT_R_BT_CNT_THR_8822C(x) \
(((x) & BIT_MASK_R_BT_CNT_THR_8822C) << BIT_SHIFT_R_BT_CNT_THR_8822C)
#define BITS_R_BT_CNT_THR_8822C \
(BIT_MASK_R_BT_CNT_THR_8822C << BIT_SHIFT_R_BT_CNT_THR_8822C)
#define BIT_CLEAR_R_BT_CNT_THR_8822C(x) ((x) & (~BITS_R_BT_CNT_THR_8822C))
#define BIT_GET_R_BT_CNT_THR_8822C(x) \
(((x) >> BIT_SHIFT_R_BT_CNT_THR_8822C) & BIT_MASK_R_BT_CNT_THR_8822C)
#define BIT_SET_R_BT_CNT_THR_8822C(x, v) \
(BIT_CLEAR_R_BT_CNT_THR_8822C(x) | BIT_R_BT_CNT_THR_8822C(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_8822C */
#define BIT_SHIFT_RXMYRTS_NAV_V1_8822C 8
#define BIT_MASK_RXMYRTS_NAV_V1_8822C 0xff
#define BIT_RXMYRTS_NAV_V1_8822C(x) \
(((x) & BIT_MASK_RXMYRTS_NAV_V1_8822C) \
<< BIT_SHIFT_RXMYRTS_NAV_V1_8822C)
#define BITS_RXMYRTS_NAV_V1_8822C \
(BIT_MASK_RXMYRTS_NAV_V1_8822C << BIT_SHIFT_RXMYRTS_NAV_V1_8822C)
#define BIT_CLEAR_RXMYRTS_NAV_V1_8822C(x) ((x) & (~BITS_RXMYRTS_NAV_V1_8822C))
#define BIT_GET_RXMYRTS_NAV_V1_8822C(x) \
(((x) >> BIT_SHIFT_RXMYRTS_NAV_V1_8822C) & \
BIT_MASK_RXMYRTS_NAV_V1_8822C)
#define BIT_SET_RXMYRTS_NAV_V1_8822C(x, v) \
(BIT_CLEAR_RXMYRTS_NAV_V1_8822C(x) | BIT_RXMYRTS_NAV_V1_8822C(v))
#define BIT_SHIFT_RTSRST_V1_8822C 0
#define BIT_MASK_RTSRST_V1_8822C 0xff
#define BIT_RTSRST_V1_8822C(x) \
(((x) & BIT_MASK_RTSRST_V1_8822C) << BIT_SHIFT_RTSRST_V1_8822C)
#define BITS_RTSRST_V1_8822C \
(BIT_MASK_RTSRST_V1_8822C << BIT_SHIFT_RTSRST_V1_8822C)
#define BIT_CLEAR_RTSRST_V1_8822C(x) ((x) & (~BITS_RTSRST_V1_8822C))
#define BIT_GET_RTSRST_V1_8822C(x) \
(((x) >> BIT_SHIFT_RTSRST_V1_8822C) & BIT_MASK_RTSRST_V1_8822C)
#define BIT_SET_RTSRST_V1_8822C(x, v) \
(BIT_CLEAR_RTSRST_V1_8822C(x) | BIT_RTSRST_V1_8822C(v))
/* 2 REG_WLAN_ACT_MASK_CTRL_1_8822C */
#define BIT_WLRX_TER_BY_CTL_1_8822C BIT(11)
#define BIT_WLRX_TER_BY_AD_1_8822C BIT(10)
#define BIT_ANT_DIVERSITY_SEL_1_8822C BIT(9)
#define BIT_ANTSEL_FOR_BT_CTRL_EN_1_8822C BIT(8)
#define BIT_WLACT_LOW_GNTWL_EN_1_8822C BIT(2)
#define BIT_WLACT_HIGH_GNTBT_EN_1_8822C BIT(1)
#define BIT_NAV_UPPER_1_V1_8822C BIT(0)
/* 2 REG_BT_COEX_ENHANCED_INTR_CTRL_8822C */
#define BIT_SHIFT_BT_STAT_DELAY_8822C 12
#define BIT_MASK_BT_STAT_DELAY_8822C 0xf
#define BIT_BT_STAT_DELAY_8822C(x) \
(((x) & BIT_MASK_BT_STAT_DELAY_8822C) << BIT_SHIFT_BT_STAT_DELAY_8822C)
#define BITS_BT_STAT_DELAY_8822C \
(BIT_MASK_BT_STAT_DELAY_8822C << BIT_SHIFT_BT_STAT_DELAY_8822C)
#define BIT_CLEAR_BT_STAT_DELAY_8822C(x) ((x) & (~BITS_BT_STAT_DELAY_8822C))
#define BIT_GET_BT_STAT_DELAY_8822C(x) \
(((x) >> BIT_SHIFT_BT_STAT_DELAY_8822C) & BIT_MASK_BT_STAT_DELAY_8822C)
#define BIT_SET_BT_STAT_DELAY_8822C(x, v) \
(BIT_CLEAR_BT_STAT_DELAY_8822C(x) | BIT_BT_STAT_DELAY_8822C(v))
#define BIT_SHIFT_BT_TRX_INIT_DETECT_8822C 8
#define BIT_MASK_BT_TRX_INIT_DETECT_8822C 0xf
#define BIT_BT_TRX_INIT_DETECT_8822C(x) \
(((x) & BIT_MASK_BT_TRX_INIT_DETECT_8822C) \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8822C)
#define BITS_BT_TRX_INIT_DETECT_8822C \
(BIT_MASK_BT_TRX_INIT_DETECT_8822C \
<< BIT_SHIFT_BT_TRX_INIT_DETECT_8822C)
#define BIT_CLEAR_BT_TRX_INIT_DETECT_8822C(x) \
((x) & (~BITS_BT_TRX_INIT_DETECT_8822C))
#define BIT_GET_BT_TRX_INIT_DETECT_8822C(x) \
(((x) >> BIT_SHIFT_BT_TRX_INIT_DETECT_8822C) & \
BIT_MASK_BT_TRX_INIT_DETECT_8822C)
#define BIT_SET_BT_TRX_INIT_DETECT_8822C(x, v) \
(BIT_CLEAR_BT_TRX_INIT_DETECT_8822C(x) | \
BIT_BT_TRX_INIT_DETECT_8822C(v))
#define BIT_SHIFT_BT_PRI_DETECT_TO_8822C 4
#define BIT_MASK_BT_PRI_DETECT_TO_8822C 0xf
#define BIT_BT_PRI_DETECT_TO_8822C(x) \
(((x) & BIT_MASK_BT_PRI_DETECT_TO_8822C) \
<< BIT_SHIFT_BT_PRI_DETECT_TO_8822C)
#define BITS_BT_PRI_DETECT_TO_8822C \
(BIT_MASK_BT_PRI_DETECT_TO_8822C << BIT_SHIFT_BT_PRI_DETECT_TO_8822C)
#define BIT_CLEAR_BT_PRI_DETECT_TO_8822C(x) \
((x) & (~BITS_BT_PRI_DETECT_TO_8822C))
#define BIT_GET_BT_PRI_DETECT_TO_8822C(x) \
(((x) >> BIT_SHIFT_BT_PRI_DETECT_TO_8822C) & \
BIT_MASK_BT_PRI_DETECT_TO_8822C)
#define BIT_SET_BT_PRI_DETECT_TO_8822C(x, v) \
(BIT_CLEAR_BT_PRI_DETECT_TO_8822C(x) | BIT_BT_PRI_DETECT_TO_8822C(v))
#define BIT_R_GRANTALL_WLMASK_8822C BIT(3)
#define BIT_STATIS_BT_EN_8822C BIT(2)
#define BIT_WL_ACT_MASK_ENABLE_8822C BIT(1)
#define BIT_ENHANCED_BT_8822C BIT(0)
/* 2 REG_BT_ACT_STATISTICS_8822C */
#define BIT_SHIFT_STATIS_BT_HI_RX_8822C 16
#define BIT_MASK_STATIS_BT_HI_RX_8822C 0xffff
#define BIT_STATIS_BT_HI_RX_8822C(x) \
(((x) & BIT_MASK_STATIS_BT_HI_RX_8822C) \
<< BIT_SHIFT_STATIS_BT_HI_RX_8822C)
#define BITS_STATIS_BT_HI_RX_8822C \
(BIT_MASK_STATIS_BT_HI_RX_8822C << BIT_SHIFT_STATIS_BT_HI_RX_8822C)
#define BIT_CLEAR_STATIS_BT_HI_RX_8822C(x) ((x) & (~BITS_STATIS_BT_HI_RX_8822C))
#define BIT_GET_STATIS_BT_HI_RX_8822C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_RX_8822C) & \
BIT_MASK_STATIS_BT_HI_RX_8822C)
#define BIT_SET_STATIS_BT_HI_RX_8822C(x, v) \
(BIT_CLEAR_STATIS_BT_HI_RX_8822C(x) | BIT_STATIS_BT_HI_RX_8822C(v))
#define BIT_SHIFT_STATIS_BT_HI_TX_8822C 0
#define BIT_MASK_STATIS_BT_HI_TX_8822C 0xffff
#define BIT_STATIS_BT_HI_TX_8822C(x) \
(((x) & BIT_MASK_STATIS_BT_HI_TX_8822C) \
<< BIT_SHIFT_STATIS_BT_HI_TX_8822C)
#define BITS_STATIS_BT_HI_TX_8822C \
(BIT_MASK_STATIS_BT_HI_TX_8822C << BIT_SHIFT_STATIS_BT_HI_TX_8822C)
#define BIT_CLEAR_STATIS_BT_HI_TX_8822C(x) ((x) & (~BITS_STATIS_BT_HI_TX_8822C))
#define BIT_GET_STATIS_BT_HI_TX_8822C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_HI_TX_8822C) & \
BIT_MASK_STATIS_BT_HI_TX_8822C)
#define BIT_SET_STATIS_BT_HI_TX_8822C(x, v) \
(BIT_CLEAR_STATIS_BT_HI_TX_8822C(x) | BIT_STATIS_BT_HI_TX_8822C(v))
/* 2 REG_BT_ACT_STATISTICS_1_8822C */
#define BIT_SHIFT_STATIS_BT_LO_RX_1_8822C 16
#define BIT_MASK_STATIS_BT_LO_RX_1_8822C 0xffff
#define BIT_STATIS_BT_LO_RX_1_8822C(x) \
(((x) & BIT_MASK_STATIS_BT_LO_RX_1_8822C) \
<< BIT_SHIFT_STATIS_BT_LO_RX_1_8822C)
#define BITS_STATIS_BT_LO_RX_1_8822C \
(BIT_MASK_STATIS_BT_LO_RX_1_8822C << BIT_SHIFT_STATIS_BT_LO_RX_1_8822C)
#define BIT_CLEAR_STATIS_BT_LO_RX_1_8822C(x) \
((x) & (~BITS_STATIS_BT_LO_RX_1_8822C))
#define BIT_GET_STATIS_BT_LO_RX_1_8822C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_RX_1_8822C) & \
BIT_MASK_STATIS_BT_LO_RX_1_8822C)
#define BIT_SET_STATIS_BT_LO_RX_1_8822C(x, v) \
(BIT_CLEAR_STATIS_BT_LO_RX_1_8822C(x) | BIT_STATIS_BT_LO_RX_1_8822C(v))
#define BIT_SHIFT_STATIS_BT_LO_TX_1_8822C 0
#define BIT_MASK_STATIS_BT_LO_TX_1_8822C 0xffff
#define BIT_STATIS_BT_LO_TX_1_8822C(x) \
(((x) & BIT_MASK_STATIS_BT_LO_TX_1_8822C) \
<< BIT_SHIFT_STATIS_BT_LO_TX_1_8822C)
#define BITS_STATIS_BT_LO_TX_1_8822C \
(BIT_MASK_STATIS_BT_LO_TX_1_8822C << BIT_SHIFT_STATIS_BT_LO_TX_1_8822C)
#define BIT_CLEAR_STATIS_BT_LO_TX_1_8822C(x) \
((x) & (~BITS_STATIS_BT_LO_TX_1_8822C))
#define BIT_GET_STATIS_BT_LO_TX_1_8822C(x) \
(((x) >> BIT_SHIFT_STATIS_BT_LO_TX_1_8822C) & \
BIT_MASK_STATIS_BT_LO_TX_1_8822C)
#define BIT_SET_STATIS_BT_LO_TX_1_8822C(x, v) \
(BIT_CLEAR_STATIS_BT_LO_TX_1_8822C(x) | BIT_STATIS_BT_LO_TX_1_8822C(v))
/* 2 REG_BT_STATISTICS_CONTROL_REGISTER_8822C */
#define BIT_SHIFT_R_BT_CMD_RPT_8822C 16
#define BIT_MASK_R_BT_CMD_RPT_8822C 0xffff
#define BIT_R_BT_CMD_RPT_8822C(x) \
(((x) & BIT_MASK_R_BT_CMD_RPT_8822C) << BIT_SHIFT_R_BT_CMD_RPT_8822C)
#define BITS_R_BT_CMD_RPT_8822C \
(BIT_MASK_R_BT_CMD_RPT_8822C << BIT_SHIFT_R_BT_CMD_RPT_8822C)
#define BIT_CLEAR_R_BT_CMD_RPT_8822C(x) ((x) & (~BITS_R_BT_CMD_RPT_8822C))
#define BIT_GET_R_BT_CMD_RPT_8822C(x) \
(((x) >> BIT_SHIFT_R_BT_CMD_RPT_8822C) & BIT_MASK_R_BT_CMD_RPT_8822C)
#define BIT_SET_R_BT_CMD_RPT_8822C(x, v) \
(BIT_CLEAR_R_BT_CMD_RPT_8822C(x) | BIT_R_BT_CMD_RPT_8822C(v))
#define BIT_SHIFT_R_RPT_FROM_BT_8822C 8
#define BIT_MASK_R_RPT_FROM_BT_8822C 0xff
#define BIT_R_RPT_FROM_BT_8822C(x) \
(((x) & BIT_MASK_R_RPT_FROM_BT_8822C) << BIT_SHIFT_R_RPT_FROM_BT_8822C)
#define BITS_R_RPT_FROM_BT_8822C \
(BIT_MASK_R_RPT_FROM_BT_8822C << BIT_SHIFT_R_RPT_FROM_BT_8822C)
#define BIT_CLEAR_R_RPT_FROM_BT_8822C(x) ((x) & (~BITS_R_RPT_FROM_BT_8822C))
#define BIT_GET_R_RPT_FROM_BT_8822C(x) \
(((x) >> BIT_SHIFT_R_RPT_FROM_BT_8822C) & BIT_MASK_R_RPT_FROM_BT_8822C)
#define BIT_SET_R_RPT_FROM_BT_8822C(x, v) \
(BIT_CLEAR_R_RPT_FROM_BT_8822C(x) | BIT_R_RPT_FROM_BT_8822C(v))
#define BIT_SHIFT_BT_HID_ISR_SET_8822C 6
#define BIT_MASK_BT_HID_ISR_SET_8822C 0x3
#define BIT_BT_HID_ISR_SET_8822C(x) \
(((x) & BIT_MASK_BT_HID_ISR_SET_8822C) \
<< BIT_SHIFT_BT_HID_ISR_SET_8822C)
#define BITS_BT_HID_ISR_SET_8822C \
(BIT_MASK_BT_HID_ISR_SET_8822C << BIT_SHIFT_BT_HID_ISR_SET_8822C)
#define BIT_CLEAR_BT_HID_ISR_SET_8822C(x) ((x) & (~BITS_BT_HID_ISR_SET_8822C))
#define BIT_GET_BT_HID_ISR_SET_8822C(x) \
(((x) >> BIT_SHIFT_BT_HID_ISR_SET_8822C) & \
BIT_MASK_BT_HID_ISR_SET_8822C)
#define BIT_SET_BT_HID_ISR_SET_8822C(x, v) \
(BIT_CLEAR_BT_HID_ISR_SET_8822C(x) | BIT_BT_HID_ISR_SET_8822C(v))
#define BIT_TDMA_BT_START_NOTIFY_8822C BIT(5)
#define BIT_ENABLE_TDMA_FW_MODE_8822C BIT(4)
#define BIT_ENABLE_PTA_TDMA_MODE_8822C BIT(3)
#define BIT_ENABLE_COEXIST_TAB_IN_TDMA_8822C BIT(2)
#define BIT_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA_8822C BIT(1)
#define BIT_RTK_BT_ENABLE_8822C BIT(0)
/* 2 REG_BT_STATUS_REPORT_REGISTER_8822C */
#define BIT_SHIFT_BT_PROFILE_8822C 24
#define BIT_MASK_BT_PROFILE_8822C 0xff
#define BIT_BT_PROFILE_8822C(x) \
(((x) & BIT_MASK_BT_PROFILE_8822C) << BIT_SHIFT_BT_PROFILE_8822C)
#define BITS_BT_PROFILE_8822C \
(BIT_MASK_BT_PROFILE_8822C << BIT_SHIFT_BT_PROFILE_8822C)
#define BIT_CLEAR_BT_PROFILE_8822C(x) ((x) & (~BITS_BT_PROFILE_8822C))
#define BIT_GET_BT_PROFILE_8822C(x) \
(((x) >> BIT_SHIFT_BT_PROFILE_8822C) & BIT_MASK_BT_PROFILE_8822C)
#define BIT_SET_BT_PROFILE_8822C(x, v) \
(BIT_CLEAR_BT_PROFILE_8822C(x) | BIT_BT_PROFILE_8822C(v))
#define BIT_SHIFT_BT_POWER_8822C 16
#define BIT_MASK_BT_POWER_8822C 0xff
#define BIT_BT_POWER_8822C(x) \
(((x) & BIT_MASK_BT_POWER_8822C) << BIT_SHIFT_BT_POWER_8822C)
#define BITS_BT_POWER_8822C \
(BIT_MASK_BT_POWER_8822C << BIT_SHIFT_BT_POWER_8822C)
#define BIT_CLEAR_BT_POWER_8822C(x) ((x) & (~BITS_BT_POWER_8822C))
#define BIT_GET_BT_POWER_8822C(x) \
(((x) >> BIT_SHIFT_BT_POWER_8822C) & BIT_MASK_BT_POWER_8822C)
#define BIT_SET_BT_POWER_8822C(x, v) \
(BIT_CLEAR_BT_POWER_8822C(x) | BIT_BT_POWER_8822C(v))
#define BIT_SHIFT_BT_PREDECT_STATUS_8822C 8
#define BIT_MASK_BT_PREDECT_STATUS_8822C 0xff
#define BIT_BT_PREDECT_STATUS_8822C(x) \
(((x) & BIT_MASK_BT_PREDECT_STATUS_8822C) \
<< BIT_SHIFT_BT_PREDECT_STATUS_8822C)
#define BITS_BT_PREDECT_STATUS_8822C \
(BIT_MASK_BT_PREDECT_STATUS_8822C << BIT_SHIFT_BT_PREDECT_STATUS_8822C)
#define BIT_CLEAR_BT_PREDECT_STATUS_8822C(x) \
((x) & (~BITS_BT_PREDECT_STATUS_8822C))
#define BIT_GET_BT_PREDECT_STATUS_8822C(x) \
(((x) >> BIT_SHIFT_BT_PREDECT_STATUS_8822C) & \
BIT_MASK_BT_PREDECT_STATUS_8822C)
#define BIT_SET_BT_PREDECT_STATUS_8822C(x, v) \
(BIT_CLEAR_BT_PREDECT_STATUS_8822C(x) | BIT_BT_PREDECT_STATUS_8822C(v))
#define BIT_SHIFT_BT_CMD_INFO_8822C 0
#define BIT_MASK_BT_CMD_INFO_8822C 0xff
#define BIT_BT_CMD_INFO_8822C(x) \
(((x) & BIT_MASK_BT_CMD_INFO_8822C) << BIT_SHIFT_BT_CMD_INFO_8822C)
#define BITS_BT_CMD_INFO_8822C \
(BIT_MASK_BT_CMD_INFO_8822C << BIT_SHIFT_BT_CMD_INFO_8822C)
#define BIT_CLEAR_BT_CMD_INFO_8822C(x) ((x) & (~BITS_BT_CMD_INFO_8822C))
#define BIT_GET_BT_CMD_INFO_8822C(x) \
(((x) >> BIT_SHIFT_BT_CMD_INFO_8822C) & BIT_MASK_BT_CMD_INFO_8822C)
#define BIT_SET_BT_CMD_INFO_8822C(x, v) \
(BIT_CLEAR_BT_CMD_INFO_8822C(x) | BIT_BT_CMD_INFO_8822C(v))
/* 2 REG_BT_INTERRUPT_CONTROL_REGISTER_8822C */
#define BIT_EN_MAC_NULL_PKT_NOTIFY_8822C BIT(31)
#define BIT_EN_WLAN_RPT_AND_BT_QUERY_8822C BIT(30)
#define BIT_EN_BT_STSTUS_RPT_8822C BIT(29)
#define BIT_EN_BT_POWER_8822C BIT(28)
#define BIT_EN_BT_CHANNEL_8822C BIT(27)
#define BIT_EN_BT_SLOT_CHANGE_8822C BIT(26)
#define BIT_EN_BT_PROFILE_OR_HID_8822C BIT(25)
#define BIT_WLAN_RPT_NOTIFY_8822C BIT(24)
#define BIT_SHIFT_WLAN_RPT_DATA_8822C 16
#define BIT_MASK_WLAN_RPT_DATA_8822C 0xff
#define BIT_WLAN_RPT_DATA_8822C(x) \
(((x) & BIT_MASK_WLAN_RPT_DATA_8822C) << BIT_SHIFT_WLAN_RPT_DATA_8822C)
#define BITS_WLAN_RPT_DATA_8822C \
(BIT_MASK_WLAN_RPT_DATA_8822C << BIT_SHIFT_WLAN_RPT_DATA_8822C)
#define BIT_CLEAR_WLAN_RPT_DATA_8822C(x) ((x) & (~BITS_WLAN_RPT_DATA_8822C))
#define BIT_GET_WLAN_RPT_DATA_8822C(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_DATA_8822C) & BIT_MASK_WLAN_RPT_DATA_8822C)
#define BIT_SET_WLAN_RPT_DATA_8822C(x, v) \
(BIT_CLEAR_WLAN_RPT_DATA_8822C(x) | BIT_WLAN_RPT_DATA_8822C(v))
#define BIT_SHIFT_CMD_ID_8822C 8
#define BIT_MASK_CMD_ID_8822C 0xff
#define BIT_CMD_ID_8822C(x) \
(((x) & BIT_MASK_CMD_ID_8822C) << BIT_SHIFT_CMD_ID_8822C)
#define BITS_CMD_ID_8822C (BIT_MASK_CMD_ID_8822C << BIT_SHIFT_CMD_ID_8822C)
#define BIT_CLEAR_CMD_ID_8822C(x) ((x) & (~BITS_CMD_ID_8822C))
#define BIT_GET_CMD_ID_8822C(x) \
(((x) >> BIT_SHIFT_CMD_ID_8822C) & BIT_MASK_CMD_ID_8822C)
#define BIT_SET_CMD_ID_8822C(x, v) \
(BIT_CLEAR_CMD_ID_8822C(x) | BIT_CMD_ID_8822C(v))
#define BIT_SHIFT_BT_DATA_8822C 0
#define BIT_MASK_BT_DATA_8822C 0xff
#define BIT_BT_DATA_8822C(x) \
(((x) & BIT_MASK_BT_DATA_8822C) << BIT_SHIFT_BT_DATA_8822C)
#define BITS_BT_DATA_8822C (BIT_MASK_BT_DATA_8822C << BIT_SHIFT_BT_DATA_8822C)
#define BIT_CLEAR_BT_DATA_8822C(x) ((x) & (~BITS_BT_DATA_8822C))
#define BIT_GET_BT_DATA_8822C(x) \
(((x) >> BIT_SHIFT_BT_DATA_8822C) & BIT_MASK_BT_DATA_8822C)
#define BIT_SET_BT_DATA_8822C(x, v) \
(BIT_CLEAR_BT_DATA_8822C(x) | BIT_BT_DATA_8822C(v))
/* 2 REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8822C */
#define BIT_SHIFT_WLAN_RPT_TO_8822C 0
#define BIT_MASK_WLAN_RPT_TO_8822C 0xff
#define BIT_WLAN_RPT_TO_8822C(x) \
(((x) & BIT_MASK_WLAN_RPT_TO_8822C) << BIT_SHIFT_WLAN_RPT_TO_8822C)
#define BITS_WLAN_RPT_TO_8822C \
(BIT_MASK_WLAN_RPT_TO_8822C << BIT_SHIFT_WLAN_RPT_TO_8822C)
#define BIT_CLEAR_WLAN_RPT_TO_8822C(x) ((x) & (~BITS_WLAN_RPT_TO_8822C))
#define BIT_GET_WLAN_RPT_TO_8822C(x) \
(((x) >> BIT_SHIFT_WLAN_RPT_TO_8822C) & BIT_MASK_WLAN_RPT_TO_8822C)
#define BIT_SET_WLAN_RPT_TO_8822C(x, v) \
(BIT_CLEAR_WLAN_RPT_TO_8822C(x) | BIT_WLAN_RPT_TO_8822C(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8822C */
#define BIT_SHIFT_ISOLATION_CHK_0_8822C 1
#define BIT_MASK_ISOLATION_CHK_0_8822C 0x7fffff
#define BIT_ISOLATION_CHK_0_8822C(x) \
(((x) & BIT_MASK_ISOLATION_CHK_0_8822C) \
<< BIT_SHIFT_ISOLATION_CHK_0_8822C)
#define BITS_ISOLATION_CHK_0_8822C \
(BIT_MASK_ISOLATION_CHK_0_8822C << BIT_SHIFT_ISOLATION_CHK_0_8822C)
#define BIT_CLEAR_ISOLATION_CHK_0_8822C(x) ((x) & (~BITS_ISOLATION_CHK_0_8822C))
#define BIT_GET_ISOLATION_CHK_0_8822C(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_0_8822C) & \
BIT_MASK_ISOLATION_CHK_0_8822C)
#define BIT_SET_ISOLATION_CHK_0_8822C(x, v) \
(BIT_CLEAR_ISOLATION_CHK_0_8822C(x) | BIT_ISOLATION_CHK_0_8822C(v))
#define BIT_ISOLATION_EN_8822C BIT(0)
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8822C */
#define BIT_SHIFT_ISOLATION_CHK_1_8822C 0
#define BIT_MASK_ISOLATION_CHK_1_8822C 0xffffffffL
#define BIT_ISOLATION_CHK_1_8822C(x) \
(((x) & BIT_MASK_ISOLATION_CHK_1_8822C) \
<< BIT_SHIFT_ISOLATION_CHK_1_8822C)
#define BITS_ISOLATION_CHK_1_8822C \
(BIT_MASK_ISOLATION_CHK_1_8822C << BIT_SHIFT_ISOLATION_CHK_1_8822C)
#define BIT_CLEAR_ISOLATION_CHK_1_8822C(x) ((x) & (~BITS_ISOLATION_CHK_1_8822C))
#define BIT_GET_ISOLATION_CHK_1_8822C(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_1_8822C) & \
BIT_MASK_ISOLATION_CHK_1_8822C)
#define BIT_SET_ISOLATION_CHK_1_8822C(x, v) \
(BIT_CLEAR_ISOLATION_CHK_1_8822C(x) | BIT_ISOLATION_CHK_1_8822C(v))
/* 2 REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8822C */
#define BIT_SHIFT_ISOLATION_CHK_2_8822C 0
#define BIT_MASK_ISOLATION_CHK_2_8822C 0xffffff
#define BIT_ISOLATION_CHK_2_8822C(x) \
(((x) & BIT_MASK_ISOLATION_CHK_2_8822C) \
<< BIT_SHIFT_ISOLATION_CHK_2_8822C)
#define BITS_ISOLATION_CHK_2_8822C \
(BIT_MASK_ISOLATION_CHK_2_8822C << BIT_SHIFT_ISOLATION_CHK_2_8822C)
#define BIT_CLEAR_ISOLATION_CHK_2_8822C(x) ((x) & (~BITS_ISOLATION_CHK_2_8822C))
#define BIT_GET_ISOLATION_CHK_2_8822C(x) \
(((x) >> BIT_SHIFT_ISOLATION_CHK_2_8822C) & \
BIT_MASK_ISOLATION_CHK_2_8822C)
#define BIT_SET_ISOLATION_CHK_2_8822C(x, v) \
(BIT_CLEAR_ISOLATION_CHK_2_8822C(x) | BIT_ISOLATION_CHK_2_8822C(v))
/* 2 REG_BT_INTERRUPT_STATUS_REGISTER_8822C */
#define BIT_BT_HID_ISR_8822C BIT(7)
#define BIT_BT_QUERY_ISR_8822C BIT(6)
#define BIT_MAC_NULL_PKT_NOTIFY_ISR_8822C BIT(5)
#define BIT_WLAN_RPT_ISR_8822C BIT(4)
#define BIT_BT_POWER_ISR_8822C BIT(3)
#define BIT_BT_CHANNEL_ISR_8822C BIT(2)
#define BIT_BT_SLOT_CHANGE_ISR_8822C BIT(1)
#define BIT_BT_PROFILE_ISR_8822C BIT(0)
/* 2 REG_BT_TDMA_TIME_REGISTER_8822C */
#define BIT_SHIFT_BT_TIME_8822C 6
#define BIT_MASK_BT_TIME_8822C 0x3ffffff
#define BIT_BT_TIME_8822C(x) \
(((x) & BIT_MASK_BT_TIME_8822C) << BIT_SHIFT_BT_TIME_8822C)
#define BITS_BT_TIME_8822C (BIT_MASK_BT_TIME_8822C << BIT_SHIFT_BT_TIME_8822C)
#define BIT_CLEAR_BT_TIME_8822C(x) ((x) & (~BITS_BT_TIME_8822C))
#define BIT_GET_BT_TIME_8822C(x) \
(((x) >> BIT_SHIFT_BT_TIME_8822C) & BIT_MASK_BT_TIME_8822C)
#define BIT_SET_BT_TIME_8822C(x, v) \
(BIT_CLEAR_BT_TIME_8822C(x) | BIT_BT_TIME_8822C(v))
#define BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822C 0
#define BIT_MASK_BT_RPT_SAMPLE_RATE_8822C 0x3f
#define BIT_BT_RPT_SAMPLE_RATE_8822C(x) \
(((x) & BIT_MASK_BT_RPT_SAMPLE_RATE_8822C) \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822C)
#define BITS_BT_RPT_SAMPLE_RATE_8822C \
(BIT_MASK_BT_RPT_SAMPLE_RATE_8822C \
<< BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822C)
#define BIT_CLEAR_BT_RPT_SAMPLE_RATE_8822C(x) \
((x) & (~BITS_BT_RPT_SAMPLE_RATE_8822C))
#define BIT_GET_BT_RPT_SAMPLE_RATE_8822C(x) \
(((x) >> BIT_SHIFT_BT_RPT_SAMPLE_RATE_8822C) & \
BIT_MASK_BT_RPT_SAMPLE_RATE_8822C)
#define BIT_SET_BT_RPT_SAMPLE_RATE_8822C(x, v) \
(BIT_CLEAR_BT_RPT_SAMPLE_RATE_8822C(x) | \
BIT_BT_RPT_SAMPLE_RATE_8822C(v))
/* 2 REG_BT_ACT_REGISTER_8822C */
#define BIT_SHIFT_BT_EISR_EN_8822C 16
#define BIT_MASK_BT_EISR_EN_8822C 0xff
#define BIT_BT_EISR_EN_8822C(x) \
(((x) & BIT_MASK_BT_EISR_EN_8822C) << BIT_SHIFT_BT_EISR_EN_8822C)
#define BITS_BT_EISR_EN_8822C \
(BIT_MASK_BT_EISR_EN_8822C << BIT_SHIFT_BT_EISR_EN_8822C)
#define BIT_CLEAR_BT_EISR_EN_8822C(x) ((x) & (~BITS_BT_EISR_EN_8822C))
#define BIT_GET_BT_EISR_EN_8822C(x) \
(((x) >> BIT_SHIFT_BT_EISR_EN_8822C) & BIT_MASK_BT_EISR_EN_8822C)
#define BIT_SET_BT_EISR_EN_8822C(x, v) \
(BIT_CLEAR_BT_EISR_EN_8822C(x) | BIT_BT_EISR_EN_8822C(v))
#define BIT_BT_ACT_FALLING_ISR_8822C BIT(10)
#define BIT_BT_ACT_RISING_ISR_8822C BIT(9)
#define BIT_TDMA_TO_ISR_8822C BIT(8)
#define BIT_SHIFT_BT_CH_V1_8822C 0
#define BIT_MASK_BT_CH_V1_8822C 0x7f
#define BIT_BT_CH_V1_8822C(x) \
(((x) & BIT_MASK_BT_CH_V1_8822C) << BIT_SHIFT_BT_CH_V1_8822C)
#define BITS_BT_CH_V1_8822C \
(BIT_MASK_BT_CH_V1_8822C << BIT_SHIFT_BT_CH_V1_8822C)
#define BIT_CLEAR_BT_CH_V1_8822C(x) ((x) & (~BITS_BT_CH_V1_8822C))
#define BIT_GET_BT_CH_V1_8822C(x) \
(((x) >> BIT_SHIFT_BT_CH_V1_8822C) & BIT_MASK_BT_CH_V1_8822C)
#define BIT_SET_BT_CH_V1_8822C(x, v) \
(BIT_CLEAR_BT_CH_V1_8822C(x) | BIT_BT_CH_V1_8822C(v))
/* 2 REG_OBFF_CTRL_BASIC_8822C */
#define BIT_OBFF_EN_V1_8822C BIT(31)
#define BIT_SHIFT_OBFF_STATE_V1_8822C 28
#define BIT_MASK_OBFF_STATE_V1_8822C 0x3
#define BIT_OBFF_STATE_V1_8822C(x) \
(((x) & BIT_MASK_OBFF_STATE_V1_8822C) << BIT_SHIFT_OBFF_STATE_V1_8822C)
#define BITS_OBFF_STATE_V1_8822C \
(BIT_MASK_OBFF_STATE_V1_8822C << BIT_SHIFT_OBFF_STATE_V1_8822C)
#define BIT_CLEAR_OBFF_STATE_V1_8822C(x) ((x) & (~BITS_OBFF_STATE_V1_8822C))
#define BIT_GET_OBFF_STATE_V1_8822C(x) \
(((x) >> BIT_SHIFT_OBFF_STATE_V1_8822C) & BIT_MASK_OBFF_STATE_V1_8822C)
#define BIT_SET_OBFF_STATE_V1_8822C(x, v) \
(BIT_CLEAR_OBFF_STATE_V1_8822C(x) | BIT_OBFF_STATE_V1_8822C(v))
#define BIT_OBFF_ACT_RXDMA_EN_8822C BIT(27)
#define BIT_OBFF_BLOCK_INT_EN_8822C BIT(26)
#define BIT_OBFF_AUTOACT_EN_8822C BIT(25)
#define BIT_OBFF_AUTOIDLE_EN_8822C BIT(24)
#define BIT_SHIFT_WAKE_MAX_PLS_8822C 20
#define BIT_MASK_WAKE_MAX_PLS_8822C 0x7
#define BIT_WAKE_MAX_PLS_8822C(x) \
(((x) & BIT_MASK_WAKE_MAX_PLS_8822C) << BIT_SHIFT_WAKE_MAX_PLS_8822C)
#define BITS_WAKE_MAX_PLS_8822C \
(BIT_MASK_WAKE_MAX_PLS_8822C << BIT_SHIFT_WAKE_MAX_PLS_8822C)
#define BIT_CLEAR_WAKE_MAX_PLS_8822C(x) ((x) & (~BITS_WAKE_MAX_PLS_8822C))
#define BIT_GET_WAKE_MAX_PLS_8822C(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_PLS_8822C) & BIT_MASK_WAKE_MAX_PLS_8822C)
#define BIT_SET_WAKE_MAX_PLS_8822C(x, v) \
(BIT_CLEAR_WAKE_MAX_PLS_8822C(x) | BIT_WAKE_MAX_PLS_8822C(v))
#define BIT_SHIFT_WAKE_MIN_PLS_8822C 16
#define BIT_MASK_WAKE_MIN_PLS_8822C 0x7
#define BIT_WAKE_MIN_PLS_8822C(x) \
(((x) & BIT_MASK_WAKE_MIN_PLS_8822C) << BIT_SHIFT_WAKE_MIN_PLS_8822C)
#define BITS_WAKE_MIN_PLS_8822C \
(BIT_MASK_WAKE_MIN_PLS_8822C << BIT_SHIFT_WAKE_MIN_PLS_8822C)
#define BIT_CLEAR_WAKE_MIN_PLS_8822C(x) ((x) & (~BITS_WAKE_MIN_PLS_8822C))
#define BIT_GET_WAKE_MIN_PLS_8822C(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_PLS_8822C) & BIT_MASK_WAKE_MIN_PLS_8822C)
#define BIT_SET_WAKE_MIN_PLS_8822C(x, v) \
(BIT_CLEAR_WAKE_MIN_PLS_8822C(x) | BIT_WAKE_MIN_PLS_8822C(v))
#define BIT_SHIFT_WAKE_MAX_F2F_8822C 12
#define BIT_MASK_WAKE_MAX_F2F_8822C 0x7
#define BIT_WAKE_MAX_F2F_8822C(x) \
(((x) & BIT_MASK_WAKE_MAX_F2F_8822C) << BIT_SHIFT_WAKE_MAX_F2F_8822C)
#define BITS_WAKE_MAX_F2F_8822C \
(BIT_MASK_WAKE_MAX_F2F_8822C << BIT_SHIFT_WAKE_MAX_F2F_8822C)
#define BIT_CLEAR_WAKE_MAX_F2F_8822C(x) ((x) & (~BITS_WAKE_MAX_F2F_8822C))
#define BIT_GET_WAKE_MAX_F2F_8822C(x) \
(((x) >> BIT_SHIFT_WAKE_MAX_F2F_8822C) & BIT_MASK_WAKE_MAX_F2F_8822C)
#define BIT_SET_WAKE_MAX_F2F_8822C(x, v) \
(BIT_CLEAR_WAKE_MAX_F2F_8822C(x) | BIT_WAKE_MAX_F2F_8822C(v))
#define BIT_SHIFT_WAKE_MIN_F2F_8822C 8
#define BIT_MASK_WAKE_MIN_F2F_8822C 0x7
#define BIT_WAKE_MIN_F2F_8822C(x) \
(((x) & BIT_MASK_WAKE_MIN_F2F_8822C) << BIT_SHIFT_WAKE_MIN_F2F_8822C)
#define BITS_WAKE_MIN_F2F_8822C \
(BIT_MASK_WAKE_MIN_F2F_8822C << BIT_SHIFT_WAKE_MIN_F2F_8822C)
#define BIT_CLEAR_WAKE_MIN_F2F_8822C(x) ((x) & (~BITS_WAKE_MIN_F2F_8822C))
#define BIT_GET_WAKE_MIN_F2F_8822C(x) \
(((x) >> BIT_SHIFT_WAKE_MIN_F2F_8822C) & BIT_MASK_WAKE_MIN_F2F_8822C)
#define BIT_SET_WAKE_MIN_F2F_8822C(x, v) \
(BIT_CLEAR_WAKE_MIN_F2F_8822C(x) | BIT_WAKE_MIN_F2F_8822C(v))
#define BIT_APP_CPU_ACT_V1_8822C BIT(3)
#define BIT_APP_OBFF_V1_8822C BIT(2)
#define BIT_APP_IDLE_V1_8822C BIT(1)
#define BIT_APP_INIT_V1_8822C BIT(0)
/* 2 REG_OBFF_CTRL2_TIMER_8822C */
#define BIT_SHIFT_RX_HIGH_TIMER_IDX_8822C 24
#define BIT_MASK_RX_HIGH_TIMER_IDX_8822C 0x7
#define BIT_RX_HIGH_TIMER_IDX_8822C(x) \
(((x) & BIT_MASK_RX_HIGH_TIMER_IDX_8822C) \
<< BIT_SHIFT_RX_HIGH_TIMER_IDX_8822C)
#define BITS_RX_HIGH_TIMER_IDX_8822C \
(BIT_MASK_RX_HIGH_TIMER_IDX_8822C << BIT_SHIFT_RX_HIGH_TIMER_IDX_8822C)
#define BIT_CLEAR_RX_HIGH_TIMER_IDX_8822C(x) \
((x) & (~BITS_RX_HIGH_TIMER_IDX_8822C))
#define BIT_GET_RX_HIGH_TIMER_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TIMER_IDX_8822C) & \
BIT_MASK_RX_HIGH_TIMER_IDX_8822C)
#define BIT_SET_RX_HIGH_TIMER_IDX_8822C(x, v) \
(BIT_CLEAR_RX_HIGH_TIMER_IDX_8822C(x) | BIT_RX_HIGH_TIMER_IDX_8822C(v))
#define BIT_SHIFT_RX_MED_TIMER_IDX_8822C 16
#define BIT_MASK_RX_MED_TIMER_IDX_8822C 0x7
#define BIT_RX_MED_TIMER_IDX_8822C(x) \
(((x) & BIT_MASK_RX_MED_TIMER_IDX_8822C) \
<< BIT_SHIFT_RX_MED_TIMER_IDX_8822C)
#define BITS_RX_MED_TIMER_IDX_8822C \
(BIT_MASK_RX_MED_TIMER_IDX_8822C << BIT_SHIFT_RX_MED_TIMER_IDX_8822C)
#define BIT_CLEAR_RX_MED_TIMER_IDX_8822C(x) \
((x) & (~BITS_RX_MED_TIMER_IDX_8822C))
#define BIT_GET_RX_MED_TIMER_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_MED_TIMER_IDX_8822C) & \
BIT_MASK_RX_MED_TIMER_IDX_8822C)
#define BIT_SET_RX_MED_TIMER_IDX_8822C(x, v) \
(BIT_CLEAR_RX_MED_TIMER_IDX_8822C(x) | BIT_RX_MED_TIMER_IDX_8822C(v))
#define BIT_SHIFT_RX_LOW_TIMER_IDX_8822C 8
#define BIT_MASK_RX_LOW_TIMER_IDX_8822C 0x7
#define BIT_RX_LOW_TIMER_IDX_8822C(x) \
(((x) & BIT_MASK_RX_LOW_TIMER_IDX_8822C) \
<< BIT_SHIFT_RX_LOW_TIMER_IDX_8822C)
#define BITS_RX_LOW_TIMER_IDX_8822C \
(BIT_MASK_RX_LOW_TIMER_IDX_8822C << BIT_SHIFT_RX_LOW_TIMER_IDX_8822C)
#define BIT_CLEAR_RX_LOW_TIMER_IDX_8822C(x) \
((x) & (~BITS_RX_LOW_TIMER_IDX_8822C))
#define BIT_GET_RX_LOW_TIMER_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_LOW_TIMER_IDX_8822C) & \
BIT_MASK_RX_LOW_TIMER_IDX_8822C)
#define BIT_SET_RX_LOW_TIMER_IDX_8822C(x, v) \
(BIT_CLEAR_RX_LOW_TIMER_IDX_8822C(x) | BIT_RX_LOW_TIMER_IDX_8822C(v))
#define BIT_SHIFT_OBFF_INT_TIMER_IDX_8822C 0
#define BIT_MASK_OBFF_INT_TIMER_IDX_8822C 0x7
#define BIT_OBFF_INT_TIMER_IDX_8822C(x) \
(((x) & BIT_MASK_OBFF_INT_TIMER_IDX_8822C) \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8822C)
#define BITS_OBFF_INT_TIMER_IDX_8822C \
(BIT_MASK_OBFF_INT_TIMER_IDX_8822C \
<< BIT_SHIFT_OBFF_INT_TIMER_IDX_8822C)
#define BIT_CLEAR_OBFF_INT_TIMER_IDX_8822C(x) \
((x) & (~BITS_OBFF_INT_TIMER_IDX_8822C))
#define BIT_GET_OBFF_INT_TIMER_IDX_8822C(x) \
(((x) >> BIT_SHIFT_OBFF_INT_TIMER_IDX_8822C) & \
BIT_MASK_OBFF_INT_TIMER_IDX_8822C)
#define BIT_SET_OBFF_INT_TIMER_IDX_8822C(x, v) \
(BIT_CLEAR_OBFF_INT_TIMER_IDX_8822C(x) | \
BIT_OBFF_INT_TIMER_IDX_8822C(v))
/* 2 REG_LTR_CTRL_BASIC_8822C */
#define BIT_LTR_EN_V1_8822C BIT(31)
#define BIT_LTR_HW_EN_V1_8822C BIT(30)
#define BIT_LRT_ACT_CTS_EN_8822C BIT(29)
#define BIT_LTR_ACT_RXPKT_EN_8822C BIT(28)
#define BIT_LTR_ACT_RXDMA_EN_8822C BIT(27)
#define BIT_LTR_IDLE_NO_SNOOP_8822C BIT(26)
#define BIT_SPDUP_MGTPKT_8822C BIT(25)
#define BIT_RX_AGG_EN_8822C BIT(24)
#define BIT_APP_LTR_ACT_8822C BIT(23)
#define BIT_APP_LTR_IDLE_8822C BIT(22)
#define BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822C 20
#define BIT_MASK_HIGH_RATE_TRIG_SEL_8822C 0x3
#define BIT_HIGH_RATE_TRIG_SEL_8822C(x) \
(((x) & BIT_MASK_HIGH_RATE_TRIG_SEL_8822C) \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822C)
#define BITS_HIGH_RATE_TRIG_SEL_8822C \
(BIT_MASK_HIGH_RATE_TRIG_SEL_8822C \
<< BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822C)
#define BIT_CLEAR_HIGH_RATE_TRIG_SEL_8822C(x) \
((x) & (~BITS_HIGH_RATE_TRIG_SEL_8822C))
#define BIT_GET_HIGH_RATE_TRIG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_TRIG_SEL_8822C) & \
BIT_MASK_HIGH_RATE_TRIG_SEL_8822C)
#define BIT_SET_HIGH_RATE_TRIG_SEL_8822C(x, v) \
(BIT_CLEAR_HIGH_RATE_TRIG_SEL_8822C(x) | \
BIT_HIGH_RATE_TRIG_SEL_8822C(v))
#define BIT_SHIFT_MED_RATE_TRIG_SEL_8822C 18
#define BIT_MASK_MED_RATE_TRIG_SEL_8822C 0x3
#define BIT_MED_RATE_TRIG_SEL_8822C(x) \
(((x) & BIT_MASK_MED_RATE_TRIG_SEL_8822C) \
<< BIT_SHIFT_MED_RATE_TRIG_SEL_8822C)
#define BITS_MED_RATE_TRIG_SEL_8822C \
(BIT_MASK_MED_RATE_TRIG_SEL_8822C << BIT_SHIFT_MED_RATE_TRIG_SEL_8822C)
#define BIT_CLEAR_MED_RATE_TRIG_SEL_8822C(x) \
((x) & (~BITS_MED_RATE_TRIG_SEL_8822C))
#define BIT_GET_MED_RATE_TRIG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_MED_RATE_TRIG_SEL_8822C) & \
BIT_MASK_MED_RATE_TRIG_SEL_8822C)
#define BIT_SET_MED_RATE_TRIG_SEL_8822C(x, v) \
(BIT_CLEAR_MED_RATE_TRIG_SEL_8822C(x) | BIT_MED_RATE_TRIG_SEL_8822C(v))
#define BIT_SHIFT_LOW_RATE_TRIG_SEL_8822C 16
#define BIT_MASK_LOW_RATE_TRIG_SEL_8822C 0x3
#define BIT_LOW_RATE_TRIG_SEL_8822C(x) \
(((x) & BIT_MASK_LOW_RATE_TRIG_SEL_8822C) \
<< BIT_SHIFT_LOW_RATE_TRIG_SEL_8822C)
#define BITS_LOW_RATE_TRIG_SEL_8822C \
(BIT_MASK_LOW_RATE_TRIG_SEL_8822C << BIT_SHIFT_LOW_RATE_TRIG_SEL_8822C)
#define BIT_CLEAR_LOW_RATE_TRIG_SEL_8822C(x) \
((x) & (~BITS_LOW_RATE_TRIG_SEL_8822C))
#define BIT_GET_LOW_RATE_TRIG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_LOW_RATE_TRIG_SEL_8822C) & \
BIT_MASK_LOW_RATE_TRIG_SEL_8822C)
#define BIT_SET_LOW_RATE_TRIG_SEL_8822C(x, v) \
(BIT_CLEAR_LOW_RATE_TRIG_SEL_8822C(x) | BIT_LOW_RATE_TRIG_SEL_8822C(v))
#define BIT_SHIFT_HIGH_RATE_BD_IDX_8822C 8
#define BIT_MASK_HIGH_RATE_BD_IDX_8822C 0x7f
#define BIT_HIGH_RATE_BD_IDX_8822C(x) \
(((x) & BIT_MASK_HIGH_RATE_BD_IDX_8822C) \
<< BIT_SHIFT_HIGH_RATE_BD_IDX_8822C)
#define BITS_HIGH_RATE_BD_IDX_8822C \
(BIT_MASK_HIGH_RATE_BD_IDX_8822C << BIT_SHIFT_HIGH_RATE_BD_IDX_8822C)
#define BIT_CLEAR_HIGH_RATE_BD_IDX_8822C(x) \
((x) & (~BITS_HIGH_RATE_BD_IDX_8822C))
#define BIT_GET_HIGH_RATE_BD_IDX_8822C(x) \
(((x) >> BIT_SHIFT_HIGH_RATE_BD_IDX_8822C) & \
BIT_MASK_HIGH_RATE_BD_IDX_8822C)
#define BIT_SET_HIGH_RATE_BD_IDX_8822C(x, v) \
(BIT_CLEAR_HIGH_RATE_BD_IDX_8822C(x) | BIT_HIGH_RATE_BD_IDX_8822C(v))
#define BIT_SHIFT_LOW_RATE_BD_IDX_8822C 0
#define BIT_MASK_LOW_RATE_BD_IDX_8822C 0x7f
#define BIT_LOW_RATE_BD_IDX_8822C(x) \
(((x) & BIT_MASK_LOW_RATE_BD_IDX_8822C) \
<< BIT_SHIFT_LOW_RATE_BD_IDX_8822C)
#define BITS_LOW_RATE_BD_IDX_8822C \
(BIT_MASK_LOW_RATE_BD_IDX_8822C << BIT_SHIFT_LOW_RATE_BD_IDX_8822C)
#define BIT_CLEAR_LOW_RATE_BD_IDX_8822C(x) ((x) & (~BITS_LOW_RATE_BD_IDX_8822C))
#define BIT_GET_LOW_RATE_BD_IDX_8822C(x) \
(((x) >> BIT_SHIFT_LOW_RATE_BD_IDX_8822C) & \
BIT_MASK_LOW_RATE_BD_IDX_8822C)
#define BIT_SET_LOW_RATE_BD_IDX_8822C(x, v) \
(BIT_CLEAR_LOW_RATE_BD_IDX_8822C(x) | BIT_LOW_RATE_BD_IDX_8822C(v))
/* 2 REG_LTR_CTRL2_TIMER_THRESHOLD_8822C */
#define BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822C 24
#define BIT_MASK_RX_EMPTY_TIMER_IDX_8822C 0x7
#define BIT_RX_EMPTY_TIMER_IDX_8822C(x) \
(((x) & BIT_MASK_RX_EMPTY_TIMER_IDX_8822C) \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822C)
#define BITS_RX_EMPTY_TIMER_IDX_8822C \
(BIT_MASK_RX_EMPTY_TIMER_IDX_8822C \
<< BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822C)
#define BIT_CLEAR_RX_EMPTY_TIMER_IDX_8822C(x) \
((x) & (~BITS_RX_EMPTY_TIMER_IDX_8822C))
#define BIT_GET_RX_EMPTY_TIMER_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_EMPTY_TIMER_IDX_8822C) & \
BIT_MASK_RX_EMPTY_TIMER_IDX_8822C)
#define BIT_SET_RX_EMPTY_TIMER_IDX_8822C(x, v) \
(BIT_CLEAR_RX_EMPTY_TIMER_IDX_8822C(x) | \
BIT_RX_EMPTY_TIMER_IDX_8822C(v))
#define BIT_SHIFT_RX_AFULL_TH_IDX_8822C 20
#define BIT_MASK_RX_AFULL_TH_IDX_8822C 0x7
#define BIT_RX_AFULL_TH_IDX_8822C(x) \
(((x) & BIT_MASK_RX_AFULL_TH_IDX_8822C) \
<< BIT_SHIFT_RX_AFULL_TH_IDX_8822C)
#define BITS_RX_AFULL_TH_IDX_8822C \
(BIT_MASK_RX_AFULL_TH_IDX_8822C << BIT_SHIFT_RX_AFULL_TH_IDX_8822C)
#define BIT_CLEAR_RX_AFULL_TH_IDX_8822C(x) ((x) & (~BITS_RX_AFULL_TH_IDX_8822C))
#define BIT_GET_RX_AFULL_TH_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_AFULL_TH_IDX_8822C) & \
BIT_MASK_RX_AFULL_TH_IDX_8822C)
#define BIT_SET_RX_AFULL_TH_IDX_8822C(x, v) \
(BIT_CLEAR_RX_AFULL_TH_IDX_8822C(x) | BIT_RX_AFULL_TH_IDX_8822C(v))
#define BIT_SHIFT_RX_HIGH_TH_IDX_8822C 16
#define BIT_MASK_RX_HIGH_TH_IDX_8822C 0x7
#define BIT_RX_HIGH_TH_IDX_8822C(x) \
(((x) & BIT_MASK_RX_HIGH_TH_IDX_8822C) \
<< BIT_SHIFT_RX_HIGH_TH_IDX_8822C)
#define BITS_RX_HIGH_TH_IDX_8822C \
(BIT_MASK_RX_HIGH_TH_IDX_8822C << BIT_SHIFT_RX_HIGH_TH_IDX_8822C)
#define BIT_CLEAR_RX_HIGH_TH_IDX_8822C(x) ((x) & (~BITS_RX_HIGH_TH_IDX_8822C))
#define BIT_GET_RX_HIGH_TH_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_HIGH_TH_IDX_8822C) & \
BIT_MASK_RX_HIGH_TH_IDX_8822C)
#define BIT_SET_RX_HIGH_TH_IDX_8822C(x, v) \
(BIT_CLEAR_RX_HIGH_TH_IDX_8822C(x) | BIT_RX_HIGH_TH_IDX_8822C(v))
#define BIT_SHIFT_RX_MED_TH_IDX_8822C 12
#define BIT_MASK_RX_MED_TH_IDX_8822C 0x7
#define BIT_RX_MED_TH_IDX_8822C(x) \
(((x) & BIT_MASK_RX_MED_TH_IDX_8822C) << BIT_SHIFT_RX_MED_TH_IDX_8822C)
#define BITS_RX_MED_TH_IDX_8822C \
(BIT_MASK_RX_MED_TH_IDX_8822C << BIT_SHIFT_RX_MED_TH_IDX_8822C)
#define BIT_CLEAR_RX_MED_TH_IDX_8822C(x) ((x) & (~BITS_RX_MED_TH_IDX_8822C))
#define BIT_GET_RX_MED_TH_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_MED_TH_IDX_8822C) & BIT_MASK_RX_MED_TH_IDX_8822C)
#define BIT_SET_RX_MED_TH_IDX_8822C(x, v) \
(BIT_CLEAR_RX_MED_TH_IDX_8822C(x) | BIT_RX_MED_TH_IDX_8822C(v))
#define BIT_SHIFT_RX_LOW_TH_IDX_8822C 8
#define BIT_MASK_RX_LOW_TH_IDX_8822C 0x7
#define BIT_RX_LOW_TH_IDX_8822C(x) \
(((x) & BIT_MASK_RX_LOW_TH_IDX_8822C) << BIT_SHIFT_RX_LOW_TH_IDX_8822C)
#define BITS_RX_LOW_TH_IDX_8822C \
(BIT_MASK_RX_LOW_TH_IDX_8822C << BIT_SHIFT_RX_LOW_TH_IDX_8822C)
#define BIT_CLEAR_RX_LOW_TH_IDX_8822C(x) ((x) & (~BITS_RX_LOW_TH_IDX_8822C))
#define BIT_GET_RX_LOW_TH_IDX_8822C(x) \
(((x) >> BIT_SHIFT_RX_LOW_TH_IDX_8822C) & BIT_MASK_RX_LOW_TH_IDX_8822C)
#define BIT_SET_RX_LOW_TH_IDX_8822C(x, v) \
(BIT_CLEAR_RX_LOW_TH_IDX_8822C(x) | BIT_RX_LOW_TH_IDX_8822C(v))
#define BIT_SHIFT_LTR_SPACE_IDX_8822C 4
#define BIT_MASK_LTR_SPACE_IDX_8822C 0x3
#define BIT_LTR_SPACE_IDX_8822C(x) \
(((x) & BIT_MASK_LTR_SPACE_IDX_8822C) << BIT_SHIFT_LTR_SPACE_IDX_8822C)
#define BITS_LTR_SPACE_IDX_8822C \
(BIT_MASK_LTR_SPACE_IDX_8822C << BIT_SHIFT_LTR_SPACE_IDX_8822C)
#define BIT_CLEAR_LTR_SPACE_IDX_8822C(x) ((x) & (~BITS_LTR_SPACE_IDX_8822C))
#define BIT_GET_LTR_SPACE_IDX_8822C(x) \
(((x) >> BIT_SHIFT_LTR_SPACE_IDX_8822C) & BIT_MASK_LTR_SPACE_IDX_8822C)
#define BIT_SET_LTR_SPACE_IDX_8822C(x, v) \
(BIT_CLEAR_LTR_SPACE_IDX_8822C(x) | BIT_LTR_SPACE_IDX_8822C(v))
#define BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822C 0
#define BIT_MASK_LTR_IDLE_TIMER_IDX_8822C 0x7
#define BIT_LTR_IDLE_TIMER_IDX_8822C(x) \
(((x) & BIT_MASK_LTR_IDLE_TIMER_IDX_8822C) \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822C)
#define BITS_LTR_IDLE_TIMER_IDX_8822C \
(BIT_MASK_LTR_IDLE_TIMER_IDX_8822C \
<< BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822C)
#define BIT_CLEAR_LTR_IDLE_TIMER_IDX_8822C(x) \
((x) & (~BITS_LTR_IDLE_TIMER_IDX_8822C))
#define BIT_GET_LTR_IDLE_TIMER_IDX_8822C(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_TIMER_IDX_8822C) & \
BIT_MASK_LTR_IDLE_TIMER_IDX_8822C)
#define BIT_SET_LTR_IDLE_TIMER_IDX_8822C(x, v) \
(BIT_CLEAR_LTR_IDLE_TIMER_IDX_8822C(x) | \
BIT_LTR_IDLE_TIMER_IDX_8822C(v))
/* 2 REG_LTR_IDLE_LATENCY_V1_8822C */
#define BIT_SHIFT_LTR_IDLE_L_8822C 0
#define BIT_MASK_LTR_IDLE_L_8822C 0xffffffffL
#define BIT_LTR_IDLE_L_8822C(x) \
(((x) & BIT_MASK_LTR_IDLE_L_8822C) << BIT_SHIFT_LTR_IDLE_L_8822C)
#define BITS_LTR_IDLE_L_8822C \
(BIT_MASK_LTR_IDLE_L_8822C << BIT_SHIFT_LTR_IDLE_L_8822C)
#define BIT_CLEAR_LTR_IDLE_L_8822C(x) ((x) & (~BITS_LTR_IDLE_L_8822C))
#define BIT_GET_LTR_IDLE_L_8822C(x) \
(((x) >> BIT_SHIFT_LTR_IDLE_L_8822C) & BIT_MASK_LTR_IDLE_L_8822C)
#define BIT_SET_LTR_IDLE_L_8822C(x, v) \
(BIT_CLEAR_LTR_IDLE_L_8822C(x) | BIT_LTR_IDLE_L_8822C(v))
/* 2 REG_LTR_ACTIVE_LATENCY_V1_8822C */
#define BIT_SHIFT_LTR_ACT_L_8822C 0
#define BIT_MASK_LTR_ACT_L_8822C 0xffffffffL
#define BIT_LTR_ACT_L_8822C(x) \
(((x) & BIT_MASK_LTR_ACT_L_8822C) << BIT_SHIFT_LTR_ACT_L_8822C)
#define BITS_LTR_ACT_L_8822C \
(BIT_MASK_LTR_ACT_L_8822C << BIT_SHIFT_LTR_ACT_L_8822C)
#define BIT_CLEAR_LTR_ACT_L_8822C(x) ((x) & (~BITS_LTR_ACT_L_8822C))
#define BIT_GET_LTR_ACT_L_8822C(x) \
(((x) >> BIT_SHIFT_LTR_ACT_L_8822C) & BIT_MASK_LTR_ACT_L_8822C)
#define BIT_SET_LTR_ACT_L_8822C(x, v) \
(BIT_CLEAR_LTR_ACT_L_8822C(x) | BIT_LTR_ACT_L_8822C(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_8822C */
#define BIT_SHIFT_TRAIN_STA_ADDR_0_8822C 0
#define BIT_MASK_TRAIN_STA_ADDR_0_8822C 0xffffffffL
#define BIT_TRAIN_STA_ADDR_0_8822C(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_0_8822C) \
<< BIT_SHIFT_TRAIN_STA_ADDR_0_8822C)
#define BITS_TRAIN_STA_ADDR_0_8822C \
(BIT_MASK_TRAIN_STA_ADDR_0_8822C << BIT_SHIFT_TRAIN_STA_ADDR_0_8822C)
#define BIT_CLEAR_TRAIN_STA_ADDR_0_8822C(x) \
((x) & (~BITS_TRAIN_STA_ADDR_0_8822C))
#define BIT_GET_TRAIN_STA_ADDR_0_8822C(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_0_8822C) & \
BIT_MASK_TRAIN_STA_ADDR_0_8822C)
#define BIT_SET_TRAIN_STA_ADDR_0_8822C(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_0_8822C(x) | BIT_TRAIN_STA_ADDR_0_8822C(v))
/* 2 REG_ANTENNA_TRAINING_CONTROL_REGISTER_1_8822C */
#define BIT_ANTTRN_SWITCH_8822C BIT(19)
#define BIT_APPEND_MACID_IN_RESP_EN_1_8822C BIT(18)
#define BIT_ADDR2_MATCH_EN_1_8822C BIT(17)
#define BIT_ANTTRN_EN_1_8822C BIT(16)
#define BIT_SHIFT_TRAIN_STA_ADDR_1_8822C 0
#define BIT_MASK_TRAIN_STA_ADDR_1_8822C 0xffff
#define BIT_TRAIN_STA_ADDR_1_8822C(x) \
(((x) & BIT_MASK_TRAIN_STA_ADDR_1_8822C) \
<< BIT_SHIFT_TRAIN_STA_ADDR_1_8822C)
#define BITS_TRAIN_STA_ADDR_1_8822C \
(BIT_MASK_TRAIN_STA_ADDR_1_8822C << BIT_SHIFT_TRAIN_STA_ADDR_1_8822C)
#define BIT_CLEAR_TRAIN_STA_ADDR_1_8822C(x) \
((x) & (~BITS_TRAIN_STA_ADDR_1_8822C))
#define BIT_GET_TRAIN_STA_ADDR_1_8822C(x) \
(((x) >> BIT_SHIFT_TRAIN_STA_ADDR_1_8822C) & \
BIT_MASK_TRAIN_STA_ADDR_1_8822C)
#define BIT_SET_TRAIN_STA_ADDR_1_8822C(x, v) \
(BIT_CLEAR_TRAIN_STA_ADDR_1_8822C(x) | BIT_TRAIN_STA_ADDR_1_8822C(v))
/* 2 REG_WMAC_PKTCNT_RWD_8822C */
#define BIT_SHIFT_PKTCNT_BSSIDMAP_8822C 4
#define BIT_MASK_PKTCNT_BSSIDMAP_8822C 0xf
#define BIT_PKTCNT_BSSIDMAP_8822C(x) \
(((x) & BIT_MASK_PKTCNT_BSSIDMAP_8822C) \
<< BIT_SHIFT_PKTCNT_BSSIDMAP_8822C)
#define BITS_PKTCNT_BSSIDMAP_8822C \
(BIT_MASK_PKTCNT_BSSIDMAP_8822C << BIT_SHIFT_PKTCNT_BSSIDMAP_8822C)
#define BIT_CLEAR_PKTCNT_BSSIDMAP_8822C(x) ((x) & (~BITS_PKTCNT_BSSIDMAP_8822C))
#define BIT_GET_PKTCNT_BSSIDMAP_8822C(x) \
(((x) >> BIT_SHIFT_PKTCNT_BSSIDMAP_8822C) & \
BIT_MASK_PKTCNT_BSSIDMAP_8822C)
#define BIT_SET_PKTCNT_BSSIDMAP_8822C(x, v) \
(BIT_CLEAR_PKTCNT_BSSIDMAP_8822C(x) | BIT_PKTCNT_BSSIDMAP_8822C(v))
#define BIT_PKTCNT_CNTRST_8822C BIT(1)
#define BIT_PKTCNT_CNTEN_8822C BIT(0)
/* 2 REG_WMAC_PKTCNT_CTRL_8822C */
#define BIT_WMAC_PKTCNT_TRST_8822C BIT(9)
#define BIT_WMAC_PKTCNT_FEN_8822C BIT(8)
#define BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822C 0
#define BIT_MASK_WMAC_PKTCNT_CFGAD_8822C 0xff
#define BIT_WMAC_PKTCNT_CFGAD_8822C(x) \
(((x) & BIT_MASK_WMAC_PKTCNT_CFGAD_8822C) \
<< BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822C)
#define BITS_WMAC_PKTCNT_CFGAD_8822C \
(BIT_MASK_WMAC_PKTCNT_CFGAD_8822C << BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822C)
#define BIT_CLEAR_WMAC_PKTCNT_CFGAD_8822C(x) \
((x) & (~BITS_WMAC_PKTCNT_CFGAD_8822C))
#define BIT_GET_WMAC_PKTCNT_CFGAD_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_PKTCNT_CFGAD_8822C) & \
BIT_MASK_WMAC_PKTCNT_CFGAD_8822C)
#define BIT_SET_WMAC_PKTCNT_CFGAD_8822C(x, v) \
(BIT_CLEAR_WMAC_PKTCNT_CFGAD_8822C(x) | BIT_WMAC_PKTCNT_CFGAD_8822C(v))
/* 2 REG_IQ_DUMP_8822C */
#define BIT_SHIFT_DUMP_OK_ADDR_8822C 16
#define BIT_MASK_DUMP_OK_ADDR_8822C 0xffff
#define BIT_DUMP_OK_ADDR_8822C(x) \
(((x) & BIT_MASK_DUMP_OK_ADDR_8822C) << BIT_SHIFT_DUMP_OK_ADDR_8822C)
#define BITS_DUMP_OK_ADDR_8822C \
(BIT_MASK_DUMP_OK_ADDR_8822C << BIT_SHIFT_DUMP_OK_ADDR_8822C)
#define BIT_CLEAR_DUMP_OK_ADDR_8822C(x) ((x) & (~BITS_DUMP_OK_ADDR_8822C))
#define BIT_GET_DUMP_OK_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_DUMP_OK_ADDR_8822C) & BIT_MASK_DUMP_OK_ADDR_8822C)
#define BIT_SET_DUMP_OK_ADDR_8822C(x, v) \
(BIT_CLEAR_DUMP_OK_ADDR_8822C(x) | BIT_DUMP_OK_ADDR_8822C(v))
#define BIT_MACDBG_TRIG_IQDUMP_8822C BIT(15)
#define BIT_SHIFT_R_TRIG_TIME_SEL_8822C 8
#define BIT_MASK_R_TRIG_TIME_SEL_8822C 0x7f
#define BIT_R_TRIG_TIME_SEL_8822C(x) \
(((x) & BIT_MASK_R_TRIG_TIME_SEL_8822C) \
<< BIT_SHIFT_R_TRIG_TIME_SEL_8822C)
#define BITS_R_TRIG_TIME_SEL_8822C \
(BIT_MASK_R_TRIG_TIME_SEL_8822C << BIT_SHIFT_R_TRIG_TIME_SEL_8822C)
#define BIT_CLEAR_R_TRIG_TIME_SEL_8822C(x) ((x) & (~BITS_R_TRIG_TIME_SEL_8822C))
#define BIT_GET_R_TRIG_TIME_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_TRIG_TIME_SEL_8822C) & \
BIT_MASK_R_TRIG_TIME_SEL_8822C)
#define BIT_SET_R_TRIG_TIME_SEL_8822C(x, v) \
(BIT_CLEAR_R_TRIG_TIME_SEL_8822C(x) | BIT_R_TRIG_TIME_SEL_8822C(v))
#define BIT_SHIFT_R_MAC_TRIG_SEL_8822C 6
#define BIT_MASK_R_MAC_TRIG_SEL_8822C 0x3
#define BIT_R_MAC_TRIG_SEL_8822C(x) \
(((x) & BIT_MASK_R_MAC_TRIG_SEL_8822C) \
<< BIT_SHIFT_R_MAC_TRIG_SEL_8822C)
#define BITS_R_MAC_TRIG_SEL_8822C \
(BIT_MASK_R_MAC_TRIG_SEL_8822C << BIT_SHIFT_R_MAC_TRIG_SEL_8822C)
#define BIT_CLEAR_R_MAC_TRIG_SEL_8822C(x) ((x) & (~BITS_R_MAC_TRIG_SEL_8822C))
#define BIT_GET_R_MAC_TRIG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_MAC_TRIG_SEL_8822C) & \
BIT_MASK_R_MAC_TRIG_SEL_8822C)
#define BIT_SET_R_MAC_TRIG_SEL_8822C(x, v) \
(BIT_CLEAR_R_MAC_TRIG_SEL_8822C(x) | BIT_R_MAC_TRIG_SEL_8822C(v))
#define BIT_MAC_TRIG_REG_8822C BIT(5)
#define BIT_SHIFT_R_LEVEL_PULSE_SEL_8822C 3
#define BIT_MASK_R_LEVEL_PULSE_SEL_8822C 0x3
#define BIT_R_LEVEL_PULSE_SEL_8822C(x) \
(((x) & BIT_MASK_R_LEVEL_PULSE_SEL_8822C) \
<< BIT_SHIFT_R_LEVEL_PULSE_SEL_8822C)
#define BITS_R_LEVEL_PULSE_SEL_8822C \
(BIT_MASK_R_LEVEL_PULSE_SEL_8822C << BIT_SHIFT_R_LEVEL_PULSE_SEL_8822C)
#define BIT_CLEAR_R_LEVEL_PULSE_SEL_8822C(x) \
((x) & (~BITS_R_LEVEL_PULSE_SEL_8822C))
#define BIT_GET_R_LEVEL_PULSE_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_LEVEL_PULSE_SEL_8822C) & \
BIT_MASK_R_LEVEL_PULSE_SEL_8822C)
#define BIT_SET_R_LEVEL_PULSE_SEL_8822C(x, v) \
(BIT_CLEAR_R_LEVEL_PULSE_SEL_8822C(x) | BIT_R_LEVEL_PULSE_SEL_8822C(v))
#define BIT_EN_LA_MAC_8822C BIT(2)
#define BIT_R_EN_IQDUMP_8822C BIT(1)
#define BIT_R_IQDATA_DUMP_8822C BIT(0)
/* 2 REG_IQ_DUMP_1_8822C */
#define BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8822C 0
#define BIT_MASK_R_WMAC_MASK_LA_MAC_1_8822C 0xffffffffL
#define BIT_R_WMAC_MASK_LA_MAC_1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_MASK_LA_MAC_1_8822C) \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8822C)
#define BITS_R_WMAC_MASK_LA_MAC_1_8822C \
(BIT_MASK_R_WMAC_MASK_LA_MAC_1_8822C \
<< BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8822C)
#define BIT_CLEAR_R_WMAC_MASK_LA_MAC_1_8822C(x) \
((x) & (~BITS_R_WMAC_MASK_LA_MAC_1_8822C))
#define BIT_GET_R_WMAC_MASK_LA_MAC_1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_MASK_LA_MAC_1_8822C) & \
BIT_MASK_R_WMAC_MASK_LA_MAC_1_8822C)
#define BIT_SET_R_WMAC_MASK_LA_MAC_1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_MASK_LA_MAC_1_8822C(x) | \
BIT_R_WMAC_MASK_LA_MAC_1_8822C(v))
/* 2 REG_IQ_DUMP_2_8822C */
#define BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8822C 0
#define BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8822C 0xffffffffL
#define BIT_R_WMAC_MATCH_REF_MAC_2_8822C(x) \
(((x) & BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8822C) \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8822C)
#define BITS_R_WMAC_MATCH_REF_MAC_2_8822C \
(BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8822C \
<< BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8822C)
#define BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2_8822C(x) \
((x) & (~BITS_R_WMAC_MATCH_REF_MAC_2_8822C))
#define BIT_GET_R_WMAC_MATCH_REF_MAC_2_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_MATCH_REF_MAC_2_8822C) & \
BIT_MASK_R_WMAC_MATCH_REF_MAC_2_8822C)
#define BIT_SET_R_WMAC_MATCH_REF_MAC_2_8822C(x, v) \
(BIT_CLEAR_R_WMAC_MATCH_REF_MAC_2_8822C(x) | \
BIT_R_WMAC_MATCH_REF_MAC_2_8822C(v))
/* 2 REG_WMAC_FTM_CTL_8822C */
#define BIT_RXFTM_TXACK_SC_8822C BIT(6)
#define BIT_RXFTM_TXACK_BW_8822C BIT(5)
#define BIT_RXFTM_EN_8822C BIT(3)
#define BIT_RXFTMREQ_BYDRV_8822C BIT(2)
#define BIT_RXFTMREQ_EN_8822C BIT(1)
#define BIT_FTM_EN_8822C BIT(0)
/* 2 REG_WMAC_IQ_MDPK_FUNC_8822C */
/* 2 REG_WMAC_OPTION_FUNCTION_8822C */
#define BIT_SHIFT_R_OFDM_LEN_V1_8822C 16
#define BIT_MASK_R_OFDM_LEN_V1_8822C 0xffff
#define BIT_R_OFDM_LEN_V1_8822C(x) \
(((x) & BIT_MASK_R_OFDM_LEN_V1_8822C) << BIT_SHIFT_R_OFDM_LEN_V1_8822C)
#define BITS_R_OFDM_LEN_V1_8822C \
(BIT_MASK_R_OFDM_LEN_V1_8822C << BIT_SHIFT_R_OFDM_LEN_V1_8822C)
#define BIT_CLEAR_R_OFDM_LEN_V1_8822C(x) ((x) & (~BITS_R_OFDM_LEN_V1_8822C))
#define BIT_GET_R_OFDM_LEN_V1_8822C(x) \
(((x) >> BIT_SHIFT_R_OFDM_LEN_V1_8822C) & BIT_MASK_R_OFDM_LEN_V1_8822C)
#define BIT_SET_R_OFDM_LEN_V1_8822C(x, v) \
(BIT_CLEAR_R_OFDM_LEN_V1_8822C(x) | BIT_R_OFDM_LEN_V1_8822C(v))
#define BIT_SHIFT_R_CCK_LEN_8822C 0
#define BIT_MASK_R_CCK_LEN_8822C 0xffff
#define BIT_R_CCK_LEN_8822C(x) \
(((x) & BIT_MASK_R_CCK_LEN_8822C) << BIT_SHIFT_R_CCK_LEN_8822C)
#define BITS_R_CCK_LEN_8822C \
(BIT_MASK_R_CCK_LEN_8822C << BIT_SHIFT_R_CCK_LEN_8822C)
#define BIT_CLEAR_R_CCK_LEN_8822C(x) ((x) & (~BITS_R_CCK_LEN_8822C))
#define BIT_GET_R_CCK_LEN_8822C(x) \
(((x) >> BIT_SHIFT_R_CCK_LEN_8822C) & BIT_MASK_R_CCK_LEN_8822C)
#define BIT_SET_R_CCK_LEN_8822C(x, v) \
(BIT_CLEAR_R_CCK_LEN_8822C(x) | BIT_R_CCK_LEN_8822C(v))
/* 2 REG_WMAC_OPTION_FUNCTION_1_8822C */
#define BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8822C 24
#define BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8822C 0xff
#define BIT_R_WMAC_RXFIFO_FULL_TH_1_8822C(x) \
(((x) & BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8822C) \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8822C)
#define BITS_R_WMAC_RXFIFO_FULL_TH_1_8822C \
(BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8822C \
<< BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8822C)
#define BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1_8822C(x) \
((x) & (~BITS_R_WMAC_RXFIFO_FULL_TH_1_8822C))
#define BIT_GET_R_WMAC_RXFIFO_FULL_TH_1_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RXFIFO_FULL_TH_1_8822C) & \
BIT_MASK_R_WMAC_RXFIFO_FULL_TH_1_8822C)
#define BIT_SET_R_WMAC_RXFIFO_FULL_TH_1_8822C(x, v) \
(BIT_CLEAR_R_WMAC_RXFIFO_FULL_TH_1_8822C(x) | \
BIT_R_WMAC_RXFIFO_FULL_TH_1_8822C(v))
#define BIT_R_WMAC_RX_SYNCFIFO_SYNC_1_8822C BIT(23)
#define BIT_R_WMAC_RXRST_DLY_1_8822C BIT(22)
#define BIT_R_WMAC_SRCH_TXRPT_REF_DROP_1_8822C BIT(21)
#define BIT_R_WMAC_SRCH_TXRPT_UA1_1_8822C BIT(20)
#define BIT_R_WMAC_SRCH_TXRPT_TYPE_1_8822C BIT(19)
#define BIT_R_WMAC_NDP_RST_1_8822C BIT(18)
#define BIT_R_WMAC_POWINT_EN_1_8822C BIT(17)
#define BIT_R_WMAC_SRCH_TXRPT_PERPKT_1_8822C BIT(16)
#define BIT_R_WMAC_SRCH_TXRPT_MID_1_8822C BIT(15)
#define BIT_R_WMAC_PFIN_TOEN_1_8822C BIT(14)
#define BIT_R_WMAC_FIL_SECERR_1_8822C BIT(13)
#define BIT_R_WMAC_FIL_CTLPKTLEN_1_8822C BIT(12)
#define BIT_R_WMAC_FIL_FCTYPE_1_8822C BIT(11)
#define BIT_R_WMAC_FIL_FCPROVER_1_8822C BIT(10)
#define BIT_R_WMAC_PHYSTS_SNIF_1_8822C BIT(9)
#define BIT_R_WMAC_PHYSTS_PLCP_1_8822C BIT(8)
#define BIT_R_MAC_TCR_VBONF_RD_1_8822C BIT(7)
#define BIT_R_WMAC_TCR_MPAR_NDP_1_8822C BIT(6)
#define BIT_R_WMAC_NDP_FILTER_1_8822C BIT(5)
#define BIT_R_WMAC_RXLEN_SEL_1_8822C BIT(4)
#define BIT_R_WMAC_RXLEN_SEL1_1_8822C BIT(3)
#define BIT_R_OFDM_FILTER_1_8822C BIT(2)
#define BIT_R_WMAC_CHK_OFDM_LEN_1_8822C BIT(1)
#define BIT_R_WMAC_CHK_CCK_LEN_1_8822C BIT(0)
/* 2 REG_WMAC_OPTION_FUNCTION_2_8822C */
#define BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8822C 0
#define BIT_MASK_R_WMAC_RX_FIL_LEN_2_8822C 0xffff
#define BIT_R_WMAC_RX_FIL_LEN_2_8822C(x) \
(((x) & BIT_MASK_R_WMAC_RX_FIL_LEN_2_8822C) \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8822C)
#define BITS_R_WMAC_RX_FIL_LEN_2_8822C \
(BIT_MASK_R_WMAC_RX_FIL_LEN_2_8822C \
<< BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8822C)
#define BIT_CLEAR_R_WMAC_RX_FIL_LEN_2_8822C(x) \
((x) & (~BITS_R_WMAC_RX_FIL_LEN_2_8822C))
#define BIT_GET_R_WMAC_RX_FIL_LEN_2_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_RX_FIL_LEN_2_8822C) & \
BIT_MASK_R_WMAC_RX_FIL_LEN_2_8822C)
#define BIT_SET_R_WMAC_RX_FIL_LEN_2_8822C(x, v) \
(BIT_CLEAR_R_WMAC_RX_FIL_LEN_2_8822C(x) | \
BIT_R_WMAC_RX_FIL_LEN_2_8822C(v))
/* 2 REG_RX_FILTER_FUNCTION_8822C */
#define BIT_RXHANG_EN_8822C BIT(15)
#define BIT_R_WMAC_MHRDDY_LATCH_8822C BIT(14)
#define BIT_R_WMAC_MHRDDY_CLR_8822C BIT(13)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY1_8822C BIT(12)
#define BIT_WMAC_DIS_VHT_PLCP_CHK_MU_8822C BIT(11)
#define BIT_R_CHK_DELIMIT_LEN_8822C BIT(10)
#define BIT_R_REAPTER_ADDR_MATCH_8822C BIT(9)
#define BIT_R_RXPKTCTL_FSM_BASED_MPDURDY_8822C BIT(8)
#define BIT_R_LATCH_MACHRDY_8822C BIT(7)
#define BIT_R_WMAC_RXFIL_REND_8822C BIT(6)
#define BIT_R_WMAC_MPDURDY_CLR_8822C BIT(5)
#define BIT_R_WMAC_CLRRXSEC_8822C BIT(4)
#define BIT_R_WMAC_RXFIL_RDEL_8822C BIT(3)
#define BIT_R_WMAC_RXFIL_FCSE_8822C BIT(2)
#define BIT_R_WMAC_RXFIL_MESH_DEL_8822C BIT(1)
#define BIT_R_WMAC_RXFIL_MASKM_8822C BIT(0)
/* 2 REG_NDP_SIG_8822C */
#define BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822C 0
#define BIT_MASK_R_WMAC_TXNDP_SIGB_8822C 0x1fffff
#define BIT_R_WMAC_TXNDP_SIGB_8822C(x) \
(((x) & BIT_MASK_R_WMAC_TXNDP_SIGB_8822C) \
<< BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822C)
#define BITS_R_WMAC_TXNDP_SIGB_8822C \
(BIT_MASK_R_WMAC_TXNDP_SIGB_8822C << BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822C)
#define BIT_CLEAR_R_WMAC_TXNDP_SIGB_8822C(x) \
((x) & (~BITS_R_WMAC_TXNDP_SIGB_8822C))
#define BIT_GET_R_WMAC_TXNDP_SIGB_8822C(x) \
(((x) >> BIT_SHIFT_R_WMAC_TXNDP_SIGB_8822C) & \
BIT_MASK_R_WMAC_TXNDP_SIGB_8822C)
#define BIT_SET_R_WMAC_TXNDP_SIGB_8822C(x, v) \
(BIT_CLEAR_R_WMAC_TXNDP_SIGB_8822C(x) | BIT_R_WMAC_TXNDP_SIGB_8822C(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_8822C */
#define BIT_SHIFT_R_MAC_DBG_SHIFT_8822C 8
#define BIT_MASK_R_MAC_DBG_SHIFT_8822C 0x7
#define BIT_R_MAC_DBG_SHIFT_8822C(x) \
(((x) & BIT_MASK_R_MAC_DBG_SHIFT_8822C) \
<< BIT_SHIFT_R_MAC_DBG_SHIFT_8822C)
#define BITS_R_MAC_DBG_SHIFT_8822C \
(BIT_MASK_R_MAC_DBG_SHIFT_8822C << BIT_SHIFT_R_MAC_DBG_SHIFT_8822C)
#define BIT_CLEAR_R_MAC_DBG_SHIFT_8822C(x) ((x) & (~BITS_R_MAC_DBG_SHIFT_8822C))
#define BIT_GET_R_MAC_DBG_SHIFT_8822C(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SHIFT_8822C) & \
BIT_MASK_R_MAC_DBG_SHIFT_8822C)
#define BIT_SET_R_MAC_DBG_SHIFT_8822C(x, v) \
(BIT_CLEAR_R_MAC_DBG_SHIFT_8822C(x) | BIT_R_MAC_DBG_SHIFT_8822C(v))
#define BIT_SHIFT_R_MAC_DBG_SEL_8822C 0
#define BIT_MASK_R_MAC_DBG_SEL_8822C 0x3
#define BIT_R_MAC_DBG_SEL_8822C(x) \
(((x) & BIT_MASK_R_MAC_DBG_SEL_8822C) << BIT_SHIFT_R_MAC_DBG_SEL_8822C)
#define BITS_R_MAC_DBG_SEL_8822C \
(BIT_MASK_R_MAC_DBG_SEL_8822C << BIT_SHIFT_R_MAC_DBG_SEL_8822C)
#define BIT_CLEAR_R_MAC_DBG_SEL_8822C(x) ((x) & (~BITS_R_MAC_DBG_SEL_8822C))
#define BIT_GET_R_MAC_DBG_SEL_8822C(x) \
(((x) >> BIT_SHIFT_R_MAC_DBG_SEL_8822C) & BIT_MASK_R_MAC_DBG_SEL_8822C)
#define BIT_SET_R_MAC_DBG_SEL_8822C(x, v) \
(BIT_CLEAR_R_MAC_DBG_SEL_8822C(x) | BIT_R_MAC_DBG_SEL_8822C(v))
/* 2 REG_TXCMD_INFO_FOR_RSP_PKT_1_8822C */
#define BIT_SHIFT_R_MAC_DEBUG_1_8822C 0
#define BIT_MASK_R_MAC_DEBUG_1_8822C 0xffffffffL
#define BIT_R_MAC_DEBUG_1_8822C(x) \
(((x) & BIT_MASK_R_MAC_DEBUG_1_8822C) << BIT_SHIFT_R_MAC_DEBUG_1_8822C)
#define BITS_R_MAC_DEBUG_1_8822C \
(BIT_MASK_R_MAC_DEBUG_1_8822C << BIT_SHIFT_R_MAC_DEBUG_1_8822C)
#define BIT_CLEAR_R_MAC_DEBUG_1_8822C(x) ((x) & (~BITS_R_MAC_DEBUG_1_8822C))
#define BIT_GET_R_MAC_DEBUG_1_8822C(x) \
(((x) >> BIT_SHIFT_R_MAC_DEBUG_1_8822C) & BIT_MASK_R_MAC_DEBUG_1_8822C)
#define BIT_SET_R_MAC_DEBUG_1_8822C(x, v) \
(BIT_CLEAR_R_MAC_DEBUG_1_8822C(x) | BIT_R_MAC_DEBUG_1_8822C(v))
/* 2 REG_WSEC_OPTION_8822C */
#define BIT_RXDEC_BM_MGNT_8822C BIT(22)
#define BIT_TXENC_BM_MGNT_8822C BIT(21)
#define BIT_RXDEC_UNI_MGNT_8822C BIT(20)
#define BIT_TXENC_UNI_MGNT_8822C BIT(19)
#define BIT_WMAC_SEC_MASKIV_8822C BIT(18)
#define BIT_SHIFT_WMAC_SEC_PN_SEL_8822C 16
#define BIT_MASK_WMAC_SEC_PN_SEL_8822C 0x3
#define BIT_WMAC_SEC_PN_SEL_8822C(x) \
(((x) & BIT_MASK_WMAC_SEC_PN_SEL_8822C) \
<< BIT_SHIFT_WMAC_SEC_PN_SEL_8822C)
#define BITS_WMAC_SEC_PN_SEL_8822C \
(BIT_MASK_WMAC_SEC_PN_SEL_8822C << BIT_SHIFT_WMAC_SEC_PN_SEL_8822C)
#define BIT_CLEAR_WMAC_SEC_PN_SEL_8822C(x) ((x) & (~BITS_WMAC_SEC_PN_SEL_8822C))
#define BIT_GET_WMAC_SEC_PN_SEL_8822C(x) \
(((x) >> BIT_SHIFT_WMAC_SEC_PN_SEL_8822C) & \
BIT_MASK_WMAC_SEC_PN_SEL_8822C)
#define BIT_SET_WMAC_SEC_PN_SEL_8822C(x, v) \
(BIT_CLEAR_WMAC_SEC_PN_SEL_8822C(x) | BIT_WMAC_SEC_PN_SEL_8822C(v))
#define BIT_SHIFT_BT_TIME_CNT_8822C 0
#define BIT_MASK_BT_TIME_CNT_8822C 0xff
#define BIT_BT_TIME_CNT_8822C(x) \
(((x) & BIT_MASK_BT_TIME_CNT_8822C) << BIT_SHIFT_BT_TIME_CNT_8822C)
#define BITS_BT_TIME_CNT_8822C \
(BIT_MASK_BT_TIME_CNT_8822C << BIT_SHIFT_BT_TIME_CNT_8822C)
#define BIT_CLEAR_BT_TIME_CNT_8822C(x) ((x) & (~BITS_BT_TIME_CNT_8822C))
#define BIT_GET_BT_TIME_CNT_8822C(x) \
(((x) >> BIT_SHIFT_BT_TIME_CNT_8822C) & BIT_MASK_BT_TIME_CNT_8822C)
#define BIT_SET_BT_TIME_CNT_8822C(x, v) \
(BIT_CLEAR_BT_TIME_CNT_8822C(x) | BIT_BT_TIME_CNT_8822C(v))
/* 2 REG_RTS_ADDRESS_0_8822C */
/* 2 REG_RTS_ADDRESS_0_1_8822C */
/* 2 REG_RTS_ADDRESS_1_8822C */
/* 2 REG_RTS_ADDRESS_1_1_8822C */
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8822C */
#define BIT_LTECOEX_ACCESS_START_V1_8822C BIT(31)
#define BIT_LTECOEX_WRITE_MODE_V1_8822C BIT(30)
#define BIT_LTECOEX_READY_BIT_V1_8822C BIT(29)
#define BIT_SHIFT_WRITE_BYTE_EN_V1_8822C 16
#define BIT_MASK_WRITE_BYTE_EN_V1_8822C 0xf
#define BIT_WRITE_BYTE_EN_V1_8822C(x) \
(((x) & BIT_MASK_WRITE_BYTE_EN_V1_8822C) \
<< BIT_SHIFT_WRITE_BYTE_EN_V1_8822C)
#define BITS_WRITE_BYTE_EN_V1_8822C \
(BIT_MASK_WRITE_BYTE_EN_V1_8822C << BIT_SHIFT_WRITE_BYTE_EN_V1_8822C)
#define BIT_CLEAR_WRITE_BYTE_EN_V1_8822C(x) \
((x) & (~BITS_WRITE_BYTE_EN_V1_8822C))
#define BIT_GET_WRITE_BYTE_EN_V1_8822C(x) \
(((x) >> BIT_SHIFT_WRITE_BYTE_EN_V1_8822C) & \
BIT_MASK_WRITE_BYTE_EN_V1_8822C)
#define BIT_SET_WRITE_BYTE_EN_V1_8822C(x, v) \
(BIT_CLEAR_WRITE_BYTE_EN_V1_8822C(x) | BIT_WRITE_BYTE_EN_V1_8822C(v))
#define BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822C 0
#define BIT_MASK_LTECOEX_REG_ADDR_V1_8822C 0xffff
#define BIT_LTECOEX_REG_ADDR_V1_8822C(x) \
(((x) & BIT_MASK_LTECOEX_REG_ADDR_V1_8822C) \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822C)
#define BITS_LTECOEX_REG_ADDR_V1_8822C \
(BIT_MASK_LTECOEX_REG_ADDR_V1_8822C \
<< BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822C)
#define BIT_CLEAR_LTECOEX_REG_ADDR_V1_8822C(x) \
((x) & (~BITS_LTECOEX_REG_ADDR_V1_8822C))
#define BIT_GET_LTECOEX_REG_ADDR_V1_8822C(x) \
(((x) >> BIT_SHIFT_LTECOEX_REG_ADDR_V1_8822C) & \
BIT_MASK_LTECOEX_REG_ADDR_V1_8822C)
#define BIT_SET_LTECOEX_REG_ADDR_V1_8822C(x, v) \
(BIT_CLEAR_LTECOEX_REG_ADDR_V1_8822C(x) | \
BIT_LTECOEX_REG_ADDR_V1_8822C(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8822C */
#define BIT_SHIFT_LTECOEX_W_DATA_V1_8822C 0
#define BIT_MASK_LTECOEX_W_DATA_V1_8822C 0xffffffffL
#define BIT_LTECOEX_W_DATA_V1_8822C(x) \
(((x) & BIT_MASK_LTECOEX_W_DATA_V1_8822C) \
<< BIT_SHIFT_LTECOEX_W_DATA_V1_8822C)
#define BITS_LTECOEX_W_DATA_V1_8822C \
(BIT_MASK_LTECOEX_W_DATA_V1_8822C << BIT_SHIFT_LTECOEX_W_DATA_V1_8822C)
#define BIT_CLEAR_LTECOEX_W_DATA_V1_8822C(x) \
((x) & (~BITS_LTECOEX_W_DATA_V1_8822C))
#define BIT_GET_LTECOEX_W_DATA_V1_8822C(x) \
(((x) >> BIT_SHIFT_LTECOEX_W_DATA_V1_8822C) & \
BIT_MASK_LTECOEX_W_DATA_V1_8822C)
#define BIT_SET_LTECOEX_W_DATA_V1_8822C(x, v) \
(BIT_CLEAR_LTECOEX_W_DATA_V1_8822C(x) | BIT_LTECOEX_W_DATA_V1_8822C(v))
/* 2 REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8822C */
#define BIT_SHIFT_LTECOEX_R_DATA_V1_8822C 0
#define BIT_MASK_LTECOEX_R_DATA_V1_8822C 0xffffffffL
#define BIT_LTECOEX_R_DATA_V1_8822C(x) \
(((x) & BIT_MASK_LTECOEX_R_DATA_V1_8822C) \
<< BIT_SHIFT_LTECOEX_R_DATA_V1_8822C)
#define BITS_LTECOEX_R_DATA_V1_8822C \
(BIT_MASK_LTECOEX_R_DATA_V1_8822C << BIT_SHIFT_LTECOEX_R_DATA_V1_8822C)
#define BIT_CLEAR_LTECOEX_R_DATA_V1_8822C(x) \
((x) & (~BITS_LTECOEX_R_DATA_V1_8822C))
#define BIT_GET_LTECOEX_R_DATA_V1_8822C(x) \
(((x) >> BIT_SHIFT_LTECOEX_R_DATA_V1_8822C) & \
BIT_MASK_LTECOEX_R_DATA_V1_8822C)
#define BIT_SET_LTECOEX_R_DATA_V1_8822C(x, v) \
(BIT_CLEAR_LTECOEX_R_DATA_V1_8822C(x) | BIT_LTECOEX_R_DATA_V1_8822C(v))
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_NOT_VALID_8822C */
/* 2 REG_SDIO_TX_CTRL_8822C */
#define BIT_SHIFT_SDIO_INT_TIMEOUT_8822C 16
#define BIT_MASK_SDIO_INT_TIMEOUT_8822C 0xffff
#define BIT_SDIO_INT_TIMEOUT_8822C(x) \
(((x) & BIT_MASK_SDIO_INT_TIMEOUT_8822C) \
<< BIT_SHIFT_SDIO_INT_TIMEOUT_8822C)
#define BITS_SDIO_INT_TIMEOUT_8822C \
(BIT_MASK_SDIO_INT_TIMEOUT_8822C << BIT_SHIFT_SDIO_INT_TIMEOUT_8822C)
#define BIT_CLEAR_SDIO_INT_TIMEOUT_8822C(x) \
((x) & (~BITS_SDIO_INT_TIMEOUT_8822C))
#define BIT_GET_SDIO_INT_TIMEOUT_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_INT_TIMEOUT_8822C) & \
BIT_MASK_SDIO_INT_TIMEOUT_8822C)
#define BIT_SET_SDIO_INT_TIMEOUT_8822C(x, v) \
(BIT_CLEAR_SDIO_INT_TIMEOUT_8822C(x) | BIT_SDIO_INT_TIMEOUT_8822C(v))
#define BIT_IO_ERR_STATUS_8822C BIT(15)
#define BIT_CMD53_W_MIX_8822C BIT(14)
#define BIT_CMD53_TX_FORMAT_8822C BIT(13)
#define BIT_CMD53_R_TIMEOUT_MASK_8822C BIT(12)
#define BIT_SHIFT_CMD53_R_TIMEOUT_UNIT_8822C 10
#define BIT_MASK_CMD53_R_TIMEOUT_UNIT_8822C 0x3
#define BIT_CMD53_R_TIMEOUT_UNIT_8822C(x) \
(((x) & BIT_MASK_CMD53_R_TIMEOUT_UNIT_8822C) \
<< BIT_SHIFT_CMD53_R_TIMEOUT_UNIT_8822C)
#define BITS_CMD53_R_TIMEOUT_UNIT_8822C \
(BIT_MASK_CMD53_R_TIMEOUT_UNIT_8822C \
<< BIT_SHIFT_CMD53_R_TIMEOUT_UNIT_8822C)
#define BIT_CLEAR_CMD53_R_TIMEOUT_UNIT_8822C(x) \
((x) & (~BITS_CMD53_R_TIMEOUT_UNIT_8822C))
#define BIT_GET_CMD53_R_TIMEOUT_UNIT_8822C(x) \
(((x) >> BIT_SHIFT_CMD53_R_TIMEOUT_UNIT_8822C) & \
BIT_MASK_CMD53_R_TIMEOUT_UNIT_8822C)
#define BIT_SET_CMD53_R_TIMEOUT_UNIT_8822C(x, v) \
(BIT_CLEAR_CMD53_R_TIMEOUT_UNIT_8822C(x) | \
BIT_CMD53_R_TIMEOUT_UNIT_8822C(v))
#define BIT_REPLY_ERRCRC_IN_DATA_8822C BIT(9)
#define BIT_EN_CMD53_OVERLAP_8822C BIT(8)
#define BIT_REPLY_ERR_IN_R5_8822C BIT(7)
#define BIT_R18A_EN_8822C BIT(6)
#define BIT_SDIO_CMD_FORCE_VLD_8822C BIT(5)
#define BIT_INIT_CMD_EN_8822C BIT(4)
#define BIT_RXINT_READ_MASK_DIS_8822C BIT(3)
#define BIT_EN_RXDMA_MASK_INT_8822C BIT(2)
#define BIT_EN_MASK_TIMER_8822C BIT(1)
#define BIT_CMD_ERR_STOP_INT_EN_8822C BIT(0)
/* 2 REG_SDIO_CMD11_VOL_SWITCH_8822C */
#define BIT_SHIFT_CMD11_SEQ_END_DELAY_8822C 4
#define BIT_MASK_CMD11_SEQ_END_DELAY_8822C 0xf
#define BIT_CMD11_SEQ_END_DELAY_8822C(x) \
(((x) & BIT_MASK_CMD11_SEQ_END_DELAY_8822C) \
<< BIT_SHIFT_CMD11_SEQ_END_DELAY_8822C)
#define BITS_CMD11_SEQ_END_DELAY_8822C \
(BIT_MASK_CMD11_SEQ_END_DELAY_8822C \
<< BIT_SHIFT_CMD11_SEQ_END_DELAY_8822C)
#define BIT_CLEAR_CMD11_SEQ_END_DELAY_8822C(x) \
((x) & (~BITS_CMD11_SEQ_END_DELAY_8822C))
#define BIT_GET_CMD11_SEQ_END_DELAY_8822C(x) \
(((x) >> BIT_SHIFT_CMD11_SEQ_END_DELAY_8822C) & \
BIT_MASK_CMD11_SEQ_END_DELAY_8822C)
#define BIT_SET_CMD11_SEQ_END_DELAY_8822C(x, v) \
(BIT_CLEAR_CMD11_SEQ_END_DELAY_8822C(x) | \
BIT_CMD11_SEQ_END_DELAY_8822C(v))
#define BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL_8822C 1
#define BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL_8822C 0x7
#define BIT_CMD11_SEQ_SAMPLE_INTERVAL_8822C(x) \
(((x) & BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL_8822C) \
<< BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL_8822C)
#define BITS_CMD11_SEQ_SAMPLE_INTERVAL_8822C \
(BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL_8822C \
<< BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL_8822C)
#define BIT_CLEAR_CMD11_SEQ_SAMPLE_INTERVAL_8822C(x) \
((x) & (~BITS_CMD11_SEQ_SAMPLE_INTERVAL_8822C))
#define BIT_GET_CMD11_SEQ_SAMPLE_INTERVAL_8822C(x) \
(((x) >> BIT_SHIFT_CMD11_SEQ_SAMPLE_INTERVAL_8822C) & \
BIT_MASK_CMD11_SEQ_SAMPLE_INTERVAL_8822C)
#define BIT_SET_CMD11_SEQ_SAMPLE_INTERVAL_8822C(x, v) \
(BIT_CLEAR_CMD11_SEQ_SAMPLE_INTERVAL_8822C(x) | \
BIT_CMD11_SEQ_SAMPLE_INTERVAL_8822C(v))
#define BIT_CMD11_SEQ_EN_8822C BIT(0)
/* 2 REG_SDIO_CTRL_8822C */
#define BIT_SIG_OUT_PH_8822C BIT(0)
/* 2 REG_SDIO_DRIVING_8822C */
#define BIT_SHIFT_SDIO_DRV_TYPE_D_8822C 12
#define BIT_MASK_SDIO_DRV_TYPE_D_8822C 0xf
#define BIT_SDIO_DRV_TYPE_D_8822C(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_D_8822C) \
<< BIT_SHIFT_SDIO_DRV_TYPE_D_8822C)
#define BITS_SDIO_DRV_TYPE_D_8822C \
(BIT_MASK_SDIO_DRV_TYPE_D_8822C << BIT_SHIFT_SDIO_DRV_TYPE_D_8822C)
#define BIT_CLEAR_SDIO_DRV_TYPE_D_8822C(x) ((x) & (~BITS_SDIO_DRV_TYPE_D_8822C))
#define BIT_GET_SDIO_DRV_TYPE_D_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_D_8822C) & \
BIT_MASK_SDIO_DRV_TYPE_D_8822C)
#define BIT_SET_SDIO_DRV_TYPE_D_8822C(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_D_8822C(x) | BIT_SDIO_DRV_TYPE_D_8822C(v))
#define BIT_SHIFT_SDIO_DRV_TYPE_C_8822C 8
#define BIT_MASK_SDIO_DRV_TYPE_C_8822C 0xf
#define BIT_SDIO_DRV_TYPE_C_8822C(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_C_8822C) \
<< BIT_SHIFT_SDIO_DRV_TYPE_C_8822C)
#define BITS_SDIO_DRV_TYPE_C_8822C \
(BIT_MASK_SDIO_DRV_TYPE_C_8822C << BIT_SHIFT_SDIO_DRV_TYPE_C_8822C)
#define BIT_CLEAR_SDIO_DRV_TYPE_C_8822C(x) ((x) & (~BITS_SDIO_DRV_TYPE_C_8822C))
#define BIT_GET_SDIO_DRV_TYPE_C_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_C_8822C) & \
BIT_MASK_SDIO_DRV_TYPE_C_8822C)
#define BIT_SET_SDIO_DRV_TYPE_C_8822C(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_C_8822C(x) | BIT_SDIO_DRV_TYPE_C_8822C(v))
#define BIT_SHIFT_SDIO_DRV_TYPE_B_8822C 4
#define BIT_MASK_SDIO_DRV_TYPE_B_8822C 0xf
#define BIT_SDIO_DRV_TYPE_B_8822C(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_B_8822C) \
<< BIT_SHIFT_SDIO_DRV_TYPE_B_8822C)
#define BITS_SDIO_DRV_TYPE_B_8822C \
(BIT_MASK_SDIO_DRV_TYPE_B_8822C << BIT_SHIFT_SDIO_DRV_TYPE_B_8822C)
#define BIT_CLEAR_SDIO_DRV_TYPE_B_8822C(x) ((x) & (~BITS_SDIO_DRV_TYPE_B_8822C))
#define BIT_GET_SDIO_DRV_TYPE_B_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_B_8822C) & \
BIT_MASK_SDIO_DRV_TYPE_B_8822C)
#define BIT_SET_SDIO_DRV_TYPE_B_8822C(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_B_8822C(x) | BIT_SDIO_DRV_TYPE_B_8822C(v))
#define BIT_SHIFT_SDIO_DRV_TYPE_A_8822C 0
#define BIT_MASK_SDIO_DRV_TYPE_A_8822C 0xf
#define BIT_SDIO_DRV_TYPE_A_8822C(x) \
(((x) & BIT_MASK_SDIO_DRV_TYPE_A_8822C) \
<< BIT_SHIFT_SDIO_DRV_TYPE_A_8822C)
#define BITS_SDIO_DRV_TYPE_A_8822C \
(BIT_MASK_SDIO_DRV_TYPE_A_8822C << BIT_SHIFT_SDIO_DRV_TYPE_A_8822C)
#define BIT_CLEAR_SDIO_DRV_TYPE_A_8822C(x) ((x) & (~BITS_SDIO_DRV_TYPE_A_8822C))
#define BIT_GET_SDIO_DRV_TYPE_A_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_DRV_TYPE_A_8822C) & \
BIT_MASK_SDIO_DRV_TYPE_A_8822C)
#define BIT_SET_SDIO_DRV_TYPE_A_8822C(x, v) \
(BIT_CLEAR_SDIO_DRV_TYPE_A_8822C(x) | BIT_SDIO_DRV_TYPE_A_8822C(v))
/* 2 REG_SDIO_MONITOR_8822C */
#define BIT_SHIFT_SDIO_INT_START_8822C 0
#define BIT_MASK_SDIO_INT_START_8822C 0xffffffffL
#define BIT_SDIO_INT_START_8822C(x) \
(((x) & BIT_MASK_SDIO_INT_START_8822C) \
<< BIT_SHIFT_SDIO_INT_START_8822C)
#define BITS_SDIO_INT_START_8822C \
(BIT_MASK_SDIO_INT_START_8822C << BIT_SHIFT_SDIO_INT_START_8822C)
#define BIT_CLEAR_SDIO_INT_START_8822C(x) ((x) & (~BITS_SDIO_INT_START_8822C))
#define BIT_GET_SDIO_INT_START_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_INT_START_8822C) & \
BIT_MASK_SDIO_INT_START_8822C)
#define BIT_SET_SDIO_INT_START_8822C(x, v) \
(BIT_CLEAR_SDIO_INT_START_8822C(x) | BIT_SDIO_INT_START_8822C(v))
/* 2 REG_SDIO_MONITOR_2_8822C */
#define BIT_CMD53_WT_EN_8822C BIT(23)
#define BIT_SHIFT_SDIO_CLK_MONITOR_8822C 21
#define BIT_MASK_SDIO_CLK_MONITOR_8822C 0x3
#define BIT_SDIO_CLK_MONITOR_8822C(x) \
(((x) & BIT_MASK_SDIO_CLK_MONITOR_8822C) \
<< BIT_SHIFT_SDIO_CLK_MONITOR_8822C)
#define BITS_SDIO_CLK_MONITOR_8822C \
(BIT_MASK_SDIO_CLK_MONITOR_8822C << BIT_SHIFT_SDIO_CLK_MONITOR_8822C)
#define BIT_CLEAR_SDIO_CLK_MONITOR_8822C(x) \
((x) & (~BITS_SDIO_CLK_MONITOR_8822C))
#define BIT_GET_SDIO_CLK_MONITOR_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_CLK_MONITOR_8822C) & \
BIT_MASK_SDIO_CLK_MONITOR_8822C)
#define BIT_SET_SDIO_CLK_MONITOR_8822C(x, v) \
(BIT_CLEAR_SDIO_CLK_MONITOR_8822C(x) | BIT_SDIO_CLK_MONITOR_8822C(v))
#define BIT_SHIFT_SDIO_CLK_CNT_8822C 0
#define BIT_MASK_SDIO_CLK_CNT_8822C 0x1fffff
#define BIT_SDIO_CLK_CNT_8822C(x) \
(((x) & BIT_MASK_SDIO_CLK_CNT_8822C) << BIT_SHIFT_SDIO_CLK_CNT_8822C)
#define BITS_SDIO_CLK_CNT_8822C \
(BIT_MASK_SDIO_CLK_CNT_8822C << BIT_SHIFT_SDIO_CLK_CNT_8822C)
#define BIT_CLEAR_SDIO_CLK_CNT_8822C(x) ((x) & (~BITS_SDIO_CLK_CNT_8822C))
#define BIT_GET_SDIO_CLK_CNT_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_CLK_CNT_8822C) & BIT_MASK_SDIO_CLK_CNT_8822C)
#define BIT_SET_SDIO_CLK_CNT_8822C(x, v) \
(BIT_CLEAR_SDIO_CLK_CNT_8822C(x) | BIT_SDIO_CLK_CNT_8822C(v))
/* 2 REG_SDIO_HIMR_8822C */
#define BIT_SDIO_CRCERR_MSK_8822C BIT(31)
#define BIT_SDIO_HSISR3_IND_MSK_8822C BIT(30)
#define BIT_SDIO_HSISR2_IND_MSK_8822C BIT(29)
#define BIT_SDIO_HEISR_IND_MSK_8822C BIT(28)
#define BIT_SDIO_CTWEND_MSK_8822C BIT(27)
#define BIT_SDIO_ATIMEND_E_MSK_8822C BIT(26)
#define BIT_SDIIO_ATIMEND_MSK_8822C BIT(25)
#define BIT_SDIO_OCPINT_MSK_8822C BIT(24)
#define BIT_SDIO_PSTIMEOUT_MSK_8822C BIT(23)
#define BIT_SDIO_GTINT4_MSK_8822C BIT(22)
#define BIT_SDIO_GTINT3_MSK_8822C BIT(21)
#define BIT_SDIO_HSISR_IND_MSK_8822C BIT(20)
#define BIT_SDIO_CPWM2_MSK_8822C BIT(19)
#define BIT_SDIO_CPWM1_MSK_8822C BIT(18)
#define BIT_SDIO_C2HCMD_INT_MSK_8822C BIT(17)
#define BIT_SDIO_BCNERLY_INT_MSK_8822C BIT(16)
#define BIT_SDIO_TXBCNERR_MSK_8822C BIT(7)
#define BIT_SDIO_TXBCNOK_MSK_8822C BIT(6)
#define BIT_SDIO_RXFOVW_MSK_8822C BIT(5)
#define BIT_SDIO_TXFOVW_MSK_8822C BIT(4)
#define BIT_SDIO_RXERR_MSK_8822C BIT(3)
#define BIT_SDIO_TXERR_MSK_8822C BIT(2)
#define BIT_SDIO_AVAL_MSK_8822C BIT(1)
#define BIT_RX_REQUEST_MSK_8822C BIT(0)
/* 2 REG_SDIO_HISR_8822C */
#define BIT_SDIO_CRCERR_8822C BIT(31)
#define BIT_SDIO_HSISR3_IND_8822C BIT(30)
#define BIT_SDIO_HSISR2_IND_8822C BIT(29)
#define BIT_SDIO_HEISR_IND_8822C BIT(28)
#define BIT_SDIO_CTWEND_8822C BIT(27)
#define BIT_SDIO_ATIMEND_E_8822C BIT(26)
#define BIT_SDIO_ATIMEND_8822C BIT(25)
#define BIT_SDIO_OCPINT_8822C BIT(24)
#define BIT_SDIO_PSTIMEOUT_8822C BIT(23)
#define BIT_SDIO_GTINT4_8822C BIT(22)
#define BIT_SDIO_GTINT3_8822C BIT(21)
#define BIT_SDIO_HSISR_IND_8822C BIT(20)
#define BIT_SDIO_CPWM2_8822C BIT(19)
#define BIT_SDIO_CPWM1_8822C BIT(18)
#define BIT_SDIO_C2HCMD_INT_8822C BIT(17)
#define BIT_SDIO_BCNERLY_INT_8822C BIT(16)
#define BIT_SDIO_TXBCNERR_8822C BIT(7)
#define BIT_SDIO_TXBCNOK_8822C BIT(6)
#define BIT_SDIO_RXFOVW_8822C BIT(5)
#define BIT_SDIO_TXFOVW_8822C BIT(4)
#define BIT_SDIO_RXERR_8822C BIT(3)
#define BIT_SDIO_TXERR_8822C BIT(2)
#define BIT_SDIO_AVAL_8822C BIT(1)
#define BIT_RX_REQUEST_8822C BIT(0)
/* 2 REG_SDIO_RX_REQ_LEN_8822C */
#define BIT_SHIFT_RX_REQ_LEN_V1_8822C 0
#define BIT_MASK_RX_REQ_LEN_V1_8822C 0x3ffff
#define BIT_RX_REQ_LEN_V1_8822C(x) \
(((x) & BIT_MASK_RX_REQ_LEN_V1_8822C) << BIT_SHIFT_RX_REQ_LEN_V1_8822C)
#define BITS_RX_REQ_LEN_V1_8822C \
(BIT_MASK_RX_REQ_LEN_V1_8822C << BIT_SHIFT_RX_REQ_LEN_V1_8822C)
#define BIT_CLEAR_RX_REQ_LEN_V1_8822C(x) ((x) & (~BITS_RX_REQ_LEN_V1_8822C))
#define BIT_GET_RX_REQ_LEN_V1_8822C(x) \
(((x) >> BIT_SHIFT_RX_REQ_LEN_V1_8822C) & BIT_MASK_RX_REQ_LEN_V1_8822C)
#define BIT_SET_RX_REQ_LEN_V1_8822C(x, v) \
(BIT_CLEAR_RX_REQ_LEN_V1_8822C(x) | BIT_RX_REQ_LEN_V1_8822C(v))
/* 2 REG_SDIO_FREE_TXPG_SEQ_V1_8822C */
#define BIT_SHIFT_FREE_TXPG_SEQ_8822C 0
#define BIT_MASK_FREE_TXPG_SEQ_8822C 0xff
#define BIT_FREE_TXPG_SEQ_8822C(x) \
(((x) & BIT_MASK_FREE_TXPG_SEQ_8822C) << BIT_SHIFT_FREE_TXPG_SEQ_8822C)
#define BITS_FREE_TXPG_SEQ_8822C \
(BIT_MASK_FREE_TXPG_SEQ_8822C << BIT_SHIFT_FREE_TXPG_SEQ_8822C)
#define BIT_CLEAR_FREE_TXPG_SEQ_8822C(x) ((x) & (~BITS_FREE_TXPG_SEQ_8822C))
#define BIT_GET_FREE_TXPG_SEQ_8822C(x) \
(((x) >> BIT_SHIFT_FREE_TXPG_SEQ_8822C) & BIT_MASK_FREE_TXPG_SEQ_8822C)
#define BIT_SET_FREE_TXPG_SEQ_8822C(x, v) \
(BIT_CLEAR_FREE_TXPG_SEQ_8822C(x) | BIT_FREE_TXPG_SEQ_8822C(v))
/* 2 REG_SDIO_FREE_TXPG_8822C */
#define BIT_SHIFT_MID_FREEPG_V1_8822C 16
#define BIT_MASK_MID_FREEPG_V1_8822C 0xfff
#define BIT_MID_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_MID_FREEPG_V1_8822C) << BIT_SHIFT_MID_FREEPG_V1_8822C)
#define BITS_MID_FREEPG_V1_8822C \
(BIT_MASK_MID_FREEPG_V1_8822C << BIT_SHIFT_MID_FREEPG_V1_8822C)
#define BIT_CLEAR_MID_FREEPG_V1_8822C(x) ((x) & (~BITS_MID_FREEPG_V1_8822C))
#define BIT_GET_MID_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_MID_FREEPG_V1_8822C) & BIT_MASK_MID_FREEPG_V1_8822C)
#define BIT_SET_MID_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_MID_FREEPG_V1_8822C(x) | BIT_MID_FREEPG_V1_8822C(v))
#define BIT_SHIFT_HIQ_FREEPG_V1_8822C 0
#define BIT_MASK_HIQ_FREEPG_V1_8822C 0xfff
#define BIT_HIQ_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_HIQ_FREEPG_V1_8822C) << BIT_SHIFT_HIQ_FREEPG_V1_8822C)
#define BITS_HIQ_FREEPG_V1_8822C \
(BIT_MASK_HIQ_FREEPG_V1_8822C << BIT_SHIFT_HIQ_FREEPG_V1_8822C)
#define BIT_CLEAR_HIQ_FREEPG_V1_8822C(x) ((x) & (~BITS_HIQ_FREEPG_V1_8822C))
#define BIT_GET_HIQ_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_HIQ_FREEPG_V1_8822C) & BIT_MASK_HIQ_FREEPG_V1_8822C)
#define BIT_SET_HIQ_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_HIQ_FREEPG_V1_8822C(x) | BIT_HIQ_FREEPG_V1_8822C(v))
/* 2 REG_SDIO_FREE_TXPG2_8822C */
#define BIT_SHIFT_PUB_FREEPG_V1_8822C 16
#define BIT_MASK_PUB_FREEPG_V1_8822C 0xfff
#define BIT_PUB_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_PUB_FREEPG_V1_8822C) << BIT_SHIFT_PUB_FREEPG_V1_8822C)
#define BITS_PUB_FREEPG_V1_8822C \
(BIT_MASK_PUB_FREEPG_V1_8822C << BIT_SHIFT_PUB_FREEPG_V1_8822C)
#define BIT_CLEAR_PUB_FREEPG_V1_8822C(x) ((x) & (~BITS_PUB_FREEPG_V1_8822C))
#define BIT_GET_PUB_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_PUB_FREEPG_V1_8822C) & BIT_MASK_PUB_FREEPG_V1_8822C)
#define BIT_SET_PUB_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_PUB_FREEPG_V1_8822C(x) | BIT_PUB_FREEPG_V1_8822C(v))
#define BIT_SHIFT_LOW_FREEPG_V1_8822C 0
#define BIT_MASK_LOW_FREEPG_V1_8822C 0xfff
#define BIT_LOW_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_LOW_FREEPG_V1_8822C) << BIT_SHIFT_LOW_FREEPG_V1_8822C)
#define BITS_LOW_FREEPG_V1_8822C \
(BIT_MASK_LOW_FREEPG_V1_8822C << BIT_SHIFT_LOW_FREEPG_V1_8822C)
#define BIT_CLEAR_LOW_FREEPG_V1_8822C(x) ((x) & (~BITS_LOW_FREEPG_V1_8822C))
#define BIT_GET_LOW_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_LOW_FREEPG_V1_8822C) & BIT_MASK_LOW_FREEPG_V1_8822C)
#define BIT_SET_LOW_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_LOW_FREEPG_V1_8822C(x) | BIT_LOW_FREEPG_V1_8822C(v))
/* 2 REG_SDIO_OQT_FREE_TXPG_V1_8822C */
#define BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822C 24
#define BIT_MASK_NOAC_OQT_FREEPG_V1_8822C 0xff
#define BIT_NOAC_OQT_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_NOAC_OQT_FREEPG_V1_8822C) \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822C)
#define BITS_NOAC_OQT_FREEPG_V1_8822C \
(BIT_MASK_NOAC_OQT_FREEPG_V1_8822C \
<< BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822C)
#define BIT_CLEAR_NOAC_OQT_FREEPG_V1_8822C(x) \
((x) & (~BITS_NOAC_OQT_FREEPG_V1_8822C))
#define BIT_GET_NOAC_OQT_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_NOAC_OQT_FREEPG_V1_8822C) & \
BIT_MASK_NOAC_OQT_FREEPG_V1_8822C)
#define BIT_SET_NOAC_OQT_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_NOAC_OQT_FREEPG_V1_8822C(x) | \
BIT_NOAC_OQT_FREEPG_V1_8822C(v))
#define BIT_SHIFT_AC_OQT_FREEPG_V1_8822C 16
#define BIT_MASK_AC_OQT_FREEPG_V1_8822C 0xff
#define BIT_AC_OQT_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_AC_OQT_FREEPG_V1_8822C) \
<< BIT_SHIFT_AC_OQT_FREEPG_V1_8822C)
#define BITS_AC_OQT_FREEPG_V1_8822C \
(BIT_MASK_AC_OQT_FREEPG_V1_8822C << BIT_SHIFT_AC_OQT_FREEPG_V1_8822C)
#define BIT_CLEAR_AC_OQT_FREEPG_V1_8822C(x) \
((x) & (~BITS_AC_OQT_FREEPG_V1_8822C))
#define BIT_GET_AC_OQT_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_AC_OQT_FREEPG_V1_8822C) & \
BIT_MASK_AC_OQT_FREEPG_V1_8822C)
#define BIT_SET_AC_OQT_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_AC_OQT_FREEPG_V1_8822C(x) | BIT_AC_OQT_FREEPG_V1_8822C(v))
#define BIT_SHIFT_EXQ_FREEPG_V1_8822C 0
#define BIT_MASK_EXQ_FREEPG_V1_8822C 0xfff
#define BIT_EXQ_FREEPG_V1_8822C(x) \
(((x) & BIT_MASK_EXQ_FREEPG_V1_8822C) << BIT_SHIFT_EXQ_FREEPG_V1_8822C)
#define BITS_EXQ_FREEPG_V1_8822C \
(BIT_MASK_EXQ_FREEPG_V1_8822C << BIT_SHIFT_EXQ_FREEPG_V1_8822C)
#define BIT_CLEAR_EXQ_FREEPG_V1_8822C(x) ((x) & (~BITS_EXQ_FREEPG_V1_8822C))
#define BIT_GET_EXQ_FREEPG_V1_8822C(x) \
(((x) >> BIT_SHIFT_EXQ_FREEPG_V1_8822C) & BIT_MASK_EXQ_FREEPG_V1_8822C)
#define BIT_SET_EXQ_FREEPG_V1_8822C(x, v) \
(BIT_CLEAR_EXQ_FREEPG_V1_8822C(x) | BIT_EXQ_FREEPG_V1_8822C(v))
/* 2 REG_SDIO_TXPKT_EMPTY_8822C */
#define BIT_SDIO_BCNQ_EMPTY_8822C BIT(11)
#define BIT_SDIO_HQQ_EMPTY_8822C BIT(10)
#define BIT_SDIO_MQQ_EMPTY_8822C BIT(9)
#define BIT_SDIO_MGQ_CPU_EMPTY_8822C BIT(8)
#define BIT_SDIO_AC7Q_EMPTY_8822C BIT(7)
#define BIT_SDIO_AC6Q_EMPTY_8822C BIT(6)
#define BIT_SDIO_AC5Q_EMPTY_8822C BIT(5)
#define BIT_SDIO_AC4Q_EMPTY_8822C BIT(4)
#define BIT_SDIO_AC3Q_EMPTY_8822C BIT(3)
#define BIT_SDIO_AC2Q_EMPTY_8822C BIT(2)
#define BIT_SDIO_AC1Q_EMPTY_8822C BIT(1)
#define BIT_SDIO_AC0Q_EMPTY_8822C BIT(0)
/* 2 REG_SDIO_HTSFR_INFO_8822C */
#define BIT_SHIFT_HTSFR1_8822C 16
#define BIT_MASK_HTSFR1_8822C 0xffff
#define BIT_HTSFR1_8822C(x) \
(((x) & BIT_MASK_HTSFR1_8822C) << BIT_SHIFT_HTSFR1_8822C)
#define BITS_HTSFR1_8822C (BIT_MASK_HTSFR1_8822C << BIT_SHIFT_HTSFR1_8822C)
#define BIT_CLEAR_HTSFR1_8822C(x) ((x) & (~BITS_HTSFR1_8822C))
#define BIT_GET_HTSFR1_8822C(x) \
(((x) >> BIT_SHIFT_HTSFR1_8822C) & BIT_MASK_HTSFR1_8822C)
#define BIT_SET_HTSFR1_8822C(x, v) \
(BIT_CLEAR_HTSFR1_8822C(x) | BIT_HTSFR1_8822C(v))
#define BIT_SHIFT_HTSFR0_8822C 0
#define BIT_MASK_HTSFR0_8822C 0xffff
#define BIT_HTSFR0_8822C(x) \
(((x) & BIT_MASK_HTSFR0_8822C) << BIT_SHIFT_HTSFR0_8822C)
#define BITS_HTSFR0_8822C (BIT_MASK_HTSFR0_8822C << BIT_SHIFT_HTSFR0_8822C)
#define BIT_CLEAR_HTSFR0_8822C(x) ((x) & (~BITS_HTSFR0_8822C))
#define BIT_GET_HTSFR0_8822C(x) \
(((x) >> BIT_SHIFT_HTSFR0_8822C) & BIT_MASK_HTSFR0_8822C)
#define BIT_SET_HTSFR0_8822C(x, v) \
(BIT_CLEAR_HTSFR0_8822C(x) | BIT_HTSFR0_8822C(v))
/* 2 REG_SDIO_HCPWM1_V2_8822C */
#define BIT_TOGGLE_8822C BIT(7)
#define BIT_CUR_PS_8822C BIT(0)
/* 2 REG_SDIO_HCPWM2_V2_8822C */
/* 2 REG_SDIO_INDIRECT_REG_CFG_8822C */
#define BIT_INDIRECT_REG_RDY_8822C BIT(20)
#define BIT_INDIRECT_REG_R_8822C BIT(19)
#define BIT_INDIRECT_REG_W_8822C BIT(18)
#define BIT_SHIFT_INDIRECT_REG_SIZE_8822C 16
#define BIT_MASK_INDIRECT_REG_SIZE_8822C 0x3
#define BIT_INDIRECT_REG_SIZE_8822C(x) \
(((x) & BIT_MASK_INDIRECT_REG_SIZE_8822C) \
<< BIT_SHIFT_INDIRECT_REG_SIZE_8822C)
#define BITS_INDIRECT_REG_SIZE_8822C \
(BIT_MASK_INDIRECT_REG_SIZE_8822C << BIT_SHIFT_INDIRECT_REG_SIZE_8822C)
#define BIT_CLEAR_INDIRECT_REG_SIZE_8822C(x) \
((x) & (~BITS_INDIRECT_REG_SIZE_8822C))
#define BIT_GET_INDIRECT_REG_SIZE_8822C(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_SIZE_8822C) & \
BIT_MASK_INDIRECT_REG_SIZE_8822C)
#define BIT_SET_INDIRECT_REG_SIZE_8822C(x, v) \
(BIT_CLEAR_INDIRECT_REG_SIZE_8822C(x) | BIT_INDIRECT_REG_SIZE_8822C(v))
#define BIT_SHIFT_INDIRECT_REG_ADDR_8822C 0
#define BIT_MASK_INDIRECT_REG_ADDR_8822C 0xffff
#define BIT_INDIRECT_REG_ADDR_8822C(x) \
(((x) & BIT_MASK_INDIRECT_REG_ADDR_8822C) \
<< BIT_SHIFT_INDIRECT_REG_ADDR_8822C)
#define BITS_INDIRECT_REG_ADDR_8822C \
(BIT_MASK_INDIRECT_REG_ADDR_8822C << BIT_SHIFT_INDIRECT_REG_ADDR_8822C)
#define BIT_CLEAR_INDIRECT_REG_ADDR_8822C(x) \
((x) & (~BITS_INDIRECT_REG_ADDR_8822C))
#define BIT_GET_INDIRECT_REG_ADDR_8822C(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_ADDR_8822C) & \
BIT_MASK_INDIRECT_REG_ADDR_8822C)
#define BIT_SET_INDIRECT_REG_ADDR_8822C(x, v) \
(BIT_CLEAR_INDIRECT_REG_ADDR_8822C(x) | BIT_INDIRECT_REG_ADDR_8822C(v))
/* 2 REG_SDIO_INDIRECT_REG_DATA_8822C */
#define BIT_SHIFT_INDIRECT_REG_DATA_8822C 0
#define BIT_MASK_INDIRECT_REG_DATA_8822C 0xffffffffL
#define BIT_INDIRECT_REG_DATA_8822C(x) \
(((x) & BIT_MASK_INDIRECT_REG_DATA_8822C) \
<< BIT_SHIFT_INDIRECT_REG_DATA_8822C)
#define BITS_INDIRECT_REG_DATA_8822C \
(BIT_MASK_INDIRECT_REG_DATA_8822C << BIT_SHIFT_INDIRECT_REG_DATA_8822C)
#define BIT_CLEAR_INDIRECT_REG_DATA_8822C(x) \
((x) & (~BITS_INDIRECT_REG_DATA_8822C))
#define BIT_GET_INDIRECT_REG_DATA_8822C(x) \
(((x) >> BIT_SHIFT_INDIRECT_REG_DATA_8822C) & \
BIT_MASK_INDIRECT_REG_DATA_8822C)
#define BIT_SET_INDIRECT_REG_DATA_8822C(x, v) \
(BIT_CLEAR_INDIRECT_REG_DATA_8822C(x) | BIT_INDIRECT_REG_DATA_8822C(v))
/* 2 REG_SDIO_H2C_8822C */
#define BIT_SHIFT_SDIO_H2C_MSG_8822C 0
#define BIT_MASK_SDIO_H2C_MSG_8822C 0xffffffffL
#define BIT_SDIO_H2C_MSG_8822C(x) \
(((x) & BIT_MASK_SDIO_H2C_MSG_8822C) << BIT_SHIFT_SDIO_H2C_MSG_8822C)
#define BITS_SDIO_H2C_MSG_8822C \
(BIT_MASK_SDIO_H2C_MSG_8822C << BIT_SHIFT_SDIO_H2C_MSG_8822C)
#define BIT_CLEAR_SDIO_H2C_MSG_8822C(x) ((x) & (~BITS_SDIO_H2C_MSG_8822C))
#define BIT_GET_SDIO_H2C_MSG_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_H2C_MSG_8822C) & BIT_MASK_SDIO_H2C_MSG_8822C)
#define BIT_SET_SDIO_H2C_MSG_8822C(x, v) \
(BIT_CLEAR_SDIO_H2C_MSG_8822C(x) | BIT_SDIO_H2C_MSG_8822C(v))
/* 2 REG_SDIO_C2H_8822C */
#define BIT_SHIFT_SDIO_C2H_MSG_8822C 0
#define BIT_MASK_SDIO_C2H_MSG_8822C 0xffffffffL
#define BIT_SDIO_C2H_MSG_8822C(x) \
(((x) & BIT_MASK_SDIO_C2H_MSG_8822C) << BIT_SHIFT_SDIO_C2H_MSG_8822C)
#define BITS_SDIO_C2H_MSG_8822C \
(BIT_MASK_SDIO_C2H_MSG_8822C << BIT_SHIFT_SDIO_C2H_MSG_8822C)
#define BIT_CLEAR_SDIO_C2H_MSG_8822C(x) ((x) & (~BITS_SDIO_C2H_MSG_8822C))
#define BIT_GET_SDIO_C2H_MSG_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_C2H_MSG_8822C) & BIT_MASK_SDIO_C2H_MSG_8822C)
#define BIT_SET_SDIO_C2H_MSG_8822C(x, v) \
(BIT_CLEAR_SDIO_C2H_MSG_8822C(x) | BIT_SDIO_C2H_MSG_8822C(v))
/* 2 REG_SDIO_HRPWM1_8822C */
#define BIT_TOGGLE_8822C BIT(7)
#define BIT_ACK_8822C BIT(6)
#define BIT_REQ_PS_8822C BIT(0)
/* 2 REG_SDIO_HRPWM2_8822C */
/* 2 REG_SDIO_HPS_CLKR_8822C */
/* 2 REG_SDIO_BUS_CTRL_8822C */
#define BIT_INT_MASK_DIS_8822C BIT(4)
#define BIT_PAD_CLK_XHGE_EN_8822C BIT(3)
#define BIT_INTER_CLK_EN_8822C BIT(2)
#define BIT_EN_RPT_TXCRC_8822C BIT(1)
#define BIT_DIS_RXDMA_STS_8822C BIT(0)
/* 2 REG_SDIO_HSUS_CTRL_8822C */
#define BIT_INTR_CTRL_8822C BIT(4)
#define BIT_SDIO_VOLTAGE_8822C BIT(3)
#define BIT_BYPASS_INIT_8822C BIT(2)
#define BIT_HCI_RESUME_RDY_8822C BIT(1)
#define BIT_HCI_SUS_REQ_8822C BIT(0)
/* 2 REG_SDIO_RESPONSE_TIMER_8822C */
#define BIT_SHIFT_CMDIN_2RESP_TIMER_8822C 0
#define BIT_MASK_CMDIN_2RESP_TIMER_8822C 0xffff
#define BIT_CMDIN_2RESP_TIMER_8822C(x) \
(((x) & BIT_MASK_CMDIN_2RESP_TIMER_8822C) \
<< BIT_SHIFT_CMDIN_2RESP_TIMER_8822C)
#define BITS_CMDIN_2RESP_TIMER_8822C \
(BIT_MASK_CMDIN_2RESP_TIMER_8822C << BIT_SHIFT_CMDIN_2RESP_TIMER_8822C)
#define BIT_CLEAR_CMDIN_2RESP_TIMER_8822C(x) \
((x) & (~BITS_CMDIN_2RESP_TIMER_8822C))
#define BIT_GET_CMDIN_2RESP_TIMER_8822C(x) \
(((x) >> BIT_SHIFT_CMDIN_2RESP_TIMER_8822C) & \
BIT_MASK_CMDIN_2RESP_TIMER_8822C)
#define BIT_SET_CMDIN_2RESP_TIMER_8822C(x, v) \
(BIT_CLEAR_CMDIN_2RESP_TIMER_8822C(x) | BIT_CMDIN_2RESP_TIMER_8822C(v))
/* 2 REG_SDIO_CMD_CRC_8822C */
#define BIT_SHIFT_SDIO_CMD_CRC_V1_8822C 0
#define BIT_MASK_SDIO_CMD_CRC_V1_8822C 0xff
#define BIT_SDIO_CMD_CRC_V1_8822C(x) \
(((x) & BIT_MASK_SDIO_CMD_CRC_V1_8822C) \
<< BIT_SHIFT_SDIO_CMD_CRC_V1_8822C)
#define BITS_SDIO_CMD_CRC_V1_8822C \
(BIT_MASK_SDIO_CMD_CRC_V1_8822C << BIT_SHIFT_SDIO_CMD_CRC_V1_8822C)
#define BIT_CLEAR_SDIO_CMD_CRC_V1_8822C(x) ((x) & (~BITS_SDIO_CMD_CRC_V1_8822C))
#define BIT_GET_SDIO_CMD_CRC_V1_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_CRC_V1_8822C) & \
BIT_MASK_SDIO_CMD_CRC_V1_8822C)
#define BIT_SET_SDIO_CMD_CRC_V1_8822C(x, v) \
(BIT_CLEAR_SDIO_CMD_CRC_V1_8822C(x) | BIT_SDIO_CMD_CRC_V1_8822C(v))
/* 2 REG_SDIO_HSISR_8822C */
#define BIT_DRV_WLAN_INT_CLR_8822C BIT(1)
#define BIT_DRV_WLAN_INT_8822C BIT(0)
/* 2 REG_SDIO_HSIMR_8822C */
#define BIT_HISR_MASK_8822C BIT(0)
/* 2 REG_SDIO_DIOERR_RPT_8822C */
#define BIT_SDIO_PAGE_ERR_8822C BIT(0)
/* 2 REG_SDIO_CMD_ERRCNT_8822C */
#define BIT_SHIFT_CMD_CRC_ERR_CNT_8822C 0
#define BIT_MASK_CMD_CRC_ERR_CNT_8822C 0xff
#define BIT_CMD_CRC_ERR_CNT_8822C(x) \
(((x) & BIT_MASK_CMD_CRC_ERR_CNT_8822C) \
<< BIT_SHIFT_CMD_CRC_ERR_CNT_8822C)
#define BITS_CMD_CRC_ERR_CNT_8822C \
(BIT_MASK_CMD_CRC_ERR_CNT_8822C << BIT_SHIFT_CMD_CRC_ERR_CNT_8822C)
#define BIT_CLEAR_CMD_CRC_ERR_CNT_8822C(x) ((x) & (~BITS_CMD_CRC_ERR_CNT_8822C))
#define BIT_GET_CMD_CRC_ERR_CNT_8822C(x) \
(((x) >> BIT_SHIFT_CMD_CRC_ERR_CNT_8822C) & \
BIT_MASK_CMD_CRC_ERR_CNT_8822C)
#define BIT_SET_CMD_CRC_ERR_CNT_8822C(x, v) \
(BIT_CLEAR_CMD_CRC_ERR_CNT_8822C(x) | BIT_CMD_CRC_ERR_CNT_8822C(v))
/* 2 REG_SDIO_DATA_ERRCNT_8822C */
#define BIT_SHIFT_DATA_CRC_ERR_CNT_8822C 0
#define BIT_MASK_DATA_CRC_ERR_CNT_8822C 0xff
#define BIT_DATA_CRC_ERR_CNT_8822C(x) \
(((x) & BIT_MASK_DATA_CRC_ERR_CNT_8822C) \
<< BIT_SHIFT_DATA_CRC_ERR_CNT_8822C)
#define BITS_DATA_CRC_ERR_CNT_8822C \
(BIT_MASK_DATA_CRC_ERR_CNT_8822C << BIT_SHIFT_DATA_CRC_ERR_CNT_8822C)
#define BIT_CLEAR_DATA_CRC_ERR_CNT_8822C(x) \
((x) & (~BITS_DATA_CRC_ERR_CNT_8822C))
#define BIT_GET_DATA_CRC_ERR_CNT_8822C(x) \
(((x) >> BIT_SHIFT_DATA_CRC_ERR_CNT_8822C) & \
BIT_MASK_DATA_CRC_ERR_CNT_8822C)
#define BIT_SET_DATA_CRC_ERR_CNT_8822C(x, v) \
(BIT_CLEAR_DATA_CRC_ERR_CNT_8822C(x) | BIT_DATA_CRC_ERR_CNT_8822C(v))
/* 2 REG_SDIO_CMD_ERR_CONTENT_8822C */
#define BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822C 0
#define BIT_MASK_SDIO_CMD_ERR_CONTENT_8822C 0xffffffffffL
#define BIT_SDIO_CMD_ERR_CONTENT_8822C(x) \
(((x) & BIT_MASK_SDIO_CMD_ERR_CONTENT_8822C) \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822C)
#define BITS_SDIO_CMD_ERR_CONTENT_8822C \
(BIT_MASK_SDIO_CMD_ERR_CONTENT_8822C \
<< BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822C)
#define BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8822C(x) \
((x) & (~BITS_SDIO_CMD_ERR_CONTENT_8822C))
#define BIT_GET_SDIO_CMD_ERR_CONTENT_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_CMD_ERR_CONTENT_8822C) & \
BIT_MASK_SDIO_CMD_ERR_CONTENT_8822C)
#define BIT_SET_SDIO_CMD_ERR_CONTENT_8822C(x, v) \
(BIT_CLEAR_SDIO_CMD_ERR_CONTENT_8822C(x) | \
BIT_SDIO_CMD_ERR_CONTENT_8822C(v))
/* 2 REG_SDIO_CRC_ERR_IDX_8822C */
#define BIT_D3_CRC_ERR_8822C BIT(4)
#define BIT_D2_CRC_ERR_8822C BIT(3)
#define BIT_D1_CRC_ERR_8822C BIT(2)
#define BIT_D0_CRC_ERR_8822C BIT(1)
#define BIT_CMD_CRC_ERR_8822C BIT(0)
/* 2 REG_SDIO_DATA_CRC_8822C */
#define BIT_SHIFT_SDIO_DATA_CRC_8822C 0
#define BIT_MASK_SDIO_DATA_CRC_8822C 0xffff
#define BIT_SDIO_DATA_CRC_8822C(x) \
(((x) & BIT_MASK_SDIO_DATA_CRC_8822C) << BIT_SHIFT_SDIO_DATA_CRC_8822C)
#define BITS_SDIO_DATA_CRC_8822C \
(BIT_MASK_SDIO_DATA_CRC_8822C << BIT_SHIFT_SDIO_DATA_CRC_8822C)
#define BIT_CLEAR_SDIO_DATA_CRC_8822C(x) ((x) & (~BITS_SDIO_DATA_CRC_8822C))
#define BIT_GET_SDIO_DATA_CRC_8822C(x) \
(((x) >> BIT_SHIFT_SDIO_DATA_CRC_8822C) & BIT_MASK_SDIO_DATA_CRC_8822C)
#define BIT_SET_SDIO_DATA_CRC_8822C(x, v) \
(BIT_CLEAR_SDIO_DATA_CRC_8822C(x) | BIT_SDIO_DATA_CRC_8822C(v))
/* 2 REG_SDIO_TRANS_FIFO_STATUS_8822C */
#define BIT_TRANS_FIFO_UNDERFLOW_8822C BIT(1)
#define BIT_TRANS_FIFO_OVERFLOW_8822C BIT(0)
#endif
================================================
FILE: hal/halmac/halmac_fw_info.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_FW_INFO_H_
#define _HALMAC_FW_INFO_H_
#define H2C_FORMAT_VERSION 12
/* FW bin information */
#define WLAN_FW_HDR_SIZE 64
#define WLAN_FW_HDR_CHKSUM_SIZE 8
#define WLAN_FW_HDR_VERSION 4
#define WLAN_FW_HDR_SUBVERSION 6
#define WLAN_FW_HDR_SUBINDEX 7
#define WLAN_FW_HDR_MONTH 16
#define WLAN_FW_HDR_DATE 17
#define WLAN_FW_HDR_HOUR 18
#define WLAN_FW_HDR_MIN 19
#define WLAN_FW_HDR_YEAR 20
#define WLAN_FW_HDR_MEM_USAGE 24
#define WLAN_FW_HDR_H2C_FMT_VER 28
#define WLAN_FW_HDR_DMEM_ADDR 32
#define WLAN_FW_HDR_DMEM_SIZE 36
#define WLAN_FW_HDR_IMEM_SIZE 48
#define WLAN_FW_HDR_EMEM_SIZE 52
#define WLAN_FW_HDR_EMEM_ADDR 56
#define WLAN_FW_HDR_IMEM_ADDR 60
#define H2C_ACK_HDR_CONTENT_LENGTH 8
#define CFG_PARAMETER_ACK_CONTENT_LENGTH 16
#define SCAN_STATUS_RPT_CONTENT_LENGTH 4
#define C2H_DBG_HDR_LEN 4
#define C2H_DBG_CONTENT_MAX_LENGTH 228
#define C2H_DBG_CONTENT_SEQ_OFFSET 1
/* Rename from FW SysHalCom_Debug_RAM.h */
#define FW_REG_H2CPKT_DONE_SEQ 0x1C8
#define FW_REG_WOW_REASON 0x1C7
enum halmac_data_type {
HALMAC_DATA_TYPE_MAC_REG = 0x00,
HALMAC_DATA_TYPE_BB_REG = 0x01,
HALMAC_DATA_TYPE_RADIO_A = 0x02,
HALMAC_DATA_TYPE_RADIO_B = 0x03,
HALMAC_DATA_TYPE_RADIO_C = 0x04,
HALMAC_DATA_TYPE_RADIO_D = 0x05,
HALMAC_DATA_TYPE_DRV_DEFINE_0 = 0x80,
HALMAC_DATA_TYPE_DRV_DEFINE_1 = 0x81,
HALMAC_DATA_TYPE_DRV_DEFINE_2 = 0x82,
HALMAC_DATA_TYPE_DRV_DEFINE_3 = 0x83,
HALMAC_DATA_TYPE_UNDEFINE = 0x7FFFFFFF,
};
enum halmac_packet_id {
HALMAC_PACKET_PROBE_REQ = 0x00,
HALMAC_PACKET_SYNC_BCN = 0x01,
HALMAC_PACKET_DISCOVERY_BCN = 0x02,
HALMAC_PACKET_PROBE_REQ_NLO = 0xF0,
HALMAC_PACKET_SYNC_BCN_NLO = 0xF1,
HALMAC_PACKET_DISCOVERY_BCN_NLO = 0xF2,
HALMAC_PACKET_UNDEFINE = 0x7FFFFFFF,
};
enum halmac_cs_action_id {
HALMAC_CS_ACTION_NONE = 0x00,
HALMAC_CS_ACTIVE_SCAN = 0x01,
HALMAC_CS_NAN_NONMASTER_DW = 0x02,
HALMAC_CS_NAN_NONMASTER_NONDW = 0x03,
HALMAC_CS_NAN_MASTER_NONDW = 0x04,
HALMAC_CS_NAN_MASTER_DW = 0x05,
HALMAC_CS_ACTION_UNDEFINE = 0x7FFFFFFF,
};
enum halmac_cs_extra_action_id {
HALMAC_CS_EXTRA_ACTION_NONE = 0x00,
HALMAC_CS_EXTRA_UPDATE_PROBE = 0x01,
HALMAC_CS_EXTRA_UPDATE_BEACON = 0x02,
HALMAC_CS_EXTRA_ACTION_UNDEFINE = 0x7FFFFFFF,
};
enum halmac_h2c_return_code {
HALMAC_H2C_RETURN_SUCCESS = 0x00,
HALMAC_H2C_RETURN_CFG_ERR_LEN = 0x01,
HALMAC_H2C_RETURN_CFG_ERR_CMD = 0x02,
HALMAC_H2C_RETURN_EFUSE_ERR_DUMP = 0x03,
HALMAC_H2C_RETURN_DATAPACK_ERR_FULL = 0x04,
HALMAC_H2C_RETURN_DATAPACK_ERR_ID = 0x05,
HALMAC_H2C_RETURN_RUN_ERR_EMPTY = 0x06,
HALMAC_H2C_RETURN_RUN_ERR_LEN = 0x07,
HALMAC_H2C_RETURN_RUN_ERR_CMD = 0x08,
HALMAC_H2C_RETURN_RUN_ERR_ID = 0x09,
HALMAC_H2C_RETURN_PACKET_ERR_FULL = 0x0A,
HALMAC_H2C_RETURN_PACKET_ERR_ID = 0x0B,
HALMAC_H2C_RETURN_SCAN_ERR_FULL = 0x0C,
HALMAC_H2C_RETURN_SCAN_ERR_PHYDM = 0x0D,
HALMAC_H2C_RETURN_ORIG_ERR_ID = 0x0E,
HALMAC_H2C_RETURN_UNDEFINE = 0x7FFFFFFF,
};
enum halmac_scan_report_code {
HALMAC_SCAN_REPORT_DONE = 0x00,
HALMAC_SCAN_REPORT_ERR_PHYDM = 0x01,
HALMAC_SCAN_REPORT_ERR_ID = 0x02,
HALMAC_SCAN_REPORT_ERR_TX = 0x03,
HALMAC_SCAN_REPORT_UNDEFINE = 0x7FFFFFFF,
};
#endif
================================================
FILE: hal/halmac/halmac_fw_offload_c2h_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_FWOFFLOADC2HFORMAT_H2C_C2H_AP_H_
#define _HAL_FWOFFLOADC2HFORMAT_H2C_C2H_AP_H_
#define C2H_SUB_CMD_ID_C2H_DBG 0X00
#define C2H_SUB_CMD_ID_BT_COEX_INFO 0X02
#define C2H_SUB_CMD_ID_SCAN_STATUS_RPT 0X03
#define C2H_SUB_CMD_ID_H2C_ACK_HDR 0X01
#define C2H_SUB_CMD_ID_CFG_PARAM_ACK 0X01
#define C2H_SUB_CMD_ID_CH_SWITCH_ACK 0X01
#define C2H_SUB_CMD_ID_BT_COEX_ACK 0X01
#define C2H_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK 0X01
#define C2H_SUB_CMD_ID_UPDATE_PKT_ACK 0X01
#define C2H_SUB_CMD_ID_UPDATE_DATAPACK_ACK 0X01
#define C2H_SUB_CMD_ID_RUN_DATAPACK_ACK 0X01
#define C2H_SUB_CMD_ID_IQK_ACK 0X01
#define C2H_SUB_CMD_ID_PWR_TRK_ACK 0X01
#define C2H_SUB_CMD_ID_PSD_ACK 0X01
#define C2H_SUB_CMD_ID_FW_MEM_DUMP_ACK 0X01
#define C2H_SUB_CMD_ID_PSD_DATA 0X04
#define C2H_SUB_CMD_ID_EFUSE_DATA 0X05
#define C2H_SUB_CMD_ID_IQK_DATA 0X06
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_DBG 0X07
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_2_DBG 0X08
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_3_DBG 0X09
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_4_DBG 0X0A
#define C2H_SUB_CMD_ID_FTMACKRPT_HDL_DBG 0X0B
#define C2H_SUB_CMD_ID_FTMC2H_RPT 0X0C
#define C2H_SUB_CMD_ID_DRVFTMC2H_RPT 0X0D
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_5_DBG 0X0E
#define C2H_SUB_CMD_ID_CCX_RPT 0X0F
#define C2H_SUB_CMD_ID_C2H_PKT_NAN_RPT 0X10
#define C2H_SUB_CMD_ID_C2H_PKT_ATM_RPT 0X11
#define C2H_SUB_CMD_ID_C2H_PKT_FTMSESSION_END 0X1C
#define C2H_SUB_CMD_ID_C2H_PKT_DETECT_THERMAL 0X1D
#define C2H_SUB_CMD_ID_FW_DBG_MSG 0XFF
#define C2H_SUB_CMD_ID_FW_SNDING_ACK 0X01
#define C2H_SUB_CMD_ID_FW_FWCTRL_RPT 0X1F
#define C2H_SUB_CMD_ID_H2C_LOOPBACK_ACK 0X20
#define C2H_SUB_CMD_ID_FWCMD_LOOPBACK_ACK 0X21
#define C2H_SUB_CMD_ID_SCAN_CH_NOTIFY 0X22
#define C2H_SUB_CMD_ID_FW_TBTT_RPT 0X23
#define C2H_SUB_CMD_ID_BCN_OFFLOAD 0X24
#define H2C_SUB_CMD_ID_CFG_PARAM_ACK SUB_CMD_ID_CFG_PARAM
#define H2C_SUB_CMD_ID_CH_SWITCH_ACK SUB_CMD_ID_CH_SWITCH
#define H2C_SUB_CMD_ID_BT_COEX_ACK SUB_CMD_ID_BT_COEX
#define H2C_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK SUB_CMD_ID_DUMP_PHYSICAL_EFUSE
#define H2C_SUB_CMD_ID_UPDATE_PKT_ACK SUB_CMD_ID_UPDATE_PKT
#define H2C_SUB_CMD_ID_UPDATE_DATAPACK_ACK SUB_CMD_ID_UPDATE_DATAPACK
#define H2C_SUB_CMD_ID_RUN_DATAPACK_ACK SUB_CMD_ID_RUN_DATAPACK
#define H2C_SUB_CMD_ID_IQK_ACK SUB_CMD_ID_IQK
#define H2C_SUB_CMD_ID_PWR_TRK_ACK SUB_CMD_ID_PWR_TRK
#define H2C_SUB_CMD_ID_PSD_ACK SUB_CMD_ID_PSD
#define H2C_SUB_CMD_ID_FW_MEM_DUMP_ACK SUB_CMD_ID_FW_MEM_DUMP
#define H2C_SUB_CMD_ID_CCX_RPT SUB_CMD_ID_CCX_RPT
#define H2C_SUB_CMD_ID_FW_DBG_MSG SUB_CMD_ID_FW_DBG_MSG
#define H2C_SUB_CMD_ID_FW_SNDING_ACK SUB_CMD_ID_FW_SNDING
#define H2C_SUB_CMD_ID_FW_FWCTRL_RPT SUB_CMD_ID_FW_FWCTRL_RPT
#define H2C_SUB_CMD_ID_H2C_LOOPBACK_ACK SUB_CMD_ID_H2C_LOOPBACK
#define H2C_SUB_CMD_ID_FWCMD_LOOPBACK_ACK SUB_CMD_ID_FWCMD_LOOPBACK
#define H2C_CMD_ID_CFG_PARAM_ACK 0XFF
#define H2C_CMD_ID_CH_SWITCH_ACK 0XFF
#define H2C_CMD_ID_BT_COEX_ACK 0XFF
#define H2C_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK 0XFF
#define H2C_CMD_ID_UPDATE_PKT_ACK 0XFF
#define H2C_CMD_ID_UPDATE_DATAPACK_ACK 0XFF
#define H2C_CMD_ID_RUN_DATAPACK_ACK 0XFF
#define H2C_CMD_ID_IQK_ACK 0XFF
#define H2C_CMD_ID_PWR_TRK_ACK 0XFF
#define H2C_CMD_ID_PSD_ACK 0XFF
#define H2C_CMD_ID_FW_MEM_DUMP_ACK 0XFF
#define H2C_CMD_ID_CCX_RPT 0XFF
#define H2C_CMD_ID_FW_DBG_MSG 0XFF
#define H2C_CMD_ID_FW_SNDING_ACK 0XFF
#define H2C_CMD_ID_FW_FWCTRL_RPT 0XFF
#define H2C_CMD_ID_H2C_LOOPBACK_ACK 0XFF
#define H2C_CMD_ID_FWCMD_LOOPBACK_ACK 0XFF
#define C2H_HDR_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_HDR_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_HDR_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_HDR_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_HDR_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_HDR_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_HDR_GET_C2H_SUB_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define C2H_HDR_SET_C2H_SUB_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_HDR_SET_C2H_SUB_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_HDR_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define C2H_HDR_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_HDR_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_DBG_GET_DBG_MSG(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define C2H_DBG_SET_DBG_MSG(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_DBG_SET_DBG_MSG_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define BT_COEX_INFO_GET_DATA_START(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define BT_COEX_INFO_SET_DATA_START(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define BT_COEX_INFO_SET_DATA_START_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_STATUS_RPT_GET_H2C_RETURN_CODE(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define SCAN_STATUS_RPT_SET_H2C_RETURN_CODE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_STATUS_RPT_SET_H2C_RETURN_CODE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_STATUS_RPT_GET_H2C_SEQ(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 16)
#define SCAN_STATUS_RPT_SET_H2C_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 16, value)
#define SCAN_STATUS_RPT_SET_H2C_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 16, value)
#define SCAN_STATUS_RPT_GET_TSF_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define SCAN_STATUS_RPT_SET_TSF_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
#define SCAN_STATUS_RPT_SET_TSF_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
#define SCAN_STATUS_RPT_SET_TSF_2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_3(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 24, 8)
#define SCAN_STATUS_RPT_SET_TSF_3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 24, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 24, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_4(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 0, 8)
#define SCAN_STATUS_RPT_SET_TSF_4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 0, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 0, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_5(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 8, 8)
#define SCAN_STATUS_RPT_SET_TSF_5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 8, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 8, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_6(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 16, 8)
#define SCAN_STATUS_RPT_SET_TSF_6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 16, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 16, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_7(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 24, 8)
#define SCAN_STATUS_RPT_SET_TSF_7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 24, 8, value)
#define SCAN_STATUS_RPT_SET_TSF_7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 24, 8, value)
#define H2C_ACK_HDR_GET_H2C_RETURN_CODE(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define H2C_ACK_HDR_SET_H2C_RETURN_CODE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define H2C_ACK_HDR_SET_H2C_RETURN_CODE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define H2C_ACK_HDR_GET_H2C_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define H2C_ACK_HDR_SET_H2C_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define H2C_ACK_HDR_SET_H2C_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define H2C_ACK_HDR_GET_H2C_SUB_CMD_ID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 16)
#define H2C_ACK_HDR_SET_H2C_SUB_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 16, value)
#define H2C_ACK_HDR_SET_H2C_SUB_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 16, value)
#define H2C_ACK_HDR_GET_H2C_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 16)
#define H2C_ACK_HDR_SET_H2C_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 16, value)
#define H2C_ACK_HDR_SET_H2C_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 16, value)
#define CFG_PARAM_ACK_GET_OFFSET_ACCUMULATION(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0XC, 0, 32)
#define CFG_PARAM_ACK_SET_OFFSET_ACCUMULATION(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 0, 32, value)
#define CFG_PARAM_ACK_SET_OFFSET_ACCUMULATION_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 0, 32, value)
#define CFG_PARAM_ACK_GET_VALUE_ACCUMULATION(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X10, 0, 32)
#define CFG_PARAM_ACK_SET_VALUE_ACCUMULATION(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X10, 0, 32, value)
#define CFG_PARAM_ACK_SET_VALUE_ACCUMULATION_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X10, 0, 32, value)
#define CH_SWITCH_ACK_GET_TSF_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 0, 8)
#define CH_SWITCH_ACK_SET_TSF_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define CH_SWITCH_ACK_SET_TSF_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define CH_SWITCH_ACK_GET_TSF_1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 8, 8)
#define CH_SWITCH_ACK_SET_TSF_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define CH_SWITCH_ACK_SET_TSF_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define CH_SWITCH_ACK_GET_TSF_2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define CH_SWITCH_ACK_SET_TSF_2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define CH_SWITCH_ACK_SET_TSF_2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define CH_SWITCH_ACK_GET_TSF_3(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define CH_SWITCH_ACK_SET_TSF_3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define CH_SWITCH_ACK_SET_TSF_3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define CH_SWITCH_ACK_GET_TSF_4(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X10, 0, 8)
#define CH_SWITCH_ACK_SET_TSF_4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X10, 0, 8, value)
#define CH_SWITCH_ACK_SET_TSF_4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X10, 0, 8, value)
#define CH_SWITCH_ACK_GET_TSF_5(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X10, 8, 8)
#define CH_SWITCH_ACK_SET_TSF_5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X10, 8, 8, value)
#define CH_SWITCH_ACK_SET_TSF_5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X10, 8, 8, value)
#define CH_SWITCH_ACK_GET_TSF_6(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X10, 16, 8)
#define CH_SWITCH_ACK_SET_TSF_6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X10, 16, 8, value)
#define CH_SWITCH_ACK_SET_TSF_6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X10, 16, 8, value)
#define CH_SWITCH_ACK_GET_TSF_7(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X10, 24, 8)
#define CH_SWITCH_ACK_SET_TSF_7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X10, 24, 8, value)
#define CH_SWITCH_ACK_SET_TSF_7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X10, 24, 8, value)
#define BT_COEX_ACK_GET_DATA_START(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 0, 8)
#define BT_COEX_ACK_SET_DATA_START(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 0, 8, value)
#define BT_COEX_ACK_SET_DATA_START_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 0, 8, value)
#define PSD_DATA_GET_SEGMENT_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 7)
#define PSD_DATA_SET_SEGMENT_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 7, value)
#define PSD_DATA_SET_SEGMENT_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 7, value)
#define PSD_DATA_GET_END_SEGMENT(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 7, 1)
#define PSD_DATA_SET_END_SEGMENT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 7, 1, value)
#define PSD_DATA_SET_END_SEGMENT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 7, 1, value)
#define PSD_DATA_GET_SEGMENT_SIZE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define PSD_DATA_SET_SEGMENT_SIZE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define PSD_DATA_SET_SEGMENT_SIZE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define PSD_DATA_GET_TOTAL_SIZE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 16)
#define PSD_DATA_SET_TOTAL_SIZE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 16, value)
#define PSD_DATA_SET_TOTAL_SIZE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 16, value)
#define PSD_DATA_GET_H2C_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 0, 16)
#define PSD_DATA_SET_H2C_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 0, 16, value)
#define PSD_DATA_SET_H2C_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 0, 16, value)
#define PSD_DATA_GET_DATA_START(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 16, 8)
#define PSD_DATA_SET_DATA_START(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 16, 8, value)
#define PSD_DATA_SET_DATA_START_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 16, 8, value)
#define EFUSE_DATA_GET_SEGMENT_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 7)
#define EFUSE_DATA_SET_SEGMENT_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 7, value)
#define EFUSE_DATA_SET_SEGMENT_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 7, value)
#define EFUSE_DATA_GET_END_SEGMENT(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 7, 1)
#define EFUSE_DATA_SET_END_SEGMENT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 7, 1, value)
#define EFUSE_DATA_SET_END_SEGMENT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 7, 1, value)
#define EFUSE_DATA_GET_SEGMENT_SIZE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define EFUSE_DATA_SET_SEGMENT_SIZE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define EFUSE_DATA_SET_SEGMENT_SIZE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define EFUSE_DATA_GET_TOTAL_SIZE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 16)
#define EFUSE_DATA_SET_TOTAL_SIZE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 16, value)
#define EFUSE_DATA_SET_TOTAL_SIZE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 16, value)
#define EFUSE_DATA_GET_H2C_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 0, 16)
#define EFUSE_DATA_SET_H2C_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 0, 16, value)
#define EFUSE_DATA_SET_H2C_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 0, 16, value)
#define EFUSE_DATA_GET_DATA_START(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 16, 8)
#define EFUSE_DATA_SET_DATA_START(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 16, 8, value)
#define EFUSE_DATA_SET_DATA_START_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 16, 8, value)
#define IQK_DATA_GET_SEGMENT_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 7)
#define IQK_DATA_SET_SEGMENT_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 7, value)
#define IQK_DATA_SET_SEGMENT_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 7, value)
#define IQK_DATA_GET_END_SEGMENT(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 7, 1)
#define IQK_DATA_SET_END_SEGMENT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 7, 1, value)
#define IQK_DATA_SET_END_SEGMENT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 7, 1, value)
#define IQK_DATA_GET_SEGMENT_SIZE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define IQK_DATA_SET_SEGMENT_SIZE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define IQK_DATA_SET_SEGMENT_SIZE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define IQK_DATA_GET_TOTAL_SIZE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 16)
#define IQK_DATA_SET_TOTAL_SIZE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 16, value)
#define IQK_DATA_SET_TOTAL_SIZE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 16, value)
#define IQK_DATA_GET_H2C_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 0, 16)
#define IQK_DATA_SET_H2C_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 0, 16, value)
#define IQK_DATA_SET_H2C_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 0, 16, value)
#define IQK_DATA_GET_DATA_START(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 16, 8)
#define IQK_DATA_SET_DATA_START(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 16, 8, value)
#define IQK_DATA_SET_DATA_START_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 16, 8, value)
#define CCX_RPT_GET_POLLUTED(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X4, 0, 1)
#define CCX_RPT_SET_POLLUTED(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 0, 1, value)
#define CCX_RPT_SET_POLLUTED_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 0, 1, value)
#define CCX_RPT_GET_RPT_SEL(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X4, 5, 3)
#define CCX_RPT_SET_RPT_SEL(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 5, 3, value)
#define CCX_RPT_SET_RPT_SEL_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 5, 3, value)
#define CCX_RPT_GET_QSEL(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X4, 8, 5)
#define CCX_RPT_SET_QSEL(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 8, 5, value)
#define CCX_RPT_SET_QSEL_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 8, 5, value)
#define CCX_RPT_GET_MISSED_RPT_NUM(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X4, 13, 3)
#define CCX_RPT_SET_MISSED_RPT_NUM(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 13, 3, value)
#define CCX_RPT_SET_MISSED_RPT_NUM_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 13, 3, value)
#define CCX_RPT_GET_MACID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X4, 16, 7)
#define CCX_RPT_SET_MACID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 16, 7, value)
#define CCX_RPT_SET_MACID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 16, 7, value)
#define CCX_RPT_GET_INITIAL_DATA_RATE(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X4, 24, 7)
#define CCX_RPT_SET_INITIAL_DATA_RATE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 24, 7, value)
#define CCX_RPT_SET_INITIAL_DATA_RATE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 24, 7, value)
#define CCX_RPT_GET_INITIAL_SGI(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X4, 31, 1)
#define CCX_RPT_SET_INITIAL_SGI(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X4, 31, 1, value)
#define CCX_RPT_SET_INITIAL_SGI_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X4, 31, 1, value)
#define CCX_RPT_GET_QUEUE_TIME(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 0, 16)
#define CCX_RPT_SET_QUEUE_TIME(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 0, 16, value)
#define CCX_RPT_SET_QUEUE_TIME_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 0, 16, value)
#define CCX_RPT_GET_SW_DEFINE_BYTE0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 16, 8)
#define CCX_RPT_SET_SW_DEFINE_BYTE0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 16, 8, value)
#define CCX_RPT_SET_SW_DEFINE_BYTE0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 16, 8, value)
#define CCX_RPT_GET_RTS_RETRY_COUNT(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 24, 4)
#define CCX_RPT_SET_RTS_RETRY_COUNT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 24, 4, value)
#define CCX_RPT_SET_RTS_RETRY_COUNT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 24, 4, value)
#define CCX_RPT_GET_BMC(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 29, 1)
#define CCX_RPT_SET_BMC(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 29, 1, value)
#define CCX_RPT_SET_BMC_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 29, 1, value)
#define CCX_RPT_GET_TX_STATE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X8, 30, 2)
#define CCX_RPT_SET_TX_STATE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 30, 2, value)
#define CCX_RPT_SET_TX_STATE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 30, 2, value)
#define CCX_RPT_GET_DATA_RETRY_COUNT(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 0, 6)
#define CCX_RPT_SET_DATA_RETRY_COUNT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 0, 6, value)
#define CCX_RPT_SET_DATA_RETRY_COUNT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 0, 6, value)
#define CCX_RPT_GET_FINAL_DATA_RATE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 8, 7)
#define CCX_RPT_SET_FINAL_DATA_RATE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 8, 7, value)
#define CCX_RPT_SET_FINAL_DATA_RATE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 8, 7, value)
#define CCX_RPT_GET_FINAL_SGI(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 15, 1)
#define CCX_RPT_SET_FINAL_SGI(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 15, 1, value)
#define CCX_RPT_SET_FINAL_SGI_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 15, 1, value)
#define CCX_RPT_GET_RF_CH_NUM(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 16, 10)
#define CCX_RPT_SET_RF_CH_NUM(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 16, 10, value)
#define CCX_RPT_SET_RF_CH_NUM_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 16, 10, value)
#define CCX_RPT_GET_SC(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 26, 4)
#define CCX_RPT_SET_SC(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 26, 4, value)
#define CCX_RPT_SET_SC_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 26, 4, value)
#define CCX_RPT_GET_BW(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0XC, 30, 2)
#define CCX_RPT_SET_BW(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0XC, 30, 2, value)
#define CCX_RPT_SET_BW_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0XC, 30, 2, value)
#define FW_DBG_MSG_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define FW_DBG_MSG_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define FW_DBG_MSG_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define FW_DBG_MSG_GET_C2H_SUB_CMD_ID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define FW_DBG_MSG_SET_C2H_SUB_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define FW_DBG_MSG_SET_C2H_SUB_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define FW_DBG_MSG_GET_FULL(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 1)
#define FW_DBG_MSG_SET_FULL(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 1, value)
#define FW_DBG_MSG_SET_FULL_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 1, value)
#define FW_DBG_MSG_GET_OWN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 31, 1)
#define FW_DBG_MSG_SET_OWN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 31, 1, value)
#define FW_DBG_MSG_SET_OWN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 31, 1, value)
#define FW_FWCTRL_RPT_GET_EVT_TYPE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define FW_FWCTRL_RPT_SET_EVT_TYPE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define FW_FWCTRL_RPT_SET_EVT_TYPE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define FW_FWCTRL_RPT_GET_LENGTH(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define FW_FWCTRL_RPT_SET_LENGTH(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define FW_FWCTRL_RPT_SET_LENGTH_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define FW_FWCTRL_RPT_GET_SEQ_NUM(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define FW_FWCTRL_RPT_SET_SEQ_NUM(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define FW_FWCTRL_RPT_SET_SEQ_NUM_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define FW_FWCTRL_RPT_GET_IS_ACK(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 1)
#define FW_FWCTRL_RPT_SET_IS_ACK(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 1, value)
#define FW_FWCTRL_RPT_SET_IS_ACK_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 1, value)
#define FW_FWCTRL_RPT_GET_MORE_CONTENT(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 25, 1)
#define FW_FWCTRL_RPT_SET_MORE_CONTENT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 25, 1, value)
#define FW_FWCTRL_RPT_SET_MORE_CONTENT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 25, 1, value)
#define FW_FWCTRL_RPT_GET_CONTENT_IDX(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 26, 6)
#define FW_FWCTRL_RPT_SET_CONTENT_IDX(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 26, 6, value)
#define FW_FWCTRL_RPT_SET_CONTENT_IDX_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 26, 6, value)
#define FW_FWCTRL_RPT_GET_CLASS_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define FW_FWCTRL_RPT_SET_CLASS_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define FW_FWCTRL_RPT_SET_CLASS_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define FW_FWCTRL_RPT_GET_CONTENT(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 16)
#define FW_FWCTRL_RPT_SET_CONTENT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 16, value)
#define FW_FWCTRL_RPT_SET_CONTENT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 16, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_2(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_3(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_4(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 0, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 0, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 0, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_5(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 8, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 8, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 8, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_6(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 16, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 16, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 16, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_7(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 24, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 24, 8, value)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 24, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_2(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_3(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_4(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 0, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 0, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 0, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_5(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 8, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 8, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 8, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_6(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 16, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 16, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 16, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_7(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X8, 24, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X8, 24, 8, value)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X8, 24, 8, value)
#define SCAN_CH_NOTIFY_GET_CH_NUM(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define SCAN_CH_NOTIFY_SET_CH_NUM(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_CH_NOTIFY_SET_CH_NUM_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_CH_NOTIFY_GET_NOTIFY_ID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define SCAN_CH_NOTIFY_SET_NOTIFY_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define SCAN_CH_NOTIFY_SET_NOTIFY_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define SCAN_CH_NOTIFY_GET_STATUS(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define SCAN_CH_NOTIFY_SET_STATUS(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define SCAN_CH_NOTIFY_SET_STATUS_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define SCAN_CH_NOTIFY_SET_TSF_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
#define SCAN_CH_NOTIFY_SET_TSF_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
#define SCAN_CH_NOTIFY_SET_TSF_2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_3(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 24, 8)
#define SCAN_CH_NOTIFY_SET_TSF_3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 24, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 24, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_4(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 0, 8)
#define SCAN_CH_NOTIFY_SET_TSF_4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_5(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 8, 8)
#define SCAN_CH_NOTIFY_SET_TSF_5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_6(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define SCAN_CH_NOTIFY_SET_TSF_6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_7(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define SCAN_CH_NOTIFY_SET_TSF_7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define SCAN_CH_NOTIFY_SET_TSF_7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define FW_TBTT_RPT_GET_PORT_NUMBER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define FW_TBTT_RPT_SET_PORT_NUMBER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define FW_TBTT_RPT_SET_PORT_NUMBER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define BCN_OFFLOAD_GET_SUPPORT_VER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define BCN_OFFLOAD_SET_SUPPORT_VER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define BCN_OFFLOAD_SET_SUPPORT_VER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define BCN_OFFLOAD_GET_STATUS(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define BCN_OFFLOAD_SET_STATUS(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define BCN_OFFLOAD_SET_STATUS_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#endif
================================================
FILE: hal/halmac/halmac_fw_offload_c2h_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_FWOFFLOADC2HFORMAT_H2C_C2H_NIC_H_
#define _HAL_FWOFFLOADC2HFORMAT_H2C_C2H_NIC_H_
#define C2H_SUB_CMD_ID_C2H_DBG 0X00
#define C2H_SUB_CMD_ID_BT_COEX_INFO 0X02
#define C2H_SUB_CMD_ID_SCAN_STATUS_RPT 0X03
#define C2H_SUB_CMD_ID_H2C_ACK_HDR 0X01
#define C2H_SUB_CMD_ID_CFG_PARAM_ACK 0X01
#define C2H_SUB_CMD_ID_CH_SWITCH_ACK 0X01
#define C2H_SUB_CMD_ID_BT_COEX_ACK 0X01
#define C2H_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK 0X01
#define C2H_SUB_CMD_ID_UPDATE_PKT_ACK 0X01
#define C2H_SUB_CMD_ID_UPDATE_DATAPACK_ACK 0X01
#define C2H_SUB_CMD_ID_RUN_DATAPACK_ACK 0X01
#define C2H_SUB_CMD_ID_IQK_ACK 0X01
#define C2H_SUB_CMD_ID_PWR_TRK_ACK 0X01
#define C2H_SUB_CMD_ID_PSD_ACK 0X01
#define C2H_SUB_CMD_ID_FW_MEM_DUMP_ACK 0X01
#define C2H_SUB_CMD_ID_PSD_DATA 0X04
#define C2H_SUB_CMD_ID_EFUSE_DATA 0X05
#define C2H_SUB_CMD_ID_IQK_DATA 0X06
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_DBG 0X07
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_2_DBG 0X08
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_3_DBG 0X09
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_4_DBG 0X0A
#define C2H_SUB_CMD_ID_FTMACKRPT_HDL_DBG 0X0B
#define C2H_SUB_CMD_ID_FTMC2H_RPT 0X0C
#define C2H_SUB_CMD_ID_DRVFTMC2H_RPT 0X0D
#define C2H_SUB_CMD_ID_C2H_PKT_FTM_5_DBG 0X0E
#define C2H_SUB_CMD_ID_CCX_RPT 0X0F
#define C2H_SUB_CMD_ID_C2H_PKT_NAN_RPT 0X10
#define C2H_SUB_CMD_ID_C2H_PKT_ATM_RPT 0X11
#define C2H_SUB_CMD_ID_C2H_PKT_FTMSESSION_END 0X1C
#define C2H_SUB_CMD_ID_C2H_PKT_DETECT_THERMAL 0X1D
#define C2H_SUB_CMD_ID_FW_DBG_MSG 0XFF
#define C2H_SUB_CMD_ID_FW_SNDING_ACK 0X01
#define C2H_SUB_CMD_ID_FW_FWCTRL_RPT 0X1F
#define C2H_SUB_CMD_ID_H2C_LOOPBACK_ACK 0X20
#define C2H_SUB_CMD_ID_FWCMD_LOOPBACK_ACK 0X21
#define C2H_SUB_CMD_ID_SCAN_CH_NOTIFY 0X22
#define C2H_SUB_CMD_ID_FW_TBTT_RPT 0X23
#define C2H_SUB_CMD_ID_BCN_OFFLOAD 0X24
#define H2C_SUB_CMD_ID_CFG_PARAM_ACK SUB_CMD_ID_CFG_PARAM
#define H2C_SUB_CMD_ID_CH_SWITCH_ACK SUB_CMD_ID_CH_SWITCH
#define H2C_SUB_CMD_ID_BT_COEX_ACK SUB_CMD_ID_BT_COEX
#define H2C_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK SUB_CMD_ID_DUMP_PHYSICAL_EFUSE
#define H2C_SUB_CMD_ID_UPDATE_PKT_ACK SUB_CMD_ID_UPDATE_PKT
#define H2C_SUB_CMD_ID_UPDATE_DATAPACK_ACK SUB_CMD_ID_UPDATE_DATAPACK
#define H2C_SUB_CMD_ID_RUN_DATAPACK_ACK SUB_CMD_ID_RUN_DATAPACK
#define H2C_SUB_CMD_ID_IQK_ACK SUB_CMD_ID_IQK
#define H2C_SUB_CMD_ID_PWR_TRK_ACK SUB_CMD_ID_PWR_TRK
#define H2C_SUB_CMD_ID_PSD_ACK SUB_CMD_ID_PSD
#define H2C_SUB_CMD_ID_FW_MEM_DUMP_ACK SUB_CMD_ID_FW_MEM_DUMP
#define H2C_SUB_CMD_ID_CCX_RPT SUB_CMD_ID_CCX_RPT
#define H2C_SUB_CMD_ID_FW_DBG_MSG SUB_CMD_ID_FW_DBG_MSG
#define H2C_SUB_CMD_ID_FW_SNDING_ACK SUB_CMD_ID_FW_SNDING
#define H2C_SUB_CMD_ID_FW_FWCTRL_RPT SUB_CMD_ID_FW_FWCTRL_RPT
#define H2C_SUB_CMD_ID_H2C_LOOPBACK_ACK SUB_CMD_ID_H2C_LOOPBACK
#define H2C_SUB_CMD_ID_FWCMD_LOOPBACK_ACK SUB_CMD_ID_FWCMD_LOOPBACK
#define H2C_CMD_ID_CFG_PARAM_ACK 0XFF
#define H2C_CMD_ID_CH_SWITCH_ACK 0XFF
#define H2C_CMD_ID_BT_COEX_ACK 0XFF
#define H2C_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK 0XFF
#define H2C_CMD_ID_UPDATE_PKT_ACK 0XFF
#define H2C_CMD_ID_UPDATE_DATAPACK_ACK 0XFF
#define H2C_CMD_ID_RUN_DATAPACK_ACK 0XFF
#define H2C_CMD_ID_IQK_ACK 0XFF
#define H2C_CMD_ID_PWR_TRK_ACK 0XFF
#define H2C_CMD_ID_PSD_ACK 0XFF
#define H2C_CMD_ID_FW_MEM_DUMP_ACK 0XFF
#define H2C_CMD_ID_CCX_RPT 0XFF
#define H2C_CMD_ID_FW_DBG_MSG 0XFF
#define H2C_CMD_ID_FW_SNDING_ACK 0XFF
#define H2C_CMD_ID_FW_FWCTRL_RPT 0XFF
#define H2C_CMD_ID_H2C_LOOPBACK_ACK 0XFF
#define H2C_CMD_ID_FWCMD_LOOPBACK_ACK 0XFF
#define C2H_HDR_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_HDR_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_HDR_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_HDR_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_HDR_GET_C2H_SUB_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define C2H_HDR_SET_C2H_SUB_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define C2H_HDR_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define C2H_HDR_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define C2H_DBG_GET_DBG_MSG(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define C2H_DBG_SET_DBG_MSG(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define BT_COEX_INFO_GET_DATA_START(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define BT_COEX_INFO_SET_DATA_START(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_STATUS_RPT_GET_H2C_RETURN_CODE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define SCAN_STATUS_RPT_SET_H2C_RETURN_CODE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_STATUS_RPT_GET_H2C_SEQ(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 16)
#define SCAN_STATUS_RPT_SET_H2C_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 16, value)
#define SCAN_STATUS_RPT_GET_TSF_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define SCAN_STATUS_RPT_SET_TSF_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
#define SCAN_STATUS_RPT_SET_TSF_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
#define SCAN_STATUS_RPT_SET_TSF_2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_3(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 24, 8)
#define SCAN_STATUS_RPT_SET_TSF_3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 24, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_4(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 0, 8)
#define SCAN_STATUS_RPT_SET_TSF_4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 0, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_5(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 8, 8)
#define SCAN_STATUS_RPT_SET_TSF_5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 8, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_6(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 16, 8)
#define SCAN_STATUS_RPT_SET_TSF_6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 16, 8, value)
#define SCAN_STATUS_RPT_GET_TSF_7(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 24, 8)
#define SCAN_STATUS_RPT_SET_TSF_7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 24, 8, value)
#define H2C_ACK_HDR_GET_H2C_RETURN_CODE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define H2C_ACK_HDR_SET_H2C_RETURN_CODE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define H2C_ACK_HDR_GET_H2C_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define H2C_ACK_HDR_SET_H2C_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define H2C_ACK_HDR_GET_H2C_SUB_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 16)
#define H2C_ACK_HDR_SET_H2C_SUB_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 16, value)
#define H2C_ACK_HDR_GET_H2C_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 16)
#define H2C_ACK_HDR_SET_H2C_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 16, value)
#define CFG_PARAM_ACK_GET_OFFSET_ACCUMULATION(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 0, 32)
#define CFG_PARAM_ACK_SET_OFFSET_ACCUMULATION(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 0, 32, value)
#define CFG_PARAM_ACK_GET_VALUE_ACCUMULATION(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X10, 0, 32)
#define CFG_PARAM_ACK_SET_VALUE_ACCUMULATION(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X10, 0, 32, value)
#define CH_SWITCH_ACK_GET_TSF_0(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 0, 8)
#define CH_SWITCH_ACK_SET_TSF_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 0, 8, value)
#define CH_SWITCH_ACK_GET_TSF_1(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 8, 8)
#define CH_SWITCH_ACK_SET_TSF_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 8, 8, value)
#define CH_SWITCH_ACK_GET_TSF_2(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define CH_SWITCH_ACK_SET_TSF_2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define CH_SWITCH_ACK_GET_TSF_3(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define CH_SWITCH_ACK_SET_TSF_3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define CH_SWITCH_ACK_GET_TSF_4(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X10, 0, 8)
#define CH_SWITCH_ACK_SET_TSF_4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X10, 0, 8, value)
#define CH_SWITCH_ACK_GET_TSF_5(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X10, 8, 8)
#define CH_SWITCH_ACK_SET_TSF_5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X10, 8, 8, value)
#define CH_SWITCH_ACK_GET_TSF_6(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X10, 16, 8)
#define CH_SWITCH_ACK_SET_TSF_6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X10, 16, 8, value)
#define CH_SWITCH_ACK_GET_TSF_7(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X10, 24, 8)
#define CH_SWITCH_ACK_SET_TSF_7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X10, 24, 8, value)
#define BT_COEX_ACK_GET_DATA_START(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 0, 8)
#define BT_COEX_ACK_SET_DATA_START(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 0, 8, value)
#define PSD_DATA_GET_SEGMENT_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 7)
#define PSD_DATA_SET_SEGMENT_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 7, value)
#define PSD_DATA_GET_END_SEGMENT(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 7, 1)
#define PSD_DATA_SET_END_SEGMENT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 7, 1, value)
#define PSD_DATA_GET_SEGMENT_SIZE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define PSD_DATA_SET_SEGMENT_SIZE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define PSD_DATA_GET_TOTAL_SIZE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 16)
#define PSD_DATA_SET_TOTAL_SIZE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 16, value)
#define PSD_DATA_GET_H2C_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 0, 16)
#define PSD_DATA_SET_H2C_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 0, 16, value)
#define PSD_DATA_GET_DATA_START(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 16, 8)
#define PSD_DATA_SET_DATA_START(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 16, 8, value)
#define EFUSE_DATA_GET_SEGMENT_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 7)
#define EFUSE_DATA_SET_SEGMENT_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 7, value)
#define EFUSE_DATA_GET_END_SEGMENT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 7, 1)
#define EFUSE_DATA_SET_END_SEGMENT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 7, 1, value)
#define EFUSE_DATA_GET_SEGMENT_SIZE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define EFUSE_DATA_SET_SEGMENT_SIZE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define EFUSE_DATA_GET_TOTAL_SIZE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 16)
#define EFUSE_DATA_SET_TOTAL_SIZE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 16, value)
#define EFUSE_DATA_GET_H2C_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 0, 16)
#define EFUSE_DATA_SET_H2C_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 0, 16, value)
#define EFUSE_DATA_GET_DATA_START(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 16, 8)
#define EFUSE_DATA_SET_DATA_START(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 16, 8, value)
#define IQK_DATA_GET_SEGMENT_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 7)
#define IQK_DATA_SET_SEGMENT_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 7, value)
#define IQK_DATA_GET_END_SEGMENT(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 7, 1)
#define IQK_DATA_SET_END_SEGMENT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 7, 1, value)
#define IQK_DATA_GET_SEGMENT_SIZE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define IQK_DATA_SET_SEGMENT_SIZE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define IQK_DATA_GET_TOTAL_SIZE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 16)
#define IQK_DATA_SET_TOTAL_SIZE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 16, value)
#define IQK_DATA_GET_H2C_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 0, 16)
#define IQK_DATA_SET_H2C_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 0, 16, value)
#define IQK_DATA_GET_DATA_START(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 16, 8)
#define IQK_DATA_SET_DATA_START(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 16, 8, value)
#define CCX_RPT_GET_POLLUTED(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 0, 1)
#define CCX_RPT_SET_POLLUTED(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 0, 1, value)
#define CCX_RPT_GET_RPT_SEL(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 5, 3)
#define CCX_RPT_SET_RPT_SEL(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 5, 3, value)
#define CCX_RPT_GET_QSEL(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 8, 5)
#define CCX_RPT_SET_QSEL(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 8, 5, value)
#define CCX_RPT_GET_MISSED_RPT_NUM(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 13, 3)
#define CCX_RPT_SET_MISSED_RPT_NUM(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 13, 3, value)
#define CCX_RPT_GET_MACID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 16, 7)
#define CCX_RPT_SET_MACID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 16, 7, value)
#define CCX_RPT_GET_INITIAL_DATA_RATE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 24, 7)
#define CCX_RPT_SET_INITIAL_DATA_RATE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 24, 7, value)
#define CCX_RPT_GET_INITIAL_SGI(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X4, 31, 1)
#define CCX_RPT_SET_INITIAL_SGI(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X4, 31, 1, value)
#define CCX_RPT_GET_QUEUE_TIME(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 0, 16)
#define CCX_RPT_SET_QUEUE_TIME(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 0, 16, value)
#define CCX_RPT_GET_SW_DEFINE_BYTE0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 16, 8)
#define CCX_RPT_SET_SW_DEFINE_BYTE0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 16, 8, value)
#define CCX_RPT_GET_RTS_RETRY_COUNT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 24, 4)
#define CCX_RPT_SET_RTS_RETRY_COUNT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 24, 4, value)
#define CCX_RPT_GET_BMC(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 29, 1)
#define CCX_RPT_SET_BMC(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 29, 1, value)
#define CCX_RPT_GET_TX_STATE(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 30, 2)
#define CCX_RPT_SET_TX_STATE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 30, 2, value)
#define CCX_RPT_GET_DATA_RETRY_COUNT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 0, 6)
#define CCX_RPT_SET_DATA_RETRY_COUNT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 0, 6, value)
#define CCX_RPT_GET_FINAL_DATA_RATE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 8, 7)
#define CCX_RPT_SET_FINAL_DATA_RATE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 8, 7, value)
#define CCX_RPT_GET_FINAL_SGI(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 15, 1)
#define CCX_RPT_SET_FINAL_SGI(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 15, 1, value)
#define CCX_RPT_GET_RF_CH_NUM(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 16, 10)
#define CCX_RPT_SET_RF_CH_NUM(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 16, 10, value)
#define CCX_RPT_GET_SC(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 26, 4)
#define CCX_RPT_SET_SC(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 26, 4, value)
#define CCX_RPT_GET_BW(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0XC, 30, 2)
#define CCX_RPT_SET_BW(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0XC, 30, 2, value)
#define FW_DBG_MSG_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define FW_DBG_MSG_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define FW_DBG_MSG_GET_C2H_SUB_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define FW_DBG_MSG_SET_C2H_SUB_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define FW_DBG_MSG_GET_FULL(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 1)
#define FW_DBG_MSG_SET_FULL(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 1, value)
#define FW_DBG_MSG_GET_OWN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 31, 1)
#define FW_DBG_MSG_SET_OWN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 31, 1, value)
#define FW_FWCTRL_RPT_GET_EVT_TYPE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define FW_FWCTRL_RPT_SET_EVT_TYPE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define FW_FWCTRL_RPT_GET_LENGTH(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define FW_FWCTRL_RPT_SET_LENGTH(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define FW_FWCTRL_RPT_GET_SEQ_NUM(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define FW_FWCTRL_RPT_SET_SEQ_NUM(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define FW_FWCTRL_RPT_GET_IS_ACK(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 1)
#define FW_FWCTRL_RPT_SET_IS_ACK(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 1, value)
#define FW_FWCTRL_RPT_GET_MORE_CONTENT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 25, 1)
#define FW_FWCTRL_RPT_SET_MORE_CONTENT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 25, 1, value)
#define FW_FWCTRL_RPT_GET_CONTENT_IDX(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 26, 6)
#define FW_FWCTRL_RPT_SET_CONTENT_IDX(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 26, 6, value)
#define FW_FWCTRL_RPT_GET_CLASS_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define FW_FWCTRL_RPT_SET_CLASS_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define FW_FWCTRL_RPT_GET_CONTENT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 16)
#define FW_FWCTRL_RPT_SET_CONTENT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 16, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_3(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_4(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 0, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 0, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_5(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 8, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 8, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_6(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 16, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 16, 8, value)
#define H2C_LOOPBACK_ACK_GET_H2C_BYTE_7(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 24, 8)
#define H2C_LOOPBACK_ACK_SET_H2C_BYTE_7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 24, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_3(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_4(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 0, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 0, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_5(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 8, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 8, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_6(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 16, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 16, 8, value)
#define FWCMD_LOOPBACK_ACK_GET_H2C_BYTE_7(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X8, 24, 8)
#define FWCMD_LOOPBACK_ACK_SET_H2C_BYTE_7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X8, 24, 8, value)
#define SCAN_CH_NOTIFY_GET_CH_NUM(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define SCAN_CH_NOTIFY_SET_CH_NUM(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define SCAN_CH_NOTIFY_GET_NOTIFY_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define SCAN_CH_NOTIFY_SET_NOTIFY_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define SCAN_CH_NOTIFY_GET_STATUS(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define SCAN_CH_NOTIFY_SET_STATUS(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_0(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define SCAN_CH_NOTIFY_SET_TSF_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_1(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
#define SCAN_CH_NOTIFY_SET_TSF_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
#define SCAN_CH_NOTIFY_SET_TSF_2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_3(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 24, 8)
#define SCAN_CH_NOTIFY_SET_TSF_3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 24, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_4(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 0, 8)
#define SCAN_CH_NOTIFY_SET_TSF_4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 0, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_5(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 8, 8)
#define SCAN_CH_NOTIFY_SET_TSF_5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 8, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_6(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define SCAN_CH_NOTIFY_SET_TSF_6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define SCAN_CH_NOTIFY_GET_TSF_7(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define SCAN_CH_NOTIFY_SET_TSF_7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define FW_TBTT_RPT_GET_PORT_NUMBER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define FW_TBTT_RPT_SET_PORT_NUMBER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define BCN_OFFLOAD_GET_SUPPORT_VER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define BCN_OFFLOAD_SET_SUPPORT_VER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define BCN_OFFLOAD_GET_STATUS(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define BCN_OFFLOAD_SET_STATUS(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#endif
================================================
FILE: hal/halmac/halmac_fw_offload_h2c_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_FWOFFLOADH2CFORMAT_H2C_C2H_AP_H_
#define _HAL_FWOFFLOADH2CFORMAT_H2C_C2H_AP_H_
#define CMD_ID_FW_OFFLOAD_H2C 0XFF
#define CMD_ID_FW_ACCESS_TEST 0XFF
#define CMD_ID_CH_SWITCH 0XFF
#define CMD_ID_DUMP_PHYSICAL_EFUSE 0XFF
#define CMD_ID_UPDATE_BEACON_PARSING_INFO 0XFF
#define CMD_ID_CFG_PARAM 0XFF
#define CMD_ID_UPDATE_DATAPACK 0XFF
#define CMD_ID_RUN_DATAPACK 0XFF
#define CMD_ID_DOWNLOAD_FLASH 0XFF
#define CMD_ID_UPDATE_PKT 0XFF
#define CMD_ID_GENERAL_INFO 0XFF
#define CMD_ID_IQK 0XFF
#define CMD_ID_PWR_TRK 0XFF
#define CMD_ID_PSD 0XFF
#define CMD_ID_PHYDM_INFO 0XFF
#define CMD_ID_FW_SNDING 0XFF
#define CMD_ID_FW_FWCTRL 0XFF
#define CMD_ID_H2C_LOOPBACK 0XFF
#define CMD_ID_FWCMD_LOOPBACK 0XFF
#define CMD_ID_UPDATE_SCAN_PKT 0XFF
#define CMD_ID_BCN_OFFLOAD 0XFF
#define CMD_ID_P2PPS 0XFF
#define CMD_ID_BT_COEX 0XFF
#define CMD_ID_NAN_CTRL 0XFF
#define CMD_ID_NAN_CHANNEL_PLAN_0 0XFF
#define CMD_ID_NAN_CHANNEL_PLAN_1 0XFF
#define CATEGORY_H2C_CMD_HEADER 0X00
#define CATEGORY_FW_OFFLOAD_H2C 0X01
#define CATEGORY_FW_ACCESS_TEST 0X01
#define CATEGORY_CH_SWITCH 0X01
#define CATEGORY_DUMP_PHYSICAL_EFUSE 0X01
#define CATEGORY_UPDATE_BEACON_PARSING_INFO 0X01
#define CATEGORY_CFG_PARAM 0X01
#define CATEGORY_UPDATE_DATAPACK 0X01
#define CATEGORY_RUN_DATAPACK 0X01
#define CATEGORY_DOWNLOAD_FLASH 0X01
#define CATEGORY_UPDATE_PKT 0X01
#define CATEGORY_GENERAL_INFO 0X01
#define CATEGORY_IQK 0X01
#define CATEGORY_PWR_TRK 0X01
#define CATEGORY_PSD 0X01
#define CATEGORY_PHYDM_INFO 0X01
#define CATEGORY_FW_SNDING 0X01
#define CATEGORY_FW_FWCTRL 0X01
#define CATEGORY_H2C_LOOPBACK 0X01
#define CATEGORY_FWCMD_LOOPBACK 0X01
#define CATEGORY_UPDATE_SCAN_PKT 0X01
#define CATEGORY_BCN_OFFLOAD 0X01
#define CATEGORY_P2PPS 0X01
#define CATEGORY_BT_COEX 0X01
#define CATEGORY_NAN_CTRL 0X01
#define CATEGORY_NAN_CHANNEL_PLAN_0 0X01
#define CATEGORY_NAN_CHANNEL_PLAN_1 0X01
#define SUB_CMD_ID_FW_ACCESS_TEST 0X00
#define SUB_CMD_ID_CH_SWITCH 0X02
#define SUB_CMD_ID_DUMP_PHYSICAL_EFUSE 0X03
#define SUB_CMD_ID_UPDATE_BEACON_PARSING_INFO 0X05
#define SUB_CMD_ID_CFG_PARAM 0X08
#define SUB_CMD_ID_UPDATE_DATAPACK 0X09
#define SUB_CMD_ID_RUN_DATAPACK 0X0A
#define SUB_CMD_ID_DOWNLOAD_FLASH 0X0B
#define SUB_CMD_ID_UPDATE_PKT 0X0C
#define SUB_CMD_ID_GENERAL_INFO 0X0D
#define SUB_CMD_ID_IQK 0X0E
#define SUB_CMD_ID_PWR_TRK 0X0F
#define SUB_CMD_ID_PSD 0X10
#define SUB_CMD_ID_PHYDM_INFO 0X11
#define SUB_CMD_ID_FW_SNDING 0X12
#define SUB_CMD_ID_FW_FWCTRL 0X13
#define SUB_CMD_ID_H2C_LOOPBACK 0X14
#define SUB_CMD_ID_FWCMD_LOOPBACK 0X15
#define SUB_CMD_ID_UPDATE_SCAN_PKT 0X16
#define SUB_CMD_ID_BCN_OFFLOAD 0X17
#define SUB_CMD_ID_P2PPS 0X24
#define SUB_CMD_ID_BT_COEX 0X60
#define SUB_CMD_ID_NAN_CTRL 0XB2
#define SUB_CMD_ID_NAN_CHANNEL_PLAN_0 0XB4
#define SUB_CMD_ID_NAN_CHANNEL_PLAN_1 0XB5
#define H2C_CMD_HEADER_GET_CATEGORY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 7)
#define H2C_CMD_HEADER_SET_CATEGORY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 7, value)
#define H2C_CMD_HEADER_SET_CATEGORY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 7, value)
#define H2C_CMD_HEADER_GET_ACK(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 7, 1)
#define H2C_CMD_HEADER_SET_ACK(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 7, 1, value)
#define H2C_CMD_HEADER_SET_ACK_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 7, 1, value)
#define H2C_CMD_HEADER_GET_TOTAL_LEN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 16)
#define H2C_CMD_HEADER_SET_TOTAL_LEN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 16, value)
#define H2C_CMD_HEADER_SET_TOTAL_LEN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 16, value)
#define H2C_CMD_HEADER_GET_SEQ_NUM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 16)
#define H2C_CMD_HEADER_SET_SEQ_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 16, value)
#define H2C_CMD_HEADER_SET_SEQ_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 16, value)
#define FW_OFFLOAD_H2C_GET_CATEGORY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 7)
#define FW_OFFLOAD_H2C_SET_CATEGORY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 7, value)
#define FW_OFFLOAD_H2C_SET_CATEGORY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 7, value)
#define FW_OFFLOAD_H2C_GET_ACK(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 7, 1)
#define FW_OFFLOAD_H2C_SET_ACK(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 7, 1, value)
#define FW_OFFLOAD_H2C_SET_ACK_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 7, 1, value)
#define FW_OFFLOAD_H2C_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define FW_OFFLOAD_H2C_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define FW_OFFLOAD_H2C_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define FW_OFFLOAD_H2C_GET_SUB_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 16)
#define FW_OFFLOAD_H2C_SET_SUB_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 16, value)
#define FW_OFFLOAD_H2C_SET_SUB_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 16, value)
#define FW_OFFLOAD_H2C_GET_TOTAL_LEN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 16)
#define FW_OFFLOAD_H2C_SET_TOTAL_LEN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 16, value)
#define FW_OFFLOAD_H2C_SET_TOTAL_LEN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 16, value)
#define FW_OFFLOAD_H2C_GET_SEQ_NUM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 16)
#define FW_OFFLOAD_H2C_SET_SEQ_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 16, value)
#define FW_OFFLOAD_H2C_SET_SEQ_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 16, value)
#define FW_ACCESS_TEST_GET_ACCESS_TXFF(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define FW_ACCESS_TEST_SET_ACCESS_TXFF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_TXFF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_RXFF(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define FW_ACCESS_TEST_SET_ACCESS_RXFF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_RXFF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_FWFF(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define FW_ACCESS_TEST_SET_ACCESS_FWFF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_FWFF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PHYFF(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 3, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PHYFF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 3, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PHYFF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 3, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_RPT_BUF(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 4, 1)
#define FW_ACCESS_TEST_SET_ACCESS_RPT_BUF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 4, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_RPT_BUF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 4, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_CAM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 5, 1)
#define FW_ACCESS_TEST_SET_ACCESS_CAM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 5, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_CAM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 5, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_WOW_CAM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 6, 1)
#define FW_ACCESS_TEST_SET_ACCESS_WOW_CAM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 6, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_WOW_CAM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 6, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_RX_CAM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 7, 1)
#define FW_ACCESS_TEST_SET_ACCESS_RX_CAM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 7, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_RX_CAM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 7, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_BA_CAM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 8, 1)
#define FW_ACCESS_TEST_SET_ACCESS_BA_CAM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_BA_CAM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_MBSSID_CAM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 9, 1)
#define FW_ACCESS_TEST_SET_ACCESS_MBSSID_CAM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 9, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_MBSSID_CAM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 9, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 16, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 17, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 17, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 17, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 18, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 18, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 18, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 19, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 19, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 19, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 20, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 20, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 20, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE5(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 21, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE5(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 21, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE5_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 21, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE6(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 22, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE6(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 22, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE6_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 22, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE7(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 23, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE7(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 23, 1, value)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE7_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 23, 1, value)
#define CH_SWITCH_GET_START(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define CH_SWITCH_SET_START(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define CH_SWITCH_SET_START_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define CH_SWITCH_GET_DEST_CH_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define CH_SWITCH_SET_DEST_CH_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define CH_SWITCH_SET_DEST_CH_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define CH_SWITCH_GET_ABSOLUTE_TIME(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define CH_SWITCH_SET_ABSOLUTE_TIME(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define CH_SWITCH_SET_ABSOLUTE_TIME_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define CH_SWITCH_GET_PERIODIC_OPT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 3, 2)
#define CH_SWITCH_SET_PERIODIC_OPT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 3, 2, value)
#define CH_SWITCH_SET_PERIODIC_OPT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 3, 2, value)
#define CH_SWITCH_GET_SCAN_MODE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 5, 1)
#define CH_SWITCH_SET_SCAN_MODE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 5, 1, value)
#define CH_SWITCH_SET_SCAN_MODE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 5, 1, value)
#define CH_SWITCH_GET_INFO_LOC(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define CH_SWITCH_SET_INFO_LOC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define CH_SWITCH_SET_INFO_LOC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define CH_SWITCH_GET_CH_NUM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define CH_SWITCH_SET_CH_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define CH_SWITCH_SET_CH_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define CH_SWITCH_GET_PRI_CH_IDX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 4)
#define CH_SWITCH_SET_PRI_CH_IDX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 4, value)
#define CH_SWITCH_SET_PRI_CH_IDX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 4, value)
#define CH_SWITCH_GET_DEST_BW(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 28, 4)
#define CH_SWITCH_SET_DEST_BW(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 28, 4, value)
#define CH_SWITCH_SET_DEST_BW_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 28, 4, value)
#define CH_SWITCH_GET_DEST_CH(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 8)
#define CH_SWITCH_SET_DEST_CH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define CH_SWITCH_SET_DEST_CH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define CH_SWITCH_GET_NORMAL_PERIOD(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 8, 6)
#define CH_SWITCH_SET_NORMAL_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 8, 6, value)
#define CH_SWITCH_SET_NORMAL_PERIOD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 8, 6, value)
#define CH_SWITCH_GET_NORMAL_PERIOD_SEL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 14, 2)
#define CH_SWITCH_SET_NORMAL_PERIOD_SEL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 14, 2, value)
#define CH_SWITCH_SET_NORMAL_PERIOD_SEL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 14, 2, value)
#define CH_SWITCH_GET_SLOW_PERIOD(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 16, 6)
#define CH_SWITCH_SET_SLOW_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 16, 6, value)
#define CH_SWITCH_SET_SLOW_PERIOD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 16, 6, value)
#define CH_SWITCH_GET_SLOW_PERIOD_SEL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 22, 2)
#define CH_SWITCH_SET_SLOW_PERIOD_SEL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 22, 2, value)
#define CH_SWITCH_SET_SLOW_PERIOD_SEL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 22, 2, value)
#define CH_SWITCH_GET_NORMAL_CYCLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 24, 8)
#define CH_SWITCH_SET_NORMAL_CYCLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 24, 8, value)
#define CH_SWITCH_SET_NORMAL_CYCLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 24, 8, value)
#define CH_SWITCH_GET_TSF_HIGH(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X10, 0, 32)
#define CH_SWITCH_SET_TSF_HIGH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 32, value)
#define CH_SWITCH_SET_TSF_HIGH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 32, value)
#define CH_SWITCH_GET_TSF_LOW(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X14, 0, 32)
#define CH_SWITCH_SET_TSF_LOW(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 0, 32, value)
#define CH_SWITCH_SET_TSF_LOW_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 0, 32, value)
#define CH_SWITCH_GET_INFO_SIZE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X18, 0, 16)
#define CH_SWITCH_SET_INFO_SIZE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 0, 16, value)
#define CH_SWITCH_SET_INFO_SIZE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 0, 16, value)
#define UPDATE_BEACON_PARSING_INFO_GET_FUNC_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define UPDATE_BEACON_PARSING_INFO_SET_FUNC_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define UPDATE_BEACON_PARSING_INFO_SET_FUNC_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define UPDATE_BEACON_PARSING_INFO_GET_SIZE_TH(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 8, 4)
#define UPDATE_BEACON_PARSING_INFO_SET_SIZE_TH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 4, value)
#define UPDATE_BEACON_PARSING_INFO_SET_SIZE_TH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 4, value)
#define UPDATE_BEACON_PARSING_INFO_GET_TIMEOUT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 12, 4)
#define UPDATE_BEACON_PARSING_INFO_SET_TIMEOUT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 12, 4, value)
#define UPDATE_BEACON_PARSING_INFO_SET_TIMEOUT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 12, 4, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X14, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X18, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X1C, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X1C, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X1C, 0, 32, value)
#define CFG_PARAM_GET_NUM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 16)
#define CFG_PARAM_SET_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 16, value)
#define CFG_PARAM_SET_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 16, value)
#define CFG_PARAM_GET_INIT_CASE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 1)
#define CFG_PARAM_SET_INIT_CASE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 1, value)
#define CFG_PARAM_SET_INIT_CASE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 1, value)
#define CFG_PARAM_GET_LOC(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define CFG_PARAM_SET_LOC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define CFG_PARAM_SET_LOC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_DATAPACK_GET_SIZE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 16)
#define UPDATE_DATAPACK_SET_SIZE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_DATAPACK_SET_SIZE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_DATAPACK_GET_DATAPACK_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define UPDATE_DATAPACK_SET_DATAPACK_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_DATAPACK_SET_DATAPACK_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_DATAPACK_GET_DATAPACK_LOC(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define UPDATE_DATAPACK_SET_DATAPACK_LOC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_DATAPACK_SET_DATAPACK_LOC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_DATAPACK_GET_DATAPACK_SEGMENT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 8)
#define UPDATE_DATAPACK_SET_DATAPACK_SEGMENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define UPDATE_DATAPACK_SET_DATAPACK_SEGMENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define UPDATE_DATAPACK_GET_END_SEGMENT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 8, 1)
#define UPDATE_DATAPACK_SET_END_SEGMENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 8, 1, value)
#define UPDATE_DATAPACK_SET_END_SEGMENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 8, 1, value)
#define RUN_DATAPACK_GET_DATAPACK_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define RUN_DATAPACK_SET_DATAPACK_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define RUN_DATAPACK_SET_DATAPACK_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define DOWNLOAD_FLASH_GET_SPI_CMD(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define DOWNLOAD_FLASH_SET_SPI_CMD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define DOWNLOAD_FLASH_SET_SPI_CMD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define DOWNLOAD_FLASH_GET_LOCATION(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 8, 16)
#define DOWNLOAD_FLASH_SET_LOCATION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 16, value)
#define DOWNLOAD_FLASH_SET_LOCATION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 16, value)
#define DOWNLOAD_FLASH_GET_SIZE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 32)
#define DOWNLOAD_FLASH_SET_SIZE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 32, value)
#define DOWNLOAD_FLASH_SET_SIZE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 32, value)
#define DOWNLOAD_FLASH_GET_START_ADDR(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 0, 32)
#define DOWNLOAD_FLASH_SET_START_ADDR(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 32, value)
#define DOWNLOAD_FLASH_SET_START_ADDR_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 32, value)
#define UPDATE_PKT_GET_SIZE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 16)
#define UPDATE_PKT_SET_SIZE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_PKT_SET_SIZE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_PKT_GET_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define UPDATE_PKT_SET_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_PKT_SET_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_PKT_GET_LOC(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define UPDATE_PKT_SET_LOC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_PKT_SET_LOC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define GENERAL_INFO_GET_FW_TX_BOUNDARY(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define GENERAL_INFO_SET_FW_TX_BOUNDARY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define GENERAL_INFO_SET_FW_TX_BOUNDARY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define IQK_GET_CLEAR(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define IQK_SET_CLEAR(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define IQK_SET_CLEAR_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define IQK_GET_SEGMENT_IQK(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define IQK_SET_SEGMENT_IQK(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define IQK_SET_SEGMENT_IQK_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define PWR_TRK_GET_ENABLE_A(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define PWR_TRK_SET_ENABLE_A(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define PWR_TRK_SET_ENABLE_A_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define PWR_TRK_GET_ENABLE_B(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define PWR_TRK_SET_ENABLE_B(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define PWR_TRK_SET_ENABLE_B_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define PWR_TRK_GET_ENABLE_C(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define PWR_TRK_SET_ENABLE_C(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define PWR_TRK_SET_ENABLE_C_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define PWR_TRK_GET_ENABLE_D(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 3, 1)
#define PWR_TRK_SET_ENABLE_D(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 3, 1, value)
#define PWR_TRK_SET_ENABLE_D_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 3, 1, value)
#define PWR_TRK_GET_TYPE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 4, 3)
#define PWR_TRK_SET_TYPE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 4, 3, value)
#define PWR_TRK_SET_TYPE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 4, 3, value)
#define PWR_TRK_GET_BBSWING_INDEX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define PWR_TRK_SET_BBSWING_INDEX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define PWR_TRK_SET_BBSWING_INDEX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_A(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_A(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define PWR_TRK_SET_TX_PWR_INDEX_A_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_A(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_A(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 8, 8, value)
#define PWR_TRK_SET_OFFSET_VALUE_A_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_A(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_A(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 16, 8, value)
#define PWR_TRK_SET_TSSI_VALUE_A_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 16, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_B(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X10, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_B(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 8, value)
#define PWR_TRK_SET_TX_PWR_INDEX_B_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_B(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X10, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_B(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 8, 8, value)
#define PWR_TRK_SET_OFFSET_VALUE_B_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_B(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X10, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_B(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 16, 8, value)
#define PWR_TRK_SET_TSSI_VALUE_B_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 16, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_C(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X14, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_C(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 0, 8, value)
#define PWR_TRK_SET_TX_PWR_INDEX_C_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_C(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X14, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_C(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 8, 8, value)
#define PWR_TRK_SET_OFFSET_VALUE_C_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_C(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X14, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_C(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 16, 8, value)
#define PWR_TRK_SET_TSSI_VALUE_C_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 16, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_D(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X18, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_D(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 0, 8, value)
#define PWR_TRK_SET_TX_PWR_INDEX_D_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_D(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X18, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_D(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 8, 8, value)
#define PWR_TRK_SET_OFFSET_VALUE_D_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_D(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X18, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_D(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 16, 8, value)
#define PWR_TRK_SET_TSSI_VALUE_D_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 16, 8, value)
#define PSD_GET_START_PSD(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 16)
#define PSD_SET_START_PSD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 16, value)
#define PSD_SET_START_PSD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 16, value)
#define PSD_GET_END_PSD(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 16)
#define PSD_SET_END_PSD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 16, value)
#define PSD_SET_END_PSD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 16, value)
#define PHYDM_INFO_GET_REF_TYPE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define PHYDM_INFO_SET_REF_TYPE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define PHYDM_INFO_SET_REF_TYPE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define PHYDM_INFO_GET_RF_TYPE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define PHYDM_INFO_SET_RF_TYPE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define PHYDM_INFO_SET_RF_TYPE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define PHYDM_INFO_GET_CUT_VER(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define PHYDM_INFO_SET_CUT_VER(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define PHYDM_INFO_SET_CUT_VER_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define PHYDM_INFO_GET_RX_ANT_STATUS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 24, 4)
#define PHYDM_INFO_SET_RX_ANT_STATUS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 4, value)
#define PHYDM_INFO_SET_RX_ANT_STATUS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 4, value)
#define PHYDM_INFO_GET_TX_ANT_STATUS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 28, 4)
#define PHYDM_INFO_SET_TX_ANT_STATUS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 28, 4, value)
#define PHYDM_INFO_SET_TX_ANT_STATUS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 28, 4, value)
#define FW_SNDING_GET_SU0(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define FW_SNDING_SET_SU0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define FW_SNDING_SET_SU0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define FW_SNDING_GET_SU1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define FW_SNDING_SET_SU1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define FW_SNDING_SET_SU1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define FW_SNDING_GET_MU(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define FW_SNDING_SET_MU(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define FW_SNDING_SET_MU_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define FW_SNDING_GET_PERIOD(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define FW_SNDING_SET_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define FW_SNDING_SET_PERIOD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define FW_SNDING_GET_NDPA0_HEAD_PG(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define FW_SNDING_SET_NDPA0_HEAD_PG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define FW_SNDING_SET_NDPA0_HEAD_PG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define FW_SNDING_GET_NDPA1_HEAD_PG(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define FW_SNDING_SET_NDPA1_HEAD_PG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define FW_SNDING_SET_NDPA1_HEAD_PG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define FW_SNDING_GET_MU_NDPA_HEAD_PG(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0XC, 0, 8)
#define FW_SNDING_SET_MU_NDPA_HEAD_PG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 0, 8, value)
#define FW_SNDING_SET_MU_NDPA_HEAD_PG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 0, 8, value)
#define FW_SNDING_GET_RPT0_HEAD_PG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0XC, 8, 8)
#define FW_SNDING_SET_RPT0_HEAD_PG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 8, 8, value)
#define FW_SNDING_SET_RPT0_HEAD_PG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 8, 8, value)
#define FW_SNDING_GET_RPT1_HEAD_PG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0XC, 16, 8)
#define FW_SNDING_SET_RPT1_HEAD_PG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 16, 8, value)
#define FW_SNDING_SET_RPT1_HEAD_PG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 16, 8, value)
#define FW_SNDING_GET_RPT2_HEAD_PG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0XC, 24, 8)
#define FW_SNDING_SET_RPT2_HEAD_PG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0XC, 24, 8, value)
#define FW_SNDING_SET_RPT2_HEAD_PG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0XC, 24, 8, value)
#define FW_FWCTRL_GET_SEQ_NUM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define FW_FWCTRL_SET_SEQ_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define FW_FWCTRL_SET_SEQ_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define FW_FWCTRL_GET_MORE_CONTENT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 1)
#define FW_FWCTRL_SET_MORE_CONTENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 1, value)
#define FW_FWCTRL_SET_MORE_CONTENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 1, value)
#define FW_FWCTRL_GET_CONTENT_IDX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 9, 7)
#define FW_FWCTRL_SET_CONTENT_IDX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 9, 7, value)
#define FW_FWCTRL_SET_CONTENT_IDX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 9, 7, value)
#define FW_FWCTRL_GET_CLASS_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define FW_FWCTRL_SET_CLASS_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define FW_FWCTRL_SET_CLASS_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define FW_FWCTRL_GET_LENGTH(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define FW_FWCTRL_SET_LENGTH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define FW_FWCTRL_SET_LENGTH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define FW_FWCTRL_GET_CONTENT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 32)
#define FW_FWCTRL_SET_CONTENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 32, value)
#define FW_FWCTRL_SET_CONTENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 32, value)
#define UPDATE_SCAN_PKT_GET_SIZE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 16)
#define UPDATE_SCAN_PKT_SET_SIZE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_SCAN_PKT_SET_SIZE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_SCAN_PKT_GET_INDEX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define UPDATE_SCAN_PKT_SET_INDEX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_SCAN_PKT_SET_INDEX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_SCAN_PKT_GET_LOC(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define UPDATE_SCAN_PKT_SET_LOC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_SCAN_PKT_SET_LOC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define BCN_OFFLOAD_GET_REQUEST_VERSION(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define BCN_OFFLOAD_SET_REQUEST_VERSION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define BCN_OFFLOAD_SET_REQUEST_VERSION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define BCN_OFFLOAD_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define BCN_OFFLOAD_SET_ENABLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define BCN_OFFLOAD_SET_ENABLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define BCN_OFFLOAD_GET_MORE_RULE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define BCN_OFFLOAD_SET_MORE_RULE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define BCN_OFFLOAD_SET_MORE_RULE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define BCN_OFFLOAD_GET_C2H_PERIODIC_REPORT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 3, 1)
#define BCN_OFFLOAD_SET_C2H_PERIODIC_REPORT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 3, 1, value)
#define BCN_OFFLOAD_SET_C2H_PERIODIC_REPORT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 3, 1, value)
#define BCN_OFFLOAD_GET_REPORT_PERIOD(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define BCN_OFFLOAD_SET_REPORT_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define BCN_OFFLOAD_SET_REPORT_PERIOD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define BCN_OFFLOAD_GET_RULE_LENGTH(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define BCN_OFFLOAD_SET_RULE_LENGTH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define BCN_OFFLOAD_SET_RULE_LENGTH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define BCN_OFFLOAD_GET_RULE_CONTENT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 8)
#define BCN_OFFLOAD_SET_RULE_CONTENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define BCN_OFFLOAD_SET_RULE_CONTENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define P2PPS_GET_OFFLOAD_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 1)
#define P2PPS_SET_OFFLOAD_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 1, value)
#define P2PPS_SET_OFFLOAD_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 1, value)
#define P2PPS_GET_ROLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 1, 1)
#define P2PPS_SET_ROLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 1, 1, value)
#define P2PPS_SET_ROLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 1, 1, value)
#define P2PPS_GET_CTWINDOW_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define P2PPS_SET_CTWINDOW_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define P2PPS_SET_CTWINDOW_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define P2PPS_GET_NOA_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 3, 1)
#define P2PPS_SET_NOA_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 3, 1, value)
#define P2PPS_SET_NOA_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 3, 1, value)
#define P2PPS_GET_NOA_SEL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 4, 1)
#define P2PPS_SET_NOA_SEL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 4, 1, value)
#define P2PPS_SET_NOA_SEL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 4, 1, value)
#define P2PPS_GET_ALLSTASLEEP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 5, 1)
#define P2PPS_SET_ALLSTASLEEP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 5, 1, value)
#define P2PPS_SET_ALLSTASLEEP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 5, 1, value)
#define P2PPS_GET_DISCOVERY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 6, 1)
#define P2PPS_SET_DISCOVERY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 6, 1, value)
#define P2PPS_SET_DISCOVERY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 6, 1, value)
#define P2PPS_GET_DISABLE_CLOSERF(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 7, 1)
#define P2PPS_SET_DISABLE_CLOSERF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 7, 1, value)
#define P2PPS_SET_DISABLE_CLOSERF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 7, 1, value)
#define P2PPS_GET_P2P_PORT_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define P2PPS_SET_P2P_PORT_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define P2PPS_SET_P2P_PORT_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define P2PPS_GET_P2P_GROUP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define P2PPS_SET_P2P_GROUP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define P2PPS_SET_P2P_GROUP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define P2PPS_GET_P2P_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define P2PPS_SET_P2P_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define P2PPS_SET_P2P_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define P2PPS_GET_CTWINDOW_LENGTH(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 8)
#define P2PPS_SET_CTWINDOW_LENGTH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define P2PPS_SET_CTWINDOW_LENGTH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define P2PPS_GET_NOA_DURATION_PARA(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 0, 32)
#define P2PPS_SET_NOA_DURATION_PARA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 32, value)
#define P2PPS_SET_NOA_DURATION_PARA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 32, value)
#define P2PPS_GET_NOA_INTERVAL_PARA(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X14, 0, 32)
#define P2PPS_SET_NOA_INTERVAL_PARA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 0, 32, value)
#define P2PPS_SET_NOA_INTERVAL_PARA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 0, 32, value)
#define P2PPS_GET_NOA_START_TIME_PARA(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X18, 0, 32)
#define P2PPS_SET_NOA_START_TIME_PARA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 0, 32, value)
#define P2PPS_SET_NOA_START_TIME_PARA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 0, 32, value)
#define P2PPS_GET_NOA_COUNT_PARA(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X1C, 0, 32)
#define P2PPS_SET_NOA_COUNT_PARA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X1C, 0, 32, value)
#define P2PPS_SET_NOA_COUNT_PARA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X1C, 0, 32, value)
#define BT_COEX_GET_DATA_START(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define BT_COEX_SET_DATA_START(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define BT_COEX_SET_DATA_START_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CTRL_GET_NAN_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 0, 2)
#define NAN_CTRL_SET_NAN_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 2, value)
#define NAN_CTRL_SET_NAN_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 2, value)
#define NAN_CTRL_GET_WARMUP_TIMER_FLAG(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 2, 1)
#define NAN_CTRL_SET_WARMUP_TIMER_FLAG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 2, 1, value)
#define NAN_CTRL_SET_WARMUP_TIMER_FLAG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 2, 1, value)
#define NAN_CTRL_GET_SUPPORT_BAND(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 8, 2)
#define NAN_CTRL_SET_SUPPORT_BAND(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 2, value)
#define NAN_CTRL_SET_SUPPORT_BAND_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 2, value)
#define NAN_CTRL_GET_DISABLE_2G_DISC_BCN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 10, 1)
#define NAN_CTRL_SET_DISABLE_2G_DISC_BCN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 10, 1, value)
#define NAN_CTRL_SET_DISABLE_2G_DISC_BCN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 10, 1, value)
#define NAN_CTRL_GET_DISABLE_5G_DISC_BCN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 11, 1)
#define NAN_CTRL_SET_DISABLE_5G_DISC_BCN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 11, 1, value)
#define NAN_CTRL_SET_DISABLE_5G_DISC_BCN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 11, 1, value)
#define NAN_CTRL_GET_BCN_RSVD_PAGE_OFFSET(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 16, 8)
#define NAN_CTRL_SET_BCN_RSVD_PAGE_OFFSET(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 16, 8, value)
#define NAN_CTRL_SET_BCN_RSVD_PAGE_OFFSET_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 16, 8, value)
#define NAN_CTRL_GET_CHANNEL_2G(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X08, 24, 8)
#define NAN_CTRL_SET_CHANNEL_2G(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 24, 8, value)
#define NAN_CTRL_SET_CHANNEL_2G_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 24, 8, value)
#define NAN_CTRL_GET_CHANNEL_5G(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 8)
#define NAN_CTRL_SET_CHANNEL_5G(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define NAN_CTRL_SET_CHANNEL_5G_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 8, value)
#define NAN_CTRL_GET_MASTERPREFERENCE_VALUE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 8, 8)
#define NAN_CTRL_SET_MASTERPREFERENCE_VALUE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 8, 8, value)
#define NAN_CTRL_SET_MASTERPREFERENCE_VALUE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 8, 8, value)
#define NAN_CTRL_GET_RANDOMFACTOR_VALUE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 16, 8)
#define NAN_CTRL_SET_RANDOMFACTOR_VALUE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 16, 8, value)
#define NAN_CTRL_SET_RANDOMFACTOR_VALUE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 16, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 16)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_DURATION_0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 16, 16)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 0, 8)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 8, 8)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X14, 0, 16)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_DURATION_1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X14, 16, 16)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X18, 0, 8)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X18, 8, 8)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X1C, 0, 16)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X1C, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X1C, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_DURATION_2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X1C, 16, 16)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X1C, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X1C, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 0, 8)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X08, 8, 8)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X08, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X08, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 0, 16)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_DURATION_3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X0C, 16, 16)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X0C, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X0C, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 0, 8)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X10, 8, 8)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X10, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X10, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X14, 0, 16)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_DURATION_4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X14, 16, 16)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X14, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X14, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_5(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X18, 0, 8)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_5(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_5_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_5(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X18, 8, 8)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_5(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X18, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_5_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X18, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_5(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X1C, 0, 16)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_5(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X1C, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_5_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X1C, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_DURATION_5(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X1C, 16, 16)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_5(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X1C, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_5_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X1C, 16, 16, value)
#endif
================================================
FILE: hal/halmac/halmac_fw_offload_h2c_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_FWOFFLOADH2CFORMAT_H2C_C2H_NIC_H_
#define _HAL_FWOFFLOADH2CFORMAT_H2C_C2H_NIC_H_
#define CMD_ID_FW_OFFLOAD_H2C 0XFF
#define CMD_ID_FW_ACCESS_TEST 0XFF
#define CMD_ID_CH_SWITCH 0XFF
#define CMD_ID_DUMP_PHYSICAL_EFUSE 0XFF
#define CMD_ID_UPDATE_BEACON_PARSING_INFO 0XFF
#define CMD_ID_CFG_PARAM 0XFF
#define CMD_ID_UPDATE_DATAPACK 0XFF
#define CMD_ID_RUN_DATAPACK 0XFF
#define CMD_ID_DOWNLOAD_FLASH 0XFF
#define CMD_ID_UPDATE_PKT 0XFF
#define CMD_ID_GENERAL_INFO 0XFF
#define CMD_ID_IQK 0XFF
#define CMD_ID_PWR_TRK 0XFF
#define CMD_ID_PSD 0XFF
#define CMD_ID_PHYDM_INFO 0XFF
#define CMD_ID_FW_SNDING 0XFF
#define CMD_ID_FW_FWCTRL 0XFF
#define CMD_ID_H2C_LOOPBACK 0XFF
#define CMD_ID_FWCMD_LOOPBACK 0XFF
#define CMD_ID_UPDATE_SCAN_PKT 0XFF
#define CMD_ID_BCN_OFFLOAD 0XFF
#define CMD_ID_P2PPS 0XFF
#define CMD_ID_BT_COEX 0XFF
#define CMD_ID_NAN_CTRL 0XFF
#define CMD_ID_NAN_CHANNEL_PLAN_0 0XFF
#define CMD_ID_NAN_CHANNEL_PLAN_1 0XFF
#define CATEGORY_H2C_CMD_HEADER 0X00
#define CATEGORY_FW_OFFLOAD_H2C 0X01
#define CATEGORY_FW_ACCESS_TEST 0X01
#define CATEGORY_CH_SWITCH 0X01
#define CATEGORY_DUMP_PHYSICAL_EFUSE 0X01
#define CATEGORY_UPDATE_BEACON_PARSING_INFO 0X01
#define CATEGORY_CFG_PARAM 0X01
#define CATEGORY_UPDATE_DATAPACK 0X01
#define CATEGORY_RUN_DATAPACK 0X01
#define CATEGORY_DOWNLOAD_FLASH 0X01
#define CATEGORY_UPDATE_PKT 0X01
#define CATEGORY_GENERAL_INFO 0X01
#define CATEGORY_IQK 0X01
#define CATEGORY_PWR_TRK 0X01
#define CATEGORY_PSD 0X01
#define CATEGORY_PHYDM_INFO 0X01
#define CATEGORY_FW_SNDING 0X01
#define CATEGORY_FW_FWCTRL 0X01
#define CATEGORY_H2C_LOOPBACK 0X01
#define CATEGORY_FWCMD_LOOPBACK 0X01
#define CATEGORY_UPDATE_SCAN_PKT 0X01
#define CATEGORY_BCN_OFFLOAD 0X01
#define CATEGORY_P2PPS 0X01
#define CATEGORY_BT_COEX 0X01
#define CATEGORY_NAN_CTRL 0X01
#define CATEGORY_NAN_CHANNEL_PLAN_0 0X01
#define CATEGORY_NAN_CHANNEL_PLAN_1 0X01
#define SUB_CMD_ID_FW_ACCESS_TEST 0X00
#define SUB_CMD_ID_CH_SWITCH 0X02
#define SUB_CMD_ID_DUMP_PHYSICAL_EFUSE 0X03
#define SUB_CMD_ID_UPDATE_BEACON_PARSING_INFO 0X05
#define SUB_CMD_ID_CFG_PARAM 0X08
#define SUB_CMD_ID_UPDATE_DATAPACK 0X09
#define SUB_CMD_ID_RUN_DATAPACK 0X0A
#define SUB_CMD_ID_DOWNLOAD_FLASH 0X0B
#define SUB_CMD_ID_UPDATE_PKT 0X0C
#define SUB_CMD_ID_GENERAL_INFO 0X0D
#define SUB_CMD_ID_IQK 0X0E
#define SUB_CMD_ID_PWR_TRK 0X0F
#define SUB_CMD_ID_PSD 0X10
#define SUB_CMD_ID_PHYDM_INFO 0X11
#define SUB_CMD_ID_FW_SNDING 0X12
#define SUB_CMD_ID_FW_FWCTRL 0X13
#define SUB_CMD_ID_H2C_LOOPBACK 0X14
#define SUB_CMD_ID_FWCMD_LOOPBACK 0X15
#define SUB_CMD_ID_UPDATE_SCAN_PKT 0X16
#define SUB_CMD_ID_BCN_OFFLOAD 0X17
#define SUB_CMD_ID_P2PPS 0X24
#define SUB_CMD_ID_BT_COEX 0X60
#define SUB_CMD_ID_NAN_CTRL 0XB2
#define SUB_CMD_ID_NAN_CHANNEL_PLAN_0 0XB4
#define SUB_CMD_ID_NAN_CHANNEL_PLAN_1 0XB5
#define H2C_CMD_HEADER_GET_CATEGORY(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 7)
#define H2C_CMD_HEADER_SET_CATEGORY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 7, value)
#define H2C_CMD_HEADER_GET_ACK(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 7, 1)
#define H2C_CMD_HEADER_SET_ACK(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 7, 1, value)
#define H2C_CMD_HEADER_GET_TOTAL_LEN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 16)
#define H2C_CMD_HEADER_SET_TOTAL_LEN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 16, value)
#define H2C_CMD_HEADER_GET_SEQ_NUM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 16)
#define H2C_CMD_HEADER_SET_SEQ_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 16, value)
#define FW_OFFLOAD_H2C_GET_CATEGORY(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 7)
#define FW_OFFLOAD_H2C_SET_CATEGORY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 7, value)
#define FW_OFFLOAD_H2C_GET_ACK(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 7, 1)
#define FW_OFFLOAD_H2C_SET_ACK(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 7, 1, value)
#define FW_OFFLOAD_H2C_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define FW_OFFLOAD_H2C_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define FW_OFFLOAD_H2C_GET_SUB_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 16)
#define FW_OFFLOAD_H2C_SET_SUB_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 16, value)
#define FW_OFFLOAD_H2C_GET_TOTAL_LEN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 16)
#define FW_OFFLOAD_H2C_SET_TOTAL_LEN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 16, value)
#define FW_OFFLOAD_H2C_GET_SEQ_NUM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 16)
#define FW_OFFLOAD_H2C_SET_SEQ_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 16, value)
#define FW_ACCESS_TEST_GET_ACCESS_TXFF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define FW_ACCESS_TEST_SET_ACCESS_TXFF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_RXFF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define FW_ACCESS_TEST_SET_ACCESS_RXFF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_FWFF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define FW_ACCESS_TEST_SET_ACCESS_FWFF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PHYFF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PHYFF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_RPT_BUF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 4, 1)
#define FW_ACCESS_TEST_SET_ACCESS_RPT_BUF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 4, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_CAM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 5, 1)
#define FW_ACCESS_TEST_SET_ACCESS_CAM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 5, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_WOW_CAM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 6, 1)
#define FW_ACCESS_TEST_SET_ACCESS_WOW_CAM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 6, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_RX_CAM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 7, 1)
#define FW_ACCESS_TEST_SET_ACCESS_RX_CAM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 7, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_BA_CAM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 1)
#define FW_ACCESS_TEST_SET_ACCESS_BA_CAM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_MBSSID_CAM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 9, 1)
#define FW_ACCESS_TEST_SET_ACCESS_MBSSID_CAM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 9, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 17, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 17, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 18, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 18, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 19, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 19, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 20, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 20, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE5(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 21, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE5(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 21, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE6(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 22, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE6(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 22, 1, value)
#define FW_ACCESS_TEST_GET_ACCESS_PAGE7(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 23, 1)
#define FW_ACCESS_TEST_SET_ACCESS_PAGE7(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 23, 1, value)
#define CH_SWITCH_GET_START(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define CH_SWITCH_SET_START(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define CH_SWITCH_GET_DEST_CH_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define CH_SWITCH_SET_DEST_CH_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define CH_SWITCH_GET_ABSOLUTE_TIME(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define CH_SWITCH_SET_ABSOLUTE_TIME(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define CH_SWITCH_GET_PERIODIC_OPT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 2)
#define CH_SWITCH_SET_PERIODIC_OPT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 2, value)
#define CH_SWITCH_GET_SCAN_MODE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 5, 1)
#define CH_SWITCH_SET_SCAN_MODE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 5, 1, value)
#define CH_SWITCH_GET_INFO_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define CH_SWITCH_SET_INFO_LOC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define CH_SWITCH_GET_CH_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define CH_SWITCH_SET_CH_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define CH_SWITCH_GET_PRI_CH_IDX(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 4)
#define CH_SWITCH_SET_PRI_CH_IDX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 4, value)
#define CH_SWITCH_GET_DEST_BW(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 28, 4)
#define CH_SWITCH_SET_DEST_BW(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 28, 4, value)
#define CH_SWITCH_GET_DEST_CH(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
#define CH_SWITCH_SET_DEST_CH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
#define CH_SWITCH_GET_NORMAL_PERIOD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 6)
#define CH_SWITCH_SET_NORMAL_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 6, value)
#define CH_SWITCH_GET_NORMAL_PERIOD_SEL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 14, 2)
#define CH_SWITCH_SET_NORMAL_PERIOD_SEL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 14, 2, value)
#define CH_SWITCH_GET_SLOW_PERIOD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 6)
#define CH_SWITCH_SET_SLOW_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 6, value)
#define CH_SWITCH_GET_SLOW_PERIOD_SEL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 22, 2)
#define CH_SWITCH_SET_SLOW_PERIOD_SEL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 22, 2, value)
#define CH_SWITCH_GET_NORMAL_CYCLE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 24, 8)
#define CH_SWITCH_SET_NORMAL_CYCLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 24, 8, value)
#define CH_SWITCH_GET_TSF_HIGH(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
#define CH_SWITCH_SET_TSF_HIGH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
#define CH_SWITCH_GET_TSF_LOW(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 32)
#define CH_SWITCH_SET_TSF_LOW(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 32, value)
#define CH_SWITCH_GET_INFO_SIZE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 16)
#define CH_SWITCH_SET_INFO_SIZE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 16, value)
#define UPDATE_BEACON_PARSING_INFO_GET_FUNC_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define UPDATE_BEACON_PARSING_INFO_SET_FUNC_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define UPDATE_BEACON_PARSING_INFO_GET_SIZE_TH(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 4)
#define UPDATE_BEACON_PARSING_INFO_SET_SIZE_TH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 4, value)
#define UPDATE_BEACON_PARSING_INFO_GET_TIMEOUT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 12, 4)
#define UPDATE_BEACON_PARSING_INFO_SET_TIMEOUT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 12, 4, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 32, value)
#define UPDATE_BEACON_PARSING_INFO_GET_IE_ID_BMP_4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 32)
#define UPDATE_BEACON_PARSING_INFO_SET_IE_ID_BMP_4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 32, value)
#define CFG_PARAM_GET_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
#define CFG_PARAM_SET_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
#define CFG_PARAM_GET_INIT_CASE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 1)
#define CFG_PARAM_SET_INIT_CASE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 1, value)
#define CFG_PARAM_GET_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define CFG_PARAM_SET_LOC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_DATAPACK_GET_SIZE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
#define UPDATE_DATAPACK_SET_SIZE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_DATAPACK_GET_DATAPACK_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define UPDATE_DATAPACK_SET_DATAPACK_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_DATAPACK_GET_DATAPACK_LOC(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define UPDATE_DATAPACK_SET_DATAPACK_LOC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define UPDATE_DATAPACK_GET_DATAPACK_SEGMENT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
#define UPDATE_DATAPACK_SET_DATAPACK_SEGMENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
#define UPDATE_DATAPACK_GET_END_SEGMENT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 1)
#define UPDATE_DATAPACK_SET_END_SEGMENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 1, value)
#define RUN_DATAPACK_GET_DATAPACK_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define RUN_DATAPACK_SET_DATAPACK_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define DOWNLOAD_FLASH_GET_SPI_CMD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define DOWNLOAD_FLASH_SET_SPI_CMD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define DOWNLOAD_FLASH_GET_LOCATION(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 16)
#define DOWNLOAD_FLASH_SET_LOCATION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 16, value)
#define DOWNLOAD_FLASH_GET_SIZE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 32)
#define DOWNLOAD_FLASH_SET_SIZE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 32, value)
#define DOWNLOAD_FLASH_GET_START_ADDR(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
#define DOWNLOAD_FLASH_SET_START_ADDR(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
#define UPDATE_PKT_GET_SIZE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
#define UPDATE_PKT_SET_SIZE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_PKT_GET_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define UPDATE_PKT_SET_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_PKT_GET_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define UPDATE_PKT_SET_LOC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define GENERAL_INFO_GET_FW_TX_BOUNDARY(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define GENERAL_INFO_SET_FW_TX_BOUNDARY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define IQK_GET_CLEAR(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define IQK_SET_CLEAR(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define IQK_GET_SEGMENT_IQK(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define IQK_SET_SEGMENT_IQK(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define PWR_TRK_GET_ENABLE_A(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define PWR_TRK_SET_ENABLE_A(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define PWR_TRK_GET_ENABLE_B(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define PWR_TRK_SET_ENABLE_B(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define PWR_TRK_GET_ENABLE_C(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define PWR_TRK_SET_ENABLE_C(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define PWR_TRK_GET_ENABLE_D(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
#define PWR_TRK_SET_ENABLE_D(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
#define PWR_TRK_GET_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 4, 3)
#define PWR_TRK_SET_TYPE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 4, 3, value)
#define PWR_TRK_GET_BBSWING_INDEX(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define PWR_TRK_SET_BBSWING_INDEX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_A(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_A(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_A(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_A(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_A(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_A(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_B(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_B(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_B(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_B(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_B(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_B(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 16, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_C(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_C(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_C(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_C(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_C(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_C(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 16, 8, value)
#define PWR_TRK_GET_TX_PWR_INDEX_D(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 8)
#define PWR_TRK_SET_TX_PWR_INDEX_D(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 8, value)
#define PWR_TRK_GET_OFFSET_VALUE_D(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 8, 8)
#define PWR_TRK_SET_OFFSET_VALUE_D(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 8, 8, value)
#define PWR_TRK_GET_TSSI_VALUE_D(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 16, 8)
#define PWR_TRK_SET_TSSI_VALUE_D(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 16, 8, value)
#define PSD_GET_START_PSD(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
#define PSD_SET_START_PSD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
#define PSD_GET_END_PSD(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 16)
#define PSD_SET_END_PSD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 16, value)
#define PHYDM_INFO_GET_REF_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define PHYDM_INFO_SET_REF_TYPE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define PHYDM_INFO_GET_RF_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define PHYDM_INFO_SET_RF_TYPE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define PHYDM_INFO_GET_CUT_VER(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define PHYDM_INFO_SET_CUT_VER(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define PHYDM_INFO_GET_RX_ANT_STATUS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 4)
#define PHYDM_INFO_SET_RX_ANT_STATUS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 4, value)
#define PHYDM_INFO_GET_TX_ANT_STATUS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 28, 4)
#define PHYDM_INFO_SET_TX_ANT_STATUS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 28, 4, value)
#define FW_SNDING_GET_SU0(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define FW_SNDING_SET_SU0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define FW_SNDING_GET_SU1(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define FW_SNDING_SET_SU1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define FW_SNDING_GET_MU(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define FW_SNDING_SET_MU(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define FW_SNDING_GET_PERIOD(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define FW_SNDING_SET_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define FW_SNDING_GET_NDPA0_HEAD_PG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define FW_SNDING_SET_NDPA0_HEAD_PG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define FW_SNDING_GET_NDPA1_HEAD_PG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define FW_SNDING_SET_NDPA1_HEAD_PG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define FW_SNDING_GET_MU_NDPA_HEAD_PG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 0, 8)
#define FW_SNDING_SET_MU_NDPA_HEAD_PG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 0, 8, value)
#define FW_SNDING_GET_RPT0_HEAD_PG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 8, 8)
#define FW_SNDING_SET_RPT0_HEAD_PG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 8, 8, value)
#define FW_SNDING_GET_RPT1_HEAD_PG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 16, 8)
#define FW_SNDING_SET_RPT1_HEAD_PG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 16, 8, value)
#define FW_SNDING_GET_RPT2_HEAD_PG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0XC, 24, 8)
#define FW_SNDING_SET_RPT2_HEAD_PG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0XC, 24, 8, value)
#define FW_FWCTRL_GET_SEQ_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define FW_FWCTRL_SET_SEQ_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define FW_FWCTRL_GET_MORE_CONTENT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 1)
#define FW_FWCTRL_SET_MORE_CONTENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 1, value)
#define FW_FWCTRL_GET_CONTENT_IDX(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 9, 7)
#define FW_FWCTRL_SET_CONTENT_IDX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 9, 7, value)
#define FW_FWCTRL_GET_CLASS_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define FW_FWCTRL_SET_CLASS_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define FW_FWCTRL_GET_LENGTH(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define FW_FWCTRL_SET_LENGTH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define FW_FWCTRL_GET_CONTENT(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 32)
#define FW_FWCTRL_SET_CONTENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 32, value)
#define UPDATE_SCAN_PKT_GET_SIZE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 16)
#define UPDATE_SCAN_PKT_SET_SIZE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 16, value)
#define UPDATE_SCAN_PKT_GET_INDEX(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define UPDATE_SCAN_PKT_SET_INDEX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define UPDATE_SCAN_PKT_GET_LOC(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define UPDATE_SCAN_PKT_SET_LOC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define BCN_OFFLOAD_GET_REQUEST_VERSION(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define BCN_OFFLOAD_SET_REQUEST_VERSION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define BCN_OFFLOAD_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define BCN_OFFLOAD_SET_ENABLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define BCN_OFFLOAD_GET_MORE_RULE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define BCN_OFFLOAD_SET_MORE_RULE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define BCN_OFFLOAD_GET_C2H_PERIODIC_REPORT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
#define BCN_OFFLOAD_SET_C2H_PERIODIC_REPORT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
#define BCN_OFFLOAD_GET_REPORT_PERIOD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define BCN_OFFLOAD_SET_REPORT_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define BCN_OFFLOAD_GET_RULE_LENGTH(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define BCN_OFFLOAD_SET_RULE_LENGTH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define BCN_OFFLOAD_GET_RULE_CONTENT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
#define BCN_OFFLOAD_SET_RULE_CONTENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
#define P2PPS_GET_OFFLOAD_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 1)
#define P2PPS_SET_OFFLOAD_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 1, value)
#define P2PPS_GET_ROLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 1, 1)
#define P2PPS_SET_ROLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 1, 1, value)
#define P2PPS_GET_CTWINDOW_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define P2PPS_SET_CTWINDOW_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define P2PPS_GET_NOA_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 3, 1)
#define P2PPS_SET_NOA_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 3, 1, value)
#define P2PPS_GET_NOA_SEL(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 4, 1)
#define P2PPS_SET_NOA_SEL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 4, 1, value)
#define P2PPS_GET_ALLSTASLEEP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 5, 1)
#define P2PPS_SET_ALLSTASLEEP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 5, 1, value)
#define P2PPS_GET_DISCOVERY(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 6, 1)
#define P2PPS_SET_DISCOVERY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 6, 1, value)
#define P2PPS_GET_DISABLE_CLOSERF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 7, 1)
#define P2PPS_SET_DISABLE_CLOSERF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 7, 1, value)
#define P2PPS_GET_P2P_PORT_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define P2PPS_SET_P2P_PORT_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define P2PPS_GET_P2P_GROUP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define P2PPS_SET_P2P_GROUP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define P2PPS_GET_P2P_MACID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define P2PPS_SET_P2P_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define P2PPS_GET_CTWINDOW_LENGTH(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
#define P2PPS_SET_CTWINDOW_LENGTH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
#define P2PPS_GET_NOA_DURATION_PARA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 32)
#define P2PPS_SET_NOA_DURATION_PARA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 32, value)
#define P2PPS_GET_NOA_INTERVAL_PARA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 32)
#define P2PPS_SET_NOA_INTERVAL_PARA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 32, value)
#define P2PPS_GET_NOA_START_TIME_PARA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 32)
#define P2PPS_SET_NOA_START_TIME_PARA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 32, value)
#define P2PPS_GET_NOA_COUNT_PARA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 32)
#define P2PPS_SET_NOA_COUNT_PARA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 32, value)
#define BT_COEX_GET_DATA_START(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define BT_COEX_SET_DATA_START(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CTRL_GET_NAN_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 2)
#define NAN_CTRL_SET_NAN_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 2, value)
#define NAN_CTRL_GET_WARMUP_TIMER_FLAG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 2, 1)
#define NAN_CTRL_SET_WARMUP_TIMER_FLAG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 2, 1, value)
#define NAN_CTRL_GET_SUPPORT_BAND(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 2)
#define NAN_CTRL_SET_SUPPORT_BAND(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 2, value)
#define NAN_CTRL_GET_DISABLE_2G_DISC_BCN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 10, 1)
#define NAN_CTRL_SET_DISABLE_2G_DISC_BCN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 10, 1, value)
#define NAN_CTRL_GET_DISABLE_5G_DISC_BCN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 11, 1)
#define NAN_CTRL_SET_DISABLE_5G_DISC_BCN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 11, 1, value)
#define NAN_CTRL_GET_BCN_RSVD_PAGE_OFFSET(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 16, 8)
#define NAN_CTRL_SET_BCN_RSVD_PAGE_OFFSET(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 16, 8, value)
#define NAN_CTRL_GET_CHANNEL_2G(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 24, 8)
#define NAN_CTRL_SET_CHANNEL_2G(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 24, 8, value)
#define NAN_CTRL_GET_CHANNEL_5G(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 8)
#define NAN_CTRL_SET_CHANNEL_5G(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 8, value)
#define NAN_CTRL_GET_MASTERPREFERENCE_VALUE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 8, 8)
#define NAN_CTRL_SET_MASTERPREFERENCE_VALUE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 8, 8, value)
#define NAN_CTRL_GET_RANDOMFACTOR_VALUE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 8)
#define NAN_CTRL_SET_RANDOMFACTOR_VALUE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 16)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_DURATION_0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 16)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 8)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 8, 8)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 16)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_DURATION_1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 16, 16)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 16, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_CHANNEL_NUMBER_2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 8)
#define NAN_CHANNEL_PLAN_0_SET_CHANNEL_NUMBER_2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_UNPAUSE_MACID_2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 8, 8)
#define NAN_CHANNEL_PLAN_0_SET_UNPAUSE_MACID_2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 8, 8, value)
#define NAN_CHANNEL_PLAN_0_GET_START_TIME_SLOT_2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 16)
#define NAN_CHANNEL_PLAN_0_SET_START_TIME_SLOT_2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 16, value)
#define NAN_CHANNEL_PLAN_0_GET_DURATION_2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 16, 16)
#define NAN_CHANNEL_PLAN_0_SET_DURATION_2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 0, 8)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X08, 8, 8)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X08, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 0, 16)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_DURATION_3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X0C, 16, 16)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X0C, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 0, 8)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X10, 8, 8)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X10, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 0, 16)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_DURATION_4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X14, 16, 16)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X14, 16, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_CHANNEL_NUMBER_5(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 0, 8)
#define NAN_CHANNEL_PLAN_1_SET_CHANNEL_NUMBER_5(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 0, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_UNPAUSE_MACID_5(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X18, 8, 8)
#define NAN_CHANNEL_PLAN_1_SET_UNPAUSE_MACID_5(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X18, 8, 8, value)
#define NAN_CHANNEL_PLAN_1_GET_START_TIME_SLOT_5(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 0, 16)
#define NAN_CHANNEL_PLAN_1_SET_START_TIME_SLOT_5(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 0, 16, value)
#define NAN_CHANNEL_PLAN_1_GET_DURATION_5(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X1C, 16, 16)
#define NAN_CHANNEL_PLAN_1_SET_DURATION_5(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X1C, 16, 16, value)
#endif
================================================
FILE: hal/halmac/halmac_gpio_cmd.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef HALMAC_GPIO_CMD
#define HALMAC_GPIO_CMD
#include "halmac_2_platform.h"
/* GPIO ID */
#define HALMAC_GPIO0 0
#define HALMAC_GPIO1 1
#define HALMAC_GPIO2 2
#define HALMAC_GPIO3 3
#define HALMAC_GPIO4 4
#define HALMAC_GPIO5 5
#define HALMAC_GPIO6 6
#define HALMAC_GPIO7 7
#define HALMAC_GPIO8 8
#define HALMAC_GPIO9 9
#define HALMAC_GPIO10 10
#define HALMAC_GPIO11 11
#define HALMAC_GPIO12 12
#define HALMAC_GPIO13 13
#define HALMAC_GPIO14 14
#define HALMAC_GPIO15 15
#define HALMAC_GPIO_NUM 16
/* GPIO type */
#define HALMAC_GPIO_IN 0
#define HALMAC_GPIO_OUT 1
#define HALMAC_GPIO_IN_OUT 2
/* Function name */
#define HALMAC_WL_HWPDN 0
#define HALMAC_BT_HWPDN 1
#define HALMAC_BT_GPIO 2
#define HALMAC_WL_HW_EXTWOL 3
#define HALMAC_BT_HW_EXTWOL 4
#define HALMAC_BT_SFLASH 5
#define HALMAC_WL_SFLASH 6
#define HALMAC_WL_LED 7
#define HALMAC_SDIO_INT 8
#define HALMAC_UART0 9
#define HALMAC_EEPROM 10
#define HALMAC_JTAG 11
#define HALMAC_LTE_COEX_UART 12
#define HALMAC_3W_LTE_WL_GPIO 13
#define HALMAC_GPIO2_3_WL_CTRL_EN 14
#define HALMAC_GPIO13_14_WL_CTRL_EN 15
#define HALMAC_DBG_GNT_WL_BT 16
#define HALMAC_BT_3DDLS_A 17
#define HALMAC_BT_3DDLS_B 18
#define HALMAC_BT_PTA 19
#define HALMAC_WL_PTA 20
#define HALMAC_WL_UART 21
#define HALMAC_WLMAC_DBG 22
#define HALMAC_WLPHY_DBG 23
#define HALMAC_BT_DBG 24
#define HALMAC_WLPHY_RFE_CTRL2GPIO 25
#define HALMAC_EXT_XTAL 26
#define HALMAC_SW_IO 27
#define HALMAC_BT_SDIO_INT 28
#define HALMAC_BT_JTAG 29
#define HALMAC_WL_JTAG 30
#define HALMAC_BT_RF 31
#define HALMAC_WLPHY_RFE_CTRL2GPIO_2 32
#define HALMAC_MAILBOX_3W 33
#define HALMAC_MAILBOX_1W 34
#define HALMAC_SW_DPDT_SEL 35
#define HALMAC_BT_DPDT_SEL 36
#define HALMAC_WL_DPDT_SEL 37
#define HALMAC_BT_PAPE_SEL 38
#define HALMAC_SW_PAPE_SEL 39
#define HALMAC_WLBT_PAPE_SEL 40
#define HALMAC_SW_LNAON_SET 41
#define HALMAC_BT_LNAON_SEL 42
#define HALMAC_WLBT_LNAON_SEL 43
#define HALMAC_SWR_CTRL_EN 44
struct halmac_gpio_pimux_list {
u16 func;
u8 id;
u8 type;
u16 offset;
u8 msk;
u8 value;
};
#endif
================================================
FILE: hal/halmac/halmac_h2c_extra_info_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_H2CEXTRAINFO_H2C_C2H_AP_H_
#define _HAL_H2CEXTRAINFO_H2C_C2H_AP_H_
#define PARAM_INFO_GET_LEN(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 8)
#define PARAM_INFO_SET_LEN(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 8, value)
#define PARAM_INFO_SET_LEN_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 8, value)
#define PARAM_INFO_GET_IO_CMD(extra_info) GET_C2H_FIELD(extra_info + 0X00, 8, 7)
#define PARAM_INFO_SET_IO_CMD(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 7, value)
#define PARAM_INFO_SET_IO_CMD_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 7, value)
#define PARAM_INFO_GET_MSK_EN(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 15, 1)
#define PARAM_INFO_SET_MSK_EN(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 15, 1, value)
#define PARAM_INFO_SET_MSK_EN_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 15, 1, value)
#define PARAM_INFO_GET_LLT_PG_BNDY(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_LLT_PG_BNDY(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_SET_LLT_PG_BNDY_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_EFUSE_RSVDPAGE_LOC(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_EFUSE_PATCH_EN(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_EFUSE_PATCH_EN(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_SET_EFUSE_PATCH_EN_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_RF_ADDR(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_RF_ADDR(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_SET_RF_ADDR_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_IO_ADDR(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 16)
#define PARAM_INFO_SET_IO_ADDR(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
#define PARAM_INFO_SET_IO_ADDR_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
#define PARAM_INFO_GET_DELAY_VAL(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 16)
#define PARAM_INFO_SET_DELAY_VAL(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
#define PARAM_INFO_SET_DELAY_VAL_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
#define PARAM_INFO_GET_RF_PATH(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 24, 8)
#define PARAM_INFO_SET_RF_PATH(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 24, 8, value)
#define PARAM_INFO_SET_RF_PATH_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 24, 8, value)
#define PARAM_INFO_GET_DATA(extra_info) GET_C2H_FIELD(extra_info + 0X04, 0, 32)
#define PARAM_INFO_SET_DATA(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 32, value)
#define PARAM_INFO_SET_DATA_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 32, value)
#define PARAM_INFO_GET_MASK(extra_info) GET_C2H_FIELD(extra_info + 0X08, 0, 32)
#define PARAM_INFO_SET_MASK(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X08, 0, 32, value)
#define PARAM_INFO_SET_MASK_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X08, 0, 32, value)
#define CH_INFO_GET_CH(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 8)
#define CH_INFO_SET_CH(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 8, value)
#define CH_INFO_SET_CH_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 8, value)
#define CH_INFO_GET_PRI_CH_IDX(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 8, 4)
#define CH_INFO_SET_PRI_CH_IDX(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 4, value)
#define CH_INFO_SET_PRI_CH_IDX_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 4, value)
#define CH_INFO_GET_BW(extra_info) GET_C2H_FIELD(extra_info + 0X00, 12, 4)
#define CH_INFO_SET_BW(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 12, 4, value)
#define CH_INFO_SET_BW_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 12, 4, value)
#define CH_INFO_GET_TIMEOUT(extra_info) GET_C2H_FIELD(extra_info + 0X00, 16, 8)
#define CH_INFO_SET_TIMEOUT(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
#define CH_INFO_SET_TIMEOUT_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
#define CH_INFO_GET_ACTION_ID(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 24, 7)
#define CH_INFO_SET_ACTION_ID(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 24, 7, value)
#define CH_INFO_SET_ACTION_ID_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 24, 7, value)
#define CH_INFO_GET_EXTRA_INFO(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 31, 1)
#define CH_INFO_SET_EXTRA_INFO(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 31, 1, value)
#define CH_INFO_SET_EXTRA_INFO_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 31, 1, value)
#define CH_EXTRA_INFO_GET_ID(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 7)
#define CH_EXTRA_INFO_SET_ID(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 7, value)
#define CH_EXTRA_INFO_SET_ID_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 7, value)
#define CH_EXTRA_INFO_GET_INFO(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 7, 1)
#define CH_EXTRA_INFO_SET_INFO(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 7, 1, value)
#define CH_EXTRA_INFO_SET_INFO_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 7, 1, value)
#define CH_EXTRA_INFO_GET_SIZE(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 8, 8)
#define CH_EXTRA_INFO_SET_SIZE(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 8, value)
#define CH_EXTRA_INFO_SET_SIZE_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 8, value)
#define CH_EXTRA_INFO_GET_DATA(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 1)
#define CH_EXTRA_INFO_SET_DATA(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 1, value)
#define CH_EXTRA_INFO_SET_DATA_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_L(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 0, 16)
#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 16, value)
#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_BITDATA(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 0, 16)
#define HIOE_INSTRUCTION_INFO_SET_BITDATA(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 16, value)
#define HIOE_INSTRUCTION_INFO_SET_BITDATA_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_H(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 16)
#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_BITMASK(extra_info) \
GET_C2H_FIELD(extra_info + 0X00, 16, 16)
#define HIOE_INSTRUCTION_INFO_SET_BITMASK(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
#define HIOE_INSTRUCTION_INFO_SET_BITMASK_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_REG_ADDR(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 0, 22)
#define HIOE_INSTRUCTION_INFO_SET_REG_ADDR(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 22, value)
#define HIOE_INSTRUCTION_INFO_SET_REG_ADDR_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 22, value)
#define HIOE_INSTRUCTION_INFO_GET_DELAY_VALUE(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 0, 22)
#define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 22, value)
#define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 22, value)
#define HIOE_INSTRUCTION_INFO_GET_MODE_SELECT(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 22, 1)
#define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 22, 1, value)
#define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 22, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_IO_DELAY(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 23, 1)
#define HIOE_INSTRUCTION_INFO_SET_IO_DELAY(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 23, 1, value)
#define HIOE_INSTRUCTION_INFO_SET_IO_DELAY_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 23, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_BYTEMASK(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 24, 4)
#define HIOE_INSTRUCTION_INFO_SET_BYTEMASK(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 24, 4, value)
#define HIOE_INSTRUCTION_INFO_SET_BYTEMASK_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 24, 4, value)
#define HIOE_INSTRUCTION_INFO_GET_RD_EN(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 28, 1)
#define HIOE_INSTRUCTION_INFO_SET_RD_EN(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 28, 1, value)
#define HIOE_INSTRUCTION_INFO_SET_RD_EN_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 28, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_WR_EN(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 29, 1)
#define HIOE_INSTRUCTION_INFO_SET_WR_EN(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 29, 1, value)
#define HIOE_INSTRUCTION_INFO_SET_WR_EN_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 29, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_RAW_R(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 30, 1)
#define HIOE_INSTRUCTION_INFO_SET_RAW_R(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 30, 1, value)
#define HIOE_INSTRUCTION_INFO_SET_RAW_R_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 30, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_RAW(extra_info) \
GET_C2H_FIELD(extra_info + 0X04, 31, 1)
#define HIOE_INSTRUCTION_INFO_SET_RAW(extra_info, value) \
SET_C2H_FIELD_CLR(extra_info + 0X04, 31, 1, value)
#define HIOE_INSTRUCTION_INFO_SET_RAW_NO_CLR(extra_info, value) \
SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 31, 1, value)
#endif
================================================
FILE: hal/halmac/halmac_h2c_extra_info_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_H2CEXTRAINFO_H2C_C2H_NIC_H_
#define _HAL_H2CEXTRAINFO_H2C_C2H_NIC_H_
/* H2C extra info (rsvd page) usage, unit : page (128byte)*/
/* dlfw : not include txdesc size*/
/* update pkt : not include txdesc size*/
/* cfg param : not include txdesc size*/
/* scan info : not include txdesc size*/
/* dl flash : not include txdesc size*/
#define DLFW_RSVDPG_SIZE 2048
#define UPDATE_PKT_RSVDPG_SIZE 2048
#define CFG_PARAM_RSVDPG_SIZE 2048
#define SCAN_INFO_RSVDPG_SIZE 256
#define DL_FLASH_RSVDPG_SIZE 2048
/* su0 snding pkt : include txdesc size */
#define SU0_SNDING_PKT_OFFSET 0
#define SU0_SNDING_PKT_RSVDPG_SIZE 128
#define PARAM_INFO_GET_LEN(extra_info) LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 8)
#define PARAM_INFO_SET_LEN(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 8, value)
#define PARAM_INFO_GET_IO_CMD(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 8, 7)
#define PARAM_INFO_SET_IO_CMD(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 8, 7, value)
#define PARAM_INFO_GET_MSK_EN(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 15, 1)
#define PARAM_INFO_SET_MSK_EN(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 15, 1, value)
#define PARAM_INFO_GET_LLT_PG_BNDY(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_LLT_PG_BNDY(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_EFUSE_RSVDPAGE_LOC(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_EFUSE_PATCH_EN(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_EFUSE_PATCH_EN(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_RF_ADDR(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
#define PARAM_INFO_SET_RF_ADDR(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
#define PARAM_INFO_GET_IO_ADDR(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
#define PARAM_INFO_SET_IO_ADDR(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
#define PARAM_INFO_GET_DELAY_VAL(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
#define PARAM_INFO_SET_DELAY_VAL(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
#define PARAM_INFO_GET_RF_PATH(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 24, 8)
#define PARAM_INFO_SET_RF_PATH(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 24, 8, value)
#define PARAM_INFO_GET_DATA(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 0, 32)
#define PARAM_INFO_SET_DATA(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 0, 32, value)
#define PARAM_INFO_GET_MASK(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X08, 0, 32)
#define PARAM_INFO_SET_MASK(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X08, 0, 32, value)
#define CH_INFO_GET_CH(extra_info) LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 8)
#define CH_INFO_SET_CH(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 8, value)
#define CH_INFO_GET_PRI_CH_IDX(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 8, 4)
#define CH_INFO_SET_PRI_CH_IDX(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 8, 4, value)
#define CH_INFO_GET_BW(extra_info) LE_BITS_TO_4BYTE(extra_info + 0X00, 12, 4)
#define CH_INFO_SET_BW(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 12, 4, value)
#define CH_INFO_GET_TIMEOUT(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 8)
#define CH_INFO_SET_TIMEOUT(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 8, value)
#define CH_INFO_GET_ACTION_ID(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 24, 7)
#define CH_INFO_SET_ACTION_ID(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 24, 7, value)
#define CH_INFO_GET_EXTRA_INFO(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 31, 1)
#define CH_INFO_SET_EXTRA_INFO(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 31, 1, value)
#define CH_EXTRA_INFO_GET_ID(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 7)
#define CH_EXTRA_INFO_SET_ID(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 7, value)
#define CH_EXTRA_INFO_GET_INFO(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 7, 1)
#define CH_EXTRA_INFO_SET_INFO(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 7, 1, value)
#define CH_EXTRA_INFO_GET_SIZE(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 8, 8)
#define CH_EXTRA_INFO_SET_SIZE(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 8, 8, value)
#define CH_EXTRA_INFO_GET_DATA(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 1)
#define CH_EXTRA_INFO_SET_DATA(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_L(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 16)
#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_BITDATA(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 0, 16)
#define HIOE_INSTRUCTION_INFO_SET_BITDATA(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 0, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_H(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
#define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_BITMASK(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X00, 16, 16)
#define HIOE_INSTRUCTION_INFO_SET_BITMASK(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X00, 16, 16, value)
#define HIOE_INSTRUCTION_INFO_GET_REG_ADDR(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 0, 22)
#define HIOE_INSTRUCTION_INFO_SET_REG_ADDR(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 0, 22, value)
#define HIOE_INSTRUCTION_INFO_GET_DELAY_VALUE(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 0, 22)
#define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 0, 22, value)
#define HIOE_INSTRUCTION_INFO_GET_MODE_SELECT(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 22, 1)
#define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 22, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_IO_DELAY(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 23, 1)
#define HIOE_INSTRUCTION_INFO_SET_IO_DELAY(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 23, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_BYTEMASK(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 24, 4)
#define HIOE_INSTRUCTION_INFO_SET_BYTEMASK(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 24, 4, value)
#define HIOE_INSTRUCTION_INFO_GET_RD_EN(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 28, 1)
#define HIOE_INSTRUCTION_INFO_SET_RD_EN(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 28, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_WR_EN(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 29, 1)
#define HIOE_INSTRUCTION_INFO_SET_WR_EN(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 29, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_RAW_R(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 30, 1)
#define HIOE_INSTRUCTION_INFO_SET_RAW_R(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 30, 1, value)
#define HIOE_INSTRUCTION_INFO_GET_RAW(extra_info) \
LE_BITS_TO_4BYTE(extra_info + 0X04, 31, 1)
#define HIOE_INSTRUCTION_INFO_SET_RAW(extra_info, value) \
SET_BITS_TO_LE_4BYTE(extra_info + 0X04, 31, 1, value)
#endif
================================================
FILE: hal/halmac/halmac_hw_cfg.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __HALMAC__HW_CFG_H__
#define __HALMAC__HW_CFG_H__
#include /* CONFIG_[IC], CONFIG_[INTF]_HCI */
#ifdef CONFIG_RTL8723A
#define HALMAC_8723A_SUPPORT 1
#else
#define HALMAC_8723A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8188E
#define HALMAC_8188E_SUPPORT 1
#else
#define HALMAC_8188E_SUPPORT 0
#endif
#ifdef CONFIG_RTL8821A
#define HALMAC_8821A_SUPPORT 1
#else
#define HALMAC_8821A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8723B
#define HALMAC_8723B_SUPPORT 1
#else
#define HALMAC_8723B_SUPPORT 0
#endif
#ifdef CONFIG_RTL8812A
#define HALMAC_8812A_SUPPORT 1
#else
#define HALMAC_8812A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8192E
#define HALMAC_8192E_SUPPORT 1
#else
#define HALMAC_8192E_SUPPORT 0
#endif
#ifdef CONFIG_RTL8881A
#define HALMAC_8881A_SUPPORT 1
#else
#define HALMAC_8881A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8821B
#define HALMAC_8821B_SUPPORT 1
#else
#define HALMAC_8821B_SUPPORT 0
#endif
#ifdef CONFIG_RTL8814A
#define HALMAC_8814A_SUPPORT 1
#else
#define HALMAC_8814A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8881A
#define HALMAC_8881A_SUPPORT 1
#else
#define HALMAC_8881A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8703B
#define HALMAC_8703B_SUPPORT 1
#else
#define HALMAC_8703B_SUPPORT 0
#endif
#ifdef CONFIG_RTL8723D
#define HALMAC_8723D_SUPPORT 1
#else
#define HALMAC_8723D_SUPPORT 0
#endif
#ifdef CONFIG_RTL8188F
#define HALMAC_8188F_SUPPORT 1
#else
#define HALMAC_8188F_SUPPORT 0
#endif
#ifdef CONFIG_RTL8821BMP
#define HALMAC_8821BMP_SUPPORT 1
#else
#define HALMAC_8821BMP_SUPPORT 0
#endif
#ifdef CONFIG_RTL8814AMP
#define HALMAC_8814AMP_SUPPORT 1
#else
#define HALMAC_8814AMP_SUPPORT 0
#endif
#ifdef CONFIG_RTL8195A
#define HALMAC_8195A_SUPPORT 1
#else
#define HALMAC_8195A_SUPPORT 0
#endif
#ifdef CONFIG_RTL8821B
#define HALMAC_8821B_SUPPORT 1
#else
#define HALMAC_8821B_SUPPORT 0
#endif
#ifdef CONFIG_RTL8196F
#define HALMAC_8196F_SUPPORT 1
#else
#define HALMAC_8196F_SUPPORT 0
#endif
#ifdef CONFIG_RTL8197F
#define HALMAC_8197F_SUPPORT 1
#else
#define HALMAC_8197F_SUPPORT 0
#endif
#ifdef CONFIG_RTL8198F
#define HALMAC_8198F_SUPPORT 1
#else
#define HALMAC_8198F_SUPPORT 0
#endif
#ifdef CONFIG_RTL8192F
#define HALMAC_8192F_SUPPORT 1
#else
#define HALMAC_8192F_SUPPORT 0
#endif
#ifdef CONFIG_RTL8197G
#define HALMAC_8197G_SUPPORT 1
#else
#define HALMAC_8197G_SUPPORT 0
#endif
#ifdef CONFIG_RTL8812F
#define HALMAC_8812F_SUPPORT 1
#else
#define HALMAC_8812F_SUPPORT 0
#endif
/* Halmac support IC version */
#ifdef CONFIG_RTL8814B
#define HALMAC_8814B_SUPPORT 1
#else
#define HALMAC_8814B_SUPPORT 0
#endif
#ifdef CONFIG_RTL8821C
#define HALMAC_8821C_SUPPORT 1
#else
#define HALMAC_8821C_SUPPORT 0
#endif
#ifdef CONFIG_RTL8822B
#define HALMAC_8822B_SUPPORT 1
#else
#define HALMAC_8822B_SUPPORT 0
#endif
#ifdef CONFIG_RTL8822C
#define HALMAC_8822C_SUPPORT 1
#else
#define HALMAC_8822C_SUPPORT 0
#endif
/* Interface support */
#ifdef CONFIG_SDIO_HCI
#define HALMAC_SDIO_SUPPORT 1
#else
#define HALMAC_SDIO_SUPPORT 0
#endif
#ifdef CONFIG_USB_HCI
#define HALMAC_USB_SUPPORT 1
#else
#define HALMAC_USB_SUPPORT 0
#endif
#ifdef CONFIG_PCI_HCI
#define HALMAC_PCIE_SUPPORT 1
#else
#define HALMAC_PCIE_SUPPORT 0
#endif
#endif /* __HALMAC__HW_CFG_H__ */
================================================
FILE: hal/halmac/halmac_intf_phy_cmd.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef HALMAC_INTF_PHY_CMD
#define HALMAC_INTF_PHY_CMD
/* Cut mask */
enum halmac_intf_phy_cut {
HALMAC_INTF_PHY_CUT_TESTCHIP = BIT(0),
HALMAC_INTF_PHY_CUT_A = BIT(1),
HALMAC_INTF_PHY_CUT_B = BIT(2),
HALMAC_INTF_PHY_CUT_C = BIT(3),
HALMAC_INTF_PHY_CUT_D = BIT(4),
HALMAC_INTF_PHY_CUT_E = BIT(5),
HALMAC_INTF_PHY_CUT_F = BIT(6),
HALMAC_INTF_PHY_CUT_G = BIT(7),
HALMAC_INTF_PHY_CUT_ALL = 0x7FFF,
};
/* IP selection */
enum halmac_ip_sel {
HALMAC_IP_INTF_PHY = 0,
HALMAC_IP_SEL_MAC = 1,
HALMAC_IP_PCIE_DBI = 2,
HALMAC_IP_SEL_UNDEFINE = 0x7FFF,
};
/* Platform mask */
enum halmac_intf_phy_platform {
HALMAC_INTF_PHY_PLATFORM_ALL = 0x7FFF,
};
#endif
================================================
FILE: hal/halmac/halmac_original_c2h_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_ORIGINALC2HFORMAT_H2C_C2H_AP_H_
#define _HAL_ORIGINALC2HFORMAT_H2C_C2H_AP_H_
#define CMD_ID_C2H 0X00
#define CMD_ID_DBG 0X00
#define CMD_ID_C2H_LB 0X01
#define CMD_ID_C2H_SND_TXBF 0X02
#define CMD_ID_C2H_CCX_RPT 0X03
#define CMD_ID_C2H_AP_REQ_TXRPT 0X04
#define CMD_ID_C2H_INITIAL_RATE_COLLECTION 0X05
#define CMD_ID_C2H_RA_RPT 0X0C
#define CMD_ID_C2H_SPECIAL_STATISTICS 0X0D
#define CMD_ID_C2H_RA_PARA_RPT 0X0E
#define CMD_ID_C2H_CUR_CHANNEL 0X10
#define CMD_ID_C2H_GPIO_WAKEUP 0X14
#define CMD_ID_C2H_DROPID_RPT 0X2D
#define C2H_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define DBG_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define DBG_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define DBG_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define DBG_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define DBG_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define DBG_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define DBG_GET_DBG_STR1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define DBG_SET_DBG_STR1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define DBG_SET_DBG_STR1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define DBG_GET_DBG_STR2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define DBG_SET_DBG_STR2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define DBG_SET_DBG_STR2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define DBG_GET_DBG_STR3(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define DBG_SET_DBG_STR3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define DBG_SET_DBG_STR3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define DBG_GET_DBG_STR4(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define DBG_SET_DBG_STR4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define DBG_SET_DBG_STR4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define DBG_GET_DBG_STR5(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define DBG_SET_DBG_STR5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define DBG_SET_DBG_STR5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define DBG_GET_DBG_STR6(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define DBG_SET_DBG_STR6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define DBG_SET_DBG_STR6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define DBG_GET_DBG_STR7(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define DBG_SET_DBG_STR7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define DBG_SET_DBG_STR7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define DBG_GET_DBG_STR8(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
#define DBG_SET_DBG_STR8(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
#define DBG_SET_DBG_STR8_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
#define DBG_GET_DBG_STR9(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
#define DBG_SET_DBG_STR9(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
#define DBG_SET_DBG_STR9_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
#define DBG_GET_DBG_STR10(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 24, 8)
#define DBG_SET_DBG_STR10(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 24, 8, value)
#define DBG_SET_DBG_STR10_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 24, 8, value)
#define DBG_GET_DBG_STR11(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 0, 8)
#define DBG_SET_DBG_STR11(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define DBG_SET_DBG_STR11_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define DBG_GET_DBG_STR12(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 8, 8)
#define DBG_SET_DBG_STR12(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define DBG_SET_DBG_STR12_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define DBG_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define DBG_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define DBG_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define DBG_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define DBG_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define DBG_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_LB_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_LB_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_LB_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_LB_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_LB_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_LB_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_LB_GET_PAYLOAD1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 16)
#define C2H_LB_SET_PAYLOAD1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 16, value)
#define C2H_LB_SET_PAYLOAD1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 16, value)
#define C2H_LB_GET_PAYLOAD2(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 32)
#define C2H_LB_SET_PAYLOAD2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 32, value)
#define C2H_LB_SET_PAYLOAD2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 32, value)
#define C2H_LB_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_LB_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_LB_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_LB_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_LB_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_LB_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_SND_TXBF_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_SND_TXBF_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SND_TXBF_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SND_TXBF_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_SND_TXBF_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SND_TXBF_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SND_TXBF_GET_SND_RESULT(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 1)
#define C2H_SND_TXBF_SET_SND_RESULT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 1, value)
#define C2H_SND_TXBF_SET_SND_RESULT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 1, value)
#define C2H_SND_TXBF_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_SND_TXBF_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_SND_TXBF_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_SND_TXBF_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_SND_TXBF_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_SND_TXBF_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_CCX_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_CCX_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_CCX_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_CCX_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_CCX_RPT_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_CCX_RPT_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_CCX_RPT_GET_QSEL(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 5)
#define C2H_CCX_RPT_SET_QSEL(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 5, value)
#define C2H_CCX_RPT_SET_QSEL_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 5, value)
#define C2H_CCX_RPT_GET_BMC(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 21, 1)
#define C2H_CCX_RPT_SET_BMC(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 21, 1, value)
#define C2H_CCX_RPT_SET_BMC_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 21, 1, value)
#define C2H_CCX_RPT_GET_LIFE_TIME_OVER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 22, 1)
#define C2H_CCX_RPT_SET_LIFE_TIME_OVER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 22, 1, value)
#define C2H_CCX_RPT_SET_LIFE_TIME_OVER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 22, 1, value)
#define C2H_CCX_RPT_GET_RETRY_OVER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 23, 1)
#define C2H_CCX_RPT_SET_RETRY_OVER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 23, 1, value)
#define C2H_CCX_RPT_SET_RETRY_OVER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 23, 1, value)
#define C2H_CCX_RPT_GET_MACID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define C2H_CCX_RPT_SET_MACID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_CCX_RPT_SET_MACID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_CCX_RPT_GET_DATA_RETRY_CNT(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 6)
#define C2H_CCX_RPT_SET_DATA_RETRY_CNT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 6, value)
#define C2H_CCX_RPT_SET_DATA_RETRY_CNT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 6, value)
#define C2H_CCX_RPT_GET_QUEUE7_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define C2H_CCX_RPT_SET_QUEUE7_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_CCX_RPT_SET_QUEUE7_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_CCX_RPT_GET_QUEUE15_8(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define C2H_CCX_RPT_SET_QUEUE15_8(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_CCX_RPT_SET_QUEUE15_8_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_CCX_RPT_GET_FINAL_DATA_RATE(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define C2H_CCX_RPT_SET_FINAL_DATA_RATE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_CCX_RPT_SET_FINAL_DATA_RATE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_CCX_RPT_GET_SW_DEFINE_0(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define C2H_CCX_RPT_SET_SW_DEFINE_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_CCX_RPT_SET_SW_DEFINE_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_CCX_RPT_GET_SW_DEFINE_1(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X08, 8, 4)
#define C2H_CCX_RPT_SET_SW_DEFINE_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 4, value)
#define C2H_CCX_RPT_SET_SW_DEFINE_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 4, value)
#define C2H_CCX_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_CCX_RPT_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_CCX_RPT_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_CCX_RPT_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_CCX_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_CCX_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_AP_REQ_TXRPT_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_AP_REQ_TXRPT_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_STA1_MACID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_STA1_MACID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_AP_REQ_TXRPT_SET_STA1_MACID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK1_0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK1_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_OK1_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK1_1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK1_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_OK1_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_STA2_MACID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_STA2_MACID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_AP_REQ_TXRPT_SET_STA2_MACID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK2_0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK2_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_OK2_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK2_1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK2_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_OK2_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 24, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE2(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_AP_REQ_TXRPT_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TRIGGER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_AP_REQ_TXRPT_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_CMD_ID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_SEQ(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_TRYING_BITMAP(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 7)
#define C2H_INITIAL_RATE_COLLECTION_SET_TRYING_BITMAP(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 7, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_TRYING_BITMAP_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 7, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE2(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE3(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE4(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE5(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE6(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE7(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_LEN(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_TRIGGER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_RA_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_RA_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_RA_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_RA_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_RA_RPT_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_RA_RPT_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_RA_RPT_GET_RATE(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define C2H_RA_RPT_SET_RATE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_RA_RPT_SET_RATE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_RA_RPT_GET_MACID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define C2H_RA_RPT_SET_MACID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_RA_RPT_SET_MACID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_RA_RPT_GET_USE_LDPC(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 1)
#define C2H_RA_RPT_SET_USE_LDPC(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 1, value)
#define C2H_RA_RPT_SET_USE_LDPC_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 1, value)
#define C2H_RA_RPT_GET_USE_TXBF(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 1, 1)
#define C2H_RA_RPT_SET_USE_TXBF(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 1, 1, value)
#define C2H_RA_RPT_SET_USE_TXBF_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 1, 1, value)
#define C2H_RA_RPT_GET_COLLISION_STATE(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define C2H_RA_RPT_SET_COLLISION_STATE(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_RA_RPT_SET_COLLISION_STATE_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_RA_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_RA_RPT_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_RA_RPT_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_RA_RPT_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_RA_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_RA_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_CMD_ID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_SPECIAL_STATISTICS_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_SEQ(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_SPECIAL_STATISTICS_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_STATISTICS_IDX(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_STATISTICS_IDX(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_STATISTICS_IDX_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA0(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 24, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA0(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA0_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA1(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA1(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA1_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA2(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 8, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA2(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA2_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA3(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA3(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA3_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA4(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X04, 24, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA4(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA4_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA5(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 0, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA5(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA5_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA6(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 8, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA6(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA6_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA7(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X08, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA7(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X08, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_DATA7_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X08, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_LEN(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_TRIGGER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_SPECIAL_STATISTICS_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_RA_PARA_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_RA_PARA_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_RA_PARA_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_RA_PARA_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_RA_PARA_RPT_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_RA_PARA_RPT_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_RA_PARA_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_RA_PARA_RPT_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_RA_PARA_RPT_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_RA_PARA_RPT_GET_TRIGGER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_RA_PARA_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_RA_PARA_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_CUR_CHANNEL_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_CUR_CHANNEL_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_CUR_CHANNEL_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_CUR_CHANNEL_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_CUR_CHANNEL_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_CUR_CHANNEL_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_CUR_CHANNEL_GET_CHANNEL_NUM(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 8)
#define C2H_CUR_CHANNEL_SET_CHANNEL_NUM(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_CUR_CHANNEL_SET_CHANNEL_NUM_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 8, value)
#define C2H_CUR_CHANNEL_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_CUR_CHANNEL_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_CUR_CHANNEL_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_CUR_CHANNEL_GET_TRIGGER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_CUR_CHANNEL_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_CUR_CHANNEL_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_GPIO_WAKEUP_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_GPIO_WAKEUP_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_GPIO_WAKEUP_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_GPIO_WAKEUP_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_GPIO_WAKEUP_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_GPIO_WAKEUP_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_GPIO_WAKEUP_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_GPIO_WAKEUP_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_GPIO_WAKEUP_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_GPIO_WAKEUP_GET_TRIGGER(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_GPIO_WAKEUP_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_GPIO_WAKEUP_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_DROPID_RPT_GET_CMD_ID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 0, 8)
#define C2H_DROPID_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_DROPID_RPT_SET_CMD_ID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 0, 8, value)
#define C2H_DROPID_RPT_GET_SEQ(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X00, 8, 8)
#define C2H_DROPID_RPT_SET_SEQ(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_DROPID_RPT_SET_SEQ_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 8, 8, value)
#define C2H_DROPID_RPT_GET_DROPIDBIT(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 16, 4)
#define C2H_DROPID_RPT_SET_DROPIDBIT(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 16, 4, value)
#define C2H_DROPID_RPT_SET_DROPIDBIT_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 16, 4, value)
#define C2H_DROPID_RPT_GET_CURDROPID(c2h_pkt) \
GET_C2H_FIELD(c2h_pkt + 0X00, 20, 2)
#define C2H_DROPID_RPT_SET_CURDROPID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X00, 20, 2, value)
#define C2H_DROPID_RPT_SET_CURDROPID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X00, 20, 2, value)
#define C2H_DROPID_RPT_GET_MACID(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X04, 0, 8)
#define C2H_DROPID_RPT_SET_MACID(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_DROPID_RPT_SET_MACID_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X04, 0, 8, value)
#define C2H_DROPID_RPT_GET_LEN(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 16, 8)
#define C2H_DROPID_RPT_SET_LEN(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_DROPID_RPT_SET_LEN_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_DROPID_RPT_GET_TRIGGER(c2h_pkt) GET_C2H_FIELD(c2h_pkt + 0X0C, 24, 8)
#define C2H_DROPID_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_C2H_FIELD_CLR(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_DROPID_RPT_SET_TRIGGER_NO_CLR(c2h_pkt, value) \
SET_C2H_FIELD_NO_CLR(c2h_pkt + 0X0C, 24, 8, value)
#endif
================================================
FILE: hal/halmac/halmac_original_c2h_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_ORIGINALC2HFORMAT_H2C_C2H_NIC_H_
#define _HAL_ORIGINALC2HFORMAT_H2C_C2H_NIC_H_
#define CMD_ID_C2H 0X00
#define CMD_ID_DBG 0X00
#define CMD_ID_C2H_LB 0X01
#define CMD_ID_C2H_SND_TXBF 0X02
#define CMD_ID_C2H_CCX_RPT 0X03
#define CMD_ID_C2H_AP_REQ_TXRPT 0X04
#define CMD_ID_C2H_INITIAL_RATE_COLLECTION 0X05
#define CMD_ID_C2H_RA_RPT 0X0C
#define CMD_ID_C2H_SPECIAL_STATISTICS 0X0D
#define CMD_ID_C2H_RA_PARA_RPT 0X0E
#define CMD_ID_C2H_CUR_CHANNEL 0X10
#define CMD_ID_C2H_GPIO_WAKEUP 0X14
#define CMD_ID_C2H_DROPID_RPT 0X2D
#define C2H_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define DBG_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define DBG_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define DBG_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define DBG_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define DBG_GET_DBG_STR1(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define DBG_SET_DBG_STR1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define DBG_GET_DBG_STR2(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define DBG_SET_DBG_STR2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define DBG_GET_DBG_STR3(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define DBG_SET_DBG_STR3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define DBG_GET_DBG_STR4(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define DBG_SET_DBG_STR4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define DBG_GET_DBG_STR5(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define DBG_SET_DBG_STR5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define DBG_GET_DBG_STR6(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define DBG_SET_DBG_STR6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define DBG_GET_DBG_STR7(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define DBG_SET_DBG_STR7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define DBG_GET_DBG_STR8(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
#define DBG_SET_DBG_STR8(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
#define DBG_GET_DBG_STR9(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
#define DBG_SET_DBG_STR9(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
#define DBG_GET_DBG_STR10(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 24, 8)
#define DBG_SET_DBG_STR10(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 24, 8, value)
#define DBG_GET_DBG_STR11(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 0, 8)
#define DBG_SET_DBG_STR11(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 0, 8, value)
#define DBG_GET_DBG_STR12(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 8, 8)
#define DBG_SET_DBG_STR12(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 8, 8, value)
#define DBG_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define DBG_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define DBG_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define DBG_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_LB_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_LB_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_LB_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_LB_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_LB_GET_PAYLOAD1(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 16)
#define C2H_LB_SET_PAYLOAD1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 16, value)
#define C2H_LB_GET_PAYLOAD2(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 32)
#define C2H_LB_SET_PAYLOAD2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 32, value)
#define C2H_LB_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_LB_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_LB_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_LB_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_SND_TXBF_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_SND_TXBF_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SND_TXBF_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_SND_TXBF_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SND_TXBF_GET_SND_RESULT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 1)
#define C2H_SND_TXBF_SET_SND_RESULT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 1, value)
#define C2H_SND_TXBF_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_SND_TXBF_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_SND_TXBF_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_SND_TXBF_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_CCX_RPT_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_CCX_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_CCX_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_CCX_RPT_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_CCX_RPT_GET_QSEL(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 5)
#define C2H_CCX_RPT_SET_QSEL(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 5, value)
#define C2H_CCX_RPT_GET_BMC(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 21, 1)
#define C2H_CCX_RPT_SET_BMC(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 21, 1, value)
#define C2H_CCX_RPT_GET_LIFE_TIME_OVER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 22, 1)
#define C2H_CCX_RPT_SET_LIFE_TIME_OVER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 22, 1, value)
#define C2H_CCX_RPT_GET_RETRY_OVER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 23, 1)
#define C2H_CCX_RPT_SET_RETRY_OVER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 23, 1, value)
#define C2H_CCX_RPT_GET_MACID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define C2H_CCX_RPT_SET_MACID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define C2H_CCX_RPT_GET_DATA_RETRY_CNT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 6)
#define C2H_CCX_RPT_SET_DATA_RETRY_CNT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 6, value)
#define C2H_CCX_RPT_GET_QUEUE7_0(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define C2H_CCX_RPT_SET_QUEUE7_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define C2H_CCX_RPT_GET_QUEUE15_8(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define C2H_CCX_RPT_SET_QUEUE15_8(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define C2H_CCX_RPT_GET_FINAL_DATA_RATE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define C2H_CCX_RPT_SET_FINAL_DATA_RATE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define C2H_CCX_RPT_GET_SW_DEFINE_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define C2H_CCX_RPT_SET_SW_DEFINE_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define C2H_CCX_RPT_GET_SW_DEFINE_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 4)
#define C2H_CCX_RPT_SET_SW_DEFINE_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 4, value)
#define C2H_CCX_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_CCX_RPT_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_CCX_RPT_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_CCX_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_STA1_MACID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_STA1_MACID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK1_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK1_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK1_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK1_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL1_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL1_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_STA2_MACID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_STA2_MACID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK2_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK2_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_OK2_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_OK2_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 24, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TX_FAIL2_1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 0, 8)
#define C2H_AP_REQ_TXRPT_SET_TX_FAIL2_1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 0, 8, value)
#define C2H_AP_REQ_TXRPT_GET_INITIAL_RATE2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 8, 8)
#define C2H_AP_REQ_TXRPT_SET_INITIAL_RATE2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 8, 8, value)
#define C2H_AP_REQ_TXRPT_GET_LEN(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_AP_REQ_TXRPT_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_AP_REQ_TXRPT_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_AP_REQ_TXRPT_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_SEQ(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_TRYING_BITMAP(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 7)
#define C2H_INITIAL_RATE_COLLECTION_SET_TRYING_BITMAP(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 7, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE3(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE4(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE5(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE6(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_INITIAL_RATE7(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_INITIAL_RATE7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_LEN(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_INITIAL_RATE_COLLECTION_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_INITIAL_RATE_COLLECTION_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_RA_RPT_GET_CMD_ID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_RA_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_RA_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_RA_RPT_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_RA_RPT_GET_RATE(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define C2H_RA_RPT_SET_RATE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define C2H_RA_RPT_GET_MACID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define C2H_RA_RPT_SET_MACID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define C2H_RA_RPT_GET_USE_LDPC(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 1)
#define C2H_RA_RPT_SET_USE_LDPC(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 1, value)
#define C2H_RA_RPT_GET_USE_TXBF(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 1, 1)
#define C2H_RA_RPT_SET_USE_TXBF(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 1, 1, value)
#define C2H_RA_RPT_GET_COLLISION_STATE(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define C2H_RA_RPT_SET_COLLISION_STATE(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define C2H_RA_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_RA_RPT_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_RA_RPT_GET_TRIGGER(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_RA_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_SPECIAL_STATISTICS_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_SEQ(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_SPECIAL_STATISTICS_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_STATISTICS_IDX(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_STATISTICS_IDX(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA0(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 24, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA0(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA1(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA1(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA2(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 8, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA2(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA3(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA3(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA4(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 24, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA4(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 24, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA5(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 0, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA5(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 0, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA6(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 8, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA6(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 8, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_DATA7(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X08, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_DATA7(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X08, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_LEN(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_SPECIAL_STATISTICS_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_SPECIAL_STATISTICS_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_SPECIAL_STATISTICS_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_RA_PARA_RPT_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_RA_PARA_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_RA_PARA_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_RA_PARA_RPT_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_RA_PARA_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_RA_PARA_RPT_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_RA_PARA_RPT_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_RA_PARA_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_CUR_CHANNEL_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_CUR_CHANNEL_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_CUR_CHANNEL_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_CUR_CHANNEL_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_CUR_CHANNEL_GET_CHANNEL_NUM(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 8)
#define C2H_CUR_CHANNEL_SET_CHANNEL_NUM(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 8, value)
#define C2H_CUR_CHANNEL_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_CUR_CHANNEL_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_CUR_CHANNEL_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_CUR_CHANNEL_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_GPIO_WAKEUP_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_GPIO_WAKEUP_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_GPIO_WAKEUP_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_GPIO_WAKEUP_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_GPIO_WAKEUP_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_GPIO_WAKEUP_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_GPIO_WAKEUP_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_GPIO_WAKEUP_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#define C2H_DROPID_RPT_GET_CMD_ID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 0, 8)
#define C2H_DROPID_RPT_SET_CMD_ID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 0, 8, value)
#define C2H_DROPID_RPT_GET_SEQ(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 8, 8)
#define C2H_DROPID_RPT_SET_SEQ(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 8, 8, value)
#define C2H_DROPID_RPT_GET_DROPIDBIT(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 16, 4)
#define C2H_DROPID_RPT_SET_DROPIDBIT(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 16, 4, value)
#define C2H_DROPID_RPT_GET_CURDROPID(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X00, 20, 2)
#define C2H_DROPID_RPT_SET_CURDROPID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X00, 20, 2, value)
#define C2H_DROPID_RPT_GET_MACID(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X04, 0, 8)
#define C2H_DROPID_RPT_SET_MACID(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X04, 0, 8, value)
#define C2H_DROPID_RPT_GET_LEN(c2h_pkt) LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 16, 8)
#define C2H_DROPID_RPT_SET_LEN(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 16, 8, value)
#define C2H_DROPID_RPT_GET_TRIGGER(c2h_pkt) \
LE_BITS_TO_4BYTE(c2h_pkt + 0X0C, 24, 8)
#define C2H_DROPID_RPT_SET_TRIGGER(c2h_pkt, value) \
SET_BITS_TO_LE_4BYTE(c2h_pkt + 0X0C, 24, 8, value)
#endif
================================================
FILE: hal/halmac/halmac_original_h2c_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_ORIGINALH2CFORMAT_H2C_C2H_AP_H_
#define _HAL_ORIGINALH2CFORMAT_H2C_C2H_AP_H_
#define CMD_ID_ORIGINAL_H2C 0X00
#define CMD_ID_H2C2H_LB 0X0
#define CMD_ID_D0_SCAN_OFFLOAD_CTRL 0X06
#define CMD_ID_RSVD_PAGE 0X0
#define CMD_ID_MEDIA_STATUS_RPT 0X01
#define CMD_ID_KEEP_ALIVE 0X03
#define CMD_ID_DISCONNECT_DECISION 0X04
#define CMD_ID_AP_OFFLOAD 0X08
#define CMD_ID_BCN_RSVDPAGE 0X09
#define CMD_ID_PROBE_RSP_RSVDPAGE 0X0A
#define CMD_ID_SINGLE_CHANNELSWITCH 0X1C
#define CMD_ID_SINGLE_CHANNELSWITCH_V2 0X1D
#define CMD_ID_SET_PWR_MODE 0X00
#define CMD_ID_PS_TUNING_PARA 0X01
#define CMD_ID_PS_TUNING_PARA_II 0X02
#define CMD_ID_PS_LPS_PARA 0X03
#define CMD_ID_P2P_PS_OFFLOAD 0X04
#define CMD_ID_PS_SCAN_EN 0X05
#define CMD_ID_SAP_PS 0X06
#define CMD_ID_INACTIVE_PS 0X07
#define CMD_ID_MACID_CFG 0X00
#define CMD_ID_TXBF 0X01
#define CMD_ID_RSSI_SETTING 0X02
#define CMD_ID_AP_REQ_TXRPT 0X03
#define CMD_ID_INIT_RATE_COLLECTION 0X04
#define CMD_ID_IQK_OFFLOAD 0X05
#define CMD_ID_MACID_CFG_3SS 0X06
#define CMD_ID_RA_PARA_ADJUST 0X07
#define CMD_ID_WWLAN 0X00
#define CMD_ID_REMOTE_WAKE_CTRL 0X01
#define CMD_ID_AOAC_GLOBAL_INFO 0X02
#define CMD_ID_AOAC_RSVD_PAGE 0X03
#define CMD_ID_AOAC_RSVD_PAGE2 0X04
#define CMD_ID_D0_SCAN_OFFLOAD_INFO 0X05
#define CMD_ID_CHANNEL_SWITCH_OFFLOAD 0X07
#define CMD_ID_AOAC_RSVD_PAGE3 0X08
#define CMD_ID_DBG_MSG_CTRL 0X1E
#define CLASS_ORIGINAL_H2C 0X00
#define CLASS_H2C2H_LB 0X07
#define CLASS_D0_SCAN_OFFLOAD_CTRL 0X04
#define CLASS_RSVD_PAGE 0X0
#define CLASS_MEDIA_STATUS_RPT 0X0
#define CLASS_KEEP_ALIVE 0X0
#define CLASS_DISCONNECT_DECISION 0X0
#define CLASS_AP_OFFLOAD 0X0
#define CLASS_BCN_RSVDPAGE 0X0
#define CLASS_PROBE_RSP_RSVDPAGE 0X0
#define CLASS_SINGLE_CHANNELSWITCH 0X0
#define CLASS_SINGLE_CHANNELSWITCH_V2 0X0
#define CLASS_SET_PWR_MODE 0X01
#define CLASS_PS_TUNING_PARA 0X01
#define CLASS_PS_TUNING_PARA_II 0X01
#define CLASS_PS_LPS_PARA 0X01
#define CLASS_P2P_PS_OFFLOAD 0X01
#define CLASS_PS_SCAN_EN 0X1
#define CLASS_SAP_PS 0X1
#define CLASS_INACTIVE_PS 0X1
#define CLASS_MACID_CFG 0X2
#define CLASS_TXBF 0X2
#define CLASS_RSSI_SETTING 0X2
#define CLASS_AP_REQ_TXRPT 0X2
#define CLASS_INIT_RATE_COLLECTION 0X2
#define CLASS_IQK_OFFLOAD 0X2
#define CLASS_MACID_CFG_3SS 0X2
#define CLASS_RA_PARA_ADJUST 0X02
#define CLASS_WWLAN 0X4
#define CLASS_REMOTE_WAKE_CTRL 0X4
#define CLASS_AOAC_GLOBAL_INFO 0X04
#define CLASS_AOAC_RSVD_PAGE 0X04
#define CLASS_AOAC_RSVD_PAGE2 0X04
#define CLASS_D0_SCAN_OFFLOAD_INFO 0X04
#define CLASS_CHANNEL_SWITCH_OFFLOAD 0X04
#define CLASS_AOAC_RSVD_PAGE3 0X04
#define CLASS_DBG_MSG_CTRL 0X07
#define ORIGINAL_H2C_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define ORIGINAL_H2C_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define ORIGINAL_H2C_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define ORIGINAL_H2C_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define ORIGINAL_H2C_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define ORIGINAL_H2C_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define H2C2H_LB_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define H2C2H_LB_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define H2C2H_LB_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define H2C2H_LB_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define H2C2H_LB_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define H2C2H_LB_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define H2C2H_LB_GET_SEQ(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define H2C2H_LB_SET_SEQ(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define H2C2H_LB_SET_SEQ_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define H2C2H_LB_GET_PAYLOAD1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 16)
#define H2C2H_LB_SET_PAYLOAD1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 16, value)
#define H2C2H_LB_SET_PAYLOAD1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 16, value)
#define H2C2H_LB_GET_PAYLOAD2(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 32)
#define H2C2H_LB_SET_PAYLOAD2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 32, value)
#define H2C2H_LB_SET_PAYLOAD2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 32, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define D0_SCAN_OFFLOAD_CTRL_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define D0_SCAN_OFFLOAD_CTRL_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_D0_SCAN_FUN_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_D0_SCAN_FUN_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_D0_SCAN_FUN_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_RTD3FUN_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_RTD3FUN_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_RTD3FUN_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_U3_SCAN_FUN_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_U3_SCAN_FUN_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_U3_SCAN_FUN_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_NLO_FUN_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_NLO_FUN_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_NLO_FUN_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_IPS_DEPENDENT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_IPS_DEPENDENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_IPS_DEPENDENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_PROBE_PACKET(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 17)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_PROBE_PACKET(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 17, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_PROBE_PACKET_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 17, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SCAN_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SCAN_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SCAN_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SSID_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SSID_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SSID_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define RSVD_PAGE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define RSVD_PAGE_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define RSVD_PAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define RSVD_PAGE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define RSVD_PAGE_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define RSVD_PAGE_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define RSVD_PAGE_GET_LOC_PROBE_RSP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define RSVD_PAGE_SET_LOC_PROBE_RSP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define RSVD_PAGE_SET_LOC_PROBE_RSP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define RSVD_PAGE_GET_LOC_PS_POLL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define RSVD_PAGE_SET_LOC_PS_POLL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define RSVD_PAGE_SET_LOC_PS_POLL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define RSVD_PAGE_GET_LOC_NULL_DATA(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define RSVD_PAGE_SET_LOC_NULL_DATA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define RSVD_PAGE_SET_LOC_NULL_DATA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define RSVD_PAGE_GET_LOC_QOS_NULL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define RSVD_PAGE_SET_LOC_QOS_NULL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define RSVD_PAGE_SET_LOC_QOS_NULL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define RSVD_PAGE_GET_LOC_BT_QOS_NULL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define RSVD_PAGE_SET_LOC_BT_QOS_NULL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define RSVD_PAGE_SET_LOC_BT_QOS_NULL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define RSVD_PAGE_GET_LOC_CTS2SELF(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define RSVD_PAGE_SET_LOC_CTS2SELF(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define RSVD_PAGE_SET_LOC_CTS2SELF_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define RSVD_PAGE_GET_LOC_LTECOEX_QOSNULL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
#define RSVD_PAGE_SET_LOC_LTECOEX_QOSNULL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
#define RSVD_PAGE_SET_LOC_LTECOEX_QOSNULL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
#define MEDIA_STATUS_RPT_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define MEDIA_STATUS_RPT_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define MEDIA_STATUS_RPT_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define MEDIA_STATUS_RPT_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define MEDIA_STATUS_RPT_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define MEDIA_STATUS_RPT_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define MEDIA_STATUS_RPT_GET_OP_MODE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define MEDIA_STATUS_RPT_SET_OP_MODE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define MEDIA_STATUS_RPT_SET_OP_MODE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define MEDIA_STATUS_RPT_GET_MACID_IN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define MEDIA_STATUS_RPT_SET_MACID_IN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define MEDIA_STATUS_RPT_SET_MACID_IN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define MEDIA_STATUS_RPT_GET_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define MEDIA_STATUS_RPT_SET_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define MEDIA_STATUS_RPT_SET_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define MEDIA_STATUS_RPT_GET_MACID_END(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define MEDIA_STATUS_RPT_SET_MACID_END(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define MEDIA_STATUS_RPT_SET_MACID_END_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define KEEP_ALIVE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define KEEP_ALIVE_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define KEEP_ALIVE_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define KEEP_ALIVE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define KEEP_ALIVE_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define KEEP_ALIVE_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define KEEP_ALIVE_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define KEEP_ALIVE_SET_ENABLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define KEEP_ALIVE_SET_ENABLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define KEEP_ALIVE_GET_ADOPT_USER_SETTING(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define KEEP_ALIVE_SET_ADOPT_USER_SETTING(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define KEEP_ALIVE_SET_ADOPT_USER_SETTING_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define KEEP_ALIVE_GET_PKT_TYPE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define KEEP_ALIVE_SET_PKT_TYPE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define KEEP_ALIVE_SET_PKT_TYPE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define KEEP_ALIVE_GET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define DISCONNECT_DECISION_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define DISCONNECT_DECISION_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define DISCONNECT_DECISION_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define DISCONNECT_DECISION_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define DISCONNECT_DECISION_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define DISCONNECT_DECISION_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define DISCONNECT_DECISION_GET_ENABLE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define DISCONNECT_DECISION_SET_ENABLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define DISCONNECT_DECISION_SET_ENABLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define DISCONNECT_DECISION_GET_ADOPT_USER_SETTING(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define DISCONNECT_DECISION_SET_ADOPT_USER_SETTING(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define DISCONNECT_DECISION_SET_ADOPT_USER_SETTING_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_EN_NO_CLR(h2c_pkt, \
value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define DISCONNECT_DECISION_GET_DISCONNECT_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define DISCONNECT_DECISION_SET_DISCONNECT_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define DISCONNECT_DECISION_SET_DISCONNECT_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define DISCONNECT_DECISION_GET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD_NO_CLR(h2c_pkt, \
value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define DISCONNECT_DECISION_GET_TRY_PKT_NUM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define DISCONNECT_DECISION_SET_TRY_PKT_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define DISCONNECT_DECISION_SET_TRY_PKT_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_LIMIT_NO_CLR(h2c_pkt, \
value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AP_OFFLOAD_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define AP_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AP_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AP_OFFLOAD_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define AP_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AP_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AP_OFFLOAD_GET_ON(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define AP_OFFLOAD_SET_ON(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define AP_OFFLOAD_SET_ON_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define AP_OFFLOAD_GET_CFG_MIFI_PLATFORM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define AP_OFFLOAD_SET_CFG_MIFI_PLATFORM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define AP_OFFLOAD_SET_CFG_MIFI_PLATFORM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define AP_OFFLOAD_GET_LINKED(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define AP_OFFLOAD_SET_LINKED(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define AP_OFFLOAD_SET_LINKED_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define AP_OFFLOAD_GET_EN_AUTO_WAKE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define AP_OFFLOAD_SET_EN_AUTO_WAKE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define AP_OFFLOAD_SET_EN_AUTO_WAKE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define AP_OFFLOAD_GET_WAKE_FLAG(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
#define AP_OFFLOAD_SET_WAKE_FLAG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
#define AP_OFFLOAD_SET_WAKE_FLAG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_ROOT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 1)
#define AP_OFFLOAD_SET_HIDDEN_ROOT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 1, value)
#define AP_OFFLOAD_SET_HIDDEN_ROOT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 17, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 17, 1, value)
#define AP_OFFLOAD_SET_HIDDEN_VAP1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 17, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP2(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 18, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 18, 1, value)
#define AP_OFFLOAD_SET_HIDDEN_VAP2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 18, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP3(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 19, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 19, 1, value)
#define AP_OFFLOAD_SET_HIDDEN_VAP3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 19, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP4(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 20, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 20, 1, value)
#define AP_OFFLOAD_SET_HIDDEN_VAP4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 20, 1, value)
#define AP_OFFLOAD_GET_DENYANY_ROOT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 1)
#define AP_OFFLOAD_SET_DENYANY_ROOT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 1, value)
#define AP_OFFLOAD_SET_DENYANY_ROOT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 25, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 25, 1, value)
#define AP_OFFLOAD_SET_DENYANY_VAP1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 25, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 26, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 26, 1, value)
#define AP_OFFLOAD_SET_DENYANY_VAP2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 26, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 27, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 27, 1, value)
#define AP_OFFLOAD_SET_DENYANY_VAP3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 27, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 28, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 28, 1, value)
#define AP_OFFLOAD_SET_DENYANY_VAP4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 28, 1, value)
#define AP_OFFLOAD_GET_WAIT_TBTT_CNT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define AP_OFFLOAD_SET_WAIT_TBTT_CNT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AP_OFFLOAD_SET_WAIT_TBTT_CNT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AP_OFFLOAD_GET_WAKE_TIMEOUT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define AP_OFFLOAD_SET_WAKE_TIMEOUT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define AP_OFFLOAD_SET_WAKE_TIMEOUT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define AP_OFFLOAD_GET_LEN_IV_PAIR(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define AP_OFFLOAD_SET_LEN_IV_PAIR(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define AP_OFFLOAD_SET_LEN_IV_PAIR_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define AP_OFFLOAD_GET_LEN_IV_GRP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
#define AP_OFFLOAD_SET_LEN_IV_GRP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
#define AP_OFFLOAD_SET_LEN_IV_GRP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
#define BCN_RSVDPAGE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define BCN_RSVDPAGE_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define BCN_RSVDPAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define BCN_RSVDPAGE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define BCN_RSVDPAGE_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define BCN_RSVDPAGE_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define BCN_RSVDPAGE_GET_LOC_ROOT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define BCN_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define BCN_RSVDPAGE_SET_LOC_ROOT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP1(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define BCN_RSVDPAGE_SET_LOC_VAP1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP2(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define BCN_RSVDPAGE_SET_LOC_VAP2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP3(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define BCN_RSVDPAGE_SET_LOC_VAP3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP4(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define BCN_RSVDPAGE_SET_LOC_VAP4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define PROBE_RSP_RSVDPAGE_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PROBE_RSP_RSVDPAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PROBE_RSP_RSVDPAGE_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define PROBE_RSP_RSVDPAGE_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PROBE_RSP_RSVDPAGE_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_ROOT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define PROBE_RSP_RSVDPAGE_SET_LOC_ROOT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP2(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP2_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP3(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP3_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP4(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP4_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define SINGLE_CHANNELSWITCH_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define SINGLE_CHANNELSWITCH_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SINGLE_CHANNELSWITCH_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SINGLE_CHANNELSWITCH_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define SINGLE_CHANNELSWITCH_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SINGLE_CHANNELSWITCH_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SINGLE_CHANNELSWITCH_GET_CHANNEL_NUM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define SINGLE_CHANNELSWITCH_SET_CHANNEL_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define SINGLE_CHANNELSWITCH_SET_CHANNEL_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define SINGLE_CHANNELSWITCH_GET_BW(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 2)
#define SINGLE_CHANNELSWITCH_SET_BW(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 2, value)
#define SINGLE_CHANNELSWITCH_SET_BW_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 2, value)
#define SINGLE_CHANNELSWITCH_GET_BW40SC(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 18, 3)
#define SINGLE_CHANNELSWITCH_SET_BW40SC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 18, 3, value)
#define SINGLE_CHANNELSWITCH_SET_BW40SC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 18, 3, value)
#define SINGLE_CHANNELSWITCH_GET_BW80SC(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 21, 3)
#define SINGLE_CHANNELSWITCH_SET_BW80SC(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 21, 3, value)
#define SINGLE_CHANNELSWITCH_SET_BW80SC_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 21, 3, value)
#define SINGLE_CHANNELSWITCH_GET_RFE_TYPE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 4)
#define SINGLE_CHANNELSWITCH_SET_RFE_TYPE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 4, value)
#define SINGLE_CHANNELSWITCH_SET_RFE_TYPE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 4, value)
#define SINGLE_CHANNELSWITCH_V2_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define SINGLE_CHANNELSWITCH_V2_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SINGLE_CHANNELSWITCH_V2_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SINGLE_CHANNELSWITCH_V2_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define SINGLE_CHANNELSWITCH_V2_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SINGLE_CHANNELSWITCH_V2_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SINGLE_CHANNELSWITCH_V2_GET_CENTRAL_CH(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define SINGLE_CHANNELSWITCH_V2_SET_CENTRAL_CH(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define SINGLE_CHANNELSWITCH_V2_SET_CENTRAL_CH_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define SINGLE_CHANNELSWITCH_V2_GET_PRIMARY_CH_IDX(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 4)
#define SINGLE_CHANNELSWITCH_V2_SET_PRIMARY_CH_IDX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 4, value)
#define SINGLE_CHANNELSWITCH_V2_SET_PRIMARY_CH_IDX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 4, value)
#define SINGLE_CHANNELSWITCH_V2_GET_BW(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 20, 4)
#define SINGLE_CHANNELSWITCH_V2_SET_BW(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 20, 4, value)
#define SINGLE_CHANNELSWITCH_V2_SET_BW_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 20, 4, value)
#define SET_PWR_MODE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define SET_PWR_MODE_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SET_PWR_MODE_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SET_PWR_MODE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define SET_PWR_MODE_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SET_PWR_MODE_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SET_PWR_MODE_GET_MODE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 7)
#define SET_PWR_MODE_SET_MODE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 7, value)
#define SET_PWR_MODE_SET_MODE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 7, value)
#define SET_PWR_MODE_GET_CLK_REQUEST(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
#define SET_PWR_MODE_SET_CLK_REQUEST(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
#define SET_PWR_MODE_SET_CLK_REQUEST_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
#define SET_PWR_MODE_GET_RLBM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 4)
#define SET_PWR_MODE_SET_RLBM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 4, value)
#define SET_PWR_MODE_SET_RLBM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 4, value)
#define SET_PWR_MODE_GET_SMART_PS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 20, 4)
#define SET_PWR_MODE_SET_SMART_PS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 20, 4, value)
#define SET_PWR_MODE_SET_SMART_PS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 20, 4, value)
#define SET_PWR_MODE_GET_AWAKE_INTERVAL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define SET_PWR_MODE_SET_AWAKE_INTERVAL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define SET_PWR_MODE_SET_AWAKE_INTERVAL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define SET_PWR_MODE_GET_B_ALL_QUEUE_UAPSD(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 1)
#define SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 1, value)
#define SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 1, value)
#define SET_PWR_MODE_GET_BCN_EARLY_RPT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 2, 1)
#define SET_PWR_MODE_SET_BCN_EARLY_RPT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 2, 1, value)
#define SET_PWR_MODE_SET_BCN_EARLY_RPT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 2, 1, value)
#define SET_PWR_MODE_GET_PORT_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 5, 3)
#define SET_PWR_MODE_SET_PORT_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 5, 3, value)
#define SET_PWR_MODE_SET_PORT_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 5, 3, value)
#define SET_PWR_MODE_GET_PWR_STATE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define SET_PWR_MODE_SET_PWR_STATE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define SET_PWR_MODE_SET_PWR_STATE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define SET_PWR_MODE_GET_RSVD_NOUSED(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define SET_PWR_MODE_SET_RSVD_NOUSED(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define SET_PWR_MODE_SET_RSVD_NOUSED_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define SET_PWR_MODE_GET_BCN_RECEIVING_TIME(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 24, 5)
#define SET_PWR_MODE_SET_BCN_RECEIVING_TIME(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 5, value)
#define SET_PWR_MODE_SET_BCN_RECEIVING_TIME_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 5, value)
#define SET_PWR_MODE_GET_BCN_LISTEN_INTERVAL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 29, 2)
#define SET_PWR_MODE_SET_BCN_LISTEN_INTERVAL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 29, 2, value)
#define SET_PWR_MODE_SET_BCN_LISTEN_INTERVAL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 29, 2, value)
#define SET_PWR_MODE_GET_ADOPT_BCN_RECEIVING_TIME(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 31, 1)
#define SET_PWR_MODE_SET_ADOPT_BCN_RECEIVING_TIME(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 31, 1, value)
#define SET_PWR_MODE_SET_ADOPT_BCN_RECEIVING_TIME_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 31, 1, value)
#define PS_TUNING_PARA_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define PS_TUNING_PARA_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_TUNING_PARA_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_TUNING_PARA_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define PS_TUNING_PARA_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_TUNING_PARA_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_TUNING_PARA_GET_BCN_TO_LIMIT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 7)
#define PS_TUNING_PARA_SET_BCN_TO_LIMIT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 7, value)
#define PS_TUNING_PARA_SET_BCN_TO_LIMIT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 7, value)
#define PS_TUNING_PARA_GET_DTIM_TIME_OUT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
#define PS_TUNING_PARA_SET_DTIM_TIME_OUT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
#define PS_TUNING_PARA_SET_DTIM_TIME_OUT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
#define PS_TUNING_PARA_GET_PS_TIME_OUT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 4)
#define PS_TUNING_PARA_SET_PS_TIME_OUT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 4, value)
#define PS_TUNING_PARA_SET_PS_TIME_OUT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 4, value)
#define PS_TUNING_PARA_GET_ADOPT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define PS_TUNING_PARA_SET_ADOPT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define PS_TUNING_PARA_SET_ADOPT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define PS_TUNING_PARA_II_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define PS_TUNING_PARA_II_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_TUNING_PARA_II_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_TUNING_PARA_II_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define PS_TUNING_PARA_II_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_TUNING_PARA_II_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_TUNING_PARA_II_GET_BCN_TO_PERIOD(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 7)
#define PS_TUNING_PARA_II_SET_BCN_TO_PERIOD(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 7, value)
#define PS_TUNING_PARA_II_SET_BCN_TO_PERIOD_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 7, value)
#define PS_TUNING_PARA_II_GET_ADOPT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
#define PS_TUNING_PARA_II_SET_ADOPT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
#define PS_TUNING_PARA_II_SET_ADOPT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
#define PS_TUNING_PARA_II_GET_DRV_EARLY_IVL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define PS_TUNING_PARA_II_SET_DRV_EARLY_IVL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define PS_TUNING_PARA_II_SET_DRV_EARLY_IVL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define PS_LPS_PARA_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define PS_LPS_PARA_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_LPS_PARA_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_LPS_PARA_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define PS_LPS_PARA_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_LPS_PARA_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_LPS_PARA_GET_LPS_CONTROL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define PS_LPS_PARA_SET_LPS_CONTROL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define PS_LPS_PARA_SET_LPS_CONTROL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define P2P_PS_OFFLOAD_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define P2P_PS_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define P2P_PS_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define P2P_PS_OFFLOAD_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define P2P_PS_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define P2P_PS_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define P2P_PS_OFFLOAD_GET_OFFLOAD_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define P2P_PS_OFFLOAD_SET_OFFLOAD_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define P2P_PS_OFFLOAD_SET_OFFLOAD_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define P2P_PS_OFFLOAD_GET_ROLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define P2P_PS_OFFLOAD_SET_ROLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define P2P_PS_OFFLOAD_SET_ROLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define P2P_PS_OFFLOAD_GET_CTWINDOW_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define P2P_PS_OFFLOAD_SET_CTWINDOW_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define P2P_PS_OFFLOAD_SET_CTWINDOW_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define P2P_PS_OFFLOAD_GET_NOA0_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define P2P_PS_OFFLOAD_SET_NOA0_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define P2P_PS_OFFLOAD_SET_NOA0_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define P2P_PS_OFFLOAD_GET_NOA1_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
#define P2P_PS_OFFLOAD_SET_NOA1_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
#define P2P_PS_OFFLOAD_SET_NOA1_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
#define P2P_PS_OFFLOAD_GET_ALL_STA_SLEEP(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 13, 1)
#define P2P_PS_OFFLOAD_SET_ALL_STA_SLEEP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 13, 1, value)
#define P2P_PS_OFFLOAD_SET_ALL_STA_SLEEP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 13, 1, value)
#define P2P_PS_OFFLOAD_GET_DISCOVERY(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 14, 1)
#define P2P_PS_OFFLOAD_SET_DISCOVERY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 14, 1, value)
#define P2P_PS_OFFLOAD_SET_DISCOVERY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 14, 1, value)
#define PS_SCAN_EN_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define PS_SCAN_EN_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_SCAN_EN_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define PS_SCAN_EN_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define PS_SCAN_EN_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_SCAN_EN_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define PS_SCAN_EN_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define PS_SCAN_EN_SET_ENABLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define PS_SCAN_EN_SET_ENABLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define SAP_PS_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define SAP_PS_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SAP_PS_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define SAP_PS_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define SAP_PS_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SAP_PS_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define SAP_PS_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define SAP_PS_SET_ENABLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define SAP_PS_SET_ENABLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define SAP_PS_GET_EN_PS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define SAP_PS_SET_EN_PS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define SAP_PS_SET_EN_PS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define SAP_PS_GET_EN_LP_RX(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define SAP_PS_SET_EN_LP_RX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define SAP_PS_SET_EN_LP_RX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define SAP_PS_GET_MANUAL_32K(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define SAP_PS_SET_MANUAL_32K(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define SAP_PS_SET_MANUAL_32K_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define SAP_PS_GET_DURATION(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define SAP_PS_SET_DURATION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define SAP_PS_SET_DURATION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define INACTIVE_PS_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define INACTIVE_PS_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define INACTIVE_PS_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define INACTIVE_PS_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define INACTIVE_PS_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define INACTIVE_PS_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define INACTIVE_PS_GET_ENABLE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define INACTIVE_PS_SET_ENABLE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define INACTIVE_PS_SET_ENABLE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define INACTIVE_PS_GET_IGNORE_PS_CONDITION(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define INACTIVE_PS_SET_IGNORE_PS_CONDITION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define INACTIVE_PS_SET_IGNORE_PS_CONDITION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define INACTIVE_PS_GET_FREQUENCY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define INACTIVE_PS_SET_FREQUENCY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define INACTIVE_PS_SET_FREQUENCY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define INACTIVE_PS_GET_DURATION(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define INACTIVE_PS_SET_DURATION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define INACTIVE_PS_SET_DURATION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define MACID_CFG_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define MACID_CFG_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define MACID_CFG_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define MACID_CFG_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define MACID_CFG_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define MACID_CFG_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define MACID_CFG_GET_MAC_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define MACID_CFG_SET_MAC_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define MACID_CFG_SET_MAC_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define MACID_CFG_GET_RATE_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 5)
#define MACID_CFG_SET_RATE_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 5, value)
#define MACID_CFG_SET_RATE_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 5, value)
#define MACID_CFG_GET_INIT_RATE_LV(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 21, 2)
#define MACID_CFG_SET_INIT_RATE_LV(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 21, 2, value)
#define MACID_CFG_SET_INIT_RATE_LV_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 21, 2, value)
#define MACID_CFG_GET_SGI(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 23, 1)
#define MACID_CFG_SET_SGI(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 23, 1, value)
#define MACID_CFG_SET_SGI_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 23, 1, value)
#define MACID_CFG_GET_BW(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 2)
#define MACID_CFG_SET_BW(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 2, value)
#define MACID_CFG_SET_BW_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 2, value)
#define MACID_CFG_GET_LDPC_CAP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 26, 1)
#define MACID_CFG_SET_LDPC_CAP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 26, 1, value)
#define MACID_CFG_SET_LDPC_CAP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 26, 1, value)
#define MACID_CFG_GET_NO_UPDATE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 27, 1)
#define MACID_CFG_SET_NO_UPDATE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 27, 1, value)
#define MACID_CFG_SET_NO_UPDATE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 27, 1, value)
#define MACID_CFG_GET_WHT_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 28, 2)
#define MACID_CFG_SET_WHT_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 28, 2, value)
#define MACID_CFG_SET_WHT_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 28, 2, value)
#define MACID_CFG_GET_DISPT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 30, 1)
#define MACID_CFG_SET_DISPT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 30, 1, value)
#define MACID_CFG_SET_DISPT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 30, 1, value)
#define MACID_CFG_GET_DISRA(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 31, 1)
#define MACID_CFG_SET_DISRA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 31, 1, value)
#define MACID_CFG_SET_DISRA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 31, 1, value)
#define MACID_CFG_GET_RATE_MASK7_0(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define MACID_CFG_SET_RATE_MASK7_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define MACID_CFG_SET_RATE_MASK7_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define MACID_CFG_GET_RATE_MASK15_8(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define MACID_CFG_SET_RATE_MASK15_8(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define MACID_CFG_SET_RATE_MASK15_8_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define MACID_CFG_GET_RATE_MASK23_16(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define MACID_CFG_SET_RATE_MASK23_16(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define MACID_CFG_SET_RATE_MASK23_16_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define MACID_CFG_GET_RATE_MASK31_24(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
#define MACID_CFG_SET_RATE_MASK31_24(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
#define MACID_CFG_SET_RATE_MASK31_24_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
#define TXBF_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define TXBF_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define TXBF_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define TXBF_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define TXBF_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define TXBF_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define TXBF_GET_NDPA0_HEAD_PAGE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define TXBF_SET_NDPA0_HEAD_PAGE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define TXBF_SET_NDPA0_HEAD_PAGE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define TXBF_GET_NDPA1_HEAD_PAGE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define TXBF_SET_NDPA1_HEAD_PAGE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define TXBF_SET_NDPA1_HEAD_PAGE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define TXBF_GET_PERIOD_0(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define TXBF_SET_PERIOD_0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define TXBF_SET_PERIOD_0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define RSSI_SETTING_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define RSSI_SETTING_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define RSSI_SETTING_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define RSSI_SETTING_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define RSSI_SETTING_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define RSSI_SETTING_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define RSSI_SETTING_GET_MAC_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define RSSI_SETTING_SET_MAC_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define RSSI_SETTING_SET_MAC_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define RSSI_SETTING_GET_RSSI(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 7)
#define RSSI_SETTING_SET_RSSI(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 7, value)
#define RSSI_SETTING_SET_RSSI_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 7, value)
#define RSSI_SETTING_GET_RA_INFO(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define RSSI_SETTING_SET_RA_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define RSSI_SETTING_SET_RA_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AP_REQ_TXRPT_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define AP_REQ_TXRPT_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AP_REQ_TXRPT_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AP_REQ_TXRPT_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define AP_REQ_TXRPT_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AP_REQ_TXRPT_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AP_REQ_TXRPT_GET_STA1_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define AP_REQ_TXRPT_SET_STA1_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AP_REQ_TXRPT_SET_STA1_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AP_REQ_TXRPT_GET_STA2_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define AP_REQ_TXRPT_SET_STA2_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AP_REQ_TXRPT_SET_STA2_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AP_REQ_TXRPT_GET_RTY_OK_TOTAL(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 1)
#define AP_REQ_TXRPT_SET_RTY_OK_TOTAL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 1, value)
#define AP_REQ_TXRPT_SET_RTY_OK_TOTAL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 1, value)
#define AP_REQ_TXRPT_GET_RTY_CNT_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 25, 1)
#define AP_REQ_TXRPT_SET_RTY_CNT_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 25, 1, value)
#define AP_REQ_TXRPT_SET_RTY_CNT_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 25, 1, value)
#define INIT_RATE_COLLECTION_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define INIT_RATE_COLLECTION_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define INIT_RATE_COLLECTION_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define INIT_RATE_COLLECTION_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define INIT_RATE_COLLECTION_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define INIT_RATE_COLLECTION_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define INIT_RATE_COLLECTION_GET_STA1_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define INIT_RATE_COLLECTION_SET_STA1_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define INIT_RATE_COLLECTION_SET_STA1_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define INIT_RATE_COLLECTION_GET_STA2_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define INIT_RATE_COLLECTION_SET_STA2_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define INIT_RATE_COLLECTION_SET_STA2_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define INIT_RATE_COLLECTION_GET_STA3_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define INIT_RATE_COLLECTION_SET_STA3_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define INIT_RATE_COLLECTION_SET_STA3_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define INIT_RATE_COLLECTION_GET_STA4_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define INIT_RATE_COLLECTION_SET_STA4_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define INIT_RATE_COLLECTION_SET_STA4_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define INIT_RATE_COLLECTION_GET_STA5_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define INIT_RATE_COLLECTION_SET_STA5_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define INIT_RATE_COLLECTION_SET_STA5_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define INIT_RATE_COLLECTION_GET_STA6_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define INIT_RATE_COLLECTION_SET_STA6_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define INIT_RATE_COLLECTION_SET_STA6_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define INIT_RATE_COLLECTION_GET_STA7_MACID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
#define INIT_RATE_COLLECTION_SET_STA7_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
#define INIT_RATE_COLLECTION_SET_STA7_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
#define IQK_OFFLOAD_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define IQK_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define IQK_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define IQK_OFFLOAD_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define IQK_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define IQK_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define IQK_OFFLOAD_GET_CHANNEL(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define IQK_OFFLOAD_SET_CHANNEL(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define IQK_OFFLOAD_SET_CHANNEL_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define IQK_OFFLOAD_GET_BWBAND(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define IQK_OFFLOAD_SET_BWBAND(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define IQK_OFFLOAD_SET_BWBAND_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define IQK_OFFLOAD_GET_EXTPALNA(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define IQK_OFFLOAD_SET_EXTPALNA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define IQK_OFFLOAD_SET_EXTPALNA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define MACID_CFG_3SS_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define MACID_CFG_3SS_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define MACID_CFG_3SS_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define MACID_CFG_3SS_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define MACID_CFG_3SS_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define MACID_CFG_3SS_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define MACID_CFG_3SS_GET_MACID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define MACID_CFG_3SS_SET_MACID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define MACID_CFG_3SS_SET_MACID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define MACID_CFG_3SS_GET_RATE_MASK_39_32(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define MACID_CFG_3SS_SET_RATE_MASK_39_32(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define MACID_CFG_3SS_SET_RATE_MASK_39_32_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define MACID_CFG_3SS_GET_RATE_MASK_47_40(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define MACID_CFG_3SS_SET_RATE_MASK_47_40(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define MACID_CFG_3SS_SET_RATE_MASK_47_40_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define RA_PARA_ADJUST_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define RA_PARA_ADJUST_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define RA_PARA_ADJUST_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define RA_PARA_ADJUST_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define RA_PARA_ADJUST_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define RA_PARA_ADJUST_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define RA_PARA_ADJUST_GET_MAC_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define RA_PARA_ADJUST_SET_MAC_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define RA_PARA_ADJUST_SET_MAC_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define RA_PARA_ADJUST_GET_PARAMETER_INDEX(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define RA_PARA_ADJUST_SET_PARAMETER_INDEX(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define RA_PARA_ADJUST_SET_PARAMETER_INDEX_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define RA_PARA_ADJUST_GET_RATE_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define RA_PARA_ADJUST_SET_RATE_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define RA_PARA_ADJUST_SET_RATE_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define RA_PARA_ADJUST_GET_VALUE_BYTE0(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define RA_PARA_ADJUST_SET_VALUE_BYTE0(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define RA_PARA_ADJUST_SET_VALUE_BYTE0_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define RA_PARA_ADJUST_GET_VALUE_BYTE1(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define RA_PARA_ADJUST_SET_VALUE_BYTE1(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define RA_PARA_ADJUST_SET_VALUE_BYTE1_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define RA_PARA_ADJUST_GET_ASK_FW_FOR_FW_PARA(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define RA_PARA_ADJUST_SET_ASK_FW_FOR_FW_PARA(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define RA_PARA_ADJUST_SET_ASK_FW_FOR_FW_PARA_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define WWLAN_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define WWLAN_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define WWLAN_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define WWLAN_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define WWLAN_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define WWLAN_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define WWLAN_GET_FUNC_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define WWLAN_SET_FUNC_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define WWLAN_SET_FUNC_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define WWLAN_GET_PATTERM_MAT_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define WWLAN_SET_PATTERM_MAT_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define WWLAN_SET_PATTERM_MAT_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define WWLAN_GET_MAGIC_PKT_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define WWLAN_SET_MAGIC_PKT_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define WWLAN_SET_MAGIC_PKT_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define WWLAN_GET_UNICAST_WAKEUP_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define WWLAN_SET_UNICAST_WAKEUP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define WWLAN_SET_UNICAST_WAKEUP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define WWLAN_GET_ALL_PKT_DROP(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
#define WWLAN_SET_ALL_PKT_DROP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
#define WWLAN_SET_ALL_PKT_DROP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
#define WWLAN_GET_GPIO_ACTIVE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 13, 1)
#define WWLAN_SET_GPIO_ACTIVE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 13, 1, value)
#define WWLAN_SET_GPIO_ACTIVE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 13, 1, value)
#define WWLAN_GET_REKEY_WAKEUP_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 14, 1)
#define WWLAN_SET_REKEY_WAKEUP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 14, 1, value)
#define WWLAN_SET_REKEY_WAKEUP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 14, 1, value)
#define WWLAN_GET_DEAUTH_WAKEUP_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
#define WWLAN_SET_DEAUTH_WAKEUP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
#define WWLAN_SET_DEAUTH_WAKEUP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
#define WWLAN_GET_GPIO_NUM(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 16, 7)
#define WWLAN_SET_GPIO_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 7, value)
#define WWLAN_SET_GPIO_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 7, value)
#define WWLAN_GET_DATAPIN_WAKEUP_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 23, 1)
#define WWLAN_SET_DATAPIN_WAKEUP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 23, 1, value)
#define WWLAN_SET_DATAPIN_WAKEUP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 23, 1, value)
#define WWLAN_GET_GPIO_DURATION(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define WWLAN_SET_GPIO_DURATION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define WWLAN_SET_GPIO_DURATION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define WWLAN_GET_GPIO_PLUS_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 0, 1)
#define WWLAN_SET_GPIO_PLUS_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 1, value)
#define WWLAN_SET_GPIO_PLUS_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 1, value)
#define WWLAN_GET_GPIO_PULSE_COUNT(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 1, 7)
#define WWLAN_SET_GPIO_PULSE_COUNT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 1, 7, value)
#define WWLAN_SET_GPIO_PULSE_COUNT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 1, 7, value)
#define WWLAN_GET_DISABLE_UPHY(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 8, 1)
#define WWLAN_SET_DISABLE_UPHY(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 1, value)
#define WWLAN_SET_DISABLE_UPHY_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 1, value)
#define WWLAN_GET_HST2DEV_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 9, 1)
#define WWLAN_SET_HST2DEV_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 9, 1, value)
#define WWLAN_SET_HST2DEV_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 9, 1, value)
#define WWLAN_GET_GPIO_DURATION_MS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X04, 10, 1)
#define WWLAN_SET_GPIO_DURATION_MS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 10, 1, value)
#define WWLAN_SET_GPIO_DURATION_MS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 10, 1, value)
#define REMOTE_WAKE_CTRL_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define REMOTE_WAKE_CTRL_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define REMOTE_WAKE_CTRL_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define REMOTE_WAKE_CTRL_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define REMOTE_WAKE_CTRL_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define REMOTE_WAKE_CTRL_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define REMOTE_WAKE_CTRL_GET_REMOTE_WAKE_CTRL_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define REMOTE_WAKE_CTRL_SET_REMOTE_WAKE_CTRL_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define REMOTE_WAKE_CTRL_SET_REMOTE_WAKE_CTRL_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define REMOTE_WAKE_CTRL_GET_ARP_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 9, 1)
#define REMOTE_WAKE_CTRL_SET_ARP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 9, 1, value)
#define REMOTE_WAKE_CTRL_SET_ARP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 9, 1, value)
#define REMOTE_WAKE_CTRL_GET_NDP_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 10, 1)
#define REMOTE_WAKE_CTRL_SET_NDP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 10, 1, value)
#define REMOTE_WAKE_CTRL_SET_NDP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 10, 1, value)
#define REMOTE_WAKE_CTRL_GET_GTK_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 11, 1)
#define REMOTE_WAKE_CTRL_SET_GTK_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 11, 1, value)
#define REMOTE_WAKE_CTRL_SET_GTK_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 11, 1, value)
#define REMOTE_WAKE_CTRL_GET_NLO_OFFLOAD_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 12, 1)
#define REMOTE_WAKE_CTRL_SET_NLO_OFFLOAD_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 1, value)
#define REMOTE_WAKE_CTRL_SET_NLO_OFFLOAD_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 1, value)
#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V1_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 13, 1)
#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V1_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 13, 1, value)
#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V1_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 13, 1, value)
#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V2_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 14, 1)
#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V2_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 14, 1, value)
#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V2_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 14, 1, value)
#define REMOTE_WAKE_CTRL_GET_FW_UNICAST(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 15, 1)
#define REMOTE_WAKE_CTRL_SET_FW_UNICAST(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 15, 1, value)
#define REMOTE_WAKE_CTRL_SET_FW_UNICAST_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 15, 1, value)
#define REMOTE_WAKE_CTRL_GET_P2P_OFFLOAD_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 1)
#define REMOTE_WAKE_CTRL_SET_P2P_OFFLOAD_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 1, value)
#define REMOTE_WAKE_CTRL_SET_P2P_OFFLOAD_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 1, value)
#define REMOTE_WAKE_CTRL_GET_RUNTIME_PM_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 17, 1)
#define REMOTE_WAKE_CTRL_SET_RUNTIME_PM_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 17, 1, value)
#define REMOTE_WAKE_CTRL_SET_RUNTIME_PM_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 17, 1, value)
#define REMOTE_WAKE_CTRL_GET_NET_BIOS_DROP_EN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 18, 1)
#define REMOTE_WAKE_CTRL_SET_NET_BIOS_DROP_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 18, 1, value)
#define REMOTE_WAKE_CTRL_SET_NET_BIOS_DROP_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 18, 1, value)
#define REMOTE_WAKE_CTRL_GET_ARP_ACTION(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 1)
#define REMOTE_WAKE_CTRL_SET_ARP_ACTION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 1, value)
#define REMOTE_WAKE_CTRL_SET_ARP_ACTION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 1, value)
#define REMOTE_WAKE_CTRL_GET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 28, 1)
#define REMOTE_WAKE_CTRL_SET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 28, 1, value)
#define REMOTE_WAKE_CTRL_SET_FW_PARSING_UNTIL_WAKEUP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 28, 1, value)
#define REMOTE_WAKE_CTRL_GET_FW_PARSING_AFTER_WAKEUP(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 29, 1)
#define REMOTE_WAKE_CTRL_SET_FW_PARSING_AFTER_WAKEUP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 29, 1, value)
#define REMOTE_WAKE_CTRL_SET_FW_PARSING_AFTER_WAKEUP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 29, 1, value)
#define AOAC_GLOBAL_INFO_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define AOAC_GLOBAL_INFO_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_GLOBAL_INFO_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_GLOBAL_INFO_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define AOAC_GLOBAL_INFO_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_GLOBAL_INFO_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_GLOBAL_INFO_GET_PAIR_WISE_ENC_ALG(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define AOAC_GLOBAL_INFO_SET_PAIR_WISE_ENC_ALG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_GLOBAL_INFO_SET_PAIR_WISE_ENC_ALG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_GLOBAL_INFO_GET_GROUP_ENC_ALG(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define AOAC_GLOBAL_INFO_SET_GROUP_ENC_ALG(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_GLOBAL_INFO_SET_GROUP_ENC_ALG_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define AOAC_RSVD_PAGE_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define AOAC_RSVD_PAGE_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE_GET_LOC_REMOTE_CTRL_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_ARP_RESPONSE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define AOAC_RSVD_PAGE_SET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_NEIGHBOR_ADVERTISEMENT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_GTK_RSP(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_RSP(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_RSP_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_GTK_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_GTK_EXT_MEM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_NDP_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
#define AOAC_RSVD_PAGE_SET_LOC_NDP_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
#define AOAC_RSVD_PAGE_SET_LOC_NDP_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
#define AOAC_RSVD_PAGE2_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define AOAC_RSVD_PAGE2_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE2_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE2_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define AOAC_RSVD_PAGE2_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE2_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE2_GET_LOC_ROUTER_SOLICATION(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_ROUTER_SOLICATION(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_ROUTER_SOLICATION_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_BUBBLE_PACKET(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_BUBBLE_PACKET(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_BUBBLE_PACKET_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_TEREDO_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_TEREDO_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_TEREDO_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_REALWOW_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 0, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_REALWOW_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_REALWOW_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 0, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_KEEP_ALIVE_PKT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 8, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_KEEP_ALIVE_PKT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 8, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_KEEP_ALIVE_PKT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 8, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_ACK_PATTERN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 16, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_ACK_PATTERN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 16, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_ACK_PATTERN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 16, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_WAKEUP_PATTERN(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X04, 24, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_WAKEUP_PATTERN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X04, 24, 8, value)
#define AOAC_RSVD_PAGE2_SET_LOC_WAKEUP_PATTERN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X04, 24, 8, value)
#define D0_SCAN_OFFLOAD_INFO_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define D0_SCAN_OFFLOAD_INFO_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define D0_SCAN_OFFLOAD_INFO_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define D0_SCAN_OFFLOAD_INFO_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define D0_SCAN_OFFLOAD_INFO_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define D0_SCAN_OFFLOAD_INFO_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define D0_SCAN_OFFLOAD_INFO_GET_LOC_CHANNEL_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define D0_SCAN_OFFLOAD_INFO_SET_LOC_CHANNEL_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define D0_SCAN_OFFLOAD_INFO_SET_LOC_CHANNEL_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_CMD_ID(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define CHANNEL_SWITCH_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define CHANNEL_SWITCH_OFFLOAD_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_CLASS(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define CHANNEL_SWITCH_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define CHANNEL_SWITCH_OFFLOAD_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_CHANNEL_NUM(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define CHANNEL_SWITCH_OFFLOAD_SET_CHANNEL_NUM(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_SET_CHANNEL_NUM_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_EN_RFE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define CHANNEL_SWITCH_OFFLOAD_SET_EN_RFE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_SET_EN_RFE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_RFE_TYPE(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 24, 8)
#define CHANNEL_SWITCH_OFFLOAD_SET_RFE_TYPE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 24, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_SET_RFE_TYPE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE3_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define AOAC_RSVD_PAGE3_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE3_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE3_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define AOAC_RSVD_PAGE3_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE3_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE3_GET_LOC_NLO_INFO(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 8, 8)
#define AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE3_GET_LOC_AOAC_REPORT(h2c_pkt) \
GET_H2C_FIELD(h2c_pkt + 0X00, 16, 8)
#define AOAC_RSVD_PAGE3_SET_LOC_AOAC_REPORT(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE3_SET_LOC_AOAC_REPORT_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 16, 8, value)
#define DBG_MSG_CTRL_GET_CMD_ID(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 0, 5)
#define DBG_MSG_CTRL_SET_CMD_ID(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 0, 5, value)
#define DBG_MSG_CTRL_SET_CMD_ID_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 0, 5, value)
#define DBG_MSG_CTRL_GET_CLASS(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 5, 3)
#define DBG_MSG_CTRL_SET_CLASS(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 5, 3, value)
#define DBG_MSG_CTRL_SET_CLASS_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 5, 3, value)
#define DBG_MSG_CTRL_GET_FUN_EN(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 8, 1)
#define DBG_MSG_CTRL_SET_FUN_EN(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 8, 1, value)
#define DBG_MSG_CTRL_SET_FUN_EN_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 8, 1, value)
#define DBG_MSG_CTRL_GET_MODE(h2c_pkt) GET_H2C_FIELD(h2c_pkt + 0X00, 12, 4)
#define DBG_MSG_CTRL_SET_MODE(h2c_pkt, value) \
SET_H2C_FIELD_CLR(h2c_pkt + 0X00, 12, 4, value)
#define DBG_MSG_CTRL_SET_MODE_NO_CLR(h2c_pkt, value) \
SET_H2C_FIELD_NO_CLR(h2c_pkt + 0X00, 12, 4, value)
#endif
================================================
FILE: hal/halmac/halmac_original_h2c_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HAL_ORIGINALH2CFORMAT_H2C_C2H_NIC_H_
#define _HAL_ORIGINALH2CFORMAT_H2C_C2H_NIC_H_
#define CMD_ID_ORIGINAL_H2C 0X00
#define CMD_ID_H2C2H_LB 0X0
#define CMD_ID_D0_SCAN_OFFLOAD_CTRL 0X06
#define CMD_ID_RSVD_PAGE 0X0
#define CMD_ID_MEDIA_STATUS_RPT 0X01
#define CMD_ID_KEEP_ALIVE 0X03
#define CMD_ID_DISCONNECT_DECISION 0X04
#define CMD_ID_AP_OFFLOAD 0X08
#define CMD_ID_BCN_RSVDPAGE 0X09
#define CMD_ID_PROBE_RSP_RSVDPAGE 0X0A
#define CMD_ID_SINGLE_CHANNELSWITCH 0X1C
#define CMD_ID_SINGLE_CHANNELSWITCH_V2 0X1D
#define CMD_ID_SET_PWR_MODE 0X00
#define CMD_ID_PS_TUNING_PARA 0X01
#define CMD_ID_PS_TUNING_PARA_II 0X02
#define CMD_ID_PS_LPS_PARA 0X03
#define CMD_ID_P2P_PS_OFFLOAD 0X04
#define CMD_ID_PS_SCAN_EN 0X05
#define CMD_ID_SAP_PS 0X06
#define CMD_ID_INACTIVE_PS 0X07
#define CMD_ID_MACID_CFG 0X00
#define CMD_ID_TXBF 0X01
#define CMD_ID_RSSI_SETTING 0X02
#define CMD_ID_AP_REQ_TXRPT 0X03
#define CMD_ID_INIT_RATE_COLLECTION 0X04
#define CMD_ID_IQK_OFFLOAD 0X05
#define CMD_ID_MACID_CFG_3SS 0X06
#define CMD_ID_RA_PARA_ADJUST 0X07
#define CMD_ID_WWLAN 0X00
#define CMD_ID_REMOTE_WAKE_CTRL 0X01
#define CMD_ID_AOAC_GLOBAL_INFO 0X02
#define CMD_ID_AOAC_RSVD_PAGE 0X03
#define CMD_ID_AOAC_RSVD_PAGE2 0X04
#define CMD_ID_D0_SCAN_OFFLOAD_INFO 0X05
#define CMD_ID_CHANNEL_SWITCH_OFFLOAD 0X07
#define CMD_ID_AOAC_RSVD_PAGE3 0X08
#define CMD_ID_DBG_MSG_CTRL 0X1E
#define CLASS_ORIGINAL_H2C 0X00
#define CLASS_H2C2H_LB 0X07
#define CLASS_D0_SCAN_OFFLOAD_CTRL 0X04
#define CLASS_RSVD_PAGE 0X0
#define CLASS_MEDIA_STATUS_RPT 0X0
#define CLASS_KEEP_ALIVE 0X0
#define CLASS_DISCONNECT_DECISION 0X0
#define CLASS_AP_OFFLOAD 0X0
#define CLASS_BCN_RSVDPAGE 0X0
#define CLASS_PROBE_RSP_RSVDPAGE 0X0
#define CLASS_SINGLE_CHANNELSWITCH 0X0
#define CLASS_SINGLE_CHANNELSWITCH_V2 0X0
#define CLASS_SET_PWR_MODE 0X01
#define CLASS_PS_TUNING_PARA 0X01
#define CLASS_PS_TUNING_PARA_II 0X01
#define CLASS_PS_LPS_PARA 0X01
#define CLASS_P2P_PS_OFFLOAD 0X01
#define CLASS_PS_SCAN_EN 0X1
#define CLASS_SAP_PS 0X1
#define CLASS_INACTIVE_PS 0X1
#define CLASS_MACID_CFG 0X2
#define CLASS_TXBF 0X2
#define CLASS_RSSI_SETTING 0X2
#define CLASS_AP_REQ_TXRPT 0X2
#define CLASS_INIT_RATE_COLLECTION 0X2
#define CLASS_IQK_OFFLOAD 0X2
#define CLASS_MACID_CFG_3SS 0X2
#define CLASS_RA_PARA_ADJUST 0X02
#define CLASS_WWLAN 0X4
#define CLASS_REMOTE_WAKE_CTRL 0X4
#define CLASS_AOAC_GLOBAL_INFO 0X04
#define CLASS_AOAC_RSVD_PAGE 0X04
#define CLASS_AOAC_RSVD_PAGE2 0X04
#define CLASS_D0_SCAN_OFFLOAD_INFO 0X04
#define CLASS_CHANNEL_SWITCH_OFFLOAD 0X04
#define CLASS_AOAC_RSVD_PAGE3 0X04
#define CLASS_DBG_MSG_CTRL 0X07
#define ORIGINAL_H2C_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define ORIGINAL_H2C_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define ORIGINAL_H2C_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define ORIGINAL_H2C_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define H2C2H_LB_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define H2C2H_LB_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define H2C2H_LB_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define H2C2H_LB_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define H2C2H_LB_GET_SEQ(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define H2C2H_LB_SET_SEQ(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define H2C2H_LB_GET_PAYLOAD1(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 16)
#define H2C2H_LB_SET_PAYLOAD1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 16, value)
#define H2C2H_LB_GET_PAYLOAD2(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 32)
#define H2C2H_LB_SET_PAYLOAD2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 32, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define D0_SCAN_OFFLOAD_CTRL_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define D0_SCAN_OFFLOAD_CTRL_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_D0_SCAN_FUN_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_D0_SCAN_FUN_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_RTD3FUN_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_RTD3FUN_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_U3_SCAN_FUN_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_U3_SCAN_FUN_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_NLO_FUN_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_NLO_FUN_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_IPS_DEPENDENT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
#define D0_SCAN_OFFLOAD_CTRL_SET_IPS_DEPENDENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_PROBE_PACKET(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 17)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_PROBE_PACKET(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 17, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SCAN_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SCAN_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define D0_SCAN_OFFLOAD_CTRL_GET_LOC_SSID_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define D0_SCAN_OFFLOAD_CTRL_SET_LOC_SSID_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define RSVD_PAGE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define RSVD_PAGE_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define RSVD_PAGE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define RSVD_PAGE_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define RSVD_PAGE_GET_LOC_PROBE_RSP(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define RSVD_PAGE_SET_LOC_PROBE_RSP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define RSVD_PAGE_GET_LOC_PS_POLL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define RSVD_PAGE_SET_LOC_PS_POLL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define RSVD_PAGE_GET_LOC_NULL_DATA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define RSVD_PAGE_SET_LOC_NULL_DATA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define RSVD_PAGE_GET_LOC_QOS_NULL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define RSVD_PAGE_SET_LOC_QOS_NULL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define RSVD_PAGE_GET_LOC_BT_QOS_NULL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define RSVD_PAGE_SET_LOC_BT_QOS_NULL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define RSVD_PAGE_GET_LOC_CTS2SELF(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define RSVD_PAGE_SET_LOC_CTS2SELF(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define RSVD_PAGE_GET_LOC_LTECOEX_QOSNULL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
#define RSVD_PAGE_SET_LOC_LTECOEX_QOSNULL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
#define MEDIA_STATUS_RPT_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define MEDIA_STATUS_RPT_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define MEDIA_STATUS_RPT_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define MEDIA_STATUS_RPT_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define MEDIA_STATUS_RPT_GET_OP_MODE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define MEDIA_STATUS_RPT_SET_OP_MODE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define MEDIA_STATUS_RPT_GET_MACID_IN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define MEDIA_STATUS_RPT_SET_MACID_IN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define MEDIA_STATUS_RPT_GET_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define MEDIA_STATUS_RPT_SET_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define MEDIA_STATUS_RPT_GET_MACID_END(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define MEDIA_STATUS_RPT_SET_MACID_END(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define KEEP_ALIVE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define KEEP_ALIVE_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define KEEP_ALIVE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define KEEP_ALIVE_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define KEEP_ALIVE_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define KEEP_ALIVE_SET_ENABLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define KEEP_ALIVE_GET_ADOPT_USER_SETTING(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define KEEP_ALIVE_SET_ADOPT_USER_SETTING(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define KEEP_ALIVE_GET_PKT_TYPE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define KEEP_ALIVE_SET_PKT_TYPE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define KEEP_ALIVE_GET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define KEEP_ALIVE_SET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define DISCONNECT_DECISION_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define DISCONNECT_DECISION_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define DISCONNECT_DECISION_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define DISCONNECT_DECISION_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define DISCONNECT_DECISION_GET_ENABLE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define DISCONNECT_DECISION_SET_ENABLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define DISCONNECT_DECISION_GET_ADOPT_USER_SETTING(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define DISCONNECT_DECISION_SET_ADOPT_USER_SETTING(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define DISCONNECT_DECISION_GET_DISCONNECT_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define DISCONNECT_DECISION_SET_DISCONNECT_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define DISCONNECT_DECISION_GET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define DISCONNECT_DECISION_SET_DISCON_DECISION_CHECK_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define DISCONNECT_DECISION_GET_TRY_PKT_NUM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define DISCONNECT_DECISION_SET_TRY_PKT_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define DISCONNECT_DECISION_GET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define DISCONNECT_DECISION_SET_TRY_OK_BCN_FAIL_COUNT_LIMIT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define AP_OFFLOAD_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define AP_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define AP_OFFLOAD_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define AP_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define AP_OFFLOAD_GET_ON(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define AP_OFFLOAD_SET_ON(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define AP_OFFLOAD_GET_CFG_MIFI_PLATFORM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define AP_OFFLOAD_SET_CFG_MIFI_PLATFORM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define AP_OFFLOAD_GET_LINKED(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define AP_OFFLOAD_SET_LINKED(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define AP_OFFLOAD_GET_EN_AUTO_WAKE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define AP_OFFLOAD_SET_EN_AUTO_WAKE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define AP_OFFLOAD_GET_WAKE_FLAG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
#define AP_OFFLOAD_SET_WAKE_FLAG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_ROOT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 1)
#define AP_OFFLOAD_SET_HIDDEN_ROOT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 17, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 17, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 18, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 18, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 19, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 19, 1, value)
#define AP_OFFLOAD_GET_HIDDEN_VAP4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 20, 1)
#define AP_OFFLOAD_SET_HIDDEN_VAP4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 20, 1, value)
#define AP_OFFLOAD_GET_DENYANY_ROOT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 1)
#define AP_OFFLOAD_SET_DENYANY_ROOT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 25, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 25, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 26, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 26, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 27, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 27, 1, value)
#define AP_OFFLOAD_GET_DENYANY_VAP4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 28, 1)
#define AP_OFFLOAD_SET_DENYANY_VAP4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 28, 1, value)
#define AP_OFFLOAD_GET_WAIT_TBTT_CNT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define AP_OFFLOAD_SET_WAIT_TBTT_CNT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define AP_OFFLOAD_GET_WAKE_TIMEOUT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define AP_OFFLOAD_SET_WAKE_TIMEOUT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define AP_OFFLOAD_GET_LEN_IV_PAIR(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define AP_OFFLOAD_SET_LEN_IV_PAIR(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define AP_OFFLOAD_GET_LEN_IV_GRP(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
#define AP_OFFLOAD_SET_LEN_IV_GRP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
#define BCN_RSVDPAGE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define BCN_RSVDPAGE_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define BCN_RSVDPAGE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define BCN_RSVDPAGE_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define BCN_RSVDPAGE_GET_LOC_ROOT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define BCN_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define BCN_RSVDPAGE_GET_LOC_VAP4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define BCN_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define PROBE_RSP_RSVDPAGE_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define PROBE_RSP_RSVDPAGE_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define PROBE_RSP_RSVDPAGE_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_ROOT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_ROOT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP2(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP2(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP3(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP3(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define PROBE_RSP_RSVDPAGE_GET_LOC_VAP4(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define PROBE_RSP_RSVDPAGE_SET_LOC_VAP4(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define SINGLE_CHANNELSWITCH_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define SINGLE_CHANNELSWITCH_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define SINGLE_CHANNELSWITCH_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define SINGLE_CHANNELSWITCH_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define SINGLE_CHANNELSWITCH_GET_CHANNEL_NUM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define SINGLE_CHANNELSWITCH_SET_CHANNEL_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define SINGLE_CHANNELSWITCH_GET_BW(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 2)
#define SINGLE_CHANNELSWITCH_SET_BW(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 2, value)
#define SINGLE_CHANNELSWITCH_GET_BW40SC(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 18, 3)
#define SINGLE_CHANNELSWITCH_SET_BW40SC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 18, 3, value)
#define SINGLE_CHANNELSWITCH_GET_BW80SC(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 21, 3)
#define SINGLE_CHANNELSWITCH_SET_BW80SC(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 21, 3, value)
#define SINGLE_CHANNELSWITCH_GET_RFE_TYPE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 4)
#define SINGLE_CHANNELSWITCH_SET_RFE_TYPE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 4, value)
#define SINGLE_CHANNELSWITCH_V2_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define SINGLE_CHANNELSWITCH_V2_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define SINGLE_CHANNELSWITCH_V2_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define SINGLE_CHANNELSWITCH_V2_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define SINGLE_CHANNELSWITCH_V2_GET_CENTRAL_CH(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define SINGLE_CHANNELSWITCH_V2_SET_CENTRAL_CH(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define SINGLE_CHANNELSWITCH_V2_GET_PRIMARY_CH_IDX(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 4)
#define SINGLE_CHANNELSWITCH_V2_SET_PRIMARY_CH_IDX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 4, value)
#define SINGLE_CHANNELSWITCH_V2_GET_BW(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 20, 4)
#define SINGLE_CHANNELSWITCH_V2_SET_BW(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 20, 4, value)
#define SET_PWR_MODE_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define SET_PWR_MODE_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define SET_PWR_MODE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define SET_PWR_MODE_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define SET_PWR_MODE_GET_MODE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 7)
#define SET_PWR_MODE_SET_MODE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 7, value)
#define SET_PWR_MODE_GET_CLK_REQUEST(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
#define SET_PWR_MODE_SET_CLK_REQUEST(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
#define SET_PWR_MODE_GET_RLBM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 4)
#define SET_PWR_MODE_SET_RLBM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 4, value)
#define SET_PWR_MODE_GET_SMART_PS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 20, 4)
#define SET_PWR_MODE_SET_SMART_PS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 20, 4, value)
#define SET_PWR_MODE_GET_AWAKE_INTERVAL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define SET_PWR_MODE_SET_AWAKE_INTERVAL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define SET_PWR_MODE_GET_B_ALL_QUEUE_UAPSD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 1)
#define SET_PWR_MODE_SET_B_ALL_QUEUE_UAPSD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 1, value)
#define SET_PWR_MODE_GET_BCN_EARLY_RPT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 2, 1)
#define SET_PWR_MODE_SET_BCN_EARLY_RPT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 2, 1, value)
#define SET_PWR_MODE_GET_PORT_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 5, 3)
#define SET_PWR_MODE_SET_PORT_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 5, 3, value)
#define SET_PWR_MODE_GET_PWR_STATE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define SET_PWR_MODE_SET_PWR_STATE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define SET_PWR_MODE_GET_RSVD_NOUSED(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define SET_PWR_MODE_SET_RSVD_NOUSED(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define SET_PWR_MODE_GET_BCN_RECEIVING_TIME(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 5)
#define SET_PWR_MODE_SET_BCN_RECEIVING_TIME(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 5, value)
#define SET_PWR_MODE_GET_BCN_LISTEN_INTERVAL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 29, 2)
#define SET_PWR_MODE_SET_BCN_LISTEN_INTERVAL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 29, 2, value)
#define SET_PWR_MODE_GET_ADOPT_BCN_RECEIVING_TIME(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 31, 1)
#define SET_PWR_MODE_SET_ADOPT_BCN_RECEIVING_TIME(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 31, 1, value)
#define PS_TUNING_PARA_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define PS_TUNING_PARA_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define PS_TUNING_PARA_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define PS_TUNING_PARA_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define PS_TUNING_PARA_GET_BCN_TO_LIMIT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 7)
#define PS_TUNING_PARA_SET_BCN_TO_LIMIT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 7, value)
#define PS_TUNING_PARA_GET_DTIM_TIME_OUT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
#define PS_TUNING_PARA_SET_DTIM_TIME_OUT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
#define PS_TUNING_PARA_GET_PS_TIME_OUT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 4)
#define PS_TUNING_PARA_SET_PS_TIME_OUT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 4, value)
#define PS_TUNING_PARA_GET_ADOPT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define PS_TUNING_PARA_SET_ADOPT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define PS_TUNING_PARA_II_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define PS_TUNING_PARA_II_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define PS_TUNING_PARA_II_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define PS_TUNING_PARA_II_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define PS_TUNING_PARA_II_GET_BCN_TO_PERIOD(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 7)
#define PS_TUNING_PARA_II_SET_BCN_TO_PERIOD(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 7, value)
#define PS_TUNING_PARA_II_GET_ADOPT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
#define PS_TUNING_PARA_II_SET_ADOPT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
#define PS_TUNING_PARA_II_GET_DRV_EARLY_IVL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define PS_TUNING_PARA_II_SET_DRV_EARLY_IVL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define PS_LPS_PARA_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define PS_LPS_PARA_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define PS_LPS_PARA_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define PS_LPS_PARA_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define PS_LPS_PARA_GET_LPS_CONTROL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define PS_LPS_PARA_SET_LPS_CONTROL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define P2P_PS_OFFLOAD_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define P2P_PS_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define P2P_PS_OFFLOAD_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define P2P_PS_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define P2P_PS_OFFLOAD_GET_OFFLOAD_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define P2P_PS_OFFLOAD_SET_OFFLOAD_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define P2P_PS_OFFLOAD_GET_ROLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define P2P_PS_OFFLOAD_SET_ROLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define P2P_PS_OFFLOAD_GET_CTWINDOW_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define P2P_PS_OFFLOAD_SET_CTWINDOW_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define P2P_PS_OFFLOAD_GET_NOA0_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define P2P_PS_OFFLOAD_SET_NOA0_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define P2P_PS_OFFLOAD_GET_NOA1_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
#define P2P_PS_OFFLOAD_SET_NOA1_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
#define P2P_PS_OFFLOAD_GET_ALL_STA_SLEEP(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 13, 1)
#define P2P_PS_OFFLOAD_SET_ALL_STA_SLEEP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 13, 1, value)
#define P2P_PS_OFFLOAD_GET_DISCOVERY(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 14, 1)
#define P2P_PS_OFFLOAD_SET_DISCOVERY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 14, 1, value)
#define PS_SCAN_EN_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define PS_SCAN_EN_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define PS_SCAN_EN_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define PS_SCAN_EN_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define PS_SCAN_EN_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define PS_SCAN_EN_SET_ENABLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define SAP_PS_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define SAP_PS_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define SAP_PS_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define SAP_PS_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define SAP_PS_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define SAP_PS_SET_ENABLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define SAP_PS_GET_EN_PS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define SAP_PS_SET_EN_PS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define SAP_PS_GET_EN_LP_RX(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define SAP_PS_SET_EN_LP_RX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define SAP_PS_GET_MANUAL_32K(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define SAP_PS_SET_MANUAL_32K(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define SAP_PS_GET_DURATION(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define SAP_PS_SET_DURATION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define INACTIVE_PS_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define INACTIVE_PS_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define INACTIVE_PS_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define INACTIVE_PS_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define INACTIVE_PS_GET_ENABLE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define INACTIVE_PS_SET_ENABLE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define INACTIVE_PS_GET_IGNORE_PS_CONDITION(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define INACTIVE_PS_SET_IGNORE_PS_CONDITION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define INACTIVE_PS_GET_FREQUENCY(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define INACTIVE_PS_SET_FREQUENCY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define INACTIVE_PS_GET_DURATION(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define INACTIVE_PS_SET_DURATION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define MACID_CFG_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define MACID_CFG_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define MACID_CFG_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define MACID_CFG_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define MACID_CFG_GET_MAC_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define MACID_CFG_SET_MAC_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define MACID_CFG_GET_RATE_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 5)
#define MACID_CFG_SET_RATE_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 5, value)
#define MACID_CFG_GET_INIT_RATE_LV(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 21, 2)
#define MACID_CFG_SET_INIT_RATE_LV(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 21, 2, value)
#define MACID_CFG_GET_SGI(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 23, 1)
#define MACID_CFG_SET_SGI(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 23, 1, value)
#define MACID_CFG_GET_BW(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 2)
#define MACID_CFG_SET_BW(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 2, value)
#define MACID_CFG_GET_LDPC_CAP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 26, 1)
#define MACID_CFG_SET_LDPC_CAP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 26, 1, value)
#define MACID_CFG_GET_NO_UPDATE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 27, 1)
#define MACID_CFG_SET_NO_UPDATE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 27, 1, value)
#define MACID_CFG_GET_WHT_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 28, 2)
#define MACID_CFG_SET_WHT_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 28, 2, value)
#define MACID_CFG_GET_DISPT(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 30, 1)
#define MACID_CFG_SET_DISPT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 30, 1, value)
#define MACID_CFG_GET_DISRA(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 31, 1)
#define MACID_CFG_SET_DISRA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 31, 1, value)
#define MACID_CFG_GET_RATE_MASK7_0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define MACID_CFG_SET_RATE_MASK7_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define MACID_CFG_GET_RATE_MASK15_8(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define MACID_CFG_SET_RATE_MASK15_8(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define MACID_CFG_GET_RATE_MASK23_16(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define MACID_CFG_SET_RATE_MASK23_16(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define MACID_CFG_GET_RATE_MASK31_24(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
#define MACID_CFG_SET_RATE_MASK31_24(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
#define TXBF_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define TXBF_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define TXBF_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define TXBF_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define TXBF_GET_NDPA0_HEAD_PAGE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define TXBF_SET_NDPA0_HEAD_PAGE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define TXBF_GET_NDPA1_HEAD_PAGE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define TXBF_SET_NDPA1_HEAD_PAGE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define TXBF_GET_PERIOD_0(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define TXBF_SET_PERIOD_0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define RSSI_SETTING_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define RSSI_SETTING_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define RSSI_SETTING_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define RSSI_SETTING_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define RSSI_SETTING_GET_MAC_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define RSSI_SETTING_SET_MAC_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define RSSI_SETTING_GET_RSSI(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 7)
#define RSSI_SETTING_SET_RSSI(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 7, value)
#define RSSI_SETTING_GET_RA_INFO(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define RSSI_SETTING_SET_RA_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define AP_REQ_TXRPT_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define AP_REQ_TXRPT_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define AP_REQ_TXRPT_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define AP_REQ_TXRPT_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define AP_REQ_TXRPT_GET_STA1_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define AP_REQ_TXRPT_SET_STA1_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define AP_REQ_TXRPT_GET_STA2_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define AP_REQ_TXRPT_SET_STA2_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define AP_REQ_TXRPT_GET_RTY_OK_TOTAL(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 1)
#define AP_REQ_TXRPT_SET_RTY_OK_TOTAL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 1, value)
#define AP_REQ_TXRPT_GET_RTY_CNT_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 25, 1)
#define AP_REQ_TXRPT_SET_RTY_CNT_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 25, 1, value)
#define INIT_RATE_COLLECTION_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define INIT_RATE_COLLECTION_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define INIT_RATE_COLLECTION_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define INIT_RATE_COLLECTION_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define INIT_RATE_COLLECTION_GET_STA1_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define INIT_RATE_COLLECTION_SET_STA1_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define INIT_RATE_COLLECTION_GET_STA2_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define INIT_RATE_COLLECTION_SET_STA2_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define INIT_RATE_COLLECTION_GET_STA3_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define INIT_RATE_COLLECTION_SET_STA3_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define INIT_RATE_COLLECTION_GET_STA4_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define INIT_RATE_COLLECTION_SET_STA4_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define INIT_RATE_COLLECTION_GET_STA5_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define INIT_RATE_COLLECTION_SET_STA5_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define INIT_RATE_COLLECTION_GET_STA6_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define INIT_RATE_COLLECTION_SET_STA6_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define INIT_RATE_COLLECTION_GET_STA7_MACID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
#define INIT_RATE_COLLECTION_SET_STA7_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
#define IQK_OFFLOAD_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define IQK_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define IQK_OFFLOAD_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define IQK_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define IQK_OFFLOAD_GET_CHANNEL(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define IQK_OFFLOAD_SET_CHANNEL(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define IQK_OFFLOAD_GET_BWBAND(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define IQK_OFFLOAD_SET_BWBAND(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define IQK_OFFLOAD_GET_EXTPALNA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define IQK_OFFLOAD_SET_EXTPALNA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define MACID_CFG_3SS_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define MACID_CFG_3SS_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define MACID_CFG_3SS_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define MACID_CFG_3SS_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define MACID_CFG_3SS_GET_MACID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define MACID_CFG_3SS_SET_MACID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define MACID_CFG_3SS_GET_RATE_MASK_39_32(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define MACID_CFG_3SS_SET_RATE_MASK_39_32(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define MACID_CFG_3SS_GET_RATE_MASK_47_40(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define MACID_CFG_3SS_SET_RATE_MASK_47_40(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define RA_PARA_ADJUST_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define RA_PARA_ADJUST_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define RA_PARA_ADJUST_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define RA_PARA_ADJUST_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define RA_PARA_ADJUST_GET_MAC_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define RA_PARA_ADJUST_SET_MAC_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define RA_PARA_ADJUST_GET_PARAMETER_INDEX(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define RA_PARA_ADJUST_SET_PARAMETER_INDEX(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define RA_PARA_ADJUST_GET_RATE_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define RA_PARA_ADJUST_SET_RATE_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define RA_PARA_ADJUST_GET_VALUE_BYTE0(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define RA_PARA_ADJUST_SET_VALUE_BYTE0(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define RA_PARA_ADJUST_GET_VALUE_BYTE1(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define RA_PARA_ADJUST_SET_VALUE_BYTE1(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define RA_PARA_ADJUST_GET_ASK_FW_FOR_FW_PARA(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define RA_PARA_ADJUST_SET_ASK_FW_FOR_FW_PARA(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define WWLAN_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define WWLAN_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define WWLAN_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define WWLAN_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define WWLAN_GET_FUNC_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define WWLAN_SET_FUNC_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define WWLAN_GET_PATTERM_MAT_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define WWLAN_SET_PATTERM_MAT_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define WWLAN_GET_MAGIC_PKT_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define WWLAN_SET_MAGIC_PKT_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define WWLAN_GET_UNICAST_WAKEUP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define WWLAN_SET_UNICAST_WAKEUP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define WWLAN_GET_ALL_PKT_DROP(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
#define WWLAN_SET_ALL_PKT_DROP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
#define WWLAN_GET_GPIO_ACTIVE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 13, 1)
#define WWLAN_SET_GPIO_ACTIVE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 13, 1, value)
#define WWLAN_GET_REKEY_WAKEUP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 14, 1)
#define WWLAN_SET_REKEY_WAKEUP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 14, 1, value)
#define WWLAN_GET_DEAUTH_WAKEUP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
#define WWLAN_SET_DEAUTH_WAKEUP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
#define WWLAN_GET_GPIO_NUM(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 7)
#define WWLAN_SET_GPIO_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 7, value)
#define WWLAN_GET_DATAPIN_WAKEUP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 23, 1)
#define WWLAN_SET_DATAPIN_WAKEUP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 23, 1, value)
#define WWLAN_GET_GPIO_DURATION(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define WWLAN_SET_GPIO_DURATION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define WWLAN_GET_GPIO_PLUS_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 1)
#define WWLAN_SET_GPIO_PLUS_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 1, value)
#define WWLAN_GET_GPIO_PULSE_COUNT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 1, 7)
#define WWLAN_SET_GPIO_PULSE_COUNT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 1, 7, value)
#define WWLAN_GET_DISABLE_UPHY(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 1)
#define WWLAN_SET_DISABLE_UPHY(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 1, value)
#define WWLAN_GET_HST2DEV_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 9, 1)
#define WWLAN_SET_HST2DEV_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 9, 1, value)
#define WWLAN_GET_GPIO_DURATION_MS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 10, 1)
#define WWLAN_SET_GPIO_DURATION_MS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 10, 1, value)
#define REMOTE_WAKE_CTRL_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define REMOTE_WAKE_CTRL_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define REMOTE_WAKE_CTRL_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define REMOTE_WAKE_CTRL_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define REMOTE_WAKE_CTRL_GET_REMOTE_WAKE_CTRL_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define REMOTE_WAKE_CTRL_SET_REMOTE_WAKE_CTRL_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define REMOTE_WAKE_CTRL_GET_ARP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 9, 1)
#define REMOTE_WAKE_CTRL_SET_ARP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 9, 1, value)
#define REMOTE_WAKE_CTRL_GET_NDP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 10, 1)
#define REMOTE_WAKE_CTRL_SET_NDP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 10, 1, value)
#define REMOTE_WAKE_CTRL_GET_GTK_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 11, 1)
#define REMOTE_WAKE_CTRL_SET_GTK_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 11, 1, value)
#define REMOTE_WAKE_CTRL_GET_NLO_OFFLOAD_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 1)
#define REMOTE_WAKE_CTRL_SET_NLO_OFFLOAD_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 1, value)
#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V1_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 13, 1)
#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V1_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 13, 1, value)
#define REMOTE_WAKE_CTRL_GET_REAL_WOW_V2_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 14, 1)
#define REMOTE_WAKE_CTRL_SET_REAL_WOW_V2_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 14, 1, value)
#define REMOTE_WAKE_CTRL_GET_FW_UNICAST(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 15, 1)
#define REMOTE_WAKE_CTRL_SET_FW_UNICAST(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 15, 1, value)
#define REMOTE_WAKE_CTRL_GET_P2P_OFFLOAD_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 1)
#define REMOTE_WAKE_CTRL_SET_P2P_OFFLOAD_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 1, value)
#define REMOTE_WAKE_CTRL_GET_RUNTIME_PM_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 17, 1)
#define REMOTE_WAKE_CTRL_SET_RUNTIME_PM_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 17, 1, value)
#define REMOTE_WAKE_CTRL_GET_NET_BIOS_DROP_EN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 18, 1)
#define REMOTE_WAKE_CTRL_SET_NET_BIOS_DROP_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 18, 1, value)
#define REMOTE_WAKE_CTRL_GET_ARP_ACTION(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 1)
#define REMOTE_WAKE_CTRL_SET_ARP_ACTION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 1, value)
#define REMOTE_WAKE_CTRL_GET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 28, 1)
#define REMOTE_WAKE_CTRL_SET_FW_PARSING_UNTIL_WAKEUP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 28, 1, value)
#define REMOTE_WAKE_CTRL_GET_FW_PARSING_AFTER_WAKEUP(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 29, 1)
#define REMOTE_WAKE_CTRL_SET_FW_PARSING_AFTER_WAKEUP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 29, 1, value)
#define AOAC_GLOBAL_INFO_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define AOAC_GLOBAL_INFO_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_GLOBAL_INFO_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define AOAC_GLOBAL_INFO_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_GLOBAL_INFO_GET_PAIR_WISE_ENC_ALG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define AOAC_GLOBAL_INFO_SET_PAIR_WISE_ENC_ALG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_GLOBAL_INFO_GET_GROUP_ENC_ALG(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define AOAC_GLOBAL_INFO_SET_GROUP_ENC_ALG(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define AOAC_RSVD_PAGE_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define AOAC_RSVD_PAGE_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE_GET_LOC_REMOTE_CTRL_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define AOAC_RSVD_PAGE_SET_LOC_REMOTE_CTRL_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_ARP_RESPONSE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define AOAC_RSVD_PAGE_SET_LOC_ARP_RESPONSE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define AOAC_RSVD_PAGE_SET_LOC_NEIGHBOR_ADVERTISEMENT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_GTK_RSP(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_RSP(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_GTK_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_GTK_EXT_MEM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define AOAC_RSVD_PAGE_SET_LOC_GTK_EXT_MEM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define AOAC_RSVD_PAGE_GET_LOC_NDP_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
#define AOAC_RSVD_PAGE_SET_LOC_NDP_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
#define AOAC_RSVD_PAGE2_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define AOAC_RSVD_PAGE2_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE2_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define AOAC_RSVD_PAGE2_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE2_GET_LOC_ROUTER_SOLICATION(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_ROUTER_SOLICATION(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_BUBBLE_PACKET(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_BUBBLE_PACKET(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_TEREDO_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_TEREDO_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_REALWOW_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 0, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_REALWOW_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 0, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_KEEP_ALIVE_PKT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 8, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_KEEP_ALIVE_PKT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 8, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_ACK_PATTERN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 16, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_ACK_PATTERN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 16, 8, value)
#define AOAC_RSVD_PAGE2_GET_LOC_WAKEUP_PATTERN(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X04, 24, 8)
#define AOAC_RSVD_PAGE2_SET_LOC_WAKEUP_PATTERN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X04, 24, 8, value)
#define D0_SCAN_OFFLOAD_INFO_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define D0_SCAN_OFFLOAD_INFO_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define D0_SCAN_OFFLOAD_INFO_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define D0_SCAN_OFFLOAD_INFO_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define D0_SCAN_OFFLOAD_INFO_GET_LOC_CHANNEL_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define D0_SCAN_OFFLOAD_INFO_SET_LOC_CHANNEL_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define CHANNEL_SWITCH_OFFLOAD_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define CHANNEL_SWITCH_OFFLOAD_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_CHANNEL_NUM(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define CHANNEL_SWITCH_OFFLOAD_SET_CHANNEL_NUM(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_EN_RFE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define CHANNEL_SWITCH_OFFLOAD_SET_EN_RFE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define CHANNEL_SWITCH_OFFLOAD_GET_RFE_TYPE(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 24, 8)
#define CHANNEL_SWITCH_OFFLOAD_SET_RFE_TYPE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 24, 8, value)
#define AOAC_RSVD_PAGE3_GET_CMD_ID(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define AOAC_RSVD_PAGE3_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define AOAC_RSVD_PAGE3_GET_CLASS(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define AOAC_RSVD_PAGE3_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define AOAC_RSVD_PAGE3_GET_LOC_NLO_INFO(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 8)
#define AOAC_RSVD_PAGE3_SET_LOC_NLO_INFO(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 8, value)
#define AOAC_RSVD_PAGE3_GET_LOC_AOAC_REPORT(h2c_pkt) \
LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 16, 8)
#define AOAC_RSVD_PAGE3_SET_LOC_AOAC_REPORT(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 16, 8, value)
#define DBG_MSG_CTRL_GET_CMD_ID(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 0, 5)
#define DBG_MSG_CTRL_SET_CMD_ID(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 0, 5, value)
#define DBG_MSG_CTRL_GET_CLASS(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 5, 3)
#define DBG_MSG_CTRL_SET_CLASS(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 5, 3, value)
#define DBG_MSG_CTRL_GET_FUN_EN(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 8, 1)
#define DBG_MSG_CTRL_SET_FUN_EN(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 8, 1, value)
#define DBG_MSG_CTRL_GET_MODE(h2c_pkt) LE_BITS_TO_4BYTE(h2c_pkt + 0X00, 12, 4)
#define DBG_MSG_CTRL_SET_MODE(h2c_pkt, value) \
SET_BITS_TO_LE_4BYTE(h2c_pkt + 0X00, 12, 4, value)
#endif
================================================
FILE: hal/halmac/halmac_pcie_reg.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __HALMAC_PCIE_REG_H__
#define __HALMAC_PCIE_REG_H__
/* PCIE PHY register */
#define RAC_CTRL_PPR 0x00
#define RAC_SET_PPR 0x20
#define RAC_TRG_PPR 0x21
#define RAC_CTRL_PPR_V1 0x30
#define RAC_SET_PPR_V1 0x31
/* PCIE CFG register */
#define PCIE_L1SS_CTRL 0x718
#define PCIE_L1_CTRL 0x719
#define PCIE_ASPM_CTRL 0x70F
#define PCIE_CLK_CTRL 0x725
#define PCIE_L1SS_CAP 0x160
#define PCIE_L1SS_SUP 0x164
#define PCIE_L1SS_STS 0x168
/* PCIE CFG bit */
#define PCIE_BIT_WAKE BIT(2)
#define PCIE_BIT_L1 BIT(3)
#define PCIE_BIT_CLK BIT(4)
#define PCIE_BIT_L0S BIT(7)
#define PCIE_BIT_L1SS BIT(5)
#define PCIE_BIT_L1SSSUP BIT(4)
/* PCIE ASPM mask*/
#define SHFT_L1DLY 3
#define SHFT_L0SDLY 0
#define PCIE_ASPMDLY_MASK 0x07
#define PCIE_L1SS_MASK 0x0F
/* PCIE Capability */
#define PCIE_L1SS_ID 0x001E
/* PCIE MAC register */
#define LINK_CTRL2_REG_OFFSET 0xA0
#define GEN2_CTRL_OFFSET 0x80C
#define LINK_STATUS_REG_OFFSET 0x82
#define PCIE_GEN1_SPEED 0x01
#define PCIE_GEN2_SPEED 0x02
#endif/* __HALMAC_PCIE_REG_H__ */
================================================
FILE: hal/halmac/halmac_pwr_seq_cmd.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef HALMAC_POWER_SEQUENCE_CMD
#define HALMAC_POWER_SEQUENCE_CMD
#include "halmac_2_platform.h"
#define HALMAC_PWR_POLLING_CNT 20000
/* The value of cmd : 4 bits */
/* offset : the read register offset
* msk : the mask of the read value
* value : N/A, left by 0
* Note : dirver shall implement this function by read & msk
*/
#define HALMAC_PWR_CMD_READ 0x00
/* offset: the read register offset
* msk: the mask of the write bits
* value: write value
* Note: driver shall implement this cmd by read & msk after write
*/
#define HALMAC_PWR_CMD_WRITE 0x01
/* offset: the read register offset
* msk: the mask of the polled value
* value: the value to be polled, masked by the msd field.
* Note: driver shall implement this cmd by
* do{
* if( (Read(offset) & msk) == (value & msk) )
* break;
* } while(not timeout);
*/
#define HALMAC_PWR_CMD_POLLING 0x02
/* offset: the value to delay
* msk: N/A
* value: the unit of delay, 0: us, 1: ms
*/
#define HALMAC_PWR_CMD_DELAY 0x03
/* offset: N/A
* msk: N/A
* value: N/A
*/
#define HALMAC_PWR_CMD_END 0x04
/* The value of base : 4 bits */
/* define the base address of each block */
#define HALMAC_PWR_ADDR_MAC 0x00
#define HALMAC_PWR_ADDR_USB 0x01
#define HALMAC_PWR_ADDR_PCIE 0x02
#define HALMAC_PWR_ADDR_SDIO 0x03
/* The value of interface_msk : 4 bits */
#define HALMAC_PWR_INTF_SDIO_MSK BIT(0)
#define HALMAC_PWR_INTF_USB_MSK BIT(1)
#define HALMAC_PWR_INTF_PCI_MSK BIT(2)
#define HALMAC_PWR_INTF_ALL_MSK (BIT(0) | BIT(1) | BIT(2) | BIT(3))
/* The value of cut_msk : 8 bits */
#define HALMAC_PWR_CUT_TESTCHIP_MSK BIT(0)
#define HALMAC_PWR_CUT_A_MSK BIT(1)
#define HALMAC_PWR_CUT_B_MSK BIT(2)
#define HALMAC_PWR_CUT_C_MSK BIT(3)
#define HALMAC_PWR_CUT_D_MSK BIT(4)
#define HALMAC_PWR_CUT_E_MSK BIT(5)
#define HALMAC_PWR_CUT_F_MSK BIT(6)
#define HALMAC_PWR_CUT_G_MSK BIT(7)
#define HALMAC_PWR_CUT_ALL_MSK 0xFF
enum halmac_pwrseq_cmd_delay_unit {
HALMAC_PWR_DELAY_US,
HALMAC_PWR_DELAY_MS,
};
struct halmac_wlan_pwr_cfg {
u16 offset;
u8 cut_msk;
u8 interface_msk;
u8 base:4;
u8 cmd:4;
u8 msk;
u8 value;
};
#endif
================================================
FILE: hal/halmac/halmac_reg2.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __HALMAC_COM_REG_H__
#define __HALMAC_COM_REG_H__
#include "halmac_hw_cfg.h"
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_ISO_CTRL 0x0000
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_TX_CTRL 0x10250000
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_FUNC_EN 0x0002
#define REG_SYS_PW_CTRL 0x0004
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_CMD11_VOL_SWITCH 0x10250004
#define REG_SDIO_CTRL 0x10250005
#define REG_SDIO_DRIVING 0x10250006
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_CLK_CTRL 0x0008
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_MONITOR 0x10250008
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_EEPROM_CTRL 0x000A
#define REG_EE_VPD 0x000C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_MONITOR_2 0x1025000C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_SWR_CTRL1 0x0010
#define REG_SYS_SWR_CTRL2 0x0014
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_HIMR 0x10250014
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_SWR_CTRL3 0x0018
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_HISR 0x10250018
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RSV_CTRL 0x001C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_RX_REQ_LEN 0x1025001C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RF_CTRL 0x001F
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_RF0_CTRL 0x001F
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_FREE_TXPG_SEQ_V1 0x1025001F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AFE_LDO_CTRL 0x0020
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_FREE_TXPG 0x10250020
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AFE_CTRL1 0x0024
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_FREE_TXPG2 0x10250024
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AFE_CTRL2 0x0028
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_OQT_FREE_TXPG_V1 0x10250028
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPARSW_POW_MAC 0x0028
#define REG_ANAPARLDO_POW_MAC 0x0029
#define REG_ANAPAR_POW_MAC 0x002A
#define REG_ANAPAR_POW_XTAL 0x002B
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AFE_CTRL3 0x002C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPARLDO_MAC 0x002C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_TXPKT_EMPTY 0x1025002C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_EFUSE_CTRL 0x0030
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_HTSFR_INFO 0x10250030
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_LDO_EFUSE_CTRL 0x0034
#define REG_PWR_OPTION_CTRL 0x0038
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_HCPWM1_V2 0x10250038
#define REG_SDIO_HCPWM2_V2 0x1025003A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_CAL_TIMER 0x003C
#define REG_ACLK_MON 0x003E
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_GPIO_MUXCFG_2 0x003F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_GPIO_MUXCFG 0x0040
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_INDIRECT_REG_CFG 0x10250040
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_GPIO_PIN_CTRL 0x0044
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_INDIRECT_REG_DATA 0x10250044
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_GPIO_INTM 0x0048
#define REG_LED_CFG 0x004C
#define REG_FSIMR 0x0050
#define REG_FSISR 0x0054
#define REG_HSIMR 0x0058
#define REG_HSISR 0x005C
#define REG_GPIO_EXT_CTRL 0x0060
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_H2C 0x10250060
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PAD_CTRL1 0x0064
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_C2H 0x10250064
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_WL_BT_PWR_CTRL 0x0068
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_SDM_DEBUG 0x006C
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_GSSR 0x006C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_SYS_SDIO_CTRL 0x0070
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_SYS_CLKR 0x0070
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_HCI_OPT_CTRL 0x0074
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_AFE_CTRL4 0x0078
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HCI_BG_CTRL 0x0078
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_AFE_XTAL_CTRL_EXT 0x0078
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HCI_LDO_CTRL 0x007A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_LDO_SWR_CTRL 0x007C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_8051FW_CTRL 0x0080
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MCUFW_CTRL 0x0080
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_HRPWM1 0x10250080
#define REG_SDIO_HRPWM2 0x10250082
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_MCU_TST_CFG 0x0084
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_HPS_CLKR 0x10250084
#define REG_SDIO_BUS_CTRL 0x10250085
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_HSUS_CTRL 0x10250086
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_HMEBOX_E0_E1 0x0088
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_RESPONSE_TIMER 0x10250088
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_CMD_CRC 0x1025008A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_HMEBOX_E2_E3 0x008C
#define REG_WLLPS_CTRL 0x0090
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_HSISR 0x10250090
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_HSIMR 0x10250091
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_AFE_CTRL5 0x0094
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_GPIO_DEBOUNCE_CTRL 0x0098
#define REG_RPWM2 0x009C
#define REG_SYSON_FSM_MON 0x00A0
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_AFE_CTRL6 0x00A4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PMC_DBG_CTRL1 0x00A8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_AFE_CTRL7 0x00AC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_HIMR0 0x00B0
#define REG_HISR0 0x00B4
#define REG_HIMR1 0x00B8
#define REG_HISR1 0x00BC
#define REG_DBG_PORT_SEL 0x00C0
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_DIOERR_RPT 0x102500C0
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_SDIO_ERR_RPT 0x102500C0
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_CMD_ERRCNT 0x102500C2
#define REG_SDIO_DATA_ERRCNT 0x102500C3
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PAD_CTRL2 0x00C4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_CMD_ERR_CONTENT 0x102500C4
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_MEM_RMC 0x00C8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SDIO_CRC_ERR_IDX 0x102500C9
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_DATA_CRC 0x102500CA
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_SDIO_DATA_REPLY_TIME 0x102500CB
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PMC_DBG_CTRL2 0x00CC
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SDIO_TRANS_FIFO_STATUS 0x102500CC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BIST_CTRL 0x00D0
#define REG_BIST_RPT 0x00D4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_MEM_CTRL 0x00D8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_AFE_CTRL8 0x00DC
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_WLAN_DBG 0x00DC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_SYN_RFC_CTRL 0x00DC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_USB_SIE_INTF 0x00E0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_SYS_PINMUX 0x00E0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PCIE_MIO_INTF 0x00E4
#define REG_PCIE_MIO_INTD 0x00E8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_WLRF1 0x00EC
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_HPON_FSM 0x00EC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SYS_CFG1 0x00F0
#define REG_SYS_STATUS1 0x00F4
#define REG_SYS_STATUS2 0x00F8
#define REG_SYS_CFG2 0x00FC
#define REG_CR 0x0100
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PG_SIZE 0x0104
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PKT_BUFF_ACCESS_CTRL 0x0106
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TSF_CLK_STATE 0x0108
#define REG_TXDMA_PQ_MAP 0x010C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TRXFF_BNDY 0x0114
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RXFF_BNDY_V1 0x0114
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PTA_I2C_MBOX 0x0118
#endif
#if (HALMAC_8814A_SUPPORT)
#define REG_FF_STATUS 0x0118
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RXFF_PTR 0x011C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXFF_BNDY 0x011C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_FEIMR 0x0120
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FE1IMR 0x0120
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_FEISR 0x0124
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FE1ISR 0x0124
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_CPWM 0x012C
#define REG_FWIMR 0x0130
#define REG_FWISR 0x0134
#define REG_FTIMR 0x0138
#define REG_FTISR 0x013C
#define REG_PKTBUF_DBG_CTRL 0x0140
#define REG_PKTBUF_DBG_DATA_L 0x0144
#define REG_PKTBUF_DBG_DATA_H 0x0148
#define REG_CPWM2 0x014C
#define REG_TC0_CTRL 0x0150
#define REG_TC1_CTRL 0x0154
#define REG_TC2_CTRL 0x0158
#define REG_TC3_CTRL 0x015C
#define REG_TC4_CTRL 0x0160
#define REG_TCUNIT_BASE 0x0164
#define REG_TC5_CTRL 0x0168
#define REG_TC6_CTRL 0x016C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBIST_FAIL 0x0170
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MBIST_DRF_FAIL 0x0170
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBIST_START_PAUSE 0x0174
#define REG_MBIST_DONE 0x0178
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBIST_ROM_CRC_DATA 0x017C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MBIST_NRML_FAIL 0x017C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_MBIST_FAIL_NRML 0x017C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MBIST_READ_BIST_RPT 0x017C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AES_DECRPT_DATA 0x0180
#define REG_AES_DECRPT_CFG 0x0184
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MBIST_READ_BIST_RPT_V1 0x0188
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HIOE_CTRL 0x0188
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
#define REG_MACCLKFRQ 0x018C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HIOE_CFG_FILE 0x018C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TMETER 0x0190
#define REG_OSC_32K_CTRL 0x0194
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_32K_CAL_REG1 0x0198
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_32K_CAL_REG0 0x0198
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_C2HEVT 0x01A0
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_C2HEVT_1 0x01A4
#define REG_C2HEVT_2 0x01A8
#define REG_C2HEVT_3 0x01AC
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MISC_CTRL_V1 0x01B0
#endif
#if (HALMAC_8814A_SUPPORT)
#define REG_TC7_CTRL 0x01B0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RXDESC_BUFF_RPTR 0x01B0
#endif
#if (HALMAC_8814A_SUPPORT)
#define REG_TC8_CTRL 0x01B4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RXDESC_BUFF_WPTR 0x01B4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SW_DEFINED_PAGE1 0x01B8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SW_DEFINED_PAGE2 0x01BC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_MCUTST_I 0x01C0
#define REG_MCUTST_II 0x01C4
#define REG_FMETHR 0x01C8
#define REG_HMETFR 0x01CC
#define REG_HMEBOX0 0x01D0
#define REG_HMEBOX1 0x01D4
#define REG_HMEBOX2 0x01D8
#define REG_HMEBOX3 0x01DC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_LLT_INIT 0x01E0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_LLT_IND_ACCESS 0x01E0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RXDESC_BUFF_BNDY 0x01E0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_GENTST 0x01E4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_LLT_INIT_ADDR 0x01E4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_BB_ACCESS_CTRL 0x01E8
#define REG_BB_ACCESS_DATA 0x01EC
#define REG_HMEBOX_E0 0x01F0
#define REG_HMEBOX_E1 0x01F4
#define REG_HMEBOX_E2 0x01F8
#define REG_HMEBOX_E3 0x01FC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RQPN_CTRL_HLPQ 0x0200
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_CTRL_1 0x0200
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCN_CTRL_0 0x0200
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_FIFOPAGE_INFO 0x0204
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_CTRL_2 0x0204
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCN_CTRL_1 0x0204
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_DWBCN0_CTRL 0x0208
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_AUTO_LLT_V1 0x0208
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TXDMA_OFFSET_CHK 0x020C
#define REG_TXDMA_STATUS 0x0210
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RQPN_NPQ 0x0214
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_TX_DMA_DBG 0x0214
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TQPNT1 0x0218
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DMA_RQPN_INFO_PUB 0x0218
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TQPNT2 0x021C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RQPN_CTRL_2_V1 0x021C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TDE_DEBUG 0x0220
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TQPNT3 0x0220
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCN_CTRL_2 0x0220
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_AUTO_LLT 0x0224
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TQPNT4 0x0224
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_DWBCN1_CTRL 0x0228
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RQPN_CTRL_1 0x0228
#define REG_RQPN_CTRL_2 0x022C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RQPN_EXQ1_EXQ2 0x0230
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_INFO_1 0x0230
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXPKTNUM_0 0x0230
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TQPNT3_V1 0x0234
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_INFO_2 0x0234
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXPKTNUM_1 0x0234
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_INFO_3 0x0238
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXPKTNUM_2 0x0238
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_INFO_4 0x023C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXPKTNUM_3 0x023C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FIFOPAGE_INFO_5 0x0240
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TX_AGG_ALIGN 0x0240
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_H2C_HEAD 0x0244
#define REG_H2C_TAIL 0x0248
#define REG_H2C_READ_ADDR 0x024C
#define REG_H2C_WR_ADDR 0x0250
#define REG_H2C_INFO 0x0254
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_FIFOPAGE_CTRL_5 0x0258
#define REG_FIFOPAGE_CTRL_3 0x025C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TQPNT5 0x0260
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DMA_OQT_0 0x0260
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TQPNT6 0x0264
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DMA_OQT_1 0x0264
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_FIFOPAGE_INFO_6 0x0268
#define REG_FIFOPAGE_INFO_7 0x026C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PGSUB_CNT 0x026C
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_FIFOPAGE_CTRL_4 0x0270
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PGSUB_H 0x0270
#define REG_PGSUB_N 0x0274
#define REG_PGSUB_L 0x0278
#define REG_PGSUB_E 0x027C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RXDMA_AGG_PG_TH 0x0280
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RXPKT_NUM 0x0284
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RXDMA_CTRL 0x0284
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RXDMA_STATUS 0x0288
#define REG_RXDMA_DPR 0x028C
#define REG_RXDMA_MODE 0x0290
#define REG_C2H_PKT 0x0294
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FWFF_C2H 0x0298
#define REG_FWFF_CTRL 0x029C
#define REG_FWFF_PKT_INFO 0x02A0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_FC2H_INFO 0x02A4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWFF_PKT_INFO2 0x02A4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXPKTNUM 0x02B0
#define REG_RXPKTNUM_TH 0x02B4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FW_UPD_RXDES_RDPTR 0x02B8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FW_MSG1 0x02E0
#define REG_FW_MSG2 0x02E4
#define REG_FW_MSG3 0x02E8
#define REG_FW_MSG4 0x02EC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_CTRL 0x0300
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_CTRL 0x0300
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_LX_CTRL1 0x0300
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_INT_MIG 0x0304
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH_CTRL 0x0304
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BCNQ_TXBD_DESA 0x0308
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HIQ_CTRL 0x0308
#define REG_INT_MIG_V1 0x030C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MGQ_TXBD_DESA 0x0310
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0MGQ_TXBD_DESA_L 0x0310
#define REG_P0MGQ_TXBD_DESA_H 0x0314
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_VOQ_TXBD_DESA 0x0318
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH0_TXBD_DESA_L 0x0318
#define REG_ACH0_TXBD_DESA_H 0x031C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_VIQ_TXBD_DESA 0x0320
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH1_TXBD_DESA_L 0x0320
#define REG_ACH1_TXBD_DESA_H 0x0324
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BEQ_TXBD_DESA 0x0328
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH2_TXBD_DESA_L 0x0328
#define REG_ACH2_TXBD_DESA_H 0x032C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BKQ_TXBD_DESA 0x0330
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH3_TXBD_DESA_L 0x0330
#define REG_ACH3_TXBD_DESA_H 0x0334
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RXQ_RXBD_DESA 0x0338
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0RXQ_RXBD_DESA_L 0x0338
#define REG_P0RXQ_RXBD_DESA_H 0x033C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI0Q_TXBD_DESA 0x0340
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0BCNQ_TXBD_DESA_L 0x0340
#define REG_P0BCNQ_TXBD_DESA_H 0x0344
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI1Q_TXBD_DESA 0x0348
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWCMDQ_TXBD_DESA_L 0x0348
#define REG_FWCMDQ_TXBD_DESA_H 0x034C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI2Q_TXBD_DESA 0x0350
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_HRPWM1_HCPWM1_DCPU 0x0354
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI3Q_TXBD_DESA 0x0358
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0_MPRT_BCNQ_TXBD_DESA_L 0x0358
#define REG_P0_MPRT_BCNQ_TXBD_DESA_H 0x035C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI4Q_TXBD_DESA 0x0360
#define REG_HI5Q_TXBD_DESA 0x0368
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0_MPRT_BCNQ_TXRXBD_NUM 0x036C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI6Q_TXBD_DESA 0x0370
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BD_RWPTR_CLR2 0x0370
#define REG_BD_RWPTR_CLR3 0x0374
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI7Q_TXBD_DESA 0x0378
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0MGQ_RXQ_TXRXBD_NUM 0x0378
#define REG_CHNL_DMA_CFG 0x037C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MGQ_TXBD_NUM 0x0380
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWCMDQ_TXBD_NUM 0x0380
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RX_RXBD_NUM 0x0382
#define REG_VOQ_TXBD_NUM 0x0384
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH0_ACH1_TXBD_NUM 0x0384
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_VIQ_TXBD_NUM 0x0386
#define REG_BEQ_TXBD_NUM 0x0388
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH2_ACH3_TXBD_NUM 0x0388
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BKQ_TXBD_NUM 0x038A
#define REG_HI0Q_TXBD_NUM 0x038C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI0Q_HI1Q_TXBD_NUM 0x038C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI1Q_TXBD_NUM 0x038E
#define REG_HI2Q_TXBD_NUM 0x0390
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI2Q_HI3Q_TXBD_NUM 0x0390
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI3Q_TXBD_NUM 0x0392
#define REG_HI4Q_TXBD_NUM 0x0394
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI4Q_HI5Q_TXBD_NUM 0x0394
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI5Q_TXBD_NUM 0x0396
#define REG_HI6Q_TXBD_NUM 0x0398
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI6Q_HI7Q_TXBD_NUM 0x0398
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI7Q_TXBD_NUM 0x039A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TSFTIMER_HCI 0x039C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BD_RWPTR_CLR 0x039C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BD_RWPTR_CLR1 0x039C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_VOQ_TXBD_IDX 0x03A0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH0_TXBD_IDX 0x03A0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_VIQ_TXBD_IDX 0x03A4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH1_TXBD_IDX 0x03A4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BEQ_TXBD_IDX 0x03A8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH2_TXBD_IDX 0x03A8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BKQ_TXBD_IDX 0x03AC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH3_TXBD_IDX 0x03AC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MGQ_TXBD_IDX 0x03B0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0MGQ_TXBD_IDX 0x03B0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RXQ_RXBD_IDX 0x03B4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0RXQ_RXBD_IDX 0x03B4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI0Q_TXBD_IDX 0x03B8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI0Q_TXBD_IDX 0x03B8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI1Q_TXBD_IDX 0x03BC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI1Q_TXBD_IDX 0x03BC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI2Q_TXBD_IDX 0x03C0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI2Q_TXBD_IDX 0x03C0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI3Q_TXBD_IDX 0x03C4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI3Q_TXBD_IDX 0x03C4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI4Q_TXBD_IDX 0x03C8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI4Q_TXBD_IDX 0x03C8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI5Q_TXBD_IDX 0x03CC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI5Q_TXBD_IDX 0x03CC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI6Q_TXBD_IDX 0x03D0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI6Q_TXBD_IDX 0x03D0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HI7Q_TXBD_IDX 0x03D4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI7Q_TXBD_IDX 0x03D4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DBG_SEL_V1 0x03D8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DBGSEL_PCIE_HRPWM1_HCPWM1_V1 0x03D8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PCIE_HRPWM1_V1 0x03D9
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_HRPWM1_V1 0x03D9
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PCIE_HCPWM1_V1 0x03DA
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_HCPWM1_V1 0x03DA
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_CTRL2 0x03DB
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_CTRL2 0x03DB
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_LX_CTRL2 0x03DB
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PCIE_HRPWM2_V1 0x03DC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_HRPWM2_V1 0x03DC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_HRPWM2_HCPWM2_V1 0x03DC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PCIE_HCPWM2_V1 0x03DE
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_HCPWM2_V1 0x03DE
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PCIE_H2C_MSG_V1 0x03E0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_H2C_MSG_V1 0x03E0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PCIE_C2H_MSG_V1 0x03E4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HCI_C2H_MSG_V1 0x03E4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DBI_WDATA_V1 0x03E8
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_LX_DMA_ISR 0x03E8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DBI_RDATA_V1 0x03EC
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_LX_DMA_IMR 0x03EC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DBI_FLAG_V1 0x03F0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_STUCK_FLAG_V1 0x03F0
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_LX_DMA_DBG 0x03F0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MDIO_V1 0x03F4
#endif
#if (HALMAC_8192E_SUPPORT)
#define REG_MDIO2_V1 0x03F8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_MIX_CFG 0x03F8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_WDT_CFG 0x03F8
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_BUS_MIX_CFG 0x03F8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HCI_MIX_CFG 0x03FC
#endif
#if (HALMAC_8881A_SUPPORT)
#define REG_BUS_MIX_CFG1 0x03FC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_Q0_INFO 0x0400
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_QUEUELIST_INFO0 0x0400
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_QUEUE_INFO1 0x0400
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_Q1_INFO 0x0404
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_QUEUELIST_INFO1 0x0404
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_QUEUE_INFO2 0x0404
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_Q2_INFO 0x0408
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_QUEUE_INFO3 0x0408
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_QUEUELIST_INFO2 0x0408
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_Q3_INFO 0x040C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_QINFO_INDEX 0x040C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_QUEUELIST_INFO3 0x040C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MGQ_INFO 0x0410
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_QUEUE_EMPTY 0x0410
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_QUEUELIST_INFO_EMPTY 0x0410
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HIQ_INFO 0x0414
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_QUEUELIST_INFO2_V1 0x0414
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ACQ_STOP_V1 0x0414
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_QUEUELIST_ACQ_EN 0x0414
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BCNQ_INFO 0x0418
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TXPKT_EMPTY_V1 0x0418
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCNQ_BDNY_V2 0x0418
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TXPKT_EMPTY 0x041A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_CPU_MGQ_INFO 0x041C
#define REG_FWHW_TXQ_CTRL 0x0420
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HWSEQ_CTRL 0x0423
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_DATAFB_SEL 0x0423
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BCNQ_BDNY 0x0424
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BCNQ_BDNY_V1 0x0424
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXBDNY 0x0424
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MGQ_BDNY 0x0425
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_LIFETIME_EN 0x0426
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_FW_FREE_TAIL 0x0427
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SPEC_SIFS 0x0428
#define REG_RETRY_LIMIT 0x042A
#define REG_TXBF_CTRL 0x042C
#define REG_DARFRC 0x0430
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DARFRCH 0x0434
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RARFRC 0x0438
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RARFRCH 0x043C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RRSR 0x0440
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_RRSR_H 0x0443
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ARFR0 0x0444
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ARFRH0 0x0448
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ARFR1_V1 0x044C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_ARFR1 0x044C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_REG_ARFR_WT0 0x044C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_ARFRH1 0x0450
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ARFRH1_V1 0x0450
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_REG_ARFR_WT1 0x0450
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_CCK_CHECK 0x0454
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_AMPDU_BURST_CTRL 0x0455
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_BCNQ2_HEAD 0x0455
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_AMPDU_MAX_TIME_V1 0x0455
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_AMPDU_MAX_TIME 0x0456
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BCNQ1_BDNY_V1 0x0456
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TAB_SEL 0x0456
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BCNQ1_BDNY 0x0457
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCN_INVALID_CTRL 0x0457
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AMPDU_MAX_LENGTH 0x0458
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_AMPDU_MAX_LENGTH_HT 0x0458
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ACQ_STOP 0x045C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WMAC_LBK_BUF_HD 0x045D
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_NDPA_RATE 0x045D
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TX_HANG_CTRL 0x045E
#define REG_NDPA_OPT_CTRL 0x045F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_FAST_EDCA_CTRL 0x0460
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_AMPDU_MAX_LENGTH_VHT 0x0460
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RD_RESP_PKT_TH 0x0463
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_CMDQ_INFO 0x0464
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_NEW_EDCA_CTRL_V1 0x0464
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_Q4_INFO 0x0468
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACQ_STOP_V2 0x0468
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_Q5_INFO 0x046C
#define REG_Q6_INFO 0x0470
#define REG_Q7_INFO 0x0474
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_WMAC_LBK_BUF_HD_V1 0x0478
#define REG_MGQ_BDNY_V1 0x047A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TXRPT_CTRL 0x047C
#define REG_INIRTS_RATE_SEL 0x0480
#define REG_BASIC_CFEND_RATE 0x0481
#define REG_STBC_CFEND_RATE 0x0482
#define REG_DATA_SC 0x0483
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MACID_SLEEP3 0x0484
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MOREDATA_V1 0x0484
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MACID_SLEEP4 0x0485
#define REG_MACID_SLEEP5 0x0487
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DATA_SC1 0x0487
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MACID_SLEEP1 0x0488
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ARFR2_V1 0x048C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_ARFR2 0x048C
#define REG_ARFRH2 0x0490
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ARFRH2_V1 0x0490
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ARFR3_V1 0x0494
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_ARFR3 0x0494
#define REG_ARFRH3 0x0498
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ARFRH3_V1 0x0498
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ARFR4 0x049C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ARFRH4 0x04A0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ARFR5 0x04A4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ARFRH5 0x04A8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TXRPT_START_OFFSET 0x04AC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TRYING_CNT_TH 0x04B0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TRY_CNT_IDX 0x04B0
#endif
#if (HALMAC_8812F_SUPPORT)
#define REG_RRSR_CTS 0x04B0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_POWER_STAGE1 0x04B4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_POWER_STAGE2 0x04B8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SW_AMPDU_BURST_MODE_CTRL 0x04BC
#define REG_PKT_LIFE_TIME 0x04C0
#define REG_STBC_SETTING 0x04C4
#define REG_STBC_SETTING2 0x04C5
#define REG_QUEUE_CTRL 0x04C6
#define REG_SINGLE_AMPDU_CTRL 0x04C7
#define REG_PROT_MODE_CTRL 0x04C8
#define REG_BAR_MODE_CTRL 0x04CC
#define REG_RA_TRY_RATE_AGG_LMT 0x04CF
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MACID_SLEEP2 0x04D0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_SLEEP_CTRL 0x04D0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MACID_SLEEP 0x04D4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_SLEEP_INFO 0x04D4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_HW_SEQ0 0x04D8
#define REG_HW_SEQ1 0x04DA
#define REG_HW_SEQ2 0x04DC
#define REG_HW_SEQ3 0x04DE
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_CSI_SEQ 0x04DE
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_NULL_PKT_STATUS 0x04E0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NULL_PKT_STATUS_V1 0x04E0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PTCL_ERR_STATUS 0x04E2
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_PTCL_ERR_STATUS_V1 0x04E2
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PTCL_PKT_NUM 0x04E3
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_NULL_PKT_STATUS_EXTEND 0x04E3
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_TRXRPT_MISS_CNT 0x04E3
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HQMGQ_DROP 0x04E4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_VIDEO_ENHANCEMENT_FUN 0x04E4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_NULL_PKT_STATUS_V2 0x04E4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PRECNT_CTRL 0x04E5
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_NULL_PKT_STATUS_EXTEND_V1 0x04E7
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_BT_POLLUTE_PKTCNT_V1 0x04E8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BT_POLLUTE_PKT_CNT 0x04E8
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_DROP_PKT_NUM 0x04EC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PTCL_DBG 0x04EC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_DROP_NUM 0x04EC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PTCL_DBG_V1 0x04EC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PTCL_TX_RPT 0x04F0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TX_RPT_INFO_L32 0x04F0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TXOP_EXTRA_CTRL 0x04F0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BT_POLLUTE_PKTCNT 0x04F0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TX_RPT_INFO_H32 0x04F4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CPUMGQ_TIMER_CTRL2 0x04F4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PTCL_DBG_OUT 0x04F8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_DUMMY_PAGE4 0x04FC
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DUMMY_PAGE4_V1 0x04FC
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_DUMMY_PAGE4_1 0x04FE
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MOREDATA 0x04FE
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_EDCA_VO_PARAM 0x0500
#define REG_EDCA_VI_PARAM 0x0504
#define REG_EDCA_BE_PARAM 0x0508
#define REG_EDCA_BK_PARAM 0x050C
#define REG_BCNTCFG 0x0510
#define REG_PIFS 0x0512
#define REG_RDG_PIFS 0x0513
#define REG_SIFS 0x0514
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TSFTR_SYN_OFFSET 0x0518
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FORCE_BCN_IFS_V1 0x0518
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_AGGR_BREAK_TIME 0x051A
#define REG_SLOT 0x051B
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NOA_ON_ERLY_TIME 0x051C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_EDCA_CPUMGQ_PARAM 0x051C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NOA_OFF_ERLY_TIME 0x051D
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_CPUMGQ_PAUSE 0x051E
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PS_TIMER_CTRL 0x051F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TX_PTCL_CTRL 0x0520
#define REG_TXPAUSE 0x0522
#define REG_DIS_TXREQ_CLR 0x0523
#define REG_RD_CTRL 0x0524
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBSSID_CTRL 0x0526
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_P2PPS_CTRL 0x0527
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PKT_LIFETIME_CTRL 0x0528
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_P2PPS_SPEC_STATE 0x052B
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_P2PPS0_SPEC_STATE 0x052B
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PS_TIMER_A_V2 0x052C
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_TBTT_AREA_BLK_4AC 0x052C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_TXOP_LIMIT_CTRL 0x052C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BAR_TX_CTRL 0x0530
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_P2PON_DIS_TXTIME 0x0531
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PS_TIMER_B_V2 0x0534
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_EDCA_REF_CTRL 0x0534
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CCA_TXEN_CNT 0x0534
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_QUEUE_INCOL_THR 0x0538
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MAX_INTER_COLLISION 0x0538
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_QUEUE_INCOL_EN 0x053C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MAX_INTER_COLLISION_CNT 0x053C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TBTT_PROHIBIT 0x0540
#define REG_P2PPS_STATE 0x0543
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RD_NAV_NXT 0x0544
#define REG_NAV_PROT_LEN 0x0546
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_FTM_SETTING 0x0548
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_FTM_CTRL 0x0548
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FTM_PTT 0x0548
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT)
#define REG_FTM_TSF_CNT 0x054C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FTM_TSF 0x054C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BCN_CTRL 0x0550
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BCN_CTRL1 0x0551
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BCN_CTRL_CLINT0 0x0551
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBID_NUM 0x0552
#define REG_DUAL_TSF_RST 0x0553
#define REG_MBSSID_BCN_SPACE 0x0554
#define REG_DRVERLYINT 0x0558
#define REG_BCNDMATIM 0x0559
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ATIMWND 0x055A
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_USTIME_TSF 0x055C
#define REG_BCN_MAX_ERR 0x055D
#define REG_RXTSF_OFFSET_CCK 0x055E
#define REG_RXTSF_OFFSET_OFDM 0x055F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TSFTR 0x0560
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFTR0_L 0x0560
#define REG_TSFTR0_H 0x0564
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_TSFTR_1 0x0564
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TSFTR1 0x0568
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFTR1_L 0x0568
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FREERUN_CNT 0x0568
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFTR1_H 0x056C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FREERUN_CNT_1 0x056C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND1 0x0570
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ATIMWND1_V1 0x0570
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TBTT_PROHIBIT_INFRA 0x0571
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_CTWND 0x0572
#define REG_BCNIVLCUNT 0x0573
#define REG_BCNDROPCTRL 0x0574
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_HGQ_TIMEOUT_PERIOD 0x0575
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TXCMD_TIMEOUT_PERIOD 0x0576
#define REG_MISC_CTRL 0x0577
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFTR2_L 0x0578
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BCN_CTRL_CLINT1 0x0578
#define REG_BCN_CTRL_CLINT2 0x0579
#define REG_BCN_CTRL_CLINT3 0x057A
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_EXTEND_CTRL 0x057B
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFTR2_H 0x057C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_P2PPS1_SPEC_STATE 0x057C
#define REG_P2PPS1_STATE 0x057D
#define REG_P2PPS2_SPEC_STATE 0x057E
#define REG_P2PPS2_STATE 0x057F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_PS_TIMER 0x0580
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER0 0x0580
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TIMER0 0x0584
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER1 0x0584
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TIMER1 0x0588
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER2 0x0588
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TBTT_CTN_AREA 0x058C
#define REG_FORCE_BCN_IFS 0x058E
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_DRVERLYINT_V1 0x058F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TXOP_MIN 0x0590
#define REG_PRE_BKF_TIME 0x0592
#define REG_CROSS_TXOP_CTRL 0x0593
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_FREERUN_CNT_L 0x0594
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TBTT_INT_SHIFT_CLI0 0x0594
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_TBTT_INT_SHIFT_CLI 0x0594
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TBTT_INT_SHIFT_CLI1 0x0595
#define REG_TBTT_INT_SHIFT_CLI2 0x0596
#define REG_TBTT_INT_SHIFT_CLI3 0x0597
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_FREERUN_CNT_H 0x0598
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TBTT_INT_SHIFT_ENABLE 0x0598
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RX_TBTT_SHIFT_V1 0x0598
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND2 0x05A0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ATIMWND_GROUP1 0x05A0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND3 0x05A1
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ATIMWND_GROUP2 0x05A1
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND4 0x05A2
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ATIMWND_GROUP3 0x05A2
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND5 0x05A3
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ATIMWND_GROUP4 0x05A3
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND6 0x05A4
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_DTIM_COUNT_GROUP1 0x05A4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMWND7 0x05A5
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_DTIM_COUNT_GROUP2 0x05A5
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ATIMUGT 0x05A6
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_DTIM_COUNT_GROUP3 0x05A6
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_HIQ_NO_LMT_EN 0x05A7
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_DTIM_COUNT_GROUP4 0x05A7
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_DTIM_COUNTER_ROOT 0x05A8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_HIQ_NO_LMT_EN_V2 0x05A8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_DTIM_COUNTER_VAP1 0x05A9
#define REG_DTIM_COUNTER_VAP2 0x05AA
#define REG_DTIM_COUNTER_VAP3 0x05AB
#define REG_DTIM_COUNTER_VAP4 0x05AC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_MBID_BCNQ_EN 0x05AC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_DTIM_COUNTER_VAP5 0x05AD
#define REG_DTIM_COUNTER_VAP6 0x05AE
#define REG_DTIM_COUNTER_VAP7 0x05AF
#define REG_DIS_ATIM 0x05B0
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_EARLY_128US 0x05B1
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TBTT_HOLD_PREDICT_P1 0x05B2
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_P2PPS1_CTRL 0x05B2
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MULTI_BCN_CS 0x05B3
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_P2PPS2_CTRL 0x05B3
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFT_SHIFT 0x05B4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TIMER0_SRC_SEL 0x05B4
#define REG_NOA_UNIT_SEL 0x05B5
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_P2POFF_DIS_TXTIME 0x05B7
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MBSSID_BCN_SPACE2 0x05B8
#define REG_MBSSID_BCN_SPACE3 0x05BC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_ACMHWCTRL 0x05C0
#define REG_ACMRSTCTRL 0x05C1
#define REG_ACMAVG 0x05C2
#define REG_VO_ADMTIME 0x05C4
#define REG_VI_ADMTIME 0x05C6
#define REG_BE_ADMTIME 0x05C8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MAC_HEADER_NAV_OFFSET 0x05CA
#define REG_DIS_NDPA_NAV_CHECK 0x05CB
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_EDCA_RANDOM_GEN 0x05CC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TXCMD_NOA_SEL 0x05CF
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXCMD_SEL 0x05CF
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_DRVERLYINT2 0x05D0
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_BCNERR_CFG 0x05D0
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_32K_CLK_SEL 0x05D0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_NAN_SETTING 0x05D4
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_BCN_ELY_ADJ 0x05D4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_EARLYINT_ADJUST 0x05D4
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_NAN_BCNSPACE 0x05D8
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_BCNERR_CNT1 0x05D8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BCNERR_CNT 0x05D8
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_NAN_SETTING1 0x05DC
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_BCNERR_CNT2 0x05DC
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BCNERR_CNT_2 0x05DC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_NOA_PARAM 0x05E0
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NOA_PARAM_1 0x05E4
#define REG_NOA_PARAM_2 0x05E8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MU_DBG_INFO 0x05E8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NOA_PARAM_3 0x05EC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MU_DBG_INFO_1 0x05EC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_NOA_SUBIE 0x05ED
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_P2P_RST 0x05F0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_SCH_DBG_SEL 0x05F0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SCHEDULER_RST 0x05F1
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MU_DBG_ERR_FLAG 0x05F2
#define REG_TX_ERR_RECOVERY_RST 0x05F3
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_SCH_DBG 0x05F4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SCH_DBG_VALUE 0x05F4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SCH_TXCMD 0x05F8
#define REG_PAGE5_DUMMY 0x05FC
#define REG_WMAC_CR 0x0600
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_FWPKT_CR 0x0601
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FW_STS_FILTER 0x0602
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_WMAC_BWOPMODE 0x0603
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_BWOPMODE 0x0603
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TCR 0x0604
#define REG_RCR 0x0608
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RX_PKT_LIMIT 0x060C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RXPKT_LIMIT 0x060C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RX_DLK_TIME 0x060D
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_SDIO_RXINT_LEN_TH 0x1025060E
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RX_DRVINFO_SZ 0x060F
#define REG_MACID 0x0610
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_H 0x0614
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_BSSID 0x0618
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BSSID_H 0x061C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_MAR 0x0620
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MAR_H 0x0624
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBIDCAMCFG_1 0x0628
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MBIDCAMCFG_2 0x062C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MBIDCAM_CFG 0x062C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_WMAC_DEBUG_SEL 0x062C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MCU_TEST_1 0x0630
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_WMAC_TCR_TSFT_OFS 0x0630
#define REG_UDF_THSD 0x0632
#define REG_ZLD_NUM 0x0633
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_MCU_TEST_2 0x0634
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_STMP_THSD 0x0634
#define REG_WMAC_TXTIMEOUT 0x0635
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_MCU_TEST_2_V1 0x0636
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_USTIME_EDCA 0x0638
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ACKTO_CCK 0x0639
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_MAC_SPEC_SIFS 0x063A
#define REG_RESP_SIFS_CCK 0x063C
#define REG_RESP_SIFS_OFDM 0x063E
#define REG_ACKTO 0x0640
#define REG_CTS2TO 0x0641
#define REG_EIFS 0x0642
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RPFM_MAP0 0x0644
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_RPFM_MAP1 0x0646
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_RPFM_MAP1_V1 0x0646
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RPFM_CAM_CMD 0x0648
#define REG_RPFM_CAM_RWD 0x064C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_NAV_CTRL 0x0650
#define REG_BACAMCMD 0x0654
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BACAMCONTENT 0x0658
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_BACAM_WD 0x0658
#define REG_BACAM_WD_H 0x065C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BACAMCONTENT_H 0x065C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_LBDLY 0x0660
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_LBK_DLY 0x0660
#define REG_BITMAP_CMD 0x0661
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_BACAM_RPMEN 0x0661
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_TX_RX 0x0662
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_BITMAP_CTL 0x0663
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RXERR_RPT 0x0664
#define REG_WMAC_TRXPTCL_CTL 0x0668
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_TRXPTCL_CTL_H 0x066C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_CAMCMD 0x0670
#define REG_CAMWRITE 0x0674
#define REG_CAMREAD 0x0678
#define REG_CAMDBG 0x067C
#define REG_SECCFG 0x0680
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXFILTER_CATEGORY_1 0x0682
#define REG_RXFILTER_ACTION_1 0x0683
#define REG_RXFILTER_CATEGORY_2 0x0684
#define REG_RXFILTER_ACTION_2 0x0685
#define REG_RXFILTER_CATEGORY_3 0x0686
#define REG_RXFILTER_ACTION_3 0x0687
#define REG_RXFLTMAP3 0x0688
#define REG_RXFLTMAP4 0x068A
#define REG_RXFLTMAP5 0x068C
#define REG_RXFLTMAP6 0x068E
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_WOW_CTRL 0x0690
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NAN_RX_TSF_FILTER 0x0691
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_PS_RX_INFO 0x0692
#define REG_WMMPS_UAPSD_TID 0x0693
#define REG_LPNAV_CTRL 0x0694
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WKFMCAM_NUM 0x0698
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WKFMCAM_CMD 0x0698
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WKFMCAM_RWD 0x069C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RXFLTMAP0 0x06A0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RXFLTER0 0x06A0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RXFLTMAP1 0x06A2
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RXFLTER1 0x06A2
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_RXFLTMAP 0x06A4
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RXFLTER2 0x06A4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXFLTMAP2 0x06A4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_BCN_PSR_RPT 0x06A8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_FLC_RPC 0x06AC
#define REG_FLC_RPCT 0x06AD
#define REG_FLC_PTS 0x06AE
#define REG_FLC_TRPC 0x06AF
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXPKTMON_CTRL 0x06B0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_STATE_MON 0x06B4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_ERROR_EVT_CTL 0x06B8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ERROR_MON 0x06B8
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RESPINFO 0x06BC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SEARCH_MACID 0x06BC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_COEX_TABLE 0x06C0
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_BT_COEX_TABLE_V1 0x06C0
#define REG_BT_COEX_TABLE2_V1 0x06C4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BT_COEX_TABLE2 0x06C4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_COEX_BREAK_TABLE 0x06C8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_BT_COEX_TABLE_H_V1 0x06CC
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BT_COEX_TABLE_H 0x06CC
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXCMD_0 0x06D0
#define REG_RXCMD_1 0x06D4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WMAC_RESP_TXINFO 0x06D8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_RESP_TXINFO_CFG 0x06D8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BBPSF_CTRL 0x06DC
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_RESP_TXINFO_RATE 0x06DE
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_P2P_RX_BCN_NOA 0x06E0
#define REG_ASSOCIATED_BFMER0_INFO 0x06E4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_SOUNDING_CFG1 0x06E8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ASSOCIATED_BFMER0_INFO_H 0x06E8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ASSOCIATED_BFMER1_INFO 0x06EC
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_SOUNDING_CFG2 0x06EC
#define REG_SOUNDING_CFG3 0x06F0
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ASSOCIATED_BFMER1_INFO_H 0x06F0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TX_CSI_RPT_PARAM_BW20 0x06F4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_SOUNDING_CFG0 0x06F4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TX_CSI_RPT_PARAM_BW40 0x06F8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT)
#define REG_ANTCD_INFO 0x06F8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_TX_CSI_RPT_PARAM_BW80 0x06FC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CSI_PTR 0x06FC
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_CSI_RRSR_V1 0x06FC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_MACID1 0x0700
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID1_1 0x0704
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BSSID1 0x0708
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_CFG_FORCE_LINK_L 0x0709
#define REG_PCIE_CFG_FORCE_LINK_H 0x070A
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BSSID1_1 0x070C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_CFG_DEFAULT_ACK_FREQUENCY 0x070C
#define REG_PCIE_CFG_CX_NFTS 0x070D
#define REG_PCIE_CFG_DEFAULT_ENTR_LATENCY 0x070F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_BCN_PSR_RPT1 0x0710
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_CFG_L1_MISC_SEL 0x0711
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ASSOCIATED_BFMEE_SEL 0x0714
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_ASSOCIATED_BFMEE_SEL_1 0x0714
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_SND_PTCL_CTRL 0x0718
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF 0x0718
#define REG_PCIE_CFG_FORCE_CLKREQ_N_PAD 0x0719
#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_ACK_NAK_LATENCY 0x071A
#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_FLOW_CONTROL_WATCHDOG 0x071B
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_RX_CSI_RPT_INFO 0x071C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_L 0x071C
#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_H 0x071D
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RX_CSI_RPT_INFO_H 0x071F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_NS_ARP_CTRL 0x0720
#define REG_NS_ARP_INFO 0x0724
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_CFG_L1_UNIT_SEL 0x0724
#define REG_PCIE_CFG_MIN_CLKREQ_SEL 0x0725
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_NS_ARP_IPADDR 0x0728
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PWR_INT_CTRL 0x0728
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BEAMFORMING_INFO_NSARP_V1 0x0728
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WRITE_RX_CSI_RPT_INFO 0x072C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RX_CSI_RPT_INFO_V1 0x072C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BEAMFORMING_INFO_NSARP 0x072C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_NS_ARP_IPV6_MYADDR 0x0730
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_POWER_MGT_0_V1 0x0730
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_IPV6 0x0730
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_POWER_MGT_1_V1 0x0734
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_IPV6_1 0x0734
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_POWER_MGT_2_V1 0x0738
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_IPV6_2 0x0738
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_POWER_MGT_3_V1 0x073C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_IPV6_3 0x073C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PLCP_HEADER 0x0740
#define REG_TXDRXDMONITOR 0x0744
#define REG_TXDRXDMONITOR_CTL 0x0748
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_RTX_CTX_SUBTYPE_CFG 0x0750
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_WMAC_SWAES_RD0_V1 0x0754
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_SWAES_DIO_B63_B32 0x0754
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_WMAC_SWAES_RD1_V1 0x0758
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_SWAES_DIO_B95_B64 0x0758
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_WMAC_SWAES_RD3_V1 0x075C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_SWAES_DIO_B127_B96 0x075C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_SWAES_CFG 0x0760
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_COEX_V2 0x0762
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_BT_COEX 0x0764
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WLAN_ACT_MSK_CTRL 0x0768
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WLAN_ACT_MASK_CTRL 0x0768
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WLAN_ACT_MASK_CTRL_1 0x076C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_STATISTICS_CTRL 0x076E
#define REG_BT_COEX_ENH_INTF_CTRL 0x076E
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_COEX_ENHANCED_INTR_CTRL 0x076E
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8881A_SUPPORT)
#define REG_BT_ACT_STATISTICS 0x0770
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_ACT_STATISTICS_1 0x0774
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_STATISTICS_OTH_CTRL 0x0778
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_STATISTICS_CONTROL_REGISTER 0x0778
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_CMD_ID 0x077C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_STATUS_REPORT_REGISTER 0x077C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT__STATUS_RPT 0x077D
#define REG_BT_DATA 0x0780
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_INTERRUPT_CONTROL_REGISTER 0x0780
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WLAN_RPT_ 0x0781
#define REG_BT_ISR_CTRL 0x0783
#define REG_WLAN_RPT_TO_CTR 0x0784
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER 0x0784
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_ISOLATION_TABLE 0x0785
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER 0x0785
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1 0x0788
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2 0x078C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_ISR_STA 0x078F
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_INTERRUPT_STATUS_REGISTER 0x078F
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_TDMA_TIME_AND_RPT_SAM_SET 0x0790
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_TDMA_TIME_REGISTER 0x0790
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_CH_INFO 0x0794
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BT_ACT_REGISTER 0x0794
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_BT_STATIC_INFO_EXT 0x0795
#define REG_LTR_IDLE_LATENCY 0x0798
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_LTR_IDLE_LATENCY_V2 0x0798
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_OBFF_CTRL_BASIC 0x0798
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_LTR_ACTIVE_LATENCY 0x079C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_LTR_ACTIVE_LATENCY_V2 0x079C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_OBFF_CTRL2_TIMER 0x079C
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_OBFF_CTRL 0x07A0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_LTR_CTRL_BASIC 0x07A0
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_LTR_CTRL 0x07A4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_LTR_CTRL2_TIMER_THRESHOLD 0x07A4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_LTR_CTRL2 0x07A8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_LTR_IDLE_LATENCY_V1 0x07A8
#define REG_LTR_ACTIVE_LATENCY_V1 0x07AC
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_ANTTRN_CTRL 0x07B0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_ANTTRN_CTR_V1 0x07B0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER 0x07B0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_SMART_ANT_CONDITION 0x07B0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_ANTTRN_CTR 0x07B4
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_1 0x07B4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_SMART_ANT_CTRL 0x07B4
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WMAC_PKTCNT_RWD 0x07B8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_CONTROL_FRAME_REPORT 0x07B8
#endif
#if (HALMAC_8192E_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8881A_SUPPORT)
#define REG_WMAC_PKTCNT_CTRL 0x07BC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_CONTROL_FRAME_CNT_CTRL 0x07BC
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL 0x07C0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_IQ_DUMP 0x07C0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA 0x07C4
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_IQ_DUMP_1 0x07C4
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA 0x07C8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_IQ_DUMP_2 0x07C8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_FTM_CTL 0x07CC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_IQ_MDPK_FUNC 0x07CE
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_IQ_DUMP_EXT 0x07CF
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT)
#define REG_OFDM_CCK_LEN_MASK 0x07D0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_OPTION_FUNCTION 0x07D0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_FA_FILTER1 0x07D4
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_OPTION_FUNCTION_1 0x07D4
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_FA_FILTER2 0x07D8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_OPTION_FUNCTION_2 0x07D8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RX_FILTER_FUNCTION 0x07DA
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_NAN_FUN 0x07DC
#define REG_NAN_CTL 0x07E0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_NDP_SIG 0x07E0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RX_NAN_ADDR_FILTER 0x07E4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_TXCMD_INFO_FOR_RSP_PKT 0x07E4
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_NAN_ADDR 0x07E8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TXCMD_INFO_FOR_RSP_PKT_1 0x07E8
#endif
#if (HALMAC_8814AMP_SUPPORT)
#define REG_SEC_OPT 0x07E8
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_RXA1_MASK 0x07EC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_SEC_OPT_V2 0x07EC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WSEC_OPTION 0x07EC
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_DUMP_FUNC 0x07F0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RTS_ADDRESS_0 0x07F0
#endif
#if (HALMAC_8814AMP_SUPPORT)
#define REG_RTS_ADDR0 0x07F0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MASK_LA_MAC 0x07F4
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RTS_ADDRESS_0_1 0x07F4
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_MATCH_REF_MAC 0x07F8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RTS_ADDRESS_1 0x07F8
#endif
#if (HALMAC_8814AMP_SUPPORT)
#define REG_RTS_ADDR1 0x07F8
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_LA_DUMP_FUNC_EXT 0x07FC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RTS_ADDRESS_1_1 0x07FC
#endif
#if (HALMAC_8822B_SUPPORT)
#define REG__RPFM_MAP1 0x07FE
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SYS_CFG3 0x1000
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPARSW_MAC_0 0x1010
#define REG_ANAPARSW_MAC_1 0x1014
#define REG_ANAPAR_MAC_0 0x1018
#define REG_ANAPAR_MAC_1 0x101C
#define REG_ANAPAR_MAC_2 0x1020
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ANAPAR_MAC_3 0x1024
#define REG_ANAPAR_MAC_4 0x1028
#define REG_ANAPAR_MAC_5 0x102C
#define REG_ANAPAR_MAC_6 0x1030
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_SYS_CFG4 0x1034
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ANAPAR_MAC_7 0x1034
#define REG_ANAPAR_MAC_8 0x1038
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPAR_XTAL_0 0x1040
#define REG_ANAPAR_XTAL_1 0x1044
#define REG_ANAPAR_XTAL_2 0x1048
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPAR_XTAL_3 0x104C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ANAPAR_XTAL_AAC 0x104C
#define REG_ANAPAR_XTAL_R_ONLY 0x1050
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPAR_XTAL_AACK_0 0x1054
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_CPHY_LDO 0x1054
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPAR_XTAL_AACK_1 0x1058
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_CPHY_BG 0x1058
#define REG_HIMR_4 0x1060
#endif
#if (HALMAC_8822C_SUPPORT)
#define REG_XTAL_AAC_OUTPUT 0x1060
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_ANAPAR_XTAL_MODE_DECODER 0x1064
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HISR_4 0x1064
#define REG_HIMR_5 0x1068
#define REG_HISR_5 0x106C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SYS_CFG5 0x1070
#endif
#if (HALMAC_8812F_SUPPORT)
#define REG_REGU_32K_1 0x1078
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HIMR_6 0x1078
#endif
#if (HALMAC_8812F_SUPPORT)
#define REG_REGU_32K_2 0x107C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HISR_6 0x107C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CPU_DMEM_CON 0x1080
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BOOT_REASON 0x1088
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HIMR4 0x1090
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DATA_CPU_CTL0 0x1090
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HISR4 0x1094
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_DATA_CPU_CTL1 0x1094
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HIMR5 0x1098
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXDMA_STOP_HIMR 0x1098
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HISR5 0x109C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXDMA_STOP_HISR 0x109C
#define REG_TXDMA_START_HIMR 0x10A0
#define REG_TXDMA_START_HISR 0x10A4
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_NFC_PAD_CTRL 0x10A8
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_NFCPAD_CTRL 0x10A8
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HIMR2 0x10B0
#define REG_HISR2 0x10B4
#define REG_HIMR3 0x10B8
#define REG_HISR3 0x10BC
#define REG_SW_MDIO 0x10C0
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_SW_FLUSH 0x10C4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_DBG_GPIO_BMUX 0x10C8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HIMR_7 0x10C8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_FPGA_TAG 0x10CC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HISR_7 0x10CC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_WL_DSS_CTRL0 0x10D0
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_H2C_PKT_READADDR 0x10D0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_WL_DSS_STATUS0 0x10D4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_H2C_PKT_WRITEADDR 0x10D4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_WL_DSS_CTRL1 0x10D8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MEM_PWR_CRTL 0x10D8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_WL_DSS_STATUS1 0x10DC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FW_DRV_HANDSHAKE 0x10DC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_FW_DBG0 0x10E0
#define REG_FW_DBG1 0x10E4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_FW_DBG2 0x10E8
#define REG_FW_DBG3 0x10EC
#define REG_FW_DBG4 0x10F0
#define REG_FW_DBG5 0x10F4
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FW_DBG6 0x10F8
#define REG_FW_DBG7 0x10FC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_CR_EXT 0x1100
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TC9_CTRL 0x1104
#define REG_TC10_CTRL 0x1108
#define REG_TC11_CTRL 0x110C
#define REG_TC12_CTRL 0x1110
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FWFF 0x1114
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_RXFF_PTR_V1 0x1118
#define REG_RXFF_WTR_V1 0x111C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FE2IMR 0x1120
#define REG_FE2ISR 0x1124
#define REG_FE3IMR 0x1128
#define REG_FE3ISR 0x112C
#define REG_FE4IMR 0x1130
#define REG_FE4ISR 0x1134
#define REG_FT1IMR 0x1138
#define REG_FT1ISR 0x113C
#define REG_SPWR0 0x1140
#define REG_SPWR1 0x1144
#define REG_SPWR2 0x1148
#define REG_SPWR3 0x114C
#define REG_POWSEQ 0x1150
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TC7_CTRL_V1 0x1158
#define REG_TC8_CTRL_V1 0x115C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_RXBCN_TBTT_INTERVAL_PORT0TO3 0x1160
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_RX_BCN_TBTT_ITVL0 0x1160
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_RXBCN_TBTT_INTERVAL_PORT4 0x1164
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_RX_BCN_TBTT_ITVL1 0x1164
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_FWIMR1 0x1168
#define REG_FWISR1 0x116C
#define REG_FWIMR2 0x1170
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_IO_WRAP_ERR_FLAG 0x1170
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_FWISR2 0x1174
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWIMR3 0x1178
#define REG_FWISR3 0x117C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_SPEED_SENSOR 0x1180
#define REG_SPEED_SENSOR1 0x1184
#define REG_SPEED_SENSOR2 0x1188
#define REG_SPEED_SENSOR3 0x118C
#define REG_SPEED_SENSOR4 0x1190
#define REG_SPEED_SENSOR5 0x1194
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RXPKTBUF_1_MAX_ADDR 0x1198
#define REG_RXFWBUF_1_MAX_ADDR 0x119C
#define REG_IO_WRAP_ERR_FLAG_V1 0x11A0
#define REG_RXPKTBUF_1_READ 0x11A4
#define REG_RXPKTBUF_1_WRITE 0x11A8
#define REG_BUFF_DBGUG 0x11AC
#define REG_RFE_CTRL_PAD_E2 0x11B0
#define REG_RFE_CTRL_PAD_SR 0x11B4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
#define REG_EXT_QUEUE_REG 0x11C0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_H2C_PRIORITY_SEL 0x11C0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
#define REG_COUNTER_CONTROL 0x11C4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_COUNTER_CTRL 0x11C4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
#define REG_COUNTER_TH 0x11C8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_COUNTER_THRESHOLD 0x11C8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_COUNTER_SET 0x11CC
#define REG_COUNTER_OVERFLOW 0x11D0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
#define REG_TDE_LEN_TH 0x11D4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_TXDMA_LEN_THRESHOLD 0x11D4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
#define REG_RDE_LEN_TH 0x11D8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_RXDMA_LEN_THRESHOLD 0x11D8
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814AMP_SUPPORT)
#define REG_PCIE_EXEC_TIME 0x11DC
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PCIE_EXEC_TIME_THRESHOLD 0x11DC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_FT2IMR 0x11E0
#define REG_FT2ISR 0x11E4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MSG2 0x11F0
#define REG_MSG3 0x11F4
#define REG_MSG4 0x11F8
#define REG_MSG5 0x11FC
#define REG_DDMA_CH0SA 0x1200
#define REG_DDMA_CH0DA 0x1204
#define REG_DDMA_CH0CTRL 0x1208
#define REG_DDMA_CH1SA 0x1210
#define REG_DDMA_CH1DA 0x1214
#define REG_DDMA_CH1CTRL 0x1218
#define REG_DDMA_CH2SA 0x1220
#define REG_DDMA_CH2DA 0x1224
#define REG_DDMA_CH2CTRL 0x1228
#define REG_DDMA_CH3SA 0x1230
#define REG_DDMA_CH3DA 0x1234
#define REG_DDMA_CH3CTRL 0x1238
#define REG_DDMA_CH4SA 0x1240
#define REG_DDMA_CH4DA 0x1244
#define REG_DDMA_CH4CTRL 0x1248
#define REG_DDMA_CH5SA 0x1250
#define REG_DDMA_CH5DA 0x1254
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_REG_DDMA_CH5CTRL 0x1258
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DDMA_CH5CTRL 0x1258
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_DDMA_INT_MSK 0x12E0
#define REG_DDMA_CHSTATUS 0x12E8
#define REG_DDMA_CHKSUM 0x12F0
#define REG_DDMA_MONITOR 0x12FC
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_STC_INT_CS 0x1300
#define REG_ST_INT_CFG 0x1304
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH4_ACH5_TXBD_NUM 0x130C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_CMU_DLY_CTRL 0x1310
#define REG_CMU_DLY_CFG 0x1314
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWCMDQ_TXBD_IDX 0x1318
#define REG_P0HI8Q_TXBD_IDX 0x131C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_H2CQ_TXBD_DESA 0x1320
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_H2CQ_TXBD_DESA_L 0x1320
#define REG_H2CQ_TXBD_DESA_H 0x1324
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_H2CQ_TXBD_NUM 0x1328
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_H2CQ_TXBD_IDX 0x132C
#endif
#if (HALMAC_8192F_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_H2CQ_CSR 0x1330
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI9Q_TXBD_IDX 0x1334
#define REG_P0HI10Q_TXBD_IDX 0x1338
#define REG_P0HI11Q_TXBD_IDX 0x133C
#define REG_P0HI12Q_TXBD_IDX 0x1340
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_CPL_BUFFER_MONITOR 0x1344
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI13Q_TXBD_IDX 0x1344
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PTM_LOCAL_CLOCK 0x1348
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI14Q_TXBD_IDX 0x1348
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PTM_LOCAL_CLOCK_H 0x134C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_P0HI15Q_TXBD_IDX 0x134C
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_TSFT_PTM_DIFF 0x1350
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_AXI_EXCEPT_CS 0x1350
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_CHANGE_PCIE_SPEED 0x1350
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_PTM_CTRL_STATUS 0x1354
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_AXI_EXCEPT_TIME 0x1354
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DEBUG_STATE1 0x1354
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_QUEUE_HEADER_CUR_REMAIN 0x1358
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI8Q_TXBD_IDX 0x1358
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DEBUG_STATE2 0x1358
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_QUEUE_HEADER_MIN_REMAIN 0x135C
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI9Q_TXBD_IDX 0x135C
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_DEBUG_STATE3 0x135C
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI10Q_TXBD_IDX 0x1360
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH5_TXBD_DESA_L 0x1360
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI11Q_TXBD_IDX 0x1364
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH5_TXBD_DESA_H 0x1364
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI12Q_TXBD_IDX 0x1368
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH6_TXBD_DESA_L 0x1368
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI13Q_TXBD_IDX 0x136C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH6_TXBD_DESA_H 0x136C
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI14Q_TXBD_IDX 0x1370
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH7_TXBD_DESA_L 0x1370
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI15Q_TXBD_IDX 0x1374
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH7_TXBD_DESA_H 0x1374
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI8Q_TXBD_DESA 0x1378
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH8_TXBD_DESA_L 0x1378
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CHNL_DMA_CFG_V1 0x137C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH8_TXBD_DESA_H 0x137C
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI9Q_TXBD_DESA 0x1380
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH9_TXBD_DESA_L 0x1380
#define REG_ACH9_TXBD_DESA_H 0x1384
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI10Q_TXBD_DESA 0x1388
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH10_TXBD_DESA_L 0x1388
#define REG_ACH10_TXBD_DESA_H 0x138C
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI11Q_TXBD_DESA 0x1390
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH11_TXBD_DESA_L 0x1390
#define REG_ACH11_TXBD_DESA_H 0x1394
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI12Q_TXBD_DESA 0x1398
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH12_TXBD_DESA_L 0x1398
#define REG_ACH12_TXBD_DESA_H 0x139C
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI13Q_TXBD_DESA 0x13A0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH13_TXBD_DESA_L 0x13A0
#define REG_ACH13_TXBD_DESA_H 0x13A4
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI14Q_TXBD_DESA 0x13A8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI0Q_TXBD_DESA_L 0x13A8
#define REG_HI0Q_TXBD_DESA_H 0x13AC
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI15Q_TXBD_DESA 0x13B0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI1Q_TXBD_DESA_L 0x13B0
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_HISR0_V1 0x13B4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI1Q_TXBD_DESA_H 0x13B4
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI8Q_TXBD_NUM 0x13B8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI2Q_TXBD_DESA_L 0x13B8
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI9Q_TXBD_NUM 0x13BA
#define REG_HI10Q_TXBD_NUM 0x13BC
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_HISR1_V1 0x13BC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI2Q_TXBD_DESA_H 0x13BC
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI11Q_TXBD_NUM 0x13BE
#define REG_HI12Q_TXBD_NUM 0x13C0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI3Q_TXBD_DESA_L 0x13C0
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI13Q_TXBD_NUM 0x13C2
#define REG_HI14Q_TXBD_NUM 0x13C4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI3Q_TXBD_DESA_H 0x13C4
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_HI15Q_TXBD_NUM 0x13C6
#define REG_HIQ_DMA_STOP 0x13C8
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI4Q_TXBD_DESA_L 0x13C8
#define REG_HI4Q_TXBD_DESA_H 0x13CC
#define REG_HI5Q_TXBD_DESA_L 0x13D0
#define REG_HI5Q_TXBD_DESA_H 0x13D4
#define REG_HI6Q_TXBD_DESA_L 0x13D8
#define REG_HI6Q_TXBD_DESA_H 0x13DC
#define REG_HI7Q_TXBD_DESA_L 0x13E0
#define REG_HI7Q_TXBD_DESA_H 0x13E4
#define REG_ACH8_ACH9_TXBD_NUM 0x13E8
#define REG_ACH10_ACH11_TXBD_NUM 0x13EC
#define REG_ACH12_ACH13_TXBD_NUM 0x13F0
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_OLD_DEHANG 0x13F4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_ACH4_TXBD_DESA_L 0x13F8
#define REG_ACH4_TXBD_DESA_H 0x13FC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_Q0_Q1_INFO 0x1400
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ARFR6 0x1400
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MU_OFFSET 0x1400
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_Q2_Q3_INFO 0x1404
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_ARFRH6 0x1404
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_Q4_Q5_INFO 0x1408
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ARFR7 0x1408
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_Q6_Q7_INFO 0x140C
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_ARFRH7 0x140C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MGQ_HIQ_INFO 0x1410
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_ARFR8 0x1410
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || \
HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_CMDQ_BCNQ_INFO 0x1414
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_ARFRH8 0x1414
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_USEREG_SETTING 0x1420
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_LOOPBACK_OPTION 0x1420
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_AESIV_SETTING 0x1424
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BF0_TIME_SETTING 0x1428
#define REG_BF1_TIME_SETTING 0x142C
#define REG_BF_TIMEOUT_EN 0x1430
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_RELEASE0 0x1434
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_RELEASE_INFO 0x1434
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_RELEASE1 0x1438
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_RELEASE_SUCCESS_INFO 0x1438
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_RELEASE2 0x143C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_RELEASE_CTRL 0x143C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_RELEASE3 0x1440
#define REG_MACID_RELEASE_SETTING 0x1444
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_FAST_EDCA_VOVI_SETTING 0x1448
#define REG_FAST_EDCA_BEBK_SETTING 0x144C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_DROP0 0x1450
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_DROP_INFO 0x1450
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_DROP1 0x1454
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MACID_DROP_CTRL 0x1454
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID_DROP2 0x1458
#define REG_MACID_DROP3 0x145C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_R_MACID_RELEASE_SUCCESS_0 0x1460
#define REG_R_MACID_RELEASE_SUCCESS_1 0x1464
#define REG_R_MACID_RELEASE_SUCCESS_2 0x1468
#define REG_R_MACID_RELEASE_SUCCESS_3 0x146C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_MGG_FIFO_CRTL 0x1470
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MGQ_FIFO_WRITE_POINTER 0x1470
#define REG_MGQ_FIFO_READ_POINTER 0x1472
#define REG_MGQ_FIFO_ENABLE 0x1472
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_MGG_FIFO_INT 0x1474
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MGQ_FIFO_RELEASE_INT_MASK 0x1474
#define REG_MGQ_FIFO_RELEASE_INT_FLAG 0x1476
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_MGG_FIFO_LIFETIME 0x1478
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MGQ_FIFO_VALID_MAP 0x1478
#define REG_MGQ_FIFO_LIFETIME 0x147A
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET 0x147C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SHCUT_SETTING 0x1480
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PKT_TRANS 0x1480
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814AMP_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SHCUT_LLC_ETH_TYPE0 0x1484
#define REG_SHCUT_LLC_ETH_TYPE1 0x1488
#define REG_SHCUT_LLC_OUI0 0x148C
#define REG_SHCUT_LLC_OUI1 0x1490
#define REG_SHCUT_LLC_OUI2 0x1494
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_SHCUT_LLC_OUI3 0x1498
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWCMDQ_CTRL 0x14A0
#define REG_FWCMDQ_PAGE 0x14A4
#define REG_FWCMDQ_INFO 0x14A8
#define REG_FWCMDQ_HOLD_PKTNUM 0x14AC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MU_TX_CTL 0x14C0
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_MU_TX_CTRL 0x14C0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MU_STA_GID_VLD 0x14C4
#define REG_MU_STA_USER_POS_INFO 0x14C8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MU_STA_USER_POS_INFO_H 0x14CC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CHNL_INFO_CTRL 0x14D0
#endif
#if (HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_MU_TRX_DBG_CNT 0x14D0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CHNL_IDLE_TIME 0x14D4
#define REG_CHNL_BUSY_TIME 0x14D8
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MU_TRX_DBG_CNT_V1 0x14DC
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_NEW_EDCA_CTRL 0x14F0
#endif
#if (HALMAC_8812F_SUPPORT)
#define REG_SU_DURATION 0x14F0
#define REG_MU_DURATION 0x14F2
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_SWPS_CTRL 0x14F4
#endif
#if (HALMAC_8812F_SUPPORT)
#define REG_HW_NDPA_RTY_LIMIT 0x14F4
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_SWPS_PKT_TH 0x14F6
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8814B_SUPPORT)
#define REG_SWPS_TIME_TH 0x14F8
#define REG_MACID_SWPS_EN 0x14FC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_CPUMGQ_TX_TIMER 0x1500
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PORT_CTRL_SEL 0x1500
#define REG_PORT_CTRL_CFG 0x1501
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER_A 0x1504
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TBTT_PROHIBIT_CFG 0x1504
#define REG_DRVERLYINT_CFG 0x1507
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER_B 0x1508
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCNDMATIM_CFG 0x1508
#define REG_CTWND_CFG 0x1509
#define REG_BCNIVLCUNT_CFG 0x150A
#define REG_EARLY_128US_CFG 0x150B
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER_C 0x150C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TSFTR_SYNC_OFFSET_CFG 0x150C
#define REG_TSFTR_SYNC_CTRL_CFG 0x150F
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL 0x1510
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCN_SPACE_CFG 0x1510
#define REG_EARLY_INT_ADJUST_CFG 0x1512
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_CPUMGQ_TX_TIMER_EARLY 0x1514
#define REG_PS_TIMER_A_EARLY 0x1515
#define REG_PS_TIMER_B_EARLY 0x1516
#define REG_PS_TIMER_C_EARLY 0x1517
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8812F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_CPUMGQ_PARAMETER 0x1518
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_SW_TBTT_TSF_INFO 0x151C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TSF_SYN_CTRL0 0x1520
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TSF_SYNC_ADJ 0x1520
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TSFTR_LOW 0x1520
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_TSF_SYN_CTRL1 0x1521
#define REG_TSF_SYN_OFFSET0 0x1522
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TSF_SYN_OFFSET1 0x1524
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TSF_ADJ_VLAUE 0x1524
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TSFTR_HIGH 0x1524
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT)
#define REG_TSF_SYN_OFFSET2 0x1528
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TSF_ADJ_VLAUE_2 0x1528
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BCN_ERR_CNT_MAC 0x1528
#define REG_BCN_ERR_CNT_EDCCA 0x1529
#define REG_BCN_ERR_CNT_CCA 0x152A
#define REG_BCN_ERR_CNT_INVALID 0x152B
#define REG_BCN_ERR_CNT_OTHERS 0x152C
#define REG_RX_BCN_TIMER 0x152D
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_TSF_SYN_COMPARE_VALUE_L 0x1530
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_TSF_SYN_COMPARE_VALUE 0x1530
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TBTT_CTN_AREA_V1 0x1530
#define REG_BCN_MAX_ERR_V1 0x1531
#define REG_RXTSF_OFFSET_CCK_V1 0x1532
#define REG_RXTSF_OFFSET_OFDM_V1 0x1533
#endif
#if (HALMAC_8197G_SUPPORT)
#define REG_TSF_SYN_COMPARE_VALUE_H 0x1534
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_SUB_BCN_SPACE 0x1534
#define REG_MBID_NUM_V1 0x1535
#define REG_MBSSID_CTRL_V1 0x1536
#define REG_USTIME_TSF_V1 0x1538
#define REG_BW_CFG 0x1539
#define REG_ATIMWND_CFG 0x153A
#define REG_DTIM_COUNTER_CFG 0x153B
#define REG_ATIM_DTIM_CTRL_SEL 0x153C
#define REG_ATIMUGT_V1 0x153D
#define REG_BCNDROPCTRL_V1 0x153E
#define REG_DIS_ATIM_V1 0x1540
#define REG_HIQ_NO_LMT_EN_V1 0x1544
#define REG_P2PPS_CTRL_V1 0x1548
#define REG_P2PPS_SPEC_STATE_V1 0x154A
#define REG_P2PPS_STATE_V1 0x154B
#define REG_P2PPS1_CTRL_V1 0x154C
#define REG_P2PPS1_SPEC_STATE_V1 0x154E
#define REG_P2PPS1_STATE_V1 0x154F
#define REG_P2PPS2_CTRL_V1 0x1550
#define REG_P2PPS2_SPEC_STATE_V1 0x1552
#define REG_P2PPS2_STATE_V1 0x1553
#define REG_P2PON_DIS_TXTIME_V1 0x1554
#define REG_P2POFF_DIS_TXTIME_V1 0x1555
#define REG_CHG_POWER_BCN_AREA 0x1556
#define REG_NOA_SEL 0x1557
#define REG_NOA_PARAM_V1 0x1558
#define REG_NOA_PARAM_1_V1 0x155C
#define REG_NOA_PARAM_2_V1 0x1560
#define REG_NOA_PARAM_3_V1 0x1564
#define REG_NOA_ON_ERLY_TIME_V1 0x1568
#define REG_NOA_OFF_ERLY_TIME_V1 0x1569
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_P2PPS_HW_AUTO_PAUSE_CTRL 0x156C
#define REG_P2PPS1_HW_AUTO_PAUSE_CTRL 0x1570
#define REG_P2PPS2_HW_AUTO_PAUSE_CTRL 0x1574
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_RX_TBTT_SHIFT 0x1578
#define REG_FREERUN_CNT_LOW 0x1580
#define REG_FREERUN_CNT_HIGH 0x1584
#define REG_CPUMGQ_TX_TIMER_V1 0x1588
#define REG_PS_TIMER_0 0x158C
#define REG_PS_TIMER_1 0x1590
#define REG_PS_TIMER_2 0x1594
#define REG_PS_TIMER_3 0x1598
#define REG_PS_TIMER_4 0x159C
#define REG_PS_TIMER_5 0x15A0
#define REG_PS_TIMER_01_CTRL 0x15A4
#define REG_PS_TIMER_23_CTRL 0x15A8
#define REG_PS_TIMER_45_CTRL 0x15AC
#define REG_CPUMGQ_FREERUN_TIMER_CTRL 0x15B0
#define REG_CPUMGQ_PROHIBIT 0x15B4
#define REG_TIMER_COMPARE 0x15C0
#define REG_TIMER_COMPARE_VALUE_LOW 0x15C4
#define REG_TIMER_COMPARE_VALUE_HIGH 0x15C8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_SCHEDULER_COUNTER 0x15D0
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BCN_PSR_RPT2 0x1600
#define REG_BCN_PSR_RPT3 0x1604
#define REG_BCN_PSR_RPT4 0x1608
#define REG_A1_ADDR_MASK 0x160C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_RXPSF_CTRL 0x1610
#define REG_RXPSF_TYPE_CTRL 0x1614
#define REG_CAM_ACCESS_CTRL 0x1618
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_HT_SND_REF_RATE 0x161C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_CUT_AMSDU_CTRL 0x161C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MACID2 0x1620
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID2_H 0x1624
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BSSID2 0x1628
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BSSID2_H 0x162C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MACID3 0x1630
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID3_H 0x1634
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BSSID3 0x1638
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BSSID3_H 0x163C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_MACID4 0x1640
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MACID4_H 0x1644
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814A_SUPPORT || HALMAC_8814AMP_SUPPORT || \
HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_BSSID4 0x1648
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_BSSID4_H 0x164C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NOA_REPORT 0x1650
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_NOA_REPORT_1 0x1654
#define REG_NOA_REPORT_2 0x1658
#define REG_NOA_REPORT_3 0x165C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PWRBIT_SETTING 0x1660
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_GENERAL_OPTION 0x1664
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_FWPHYFF_RCR 0x1668
#define REG_ADDRCAM_WRITE_CONTENT 0x166C
#define REG_ADDRCAM_READ_CONTENT 0x1670
#define REG_ADDRCAM_CFG 0x1674
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_CSI_RRSR 0x1678
#endif
#if (HALMAC_8198F_SUPPORT)
#define REG_WMAC_CSI_FRAME_RRSR_SETTING 0x1678
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822B_SUPPORT)
#define REG_WMAC_MU_BF_OPTION 0x167C
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_MU_BF_OPTION 0x167C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT)
#define REG_WMAC_PAUSE_BB_CLR_TH 0x167D
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT)
#define REG_WMAC_MU_ARB 0x167E
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG__WMAC_MULBK_BUF 0x167E
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_WMAC_MULBK_BUF 0x167E
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_MU_OPTION 0x167F
#define REG_WMAC_MU_BF_CTL 0x1680
#define REG_WMAC_MU_BFRPT_PARA 0x1682
#define REG_WMAC_ASSOCIATED_MU_BFMEE2 0x1684
#define REG_WMAC_ASSOCIATED_MU_BFMEE3 0x1686
#define REG_WMAC_ASSOCIATED_MU_BFMEE4 0x1688
#define REG_WMAC_ASSOCIATED_MU_BFMEE5 0x168A
#define REG_WMAC_ASSOCIATED_MU_BFMEE6 0x168C
#define REG_WMAC_ASSOCIATED_MU_BFMEE7 0x168E
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_BB_STOP_RX_COUNTER 0x1690
#define REG_WMAC_PLCP_MONITOR 0x1694
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_PLCP_MONITOR_MUTX 0x1698
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_WMAC_DEBUG_PORT 0x1698
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WMAC_CSIDMA_CFG 0x169C
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_0 0x16A0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_0_H 0x16A4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_1 0x16A8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_1_H 0x16AC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_2 0x16B0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_2_H 0x16B4
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_3 0x16B8
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_3_H 0x16BC
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_4 0x16C0
#endif
#if (HALMAC_8197G_SUPPORT || HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_TRANSMIT_ADDRSS_4_H 0x16C4
#endif
#if (HALMAC_8812F_SUPPORT)
#define REG_SND_AID12 0x16D0
#define REG_SND_PKT_INFO 0x16D2
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8197G_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8812F_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822B_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1 0x1700
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1 0x1704
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1 0x1708
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_BIST_RSTN0 0x2100
#define REG_BIST_RSTN2 0x2108
#define REG_BIST_MODE_NRML0 0x2110
#define REG_BIST_MODE_NRML1 0x2114
#define REG_BIST_MODE_NRML2 0x2118
#define REG_BIST_MODE_NRML3 0x211C
#define REG_BIST_DONE_NRML_MAC 0x2150
#define REG_BIST_DONE_NRML1 0x2158
#define REG_BIST_DONE_DRF_MAC 0x2160
#define REG_BIST_DONE_DRF 0x2164
#define REG_BIST_DONE_DRF1 0x2168
#define REG_BIST_FAIL_NRML_MAC 0x2170
#define REG_BIST_FAIL_NRML 0x2174
#define REG_BIST_FAIL_NRML1 0x2178
#define REG_BIST_FAIL_NRML_MAC_V1 0x2180
#define REG_BIST_FAIL_NRML_V1 0x2184
#define REG_BIST_FAIL_NRML1_V1 0x2188
#define REG_BIST_MISR_DATAOUT 0x2190
#define REG_BIST_MISR_DATAOUT1 0x2194
#define REG_BIST_MISR_DATAOUT_CPU 0x2198
#define REG_BIST_MISR_DATAOUT_CPU1 0x219C
#define REG_BIST_MISR_DATAOUT_CPU2 0x21A0
#define REG_BIST_MISR_DATOUT_CPU3 0x21A4
#define REG_DMA_RQPN_INFO_0 0x2200
#define REG_DMA_RQPN_INFO_1 0x2204
#define REG_DMA_RQPN_INFO_2 0x2208
#define REG_DMA_RQPN_INFO_3 0x220C
#define REG_DMA_RQPN_INFO_4 0x2210
#define REG_DMA_RQPN_INFO_5 0x2214
#define REG_DMA_RQPN_INFO_6 0x2218
#define REG_DMA_RQPN_INFO_7 0x221C
#define REG_DMA_RQPN_INFO_8 0x2220
#define REG_DMA_RQPN_INFO_9 0x2224
#define REG_DMA_RQPN_INFO_10 0x2228
#define REG_DMA_RQPN_INFO_11 0x222C
#define REG_DMA_RQPN_INFO_12 0x2230
#define REG_DMA_RQPN_INFO_13 0x2234
#define REG_DMA_RQPN_INFO_14 0x2238
#define REG_DMA_RQPN_INFO_15 0x223C
#define REG_DMA_RQPN_INFO_16 0x2240
#define REG_HWAMSDU_CTL1 0x2250
#define REG_HWAMSDU_CTL2 0x2254
#define REG_HI8Q_TXBD_DESA_L 0x2300
#define REG_HI8Q_TXBD_DESA_H 0x2304
#define REG_HI9Q_TXBD_DESA_L 0x2308
#define REG_HI9Q_TXBD_DESA_H 0x230C
#define REG_HI10Q_TXBD_DESA_L 0x2310
#define REG_HI10Q_TXBD_DESA_H 0x2314
#define REG_HI11Q_TXBD_DESA_L 0x2318
#define REG_HI11Q_TXBD_DESA_H 0x231C
#define REG_HI12Q_TXBD_DESA_L 0x2320
#define REG_HI12Q_TXBD_DESA_H 0x2324
#define REG_HI13Q_TXBD_DESA_L 0x2328
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_H2CQ_TXBD_IDX_V1 0x232C
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_HI13Q_TXBD_DESA_H 0x232C
#define REG_HI14Q_TXBD_DESA_L 0x2330
#define REG_HI14Q_TXBD_DESA_H 0x2334
#define REG_HI15Q_TXBD_DESA_L 0x2338
#define REG_HI15Q_TXBD_DESA_H 0x233C
#define REG_HI16Q_TXBD_DESA_L 0x2340
#define REG_HI16Q_TXBD_DESA_H 0x2344
#define REG_HI17Q_TXBD_DESA_L 0x2348
#define REG_HI17Q_TXBD_DESA_H 0x234C
#define REG_HI18Q_TXBD_DESA_L 0x2350
#define REG_HI18Q_TXBD_DESA_H 0x2354
#define REG_HI19Q_TXBD_DESA_L 0x2358
#define REG_HI19Q_TXBD_DESA_H 0x235C
#define REG_BD_RWPTR_CLR6 0x2364
#define REG_P0HI16Q_TXBD_IDX 0x2370
#define REG_P0HI17Q_TXBD_IDX 0x2374
#define REG_P0HI18Q_TXBD_IDX 0x2378
#define REG_P0HI19Q_TXBD_IDX 0x237C
#define REG_P0HI16Q_HI17Q_TXBD_NUM 0x2380
#define REG_P0HI18Q_HI19Q_TXBD_NUM 0x2384
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_HISR2_V1 0x23B4
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_HISR0 0x23B4
#endif
#if (HALMAC_8812F_SUPPORT || HALMAC_8822C_SUPPORT)
#define REG_PCIE_HISR3_V1 0x23BC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_PCIE_HISR1 0x23BC
#define REG_P0HI8Q_HI9Q_TXBD_NUM 0x23C0
#define REG_P0HI10Q_HI11Q_TXBD_NUM 0x23C4
#define REG_P0HI12Q_HI13Q_TXBD_NUM 0x23C8
#define REG_P0HI14Q_HI15Q_TXBD_NUM 0x23CC
#define REG_ACH6_ACH7_TXBD_NUM 0x23F0
#endif
#if (HALMAC_8192F_SUPPORT)
#define REG_BF0_TIME_SETTING_V1 0x2428
#define REG_BF1_TIME_SETTING_V1 0x242C
#define REG_BF_TIMEOUT_EN_V1 0x2430
#define REG_MACID_RELEASE0_V1 0x2434
#define REG_MACID_RELEASE1_V1 0x2438
#define REG_MACID_RELEASE2_V1 0x243C
#define REG_MACID_RELEASE3_V1 0x2440
#define REG_MACID_RELEASE_SETTING_V1 0x2444
#define REG_FAST_EDCA_VOVI_SETTING_V1 0x2448
#define REG_FAST_EDCA_BEBK_SETTING_V1 0x244C
#define REG_R_MACID_RELEASE_SUCCESS_0_V1 0x2460
#define REG_R_MACID_RELEASE_SUCCESS_1_V1 0x2464
#define REG_R_MACID_RELEASE_SUCCESS_2_V1 0x2468
#define REG_R_MACID_RELEASE_SUCCESS_3_V1 0x246C
#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_V1 0x247C
#define REG_NAN_INFO0 0x2480
#define REG_NAN_INFO1 0x2484
#define REG_NAN_INFO2 0x2488
#define REG_NAN_INFO3 0x248C
#define REG_NAN_INFO4 0x2490
#define REG_NAN_INFO5 0x2494
#define REG_NAN_INFO6 0x2498
#define REG_NAN_INFO7 0x249C
#define REG_NAN_INFO8 0x24A0
#define REG_NAN_INFO9 0x24A4
#define REG_CHNL_INFO_CTRL_V1 0x24D0
#define REG_CHNL_IDLE_TIME_V1 0x24D4
#define REG_CHNL_BUSY_TIME_V1 0x24D8
#define REG_SWPS_CTRL_V1 0x24F4
#define REG_SWPS_PKT_TH_V1 0x24F6
#define REG_SWPS_TIME_TH_V1 0x24F8
#define REG_MACID_SWPS_EN_V1 0x24FC
#endif
#if (HALMAC_8814B_SUPPORT)
#define REG_TXPAGE_INT_CTRL_0 0x3200
#define REG_TXPAGE_INT_CTRL_1 0x3204
#define REG_TXPAGE_INT_CTRL_2 0x3208
#define REG_TXPAGE_INT_CTRL_3 0x320C
#define REG_TXPAGE_INT_CTRL_4 0x3210
#define REG_TXPAGE_INT_CTRL_5 0x3214
#define REG_TXPAGE_INT_CTRL_6 0x3218
#define REG_TXPAGE_INT_CTRL_7 0x321C
#define REG_TXPAGE_INT_CTRL_8 0x3220
#define REG_TXPAGE_INT_CTRL_9 0x3224
#define REG_TXPAGE_INT_CTRL_10 0x3228
#define REG_TXPAGE_INT_CTRL_11 0x322C
#define REG_TXPAGE_INT_CTRL_12 0x3230
#define REG_TXPAGE_INT_CTRL_13 0x3234
#define REG_TXPAGE_INT_CTRL_14 0x3238
#define REG_TXPAGE_INT_CTRL_15 0x323C
#define REG_TXPAGE_INT_CTRL_16 0x3240
#define REG_ACH4_TXBD_IDX 0x3340
#define REG_ACH5_TXBD_IDX 0x3344
#define REG_ACH6_TXBD_IDX 0x3348
#define REG_ACH7_TXBD_IDX 0x334C
#define REG_ACH8_TXBD_IDX 0x3350
#define REG_ACH9_TXBD_IDX 0x3354
#define REG_ACH10_TXBD_IDX 0x3358
#define REG_ACH11_TXBD_IDX 0x335C
#define REG_ACH12_TXBD_IDX 0x3360
#define REG_ACH13_TXBD_IDX 0x3364
#define REG_AC_CHANNEL0_WEIGHT 0x3368
#define REG_AC_CHANNEL1_WEIGHT 0x3369
#define REG_AC_CHANNEL2_WEIGHT 0x336A
#define REG_AC_CHANNEL3_WEIGHT 0x336B
#define REG_AC_CHANNEL4_WEIGHT 0x336C
#define REG_AC_CHANNEL5_WEIGHT 0x336D
#define REG_AC_CHANNEL6_WEIGHT 0x336E
#define REG_AC_CHANNEL7_WEIGHT 0x336F
#define REG_AC_CHANNEL8_WEIGHT 0x3370
#define REG_AC_CHANNEL9_WEIGHT 0x3371
#define REG_AC_CHANNEL10_WEIGHT 0x3372
#define REG_AC_CHANNEL11_WEIGHT 0x3373
#define REG_AC_CHANNEL12_WEIGHT 0x3374
#define REG_AC_CHANNEL13_WEIGHT 0x3375
#define REG_PCIE_HISR2 0x33B4
#define REG_PCIE_HISR3 0x33BC
#endif
/* ----------------------------------------------------- */
/* */
/* 0xFB00h ~ 0xFCFFh TX/RX packet buffer affress */
/* */
/* ----------------------------------------------------- */
#define REG_RXPKTBUF_STARTADDR 0xFB00
#define REG_TXPKTBUF_STARTADDR 0xFC00
/* ----------------------------------------------------- */
/* */
/* 0xFD00h ~ 0xFDFFh 8051 CPU Local REG */
/* */
/* ----------------------------------------------------- */
#define REG_SYS_CTRL 0xFD00
#define REG_PONSTS_RPT1 0xFD01
#define REG_PONSTS_RPT2 0xFD02
#define REG_PONSTS_RPT3 0xFD03
#define REG_PONSTS_RPT4 0xFD04 /* 0x84 */
#define REG_PONSTS_RPT5 0xFD05 /* 0x85 */
#define REG_8051ERRFLAG 0xFD08
#define REG_8051ERRFLAG_MASK 0xFD09
#define REG_TXADDRH 0xFD10 /* Tx Packet High Address */
#define REG_RXADDRH 0xFD11 /* Rx Packet High Address */
#define REG_TXADDRH_EXT 0xFD12
#define REG_U3_STATE 0xFD48
/* for MAILBOX */
#define REG_OUTDATA0 0xFD50
#define REG_OUTDATA1 0xFD54
#define REG_OUTRDY 0xFD58 /* bit[0] : OutReady, bit[1] : OutEmptyIntEn */
#define REG_INDATA0 0xFD60
#define REG_INDATA1 0xFD64
#define REG_INRDY 0xFD68 /* bit[0] : InReady, bit[1] : InRdyIntEn */
/* MCU ERROR debug REG */
#define REG_MCUERR_PCLSB 0xFD90 /* PC[7:0] */
#define REG_MCUERR_PCMSB 0xFD91 /* PC[15:8] */
#define REG_MCUERR_ACC 0xFD92
#define REG_MCUERR_B 0xFD93
#define REG_MCUERR_DPTRLSB 0xFD94 /* DPTR[7:0] */
#define REG_MCUERR_DPTRMSB 0xFD95 /* DPTR[15:8] */
#define REG_MCUERR_SP 0xFD96 /* SP[7:0] */
#define REG_MCUERR_IE 0xFD97 /* IE[7:0] */
#define REG_MCUERR_EIE 0xFD98 /* EIE[7:0] */
#define REG_VERA_SIM 0xFD9F
/* 0xFD99~0xFD9F are reserved.. */
/* ----------------------------------------------------- */
/* */
/* 0xFE00h ~ 0xFEFFh USB Configuration */
/* */
/* ----------------------------------------------------- */
/* RTS5101 USB Register Definition */
#define REG_USB_SETUP_DEC_INT 0xFE00
#define REG_USB_DMACTL 0xFE01
#define REG_USB_IRQSTAT0 0xFE02
#define REG_USB_IRQSTAT1 0xFE03
#define REG_USB_IRQEN0 0xFE04
#define REG_USB_IRQEN1 0xFE05
#define REG_USB_AUTOPTRL 0xFE06
#define REG_USB_AUTOPTRH 0xFE07
#define REG_USB_AUTODAT 0xFE08
#define REG_USB_SCRATCH0 0xFE09
#define REG_USB_SCRATCH1 0xFE0A
#define REG_USB_SEEPROM 0xFE0B
#define REG_USB_GPIO0 0xFE0C
#define REG_USB_GPIO0DIR 0xFE0D
#define REG_USB_CLKSEL 0xFE0E
#define REG_USB_BOOTCTL 0xFE0F
#define REG_USB_USBCTL 0xFE10
#define REG_USB_USBSTAT 0xFE11
#define REG_USB_DEVADDR 0xFE12
#define REG_USB_USBTEST 0xFE13
#define REG_USB_FNUM0 0xFE14
#define REG_USB_FNUM1 0xFE15
#define REG_USB_EP_IDX 0xFE20
#define REG_USB_EP_CFG 0xFE21
#define REG_USB_EP_CTL 0xFE22
#define REG_USB_EP_STAT 0xFE23
#define REG_USB_EP_IRQ 0xFE24
#define REG_USB_EP_IRQEN 0xFE25
#define REG_USB_EP_MAXPKT0 0xFE26
#define REG_USB_EP_MAXPKT1 0xFE27
#define REG_USB_EP_DAT 0xFE28
#define REG_USB_EP_BC0 0xFE29
#define REG_USB_EP_BC1 0xFE2A
#define REG_USB_EP_TC0 0xFE2B
#define REG_USB_EP_TC1 0xFE2C
#define REG_USB_EP_TC2 0xFE2D
#define REG_USB_EP_CTL2 0xFE2E
#define REG_USB_INFO 0xFE17
#define REG_USB_SPECIAL_OPTION 0xFE55
#define REG_USB_DMA_AGG_TO 0xFE5B
#define REG_USB_AGG_TO 0xFE5C
#define REG_USB_AGG_TH 0xFE5D
#define REG_USB_VID 0xFE60
#define REG_USB_PID 0xFE62
#define REG_USB_OPT 0xFE64
#define REG_USB_CONFIG 0xFE65
#define REG_USB_PHY_PARA1 0xFE68
#define REG_USB_PHY_PARA2 0xFE69
#define REG_USB_PHY_PARA3 0xFE6A
#define REG_USB_PHY_PARA4 0xFE6B
#define REG_USB_OPT2 0xFE6C
#define REG_USB_MAC_ADDR 0xFE70
#define REG_USB_MANUFACTURE_SETTING 0xFE80
#define REG_USB_PRODUCT_STRING 0xFEA0
#define REG_USB_SERIAL_NUMBER_STRING 0xFED0
#define REG_USB_ALTERNATE_SETTING 0xFE4F
#define REG_USB_INT_BINTERVAL 0xFE6E
#define REG_USB_GPS_EP_CONFIG 0xFE6D
#endif /* __HALMAC_COM_REG_H__ */
================================================
FILE: hal/halmac/halmac_reg_8197f.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_REG_8197F_H
#define __INC_HALMAC_REG_8197F_H
#define REG_SYS_ISO_CTRL_8197F 0x0000
#define REG_SYS_FUNC_EN_8197F 0x0002
#define REG_SYS_PW_CTRL_8197F 0x0004
#define REG_SYS_CLK_CTRL_8197F 0x0008
#define REG_SYS_EEPROM_CTRL_8197F 0x000A
#define REG_EE_VPD_8197F 0x000C
#define REG_SYS_SWR_CTRL1_8197F 0x0010
#define REG_SYS_SWR_CTRL2_8197F 0x0014
#define REG_SYS_SWR_CTRL3_8197F 0x0018
#define REG_RSV_CTRL_8197F 0x001C
#define REG_RF0_CTRL_8197F 0x001F
#define REG_AFE_LDO_CTRL_8197F 0x0020
#define REG_AFE_CTRL1_8197F 0x0024
#define REG_AFE_CTRL2_8197F 0x0028
#define REG_AFE_CTRL3_8197F 0x002C
#define REG_EFUSE_CTRL_8197F 0x0030
#define REG_LDO_EFUSE_CTRL_8197F 0x0034
#define REG_PWR_OPTION_CTRL_8197F 0x0038
#define REG_CAL_TIMER_8197F 0x003C
#define REG_ACLK_MON_8197F 0x003E
#define REG_GPIO_MUXCFG_8197F 0x0040
#define REG_GPIO_PIN_CTRL_8197F 0x0044
#define REG_GPIO_INTM_8197F 0x0048
#define REG_LED_CFG_8197F 0x004C
#define REG_FSIMR_8197F 0x0050
#define REG_FSISR_8197F 0x0054
#define REG_HSIMR_8197F 0x0058
#define REG_HSISR_8197F 0x005C
#define REG_GPIO_EXT_CTRL_8197F 0x0060
#define REG_PAD_CTRL1_8197F 0x0064
#define REG_WL_BT_PWR_CTRL_8197F 0x0068
#define REG_SDM_DEBUG_8197F 0x006C
#define REG_SYS_SDIO_CTRL_8197F 0x0070
#define REG_HCI_OPT_CTRL_8197F 0x0074
#define REG_AFE_CTRL4_8197F 0x0078
#define REG_LDO_SWR_CTRL_8197F 0x007C
#define REG_MCUFW_CTRL_8197F 0x0080
#define REG_MCU_TST_CFG_8197F 0x0084
#define REG_HMEBOX_E0_E1_8197F 0x0088
#define REG_HMEBOX_E2_E3_8197F 0x008C
#define REG_WLLPS_CTRL_8197F 0x0090
#define REG_AFE_CTRL5_8197F 0x0094
#define REG_GPIO_DEBOUNCE_CTRL_8197F 0x0098
#define REG_RPWM2_8197F 0x009C
#define REG_SYSON_FSM_MON_8197F 0x00A0
#define REG_AFE_CTRL6_8197F 0x00A4
#define REG_PMC_DBG_CTRL1_8197F 0x00A8
#define REG_AFE_CTRL7_8197F 0x00AC
#define REG_HIMR0_8197F 0x00B0
#define REG_HISR0_8197F 0x00B4
#define REG_HIMR1_8197F 0x00B8
#define REG_HISR1_8197F 0x00BC
#define REG_DBG_PORT_SEL_8197F 0x00C0
#define REG_PAD_CTRL2_8197F 0x00C4
#define REG_PMC_DBG_CTRL2_8197F 0x00CC
#define REG_BIST_CTRL_8197F 0x00D0
#define REG_BIST_RPT_8197F 0x00D4
#define REG_MEM_CTRL_8197F 0x00D8
#define REG_AFE_CTRL8_8197F 0x00DC
#define REG_USB_SIE_INTF_8197F 0x00E0
#define REG_PCIE_MIO_INTF_8197F 0x00E4
#define REG_PCIE_MIO_INTD_8197F 0x00E8
#define REG_WLRF1_8197F 0x00EC
#define REG_SYS_CFG1_8197F 0x00F0
#define REG_SYS_STATUS1_8197F 0x00F4
#define REG_SYS_STATUS2_8197F 0x00F8
#define REG_SYS_CFG2_8197F 0x00FC
#define REG_SYS_CFG3_8197F 0x1000
#define REG_SYS_CFG4_8197F 0x1034
#define REG_CPU_DMEM_CON_8197F 0x1080
#define REG_HIMR2_8197F 0x10B0
#define REG_HISR2_8197F 0x10B4
#define REG_HIMR3_8197F 0x10B8
#define REG_HISR3_8197F 0x10BC
#define REG_SW_MDIO_8197F 0x10C0
#define REG_SW_FLUSH_8197F 0x10C4
#define REG_DBG_GPIO_BMUX_8197F 0x10C8
#define REG_FPGA_TAG_8197F 0x10CC
#define REG_WL_DSS_CTRL0_8197F 0x10D0
#define REG_WL_DSS_CTRL1_8197F 0x10D8
#define REG_WL_DSS_STATUS1_8197F 0x10DC
#define REG_FW_DBG0_8197F 0x10E0
#define REG_FW_DBG1_8197F 0x10E4
#define REG_FW_DBG2_8197F 0x10E8
#define REG_FW_DBG3_8197F 0x10EC
#define REG_FW_DBG4_8197F 0x10F0
#define REG_FW_DBG5_8197F 0x10F4
#define REG_FW_DBG6_8197F 0x10F8
#define REG_FW_DBG7_8197F 0x10FC
#define REG_CR_8197F 0x0100
#define REG_TSF_CLK_STATE_8197F 0x0108
#define REG_TXDMA_PQ_MAP_8197F 0x010C
#define REG_TRXFF_BNDY_8197F 0x0114
#define REG_PTA_I2C_MBOX_8197F 0x0118
#define REG_RXFF_BNDY_8197F 0x011C
#define REG_FE1IMR_8197F 0x0120
#define REG_FE1ISR_8197F 0x0124
#define REG_CPWM_8197F 0x012C
#define REG_FWIMR_8197F 0x0130
#define REG_FWISR_8197F 0x0134
#define REG_FTIMR_8197F 0x0138
#define REG_FTISR_8197F 0x013C
#define REG_PKTBUF_DBG_CTRL_8197F 0x0140
#define REG_PKTBUF_DBG_DATA_L_8197F 0x0144
#define REG_PKTBUF_DBG_DATA_H_8197F 0x0148
#define REG_CPWM2_8197F 0x014C
#define REG_TC0_CTRL_8197F 0x0150
#define REG_TC1_CTRL_8197F 0x0154
#define REG_TC2_CTRL_8197F 0x0158
#define REG_TC3_CTRL_8197F 0x015C
#define REG_TC4_CTRL_8197F 0x0160
#define REG_TCUNIT_BASE_8197F 0x0164
#define REG_TC5_CTRL_8197F 0x0168
#define REG_TC6_CTRL_8197F 0x016C
#define REG_MBIST_FAIL_8197F 0x0170
#define REG_MBIST_START_PAUSE_8197F 0x0174
#define REG_MBIST_DONE_8197F 0x0178
#define REG_MBIST_FAIL_NRML_8197F 0x017C
#define REG_AES_DECRPT_DATA_8197F 0x0180
#define REG_AES_DECRPT_CFG_8197F 0x0184
#define REG_MACCLKFRQ_8197F 0x018C
#define REG_TMETER_8197F 0x0190
#define REG_OSC_32K_CTRL_8197F 0x0194
#define REG_32K_CAL_REG1_8197F 0x0198
#define REG_C2HEVT_8197F 0x01A0
#define REG_SW_DEFINED_PAGE1_8197F 0x01B8
#define REG_MCUTST_I_8197F 0x01C0
#define REG_MCUTST_II_8197F 0x01C4
#define REG_FMETHR_8197F 0x01C8
#define REG_HMETFR_8197F 0x01CC
#define REG_HMEBOX0_8197F 0x01D0
#define REG_HMEBOX1_8197F 0x01D4
#define REG_HMEBOX2_8197F 0x01D8
#define REG_HMEBOX3_8197F 0x01DC
#define REG_LLT_INIT_8197F 0x01E0
#define REG_LLT_INIT_ADDR_8197F 0x01E4
#define REG_BB_ACCESS_CTRL_8197F 0x01E8
#define REG_BB_ACCESS_DATA_8197F 0x01EC
#define REG_HMEBOX_E0_8197F 0x01F0
#define REG_HMEBOX_E1_8197F 0x01F4
#define REG_HMEBOX_E2_8197F 0x01F8
#define REG_HMEBOX_E3_8197F 0x01FC
#define REG_CR_EXT_8197F 0x1100
#define REG_FWFF_8197F 0x1114
#define REG_RXFF_PTR_V1_8197F 0x1118
#define REG_RXFF_WTR_V1_8197F 0x111C
#define REG_FE2IMR_8197F 0x1120
#define REG_FE2ISR_8197F 0x1124
#define REG_FE3IMR_8197F 0x1128
#define REG_FE3ISR_8197F 0x112C
#define REG_FE4IMR_8197F 0x1130
#define REG_FE4ISR_8197F 0x1134
#define REG_FT1IMR_8197F 0x1138
#define REG_FT1ISR_8197F 0x113C
#define REG_SPWR0_8197F 0x1140
#define REG_SPWR1_8197F 0x1144
#define REG_SPWR2_8197F 0x1148
#define REG_SPWR3_8197F 0x114C
#define REG_POWSEQ_8197F 0x1150
#define REG_TC7_CTRL_V1_8197F 0x1158
#define REG_TC8_CTRL_V1_8197F 0x115C
#define REG_RXBCN_TBTT_INTERVAL_PORT0TO3_8197F 0x1160
#define REG_RXBCN_TBTT_INTERVAL_PORT4_8197F 0x1164
#define REG_EXT_QUEUE_REG_8197F 0x11C0
#define REG_COUNTER_CONTROL_8197F 0x11C4
#define REG_COUNTER_TH_8197F 0x11C8
#define REG_COUNTER_SET_8197F 0x11CC
#define REG_COUNTER_OVERFLOW_8197F 0x11D0
#define REG_TDE_LEN_TH_8197F 0x11D4
#define REG_RDE_LEN_TH_8197F 0x11D8
#define REG_PCIE_EXEC_TIME_8197F 0x11DC
#define REG_FT2IMR_8197F 0x11E0
#define REG_FT2ISR_8197F 0x11E4
#define REG_MSG2_8197F 0x11F0
#define REG_MSG3_8197F 0x11F4
#define REG_MSG4_8197F 0x11F8
#define REG_MSG5_8197F 0x11FC
#define REG_FIFOPAGE_CTRL_1_8197F 0x0200
#define REG_FIFOPAGE_CTRL_2_8197F 0x0204
#define REG_AUTO_LLT_V1_8197F 0x0208
#define REG_TXDMA_OFFSET_CHK_8197F 0x020C
#define REG_TXDMA_STATUS_8197F 0x0210
#define REG_TX_DMA_DBG_8197F 0x0214
#define REG_TQPNT1_8197F 0x0218
#define REG_TQPNT2_8197F 0x021C
#define REG_TQPNT3_8197F 0x0220
#define REG_TQPNT4_8197F 0x0224
#define REG_RQPN_CTRL_1_8197F 0x0228
#define REG_RQPN_CTRL_2_8197F 0x022C
#define REG_FIFOPAGE_INFO_1_8197F 0x0230
#define REG_FIFOPAGE_INFO_2_8197F 0x0234
#define REG_FIFOPAGE_INFO_3_8197F 0x0238
#define REG_FIFOPAGE_INFO_4_8197F 0x023C
#define REG_FIFOPAGE_INFO_5_8197F 0x0240
#define REG_H2C_HEAD_8197F 0x0244
#define REG_H2C_TAIL_8197F 0x0248
#define REG_H2C_READ_ADDR_8197F 0x024C
#define REG_H2C_WR_ADDR_8197F 0x0250
#define REG_H2C_INFO_8197F 0x0254
#define REG_RXDMA_AGG_PG_TH_8197F 0x0280
#define REG_RXPKT_NUM_8197F 0x0284
#define REG_RXDMA_STATUS_8197F 0x0288
#define REG_RXDMA_DPR_8197F 0x028C
#define REG_RXDMA_MODE_8197F 0x0290
#define REG_C2H_PKT_8197F 0x0294
#define REG_FWFF_C2H_8197F 0x0298
#define REG_FWFF_CTRL_8197F 0x029C
#define REG_FWFF_PKT_INFO_8197F 0x02A0
#define REG_FC2H_INFO_8197F 0x02A4
#define REG_DDMA_CH0SA_8197F 0x1200
#define REG_DDMA_CH0DA_8197F 0x1204
#define REG_DDMA_CH0CTRL_8197F 0x1208
#define REG_DDMA_CH1SA_8197F 0x1210
#define REG_DDMA_CH1DA_8197F 0x1214
#define REG_DDMA_CH1CTRL_8197F 0x1218
#define REG_DDMA_CH2SA_8197F 0x1220
#define REG_DDMA_CH2DA_8197F 0x1224
#define REG_DDMA_CH2CTRL_8197F 0x1228
#define REG_DDMA_CH3SA_8197F 0x1230
#define REG_DDMA_CH3DA_8197F 0x1234
#define REG_DDMA_CH3CTRL_8197F 0x1238
#define REG_DDMA_CH4SA_8197F 0x1240
#define REG_DDMA_CH4DA_8197F 0x1244
#define REG_DDMA_CH4CTRL_8197F 0x1248
#define REG_DDMA_CH5SA_8197F 0x1250
#define REG_DDMA_CH5DA_8197F 0x1254
#define REG_REG_DDMA_CH5CTRL_8197F 0x1258
#define REG_DDMA_INT_MSK_8197F 0x12E0
#define REG_DDMA_CHSTATUS_8197F 0x12E8
#define REG_DDMA_CHKSUM_8197F 0x12F0
#define REG_DDMA_MONITOR_8197F 0x12FC
#define REG_HCI_CTRL_8197F 0x0300
#define REG_INT_MIG_8197F 0x0304
#define REG_BCNQ_TXBD_DESA_8197F 0x0308
#define REG_MGQ_TXBD_DESA_8197F 0x0310
#define REG_VOQ_TXBD_DESA_8197F 0x0318
#define REG_VIQ_TXBD_DESA_8197F 0x0320
#define REG_BEQ_TXBD_DESA_8197F 0x0328
#define REG_BKQ_TXBD_DESA_8197F 0x0330
#define REG_RXQ_RXBD_DESA_8197F 0x0338
#define REG_HI0Q_TXBD_DESA_8197F 0x0340
#define REG_HI1Q_TXBD_DESA_8197F 0x0348
#define REG_HI2Q_TXBD_DESA_8197F 0x0350
#define REG_HI3Q_TXBD_DESA_8197F 0x0358
#define REG_HI4Q_TXBD_DESA_8197F 0x0360
#define REG_HI5Q_TXBD_DESA_8197F 0x0368
#define REG_HI6Q_TXBD_DESA_8197F 0x0370
#define REG_HI7Q_TXBD_DESA_8197F 0x0378
#define REG_MGQ_TXBD_NUM_8197F 0x0380
#define REG_RX_RXBD_NUM_8197F 0x0382
#define REG_VOQ_TXBD_NUM_8197F 0x0384
#define REG_VIQ_TXBD_NUM_8197F 0x0386
#define REG_BEQ_TXBD_NUM_8197F 0x0388
#define REG_BKQ_TXBD_NUM_8197F 0x038A
#define REG_HI0Q_TXBD_NUM_8197F 0x038C
#define REG_HI1Q_TXBD_NUM_8197F 0x038E
#define REG_HI2Q_TXBD_NUM_8197F 0x0390
#define REG_HI3Q_TXBD_NUM_8197F 0x0392
#define REG_HI4Q_TXBD_NUM_8197F 0x0394
#define REG_HI5Q_TXBD_NUM_8197F 0x0396
#define REG_HI6Q_TXBD_NUM_8197F 0x0398
#define REG_HI7Q_TXBD_NUM_8197F 0x039A
#define REG_TSFTIMER_HCI_8197F 0x039C
#define REG_BD_RWPTR_CLR_8197F 0x039C
#define REG_VOQ_TXBD_IDX_8197F 0x03A0
#define REG_VIQ_TXBD_IDX_8197F 0x03A4
#define REG_BEQ_TXBD_IDX_8197F 0x03A8
#define REG_BKQ_TXBD_IDX_8197F 0x03AC
#define REG_MGQ_TXBD_IDX_8197F 0x03B0
#define REG_RXQ_RXBD_IDX_8197F 0x03B4
#define REG_HI0Q_TXBD_IDX_8197F 0x03B8
#define REG_HI1Q_TXBD_IDX_8197F 0x03BC
#define REG_HI2Q_TXBD_IDX_8197F 0x03C0
#define REG_HI3Q_TXBD_IDX_8197F 0x03C4
#define REG_HI4Q_TXBD_IDX_8197F 0x03C8
#define REG_HI5Q_TXBD_IDX_8197F 0x03CC
#define REG_HI6Q_TXBD_IDX_8197F 0x03D0
#define REG_HI7Q_TXBD_IDX_8197F 0x03D4
#define REG_DBG_SEL_V1_8197F 0x03D8
#define REG_HCI_HRPWM1_V1_8197F 0x03D9
#define REG_HCI_HCPWM1_V1_8197F 0x03DA
#define REG_HCI_CTRL2_8197F 0x03DB
#define REG_HCI_HRPWM2_V1_8197F 0x03DC
#define REG_HCI_HCPWM2_V1_8197F 0x03DE
#define REG_HCI_H2C_MSG_V1_8197F 0x03E0
#define REG_HCI_C2H_MSG_V1_8197F 0x03E4
#define REG_DBI_WDATA_V1_8197F 0x03E8
#define REG_DBI_RDATA_V1_8197F 0x03EC
#define REG_STUCK_FLAG_V1_8197F 0x03F0
#define REG_MDIO_V1_8197F 0x03F4
#define REG_WDT_CFG_8197F 0x03F8
#define REG_HCI_MIX_CFG_8197F 0x03FC
#define REG_STC_INT_CS_8197F 0x1300
#define REG_ST_INT_CFG_8197F 0x1304
#define REG_CMU_DLY_CTRL_8197F 0x1310
#define REG_CMU_DLY_CFG_8197F 0x1314
#define REG_H2CQ_TXBD_DESA_8197F 0x1320
#define REG_H2CQ_TXBD_NUM_8197F 0x1328
#define REG_H2CQ_TXBD_IDX_8197F 0x132C
#define REG_H2CQ_CSR_8197F 0x1330
#define REG_AXI_EXCEPT_CS_8197F 0x1350
#define REG_AXI_EXCEPT_TIME_8197F 0x1354
#define REG_Q0_INFO_8197F 0x0400
#define REG_Q1_INFO_8197F 0x0404
#define REG_Q2_INFO_8197F 0x0408
#define REG_Q3_INFO_8197F 0x040C
#define REG_MGQ_INFO_8197F 0x0410
#define REG_HIQ_INFO_8197F 0x0414
#define REG_BCNQ_INFO_8197F 0x0418
#define REG_TXPKT_EMPTY_8197F 0x041A
#define REG_CPU_MGQ_INFO_8197F 0x041C
#define REG_FWHW_TXQ_CTRL_8197F 0x0420
#define REG_BCNQ_BDNY_V1_8197F 0x0424
#define REG_LIFETIME_EN_8197F 0x0426
#define REG_SPEC_SIFS_8197F 0x0428
#define REG_RETRY_LIMIT_8197F 0x042A
#define REG_TXBF_CTRL_8197F 0x042C
#define REG_DARFRC_8197F 0x0430
#define REG_RARFRC_8197F 0x0438
#define REG_RRSR_8197F 0x0440
#define REG_ARFR0_8197F 0x0444
#define REG_ARFR1_V1_8197F 0x044C
#define REG_CCK_CHECK_8197F 0x0454
#define REG_AMPDU_MAX_TIME_V1_8197F 0x0455
#define REG_BCNQ1_BDNY_V1_8197F 0x0456
#define REG_AMPDU_MAX_LENGTH_8197F 0x0458
#define REG_ACQ_STOP_8197F 0x045C
#define REG_NDPA_RATE_8197F 0x045D
#define REG_TX_HANG_CTRL_8197F 0x045E
#define REG_NDPA_OPT_CTRL_8197F 0x045F
#define REG_RD_RESP_PKT_TH_8197F 0x0463
#define REG_CMDQ_INFO_8197F 0x0464
#define REG_Q4_INFO_8197F 0x0468
#define REG_Q5_INFO_8197F 0x046C
#define REG_Q6_INFO_8197F 0x0470
#define REG_Q7_INFO_8197F 0x0474
#define REG_WMAC_LBK_BUF_HD_V1_8197F 0x0478
#define REG_MGQ_BDNY_V1_8197F 0x047A
#define REG_TXRPT_CTRL_8197F 0x047C
#define REG_INIRTS_RATE_SEL_8197F 0x0480
#define REG_BASIC_CFEND_RATE_8197F 0x0481
#define REG_STBC_CFEND_RATE_8197F 0x0482
#define REG_DATA_SC_8197F 0x0483
#define REG_MACID_SLEEP3_8197F 0x0484
#define REG_MACID_SLEEP1_8197F 0x0488
#define REG_ARFR2_V1_8197F 0x048C
#define REG_ARFR3_V1_8197F 0x0494
#define REG_ARFR4_8197F 0x049C
#define REG_ARFR5_8197F 0x04A4
#define REG_TXRPT_START_OFFSET_8197F 0x04AC
#define REG_POWER_STAGE1_8197F 0x04B4
#define REG_POWER_STAGE2_8197F 0x04B8
#define REG_SW_AMPDU_BURST_MODE_CTRL_8197F 0x04BC
#define REG_PKT_LIFE_TIME_8197F 0x04C0
#define REG_STBC_SETTING_8197F 0x04C4
#define REG_STBC_SETTING2_8197F 0x04C5
#define REG_QUEUE_CTRL_8197F 0x04C6
#define REG_SINGLE_AMPDU_CTRL_8197F 0x04C7
#define REG_PROT_MODE_CTRL_8197F 0x04C8
#define REG_BAR_MODE_CTRL_8197F 0x04CC
#define REG_RA_TRY_RATE_AGG_LMT_8197F 0x04CF
#define REG_MACID_SLEEP2_8197F 0x04D0
#define REG_MACID_SLEEP_8197F 0x04D4
#define REG_HW_SEQ0_8197F 0x04D8
#define REG_HW_SEQ1_8197F 0x04DA
#define REG_HW_SEQ2_8197F 0x04DC
#define REG_HW_SEQ3_8197F 0x04DE
#define REG_NULL_PKT_STATUS_V1_8197F 0x04E0
#define REG_PTCL_ERR_STATUS_8197F 0x04E2
#define REG_NULL_PKT_STATUS_EXTEND_8197F 0x04E3
#define REG_VIDEO_ENHANCEMENT_FUN_8197F 0x04E4
#define REG_BT_POLLUTE_PKT_CNT_8197F 0x04E8
#define REG_PTCL_DBG_8197F 0x04EC
#define REG_TXOP_EXTRA_CTRL_8197F 0x04F0
#define REG_CPUMGQ_TIMER_CTRL2_8197F 0x04F4
#define REG_DUMMY_PAGE4_8197F 0x04FC
#define REG_Q0_Q1_INFO_8197F 0x1400
#define REG_Q2_Q3_INFO_8197F 0x1404
#define REG_Q4_Q5_INFO_8197F 0x1408
#define REG_Q6_Q7_INFO_8197F 0x140C
#define REG_MGQ_HIQ_INFO_8197F 0x1410
#define REG_CMDQ_BCNQ_INFO_8197F 0x1414
#define REG_USEREG_SETTING_8197F 0x1420
#define REG_AESIV_SETTING_8197F 0x1424
#define REG_BF0_TIME_SETTING_8197F 0x1428
#define REG_BF1_TIME_SETTING_8197F 0x142C
#define REG_BF_TIMEOUT_EN_8197F 0x1430
#define REG_MACID_RELEASE0_8197F 0x1434
#define REG_MACID_RELEASE1_8197F 0x1438
#define REG_MACID_RELEASE2_8197F 0x143C
#define REG_MACID_RELEASE3_8197F 0x1440
#define REG_MACID_RELEASE_SETTING_8197F 0x1444
#define REG_FAST_EDCA_VOVI_SETTING_8197F 0x1448
#define REG_FAST_EDCA_BEBK_SETTING_8197F 0x144C
#define REG_MACID_DROP0_8197F 0x1450
#define REG_MACID_DROP1_8197F 0x1454
#define REG_MACID_DROP2_8197F 0x1458
#define REG_MACID_DROP3_8197F 0x145C
#define REG_R_MACID_RELEASE_SUCCESS_0_8197F 0x1460
#define REG_R_MACID_RELEASE_SUCCESS_1_8197F 0x1464
#define REG_R_MACID_RELEASE_SUCCESS_2_8197F 0x1468
#define REG_R_MACID_RELEASE_SUCCESS_3_8197F 0x146C
#define REG_MGG_FIFO_CRTL_8197F 0x1470
#define REG_MGG_FIFO_INT_8197F 0x1474
#define REG_MGG_FIFO_LIFETIME_8197F 0x1478
#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8197F 0x147C
#define REG_SHCUT_SETTING_8197F 0x1480
#define REG_SHCUT_LLC_ETH_TYPE0_8197F 0x1484
#define REG_SHCUT_LLC_ETH_TYPE1_8197F 0x1488
#define REG_SHCUT_LLC_OUI0_8197F 0x148C
#define REG_SHCUT_LLC_OUI1_8197F 0x1490
#define REG_SHCUT_LLC_OUI2_8197F 0x1494
#define REG_SHCUT_LLC_OUI3_8197F 0x1498
#define REG_CHNL_INFO_CTRL_8197F 0x14D0
#define REG_CHNL_IDLE_TIME_8197F 0x14D4
#define REG_CHNL_BUSY_TIME_8197F 0x14D8
#define REG_EDCA_VO_PARAM_8197F 0x0500
#define REG_EDCA_VI_PARAM_8197F 0x0504
#define REG_EDCA_BE_PARAM_8197F 0x0508
#define REG_EDCA_BK_PARAM_8197F 0x050C
#define REG_BCNTCFG_8197F 0x0510
#define REG_PIFS_8197F 0x0512
#define REG_RDG_PIFS_8197F 0x0513
#define REG_SIFS_8197F 0x0514
#define REG_TSFTR_SYN_OFFSET_8197F 0x0518
#define REG_AGGR_BREAK_TIME_8197F 0x051A
#define REG_SLOT_8197F 0x051B
#define REG_TX_PTCL_CTRL_8197F 0x0520
#define REG_TXPAUSE_8197F 0x0522
#define REG_DIS_TXREQ_CLR_8197F 0x0523
#define REG_RD_CTRL_8197F 0x0524
#define REG_MBSSID_CTRL_8197F 0x0526
#define REG_P2PPS_CTRL_8197F 0x0527
#define REG_PKT_LIFETIME_CTRL_8197F 0x0528
#define REG_P2PPS_SPEC_STATE_8197F 0x052B
#define REG_QUEUE_INCOL_THR_8197F 0x0538
#define REG_QUEUE_INCOL_EN_8197F 0x053C
#define REG_TBTT_PROHIBIT_8197F 0x0540
#define REG_P2PPS_STATE_8197F 0x0543
#define REG_RD_NAV_NXT_8197F 0x0544
#define REG_NAV_PROT_LEN_8197F 0x0546
#define REG_FTM_CTRL_8197F 0x0548
#define REG_FTM_TSF_CNT_8197F 0x054C
#define REG_BCN_CTRL_8197F 0x0550
#define REG_BCN_CTRL_CLINT0_8197F 0x0551
#define REG_MBID_NUM_8197F 0x0552
#define REG_DUAL_TSF_RST_8197F 0x0553
#define REG_MBSSID_BCN_SPACE_8197F 0x0554
#define REG_DRVERLYINT_8197F 0x0558
#define REG_BCNDMATIM_8197F 0x0559
#define REG_ATIMWND_8197F 0x055A
#define REG_USTIME_TSF_8197F 0x055C
#define REG_BCN_MAX_ERR_8197F 0x055D
#define REG_RXTSF_OFFSET_CCK_8197F 0x055E
#define REG_RXTSF_OFFSET_OFDM_8197F 0x055F
#define REG_TSFTR_8197F 0x0560
#define REG_FREERUN_CNT_8197F 0x0568
#define REG_ATIMWND1_8197F 0x0570
#define REG_TBTT_PROHIBIT_INFRA_8197F 0x0571
#define REG_CTWND_8197F 0x0572
#define REG_BCNIVLCUNT_8197F 0x0573
#define REG_BCNDROPCTRL_8197F 0x0574
#define REG_HGQ_TIMEOUT_PERIOD_8197F 0x0575
#define REG_TXCMD_TIMEOUT_PERIOD_8197F 0x0576
#define REG_MISC_CTRL_8197F 0x0577
#define REG_BCN_CTRL_CLINT1_8197F 0x0578
#define REG_BCN_CTRL_CLINT2_8197F 0x0579
#define REG_BCN_CTRL_CLINT3_8197F 0x057A
#define REG_EXTEND_CTRL_8197F 0x057B
#define REG_P2PPS1_SPEC_STATE_8197F 0x057C
#define REG_P2PPS1_STATE_8197F 0x057D
#define REG_P2PPS2_SPEC_STATE_8197F 0x057E
#define REG_P2PPS2_STATE_8197F 0x057F
#define REG_PS_TIMER0_8197F 0x0580
#define REG_PS_TIMER1_8197F 0x0584
#define REG_PS_TIMER2_8197F 0x0588
#define REG_TBTT_CTN_AREA_8197F 0x058C
#define REG_FORCE_BCN_IFS_8197F 0x058E
#define REG_TXOP_MIN_8197F 0x0590
#define REG_PRE_BKF_TIME_8197F 0x0592
#define REG_CROSS_TXOP_CTRL_8197F 0x0593
#define REG_TBTT_INT_SHIFT_CLI0_8197F 0x0594
#define REG_TBTT_INT_SHIFT_CLI1_8197F 0x0595
#define REG_TBTT_INT_SHIFT_CLI2_8197F 0x0596
#define REG_TBTT_INT_SHIFT_CLI3_8197F 0x0597
#define REG_TBTT_INT_SHIFT_ENABLE_8197F 0x0598
#define REG_ATIMWND2_8197F 0x05A0
#define REG_ATIMWND3_8197F 0x05A1
#define REG_ATIMWND4_8197F 0x05A2
#define REG_ATIMWND5_8197F 0x05A3
#define REG_ATIMWND6_8197F 0x05A4
#define REG_ATIMWND7_8197F 0x05A5
#define REG_ATIMUGT_8197F 0x05A6
#define REG_HIQ_NO_LMT_EN_8197F 0x05A7
#define REG_DTIM_COUNTER_ROOT_8197F 0x05A8
#define REG_DTIM_COUNTER_VAP1_8197F 0x05A9
#define REG_DTIM_COUNTER_VAP2_8197F 0x05AA
#define REG_DTIM_COUNTER_VAP3_8197F 0x05AB
#define REG_DTIM_COUNTER_VAP4_8197F 0x05AC
#define REG_DTIM_COUNTER_VAP5_8197F 0x05AD
#define REG_DTIM_COUNTER_VAP6_8197F 0x05AE
#define REG_DTIM_COUNTER_VAP7_8197F 0x05AF
#define REG_DIS_ATIM_8197F 0x05B0
#define REG_EARLY_128US_8197F 0x05B1
#define REG_P2PPS1_CTRL_8197F 0x05B2
#define REG_P2PPS2_CTRL_8197F 0x05B3
#define REG_TIMER0_SRC_SEL_8197F 0x05B4
#define REG_NOA_UNIT_SEL_8197F 0x05B5
#define REG_P2POFF_DIS_TXTIME_8197F 0x05B7
#define REG_MBSSID_BCN_SPACE2_8197F 0x05B8
#define REG_MBSSID_BCN_SPACE3_8197F 0x05BC
#define REG_ACMHWCTRL_8197F 0x05C0
#define REG_ACMRSTCTRL_8197F 0x05C1
#define REG_ACMAVG_8197F 0x05C2
#define REG_VO_ADMTIME_8197F 0x05C4
#define REG_VI_ADMTIME_8197F 0x05C6
#define REG_BE_ADMTIME_8197F 0x05C8
#define REG_EDCA_RANDOM_GEN_8197F 0x05CC
#define REG_TXCMD_NOA_SEL_8197F 0x05CF
#define REG_NOA_PARAM_8197F 0x05E0
#define REG_P2P_RST_8197F 0x05F0
#define REG_SCHEDULER_RST_8197F 0x05F1
#define REG_SCH_TXCMD_8197F 0x05F8
#define REG_PAGE5_DUMMY_8197F 0x05FC
#define REG_CPUMGQ_TX_TIMER_8197F 0x1500
#define REG_PS_TIMER_A_8197F 0x1504
#define REG_PS_TIMER_B_8197F 0x1508
#define REG_PS_TIMER_C_8197F 0x150C
#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8197F 0x1510
#define REG_CPUMGQ_TX_TIMER_EARLY_8197F 0x1514
#define REG_PS_TIMER_A_EARLY_8197F 0x1515
#define REG_PS_TIMER_B_EARLY_8197F 0x1516
#define REG_PS_TIMER_C_EARLY_8197F 0x1517
#define REG_WMAC_CR_8197F 0x0600
#define REG_WMAC_FWPKT_CR_8197F 0x0601
#define REG_BWOPMODE_8197F 0x0603
#define REG_TCR_8197F 0x0604
#define REG_RCR_8197F 0x0608
#define REG_RX_PKT_LIMIT_8197F 0x060C
#define REG_RX_DLK_TIME_8197F 0x060D
#define REG_RX_DRVINFO_SZ_8197F 0x060F
#define REG_MACID_8197F 0x0610
#define REG_BSSID_8197F 0x0618
#define REG_MAR_8197F 0x0620
#define REG_MBIDCAMCFG_1_8197F 0x0628
#define REG_MBIDCAMCFG_2_8197F 0x062C
#define REG_WMAC_TCR_TSFT_OFS_8197F 0x0630
#define REG_UDF_THSD_8197F 0x0632
#define REG_ZLD_NUM_8197F 0x0633
#define REG_STMP_THSD_8197F 0x0634
#define REG_WMAC_TXTIMEOUT_8197F 0x0635
#define REG_MCU_TEST_2_V1_8197F 0x0636
#define REG_USTIME_EDCA_8197F 0x0638
#define REG_MAC_SPEC_SIFS_8197F 0x063A
#define REG_RESP_SIFS_CCK_8197F 0x063C
#define REG_RESP_SIFS_OFDM_8197F 0x063E
#define REG_ACKTO_8197F 0x0640
#define REG_CTS2TO_8197F 0x0641
#define REG_EIFS_8197F 0x0642
#define REG_NAV_CTRL_8197F 0x0650
#define REG_BACAMCMD_8197F 0x0654
#define REG_BACAMCONTENT_8197F 0x0658
#define REG_LBDLY_8197F 0x0660
#define REG_WMAC_BACAM_RPMEN_8197F 0x0661
#define REG_WMAC_BITMAP_CTL_8197F 0x0663
#define REG_RXERR_RPT_8197F 0x0664
#define REG_WMAC_TRXPTCL_CTL_8197F 0x0668
#define REG_CAMCMD_8197F 0x0670
#define REG_CAMWRITE_8197F 0x0674
#define REG_CAMREAD_8197F 0x0678
#define REG_CAMDBG_8197F 0x067C
#define REG_SECCFG_8197F 0x0680
#define REG_RXFILTER_CATEGORY_1_8197F 0x0682
#define REG_RXFILTER_ACTION_1_8197F 0x0683
#define REG_RXFILTER_CATEGORY_2_8197F 0x0684
#define REG_RXFILTER_ACTION_2_8197F 0x0685
#define REG_RXFILTER_CATEGORY_3_8197F 0x0686
#define REG_RXFILTER_ACTION_3_8197F 0x0687
#define REG_RXFLTMAP3_8197F 0x0688
#define REG_RXFLTMAP4_8197F 0x068A
#define REG_RXFLTMAP5_8197F 0x068C
#define REG_RXFLTMAP6_8197F 0x068E
#define REG_WOW_CTRL_8197F 0x0690
#define REG_PS_RX_INFO_8197F 0x0692
#define REG_WMMPS_UAPSD_TID_8197F 0x0693
#define REG_LPNAV_CTRL_8197F 0x0694
#define REG_WKFMCAM_CMD_8197F 0x0698
#define REG_WKFMCAM_RWD_8197F 0x069C
#define REG_RXFLTMAP0_8197F 0x06A0
#define REG_RXFLTMAP1_8197F 0x06A2
#define REG_RXFLTMAP_8197F 0x06A4
#define REG_BCN_PSR_RPT_8197F 0x06A8
#define REG_RXPKTMON_CTRL_8197F 0x06B0
#define REG_STATE_MON_8197F 0x06B4
#define REG_ERROR_MON_8197F 0x06B8
#define REG_SEARCH_MACID_8197F 0x06BC
#define REG_BT_COEX_TABLE_8197F 0x06C0
#define REG_RXCMD_0_8197F 0x06D0
#define REG_RXCMD_1_8197F 0x06D4
#define REG_WMAC_RESP_TXINFO_8197F 0x06D8
#define REG_BBPSF_CTRL_8197F 0x06DC
#define REG_P2P_RX_BCN_NOA_8197F 0x06E0
#define REG_ASSOCIATED_BFMER0_INFO_8197F 0x06E4
#define REG_ASSOCIATED_BFMER1_INFO_8197F 0x06EC
#define REG_TX_CSI_RPT_PARAM_BW20_8197F 0x06F4
#define REG_TX_CSI_RPT_PARAM_BW40_8197F 0x06F8
#define REG_TX_CSI_RPT_PARAM_BW80_8197F 0x06FC
#define REG_BCN_PSR_RPT2_8197F 0x1600
#define REG_BCN_PSR_RPT3_8197F 0x1604
#define REG_BCN_PSR_RPT4_8197F 0x1608
#define REG_A1_ADDR_MASK_8197F 0x160C
#define REG_MACID2_8197F 0x1620
#define REG_BSSID2_8197F 0x1628
#define REG_MACID3_8197F 0x1630
#define REG_BSSID3_8197F 0x1638
#define REG_MACID4_8197F 0x1640
#define REG_BSSID4_8197F 0x1648
#define REG_NOA_REPORT_8197F 0x1650
#define REG_PWRBIT_SETTING_8197F 0x1660
#define REG_WMAC_MU_BF_OPTION_8197F 0x167C
#define REG_WMAC_PAUSE_BB_CLR_TH_8197F 0x167D
#define REG_WMAC_MU_ARB_8197F 0x167E
#define REG_WMAC_MU_OPTION_8197F 0x167F
#define REG_WMAC_MU_BF_CTL_8197F 0x1680
#define REG_WMAC_MU_BFRPT_PARA_8197F 0x1682
#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8197F 0x1684
#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8197F 0x1686
#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8197F 0x1688
#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8197F 0x168A
#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8197F 0x168C
#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8197F 0x168E
#define REG_TRANSMIT_ADDRSS_0_8197F 0x16A0
#define REG_TRANSMIT_ADDRSS_1_8197F 0x16A8
#define REG_TRANSMIT_ADDRSS_2_8197F 0x16B0
#define REG_TRANSMIT_ADDRSS_3_8197F 0x16B8
#define REG_TRANSMIT_ADDRSS_4_8197F 0x16C0
#define REG_MACID1_8197F 0x0700
#define REG_BSSID1_8197F 0x0708
#define REG_BCN_PSR_RPT1_8197F 0x0710
#define REG_ASSOCIATED_BFMEE_SEL_8197F 0x0714
#define REG_SND_PTCL_CTRL_8197F 0x0718
#define REG_RX_CSI_RPT_INFO_8197F 0x071C
#define REG_NS_ARP_CTRL_8197F 0x0720
#define REG_NS_ARP_INFO_8197F 0x0724
#define REG_BEAMFORMING_INFO_NSARP_V1_8197F 0x0728
#define REG_BEAMFORMING_INFO_NSARP_8197F 0x072C
#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8197F 0x0750
#define REG_WMAC_SWAES_CFG_8197F 0x0760
#define REG_BT_COEX_V2_8197F 0x0762
#define REG_BT_COEX_8197F 0x0764
#define REG_WLAN_ACT_MASK_CTRL_8197F 0x0768
#define REG_BT_COEX_ENHANCED_INTR_CTRL_8197F 0x076E
#define REG_BT_ACT_STATISTICS_8197F 0x0770
#define REG_BT_STATISTICS_CONTROL_REGISTER_8197F 0x0778
#define REG_BT_STATUS_REPORT_REGISTER_8197F 0x077C
#define REG_BT_INTERRUPT_CONTROL_REGISTER_8197F 0x0780
#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8197F 0x0784
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8197F 0x0785
#define REG_BT_INTERRUPT_STATUS_REGISTER_8197F 0x078F
#define REG_BT_TDMA_TIME_REGISTER_8197F 0x0790
#define REG_BT_ACT_REGISTER_8197F 0x0794
#define REG_OBFF_CTRL_BASIC_8197F 0x0798
#define REG_OBFF_CTRL2_TIMER_8197F 0x079C
#define REG_LTR_CTRL_BASIC_8197F 0x07A0
#define REG_LTR_CTRL2_TIMER_THRESHOLD_8197F 0x07A4
#define REG_LTR_IDLE_LATENCY_V1_8197F 0x07A8
#define REG_LTR_ACTIVE_LATENCY_V1_8197F 0x07AC
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8197F 0x07B0
#define REG_WMAC_PKTCNT_RWD_8197F 0x07B8
#define REG_WMAC_PKTCNT_CTRL_8197F 0x07BC
#define REG_IQ_DUMP_8197F 0x07C0
#define REG_WMAC_FTM_CTL_8197F 0x07CC
#define REG_IQ_DUMP_EXT_8197F 0x07CF
#define REG_OFDM_CCK_LEN_MASK_8197F 0x07D0
#define REG_RX_FILTER_FUNCTION_8197F 0x07DA
#define REG_NDP_SIG_8197F 0x07E0
#define REG_TXCMD_INFO_FOR_RSP_PKT_8197F 0x07E4
#define REG_SEC_OPT_V2_8197F 0x07EC
#define REG_RTS_ADDRESS_0_8197F 0x07F0
#define REG_RTS_ADDRESS_1_8197F 0x07F8
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8197F 0x1700
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8197F 0x1704
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8197F 0x1708
#endif
================================================
FILE: hal/halmac/halmac_reg_8814b.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_REG_8814B_H
#define __INC_HALMAC_REG_8814B_H
#define REG_SYS_ISO_CTRL_8814B 0x0000
#define REG_SYS_FUNC_EN_8814B 0x0002
#define REG_SYS_PW_CTRL_8814B 0x0004
#define REG_SYS_CLK_CTRL_8814B 0x0008
#define REG_SYS_EEPROM_CTRL_8814B 0x000A
#define REG_EE_VPD_8814B 0x000C
#define REG_SYS_SWR_CTRL1_8814B 0x0010
#define REG_SYS_SWR_CTRL2_8814B 0x0014
#define REG_SYS_SWR_CTRL3_8814B 0x0018
#define REG_RSV_CTRL_8814B 0x001C
#define REG_RF_CTRL_8814B 0x001F
#define REG_AFE_LDO_CTRL_8814B 0x0020
#define REG_AFE_CTRL1_8814B 0x0024
#define REG_ANAPARSW_POW_MAC_8814B 0x0028
#define REG_ANAPARLDO_POW_MAC_8814B 0x0029
#define REG_ANAPAR_POW_MAC_8814B 0x002A
#define REG_ANAPAR_POW_XTAL_8814B 0x002B
#define REG_ANAPARLDO_MAC_8814B 0x002C
#define REG_EFUSE_CTRL_8814B 0x0030
#define REG_LDO_EFUSE_CTRL_8814B 0x0034
#define REG_PWR_OPTION_CTRL_8814B 0x0038
#define REG_CAL_TIMER_8814B 0x003C
#define REG_ACLK_MON_8814B 0x003E
#define REG_GPIO_MUXCFG_8814B 0x0040
#define REG_GPIO_PIN_CTRL_8814B 0x0044
#define REG_GPIO_INTM_8814B 0x0048
#define REG_LED_CFG_8814B 0x004C
#define REG_FSIMR_8814B 0x0050
#define REG_FSISR_8814B 0x0054
#define REG_HSIMR_8814B 0x0058
#define REG_HSISR_8814B 0x005C
#define REG_GPIO_EXT_CTRL_8814B 0x0060
#define REG_PAD_CTRL1_8814B 0x0064
#define REG_WL_BT_PWR_CTRL_8814B 0x0068
#define REG_SDM_DEBUG_8814B 0x006C
#define REG_SYS_SDIO_CTRL_8814B 0x0070
#define REG_HCI_OPT_CTRL_8814B 0x0074
#define REG_AFE_CTRL4_8814B 0x0078
#define REG_LDO_SWR_CTRL_8814B 0x007C
#define REG_MCUFW_CTRL_8814B 0x0080
#define REG_MCU_TST_CFG_8814B 0x0084
#define REG_HMEBOX_E0_E1_8814B 0x0088
#define REG_HMEBOX_E2_E3_8814B 0x008C
#define REG_WLLPS_CTRL_8814B 0x0090
#define REG_AFE_CTRL5_8814B 0x0094
#define REG_GPIO_DEBOUNCE_CTRL_8814B 0x0098
#define REG_RPWM2_8814B 0x009C
#define REG_SYSON_FSM_MON_8814B 0x00A0
#define REG_AFE_CTRL6_8814B 0x00A4
#define REG_PMC_DBG_CTRL1_8814B 0x00A8
#define REG_AFE_CTRL7_8814B 0x00AC
#define REG_HIMR0_8814B 0x00B0
#define REG_HISR0_8814B 0x00B4
#define REG_HIMR1_8814B 0x00B8
#define REG_HISR1_8814B 0x00BC
#define REG_DBG_PORT_SEL_8814B 0x00C0
#define REG_PAD_CTRL2_8814B 0x00C4
#define REG_PMC_DBG_CTRL2_8814B 0x00CC
#define REG_MEM_CTRL_8814B 0x00D8
#define REG_SYN_RFC_CTRL_8814B 0x00DC
#define REG_USB_SIE_INTF_8814B 0x00E0
#define REG_PCIE_MIO_INTF_8814B 0x00E4
#define REG_PCIE_MIO_INTD_8814B 0x00E8
#define REG_WLRF1_8814B 0x00EC
#define REG_SYS_CFG1_8814B 0x00F0
#define REG_SYS_STATUS1_8814B 0x00F4
#define REG_SYS_STATUS2_8814B 0x00F8
#define REG_SYS_CFG2_8814B 0x00FC
#define REG_ANAPARSW_MAC_0_8814B 0x1010
#define REG_ANAPARSW_MAC_1_8814B 0x1014
#define REG_ANAPAR_MAC_0_8814B 0x1018
#define REG_ANAPAR_MAC_1_8814B 0x101C
#define REG_ANAPAR_MAC_2_8814B 0x1020
#define REG_ANAPAR_MAC_3_8814B 0x1024
#define REG_ANAPAR_MAC_4_8814B 0x1028
#define REG_ANAPAR_MAC_5_8814B 0x102C
#define REG_ANAPAR_MAC_6_8814B 0x1030
#define REG_ANAPAR_MAC_7_8814B 0x1034
#define REG_ANAPAR_MAC_8_8814B 0x1038
#define REG_ANAPAR_XTAL_0_8814B 0x1040
#define REG_ANAPAR_XTAL_1_8814B 0x1044
#define REG_ANAPAR_XTAL_2_8814B 0x1048
#define REG_ANAPAR_XTAL_AAC_8814B 0x104C
#define REG_ANAPAR_XTAL_R_ONLY_8814B 0x1050
#define REG_CPHY_LDO_8814B 0x1054
#define REG_CPHY_BG_8814B 0x1058
#define REG_HIMR_4_8814B 0x1060
#define REG_HISR_4_8814B 0x1064
#define REG_HIMR_5_8814B 0x1068
#define REG_HISR_5_8814B 0x106C
#define REG_SYS_CFG5_8814B 0x1070
#define REG_HIMR_6_8814B 0x1078
#define REG_HISR_6_8814B 0x107C
#define REG_CPU_DMEM_CON_8814B 0x1080
#define REG_BOOT_REASON_8814B 0x1088
#define REG_DATA_CPU_CTL0_8814B 0x1090
#define REG_DATA_CPU_CTL1_8814B 0x1094
#define REG_TXDMA_STOP_HIMR_8814B 0x1098
#define REG_TXDMA_STOP_HISR_8814B 0x109C
#define REG_TXDMA_START_HIMR_8814B 0x10A0
#define REG_TXDMA_START_HISR_8814B 0x10A4
#define REG_NFCPAD_CTRL_8814B 0x10A8
#define REG_HIMR2_8814B 0x10B0
#define REG_HISR2_8814B 0x10B4
#define REG_HIMR3_8814B 0x10B8
#define REG_HISR3_8814B 0x10BC
#define REG_SW_MDIO_8814B 0x10C0
#define REG_HIMR_7_8814B 0x10C8
#define REG_HISR_7_8814B 0x10CC
#define REG_H2C_PKT_READADDR_8814B 0x10D0
#define REG_H2C_PKT_WRITEADDR_8814B 0x10D4
#define REG_MEM_PWR_CRTL_8814B 0x10D8
#define REG_FW_DRV_HANDSHAKE_8814B 0x10DC
#define REG_FW_DBG0_8814B 0x10E0
#define REG_FW_DBG1_8814B 0x10E4
#define REG_FW_DBG2_8814B 0x10E8
#define REG_FW_DBG3_8814B 0x10EC
#define REG_FW_DBG4_8814B 0x10F0
#define REG_FW_DBG5_8814B 0x10F4
#define REG_FW_DBG6_8814B 0x10F8
#define REG_FW_DBG7_8814B 0x10FC
#define REG_CR_8814B 0x0100
#define REG_PG_SIZE_8814B 0x0104
#define REG_PKT_BUFF_ACCESS_CTRL_8814B 0x0106
#define REG_TSF_CLK_STATE_8814B 0x0108
#define REG_TXDMA_PQ_MAP_8814B 0x010C
#define REG_TRXFF_BNDY_8814B 0x0114
#define REG_PTA_I2C_MBOX_8814B 0x0118
#define REG_RXFF_BNDY_8814B 0x011C
#define REG_FE1IMR_8814B 0x0120
#define REG_FE1ISR_8814B 0x0124
#define REG_CPWM_8814B 0x012C
#define REG_FWIMR_8814B 0x0130
#define REG_FWISR_8814B 0x0134
#define REG_FTIMR_8814B 0x0138
#define REG_FTISR_8814B 0x013C
#define REG_PKTBUF_DBG_CTRL_8814B 0x0140
#define REG_PKTBUF_DBG_DATA_L_8814B 0x0144
#define REG_PKTBUF_DBG_DATA_H_8814B 0x0148
#define REG_CPWM2_8814B 0x014C
#define REG_TC0_CTRL_8814B 0x0150
#define REG_TC1_CTRL_8814B 0x0154
#define REG_TC2_CTRL_8814B 0x0158
#define REG_TC3_CTRL_8814B 0x015C
#define REG_TC4_CTRL_8814B 0x0160
#define REG_TCUNIT_BASE_8814B 0x0164
#define REG_TC5_CTRL_8814B 0x0168
#define REG_TC6_CTRL_8814B 0x016C
#define REG_AES_DECRPT_DATA_8814B 0x0180
#define REG_AES_DECRPT_CFG_8814B 0x0184
#define REG_HIOE_CTRL_8814B 0x0188
#define REG_HIOE_CFG_FILE_8814B 0x018C
#define REG_TMETER_8814B 0x0190
#define REG_OSC_32K_CTRL_8814B 0x0194
#define REG_32K_CAL_REG1_8814B 0x0198
#define REG_C2HEVT_8814B 0x01A0
#define REG_C2HEVT_1_8814B 0x01A4
#define REG_C2HEVT_2_8814B 0x01A8
#define REG_C2HEVT_3_8814B 0x01AC
#define REG_RXDESC_BUFF_RPTR_8814B 0x01B0
#define REG_RXDESC_BUFF_WPTR_8814B 0x01B4
#define REG_SW_DEFINED_PAGE1_8814B 0x01B8
#define REG_SW_DEFINED_PAGE2_8814B 0x01BC
#define REG_MCUTST_I_8814B 0x01C0
#define REG_MCUTST_II_8814B 0x01C4
#define REG_FMETHR_8814B 0x01C8
#define REG_HMETFR_8814B 0x01CC
#define REG_HMEBOX0_8814B 0x01D0
#define REG_HMEBOX1_8814B 0x01D4
#define REG_HMEBOX2_8814B 0x01D8
#define REG_HMEBOX3_8814B 0x01DC
#define REG_RXDESC_BUFF_BNDY_8814B 0x01E0
#define REG_BB_ACCESS_CTRL_8814B 0x01E8
#define REG_BB_ACCESS_DATA_8814B 0x01EC
#define REG_HMEBOX_E0_8814B 0x01F0
#define REG_HMEBOX_E1_8814B 0x01F4
#define REG_HMEBOX_E2_8814B 0x01F8
#define REG_HMEBOX_E3_8814B 0x01FC
#define REG_CR_EXT_8814B 0x1100
#define REG_TC9_CTRL_8814B 0x1104
#define REG_TC10_CTRL_8814B 0x1108
#define REG_TC11_CTRL_8814B 0x110C
#define REG_TC12_CTRL_8814B 0x1110
#define REG_FWFF_8814B 0x1114
#define REG_RXFF_PTR_V1_8814B 0x1118
#define REG_RXFF_WTR_V1_8814B 0x111C
#define REG_FE2IMR_8814B 0x1120
#define REG_FE2ISR_8814B 0x1124
#define REG_FE3IMR_8814B 0x1128
#define REG_FE3ISR_8814B 0x112C
#define REG_FE4IMR_8814B 0x1130
#define REG_FE4ISR_8814B 0x1134
#define REG_FT1IMR_8814B 0x1138
#define REG_FT1ISR_8814B 0x113C
#define REG_SPWR0_8814B 0x1140
#define REG_SPWR1_8814B 0x1144
#define REG_SPWR2_8814B 0x1148
#define REG_SPWR3_8814B 0x114C
#define REG_POWSEQ_8814B 0x1150
#define REG_TC7_CTRL_V1_8814B 0x1158
#define REG_TC8_CTRL_V1_8814B 0x115C
#define REG_RX_BCN_TBTT_ITVL0_8814B 0x1160
#define REG_RX_BCN_TBTT_ITVL1_8814B 0x1164
#define REG_FWIMR1_8814B 0x1168
#define REG_FWISR1_8814B 0x116C
#define REG_FWIMR2_8814B 0x1170
#define REG_FWISR2_8814B 0x1174
#define REG_FWIMR3_8814B 0x1178
#define REG_FWISR3_8814B 0x117C
#define REG_SPEED_SENSOR_8814B 0x1180
#define REG_SPEED_SENSOR1_8814B 0x1184
#define REG_SPEED_SENSOR2_8814B 0x1188
#define REG_SPEED_SENSOR3_8814B 0x118C
#define REG_SPEED_SENSOR4_8814B 0x1190
#define REG_SPEED_SENSOR5_8814B 0x1194
#define REG_RXPKTBUF_1_MAX_ADDR_8814B 0x1198
#define REG_RXFWBUF_1_MAX_ADDR_8814B 0x119C
#define REG_IO_WRAP_ERR_FLAG_V1_8814B 0x11A0
#define REG_RXPKTBUF_1_READ_8814B 0x11A4
#define REG_RXPKTBUF_1_WRITE_8814B 0x11A8
#define REG_BUFF_DBGUG_8814B 0x11AC
#define REG_RFE_CTRL_PAD_E2_8814B 0x11B0
#define REG_RFE_CTRL_PAD_SR_8814B 0x11B4
#define REG_H2C_PRIORITY_SEL_8814B 0x11C0
#define REG_COUNTER_CTRL_8814B 0x11C4
#define REG_COUNTER_THRESHOLD_8814B 0x11C8
#define REG_COUNTER_SET_8814B 0x11CC
#define REG_COUNTER_OVERFLOW_8814B 0x11D0
#define REG_TXDMA_LEN_THRESHOLD_8814B 0x11D4
#define REG_RXDMA_LEN_THRESHOLD_8814B 0x11D8
#define REG_PCIE_EXEC_TIME_THRESHOLD_8814B 0x11DC
#define REG_FT2IMR_8814B 0x11E0
#define REG_FT2ISR_8814B 0x11E4
#define REG_MSG2_8814B 0x11F0
#define REG_MSG3_8814B 0x11F4
#define REG_MSG4_8814B 0x11F8
#define REG_MSG5_8814B 0x11FC
#define REG_BIST_RSTN0_8814B 0x2100
#define REG_BIST_RSTN2_8814B 0x2108
#define REG_BIST_MODE_NRML0_8814B 0x2110
#define REG_BIST_MODE_NRML1_8814B 0x2114
#define REG_BIST_MODE_NRML2_8814B 0x2118
#define REG_BIST_MODE_NRML3_8814B 0x211C
#define REG_BIST_DONE_NRML_MAC_8814B 0x2150
#define REG_BIST_DONE_NRML1_8814B 0x2158
#define REG_BIST_DONE_DRF_MAC_8814B 0x2160
#define REG_BIST_DONE_DRF_8814B 0x2164
#define REG_BIST_DONE_DRF1_8814B 0x2168
#define REG_BIST_FAIL_NRML_MAC_8814B 0x2170
#define REG_BIST_FAIL_NRML_8814B 0x2174
#define REG_BIST_FAIL_NRML1_8814B 0x2178
#define REG_BIST_FAIL_NRML_MAC_V1_8814B 0x2180
#define REG_BIST_FAIL_NRML_V1_8814B 0x2184
#define REG_BIST_FAIL_NRML1_V1_8814B 0x2188
#define REG_BIST_MISR_DATAOUT_8814B 0x2190
#define REG_BIST_MISR_DATAOUT1_8814B 0x2194
#define REG_BIST_MISR_DATAOUT_CPU_8814B 0x2198
#define REG_BIST_MISR_DATAOUT_CPU1_8814B 0x219C
#define REG_BIST_MISR_DATAOUT_CPU2_8814B 0x21A0
#define REG_BIST_MISR_DATOUT_CPU3_8814B 0x21A4
#define REG_BCN_CTRL_0_8814B 0x0200
#define REG_BCN_CTRL_1_8814B 0x0204
#define REG_AUTO_LLT_V1_8814B 0x0208
#define REG_TXDMA_OFFSET_CHK_8814B 0x020C
#define REG_TXDMA_STATUS_8814B 0x0210
#define REG_TX_DMA_DBG_8814B 0x0214
#define REG_DMA_RQPN_INFO_PUB_8814B 0x0218
#define REG_RQPN_CTRL_2_V1_8814B 0x021C
#define REG_BCN_CTRL_2_8814B 0x0220
#define REG_TXPKTNUM_0_8814B 0x0230
#define REG_TXPKTNUM_1_8814B 0x0234
#define REG_TXPKTNUM_2_8814B 0x0238
#define REG_TXPKTNUM_3_8814B 0x023C
#define REG_TX_AGG_ALIGN_8814B 0x0240
#define REG_H2C_HEAD_8814B 0x0244
#define REG_H2C_TAIL_8814B 0x0248
#define REG_H2C_READ_ADDR_8814B 0x024C
#define REG_H2C_WR_ADDR_8814B 0x0250
#define REG_H2C_INFO_8814B 0x0254
#define REG_DMA_OQT_0_8814B 0x0260
#define REG_DMA_OQT_1_8814B 0x0264
#define REG_RXDMA_AGG_PG_TH_8814B 0x0280
#define REG_RXDMA_CTRL_8814B 0x0284
#define REG_RXDMA_STATUS_8814B 0x0288
#define REG_RXDMA_DPR_8814B 0x028C
#define REG_RXDMA_MODE_8814B 0x0290
#define REG_C2H_PKT_8814B 0x0294
#define REG_FWFF_C2H_8814B 0x0298
#define REG_FWFF_CTRL_8814B 0x029C
#define REG_FWFF_PKT_INFO_8814B 0x02A0
#define REG_FWFF_PKT_INFO2_8814B 0x02A4
#define REG_RXPKTNUM_8814B 0x02B0
#define REG_RXPKTNUM_TH_8814B 0x02B4
#define REG_FW_UPD_RXDES_RDPTR_8814B 0x02B8
#define REG_DDMA_CH0SA_8814B 0x1200
#define REG_DDMA_CH0DA_8814B 0x1204
#define REG_DDMA_CH0CTRL_8814B 0x1208
#define REG_DDMA_CH1SA_8814B 0x1210
#define REG_DDMA_CH1DA_8814B 0x1214
#define REG_DDMA_CH1CTRL_8814B 0x1218
#define REG_DDMA_CH2SA_8814B 0x1220
#define REG_DDMA_CH2DA_8814B 0x1224
#define REG_DDMA_CH2CTRL_8814B 0x1228
#define REG_DDMA_CH3SA_8814B 0x1230
#define REG_DDMA_CH3DA_8814B 0x1234
#define REG_DDMA_CH3CTRL_8814B 0x1238
#define REG_DDMA_CH4SA_8814B 0x1240
#define REG_DDMA_CH4DA_8814B 0x1244
#define REG_DDMA_CH4CTRL_8814B 0x1248
#define REG_DDMA_CH5SA_8814B 0x1250
#define REG_DDMA_CH5DA_8814B 0x1254
#define REG_DDMA_CH5CTRL_8814B 0x1258
#define REG_DDMA_INT_MSK_8814B 0x12E0
#define REG_DDMA_CHSTATUS_8814B 0x12E8
#define REG_DDMA_CHKSUM_8814B 0x12F0
#define REG_DDMA_MONITOR_8814B 0x12FC
#define REG_DMA_RQPN_INFO_0_8814B 0x2200
#define REG_DMA_RQPN_INFO_1_8814B 0x2204
#define REG_DMA_RQPN_INFO_2_8814B 0x2208
#define REG_DMA_RQPN_INFO_3_8814B 0x220C
#define REG_DMA_RQPN_INFO_4_8814B 0x2210
#define REG_DMA_RQPN_INFO_5_8814B 0x2214
#define REG_DMA_RQPN_INFO_6_8814B 0x2218
#define REG_DMA_RQPN_INFO_7_8814B 0x221C
#define REG_DMA_RQPN_INFO_8_8814B 0x2220
#define REG_DMA_RQPN_INFO_9_8814B 0x2224
#define REG_DMA_RQPN_INFO_10_8814B 0x2228
#define REG_DMA_RQPN_INFO_11_8814B 0x222C
#define REG_DMA_RQPN_INFO_12_8814B 0x2230
#define REG_DMA_RQPN_INFO_13_8814B 0x2234
#define REG_DMA_RQPN_INFO_14_8814B 0x2238
#define REG_DMA_RQPN_INFO_15_8814B 0x223C
#define REG_DMA_RQPN_INFO_16_8814B 0x2240
#define REG_HWAMSDU_CTL1_8814B 0x2250
#define REG_HWAMSDU_CTL2_8814B 0x2254
#define REG_TXPAGE_INT_CTRL_0_8814B 0x3200
#define REG_TXPAGE_INT_CTRL_1_8814B 0x3204
#define REG_TXPAGE_INT_CTRL_2_8814B 0x3208
#define REG_TXPAGE_INT_CTRL_3_8814B 0x320C
#define REG_TXPAGE_INT_CTRL_4_8814B 0x3210
#define REG_TXPAGE_INT_CTRL_5_8814B 0x3214
#define REG_TXPAGE_INT_CTRL_6_8814B 0x3218
#define REG_TXPAGE_INT_CTRL_7_8814B 0x321C
#define REG_TXPAGE_INT_CTRL_8_8814B 0x3220
#define REG_TXPAGE_INT_CTRL_9_8814B 0x3224
#define REG_TXPAGE_INT_CTRL_10_8814B 0x3228
#define REG_TXPAGE_INT_CTRL_11_8814B 0x322C
#define REG_TXPAGE_INT_CTRL_12_8814B 0x3230
#define REG_TXPAGE_INT_CTRL_13_8814B 0x3234
#define REG_TXPAGE_INT_CTRL_14_8814B 0x3238
#define REG_TXPAGE_INT_CTRL_15_8814B 0x323C
#define REG_TXPAGE_INT_CTRL_16_8814B 0x3240
#define REG_PCIE_CTRL_8814B 0x0300
#define REG_ACH_CTRL_8814B 0x0304
#define REG_HIQ_CTRL_8814B 0x0308
#define REG_INT_MIG_V1_8814B 0x030C
#define REG_P0MGQ_TXBD_DESA_L_8814B 0x0310
#define REG_P0MGQ_TXBD_DESA_H_8814B 0x0314
#define REG_ACH0_TXBD_DESA_L_8814B 0x0318
#define REG_ACH0_TXBD_DESA_H_8814B 0x031C
#define REG_ACH1_TXBD_DESA_L_8814B 0x0320
#define REG_ACH1_TXBD_DESA_H_8814B 0x0324
#define REG_ACH2_TXBD_DESA_L_8814B 0x0328
#define REG_ACH2_TXBD_DESA_H_8814B 0x032C
#define REG_ACH3_TXBD_DESA_L_8814B 0x0330
#define REG_ACH3_TXBD_DESA_H_8814B 0x0334
#define REG_P0RXQ_RXBD_DESA_L_8814B 0x0338
#define REG_P0RXQ_RXBD_DESA_H_8814B 0x033C
#define REG_P0BCNQ_TXBD_DESA_L_8814B 0x0340
#define REG_P0BCNQ_TXBD_DESA_H_8814B 0x0344
#define REG_FWCMDQ_TXBD_DESA_L_8814B 0x0348
#define REG_FWCMDQ_TXBD_DESA_H_8814B 0x034C
#define REG_PCIE_HRPWM1_HCPWM1_DCPU_8814B 0x0354
#define REG_P0_MPRT_BCNQ_TXBD_DESA_L_8814B 0x0358
#define REG_P0_MPRT_BCNQ_TXBD_DESA_H_8814B 0x035C
#define REG_P0_MPRT_BCNQ_TXRXBD_NUM_8814B 0x036C
#define REG_BD_RWPTR_CLR2_8814B 0x0370
#define REG_BD_RWPTR_CLR3_8814B 0x0374
#define REG_P0MGQ_RXQ_TXRXBD_NUM_8814B 0x0378
#define REG_CHNL_DMA_CFG_8814B 0x037C
#define REG_FWCMDQ_TXBD_NUM_8814B 0x0380
#define REG_ACH0_ACH1_TXBD_NUM_8814B 0x0384
#define REG_ACH2_ACH3_TXBD_NUM_8814B 0x0388
#define REG_P0HI0Q_HI1Q_TXBD_NUM_8814B 0x038C
#define REG_P0HI2Q_HI3Q_TXBD_NUM_8814B 0x0390
#define REG_P0HI4Q_HI5Q_TXBD_NUM_8814B 0x0394
#define REG_P0HI6Q_HI7Q_TXBD_NUM_8814B 0x0398
#define REG_BD_RWPTR_CLR1_8814B 0x039C
#define REG_TSFTIMER_HCI_8814B 0x039C
#define REG_ACH0_TXBD_IDX_8814B 0x03A0
#define REG_ACH1_TXBD_IDX_8814B 0x03A4
#define REG_ACH2_TXBD_IDX_8814B 0x03A8
#define REG_ACH3_TXBD_IDX_8814B 0x03AC
#define REG_P0MGQ_TXBD_IDX_8814B 0x03B0
#define REG_P0RXQ_RXBD_IDX_8814B 0x03B4
#define REG_P0HI0Q_TXBD_IDX_8814B 0x03B8
#define REG_P0HI1Q_TXBD_IDX_8814B 0x03BC
#define REG_P0HI2Q_TXBD_IDX_8814B 0x03C0
#define REG_P0HI3Q_TXBD_IDX_8814B 0x03C4
#define REG_P0HI4Q_TXBD_IDX_8814B 0x03C8
#define REG_P0HI5Q_TXBD_IDX_8814B 0x03CC
#define REG_P0HI6Q_TXBD_IDX_8814B 0x03D0
#define REG_P0HI7Q_TXBD_IDX_8814B 0x03D4
#define REG_DBGSEL_PCIE_HRPWM1_HCPWM1_V1_8814B 0x03D8
#define REG_PCIE_HRPWM2_HCPWM2_V1_8814B 0x03DC
#define REG_PCIE_H2C_MSG_V1_8814B 0x03E0
#define REG_PCIE_C2H_MSG_V1_8814B 0x03E4
#define REG_DBI_WDATA_V1_8814B 0x03E8
#define REG_DBI_RDATA_V1_8814B 0x03EC
#define REG_DBI_FLAG_V1_8814B 0x03F0
#define REG_MDIO_V1_8814B 0x03F4
#define REG_PCIE_MIX_CFG_8814B 0x03F8
#define REG_HCI_MIX_CFG_8814B 0x03FC
#define REG_STC_INT_CS_8814B 0x1300
#define REG_ST_INT_CFG_8814B 0x1304
#define REG_ACH4_ACH5_TXBD_NUM_8814B 0x130C
#define REG_FWCMDQ_TXBD_IDX_8814B 0x1318
#define REG_P0HI8Q_TXBD_IDX_8814B 0x131C
#define REG_H2CQ_TXBD_DESA_L_8814B 0x1320
#define REG_H2CQ_TXBD_DESA_H_8814B 0x1324
#define REG_H2CQ_TXBD_NUM_8814B 0x1328
#define REG_H2CQ_TXBD_IDX_8814B 0x132C
#define REG_H2CQ_CSR_8814B 0x1330
#define REG_P0HI9Q_TXBD_IDX_8814B 0x1334
#define REG_P0HI10Q_TXBD_IDX_8814B 0x1338
#define REG_P0HI11Q_TXBD_IDX_8814B 0x133C
#define REG_P0HI12Q_TXBD_IDX_8814B 0x1340
#define REG_P0HI13Q_TXBD_IDX_8814B 0x1344
#define REG_P0HI14Q_TXBD_IDX_8814B 0x1348
#define REG_P0HI15Q_TXBD_IDX_8814B 0x134C
#define REG_CHANGE_PCIE_SPEED_8814B 0x1350
#define REG_DEBUG_STATE1_8814B 0x1354
#define REG_DEBUG_STATE2_8814B 0x1358
#define REG_DEBUG_STATE3_8814B 0x135C
#define REG_ACH5_TXBD_DESA_L_8814B 0x1360
#define REG_ACH5_TXBD_DESA_H_8814B 0x1364
#define REG_ACH6_TXBD_DESA_L_8814B 0x1368
#define REG_ACH6_TXBD_DESA_H_8814B 0x136C
#define REG_ACH7_TXBD_DESA_L_8814B 0x1370
#define REG_ACH7_TXBD_DESA_H_8814B 0x1374
#define REG_ACH8_TXBD_DESA_L_8814B 0x1378
#define REG_ACH8_TXBD_DESA_H_8814B 0x137C
#define REG_ACH9_TXBD_DESA_L_8814B 0x1380
#define REG_ACH9_TXBD_DESA_H_8814B 0x1384
#define REG_ACH10_TXBD_DESA_L_8814B 0x1388
#define REG_ACH10_TXBD_DESA_H_8814B 0x138C
#define REG_ACH11_TXBD_DESA_L_8814B 0x1390
#define REG_ACH11_TXBD_DESA_H_8814B 0x1394
#define REG_ACH12_TXBD_DESA_L_8814B 0x1398
#define REG_ACH12_TXBD_DESA_H_8814B 0x139C
#define REG_ACH13_TXBD_DESA_L_8814B 0x13A0
#define REG_ACH13_TXBD_DESA_H_8814B 0x13A4
#define REG_HI0Q_TXBD_DESA_L_8814B 0x13A8
#define REG_HI0Q_TXBD_DESA_H_8814B 0x13AC
#define REG_HI1Q_TXBD_DESA_L_8814B 0x13B0
#define REG_HI1Q_TXBD_DESA_H_8814B 0x13B4
#define REG_HI2Q_TXBD_DESA_L_8814B 0x13B8
#define REG_HI2Q_TXBD_DESA_H_8814B 0x13BC
#define REG_HI3Q_TXBD_DESA_L_8814B 0x13C0
#define REG_HI3Q_TXBD_DESA_H_8814B 0x13C4
#define REG_HI4Q_TXBD_DESA_L_8814B 0x13C8
#define REG_HI4Q_TXBD_DESA_H_8814B 0x13CC
#define REG_HI5Q_TXBD_DESA_L_8814B 0x13D0
#define REG_HI5Q_TXBD_DESA_H_8814B 0x13D4
#define REG_HI6Q_TXBD_DESA_L_8814B 0x13D8
#define REG_HI6Q_TXBD_DESA_H_8814B 0x13DC
#define REG_HI7Q_TXBD_DESA_L_8814B 0x13E0
#define REG_HI7Q_TXBD_DESA_H_8814B 0x13E4
#define REG_ACH8_ACH9_TXBD_NUM_8814B 0x13E8
#define REG_ACH10_ACH11_TXBD_NUM_8814B 0x13EC
#define REG_ACH12_ACH13_TXBD_NUM_8814B 0x13F0
#define REG_OLD_DEHANG_8814B 0x13F4
#define REG_ACH4_TXBD_DESA_L_8814B 0x13F8
#define REG_ACH4_TXBD_DESA_H_8814B 0x13FC
#define REG_HI8Q_TXBD_DESA_L_8814B 0x2300
#define REG_HI8Q_TXBD_DESA_H_8814B 0x2304
#define REG_HI9Q_TXBD_DESA_L_8814B 0x2308
#define REG_HI9Q_TXBD_DESA_H_8814B 0x230C
#define REG_HI10Q_TXBD_DESA_L_8814B 0x2310
#define REG_HI10Q_TXBD_DESA_H_8814B 0x2314
#define REG_HI11Q_TXBD_DESA_L_8814B 0x2318
#define REG_HI11Q_TXBD_DESA_H_8814B 0x231C
#define REG_HI12Q_TXBD_DESA_L_8814B 0x2320
#define REG_HI12Q_TXBD_DESA_H_8814B 0x2324
#define REG_HI13Q_TXBD_DESA_L_8814B 0x2328
#define REG_HI13Q_TXBD_DESA_H_8814B 0x232C
#define REG_HI14Q_TXBD_DESA_L_8814B 0x2330
#define REG_HI14Q_TXBD_DESA_H_8814B 0x2334
#define REG_HI15Q_TXBD_DESA_L_8814B 0x2338
#define REG_HI15Q_TXBD_DESA_H_8814B 0x233C
#define REG_HI16Q_TXBD_DESA_L_8814B 0x2340
#define REG_HI16Q_TXBD_DESA_H_8814B 0x2344
#define REG_HI17Q_TXBD_DESA_L_8814B 0x2348
#define REG_HI17Q_TXBD_DESA_H_8814B 0x234C
#define REG_HI18Q_TXBD_DESA_L_8814B 0x2350
#define REG_HI18Q_TXBD_DESA_H_8814B 0x2354
#define REG_HI19Q_TXBD_DESA_L_8814B 0x2358
#define REG_HI19Q_TXBD_DESA_H_8814B 0x235C
#define REG_BD_RWPTR_CLR6_8814B 0x2364
#define REG_P0HI16Q_TXBD_IDX_8814B 0x2370
#define REG_P0HI17Q_TXBD_IDX_8814B 0x2374
#define REG_P0HI18Q_TXBD_IDX_8814B 0x2378
#define REG_P0HI19Q_TXBD_IDX_8814B 0x237C
#define REG_P0HI16Q_HI17Q_TXBD_NUM_8814B 0x2380
#define REG_P0HI18Q_HI19Q_TXBD_NUM_8814B 0x2384
#define REG_PCIE_HISR0_8814B 0x23B4
#define REG_PCIE_HISR1_8814B 0x23BC
#define REG_P0HI8Q_HI9Q_TXBD_NUM_8814B 0x23C0
#define REG_P0HI10Q_HI11Q_TXBD_NUM_8814B 0x23C4
#define REG_P0HI12Q_HI13Q_TXBD_NUM_8814B 0x23C8
#define REG_P0HI14Q_HI15Q_TXBD_NUM_8814B 0x23CC
#define REG_ACH6_ACH7_TXBD_NUM_8814B 0x23F0
#define REG_ACH4_TXBD_IDX_8814B 0x3340
#define REG_ACH5_TXBD_IDX_8814B 0x3344
#define REG_ACH6_TXBD_IDX_8814B 0x3348
#define REG_ACH7_TXBD_IDX_8814B 0x334C
#define REG_ACH8_TXBD_IDX_8814B 0x3350
#define REG_ACH9_TXBD_IDX_8814B 0x3354
#define REG_ACH10_TXBD_IDX_8814B 0x3358
#define REG_ACH11_TXBD_IDX_8814B 0x335C
#define REG_ACH12_TXBD_IDX_8814B 0x3360
#define REG_ACH13_TXBD_IDX_8814B 0x3364
#define REG_AC_CHANNEL0_WEIGHT_8814B 0x3368
#define REG_AC_CHANNEL1_WEIGHT_8814B 0x3369
#define REG_AC_CHANNEL2_WEIGHT_8814B 0x336A
#define REG_AC_CHANNEL3_WEIGHT_8814B 0x336B
#define REG_AC_CHANNEL4_WEIGHT_8814B 0x336C
#define REG_AC_CHANNEL5_WEIGHT_8814B 0x336D
#define REG_AC_CHANNEL6_WEIGHT_8814B 0x336E
#define REG_AC_CHANNEL7_WEIGHT_8814B 0x336F
#define REG_AC_CHANNEL8_WEIGHT_8814B 0x3370
#define REG_AC_CHANNEL9_WEIGHT_8814B 0x3371
#define REG_AC_CHANNEL10_WEIGHT_8814B 0x3372
#define REG_AC_CHANNEL11_WEIGHT_8814B 0x3373
#define REG_AC_CHANNEL12_WEIGHT_8814B 0x3374
#define REG_AC_CHANNEL13_WEIGHT_8814B 0x3375
#define REG_PCIE_HISR2_8814B 0x33B4
#define REG_PCIE_HISR3_8814B 0x33BC
#define REG_QUEUELIST_INFO0_8814B 0x0400
#define REG_QUEUELIST_INFO1_8814B 0x0404
#define REG_QUEUELIST_INFO2_8814B 0x0408
#define REG_QUEUELIST_INFO3_8814B 0x040C
#define REG_QUEUELIST_INFO_EMPTY_8814B 0x0410
#define REG_QUEUELIST_ACQ_EN_8814B 0x0414
#define REG_BCNQ_BDNY_V2_8814B 0x0418
#define REG_CPU_MGQ_INFO_8814B 0x041C
#define REG_FWHW_TXQ_CTRL_8814B 0x0420
#define REG_DATAFB_SEL_8814B 0x0423
#define REG_TXBDNY_8814B 0x0424
#define REG_LIFETIME_EN_8814B 0x0426
#define REG_SPEC_SIFS_8814B 0x0428
#define REG_RETRY_LIMIT_8814B 0x042A
#define REG_TXBF_CTRL_8814B 0x042C
#define REG_DARFRC_8814B 0x0430
#define REG_DARFRCH_8814B 0x0434
#define REG_RARFRC_8814B 0x0438
#define REG_RARFRCH_8814B 0x043C
#define REG_RRSR_8814B 0x0440
#define REG_ARFR0_8814B 0x0444
#define REG_ARFRH0_8814B 0x0448
#define REG_REG_ARFR_WT0_8814B 0x044C
#define REG_REG_ARFR_WT1_8814B 0x0450
#define REG_CCK_CHECK_8814B 0x0454
#define REG_AMPDU_MAX_TIME_V1_8814B 0x0455
#define REG_TAB_SEL_8814B 0x0456
#define REG_BCN_INVALID_CTRL_8814B 0x0457
#define REG_AMPDU_MAX_LENGTH_HT_8814B 0x0458
#define REG_NDPA_RATE_8814B 0x045D
#define REG_TX_HANG_CTRL_8814B 0x045E
#define REG_NDPA_OPT_CTRL_8814B 0x045F
#define REG_AMPDU_MAX_LENGTH_VHT_8814B 0x0460
#define REG_RD_RESP_PKT_TH_8814B 0x0463
#define REG_NEW_EDCA_CTRL_V1_8814B 0x0464
#define REG_ACQ_STOP_V2_8814B 0x0468
#define REG_WMAC_LBK_BUF_HD_V1_8814B 0x0478
#define REG_MGQ_BDNY_V1_8814B 0x047A
#define REG_TXRPT_CTRL_8814B 0x047C
#define REG_INIRTS_RATE_SEL_8814B 0x0480
#define REG_BASIC_CFEND_RATE_8814B 0x0481
#define REG_STBC_CFEND_RATE_8814B 0x0482
#define REG_DATA_SC_8814B 0x0483
#define REG_MOREDATA_V1_8814B 0x0484
#define REG_DATA_SC1_8814B 0x0487
#define REG_TXRPT_START_OFFSET_8814B 0x04AC
#define REG_POWER_STAGE1_8814B 0x04B4
#define REG_POWER_STAGE2_8814B 0x04B8
#define REG_SW_AMPDU_BURST_MODE_CTRL_8814B 0x04BC
#define REG_PKT_LIFE_TIME_8814B 0x04C0
#define REG_STBC_SETTING_8814B 0x04C4
#define REG_STBC_SETTING2_8814B 0x04C5
#define REG_QUEUE_CTRL_8814B 0x04C6
#define REG_SINGLE_AMPDU_CTRL_8814B 0x04C7
#define REG_PROT_MODE_CTRL_8814B 0x04C8
#define REG_BAR_MODE_CTRL_8814B 0x04CC
#define REG_RA_TRY_RATE_AGG_LMT_8814B 0x04CF
#define REG_MACID_SLEEP_CTRL_8814B 0x04D0
#define REG_MACID_SLEEP_INFO_8814B 0x04D4
#define REG_HW_SEQ0_8814B 0x04D8
#define REG_HW_SEQ1_8814B 0x04DA
#define REG_HW_SEQ2_8814B 0x04DC
#define REG_HW_SEQ3_8814B 0x04DE
#define REG_PTCL_ERR_STATUS_V1_8814B 0x04E2
#define REG_NULL_PKT_STATUS_V2_8814B 0x04E4
#define REG_PRECNT_CTRL_8814B 0x04E5
#define REG_NULL_PKT_STATUS_EXTEND_V1_8814B 0x04E7
#define REG_PTCL_DBG_V1_8814B 0x04EC
#define REG_BT_POLLUTE_PKTCNT_8814B 0x04F0
#define REG_CPUMGQ_TIMER_CTRL2_8814B 0x04F4
#define REG_PTCL_DBG_OUT_8814B 0x04F8
#define REG_DUMMY_PAGE4_V1_8814B 0x04FC
#define REG_DUMMY_PAGE4_1_8814B 0x04FE
#define REG_MU_OFFSET_8814B 0x1400
#define REG_BF0_TIME_SETTING_8814B 0x1428
#define REG_BF1_TIME_SETTING_8814B 0x142C
#define REG_BF_TIMEOUT_EN_8814B 0x1430
#define REG_MACID_RELEASE_INFO_8814B 0x1434
#define REG_MACID_RELEASE_SUCCESS_INFO_8814B 0x1438
#define REG_MACID_RELEASE_CTRL_8814B 0x143C
#define REG_FAST_EDCA_VOVI_SETTING_8814B 0x1448
#define REG_FAST_EDCA_BEBK_SETTING_8814B 0x144C
#define REG_MACID_DROP_INFO_8814B 0x1450
#define REG_MACID_DROP_CTRL_8814B 0x1454
#define REG_MGQ_FIFO_WRITE_POINTER_8814B 0x1470
#define REG_MGQ_FIFO_READ_POINTER_8814B 0x1472
#define REG_MGQ_FIFO_ENABLE_8814B 0x1472
#define REG_MGQ_FIFO_RELEASE_INT_MASK_8814B 0x1474
#define REG_MGQ_FIFO_RELEASE_INT_FLAG_8814B 0x1476
#define REG_MGQ_FIFO_VALID_MAP_8814B 0x1478
#define REG_MGQ_FIFO_LIFETIME_8814B 0x147A
#define REG_PKT_TRANS_8814B 0x1480
#define REG_SHCUT_LLC_ETH_TYPE0_8814B 0x1484
#define REG_SHCUT_LLC_ETH_TYPE1_8814B 0x1488
#define REG_SHCUT_LLC_OUI0_8814B 0x148C
#define REG_SHCUT_LLC_OUI1_8814B 0x1490
#define REG_SHCUT_LLC_OUI2_8814B 0x1494
#define REG_FWCMDQ_CTRL_8814B 0x14A0
#define REG_FWCMDQ_PAGE_8814B 0x14A4
#define REG_FWCMDQ_INFO_8814B 0x14A8
#define REG_FWCMDQ_HOLD_PKTNUM_8814B 0x14AC
#define REG_MU_TX_CTRL_8814B 0x14C0
#define REG_MU_STA_GID_VLD_8814B 0x14C4
#define REG_MU_STA_USER_POS_INFO_8814B 0x14C8
#define REG_MU_STA_USER_POS_INFO_H_8814B 0x14CC
#define REG_CHNL_INFO_CTRL_8814B 0x14D0
#define REG_CHNL_IDLE_TIME_8814B 0x14D4
#define REG_CHNL_BUSY_TIME_8814B 0x14D8
#define REG_MU_TRX_DBG_CNT_V1_8814B 0x14DC
#define REG_SWPS_CTRL_8814B 0x14F4
#define REG_SWPS_PKT_TH_8814B 0x14F6
#define REG_SWPS_TIME_TH_8814B 0x14F8
#define REG_MACID_SWPS_EN_8814B 0x14FC
#define REG_EDCA_VO_PARAM_8814B 0x0500
#define REG_EDCA_VI_PARAM_8814B 0x0504
#define REG_EDCA_BE_PARAM_8814B 0x0508
#define REG_EDCA_BK_PARAM_8814B 0x050C
#define REG_BCNTCFG_8814B 0x0510
#define REG_PIFS_8814B 0x0512
#define REG_RDG_PIFS_8814B 0x0513
#define REG_SIFS_8814B 0x0514
#define REG_FORCE_BCN_IFS_V1_8814B 0x0518
#define REG_AGGR_BREAK_TIME_8814B 0x051A
#define REG_SLOT_8814B 0x051B
#define REG_EDCA_CPUMGQ_PARAM_8814B 0x051C
#define REG_CPUMGQ_PAUSE_8814B 0x051E
#define REG_TX_PTCL_CTRL_8814B 0x0520
#define REG_TXPAUSE_8814B 0x0522
#define REG_DIS_TXREQ_CLR_8814B 0x0523
#define REG_RD_CTRL_8814B 0x0524
#define REG_PKT_LIFETIME_CTRL_8814B 0x0528
#define REG_TXOP_LIMIT_CTRL_8814B 0x052C
#define REG_CCA_TXEN_CNT_8814B 0x0534
#define REG_MAX_INTER_COLLISION_8814B 0x0538
#define REG_MAX_INTER_COLLISION_CNT_8814B 0x053C
#define REG_RD_NAV_NXT_8814B 0x0544
#define REG_NAV_PROT_LEN_8814B 0x0546
#define REG_FTM_PTT_8814B 0x0548
#define REG_FTM_TSF_8814B 0x054C
#define REG_HGQ_TIMEOUT_PERIOD_8814B 0x0575
#define REG_TXCMD_TIMEOUT_PERIOD_8814B 0x0576
#define REG_MISC_CTRL_8814B 0x0577
#define REG_TXOP_MIN_8814B 0x0590
#define REG_PRE_BKF_TIME_8814B 0x0592
#define REG_CROSS_TXOP_CTRL_8814B 0x0593
#define REG_ACMHWCTRL_8814B 0x05C0
#define REG_ACMRSTCTRL_8814B 0x05C1
#define REG_ACMAVG_8814B 0x05C2
#define REG_VO_ADMTIME_8814B 0x05C4
#define REG_VI_ADMTIME_8814B 0x05C6
#define REG_BE_ADMTIME_8814B 0x05C8
#define REG_MAC_HEADER_NAV_OFFSET_8814B 0x05CA
#define REG_DIS_NDPA_NAV_CHECK_8814B 0x05CB
#define REG_EDCA_RANDOM_GEN_8814B 0x05CC
#define REG_TXCMD_SEL_8814B 0x05CF
#define REG_MU_DBG_INFO_8814B 0x05E8
#define REG_MU_DBG_INFO_1_8814B 0x05EC
#define REG_SCH_DBG_SEL_8814B 0x05F0
#define REG_SCHEDULER_RST_8814B 0x05F1
#define REG_MU_DBG_ERR_FLAG_8814B 0x05F2
#define REG_TX_ERR_RECOVERY_RST_8814B 0x05F3
#define REG_SCH_DBG_VALUE_8814B 0x05F4
#define REG_SCH_TXCMD_8814B 0x05F8
#define REG_PAGE5_DUMMY_8814B 0x05FC
#define REG_PORT_CTRL_SEL_8814B 0x1500
#define REG_PORT_CTRL_CFG_8814B 0x1501
#define REG_TBTT_PROHIBIT_CFG_8814B 0x1504
#define REG_DRVERLYINT_CFG_8814B 0x1507
#define REG_BCNDMATIM_CFG_8814B 0x1508
#define REG_CTWND_CFG_8814B 0x1509
#define REG_BCNIVLCUNT_CFG_8814B 0x150A
#define REG_EARLY_128US_CFG_8814B 0x150B
#define REG_TSFTR_SYNC_OFFSET_CFG_8814B 0x150C
#define REG_TSFTR_SYNC_CTRL_CFG_8814B 0x150F
#define REG_BCN_SPACE_CFG_8814B 0x1510
#define REG_EARLY_INT_ADJUST_CFG_8814B 0x1512
#define REG_SW_TBTT_TSF_INFO_8814B 0x151C
#define REG_TSFTR_LOW_8814B 0x1520
#define REG_TSFTR_HIGH_8814B 0x1524
#define REG_BCN_ERR_CNT_MAC_8814B 0x1528
#define REG_BCN_ERR_CNT_EDCCA_8814B 0x1529
#define REG_BCN_ERR_CNT_CCA_8814B 0x152A
#define REG_BCN_ERR_CNT_INVALID_8814B 0x152B
#define REG_BCN_ERR_CNT_OTHERS_8814B 0x152C
#define REG_RX_BCN_TIMER_8814B 0x152D
#define REG_TBTT_CTN_AREA_V1_8814B 0x1530
#define REG_BCN_MAX_ERR_V1_8814B 0x1531
#define REG_RXTSF_OFFSET_CCK_V1_8814B 0x1532
#define REG_RXTSF_OFFSET_OFDM_V1_8814B 0x1533
#define REG_SUB_BCN_SPACE_8814B 0x1534
#define REG_MBID_NUM_V1_8814B 0x1535
#define REG_MBSSID_CTRL_V1_8814B 0x1536
#define REG_USTIME_TSF_V1_8814B 0x1538
#define REG_BW_CFG_8814B 0x1539
#define REG_ATIMWND_CFG_8814B 0x153A
#define REG_DTIM_COUNTER_CFG_8814B 0x153B
#define REG_ATIM_DTIM_CTRL_SEL_8814B 0x153C
#define REG_ATIMUGT_V1_8814B 0x153D
#define REG_BCNDROPCTRL_V1_8814B 0x153E
#define REG_DIS_ATIM_V1_8814B 0x1540
#define REG_HIQ_NO_LMT_EN_V1_8814B 0x1544
#define REG_P2PPS_CTRL_V1_8814B 0x1548
#define REG_P2PPS_SPEC_STATE_V1_8814B 0x154A
#define REG_P2PPS_STATE_V1_8814B 0x154B
#define REG_P2PPS1_CTRL_V1_8814B 0x154C
#define REG_P2PPS1_SPEC_STATE_V1_8814B 0x154E
#define REG_P2PPS1_STATE_V1_8814B 0x154F
#define REG_P2PPS2_CTRL_V1_8814B 0x1550
#define REG_P2PPS2_SPEC_STATE_V1_8814B 0x1552
#define REG_P2PPS2_STATE_V1_8814B 0x1553
#define REG_P2PON_DIS_TXTIME_V1_8814B 0x1554
#define REG_P2POFF_DIS_TXTIME_V1_8814B 0x1555
#define REG_CHG_POWER_BCN_AREA_8814B 0x1556
#define REG_NOA_SEL_8814B 0x1557
#define REG_NOA_PARAM_V1_8814B 0x1558
#define REG_NOA_PARAM_1_V1_8814B 0x155C
#define REG_NOA_PARAM_2_V1_8814B 0x1560
#define REG_NOA_PARAM_3_V1_8814B 0x1564
#define REG_NOA_ON_ERLY_TIME_V1_8814B 0x1568
#define REG_NOA_OFF_ERLY_TIME_V1_8814B 0x1569
#define REG_P2PPS_HW_AUTO_PAUSE_CTRL_8814B 0x156C
#define REG_P2PPS1_HW_AUTO_PAUSE_CTRL_8814B 0x1570
#define REG_P2PPS2_HW_AUTO_PAUSE_CTRL_8814B 0x1574
#define REG_RX_TBTT_SHIFT_8814B 0x1578
#define REG_FREERUN_CNT_LOW_8814B 0x1580
#define REG_FREERUN_CNT_HIGH_8814B 0x1584
#define REG_CPUMGQ_TX_TIMER_V1_8814B 0x1588
#define REG_PS_TIMER_0_8814B 0x158C
#define REG_PS_TIMER_1_8814B 0x1590
#define REG_PS_TIMER_2_8814B 0x1594
#define REG_PS_TIMER_3_8814B 0x1598
#define REG_PS_TIMER_4_8814B 0x159C
#define REG_PS_TIMER_5_8814B 0x15A0
#define REG_PS_TIMER_01_CTRL_8814B 0x15A4
#define REG_PS_TIMER_23_CTRL_8814B 0x15A8
#define REG_PS_TIMER_45_CTRL_8814B 0x15AC
#define REG_CPUMGQ_FREERUN_TIMER_CTRL_8814B 0x15B0
#define REG_CPUMGQ_PROHIBIT_8814B 0x15B4
#define REG_TIMER_COMPARE_8814B 0x15C0
#define REG_TIMER_COMPARE_VALUE_LOW_8814B 0x15C4
#define REG_TIMER_COMPARE_VALUE_HIGH_8814B 0x15C8
#define REG_SCHEDULER_COUNTER_8814B 0x15D0
#define REG_WMAC_CR_8814B 0x0600
#define REG_WMAC_FWPKT_CR_8814B 0x0601
#define REG_FW_STS_FILTER_8814B 0x0602
#define REG_TCR_8814B 0x0604
#define REG_RCR_8814B 0x0608
#define REG_RX_PKT_LIMIT_8814B 0x060C
#define REG_RX_DLK_TIME_8814B 0x060D
#define REG_RX_DRVINFO_SZ_8814B 0x060F
#define REG_MACID_8814B 0x0610
#define REG_MACID_H_8814B 0x0614
#define REG_BSSID_8814B 0x0618
#define REG_BSSID_H_8814B 0x061C
#define REG_MAR_8814B 0x0620
#define REG_MAR_H_8814B 0x0624
#define REG_WMAC_DEBUG_SEL_8814B 0x062C
#define REG_WMAC_TCR_TSFT_OFS_8814B 0x0630
#define REG_UDF_THSD_8814B 0x0632
#define REG_ZLD_NUM_8814B 0x0633
#define REG_STMP_THSD_8814B 0x0634
#define REG_WMAC_TXTIMEOUT_8814B 0x0635
#define REG_MCU_TEST_2_V1_8814B 0x0636
#define REG_USTIME_EDCA_8814B 0x0638
#define REG_ACKTO_CCK_8814B 0x0639
#define REG_MAC_SPEC_SIFS_8814B 0x063A
#define REG_RESP_SIFS_CCK_8814B 0x063C
#define REG_RESP_SIFS_OFDM_8814B 0x063E
#define REG_ACKTO_8814B 0x0640
#define REG_CTS2TO_8814B 0x0641
#define REG_EIFS_8814B 0x0642
#define REG_RPFM_MAP0_8814B 0x0644
#define REG_RPFM_MAP1_V1_8814B 0x0646
#define REG_RPFM_CAM_CMD_8814B 0x0648
#define REG_RPFM_CAM_RWD_8814B 0x064C
#define REG_NAV_CTRL_8814B 0x0650
#define REG_BACAMCMD_8814B 0x0654
#define REG_BACAMCONTENT_8814B 0x0658
#define REG_BACAMCONTENT_H_8814B 0x065C
#define REG_LBDLY_8814B 0x0660
#define REG_WMAC_BACAM_RPMEN_8814B 0x0661
#define REG_TX_RX_8814B 0x0662
#define REG_WMAC_BITMAP_CTL_8814B 0x0663
#define REG_RXERR_RPT_8814B 0x0664
#define REG_WMAC_TRXPTCL_CTL_8814B 0x0668
#define REG_WMAC_TRXPTCL_CTL_H_8814B 0x066C
#define REG_CAMCMD_8814B 0x0670
#define REG_CAMWRITE_8814B 0x0674
#define REG_CAMREAD_8814B 0x0678
#define REG_CAMDBG_8814B 0x067C
#define REG_SECCFG_8814B 0x0680
#define REG_RXFILTER_CATEGORY_1_8814B 0x0682
#define REG_RXFILTER_ACTION_1_8814B 0x0683
#define REG_RXFILTER_CATEGORY_2_8814B 0x0684
#define REG_RXFILTER_ACTION_2_8814B 0x0685
#define REG_RXFILTER_CATEGORY_3_8814B 0x0686
#define REG_RXFILTER_ACTION_3_8814B 0x0687
#define REG_RXFLTMAP3_8814B 0x0688
#define REG_RXFLTMAP4_8814B 0x068A
#define REG_RXFLTMAP5_8814B 0x068C
#define REG_RXFLTMAP6_8814B 0x068E
#define REG_WOW_CTRL_8814B 0x0690
#define REG_NAN_RX_TSF_FILTER_8814B 0x0691
#define REG_PS_RX_INFO_8814B 0x0692
#define REG_WMMPS_UAPSD_TID_8814B 0x0693
#define REG_LPNAV_CTRL_8814B 0x0694
#define REG_WKFMCAM_CMD_8814B 0x0698
#define REG_WKFMCAM_RWD_8814B 0x069C
#define REG_RXFLTMAP0_8814B 0x06A0
#define REG_RXFLTMAP1_8814B 0x06A2
#define REG_RXFLTMAP2_8814B 0x06A4
#define REG_BCN_PSR_RPT_8814B 0x06A8
#define REG_FLC_RPC_8814B 0x06AC
#define REG_FLC_RPCT_8814B 0x06AD
#define REG_FLC_PTS_8814B 0x06AE
#define REG_FLC_TRPC_8814B 0x06AF
#define REG_RXPKTMON_CTRL_8814B 0x06B0
#define REG_STATE_MON_8814B 0x06B4
#define REG_ERROR_MON_8814B 0x06B8
#define REG_SEARCH_MACID_8814B 0x06BC
#define REG_BT_COEX_TABLE_8814B 0x06C0
#define REG_BT_COEX_TABLE2_8814B 0x06C4
#define REG_BT_COEX_BREAK_TABLE_8814B 0x06C8
#define REG_BT_COEX_TABLE_H_8814B 0x06CC
#define REG_RXCMD_0_8814B 0x06D0
#define REG_RXCMD_1_8814B 0x06D4
#define REG_WMAC_RESP_TXINFO_8814B 0x06D8
#define REG_BBPSF_CTRL_8814B 0x06DC
#define REG_P2P_RX_BCN_NOA_8814B 0x06E0
#define REG_ASSOCIATED_BFMER0_INFO_8814B 0x06E4
#define REG_ASSOCIATED_BFMER0_INFO_H_8814B 0x06E8
#define REG_ASSOCIATED_BFMER1_INFO_8814B 0x06EC
#define REG_ASSOCIATED_BFMER1_INFO_H_8814B 0x06F0
#define REG_TX_CSI_RPT_PARAM_BW20_8814B 0x06F4
#define REG_TX_CSI_RPT_PARAM_BW40_8814B 0x06F8
#define REG_BCN_PSR_RPT2_8814B 0x1600
#define REG_BCN_PSR_RPT3_8814B 0x1604
#define REG_BCN_PSR_RPT4_8814B 0x1608
#define REG_A1_ADDR_MASK_8814B 0x160C
#define REG_RXPSF_CTRL_8814B 0x1610
#define REG_RXPSF_TYPE_CTRL_8814B 0x1614
#define REG_CAM_ACCESS_CTRL_8814B 0x1618
#define REG_CUT_AMSDU_CTRL_8814B 0x161C
#define REG_MACID2_8814B 0x1620
#define REG_MACID2_H_8814B 0x1624
#define REG_BSSID2_8814B 0x1628
#define REG_BSSID2_H_8814B 0x162C
#define REG_MACID3_8814B 0x1630
#define REG_MACID3_H_8814B 0x1634
#define REG_BSSID3_8814B 0x1638
#define REG_BSSID3_H_8814B 0x163C
#define REG_MACID4_8814B 0x1640
#define REG_MACID4_H_8814B 0x1644
#define REG_BSSID4_8814B 0x1648
#define REG_BSSID4_H_8814B 0x164C
#define REG_NOA_REPORT_8814B 0x1650
#define REG_NOA_REPORT_1_8814B 0x1654
#define REG_NOA_REPORT_2_8814B 0x1658
#define REG_NOA_REPORT_3_8814B 0x165C
#define REG_PWRBIT_SETTING_8814B 0x1660
#define REG_GENERAL_OPTION_8814B 0x1664
#define REG_FWPHYFF_RCR_8814B 0x1668
#define REG_ADDRCAM_WRITE_CONTENT_8814B 0x166C
#define REG_ADDRCAM_READ_CONTENT_8814B 0x1670
#define REG_ADDRCAM_CFG_8814B 0x1674
#define REG_CSI_RRSR_8814B 0x1678
#define REG_MU_BF_OPTION_8814B 0x167C
#define REG_WMAC_PAUSE_BB_CLR_TH_8814B 0x167D
#define REG_WMAC_MULBK_BUF_8814B 0x167E
#define REG_WMAC_MU_OPTION_8814B 0x167F
#define REG_WMAC_MU_BF_CTL_8814B 0x1680
#define REG_WMAC_MU_BFRPT_PARA_8814B 0x1682
#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8814B 0x1684
#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8814B 0x1686
#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8814B 0x1688
#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8814B 0x168A
#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8814B 0x168C
#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8814B 0x168E
#define REG_WMAC_BB_STOP_RX_COUNTER_8814B 0x1690
#define REG_WMAC_PLCP_MONITOR_8814B 0x1694
#define REG_WMAC_DEBUG_PORT_8814B 0x1698
#define REG_TRANSMIT_ADDRSS_0_8814B 0x16A0
#define REG_TRANSMIT_ADDRSS_0_H_8814B 0x16A4
#define REG_TRANSMIT_ADDRSS_1_8814B 0x16A8
#define REG_TRANSMIT_ADDRSS_1_H_8814B 0x16AC
#define REG_TRANSMIT_ADDRSS_2_8814B 0x16B0
#define REG_TRANSMIT_ADDRSS_2_H_8814B 0x16B4
#define REG_TRANSMIT_ADDRSS_3_8814B 0x16B8
#define REG_TRANSMIT_ADDRSS_3_H_8814B 0x16BC
#define REG_TRANSMIT_ADDRSS_4_8814B 0x16C0
#define REG_TRANSMIT_ADDRSS_4_H_8814B 0x16C4
#define REG_MACID1_8814B 0x0700
#define REG_MACID1_1_8814B 0x0704
#define REG_BSSID1_8814B 0x0708
#define REG_BSSID1_1_8814B 0x070C
#define REG_BCN_PSR_RPT1_8814B 0x0710
#define REG_ASSOCIATED_BFMEE_SEL_8814B 0x0714
#define REG_SND_PTCL_CTRL_8814B 0x0718
#define REG_RX_CSI_RPT_INFO_8814B 0x071C
#define REG_NS_ARP_CTRL_8814B 0x0720
#define REG_NS_ARP_INFO_8814B 0x0724
#define REG_BEAMFORMING_INFO_NSARP_V1_8814B 0x0728
#define REG_BEAMFORMING_INFO_NSARP_8814B 0x072C
#define REG_IPV6_8814B 0x0730
#define REG_IPV6_1_8814B 0x0734
#define REG_IPV6_2_8814B 0x0738
#define REG_IPV6_3_8814B 0x073C
#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8814B 0x0750
#define REG_WMAC_SWAES_CFG_8814B 0x0760
#define REG_BT_COEX_V2_8814B 0x0762
#define REG_BT_COEX_8814B 0x0764
#define REG_WLAN_ACT_MASK_CTRL_8814B 0x0768
#define REG_WLAN_ACT_MASK_CTRL_1_8814B 0x076C
#define REG_BT_COEX_ENHANCED_INTR_CTRL_8814B 0x076E
#define REG_BT_ACT_STATISTICS_8814B 0x0770
#define REG_BT_ACT_STATISTICS_1_8814B 0x0774
#define REG_BT_STATISTICS_CONTROL_REGISTER_8814B 0x0778
#define REG_BT_STATUS_REPORT_REGISTER_8814B 0x077C
#define REG_BT_INTERRUPT_CONTROL_REGISTER_8814B 0x0780
#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8814B 0x0784
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8814B 0x0785
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8814B 0x0788
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8814B 0x078C
#define REG_BT_INTERRUPT_STATUS_REGISTER_8814B 0x078F
#define REG_BT_TDMA_TIME_REGISTER_8814B 0x0790
#define REG_BT_ACT_REGISTER_8814B 0x0794
#define REG_OBFF_CTRL_BASIC_8814B 0x0798
#define REG_OBFF_CTRL2_TIMER_8814B 0x079C
#define REG_LTR_CTRL_BASIC_8814B 0x07A0
#define REG_LTR_CTRL2_TIMER_THRESHOLD_8814B 0x07A4
#define REG_LTR_IDLE_LATENCY_V1_8814B 0x07A8
#define REG_LTR_ACTIVE_LATENCY_V1_8814B 0x07AC
#define REG_SMART_ANT_CONDITION_8814B 0x07B0
#define REG_SMART_ANT_CTRL_8814B 0x07B4
#define REG_CONTROL_FRAME_REPORT_8814B 0x07B8
#define REG_CONTROL_FRAME_CNT_CTRL_8814B 0x07BC
#define REG_IQ_DUMP_8814B 0x07C0
#define REG_IQ_DUMP_1_8814B 0x07C4
#define REG_IQ_DUMP_2_8814B 0x07C8
#define REG_WMAC_FTM_CTL_8814B 0x07CC
#define REG_WMAC_IQ_MDPK_FUNC_8814B 0x07CE
#define REG_WMAC_OPTION_FUNCTION_8814B 0x07D0
#define REG_WMAC_OPTION_FUNCTION_1_8814B 0x07D4
#define REG_WMAC_OPTION_FUNCTION_2_8814B 0x07D8
#define REG_RX_FILTER_FUNCTION_8814B 0x07DA
#define REG_NDP_SIG_8814B 0x07E0
#define REG_TXCMD_INFO_FOR_RSP_PKT_8814B 0x07E4
#define REG_TXCMD_INFO_FOR_RSP_PKT_1_8814B 0x07E8
#define REG_WSEC_OPTION_8814B 0x07EC
#define REG_RTS_ADDRESS_0_8814B 0x07F0
#define REG_RTS_ADDRESS_0_1_8814B 0x07F4
#define REG_RTS_ADDRESS_1_8814B 0x07F8
#define REG_RTS_ADDRESS_1_1_8814B 0x07FC
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8814B 0x1700
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8814B 0x1704
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8814B 0x1708
#define REG_PCIE_CFG_FORCE_LINK_L_8814B 0x0709
#define REG_PCIE_CFG_FORCE_LINK_H_8814B 0x070A
#define REG_PCIE_CFG_DEFAULT_ACK_FREQUENCY_8814B 0x070C
#define REG_PCIE_CFG_CX_NFTS_8814B 0x070D
#define REG_PCIE_CFG_DEFAULT_ENTR_LATENCY_8814B 0x070F
#define REG_PCIE_CFG_L1_MISC_SEL_8814B 0x0711
#define REG_PCIE_CFG_TIMER_CTRL_MAX_FUNC_NUM_OFF_8814B 0x0718
#define REG_PCIE_CFG_FORCE_CLKREQ_N_PAD_8814B 0x0719
#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_ACK_NAK_LATENCY_8814B 0x071A
#define REG_PCIE_CFG_TIMER_MODIFIER_FOR_FLOW_CONTROL_WATCHDOG_8814B 0x071B
#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_L_8814B 0x071C
#define REG_PCIE_CFG_SKP_INTERVAL_VALUE_H_8814B 0x071D
#define REG_PCIE_CFG_L1_UNIT_SEL_8814B 0x0724
#define REG_PCIE_CFG_MIN_CLKREQ_SEL_8814B 0x0725
#define REG_SDIO_TX_CTRL_8814B 0x10250000
#define REG_SDIO_HIMR_8814B 0x10250014
#define REG_SDIO_HISR_8814B 0x10250018
#define REG_SDIO_RX_REQ_LEN_8814B 0x1025001C
#define REG_SDIO_FREE_TXPG_SEQ_V1_8814B 0x1025001F
#define REG_SDIO_FREE_TXPG_8814B 0x10250020
#define REG_SDIO_FREE_TXPG2_8814B 0x10250024
#define REG_SDIO_OQT_FREE_TXPG_V1_8814B 0x10250028
#define REG_SDIO_HTSFR_INFO_8814B 0x10250030
#define REG_SDIO_HCPWM1_V2_8814B 0x10250038
#define REG_SDIO_HCPWM2_V2_8814B 0x1025003A
#define REG_SDIO_INDIRECT_REG_CFG_8814B 0x10250040
#define REG_SDIO_INDIRECT_REG_DATA_8814B 0x10250044
#define REG_SDIO_H2C_8814B 0x10250060
#define REG_SDIO_C2H_8814B 0x10250064
#define REG_SDIO_HRPWM1_8814B 0x10250080
#define REG_SDIO_HRPWM2_8814B 0x10250082
#define REG_SDIO_HPS_CLKR_8814B 0x10250084
#define REG_SDIO_BUS_CTRL_8814B 0x10250085
#define REG_SDIO_HSUS_CTRL_8814B 0x10250086
#define REG_SDIO_RESPONSE_TIMER_8814B 0x10250088
#define REG_SDIO_CMD_CRC_8814B 0x1025008A
#define REG_SDIO_HSISR_8814B 0x10250090
#define REG_SDIO_ERR_RPT_8814B 0x102500C0
#define REG_SDIO_CMD_ERRCNT_8814B 0x102500C2
#define REG_SDIO_DATA_ERRCNT_8814B 0x102500C3
#define REG_SDIO_CMD_ERR_CONTENT_8814B 0x102500C4
#define REG_SDIO_CRC_ERR_IDX_8814B 0x102500C9
#define REG_SDIO_DATA_CRC_8814B 0x102500CA
#define REG_SDIO_DATA_REPLY_TIME_8814B 0x102500CB
#endif
================================================
FILE: hal/halmac/halmac_reg_8821c.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_REG_8821C_H
#define __INC_HALMAC_REG_8821C_H
#define REG_SYS_ISO_CTRL_8821C 0x0000
#define REG_SYS_FUNC_EN_8821C 0x0002
#define REG_SYS_PW_CTRL_8821C 0x0004
#define REG_SYS_CLK_CTRL_8821C 0x0008
#define REG_SYS_EEPROM_CTRL_8821C 0x000A
#define REG_EE_VPD_8821C 0x000C
#define REG_SYS_SWR_CTRL1_8821C 0x0010
#define REG_SYS_SWR_CTRL2_8821C 0x0014
#define REG_SYS_SWR_CTRL3_8821C 0x0018
#define REG_RSV_CTRL_8821C 0x001C
#define REG_RF_CTRL_8821C 0x001F
#define REG_AFE_LDO_CTRL_8821C 0x0020
#define REG_AFE_CTRL1_8821C 0x0024
#define REG_AFE_CTRL2_8821C 0x0028
#define REG_AFE_CTRL3_8821C 0x002C
#define REG_EFUSE_CTRL_8821C 0x0030
#define REG_LDO_EFUSE_CTRL_8821C 0x0034
#define REG_PWR_OPTION_CTRL_8821C 0x0038
#define REG_CAL_TIMER_8821C 0x003C
#define REG_ACLK_MON_8821C 0x003E
#define REG_GPIO_MUXCFG_8821C 0x0040
#define REG_GPIO_PIN_CTRL_8821C 0x0044
#define REG_GPIO_INTM_8821C 0x0048
#define REG_LED_CFG_8821C 0x004C
#define REG_FSIMR_8821C 0x0050
#define REG_FSISR_8821C 0x0054
#define REG_HSIMR_8821C 0x0058
#define REG_HSISR_8821C 0x005C
#define REG_GPIO_EXT_CTRL_8821C 0x0060
#define REG_PAD_CTRL1_8821C 0x0064
#define REG_WL_BT_PWR_CTRL_8821C 0x0068
#define REG_SDM_DEBUG_8821C 0x006C
#define REG_SYS_SDIO_CTRL_8821C 0x0070
#define REG_HCI_OPT_CTRL_8821C 0x0074
#define REG_AFE_CTRL4_8821C 0x0078
#define REG_LDO_SWR_CTRL_8821C 0x007C
#define REG_MCUFW_CTRL_8821C 0x0080
#define REG_MCU_TST_CFG_8821C 0x0084
#define REG_HMEBOX_E0_E1_8821C 0x0088
#define REG_HMEBOX_E2_E3_8821C 0x008C
#define REG_WLLPS_CTRL_8821C 0x0090
#define REG_AFE_CTRL5_8821C 0x0094
#define REG_GPIO_DEBOUNCE_CTRL_8821C 0x0098
#define REG_RPWM2_8821C 0x009C
#define REG_SYSON_FSM_MON_8821C 0x00A0
#define REG_AFE_CTRL6_8821C 0x00A4
#define REG_PMC_DBG_CTRL1_8821C 0x00A8
#define REG_AFE_CTRL7_8821C 0x00AC
#define REG_HIMR0_8821C 0x00B0
#define REG_HISR0_8821C 0x00B4
#define REG_HIMR1_8821C 0x00B8
#define REG_HISR1_8821C 0x00BC
#define REG_DBG_PORT_SEL_8821C 0x00C0
#define REG_PAD_CTRL2_8821C 0x00C4
#define REG_PMC_DBG_CTRL2_8821C 0x00CC
#define REG_BIST_CTRL_8821C 0x00D0
#define REG_BIST_RPT_8821C 0x00D4
#define REG_MEM_CTRL_8821C 0x00D8
#define REG_AFE_CTRL8_8821C 0x00DC
#define REG_USB_SIE_INTF_8821C 0x00E0
#define REG_PCIE_MIO_INTF_8821C 0x00E4
#define REG_PCIE_MIO_INTD_8821C 0x00E8
#define REG_WLRF1_8821C 0x00EC
#define REG_SYS_CFG1_8821C 0x00F0
#define REG_SYS_STATUS1_8821C 0x00F4
#define REG_SYS_STATUS2_8821C 0x00F8
#define REG_SYS_CFG2_8821C 0x00FC
#define REG_SYS_CFG3_8821C 0x1000
#define REG_SYS_CFG5_8821C 0x1070
#define REG_CPU_DMEM_CON_8821C 0x1080
#define REG_BOOT_REASON_8821C 0x1088
#define REG_NFCPAD_CTRL_8821C 0x10A8
#define REG_HIMR2_8821C 0x10B0
#define REG_HISR2_8821C 0x10B4
#define REG_HIMR3_8821C 0x10B8
#define REG_HISR3_8821C 0x10BC
#define REG_SW_MDIO_8821C 0x10C0
#define REG_H2C_PKT_READADDR_8821C 0x10D0
#define REG_H2C_PKT_WRITEADDR_8821C 0x10D4
#define REG_MEM_PWR_CRTL_8821C 0x10D8
#define REG_FW_DBG6_8821C 0x10F8
#define REG_FW_DBG7_8821C 0x10FC
#define REG_CR_8821C 0x0100
#define REG_PG_SIZE_8821C 0x0104
#define REG_PKT_BUFF_ACCESS_CTRL_8821C 0x0106
#define REG_TSF_CLK_STATE_8821C 0x0108
#define REG_TXDMA_PQ_MAP_8821C 0x010C
#define REG_TRXFF_BNDY_8821C 0x0114
#define REG_PTA_I2C_MBOX_8821C 0x0118
#define REG_RXFF_BNDY_8821C 0x011C
#define REG_FE1IMR_8821C 0x0120
#define REG_FE1ISR_8821C 0x0124
#define REG_CPWM_8821C 0x012C
#define REG_FWIMR_8821C 0x0130
#define REG_FWISR_8821C 0x0134
#define REG_FTIMR_8821C 0x0138
#define REG_FTISR_8821C 0x013C
#define REG_PKTBUF_DBG_CTRL_8821C 0x0140
#define REG_PKTBUF_DBG_DATA_L_8821C 0x0144
#define REG_PKTBUF_DBG_DATA_H_8821C 0x0148
#define REG_CPWM2_8821C 0x014C
#define REG_TC0_CTRL_8821C 0x0150
#define REG_TC1_CTRL_8821C 0x0154
#define REG_TC2_CTRL_8821C 0x0158
#define REG_TC3_CTRL_8821C 0x015C
#define REG_TC4_CTRL_8821C 0x0160
#define REG_TCUNIT_BASE_8821C 0x0164
#define REG_TC5_CTRL_8821C 0x0168
#define REG_TC6_CTRL_8821C 0x016C
#define REG_MBIST_DRF_FAIL_8821C 0x0170
#define REG_MBIST_START_PAUSE_8821C 0x0174
#define REG_MBIST_DONE_8821C 0x0178
#define REG_MBIST_READ_BIST_RPT_8821C 0x017C
#define REG_AES_DECRPT_DATA_8821C 0x0180
#define REG_AES_DECRPT_CFG_8821C 0x0184
#define REG_TMETER_8821C 0x0190
#define REG_OSC_32K_CTRL_8821C 0x0194
#define REG_32K_CAL_REG1_8821C 0x0198
#define REG_C2HEVT_8821C 0x01A0
#define REG_C2HEVT_1_8821C 0x01A4
#define REG_C2HEVT_2_8821C 0x01A8
#define REG_C2HEVT_3_8821C 0x01AC
#define REG_SW_DEFINED_PAGE1_8821C 0x01B8
#define REG_SW_DEFINED_PAGE2_8821C 0x01BC
#define REG_MCUTST_I_8821C 0x01C0
#define REG_MCUTST_II_8821C 0x01C4
#define REG_FMETHR_8821C 0x01C8
#define REG_HMETFR_8821C 0x01CC
#define REG_HMEBOX0_8821C 0x01D0
#define REG_HMEBOX1_8821C 0x01D4
#define REG_HMEBOX2_8821C 0x01D8
#define REG_HMEBOX3_8821C 0x01DC
#define REG_BB_ACCESS_CTRL_8821C 0x01E8
#define REG_BB_ACCESS_DATA_8821C 0x01EC
#define REG_HMEBOX_E0_8821C 0x01F0
#define REG_HMEBOX_E1_8821C 0x01F4
#define REG_HMEBOX_E2_8821C 0x01F8
#define REG_HMEBOX_E3_8821C 0x01FC
#define REG_CR_EXT_8821C 0x1100
#define REG_FWFF_8821C 0x1114
#define REG_RXFF_PTR_V1_8821C 0x1118
#define REG_RXFF_WTR_V1_8821C 0x111C
#define REG_FE2IMR_8821C 0x1120
#define REG_FE2ISR_8821C 0x1124
#define REG_FE3IMR_8821C 0x1128
#define REG_FE3ISR_8821C 0x112C
#define REG_FE4IMR_8821C 0x1130
#define REG_FE4ISR_8821C 0x1134
#define REG_FT1IMR_8821C 0x1138
#define REG_FT1ISR_8821C 0x113C
#define REG_SPWR0_8821C 0x1140
#define REG_SPWR1_8821C 0x1144
#define REG_SPWR2_8821C 0x1148
#define REG_SPWR3_8821C 0x114C
#define REG_POWSEQ_8821C 0x1150
#define REG_TC7_CTRL_V1_8821C 0x1158
#define REG_TC8_CTRL_V1_8821C 0x115C
#define REG_RX_BCN_TBTT_ITVL0_8821C 0x1160
#define REG_RX_BCN_TBTT_ITVL1_8821C 0x1164
#define REG_IO_WRAP_ERR_FLAG_8821C 0x1170
#define REG_SPEED_SENSOR_8821C 0x1180
#define REG_SPEED_SENSOR1_8821C 0x1184
#define REG_SPEED_SENSOR2_8821C 0x1188
#define REG_SPEED_SENSOR3_8821C 0x118C
#define REG_SPEED_SENSOR4_8821C 0x1190
#define REG_SPEED_SENSOR5_8821C 0x1194
#define REG_COUNTER_CTRL_8821C 0x11C4
#define REG_COUNTER_THRESHOLD_8821C 0x11C8
#define REG_COUNTER_SET_8821C 0x11CC
#define REG_COUNTER_OVERFLOW_8821C 0x11D0
#define REG_TXDMA_LEN_THRESHOLD_8821C 0x11D4
#define REG_RXDMA_LEN_THRESHOLD_8821C 0x11D8
#define REG_PCIE_EXEC_TIME_THRESHOLD_8821C 0x11DC
#define REG_FT2IMR_8821C 0x11E0
#define REG_FT2ISR_8821C 0x11E4
#define REG_MSG2_8821C 0x11F0
#define REG_MSG3_8821C 0x11F4
#define REG_MSG4_8821C 0x11F8
#define REG_MSG5_8821C 0x11FC
#define REG_FIFOPAGE_CTRL_1_8821C 0x0200
#define REG_FIFOPAGE_CTRL_2_8821C 0x0204
#define REG_AUTO_LLT_V1_8821C 0x0208
#define REG_TXDMA_OFFSET_CHK_8821C 0x020C
#define REG_TXDMA_STATUS_8821C 0x0210
#define REG_TX_DMA_DBG_8821C 0x0214
#define REG_TQPNT1_8821C 0x0218
#define REG_TQPNT2_8821C 0x021C
#define REG_TQPNT3_8821C 0x0220
#define REG_TQPNT4_8821C 0x0224
#define REG_RQPN_CTRL_1_8821C 0x0228
#define REG_RQPN_CTRL_2_8821C 0x022C
#define REG_FIFOPAGE_INFO_1_8821C 0x0230
#define REG_FIFOPAGE_INFO_2_8821C 0x0234
#define REG_FIFOPAGE_INFO_3_8821C 0x0238
#define REG_FIFOPAGE_INFO_4_8821C 0x023C
#define REG_FIFOPAGE_INFO_5_8821C 0x0240
#define REG_H2C_HEAD_8821C 0x0244
#define REG_H2C_TAIL_8821C 0x0248
#define REG_H2C_READ_ADDR_8821C 0x024C
#define REG_H2C_WR_ADDR_8821C 0x0250
#define REG_H2C_INFO_8821C 0x0254
#define REG_RXDMA_AGG_PG_TH_8821C 0x0280
#define REG_RXPKT_NUM_8821C 0x0284
#define REG_RXDMA_STATUS_8821C 0x0288
#define REG_RXDMA_DPR_8821C 0x028C
#define REG_RXDMA_MODE_8821C 0x0290
#define REG_C2H_PKT_8821C 0x0294
#define REG_FWFF_C2H_8821C 0x0298
#define REG_FWFF_CTRL_8821C 0x029C
#define REG_FWFF_PKT_INFO_8821C 0x02A0
#define REG_DDMA_CH0SA_8821C 0x1200
#define REG_DDMA_CH0DA_8821C 0x1204
#define REG_DDMA_CH0CTRL_8821C 0x1208
#define REG_DDMA_CH1SA_8821C 0x1210
#define REG_DDMA_CH1DA_8821C 0x1214
#define REG_DDMA_CH1CTRL_8821C 0x1218
#define REG_DDMA_CH2SA_8821C 0x1220
#define REG_DDMA_CH2DA_8821C 0x1224
#define REG_DDMA_CH2CTRL_8821C 0x1228
#define REG_DDMA_CH3SA_8821C 0x1230
#define REG_DDMA_CH3DA_8821C 0x1234
#define REG_DDMA_CH3CTRL_8821C 0x1238
#define REG_DDMA_CH4SA_8821C 0x1240
#define REG_DDMA_CH4DA_8821C 0x1244
#define REG_DDMA_CH4CTRL_8821C 0x1248
#define REG_DDMA_CH5SA_8821C 0x1250
#define REG_DDMA_CH5DA_8821C 0x1254
#define REG_DDMA_CH5CTRL_8821C 0x1258
#define REG_DDMA_INT_MSK_8821C 0x12E0
#define REG_DDMA_CHSTATUS_8821C 0x12E8
#define REG_DDMA_CHKSUM_8821C 0x12F0
#define REG_DDMA_MONITOR_8821C 0x12FC
#define REG_PCIE_CTRL_8821C 0x0300
#define REG_INT_MIG_8821C 0x0304
#define REG_BCNQ_TXBD_DESA_8821C 0x0308
#define REG_MGQ_TXBD_DESA_8821C 0x0310
#define REG_VOQ_TXBD_DESA_8821C 0x0318
#define REG_VIQ_TXBD_DESA_8821C 0x0320
#define REG_BEQ_TXBD_DESA_8821C 0x0328
#define REG_BKQ_TXBD_DESA_8821C 0x0330
#define REG_RXQ_RXBD_DESA_8821C 0x0338
#define REG_HI0Q_TXBD_DESA_8821C 0x0340
#define REG_HI1Q_TXBD_DESA_8821C 0x0348
#define REG_HI2Q_TXBD_DESA_8821C 0x0350
#define REG_HI3Q_TXBD_DESA_8821C 0x0358
#define REG_HI4Q_TXBD_DESA_8821C 0x0360
#define REG_HI5Q_TXBD_DESA_8821C 0x0368
#define REG_HI6Q_TXBD_DESA_8821C 0x0370
#define REG_HI7Q_TXBD_DESA_8821C 0x0378
#define REG_MGQ_TXBD_NUM_8821C 0x0380
#define REG_RX_RXBD_NUM_8821C 0x0382
#define REG_VOQ_TXBD_NUM_8821C 0x0384
#define REG_VIQ_TXBD_NUM_8821C 0x0386
#define REG_BEQ_TXBD_NUM_8821C 0x0388
#define REG_BKQ_TXBD_NUM_8821C 0x038A
#define REG_HI0Q_TXBD_NUM_8821C 0x038C
#define REG_HI1Q_TXBD_NUM_8821C 0x038E
#define REG_HI2Q_TXBD_NUM_8821C 0x0390
#define REG_HI3Q_TXBD_NUM_8821C 0x0392
#define REG_HI4Q_TXBD_NUM_8821C 0x0394
#define REG_HI5Q_TXBD_NUM_8821C 0x0396
#define REG_HI6Q_TXBD_NUM_8821C 0x0398
#define REG_HI7Q_TXBD_NUM_8821C 0x039A
#define REG_TSFTIMER_HCI_8821C 0x039C
#define REG_BD_RWPTR_CLR_8821C 0x039C
#define REG_VOQ_TXBD_IDX_8821C 0x03A0
#define REG_VIQ_TXBD_IDX_8821C 0x03A4
#define REG_BEQ_TXBD_IDX_8821C 0x03A8
#define REG_BKQ_TXBD_IDX_8821C 0x03AC
#define REG_MGQ_TXBD_IDX_8821C 0x03B0
#define REG_RXQ_RXBD_IDX_8821C 0x03B4
#define REG_HI0Q_TXBD_IDX_8821C 0x03B8
#define REG_HI1Q_TXBD_IDX_8821C 0x03BC
#define REG_HI2Q_TXBD_IDX_8821C 0x03C0
#define REG_HI3Q_TXBD_IDX_8821C 0x03C4
#define REG_HI4Q_TXBD_IDX_8821C 0x03C8
#define REG_HI5Q_TXBD_IDX_8821C 0x03CC
#define REG_HI6Q_TXBD_IDX_8821C 0x03D0
#define REG_HI7Q_TXBD_IDX_8821C 0x03D4
#define REG_DBG_SEL_V1_8821C 0x03D8
#define REG_PCIE_HRPWM1_V1_8821C 0x03D9
#define REG_PCIE_HCPWM1_V1_8821C 0x03DA
#define REG_PCIE_CTRL2_8821C 0x03DB
#define REG_PCIE_HRPWM2_V1_8821C 0x03DC
#define REG_PCIE_HCPWM2_V1_8821C 0x03DE
#define REG_PCIE_H2C_MSG_V1_8821C 0x03E0
#define REG_PCIE_C2H_MSG_V1_8821C 0x03E4
#define REG_DBI_WDATA_V1_8821C 0x03E8
#define REG_DBI_RDATA_V1_8821C 0x03EC
#define REG_DBI_FLAG_V1_8821C 0x03F0
#define REG_MDIO_V1_8821C 0x03F4
#define REG_PCIE_MIX_CFG_8821C 0x03F8
#define REG_HCI_MIX_CFG_8821C 0x03FC
#define REG_STC_INT_CS_8821C 0x1300
#define REG_ST_INT_CFG_8821C 0x1304
#define REG_CMU_DLY_CTRL_8821C 0x1310
#define REG_CMU_DLY_CFG_8821C 0x1314
#define REG_H2CQ_TXBD_DESA_8821C 0x1320
#define REG_H2CQ_TXBD_NUM_8821C 0x1328
#define REG_H2CQ_TXBD_IDX_8821C 0x132C
#define REG_H2CQ_CSR_8821C 0x1330
#define REG_Q0_INFO_8821C 0x0400
#define REG_Q1_INFO_8821C 0x0404
#define REG_Q2_INFO_8821C 0x0408
#define REG_Q3_INFO_8821C 0x040C
#define REG_MGQ_INFO_8821C 0x0410
#define REG_HIQ_INFO_8821C 0x0414
#define REG_BCNQ_INFO_8821C 0x0418
#define REG_TXPKT_EMPTY_8821C 0x041A
#define REG_CPU_MGQ_INFO_8821C 0x041C
#define REG_FWHW_TXQ_CTRL_8821C 0x0420
#define REG_DATAFB_SEL_8821C 0x0423
#define REG_BCNQ_BDNY_V1_8821C 0x0424
#define REG_LIFETIME_EN_8821C 0x0426
#define REG_SPEC_SIFS_8821C 0x0428
#define REG_RETRY_LIMIT_8821C 0x042A
#define REG_TXBF_CTRL_8821C 0x042C
#define REG_DARFRC_8821C 0x0430
#define REG_DARFRCH_8821C 0x0434
#define REG_RARFRC_8821C 0x0438
#define REG_RARFRCH_8821C 0x043C
#define REG_RRSR_8821C 0x0440
#define REG_ARFR0_8821C 0x0444
#define REG_ARFRH0_8821C 0x0448
#define REG_ARFR1_V1_8821C 0x044C
#define REG_ARFRH1_V1_8821C 0x0450
#define REG_CCK_CHECK_8821C 0x0454
#define REG_AMPDU_MAX_TIME_V1_8821C 0x0455
#define REG_BCNQ1_BDNY_V1_8821C 0x0456
#define REG_AMPDU_MAX_LENGTH_8821C 0x0458
#define REG_ACQ_STOP_8821C 0x045C
#define REG_NDPA_RATE_8821C 0x045D
#define REG_TX_HANG_CTRL_8821C 0x045E
#define REG_NDPA_OPT_CTRL_8821C 0x045F
#define REG_RD_RESP_PKT_TH_8821C 0x0463
#define REG_CMDQ_INFO_8821C 0x0464
#define REG_Q4_INFO_8821C 0x0468
#define REG_Q5_INFO_8821C 0x046C
#define REG_Q6_INFO_8821C 0x0470
#define REG_Q7_INFO_8821C 0x0474
#define REG_WMAC_LBK_BUF_HD_V1_8821C 0x0478
#define REG_MGQ_BDNY_V1_8821C 0x047A
#define REG_TXRPT_CTRL_8821C 0x047C
#define REG_INIRTS_RATE_SEL_8821C 0x0480
#define REG_BASIC_CFEND_RATE_8821C 0x0481
#define REG_STBC_CFEND_RATE_8821C 0x0482
#define REG_DATA_SC_8821C 0x0483
#define REG_MACID_SLEEP3_8821C 0x0484
#define REG_MACID_SLEEP1_8821C 0x0488
#define REG_ARFR2_V1_8821C 0x048C
#define REG_ARFRH2_V1_8821C 0x0490
#define REG_ARFR3_V1_8821C 0x0494
#define REG_ARFRH3_V1_8821C 0x0498
#define REG_ARFR4_8821C 0x049C
#define REG_ARFRH4_8821C 0x04A0
#define REG_ARFR5_8821C 0x04A4
#define REG_ARFRH5_8821C 0x04A8
#define REG_TXRPT_START_OFFSET_8821C 0x04AC
#define REG_POWER_STAGE1_8821C 0x04B4
#define REG_POWER_STAGE2_8821C 0x04B8
#define REG_SW_AMPDU_BURST_MODE_CTRL_8821C 0x04BC
#define REG_PKT_LIFE_TIME_8821C 0x04C0
#define REG_STBC_SETTING_8821C 0x04C4
#define REG_STBC_SETTING2_8821C 0x04C5
#define REG_QUEUE_CTRL_8821C 0x04C6
#define REG_SINGLE_AMPDU_CTRL_8821C 0x04C7
#define REG_PROT_MODE_CTRL_8821C 0x04C8
#define REG_BAR_MODE_CTRL_8821C 0x04CC
#define REG_RA_TRY_RATE_AGG_LMT_8821C 0x04CF
#define REG_MACID_SLEEP2_8821C 0x04D0
#define REG_MACID_SLEEP_8821C 0x04D4
#define REG_HW_SEQ0_8821C 0x04D8
#define REG_HW_SEQ1_8821C 0x04DA
#define REG_HW_SEQ2_8821C 0x04DC
#define REG_HW_SEQ3_8821C 0x04DE
#define REG_NULL_PKT_STATUS_V1_8821C 0x04E0
#define REG_PTCL_ERR_STATUS_8821C 0x04E2
#define REG_NULL_PKT_STATUS_EXTEND_8821C 0x04E3
#define REG_VIDEO_ENHANCEMENT_FUN_8821C 0x04E4
#define REG_PRECNT_CTRL_8821C 0x04E5
#define REG_BT_POLLUTE_PKT_CNT_8821C 0x04E8
#define REG_PTCL_DBG_8821C 0x04EC
#define REG_CPUMGQ_TIMER_CTRL2_8821C 0x04F4
#define REG_DUMMY_PAGE4_V1_8821C 0x04FC
#define REG_MOREDATA_8821C 0x04FE
#define REG_Q0_Q1_INFO_8821C 0x1400
#define REG_Q2_Q3_INFO_8821C 0x1404
#define REG_Q4_Q5_INFO_8821C 0x1408
#define REG_Q6_Q7_INFO_8821C 0x140C
#define REG_MGQ_HIQ_INFO_8821C 0x1410
#define REG_CMDQ_BCNQ_INFO_8821C 0x1414
#define REG_USEREG_SETTING_8821C 0x1420
#define REG_AESIV_SETTING_8821C 0x1424
#define REG_BF0_TIME_SETTING_8821C 0x1428
#define REG_BF1_TIME_SETTING_8821C 0x142C
#define REG_BF_TIMEOUT_EN_8821C 0x1430
#define REG_MACID_RELEASE0_8821C 0x1434
#define REG_MACID_RELEASE1_8821C 0x1438
#define REG_MACID_RELEASE2_8821C 0x143C
#define REG_MACID_RELEASE3_8821C 0x1440
#define REG_MACID_RELEASE_SETTING_8821C 0x1444
#define REG_FAST_EDCA_VOVI_SETTING_8821C 0x1448
#define REG_FAST_EDCA_BEBK_SETTING_8821C 0x144C
#define REG_MACID_DROP0_8821C 0x1450
#define REG_MACID_DROP1_8821C 0x1454
#define REG_MACID_DROP2_8821C 0x1458
#define REG_MACID_DROP3_8821C 0x145C
#define REG_R_MACID_RELEASE_SUCCESS_0_8821C 0x1460
#define REG_R_MACID_RELEASE_SUCCESS_1_8821C 0x1464
#define REG_R_MACID_RELEASE_SUCCESS_2_8821C 0x1468
#define REG_R_MACID_RELEASE_SUCCESS_3_8821C 0x146C
#define REG_MGQ_FIFO_WRITE_POINTER_8821C 0x1470
#define REG_MGQ_FIFO_READ_POINTER_8821C 0x1472
#define REG_MGQ_FIFO_ENABLE_8821C 0x1472
#define REG_MGQ_FIFO_RELEASE_INT_MASK_8821C 0x1474
#define REG_MGQ_FIFO_RELEASE_INT_FLAG_8821C 0x1476
#define REG_MGQ_FIFO_VALID_MAP_8821C 0x1478
#define REG_MGQ_FIFO_LIFETIME_8821C 0x147A
#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8821C 0x147C
#define REG_SHCUT_SETTING_8821C 0x1480
#define REG_SHCUT_LLC_ETH_TYPE0_8821C 0x1484
#define REG_SHCUT_LLC_ETH_TYPE1_8821C 0x1488
#define REG_SHCUT_LLC_OUI0_8821C 0x148C
#define REG_SHCUT_LLC_OUI1_8821C 0x1490
#define REG_SHCUT_LLC_OUI2_8821C 0x1494
#define REG_MU_TX_CTL_8821C 0x14C0
#define REG_MU_STA_GID_VLD_8821C 0x14C4
#define REG_MU_STA_USER_POS_INFO_8821C 0x14C8
#define REG_MU_STA_USER_POS_INFO_H_8821C 0x14CC
#define REG_MU_TRX_DBG_CNT_8821C 0x14D0
#define REG_EDCA_VO_PARAM_8821C 0x0500
#define REG_EDCA_VI_PARAM_8821C 0x0504
#define REG_EDCA_BE_PARAM_8821C 0x0508
#define REG_EDCA_BK_PARAM_8821C 0x050C
#define REG_BCNTCFG_8821C 0x0510
#define REG_PIFS_8821C 0x0512
#define REG_RDG_PIFS_8821C 0x0513
#define REG_SIFS_8821C 0x0514
#define REG_TSFTR_SYN_OFFSET_8821C 0x0518
#define REG_AGGR_BREAK_TIME_8821C 0x051A
#define REG_SLOT_8821C 0x051B
#define REG_NOA_ON_ERLY_TIME_8821C 0x051C
#define REG_NOA_OFF_ERLY_TIME_8821C 0x051D
#define REG_TX_PTCL_CTRL_8821C 0x0520
#define REG_TXPAUSE_8821C 0x0522
#define REG_DIS_TXREQ_CLR_8821C 0x0523
#define REG_RD_CTRL_8821C 0x0524
#define REG_MBSSID_CTRL_8821C 0x0526
#define REG_P2PPS_CTRL_8821C 0x0527
#define REG_PKT_LIFETIME_CTRL_8821C 0x0528
#define REG_P2PPS_SPEC_STATE_8821C 0x052B
#define REG_BAR_TX_CTRL_8821C 0x0530
#define REG_P2PON_DIS_TXTIME_8821C 0x0531
#define REG_TBTT_PROHIBIT_8821C 0x0540
#define REG_P2PPS_STATE_8821C 0x0543
#define REG_RD_NAV_NXT_8821C 0x0544
#define REG_NAV_PROT_LEN_8821C 0x0546
#define REG_BCN_CTRL_8821C 0x0550
#define REG_BCN_CTRL_CLINT0_8821C 0x0551
#define REG_MBID_NUM_8821C 0x0552
#define REG_DUAL_TSF_RST_8821C 0x0553
#define REG_MBSSID_BCN_SPACE_8821C 0x0554
#define REG_DRVERLYINT_8821C 0x0558
#define REG_BCNDMATIM_8821C 0x0559
#define REG_ATIMWND_8821C 0x055A
#define REG_USTIME_TSF_8821C 0x055C
#define REG_BCN_MAX_ERR_8821C 0x055D
#define REG_RXTSF_OFFSET_CCK_8821C 0x055E
#define REG_RXTSF_OFFSET_OFDM_8821C 0x055F
#define REG_TSFTR_8821C 0x0560
#define REG_TSFTR_1_8821C 0x0564
#define REG_FREERUN_CNT_8821C 0x0568
#define REG_FREERUN_CNT_1_8821C 0x056C
#define REG_ATIMWND1_V1_8821C 0x0570
#define REG_TBTT_PROHIBIT_INFRA_8821C 0x0571
#define REG_CTWND_8821C 0x0572
#define REG_BCNIVLCUNT_8821C 0x0573
#define REG_BCNDROPCTRL_8821C 0x0574
#define REG_HGQ_TIMEOUT_PERIOD_8821C 0x0575
#define REG_TXCMD_TIMEOUT_PERIOD_8821C 0x0576
#define REG_MISC_CTRL_8821C 0x0577
#define REG_BCN_CTRL_CLINT1_8821C 0x0578
#define REG_BCN_CTRL_CLINT2_8821C 0x0579
#define REG_BCN_CTRL_CLINT3_8821C 0x057A
#define REG_EXTEND_CTRL_8821C 0x057B
#define REG_P2PPS1_SPEC_STATE_8821C 0x057C
#define REG_P2PPS1_STATE_8821C 0x057D
#define REG_P2PPS2_SPEC_STATE_8821C 0x057E
#define REG_P2PPS2_STATE_8821C 0x057F
#define REG_PS_TIMER0_8821C 0x0580
#define REG_PS_TIMER1_8821C 0x0584
#define REG_PS_TIMER2_8821C 0x0588
#define REG_TBTT_CTN_AREA_8821C 0x058C
#define REG_FORCE_BCN_IFS_8821C 0x058E
#define REG_TXOP_MIN_8821C 0x0590
#define REG_PRE_BKF_TIME_8821C 0x0592
#define REG_CROSS_TXOP_CTRL_8821C 0x0593
#define REG_ATIMWND2_8821C 0x05A0
#define REG_ATIMWND3_8821C 0x05A1
#define REG_ATIMWND4_8821C 0x05A2
#define REG_ATIMWND5_8821C 0x05A3
#define REG_ATIMWND6_8821C 0x05A4
#define REG_ATIMWND7_8821C 0x05A5
#define REG_ATIMUGT_8821C 0x05A6
#define REG_HIQ_NO_LMT_EN_8821C 0x05A7
#define REG_DTIM_COUNTER_ROOT_8821C 0x05A8
#define REG_DTIM_COUNTER_VAP1_8821C 0x05A9
#define REG_DTIM_COUNTER_VAP2_8821C 0x05AA
#define REG_DTIM_COUNTER_VAP3_8821C 0x05AB
#define REG_DTIM_COUNTER_VAP4_8821C 0x05AC
#define REG_DTIM_COUNTER_VAP5_8821C 0x05AD
#define REG_DTIM_COUNTER_VAP6_8821C 0x05AE
#define REG_DTIM_COUNTER_VAP7_8821C 0x05AF
#define REG_DIS_ATIM_8821C 0x05B0
#define REG_EARLY_128US_8821C 0x05B1
#define REG_P2PPS1_CTRL_8821C 0x05B2
#define REG_P2PPS2_CTRL_8821C 0x05B3
#define REG_TIMER0_SRC_SEL_8821C 0x05B4
#define REG_NOA_UNIT_SEL_8821C 0x05B5
#define REG_P2POFF_DIS_TXTIME_8821C 0x05B7
#define REG_MBSSID_BCN_SPACE2_8821C 0x05B8
#define REG_MBSSID_BCN_SPACE3_8821C 0x05BC
#define REG_ACMHWCTRL_8821C 0x05C0
#define REG_ACMRSTCTRL_8821C 0x05C1
#define REG_ACMAVG_8821C 0x05C2
#define REG_VO_ADMTIME_8821C 0x05C4
#define REG_VI_ADMTIME_8821C 0x05C6
#define REG_BE_ADMTIME_8821C 0x05C8
#define REG_EDCA_RANDOM_GEN_8821C 0x05CC
#define REG_TXCMD_NOA_SEL_8821C 0x05CF
#define REG_NOA_PARAM_8821C 0x05E0
#define REG_NOA_PARAM_1_8821C 0x05E4
#define REG_NOA_PARAM_2_8821C 0x05E8
#define REG_NOA_PARAM_3_8821C 0x05EC
#define REG_P2P_RST_8821C 0x05F0
#define REG_SCHEDULER_RST_8821C 0x05F1
#define REG_SCH_TXCMD_8821C 0x05F8
#define REG_PAGE5_DUMMY_8821C 0x05FC
#define REG_CPUMGQ_TX_TIMER_8821C 0x1500
#define REG_PS_TIMER_A_8821C 0x1504
#define REG_PS_TIMER_B_8821C 0x1508
#define REG_PS_TIMER_C_8821C 0x150C
#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8821C 0x1510
#define REG_CPUMGQ_TX_TIMER_EARLY_8821C 0x1514
#define REG_PS_TIMER_A_EARLY_8821C 0x1515
#define REG_PS_TIMER_B_EARLY_8821C 0x1516
#define REG_PS_TIMER_C_EARLY_8821C 0x1517
#define REG_CPUMGQ_PARAMETER_8821C 0x1518
#define REG_WMAC_CR_8821C 0x0600
#define REG_WMAC_FWPKT_CR_8821C 0x0601
#define REG_FW_STS_FILTER_8821C 0x0602
#define REG_TCR_8821C 0x0604
#define REG_RCR_8821C 0x0608
#define REG_RX_PKT_LIMIT_8821C 0x060C
#define REG_RX_DLK_TIME_8821C 0x060D
#define REG_RX_DRVINFO_SZ_8821C 0x060F
#define REG_MACID_8821C 0x0610
#define REG_MACID_H_8821C 0x0614
#define REG_BSSID_8821C 0x0618
#define REG_BSSID_H_8821C 0x061C
#define REG_MAR_8821C 0x0620
#define REG_MAR_H_8821C 0x0624
#define REG_MBIDCAMCFG_1_8821C 0x0628
#define REG_MBIDCAMCFG_2_8821C 0x062C
#define REG_WMAC_TCR_TSFT_OFS_8821C 0x0630
#define REG_UDF_THSD_8821C 0x0632
#define REG_ZLD_NUM_8821C 0x0633
#define REG_STMP_THSD_8821C 0x0634
#define REG_WMAC_TXTIMEOUT_8821C 0x0635
#define REG_MCU_TEST_2_V1_8821C 0x0636
#define REG_USTIME_EDCA_8821C 0x0638
#define REG_ACKTO_CCK_8821C 0x0639
#define REG_MAC_SPEC_SIFS_8821C 0x063A
#define REG_RESP_SIFS_CCK_8821C 0x063C
#define REG_RESP_SIFS_OFDM_8821C 0x063E
#define REG_ACKTO_8821C 0x0640
#define REG_CTS2TO_8821C 0x0641
#define REG_EIFS_8821C 0x0642
#define REG_RPFM_MAP0_8821C 0x0644
#define REG_RPFM_MAP1_V1_8821C 0x0646
#define REG_RPFM_CAM_CMD_8821C 0x0648
#define REG_RPFM_CAM_RWD_8821C 0x064C
#define REG_NAV_CTRL_8821C 0x0650
#define REG_BACAMCMD_8821C 0x0654
#define REG_BACAMCONTENT_8821C 0x0658
#define REG_BACAMCONTENT_H_8821C 0x065C
#define REG_LBDLY_8821C 0x0660
#define REG_WMAC_BACAM_RPMEN_8821C 0x0661
#define REG_TX_RX_8821C 0x0662
#define REG_WMAC_BITMAP_CTL_8821C 0x0663
#define REG_RXERR_RPT_8821C 0x0664
#define REG_WMAC_TRXPTCL_CTL_8821C 0x0668
#define REG_WMAC_TRXPTCL_CTL_H_8821C 0x066C
#define REG_CAMCMD_8821C 0x0670
#define REG_CAMWRITE_8821C 0x0674
#define REG_CAMREAD_8821C 0x0678
#define REG_CAMDBG_8821C 0x067C
#define REG_SECCFG_8821C 0x0680
#define REG_RXFILTER_CATEGORY_1_8821C 0x0682
#define REG_RXFILTER_ACTION_1_8821C 0x0683
#define REG_RXFILTER_CATEGORY_2_8821C 0x0684
#define REG_RXFILTER_ACTION_2_8821C 0x0685
#define REG_RXFILTER_CATEGORY_3_8821C 0x0686
#define REG_RXFILTER_ACTION_3_8821C 0x0687
#define REG_RXFLTMAP3_8821C 0x0688
#define REG_RXFLTMAP4_8821C 0x068A
#define REG_RXFLTMAP5_8821C 0x068C
#define REG_RXFLTMAP6_8821C 0x068E
#define REG_WOW_CTRL_8821C 0x0690
#define REG_NAN_RX_TSF_FILTER_8821C 0x0691
#define REG_PS_RX_INFO_8821C 0x0692
#define REG_WMMPS_UAPSD_TID_8821C 0x0693
#define REG_LPNAV_CTRL_8821C 0x0694
#define REG_WKFMCAM_CMD_8821C 0x0698
#define REG_WKFMCAM_RWD_8821C 0x069C
#define REG_RXFLTMAP0_8821C 0x06A0
#define REG_RXFLTMAP1_8821C 0x06A2
#define REG_RXFLTMAP2_8821C 0x06A4
#define REG_BCN_PSR_RPT_8821C 0x06A8
#define REG_FLC_RPC_8821C 0x06AC
#define REG_FLC_RPCT_8821C 0x06AD
#define REG_FLC_PTS_8821C 0x06AE
#define REG_FLC_TRPC_8821C 0x06AF
#define REG_RXPKTMON_CTRL_8821C 0x06B0
#define REG_STATE_MON_8821C 0x06B4
#define REG_ERROR_MON_8821C 0x06B8
#define REG_SEARCH_MACID_8821C 0x06BC
#define REG_BT_COEX_TABLE_8821C 0x06C0
#define REG_BT_COEX_TABLE2_8821C 0x06C4
#define REG_BT_COEX_BREAK_TABLE_8821C 0x06C8
#define REG_BT_COEX_TABLE_H_8821C 0x06CC
#define REG_RXCMD_0_8821C 0x06D0
#define REG_RXCMD_1_8821C 0x06D4
#define REG_WMAC_RESP_TXINFO_8821C 0x06D8
#define REG_BBPSF_CTRL_8821C 0x06DC
#define REG_P2P_RX_BCN_NOA_8821C 0x06E0
#define REG_ASSOCIATED_BFMER0_INFO_8821C 0x06E4
#define REG_ASSOCIATED_BFMER0_INFO_H_8821C 0x06E8
#define REG_ASSOCIATED_BFMER1_INFO_8821C 0x06EC
#define REG_ASSOCIATED_BFMER1_INFO_H_8821C 0x06F0
#define REG_TX_CSI_RPT_PARAM_BW20_8821C 0x06F4
#define REG_TX_CSI_RPT_PARAM_BW40_8821C 0x06F8
#define REG_BCN_PSR_RPT2_8821C 0x1600
#define REG_BCN_PSR_RPT3_8821C 0x1604
#define REG_BCN_PSR_RPT4_8821C 0x1608
#define REG_A1_ADDR_MASK_8821C 0x160C
#define REG_MACID2_8821C 0x1620
#define REG_MACID2_H_8821C 0x1624
#define REG_BSSID2_8821C 0x1628
#define REG_BSSID2_H_8821C 0x162C
#define REG_MACID3_8821C 0x1630
#define REG_MACID3_H_8821C 0x1634
#define REG_BSSID3_8821C 0x1638
#define REG_BSSID3_H_8821C 0x163C
#define REG_MACID4_8821C 0x1640
#define REG_MACID4_H_8821C 0x1644
#define REG_BSSID4_8821C 0x1648
#define REG_BSSID4_H_8821C 0x164C
#define REG_NOA_REPORT_8821C 0x1650
#define REG_NOA_REPORT_1_8821C 0x1654
#define REG_NOA_REPORT_2_8821C 0x1658
#define REG_NOA_REPORT_3_8821C 0x165C
#define REG_PWRBIT_SETTING_8821C 0x1660
#define REG_MU_BF_OPTION_8821C 0x167C
#define REG_WMAC_PAUSE_BB_CLR_TH_8821C 0x167D
#define REG_WMAC_MU_ARB_8821C 0x167E
#define REG_WMAC_MU_OPTION_8821C 0x167F
#define REG_WMAC_MU_BF_CTL_8821C 0x1680
#define REG_WMAC_MU_BFRPT_PARA_8821C 0x1682
#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8821C 0x1684
#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8821C 0x1686
#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8821C 0x1688
#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8821C 0x168A
#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8821C 0x168C
#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8821C 0x168E
#define REG_WMAC_BB_STOP_RX_COUNTER_8821C 0x1690
#define REG_WMAC_PLCP_MONITOR_8821C 0x1694
#define REG_WMAC_PLCP_MONITOR_MUTX_8821C 0x1698
#define REG_TRANSMIT_ADDRSS_0_8821C 0x16A0
#define REG_TRANSMIT_ADDRSS_0_H_8821C 0x16A4
#define REG_TRANSMIT_ADDRSS_1_8821C 0x16A8
#define REG_TRANSMIT_ADDRSS_1_H_8821C 0x16AC
#define REG_TRANSMIT_ADDRSS_2_8821C 0x16B0
#define REG_TRANSMIT_ADDRSS_2_H_8821C 0x16B4
#define REG_TRANSMIT_ADDRSS_3_8821C 0x16B8
#define REG_TRANSMIT_ADDRSS_3_H_8821C 0x16BC
#define REG_TRANSMIT_ADDRSS_4_8821C 0x16C0
#define REG_TRANSMIT_ADDRSS_4_H_8821C 0x16C4
#define REG_MACID1_8821C 0x0700
#define REG_MACID1_1_8821C 0x0704
#define REG_BSSID1_8821C 0x0708
#define REG_BSSID1_1_8821C 0x070C
#define REG_BCN_PSR_RPT1_8821C 0x0710
#define REG_ASSOCIATED_BFMEE_SEL_8821C 0x0714
#define REG_SND_PTCL_CTRL_8821C 0x0718
#define REG_RX_CSI_RPT_INFO_8821C 0x071C
#define REG_NS_ARP_CTRL_8821C 0x0720
#define REG_NS_ARP_INFO_8821C 0x0724
#define REG_BEAMFORMING_INFO_NSARP_V1_8821C 0x0728
#define REG_BEAMFORMING_INFO_NSARP_8821C 0x072C
#define REG_IPV6_8821C 0x0730
#define REG_IPV6_1_8821C 0x0734
#define REG_IPV6_2_8821C 0x0738
#define REG_IPV6_3_8821C 0x073C
#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8821C 0x0750
#define REG_WMAC_SWAES_CFG_8821C 0x0760
#define REG_BT_COEX_V2_8821C 0x0762
#define REG_BT_COEX_8821C 0x0764
#define REG_WLAN_ACT_MASK_CTRL_8821C 0x0768
#define REG_WLAN_ACT_MASK_CTRL_1_8821C 0x076C
#define REG_BT_COEX_ENHANCED_INTR_CTRL_8821C 0x076E
#define REG_BT_ACT_STATISTICS_8821C 0x0770
#define REG_BT_ACT_STATISTICS_1_8821C 0x0774
#define REG_BT_STATISTICS_CONTROL_REGISTER_8821C 0x0778
#define REG_BT_STATUS_REPORT_REGISTER_8821C 0x077C
#define REG_BT_INTERRUPT_CONTROL_REGISTER_8821C 0x0780
#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8821C 0x0784
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8821C 0x0785
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8821C 0x0788
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8821C 0x078C
#define REG_BT_INTERRUPT_STATUS_REGISTER_8821C 0x078F
#define REG_BT_TDMA_TIME_REGISTER_8821C 0x0790
#define REG_BT_ACT_REGISTER_8821C 0x0794
#define REG_OBFF_CTRL_BASIC_8821C 0x0798
#define REG_OBFF_CTRL2_TIMER_8821C 0x079C
#define REG_LTR_CTRL_BASIC_8821C 0x07A0
#define REG_LTR_CTRL2_TIMER_THRESHOLD_8821C 0x07A4
#define REG_LTR_IDLE_LATENCY_V1_8821C 0x07A8
#define REG_LTR_ACTIVE_LATENCY_V1_8821C 0x07AC
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8821C 0x07B0
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_1_8821C 0x07B4
#define REG_WMAC_PKTCNT_RWD_8821C 0x07B8
#define REG_WMAC_PKTCNT_CTRL_8821C 0x07BC
#define REG_IQ_DUMP_8821C 0x07C0
#define REG_IQ_DUMP_1_8821C 0x07C4
#define REG_IQ_DUMP_2_8821C 0x07C8
#define REG_WMAC_FTM_CTL_8821C 0x07CC
#define REG_WMAC_IQ_MDPK_FUNC_8821C 0x07CE
#define REG_WMAC_OPTION_FUNCTION_8821C 0x07D0
#define REG_WMAC_OPTION_FUNCTION_1_8821C 0x07D4
#define REG_WMAC_OPTION_FUNCTION_2_8821C 0x07D8
#define REG_RX_FILTER_FUNCTION_8821C 0x07DA
#define REG_NDP_SIG_8821C 0x07E0
#define REG_TXCMD_INFO_FOR_RSP_PKT_8821C 0x07E4
#define REG_TXCMD_INFO_FOR_RSP_PKT_1_8821C 0x07E8
#define REG_WSEC_OPTION_8821C 0x07EC
#define REG_RTS_ADDRESS_0_8821C 0x07F0
#define REG_RTS_ADDRESS_0_1_8821C 0x07F4
#define REG_RTS_ADDRESS_1_8821C 0x07F8
#define REG_RTS_ADDRESS_1_1_8821C 0x07FC
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8821C 0x1700
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8821C 0x1704
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8821C 0x1708
#define REG_SDIO_TX_CTRL_8821C 0x10250000
#define REG_SDIO_HIMR_8821C 0x10250014
#define REG_SDIO_HISR_8821C 0x10250018
#define REG_SDIO_RX_REQ_LEN_8821C 0x1025001C
#define REG_SDIO_FREE_TXPG_SEQ_V1_8821C 0x1025001F
#define REG_SDIO_FREE_TXPG_8821C 0x10250020
#define REG_SDIO_FREE_TXPG2_8821C 0x10250024
#define REG_SDIO_OQT_FREE_TXPG_V1_8821C 0x10250028
#define REG_SDIO_HTSFR_INFO_8821C 0x10250030
#define REG_SDIO_HCPWM1_V2_8821C 0x10250038
#define REG_SDIO_HCPWM2_V2_8821C 0x1025003A
#define REG_SDIO_INDIRECT_REG_CFG_8821C 0x10250040
#define REG_SDIO_INDIRECT_REG_DATA_8821C 0x10250044
#define REG_SDIO_H2C_8821C 0x10250060
#define REG_SDIO_C2H_8821C 0x10250064
#define REG_SDIO_HRPWM1_8821C 0x10250080
#define REG_SDIO_HRPWM2_8821C 0x10250082
#define REG_SDIO_HPS_CLKR_8821C 0x10250084
#define REG_SDIO_BUS_CTRL_8821C 0x10250085
#define REG_SDIO_HSUS_CTRL_8821C 0x10250086
#define REG_SDIO_RESPONSE_TIMER_8821C 0x10250088
#define REG_SDIO_CMD_CRC_8821C 0x1025008A
#define REG_SDIO_HSISR_8821C 0x10250090
#define REG_SDIO_ERR_RPT_8821C 0x102500C0
#define REG_SDIO_CMD_ERRCNT_8821C 0x102500C2
#define REG_SDIO_DATA_ERRCNT_8821C 0x102500C3
#define REG_SDIO_CMD_ERR_CONTENT_8821C 0x102500C4
#define REG_SDIO_CRC_ERR_IDX_8821C 0x102500C9
#define REG_SDIO_DATA_CRC_8821C 0x102500CA
#define REG_SDIO_DATA_REPLY_TIME_8821C 0x102500CB
#endif
================================================
FILE: hal/halmac/halmac_reg_8822b.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_REG_8822B_H
#define __INC_HALMAC_REG_8822B_H
#define REG_SYS_ISO_CTRL_8822B 0x0000
#define REG_SYS_FUNC_EN_8822B 0x0002
#define REG_SYS_PW_CTRL_8822B 0x0004
#define REG_SYS_CLK_CTRL_8822B 0x0008
#define REG_SYS_EEPROM_CTRL_8822B 0x000A
#define REG_EE_VPD_8822B 0x000C
#define REG_SYS_SWR_CTRL1_8822B 0x0010
#define REG_SYS_SWR_CTRL2_8822B 0x0014
#define REG_SYS_SWR_CTRL3_8822B 0x0018
#define REG_RSV_CTRL_8822B 0x001C
#define REG_RF_CTRL_8822B 0x001F
#define REG_AFE_LDO_CTRL_8822B 0x0020
#define REG_AFE_CTRL1_8822B 0x0024
#define REG_AFE_CTRL2_8822B 0x0028
#define REG_AFE_CTRL3_8822B 0x002C
#define REG_EFUSE_CTRL_8822B 0x0030
#define REG_LDO_EFUSE_CTRL_8822B 0x0034
#define REG_PWR_OPTION_CTRL_8822B 0x0038
#define REG_CAL_TIMER_8822B 0x003C
#define REG_ACLK_MON_8822B 0x003E
#define REG_GPIO_MUXCFG_8822B 0x0040
#define REG_GPIO_PIN_CTRL_8822B 0x0044
#define REG_GPIO_INTM_8822B 0x0048
#define REG_LED_CFG_8822B 0x004C
#define REG_FSIMR_8822B 0x0050
#define REG_FSISR_8822B 0x0054
#define REG_HSIMR_8822B 0x0058
#define REG_HSISR_8822B 0x005C
#define REG_GPIO_EXT_CTRL_8822B 0x0060
#define REG_PAD_CTRL1_8822B 0x0064
#define REG_WL_BT_PWR_CTRL_8822B 0x0068
#define REG_SDM_DEBUG_8822B 0x006C
#define REG_SYS_SDIO_CTRL_8822B 0x0070
#define REG_HCI_OPT_CTRL_8822B 0x0074
#define REG_AFE_CTRL4_8822B 0x0078
#define REG_LDO_SWR_CTRL_8822B 0x007C
#define REG_MCUFW_CTRL_8822B 0x0080
#define REG_MCU_TST_CFG_8822B 0x0084
#define REG_HMEBOX_E0_E1_8822B 0x0088
#define REG_HMEBOX_E2_E3_8822B 0x008C
#define REG_WLLPS_CTRL_8822B 0x0090
#define REG_AFE_CTRL5_8822B 0x0094
#define REG_GPIO_DEBOUNCE_CTRL_8822B 0x0098
#define REG_RPWM2_8822B 0x009C
#define REG_SYSON_FSM_MON_8822B 0x00A0
#define REG_AFE_CTRL6_8822B 0x00A4
#define REG_PMC_DBG_CTRL1_8822B 0x00A8
#define REG_AFE_CTRL7_8822B 0x00AC
#define REG_HIMR0_8822B 0x00B0
#define REG_HISR0_8822B 0x00B4
#define REG_HIMR1_8822B 0x00B8
#define REG_HISR1_8822B 0x00BC
#define REG_DBG_PORT_SEL_8822B 0x00C0
#define REG_PAD_CTRL2_8822B 0x00C4
#define REG_PMC_DBG_CTRL2_8822B 0x00CC
#define REG_BIST_CTRL_8822B 0x00D0
#define REG_BIST_RPT_8822B 0x00D4
#define REG_MEM_CTRL_8822B 0x00D8
#define REG_AFE_CTRL8_8822B 0x00DC
#define REG_USB_SIE_INTF_8822B 0x00E0
#define REG_PCIE_MIO_INTF_8822B 0x00E4
#define REG_PCIE_MIO_INTD_8822B 0x00E8
#define REG_WLRF1_8822B 0x00EC
#define REG_SYS_CFG1_8822B 0x00F0
#define REG_SYS_STATUS1_8822B 0x00F4
#define REG_SYS_STATUS2_8822B 0x00F8
#define REG_SYS_CFG2_8822B 0x00FC
#define REG_SYS_CFG3_8822B 0x1000
#define REG_SYS_CFG4_8822B 0x1034
#define REG_SYS_CFG5_8822B 0x1070
#define REG_CPU_DMEM_CON_8822B 0x1080
#define REG_BOOT_REASON_8822B 0x1088
#define REG_NFCPAD_CTRL_8822B 0x10A8
#define REG_HIMR2_8822B 0x10B0
#define REG_HISR2_8822B 0x10B4
#define REG_HIMR3_8822B 0x10B8
#define REG_HISR3_8822B 0x10BC
#define REG_SW_MDIO_8822B 0x10C0
#define REG_SW_FLUSH_8822B 0x10C4
#define REG_H2C_PKT_READADDR_8822B 0x10D0
#define REG_H2C_PKT_WRITEADDR_8822B 0x10D4
#define REG_MEM_PWR_CRTL_8822B 0x10D8
#define REG_FW_DBG0_8822B 0x10E0
#define REG_FW_DBG1_8822B 0x10E4
#define REG_FW_DBG2_8822B 0x10E8
#define REG_FW_DBG3_8822B 0x10EC
#define REG_FW_DBG4_8822B 0x10F0
#define REG_FW_DBG5_8822B 0x10F4
#define REG_FW_DBG6_8822B 0x10F8
#define REG_FW_DBG7_8822B 0x10FC
#define REG_CR_8822B 0x0100
#define REG_TSF_CLK_STATE_8822B 0x0108
#define REG_TXDMA_PQ_MAP_8822B 0x010C
#define REG_TRXFF_BNDY_8822B 0x0114
#define REG_PTA_I2C_MBOX_8822B 0x0118
#define REG_RXFF_BNDY_8822B 0x011C
#define REG_FE1IMR_8822B 0x0120
#define REG_FE1ISR_8822B 0x0124
#define REG_CPWM_8822B 0x012C
#define REG_FWIMR_8822B 0x0130
#define REG_FWISR_8822B 0x0134
#define REG_FTIMR_8822B 0x0138
#define REG_FTISR_8822B 0x013C
#define REG_PKTBUF_DBG_CTRL_8822B 0x0140
#define REG_PKTBUF_DBG_DATA_L_8822B 0x0144
#define REG_PKTBUF_DBG_DATA_H_8822B 0x0148
#define REG_CPWM2_8822B 0x014C
#define REG_TC0_CTRL_8822B 0x0150
#define REG_TC1_CTRL_8822B 0x0154
#define REG_TC2_CTRL_8822B 0x0158
#define REG_TC3_CTRL_8822B 0x015C
#define REG_TC4_CTRL_8822B 0x0160
#define REG_TCUNIT_BASE_8822B 0x0164
#define REG_TC5_CTRL_8822B 0x0168
#define REG_TC6_CTRL_8822B 0x016C
#define REG_MBIST_FAIL_8822B 0x0170
#define REG_MBIST_START_PAUSE_8822B 0x0174
#define REG_MBIST_DONE_8822B 0x0178
#define REG_MBIST_FAIL_NRML_8822B 0x017C
#define REG_AES_DECRPT_DATA_8822B 0x0180
#define REG_AES_DECRPT_CFG_8822B 0x0184
#define REG_TMETER_8822B 0x0190
#define REG_OSC_32K_CTRL_8822B 0x0194
#define REG_32K_CAL_REG1_8822B 0x0198
#define REG_C2HEVT_8822B 0x01A0
#define REG_C2HEVT_1_8822B 0x01A4
#define REG_C2HEVT_2_8822B 0x01A8
#define REG_C2HEVT_3_8822B 0x01AC
#define REG_SW_DEFINED_PAGE1_8822B 0x01B8
#define REG_MCUTST_I_8822B 0x01C0
#define REG_MCUTST_II_8822B 0x01C4
#define REG_FMETHR_8822B 0x01C8
#define REG_HMETFR_8822B 0x01CC
#define REG_HMEBOX0_8822B 0x01D0
#define REG_HMEBOX1_8822B 0x01D4
#define REG_HMEBOX2_8822B 0x01D8
#define REG_HMEBOX3_8822B 0x01DC
#define REG_LLT_INIT_8822B 0x01E0
#define REG_LLT_INIT_ADDR_8822B 0x01E4
#define REG_BB_ACCESS_CTRL_8822B 0x01E8
#define REG_BB_ACCESS_DATA_8822B 0x01EC
#define REG_HMEBOX_E0_8822B 0x01F0
#define REG_HMEBOX_E1_8822B 0x01F4
#define REG_HMEBOX_E2_8822B 0x01F8
#define REG_HMEBOX_E3_8822B 0x01FC
#define REG_CR_EXT_8822B 0x1100
#define REG_FWFF_8822B 0x1114
#define REG_RXFF_PTR_V1_8822B 0x1118
#define REG_RXFF_WTR_V1_8822B 0x111C
#define REG_FE2IMR_8822B 0x1120
#define REG_FE2ISR_8822B 0x1124
#define REG_FE3IMR_8822B 0x1128
#define REG_FE3ISR_8822B 0x112C
#define REG_FE4IMR_8822B 0x1130
#define REG_FE4ISR_8822B 0x1134
#define REG_FT1IMR_8822B 0x1138
#define REG_FT1ISR_8822B 0x113C
#define REG_SPWR0_8822B 0x1140
#define REG_SPWR1_8822B 0x1144
#define REG_SPWR2_8822B 0x1148
#define REG_SPWR3_8822B 0x114C
#define REG_POWSEQ_8822B 0x1150
#define REG_TC7_CTRL_V1_8822B 0x1158
#define REG_TC8_CTRL_V1_8822B 0x115C
#define REG_FT2IMR_8822B 0x11E0
#define REG_FT2ISR_8822B 0x11E4
#define REG_MSG2_8822B 0x11F0
#define REG_MSG3_8822B 0x11F4
#define REG_MSG4_8822B 0x11F8
#define REG_MSG5_8822B 0x11FC
#define REG_FIFOPAGE_CTRL_1_8822B 0x0200
#define REG_FIFOPAGE_CTRL_2_8822B 0x0204
#define REG_AUTO_LLT_V1_8822B 0x0208
#define REG_TXDMA_OFFSET_CHK_8822B 0x020C
#define REG_TXDMA_STATUS_8822B 0x0210
#define REG_TX_DMA_DBG_8822B 0x0214
#define REG_TQPNT1_8822B 0x0218
#define REG_TQPNT2_8822B 0x021C
#define REG_TQPNT3_8822B 0x0220
#define REG_TQPNT4_8822B 0x0224
#define REG_RQPN_CTRL_1_8822B 0x0228
#define REG_RQPN_CTRL_2_8822B 0x022C
#define REG_FIFOPAGE_INFO_1_8822B 0x0230
#define REG_FIFOPAGE_INFO_2_8822B 0x0234
#define REG_FIFOPAGE_INFO_3_8822B 0x0238
#define REG_FIFOPAGE_INFO_4_8822B 0x023C
#define REG_FIFOPAGE_INFO_5_8822B 0x0240
#define REG_H2C_HEAD_8822B 0x0244
#define REG_H2C_TAIL_8822B 0x0248
#define REG_H2C_READ_ADDR_8822B 0x024C
#define REG_H2C_WR_ADDR_8822B 0x0250
#define REG_H2C_INFO_8822B 0x0254
#define REG_RXDMA_AGG_PG_TH_8822B 0x0280
#define REG_RXPKT_NUM_8822B 0x0284
#define REG_RXDMA_STATUS_8822B 0x0288
#define REG_RXDMA_DPR_8822B 0x028C
#define REG_RXDMA_MODE_8822B 0x0290
#define REG_C2H_PKT_8822B 0x0294
#define REG_FWFF_C2H_8822B 0x0298
#define REG_FWFF_CTRL_8822B 0x029C
#define REG_FWFF_PKT_INFO_8822B 0x02A0
#define REG_DDMA_CH0SA_8822B 0x1200
#define REG_DDMA_CH0DA_8822B 0x1204
#define REG_DDMA_CH0CTRL_8822B 0x1208
#define REG_DDMA_CH1SA_8822B 0x1210
#define REG_DDMA_CH1DA_8822B 0x1214
#define REG_DDMA_CH1CTRL_8822B 0x1218
#define REG_DDMA_CH2SA_8822B 0x1220
#define REG_DDMA_CH2DA_8822B 0x1224
#define REG_DDMA_CH2CTRL_8822B 0x1228
#define REG_DDMA_CH3SA_8822B 0x1230
#define REG_DDMA_CH3DA_8822B 0x1234
#define REG_DDMA_CH3CTRL_8822B 0x1238
#define REG_DDMA_CH4SA_8822B 0x1240
#define REG_DDMA_CH4DA_8822B 0x1244
#define REG_DDMA_CH4CTRL_8822B 0x1248
#define REG_DDMA_CH5SA_8822B 0x1250
#define REG_DDMA_CH5DA_8822B 0x1254
#define REG_REG_DDMA_CH5CTRL_8822B 0x1258
#define REG_DDMA_INT_MSK_8822B 0x12E0
#define REG_DDMA_CHSTATUS_8822B 0x12E8
#define REG_DDMA_CHKSUM_8822B 0x12F0
#define REG_DDMA_MONITOR_8822B 0x12FC
#define REG_PCIE_CTRL_8822B 0x0300
#define REG_INT_MIG_8822B 0x0304
#define REG_BCNQ_TXBD_DESA_8822B 0x0308
#define REG_MGQ_TXBD_DESA_8822B 0x0310
#define REG_VOQ_TXBD_DESA_8822B 0x0318
#define REG_VIQ_TXBD_DESA_8822B 0x0320
#define REG_BEQ_TXBD_DESA_8822B 0x0328
#define REG_BKQ_TXBD_DESA_8822B 0x0330
#define REG_RXQ_RXBD_DESA_8822B 0x0338
#define REG_HI0Q_TXBD_DESA_8822B 0x0340
#define REG_HI1Q_TXBD_DESA_8822B 0x0348
#define REG_HI2Q_TXBD_DESA_8822B 0x0350
#define REG_HI3Q_TXBD_DESA_8822B 0x0358
#define REG_HI4Q_TXBD_DESA_8822B 0x0360
#define REG_HI5Q_TXBD_DESA_8822B 0x0368
#define REG_HI6Q_TXBD_DESA_8822B 0x0370
#define REG_HI7Q_TXBD_DESA_8822B 0x0378
#define REG_MGQ_TXBD_NUM_8822B 0x0380
#define REG_RX_RXBD_NUM_8822B 0x0382
#define REG_VOQ_TXBD_NUM_8822B 0x0384
#define REG_VIQ_TXBD_NUM_8822B 0x0386
#define REG_BEQ_TXBD_NUM_8822B 0x0388
#define REG_BKQ_TXBD_NUM_8822B 0x038A
#define REG_HI0Q_TXBD_NUM_8822B 0x038C
#define REG_HI1Q_TXBD_NUM_8822B 0x038E
#define REG_HI2Q_TXBD_NUM_8822B 0x0390
#define REG_HI3Q_TXBD_NUM_8822B 0x0392
#define REG_HI4Q_TXBD_NUM_8822B 0x0394
#define REG_HI5Q_TXBD_NUM_8822B 0x0396
#define REG_HI6Q_TXBD_NUM_8822B 0x0398
#define REG_HI7Q_TXBD_NUM_8822B 0x039A
#define REG_TSFTIMER_HCI_8822B 0x039C
#define REG_BD_RWPTR_CLR_8822B 0x039C
#define REG_VOQ_TXBD_IDX_8822B 0x03A0
#define REG_VIQ_TXBD_IDX_8822B 0x03A4
#define REG_BEQ_TXBD_IDX_8822B 0x03A8
#define REG_BKQ_TXBD_IDX_8822B 0x03AC
#define REG_MGQ_TXBD_IDX_8822B 0x03B0
#define REG_RXQ_RXBD_IDX_8822B 0x03B4
#define REG_HI0Q_TXBD_IDX_8822B 0x03B8
#define REG_HI1Q_TXBD_IDX_8822B 0x03BC
#define REG_HI2Q_TXBD_IDX_8822B 0x03C0
#define REG_HI3Q_TXBD_IDX_8822B 0x03C4
#define REG_HI4Q_TXBD_IDX_8822B 0x03C8
#define REG_HI5Q_TXBD_IDX_8822B 0x03CC
#define REG_HI6Q_TXBD_IDX_8822B 0x03D0
#define REG_HI7Q_TXBD_IDX_8822B 0x03D4
#define REG_DBG_SEL_V1_8822B 0x03D8
#define REG_PCIE_HRPWM1_V1_8822B 0x03D9
#define REG_PCIE_HCPWM1_V1_8822B 0x03DA
#define REG_PCIE_CTRL2_8822B 0x03DB
#define REG_PCIE_HRPWM2_V1_8822B 0x03DC
#define REG_PCIE_HCPWM2_V1_8822B 0x03DE
#define REG_PCIE_H2C_MSG_V1_8822B 0x03E0
#define REG_PCIE_C2H_MSG_V1_8822B 0x03E4
#define REG_DBI_WDATA_V1_8822B 0x03E8
#define REG_DBI_RDATA_V1_8822B 0x03EC
#define REG_DBI_FLAG_V1_8822B 0x03F0
#define REG_MDIO_V1_8822B 0x03F4
#define REG_PCIE_MIX_CFG_8822B 0x03F8
#define REG_HCI_MIX_CFG_8822B 0x03FC
#define REG_STC_INT_CS_8822B 0x1300
#define REG_ST_INT_CFG_8822B 0x1304
#define REG_CMU_DLY_CTRL_8822B 0x1310
#define REG_CMU_DLY_CFG_8822B 0x1314
#define REG_H2CQ_TXBD_DESA_8822B 0x1320
#define REG_H2CQ_TXBD_NUM_8822B 0x1328
#define REG_H2CQ_TXBD_IDX_8822B 0x132C
#define REG_H2CQ_CSR_8822B 0x1330
#define REG_CHANGE_PCIE_SPEED_8822B 0x1350
#define REG_OLD_DEHANG_8822B 0x13F4
#define REG_Q0_INFO_8822B 0x0400
#define REG_Q1_INFO_8822B 0x0404
#define REG_Q2_INFO_8822B 0x0408
#define REG_Q3_INFO_8822B 0x040C
#define REG_MGQ_INFO_8822B 0x0410
#define REG_HIQ_INFO_8822B 0x0414
#define REG_BCNQ_INFO_8822B 0x0418
#define REG_TXPKT_EMPTY_8822B 0x041A
#define REG_CPU_MGQ_INFO_8822B 0x041C
#define REG_FWHW_TXQ_CTRL_8822B 0x0420
#define REG_DATAFB_SEL_8822B 0x0423
#define REG_BCNQ_BDNY_V1_8822B 0x0424
#define REG_LIFETIME_EN_8822B 0x0426
#define REG_SPEC_SIFS_8822B 0x0428
#define REG_RETRY_LIMIT_8822B 0x042A
#define REG_TXBF_CTRL_8822B 0x042C
#define REG_DARFRC_8822B 0x0430
#define REG_RARFRC_8822B 0x0438
#define REG_RRSR_8822B 0x0440
#define REG_ARFR0_8822B 0x0444
#define REG_ARFR1_V1_8822B 0x044C
#define REG_CCK_CHECK_8822B 0x0454
#define REG_AMPDU_MAX_TIME_V1_8822B 0x0455
#define REG_BCNQ1_BDNY_V1_8822B 0x0456
#define REG_AMPDU_MAX_LENGTH_8822B 0x0458
#define REG_ACQ_STOP_8822B 0x045C
#define REG_NDPA_RATE_8822B 0x045D
#define REG_TX_HANG_CTRL_8822B 0x045E
#define REG_NDPA_OPT_CTRL_8822B 0x045F
#define REG_RD_RESP_PKT_TH_8822B 0x0463
#define REG_CMDQ_INFO_8822B 0x0464
#define REG_Q4_INFO_8822B 0x0468
#define REG_Q5_INFO_8822B 0x046C
#define REG_Q6_INFO_8822B 0x0470
#define REG_Q7_INFO_8822B 0x0474
#define REG_WMAC_LBK_BUF_HD_V1_8822B 0x0478
#define REG_MGQ_BDNY_V1_8822B 0x047A
#define REG_TXRPT_CTRL_8822B 0x047C
#define REG_INIRTS_RATE_SEL_8822B 0x0480
#define REG_BASIC_CFEND_RATE_8822B 0x0481
#define REG_STBC_CFEND_RATE_8822B 0x0482
#define REG_DATA_SC_8822B 0x0483
#define REG_MACID_SLEEP3_8822B 0x0484
#define REG_MACID_SLEEP1_8822B 0x0488
#define REG_ARFR2_V1_8822B 0x048C
#define REG_ARFR3_V1_8822B 0x0494
#define REG_ARFR4_8822B 0x049C
#define REG_ARFR5_8822B 0x04A4
#define REG_TXRPT_START_OFFSET_8822B 0x04AC
#define REG_POWER_STAGE1_8822B 0x04B4
#define REG_POWER_STAGE2_8822B 0x04B8
#define REG_SW_AMPDU_BURST_MODE_CTRL_8822B 0x04BC
#define REG_PKT_LIFE_TIME_8822B 0x04C0
#define REG_STBC_SETTING_8822B 0x04C4
#define REG_STBC_SETTING2_8822B 0x04C5
#define REG_QUEUE_CTRL_8822B 0x04C6
#define REG_SINGLE_AMPDU_CTRL_8822B 0x04C7
#define REG_PROT_MODE_CTRL_8822B 0x04C8
#define REG_BAR_MODE_CTRL_8822B 0x04CC
#define REG_RA_TRY_RATE_AGG_LMT_8822B 0x04CF
#define REG_MACID_SLEEP2_8822B 0x04D0
#define REG_MACID_SLEEP_8822B 0x04D4
#define REG_HW_SEQ0_8822B 0x04D8
#define REG_HW_SEQ1_8822B 0x04DA
#define REG_HW_SEQ2_8822B 0x04DC
#define REG_HW_SEQ3_8822B 0x04DE
#define REG_NULL_PKT_STATUS_V1_8822B 0x04E0
#define REG_PTCL_ERR_STATUS_8822B 0x04E2
#define REG_NULL_PKT_STATUS_EXTEND_8822B 0x04E3
#define REG_VIDEO_ENHANCEMENT_FUN_8822B 0x04E4
#define REG_BT_POLLUTE_PKT_CNT_8822B 0x04E8
#define REG_PTCL_DBG_8822B 0x04EC
#define REG_CPUMGQ_TIMER_CTRL2_8822B 0x04F4
#define REG_DUMMY_PAGE4_V1_8822B 0x04FC
#define REG_MOREDATA_8822B 0x04FE
#define REG_Q0_Q1_INFO_8822B 0x1400
#define REG_Q2_Q3_INFO_8822B 0x1404
#define REG_Q4_Q5_INFO_8822B 0x1408
#define REG_Q6_Q7_INFO_8822B 0x140C
#define REG_MGQ_HIQ_INFO_8822B 0x1410
#define REG_CMDQ_BCNQ_INFO_8822B 0x1414
#define REG_USEREG_SETTING_8822B 0x1420
#define REG_AESIV_SETTING_8822B 0x1424
#define REG_BF0_TIME_SETTING_8822B 0x1428
#define REG_BF1_TIME_SETTING_8822B 0x142C
#define REG_BF_TIMEOUT_EN_8822B 0x1430
#define REG_MACID_RELEASE0_8822B 0x1434
#define REG_MACID_RELEASE1_8822B 0x1438
#define REG_MACID_RELEASE2_8822B 0x143C
#define REG_MACID_RELEASE3_8822B 0x1440
#define REG_MACID_RELEASE_SETTING_8822B 0x1444
#define REG_FAST_EDCA_VOVI_SETTING_8822B 0x1448
#define REG_FAST_EDCA_BEBK_SETTING_8822B 0x144C
#define REG_MACID_DROP0_8822B 0x1450
#define REG_MACID_DROP1_8822B 0x1454
#define REG_MACID_DROP2_8822B 0x1458
#define REG_MACID_DROP3_8822B 0x145C
#define REG_R_MACID_RELEASE_SUCCESS_0_8822B 0x1460
#define REG_R_MACID_RELEASE_SUCCESS_1_8822B 0x1464
#define REG_R_MACID_RELEASE_SUCCESS_2_8822B 0x1468
#define REG_R_MACID_RELEASE_SUCCESS_3_8822B 0x146C
#define REG_MGG_FIFO_CRTL_8822B 0x1470
#define REG_MGG_FIFO_INT_8822B 0x1474
#define REG_MGG_FIFO_LIFETIME_8822B 0x1478
#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822B 0x147C
#define REG_SHCUT_SETTING_8822B 0x1480
#define REG_SHCUT_LLC_ETH_TYPE0_8822B 0x1484
#define REG_SHCUT_LLC_ETH_TYPE1_8822B 0x1488
#define REG_SHCUT_LLC_OUI0_8822B 0x148C
#define REG_SHCUT_LLC_OUI1_8822B 0x1490
#define REG_SHCUT_LLC_OUI2_8822B 0x1494
#define REG_SHCUT_LLC_OUI3_8822B 0x1498
#define REG_MU_TX_CTL_8822B 0x14C0
#define REG_MU_TX_CTL_8822B 0x14C0
#define REG_MU_STA_GID_VLD_8822B 0x14C4
#define REG_MU_STA_GID_VLD_8822B 0x14C4
#define REG_MU_STA_USER_POS_INFO_8822B 0x14C8
#define REG_MU_STA_USER_POS_INFO_8822B 0x14C8
#define REG_MU_TRX_DBG_CNT_8822B 0x14D0
#define REG_MU_TRX_DBG_CNT_8822B 0x14D0
#define REG_EDCA_VO_PARAM_8822B 0x0500
#define REG_EDCA_VI_PARAM_8822B 0x0504
#define REG_EDCA_BE_PARAM_8822B 0x0508
#define REG_EDCA_BK_PARAM_8822B 0x050C
#define REG_BCNTCFG_8822B 0x0510
#define REG_PIFS_8822B 0x0512
#define REG_RDG_PIFS_8822B 0x0513
#define REG_SIFS_8822B 0x0514
#define REG_TSFTR_SYN_OFFSET_8822B 0x0518
#define REG_AGGR_BREAK_TIME_8822B 0x051A
#define REG_SLOT_8822B 0x051B
#define REG_TX_PTCL_CTRL_8822B 0x0520
#define REG_TXPAUSE_8822B 0x0522
#define REG_DIS_TXREQ_CLR_8822B 0x0523
#define REG_RD_CTRL_8822B 0x0524
#define REG_MBSSID_CTRL_8822B 0x0526
#define REG_P2PPS_CTRL_8822B 0x0527
#define REG_PKT_LIFETIME_CTRL_8822B 0x0528
#define REG_P2PPS_SPEC_STATE_8822B 0x052B
#define REG_TXOP_LIMIT_CTRL_8822B 0x052C
#define REG_BAR_TX_CTRL_8822B 0x0530
#define REG_P2PON_DIS_TXTIME_8822B 0x0531
#define REG_QUEUE_INCOL_THR_8822B 0x0538
#define REG_QUEUE_INCOL_EN_8822B 0x053C
#define REG_TBTT_PROHIBIT_8822B 0x0540
#define REG_P2PPS_STATE_8822B 0x0543
#define REG_RD_NAV_NXT_8822B 0x0544
#define REG_NAV_PROT_LEN_8822B 0x0546
#define REG_BCN_CTRL_8822B 0x0550
#define REG_BCN_CTRL_CLINT0_8822B 0x0551
#define REG_MBID_NUM_8822B 0x0552
#define REG_DUAL_TSF_RST_8822B 0x0553
#define REG_MBSSID_BCN_SPACE_8822B 0x0554
#define REG_DRVERLYINT_8822B 0x0558
#define REG_BCNDMATIM_8822B 0x0559
#define REG_ATIMWND_8822B 0x055A
#define REG_USTIME_TSF_8822B 0x055C
#define REG_BCN_MAX_ERR_8822B 0x055D
#define REG_RXTSF_OFFSET_CCK_8822B 0x055E
#define REG_RXTSF_OFFSET_OFDM_8822B 0x055F
#define REG_TSFTR_8822B 0x0560
#define REG_FREERUN_CNT_8822B 0x0568
#define REG_ATIMWND1_V1_8822B 0x0570
#define REG_TBTT_PROHIBIT_INFRA_8822B 0x0571
#define REG_CTWND_8822B 0x0572
#define REG_BCNIVLCUNT_8822B 0x0573
#define REG_BCNDROPCTRL_8822B 0x0574
#define REG_HGQ_TIMEOUT_PERIOD_8822B 0x0575
#define REG_TXCMD_TIMEOUT_PERIOD_8822B 0x0576
#define REG_MISC_CTRL_8822B 0x0577
#define REG_BCN_CTRL_CLINT1_8822B 0x0578
#define REG_BCN_CTRL_CLINT2_8822B 0x0579
#define REG_BCN_CTRL_CLINT3_8822B 0x057A
#define REG_EXTEND_CTRL_8822B 0x057B
#define REG_P2PPS1_SPEC_STATE_8822B 0x057C
#define REG_P2PPS1_STATE_8822B 0x057D
#define REG_P2PPS2_SPEC_STATE_8822B 0x057E
#define REG_P2PPS2_STATE_8822B 0x057F
#define REG_PS_TIMER0_8822B 0x0580
#define REG_PS_TIMER1_8822B 0x0584
#define REG_PS_TIMER2_8822B 0x0588
#define REG_TBTT_CTN_AREA_8822B 0x058C
#define REG_FORCE_BCN_IFS_8822B 0x058E
#define REG_TXOP_MIN_8822B 0x0590
#define REG_PRE_BKF_TIME_8822B 0x0592
#define REG_CROSS_TXOP_CTRL_8822B 0x0593
#define REG_ATIMWND2_8822B 0x05A0
#define REG_ATIMWND3_8822B 0x05A1
#define REG_ATIMWND4_8822B 0x05A2
#define REG_ATIMWND5_8822B 0x05A3
#define REG_ATIMWND6_8822B 0x05A4
#define REG_ATIMWND7_8822B 0x05A5
#define REG_ATIMUGT_8822B 0x05A6
#define REG_HIQ_NO_LMT_EN_8822B 0x05A7
#define REG_DTIM_COUNTER_ROOT_8822B 0x05A8
#define REG_DTIM_COUNTER_VAP1_8822B 0x05A9
#define REG_DTIM_COUNTER_VAP2_8822B 0x05AA
#define REG_DTIM_COUNTER_VAP3_8822B 0x05AB
#define REG_DTIM_COUNTER_VAP4_8822B 0x05AC
#define REG_DTIM_COUNTER_VAP5_8822B 0x05AD
#define REG_DTIM_COUNTER_VAP6_8822B 0x05AE
#define REG_DTIM_COUNTER_VAP7_8822B 0x05AF
#define REG_DIS_ATIM_8822B 0x05B0
#define REG_EARLY_128US_8822B 0x05B1
#define REG_P2PPS1_CTRL_8822B 0x05B2
#define REG_P2PPS2_CTRL_8822B 0x05B3
#define REG_TIMER0_SRC_SEL_8822B 0x05B4
#define REG_NOA_UNIT_SEL_8822B 0x05B5
#define REG_P2POFF_DIS_TXTIME_8822B 0x05B7
#define REG_MBSSID_BCN_SPACE2_8822B 0x05B8
#define REG_MBSSID_BCN_SPACE3_8822B 0x05BC
#define REG_ACMHWCTRL_8822B 0x05C0
#define REG_ACMRSTCTRL_8822B 0x05C1
#define REG_ACMAVG_8822B 0x05C2
#define REG_VO_ADMTIME_8822B 0x05C4
#define REG_VI_ADMTIME_8822B 0x05C6
#define REG_BE_ADMTIME_8822B 0x05C8
#define REG_EDCA_RANDOM_GEN_8822B 0x05CC
#define REG_TXCMD_NOA_SEL_8822B 0x05CF
#define REG_NOA_PARAM_8822B 0x05E0
#define REG_P2P_RST_8822B 0x05F0
#define REG_SCHEDULER_RST_8822B 0x05F1
#define REG_SCH_TXCMD_8822B 0x05F8
#define REG_PAGE5_DUMMY_8822B 0x05FC
#define REG_CPUMGQ_TX_TIMER_8822B 0x1500
#define REG_PS_TIMER_A_8822B 0x1504
#define REG_PS_TIMER_B_8822B 0x1508
#define REG_PS_TIMER_C_8822B 0x150C
#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8822B 0x1510
#define REG_CPUMGQ_TX_TIMER_EARLY_8822B 0x1514
#define REG_PS_TIMER_A_EARLY_8822B 0x1515
#define REG_PS_TIMER_B_EARLY_8822B 0x1516
#define REG_PS_TIMER_C_EARLY_8822B 0x1517
#define REG_CPUMGQ_PARAMETER_8822B 0x1518
#define REG_WMAC_CR_8822B 0x0600
#define REG_WMAC_FWPKT_CR_8822B 0x0601
#define REG_BWOPMODE_8822B 0x0603
#define REG_TCR_8822B 0x0604
#define REG_RCR_8822B 0x0608
#define REG_RX_PKT_LIMIT_8822B 0x060C
#define REG_RX_DLK_TIME_8822B 0x060D
#define REG_RX_DRVINFO_SZ_8822B 0x060F
#define REG_MACID_8822B 0x0610
#define REG_BSSID_8822B 0x0618
#define REG_MAR_8822B 0x0620
#define REG_MBIDCAMCFG_1_8822B 0x0628
#define REG_MBIDCAMCFG_2_8822B 0x062C
#define REG_WMAC_TCR_TSFT_OFS_8822B 0x0630
#define REG_UDF_THSD_8822B 0x0632
#define REG_ZLD_NUM_8822B 0x0633
#define REG_STMP_THSD_8822B 0x0634
#define REG_WMAC_TXTIMEOUT_8822B 0x0635
#define REG_MCU_TEST_2_V1_8822B 0x0636
#define REG_USTIME_EDCA_8822B 0x0638
#define REG_MAC_SPEC_SIFS_8822B 0x063A
#define REG_RESP_SIFS_CCK_8822B 0x063C
#define REG_RESP_SIFS_OFDM_8822B 0x063E
#define REG_ACKTO_8822B 0x0640
#define REG_CTS2TO_8822B 0x0641
#define REG_EIFS_8822B 0x0642
#define REG_NAV_CTRL_8822B 0x0650
#define REG_BACAMCMD_8822B 0x0654
#define REG_BACAMCONTENT_8822B 0x0658
#define REG_LBDLY_8822B 0x0660
#define REG_WMAC_BACAM_RPMEN_8822B 0x0661
#define REG_TX_RX_8822B 0x0662
#define REG_WMAC_BITMAP_CTL_8822B 0x0663
#define REG_RXERR_RPT_8822B 0x0664
#define REG_WMAC_TRXPTCL_CTL_8822B 0x0668
#define REG_CAMCMD_8822B 0x0670
#define REG_CAMWRITE_8822B 0x0674
#define REG_CAMREAD_8822B 0x0678
#define REG_CAMDBG_8822B 0x067C
#define REG_SECCFG_8822B 0x0680
#define REG_RXFILTER_CATEGORY_1_8822B 0x0682
#define REG_RXFILTER_ACTION_1_8822B 0x0683
#define REG_RXFILTER_CATEGORY_2_8822B 0x0684
#define REG_RXFILTER_ACTION_2_8822B 0x0685
#define REG_RXFILTER_CATEGORY_3_8822B 0x0686
#define REG_RXFILTER_ACTION_3_8822B 0x0687
#define REG_RXFLTMAP3_8822B 0x0688
#define REG_RXFLTMAP4_8822B 0x068A
#define REG_RXFLTMAP5_8822B 0x068C
#define REG_RXFLTMAP6_8822B 0x068E
#define REG_WOW_CTRL_8822B 0x0690
#define REG_NAN_RX_TSF_FILTER_8822B 0x0691
#define REG_PS_RX_INFO_8822B 0x0692
#define REG_WMMPS_UAPSD_TID_8822B 0x0693
#define REG_LPNAV_CTRL_8822B 0x0694
#define REG_WKFMCAM_CMD_8822B 0x0698
#define REG_WKFMCAM_RWD_8822B 0x069C
#define REG_RXFLTMAP0_8822B 0x06A0
#define REG_RXFLTMAP1_8822B 0x06A2
#define REG_RXFLTMAP2_8822B 0x06A4
#define REG_BCN_PSR_RPT_8822B 0x06A8
#define REG_FLC_RPC_8822B 0x06AC
#define REG_FLC_RPCT_8822B 0x06AD
#define REG_FLC_PTS_8822B 0x06AE
#define REG_FLC_TRPC_8822B 0x06AF
#define REG_RXPKTMON_CTRL_8822B 0x06B0
#define REG_STATE_MON_8822B 0x06B4
#define REG_ERROR_MON_8822B 0x06B8
#define REG_SEARCH_MACID_8822B 0x06BC
#define REG_BT_COEX_TABLE_8822B 0x06C0
#define REG_RXCMD_0_8822B 0x06D0
#define REG_RXCMD_1_8822B 0x06D4
#define REG_WMAC_RESP_TXINFO_8822B 0x06D8
#define REG_BBPSF_CTRL_8822B 0x06DC
#define REG_P2P_RX_BCN_NOA_8822B 0x06E0
#define REG_ASSOCIATED_BFMER0_INFO_8822B 0x06E4
#define REG_ASSOCIATED_BFMER1_INFO_8822B 0x06EC
#define REG_TX_CSI_RPT_PARAM_BW20_8822B 0x06F4
#define REG_TX_CSI_RPT_PARAM_BW40_8822B 0x06F8
#define REG_TX_CSI_RPT_PARAM_BW80_8822B 0x06FC
#define REG_BCN_PSR_RPT2_8822B 0x1600
#define REG_BCN_PSR_RPT3_8822B 0x1604
#define REG_BCN_PSR_RPT4_8822B 0x1608
#define REG_A1_ADDR_MASK_8822B 0x160C
#define REG_MACID2_8822B 0x1620
#define REG_BSSID2_8822B 0x1628
#define REG_MACID3_8822B 0x1630
#define REG_BSSID3_8822B 0x1638
#define REG_MACID4_8822B 0x1640
#define REG_BSSID4_8822B 0x1648
#define REG_NOA_REPORT_8822B 0x1650
#define REG_PWRBIT_SETTING_8822B 0x1660
#define REG_WMAC_MU_BF_OPTION_8822B 0x167C
#define REG_WMAC_MU_ARB_8822B 0x167E
#define REG_WMAC_MU_OPTION_8822B 0x167F
#define REG_WMAC_MU_BF_CTL_8822B 0x1680
#define REG_WMAC_MU_BFRPT_PARA_8822B 0x1682
#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8822B 0x1684
#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8822B 0x1686
#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8822B 0x1688
#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8822B 0x168A
#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8822B 0x168C
#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8822B 0x168E
#define REG_TRANSMIT_ADDRSS_0_8822B 0x16A0
#define REG_TRANSMIT_ADDRSS_1_8822B 0x16A8
#define REG_TRANSMIT_ADDRSS_2_8822B 0x16B0
#define REG_TRANSMIT_ADDRSS_3_8822B 0x16B8
#define REG_TRANSMIT_ADDRSS_4_8822B 0x16C0
#define REG_MACID1_8822B 0x0700
#define REG_BSSID1_8822B 0x0708
#define REG_BCN_PSR_RPT1_8822B 0x0710
#define REG_ASSOCIATED_BFMEE_SEL_8822B 0x0714
#define REG_SND_PTCL_CTRL_8822B 0x0718
#define REG_RX_CSI_RPT_INFO_8822B 0x071C
#define REG_NS_ARP_CTRL_8822B 0x0720
#define REG_NS_ARP_INFO_8822B 0x0724
#define REG_BEAMFORMING_INFO_NSARP_V1_8822B 0x0728
#define REG_BEAMFORMING_INFO_NSARP_8822B 0x072C
#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8822B 0x0750
#define REG_WMAC_SWAES_CFG_8822B 0x0760
#define REG_BT_COEX_V2_8822B 0x0762
#define REG_BT_COEX_8822B 0x0764
#define REG_WLAN_ACT_MASK_CTRL_8822B 0x0768
#define REG_BT_COEX_ENHANCED_INTR_CTRL_8822B 0x076E
#define REG_BT_ACT_STATISTICS_8822B 0x0770
#define REG_BT_STATISTICS_CONTROL_REGISTER_8822B 0x0778
#define REG_BT_STATUS_REPORT_REGISTER_8822B 0x077C
#define REG_BT_INTERRUPT_CONTROL_REGISTER_8822B 0x0780
#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8822B 0x0784
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8822B 0x0785
#define REG_BT_INTERRUPT_STATUS_REGISTER_8822B 0x078F
#define REG_BT_TDMA_TIME_REGISTER_8822B 0x0790
#define REG_BT_ACT_REGISTER_8822B 0x0794
#define REG_OBFF_CTRL_BASIC_8822B 0x0798
#define REG_OBFF_CTRL2_TIMER_8822B 0x079C
#define REG_LTR_CTRL_BASIC_8822B 0x07A0
#define REG_LTR_CTRL2_TIMER_THRESHOLD_8822B 0x07A4
#define REG_LTR_IDLE_LATENCY_V1_8822B 0x07A8
#define REG_LTR_ACTIVE_LATENCY_V1_8822B 0x07AC
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8822B 0x07B0
#define REG_WMAC_PKTCNT_RWD_8822B 0x07B8
#define REG_WMAC_PKTCNT_CTRL_8822B 0x07BC
#define REG_IQ_DUMP_8822B 0x07C0
#define REG_WMAC_FTM_CTL_8822B 0x07CC
#define REG_WMAC_IQ_MDPK_FUNC_8822B 0x07CE
#define REG_WMAC_OPTION_FUNCTION_8822B 0x07D0
#define REG_RX_FILTER_FUNCTION_8822B 0x07DA
#define REG_NDP_SIG_8822B 0x07E0
#define REG_TXCMD_INFO_FOR_RSP_PKT_8822B 0x07E4
#define REG_RTS_ADDRESS_0_8822B 0x07F0
#define REG_RTS_ADDRESS_1_8822B 0x07F8
#define REG__RPFM_MAP1_8822B 0x07FE
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8822B 0x1700
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8822B 0x1704
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8822B 0x1708
#define REG_SDIO_TX_CTRL_8822B 0x10250000
#define REG_SDIO_HIMR_8822B 0x10250014
#define REG_SDIO_HISR_8822B 0x10250018
#define REG_SDIO_RX_REQ_LEN_8822B 0x1025001C
#define REG_SDIO_FREE_TXPG_SEQ_V1_8822B 0x1025001F
#define REG_SDIO_FREE_TXPG_8822B 0x10250020
#define REG_SDIO_FREE_TXPG2_8822B 0x10250024
#define REG_SDIO_OQT_FREE_TXPG_V1_8822B 0x10250028
#define REG_SDIO_HTSFR_INFO_8822B 0x10250030
#define REG_SDIO_HCPWM1_V2_8822B 0x10250038
#define REG_SDIO_HCPWM2_V2_8822B 0x1025003A
#define REG_SDIO_INDIRECT_REG_CFG_8822B 0x10250040
#define REG_SDIO_INDIRECT_REG_DATA_8822B 0x10250044
#define REG_SDIO_H2C_8822B 0x10250060
#define REG_SDIO_C2H_8822B 0x10250064
#define REG_SDIO_HRPWM1_8822B 0x10250080
#define REG_SDIO_HRPWM2_8822B 0x10250082
#define REG_SDIO_HPS_CLKR_8822B 0x10250084
#define REG_SDIO_BUS_CTRL_8822B 0x10250085
#define REG_SDIO_HSUS_CTRL_8822B 0x10250086
#define REG_SDIO_RESPONSE_TIMER_8822B 0x10250088
#define REG_SDIO_CMD_CRC_8822B 0x1025008A
#define REG_SDIO_HSISR_8822B 0x10250090
#define REG_SDIO_ERR_RPT_8822B 0x102500C0
#define REG_SDIO_CMD_ERRCNT_8822B 0x102500C2
#define REG_SDIO_DATA_ERRCNT_8822B 0x102500C3
#define REG_SDIO_CMD_ERR_CONTENT_8822B 0x102500C4
#define REG_SDIO_CRC_ERR_IDX_8822B 0x102500C9
#define REG_SDIO_DATA_CRC_8822B 0x102500CA
#define REG_SDIO_DATA_REPLY_TIME_8822B 0x102500CB
#endif
================================================
FILE: hal/halmac/halmac_reg_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __INC_HALMAC_REG_8822C_H
#define __INC_HALMAC_REG_8822C_H
#define REG_SYS_ISO_CTRL_8822C 0x0000
#define REG_SYS_FUNC_EN_8822C 0x0002
#define REG_SYS_PW_CTRL_8822C 0x0004
#define REG_SYS_CLK_CTRL_8822C 0x0008
#define REG_SYS_EEPROM_CTRL_8822C 0x000A
#define REG_EE_VPD_8822C 0x000C
#define REG_SYS_SWR_CTRL1_8822C 0x0010
#define REG_SYS_SWR_CTRL2_8822C 0x0014
#define REG_SYS_SWR_CTRL3_8822C 0x0018
#define REG_RSV_CTRL_8822C 0x001C
#define REG_RF_CTRL_8822C 0x001F
#define REG_AFE_LDO_CTRL_8822C 0x0020
#define REG_AFE_CTRL1_8822C 0x0024
#define REG_ANAPARSW_POW_MAC_8822C 0x0028
#define REG_ANAPARLDO_POW_MAC_8822C 0x0029
#define REG_ANAPAR_POW_MAC_8822C 0x002A
#define REG_ANAPAR_POW_XTAL_8822C 0x002B
#define REG_ANAPARLDO_MAC_8822C 0x002C
#define REG_EFUSE_CTRL_8822C 0x0030
#define REG_LDO_EFUSE_CTRL_8822C 0x0034
#define REG_PWR_OPTION_CTRL_8822C 0x0038
#define REG_CAL_TIMER_8822C 0x003C
#define REG_ACLK_MON_8822C 0x003E
#define REG_GPIO_MUXCFG_2_8822C 0x003F
#define REG_GPIO_MUXCFG_8822C 0x0040
#define REG_GPIO_PIN_CTRL_8822C 0x0044
#define REG_GPIO_INTM_8822C 0x0048
#define REG_LED_CFG_8822C 0x004C
#define REG_FSIMR_8822C 0x0050
#define REG_FSISR_8822C 0x0054
#define REG_HSIMR_8822C 0x0058
#define REG_HSISR_8822C 0x005C
#define REG_GPIO_EXT_CTRL_8822C 0x0060
#define REG_PAD_CTRL1_8822C 0x0064
#define REG_WL_BT_PWR_CTRL_8822C 0x0068
#define REG_SDM_DEBUG_8822C 0x006C
#define REG_SYS_SDIO_CTRL_8822C 0x0070
#define REG_HCI_OPT_CTRL_8822C 0x0074
#define REG_HCI_BG_CTRL_8822C 0x0078
#define REG_HCI_LDO_CTRL_8822C 0x007A
#define REG_LDO_SWR_CTRL_8822C 0x007C
#define REG_MCUFW_CTRL_8822C 0x0080
#define REG_MCU_TST_CFG_8822C 0x0084
#define REG_HMEBOX_E0_E1_8822C 0x0088
#define REG_HMEBOX_E2_E3_8822C 0x008C
#define REG_WLLPS_CTRL_8822C 0x0090
#define REG_GPIO_DEBOUNCE_CTRL_8822C 0x0098
#define REG_RPWM2_8822C 0x009C
#define REG_SYSON_FSM_MON_8822C 0x00A0
#define REG_PMC_DBG_CTRL1_8822C 0x00A8
#define REG_HIMR0_8822C 0x00B0
#define REG_HISR0_8822C 0x00B4
#define REG_HIMR1_8822C 0x00B8
#define REG_HISR1_8822C 0x00BC
#define REG_DBG_PORT_SEL_8822C 0x00C0
#define REG_PAD_CTRL2_8822C 0x00C4
#define REG_PMC_DBG_CTRL2_8822C 0x00CC
#define REG_BIST_CTRL_8822C 0x00D0
#define REG_BIST_RPT_8822C 0x00D4
#define REG_MEM_CTRL_8822C 0x00D8
#define REG_USB_SIE_INTF_8822C 0x00E0
#define REG_PCIE_MIO_INTF_8822C 0x00E4
#define REG_PCIE_MIO_INTD_8822C 0x00E8
#define REG_WLRF1_8822C 0x00EC
#define REG_SYS_CFG1_8822C 0x00F0
#define REG_SYS_STATUS1_8822C 0x00F4
#define REG_SYS_STATUS2_8822C 0x00F8
#define REG_SYS_CFG2_8822C 0x00FC
#define REG_SYS_CFG3_8822C 0x1000
#define REG_ANAPARSW_MAC_0_8822C 0x1010
#define REG_ANAPARSW_MAC_1_8822C 0x1014
#define REG_ANAPAR_MAC_0_8822C 0x1018
#define REG_ANAPAR_MAC_1_8822C 0x101C
#define REG_ANAPAR_MAC_2_8822C 0x1020
#define REG_ANAPAR_XTAL_0_8822C 0x1040
#define REG_ANAPAR_XTAL_1_8822C 0x1044
#define REG_ANAPAR_XTAL_2_8822C 0x1048
#define REG_ANAPAR_XTAL_3_8822C 0x104C
#define REG_ANAPAR_XTAL_AACK_0_8822C 0x1054
#define REG_ANAPAR_XTAL_AACK_1_8822C 0x1058
#define REG_ANAPAR_XTAL_MODE_DECODER_8822C 0x1064
#define REG_SYS_CFG5_8822C 0x1070
#define REG_CPU_DMEM_CON_8822C 0x1080
#define REG_BOOT_REASON_8822C 0x1088
#define REG_HIMR2_8822C 0x10B0
#define REG_HISR2_8822C 0x10B4
#define REG_HIMR3_8822C 0x10B8
#define REG_HISR3_8822C 0x10BC
#define REG_SW_MDIO_8822C 0x10C0
#define REG_H2C_PKT_READADDR_8822C 0x10D0
#define REG_H2C_PKT_WRITEADDR_8822C 0x10D4
#define REG_MEM_PWR_CRTL_8822C 0x10D8
#define REG_FW_DBG6_8822C 0x10F8
#define REG_FW_DBG7_8822C 0x10FC
#define REG_CR_8822C 0x0100
#define REG_PG_SIZE_8822C 0x0104
#define REG_PKT_BUFF_ACCESS_CTRL_8822C 0x0106
#define REG_TSF_CLK_STATE_8822C 0x0108
#define REG_TXDMA_PQ_MAP_8822C 0x010C
#define REG_TRXFF_BNDY_8822C 0x0114
#define REG_PTA_I2C_MBOX_8822C 0x0118
#define REG_RXFF_BNDY_8822C 0x011C
#define REG_FE1IMR_8822C 0x0120
#define REG_FE1ISR_8822C 0x0124
#define REG_CPWM_8822C 0x012C
#define REG_FWIMR_8822C 0x0130
#define REG_FWISR_8822C 0x0134
#define REG_FTIMR_8822C 0x0138
#define REG_FTISR_8822C 0x013C
#define REG_PKTBUF_DBG_CTRL_8822C 0x0140
#define REG_PKTBUF_DBG_DATA_L_8822C 0x0144
#define REG_PKTBUF_DBG_DATA_H_8822C 0x0148
#define REG_CPWM2_8822C 0x014C
#define REG_TC0_CTRL_8822C 0x0150
#define REG_TC1_CTRL_8822C 0x0154
#define REG_TC2_CTRL_8822C 0x0158
#define REG_TC3_CTRL_8822C 0x015C
#define REG_TC4_CTRL_8822C 0x0160
#define REG_TCUNIT_BASE_8822C 0x0164
#define REG_TC5_CTRL_8822C 0x0168
#define REG_TC6_CTRL_8822C 0x016C
#define REG_MBIST_DRF_FAIL_8822C 0x0170
#define REG_MBIST_START_PAUSE_8822C 0x0174
#define REG_MBIST_DONE_8822C 0x0178
#define REG_MBIST_READ_BIST_RPT_8822C 0x017C
#define REG_AES_DECRPT_DATA_8822C 0x0180
#define REG_AES_DECRPT_CFG_8822C 0x0184
#define REG_HIOE_CTRL_8822C 0x0188
#define REG_HIOE_CFG_FILE_8822C 0x018C
#define REG_TMETER_8822C 0x0190
#define REG_OSC_32K_CTRL_8822C 0x0194
#define REG_32K_CAL_REG1_8822C 0x0198
#define REG_C2HEVT_8822C 0x01A0
#define REG_C2HEVT_1_8822C 0x01A4
#define REG_C2HEVT_2_8822C 0x01A8
#define REG_C2HEVT_3_8822C 0x01AC
#define REG_SW_DEFINED_PAGE1_8822C 0x01B8
#define REG_SW_DEFINED_PAGE2_8822C 0x01BC
#define REG_MCUTST_I_8822C 0x01C0
#define REG_MCUTST_II_8822C 0x01C4
#define REG_FMETHR_8822C 0x01C8
#define REG_HMETFR_8822C 0x01CC
#define REG_HMEBOX0_8822C 0x01D0
#define REG_HMEBOX1_8822C 0x01D4
#define REG_HMEBOX2_8822C 0x01D8
#define REG_HMEBOX3_8822C 0x01DC
#define REG_BB_ACCESS_CTRL_8822C 0x01E8
#define REG_BB_ACCESS_DATA_8822C 0x01EC
#define REG_HMEBOX_E0_8822C 0x01F0
#define REG_HMEBOX_E1_8822C 0x01F4
#define REG_HMEBOX_E2_8822C 0x01F8
#define REG_HMEBOX_E3_8822C 0x01FC
#define REG_CR_EXT_8822C 0x1100
#define REG_FWFF_8822C 0x1114
#define REG_RXFF_PTR_V1_8822C 0x1118
#define REG_RXFF_WTR_V1_8822C 0x111C
#define REG_FE2IMR_8822C 0x1120
#define REG_FE2ISR_8822C 0x1124
#define REG_FE3IMR_8822C 0x1128
#define REG_FE3ISR_8822C 0x112C
#define REG_FE4IMR_8822C 0x1130
#define REG_FE4ISR_8822C 0x1134
#define REG_FT1IMR_8822C 0x1138
#define REG_FT1ISR_8822C 0x113C
#define REG_SPWR0_8822C 0x1140
#define REG_SPWR1_8822C 0x1144
#define REG_SPWR2_8822C 0x1148
#define REG_SPWR3_8822C 0x114C
#define REG_POWSEQ_8822C 0x1150
#define REG_TC7_CTRL_V1_8822C 0x1158
#define REG_TC8_CTRL_V1_8822C 0x115C
#define REG_RX_BCN_TBTT_ITVL0_8822C 0x1160
#define REG_RX_BCN_TBTT_ITVL1_8822C 0x1164
#define REG_IO_WRAP_ERR_FLAG_8822C 0x1170
#define REG_SPEED_SENSOR_8822C 0x1180
#define REG_SPEED_SENSOR1_8822C 0x1184
#define REG_SPEED_SENSOR2_8822C 0x1188
#define REG_SPEED_SENSOR3_8822C 0x118C
#define REG_SPEED_SENSOR4_8822C 0x1190
#define REG_SPEED_SENSOR5_8822C 0x1194
#define REG_COUNTER_CTRL_8822C 0x11C4
#define REG_COUNTER_THRESHOLD_8822C 0x11C8
#define REG_COUNTER_SET_8822C 0x11CC
#define REG_COUNTER_OVERFLOW_8822C 0x11D0
#define REG_TXDMA_LEN_THRESHOLD_8822C 0x11D4
#define REG_RXDMA_LEN_THRESHOLD_8822C 0x11D8
#define REG_PCIE_EXEC_TIME_THRESHOLD_8822C 0x11DC
#define REG_FT2IMR_8822C 0x11E0
#define REG_FT2ISR_8822C 0x11E4
#define REG_MSG2_8822C 0x11F0
#define REG_MSG3_8822C 0x11F4
#define REG_MSG4_8822C 0x11F8
#define REG_MSG5_8822C 0x11FC
#define REG_FIFOPAGE_CTRL_1_8822C 0x0200
#define REG_FIFOPAGE_CTRL_2_8822C 0x0204
#define REG_AUTO_LLT_V1_8822C 0x0208
#define REG_TXDMA_OFFSET_CHK_8822C 0x020C
#define REG_TXDMA_STATUS_8822C 0x0210
#define REG_TX_DMA_DBG_8822C 0x0214
#define REG_TQPNT1_8822C 0x0218
#define REG_TQPNT2_8822C 0x021C
#define REG_TQPNT3_8822C 0x0220
#define REG_TQPNT4_8822C 0x0224
#define REG_RQPN_CTRL_1_8822C 0x0228
#define REG_RQPN_CTRL_2_8822C 0x022C
#define REG_FIFOPAGE_INFO_1_8822C 0x0230
#define REG_FIFOPAGE_INFO_2_8822C 0x0234
#define REG_FIFOPAGE_INFO_3_8822C 0x0238
#define REG_FIFOPAGE_INFO_4_8822C 0x023C
#define REG_FIFOPAGE_INFO_5_8822C 0x0240
#define REG_H2C_HEAD_8822C 0x0244
#define REG_H2C_TAIL_8822C 0x0248
#define REG_H2C_READ_ADDR_8822C 0x024C
#define REG_H2C_WR_ADDR_8822C 0x0250
#define REG_H2C_INFO_8822C 0x0254
#define REG_PGSUB_CNT_8822C 0x026C
#define REG_PGSUB_H_8822C 0x0270
#define REG_PGSUB_N_8822C 0x0274
#define REG_PGSUB_L_8822C 0x0278
#define REG_PGSUB_E_8822C 0x027C
#define REG_RXDMA_AGG_PG_TH_8822C 0x0280
#define REG_RXPKT_NUM_8822C 0x0284
#define REG_RXDMA_STATUS_8822C 0x0288
#define REG_RXDMA_DPR_8822C 0x028C
#define REG_RXDMA_MODE_8822C 0x0290
#define REG_C2H_PKT_8822C 0x0294
#define REG_FWFF_C2H_8822C 0x0298
#define REG_FWFF_CTRL_8822C 0x029C
#define REG_FWFF_PKT_INFO_8822C 0x02A0
#define REG_RXPKTNUM_8822C 0x02B0
#define REG_RXPKTNUM_TH_8822C 0x02B4
#define REG_FW_MSG1_8822C 0x02E0
#define REG_FW_MSG2_8822C 0x02E4
#define REG_FW_MSG3_8822C 0x02E8
#define REG_FW_MSG4_8822C 0x02EC
#define REG_DDMA_CH0SA_8822C 0x1200
#define REG_DDMA_CH0DA_8822C 0x1204
#define REG_DDMA_CH0CTRL_8822C 0x1208
#define REG_DDMA_CH1SA_8822C 0x1210
#define REG_DDMA_CH1DA_8822C 0x1214
#define REG_DDMA_CH1CTRL_8822C 0x1218
#define REG_DDMA_CH2SA_8822C 0x1220
#define REG_DDMA_CH2DA_8822C 0x1224
#define REG_DDMA_CH2CTRL_8822C 0x1228
#define REG_DDMA_CH3SA_8822C 0x1230
#define REG_DDMA_CH3DA_8822C 0x1234
#define REG_DDMA_CH3CTRL_8822C 0x1238
#define REG_DDMA_CH4SA_8822C 0x1240
#define REG_DDMA_CH4DA_8822C 0x1244
#define REG_DDMA_CH4CTRL_8822C 0x1248
#define REG_DDMA_CH5SA_8822C 0x1250
#define REG_DDMA_CH5DA_8822C 0x1254
#define REG_DDMA_CH5CTRL_8822C 0x1258
#define REG_DDMA_INT_MSK_8822C 0x12E0
#define REG_DDMA_CHSTATUS_8822C 0x12E8
#define REG_DDMA_CHKSUM_8822C 0x12F0
#define REG_DDMA_MONITOR_8822C 0x12FC
#define REG_PCIE_CTRL_8822C 0x0300
#define REG_INT_MIG_8822C 0x0304
#define REG_BCNQ_TXBD_DESA_8822C 0x0308
#define REG_MGQ_TXBD_DESA_8822C 0x0310
#define REG_VOQ_TXBD_DESA_8822C 0x0318
#define REG_VIQ_TXBD_DESA_8822C 0x0320
#define REG_BEQ_TXBD_DESA_8822C 0x0328
#define REG_BKQ_TXBD_DESA_8822C 0x0330
#define REG_RXQ_RXBD_DESA_8822C 0x0338
#define REG_HI0Q_TXBD_DESA_8822C 0x0340
#define REG_HI1Q_TXBD_DESA_8822C 0x0348
#define REG_HI2Q_TXBD_DESA_8822C 0x0350
#define REG_HI3Q_TXBD_DESA_8822C 0x0358
#define REG_HI4Q_TXBD_DESA_8822C 0x0360
#define REG_HI5Q_TXBD_DESA_8822C 0x0368
#define REG_HI6Q_TXBD_DESA_8822C 0x0370
#define REG_HI7Q_TXBD_DESA_8822C 0x0378
#define REG_MGQ_TXBD_NUM_8822C 0x0380
#define REG_RX_RXBD_NUM_8822C 0x0382
#define REG_VOQ_TXBD_NUM_8822C 0x0384
#define REG_VIQ_TXBD_NUM_8822C 0x0386
#define REG_BEQ_TXBD_NUM_8822C 0x0388
#define REG_BKQ_TXBD_NUM_8822C 0x038A
#define REG_HI0Q_TXBD_NUM_8822C 0x038C
#define REG_HI1Q_TXBD_NUM_8822C 0x038E
#define REG_HI2Q_TXBD_NUM_8822C 0x0390
#define REG_HI3Q_TXBD_NUM_8822C 0x0392
#define REG_HI4Q_TXBD_NUM_8822C 0x0394
#define REG_HI5Q_TXBD_NUM_8822C 0x0396
#define REG_HI6Q_TXBD_NUM_8822C 0x0398
#define REG_HI7Q_TXBD_NUM_8822C 0x039A
#define REG_TSFTIMER_HCI_8822C 0x039C
#define REG_BD_RWPTR_CLR_8822C 0x039C
#define REG_VOQ_TXBD_IDX_8822C 0x03A0
#define REG_VIQ_TXBD_IDX_8822C 0x03A4
#define REG_BEQ_TXBD_IDX_8822C 0x03A8
#define REG_BKQ_TXBD_IDX_8822C 0x03AC
#define REG_MGQ_TXBD_IDX_8822C 0x03B0
#define REG_RXQ_RXBD_IDX_8822C 0x03B4
#define REG_HI0Q_TXBD_IDX_8822C 0x03B8
#define REG_HI1Q_TXBD_IDX_8822C 0x03BC
#define REG_HI2Q_TXBD_IDX_8822C 0x03C0
#define REG_HI3Q_TXBD_IDX_8822C 0x03C4
#define REG_HI4Q_TXBD_IDX_8822C 0x03C8
#define REG_HI5Q_TXBD_IDX_8822C 0x03CC
#define REG_HI6Q_TXBD_IDX_8822C 0x03D0
#define REG_HI7Q_TXBD_IDX_8822C 0x03D4
#define REG_DBG_SEL_V1_8822C 0x03D8
#define REG_PCIE_HRPWM1_V1_8822C 0x03D9
#define REG_PCIE_HCPWM1_V1_8822C 0x03DA
#define REG_PCIE_CTRL2_8822C 0x03DB
#define REG_PCIE_HRPWM2_V1_8822C 0x03DC
#define REG_PCIE_HCPWM2_V1_8822C 0x03DE
#define REG_PCIE_H2C_MSG_V1_8822C 0x03E0
#define REG_PCIE_C2H_MSG_V1_8822C 0x03E4
#define REG_DBI_WDATA_V1_8822C 0x03E8
#define REG_DBI_RDATA_V1_8822C 0x03EC
#define REG_DBI_FLAG_V1_8822C 0x03F0
#define REG_MDIO_V1_8822C 0x03F4
#define REG_PCIE_MIX_CFG_8822C 0x03F8
#define REG_HCI_MIX_CFG_8822C 0x03FC
#define REG_STC_INT_CS_8822C 0x1300
#define REG_ST_INT_CFG_8822C 0x1304
#define REG_H2CQ_TXBD_DESA_8822C 0x1320
#define REG_H2CQ_TXBD_NUM_8822C 0x1328
#define REG_H2CQ_TXBD_IDX_8822C 0x132C
#define REG_H2CQ_CSR_8822C 0x1330
#define REG_CHANGE_PCIE_SPEED_8822C 0x1350
#define REG_DEBUG_STATE1_8822C 0x1354
#define REG_DEBUG_STATE2_8822C 0x1358
#define REG_DEBUG_STATE3_8822C 0x135C
#define REG_CHNL_DMA_CFG_V1_8822C 0x137C
#define REG_PCIE_HISR0_V1_8822C 0x13B4
#define REG_PCIE_HISR1_V1_8822C 0x13BC
#define REG_PCIE_HISR2_V1_8822C 0x23B4
#define REG_PCIE_HISR3_V1_8822C 0x23BC
#define REG_Q0_INFO_8822C 0x0400
#define REG_Q1_INFO_8822C 0x0404
#define REG_Q2_INFO_8822C 0x0408
#define REG_Q3_INFO_8822C 0x040C
#define REG_MGQ_INFO_8822C 0x0410
#define REG_HIQ_INFO_8822C 0x0414
#define REG_BCNQ_INFO_8822C 0x0418
#define REG_TXPKT_EMPTY_8822C 0x041A
#define REG_CPU_MGQ_INFO_8822C 0x041C
#define REG_FWHW_TXQ_CTRL_8822C 0x0420
#define REG_DATAFB_SEL_8822C 0x0423
#define REG_BCNQ_BDNY_V1_8822C 0x0424
#define REG_LIFETIME_EN_8822C 0x0426
#define REG_SPEC_SIFS_8822C 0x0428
#define REG_RETRY_LIMIT_8822C 0x042A
#define REG_TXBF_CTRL_8822C 0x042C
#define REG_DARFRC_8822C 0x0430
#define REG_DARFRCH_8822C 0x0434
#define REG_RARFRC_8822C 0x0438
#define REG_RARFRCH_8822C 0x043C
#define REG_RRSR_8822C 0x0440
#define REG_ARFR0_8822C 0x0444
#define REG_ARFRH0_8822C 0x0448
#define REG_ARFR1_V1_8822C 0x044C
#define REG_ARFRH1_V1_8822C 0x0450
#define REG_CCK_CHECK_8822C 0x0454
#define REG_AMPDU_MAX_TIME_V1_8822C 0x0455
#define REG_BCNQ1_BDNY_V1_8822C 0x0456
#define REG_AMPDU_MAX_LENGTH_HT_8822C 0x0458
#define REG_ACQ_STOP_8822C 0x045C
#define REG_NDPA_RATE_8822C 0x045D
#define REG_TX_HANG_CTRL_8822C 0x045E
#define REG_NDPA_OPT_CTRL_8822C 0x045F
#define REG_AMPDU_MAX_LENGTH_VHT_8822C 0x0460
#define REG_RD_RESP_PKT_TH_8822C 0x0463
#define REG_CMDQ_INFO_8822C 0x0464
#define REG_Q4_INFO_8822C 0x0468
#define REG_Q5_INFO_8822C 0x046C
#define REG_Q6_INFO_8822C 0x0470
#define REG_Q7_INFO_8822C 0x0474
#define REG_WMAC_LBK_BUF_HD_V1_8822C 0x0478
#define REG_MGQ_BDNY_V1_8822C 0x047A
#define REG_TXRPT_CTRL_8822C 0x047C
#define REG_INIRTS_RATE_SEL_8822C 0x0480
#define REG_BASIC_CFEND_RATE_8822C 0x0481
#define REG_STBC_CFEND_RATE_8822C 0x0482
#define REG_DATA_SC_8822C 0x0483
#define REG_MACID_SLEEP3_8822C 0x0484
#define REG_MACID_SLEEP1_8822C 0x0488
#define REG_ARFR2_V1_8822C 0x048C
#define REG_ARFRH2_V1_8822C 0x0490
#define REG_ARFR3_V1_8822C 0x0494
#define REG_ARFRH3_V1_8822C 0x0498
#define REG_ARFR4_8822C 0x049C
#define REG_ARFRH4_8822C 0x04A0
#define REG_ARFR5_8822C 0x04A4
#define REG_ARFRH5_8822C 0x04A8
#define REG_TXRPT_START_OFFSET_8822C 0x04AC
#define REG_POWER_STAGE1_8822C 0x04B4
#define REG_POWER_STAGE2_8822C 0x04B8
#define REG_SW_AMPDU_BURST_MODE_CTRL_8822C 0x04BC
#define REG_PKT_LIFE_TIME_8822C 0x04C0
#define REG_STBC_SETTING_8822C 0x04C4
#define REG_STBC_SETTING2_8822C 0x04C5
#define REG_QUEUE_CTRL_8822C 0x04C6
#define REG_SINGLE_AMPDU_CTRL_8822C 0x04C7
#define REG_PROT_MODE_CTRL_8822C 0x04C8
#define REG_BAR_MODE_CTRL_8822C 0x04CC
#define REG_RA_TRY_RATE_AGG_LMT_8822C 0x04CF
#define REG_MACID_SLEEP2_8822C 0x04D0
#define REG_MACID_SLEEP_8822C 0x04D4
#define REG_HW_SEQ0_8822C 0x04D8
#define REG_HW_SEQ1_8822C 0x04DA
#define REG_HW_SEQ2_8822C 0x04DC
#define REG_HW_SEQ3_8822C 0x04DE
#define REG_NULL_PKT_STATUS_V1_8822C 0x04E0
#define REG_PTCL_ERR_STATUS_8822C 0x04E2
#define REG_NULL_PKT_STATUS_EXTEND_8822C 0x04E3
#define REG_HQMGQ_DROP_8822C 0x04E4
#define REG_PRECNT_CTRL_8822C 0x04E5
#define REG_BT_POLLUTE_PKT_CNT_8822C 0x04E8
#define REG_PTCL_DBG_8822C 0x04EC
#define REG_CPUMGQ_TIMER_CTRL2_8822C 0x04F4
#define REG_DUMMY_PAGE4_V1_8822C 0x04FC
#define REG_MOREDATA_8822C 0x04FE
#define REG_Q0_Q1_INFO_8822C 0x1400
#define REG_Q2_Q3_INFO_8822C 0x1404
#define REG_Q4_Q5_INFO_8822C 0x1408
#define REG_Q6_Q7_INFO_8822C 0x140C
#define REG_MGQ_HIQ_INFO_8822C 0x1410
#define REG_CMDQ_BCNQ_INFO_8822C 0x1414
#define REG_LOOPBACK_OPTION_8822C 0x1420
#define REG_AESIV_SETTING_8822C 0x1424
#define REG_BF0_TIME_SETTING_8822C 0x1428
#define REG_BF1_TIME_SETTING_8822C 0x142C
#define REG_BF_TIMEOUT_EN_8822C 0x1430
#define REG_MACID_RELEASE0_8822C 0x1434
#define REG_MACID_RELEASE1_8822C 0x1438
#define REG_MACID_RELEASE2_8822C 0x143C
#define REG_MACID_RELEASE3_8822C 0x1440
#define REG_MACID_RELEASE_SETTING_8822C 0x1444
#define REG_FAST_EDCA_VOVI_SETTING_8822C 0x1448
#define REG_FAST_EDCA_BEBK_SETTING_8822C 0x144C
#define REG_MACID_DROP0_8822C 0x1450
#define REG_MACID_DROP1_8822C 0x1454
#define REG_MACID_DROP2_8822C 0x1458
#define REG_MACID_DROP3_8822C 0x145C
#define REG_R_MACID_RELEASE_SUCCESS_0_8822C 0x1460
#define REG_R_MACID_RELEASE_SUCCESS_1_8822C 0x1464
#define REG_R_MACID_RELEASE_SUCCESS_2_8822C 0x1468
#define REG_R_MACID_RELEASE_SUCCESS_3_8822C 0x146C
#define REG_MGQ_FIFO_WRITE_POINTER_8822C 0x1470
#define REG_MGQ_FIFO_READ_POINTER_8822C 0x1472
#define REG_MGQ_FIFO_ENABLE_8822C 0x1472
#define REG_MGQ_FIFO_RELEASE_INT_MASK_8822C 0x1474
#define REG_MGQ_FIFO_RELEASE_INT_FLAG_8822C 0x1476
#define REG_MGQ_FIFO_VALID_MAP_8822C 0x1478
#define REG_MGQ_FIFO_LIFETIME_8822C 0x147A
#define REG_R_MACID_RELEASE_SUCCESS_CLEAR_OFFSET_8822C 0x147C
#define REG_SHCUT_SETTING_8822C 0x1480
#define REG_SHCUT_LLC_ETH_TYPE0_8822C 0x1484
#define REG_SHCUT_LLC_ETH_TYPE1_8822C 0x1488
#define REG_SHCUT_LLC_OUI0_8822C 0x148C
#define REG_SHCUT_LLC_OUI1_8822C 0x1490
#define REG_SHCUT_LLC_OUI2_8822C 0x1494
#define REG_MU_TX_CTL_8822C 0x14C0
#define REG_MU_STA_GID_VLD_8822C 0x14C4
#define REG_MU_STA_USER_POS_INFO_8822C 0x14C8
#define REG_MU_STA_USER_POS_INFO_H_8822C 0x14CC
#define REG_CHNL_INFO_CTRL_8822C 0x14D0
#define REG_CHNL_IDLE_TIME_8822C 0x14D4
#define REG_CHNL_BUSY_TIME_8822C 0x14D8
#define REG_MU_TRX_DBG_CNT_V1_8822C 0x14DC
#define REG_EDCA_VO_PARAM_8822C 0x0500
#define REG_EDCA_VI_PARAM_8822C 0x0504
#define REG_EDCA_BE_PARAM_8822C 0x0508
#define REG_EDCA_BK_PARAM_8822C 0x050C
#define REG_BCNTCFG_8822C 0x0510
#define REG_PIFS_8822C 0x0512
#define REG_RDG_PIFS_8822C 0x0513
#define REG_SIFS_8822C 0x0514
#define REG_TSFTR_SYN_OFFSET_8822C 0x0518
#define REG_AGGR_BREAK_TIME_8822C 0x051A
#define REG_SLOT_8822C 0x051B
#define REG_NOA_ON_ERLY_TIME_8822C 0x051C
#define REG_NOA_OFF_ERLY_TIME_8822C 0x051D
#define REG_TX_PTCL_CTRL_8822C 0x0520
#define REG_TXPAUSE_8822C 0x0522
#define REG_DIS_TXREQ_CLR_8822C 0x0523
#define REG_RD_CTRL_8822C 0x0524
#define REG_MBSSID_CTRL_8822C 0x0526
#define REG_P2PPS_CTRL_8822C 0x0527
#define REG_PKT_LIFETIME_CTRL_8822C 0x0528
#define REG_P2PPS_SPEC_STATE_8822C 0x052B
#define REG_TXOP_LIMIT_CTRL_8822C 0x052C
#define REG_BAR_TX_CTRL_8822C 0x0530
#define REG_P2PON_DIS_TXTIME_8822C 0x0531
#define REG_CCA_TXEN_CNT_8822C 0x0534
#define REG_MAX_INTER_COLLISION_8822C 0x0538
#define REG_MAX_INTER_COLLISION_CNT_8822C 0x053C
#define REG_TBTT_PROHIBIT_8822C 0x0540
#define REG_P2PPS_STATE_8822C 0x0543
#define REG_RD_NAV_NXT_8822C 0x0544
#define REG_NAV_PROT_LEN_8822C 0x0546
#define REG_FTM_PTT_8822C 0x0548
#define REG_FTM_TSF_8822C 0x054C
#define REG_BCN_CTRL_8822C 0x0550
#define REG_BCN_CTRL_CLINT0_8822C 0x0551
#define REG_MBID_NUM_8822C 0x0552
#define REG_DUAL_TSF_RST_8822C 0x0553
#define REG_MBSSID_BCN_SPACE_8822C 0x0554
#define REG_DRVERLYINT_8822C 0x0558
#define REG_BCNDMATIM_8822C 0x0559
#define REG_ATIMWND_8822C 0x055A
#define REG_USTIME_TSF_8822C 0x055C
#define REG_BCN_MAX_ERR_8822C 0x055D
#define REG_RXTSF_OFFSET_CCK_8822C 0x055E
#define REG_RXTSF_OFFSET_OFDM_8822C 0x055F
#define REG_TSFTR_8822C 0x0560
#define REG_TSFTR_1_8822C 0x0564
#define REG_FREERUN_CNT_8822C 0x0568
#define REG_FREERUN_CNT_1_8822C 0x056C
#define REG_ATIMWND1_V1_8822C 0x0570
#define REG_TBTT_PROHIBIT_INFRA_8822C 0x0571
#define REG_CTWND_8822C 0x0572
#define REG_BCNIVLCUNT_8822C 0x0573
#define REG_BCNDROPCTRL_8822C 0x0574
#define REG_HGQ_TIMEOUT_PERIOD_8822C 0x0575
#define REG_TXCMD_TIMEOUT_PERIOD_8822C 0x0576
#define REG_MISC_CTRL_8822C 0x0577
#define REG_BCN_CTRL_CLINT1_8822C 0x0578
#define REG_BCN_CTRL_CLINT2_8822C 0x0579
#define REG_BCN_CTRL_CLINT3_8822C 0x057A
#define REG_EXTEND_CTRL_8822C 0x057B
#define REG_P2PPS1_SPEC_STATE_8822C 0x057C
#define REG_P2PPS1_STATE_8822C 0x057D
#define REG_P2PPS2_SPEC_STATE_8822C 0x057E
#define REG_P2PPS2_STATE_8822C 0x057F
#define REG_PS_TIMER0_8822C 0x0580
#define REG_PS_TIMER1_8822C 0x0584
#define REG_PS_TIMER2_8822C 0x0588
#define REG_TBTT_CTN_AREA_8822C 0x058C
#define REG_FORCE_BCN_IFS_8822C 0x058E
#define REG_TXOP_MIN_8822C 0x0590
#define REG_PRE_BKF_TIME_8822C 0x0592
#define REG_CROSS_TXOP_CTRL_8822C 0x0593
#define REG_RX_TBTT_SHIFT_V1_8822C 0x0598
#define REG_ATIMWND2_8822C 0x05A0
#define REG_ATIMWND3_8822C 0x05A1
#define REG_ATIMWND4_8822C 0x05A2
#define REG_ATIMWND5_8822C 0x05A3
#define REG_ATIMWND6_8822C 0x05A4
#define REG_ATIMWND7_8822C 0x05A5
#define REG_ATIMUGT_8822C 0x05A6
#define REG_HIQ_NO_LMT_EN_8822C 0x05A7
#define REG_DTIM_COUNTER_ROOT_8822C 0x05A8
#define REG_DTIM_COUNTER_VAP1_8822C 0x05A9
#define REG_DTIM_COUNTER_VAP2_8822C 0x05AA
#define REG_DTIM_COUNTER_VAP3_8822C 0x05AB
#define REG_DTIM_COUNTER_VAP4_8822C 0x05AC
#define REG_DTIM_COUNTER_VAP5_8822C 0x05AD
#define REG_DTIM_COUNTER_VAP6_8822C 0x05AE
#define REG_DTIM_COUNTER_VAP7_8822C 0x05AF
#define REG_DIS_ATIM_8822C 0x05B0
#define REG_EARLY_128US_8822C 0x05B1
#define REG_P2PPS1_CTRL_8822C 0x05B2
#define REG_P2PPS2_CTRL_8822C 0x05B3
#define REG_TIMER0_SRC_SEL_8822C 0x05B4
#define REG_NOA_UNIT_SEL_8822C 0x05B5
#define REG_P2POFF_DIS_TXTIME_8822C 0x05B7
#define REG_MBSSID_BCN_SPACE2_8822C 0x05B8
#define REG_MBSSID_BCN_SPACE3_8822C 0x05BC
#define REG_ACMHWCTRL_8822C 0x05C0
#define REG_ACMRSTCTRL_8822C 0x05C1
#define REG_ACMAVG_8822C 0x05C2
#define REG_VO_ADMTIME_8822C 0x05C4
#define REG_VI_ADMTIME_8822C 0x05C6
#define REG_BE_ADMTIME_8822C 0x05C8
#define REG_MAC_HEADER_NAV_OFFSET_8822C 0x05CA
#define REG_DIS_NDPA_NAV_CHECK_8822C 0x05CB
#define REG_EDCA_RANDOM_GEN_8822C 0x05CC
#define REG_TXCMD_NOA_SEL_8822C 0x05CF
#define REG_32K_CLK_SEL_8822C 0x05D0
#define REG_EARLYINT_ADJUST_8822C 0x05D4
#define REG_BCNERR_CNT_8822C 0x05D8
#define REG_BCNERR_CNT_2_8822C 0x05DC
#define REG_NOA_PARAM_8822C 0x05E0
#define REG_NOA_PARAM_1_8822C 0x05E4
#define REG_NOA_PARAM_2_8822C 0x05E8
#define REG_NOA_PARAM_3_8822C 0x05EC
#define REG_P2P_RST_8822C 0x05F0
#define REG_SCHEDULER_RST_8822C 0x05F1
#define REG_SCH_DBG_VALUE_8822C 0x05F4
#define REG_SCH_TXCMD_8822C 0x05F8
#define REG_PAGE5_DUMMY_8822C 0x05FC
#define REG_CPUMGQ_TX_TIMER_8822C 0x1500
#define REG_PS_TIMER_A_8822C 0x1504
#define REG_PS_TIMER_B_8822C 0x1508
#define REG_PS_TIMER_C_8822C 0x150C
#define REG_PS_TIMER_ABC_CPUMGQ_TIMER_CRTL_8822C 0x1510
#define REG_CPUMGQ_TX_TIMER_EARLY_8822C 0x1514
#define REG_PS_TIMER_A_EARLY_8822C 0x1515
#define REG_PS_TIMER_B_EARLY_8822C 0x1516
#define REG_PS_TIMER_C_EARLY_8822C 0x1517
#define REG_CPUMGQ_PARAMETER_8822C 0x1518
#define REG_TSF_SYNC_ADJ_8822C 0x1520
#define REG_TSF_ADJ_VLAUE_8822C 0x1524
#define REG_TSF_ADJ_VLAUE_2_8822C 0x1528
#define REG_P2PPS_HW_AUTO_PAUSE_CTRL_8822C 0x156C
#define REG_P2PPS1_HW_AUTO_PAUSE_CTRL_8822C 0x1570
#define REG_P2PPS2_HW_AUTO_PAUSE_CTRL_8822C 0x1574
#define REG_SCHEDULER_COUNTER_8822C 0x15D0
#define REG_WMAC_CR_8822C 0x0600
#define REG_WMAC_FWPKT_CR_8822C 0x0601
#define REG_FW_STS_FILTER_8822C 0x0602
#define REG_TCR_8822C 0x0604
#define REG_RCR_8822C 0x0608
#define REG_RX_PKT_LIMIT_8822C 0x060C
#define REG_RX_DLK_TIME_8822C 0x060D
#define REG_RX_DRVINFO_SZ_8822C 0x060F
#define REG_MACID_8822C 0x0610
#define REG_MACID_H_8822C 0x0614
#define REG_BSSID_8822C 0x0618
#define REG_BSSID_H_8822C 0x061C
#define REG_MAR_8822C 0x0620
#define REG_MAR_H_8822C 0x0624
#define REG_MBIDCAMCFG_1_8822C 0x0628
#define REG_MBIDCAMCFG_2_8822C 0x062C
#define REG_WMAC_TCR_TSFT_OFS_8822C 0x0630
#define REG_UDF_THSD_8822C 0x0632
#define REG_ZLD_NUM_8822C 0x0633
#define REG_STMP_THSD_8822C 0x0634
#define REG_WMAC_TXTIMEOUT_8822C 0x0635
#define REG_USTIME_EDCA_8822C 0x0638
#define REG_ACKTO_CCK_8822C 0x0639
#define REG_MAC_SPEC_SIFS_8822C 0x063A
#define REG_RESP_SIFS_CCK_8822C 0x063C
#define REG_RESP_SIFS_OFDM_8822C 0x063E
#define REG_ACKTO_8822C 0x0640
#define REG_CTS2TO_8822C 0x0641
#define REG_EIFS_8822C 0x0642
#define REG_RPFM_MAP0_8822C 0x0644
#define REG_RPFM_MAP1_V1_8822C 0x0646
#define REG_RPFM_CAM_CMD_8822C 0x0648
#define REG_RPFM_CAM_RWD_8822C 0x064C
#define REG_NAV_CTRL_8822C 0x0650
#define REG_BACAMCMD_8822C 0x0654
#define REG_BACAMCONTENT_8822C 0x0658
#define REG_BACAMCONTENT_H_8822C 0x065C
#define REG_LBDLY_8822C 0x0660
#define REG_WMAC_BACAM_RPMEN_8822C 0x0661
#define REG_TX_RX_8822C 0x0662
#define REG_WMAC_BITMAP_CTL_8822C 0x0663
#define REG_RXERR_RPT_8822C 0x0664
#define REG_WMAC_TRXPTCL_CTL_8822C 0x0668
#define REG_WMAC_TRXPTCL_CTL_H_8822C 0x066C
#define REG_CAMCMD_8822C 0x0670
#define REG_CAMWRITE_8822C 0x0674
#define REG_CAMREAD_8822C 0x0678
#define REG_CAMDBG_8822C 0x067C
#define REG_SECCFG_8822C 0x0680
#define REG_RXFILTER_CATEGORY_1_8822C 0x0682
#define REG_RXFILTER_ACTION_1_8822C 0x0683
#define REG_RXFILTER_CATEGORY_2_8822C 0x0684
#define REG_RXFILTER_ACTION_2_8822C 0x0685
#define REG_RXFILTER_CATEGORY_3_8822C 0x0686
#define REG_RXFILTER_ACTION_3_8822C 0x0687
#define REG_RXFLTMAP3_8822C 0x0688
#define REG_RXFLTMAP4_8822C 0x068A
#define REG_RXFLTMAP5_8822C 0x068C
#define REG_RXFLTMAP6_8822C 0x068E
#define REG_WOW_CTRL_8822C 0x0690
#define REG_NAN_RX_TSF_FILTER_8822C 0x0691
#define REG_PS_RX_INFO_8822C 0x0692
#define REG_WMMPS_UAPSD_TID_8822C 0x0693
#define REG_LPNAV_CTRL_8822C 0x0694
#define REG_WKFMCAM_CMD_8822C 0x0698
#define REG_WKFMCAM_RWD_8822C 0x069C
#define REG_RXFLTMAP0_8822C 0x06A0
#define REG_RXFLTMAP1_8822C 0x06A2
#define REG_RXFLTMAP2_8822C 0x06A4
#define REG_BCN_PSR_RPT_8822C 0x06A8
#define REG_FLC_RPC_8822C 0x06AC
#define REG_FLC_RPCT_8822C 0x06AD
#define REG_FLC_PTS_8822C 0x06AE
#define REG_FLC_TRPC_8822C 0x06AF
#define REG_RXPKTMON_CTRL_8822C 0x06B0
#define REG_STATE_MON_8822C 0x06B4
#define REG_ERROR_MON_8822C 0x06B8
#define REG_SEARCH_MACID_8822C 0x06BC
#define REG_BT_COEX_TABLE_8822C 0x06C0
#define REG_BT_COEX_TABLE2_8822C 0x06C4
#define REG_BT_COEX_BREAK_TABLE_8822C 0x06C8
#define REG_BT_COEX_TABLE_H_8822C 0x06CC
#define REG_RXCMD_0_8822C 0x06D0
#define REG_RXCMD_1_8822C 0x06D4
#define REG_WMAC_RESP_TXINFO_8822C 0x06D8
#define REG_BBPSF_CTRL_8822C 0x06DC
#define REG_P2P_RX_BCN_NOA_8822C 0x06E0
#define REG_ASSOCIATED_BFMER0_INFO_8822C 0x06E4
#define REG_ASSOCIATED_BFMER0_INFO_H_8822C 0x06E8
#define REG_ASSOCIATED_BFMER1_INFO_8822C 0x06EC
#define REG_ASSOCIATED_BFMER1_INFO_H_8822C 0x06F0
#define REG_TX_CSI_RPT_PARAM_BW20_8822C 0x06F4
#define REG_TX_CSI_RPT_PARAM_BW40_8822C 0x06F8
#define REG_CSI_PTR_8822C 0x06FC
#define REG_BCN_PSR_RPT2_8822C 0x1600
#define REG_BCN_PSR_RPT3_8822C 0x1604
#define REG_BCN_PSR_RPT4_8822C 0x1608
#define REG_A1_ADDR_MASK_8822C 0x160C
#define REG_RXPSF_CTRL_8822C 0x1610
#define REG_RXPSF_TYPE_CTRL_8822C 0x1614
#define REG_CAM_ACCESS_CTRL_8822C 0x1618
#define REG_HT_SND_REF_RATE_8822C 0x161C
#define REG_MACID2_8822C 0x1620
#define REG_MACID2_H_8822C 0x1624
#define REG_BSSID2_8822C 0x1628
#define REG_BSSID2_H_8822C 0x162C
#define REG_MACID3_8822C 0x1630
#define REG_MACID3_H_8822C 0x1634
#define REG_BSSID3_8822C 0x1638
#define REG_BSSID3_H_8822C 0x163C
#define REG_MACID4_8822C 0x1640
#define REG_MACID4_H_8822C 0x1644
#define REG_BSSID4_8822C 0x1648
#define REG_BSSID4_H_8822C 0x164C
#define REG_NOA_REPORT_8822C 0x1650
#define REG_NOA_REPORT_1_8822C 0x1654
#define REG_NOA_REPORT_2_8822C 0x1658
#define REG_NOA_REPORT_3_8822C 0x165C
#define REG_PWRBIT_SETTING_8822C 0x1660
#define REG_GENERAL_OPTION_8822C 0x1664
#define REG_CSI_RRSR_8822C 0x1678
#define REG_MU_BF_OPTION_8822C 0x167C
#define REG_WMAC_PAUSE_BB_CLR_TH_8822C 0x167D
#define REG__WMAC_MULBK_BUF_8822C 0x167E
#define REG_WMAC_MU_OPTION_8822C 0x167F
#define REG_WMAC_MU_BF_CTL_8822C 0x1680
#define REG_WMAC_MU_BFRPT_PARA_8822C 0x1682
#define REG_WMAC_ASSOCIATED_MU_BFMEE2_8822C 0x1684
#define REG_WMAC_ASSOCIATED_MU_BFMEE3_8822C 0x1686
#define REG_WMAC_ASSOCIATED_MU_BFMEE4_8822C 0x1688
#define REG_WMAC_ASSOCIATED_MU_BFMEE5_8822C 0x168A
#define REG_WMAC_ASSOCIATED_MU_BFMEE6_8822C 0x168C
#define REG_WMAC_ASSOCIATED_MU_BFMEE7_8822C 0x168E
#define REG_WMAC_BB_STOP_RX_COUNTER_8822C 0x1690
#define REG_WMAC_PLCP_MONITOR_8822C 0x1694
#define REG_WMAC_PLCP_MONITOR_MUTX_8822C 0x1698
#define REG_WMAC_CSIDMA_CFG_8822C 0x169C
#define REG_TRANSMIT_ADDRSS_0_8822C 0x16A0
#define REG_TRANSMIT_ADDRSS_0_H_8822C 0x16A4
#define REG_TRANSMIT_ADDRSS_1_8822C 0x16A8
#define REG_TRANSMIT_ADDRSS_1_H_8822C 0x16AC
#define REG_TRANSMIT_ADDRSS_2_8822C 0x16B0
#define REG_TRANSMIT_ADDRSS_2_H_8822C 0x16B4
#define REG_TRANSMIT_ADDRSS_3_8822C 0x16B8
#define REG_TRANSMIT_ADDRSS_3_H_8822C 0x16BC
#define REG_TRANSMIT_ADDRSS_4_8822C 0x16C0
#define REG_TRANSMIT_ADDRSS_4_H_8822C 0x16C4
#define REG_MACID1_8822C 0x0700
#define REG_MACID1_1_8822C 0x0704
#define REG_BSSID1_8822C 0x0708
#define REG_BSSID1_1_8822C 0x070C
#define REG_BCN_PSR_RPT1_8822C 0x0710
#define REG_ASSOCIATED_BFMEE_SEL_8822C 0x0714
#define REG_SND_PTCL_CTRL_8822C 0x0718
#define REG_RX_CSI_RPT_INFO_8822C 0x071C
#define REG_NS_ARP_CTRL_8822C 0x0720
#define REG_NS_ARP_INFO_8822C 0x0724
#define REG_BEAMFORMING_INFO_NSARP_V1_8822C 0x0728
#define REG_BEAMFORMING_INFO_NSARP_8822C 0x072C
#define REG_IPV6_8822C 0x0730
#define REG_IPV6_1_8822C 0x0734
#define REG_IPV6_2_8822C 0x0738
#define REG_IPV6_3_8822C 0x073C
#define REG_WMAC_RTX_CTX_SUBTYPE_CFG_8822C 0x0750
#define REG_WMAC_SWAES_DIO_B63_B32_8822C 0x0754
#define REG_WMAC_SWAES_DIO_B95_B64_8822C 0x0758
#define REG_WMAC_SWAES_DIO_B127_B96_8822C 0x075C
#define REG_WMAC_SWAES_CFG_8822C 0x0760
#define REG_BT_COEX_V2_8822C 0x0762
#define REG_BT_COEX_8822C 0x0764
#define REG_WLAN_ACT_MASK_CTRL_8822C 0x0768
#define REG_WLAN_ACT_MASK_CTRL_1_8822C 0x076C
#define REG_BT_COEX_ENHANCED_INTR_CTRL_8822C 0x076E
#define REG_BT_ACT_STATISTICS_8822C 0x0770
#define REG_BT_ACT_STATISTICS_1_8822C 0x0774
#define REG_BT_STATISTICS_CONTROL_REGISTER_8822C 0x0778
#define REG_BT_STATUS_REPORT_REGISTER_8822C 0x077C
#define REG_BT_INTERRUPT_CONTROL_REGISTER_8822C 0x0780
#define REG_WLAN_REPORT_TIME_OUT_CONTROL_REGISTER_8822C 0x0784
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_8822C 0x0785
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_1_8822C 0x0788
#define REG_BT_ISOLATION_TABLE_REGISTER_REGISTER_2_8822C 0x078C
#define REG_BT_INTERRUPT_STATUS_REGISTER_8822C 0x078F
#define REG_BT_TDMA_TIME_REGISTER_8822C 0x0790
#define REG_BT_ACT_REGISTER_8822C 0x0794
#define REG_OBFF_CTRL_BASIC_8822C 0x0798
#define REG_OBFF_CTRL2_TIMER_8822C 0x079C
#define REG_LTR_CTRL_BASIC_8822C 0x07A0
#define REG_LTR_CTRL2_TIMER_THRESHOLD_8822C 0x07A4
#define REG_LTR_IDLE_LATENCY_V1_8822C 0x07A8
#define REG_LTR_ACTIVE_LATENCY_V1_8822C 0x07AC
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_8822C 0x07B0
#define REG_ANTENNA_TRAINING_CONTROL_REGISTER_1_8822C 0x07B4
#define REG_WMAC_PKTCNT_RWD_8822C 0x07B8
#define REG_WMAC_PKTCNT_CTRL_8822C 0x07BC
#define REG_IQ_DUMP_8822C 0x07C0
#define REG_IQ_DUMP_1_8822C 0x07C4
#define REG_IQ_DUMP_2_8822C 0x07C8
#define REG_WMAC_FTM_CTL_8822C 0x07CC
#define REG_WMAC_IQ_MDPK_FUNC_8822C 0x07CE
#define REG_WMAC_OPTION_FUNCTION_8822C 0x07D0
#define REG_WMAC_OPTION_FUNCTION_1_8822C 0x07D4
#define REG_WMAC_OPTION_FUNCTION_2_8822C 0x07D8
#define REG_RX_FILTER_FUNCTION_8822C 0x07DA
#define REG_NDP_SIG_8822C 0x07E0
#define REG_TXCMD_INFO_FOR_RSP_PKT_8822C 0x07E4
#define REG_TXCMD_INFO_FOR_RSP_PKT_1_8822C 0x07E8
#define REG_WSEC_OPTION_8822C 0x07EC
#define REG_RTS_ADDRESS_0_8822C 0x07F0
#define REG_RTS_ADDRESS_0_1_8822C 0x07F4
#define REG_RTS_ADDRESS_1_8822C 0x07F8
#define REG_RTS_ADDRESS_1_1_8822C 0x07FC
#define REG_WL2LTECOEX_INDIRECT_ACCESS_CTRL_V1_8822C 0x1700
#define REG_WL2LTECOEX_INDIRECT_ACCESS_WRITE_DATA_V1_8822C 0x1704
#define REG_WL2LTECOEX_INDIRECT_ACCESS_READ_DATA_V1_8822C 0x1708
#define REG_SDIO_TX_CTRL_8822C 0x10250000
#define REG_SDIO_CMD11_VOL_SWITCH_8822C 0x10250004
#define REG_SDIO_CTRL_8822C 0x10250005
#define REG_SDIO_DRIVING_8822C 0x10250006
#define REG_SDIO_MONITOR_8822C 0x10250008
#define REG_SDIO_MONITOR_2_8822C 0x1025000C
#define REG_SDIO_HIMR_8822C 0x10250014
#define REG_SDIO_HISR_8822C 0x10250018
#define REG_SDIO_RX_REQ_LEN_8822C 0x1025001C
#define REG_SDIO_FREE_TXPG_SEQ_V1_8822C 0x1025001F
#define REG_SDIO_FREE_TXPG_8822C 0x10250020
#define REG_SDIO_FREE_TXPG2_8822C 0x10250024
#define REG_SDIO_OQT_FREE_TXPG_V1_8822C 0x10250028
#define REG_SDIO_TXPKT_EMPTY_8822C 0x1025002C
#define REG_SDIO_HTSFR_INFO_8822C 0x10250030
#define REG_SDIO_HCPWM1_V2_8822C 0x10250038
#define REG_SDIO_HCPWM2_V2_8822C 0x1025003A
#define REG_SDIO_INDIRECT_REG_CFG_8822C 0x10250040
#define REG_SDIO_INDIRECT_REG_DATA_8822C 0x10250044
#define REG_SDIO_H2C_8822C 0x10250060
#define REG_SDIO_C2H_8822C 0x10250064
#define REG_SDIO_HRPWM1_8822C 0x10250080
#define REG_SDIO_HRPWM2_8822C 0x10250082
#define REG_SDIO_HPS_CLKR_8822C 0x10250084
#define REG_SDIO_BUS_CTRL_8822C 0x10250085
#define REG_SDIO_HSUS_CTRL_8822C 0x10250086
#define REG_SDIO_RESPONSE_TIMER_8822C 0x10250088
#define REG_SDIO_CMD_CRC_8822C 0x1025008A
#define REG_SDIO_HSISR_8822C 0x10250090
#define REG_SDIO_HSIMR_8822C 0x10250091
#define REG_SDIO_DIOERR_RPT_8822C 0x102500C0
#define REG_SDIO_CMD_ERRCNT_8822C 0x102500C2
#define REG_SDIO_DATA_ERRCNT_8822C 0x102500C3
#define REG_SDIO_CMD_ERR_CONTENT_8822C 0x102500C4
#define REG_SDIO_CRC_ERR_IDX_8822C 0x102500C9
#define REG_SDIO_DATA_CRC_8822C 0x102500CA
#define REG_SDIO_TRANS_FIFO_STATUS_8822C 0x102500CC
#endif
================================================
FILE: hal/halmac/halmac_rx_bd_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_RX_BD_NIC_H_
#define _HALMAC_RX_BD_NIC_H_
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT ||\
HALMAC_8812F_SUPPORT)
/*TXBD_DW0*/
#define GET_RX_BD_RXFAIL(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 31, 1)
#define GET_RX_BD_TOTALRXPKTSIZE(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 16, 13)
#define GET_RX_BD_RXTAG(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 16, 13)
#define GET_RX_BD_FS(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 15, 1)
#define GET_RX_BD_LS(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 14, 1)
#define GET_RX_BD_RXBUFFSIZE(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x00, 0, 14)
/*TXBD_DW1*/
#define GET_RX_BD_PHYSICAL_ADDR_LOW(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x04, 0, 32)
/*TXBD_DW2*/
#define GET_RX_BD_PHYSICAL_ADDR_HIGH(rxbd) LE_BITS_TO_4BYTE(rxbd + 0x08, 0, 32)
#endif
#endif
================================================
FILE: hal/halmac/halmac_rx_desc_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_RX_DESC_AP_H_
#define _HALMAC_RX_DESC_AP_H_
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PHYPKTIDC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
28)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_EVT_PKT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_SWDEC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
27)
#define GET_RX_DESC_PHYST(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
26)
#define GET_RX_DESC_SHIFT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x3, \
24)
#define GET_RX_DESC_QOS(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
23)
#define GET_RX_DESC_SECURITY(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x7, \
20)
#define GET_RX_DESC_DRV_INFO_SIZE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0xf, \
16)
#define GET_RX_DESC_ICV_ERR(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
15)
#define GET_RX_DESC_CRC32(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, 0x1, \
14)
#define GET_RX_DESC_PKT_LEN(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword0, \
0x3fff, 0)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
31)
#define GET_RX_DESC_MC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_TY_PE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x3, \
28)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_TYPE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x3, \
28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MF(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
27)
#define GET_RX_DESC_MD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
26)
#define GET_RX_DESC_PWR(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PAM(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
24)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_A1_MATCH(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_CHK_VLD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
23)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_TCP_CHKSUM_VLD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_IS_TCP_UDP(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
22)
#define GET_RX_DESC_RX_IPV(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_CHKERR(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
20)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_TCP_CHKSUM_ERR(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
20)
#define GET_RX_DESC_PHY_PKT_IDC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
17)
#define GET_RX_DESC_FW_FIFO_FULL(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PAGGR(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
15)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_AMPDU(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RXID_MATCH(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
14)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_RXCMD_IDC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_AMSDU(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MACID_VLD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x1, \
12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_TID(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0xf, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MACID(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword1, 0x7f, \
0)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
31)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_AMSDU_CUT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
31)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PPDU_CNT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x3, \
29)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_C2H(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
28)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_HWRSVD_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x7, \
25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_HWRSVD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0xf, \
24)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_RXMAGPKT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_WLANHD_IV_LEN(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x3f, \
18)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_LAST_MSDU(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
17)
#endif
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_STATISTICS(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_IS_QOS(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
16)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_EXT_SEC_TYPE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0x1, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_FRAG(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, 0xf, \
12)
#define GET_RX_DESC_SEQ(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword2, \
0xfff, 0)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
31)
#define GET_RX_DESC_UNICAST_WAKE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PATTERN_MATCH(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
29)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_PATTERN_WAKE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
29)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
28)
#define GET_RX_DESC_RXPAYLOAD_ID(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0xf, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_DMA_AGG_NUM(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0xff, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_BSSID_FIT_1_0(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x3, \
12)
#define GET_RX_DESC_EOSP(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
11)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_BSSID_FIT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1f, \
11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_HTC(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, \
10)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_AMPDU_END_PKT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, 9)
#define GET_RX_DESC_ADDRESS_CAM_VLD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_BSSID_FIT_4_2(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x7, 7)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_EOSP_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x1, 7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_RATE(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword3, 0x7f, \
0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1f, \
24)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_ADDRESS_CAM(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0xff, \
24)
#endif
#if (HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_A1_FIT_A1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x7f, \
24)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_MACID_VLD_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, \
23)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MACID_RPT_BUFF(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x7f, \
17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, \
16)
#endif
#if (HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_SWPS_RPT_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, \
16)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_MACID_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0xff, \
15)
#endif
#if (HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_FC_POWER_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, \
15)
#define GET_RX_DESC_TXRPTMID_CTL_MASK_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, \
14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_SCRAMBLER(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x7f, \
9)
#define GET_RX_DESC_RX_EOF(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 8)
#endif
#if (HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_SNIF_INFO(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x3f, \
8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_FC_POWER(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 7)
#endif
#if (HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_TXRPTMID_CTL_MASK(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 6)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_SWPS_RPT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PATTERN_IDX(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0xff, \
0)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_PATTERN_IDX_V1(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1f, \
0)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_PATTERN_IDX_V2(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword4, 0x1f, \
0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword5, \
0xffffffff, 0)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_FREERUN_CNT(rxdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_rx_desc *)rxdesc)->dword5, \
0xffffffff, 0)
#endif
#endif
================================================
FILE: hal/halmac/halmac_rx_desc_chip.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_RX_DESC_CHIP_H_
#define _HALMAC_RX_DESC_CHIP_H_
#if (HALMAC_8814A_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8814A(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8814A(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8814A(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8814A(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8814A(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8814A(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8814A(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8814A(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8814A(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8814A(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8814A(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8814A(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8814A(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8814A(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8814A(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8814A(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8814A(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8814A(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8814A(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8814A(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8814A(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8814A(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8814A(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8814A(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8814A(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8814A(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8814A(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8814A(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8814A(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_C2H_8814A(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8814A(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8814A(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8814A(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8814A(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8814A(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8814A(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8814A(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8814A(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8814A(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8814A(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8814A(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8814A(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8814A(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8814A(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8814A(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8814A(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8814A(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8814A(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8814A(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8814A(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8814A(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8822B_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8822B(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8822B(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8822B(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8822B(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8822B(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8822B(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8822B(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8822B(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8822B(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8822B(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8822B(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8822B(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8822B(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8822B(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8822B(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8822B(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8822B(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8822B(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8822B(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8822B(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8822B(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8822B(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8822B(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8822B(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8822B(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8822B(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8822B(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8822B(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8822B(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8822B(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8822B(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8822B(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8822B(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8822B(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8822B(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8822B(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8822B(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8822B(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8822B(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_MATCH_8822B(rxdesc) \
GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_ID_8822B(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8822B(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8822B(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8822B(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8822B(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8822B(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8822B(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8822B(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8822B(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8822B(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8822B(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8822B(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8822B(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8822B(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8197F_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8197F(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8197F(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8197F(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8197F(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8197F(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8197F(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8197F(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8197F(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8197F(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8197F(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8197F(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8197F(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8197F(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8197F(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8197F(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8197F(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8197F(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8197F(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8197F(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8197F(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8197F(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8197F(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8197F(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8197F(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8197F(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8197F(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8197F(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8197F(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8197F(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_C2H_8197F(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8197F(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8197F(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8197F(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8197F(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8197F(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8197F(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8197F(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8197F(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8197F(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8197F(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8197F(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8197F(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8197F(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8197F(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8197F(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8197F(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8197F(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8197F(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8197F(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_FC_POWER_8197F(rxdesc) GET_RX_DESC_FC_POWER(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8197F(rxdesc) GET_RX_DESC_PATTERN_IDX_V1(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8197F(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8821C_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8821C(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8821C(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8821C(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8821C(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8821C(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8821C(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8821C(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8821C(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8821C(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8821C(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8821C(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8821C(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8821C(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8821C(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8821C(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8821C(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8821C(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8821C(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8821C(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8821C(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8821C(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8821C(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8821C(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8821C(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8821C(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8821C(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8821C(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8821C(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8821C(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8821C(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8821C(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8821C(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8821C(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8821C(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8821C(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8821C(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8821C(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8821C(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8821C(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_MATCH_8821C(rxdesc) \
GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_ID_8821C(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8821C(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8821C(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8821C(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8821C(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8821C(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8821C(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8821C(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8821C(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8821C(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8821C(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8821C(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8821C(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8821C(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8814B_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EVT_PKT_8814B(rxdesc) GET_RX_DESC_EVT_PKT(rxdesc)
#define GET_RX_DESC_SWDEC_8814B(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8814B(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8814B(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8814B(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8814B(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8814B(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8814B(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8814B(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8814B(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8814B(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8814B(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TYPE_8814B(rxdesc) GET_RX_DESC_TYPE(rxdesc)
#define GET_RX_DESC_MF_8814B(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8814B(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8814B(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_A1_MATCH_8814B(rxdesc) GET_RX_DESC_A1_MATCH(rxdesc)
#define GET_RX_DESC_TCP_CHKSUM_VLD_8814B(rxdesc) \
GET_RX_DESC_TCP_CHKSUM_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8814B(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8814B(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_TCP_CHKSUM_ERR_8814B(rxdesc) \
GET_RX_DESC_TCP_CHKSUM_ERR(rxdesc)
#define GET_RX_DESC_PHY_PKT_IDC_8814B(rxdesc) GET_RX_DESC_PHY_PKT_IDC(rxdesc)
#define GET_RX_DESC_FW_FIFO_FULL_8814B(rxdesc) GET_RX_DESC_FW_FIFO_FULL(rxdesc)
#define GET_RX_DESC_AMPDU_8814B(rxdesc) GET_RX_DESC_AMPDU(rxdesc)
#define GET_RX_DESC_RXCMD_IDC_8814B(rxdesc) GET_RX_DESC_RXCMD_IDC(rxdesc)
#define GET_RX_DESC_AMSDU_8814B(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_TID_8814B(rxdesc) GET_RX_DESC_TID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_AMSDU_CUT_8814B(rxdesc) GET_RX_DESC_AMSDU_CUT(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8814B(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8814B(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8814B(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_LAST_MSDU_8814B(rxdesc) GET_RX_DESC_LAST_MSDU(rxdesc)
#define GET_RX_DESC_EXT_SEC_TYPE_8814B(rxdesc) GET_RX_DESC_EXT_SEC_TYPE(rxdesc)
#define GET_RX_DESC_FRAG_8814B(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8814B(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8814B(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8814B(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_WAKE_8814B(rxdesc) GET_RX_DESC_PATTERN_WAKE(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_MATCH_8814B(rxdesc) \
GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_ID_8814B(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8814B(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_8814B(rxdesc) GET_RX_DESC_BSSID_FIT(rxdesc)
#define GET_RX_DESC_HTC_8814B(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_AMPDU_END_PKT_8814B(rxdesc) \
GET_RX_DESC_AMPDU_END_PKT(rxdesc)
#define GET_RX_DESC_ADDRESS_CAM_VLD_8814B(rxdesc) \
GET_RX_DESC_ADDRESS_CAM_VLD(rxdesc)
#define GET_RX_DESC_EOSP_8814B(rxdesc) GET_RX_DESC_EOSP_V1(rxdesc)
#define GET_RX_DESC_RX_RATE_8814B(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_ADDRESS_CAM_8814B(rxdesc) GET_RX_DESC_ADDRESS_CAM(rxdesc)
#define GET_RX_DESC_MACID_VLD_8814B(rxdesc) GET_RX_DESC_MACID_VLD_V1(rxdesc)
#define GET_RX_DESC_MACID_8814B(rxdesc) GET_RX_DESC_MACID_V1(rxdesc)
#define GET_RX_DESC_SWPS_RPT_8814B(rxdesc) GET_RX_DESC_SWPS_RPT(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8814B(rxdesc) GET_RX_DESC_PATTERN_IDX_V2(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_FREERUN_CNT_8814B(rxdesc) GET_RX_DESC_FREERUN_CNT(rxdesc)
#endif
#if (HALMAC_8198F_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8198F(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8198F(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8198F(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8198F(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8198F(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8198F(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8198F(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8198F(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8198F(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8198F(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8198F(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8198F(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8198F(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8198F(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8198F(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8198F(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8198F(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8198F(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8198F(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8198F(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8198F(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8198F(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8198F(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8198F(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8198F(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8198F(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8198F(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8198F(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8198F(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8198F(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8198F(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8198F(rxdesc) GET_RX_DESC_HWRSVD_V1(rxdesc)
#define GET_RX_DESC_RXMAGPKT_8198F(rxdesc) GET_RX_DESC_RXMAGPKT(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8198F(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8198F(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8198F(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8198F(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8198F(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8198F(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8198F(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_MATCH_8198F(rxdesc) \
GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_ID_8198F(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8198F(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8198F(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8198F(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8198F(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8198F(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8198F(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_A1_8198F(rxdesc) GET_RX_DESC_A1_FIT_A1(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8198F(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8198F(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8198F(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8198F(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_FC_POWER_8198F(rxdesc) GET_RX_DESC_FC_POWER(rxdesc)
#define GET_RX_DESC_TXRPTMID_CTL_MASK_8198F(rxdesc) \
GET_RX_DESC_TXRPTMID_CTL_MASK(rxdesc)
#define GET_RX_DESC_SWPS_RPT_8198F(rxdesc) GET_RX_DESC_SWPS_RPT(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8198F(rxdesc) GET_RX_DESC_PATTERN_IDX_V1(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8198F(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8822C_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8822C(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8822C(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8822C(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8822C(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8822C(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8822C(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8822C(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8822C(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8822C(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8822C(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8822C(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8822C(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8822C(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8822C(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8822C(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8822C(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8822C(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8822C(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8822C(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8822C(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8822C(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8822C(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8822C(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8822C(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8822C(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8822C(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8822C(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8822C(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8822C(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8822C(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8822C(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8822C(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8822C(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_STATISTICS_8822C(rxdesc) \
GET_RX_DESC_RX_STATISTICS(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8822C(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8822C(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8822C(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8822C(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8822C(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8822C(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_MATCH_8822C(rxdesc) \
GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_ID_8822C(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8822C(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8822C(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8822C(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8822C(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8822C(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8822C(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8822C(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8822C(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8822C(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8822C(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8822C(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8822C(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8822C(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8192F_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8192F(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_SWDEC_8192F(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8192F(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8192F(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8192F(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8192F(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8192F(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8192F(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8192F(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8192F(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8192F(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8192F(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8192F(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8192F(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8192F(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8192F(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8192F(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8192F(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8192F(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8192F(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8192F(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8192F(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8192F(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8192F(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8192F(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8192F(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8192F(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8192F(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8192F(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8192F(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8192F(rxdesc) GET_RX_DESC_HWRSVD_V1(rxdesc)
#define GET_RX_DESC_RXMAGPKT_8192F(rxdesc) GET_RX_DESC_RXMAGPKT(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8192F(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8192F(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8192F(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8192F(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8192F(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8192F(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8192F(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8192F(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8192F(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8192F(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8192F(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_RX_RATE_8192F(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8192F(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8192F(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_SWPS_RPT_8192F(rxdesc) GET_RX_DESC_SWPS_RPT_V1(rxdesc)
#define GET_RX_DESC_FC_POWER_8192F(rxdesc) GET_RX_DESC_FC_POWER_V1(rxdesc)
#define GET_RX_DESC_TXRPTMID_CTL_MASK_8192F(rxdesc) \
GET_RX_DESC_TXRPTMID_CTL_MASK_V1(rxdesc)
#define GET_RX_DESC_SNIF_INFO_8192F(rxdesc) GET_RX_DESC_SNIF_INFO(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8192F(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8192F(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#if (HALMAC_8812F_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR_8812F(rxdesc) GET_RX_DESC_EOR(rxdesc)
#define GET_RX_DESC_PHYPKTIDC_8812F(rxdesc) GET_RX_DESC_PHYPKTIDC(rxdesc)
#define GET_RX_DESC_SWDEC_8812F(rxdesc) GET_RX_DESC_SWDEC(rxdesc)
#define GET_RX_DESC_PHYST_8812F(rxdesc) GET_RX_DESC_PHYST(rxdesc)
#define GET_RX_DESC_SHIFT_8812F(rxdesc) GET_RX_DESC_SHIFT(rxdesc)
#define GET_RX_DESC_QOS_8812F(rxdesc) GET_RX_DESC_QOS(rxdesc)
#define GET_RX_DESC_SECURITY_8812F(rxdesc) GET_RX_DESC_SECURITY(rxdesc)
#define GET_RX_DESC_DRV_INFO_SIZE_8812F(rxdesc) \
GET_RX_DESC_DRV_INFO_SIZE(rxdesc)
#define GET_RX_DESC_ICV_ERR_8812F(rxdesc) GET_RX_DESC_ICV_ERR(rxdesc)
#define GET_RX_DESC_CRC32_8812F(rxdesc) GET_RX_DESC_CRC32(rxdesc)
#define GET_RX_DESC_PKT_LEN_8812F(rxdesc) GET_RX_DESC_PKT_LEN(rxdesc)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC_8812F(rxdesc) GET_RX_DESC_BC(rxdesc)
#define GET_RX_DESC_MC_8812F(rxdesc) GET_RX_DESC_MC(rxdesc)
#define GET_RX_DESC_TY_PE_8812F(rxdesc) GET_RX_DESC_TY_PE(rxdesc)
#define GET_RX_DESC_MF_8812F(rxdesc) GET_RX_DESC_MF(rxdesc)
#define GET_RX_DESC_MD_8812F(rxdesc) GET_RX_DESC_MD(rxdesc)
#define GET_RX_DESC_PWR_8812F(rxdesc) GET_RX_DESC_PWR(rxdesc)
#define GET_RX_DESC_PAM_8812F(rxdesc) GET_RX_DESC_PAM(rxdesc)
#define GET_RX_DESC_CHK_VLD_8812F(rxdesc) GET_RX_DESC_CHK_VLD(rxdesc)
#define GET_RX_DESC_RX_IS_TCP_UDP_8812F(rxdesc) \
GET_RX_DESC_RX_IS_TCP_UDP(rxdesc)
#define GET_RX_DESC_RX_IPV_8812F(rxdesc) GET_RX_DESC_RX_IPV(rxdesc)
#define GET_RX_DESC_CHKERR_8812F(rxdesc) GET_RX_DESC_CHKERR(rxdesc)
#define GET_RX_DESC_PAGGR_8812F(rxdesc) GET_RX_DESC_PAGGR(rxdesc)
#define GET_RX_DESC_RXID_MATCH_8812F(rxdesc) GET_RX_DESC_RXID_MATCH(rxdesc)
#define GET_RX_DESC_AMSDU_8812F(rxdesc) GET_RX_DESC_AMSDU(rxdesc)
#define GET_RX_DESC_MACID_VLD_8812F(rxdesc) GET_RX_DESC_MACID_VLD(rxdesc)
#define GET_RX_DESC_TID_8812F(rxdesc) GET_RX_DESC_TID(rxdesc)
#define GET_RX_DESC_MACID_8812F(rxdesc) GET_RX_DESC_MACID(rxdesc)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK_8812F(rxdesc) GET_RX_DESC_FCS_OK(rxdesc)
#define GET_RX_DESC_PPDU_CNT_8812F(rxdesc) GET_RX_DESC_PPDU_CNT(rxdesc)
#define GET_RX_DESC_C2H_8812F(rxdesc) GET_RX_DESC_C2H(rxdesc)
#define GET_RX_DESC_HWRSVD_8812F(rxdesc) GET_RX_DESC_HWRSVD(rxdesc)
#define GET_RX_DESC_WLANHD_IV_LEN_8812F(rxdesc) \
GET_RX_DESC_WLANHD_IV_LEN(rxdesc)
#define GET_RX_DESC_RX_STATISTICS_8812F(rxdesc) \
GET_RX_DESC_RX_STATISTICS(rxdesc)
#define GET_RX_DESC_RX_IS_QOS_8812F(rxdesc) GET_RX_DESC_RX_IS_QOS(rxdesc)
#define GET_RX_DESC_FRAG_8812F(rxdesc) GET_RX_DESC_FRAG(rxdesc)
#define GET_RX_DESC_SEQ_8812F(rxdesc) GET_RX_DESC_SEQ(rxdesc)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE_8812F(rxdesc) GET_RX_DESC_MAGIC_WAKE(rxdesc)
#define GET_RX_DESC_UNICAST_WAKE_8812F(rxdesc) GET_RX_DESC_UNICAST_WAKE(rxdesc)
#define GET_RX_DESC_PATTERN_MATCH_8812F(rxdesc) \
GET_RX_DESC_PATTERN_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_MATCH_8812F(rxdesc) \
GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc)
#define GET_RX_DESC_RXPAYLOAD_ID_8812F(rxdesc) GET_RX_DESC_RXPAYLOAD_ID(rxdesc)
#define GET_RX_DESC_DMA_AGG_NUM_8812F(rxdesc) GET_RX_DESC_DMA_AGG_NUM(rxdesc)
#define GET_RX_DESC_BSSID_FIT_1_0_8812F(rxdesc) \
GET_RX_DESC_BSSID_FIT_1_0(rxdesc)
#define GET_RX_DESC_EOSP_8812F(rxdesc) GET_RX_DESC_EOSP(rxdesc)
#define GET_RX_DESC_HTC_8812F(rxdesc) GET_RX_DESC_HTC(rxdesc)
#define GET_RX_DESC_BSSID_FIT_4_2_8812F(rxdesc) \
GET_RX_DESC_BSSID_FIT_4_2(rxdesc)
#define GET_RX_DESC_RX_RATE_8812F(rxdesc) GET_RX_DESC_RX_RATE(rxdesc)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT_8812F(rxdesc) GET_RX_DESC_A1_FIT(rxdesc)
#define GET_RX_DESC_MACID_RPT_BUFF_8812F(rxdesc) \
GET_RX_DESC_MACID_RPT_BUFF(rxdesc)
#define GET_RX_DESC_RX_PRE_NDP_VLD_8812F(rxdesc) \
GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc)
#define GET_RX_DESC_RX_SCRAMBLER_8812F(rxdesc) GET_RX_DESC_RX_SCRAMBLER(rxdesc)
#define GET_RX_DESC_RX_EOF_8812F(rxdesc) GET_RX_DESC_RX_EOF(rxdesc)
#define GET_RX_DESC_PATTERN_IDX_8812F(rxdesc) GET_RX_DESC_PATTERN_IDX(rxdesc)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL_8812F(rxdesc) GET_RX_DESC_TSFL(rxdesc)
#endif
#endif
================================================
FILE: hal/halmac/halmac_rx_desc_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_RX_DESC_NIC_H_
#define _HALMAC_RX_DESC_NIC_H_
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*RXDESC_WORD0*/
#define GET_RX_DESC_EOR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 30, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PHYPKTIDC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 28, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_EVT_PKT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 28, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_SWDEC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 27, 1)
#define GET_RX_DESC_PHYST(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 26, 1)
#define GET_RX_DESC_SHIFT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 24, 2)
#define GET_RX_DESC_QOS(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 23, 1)
#define GET_RX_DESC_SECURITY(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 20, 3)
#define GET_RX_DESC_DRV_INFO_SIZE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 16, 4)
#define GET_RX_DESC_ICV_ERR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 15, 1)
#define GET_RX_DESC_CRC32(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 14, 1)
#define GET_RX_DESC_PKT_LEN(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x00, 0, 14)
/*RXDESC_WORD1*/
#define GET_RX_DESC_BC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 31, 1)
#define GET_RX_DESC_MC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 30, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_TY_PE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 28, 2)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_TYPE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 28, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MF(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 27, 1)
#define GET_RX_DESC_MD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 26, 1)
#define GET_RX_DESC_PWR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 25, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PAM(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 24, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_A1_MATCH(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 24, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_CHK_VLD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 23, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_TCP_CHKSUM_VLD(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x04, 23, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_IS_TCP_UDP(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 22, 1)
#define GET_RX_DESC_RX_IPV(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 21, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_CHKERR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 20, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_TCP_CHKSUM_ERR(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x04, 20, 1)
#define GET_RX_DESC_PHY_PKT_IDC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 17, 1)
#define GET_RX_DESC_FW_FIFO_FULL(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 16, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PAGGR(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 15, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_AMPDU(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 15, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RXID_MATCH(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 14, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_RXCMD_IDC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 14, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_AMSDU(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 13, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MACID_VLD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 12, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_TID(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 8, 4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MACID(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x04, 0, 7)
/*RXDESC_WORD2*/
#define GET_RX_DESC_FCS_OK(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 31, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_AMSDU_CUT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 31, 1)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PPDU_CNT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 29, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_C2H(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 28, 1)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_HWRSVD_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 25, 3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_HWRSVD(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 24, 4)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_RXMAGPKT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 24, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_WLANHD_IV_LEN(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 18, 6)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_LAST_MSDU(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 17, 1)
#endif
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_STATISTICS(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 17, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_IS_QOS(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 16, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_EXT_SEC_TYPE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 16, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_FRAG(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 12, 4)
#define GET_RX_DESC_SEQ(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x08, 0, 12)
/*RXDESC_WORD3*/
#define GET_RX_DESC_MAGIC_WAKE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 31, 1)
#define GET_RX_DESC_UNICAST_WAKE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 30, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PATTERN_MATCH(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 29, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_PATTERN_WAKE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 29, 1)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RXPAYLOAD_MATCH(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x0C, 28, 1)
#define GET_RX_DESC_RXPAYLOAD_ID(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 24, 4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_DMA_AGG_NUM(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 16, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_BSSID_FIT_1_0(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 12, 2)
#define GET_RX_DESC_EOSP(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 11, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_BSSID_FIT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 11, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_HTC(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 10, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_AMPDU_END_PKT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 9, 1)
#define GET_RX_DESC_ADDRESS_CAM_VLD(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x0C, 8, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_BSSID_FIT_4_2(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 7, 3)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_EOSP_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 7, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_RATE(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x0C, 0, 7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*RXDESC_WORD4*/
#define GET_RX_DESC_A1_FIT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 24, 5)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_ADDRESS_CAM(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 24, 8)
#endif
#if (HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_A1_FIT_A1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 24, 7)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_MACID_VLD_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 23, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_MACID_RPT_BUFF(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x10, 17, 7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_PRE_NDP_VLD(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x10, 16, 1)
#endif
#if (HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_SWPS_RPT_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 16, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_MACID_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 15, 8)
#endif
#if (HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_FC_POWER_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 15, 1)
#define GET_RX_DESC_TXRPTMID_CTL_MASK_V1(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x10, 14, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_RX_SCRAMBLER(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 9, 7)
#define GET_RX_DESC_RX_EOF(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 8, 1)
#endif
#if (HALMAC_8192F_SUPPORT)
#define GET_RX_DESC_SNIF_INFO(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 8, 6)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_FC_POWER(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 7, 1)
#endif
#if (HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_TXRPTMID_CTL_MASK(rxdesc) \
LE_BITS_TO_4BYTE(rxdesc + 0x10, 6, 1)
#endif
#if (HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_SWPS_RPT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 5, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define GET_RX_DESC_PATTERN_IDX(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 0, 8)
#endif
#if (HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT)
#define GET_RX_DESC_PATTERN_IDX_V1(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 0, 5)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_PATTERN_IDX_V2(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x10, 0, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*RXDESC_WORD5*/
#define GET_RX_DESC_TSFL(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x14, 0, 32)
#endif
#if (HALMAC_8814B_SUPPORT)
#define GET_RX_DESC_FREERUN_CNT(rxdesc) LE_BITS_TO_4BYTE(rxdesc + 0x14, 0, 32)
#endif
#endif
================================================
FILE: hal/halmac/halmac_sdio_reg.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __HALMAC_SDIO_REG_H__
#define __HALMAC_SDIO_REG_H__
/* SDIO CMD address mapping */
#define HALMAC_SDIO_4BYTE_LEN_MASK 0x1FFF
#define HALMAC_SDIO_LOCAL_MSK 0x0FFF
#define HALMAC_WLAN_MAC_REG_MSK 0xFFFF
#define HALMAC_WLAN_IOREG_MSK 0xFFFF
/* Sdio Address for SDIO Local Reg, TRX FIFO, MAC Reg */
enum halmac_sdio_cmd_addr {
HALMAC_SDIO_CMD_ADDR_SDIO_REG = 0,
HALMAC_SDIO_CMD_ADDR_MAC_REG = 8,
HALMAC_SDIO_CMD_ADDR_TXFF_HIGH = 4,
HALMAC_SDIO_CMD_ADDR_TXFF_LOW = 6,
HALMAC_SDIO_CMD_ADDR_TXFF_NORMAL = 5,
HALMAC_SDIO_CMD_ADDR_TXFF_EXTRA = 7,
HALMAC_SDIO_CMD_ADDR_RXFF = 7,
};
/* IO Bus domain address mapping */
#define SDIO_LOCAL_OFFSET 0x10250000
#define WLAN_IOREG_OFFSET 0x10260000
#define FW_FIFO_OFFSET 0x10270000
#define TX_HIQ_OFFSET 0x10310000
#define TX_MIQ_OFFSET 0x10320000
#define TX_LOQ_OFFSET 0x10330000
#define TX_EXQ_OFFSET 0x10350000
#define RX_RXOFF_OFFSET 0x10340000
/* Get TX WLAN FIFO information in CMD53 addr */
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT)
#define GET_WLAN_TXFF_DEVICE_ID(cmd53_addr) \
LE_BITS_TO_4BYTE((u32 *)cmd53_addr, 13, 4)
#define GET_WLAN_TXFF_PKT_SIZE(cmd53_addr) \
(LE_BITS_TO_4BYTE((u32 *)cmd53_addr, 0, 13) << 2)
#endif
#endif/* __HALMAC_SDIO_REG_H__ */
================================================
FILE: hal/halmac/halmac_state_machine.h
================================================
/******************************************************************************
*
* Copyright(c) 2017 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_STATE_MACHINE_H_
#define _HALMAC_STATE_MACHINE_H_
enum halmac_dlfw_state {
HALMAC_DLFW_NONE = 0,
HALMAC_DLFW_DONE = 1,
HALMAC_GEN_INFO_SENT = 2,
/* Data CPU firmware download framework */
HALMAC_DLFW_INIT = 0x11,
HALMAC_DLFW_START = 0x12,
HALMAC_DLFW_CONF_READY = 0x13,
HALMAC_DLFW_CPU_READY = 0x14,
HALMAC_DLFW_MEM_READY = 0x15,
HALMAC_DLFW_SW_READY = 0x16,
HALMAC_DLFW_OFLD_READY = 0x17,
HALMAC_DLFW_UNDEFINED = 0x7F,
};
enum halmac_gpio_cfg_state {
HALMAC_GPIO_CFG_STATE_IDLE = 0,
HALMAC_GPIO_CFG_STATE_BUSY = 1,
HALMAC_GPIO_CFG_STATE_UNDEFINED = 0x7F,
};
enum halmac_rsvd_pg_state {
HALMAC_RSVD_PG_STATE_IDLE = 0,
HALMAC_RSVD_PG_STATE_BUSY = 1,
HALMAC_RSVD_PG_STATE_UNDEFINED = 0x7F,
};
enum halmac_api_state {
HALMAC_API_STATE_INIT = 0,
HALMAC_API_STATE_HALT = 1,
HALMAC_API_STATE_UNDEFINED = 0x7F,
};
enum halmac_cmd_construct_state {
HALMAC_CMD_CNSTR_IDLE = 0,
HALMAC_CMD_CNSTR_BUSY = 1,
HALMAC_CMD_CNSTR_H2C_SENT = 2,
HALMAC_CMD_CNSTR_CNSTR = 3,
HALMAC_CMD_CNSTR_BUF_CLR = 4,
HALMAC_CMD_CNSTR_UNDEFINED = 0x7F,
};
enum halmac_cmd_process_status {
HALMAC_CMD_PROCESS_IDLE = 0x01, /* Init status */
HALMAC_CMD_PROCESS_SENDING = 0x02, /* Wait ack */
HALMAC_CMD_PROCESS_RCVD = 0x03, /* Rcvd ack */
HALMAC_CMD_PROCESS_DONE = 0x04, /* Event done */
HALMAC_CMD_PROCESS_ERROR = 0x05, /* Return code error */
HALMAC_CMD_PROCESS_UNDEFINE = 0x7F,
};
enum halmac_mac_power {
HALMAC_MAC_POWER_OFF = 0x0,
HALMAC_MAC_POWER_ON = 0x1,
HALMAC_MAC_POWER_UNDEFINE = 0x7F,
};
enum halmac_wlcpu_mode {
HALMAC_WLCPU_ACTIVE = 0x0,
HALMAC_WLCPU_ENTER_SLEEP = 0x1,
HALMAC_WLCPU_SLEEP = 0x2,
HALMAC_WLCPU_UNDEFINE = 0x7F,
};
struct halmac_efuse_state {
enum halmac_cmd_construct_state cmd_cnstr_state;
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_cfg_param_state {
enum halmac_cmd_construct_state cmd_cnstr_state;
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_scan_state {
enum halmac_cmd_construct_state cmd_cnstr_state;
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_update_pkt_state {
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_iqk_state {
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_pwr_tracking_state {
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_psd_state {
enum halmac_cmd_process_status proc_status;
u16 data_size;
u16 seg_size;
u8 *data;
u8 fw_rc;
u16 seq_num;
};
struct halmac_fw_snding_state {
enum halmac_cmd_construct_state cmd_cnstr_state;
enum halmac_cmd_process_status proc_status;
u8 fw_rc;
u16 seq_num;
};
struct halmac_state {
struct halmac_efuse_state efuse_state;
struct halmac_cfg_param_state cfg_param_state;
struct halmac_scan_state scan_state;
struct halmac_update_pkt_state update_pkt_state;
struct halmac_iqk_state iqk_state;
struct halmac_pwr_tracking_state pwr_trk_state;
struct halmac_psd_state psd_state;
struct halmac_fw_snding_state fw_snding_state;
enum halmac_api_state api_state;
enum halmac_mac_power mac_pwr;
enum halmac_dlfw_state dlfw_state;
enum halmac_wlcpu_mode wlcpu_mode;
enum halmac_gpio_cfg_state gpio_cfg_state;
enum halmac_rsvd_pg_state rsvd_pg_state;
};
#endif
================================================
FILE: hal/halmac/halmac_tx_bd_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_BD_NIC_H_
#define _HALMAC_TX_BD_NIC_H_
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT ||\
HALMAC_8812F_SUPPORT)
/*TXBD_DW0*/
#define SET_TX_BD_OWN(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x00, 31, 1, value)
#define GET_TX_BD_OWN(txbd) LE_BITS_TO_4BYTE(txbd + 0x00, 31, 1)
#define SET_TX_BD_PSB(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x00, 16, 8, value)
#define GET_TX_BD_PSB(txbd) LE_BITS_TO_4BYTE(txbd + 0x00, 16, 8)
#define SET_TX_BD_TX_BUFF_SIZE0(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x00, 0, 16, value)
#define GET_TX_BD_TX_BUFF_SIZE0(txbd) LE_BITS_TO_4BYTE(txbd + 0x00, 0, 16)
/*TXBD_DW1*/
#define SET_TX_BD_PHYSICAL_ADDR0_LOW(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x04, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR0_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x04, 0, 32)
/*TXBD_DW2*/
#define SET_TX_BD_PHYSICAL_ADDR0_HIGH(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x08, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR0_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x08, 0, 32)
/*TXBD_DW4*/
#define SET_TX_BD_A1(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x10, 31, 1, value)
#define GET_TX_BD_A1(txbd) LE_BITS_TO_4BYTE(txbd + 0x10, 31, 1)
#define SET_TX_BD_TX_BUFF_SIZE1(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x10, 0, 16, value)
#define GET_TX_BD_TX_BUFF_SIZE1(txbd) LE_BITS_TO_4BYTE(txbd + 0x10, 0, 16)
/*TXBD_DW5*/
#define SET_TX_BD_PHYSICAL_ADDR1_LOW(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x14, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR1_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x14, 0, 32)
/*TXBD_DW6*/
#define SET_TX_BD_PHYSICAL_ADDR1_HIGH(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x18, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR1_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x18, 0, 32)
/*TXBD_DW8*/
#define SET_TX_BD_A2(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x20, 31, 1, value)
#define GET_TX_BD_A2(txbd) LE_BITS_TO_4BYTE(txbd + 0x20, 31, 1)
#define SET_TX_BD_TX_BUFF_SIZE2(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x20, 0, 16, value)
#define GET_TX_BD_TX_BUFF_SIZE2(txbd) LE_BITS_TO_4BYTE(txbd + 0x20, 0, 16)
/*TXBD_DW9*/
#define SET_TX_BD_PHYSICAL_ADDR2_LOW(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x24, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR2_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x24, 0, 32)
/*TXBD_DW10*/
#define SET_TX_BD_PHYSICAL_ADDR2_HIGH(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x28, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR2_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x28, 0, 32)
/*TXBD_DW12*/
#define SET_TX_BD_A3(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x30, 31, 1, value)
#define GET_TX_BD_A3(txbd) LE_BITS_TO_4BYTE(txbd + 0x30, 31, 1)
#define SET_TX_BD_TX_BUFF_SIZE3(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x30, 0, 16, value)
#define GET_TX_BD_TX_BUFF_SIZE3(txbd) LE_BITS_TO_4BYTE(txbd + 0x30, 0, 16)
/*TXBD_DW13*/
#define SET_TX_BD_PHYSICAL_ADDR3_LOW(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x34, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR3_LOW(txbd) LE_BITS_TO_4BYTE(txbd + 0x34, 0, 32)
/*TXBD_DW14*/
#define SET_TX_BD_PHYSICAL_ADDR3_HIGH(txbd, value) \
SET_BITS_TO_LE_4BYTE(txbd + 0x38, 0, 32, value)
#define GET_TX_BD_PHYSICAL_ADDR3_HIGH(txbd) LE_BITS_TO_4BYTE(txbd + 0x38, 0, 32)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_AP_H_
#define _HALMAC_TX_DESC_AP_H_
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 31)
#define SET_TX_DESC_DISQSELSEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 31)
#define GET_TX_DESC_DISQSELSEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
31)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_IE_END_BODY(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 31)
#define SET_TX_DESC_IE_END_BODY_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 31)
#define GET_TX_DESC_IE_END_BODY(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
31)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_GF(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 30)
#define SET_TX_DESC_GF_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 30)
#define GET_TX_DESC_GF(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
30)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_AGG_EN_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 30)
#define SET_TX_DESC_AGG_EN_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 30)
#define GET_TX_DESC_AGG_EN_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NO_ACM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 29)
#define SET_TX_DESC_NO_ACM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 29)
#define GET_TX_DESC_NO_ACM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
29)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_BK_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 29)
#define SET_TX_DESC_BK_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 29)
#define GET_TX_DESC_BK_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
29)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 28)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 28)
#define GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_AMSDU_PAD_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 27)
#define SET_TX_DESC_AMSDU_PAD_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 27)
#define GET_TX_DESC_AMSDU_PAD_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_LS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 26)
#define SET_TX_DESC_LS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 26)
#define GET_TX_DESC_LS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_HTC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 25)
#define SET_TX_DESC_HTC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 25)
#define GET_TX_DESC_HTC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
25)
#define SET_TX_DESC_BMC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 24)
#define SET_TX_DESC_BMC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 24)
#define GET_TX_DESC_BMC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
24)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_PKT_OFFSET_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1f, 24)
#define SET_TX_DESC_PKT_OFFSET_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1f, 24)
#define GET_TX_DESC_PKT_OFFSET_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1f, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_OFFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0xff, 16)
#define SET_TX_DESC_OFFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0xff, 16)
#define GET_TX_DESC_OFFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0xff, \
16)
#define SET_TX_DESC_TXPKTSIZE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0xffff, 0)
#define SET_TX_DESC_TXPKTSIZE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0xffff, 0)
#define GET_TX_DESC_TXPKTSIZE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, \
0xffff, 0)
#endif
#if (HALMAC_8198F_SUPPORT)
/*WORD1*/
#define SET_TX_DESC_HW_AES_IV_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 31)
#define SET_TX_DESC_HW_AES_IV_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 31)
#define GET_TX_DESC_HW_AES_IV_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
31)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_AMSDU(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 30)
#define SET_TX_DESC_AMSDU_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
#define GET_TX_DESC_AMSDU(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
30)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_FTM_EN_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 30)
#define SET_TX_DESC_FTM_EN_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
#define GET_TX_DESC_FTM_EN_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
30)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_KEYID_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 30)
#define SET_TX_DESC_KEYID_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
#define GET_TX_DESC_KEYID_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MOREDATA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 29)
#define SET_TX_DESC_MOREDATA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 29)
#define GET_TX_DESC_MOREDATA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
29)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_HW_AES_IV_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 29)
#define SET_TX_DESC_HW_AES_IV_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 29)
#define GET_TX_DESC_HW_AES_IV_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
29)
#define SET_TX_DESC_MHR_CP(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 25)
#define SET_TX_DESC_MHR_CP_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 25)
#define GET_TX_DESC_MHR_CP(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
25)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PKT_OFFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1f, 24)
#define SET_TX_DESC_PKT_OFFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 24)
#define GET_TX_DESC_PKT_OFFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
24)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_SMH_EN_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 24)
#define SET_TX_DESC_SMH_EN_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 24)
#define GET_TX_DESC_SMH_EN_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SEC_TYPE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x3, 22)
#define SET_TX_DESC_SEC_TYPE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x3, 22)
#define GET_TX_DESC_SEC_TYPE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x3, \
22)
#define SET_TX_DESC_EN_DESC_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 21)
#define SET_TX_DESC_EN_DESC_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 21)
#define GET_TX_DESC_EN_DESC_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
21)
#define SET_TX_DESC_RATE_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1f, 16)
#define SET_TX_DESC_RATE_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 16)
#define GET_TX_DESC_RATE_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
16)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_SMH_CAM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0xff, 16)
#define SET_TX_DESC_SMH_CAM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0xff, 16)
#define GET_TX_DESC_SMH_CAM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0xff, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PIFS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 15)
#define SET_TX_DESC_PIFS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 15)
#define GET_TX_DESC_PIFS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
15)
#define SET_TX_DESC_LSIG_TXOP_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 14)
#define SET_TX_DESC_LSIG_TXOP_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 14)
#define GET_TX_DESC_LSIG_TXOP_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
14)
#define SET_TX_DESC_RD_NAV_EXT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 13)
#define SET_TX_DESC_RD_NAV_EXT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 13)
#define GET_TX_DESC_RD_NAV_EXT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
13)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_EXT_EDCA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 13)
#define SET_TX_DESC_EXT_EDCA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 13)
#define GET_TX_DESC_EXT_EDCA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_QSEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1f, 8)
#define SET_TX_DESC_QSEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 8)
#define GET_TX_DESC_QSEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
8)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_SPECIAL_CW(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 7)
#define SET_TX_DESC_SPECIAL_CW_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 7)
#define GET_TX_DESC_SPECIAL_CW(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, 7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MACID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x7f, 0)
#define SET_TX_DESC_MACID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x7f, 0)
#define GET_TX_DESC_MACID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x7f, \
0)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_MACID_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x7f, 0)
#define SET_TX_DESC_MACID_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x7f, 0)
#define GET_TX_DESC_MACID_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x7f, \
0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 31)
#define SET_TX_DESC_HW_AES_IV_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 31)
#define GET_TX_DESC_HW_AES_IV(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
31)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_CHK_EN_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 31)
#define SET_TX_DESC_CHK_EN_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 31)
#define GET_TX_DESC_CHK_EN_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
31)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_FTM_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 30)
#define SET_TX_DESC_FTM_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 30)
#define GET_TX_DESC_FTM_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
30)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTCEL_D_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0xf, 28)
#define SET_TX_DESC_ANTCEL_D_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0xf, 28)
#define GET_TX_DESC_ANTCEL_D_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xf, \
28)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_DMA_PRI(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 27)
#define SET_TX_DESC_DMA_PRI_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 27)
#define GET_TX_DESC_DMA_PRI(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
27)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_G_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x3f, 24)
#define SET_TX_DESC_G_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x3f, 24)
#define GET_TX_DESC_G_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x3f, \
24)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_MAX_AMSDU_MODE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x7, 24)
#define SET_TX_DESC_MAX_AMSDU_MODE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x7, 24)
#define GET_TX_DESC_MAX_AMSDU_MODE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x7, \
24)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_C_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0xf, 24)
#define SET_TX_DESC_ANTSEL_C_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0xf, 24)
#define GET_TX_DESC_ANTSEL_C_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xf, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_BT_NULL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 23)
#define SET_TX_DESC_BT_NULL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 23)
#define GET_TX_DESC_BT_NULL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
23)
#define SET_TX_DESC_AMPDU_DENSITY(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x7, 20)
#define SET_TX_DESC_AMPDU_DENSITY_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x7, 20)
#define GET_TX_DESC_AMPDU_DENSITY(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x7, \
20)
#define SET_TX_DESC_SPE_RPT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 19)
#define SET_TX_DESC_SPE_RPT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 19)
#define GET_TX_DESC_SPE_RPT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
19)
#define SET_TX_DESC_RAW(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 18)
#define SET_TX_DESC_RAW_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 18)
#define GET_TX_DESC_RAW(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
18)
#define SET_TX_DESC_MOREFRAG(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 17)
#define SET_TX_DESC_MOREFRAG_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 17)
#define GET_TX_DESC_MOREFRAG(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
17)
#define SET_TX_DESC_BK(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 16)
#define SET_TX_DESC_BK_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 16)
#define GET_TX_DESC_BK(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
16)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0xff, 16)
#define SET_TX_DESC_DMA_TXAGG_NUM_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0xff, 16)
#define GET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xff, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NULL_1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 15)
#define SET_TX_DESC_NULL_1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 15)
#define GET_TX_DESC_NULL_1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
15)
#define SET_TX_DESC_NULL_0(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 14)
#define SET_TX_DESC_NULL_0_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 14)
#define GET_TX_DESC_NULL_0(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
14)
#define SET_TX_DESC_RDG_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 13)
#define SET_TX_DESC_RDG_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 13)
#define GET_TX_DESC_RDG_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
13)
#define SET_TX_DESC_AGG_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 12)
#define SET_TX_DESC_AGG_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 12)
#define GET_TX_DESC_AGG_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
12)
#define SET_TX_DESC_CCA_RTS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x3, 10)
#define SET_TX_DESC_CCA_RTS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x3, 10)
#define GET_TX_DESC_CCA_RTS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x3, \
10)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TRI_FRAME(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 9)
#define SET_TX_DESC_TRI_FRAME_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 9)
#define GET_TX_DESC_TRI_FRAME(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, 9)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_P_AID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1ff, 0)
#define SET_TX_DESC_P_AID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1ff, 0)
#define GET_TX_DESC_P_AID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, \
0x1ff, 0)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0xffff, 0)
#define SET_TX_DESC_TXDESC_CHECKSUM_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0xffff, 0)
#define GET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, \
0xffff, 0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0xff, 24)
#define SET_TX_DESC_AMPDU_MAX_TIME_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0xff, 24)
#define GET_TX_DESC_AMPDU_MAX_TIME(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0xff, \
24)
#define SET_TX_DESC_NDPA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x3, 22)
#define SET_TX_DESC_NDPA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x3, 22)
#define GET_TX_DESC_NDPA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x3, \
22)
#define SET_TX_DESC_MAX_AGG_NUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1f, 17)
#define SET_TX_DESC_MAX_AGG_NUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 17)
#define GET_TX_DESC_MAX_AGG_NUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
17)
#define SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 16)
#define SET_TX_DESC_USE_MAX_TIME_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 16)
#define GET_TX_DESC_USE_MAX_TIME_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
16)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_OFFLOAD_SIZE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x7fff, 16)
#define SET_TX_DESC_OFFLOAD_SIZE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x7fff, 16)
#define GET_TX_DESC_OFFLOAD_SIZE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, \
0x7fff, 16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NAVUSEHDR(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 15)
#define SET_TX_DESC_NAVUSEHDR_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 15)
#define GET_TX_DESC_NAVUSEHDR(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
15)
#define SET_TX_DESC_CHK_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 14)
#define SET_TX_DESC_CHK_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 14)
#define GET_TX_DESC_CHK_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
14)
#define SET_TX_DESC_HW_RTS_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 13)
#define SET_TX_DESC_HW_RTS_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 13)
#define GET_TX_DESC_HW_RTS_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
13)
#define SET_TX_DESC_RTSEN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 12)
#define SET_TX_DESC_RTSEN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 12)
#define GET_TX_DESC_RTSEN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
12)
#define SET_TX_DESC_CTS2SELF(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 11)
#define SET_TX_DESC_CTS2SELF_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 11)
#define GET_TX_DESC_CTS2SELF(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
11)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_CHANNEL_DMA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1f, 11)
#define SET_TX_DESC_CHANNEL_DMA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 11)
#define GET_TX_DESC_CHANNEL_DMA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_DISDATAFB(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 10)
#define SET_TX_DESC_DISDATAFB_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 10)
#define GET_TX_DESC_DISDATAFB(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, \
10)
#define SET_TX_DESC_DISRTSFB(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 9)
#define SET_TX_DESC_DISRTSFB_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 9)
#define GET_TX_DESC_DISRTSFB(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 9)
#define SET_TX_DESC_USE_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 8)
#define SET_TX_DESC_USE_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 8)
#define GET_TX_DESC_USE_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 8)
#define SET_TX_DESC_HW_SSN_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x3, 6)
#define SET_TX_DESC_HW_SSN_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x3, 6)
#define GET_TX_DESC_HW_SSN_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x3, 6)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_IE_CNT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x7, 6)
#define SET_TX_DESC_IE_CNT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x7, 6)
#define GET_TX_DESC_IE_CNT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x7, 6)
#define SET_TX_DESC_IE_CNT_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 5)
#define SET_TX_DESC_IE_CNT_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 5)
#define GET_TX_DESC_IE_CNT_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_WHEADER_LEN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1f, 0)
#define SET_TX_DESC_WHEADER_LEN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 0)
#define GET_TX_DESC_WHEADER_LEN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
0)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_WHEADER_LEN_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1f, 0)
#define SET_TX_DESC_WHEADER_LEN_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 0)
#define GET_TX_DESC_WHEADER_LEN_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x3, 30)
#define SET_TX_DESC_PCTS_MASK_IDX_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x3, 30)
#define GET_TX_DESC_PCTS_MASK_IDX(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x3, \
30)
#define SET_TX_DESC_PCTS_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1, 29)
#define SET_TX_DESC_PCTS_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 29)
#define GET_TX_DESC_PCTS_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, \
29)
#define SET_TX_DESC_RTSRATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1f, 24)
#define SET_TX_DESC_RTSRATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1f, 24)
#define GET_TX_DESC_RTSRATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1f, \
24)
#define SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x3f, 18)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x3f, 18)
#define GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x3f, \
18)
#define SET_TX_DESC_RTY_LMT_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1, 17)
#define SET_TX_DESC_RTY_LMT_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 17)
#define GET_TX_DESC_RTY_LMT_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, \
17)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0xf, 13)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0xf, 13)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0xf, \
13)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1f, 8)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1f, 8)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1f, \
8)
#define SET_TX_DESC_TRY_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1, 7)
#define SET_TX_DESC_TRY_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 7)
#define GET_TX_DESC_TRY_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, 7)
#define SET_TX_DESC_DATARATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x7f, 0)
#define SET_TX_DESC_DATARATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x7f, 0)
#define GET_TX_DESC_DATARATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x7f, \
0)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 31)
#define SET_TX_DESC_POLLUTED_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 31)
#define GET_TX_DESC_POLLUTED(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
31)
#endif
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANTSEL_EN_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 30)
#define SET_TX_DESC_ANTSEL_EN_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 30)
#define GET_TX_DESC_ANTSEL_EN_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_TXPWR_OFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x7, 28)
#define SET_TX_DESC_TXPWR_OFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 28)
#define GET_TX_DESC_TXPWR_OFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7, \
28)
#endif
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 28)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 28)
#define GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, \
28)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x7, 28)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 28)
#define GET_TX_DESC_TXPWR_OFSET_TYPE_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7, \
28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TX_ANT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0xf, 24)
#define SET_TX_DESC_TX_ANT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 24)
#define GET_TX_DESC_TX_ANT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf, \
24)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_DROP_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 24)
#define SET_TX_DESC_DROP_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 24)
#define GET_TX_DESC_DROP_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, \
24)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_DROP_ID_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 22)
#define SET_TX_DESC_DROP_ID_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 22)
#define GET_TX_DESC_DROP_ID_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, \
22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PORT_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x7, 21)
#define SET_TX_DESC_PORT_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 21)
#define GET_TX_DESC_PORT_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7, \
21)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_PORT_ID_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 21)
#define SET_TX_DESC_PORT_ID_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 21)
#define GET_TX_DESC_PORT_ID_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
21)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MULTIPLE_PORT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x7, 18)
#define SET_TX_DESC_MULTIPLE_PORT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x7, 18)
#define GET_TX_DESC_MULTIPLE_PORT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x7, \
18)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 17)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 17)
#define GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
17)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_RTS_SC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0xf, 13)
#define SET_TX_DESC_RTS_SC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 13)
#define GET_TX_DESC_RTS_SC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf, \
13)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0xf, 13)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 13)
#define GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf, \
13)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_RTS_SHORT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 12)
#define SET_TX_DESC_RTS_SHORT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 12)
#define GET_TX_DESC_RTS_SHORT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
12)
#define SET_TX_DESC_VCS_STBC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 10)
#define SET_TX_DESC_VCS_STBC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 10)
#define GET_TX_DESC_VCS_STBC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, \
10)
#define SET_TX_DESC_DATA_STBC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 8)
#define SET_TX_DESC_DATA_STBC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 8)
#define GET_TX_DESC_DATA_STBC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, 8)
#define SET_TX_DESC_DATA_LDPC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 7)
#define SET_TX_DESC_DATA_LDPC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 7)
#define GET_TX_DESC_DATA_LDPC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 7)
#define SET_TX_DESC_DATA_BW(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 5)
#define SET_TX_DESC_DATA_BW_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 5)
#define GET_TX_DESC_DATA_BW(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, 5)
#define SET_TX_DESC_DATA_SHORT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 4)
#define SET_TX_DESC_DATA_SHORT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 4)
#define GET_TX_DESC_DATA_SHORT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 4)
#define SET_TX_DESC_DATA_SC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0xf, 0)
#define SET_TX_DESC_DATA_SC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 0)
#define GET_TX_DESC_DATA_SC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf, 0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 30)
#define SET_TX_DESC_ANTSEL_D_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 30)
#define GET_TX_DESC_ANTSEL_D(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
30)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPD_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 30)
#define SET_TX_DESC_ANT_MAPD_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 30)
#define GET_TX_DESC_ANT_MAPD_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
30)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPC_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 30)
#define SET_TX_DESC_ANT_MAPC_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 30)
#define GET_TX_DESC_ANT_MAPC_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
30)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPD(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 28)
#define SET_TX_DESC_ANT_MAPD_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 28)
#define GET_TX_DESC_ANT_MAPD(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
28)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPC_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 28)
#define SET_TX_DESC_ANT_MAPC_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 28)
#define GET_TX_DESC_ANT_MAPC_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
28)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPB_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 28)
#define SET_TX_DESC_ANT_MAPB_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 28)
#define GET_TX_DESC_ANT_MAPB_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
28)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 26)
#define SET_TX_DESC_ANT_MAPC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 26)
#define GET_TX_DESC_ANT_MAPC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
26)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPB_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 26)
#define SET_TX_DESC_ANT_MAPB_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 26)
#define GET_TX_DESC_ANT_MAPB_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
26)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPA_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 26)
#define SET_TX_DESC_ANT_MAPA_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 26)
#define GET_TX_DESC_ANT_MAPA_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
26)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPB(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 24)
#define SET_TX_DESC_ANT_MAPB_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 24)
#define GET_TX_DESC_ANT_MAPB(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
24)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPA_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 24)
#define SET_TX_DESC_ANT_MAPA_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 24)
#define GET_TX_DESC_ANT_MAPA_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
24)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_D_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 24)
#define SET_TX_DESC_ANTSEL_D_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 24)
#define GET_TX_DESC_ANTSEL_D_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 22)
#define SET_TX_DESC_ANT_MAPA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 22)
#define GET_TX_DESC_ANT_MAPA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
22)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_C_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 22)
#define SET_TX_DESC_ANTSEL_C_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 22)
#define GET_TX_DESC_ANTSEL_C_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
22)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANTSEL_C(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 20)
#define SET_TX_DESC_ANTSEL_C_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 20)
#define GET_TX_DESC_ANTSEL_C(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
20)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_B_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0xf, 20)
#define SET_TX_DESC_ANTSEL_B_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0xf, 20)
#define GET_TX_DESC_ANTSEL_B_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0xf, \
20)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_B_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x7, 19)
#define SET_TX_DESC_ANTSEL_B_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x7, 19)
#define GET_TX_DESC_ANTSEL_B_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x7, \
19)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANTSEL_B(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 18)
#define SET_TX_DESC_ANTSEL_B_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 18)
#define GET_TX_DESC_ANTSEL_B(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
18)
#define SET_TX_DESC_ANTSEL_A(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 16)
#define SET_TX_DESC_ANTSEL_A_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 16)
#define GET_TX_DESC_ANTSEL_A(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
16)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_A_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0xf, 16)
#define SET_TX_DESC_ANTSEL_A_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0xf, 16)
#define GET_TX_DESC_ANTSEL_A_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0xf, \
16)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_A_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x7, 16)
#define SET_TX_DESC_ANTSEL_A_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x7, 16)
#define GET_TX_DESC_ANTSEL_A_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x7, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MBSSID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0xf, 12)
#define SET_TX_DESC_MBSSID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0xf, 12)
#define GET_TX_DESC_MBSSID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0xf, \
12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SW_DEFINE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0xfff, 0)
#define SET_TX_DESC_SW_DEFINE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0xfff, 0)
#define GET_TX_DESC_SW_DEFINE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, \
0xfff, 0)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_SWPS_SEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0xfff, 0)
#define SET_TX_DESC_SWPS_SEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0xfff, 0)
#define GET_TX_DESC_SWPS_SEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, \
0xfff, 0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xff, 24)
#define SET_TX_DESC_DMA_TXAGG_NUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xff, 24)
#define GET_TX_DESC_DMA_TXAGG_NUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xff, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_FINAL_DATA_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xff, 24)
#define SET_TX_DESC_FINAL_DATA_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xff, 24)
#define GET_TX_DESC_FINAL_DATA_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xff, \
24)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPD_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x3, 22)
#define SET_TX_DESC_ANT_MAPD_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x3, 22)
#define GET_TX_DESC_ANT_MAPD_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x3, \
22)
#define SET_TX_DESC_ANTSEL_EN_V2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x1, 21)
#define SET_TX_DESC_ANTSEL_EN_V2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1, 21)
#define GET_TX_DESC_ANTSEL_EN_V2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1, \
21)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NTX_MAP(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xf, 20)
#define SET_TX_DESC_NTX_MAP_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xf, 20)
#define GET_TX_DESC_NTX_MAP(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xf, \
20)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x1, 19)
#define SET_TX_DESC_ANTSEL_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1, 19)
#define GET_TX_DESC_ANTSEL_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1, \
19)
#define SET_TX_DESC_MBSSID_EX(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x7, 16)
#define SET_TX_DESC_MBSSID_EX_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x7, 16)
#define GET_TX_DESC_MBSSID_EX(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x7, \
16)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_MBSSID_EX_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x1, 16)
#define SET_TX_DESC_MBSSID_EX_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1, 16)
#define GET_TX_DESC_MBSSID_EX_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TX_BUFF_SIZE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xffff, 0)
#define SET_TX_DESC_TX_BUFF_SIZE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xffff, 0)
#define GET_TX_DESC_TX_BUFF_SIZE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, \
0xffff, 0)
#define SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xffff, 0)
#define SET_TX_DESC_TXDESC_CHECKSUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xffff, 0)
#define GET_TX_DESC_TXDESC_CHECKSUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, \
0xffff, 0)
#define SET_TX_DESC_TIMESTAMP(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xffff, 0)
#define SET_TX_DESC_TIMESTAMP_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xffff, 0)
#define GET_TX_DESC_TIMESTAMP(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, \
0xffff, 0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 31)
#define SET_TX_DESC_TXWIFI_CP_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 31)
#define GET_TX_DESC_TXWIFI_CP(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
31)
#define SET_TX_DESC_MAC_CP(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 30)
#define SET_TX_DESC_MAC_CP_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 30)
#define GET_TX_DESC_MAC_CP(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
30)
#define SET_TX_DESC_STW_PKTRE_DIS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 29)
#define SET_TX_DESC_STW_PKTRE_DIS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 29)
#define GET_TX_DESC_STW_PKTRE_DIS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
29)
#define SET_TX_DESC_STW_RB_DIS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 28)
#define SET_TX_DESC_STW_RB_DIS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 28)
#define GET_TX_DESC_STW_RB_DIS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
28)
#define SET_TX_DESC_STW_RATE_DIS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 27)
#define SET_TX_DESC_STW_RATE_DIS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 27)
#define GET_TX_DESC_STW_RATE_DIS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
27)
#define SET_TX_DESC_STW_ANT_DIS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 26)
#define SET_TX_DESC_STW_ANT_DIS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 26)
#define GET_TX_DESC_STW_ANT_DIS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
26)
#define SET_TX_DESC_STW_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 25)
#define SET_TX_DESC_STW_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 25)
#define GET_TX_DESC_STW_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
25)
#define SET_TX_DESC_SMH_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 24)
#define SET_TX_DESC_SMH_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 24)
#define GET_TX_DESC_SMH_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TAILPAGE_L(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xff, 24)
#define SET_TX_DESC_TAILPAGE_L_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xff, 24)
#define GET_TX_DESC_TAILPAGE_L(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xff, \
24)
#define SET_TX_DESC_SDIO_DMASEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xff, 16)
#define SET_TX_DESC_SDIO_DMASEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xff, 16)
#define GET_TX_DESC_SDIO_DMASEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xff, \
16)
#define SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xff, 16)
#define SET_TX_DESC_NEXTHEADPAGE_L_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xff, 16)
#define GET_TX_DESC_NEXTHEADPAGE_L(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xff, \
16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_EN_HWSEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 15)
#define SET_TX_DESC_EN_HWSEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 15)
#define GET_TX_DESC_EN_HWSEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
#define SET_TX_DESC_EN_HWEXSEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 14)
#define SET_TX_DESC_EN_HWEXSEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 14)
#define GET_TX_DESC_EN_HWEXSEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, \
14)
#endif
#if (HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_EN_HWSEQ_MODE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3, 14)
#define SET_TX_DESC_EN_HWSEQ_MODE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 14)
#define GET_TX_DESC_EN_HWSEQ_MODE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, \
14)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_DATA_RC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3f, 8)
#define SET_TX_DESC_DATA_RC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3f, 8)
#define GET_TX_DESC_DATA_RC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3f, \
8)
#define SET_TX_DESC_BAR_RTY_TH(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3, 6)
#define SET_TX_DESC_BAR_RTY_TH_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 6)
#define GET_TX_DESC_BAR_RTY_TH(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, 6)
#define SET_TX_DESC_RTS_RC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3f, 0)
#define SET_TX_DESC_RTS_RC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3f, 0)
#define GET_TX_DESC_RTS_RC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3f, \
0)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xf, 28)
#define SET_TX_DESC_TAILPAGE_H_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xf, 28)
#define GET_TX_DESC_TAILPAGE_H(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xf, \
28)
#define SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xf, 24)
#define SET_TX_DESC_NEXTHEADPAGE_H_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xf, 24)
#define GET_TX_DESC_NEXTHEADPAGE_H(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xf, \
24)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_FINAL_DATA_RATE_V1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xff, 24)
#define SET_TX_DESC_FINAL_DATA_RATE_V1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xff, 24)
#define GET_TX_DESC_FINAL_DATA_RATE_V1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xff, \
24)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SW_SEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xfff, 12)
#define SET_TX_DESC_SW_SEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xfff, 12)
#define GET_TX_DESC_SW_SEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, \
0xfff, 12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TXBF_PATH(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 11)
#define SET_TX_DESC_TXBF_PATH_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 11)
#define GET_TX_DESC_TXBF_PATH(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, \
11)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PADDING_LEN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x7ff, 0)
#define SET_TX_DESC_PADDING_LEN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x7ff, 0)
#define GET_TX_DESC_PADDING_LEN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, \
0x7ff, 0)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xff, 0)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xff, 0)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xff, \
0)
#endif
#if (HALMAC_8812F_SUPPORT)
/*WORD10*/
#define SET_TX_DESC_HT_DATA_SND(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 31)
#define SET_TX_DESC_HT_DATA_SND_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 31)
#define GET_TX_DESC_HT_DATA_SND(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
31)
#define SET_TX_DESC_SHCUT_CAM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x3f, 16)
#define SET_TX_DESC_SHCUT_CAM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x3f, 16)
#define GET_TX_DESC_SHCUT_CAM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, \
0x3f, 16)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MU_DATARATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0xff, 8)
#define SET_TX_DESC_MU_DATARATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0xff, 8)
#define GET_TX_DESC_MU_DATARATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, \
0xff, 8)
#define SET_TX_DESC_MU_RC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0xf, 4)
#define SET_TX_DESC_MU_RC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0xf, 4)
#define GET_TX_DESC_MU_RC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0xf, \
4)
#endif
#if (HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NDPA_RATE_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 3)
#define SET_TX_DESC_NDPA_RATE_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 3)
#define GET_TX_DESC_NDPA_RATE_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
3)
#define SET_TX_DESC_HW_NDPA_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 2)
#define SET_TX_DESC_HW_NDPA_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 2)
#define GET_TX_DESC_HW_NDPA_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
2)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SND_PKT_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x3, 0)
#define SET_TX_DESC_SND_PKT_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x3, 0)
#define GET_TX_DESC_SND_PKT_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x3, \
0)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_buffer_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_BUFFER_AP_H_
#define _HALMAC_TX_DESC_BUFFER_AP_H_
#if (HALMAC_8814B_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_BUFFER_RDG_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 31)
#define SET_TX_DESC_BUFFER_RDG_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 31)
#define GET_TX_DESC_BUFFER_RDG_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
31)
#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 30)
#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 30)
#define GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
30)
#define SET_TX_DESC_BUFFER_AGG_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1, 29)
#define SET_TX_DESC_BUFFER_AGG_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1, 29)
#define GET_TX_DESC_BUFFER_AGG_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1, \
29)
#define SET_TX_DESC_BUFFER_PKT_OFFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0x1f, 24)
#define SET_TX_DESC_BUFFER_PKT_OFFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0x1f, 24)
#define GET_TX_DESC_BUFFER_PKT_OFFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0x1f, \
24)
#define SET_TX_DESC_BUFFER_OFFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0xff, 16)
#define SET_TX_DESC_BUFFER_OFFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0xff, 16)
#define GET_TX_DESC_BUFFER_OFFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, 0xff, \
16)
#define SET_TX_DESC_BUFFER_TXPKTSIZE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword0, \
value, 0xffff, 0)
#define SET_TX_DESC_BUFFER_TXPKTSIZE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword0, value, 0xffff, 0)
#define GET_TX_DESC_BUFFER_TXPKTSIZE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword0, \
0xffff, 0)
/*TXDESC_WORD1*/
#define SET_TX_DESC_BUFFER_USERATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 31)
#define SET_TX_DESC_BUFFER_USERATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 31)
#define GET_TX_DESC_BUFFER_USERATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
31)
#define SET_TX_DESC_BUFFER_AMSDU(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 30)
#define SET_TX_DESC_BUFFER_AMSDU_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 30)
#define GET_TX_DESC_BUFFER_AMSDU(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
30)
#define SET_TX_DESC_BUFFER_EN_HWSEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 29)
#define SET_TX_DESC_BUFFER_EN_HWSEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 29)
#define GET_TX_DESC_BUFFER_EN_HWSEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
29)
#define SET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 28)
#define SET_TX_DESC_BUFFER_EN_HWEXSEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 28)
#define GET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
28)
#define SET_TX_DESC_BUFFER_SW_SEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0xfff, 16)
#define SET_TX_DESC_BUFFER_SW_SEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0xfff, 16)
#define GET_TX_DESC_BUFFER_SW_SEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, \
0xfff, 16)
#define SET_TX_DESC_BUFFER_DROP_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x3, 14)
#define SET_TX_DESC_BUFFER_DROP_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x3, 14)
#define GET_TX_DESC_BUFFER_DROP_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x3, \
14)
#define SET_TX_DESC_BUFFER_MOREDATA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1, 13)
#define SET_TX_DESC_BUFFER_MOREDATA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1, 13)
#define GET_TX_DESC_BUFFER_MOREDATA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1, \
13)
#define SET_TX_DESC_BUFFER_QSEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0x1f, 8)
#define SET_TX_DESC_BUFFER_QSEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0x1f, 8)
#define GET_TX_DESC_BUFFER_QSEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0x1f, \
8)
#define SET_TX_DESC_BUFFER_MACID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword1, \
value, 0xff, 0)
#define SET_TX_DESC_BUFFER_MACID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword1, value, 0xff, 0)
#define GET_TX_DESC_BUFFER_MACID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword1, 0xff, \
0)
/*TXDESC_WORD2*/
#define SET_TX_DESC_BUFFER_CHK_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 31)
#define SET_TX_DESC_BUFFER_CHK_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 31)
#define GET_TX_DESC_BUFFER_CHK_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
31)
#define SET_TX_DESC_BUFFER_DISQSELSEQ(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 30)
#define SET_TX_DESC_BUFFER_DISQSELSEQ_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 30)
#define GET_TX_DESC_BUFFER_DISQSELSEQ(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
30)
#define SET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x3, 28)
#define SET_TX_DESC_BUFFER_SND_PKT_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x3, 28)
#define GET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x3, \
28)
#define SET_TX_DESC_BUFFER_DMA_PRI(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x1, 27)
#define SET_TX_DESC_BUFFER_DMA_PRI_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x1, 27)
#define GET_TX_DESC_BUFFER_DMA_PRI(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x1, \
27)
#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0x7, 24)
#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0x7, 24)
#define GET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0x7, \
24)
#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0xff, 16)
#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0xff, 16)
#define GET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, 0xff, \
16)
#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword2, \
value, 0xffff, 0)
#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword2, value, 0xffff, 0)
#define GET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword2, \
0xffff, 0)
/*TXDESC_WORD3*/
#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x7fff, 16)
#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x7fff, 16)
#define GET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, \
0x7fff, 16)
#define SET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1f, 11)
#define SET_TX_DESC_BUFFER_CHANNEL_DMA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 11)
#define GET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
11)
#define SET_TX_DESC_BUFFER_MBSSID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0xf, 7)
#define SET_TX_DESC_BUFFER_MBSSID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0xf, 7)
#define GET_TX_DESC_BUFFER_MBSSID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0xf, 7)
#define SET_TX_DESC_BUFFER_BK(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1, 6)
#define SET_TX_DESC_BUFFER_BK_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1, 6)
#define GET_TX_DESC_BUFFER_BK(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1, 6)
#define SET_TX_DESC_BUFFER_WHEADER_LEN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword3, \
value, 0x1f, 0)
#define SET_TX_DESC_BUFFER_WHEADER_LEN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword3, value, 0x1f, 0)
#define GET_TX_DESC_BUFFER_WHEADER_LEN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword3, 0x1f, \
0)
/*TXDESC_WORD4*/
#define SET_TX_DESC_BUFFER_TRY_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1, 26)
#define SET_TX_DESC_BUFFER_TRY_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 26)
#define GET_TX_DESC_BUFFER_TRY_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, \
26)
#define SET_TX_DESC_BUFFER_DATA_BW(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x3, 24)
#define SET_TX_DESC_BUFFER_DATA_BW_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x3, 24)
#define GET_TX_DESC_BUFFER_DATA_BW(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x3, \
24)
#define SET_TX_DESC_BUFFER_DATA_SHORT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1, 23)
#define SET_TX_DESC_BUFFER_DATA_SHORT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 23)
#define GET_TX_DESC_BUFFER_DATA_SHORT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, \
23)
#define SET_TX_DESC_BUFFER_DATARATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x7f, 16)
#define SET_TX_DESC_BUFFER_DATARATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x7f, 16)
#define GET_TX_DESC_BUFFER_DATARATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x7f, \
16)
#define SET_TX_DESC_BUFFER_TXBF_PATH(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x1, 11)
#define SET_TX_DESC_BUFFER_TXBF_PATH_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x1, 11)
#define GET_TX_DESC_BUFFER_TXBF_PATH(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, 0x1, \
11)
#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword4, \
value, 0x7ff, 0)
#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword4, value, 0x7ff, 0)
#define GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword4, \
0x7ff, 0)
/*TXDESC_WORD5*/
#define SET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 31)
#define SET_TX_DESC_BUFFER_RTY_LMT_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 31)
#define GET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
31)
#define SET_TX_DESC_BUFFER_HW_RTS_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 30)
#define SET_TX_DESC_BUFFER_HW_RTS_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 30)
#define GET_TX_DESC_BUFFER_HW_RTS_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
30)
#define SET_TX_DESC_BUFFER_RTS_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 29)
#define SET_TX_DESC_BUFFER_RTS_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 29)
#define GET_TX_DESC_BUFFER_RTS_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
29)
#define SET_TX_DESC_BUFFER_CTS2SELF(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 28)
#define SET_TX_DESC_BUFFER_CTS2SELF_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 28)
#define GET_TX_DESC_BUFFER_CTS2SELF(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
28)
#define SET_TX_DESC_BUFFER_TAILPAGE_H(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0xf, 24)
#define SET_TX_DESC_BUFFER_TAILPAGE_H_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0xf, 24)
#define GET_TX_DESC_BUFFER_TAILPAGE_H(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xf, \
24)
#define SET_TX_DESC_BUFFER_TAILPAGE_L(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0xff, 16)
#define SET_TX_DESC_BUFFER_TAILPAGE_L_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0xff, 16)
#define GET_TX_DESC_BUFFER_TAILPAGE_L(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0xff, \
16)
#define SET_TX_DESC_BUFFER_NAVUSEHDR(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 15)
#define SET_TX_DESC_BUFFER_NAVUSEHDR_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 15)
#define GET_TX_DESC_BUFFER_NAVUSEHDR(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
15)
#define SET_TX_DESC_BUFFER_BMC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 14)
#define SET_TX_DESC_BUFFER_BMC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 14)
#define GET_TX_DESC_BUFFER_BMC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, \
14)
#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3f, 8)
#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3f, 8)
#define GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3f, \
8)
#define SET_TX_DESC_BUFFER_HW_AES_IV(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 7)
#define SET_TX_DESC_BUFFER_HW_AES_IV_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 7)
#define GET_TX_DESC_BUFFER_HW_AES_IV(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 7)
#define SET_TX_DESC_BUFFER_BT_NULL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 3)
#define SET_TX_DESC_BUFFER_BT_NULL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 3)
#define GET_TX_DESC_BUFFER_BT_NULL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 3)
#define SET_TX_DESC_BUFFER_EN_DESC_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x1, 2)
#define SET_TX_DESC_BUFFER_EN_DESC_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x1, 2)
#define GET_TX_DESC_BUFFER_EN_DESC_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x1, 2)
#define SET_TX_DESC_BUFFER_SECTYPE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword5, \
value, 0x3, 0)
#define SET_TX_DESC_BUFFER_SECTYPE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword5, value, 0x3, 0)
#define GET_TX_DESC_BUFFER_SECTYPE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword5, 0x3, 0)
/*TXDESC_WORD6*/
#define SET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x7, 29)
#define SET_TX_DESC_BUFFER_MULTIPLE_PORT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x7, 29)
#define GET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x7, \
29)
#define SET_TX_DESC_BUFFER_POLLUTED(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1, 28)
#define SET_TX_DESC_BUFFER_POLLUTED_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 28)
#define GET_TX_DESC_BUFFER_POLLUTED(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1, \
28)
#define SET_TX_DESC_BUFFER_NULL_1(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1, 27)
#define SET_TX_DESC_BUFFER_NULL_1_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 27)
#define GET_TX_DESC_BUFFER_NULL_1(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1, \
27)
#define SET_TX_DESC_BUFFER_NULL_0(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1, 26)
#define SET_TX_DESC_BUFFER_NULL_0_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 26)
#define GET_TX_DESC_BUFFER_NULL_0(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1, \
26)
#define SET_TX_DESC_BUFFER_TRI_FRAME(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1, 25)
#define SET_TX_DESC_BUFFER_TRI_FRAME_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 25)
#define GET_TX_DESC_BUFFER_TRI_FRAME(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1, \
25)
#define SET_TX_DESC_BUFFER_SPE_RPT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1, 24)
#define SET_TX_DESC_BUFFER_SPE_RPT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 24)
#define GET_TX_DESC_BUFFER_SPE_RPT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1, \
24)
#define SET_TX_DESC_BUFFER_FTM_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1, 23)
#define SET_TX_DESC_BUFFER_FTM_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1, 23)
#define GET_TX_DESC_BUFFER_FTM_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x1, \
23)
#define SET_TX_DESC_BUFFER_MU_DATARATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x7f, 16)
#define SET_TX_DESC_BUFFER_MU_DATARATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x7f, 16)
#define GET_TX_DESC_BUFFER_MU_DATARATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x7f, \
16)
#define SET_TX_DESC_BUFFER_CCA_RTS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 14)
#define SET_TX_DESC_BUFFER_CCA_RTS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 14)
#define GET_TX_DESC_BUFFER_CCA_RTS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
14)
#define SET_TX_DESC_BUFFER_NDPA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 12)
#define SET_TX_DESC_BUFFER_NDPA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 12)
#define GET_TX_DESC_BUFFER_NDPA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, \
12)
#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x3, 9)
#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x3, 9)
#define GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, 0x3, 9)
#define SET_TX_DESC_BUFFER_P_AID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword6, \
value, 0x1ff, 0)
#define SET_TX_DESC_BUFFER_P_AID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword6, value, 0x1ff, 0)
#define GET_TX_DESC_BUFFER_P_AID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword6, \
0x1ff, 0)
/*TXDESC_WORD7*/
#define SET_TX_DESC_BUFFER_SW_DEFINE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xfff, 16)
#define SET_TX_DESC_BUFFER_SW_DEFINE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xfff, 16)
#define GET_TX_DESC_BUFFER_SW_DEFINE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, \
0xfff, 16)
#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x1, 9)
#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1, 9)
#define GET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1, 9)
#define SET_TX_DESC_BUFFER_CTRL_CNT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0xf, 5)
#define SET_TX_DESC_BUFFER_CTRL_CNT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0xf, 5)
#define GET_TX_DESC_BUFFER_CTRL_CNT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0xf, 5)
#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword7, \
value, 0x1f, 0)
#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword7, value, 0x1f, 0)
#define GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword7, 0x1f, \
0)
/*TXDESC_WORD8*/
#define SET_TX_DESC_BUFFER_PATH_MAPA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3, 30)
#define SET_TX_DESC_BUFFER_PATH_MAPA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 30)
#define GET_TX_DESC_BUFFER_PATH_MAPA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, \
30)
#define SET_TX_DESC_BUFFER_PATH_MAPB(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3, 28)
#define SET_TX_DESC_BUFFER_PATH_MAPB_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 28)
#define GET_TX_DESC_BUFFER_PATH_MAPB(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, \
28)
#define SET_TX_DESC_BUFFER_PATH_MAPC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3, 26)
#define SET_TX_DESC_BUFFER_PATH_MAPC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 26)
#define GET_TX_DESC_BUFFER_PATH_MAPC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, \
26)
#define SET_TX_DESC_BUFFER_PATH_MAPD(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x3, 24)
#define SET_TX_DESC_BUFFER_PATH_MAPD_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x3, 24)
#define GET_TX_DESC_BUFFER_PATH_MAPD(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x3, \
24)
#define SET_TX_DESC_BUFFER_ANTSEL_A(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xf, 20)
#define SET_TX_DESC_BUFFER_ANTSEL_A_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 20)
#define GET_TX_DESC_BUFFER_ANTSEL_A(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, \
20)
#define SET_TX_DESC_BUFFER_ANTSEL_B(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xf, 16)
#define SET_TX_DESC_BUFFER_ANTSEL_B_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 16)
#define GET_TX_DESC_BUFFER_ANTSEL_B(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, \
16)
#define SET_TX_DESC_BUFFER_ANTSEL_C(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xf, 12)
#define SET_TX_DESC_BUFFER_ANTSEL_C_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 12)
#define GET_TX_DESC_BUFFER_ANTSEL_C(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, \
12)
#define SET_TX_DESC_BUFFER_ANTSEL_D(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xf, 8)
#define SET_TX_DESC_BUFFER_ANTSEL_D_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 8)
#define GET_TX_DESC_BUFFER_ANTSEL_D(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, 8)
#define SET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0xf, 4)
#define SET_TX_DESC_BUFFER_NTX_PATH_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0xf, 4)
#define GET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0xf, 4)
#define SET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x1, 3)
#define SET_TX_DESC_BUFFER_ANTLSEL_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x1, 3)
#define GET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x1, 3)
#define SET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword8, \
value, 0x7, 0)
#define SET_TX_DESC_BUFFER_AMPDU_DENSITY_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword8, value, 0x7, 0)
#define GET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword8, 0x7, 0)
/*TXDESC_WORD9*/
#define SET_TX_DESC_BUFFER_VCS_STBC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x3, 30)
#define SET_TX_DESC_BUFFER_VCS_STBC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x3, 30)
#define GET_TX_DESC_BUFFER_VCS_STBC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x3, \
30)
#define SET_TX_DESC_BUFFER_DATA_STBC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x3, 28)
#define SET_TX_DESC_BUFFER_DATA_STBC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x3, 28)
#define GET_TX_DESC_BUFFER_DATA_STBC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x3, \
28)
#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xf, 24)
#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xf, 24)
#define GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xf, \
24)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 23)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 23)
#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, \
23)
#define SET_TX_DESC_BUFFER_MHR_CP(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 22)
#define SET_TX_DESC_BUFFER_MHR_CP_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 22)
#define GET_TX_DESC_BUFFER_MHR_CP(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, \
22)
#define SET_TX_DESC_BUFFER_SMH_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 21)
#define SET_TX_DESC_BUFFER_SMH_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 21)
#define GET_TX_DESC_BUFFER_SMH_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, \
21)
#define SET_TX_DESC_BUFFER_RTSRATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1f, 16)
#define SET_TX_DESC_BUFFER_RTSRATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1f, 16)
#define GET_TX_DESC_BUFFER_RTSRATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1f, \
16)
#define SET_TX_DESC_BUFFER_SMH_CAM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0xff, 8)
#define SET_TX_DESC_BUFFER_SMH_CAM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0xff, 8)
#define GET_TX_DESC_BUFFER_SMH_CAM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0xff, \
8)
#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 7)
#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 7)
#define GET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 7)
#define SET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 6)
#define SET_TX_DESC_BUFFER_ARFR_HT_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 6)
#define GET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 6)
#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 5)
#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 5)
#define GET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 5)
#define SET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 4)
#define SET_TX_DESC_BUFFER_ARFR_CCK_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 4)
#define GET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 4)
#define SET_TX_DESC_BUFFER_RTS_SHORT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 3)
#define SET_TX_DESC_BUFFER_RTS_SHORT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 3)
#define GET_TX_DESC_BUFFER_RTS_SHORT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 3)
#define SET_TX_DESC_BUFFER_DISDATAFB(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 2)
#define SET_TX_DESC_BUFFER_DISDATAFB_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 2)
#define GET_TX_DESC_BUFFER_DISDATAFB(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 2)
#define SET_TX_DESC_BUFFER_DISRTSFB(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 1)
#define SET_TX_DESC_BUFFER_DISRTSFB_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 1)
#define GET_TX_DESC_BUFFER_DISRTSFB(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 1)
#define SET_TX_DESC_BUFFER_EXT_EDCA(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword9, \
value, 0x1, 0)
#define SET_TX_DESC_BUFFER_EXT_EDCA_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword9, value, 0x1, 0)
#define GET_TX_DESC_BUFFER_EXT_EDCA(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword9, 0x1, 0)
/*TXDESC_WORD10*/
#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0xff, 24)
#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0xff, 24)
#define GET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, \
0xff, 24)
#define SET_TX_DESC_BUFFER_SPECIAL_CW(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 23)
#define SET_TX_DESC_BUFFER_SPECIAL_CW_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 23)
#define GET_TX_DESC_BUFFER_SPECIAL_CW(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
23)
#define SET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 22)
#define SET_TX_DESC_BUFFER_RDG_NAV_EXT_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 22)
#define GET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
22)
#define SET_TX_DESC_BUFFER_RAW(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 21)
#define SET_TX_DESC_BUFFER_RAW_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 21)
#define GET_TX_DESC_BUFFER_RAW(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
21)
#define SET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1f, 16)
#define SET_TX_DESC_BUFFER_MAX_AGG_NUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1f, 16)
#define GET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, \
0x1f, 16)
#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0xff, 8)
#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0xff, 8)
#define GET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, \
0xff, 8)
#define SET_TX_DESC_BUFFER_GF(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 7)
#define SET_TX_DESC_BUFFER_GF_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 7)
#define GET_TX_DESC_BUFFER_GF(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
7)
#define SET_TX_DESC_BUFFER_MOREFRAG(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 6)
#define SET_TX_DESC_BUFFER_MOREFRAG_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 6)
#define GET_TX_DESC_BUFFER_MOREFRAG(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
6)
#define SET_TX_DESC_BUFFER_NOACM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 5)
#define SET_TX_DESC_BUFFER_NOACM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 5)
#define GET_TX_DESC_BUFFER_NOACM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
5)
#define SET_TX_DESC_BUFFER_HTC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 4)
#define SET_TX_DESC_BUFFER_HTC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 4)
#define GET_TX_DESC_BUFFER_HTC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
4)
#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 3)
#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 3)
#define GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
3)
#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x1, 2)
#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x1, 2)
#define GET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x1, \
2)
#define SET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword10, \
value, 0x3, 0)
#define SET_TX_DESC_BUFFER_HW_SSN_SEL_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword10, value, 0x3, 0)
#define GET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword10, 0x3, \
0)
/*TXDESC_WORD11*/
#define SET_TX_DESC_BUFFER_ADDR_CAM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0xff, 24)
#define SET_TX_DESC_BUFFER_ADDR_CAM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0xff, 24)
#define GET_TX_DESC_BUFFER_ADDR_CAM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, \
0xff, 24)
#define SET_TX_DESC_BUFFER_SND_TARGET(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0xff, 16)
#define SET_TX_DESC_BUFFER_SND_TARGET_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0xff, 16)
#define GET_TX_DESC_BUFFER_SND_TARGET(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, \
0xff, 16)
#define SET_TX_DESC_BUFFER_DATA_LDPC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0x1, 15)
#define SET_TX_DESC_BUFFER_DATA_LDPC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0x1, 15)
#define GET_TX_DESC_BUFFER_DATA_LDPC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0x1, \
15)
#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0x1, 14)
#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0x1, 14)
#define GET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0x1, \
14)
#define SET_TX_DESC_BUFFER_G_ID(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0x3f, 8)
#define SET_TX_DESC_BUFFER_G_ID_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0x3f, 8)
#define GET_TX_DESC_BUFFER_G_ID(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, \
0x3f, 8)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0xf, 4)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0xf, 4)
#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0xf, \
4)
#define SET_TX_DESC_BUFFER_DATA_SC(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword11, \
value, 0xf, 0)
#define SET_TX_DESC_BUFFER_DATA_SC_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword11, value, 0xf, 0)
#define GET_TX_DESC_BUFFER_DATA_SC(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword11, 0xf, \
0)
/*TXDESC_WORD12*/
#define SET_TX_DESC_BUFFER_LEN1_L(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword12, \
value, 0x7f, 17)
#define SET_TX_DESC_BUFFER_LEN1_L_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword12, value, 0x7f, 17)
#define GET_TX_DESC_BUFFER_LEN1_L(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword12, \
0x7f, 17)
#define SET_TX_DESC_BUFFER_LEN0(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword12, \
value, 0x1fff, 4)
#define SET_TX_DESC_BUFFER_LEN0_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword12, value, 0x1fff, 4)
#define GET_TX_DESC_BUFFER_LEN0(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword12, \
0x1fff, 4)
#define SET_TX_DESC_BUFFER_PKT_NUM(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword12, \
value, 0xf, 0)
#define SET_TX_DESC_BUFFER_PKT_NUM_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword12, value, 0xf, 0)
#define GET_TX_DESC_BUFFER_PKT_NUM(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword12, 0xf, \
0)
/*TXDESC_WORD13*/
#define SET_TX_DESC_BUFFER_LEN3(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword13, \
value, 0x1fff, 19)
#define SET_TX_DESC_BUFFER_LEN3_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword13, value, 0x1fff, 19)
#define GET_TX_DESC_BUFFER_LEN3(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword13, \
0x1fff, 19)
#define SET_TX_DESC_BUFFER_LEN2(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword13, \
value, 0x1fff, 6)
#define SET_TX_DESC_BUFFER_LEN2_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword13, value, 0x1fff, 6)
#define GET_TX_DESC_BUFFER_LEN2(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword13, \
0x1fff, 6)
#define SET_TX_DESC_BUFFER_LEN1_H(txdesc, value) \
HALMAC_SET_DESC_FIELD_CLR(((struct halmac_tx_desc *)txdesc)->dword13, \
value, 0x3f, 0)
#define SET_TX_DESC_BUFFER_LEN1_H_NO_CLR(txdesc, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc)->dword13, value, 0x3f, 0)
#define GET_TX_DESC_BUFFER_LEN1_H(txdesc) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc)->dword13, \
0x3f, 0)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_buffer_chip.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_BUFFER_CHIP_H_
#define _HALMAC_TX_DESC_BUFFER_CHIP_H_
#if (HALMAC_8814B_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_BUFFER_RDG_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RDG_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_RDG_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_RDG_EN(txdesc)
#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL_8814B(txdesc) \
GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_BUFFER_AGG_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_AGG_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_AGG_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_AGG_EN(txdesc)
#define SET_TX_DESC_BUFFER_PKT_OFFSET_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_BUFFER_PKT_OFFSET_8814B(txdesc) \
GET_TX_DESC_BUFFER_PKT_OFFSET(txdesc)
#define SET_TX_DESC_BUFFER_OFFSET_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_OFFSET(txdesc, value)
#define GET_TX_DESC_BUFFER_OFFSET_8814B(txdesc) \
GET_TX_DESC_BUFFER_OFFSET(txdesc)
#define SET_TX_DESC_BUFFER_TXPKTSIZE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_BUFFER_TXPKTSIZE_8814B(txdesc) \
GET_TX_DESC_BUFFER_TXPKTSIZE(txdesc)
/*TXDESC_WORD1*/
#define SET_TX_DESC_BUFFER_USERATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_USERATE(txdesc, value)
#define GET_TX_DESC_BUFFER_USERATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_USERATE(txdesc)
#define SET_TX_DESC_BUFFER_AMSDU_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_AMSDU(txdesc, value)
#define GET_TX_DESC_BUFFER_AMSDU_8814B(txdesc) GET_TX_DESC_BUFFER_AMSDU(txdesc)
#define SET_TX_DESC_BUFFER_EN_HWSEQ_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_BUFFER_EN_HWSEQ_8814B(txdesc) \
GET_TX_DESC_BUFFER_EN_HWSEQ(txdesc)
#define SET_TX_DESC_BUFFER_EN_HWEXSEQ_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_BUFFER_EN_HWEXSEQ_8814B(txdesc) \
GET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_BUFFER_SW_SEQ_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SW_SEQ(txdesc, value)
#define GET_TX_DESC_BUFFER_SW_SEQ_8814B(txdesc) \
GET_TX_DESC_BUFFER_SW_SEQ(txdesc)
#define SET_TX_DESC_BUFFER_DROP_ID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DROP_ID(txdesc, value)
#define GET_TX_DESC_BUFFER_DROP_ID_8814B(txdesc) \
GET_TX_DESC_BUFFER_DROP_ID(txdesc)
#define SET_TX_DESC_BUFFER_MOREDATA_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MOREDATA(txdesc, value)
#define GET_TX_DESC_BUFFER_MOREDATA_8814B(txdesc) \
GET_TX_DESC_BUFFER_MOREDATA(txdesc)
#define SET_TX_DESC_BUFFER_QSEL_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_QSEL(txdesc, value)
#define GET_TX_DESC_BUFFER_QSEL_8814B(txdesc) GET_TX_DESC_BUFFER_QSEL(txdesc)
#define SET_TX_DESC_BUFFER_MACID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MACID(txdesc, value)
#define GET_TX_DESC_BUFFER_MACID_8814B(txdesc) GET_TX_DESC_BUFFER_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_BUFFER_CHK_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_CHK_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_CHK_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_CHK_EN(txdesc)
#define SET_TX_DESC_BUFFER_DISQSELSEQ_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_BUFFER_DISQSELSEQ_8814B(txdesc) \
GET_TX_DESC_BUFFER_DISQSELSEQ(txdesc)
#define SET_TX_DESC_BUFFER_SND_PKT_SEL_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc, value)
#define GET_TX_DESC_BUFFER_SND_PKT_SEL_8814B(txdesc) \
GET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc)
#define SET_TX_DESC_BUFFER_DMA_PRI_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DMA_PRI(txdesc, value)
#define GET_TX_DESC_BUFFER_DMA_PRI_8814B(txdesc) \
GET_TX_DESC_BUFFER_DMA_PRI(txdesc)
#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc, value)
#define GET_TX_DESC_BUFFER_MAX_AMSDU_MODE_8814B(txdesc) \
GET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc)
#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_BUFFER_DMA_TXAGG_NUM_8814B(txdesc) \
GET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_BUFFER_TXDESC_CHECKSUM_8814B(txdesc) \
GET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc, value)
#define GET_TX_DESC_BUFFER_OFFLOAD_SIZE_8814B(txdesc) \
GET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc)
#define SET_TX_DESC_BUFFER_CHANNEL_DMA_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc, value)
#define GET_TX_DESC_BUFFER_CHANNEL_DMA_8814B(txdesc) \
GET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc)
#define SET_TX_DESC_BUFFER_MBSSID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MBSSID(txdesc, value)
#define GET_TX_DESC_BUFFER_MBSSID_8814B(txdesc) \
GET_TX_DESC_BUFFER_MBSSID(txdesc)
#define SET_TX_DESC_BUFFER_BK_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_BK(txdesc, value)
#define GET_TX_DESC_BUFFER_BK_8814B(txdesc) GET_TX_DESC_BUFFER_BK(txdesc)
#define SET_TX_DESC_BUFFER_WHEADER_LEN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_BUFFER_WHEADER_LEN_8814B(txdesc) \
GET_TX_DESC_BUFFER_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_BUFFER_TRY_RATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TRY_RATE(txdesc, value)
#define GET_TX_DESC_BUFFER_TRY_RATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_TRY_RATE(txdesc)
#define SET_TX_DESC_BUFFER_DATA_BW_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATA_BW(txdesc, value)
#define GET_TX_DESC_BUFFER_DATA_BW_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATA_BW(txdesc)
#define SET_TX_DESC_BUFFER_DATA_SHORT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_BUFFER_DATA_SHORT_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATA_SHORT(txdesc)
#define SET_TX_DESC_BUFFER_DATARATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATARATE(txdesc, value)
#define GET_TX_DESC_BUFFER_DATARATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATARATE(txdesc)
#define SET_TX_DESC_BUFFER_TXBF_PATH_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_BUFFER_TXBF_PATH_8814B(txdesc) \
GET_TX_DESC_BUFFER_TXBF_PATH(txdesc)
#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET_8814B(txdesc) \
GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_BUFFER_RTY_LMT_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_RTY_LMT_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_BUFFER_HW_RTS_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_HW_RTS_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_HW_RTS_EN(txdesc)
#define SET_TX_DESC_BUFFER_RTS_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RTS_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_RTS_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_RTS_EN(txdesc)
#define SET_TX_DESC_BUFFER_CTS2SELF_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_CTS2SELF(txdesc, value)
#define GET_TX_DESC_BUFFER_CTS2SELF_8814B(txdesc) \
GET_TX_DESC_BUFFER_CTS2SELF(txdesc)
#define SET_TX_DESC_BUFFER_TAILPAGE_H_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_BUFFER_TAILPAGE_H_8814B(txdesc) \
GET_TX_DESC_BUFFER_TAILPAGE_H(txdesc)
#define SET_TX_DESC_BUFFER_TAILPAGE_L_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_BUFFER_TAILPAGE_L_8814B(txdesc) \
GET_TX_DESC_BUFFER_TAILPAGE_L(txdesc)
#define SET_TX_DESC_BUFFER_NAVUSEHDR_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_BUFFER_NAVUSEHDR_8814B(txdesc) \
GET_TX_DESC_BUFFER_NAVUSEHDR(txdesc)
#define SET_TX_DESC_BUFFER_BMC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_BMC(txdesc, value)
#define GET_TX_DESC_BUFFER_BMC_8814B(txdesc) GET_TX_DESC_BUFFER_BMC(txdesc)
#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT_8814B(txdesc) \
GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_BUFFER_HW_AES_IV_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_BUFFER_HW_AES_IV_8814B(txdesc) \
GET_TX_DESC_BUFFER_HW_AES_IV(txdesc)
#define SET_TX_DESC_BUFFER_BT_NULL_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_BT_NULL(txdesc, value)
#define GET_TX_DESC_BUFFER_BT_NULL_8814B(txdesc) \
GET_TX_DESC_BUFFER_BT_NULL(txdesc)
#define SET_TX_DESC_BUFFER_EN_DESC_ID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_BUFFER_EN_DESC_ID_8814B(txdesc) \
GET_TX_DESC_BUFFER_EN_DESC_ID(txdesc)
#define SET_TX_DESC_BUFFER_SECTYPE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SECTYPE(txdesc, value)
#define GET_TX_DESC_BUFFER_SECTYPE_8814B(txdesc) \
GET_TX_DESC_BUFFER_SECTYPE(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_BUFFER_MULTIPLE_PORT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_BUFFER_MULTIPLE_PORT_8814B(txdesc) \
GET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_BUFFER_POLLUTED_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_POLLUTED(txdesc, value)
#define GET_TX_DESC_BUFFER_POLLUTED_8814B(txdesc) \
GET_TX_DESC_BUFFER_POLLUTED(txdesc)
#define SET_TX_DESC_BUFFER_NULL_1_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_NULL_1(txdesc, value)
#define GET_TX_DESC_BUFFER_NULL_1_8814B(txdesc) \
GET_TX_DESC_BUFFER_NULL_1(txdesc)
#define SET_TX_DESC_BUFFER_NULL_0_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_NULL_0(txdesc, value)
#define GET_TX_DESC_BUFFER_NULL_0_8814B(txdesc) \
GET_TX_DESC_BUFFER_NULL_0(txdesc)
#define SET_TX_DESC_BUFFER_TRI_FRAME_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_BUFFER_TRI_FRAME_8814B(txdesc) \
GET_TX_DESC_BUFFER_TRI_FRAME(txdesc)
#define SET_TX_DESC_BUFFER_SPE_RPT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SPE_RPT(txdesc, value)
#define GET_TX_DESC_BUFFER_SPE_RPT_8814B(txdesc) \
GET_TX_DESC_BUFFER_SPE_RPT(txdesc)
#define SET_TX_DESC_BUFFER_FTM_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_FTM_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_FTM_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_FTM_EN(txdesc)
#define SET_TX_DESC_BUFFER_MU_DATARATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MU_DATARATE(txdesc, value)
#define GET_TX_DESC_BUFFER_MU_DATARATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_MU_DATARATE(txdesc)
#define SET_TX_DESC_BUFFER_CCA_RTS_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_CCA_RTS(txdesc, value)
#define GET_TX_DESC_BUFFER_CCA_RTS_8814B(txdesc) \
GET_TX_DESC_BUFFER_CCA_RTS(txdesc)
#define SET_TX_DESC_BUFFER_NDPA_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_NDPA(txdesc, value)
#define GET_TX_DESC_BUFFER_NDPA_8814B(txdesc) GET_TX_DESC_BUFFER_NDPA(txdesc)
#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc, value)
#define GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE_8814B(txdesc) \
GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc)
#define SET_TX_DESC_BUFFER_P_AID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_P_AID(txdesc, value)
#define GET_TX_DESC_BUFFER_P_AID_8814B(txdesc) GET_TX_DESC_BUFFER_P_AID(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_BUFFER_SW_DEFINE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_BUFFER_SW_DEFINE_8814B(txdesc) \
GET_TX_DESC_BUFFER_SW_DEFINE(txdesc)
#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc, value)
#define GET_TX_DESC_BUFFER_CTRL_CNT_VALID_8814B(txdesc) \
GET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc)
#define SET_TX_DESC_BUFFER_CTRL_CNT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_CTRL_CNT(txdesc, value)
#define GET_TX_DESC_BUFFER_CTRL_CNT_8814B(txdesc) \
GET_TX_DESC_BUFFER_CTRL_CNT(txdesc)
#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_BUFFER_PATH_MAPA_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_PATH_MAPA(txdesc, value)
#define GET_TX_DESC_BUFFER_PATH_MAPA_8814B(txdesc) \
GET_TX_DESC_BUFFER_PATH_MAPA(txdesc)
#define SET_TX_DESC_BUFFER_PATH_MAPB_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_PATH_MAPB(txdesc, value)
#define GET_TX_DESC_BUFFER_PATH_MAPB_8814B(txdesc) \
GET_TX_DESC_BUFFER_PATH_MAPB(txdesc)
#define SET_TX_DESC_BUFFER_PATH_MAPC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_PATH_MAPC(txdesc, value)
#define GET_TX_DESC_BUFFER_PATH_MAPC_8814B(txdesc) \
GET_TX_DESC_BUFFER_PATH_MAPC(txdesc)
#define SET_TX_DESC_BUFFER_PATH_MAPD_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_PATH_MAPD(txdesc, value)
#define GET_TX_DESC_BUFFER_PATH_MAPD_8814B(txdesc) \
GET_TX_DESC_BUFFER_PATH_MAPD(txdesc)
#define SET_TX_DESC_BUFFER_ANTSEL_A_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_BUFFER_ANTSEL_A_8814B(txdesc) \
GET_TX_DESC_BUFFER_ANTSEL_A(txdesc)
#define SET_TX_DESC_BUFFER_ANTSEL_B_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_BUFFER_ANTSEL_B_8814B(txdesc) \
GET_TX_DESC_BUFFER_ANTSEL_B(txdesc)
#define SET_TX_DESC_BUFFER_ANTSEL_C_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_BUFFER_ANTSEL_C_8814B(txdesc) \
GET_TX_DESC_BUFFER_ANTSEL_C(txdesc)
#define SET_TX_DESC_BUFFER_ANTSEL_D_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_BUFFER_ANTSEL_D_8814B(txdesc) \
GET_TX_DESC_BUFFER_ANTSEL_D(txdesc)
#define SET_TX_DESC_BUFFER_NTX_PATH_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_NTX_PATH_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc)
#define SET_TX_DESC_BUFFER_ANTLSEL_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_ANTLSEL_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc)
#define SET_TX_DESC_BUFFER_AMPDU_DENSITY_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_BUFFER_AMPDU_DENSITY_8814B(txdesc) \
GET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_BUFFER_VCS_STBC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_VCS_STBC(txdesc, value)
#define GET_TX_DESC_BUFFER_VCS_STBC_8814B(txdesc) \
GET_TX_DESC_BUFFER_VCS_STBC(txdesc)
#define SET_TX_DESC_BUFFER_DATA_STBC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATA_STBC(txdesc, value)
#define GET_TX_DESC_BUFFER_DATA_STBC_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATA_STBC(txdesc)
#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc)
#define SET_TX_DESC_BUFFER_MHR_CP_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MHR_CP(txdesc, value)
#define GET_TX_DESC_BUFFER_MHR_CP_8814B(txdesc) \
GET_TX_DESC_BUFFER_MHR_CP(txdesc)
#define SET_TX_DESC_BUFFER_SMH_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SMH_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_SMH_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_SMH_EN(txdesc)
#define SET_TX_DESC_BUFFER_RTSRATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RTSRATE(txdesc, value)
#define GET_TX_DESC_BUFFER_RTSRATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_RTSRATE(txdesc)
#define SET_TX_DESC_BUFFER_SMH_CAM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SMH_CAM(txdesc, value)
#define GET_TX_DESC_BUFFER_SMH_CAM_8814B(txdesc) \
GET_TX_DESC_BUFFER_SMH_CAM(txdesc)
#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc, value)
#define GET_TX_DESC_BUFFER_ARFR_TABLE_SEL_8814B(txdesc) \
GET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc)
#define SET_TX_DESC_BUFFER_ARFR_HT_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_ARFR_HT_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc)
#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_ARFR_OFDM_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc)
#define SET_TX_DESC_BUFFER_ARFR_CCK_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_ARFR_CCK_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc)
#define SET_TX_DESC_BUFFER_RTS_SHORT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_BUFFER_RTS_SHORT_8814B(txdesc) \
GET_TX_DESC_BUFFER_RTS_SHORT(txdesc)
#define SET_TX_DESC_BUFFER_DISDATAFB_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DISDATAFB(txdesc, value)
#define GET_TX_DESC_BUFFER_DISDATAFB_8814B(txdesc) \
GET_TX_DESC_BUFFER_DISDATAFB(txdesc)
#define SET_TX_DESC_BUFFER_DISRTSFB_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DISRTSFB(txdesc, value)
#define GET_TX_DESC_BUFFER_DISRTSFB_8814B(txdesc) \
GET_TX_DESC_BUFFER_DISRTSFB(txdesc)
#define SET_TX_DESC_BUFFER_EXT_EDCA_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_EXT_EDCA(txdesc, value)
#define GET_TX_DESC_BUFFER_EXT_EDCA_8814B(txdesc) \
GET_TX_DESC_BUFFER_EXT_EDCA(txdesc)
/*TXDESC_WORD10*/
#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_BUFFER_AMPDU_MAX_TIME_8814B(txdesc) \
GET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_BUFFER_SPECIAL_CW_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SPECIAL_CW(txdesc, value)
#define GET_TX_DESC_BUFFER_SPECIAL_CW_8814B(txdesc) \
GET_TX_DESC_BUFFER_SPECIAL_CW(txdesc)
#define SET_TX_DESC_BUFFER_RDG_NAV_EXT_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc, value)
#define GET_TX_DESC_BUFFER_RDG_NAV_EXT_8814B(txdesc) \
GET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc)
#define SET_TX_DESC_BUFFER_RAW_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_RAW(txdesc, value)
#define GET_TX_DESC_BUFFER_RAW_8814B(txdesc) GET_TX_DESC_BUFFER_RAW(txdesc)
#define SET_TX_DESC_BUFFER_MAX_AGG_NUM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_BUFFER_MAX_AGG_NUM_8814B(txdesc) \
GET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_BUFFER_FINAL_DATA_RATE_8814B(txdesc) \
GET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_BUFFER_GF_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_GF(txdesc, value)
#define GET_TX_DESC_BUFFER_GF_8814B(txdesc) GET_TX_DESC_BUFFER_GF(txdesc)
#define SET_TX_DESC_BUFFER_MOREFRAG_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_MOREFRAG(txdesc, value)
#define GET_TX_DESC_BUFFER_MOREFRAG_8814B(txdesc) \
GET_TX_DESC_BUFFER_MOREFRAG(txdesc)
#define SET_TX_DESC_BUFFER_NOACM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_NOACM(txdesc, value)
#define GET_TX_DESC_BUFFER_NOACM_8814B(txdesc) GET_TX_DESC_BUFFER_NOACM(txdesc)
#define SET_TX_DESC_BUFFER_HTC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_HTC(txdesc, value)
#define GET_TX_DESC_BUFFER_HTC_8814B(txdesc) GET_TX_DESC_BUFFER_HTC(txdesc)
#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc, value)
#define GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS_8814B(txdesc) \
GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc)
#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_USE_MAX_TIME_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_BUFFER_HW_SSN_SEL_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_BUFFER_HW_SSN_SEL_8814B(txdesc) \
GET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc)
/*TXDESC_WORD11*/
#define SET_TX_DESC_BUFFER_ADDR_CAM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_ADDR_CAM(txdesc, value)
#define GET_TX_DESC_BUFFER_ADDR_CAM_8814B(txdesc) \
GET_TX_DESC_BUFFER_ADDR_CAM(txdesc)
#define SET_TX_DESC_BUFFER_SND_TARGET_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SND_TARGET(txdesc, value)
#define GET_TX_DESC_BUFFER_SND_TARGET_8814B(txdesc) \
GET_TX_DESC_BUFFER_SND_TARGET(txdesc)
#define SET_TX_DESC_BUFFER_DATA_LDPC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_BUFFER_DATA_LDPC_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATA_LDPC(txdesc)
#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_BUFFER_LSIG_TXOP_EN_8814B(txdesc) \
GET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_BUFFER_G_ID_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_G_ID(txdesc, value)
#define GET_TX_DESC_BUFFER_G_ID_8814B(txdesc) GET_TX_DESC_BUFFER_G_ID(txdesc)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc, value)
#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC_8814B(txdesc) \
GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc)
#define SET_TX_DESC_BUFFER_DATA_SC_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_DATA_SC(txdesc, value)
#define GET_TX_DESC_BUFFER_DATA_SC_8814B(txdesc) \
GET_TX_DESC_BUFFER_DATA_SC(txdesc)
/*TXDESC_WORD12*/
#define SET_TX_DESC_BUFFER_LEN1_L_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_LEN1_L(txdesc, value)
#define GET_TX_DESC_BUFFER_LEN1_L_8814B(txdesc) \
GET_TX_DESC_BUFFER_LEN1_L(txdesc)
#define SET_TX_DESC_BUFFER_LEN0_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_LEN0(txdesc, value)
#define GET_TX_DESC_BUFFER_LEN0_8814B(txdesc) GET_TX_DESC_BUFFER_LEN0(txdesc)
#define SET_TX_DESC_BUFFER_PKT_NUM_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_PKT_NUM(txdesc, value)
#define GET_TX_DESC_BUFFER_PKT_NUM_8814B(txdesc) \
GET_TX_DESC_BUFFER_PKT_NUM(txdesc)
/*TXDESC_WORD13*/
#define SET_TX_DESC_BUFFER_LEN3_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_LEN3(txdesc, value)
#define GET_TX_DESC_BUFFER_LEN3_8814B(txdesc) GET_TX_DESC_BUFFER_LEN3(txdesc)
#define SET_TX_DESC_BUFFER_LEN2_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_LEN2(txdesc, value)
#define GET_TX_DESC_BUFFER_LEN2_8814B(txdesc) GET_TX_DESC_BUFFER_LEN2(txdesc)
#define SET_TX_DESC_BUFFER_LEN1_H_8814B(txdesc, value) \
SET_TX_DESC_BUFFER_LEN1_H(txdesc, value)
#define GET_TX_DESC_BUFFER_LEN1_H_8814B(txdesc) \
GET_TX_DESC_BUFFER_LEN1_H(txdesc)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_buffer_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_BUFFER_NIC_H_
#define _HALMAC_TX_DESC_BUFFER_NIC_H_
#if (HALMAC_8814B_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_BUFFER_RDG_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 31, 1, value)
#define GET_TX_DESC_BUFFER_RDG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 31, 1)
#define SET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 30, 1, value)
#define GET_TX_DESC_BUFFER_BCNPKT_TSF_CTRL(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x00, 30, 1)
#define SET_TX_DESC_BUFFER_AGG_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 29, 1, value)
#define GET_TX_DESC_BUFFER_AGG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 29, 1)
#define SET_TX_DESC_BUFFER_PKT_OFFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 24, 5, value)
#define GET_TX_DESC_BUFFER_PKT_OFFSET(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x00, 24, 5)
#define SET_TX_DESC_BUFFER_OFFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 16, 8, value)
#define GET_TX_DESC_BUFFER_OFFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 16, 8)
#define SET_TX_DESC_BUFFER_TXPKTSIZE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 0, 16, value)
#define GET_TX_DESC_BUFFER_TXPKTSIZE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x00, 0, 16)
/*TXDESC_WORD1*/
#define SET_TX_DESC_BUFFER_USERATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 31, 1, value)
#define GET_TX_DESC_BUFFER_USERATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x04, 31, 1)
#define SET_TX_DESC_BUFFER_AMSDU(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
#define GET_TX_DESC_BUFFER_AMSDU(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
#define SET_TX_DESC_BUFFER_EN_HWSEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 29, 1, value)
#define GET_TX_DESC_BUFFER_EN_HWSEQ(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x04, 29, 1)
#define SET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 28, 1, value)
#define GET_TX_DESC_BUFFER_EN_HWEXSEQ(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x04, 28, 1)
#define SET_TX_DESC_BUFFER_SW_SEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 16, 12, value)
#define GET_TX_DESC_BUFFER_SW_SEQ(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x04, 16, 12)
#define SET_TX_DESC_BUFFER_DROP_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 14, 2, value)
#define GET_TX_DESC_BUFFER_DROP_ID(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x04, 14, 2)
#define SET_TX_DESC_BUFFER_MOREDATA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 13, 1, value)
#define GET_TX_DESC_BUFFER_MOREDATA(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x04, 13, 1)
#define SET_TX_DESC_BUFFER_QSEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 8, 5, value)
#define GET_TX_DESC_BUFFER_QSEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 8, 5)
#define SET_TX_DESC_BUFFER_MACID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 0, 8, value)
#define GET_TX_DESC_BUFFER_MACID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 0, 8)
/*TXDESC_WORD2*/
#define SET_TX_DESC_BUFFER_CHK_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 31, 1, value)
#define GET_TX_DESC_BUFFER_CHK_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 31, 1)
#define SET_TX_DESC_BUFFER_DISQSELSEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 30, 1, value)
#define GET_TX_DESC_BUFFER_DISQSELSEQ(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 30, 1)
#define SET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 28, 2, value)
#define GET_TX_DESC_BUFFER_SND_PKT_SEL(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 28, 2)
#define SET_TX_DESC_BUFFER_DMA_PRI(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 27, 1, value)
#define GET_TX_DESC_BUFFER_DMA_PRI(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 27, 1)
#define SET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 3, value)
#define GET_TX_DESC_BUFFER_MAX_AMSDU_MODE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 3)
#define SET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 16, 8, value)
#define GET_TX_DESC_BUFFER_DMA_TXAGG_NUM(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 16, 8)
#define SET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 0, 16, value)
#define GET_TX_DESC_BUFFER_TXDESC_CHECKSUM(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 0, 16)
/*TXDESC_WORD3*/
#define SET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 16, 15, value)
#define GET_TX_DESC_BUFFER_OFFLOAD_SIZE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x0C, 16, 15)
#define SET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 11, 5, value)
#define GET_TX_DESC_BUFFER_CHANNEL_DMA(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x0C, 11, 5)
#define SET_TX_DESC_BUFFER_MBSSID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 7, 4, value)
#define GET_TX_DESC_BUFFER_MBSSID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 7, 4)
#define SET_TX_DESC_BUFFER_BK(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 6, 1, value)
#define GET_TX_DESC_BUFFER_BK(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 6, 1)
#define SET_TX_DESC_BUFFER_WHEADER_LEN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 0, 5, value)
#define GET_TX_DESC_BUFFER_WHEADER_LEN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x0C, 0, 5)
/*TXDESC_WORD4*/
#define SET_TX_DESC_BUFFER_TRY_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 26, 1, value)
#define GET_TX_DESC_BUFFER_TRY_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 26, 1)
#define SET_TX_DESC_BUFFER_DATA_BW(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 24, 2, value)
#define GET_TX_DESC_BUFFER_DATA_BW(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 24, 2)
#define SET_TX_DESC_BUFFER_DATA_SHORT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 23, 1, value)
#define GET_TX_DESC_BUFFER_DATA_SHORT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 23, 1)
#define SET_TX_DESC_BUFFER_DATARATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 16, 7, value)
#define GET_TX_DESC_BUFFER_DATARATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 16, 7)
#define SET_TX_DESC_BUFFER_TXBF_PATH(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 11, 1, value)
#define GET_TX_DESC_BUFFER_TXBF_PATH(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 11, 1)
#define SET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 0, 11, value)
#define GET_TX_DESC_BUFFER_GROUP_BIT_IE_OFFSET(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 0, 11)
/*TXDESC_WORD5*/
#define SET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 31, 1, value)
#define GET_TX_DESC_BUFFER_RTY_LMT_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 31, 1)
#define SET_TX_DESC_BUFFER_HW_RTS_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 30, 1, value)
#define GET_TX_DESC_BUFFER_HW_RTS_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 30, 1)
#define SET_TX_DESC_BUFFER_RTS_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 29, 1, value)
#define GET_TX_DESC_BUFFER_RTS_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 29, 1)
#define SET_TX_DESC_BUFFER_CTS2SELF(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 1, value)
#define GET_TX_DESC_BUFFER_CTS2SELF(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 1)
#define SET_TX_DESC_BUFFER_TAILPAGE_H(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 24, 4, value)
#define GET_TX_DESC_BUFFER_TAILPAGE_H(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 24, 4)
#define SET_TX_DESC_BUFFER_TAILPAGE_L(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 16, 8, value)
#define GET_TX_DESC_BUFFER_TAILPAGE_L(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 16, 8)
#define SET_TX_DESC_BUFFER_NAVUSEHDR(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 15, 1, value)
#define GET_TX_DESC_BUFFER_NAVUSEHDR(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 15, 1)
#define SET_TX_DESC_BUFFER_BMC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 14, 1, value)
#define GET_TX_DESC_BUFFER_BMC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 14, 1)
#define SET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 8, 6, value)
#define GET_TX_DESC_BUFFER_RTS_DATA_RTY_LMT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 8, 6)
#define SET_TX_DESC_BUFFER_HW_AES_IV(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 7, 1, value)
#define GET_TX_DESC_BUFFER_HW_AES_IV(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 7, 1)
#define SET_TX_DESC_BUFFER_BT_NULL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 3, 1, value)
#define GET_TX_DESC_BUFFER_BT_NULL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 3, 1)
#define SET_TX_DESC_BUFFER_EN_DESC_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 2, 1, value)
#define GET_TX_DESC_BUFFER_EN_DESC_ID(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 2, 1)
#define SET_TX_DESC_BUFFER_SECTYPE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 0, 2, value)
#define GET_TX_DESC_BUFFER_SECTYPE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 0, 2)
/*TXDESC_WORD6*/
#define SET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 29, 3, value)
#define GET_TX_DESC_BUFFER_MULTIPLE_PORT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 29, 3)
#define SET_TX_DESC_BUFFER_POLLUTED(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 1, value)
#define GET_TX_DESC_BUFFER_POLLUTED(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 1)
#define SET_TX_DESC_BUFFER_NULL_1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 27, 1, value)
#define GET_TX_DESC_BUFFER_NULL_1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 27, 1)
#define SET_TX_DESC_BUFFER_NULL_0(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 1, value)
#define GET_TX_DESC_BUFFER_NULL_0(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 1)
#define SET_TX_DESC_BUFFER_TRI_FRAME(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 25, 1, value)
#define GET_TX_DESC_BUFFER_TRI_FRAME(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 25, 1)
#define SET_TX_DESC_BUFFER_SPE_RPT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 1, value)
#define GET_TX_DESC_BUFFER_SPE_RPT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 1)
#define SET_TX_DESC_BUFFER_FTM_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 23, 1, value)
#define GET_TX_DESC_BUFFER_FTM_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 23, 1)
#define SET_TX_DESC_BUFFER_MU_DATARATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 7, value)
#define GET_TX_DESC_BUFFER_MU_DATARATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 7)
#define SET_TX_DESC_BUFFER_CCA_RTS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 14, 2, value)
#define GET_TX_DESC_BUFFER_CCA_RTS(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 14, 2)
#define SET_TX_DESC_BUFFER_NDPA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 12, 2, value)
#define GET_TX_DESC_BUFFER_NDPA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 12, 2)
#define SET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 9, 2, value)
#define GET_TX_DESC_BUFFER_TXPWR_OFSET_TYPE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x18, 9, 2)
#define SET_TX_DESC_BUFFER_P_AID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 0, 9, value)
#define GET_TX_DESC_BUFFER_P_AID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 0, 9)
/*TXDESC_WORD7*/
#define SET_TX_DESC_BUFFER_SW_DEFINE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 16, 12, value)
#define GET_TX_DESC_BUFFER_SW_DEFINE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x1C, 16, 12)
#define SET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 9, 1, value)
#define GET_TX_DESC_BUFFER_CTRL_CNT_VALID(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x1C, 9, 1)
#define SET_TX_DESC_BUFFER_CTRL_CNT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 5, 4, value)
#define GET_TX_DESC_BUFFER_CTRL_CNT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x1C, 5, 4)
#define SET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 5, value)
#define GET_TX_DESC_BUFFER_DATA_RTY_LOWEST_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 5)
/*TXDESC_WORD8*/
#define SET_TX_DESC_BUFFER_PATH_MAPA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 30, 2, value)
#define GET_TX_DESC_BUFFER_PATH_MAPA(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 30, 2)
#define SET_TX_DESC_BUFFER_PATH_MAPB(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 28, 2, value)
#define GET_TX_DESC_BUFFER_PATH_MAPB(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 28, 2)
#define SET_TX_DESC_BUFFER_PATH_MAPC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 26, 2, value)
#define GET_TX_DESC_BUFFER_PATH_MAPC(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 26, 2)
#define SET_TX_DESC_BUFFER_PATH_MAPD(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 24, 2, value)
#define GET_TX_DESC_BUFFER_PATH_MAPD(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 24, 2)
#define SET_TX_DESC_BUFFER_ANTSEL_A(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 20, 4, value)
#define GET_TX_DESC_BUFFER_ANTSEL_A(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 20, 4)
#define SET_TX_DESC_BUFFER_ANTSEL_B(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 16, 4, value)
#define GET_TX_DESC_BUFFER_ANTSEL_B(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 16, 4)
#define SET_TX_DESC_BUFFER_ANTSEL_C(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 12, 4, value)
#define GET_TX_DESC_BUFFER_ANTSEL_C(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 12, 4)
#define SET_TX_DESC_BUFFER_ANTSEL_D(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 8, 4, value)
#define GET_TX_DESC_BUFFER_ANTSEL_D(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 8, 4)
#define SET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 4, 4, value)
#define GET_TX_DESC_BUFFER_NTX_PATH_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 4, 4)
#define SET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 3, 1, value)
#define GET_TX_DESC_BUFFER_ANTLSEL_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 3, 1)
#define SET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 0, 3, value)
#define GET_TX_DESC_BUFFER_AMPDU_DENSITY(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 0, 3)
/*TXDESC_WORD9*/
#define SET_TX_DESC_BUFFER_VCS_STBC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 30, 2, value)
#define GET_TX_DESC_BUFFER_VCS_STBC(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 30, 2)
#define SET_TX_DESC_BUFFER_DATA_STBC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 28, 2, value)
#define GET_TX_DESC_BUFFER_DATA_STBC(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 28, 2)
#define SET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 24, 4, value)
#define GET_TX_DESC_BUFFER_RTS_RTY_LOWEST_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 24, 4)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 23, 1, value)
#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 23, 1)
#define SET_TX_DESC_BUFFER_MHR_CP(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 22, 1, value)
#define GET_TX_DESC_BUFFER_MHR_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 22, 1)
#define SET_TX_DESC_BUFFER_SMH_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 21, 1, value)
#define GET_TX_DESC_BUFFER_SMH_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 21, 1)
#define SET_TX_DESC_BUFFER_RTSRATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 16, 5, value)
#define GET_TX_DESC_BUFFER_RTSRATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 16, 5)
#define SET_TX_DESC_BUFFER_SMH_CAM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 8, 8, value)
#define GET_TX_DESC_BUFFER_SMH_CAM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 8, 8)
#define SET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 7, 1, value)
#define GET_TX_DESC_BUFFER_ARFR_TABLE_SEL(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 7, 1)
#define SET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 6, 1, value)
#define GET_TX_DESC_BUFFER_ARFR_HT_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 6, 1)
#define SET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 5, 1, value)
#define GET_TX_DESC_BUFFER_ARFR_OFDM_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 5, 1)
#define SET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 4, 1, value)
#define GET_TX_DESC_BUFFER_ARFR_CCK_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 4, 1)
#define SET_TX_DESC_BUFFER_RTS_SHORT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 3, 1, value)
#define GET_TX_DESC_BUFFER_RTS_SHORT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 3, 1)
#define SET_TX_DESC_BUFFER_DISDATAFB(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 2, 1, value)
#define GET_TX_DESC_BUFFER_DISDATAFB(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 2, 1)
#define SET_TX_DESC_BUFFER_DISRTSFB(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 1, 1, value)
#define GET_TX_DESC_BUFFER_DISRTSFB(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 1, 1)
#define SET_TX_DESC_BUFFER_EXT_EDCA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 0, 1, value)
#define GET_TX_DESC_BUFFER_EXT_EDCA(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 0, 1)
/*TXDESC_WORD10*/
#define SET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 24, 8, value)
#define GET_TX_DESC_BUFFER_AMPDU_MAX_TIME(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 24, 8)
#define SET_TX_DESC_BUFFER_SPECIAL_CW(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 23, 1, value)
#define GET_TX_DESC_BUFFER_SPECIAL_CW(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 23, 1)
#define SET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 22, 1, value)
#define GET_TX_DESC_BUFFER_RDG_NAV_EXT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 22, 1)
#define SET_TX_DESC_BUFFER_RAW(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 21, 1, value)
#define GET_TX_DESC_BUFFER_RAW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 21, 1)
#define SET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 16, 5, value)
#define GET_TX_DESC_BUFFER_MAX_AGG_NUM(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 16, 5)
#define SET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 8, 8, value)
#define GET_TX_DESC_BUFFER_FINAL_DATA_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 8, 8)
#define SET_TX_DESC_BUFFER_GF(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 7, 1, value)
#define GET_TX_DESC_BUFFER_GF(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 7, 1)
#define SET_TX_DESC_BUFFER_MOREFRAG(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 6, 1, value)
#define GET_TX_DESC_BUFFER_MOREFRAG(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 6, 1)
#define SET_TX_DESC_BUFFER_NOACM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 5, 1, value)
#define GET_TX_DESC_BUFFER_NOACM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 5, 1)
#define SET_TX_DESC_BUFFER_HTC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 4, 1, value)
#define GET_TX_DESC_BUFFER_HTC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 4, 1)
#define SET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 3, 1, value)
#define GET_TX_DESC_BUFFER_TX_PKT_AFTER_PIFS(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 3, 1)
#define SET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 2, 1, value)
#define GET_TX_DESC_BUFFER_USE_MAX_TIME_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 2, 1)
#define SET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 0, 2, value)
#define GET_TX_DESC_BUFFER_HW_SSN_SEL(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x28, 0, 2)
/*TXDESC_WORD11*/
#define SET_TX_DESC_BUFFER_ADDR_CAM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 24, 8, value)
#define GET_TX_DESC_BUFFER_ADDR_CAM(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x2C, 24, 8)
#define SET_TX_DESC_BUFFER_SND_TARGET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 16, 8, value)
#define GET_TX_DESC_BUFFER_SND_TARGET(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x2C, 16, 8)
#define SET_TX_DESC_BUFFER_DATA_LDPC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 15, 1, value)
#define GET_TX_DESC_BUFFER_DATA_LDPC(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x2C, 15, 1)
#define SET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 14, 1, value)
#define GET_TX_DESC_BUFFER_LSIG_TXOP_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x2C, 14, 1)
#define SET_TX_DESC_BUFFER_G_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 8, 6, value)
#define GET_TX_DESC_BUFFER_G_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x2C, 8, 6)
#define SET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 4, 4, value)
#define GET_TX_DESC_BUFFER_SIGNALING_TA_PKT_SC(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x2C, 4, 4)
#define SET_TX_DESC_BUFFER_DATA_SC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x2C, 0, 4, value)
#define GET_TX_DESC_BUFFER_DATA_SC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x2C, 0, 4)
/*TXDESC_WORD12*/
#define SET_TX_DESC_BUFFER_LEN1_L(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x30, 17, 7, value)
#define GET_TX_DESC_BUFFER_LEN1_L(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x30, 17, 7)
#define SET_TX_DESC_BUFFER_LEN0(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x30, 4, 13, value)
#define GET_TX_DESC_BUFFER_LEN0(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x30, 4, 13)
#define SET_TX_DESC_BUFFER_PKT_NUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x30, 0, 4, value)
#define GET_TX_DESC_BUFFER_PKT_NUM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x30, 0, 4)
/*TXDESC_WORD13*/
#define SET_TX_DESC_BUFFER_LEN3(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x34, 19, 13, value)
#define GET_TX_DESC_BUFFER_LEN3(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x34, 19, 13)
#define SET_TX_DESC_BUFFER_LEN2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x34, 6, 13, value)
#define GET_TX_DESC_BUFFER_LEN2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x34, 6, 13)
#define SET_TX_DESC_BUFFER_LEN1_H(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x34, 0, 6, value)
#define GET_TX_DESC_BUFFER_LEN1_H(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x34, 0, 6)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_chip.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_CHIP_H_
#define _HALMAC_TX_DESC_CHIP_H_
#if (HALMAC_8814A_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8814A(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8814A(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8814A(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8814A(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8814A(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8814A(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8814A(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8814A(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8814A(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8814A(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8814A(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8814A(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8814A(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8814A(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8814A(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8814A(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8814A(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8814A(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_MOREDATA_8814A(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8814A(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8814A(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8814A(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8814A(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8814A(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8814A(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8814A(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8814A(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8814A(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8814A(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8814A(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8814A(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8814A(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8814A(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8814A(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8814A(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8814A(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8814A(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8814A(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV_8814A(txdesc, value) \
SET_TX_DESC_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8814A(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
#define SET_TX_DESC_G_ID_8814A(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8814A(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8814A(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8814A(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8814A(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8814A(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8814A(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8814A(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8814A(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8814A(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8814A(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8814A(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8814A(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8814A(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8814A(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8814A(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8814A(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8814A(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8814A(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8814A(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8814A(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8814A(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8814A(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8814A(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_P_AID_8814A(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8814A(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8814A(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8814A(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8814A(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8814A(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8814A(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8814A(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8814A(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8814A(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8814A(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8814A(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8814A(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8814A(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8814A(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8814A(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8814A(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8814A(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8814A(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8814A(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8814A(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8814A(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8814A(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8814A(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8814A(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8814A(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8814A(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8814A(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8814A(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8814A(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8814A(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8814A(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8814A(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8814A(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8814A(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8814A(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8814A(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8814A(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8814A(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8814A(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8814A(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8814A(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8814A(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8814A(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8814A(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8814A(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8814A(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8814A(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8814A(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8814A(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_8814A(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_8814A(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
#define SET_TX_DESC_TX_ANT_8814A(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8814A(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_PORT_ID_8814A(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8814A(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8814A(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8814A(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_RTS_SC_8814A(txdesc, value) \
SET_TX_DESC_RTS_SC(txdesc, value)
#define GET_TX_DESC_RTS_SC_8814A(txdesc) GET_TX_DESC_RTS_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8814A(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8814A(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8814A(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8814A(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8814A(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8814A(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8814A(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8814A(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8814A(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8814A(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8814A(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8814A(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8814A(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8814A(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D_8814A(txdesc, value) \
SET_TX_DESC_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8814A(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
#define SET_TX_DESC_ANT_MAPD_8814A(txdesc, value) \
SET_TX_DESC_ANT_MAPD(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8814A(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
#define SET_TX_DESC_ANT_MAPC_8814A(txdesc, value) \
SET_TX_DESC_ANT_MAPC(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8814A(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
#define SET_TX_DESC_ANT_MAPB_8814A(txdesc, value) \
SET_TX_DESC_ANT_MAPB(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8814A(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
#define SET_TX_DESC_ANT_MAPA_8814A(txdesc, value) \
SET_TX_DESC_ANT_MAPA(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8814A(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
#define SET_TX_DESC_ANTSEL_C_8814A(txdesc, value) \
SET_TX_DESC_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8814A(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
#define SET_TX_DESC_ANTSEL_B_8814A(txdesc, value) \
SET_TX_DESC_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8814A(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
#define SET_TX_DESC_ANTSEL_A_8814A(txdesc, value) \
SET_TX_DESC_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8814A(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
#define SET_TX_DESC_MBSSID_8814A(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8814A(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SW_DEFINE_8814A(txdesc, value) \
SET_TX_DESC_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_SW_DEFINE_8814A(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8814A(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8814A(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8814A(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8814A(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8814A(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8814A(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8814A(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8814A(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8814A(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8814A(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8814A(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8814A(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8814A(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8814A(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8814A(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8814A(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8814A(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8814A(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8814A(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8814A(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8814A(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8814A(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8814A(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8814A(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8814A(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8814A(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8814A(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8814A(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8814A(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8814A(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8814A(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8814A(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8814A(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8814A(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8814A(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8814A(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_EN_HWEXSEQ_8814A(txdesc, value) \
SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWEXSEQ_8814A(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8814A(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8814A(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8814A(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8814A(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8814A(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8814A(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8814A(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8814A(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8814A(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8814A(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8814A(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8814A(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8814A(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8814A(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8814A(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8814A(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8814A(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8814A(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#endif
#if (HALMAC_8822B_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8822B(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8822B(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8822B(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8822B(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8822B(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8822B(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_8822B(txdesc, value) \
SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL_8822B(txdesc) \
GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8822B(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8822B(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8822B(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8822B(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8822B(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8822B(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8822B(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8822B(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8822B(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8822B(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8822B(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8822B(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_MOREDATA_8822B(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8822B(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8822B(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8822B(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8822B(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8822B(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8822B(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8822B(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8822B(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8822B(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8822B(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8822B(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8822B(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8822B(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8822B(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8822B(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8822B(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8822B(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8822B(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8822B(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV_8822B(txdesc, value) \
SET_TX_DESC_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8822B(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
#define SET_TX_DESC_FTM_EN_8822B(txdesc, value) \
SET_TX_DESC_FTM_EN(txdesc, value)
#define GET_TX_DESC_FTM_EN_8822B(txdesc) GET_TX_DESC_FTM_EN(txdesc)
#define SET_TX_DESC_G_ID_8822B(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8822B(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8822B(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8822B(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8822B(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8822B(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8822B(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8822B(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8822B(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8822B(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8822B(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8822B(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8822B(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8822B(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8822B(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8822B(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8822B(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8822B(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8822B(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8822B(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8822B(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8822B(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8822B(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8822B(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8822B(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8822B(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8822B(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8822B(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8822B(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8822B(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8822B(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8822B(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8822B(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8822B(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8822B(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8822B(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8822B(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8822B(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8822B(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8822B(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8822B(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8822B(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8822B(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8822B(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8822B(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8822B(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8822B(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8822B(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8822B(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8822B(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8822B(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8822B(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8822B(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8822B(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8822B(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8822B(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8822B(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8822B(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8822B(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8822B(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8822B(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8822B(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8822B(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8822B(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8822B(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8822B(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8822B(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8822B(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8822B(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8822B(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8822B(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8822B(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8822B(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8822B(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8822B(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_8822B(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_8822B(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
#define SET_TX_DESC_TX_ANT_8822B(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8822B(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_PORT_ID_8822B(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8822B(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_MULTIPLE_PORT_8822B(txdesc, value) \
SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_MULTIPLE_PORT_8822B(txdesc) \
GET_TX_DESC_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8822B(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8822B(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8822B(txdesc, value) \
SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8822B(txdesc) \
GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8822B(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8822B(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8822B(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8822B(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8822B(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8822B(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8822B(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8822B(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8822B(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8822B(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8822B(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8822B(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8822B(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8822B(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D_8822B(txdesc, value) \
SET_TX_DESC_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8822B(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
#define SET_TX_DESC_ANT_MAPD_8822B(txdesc, value) \
SET_TX_DESC_ANT_MAPD(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8822B(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
#define SET_TX_DESC_ANT_MAPC_8822B(txdesc, value) \
SET_TX_DESC_ANT_MAPC(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8822B(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
#define SET_TX_DESC_ANT_MAPB_8822B(txdesc, value) \
SET_TX_DESC_ANT_MAPB(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8822B(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
#define SET_TX_DESC_ANT_MAPA_8822B(txdesc, value) \
SET_TX_DESC_ANT_MAPA(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8822B(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
#define SET_TX_DESC_ANTSEL_C_8822B(txdesc, value) \
SET_TX_DESC_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8822B(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
#define SET_TX_DESC_ANTSEL_B_8822B(txdesc, value) \
SET_TX_DESC_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8822B(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
#define SET_TX_DESC_ANTSEL_A_8822B(txdesc, value) \
SET_TX_DESC_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8822B(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
#define SET_TX_DESC_MBSSID_8822B(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8822B(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SW_DEFINE_8822B(txdesc, value) \
SET_TX_DESC_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_SW_DEFINE_8822B(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8822B(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8822B(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8822B(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8822B(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8822B(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8822B(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8822B(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8822B(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8822B(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8822B(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8822B(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8822B(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8822B(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8822B(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8822B(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8822B(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8822B(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8822B(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8822B(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8822B(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8822B(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8822B(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8822B(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8822B(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8822B(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8822B(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8822B(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8822B(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8822B(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8822B(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8822B(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8822B(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8822B(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8822B(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8822B(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8822B(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_EN_HWEXSEQ_8822B(txdesc, value) \
SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWEXSEQ_8822B(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8822B(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8822B(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8822B(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8822B(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8822B(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8822B(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8822B(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8822B(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8822B(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8822B(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8822B(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8822B(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8822B(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8822B(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8822B(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8822B(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8822B(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8822B(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#define SET_TX_DESC_MU_DATARATE_8822B(txdesc, value) \
SET_TX_DESC_MU_DATARATE(txdesc, value)
#define GET_TX_DESC_MU_DATARATE_8822B(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
#define SET_TX_DESC_MU_RC_8822B(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
#define GET_TX_DESC_MU_RC_8822B(txdesc) GET_TX_DESC_MU_RC(txdesc)
#define SET_TX_DESC_SND_PKT_SEL_8822B(txdesc, value) \
SET_TX_DESC_SND_PKT_SEL(txdesc, value)
#define GET_TX_DESC_SND_PKT_SEL_8822B(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
#endif
#if (HALMAC_8197F_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8197F(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8197F(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8197F(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8197F(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8197F(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8197F(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_8197F(txdesc, value) \
SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL_8197F(txdesc) \
GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8197F(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8197F(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8197F(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8197F(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8197F(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8197F(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8197F(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8197F(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8197F(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8197F(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8197F(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8197F(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_MOREDATA_8197F(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8197F(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8197F(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8197F(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8197F(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8197F(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8197F(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8197F(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8197F(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8197F(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8197F(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8197F(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8197F(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8197F(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8197F(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8197F(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8197F(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8197F(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8197F(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8197F(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV_8197F(txdesc, value) \
SET_TX_DESC_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8197F(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
#define SET_TX_DESC_FTM_EN_8197F(txdesc, value) \
SET_TX_DESC_FTM_EN(txdesc, value)
#define GET_TX_DESC_FTM_EN_8197F(txdesc) GET_TX_DESC_FTM_EN(txdesc)
#define SET_TX_DESC_G_ID_8197F(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8197F(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8197F(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8197F(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8197F(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8197F(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8197F(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8197F(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8197F(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8197F(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8197F(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8197F(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8197F(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8197F(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8197F(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8197F(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8197F(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8197F(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8197F(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8197F(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8197F(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8197F(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8197F(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8197F(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8197F(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8197F(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8197F(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8197F(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8197F(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8197F(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8197F(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8197F(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8197F(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8197F(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8197F(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8197F(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8197F(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8197F(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8197F(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8197F(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8197F(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8197F(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8197F(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8197F(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8197F(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8197F(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8197F(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8197F(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8197F(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8197F(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8197F(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8197F(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8197F(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8197F(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8197F(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8197F(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8197F(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8197F(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8197F(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8197F(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8197F(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8197F(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8197F(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8197F(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8197F(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8197F(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8197F(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8197F(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8197F(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8197F(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8197F(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8197F(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8197F(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8197F(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8197F(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8197F(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_8197F(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_8197F(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
#define SET_TX_DESC_TX_ANT_8197F(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8197F(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_PORT_ID_8197F(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8197F(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_MULTIPLE_PORT_8197F(txdesc, value) \
SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_MULTIPLE_PORT_8197F(txdesc) \
GET_TX_DESC_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8197F(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8197F(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_RTS_SC_8197F(txdesc, value) \
SET_TX_DESC_RTS_SC(txdesc, value)
#define GET_TX_DESC_RTS_SC_8197F(txdesc) GET_TX_DESC_RTS_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8197F(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8197F(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8197F(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8197F(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8197F(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8197F(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8197F(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8197F(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8197F(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8197F(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8197F(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8197F(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8197F(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8197F(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D_8197F(txdesc, value) \
SET_TX_DESC_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8197F(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
#define SET_TX_DESC_ANT_MAPD_8197F(txdesc, value) \
SET_TX_DESC_ANT_MAPD(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8197F(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
#define SET_TX_DESC_ANT_MAPC_8197F(txdesc, value) \
SET_TX_DESC_ANT_MAPC(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8197F(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
#define SET_TX_DESC_ANT_MAPB_8197F(txdesc, value) \
SET_TX_DESC_ANT_MAPB(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8197F(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
#define SET_TX_DESC_ANT_MAPA_8197F(txdesc, value) \
SET_TX_DESC_ANT_MAPA(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8197F(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
#define SET_TX_DESC_ANTSEL_C_8197F(txdesc, value) \
SET_TX_DESC_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8197F(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
#define SET_TX_DESC_ANTSEL_B_8197F(txdesc, value) \
SET_TX_DESC_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8197F(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
#define SET_TX_DESC_ANTSEL_A_8197F(txdesc, value) \
SET_TX_DESC_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8197F(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
#define SET_TX_DESC_MBSSID_8197F(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8197F(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SW_DEFINE_8197F(txdesc, value) \
SET_TX_DESC_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_SW_DEFINE_8197F(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8197F(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8197F(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8197F(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8197F(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8197F(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8197F(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8197F(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8197F(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8197F(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8197F(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8197F(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8197F(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8197F(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8197F(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8197F(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8197F(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8197F(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8197F(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8197F(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8197F(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8197F(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8197F(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8197F(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8197F(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8197F(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8197F(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8197F(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8197F(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8197F(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8197F(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8197F(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8197F(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8197F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8197F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8197F(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8197F(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_EN_HWEXSEQ_8197F(txdesc, value) \
SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWEXSEQ_8197F(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8197F(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8197F(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8197F(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8197F(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8197F(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8197F(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8197F(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8197F(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8197F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8197F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8197F(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8197F(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8197F(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8197F(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8197F(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8197F(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8197F(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8197F(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#endif
#if (HALMAC_8821C_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8821C(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8821C(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8821C(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8821C(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8821C(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8821C(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_8821C(txdesc, value) \
SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL_8821C(txdesc) \
GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8821C(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8821C(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8821C(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8821C(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8821C(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8821C(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8821C(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8821C(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8821C(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8821C(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8821C(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8821C(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_MOREDATA_8821C(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8821C(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8821C(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8821C(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8821C(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8821C(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8821C(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8821C(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8821C(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8821C(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8821C(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8821C(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8821C(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8821C(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8821C(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8821C(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8821C(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8821C(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8821C(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8821C(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV_8821C(txdesc, value) \
SET_TX_DESC_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8821C(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
#define SET_TX_DESC_FTM_EN_8821C(txdesc, value) \
SET_TX_DESC_FTM_EN(txdesc, value)
#define GET_TX_DESC_FTM_EN_8821C(txdesc) GET_TX_DESC_FTM_EN(txdesc)
#define SET_TX_DESC_G_ID_8821C(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8821C(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8821C(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8821C(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8821C(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8821C(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8821C(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8821C(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8821C(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8821C(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8821C(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8821C(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8821C(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8821C(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8821C(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8821C(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8821C(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8821C(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8821C(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8821C(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8821C(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8821C(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8821C(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8821C(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8821C(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8821C(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8821C(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8821C(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8821C(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8821C(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8821C(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8821C(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8821C(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8821C(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8821C(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8821C(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8821C(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8821C(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8821C(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8821C(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8821C(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8821C(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8821C(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8821C(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8821C(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8821C(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8821C(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8821C(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8821C(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8821C(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8821C(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8821C(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8821C(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8821C(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8821C(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8821C(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8821C(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8821C(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8821C(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8821C(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8821C(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8821C(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8821C(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8821C(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8821C(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8821C(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8821C(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8821C(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8821C(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8821C(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8821C(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8821C(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8821C(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8821C(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8821C(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8821C(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_8821C(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_8821C(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
#define SET_TX_DESC_TX_ANT_8821C(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8821C(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_PORT_ID_8821C(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8821C(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_MULTIPLE_PORT_8821C(txdesc, value) \
SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_MULTIPLE_PORT_8821C(txdesc) \
GET_TX_DESC_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8821C(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8821C(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8821C(txdesc, value) \
SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8821C(txdesc) \
GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8821C(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8821C(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8821C(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8821C(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8821C(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8821C(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8821C(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8821C(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8821C(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8821C(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8821C(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8821C(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8821C(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8821C(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D_8821C(txdesc, value) \
SET_TX_DESC_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8821C(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
#define SET_TX_DESC_ANT_MAPD_8821C(txdesc, value) \
SET_TX_DESC_ANT_MAPD(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8821C(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
#define SET_TX_DESC_ANT_MAPC_8821C(txdesc, value) \
SET_TX_DESC_ANT_MAPC(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8821C(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
#define SET_TX_DESC_ANT_MAPB_8821C(txdesc, value) \
SET_TX_DESC_ANT_MAPB(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8821C(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
#define SET_TX_DESC_ANT_MAPA_8821C(txdesc, value) \
SET_TX_DESC_ANT_MAPA(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8821C(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
#define SET_TX_DESC_ANTSEL_C_8821C(txdesc, value) \
SET_TX_DESC_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8821C(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
#define SET_TX_DESC_ANTSEL_B_8821C(txdesc, value) \
SET_TX_DESC_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8821C(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
#define SET_TX_DESC_ANTSEL_A_8821C(txdesc, value) \
SET_TX_DESC_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8821C(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
#define SET_TX_DESC_MBSSID_8821C(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8821C(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SW_DEFINE_8821C(txdesc, value) \
SET_TX_DESC_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_SW_DEFINE_8821C(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8821C(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8821C(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8821C(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8821C(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8821C(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8821C(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8821C(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8821C(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8821C(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8821C(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8821C(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8821C(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8821C(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8821C(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8821C(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8821C(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8821C(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8821C(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8821C(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8821C(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8821C(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8821C(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8821C(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8821C(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8821C(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8821C(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8821C(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8821C(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8821C(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8821C(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8821C(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8821C(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8821C(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8821C(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8821C(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8821C(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_EN_HWEXSEQ_8821C(txdesc, value) \
SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWEXSEQ_8821C(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8821C(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8821C(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8821C(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8821C(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8821C(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8821C(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8821C(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8821C(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8821C(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8821C(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8821C(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8821C(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8821C(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8821C(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8821C(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8821C(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8821C(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8821C(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#define SET_TX_DESC_MU_DATARATE_8821C(txdesc, value) \
SET_TX_DESC_MU_DATARATE(txdesc, value)
#define GET_TX_DESC_MU_DATARATE_8821C(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
#define SET_TX_DESC_MU_RC_8821C(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
#define GET_TX_DESC_MU_RC_8821C(txdesc) GET_TX_DESC_MU_RC(txdesc)
#define SET_TX_DESC_SND_PKT_SEL_8821C(txdesc, value) \
SET_TX_DESC_SND_PKT_SEL(txdesc, value)
#define GET_TX_DESC_SND_PKT_SEL_8821C(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
#endif
#if (HALMAC_8814B_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_IE_END_BODY_8814B(txdesc, value) \
SET_TX_DESC_IE_END_BODY(txdesc, value)
#define GET_TX_DESC_IE_END_BODY_8814B(txdesc) GET_TX_DESC_IE_END_BODY(txdesc)
#define SET_TX_DESC_AGG_EN_8814B(txdesc, value) \
SET_TX_DESC_AGG_EN_V1(txdesc, value)
#define GET_TX_DESC_AGG_EN_8814B(txdesc) GET_TX_DESC_AGG_EN_V1(txdesc)
#define SET_TX_DESC_BK_8814B(txdesc, value) SET_TX_DESC_BK_V1(txdesc, value)
#define GET_TX_DESC_BK_8814B(txdesc) GET_TX_DESC_BK_V1(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8814B(txdesc, value) \
SET_TX_DESC_PKT_OFFSET_V1(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8814B(txdesc) GET_TX_DESC_PKT_OFFSET_V1(txdesc)
#define SET_TX_DESC_OFFSET_8814B(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8814B(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8814B(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8814B(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_AMSDU_8814B(txdesc, value) SET_TX_DESC_AMSDU(txdesc, value)
#define GET_TX_DESC_AMSDU_8814B(txdesc) GET_TX_DESC_AMSDU(txdesc)
#define SET_TX_DESC_HW_AES_IV_8814B(txdesc, value) \
SET_TX_DESC_HW_AES_IV_V1(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8814B(txdesc) GET_TX_DESC_HW_AES_IV_V1(txdesc)
#define SET_TX_DESC_MHR_CP_8814B(txdesc, value) \
SET_TX_DESC_MHR_CP(txdesc, value)
#define GET_TX_DESC_MHR_CP_8814B(txdesc) GET_TX_DESC_MHR_CP(txdesc)
#define SET_TX_DESC_SMH_EN_8814B(txdesc, value) \
SET_TX_DESC_SMH_EN_V1(txdesc, value)
#define GET_TX_DESC_SMH_EN_8814B(txdesc) GET_TX_DESC_SMH_EN_V1(txdesc)
#define SET_TX_DESC_SMH_CAM_8814B(txdesc, value) \
SET_TX_DESC_SMH_CAM(txdesc, value)
#define GET_TX_DESC_SMH_CAM_8814B(txdesc) GET_TX_DESC_SMH_CAM(txdesc)
#define SET_TX_DESC_EXT_EDCA_8814B(txdesc, value) \
SET_TX_DESC_EXT_EDCA(txdesc, value)
#define GET_TX_DESC_EXT_EDCA_8814B(txdesc) GET_TX_DESC_EXT_EDCA(txdesc)
#define SET_TX_DESC_QSEL_8814B(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8814B(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8814B(txdesc, value) \
SET_TX_DESC_MACID_V1(txdesc, value)
#define GET_TX_DESC_MACID_8814B(txdesc) GET_TX_DESC_MACID_V1(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_CHK_EN_8814B(txdesc, value) \
SET_TX_DESC_CHK_EN_V1(txdesc, value)
#define GET_TX_DESC_CHK_EN_8814B(txdesc) GET_TX_DESC_CHK_EN_V1(txdesc)
#define SET_TX_DESC_DMA_PRI_8814B(txdesc, value) \
SET_TX_DESC_DMA_PRI(txdesc, value)
#define GET_TX_DESC_DMA_PRI_8814B(txdesc) GET_TX_DESC_DMA_PRI(txdesc)
#define SET_TX_DESC_MAX_AMSDU_MODE_8814B(txdesc, value) \
SET_TX_DESC_MAX_AMSDU_MODE(txdesc, value)
#define GET_TX_DESC_MAX_AMSDU_MODE_8814B(txdesc) \
GET_TX_DESC_MAX_AMSDU_MODE(txdesc)
#define SET_TX_DESC_DMA_TXAGG_NUM_8814B(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8814B(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8814B(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8814B(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_OFFLOAD_SIZE_8814B(txdesc, value) \
SET_TX_DESC_OFFLOAD_SIZE(txdesc, value)
#define GET_TX_DESC_OFFLOAD_SIZE_8814B(txdesc) GET_TX_DESC_OFFLOAD_SIZE(txdesc)
#define SET_TX_DESC_CHANNEL_DMA_8814B(txdesc, value) \
SET_TX_DESC_CHANNEL_DMA(txdesc, value)
#define GET_TX_DESC_CHANNEL_DMA_8814B(txdesc) GET_TX_DESC_CHANNEL_DMA(txdesc)
#define SET_TX_DESC_IE_CNT_8814B(txdesc, value) \
SET_TX_DESC_IE_CNT(txdesc, value)
#define GET_TX_DESC_IE_CNT_8814B(txdesc) GET_TX_DESC_IE_CNT(txdesc)
#define SET_TX_DESC_IE_CNT_EN_8814B(txdesc, value) \
SET_TX_DESC_IE_CNT_EN(txdesc, value)
#define GET_TX_DESC_IE_CNT_EN_8814B(txdesc) GET_TX_DESC_IE_CNT_EN(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8814B(txdesc, value) \
SET_TX_DESC_WHEADER_LEN_V1(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8814B(txdesc) GET_TX_DESC_WHEADER_LEN_V1(txdesc)
/*TXDESC_WORD4*/
/*TXDESC_WORD5*/
/*TXDESC_WORD6*/
/*TXDESC_WORD7*/
/*TXDESC_WORD8*/
/*TXDESC_WORD9*/
/*WORD10*/
#endif
#if (HALMAC_8198F_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8198F(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8198F(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8198F(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8198F(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8198F(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8198F(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_8198F(txdesc, value) \
SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL_8198F(txdesc) \
GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8198F(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8198F(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8198F(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8198F(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8198F(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8198F(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8198F(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8198F(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8198F(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8198F(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8198F(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8198F(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_HW_AES_IV_8198F(txdesc, value) \
SET_TX_DESC_HW_AES_IV_V2(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8198F(txdesc) GET_TX_DESC_HW_AES_IV_V2(txdesc)
#define SET_TX_DESC_FTM_EN_8198F(txdesc, value) \
SET_TX_DESC_FTM_EN_V1(txdesc, value)
#define GET_TX_DESC_FTM_EN_8198F(txdesc) GET_TX_DESC_FTM_EN_V1(txdesc)
#define SET_TX_DESC_MOREDATA_8198F(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8198F(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8198F(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8198F(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8198F(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8198F(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8198F(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8198F(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8198F(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8198F(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8198F(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8198F(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8198F(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8198F(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8198F(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8198F(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8198F(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8198F(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_SPECIAL_CW_8198F(txdesc, value) \
SET_TX_DESC_SPECIAL_CW(txdesc, value)
#define GET_TX_DESC_SPECIAL_CW_8198F(txdesc) GET_TX_DESC_SPECIAL_CW(txdesc)
#define SET_TX_DESC_MACID_8198F(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8198F(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_ANTCEL_D_8198F(txdesc, value) \
SET_TX_DESC_ANTCEL_D_V1(txdesc, value)
#define GET_TX_DESC_ANTCEL_D_8198F(txdesc) GET_TX_DESC_ANTCEL_D_V1(txdesc)
#define SET_TX_DESC_ANTSEL_C_8198F(txdesc, value) \
SET_TX_DESC_ANTSEL_C_V1(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8198F(txdesc) GET_TX_DESC_ANTSEL_C_V1(txdesc)
#define SET_TX_DESC_BT_NULL_8198F(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8198F(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8198F(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8198F(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8198F(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8198F(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8198F(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8198F(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8198F(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8198F(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8198F(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8198F(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8198F(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8198F(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8198F(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8198F(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8198F(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8198F(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8198F(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8198F(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8198F(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8198F(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8198F(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8198F(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8198F(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8198F(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8198F(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8198F(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8198F(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8198F(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8198F(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8198F(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8198F(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8198F(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8198F(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8198F(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8198F(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8198F(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8198F(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8198F(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8198F(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8198F(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8198F(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8198F(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8198F(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8198F(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8198F(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8198F(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8198F(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8198F(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8198F(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8198F(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8198F(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8198F(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8198F(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8198F(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8198F(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8198F(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8198F(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8198F(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8198F(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8198F(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8198F(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8198F(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8198F(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8198F(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8198F(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8198F(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8198F(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8198F(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8198F(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8198F(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8198F(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8198F(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_8198F(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_8198F(txdesc) GET_TX_DESC_TXPWR_OFSET(txdesc)
#define SET_TX_DESC_DROP_ID_8198F(txdesc, value) \
SET_TX_DESC_DROP_ID(txdesc, value)
#define GET_TX_DESC_DROP_ID_8198F(txdesc) GET_TX_DESC_DROP_ID(txdesc)
#define SET_TX_DESC_PORT_ID_8198F(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8198F(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_MULTIPLE_PORT_8198F(txdesc, value) \
SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_MULTIPLE_PORT_8198F(txdesc) \
GET_TX_DESC_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8198F(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8198F(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_RTS_SC_8198F(txdesc, value) \
SET_TX_DESC_RTS_SC(txdesc, value)
#define GET_TX_DESC_RTS_SC_8198F(txdesc) GET_TX_DESC_RTS_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8198F(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8198F(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8198F(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8198F(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8198F(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8198F(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8198F(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8198F(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8198F(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8198F(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8198F(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8198F(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8198F(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8198F(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANT_MAPD_8198F(txdesc, value) \
SET_TX_DESC_ANT_MAPD_V1(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8198F(txdesc) GET_TX_DESC_ANT_MAPD_V1(txdesc)
#define SET_TX_DESC_ANT_MAPC_8198F(txdesc, value) \
SET_TX_DESC_ANT_MAPC_V1(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8198F(txdesc) GET_TX_DESC_ANT_MAPC_V1(txdesc)
#define SET_TX_DESC_ANT_MAPB_8198F(txdesc, value) \
SET_TX_DESC_ANT_MAPB_V1(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8198F(txdesc) GET_TX_DESC_ANT_MAPB_V1(txdesc)
#define SET_TX_DESC_ANT_MAPA_8198F(txdesc, value) \
SET_TX_DESC_ANT_MAPA_V1(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8198F(txdesc) GET_TX_DESC_ANT_MAPA_V1(txdesc)
#define SET_TX_DESC_ANTSEL_B_8198F(txdesc, value) \
SET_TX_DESC_ANTSEL_B_V1(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8198F(txdesc) GET_TX_DESC_ANTSEL_B_V1(txdesc)
#define SET_TX_DESC_ANTSEL_A_8198F(txdesc, value) \
SET_TX_DESC_ANTSEL_A_V1(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8198F(txdesc) GET_TX_DESC_ANTSEL_A_V1(txdesc)
#define SET_TX_DESC_MBSSID_8198F(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8198F(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SWPS_SEQ_8198F(txdesc, value) \
SET_TX_DESC_SWPS_SEQ(txdesc, value)
#define GET_TX_DESC_SWPS_SEQ_8198F(txdesc) GET_TX_DESC_SWPS_SEQ(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8198F(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8198F(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8198F(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8198F(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8198F(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8198F(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_ANTSEL_EN_8198F(txdesc, value) \
SET_TX_DESC_ANTSEL_EN(txdesc, value)
#define GET_TX_DESC_ANTSEL_EN_8198F(txdesc) GET_TX_DESC_ANTSEL_EN(txdesc)
#define SET_TX_DESC_MBSSID_EX_8198F(txdesc, value) \
SET_TX_DESC_MBSSID_EX(txdesc, value)
#define GET_TX_DESC_MBSSID_EX_8198F(txdesc) GET_TX_DESC_MBSSID_EX(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8198F(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8198F(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8198F(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8198F(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8198F(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8198F(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8198F(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8198F(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8198F(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8198F(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8198F(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8198F(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8198F(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8198F(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8198F(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8198F(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8198F(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8198F(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8198F(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8198F(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8198F(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8198F(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8198F(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8198F(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8198F(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8198F(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8198F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8198F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8198F(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8198F(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_EN_HWEXSEQ_8198F(txdesc, value) \
SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWEXSEQ_8198F(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8198F(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8198F(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8198F(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8198F(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8198F(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8198F(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8198F(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8198F(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8198F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8198F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8198F(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8198F(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8198F(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8198F(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8198F(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8198F(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8198F(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8198F(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#endif
#if (HALMAC_8822C_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8822C(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8822C(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8822C(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8822C(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8822C(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8822C(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_8822C(txdesc, value) \
SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL_8822C(txdesc) \
GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8822C(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8822C(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8822C(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8822C(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8822C(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8822C(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8822C(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8822C(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8822C(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8822C(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8822C(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8822C(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_MOREDATA_8822C(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8822C(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8822C(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8822C(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8822C(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8822C(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8822C(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8822C(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8822C(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8822C(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8822C(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8822C(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8822C(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8822C(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8822C(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8822C(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8822C(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8822C(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8822C(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8822C(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV_8822C(txdesc, value) \
SET_TX_DESC_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8822C(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
#define SET_TX_DESC_FTM_EN_8822C(txdesc, value) \
SET_TX_DESC_FTM_EN(txdesc, value)
#define GET_TX_DESC_FTM_EN_8822C(txdesc) GET_TX_DESC_FTM_EN(txdesc)
#define SET_TX_DESC_G_ID_8822C(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8822C(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8822C(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8822C(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8822C(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8822C(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8822C(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8822C(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8822C(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8822C(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8822C(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8822C(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8822C(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8822C(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8822C(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8822C(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8822C(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8822C(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8822C(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8822C(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8822C(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8822C(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8822C(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8822C(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8822C(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8822C(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8822C(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8822C(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8822C(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8822C(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8822C(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8822C(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8822C(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8822C(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8822C(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8822C(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8822C(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8822C(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8822C(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8822C(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8822C(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8822C(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8822C(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8822C(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8822C(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8822C(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8822C(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8822C(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8822C(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8822C(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8822C(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8822C(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8822C(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8822C(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8822C(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8822C(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8822C(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8822C(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8822C(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8822C(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8822C(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8822C(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8822C(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8822C(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8822C(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8822C(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8822C(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8822C(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8822C(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8822C(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8822C(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8822C(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8822C(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8822C(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8822C(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8822C(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_ANTSEL_EN_8822C(txdesc, value) \
SET_TX_DESC_ANTSEL_EN_V1(txdesc, value)
#define GET_TX_DESC_ANTSEL_EN_8822C(txdesc) GET_TX_DESC_ANTSEL_EN_V1(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_8822C(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_TYPE_8822C(txdesc) \
GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc)
#define SET_TX_DESC_TX_ANT_8822C(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8822C(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_PORT_ID_8822C(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8822C(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_MULTIPLE_PORT_8822C(txdesc, value) \
SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_MULTIPLE_PORT_8822C(txdesc) \
GET_TX_DESC_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8822C(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8822C(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8822C(txdesc, value) \
SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8822C(txdesc) \
GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8822C(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8822C(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8822C(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8822C(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8822C(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8822C(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8822C(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8822C(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8822C(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8822C(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8822C(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8822C(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8822C(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8822C(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D_8822C(txdesc, value) \
SET_TX_DESC_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8822C(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
#define SET_TX_DESC_ANT_MAPD_8822C(txdesc, value) \
SET_TX_DESC_ANT_MAPD(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8822C(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
#define SET_TX_DESC_ANT_MAPC_8822C(txdesc, value) \
SET_TX_DESC_ANT_MAPC(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8822C(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
#define SET_TX_DESC_ANT_MAPB_8822C(txdesc, value) \
SET_TX_DESC_ANT_MAPB(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8822C(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
#define SET_TX_DESC_ANT_MAPA_8822C(txdesc, value) \
SET_TX_DESC_ANT_MAPA(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8822C(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
#define SET_TX_DESC_ANTSEL_C_8822C(txdesc, value) \
SET_TX_DESC_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8822C(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
#define SET_TX_DESC_ANTSEL_B_8822C(txdesc, value) \
SET_TX_DESC_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8822C(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
#define SET_TX_DESC_ANTSEL_A_8822C(txdesc, value) \
SET_TX_DESC_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8822C(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
#define SET_TX_DESC_MBSSID_8822C(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8822C(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SW_DEFINE_8822C(txdesc, value) \
SET_TX_DESC_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_SW_DEFINE_8822C(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8822C(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8822C(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8822C(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8822C(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8822C(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8822C(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8822C(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8822C(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8822C(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8822C(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8822C(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8822C(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8822C(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8822C(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8822C(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8822C(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8822C(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8822C(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8822C(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8822C(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8822C(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8822C(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8822C(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8822C(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8822C(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8822C(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8822C(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8822C(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8822C(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8822C(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8822C(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8822C(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8822C(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8822C(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8822C(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8822C(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_EN_HWEXSEQ_8822C(txdesc, value) \
SET_TX_DESC_EN_HWEXSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWEXSEQ_8822C(txdesc) GET_TX_DESC_EN_HWEXSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8822C(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8822C(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8822C(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8822C(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8822C(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8822C(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8822C(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8822C(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8822C(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8822C(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8822C(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8822C(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8822C(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8822C(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8822C(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8822C(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8822C(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8822C(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#define SET_TX_DESC_MU_DATARATE_8822C(txdesc, value) \
SET_TX_DESC_MU_DATARATE(txdesc, value)
#define GET_TX_DESC_MU_DATARATE_8822C(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
#define SET_TX_DESC_MU_RC_8822C(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
#define GET_TX_DESC_MU_RC_8822C(txdesc) GET_TX_DESC_MU_RC(txdesc)
#define SET_TX_DESC_SND_PKT_SEL_8822C(txdesc, value) \
SET_TX_DESC_SND_PKT_SEL(txdesc, value)
#define GET_TX_DESC_SND_PKT_SEL_8822C(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
#endif
#if (HALMAC_8192F_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_GF_8192F(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8192F(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8192F(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8192F(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8192F(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8192F(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_HTC_8192F(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8192F(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8192F(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8192F(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8192F(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8192F(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8192F(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8192F(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_KEYID_SEL_8192F(txdesc, value) \
SET_TX_DESC_KEYID_SEL(txdesc, value)
#define GET_TX_DESC_KEYID_SEL_8192F(txdesc) GET_TX_DESC_KEYID_SEL(txdesc)
#define SET_TX_DESC_MOREDATA_8192F(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8192F(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8192F(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8192F(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8192F(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8192F(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8192F(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8192F(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8192F(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8192F(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8192F(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8192F(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8192F(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8192F(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8192F(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8192F(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8192F(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8192F(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8192F(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8192F(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_FTM_EN_8192F(txdesc, value) \
SET_TX_DESC_FTM_EN(txdesc, value)
#define GET_TX_DESC_FTM_EN_8192F(txdesc) GET_TX_DESC_FTM_EN(txdesc)
#define SET_TX_DESC_G_ID_8192F(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8192F(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8192F(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8192F(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8192F(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8192F(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8192F(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8192F(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8192F(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8192F(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8192F(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8192F(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8192F(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8192F(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8192F(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8192F(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8192F(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8192F(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8192F(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8192F(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8192F(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8192F(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8192F(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8192F(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8192F(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8192F(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8192F(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8192F(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8192F(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8192F(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8192F(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8192F(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8192F(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8192F(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8192F(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8192F(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8192F(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8192F(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8192F(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8192F(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8192F(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8192F(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8192F(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8192F(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8192F(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8192F(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8192F(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8192F(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8192F(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8192F(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8192F(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8192F(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8192F(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8192F(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8192F(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8192F(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8192F(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8192F(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8192F(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8192F(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8192F(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8192F(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8192F(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8192F(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8192F(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8192F(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8192F(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8192F(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8192F(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8192F(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8192F(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8192F(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8192F(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8192F(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8192F(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8192F(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_8192F(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET_TYPE_V1(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_TYPE_8192F(txdesc) \
GET_TX_DESC_TXPWR_OFSET_TYPE_V1(txdesc)
#define SET_TX_DESC_TX_ANT_8192F(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8192F(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_DROP_ID_8192F(txdesc, value) \
SET_TX_DESC_DROP_ID_V1(txdesc, value)
#define GET_TX_DESC_DROP_ID_8192F(txdesc) GET_TX_DESC_DROP_ID_V1(txdesc)
#define SET_TX_DESC_PORT_ID_8192F(txdesc, value) \
SET_TX_DESC_PORT_ID_V1(txdesc, value)
#define GET_TX_DESC_PORT_ID_8192F(txdesc) GET_TX_DESC_PORT_ID_V1(txdesc)
#define SET_TX_DESC_RTS_SC_8192F(txdesc, value) \
SET_TX_DESC_RTS_SC(txdesc, value)
#define GET_TX_DESC_RTS_SC_8192F(txdesc) GET_TX_DESC_RTS_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8192F(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8192F(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8192F(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8192F(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8192F(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8192F(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8192F(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8192F(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8192F(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8192F(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8192F(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8192F(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8192F(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8192F(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANT_MAPC_8192F(txdesc, value) \
SET_TX_DESC_ANT_MAPC_V2(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8192F(txdesc) GET_TX_DESC_ANT_MAPC_V2(txdesc)
#define SET_TX_DESC_ANT_MAPB_8192F(txdesc, value) \
SET_TX_DESC_ANT_MAPB_V2(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8192F(txdesc) GET_TX_DESC_ANT_MAPB_V2(txdesc)
#define SET_TX_DESC_ANT_MAPA_8192F(txdesc, value) \
SET_TX_DESC_ANT_MAPA_V2(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8192F(txdesc) GET_TX_DESC_ANT_MAPA_V2(txdesc)
#define SET_TX_DESC_ANTSEL_D_8192F(txdesc, value) \
SET_TX_DESC_ANTSEL_D_V1(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8192F(txdesc) GET_TX_DESC_ANTSEL_D_V1(txdesc)
#define SET_TX_DESC_ANTSEL_C_8192F(txdesc, value) \
SET_TX_DESC_ANTSEL_C_V2(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8192F(txdesc) GET_TX_DESC_ANTSEL_C_V2(txdesc)
#define SET_TX_DESC_ANTSEL_B_8192F(txdesc, value) \
SET_TX_DESC_ANTSEL_B_V2(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8192F(txdesc) GET_TX_DESC_ANTSEL_B_V2(txdesc)
#define SET_TX_DESC_ANTSEL_A_8192F(txdesc, value) \
SET_TX_DESC_ANTSEL_A_V2(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8192F(txdesc) GET_TX_DESC_ANTSEL_A_V2(txdesc)
#define SET_TX_DESC_MBSSID_8192F(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8192F(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SWPS_SEQ_8192F(txdesc, value) \
SET_TX_DESC_SWPS_SEQ(txdesc, value)
#define GET_TX_DESC_SWPS_SEQ_8192F(txdesc) GET_TX_DESC_SWPS_SEQ(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8192F(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8192F(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_ANT_MAPD_8192F(txdesc, value) \
SET_TX_DESC_ANT_MAPD_V2(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8192F(txdesc) GET_TX_DESC_ANT_MAPD_V2(txdesc)
#define SET_TX_DESC_ANTSEL_EN_8192F(txdesc, value) \
SET_TX_DESC_ANTSEL_EN_V2(txdesc, value)
#define GET_TX_DESC_ANTSEL_EN_8192F(txdesc) GET_TX_DESC_ANTSEL_EN_V2(txdesc)
#define SET_TX_DESC_MBSSID_EX_8192F(txdesc, value) \
SET_TX_DESC_MBSSID_EX_V1(txdesc, value)
#define GET_TX_DESC_MBSSID_EX_8192F(txdesc) GET_TX_DESC_MBSSID_EX_V1(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8192F(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8192F(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8192F(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8192F(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8192F(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8192F(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TAILPAGE_L_8192F(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8192F(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8192F(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8192F(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8192F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8192F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_8192F(txdesc, value) \
SET_TX_DESC_EN_HWSEQ(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_8192F(txdesc) GET_TX_DESC_EN_HWSEQ(txdesc)
#define SET_TX_DESC_DATA_RC_8192F(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8192F(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8192F(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8192F(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8192F(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8192F(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_FINAL_DATA_RATE_8192F(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE_V1(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8192F(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE_V1(txdesc)
#define SET_TX_DESC_SW_SEQ_8192F(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8192F(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_PADDING_LEN_8192F(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8192F(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8192F(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8192F(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#endif
#if (HALMAC_8812F_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ_8812F(txdesc, value) \
SET_TX_DESC_DISQSELSEQ(txdesc, value)
#define GET_TX_DESC_DISQSELSEQ_8812F(txdesc) GET_TX_DESC_DISQSELSEQ(txdesc)
#define SET_TX_DESC_GF_8812F(txdesc, value) SET_TX_DESC_GF(txdesc, value)
#define GET_TX_DESC_GF_8812F(txdesc) GET_TX_DESC_GF(txdesc)
#define SET_TX_DESC_NO_ACM_8812F(txdesc, value) \
SET_TX_DESC_NO_ACM(txdesc, value)
#define GET_TX_DESC_NO_ACM_8812F(txdesc) GET_TX_DESC_NO_ACM(txdesc)
#define SET_TX_DESC_BCNPKT_TSF_CTRL_8812F(txdesc, value) \
SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL_8812F(txdesc) \
GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc)
#define SET_TX_DESC_AMSDU_PAD_EN_8812F(txdesc, value) \
SET_TX_DESC_AMSDU_PAD_EN(txdesc, value)
#define GET_TX_DESC_AMSDU_PAD_EN_8812F(txdesc) GET_TX_DESC_AMSDU_PAD_EN(txdesc)
#define SET_TX_DESC_LS_8812F(txdesc, value) SET_TX_DESC_LS(txdesc, value)
#define GET_TX_DESC_LS_8812F(txdesc) GET_TX_DESC_LS(txdesc)
#define SET_TX_DESC_HTC_8812F(txdesc, value) SET_TX_DESC_HTC(txdesc, value)
#define GET_TX_DESC_HTC_8812F(txdesc) GET_TX_DESC_HTC(txdesc)
#define SET_TX_DESC_BMC_8812F(txdesc, value) SET_TX_DESC_BMC(txdesc, value)
#define GET_TX_DESC_BMC_8812F(txdesc) GET_TX_DESC_BMC(txdesc)
#define SET_TX_DESC_OFFSET_8812F(txdesc, value) \
SET_TX_DESC_OFFSET(txdesc, value)
#define GET_TX_DESC_OFFSET_8812F(txdesc) GET_TX_DESC_OFFSET(txdesc)
#define SET_TX_DESC_TXPKTSIZE_8812F(txdesc, value) \
SET_TX_DESC_TXPKTSIZE(txdesc, value)
#define GET_TX_DESC_TXPKTSIZE_8812F(txdesc) GET_TX_DESC_TXPKTSIZE(txdesc)
/*WORD1*/
#define SET_TX_DESC_MOREDATA_8812F(txdesc, value) \
SET_TX_DESC_MOREDATA(txdesc, value)
#define GET_TX_DESC_MOREDATA_8812F(txdesc) GET_TX_DESC_MOREDATA(txdesc)
#define SET_TX_DESC_PKT_OFFSET_8812F(txdesc, value) \
SET_TX_DESC_PKT_OFFSET(txdesc, value)
#define GET_TX_DESC_PKT_OFFSET_8812F(txdesc) GET_TX_DESC_PKT_OFFSET(txdesc)
#define SET_TX_DESC_SEC_TYPE_8812F(txdesc, value) \
SET_TX_DESC_SEC_TYPE(txdesc, value)
#define GET_TX_DESC_SEC_TYPE_8812F(txdesc) GET_TX_DESC_SEC_TYPE(txdesc)
#define SET_TX_DESC_EN_DESC_ID_8812F(txdesc, value) \
SET_TX_DESC_EN_DESC_ID(txdesc, value)
#define GET_TX_DESC_EN_DESC_ID_8812F(txdesc) GET_TX_DESC_EN_DESC_ID(txdesc)
#define SET_TX_DESC_RATE_ID_8812F(txdesc, value) \
SET_TX_DESC_RATE_ID(txdesc, value)
#define GET_TX_DESC_RATE_ID_8812F(txdesc) GET_TX_DESC_RATE_ID(txdesc)
#define SET_TX_DESC_PIFS_8812F(txdesc, value) SET_TX_DESC_PIFS(txdesc, value)
#define GET_TX_DESC_PIFS_8812F(txdesc) GET_TX_DESC_PIFS(txdesc)
#define SET_TX_DESC_LSIG_TXOP_EN_8812F(txdesc, value) \
SET_TX_DESC_LSIG_TXOP_EN(txdesc, value)
#define GET_TX_DESC_LSIG_TXOP_EN_8812F(txdesc) GET_TX_DESC_LSIG_TXOP_EN(txdesc)
#define SET_TX_DESC_RD_NAV_EXT_8812F(txdesc, value) \
SET_TX_DESC_RD_NAV_EXT(txdesc, value)
#define GET_TX_DESC_RD_NAV_EXT_8812F(txdesc) GET_TX_DESC_RD_NAV_EXT(txdesc)
#define SET_TX_DESC_QSEL_8812F(txdesc, value) SET_TX_DESC_QSEL(txdesc, value)
#define GET_TX_DESC_QSEL_8812F(txdesc) GET_TX_DESC_QSEL(txdesc)
#define SET_TX_DESC_MACID_8812F(txdesc, value) SET_TX_DESC_MACID(txdesc, value)
#define GET_TX_DESC_MACID_8812F(txdesc) GET_TX_DESC_MACID(txdesc)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV_8812F(txdesc, value) \
SET_TX_DESC_HW_AES_IV(txdesc, value)
#define GET_TX_DESC_HW_AES_IV_8812F(txdesc) GET_TX_DESC_HW_AES_IV(txdesc)
#define SET_TX_DESC_FTM_EN_8812F(txdesc, value) \
SET_TX_DESC_FTM_EN(txdesc, value)
#define GET_TX_DESC_FTM_EN_8812F(txdesc) GET_TX_DESC_FTM_EN(txdesc)
#define SET_TX_DESC_G_ID_8812F(txdesc, value) SET_TX_DESC_G_ID(txdesc, value)
#define GET_TX_DESC_G_ID_8812F(txdesc) GET_TX_DESC_G_ID(txdesc)
#define SET_TX_DESC_BT_NULL_8812F(txdesc, value) \
SET_TX_DESC_BT_NULL(txdesc, value)
#define GET_TX_DESC_BT_NULL_8812F(txdesc) GET_TX_DESC_BT_NULL(txdesc)
#define SET_TX_DESC_AMPDU_DENSITY_8812F(txdesc, value) \
SET_TX_DESC_AMPDU_DENSITY(txdesc, value)
#define GET_TX_DESC_AMPDU_DENSITY_8812F(txdesc) \
GET_TX_DESC_AMPDU_DENSITY(txdesc)
#define SET_TX_DESC_SPE_RPT_8812F(txdesc, value) \
SET_TX_DESC_SPE_RPT(txdesc, value)
#define GET_TX_DESC_SPE_RPT_8812F(txdesc) GET_TX_DESC_SPE_RPT(txdesc)
#define SET_TX_DESC_RAW_8812F(txdesc, value) SET_TX_DESC_RAW(txdesc, value)
#define GET_TX_DESC_RAW_8812F(txdesc) GET_TX_DESC_RAW(txdesc)
#define SET_TX_DESC_MOREFRAG_8812F(txdesc, value) \
SET_TX_DESC_MOREFRAG(txdesc, value)
#define GET_TX_DESC_MOREFRAG_8812F(txdesc) GET_TX_DESC_MOREFRAG(txdesc)
#define SET_TX_DESC_BK_8812F(txdesc, value) SET_TX_DESC_BK(txdesc, value)
#define GET_TX_DESC_BK_8812F(txdesc) GET_TX_DESC_BK(txdesc)
#define SET_TX_DESC_NULL_1_8812F(txdesc, value) \
SET_TX_DESC_NULL_1(txdesc, value)
#define GET_TX_DESC_NULL_1_8812F(txdesc) GET_TX_DESC_NULL_1(txdesc)
#define SET_TX_DESC_NULL_0_8812F(txdesc, value) \
SET_TX_DESC_NULL_0(txdesc, value)
#define GET_TX_DESC_NULL_0_8812F(txdesc) GET_TX_DESC_NULL_0(txdesc)
#define SET_TX_DESC_RDG_EN_8812F(txdesc, value) \
SET_TX_DESC_RDG_EN(txdesc, value)
#define GET_TX_DESC_RDG_EN_8812F(txdesc) GET_TX_DESC_RDG_EN(txdesc)
#define SET_TX_DESC_AGG_EN_8812F(txdesc, value) \
SET_TX_DESC_AGG_EN(txdesc, value)
#define GET_TX_DESC_AGG_EN_8812F(txdesc) GET_TX_DESC_AGG_EN(txdesc)
#define SET_TX_DESC_CCA_RTS_8812F(txdesc, value) \
SET_TX_DESC_CCA_RTS(txdesc, value)
#define GET_TX_DESC_CCA_RTS_8812F(txdesc) GET_TX_DESC_CCA_RTS(txdesc)
#define SET_TX_DESC_TRI_FRAME_8812F(txdesc, value) \
SET_TX_DESC_TRI_FRAME(txdesc, value)
#define GET_TX_DESC_TRI_FRAME_8812F(txdesc) GET_TX_DESC_TRI_FRAME(txdesc)
#define SET_TX_DESC_P_AID_8812F(txdesc, value) SET_TX_DESC_P_AID(txdesc, value)
#define GET_TX_DESC_P_AID_8812F(txdesc) GET_TX_DESC_P_AID(txdesc)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME_8812F(txdesc, value) \
SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value)
#define GET_TX_DESC_AMPDU_MAX_TIME_8812F(txdesc) \
GET_TX_DESC_AMPDU_MAX_TIME(txdesc)
#define SET_TX_DESC_NDPA_8812F(txdesc, value) SET_TX_DESC_NDPA(txdesc, value)
#define GET_TX_DESC_NDPA_8812F(txdesc) GET_TX_DESC_NDPA(txdesc)
#define SET_TX_DESC_MAX_AGG_NUM_8812F(txdesc, value) \
SET_TX_DESC_MAX_AGG_NUM(txdesc, value)
#define GET_TX_DESC_MAX_AGG_NUM_8812F(txdesc) GET_TX_DESC_MAX_AGG_NUM(txdesc)
#define SET_TX_DESC_USE_MAX_TIME_EN_8812F(txdesc, value) \
SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value)
#define GET_TX_DESC_USE_MAX_TIME_EN_8812F(txdesc) \
GET_TX_DESC_USE_MAX_TIME_EN(txdesc)
#define SET_TX_DESC_NAVUSEHDR_8812F(txdesc, value) \
SET_TX_DESC_NAVUSEHDR(txdesc, value)
#define GET_TX_DESC_NAVUSEHDR_8812F(txdesc) GET_TX_DESC_NAVUSEHDR(txdesc)
#define SET_TX_DESC_CHK_EN_8812F(txdesc, value) \
SET_TX_DESC_CHK_EN(txdesc, value)
#define GET_TX_DESC_CHK_EN_8812F(txdesc) GET_TX_DESC_CHK_EN(txdesc)
#define SET_TX_DESC_HW_RTS_EN_8812F(txdesc, value) \
SET_TX_DESC_HW_RTS_EN(txdesc, value)
#define GET_TX_DESC_HW_RTS_EN_8812F(txdesc) GET_TX_DESC_HW_RTS_EN(txdesc)
#define SET_TX_DESC_RTSEN_8812F(txdesc, value) SET_TX_DESC_RTSEN(txdesc, value)
#define GET_TX_DESC_RTSEN_8812F(txdesc) GET_TX_DESC_RTSEN(txdesc)
#define SET_TX_DESC_CTS2SELF_8812F(txdesc, value) \
SET_TX_DESC_CTS2SELF(txdesc, value)
#define GET_TX_DESC_CTS2SELF_8812F(txdesc) GET_TX_DESC_CTS2SELF(txdesc)
#define SET_TX_DESC_DISDATAFB_8812F(txdesc, value) \
SET_TX_DESC_DISDATAFB(txdesc, value)
#define GET_TX_DESC_DISDATAFB_8812F(txdesc) GET_TX_DESC_DISDATAFB(txdesc)
#define SET_TX_DESC_DISRTSFB_8812F(txdesc, value) \
SET_TX_DESC_DISRTSFB(txdesc, value)
#define GET_TX_DESC_DISRTSFB_8812F(txdesc) GET_TX_DESC_DISRTSFB(txdesc)
#define SET_TX_DESC_USE_RATE_8812F(txdesc, value) \
SET_TX_DESC_USE_RATE(txdesc, value)
#define GET_TX_DESC_USE_RATE_8812F(txdesc) GET_TX_DESC_USE_RATE(txdesc)
#define SET_TX_DESC_HW_SSN_SEL_8812F(txdesc, value) \
SET_TX_DESC_HW_SSN_SEL(txdesc, value)
#define GET_TX_DESC_HW_SSN_SEL_8812F(txdesc) GET_TX_DESC_HW_SSN_SEL(txdesc)
#define SET_TX_DESC_WHEADER_LEN_8812F(txdesc, value) \
SET_TX_DESC_WHEADER_LEN(txdesc, value)
#define GET_TX_DESC_WHEADER_LEN_8812F(txdesc) GET_TX_DESC_WHEADER_LEN(txdesc)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX_8812F(txdesc, value) \
SET_TX_DESC_PCTS_MASK_IDX(txdesc, value)
#define GET_TX_DESC_PCTS_MASK_IDX_8812F(txdesc) \
GET_TX_DESC_PCTS_MASK_IDX(txdesc)
#define SET_TX_DESC_PCTS_EN_8812F(txdesc, value) \
SET_TX_DESC_PCTS_EN(txdesc, value)
#define GET_TX_DESC_PCTS_EN_8812F(txdesc) GET_TX_DESC_PCTS_EN(txdesc)
#define SET_TX_DESC_RTSRATE_8812F(txdesc, value) \
SET_TX_DESC_RTSRATE(txdesc, value)
#define GET_TX_DESC_RTSRATE_8812F(txdesc) GET_TX_DESC_RTSRATE(txdesc)
#define SET_TX_DESC_RTS_DATA_RTY_LMT_8812F(txdesc, value) \
SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT_8812F(txdesc) \
GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc)
#define SET_TX_DESC_RTY_LMT_EN_8812F(txdesc, value) \
SET_TX_DESC_RTY_LMT_EN(txdesc, value)
#define GET_TX_DESC_RTY_LMT_EN_8812F(txdesc) GET_TX_DESC_RTY_LMT_EN(txdesc)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE_8812F(txdesc, value) \
SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE_8812F(txdesc) \
GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE_8812F(txdesc, value) \
SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE_8812F(txdesc) \
GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc)
#define SET_TX_DESC_TRY_RATE_8812F(txdesc, value) \
SET_TX_DESC_TRY_RATE(txdesc, value)
#define GET_TX_DESC_TRY_RATE_8812F(txdesc) GET_TX_DESC_TRY_RATE(txdesc)
#define SET_TX_DESC_DATARATE_8812F(txdesc, value) \
SET_TX_DESC_DATARATE(txdesc, value)
#define GET_TX_DESC_DATARATE_8812F(txdesc) GET_TX_DESC_DATARATE(txdesc)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED_8812F(txdesc, value) \
SET_TX_DESC_POLLUTED(txdesc, value)
#define GET_TX_DESC_POLLUTED_8812F(txdesc) GET_TX_DESC_POLLUTED(txdesc)
#define SET_TX_DESC_ANTSEL_EN_8812F(txdesc, value) \
SET_TX_DESC_ANTSEL_EN_V1(txdesc, value)
#define GET_TX_DESC_ANTSEL_EN_8812F(txdesc) GET_TX_DESC_ANTSEL_EN_V1(txdesc)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_8812F(txdesc, value) \
SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value)
#define GET_TX_DESC_TXPWR_OFSET_TYPE_8812F(txdesc) \
GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc)
#define SET_TX_DESC_TX_ANT_8812F(txdesc, value) \
SET_TX_DESC_TX_ANT(txdesc, value)
#define GET_TX_DESC_TX_ANT_8812F(txdesc) GET_TX_DESC_TX_ANT(txdesc)
#define SET_TX_DESC_PORT_ID_8812F(txdesc, value) \
SET_TX_DESC_PORT_ID(txdesc, value)
#define GET_TX_DESC_PORT_ID_8812F(txdesc) GET_TX_DESC_PORT_ID(txdesc)
#define SET_TX_DESC_MULTIPLE_PORT_8812F(txdesc, value) \
SET_TX_DESC_MULTIPLE_PORT(txdesc, value)
#define GET_TX_DESC_MULTIPLE_PORT_8812F(txdesc) \
GET_TX_DESC_MULTIPLE_PORT(txdesc)
#define SET_TX_DESC_SIGNALING_TAPKT_EN_8812F(txdesc, value) \
SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN_8812F(txdesc) \
GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC_8812F(txdesc, value) \
SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value)
#define GET_TX_DESC_SIGNALING_TA_PKT_SC_8812F(txdesc) \
GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc)
#define SET_TX_DESC_RTS_SHORT_8812F(txdesc, value) \
SET_TX_DESC_RTS_SHORT(txdesc, value)
#define GET_TX_DESC_RTS_SHORT_8812F(txdesc) GET_TX_DESC_RTS_SHORT(txdesc)
#define SET_TX_DESC_VCS_STBC_8812F(txdesc, value) \
SET_TX_DESC_VCS_STBC(txdesc, value)
#define GET_TX_DESC_VCS_STBC_8812F(txdesc) GET_TX_DESC_VCS_STBC(txdesc)
#define SET_TX_DESC_DATA_STBC_8812F(txdesc, value) \
SET_TX_DESC_DATA_STBC(txdesc, value)
#define GET_TX_DESC_DATA_STBC_8812F(txdesc) GET_TX_DESC_DATA_STBC(txdesc)
#define SET_TX_DESC_DATA_LDPC_8812F(txdesc, value) \
SET_TX_DESC_DATA_LDPC(txdesc, value)
#define GET_TX_DESC_DATA_LDPC_8812F(txdesc) GET_TX_DESC_DATA_LDPC(txdesc)
#define SET_TX_DESC_DATA_BW_8812F(txdesc, value) \
SET_TX_DESC_DATA_BW(txdesc, value)
#define GET_TX_DESC_DATA_BW_8812F(txdesc) GET_TX_DESC_DATA_BW(txdesc)
#define SET_TX_DESC_DATA_SHORT_8812F(txdesc, value) \
SET_TX_DESC_DATA_SHORT(txdesc, value)
#define GET_TX_DESC_DATA_SHORT_8812F(txdesc) GET_TX_DESC_DATA_SHORT(txdesc)
#define SET_TX_DESC_DATA_SC_8812F(txdesc, value) \
SET_TX_DESC_DATA_SC(txdesc, value)
#define GET_TX_DESC_DATA_SC_8812F(txdesc) GET_TX_DESC_DATA_SC(txdesc)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D_8812F(txdesc, value) \
SET_TX_DESC_ANTSEL_D(txdesc, value)
#define GET_TX_DESC_ANTSEL_D_8812F(txdesc) GET_TX_DESC_ANTSEL_D(txdesc)
#define SET_TX_DESC_ANT_MAPD_8812F(txdesc, value) \
SET_TX_DESC_ANT_MAPD(txdesc, value)
#define GET_TX_DESC_ANT_MAPD_8812F(txdesc) GET_TX_DESC_ANT_MAPD(txdesc)
#define SET_TX_DESC_ANT_MAPC_8812F(txdesc, value) \
SET_TX_DESC_ANT_MAPC(txdesc, value)
#define GET_TX_DESC_ANT_MAPC_8812F(txdesc) GET_TX_DESC_ANT_MAPC(txdesc)
#define SET_TX_DESC_ANT_MAPB_8812F(txdesc, value) \
SET_TX_DESC_ANT_MAPB(txdesc, value)
#define GET_TX_DESC_ANT_MAPB_8812F(txdesc) GET_TX_DESC_ANT_MAPB(txdesc)
#define SET_TX_DESC_ANT_MAPA_8812F(txdesc, value) \
SET_TX_DESC_ANT_MAPA(txdesc, value)
#define GET_TX_DESC_ANT_MAPA_8812F(txdesc) GET_TX_DESC_ANT_MAPA(txdesc)
#define SET_TX_DESC_ANTSEL_C_8812F(txdesc, value) \
SET_TX_DESC_ANTSEL_C(txdesc, value)
#define GET_TX_DESC_ANTSEL_C_8812F(txdesc) GET_TX_DESC_ANTSEL_C(txdesc)
#define SET_TX_DESC_ANTSEL_B_8812F(txdesc, value) \
SET_TX_DESC_ANTSEL_B(txdesc, value)
#define GET_TX_DESC_ANTSEL_B_8812F(txdesc) GET_TX_DESC_ANTSEL_B(txdesc)
#define SET_TX_DESC_ANTSEL_A_8812F(txdesc, value) \
SET_TX_DESC_ANTSEL_A(txdesc, value)
#define GET_TX_DESC_ANTSEL_A_8812F(txdesc) GET_TX_DESC_ANTSEL_A(txdesc)
#define SET_TX_DESC_MBSSID_8812F(txdesc, value) \
SET_TX_DESC_MBSSID(txdesc, value)
#define GET_TX_DESC_MBSSID_8812F(txdesc) GET_TX_DESC_MBSSID(txdesc)
#define SET_TX_DESC_SW_DEFINE_8812F(txdesc, value) \
SET_TX_DESC_SW_DEFINE(txdesc, value)
#define GET_TX_DESC_SW_DEFINE_8812F(txdesc) GET_TX_DESC_SW_DEFINE(txdesc)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM_8812F(txdesc, value) \
SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_8812F(txdesc) \
GET_TX_DESC_DMA_TXAGG_NUM(txdesc)
#define SET_TX_DESC_FINAL_DATA_RATE_8812F(txdesc, value) \
SET_TX_DESC_FINAL_DATA_RATE(txdesc, value)
#define GET_TX_DESC_FINAL_DATA_RATE_8812F(txdesc) \
GET_TX_DESC_FINAL_DATA_RATE(txdesc)
#define SET_TX_DESC_NTX_MAP_8812F(txdesc, value) \
SET_TX_DESC_NTX_MAP(txdesc, value)
#define GET_TX_DESC_NTX_MAP_8812F(txdesc) GET_TX_DESC_NTX_MAP(txdesc)
#define SET_TX_DESC_TX_BUFF_SIZE_8812F(txdesc, value) \
SET_TX_DESC_TX_BUFF_SIZE(txdesc, value)
#define GET_TX_DESC_TX_BUFF_SIZE_8812F(txdesc) GET_TX_DESC_TX_BUFF_SIZE(txdesc)
#define SET_TX_DESC_TXDESC_CHECKSUM_8812F(txdesc, value) \
SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_8812F(txdesc) \
GET_TX_DESC_TXDESC_CHECKSUM(txdesc)
#define SET_TX_DESC_TIMESTAMP_8812F(txdesc, value) \
SET_TX_DESC_TIMESTAMP(txdesc, value)
#define GET_TX_DESC_TIMESTAMP_8812F(txdesc) GET_TX_DESC_TIMESTAMP(txdesc)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP_8812F(txdesc, value) \
SET_TX_DESC_TXWIFI_CP(txdesc, value)
#define GET_TX_DESC_TXWIFI_CP_8812F(txdesc) GET_TX_DESC_TXWIFI_CP(txdesc)
#define SET_TX_DESC_MAC_CP_8812F(txdesc, value) \
SET_TX_DESC_MAC_CP(txdesc, value)
#define GET_TX_DESC_MAC_CP_8812F(txdesc) GET_TX_DESC_MAC_CP(txdesc)
#define SET_TX_DESC_STW_PKTRE_DIS_8812F(txdesc, value) \
SET_TX_DESC_STW_PKTRE_DIS(txdesc, value)
#define GET_TX_DESC_STW_PKTRE_DIS_8812F(txdesc) \
GET_TX_DESC_STW_PKTRE_DIS(txdesc)
#define SET_TX_DESC_STW_RB_DIS_8812F(txdesc, value) \
SET_TX_DESC_STW_RB_DIS(txdesc, value)
#define GET_TX_DESC_STW_RB_DIS_8812F(txdesc) GET_TX_DESC_STW_RB_DIS(txdesc)
#define SET_TX_DESC_STW_RATE_DIS_8812F(txdesc, value) \
SET_TX_DESC_STW_RATE_DIS(txdesc, value)
#define GET_TX_DESC_STW_RATE_DIS_8812F(txdesc) GET_TX_DESC_STW_RATE_DIS(txdesc)
#define SET_TX_DESC_STW_ANT_DIS_8812F(txdesc, value) \
SET_TX_DESC_STW_ANT_DIS(txdesc, value)
#define GET_TX_DESC_STW_ANT_DIS_8812F(txdesc) GET_TX_DESC_STW_ANT_DIS(txdesc)
#define SET_TX_DESC_STW_EN_8812F(txdesc, value) \
SET_TX_DESC_STW_EN(txdesc, value)
#define GET_TX_DESC_STW_EN_8812F(txdesc) GET_TX_DESC_STW_EN(txdesc)
#define SET_TX_DESC_SMH_EN_8812F(txdesc, value) \
SET_TX_DESC_SMH_EN(txdesc, value)
#define GET_TX_DESC_SMH_EN_8812F(txdesc) GET_TX_DESC_SMH_EN(txdesc)
#define SET_TX_DESC_TAILPAGE_L_8812F(txdesc, value) \
SET_TX_DESC_TAILPAGE_L(txdesc, value)
#define GET_TX_DESC_TAILPAGE_L_8812F(txdesc) GET_TX_DESC_TAILPAGE_L(txdesc)
#define SET_TX_DESC_SDIO_DMASEQ_8812F(txdesc, value) \
SET_TX_DESC_SDIO_DMASEQ(txdesc, value)
#define GET_TX_DESC_SDIO_DMASEQ_8812F(txdesc) GET_TX_DESC_SDIO_DMASEQ(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_L_8812F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_L_8812F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_L(txdesc)
#define SET_TX_DESC_EN_HWSEQ_MODE_8812F(txdesc, value) \
SET_TX_DESC_EN_HWSEQ_MODE(txdesc, value)
#define GET_TX_DESC_EN_HWSEQ_MODE_8812F(txdesc) \
GET_TX_DESC_EN_HWSEQ_MODE(txdesc)
#define SET_TX_DESC_DATA_RC_8812F(txdesc, value) \
SET_TX_DESC_DATA_RC(txdesc, value)
#define GET_TX_DESC_DATA_RC_8812F(txdesc) GET_TX_DESC_DATA_RC(txdesc)
#define SET_TX_DESC_BAR_RTY_TH_8812F(txdesc, value) \
SET_TX_DESC_BAR_RTY_TH(txdesc, value)
#define GET_TX_DESC_BAR_RTY_TH_8812F(txdesc) GET_TX_DESC_BAR_RTY_TH(txdesc)
#define SET_TX_DESC_RTS_RC_8812F(txdesc, value) \
SET_TX_DESC_RTS_RC(txdesc, value)
#define GET_TX_DESC_RTS_RC_8812F(txdesc) GET_TX_DESC_RTS_RC(txdesc)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H_8812F(txdesc, value) \
SET_TX_DESC_TAILPAGE_H(txdesc, value)
#define GET_TX_DESC_TAILPAGE_H_8812F(txdesc) GET_TX_DESC_TAILPAGE_H(txdesc)
#define SET_TX_DESC_NEXTHEADPAGE_H_8812F(txdesc, value) \
SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value)
#define GET_TX_DESC_NEXTHEADPAGE_H_8812F(txdesc) \
GET_TX_DESC_NEXTHEADPAGE_H(txdesc)
#define SET_TX_DESC_SW_SEQ_8812F(txdesc, value) \
SET_TX_DESC_SW_SEQ(txdesc, value)
#define GET_TX_DESC_SW_SEQ_8812F(txdesc) GET_TX_DESC_SW_SEQ(txdesc)
#define SET_TX_DESC_TXBF_PATH_8812F(txdesc, value) \
SET_TX_DESC_TXBF_PATH(txdesc, value)
#define GET_TX_DESC_TXBF_PATH_8812F(txdesc) GET_TX_DESC_TXBF_PATH(txdesc)
#define SET_TX_DESC_PADDING_LEN_8812F(txdesc, value) \
SET_TX_DESC_PADDING_LEN(txdesc, value)
#define GET_TX_DESC_PADDING_LEN_8812F(txdesc) GET_TX_DESC_PADDING_LEN(txdesc)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET_8812F(txdesc, value) \
SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET_8812F(txdesc) \
GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc)
/*WORD10*/
#define SET_TX_DESC_HT_DATA_SND_8812F(txdesc, value) \
SET_TX_DESC_HT_DATA_SND(txdesc, value)
#define GET_TX_DESC_HT_DATA_SND_8812F(txdesc) GET_TX_DESC_HT_DATA_SND(txdesc)
#define SET_TX_DESC_SHCUT_CAM_8812F(txdesc, value) \
SET_TX_DESC_SHCUT_CAM(txdesc, value)
#define GET_TX_DESC_SHCUT_CAM_8812F(txdesc) GET_TX_DESC_SHCUT_CAM(txdesc)
#define SET_TX_DESC_MU_DATARATE_8812F(txdesc, value) \
SET_TX_DESC_MU_DATARATE(txdesc, value)
#define GET_TX_DESC_MU_DATARATE_8812F(txdesc) GET_TX_DESC_MU_DATARATE(txdesc)
#define SET_TX_DESC_MU_RC_8812F(txdesc, value) SET_TX_DESC_MU_RC(txdesc, value)
#define GET_TX_DESC_MU_RC_8812F(txdesc) GET_TX_DESC_MU_RC(txdesc)
#define SET_TX_DESC_NDPA_RATE_SEL_8812F(txdesc, value) \
SET_TX_DESC_NDPA_RATE_SEL(txdesc, value)
#define GET_TX_DESC_NDPA_RATE_SEL_8812F(txdesc) \
GET_TX_DESC_NDPA_RATE_SEL(txdesc)
#define SET_TX_DESC_HW_NDPA_EN_8812F(txdesc, value) \
SET_TX_DESC_HW_NDPA_EN(txdesc, value)
#define GET_TX_DESC_HW_NDPA_EN_8812F(txdesc) GET_TX_DESC_HW_NDPA_EN(txdesc)
#define SET_TX_DESC_SND_PKT_SEL_8812F(txdesc, value) \
SET_TX_DESC_SND_PKT_SEL(txdesc, value)
#define GET_TX_DESC_SND_PKT_SEL_8812F(txdesc) GET_TX_DESC_SND_PKT_SEL(txdesc)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_ie_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_IE_AP_H_
#define _HALMAC_TX_DESC_IE_AP_H_
#if (HALMAC_8814B_SUPPORT)
#define IE0_GET_TX_DESC_IE_END(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 31)
#define IE0_SET_TX_DESC_IE_END(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE0_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE0_GET_TX_DESC_IE_UP(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 30)
#define IE0_SET_TX_DESC_IE_UP(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE0_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE0_GET_TX_DESC_IE_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 24)
#define IE0_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE0_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE0_GET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 19)
#define IE0_SET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 19)
#define IE0_SET_TX_DESC_ARFR_TABLE_SEL_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 19)
#define IE0_GET_TX_DESC_ARFR_HT_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 18)
#define IE0_SET_TX_DESC_ARFR_HT_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 18)
#define IE0_SET_TX_DESC_ARFR_HT_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 18)
#define IE0_GET_TX_DESC_ARFR_OFDM_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 17)
#define IE0_SET_TX_DESC_ARFR_OFDM_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 17)
#define IE0_SET_TX_DESC_ARFR_OFDM_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 17)
#define IE0_GET_TX_DESC_ARFR_CCK_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 16)
#define IE0_SET_TX_DESC_ARFR_CCK_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 16)
#define IE0_SET_TX_DESC_ARFR_CCK_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 16)
#define IE0_GET_TX_DESC_HW_RTS_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 9)
#define IE0_SET_TX_DESC_HW_RTS_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
#define IE0_SET_TX_DESC_HW_RTS_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
#define IE0_GET_TX_DESC_RTS_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 8)
#define IE0_SET_TX_DESC_RTS_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
#define IE0_SET_TX_DESC_RTS_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
#define IE0_GET_TX_DESC_CTS2SELF(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 7)
#define IE0_SET_TX_DESC_CTS2SELF(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
#define IE0_SET_TX_DESC_CTS2SELF_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
#define IE0_GET_TX_DESC_RTY_LMT_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 6)
#define IE0_SET_TX_DESC_RTY_LMT_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
#define IE0_SET_TX_DESC_RTY_LMT_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
#define IE0_GET_TX_DESC_RTS_SHORT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 5)
#define IE0_SET_TX_DESC_RTS_SHORT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
#define IE0_SET_TX_DESC_RTS_SHORT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
#define IE0_GET_TX_DESC_DISDATAFB(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 4)
#define IE0_SET_TX_DESC_DISDATAFB(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
#define IE0_SET_TX_DESC_DISDATAFB_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
#define IE0_GET_TX_DESC_DISRTSFB(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 3)
#define IE0_SET_TX_DESC_DISRTSFB(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
#define IE0_SET_TX_DESC_DISRTSFB_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
#define IE0_GET_TX_DESC_DATA_SHORT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 2)
#define IE0_SET_TX_DESC_DATA_SHORT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE0_SET_TX_DESC_DATA_SHORT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE0_GET_TX_DESC_TRY_RATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 1)
#define IE0_SET_TX_DESC_TRY_RATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE0_SET_TX_DESC_TRY_RATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE0_GET_TX_DESC_USERATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 0)
#define IE0_SET_TX_DESC_USERATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE0_SET_TX_DESC_USERATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 27)
#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
#define IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1f, 22)
#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1f, 22)
#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1f, 22)
#define IE0_GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3f, 16)
#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 16)
#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 16)
#define IE0_GET_TX_DESC_DATA_BW(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 12)
#define IE0_SET_TX_DESC_DATA_BW(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
#define IE0_SET_TX_DESC_DATA_BW_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
#define IE0_GET_TX_DESC_RTSRATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 7)
#define IE0_SET_TX_DESC_RTSRATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 7)
#define IE0_SET_TX_DESC_RTSRATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 7)
#define IE0_GET_TX_DESC_DATARATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x7f, 0)
#define IE0_SET_TX_DESC_DATARATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
#define IE0_SET_TX_DESC_DATARATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
#define IE1_GET_TX_DESC_IE_END(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 31)
#define IE1_SET_TX_DESC_IE_END(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE1_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE1_GET_TX_DESC_IE_UP(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 30)
#define IE1_SET_TX_DESC_IE_UP(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE1_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE1_GET_TX_DESC_IE_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 24)
#define IE1_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE1_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE1_GET_TX_DESC_AMPDU_DENSITY(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x7, 21)
#define IE1_SET_TX_DESC_AMPDU_DENSITY(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 21)
#define IE1_SET_TX_DESC_AMPDU_DENSITY_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 21)
#define IE1_GET_TX_DESC_MAX_AGG_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1f, 16)
#define IE1_SET_TX_DESC_MAX_AGG_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1f, 16)
#define IE1_SET_TX_DESC_MAX_AGG_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1f, 16)
#define IE1_GET_TX_DESC_SECTYPE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x3, 14)
#define IE1_SET_TX_DESC_SECTYPE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 14)
#define IE1_SET_TX_DESC_SECTYPE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 14)
#define IE1_GET_TX_DESC_MOREFRAG(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 13)
#define IE1_SET_TX_DESC_MOREFRAG(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 13)
#define IE1_SET_TX_DESC_MOREFRAG_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 13)
#define IE1_GET_TX_DESC_NOACM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 12)
#define IE1_SET_TX_DESC_NOACM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 12)
#define IE1_SET_TX_DESC_NOACM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 12)
#define IE1_GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 11)
#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
#define IE1_GET_TX_DESC_NAVUSEHDR(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 10)
#define IE1_SET_TX_DESC_NAVUSEHDR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
#define IE1_SET_TX_DESC_NAVUSEHDR_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
#define IE1_GET_TX_DESC_HTC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 9)
#define IE1_SET_TX_DESC_HTC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
#define IE1_SET_TX_DESC_HTC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 9)
#define IE1_GET_TX_DESC_BMC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 8)
#define IE1_SET_TX_DESC_BMC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
#define IE1_SET_TX_DESC_BMC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 8)
#define IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 7)
#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
#define IE1_GET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 6)
#define IE1_SET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
#define IE1_SET_TX_DESC_USE_MAX_TIME_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
#define IE1_GET_TX_DESC_HW_SSN_SEL(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x3, 4)
#define IE1_SET_TX_DESC_HW_SSN_SEL(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 4)
#define IE1_SET_TX_DESC_HW_SSN_SEL_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 4)
#define IE1_GET_TX_DESC_DISQSELSEQ(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 3)
#define IE1_SET_TX_DESC_DISQSELSEQ(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
#define IE1_SET_TX_DESC_DISQSELSEQ_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
#define IE1_GET_TX_DESC_EN_HWSEQ(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 2)
#define IE1_SET_TX_DESC_EN_HWSEQ(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE1_SET_TX_DESC_EN_HWSEQ_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE1_GET_TX_DESC_EN_HWEXSEQ(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 1)
#define IE1_SET_TX_DESC_EN_HWEXSEQ(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE1_SET_TX_DESC_EN_HWEXSEQ_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE1_GET_TX_DESC_EN_DESC_ID(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 0)
#define IE1_SET_TX_DESC_EN_DESC_ID(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE1_SET_TX_DESC_EN_DESC_ID_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE1_GET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xff, 24)
#define IE1_SET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 24)
#define IE1_SET_TX_DESC_AMPDU_MAX_TIME_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 24)
#define IE1_GET_TX_DESC_P_AID(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1ff, 15)
#define IE1_SET_TX_DESC_P_AID(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1ff, \
15)
#define IE1_SET_TX_DESC_P_AID_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1ff, \
15)
#define IE1_GET_TX_DESC_MOREDATA(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1, 14)
#define IE1_SET_TX_DESC_MOREDATA(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 14)
#define IE1_SET_TX_DESC_MOREDATA_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 14)
#define IE1_GET_TX_DESC_SW_SEQ(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xfff, 0)
#define IE1_SET_TX_DESC_SW_SEQ(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
#define IE1_SET_TX_DESC_SW_SEQ_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
#define IE2_GET_TX_DESC_IE_END(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 31)
#define IE2_SET_TX_DESC_IE_END(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE2_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE2_GET_TX_DESC_IE_UP(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 30)
#define IE2_SET_TX_DESC_IE_UP(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE2_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE2_GET_TX_DESC_IE_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 24)
#define IE2_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE2_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE2_GET_TX_DESC_ADDR_CAM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xff, 16)
#define IE2_SET_TX_DESC_ADDR_CAM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xff, 16)
#define IE2_SET_TX_DESC_ADDR_CAM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xff, 16)
#define IE2_GET_TX_DESC_MULTIPLE_PORT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x7, 12)
#define IE2_SET_TX_DESC_MULTIPLE_PORT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 12)
#define IE2_SET_TX_DESC_MULTIPLE_PORT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7, 12)
#define IE2_GET_TX_DESC_RAW(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 11)
#define IE2_SET_TX_DESC_RAW(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
#define IE2_SET_TX_DESC_RAW_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 11)
#define IE2_GET_TX_DESC_RDG_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 10)
#define IE2_SET_TX_DESC_RDG_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
#define IE2_SET_TX_DESC_RDG_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 10)
#define IE2_GET_TX_DESC_SPECIAL_CW(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 7)
#define IE2_SET_TX_DESC_SPECIAL_CW(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
#define IE2_SET_TX_DESC_SPECIAL_CW_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 7)
#define IE2_GET_TX_DESC_POLLUTED(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 6)
#define IE2_SET_TX_DESC_POLLUTED(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
#define IE2_SET_TX_DESC_POLLUTED_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 6)
#define IE2_GET_TX_DESC_BT_NULL(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 5)
#define IE2_SET_TX_DESC_BT_NULL(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
#define IE2_SET_TX_DESC_BT_NULL_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 5)
#define IE2_GET_TX_DESC_NULL_1(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 4)
#define IE2_SET_TX_DESC_NULL_1(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
#define IE2_SET_TX_DESC_NULL_1_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 4)
#define IE2_GET_TX_DESC_NULL_0(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 3)
#define IE2_SET_TX_DESC_NULL_0(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
#define IE2_SET_TX_DESC_NULL_0_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 3)
#define IE2_GET_TX_DESC_TRI_FRAME(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 2)
#define IE2_SET_TX_DESC_TRI_FRAME(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE2_SET_TX_DESC_TRI_FRAME_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE2_GET_TX_DESC_SPE_RPT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 1)
#define IE2_SET_TX_DESC_SPE_RPT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE2_SET_TX_DESC_SPE_RPT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE2_GET_TX_DESC_FTM_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 0)
#define IE2_SET_TX_DESC_FTM_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE2_SET_TX_DESC_FTM_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE2_GET_TX_DESC_MBSSID(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 27)
#define IE2_SET_TX_DESC_MBSSID(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
#define IE2_SET_TX_DESC_MBSSID_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 27)
#define IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x7ff, 16)
#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7ff, \
16)
#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7ff, \
16)
#define IE2_GET_TX_DESC_RDG_NAV_EXT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1, 15)
#define IE2_SET_TX_DESC_RDG_NAV_EXT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 15)
#define IE2_SET_TX_DESC_RDG_NAV_EXT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 15)
#define IE2_GET_TX_DESC_DROP_ID(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 12)
#define IE2_SET_TX_DESC_DROP_ID(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
#define IE2_SET_TX_DESC_DROP_ID_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 12)
#define IE2_GET_TX_DESC_SW_DEFINE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xfff, 0)
#define IE2_SET_TX_DESC_SW_DEFINE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
#define IE2_SET_TX_DESC_SW_DEFINE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xfff, 0)
#define IE3_GET_TX_DESC_IE_END(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 31)
#define IE3_SET_TX_DESC_IE_END(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE3_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE3_GET_TX_DESC_IE_UP(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 30)
#define IE3_SET_TX_DESC_IE_UP(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE3_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE3_GET_TX_DESC_IE_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 24)
#define IE3_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE3_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE3_GET_TX_DESC_DATA_SC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 20)
#define IE3_SET_TX_DESC_DATA_SC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 20)
#define IE3_SET_TX_DESC_DATA_SC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 20)
#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 16)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 16)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 16)
#define IE3_GET_TX_DESC_CTRL_CNT(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 8)
#define IE3_SET_TX_DESC_CTRL_CNT(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 8)
#define IE3_SET_TX_DESC_CTRL_CNT_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 8)
#define IE3_GET_TX_DESC_CTRL_CNT_VALID(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 1)
#define IE3_SET_TX_DESC_CTRL_CNT_VALID(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE3_SET_TX_DESC_CTRL_CNT_VALID_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 0)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE3_GET_TX_DESC_G_ID(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3f, 24)
#define IE3_SET_TX_DESC_G_ID(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 24)
#define IE3_SET_TX_DESC_G_ID_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 24)
#define IE3_GET_TX_DESC_SND_TARGET(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xff, 16)
#define IE3_SET_TX_DESC_SND_TARGET(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 16)
#define IE3_SET_TX_DESC_SND_TARGET_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xff, 16)
#define IE3_GET_TX_DESC_CCA_RTS(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 11)
#define IE3_SET_TX_DESC_CCA_RTS(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 11)
#define IE3_SET_TX_DESC_CCA_RTS_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 11)
#define IE3_GET_TX_DESC_SND_PKT_SEL(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 9)
#define IE3_SET_TX_DESC_SND_PKT_SEL(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 9)
#define IE3_SET_TX_DESC_SND_PKT_SEL_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 9)
#define IE3_GET_TX_DESC_NDPA(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 7)
#define IE3_SET_TX_DESC_NDPA(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 7)
#define IE3_SET_TX_DESC_NDPA_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 7)
#define IE3_GET_TX_DESC_MU_DATARATE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x7f, 0)
#define IE3_SET_TX_DESC_MU_DATARATE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
#define IE3_SET_TX_DESC_MU_DATARATE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x7f, 0)
#define IE4_GET_TX_DESC_IE_END(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 31)
#define IE4_SET_TX_DESC_IE_END(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE4_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE4_GET_TX_DESC_IE_UP(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 30)
#define IE4_SET_TX_DESC_IE_UP(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE4_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE4_GET_TX_DESC_IE_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 24)
#define IE4_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE4_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE4_GET_TX_DESC_VCS_STBC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x3, 10)
#define IE4_SET_TX_DESC_VCS_STBC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 10)
#define IE4_SET_TX_DESC_VCS_STBC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 10)
#define IE4_GET_TX_DESC_DATA_STBC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x3, 8)
#define IE4_SET_TX_DESC_DATA_STBC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 8)
#define IE4_SET_TX_DESC_DATA_STBC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x3, 8)
#define IE4_GET_TX_DESC_DATA_LDPC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 2)
#define IE4_SET_TX_DESC_DATA_LDPC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE4_SET_TX_DESC_DATA_LDPC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 2)
#define IE4_GET_TX_DESC_GF(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 1)
#define IE4_SET_TX_DESC_GF(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE4_SET_TX_DESC_GF_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 1)
#define IE4_GET_TX_DESC_LSIG_TXOP_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 0)
#define IE4_SET_TX_DESC_LSIG_TXOP_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE4_SET_TX_DESC_LSIG_TXOP_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 0)
#define IE4_GET_TX_DESC_PATH_MAPA(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 30)
#define IE4_SET_TX_DESC_PATH_MAPA(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 30)
#define IE4_SET_TX_DESC_PATH_MAPA_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 30)
#define IE4_GET_TX_DESC_PATH_MAPB(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 28)
#define IE4_SET_TX_DESC_PATH_MAPB(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 28)
#define IE4_SET_TX_DESC_PATH_MAPB_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 28)
#define IE4_GET_TX_DESC_PATH_MAPC(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 26)
#define IE4_SET_TX_DESC_PATH_MAPC(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 26)
#define IE4_SET_TX_DESC_PATH_MAPC_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 26)
#define IE4_GET_TX_DESC_PATH_MAPD(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 24)
#define IE4_SET_TX_DESC_PATH_MAPD(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 24)
#define IE4_SET_TX_DESC_PATH_MAPD_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 24)
#define IE4_GET_TX_DESC_ANTSEL_A(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 20)
#define IE4_SET_TX_DESC_ANTSEL_A(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 20)
#define IE4_SET_TX_DESC_ANTSEL_A_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 20)
#define IE4_GET_TX_DESC_ANTSEL_B(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 16)
#define IE4_SET_TX_DESC_ANTSEL_B(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 16)
#define IE4_SET_TX_DESC_ANTSEL_B_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 16)
#define IE4_GET_TX_DESC_ANTSEL_C(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 12)
#define IE4_SET_TX_DESC_ANTSEL_C(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 12)
#define IE4_SET_TX_DESC_ANTSEL_C_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 12)
#define IE4_GET_TX_DESC_ANTSEL_D(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 8)
#define IE4_SET_TX_DESC_ANTSEL_D(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 8)
#define IE4_SET_TX_DESC_ANTSEL_D_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 8)
#define IE4_GET_TX_DESC_NTX_PATH_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0xf, 4)
#define IE4_SET_TX_DESC_NTX_PATH_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 4)
#define IE4_SET_TX_DESC_NTX_PATH_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0xf, 4)
#define IE4_GET_TX_DESC_ANTLSEL_EN(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1, 3)
#define IE4_SET_TX_DESC_ANTLSEL_EN(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 3)
#define IE4_SET_TX_DESC_ANTLSEL_EN_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1, 3)
#define IE4_GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3, 0)
#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 0)
#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3, 0)
#define IE5_GET_TX_DESC_IE_END(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 31)
#define IE5_SET_TX_DESC_IE_END(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE5_SET_TX_DESC_IE_END_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 31)
#define IE5_GET_TX_DESC_IE_UP(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1, 30)
#define IE5_SET_TX_DESC_IE_UP(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE5_SET_TX_DESC_IE_UP_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1, 30)
#define IE5_GET_TX_DESC_IE_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 24)
#define IE5_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE5_SET_TX_DESC_IE_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 24)
#define IE5_GET_TX_DESC_LEN1_L(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x7f, 17)
#define IE5_SET_TX_DESC_LEN1_L(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7f, 17)
#define IE5_SET_TX_DESC_LEN1_L_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x7f, 17)
#define IE5_GET_TX_DESC_LEN0(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0x1fff, 4)
#define IE5_SET_TX_DESC_LEN0(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1fff, \
4)
#define IE5_SET_TX_DESC_LEN0_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0x1fff, \
4)
#define IE5_GET_TX_DESC_PKT_NUM(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword0, \
0xf, 0)
#define IE5_SET_TX_DESC_PKT_NUM(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 0)
#define IE5_SET_TX_DESC_PKT_NUM_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword0, value, 0xf, 0)
#define IE5_GET_TX_DESC_LEN3(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1fff, 19)
#define IE5_SET_TX_DESC_LEN3(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff, \
19)
#define IE5_SET_TX_DESC_LEN3_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff, \
19)
#define IE5_GET_TX_DESC_LEN2(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x1fff, 6)
#define IE5_SET_TX_DESC_LEN2(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff, \
6)
#define IE5_SET_TX_DESC_LEN2_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x1fff, \
6)
#define IE5_GET_TX_DESC_LEN1_H(txdesc_ie) \
HALMAC_GET_DESC_FIELD(((struct halmac_tx_desc *)txdesc_ie)->dword1, \
0x3f, 0)
#define IE5_SET_TX_DESC_LEN1_H(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 0)
#define IE5_SET_TX_DESC_LEN1_H_NO_CLR(txdesc_ie, value) \
HALMAC_SET_DESC_FIELD_NO_CLR( \
((struct halmac_tx_desc *)txdesc_ie)->dword1, value, 0x3f, 0)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_ie_chip.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_IE_CHIP_H_
#define _HALMAC_TX_DESC_IE_CHIP_H_
#if (HALMAC_8814B_SUPPORT)
#define IE0_GET_TX_DESC_IE_END_8814B(txdesc_ie) \
IE0_GET_TX_DESC_IE_END(txdesc_ie)
#define IE0_SET_TX_DESC_IE_END_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_IE_END(txdesc_ie, value)
#define IE0_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE0_GET_TX_DESC_IE_UP(txdesc_ie)
#define IE0_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_IE_UP(txdesc_ie, value)
#define IE0_GET_TX_DESC_IE_NUM_8814B(txdesc_ie) \
IE0_GET_TX_DESC_IE_NUM(txdesc_ie)
#define IE0_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_IE_NUM(txdesc_ie, value)
#define IE0_GET_TX_DESC_ARFR_TABLE_SEL_8814B(txdesc_ie) \
IE0_GET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie)
#define IE0_SET_TX_DESC_ARFR_TABLE_SEL_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie, value)
#define IE0_GET_TX_DESC_ARFR_HT_EN_8814B(txdesc_ie) \
IE0_GET_TX_DESC_ARFR_HT_EN(txdesc_ie)
#define IE0_SET_TX_DESC_ARFR_HT_EN_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_ARFR_HT_EN(txdesc_ie, value)
#define IE0_GET_TX_DESC_ARFR_OFDM_EN_8814B(txdesc_ie) \
IE0_GET_TX_DESC_ARFR_OFDM_EN(txdesc_ie)
#define IE0_SET_TX_DESC_ARFR_OFDM_EN_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_ARFR_OFDM_EN(txdesc_ie, value)
#define IE0_GET_TX_DESC_ARFR_CCK_EN_8814B(txdesc_ie) \
IE0_GET_TX_DESC_ARFR_CCK_EN(txdesc_ie)
#define IE0_SET_TX_DESC_ARFR_CCK_EN_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_ARFR_CCK_EN(txdesc_ie, value)
#define IE0_GET_TX_DESC_HW_RTS_EN_8814B(txdesc_ie) \
IE0_GET_TX_DESC_HW_RTS_EN(txdesc_ie)
#define IE0_SET_TX_DESC_HW_RTS_EN_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_HW_RTS_EN(txdesc_ie, value)
#define IE0_GET_TX_DESC_RTS_EN_8814B(txdesc_ie) \
IE0_GET_TX_DESC_RTS_EN(txdesc_ie)
#define IE0_SET_TX_DESC_RTS_EN_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_RTS_EN(txdesc_ie, value)
#define IE0_GET_TX_DESC_CTS2SELF_8814B(txdesc_ie) \
IE0_GET_TX_DESC_CTS2SELF(txdesc_ie)
#define IE0_SET_TX_DESC_CTS2SELF_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_CTS2SELF(txdesc_ie, value)
#define IE0_GET_TX_DESC_RTY_LMT_EN_8814B(txdesc_ie) \
IE0_GET_TX_DESC_RTY_LMT_EN(txdesc_ie)
#define IE0_SET_TX_DESC_RTY_LMT_EN_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_RTY_LMT_EN(txdesc_ie, value)
#define IE0_GET_TX_DESC_RTS_SHORT_8814B(txdesc_ie) \
IE0_GET_TX_DESC_RTS_SHORT(txdesc_ie)
#define IE0_SET_TX_DESC_RTS_SHORT_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_RTS_SHORT(txdesc_ie, value)
#define IE0_GET_TX_DESC_DISDATAFB_8814B(txdesc_ie) \
IE0_GET_TX_DESC_DISDATAFB(txdesc_ie)
#define IE0_SET_TX_DESC_DISDATAFB_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_DISDATAFB(txdesc_ie, value)
#define IE0_GET_TX_DESC_DISRTSFB_8814B(txdesc_ie) \
IE0_GET_TX_DESC_DISRTSFB(txdesc_ie)
#define IE0_SET_TX_DESC_DISRTSFB_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_DISRTSFB(txdesc_ie, value)
#define IE0_GET_TX_DESC_DATA_SHORT_8814B(txdesc_ie) \
IE0_GET_TX_DESC_DATA_SHORT(txdesc_ie)
#define IE0_SET_TX_DESC_DATA_SHORT_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_DATA_SHORT(txdesc_ie, value)
#define IE0_GET_TX_DESC_TRY_RATE_8814B(txdesc_ie) \
IE0_GET_TX_DESC_TRY_RATE(txdesc_ie)
#define IE0_SET_TX_DESC_TRY_RATE_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_TRY_RATE(txdesc_ie, value)
#define IE0_GET_TX_DESC_USERATE_8814B(txdesc_ie) \
IE0_GET_TX_DESC_USERATE(txdesc_ie)
#define IE0_SET_TX_DESC_USERATE_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_USERATE(txdesc_ie, value)
#define IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE_8814B(txdesc_ie) \
IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie)
#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie, value)
#define IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE_8814B(txdesc_ie) \
IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie)
#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie, value)
#define IE0_GET_TX_DESC_RTS_DATA_RTY_LMT_8814B(txdesc_ie) \
IE0_GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie)
#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie, value)
#define IE0_GET_TX_DESC_DATA_BW_8814B(txdesc_ie) \
IE0_GET_TX_DESC_DATA_BW(txdesc_ie)
#define IE0_SET_TX_DESC_DATA_BW_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_DATA_BW(txdesc_ie, value)
#define IE0_GET_TX_DESC_RTSRATE_8814B(txdesc_ie) \
IE0_GET_TX_DESC_RTSRATE(txdesc_ie)
#define IE0_SET_TX_DESC_RTSRATE_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_RTSRATE(txdesc_ie, value)
#define IE0_GET_TX_DESC_DATARATE_8814B(txdesc_ie) \
IE0_GET_TX_DESC_DATARATE(txdesc_ie)
#define IE0_SET_TX_DESC_DATARATE_8814B(txdesc_ie, value) \
IE0_SET_TX_DESC_DATARATE(txdesc_ie, value)
#define IE1_GET_TX_DESC_IE_END_8814B(txdesc_ie) \
IE1_GET_TX_DESC_IE_END(txdesc_ie)
#define IE1_SET_TX_DESC_IE_END_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_IE_END(txdesc_ie, value)
#define IE1_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE1_GET_TX_DESC_IE_UP(txdesc_ie)
#define IE1_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_IE_UP(txdesc_ie, value)
#define IE1_GET_TX_DESC_IE_NUM_8814B(txdesc_ie) \
IE1_GET_TX_DESC_IE_NUM(txdesc_ie)
#define IE1_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_IE_NUM(txdesc_ie, value)
#define IE1_GET_TX_DESC_AMPDU_DENSITY_8814B(txdesc_ie) \
IE1_GET_TX_DESC_AMPDU_DENSITY(txdesc_ie)
#define IE1_SET_TX_DESC_AMPDU_DENSITY_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_AMPDU_DENSITY(txdesc_ie, value)
#define IE1_GET_TX_DESC_MAX_AGG_NUM_8814B(txdesc_ie) \
IE1_GET_TX_DESC_MAX_AGG_NUM(txdesc_ie)
#define IE1_SET_TX_DESC_MAX_AGG_NUM_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_MAX_AGG_NUM(txdesc_ie, value)
#define IE1_GET_TX_DESC_SECTYPE_8814B(txdesc_ie) \
IE1_GET_TX_DESC_SECTYPE(txdesc_ie)
#define IE1_SET_TX_DESC_SECTYPE_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_SECTYPE(txdesc_ie, value)
#define IE1_GET_TX_DESC_MOREFRAG_8814B(txdesc_ie) \
IE1_GET_TX_DESC_MOREFRAG(txdesc_ie)
#define IE1_SET_TX_DESC_MOREFRAG_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_MOREFRAG(txdesc_ie, value)
#define IE1_GET_TX_DESC_NOACM_8814B(txdesc_ie) IE1_GET_TX_DESC_NOACM(txdesc_ie)
#define IE1_SET_TX_DESC_NOACM_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_NOACM(txdesc_ie, value)
#define IE1_GET_TX_DESC_BCNPKT_TSF_CTRL_8814B(txdesc_ie) \
IE1_GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie)
#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie, value)
#define IE1_GET_TX_DESC_NAVUSEHDR_8814B(txdesc_ie) \
IE1_GET_TX_DESC_NAVUSEHDR(txdesc_ie)
#define IE1_SET_TX_DESC_NAVUSEHDR_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_NAVUSEHDR(txdesc_ie, value)
#define IE1_GET_TX_DESC_HTC_8814B(txdesc_ie) IE1_GET_TX_DESC_HTC(txdesc_ie)
#define IE1_SET_TX_DESC_HTC_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_HTC(txdesc_ie, value)
#define IE1_GET_TX_DESC_BMC_8814B(txdesc_ie) IE1_GET_TX_DESC_BMC(txdesc_ie)
#define IE1_SET_TX_DESC_BMC_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_BMC(txdesc_ie, value)
#define IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS_8814B(txdesc_ie) \
IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie)
#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie, value)
#define IE1_GET_TX_DESC_USE_MAX_TIME_EN_8814B(txdesc_ie) \
IE1_GET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie)
#define IE1_SET_TX_DESC_USE_MAX_TIME_EN_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie, value)
#define IE1_GET_TX_DESC_HW_SSN_SEL_8814B(txdesc_ie) \
IE1_GET_TX_DESC_HW_SSN_SEL(txdesc_ie)
#define IE1_SET_TX_DESC_HW_SSN_SEL_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_HW_SSN_SEL(txdesc_ie, value)
#define IE1_GET_TX_DESC_DISQSELSEQ_8814B(txdesc_ie) \
IE1_GET_TX_DESC_DISQSELSEQ(txdesc_ie)
#define IE1_SET_TX_DESC_DISQSELSEQ_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_DISQSELSEQ(txdesc_ie, value)
#define IE1_GET_TX_DESC_EN_HWSEQ_8814B(txdesc_ie) \
IE1_GET_TX_DESC_EN_HWSEQ(txdesc_ie)
#define IE1_SET_TX_DESC_EN_HWSEQ_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_EN_HWSEQ(txdesc_ie, value)
#define IE1_GET_TX_DESC_EN_HWEXSEQ_8814B(txdesc_ie) \
IE1_GET_TX_DESC_EN_HWEXSEQ(txdesc_ie)
#define IE1_SET_TX_DESC_EN_HWEXSEQ_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_EN_HWEXSEQ(txdesc_ie, value)
#define IE1_GET_TX_DESC_EN_DESC_ID_8814B(txdesc_ie) \
IE1_GET_TX_DESC_EN_DESC_ID(txdesc_ie)
#define IE1_SET_TX_DESC_EN_DESC_ID_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_EN_DESC_ID(txdesc_ie, value)
#define IE1_GET_TX_DESC_AMPDU_MAX_TIME_8814B(txdesc_ie) \
IE1_GET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie)
#define IE1_SET_TX_DESC_AMPDU_MAX_TIME_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie, value)
#define IE1_GET_TX_DESC_P_AID_8814B(txdesc_ie) IE1_GET_TX_DESC_P_AID(txdesc_ie)
#define IE1_SET_TX_DESC_P_AID_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_P_AID(txdesc_ie, value)
#define IE1_GET_TX_DESC_MOREDATA_8814B(txdesc_ie) \
IE1_GET_TX_DESC_MOREDATA(txdesc_ie)
#define IE1_SET_TX_DESC_MOREDATA_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_MOREDATA(txdesc_ie, value)
#define IE1_GET_TX_DESC_SW_SEQ_8814B(txdesc_ie) \
IE1_GET_TX_DESC_SW_SEQ(txdesc_ie)
#define IE1_SET_TX_DESC_SW_SEQ_8814B(txdesc_ie, value) \
IE1_SET_TX_DESC_SW_SEQ(txdesc_ie, value)
#define IE2_GET_TX_DESC_IE_END_8814B(txdesc_ie) \
IE2_GET_TX_DESC_IE_END(txdesc_ie)
#define IE2_SET_TX_DESC_IE_END_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_IE_END(txdesc_ie, value)
#define IE2_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE2_GET_TX_DESC_IE_UP(txdesc_ie)
#define IE2_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_IE_UP(txdesc_ie, value)
#define IE2_GET_TX_DESC_IE_NUM_8814B(txdesc_ie) \
IE2_GET_TX_DESC_IE_NUM(txdesc_ie)
#define IE2_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_IE_NUM(txdesc_ie, value)
#define IE2_GET_TX_DESC_ADDR_CAM_8814B(txdesc_ie) \
IE2_GET_TX_DESC_ADDR_CAM(txdesc_ie)
#define IE2_SET_TX_DESC_ADDR_CAM_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_ADDR_CAM(txdesc_ie, value)
#define IE2_GET_TX_DESC_MULTIPLE_PORT_8814B(txdesc_ie) \
IE2_GET_TX_DESC_MULTIPLE_PORT(txdesc_ie)
#define IE2_SET_TX_DESC_MULTIPLE_PORT_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_MULTIPLE_PORT(txdesc_ie, value)
#define IE2_GET_TX_DESC_RAW_8814B(txdesc_ie) IE2_GET_TX_DESC_RAW(txdesc_ie)
#define IE2_SET_TX_DESC_RAW_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_RAW(txdesc_ie, value)
#define IE2_GET_TX_DESC_RDG_EN_8814B(txdesc_ie) \
IE2_GET_TX_DESC_RDG_EN(txdesc_ie)
#define IE2_SET_TX_DESC_RDG_EN_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_RDG_EN(txdesc_ie, value)
#define IE2_GET_TX_DESC_SPECIAL_CW_8814B(txdesc_ie) \
IE2_GET_TX_DESC_SPECIAL_CW(txdesc_ie)
#define IE2_SET_TX_DESC_SPECIAL_CW_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_SPECIAL_CW(txdesc_ie, value)
#define IE2_GET_TX_DESC_POLLUTED_8814B(txdesc_ie) \
IE2_GET_TX_DESC_POLLUTED(txdesc_ie)
#define IE2_SET_TX_DESC_POLLUTED_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_POLLUTED(txdesc_ie, value)
#define IE2_GET_TX_DESC_BT_NULL_8814B(txdesc_ie) \
IE2_GET_TX_DESC_BT_NULL(txdesc_ie)
#define IE2_SET_TX_DESC_BT_NULL_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_BT_NULL(txdesc_ie, value)
#define IE2_GET_TX_DESC_NULL_1_8814B(txdesc_ie) \
IE2_GET_TX_DESC_NULL_1(txdesc_ie)
#define IE2_SET_TX_DESC_NULL_1_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_NULL_1(txdesc_ie, value)
#define IE2_GET_TX_DESC_NULL_0_8814B(txdesc_ie) \
IE2_GET_TX_DESC_NULL_0(txdesc_ie)
#define IE2_SET_TX_DESC_NULL_0_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_NULL_0(txdesc_ie, value)
#define IE2_GET_TX_DESC_TRI_FRAME_8814B(txdesc_ie) \
IE2_GET_TX_DESC_TRI_FRAME(txdesc_ie)
#define IE2_SET_TX_DESC_TRI_FRAME_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_TRI_FRAME(txdesc_ie, value)
#define IE2_GET_TX_DESC_SPE_RPT_8814B(txdesc_ie) \
IE2_GET_TX_DESC_SPE_RPT(txdesc_ie)
#define IE2_SET_TX_DESC_SPE_RPT_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_SPE_RPT(txdesc_ie, value)
#define IE2_GET_TX_DESC_FTM_EN_8814B(txdesc_ie) \
IE2_GET_TX_DESC_FTM_EN(txdesc_ie)
#define IE2_SET_TX_DESC_FTM_EN_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_FTM_EN(txdesc_ie, value)
#define IE2_GET_TX_DESC_MBSSID_8814B(txdesc_ie) \
IE2_GET_TX_DESC_MBSSID(txdesc_ie)
#define IE2_SET_TX_DESC_MBSSID_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_MBSSID(txdesc_ie, value)
#define IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET_8814B(txdesc_ie) \
IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie)
#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie, value)
#define IE2_GET_TX_DESC_RDG_NAV_EXT_8814B(txdesc_ie) \
IE2_GET_TX_DESC_RDG_NAV_EXT(txdesc_ie)
#define IE2_SET_TX_DESC_RDG_NAV_EXT_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_RDG_NAV_EXT(txdesc_ie, value)
#define IE2_GET_TX_DESC_DROP_ID_8814B(txdesc_ie) \
IE2_GET_TX_DESC_DROP_ID(txdesc_ie)
#define IE2_SET_TX_DESC_DROP_ID_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_DROP_ID(txdesc_ie, value)
#define IE2_GET_TX_DESC_SW_DEFINE_8814B(txdesc_ie) \
IE2_GET_TX_DESC_SW_DEFINE(txdesc_ie)
#define IE2_SET_TX_DESC_SW_DEFINE_8814B(txdesc_ie, value) \
IE2_SET_TX_DESC_SW_DEFINE(txdesc_ie, value)
#define IE3_GET_TX_DESC_IE_END_8814B(txdesc_ie) \
IE3_GET_TX_DESC_IE_END(txdesc_ie)
#define IE3_SET_TX_DESC_IE_END_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_IE_END(txdesc_ie, value)
#define IE3_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE3_GET_TX_DESC_IE_UP(txdesc_ie)
#define IE3_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_IE_UP(txdesc_ie, value)
#define IE3_GET_TX_DESC_IE_NUM_8814B(txdesc_ie) \
IE3_GET_TX_DESC_IE_NUM(txdesc_ie)
#define IE3_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_IE_NUM(txdesc_ie, value)
#define IE3_GET_TX_DESC_DATA_SC_8814B(txdesc_ie) \
IE3_GET_TX_DESC_DATA_SC(txdesc_ie)
#define IE3_SET_TX_DESC_DATA_SC_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_DATA_SC(txdesc_ie, value)
#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC_8814B(txdesc_ie) \
IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie, value)
#define IE3_GET_TX_DESC_CTRL_CNT_8814B(txdesc_ie) \
IE3_GET_TX_DESC_CTRL_CNT(txdesc_ie)
#define IE3_SET_TX_DESC_CTRL_CNT_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_CTRL_CNT(txdesc_ie, value)
#define IE3_GET_TX_DESC_CTRL_CNT_VALID_8814B(txdesc_ie) \
IE3_GET_TX_DESC_CTRL_CNT_VALID(txdesc_ie)
#define IE3_SET_TX_DESC_CTRL_CNT_VALID_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_CTRL_CNT_VALID(txdesc_ie, value)
#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN_8814B(txdesc_ie) \
IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie, value)
#define IE3_GET_TX_DESC_G_ID_8814B(txdesc_ie) IE3_GET_TX_DESC_G_ID(txdesc_ie)
#define IE3_SET_TX_DESC_G_ID_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_G_ID(txdesc_ie, value)
#define IE3_GET_TX_DESC_SND_TARGET_8814B(txdesc_ie) \
IE3_GET_TX_DESC_SND_TARGET(txdesc_ie)
#define IE3_SET_TX_DESC_SND_TARGET_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_SND_TARGET(txdesc_ie, value)
#define IE3_GET_TX_DESC_CCA_RTS_8814B(txdesc_ie) \
IE3_GET_TX_DESC_CCA_RTS(txdesc_ie)
#define IE3_SET_TX_DESC_CCA_RTS_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_CCA_RTS(txdesc_ie, value)
#define IE3_GET_TX_DESC_SND_PKT_SEL_8814B(txdesc_ie) \
IE3_GET_TX_DESC_SND_PKT_SEL(txdesc_ie)
#define IE3_SET_TX_DESC_SND_PKT_SEL_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_SND_PKT_SEL(txdesc_ie, value)
#define IE3_GET_TX_DESC_NDPA_8814B(txdesc_ie) IE3_GET_TX_DESC_NDPA(txdesc_ie)
#define IE3_SET_TX_DESC_NDPA_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_NDPA(txdesc_ie, value)
#define IE3_GET_TX_DESC_MU_DATARATE_8814B(txdesc_ie) \
IE3_GET_TX_DESC_MU_DATARATE(txdesc_ie)
#define IE3_SET_TX_DESC_MU_DATARATE_8814B(txdesc_ie, value) \
IE3_SET_TX_DESC_MU_DATARATE(txdesc_ie, value)
#define IE4_GET_TX_DESC_IE_END_8814B(txdesc_ie) \
IE4_GET_TX_DESC_IE_END(txdesc_ie)
#define IE4_SET_TX_DESC_IE_END_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_IE_END(txdesc_ie, value)
#define IE4_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE4_GET_TX_DESC_IE_UP(txdesc_ie)
#define IE4_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_IE_UP(txdesc_ie, value)
#define IE4_GET_TX_DESC_IE_NUM_8814B(txdesc_ie) \
IE4_GET_TX_DESC_IE_NUM(txdesc_ie)
#define IE4_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_IE_NUM(txdesc_ie, value)
#define IE4_GET_TX_DESC_VCS_STBC_8814B(txdesc_ie) \
IE4_GET_TX_DESC_VCS_STBC(txdesc_ie)
#define IE4_SET_TX_DESC_VCS_STBC_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_VCS_STBC(txdesc_ie, value)
#define IE4_GET_TX_DESC_DATA_STBC_8814B(txdesc_ie) \
IE4_GET_TX_DESC_DATA_STBC(txdesc_ie)
#define IE4_SET_TX_DESC_DATA_STBC_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_DATA_STBC(txdesc_ie, value)
#define IE4_GET_TX_DESC_DATA_LDPC_8814B(txdesc_ie) \
IE4_GET_TX_DESC_DATA_LDPC(txdesc_ie)
#define IE4_SET_TX_DESC_DATA_LDPC_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_DATA_LDPC(txdesc_ie, value)
#define IE4_GET_TX_DESC_GF_8814B(txdesc_ie) IE4_GET_TX_DESC_GF(txdesc_ie)
#define IE4_SET_TX_DESC_GF_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_GF(txdesc_ie, value)
#define IE4_GET_TX_DESC_LSIG_TXOP_EN_8814B(txdesc_ie) \
IE4_GET_TX_DESC_LSIG_TXOP_EN(txdesc_ie)
#define IE4_SET_TX_DESC_LSIG_TXOP_EN_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_LSIG_TXOP_EN(txdesc_ie, value)
#define IE4_GET_TX_DESC_PATH_MAPA_8814B(txdesc_ie) \
IE4_GET_TX_DESC_PATH_MAPA(txdesc_ie)
#define IE4_SET_TX_DESC_PATH_MAPA_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_PATH_MAPA(txdesc_ie, value)
#define IE4_GET_TX_DESC_PATH_MAPB_8814B(txdesc_ie) \
IE4_GET_TX_DESC_PATH_MAPB(txdesc_ie)
#define IE4_SET_TX_DESC_PATH_MAPB_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_PATH_MAPB(txdesc_ie, value)
#define IE4_GET_TX_DESC_PATH_MAPC_8814B(txdesc_ie) \
IE4_GET_TX_DESC_PATH_MAPC(txdesc_ie)
#define IE4_SET_TX_DESC_PATH_MAPC_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_PATH_MAPC(txdesc_ie, value)
#define IE4_GET_TX_DESC_PATH_MAPD_8814B(txdesc_ie) \
IE4_GET_TX_DESC_PATH_MAPD(txdesc_ie)
#define IE4_SET_TX_DESC_PATH_MAPD_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_PATH_MAPD(txdesc_ie, value)
#define IE4_GET_TX_DESC_ANTSEL_A_8814B(txdesc_ie) \
IE4_GET_TX_DESC_ANTSEL_A(txdesc_ie)
#define IE4_SET_TX_DESC_ANTSEL_A_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_ANTSEL_A(txdesc_ie, value)
#define IE4_GET_TX_DESC_ANTSEL_B_8814B(txdesc_ie) \
IE4_GET_TX_DESC_ANTSEL_B(txdesc_ie)
#define IE4_SET_TX_DESC_ANTSEL_B_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_ANTSEL_B(txdesc_ie, value)
#define IE4_GET_TX_DESC_ANTSEL_C_8814B(txdesc_ie) \
IE4_GET_TX_DESC_ANTSEL_C(txdesc_ie)
#define IE4_SET_TX_DESC_ANTSEL_C_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_ANTSEL_C(txdesc_ie, value)
#define IE4_GET_TX_DESC_ANTSEL_D_8814B(txdesc_ie) \
IE4_GET_TX_DESC_ANTSEL_D(txdesc_ie)
#define IE4_SET_TX_DESC_ANTSEL_D_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_ANTSEL_D(txdesc_ie, value)
#define IE4_GET_TX_DESC_NTX_PATH_EN_8814B(txdesc_ie) \
IE4_GET_TX_DESC_NTX_PATH_EN(txdesc_ie)
#define IE4_SET_TX_DESC_NTX_PATH_EN_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_NTX_PATH_EN(txdesc_ie, value)
#define IE4_GET_TX_DESC_ANTLSEL_EN_8814B(txdesc_ie) \
IE4_GET_TX_DESC_ANTLSEL_EN(txdesc_ie)
#define IE4_SET_TX_DESC_ANTLSEL_EN_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_ANTLSEL_EN(txdesc_ie, value)
#define IE4_GET_TX_DESC_TXPWR_OFSET_TYPE_8814B(txdesc_ie) \
IE4_GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie)
#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE_8814B(txdesc_ie, value) \
IE4_SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie, value)
#define IE5_GET_TX_DESC_IE_END_8814B(txdesc_ie) \
IE5_GET_TX_DESC_IE_END(txdesc_ie)
#define IE5_SET_TX_DESC_IE_END_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_IE_END(txdesc_ie, value)
#define IE5_GET_TX_DESC_IE_UP_8814B(txdesc_ie) IE5_GET_TX_DESC_IE_UP(txdesc_ie)
#define IE5_SET_TX_DESC_IE_UP_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_IE_UP(txdesc_ie, value)
#define IE5_GET_TX_DESC_IE_NUM_8814B(txdesc_ie) \
IE5_GET_TX_DESC_IE_NUM(txdesc_ie)
#define IE5_SET_TX_DESC_IE_NUM_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_IE_NUM(txdesc_ie, value)
#define IE5_GET_TX_DESC_LEN1_L_8814B(txdesc_ie) \
IE5_GET_TX_DESC_LEN1_L(txdesc_ie)
#define IE5_SET_TX_DESC_LEN1_L_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_LEN1_L(txdesc_ie, value)
#define IE5_GET_TX_DESC_LEN0_8814B(txdesc_ie) IE5_GET_TX_DESC_LEN0(txdesc_ie)
#define IE5_SET_TX_DESC_LEN0_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_LEN0(txdesc_ie, value)
#define IE5_GET_TX_DESC_PKT_NUM_8814B(txdesc_ie) \
IE5_GET_TX_DESC_PKT_NUM(txdesc_ie)
#define IE5_SET_TX_DESC_PKT_NUM_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_PKT_NUM(txdesc_ie, value)
#define IE5_GET_TX_DESC_LEN3_8814B(txdesc_ie) IE5_GET_TX_DESC_LEN3(txdesc_ie)
#define IE5_SET_TX_DESC_LEN3_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_LEN3(txdesc_ie, value)
#define IE5_GET_TX_DESC_LEN2_8814B(txdesc_ie) IE5_GET_TX_DESC_LEN2(txdesc_ie)
#define IE5_SET_TX_DESC_LEN2_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_LEN2(txdesc_ie, value)
#define IE5_GET_TX_DESC_LEN1_H_8814B(txdesc_ie) \
IE5_GET_TX_DESC_LEN1_H(txdesc_ie)
#define IE5_SET_TX_DESC_LEN1_H_8814B(txdesc_ie, value) \
IE5_SET_TX_DESC_LEN1_H(txdesc_ie, value)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_ie_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_IE_NIC_H_
#define _HALMAC_TX_DESC_IE_NIC_H_
#if (HALMAC_8814B_SUPPORT)
#define IE0_GET_TX_DESC_IE_END(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
#define IE0_SET_TX_DESC_IE_END(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
#define IE0_GET_TX_DESC_IE_UP(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
#define IE0_SET_TX_DESC_IE_UP(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
#define IE0_GET_TX_DESC_IE_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
#define IE0_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
#define IE0_GET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 19, 1)
#define IE0_SET_TX_DESC_ARFR_TABLE_SEL(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 19, 1, value)
#define IE0_GET_TX_DESC_ARFR_HT_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 18, 1)
#define IE0_SET_TX_DESC_ARFR_HT_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 18, 1, value)
#define IE0_GET_TX_DESC_ARFR_OFDM_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 17, 1)
#define IE0_SET_TX_DESC_ARFR_OFDM_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 17, 1, value)
#define IE0_GET_TX_DESC_ARFR_CCK_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 1)
#define IE0_SET_TX_DESC_ARFR_CCK_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 1, value)
#define IE0_GET_TX_DESC_HW_RTS_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 9, 1)
#define IE0_SET_TX_DESC_HW_RTS_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 9, 1, value)
#define IE0_GET_TX_DESC_RTS_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 1)
#define IE0_SET_TX_DESC_RTS_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 1, value)
#define IE0_GET_TX_DESC_CTS2SELF(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 7, 1)
#define IE0_SET_TX_DESC_CTS2SELF(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 7, 1, value)
#define IE0_GET_TX_DESC_RTY_LMT_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 6, 1)
#define IE0_SET_TX_DESC_RTY_LMT_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 6, 1, value)
#define IE0_GET_TX_DESC_RTS_SHORT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 5, 1)
#define IE0_SET_TX_DESC_RTS_SHORT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 5, 1, value)
#define IE0_GET_TX_DESC_DISDATAFB(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 1)
#define IE0_SET_TX_DESC_DISDATAFB(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 1, value)
#define IE0_GET_TX_DESC_DISRTSFB(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 3, 1)
#define IE0_SET_TX_DESC_DISRTSFB(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 3, 1, value)
#define IE0_GET_TX_DESC_DATA_SHORT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
#define IE0_SET_TX_DESC_DATA_SHORT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
#define IE0_GET_TX_DESC_TRY_RATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
#define IE0_SET_TX_DESC_TRY_RATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
#define IE0_GET_TX_DESC_USERATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
#define IE0_SET_TX_DESC_USERATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
#define IE0_GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 27, 4)
#define IE0_SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 27, 4, value)
#define IE0_GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 22, 5)
#define IE0_SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 22, 5, value)
#define IE0_GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 6)
#define IE0_SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 6, value)
#define IE0_GET_TX_DESC_DATA_BW(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 12, 2)
#define IE0_SET_TX_DESC_DATA_BW(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 12, 2, value)
#define IE0_GET_TX_DESC_RTSRATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 7, 4)
#define IE0_SET_TX_DESC_RTSRATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 7, 4, value)
#define IE0_GET_TX_DESC_DATARATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 7)
#define IE0_SET_TX_DESC_DATARATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 7, value)
#define IE1_GET_TX_DESC_IE_END(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
#define IE1_SET_TX_DESC_IE_END(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
#define IE1_GET_TX_DESC_IE_UP(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
#define IE1_SET_TX_DESC_IE_UP(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
#define IE1_GET_TX_DESC_IE_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
#define IE1_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
#define IE1_GET_TX_DESC_AMPDU_DENSITY(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 21, 3)
#define IE1_SET_TX_DESC_AMPDU_DENSITY(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 21, 3, value)
#define IE1_GET_TX_DESC_MAX_AGG_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 5)
#define IE1_SET_TX_DESC_MAX_AGG_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 5, value)
#define IE1_GET_TX_DESC_SECTYPE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 14, 2)
#define IE1_SET_TX_DESC_SECTYPE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 14, 2, value)
#define IE1_GET_TX_DESC_MOREFRAG(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 13, 1)
#define IE1_SET_TX_DESC_MOREFRAG(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 13, 1, value)
#define IE1_GET_TX_DESC_NOACM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 12, 1)
#define IE1_SET_TX_DESC_NOACM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 12, 1, value)
#define IE1_GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 11, 1)
#define IE1_SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 11, 1, value)
#define IE1_GET_TX_DESC_NAVUSEHDR(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 10, 1)
#define IE1_SET_TX_DESC_NAVUSEHDR(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 10, 1, value)
#define IE1_GET_TX_DESC_HTC(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 9, 1)
#define IE1_SET_TX_DESC_HTC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 9, 1, value)
#define IE1_GET_TX_DESC_BMC(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 1)
#define IE1_SET_TX_DESC_BMC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 1, value)
#define IE1_GET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 7, 1)
#define IE1_SET_TX_DESC_TX_PKT_AFTER_PIFS(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 7, 1, value)
#define IE1_GET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 6, 1)
#define IE1_SET_TX_DESC_USE_MAX_TIME_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 6, 1, value)
#define IE1_GET_TX_DESC_HW_SSN_SEL(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 2)
#define IE1_SET_TX_DESC_HW_SSN_SEL(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 2, value)
#define IE1_GET_TX_DESC_DISQSELSEQ(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 3, 1)
#define IE1_SET_TX_DESC_DISQSELSEQ(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 3, 1, value)
#define IE1_GET_TX_DESC_EN_HWSEQ(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
#define IE1_SET_TX_DESC_EN_HWSEQ(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
#define IE1_GET_TX_DESC_EN_HWEXSEQ(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
#define IE1_SET_TX_DESC_EN_HWEXSEQ(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
#define IE1_GET_TX_DESC_EN_DESC_ID(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
#define IE1_SET_TX_DESC_EN_DESC_ID(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
#define IE1_GET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 24, 8)
#define IE1_SET_TX_DESC_AMPDU_MAX_TIME(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 24, 8, value)
#define IE1_GET_TX_DESC_P_AID(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 15, 9)
#define IE1_SET_TX_DESC_P_AID(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 15, 9, value)
#define IE1_GET_TX_DESC_MOREDATA(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 14, 1)
#define IE1_SET_TX_DESC_MOREDATA(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 14, 1, value)
#define IE1_GET_TX_DESC_SW_SEQ(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 12)
#define IE1_SET_TX_DESC_SW_SEQ(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 12, value)
#define IE2_GET_TX_DESC_IE_END(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
#define IE2_SET_TX_DESC_IE_END(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
#define IE2_GET_TX_DESC_IE_UP(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
#define IE2_SET_TX_DESC_IE_UP(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
#define IE2_GET_TX_DESC_IE_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
#define IE2_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
#define IE2_GET_TX_DESC_ADDR_CAM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 8)
#define IE2_SET_TX_DESC_ADDR_CAM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 8, value)
#define IE2_GET_TX_DESC_MULTIPLE_PORT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 12, 3)
#define IE2_SET_TX_DESC_MULTIPLE_PORT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 12, 3, value)
#define IE2_GET_TX_DESC_RAW(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 11, 1)
#define IE2_SET_TX_DESC_RAW(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 11, 1, value)
#define IE2_GET_TX_DESC_RDG_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 10, 1)
#define IE2_SET_TX_DESC_RDG_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 10, 1, value)
#define IE2_GET_TX_DESC_SPECIAL_CW(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 7, 1)
#define IE2_SET_TX_DESC_SPECIAL_CW(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 7, 1, value)
#define IE2_GET_TX_DESC_POLLUTED(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 6, 1)
#define IE2_SET_TX_DESC_POLLUTED(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 6, 1, value)
#define IE2_GET_TX_DESC_BT_NULL(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 5, 1)
#define IE2_SET_TX_DESC_BT_NULL(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 5, 1, value)
#define IE2_GET_TX_DESC_NULL_1(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 1)
#define IE2_SET_TX_DESC_NULL_1(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 1, value)
#define IE2_GET_TX_DESC_NULL_0(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 3, 1)
#define IE2_SET_TX_DESC_NULL_0(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 3, 1, value)
#define IE2_GET_TX_DESC_TRI_FRAME(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
#define IE2_SET_TX_DESC_TRI_FRAME(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
#define IE2_GET_TX_DESC_SPE_RPT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
#define IE2_SET_TX_DESC_SPE_RPT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
#define IE2_GET_TX_DESC_FTM_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
#define IE2_SET_TX_DESC_FTM_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
#define IE2_GET_TX_DESC_MBSSID(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 27, 4)
#define IE2_SET_TX_DESC_MBSSID(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 27, 4, value)
#define IE2_GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 11)
#define IE2_SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 11, value)
#define IE2_GET_TX_DESC_RDG_NAV_EXT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 15, 1)
#define IE2_SET_TX_DESC_RDG_NAV_EXT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 15, 1, value)
#define IE2_GET_TX_DESC_DROP_ID(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 12, 2)
#define IE2_SET_TX_DESC_DROP_ID(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 12, 2, value)
#define IE2_GET_TX_DESC_SW_DEFINE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 12)
#define IE2_SET_TX_DESC_SW_DEFINE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 12, value)
#define IE3_GET_TX_DESC_IE_END(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
#define IE3_SET_TX_DESC_IE_END(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
#define IE3_GET_TX_DESC_IE_UP(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
#define IE3_SET_TX_DESC_IE_UP(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
#define IE3_GET_TX_DESC_IE_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
#define IE3_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
#define IE3_GET_TX_DESC_DATA_SC(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 20, 4)
#define IE3_SET_TX_DESC_DATA_SC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 20, 4, value)
#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 16, 4)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 16, 4, value)
#define IE3_GET_TX_DESC_CTRL_CNT(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 4)
#define IE3_SET_TX_DESC_CTRL_CNT(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 4, value)
#define IE3_GET_TX_DESC_CTRL_CNT_VALID(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
#define IE3_SET_TX_DESC_CTRL_CNT_VALID(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
#define IE3_GET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
#define IE3_SET_TX_DESC_SIGNALING_TA_PKT_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
#define IE3_GET_TX_DESC_G_ID(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 24, 6)
#define IE3_SET_TX_DESC_G_ID(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 24, 6, value)
#define IE3_GET_TX_DESC_SND_TARGET(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 8)
#define IE3_SET_TX_DESC_SND_TARGET(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 8, value)
#define IE3_GET_TX_DESC_CCA_RTS(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 11, 2)
#define IE3_SET_TX_DESC_CCA_RTS(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 11, 2, value)
#define IE3_GET_TX_DESC_SND_PKT_SEL(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 9, 2)
#define IE3_SET_TX_DESC_SND_PKT_SEL(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 9, 2, value)
#define IE3_GET_TX_DESC_NDPA(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 7, 2)
#define IE3_SET_TX_DESC_NDPA(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 7, 2, value)
#define IE3_GET_TX_DESC_MU_DATARATE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 7)
#define IE3_SET_TX_DESC_MU_DATARATE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 7, value)
#define IE4_GET_TX_DESC_IE_END(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
#define IE4_SET_TX_DESC_IE_END(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
#define IE4_GET_TX_DESC_IE_UP(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
#define IE4_SET_TX_DESC_IE_UP(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
#define IE4_GET_TX_DESC_IE_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
#define IE4_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
#define IE4_GET_TX_DESC_VCS_STBC(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 10, 2)
#define IE4_SET_TX_DESC_VCS_STBC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 10, 2, value)
#define IE4_GET_TX_DESC_DATA_STBC(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 8, 2)
#define IE4_SET_TX_DESC_DATA_STBC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 8, 2, value)
#define IE4_GET_TX_DESC_DATA_LDPC(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 2, 1)
#define IE4_SET_TX_DESC_DATA_LDPC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 2, 1, value)
#define IE4_GET_TX_DESC_GF(txdesc_ie) LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 1, 1)
#define IE4_SET_TX_DESC_GF(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 1, 1, value)
#define IE4_GET_TX_DESC_LSIG_TXOP_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 1)
#define IE4_SET_TX_DESC_LSIG_TXOP_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 1, value)
#define IE4_GET_TX_DESC_PATH_MAPA(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 30, 2)
#define IE4_SET_TX_DESC_PATH_MAPA(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 30, 2, value)
#define IE4_GET_TX_DESC_PATH_MAPB(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 28, 2)
#define IE4_SET_TX_DESC_PATH_MAPB(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 28, 2, value)
#define IE4_GET_TX_DESC_PATH_MAPC(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 26, 2)
#define IE4_SET_TX_DESC_PATH_MAPC(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 26, 2, value)
#define IE4_GET_TX_DESC_PATH_MAPD(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 24, 2)
#define IE4_SET_TX_DESC_PATH_MAPD(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 24, 2, value)
#define IE4_GET_TX_DESC_ANTSEL_A(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 20, 4)
#define IE4_SET_TX_DESC_ANTSEL_A(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 20, 4, value)
#define IE4_GET_TX_DESC_ANTSEL_B(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 16, 4)
#define IE4_SET_TX_DESC_ANTSEL_B(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 16, 4, value)
#define IE4_GET_TX_DESC_ANTSEL_C(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 12, 4)
#define IE4_SET_TX_DESC_ANTSEL_C(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 12, 4, value)
#define IE4_GET_TX_DESC_ANTSEL_D(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 8, 4)
#define IE4_SET_TX_DESC_ANTSEL_D(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 8, 4, value)
#define IE4_GET_TX_DESC_NTX_PATH_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 4, 4)
#define IE4_SET_TX_DESC_NTX_PATH_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 4, 4, value)
#define IE4_GET_TX_DESC_ANTLSEL_EN(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 3, 1)
#define IE4_SET_TX_DESC_ANTLSEL_EN(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 3, 1, value)
#define IE4_GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 2)
#define IE4_SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 2, value)
#define IE5_GET_TX_DESC_IE_END(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 31, 1)
#define IE5_SET_TX_DESC_IE_END(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 31, 1, value)
#define IE5_GET_TX_DESC_IE_UP(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 30, 1)
#define IE5_SET_TX_DESC_IE_UP(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 30, 1, value)
#define IE5_GET_TX_DESC_IE_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 24, 4)
#define IE5_SET_TX_DESC_IE_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 24, 4, value)
#define IE5_GET_TX_DESC_LEN1_L(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 17, 7)
#define IE5_SET_TX_DESC_LEN1_L(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 17, 7, value)
#define IE5_GET_TX_DESC_LEN0(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 4, 13)
#define IE5_SET_TX_DESC_LEN0(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 4, 13, value)
#define IE5_GET_TX_DESC_PKT_NUM(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x00, 0, 4)
#define IE5_SET_TX_DESC_PKT_NUM(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x00, 0, 4, value)
#define IE5_GET_TX_DESC_LEN3(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 19, 13)
#define IE5_SET_TX_DESC_LEN3(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 19, 13, value)
#define IE5_GET_TX_DESC_LEN2(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 6, 13)
#define IE5_SET_TX_DESC_LEN2(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 6, 13, value)
#define IE5_GET_TX_DESC_LEN1_H(txdesc_ie) \
LE_BITS_TO_4BYTE(txdesc_ie + 0x04, 0, 6)
#define IE5_SET_TX_DESC_LEN1_H(txdesc_ie, value) \
SET_BITS_TO_LE_4BYTE(txdesc_ie + 0x04, 0, 6, value)
#endif
#endif
================================================
FILE: hal/halmac/halmac_tx_desc_nic.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TX_DESC_NIC_H_
#define _HALMAC_TX_DESC_NIC_H_
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*TXDESC_WORD0*/
#define SET_TX_DESC_DISQSELSEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 31, 1, value)
#define GET_TX_DESC_DISQSELSEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 31, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_IE_END_BODY(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 31, 1, value)
#define GET_TX_DESC_IE_END_BODY(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 31, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_GF(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 30, 1, value)
#define GET_TX_DESC_GF(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 30, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_AGG_EN_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 30, 1, value)
#define GET_TX_DESC_AGG_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 30, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NO_ACM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 29, 1, value)
#define GET_TX_DESC_NO_ACM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 29, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_BK_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 29, 1, value)
#define GET_TX_DESC_BK_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 29, 1)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_BCNPKT_TSF_CTRL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 28, 1, value)
#define GET_TX_DESC_BCNPKT_TSF_CTRL(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x00, 28, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_AMSDU_PAD_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 27, 1, value)
#define GET_TX_DESC_AMSDU_PAD_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 27, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_LS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 26, 1, value)
#define GET_TX_DESC_LS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 26, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_HTC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 25, 1, value)
#define GET_TX_DESC_HTC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 25, 1)
#define SET_TX_DESC_BMC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 24, 1, value)
#define GET_TX_DESC_BMC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 24, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_PKT_OFFSET_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 24, 5, value)
#define GET_TX_DESC_PKT_OFFSET_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 24, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_OFFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 16, 8, value)
#define GET_TX_DESC_OFFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 16, 8)
#define SET_TX_DESC_TXPKTSIZE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x00, 0, 16, value)
#define GET_TX_DESC_TXPKTSIZE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x00, 0, 16)
#endif
#if (HALMAC_8198F_SUPPORT)
/*WORD1*/
#define SET_TX_DESC_HW_AES_IV_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 31, 1, value)
#define GET_TX_DESC_HW_AES_IV_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 31, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_AMSDU(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
#define GET_TX_DESC_AMSDU(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_FTM_EN_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
#define GET_TX_DESC_FTM_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_KEYID_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 30, 1, value)
#define GET_TX_DESC_KEYID_SEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 30, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MOREDATA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 29, 1, value)
#define GET_TX_DESC_MOREDATA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 29, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_HW_AES_IV_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 29, 1, value)
#define GET_TX_DESC_HW_AES_IV_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 29, 1)
#define SET_TX_DESC_MHR_CP(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 25, 1, value)
#define GET_TX_DESC_MHR_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 25, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PKT_OFFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 24, 5, value)
#define GET_TX_DESC_PKT_OFFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 24, 5)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_SMH_EN_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 24, 1, value)
#define GET_TX_DESC_SMH_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 24, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SEC_TYPE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 22, 2, value)
#define GET_TX_DESC_SEC_TYPE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 22, 2)
#define SET_TX_DESC_EN_DESC_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 21, 1, value)
#define GET_TX_DESC_EN_DESC_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 21, 1)
#define SET_TX_DESC_RATE_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 16, 5, value)
#define GET_TX_DESC_RATE_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 16, 5)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_SMH_CAM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 16, 8, value)
#define GET_TX_DESC_SMH_CAM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 16, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PIFS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 15, 1, value)
#define GET_TX_DESC_PIFS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 15, 1)
#define SET_TX_DESC_LSIG_TXOP_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 14, 1, value)
#define GET_TX_DESC_LSIG_TXOP_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 14, 1)
#define SET_TX_DESC_RD_NAV_EXT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 13, 1, value)
#define GET_TX_DESC_RD_NAV_EXT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 13, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_EXT_EDCA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 13, 1, value)
#define GET_TX_DESC_EXT_EDCA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 13, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8814B_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_QSEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 8, 5, value)
#define GET_TX_DESC_QSEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 8, 5)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_SPECIAL_CW(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 7, 1, value)
#define GET_TX_DESC_SPECIAL_CW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 7, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MACID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 0, 7, value)
#define GET_TX_DESC_MACID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 0, 7)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_MACID_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x04, 0, 7, value)
#define GET_TX_DESC_MACID_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x04, 0, 7)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD2*/
#define SET_TX_DESC_HW_AES_IV(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 31, 1, value)
#define GET_TX_DESC_HW_AES_IV(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 31, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_CHK_EN_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 31, 1, value)
#define GET_TX_DESC_CHK_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 31, 1)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_FTM_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 30, 1, value)
#define GET_TX_DESC_FTM_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 30, 1)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTCEL_D_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 28, 4, value)
#define GET_TX_DESC_ANTCEL_D_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 28, 4)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_DMA_PRI(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 27, 1, value)
#define GET_TX_DESC_DMA_PRI(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 27, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_G_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 6, value)
#define GET_TX_DESC_G_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 6)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_MAX_AMSDU_MODE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 3, value)
#define GET_TX_DESC_MAX_AMSDU_MODE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 3)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_C_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 24, 4, value)
#define GET_TX_DESC_ANTSEL_C_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 24, 4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_BT_NULL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 23, 1, value)
#define GET_TX_DESC_BT_NULL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 23, 1)
#define SET_TX_DESC_AMPDU_DENSITY(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 20, 3, value)
#define GET_TX_DESC_AMPDU_DENSITY(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 20, 3)
#define SET_TX_DESC_SPE_RPT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 19, 1, value)
#define GET_TX_DESC_SPE_RPT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 19, 1)
#define SET_TX_DESC_RAW(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 18, 1, value)
#define GET_TX_DESC_RAW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 18, 1)
#define SET_TX_DESC_MOREFRAG(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 17, 1, value)
#define GET_TX_DESC_MOREFRAG(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 17, 1)
#define SET_TX_DESC_BK(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 16, 1, value)
#define GET_TX_DESC_BK(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 16, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 16, 8, value)
#define GET_TX_DESC_DMA_TXAGG_NUM_V1(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 16, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NULL_1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 15, 1, value)
#define GET_TX_DESC_NULL_1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 15, 1)
#define SET_TX_DESC_NULL_0(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 14, 1, value)
#define GET_TX_DESC_NULL_0(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 14, 1)
#define SET_TX_DESC_RDG_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 13, 1, value)
#define GET_TX_DESC_RDG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 13, 1)
#define SET_TX_DESC_AGG_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 12, 1, value)
#define GET_TX_DESC_AGG_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 12, 1)
#define SET_TX_DESC_CCA_RTS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 10, 2, value)
#define GET_TX_DESC_CCA_RTS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 10, 2)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TRI_FRAME(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 9, 1, value)
#define GET_TX_DESC_TRI_FRAME(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 9, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_P_AID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 0, 9, value)
#define GET_TX_DESC_P_AID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x08, 0, 9)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x08, 0, 16, value)
#define GET_TX_DESC_TXDESC_CHECKSUM_V1(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x08, 0, 16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD3*/
#define SET_TX_DESC_AMPDU_MAX_TIME(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 24, 8, value)
#define GET_TX_DESC_AMPDU_MAX_TIME(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x0C, 24, 8)
#define SET_TX_DESC_NDPA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 22, 2, value)
#define GET_TX_DESC_NDPA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 22, 2)
#define SET_TX_DESC_MAX_AGG_NUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 17, 5, value)
#define GET_TX_DESC_MAX_AGG_NUM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 17, 5)
#define SET_TX_DESC_USE_MAX_TIME_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 16, 1, value)
#define GET_TX_DESC_USE_MAX_TIME_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x0C, 16, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_OFFLOAD_SIZE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 16, 15, value)
#define GET_TX_DESC_OFFLOAD_SIZE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 16, 15)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NAVUSEHDR(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 15, 1, value)
#define GET_TX_DESC_NAVUSEHDR(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 15, 1)
#define SET_TX_DESC_CHK_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 14, 1, value)
#define GET_TX_DESC_CHK_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 14, 1)
#define SET_TX_DESC_HW_RTS_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 13, 1, value)
#define GET_TX_DESC_HW_RTS_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 13, 1)
#define SET_TX_DESC_RTSEN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 12, 1, value)
#define GET_TX_DESC_RTSEN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 12, 1)
#define SET_TX_DESC_CTS2SELF(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 11, 1, value)
#define GET_TX_DESC_CTS2SELF(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 11, 1)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_CHANNEL_DMA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 11, 5, value)
#define GET_TX_DESC_CHANNEL_DMA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 11, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_DISDATAFB(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 10, 1, value)
#define GET_TX_DESC_DISDATAFB(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 10, 1)
#define SET_TX_DESC_DISRTSFB(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 9, 1, value)
#define GET_TX_DESC_DISRTSFB(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 9, 1)
#define SET_TX_DESC_USE_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 8, 1, value)
#define GET_TX_DESC_USE_RATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 8, 1)
#define SET_TX_DESC_HW_SSN_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 6, 2, value)
#define GET_TX_DESC_HW_SSN_SEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 6, 2)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_IE_CNT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 6, 3, value)
#define GET_TX_DESC_IE_CNT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 6, 3)
#define SET_TX_DESC_IE_CNT_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 5, 1, value)
#define GET_TX_DESC_IE_CNT_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 5, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_WHEADER_LEN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 0, 5, value)
#define GET_TX_DESC_WHEADER_LEN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 0, 5)
#endif
#if (HALMAC_8814B_SUPPORT)
#define SET_TX_DESC_WHEADER_LEN_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x0C, 0, 5, value)
#define GET_TX_DESC_WHEADER_LEN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x0C, 0, 5)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD4*/
#define SET_TX_DESC_PCTS_MASK_IDX(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 30, 2, value)
#define GET_TX_DESC_PCTS_MASK_IDX(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 30, 2)
#define SET_TX_DESC_PCTS_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 29, 1, value)
#define GET_TX_DESC_PCTS_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 29, 1)
#define SET_TX_DESC_RTSRATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 24, 5, value)
#define GET_TX_DESC_RTSRATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 24, 5)
#define SET_TX_DESC_RTS_DATA_RTY_LMT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 18, 6, value)
#define GET_TX_DESC_RTS_DATA_RTY_LMT(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 18, 6)
#define SET_TX_DESC_RTY_LMT_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 17, 1, value)
#define GET_TX_DESC_RTY_LMT_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 17, 1)
#define SET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 13, 4, value)
#define GET_TX_DESC_RTS_RTY_LOWEST_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 13, 4)
#define SET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 8, 5, value)
#define GET_TX_DESC_DATA_RTY_LOWEST_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x10, 8, 5)
#define SET_TX_DESC_TRY_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 7, 1, value)
#define GET_TX_DESC_TRY_RATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 7, 1)
#define SET_TX_DESC_DATARATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x10, 0, 7, value)
#define GET_TX_DESC_DATARATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x10, 0, 7)
/*TXDESC_WORD5*/
#define SET_TX_DESC_POLLUTED(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 31, 1, value)
#define GET_TX_DESC_POLLUTED(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 31, 1)
#endif
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANTSEL_EN_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 30, 1, value)
#define GET_TX_DESC_ANTSEL_EN_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 30, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_TXPWR_OFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 3, value)
#define GET_TX_DESC_TXPWR_OFSET(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 3)
#endif
#if (HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TXPWR_OFSET_TYPE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 2, value)
#define GET_TX_DESC_TXPWR_OFSET_TYPE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_TXPWR_OFSET_TYPE_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 28, 3, value)
#define GET_TX_DESC_TXPWR_OFSET_TYPE_V1(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 28, 3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8192F_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TX_ANT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 24, 4, value)
#define GET_TX_DESC_TX_ANT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 24, 4)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_DROP_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 24, 2, value)
#define GET_TX_DESC_DROP_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 24, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_DROP_ID_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 22, 2, value)
#define GET_TX_DESC_DROP_ID_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 22, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PORT_ID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 21, 3, value)
#define GET_TX_DESC_PORT_ID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 21, 3)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_PORT_ID_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 21, 1, value)
#define GET_TX_DESC_PORT_ID_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 21, 1)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8821C_SUPPORT || \
HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MULTIPLE_PORT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 18, 3, value)
#define GET_TX_DESC_MULTIPLE_PORT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 18, 3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SIGNALING_TAPKT_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 17, 1, value)
#define GET_TX_DESC_SIGNALING_TAPKT_EN(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 17, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8197F_SUPPORT || HALMAC_8198F_SUPPORT || \
HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_RTS_SC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 13, 4, value)
#define GET_TX_DESC_RTS_SC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 13, 4)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 13, 4, value)
#define GET_TX_DESC_SIGNALING_TA_PKT_SC(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x14, 13, 4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_RTS_SHORT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 12, 1, value)
#define GET_TX_DESC_RTS_SHORT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 12, 1)
#define SET_TX_DESC_VCS_STBC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 10, 2, value)
#define GET_TX_DESC_VCS_STBC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 10, 2)
#define SET_TX_DESC_DATA_STBC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 8, 2, value)
#define GET_TX_DESC_DATA_STBC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 8, 2)
#define SET_TX_DESC_DATA_LDPC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 7, 1, value)
#define GET_TX_DESC_DATA_LDPC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 7, 1)
#define SET_TX_DESC_DATA_BW(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 5, 2, value)
#define GET_TX_DESC_DATA_BW(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 5, 2)
#define SET_TX_DESC_DATA_SHORT(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 4, 1, value)
#define GET_TX_DESC_DATA_SHORT(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 4, 1)
#define SET_TX_DESC_DATA_SC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x14, 0, 4, value)
#define GET_TX_DESC_DATA_SC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x14, 0, 4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD6*/
#define SET_TX_DESC_ANTSEL_D(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 30, 2, value)
#define GET_TX_DESC_ANTSEL_D(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 30, 2)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPD_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 30, 2, value)
#define GET_TX_DESC_ANT_MAPD_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 30, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPC_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 30, 2, value)
#define GET_TX_DESC_ANT_MAPC_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 30, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPD(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 2, value)
#define GET_TX_DESC_ANT_MAPD(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 2)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPC_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 2, value)
#define GET_TX_DESC_ANT_MAPC_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPB_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 28, 2, value)
#define GET_TX_DESC_ANT_MAPB_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 28, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 2, value)
#define GET_TX_DESC_ANT_MAPC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 2)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPB_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 2, value)
#define GET_TX_DESC_ANT_MAPB_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPA_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 26, 2, value)
#define GET_TX_DESC_ANT_MAPA_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 26, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPB(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 2, value)
#define GET_TX_DESC_ANT_MAPB(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 2)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANT_MAPA_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 2, value)
#define GET_TX_DESC_ANT_MAPA_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_D_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 24, 2, value)
#define GET_TX_DESC_ANTSEL_D_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 24, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANT_MAPA(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 22, 2, value)
#define GET_TX_DESC_ANT_MAPA(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 22, 2)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_C_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 22, 2, value)
#define GET_TX_DESC_ANTSEL_C_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 22, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANTSEL_C(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 20, 2, value)
#define GET_TX_DESC_ANTSEL_C(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 20, 2)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_B_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 20, 4, value)
#define GET_TX_DESC_ANTSEL_B_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 20, 4)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_B_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 19, 3, value)
#define GET_TX_DESC_ANTSEL_B_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 19, 3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_ANTSEL_B(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 18, 2, value)
#define GET_TX_DESC_ANTSEL_B(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 18, 2)
#define SET_TX_DESC_ANTSEL_A(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 2, value)
#define GET_TX_DESC_ANTSEL_A(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 2)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_A_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 4, value)
#define GET_TX_DESC_ANTSEL_A_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 4)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANTSEL_A_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 16, 3, value)
#define GET_TX_DESC_ANTSEL_A_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 16, 3)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MBSSID(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 12, 4, value)
#define GET_TX_DESC_MBSSID(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 12, 4)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SW_DEFINE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 0, 12, value)
#define GET_TX_DESC_SW_DEFINE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 0, 12)
#endif
#if (HALMAC_8198F_SUPPORT || HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_SWPS_SEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x18, 0, 12, value)
#define GET_TX_DESC_SWPS_SEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x18, 0, 12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
/*TXDESC_WORD7*/
#define SET_TX_DESC_DMA_TXAGG_NUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 24, 8, value)
#define GET_TX_DESC_DMA_TXAGG_NUM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 24, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_FINAL_DATA_RATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 24, 8, value)
#define GET_TX_DESC_FINAL_DATA_RATE(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x1C, 24, 8)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_ANT_MAPD_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 22, 2, value)
#define GET_TX_DESC_ANT_MAPD_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 22, 2)
#define SET_TX_DESC_ANTSEL_EN_V2(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 21, 1, value)
#define GET_TX_DESC_ANTSEL_EN_V2(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 21, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NTX_MAP(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 20, 4, value)
#define GET_TX_DESC_NTX_MAP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 20, 4)
#endif
#if (HALMAC_8198F_SUPPORT)
#define SET_TX_DESC_ANTSEL_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 19, 1, value)
#define GET_TX_DESC_ANTSEL_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 19, 1)
#define SET_TX_DESC_MBSSID_EX(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 16, 3, value)
#define GET_TX_DESC_MBSSID_EX(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 16, 3)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_MBSSID_EX_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 16, 1, value)
#define GET_TX_DESC_MBSSID_EX_V1(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 16, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TX_BUFF_SIZE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 16, value)
#define GET_TX_DESC_TX_BUFF_SIZE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 16)
#define SET_TX_DESC_TXDESC_CHECKSUM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 16, value)
#define GET_TX_DESC_TXDESC_CHECKSUM(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 16)
#define SET_TX_DESC_TIMESTAMP(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x1C, 0, 16, value)
#define GET_TX_DESC_TIMESTAMP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x1C, 0, 16)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*TXDESC_WORD8*/
#define SET_TX_DESC_TXWIFI_CP(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 31, 1, value)
#define GET_TX_DESC_TXWIFI_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 31, 1)
#define SET_TX_DESC_MAC_CP(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 30, 1, value)
#define GET_TX_DESC_MAC_CP(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 30, 1)
#define SET_TX_DESC_STW_PKTRE_DIS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 29, 1, value)
#define GET_TX_DESC_STW_PKTRE_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 29, 1)
#define SET_TX_DESC_STW_RB_DIS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 28, 1, value)
#define GET_TX_DESC_STW_RB_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 28, 1)
#define SET_TX_DESC_STW_RATE_DIS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 27, 1, value)
#define GET_TX_DESC_STW_RATE_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 27, 1)
#define SET_TX_DESC_STW_ANT_DIS(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 26, 1, value)
#define GET_TX_DESC_STW_ANT_DIS(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 26, 1)
#define SET_TX_DESC_STW_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 25, 1, value)
#define GET_TX_DESC_STW_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 25, 1)
#define SET_TX_DESC_SMH_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 24, 1, value)
#define GET_TX_DESC_SMH_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 24, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TAILPAGE_L(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 24, 8, value)
#define GET_TX_DESC_TAILPAGE_L(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 24, 8)
#define SET_TX_DESC_SDIO_DMASEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 16, 8, value)
#define GET_TX_DESC_SDIO_DMASEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 16, 8)
#define SET_TX_DESC_NEXTHEADPAGE_L(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 16, 8, value)
#define GET_TX_DESC_NEXTHEADPAGE_L(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x20, 16, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_EN_HWSEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 15, 1, value)
#define GET_TX_DESC_EN_HWSEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 15, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT)
#define SET_TX_DESC_EN_HWEXSEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 14, 1, value)
#define GET_TX_DESC_EN_HWEXSEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 14, 1)
#endif
#if (HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_EN_HWSEQ_MODE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 14, 2, value)
#define GET_TX_DESC_EN_HWSEQ_MODE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 14, 2)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_DATA_RC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 8, 6, value)
#define GET_TX_DESC_DATA_RC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 8, 6)
#define SET_TX_DESC_BAR_RTY_TH(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 6, 2, value)
#define GET_TX_DESC_BAR_RTY_TH(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 6, 2)
#define SET_TX_DESC_RTS_RC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x20, 0, 6, value)
#define GET_TX_DESC_RTS_RC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x20, 0, 6)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
/*TXDESC_WORD9*/
#define SET_TX_DESC_TAILPAGE_H(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 28, 4, value)
#define GET_TX_DESC_TAILPAGE_H(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 28, 4)
#define SET_TX_DESC_NEXTHEADPAGE_H(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 24, 4, value)
#define GET_TX_DESC_NEXTHEADPAGE_H(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 24, 4)
#endif
#if (HALMAC_8192F_SUPPORT)
#define SET_TX_DESC_FINAL_DATA_RATE_V1(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 24, 8, value)
#define GET_TX_DESC_FINAL_DATA_RATE_V1(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 24, 8)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SW_SEQ(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 12, 12, value)
#define GET_TX_DESC_SW_SEQ(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 12, 12)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_TXBF_PATH(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 11, 1, value)
#define GET_TX_DESC_TXBF_PATH(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 11, 1)
#endif
#if (HALMAC_8814A_SUPPORT || HALMAC_8822B_SUPPORT || HALMAC_8197F_SUPPORT || \
HALMAC_8821C_SUPPORT || HALMAC_8198F_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8192F_SUPPORT || HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_PADDING_LEN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 0, 11, value)
#define GET_TX_DESC_PADDING_LEN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x24, 0, 11)
#define SET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x24, 0, 8, value)
#define GET_TX_DESC_GROUP_BIT_IE_OFFSET(txdesc) \
LE_BITS_TO_4BYTE(txdesc + 0x24, 0, 8)
#endif
#if (HALMAC_8812F_SUPPORT)
/*WORD10*/
#define SET_TX_DESC_HT_DATA_SND(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 31, 1, value)
#define GET_TX_DESC_HT_DATA_SND(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 31, 1)
#define SET_TX_DESC_SHCUT_CAM(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 16, 6, value)
#define GET_TX_DESC_SHCUT_CAM(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 16, 6)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_MU_DATARATE(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 8, 8, value)
#define GET_TX_DESC_MU_DATARATE(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 8, 8)
#define SET_TX_DESC_MU_RC(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 4, 4, value)
#define GET_TX_DESC_MU_RC(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 4, 4)
#endif
#if (HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_NDPA_RATE_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 3, 1, value)
#define GET_TX_DESC_NDPA_RATE_SEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 3, 1)
#define SET_TX_DESC_HW_NDPA_EN(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 2, 1, value)
#define GET_TX_DESC_HW_NDPA_EN(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 2, 1)
#endif
#if (HALMAC_8822B_SUPPORT || HALMAC_8821C_SUPPORT || HALMAC_8822C_SUPPORT || \
HALMAC_8812F_SUPPORT)
#define SET_TX_DESC_SND_PKT_SEL(txdesc, value) \
SET_BITS_TO_LE_4BYTE(txdesc + 0x28, 0, 2, value)
#define GET_TX_DESC_SND_PKT_SEL(txdesc) LE_BITS_TO_4BYTE(txdesc + 0x28, 0, 2)
#endif
#endif
================================================
FILE: hal/halmac/halmac_type.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef _HALMAC_TYPE_H_
#define _HALMAC_TYPE_H_
#include "halmac_2_platform.h"
#include "halmac_hw_cfg.h"
#include "halmac_fw_info.h"
#include "halmac_intf_phy_cmd.h"
#include "halmac_state_machine.h"
#define IN
#define OUT
#define INOUT
#define HALMAC_BCN_IE_BMP_SIZE 24 /* ID0~ID191, 192/8=24 */
#ifndef HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE
#define HALMAC_RX_FIFO_EXPANDING_MODE_PKT_SIZE 80
#endif
#ifndef HALMAC_MSG_LEVEL_TRACE
#define HALMAC_MSG_LEVEL_TRACE 3
#endif
#ifndef HALMAC_MSG_LEVEL_WARNING
#define HALMAC_MSG_LEVEL_WARNING 2
#endif
#ifndef HALMAC_MSG_LEVEL_ERR
#define HALMAC_MSG_LEVEL_ERR 1
#endif
#ifndef HALMAC_MSG_LEVEL_NO_LOG
#define HALMAC_MSG_LEVEL_NO_LOG 0
#endif
#ifndef HALMAC_SDIO_SUPPORT
#define HALMAC_SDIO_SUPPORT 1
#endif
#ifndef HALMAC_USB_SUPPORT
#define HALMAC_USB_SUPPORT 1
#endif
#ifndef HALMAC_PCIE_SUPPORT
#define HALMAC_PCIE_SUPPORT 1
#endif
#ifndef HALMAC_MSG_LEVEL
#define HALMAC_MSG_LEVEL HALMAC_MSG_LEVEL_TRACE
#endif
/* platform api */
#define PLTFM_SDIO_CMD52_R(offset) \
adapter->pltfm_api->SDIO_CMD52_READ(adapter->drv_adapter, offset)
#define PLTFM_SDIO_CMD53_R8(offset) \
adapter->pltfm_api->SDIO_CMD53_READ_8(adapter->drv_adapter, offset)
#define PLTFM_SDIO_CMD53_R16(offset) \
adapter->pltfm_api->SDIO_CMD53_READ_16(adapter->drv_adapter, offset)
#define PLTFM_SDIO_CMD53_R32(offset) \
adapter->pltfm_api->SDIO_CMD53_READ_32(adapter->drv_adapter, offset)
#define PLTFM_SDIO_CMD53_RN(offset, size, data) \
adapter->pltfm_api->SDIO_CMD53_READ_N(adapter->drv_adapter, offset, \
size, data)
#define PLTFM_SDIO_CMD52_W(offset, val) \
adapter->pltfm_api->SDIO_CMD52_WRITE(adapter->drv_adapter, offset, val)
#define PLTFM_SDIO_CMD53_W8(offset, val) \
adapter->pltfm_api->SDIO_CMD53_WRITE_8(adapter->drv_adapter, offset, \
val)
#define PLTFM_SDIO_CMD53_W16(offset, val) \
adapter->pltfm_api->SDIO_CMD53_WRITE_16(adapter->drv_adapter, offset, \
val)
#define PLTFM_SDIO_CMD53_W32(offset, val) \
adapter->pltfm_api->SDIO_CMD53_WRITE_32(adapter->drv_adapter, offset, \
val)
#define PLTFM_SDIO_CMD52_CIA_R(offset) \
adapter->pltfm_api->SDIO_CMD52_CIA_READ(adapter->drv_adapter, offset)
#define PLTFM_REG_R8(offset) \
adapter->pltfm_api->REG_READ_8(adapter->drv_adapter, offset)
#define PLTFM_REG_R16(offset) \
adapter->pltfm_api->REG_READ_16(adapter->drv_adapter, offset)
#define PLTFM_REG_R32(offset) \
adapter->pltfm_api->REG_READ_32(adapter->drv_adapter, offset)
#define PLTFM_REG_W8(offset, val) \
adapter->pltfm_api->REG_WRITE_8(adapter->drv_adapter, offset, val)
#define PLTFM_REG_W16(offset, val) \
adapter->pltfm_api->REG_WRITE_16(adapter->drv_adapter, offset, val)
#define PLTFM_REG_W32(offset, val) \
adapter->pltfm_api->REG_WRITE_32(adapter->drv_adapter, offset, val)
#define PLTFM_SEND_RSVD_PAGE(buf, size) \
adapter->pltfm_api->SEND_RSVD_PAGE(adapter->drv_adapter, buf, size)
#define PLTFM_SEND_H2C_PKT(buf, size) \
adapter->pltfm_api->SEND_H2C_PKT(adapter->drv_adapter, buf, size)
#define PLTFM_FREE(buf, size) \
adapter->pltfm_api->RTL_FREE(adapter->drv_adapter, buf, size)
#define PLTFM_MALLOC(size) \
adapter->pltfm_api->RTL_MALLOC(adapter->drv_adapter, size)
#define PLTFM_MEMCPY(dest, src, size) \
adapter->pltfm_api->RTL_MEMCPY(adapter->drv_adapter, dest, src, size)
#define PLTFM_MEMSET(addr, value, size) \
adapter->pltfm_api->RTL_MEMSET(adapter->drv_adapter, addr, value, size)
#define PLTFM_DELAY_US(us) \
adapter->pltfm_api->RTL_DELAY_US(adapter->drv_adapter, us)
#define PLTFM_MUTEX_INIT(mutex) \
adapter->pltfm_api->MUTEX_INIT(adapter->drv_adapter, mutex)
#define PLTFM_MUTEX_DEINIT(mutex) \
adapter->pltfm_api->MUTEX_DEINIT(adapter->drv_adapter, mutex)
#define PLTFM_MUTEX_LOCK(mutex) \
adapter->pltfm_api->MUTEX_LOCK(adapter->drv_adapter, mutex)
#define PLTFM_MUTEX_UNLOCK(mutex) \
adapter->pltfm_api->MUTEX_UNLOCK(adapter->drv_adapter, mutex)
#define PLTFM_EVENT_SIG(feature_id, proc_status, buf, size) \
adapter->pltfm_api->EVENT_INDICATION(adapter->drv_adapter, feature_id, \
proc_status, buf, size)
#if HALMAC_PLATFORM_WINDOWS
#define PLTFM_MSG_PRINT adapter->pltfm_api->MSG_PRINT
#endif
#define PLTFM_MSG_ALWAYS(...) \
adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT, \
HALMAC_DBG_ALWAYS, __VA_ARGS__)
#if HALMAC_DBG_MSG_ENABLE
/* Enable debug msg depends on HALMAC_MSG_LEVEL */
#if (HALMAC_MSG_LEVEL >= HALMAC_MSG_LEVEL_ERR)
#define PLTFM_MSG_ERR(...) \
adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT, \
HALMAC_DBG_ERR, __VA_ARGS__)
#else
#define PLTFM_MSG_ERR(...) do {} while (0)
#endif
#if (HALMAC_MSG_LEVEL >= HALMAC_MSG_LEVEL_WARNING)
#define PLTFM_MSG_WARN(...) \
adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT, \
HALMAC_DBG_WARN, __VA_ARGS__)
#else
#define PLTFM_MSG_WARN(...) do {} while (0)
#endif
#if (HALMAC_MSG_LEVEL >= HALMAC_MSG_LEVEL_TRACE)
#define PLTFM_MSG_TRACE(...) \
adapter->pltfm_api->MSG_PRINT(adapter->drv_adapter, HALMAC_MSG_INIT, \
HALMAC_DBG_TRACE, __VA_ARGS__)
#else
#define PLTFM_MSG_TRACE(...) do {} while (0)
#endif
#else
/* Disable debug msg */
#define PLTFM_MSG_ERR(...) do {} while (0)
#define PLTFM_MSG_WARN(...) do {} while (0)
#define PLTFM_MSG_TRACE(...) do {} while (0)
#endif
#define HALMAC_REG_R8(offset) api->halmac_reg_read_8(adapter, offset)
#define HALMAC_REG_R16(offset) api->halmac_reg_read_16(adapter, offset)
#define HALMAC_REG_R32(offset) api->halmac_reg_read_32(adapter, offset)
#define HALMAC_REG_W8(offset, val) api->halmac_reg_write_8(adapter, offset, val)
#define HALMAC_REG_W16(offset, val) \
api->halmac_reg_write_16(adapter, offset, val)
#define HALMAC_REG_W32(offset, val) \
api->halmac_reg_write_32(adapter, offset, val)
#define HALMAC_REG_SDIO_RN(offset, size, data) \
api->halmac_reg_sdio_cmd53_read_n(adapter, offset, size, data)
#define HALMAC_REG_W8_CLR(offset, mask) \
do { \
u32 __offset = (u32)offset; \
HALMAC_REG_W8(__offset, HALMAC_REG_R8(__offset) & ~(mask)); \
} while (0)
#define HALMAC_REG_W16_CLR(offset, mask) \
do { \
u32 __offset = (u32)offset; \
HALMAC_REG_W16(__offset, HALMAC_REG_R16(__offset) & ~(mask)); \
} while (0)
#define HALMAC_REG_W32_CLR(offset, mask) \
do { \
u32 __offset = (u32)offset; \
HALMAC_REG_W32(__offset, HALMAC_REG_R32(__offset) & ~(mask)); \
} while (0)
#define HALMAC_REG_W8_SET(offset, mask) \
do { \
u32 __offset = (u32)offset; \
HALMAC_REG_W8(__offset, HALMAC_REG_R8(__offset) | mask); \
} while (0)
#define HALMAC_REG_W16_SET(offset, mask) \
do { \
u32 __offset = (u32)offset; \
HALMAC_REG_W16(__offset, HALMAC_REG_R16(__offset) | mask); \
} while (0)
#define HALMAC_REG_W32_SET(offset, mask) \
do { \
u32 __offset = (u32)offset; \
HALMAC_REG_W32(__offset, HALMAC_REG_R32(__offset) | mask); \
} while (0)
/* Swap Little-endian <-> Big-endia*/
#define SWAP32(x) \
((u32)((((u32)(x) & (u32)0x000000ff) << 24) | \
(((u32)(x) & (u32)0x0000ff00) << 8) | \
(((u32)(x) & (u32)0x00ff0000) >> 8) | \
(((u32)(x) & (u32)0xff000000) >> 24)))
#define SWAP16(x) \
((u16)((((u16)(x) & (u16)0x00ff) << 8) | \
(((u16)(x) & (u16)0xff00) >> 8)))
/*1->Little endian 0->Big endian*/
#if HALMAC_SYSTEM_ENDIAN
#ifndef rtk_le16_to_cpu
#define rtk_cpu_to_le32(x) ((u32)(x))
#define rtk_le32_to_cpu(x) ((u32)(x))
#define rtk_cpu_to_le16(x) ((u16)(x))
#define rtk_le16_to_cpu(x) ((u16)(x))
#define rtk_cpu_to_be32(x) SWAP32((x))
#define rtk_be32_to_cpu(x) SWAP32((x))
#define rtk_cpu_to_be16(x) SWAP16((x))
#define rtk_be16_to_cpu(x) SWAP16((x))
#endif
#else
#ifndef rtk_le16_to_cpu
#define rtk_cpu_to_le32(x) SWAP32((x))
#define rtk_le32_to_cpu(x) SWAP32((x))
#define rtk_cpu_to_le16(x) SWAP16((x))
#define rtk_le16_to_cpu(x) SWAP16((x))
#define rtk_cpu_to_be32(x) ((u32)(x))
#define rtk_be32_to_cpu(x) ((u32)(x))
#define rtk_cpu_to_be16(x) ((u16)(x))
#define rtk_be16_to_cpu(x) ((u16)(x))
#endif
#endif
#define HALMAC_ALIGN(x, a) HALMAC_ALIGN_MASK(x, (a) - 1)
#define HALMAC_ALIGN_MASK(x, mask) (((x) + (mask)) & ~(mask))
/* #if !HALMAC_PLATFORM_WINDOWS */
#if !((HALMAC_PLATFORM_WINDOWS == 1) && (HALMAC_PLATFORM_TESTPROGRAM == 0))
/* Byte Swapping routine */
#ifndef EF1BYTE
#define EF1BYTE (u8)
#endif
#ifndef EF2BYTE
#define EF2BYTE rtk_le16_to_cpu
#endif
#ifndef EF4BYTE
#define EF4BYTE rtk_le32_to_cpu
#endif
/* Example:
* BIT_LEN_MASK_32(0) => 0x00000000
* BIT_LEN_MASK_32(1) => 0x00000001
* BIT_LEN_MASK_32(2) => 0x00000003
* BIT_LEN_MASK_32(32) => 0xFFFFFFFF
*/
#ifndef BIT_LEN_MASK_32
#define BIT_LEN_MASK_32(__bitlen) (0xFFFFFFFF >> (32 - (__bitlen)))
#endif
/* Example:
* BIT_OFFSET_LEN_MASK_32(0, 2) => 0x00000003
* BIT_OFFSET_LEN_MASK_32(16, 2) => 0x00030000
*/
#ifndef BIT_OFFSET_LEN_MASK_32
#define BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen) \
(BIT_LEN_MASK_32(__bitlen) << (__bitoffset))
#endif
/* Return 4-byte value in host byte ordering from
* 4-byte pointer in litten-endian system
*/
#ifndef LE_P4BYTE_TO_HOST_4BYTE
#define LE_P4BYTE_TO_HOST_4BYTE(__start) (EF4BYTE(*((u32 *)(__start))))
#endif
/* Translate subfield (continuous bits in little-endian) of
* 4-byte value in litten byte to 4-byte value in host byte ordering
*/
#ifndef LE_BITS_TO_4BYTE
#define LE_BITS_TO_4BYTE(__start, __bitoffset, __bitlen) \
((LE_P4BYTE_TO_HOST_4BYTE(__start) >> (__bitoffset)) & \
BIT_LEN_MASK_32(__bitlen))
#endif
/* Mask subfield (continuous bits in little-endian) of 4-byte
* value in litten byte oredering and return the result in 4-byte
* value in host byte ordering
*/
#ifndef LE_BITS_CLEARED_TO_4BYTE
#define LE_BITS_CLEARED_TO_4BYTE(__start, __bitoffset, __bitlen) \
(LE_P4BYTE_TO_HOST_4BYTE(__start) & \
(~BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen)))
#endif
/* Set subfield of little-endian 4-byte value to specified value */
#ifndef SET_BITS_TO_LE_4BYTE
#define SET_BITS_TO_LE_4BYTE(__start, __bitoffset, __bitlen, __value) \
do { \
*((u32 *)(__start)) = \
EF4BYTE( \
LE_BITS_CLEARED_TO_4BYTE(__start, __bitoffset, __bitlen) | \
((((u32)__value) & BIT_LEN_MASK_32(__bitlen)) << (__bitoffset))\
); \
} while (0)
#endif
#ifndef HALMAC_BIT_OFFSET_VAL_MASK_32
#define HALMAC_BIT_OFFSET_VAL_MASK_32(__bitval, __bitoffset) \
(__bitval << (__bitoffset))
#endif
#ifndef SET_MEM_OP
#define SET_MEM_OP(dw, value32, mask, shift) \
(((dw) & ~((mask) << (shift))) | (((value32) & (mask)) << (shift)))
#endif
#ifndef HALMAC_SET_DESC_FIELD_CLR
#define HALMAC_SET_DESC_FIELD_CLR(dw, value32, mask, shift) \
(dw = (rtk_cpu_to_le32( \
SET_MEM_OP(rtk_cpu_to_le32(dw), value32, mask, shift))))
#endif
#ifndef HALMAC_SET_DESC_FIELD_NO_CLR
#define HALMAC_SET_DESC_FIELD_NO_CLR(dw, value32, mask, shift) \
(dw |= (rtk_cpu_to_le32(((value32) & (mask)) << (shift))))
#endif
#ifndef HALMAC_GET_DESC_FIELD
#define HALMAC_GET_DESC_FIELD(dw, mask, shift) \
((rtk_le32_to_cpu(dw) >> (shift)) & (mask))
#endif
#define HALMAC_SET_BD_FIELD_CLR HALMAC_SET_DESC_FIELD_CLR
#define HALMAC_SET_BD_FIELD_NO_CLR HALMAC_SET_DESC_FIELD_NO_CLR
#define HALMAC_GET_BD_FIELD HALMAC_GET_DESC_FIELD
#ifndef GET_H2C_FIELD
#define GET_H2C_FIELD LE_BITS_TO_4BYTE
#endif
#ifndef SET_H2C_FIELD_CLR
#define SET_H2C_FIELD_CLR SET_BITS_TO_LE_4BYTE
#endif
#ifndef SET_H2C_FIELD_NO_CLR
#define SET_H2C_FIELD_NO_CLR SET_BITS_TO_LE_4BYTE
#endif
#ifndef GET_C2H_FIELD
#define GET_C2H_FIELD LE_BITS_TO_4BYTE
#endif
#ifndef SET_C2H_FIELD_CLR
#define SET_C2H_FIELD_CLR SET_BITS_TO_LE_4BYTE
#endif
#ifndef SET_C2H_FIELD_NO_CLR
#define SET_C2H_FIELD_NO_CLR SET_BITS_TO_LE_4BYTE
#endif
#endif /* #if !HALMAC_PLATFORM_WINDOWS */
#ifndef BIT
#define BIT(x) (1 << (x))
#endif
#ifndef ARRAY_SIZE
#define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
#endif
/* HALMAC API return status*/
enum halmac_ret_status {
HALMAC_RET_SUCCESS = 0x00,
HALMAC_RET_NOT_SUPPORT = 0x01,
HALMAC_RET_SUCCESS_ENQUEUE = 0x01, /*Don't use this return code!!*/
HALMAC_RET_PLATFORM_API_NULL = 0x02,
HALMAC_RET_EFUSE_SIZE_INCORRECT = 0x03,
HALMAC_RET_MALLOC_FAIL = 0x04,
HALMAC_RET_ADAPTER_INVALID = 0x05,
HALMAC_RET_ITF_INCORRECT = 0x06,
HALMAC_RET_DLFW_FAIL = 0x07,
HALMAC_RET_PORT_NOT_SUPPORT = 0x08,
HALMAC_RET_TXAGG_OVERFLOW = 0x09,
HALMAC_RET_INIT_LLT_FAIL = 0x0A,
HALMAC_RET_POWER_STATE_INVALID = 0x0B,
HALMAC_RET_H2C_ACK_NOT_RECEIVED = 0x0C,
HALMAC_RET_DL_RSVD_PAGE_FAIL = 0x0D,
HALMAC_RET_EFUSE_R_FAIL = 0x0E,
HALMAC_RET_EFUSE_W_FAIL = 0x0F,
HALMAC_RET_H2C_SW_RES_FAIL = 0x10,
HALMAC_RET_SEND_H2C_FAIL = 0x11,
HALMAC_RET_PARA_NOT_SUPPORT = 0x12,
HALMAC_RET_PLATFORM_API_INCORRECT = 0x13,
HALMAC_RET_ENDIAN_ERR = 0x14,
HALMAC_RET_FW_SIZE_ERR = 0x15,
HALMAC_RET_TRX_MODE_NOT_SUPPORT = 0x16,
HALMAC_RET_FAIL = 0x17,
HALMAC_RET_CHANGE_PS_FAIL = 0x18,
HALMAC_RET_CFG_PARA_FAIL = 0x19,
HALMAC_RET_UPDATE_PROBE_FAIL = 0x1A,
HALMAC_RET_SCAN_FAIL = 0x1B,
HALMAC_RET_STOP_SCAN_FAIL = 0x1C,
HALMAC_RET_BCN_PARSER_CMD_FAIL = 0x1D,
HALMAC_RET_POWER_ON_FAIL = 0x1E,
HALMAC_RET_POWER_OFF_FAIL = 0x1F,
HALMAC_RET_RX_AGG_MODE_FAIL = 0x20,
HALMAC_RET_DATA_BUF_NULL = 0x21,
HALMAC_RET_DATA_SIZE_INCORRECT = 0x22,
HALMAC_RET_QSEL_INCORRECT = 0x23,
HALMAC_RET_DMA_MAP_INCORRECT = 0x24,
HALMAC_RET_SEND_ORIGINAL_H2C_FAIL = 0x25,
HALMAC_RET_DDMA_FAIL = 0x26,
HALMAC_RET_FW_CHECKSUM_FAIL = 0x27,
HALMAC_RET_PWRSEQ_POLLING_FAIL = 0x28,
HALMAC_RET_PWRSEQ_CMD_INCORRECT = 0x29,
HALMAC_RET_WRITE_DATA_FAIL = 0x2A,
HALMAC_RET_DUMP_FIFOSIZE_INCORRECT = 0x2B,
HALMAC_RET_NULL_POINTER = 0x2C,
HALMAC_RET_PROBE_NOT_FOUND = 0x2D,
HALMAC_RET_FW_NO_MEMORY = 0x2E,
HALMAC_RET_H2C_STATUS_ERR = 0x2F,
HALMAC_RET_GET_H2C_SPACE_ERR = 0x30,
HALMAC_RET_H2C_SPACE_FULL = 0x31,
HALMAC_RET_DATAPACK_NO_FOUND = 0x32,
HALMAC_RET_CANNOT_FIND_H2C_RESOURCE = 0x33,
HALMAC_RET_TX_DMA_ERR = 0x34,
HALMAC_RET_RX_DMA_ERR = 0x35,
HALMAC_RET_CHIP_NOT_SUPPORT = 0x36,
HALMAC_RET_FREE_SPACE_NOT_ENOUGH = 0x37,
HALMAC_RET_CH_SW_SEQ_WRONG = 0x38,
HALMAC_RET_CH_SW_NO_BUF = 0x39,
HALMAC_RET_SW_CASE_NOT_SUPPORT = 0x3A,
HALMAC_RET_CONVERT_SDIO_OFFSET_FAIL = 0x3B,
HALMAC_RET_INVALID_SOUNDING_SETTING = 0x3C,
HALMAC_RET_GEN_INFO_NOT_SENT = 0x3D,
HALMAC_RET_STATE_INCORRECT = 0x3E,
HALMAC_RET_H2C_BUSY = 0x3F,
HALMAC_RET_INVALID_FEATURE_ID = 0x40,
HALMAC_RET_BUFFER_TOO_SMALL = 0x41,
HALMAC_RET_ZERO_LEN_RSVD_PACKET = 0x42,
HALMAC_RET_BUSY_STATE = 0x43,
HALMAC_RET_ERROR_STATE = 0x44,
HALMAC_RET_API_INVALID = 0x45,
HALMAC_RET_POLLING_BCN_VALID_FAIL = 0x46,
HALMAC_RET_SDIO_LEAVE_SUSPEND_FAIL = 0x47,
HALMAC_RET_EEPROM_PARSING_FAIL = 0x48,
HALMAC_RET_EFUSE_NOT_ENOUGH = 0x49,
HALMAC_RET_WRONG_ARGUMENT = 0x4A,
HALMAC_RET_C2H_NOT_HANDLED = 0x4C,
HALMAC_RET_PARA_SENDING = 0x4D,
HALMAC_RET_CFG_DLFW_SIZE_FAIL = 0x4E,
HALMAC_RET_CFG_TXFIFO_PAGE_FAIL = 0x4F,
HALMAC_RET_SWITCH_CASE_ERROR = 0x50,
HALMAC_RET_EFUSE_BANK_INCORRECT = 0x51,
HALMAC_RET_SWITCH_EFUSE_BANK_FAIL = 0x52,
HALMAC_RET_USB_MODE_UNCHANGE = 0x53,
HALMAC_RET_NO_DLFW = 0x54,
HALMAC_RET_USB2_3_SWITCH_UNSUPPORT = 0x55,
HALMAC_RET_BIP_NO_SUPPORT = 0x56,
HALMAC_RET_ENTRY_INDEX_ERROR = 0x57,
HALMAC_RET_ENTRY_KEY_ID_ERROR = 0x58,
HALMAC_RET_DRV_DL_ERR = 0x59,
HALMAC_RET_OQT_NOT_ENOUGH = 0x5A,
HALMAC_RET_PWR_UNCHANGE = 0x5B,
HALMAC_RET_WRONG_INTF = 0x5C,
HALMAC_RET_POLLING_HIOE_REQ_FAIL = 0x5E,
HALMAC_RET_HIOE_CHKSUM_FAIL = 0x5F,
HALMAC_RET_HIOE_ERR = 0x60,
HALMAC_RET_FW_NO_SUPPORT = 0x60,
HALMAC_RET_TXFIFO_NO_EMPTY = 0x61,
HALMAC_RET_SDIO_CLOCK_ERR = 0x62,
HALMAC_RET_GET_PINMUX_ERR = 0x63,
HALMAC_RET_PINMUX_USED = 0x64,
HALMAC_RET_WRONG_GPIO = 0x65,
HALMAC_RET_LTECOEX_READY_FAIL = 0x66,
HALMAC_RET_IDMEM_CHKSUM_FAIL = 0x67,
HALMAC_RET_ILLEGAL_KEY_FAIL = 0x68,
HALMAC_RET_FW_READY_CHK_FAIL = 0x69,
HALMAC_RET_RSVD_PG_OVERFLOW_FAIL = 0x70,
HALMAC_RET_THRESHOLD_FAIL = 0x71,
HALMAC_RET_SDIO_MIX_MODE = 0x72,
HALMAC_RET_TXDESC_SET_FAIL = 0x73,
HALMAC_RET_WLHDR_FAIL = 0x74,
HALMAC_RET_WLAN_MODE_FAIL = 0x75,
HALMAC_RET_SDIO_SEQ_FAIL = 0x72,
HALMAC_RET_INIT_XTAL_AAC_FAIL = 0x76,
HALMAC_RET_FWFF_NO_EMPTY = 0x78,
};
enum halmac_chip_id {
HALMAC_CHIP_ID_8822B = 0,
HALMAC_CHIP_ID_8821C = 1,
HALMAC_CHIP_ID_8814B = 2,
HALMAC_CHIP_ID_8197F = 3,
HALMAC_CHIP_ID_8822C = 4,
HALMAC_CHIP_ID_8812F = 5,
HALMAC_CHIP_ID_UNDEFINE = 0x7F,
};
enum halmac_chip_ver {
HALMAC_CHIP_VER_A_CUT = 0x00,
HALMAC_CHIP_VER_B_CUT = 0x01,
HALMAC_CHIP_VER_C_CUT = 0x02,
HALMAC_CHIP_VER_D_CUT = 0x03,
HALMAC_CHIP_VER_E_CUT = 0x04,
HALMAC_CHIP_VER_F_CUT = 0x05,
HALMAC_CHIP_VER_TEST = 0xFF,
HALMAC_CHIP_VER_UNDEFINE = 0x7FFF,
};
enum halmac_network_type_select {
HALMAC_NETWORK_NO_LINK = 0,
HALMAC_NETWORK_ADHOC = 1,
HALMAC_NETWORK_INFRASTRUCTURE = 2,
HALMAC_NETWORK_AP = 3,
HALMAC_NETWORK_UNDEFINE = 0x7F,
};
enum halmac_transfer_mode_select {
HALMAC_TRNSFER_NORMAL = 0x0,
HALMAC_TRNSFER_LOOPBACK_DIRECT = 0xB,
HALMAC_TRNSFER_LOOPBACK_DELAY = 0x3,
HALMAC_TRNSFER_UNDEFINE = 0x7F,
};
enum halmac_dma_mapping {
HALMAC_DMA_MAPPING_EXTRA = 0,
HALMAC_DMA_MAPPING_LOW = 1,
HALMAC_DMA_MAPPING_NORMAL = 2,
HALMAC_DMA_MAPPING_HIGH = 3,
HALMAC_DMA_MAPPING_UNDEFINE = 0x7F,
};
enum halmac_io_size {
HALMAC_IO_BYTE = 0x0,
HALMAC_IO_WORD = 0x1,
HALMAC_IO_DWORD = 0x2,
HALMAC_IO_UNDEFINE = 0x7F,
};
#define HALMAC_MAP2_HQ HALMAC_DMA_MAPPING_HIGH
#define HALMAC_MAP2_NQ HALMAC_DMA_MAPPING_NORMAL
#define HALMAC_MAP2_LQ HALMAC_DMA_MAPPING_LOW
#define HALMAC_MAP2_EXQ HALMAC_DMA_MAPPING_EXTRA
#define HALMAC_MAP2_UNDEF HALMAC_DMA_MAPPING_UNDEFINE
enum halmac_txdesc_queue_tid {
HALMAC_TXDESC_QSEL_TID0 = 0,
HALMAC_TXDESC_QSEL_TID1 = 1,
HALMAC_TXDESC_QSEL_TID2 = 2,
HALMAC_TXDESC_QSEL_TID3 = 3,
HALMAC_TXDESC_QSEL_TID4 = 4,
HALMAC_TXDESC_QSEL_TID5 = 5,
HALMAC_TXDESC_QSEL_TID6 = 6,
HALMAC_TXDESC_QSEL_TID7 = 7,
HALMAC_TXDESC_QSEL_TID8 = 8,
HALMAC_TXDESC_QSEL_TID9 = 9,
HALMAC_TXDESC_QSEL_TIDA = 10,
HALMAC_TXDESC_QSEL_TIDB = 11,
HALMAC_TXDESC_QSEL_TIDC = 12,
HALMAC_TXDESC_QSEL_TIDD = 13,
HALMAC_TXDESC_QSEL_TIDE = 14,
HALMAC_TXDESC_QSEL_TIDF = 15,
HALMAC_TXDESC_QSEL_BEACON = 0x10,
HALMAC_TXDESC_QSEL_HIGH = 0x11,
HALMAC_TXDESC_QSEL_MGT = 0x12,
HALMAC_TXDESC_QSEL_H2C_CMD = 0x13,
HALMAC_TXDESC_QSEL_FWCMD = 0x14,
HALMAC_TXDESC_QSEL_UNDEFINE = 0x7F,
};
enum halmac_pq_map_id {
HALMAC_PQ_MAP_VO = 0x0,
HALMAC_PQ_MAP_VI = 0x1,
HALMAC_PQ_MAP_BE = 0x2,
HALMAC_PQ_MAP_BK = 0x3,
HALMAC_PQ_MAP_MG = 0x4,
HALMAC_PQ_MAP_HI = 0x5,
HALMAC_PQ_MAP_NUM = 0x6,
HALMAC_PQ_MAP_UNDEF = 0x7F,
};
enum halmac_qsel {
HALMAC_QSEL_VO = HALMAC_TXDESC_QSEL_TID6,
HALMAC_QSEL_VI = HALMAC_TXDESC_QSEL_TID4,
HALMAC_QSEL_BE = HALMAC_TXDESC_QSEL_TID0,
HALMAC_QSEL_BK = HALMAC_TXDESC_QSEL_TID1,
HALMAC_QSEL_VO_V2 = HALMAC_TXDESC_QSEL_TID7,
HALMAC_QSEL_VI_V2 = HALMAC_TXDESC_QSEL_TID5,
HALMAC_QSEL_BE_V2 = HALMAC_TXDESC_QSEL_TID3,
HALMAC_QSEL_BK_V2 = HALMAC_TXDESC_QSEL_TID2,
HALMAC_QSEL_TID8 = HALMAC_TXDESC_QSEL_TID8,
HALMAC_QSEL_TID9 = HALMAC_TXDESC_QSEL_TID9,
HALMAC_QSEL_TIDA = HALMAC_TXDESC_QSEL_TIDA,
HALMAC_QSEL_TIDB = HALMAC_TXDESC_QSEL_TIDB,
HALMAC_QSEL_TIDC = HALMAC_TXDESC_QSEL_TIDC,
HALMAC_QSEL_TIDD = HALMAC_TXDESC_QSEL_TIDD,
HALMAC_QSEL_TIDE = HALMAC_TXDESC_QSEL_TIDE,
HALMAC_QSEL_TIDF = HALMAC_TXDESC_QSEL_TIDF,
HALMAC_QSEL_BCN = HALMAC_TXDESC_QSEL_BEACON,
HALMAC_QSEL_HIGH = HALMAC_TXDESC_QSEL_HIGH,
HALMAC_QSEL_MGNT = HALMAC_TXDESC_QSEL_MGT,
HALMAC_QSEL_CMD = HALMAC_TXDESC_QSEL_H2C_CMD,
HALMAC_QSEL_FWCMD = HALMAC_TXDESC_QSEL_FWCMD,
HALMAC_QSEL_UNDEFINE = 0x7F,
};
enum halmac_acq_id {
HALMAC_ACQ_ID_VO = 0,
HALMAC_ACQ_ID_VI = 1,
HALMAC_ACQ_ID_BE = 2,
HALMAC_ACQ_ID_BK = 3,
HALMAC_ACQ_ID_MAX = 0x7F,
};
enum halmac_txdesc_dma_ch {
HALMAC_TXDESC_DMA_CH0 = 0,
HALMAC_TXDESC_DMA_CH1 = 1,
HALMAC_TXDESC_DMA_CH2 = 2,
HALMAC_TXDESC_DMA_CH3 = 3,
HALMAC_TXDESC_DMA_CH4 = 4,
HALMAC_TXDESC_DMA_CH5 = 5,
HALMAC_TXDESC_DMA_CH6 = 6,
HALMAC_TXDESC_DMA_CH7 = 7,
HALMAC_TXDESC_DMA_CH8 = 8,
HALMAC_TXDESC_DMA_CH9 = 9,
HALMAC_TXDESC_DMA_CH10 = 10,
HALMAC_TXDESC_DMA_CH11 = 11,
HALMAC_TXDESC_DMA_CH12 = 12,
HALMAC_TXDESC_DMA_CH13 = 13,
HALMAC_TXDESC_DMA_CH14 = 14,
HALMAC_TXDESC_DMA_CH15 = 15,
HALMAC_TXDESC_DMA_CH16 = 16,
HALMAC_TXDESC_DMA_CH17 = 17,
HALMAC_TXDESC_DMA_CH18 = 18,
HALMAC_TXDESC_DMA_CH19 = 19,
HALMAC_TXDESC_DMA_CH20 = 20,
HALMAC_TXDESC_DMA_CHMAX,
HALMAC_TXDESC_DMA_CHUNDEFINE = 0x7F,
};
enum halmac_dma_ch {
HALMAC_DMA_CH_0 = HALMAC_TXDESC_DMA_CH0,
HALMAC_DMA_CH_1 = HALMAC_TXDESC_DMA_CH1,
HALMAC_DMA_CH_2 = HALMAC_TXDESC_DMA_CH2,
HALMAC_DMA_CH_3 = HALMAC_TXDESC_DMA_CH3,
HALMAC_DMA_CH_4 = HALMAC_TXDESC_DMA_CH4,
HALMAC_DMA_CH_5 = HALMAC_TXDESC_DMA_CH5,
HALMAC_DMA_CH_6 = HALMAC_TXDESC_DMA_CH6,
HALMAC_DMA_CH_7 = HALMAC_TXDESC_DMA_CH7,
HALMAC_DMA_CH_8 = HALMAC_TXDESC_DMA_CH8,
HALMAC_DMA_CH_9 = HALMAC_TXDESC_DMA_CH9,
HALMAC_DMA_CH_10 = HALMAC_TXDESC_DMA_CH10,
HALMAC_DMA_CH_11 = HALMAC_TXDESC_DMA_CH11,
HALMAC_DMA_CH_S0 = HALMAC_TXDESC_DMA_CH12,
HALMAC_DMA_CH_S1 = HALMAC_TXDESC_DMA_CH13,
HALMAC_DMA_CH_MGQ = HALMAC_TXDESC_DMA_CH14,
HALMAC_DMA_CH_HIGH = HALMAC_TXDESC_DMA_CH15,
HALMAC_DMA_CH_FWCMD = HALMAC_TXDESC_DMA_CH16,
HALMAC_DMA_CH_MGQ_BAND1 = HALMAC_TXDESC_DMA_CH17,
HALMAC_DMA_CH_HIGH_BAND1 = HALMAC_TXDESC_DMA_CH18,
HALMAC_DMA_CH_BCN = HALMAC_TXDESC_DMA_CH19,
HALMAC_DMA_CH_H2C = HALMAC_TXDESC_DMA_CH20,
HALMAC_DMA_CH_MAX = HALMAC_TXDESC_DMA_CHMAX,
HALMAC_DMA_CH_UNDEFINE = 0x7F,
};
enum halmac_interface {
HALMAC_INTERFACE_PCIE = 0x0,
HALMAC_INTERFACE_USB = 0x1,
HALMAC_INTERFACE_SDIO = 0x2,
HALMAC_INTERFACE_AXI = 0x3,
HALMAC_INTERFACE_UNDEFINE = 0x7F,
};
enum halmac_rx_agg_mode {
HALMAC_RX_AGG_MODE_NONE = 0x0,
HALMAC_RX_AGG_MODE_DMA = 0x1,
HALMAC_RX_AGG_MODE_USB = 0x2,
HALMAC_RX_AGG_MODE_UNDEFINE = 0x7F,
};
struct halmac_rxagg_th {
u8 drv_define;
u8 timeout;
u8 size;
u8 size_limit_en;
};
struct halmac_rxagg_cfg {
enum halmac_rx_agg_mode mode;
struct halmac_rxagg_th threshold;
};
struct halmac_api_registry {
u8 rx_exp_en:1;
u8 la_mode_en:1;
u8 cfg_drv_rsvd_pg_en:1;
u8 sdio_cmd53_4byte_en:1;
u8 rsvd:4;
};
enum halmac_trx_mode {
HALMAC_TRX_MODE_NORMAL = 0x0,
HALMAC_TRX_MODE_TRXSHARE = 0x1,
HALMAC_TRX_MODE_WMM = 0x2,
HALMAC_TRX_MODE_P2P = 0x3,
HALMAC_TRX_MODE_LOOPBACK = 0x4,
HALMAC_TRX_MODE_DELAY_LOOPBACK = 0x5,
HALMAC_TRX_MODE_MAX = 0x6,
HALMAC_TRX_MODE_WMM_LINUX = 0x7E,
HALMAC_TRX_MODE_UNDEFINE = 0x7F,
};
enum halmac_wireless_mode {
HALMAC_WIRELESS_MODE_B = 0x0,
HALMAC_WIRELESS_MODE_G = 0x1,
HALMAC_WIRELESS_MODE_N = 0x2,
HALMAC_WIRELESS_MODE_AC = 0x3,
HALMAC_WIRELESS_MODE_UNDEFINE = 0x7F,
};
enum halmac_bw {
HALMAC_BW_20 = 0x00,
HALMAC_BW_40 = 0x01,
HALMAC_BW_80 = 0x02,
HALMAC_BW_160 = 0x03,
HALMAC_BW_5 = 0x04,
HALMAC_BW_10 = 0x05,
HALMAC_BW_MAX = 0x06,
HALMAC_BW_UNDEFINE = 0x7F,
};
enum halmac_efuse_read_cfg {
HALMAC_EFUSE_R_AUTO = 0x00,
HALMAC_EFUSE_R_DRV = 0x01,
HALMAC_EFUSE_R_FW = 0x02,
HALMAC_EFUSE_R_UNDEFINE = 0x7F,
};
enum halmac_dlfw_mem {
HALMAC_DLFW_MEM_EMEM = 0x00,
HALMAC_DLFW_MEM_EMEM_RSVD_PG = 0x01,
HALMAC_DLFW_MEM_UNDEFINE = 0x7F,
};
struct halmac_tx_desc {
u32 dword0;
u32 dword1;
u32 dword2;
u32 dword3;
u32 dword4;
u32 dword5;
u32 dword6;
u32 dword7;
u32 dword8;
u32 dword9;
u32 dword10;
u32 dword11;
};
struct halmac_rx_desc {
u32 dword0;
u32 dword1;
u32 dword2;
u32 dword3;
u32 dword4;
u32 dword5;
};
struct halmac_bcn_ie_info {
u8 func_en;
u8 size_th;
u8 timeout;
u8 ie_bmp[HALMAC_BCN_IE_BMP_SIZE];
};
enum halmac_parameter_cmd {
/* HALMAC_PARAMETER_CMD_LLT = 0x1, */
/* HALMAC_PARAMETER_CMD_R_EFUSE = 0x2, */
/* HALMAC_PARAMETER_CMD_EFUSE_PATCH = 0x3, */
HALMAC_PARAMETER_CMD_MAC_W8 = 0x4,
HALMAC_PARAMETER_CMD_MAC_W16 = 0x5,
HALMAC_PARAMETER_CMD_MAC_W32 = 0x6,
HALMAC_PARAMETER_CMD_RF_W = 0x7,
HALMAC_PARAMETER_CMD_BB_W8 = 0x8,
HALMAC_PARAMETER_CMD_BB_W16 = 0x9,
HALMAC_PARAMETER_CMD_BB_W32 = 0XA,
HALMAC_PARAMETER_CMD_DELAY_US = 0X10,
HALMAC_PARAMETER_CMD_DELAY_MS = 0X11,
HALMAC_PARAMETER_CMD_END = 0XFF,
};
union halmac_parameter_content {
struct _MAC_REG_W {
u32 value;
u32 msk;
u16 offset;
u8 msk_en;
} MAC_REG_W;
struct _BB_REG_W {
u32 value;
u32 msk;
u16 offset;
u8 msk_en;
} BB_REG_W;
struct _RF_REG_W {
u32 value;
u32 msk;
u8 offset;
u8 msk_en;
u8 rf_path;
} RF_REG_W;
struct _DELAY_TIME {
u32 rsvd1;
u32 rsvd2;
u16 delay_time;
u8 rsvd3;
} DELAY_TIME;
};
struct halmac_phy_parameter_info {
enum halmac_parameter_cmd cmd_id;
union halmac_parameter_content content;
};
struct halmac_pg_efuse_info {
u8 *efuse_map;
u32 efuse_map_size;
u8 *efuse_mask;
u32 efuse_mask_size;
};
struct halmac_cfg_param_info {
u32 buf_size;
u8 *buf;
u8 *buf_wptr;
u32 num;
u32 avl_buf_size;
u32 offset_accum;
u32 value_accum;
enum halmac_data_type data_type;
u8 full_fifo_mode;
};
struct halmac_hw_cfg_info {
u32 efuse_size;
u32 eeprom_size;
u32 bt_efuse_size;
u32 tx_fifo_size;
u32 rx_fifo_size;
u32 rx_desc_fifo_size;
u32 page_size;
u16 tx_align_size;
u8 txdesc_size;
u8 rxdesc_size;
u8 cam_entry_num;
u8 chk_security_keyid;
u8 txdesc_ie_max_num;
u8 txdesc_body_size;
u8 ac_oqt_size;
u8 non_ac_oqt_size;
u8 acq_num;
u8 trx_mode;
u8 usb_txagg_num;
u32 prtct_efuse_size;
};
struct halmac_sdio_free_space {
u16 hiq_pg_num;
u16 miq_pg_num;
u16 lowq_pg_num;
u16 pubq_pg_num;
u16 exq_pg_num;
u8 ac_oqt_num;
u8 non_ac_oqt_num;
u8 ac_empty;
u8 *macid_map;
u32 macid_map_size;
};
enum hal_fifo_sel {
HAL_FIFO_SEL_TX,
HAL_FIFO_SEL_RX,
HAL_FIFO_SEL_RSVD_PAGE,
HAL_FIFO_SEL_REPORT,
HAL_FIFO_SEL_LLT,
HAL_FIFO_SEL_RXBUF_FW,
HAL_FIFO_SEL_RXBUF_PHY,
HAL_FIFO_SEL_RXDESC,
HAL_BUF_SECURITY_CAM,
HAL_BUF_WOW_CAM,
HAL_BUF_RX_FILTER_CAM,
HAL_BUF_BA_CAM,
HAL_BUF_MBSSID_CAM
};
enum halmac_drv_info {
/* No information is appended in rx_pkt */
HALMAC_DRV_INFO_NONE,
/* PHY status is appended after rx_desc */
HALMAC_DRV_INFO_PHY_STATUS,
/* PHY status and sniffer info are appended after rx_desc */
HALMAC_DRV_INFO_PHY_SNIFFER,
/* PHY status and plcp header are appended after rx_desc */
HALMAC_DRV_INFO_PHY_PLCP,
HALMAC_DRV_INFO_UNDEFINE,
};
enum halmac_pri_ch_idx {
HALMAC_CH_IDX_UNDEFINE = 0,
HALMAC_CH_IDX_1 = 1,
HALMAC_CH_IDX_2 = 2,
HALMAC_CH_IDX_3 = 3,
HALMAC_CH_IDX_4 = 4,
HALMAC_CH_IDX_MAX = 5,
};
struct halmac_ch_info {
enum halmac_cs_action_id action_id;
enum halmac_bw bw;
enum halmac_pri_ch_idx pri_ch_idx;
u8 channel;
u8 timeout;
u8 extra_info;
};
struct halmac_ch_extra_info {
u8 extra_info;
enum halmac_cs_extra_action_id extra_action_id;
u8 extra_info_size;
u8 *extra_info_data;
};
enum halmac_cs_periodic_option {
HALMAC_CS_PERIODIC_NONE,
HALMAC_CS_PERIODIC_NORMAL,
HALMAC_CS_PERIODIC_2_PHASE,
HALMAC_CS_PERIODIC_SEAMLESS,
};
struct halmac_ch_switch_option {
enum halmac_bw dest_bw;
enum halmac_cs_periodic_option periodic_option;
enum halmac_pri_ch_idx dest_pri_ch_idx;
/* u32 tsf_high; */
u32 tsf_low;
u8 switch_en;
u8 dest_ch_en;
u8 absolute_time_en;
u8 dest_ch;
u8 normal_period;
u8 normal_period_sel;
u8 normal_cycle;
u8 phase_2_period;
u8 phase_2_period_sel;
u8 nlo_en;
};
struct halmac_p2pps {
u8 offload_en:1;
u8 role:1;
u8 ctwindow_en:1;
u8 noa_en:1;
u8 noa_sel:1;
u8 all_sta_sleep:1;
u8 discovery:1;
u8 disable_close_rf:1;
u8 p2p_port_id;
u8 p2p_group;
u8 p2p_macid;
u8 ctwindow_length;
u8 rsvd3;
u8 rsvd4;
u8 rsvd5;
u32 noa_duration_para;
u32 noa_interval_para;
u32 noa_start_time_para;
u32 noa_count_para;
};
struct halmac_fw_build_time {
u16 year;
u8 month;
u8 date;
u8 hour;
u8 min;
};
struct halmac_fw_version {
u16 version;
u8 sub_version;
u8 sub_index;
u16 h2c_version;
struct halmac_fw_build_time build_time;
};
enum halmac_rf_type {
HALMAC_RF_1T2R = 0,
HALMAC_RF_2T4R = 1,
HALMAC_RF_2T2R = 2,
HALMAC_RF_2T3R = 3,
HALMAC_RF_1T1R = 4,
HALMAC_RF_2T2R_GREEN = 5,
HALMAC_RF_3T3R = 6,
HALMAC_RF_3T4R = 7,
HALMAC_RF_4T4R = 8,
HALMAC_RF_MAX_TYPE = 0xF,
};
struct halmac_general_info {
u8 rfe_type;
enum halmac_rf_type rf_type;
u8 tx_ant_status;
u8 rx_ant_status;
};
struct halmac_pwr_tracking_para {
u8 enable;
u8 tx_pwr_index;
u8 pwr_tracking_offset_value;
u8 tssi_value;
};
struct halmac_pwr_tracking_option {
u8 type;
u8 bbswing_index;
/* pathA, pathB, pathC, pathD */
struct halmac_pwr_tracking_para pwr_tracking_para[4];
};
struct halmac_fast_edca_cfg {
enum halmac_acq_id acq_id;
u8 queue_to; /* unit : 32us*/
};
struct halmac_txfifo_lifetime_cfg {
u8 enable;
u32 lifetime;
};
enum halmac_data_rate {
HALMAC_CCK1,
HALMAC_CCK2,
HALMAC_CCK5_5,
HALMAC_CCK11,
HALMAC_OFDM6,
HALMAC_OFDM9,
HALMAC_OFDM12,
HALMAC_OFDM18,
HALMAC_OFDM24,
HALMAC_OFDM36,
HALMAC_OFDM48,
HALMAC_OFDM54,
HALMAC_MCS0,
HALMAC_MCS1,
HALMAC_MCS2,
HALMAC_MCS3,
HALMAC_MCS4,
HALMAC_MCS5,
HALMAC_MCS6,
HALMAC_MCS7,
HALMAC_MCS8,
HALMAC_MCS9,
HALMAC_MCS10,
HALMAC_MCS11,
HALMAC_MCS12,
HALMAC_MCS13,
HALMAC_MCS14,
HALMAC_MCS15,
HALMAC_MCS16,
HALMAC_MCS17,
HALMAC_MCS18,
HALMAC_MCS19,
HALMAC_MCS20,
HALMAC_MCS21,
HALMAC_MCS22,
HALMAC_MCS23,
HALMAC_MCS24,
HALMAC_MCS25,
HALMAC_MCS26,
HALMAC_MCS27,
HALMAC_MCS28,
HALMAC_MCS29,
HALMAC_MCS30,
HALMAC_MCS31,
HALMAC_VHT_NSS1_MCS0,
HALMAC_VHT_NSS1_MCS1,
HALMAC_VHT_NSS1_MCS2,
HALMAC_VHT_NSS1_MCS3,
HALMAC_VHT_NSS1_MCS4,
HALMAC_VHT_NSS1_MCS5,
HALMAC_VHT_NSS1_MCS6,
HALMAC_VHT_NSS1_MCS7,
HALMAC_VHT_NSS1_MCS8,
HALMAC_VHT_NSS1_MCS9,
HALMAC_VHT_NSS2_MCS0,
HALMAC_VHT_NSS2_MCS1,
HALMAC_VHT_NSS2_MCS2,
HALMAC_VHT_NSS2_MCS3,
HALMAC_VHT_NSS2_MCS4,
HALMAC_VHT_NSS2_MCS5,
HALMAC_VHT_NSS2_MCS6,
HALMAC_VHT_NSS2_MCS7,
HALMAC_VHT_NSS2_MCS8,
HALMAC_VHT_NSS2_MCS9,
HALMAC_VHT_NSS3_MCS0,
HALMAC_VHT_NSS3_MCS1,
HALMAC_VHT_NSS3_MCS2,
HALMAC_VHT_NSS3_MCS3,
HALMAC_VHT_NSS3_MCS4,
HALMAC_VHT_NSS3_MCS5,
HALMAC_VHT_NSS3_MCS6,
HALMAC_VHT_NSS3_MCS7,
HALMAC_VHT_NSS3_MCS8,
HALMAC_VHT_NSS3_MCS9,
HALMAC_VHT_NSS4_MCS0,
HALMAC_VHT_NSS4_MCS1,
HALMAC_VHT_NSS4_MCS2,
HALMAC_VHT_NSS4_MCS3,
HALMAC_VHT_NSS4_MCS4,
HALMAC_VHT_NSS4_MCS5,
HALMAC_VHT_NSS4_MCS6,
HALMAC_VHT_NSS4_MCS7,
HALMAC_VHT_NSS4_MCS8,
HALMAC_VHT_NSS4_MCS9,
/*FPGA only*/
HALMAC_VHT_NSS5_MCS0,
HALMAC_VHT_NSS6_MCS0,
HALMAC_VHT_NSS7_MCS0,
HALMAC_VHT_NSS8_MCS0
};
enum halmac_rf_path {
HALMAC_RF_PATH_A,
HALMAC_RF_PATH_B,
HALMAC_RF_PATH_C,
HALMAC_RF_PATH_D
};
enum hal_security_type {
HAL_SECURITY_TYPE_NONE = 0,
HAL_SECURITY_TYPE_WEP40 = 1,
HAL_SECURITY_TYPE_WEP104 = 2,
HAL_SECURITY_TYPE_TKIP = 3,
HAL_SECURITY_TYPE_AES128 = 4,
HAL_SECURITY_TYPE_WAPI = 5,
HAL_SECURITY_TYPE_AES256 = 6,
HAL_SECURITY_TYPE_GCMP128 = 7,
HAL_SECURITY_TYPE_GCMP256 = 8,
HAL_SECURITY_TYPE_GCMSMS4 = 9,
HAL_SECURITY_TYPE_BIP = 10,
HAL_SECURITY_TYPE_UNDEFINE = 0x7F,
};
enum hal_intf_phy {
HAL_INTF_PHY_USB2 = 0,
HAL_INTF_PHY_USB3 = 1,
HAL_INTF_PHY_PCIE_GEN1 = 2,
HAL_INTF_PHY_PCIE_GEN2 = 3,
HAL_INTF_PHY_UNDEFINE = 0x7F,
};
struct halmac_cut_amsdu_cfg {
u8 cut_amsdu_en;
u8 chk_len_en;
u8 chk_len_def_val;
u8 chk_len_l_th;
u16 chk_len_h_th;
};
enum halmac_dbg_msg_info {
HALMAC_DBG_ALWAYS,
HALMAC_DBG_ERR,
HALMAC_DBG_WARN,
HALMAC_DBG_TRACE,
};
enum halmac_dbg_msg_type {
HALMAC_MSG_INIT,
HALMAC_MSG_EFUSE,
HALMAC_MSG_FW,
HALMAC_MSG_H2C,
HALMAC_MSG_PWR,
HALMAC_MSG_SND,
HALMAC_MSG_COMMON,
HALMAC_MSG_DBI,
HALMAC_MSG_MDIO,
HALMAC_MSG_USB,
};
enum halmac_feature_id {
HALMAC_FEATURE_CFG_PARA, /* Support */
HALMAC_FEATURE_DUMP_PHYSICAL_EFUSE, /* Support */
HALMAC_FEATURE_DUMP_LOGICAL_EFUSE, /* Support */
HALMAC_FEATURE_UPDATE_PACKET, /* Support */
HALMAC_FEATURE_UPDATE_DATAPACK,
HALMAC_FEATURE_RUN_DATAPACK,
HALMAC_FEATURE_CHANNEL_SWITCH, /* Support */
HALMAC_FEATURE_IQK, /* Support */
HALMAC_FEATURE_POWER_TRACKING, /* Support */
HALMAC_FEATURE_PSD, /* Support */
HALMAC_FEATURE_FW_SNDING, /* Support */
HALMAC_FEATURE_ALL, /* Support, only for reset */
};
enum halmac_drv_rsvd_pg_num {
HALMAC_RSVD_PG_NUM8, /* 1K */
HALMAC_RSVD_PG_NUM16, /* 2K */
HALMAC_RSVD_PG_NUM24, /* 3K */
HALMAC_RSVD_PG_NUM32, /* 4K */
HALMAC_RSVD_PG_NUM64, /* 8K */
HALMAC_RSVD_PG_NUM128, /* 16K */
HALMAC_RSVD_PG_NUM256, /* 32K */
};
enum halmac_pcie_cfg {
HALMAC_PCIE_GEN1,
HALMAC_PCIE_GEN2,
HALMAC_PCIE_CFG_UNDEFINE,
};
enum halmac_portid {
HALMAC_PORTID0 = 0,
HALMAC_PORTID1 = 1,
HALMAC_PORTID2 = 2,
HALMAC_PORTID3 = 3,
HALMAC_PORTID4 = 4,
HALMAC_PORTID_NUM = 5,
};
struct halmac_bcn_ctrl {
u8 dis_rx_bssid_fit;
u8 en_txbcn_rpt;
u8 dis_tsf_udt;
u8 en_bcn;
u8 en_rxbcn_rpt;
u8 en_p2p_ctwin;
u8 en_p2p_bcn_area;
};
/* User only can use Address[6]*/
/* Address[0] is lowest, Address[5] is highest */
union halmac_wlan_addr {
u8 addr[6];
struct {
union {
__le32 low;
u8 low_byte[4];
};
union {
__le16 high;
u8 high_byte[2];
};
} addr_l_h;
};
struct halmac_platform_api {
/* R/W register */
u8 (*SDIO_CMD52_READ)(void *drv_adapter, u32 offset);
u8 (*SDIO_CMD53_READ_8)(void *drv_adapter, u32 offset);
u16 (*SDIO_CMD53_READ_16)(void *drv_adapter, u32 offset);
u32 (*SDIO_CMD53_READ_32)(void *drv_adapter, u32 offset);
u8 (*SDIO_CMD53_READ_N)(void *drv_adapter, u32 offset, u32 size,
u8 *data);
void (*SDIO_CMD52_WRITE)(void *drv_adapter, u32 offset, u8 value);
void (*SDIO_CMD53_WRITE_8)(void *drv_adapter, u32 offset, u8 value);
void (*SDIO_CMD53_WRITE_16)(void *drv_adapter, u32 offset, u16 value);
void (*SDIO_CMD53_WRITE_32)(void *drv_adapter, u32 offset, u32 value);
u8 (*REG_READ_8)(void *drv_adapter, u32 offset);
u16 (*REG_READ_16)(void *drv_adapter, u32 offset);
u32 (*REG_READ_32)(void *drv_adapter, u32 offset);
void (*REG_WRITE_8)(void *drv_adapter, u32 offset, u8 value);
void (*REG_WRITE_16)(void *drv_adapter, u32 offset, u16 value);
void (*REG_WRITE_32)(void *drv_adapter, u32 offset, u32 value);
u8 (*SDIO_CMD52_CIA_READ)(void *drv_adapter, u32 offset);
/* send pBuf to reserved page, the tx_desc is not included in pBuf */
/* driver need to fill tx_desc with qsel = bcn */
u8 (*SEND_RSVD_PAGE)(void *drv_adapter, u8 *buf, u32 size);
/* send pBuf to h2c queue, the tx_desc is not included in pBuf */
/* driver need to fill tx_desc with qsel = h2c */
u8 (*SEND_H2C_PKT)(void *drv_adapter, u8 *buf, u32 size);
u8 (*RTL_FREE)(void *drv_adapter, void *buf, u32 size);
void* (*RTL_MALLOC)(void *drv_adapter, u32 size);
u8 (*RTL_MEMCPY)(void *drv_adapter, void *dest, void *src, u32 size);
u8 (*RTL_MEMSET)(void *drv_adapter, void *addr, u8 value, u32 size);
void (*RTL_DELAY_US)(void *drv_adapter, u32 us);
u8 (*MUTEX_INIT)(void *drv_adapter, HALMAC_MUTEX *mutex);
u8 (*MUTEX_DEINIT)(void *drv_adapter, HALMAC_MUTEX *mutex);
u8 (*MUTEX_LOCK)(void *drv_adapter, HALMAC_MUTEX *mutex);
u8 (*MUTEX_UNLOCK)(void *drv_adapter, HALMAC_MUTEX *mutex);
u8 (*MSG_PRINT)(void *drv_adapter, u32 msg_type, u8 msg_level,
s8 *fmt, ...);
u8 (*BUFF_PRINT)(void *drv_adapter, u32 msg_type, u8 msg_level, s8 *buf,
u32 size);
u8 (*EVENT_INDICATION)(void *drv_adapter,
enum halmac_feature_id feature_id,
enum halmac_cmd_process_status process_status,
u8 *buf, u32 size);
#if HALMAC_PLATFORM_TESTPROGRAM
struct halmisc_platform_api *halmisc_pltfm_api;
#endif
};
enum halmac_snd_role {
HAL_BFER = 0,
HAL_BFEE = 1,
};
enum halmac_csi_seg_len {
HAL_CSI_SEG_4K = 0,
HAL_CSI_SEG_8K = 1,
HAL_CSI_SEG_11K = 2,
};
struct halmac_cfg_mumimo_para {
enum halmac_snd_role role;
u8 sounding_sts[6];
u16 grouping_bitmap;
u8 mu_tx_en;
u32 given_gid_tab[2];
u32 given_user_pos[4];
};
struct halmac_su_bfer_init_para {
u8 userid;
u16 paid;
u16 csi_para;
union halmac_wlan_addr bfer_address;
};
struct halmac_mu_bfee_init_para {
u8 userid;
u16 paid;
u32 user_position_l; /*for gid 0~15*/
u32 user_position_h; /*for gid 16~31*/
u32 user_position_l_1; /*for gid 32~47*/
u32 user_position_h_1; /*for gid 48~63*/
};
struct halmac_mu_bfer_init_para {
u16 paid;
u16 csi_para;
u16 my_aid;
enum halmac_csi_seg_len csi_length_sel;
union halmac_wlan_addr bfer_address;
};
struct halmac_ch_sw_info {
u8 *buf;
u8 *buf_wptr;
u8 extra_info_en;
u32 buf_size;
u32 avl_buf_size;
u32 total_size;
u32 ch_num;
};
struct halmac_event_trigger {
u32 phy_efuse_map : 1;
u32 log_efuse_map : 1;
u32 rsvd1 : 28;
};
struct halmac_h2c_header_info {
u16 sub_cmd_id;
u16 content_size;
u8 ack;
};
struct halmac_ver {
u8 major_ver;
u8 prototype_ver;
u8 minor_ver;
};
enum halmac_api_id {
/*stuff, need to be the 1st*/
HALMAC_API_STUFF = 0x0,
/*stuff, need to be the 1st*/
HALMAC_API_MAC_POWER_SWITCH = 0x1,
HALMAC_API_DOWNLOAD_FIRMWARE = 0x2,
HALMAC_API_CFG_MAC_ADDR = 0x3,
HALMAC_API_CFG_BSSID = 0x4,
HALMAC_API_CFG_MULTICAST_ADDR = 0x5,
HALMAC_API_PRE_INIT_SYSTEM_CFG = 0x6,
HALMAC_API_INIT_SYSTEM_CFG = 0x7,
HALMAC_API_INIT_TRX_CFG = 0x8,
HALMAC_API_CFG_RX_AGGREGATION = 0x9,
HALMAC_API_INIT_PROTOCOL_CFG = 0xA,
HALMAC_API_INIT_EDCA_CFG = 0xB,
HALMAC_API_CFG_OPERATION_MODE = 0xC,
HALMAC_API_CFG_CH_BW = 0xD,
HALMAC_API_CFG_BW = 0xE,
HALMAC_API_INIT_WMAC_CFG = 0xF,
HALMAC_API_INIT_MAC_CFG = 0x10,
HALMAC_API_INIT_SDIO_CFG = 0x11,
HALMAC_API_INIT_USB_CFG = 0x12,
HALMAC_API_INIT_PCIE_CFG = 0x13,
HALMAC_API_INIT_INTERFACE_CFG = 0x14,
HALMAC_API_DEINIT_SDIO_CFG = 0x15,
HALMAC_API_DEINIT_USB_CFG = 0x16,
HALMAC_API_DEINIT_PCIE_CFG = 0x17,
HALMAC_API_DEINIT_INTERFACE_CFG = 0x18,
HALMAC_API_GET_EFUSE_SIZE = 0x19,
HALMAC_API_DUMP_EFUSE_MAP = 0x1A,
HALMAC_API_GET_LOGICAL_EFUSE_SIZE = 0x1D,
HALMAC_API_DUMP_LOGICAL_EFUSE_MAP = 0x1E,
HALMAC_API_WRITE_LOGICAL_EFUSE = 0x1F,
HALMAC_API_READ_LOGICAL_EFUSE = 0x20,
HALMAC_API_PG_EFUSE_BY_MAP = 0x21,
HALMAC_API_GET_C2H_INFO = 0x22,
HALMAC_API_CFG_FWLPS_OPTION = 0x23,
HALMAC_API_CFG_FWIPS_OPTION = 0x24,
HALMAC_API_ENTER_WOWLAN = 0x25,
HALMAC_API_LEAVE_WOWLAN = 0x26,
HALMAC_API_ENTER_PS = 0x27,
HALMAC_API_LEAVE_PS = 0x28,
HALMAC_API_H2C_LB = 0x29,
HALMAC_API_DEBUG = 0x2A,
HALMAC_API_CFG_PARAMETER = 0x2B,
HALMAC_API_UPDATE_PACKET = 0x2C,
HALMAC_API_BCN_IE_FILTER = 0x2D,
HALMAC_API_REG_READ_8 = 0x2E,
HALMAC_API_REG_WRITE_8 = 0x2F,
HALMAC_API_REG_READ_16 = 0x30,
HALMAC_API_REG_WRITE_16 = 0x31,
HALMAC_API_REG_READ_32 = 0x32,
HALMAC_API_REG_WRITE_32 = 0x33,
HALMAC_API_TX_ALLOWED_SDIO = 0x34,
HALMAC_API_SET_BULKOUT_NUM = 0x35,
HALMAC_API_GET_SDIO_TX_ADDR = 0x36,
HALMAC_API_GET_USB_BULKOUT_ID = 0x37,
HALMAC_API_TIMER_2S = 0x38,
HALMAC_API_FILL_TXDESC_CHECKSUM = 0x39,
HALMAC_API_SEND_ORIGINAL_H2C = 0x3A,
HALMAC_API_UPDATE_DATAPACK = 0x3B,
HALMAC_API_RUN_DATAPACK = 0x3C,
HALMAC_API_CFG_DRV_INFO = 0x3D,
HALMAC_API_SEND_BT_COEX = 0x3E,
HALMAC_API_VERIFY_PLATFORM_API = 0x3F,
HALMAC_API_GET_FIFO_SIZE = 0x40,
HALMAC_API_DUMP_FIFO = 0x41,
HALMAC_API_CFG_TXBF = 0x42,
HALMAC_API_CFG_MUMIMO = 0x43,
HALMAC_API_CFG_SOUNDING = 0x44,
HALMAC_API_DEL_SOUNDING = 0x45,
HALMAC_API_SU_BFER_ENTRY_INIT = 0x46,
HALMAC_API_SU_BFEE_ENTRY_INIT = 0x47,
HALMAC_API_MU_BFER_ENTRY_INIT = 0x48,
HALMAC_API_MU_BFEE_ENTRY_INIT = 0x49,
HALMAC_API_SU_BFER_ENTRY_DEL = 0x4A,
HALMAC_API_SU_BFEE_ENTRY_DEL = 0x4B,
HALMAC_API_MU_BFER_ENTRY_DEL = 0x4C,
HALMAC_API_MU_BFEE_ENTRY_DEL = 0x4D,
HALMAC_API_ADD_CH_INFO = 0x4E,
HALMAC_API_ADD_EXTRA_CH_INFO = 0x4F,
HALMAC_API_CTRL_CH_SWITCH = 0x50,
HALMAC_API_CLEAR_CH_INFO = 0x51,
HALMAC_API_SEND_GENERAL_INFO = 0x52,
HALMAC_API_START_IQK = 0x53,
HALMAC_API_CTRL_PWR_TRACKING = 0x54,
HALMAC_API_PSD = 0x55,
HALMAC_API_CFG_TX_AGG_ALIGN = 0x56,
HALMAC_API_QUERY_STATE = 0x57,
HALMAC_API_RESET_FEATURE = 0x58,
HALMAC_API_CHECK_FW_STATUS = 0x59,
HALMAC_API_DUMP_FW_DMEM = 0x5A,
HALMAC_API_CFG_MAX_DL_SIZE = 0x5B,
HALMAC_API_INIT_OBJ = 0x5C,
HALMAC_API_DEINIT_OBJ = 0x5D,
HALMAC_API_CFG_LA_MODE = 0x5E,
HALMAC_API_GET_HW_VALUE = 0x5F,
HALMAC_API_SET_HW_VALUE = 0x60,
HALMAC_API_CFG_DRV_RSVD_PG_NUM = 0x61,
HALMAC_API_WRITE_EFUSE_BT = 0x63,
HALMAC_API_DUMP_EFUSE_MAP_BT = 0x64,
HALMAC_API_DL_DRV_RSVD_PG = 0x65,
HALMAC_API_PCIE_SWITCH = 0x66,
HALMAC_API_PHY_CFG = 0x67,
HALMAC_API_CFG_RX_FIFO_EXPANDING_MODE = 0x68,
HALMAC_API_CFG_CSI_RATE = 0x69,
HALMAC_API_P2PPS = 0x6A,
HALMAC_API_CFG_TX_ADDR = 0x6B,
HALMAC_API_CFG_NET_TYPE = 0x6C,
HALMAC_API_CFG_TSF_RESET = 0x6D,
HALMAC_API_CFG_BCN_SPACE = 0x6E,
HALMAC_API_CFG_BCN_CTRL = 0x6F,
HALMAC_API_CFG_SIDEBAND_INT = 0x70,
HALMAC_API_REGISTER_API = 0x71,
HALMAC_API_FREE_DOWNLOAD_FIRMWARE = 0x72,
HALMAC_API_GET_FW_VERSION = 0x73,
HALMAC_API_GET_EFUSE_AVAL_SIZE = 0x74,
HALMAC_API_CHK_TXDESC = 0x75,
HALMAC_API_SDIO_CMD53_4BYTE = 0x76,
HALMAC_API_CFG_TRANS_ADDR = 0x77,
HALMAC_API_INTF_INTEGRA_TUNING = 0x78,
HALMAC_API_TXFIFO_IS_EMPTY = 0x79,
HALMAC_API_DOWNLOAD_FLASH = 0x7A,
HALMAC_API_READ_FLASH = 0x7B,
HALMAC_API_ERASE_FLASH = 0x7C,
HALMAC_API_CHECK_FLASH = 0x7D,
HALMAC_API_SDIO_HW_INFO = 0x80,
HALMAC_API_READ_EFUSE_BT = 0x81,
HALMAC_API_CFG_EFUSE_AUTO_CHECK = 0x82,
HALMAC_API_CFG_PINMUX_GET_FUNC = 0x83,
HALMAC_API_CFG_PINMUX_SET_FUNC = 0x84,
HALMAC_API_CFG_PINMUX_FREE_FUNC = 0x85,
HALMAC_API_CFG_PINMUX_WL_LED_MODE = 0x86,
HALMAC_API_CFG_PINMUX_WL_LED_SW_CTRL = 0x87,
HALMAC_API_CFG_PINMUX_SDIO_INT_POLARITY = 0x88,
HALMAC_API_CFG_PINMUX_GPIO_MODE = 0x89,
HALMAC_API_CFG_PINMUX_GPIO_OUTPUT = 0x90,
HALMAC_API_REG_READ_INDIRECT_32 = 0x91,
HALMAC_API_REG_SDIO_CMD53_READ_N = 0x92,
HALMAC_API_PINMUX_PIN_STATUS = 0x94,
HALMAC_API_OFLD_FUNC_CFG = 0x95,
HALMAC_API_MASK_LOGICAL_EFUSE = 0x96,
HALMAC_API_RX_CUT_AMSDU_CFG = 0x97,
HALMAC_API_FW_SNDING = 0x98,
HALMAC_API_ENTER_CPU_SLEEP_MODE = 0x99,
HALMAC_API_GET_CPU_MODE = 0x9A,
HALMAC_API_DRV_FWCTRL = 0x9B,
HALMAC_API_EN_REF_AUTOK = 0x9C,
HALMAC_API_RESET_WIFI_FW = 0x9D,
HALMAC_API_CFGSPC_SET_PCIE = 0x9E,
HALMAC_API_MAX
};
enum halmac_la_mode {
HALMAC_LA_MODE_DISABLE = 0,
HALMAC_LA_MODE_PARTIAL = 1,
HALMAC_LA_MODE_FULL = 2,
HALMAC_LA_MODE_UNDEFINE = 0x7F,
};
enum halmac_rx_fifo_expanding_mode {
HALMAC_RX_FIFO_EXPANDING_MODE_DISABLE = 0,
HALMAC_RX_FIFO_EXPANDING_MODE_1_BLOCK = 1,
HALMAC_RX_FIFO_EXPANDING_MODE_2_BLOCK = 2,
HALMAC_RX_FIFO_EXPANDING_MODE_3_BLOCK = 3,
HALMAC_RX_FIFO_EXPANDING_MODE_4_BLOCK = 4,
HALMAC_RX_FIFO_EXPANDING_MODE_UNDEFINE = 0x7F,
};
enum halmac_sdio_cmd53_4byte_mode {
HALMAC_SDIO_CMD53_4BYTE_MODE_DISABLE = 0,
HALMAC_SDIO_CMD53_4BYTE_MODE_RW = 1,
HALMAC_SDIO_CMD53_4BYTE_MODE_R = 2,
HALMAC_SDIO_CMD53_4BYTE_MODE_W = 3,
HALMAC_SDIO_CMD53_4BYTE_MODE_UNDEFINE = 0x7F,
};
enum halmac_usb_mode {
HALMAC_USB_MODE_U2 = 1,
HALMAC_USB_MODE_U3 = 2,
};
enum halmac_sdio_tx_format {
HALMAC_SDIO_AGG_MODE = 1,
HALMAC_SDIO_DUMMY_BLOCK_MODE = 2,
HALMAC_SDIO_DUMMY_AUTO_MODE = 3,
};
enum halmac_sdio_clk_monitor {
HALMAC_MONITOR_5US = 1,
HALMAC_MONITOR_50US = 2,
HALMAC_MONITOR_9MS = 3,
};
enum halmac_hw_id {
/* Get HW value */
HALMAC_HW_RQPN_MAPPING = 0x00,
HALMAC_HW_EFUSE_SIZE = 0x01,
HALMAC_HW_EEPROM_SIZE = 0x02,
HALMAC_HW_BT_BANK_EFUSE_SIZE = 0x03,
HALMAC_HW_BT_BANK1_EFUSE_SIZE = 0x04,
HALMAC_HW_BT_BANK2_EFUSE_SIZE = 0x05,
HALMAC_HW_TXFIFO_SIZE = 0x06,
HALMAC_HW_RXFIFO_SIZE = 0x07,
HALMAC_HW_RSVD_PG_BNDY = 0x08,
HALMAC_HW_CAM_ENTRY_NUM = 0x09,
HALMAC_HW_IC_VERSION = 0x0A,
HALMAC_HW_PAGE_SIZE = 0x0B,
HALMAC_HW_TX_AGG_ALIGN_SIZE = 0x0C,
HALMAC_HW_RX_AGG_ALIGN_SIZE = 0x0D,
HALMAC_HW_DRV_INFO_SIZE = 0x0E,
HALMAC_HW_TXFF_ALLOCATION = 0x0F,
HALMAC_HW_RSVD_EFUSE_SIZE = 0x10,
HALMAC_HW_FW_HDR_SIZE = 0x11,
HALMAC_HW_TX_DESC_SIZE = 0x12,
HALMAC_HW_RX_DESC_SIZE = 0x13,
HALMAC_HW_FW_MAX_SIZE = 0x14,
HALMAC_HW_ORI_H2C_SIZE = 0x15,
HALMAC_HW_RSVD_DRV_PGNUM = 0x16,
HALMAC_HW_TX_PAGE_SIZE = 0x17,
HALMAC_HW_USB_TXAGG_DESC_NUM = 0x18,
HALMAC_HW_WLAN_EFUSE_AVAILABLE_SIZE = 0x19,
HALMAC_HW_AC_OQT_SIZE = 0x1C,
HALMAC_HW_NON_AC_OQT_SIZE = 0x1D,
HALMAC_HW_AC_QUEUE_NUM = 0x1E,
HALMAC_HW_RQPN_CH_MAPPING = 0x1F,
HALMAC_HW_PWR_STATE = 0x20,
HALMAC_HW_SDIO_INT_LAT = 0x21,
HALMAC_HW_SDIO_CLK_CNT = 0x22,
/* Set HW value */
HALMAC_HW_USB_MODE = 0x60,
HALMAC_HW_SEQ_EN = 0x61,
HALMAC_HW_BANDWIDTH = 0x62,
HALMAC_HW_CHANNEL = 0x63,
HALMAC_HW_PRI_CHANNEL_IDX = 0x64,
HALMAC_HW_EN_BB_RF = 0x65,
HALMAC_HW_SDIO_TX_PAGE_THRESHOLD = 0x66,
HALMAC_HW_AMPDU_CONFIG = 0x67,
HALMAC_HW_RX_SHIFT = 0x68,
HALMAC_HW_TXDESC_CHECKSUM = 0x69,
HALMAC_HW_RX_CLK_GATE = 0x6A,
HALMAC_HW_RXGCK_FIFO = 0x6B,
HALMAC_HW_RX_IGNORE = 0x6C,
HALMAC_HW_SDIO_TX_FORMAT = 0x6D,
HALMAC_HW_FAST_EDCA = 0x6E,
HALMAC_HW_LDO25_EN = 0x6F,
HALMAC_HW_PCIE_REF_AUTOK = 0x70,
HALMAC_HW_RTS_FULL_BW = 0x71,
HALMAC_HW_FREE_CNT_EN = 0x72,
HALMAC_HW_SDIO_WT_EN = 0x73,
HALMAC_HW_SDIO_CLK_MONITOR = 0x74,
HALMAC_HW_TXFIFO_LIFETIME = 0x75,
HALMAC_HW_ID_UNDEFINE = 0x7F,
};
enum halmac_efuse_bank {
HALMAC_EFUSE_BANK_WIFI = 0,
HALMAC_EFUSE_BANK_BT = 1,
HALMAC_EFUSE_BANK_BT_1 = 2,
HALMAC_EFUSE_BANK_BT_2 = 3,
HALMAC_EFUSE_BANK_MAX,
HALMAC_EFUSE_BANK_UNDEFINE = 0X7F,
};
enum halmac_sdio_spec_ver {
HALMAC_SDIO_SPEC_VER_2_00 = 0,
HALMAC_SDIO_SPEC_VER_3_00 = 1,
HALMAC_SDIO_SPEC_VER_UNDEFINE = 0X7F,
};
enum halmac_gpio_func {
HALMAC_GPIO_FUNC_WL_LED = 0,
HALMAC_GPIO_FUNC_SDIO_INT = 1,
HALMAC_GPIO_FUNC_SW_IO_0 = 2,
HALMAC_GPIO_FUNC_SW_IO_1 = 3,
HALMAC_GPIO_FUNC_SW_IO_2 = 4,
HALMAC_GPIO_FUNC_SW_IO_3 = 5,
HALMAC_GPIO_FUNC_SW_IO_4 = 6,
HALMAC_GPIO_FUNC_SW_IO_5 = 7,
HALMAC_GPIO_FUNC_SW_IO_6 = 8,
HALMAC_GPIO_FUNC_SW_IO_7 = 9,
HALMAC_GPIO_FUNC_SW_IO_8 = 10,
HALMAC_GPIO_FUNC_SW_IO_9 = 11,
HALMAC_GPIO_FUNC_SW_IO_10 = 12,
HALMAC_GPIO_FUNC_SW_IO_11 = 13,
HALMAC_GPIO_FUNC_SW_IO_12 = 14,
HALMAC_GPIO_FUNC_SW_IO_13 = 15,
HALMAC_GPIO_FUNC_SW_IO_14 = 16,
HALMAC_GPIO_FUNC_SW_IO_15 = 17,
HALMAC_GPIO_FUNC_BT_HOST_WAKE1 = 18,
HALMAC_GPIO_FUNC_BT_DEV_WAKE1 = 19,
HALMAC_GPIO_FUNC_UNDEFINE = 0X7F,
};
enum halmac_wlled_mode {
HALMAC_WLLED_MODE_TRX = 0,
HALMAC_WLLED_MODE_TX = 1,
HALMAC_WLLED_MODE_RX = 2,
HALMAC_WLLED_MODE_SW_CTRL = 3,
HALMAC_WLLED_MODE_UNDEFINE = 0X7F,
};
enum halmac_psf_fcs_chk_thr {
HALMAC_PSF_FCS_CHK_THR_1 = 0,
HALMAC_PSF_FCS_CHK_THR_4 = 1,
HALMAC_PSF_FCS_CHK_THR_8 = 2,
HALMAC_PSF_FCS_CHK_THR_12 = 3,
HALMAC_PSF_FCS_CHK_THR_16 = 4,
HALMAC_PSF_FCS_CHK_THR_20 = 5,
HALMAC_PSF_FCS_CHK_THR_24 = 6,
HALMAC_PSF_FCS_CHK_THR_28 = 7,
};
enum halmac_func_ctrl {
HALMAC_DISABLE = 0,
HALMAC_ENABLE = 1,
HALMAC_DEFAULT = 0xFE,
HALMAC_IGNORE = 0xFF
};
enum halmac_pcie_clkdly {
HALMAC_CLKDLY_0 = 0,
HALMAC_CLKDLY_5US = 1,
HALMAC_CLKDLY_6US = 2,
HALMAC_CLKDLY_11US = 3,
HALMAC_CLKDLY_15US = 4,
HALMAC_CLKDLY_19US = 5,
HALMAC_CLKDLY_25US = 6,
HALMAC_CLKDLY_30US = 7,
HALMAC_CLKDLY_38US = 8,
HALMAC_CLKDLY_50US = 9,
HALMAC_CLKDLY_64US = 10,
HALMAC_CLKDLY_100US = 11,
HALMAC_CLKDLY_128US = 12,
HALMAC_CLKDLY_150US = 13,
HALMAC_CLKDLY_192US = 14,
HALMAC_CLKDLY_200US = 15,
HALMAC_CLKDLY_R_ERR = 0xFD,
HALMAC_CLKDLY_DEF = 0xFE,
HALMAC_CLKDLY_IGNORE = 0xFF
};
enum halmac_pcie_l1dly {
HALMAC_L1DLY_16US = 0,
HALMAC_L1DLY_32US = 1,
HALMAC_L1DLY_64US = 2,
HALMAC_L1DLY_INFI = 3,
HALMAC_L1DLY_R_ERR = 0xFD,
HALMAC_L1DLY_DEF = 0xFE,
HALMAC_L1DLY_IGNORE = 0xFF
};
enum halmac_pcie_l0sdly {
HALMAC_L0SDLY_1US = 0,
HALMAC_L0SDLY_3US = 1,
HALMAC_L0SDLY_5US = 2,
HALMAC_L0SDLY_7US = 3,
HALMAC_L0SDLY_R_ERR = 0xFD,
HALMAC_L0SDLY_DEF = 0xFE,
HALMAC_L0SDLY_IGNORE = 0xFF
};
struct halmac_pcie_cfgspc_param {
u8 write;
u8 read;
enum halmac_func_ctrl l0s_ctrl;
enum halmac_func_ctrl l1_ctrl;
enum halmac_func_ctrl l1ss_ctrl;
enum halmac_func_ctrl wake_ctrl;
enum halmac_func_ctrl crq_ctrl;
enum halmac_pcie_clkdly clkdly_ctrl;
enum halmac_pcie_l0sdly l0sdly_ctrl;
enum halmac_pcie_l1dly l1dly_ctrl;
};
struct halmac_txff_allocation {
u16 tx_fifo_pg_num;
u16 rsvd_pg_num;
u16 rsvd_drv_pg_num;
u16 acq_pg_num;
u16 high_queue_pg_num;
u16 low_queue_pg_num;
u16 normal_queue_pg_num;
u16 extra_queue_pg_num;
u16 pub_queue_pg_num;
u16 rsvd_boundary;
u16 rsvd_drv_addr;
u16 rsvd_h2c_info_addr;
u16 rsvd_h2c_sta_info_addr;
u16 rsvd_h2cq_addr;
u16 rsvd_cpu_instr_addr;
u16 rsvd_fw_txbuf_addr;
u16 rsvd_csibuf_addr;
enum halmac_la_mode la_mode;
enum halmac_rx_fifo_expanding_mode rx_fifo_exp_mode;
};
struct halmac_rqpn_map {
enum halmac_dma_mapping dma_map_vo;
enum halmac_dma_mapping dma_map_vi;
enum halmac_dma_mapping dma_map_be;
enum halmac_dma_mapping dma_map_bk;
enum halmac_dma_mapping dma_map_mg;
enum halmac_dma_mapping dma_map_hi;
};
struct halmac_rqpn_ch_map {
enum halmac_dma_ch dma_map_vo;
enum halmac_dma_ch dma_map_vi;
enum halmac_dma_ch dma_map_be;
enum halmac_dma_ch dma_map_bk;
enum halmac_dma_ch dma_map_mg;
enum halmac_dma_ch dma_map_hi;
};
struct halmac_security_setting {
u8 tx_encryption;
u8 rx_decryption;
u8 bip_enable;
u8 compare_keyid;
};
struct halmac_cam_entry_info {
enum hal_security_type security_type;
u32 key[4];
u32 key_ext[4];
u8 mac_address[6];
u8 unicast;
u8 key_id;
u8 valid;
};
struct halmac_cam_entry_format {
u16 key_id : 2;
u16 type : 3;
u16 mic : 1;
u16 grp : 1;
u16 spp_mode : 1;
u16 rpt_md : 1;
u16 ext_sectype : 1;
u16 mgnt : 1;
u16 rsvd1 : 4;
u16 valid : 1;
u8 mac_address[6];
u32 key[4];
u32 rsvd[2];
};
struct halmac_tx_page_threshold_info {
u32 threshold;
enum halmac_dma_mapping dma_queue_sel;
u8 enable;
};
struct halmac_ampdu_config {
u8 max_agg_num;
u8 max_len_en;
u32 ht_max_len;
u32 vht_max_len;
};
struct halmac_rqpn {
enum halmac_trx_mode mode;
enum halmac_dma_mapping dma_map_vo;
enum halmac_dma_mapping dma_map_vi;
enum halmac_dma_mapping dma_map_be;
enum halmac_dma_mapping dma_map_bk;
enum halmac_dma_mapping dma_map_mg;
enum halmac_dma_mapping dma_map_hi;
};
struct halmac_ch_mapping {
enum halmac_trx_mode mode;
enum halmac_dma_ch dma_map_vo;
enum halmac_dma_ch dma_map_vi;
enum halmac_dma_ch dma_map_be;
enum halmac_dma_ch dma_map_bk;
enum halmac_dma_ch dma_map_mg;
enum halmac_dma_ch dma_map_hi;
};
struct halmac_pg_num {
enum halmac_trx_mode mode;
u16 hq_num;
u16 nq_num;
u16 lq_num;
u16 exq_num;
u16 gap_num;/*used for loopback mode*/
};
struct halmac_ch_pg_num {
enum halmac_trx_mode mode;
u16 ch_num[HALMAC_TXDESC_DMA_CH16 + 1];
u16 gap_num;
};
struct halmac_intf_phy_para {
u16 offset;
u16 value;
u16 ip_sel;
u16 cut;
u16 plaform;
};
struct halmac_iqk_para {
u8 clear;
u8 segment_iqk;
};
struct halmac_txdesc_ie_param {
u8 *start_offset;
u8 *end_offset;
u8 *ie_offset;
u8 *ie_exist;
};
struct halmac_sdio_hw_info {
enum halmac_sdio_spec_ver spec_ver;
u32 clock_speed;
u8 io_hi_speed_flag; /* Halmac internal use */
enum halmac_sdio_tx_format tx_addr_format;
u16 block_size;
u8 tx_seq;
u8 io_indir_flag; /* Halmac internal use */
};
struct halmac_edca_para {
u8 aifs;
u8 cw;
u16 txop_limit;
};
struct halmac_mac_rx_ignore_cfg {
u8 hdr_chk_en;
u8 fcs_chk_en;
u8 cck_rst_en;
enum halmac_psf_fcs_chk_thr fcs_chk_thr;
};
struct halmac_rx_ignore_info {
u8 hdr_chk_mask;
u8 fcs_chk_mask;
u8 hdr_chk_en;
u8 fcs_chk_en;
u8 cck_rst_en;
enum halmac_psf_fcs_chk_thr fcs_chk_thr;
};
struct halmac_pinmux_info {
/* byte0 */
u8 wl_led:1;
u8 sdio_int:1;
u8 bt_host_wake:1;
u8 bt_dev_wake:1;
u8 rsvd1:4;
/* byte1 */
u8 sw_io_0:1;
u8 sw_io_1:1;
u8 sw_io_2:1;
u8 sw_io_3:1;
u8 sw_io_4:1;
u8 sw_io_5:1;
u8 sw_io_6:1;
u8 sw_io_7:1;
/* byte2 */
u8 sw_io_8:1;
u8 sw_io_9:1;
u8 sw_io_10:1;
u8 sw_io_11:1;
u8 sw_io_12:1;
u8 sw_io_13:1;
u8 sw_io_14:1;
u8 sw_io_15:1;
};
struct halmac_ofld_func_info {
u32 halmac_malloc_max_sz;
u32 rsvd_pg_drv_buf_max_sz;
};
struct halmac_pltfm_cfg_info {
u32 malloc_size;
u32 rsvd_pg_size;
};
struct halmac_su_snding_info {
u8 su0_en;
u8 *su0_ndpa_pkt;
u32 su0_pkt_sz;
};
struct halmac_mu_snding_info {
u8 tmp;
};
struct halmac_h2c_info {
u32 buf_fs;
u32 buf_size;
u8 seq_num;
};
struct halmac_adapter {
enum halmac_dma_mapping pq_map[HALMAC_PQ_MAP_NUM];
enum halmac_dma_ch ch_map[HALMAC_PQ_MAP_NUM];
HALMAC_MUTEX h2c_seq_mutex; /* protect h2c seq num */
HALMAC_MUTEX efuse_mutex; /*protect adapter efuse map */
HALMAC_MUTEX sdio_indir_mutex; /*protect sdio indirect access */
struct halmac_cfg_param_info cfg_param_info;
struct halmac_ch_sw_info ch_sw_info;
struct halmac_event_trigger evnt;
struct halmac_hw_cfg_info hw_cfg_info;
struct halmac_sdio_free_space sdio_fs;
struct halmac_api_registry api_registry;
struct halmac_pinmux_info pinmux_info;
struct halmac_pltfm_cfg_info pltfm_info;
struct halmac_h2c_info h2c_info;
void *drv_adapter;
u8 *efuse_map;
void *halmac_api;
struct halmac_platform_api *pltfm_api;
u32 efuse_end;
u32 dlfw_pkt_size;
enum halmac_chip_id chip_id;
enum halmac_chip_ver chip_ver;
struct halmac_fw_version fw_ver;
struct halmac_state halmac_state;
enum halmac_interface intf;
enum halmac_trx_mode trx_mode;
struct halmac_txff_allocation txff_alloc;
u8 efuse_map_valid;
u8 efuse_seg_size;
u8 rpwm;
u8 bulkout_num;
u8 drv_info_size;
enum halmac_sdio_cmd53_4byte_mode sdio_cmd53_4byte;
struct halmac_sdio_hw_info sdio_hw_info;
u8 tx_desc_transfer;
u8 tx_desc_checksum;
u8 efuse_auto_check_en;
u8 pcie_refautok_en;
u8 pwr_off_flow_flag;
u8 nlo_flag;
struct halmac_rx_ignore_info rx_ignore_info;
#if HALMAC_PLATFORM_TESTPROGRAM
struct halmisc_adapter *halmisc_adapter;
#endif
};
struct halmac_api {
enum halmac_ret_status
(*halmac_register_api)(struct halmac_adapter *adapter,
struct halmac_api_registry *registry);
enum halmac_ret_status
(*halmac_mac_power_switch)(struct halmac_adapter *adapter,
enum halmac_mac_power pwr);
enum halmac_ret_status
(*halmac_download_firmware)(struct halmac_adapter *adapter, u8 *fw_bin,
u32 size);
enum halmac_ret_status
(*halmac_free_download_firmware)(struct halmac_adapter *adapter,
enum halmac_dlfw_mem mem_sel,
u8 *fw_bin, u32 size);
enum halmac_ret_status
(*halmac_reset_wifi_fw)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_get_fw_version)(struct halmac_adapter *adapter,
struct halmac_fw_version *ver);
enum halmac_ret_status
(*halmac_cfg_mac_addr)(struct halmac_adapter *adapter,
u8 port, union halmac_wlan_addr *addr);
enum halmac_ret_status
(*halmac_cfg_bssid)(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
enum halmac_ret_status
(*halmac_cfg_multicast_addr)(struct halmac_adapter *adapter,
union halmac_wlan_addr *addr);
enum halmac_ret_status
(*halmac_pre_init_system_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_system_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_trx_cfg)(struct halmac_adapter *adapter,
enum halmac_trx_mode mode);
enum halmac_ret_status
(*halmac_init_h2c)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_cfg_rx_aggregation)(struct halmac_adapter *adapter,
struct halmac_rxagg_cfg *cfg);
enum halmac_ret_status
(*halmac_init_protocol_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_edca_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_cfg_operation_mode)(struct halmac_adapter *adapter,
enum halmac_wireless_mode mode);
enum halmac_ret_status
(*halmac_cfg_ch_bw)(struct halmac_adapter *adapter, u8 ch,
enum halmac_pri_ch_idx idx, enum halmac_bw bw);
enum halmac_ret_status
(*halmac_cfg_bw)(struct halmac_adapter *adapter, enum halmac_bw bw);
enum halmac_ret_status
(*halmac_init_wmac_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_mac_cfg)(struct halmac_adapter *adapter,
enum halmac_trx_mode mode);
enum halmac_ret_status
(*halmac_init_interface_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_deinit_interface_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_sdio_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_usb_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_init_pcie_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_deinit_sdio_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_deinit_usb_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_deinit_pcie_cfg)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_get_efuse_size)(struct halmac_adapter *adapter, u32 *size);
enum halmac_ret_status
(*halmac_get_efuse_available_size)(struct halmac_adapter *adapter,
u32 *size);
enum halmac_ret_status
(*halmac_dump_efuse_map)(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg);
enum halmac_ret_status
(*halmac_dump_efuse_map_bt)(struct halmac_adapter *adapter,
enum halmac_efuse_bank bank, u32 size,
u8 *map);
enum halmac_ret_status
(*halmac_write_efuse_bt)(struct halmac_adapter *adapter, u32 offset,
u8 value, enum halmac_efuse_bank bank);
enum halmac_ret_status
(*halmac_read_efuse_bt)(struct halmac_adapter *adapter, u32 offset,
u8 *value, enum halmac_efuse_bank bank);
enum halmac_ret_status
(*halmac_cfg_efuse_auto_check)(struct halmac_adapter *adapter,
u8 enable);
enum halmac_ret_status
(*halmac_get_logical_efuse_size)(struct halmac_adapter *adapter,
u32 *size);
enum halmac_ret_status
(*halmac_dump_logical_efuse_map)(struct halmac_adapter *adapter,
enum halmac_efuse_read_cfg cfg);
enum halmac_ret_status
(*halmac_write_logical_efuse)(struct halmac_adapter *adapter,
u32 offset, u8 value);
enum halmac_ret_status
(*halmac_read_logical_efuse)(struct halmac_adapter *adapter, u32 offset,
u8 *value);
enum halmac_ret_status
(*halmac_pg_efuse_by_map)(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info,
enum halmac_efuse_read_cfg cfg);
enum halmac_ret_status
(*halmac_mask_logical_efuse)(struct halmac_adapter *adapter,
struct halmac_pg_efuse_info *info);
enum halmac_ret_status
(*halmac_get_c2h_info)(struct halmac_adapter *adapter, u8 *buf,
u32 size);
enum halmac_ret_status
(*halmac_h2c_lb)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_debug)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_cfg_parameter)(struct halmac_adapter *adapter,
struct halmac_phy_parameter_info *info,
u8 full_fifo);
enum halmac_ret_status
(*halmac_update_packet)(struct halmac_adapter *adapter,
enum halmac_packet_id pkt_id, u8 *pkt,
u32 size);
enum halmac_ret_status
(*halmac_bcn_ie_filter)(struct halmac_adapter *adapter,
struct halmac_bcn_ie_info *info);
u8
(*halmac_reg_read_8)(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
(*halmac_reg_write_8)(struct halmac_adapter *adapter, u32 offset,
u8 value);
u16
(*halmac_reg_read_16)(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
(*halmac_reg_write_16)(struct halmac_adapter *adapter, u32 offset,
u16 value);
u32
(*halmac_reg_read_32)(struct halmac_adapter *adapter, u32 offset);
enum halmac_ret_status
(*halmac_reg_write_32)(struct halmac_adapter *adapter, u32 offset,
u32 value);
u32
(*halmac_reg_read_indirect_32)(struct halmac_adapter *adapter,
u32 offset);
enum halmac_ret_status
(*halmac_reg_sdio_cmd53_read_n)(struct halmac_adapter *adapter,
u32 offset, u32 size, u8 *value);
enum halmac_ret_status
(*halmac_tx_allowed_sdio)(struct halmac_adapter *adapter, u8 *buf,
u32 size);
enum halmac_ret_status
(*halmac_set_bulkout_num)(struct halmac_adapter *adapter, u8 num);
enum halmac_ret_status
(*halmac_get_sdio_tx_addr)(struct halmac_adapter *adapter, u8 *buf,
u32 size, u32 *cmd53_addr);
enum halmac_ret_status
(*halmac_get_usb_bulkout_id)(struct halmac_adapter *adapter, u8 *buf,
u32 size, u8 *id);
enum halmac_ret_status
(*halmac_fill_txdesc_checksum)(struct halmac_adapter *adapter,
u8 *txdesc);
enum halmac_ret_status
(*halmac_update_datapack)(struct halmac_adapter *adapter,
enum halmac_data_type data_type,
struct halmac_phy_parameter_info *info);
enum halmac_ret_status
(*halmac_run_datapack)(struct halmac_adapter *adapter,
enum halmac_data_type data_type);
enum halmac_ret_status
(*halmac_cfg_drv_info)(struct halmac_adapter *adapter,
enum halmac_drv_info drv_info);
enum halmac_ret_status
(*halmac_send_bt_coex)(struct halmac_adapter *adapter, u8 *buf,
u32 size, u8 ack);
enum halmac_ret_status
(*halmac_verify_platform_api)(struct halmac_adapter *adapter);
u32
(*halmac_get_fifo_size)(struct halmac_adapter *adapter,
enum hal_fifo_sel sel);
enum halmac_ret_status
(*halmac_dump_fifo)(struct halmac_adapter *adapter,
enum hal_fifo_sel sel, u32 start_addr, u32 size,
u8 *data);
enum halmac_ret_status
(*halmac_cfg_txbf)(struct halmac_adapter *adapter, u8 userid,
enum halmac_bw bw, u8 txbf_en);
enum halmac_ret_status
(*halmac_cfg_mumimo)(struct halmac_adapter *adapter,
struct halmac_cfg_mumimo_para *param);
enum halmac_ret_status
(*halmac_cfg_sounding)(struct halmac_adapter *adapter,
enum halmac_snd_role role,
enum halmac_data_rate rate);
enum halmac_ret_status
(*halmac_del_sounding)(struct halmac_adapter *adapter,
enum halmac_snd_role role);
enum halmac_ret_status
(*halmac_su_bfer_entry_init)(struct halmac_adapter *adapter,
struct halmac_su_bfer_init_para *param);
enum halmac_ret_status
(*halmac_su_bfee_entry_init)(struct halmac_adapter *adapter, u8 userid,
u16 paid);
enum halmac_ret_status
(*halmac_mu_bfer_entry_init)(struct halmac_adapter *adapter,
struct halmac_mu_bfer_init_para *param);
enum halmac_ret_status
(*halmac_mu_bfee_entry_init)(struct halmac_adapter *adapter,
struct halmac_mu_bfee_init_para *param);
enum halmac_ret_status
(*halmac_su_bfer_entry_del)(struct halmac_adapter *adapter, u8 userid);
enum halmac_ret_status
(*halmac_su_bfee_entry_del)(struct halmac_adapter *adapter, u8 userid);
enum halmac_ret_status
(*halmac_mu_bfer_entry_del)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_mu_bfee_entry_del)(struct halmac_adapter *adapter, u8 userid);
enum halmac_ret_status
(*halmac_add_ch_info)(struct halmac_adapter *adapter,
struct halmac_ch_info *info);
enum halmac_ret_status
(*halmac_add_extra_ch_info)(struct halmac_adapter *adapter,
struct halmac_ch_extra_info *info);
enum halmac_ret_status
(*halmac_ctrl_ch_switch)(struct halmac_adapter *adapter,
struct halmac_ch_switch_option *opt);
enum halmac_ret_status
(*halmac_p2pps)(struct halmac_adapter *adapter,
struct halmac_p2pps *info);
enum halmac_ret_status
(*halmac_clear_ch_info)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_send_general_info)(struct halmac_adapter *adapter,
struct halmac_general_info *info);
enum halmac_ret_status
(*halmac_start_iqk)(struct halmac_adapter *adapter,
struct halmac_iqk_para *param);
enum halmac_ret_status
(*halmac_ctrl_pwr_tracking)(struct halmac_adapter *adapter,
struct halmac_pwr_tracking_option *opt);
enum halmac_ret_status
(*halmac_psd)(struct halmac_adapter *adapter, u16 start_psd,
u16 end_psd);
enum halmac_ret_status
(*halmac_cfg_tx_agg_align)(struct halmac_adapter *adapter, u8 enable,
u16 align_size);
enum halmac_ret_status
(*halmac_query_status)(struct halmac_adapter *adapter,
enum halmac_feature_id feature_id,
enum halmac_cmd_process_status *proc_status,
u8 *data, u32 *size);
enum halmac_ret_status
(*halmac_reset_feature)(struct halmac_adapter *adapter,
enum halmac_feature_id feature_id);
enum halmac_ret_status
(*halmac_check_fw_status)(struct halmac_adapter *adapter,
u8 *fw_status);
enum halmac_ret_status
(*halmac_dump_fw_dmem)(struct halmac_adapter *adapter, u8 *dmem,
u32 *size);
enum halmac_ret_status
(*halmac_cfg_max_dl_size)(struct halmac_adapter *adapter, u32 size);
enum halmac_ret_status
(*halmac_cfg_la_mode)(struct halmac_adapter *adapter,
enum halmac_la_mode mode);
enum halmac_ret_status
(*halmac_cfg_rxff_expand_mode)(struct halmac_adapter *adapter,
enum halmac_rx_fifo_expanding_mode mode);
enum halmac_ret_status
(*halmac_config_security)(struct halmac_adapter *adapter,
struct halmac_security_setting *setting);
u8
(*halmac_get_used_cam_entry_num)(struct halmac_adapter *adapter,
enum hal_security_type sec_type);
enum halmac_ret_status
(*halmac_write_cam)(struct halmac_adapter *adapter, u32 idx,
struct halmac_cam_entry_info *info);
enum halmac_ret_status
(*halmac_read_cam_entry)(struct halmac_adapter *adapter, u32 idx,
struct halmac_cam_entry_format *content);
enum halmac_ret_status
(*halmac_clear_cam_entry)(struct halmac_adapter *adapter, u32 idx);
enum halmac_ret_status
(*halmac_get_hw_value)(struct halmac_adapter *adapter,
enum halmac_hw_id hw_id, void *value);
enum halmac_ret_status
(*halmac_set_hw_value)(struct halmac_adapter *adapter,
enum halmac_hw_id hw_id, void *value);
enum halmac_ret_status
(*halmac_cfg_drv_rsvd_pg_num)(struct halmac_adapter *adapter,
enum halmac_drv_rsvd_pg_num pg_num);
enum halmac_ret_status
(*halmac_get_chip_version)(struct halmac_adapter *adapter,
struct halmac_ver *ver);
enum halmac_ret_status
(*halmac_chk_txdesc)(struct halmac_adapter *adapter, u8 *buf, u32 size);
enum halmac_ret_status
(*halmac_dl_drv_rsvd_page)(struct halmac_adapter *adapter, u8 pg_offset,
u8 *buf, u32 size);
enum halmac_ret_status
(*halmac_pcie_switch)(struct halmac_adapter *adapter,
enum halmac_pcie_cfg cfg);
enum halmac_ret_status
(*halmac_phy_cfg)(struct halmac_adapter *adapter,
enum halmac_intf_phy_platform pltfm);
enum halmac_ret_status
(*halmac_cfg_csi_rate)(struct halmac_adapter *adapter, u8 rssi,
u8 cur_rate, u8 fixrate_en, u8 *new_rate,
u8 *bmp_ofdm54);
#if HALMAC_SDIO_SUPPORT
enum halmac_ret_status
(*halmac_sdio_cmd53_4byte)(struct halmac_adapter *adapter,
enum halmac_sdio_cmd53_4byte_mode mode);
enum halmac_ret_status
(*halmac_sdio_hw_info)(struct halmac_adapter *adapter,
struct halmac_sdio_hw_info *info);
#endif
enum halmac_ret_status
(*halmac_cfg_transmitter_addr)(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
enum halmac_ret_status
(*halmac_cfg_net_type)(struct halmac_adapter *adapter, u8 port,
enum halmac_network_type_select net_type);
enum halmac_ret_status
(*halmac_cfg_tsf_rst)(struct halmac_adapter *adapter, u8 port);
enum halmac_ret_status
(*halmac_cfg_bcn_space)(struct halmac_adapter *adapter, u8 port,
u32 bcn_space);
enum halmac_ret_status
(*halmac_rw_bcn_ctrl)(struct halmac_adapter *adapter, u8 port,
u8 write_en, struct halmac_bcn_ctrl *ctrl);
enum halmac_ret_status
(*halmac_interface_integration_tuning)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_txfifo_is_empty)(struct halmac_adapter *adapter, u32 chk_num);
enum halmac_ret_status
(*halmac_download_flash)(struct halmac_adapter *adapter, u8 *fw_bin,
u32 size, u32 rom_addr);
enum halmac_ret_status
(*halmac_read_flash)(struct halmac_adapter *adapter, u32 addr,
u32 length);
enum halmac_ret_status
(*halmac_erase_flash)(struct halmac_adapter *adapter, u8 erase_cmd,
u32 addr);
enum halmac_ret_status
(*halmac_check_flash)(struct halmac_adapter *adapter, u8 *fw_bin,
u32 size, u32 addr);
enum halmac_ret_status
(*halmac_cfg_edca_para)(struct halmac_adapter *adapter,
enum halmac_acq_id acq_id,
struct halmac_edca_para *param);
enum halmac_ret_status
(*halmac_pinmux_get_func)(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func, u8 *enable);
enum halmac_ret_status
(*halmac_pinmux_set_func)(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func);
enum halmac_ret_status
(*halmac_pinmux_free_func)(struct halmac_adapter *adapter,
enum halmac_gpio_func gpio_func);
enum halmac_ret_status
(*halmac_pinmux_wl_led_mode)(struct halmac_adapter *adapter,
enum halmac_wlled_mode mode);
void
(*halmac_pinmux_wl_led_sw_ctrl)(struct halmac_adapter *adapter, u8 on);
void
(*halmac_pinmux_sdio_int_polarity)(struct halmac_adapter *adapter,
u8 low_active);
enum halmac_ret_status
(*halmac_pinmux_gpio_mode)(struct halmac_adapter *adapter, u8 gpio_id,
u8 output);
enum halmac_ret_status
(*halmac_pinmux_gpio_output)(struct halmac_adapter *adapter, u8 gpio_id,
u8 high);
enum halmac_ret_status
(*halmac_pinmux_pin_status)(struct halmac_adapter *adapter, u8 pin_id,
u8 *high);
enum halmac_ret_status
(*halmac_ofld_func_cfg)(struct halmac_adapter *adapter,
struct halmac_ofld_func_info *info);
enum halmac_ret_status
(*halmac_rx_cut_amsdu_cfg)(struct halmac_adapter *adapter,
struct halmac_cut_amsdu_cfg *cfg);
enum halmac_ret_status
(*halmac_fw_snding)(struct halmac_adapter *adapter,
struct halmac_su_snding_info *su_info,
struct halmac_mu_snding_info *mu_info, u8 period);
enum halmac_ret_status
(*halmac_get_mac_addr)(struct halmac_adapter *adapter, u8 port,
union halmac_wlan_addr *addr);
enum halmac_ret_status
(*halmac_init_low_pwr)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_enter_cpu_sleep_mode)(struct halmac_adapter *adapter);
enum halmac_ret_status
(*halmac_get_cpu_mode)(struct halmac_adapter *adapter,
enum halmac_wlcpu_mode *mode);
enum halmac_ret_status
(*halmac_drv_fwctrl)(struct halmac_adapter *adapter, u8 *payload,
u32 size, u8 ack);
enum halmac_ret_status
(*halmac_read_efuse)(struct halmac_adapter *adapter, u32 offset,
u8 *value);
enum halmac_ret_status
(*halmac_write_efuse)(struct halmac_adapter *adapter, u32 offset,
u8 value);
#if HALMAC_PCIE_SUPPORT
enum halmac_ret_status
(*halmac_cfgspc_set_pcie)(struct halmac_adapter *adapter,
struct halmac_pcie_cfgspc_param *param);
void
(*halmac_en_ref_autok_pcie)(struct halmac_adapter *adapter, u8 en);
#endif
#if HALMAC_PLATFORM_TESTPROGRAM
struct halmisc_api *halmisc_api;
#endif
};
#define HALMAC_GET_API(halmac_adapter) \
((struct halmac_api *)halmac_adapter->halmac_api)
static HALMAC_INLINE enum halmac_ret_status
halmac_fw_validate(struct halmac_adapter *adapter)
{
if (adapter->halmac_state.dlfw_state != HALMAC_DLFW_DONE &&
adapter->halmac_state.dlfw_state != HALMAC_GEN_INFO_SENT)
return HALMAC_RET_NO_DLFW;
return HALMAC_RET_SUCCESS;
}
#endif
================================================
FILE: hal/halmac/halmac_usb_reg.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
******************************************************************************/
#ifndef __HALMAC_USB_REG_H__
#define __HALMAC_USB_REG_H__
#endif/* __HALMAC_USB_REG_H__ */
================================================
FILE: hal/led/hal_led.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#ifdef CONFIG_RTW_LED
void dump_led_config(void *sel, _adapter *adapter)
{
struct dvobj_priv *dvobj = adapter_to_dvobj(adapter);
struct led_priv *ledpriv = adapter_to_led(adapter);
int i;
RTW_PRINT_SEL(sel, "strategy:%u\n", ledpriv->LedStrategy);
#ifdef CONFIG_RTW_SW_LED
RTW_PRINT_SEL(sel, "bRegUseLed:%u\n", ledpriv->bRegUseLed);
RTW_PRINT_SEL(sel, "iface_en_mask:0x%02X\n", ledpriv->iface_en_mask);
for (i = 0; i < dvobj->iface_nums; i++)
RTW_PRINT_SEL(sel, "ctl_en_mask[%d]:0x%08X\n", i, ledpriv->ctl_en_mask[i]);
#endif
}
void rtw_led_set_strategy(_adapter *adapter, u8 strategy)
{
struct led_priv *ledpriv = adapter_to_led(adapter);
_adapter *pri_adapter = GET_PRIMARY_ADAPTER(adapter);
#ifndef CONFIG_RTW_SW_LED
if (IS_SW_LED_STRATEGY(strategy)) {
RTW_WARN("CONFIG_RTW_SW_LED is not defined\n");
return;
}
#endif
#ifdef CONFIG_RTW_SW_LED
if (!ledpriv->bRegUseLed)
return;
#endif
if (ledpriv->LedStrategy == strategy)
return;
if (IS_HW_LED_STRATEGY(strategy) || IS_HW_LED_STRATEGY(ledpriv->LedStrategy)) {
RTW_WARN("switching on/off HW_LED strategy is not supported\n");
return;
}
ledpriv->LedStrategy = strategy;
#ifdef CONFIG_RTW_SW_LED
rtw_hal_sw_led_deinit(pri_adapter);
#endif
rtw_led_control(pri_adapter, RTW_LED_OFF);
}
#ifdef CONFIG_RTW_SW_LED
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
void rtw_sw_led_blink_uc_trx_only(LED_DATA *led)
{
_adapter *adapter = led->padapter;
BOOLEAN bStopBlinking = _FALSE;
if (led->BlinkingLedState == RTW_LED_ON)
SwLedOn(adapter, led);
else
SwLedOff(adapter, led);
switch (led->CurrLedState) {
case RTW_LED_ON:
SwLedOn(adapter, led);
break;
case RTW_LED_OFF:
SwLedOff(adapter, led);
break;
case LED_BLINK_TXRX:
led->BlinkTimes--;
if (led->BlinkTimes == 0)
bStopBlinking = _TRUE;
if (adapter_to_pwrctl(adapter)->rf_pwrstate != rf_on
&& adapter_to_pwrctl(adapter)->rfoff_reason > RF_CHANGE_BY_PS
) {
SwLedOff(adapter, led);
led->bLedBlinkInProgress = _FALSE;
} else {
if (led->bLedOn)
led->BlinkingLedState = RTW_LED_OFF;
else
led->BlinkingLedState = RTW_LED_ON;
if (bStopBlinking) {
led->CurrLedState = RTW_LED_OFF;
led->bLedBlinkInProgress = _FALSE;
}
_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
}
break;
default:
break;
}
}
void rtw_sw_led_ctl_mode_uc_trx_only(_adapter *adapter, LED_CTL_MODE ctl)
{
struct led_priv *ledpriv = adapter_to_led(adapter);
LED_DATA *led = &(ledpriv->SwLed0);
LED_DATA *led1 = &(ledpriv->SwLed1);
LED_DATA *led2 = &(ledpriv->SwLed2);
switch (ctl) {
case LED_CTL_UC_TX:
case LED_CTL_UC_RX:
if (led->bLedBlinkInProgress == _FALSE) {
led->bLedBlinkInProgress = _TRUE;
led->CurrLedState = LED_BLINK_TXRX;
led->BlinkTimes = 2;
if (led->bLedOn)
led->BlinkingLedState = RTW_LED_OFF;
else
led->BlinkingLedState = RTW_LED_ON;
_set_timer(&(led->BlinkTimer), LED_BLINK_FASTER_INTERVAL_ALPHA);
}
break;
case LED_CTL_POWER_OFF:
led->CurrLedState = RTW_LED_OFF;
led->BlinkingLedState = RTW_LED_OFF;
if (led->bLedBlinkInProgress) {
_cancel_timer_ex(&(led->BlinkTimer));
led->bLedBlinkInProgress = _FALSE;
}
SwLedOff(adapter, led);
SwLedOff(adapter, led1);
SwLedOff(adapter, led2);
break;
default:
break;
}
}
#endif /* CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY */
void rtw_led_control(_adapter *adapter, LED_CTL_MODE ctl)
{
struct led_priv *ledpriv = adapter_to_led(adapter);
if (ledpriv->LedControlHandler) {
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
if (ledpriv->LedStrategy != SW_LED_MODE_UC_TRX_ONLY) {
if (ctl == LED_CTL_UC_TX || ctl == LED_CTL_BMC_TX) {
if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_TX))
ctl = LED_CTL_TX; /* transform specific TX ctl to general TX ctl */
} else if (ctl == LED_CTL_UC_RX || ctl == LED_CTL_BMC_RX) {
if (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(LED_CTL_RX))
ctl = LED_CTL_RX; /* transform specific RX ctl to general RX ctl */
}
}
#endif
if ((ledpriv->iface_en_mask & BIT(adapter->iface_id))
&& (ledpriv->ctl_en_mask[adapter->iface_id] & BIT(ctl)))
ledpriv->LedControlHandler(adapter, ctl);
}
}
void rtw_led_tx_control(_adapter *adapter, const u8 *da)
{
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
if (IS_MCAST(da))
rtw_led_control(adapter, LED_CTL_BMC_TX);
else
rtw_led_control(adapter, LED_CTL_UC_TX);
#else
rtw_led_control(adapter, LED_CTL_TX);
#endif
}
void rtw_led_rx_control(_adapter *adapter, const u8 *da)
{
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
if (IS_MCAST(da))
rtw_led_control(adapter, LED_CTL_BMC_RX);
else
rtw_led_control(adapter, LED_CTL_UC_RX);
#else
rtw_led_control(adapter, LED_CTL_RX);
#endif
}
void rtw_led_set_iface_en(_adapter *adapter, u8 en)
{
struct led_priv *ledpriv = adapter_to_led(adapter);
if (en)
ledpriv->iface_en_mask |= BIT(adapter->iface_id);
else
ledpriv->iface_en_mask &= ~BIT(adapter->iface_id);
}
void rtw_led_set_iface_en_mask(_adapter *adapter, u8 mask)
{
struct led_priv *ledpriv = adapter_to_led(adapter);
ledpriv->iface_en_mask = mask;
}
void rtw_led_set_ctl_en_mask(_adapter *adapter, u32 ctl_mask)
{
struct led_priv *ledpriv = adapter_to_led(adapter);
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
if (ctl_mask & BIT(LED_CTL_TX))
ctl_mask |= BIT(LED_CTL_UC_TX) | BIT(LED_CTL_BMC_TX);
if (ctl_mask & BIT(LED_CTL_RX))
ctl_mask |= BIT(LED_CTL_UC_RX) | BIT(LED_CTL_BMC_RX);
#endif
ledpriv->ctl_en_mask[adapter->iface_id] = ctl_mask;
}
void rtw_led_set_ctl_en_mask_primary(_adapter *adapter)
{
rtw_led_set_ctl_en_mask(adapter, 0xFFFFFFFF);
}
void rtw_led_set_ctl_en_mask_virtual(_adapter *adapter)
{
rtw_led_set_ctl_en_mask(adapter
, BIT(LED_CTL_POWER_ON) | BIT(LED_CTL_POWER_OFF)
| BIT(LED_CTL_TX) | BIT(LED_CTL_RX)
);
}
#endif /* CONFIG_RTW_SW_LED */
#endif /* CONFIG_RTW_LED */
================================================
FILE: hal/led/hal_pci_led.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include
#include
#ifdef CONFIG_RTW_SW_LED
/*
* Description:
* Turn on LED according to LedPin specified.
* */
void
HwLedBlink(
PADAPTER Adapter,
PLED_PCIE pLed
)
{
switch (pLed->LedPin) {
case LED_PIN_GPIO0:
break;
case LED_PIN_LED0:
/* rtw_write8(Adapter, LED0Cfg, 0x2); */
break;
case LED_PIN_LED1:
/* rtw_write8(Adapter, LED1Cfg, 0x2); */
break;
default:
break;
}
pLed->bLedOn = _TRUE;
}
/*
* Description:
* Implement LED blinking behavior for SW_LED_MODE0.
* It toggle off LED and schedule corresponding timer if necessary.
* */
void
SwLedBlink(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
/* Determine if we shall change LED state again. */
pLed->BlinkTimes--;
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_TXRX:
case LED_BLINK_RUNTOP:
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
break;
case LED_BLINK_SCAN:
if (((check_fwstate(pmlmepriv, WIFI_STATION_STATE) && check_fwstate(pmlmepriv, _FW_LINKED)) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))) && /* Linked. */
(!check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) && /* Not in scan stage. */
(pLed->BlinkTimes % 2 == 0)) /* Even */
bStopBlinking = _TRUE;
break;
case LED_BLINK_NO_LINK:
case LED_BLINK_StartToBlink:
if (check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE))
bStopBlinking = _TRUE;
else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) &&
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
bStopBlinking = _TRUE;
else if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
break;
case LED_BLINK_CAMEO:
if (check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE))
bStopBlinking = _TRUE;
else if (check_fwstate(pmlmepriv, _FW_LINKED) &&
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
bStopBlinking = _TRUE;
break;
default:
bStopBlinking = _TRUE;
break;
}
if (bStopBlinking) {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
SwLedOff(Adapter, pLed);
else if (pLed->CurrLedState == LED_BLINK_TXRX)
SwLedOff(Adapter, pLed);
else if (pLed->CurrLedState == LED_BLINK_RUNTOP)
SwLedOff(Adapter, pLed);
else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) && pLed->bLedOn == _FALSE)
SwLedOn(Adapter, pLed);
else if ((check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) && pLed->bLedOn == _TRUE)
SwLedOff(Adapter, pLed);
pLed->BlinkTimes = 0;
pLed->bLedBlinkInProgress = _FALSE;
} else {
/* Assign LED state to toggle. */
if (pLed->BlinkingLedState == RTW_LED_ON)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/* Schedule a timer to toggle LED state. */
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_TXRX:
case LED_BLINK_StartToBlink:
_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
break;
case LED_BLINK_SLOWLY:
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
break;
case LED_BLINK_SCAN:
case LED_BLINK_NO_LINK:
if (pLed->bLedOn)
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
else
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_OFF_INTERVAL);
break;
case LED_BLINK_RUNTOP:
_set_timer(&(pLed->BlinkTimer), LED_RunTop_BLINK_INTERVAL);
break;
case LED_BLINK_CAMEO:
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_PORNET);
break;
default:
/* RTW_INFO("SwLedCm2Blink(): unexpected state!\n"); */
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL);
break;
}
}
}
void
SwLedBlink5(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
switch (pLed->CurrLedState) {
case RTW_LED_OFF:
SwLedOff(Adapter, pLed);
break;
case LED_BLINK_SLOWLY:
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_NETTRONIX);
break;
case LED_BLINK_NORMAL:
pLed->BlinkTimes--;
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
if (bStopBlinking) {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
SwLedOff(Adapter, pLed);
else {
pLed->bLedSlowBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_SLOWLY;
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_NETTRONIX);
}
pLed->BlinkTimes = 0;
pLed->bLedBlinkInProgress = _FALSE;
} else {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
SwLedOff(Adapter, pLed);
else {
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL_NETTRONIX);
}
}
break;
default:
break;
}
}
void
SwLedBlink6(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
switch (pLed->CurrLedState) {
case RTW_LED_OFF:
SwLedOff(Adapter, pLed);
break;
case LED_BLINK_SLOWLY:
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_PORNET);
break;
case LED_BLINK_NORMAL:
pLed->BlinkTimes--;
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
if (bStopBlinking) {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
SwLedOff(Adapter, pLed);
else {
pLed->bLedSlowBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_SLOWLY;
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_PORNET);
}
pLed->BlinkTimes = 0;
pLed->bLedBlinkInProgress = _FALSE;
} else {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on)
SwLedOff(Adapter, pLed);
else {
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL_PORNET);
}
}
break;
default:
break;
}
}
void
SwLedBlink7(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
SwLedOn(Adapter, pLed);
}
/*
* Description:
* Implement LED blinking behavior for SW_LED_MODE8.
* It toggle off LED and schedule corresponding timer if necessary.
* */
void
SwLedBlink8(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
/* Determine if we shall change LED state again. */
if (pLed->CurrLedState != LED_BLINK_NO_LINK)
pLed->BlinkTimes--;
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_SCAN:
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
break;
default:
break;
}
if (bStopBlinking) {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS) {
pLed->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
} else {
pLed->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed);
}
pLed->BlinkTimes = 0;
pLed->bLedBlinkInProgress = _FALSE;
} else {
/* Assign LED state to toggle. */
if (pLed->BlinkingLedState == RTW_LED_ON)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/* Schedule a timer to toggle LED state. */
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
break;
default:
/* RTW_INFO("SwLedCm8Blink(): unexpected state!\n"); */
break;
}
}
}
void
SwLedBlink9(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
/* Determine if we shall change LED state again. */
if (pLed->CurrLedState != LED_BLINK_NO_LINK)
pLed->BlinkTimes--;
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_SCAN:
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
break;
case LED_BLINK_NO_LINK:
if (check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE))
bStopBlinking = _TRUE;
else if (check_fwstate(pmlmepriv, _FW_LINKED) &&
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
bStopBlinking = _TRUE;
break;
default:
break;
}
if (bStopBlinking) {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS) {
pLed->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
pLed->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed);
} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
pLed->CurrLedState = LED_BLINK_NO_LINK;
if (pLed->bLedOn)
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
else
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
pLed->BlinkTimes = 0;
if (pLed->CurrLedState != LED_BLINK_NO_LINK)
pLed->bLedBlinkInProgress = _FALSE;
} else {
/* Assign LED state to toggle. */
if (pLed->BlinkingLedState == RTW_LED_ON)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/* Schedule a timer to toggle LED state. */
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
_set_timer(&(pLed->BlinkTimer), LED_BLINK_FAST_INTERVAL_BITLAND);
break;
case LED_BLINK_SCAN:
case LED_BLINK_NO_LINK:
if (pLed->bLedOn)
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
else
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
break;
default:
/* RTW_INFO("SwLedCm2Blink(): unexpected state!\n"); */
break;
}
}
}
void
SwLedBlink10(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
/* Determine if we shall change LED state again. */
if (pLed->CurrLedState != LED_BLINK_NO_LINK)
pLed->BlinkTimes--;
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_SCAN:
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
break;
default:
break;
}
if (bStopBlinking) {
pLed->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
pLed->BlinkTimes = 0;
pLed->bLedBlinkInProgress = _FALSE;
} else {
/* Assign LED state to toggle. */
if (pLed->BlinkingLedState == RTW_LED_ON)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/* Schedule a timer to toggle LED state. */
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_SCAN:
_set_timer(&(pLed->BlinkTimer), LED_BLINK_FAST_INTERVAL_BITLAND);
break;
default:
/* RT_ASSERT(_FALSE, ("SwLedCm2Blink(): unexpected state!\n")); */
break;
}
}
}
void
SwLedBlink11(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->bLedBlinkInProgress == _TRUE) {
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
}
/* Determine if we shall change LED state again. */
if (pLed->CurrLedState != LED_BLINK_NO_LINK)
pLed->BlinkTimes--;
switch (pLed->CurrLedState) {
case RTW_LED_ON:
bStopBlinking = _TRUE; /* LED on for 3 seconds */
default:
break;
}
if (bStopBlinking) {
pLed->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
pLed->BlinkTimes = 0;
pLed->bLedBlinkInProgress = _FALSE;
} else {
/* Assign LED state to toggle. */
if (pLed->BlinkingLedState == RTW_LED_ON)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/* Schedule a timer to toggle LED state. */
switch (pLed->CurrLedState) {
case LED_BLINK_XAVI:
_set_timer(&(pLed->BlinkTimer), LED_CM11_BLINK_INTERVAL);
break;
default:
/* RT_ASSERT(_FALSE, ("SwLedCm11Blink(): unexpected state!\n")); */
break;
}
}
}
void
SwLedBlink12(
PLED_PCIE pLed
)
{
PADAPTER Adapter = pLed->padapter;
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
BOOLEAN bStopBlinking = _FALSE;
/* Change LED according to BlinkingLedState specified. */
if (pLed->BlinkingLedState == RTW_LED_ON) {
SwLedOn(Adapter, pLed);
} else {
SwLedOff(Adapter, pLed);
}
/* Determine if we shall change LED state again. */
if (pLed->CurrLedState != LED_BLINK_NO_LINK && pLed->CurrLedState != LED_BLINK_Azurewave_5Mbps
&& pLed->CurrLedState != LED_BLINK_Azurewave_10Mbps && pLed->CurrLedState != LED_BLINK_Azurewave_20Mbps
&& pLed->CurrLedState != LED_BLINK_Azurewave_40Mbps && pLed->CurrLedState != LED_BLINK_Azurewave_80Mbps
&& pLed->CurrLedState != LED_BLINK_Azurewave_MAXMbps)
pLed->BlinkTimes--;
switch (pLed->CurrLedState) {
case LED_BLINK_NORMAL:
case LED_BLINK_SCAN:
if (pLed->BlinkTimes == 0)
bStopBlinking = _TRUE;
break;
case LED_BLINK_NO_LINK:
if (check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE))
bStopBlinking = _TRUE;
else if (check_fwstate(pmlmepriv, _FW_LINKED) &&
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
bStopBlinking = _TRUE;
break;
case LED_BLINK_Azurewave_5Mbps:
case LED_BLINK_Azurewave_10Mbps:
case LED_BLINK_Azurewave_20Mbps:
case LED_BLINK_Azurewave_40Mbps:
case LED_BLINK_Azurewave_80Mbps:
case LED_BLINK_Azurewave_MAXMbps:
/* if(pTurboCa->TxThroughput + pTurboCa->RxThroughput == 0) */
/* bStopBlinking = _TRUE; */
default:
break;
}
if (bStopBlinking) {
if (adapter_to_pwrctl(Adapter)->rf_pwrstate != rf_on && adapter_to_pwrctl(Adapter)->rfoff_reason > RF_CHANGE_BY_PS) {
pLed->CurrLedState = RTW_LED_OFF;
pLed->BlinkingLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
pLed->CurrLedState = RTW_LED_ON;
pLed->BlinkingLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed);
} else if (check_fwstate(pmlmepriv, _FW_LINKED) == _FALSE) {
pLed->CurrLedState = LED_BLINK_NO_LINK;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
}
pLed->BlinkTimes = 0;
if (pLed->CurrLedState != LED_BLINK_NO_LINK)
pLed->bLedBlinkInProgress = _FALSE;
} else {
/* Assign LED state to toggle. */
if (pLed->BlinkingLedState == RTW_LED_ON)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/* Schedule a timer to toggle LED state. */
switch (pLed->CurrLedState) {
case LED_BLINK_Azurewave_5Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_5Mbps);
break;
case LED_BLINK_Azurewave_10Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_10Mbps);
break;
case LED_BLINK_Azurewave_20Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_20Mbps);
break;
case LED_BLINK_Azurewave_40Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_40Mbps);
break;
case LED_BLINK_Azurewave_80Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_80Mbps);
break;
case LED_BLINK_Azurewave_MAXMbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_MAXMbps);
break;
case LED_BLINK_SCAN:
case LED_BLINK_NO_LINK:
if (pLed->bLedOn)
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
else
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
break;
default:
/* RT_ASSERT(_FALSE, ("SwLedCm12Blink(): unexpected state!\n")); */
break;
}
}
}
/*
* Description:
* Handler function of LED Blinking.
* We dispatch acture LED blink action according to LedStrategy.
* */
void BlinkHandler(PLED_PCIE pLed)
{
_adapter *padapter = pLed->padapter;
struct led_priv *ledpriv = adapter_to_led(padapter);
if (RTW_CANNOT_RUN(padapter))
return;
if (IS_HARDWARE_TYPE_8188E(padapter) ||
IS_HARDWARE_TYPE_JAGUAR(padapter) ||
IS_HARDWARE_TYPE_8723B(padapter) ||
IS_HARDWARE_TYPE_8192E(padapter))
return;
switch (ledpriv->LedStrategy) {
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
case SW_LED_MODE_UC_TRX_ONLY:
rtw_sw_led_blink_uc_trx_only(pLed);
break;
#endif
case SW_LED_MODE1:
/* SwLedBlink(pLed); */
break;
case SW_LED_MODE2:
/* SwLedBlink(pLed); */
break;
case SW_LED_MODE3:
/* SwLedBlink(pLed); */
break;
case SW_LED_MODE5:
/* SwLedBlink5(pLed); */
break;
case SW_LED_MODE6:
/* SwLedBlink6(pLed); */
break;
case SW_LED_MODE7:
SwLedBlink7(pLed);
break;
case SW_LED_MODE8:
SwLedBlink8(pLed);
break;
case SW_LED_MODE9:
SwLedBlink9(pLed);
break;
case SW_LED_MODE10:
SwLedBlink10(pLed);
break;
case SW_LED_MODE11:
SwLedBlink11(pLed);
break;
case SW_LED_MODE12:
SwLedBlink12(pLed);
break;
default:
/* SwLedBlink(pLed); */
break;
}
}
/*
* Description:
* Callback function of LED BlinkTimer,
* it just schedules to corresponding BlinkWorkItem/led_blink_hdl
* */
void BlinkTimerCallback(void *data)
{
PLED_PCIE pLed = (PLED_PCIE)data;
_adapter *padapter = pLed->padapter;
/* RTW_INFO("%s\n", __FUNCTION__); */
if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter))) {
/*RTW_INFO("%s bDriverStopped:%s, bSurpriseRemoved:%s\n"
, __func__
, rtw_is_drv_stopped(padapter)?"True":"False"
, rtw_is_surprise_removed(padapter)?"True":"False" );
*/
return;
}
#ifdef CONFIG_RTW_LED_HANDLED_BY_CMD_THREAD
rtw_led_blink_cmd(padapter, pLed);
#else
BlinkHandler(pLed);
#endif
}
/*
* Description:
* Implement each led action for SW_LED_MODE0. */
void
SwLedControlMode0(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
switch (LedAction) {
case LED_CTL_TX:
case LED_CTL_RX:
break;
case LED_CTL_LINK:
pLed0->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed0);
pLed1->CurrLedState = LED_BLINK_NORMAL;
HwLedBlink(Adapter, pLed1);
break;
case LED_CTL_POWER_ON:
pLed0->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed0);
pLed1->CurrLedState = LED_BLINK_NORMAL;
HwLedBlink(Adapter, pLed1);
break;
case LED_CTL_POWER_OFF:
pLed0->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed0);
pLed1->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed1);
break;
case LED_CTL_SITE_SURVEY:
break;
case LED_CTL_NO_LINK:
pLed0->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed0);
pLed1->CurrLedState = LED_BLINK_NORMAL;
HwLedBlink(Adapter, pLed1);
break;
default:
break;
}
}
void
SwLedControlMode1(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
PLED_PCIE pLed = &(ledpriv->SwLed1);
/* Decide led state */
switch (LedAction) {
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed->bLedBlinkInProgress == _FALSE) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_NORMAL;
pLed->BlinkTimes = 2;
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
}
break;
case LED_CTL_SITE_SURVEY:
if (pLed->bLedBlinkInProgress == _FALSE) {
pLed->bLedBlinkInProgress = _TRUE;
if ((check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE)) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))) {
pLed->CurrLedState = LED_BLINK_SCAN;
pLed->BlinkTimes = 4;
} else {
pLed->CurrLedState = LED_BLINK_NO_LINK;
pLed->BlinkTimes = 24;
}
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_OFF_INTERVAL);
}
} else {
if (pLed->CurrLedState != LED_BLINK_NO_LINK) {
if ((check_fwstate(pmlmepriv, _FW_LINKED) && check_fwstate(pmlmepriv, WIFI_STATION_STATE)) ||
(check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) || check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)))
pLed->CurrLedState = LED_BLINK_SCAN;
else
pLed->CurrLedState = LED_BLINK_NO_LINK;
}
}
break;
case LED_CTL_NO_LINK:
if (pLed->bLedBlinkInProgress == _FALSE) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_NO_LINK;
pLed->BlinkTimes = 24;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_OFF_INTERVAL);
}
} else
pLed->CurrLedState = LED_BLINK_NO_LINK;
break;
case LED_CTL_LINK:
pLed->CurrLedState = RTW_LED_ON;
if (pLed->bLedBlinkInProgress == _FALSE)
SwLedOn(Adapter, pLed);
break;
case LED_CTL_POWER_OFF:
pLed->CurrLedState = RTW_LED_OFF;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed);
break;
default:
break;
}
}
void
SwLedControlMode2(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
/* Decide led state */
switch (LedAction) {
case LED_CTL_POWER_ON:
pLed0->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed0);
pLed1->CurrLedState = LED_BLINK_CAMEO;
if (pLed1->bLedBlinkInProgress == _FALSE) {
pLed1->bLedBlinkInProgress = _TRUE;
pLed1->BlinkTimes = 6;
if (pLed1->bLedOn)
pLed1->BlinkingLedState = RTW_LED_OFF;
else
pLed1->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_PORNET);
}
break;
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed0->bLedBlinkInProgress == _FALSE) {
pLed0->bLedBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_TXRX;
pLed0->BlinkTimes = 2;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
}
break;
case LED_CTL_NO_LINK:
pLed1->CurrLedState = LED_BLINK_CAMEO;
if (pLed1->bLedBlinkInProgress == _FALSE) {
pLed1->bLedBlinkInProgress = _TRUE;
pLed1->BlinkTimes = 6;
if (pLed1->bLedOn)
pLed1->BlinkingLedState = RTW_LED_OFF;
else
pLed1->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_PORNET);
}
break;
case LED_CTL_LINK:
pLed1->CurrLedState = RTW_LED_ON;
if (pLed1->bLedBlinkInProgress == _FALSE)
SwLedOn(Adapter, pLed1);
break;
case LED_CTL_POWER_OFF:
pLed0->CurrLedState = RTW_LED_OFF;
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
if (pLed1->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
SwLedOff(Adapter, pLed1);
break;
default:
break;
}
}
void
SwLedControlMode3(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
/* Decide led state */
switch (LedAction) {
case LED_CTL_POWER_ON:
pLed0->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed0);
pLed1->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed1);
break;
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed1->bLedBlinkInProgress == _FALSE) {
pLed1->bLedBlinkInProgress = _TRUE;
pLed1->CurrLedState = LED_BLINK_RUNTOP;
pLed1->BlinkTimes = 2;
if (pLed1->bLedOn)
pLed1->BlinkingLedState = RTW_LED_OFF;
else
pLed1->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed1->BlinkTimer), LED_RunTop_BLINK_INTERVAL);
}
break;
case LED_CTL_POWER_OFF:
pLed0->CurrLedState = RTW_LED_OFF;
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
if (pLed1->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
SwLedOff(Adapter, pLed1);
break;
default:
break;
}
}
void
SwLedControlMode4(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
/* Decide led state */
switch (LedAction) {
case LED_CTL_POWER_ON:
pLed1->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed1);
pLed0->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed0);
break;
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed0->bLedBlinkInProgress == _FALSE) {
pLed0->bLedBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_RUNTOP;
pLed0->BlinkTimes = 2;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_RunTop_BLINK_INTERVAL);
}
break;
case LED_CTL_POWER_OFF:
pLed0->CurrLedState = RTW_LED_OFF;
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
if (pLed1->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
SwLedOff(Adapter, pLed1);
break;
default:
break;
}
}
/* added by vivi, for led new mode */
void
SwLedControlMode5(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
/* Decide led state */
switch (LedAction) {
case LED_CTL_POWER_ON:
case LED_CTL_START_TO_LINK:
case LED_CTL_NO_LINK:
pLed1->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed1);
if (pLed0->bLedSlowBlinkInProgress == _FALSE) {
pLed0->bLedSlowBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_SLOWLY;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_NETTRONIX);
}
break;
case LED_CTL_TX:
case LED_CTL_RX:
pLed1->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed1);
if (pLed0->bLedBlinkInProgress == _FALSE) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedSlowBlinkInProgress = _FALSE;
pLed0->bLedBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_NORMAL;
pLed0->BlinkTimes = 2;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_BLINK_NORMAL_INTERVAL_NETTRONIX);
}
break;
case LED_CTL_LINK:
pLed1->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed1);
if (pLed0->bLedSlowBlinkInProgress == _FALSE) {
pLed0->bLedSlowBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_SLOWLY;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_NETTRONIX);
}
break;
case LED_CTL_POWER_OFF:
pLed0->CurrLedState = RTW_LED_OFF;
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedSlowBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedSlowBlinkInProgress = _FALSE;
}
if (pLed0->bLedBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
SwLedOff(Adapter, pLed1);
break;
default:
break;
}
}
/* added by vivi, for led new mode */
void
SwLedControlMode6(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
switch (LedAction) {
case LED_CTL_POWER_ON:
case LED_CTL_START_TO_LINK:
case LED_CTL_NO_LINK:
case LED_CTL_LINK:
case LED_CTL_SITE_SURVEY:
pLed1->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed1);
if (pLed0->bLedSlowBlinkInProgress == _FALSE) {
pLed0->bLedSlowBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_SLOWLY;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_BLINK_SLOWLY_INTERVAL_PORNET);
}
break;
case LED_CTL_TX:
case LED_CTL_RX:
pLed1->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed1);
if (pLed0->bLedBlinkInProgress == _FALSE) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedSlowBlinkInProgress = _FALSE;
pLed0->bLedBlinkInProgress = _TRUE;
pLed0->CurrLedState = LED_BLINK_NORMAL;
pLed0->BlinkTimes = 2;
if (pLed0->bLedOn)
pLed0->BlinkingLedState = RTW_LED_OFF;
else
pLed0->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed0->BlinkTimer), LED_BLINK_NORMAL_INTERVAL_PORNET);
}
break;
case LED_CTL_POWER_OFF:
pLed1->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed1);
pLed0->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedSlowBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedSlowBlinkInProgress = _FALSE;
}
if (pLed0->bLedBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
break;
default:
break;
}
}
/* added by chiyokolin, for Lenovo */
void
SwLedControlMode7(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
switch (LedAction) {
case LED_CTL_POWER_ON:
case LED_CTL_LINK:
case LED_CTL_NO_LINK:
SwLedOn(Adapter, pLed0);
break;
case LED_CTL_POWER_OFF:
SwLedOff(Adapter, pLed0);
break;
default:
break;
}
}
/* added by chiyokolin, for QMI */
void
SwLedControlMode8(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed = &(ledpriv->SwLed0);
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
/* Decide led state */
switch (LedAction) {
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed->bLedBlinkInProgress == _FALSE && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_NORMAL;
pLed->BlinkTimes = 2;
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
}
break;
case LED_CTL_SITE_SURVEY:
case LED_CTL_POWER_ON:
case LED_CTL_NO_LINK:
case LED_CTL_LINK:
pLed->CurrLedState = RTW_LED_ON;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOn(Adapter, pLed);
break;
case LED_CTL_POWER_OFF:
pLed->CurrLedState = RTW_LED_OFF;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed);
break;
default:
break;
}
}
/* added by chiyokolin, for MSI */
void
SwLedControlMode9(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed = &(ledpriv->SwLed0);
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
/* Decide led state */
switch (LedAction) {
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed->bLedBlinkInProgress == _FALSE && (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_NORMAL;
pLed->BlinkTimes = 2;
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_BLINK_FAST_INTERVAL_BITLAND);
}
break;
case LED_CTL_SITE_SURVEY:
if (pLed->bLedBlinkInProgress == _FALSE) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_SCAN;
pLed->BlinkTimes = 2;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
} else if (pLed->CurrLedState != LED_BLINK_SCAN) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->CurrLedState = LED_BLINK_SCAN;
pLed->BlinkTimes = 2;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
}
break;
case LED_CTL_POWER_ON:
case LED_CTL_NO_LINK:
if (pLed->bLedBlinkInProgress == _FALSE) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_NO_LINK;
pLed->BlinkTimes = 24;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
} else if (pLed->CurrLedState != LED_BLINK_SCAN && pLed->CurrLedState != LED_BLINK_NO_LINK) {
pLed->CurrLedState = LED_BLINK_NO_LINK;
pLed->BlinkTimes = 24;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
}
break;
case LED_CTL_LINK:
pLed->CurrLedState = RTW_LED_ON;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOn(Adapter, pLed);
break;
case LED_CTL_POWER_OFF:
pLed->CurrLedState = RTW_LED_OFF;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed);
break;
default:
break;
}
}
/* added by chiyokolin, for Edimax-ASUS */
void
SwLedControlMode10(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(ledpriv->SwLed0);
PLED_PCIE pLed1 = &(ledpriv->SwLed1);
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
/* Decide led state */
switch (LedAction) {
case LED_CTL_TX:
case LED_CTL_RX:
if (pLed1->bLedBlinkInProgress == _FALSE && pLed1->bLedWPSBlinkInProgress == _FALSE &&
(check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE)) {
pLed1->bLedBlinkInProgress = _TRUE;
pLed1->CurrLedState = LED_BLINK_NORMAL;
pLed1->BlinkTimes = 2;
if (pLed1->bLedOn)
pLed1->BlinkingLedState = RTW_LED_OFF;
else
pLed1->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
}
break;
case LED_CTL_SITE_SURVEY:
if (pLed1->bLedBlinkInProgress == _FALSE && pLed1->bLedWPSBlinkInProgress == _FALSE) {
pLed1->bLedBlinkInProgress = _TRUE;
pLed1->CurrLedState = LED_BLINK_SCAN;
pLed1->BlinkTimes = 12;
if (pLed1->bLedOn) {
pLed1->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
} else {
pLed1->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
}
} else if (pLed1->CurrLedState != LED_BLINK_SCAN && pLed1->bLedWPSBlinkInProgress == _FALSE) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->CurrLedState = LED_BLINK_SCAN;
pLed1->BlinkTimes = 24;
if (pLed1->bLedOn) {
pLed1->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
} else {
pLed1->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed1->BlinkTimer), LED_BLINK_NORMAL_INTERVAL);
}
}
break;
case LED_CTL_START_WPS:
case LED_CTL_START_WPS_BOTTON:
pLed1->CurrLedState = RTW_LED_ON;
if (pLed1->bLedBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
if (pLed1->bLedWPSBlinkInProgress == _FALSE) {
pLed1->bLedWPSBlinkInProgress = _TRUE;
SwLedOn(Adapter, pLed1);
}
break;
case LED_CTL_STOP_WPS:
case LED_CTL_STOP_WPS_FAIL:
case LED_CTL_STOP_WPS_FAIL_OVERLAP:
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
pLed0->CurrLedState = RTW_LED_ON;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOn(Adapter, pLed0);
} else {
pLed0->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
}
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed1->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed1);
pLed1->bLedWPSBlinkInProgress = _FALSE;
break;
case LED_CTL_LINK:
pLed0->CurrLedState = RTW_LED_ON;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOn(Adapter, pLed0);
break;
case LED_CTL_NO_LINK:
if (pLed1->bLedWPSBlinkInProgress == _TRUE) {
SwLedOn(Adapter, pLed1);
break;
}
if (pLed1->CurrLedState == LED_BLINK_SCAN)
break;
pLed0->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed1->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed1);
break;
case LED_CTL_POWER_ON:
case LED_CTL_POWER_OFF:
if (pLed1->bLedWPSBlinkInProgress == _TRUE) {
SwLedOn(Adapter, pLed1);
break;
}
pLed0->CurrLedState = RTW_LED_OFF;
if (pLed0->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed0->BlinkTimer));
pLed0->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed0);
pLed1->CurrLedState = RTW_LED_OFF;
if (pLed1->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed1->BlinkTimer));
pLed1->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed1);
break;
default:
break;
}
}
/* added by hpfan, for Xavi */
void
SwLedControlMode11(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed = &(ledpriv->SwLed0);
/* Decide led state */
switch (LedAction) {
case LED_CTL_START_WPS:
case LED_CTL_START_WPS_BOTTON:
pLed->bLedWPSBlinkInProgress = _TRUE;
if (pLed->bLedBlinkInProgress == _FALSE) {
pLed->bLedBlinkInProgress = _TRUE;
pLed->CurrLedState = LED_BLINK_XAVI;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM11_BLINK_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM11_BLINK_INTERVAL);
}
}
break;
case LED_CTL_STOP_WPS:
case LED_CTL_STOP_WPS_FAIL:
case LED_CTL_STOP_WPS_FAIL_OVERLAP:
pLed->bLedWPSBlinkInProgress = _FALSE;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
pLed->CurrLedState = RTW_LED_OFF;
}
SwLedOff(Adapter, pLed);
break;
case LED_CTL_LINK:
if (pLed->bLedWPSBlinkInProgress)
break;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
pLed->CurrLedState = RTW_LED_ON;
if (!pLed->bLedOn)
SwLedOn(Adapter, pLed);
} else {
pLed->CurrLedState = RTW_LED_ON;
SwLedOn(Adapter, pLed);
}
_set_timer(&(pLed->BlinkTimer), LED_CM11_LINK_ON_INTERVEL);
pLed->BlinkingLedState = RTW_LED_OFF;
break;
case LED_CTL_NO_LINK:
if (pLed->bLedWPSBlinkInProgress)
break;
if (pLed->bLedBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
pLed->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
break;
case LED_CTL_POWER_ON:
case LED_CTL_POWER_OFF:
if (pLed->bLedBlinkInProgress == _TRUE) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
pLed->CurrLedState = RTW_LED_OFF;
SwLedOff(Adapter, pLed);
break;
default:
break;
}
}
/* added by chiyokolin, for Azurewave */
void
SwLedControlMode12(
PADAPTER Adapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed = &(ledpriv->SwLed0);
struct mlme_priv *pmlmepriv = &(Adapter->mlmepriv);
LED_STATE LedState = LED_UNKNOWN;
/* Decide led state */
switch (LedAction) {
case LED_CTL_TX:
case LED_CTL_RX:
if (check_fwstate(pmlmepriv, _FW_LINKED) == _TRUE) {
if (pLed->CurrLedState == LED_BLINK_SCAN)
break;
pLed->BlinkTimes = 0;
if (pLed->bLedOn)
pLed->BlinkingLedState = RTW_LED_OFF;
else
pLed->BlinkingLedState = RTW_LED_ON;
/*if(pTurboCa->TotalThroughput <= 5)
LedState = LED_BLINK_Azurewave_5Mbps;
else if(pTurboCa->TotalThroughput <= 10)
LedState = LED_BLINK_Azurewave_10Mbps;
else if(pTurboCa->TotalThroughput <=20)
LedState = LED_BLINK_Azurewave_20Mbps;
else if(pTurboCa->TotalThroughput <=40)
LedState = LED_BLINK_Azurewave_40Mbps;
else if(pTurboCa->TotalThroughput <=80)
LedState = LED_BLINK_Azurewave_80Mbps;
else*/
LedState = LED_BLINK_Azurewave_MAXMbps;
if (pLed->bLedBlinkInProgress == _FALSE || pLed->CurrLedState != LedState) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->CurrLedState = LedState;
pLed->bLedBlinkInProgress = _TRUE;
switch (LedState) {
case LED_BLINK_Azurewave_5Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_5Mbps);
break;
case LED_BLINK_Azurewave_10Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_10Mbps);
break;
case LED_BLINK_Azurewave_20Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_20Mbps);
break;
case LED_BLINK_Azurewave_40Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_40Mbps);
break;
case LED_BLINK_Azurewave_80Mbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_80Mbps);
break;
case LED_BLINK_Azurewave_MAXMbps:
_set_timer(&(pLed->BlinkTimer), LED_CM12_BLINK_INTERVAL_MAXMbps);
break;
default:
break;
}
}
}
break;
case LED_CTL_SITE_SURVEY:
case LED_CTL_START_WPS:
case LED_CTL_START_WPS_BOTTON:
if (pLed->bLedBlinkInProgress == _FALSE)
pLed->bLedBlinkInProgress = _TRUE;
else if (pLed->CurrLedState != LED_BLINK_SCAN)
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->CurrLedState = LED_BLINK_SCAN;
pLed->BlinkTimes = 2;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
break;
case LED_CTL_LINK:
pLed->CurrLedState = RTW_LED_ON;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOn(Adapter, pLed);
break;
case LED_CTL_NO_LINK:
case LED_CTL_POWER_ON:
if (pLed->CurrLedState == LED_BLINK_SCAN)
break;
pLed->CurrLedState = LED_BLINK_NO_LINK;
pLed->bLedBlinkInProgress = _TRUE;
if (pLed->bLedOn) {
pLed->BlinkingLedState = RTW_LED_OFF;
_set_timer(&(pLed->BlinkTimer), LED_CM2_BLINK_ON_INTERVAL);
} else {
pLed->BlinkingLedState = RTW_LED_ON;
_set_timer(&(pLed->BlinkTimer), LED_CM8_BLINK_OFF_INTERVAL);
}
break;
case LED_CTL_POWER_OFF:
pLed->CurrLedState = RTW_LED_OFF;
if (pLed->bLedBlinkInProgress) {
_cancel_timer_ex(&(pLed->BlinkTimer));
pLed->bLedBlinkInProgress = _FALSE;
}
SwLedOff(Adapter, pLed);
break;
default:
break;
}
}
void
LedControlPCIE(
_adapter *padapter,
LED_CTL_MODE LedAction
)
{
struct led_priv *ledpriv = adapter_to_led(padapter);
#if (MP_DRIVER == 1)
if (padapter->registrypriv.mp_mode == 1)
return;
#endif
if (RTW_CANNOT_RUN(padapter) || (!rtw_is_hw_init_completed(padapter)))
return;
/* if(priv->bInHctTest) */
/* return; */
if ((adapter_to_pwrctl(padapter)->rfoff_reason > RF_CHANGE_BY_PS) &&
(LedAction == LED_CTL_TX ||
LedAction == LED_CTL_RX ||
LedAction == LED_CTL_SITE_SURVEY ||
LedAction == LED_CTL_LINK ||
LedAction == LED_CTL_NO_LINK ||
LedAction == LED_CTL_START_TO_LINK ||
LedAction == LED_CTL_POWER_ON)) {
return;
}
switch (ledpriv->LedStrategy) {
#if CONFIG_RTW_SW_LED_TRX_DA_CLASSIFY
case SW_LED_MODE_UC_TRX_ONLY:
rtw_sw_led_ctl_mode_uc_trx_only(padapter, LedAction);
break;
#endif
case SW_LED_MODE0:
/* SwLedControlMode0(padapter, LedAction); */
break;
case SW_LED_MODE1:
/* SwLedControlMode1(padapter, LedAction); */
break;
case SW_LED_MODE2:
/* SwLedControlMode2(padapter, LedAction); */
break;
case SW_LED_MODE3:
/* SwLedControlMode3(padapter, LedAction); */
break;
case SW_LED_MODE4:
/* SwLedControlMode4(padapter, LedAction); */
break;
case SW_LED_MODE5:
/* SwLedControlMode5(padapter, LedAction); */
break;
case SW_LED_MODE6:
/* SwLedControlMode6(padapter, LedAction); */
break;
case SW_LED_MODE7:
SwLedControlMode7(padapter, LedAction);
break;
case SW_LED_MODE8:
SwLedControlMode8(padapter, LedAction);
break;
case SW_LED_MODE9:
SwLedControlMode9(padapter, LedAction);
break;
case SW_LED_MODE10:
SwLedControlMode10(padapter, LedAction);
break;
case SW_LED_MODE11:
SwLedControlMode11(padapter, LedAction);
break;
case SW_LED_MODE12:
SwLedControlMode12(padapter, LedAction);
break;
default:
break;
}
}
/*-----------------------------------------------------------------------------
* Function: gen_RefreshLedState()
*
* Overview: When we call the function, media status is no link. It must be in SW/HW
* radio off. Or IPS state. If IPS no link we will turn on LED, otherwise, we must turn off.
* After MAC IO reset, we must write LED control 0x2f2 again.
*
* Input: PADAPTER Adapter)
*
* Output: NONE
*
* Return: NONE
*
* Revised History:
* When Who Remark
* 03/27/2009 MHC Create for LED judge only~!!
*
*---------------------------------------------------------------------------*/
void
gen_RefreshLedState(
PADAPTER Adapter)
{
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(Adapter);
struct pwrctrl_priv *pwrctrlpriv = adapter_to_pwrctl(Adapter);
struct led_priv *pledpriv = adapter_to_led(Adapter);
PLED_PCIE pLed0 = &(pledpriv->SwLed0);
RTW_INFO("gen_RefreshLedState:() pwrctrlpriv->rfoff_reason=%x\n", pwrctrlpriv->rfoff_reason);
if (Adapter->bDriverIsGoingToUnload) {
switch (pledpriv->LedStrategy) {
case SW_LED_MODE9:
case SW_LED_MODE10:
rtw_led_control(Adapter, LED_CTL_POWER_OFF);
break;
default:
/* Turn off LED if RF is not ON. */
SwLedOff(Adapter, pLed0);
break;
}
} else if (pwrctrlpriv->rfoff_reason == RF_CHANGE_BY_IPS) {
switch (pledpriv->LedStrategy) {
case SW_LED_MODE7:
SwLedOn(Adapter, pLed0);
break;
case SW_LED_MODE8:
case SW_LED_MODE9:
rtw_led_control(Adapter, LED_CTL_NO_LINK);
break;
default:
SwLedOn(Adapter, pLed0);
break;
}
} else if (pwrctrlpriv->rfoff_reason == RF_CHANGE_BY_INIT) {
switch (pledpriv->LedStrategy) {
case SW_LED_MODE7:
SwLedOn(Adapter, pLed0);
break;
case SW_LED_MODE9:
rtw_led_control(Adapter, LED_CTL_NO_LINK);
break;
default:
SwLedOn(Adapter, pLed0);
break;
}
} else { /* SW/HW radio off */
switch (pledpriv->LedStrategy) {
case SW_LED_MODE9:
rtw_led_control(Adapter, LED_CTL_POWER_OFF);
break;
default:
/* Turn off LED if RF is not ON. */
SwLedOff(Adapter, pLed0);
break;
}
}
}
/*
* Description:
* Reset status of LED_871x object.
* */
void ResetLedStatus(PLED_PCIE pLed)
{
pLed->CurrLedState = RTW_LED_OFF; /* Current LED state. */
pLed->bLedOn = _FALSE; /* true if LED is ON, false if LED is OFF. */
pLed->bLedBlinkInProgress = _FALSE; /* true if it is blinking, false o.w.. */
pLed->bLedWPSBlinkInProgress = _FALSE;
pLed->bLedSlowBlinkInProgress = _FALSE;
pLed->BlinkTimes = 0; /* Number of times to toggle led state for blinking. */
pLed->BlinkingLedState = LED_UNKNOWN; /* Next state for blinking, either RTW_LED_ON or RTW_LED_OFF are. */
}
/*
* Description:
* Initialize an LED_871x object.
* */
void
InitLed(
_adapter *padapter,
PLED_PCIE pLed,
LED_PIN LedPin
)
{
pLed->padapter = padapter;
pLed->LedPin = LedPin;
ResetLedStatus(pLed);
rtw_init_timer(&(pLed->BlinkTimer), padapter, BlinkTimerCallback, pLed);
}
/*
* Description:
* DeInitialize an LED_871x object.
* */
void
DeInitLed(
PLED_PCIE pLed
)
{
_cancel_timer_ex(&(pLed->BlinkTimer));
ResetLedStatus(pLed);
}
#endif
================================================
FILE: hal/phydm/ap_makefile.mk
================================================
_PHYDM_FILES :=\
phydm/phydm.o \
phydm/phydm_dig.o\
phydm/phydm_antdiv.o\
phydm/phydm_soml.o\
phydm/phydm_smt_ant.o\
phydm/phydm_pathdiv.o\
phydm/phydm_rainfo.o\
phydm/phydm_dynamictxpower.o\
phydm/phydm_adaptivity.o\
phydm/phydm_debug.o\
phydm/phydm_interface.o\
phydm/phydm_phystatus.o\
phydm/phydm_hwconfig.o\
phydm/phydm_dfs.o\
phydm/phydm_cfotracking.o\
phydm/phydm_adc_sampling.o\
phydm/phydm_ccx.o\
phydm/phydm_primary_cca.o\
phydm/phydm_cck_pd.o\
phydm/phydm_rssi_monitor.o\
phydm/phydm_auto_dbg.o\
phydm/phydm_math_lib.o\
phydm/phydm_noisemonitor.o\
phydm/phydm_api.o\
phydm/phydm_pow_train.o\
phydm/phydm_lna_sat.o\
phydm/phydm_pmac_tx_setting.o\
phydm/phydm_mp.o\
phydm/txbf/phydm_hal_txbf_api.o\
EdcaTurboCheck.o\
phydm/halrf/halrf.o\
phydm/halrf/halrf_debug.o\
phydm/halrf/halphyrf_ap.o\
phydm/halrf/halrf_powertracking_ap.o\
phydm/halrf/halrf_powertracking.o\
phydm/halrf/halrf_kfree.o
ifeq ($(CONFIG_RTL_88E_SUPPORT),y)
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8188e/halhwimg8188e_bb.o\
phydm/rtl8188e/halhwimg8188e_mac.o\
phydm/rtl8188e/halhwimg8188e_rf.o\
phydm/rtl8188e/phydm_regconfig8188e.o\
phydm/rtl8188e/hal8188erateadaptive.o\
phydm/rtl8188e/phydm_rtl8188e.o\
phydm/halrf/rtl8188e/halrf_8188e_ap.o
endif
endif
ifeq ($(CONFIG_RTL_8812_SUPPORT),y)
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += ./phydm/halrf/rtl8812a/halrf_8812a_ap.o
endif
_PHYDM_FILES += phydm/rtl8812a/phydm_rtl8812a.o
endif
ifeq ($(CONFIG_WLAN_HAL_8881A),y)
_PHYDM_FILES += phydm/halrf/rtl8821a/halrf_iqk_8821a_ap.o
endif
ifeq ($(CONFIG_WLAN_HAL_8192EE),y)
_PHYDM_FILES += \
phydm/halrf/rtl8192e/halrf_8192e_ap.o\
phydm/rtl8192e/phydm_rtl8192e.o
endif
ifeq ($(CONFIG_WLAN_HAL_8814AE),y)
rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_8814a_ap.o
rtl8192cd-objs += phydm/halrf/rtl8814a/halrf_iqk_8814a.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
rtl8192cd-objs += \
phydm/rtl8814a/halhwimg8814a_bb.o\
phydm/rtl8814a/halhwimg8814a_mac.o\
phydm/rtl8814a/halhwimg8814a_rf.o\
phydm/rtl8814a/phydm_regconfig8814a.o\
phydm/rtl8814a/phydm_rtl8814a.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8822BE),y)
_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_8822b.o
_PHYDM_FILES += phydm/halrf/rtl8822b/halrf_iqk_8822b.o
_PHYDM_FILES += phydm/halrf/rtl8822b/halhwimg8822b_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8822b/halhwimg8822b_bb.o\
phydm/rtl8822b/halhwimg8822b_mac.o\
phydm/rtl8822b/phydm_regconfig8822b.o\
phydm/rtl8822b/phydm_hal_api8822b.o\
phydm/rtl8822b/phydm_rtl8822b.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8822CE),y)
_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_8822c.o
_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_iqk_8822c.o
_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_dpk_8822c.o
_PHYDM_FILES += phydm/halrf/rtl8822c/halrf_rfk_init_8822c.o
_PHYDM_FILES += phydm/halrf/rtl8822c/halhwimg8822c_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8822c/halhwimg8822c_bb.o\
phydm/rtl8822c/phydm_regconfig8822c.o\
phydm/rtl8822c/phydm_hal_api8822c.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8812FE),y)
_PHYDM_FILES += phydm/halrf/rtl8812f/halrf_8812f.o
_PHYDM_FILES += phydm/halrf/rtl8812f/halrf_iqk_8812f.o
_PHYDM_FILES += phydm/halrf/rtl8812f/halrf_dpk_8812f.o
_PHYDM_FILES += phydm/halrf/rtl8812f/halrf_tssi_8812f.o
_PHYDM_FILES += phydm/halrf/rtl8812f/halrf_rfk_init_8812f.o
_PHYDM_FILES += phydm/halrf/rtl8812f/halhwimg8812f_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8812f/halhwimg8812f_bb.o\
phydm/rtl8812f/halhwimg8812f_mac.o\
phydm/rtl8812f/phydm_regconfig8812f.o\
phydm/rtl8812f/phydm_hal_api8812f.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8821CE),y)
_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_8821c.o
_PHYDM_FILES += phydm/halrf/rtl8821c/halrf_iqk_8821c.o
_PHYDM_FILES += phydm/halrf/rtl8821c/halhwimg8821c_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8821c/halhwimg8821c_bb.o\
phydm/rtl8821c/halhwimg8821c_mac.o\
phydm/rtl8821c/phydm_regconfig8821c.o\
phydm/rtl8821c/phydm_hal_api8821c.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8197F),y)
_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_8197f.o
_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_iqk_8197f.o
_PHYDM_FILES += phydm/halrf/rtl8197f/halrf_dpk_8197f.o
_PHYDM_FILES += phydm/halrf/rtl8197f/halhwimg8197f_rf.o
_PHYDM_FILES += efuse_97f/efuse.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8197f/halhwimg8197f_bb.o\
phydm/rtl8197f/halhwimg8197f_mac.o\
phydm/rtl8197f/phydm_hal_api8197f.o\
phydm/rtl8197f/phydm_regconfig8197f.o\
phydm/rtl8197f/phydm_rtl8197f.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8192FE),y)
_PHYDM_FILES += phydm/halrf/rtl8192f/halrf_8192f.o
_PHYDM_FILES += phydm/halrf/rtl8192f/halrf_dpk_8192f.o
_PHYDM_FILES += phydm/halrf/rtl8192f/halhwimg8192f_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8192f/halhwimg8192f_bb.o\
phydm/rtl8192f/halhwimg8192f_mac.o\
phydm/rtl8192f/phydm_hal_api8192f.o\
phydm/rtl8192f/phydm_regconfig8192f.o\
phydm/rtl8192f/phydm_rtl8192f.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8198F),y)
_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_8198f.o
_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_iqk_8198f.o
_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_dpk_8198f.o
_PHYDM_FILES += phydm/halrf/rtl8198f/halrf_rfk_init_8198f.o
_PHYDM_FILES += phydm/halrf/rtl8198f/halhwimg8198f_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8198f/phydm_hal_api8198f.o\
phydm/rtl8198f/halhwimg8198f_bb.o\
phydm/rtl8198f/halhwimg8198f_mac.o\
phydm/rtl8198f/phydm_regconfig8198f.o \
phydm/halrf/rtl8198f/halrf_8198f.o
endif
endif
ifeq ($(CONFIG_WLAN_HAL_8814BE),y)
_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_8814b.o
_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_iqk_8814b.o
_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_dpk_8814b.o
_PHYDM_FILES += phydm/halrf/rtl8814b/halrf_rfk_init_8814b.o
_PHYDM_FILES += phydm/halrf/rtl8814b/halhwimg8814b_rf.o
ifeq ($(CONFIG_RTL_ODM_WLAN_DRIVER),y)
_PHYDM_FILES += \
phydm/rtl8814b/phydm_hal_api8814b.o\
phydm/rtl8814b/halhwimg8814b_bb.o\
phydm/rtl8814b/halhwimg8814b_mac.o\
phydm/rtl8814b/phydm_regconfig8814b.o \
phydm/halrf/rtl8814b/halrf_8814b.o
endif
endif
================================================
FILE: hal/phydm/halhwimg.h
================================================
/******************************************************************************
*
* Copyright(c) 2016 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#pragma once
#ifndef __INC_HW_IMG_H
#define __INC_HW_IMG_H
/*@
* 2011/03/15 MH Add for different IC HW image file selection. code size consideration.
* */
#if RT_PLATFORM == PLATFORM_LINUX
#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
/* @For 92C */
#define RTL8192CE_HWIMG_SUPPORT 1
#define RTL8192CE_TEST_HWIMG_SUPPORT 0
#define RTL8192CU_HWIMG_SUPPORT 0
#define RTL8192CU_TEST_HWIMG_SUPPORT 0
/* @For 92D */
#define RTL8192DE_HWIMG_SUPPORT 1
#define RTL8192DE_TEST_HWIMG_SUPPORT 0
#define RTL8192DU_HWIMG_SUPPORT 0
#define RTL8192DU_TEST_HWIMG_SUPPORT 0
/* @For 8723 */
#define RTL8723E_HWIMG_SUPPORT 1
#define RTL8723U_HWIMG_SUPPORT 0
#define RTL8723S_HWIMG_SUPPORT 0
/* @For 88E */
#define RTL8188EE_HWIMG_SUPPORT 0
#define RTL8188EU_HWIMG_SUPPORT 0
#define RTL8188ES_HWIMG_SUPPORT 0
#elif (DEV_BUS_TYPE == RT_USB_INTERFACE)
/* @For 92C */
#define RTL8192CE_HWIMG_SUPPORT 0
#define RTL8192CE_TEST_HWIMG_SUPPORT 0
#define RTL8192CU_HWIMG_SUPPORT 1
#define RTL8192CU_TEST_HWIMG_SUPPORT 0
/* @For 92D */
#define RTL8192DE_HWIMG_SUPPORT 0
#define RTL8192DE_TEST_HWIMG_SUPPORT 0
#define RTL8192DU_HWIMG_SUPPORT 1
#define RTL8192DU_TEST_HWIMG_SUPPORT 0
/* @For 8723 */
#define RTL8723E_HWIMG_SUPPORT 0
#define RTL8723U_HWIMG_SUPPORT 1
#define RTL8723S_HWIMG_SUPPORT 0
/* @For 88E */
#define RTL8188EE_HWIMG_SUPPORT 0
#define RTL8188EU_HWIMG_SUPPORT 0
#define RTL8188ES_HWIMG_SUPPORT 0
#elif (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
/* @For 92C */
#define RTL8192CE_HWIMG_SUPPORT 0
#define RTL8192CE_TEST_HWIMG_SUPPORT 0
#define RTL8192CU_HWIMG_SUPPORT 1
#define RTL8192CU_TEST_HWIMG_SUPPORT 0
/* @For 92D */
#define RTL8192DE_HWIMG_SUPPORT 0
#define RTL8192DE_TEST_HWIMG_SUPPORT 0
#define RTL8192DU_HWIMG_SUPPORT 1
#define RTL8192DU_TEST_HWIMG_SUPPORT 0
/* @For 8723 */
#define RTL8723E_HWIMG_SUPPORT 0
#define RTL8723U_HWIMG_SUPPORT 0
#define RTL8723S_HWIMG_SUPPORT 1
/* @For 88E */
#define RTL8188EE_HWIMG_SUPPORT 0
#define RTL8188EU_HWIMG_SUPPORT 0
#define RTL8188ES_HWIMG_SUPPORT 0
#endif
#else /* PLATFORM_WINDOWS & MacOSX */
/* @For 92C */
#define RTL8192CE_HWIMG_SUPPORT 1
#define RTL8192CE_TEST_HWIMG_SUPPORT 1
#define RTL8192CU_HWIMG_SUPPORT 1
#define RTL8192CU_TEST_HWIMG_SUPPORT 1
/* @For 92D */
#define RTL8192DE_HWIMG_SUPPORT 1
#define RTL8192DE_TEST_HWIMG_SUPPORT 1
#define RTL8192DU_HWIMG_SUPPORT 1
#define RTL8192DU_TEST_HWIMG_SUPPORT 1
#if defined(UNDER_CE)
/* @For 8723 */
#define RTL8723E_HWIMG_SUPPORT 0
#define RTL8723U_HWIMG_SUPPORT 0
#define RTL8723S_HWIMG_SUPPORT 1
/* @For 88E */
#define RTL8188EE_HWIMG_SUPPORT 0
#define RTL8188EU_HWIMG_SUPPORT 0
#define RTL8188ES_HWIMG_SUPPORT 0
#else
/* @For 8723 */
#define RTL8723E_HWIMG_SUPPORT 1
/* @#define RTL_8723E_TEST_HWIMG_SUPPORT 1 */
#define RTL8723U_HWIMG_SUPPORT 1
/* @#define RTL_8723U_TEST_HWIMG_SUPPORT 1 */
#define RTL8723S_HWIMG_SUPPORT 1
/* @#define RTL_8723S_TEST_HWIMG_SUPPORT 1 */
/* @For 88E */
#define RTL8188EE_HWIMG_SUPPORT 1
#define RTL8188EU_HWIMG_SUPPORT 1
#define RTL8188ES_HWIMG_SUPPORT 1
#endif
#endif
#endif /* @__INC_HW_IMG_H */
================================================
FILE: hal/phydm/halrf/halphyrf_ap.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include "mp_precomp.h"
#include "phydm_precomp.h"
#ifndef index_mapping_NUM_88E
#define index_mapping_NUM_88E 15
#endif
/* #if(DM_ODM_SUPPORT_TYPE & ODM_WIN) */
#define CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
do {\
for (_offset = 0; _offset < _size; _offset++) { \
\
if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
\
if (_offset != 0)\
_offset--;\
break;\
} \
} \
if (_offset >= _size)\
_offset = _size-1;\
} while (0)
void odm_clear_txpowertracking_state(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct rtl8192cd_priv *priv = dm->priv;
u8 i;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "===>%s\n", __func__);
for (i = 0; i < MAX_RF_PATH; i++) {
cali_info->absolute_ofdm_swing_idx[i] = 0;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "cali_info->absolute_ofdm_swing_idx[%d]=%d\n",
i, cali_info->absolute_ofdm_swing_idx[i]);
}
dm->rf_calibrate_info.thermal_value = 0;
dm->rf_calibrate_info.thermal_value_lck = 0;
dm->rf_calibrate_info.thermal_value_iqk = 0;
}
void configure_txpower_track(
void *dm_void,
struct txpwrtrack_cfg *config
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if RTL8812A_SUPPORT
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
/* if (IS_HARDWARE_TYPE_8812(dm->adapter)) */
if (dm->support_ic_type == ODM_RTL8812)
configure_txpower_track_8812a(config);
/* else */
#endif
#endif
#if RTL8814A_SUPPORT
if (dm->support_ic_type == ODM_RTL8814A)
configure_txpower_track_8814a(config);
#endif
#if RTL8188E_SUPPORT
if (dm->support_ic_type == ODM_RTL8188E)
configure_txpower_track_8188e(config);
#endif
#if RTL8197F_SUPPORT
if (dm->support_ic_type == ODM_RTL8197F)
configure_txpower_track_8197f(config);
#endif
#if RTL8822B_SUPPORT
if (dm->support_ic_type == ODM_RTL8822B)
configure_txpower_track_8822b(config);
#endif
#if RTL8192F_SUPPORT
if (dm->support_ic_type == ODM_RTL8192F)
configure_txpower_track_8192f(config);
#endif
#if RTL8198F_SUPPORT
if (dm->support_ic_type == ODM_RTL8198F)
configure_txpower_track_8198f(config);
#endif
#if RTL8814B_SUPPORT
if (dm->support_ic_type == ODM_RTL8814B)
configure_txpower_track_8814b(config);
#endif
}
#if (RTL8192E_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_92e(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 thermal_value = 0, delta, delta_IQK, delta_LCK, channel, is_decrease, rf_mimo_mode;
u8 thermal_value_avg_count = 0;
u8 OFDM_min_index = 10; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur */
s8 OFDM_index[2], index ;
u32 thermal_value_avg = 0, reg0x18;
u32 i = 0, j = 0, rf;
s32 value32, CCK_index = 0, ele_A, ele_D, ele_C, X, Y;
struct rtl8192cd_priv *priv = dm->priv;
rf_mimo_mode = dm->rf_type;
/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK,"%s:%d rf_mimo_mode:%d\n", __FUNCTION__, __LINE__, rf_mimo_mode); */
#ifdef MP_TEST
if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
channel = priv->pshare->working_channel;
if (priv->pshare->mp_txpwr_tracking == false)
return;
} else
#endif
{
channel = (priv->pmib->dot11RFEntry.dot11channel);
}
thermal_value = (unsigned char)odm_get_rf_reg(dm, RF_PATH_A, ODM_RF_T_METER_92E, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
switch (rf_mimo_mode) {
case RF_1T1R:
rf = 1;
break;
case RF_2T2R:
rf = 2;
break;
default:
rf = 2;
break;
}
/* Query OFDM path A default setting Bit[31:21] */
ele_D = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
OFDM_index[0] = (unsigned char)i;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "PathA 0xC80[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[0]);
break;
}
}
/* Query OFDM path B default setting */
if (rf_mimo_mode == RF_2T2R) {
ele_D = phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKOFDM_D);
for (i = 0; i < OFDM_TABLE_SIZE_92E; i++) {
if (ele_D == (ofdm_swing_table_92e[i] >> 22)) {
OFDM_index[1] = (unsigned char)i;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "PathB 0xC88[31:22] = 0x%x, OFDM_index=%d\n", ele_D, OFDM_index[1]);
break;
}
}
}
/* calculate average thermal meter */
{
priv->pshare->thermal_value_avg_88xx[priv->pshare->thermal_value_avg_index_88xx] = thermal_value;
priv->pshare->thermal_value_avg_index_88xx++;
if (priv->pshare->thermal_value_avg_index_88xx == AVG_THERMAL_NUM_88XX)
priv->pshare->thermal_value_avg_index_88xx = 0;
for (i = 0; i < AVG_THERMAL_NUM_88XX; i++) {
if (priv->pshare->thermal_value_avg_88xx[i]) {
thermal_value_avg += priv->pshare->thermal_value_avg_88xx[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) {
thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
}
}
/* Initialize */
if (!priv->pshare->thermal_value) {
priv->pshare->thermal_value = priv->pmib->dot11RFEntry.ther;
priv->pshare->thermal_value_iqk = thermal_value;
priv->pshare->thermal_value_lck = thermal_value;
}
if (thermal_value != priv->pshare->thermal_value) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
delta_IQK = RTL_ABS(thermal_value, priv->pshare->thermal_value_iqk);
delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
#ifdef _TRACKING_TABLE_FILE
if (priv->pshare->rf_ft_var.pwr_track_file) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
if (is_decrease) {
for (i = 0; i < rf; i++) {
OFDM_index[i] = priv->pshare->OFDM_index0[i] + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
OFDM_index[i] = ((OFDM_index[i] > (OFDM_TABLE_SIZE_92E- 1)) ? (OFDM_TABLE_SIZE_92E - 1) : OFDM_index[i]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
CCK_index = priv->pshare->CCK_index0 + get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
CCK_index = ((CCK_index > (CCK_TABLE_SIZE_92E - 1)) ? (CCK_TABLE_SIZE_92E - 1) : CCK_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> Decrese power ---> new CCK_INDEX:%d (%d + %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
}
} else {
for (i = 0; i < rf; i++) {
OFDM_index[i] = priv->pshare->OFDM_index0[i] - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0);
OFDM_index[i] = ((OFDM_index[i] < OFDM_min_index) ? OFDM_min_index : OFDM_index[i]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> Increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[i], priv->pshare->OFDM_index0[i], get_tx_tracking_index(priv, channel, i, delta, is_decrease, 0));
CCK_index = priv->pshare->CCK_index0 - get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1);
CCK_index = ((CCK_index < 0) ? 0 : CCK_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> Increse power ---> new CCK_INDEX:%d (%d - %d)\n", CCK_index, priv->pshare->CCK_index0, get_tx_tracking_index(priv, channel, i, delta, is_decrease, 1));
}
}
}
#endif /* CFG_TRACKING_TABLE_FILE */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] = %x\n", ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
/* Adujst OFDM Ant_A according to IQK result */
ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[0]] & 0xFFC00000) >> 22;
X = priv->pshare->rege94;
Y = priv->pshare->rege9c;
if (X != 0) {
if ((X & 0x00000200) != 0)
X = X | 0xFFFFFC00;
ele_A = ((X * ele_D) >> 8) & 0x000003FF;
/* new element C = element D x Y */
if ((Y & 0x00000200) != 0)
Y = Y | 0xFFFFFC00;
ele_C = ((Y * ele_D) >> 8) & 0x000003FF;
/* wirte new elements A, C, D to regC80 and regC94, element B is always 0 */
value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
phy_set_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, value32);
value32 = (ele_C & 0x000003C0) >> 6;
phy_set_bb_reg(priv, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, value32);
value32 = ((X * ele_D) >> 7) & 0x01;
phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), value32);
} else {
phy_set_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_92e[(unsigned int)OFDM_index[0]]);
phy_set_bb_reg(priv, REG_OFDM_0_XC_TX_AFE, MASKH4BITS, 0x00);
phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(24), 0x00);
}
set_CCK_swing_index(priv, CCK_index);
if (rf == 2) {
ele_D = (ofdm_swing_table_92e[(unsigned int)OFDM_index[1]] & 0xFFC00000) >> 22;
X = priv->pshare->regeb4;
Y = priv->pshare->regebc;
if (X != 0) {
if ((X & 0x00000200) != 0) /* consider minus */
X = X | 0xFFFFFC00;
ele_A = ((X * ele_D) >> 8) & 0x000003FF;
/* new element C = element D x Y */
if ((Y & 0x00000200) != 0)
Y = Y | 0xFFFFFC00;
ele_C = ((Y * ele_D) >> 8) & 0x00003FF;
/* wirte new elements A, C, D to regC88 and regC9C, element B is always 0 */
value32 = (ele_D << 22) | ((ele_C & 0x3F) << 16) | ele_A;
phy_set_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, value32);
value32 = (ele_C & 0x000003C0) >> 6;
phy_set_bb_reg(priv, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, value32);
value32 = ((X * ele_D) >> 7) & 0x01;
phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), value32);
} else {
phy_set_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD, ofdm_swing_table_92e[(unsigned int)OFDM_index[1]]);
phy_set_bb_reg(priv, REG_OFDM_0_XD_TX_AFE, MASKH4BITS, 0x00);
phy_set_bb_reg(priv, REG_OFDM_0_ECCA_THRESHOLD, BIT(28), 0x00);
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xc80 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKDWORD));
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xc88 = 0x%x\n", phy_query_bb_reg(priv, REG_OFDM_0_XB_TX_IQ_IMBALANCE, MASKDWORD));
if ((delta_IQK > 3) && (!iqk_info->rfk_forbidden)) {
priv->pshare->thermal_value_iqk = thermal_value;
#ifdef MP_TEST
#endif if (!(*(dm->mp_mode) && (OPMODE & (WIFI_MP_CTX_BACKGROUND | WIFI_MP_CTX_PACKET))))
halrf_iqk_trigger(dm, false);
}
if ((delta_LCK > 8) && (!iqk_info->rfk_forbidden)) {
RTL_W8(0x522, 0xff);
reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
phy_set_rf_reg(priv, RF_PATH_A, 0x18, BIT(15), 1);
delay_ms(1);
phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
phy_set_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, reg0x18);
RTL_W8(0x522, 0x0);
priv->pshare->thermal_value_lck = thermal_value;
}
}
/* update thermal meter value */
priv->pshare->thermal_value = thermal_value;
for (i = 0 ; i < rf ; i++)
priv->pshare->OFDM_index[i] = OFDM_index[i];
priv->pshare->CCK_index = CCK_index;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
}
#endif
#if (RTL8814B_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series4(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
struct _halrf_tssi_data *tssi = &rf->halrf_tssi_data;
struct rtl8192cd_priv *priv = dm->priv;
struct txpwrtrack_cfg c;
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
u8 thermal_value[MAX_RF_PATH] = {0}, delta[MAX_RF_PATH] = {0};
u8 delta_swing_table_idx_tup[DELTA_SWINGIDX_SIZE] = {0};
u8 delta_swing_table_idx_tdown[DELTA_SWINGIDX_SIZE] = {0};
u8 delta_LCK = 0, delta_IQK = 0, i = 0, j = 0, p;
u8 thermal_value_avg_count[MAX_RF_PATH] = {0};
u32 thermal_value_avg[MAX_RF_PATH] = {0};
s8 thermal_value_temp[MAX_RF_PATH] = {0};
u8 *pwrtrk_tab_up_a = NULL;
u8 *pwrtrk_tab_down_a = NULL;
u8 *pwrtrk_tab_up_b = NULL;
u8 *pwrtrk_tab_down_b = NULL;
u8 *pwrtrk_tab_up_c = NULL;
u8 *pwrtrk_tab_down_c = NULL;
u8 *pwrtrk_tab_up_d = NULL;
u8 *pwrtrk_tab_down_d = NULL;
configure_txpower_track(dm, &c);
(*c.get_delta_swing_table)(dm,
(u8 **)&pwrtrk_tab_up_a, (u8 **)&pwrtrk_tab_down_a,
(u8 **)&pwrtrk_tab_up_b, (u8 **)&pwrtrk_tab_down_b);
if (GET_CHIP_VER(priv) == VERSION_8814B) {
(*c.get_delta_swing_table8814only)(dm,
(u8 **)&pwrtrk_tab_up_c, (u8 **)&pwrtrk_tab_down_c,
(u8 **)&pwrtrk_tab_up_d, (u8 **)&pwrtrk_tab_down_d);
}
cali_info->txpowertracking_callback_cnt++;
cali_info->is_txpowertracking_init = true;
/* Initialize */
if (!dm->rf_calibrate_info.thermal_value)
dm->rf_calibrate_info.thermal_value =
priv->pmib->dot11RFEntry.thermal[RF_PATH_A];
if (!dm->rf_calibrate_info.thermal_value_lck)
dm->rf_calibrate_info.thermal_value_lck =
priv->pmib->dot11RFEntry.thermal[RF_PATH_A];
if (!dm->rf_calibrate_info.thermal_value_iqk)
dm->rf_calibrate_info.thermal_value_iqk =
priv->pmib->dot11RFEntry.thermal[RF_PATH_A];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base_path[RF_PATH_A], cali_info->default_ofdm_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->txpowertrack_control=%d\n", cali_info->txpowertrack_control);
for (i = 0; i < c.rf_path_count; i++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"PGthermal[%d]=0x%x(%d)\n", i,
priv->pmib->dot11RFEntry.thermal[i],
priv->pmib->dot11RFEntry.thermal[i]);
if (priv->pmib->dot11RFEntry.thermal[i] == 0xff ||
priv->pmib->dot11RFEntry.thermal[i] == 0x0)
return;
}
for (i = 0; i < c.rf_path_count; i++) {
thermal_value[i] = (u8)odm_get_rf_reg(dm, i, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
thermal_value_temp[i] = (s8)thermal_value[i] + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp[%d](%d) = thermal_value[%d](%d) + power_time_thermal(%d)\n", i, thermal_value_temp[i], i, thermal_value[i], phydm_get_thermal_offset(dm));
if (thermal_value_temp[i] > 63)
thermal_value[i] = 63;
else if (thermal_value_temp[i] < 0)
thermal_value[i] = 0;
else
thermal_value[i] = thermal_value_temp[i];
}
for (j = 0; j < c.rf_path_count; j++) {
cali_info->thermal_value_avg_path[j][cali_info->thermal_value_avg_index_path[j]] = thermal_value[j];
cali_info->thermal_value_avg_index_path[j]++;
if (cali_info->thermal_value_avg_index_path[j] == c.average_thermal_num) /*Average times = c.average_thermal_num*/
cali_info->thermal_value_avg_index_path[j] = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (cali_info->thermal_value_avg_path[j][i]) {
thermal_value_avg[j] += cali_info->thermal_value_avg_path[j][i];
thermal_value_avg_count[j]++;
}
}
if (thermal_value_avg_count[j]) { /* Calculate Average thermal_value after average enough times */
thermal_value[j] = (u8)(thermal_value_avg[j] / thermal_value_avg_count[j]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"PGthermal[%d] = 0x%x(%d), AVG Thermal Meter = 0x%x(%d)\n", j,
priv->pmib->dot11RFEntry.thermal[j],
priv->pmib->dot11RFEntry.thermal[j],
thermal_value[j],
thermal_value[j]);
}
/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
/* "delta" here is used to determine whether thermal value changes or not. */
delta[j] = RTL_ABS(thermal_value[j], priv->pmib->dot11RFEntry.thermal[j]);
delta_LCK = RTL_ABS(thermal_value[RF_PATH_A], dm->rf_calibrate_info.thermal_value_lck);
delta_IQK = RTL_ABS(thermal_value[RF_PATH_A], dm->rf_calibrate_info.thermal_value_iqk);
}
/*4 6. If necessary, do LCK.*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta[%d], delta_LCK, delta_IQK) = (%d, %d, %d)\n", RF_PATH_A, delta[RF_PATH_A], delta_LCK, delta_IQK);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta[%d], delta_LCK, delta_IQK) = (%d, %d, %d)\n", RF_PATH_B, delta[RF_PATH_B], delta_LCK, delta_IQK);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta[%d], delta_LCK, delta_IQK) = (%d, %d, %d)\n", RF_PATH_C, delta[RF_PATH_C], delta_LCK, delta_IQK);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta[%d], delta_LCK, delta_IQK) = (%d, %d, %d)\n", RF_PATH_D, delta[RF_PATH_D], delta_LCK, delta_IQK);
/* Wait sacn to do LCK by RF Jenyu*/
if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
/* Delta temperature is equal to or larger than 20 centigrade.*/
if (delta_LCK >= c.threshold_iqk) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
cali_info->thermal_value_lck = thermal_value[RF_PATH_A];
/*Use RTLCK, so close power tracking driver LCK*/
if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
} else
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do not do LCK\n");
}
}
/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
#ifdef _TRACKING_TABLE_FILE
for (i = 0; i < c.rf_path_count; i++) {
if (i == RF_PATH_B) {
odm_move_memory(dm, delta_swing_table_idx_tup, pwrtrk_tab_up_b, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, pwrtrk_tab_down_b, DELTA_SWINGIDX_SIZE);
} else if (i == RF_PATH_C) {
odm_move_memory(dm, delta_swing_table_idx_tup, pwrtrk_tab_up_c, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, pwrtrk_tab_down_c, DELTA_SWINGIDX_SIZE);
} else if (i == RF_PATH_D) {
odm_move_memory(dm, delta_swing_table_idx_tup, pwrtrk_tab_up_d, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, pwrtrk_tab_down_d, DELTA_SWINGIDX_SIZE);
} else {
odm_move_memory(dm, delta_swing_table_idx_tup, pwrtrk_tab_up_a, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, pwrtrk_tab_down_a, DELTA_SWINGIDX_SIZE);
}
cali_info->delta_power_index_last_path[i] = cali_info->delta_power_index_path[i]; /*recording poer index offset*/
delta[i] = thermal_value[i] > priv->pmib->dot11RFEntry.thermal[i] ? (thermal_value[i] - priv->pmib->dot11RFEntry.thermal[i]) : (priv->pmib->dot11RFEntry.thermal[i] - thermal_value[i]);
if (delta[i] >= TXPWR_TRACK_TABLE_SIZE)
delta[i] = TXPWR_TRACK_TABLE_SIZE - 1;
if (thermal_value[i] > priv->pmib->dot11RFEntry.thermal[i]) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup[%d]=%d Path=%d\n", delta[i], delta_swing_table_idx_tup[delta[i]], i);
cali_info->delta_power_index_path[i] = delta_swing_table_idx_tup[delta[i]];
cali_info->absolute_ofdm_swing_idx[i] = delta_swing_table_idx_tup[delta[i]]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[%d]=%d Path=%d\n", delta[i], cali_info->absolute_ofdm_swing_idx[i], i);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown[%d]=%d Path=%d\n", delta[i], delta_swing_table_idx_tdown[delta[i]], i);
cali_info->delta_power_index_path[i] = -1 * delta_swing_table_idx_tdown[delta[i]];
cali_info->absolute_ofdm_swing_idx[i] = -1 * delta_swing_table_idx_tdown[delta[i]]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[%d]=%d Path=%d\n", delta[i], cali_info->absolute_ofdm_swing_idx[i], i);
}
}
#endif
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
if (cali_info->delta_power_index_path[p] == cali_info->delta_power_index_last_path[p]) /*If Thermal value changes but lookup table value still the same*/
cali_info->power_index_offset_path[p] = 0;
else
cali_info->power_index_offset_path[p] = cali_info->delta_power_index_path[p] - cali_info->delta_power_index_last_path[p]; /*Power index diff between 2 times Power Tracking*/
}
if ((cali_info->power_index_offset_path[RF_PATH_A] != 0 ||
cali_info->power_index_offset_path[RF_PATH_B] != 0 ||
cali_info->power_index_offset_path[RF_PATH_C] != 0 ||
cali_info->power_index_offset_path[RF_PATH_D] != 0)) {
if (dm->support_ic_type == ODM_RTL8814B) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
}
} else
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "TXAGC offset is unchanged\n");
/* Wait sacn to do IQK by RF Jenyu*/
if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
if (delta_IQK >= c.threshold_iqk) {
cali_info->thermal_value_iqk = thermal_value[RF_PATH_A];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
if (!cali_info->is_iqk_in_progress)
(*c.do_iqk)(dm, delta_IQK, thermal_value[RF_PATH_A], 8);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do IQK\n");
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===%s\n", __func__);
cali_info->tx_powercount = 0;
}
#endif
#if (RTL8197F_SUPPORT == 1 || RTL8192F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series3(
void *dm_void
)
{
#if 1
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
u8 thermal_value_avg_count = 0, p = 0, i = 0;
u32 thermal_value_avg = 0;
struct rtl8192cd_priv *priv = dm->priv;
struct txpwrtrack_cfg c;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
/*The following tables decide the final index of OFDM/CCK swing table.*/
u8 *pwrtrk_tab_up_a = NULL, *pwrtrk_tab_down_a = NULL;
u8 *pwrtrk_tab_up_b = NULL, *pwrtrk_tab_down_b = NULL;
u8 *pwrtrk_tab_up_cck_a = NULL, *pwrtrk_tab_down_cck_a = NULL;
u8 *pwrtrk_tab_up_cck_b = NULL, *pwrtrk_tab_down_cck_b = NULL;
/*for 8814 add by Yu Chen*/
u8 *pwrtrk_tab_up_c = NULL, *pwrtrk_tab_down_c = NULL;
u8 *pwrtrk_tab_up_d = NULL, *pwrtrk_tab_down_d = NULL;
u8 *pwrtrk_tab_up_cck_c = NULL, *pwrtrk_tab_down_cck_c = NULL;
u8 *pwrtrk_tab_up_cck_d = NULL, *pwrtrk_tab_down_cck_d = NULL;
s8 thermal_value_temp = 0;
#ifdef MP_TEST
if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
channel = priv->pshare->working_channel;
if (priv->pshare->mp_txpwr_tracking == false)
return;
} else
#endif
{
channel = (priv->pmib->dot11RFEntry.dot11channel);
}
configure_txpower_track(dm, &c);
(*c.get_delta_all_swing_table)(dm,
(u8 **)&pwrtrk_tab_up_a, (u8 **)&pwrtrk_tab_down_a,
(u8 **)&pwrtrk_tab_up_b, (u8 **)&pwrtrk_tab_down_b,
(u8 **)&pwrtrk_tab_up_cck_a, (u8 **)&pwrtrk_tab_down_cck_a,
(u8 **)&pwrtrk_tab_up_cck_b, (u8 **)&pwrtrk_tab_down_cck_b);
if (GET_CHIP_VER(priv) == VERSION_8198F) {
(*c.get_delta_all_swing_table_ex)(dm,
(u8 **)&pwrtrk_tab_up_c, (u8 **)&pwrtrk_tab_down_c,
(u8 **)&pwrtrk_tab_up_d, (u8 **)&pwrtrk_tab_down_d,
(u8 **)&pwrtrk_tab_up_cck_c, (u8 **)&pwrtrk_tab_down_cck_c,
(u8 **)&pwrtrk_tab_up_cck_d, (u8 **)&pwrtrk_tab_down_cck_d);
}
/*0x42: RF Reg[15:10] 88E*/
thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);
#ifdef THER_TRIM
if (GET_CHIP_VER(priv) == VERSION_8197F) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"orig thermal_value=%d, ther_trim_val=%d\n", thermal_value, priv->pshare->rf_ft_var.ther_trim_val);
thermal_value += priv->pshare->rf_ft_var.ther_trim_val;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"after thermal trim, thermal_value=%d\n", thermal_value);
}
if (GET_CHIP_VER(priv) == VERSION_8198F) {
thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp(%d) = ther_value(%d) + ther_trim_ther(%d)\n",
thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
if (thermal_value_temp > 63)
thermal_value = 63;
else if (thermal_value_temp < 0)
thermal_value = 0;
else
thermal_value = thermal_value_temp;
}
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\n\n\nCurrent Thermal = 0x%x(%d) EEPROMthermalmeter 0x%x(%d)\n"
, thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
/* Initialize */
if (!dm->rf_calibrate_info.thermal_value)
dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
if (!dm->rf_calibrate_info.thermal_value_lck)
dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
if (!dm->rf_calibrate_info.thermal_value_iqk)
dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
/* calculate average thermal meter */
dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
dm->rf_calibrate_info.thermal_value_avg_index++;
if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num) /*Average times = c.average_thermal_num*/
dm->rf_calibrate_info.thermal_value_avg_index = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (dm->rf_calibrate_info.thermal_value_avg[i]) {
thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) {/*Calculate Average thermal_value after average enough times*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"thermal_value_avg=0x%x(%d) thermal_value_avg_count = %d\n"
, thermal_value_avg, thermal_value_avg, thermal_value_avg_count);
thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X(%d), EEPROMthermalmeter = 0x%X(%d)\n", thermal_value, thermal_value, priv->pmib->dot11RFEntry.ther, priv->pmib->dot11RFEntry.ther);
}
/*4 Calculate delta, delta_LCK, delta_IQK.*/
delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
if (delta > 29) { /* power track table index(thermal diff.) upper bound*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta(%d) > 29, set delta to 29\n", delta);
delta = 29;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
/*4 if necessary, do LCK.*/
if ((delta_LCK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
dm->rf_calibrate_info.thermal_value_lck = thermal_value;
#if (RTL8822B_SUPPORT != 1)
if (!(dm->support_ic_type & ODM_RTL8822B)) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
}
#endif
}
if (!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
return;
/*4 Do Power Tracking*/
if (thermal_value != dm->rf_calibrate_info.thermal_value) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******** START POWER TRACKING ********\n");
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"Readback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n",
thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
#ifdef _TRACKING_TABLE_FILE
if (priv->pshare->rf_ft_var.pwr_track_file) {
if (is_increase) { /*thermal is higher than base*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_b[%d] = %d pwrtrk_tab_up_cck_b[%d] = %d\n", delta, pwrtrk_tab_up_b[delta], delta, pwrtrk_tab_up_cck_b[delta]);
cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_b[delta];
cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_b[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_c[%d] = %d pwrtrk_tab_up_cck_c[%d] = %d\n", delta, pwrtrk_tab_up_c[delta], delta, pwrtrk_tab_up_cck_c[delta]);
cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_c[delta];
cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_c[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_d[%d] = %d pwrtrk_tab_up_cck_d[%d] = %d\n", delta, pwrtrk_tab_up_d[delta], delta, pwrtrk_tab_up_cck_d[delta]);
cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_d[delta];
cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_d[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_up_a[%d] = %d pwrtrk_tab_up_cck_a[%d] = %d\n", delta, pwrtrk_tab_up_a[delta], delta, pwrtrk_tab_up_cck_a[delta]);
cali_info->absolute_ofdm_swing_idx[p] = pwrtrk_tab_up_a[delta];
cali_info->absolute_cck_swing_idx[p] = pwrtrk_tab_up_cck_a[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
}
}
} else { /* thermal is lower than base*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_b[%d] = %d pwrtrk_tab_down_cck_b[%d] = %d\n", delta, pwrtrk_tab_down_b[delta], delta, pwrtrk_tab_down_cck_b[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_b[delta];
cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_b[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_B] = %d pRF->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_c[%d] = %d pwrtrk_tab_down_cck_c[%d] = %d\n", delta, pwrtrk_tab_down_c[delta], delta, pwrtrk_tab_down_cck_c[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_c[delta];
cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_c[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_C] = %d pRF->absolute_cck_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_d[%d] = %d pwrtrk_tab_down_cck_d[%d] = %d\n", delta, pwrtrk_tab_down_d[delta], delta, pwrtrk_tab_down_cck_d[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_d[delta];
cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_d[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_D] = %d pRF->absolute_cck_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"pwrtrk_tab_down_a[%d] = %d pwrtrk_tab_down_cck_a[%d] = %d\n", delta, pwrtrk_tab_down_a[delta], delta, pwrtrk_tab_down_cck_a[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * pwrtrk_tab_down_a[delta];
cali_info->absolute_cck_swing_idx[p] = -1 * pwrtrk_tab_down_cck_a[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and pRF->absolute_ofdm_swing_idx[RF_PATH_A] = %d pRF->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p], cali_info->absolute_cck_swing_idx[p]);
break;
}
}
}
if (is_increase) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> increse power --->\n");
if (GET_CHIP_VER(priv) == VERSION_8197F) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
//} else if (GET_CHIP_VER(priv) == VERSION_8192F) {
// for (p = RF_PATH_A; p < c.rf_path_count; p++)
// (*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (GET_CHIP_VER(priv) == VERSION_8198F) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
}
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power --->\n");
if (GET_CHIP_VER(priv) == VERSION_8197F) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
//} else if (GET_CHIP_VER(priv) == VERSION_8192F) {
// for (p = RF_PATH_A; p < c.rf_path_count; p++)
// (*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (GET_CHIP_VER(priv) == VERSION_8822B) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (GET_CHIP_VER(priv) == VERSION_8821C) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (GET_CHIP_VER(priv) == VERSION_8198F) {
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
}
}
}
#endif
if (GET_CHIP_VER(priv) != VERSION_8198F) {
if ((delta_IQK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
if (!(dm->support_ic_type & ODM_RTL8197F)) {
if (c.do_iqk)
(*c.do_iqk)(dm, false, thermal_value, 0);
}
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n\n", __func__);
/*update thermal meter value*/
dm->rf_calibrate_info.thermal_value = thermal_value;
}
#endif
}
#endif
/*#if (RTL8814A_SUPPORT == 1)*/
#if (RTL8814A_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series2(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 thermal_value = 0, delta, delta_LCK, delta_IQK, channel, is_increase;
u8 thermal_value_avg_count = 0, p = 0, i = 0;
u32 thermal_value_avg = 0, reg0x18;
u32 bb_swing_reg[4] = {REG_A_TX_SCALE_JAGUAR, REG_B_TX_SCALE_JAGUAR, REG_C_TX_SCALE_JAGUAR2, REG_D_TX_SCALE_JAGUAR2};
s32 ele_D;
u32 bb_swing_idx;
struct rtl8192cd_priv *priv = dm->priv;
struct txpwrtrack_cfg c;
boolean is_tssi_enable = false;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
u8 *delta_swing_table_idx_tup_a = NULL, *delta_swing_table_idx_tdown_a = NULL;
u8 *delta_swing_table_idx_tup_b = NULL, *delta_swing_table_idx_tdown_b = NULL;
/* for 8814 add by Yu Chen */
u8 *delta_swing_table_idx_tup_c = NULL, *delta_swing_table_idx_tdown_c = NULL;
u8 *delta_swing_table_idx_tup_d = NULL, *delta_swing_table_idx_tdown_d = NULL;
#ifdef MP_TEST
if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
channel = priv->pshare->working_channel;
if (priv->pshare->mp_txpwr_tracking == false)
return;
} else
#endif
{
channel = (priv->pmib->dot11RFEntry.dot11channel);
}
configure_txpower_track(dm, &c);
cali_info->default_ofdm_index = priv->pshare->OFDM_index0[RF_PATH_A];
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
if (dm->support_ic_type & ODM_RTL8814A) /* for 8814 path C & D */
(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x, pre thermal meter 0x%x, EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
/* Initialize */
if (!dm->rf_calibrate_info.thermal_value)
dm->rf_calibrate_info.thermal_value = priv->pmib->dot11RFEntry.ther;
if (!dm->rf_calibrate_info.thermal_value_lck)
dm->rf_calibrate_info.thermal_value_lck = priv->pmib->dot11RFEntry.ther;
if (!dm->rf_calibrate_info.thermal_value_iqk)
dm->rf_calibrate_info.thermal_value_iqk = priv->pmib->dot11RFEntry.ther;
is_tssi_enable = (boolean)odm_get_rf_reg(dm, RF_PATH_A, REG_RF_TX_GAIN_OFFSET, BIT(7)); /* check TSSI enable */
/* 4 Query OFDM BB swing default setting Bit[31:21] */
for (p = RF_PATH_A ; p < c.rf_path_count ; p++) {
ele_D = odm_get_bb_reg(dm, bb_swing_reg[p], 0xffe00000);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[p], odm_get_bb_reg(dm, bb_swing_reg[p], MASKDWORD), ele_D);
for (bb_swing_idx = 0; bb_swing_idx < TXSCALE_TABLE_SIZE; bb_swing_idx++) {/* 4 */
if (ele_D == tx_scaling_table_jaguar[bb_swing_idx]) {
dm->rf_calibrate_info.OFDM_index[p] = (u8)bb_swing_idx;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"OFDM_index[%d]=%d\n", p, dm->rf_calibrate_info.OFDM_index[p]);
break;
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "kfree_offset[%d]=%d\n", p, cali_info->kfree_offset[p]);
}
/* calculate average thermal meter */
dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
dm->rf_calibrate_info.thermal_value_avg_index++;
if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num) /* Average times = c.average_thermal_num */
dm->rf_calibrate_info.thermal_value_avg_index = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (dm->rf_calibrate_info.thermal_value_avg[i]) {
thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) { /* Calculate Average thermal_value after average enough times */
thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"AVG Thermal Meter = 0x%X, EEPROMthermalmeter = 0x%X\n", thermal_value, priv->pmib->dot11RFEntry.ther);
}
/* 4 Calculate delta, delta_LCK, delta_IQK. */
delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
delta_LCK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_lck);
delta_IQK = RTL_ABS(thermal_value, dm->rf_calibrate_info.thermal_value_iqk);
is_increase = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 0 : 1);
/* 4 if necessary, do LCK. */
if (!(dm->support_ic_type & ODM_RTL8821)) {
if ((delta_LCK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
dm->rf_calibrate_info.thermal_value_lck = thermal_value;
/*Use RTLCK, so close power tracking driver LCK*/
#if (RTL8814A_SUPPORT != 1)
if (!(dm->support_ic_type & ODM_RTL8814A)) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
}
#endif
}
}
if ((delta_IQK > c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
panic_printk("%s(%d)\n", __FUNCTION__, __LINE__);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
if (c.do_iqk)
(*c.do_iqk)(dm, true, 0, 0);
}
if (!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
return;
/* 4 Do Power Tracking */
if (is_tssi_enable == true) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter PURE TSSI MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
} else if (thermal_value != dm->rf_calibrate_info.thermal_value) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\n******** START POWER TRACKING ********\n");
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, dm->rf_calibrate_info.thermal_value, priv->pmib->dot11RFEntry.ther);
#ifdef _TRACKING_TABLE_FILE
if (priv->pshare->rf_ft_var.pwr_track_file) {
if (is_increase) { /* thermal is higher than base */
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is higher and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
} else { /* thermal is lower than base */
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta]; /* Record delta swing for mix mode power tracking */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"******Temp is lower and dm->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
}
if (is_increase) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> increse power --->\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power --->\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
}
}
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
/* update thermal meter value */
dm->rf_calibrate_info.thermal_value = thermal_value;
}
}
#endif
#if (RTL8812A_SUPPORT == 1 || RTL8881A_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
unsigned char thermal_value = 0, delta, delta_LCK, channel, is_decrease;
unsigned char thermal_value_avg_count = 0;
unsigned int thermal_value_avg = 0, reg0x18;
unsigned int bb_swing_reg[4] = {0xc1c, 0xe1c, 0x181c, 0x1a1c};
int ele_D, value32;
char OFDM_index[2], index;
unsigned int i = 0, j = 0, rf_path, max_rf_path = 2, rf;
struct rtl8192cd_priv *priv = dm->priv;
unsigned char OFDM_min_index = 7; /* OFDM BB Swing should be less than +2.5dB, which is required by Arthur and Mimic */
struct dm_iqk_info *iqk_info = &dm->IQK_info;
#ifdef MP_TEST
if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
channel = priv->pshare->working_channel;
if (priv->pshare->mp_txpwr_tracking == false)
return;
} else
#endif
{
channel = (priv->pmib->dot11RFEntry.dot11channel);
}
#if RTL8881A_SUPPORT
if (dm->support_ic_type == ODM_RTL8881A) {
max_rf_path = 1;
if ((get_bonding_type_8881A() == BOND_8881AM || get_bonding_type_8881A() == BOND_8881AN)
&& priv->pshare->rf_ft_var.use_intpa8881A && (*dm->band_type == ODM_BAND_2_4G))
OFDM_min_index = 6; /* intPA - upper bond set to +3 dB (base: -2 dB)ot11RFEntry.phy_band_select == PHY_BAND_2G)) */
else
OFDM_min_index = 10; /* OFDM BB Swing should be less than +1dB, which is required by Arthur and Mimic */
}
#endif
thermal_value = (unsigned char)phy_query_rf_reg(priv, RF_PATH_A, 0x42, 0xfc00, 1); /* 0x42: RF Reg[15:10] 88E */
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
/* 4 Query OFDM BB swing default setting Bit[31:21] */
for (rf_path = 0 ; rf_path < max_rf_path ; rf_path++) {
ele_D = phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0x%x:0x%x ([31:21] = 0x%x)\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], MASKDWORD), ele_D);
for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
if (ele_D == ofdm_swing_table_8812[i]) {
OFDM_index[rf_path] = (unsigned char)i;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "OFDM_index[%d]=%d\n", rf_path, OFDM_index[rf_path]);
break;
}
}
}
#if 0
/* Query OFDM path A default setting Bit[31:21] */
ele_D = phy_query_bb_reg(priv, 0xc1c, 0xffe00000);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xc1c:0x%x ([31:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xc1c, MASKDWORD), ele_D);
for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {/* 4 */
if (ele_D == ofdm_swing_table_8812[i]) {
OFDM_index[0] = (unsigned char)i;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "OFDM_index[0]=%d\n", OFDM_index[0]);
break;
}
}
/* Query OFDM path B default setting */
if (rf == 2) {
ele_D = phy_query_bb_reg(priv, 0xe1c, 0xffe00000);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "0xe1c:0x%x ([32:21] = 0x%x)\n", phy_query_bb_reg(priv, 0xe1c, MASKDWORD), ele_D);
for (i = 0; i < OFDM_TABLE_SIZE_8812; i++) {
if (ele_D == ofdm_swing_table_8812[i]) {
OFDM_index[1] = (unsigned char)i;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "OFDM_index[1]=%d\n", OFDM_index[1]);
break;
}
}
}
#endif
/* Initialize */
if (!priv->pshare->thermal_value) {
priv->pshare->thermal_value = priv->pmib->dot11RFEntry.ther;
priv->pshare->thermal_value_lck = thermal_value;
}
/* calculate average thermal meter */
{
priv->pshare->thermal_value_avg_8812[priv->pshare->thermal_value_avg_index_8812] = thermal_value;
priv->pshare->thermal_value_avg_index_8812++;
if (priv->pshare->thermal_value_avg_index_8812 == AVG_THERMAL_NUM_8812)
priv->pshare->thermal_value_avg_index_8812 = 0;
for (i = 0; i < AVG_THERMAL_NUM_8812; i++) {
if (priv->pshare->thermal_value_avg_8812[i]) {
thermal_value_avg += priv->pshare->thermal_value_avg_8812[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) {
thermal_value = (unsigned char)(thermal_value_avg / thermal_value_avg_count);
/* printk("AVG Thermal Meter = 0x%x\n", thermal_value); */
}
}
/* 4 If necessary, do power tracking */
if (!priv->pmib->dot11RFEntry.ther) /*Don't do power tracking since no calibrated thermal value*/
return;
if (thermal_value != priv->pshare->thermal_value) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** START POWER TRACKING ********\n");
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\nReadback Thermal Meter = 0x%x pre thermal meter 0x%x EEPROMthermalmeter 0x%x\n", thermal_value, priv->pshare->thermal_value, priv->pmib->dot11RFEntry.ther);
delta = RTL_ABS(thermal_value, priv->pmib->dot11RFEntry.ther);
delta_LCK = RTL_ABS(thermal_value, priv->pshare->thermal_value_lck);
is_decrease = ((thermal_value < priv->pmib->dot11RFEntry.ther) ? 1 : 0);
/* if (*dm->band_type == ODM_BAND_5G) */
{
#ifdef _TRACKING_TABLE_FILE
if (priv->pshare->rf_ft_var.pwr_track_file) {
for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "diff: (%s)%d ==> get index from table : %d)\n", (is_decrease ? "-" : "+"), delta, get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
if (is_decrease) {
OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] + get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
OFDM_index[rf_path] = ((OFDM_index[rf_path] > (OFDM_TABLE_SIZE_8812 - 1)) ? (OFDM_TABLE_SIZE_8812 - 1) : OFDM_index[rf_path]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> decrese power ---> new OFDM_INDEX:%d (%d + %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
#if 0/* RTL8881A_SUPPORT */
if (dm->support_ic_type == ODM_RTL8881A) {
if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
if (priv->pshare->add_tx_agc) { /* tx_agc has been added */
add_tx_power88xx_ac(priv, 0);
priv->pshare->add_tx_agc = 0;
priv->pshare->add_tx_agc_index = 0;
}
}
}
#endif
} else {
OFDM_index[rf_path] = priv->pshare->OFDM_index0[rf_path] - get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0);
#if 0/* RTL8881A_SUPPORT */
if (dm->support_ic_type == ODM_RTL8881A) {
if (priv->pshare->rf_ft_var.pwrtrk_tx_agc_enable) {
if (OFDM_index[i] < OFDM_min_index) {
priv->pshare->add_tx_agc_index = (OFDM_min_index - OFDM_index[i]) / 2; /* Calculate Remnant tx_agc value, 2 index for 1 tx_agc */
add_tx_power88xx_ac(priv, priv->pshare->add_tx_agc_index);
priv->pshare->add_tx_agc = 1; /* add_tx_agc Flag = 1 */
OFDM_index[i] = OFDM_min_index;
} else {
if (priv->pshare->add_tx_agc) { /* tx_agc been added */
priv->pshare->add_tx_agc = 0;
priv->pshare->add_tx_agc_index = 0;
add_tx_power88xx_ac(priv, 0); /* minus the added TPI */
}
}
}
}
#else
OFDM_index[rf_path] = ((OFDM_index[rf_path] < OFDM_min_index) ? OFDM_min_index : OFDM_index[rf_path]);
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, ">>> increse power ---> new OFDM_INDEX:%d (%d - %d)\n", OFDM_index[rf_path], priv->pshare->OFDM_index0[rf_path], get_tx_tracking_index(priv, channel, rf_path, delta, is_decrease, 0));
}
}
}
#endif
/* 4 Set new BB swing index */
for (rf_path = 0; rf_path < max_rf_path; rf_path++) {
phy_set_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000, ofdm_swing_table_8812[(unsigned int)OFDM_index[rf_path]]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Readback 0x%x[31:21] = 0x%x, OFDM_index:%d\n", bb_swing_reg[rf_path], phy_query_bb_reg(priv, bb_swing_reg[rf_path], 0xffe00000), OFDM_index[rf_path]);
}
}
if ((delta_LCK > 8) && (!iqk_info->rfk_forbidden)) {
RTL_W8(0x522, 0xff);
reg0x18 = phy_query_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, 1);
phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 1);
phy_set_rf_reg(priv, RF_PATH_A, 0x18, BIT(15), 1);
delay_ms(200); /* frequency deviation */
phy_set_rf_reg(priv, RF_PATH_A, 0xB4, BIT(14), 0);
phy_set_rf_reg(priv, RF_PATH_A, 0x18, MASK20BITS, reg0x18);
#ifdef CONFIG_RTL_8812_SUPPORT
if (GET_CHIP_VER(priv) == VERSION_8812E)
update_bbrf_val8812(priv, priv->pmib->dot11RFEntry.dot11channel);
#endif
RTL_W8(0x522, 0x0);
priv->pshare->thermal_value_lck = thermal_value;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "\n******** END:%s() ********\n", __FUNCTION__);
/* update thermal meter value */
priv->pshare->thermal_value = thermal_value;
for (rf_path = 0; rf_path < max_rf_path; rf_path++)
priv->pshare->OFDM_index[rf_path] = OFDM_index[rf_path];
}
}
#endif
void
odm_txpowertracking_callback_thermal_meter(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
#if (RTL8814B_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8814B) {
odm_txpowertracking_callback_thermal_meter_jaguar_series4(dm);
}
#endif
#if (RTL8197F_SUPPORT == 1 ||RTL8192F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8197F || dm->support_ic_type == ODM_RTL8192F || dm->support_ic_type == ODM_RTL8822B
|| dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8198F) {
odm_txpowertracking_callback_thermal_meter_jaguar_series3(dm);
return;
}
#endif
#if (RTL8814A_SUPPORT == 1) /*use this function to do power tracking after 8814 by YuChen*/
if (dm->support_ic_type & ODM_RTL8814A) {
odm_txpowertracking_callback_thermal_meter_jaguar_series2(dm);
return;
}
#endif
#if (RTL8881A_SUPPORT || RTL8812A_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8812 || dm->support_ic_type & ODM_RTL8881A) {
odm_txpowertracking_callback_thermal_meter_jaguar_series(dm);
return;
}
#endif
#if (RTL8192E_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8192E) {
odm_txpowertracking_callback_thermal_meter_92e(dm);
return;
}
#endif
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
/* PMGNT_INFO mgnt_info = &adapter->mgnt_info; */
#endif
u8 thermal_value = 0, delta, delta_LCK, delta_IQK, offset;
u8 thermal_value_avg_count = 0;
u32 thermal_value_avg = 0;
/* s32 ele_A=0, ele_D, TempCCk, X, value32;
* s32 Y, ele_C=0;
* s8 OFDM_index[2], CCK_index=0, OFDM_index_old[2]={0,0}, CCK_index_old=0, index;
* s8 deltaPowerIndex = 0; */
u32 i = 0;/* , j = 0; */
boolean is2T = false;
/* bool bInteralPA = false; */
u8 OFDM_max_index = 34, rf = (is2T) ? 2 : 1; /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
u8 indexforchannel = 0;/*get_right_chnl_place_for_iqk(hal_data->current_channel)*/
enum _POWER_DEC_INC { POWER_DEC, POWER_INC };
struct txpwrtrack_cfg c;
/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
s8 delta_swing_table_idx[2][index_mapping_NUM_88E] = {
/* {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}} */
{0, 0, 2, 3, 4, 4, 5, 6, 7, 7, 8, 9, 10, 10, 11}, {0, 0, 1, 2, 3, 4, 4, 4, 4, 5, 7, 8, 9, 9, 10}
};
u8 thermal_threshold[2][index_mapping_NUM_88E] = {
/* {{Power decreasing(lower temperature)}, {Power increasing(higher temperature)}} */
{0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 27}, {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 25, 25, 25}
};
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
struct rtl8192cd_priv *priv = dm->priv;
#endif
/* 4 2. Initilization ( 7 steps in total ) */
configure_txpower_track(dm, &c);
dm->rf_calibrate_info.txpowertracking_callback_cnt++; /* cosa add for debug */
dm->rf_calibrate_info.is_txpowertracking_init = true;
#if (MP_DRIVER == 1)
dm->rf_calibrate_info.txpowertrack_control = hal_data->txpowertrack_control; /* We should keep updating the control variable according to HalData.
* rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
dm->rf_calibrate_info.rega24 = 0x090e1317;
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_AP) && defined(MP_TEST)
if ((OPMODE & WIFI_MP_STATE) || *(dm->mp_mode)) {
if (dm->priv->pshare->mp_txpwr_tracking == false)
return;
}
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "===>odm_txpowertracking_callback_thermal_meter_8188e, dm->bb_swing_idx_cck_base: %d, dm->bb_swing_idx_ofdm_base: %d\n", cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base);
/*
if (!dm->rf_calibrate_info.tm_trigger) {
odm_set_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, BIT(17) | BIT(16), 0x3);
dm->rf_calibrate_info.tm_trigger = 1;
return;
}
*/
thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
if (!thermal_value || !dm->rf_calibrate_info.txpowertrack_control)
#else
if (!dm->rf_calibrate_info.txpowertrack_control)
#endif
return;
/* 4 3. Initialize ThermalValues of rf_calibrate_info */
if (!dm->rf_calibrate_info.thermal_value) {
dm->rf_calibrate_info.thermal_value_lck = thermal_value;
dm->rf_calibrate_info.thermal_value_iqk = thermal_value;
}
if (dm->rf_calibrate_info.is_reloadtxpowerindex)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "reload ofdm index for band switch\n");
/* 4 4. Calculate average thermal meter */
dm->rf_calibrate_info.thermal_value_avg[dm->rf_calibrate_info.thermal_value_avg_index] = thermal_value;
dm->rf_calibrate_info.thermal_value_avg_index++;
if (dm->rf_calibrate_info.thermal_value_avg_index == c.average_thermal_num)
dm->rf_calibrate_info.thermal_value_avg_index = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (dm->rf_calibrate_info.thermal_value_avg[i]) {
thermal_value_avg += dm->rf_calibrate_info.thermal_value_avg[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) {
/* Give the new thermo value a weighting */
thermal_value_avg += (thermal_value * 4);
thermal_value = (u8)(thermal_value_avg / (thermal_value_avg_count + 4));
cali_info->thermal_value_delta = thermal_value - priv->pmib->dot11RFEntry.ther;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "AVG Thermal Meter = 0x%x\n", thermal_value);
}
/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
delta = (thermal_value > dm->rf_calibrate_info.thermal_value) ? (thermal_value - dm->rf_calibrate_info.thermal_value) : (dm->rf_calibrate_info.thermal_value - thermal_value);
delta_LCK = (thermal_value > dm->rf_calibrate_info.thermal_value_lck) ? (thermal_value - dm->rf_calibrate_info.thermal_value_lck) : (dm->rf_calibrate_info.thermal_value_lck - thermal_value);
delta_IQK = (thermal_value > dm->rf_calibrate_info.thermal_value_iqk) ? (thermal_value - dm->rf_calibrate_info.thermal_value_iqk) : (dm->rf_calibrate_info.thermal_value_iqk - thermal_value);
/* 4 6. If necessary, do LCK. */
if (!(dm->support_ic_type & ODM_RTL8821)) {
/*if((delta_LCK > hal_data->delta_lck) && (hal_data->delta_lck != 0))*/
if ((delta_LCK >= c.threshold_iqk) && (!iqk_info->rfk_forbidden)) {
/*Delta temperature is equal to or larger than 20 centigrade.*/
dm->rf_calibrate_info.thermal_value_lck = thermal_value;
(*c.phy_lc_calibrate)(dm);
}
}
/* 3 7. If necessary, move the index of swing table to adjust Tx power. */
if (delta > 0 && dm->rf_calibrate_info.txpowertrack_control) {
delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
/* 4 7.1 The Final Power index = BaseIndex + power_index_offset */
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
CALCULATE_SWINGTALBE_OFFSET(offset, POWER_INC, index_mapping_NUM_88E, delta);
dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
dm->rf_calibrate_info.delta_power_index = delta_swing_table_idx[POWER_INC][offset];
} else {
CALCULATE_SWINGTALBE_OFFSET(offset, POWER_DEC, index_mapping_NUM_88E, delta);
dm->rf_calibrate_info.delta_power_index_last = dm->rf_calibrate_info.delta_power_index;
dm->rf_calibrate_info.delta_power_index = (-1) * delta_swing_table_idx[POWER_DEC][offset];
}
if (dm->rf_calibrate_info.delta_power_index == dm->rf_calibrate_info.delta_power_index_last)
dm->rf_calibrate_info.power_index_offset = 0;
else
dm->rf_calibrate_info.power_index_offset = dm->rf_calibrate_info.delta_power_index - dm->rf_calibrate_info.delta_power_index_last;
for (i = 0; i < rf; i++)
dm->rf_calibrate_info.OFDM_index[i] = cali_info->bb_swing_idx_ofdm_base + dm->rf_calibrate_info.power_index_offset;
dm->rf_calibrate_info.CCK_index = cali_info->bb_swing_idx_cck_base + dm->rf_calibrate_info.power_index_offset;
cali_info->bb_swing_idx_cck = dm->rf_calibrate_info.CCK_index;
cali_info->bb_swing_idx_ofdm[RF_PATH_A] = dm->rf_calibrate_info.OFDM_index[RF_PATH_A];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, dm->rf_calibrate_info.power_index_offset);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "The 'OFDM' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base, dm->rf_calibrate_info.power_index_offset);
/* 4 7.1 Handle boundary conditions of index. */
for (i = 0; i < rf; i++) {
if (dm->rf_calibrate_info.OFDM_index[i] > OFDM_max_index)
dm->rf_calibrate_info.OFDM_index[i] = OFDM_max_index;
else if (dm->rf_calibrate_info.OFDM_index[i] < 0)
dm->rf_calibrate_info.OFDM_index[i] = 0;
}
if (dm->rf_calibrate_info.CCK_index > c.swing_table_size_cck - 1)
dm->rf_calibrate_info.CCK_index = c.swing_table_size_cck - 1;
else if (dm->rf_calibrate_info.CCK_index < 0)
dm->rf_calibrate_info.CCK_index = 0;
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"The thermal meter is unchanged or TxPowerTracking OFF: thermal_value: %d, dm->rf_calibrate_info.thermal_value: %d)\n", thermal_value, dm->rf_calibrate_info.thermal_value);
dm->rf_calibrate_info.power_index_offset = 0;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.CCK_index, cali_info->bb_swing_idx_cck_base);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index: %d\n", dm->rf_calibrate_info.OFDM_index[RF_PATH_A], cali_info->bb_swing_idx_ofdm_base);
if (dm->rf_calibrate_info.power_index_offset != 0 && dm->rf_calibrate_info.txpowertrack_control) {
/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
dm->rf_calibrate_info.is_tx_power_changed = true; /* Always true after Tx Power is adjusted by power tracking. */
/* */
/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
/* to increase TX power. Otherwise, EVM will be bad. */
/* */
/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
if (thermal_value > dm->rf_calibrate_info.thermal_value) {
/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK, */
/* "Temperature Increasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
/* dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
} else if (thermal_value < dm->rf_calibrate_info.thermal_value) { /* Low temperature */
/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK, */
/* "Temperature Decreasing: delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n", */
/* dm->rf_calibrate_info.power_index_offset, delta, thermal_value, hal_data->eeprom_thermal_meter, dm->rf_calibrate_info.thermal_value); */
}
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
{
/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK,"Temperature(%d) hugher than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
(*c.odm_tx_pwr_track_set_pwr)(dm, TXAGC, 0, 0);
} else {
/* RF_DBG(dm,DBG_RF_TX_PWR_TRACK,"Temperature(%d) lower than PG value(%d), increases the power by tx_agc\n", thermal_value, hal_data->eeprom_thermal_meter); */
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_A, indexforchannel);
if (is2T)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, RF_PATH_B, indexforchannel);
}
cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
cali_info->bb_swing_idx_ofdm_base = cali_info->bb_swing_idx_ofdm[RF_PATH_A];
dm->rf_calibrate_info.thermal_value = thermal_value;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===dm_TXPowerTrackingCallback_ThermalMeter_8188E\n");
dm->rf_calibrate_info.tx_powercount = 0;
}
/* 3============================================================
* 3 IQ Calibration
* 3============================================================ */
void
odm_reset_iqk_result(
void *dm_void
)
{
return;
}
#if 1/* !(DM_ODM_SUPPORT_TYPE & ODM_AP) */
u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
{
u8 channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122, 124, 126, 128, 130, 132, 134, 136, 138, 140, 149, 151, 153, 155, 157, 159, 161, 163, 165
};
u8 place = chnl;
if (chnl > 14) {
for (place = 14; place < sizeof(channel_all); place++) {
if (channel_all[place] == chnl)
return place - 13;
}
}
return 0;
}
#endif
void
odm_iq_calibrate(
struct dm_struct *dm
)
{
struct dm_iqk_info *iqk_info = &dm->IQK_info;
if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
if ((*dm->channel != dm->pre_channel) && (!*dm->is_scan_in_process)) {
dm->pre_channel = *dm->channel;
dm->linked_interval = 0;
}
if (dm->linked_interval < 3)
dm->linked_interval++;
if (dm->linked_interval == 2)
halrf_iqk_trigger(dm, false);
} else
dm->linked_interval = 0;
}
void phydm_rf_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_init(dm);
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8814A_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8814A)
phy_iq_calibrate_8814a_init(dm);
#endif
#endif
}
void phydm_rf_watchdog(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_check(dm);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
if (dm->support_ic_type & ODM_IC_11AC_SERIES)
odm_iq_calibrate(dm);
#endif
}
================================================
FILE: hal/phydm/halrf/halphyrf_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HALPHYRF_H__
#define __HALPHYRF_H__
#include "halrf/halrf_powertracking_ap.h"
#include "halrf/halrf_kfree.h"
#if (RTL8814A_SUPPORT == 1)
#include "halrf/rtl8814a/halrf_iqk_8814a.h"
#endif
#if (RTL8822B_SUPPORT == 1)
#include "halrf/rtl8822b/halrf_iqk_8822b.h"
#endif
#if (RTL8821C_SUPPORT == 1)
#include "halrf/rtl8821c/halrf_iqk_8821c.h"
#endif
#if (RTL8195B_SUPPORT == 1)
// #include "halrf/rtl8195b/halrf.h"
#include "halrf/rtl8195b/halrf_iqk_8195b.h"
#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
#include "halrf/rtl8195b/halrf_dpk_8195b.h"
#endif
#if (RTL8198F_SUPPORT == 1)
#include "halrf/rtl8198f/halrf_iqk_8198f.h"
#include "halrf/rtl8198f/halrf_dpk_8198f.h"
#endif
#if (RTL8812F_SUPPORT == 1)
#include "halrf/rtl8812f/halrf_iqk_8812f.h"
#include "halrf/rtl8812f/halrf_dpk_8812f.h"
#include "halrf/rtl8812f/halrf_tssi_8812f.h"
#endif
#if (RTL8814B_SUPPORT == 1)
#include "halrf/rtl8814b/halrf_iqk_8814b.h"
#include "halrf/rtl8814b/halrf_dpk_8814b.h"
#endif
enum pwrtrack_method {
BBSWING,
TXAGC,
MIX_MODE,
TSSI_MODE,
MIX_2G_TSSI_5G_MODE,
MIX_5G_TSSI_2G_MODE,
CLEAN_MODE
};
typedef void (*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
typedef void(*func_iqk)(void *, u8, u8, u8);
typedef void (*func_lck)(void *);
/* refine by YuChen for 8814A */
typedef void (*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void (*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void (*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
typedef void (*func_all_swing_ex)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
struct txpwrtrack_cfg {
u8 swing_table_size_cck;
u8 swing_table_size_ofdm;
u8 threshold_iqk;
u8 threshold_dpk;
u8 average_thermal_num;
u8 rf_path_count;
u32 thermal_reg_addr;
func_set_pwr odm_tx_pwr_track_set_pwr;
func_iqk do_iqk;
func_lck phy_lc_calibrate;
func_swing get_delta_swing_table;
func_swing8814only get_delta_swing_table8814only;
func_all_swing get_delta_all_swing_table;
func_all_swing_ex get_delta_all_swing_table_ex;
};
void
odm_clear_txpowertracking_state(
void *dm_void
);
void
configure_txpower_track(
void *dm_void,
struct txpwrtrack_cfg *config
);
void
odm_txpowertracking_callback_thermal_meter(
void *dm_void
);
#if (RTL8192E_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_92e(
void *dm_void
);
#endif
#if (RTL8814A_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series2(
void *dm_void
);
#elif ODM_IC_11AC_SERIES_SUPPORT
void
odm_txpowertracking_callback_thermal_meter_jaguar_series(
void *dm_void
);
#elif (RTL8197F_SUPPORT == 1 || RTL8192F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series3(
void *dm_void
);
#elif (RTL8814B_SUPPORT == 1)
void
odm_txpowertracking_callback_thermal_meter_jaguar_series4(
void *dm_void
);
#endif
#define IS_CCK_RATE(_rate) (ODM_MGN_1M == _rate || _rate == ODM_MGN_2M || _rate == ODM_MGN_5_5M || _rate == ODM_MGN_11M)
#define ODM_TARGET_CHNL_NUM_2G_5G 59
void
odm_reset_iqk_result(
void *dm_void
);
u8
odm_get_right_chnl_place_for_iqk(
u8 chnl
);
void phydm_rf_init(void *dm_void);
void phydm_rf_watchdog(void *dm_void);
#endif /*#ifndef __HALPHYRF_H__*/
================================================
FILE: hal/phydm/halrf/halphyrf_ce.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#include "mp_precomp.h"
#include "phydm_precomp.h"
#define CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal)\
do { \
u32 __offset = (u32)_offset; \
u32 __size = (u32)_size; \
for (__offset = 0; __offset < __size; __offset++) { \
if (_delta_thermal < \
thermal_threshold[_direction][__offset]) { \
if (__offset != 0) \
__offset--; \
break; \
} \
} \
if (__offset >= __size) \
__offset = __size - 1; \
} while (0)
void configure_txpower_track(void *dm_void, struct txpwrtrack_cfg *config)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if RTL8192E_SUPPORT
if (dm->support_ic_type == ODM_RTL8192E)
configure_txpower_track_8192e(config);
#endif
#if RTL8821A_SUPPORT
if (dm->support_ic_type == ODM_RTL8821)
configure_txpower_track_8821a(config);
#endif
#if RTL8812A_SUPPORT
if (dm->support_ic_type == ODM_RTL8812)
configure_txpower_track_8812a(config);
#endif
#if RTL8188E_SUPPORT
if (dm->support_ic_type == ODM_RTL8188E)
configure_txpower_track_8188e(config);
#endif
#if RTL8723B_SUPPORT
if (dm->support_ic_type == ODM_RTL8723B)
configure_txpower_track_8723b(config);
#endif
#if RTL8814A_SUPPORT
if (dm->support_ic_type == ODM_RTL8814A)
configure_txpower_track_8814a(config);
#endif
#if RTL8703B_SUPPORT
if (dm->support_ic_type == ODM_RTL8703B)
configure_txpower_track_8703b(config);
#endif
#if RTL8188F_SUPPORT
if (dm->support_ic_type == ODM_RTL8188F)
configure_txpower_track_8188f(config);
#endif
#if RTL8723D_SUPPORT
if (dm->support_ic_type == ODM_RTL8723D)
configure_txpower_track_8723d(config);
#endif
/*@ JJ ADD 20161014 */
#if RTL8710B_SUPPORT
if (dm->support_ic_type == ODM_RTL8710B)
configure_txpower_track_8710b(config);
#endif
#if RTL8822B_SUPPORT
if (dm->support_ic_type == ODM_RTL8822B)
configure_txpower_track_8822b(config);
#endif
#if RTL8821C_SUPPORT
if (dm->support_ic_type == ODM_RTL8821C)
configure_txpower_track_8821c(config);
#endif
#if RTL8192F_SUPPORT
if (dm->support_ic_type == ODM_RTL8192F)
configure_txpower_track_8192f(config);
#endif
#if RTL8822C_SUPPORT
if (dm->support_ic_type == ODM_RTL8822C)
configure_txpower_track_8822c(config);
#endif
}
/*@ **********************************************************************
* <20121113, Kordan> This function should be called when tx_agc changed.
* Otherwise the previous compensation is gone, because we record the
* delta of temperature between two TxPowerTracking watch dogs.
*
* NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
* need to call this function.
* **********************************************************************
*/
void odm_clear_txpowertracking_state(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u8 p = 0;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
dm->rf_calibrate_info.CCK_index = 0;
for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
cali_info->bb_swing_idx_ofdm_base[p]
= cali_info->default_ofdm_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->power_index_offset[p] = 0;
cali_info->delta_power_index[p] = 0;
cali_info->delta_power_index_last[p] = 0;
/* Initial Mix mode power tracking*/
cali_info->absolute_ofdm_swing_idx[p] = 0;
cali_info->remnant_ofdm_swing_idx[p] = 0;
cali_info->kfree_offset[p] = 0;
}
/* Initial Mix mode power tracking*/
cali_info->modify_tx_agc_flag_path_a = false;
cali_info->modify_tx_agc_flag_path_b = false;
cali_info->modify_tx_agc_flag_path_c = false;
cali_info->modify_tx_agc_flag_path_d = false;
cali_info->remnant_cck_swing_idx = 0;
cali_info->thermal_value = rf->eeprom_thermal;
cali_info->modify_tx_agc_value_cck = 0;
cali_info->modify_tx_agc_value_ofdm = 0;
}
void odm_get_tracking_table(void *dm_void, u8 thermal_value, u8 delta)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
struct _hal_rf_ *rf = &dm->rf_table;
struct txpwrtrack_cfg c = {0};
u8 p;
/* 4 1. TWO tables decide the final index of OFDM/CCK swing table. */
u8 *pwrtrk_tab_up_a = NULL;
u8 *pwrtrk_tab_down_a = NULL;
u8 *pwrtrk_tab_up_b = NULL;
u8 *pwrtrk_tab_down_b = NULL;
/*for 8814 add by Yu Chen*/
u8 *pwrtrk_tab_up_c = NULL;
u8 *pwrtrk_tab_down_c = NULL;
u8 *pwrtrk_tab_up_d = NULL;
u8 *pwrtrk_tab_down_d = NULL;
/*for Xtal Offset by James.Tung*/
s8 *xtal_tab_up = NULL;
s8 *xtal_tab_down = NULL;
configure_txpower_track(dm, &c);
(*c.get_delta_swing_table)(dm,
(u8 **)&pwrtrk_tab_up_a,
(u8 **)&pwrtrk_tab_down_a,
(u8 **)&pwrtrk_tab_up_b,
(u8 **)&pwrtrk_tab_down_b);
if (dm->support_ic_type & ODM_RTL8814A) /*for 8814 path C & D*/
(*c.get_delta_swing_table8814only)(dm,
(u8 **)&pwrtrk_tab_up_c,
(u8 **)&pwrtrk_tab_down_c,
(u8 **)&pwrtrk_tab_up_d,
(u8 **)&pwrtrk_tab_down_d);
/*for Xtal Offset*/
if (dm->support_ic_type &
(ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F))
(*c.get_delta_swing_xtal_table)(dm,
(s8 **)&xtal_tab_up,
(s8 **)&xtal_tab_down);
if (thermal_value > rf->eeprom_thermal) {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
/*recording power index offset*/
cali_info->delta_power_index_last[p] =
cali_info->delta_power_index[p];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher******\n");
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_up_b[%d] = %d\n", delta,
pwrtrk_tab_up_b[delta]);
cali_info->delta_power_index[p] =
pwrtrk_tab_up_b[delta];
cali_info->absolute_ofdm_swing_idx[p] =
pwrtrk_tab_up_b[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_B] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_up_c[%d] = %d\n", delta,
pwrtrk_tab_up_c[delta]);
cali_info->delta_power_index[p] =
pwrtrk_tab_up_c[delta];
cali_info->absolute_ofdm_swing_idx[p] =
pwrtrk_tab_up_c[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_C] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_up_d[%d] = %d\n", delta,
pwrtrk_tab_up_d[delta]);
cali_info->delta_power_index[p] =
pwrtrk_tab_up_d[delta];
cali_info->absolute_ofdm_swing_idx[p] =
pwrtrk_tab_up_d[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_D] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_up_a[%d] = %d\n", delta,
pwrtrk_tab_up_a[delta]);
cali_info->delta_power_index[p] =
pwrtrk_tab_up_a[delta];
cali_info->absolute_ofdm_swing_idx[p] =
pwrtrk_tab_up_a[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_A] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
/* @JJ ADD 20161014 */
/*Save xtal_offset from Xtal table*/
if (dm->support_ic_type &
(ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B |
ODM_RTL8192F)) {
/*recording last Xtal offset*/
cali_info->xtal_offset_last = cali_info->xtal_offset;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[Xtal] xtal_tab_up[%d] = %d\n",
delta, xtal_tab_up[delta]);
cali_info->xtal_offset = xtal_tab_up[delta];
if (cali_info->xtal_offset_last != xtal_tab_up[delta])
cali_info->xtal_offset_eanble = 1;
}
} else {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
/*recording power index offset*/
cali_info->delta_power_index_last[p] =
cali_info->delta_power_index[p];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower******\n");
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_down_b[%d] = %d\n", delta,
pwrtrk_tab_down_b[delta]);
cali_info->delta_power_index[p] =
-1 * pwrtrk_tab_down_b[delta];
cali_info->absolute_ofdm_swing_idx[p] =
-1 * pwrtrk_tab_down_b[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_B] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_down_c[%d] = %d\n", delta,
pwrtrk_tab_down_c[delta]);
cali_info->delta_power_index[p] =
-1 * pwrtrk_tab_down_c[delta];
cali_info->absolute_ofdm_swing_idx[p] =
-1 * pwrtrk_tab_down_c[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_C] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_down_d[%d] = %d\n", delta,
pwrtrk_tab_down_d[delta]);
cali_info->delta_power_index[p] =
-1 * pwrtrk_tab_down_d[delta];
cali_info->absolute_ofdm_swing_idx[p] =
-1 * pwrtrk_tab_down_d[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_D] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pwrtrk_tab_down_a[%d] = %d\n", delta,
pwrtrk_tab_down_a[delta]);
cali_info->delta_power_index[p] =
-1 * pwrtrk_tab_down_a[delta];
cali_info->absolute_ofdm_swing_idx[p] =
-1 * pwrtrk_tab_down_a[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"absolute_ofdm_swing_idx[PATH_A] = %d\n",
cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
/* @JJ ADD 20161014 */
if (dm->support_ic_type &
(ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B |
ODM_RTL8192F)) {
/*recording last Xtal offset*/
cali_info->xtal_offset_last = cali_info->xtal_offset;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[Xtal] xtal_tab_down[%d] = %d\n", delta,
xtal_tab_down[delta]);
/*Save xtal_offset from Xtal table*/
cali_info->xtal_offset = xtal_tab_down[delta];
if (cali_info->xtal_offset_last != xtal_tab_down[delta])
cali_info->xtal_offset_eanble = 1;
}
}
}
void odm_pwrtrk_method(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 p, idxforchnl = 0;
struct txpwrtrack_cfg c = {0};
configure_txpower_track(dm, &c);
if (dm->support_ic_type &
(ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8821 | ODM_RTL8812 |
ODM_RTL8723B | ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8188F |
ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8710B |
ODM_RTL8192F)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk MIX_MODE***\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (dm->support_ic_type & ODM_RTL8723D) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk MIX_MODE***\n");
p = (u8)odm_get_bb_reg(dm, R_0x948, 0x00000080);
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
/*if open ant_div 0x948=140,do 2 path pwr_track*/
if (odm_get_bb_reg(dm, R_0x948, 0x00000040))
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, 1, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk BBSWING_MODE***\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)
(dm, BBSWING, p, idxforchnl);
}
}
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
void odm_txpowertracking_callback_thermal_meter(struct dm_struct *dm)
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
void odm_txpowertracking_callback_thermal_meter(void *dm_void)
#else
void odm_txpowertracking_callback_thermal_meter(void *adapter)
#endif
{
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_struct *dm = &hal_data->DM_OutSrc;
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
struct dm_struct *dm = (struct dm_struct *)dm_void;
#endif
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 thermal_value = 0, delta, delta_lck, delta_iqk, p = 0, i = 0;
u8 thermal_value_avg_count = 0;
u32 thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
/* OFDM BB Swing should be less than +3.0dB, required by Arthur */
#if 0
u8 OFDM_min_index = 0;
#endif
#if 0
/* get_right_chnl_place_for_iqk(hal_data->current_channel) */
#endif
u8 power_tracking_type = rf->pwt_type;
s8 thermal_value_temp = 0;
struct txpwrtrack_cfg c = {0};
/* @4 2. Initialization ( 7 steps in total ) */
configure_txpower_track(dm, &c);
cali_info->txpowertracking_callback_cnt++;
cali_info->is_txpowertracking_init = true;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n\n\n===>%s bbsw_idx_cck_base=%d\n",
__func__, cali_info->bb_swing_idx_cck_base);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"bbsw_idx_ofdm_base[A]=%d default_ofdm_idx=%d\n",
cali_info->bb_swing_idx_ofdm_base[RF_PATH_A],
cali_info->default_ofdm_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->txpowertrack_control=%d, rf->eeprom_thermal %d\n",
cali_info->txpowertrack_control, rf->eeprom_thermal);
/* 0x42: RF Reg[15:10] 88E */
thermal_value =
(u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);
thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp(%d) = ther_value(%d) + pwr_trim_ther(%d)\n",
thermal_value_temp, thermal_value,
phydm_get_thermal_offset(dm));
if (thermal_value_temp > 63)
thermal_value = 63;
else if (thermal_value_temp < 0)
thermal_value = 0;
else
thermal_value = thermal_value_temp;
/*@add log by zhao he, check c80/c94/c14/ca0 value*/
if (dm->support_ic_type &
(ODM_RTL8723D | ODM_RTL8710B)) {
regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
RF_DBG(dm, DBG_RF_IQK,
"0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n",
regc80, regcd0, regcd4, regab4);
}
if (!cali_info->txpowertrack_control)
return;
if (rf->eeprom_thermal == 0xff) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"no pg, hal_data->eeprom_thermal_meter = 0x%x\n",
rf->eeprom_thermal);
return;
}
/*@4 3. Initialize ThermalValues of rf_calibrate_info*/
if (cali_info->is_reloadtxpowerindex)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"reload ofdm index for band switch\n");
/*@4 4. Calculate average thermal meter*/
cali_info->thermal_value_avg[cali_info->thermal_value_avg_index]
= thermal_value;
cali_info->thermal_value_avg_index++;
/*Average times = c.average_thermal_num*/
if (cali_info->thermal_value_avg_index == c.average_thermal_num)
cali_info->thermal_value_avg_index = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (cali_info->thermal_value_avg[i]) {
thermal_value_avg += cali_info->thermal_value_avg[i];
thermal_value_avg_count++;
}
}
/* Calculate Average thermal_value after average enough times */
if (thermal_value_avg_count) {
thermal_value =
(u8)(thermal_value_avg / thermal_value_avg_count);
cali_info->thermal_value_delta
= thermal_value - rf->eeprom_thermal;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n",
thermal_value, rf->eeprom_thermal);
}
/* @4 5. Calculate delta, delta_lck, delta_iqk. */
/* "delta" here is used to determine thermal value changes or not. */
if (thermal_value > cali_info->thermal_value)
delta = thermal_value - cali_info->thermal_value;
else
delta = cali_info->thermal_value - thermal_value;
if (thermal_value > cali_info->thermal_value_lck)
delta_lck = thermal_value - cali_info->thermal_value_lck;
else
delta_lck = cali_info->thermal_value_lck - thermal_value;
if (thermal_value > cali_info->thermal_value_iqk)
delta_iqk = thermal_value - cali_info->thermal_value_iqk;
else
delta_iqk = cali_info->thermal_value_iqk - thermal_value;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"(delta, delta_lck, delta_iqk) = (%d, %d, %d)\n", delta,
delta_lck, delta_iqk);
/*@4 6. If necessary, do LCK.*/
/* Wait sacn to do LCK by RF Jenyu*/
if (!(*dm->is_scan_in_process) && !iqk_info->rfk_forbidden) {
/* Delta temperature is equal to or larger than 20 centigrade.*/
if (delta_lck >= c.threshold_iqk) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_lck(%d) >= threshold_iqk(%d)\n",
delta_lck, c.threshold_iqk);
cali_info->thermal_value_lck = thermal_value;
/*Use RTLCK, close power tracking driver LCK*/
/*8821 don't do LCK*/
if (!(dm->support_ic_type &
(ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B)) &&
c.phy_lc_calibrate) {
(*c.phy_lc_calibrate)(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"do pwrtrk lck\n");
}
}
}
/*@3 7. If necessary, move the index of swing table to adjust Tx power.*/
/* "delta" here is used to record the absolute value of difference. */
if (delta > 0 && cali_info->txpowertrack_control) {
if (thermal_value > rf->eeprom_thermal)
delta = thermal_value - rf->eeprom_thermal;
else
delta = rf->eeprom_thermal - thermal_value;
if (delta >= TXPWR_TRACK_TABLE_SIZE)
delta = TXPWR_TRACK_TABLE_SIZE - 1;
odm_get_tracking_table(dm, thermal_value, delta);
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n[path-%d] Calculate pwr_idx_offset\n", p);
/*If Thermal value changes but table value is the same*/
if (cali_info->delta_power_index[p] ==
cali_info->delta_power_index_last[p])
cali_info->power_index_offset[p] = 0;
else
cali_info->power_index_offset[p] =
cali_info->delta_power_index[p] -
cali_info->delta_power_index_last[p];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"path-%d pwridx_diff%d=pwr_idx%d - last_idx%d\n",
p, cali_info->power_index_offset[p],
cali_info->delta_power_index[p],
cali_info->delta_power_index_last[p]);
#if 0
cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
cali_info->bb_swing_idx_cck = cali_info->CCK_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
/*************Print BB Swing base and index Offset*************/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n",
cali_info->bb_swing_idx_cck,
cali_info->bb_swing_idx_cck_base,
cali_info->power_index_offset[p]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n",
cali_info->bb_swing_idx_ofdm[p], p,
cali_info->bb_swing_idx_ofdm_base[p],
cali_info->power_index_offset[p]);
/*4 7.1 Handle boundary conditions of index.*/
if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
else if (cali_info->OFDM_index[p] <= OFDM_min_index)
cali_info->OFDM_index[p] = OFDM_min_index;
#endif
}
#if 0
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n\n========================================================================================================\n");
if (cali_info->CCK_index > c.swing_table_size_cck - 1)
cali_info->CCK_index = c.swing_table_size_cck - 1;
else if (cali_info->CCK_index <= 0)
cali_info->CCK_index = 0;
#endif
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Thermal is unchanged thermal=%d last_thermal=%d\n",
thermal_value,
cali_info->thermal_value);
for (p = RF_PATH_A; p < c.rf_path_count; p++)
cali_info->power_index_offset[p] = 0;
}
#if 0
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
cali_info->CCK_index,
cali_info->bb_swing_idx_cck_base); /*Print Swing base & current*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
cali_info->OFDM_index[p], p,
cali_info->bb_swing_idx_ofdm_base[p]);
}
#endif
if ((dm->support_ic_type & ODM_RTL8814A)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "power_tracking_type=%d\n",
power_tracking_type);
if (power_tracking_type == 0) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk MIX_MODE***\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)
(dm, MIX_MODE, p, 0);
} else if (power_tracking_type == 1) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk MIX(2G) TSSI(5G) MODE***\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)
(dm, MIX_2G_TSSI_5G_MODE, p, 0);
} else if (power_tracking_type == 2) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk MIX(5G) TSSI(2G)MODE***\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)
(dm, MIX_5G_TSSI_2G_MODE, p, 0);
} else if (power_tracking_type == 3) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"***Enter PwrTrk TSSI MODE***\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)
(dm, TSSI_MODE, p, 0);
}
} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
cali_info->power_index_offset[RF_PATH_B] != 0 ||
cali_info->power_index_offset[RF_PATH_C] != 0 ||
cali_info->power_index_offset[RF_PATH_D] != 0)) {
#if 0
/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
/*Always true after Tx Power is adjusted by power tracking.*/
cali_info->is_tx_power_changed = true;
/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital
* to increase TX power. Otherwise, EVM will be bad.
*
* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E.
*/
if (thermal_value > cali_info->thermal_value) {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
p, cali_info->power_index_offset[p],
delta, thermal_value, rf->eeprom_thermal,
cali_info->thermal_value);
}
} else if (thermal_value < cali_info->thermal_value) { /*Low temperature*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
p, cali_info->power_index_offset[p],
delta, thermal_value, rf->eeprom_thermal,
cali_info->thermal_value);
}
}
#endif
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
if (thermal_value > rf->eeprom_thermal) {
#else
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) higher than PG value(%d)\n",
thermal_value, rf->eeprom_thermal);
odm_pwrtrk_method(dm);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) lower than PG value(%d)\n",
thermal_value, rf->eeprom_thermal);
odm_pwrtrk_method(dm);
}
#if 0
/*Record last time Power Tracking result as base.*/
cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
for (p = RF_PATH_A; p < c.rf_path_count; p++)
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->thermal_value = %d thermal_value= %d\n",
cali_info->thermal_value, thermal_value);
}
/*Record last Power Tracking Thermal value*/
cali_info->thermal_value = thermal_value;
if (dm->support_ic_type &
(ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8192F | ODM_RTL8710B)) {
if (cali_info->xtal_offset_eanble != 0 &&
cali_info->txpowertrack_control &&
rf->eeprom_thermal != 0xff) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"**********Enter Xtal Tracking**********\n");
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
if (thermal_value > rf->eeprom_thermal) {
#else
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) higher than PG (%d)\n",
thermal_value, rf->eeprom_thermal);
(*c.odm_txxtaltrack_set_xtal)(dm);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) lower than PG (%d)\n",
thermal_value, rf->eeprom_thermal);
(*c.odm_txxtaltrack_set_xtal)(dm);
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"**********End Xtal Tracking**********\n");
}
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
/* Wait sacn to do IQK by RF Jenyu*/
if (!(*dm->is_scan_in_process) && !iqk_info->rfk_forbidden &&
!cali_info->is_iqk_in_progress) {
if (!(dm->support_ic_type & ODM_RTL8723B)) {
/*Delta temperature is equal or larger than 20 Celsius*/
/*When threshold is 8*/
if (delta_iqk >= c.threshold_iqk) {
cali_info->thermal_value_iqk = thermal_value;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_iqk(%d) >= threshold_iqk(%d)\n",
delta_iqk, c.threshold_iqk);
(*c.do_iqk)(dm, delta_iqk, thermal_value, 8);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"do pwrtrk iqk\n");
}
}
}
#if 0
if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
}
}
if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
}
}
#endif
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===%s\n", __func__);
cali_info->tx_powercount = 0;
}
#if (RTL8822C_SUPPORT == 1 || RTL8814B_SUPPORT == 1)
void
odm_txpowertracking_new_callback_thermal_meter(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
struct _halrf_tssi_data *tssi = &rf->halrf_tssi_data;
u8 thermal_value[MAX_RF_PATH] = {0}, delta[MAX_RF_PATH] = {0};
u8 delta_swing_table_idx_tup[DELTA_SWINGIDX_SIZE] = {0};
u8 delta_swing_table_idx_tdown[DELTA_SWINGIDX_SIZE] = {0};
u8 delta_LCK = 0, delta_IQK = 0, i = 0, j = 0, p;
u8 thermal_value_avg_count[MAX_RF_PATH] = {0};
u32 thermal_value_avg[MAX_RF_PATH] = {0};
s8 thermal_value_temp[MAX_RF_PATH] = {0};
u8 tracking_method = MIX_MODE;
struct txpwrtrack_cfg c;
u8 *delta_swing_table_idx_tup_a = NULL;
u8 *delta_swing_table_idx_tdown_a = NULL;
u8 *delta_swing_table_idx_tup_b = NULL;
u8 *delta_swing_table_idx_tdown_b = NULL;
u8 *delta_swing_table_idx_tup_c = NULL;
u8 *delta_swing_table_idx_tdown_c = NULL;
u8 *delta_swing_table_idx_tup_d = NULL;
u8 *delta_swing_table_idx_tdown_d = NULL;
configure_txpower_track(dm, &c);
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
if (dm->support_ic_type == ODM_RTL8814B) {
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
}
cali_info->txpowertracking_callback_cnt++;
cali_info->is_txpowertracking_init = true;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->txpowertrack_control=%d, tssi->thermal[RF_PATH_A]=%d tssi->thermal[RF_PATH_B]=%d\n",
cali_info->txpowertrack_control, tssi->thermal[RF_PATH_A], tssi->thermal[RF_PATH_B]);
if (dm->support_ic_type == ODM_RTL8822C) {
for (i = 0; i < c.rf_path_count; i++)
thermal_value[i] = (u8)odm_get_rf_reg(dm, i, c.thermal_reg_addr, 0x7e); /* 0x42: RF Reg[6:1] Thermal Trim*/
} else {
for (i = 0; i < c.rf_path_count; i++) {
thermal_value[i] = (u8)odm_get_rf_reg(dm, i, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
thermal_value_temp[i] = (s8)thermal_value[i] + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp[%d](%d) = thermal_value[%d](%d) + thermal_trim(%d)\n", i, thermal_value_temp[i], i, thermal_value[i], phydm_get_thermal_offset(dm));
if (thermal_value_temp[i] > 63)
thermal_value[i] = 63;
else if (thermal_value_temp[i] < 0)
thermal_value[i] = 0;
else
thermal_value[i] = thermal_value_temp[i];
}
}
if ((tssi->thermal[RF_PATH_A] == 0xff || tssi->thermal[RF_PATH_B] == 0xff) &&
cali_info->txpowertrack_control != 3) {
for (i = 0; i < c.rf_path_count; i++)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no pg, tssi->thermal[%d] = 0x%x\n",
i, tssi->thermal[i]);
return;
}
for (j = 0; j < c.rf_path_count; j++) {
cali_info->thermal_value_avg_path[j][cali_info->thermal_value_avg_index_path[j]] = thermal_value[j];
cali_info->thermal_value_avg_index_path[j]++;
if (cali_info->thermal_value_avg_index_path[j] == c.average_thermal_num) /*Average times = c.average_thermal_num*/
cali_info->thermal_value_avg_index_path[j] = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (cali_info->thermal_value_avg_path[j][i]) {
thermal_value_avg[j] += cali_info->thermal_value_avg_path[j][i];
thermal_value_avg_count[j]++;
}
}
if (thermal_value_avg_count[j]) { /* Calculate Average thermal_value after average enough times */
thermal_value[j] = (u8)(thermal_value_avg[j] / thermal_value_avg_count[j]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"AVG Thermal Meter = 0x%X, tssi->thermal[%d] = 0x%x\n",
thermal_value[j], j, tssi->thermal[j]);
}
/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
/* "delta" here is used to determine whether thermal value changes or not. */
delta[j] = (thermal_value[j] > cali_info->thermal_value_path[j]) ? (thermal_value[j] - cali_info->thermal_value_path[j]) : (cali_info->thermal_value_path[j] - thermal_value[j]);
delta_LCK = (thermal_value[0] > cali_info->thermal_value_lck) ? (thermal_value[0] - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value[0]);
delta_IQK = (thermal_value[0] > cali_info->thermal_value_iqk) ? (thermal_value[0] - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value[0]);
}
/*4 6. If necessary, do LCK.*/
for (i = 0; i < c.rf_path_count; i++)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta[%d], delta_LCK, delta_IQK) = (%d, %d, %d)\n", i, delta[i], delta_LCK, delta_IQK);
/* Wait sacn to do LCK by RF Jenyu*/
if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
/* Delta temperature is equal to or larger than 20 centigrade.*/
if (delta_LCK >= c.threshold_iqk) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
cali_info->thermal_value_lck = thermal_value[RF_PATH_A];
/*Use RTLCK, so close power tracking driver LCK*/
if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
} else
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do not do LCK\n");
}
}
/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
for (i = 0; i < c.rf_path_count; i++) {
if (i == RF_PATH_B) {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_b, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_b, DELTA_SWINGIDX_SIZE);
} else if (i == RF_PATH_C) {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_c, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_c, DELTA_SWINGIDX_SIZE);
} else if (i == RF_PATH_D) {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_d, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_d, DELTA_SWINGIDX_SIZE);
} else {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_a, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_a, DELTA_SWINGIDX_SIZE);
}
cali_info->delta_power_index_last[i] = cali_info->delta_power_index[i]; /*recording poer index offset*/
delta[i] = thermal_value[i] > tssi->thermal[i] ? (thermal_value[i] - tssi->thermal[i]) : (tssi->thermal[i] - thermal_value[i]);
if (delta[i] >= TXPWR_TRACK_TABLE_SIZE)
delta[i] = TXPWR_TRACK_TABLE_SIZE - 1;
if (thermal_value[i] > tssi->thermal[i]) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup[%d]=%d Path=%d\n", delta[i], delta_swing_table_idx_tup[delta[i]], i);
cali_info->delta_power_index[i] = delta_swing_table_idx_tup[delta[i]];
cali_info->absolute_ofdm_swing_idx[i] = delta_swing_table_idx_tup[delta[i]]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[%d]=%d Path=%d\n", delta[i], cali_info->absolute_ofdm_swing_idx[i], i);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown[%d]=%d Path=%d\n", delta[i], delta_swing_table_idx_tdown[delta[i]], i);
cali_info->delta_power_index[i] = -1 * delta_swing_table_idx_tdown[delta[i]];
cali_info->absolute_ofdm_swing_idx[i] = -1 * delta_swing_table_idx_tdown[delta[i]]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[%d]=%d Path=%d\n", delta[i], cali_info->absolute_ofdm_swing_idx[i], i);
}
}
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p]) /*If Thermal value changes but lookup table value still the same*/
cali_info->power_index_offset[p] = 0;
else
cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p]; /*Power index diff between 2 times Power Tracking*/
}
#if 0
if (dm->support_ic_type == ODM_RTL8822C) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
}
#endif
if (*dm->mp_mode == 1) {
if (cali_info->txpowertrack_control == 1) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
tracking_method = MIX_MODE;
} else if (cali_info->txpowertrack_control == 3) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI_MODE**********\n");
tracking_method = TSSI_MODE;
}
} else {
if (rf->power_track_type >= 0 && rf->power_track_type <= 3) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
tracking_method = MIX_MODE;
} else if (rf->power_track_type >= 4 && rf->power_track_type <= 7) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI_MODE**********\n");
tracking_method = TSSI_MODE;
}
}
if (dm->support_ic_type == ODM_RTL8822C || dm->support_ic_type == ODM_RTL8814B)
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, tracking_method, p, 0);
/* Wait sacn to do IQK by RF Jenyu*/
if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden) && dm->is_linked) {
/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
if (delta_IQK >= c.threshold_iqk) {
cali_info->thermal_value_iqk = thermal_value[RF_PATH_A];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
/*if (!cali_info->is_iqk_in_progress)*/
/* (*c.do_iqk)(dm, delta_IQK, thermal_value[RF_PATH_A], 8);*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do IQK\n");
/*if (!cali_info->is_iqk_in_progress)*/
/* (*c.do_tssi_dck)(dm, true);*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do TSSI DCK\n");
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===%s\n", __func__);
cali_info->tx_powercount = 0;
}
#endif
/*@3============================================================
* 3 IQ Calibration
* 3============================================================
*/
void odm_reset_iqk_result(void *dm_void)
{
}
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
{
u8 channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64,
100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122,
124, 126, 128, 130, 132, 134, 136, 138, 140,
149, 151, 153, 155, 157, 159, 161, 163, 165};
u8 place = chnl;
if (chnl > 14) {
for (place = 14; place < sizeof(channel_all); place++) {
if (channel_all[place] == chnl)
return place - 13;
}
}
return 0;
}
#endif
void odm_iq_calibrate(struct dm_struct *dm)
{
void *adapter = dm->adapter;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
if (*dm->is_fcs_mode_enable)
return;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
if (IS_HARDWARE_TYPE_8812AU(adapter))
return;
#endif
if (dm->is_linked && !iqk_info->rfk_forbidden) {
if ((*dm->channel != dm->pre_channel) &&
(!*dm->is_scan_in_process)) {
dm->pre_channel = *dm->channel;
dm->linked_interval = 0;
}
if (dm->linked_interval < 3)
dm->linked_interval++;
if (dm->linked_interval == 2)
halrf_iqk_trigger(dm, false);
} else {
dm->linked_interval = 0;
}
}
void phydm_rf_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_init(dm);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
odm_clear_txpowertracking_state(dm);
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8814A_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8814A)
phy_iq_calibrate_8814a_init(dm);
#endif
#endif
}
void phydm_rf_watchdog(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
odm_txpowertracking_check(dm);
#if 0
/*if (dm->support_ic_type & ODM_IC_11AC_SERIES)*/
/*odm_iq_calibrate(dm);*/
#endif
#endif
}
================================================
FILE: hal/phydm/halrf/halphyrf_ce.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALPHYRF_H__
#define __HALPHYRF_H__
#include "halrf/halrf_kfree.h"
#if (RTL8814A_SUPPORT == 1)
#include "halrf/rtl8814a/halrf_iqk_8814a.h"
#endif
#if (RTL8822B_SUPPORT == 1)
#include "halrf/rtl8822b/halrf_iqk_8822b.h"
#endif
#if (RTL8821C_SUPPORT == 1)
#include "halrf/rtl8821c/halrf_iqk_8821c.h"
#endif
#if (RTL8195B_SUPPORT == 1)
/* #include "halrf/rtl8195b/halrf.h" */
#include "halrf/rtl8195b/halrf_iqk_8195b.h"
#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
#include "halrf/rtl8195b/halrf_dpk_8195b.h"
#endif
#if (RTL8814B_SUPPORT == 1)
#include "halrf/rtl8814b/halrf_iqk_8814b.h"
#include "halrf/rtl8814b/halrf_dpk_8814b.h"
#endif
#include "halrf/halrf_powertracking_ce.h"
enum spur_cal_method {
PLL_RESET,
AFE_PHASE_SEL
};
enum pwrtrack_method {
BBSWING,
TXAGC,
MIX_MODE,
TSSI_MODE,
MIX_2G_TSSI_5G_MODE,
MIX_5G_TSSI_2G_MODE,
CLEAN_MODE
};
typedef void (*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
typedef void (*func_iqk)(void *, u8, u8, u8);
typedef void (*func_lck)(void *);
typedef void (*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void (*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void (*func_swing_xtal)(void *, s8 **, s8 **);
typedef void (*func_set_xtal)(void *);
struct txpwrtrack_cfg {
u8 swing_table_size_cck;
u8 swing_table_size_ofdm;
u8 threshold_iqk;
u8 threshold_dpk;
u8 average_thermal_num;
u8 rf_path_count;
u32 thermal_reg_addr;
func_set_pwr odm_tx_pwr_track_set_pwr;
func_iqk do_iqk;
func_lck phy_lc_calibrate;
func_swing get_delta_swing_table;
func_swing8814only get_delta_swing_table8814only;
func_swing_xtal get_delta_swing_xtal_table;
func_set_xtal odm_txxtaltrack_set_xtal;
};
void configure_txpower_track(void *dm_void, struct txpwrtrack_cfg *config);
void odm_clear_txpowertracking_state(void *dm_void);
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
void odm_txpowertracking_callback_thermal_meter(void *dm_void);
#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
void odm_txpowertracking_callback_thermal_meter(void *dm);
#else
void odm_txpowertracking_callback_thermal_meter(void *adapter);
#endif
#if (RTL8822C_SUPPORT == 1)
void odm_txpowertracking_new_callback_thermal_meter(void *dm_void);
#endif
#define ODM_TARGET_CHNL_NUM_2G_5G 59
void odm_reset_iqk_result(void *dm_void);
u8 odm_get_right_chnl_place_for_iqk(u8 chnl);
void phydm_rf_init(void *dm_void);
void phydm_rf_watchdog(void *dm_void);
#endif /*__HALPHYRF_H__*/
================================================
FILE: hal/phydm/halrf/halphyrf_iot.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#include "mp_precomp.h"
#include "phydm_precomp.h"
#define CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
do {\
for (_offset = 0; _offset < _size; _offset++) { \
if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
if (_offset != 0)\
_offset--;\
break;\
} \
} \
if (_offset >= _size)\
_offset = _size-1;\
} while (0)
void configure_txpower_track(
void *dm_void,
struct txpwrtrack_cfg *config
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if RTL8195B_SUPPORT
if (dm->support_ic_type == ODM_RTL8195B)
configure_txpower_track_8195b(config);
#endif
#if RTL8710C_SUPPORT
if (dm->support_ic_type == ODM_RTL8710C)
configure_txpower_track_8710c(config);
#endif
#if RTL8721D_SUPPORT
if (dm->support_ic_type == ODM_RTL8721D)
configure_txpower_track_8721d(config);
#endif
}
/* **********************************************************************
* <20121113, Kordan> This function should be called when tx_agc changed.
* Otherwise the previous compensation is gone, because we record the
* delta of temperature between two TxPowerTracking watch dogs.
*
* NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
* need to call this function.
* ********************************************************************** */
void
odm_clear_txpowertracking_state(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u8 p = 0;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
dm->rf_calibrate_info.CCK_index = 0;
for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->power_index_offset[p] = 0;
cali_info->delta_power_index[p] = 0;
cali_info->delta_power_index_last[p] = 0;
cali_info->absolute_ofdm_swing_idx[p] = 0;
cali_info->remnant_ofdm_swing_idx[p] = 0;
cali_info->kfree_offset[p] = 0;
}
cali_info->modify_tx_agc_flag_path_a = false;
cali_info->modify_tx_agc_flag_path_b = false;
cali_info->modify_tx_agc_flag_path_c = false;
cali_info->modify_tx_agc_flag_path_d = false;
cali_info->remnant_cck_swing_idx = 0;
cali_info->thermal_value = rf->eeprom_thermal;
cali_info->modify_tx_agc_value_cck = 0;
cali_info->modify_tx_agc_value_ofdm = 0;
}
void
odm_txpowertracking_callback_thermal_meter(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
u8 thermal_value_avg_count = 0;
u32 thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
u8 OFDM_min_index = 0; /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
u8 indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
u8 power_tracking_type = rf->pwt_type;
u8 xtal_offset_eanble = 0;
s8 thermal_value_temp = 0;
struct txpwrtrack_cfg c = {0};
/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
u8 *delta_swing_table_idx_tup_a = NULL;
u8 *delta_swing_table_idx_tdown_a = NULL;
u8 *delta_swing_table_idx_tup_b = NULL;
u8 *delta_swing_table_idx_tdown_b = NULL;
#if (RTL8721D_SUPPORT == 1)
u8 *delta_swing_table_idx_tup_a_cck = NULL;
u8 *delta_swing_table_idx_tdown_a_cck = NULL;
u8 *delta_swing_table_idx_tup_b_cck = NULL;
u8 *delta_swing_table_idx_tdown_b_cck = NULL;
#endif
/*for Xtal Offset by James.Tung*/
s8 *delta_swing_table_xtal_up = NULL;
s8 *delta_swing_table_xtal_down = NULL;
/* 4 2. Initialization ( 7 steps in total ) */
configure_txpower_track(dm, &c);
#if (RTL8721D_SUPPORT == 1)
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b,
(u8 **)&delta_swing_table_idx_tup_a_cck, (u8 **)&delta_swing_table_idx_tdown_a_cck,
(u8 **)&delta_swing_table_idx_tup_b_cck, (u8 **)&delta_swing_table_idx_tdown_b_cck);
#else
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
#endif
/*for Xtal Offset*/
if (dm->support_ic_type == ODM_RTL8195B ||
dm->support_ic_type == ODM_RTL8721D)
(*c.get_delta_swing_xtal_table)(dm,
(s8 **)&delta_swing_table_xtal_up,
(s8 **)&delta_swing_table_xtal_down);
cali_info->txpowertracking_callback_cnt++; /*cosa add for debug*/
cali_info->is_txpowertracking_init = true;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
cali_info->bb_swing_idx_cck_base,
cali_info->bb_swing_idx_ofdm_base[RF_PATH_A],
cali_info->default_ofdm_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->txpowertrack_control = %d, hal_data->eeprom_thermal_meter %d\n",
cali_info->txpowertrack_control, rf->eeprom_thermal);
if (dm->support_ic_type == ODM_RTL8721D)
thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A,
c.thermal_reg_addr, 0x7e0);
/* 0x42: RF Reg[10:5] 8721D */
else
thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A,
c.thermal_reg_addr, 0xfc00);
/* 0x42: RF Reg[15:10] 88E */
thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp(%d) = thermal_value(%d) + power_trim_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
if (thermal_value_temp > 63)
thermal_value = 63;
else if (thermal_value_temp < 0)
thermal_value = 0;
else
thermal_value = thermal_value_temp;
if (!cali_info->txpowertrack_control)
return;
if (rf->eeprom_thermal == 0xff) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", rf->eeprom_thermal);
return;
}
#if 0
/*4 3. Initialize ThermalValues of rf_calibrate_info*/
//if (cali_info->is_reloadtxpowerindex)
// RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "reload ofdm index for band switch\n");
#endif
/*4 4. Calculate average thermal meter*/
cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
cali_info->thermal_value_avg_index++;
if (cali_info->thermal_value_avg_index == c.average_thermal_num) /*Average times = c.average_thermal_num*/
cali_info->thermal_value_avg_index = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (cali_info->thermal_value_avg[i]) {
thermal_value_avg += cali_info->thermal_value_avg[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) { /* Calculate Average thermal_value after average enough times */
thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
cali_info->thermal_value_delta = thermal_value - rf->eeprom_thermal;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, rf->eeprom_thermal);
}
/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
/* "delta" here is used to determine whether thermal value changes or not. */
delta = (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
/*4 6. If necessary, do LCK.*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
/* Wait sacn to do LCK by RF Jenyu*/
if ((!*dm->is_scan_in_process) && !iqk_info->rfk_forbidden &&
(!*dm->is_tdma)) {
/* Delta temperature is equal to or larger than 20 centigrade.*/
if (delta_LCK >= c.threshold_iqk) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
cali_info->thermal_value_lck = thermal_value;
/*Use RTLCK, so close power tracking driver LCK*/
(*c.phy_lc_calibrate)(dm);
}
}
/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
if (delta > 0 && cali_info->txpowertrack_control) {
/* "delta" here is used to record the absolute value of difference. */
delta = thermal_value > rf->eeprom_thermal ? (thermal_value - rf->eeprom_thermal) : (rf->eeprom_thermal - thermal_value);
if (delta >= TXPWR_TRACK_TABLE_SIZE)
delta = TXPWR_TRACK_TABLE_SIZE - 1;
/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
if (thermal_value > rf->eeprom_thermal) {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p]; /*recording poer index offset*/
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
#if (RTL8721D_SUPPORT == 1)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_b_cck[%d] = %d\n", delta, delta_swing_table_idx_tup_b_cck[delta]);
cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_b_cck[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_cck_swing_idx[RF_PATH_B] = %d\n",
cali_info->absolute_cck_swing_idx[p]);
#endif
cali_info->delta_power_index[p] =
delta_swing_table_idx_tup_b
[delta];
cali_info->absolute_ofdm_swing_idx[p] =
delta_swing_table_idx_tup_b
[delta];
/*Record delta swing for mix mode*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
#if (RTL8721D_SUPPORT == 1)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_a_cck[%d] = %d\n", delta, delta_swing_table_idx_tup_a_cck[delta]);
cali_info->absolute_cck_swing_idx[p] = delta_swing_table_idx_tup_a_cck[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_cck_swing_idx[p]);
#endif
cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
cali_info->absolute_ofdm_swing_idx[p] =
delta_swing_table_idx_tup_a[delta];
/*Record delta swing*/
/*for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
/* JJ ADD 20161014 */
if (dm->support_ic_type == ODM_RTL8195B ||
dm->support_ic_type == ODM_RTL8721D) {
/*Save xtal_offset from Xtal table*/
cali_info->xtal_offset_last = cali_info->xtal_offset; /*recording last Xtal offset*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
}
} else {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p]; /*recording poer index offset*/
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
#if (RTL8721D_SUPPORT == 1)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_b_cck[%d] = %d\n", delta, delta_swing_table_idx_tdown_b_cck[delta]);
cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b_cck[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_cck_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_cck_swing_idx[p]);
#endif
cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
#if (RTL8721D_SUPPORT == 1)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_a_cck[%d] = %d\n", delta, delta_swing_table_idx_tdown_a_cck[delta]);
cali_info->absolute_cck_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a_cck[delta];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_cck_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_cck_swing_idx[p]);
#endif
cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
/* JJ ADD 20161014 */
if (dm->support_ic_type == ODM_RTL8195B ||
dm->support_ic_type == ODM_RTL8721D) {
/*Save xtal_offset from Xtal table*/
cali_info->xtal_offset_last = cali_info->xtal_offset; /*recording last Xtal offset*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
xtal_offset_eanble = (cali_info->xtal_offset_last != cali_info->xtal_offset);
}
}
#if 0
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p]) /*If Thermal value changes but lookup table value still the same*/
cali_info->power_index_offset[p] = 0;
else
cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p]; /*Power index diff between 2 times Power Tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
cali_info->bb_swing_idx_cck = cali_info->CCK_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
/*************Print BB Swing base and index Offset*************/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
/*4 7.1 Handle boundary conditions of index.*/
if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
else if (cali_info->OFDM_index[p] <= OFDM_min_index)
cali_info->OFDM_index[p] = OFDM_min_index;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n\n========================================================================================================\n");
if (cali_info->CCK_index > c.swing_table_size_cck - 1)
cali_info->CCK_index = c.swing_table_size_cck - 1;
else if (cali_info->CCK_index <= 0)
cali_info->CCK_index = 0;
#endif
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
for (p = RF_PATH_A; p < c.rf_path_count; p++)
cali_info->power_index_offset[p] = 0;
}
#if 0
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
cali_info->CCK_index, cali_info->bb_swing_idx_cck_base); /*Print Swing base & current*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
}
#endif
if (thermal_value > rf->eeprom_thermal) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) higher than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
if (dm->support_ic_type == ODM_RTL8188E ||
dm->support_ic_type == ODM_RTL8192E ||
dm->support_ic_type == ODM_RTL8821 ||
dm->support_ic_type == ODM_RTL8812 ||
dm->support_ic_type == ODM_RTL8723B ||
dm->support_ic_type == ODM_RTL8814A ||
dm->support_ic_type == ODM_RTL8703B ||
dm->support_ic_type == ODM_RTL8188F ||
dm->support_ic_type == ODM_RTL8822B ||
dm->support_ic_type == ODM_RTL8723D ||
dm->support_ic_type == ODM_RTL8821C ||
dm->support_ic_type == ODM_RTL8710B ||
dm->support_ic_type == ODM_RTL8192F ||
dm->support_ic_type == ODM_RTL8195B ||
dm->support_ic_type == ODM_RTL8721D){
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
}
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) lower than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
if (dm->support_ic_type == ODM_RTL8188E ||
dm->support_ic_type == ODM_RTL8192E ||
dm->support_ic_type == ODM_RTL8821 ||
dm->support_ic_type == ODM_RTL8812 ||
dm->support_ic_type == ODM_RTL8723B ||
dm->support_ic_type == ODM_RTL8814A ||
dm->support_ic_type == ODM_RTL8703B ||
dm->support_ic_type == ODM_RTL8188F ||
dm->support_ic_type == ODM_RTL8822B ||
dm->support_ic_type == ODM_RTL8723D ||
dm->support_ic_type == ODM_RTL8821C ||
dm->support_ic_type == ODM_RTL8710B ||
dm->support_ic_type == ODM_RTL8192F ||
dm->support_ic_type == ODM_RTL8195B ||
dm->support_ic_type == ODM_RTL8721D) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
}
cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck; /*Record last time Power Tracking result as base.*/
for (p = RF_PATH_A; p < c.rf_path_count; p++)
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
cali_info->thermal_value = thermal_value; /*Record last Power Tracking Thermal value*/
}
/* JJ ADD 20161014 */
if (dm->support_ic_type == ODM_RTL8195B ||
dm->support_ic_type == ODM_RTL8721D) {
if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (rf->eeprom_thermal != 0xff)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
if (thermal_value > rf->eeprom_thermal) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) higher than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
(*c.odm_txxtaltrack_set_xtal)(dm);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) lower than PG value(%d)\n", thermal_value, rf->eeprom_thermal);
(*c.odm_txxtaltrack_set_xtal)(dm);
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
}
}
#if (!RTL8721D_SUPPORT)
/* Wait sacn to do IQK by RF Jenyu*/
if ((!*dm->is_scan_in_process) && (!iqk_info->rfk_forbidden)) {
/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
if (delta_IQK >= c.threshold_iqk) {
cali_info->thermal_value_iqk = thermal_value;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
if (!cali_info->is_iqk_in_progress)
(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
}
}
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
cali_info->tx_powercount = 0;
}
/* 3============================================================
* 3 IQ Calibration
* 3============================================================
*/
void
odm_reset_iqk_result(
void *dm_void
)
{
return;
}
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
{
u8 channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64,
100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122,
124, 126, 128, 130, 132, 134, 136, 138, 140,
149, 151, 153, 155, 157, 159, 161, 163, 165};
u8 place = chnl;
if (chnl > 14) {
for (place = 14; place < sizeof(channel_all); place++) {
if (channel_all[place] == chnl)
return place - 13;
}
}
return 0;
}
#endif
void
odm_iq_calibrate(
struct dm_struct *dm
)
{
#if (RTL8721D_SUPPORT == 1)
struct dm_iqk_info *iqk_info = &dm->IQK_info;
if (dm->is_linked && !iqk_info->rfk_forbidden) {
if ((*dm->channel != dm->pre_channel) &&
(!*dm->is_scan_in_process)) {
dm->pre_channel = *dm->channel;
dm->linked_interval = 0;
}
if (dm->linked_interval < 3)
dm->linked_interval++;
if (dm->linked_interval == 2)
halrf_iqk_trigger(dm, false);
} else {
dm->linked_interval = 0;
}
#endif
}
void phydm_rf_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_init(dm);
odm_clear_txpowertracking_state(dm);
}
void phydm_rf_watchdog(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_check(dm);
#if (RTL8721D_SUPPORT == 1)
odm_iq_calibrate(dm);
#endif
}
================================================
FILE: hal/phydm/halrf/halphyrf_iot.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALPHYRF_H__
#define __HALPHYRF_H__
#include "halrf/halrf_kfree.h"
#if (RTL8821C_SUPPORT == 1)
#include "halrf/rtl8821c/halrf_iqk_8821c.h"
#endif
#if (RTL8195B_SUPPORT == 1)
// #include "halrf/rtl8195b/halrf.h"
#include "halrf/rtl8195b/halrf_iqk_8195b.h"
#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
#include "halrf/rtl8195b/halrf_dpk_8195b.h"
#endif
#include "halrf/halrf_powertracking_iot.h"
enum spur_cal_method {
PLL_RESET,
AFE_PHASE_SEL
};
enum pwrtrack_method {
BBSWING,
TXAGC,
MIX_MODE,
TSSI_MODE,
MIX_2G_TSSI_5G_MODE,
MIX_5G_TSSI_2G_MODE
};
typedef void (*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
typedef void(*func_iqk)(void *, u8, u8, u8);
typedef void (*func_lck)(void *);
#if (RTL8721D_SUPPORT == 1)
typedef void (*func_swing)(void *, u8 **, u8 **, u8 **, u8 **,
u8 **, u8 **, u8 **, u8 **);
#else
typedef void (*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
#endif
typedef void (*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void(*func_swing_xtal)(void *, s8 **, s8 **);
typedef void(*func_set_xtal)(void *);
struct txpwrtrack_cfg {
u8 swing_table_size_cck;
u8 swing_table_size_ofdm;
u8 threshold_iqk;
u8 threshold_dpk;
u8 average_thermal_num;
u8 rf_path_count;
u32 thermal_reg_addr;
func_set_pwr odm_tx_pwr_track_set_pwr;
func_iqk do_iqk;
func_lck phy_lc_calibrate;
func_swing get_delta_swing_table;
func_swing8814only get_delta_swing_table8814only;
func_swing_xtal get_delta_swing_xtal_table;
func_set_xtal odm_txxtaltrack_set_xtal;
};
void
configure_txpower_track(
void *dm_void,
struct txpwrtrack_cfg *config
);
void
odm_clear_txpowertracking_state(
void *dm_void
);
void
odm_txpowertracking_callback_thermal_meter(
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
void *dm_void
#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
void *dm
#else
void *adapter
#endif
);
#define ODM_TARGET_CHNL_NUM_2G_5G 59
void
odm_reset_iqk_result(
void *dm_void
);
u8
odm_get_right_chnl_place_for_iqk(
u8 chnl
);
void phydm_rf_init(void *dm_void);
void phydm_rf_watchdog(void *dm_void);
#endif /*#ifndef __HALPHYRF_H__*/
================================================
FILE: hal/phydm/halrf/halphyrf_win.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#include "mp_precomp.h"
#include "phydm_precomp.h"
#define CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal) \
do {\
for (_offset = 0; _offset < _size; _offset++) { \
\
if (_delta_thermal < thermal_threshold[_direction][_offset]) { \
\
if (_offset != 0)\
_offset--;\
break;\
} \
} \
if (_offset >= _size)\
_offset = _size-1;\
} while (0)
void configure_txpower_track(
struct dm_struct *dm,
struct txpwrtrack_cfg *config
)
{
#if RTL8192E_SUPPORT
if (dm->support_ic_type == ODM_RTL8192E)
configure_txpower_track_8192e(config);
#endif
#if RTL8821A_SUPPORT
if (dm->support_ic_type == ODM_RTL8821)
configure_txpower_track_8821a(config);
#endif
#if RTL8812A_SUPPORT
if (dm->support_ic_type == ODM_RTL8812)
configure_txpower_track_8812a(config);
#endif
#if RTL8188E_SUPPORT
if (dm->support_ic_type == ODM_RTL8188E)
configure_txpower_track_8188e(config);
#endif
#if RTL8188F_SUPPORT
if (dm->support_ic_type == ODM_RTL8188F)
configure_txpower_track_8188f(config);
#endif
#if RTL8723B_SUPPORT
if (dm->support_ic_type == ODM_RTL8723B)
configure_txpower_track_8723b(config);
#endif
#if RTL8814A_SUPPORT
if (dm->support_ic_type == ODM_RTL8814A)
configure_txpower_track_8814a(config);
#endif
#if RTL8703B_SUPPORT
if (dm->support_ic_type == ODM_RTL8703B)
configure_txpower_track_8703b(config);
#endif
#if RTL8822B_SUPPORT
if (dm->support_ic_type == ODM_RTL8822B)
configure_txpower_track_8822b(config);
#endif
#if RTL8723D_SUPPORT
if (dm->support_ic_type == ODM_RTL8723D)
configure_txpower_track_8723d(config);
#endif
/* JJ ADD 20161014 */
#if RTL8710B_SUPPORT
if (dm->support_ic_type == ODM_RTL8710B)
configure_txpower_track_8710b(config);
#endif
#if RTL8821C_SUPPORT
if (dm->support_ic_type == ODM_RTL8821C)
configure_txpower_track_8821c(config);
#endif
#if RTL8192F_SUPPORT
if (dm->support_ic_type == ODM_RTL8192F)
configure_txpower_track_8192f(config);
#endif
#if RTL8822C_SUPPORT
if (dm->support_ic_type == ODM_RTL8822C)
configure_txpower_track_8822c(config);
#endif
#if RTL8814B_SUPPORT
if (dm->support_ic_type == ODM_RTL8814B)
configure_txpower_track_8814b(config);
#endif
}
/* **********************************************************************
* <20121113, Kordan> This function should be called when tx_agc changed.
* Otherwise the previous compensation is gone, because we record the
* delta of temperature between two TxPowerTracking watch dogs.
*
* NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
* need to call this function.
* ********************************************************************** */
void
odm_clear_txpowertracking_state(
struct dm_struct *dm
)
{
PHAL_DATA_TYPE hal_data = GET_HAL_DATA((PADAPTER)(dm->adapter));
u8 p = 0;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
cali_info->CCK_index = 0;
for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->power_index_offset[p] = 0;
cali_info->delta_power_index[p] = 0;
cali_info->delta_power_index_last[p] = 0;
cali_info->absolute_ofdm_swing_idx[p] = 0; /* Initial Mix mode power tracking*/
cali_info->remnant_ofdm_swing_idx[p] = 0;
cali_info->kfree_offset[p] = 0;
}
cali_info->modify_tx_agc_flag_path_a = false; /*Initial at Modify Tx Scaling mode*/
cali_info->modify_tx_agc_flag_path_b = false; /*Initial at Modify Tx Scaling mode*/
cali_info->modify_tx_agc_flag_path_c = false; /*Initial at Modify Tx Scaling mode*/
cali_info->modify_tx_agc_flag_path_d = false; /*Initial at Modify Tx Scaling mode*/
cali_info->remnant_cck_swing_idx = 0;
cali_info->thermal_value = hal_data->eeprom_thermal_meter;
cali_info->modify_tx_agc_value_cck = 0; /* modify by Mingzhi.Guo */
cali_info->modify_tx_agc_value_ofdm = 0; /* modify by Mingzhi.Guo */
}
void
odm_txpowertracking_callback_thermal_meter(
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
struct dm_struct *dm
#else
void *adapter
#endif
)
{
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
struct dm_struct *dm = &hal_data->DM_OutSrc;
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
struct dm_struct *dm = &hal_data->odmpriv;
#endif
#endif
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 thermal_value = 0, delta, delta_LCK, delta_IQK, p = 0, i = 0;
s8 diff_DPK[4] = {0};
u8 thermal_value_avg_count = 0;
u32 thermal_value_avg = 0, regc80, regcd0, regcd4, regab4, regc88, rege14, reg848,reg838, reg86c;
u8 OFDM_min_index = 0; /* OFDM BB Swing should be less than +3.0dB, which is required by Arthur */
u8 indexforchannel = 0; /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
u8 power_tracking_type = hal_data->RfPowerTrackingType;
u8 xtal_offset_eanble = 0;
s8 thermal_value_temp = 0;
struct txpwrtrack_cfg c;
/* 4 1. The following TWO tables decide the final index of OFDM/CCK swing table. */
u8 *delta_swing_table_idx_tup_a = NULL;
u8 *delta_swing_table_idx_tdown_a = NULL;
u8 *delta_swing_table_idx_tup_b = NULL;
u8 *delta_swing_table_idx_tdown_b = NULL;
/*for 8814 add by Yu Chen*/
u8 *delta_swing_table_idx_tup_c = NULL;
u8 *delta_swing_table_idx_tdown_c = NULL;
u8 *delta_swing_table_idx_tup_d = NULL;
u8 *delta_swing_table_idx_tdown_d = NULL;
/*for Xtal Offset by James.Tung*/
s8 *delta_swing_table_xtal_up = NULL;
s8 *delta_swing_table_xtal_down = NULL;
/* 4 2. Initilization ( 7 steps in total ) */
configure_txpower_track(dm, &c);
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8814B)) /*for 8814 path C & D*/
(*c.get_delta_swing_table8814only)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
/* JJ ADD 20161014 */
if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F)) /*for Xtal Offset*/
(*c.get_delta_swing_xtal_table)(dm, (s8 **)&delta_swing_table_xtal_up, (s8 **)&delta_swing_table_xtal_down);
cali_info->txpowertracking_callback_cnt++; /*cosa add for debug*/
cali_info->is_txpowertracking_init = true;
/*cali_info->txpowertrack_control = hal_data->txpowertrack_control;
We should keep updating the control variable according to HalData.
rf_calibrate_info.rega24 will be initialized when ODM HW configuring, but MP configures with para files. */
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
#if (MP_DRIVER == 1)
cali_info->rega24 = 0x090e1317;
#endif
#elif (DM_ODM_SUPPORT_TYPE & ODM_CE)
if (*(dm->mp_mode) == true)
cali_info->rega24 = 0x090e1317;
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->txpowertrack_control=%d, hal_data->eeprom_thermal_meter %d\n", cali_info->txpowertrack_control, hal_data->eeprom_thermal_meter);
thermal_value = (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10] 88E */
thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp(%d) = thermal_value(%d) + power_time_thermal(%d)\n", thermal_value_temp, thermal_value, phydm_get_thermal_offset(dm));
if (thermal_value_temp > 63)
thermal_value = 63;
else if (thermal_value_temp < 0)
thermal_value = 0;
else
thermal_value = thermal_value_temp;
/*add log by zhao he, check c80/c94/c14/ca0 value*/
if (dm->support_ic_type == ODM_RTL8723D) {
regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
RF_DBG(dm, DBG_RF_IQK, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
}
/* JJ ADD 20161014 */
if (dm->support_ic_type == ODM_RTL8710B) {
regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
RF_DBG(dm, DBG_RF_IQK, "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n", regc80, regcd0, regcd4, regab4);
}
/* Winnita add 20171205 */
if (dm->support_ic_type == ODM_RTL8192F) {
regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
regc88 = odm_get_bb_reg(dm, R_0xc88, MASKDWORD);
regab4 = odm_get_bb_reg(dm, R_0xab4, MASKDWORD);
rege14 = odm_get_bb_reg(dm, R_0xe14, MASKDWORD);
reg848 = odm_get_bb_reg(dm, R_0x848, MASKDWORD);
reg838 = odm_get_bb_reg(dm, R_0x838, MASKDWORD);
reg86c = odm_get_bb_reg(dm, R_0x86c, MASKDWORD);
RF_DBG(dm, DBG_RF_IQK, "0xc80 = 0x%x 0xc88 = 0x%x 0xab4 = 0x%x 0xe14 = 0x%x\n", regc80, regc88, regab4, rege14);
RF_DBG(dm, DBG_RF_IQK, "0x848 = 0x%x 0x838 = 0x%x 0x86c = 0x%x\n", reg848, reg838, reg86c);
}
if (!cali_info->txpowertrack_control)
return;
if (hal_data->eeprom_thermal_meter == 0xff) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no pg, hal_data->eeprom_thermal_meter = 0x%x\n", hal_data->eeprom_thermal_meter);
return;
}
/*4 3. Initialize ThermalValues of rf_calibrate_info*/
if (cali_info->is_reloadtxpowerindex)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "reload ofdm index for band switch\n");
/*4 4. Calculate average thermal meter*/
cali_info->thermal_value_avg[cali_info->thermal_value_avg_index] = thermal_value;
cali_info->thermal_value_avg_index++;
if (cali_info->thermal_value_avg_index == c.average_thermal_num) /*Average times = c.average_thermal_num*/
cali_info->thermal_value_avg_index = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (cali_info->thermal_value_avg[i]) {
thermal_value_avg += cali_info->thermal_value_avg[i];
thermal_value_avg_count++;
}
}
if (thermal_value_avg_count) { /* Calculate Average thermal_value after average enough times */
thermal_value = (u8)(thermal_value_avg / thermal_value_avg_count);
cali_info->thermal_value_delta = thermal_value - hal_data->eeprom_thermal_meter;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n", thermal_value, hal_data->eeprom_thermal_meter);
}
/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
/* "delta" here is used to determine whether thermal value changes or not. */
delta = (thermal_value > cali_info->thermal_value) ? (thermal_value - cali_info->thermal_value) : (cali_info->thermal_value - thermal_value);
delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
if (cali_info->thermal_value_iqk == 0xff) { /*no PG, use thermal value for IQK*/
cali_info->thermal_value_iqk = thermal_value;
delta_IQK = (thermal_value > cali_info->thermal_value_iqk) ? (thermal_value - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no PG, use thermal_value for IQK\n");
}
for (p = RF_PATH_A; p < c.rf_path_count; p++)
diff_DPK[p] = (s8)thermal_value - (s8)cali_info->dpk_thermal[p];
/*4 6. If necessary, do LCK.*/
if (!(dm->support_ic_type & ODM_RTL8821)) { /*no PG, do LCK at initial status*/
if (cali_info->thermal_value_lck == 0xff) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no PG, do LCK\n");
cali_info->thermal_value_lck = thermal_value;
/*Use RTLCK, so close power tracking driver LCK*/
if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
}
delta_LCK = (thermal_value > cali_info->thermal_value_lck) ? (thermal_value - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value);
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta, delta_LCK, delta_IQK) = (%d, %d, %d)\n", delta, delta_LCK, delta_IQK);
/* Wait sacn to do LCK by RF Jenyu*/
if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
/* Delta temperature is equal to or larger than 20 centigrade.*/
if (delta_LCK >= c.threshold_iqk) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
cali_info->thermal_value_lck = thermal_value;
/*Use RTLCK, so close power tracking driver LCK*/
if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
}
}
}
}
/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
if (delta > 0 && cali_info->txpowertrack_control) {
/* "delta" here is used to record the absolute value of differrence. */
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
delta = thermal_value > hal_data->eeprom_thermal_meter ? (thermal_value - hal_data->eeprom_thermal_meter) : (hal_data->eeprom_thermal_meter - thermal_value);
#else
delta = (thermal_value > dm->priv->pmib->dot11RFEntry.ther) ? (thermal_value - dm->priv->pmib->dot11RFEntry.ther) : (dm->priv->pmib->dot11RFEntry.ther - thermal_value);
#endif
if (delta >= TXPWR_TRACK_TABLE_SIZE)
delta = TXPWR_TRACK_TABLE_SIZE - 1;
/*4 7.1 The Final Power index = BaseIndex + power_index_offset*/
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
if (thermal_value > hal_data->eeprom_thermal_meter) {
#else
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
#endif
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p]; /*recording poer index offset*/
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_b[%d] = %d\n", delta, delta_swing_table_idx_tup_b[delta]);
cali_info->delta_power_index[p] = delta_swing_table_idx_tup_b[delta];
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_b[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_c[%d] = %d\n", delta, delta_swing_table_idx_tup_c[delta]);
cali_info->delta_power_index[p] = delta_swing_table_idx_tup_c[delta];
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_c[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_d[%d] = %d\n", delta, delta_swing_table_idx_tup_d[delta]);
cali_info->delta_power_index[p] = delta_swing_table_idx_tup_d[delta];
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_d[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup_a[%d] = %d\n", delta, delta_swing_table_idx_tup_a[delta]);
cali_info->delta_power_index[p] = delta_swing_table_idx_tup_a[delta];
cali_info->absolute_ofdm_swing_idx[p] = delta_swing_table_idx_tup_a[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
/* JJ ADD 20161014 */
if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F)) {
/*Save xtal_offset from Xtal table*/
cali_info->xtal_offset_last = cali_info->xtal_offset; /*recording last Xtal offset*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[Xtal] delta_swing_table_xtal_up[%d] = %d\n", delta, delta_swing_table_xtal_up[delta]);
cali_info->xtal_offset = delta_swing_table_xtal_up[delta];
if (cali_info->xtal_offset_last == cali_info->xtal_offset)
xtal_offset_eanble = 0;
else
xtal_offset_eanble = 1;
}
} else {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
cali_info->delta_power_index_last[p] = cali_info->delta_power_index[p]; /*recording poer index offset*/
switch (p) {
case RF_PATH_B:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_b[%d] = %d\n", delta, delta_swing_table_idx_tdown_b[delta]);
cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_b[delta];
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_b[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_B] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_C:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_c[%d] = %d\n", delta, delta_swing_table_idx_tdown_c[delta]);
cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_c[delta];
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_c[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_C] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
case RF_PATH_D:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_d[%d] = %d\n", delta, delta_swing_table_idx_tdown_d[delta]);
cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_d[delta];
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_d[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_D] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
default:
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown_a[%d] = %d\n", delta, delta_swing_table_idx_tdown_a[delta]);
cali_info->delta_power_index[p] = -1 * delta_swing_table_idx_tdown_a[delta];
cali_info->absolute_ofdm_swing_idx[p] = -1 * delta_swing_table_idx_tdown_a[delta]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[RF_PATH_A] = %d\n", cali_info->absolute_ofdm_swing_idx[p]);
break;
}
}
/* JJ ADD 20161014 */
if (dm->support_ic_type & (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F)) {
/*Save xtal_offset from Xtal table*/
cali_info->xtal_offset_last = cali_info->xtal_offset; /*recording last Xtal offset*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[Xtal] delta_swing_table_xtal_down[%d] = %d\n", delta, delta_swing_table_xtal_down[delta]);
cali_info->xtal_offset = delta_swing_table_xtal_down[delta];
if (cali_info->xtal_offset_last == cali_info->xtal_offset)
xtal_offset_eanble = 0;
else
xtal_offset_eanble = 1;
}
}
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n\n=========================== [path-%d] Calculating power_index_offset===========================\n", p);
if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p]) /*If Thermal value changes but lookup table value still the same*/
cali_info->power_index_offset[p] = 0;
else
cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p]; /*Power index diff between 2 times Power Tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"[path-%d] power_index_offset(%d) = delta_power_index(%d) - delta_power_index_last(%d)\n", p, cali_info->power_index_offset[p], cali_info->delta_power_index[p], cali_info->delta_power_index_last[p]);
cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
cali_info->bb_swing_idx_cck = cali_info->CCK_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
/*************Print BB Swing base and index Offset*************/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_cck, cali_info->bb_swing_idx_cck_base, cali_info->power_index_offset[p]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n", cali_info->bb_swing_idx_ofdm[p], p, cali_info->bb_swing_idx_ofdm_base[p], cali_info->power_index_offset[p]);
/*4 7.1 Handle boundary conditions of index.*/
if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
else if (cali_info->OFDM_index[p] <= OFDM_min_index)
cali_info->OFDM_index[p] = OFDM_min_index;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"\n\n========================================================================================================\n");
if (cali_info->CCK_index > c.swing_table_size_cck - 1)
cali_info->CCK_index = c.swing_table_size_cck - 1;
else if (cali_info->CCK_index <= 0)
cali_info->CCK_index = 0;
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"The thermal meter is unchanged or TxPowerTracking OFF(%d): thermal_value: %d, cali_info->thermal_value: %d\n",
cali_info->txpowertrack_control, thermal_value, cali_info->thermal_value);
for (p = RF_PATH_A; p < c.rf_path_count; p++)
cali_info->power_index_offset[p] = 0;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
cali_info->CCK_index, cali_info->bb_swing_idx_cck_base); /*Print Swing base & current*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
cali_info->OFDM_index[p], p, cali_info->bb_swing_idx_ofdm_base[p]);
}
if (dm->support_ic_type & ODM_RTL8814B)
power_tracking_type = TSSI_MODE;
if (dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8814B)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "power_tracking_type=%d\n", power_tracking_type);
if (power_tracking_type == 0) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else if (power_tracking_type == 1) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(2G) TSSI(5G) MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_2G_TSSI_5G_MODE, p, 0);
} else if (power_tracking_type == 2) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX(5G) TSSI(2G)MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_5G_TSSI_2G_MODE, p, 0);
} else if (power_tracking_type == 3) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, TSSI_MODE, p, 0);
}
cali_info->thermal_value = thermal_value; /*Record last Power Tracking Thermal value*/
} else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
cali_info->power_index_offset[RF_PATH_B] != 0 ||
cali_info->power_index_offset[RF_PATH_C] != 0 ||
cali_info->power_index_offset[RF_PATH_D] != 0) &&
cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
/* 4 7.2 Configure the Swing Table to adjust Tx Power. */
cali_info->is_tx_power_changed = true; /*Always true after Tx Power is adjusted by power tracking.*/
/* */
/* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital */
/* to increase TX power. Otherwise, EVM will be bad. */
/* */
/* 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E. */
if (thermal_value > cali_info->thermal_value) {
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
}
} else if (thermal_value < cali_info->thermal_value) { /*Low temperature*/
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
p, cali_info->power_index_offset[p], delta, thermal_value, hal_data->eeprom_thermal_meter, cali_info->thermal_value);
}
}
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
if (thermal_value > hal_data->eeprom_thermal_meter)
#else
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther)
#endif
{
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B ||
dm->support_ic_type == ODM_RTL8192F) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
}
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8821 ||
dm->support_ic_type == ODM_RTL8812 || dm->support_ic_type == ODM_RTL8723B || dm->support_ic_type == ODM_RTL8814A ||
dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8188F || dm->support_ic_type == ODM_RTL8822B ||
dm->support_ic_type == ODM_RTL8723D || dm->support_ic_type == ODM_RTL8821C || dm->support_ic_type == ODM_RTL8710B ||
dm->support_ic_type == ODM_RTL8192F) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, indexforchannel);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, indexforchannel);
}
}
cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck; /*Record last time Power Tracking result as base.*/
for (p = RF_PATH_A; p < c.rf_path_count; p++)
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->thermal_value = %d thermal_value= %d\n", cali_info->thermal_value, thermal_value);
cali_info->thermal_value = thermal_value; /*Record last Power Tracking Thermal value*/
}
if (dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D ||
dm->support_ic_type == ODM_RTL8192F || dm->support_ic_type == ODM_RTL8710B) {/* JJ ADD 20161014 */
if (xtal_offset_eanble != 0 && cali_info->txpowertrack_control && (hal_data->eeprom_thermal_meter != 0xff)) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter Xtal Tracking**********\n");
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
if (thermal_value > hal_data->eeprom_thermal_meter) {
#else
if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) higher than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
(*c.odm_txxtaltrack_set_xtal)(dm);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Temperature(%d) lower than PG value(%d)\n", thermal_value, hal_data->eeprom_thermal_meter);
(*c.odm_txxtaltrack_set_xtal)(dm);
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********End Xtal Tracking**********\n");
}
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
/* Wait sacn to do IQK by RF Jenyu*/
if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
if (!IS_HARDWARE_TYPE_8723B(adapter)) {
/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
if (delta_IQK >= c.threshold_iqk) {
cali_info->thermal_value_iqk = thermal_value;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
if (!cali_info->is_iqk_in_progress)
(*c.do_iqk)(dm, delta_IQK, thermal_value, 8);
}
}
}
if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
}
}
if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
} else {
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
}
}
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===odm_txpowertracking_callback_thermal_meter\n");
cali_info->tx_powercount = 0;
}
#if (RTL8822C_SUPPORT == 1 || RTL8814B_SUPPORT == 1)
void
odm_txpowertracking_new_callback_thermal_meter(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
struct _halrf_tssi_data *tssi = &rf->halrf_tssi_data;
u8 thermal_value[MAX_RF_PATH] = {0}, delta[MAX_RF_PATH] = {0};
u8 delta_swing_table_idx_tup[DELTA_SWINGIDX_SIZE] = {0};
u8 delta_swing_table_idx_tdown[DELTA_SWINGIDX_SIZE] = {0};
u8 delta_LCK = 0, delta_IQK = 0, i = 0, j = 0, p;
u8 thermal_value_avg_count[MAX_RF_PATH] = {0};
u32 thermal_value_avg[MAX_RF_PATH] = {0};
s8 thermal_value_temp[MAX_RF_PATH] = {0};
u8 tracking_method = MIX_MODE;
struct txpwrtrack_cfg c;
u8 *delta_swing_table_idx_tup_a = NULL;
u8 *delta_swing_table_idx_tdown_a = NULL;
u8 *delta_swing_table_idx_tup_b = NULL;
u8 *delta_swing_table_idx_tdown_b = NULL;
u8 *delta_swing_table_idx_tup_c = NULL;
u8 *delta_swing_table_idx_tdown_c = NULL;
u8 *delta_swing_table_idx_tup_d = NULL;
u8 *delta_swing_table_idx_tdown_d = NULL;
configure_txpower_track(dm, &c);
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_a, (u8 **)&delta_swing_table_idx_tdown_a,
(u8 **)&delta_swing_table_idx_tup_b, (u8 **)&delta_swing_table_idx_tdown_b);
if (dm->support_ic_type == ODM_RTL8814B) {
(*c.get_delta_swing_table)(dm, (u8 **)&delta_swing_table_idx_tup_c, (u8 **)&delta_swing_table_idx_tdown_c,
(u8 **)&delta_swing_table_idx_tup_d, (u8 **)&delta_swing_table_idx_tdown_d);
}
cali_info->txpowertracking_callback_cnt++;
cali_info->is_txpowertracking_init = true;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"===>odm_txpowertracking_callback_thermal_meter\n cali_info->bb_swing_idx_cck_base: %d, cali_info->bb_swing_idx_ofdm_base[A]: %d, cali_info->default_ofdm_index: %d\n",
cali_info->bb_swing_idx_cck_base, cali_info->bb_swing_idx_ofdm_base[RF_PATH_A], cali_info->default_ofdm_index);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"cali_info->txpowertrack_control=%d, tssi->thermal[RF_PATH_A]=%d tssi->thermal[RF_PATH_B]=%d\n",
cali_info->txpowertrack_control, tssi->thermal[RF_PATH_A], tssi->thermal[RF_PATH_B]);
if (dm->support_ic_type == ODM_RTL8822C) {
for (i = 0; i < c.rf_path_count; i++)
thermal_value[i] = (u8)odm_get_rf_reg(dm, i, c.thermal_reg_addr, 0x7e); /* 0x42: RF Reg[6:1] Thermal Trim*/
} else {
for (i = 0; i < c.rf_path_count; i++) {
thermal_value[i] = (u8)odm_get_rf_reg(dm, i, c.thermal_reg_addr, 0xfc00); /* 0x42: RF Reg[15:10]*/
thermal_value_temp[i] = (s8)thermal_value[i] + phydm_get_thermal_offset(dm);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"thermal_value_temp[%d](%d) = thermal_value[%d](%d) + power_time_thermal(%d)\n", i, thermal_value_temp[i], i, thermal_value[i], phydm_get_thermal_offset(dm));
if (thermal_value_temp[i] > 63)
thermal_value[i] = 63;
else if (thermal_value_temp[i] < 0)
thermal_value[i] = 0;
else
thermal_value[i] = thermal_value_temp[i];
}
}
if ((tssi->thermal[RF_PATH_A] == 0xff || tssi->thermal[RF_PATH_B] == 0xff)) {
for (i = 0; i < c.rf_path_count; i++)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "no pg, tssi->thermal[%d] = 0x%x\n",
i, tssi->thermal[i]);
return;
}
for (j = 0; j < c.rf_path_count; j++) {
cali_info->thermal_value_avg_path[j][cali_info->thermal_value_avg_index_path[j]] = thermal_value[j];
cali_info->thermal_value_avg_index_path[j]++;
if (cali_info->thermal_value_avg_index_path[j] == c.average_thermal_num) /*Average times = c.average_thermal_num*/
cali_info->thermal_value_avg_index_path[j] = 0;
for (i = 0; i < c.average_thermal_num; i++) {
if (cali_info->thermal_value_avg_path[j][i]) {
thermal_value_avg[j] += cali_info->thermal_value_avg_path[j][i];
thermal_value_avg_count[j]++;
}
}
if (thermal_value_avg_count[j]) { /* Calculate Average thermal_value after average enough times */
thermal_value[j] = (u8)(thermal_value_avg[j] / thermal_value_avg_count[j]);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"AVG Thermal Meter = 0x%X, tssi->thermal[%d] = 0x%x\n",
thermal_value[j], j, tssi->thermal[j]);
}
/* 4 5. Calculate delta, delta_LCK, delta_IQK. */
/* "delta" here is used to determine whether thermal value changes or not. */
delta[j] = (thermal_value[j] > cali_info->thermal_value_path[j]) ? (thermal_value[j] - cali_info->thermal_value_path[j]) : (cali_info->thermal_value_path[j] - thermal_value[j]);
delta_LCK = (thermal_value[0] > cali_info->thermal_value_lck) ? (thermal_value[0] - cali_info->thermal_value_lck) : (cali_info->thermal_value_lck - thermal_value[0]);
delta_IQK = (thermal_value[0] > cali_info->thermal_value_iqk) ? (thermal_value[0] - cali_info->thermal_value_iqk) : (cali_info->thermal_value_iqk - thermal_value[0]);
}
/*4 6. If necessary, do LCK.*/
for (i = 0; i < c.rf_path_count; i++)
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "(delta[%d], delta_LCK, delta_IQK) = (%d, %d, %d)\n", i, delta[i], delta_LCK, delta_IQK);
/* Wait sacn to do LCK by RF Jenyu*/
if( (*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
/* Delta temperature is equal to or larger than 20 centigrade.*/
if (delta_LCK >= c.threshold_iqk) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_LCK(%d) >= threshold_iqk(%d)\n", delta_LCK, c.threshold_iqk);
cali_info->thermal_value_lck = thermal_value[RF_PATH_A];
/*Use RTLCK, so close power tracking driver LCK*/
if ((!(dm->support_ic_type & ODM_RTL8814A)) && (!(dm->support_ic_type & ODM_RTL8822B))) {
if (c.phy_lc_calibrate)
(*c.phy_lc_calibrate)(dm);
} else
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do not do LCK\n");
}
}
/*3 7. If necessary, move the index of swing table to adjust Tx power.*/
for (i = 0; i < c.rf_path_count; i++) {
if (i == RF_PATH_B) {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_b, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_b, DELTA_SWINGIDX_SIZE);
} else if (i == RF_PATH_C) {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_c, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_c, DELTA_SWINGIDX_SIZE);
} else if (i == RF_PATH_D) {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_d, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_d, DELTA_SWINGIDX_SIZE);
} else {
odm_move_memory(dm, delta_swing_table_idx_tup, delta_swing_table_idx_tup_a, DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, delta_swing_table_idx_tdown, delta_swing_table_idx_tdown_a, DELTA_SWINGIDX_SIZE);
}
cali_info->delta_power_index_last[i] = cali_info->delta_power_index[i]; /*recording poer index offset*/
delta[i] = thermal_value[i] > tssi->thermal[i] ? (thermal_value[i] - tssi->thermal[i]) : (tssi->thermal[i] - thermal_value[i]);
if (delta[i] >= TXPWR_TRACK_TABLE_SIZE)
delta[i] = TXPWR_TRACK_TABLE_SIZE - 1;
if (thermal_value[i] > tssi->thermal[i]) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tup[%d]=%d Path=%d\n", delta[i], delta_swing_table_idx_tup[delta[i]], i);
cali_info->delta_power_index[i] = delta_swing_table_idx_tup[delta[i]];
cali_info->absolute_ofdm_swing_idx[i] = delta_swing_table_idx_tup[delta[i]]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is higher and cali_info->absolute_ofdm_swing_idx[%d]=%d Path=%d\n", delta[i], cali_info->absolute_ofdm_swing_idx[i], i);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"delta_swing_table_idx_tdown[%d]=%d Path=%d\n", delta[i], delta_swing_table_idx_tdown[delta[i]], i);
cali_info->delta_power_index[i] = -1 * delta_swing_table_idx_tdown[delta[i]];
cali_info->absolute_ofdm_swing_idx[i] = -1 * delta_swing_table_idx_tdown[delta[i]]; /*Record delta swing for mix mode power tracking*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"******Temp is lower and cali_info->absolute_ofdm_swing_idx[%d]=%d Path=%d\n", delta[i], cali_info->absolute_ofdm_swing_idx[i], i);
}
}
for (p = RF_PATH_A; p < c.rf_path_count; p++) {
if (cali_info->delta_power_index[p] == cali_info->delta_power_index_last[p]) /*If Thermal value changes but lookup table value still the same*/
cali_info->power_index_offset[p] = 0;
else
cali_info->power_index_offset[p] = cali_info->delta_power_index[p] - cali_info->delta_power_index_last[p]; /*Power index diff between 2 times Power Tracking*/
}
#if 0
if (dm->support_ic_type == ODM_RTL8822C) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
} else {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking BBSWING_MODE**********\n");
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, BBSWING, p, 0);
}
#endif
if (*dm->mp_mode == 1) {
if (cali_info->txpowertrack_control == 1) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
tracking_method = MIX_MODE;
} else if (cali_info->txpowertrack_control == 3) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI_MODE**********\n");
tracking_method = TSSI_MODE;
}
} else {
if (rf->power_track_type >= 0 && rf->power_track_type <= 3) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking MIX_MODE**********\n");
tracking_method = MIX_MODE;
} else if (rf->power_track_type >= 4 && rf->power_track_type <= 7) {
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "**********Enter POWER Tracking TSSI_MODE**********\n");
tracking_method = TSSI_MODE;
}
}
if (dm->support_ic_type == ODM_RTL8822C || dm->support_ic_type == ODM_RTL8814B)
for (p = RF_PATH_A; p < c.rf_path_count; p++)
(*c.odm_tx_pwr_track_set_pwr)(dm, tracking_method, p, 0);
/* Wait sacn to do IQK by RF Jenyu*/
if ((*dm->is_scan_in_process == false) && (!iqk_info->rfk_forbidden)) {
/*Delta temperature is equal to or larger than 20 centigrade (When threshold is 8).*/
if (delta_IQK >= c.threshold_iqk) {
cali_info->thermal_value_iqk = thermal_value[RF_PATH_A];
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "delta_IQK(%d) >= threshold_iqk(%d)\n", delta_IQK, c.threshold_iqk);
/*if (!cali_info->is_iqk_in_progress)*/
/* (*c.do_iqk)(dm, delta_IQK, thermal_value[RF_PATH_A], 8);*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do IQK\n");
/*if (!cali_info->is_iqk_in_progress)*/
/* (*c.do_tssi_dck)(dm, true);*/
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Do TSSI DCK\n");
}
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===%s\n", __func__);
cali_info->tx_powercount = 0;
}
#endif
/* 3============================================================
* 3 IQ Calibration
* 3============================================================ */
void
odm_reset_iqk_result(
struct dm_struct *dm
)
{
return;
}
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
{
u8 channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122, 124, 126, 128, 130, 132, 134, 136, 138, 140, 149, 151, 153, 155, 157, 159, 161, 163, 165
};
u8 place = chnl;
if (chnl > 14) {
for (place = 14; place < sizeof(channel_all); place++) {
if (channel_all[place] == chnl)
return place - 13;
}
}
return 0;
}
#endif
void
odm_iq_calibrate(
struct dm_struct *dm
)
{
void *adapter = dm->adapter;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
RF_DBG(dm, DBG_RF_IQK, "=>%s\n",__FUNCTION__);
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
if (*dm->is_fcs_mode_enable)
return;
#endif
if ((dm->is_linked) && (!iqk_info->rfk_forbidden)) {
RF_DBG(dm, DBG_RF_IQK, "interval=%d ch=%d prech=%d scan=%s\n", dm->linked_interval,
*dm->channel, dm->pre_channel, *dm->is_scan_in_process == TRUE ? "TRUE":"FALSE");
if (*dm->channel != dm->pre_channel) {
dm->pre_channel = *dm->channel;
dm->linked_interval = 0;
}
if ((dm->linked_interval < 3) && (!*dm->is_scan_in_process))
dm->linked_interval++;
if (dm->linked_interval == 2)
PHY_IQCalibrate(adapter, false);
} else
dm->linked_interval = 0;
RF_DBG(dm, DBG_RF_IQK, "<=%s interval=%d ch=%d prech=%d scan=%s\n", __FUNCTION__, dm->linked_interval,
*dm->channel, dm->pre_channel, *dm->is_scan_in_process == TRUE?"TRUE":"FALSE");
}
void phydm_rf_init(struct dm_struct *dm)
{
odm_txpowertracking_init(dm);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
odm_clear_txpowertracking_state(dm);
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8814A_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8814A)
phy_iq_calibrate_8814a_init(dm);
#endif
#endif
}
void phydm_rf_watchdog(struct dm_struct *dm)
{
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
#if (MP_DRIVER == 1)
/*struct _ADAPTER *adapter = dm->adapter;*/
/*PMPT_CONTEXT p_mpt_ctx = &(adapter->MptCtx);*/
#endif
FunctionIn(COMP_MLME);
if (*dm->mp_mode == 1) {
#if (MP_DRIVER == 1)
/*if (p_mpt_ctx->bTxPowerTrackOn)*/
odm_txpowertracking_check(dm);
#endif
} else {
odm_txpowertracking_check(dm);
if (dm->support_ic_type & (ODM_IC_11AC_SERIES | ODM_IC_JGR3_SERIES))
odm_iq_calibrate(dm);
}
#endif
}
================================================
FILE: hal/phydm/halrf/halphyrf_win.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HALPHYRF_H__
#define __HALPHYRF_H__
#if (RTL8814A_SUPPORT == 1)
#include "halrf/rtl8814a/halrf_iqk_8814a.h"
#endif
#if (RTL8822B_SUPPORT == 1)
#include "halrf/rtl8822b/halrf_iqk_8822b.h"
#include "../mac/Halmac_type.h"
#endif
#include "halrf/halrf_powertracking_win.h"
#include "halrf/halrf_kfree.h"
#include "halrf/halrf_txgapcal.h"
#if (RTL8821C_SUPPORT == 1)
#include "halrf/rtl8821c/halrf_iqk_8821c.h"
#endif
#if (RTL8195B_SUPPORT == 1)
// #include "halrf/rtl8195b/halrf.h"
#include "halrf/rtl8195b/halrf_iqk_8195b.h"
#include "halrf/rtl8195b/halrf_txgapk_8195b.h"
#include "halrf/rtl8195b/halrf_dpk_8195b.h"
#endif
#if (RTL8814B_SUPPORT == 1)
#include "halrf/rtl8814b/halrf_iqk_8814b.h"
#endif
enum spur_cal_method {
PLL_RESET,
AFE_PHASE_SEL
};
enum pwrtrack_method {
BBSWING,
TXAGC,
MIX_MODE,
TSSI_MODE,
MIX_2G_TSSI_5G_MODE,
MIX_5G_TSSI_2G_MODE,
CLEAN_MODE
};
typedef void(*func_set_pwr)(void *, enum pwrtrack_method, u8, u8);
typedef void(*func_iqk)(void *, u8, u8, u8);
typedef void(*func_lck)(void *);
typedef void(*func_swing)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void(*func_swing8814only)(void *, u8 **, u8 **, u8 **, u8 **);
typedef void (*func_swing_xtal)(void *, s8 **, s8 **);
typedef void (*func_set_xtal)(void *);
typedef void(*func_all_swing)(void *, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **, u8 **);
struct txpwrtrack_cfg {
u8 swing_table_size_cck;
u8 swing_table_size_ofdm;
u8 threshold_iqk;
u8 threshold_dpk;
u8 average_thermal_num;
u8 rf_path_count;
u32 thermal_reg_addr;
func_set_pwr odm_tx_pwr_track_set_pwr;
func_iqk do_iqk;
func_lck phy_lc_calibrate;
func_swing get_delta_swing_table;
func_swing8814only get_delta_swing_table8814only;
func_swing_xtal get_delta_swing_xtal_table;
func_set_xtal odm_txxtaltrack_set_xtal;
func_all_swing get_delta_all_swing_table;
};
void
configure_txpower_track(
struct dm_struct *dm,
struct txpwrtrack_cfg *config
);
void
odm_clear_txpowertracking_state(
struct dm_struct *dm
);
void
odm_txpowertracking_callback_thermal_meter(
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
struct dm_struct *dm
#else
void *adapter
#endif
);
#if (RTL8822C_SUPPORT == 1)
void
odm_txpowertracking_new_callback_thermal_meter(void *dm_void);
#endif
#define ODM_TARGET_CHNL_NUM_2G_5G 59
void
odm_reset_iqk_result(
struct dm_struct *dm
);
u8
odm_get_right_chnl_place_for_iqk(
u8 chnl
);
void odm_iq_calibrate(struct dm_struct *dm);
void phydm_rf_init(struct dm_struct *dm);
void phydm_rf_watchdog(struct dm_struct *dm);
#endif /*#ifndef __HALPHYRF_H__*/
================================================
FILE: hal/phydm/halrf/halrf.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*@************************************************************
* include files
* ************************************************************
*/
#include "mp_precomp.h"
#include "phydm_precomp.h"
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1 ||\
RTL8812F_SUPPORT == 1)
void _iqk_check_if_reload(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
iqk_info->is_reload = (boolean)odm_get_bb_reg(dm, R_0x1bf0, BIT(16));
}
void _iqk_page_switch(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (dm->support_ic_type == ODM_RTL8821C)
odm_write_4byte(dm, 0x1b00, 0xf8000008);
else
odm_write_4byte(dm, 0x1b00, 0xf800000a);
}
u32 halrf_psd_log2base(u32 val)
{
u8 j;
u32 tmp, tmp2, val_integerd_b = 0, tindex, shiftcount = 0;
u32 result, val_fractiond_b = 0;
u32 table_fraction[21] = {
0, 432, 332, 274, 232, 200, 174, 151, 132, 115,
100, 86, 74, 62, 51, 42, 32, 23, 15, 7, 0};
if (val == 0)
return 0;
tmp = val;
while (1) {
if (tmp == 1)
break;
tmp = (tmp >> 1);
shiftcount++;
}
val_integerd_b = shiftcount + 1;
tmp2 = 1;
for (j = 1; j <= val_integerd_b; j++)
tmp2 = tmp2 * 2;
tmp = (val * 100) / tmp2;
tindex = tmp / 5;
if (tindex > 20)
tindex = 20;
val_fractiond_b = table_fraction[tindex];
result = val_integerd_b * 100 - val_fractiond_b;
return result;
}
void phydm_get_iqk_cfir(void *dm_void, u8 idx, u8 path, boolean debug)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 i, ch;
u32 tmp;
u32 bit_mask_20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
if (debug)
ch = 2;
else
ch = 0;
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0xf8000008 | path << 1);
if (idx == 0)
odm_set_bb_reg(dm, R_0x1b0c, BIT(13) | BIT(12), 0x3);
else
odm_set_bb_reg(dm, R_0x1b0c, BIT(13) | BIT(12), 0x1);
odm_set_bb_reg(dm, R_0x1bd4, bit_mask_20_16, 0x10);
for (i = 0; i < 8; i++) {
odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0xe0000001 + (i * 4));
tmp = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
iqk_info->iqk_cfir_real[ch][path][idx][i] =
(u16)((tmp & 0x0fff0000) >> 16);
iqk_info->iqk_cfir_imag[ch][path][idx][i] = (u16)(tmp & 0xfff);
}
odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
odm_set_bb_reg(dm, R_0x1b0c, BIT(13) | BIT(12), 0x0);
}
void halrf_iqk_xym_enable(struct dm_struct *dm, u8 xym_enable)
{
struct dm_iqk_info *iqk_info = &dm->IQK_info;
if (xym_enable == 0)
iqk_info->xym_read = false;
else
iqk_info->xym_read = true;
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s %s\n", "xym_read = ",
(iqk_info->xym_read ? "true" : "false"));
}
/*xym_type => 0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
void halrf_iqk_xym_read(void *dm_void, u8 path, u8 xym_type)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 i, start, num;
u32 tmp1, tmp2;
if (!iqk_info->xym_read)
return;
if (*dm->band_width == 0) {
start = 3;
num = 4;
} else if (*dm->band_width == 1) {
start = 2;
num = 6;
} else {
start = 0;
num = 10;
}
odm_write_4byte(dm, 0x1b00, 0xf8000008);
tmp1 = odm_read_4byte(dm, 0x1b1c);
odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
odm_write_4byte(dm, 0x1b00, 0xf800000a);
tmp2 = odm_read_4byte(dm, 0x1b1c);
odm_write_4byte(dm, 0x1b1c, 0xa2193c32);
for (path = 0; path < 2; path++) {
odm_write_4byte(dm, 0x1b00, 0xf8000008 | path << 1);
switch (xym_type) {
case 0:
for (i = 0; i < num; i++) {
odm_write_4byte(dm, 0x1b14, 0xe6 + start + i);
odm_write_4byte(dm, 0x1b14, 0x0);
iqk_info->rx_xym[path][i] =
odm_read_4byte(dm, 0x1b38);
}
break;
case 1:
for (i = 0; i < num; i++) {
odm_write_4byte(dm, 0x1b14, 0xe6 + start + i);
odm_write_4byte(dm, 0x1b14, 0x0);
iqk_info->tx_xym[path][i] =
odm_read_4byte(dm, 0x1b38);
}
break;
case 2:
for (i = 0; i < 6; i++) {
odm_write_4byte(dm, 0x1b14, 0xe0 + i);
odm_write_4byte(dm, 0x1b14, 0x0);
iqk_info->gs1_xym[path][i] =
odm_read_4byte(dm, 0x1b38);
}
break;
case 3:
for (i = 0; i < 6; i++) {
odm_write_4byte(dm, 0x1b14, 0xe0 + i);
odm_write_4byte(dm, 0x1b14, 0x0);
iqk_info->gs2_xym[path][i] =
odm_read_4byte(dm, 0x1b38);
}
break;
case 4:
for (i = 0; i < 6; i++) {
odm_write_4byte(dm, 0x1b14, 0xe0 + i);
odm_write_4byte(dm, 0x1b14, 0x0);
iqk_info->rxk1_xym[path][i] =
odm_read_4byte(dm, 0x1b38);
}
break;
}
odm_write_4byte(dm, 0x1b38, 0x20000000);
odm_write_4byte(dm, 0x1b00, 0xf8000008);
odm_write_4byte(dm, 0x1b1c, tmp1);
odm_write_4byte(dm, 0x1b00, 0xf800000a);
odm_write_4byte(dm, 0x1b1c, tmp2);
_iqk_page_switch(dm);
}
}
/*xym_type => 0: rx_sym; 1: tx_xym; 2:gs1_xym; 3:gs2_sym; 4: rxk1_xym*/
void halrf_iqk_xym_show(struct dm_struct *dm, u8 xym_type)
{
u8 num, path, path_num, i;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
if (dm->rf_type == RF_1T1R)
path_num = 0x1;
else if (dm->rf_type == RF_2T2R)
path_num = 0x2;
else
path_num = 0x4;
if (*dm->band_width == CHANNEL_WIDTH_20)
num = 4;
else if (*dm->band_width == CHANNEL_WIDTH_40)
num = 6;
else
num = 10;
for (path = 0; path < path_num; path++) {
switch (xym_type) {
case 0:
for (i = 0; i < num; i++)
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-20s %-2d: 0x%x\n",
(path == 0) ? "PATH A RX-XYM " :
"PATH B RX-XYM", i,
iqk_info->rx_xym[path][i]);
break;
case 1:
for (i = 0; i < num; i++)
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-20s %-2d: 0x%x\n",
(path == 0) ? "PATH A TX-XYM " :
"PATH B TX-XYM", i,
iqk_info->tx_xym[path][i]);
break;
case 2:
for (i = 0; i < 6; i++)
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-20s %-2d: 0x%x\n",
(path == 0) ? "PATH A GS1-XYM " :
"PATH B GS1-XYM", i,
iqk_info->gs1_xym[path][i]);
break;
case 3:
for (i = 0; i < 6; i++)
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-20s %-2d: 0x%x\n",
(path == 0) ? "PATH A GS2-XYM " :
"PATH B GS2-XYM", i,
iqk_info->gs2_xym[path][i]);
break;
case 4:
for (i = 0; i < 6; i++)
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-20s %-2d: 0x%x\n",
(path == 0) ? "PATH A RXK1-XYM " :
"PATH B RXK1-XYM", i,
iqk_info->rxk1_xym[path][i]);
break;
}
}
}
void halrf_iqk_xym_dump(void *dm_void)
{
u32 tmp1, tmp2;
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_write_4byte(dm, 0x1b00, 0xf8000008);
tmp1 = odm_read_4byte(dm, 0x1b1c);
odm_write_4byte(dm, 0x1b00, 0xf800000a);
tmp2 = odm_read_4byte(dm, 0x1b1c);
#if 0
/*halrf_iqk_xym_read(dm, xym_type);*/
#endif
odm_write_4byte(dm, 0x1b00, 0xf8000008);
odm_write_4byte(dm, 0x1b1c, tmp1);
odm_write_4byte(dm, 0x1b00, 0xf800000a);
odm_write_4byte(dm, 0x1b1c, tmp2);
_iqk_page_switch(dm);
}
void halrf_iqk_info_dump(void *dm_void, u32 *_used, char *output, u32 *_out_len)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 used = *_used;
u32 out_len = *_out_len;
u8 rf_path, j, reload_iqk = 0;
u32 tmp;
/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
boolean iqk_result[2][NUM][2];
struct dm_iqk_info *iqk_info = &dm->IQK_info;
if (!(dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C)))
return;
/* IQK INFO */
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s\n",
"% IQK Info %");
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s\n",
(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" :
"Driver-IQK");
reload_iqk = (u8)odm_get_bb_reg(dm, R_0x1bf0, BIT(16));
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"reload", (reload_iqk) ? "True" : "False");
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"rfk_forbidden", (iqk_info->rfk_forbidden) ? "True" : "False");
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"segment_iqk", (iqk_info->segment_iqk) ? "True" : "False");
#endif
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s:%d %d\n",
"iqk count / fail count", dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %d\n",
"channel", *dm->channel);
if (*dm->band_width == CHANNEL_WIDTH_20)
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: %s\n", "bandwidth", "BW_20");
else if (*dm->band_width == CHANNEL_WIDTH_40)
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: %s\n", "bandwidth", "BW_40");
else if (*dm->band_width == CHANNEL_WIDTH_80)
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: %s\n", "bandwidth", "BW_80");
else if (*dm->band_width == CHANNEL_WIDTH_160)
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: %s\n", "bandwidth", "BW_160");
else
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: %s\n", "bandwidth", "BW_UNKNOWN");
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: %llu %s\n", "progressing_time",
dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
tmp = odm_read_4byte(dm, 0x1bf0);
for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
for (j = 0; j < 2; j++)
iqk_result[0][rf_path][j] = (boolean)
(tmp & (BIT(rf_path + (j * 4)) >> (rf_path + (j * 4))));
PDM_SNPF(out_len, used, output + used, out_len - used,
"%-20s: 0x%08x\n", "Reg0x1bf0", tmp);
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"PATH_A-Tx result",
(iqk_result[0][RF_PATH_A][0]) ? "Fail" : "Pass");
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"PATH_A-Rx result",
(iqk_result[0][RF_PATH_A][1]) ? "Fail" : "Pass");
#if (RTL8822B_SUPPORT == 1)
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"PATH_B-Tx result",
(iqk_result[0][RF_PATH_B][0]) ? "Fail" : "Pass");
PDM_SNPF(out_len, used, output + used, out_len - used, "%-20s: %s\n",
"PATH_B-Rx result",
(iqk_result[0][RF_PATH_B][1]) ? "Fail" : "Pass");
#endif
*_used = used;
*_out_len = out_len;
}
void halrf_get_fw_version(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
rf->fw_ver = (dm->fw_version << 16) | dm->fw_sub_version;
}
void halrf_iqk_dbg(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 rf_path, j;
u32 tmp;
/*two channel, PATH, TX/RX, 0:pass 1 :fail*/
boolean iqk_result[2][NUM][2];
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
/* IQK INFO */
RF_DBG(dm, DBG_RF_IQK, "%-20s\n", "====== IQK Info ======");
RF_DBG(dm, DBG_RF_IQK, "%-20s\n",
(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW-IQK" :
"Driver-IQK");
if (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) {
halrf_get_fw_version(dm);
RF_DBG(dm, DBG_RF_IQK, "%-20s: 0x%x\n", "FW_VER", rf->fw_ver);
} else {
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "IQK_VER", HALRF_IQK_VER);
}
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "reload",
(iqk_info->is_reload) ? "True" : "False");
RF_DBG(dm, DBG_RF_IQK, "%-20s: %d %d\n", "iqk count / fail count",
dm->n_iqk_cnt, dm->n_iqk_fail_cnt);
RF_DBG(dm, DBG_RF_IQK, "%-20s: %d\n", "channel", *dm->channel);
if (*dm->band_width == CHANNEL_WIDTH_20)
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_20");
else if (*dm->band_width == CHANNEL_WIDTH_40)
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_40");
else if (*dm->band_width == CHANNEL_WIDTH_80)
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_80");
else if (*dm->band_width == CHANNEL_WIDTH_160)
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth", "BW_160");
else
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "bandwidth",
"BW_UNKNOWN");
#if 0
/*
* RF_DBG(dm, DBG_RF_IQK, "%-20s: %llu %s\n",
* "progressing_time",
* dm->rf_calibrate_info.iqk_total_progressing_time, "(ms)");
*/
#endif
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "rfk_forbidden",
(iqk_info->rfk_forbidden) ? "True" : "False");
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "segment_iqk",
(iqk_info->segment_iqk) ? "True" : "False");
#endif
RF_DBG(dm, DBG_RF_IQK, "%-20s: %llu %s\n", "progressing_time",
dm->rf_calibrate_info.iqk_progressing_time, "(ms)");
tmp = odm_read_4byte(dm, 0x1bf0);
for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++)
for (j = 0; j < 2; j++)
iqk_result[0][rf_path][j] = (boolean)
(tmp & (BIT(rf_path + (j * 4)) >> (rf_path + (j * 4))));
RF_DBG(dm, DBG_RF_IQK, "%-20s: 0x%08x\n", "Reg0x1bf0", tmp);
RF_DBG(dm, DBG_RF_IQK, "%-20s: 0x%08x\n", "Reg0x1be8",
odm_read_4byte(dm, 0x1be8));
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_A-Tx result",
(iqk_result[0][RF_PATH_A][0]) ? "Fail" : "Pass");
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_A-Rx result",
(iqk_result[0][RF_PATH_A][1]) ? "Fail" : "Pass");
#if (RTL8822B_SUPPORT == 1)
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_B-Tx result",
(iqk_result[0][RF_PATH_B][0]) ? "Fail" : "Pass");
RF_DBG(dm, DBG_RF_IQK, "%-20s: %s\n", "PATH_B-Rx result",
(iqk_result[0][RF_PATH_B][1]) ? "Fail" : "Pass");
#endif
}
void halrf_lck_dbg(struct dm_struct *dm)
{
RF_DBG(dm, DBG_RF_IQK, "%-20s\n", "====== LCK Info ======");
#if 0
/*RF_DBG(dm, DBG_RF_IQK, "%-20s\n",
* (dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "LCK" : "RTK"));
*/
#endif
RF_DBG(dm, DBG_RF_IQK, "%-20s: %llu %s\n", "progressing_time",
dm->rf_calibrate_info.lck_progressing_time, "(ms)");
}
void halrf_iqk_dbg_cfir_backup(struct dm_struct *dm)
{
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 path, idx, i;
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "backup TX/RX CFIR");
for (path = 0; path < 2; path++)
for (idx = 0; idx < 2; idx++)
phydm_get_iqk_cfir(dm, idx, path, true);
for (path = 0; path < 2; path++) {
for (idx = 0; idx < 2; idx++) {
for (i = 0; i < 8; i++) {
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-7s %-3s CFIR_real: %-2d: 0x%x\n",
(path == 0) ? "PATH A" : "PATH B",
(idx == 0) ? "TX" : "RX", i,
iqk_info->iqk_cfir_real[2][path][idx][i])
;
}
for (i = 0; i < 8; i++) {
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-7s %-3s CFIR_img:%-2d: 0x%x\n",
(path == 0) ? "PATH A" : "PATH B",
(idx == 0) ? "TX" : "RX", i,
iqk_info->iqk_cfir_imag[2][path][idx][i])
;
}
}
}
}
void halrf_iqk_dbg_cfir_backup_update(struct dm_struct *dm)
{
struct dm_iqk_info *iqk = &dm->IQK_info;
u8 i, path, idx;
u32 bmask13_12 = BIT(13) | BIT(12);
u32 bmask20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
u32 data;
if (iqk->iqk_cfir_real[2][0][0][0] == 0) {
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "CFIR is invalid");
return;
}
for (path = 0; path < 2; path++) {
for (idx = 0; idx < 2; idx++) {
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD,
0xf8000008 | path << 1);
odm_set_bb_reg(dm, R_0x1b2c, MASKDWORD, 0x7);
odm_set_bb_reg(dm, R_0x1b38, MASKDWORD, 0x20000000);
odm_set_bb_reg(dm, R_0x1b3c, MASKDWORD, 0x20000000);
odm_set_bb_reg(dm, R_0x1bcc, MASKDWORD, 0x00000000);
if (idx == 0)
odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x3);
else
odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x1);
odm_set_bb_reg(dm, R_0x1bd4, bmask20_16, 0x10);
for (i = 0; i < 8; i++) {
data = ((0xc0000000 >> idx) + 0x3) + (i * 4) +
(iqk->iqk_cfir_real[2][path][idx][i]
<< 9);
odm_write_4byte(dm, 0x1bd8, data);
data = ((0xc0000000 >> idx) + 0x1) + (i * 4) +
(iqk->iqk_cfir_imag[2][path][idx][i]
<< 9);
odm_write_4byte(dm, 0x1bd8, data);
#if 0
/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_real[2][path][idx][i]);*/
/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_imag[2][path][idx][i]);*/
#endif
}
}
odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x0);
}
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "update new CFIR");
}
void halrf_iqk_dbg_cfir_reload(struct dm_struct *dm)
{
struct dm_iqk_info *iqk = &dm->IQK_info;
u8 i, path, idx;
u32 bmask13_12 = BIT(13) | BIT(12);
u32 bmask20_16 = BIT(20) | BIT(19) | BIT(18) | BIT(17) | BIT(16);
u32 data;
if (iqk->iqk_cfir_real[0][0][0][0] == 0) {
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "CFIR is invalid");
return;
}
for (path = 0; path < 2; path++) {
for (idx = 0; idx < 2; idx++) {
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD,
0xf8000008 | path << 1);
odm_set_bb_reg(dm, R_0x1b2c, MASKDWORD, 0x7);
odm_set_bb_reg(dm, R_0x1b38, MASKDWORD, 0x20000000);
odm_set_bb_reg(dm, R_0x1b3c, MASKDWORD, 0x20000000);
odm_set_bb_reg(dm, R_0x1bcc, MASKDWORD, 0x00000000);
if (idx == 0)
odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x3);
else
odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x1);
odm_set_bb_reg(dm, R_0x1bd4, bmask20_16, 0x10);
for (i = 0; i < 8; i++) {
#if 0
/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_real[0][path][idx][i]);*/
/*odm_write_4byte(dm, 0x1bd8, iqk->iqk_cfir_imag[0][path][idx][i]);*/
#endif
data = ((0xc0000000 >> idx) + 0x3) + (i * 4) +
(iqk->iqk_cfir_real[0][path][idx][i]
<< 9);
odm_write_4byte(dm, 0x1bd8, data);
data = ((0xc0000000 >> idx) + 0x1) + (i * 4) +
(iqk->iqk_cfir_imag[0][path][idx][i]
<< 9);
odm_write_4byte(dm, 0x1bd8, data);
}
}
odm_set_bb_reg(dm, R_0x1bd8, MASKDWORD, 0x0);
odm_set_bb_reg(dm, R_0x1b0c, bmask13_12, 0x0);
}
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "write CFIR with default value");
}
void halrf_iqk_dbg_cfir_write(struct dm_struct *dm, u8 type, u32 path, u32 idx,
u32 i, u32 data)
{
struct dm_iqk_info *iqk_info = &dm->IQK_info;
if (type == 0)
iqk_info->iqk_cfir_real[2][path][idx][i] = (u16)data;
else
iqk_info->iqk_cfir_imag[2][path][idx][i] = (u16)data;
}
void halrf_iqk_dbg_cfir_backup_show(struct dm_struct *dm)
{
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u8 path, idx, i;
RF_DBG(dm, DBG_RF_IQK, "[IQK]%-20s\n", "backup TX/RX CFIR");
for (path = 0; path < 2; path++) {
for (idx = 0; idx < 2; idx++) {
for (i = 0; i < 8; i++) {
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-10s %-3s CFIR_real:%-2d: 0x%x\n",
(path == 0) ? "PATH A" : "PATH B",
(idx == 0) ? "TX" : "RX", i,
iqk_info->iqk_cfir_real[2][path][idx][i])
;
}
for (i = 0; i < 8; i++) {
RF_DBG(dm, DBG_RF_IQK,
"[IQK]%-10s %-3s CFIR_img:%-2d: 0x%x\n",
(path == 0) ? "PATH A" : "PATH B",
(idx == 0) ? "TX" : "RX", i,
iqk_info->iqk_cfir_imag[2][path][idx][i])
;
}
}
}
}
void halrf_do_imr_test(void *dm_void, u8 flag_imr_test)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (flag_imr_test != 0x0)
switch (dm->support_ic_type) {
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
do_imr_test_8822b(dm);
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
do_imr_test_8821c(dm);
break;
#endif
default:
break;
}
}
void halrf_iqk_debug(void *dm_void, u32 *const dm_value, u32 *_used,
char *output, u32 *_out_len)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if 0
/*dm_value[0]=0x0: backup from SRAM & show*/
/*dm_value[0]=0x1: write backup CFIR to SRAM*/
/*dm_value[0]=0x2: reload default CFIR to SRAM*/
/*dm_value[0]=0x3: show backup*/
/*dm_value[0]=0x10: write backup CFIR real part*/
/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/
/*dm_value[0]=0x11: write backup CFIR imag*/
/*--> dm_value[1]:path, dm_value[2]:tx/rx, dm_value[3]:index, dm_value[4]:data*/
/*dm_value[0]=0x20 :xym_read enable*/
/*--> dm_value[1]:0:disable, 1:enable*/
/*if dm_value[0]=0x20 = enable, */
/*0x1:show rx_sym; 0x2: tx_xym; 0x3:gs1_xym; 0x4:gs2_sym; 0x5:rxk1_xym*/
#endif
if (dm_value[0] == 0x0)
halrf_iqk_dbg_cfir_backup(dm);
else if (dm_value[0] == 0x1)
halrf_iqk_dbg_cfir_backup_update(dm);
else if (dm_value[0] == 0x2)
halrf_iqk_dbg_cfir_reload(dm);
else if (dm_value[0] == 0x3)
halrf_iqk_dbg_cfir_backup_show(dm);
else if (dm_value[0] == 0x10)
halrf_iqk_dbg_cfir_write(dm, 0, dm_value[1], dm_value[2],
dm_value[3], dm_value[4]);
else if (dm_value[0] == 0x11)
halrf_iqk_dbg_cfir_write(dm, 1, dm_value[1], dm_value[2],
dm_value[3], dm_value[4]);
else if (dm_value[0] == 0x20)
halrf_iqk_xym_enable(dm, (u8)dm_value[1]);
else if (dm_value[0] == 0x21)
halrf_iqk_xym_show(dm, (u8)dm_value[1]);
else if (dm_value[0] == 0x30)
halrf_do_imr_test(dm, (u8)dm_value[1]);
}
void halrf_iqk_hwtx_check(void *dm_void, boolean is_check)
{
#if 0
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u32 tmp_b04;
if (is_check) {
iqk_info->is_hwtx = (boolean)odm_get_bb_reg(dm, R_0xb00, BIT(8));
} else {
if (iqk_info->is_hwtx) {
tmp_b04 = odm_read_4byte(dm, 0xb04);
odm_set_bb_reg(dm, R_0xb04, BIT(3) | BIT(2), 0x0);
odm_write_4byte(dm, 0xb04, tmp_b04);
}
}
#endif
}
#endif
u8 halrf_match_iqk_version(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 iqk_version = 0;
char temp[10] = {0};
odm_move_memory(dm, temp, HALRF_IQK_VER, sizeof(temp));
PHYDM_SSCANF(temp + 2, DCMD_HEX, &iqk_version);
if (dm->support_ic_type == ODM_RTL8822B) {
if (iqk_version >= 0x24 && (odm_get_hw_img_version(dm) >= 72))
return 1;
else if ((iqk_version <= 0x23) &&
(odm_get_hw_img_version(dm) <= 71))
return 1;
else
return 0;
}
if (dm->support_ic_type == ODM_RTL8821C) {
if (iqk_version >= 0x18 && (odm_get_hw_img_version(dm) >= 37))
return 1;
else
return 0;
}
return 1;
}
void halrf_rf_lna_setting(void *dm_void, enum halrf_lna_set type)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
switch (dm->support_ic_type) {
#if (RTL8188E_SUPPORT == 1)
case ODM_RTL8188E:
halrf_rf_lna_setting_8188e(dm, type);
break;
#endif
#if (RTL8192E_SUPPORT == 1)
case ODM_RTL8192E:
halrf_rf_lna_setting_8192e(dm, type);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
halrf_rf_lna_setting_8192f(dm, type);
break;
#endif
#if (RTL8723B_SUPPORT == 1)
case ODM_RTL8723B:
halrf_rf_lna_setting_8723b(dm, type);
break;
#endif
#if (RTL8812A_SUPPORT == 1)
case ODM_RTL8812:
halrf_rf_lna_setting_8812a(dm, type);
break;
#endif
#if ((RTL8821A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1))
case ODM_RTL8881A:
case ODM_RTL8821:
halrf_rf_lna_setting_8821a(dm, type);
break;
#endif
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
halrf_rf_lna_setting_8822b(dm_void, type);
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
halrf_rf_lna_setting_8822c(dm_void, type);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
halrf_rf_lna_setting_8812f(dm_void, type);
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
halrf_rf_lna_setting_8821c(dm_void, type);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
break;
#endif
default:
break;
}
}
void halrf_support_ability_debug(void *dm_void, char input[][16], u32 *_used,
char *output, u32 *_out_len)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u32 dm_value[10] = {0};
u32 used = *_used;
u32 out_len = *_out_len;
u8 i;
for (i = 0; i < 5; i++)
if (input[i + 1])
PHYDM_SSCANF(input[i + 2], DCMD_DECIMAL, &dm_value[i]);
if (dm_value[0] == 100) {
PDM_SNPF(out_len, used, output + used, out_len - used,
"\n[RF Supportability]\n");
PDM_SNPF(out_len, used, output + used, out_len - used,
"00. (( %s ))Power Tracking\n",
((rf->rf_supportability & HAL_RF_TX_PWR_TRACK) ?
("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"01. (( %s ))IQK\n",
((rf->rf_supportability & HAL_RF_IQK) ? ("V") :
(".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"02. (( %s ))LCK\n",
((rf->rf_supportability & HAL_RF_LCK) ? ("V") :
(".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"03. (( %s ))DPK\n",
((rf->rf_supportability & HAL_RF_DPK) ? ("V") :
(".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"04. (( %s ))HAL_RF_TXGAPK\n",
((rf->rf_supportability & HAL_RF_TXGAPK) ? ("V") :
(".")));
} else {
if (dm_value[1] == 1) /* enable */
rf->rf_supportability |= BIT(dm_value[0]);
else if (dm_value[1] == 2) /* disable */
rf->rf_supportability &= ~(BIT(dm_value[0]));
else
PDM_SNPF(out_len, used, output + used, out_len - used,
"[Warning!!!] 1:enable, 2:disable\n");
}
PDM_SNPF(out_len, used, output + used, out_len - used,
"\nCurr-RF_supportability = 0x%x\n\n", rf->rf_supportability);
*_used = used;
*_out_len = out_len;
}
void halrf_cmn_info_init(void *dm_void, enum halrf_cmninfo_init cmn_info,
u32 value)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
switch (cmn_info) {
case HALRF_CMNINFO_EEPROM_THERMAL_VALUE:
rf->eeprom_thermal = (u8)value;
break;
case HALRF_CMNINFO_PWT_TYPE:
rf->pwt_type = (u8)value;
break;
default:
break;
}
}
void halrf_cmn_info_hook(void *dm_void, enum halrf_cmninfo_hook cmn_info,
void *value)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
switch (cmn_info) {
case HALRF_CMNINFO_CON_TX:
rf->is_con_tx = (boolean *)value;
break;
case HALRF_CMNINFO_SINGLE_TONE:
rf->is_single_tone = (boolean *)value;
break;
case HALRF_CMNINFO_CARRIER_SUPPRESSION:
rf->is_carrier_suppresion = (boolean *)value;
break;
case HALRF_CMNINFO_MP_RATE_INDEX:
rf->mp_rate_index = (u8 *)value;
break;
case HALRF_CMNINFO_MANUAL_RF_SUPPORTABILITY:
rf->manual_rf_supportability = (u32 *)value;
break;
default:
/*do nothing*/
break;
}
}
void halrf_cmn_info_set(void *dm_void, u32 cmn_info, u64 value)
{
/* This init variable may be changed in run time. */
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
switch (cmn_info) {
case HALRF_CMNINFO_ABILITY:
rf->rf_supportability = (u32)value;
break;
case HALRF_CMNINFO_DPK_EN:
rf->dpk_en = (u8)value;
break;
case HALRF_CMNINFO_RFK_FORBIDDEN:
dm->IQK_info.rfk_forbidden = (boolean)value;
break;
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
case HALRF_CMNINFO_IQK_SEGMENT:
dm->IQK_info.segment_iqk = (boolean)value;
break;
#endif
case HALRF_CMNINFO_RATE_INDEX:
rf->p_rate_index = (u32)value;
break;
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
case HALRF_CMNINFO_MP_PSD_POINT:
rf->halrf_psd_data.point = (u32)value;
break;
case HALRF_CMNINFO_MP_PSD_START_POINT:
rf->halrf_psd_data.start_point = (u32)value;
break;
case HALRF_CMNINFO_MP_PSD_STOP_POINT:
rf->halrf_psd_data.stop_point = (u32)value;
break;
case HALRF_CMNINFO_MP_PSD_AVERAGE:
rf->halrf_psd_data.average = (u32)value;
break;
#endif
default:
/* do nothing */
break;
}
}
u64 halrf_cmn_info_get(void *dm_void, u32 cmn_info)
{
/* This init variable may be changed in run time. */
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u64 return_value = 0;
switch (cmn_info) {
case HALRF_CMNINFO_ABILITY:
return_value = (u32)rf->rf_supportability;
break;
case HALRF_CMNINFO_RFK_FORBIDDEN:
return_value = dm->IQK_info.rfk_forbidden;
break;
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || \
RTL8821C_SUPPORT == 1 || RTL8195B_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1)
case HALRF_CMNINFO_IQK_SEGMENT:
return_value = dm->IQK_info.segment_iqk;
break;
case HALRF_CMNINFO_IQK_TIMES:
return_value = dm->IQK_info.iqk_times;
break;
#endif
default:
/* do nothing */
break;
}
return return_value;
}
void halrf_supportability_init_mp(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
switch (dm->support_ic_type) {
case ODM_RTL8814B:
#if (RTL8814B_SUPPORT == 1)
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_DACK |
HAL_RF_DPK_TRACK |
0;
#endif
break;
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
/*@HAL_RF_DPK |*/
0;
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_DACK |
HAL_RF_DPK_TRACK |
0;
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
/*@HAL_RF_DPK |*/
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_TXGAPK |
HAL_RF_DPK_TRACK |
0;
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_DACK |
HAL_RF_DPK_TRACK |
0;
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
default:
rf->rf_supportability =
/*HAL_RF_TX_PWR_TRACK |*/
HAL_RF_IQK |
HAL_RF_LCK |
/*@HAL_RF_DPK |*/
/*@HAL_RF_TXGAPK |*/
0;
break;
}
RF_DBG(dm, DBG_RF_INIT,
"IC = ((0x%x)), RF_Supportability Init MP = ((0x%x))\n",
dm->support_ic_type, rf->rf_supportability);
}
void halrf_supportability_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
switch (dm->support_ic_type) {
case ODM_RTL8814B:
#if (RTL8814B_SUPPORT == 1)
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_DPK_TRACK |
0;
#endif
break;
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
/*@HAL_RF_DPK |*/
0;
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_DACK |
HAL_RF_DPK_TRACK |
0;
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
/*@HAL_RF_DPK |*/
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_TXGAPK |
HAL_RF_DPK_TRACK |
0;
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
HAL_RF_DACK |
HAL_RF_DPK_TRACK |
0;
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
HAL_RF_DPK |
/*@HAL_RF_TXGAPK |*/
0;
break;
#endif
default:
rf->rf_supportability =
HAL_RF_TX_PWR_TRACK |
HAL_RF_IQK |
HAL_RF_LCK |
/*@HAL_RF_DPK |*/
0;
break;
}
RF_DBG(dm, DBG_RF_INIT,
"IC = ((0x%x)), RF_Supportability Init = ((0x%x))\n",
dm->support_ic_type, rf->rf_supportability);
}
void halrf_watchdog(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
#if 0
/*RF_DBG(dm, DBG_RF_TMP, "%s\n", __func__);*/
#endif
if (rf->is_dpk_in_progress || dm->rf_calibrate_info.is_iqk_in_progress)
return;
phydm_rf_watchdog(dm);
halrf_dpk_track(dm);
}
#if 0
void
halrf_iqk_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
switch (dm->support_ic_type) {
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
break;
#endif
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
_iq_calibrate_8822b_init(dm);
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
_iq_calibrate_8822c_init(dm);
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
break;
#endif
default:
break;
}
}
#endif
void halrf_rfk_handshake(void *dm_void, boolean is_before_k)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (*dm->mp_mode)
return;
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
halrf_rfk_handshake_8822c(dm, is_before_k);
break;
#endif
default:
break;
}
}
void halrf_rf_k_connect_trigger(void *dm_void, boolean is_recovery,
enum halrf_k_segment_time seg_time)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct _hal_rf_ *rf = &dm->rf_table;
if (dm->mp_mode && rf->is_con_tx && rf->is_single_tone &&
rf->is_carrier_suppresion) {
if (*dm->mp_mode &&
(*rf->is_con_tx || *rf->is_single_tone ||
*rf->is_carrier_suppresion))
return;
}
/*[TX GAP K]*/
/*[LOK, IQK]*/
halrf_segment_iqk_trigger(dm, true, seg_time);
/*[TSSI Trk]*/
/*halrf_do_tssi(dm);*/
/*halrf_do_tssi(dm);*/
/*halrf_tssi_set_de(dm);*/
/*[DPK]*/
if(dpk_info->is_dpk_by_channel == true)
halrf_dpk_trigger(dm);
else
halrf_dpk_reload(dm);
}
void halrf_dack_trigger(void *dm_void, boolean force)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u64 start_time;
if (!(rf->rf_supportability & HAL_RF_DACK))
return;
start_time = odm_get_current_time(dm);
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
halrf_dac_cal_8822c(dm, force);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
halrf_dac_cal_8812f(dm);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
halrf_dac_cal_8814b(dm);
break;
#endif
default:
break;
}
rf->dpk_progressing_time = odm_get_progressing_time(dm, start_time);
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK progressing_time = %lld ms\n",
rf->dpk_progressing_time);
}
void halrf_dack_dbg(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u64 start_time;
if (!(rf->rf_supportability & HAL_RF_DACK))
return;
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
halrf_dack_dbg_8822c(dm);
break;
#endif
default:
break;
}
}
void halrf_segment_iqk_trigger(void *dm_void, boolean clear,
boolean segment_iqk)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
u64 start_time;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
if (odm_check_power_status(dm) == false)
return;
#endif
if (dm->mp_mode &&
rf->is_con_tx &&
rf->is_single_tone &&
rf->is_carrier_suppresion)
if (*dm->mp_mode &&
((*rf->is_con_tx ||
*rf->is_single_tone ||
*rf->is_carrier_suppresion)))
return;
if (!(rf->rf_supportability & HAL_RF_IQK))
return;
#if DISABLE_BB_RF
return;
#endif
if (iqk_info->rfk_forbidden)
return;
halrf_rfk_handshake(dm, true);
if (!dm->rf_calibrate_info.is_iqk_in_progress) {
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
dm->rf_calibrate_info.is_iqk_in_progress = true;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
start_time = odm_get_current_time(dm);
dm->IQK_info.segment_iqk = segment_iqk;
switch (dm->support_ic_type) {
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
phy_iq_calibrate_8822b(dm, clear, segment_iqk);
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
phy_iq_calibrate_8822c(dm, clear, segment_iqk);
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
phy_iq_calibrate_8821c(dm, clear, segment_iqk);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
phy_iq_calibrate_8814b(dm, clear, segment_iqk);
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
phy_iq_calibrate_8195b(dm, clear, segment_iqk);
break;
#endif
/*
#if (RTL8710C_SUPPORT == 1)
case ODM_RTL8710C:
phy_iq_calibrate_8710c(dm, clear, segment_iqk);
break;
#endif
*/
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
phy_iq_calibrate_8198f(dm, clear, segment_iqk);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
phy_iq_calibrate_8812f(dm, clear, segment_iqk);
break;
#endif
#if (RTL8197G_SUPPORT == 1)
case ODM_RTL8197G:
phy_iq_calibrate_8197g(dm, clear, segment_iqk);
break;
#endif
#if (RTL8188E_SUPPORT == 1)
case ODM_RTL8188E:
phy_iq_calibrate_8188e(dm, false);
break;
#endif
#if (RTL8188F_SUPPORT == 1)
case ODM_RTL8188F:
phy_iq_calibrate_8188f(dm, false);
break;
#endif
#if (RTL8192E_SUPPORT == 1)
case ODM_RTL8192E:
phy_iq_calibrate_8192e(dm, false);
break;
#endif
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
phy_iq_calibrate_8197f(dm, false);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
phy_iq_calibrate_8192f(dm, false);
break;
#endif
#if (RTL8703B_SUPPORT == 1)
case ODM_RTL8703B:
phy_iq_calibrate_8703b(dm, false);
break;
#endif
#if (RTL8710B_SUPPORT == 1)
case ODM_RTL8710B:
phy_iq_calibrate_8710b(dm, false);
break;
#endif
#if (RTL8723B_SUPPORT == 1)
case ODM_RTL8723B:
phy_iq_calibrate_8723b(dm, false);
break;
#endif
#if (RTL8723D_SUPPORT == 1)
case ODM_RTL8723D:
phy_iq_calibrate_8723d(dm, false);
break;
#endif
#if (RTL8721D_SUPPORT == 1)
case ODM_RTL8721D:
phy_iq_calibrate_8721d(dm, false);
break;
#endif
#if (RTL8812A_SUPPORT == 1)
case ODM_RTL8812:
phy_iq_calibrate_8812a(dm, false);
break;
#endif
#if (RTL8821A_SUPPORT == 1)
case ODM_RTL8821:
phy_iq_calibrate_8821a(dm, false);
break;
#endif
#if (RTL8814A_SUPPORT == 1)
case ODM_RTL8814A:
phy_iq_calibrate_8814a(dm, false);
break;
#endif
default:
break;
}
dm->rf_calibrate_info.iqk_progressing_time =
odm_get_progressing_time(dm, start_time);
RF_DBG(dm, DBG_RF_IQK, "[IQK]IQK progressing_time = %lld ms\n",
dm->rf_calibrate_info.iqk_progressing_time);
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
dm->rf_calibrate_info.is_iqk_in_progress = false;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
halrf_rfk_handshake(dm, false);
} else {
RF_DBG(dm, DBG_RF_IQK,
"== Return the IQK CMD, because RFKs in Progress ==\n");
}
}
void halrf_iqk_trigger(void *dm_void, boolean is_recovery)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct _hal_rf_ *rf = &dm->rf_table;
u64 start_time;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
if (odm_check_power_status(dm) == false)
return;
#endif
if (dm->mp_mode &&
rf->is_con_tx &&
rf->is_single_tone &&
rf->is_carrier_suppresion)
if (*dm->mp_mode &&
((*rf->is_con_tx ||
*rf->is_single_tone ||
*rf->is_carrier_suppresion)))
return;
if (!(rf->rf_supportability & HAL_RF_IQK))
return;
#if DISABLE_BB_RF
return;
#endif
if (iqk_info->rfk_forbidden)
return;
halrf_rfk_handshake(dm, true);
if (!dm->rf_calibrate_info.is_iqk_in_progress) {
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
dm->rf_calibrate_info.is_iqk_in_progress = true;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
start_time = odm_get_current_time(dm);
switch (dm->support_ic_type) {
#if (RTL8188E_SUPPORT == 1)
case ODM_RTL8188E:
phy_iq_calibrate_8188e(dm, is_recovery);
break;
#endif
#if (RTL8188F_SUPPORT == 1)
case ODM_RTL8188F:
phy_iq_calibrate_8188f(dm, is_recovery);
break;
#endif
#if (RTL8192E_SUPPORT == 1)
case ODM_RTL8192E:
phy_iq_calibrate_8192e(dm, is_recovery);
break;
#endif
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
phy_iq_calibrate_8197f(dm, is_recovery);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
phy_iq_calibrate_8192f(dm, is_recovery);
break;
#endif
#if (RTL8703B_SUPPORT == 1)
case ODM_RTL8703B:
phy_iq_calibrate_8703b(dm, is_recovery);
break;
#endif
#if (RTL8710B_SUPPORT == 1)
case ODM_RTL8710B:
phy_iq_calibrate_8710b(dm, is_recovery);
break;
#endif
#if (RTL8723B_SUPPORT == 1)
case ODM_RTL8723B:
phy_iq_calibrate_8723b(dm, is_recovery);
break;
#endif
#if (RTL8723D_SUPPORT == 1)
case ODM_RTL8723D:
phy_iq_calibrate_8723d(dm, is_recovery);
break;
#endif
#if (RTL8721D_SUPPORT == 1)
case ODM_RTL8721D:
phy_iq_calibrate_8721d(dm, is_recovery);
break;
#endif
#if (RTL8812A_SUPPORT == 1)
case ODM_RTL8812:
phy_iq_calibrate_8812a(dm, is_recovery);
break;
#endif
#if (RTL8821A_SUPPORT == 1)
case ODM_RTL8821:
phy_iq_calibrate_8821a(dm, is_recovery);
break;
#endif
#if (RTL8814A_SUPPORT == 1)
case ODM_RTL8814A:
phy_iq_calibrate_8814a(dm, is_recovery);
break;
#endif
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
phy_iq_calibrate_8822b(dm, false, false);
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
phy_iq_calibrate_8822c(dm, false, false);
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
phy_iq_calibrate_8821c(dm, false, false);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
phy_iq_calibrate_8814b(dm, false, false);
//_do_dpk_8814b(dm);
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
phy_iq_calibrate_8195b(dm, false, false);
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
phy_iq_calibrate_8198f(dm, false, false);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
phy_iq_calibrate_8812f(dm, false, false);
break;
#endif
default:
break;
}
rf->iqk_progressing_time = odm_get_progressing_time(dm, start_time);
RF_DBG(dm, DBG_RF_LCK, "[IQK]Trigger IQK progressing_time = %lld ms\n",
rf->iqk_progressing_time);
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
dm->rf_calibrate_info.is_iqk_in_progress = false;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
halrf_rfk_handshake(dm, false);
} else {
RF_DBG(dm, DBG_RF_IQK,
"== Return the IQK CMD, because RFKs in Progress ==\n");
}
}
void halrf_lck_trigger(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
struct _hal_rf_ *rf = &dm->rf_table;
u64 start_time;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
if (odm_check_power_status(dm) == false)
return;
#endif
if (dm->mp_mode &&
rf->is_con_tx &&
rf->is_single_tone &&
rf->is_carrier_suppresion)
if (*dm->mp_mode &&
((*rf->is_con_tx ||
*rf->is_single_tone ||
*rf->is_carrier_suppresion)))
return;
if (!(rf->rf_supportability & HAL_RF_LCK))
return;
#if DISABLE_BB_RF
return;
#endif
if (iqk_info->rfk_forbidden)
return;
while (*dm->is_scan_in_process) {
RF_DBG(dm, DBG_RF_IQK, "[LCK]scan is in process, bypass LCK\n");
return;
}
if (!dm->rf_calibrate_info.is_lck_in_progress) {
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
dm->rf_calibrate_info.is_lck_in_progress = true;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
start_time = odm_get_current_time(dm);
switch (dm->support_ic_type) {
#if (RTL8188E_SUPPORT == 1)
case ODM_RTL8188E:
phy_lc_calibrate_8188e(dm);
break;
#endif
#if (RTL8188F_SUPPORT == 1)
case ODM_RTL8188F:
phy_lc_calibrate_8188f(dm);
break;
#endif
#if (RTL8192E_SUPPORT == 1)
case ODM_RTL8192E:
phy_lc_calibrate_8192e(dm);
break;
#endif
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
phy_lc_calibrate_8197f(dm);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
phy_lc_calibrate_8192f(dm);
break;
#endif
#if (RTL8703B_SUPPORT == 1)
case ODM_RTL8703B:
phy_lc_calibrate_8703b(dm);
break;
#endif
#if (RTL8710B_SUPPORT == 1)
case ODM_RTL8710B:
phy_lc_calibrate_8710b(dm);
break;
#endif
#if (RTL8721D_SUPPORT == 1)
case ODM_RTL8721D:
phy_lc_calibrate_8721d(dm);
break;
#endif
#if (RTL8723B_SUPPORT == 1)
case ODM_RTL8723B:
phy_lc_calibrate_8723b(dm);
break;
#endif
#if (RTL8723D_SUPPORT == 1)
case ODM_RTL8723D:
phy_lc_calibrate_8723d(dm);
break;
#endif
#if (RTL8812A_SUPPORT == 1)
case ODM_RTL8812:
phy_lc_calibrate_8812a(dm);
break;
#endif
#if (RTL8821A_SUPPORT == 1)
case ODM_RTL8821:
phy_lc_calibrate_8821a(dm);
break;
#endif
#if (RTL8814A_SUPPORT == 1)
case ODM_RTL8814A:
phy_lc_calibrate_8814a(dm);
break;
#endif
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
phy_lc_calibrate_8822b(dm);
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
phy_lc_calibrate_8822c(dm);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
phy_lc_calibrate_8812f(dm);
break;
#endif
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
phy_lc_calibrate_8821c(dm);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
break;
#endif
default:
break;
}
dm->rf_calibrate_info.lck_progressing_time =
odm_get_progressing_time(dm, start_time);
RF_DBG(dm, DBG_RF_IQK, "[IQK]LCK progressing_time = %lld ms\n",
dm->rf_calibrate_info.lck_progressing_time);
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
halrf_lck_dbg(dm);
#endif
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
dm->rf_calibrate_info.is_lck_in_progress = false;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
} else {
RF_DBG(dm, DBG_RF_IQK,
"= Return the LCK CMD, because RFK is in Progress =\n");
}
}
void halrf_aac_check(struct dm_struct *dm)
{
switch (dm->support_ic_type) {
#if (RTL8821C_SUPPORT == 1)
case ODM_RTL8821C:
#if 0
aac_check_8821c(dm);
#endif
break;
#endif
#if (RTL8822B_SUPPORT == 1)
case ODM_RTL8822B:
#if 1
aac_check_8822b(dm);
#endif
break;
#endif
default:
break;
}
}
void halrf_x2k_check(struct dm_struct *dm)
{
switch (dm->support_ic_type) {
case ODM_RTL8821C:
#if (RTL8821C_SUPPORT == 1)
#endif
break;
case ODM_RTL8822C:
#if (RTL8822C_SUPPORT == 1)
phy_x2_check_8822c(dm);
break;
#endif
case ODM_RTL8812F:
#if (RTL8812F_SUPPORT == 1)
phy_x2_check_8812f(dm);
break;
#endif
default:
break;
}
}
void halrf_set_rfsupportability(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
if (rf->manual_rf_supportability &&
*rf->manual_rf_supportability != 0xffffffff) {
rf->rf_supportability = *rf->manual_rf_supportability;
} else if (*dm->mp_mode) {
halrf_supportability_init_mp(dm);
} else {
halrf_supportability_init(dm);
}
}
void halrf_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
RF_DBG(dm, DBG_RF_INIT, "HALRF_Init\n");
rf->aac_checked = false;
halrf_init_debug_setting(dm);
halrf_set_rfsupportability(dm);
#if 1
/*Init all RF funciton*/
halrf_aac_check(dm);
halrf_dack_trigger(dm, false);
halrf_x2k_check(dm);
#endif
/*power trim, thrmal trim, pa bias*/
phydm_config_new_kfree(dm);
/*TSSI Init*/
halrf_tssi_get_efuse(dm);
}
void halrf_dpk_trigger(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
u64 start_time;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
if (odm_check_power_status(dm) == false)
return;
#endif
if (dm->mp_mode &&
rf->is_con_tx &&
rf->is_single_tone &&
rf->is_carrier_suppresion)
if (*dm->mp_mode &&
((*rf->is_con_tx ||
*rf->is_single_tone ||
*rf->is_carrier_suppresion)))
return;
if (!(rf->rf_supportability & HAL_RF_DPK))
return;
#if DISABLE_BB_RF
return;
#endif
if (iqk_info->rfk_forbidden)
return;
halrf_rfk_handshake(dm, true);
if (!rf->is_dpk_in_progress) {
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
rf->is_dpk_in_progress = true;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
start_time = odm_get_current_time(dm);
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
do_dpk_8822c(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
do_dpk_8197f(dm);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
do_dpk_8192f(dm);
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
do_dpk_8198f(dm);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
do_dpk_8812f(dm);
break;
#endif
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
do_dpk_8814b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
do_dpk_8195b(dm);
break;
#endif
#endif
default:
break;
}
rf->dpk_progressing_time = odm_get_progressing_time(dm, start_time);
RF_DBG(dm, DBG_RF_DPK, "[DPK]DPK progressing_time = %lld ms\n",
rf->dpk_progressing_time);
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
rf->is_dpk_in_progress = false;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
halrf_rfk_handshake(dm, false);
} else {
RF_DBG(dm, DBG_RF_DPK,
"== Return the DPK CMD, because RFKs in Progress ==\n");
}
}
void halrf_set_dpkbychannel(void *dm_void, boolean dpk_by_ch)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
switch (dm->support_ic_type) {
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
dpk_set_dpkbychannel_8814b(dm, dpk_by_ch);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
dpk_set_dpkbychannel_8195b(dm,dpk_by_ch);
break;
#endif
#endif
default:
if (dpk_by_ch)
dpk_info->is_dpk_by_channel = 1;
else
dpk_info->is_dpk_by_channel = 0;
break;
}
}
void halrf_set_dpkenable(void *dm_void, boolean is_dpk_enable)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
switch (dm->support_ic_type) {
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
dpk_set_is_dpk_enable_8814b(dm, is_dpk_enable);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
dpk_set_is_dpk_enable_8195b(dm, is_dpk_enable);
break;
#endif
#endif
default:
break;
}
}
boolean halrf_get_dpkbychannel(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
boolean is_dpk_by_channel = true;
switch (dm->support_ic_type) {
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
is_dpk_by_channel = dpk_get_dpkbychannel_8814b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
is_dpk_by_channel = dpk_get_dpkbychannel_8195b(dm);
break;
#endif
#endif
default:
break;
}
return is_dpk_by_channel;
}
boolean halrf_get_dpkenable(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct dm_iqk_info *iqk_info = &dm->IQK_info;
boolean is_dpk_enable = true;
switch (dm->support_ic_type) {
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
is_dpk_enable = dpk_get_is_dpk_enable_8814b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
is_dpk_enable = dpk_get_is_dpk_enable_8195b(dm);
break;
#endif
#endif
default:
break;
}
return is_dpk_enable;
}
u8 halrf_dpk_result_check(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 result = 0;
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
if (dpk_info->dpk_path_ok == 0x3)
result = 1;
else
result = 0;
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
if (dpk_info->dpk_path_ok == 0x1)
result = 1;
else
result = 0;
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
if (dpk_info->dpk_path_ok == 0x3)
result = 1;
else
result = 0;
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
if (dpk_info->dpk_path_ok == 0x3)
result = 1;
else
result = 0;
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
if (dpk_info->dpk_path_ok == 0xf)
result = 1;
else
result = 0;
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
if (dpk_info->dpk_path_ok == 0xf)
result = 1;
else
result = 0;
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
if (dpk_info->dpk_path_ok == 0x3)
result = 1;
else
result = 0;
break;
#endif
#endif
default:
break;
}
return result;
}
void halrf_dpk_sram_read(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 path, group;
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
dpk_coef_read_8822c(dm);
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
dpk_sram_read_8195b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
dpk_sram_read_8197f(dm);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
dpk_sram_read_8192f(dm);
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
dpk_sram_read_8198f(dm);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
dpk_sram_read_8814b(dm);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
dpk_coef_read_8812f(dm);
break;
#endif
#endif
default:
break;
}
}
void halrf_dpk_enable_disable(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
if (!(rf->rf_supportability & HAL_RF_DPK))
return;
if (!rf->is_dpk_in_progress) {
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
rf->is_dpk_in_progress = true;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
dpk_enable_disable_8822c(dm);
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
dpk_enable_disable_8195b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
phy_dpk_enable_disable_8197f(dm);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
phy_dpk_enable_disable_8192f(dm);
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
dpk_enable_disable_8198f(dm);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
dpk_enable_disable_8814b(dm);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
dpk_enable_disable_8812f(dm);
break;
#endif
#endif
default:
break;
}
odm_acquire_spin_lock(dm, RT_IQK_SPINLOCK);
rf->is_dpk_in_progress = false;
odm_release_spin_lock(dm, RT_IQK_SPINLOCK);
} else {
RF_DBG(dm, DBG_RF_DPK,
"== Return the DPK CMD, because RFKs in Progress ==\n");
}
}
void halrf_dpk_track(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct _hal_rf_ *rf = &dm->rf_table;
if (rf->is_dpk_in_progress || dm->rf_calibrate_info.is_iqk_in_progress ||
dm->is_psd_in_process || (dpk_info->dpk_path_ok == 0) ||
!(rf->rf_supportability & HAL_RF_DPK_TRACK))
return;
switch (dm->support_ic_type) {
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
dpk_track_8814b(dm);
break;
#endif
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
dpk_track_8822c(dm);
break;
#endif
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
dpk_track_8195b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
phy_dpk_track_8197f(dm);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
phy_dpk_track_8192f(dm);
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
dpk_track_8198f(dm);
break;
#endif
#if (RTL8812F_SUPPORT == 1)
case ODM_RTL8812F:
dpk_track_8812f(dm);
break;
#endif
#endif
default:
break;
}
}
void halrf_set_dpk_track(void *dm_void, u8 enable)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
if (enable)
rf->rf_supportability = rf->rf_supportability | HAL_RF_DPK_TRACK;
else
rf->rf_supportability = rf->rf_supportability & ~HAL_RF_DPK_TRACK;
}
void halrf_dpk_reload(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
switch (dm->support_ic_type) {
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
if (dpk_info->dpk_path_ok > 0)
dpk_reload_8195b(dm);
break;
#endif
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#if (RTL8197F_SUPPORT == 1)
case ODM_RTL8197F:
if (dpk_info->dpk_path_ok > 0)
dpk_reload_8197f(dm);
break;
#endif
#if (RTL8192F_SUPPORT == 1)
case ODM_RTL8192F:
if (dpk_info->dpk_path_ok > 0)
dpk_reload_8192f(dm);
break;
#endif
#if (RTL8198F_SUPPORT == 1)
case ODM_RTL8198F:
if (dpk_info->dpk_path_ok > 0)
dpk_reload_8198f(dm);
break;
#endif
#if (RTL8814B_SUPPORT == 1)
case ODM_RTL8814B:
if (dpk_info->dpk_path_ok > 0)
dpk_reload_8814b(dm);
break;
#endif
#endif
default:
break;
}
}
void halrf_dpk_info_rsvd_page(void *dm_void, u8 *buf, u32 *buf_size)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
if (!(rf->rf_supportability & HAL_RF_DPK) || rf->is_dpk_in_progress)
return;
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
dpk_info_rsvd_page_8822c(dm, buf, buf_size);
break;
#endif
default:
break;
}
}
void halrf_iqk_info_rsvd_page(void *dm_void, u8 *buf, u32 *buf_size)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
if (!(rf->rf_supportability & HAL_RF_IQK))
return;
if (dm->rf_calibrate_info.is_iqk_in_progress)
return;
switch (dm->support_ic_type) {
#if (RTL8822C_SUPPORT == 1)
case ODM_RTL8822C:
iqk_info_rsvd_page_8822c(dm, buf, buf_size);
break;
#endif
default:
break;
}
}
enum hal_status
halrf_config_rfk_with_header_file(void *dm_void, u32 config_type)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
enum hal_status result = HAL_STATUS_SUCCESS;
#if 0
#if (RTL8822B_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8822B) {
if (config_type == CONFIG_BB_RF_CAL_INIT)
odm_read_and_config_mp_8822b_cal_init(dm);
}
#endif
#endif
#if (RTL8198F_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8198F) {
if (config_type == CONFIG_BB_RF_CAL_INIT)
odm_read_and_config_mp_8198f_cal_init(dm);
}
#endif
#if (RTL8812F_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8812F) {
if (config_type == CONFIG_BB_RF_CAL_INIT)
odm_read_and_config_mp_8812f_cal_init(dm);
}
#endif
#if (RTL8822C_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8822C) {
if (config_type == CONFIG_BB_RF_CAL_INIT)
odm_read_and_config_mp_8822c_cal_init(dm);
}
#endif
#if (RTL8814B_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8814B) {
if (config_type == CONFIG_BB_RF_CAL_INIT)
odm_read_and_config_mp_8814b_cal_init(dm);
}
#endif
#if (RTL8195B_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8195B) {
if (config_type == CONFIG_BB_RF_CAL_INIT)
odm_read_and_config_mp_8195b_cal_init(dm);
}
#endif
return result;
}
void halrf_txgapk_trigger(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u64 start_time;
start_time = odm_get_current_time(dm);
switch (dm->support_ic_type) {
#if (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#if (RTL8195B_SUPPORT == 1)
case ODM_RTL8195B:
phy_txgap_calibrate_8195b(dm, false);
break;
#endif
#endif
default:
break;
}
rf->dpk_progressing_time =
odm_get_progressing_time(dm_void, start_time);
RF_DBG(dm, DBG_RF_TXGAPK, "[TGGC]TXGAPK progressing_time = %lld ms\n",
rf->dpk_progressing_time);
}
void halrf_tssi_get_efuse(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8822C) {
/*halrf_tssi_get_efuse_8822c(dm);*/
/*halrf_tssi_get_kfree_efuse_8822c(dm);*/
halrf_get_efuse_thermal_pwrtype_8822c(dm);
}
#endif
#if (RTL8814B_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8814B) {
halrf_tssi_get_efuse_8814b(dm);
}
#endif
}
void halrf_do_tssi(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
/*halrf_do_tssi_8822c(dm);*/
halrf_do_thermal_8822c(dm);
#endif
}
void halrf_do_thermal(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
halrf_do_thermal_8822c(dm);
#endif
}
u32 halrf_set_tssi_value(void *dm_void, u32 tssi_value)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
return halrf_set_tssi_value_8822c(dm, tssi_value);
#endif
return 0;
}
void halrf_set_tssi_power(void *dm_void, s8 power)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
/*halrf_set_tssi_poewr_8822c(dm, power);*/
#endif
}
void halrf_tssi_set_de_for_tx_verify(void *dm_void, u32 tssi_de, u8 path)
{
return;
}
u32 halrf_query_tssi_value(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
/*return halrf_query_tssi_value_8822c(dm);*/
#endif
return 0;
}
void halrf_tssi_cck(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
/*halrf_tssi_cck_8822c(dm);*/
halrf_thermal_cck_8822c(dm);
#endif
}
void halrf_thermal_cck(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8822C_SUPPORT == 1)
halrf_thermal_cck_8822c(dm);
#endif
}
void halrf_tssi_set_de(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (RTL8814B_SUPPORT == 1)
if (dm->support_ic_type & ODM_RTL8814B)
halrf_tssi_set_de_8814b(dm);
#endif
}
void halrf_tssi_dck(void *dm_void, u8 direct_do)
{
}
void halrf_calculate_tssi_codeword(void *dm_void)
{
}
void halrf_set_tssi_codeword(void *dm_void)
{
}
u8 halrf_get_tssi_codeword_for_txindex(void *dm_void)
{
return 0;
}
u32 halrf_tssi_get_de(void *dm_void, u8 path)
{
return 0;
}
/*Golbal function*/
void halrf_reload_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 i;
for (i = 0; i < num; i++)
odm_write_4byte(dm, bp_reg[i], bp[i]);
}
void halrf_reload_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num,
u8 ss)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 i, path;
for (i = 0; i < num; i++) {
for (path = 0; path < ss; path++)
odm_set_rf_reg(dm, (enum rf_path)path, bp_reg[i],
MASK20BITS, bp[i][path]);
}
}
void halrf_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 i;
for (i = 0; i < num; i++)
bp[i] = odm_read_4byte(dm, bp_reg[i]);
}
void halrf_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num, u8 ss)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 i, path;
for (i = 0; i < num; i++) {
for (path = 0; path < ss; path++) {
bp[i][path] =
odm_get_rf_reg(dm, (enum rf_path)path,
bp_reg[i], MASK20BITS);
}
}
}
void halrf_swap(void *dm_void, u32 *v1, u32 *v2)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 temp;
temp = *v1;
*v1 = *v2;
*v2 = temp;
}
void halrf_bubble(void *dm_void, u32 *v1, u32 *v2)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 temp;
if (*v1 >= 0x200 && *v2 >= 0x200) {
if (*v1 > *v2)
halrf_swap(dm, v1, v2);
} else if (*v1 < 0x200 && *v2 < 0x200) {
if (*v1 > *v2)
halrf_swap(dm, v1, v2);
} else if (*v1 < 0x200 && *v2 >= 0x200) {
halrf_swap(dm, v1, v2);
}
}
void halrf_b_sort(void *dm_void, u32 *iv, u32 *qv)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 temp;
u32 i, j;
RF_DBG(dm, DBG_RF_DACK, "[DACK]bubble!!!!!!!!!!!!");
for (i = 0; i < SN - 1; i++) {
for (j = 0; j < (SN - 1 - i) ; j++) {
halrf_bubble(dm, &iv[j], &iv[j + 1]);
halrf_bubble(dm, &qv[j], &qv[j + 1]);
}
}
}
void halrf_minmax_compare(void *dm_void, u32 value, u32 *min,
u32 *max)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (value >= 0x200) {
if (*min >= 0x200) {
if (*min > value)
*min = value;
} else {
*min = value;
}
if (*max >= 0x200) {
if (*max < value)
*max = value;
}
} else {
if (*min < 0x200) {
if (*min > value)
*min = value;
}
if (*max >= 0x200) {
*max = value;
} else {
if (*max < value)
*max = value;
}
}
}
u32 halrf_delta(void *dm_void, u32 v1, u32 v2)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (v1 >= 0x200 && v2 >= 0x200) {
if (v1 > v2)
return v1 - v2;
else
return v2 - v1;
} else if (v1 >= 0x200 && v2 < 0x200) {
return v2 + (0x400 - v1);
} else if (v1 < 0x200 && v2 >= 0x200) {
return v1 + (0x400 - v2);
}
if (v1 > v2)
return v1 - v2;
else
return v2 - v1;
}
boolean halrf_compare(void *dm_void, u32 value)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
boolean fail = false;
if (value >= 0x200 && (0x400 - value) > 0x64)
fail = true;
else if (value < 0x200 && value > 0x64)
fail = true;
if (fail)
RF_DBG(dm, DBG_RF_DACK, "[DACK]overflow!!!!!!!!!!!!!!!");
return fail;
}
void halrf_mode(void *dm_void, u32 *i_value, u32 *q_value)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 iv[SN], qv[SN], im[SN], qm[SN], temp, temp1, temp2;
u32 p, m, t;
u32 i_max = 0, q_max = 0, i_min = 0x0, q_min = 0x0, c = 0x0;
u32 i_delta, q_delta;
u8 i, j, ii = 0, qi = 0;
boolean fail = false;
ODM_delay_ms(10);
for (i = 0; i < SN; i++) {
im[i] = 0;
qm[i] = 0;
}
i = 0;
c = 0;
while (i < SN && c < 1000) {
c++;
temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
iv[i] = (temp & 0x3ff000) >> 12;
qv[i] = temp & 0x3ff;
fail = false;
if (halrf_compare(dm, iv[i]))
fail = true;
if (halrf_compare(dm, qv[i]))
fail = true;
if (!fail)
i++;
}
c = 0;
do {
c++;
i_min = iv[0];
i_max = iv[0];
q_min = qv[0];
q_max = qv[0];
for (i = 0; i < SN; i++) {
halrf_minmax_compare(dm, iv[i], &i_min, &i_max);
halrf_minmax_compare(dm, qv[i], &q_min, &q_max);
}
RF_DBG(dm, DBG_RF_DACK, "[DACK]i_min=0x%x, i_max=0x%x",
i_min, i_max);
RF_DBG(dm, DBG_RF_DACK, "[DACK]q_min=0x%x, q_max=0x%x",
q_min, q_max);
if (i_max < 0x200 && i_min < 0x200)
i_delta = i_max - i_min;
else if (i_max >= 0x200 && i_min >= 0x200)
i_delta = i_max - i_min;
else
i_delta = i_max + (0x400 - i_min);
if (q_max < 0x200 && q_min < 0x200)
q_delta = q_max - q_min;
else if (q_max >= 0x200 && q_min >= 0x200)
q_delta = q_max - q_min;
else
q_delta = q_max + (0x400 - q_min);
RF_DBG(dm, DBG_RF_DACK, "[DACK]i_delta=0x%x, q_delta=0x%x",
i_delta, q_delta);
halrf_b_sort(dm, iv, qv);
if (i_delta > 5 || q_delta > 5) {
temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
iv[0] = (temp & 0x3ff000) >> 12;
qv[0] = temp & 0x3ff;
temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
iv[SN - 1] = (temp & 0x3ff000) >> 12;
qv[SN - 1] = temp & 0x3ff;
} else {
break;
}
} while (c < 100);
#if 1
#if 0
for (i = 0; i < SN; i++)
RF_DBG(dm, DBG_RF_DACK, "[DACK]iv[%d] = 0x%x\n", i, iv[i]);
for (i = 0; i < SN; i++)
RF_DBG(dm, DBG_RF_DACK, "[DACK]qv[%d] = 0x%x\n", i, qv[i]);
#endif
/*i*/
m = 0;
p = 0;
for (i = 10; i < SN - 10; i++) {
if (iv[i] > 0x200)
m = (0x400 - iv[i]) + m;
else
p = iv[i] + p;
}
if (p > m) {
t = p - m;
t = t / (SN - 20);
} else {
t = m - p;
t = t / (SN - 20);
if (t != 0x0)
t = 0x400 - t;
}
*i_value = t;
/*q*/
m = 0;
p = 0;
for (i = 10; i < SN - 10; i++) {
if (qv[i] > 0x200)
m = (0x400 - qv[i]) + m;
else
p = qv[i] + p;
}
if (p > m) {
t = p - m;
t = t / (SN - 20);
} else {
t = m - p;
t = t / (SN - 20);
if (t != 0x0)
t = 0x400 - t;
}
*q_value = t;
#endif
}
================================================
FILE: hal/phydm/halrf/halrf.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_H__
#define __HALRF_H__
/*@============================================================*/
/*@include files*/
/*@============================================================*/
#include "halrf/halrf_psd.h"
#if (RTL8822B_SUPPORT == 1)
#include "halrf/rtl8822b/halrf_rfk_init_8822b.h"
#endif
#if (RTL8822C_SUPPORT == 1)
#include "halrf/rtl8822c/halrf_rfk_init_8822c.h"
#include "halrf/rtl8822c/halrf_iqk_8822c.h"
#include "halrf/rtl8822c/halrf_tssi_8822c.h"
#include "halrf/rtl8822c/halrf_dpk_8822c.h"
#endif
#if (DM_ODM_SUPPORT_TYPE & ODM_AP)
#if (RTL8198F_SUPPORT == 1)
#include "halrf/rtl8198f/halrf_rfk_init_8198f.h"
#endif
#if (RTL8812F_SUPPORT == 1)
#include "halrf/rtl8812f/halrf_rfk_init_8812f.h"
#endif
#endif
#if (RTL8814B_SUPPORT == 1)
#include "halrf/rtl8814b/halrf_rfk_init_8814b.h"
#include "halrf/rtl8814b/halrf_iqk_8814b.h"
#include "halrf/rtl8814b/halrf_dpk_8814b.h"
#endif
/*@============================================================*/
/*@Definition */
/*@============================================================*/
/*IQK version*/
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
#define IQK_VER_8188E "0x14"
#define IQK_VER_8192E "0x01"
#define IQK_VER_8192F "0x01"
#define IQK_VER_8723B "0x1e"
#define IQK_VER_8812A "0x02"
#define IQK_VER_8821A "0x02"
#elif (DM_ODM_SUPPORT_TYPE & (ODM_CE))
#define IQK_VER_8188E "0x01"
#define IQK_VER_8192E "0x01"
#define IQK_VER_8192F "0x01"
#define IQK_VER_8723B "0x1e"
#define IQK_VER_8812A "0x01"
#define IQK_VER_8821A "0x01"
#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#define IQK_VER_8188E "0x01"
#define IQK_VER_8192E "0x01"
#define IQK_VER_8192F "0x01"
#define IQK_VER_8723B "0x1e"
#define IQK_VER_8812A "0x01"
#define IQK_VER_8821A "0x01"
#elif (DM_ODM_SUPPORT_TYPE & (ODM_IOT))
#define IQK_VER_8188E "0x01"
#define IQK_VER_8192E "0x01"
#define IQK_VER_8192F "0x01"
#define IQK_VER_8723B "0x1e"
#define IQK_VER_8812A "0x01"
#define IQK_VER_8821A "0x01"
#endif
#define IQK_VER_8814A "0x0f"
#define IQK_VER_8188F "0x01"
#define IQK_VER_8197F "0x1d"
#define IQK_VER_8703B "0x05"
#define IQK_VER_8710B "0x01"
#define IQK_VER_8723D "0x02"
#define IQK_VER_8822B "0x30"
#define IQK_VER_8822C "0x0d"
#define IQK_VER_8821C "0x23"
#define IQK_VER_8198F "0x09"
#define IQK_VER_8814B "0x0b"
#define IQK_VER_8812F "0x07"
/*LCK version*/
#define LCK_VER_8188E "0x02"
#define LCK_VER_8192E "0x02"
#define LCK_VER_8192F "0x01"
#define LCK_VER_8723B "0x02"
#define LCK_VER_8812A "0x01"
#define LCK_VER_8821A "0x01"
#define LCK_VER_8814A "0x01"
#define LCK_VER_8188F "0x01"
#define LCK_VER_8197F "0x01"
#define LCK_VER_8703B "0x01"
#define LCK_VER_8710B "0x01"
#define LCK_VER_8723D "0x01"
#define LCK_VER_8822B "0x02"
#define LCK_VER_8822C "0x00"
#define LCK_VER_8821C "0x02"
#define LCK_VER_8814B "0x00"
#define LCK_VER_8195B "0x02"
/*power tracking version*/
#define PWRTRK_VER_8188E "0x01"
#define PWRTRK_VER_8192E "0x01"
#define PWRTRK_VER_8192F "0x01"
#define PWRTRK_VER_8723B "0x01"
#define PWRTRK_VER_8812A "0x01"
#define PWRTRK_VER_8821A "0x01"
#define PWRTRK_VER_8814A "0x01"
#define PWRTRK_VER_8188F "0x01"
#define PWRTRK_VER_8197F "0x01"
#define PWRTRK_VER_8703B "0x01"
#define PWRTRK_VER_8710B "0x01"
#define PWRTRK_VER_8723D "0x01"
#define PWRTRK_VER_8822B "0x01"
#define PWRTRK_VER_8822C "0x00"
#define PWRTRK_VER_8821C "0x01"
#define PWRTRK_VER_8814B "0x00"
/*DPK version*/
#define DPK_VER_8188E "NONE"
#define DPK_VER_8192E "NONE"
#define DPK_VER_8723B "NONE"
#define DPK_VER_8812A "NONE"
#define DPK_VER_8821A "NONE"
#define DPK_VER_8814A "NONE"
#define DPK_VER_8188F "NONE"
#define DPK_VER_8197F "0x08"
#define DPK_VER_8703B "NONE"
#define DPK_VER_8710B "NONE"
#define DPK_VER_8723D "NONE"
#define DPK_VER_8822B "NONE"
#define DPK_VER_8822C "0x19"
#define DPK_VER_8821C "NONE"
#define DPK_VER_8192F "0x0d"
#define DPK_VER_8198F "0x0a"
#define DPK_VER_8814B "0x04"
#define DPK_VER_8195B "0x0a"
#define DPK_VER_8812F "0x02"
/*RFK_INIT version*/
#define RFK_INIT_VER_8822B "0x8"
#define RFK_INIT_VER_8822C "0x7"
#define RFK_INIT_VER_8195B "0x1"
#define RFK_INIT_VER_8198F "0x5"
#define RFK_INIT_VER_8814B "0x5"
#define RFK_INIT_VER_8812F "0x2"
/*DACK version*/
#define DACK_VER_8822C "0xa"
#define DACK_VER_8814B "0x3"
/*Kfree tracking version*/
#define KFREE_VER_8188E \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8192E \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8192F \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8723B \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8812A \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8821A \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8814A \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8188F \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8197F \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8703B \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8710B \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8723D \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8822B \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8822C \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8821C \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
#define KFREE_VER_8814B \
(dm->power_trim_data.flag & KFREE_FLAG_ON) ? "0x01" : "NONE"
/*PA Bias Calibration version*/
#define PABIASK_VER_8188E \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8192E \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8192F \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8723B \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8812A \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8821A \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8814A \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8188F \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8197F \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8703B \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8710B \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8723D \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8822B \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8822C \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8821C \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define PABIASK_VER_8814B \
(dm->power_trim_data.pa_bias_flag & PA_BIAS_FLAG_ON) ? "0x01" : "NONE"
#define HALRF_IQK_VER \
(dm->support_ic_type == ODM_RTL8188E) ? IQK_VER_8188E : \
(dm->support_ic_type == ODM_RTL8192E) ? IQK_VER_8192E : \
(dm->support_ic_type == ODM_RTL8192F) ? IQK_VER_8192F : \
(dm->support_ic_type == ODM_RTL8723B) ? IQK_VER_8723B : \
(dm->support_ic_type == ODM_RTL8812) ? IQK_VER_8812A : \
(dm->support_ic_type == ODM_RTL8821) ? IQK_VER_8821A : \
(dm->support_ic_type == ODM_RTL8814A) ? IQK_VER_8814A : \
(dm->support_ic_type == ODM_RTL8188F) ? IQK_VER_8188F : \
(dm->support_ic_type == ODM_RTL8197F) ? IQK_VER_8197F : \
(dm->support_ic_type == ODM_RTL8703B) ? IQK_VER_8703B : \
(dm->support_ic_type == ODM_RTL8710B) ? IQK_VER_8710B : \
(dm->support_ic_type == ODM_RTL8723D) ? IQK_VER_8723D : \
(dm->support_ic_type == ODM_RTL8822B) ? IQK_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? IQK_VER_8822C : \
(dm->support_ic_type == ODM_RTL8821C) ? IQK_VER_8821C : \
(dm->support_ic_type == ODM_RTL8814B) ? IQK_VER_8814B : "unknown"
#define HALRF_LCK_VER \
(dm->support_ic_type == ODM_RTL8188E) ? LCK_VER_8188E : \
(dm->support_ic_type == ODM_RTL8192E) ? LCK_VER_8192E : \
(dm->support_ic_type == ODM_RTL8192F) ? LCK_VER_8192F : \
(dm->support_ic_type == ODM_RTL8723B) ? LCK_VER_8723B : \
(dm->support_ic_type == ODM_RTL8812) ? LCK_VER_8812A : \
(dm->support_ic_type == ODM_RTL8821) ? LCK_VER_8821A : \
(dm->support_ic_type == ODM_RTL8814A) ? LCK_VER_8814A : \
(dm->support_ic_type == ODM_RTL8188F) ? LCK_VER_8188F : \
(dm->support_ic_type == ODM_RTL8197F) ? LCK_VER_8197F : \
(dm->support_ic_type == ODM_RTL8703B) ? LCK_VER_8703B : \
(dm->support_ic_type == ODM_RTL8710B) ? LCK_VER_8710B : \
(dm->support_ic_type == ODM_RTL8723D) ? LCK_VER_8723D : \
(dm->support_ic_type == ODM_RTL8822B) ? LCK_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? LCK_VER_8822C : \
(dm->support_ic_type == ODM_RTL8821C) ? LCK_VER_8821C : \
(dm->support_ic_type == ODM_RTL8814B) ? LCK_VER_8814B : "unknown"
#define HALRF_POWRTRACKING_VER \
(dm->support_ic_type == ODM_RTL8188E) ? PWRTRK_VER_8188E : \
(dm->support_ic_type == ODM_RTL8192E) ? PWRTRK_VER_8192E : \
(dm->support_ic_type == ODM_RTL8192F) ? PWRTRK_VER_8192F : \
(dm->support_ic_type == ODM_RTL8723B) ? PWRTRK_VER_8723B : \
(dm->support_ic_type == ODM_RTL8812) ? PWRTRK_VER_8812A : \
(dm->support_ic_type == ODM_RTL8821) ? PWRTRK_VER_8821A : \
(dm->support_ic_type == ODM_RTL8814A) ? PWRTRK_VER_8814A : \
(dm->support_ic_type == ODM_RTL8188F) ? PWRTRK_VER_8188F : \
(dm->support_ic_type == ODM_RTL8197F) ? PWRTRK_VER_8197F : \
(dm->support_ic_type == ODM_RTL8703B) ? PWRTRK_VER_8703B : \
(dm->support_ic_type == ODM_RTL8710B) ? PWRTRK_VER_8710B : \
(dm->support_ic_type == ODM_RTL8723D) ? PWRTRK_VER_8723D : \
(dm->support_ic_type == ODM_RTL8822B) ? PWRTRK_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? PWRTRK_VER_8822C : \
(dm->support_ic_type == ODM_RTL8821C) ? PWRTRK_VER_8821C : \
(dm->support_ic_type == ODM_RTL8814B) ? PWRTRK_VER_8814B : "unknown"
#define HALRF_DPK_VER \
(dm->support_ic_type == ODM_RTL8188E) ? DPK_VER_8188E : \
(dm->support_ic_type == ODM_RTL8192E) ? DPK_VER_8192E : \
(dm->support_ic_type == ODM_RTL8192F) ? DPK_VER_8192F : \
(dm->support_ic_type == ODM_RTL8723B) ? DPK_VER_8723B : \
(dm->support_ic_type == ODM_RTL8812) ? DPK_VER_8812A : \
(dm->support_ic_type == ODM_RTL8821) ? DPK_VER_8821A : \
(dm->support_ic_type == ODM_RTL8814A) ? DPK_VER_8814A : \
(dm->support_ic_type == ODM_RTL8188F) ? DPK_VER_8188F : \
(dm->support_ic_type == ODM_RTL8197F) ? DPK_VER_8197F : \
(dm->support_ic_type == ODM_RTL8198F) ? DPK_VER_8198F : \
(dm->support_ic_type == ODM_RTL8703B) ? DPK_VER_8703B : \
(dm->support_ic_type == ODM_RTL8710B) ? DPK_VER_8710B : \
(dm->support_ic_type == ODM_RTL8723D) ? DPK_VER_8723D : \
(dm->support_ic_type == ODM_RTL8822B) ? DPK_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? DPK_VER_8822C : \
(dm->support_ic_type == ODM_RTL8821C) ? DPK_VER_8821C : \
(dm->support_ic_type == ODM_RTL8814B) ? DPK_VER_8814B : "unknown"
#define HALRF_KFREE_VER \
(dm->support_ic_type == ODM_RTL8188E) ? KFREE_VER_8188E : \
(dm->support_ic_type == ODM_RTL8192E) ? KFREE_VER_8192E : \
(dm->support_ic_type == ODM_RTL8192F) ? KFREE_VER_8192F : \
(dm->support_ic_type == ODM_RTL8723B) ? KFREE_VER_8723B : \
(dm->support_ic_type == ODM_RTL8812) ? KFREE_VER_8812A : \
(dm->support_ic_type == ODM_RTL8821) ? KFREE_VER_8821A : \
(dm->support_ic_type == ODM_RTL8814A) ? KFREE_VER_8814A : \
(dm->support_ic_type == ODM_RTL8188F) ? KFREE_VER_8188F : \
(dm->support_ic_type == ODM_RTL8197F) ? KFREE_VER_8197F : \
(dm->support_ic_type == ODM_RTL8703B) ? KFREE_VER_8703B : \
(dm->support_ic_type == ODM_RTL8710B) ? KFREE_VER_8710B : \
(dm->support_ic_type == ODM_RTL8723D) ? KFREE_VER_8723D : \
(dm->support_ic_type == ODM_RTL8822B) ? KFREE_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? KFREE_VER_8822C : \
(dm->support_ic_type == ODM_RTL8821C) ? KFREE_VER_8821C : \
(dm->support_ic_type == ODM_RTL8814B) ? KFREE_VER_8814B : "unknown"
#define HALRF_PABIASK_VER \
(dm->support_ic_type == ODM_RTL8188E) ? PABIASK_VER_8188E : \
(dm->support_ic_type == ODM_RTL8192E) ? PABIASK_VER_8192E : \
(dm->support_ic_type == ODM_RTL8192F) ? PABIASK_VER_8192F : \
(dm->support_ic_type == ODM_RTL8723B) ? PABIASK_VER_8723B : \
(dm->support_ic_type == ODM_RTL8812) ? PABIASK_VER_8812A : \
(dm->support_ic_type == ODM_RTL8821) ? PABIASK_VER_8821A : \
(dm->support_ic_type == ODM_RTL8814A) ? PABIASK_VER_8814A : \
(dm->support_ic_type == ODM_RTL8188F) ? PABIASK_VER_8188F : \
(dm->support_ic_type == ODM_RTL8197F) ? PABIASK_VER_8197F : \
(dm->support_ic_type == ODM_RTL8703B) ? PABIASK_VER_8703B : \
(dm->support_ic_type == ODM_RTL8710B) ? PABIASK_VER_8710B : \
(dm->support_ic_type == ODM_RTL8723D) ? PABIASK_VER_8723D : \
(dm->support_ic_type == ODM_RTL8822B) ? PABIASK_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? PABIASK_VER_8822C : \
(dm->support_ic_type == ODM_RTL8821C) ? PABIASK_VER_8821C : \
(dm->support_ic_type == ODM_RTL8814B) ? PABIASK_VER_8814B : "unknown"
#define HALRF_RFK_INIT_VER \
(dm->support_ic_type == ODM_RTL8822B) ? RFK_INIT_VER_8822B : \
(dm->support_ic_type == ODM_RTL8822C) ? RFK_INIT_VER_8822C : \
(dm->support_ic_type == ODM_RTL8198F) ? RFK_INIT_VER_8198F : \
(dm->support_ic_type == ODM_RTL8814B) ? RFK_INIT_VER_8814B : "unknown"
#define HALRF_DACK_VER \
(dm->support_ic_type == ODM_RTL8822C) ? DACK_VER_8822C : "unknown"
#define IQK_THRESHOLD 8
#define DPK_THRESHOLD 4
#define HALRF_ABS(a,b) ((a>b) ? (a-b) : (b-a))
#define SN 100
#define CCK_TSSI_NUM 6
#define OFDM_2G_TSSI_NUM 5
#define OFDM_5G_TSSI_NUM 14
/*@===========================================================*/
/*AGC RX High Power mode*/
/*@===========================================================*/
#define lna_low_gain_1 0x64
#define lna_low_gain_2 0x5A
#define lna_low_gain_3 0x58
/*@============================================================*/
/*@ enumeration */
/*@============================================================*/
#define POWER_INDEX_DIFF 4
#define TSSI_TXAGC_DIFF 2
#define TSSI_CODE_NUM 84
#define TSSI_SLOPE_2G 8
#define TSSI_SLOPE_5G 5
#define TSSI_EFUSE_NUM 25
#define TSSI_EFUSE_KFREE_NUM 4
enum halrf_func_idx { /*F_XXX = PHYDM XXX function*/
RF00_PWR_TRK = 0, /*Pow_trk, TSSI_trk*/
RF01_IQK = 1, /*LOK, IQK*/
RF02_LCK = 2,
RF03_DPK = 3,
RF04_TXGAPK = 4,
RF05_DACK = 5,
RF06_DPK_TRK = 6,
};
enum halrf_ability {
HAL_RF_TX_PWR_TRACK = BIT(RF00_PWR_TRK),
HAL_RF_IQK = BIT(RF01_IQK),
HAL_RF_LCK = BIT(RF02_LCK),
HAL_RF_DPK = BIT(RF03_DPK),
HAL_RF_TXGAPK = BIT(RF04_TXGAPK),
HAL_RF_DACK = BIT(RF05_DACK),
HAL_RF_DPK_TRACK = BIT(RF06_DPK_TRK)
};
enum halrf_dbg_comp {
DBG_RF_TX_PWR_TRACK = BIT(RF00_PWR_TRK),
DBG_RF_IQK = BIT(RF01_IQK),
DBG_RF_LCK = BIT(RF02_LCK),
DBG_RF_DPK = BIT(RF03_DPK),
DBG_RF_TXGAPK = BIT(RF04_TXGAPK),
DBG_RF_DACK = BIT(RF05_DACK),
DBG_RF_MP = BIT(29),
DBG_RF_TMP = BIT(30),
DBG_RF_INIT = BIT(31)
};
enum halrf_cmninfo_init {
HALRF_CMNINFO_ABILITY = 0,
HALRF_CMNINFO_DPK_EN = 1,
HALRF_CMNINFO_EEPROM_THERMAL_VALUE,
HALRF_CMNINFO_RFK_FORBIDDEN,
HALRF_CMNINFO_IQK_SEGMENT,
HALRF_CMNINFO_RATE_INDEX,
HALRF_CMNINFO_PWT_TYPE,
HALRF_CMNINFO_MP_PSD_POINT,
HALRF_CMNINFO_MP_PSD_START_POINT,
HALRF_CMNINFO_MP_PSD_STOP_POINT,
HALRF_CMNINFO_MP_PSD_AVERAGE,
HALRF_CMNINFO_IQK_TIMES
};
enum halrf_cmninfo_hook {
HALRF_CMNINFO_CON_TX,
HALRF_CMNINFO_SINGLE_TONE,
HALRF_CMNINFO_CARRIER_SUPPRESSION,
HALRF_CMNINFO_MP_RATE_INDEX,
HALRF_CMNINFO_MANUAL_RF_SUPPORTABILITY
};
enum halrf_lna_set {
HALRF_LNA_DISABLE = 0,
HALRF_LNA_ENABLE = 1,
};
enum halrf_k_segment_time {
SEGMENT_FREE = 0,
SEGMENT_10MS = 10, /*10ms*/
SEGMENT_30MS = 30, /*30ms*/
SEGMENT_50MS = 50, /*50ms*/
};
#if (RTL8822C_SUPPORT == 1 || RTL8812F_SUPPORT == 1 || RTL8814B_SUPPORT)
#define POWER_INDEX_DIFF 4
#define TSSI_TXAGC_DIFF 2
#define TSSI_CODE_NUM 84
#define TSSI_SLOPE_2G 8
#define TSSI_SLOPE_5G 5
#define TSSI_EFUSE_NUM 25
#define TSSI_EFUSE_KFREE_NUM 4
struct _halrf_tssi_data {
s32 cck_offset_patha;
s32 cck_offset_pathb;
s32 power_track_offset[PHYDM_MAX_RF_PATH];
s16 txagc_codeword[TSSI_CODE_NUM];
u16 tssi_codeword[TSSI_CODE_NUM];
s8 tssi_efuse[PHYDM_MAX_RF_PATH][TSSI_EFUSE_NUM];
s8 tssi_kfree_efuse[PHYDM_MAX_RF_PATH][TSSI_EFUSE_KFREE_NUM];
u8 thermal[PHYDM_MAX_RF_PATH];
u32 index[PHYDM_MAX_RF_PATH][14];
u8 do_tssi;
u8 get_thermal;
};
#endif
/*@============================================================*/
/*@ structure */
/*@============================================================*/
struct _hal_rf_ {
/*hook*/
u8 *test1;
/*update*/
u32 rf_supportability;
u8 eeprom_thermal;
u8 dpk_en; /*Enable Function DPK OFF/ON = 0/1*/
boolean dpk_done;
u64 dpk_progressing_time;
u64 iqk_progressing_time;
u32 fw_ver;
boolean *is_con_tx;
boolean *is_single_tone;
boolean *is_carrier_suppresion;
boolean is_dpk_in_progress;
boolean is_tssi_in_progress;
boolean is_bt_iqk_timeout;
boolean aac_checked;
u8 *mp_rate_index;
u32 *manual_rf_supportability;
u32 p_rate_index;
u8 pwt_type;
u32 rf_dbg_comp;
struct _halrf_psd_data halrf_psd_data;
#if (RTL8822C_SUPPORT == 1 || RTL8812F_SUPPORT == 1 || RTL8814B_SUPPORT == 1)
struct _halrf_tssi_data halrf_tssi_data;
#endif
u8 power_track_type;
};
/*@============================================================*/
/*@ function prototype */
/*@============================================================*/
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1 ||\
RTL8812F_SUPPORT == 1)
void halrf_iqk_info_dump(void *dm_void, u32 *_used, char *output,
u32 *_out_len);
void halrf_iqk_hwtx_check(void *dm_void, boolean is_check);
#endif
u8 halrf_match_iqk_version(void *dm_void);
void halrf_support_ability_debug(void *dm_void, char input[][16], u32 *_used,
char *output, u32 *_out_len);
void halrf_cmn_info_init(void *dm_void, enum halrf_cmninfo_init cmn_info,
u32 value);
void halrf_cmn_info_hook(void *dm_void, enum halrf_cmninfo_hook cmn_info,
void *value);
void halrf_cmn_info_set(void *dm_void, u32 cmn_info, u64 value);
u64 halrf_cmn_info_get(void *dm_void, u32 cmn_info);
void halrf_watchdog(void *dm_void);
void halrf_supportability_init(void *dm_void);
void halrf_init(void *dm_void);
void halrf_iqk_trigger(void *dm_void, boolean is_recovery);
void halrf_rfk_handshake(void *dm_void, boolean is_before_k);
void halrf_rf_k_connect_trigger(void *dm_void, boolean is_recovery,
enum halrf_k_segment_time seg_time);
void halrf_segment_iqk_trigger(void *dm_void, boolean clear,
boolean segment_iqk);
void halrf_lck_trigger(void *dm_void);
void halrf_iqk_debug(void *dm_void, u32 *const dm_value, u32 *_used,
char *output, u32 *_out_len);
void phydm_get_iqk_cfir(void *dm_void, u8 idx, u8 path, boolean debug);
void halrf_iqk_xym_read(void *dm_void, u8 path, u8 xym_type);
void halrf_rf_lna_setting(void *dm_void, enum halrf_lna_set type);
void halrf_do_imr_test(void *dm_void, u8 data);
u32 halrf_psd_log2base(u32 val);
void halrf_dpk_trigger(void *dm_void);
u8 halrf_dpk_result_check(void *dm_void);
void halrf_dpk_sram_read(void *dm_void);
void halrf_dpk_enable_disable(void *dm_void);
void halrf_dpk_track(void *dm_void);
void halrf_dpk_reload(void *dm_void);
void halrf_dpk_info_rsvd_page(void *dm_void, u8 *buf, u32 *buf_size);
/*Global function*/
void halrf_reload_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num);
void halrf_reload_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num,
u8 ss);
void halrf_bp(void *dm_void, u32 *bp_reg, u32 *bp, u32 num);
void halrf_bprf(void *dm_void, u32 *bp_reg, u32 bp[][4], u32 num, u8 ss);
void halrf_mode(void *dm_void, u32 *i_value, u32 *q_value);
boolean halrf_compare(void *dm_void, u32 value);
u32 halrf_delta(void *dm_void, u32 v1, u32 v2);
void halrf_minmax_compare(void *dm_void, u32 value, u32 *min, u32 *max);
void halrf_b_sort(void *dm_void, u32 *iv, u32 *qv);
void halrf_bubble(void *dm_void, u32 *v1, u32 *v2);
void halrf_swap(void *dm_void, u32 *v1, u32 *v2);
enum hal_status
halrf_config_rfk_with_header_file(void *dm_void, u32 config_type);
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1 ||\
RTL8812F_SUPPORT == 1)
void halrf_iqk_dbg(void *dm_void);
#endif
void halrf_tssi_get_efuse(void *dm_void);
void halrf_do_tssi(void *dm_void);
void halrf_do_thermal(void *dm_void);
u32 halrf_set_tssi_value(void *dm_void, u32 tssi_value);
void halrf_tssi_set_de_for_tx_verify(void *dm_void, u32 tssi_de, u8 path);
void halrf_set_tssi_power(void *dm_void, s8 power);
u32 halrf_query_tssi_value(void *dm_void);
void halrf_tssi_cck(void *dm_void);
void halrf_thermal_cck(void *dm_void);
void halrf_tssi_set_de(void *dm_void);
void halrf_tssi_dck(void *dm_void, u8 direct_do);
void halrf_calculate_tssi_codeword(void *dm_void);
void halrf_set_tssi_codeword(void *dm_void);
u8 halrf_get_tssi_codeword_for_txindex(void *dm_void);
u32 halrf_tssi_get_de(void *dm_void, u8 path);
void halrf_set_dpk_track(void *dm_void, u8 enable);
void halrf_set_dpkbychannel(void *dm_void, boolean dpk_by_ch);
void halrf_set_dpkenable(void *dm_void, boolean is_dpk_enable);
boolean halrf_get_dpkbychannel(void *dm_void);
boolean halrf_get_dpkenable(void *dm_void);
void _iqk_check_if_reload(void *dm_void);
void halrf_dack_dbg(void *dm_void);
void halrf_iqk_info_rsvd_page(void *dm_void, u8 *buf, u32 *buf_size);
void halrf_set_rfsupportability(void *dm_void);
#endif /*__HALRF_H__*/
================================================
FILE: hal/phydm/halrf/halrf_debug.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*@************************************************************
* include files
* ************************************************************
*/
#include "mp_precomp.h"
#include "phydm_precomp.h"
void halrf_basic_profile(void *dm_void, u32 *_used, char *output, u32 *_out_len)
{
#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 used = *_used;
u32 out_len = *_out_len;
u32 rf_release_ver = 0;
#if (RTL8822C_SUPPORT)
if (dm->support_ic_type == ODM_RTL8822C) {
rf_release_ver = RF_RELEASE_VERSION_8822C;
}
#endif
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %d\n",
"RF Para Release Ver", rf_release_ver);
/* HAL RF version List */
PDM_SNPF(out_len, used, output + used, out_len - used, "%-35s\n",
"% HAL RF version %");
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %s\n",
"Power Tracking", HALRF_POWRTRACKING_VER);
PDM_SNPF(out_len, used, output + used, out_len - used,
" %-35s: %s %s\n", "IQK",
(dm->fw_offload_ability & PHYDM_RF_IQK_OFFLOAD) ? "FW" :
HALRF_IQK_VER,
(halrf_match_iqk_version(dm_void)) ? "(match)" : "(mismatch)");
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %s\n",
"LCK", HALRF_LCK_VER);
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %s\n",
"DPK", HALRF_DPK_VER);
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %s\n",
"KFREE", HALRF_KFREE_VER);
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %s\n",
"TX 2G Current Calibration", HALRF_PABIASK_VER);
PDM_SNPF(out_len, used, output + used, out_len - used, " %-35s: %s\n",
"RFK Init. Parameter", HALRF_RFK_INIT_VER);
*_used = used;
*_out_len = out_len;
#endif
}
void halrf_debug_trace(void *dm_void, char input[][16], u32 *_used,
char *output, u32 *_out_len)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u32 one = 1;
u32 used = *_used;
u32 out_len = *_out_len;
u32 rf_var[10] = {0};
u8 i;
for (i = 0; i < 5; i++)
if (input[i + 1])
PHYDM_SSCANF(input[i + 2], DCMD_DECIMAL, &rf_var[i]);
if (rf_var[0] == 100) {
PDM_SNPF(out_len, used, output + used, out_len - used,
"\n[DBG MSG] RF Selection\n");
PDM_SNPF(out_len, used, output + used, out_len - used,
"00. (( %s ))TX_PWR_TRACK\n",
((rf->rf_dbg_comp & DBG_RF_TX_PWR_TRACK) ? ("V") :
(".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"01. (( %s ))IQK\n",
((rf->rf_dbg_comp & DBG_RF_IQK) ? ("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"02. (( %s ))LCK\n",
((rf->rf_dbg_comp & DBG_RF_LCK) ? ("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"03. (( %s ))DPK\n",
((rf->rf_dbg_comp & DBG_RF_DPK) ? ("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"04. (( %s ))TXGAPK\n",
((rf->rf_dbg_comp & DBG_RF_TXGAPK) ? ("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"29. (( %s ))MP\n",
((rf->rf_dbg_comp & DBG_RF_MP) ? ("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"30. (( %s ))TMP\n",
((rf->rf_dbg_comp & DBG_RF_TMP) ? ("V") : (".")));
PDM_SNPF(out_len, used, output + used, out_len - used,
"31. (( %s ))INIT\n",
((rf->rf_dbg_comp & DBG_RF_INIT) ? ("V") : (".")));
} else if (rf_var[0] == 101) {
rf->rf_dbg_comp = 0;
PDM_SNPF(out_len, used, output + used, out_len - used,
"Disable all DBG COMP\n");
} else {
if (rf_var[1] == 1) /*enable*/
rf->rf_dbg_comp |= (one << rf_var[0]);
else if (rf_var[1] == 2) /*disable*/
rf->rf_dbg_comp &= ~(one << rf_var[0]);
}
PDM_SNPF(out_len, used, output + used, out_len - used,
"\nCurr-RF_Dbg_Comp = 0x%x\n", rf->rf_dbg_comp);
*_used = used;
*_out_len = out_len;
}
struct halrf_command {
char name[16];
u8 id;
};
enum halrf_CMD_ID {
HALRF_HELP,
HALRF_SUPPORTABILITY,
HALRF_DBG_COMP,
HALRF_PROFILE,
HALRF_IQK_INFO,
HALRF_IQK,
HALRF_IQK_DEBUG,
};
struct halrf_command halrf_cmd_ary[] = {
{"-h", HALRF_HELP},
{"ability", HALRF_SUPPORTABILITY},
{"dbg", HALRF_DBG_COMP},
{"profile", HALRF_PROFILE},
{"iqk_info", HALRF_IQK_INFO},
{"iqk", HALRF_IQK},
{"iqk_dbg", HALRF_IQK_DEBUG},
};
void halrf_cmd_parser(void *dm_void, char input[][16], u32 *_used, char *output,
u32 *_out_len, u32 input_num)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#ifdef CONFIG_PHYDM_DEBUG_FUNCTION
u8 id = 0;
u32 rf_var[10] = {0};
u32 i, input_idx = 0;
u32 halrf_ary_size =
sizeof(halrf_cmd_ary) / sizeof(struct halrf_command);
u32 used = *_used;
u32 out_len = *_out_len;
/* Parsing Cmd ID */
for (i = 0; i < halrf_ary_size; i++) {
if (strcmp(halrf_cmd_ary[i].name, input[1]) == 0) {
id = halrf_cmd_ary[i].id;
break;
}
}
if (i == halrf_ary_size) {
PDM_SNPF(out_len, used, output + used, out_len - used,
"RF Cmd not found\n");
return;
}
switch (id) {
case HALRF_HELP:
PDM_SNPF(out_len, used, output + used, out_len - used,
"RF cmd ==>\n");
for (i = 0; i < halrf_ary_size - 1; i++) {
PDM_SNPF(out_len, used, output + used, out_len - used,
" %-5d: %s\n", i, halrf_cmd_ary[i + 1].name);
}
break;
case HALRF_SUPPORTABILITY:
halrf_support_ability_debug(dm, &input[0], &used, output,
&out_len);
break;
case HALRF_DBG_COMP:
halrf_debug_trace(dm, &input[0], &used, output, &out_len);
break;
case HALRF_PROFILE:
halrf_basic_profile(dm, &used, output, &out_len);
break;
case HALRF_IQK_INFO:
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
halrf_iqk_info_dump(dm, &used, output, &out_len);
#endif
break;
case HALRF_IQK:
PDM_SNPF(out_len, used, output + used, out_len - used,
"TRX IQK Trigger\n");
halrf_iqk_trigger(dm, false);
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
halrf_iqk_info_dump(dm, &used, output, &out_len);
#endif
break;
case HALRF_IQK_DEBUG:
for (i = 0; i < 5; i++) {
if (input[i + 1]) {
PHYDM_SSCANF(input[i + 2], DCMD_HEX,
&rf_var[i]);
input_idx++;
}
}
if (input_idx >= 1) {
#if (RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1)
if (dm->support_ic_type & (ODM_RTL8822B | ODM_RTL8821C))
halrf_iqk_debug(dm, (u32 *)rf_var, &used,
output, &out_len);
#endif
}
break;
default:
break;
}
*_used = used;
*_out_len = out_len;
#endif
}
void halrf_init_debug_setting(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
rf->rf_dbg_comp =
#if DBG
#if 0
/*DBG_RF_TX_PWR_TRACK |*/
/*DBG_RF_IQK | */
/*DBG_RF_LCK | */
/*DBG_RF_DPK | */
/*DBG_RF_DACK | */
/*DBG_RF_TXGAPK | */
/*DBG_RF_MP | */
/*DBG_RF_TMP | */
/*DBG_RF_INIT | */
#endif
#endif
0;
}
================================================
FILE: hal/phydm/halrf/halrf_debug.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_DEBUG_H__
#define __HALRF_DEBUG_H__
/*@============================================================*/
/*@include files*/
/*@============================================================*/
/*@============================================================*/
/*@Definition */
/*@============================================================*/
#if DBG
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
#define RF_DBG(dm, comp, fmt, args...) \
do { \
if ((comp) & dm->rf_table.rf_dbg_comp) { \
pr_debug("[RF] "); \
RT_PRINTK(fmt, ##args); \
} \
} while (0)
#elif (DM_ODM_SUPPORT_TYPE == ODM_WIN)
static __inline void RF_DBG(PDM_ODM_T dm, int comp, char *fmt, ...)
{
RT_STATUS rt_status;
va_list args;
char buf[PRINT_MAX_SIZE] = {0};
if ((comp & dm->rf_table.rf_dbg_comp) == 0)
return;
if (fmt == NULL)
return;
va_start(args, fmt);
rt_status = (RT_STATUS)RtlStringCbVPrintfA(buf, PRINT_MAX_SIZE, fmt, args);
va_end(args);
if (rt_status != RT_STATUS_SUCCESS) {
DbgPrint("Failed (%d) to print message to buffer\n", rt_status);
return;
}
DbgPrint("[RF] %s", buf);
}
#elif (DM_ODM_SUPPORT_TYPE == ODM_IOT)
#define RF_DBG(dm, comp, fmt, args...) \
do { \
if ((comp) & dm->rf_table.rf_dbg_comp) { \
RT_DEBUG(COMP_PHYDM, DBG_DMESG, "[RF] " fmt, ##args); \
} \
} while (0)
#else
#define RF_DBG(dm, comp, fmt, args...) \
do { \
struct dm_struct *__dm = dm; \
if ((comp) & __dm->rf_table.rf_dbg_comp) { \
RT_TRACE(((struct rtl_priv *)__dm->adapter), \
COMP_PHYDM, DBG_DMESG, "[RF] " fmt, ##args); \
} \
} while (0)
#endif
#else /*#if DBG*/
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
static __inline void RF_DBG(struct dm_struct *dm, int comp, char *fmt, ...)
{
}
#else
#define RF_DBG(dm, comp, fmt, args...)
#endif
#endif /*#if DBG*/
/*@============================================================*/
/*@ enumeration */
/*@============================================================*/
/*@============================================================*/
/*@ structure */
/*@============================================================*/
/*@============================================================*/
/*@ function prototype */
/*@============================================================*/
void halrf_cmd_parser(void *dm_void, char input[][16], u32 *_used, char *output,
u32 *_out_len, u32 input_num);
void halrf_init_debug_setting(void *dm_void);
#endif /*__HALRF_H__*/
================================================
FILE: hal/phydm/halrf/halrf_dpk.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_DPK_H__
#define __HALRF_DPK_H__
/*@--------------------------Define Parameters-------------------------------*/
#define GAIN_LOSS 1
#define DO_DPK 2
#define DPK_ON 3
#define DPK_LOK 4
#define DPK_TXK 5
#define DAGC 4
#define LOSS_CHK 0
#define GAIN_CHK 1
#define PAS_READ 2
#define AVG_THERMAL_NUM 8
#define AVG_THERMAL_NUM_DPK 8
#define THERMAL_DPK_AVG_NUM 4
/*@---------------------------End Define Parameters---------------------------*/
struct dm_dpk_info {
boolean is_dpk_enable;
boolean is_dpk_pwr_on;
boolean is_dpk_by_channel;
boolean is_tssi_mode;
boolean is_reload;
u16 dpk_path_ok;
/*@BIT(15)~BIT(12) : 5G reserved, BIT(11)~BIT(8) 5G_S3~5G_S0*/
/*@BIT(7)~BIT(4) : 2G reserved, BIT(3)~BIT(0) 2G_S3~2G_S0*/
u8 thermal_dpk[4]; /*path*/
u8 thermal_dpk_avg[4][AVG_THERMAL_NUM_DPK]; /*path*/
u8 thermal_dpk_avg_index;
u8 pre_pwsf[4];
u32 gnt_control;
u32 gnt_value;
u8 dpk_ch;
u8 dpk_band;
u8 dpk_bw;
#if (RTL8822C_SUPPORT == 1 || RTL8812F_SUPPORT == 1)
u8 result[2]; /*path*/
u8 dpk_txagc[2]; /*path*/
u32 coef[2][20]; /*path/MDPD coefficient*/
u16 dpk_gs[2]; /*MDPD coef gs*/
u8 thermal_dpk_delta[2]; /*path*/
#endif
#if (RTL8198F_SUPPORT == 1 || RTL8192F_SUPPORT == 1 || RTL8197F_SUPPORT == 1 || RTL8814B_SUPPORT)
/*2G DPK data*/
u8 dpk_result[4][3]; /*path/group*/
u8 pwsf_2g[4][3]; /*path/group*/
u32 lut_2g_even[4][3][64]; /*path/group/LUT data*/
u32 lut_2g_odd[4][3][64]; /*path/group/LUT data*/
/*5G DPK data*/
u8 dpk_5g_result[4][6]; /*path/group*/
u8 pwsf_5g[4][6]; /*path/group*/
u32 lut_5g[4][6][64]; /*path/group/LUT data*/
u32 lut_2g[4][3][64]; /*path/group/LUT data*/
/*8814B*/
u8 rxbb[4]; /*path/group*/
u8 txbb[4]; /*path/group*/
u8 tx_gain;
#endif
#if (RTL8195B_SUPPORT == 1)
/*2G DPK data*/
u8 dpk_2g_result[1][3]; /*path/group*/
u8 pwsf_2g[1][3]; /*path/group*/
u32 lut_2g_even[1][3][16]; /*path/group/LUT data*/
u32 lut_2g_odd[1][3][16]; /*path/group/LUT data*/
/*5G DPK data*/
u8 dpk_5g_result[1][13]; /*path/group*/
u8 pwsf_5g[1][13]; /*path/group*/
u32 lut_5g_even[1][13][16]; /*path/group/LUT data*/
u32 lut_5g_odd[1][13][16]; /*path/group/LUT data*/
#endif
};
#endif /*__HALRF_DPK_H__*/
================================================
FILE: hal/phydm/halrf/halrf_features.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_FEATURES_H__
#define __HALRF_FEATURES_H__
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
#define CONFIG_HALRF_POWERTRACKING 1
#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
#define CONFIG_HALRF_POWERTRACKING 1
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
#define CONFIG_HALRF_POWERTRACKING 1
#endif
#endif /*#ifndef __HALRF_FEATURES_H__*/
================================================
FILE: hal/phydm/halrf/halrf_iqk.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_IQK_H__
#define __HALRF_IQK_H__
/*@--------------------------Define Parameters-------------------------------*/
#define LOK_delay 1
#define WBIQK_delay 10
#define TX_IQK 0
#define RX_IQK 1
#define TXIQK 0
#define RXIQK1 1
#define RXIQK2 2
#define kcount_limit_80m 2
#define kcount_limit_others 4
#define rxiqk_gs_limit 6
#define TXWBIQK_EN 1
#define RXWBIQK_EN 1
#define NUM 4
/*@-----------------------End Define Parameters-----------------------*/
struct dm_dack_info {
u32 ic_a;
u32 qc_a;
u32 ic_b;
u32 qc_b;
boolean dack_en;
u16 msbk_d[2][2][15];
u8 dck_d[2][2][2];
u16 biask_d[2][2];
};
struct dm_iqk_info {
boolean lok_fail[NUM];
boolean iqk_fail[2][NUM];
u32 iqc_matrix[2][NUM];
u8 iqk_times;
u32 rf_reg18;
u32 rf_reg08;
u32 lna_idx;
u8 iqk_step;
u8 rxiqk_step;
u8 tmp1bcc;
u8 txgain;
u32 txgain56;
u8 kcount;
u8 rfk_ing; /*bit0:IQKing, bit1:LCKing, bit2:DPKing*/
boolean rfk_forbidden;
u8 rxbb;
u32 rf_reg58;
boolean segment_iqk;
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8821C_SUPPORT == 1 ||\
RTL8195B_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1 || RTL8822C_SUPPORT == 1 ||\
RTL8812F_SUPPORT == 1 || RTL8197G_SUPPORT == 1 )
u32 iqk_channel[2];
boolean iqk_fail_report[2][4][2]; /*channel/path/TRX(TX:0, RX:1) */
/*channel / path / TRX(TX:0, RX:1) / CFIR_real*/
/*channel index = 2 is just for debug*/
#if (RTL8812F_SUPPORT == 1 || RTL8822C_SUPPORT == 1 )
u16 iqk_cfir_real[3][2][2][17];
/*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/
/*channel index = 2 is just for debug*/
u16 iqk_cfir_imag[3][2][2][17];
u32 rx_cfir_real[2][2][17];
u32 rx_cfir_imag[2][2][17];
u32 rx_cfir[2][2];
/*times/path*/
#else
u32 iqk_cfir_real[3][4][2][8];
/*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/
/*channel index = 2 is just for debug*/
u32 iqk_cfir_imag[3][4][2][8];
#endif
u8 retry_count[2][4][3]; /* channel / path / (TXK:0, RXK1:1, RXK2:2) */
u8 gs_retry_count[2][4][2]; /* channel / path / (GSRXK1:0, GSRXK2:1) */
/* channel / path 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail */
u8 rxiqk_fail_code[2][4];
u32 lok_idac[2][4]; /*channel / path*/
u16 rxiqk_agc[2][4]; /*channel / path*/
u32 bypass_iqk[2][4]; /*channel / 0xc94/0xe94*/
u32 txgap_result[8]; /*txagpK result */
u32 tmp_gntwl;
boolean is_btg;
boolean isbnd;
boolean is_reload;
boolean is_hwtx;
boolean xym_read;
boolean trximr_enable;
u32 rx_xym[2][10];
u32 tx_xym[2][10];
u32 gs1_xym[2][6];
u32 gs2_xym[2][6];
u32 rxk1_xym[2][6];
u32 txxy[2][2];
u32 rxxy[2][2];
#endif
};
#endif /*__HALRF_IQK_H__*/
================================================
FILE: hal/phydm/halrf/halrf_kfree.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*@============================================================*/
/*@include files*/
/*@============================================================*/
#include "mp_precomp.h"
#include "phydm_precomp.h"
/*@ Add for KFree Feature Requested by RF David.*/
/*@This is a phydm API*/
void phydm_set_kfree_to_rf_8814a(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
boolean is_odd;
u32 tx_gain_bitmask = (BIT(17) | BIT(16) | BIT(15));
if ((data % 2) != 0) { /*odd->positive*/
data = data - 1;
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), 1);
is_odd = true;
} else { /*even->negative*/
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), 0);
is_odd = false;
}
RF_DBG(dm, DBG_RF_MP, "phy_ConfigKFree8814A(): RF_0x55[19]= %d\n",
is_odd);
switch (data) {
case 0:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 0);
cali_info->kfree_offset[e_rf_path] = 0;
break;
case 2:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 0);
cali_info->kfree_offset[e_rf_path] = 0;
break;
case 4:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 1);
cali_info->kfree_offset[e_rf_path] = 1;
break;
case 6:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 1);
cali_info->kfree_offset[e_rf_path] = 1;
break;
case 8:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 2);
cali_info->kfree_offset[e_rf_path] = 2;
break;
case 10:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 2);
cali_info->kfree_offset[e_rf_path] = 2;
break;
case 12:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 3);
cali_info->kfree_offset[e_rf_path] = 3;
break;
case 14:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 3);
cali_info->kfree_offset[e_rf_path] = 3;
break;
case 16:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 4);
cali_info->kfree_offset[e_rf_path] = 4;
break;
case 18:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 4);
cali_info->kfree_offset[e_rf_path] = 4;
break;
case 20:
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(14), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, tx_gain_bitmask, 5);
cali_info->kfree_offset[e_rf_path] = 5;
break;
default:
break;
}
if (!is_odd) {
/*that means Kfree offset is negative, we need to record it.*/
cali_info->kfree_offset[e_rf_path] =
(-1) * cali_info->kfree_offset[e_rf_path];
RF_DBG(dm, DBG_RF_MP,
"phy_ConfigKFree8814A(): kfree_offset = %d\n",
cali_info->kfree_offset[e_rf_path]);
} else {
RF_DBG(dm, DBG_RF_MP,
"phy_ConfigKFree8814A(): kfree_offset = %d\n",
cali_info->kfree_offset[e_rf_path]);
}
}
void phydm_get_thermal_trim_offset_8821c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_therm = 0xff;
odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_21C, &pg_therm, false);
if (pg_therm != 0xff) {
pg_therm = pg_therm & 0x1f;
if ((pg_therm & BIT(0)) == 0)
power_trim_info->thermal = (-1 * (pg_therm >> 1));
else
power_trim_info->thermal = (pg_therm >> 1);
power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8821c thermal trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
RF_DBG(dm, DBG_RF_MP, "[kfree] 8821c thermal:%d\n",
power_trim_info->thermal);
}
void phydm_get_power_trim_offset_8821c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_power = 0xff, i;
odm_efuse_one_byte_read(dm, PPG_2G_TXAB_21C, &pg_power, false);
if (pg_power != 0xff) {
power_trim_info->bb_gain[0][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_21C, &pg_power, false);
power_trim_info->bb_gain[1][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GL2_TXA_21C, &pg_power, false);
power_trim_info->bb_gain[2][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GM1_TXA_21C, &pg_power, false);
power_trim_info->bb_gain[3][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GM2_TXA_21C, &pg_power, false);
power_trim_info->bb_gain[4][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GH1_TXA_21C, &pg_power, false);
power_trim_info->bb_gain[5][0] = pg_power;
power_trim_info->flag =
power_trim_info->flag | KFREE_FLAG_ON |
KFREE_FLAG_ON_2G | KFREE_FLAG_ON_5G;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8821c power trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_ON) {
for (i = 0; i < KFREE_BAND_NUM; i++)
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8821c pwr_trim->bb_gain[%d][0]=0x%X\n",
i, power_trim_info->bb_gain[i][0]);
}
}
void phydm_set_kfree_to_rf_8821c(void *dm_void, u8 e_rf_path, boolean wlg_btg,
u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 wlg, btg;
u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
u32 s_gain_bmask = (BIT(19) | BIT(18) | BIT(17) |
BIT(16) | BIT(15) | BIT(14));
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(5), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(6), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(6), 1);
if (wlg_btg) {
wlg = data & 0xf;
btg = (data & 0xf0) >> 4;
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (wlg & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask, (wlg >> 1));
odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(19), (btg & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x65, gain_bmask, (btg >> 1));
} else {
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), data & BIT(0));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
((data & 0x1f) >> 1));
}
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55, s_gain_bmask),
odm_get_rf_reg(dm, e_rf_path, RF_0x65, s_gain_bmask));
}
void phydm_clear_kfree_to_rf_8821c(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
u32 s_gain_bmask = (BIT(19) | BIT(18) | BIT(17) |
BIT(16) | BIT(15) | BIT(14));
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(5), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(6), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(6), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask, (data >> 1));
odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x65, gain_bmask, (data >> 1));
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(5), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(6), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x65, BIT(6), 0);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8821c 0x55[19:14]=0x%X 0x65[19:14]=0x%X\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55, s_gain_bmask),
odm_get_rf_reg(dm, e_rf_path, RF_0x65, s_gain_bmask));
}
void phydm_get_thermal_trim_offset_8822b(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_therm = 0xff;
odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_22B, &pg_therm, false);
if (pg_therm != 0xff) {
pg_therm = pg_therm & 0x1f;
if ((pg_therm & BIT(0)) == 0)
power_trim_info->thermal = (-1 * (pg_therm >> 1));
else
power_trim_info->thermal = (pg_therm >> 1);
power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b thermal trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b thermal:%d\n",
power_trim_info->thermal);
}
void phydm_get_power_trim_offset_8822b(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_power = 0xff, i, j;
odm_efuse_one_byte_read(dm, PPG_2G_TXAB_22B, &pg_power, false);
if (pg_power != 0xff) {
/*Path A*/
odm_efuse_one_byte_read(dm, PPG_2G_TXAB_22B, &pg_power, false);
power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
/*Path B*/
odm_efuse_one_byte_read(dm, PPG_2G_TXAB_22B, &pg_power, false);
power_trim_info->bb_gain[0][1] = ((pg_power & 0xf0) >> 4);
power_trim_info->flag |= KFREE_FLAG_ON_2G;
power_trim_info->flag |= KFREE_FLAG_ON;
}
odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_22B, &pg_power, false);
if (pg_power != 0xff) {
/*Path A*/
odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_22B, &pg_power, false);
power_trim_info->bb_gain[1][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GL2_TXA_22B, &pg_power, false);
power_trim_info->bb_gain[2][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GM1_TXA_22B, &pg_power, false);
power_trim_info->bb_gain[3][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GM2_TXA_22B, &pg_power, false);
power_trim_info->bb_gain[4][0] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GH1_TXA_22B, &pg_power, false);
power_trim_info->bb_gain[5][0] = pg_power;
/*Path B*/
odm_efuse_one_byte_read(dm, PPG_5GL1_TXB_22B, &pg_power, false);
power_trim_info->bb_gain[1][1] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GL2_TXB_22B, &pg_power, false);
power_trim_info->bb_gain[2][1] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GM1_TXB_22B, &pg_power, false);
power_trim_info->bb_gain[3][1] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GM2_TXB_22B, &pg_power, false);
power_trim_info->bb_gain[4][1] = pg_power;
odm_efuse_one_byte_read(dm, PPG_5GH1_TXB_22B, &pg_power, false);
power_trim_info->bb_gain[5][1] = pg_power;
power_trim_info->flag |= KFREE_FLAG_ON_5G;
power_trim_info->flag |= KFREE_FLAG_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b power trim flag:0x%02x\n",
power_trim_info->flag);
if (!(power_trim_info->flag & KFREE_FLAG_ON))
return;
for (i = 0; i < KFREE_BAND_NUM; i++) {
for (j = 0; j < 2; j++)
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b PwrTrim->bb_gain[%d][%d]=0x%X\n",
i, j, power_trim_info->bb_gain[i][j]);
}
}
void phydm_set_pa_bias_to_rf_8822b(void *dm_void, u8 e_rf_path, s8 tx_pa_bias)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 rf_reg_51 = 0, rf_reg_52 = 0, rf_reg_3f = 0;
u32 tx_pa_bias_bmask = (BIT(12) | BIT(11) | BIT(10) | BIT(9));
rf_reg_51 = odm_get_rf_reg(dm, e_rf_path, RF_0x51, RFREGOFFSETMASK);
rf_reg_52 = odm_get_rf_reg(dm, e_rf_path, RF_0x52, RFREGOFFSETMASK);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b 2g rf(0x51)=0x%X rf(0x52)=0x%X path=%d\n",
rf_reg_51, rf_reg_52, e_rf_path);
#if 0
/*rf3f => rf52[19:17] = rf3f[2:0] rf52[16:15] = rf3f[4:3] rf52[3:0] = rf3f[8:5]*/
/*rf3f => rf51[6:3] = rf3f[12:9] rf52[13] = rf3f[13]*/
#endif
rf_reg_3f = ((rf_reg_52 & 0xe0000) >> 17) |
(((rf_reg_52 & 0x18000) >> 15) << 3) |
((rf_reg_52 & 0xf) << 5) |
(((rf_reg_51 & 0x78) >> 3) << 9) |
(((rf_reg_52 & 0x2000) >> 13) << 13);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b 2g original pa_bias=%d rf_reg_3f=0x%X path=%d\n",
tx_pa_bias, rf_reg_3f, e_rf_path);
tx_pa_bias = (s8)((rf_reg_3f & tx_pa_bias_bmask) >> 9) + tx_pa_bias;
if (tx_pa_bias < 0)
tx_pa_bias = 0;
else if (tx_pa_bias > 7)
tx_pa_bias = 7;
rf_reg_3f = ((rf_reg_3f & 0xfe1ff) | (tx_pa_bias << 9));
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b 2g 0x%X 0x%X pa_bias=%d rfreg_3f=0x%X path=%d\n",
PPG_PABIAS_2GA_22B, PPG_PABIAS_2GB_22B,
tx_pa_bias, rf_reg_3f, e_rf_path);
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(10), 0x1);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x0);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, BIT(0), 0x1);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, BIT(1), 0x1);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, (BIT(1) | BIT(0)), 0x3);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK, rf_reg_3f);
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(10), 0x0);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b 2g tx pa bias rf_0x3f(0x%X) path=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x3f,
(BIT(12) | BIT(11) | BIT(10) | BIT(9))),
e_rf_path);
}
void phydm_get_pa_bias_offset_8822b(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_pa_bias = 0xff, e_rf_path = 0;
s8 tx_pa_bias[2] = {0};
odm_efuse_one_byte_read(dm, PPG_PABIAS_2GA_22B, &pg_pa_bias, false);
if (pg_pa_bias != 0xff) {
/*paht a*/
odm_efuse_one_byte_read(dm, PPG_PABIAS_2GA_22B,
&pg_pa_bias, false);
pg_pa_bias = pg_pa_bias & 0xf;
if ((pg_pa_bias & BIT(0)) == 0)
tx_pa_bias[0] = (-1 * (pg_pa_bias >> 1));
else
tx_pa_bias[0] = (pg_pa_bias >> 1);
/*paht b*/
odm_efuse_one_byte_read(dm, PPG_PABIAS_2GB_22B,
&pg_pa_bias, false);
pg_pa_bias = pg_pa_bias & 0xf;
if ((pg_pa_bias & BIT(0)) == 0)
tx_pa_bias[1] = (-1 * (pg_pa_bias >> 1));
else
tx_pa_bias[1] = (pg_pa_bias >> 1);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b 2g PathA_pa_bias:%d PathB_pa_bias:%d\n",
tx_pa_bias[0], tx_pa_bias[1]);
for (e_rf_path = RF_PATH_A; e_rf_path < 2; e_rf_path++)
phydm_set_pa_bias_to_rf_8822b(dm, e_rf_path,
tx_pa_bias[e_rf_path]);
power_trim_info->pa_bias_flag |= PA_BIAS_FLAG_ON;
} else {
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b 2g tx pa bias no pg\n");
}
}
void phydm_set_kfree_to_rf_8822b(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(4), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x65, MASKLWORD, 0x9000);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
((data & 0x1f) >> 1));
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822b 0x55[19:14]=0x%X path=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55,
(BIT(19) | BIT(18) | BIT(17) | BIT(16) |
BIT(15) | BIT(14))), e_rf_path);
}
void phydm_clear_kfree_to_rf_8822b(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(4), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x65, MASKLWORD, 0x9000);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
((data & 0x1f) >> 1));
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(0), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0xde, BIT(4), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x65, MASKLWORD, 0x9000);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(7), 0);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822b clear power trim 0x55[19:14]=0x%X path=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55,
(BIT(19) | BIT(18) | BIT(17) | BIT(16) |
BIT(15) | BIT(14))), e_rf_path);
}
void phydm_get_thermal_trim_offset_8710b(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_therm = 0xff;
odm_efuse_one_byte_read(dm, 0x0EF, &pg_therm, false);
if (pg_therm != 0xff) {
pg_therm = pg_therm & 0x1f;
if ((pg_therm & BIT(0)) == 0)
power_trim_info->thermal = (-1 * (pg_therm >> 1));
else
power_trim_info->thermal = (pg_therm >> 1);
power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b thermal trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b thermal:%d\n",
power_trim_info->thermal);
}
void phydm_get_power_trim_offset_8710b(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_power = 0xff;
odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
if (pg_power != 0xff) {
/*Path A*/
odm_efuse_one_byte_read(dm, 0xEE, &pg_power, false);
power_trim_info->bb_gain[0][0] = (pg_power & 0xf);
power_trim_info->flag |= KFREE_FLAG_ON_2G;
power_trim_info->flag |= KFREE_FLAG_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b power trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_ON)
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8710b power_trim_data->bb_gain[0][0]=0x%X\n",
power_trim_info->bb_gain[0][0]);
}
void phydm_set_kfree_to_rf_8710b(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask, ((data & 0xf) >> 1));
RF_DBG(dm, DBG_RF_MP, "[kfree] 8710b 0x55[19:14]=0x%X path=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55,
(BIT(19) | BIT(18) | BIT(17) | BIT(16) |
BIT(15) | BIT(14))), e_rf_path);
}
void phydm_clear_kfree_to_rf_8710b(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 gain_bmask = (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, gain_bmask,
((data & 0x1f) >> 1));
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8710b clear power trim 0x55[19:14]=0x%X path=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55,
(BIT(19) | BIT(18) | BIT(17) | BIT(16) |
BIT(15) | BIT(14))), e_rf_path);
}
void phydm_get_thermal_trim_offset_8192f(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_therm = 0xff;
odm_efuse_one_byte_read(dm, 0x1EF, &pg_therm, false);
if (pg_therm != 0xff) {
pg_therm = pg_therm & 0x1f;
if ((pg_therm & BIT(0)) == 0)
power_trim_info->thermal = (-1 * (pg_therm >> 1));
else
power_trim_info->thermal = (pg_therm >> 1);
power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8192f thermal trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
RF_DBG(dm, DBG_RF_MP, "[kfree] 8192f thermal:%d\n",
power_trim_info->thermal);
}
void phydm_get_power_trim_offset_8192f(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_power1 = 0xff, pg_power2 = 0xff, pg_power3 = 0xff, i, j;
odm_efuse_one_byte_read(dm, 0x1EE, &pg_power1, false); /*CH4-9*/
if (pg_power1 != 0xff) {
/*Path A*/
odm_efuse_one_byte_read(dm, 0x1EE, &pg_power1, false);
power_trim_info->bb_gain[1][0] = (pg_power1 & 0xf);
/*Path B*/
odm_efuse_one_byte_read(dm, 0x1EE, &pg_power1, false);
power_trim_info->bb_gain[1][1] = ((pg_power1 & 0xf0) >> 4);
power_trim_info->flag |= KFREE_FLAG_ON_2G;
power_trim_info->flag |= KFREE_FLAG_ON;
}
odm_efuse_one_byte_read(dm, 0x1EC, &pg_power2, false); /*CH1-3*/
if (pg_power2 != 0xff) {
/*Path A*/
odm_efuse_one_byte_read(dm, 0x1EC, &pg_power2, false);
power_trim_info->bb_gain[0][0] = (pg_power2 & 0xf);
/*Path B*/
odm_efuse_one_byte_read(dm, 0x1EC, &pg_power2, false);
power_trim_info->bb_gain[0][1] = ((pg_power2 & 0xf0) >> 4);
power_trim_info->flag |= KFREE_FLAG_ON_2G;
power_trim_info->flag |= KFREE_FLAG_ON;
} else {
power_trim_info->bb_gain[0][0] = (pg_power1 & 0xf);
power_trim_info->bb_gain[0][1] = ((pg_power1 & 0xf0) >> 4);
}
odm_efuse_one_byte_read(dm, 0x1EA, &pg_power3, false); /*CH10-14*/
if (pg_power3 != 0xff) {
/*Path A*/
odm_efuse_one_byte_read(dm, 0x1EA, &pg_power3, false);
power_trim_info->bb_gain[2][0] = (pg_power3 & 0xf);
/*Path B*/
odm_efuse_one_byte_read(dm, 0x1EA, &pg_power3, false);
power_trim_info->bb_gain[2][1] = ((pg_power3 & 0xf0) >> 4);
power_trim_info->flag |= KFREE_FLAG_ON_2G;
power_trim_info->flag |= KFREE_FLAG_ON;
} else {
power_trim_info->bb_gain[2][0] = (pg_power1 & 0xf);
power_trim_info->bb_gain[2][1] = ((pg_power1 & 0xf0) >> 4);
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8192F power trim flag:0x%02x\n",
power_trim_info->flag);
if (!(power_trim_info->flag & KFREE_FLAG_ON))
return;
for (i = 0; i < KFREE_CH_NUM; i++) {
for (j = 0; j < 2; j++)
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8192F PwrTrim->bb_gain[%d][%d]=0x%X\n",
i, j, power_trim_info->bb_gain[i][j]);
}
}
void phydm_set_kfree_to_rf_8192f(void *dm_void, u8 e_rf_path, u8 channel_idx,
u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
/*power_trim based on 55[19:14]*/
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
/*enable 55[14] for 0.5db step*/
odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 1);
/*enter power_trim debug mode*/
odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 1);
/*write enable*/
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 1);
if (e_rf_path == 0) {
if (channel_idx == 0) {
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
} else if (channel_idx == 1) {
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
} else if (channel_idx == 2) {
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
}
} else if (e_rf_path == 1) {
if (channel_idx == 0) {
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
} else if (channel_idx == 1) {
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
} else if (channel_idx == 2) {
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
odm_set_rf_reg(dm, e_rf_path, 0x33, 0x3F, data);
}
}
/*leave power_trim debug mode*/
odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
/*write disable*/
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 0);
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8192F 0x55[19:14]=0x%X path=%d channel=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55,
(BIT(19) | BIT(18) | BIT(17) | BIT(16) |
BIT(15) | BIT(14))), e_rf_path, channel_idx);
}
#if 0
/*
void phydm_clear_kfree_to_rf_8192f(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(19), (data & BIT(0)));
odm_set_rf_reg(dm, e_rf_path, RF_0x55, (BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14)), ((data & 0x1f) >> 1));
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8192F clear power trim 0x55[19:14]=0x%X path=%d\n",
odm_get_rf_reg(dm, e_rf_path, RF_0x55, (BIT(19) | BIT(18) | BIT(17) | BIT(16) | BIT(15) | BIT(14))),
e_rf_path
);
}
*/
#endif
void phydm_get_thermal_trim_offset_8198f(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_therm = 0xff;
odm_efuse_one_byte_read(dm, PPG_THERMAL_OFFSET_98F, &pg_therm, false);
if (pg_therm != 0xff) {
pg_therm = pg_therm & 0x1f;
if ((pg_therm & BIT(0)) == 0)
power_trim_info->thermal = (-1 * (pg_therm >> 1));
else
power_trim_info->thermal = (pg_therm >> 1);
power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8198f thermal trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
RF_DBG(dm, DBG_RF_MP, "[kfree] 8198f thermal:%d\n",
power_trim_info->thermal);
}
void phydm_get_power_trim_offset_8198f(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_power = 0xff, i, j;
odm_efuse_one_byte_read(dm, PPG_2GL_TXAB_98F, &pg_power, false);
if (pg_power != 0xff) {
power_trim_info->bb_gain[0][0] = pg_power & 0xf;
power_trim_info->bb_gain[0][1] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GL_TXCD_98F, &pg_power, false);
power_trim_info->bb_gain[0][2] = pg_power & 0xf;
power_trim_info->bb_gain[0][3] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GM_TXAB_98F, &pg_power, false);
power_trim_info->bb_gain[1][0] = pg_power & 0xf;
power_trim_info->bb_gain[1][1] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GM_TXCD_98F, &pg_power, false);
power_trim_info->bb_gain[1][2] = pg_power & 0xf;
power_trim_info->bb_gain[1][3] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GH_TXAB_98F, &pg_power, false);
power_trim_info->bb_gain[2][0] = pg_power & 0xf;
power_trim_info->bb_gain[2][1] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GH_TXCD_98F, &pg_power, false);
power_trim_info->bb_gain[2][2] = pg_power & 0xf;
power_trim_info->bb_gain[2][3] = (pg_power & 0xf0) >> 4;
power_trim_info->flag =
power_trim_info->flag | KFREE_FLAG_ON | KFREE_FLAG_ON_2G;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8198f power trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_ON) {
for (i = 0; i < KFREE_BAND_NUM; i++) {
for (j = 0; j < MAX_RF_PATH; j++) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8198f pwr_trim->bb_gain[%d][%d]=0x%X\n",
i, j, power_trim_info->bb_gain[i][j]);
}
}
}
}
void phydm_set_kfree_to_rf_8198f(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u32 band, i;
s8 pwr_offset[3];
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s:Set kfree to rf 0x33\n", __func__);
/*power_trim based on 55[19:14]*/
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
/*enable 55[14] for 0.5db step*/
odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 1);
/*enter power_trim debug mode*/
odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
/*write enable*/
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 1);
for (i =0; i < 3; i++)
pwr_offset[i] = power_trim_info->bb_gain[i][e_rf_path];
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[0]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[0]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[1]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[1]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[2]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, pwr_offset[2]);
/*leave power_trim debug mode*/
/*odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);*/
/*write disable*/
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 0);
}
void phydm_clear_kfree_to_rf_8198f(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s:Clear kfree to rf 0x55\n", __func__);
#if 0
/*power_trim based on 55[19:14]*/
odm_set_rf_reg(dm, e_rf_path, RF_0x55, BIT(5), 1);
/*enable 55[14] for 0.5db step*/
odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 1);
/*enter power_trim debug mode*/
odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
/*write enable*/
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 0);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 2);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 3);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 4);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x70000, 5);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, 0x3F, data);
/*leave power_trim debug mode*/
odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 0);
/*enable 55[14] for 0.5db step*/
odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 0);
/*write disable*/
odm_set_rf_reg(dm, e_rf_path, RF_0xef, BIT(7), 0);
#else
odm_set_rf_reg(dm, e_rf_path, RF_0xdf, BIT(7), 1);
/*odm_set_rf_reg(dm, e_rf_path, RF_0xf5, BIT(18), 0);*/
#endif
}
void phydm_get_set_thermal_trim_offset_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_therm = 0xff, thermal[2] = {0};
odm_efuse_one_byte_read(dm, PPG_THERMAL_A_OFFSET_22C, &pg_therm, false);
if (pg_therm != 0xff) {
/*s0*/
pg_therm = pg_therm & 0x1f;
thermal[RF_PATH_A] =
((pg_therm & 0x1) << 3) | ((pg_therm >> 1) & 0x7);
odm_set_rf_reg(dm, RF_PATH_A, RF_0x43, 0x000f0000, thermal[RF_PATH_A]);
/*s1*/
odm_efuse_one_byte_read(dm, PPG_THERMAL_B_OFFSET_22C, &pg_therm, false);
pg_therm = pg_therm & 0x1f;
thermal[RF_PATH_B] = ((pg_therm & 0x1) << 3) | ((pg_therm >> 1) & 0x7);
odm_set_rf_reg(dm, RF_PATH_B, RF_0x43, 0x000f0000, thermal[RF_PATH_B]);
power_trim_info->flag |= KFREE_FLAG_THERMAL_K_ON;
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822c thermal trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822c thermalA:%d thermalB:%d\n",
thermal[RF_PATH_A],
thermal[RF_PATH_B]);
}
void phydm_set_power_trim_offset_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 e_rf_path;
for (e_rf_path = RF_PATH_A; e_rf_path < 2; e_rf_path++)
{
odm_set_rf_reg(dm, e_rf_path, RF_0xee, BIT(19), 1);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x0);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[0][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x1);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[1][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x2);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[2][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x3);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[2][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x4);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[3][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x5);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[4][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x6);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[5][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x7);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[6][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x8);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[7][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0x9);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[3][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0xa);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[4][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0xb);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[5][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0xc);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[6][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0xd);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[7][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0x33, RFREGOFFSETMASK, 0xe);
odm_set_rf_reg(dm, e_rf_path, RF_0x3f, RFREGOFFSETMASK,
power_trim_info->bb_gain[7][e_rf_path]);
odm_set_rf_reg(dm, e_rf_path, RF_0xee, BIT(19), 0);
}
}
void phydm_get_power_trim_offset_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_power = 0xff, i, j;
u8 pg_power1, pg_power2 , pg_power3, pg_power4, pg_power5;
odm_efuse_one_byte_read(dm, PPG_2GL_TXAB_22C, &pg_power1, false);
odm_efuse_one_byte_read(dm, PPG_2GM_TXAB_22C, &pg_power2, false);
odm_efuse_one_byte_read(dm, PPG_2GH_TXAB_22C, &pg_power3, false);
odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_22C, &pg_power4, false);
odm_efuse_one_byte_read(dm, PPG_5GL1_TXB_22C, &pg_power5, false);
if (pg_power1 != 0xff || pg_power2 != 0xff || pg_power3 != 0xff ||
pg_power4 != 0xff || pg_power5 != 0xff) {
odm_efuse_one_byte_read(dm, PPG_2GL_TXAB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[0][0] = pg_power & 0xf;
power_trim_info->bb_gain[0][1] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GM_TXAB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[1][0] = pg_power & 0xf;
power_trim_info->bb_gain[1][1] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_2GH_TXAB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[2][0] = pg_power & 0xf;
power_trim_info->bb_gain[2][1] = (pg_power & 0xf0) >> 4;
odm_efuse_one_byte_read(dm, PPG_5GL1_TXA_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[3][0] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GL1_TXB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[3][1] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GL2_TXA_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[4][0] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GL2_TXB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[4][1] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GM1_TXA_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[5][0] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GM1_TXB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[5][1] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GM2_TXA_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[6][0] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GM2_TXB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[6][1] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GH1_TXA_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[7][0] = pg_power & 0x1f;
odm_efuse_one_byte_read(dm, PPG_5GH1_TXB_22C, &pg_power, false);
if (pg_power == 0xff)
pg_power = 0;
power_trim_info->bb_gain[7][1] = pg_power & 0x1f;
power_trim_info->flag =
power_trim_info->flag | KFREE_FLAG_ON |
KFREE_FLAG_ON_2G |
KFREE_FLAG_ON_5G;
phydm_set_power_trim_offset_8822c(dm);
}
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822c power trim flag:0x%02x\n",
power_trim_info->flag);
if (power_trim_info->flag & KFREE_FLAG_ON) {
for (i = 0; i < KFREE_BAND_NUM; i++) {
for (j = 0; j < 2; j++) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] 8822c pwr_trim->bb_gain[%d][%d]=0x%X\n",
i, j, power_trim_info->bb_gain[i][j]);
}
}
}
}
void phydm_get_set_pa_bias_offset_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
u8 pg_pa_bias = 0xff;
RF_DBG(dm, DBG_RF_MP, "======>%s\n", __func__);
odm_efuse_one_byte_read(dm, PPG_PABIAS_2GA_22C, &pg_pa_bias, false);
if (pg_pa_bias != 0xff) {
/*2G s0*/
odm_efuse_one_byte_read(dm, PPG_PABIAS_2GA_22C,
&pg_pa_bias, false);
pg_pa_bias = pg_pa_bias & 0xf;
RF_DBG(dm, DBG_RF_MP, "[kfree] 2G s0 pa_bias=0x%x\n", pg_pa_bias);
odm_set_rf_reg(dm, RF_PATH_A, 0x60, 0x0000f000, pg_pa_bias);
/*2G s1*/
odm_efuse_one_byte_read(dm, PPG_PABIAS_2GB_22C,
&pg_pa_bias, false);
pg_pa_bias = pg_pa_bias & 0xf;
RF_DBG(dm, DBG_RF_MP, "[kfree] 2G s1 pa_bias=0x%x\n", pg_pa_bias);
odm_set_rf_reg(dm, RF_PATH_B, 0x60, 0x0000f000, pg_pa_bias);
/*5G s0*/
odm_efuse_one_byte_read(dm, PPG_PABIAS_5GA_22C,
&pg_pa_bias, false);
pg_pa_bias = pg_pa_bias & 0xf;
RF_DBG(dm, DBG_RF_MP, "[kfree] 5G s0 pa_bias=0x%x\n", pg_pa_bias);
odm_set_rf_reg(dm, RF_PATH_A, 0x60, 0x000f0000, pg_pa_bias);
/*5G s1*/
odm_efuse_one_byte_read(dm, PPG_PABIAS_5GB_22C,
&pg_pa_bias, false);
pg_pa_bias = pg_pa_bias & 0xf;
RF_DBG(dm, DBG_RF_MP, "[kfree] 5G s1 pa_bias=0x%x\n", pg_pa_bias);
odm_set_rf_reg(dm, RF_PATH_B, 0x60, 0x000f0000, pg_pa_bias);
power_trim_info->pa_bias_flag |= PA_BIAS_FLAG_ON;
} else {
RF_DBG(dm, DBG_RF_MP, "[kfree] 8822c tx pa bias no pg\n");
}
}
void phydm_do_new_kfree(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (dm->support_ic_type & ODM_RTL8822C) {
phydm_get_set_thermal_trim_offset_8822c(dm);
phydm_get_power_trim_offset_8822c(dm);
phydm_get_set_pa_bias_offset_8822c(dm);
}
}
void phydm_set_kfree_to_rf(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (dm->support_ic_type & ODM_RTL8814A)
phydm_set_kfree_to_rf_8814a(dm, e_rf_path, data);
if ((dm->support_ic_type & ODM_RTL8821C) &&
(*dm->band_type == ODM_BAND_2_4G))
phydm_set_kfree_to_rf_8821c(dm, e_rf_path, true, data);
else if (dm->support_ic_type & ODM_RTL8821C)
phydm_set_kfree_to_rf_8821c(dm, e_rf_path, false, data);
if (dm->support_ic_type & ODM_RTL8822B)
phydm_set_kfree_to_rf_8822b(dm, e_rf_path, data);
if (dm->support_ic_type & ODM_RTL8710B)
phydm_set_kfree_to_rf_8710b(dm, e_rf_path, data);
if (dm->support_ic_type & ODM_RTL8198F)
phydm_set_kfree_to_rf_8198f(dm, e_rf_path, data);
}
void phydm_clear_kfree_to_rf(void *dm_void, u8 e_rf_path, u8 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
if (dm->support_ic_type & ODM_RTL8822B)
phydm_clear_kfree_to_rf_8822b(dm, e_rf_path, 1);
if (dm->support_ic_type & ODM_RTL8821C)
phydm_clear_kfree_to_rf_8821c(dm, e_rf_path, 1);
if (dm->support_ic_type & ODM_RTL8198F)
phydm_clear_kfree_to_rf_8198f(dm, e_rf_path, 0);
}
void phydm_get_thermal_trim_offset(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
PEFUSE_HAL pEfuseHal = &hal_data->EfuseHal;
u1Byte eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
RF_DBG(dm, DBG_RF_MP, "[kfree] dump efuse fail !!!\n");
#endif
if (dm->support_ic_type & ODM_RTL8821C)
phydm_get_thermal_trim_offset_8821c(dm_void);
else if (dm->support_ic_type & ODM_RTL8822B)
phydm_get_thermal_trim_offset_8822b(dm_void);
else if (dm->support_ic_type & ODM_RTL8710B)
phydm_get_thermal_trim_offset_8710b(dm_void);
else if (dm->support_ic_type & ODM_RTL8192F)
phydm_get_thermal_trim_offset_8192f(dm_void);
else if (dm->support_ic_type & ODM_RTL8198F)
phydm_get_thermal_trim_offset_8198f(dm_void);
}
void phydm_get_power_trim_offset(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if 0 //(DM_ODM_SUPPORT_TYPE & ODM_WIN) // 2017 MH DM Should use the same code.s
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
PEFUSE_HAL pEfuseHal = &hal_data->EfuseHal;
u1Byte eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO(adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
RF_DBG(dm, DBG_RF_MP, "[kfree] dump efuse fail !!!\n");
#endif
if (dm->support_ic_type & ODM_RTL8821C)
phydm_get_power_trim_offset_8821c(dm_void);
else if (dm->support_ic_type & ODM_RTL8822B)
phydm_get_power_trim_offset_8822b(dm_void);
else if (dm->support_ic_type & ODM_RTL8710B)
phydm_get_power_trim_offset_8710b(dm_void);
else if (dm->support_ic_type & ODM_RTL8192F)
phydm_get_power_trim_offset_8192f(dm_void);
else if (dm->support_ic_type & ODM_RTL8198F)
phydm_get_power_trim_offset_8198f(dm_void);
}
void phydm_get_pa_bias_offset(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE & ODM_WIN)
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
PEFUSE_HAL pEfuseHal = &hal_data->EfuseHal;
u1Byte eFuseContent[DCMD_EFUSE_MAX_SECTION_NUM * EFUSE_MAX_WORD_UNIT * 2];
if (HAL_MAC_Dump_EFUSE(&GET_HAL_MAC_INFO((PADAPTER)adapter), EFUSE_WIFI, eFuseContent, pEfuseHal->PhysicalLen_WiFi, HAL_MAC_EFUSE_PHYSICAL, HAL_MAC_EFUSE_PARSE_DRV) != RT_STATUS_SUCCESS)
RF_DBG(dm, DBG_RF_MP, "[kfree] dump efuse fail !!!\n");
#endif
if (dm->support_ic_type & ODM_RTL8822B)
phydm_get_pa_bias_offset_8822b(dm_void);
}
s8 phydm_get_thermal_offset(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *power_trim_info = &dm->power_trim_data;
if (power_trim_info->flag & KFREE_FLAG_THERMAL_K_ON)
return power_trim_info->thermal;
else
return 0;
}
void phydm_do_kfree(void *dm_void, u8 channel_to_sw)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct odm_power_trim_data *pwrtrim = &dm->power_trim_data;
u8 channel_idx = 0, rfpath = 0, max_path = 0, kfree_band_num = 0;
u8 i, j;
s8 bb_gain;
if (dm->support_ic_type & ODM_RTL8814A)
max_path = 4; /*0~3*/
else if (dm->support_ic_type &
(ODM_RTL8812 | ODM_RTL8822B | ODM_RTL8192F)) {
max_path = 2; /*0~1*/
kfree_band_num = KFREE_BAND_NUM;
} else if (dm->support_ic_type & ODM_RTL8821C) {
max_path = 1;
kfree_band_num = KFREE_BAND_NUM;
} else if (dm->support_ic_type & ODM_RTL8710B) {
max_path = 1;
kfree_band_num = 1;
} else if (dm->support_ic_type & ODM_RTL8198F) {
max_path = 4;
kfree_band_num = 3;
}
if (dm->support_ic_type &
(ODM_RTL8192F | ODM_RTL8822B | ODM_RTL8821C |
ODM_RTL8814A | ODM_RTL8710B)) {
for (i = 0; i < kfree_band_num; i++) {
for (j = 0; j < max_path; j++)
RF_DBG(dm, DBG_RF_MP,
"[kfree] PwrTrim->gain[%d][%d]=0x%X\n",
i, j, pwrtrim->bb_gain[i][j]);
}
}
if (*dm->band_type == ODM_BAND_2_4G &&
pwrtrim->flag & KFREE_FLAG_ON_2G) {
if (!(dm->support_ic_type & ODM_RTL8192F)) {
if (channel_to_sw >= 1 && channel_to_sw <= 14)
channel_idx = PHYDM_2G;
for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s:chnl=%d PATH=%d gain:0x%X\n",
__func__, channel_to_sw, rfpath,
pwrtrim->bb_gain[channel_idx][rfpath]);
bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
phydm_set_kfree_to_rf(dm, rfpath, bb_gain);
}
} else if (dm->support_ic_type & ODM_RTL8192F) {
if (channel_to_sw >= 1 && channel_to_sw <= 3)
channel_idx = 0;
if (channel_to_sw >= 4 && channel_to_sw <= 9)
channel_idx = 1;
if (channel_to_sw >= 10 && channel_to_sw <= 14)
channel_idx = 2;
for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s:chnl=%d PATH=%d gain:0x%X\n",
__func__, channel_to_sw, rfpath,
pwrtrim->bb_gain[channel_idx][rfpath]);
bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
phydm_set_kfree_to_rf_8192f(dm, rfpath,
channel_idx,
bb_gain);
}
}
} else if (*dm->band_type == ODM_BAND_5G &&
pwrtrim->flag & KFREE_FLAG_ON_5G) {
if (channel_to_sw >= 36 && channel_to_sw <= 48)
channel_idx = PHYDM_5GLB1;
if (channel_to_sw >= 52 && channel_to_sw <= 64)
channel_idx = PHYDM_5GLB2;
if (channel_to_sw >= 100 && channel_to_sw <= 120)
channel_idx = PHYDM_5GMB1;
if (channel_to_sw >= 122 && channel_to_sw <= 144)
channel_idx = PHYDM_5GMB2;
if (channel_to_sw >= 149 && channel_to_sw <= 177)
channel_idx = PHYDM_5GHB;
for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s: channel=%d PATH=%d bb_gain:0x%X\n",
__func__, channel_to_sw, rfpath,
pwrtrim->bb_gain[channel_idx][rfpath]);
bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
phydm_set_kfree_to_rf(dm, rfpath, bb_gain);
}
} else {
RF_DBG(dm, DBG_RF_MP, "[kfree] Set default Register\n");
if (!(dm->support_ic_type & ODM_RTL8192F)) {
for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++) {
bb_gain = pwrtrim->bb_gain[channel_idx][rfpath];
phydm_clear_kfree_to_rf(dm, rfpath, bb_gain);
}
}
#if 0
/*else if(dm->support_ic_type & ODM_RTL8192F){
if (channel_to_sw >= 1 && channel_to_sw <= 3)
channel_idx = 0;
if (channel_to_sw >= 4 && channel_to_sw <= 9)
channel_idx = 1;
if (channel_to_sw >= 9 && channel_to_sw <= 14)
channel_idx = 2;
for (rfpath = RF_PATH_A; rfpath < max_path; rfpath++)
phydm_clear_kfree_to_rf_8192f(dm, rfpath, pwrtrim->bb_gain[channel_idx][rfpath]);
}*/
#endif
}
}
void phydm_config_new_kfree(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
if (cali_info->reg_rf_kfree_enable == 2) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s: reg_rf_kfree_enable == 2, Disable\n",
__func__);
return;
} else if (cali_info->reg_rf_kfree_enable == 1 ||
cali_info->reg_rf_kfree_enable == 0) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s: reg_rf_kfree_enable == true\n", __func__);
phydm_do_new_kfree(dm);
}
}
void phydm_config_kfree(void *dm_void, u8 channel_to_sw)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
struct odm_power_trim_data *pwrtrim = &dm->power_trim_data;
RF_DBG(dm, DBG_RF_MP, "===>[kfree] phy_ConfigKFree()\n");
if (cali_info->reg_rf_kfree_enable == 2) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s: reg_rf_kfree_enable == 2, Disable\n",
__func__);
return;
} else if (cali_info->reg_rf_kfree_enable == 1 ||
cali_info->reg_rf_kfree_enable == 0) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s: reg_rf_kfree_enable == true\n", __func__);
/*Make sure the targetval is defined*/
if (!(pwrtrim->flag & KFREE_FLAG_ON)) {
RF_DBG(dm, DBG_RF_MP,
"[kfree] %s: efuse is 0xff, KFree not work\n",
__func__);
return;
}
#if 0
/*if kfree_table[0] == 0xff, means no Kfree*/
#endif
phydm_do_kfree(dm, channel_to_sw);
}
RF_DBG(dm, DBG_RF_MP, "<===[kfree] phy_ConfigKFree()\n");
}
================================================
FILE: hal/phydm/halrf/halrf_kfree.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_KFREE_H__
#define __HALRF_KFREE_H__
#define KFREE_VERSION "1.0"
#define KFREE_BAND_NUM 8
#define KFREE_CH_NUM 3
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_AP))
#define BB_GAIN_NUM 6
#endif
#define KFREE_FLAG_ON BIT(0)
#define KFREE_FLAG_THERMAL_K_ON BIT(1)
#define KFREE_FLAG_ON_2G BIT(2)
#define KFREE_FLAG_ON_5G BIT(3)
#define PA_BIAS_FLAG_ON BIT(4)
#define PPG_THERMAL_OFFSET_98F 0x50
#define PPG_2GM_TXAB_98F 0x51
#define PPG_2GM_TXCD_98F 0x52
#define PPG_2GL_TXAB_98F 0x53
#define PPG_2GL_TXCD_98F 0x54
#define PPG_2GH_TXAB_98F 0x55
#define PPG_2GH_TXCD_98F 0x56
#define PPG_THERMAL_OFFSET_21C 0x1EF
#define PPG_2G_TXAB_21C 0x1EE
#define PPG_5GL1_TXA_21C 0x1EC
#define PPG_5GL2_TXA_21C 0x1E8
#define PPG_5GM1_TXA_21C 0x1E4
#define PPG_5GM2_TXA_21C 0x1E0
#define PPG_5GH1_TXA_21C 0x1DC
#define PPG_THERMAL_OFFSET_22B 0x3EF
#define PPG_2G_TXAB_22B 0x3EE
#define PPG_2G_TXCD_22B 0x3ED
#define PPG_5GL1_TXA_22B 0x3EC
#define PPG_5GL1_TXB_22B 0x3EB
#define PPG_5GL1_TXC_22B 0x3EA
#define PPG_5GL1_TXD_22B 0x3E9
#define PPG_5GL2_TXA_22B 0x3E8
#define PPG_5GL2_TXB_22B 0x3E7
#define PPG_5GL2_TXC_22B 0x3E6
#define PPG_5GL2_TXD_22B 0x3E5
#define PPG_5GM1_TXA_22B 0x3E4
#define PPG_5GM1_TXB_22B 0x3E3
#define PPG_5GM1_TXC_22B 0x3E2
#define PPG_5GM1_TXD_22B 0x3E1
#define PPG_5GM2_TXA_22B 0x3E0
#define PPG_5GM2_TXB_22B 0x3DF
#define PPG_5GM2_TXC_22B 0x3DE
#define PPG_5GM2_TXD_22B 0x3DD
#define PPG_5GH1_TXA_22B 0x3DC
#define PPG_5GH1_TXB_22B 0x3DB
#define PPG_5GH1_TXC_22B 0x3DA
#define PPG_5GH1_TXD_22B 0x3D9
#define PPG_PABIAS_2GA_22B 0x3D5
#define PPG_PABIAS_2GB_22B 0x3D6
#define PPG_THERMAL_A_OFFSET_22C 0x1ef
#define PPG_THERMAL_B_OFFSET_22C 0x1b0
#define PPG_2GL_TXAB_22C 0x1d4
#define PPG_2GM_TXAB_22C 0x1ee
#define PPG_2GH_TXAB_22C 0x1d2
#define PPG_5GL1_TXA_22C 0x1ec
#define PPG_5GL1_TXB_22C 0x1eb
#define PPG_5GL2_TXA_22C 0x1e8
#define PPG_5GL2_TXB_22C 0x1e7
#define PPG_5GM1_TXA_22C 0x1e4
#define PPG_5GM1_TXB_22C 0x1e3
#define PPG_5GM2_TXA_22C 0x1e0
#define PPG_5GM2_TXB_22C 0x1df
#define PPG_5GH1_TXA_22C 0x1dc
#define PPG_5GH1_TXB_22C 0x1db
#define PPG_PABIAS_2GA_22C 0x1d6
#define PPG_PABIAS_2GB_22C 0x1d5
#define PPG_PABIAS_5GA_22C 0x1d8
#define PPG_PABIAS_5GB_22C 0x1d7
struct odm_power_trim_data {
u8 flag;
u8 pa_bias_flag;
s8 bb_gain[KFREE_BAND_NUM][MAX_RF_PATH];
s8 thermal;
};
enum phydm_kfree_channeltosw {
PHYDM_2G = 0,
PHYDM_5GLB1 = 1,
PHYDM_5GLB2 = 2,
PHYDM_5GMB1 = 3,
PHYDM_5GMB2 = 4,
PHYDM_5GHB = 5,
};
void phydm_get_thermal_trim_offset(void *dm_void);
void phydm_get_power_trim_offset(void *dm_void);
void phydm_get_pa_bias_offset(void *dm_void);
s8 phydm_get_thermal_offset(void *dm_void);
void phydm_clear_kfree_to_rf(void *dm_void, u8 e_rf_path, u8 data);
void phydm_config_new_kfree(void *dm_void);
void phydm_config_kfree(void *dm_void, u8 channel_to_sw);
#endif /*__HALRF_KFREE_H__*/
================================================
FILE: hal/phydm/halrf/halrf_powertracking.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*@************************************************************
* include files
* ************************************************************
*/
#include "mp_precomp.h"
#include "phydm_precomp.h"
boolean
odm_check_power_status(void *dm_void)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
struct dm_struct *dm = (struct dm_struct *)dm_void;
PADAPTER *adapter = dm->adapter;
RT_RF_POWER_STATE rt_state;
MGNT_INFO *mgnt_info = &((PADAPTER)adapter)->MgntInfo;
/* 2011/07/27 MH We are not testing ready~~!! We may fail to get correct value when init sequence. */
if (mgnt_info->init_adpt_in_progress == true) {
RF_DBG(dm, DBG_RF_INIT,
"check_pow_status Return true, due to initadapter\n");
return true;
}
/*
* 2011/07/19 MH We can not execute tx pwoer tracking/ LLC calibrate or IQK.
*/
((PADAPTER)adapter)->HalFunc.GetHwRegHandler((PADAPTER)adapter, HW_VAR_RF_STATE, (u8 *)(&rt_state));
if (((PADAPTER)adapter)->bDriverStopped || ((PADAPTER)adapter)->bDriverIsGoingToPnpSetPowerSleep || rt_state == eRfOff) {
RF_DBG(dm, DBG_RF_INIT,
"check_pow_status Return false, due to %d/%d/%d\n",
((PADAPTER)adapter)->bDriverStopped,
((PADAPTER)adapter)->bDriverIsGoingToPnpSetPowerSleep,
rt_state);
return false;
}
#endif
return true;
}
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
void halrf_update_pwr_track(void *dm_void, u8 rate)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
u8 path_idx = 0;
#endif
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "Pwr Track Get rate=0x%x\n", rate);
dm->tx_rate = rate;
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
#if DEV_BUS_TYPE == RT_PCI_INTERFACE
#if USE_WORKITEM
odm_schedule_work_item(&dm->ra_rpt_workitem);
#else
if (dm->support_ic_type == ODM_RTL8821) {
#if (RTL8821A_SUPPORT == 1)
odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
#endif
} else if (dm->support_ic_type == ODM_RTL8812) {
for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8812A; path_idx++) {
#if (RTL8812A_SUPPORT == 1)
odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, path_idx, 0);
#endif
}
} else if (dm->support_ic_type == ODM_RTL8723B) {
#if (RTL8723B_SUPPORT == 1)
odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
#endif
} else if (dm->support_ic_type == ODM_RTL8192E) {
for (path_idx = RF_PATH_A; path_idx < MAX_PATH_NUM_8192E; path_idx++) {
#if (RTL8192E_SUPPORT == 1)
odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, path_idx, 0);
#endif
}
} else if (dm->support_ic_type == ODM_RTL8188E) {
#if (RTL8188E_SUPPORT == 1)
odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
#endif
}
#endif
#else
odm_schedule_work_item(&dm->ra_rpt_workitem);
#endif
#endif
}
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void halrf_update_init_rate_work_item_callback(
void *context)
{
void *adapter = (void *)context;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_struct *dm = &hal_data->DM_OutSrc;
u8 p = 0;
if (dm->support_ic_type == ODM_RTL8821) {
#if (RTL8821A_SUPPORT == 1)
odm_tx_pwr_track_set_pwr8821a(dm, MIX_MODE, RF_PATH_A, 0);
#endif
} else if (dm->support_ic_type == ODM_RTL8812) {
#if (RTL8812A_SUPPORT == 1)
/*Don't know how to include &c*/
for (p = RF_PATH_A; p < MAX_PATH_NUM_8812A; p++)
odm_tx_pwr_track_set_pwr8812a(dm, MIX_MODE, p, 0);
#endif
} else if (dm->support_ic_type == ODM_RTL8723B) {
#if (RTL8723B_SUPPORT == 1)
odm_tx_pwr_track_set_pwr_8723b(dm, MIX_MODE, RF_PATH_A, 0);
#endif
} else if (dm->support_ic_type == ODM_RTL8192E) {
#if (RTL8192E_SUPPORT == 1)
/*Don't know how to include &c*/
for (p = RF_PATH_A; p < MAX_PATH_NUM_8192E; p++)
odm_tx_pwr_track_set_pwr92_e(dm, MIX_MODE, p, 0);
#endif
} else if (dm->support_ic_type == ODM_RTL8188E) {
#if (RTL8188E_SUPPORT == 1)
odm_tx_pwr_track_set_pwr88_e(dm, MIX_MODE, RF_PATH_A, 0);
#endif
}
}
#endif
void halrf_set_pwr_track(void *dm_void, u8 enable)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
struct txpwrtrack_cfg c;
u8 i;
configure_txpower_track(dm, &c);
if (enable)
rf->rf_supportability = rf->rf_supportability | HAL_RF_TX_PWR_TRACK;
else {
rf->rf_supportability = rf->rf_supportability & ~HAL_RF_TX_PWR_TRACK;
odm_clear_txpowertracking_state(dm);
for (i = 0; i < c.rf_path_count; i++)
(*c.odm_tx_pwr_track_set_pwr)(dm, CLEAN_MODE, i, 0);
}
/*halrf_do_tssi(dm);*/
}
================================================
FILE: hal/phydm/halrf/halrf_powertracking.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_POWER_TRACKING_H__
#define __HALRF_POWER_TRACKING_H__
boolean
odm_check_power_status(void *dm_void);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
void halrf_update_pwr_track(void *dm_void, u8 rate);
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void halrf_update_init_rate_work_item_callback(
void *context);
#endif
void halrf_set_pwr_track(void *dm_void, u8 enable);
#endif /*#ifndef __HALRF_POWERTRACKING_H__*/
================================================
FILE: hal/phydm/halrf/halrf_powertracking_ap.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/* ************************************************************
* include files
* ************************************************************ */
#include "mp_precomp.h"
#include "phydm_precomp.h"
#if !defined(_OUTSRC_COEXIST)
/* ************************************************************
* Global var
* ************************************************************ */
u32 ofdm_swing_table_new[OFDM_TABLE_SIZE_92D] = {
0x0b40002d, /* 0, -15.0dB */
0x0c000030, /* 1, -14.5dB */
0x0cc00033, /* 2, -14.0dB */
0x0d800036, /* 3, -13.5dB */
0x0e400039, /* 4, -13.0dB */
0x0f00003c, /* 5, -12.5dB */
0x10000040, /* 6, -12.0dB */
0x11000044, /* 7, -11.5dB */
0x12000048, /* 8, -11.0dB */
0x1300004c, /* 9, -10.5dB */
0x14400051, /* 10, -10.0dB */
0x15800056, /* 11, -9.5dB */
0x16c0005b, /* 12, -9.0dB */
0x18000060, /* 13, -8.5dB */
0x19800066, /* 14, -8.0dB */
0x1b00006c, /* 15, -7.5dB */
0x1c800072, /* 16, -7.0dB */
0x1e400079, /* 17, -6.5dB */
0x20000080, /* 18, -6.0dB */
0x22000088, /* 19, -5.5dB */
0x24000090, /* 20, -5.0dB */
0x26000098, /* 21, -4.5dB */
0x288000a2, /* 22, -4.0dB */
0x2ac000ab, /* 23, -3.5dB */
0x2d4000b5, /* 24, -3.0dB */
0x300000c0, /* 25, -2.5dB */
0x32c000cb, /* 26, -2.0dB */
0x35c000d7, /* 27, -1.5dB */
0x390000e4, /* 28, -1.0dB */
0x3c8000f2, /* 29, -0.5dB */
0x40000100, /* 30, +0dB */
0x43c0010f, /* 31, +0.5dB */
0x47c0011f, /* 32, +1.0dB */
0x4c000130, /* 33, +1.5dB */
0x50800142, /* 34, +2.0dB */
0x55400155, /* 35, +2.5dB */
0x5a400169, /* 36, +3.0dB */
0x5fc0017f, /* 37, +3.5dB */
0x65400195, /* 38, +4.0dB */
0x6b8001ae, /* 39, +4.5dB */
0x71c001c7, /* 40, +5.0dB */
0x788001e2, /* 41, +5.5dB */
0x7f8001fe /* 42, +6.0dB */
};
u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}, /* 0, -16.0dB */
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 1, -15.5dB */
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 2, -15.0dB */
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 3, -14.5dB */
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 4, -14.0dB */
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 5, -13.5dB */
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 6, -13.0dB */
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 7, -12.5dB */
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 8, -12.0dB */
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 9, -11.5dB */
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 10, -11.0dB */
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 11, -10.5dB */
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 12, -10.0dB */
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 13, -9.5dB */
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 15, -8.5dB */
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 17, -7.5dB */
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 19, -6.5dB */
{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 21, -5.5dB */
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 23, -4.5dB */
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 26, -3.0dB */
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 27, -2.5dB */
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 29, -1.5dB */
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} /* 32, +0dB */
};
u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}, /* 0, -16.0dB */
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 1, -15.5dB */
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 2, -15.0dB */
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 3, -14.5dB */
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 4, -14.0dB */
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 5, -13.5dB */
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 6, -13.0dB */
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 7, -12.5dB */
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 8, -12.0dB */
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 9, -11.5dB */
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 10, -11.0dB */
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 11, -10.5dB */
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 12, -10.0dB */
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 13, -9.5dB */
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 15, -8.5dB */
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 17, -7.5dB */
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 19, -6.5dB */
{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 21, -5.5dB */
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /* 23, -4.5dB */
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 26, -3.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /* 27, -2.5dB */
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /* 29, -1.5dB */
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} /* 32, +0dB */
};
u32 ofdm_swing_table[OFDM_TABLE_SIZE_92D] = {
0x0b40002d, /* 0, -15.0dB */
0x0c000030, /* 1, -14.5dB */
0x0cc00033, /* 2, -14.0dB */
0x0d800036, /* 3, -13.5dB */
0x0e400039, /* 4, -13.0dB */
0x0f00003c, /* 5, -12.5dB */
0x10000040, /* 6, -12.0dB */
0x11000044, /* 7, -11.5dB */
0x12000048, /* 8, -11.0dB */
0x1300004c, /* 9, -10.5dB */
0x14400051, /* 10, -10.0dB */
0x15800056, /* 11, -9.5dB */
0x16c0005b, /* 12, -9.0dB */
0x18000060, /* 13, -8.5dB */
0x19800066, /* 14, -8.0dB */
0x1b00006c, /* 15, -7.5dB */
0x1c800072, /* 16, -7.0dB */
0x1e400079, /* 17, -6.5dB */
0x20000080, /* 18, -6.0dB */
0x22000088, /* 19, -5.5dB */
0x24000090, /* 20, -5.0dB */
0x26000098, /* 21, -4.5dB */
0x288000a2, /* 22, -4.0dB */
0x2ac000ab, /* 23, -3.5dB */
0x2d4000b5, /* 24, -3.0dB */
0x300000c0, /* 25, -2.5dB */
0x32c000cb, /* 26, -2.0dB */
0x35c000d7, /* 27, -1.5dB */
0x390000e4, /* 28, -1.0dB */
0x3c8000f2, /* 29, -0.5dB */
0x40000100, /* 30, +0dB */
0x43c0010f, /* 31, +0.5dB */
0x47c0011f, /* 32, +1.0dB */
0x4c000130, /* 33, +1.5dB */
0x50800142, /* 34, +2.0dB */
0x55400155, /* 35, +2.5dB */
0x5a400169, /* 36, +3.0dB */
0x5fc0017f, /* 37, +3.5dB */
0x65400195, /* 38, +4.0dB */
0x6b8001ae, /* 39, +4.5dB */
0x71c001c7, /* 40, +5.0dB */
0x788001e2, /* 41, +5.5dB */
0x7f8001fe /* 42, +6.0dB */
};
u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}, /* 0, -16.0dB */
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 1, -15.5dB */
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 2, -15.0dB */
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 3, -14.5dB */
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 4, -14.0dB */
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 5, -13.5dB */
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 6, -13.0dB */
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 7, -12.5dB */
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 8, -12.0dB */
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 9, -11.5dB */
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 10, -11.0dB */
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 11, -10.5dB */
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 12, -10.0dB */
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 13, -9.5dB */
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 15, -8.5dB */
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 17, -7.5dB */
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 19, -6.5dB */
{0x1c, 0x1a, 0x18, 0x12, 0x0e, 0x08, 0x04, 0x02}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 21, -5.5dB */
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 23, -4.5dB */
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 26, -3.0dB */
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 27, -2.5dB */
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 29, -1.5dB */
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} /* 32, +0dB */
};
u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}, /* 0, -16.0dB */
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 1, -15.5dB */
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 2, -15.0dB */
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 3, -14.5dB */
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 4, -14.0dB */
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 5, -13.5dB */
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 6, -13.0dB */
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 7, -12.5dB */
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 8, -12.0dB */
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 9, -11.5dB */
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 10, -11.0dB */
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 11, -10.5dB */
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 12, -10.0dB */
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 13, -9.5dB */
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 15, -8.5dB */
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 17, -7.5dB */
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 19, -6.5dB */
{0x1c, 0x1a, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 21, -5.5dB */
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /* 23, -4.5dB */
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 26, -3.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /* 27, -2.5dB */
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /* 29, -1.5dB */
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} /* 32, +0dB */
};
u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 0 -16dB */
{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 1 -15.5dB */
{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 2 -15dB */
{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 3 -14.5dB */
{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 4 -14dB */
{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 5 -13.5dB */
{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 6 -13dB */
{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 7 -12.5dB */
{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 8 -12dB */
{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 9 -11.5dB */
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 10 -11dB */
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 11 -10.5dB */
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 12 -10dB */
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 13 -9.5dB */
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 14 -9dB */
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 15 -8.5dB */
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 16 -8dB */
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 17 -7.5dB */
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 18 -7dB */
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 19 -6.5dB */
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0} /* 20 -6dB */
};
u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
{0x16, 0x15, 0x13, 0x10, 0xD, 0x9, 0x6, 0x3, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 0 -16dB */
{0x18, 0x17, 0x15, 0x12, 0xE, 0xA, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 1 -15.5dB */
{0x1B, 0x1A, 0x18, 0x14, 0x10, 0xB, 0x7, 0x4, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 2 -15dB */
{0x1F, 0x1E, 0x1B, 0x17, 0x12, 0xD, 0x8, 0x5, 0x2, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 3 -14.5dB */
{0x22, 0x21, 0x1E, 0x19, 0x14, 0xE, 0x9, 0x5, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 4 -14dB */
{0x26, 0x25, 0x22, 0x1C, 0x16, 0x10, 0xA, 0x6, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 5 -13.5dB */
{0x2B, 0x2A, 0x26, 0x20, 0x19, 0x12, 0xC, 0x7, 0x3, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 6 -13dB */
{0x30, 0x2F, 0x2A, 0x24, 0x1C, 0x14, 0xD, 0x8, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 7 -12.5dB */
{0x36, 0x34, 0x2F, 0x28, 0x1F, 0x17, 0xF, 0x9, 0x4, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 8 -12dB */
{0x3D, 0x3B, 0x35, 0x2D, 0x23, 0x19, 0x11, 0xA, 0x5, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 9 -11.5dB */
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0xB, 0x5, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 10 -11dB */
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0xC, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 11 -10.5dB */
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0xE, 0x6, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 12 -10dB */
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0xF, 0x7, 0x2, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 13 -9.5dB */
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x8, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 14 -9dB */
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x9, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 15 -8.5dB */
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0xA, 0x3, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 16 -8dB */
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0xB, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 17 -7.5dB */
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0xD, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 18 -7dB */
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0xE, 0x4, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, /* 19 -6.5dB */
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x5, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0} /* 20 -6dB */
};
u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
/* Winnita ADD 20171113 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263, /*19*/
0x287, /*20*/
0x2AE, /*21*/
0x2D6, /*22*/
0x301, /*23*/
0x32F, /*24*/
0x35F, /*25*/
0x392, /*26*/
0x3C9, /*27*/
0x402, /*28*/
0x43F, /*29*/
0x47F, /*30*/
0x4C3, /*31*/
0x50C, /*32*/
0x558, /*33*/
0x5A9, /*34*/
0x5FF, /*35*/
0x65A, /*36*/
0x6BA,
0x720,
0x78C,
0x7FF,
};
#if 0
u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E] = {
/* Index0 6 dB */ 0x7fc001ff,
/* Index1 5.7dB */ 0x7b4001ed,
/* Index2 5.4dB */ 0x774001dd,
/* Index3 5.1dB */ 0x734001cd,
/* Index4 4.8dB */ 0x6f4001bd,
/* Index5 4.5dB */ 0x6b8001ae,
/* Index6 4.2dB */ 0x67c0019f,
/* Index7 3.9dB */ 0x64400191,
/* Index8 3.6dB */ 0x60c00183,
/* Index9 3.3dB */ 0x5d800176,
/* Index10 3 dB */ 0x5a80016a,
/* Index11 2.7dB */ 0x5740015d,
/* Index12 2.4dB */ 0x54400151,
/* Index13 2.1dB */ 0x51800146,
/* Index14 1.8dB */ 0x4ec0013b,
/* Index15 1.5dB */ 0x4c000130,
/* Index16 1.2dB */ 0x49800126,
/* Index17 0.9dB */ 0x4700011c,
/* Index18 0.6dB */ 0x44800112,
/* Index19 0.3dB */ 0x42000108,
/* Index20 0 dB */ 0x40000100, /* 20 This is OFDM base index */
/* Index21 -0.3dB */ 0x3dc000f7,
/* Index22 -0.6dB */ 0x3bc000ef,
/* Index23 -0.9dB */ 0x39c000e7,
/* Index24 -1.2dB */ 0x37c000df,
/* Index25 -1.5dB */ 0x35c000d7,
/* Index26 -1.8dB */ 0x340000d0,
/* Index27 -2.1dB */ 0x324000c9,
/* Index28 -2.4dB */ 0x308000c2,
/* Index29 -2.7dB */ 0x2f0000bc,
/* Index30 -3 dB */ 0x2d4000b5,
/* Index31 -3.3dB */ 0x2bc000af,
/* Index32 -3.6dB */ 0x2a4000a9,
/* Index33 -3.9dB */ 0x28c000a3,
/* Index34 -4.2dB */ 0x2780009e,
/* Index35 -4.5dB */ 0x26000098,
/* Index36 -4.8dB */ 0x24c00093,
/* Index37 -5.1dB */ 0x2380008e,
/* Index38 -5.4dB */ 0x22400089,
/* Index39 -5.7dB */ 0x21400085,
/* Index40 -6 dB */ 0x20000080,
/* Index41 -6.3dB */ 0x1f00007c,
/* Index42 -6.6dB */ 0x1e000078,
/* Index43 -6.9dB */ 0x1d000074,
/* Index44 -7.2dB */ 0x1c000070,
/* Index45 -7.5dB */ 0x1b00006c,
/* Index46 -7.8dB */ 0x1a000068,
/* Index47 -8.1dB */ 0x19400065,
/* Index48 -8.4dB */ 0x18400061,
/* Index49 -8.7dB */ 0x1780005e,
/* Index50 -9 dB */ 0x16c0005b,
/* Index51 -9.3dB */ 0x16000058,
/* Index52 -9.6dB */ 0x15400055,
/* Index53 -9.9dB */ 0x14800052
};
u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8] = {
/* Index0 0 dB */ {0x36, 0x34, 0x2E, 0x26, 0x1C, 0x12, 0x08, 0x04},
/* Index1 -0.3dB */ {0x34, 0x32, 0x2C, 0x25, 0x1B, 0x11, 0x08, 0x04},
/* Index2 -0.6dB */ {0x32, 0x30, 0x2B, 0x23, 0x1A, 0x11, 0x07, 0x04},
/* Index3 -0.9dB */ {0x31, 0x2F, 0x29, 0x22, 0x19, 0x10, 0x07, 0x04},
/* Index4 -1.2dB */ {0x2F, 0x2D, 0x28, 0x21, 0x18, 0x10, 0x07, 0x03},
/* Index5 -1.5dB */ {0x2D, 0x2C, 0x27, 0x20, 0x18, 0x0F, 0x07, 0x03},
/* Index6 -1.8dB */ {0x2C, 0x2A, 0x25, 0x1F, 0x17, 0x0F, 0x06, 0x03},
/* Index7 -2.1dB */ {0x2A, 0x29, 0x24, 0x1E, 0x16, 0x0E, 0x06, 0x03},
/* Index8 -2.4dB */ {0x29, 0x27, 0x23, 0x1D, 0x15, 0x0E, 0x06, 0x03},
/* Index9 -2.7dB */ {0x27, 0x26, 0x22, 0x1C, 0x14, 0x0D, 0x06, 0x03},
/* Index10 -3 dB */ {0x26, 0x25, 0x20, 0x1B, 0x14, 0x0D, 0x06, 0x03},
/* Index11 -3.3dB */ {0x25, 0x23, 0x1F, 0x1A, 0x13, 0x0C, 0x05, 0x03},
/* Index12 -3.6dB */ {0x24, 0x22, 0x1E, 0x19, 0x12, 0x0C, 0x05, 0x03},
/* Index13 -3.9dB */ {0x22, 0x21, 0x1D, 0x18, 0x12, 0x0B, 0x05, 0x03},
/* Index14 -4.2dB */ {0x21, 0x20, 0x1C, 0x17, 0x11, 0x0B, 0x05, 0x02},
/* Index15 -4.5dB */ {0x20, 0x1F, 0x1B, 0x17, 0x11, 0x0B, 0x05, 0x02},
/* Index16 -4.8dB */ {0x1F, 0x1E, 0x1A, 0x16, 0x10, 0x0A, 0x05, 0x02},
/* Index17 -5.1dB */ {0x1E, 0x1D, 0x1A, 0x15, 0x10, 0x0A, 0x04, 0x02},
/* Index18 -5.4dB */ {0x1D, 0x1C, 0x19, 0x14, 0x0F, 0x0A, 0x04, 0x02},
/* Index19 -5.7dB */ {0x1C, 0x1B, 0x18, 0x14, 0x0E, 0x09, 0x04, 0x02},
/* Index20 -6.0dB */ {0x1B, 0x1A, 0x17, 0x13, 0x0E, 0x09, 0x04, 0x02}, /* 20 This is CCK base index */
/* Index21 -6.3dB */ {0x1A, 0x19, 0x16, 0x12, 0x0E, 0x09, 0x04, 0x02},
/* Index22 -6.6dB */ {0x19, 0x18, 0x15, 0x12, 0x0D, 0x08, 0x04, 0x02},
/* Index23 -6.9dB */ {0x18, 0x17, 0x15, 0x11, 0x0D, 0x08, 0x04, 0x02},
/* Index24 -7.2dB */ {0x18, 0x17, 0x14, 0x11, 0x0C, 0x08, 0x03, 0x02},
/* Index25 -7.5dB */ {0x17, 0x16, 0x13, 0x10, 0x0C, 0x08, 0x03, 0x02},
/* Index26 -7.8dB */ {0x16, 0x15, 0x13, 0x0F, 0x0B, 0x07, 0x03, 0x02},
/* Index27 -8.1dB */ {0x15, 0x14, 0x12, 0x0F, 0x0B, 0x07, 0x03, 0x02},
/* Index28 -8.4dB */ {0x14, 0x14, 0x11, 0x0E, 0x0B, 0x07, 0x03, 0x02},
/* Index29 -8.7dB */ {0x14, 0x13, 0x11, 0x0E, 0x0A, 0x07, 0x03, 0x01},
/* Index30 -9.0dB */ {0x13, 0x12, 0x10, 0x0D, 0x0A, 0x06, 0x03, 0x01}, /* 30 This is hp CCK base index */
/* Index31 -9.3dB */ {0x12, 0x12, 0x0F, 0x0D, 0x0A, 0x06, 0x03, 0x01},
/* Index32 -9.6dB */ {0x12, 0x11, 0x0F, 0x0D, 0x09, 0x06, 0x03, 0x01},
/* Index33 -9.9dB */ {0x11, 0x11, 0x0F, 0x0C, 0x09, 0x06, 0x03, 0x01},
/* Index34 -10.2dB */ {0x11, 0x11, 0x0E, 0x0C, 0x09, 0x06, 0x02, 0x01},
/* Index35 -10.5dB */ {0x10, 0x0F, 0x0E, 0x0B, 0x08, 0x05, 0x02, 0x01},
/* Index36 -10.8dB */ {0x10, 0x0F, 0x0D, 0x0B, 0x08, 0x05, 0x02, 0x01},
/* Index37 -11.1dB */ {0x0F, 0x0E, 0x0D, 0x0A, 0x08, 0x05, 0x02, 0x01},
/* Index38 -11.4dB */ {0x0E, 0x0E, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
/* Index39 -11.7dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
/* Index40 -12 dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
/* Index41 -12.3dB */ {0x0D, 0x0D, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
/* Index42 -12.6dB */ {0x0D, 0x0C, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
/* Index43 -12.9dB */ {0x0C, 0x0C, 0x0A, 0x09, 0x06, 0x04, 0x02, 0x01},
/* Index44 -13.2dB */ {0x0C, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
/* Index45 -13.5dB */ {0x0B, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
/* Index46 -13.8dB */ {0x0B, 0x0B, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},
/* Index47 -14.1dB */ {0x0B, 0x0A, 0x09, 0x07, 0x06, 0x04, 0x02, 0x01},
/* Index48 -14.4dB */ {0x0A, 0x0A, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},
/* Index49 -14.7dB */ {0x0A, 0x0A, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
/* Index50 -15 dB */ {0x0A, 0x09, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
/* Index51 -15.3dB */ {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
/* Index52 -15.6dB */ {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
/* Index53 -15.9dB */ {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}
};
u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
/* Index0 0 dB */ {0x36, 0x34, 0x2E, 0x26, 0x00, 0x00, 0x00, 0x00},
/* Index1 -0.3dB */ {0x34, 0x32, 0x2C, 0x25, 0x00, 0x00, 0x00, 0x00},
/* Index2 -0.6dB */ {0x32, 0x30, 0x2B, 0x23, 0x00, 0x00, 0x00, 0x00},
/* Index3 -0.9dB */ {0x31, 0x2F, 0x29, 0x22, 0x00, 0x00, 0x00, 0x00},
/* Index4 -1.2dB */ {0x2F, 0x2D, 0x28, 0x21, 0x00, 0x00, 0x00, 0x00},
/* Index5 -1.5dB */ {0x2D, 0x2C, 0x27, 0x20, 0x00, 0x00, 0x00, 0x00},
/* Index6 -1.8dB */ {0x2C, 0x2A, 0x25, 0x1F, 0x00, 0x00, 0x00, 0x00},
/* Index7 -2.1dB */ {0x2A, 0x29, 0x24, 0x1E, 0x00, 0x00, 0x00, 0x00},
/* Index8 -2.4dB */ {0x29, 0x27, 0x23, 0x1D, 0x00, 0x00, 0x00, 0x00},
/* Index9 -2.7dB */ {0x27, 0x26, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00},
/* Index10 -3 dB */ {0x26, 0x25, 0x20, 0x1B, 0x00, 0x00, 0x00, 0x00},
/* Index11 -3.3dB */ {0x25, 0x23, 0x1F, 0x1A, 0x00, 0x00, 0x00, 0x00},
/* Index12 -3.6dB */ {0x24, 0x22, 0x1E, 0x19, 0x00, 0x00, 0x00, 0x00},
/* Index13 -3.9dB */ {0x22, 0x21, 0x1D, 0x18, 0x00, 0x00, 0x00, 0x00},
/* Index14 -4.2dB */ {0x21, 0x20, 0x1C, 0x17, 0x00, 0x00, 0x00, 0x00},
/* Index15 -4.5dB */ {0x20, 0x1F, 0x1B, 0x17, 0x00, 0x00, 0x00, 0x00},
/* Index16 -4.8dB */ {0x1F, 0x1E, 0x1A, 0x16, 0x00, 0x00, 0x00, 0x00},
/* Index17 -5.1dB */ {0x1E, 0x1D, 0x1A, 0x15, 0x00, 0x00, 0x00, 0x00},
/* Index18 -5.4dB */ {0x1D, 0x1C, 0x19, 0x14, 0x00, 0x00, 0x00, 0x00},
/* Index19 -5.7dB */ {0x1C, 0x1B, 0x18, 0x14, 0x00, 0x00, 0x00, 0x00},
/* Index20 -6 dB */ {0x1B, 0x1A, 0x17, 0x13, 0x00, 0x00, 0x00, 0x00},
/* Index21 -6.3dB */ {0x1A, 0x19, 0x16, 0x12, 0x00, 0x00, 0x00, 0x00},
/* Index22 -6.6dB */ {0x19, 0x18, 0x15, 0x12, 0x00, 0x00, 0x00, 0x00},
/* Index23 -6.9dB */ {0x18, 0x17, 0x15, 0x11, 0x00, 0x00, 0x00, 0x00},
/* Index24 -7.2dB */ {0x18, 0x17, 0x14, 0x11, 0x00, 0x00, 0x00, 0x00},
/* Index25 -7.5dB */ {0x17, 0x16, 0x13, 0x10, 0x00, 0x00, 0x00, 0x00},
/* Index26 -7.8dB */ {0x16, 0x15, 0x13, 0x0F, 0x00, 0x00, 0x00, 0x00},
/* Index27 -8.1dB */ {0x15, 0x14, 0x12, 0x0F, 0x00, 0x00, 0x00, 0x00},
/* Index28 -8.4dB */ {0x14, 0x14, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
/* Index29 -8.7dB */ {0x14, 0x13, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
/* Index30 -9 dB */ {0x13, 0x12, 0x10, 0x0D, 0x00, 0x00, 0x00, 0x00},
/* Index31 -9.3dB */ {0x12, 0x12, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
/* Index32 -9.6dB */ {0x12, 0x11, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
/* Index33 -9.9dB */ {0x11, 0x11, 0x0F, 0x0C, 0x00, 0x00, 0x00, 0x00},
/* Index34 -10.2dB */ {0x11, 0x11, 0x0E, 0x0C, 0x00, 0x00, 0x00, 0x00},
/* Index35 -10.5dB */ {0x10, 0x0F, 0x0E, 0x0B, 0x00, 0x00, 0x00, 0x00},
/* Index36 -10.8dB */ {0x10, 0x0F, 0x0D, 0x0B, 0x00, 0x00, 0x00, 0x00},
/* Index37 -11.1dB */ {0x0F, 0x0E, 0x0D, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index38 -11.4dB */ {0x0E, 0x0E, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index39 -11.7dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index40 -12 dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index41 -12.3dB */ {0x0D, 0x0D, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
/* Index42 -12.6dB */ {0x0D, 0x0C, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
/* Index43 -12.9dB */ {0x0C, 0x0C, 0x0A, 0x09, 0x00, 0x00, 0x00, 0x00},
/* Index44 -13.2dB */ {0x0C, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
/* Index45 -13.5dB */ {0x0B, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
/* Index46 -13.8dB */ {0x0B, 0x0B, 0x09, 0x08, 0x00, 0x00, 0x00, 0x00},
/* Index47 -14.1dB */ {0x0B, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index48 -14.4dB */ {0x0A, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index49 -14.7dB */ {0x0A, 0x0A, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index50 -15 dB */ {0x0A, 0x09, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index51 -15.3dB */ {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
/* Index52 -15.6dB */ {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
/* Index53 -15.9dB */ {0x09, 0x08, 0x07, 0x06, 0x00, 0x00, 0x00, 0x00}
};
#endif
#endif
u8 delta_swing_table_idx_2ga_p_default[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3
, 4, 4, 4, 4, 4, 4, 4, 4, 5, 5, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9
};
u8 delta_swing_table_idx_2ga_n_default[DELTA_SWINGIDX_SIZE] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4
, 4, 5, 5, 6, 6, 7, 7, 7, 7, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11
};
#ifdef CONFIG_WLAN_HAL_8192EE
u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E] = {
/* Index0 6 dB */ 0x7fc001ff,
/* Index1 5.7dB */ 0x7b4001ed,
/* Index2 5.4dB */ 0x774001dd,
/* Index3 5.1dB */ 0x734001cd,
/* Index4 4.8dB */ 0x6f4001bd,
/* Index5 4.5dB */ 0x6b8001ae,
/* Index6 4.2dB */ 0x67c0019f,
/* Index7 3.9dB */ 0x64400191,
/* Index8 3.6dB */ 0x60c00183,
/* Index9 3.3dB */ 0x5d800176,
/* Index10 3 dB */ 0x5a80016a,
/* Index11 2.7dB */ 0x5740015d,
/* Index12 2.4dB */ 0x54400151,
/* Index13 2.1dB */ 0x51800146,
/* Index14 1.8dB */ 0x4ec0013b,
/* Index15 1.5dB */ 0x4c000130,
/* Index16 1.2dB */ 0x49800126,
/* Index17 0.9dB */ 0x4700011c,
/* Index18 0.6dB */ 0x44800112,
/* Index19 0.3dB */ 0x42000108,
/* Index20 0 dB */ 0x40000100, /* 20 This is OFDM base index */
/* Index21 -0.3dB */ 0x3dc000f7,
/* Index22 -0.6dB */ 0x3bc000ef,
/* Index23 -0.9dB */ 0x39c000e7,
/* Index24 -1.2dB */ 0x37c000df,
/* Index25 -1.5dB */ 0x35c000d7,
/* Index26 -1.8dB */ 0x340000d0,
/* Index27 -2.1dB */ 0x324000c9,
/* Index28 -2.4dB */ 0x308000c2,
/* Index29 -2.7dB */ 0x2f0000bc,
/* Index30 -3 dB */ 0x2d4000b5,
/* Index31 -3.3dB */ 0x2bc000af,
/* Index32 -3.6dB */ 0x2a4000a9,
/* Index33 -3.9dB */ 0x28c000a3,
/* Index34 -4.2dB */ 0x2780009e,
/* Index35 -4.5dB */ 0x26000098,
/* Index36 -4.8dB */ 0x24c00093,
/* Index37 -5.1dB */ 0x2380008e,
/* Index38 -5.4dB */ 0x22400089,
/* Index39 -5.7dB */ 0x21400085,
/* Index40 -6 dB */ 0x20000080,
/* Index41 -6.3dB */ 0x1f00007c,
/* Index42 -6.6dB */ 0x1e000078,
/* Index43 -6.9dB */ 0x1d000074,
/* Index44 -7.2dB */ 0x1c000070,
/* Index45 -7.5dB */ 0x1b00006c,
/* Index46 -7.8dB */ 0x1a000068,
/* Index47 -8.1dB */ 0x19400065,
/* Index48 -8.4dB */ 0x18400061,
/* Index49 -8.7dB */ 0x1780005e,
/* Index50 -9 dB */ 0x16c0005b,
/* Index51 -9.3dB */ 0x16000058,
/* Index52 -9.6dB */ 0x15400055,
/* Index53 -9.9dB */ 0x14800052
};
u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8] = {
/* Index0 0 dB */ {0x36, 0x34, 0x2E, 0x26, 0x1C, 0x12, 0x08, 0x04},
/* Index1 -0.3dB */ {0x34, 0x32, 0x2C, 0x25, 0x1B, 0x11, 0x08, 0x04},
/* Index2 -0.6dB */ {0x32, 0x30, 0x2B, 0x23, 0x1A, 0x11, 0x07, 0x04},
/* Index3 -0.9dB */ {0x31, 0x2F, 0x29, 0x22, 0x19, 0x10, 0x07, 0x04},
/* Index4 -1.2dB */ {0x2F, 0x2D, 0x28, 0x21, 0x18, 0x10, 0x07, 0x03},
/* Index5 -1.5dB */ {0x2D, 0x2C, 0x27, 0x20, 0x18, 0x0F, 0x07, 0x03},
/* Index6 -1.8dB */ {0x2C, 0x2A, 0x25, 0x1F, 0x17, 0x0F, 0x06, 0x03},
/* Index7 -2.1dB */ {0x2A, 0x29, 0x24, 0x1E, 0x16, 0x0E, 0x06, 0x03},
/* Index8 -2.4dB */ {0x29, 0x27, 0x23, 0x1D, 0x15, 0x0E, 0x06, 0x03},
/* Index9 -2.7dB */ {0x27, 0x26, 0x22, 0x1C, 0x14, 0x0D, 0x06, 0x03},
/* Index10 -3 dB */ {0x26, 0x25, 0x20, 0x1B, 0x14, 0x0D, 0x06, 0x03},
/* Index11 -3.3dB */ {0x25, 0x23, 0x1F, 0x1A, 0x13, 0x0C, 0x05, 0x03},
/* Index12 -3.6dB */ {0x24, 0x22, 0x1E, 0x19, 0x12, 0x0C, 0x05, 0x03},
/* Index13 -3.9dB */ {0x22, 0x21, 0x1D, 0x18, 0x12, 0x0B, 0x05, 0x03},
/* Index14 -4.2dB */ {0x21, 0x20, 0x1C, 0x17, 0x11, 0x0B, 0x05, 0x02},
/* Index15 -4.5dB */ {0x20, 0x1F, 0x1B, 0x17, 0x11, 0x0B, 0x05, 0x02},
/* Index16 -4.8dB */ {0x1F, 0x1E, 0x1A, 0x16, 0x10, 0x0A, 0x05, 0x02},
/* Index17 -5.1dB */ {0x1E, 0x1D, 0x1A, 0x15, 0x10, 0x0A, 0x04, 0x02},
/* Index18 -5.4dB */ {0x1D, 0x1C, 0x19, 0x14, 0x0F, 0x0A, 0x04, 0x02},
/* Index19 -5.7dB */ {0x1C, 0x1B, 0x18, 0x14, 0x0E, 0x09, 0x04, 0x02},
/* Index20 -6.0dB */ {0x1B, 0x1A, 0x17, 0x13, 0x0E, 0x09, 0x04, 0x02}, /* 20 This is CCK base index */
/* Index21 -6.3dB */ {0x1A, 0x19, 0x16, 0x12, 0x0E, 0x09, 0x04, 0x02},
/* Index22 -6.6dB */ {0x19, 0x18, 0x15, 0x12, 0x0D, 0x08, 0x04, 0x02},
/* Index23 -6.9dB */ {0x18, 0x17, 0x15, 0x11, 0x0D, 0x08, 0x04, 0x02},
/* Index24 -7.2dB */ {0x18, 0x17, 0x14, 0x11, 0x0C, 0x08, 0x03, 0x02},
/* Index25 -7.5dB */ {0x17, 0x16, 0x13, 0x10, 0x0C, 0x08, 0x03, 0x02},
/* Index26 -7.8dB */ {0x16, 0x15, 0x13, 0x0F, 0x0B, 0x07, 0x03, 0x02},
/* Index27 -8.1dB */ {0x15, 0x14, 0x12, 0x0F, 0x0B, 0x07, 0x03, 0x02},
/* Index28 -8.4dB */ {0x14, 0x14, 0x11, 0x0E, 0x0B, 0x07, 0x03, 0x02},
/* Index29 -8.7dB */ {0x14, 0x13, 0x11, 0x0E, 0x0A, 0x07, 0x03, 0x01},
/* Index30 -9.0dB */ {0x13, 0x12, 0x10, 0x0D, 0x0A, 0x06, 0x03, 0x01}, /* 30 This is hp CCK base index */
/* Index31 -9.3dB */ {0x12, 0x12, 0x0F, 0x0D, 0x0A, 0x06, 0x03, 0x01},
/* Index32 -9.6dB */ {0x12, 0x11, 0x0F, 0x0D, 0x09, 0x06, 0x03, 0x01},
/* Index33 -9.9dB */ {0x11, 0x11, 0x0F, 0x0C, 0x09, 0x06, 0x03, 0x01},
/* Index34 -10.2dB */ {0x11, 0x11, 0x0E, 0x0C, 0x09, 0x06, 0x02, 0x01},
/* Index35 -10.5dB */ {0x10, 0x0F, 0x0E, 0x0B, 0x08, 0x05, 0x02, 0x01},
/* Index36 -10.8dB */ {0x10, 0x0F, 0x0D, 0x0B, 0x08, 0x05, 0x02, 0x01},
/* Index37 -11.1dB */ {0x0F, 0x0E, 0x0D, 0x0A, 0x08, 0x05, 0x02, 0x01},
/* Index38 -11.4dB */ {0x0E, 0x0E, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
/* Index39 -11.7dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
/* Index40 -12 dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x07, 0x05, 0x02, 0x01},
/* Index41 -12.3dB */ {0x0D, 0x0D, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
/* Index42 -12.6dB */ {0x0D, 0x0C, 0x0B, 0x09, 0x07, 0x04, 0x02, 0x01},
/* Index43 -12.9dB */ {0x0C, 0x0C, 0x0A, 0x09, 0x06, 0x04, 0x02, 0x01},
/* Index44 -13.2dB */ {0x0C, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
/* Index45 -13.5dB */ {0x0B, 0x0B, 0x0A, 0x08, 0x06, 0x04, 0x02, 0x01},
/* Index46 -13.8dB */ {0x0B, 0x0B, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01},
/* Index47 -14.1dB */ {0x0B, 0x0A, 0x09, 0x07, 0x06, 0x04, 0x02, 0x01},
/* Index48 -14.4dB */ {0x0A, 0x0A, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01},
/* Index49 -14.7dB */ {0x0A, 0x0A, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
/* Index50 -15 dB */ {0x0A, 0x09, 0x08, 0x07, 0x05, 0x03, 0x01, 0x01},
/* Index51 -15.3dB */ {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
/* Index52 -15.6dB */ {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01},
/* Index53 -15.9dB */ {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}
};
u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8] = {
/* Index0 0 dB */ {0x36, 0x34, 0x2E, 0x26, 0x00, 0x00, 0x00, 0x00},
/* Index1 -0.3dB */ {0x34, 0x32, 0x2C, 0x25, 0x00, 0x00, 0x00, 0x00},
/* Index2 -0.6dB */ {0x32, 0x30, 0x2B, 0x23, 0x00, 0x00, 0x00, 0x00},
/* Index3 -0.9dB */ {0x31, 0x2F, 0x29, 0x22, 0x00, 0x00, 0x00, 0x00},
/* Index4 -1.2dB */ {0x2F, 0x2D, 0x28, 0x21, 0x00, 0x00, 0x00, 0x00},
/* Index5 -1.5dB */ {0x2D, 0x2C, 0x27, 0x20, 0x00, 0x00, 0x00, 0x00},
/* Index6 -1.8dB */ {0x2C, 0x2A, 0x25, 0x1F, 0x00, 0x00, 0x00, 0x00},
/* Index7 -2.1dB */ {0x2A, 0x29, 0x24, 0x1E, 0x00, 0x00, 0x00, 0x00},
/* Index8 -2.4dB */ {0x29, 0x27, 0x23, 0x1D, 0x00, 0x00, 0x00, 0x00},
/* Index9 -2.7dB */ {0x27, 0x26, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00},
/* Index10 -3 dB */ {0x26, 0x25, 0x20, 0x1B, 0x00, 0x00, 0x00, 0x00},
/* Index11 -3.3dB */ {0x25, 0x23, 0x1F, 0x1A, 0x00, 0x00, 0x00, 0x00},
/* Index12 -3.6dB */ {0x24, 0x22, 0x1E, 0x19, 0x00, 0x00, 0x00, 0x00},
/* Index13 -3.9dB */ {0x22, 0x21, 0x1D, 0x18, 0x00, 0x00, 0x00, 0x00},
/* Index14 -4.2dB */ {0x21, 0x20, 0x1C, 0x17, 0x00, 0x00, 0x00, 0x00},
/* Index15 -4.5dB */ {0x20, 0x1F, 0x1B, 0x17, 0x00, 0x00, 0x00, 0x00},
/* Index16 -4.8dB */ {0x1F, 0x1E, 0x1A, 0x16, 0x00, 0x00, 0x00, 0x00},
/* Index17 -5.1dB */ {0x1E, 0x1D, 0x1A, 0x15, 0x00, 0x00, 0x00, 0x00},
/* Index18 -5.4dB */ {0x1D, 0x1C, 0x19, 0x14, 0x00, 0x00, 0x00, 0x00},
/* Index19 -5.7dB */ {0x1C, 0x1B, 0x18, 0x14, 0x00, 0x00, 0x00, 0x00},
/* Index20 -6 dB */ {0x1B, 0x1A, 0x17, 0x13, 0x00, 0x00, 0x00, 0x00},
/* Index21 -6.3dB */ {0x1A, 0x19, 0x16, 0x12, 0x00, 0x00, 0x00, 0x00},
/* Index22 -6.6dB */ {0x19, 0x18, 0x15, 0x12, 0x00, 0x00, 0x00, 0x00},
/* Index23 -6.9dB */ {0x18, 0x17, 0x15, 0x11, 0x00, 0x00, 0x00, 0x00},
/* Index24 -7.2dB */ {0x18, 0x17, 0x14, 0x11, 0x00, 0x00, 0x00, 0x00},
/* Index25 -7.5dB */ {0x17, 0x16, 0x13, 0x10, 0x00, 0x00, 0x00, 0x00},
/* Index26 -7.8dB */ {0x16, 0x15, 0x13, 0x0F, 0x00, 0x00, 0x00, 0x00},
/* Index27 -8.1dB */ {0x15, 0x14, 0x12, 0x0F, 0x00, 0x00, 0x00, 0x00},
/* Index28 -8.4dB */ {0x14, 0x14, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
/* Index29 -8.7dB */ {0x14, 0x13, 0x11, 0x0E, 0x00, 0x00, 0x00, 0x00},
/* Index30 -9 dB */ {0x13, 0x12, 0x10, 0x0D, 0x00, 0x00, 0x00, 0x00},
/* Index31 -9.3dB */ {0x12, 0x12, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
/* Index32 -9.6dB */ {0x12, 0x11, 0x0F, 0x0D, 0x00, 0x00, 0x00, 0x00},
/* Index33 -9.9dB */ {0x11, 0x11, 0x0F, 0x0C, 0x00, 0x00, 0x00, 0x00},
/* Index34 -10.2dB */ {0x11, 0x11, 0x0E, 0x0C, 0x00, 0x00, 0x00, 0x00},
/* Index35 -10.5dB */ {0x10, 0x0F, 0x0E, 0x0B, 0x00, 0x00, 0x00, 0x00},
/* Index36 -10.8dB */ {0x10, 0x0F, 0x0D, 0x0B, 0x00, 0x00, 0x00, 0x00},
/* Index37 -11.1dB */ {0x0F, 0x0E, 0x0D, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index38 -11.4dB */ {0x0E, 0x0E, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index39 -11.7dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index40 -12 dB */ {0x0E, 0x0D, 0x0C, 0x0A, 0x00, 0x00, 0x00, 0x00},
/* Index41 -12.3dB */ {0x0D, 0x0D, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
/* Index42 -12.6dB */ {0x0D, 0x0C, 0x0B, 0x09, 0x00, 0x00, 0x00, 0x00},
/* Index43 -12.9dB */ {0x0C, 0x0C, 0x0A, 0x09, 0x00, 0x00, 0x00, 0x00},
/* Index44 -13.2dB */ {0x0C, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
/* Index45 -13.5dB */ {0x0B, 0x0B, 0x0A, 0x08, 0x00, 0x00, 0x00, 0x00},
/* Index46 -13.8dB */ {0x0B, 0x0B, 0x09, 0x08, 0x00, 0x00, 0x00, 0x00},
/* Index47 -14.1dB */ {0x0B, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index48 -14.4dB */ {0x0A, 0x0A, 0x09, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index49 -14.7dB */ {0x0A, 0x0A, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index50 -15 dB */ {0x0A, 0x09, 0x08, 0x07, 0x00, 0x00, 0x00, 0x00},
/* Index51 -15.3dB */ {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
/* Index52 -15.6dB */ {0x09, 0x09, 0x08, 0x06, 0x00, 0x00, 0x00, 0x00},
/* Index53 -15.9dB */ {0x09, 0x08, 0x07, 0x06, 0x00, 0x00, 0x00, 0x00}
};
#endif
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1)
u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
0x081, /* 0, -12.0dB */
0x088, /* 1, -11.5dB */
0x090, /* 2, -11.0dB */
0x099, /* 3, -10.5dB */
0x0A2, /* 4, -10.0dB */
0x0AC, /* 5, -9.5dB */
0x0B6, /* 6, -9.0dB */
0x0C0, /* 7, -8.5dB */
0x0CC, /* 8, -8.0dB */
0x0D8, /* 9, -7.5dB */
0x0E5, /* 10, -7.0dB */
0x0F2, /* 11, -6.5dB */
0x101, /* 12, -6.0dB */
0x110, /* 13, -5.5dB */
0x120, /* 14, -5.0dB */
0x131, /* 15, -4.5dB */
0x143, /* 16, -4.0dB */
0x156, /* 17, -3.5dB */
0x16A, /* 18, -3.0dB */
0x180, /* 19, -2.5dB */
0x197, /* 20, -2.0dB */
0x1AF, /* 21, -1.5dB */
0x1C8, /* 22, -1.0dB */
0x1E3, /* 23, -0.5dB */
0x200, /* 24, +0 dB */
0x21E, /* 25, +0.5dB */
0x23E, /* 26, +1.0dB */
0x261, /* 27, +1.5dB */
0x285, /* 28, +2.0dB */
0x2AB, /* 29, +2.5dB */
0x2D3, /* 30, +3.0dB */
0x2FE, /* 31, +3.5dB */
0x32B, /* 32, +4.0dB */
0x35C, /* 33, +4.5dB */
0x38E, /* 34, +5.0dB */
0x3C4, /* 35, +5.5dB */
0x3FE /* 36, +6.0dB */
};
#elif(ODM_IC_11AC_SERIES_SUPPORT)
u32 ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812] = {
0x3FE, /* 0, (6dB) */
0x3C4, /* 1, (5.5dB) */
0x38E, /* 2, (5dB) */
0x35C, /* 3, (4.5dB) */
0x32B, /* 4, (4dB) */
0x2FE, /* 5, (3.5dB) */
0x2D3, /* 6, (3dB) */
0x2AB, /* 7, (2.5dB) */
0x285, /* 8, (2dB) */
0x261, /* 9, (1.5dB */
0x23E, /* 10, (1dB) */
0x21E, /* 11, (0.5dB) */
0x200, /* 12, (0dB) 8814 int PA 2G default */
0x1E3, /* 13, (-0.5dB) */
0x1C8, /* 14, (-1dB) */
0x1AF, /* 15, (-1.5dB) */
0x197, /* 16, (-2dB) */
0x180, /* 17, (-2.5dB) */
0x16A, /* 18, (-3dB) 8812 / 8814 int PA 5G / 8814 ext PA 2G5G default */
0x156, /* 19, (-3.5dB) */
0x143, /* 20, (-4dB) 8812 HP default */
0x131, /* 21, (-4.5dB) */
0x120, /* 22, (-5dB) */
0x110, /* 23, (-5.5dB) */
0x101, /* 24, (-6dB) */
0x0F2, /* 25, (-6.5dB) */
0x0E5, /* 26, (-7dB) */
0x0D8, /* 27, (-7.5dB) */
0x0CC, /* 28, (-8dB) */
0x0C0, /* 29, (-8.5dB) */
0x0B6, /* 30, (-9dB) */
0x0AC, /* 31, (-9.5dB) */
0x0A2, /* 32, (-10dB) */
0x099, /* 33, (-10.5dB) */
0x090, /* 34, (-11dB) */
0x088, /* 35, (-11.5dB) */
0x081, /* 36, (-12dB) */
0x079, /* 37, (-12.5dB) */
0x072, /* 38, (-13dB) */
0x06c, /* 39, (-13.5dB) */
0x066, /* 40, (-14dB) */
0x060, /* 41, (-14.5dB) */
0x05B /* 42, (-15dB) */
};
#endif
u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
0x0CD,
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* JJ ADD 20161014 */
u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
0x0CD,
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* #endif */
/* 3============================================================
* 3 Tx Power Tracking
* 3============================================================ */
void
odm_txpowertracking_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_RTL8822B | ODM_IC_11N_SERIES)))
return;
#endif
odm_txpowertracking_thermal_meter_init(dm);
}
u8
get_swing_index(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 i = 0, bb_swing_mask = 0;
u32 bb_swing = 0;
u32 swing_table_size = 0;
u32 *swing_table = 0;
struct rtl8192cd_priv *priv = dm->priv;
#if (RTL8197F_SUPPORT == 1)
if (GET_CHIP_VER(priv) == VERSION_8197F) {
bb_swing = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
swing_table = ofdm_swing_table_new;
swing_table_size = OFDM_TABLE_SIZE_92D;
bb_swing_mask = 22;
}
#endif
#if (RTL8192F_SUPPORT == 1)
if (GET_CHIP_VER(priv) == VERSION_8192F) {
bb_swing = phy_query_bb_reg(priv, REG_OFDM_0_XA_TX_IQ_IMBALANCE, MASKOFDM_D);
swing_table = ofdm_swing_table_new;
swing_table_size = OFDM_TABLE_SIZE_92D;
bb_swing_mask = 22;
}
#endif
#if (RTL8822B_SUPPORT == 1)
if (GET_CHIP_VER(priv) == VERSION_8822B) {
bb_swing = phy_query_bb_reg(priv, REG_A_TX_SCALE_JAGUAR, 0xFFE00000);
swing_table = tx_scaling_table_jaguar;
swing_table_size = TXSCALE_TABLE_SIZE;
bb_swing_mask = 0;
}
#endif
for (i = 0; i < swing_table_size - 1; i++) {
u32 table_value = swing_table[i] >> bb_swing_mask;
if (bb_swing == table_value)
break;
}
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "bb_swing=0x%x bbswing_index=%d\n", bb_swing, i);
return i;
}
void
odm_txpowertracking_thermal_meter_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct rtl8192cd_priv *priv = dm->priv;
u8 p;
u8 default_swing_index;
#if (RTL8197F_SUPPORT == 1 || RTL8822B_SUPPORT == 1 || RTL8192F_SUPPORT == 1)
if ((GET_CHIP_VER(priv) == VERSION_8197F) || (GET_CHIP_VER(priv) == VERSION_8822B) ||(GET_CHIP_VER(priv) == VERSION_8192F))
default_swing_index = get_swing_index(dm);
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void *adapter = dm->adapter;
PMGNT_INFO mgnt_info = &adapter->MgntInfo;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
mgnt_info->is_txpowertracking = true;
hal_data->tx_powercount = 0;
hal_data->is_txpowertracking_init = false;
if (*(dm->mp_mode) == false)
hal_data->txpowertrack_control = true;
RF_DBG(dm, COMP_POWER_TRACKING, "mgnt_info->is_txpowertracking = %d\n", mgnt_info->is_txpowertracking);
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
#ifdef CONFIG_RTL8188E
{
dm->rf_calibrate_info.is_txpowertracking = true;
dm->rf_calibrate_info.tx_powercount = 0;
dm->rf_calibrate_info.is_txpowertracking_init = false;
if (*(dm->mp_mode) == false)
dm->rf_calibrate_info.txpowertrack_control = true;
MSG_8192C("dm txpowertrack_control = %d\n", dm->rf_calibrate_info.txpowertrack_control);
}
#else
{
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_priv *pdmpriv = &hal_data->dmpriv;
pdmpriv->is_txpowertracking = true;
pdmpriv->tx_powercount = 0;
pdmpriv->is_txpowertracking_init = false;
if (*(dm->mp_mode) == false) /* for mp driver, turn off txpwrtracking as default */
pdmpriv->txpowertrack_control = true;
MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
}
#endif/* endif (CONFIG_RTL8188E==1) */
#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#ifdef RTL8188E_SUPPORT
{
dm->rf_calibrate_info.is_txpowertracking = true;
dm->rf_calibrate_info.tx_powercount = 0;
dm->rf_calibrate_info.is_txpowertracking_init = false;
dm->rf_calibrate_info.txpowertrack_control = true;
dm->rf_calibrate_info.tm_trigger = 0;
}
#endif
#endif
dm->rf_calibrate_info.txpowertrack_control = true;
dm->rf_calibrate_info.delta_power_index = 0;
dm->rf_calibrate_info.delta_power_index_last = 0;
dm->rf_calibrate_info.power_index_offset = 0;
dm->rf_calibrate_info.thermal_value = 0;
cali_info->default_ofdm_index = 28;
#if (RTL8197F_SUPPORT == 1)
if (GET_CHIP_VER(priv) == VERSION_8197F) {
cali_info->default_ofdm_index = (default_swing_index >= (OFDM_TABLE_SIZE_92D - 1)) ? 30 : default_swing_index;
cali_info->default_cck_index = 28;
}
#endif
#if (RTL8192F_SUPPORT == 1)
if (GET_CHIP_VER(priv) == VERSION_8192F) {
cali_info->default_ofdm_index = 30;
cali_info->default_cck_index = 28;
}
#endif
#if (RTL8822B_SUPPORT == 1)
if (GET_CHIP_VER(priv) == VERSION_8822B) {
cali_info->default_ofdm_index = (default_swing_index >= (TXSCALE_TABLE_SIZE - 1)) ? 24 : default_swing_index;
cali_info->default_cck_index = 20;
}
#endif
#if RTL8188E_SUPPORT
cali_info->default_cck_index = 20; /* -6 dB */
#elif RTL8192E_SUPPORT
cali_info->default_cck_index = 8; /* -12 dB */
#endif
cali_info->bb_swing_idx_ofdm_base = cali_info->default_ofdm_index;
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
dm->rf_calibrate_info.CCK_index = cali_info->default_cck_index;
for (p = 0; p < MAX_RF_PATH; p++) {
dm->rf_calibrate_info.OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
cali_info->kfree_offset[p] = 0; /* for 8814 kfree*/
}
cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "cali_info->default_ofdm_index=%d cali_info->default_cck_index=%d\n", cali_info->default_ofdm_index, cali_info->default_cck_index);
cali_info->tm_trigger = 0;
}
void
odm_txpowertracking_check(
void *dm_void
)
{
/* */
/* For AP/ADSL use struct rtl8192cd_priv* */
/* For CE/NIC use struct void* */
/* */
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
/* */
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
/* */
switch (dm->support_platform) {
case ODM_WIN:
odm_txpowertracking_check_mp(dm);
break;
case ODM_CE:
odm_txpowertracking_check_ce(dm);
break;
case ODM_AP:
odm_txpowertracking_check_ap(dm);
break;
}
}
void
odm_txpowertracking_check_ce(
void *dm_void
)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
struct dm_struct *dm = (struct dm_struct *)dm_void;
void *adapter = dm->adapter;
struct _hal_rf_ *rf = &(dm->rf_table);
#if (RTL8188E_SUPPORT == 1)
/* if(!mgnt_info->is_txpowertracking || (!pdmpriv->txpowertrack_control && pdmpriv->is_ap_kdone)) */
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
if (!dm->rf_calibrate_info.tm_trigger) { /* at least delay 1 sec */
/* hal_data->TxPowerCheckCnt++; */ /* cosa add for debug */
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
/* DBG_8192C("Trigger 92C Thermal Meter!!\n"); */
dm->rf_calibrate_info.tm_trigger = 1;
return;
} else {
/* DBG_8192C("Schedule TxPowerTracking direct call!!\n"); */
odm_txpowertracking_callback_thermal_meter_8188e(adapter);
dm->rf_calibrate_info.tm_trigger = 0;
}
#endif
#endif
}
void
odm_txpowertracking_check_mp(
void *dm_void
)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
struct dm_struct *dm = (struct dm_struct *)dm_void;
void *adapter = dm->adapter;
if (odm_check_power_status(adapter) == false)
return;
if (!adapter->is_slave_of_dmsp || adapter->dual_mac_smart_concurrent == false)
odm_txpowertracking_thermal_meter_check(adapter);
#endif
}
void
odm_txpowertracking_check_ap(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if ((RTL8188E_SUPPORT == 1) || (RTL8192E_SUPPORT == 1) || (RTL8812A_SUPPORT == 1) || (RTL8881A_SUPPORT == 1) || (RTL8814A_SUPPORT == 1) || (RTL8197F_SUPPORT == 1) || (RTL8192F_SUPPORT == 1) || (RTL8198F_SUPPORT == 1) || (RTL8814B_SUPPORT == 1) || (RTL8812F_SUPPORT == 1))
if (!dm->rf_calibrate_info.tm_trigger) {
if (dm->support_ic_type & (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8812 | ODM_RTL8881A | ODM_RTL8814A | ODM_RTL8197F | ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8192F | ODM_RTL8198F)) {
odm_set_rf_reg(dm, RF_PATH_A, 0x42, (BIT(17) | BIT(16)), 0x3);
} else if (dm->support_ic_type & ODM_RTL8812F) {
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
} else if (dm->support_ic_type & ODM_RTL8814B) {
odm_set_rf_reg(dm, RF_PATH_A, 0x42, BIT(17), 0x1);
odm_set_rf_reg(dm, RF_PATH_B, 0x42, BIT(17), 0x1);
odm_set_rf_reg(dm, RF_PATH_C, 0x42, BIT(17), 0x1);
odm_set_rf_reg(dm, RF_PATH_D, 0x42, BIT(17), 0x1);
}
dm->rf_calibrate_info.tm_trigger = 1;
} else {
odm_txpowertracking_callback_thermal_meter(dm);
dm->rf_calibrate_info.tm_trigger = 0;
}
#endif
}
================================================
FILE: hal/phydm/halrf/halrf_powertracking_ap.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HALRF_POWERTRACKING_H__
#define __HALRF_POWERTRACKING_H__
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
#ifdef RTK_AC_SUPPORT
#define ODM_IC_11AC_SERIES_SUPPORT 1
#else
#define ODM_IC_11AC_SERIES_SUPPORT 0
#endif
#else
#define ODM_IC_11AC_SERIES_SUPPORT 1
#endif
#define DPK_DELTA_MAPPING_NUM 13
#define index_mapping_HP_NUM 15
#define DELTA_SWINGIDX_SIZE 30
#define DELTA_SWINTSSI_SIZE 61
#define BAND_NUM 3
#define MAX_RF_PATH 4
#define TXSCALE_TABLE_SIZE 37
#define CCK_TABLE_SIZE_8723D 41
/* JJ ADD 20161014 */
#define CCK_TABLE_SIZE_8710B 41
#define IQK_MAC_REG_NUM 4
#define IQK_ADDA_REG_NUM 16
#define IQK_BB_REG_NUM_MAX 10
#define IQK_BB_REG_NUM 9
#define AVG_THERMAL_NUM 8
#define AVG_THERMAL_NUM_DPK 8
#define THERMAL_DPK_AVG_NUM 4
#define iqk_matrix_reg_num 8
/* #define IQK_MATRIX_SETTINGS_NUM 1+24+21 */
#define IQK_MATRIX_SETTINGS_NUM (14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
#if !defined(_OUTSRC_COEXIST)
#define OFDM_TABLE_SIZE_92D 43
#define OFDM_TABLE_SIZE 37
#define CCK_TABLE_SIZE 33
#define CCK_TABLE_SIZE_88F 21
#define CCK_TABLE_SIZE_8192F 41
/* #define OFDM_TABLE_SIZE_92E 54 */
/* #define CCK_TABLE_SIZE_92E 54 */
extern u32 ofdm_swing_table[OFDM_TABLE_SIZE_92D];
extern u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
extern u32 ofdm_swing_table_new[OFDM_TABLE_SIZE_92D];
extern u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
#endif
#define ODM_OFDM_TABLE_SIZE 37
#define ODM_CCK_TABLE_SIZE 33
#define TXPWR_TRACK_TABLE_SIZE 30
/* <20140613, YuChen> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
extern u8 delta_swing_table_idx_2ga_p_default[DELTA_SWINGIDX_SIZE];
extern u8 delta_swing_table_idx_2ga_n_default[DELTA_SWINGIDX_SIZE];
static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 5, 5, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9};
static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 7, 7, 7, 7, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11};
/* extern u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E];
* extern u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8];
* extern u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8]; */
#ifdef CONFIG_WLAN_HAL_8192EE
#define OFDM_TABLE_SIZE_92E 54
#define CCK_TABLE_SIZE_92E 54
extern u32 ofdm_swing_table_92e[OFDM_TABLE_SIZE_92E];
extern u8 cck_swing_table_ch1_ch13_92e[CCK_TABLE_SIZE_92E][8];
extern u8 cck_swing_table_ch14_92e[CCK_TABLE_SIZE_92E][8];
#endif
#define OFDM_TABLE_SIZE_8812 43
#define AVG_THERMAL_NUM_8812 4
#if (RTL8814A_SUPPORT == 1 || RTL8822B_SUPPORT == 1 ||\
RTL8821C_SUPPORT == 1 || RTL8198F_SUPPORT == 1 ||\
RTL8814B_SUPPORT == 1)
extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
#elif(ODM_IC_11AC_SERIES_SUPPORT)
extern unsigned int ofdm_swing_table_8812[OFDM_TABLE_SIZE_8812];
#endif
extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
/* JJ ADD 20161014 */
extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
#define dm_check_txpowertracking odm_txpowertracking_check
struct iqk_matrix_regs_setting {
boolean is_iqk_done;
s32 value[1][iqk_matrix_reg_num];
};
struct dm_rf_calibration_struct {
/* for tx power tracking */
u32 rega24; /* for TempCCK */
s32 rege94;
s32 rege9c;
s32 regeb4;
s32 regebc;
/* u8 is_txpowertracking; */
u8 tx_powercount;
boolean is_txpowertracking_init;
boolean is_txpowertracking;
u8 txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
u8 tm_trigger;
u8 internal_pa_5g[2]; /* pathA / pathB */
u8 thermal_meter[2]; /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
u8 thermal_value;
u8 thermal_value_path[MAX_RF_PATH];
u8 thermal_value_lck;
u8 thermal_value_iqk;
s8 thermal_value_delta; /* delta of thermal_value and efuse thermal */
u8 thermal_value_avg[AVG_THERMAL_NUM];
u8 thermal_value_avg_path[MAX_RF_PATH][AVG_THERMAL_NUM];
u8 thermal_value_avg_index;
u8 thermal_value_avg_index_path[MAX_RF_PATH];
s8 power_index_offset_path[MAX_RF_PATH];
u8 thermal_value_rx_gain;
u8 thermal_value_crystal;
u8 thermal_value_dpk_store;
u8 thermal_value_dpk_track;
boolean txpowertracking_in_progress;
boolean is_reloadtxpowerindex;
u8 is_rf_pi_enable;
u32 txpowertracking_callback_cnt; /* cosa add for debug */
u8 is_cck_in_ch14;
u8 CCK_index;
u8 OFDM_index[MAX_RF_PATH];
s8 power_index_offset;
s8 delta_power_index;
s8 delta_power_index_path[MAX_RF_PATH];
s8 delta_power_index_last;
s8 delta_power_index_last_path[MAX_RF_PATH];
boolean is_tx_power_changed;
struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
u8 delta_lck;
u8 delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
s8 delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
s8 delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
u8 bb_swing_idx_ofdm[MAX_RF_PATH];
u8 bb_swing_idx_ofdm_current;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
u8 bb_swing_idx_ofdm_base[MAX_RF_PATH];
#else
u8 bb_swing_idx_ofdm_base;
u8 bb_swing_idx_ofdm_base_path[MAX_RF_PATH];
#endif
boolean bb_swing_flag_ofdm;
u8 bb_swing_idx_cck;
u8 bb_swing_idx_cck_current;
u8 bb_swing_idx_cck_base;
u8 default_ofdm_index;
u8 default_cck_index;
boolean bb_swing_flag_cck;
s8 absolute_ofdm_swing_idx[MAX_RF_PATH];
s8 remnant_ofdm_swing_idx[MAX_RF_PATH];
s8 absolute_cck_swing_idx[MAX_RF_PATH];
s8 remnant_cck_swing_idx;
s8 modify_tx_agc_value; /*Remnat compensate value at tx_agc */
boolean modify_tx_agc_flag_path_a;
boolean modify_tx_agc_flag_path_b;
boolean modify_tx_agc_flag_path_c;
boolean modify_tx_agc_flag_path_d;
boolean modify_tx_agc_flag_path_a_cck;
boolean modify_tx_agc_flag_path_b_cck;
s8 kfree_offset[MAX_RF_PATH];
/* -------------------------------------------------------------------- */
/* for IQK */
u32 regc04;
u32 reg874;
u32 regc08;
u32 regb68;
u32 regb6c;
u32 reg870;
u32 reg860;
u32 reg864;
boolean is_iqk_initialized;
boolean is_lck_in_progress;
boolean is_antenna_detected;
boolean is_need_iqk;
boolean is_iqk_in_progress;
boolean is_iqk_pa_off;
u8 delta_iqk;
u32 ADDA_backup[IQK_ADDA_REG_NUM];
u32 IQK_MAC_backup[IQK_MAC_REG_NUM];
u32 IQK_BB_backup_recover[9];
u32 IQK_BB_backup[IQK_BB_REG_NUM];
u32 tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 tx_iqc_8703b[3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8703b[2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
u64 iqk_start_time;
u64 iqk_total_progressing_time;
u64 iqk_progressing_time;
u64 lck_progressing_time;
u32 lok_result;
u8 iqk_step;
u8 kcount;
u8 retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
boolean is_mp_mode;
/* for APK */
u32 ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
u8 is_ap_kdone;
u8 is_apk_thermal_meter_ignore;
u8 is_dp_done;
#if 0 /*move below members to halrf_dpk.h*/
u8 is_dp_path_aok;
u8 is_dp_path_bok;
u8 is_dp_path_cok;
u8 is_dp_path_dok;
u8 dp_path_a_result[3];
u8 dp_path_b_result[3];
u8 dp_path_c_result[3];
u8 dp_path_d_result[3];
boolean is_dpk_enable;
u32 txrate[11];
u8 pwsf_2g_a[3];
u8 pwsf_2g_b[3];
u8 pwsf_2g_c[3];
u8 pwsf_2g_d[3];
u32 lut_2g_even_a[3][64];
u32 lut_2g_odd_a[3][64];
u32 lut_2g_even_b[3][64];
u32 lut_2g_odd_b[3][64];
u32 lut_2g_even_c[3][64];
u32 lut_2g_odd_c[3][64];
u32 lut_2g_even_d[3][64];
u32 lut_2g_odd_d[3][64];
u1Byte is_5g_pdk_a_ok;
u1Byte is_5g_pdk_b_ok;
u1Byte is_5g_pdk_c_ok;
u1Byte is_5g_pdk_d_ok;
u1Byte pwsf_5g_a[9];
u1Byte pwsf_5g_b[9];
u1Byte pwsf_5g_c[9];
u1Byte pwsf_5g_d[9];
u4Byte lut_5g_even_a[9][16];
u4Byte lut_5g_odd_a[9][16];
u4Byte lut_5g_even_b[9][16];
u4Byte lut_5g_odd_b[9][16];
u4Byte lut_5g_even_c[9][16];
u4Byte lut_5g_odd_c[9][16];
u4Byte lut_5g_even_d[9][16];
u4Byte lut_5g_odd_d[9][16];
u8 thermal_value_dpk;
u8 thermal_value_dpk_avg[AVG_THERMAL_NUM_DPK];
u8 thermal_value_dpk_avg_index;
#endif
s8 modify_tx_agc_value_ofdm;
s8 modify_tx_agc_value_cck;
/*Add by Yuchen for Kfree Phydm*/
u8 reg_rf_kfree_enable; /*for registry*/
u8 rf_kfree_enable; /*for efuse enable check*/
u32 tx_lok[2];
};
void
odm_txpowertracking_check_ap(
void *dm_void
);
void
odm_txpowertracking_check(
void *dm_void
);
void
odm_txpowertracking_thermal_meter_init(
void *dm_void
);
void
odm_txpowertracking_init(
void *dm_void
);
void
odm_txpowertracking_check_mp(
void *dm_void
);
void
odm_txpowertracking_check_ce(
void *dm_void
);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
void
odm_txpowertracking_callback_thermal_meter92c(
void *adapter
);
void
odm_txpowertracking_callback_rx_gain_thermal_meter92d(
void *adapter
);
void
odm_txpowertracking_callback_thermal_meter92d(
void *adapter
);
void
odm_txpowertracking_direct_call92c(
void *adapter
);
void
odm_txpowertracking_thermal_meter_check(
void *adapter
);
#endif
#endif /*#ifndef __HALRF_POWER_TRACKING_H__*/
================================================
FILE: hal/phydm/halrf/halrf_powertracking_ce.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*@===========================================================
* include files
*============================================================
*/
#include "mp_precomp.h"
#include "phydm_precomp.h"
/*@************************************************************
* Global var
* ************************************************************
*/
u32 ofdm_swing_table[OFDM_TABLE_SIZE] = {
0x7f8001fe, /* 0, +6.0dB */
0x788001e2, /* 1, +5.5dB */
0x71c001c7, /* 2, +5.0dB*/
0x6b8001ae, /* 3, +4.5dB*/
0x65400195, /* 4, +4.0dB*/
0x5fc0017f, /* 5, +3.5dB*/
0x5a400169, /* 6, +3.0dB*/
0x55400155, /* 7, +2.5dB*/
0x50800142, /* 8, +2.0dB*/
0x4c000130, /* 9, +1.5dB*/
0x47c0011f, /* 10, +1.0dB*/
0x43c0010f, /* 11, +0.5dB*/
0x40000100, /* 12, +0dB*/
0x3c8000f2, /* 13, -0.5dB*/
0x390000e4, /* 14, -1.0dB*/
0x35c000d7, /* 15, -1.5dB*/
0x32c000cb, /* 16, -2.0dB*/
0x300000c0, /* 17, -2.5dB*/
0x2d4000b5, /* 18, -3.0dB*/
0x2ac000ab, /* 19, -3.5dB*/
0x288000a2, /* 20, -4.0dB*/
0x26000098, /* 21, -4.5dB*/
0x24000090, /* 22, -5.0dB*/
0x22000088, /* 23, -5.5dB*/
0x20000080, /* 24, -6.0dB*/
0x1e400079, /* 25, -6.5dB*/
0x1c800072, /* 26, -7.0dB*/
0x1b00006c, /* 27. -7.5dB*/
0x19800066, /* 28, -8.0dB*/
0x18000060, /* 29, -8.5dB*/
0x16c0005b, /* 30, -9.0dB*/
0x15800056, /* 31, -9.5dB*/
0x14400051, /* 32, -10.0dB*/
0x1300004c, /* 33, -10.5dB*/
0x12000048, /* 34, -11.0dB*/
0x11000044, /* 35, -11.5dB*/
0x10000040, /* 36, -12.0dB*/
};
u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8] = {
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}, /* 0, +0dB */
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 1, -0.5dB */
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 2, -1.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 3, -1.5dB */
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 4, -2.0dB */
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 5, -2.5dB */
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 6, -3.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 7, -3.5dB */
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 8, -4.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 9, -4.5dB */
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 10, -5.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 11, -5.5dB */
{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /* 12, -6.0 default*/
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 13, -6.5dB */
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 14, -7.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 15, -7.5dB */
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 17, -8.5dB */
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 18, -9.0dB */
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 19, -9.5dB */
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 20, -10.0dB */
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 21, -10.5dB */
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 22, -11.0dB */
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 23, -11.5dB */
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 24, -12.0dB */
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 25, -12.5dB */
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 26, -13.0dB */
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 27, -13.5dB */
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 28, -14.0dB */
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 29, -14.5dB */
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 30, -15.0dB */
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 31, -15.5dB */
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01} /* 32, -16.0dB */
};
u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8] = {
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}, /* 0, +0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 1, -0.5dB */
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 2, -1.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /* 3, -1.5dB */
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 4, -2.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /* 5, -2.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 6, -3.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 7, -3.5dB */
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 8, -4.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /* 9, -4.5dB */
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 10, -5.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 11, -5.5dB */
{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 12, -6.0 default*/
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 13, -6.5dB */
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 14, -7.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 15, -7.5dB */
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 17, -8.5dB */
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 18, -9.0dB */
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 19, -9.5dB */
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 20, -10.0dB */
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 21, -10.5dB */
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 22, -11.0dB */
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 23, -11.5dB */
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 24, -12.0dB */
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 25, -12.5dB */
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 26, -13.0dB */
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 27, -13.5dB */
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 28, -14.0dB */
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 29, -14.5dB */
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 30, -15.0dB */
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 31, -15.5dB */
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00} /* 32, -16.0dB */
};
u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
0x0b40002d, /* 0, -15.0dB */
0x0c000030, /* 1, -14.5dB */
0x0cc00033, /* 2, -14.0dB */
0x0d800036, /* 3, -13.5dB */
0x0e400039, /* 4, -13.0dB */
0x0f00003c, /* 5, -12.5dB */
0x10000040, /* 6, -12.0dB */
0x11000044, /* 7, -11.5dB */
0x12000048, /* 8, -11.0dB */
0x1300004c, /* 9, -10.5dB */
0x14400051, /* 10, -10.0dB */
0x15800056, /* 11, -9.5dB */
0x16c0005b, /* 12, -9.0dB */
0x18000060, /* 13, -8.5dB */
0x19800066, /* 14, -8.0dB */
0x1b00006c, /* 15, -7.5dB */
0x1c800072, /* 16, -7.0dB */
0x1e400079, /* 17, -6.5dB */
0x20000080, /* 18, -6.0dB */
0x22000088, /* 19, -5.5dB */
0x24000090, /* 20, -5.0dB */
0x26000098, /* 21, -4.5dB */
0x288000a2, /* 22, -4.0dB */
0x2ac000ab, /* 23, -3.5dB */
0x2d4000b5, /* 24, -3.0dB */
0x300000c0, /* 25, -2.5dB */
0x32c000cb, /* 26, -2.0dB */
0x35c000d7, /* 27, -1.5dB */
0x390000e4, /* 28, -1.0dB */
0x3c8000f2, /* 29, -0.5dB */
0x40000100, /* 30, +0dB */
0x43c0010f, /* 31, +0.5dB */
0x47c0011f, /* 32, +1.0dB */
0x4c000130, /* 33, +1.5dB */
0x50800142, /* 34, +2.0dB */
0x55400155, /* 35, +2.5dB */
0x5a400169, /* 36, +3.0dB */
0x5fc0017f, /* 37, +3.5dB */
0x65400195, /* 38, +4.0dB */
0x6b8001ae, /* 39, +4.5dB */
0x71c001c7, /* 40, +5.0dB */
0x788001e2, /* 41, +5.5dB */
0x7f8001fe /* 42, +6.0dB */
};
u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}, /* 0, -16.0dB*/
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 1, -15.5dB*/
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 2, -15.0dB*/
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 3, -14.5dB*/
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 4, -14.0dB*/
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 5, -13.5dB*/
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 6, -13.0dB*/
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 7, -12.5dB*/
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 8, -12.0dB*/
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 9, -11.5dB*/
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 10, -11.0dB*/
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 11, -10.5dB*/
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 12, -10.0dB*/
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 13, -9.5dB*/
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 15, -8.5dB*/
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 17, -7.5dB*/
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 19, -6.5dB*/
{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 21, -5.5dB*/
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 23, -4.5dB*/
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 25, -3.5dB*/
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 26, -3.0dB*/
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 27, -2.5dB*/
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 29, -1.5dB*/
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 30, -1.0dB*/
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 31, -0.5dB*/
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} /* 32, +0dB*/
};
u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}, /* 0, -16.0dB*/
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 1, -15.5dB*/
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 2, -15.0dB*/
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 3, -14.5dB*/
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 4, -14.0dB*/
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /*5, -13.5dB*/
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 6, -13.0dB*/
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 7, -12.5dB*/
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 8, -12.0dB*/
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 9, -11.5dB*/
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 10, -11.0dB*/
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /*11, -10.5dB*/
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 12, -10.0dB*/
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 13, -9.5dB*/
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /*14, -9.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 15, -8.5dB*/
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 17, -7.5dB*/
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 19, -6.5dB */
{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 21, -5.5dB*/
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /*23, -4.5dB*/
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 26, -3.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /*27, -2.5dB*/
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /*29, -1.5dB*/
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} /* 32, +0dB */
};
u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/*@JJ ADD 20161014 */
u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/*@Winnita ADD 20171116 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263, /*19*/
0x287, /*20*/
0x2AE, /*21*/
0x2D6, /*22*/
0x301, /*23*/
0x32F, /*24*/
0x35F, /*25*/
0x392, /*26*/
0x3C9, /*27*/
0x402, /*28*/
0x43F, /*29*/
0x47F, /*30*/
0x4C3, /*31*/
0x50C, /*32*/
0x558, /*33*/
0x5A9, /*34*/
0x5FF, /*35*/
0x65A, /*36*/
0x6BA,
0x720,
0x78C,
0x7FF,
};
u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
0x081, /* 0, -12.0dB*/
0x088, /* 1, -11.5dB*/
0x090, /* 2, -11.0dB*/
0x099, /* 3, -10.5dB*/
0x0A2, /* 4, -10.0dB*/
0x0AC, /* 5, -9.5dB*/
0x0B6, /* 6, -9.0dB*/
0x0C0, /*7, -8.5dB*/
0x0CC, /* 8, -8.0dB*/
0x0D8, /* 9, -7.5dB*/
0x0E5, /* 10, -7.0dB*/
0x0F2, /* 11, -6.5dB*/
0x101, /* 12, -6.0dB*/
0x110, /* 13, -5.5dB*/
0x120, /* 14, -5.0dB*/
0x131, /* 15, -4.5dB*/
0x143, /* 16, -4.0dB*/
0x156, /* 17, -3.5dB*/
0x16A, /* 18, -3.0dB*/
0x180, /* 19, -2.5dB*/
0x197, /* 20, -2.0dB*/
0x1AF, /* 21, -1.5dB*/
0x1C8, /* 22, -1.0dB*/
0x1E3, /* 23, -0.5dB*/
0x200, /* 24, +0 dB*/
0x21E, /* 25, +0.5dB*/
0x23E, /* 26, +1.0dB*/
0x261, /* 27, +1.5dB*/
0x285, /* 28, +2.0dB*/
0x2AB, /* 29, +2.5dB*/
0x2D3, /*30, +3.0dB*/
0x2FE, /* 31, +3.5dB*/
0x32B, /* 32, +4.0dB*/
0x35C, /* 33, +4.5dB*/
0x38E, /* 34, +5.0dB*/
0x3C4, /* 35, +5.5dB*/
0x3FE /* 36, +6.0dB */
};
#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
#else
u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3,
4, 4, 4, 4, 4, 4, 4, 4, 5, 5,
7, 7, 8, 8, 8, 9, 9, 9, 9, 9};
u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4,
4, 5, 5, 6, 6, 7, 7, 7, 7, 8,
8, 9, 9, 10, 10, 10, 11, 11, 11, 11};
#endif
void odm_txpowertracking_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_thermal_meter_init(dm);
}
u8 get_swing_index(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if ((RTL8812A_SUPPORT == 1) || (RTL8821A_SUPPORT == 1))
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(adapter);
#endif
u8 i = 0;
u32 bb_swing, table_value;
if (dm->support_ic_type &
(ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E |
ODM_RTL8188F | ODM_RTL8703B | ODM_RTL8723D |
ODM_RTL8710B | ODM_RTL8821)) {
#if (RTL8821A_SUPPORT == 1)
bb_swing =
phy_get_tx_bb_swing_8812a(adapter,
hal_data->current_band_type,
RF_PATH_A);
#else
bb_swing = odm_get_bb_reg(dm, R_0xc80, 0xFFC00000);
#endif
for (i = 0; i < OFDM_TABLE_SIZE; i++) {
table_value = ofdm_swing_table_new[i];
if (table_value >= 0x100000)
table_value >>= 22;
if (bb_swing == table_value)
break;
}
} else {
#if (RTL8812A_SUPPORT == 1)
bb_swing =
phy_get_tx_bb_swing_8812a(adapter,
hal_data->current_band_type,
RF_PATH_A);
#else
bb_swing = odm_get_bb_reg(dm, R_0xc1c, 0xFFE00000);
#endif
for (i = 0; i < TXSCALE_TABLE_SIZE; i++) {
table_value = tx_scaling_table_jaguar[i];
if (bb_swing == table_value)
break;
}
}
return i;
}
u8 get_cck_swing_index(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 i = 0;
u32 bb_cck_swing;
if (dm->support_ic_type &
(ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E)) {
bb_cck_swing = odm_read_1byte(dm, 0xa22);
for (i = 0; i < CCK_TABLE_SIZE; i++) {
if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
break;
}
} else if (dm->support_ic_type & ODM_RTL8703B) {
bb_cck_swing = odm_read_1byte(dm, 0xa22);
for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
break;
}
}
return i;
}
void odm_txpowertracking_thermal_meter_init(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
struct _hal_rf_ *rf = &dm->rf_table;
#if (RTL8822C_SUPPORT == 1)
struct _halrf_tssi_data *tssi = &rf->halrf_tssi_data;
#endif
u8 swing_idx = get_swing_index(dm);
u8 cckswing_idx = get_cck_swing_index(dm);
u8 p = 0;
cali_info->is_txpowertracking = true;
cali_info->tx_powercount = 0;
cali_info->is_txpowertracking_init = false;
if (!(*dm->mp_mode))
cali_info->txpowertrack_control = true;
else
cali_info->txpowertrack_control = false;
if (!(*dm->mp_mode))
cali_info->txpowertrack_control = true;
RF_DBG(dm, DBG_RF_IQK, "dm txpowertrack_control = %d\n",
cali_info->txpowertrack_control);
#if 0
/* dm->rf_calibrate_info.txpowertrack_control = true; */
#endif
cali_info->thermal_value = rf->eeprom_thermal;
cali_info->thermal_value_iqk = rf->eeprom_thermal;
cali_info->thermal_value_lck = rf->eeprom_thermal;
#if (RTL8822C_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8822C) {
cali_info->thermal_value_path[RF_PATH_A] = tssi->thermal[RF_PATH_A];
cali_info->thermal_value_path[RF_PATH_B] = tssi->thermal[RF_PATH_B];
cali_info->thermal_value_iqk = tssi->thermal[RF_PATH_A];
cali_info->thermal_value_lck = tssi->thermal[RF_PATH_A];
}
#endif
if (!cali_info->default_bb_swing_index_flag) {
if (dm->support_ic_type &
(ODM_RTL8188E | ODM_RTL8723B | ODM_RTL8192E |
ODM_RTL8703B | ODM_RTL8821)) {
if (swing_idx >= OFDM_TABLE_SIZE)
cali_info->default_ofdm_index = 30;
else
cali_info->default_ofdm_index = swing_idx;
if (cckswing_idx >= CCK_TABLE_SIZE)
cali_info->default_cck_index = 20;
else
cali_info->default_cck_index = cckswing_idx;
/*@add by Mingzhi.Guo 2015-03-23*/
} else if (dm->support_ic_type == ODM_RTL8188F) {
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 20; /*CCK:-6dB*/
/*@add by zhaohe 2015-10-27*/
} else if (dm->support_ic_type == ODM_RTL8723D) {
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
/*@JJ ADD 20161014 */
} else if (dm->support_ic_type == ODM_RTL8710B) {
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
} else if (dm->support_ic_type == ODM_RTL8192F) {
cali_info->default_ofdm_index = 30;/*OFDM: 0dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
} else {
if (swing_idx >= TXSCALE_TABLE_SIZE)
cali_info->default_ofdm_index = 24;
else
cali_info->default_ofdm_index = swing_idx;
cali_info->default_cck_index = 24;
}
cali_info->default_bb_swing_index_flag = true;
}
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
cali_info->CCK_index = cali_info->default_cck_index;
for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
cali_info->bb_swing_idx_ofdm_base[p] =
cali_info->default_ofdm_index;
cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->delta_power_index[p] = 0;
cali_info->delta_power_index_last[p] = 0;
cali_info->power_index_offset[p] = 0;
}
cali_info->modify_tx_agc_value_ofdm = 0;
cali_info->modify_tx_agc_value_cck = 0;
cali_info->tm_trigger = 0;
}
void odm_txpowertracking_check(void *dm_void)
{
/*@2011/09/29 MH In HW integration first stage
* we provide 4 different handle to operate at the same time.
* In the stage2/3, we need to prive universal interface and merge all
* HW dynamic mechanism.
*/
struct dm_struct *dm = (struct dm_struct *)dm_void;
switch (dm->support_platform) {
case ODM_WIN:
odm_txpowertracking_check_mp(dm);
break;
case ODM_CE:
odm_txpowertracking_check_ce(dm);
break;
case ODM_AP:
odm_txpowertracking_check_ap(dm);
break;
default:
break;
}
}
void odm_txpowertracking_check_ce(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
#if (RTL8822C_SUPPORT == 1)
struct _halrf_tssi_data *tssi = &rf->halrf_tssi_data;
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
if (dm->support_ic_type & ODM_RTL8814B)
return;
if ((rf->power_track_type & 0xf0) >> 4 != 0) {
if (dm->support_ic_type & ODM_RTL8822C) {
/*halrf_tssi_cck(dm);*/
/*halrf_thermal_cck(dm);*/
return;
}
}
if (!dm->rf_calibrate_info.tm_trigger) {
if (dm->support_ic_type &
(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8192E |
ODM_RTL8723B | ODM_RTL8812 | ODM_RTL8821 |
ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8723D |
ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8710B |
ODM_RTL8192F))
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW,
(BIT(17) | BIT(16)), 0x03);
else if (dm->support_ic_type & ODM_RTL8822C) {
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
} else
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_OLD,
RFREGOFFSETMASK, 0x60);
dm->rf_calibrate_info.tm_trigger = 1;
return;
}
if (dm->support_ic_type & ODM_RTL8822C) {
#if (RTL8822C_SUPPORT == 1)
odm_txpowertracking_new_callback_thermal_meter(dm);
#endif
} else
odm_txpowertracking_callback_thermal_meter(dm);
dm->rf_calibrate_info.tm_trigger = 0;
#endif
}
void
odm_txpowertracking_direct_ce(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
if (dm->support_ic_type & ODM_RTL8814B)
return;
if (dm->support_ic_type & ODM_RTL8822C) {
/*halrf_tssi_cck(dm);*/
/*halrf_thermal_cck(dm);*/
return;
}
if (dm->support_ic_type &
(ODM_RTL8188E | ODM_RTL8188F | ODM_RTL8192E |
ODM_RTL8723B | ODM_RTL8812 | ODM_RTL8821 |
ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8723D |
ODM_RTL8822B | ODM_RTL8821C | ODM_RTL8710B |
ODM_RTL8192F))
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
else if (dm->support_ic_type & ODM_RTL8822C) {
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
} else
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_OLD, RFREGOFFSETMASK, 0x60);
odm_txpowertracking_callback_thermal_meter(dm);
#endif
}
void odm_txpowertracking_check_mp(void *dm_void)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
struct dm_struct *dm = (struct dm_struct *)dm_void;
void *adapter = dm->adapter;
if (odm_check_power_status(adapter) == false) {
RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
("check_pow_status, return false\n"));
return;
}
odm_txpowertracking_thermal_meter_check(adapter);
#endif
}
void odm_txpowertracking_check_ap(void *dm_void)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct rtl8192cd_priv *priv = dm->priv;
return;
#endif
}
================================================
FILE: hal/phydm/halrf/halrf_powertracking_ce.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_POWERTRACKING_H__
#define __HALRF_POWERTRACKING_H__
#define DPK_DELTA_MAPPING_NUM 13
#define index_mapping_HP_NUM 15
#define OFDM_TABLE_SIZE 43
#define CCK_TABLE_SIZE 33
#define CCK_TABLE_SIZE_88F 21
#define TXSCALE_TABLE_SIZE 37
#define CCK_TABLE_SIZE_8723D 41
/*@JJ ADD 20161014 */
#define CCK_TABLE_SIZE_8710B 41
#define CCK_TABLE_SIZE_8192F 41
#define TXPWR_TRACK_TABLE_SIZE 30
#define DELTA_SWINGIDX_SIZE 30
#define DELTA_SWINTSSI_SIZE 61
#define BAND_NUM 4
#define AVG_THERMAL_NUM 8
#define IQK_MAC_REG_NUM 4
#define IQK_ADDA_REG_NUM 16
#define IQK_BB_REG_NUM_MAX 10
#define IQK_BB_REG_NUM 9
#define iqk_matrix_reg_num 8
#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
#else
/* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
#define IQK_MATRIX_SETTINGS_NUM (14 + 24 + 21)
#endif
extern u32 ofdm_swing_table[OFDM_TABLE_SIZE];
extern u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
extern u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
extern u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
/*@JJ ADD 20161014 */
extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
extern u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
/*@<20121018, Kordan> In case fail to read TxPowerTrack.txt */
/* we use the table of 88E as the default table. */
#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
#else
extern u8 delta_swing_table_idx_2ga_p_8188e[];
extern u8 delta_swing_table_idx_2ga_n_8188e[];
#endif
#define dm_check_txpowertracking odm_txpowertracking_check
struct iqk_matrix_regs_setting {
boolean is_iqk_done;
s32 value[3][iqk_matrix_reg_num];
boolean is_bw_iqk_result_saved[3];
};
struct dm_rf_calibration_struct {
/* for tx power tracking */
u32 rega24; /* for TempCCK */
s32 rege94;
s32 rege9c;
s32 regeb4;
s32 regebc;
u8 tx_powercount;
boolean is_txpowertracking_init;
boolean is_txpowertracking;
/* for mp mode, turn off txpwrtracking as default */
u8 txpowertrack_control;
u8 tm_trigger;
u8 internal_pa_5g[2]; /* pathA / pathB */
/* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
u8 thermal_meter[2];
u8 thermal_value;
u8 thermal_value_path[MAX_RF_PATH];
u8 thermal_value_lck;
u8 thermal_value_iqk;
s8 thermal_value_delta; /* delta of thermal_value and efuse thermal */
u8 thermal_value_dpk;
u8 thermal_value_avg[AVG_THERMAL_NUM];
u8 thermal_value_avg_path[MAX_RF_PATH][AVG_THERMAL_NUM];
u8 thermal_value_avg_index;
u8 thermal_value_avg_index_path[MAX_RF_PATH];
u8 thermal_value_rx_gain;
u8 thermal_value_crystal;
u8 thermal_value_dpk_store;
u8 thermal_value_dpk_track;
boolean txpowertracking_in_progress;
boolean is_reloadtxpowerindex;
u8 is_rf_pi_enable;
u32 txpowertracking_callback_cnt; /* cosa add for debug */
/*@---------------------- Tx power Tracking ---------------------- */
u8 is_cck_in_ch14;
u8 CCK_index;
u8 OFDM_index[MAX_RF_PATH];
s8 power_index_offset[MAX_RF_PATH];
s8 delta_power_index[MAX_RF_PATH];
s8 delta_power_index_last[MAX_RF_PATH];
boolean is_tx_power_changed;
s8 xtal_offset;
s8 xtal_offset_last;
u8 xtal_offset_eanble;
struct iqk_matrix_regs_setting
iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
u8 delta_lck;
s8 bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
u8 delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
s8 delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
s8 delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
u8 bb_swing_idx_ofdm[MAX_RF_PATH];
u8 bb_swing_idx_ofdm_current;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
u8 bb_swing_idx_ofdm_base[MAX_RF_PATH];
#else
u8 bb_swing_idx_ofdm_base;
#endif
boolean default_bb_swing_index_flag;
boolean bb_swing_flag_ofdm;
u8 bb_swing_idx_cck;
u8 bb_swing_idx_cck_current;
u8 bb_swing_idx_cck_base;
u8 default_ofdm_index;
u8 default_cck_index;
boolean bb_swing_flag_cck;
s8 absolute_ofdm_swing_idx[MAX_RF_PATH];
s8 remnant_ofdm_swing_idx[MAX_RF_PATH];
s8 absolute_cck_swing_idx[MAX_RF_PATH];
s8 remnant_cck_swing_idx;
s8 modify_tx_agc_value; /*Remnat compensate value at tx_agc */
boolean modify_tx_agc_flag_path_a;
boolean modify_tx_agc_flag_path_b;
boolean modify_tx_agc_flag_path_c;
boolean modify_tx_agc_flag_path_d;
boolean modify_tx_agc_flag_path_a_cck;
boolean modify_tx_agc_flag_path_b_cck;
s8 kfree_offset[MAX_RF_PATH];
/*@----------------------------------------------------------------- */
/* for IQK */
u32 regc04;
u32 reg874;
u32 regc08;
u32 regb68;
u32 regb6c;
u32 reg870;
u32 reg860;
u32 reg864;
boolean is_iqk_initialized;
boolean is_lck_in_progress;
boolean is_antenna_detected;
boolean is_need_iqk;
boolean is_iqk_in_progress;
boolean is_iqk_pa_off;
u8 delta_iqk;
u32 ADDA_backup[IQK_ADDA_REG_NUM];
u32 IQK_MAC_backup[IQK_MAC_REG_NUM];
u32 IQK_BB_backup_recover[9];
u32 IQK_BB_backup[IQK_BB_REG_NUM];
/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 tx_iqc_8723b[2][3][2];
/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 rx_iqc_8723b[2][2][2];
/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 tx_iqc_8703b[3][2];
/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 rx_iqc_8703b[2][2];
/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 tx_iqc_8723d[2][3][2];
/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 rx_iqc_8723d[2][2][2];
/* JJ ADD 20161014 */
/* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 tx_iqc_8710b[2][3][2];
/* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 rx_iqc_8710b[2][2][2];
u8 iqk_step;
u8 kcount;
u8 retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
boolean is_mp_mode;
/*@ IQK time measurement */
u64 iqk_start_time;
u64 iqk_progressing_time;
u64 iqk_total_progressing_time;
u64 lck_progressing_time;
u32 lok_result;
/* for APK */
u32 ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
u8 is_ap_kdone;
u8 is_apk_thermal_meter_ignore;
/* DPK */
boolean is_dpk_fail;
u8 is_dp_done;
u8 is_dp_path_aok;
u8 is_dp_path_bok;
u32 tx_lok[2];
u32 dpk_tx_agc;
s32 dpk_gain;
u32 dpk_thermal[4];
s8 modify_tx_agc_value_ofdm;
s8 modify_tx_agc_value_cck;
/*@Add by Yuchen for Kfree Phydm*/
u8 reg_rf_kfree_enable; /*for registry*/
u8 rf_kfree_enable; /*for efuse enable check*/
};
void odm_txpowertracking_check(void *dm_void);
void odm_txpowertracking_init(void *dm_void);
void odm_txpowertracking_check_ap(void *dm_void);
void odm_txpowertracking_thermal_meter_init(void *dm_void);
void odm_txpowertracking_init(void *dm_void);
void odm_txpowertracking_check_mp(void *dm_void);
void odm_txpowertracking_check_ce(void *dm_void);
void odm_txpowertracking_direct_ce(void *dm_void);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
void odm_txpowertracking_callback_thermal_meter92c(
void *adapter);
void odm_txpowertracking_callback_rx_gain_thermal_meter92d(
void *adapter);
void odm_txpowertracking_callback_thermal_meter92d(
void *adapter);
void odm_txpowertracking_direct_call92c(
void *adapter);
void odm_txpowertracking_thermal_meter_check(
void *adapter);
#endif
#endif /*__HALRF_POWER_TRACKING_H__*/
================================================
FILE: hal/phydm/halrf/halrf_powertracking_iot.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*============================================================ */
/* include files */
/*============================================================ */
#include "mp_precomp.h"
#include "phydm_precomp.h"
/* ************************************************************
* Global var
* ************************************************************
*/
u32 ofdm_swing_table[OFDM_TABLE_SIZE] = {
0x7f8001fe, /* 0, +6.0dB */
0x788001e2, /* 1, +5.5dB */
0x71c001c7, /* 2, +5.0dB*/
0x6b8001ae, /* 3, +4.5dB*/
0x65400195, /* 4, +4.0dB*/
0x5fc0017f, /* 5, +3.5dB*/
0x5a400169, /* 6, +3.0dB*/
0x55400155, /* 7, +2.5dB*/
0x50800142, /* 8, +2.0dB*/
0x4c000130, /* 9, +1.5dB*/
0x47c0011f, /* 10, +1.0dB*/
0x43c0010f, /* 11, +0.5dB*/
0x40000100, /* 12, +0dB*/
0x3c8000f2, /* 13, -0.5dB*/
0x390000e4, /* 14, -1.0dB*/
0x35c000d7, /* 15, -1.5dB*/
0x32c000cb, /* 16, -2.0dB*/
0x300000c0, /* 17, -2.5dB*/
0x2d4000b5, /* 18, -3.0dB*/
0x2ac000ab, /* 19, -3.5dB*/
0x288000a2, /* 20, -4.0dB*/
0x26000098, /* 21, -4.5dB*/
0x24000090, /* 22, -5.0dB*/
0x22000088, /* 23, -5.5dB*/
0x20000080, /* 24, -6.0dB*/
0x1e400079, /* 25, -6.5dB*/
0x1c800072, /* 26, -7.0dB*/
0x1b00006c, /* 27. -7.5dB*/
0x19800066, /* 28, -8.0dB*/
0x18000060, /* 29, -8.5dB*/
0x16c0005b, /* 30, -9.0dB*/
0x15800056, /* 31, -9.5dB*/
0x14400051, /* 32, -10.0dB*/
0x1300004c, /* 33, -10.5dB*/
0x12000048, /* 34, -11.0dB*/
0x11000044, /* 35, -11.5dB*/
0x10000040, /* 36, -12.0dB*/
};
u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8] = {
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}, /* 0, +0dB */
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 1, -0.5dB */
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 2, -1.0dB*/
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 3, -1.5dB*/
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 4, -2.0dB */
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 5, -2.5dB*/
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 6, -3.0dB*/
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 7, -3.5dB*/
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 8, -4.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 9, -4.5dB*/
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 10, -5.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 11, -5.5dB*/
{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /* 12, -6.0dB <== default */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 13, -6.5dB*/
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 14, -7.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 15, -7.5dB*/
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 17, -8.5dB*/
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 18, -9.0dB */
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 19, -9.5dB*/
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 20, -10.0dB*/
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 21, -10.5dB*/
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 22, -11.0dB*/
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 23, -11.5dB*/
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 24, -12.0dB*/
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 25, -12.5dB*/
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 26, -13.0dB*/
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 27, -13.5dB*/
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 28, -14.0dB*/
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 29, -14.5dB*/
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 30, -15.0dB*/
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 31, -15.5dB*/
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01} /* 32, -16.0dB*/
};
u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8] = {
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}, /* 0, +0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 1, -0.5dB */
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 2, -1.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /* 3, -1.5dB*/
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 4, -2.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /* 5, -2.5dB*/
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 6, -3.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 7, -3.5dB */
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 8, -4.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /* 9, -4.5dB*/
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 10, -5.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 11, -5.5dB*/
{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 12, -6.0dB <== default*/
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 13, -6.5dB */
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 14, -7.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 15, -7.5dB*/
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 17, -8.5dB*/
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 18, -9.0dB */
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 19, -9.5dB*/
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 20, -10.0dB*/
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 21, -10.5dB*/
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 22, -11.0dB*/
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 23, -11.5dB*/
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 24, -12.0dB*/
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 25, -12.5dB*/
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 26, -13.0dB*/
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 27, -13.5dB*/
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 28, -14.0dB*/
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 29, -14.5dB*/
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 30, -15.0dB*/
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 31, -15.5dB*/
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00} /* 32, -16.0dB*/
};
u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
0x0b40002d, /* 0, -15.0dB */
0x0c000030, /* 1, -14.5dB*/
0x0cc00033, /* 2, -14.0dB*/
0x0d800036, /* 3, -13.5dB*/
0x0e400039, /* 4, -13.0dB */
0x0f00003c, /* 5, -12.5dB*/
0x10000040, /* 6, -12.0dB*/
0x11000044, /* 7, -11.5dB*/
0x12000048, /* 8, -11.0dB*/
0x1300004c, /* 9, -10.5dB*/
0x14400051, /* 10, -10.0dB*/
0x15800056, /* 11, -9.5dB*/
0x16c0005b, /* 12, -9.0dB*/
0x18000060, /* 13, -8.5dB*/
0x19800066, /* 14, -8.0dB*/
0x1b00006c, /* 15, -7.5dB*/
0x1c800072, /* 16, -7.0dB*/
0x1e400079, /* 17, -6.5dB*/
0x20000080, /* 18, -6.0dB*/
0x22000088, /* 19, -5.5dB*/
0x24000090, /* 20, -5.0dB*/
0x26000098, /* 21, -4.5dB*/
0x288000a2, /* 22, -4.0dB*/
0x2ac000ab, /* 23, -3.5dB*/
0x2d4000b5, /* 24, -3.0dB*/
0x300000c0, /* 25, -2.5dB*/
0x32c000cb, /* 26, -2.0dB*/
0x35c000d7, /* 27, -1.5dB*/
0x390000e4, /* 28, -1.0dB*/
0x3c8000f2, /* 29, -0.5dB*/
0x40000100, /* 30, +0dB*/
0x43c0010f, /* 31, +0.5dB*/
0x47c0011f, /* 32, +1.0dB*/
0x4c000130, /* 33, +1.5dB*/
0x50800142, /* 34, +2.0dB*/
0x55400155, /* 35, +2.5dB*/
0x5a400169, /* 36, +3.0dB*/
0x5fc0017f, /* 37, +3.5dB*/
0x65400195, /* 38, +4.0dB*/
0x6b8001ae, /* 39, +4.5dB*/
0x71c001c7, /* 40, +5.0dB*/
0x788001e2, /* 41, +5.5dB*/
0x7f8001fe /* 42, +6.0dB*/
};
u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}, /* 0, -16.0dB*/
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 1, -15.5dB*/
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 2, -15.0dB*/
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 3, -14.5dB*/
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 4, -14.0dB*/
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 5, -13.5dB*/
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 6, -13.0dB*/
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 7, -12.5dB*/
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 8, -12.0dB*/
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 9, -11.5dB*/
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 10, -11.0dB*/
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 11, -10.5dB*/
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 12, -10.0dB*/
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 13, -9.5dB*/
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 15, -8.5dB*/
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 17, -7.5dB*/
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 19, -6.5dB*/
{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /*20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 21, -5.5dB*/
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 23, -4.5dB*/
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 25, -3.5dB*/
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 26, -3.0dB*/
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 27, -2.5dB*/
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 29, -1.5dB*/
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 30, -1.0dB*/
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 31, -0.5dB*/
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} /* 32, +0dB*/
};
u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}, /* 0, -16.0dB*/
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 1, -15.5dB*/
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 2, -15.0dB*/
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 3, -14.5dB*/
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 4, -14.0dB*/
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /*5, -13.5dB*/
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 6, -13.0dB*/
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 7, -12.5dB*/
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 8, -12.0dB*/
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 9, -11.5dB*/
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 10, -11.0dB*/
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /*11, -10.5dB*/
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 12, -10.0dB*/
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 13, -9.5dB*/
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /*14, -9.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 15, -8.5dB*/
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 17, -7.5dB*/
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 19, -6.5dB */
{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 21, -5.5dB*/
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /*23, -4.5dB*/
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 26, -3.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /*27, -2.5dB*/
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /*29, -1.5dB*/
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} /* 32, +0dB */
};
u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* JJ ADD 20161014 */
u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* Winnita ADD 20171116 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263, /*19*/
0x287, /*20*/
0x2AE, /*21*/
0x2D6, /*22*/
0x301, /*23*/
0x32F, /*24*/
0x35F, /*25*/
0x392, /*26*/
0x3C9, /*27*/
0x402, /*28*/
0x43F, /*29*/
0x47F, /*30*/
0x4C3, /*31*/
0x50C, /*32*/
0x558, /*33*/
0x5A9, /*34*/
0x5FF, /*35*/
0x65A, /*36*/
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* Winnita ADD 201805 PathA 0xAB4[10:0]*/
u32 cck_swing_table_ch1_ch14_8721d[CCK_TABLE_SIZE_8721D] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263, /*19*/
0x287, /*20*/
0x2AE, /*21*/
0x2D6, /*22*/
0x301, /*23*/
0x32F, /*24*/
0x35F, /*25*/
0x392, /*26*/
0x3C9, /*27*/
0x402, /*28*/
0x43F, /*29*/
0x47F, /*30*/
0x4C3, /*31*/
0x50C, /*32*/
0x558, /*33*/
0x5A9, /*34*/
0x5FF, /*35*/
0x65A, /*36*/
0x6BA,
0x720,
0x78C,
0x7FF,
};
u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
0x081, /* 0, -12.0dB*/
0x088, /* 1, -11.5dB*/
0x090, /* 2, -11.0dB*/
0x099, /* 3, -10.5dB*/
0x0A2, /* 4, -10.0dB*/
0x0AC, /* 5, -9.5dB*/
0x0B6, /* 6, -9.0dB*/
0x0C0, /*7, -8.5dB*/
0x0CC, /* 8, -8.0dB*/
0x0D8, /* 9, -7.5dB*/
0x0E5, /* 10, -7.0dB*/
0x0F2, /* 11, -6.5dB*/
0x101, /* 12, -6.0dB*/
0x110, /* 13, -5.5dB*/
0x120, /* 14, -5.0dB*/
0x131, /* 15, -4.5dB*/
0x143, /* 16, -4.0dB*/
0x156, /* 17, -3.5dB*/
0x16A, /* 18, -3.0dB*/
0x180, /* 19, -2.5dB*/
0x197, /* 20, -2.0dB*/
0x1AF, /* 21, -1.5dB*/
0x1C8, /* 22, -1.0dB*/
0x1E3, /* 23, -0.5dB*/
0x200, /* 24, +0 dB*/
0x21E, /* 25, +0.5dB*/
0x23E, /* 26, +1.0dB*/
0x261, /* 27, +1.5dB*/
0x285,/* 28, +2.0dB*/
0x2AB, /* 29, +2.5dB*/
0x2D3, /*30, +3.0dB*/
0x2FE, /* 31, +3.5dB*/
0x32B, /* 32, +4.0dB*/
0x35C, /* 33, +4.5dB*/
0x38E, /* 34, +5.0dB*/
0x3C4, /* 35, +5.5dB*/
0x3FE /* 36, +6.0dB */
};
void
odm_txpowertracking_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_thermal_meter_init(dm);
}
u8
get_swing_index(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 i = 0;
u32 bb_swing;
u32 swing_table_size;
u32 *swing_table;
if (dm->support_ic_type == ODM_RTL8195B) {
bb_swing = odm_get_bb_reg(dm, R_0xc1c, 0xFFE00000);
swing_table = tx_scaling_table_jaguar;
swing_table_size = TXSCALE_TABLE_SIZE;
}
for (i = 0; i < swing_table_size; i++) {
u32 table_value = swing_table[i];
table_value = table_value;
if (bb_swing == table_value)
break;
}
return i;
}
u8
get_cck_swing_index(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 i = 0;
u32 bb_cck_swing;
if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
dm->support_ic_type == ODM_RTL8192E) {
bb_cck_swing = odm_read_1byte(dm, 0xa22);
for (i = 0; i < CCK_TABLE_SIZE; i++) {
if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
break;
}
} else if (dm->support_ic_type == ODM_RTL8703B) {
bb_cck_swing = odm_read_1byte(dm, 0xa22);
for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
break;
}
}
return i;
}
void
odm_txpowertracking_thermal_meter_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 default_swing_index = get_swing_index(dm);
u8 p = 0;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
struct _hal_rf_ *rf = &dm->rf_table;
if (!(*dm->mp_mode))
cali_info->txpowertrack_control = true;
else
cali_info->txpowertrack_control = false;
RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
/* dm->rf_calibrate_info.txpowertrack_control = true; */
cali_info->thermal_value = rf->eeprom_thermal;
cali_info->thermal_value_iqk = rf->eeprom_thermal;
cali_info->thermal_value_lck = rf->eeprom_thermal;
if (!cali_info->default_bb_swing_index_flag) {
if (dm->support_ic_type == ODM_RTL8195B) {
cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
cali_info->default_cck_index = 24;
} else if (dm->support_ic_type == ODM_RTL8721D) {
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
}
cali_info->default_bb_swing_index_flag = true;
}
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
cali_info->CCK_index = cali_info->default_cck_index;
for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->delta_power_index[p] = 0;
cali_info->delta_power_index_last[p] = 0;
cali_info->power_index_offset[p] = 0;
}
cali_info->modify_tx_agc_value_ofdm = 0;
cali_info->modify_tx_agc_value_cck = 0;
cali_info->tm_trigger = 0;
}
void
odm_txpowertracking_check(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
odm_txpowertracking_check_iot(dm);
}
void
odm_txpowertracking_check_iot(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
if (!dm->rf_calibrate_info.tm_trigger) {
if (dm->support_ic_type == ODM_RTL8195B)
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW, (BIT(17) | BIT(16)), 0x03);
else if (dm->support_ic_type == ODM_RTL8721D)
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER_NEW,
(BIT(12) | BIT(11)), 0x03);
dm->rf_calibrate_info.tm_trigger = 1;
return;
}
odm_txpowertracking_callback_thermal_meter(dm);
dm->rf_calibrate_info.tm_trigger = 0;
}
void
odm_txpowertracking_check_mp(
void *dm_void
)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
struct dm_struct *dm = (struct dm_struct *)dm_void;
void *adapter = dm->adapter;
if (odm_check_power_status(adapter) == false) {
RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status, return false\n"));
return;
}
odm_txpowertracking_thermal_meter_check(adapter);
#endif
}
void
odm_txpowertracking_check_ap(
void *dm_void
)
{
#if (DM_ODM_SUPPORT_TYPE == ODM_AP)
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct rtl8192cd_priv *priv = dm->priv;
return;
#endif
}
================================================
FILE: hal/phydm/halrf/halrf_powertracking_iot.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_POWERTRACKING_H__
#define __HALRF_POWERTRACKING_H__
#define DPK_DELTA_MAPPING_NUM 13
#define index_mapping_HP_NUM 15
#define OFDM_TABLE_SIZE 43
#define CCK_TABLE_SIZE 33
#define CCK_TABLE_SIZE_88F 21
#define TXSCALE_TABLE_SIZE 37
#define CCK_TABLE_SIZE_8723D 41
/* JJ ADD 20161014 */
#define CCK_TABLE_SIZE_8710B 41
#define CCK_TABLE_SIZE_8192F 41
#define CCK_TABLE_SIZE_8721D 41
#define TXPWR_TRACK_TABLE_SIZE 30
#define DELTA_SWINGIDX_SIZE 30
#define DELTA_SWINTSSI_SIZE 61
#define BAND_NUM 4
#define AVG_THERMAL_NUM 8
#define IQK_MAC_REG_NUM 4
#define IQK_ADDA_REG_NUM 16
#define IQK_BB_REG_NUM_MAX 10
#define IQK_BB_REG_NUM 9
#define iqk_matrix_reg_num 8
#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
#else
#define IQK_MATRIX_SETTINGS_NUM (14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
#endif
extern u32 ofdm_swing_table[OFDM_TABLE_SIZE];
extern u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
extern u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
extern u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
/* JJ ADD 20161014 */
extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
extern u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
extern u32 cck_swing_table_ch1_ch14_8721d[CCK_TABLE_SIZE_8721D];
extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
#if (DM_ODM_SUPPORT_TYPE == ODM_CE) && defined(DM_ODM_CE_MAC80211)
#else
static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 5, 5, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9};
static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 7, 7, 7, 7, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11};
#endif
void
odm_txpowertracking_init(
void *dm_void
);
#define dm_check_txpowertracking odm_txpowertracking_check
struct iqk_matrix_regs_setting {
boolean is_iqk_done;
s32 value[3][iqk_matrix_reg_num];
boolean is_bw_iqk_result_saved[3];
};
struct dm_rf_calibration_struct {
/* for tx power tracking */
u32 rega24; /* for TempCCK */
s32 rege94;
s32 rege9c;
s32 regeb4;
s32 regebc;
u8 tx_powercount;
boolean is_txpowertracking_init;
boolean is_txpowertracking;
u8 txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
u8 tm_trigger;
u8 internal_pa_5g[2]; /* pathA / pathB */
u8 thermal_meter[2]; /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
u8 thermal_value;
u8 thermal_value_lck;
u8 thermal_value_iqk;
s8 thermal_value_delta; /* delta of thermal_value and efuse thermal */
u8 thermal_value_dpk;
u8 thermal_value_avg[AVG_THERMAL_NUM];
u8 thermal_value_avg_index;
u8 thermal_value_rx_gain;
u8 thermal_value_crystal;
u8 thermal_value_dpk_store;
u8 thermal_value_dpk_track;
boolean txpowertracking_in_progress;
boolean is_reloadtxpowerindex;
u8 is_rf_pi_enable;
u32 txpowertracking_callback_cnt; /* cosa add for debug */
/* ------------------------- Tx power Tracking ------------------------- */
u8 is_cck_in_ch14;
u8 CCK_index;
u8 OFDM_index[MAX_RF_PATH];
s8 power_index_offset[MAX_RF_PATH];
s8 delta_power_index[MAX_RF_PATH];
s8 delta_power_index_last[MAX_RF_PATH];
boolean is_tx_power_changed;
s8 xtal_offset;
s8 xtal_offset_last;
struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
u8 delta_lck;
s8 bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
u8 delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
s8 delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
s8 delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
u8 bb_swing_idx_ofdm[MAX_RF_PATH];
u8 bb_swing_idx_ofdm_current;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE | ODM_IOT))
u8 bb_swing_idx_ofdm_base[MAX_RF_PATH];
#else
u8 bb_swing_idx_ofdm_base;
#endif
boolean default_bb_swing_index_flag;
boolean bb_swing_flag_ofdm;
u8 bb_swing_idx_cck;
u8 bb_swing_idx_cck_current;
u8 bb_swing_idx_cck_base;
u8 default_ofdm_index;
u8 default_cck_index;
boolean bb_swing_flag_cck;
s8 absolute_ofdm_swing_idx[MAX_RF_PATH];
s8 remnant_ofdm_swing_idx[MAX_RF_PATH];
s8 absolute_cck_swing_idx[MAX_RF_PATH];
s8 remnant_cck_swing_idx;
s8 modify_tx_agc_value; /*Remnat compensate value at tx_agc */
boolean modify_tx_agc_flag_path_a;
boolean modify_tx_agc_flag_path_b;
boolean modify_tx_agc_flag_path_c;
boolean modify_tx_agc_flag_path_d;
boolean modify_tx_agc_flag_path_a_cck;
boolean modify_tx_agc_flag_path_b_cck;
s8 kfree_offset[MAX_RF_PATH];
/* -------------------------------------------------------------------- */
/* for IQK */
u32 regc04;
u32 reg874;
u32 regc08;
u32 regb68;
u32 regb6c;
u32 reg870;
u32 reg860;
u32 reg864;
boolean is_iqk_initialized;
boolean is_lck_in_progress;
boolean is_antenna_detected;
boolean is_need_iqk;
boolean is_iqk_in_progress;
boolean is_iqk_pa_off;
u8 delta_iqk;
u32 ADDA_backup[IQK_ADDA_REG_NUM];
u32 IQK_MAC_backup[IQK_MAC_REG_NUM];
u32 IQK_BB_backup_recover[9];
u32 IQK_BB_backup[IQK_BB_REG_NUM];
u32 tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 tx_iqc_8703b[3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8703b[2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
u32 tx_iqc_8723d[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8723d[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
/* JJ ADD 20161014 */
u32 tx_iqc_8710b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8710b[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
u8 iqk_step;
u8 kcount;
u8 retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
boolean is_mp_mode;
/* IQK time measurement */
u32 iqk_start_time;
u32 iqk_progressing_time;
u32 iqk_total_progressing_time;
u32 lck_progressing_time;
u32 lok_result;
/* for APK */
u32 ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
u8 is_ap_kdone;
u8 is_apk_thermal_meter_ignore;
/* DPK */
boolean is_dpk_fail;
u8 is_dp_done;
u8 is_dp_path_aok;
u8 is_dp_path_bok;
u32 tx_lok[2];
u32 dpk_tx_agc;
s32 dpk_gain;
u32 dpk_thermal[4];
s8 modify_tx_agc_value_ofdm;
s8 modify_tx_agc_value_cck;
/*Add by Yuchen for Kfree Phydm*/
u8 reg_rf_kfree_enable; /*for registry*/
u8 rf_kfree_enable; /*for efuse enable check*/
};
void
odm_txpowertracking_check(
void *dm_void
);
void
odm_txpowertracking_check_ap(
void *dm_void
);
void
odm_txpowertracking_thermal_meter_init(
void *dm_void
);
void
odm_txpowertracking_check_mp(
void *dm_void
);
void
odm_txpowertracking_check_iot(
void *dm_void
);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
void
odm_txpowertracking_callback_thermal_meter92c(
void *adapter
);
void
odm_txpowertracking_callback_rx_gain_thermal_meter92d(
void *adapter
);
void
odm_txpowertracking_callback_thermal_meter92d(
void *adapter
);
void
odm_txpowertracking_direct_call92c(
void *adapter
);
void
odm_txpowertracking_thermal_meter_check(
void *adapter
);
#endif
#endif /*#ifndef __HALRF_POWER_TRACKING_H__*/
================================================
FILE: hal/phydm/halrf/halrf_powertracking_win.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/*============================================================ */
/* include files */
/*============================================================ */
#include "mp_precomp.h"
#include "phydm_precomp.h"
/* ************************************************************
* Global var
* ************************************************************ */
u32 ofdm_swing_table[OFDM_TABLE_SIZE] = {
0x7f8001fe, /* 0, +6.0dB */
0x788001e2, /* 1, +5.5dB */
0x71c001c7, /* 2, +5.0dB */
0x6b8001ae, /* 3, +4.5dB */
0x65400195, /* 4, +4.0dB */
0x5fc0017f, /* 5, +3.5dB */
0x5a400169, /* 6, +3.0dB */
0x55400155, /* 7, +2.5dB */
0x50800142, /* 8, +2.0dB */
0x4c000130, /* 9, +1.5dB */
0x47c0011f, /* 10, +1.0dB */
0x43c0010f, /* 11, +0.5dB */
0x40000100, /* 12, +0dB */
0x3c8000f2, /* 13, -0.5dB */
0x390000e4, /* 14, -1.0dB */
0x35c000d7, /* 15, -1.5dB */
0x32c000cb, /* 16, -2.0dB */
0x300000c0, /* 17, -2.5dB */
0x2d4000b5, /* 18, -3.0dB */
0x2ac000ab, /* 19, -3.5dB */
0x288000a2, /* 20, -4.0dB */
0x26000098, /* 21, -4.5dB */
0x24000090, /* 22, -5.0dB */
0x22000088, /* 23, -5.5dB */
0x20000080, /* 24, -6.0dB */
0x1e400079, /* 25, -6.5dB */
0x1c800072, /* 26, -7.0dB */
0x1b00006c, /* 27. -7.5dB */
0x19800066, /* 28, -8.0dB */
0x18000060, /* 29, -8.5dB */
0x16c0005b, /* 30, -9.0dB */
0x15800056, /* 31, -9.5dB */
0x14400051, /* 32, -10.0dB */
0x1300004c, /* 33, -10.5dB */
0x12000048, /* 34, -11.0dB */
0x11000044, /* 35, -11.5dB */
0x10000040, /* 36, -12.0dB */
};
u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8] = {
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}, /* 0, +0dB */
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 1, -0.5dB */
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 2, -1.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 3, -1.5dB */
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 4, -2.0dB */
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 5, -2.5dB */
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 6, -3.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 7, -3.5dB */
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 8, -4.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 9, -4.5dB */
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 10, -5.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 11, -5.5dB */
{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /* 12, -6.0dB <== default */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 13, -6.5dB */
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 14, -7.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 15, -7.5dB */
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 17, -8.5dB */
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 18, -9.0dB */
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 19, -9.5dB */
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 20, -10.0dB */
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 21, -10.5dB */
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 22, -11.0dB */
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 23, -11.5dB */
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 24, -12.0dB */
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 25, -12.5dB */
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 26, -13.0dB */
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 27, -13.5dB */
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 28, -14.0dB */
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 29, -14.5dB */
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 30, -15.0dB */
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 31, -15.5dB */
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01} /* 32, -16.0dB */
};
u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8] = {
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}, /* 0, +0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 1, -0.5dB */
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 2, -1.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /* 3, -1.5dB */
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 4, -2.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /* 5, -2.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 6, -3.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 7, -3.5dB */
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 8, -4.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /* 9, -4.5dB */
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 10, -5.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 11, -5.5dB */
{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 12, -6.0dB <== default */
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 13, -6.5dB */
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 14, -7.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 15, -7.5dB */
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 17, -8.5dB */
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 18, -9.0dB */
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 19, -9.5dB */
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 20, -10.0dB */
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 21, -10.5dB */
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 22, -11.0dB */
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 23, -11.5dB */
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 24, -12.0dB */
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 25, -12.5dB */
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 26, -13.0dB */
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 27, -13.5dB */
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 28, -14.0dB */
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 29, -14.5dB */
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 30, -15.0dB */
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 31, -15.5dB */
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00} /* 32, -16.0dB */
};
u32 ofdm_swing_table_new[OFDM_TABLE_SIZE] = {
0x0b40002d, /* 0, -15.0dB */
0x0c000030, /* 1, -14.5dB */
0x0cc00033, /* 2, -14.0dB */
0x0d800036, /* 3, -13.5dB */
0x0e400039, /* 4, -13.0dB */
0x0f00003c, /* 5, -12.5dB */
0x10000040, /* 6, -12.0dB */
0x11000044, /* 7, -11.5dB */
0x12000048, /* 8, -11.0dB */
0x1300004c, /* 9, -10.5dB */
0x14400051, /* 10, -10.0dB */
0x15800056, /* 11, -9.5dB */
0x16c0005b, /* 12, -9.0dB */
0x18000060, /* 13, -8.5dB */
0x19800066, /* 14, -8.0dB */
0x1b00006c, /* 15, -7.5dB */
0x1c800072, /* 16, -7.0dB */
0x1e400079, /* 17, -6.5dB */
0x20000080, /* 18, -6.0dB */
0x22000088, /* 19, -5.5dB */
0x24000090, /* 20, -5.0dB */
0x26000098, /* 21, -4.5dB */
0x288000a2, /* 22, -4.0dB */
0x2ac000ab, /* 23, -3.5dB */
0x2d4000b5, /* 24, -3.0dB */
0x300000c0, /* 25, -2.5dB */
0x32c000cb, /* 26, -2.0dB */
0x35c000d7, /* 27, -1.5dB */
0x390000e4, /* 28, -1.0dB */
0x3c8000f2, /* 29, -0.5dB */
0x40000100, /* 30, +0dB */
0x43c0010f, /* 31, +0.5dB */
0x47c0011f, /* 32, +1.0dB */
0x4c000130, /* 33, +1.5dB */
0x50800142, /* 34, +2.0dB */
0x55400155, /* 35, +2.5dB */
0x5a400169, /* 36, +3.0dB */
0x5fc0017f, /* 37, +3.5dB */
0x65400195, /* 38, +4.0dB */
0x6b8001ae, /* 39, +4.5dB */
0x71c001c7, /* 40, +5.0dB */
0x788001e2, /* 41, +5.5dB */
0x7f8001fe /* 42, +6.0dB */
};
u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x33, 0x28, 0x1C, 0x13, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x36, 0x2A, 0x1E, 0x14, 0x0B, 0x05, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x39, 0x2C, 0x20, 0x15, 0x0C, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x3C, 0x2F, 0x22, 0x16, 0x0D, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x40, 0x32, 0x24, 0x17, 0x0E, 0x06, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x43, 0x35, 0x26, 0x19, 0x0E, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x47, 0x38, 0x28, 0x1A, 0x0F, 0x07, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x4C, 0x3B, 0x2B, 0x1C, 0x10, 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x50, 0x3F, 0x2D, 0x1E, 0x11, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x55, 0x42, 0x30, 0x1F, 0x12, 0x08, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x5A, 0x46, 0x33, 0x21, 0x13, 0x09, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x5F, 0x4A, 0x36, 0x23, 0x14, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x65, 0x4F, 0x39, 0x25, 0x15, 0x0A, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x6B, 0x54, 0x3C, 0x27, 0x17, 0x0B, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x71, 0x58, 0x40, 0x2A, 0x18, 0x0B, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x78, 0x5E, 0x43, 0x2C, 0x19, 0x0C, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x7F, 0x63, 0x47, 0x2F, 0x1B, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x87, 0x69, 0x4C, 0x32, 0x1D, 0x0D, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x8F, 0x6F, 0x50, 0x35, 0x1E, 0x0E, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x97, 0x76, 0x55, 0x38, 0x20, 0x0F, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0xA0, 0x7D, 0x5A, 0x3B, 0x22, 0x10, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16] = {
{0x44, 0x42, 0x3C, 0x28, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-16dB*/
{0x48, 0x46, 0x3F, 0x2A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15.5dB*/
{0x4D, 0x4A, 0x43, 0x2C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-15dB*/
{0x51, 0x4F, 0x47, 0x2F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14.5dB*/
{0x56, 0x53, 0x4B, 0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-14dB*/
{0x5B, 0x58, 0x50, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13.5dB*/
{0x60, 0x5D, 0x54, 0x38, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-13dB*/
{0x66, 0x63, 0x59, 0x3B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12.5dB*/
{0x6C, 0x69, 0x5F, 0x3F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-12dB*/
{0x73, 0x6F, 0x64, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11.5dB*/
{0x79, 0x76, 0x6A, 0x46, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-11dB*/
{0x81, 0x7C, 0x71, 0x4A, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10.5dB*/
{0x88, 0x84, 0x77, 0x4F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-10dB*/
{0x90, 0x8C, 0x7E, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9.5dB*/
{0x99, 0x94, 0x86, 0x58, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-9dB*/
{0xA2, 0x9D, 0x8E, 0x5E, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8.5dB*/
{0xAC, 0xA6, 0x96, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-8dB*/
{0xB6, 0xB0, 0x9F, 0x69, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7.5dB*/
{0xC1, 0xBA, 0xA8, 0x6F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-7dB*/
{0xCC, 0xC5, 0xB2, 0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /*-6.5dB*/
{0xD8, 0xD1, 0xBD, 0x7D, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00} /*-6dB*/
};
u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}, /* 0, -16.0dB */
{0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /* 1, -15.5dB */
{0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 2, -15.0dB */
{0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /* 3, -14.5dB */
{0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 4, -14.0dB */
{0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /* 5, -13.5dB */
{0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /* 6, -13.0dB */
{0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /* 7, -12.5dB */
{0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /* 8, -12.0dB */
{0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /* 9, -11.5dB */
{0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 10, -11.0dB */
{0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /* 11, -10.5dB */
{0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 12, -10.0dB */
{0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /* 13, -9.5dB */
{0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /* 15, -8.5dB */
{0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /* 17, -7.5dB */
{0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /* 19, -6.5dB */
{0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /* 21, -5.5dB */
{0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /* 23, -4.5dB */
{0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /* 26, -3.0dB */
{0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /* 27, -2.5dB */
{0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /* 29, -1.5dB */
{0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04} /* 32, +0dB */
};
u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8] = {
{0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}, /* 0, -16.0dB */
{0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 1, -15.5dB */
{0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 2, -15.0dB */
{0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 3, -14.5dB */
{0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /* 4, -14.0dB */
{0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 5, -13.5dB */
{0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 6, -13.0dB */
{0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /* 7, -12.5dB */
{0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 8, -12.0dB */
{0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /* 9, -11.5dB */
{0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 10, -11.0dB */
{0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /* 11, -10.5dB */
{0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 12, -10.0dB */
{0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /* 13, -9.5dB */
{0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 14, -9.0dB */
{0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /* 15, -8.5dB */
{0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 16, -8.0dB */
{0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /* 17, -7.5dB */
{0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /* 18, -7.0dB */
{0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /* 19, -6.5dB */
{0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 20, -6.0dB */
{0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /* 21, -5.5dB */
{0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /* 22, -5.0dB */
{0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /* 23, -4.5dB */
{0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /* 24, -4.0dB */
{0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /* 25, -3.5dB */
{0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /* 26, -3.0dB */
{0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /* 27, -2.5dB */
{0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /* 28, -2.0dB */
{0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /* 29, -1.5dB */
{0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /* 30, -1.0dB */
{0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /* 31, -0.5dB */
{0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00} /* 32, +0dB */
};
u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D] = {
0x0CD,
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263,
0x287,
0x2AE,
0x2D6,
0x301,
0x32F,
0x35F,
0x392,
0x3C9,
0x402,
0x43F,
0x47F,
0x4C3,
0x50C,
0x558,
0x5A9,
0x5FF,
0x65A,
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* JJ ADD 20161014 */
u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263, /*19*/
0x287, /*20*/
0x2AE, /*21*/
0x2D6, /*22*/
0x301, /*23*/
0x32F, /*24*/
0x35F, /*25*/
0x392, /*26*/
0x3C9, /*27*/
0x402, /*28*/
0x43F, /*29*/
0x47F, /*30*/
0x4C3, /*31*/
0x50C, /*32*/
0x558, /*33*/
0x5A9, /*34*/
0x5FF, /*35*/
0x65A, /*36*/
0x6BA,
0x720,
0x78C,
0x7FF,
};
/* Winnita ADD 20170828 PathA 0xAB4[10:0],PathB 0xAB4[21:11]*/
u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F] = {
0x0CD, /*0 , -20dB*/
0x0D9,
0x0E6,
0x0F3,
0x102,
0x111,
0x121,
0x132,
0x144,
0x158,
0x16C,
0x182,
0x198,
0x1B1,
0x1CA,
0x1E5,
0x202,
0x221,
0x241,
0x263, /*19*/
0x287, /*20*/
0x2AE, /*21*/
0x2D6, /*22*/
0x301, /*23*/
0x32F, /*24*/
0x35F, /*25*/
0x392, /*26*/
0x3C9, /*27*/
0x402, /*28*/
0x43F, /*29*/
0x47F, /*30*/
0x4C3, /*31*/
0x50C, /*32*/
0x558, /*33*/
0x5A9, /*34*/
0x5FF, /*35*/
0x65A, /*36*/
0x6BA,
0x720,
0x78C,
0x7FF,
};
u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE] = {
0x081, /* 0, -12.0dB */
0x088, /* 1, -11.5dB */
0x090, /* 2, -11.0dB */
0x099, /* 3, -10.5dB */
0x0A2, /* 4, -10.0dB */
0x0AC, /* 5, -9.5dB */
0x0B6, /* 6, -9.0dB */
0x0C0, /* 7, -8.5dB */
0x0CC, /* 8, -8.0dB */
0x0D8, /* 9, -7.5dB */
0x0E5, /* 10, -7.0dB */
0x0F2, /* 11, -6.5dB */
0x101, /* 12, -6.0dB */
0x110, /* 13, -5.5dB */
0x120, /* 14, -5.0dB */
0x131, /* 15, -4.5dB */
0x143, /* 16, -4.0dB */
0x156, /* 17, -3.5dB */
0x16A, /* 18, -3.0dB */
0x180, /* 19, -2.5dB */
0x197, /* 20, -2.0dB */
0x1AF, /* 21, -1.5dB */
0x1C8, /* 22, -1.0dB */
0x1E3, /* 23, -0.5dB */
0x200, /* 24, +0 dB */
0x21E, /* 25, +0.5dB */
0x23E, /* 26, +1.0dB */
0x261, /* 27, +1.5dB */
0x285, /* 28, +2.0dB */
0x2AB, /* 29, +2.5dB */
0x2D3, /* 30, +3.0dB */
0x2FE, /* 31, +3.5dB */
0x32B, /* 32, +4.0dB */
0x35C, /* 33, +4.5dB */
0x38E, /* 34, +5.0dB */
0x3C4, /* 35, +5.5dB */
0x3FE /* 36, +6.0dB */
};
void
odm_txpowertracking_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
if (!(dm->support_ic_type & (ODM_RTL8814A | ODM_IC_11N_SERIES | ODM_RTL8822B)))
return;
#endif
odm_txpowertracking_thermal_meter_init(dm);
}
u8
get_swing_index(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
u8 i = 0;
u32 bb_swing, table_value;
if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8188F ||
dm->support_ic_type == ODM_RTL8703B || dm->support_ic_type == ODM_RTL8723D ||
dm->support_ic_type == ODM_RTL8192F || dm->support_ic_type == ODM_RTL8710B ||
dm->support_ic_type == ODM_RTL8821) {
bb_swing = odm_get_bb_reg(dm, REG_OFDM_0_XA_TX_IQ_IMBALANCE, 0xFFC00000);
for (i = 0; i < OFDM_TABLE_SIZE; i++) {
table_value = ofdm_swing_table_new[i];
if (table_value >= 0x100000)
table_value >>= 22;
if (bb_swing == table_value)
break;
}
} else {
bb_swing = PHY_GetTxBBSwing_8812A(adapter, hal_data->CurrentBandType, RF_PATH_A);
for (i = 0; i < TXSCALE_TABLE_SIZE; i++) {
table_value = tx_scaling_table_jaguar[i];
if (bb_swing == table_value)
break;
}
}
return i;
}
u8
get_cck_swing_index(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 i = 0;
u32 bb_cck_swing;
if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
dm->support_ic_type == ODM_RTL8192E) {
bb_cck_swing = odm_read_1byte(dm, 0xa22);
for (i = 0; i < CCK_TABLE_SIZE; i++) {
if (bb_cck_swing == cck_swing_table_ch1_ch13_new[i][0])
break;
}
} else if (dm->support_ic_type == ODM_RTL8703B) {
bb_cck_swing = odm_read_1byte(dm, 0xa22);
for (i = 0; i < CCK_TABLE_SIZE_88F; i++) {
if (bb_cck_swing == cck_swing_table_ch1_ch14_88f[i][0])
break;
}
}
return i;
}
void
odm_txpowertracking_thermal_meter_init(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 default_swing_index = get_swing_index(dm);
u8 default_cck_swing_index = get_cck_swing_index(dm);
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
struct _hal_rf_ *rf = &dm->rf_table;
#if (RTL8822C_SUPPORT == 1)
struct _halrf_tssi_data *tssi = &rf->halrf_tssi_data;
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
u8 p = 0;
if (*(dm->mp_mode) == false)
cali_info->txpowertrack_control = true;
#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
#ifdef CONFIG_RTL8188E
{
cali_info->is_txpowertracking = true;
cali_info->tx_powercount = 0;
cali_info->is_txpowertracking_init = false;
if (*(dm->mp_mode) == false)
cali_info->txpowertrack_control = true;
MSG_8192C("dm txpowertrack_control = %d\n", cali_info->txpowertrack_control);
}
#else
{
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_priv *pdmpriv = &hal_data->dmpriv;
pdmpriv->is_txpowertracking = true;
pdmpriv->tx_powercount = 0;
pdmpriv->is_txpowertracking_init = false;
if (*(dm->mp_mode) == false)
pdmpriv->txpowertrack_control = true;
MSG_8192C("pdmpriv->txpowertrack_control = %d\n", pdmpriv->txpowertrack_control);
}
#endif
#elif (DM_ODM_SUPPORT_TYPE & (ODM_AP))
#ifdef RTL8188E_SUPPORT
{
cali_info->is_txpowertracking = true;
cali_info->tx_powercount = 0;
cali_info->is_txpowertracking_init = false;
cali_info->txpowertrack_control = true;
}
#endif
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
#if (MP_DRIVER == 1)
cali_info->txpowertrack_control = false;
#else
cali_info->txpowertrack_control = true;
#endif
#else
cali_info->txpowertrack_control = true;
#endif
cali_info->thermal_value = hal_data->eeprom_thermal_meter;
cali_info->thermal_value_iqk = hal_data->eeprom_thermal_meter;
cali_info->thermal_value_lck = hal_data->eeprom_thermal_meter;
#if (RTL8822C_SUPPORT == 1)
if (dm->support_ic_type == ODM_RTL8822C) {
cali_info->thermal_value_path[RF_PATH_A] = tssi->thermal[RF_PATH_A];
cali_info->thermal_value_path[RF_PATH_B] = tssi->thermal[RF_PATH_B];
cali_info->thermal_value_iqk = tssi->thermal[RF_PATH_A];
cali_info->thermal_value_lck = tssi->thermal[RF_PATH_A];
}
#endif
if (cali_info->default_bb_swing_index_flag != true) {
/*The index of "0 dB" in SwingTable.*/
if (dm->support_ic_type == ODM_RTL8188E || dm->support_ic_type == ODM_RTL8723B ||
dm->support_ic_type == ODM_RTL8192E || dm->support_ic_type == ODM_RTL8703B ||
dm->support_ic_type == ODM_RTL8821) {
cali_info->default_ofdm_index = (default_swing_index >= OFDM_TABLE_SIZE) ? 30 : default_swing_index;
cali_info->default_cck_index = (default_cck_swing_index >= CCK_TABLE_SIZE) ? 20 : default_cck_swing_index;
} else if (dm->support_ic_type == ODM_RTL8188F) { /*add by Mingzhi.Guo 2015-03-23*/
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 20; /*CCK:-6dB*/
} else if (dm->support_ic_type == ODM_RTL8723D) { /*add by zhaohe 2015-10-27*/
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
/* JJ ADD 20161014 */
} else if (dm->support_ic_type == ODM_RTL8710B) {
cali_info->default_ofdm_index = 28; /*OFDM: -1dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
/*Winnita add 20170828*/
} else if (dm->support_ic_type == ODM_RTL8192F) {
cali_info->default_ofdm_index = 30; /*OFDM: 0dB*/
cali_info->default_cck_index = 28; /*CCK: -6dB*/
} else {
cali_info->default_ofdm_index = (default_swing_index >= TXSCALE_TABLE_SIZE) ? 24 : default_swing_index;
cali_info->default_cck_index = 24;
}
cali_info->default_bb_swing_index_flag = true;
}
cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
cali_info->CCK_index = cali_info->default_cck_index;
for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
cali_info->bb_swing_idx_ofdm_base[p] = cali_info->default_ofdm_index;
cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
cali_info->delta_power_index[p] = 0;
cali_info->delta_power_index_last[p] = 0;
cali_info->power_index_offset[p] = 0;
cali_info->kfree_offset[p] = 0;
}
cali_info->modify_tx_agc_value_ofdm = 0;
cali_info->modify_tx_agc_value_cck = 0;
cali_info->tm_trigger = 0;
}
void
odm_txpowertracking_check(
void *dm_void
)
{
#if 0
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
#endif
struct dm_struct *dm = (struct dm_struct *)dm_void;
switch (dm->support_platform) {
case ODM_WIN:
odm_txpowertracking_check_mp(dm);
break;
case ODM_CE:
odm_txpowertracking_check_ce(dm);
break;
case ODM_AP:
odm_txpowertracking_check_ap(dm);
break;
default:
break;
}
}
void
odm_txpowertracking_check_ce(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
#if (DM_ODM_SUPPORT_TYPE == ODM_CE)
void *adapter = dm->adapter;
#if ((RTL8188F_SUPPORT == 1))
rtl8192c_odm_check_txpowertracking(adapter);
#endif
#if (RTL8188E_SUPPORT == 1)
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK))
return;
if (!cali_info->tm_trigger) {
odm_set_rf_reg(dm, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
/*DBG_8192C("Trigger 92C Thermal Meter!!\n");*/
cali_info->tm_trigger = 1;
return;
} else {
/*DBG_8192C("Schedule TxPowerTracking direct call!!\n");*/
odm_txpowertracking_callback_thermal_meter_8188e(adapter);
cali_info->tm_trigger = 0;
}
#endif
#endif
}
void
odm_txpowertracking_check_mp(
void *dm_void
)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void *adapter = dm->adapter;
if (*dm->is_fcs_mode_enable)
return;
if (odm_check_power_status(dm) == false) {
RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("check_pow_status return false\n"));
return;
}
if (IS_HARDWARE_TYPE_8821B(adapter)) /* TODO: Don't Do PowerTracking*/
return;
odm_txpowertracking_thermal_meter_check(adapter);
#endif
}
void
odm_txpowertracking_check_ap(
void *dm_void
)
{
return;
}
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void
odm_txpowertracking_direct_call(
void *adapter
)
{
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_struct *dm = &hal_data->DM_OutSrc;
if (dm->support_ic_type & ODM_RTL8822C) {
#if (RTL8822C_SUPPORT == 1)
odm_txpowertracking_new_callback_thermal_meter(dm);
#endif
} else
odm_txpowertracking_callback_thermal_meter(adapter);
}
void
odm_txpowertracking_thermal_meter_check(
void *adapter
)
{
static u8 tm_trigger = 0;
HAL_DATA_TYPE *pHalData = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_struct *dm = &(pHalData->DM_OutSrc);
struct _hal_rf_ *rf = &(dm->rf_table);
if (!(rf->rf_supportability & HAL_RF_TX_PWR_TRACK)) {
RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD,
("===>odm_txpowertracking_thermal_meter_check(),mgnt_info->is_txpowertracking is false, return!!\n"));
return;
}
if (rf->power_track_type != 0) {
if (IS_HARDWARE_TYPE_8822C(adapter)) {
/*halrf_tssi_cck(dm);*/
/*halrf_thermal_cck(dm);*/
return;
}
}
if (!tm_trigger) {
if (IS_HARDWARE_TYPE_8188E(adapter) || IS_HARDWARE_TYPE_JAGUAR(adapter) || IS_HARDWARE_TYPE_8192E(adapter) || IS_HARDWARE_TYPE_8192F(adapter)
||IS_HARDWARE_TYPE_8723B(adapter) || IS_HARDWARE_TYPE_8814A(adapter) || IS_HARDWARE_TYPE_8188F(adapter) || IS_HARDWARE_TYPE_8703B(adapter)
|| IS_HARDWARE_TYPE_8822B(adapter) || IS_HARDWARE_TYPE_8723D(adapter) || IS_HARDWARE_TYPE_8821C(adapter) || IS_HARDWARE_TYPE_8710B(adapter)
|| IS_HARDWARE_TYPE_8814B(adapter))/* JJ ADD 20161014 */
PHY_SetRFReg(adapter, RF_PATH_A, RF_T_METER_88E, BIT(17) | BIT(16), 0x03);
else if (IS_HARDWARE_TYPE_8822C(adapter)) {
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_A, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x00);
odm_set_rf_reg(dm, RF_PATH_B, R_0x42, BIT(19), 0x01);
}
else
PHY_SetRFReg(adapter, RF_PATH_A, RF_T_METER, RFREGOFFSETMASK, 0x60);
RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Trigger Thermal Meter!!\n"));
tm_trigger = 1;
return;
} else {
RT_TRACE(COMP_POWER_TRACKING, DBG_LOUD, ("Schedule TxPowerTracking direct call!!\n"));
odm_txpowertracking_direct_call(adapter);
tm_trigger = 0;
}
}
#endif
================================================
FILE: hal/phydm/halrf/halrf_powertracking_win.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HALRF_POWERTRACKING_H__
#define __HALRF_POWERTRACKING_H__
#define DPK_DELTA_MAPPING_NUM 13
#define index_mapping_HP_NUM 15
#define TXSCALE_TABLE_SIZE 37
#define OFDM_TABLE_SIZE 43
#define CCK_TABLE_SIZE 33
#define CCK_TABLE_SIZE_8723D 41
#define TXPWR_TRACK_TABLE_SIZE 30
#define DELTA_SWINGIDX_SIZE 30
#define DELTA_SWINTSSI_SIZE 61
#define BAND_NUM 3
#define MAX_RF_PATH 4
#define CCK_TABLE_SIZE_88F 21
/* JJ ADD 20161014 */
#define CCK_TABLE_SIZE_8710B 41
#define CCK_TABLE_SIZE_8192F 41
#define dm_check_txpowertracking odm_txpowertracking_check
#define IQK_MATRIX_SETTINGS_NUM (14+24+21) /* Channels_2_4G_NUM + Channels_5G_20M_NUM + Channels_5G */
#define AVG_THERMAL_NUM 8
#define iqk_matrix_reg_num 8
#define IQK_MAC_REG_NUM 4
#define IQK_ADDA_REG_NUM 16
#define IQK_BB_REG_NUM 9
extern u32 ofdm_swing_table[OFDM_TABLE_SIZE];
extern u8 cck_swing_table_ch1_ch13[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14[CCK_TABLE_SIZE][8];
extern u32 ofdm_swing_table_new[OFDM_TABLE_SIZE];
extern u8 cck_swing_table_ch1_ch13_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch14_new[CCK_TABLE_SIZE][8];
extern u8 cck_swing_table_ch1_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch1_ch13_88f[CCK_TABLE_SIZE_88F][16];
extern u8 cck_swing_table_ch14_88f[CCK_TABLE_SIZE_88F][16];
extern u32 cck_swing_table_ch1_ch14_8723d[CCK_TABLE_SIZE_8723D];
/* JJ ADD 20161014 */
extern u32 cck_swing_table_ch1_ch14_8710b[CCK_TABLE_SIZE_8710B];
extern u32 cck_swing_table_ch1_ch14_8192f[CCK_TABLE_SIZE_8192F];
extern u32 tx_scaling_table_jaguar[TXSCALE_TABLE_SIZE];
/* <20121018, Kordan> In case fail to read TxPowerTrack.txt, we use the table of 88E as the default table. */
static u8 delta_swing_table_idx_2ga_p_8188e[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 5, 5, 7, 7, 8, 8, 8, 9, 9, 9, 9, 9};
static u8 delta_swing_table_idx_2ga_n_8188e[] = {0, 0, 0, 2, 2, 3, 3, 4, 4, 4, 4, 5, 5, 6, 6, 7, 7, 7, 7, 8, 8, 9, 9, 10, 10, 10, 11, 11, 11, 11};
void
odm_txpowertracking_check(
void *dm_void
);
void
odm_txpowertracking_check_ap(
void *dm_void
);
void
odm_txpowertracking_thermal_meter_init(
void *dm_void
);
void
odm_txpowertracking_init(
void *dm_void
);
void
odm_txpowertracking_check_mp(
void *dm_void
);
void
odm_txpowertracking_check_ce(
void *dm_void
);
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN))
void
odm_txpowertracking_thermal_meter_check(
void *adapter
);
#endif
struct iqk_matrix_regs_setting {
boolean is_iqk_done;
s32 value[3][iqk_matrix_reg_num];
boolean is_bw_iqk_result_saved[3];
};
struct dm_rf_calibration_struct {
/* for tx power tracking */
u32 rega24; /* for TempCCK */
s32 rege94;
s32 rege9c;
s32 regeb4;
s32 regebc;
/* u8 is_txpowertracking; */
u8 tx_powercount;
boolean is_txpowertracking_init;
boolean is_txpowertracking;
u8 txpowertrack_control; /* for mp mode, turn off txpwrtracking as default */
u8 tm_trigger;
u8 internal_pa_5g[2]; /* pathA / pathB */
u8 thermal_meter[2]; /* thermal_meter, index 0 for RFIC0, and 1 for RFIC1 */
u8 thermal_value;
u8 thermal_value_path[MAX_RF_PATH];
u8 thermal_value_lck;
u8 thermal_value_iqk;
u8 thermal_value_dpk;
s8 thermal_value_delta; /* delta of thermal_value and efuse thermal */
u8 thermal_value_avg[AVG_THERMAL_NUM];
u8 thermal_value_avg_path[MAX_RF_PATH][AVG_THERMAL_NUM];
u8 thermal_value_avg_index;
u8 thermal_value_avg_index_path[MAX_RF_PATH];
u8 thermal_value_rx_gain;
boolean is_reloadtxpowerindex;
u8 is_rf_pi_enable;
u32 txpowertracking_callback_cnt; /* cosa add for debug */
/* ------------------------- Tx power Tracking ------------------------- */
u8 is_cck_in_ch14;
u8 CCK_index;
u8 OFDM_index[MAX_RF_PATH];
s8 power_index_offset[MAX_RF_PATH];
s8 delta_power_index[MAX_RF_PATH];
s8 delta_power_index_last[MAX_RF_PATH];
boolean is_tx_power_changed;
s8 xtal_offset;
s8 xtal_offset_last;
struct iqk_matrix_regs_setting iqk_matrix_reg_setting[IQK_MATRIX_SETTINGS_NUM];
u8 delta_lck;
s8 bb_swing_diff_2g, bb_swing_diff_5g; /* Unit: dB */
u8 delta_swing_table_idx_2g_cck_a_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_a_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_b_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_c_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2g_cck_d_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gb_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gc_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_p[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2gd_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5ga_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gb_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gc_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_p[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_5gd_n[BAND_NUM][DELTA_SWINGIDX_SIZE];
u8 delta_swing_tssi_table_2g_cck_a[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_b[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_c[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2g_cck_d[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2ga[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gb[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gc[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_2gd[DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5ga[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gb[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gc[BAND_NUM][DELTA_SWINTSSI_SIZE];
u8 delta_swing_tssi_table_5gd[BAND_NUM][DELTA_SWINTSSI_SIZE];
s8 delta_swing_table_xtal_p[DELTA_SWINGIDX_SIZE];
s8 delta_swing_table_xtal_n[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_p_8188e[DELTA_SWINGIDX_SIZE];
u8 delta_swing_table_idx_2ga_n_8188e[DELTA_SWINGIDX_SIZE];
u8 bb_swing_idx_ofdm[MAX_RF_PATH];
u8 bb_swing_idx_ofdm_current;
#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
u8 bb_swing_idx_ofdm_base[MAX_RF_PATH];
#else
u8 bb_swing_idx_ofdm_base;
#endif
boolean default_bb_swing_index_flag;
boolean bb_swing_flag_ofdm;
u8 bb_swing_idx_cck;
u8 bb_swing_idx_cck_current;
u8 bb_swing_idx_cck_base;
u8 default_ofdm_index;
u8 default_cck_index;
boolean bb_swing_flag_cck;
s8 absolute_ofdm_swing_idx[MAX_RF_PATH];
s8 remnant_ofdm_swing_idx[MAX_RF_PATH];
s8 absolute_cck_swing_idx[MAX_RF_PATH];
s8 remnant_cck_swing_idx;
s8 modify_tx_agc_value; /*Remnat compensate value at tx_agc */
boolean modify_tx_agc_flag_path_a;
boolean modify_tx_agc_flag_path_b;
boolean modify_tx_agc_flag_path_c;
boolean modify_tx_agc_flag_path_d;
boolean modify_tx_agc_flag_path_a_cck;
boolean modify_tx_agc_flag_path_b_cck;
s8 kfree_offset[MAX_RF_PATH];
/* -------------------------------------------------------------------- */
/* for IQK */
u32 regc04;
u32 reg874;
u32 regc08;
u32 regb68;
u32 regb6c;
u32 reg870;
u32 reg860;
u32 reg864;
boolean is_iqk_initialized;
boolean is_lck_in_progress;
boolean is_antenna_detected;
boolean is_need_iqk;
boolean is_iqk_in_progress;
boolean is_iqk_pa_off;
u8 delta_iqk;
u32 ADDA_backup[IQK_ADDA_REG_NUM];
u32 IQK_MAC_backup[IQK_MAC_REG_NUM];
u32 IQK_BB_backup_recover[9];
u32 IQK_BB_backup[IQK_BB_REG_NUM];
u32 tx_iqc_8723b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}} */
u32 rx_iqc_8723b[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}} */
u32 tx_iqc_8703b[3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8703b[2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
u32 tx_iqc_8723d[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8723d[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
/* JJ ADD 20161014 */
u32 tx_iqc_8710b[2][3][2]; /* { {S1: 0xc94, 0xc80, 0xc4c} , {S0: 0xc9c, 0xc88, 0xc4c}}*/
u32 rx_iqc_8710b[2][2][2]; /* { {S1: 0xc14, 0xca0} , {S0: 0xc14, 0xca0}}*/
u64 iqk_start_time;
u64 iqk_total_progressing_time;
u64 iqk_progressing_time;
u64 lck_progressing_time;
u32 lok_result;
u8 iqk_step;
u8 kcount;
u8 retry_count[4][2]; /* [4]: path ABCD, [2] TXK, RXK */
boolean is_mp_mode;
/* for APK */
u32 ap_koutput[2][2]; /* path A/B; output1_1a/output1_2a */
u8 is_ap_kdone;
u8 is_apk_thermal_meter_ignore;
/* DPK */
boolean is_dpk_fail;
u8 is_dp_done;
u8 is_dp_path_aok;
u8 is_dp_path_bok;
u32 tx_lok[2];
u32 dpk_tx_agc;
s32 dpk_gain;
u32 dpk_thermal[4];
s8 modify_tx_agc_value_ofdm;
s8 modify_tx_agc_value_cck;
/*Add by Yuchen for Kfree Phydm*/
u8 reg_rf_kfree_enable; /*for registry*/
u8 rf_kfree_enable; /*for efuse enable check*/
};
#endif /*#ifndef __HALRF_POWER_TRACKING_H__*/
================================================
FILE: hal/phydm/halrf/halrf_psd.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
/*@===========================================================
* include files
*============================================================
*/
#include "mp_precomp.h"
#include "phydm_precomp.h"
u64 _sqrt(u64 x)
{
u64 i = 0;
u64 j = (x >> 1) + 1;
while (i <= j) {
u64 mid = (i + j) >> 1;
u64 sq = mid * mid;
if (sq == x)
return mid;
else if (sq < x)
i = mid + 1;
else
j = mid - 1;
}
return j;
}
u32 halrf_get_psd_data(
struct dm_struct *dm,
u32 point)
{
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
u32 psd_val = 0, psd_reg, psd_report, psd_point, psd_start, i, delay_time = 0;
#if (DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO) {
if (psd->average == 0)
delay_time = 100;
else
delay_time = 0;
}
#endif
#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
if (dm->support_interface == ODM_ITRF_PCIE) {
if (psd->average == 0)
delay_time = 1000;
else
delay_time = 100;
}
#endif
if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C)) {
psd_reg = R_0x910;
psd_report = R_0xf44;
} else {
psd_reg = R_0x808;
psd_report = R_0x8b4;
}
if (dm->support_ic_type & ODM_RTL8710B) {
psd_point = 0xeffffc00;
psd_start = 0x10000000;
} else {
psd_point = 0xffbffc00;
psd_start = 0x00400000;
}
psd_val = odm_get_bb_reg(dm, psd_reg, MASKDWORD);
psd_val &= psd_point;
psd_val |= point;
odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
psd_val |= psd_start;
odm_set_bb_reg(dm, psd_reg, MASKDWORD, psd_val);
for (i = 0; i < delay_time; i++)
ODM_delay_us(1);
psd_val = odm_get_bb_reg(dm, psd_report, MASKDWORD);
if (dm->support_ic_type & (ODM_RTL8821C | ODM_RTL8710B)) {
psd_val &= MASKL3BYTES;
psd_val = psd_val / 32;
} else {
psd_val &= MASKLWORD;
}
return psd_val;
}
void halrf_psd(
struct dm_struct *dm,
u32 point,
u32 start_point,
u32 stop_point,
u32 average)
{
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
u32 i = 0, j = 0, k = 0;
u32 psd_reg, avg_org, point_temp, average_tmp, mode;
u64 data_tatal = 0, data_temp[64] = {0};
psd->buf_size = 256;
mode = average >> 16;
if (mode == 2)
average_tmp = 1;
else
average_tmp = average & 0xffff;
if (dm->support_ic_type & (ODM_RTL8812 | ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B | ODM_RTL8821C))
psd_reg = R_0x910;
else
psd_reg = R_0x808;
#if 0
dbg_print("[PSD]point=%d, start_point=%d, stop_point=%d, average=%d, average_tmp=%d, buf_size=%d\n",
point, start_point, stop_point, average, average_tmp, psd->buf_size);
#endif
for (i = 0; i < psd->buf_size; i++)
psd->psd_data[i] = 0;
if (dm->support_ic_type & ODM_RTL8710B)
avg_org = odm_get_bb_reg(dm, psd_reg, 0x30000);
else
avg_org = odm_get_bb_reg(dm, psd_reg, 0x3000);
if (mode == 1) {
if (dm->support_ic_type & ODM_RTL8710B)
odm_set_bb_reg(dm, psd_reg, 0x30000, 0x1);
else
odm_set_bb_reg(dm, psd_reg, 0x3000, 0x1);
}
#if 0
if (avg_temp == 0)
avg = 1;
else if (avg_temp == 1)
avg = 8;
else if (avg_temp == 2)
avg = 16;
else if (avg_temp == 3)
avg = 32;
#endif
i = start_point;
while (i < stop_point) {
data_tatal = 0;
if (i >= point)
point_temp = i - point;
else
point_temp = i;
for (k = 0; k < average_tmp; k++) {
data_temp[k] = halrf_get_psd_data(dm, point_temp);
data_tatal = data_tatal + (data_temp[k] * data_temp[k]);
#if 0
if ((k % 20) == 0)
dbg_print("\n ");
dbg_print("0x%x ", data_temp[k]);
#endif
}
#if 0
/*dbg_print("\n");*/
#endif
data_tatal = phydm_division64((data_tatal * 100), average_tmp);
psd->psd_data[j] = (u32)_sqrt(data_tatal);
i++;
j++;
}
#if 0
for (i = 0; i < psd->buf_size; i++) {
if ((i % 20) == 0)
dbg_print("\n ");
dbg_print("0x%x ", psd->psd_data[i]);
}
dbg_print("\n\n");
#endif
if (dm->support_ic_type & ODM_RTL8710B)
odm_set_bb_reg(dm, psd_reg, 0x30000, avg_org);
else
odm_set_bb_reg(dm, psd_reg, 0x3000, avg_org);
}
void backup_bb_register(struct dm_struct *dm, u32 *bb_backup, u32 *backup_bb_reg, u32 counter)
{
u32 i ;
for (i = 0; i < counter; i++)
bb_backup[i] = odm_get_bb_reg(dm, backup_bb_reg[i], MASKDWORD);
}
void restore_bb_register(struct dm_struct *dm, u32 *bb_backup, u32 *backup_bb_reg, u32 counter)
{
u32 i ;
for (i = 0; i < counter; i++)
odm_set_bb_reg(dm, backup_bb_reg[i], MASKDWORD, bb_backup[i]);
}
void _halrf_psd_iqk_init(struct dm_struct *dm)
{
odm_set_bb_reg(dm, 0x1b04, MASKDWORD, 0x0);
odm_set_bb_reg(dm, 0x1b08, MASKDWORD, 0x80);
odm_set_bb_reg(dm, 0x1b0c, 0xc00, 0x3);
odm_set_bb_reg(dm, 0x1b14, MASKDWORD, 0x0);
odm_set_bb_reg(dm, 0x1b18, BIT(0), 0x1);
if (dm->support_ic_type & ODM_RTL8197G)
odm_set_bb_reg(dm, 0x1b20, MASKDWORD, 0x00040008);
if (dm->support_ic_type & ODM_RTL8198F) {
odm_set_bb_reg(dm, 0x1b20, MASKDWORD, 0x00000000);
odm_set_bb_reg(dm, 0x1b1c, 0xfff, 0xd21);
odm_set_bb_reg(dm, 0x1b1c, 0xfff00000, 0x821);
}
if (dm->support_ic_type & (ODM_RTL8197G | ODM_RTL8198F)) {
odm_set_bb_reg(dm, 0x1b24, MASKDWORD, 0x00030000);
odm_set_bb_reg(dm, 0x1b28, MASKDWORD, 0x00000000);
odm_set_bb_reg(dm, 0x1b2c, MASKDWORD, 0x00180018);
odm_set_bb_reg(dm, 0x1b30, MASKDWORD, 0x20000000);
/*odm_set_bb_reg(dm, 0x1b38, MASKDWORD, 0x20000000);*/
/*odm_set_bb_reg(dm, 0x1b3C, MASKDWORD, 0x20000000);*/
}
odm_set_bb_reg(dm, 0x1b28, MASKDWORD, 0x0);
odm_set_bb_reg(dm, 0x1bcc, 0x3f, 0x3f);
}
u32 halrf_get_iqk_psd_data(
struct dm_struct *dm,
u32 point)
{
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
u32 psd_val, psd_val1, psd_val2, psd_point, i, delay_time = 0;
#if (DEV_BUS_TYPE == RT_USB_INTERFACE) || (DEV_BUS_TYPE == RT_SDIO_INTERFACE)
if (dm->support_interface == ODM_ITRF_USB || dm->support_interface == ODM_ITRF_SDIO) {
if (dm->support_ic_type & ODM_RTL8822C)
delay_time = 1000;
else
delay_time = 0;
}
#endif
#if (DEV_BUS_TYPE == RT_PCI_INTERFACE)
if (dm->support_interface == ODM_ITRF_PCIE) {
if (dm->support_ic_type & ODM_RTL8822C)
delay_time = 1000;
else
delay_time = 150;
}
#endif
psd_point = odm_get_bb_reg(dm, R_0x1b2c, MASKDWORD);
psd_point &= 0xF000FFFF;
point &= 0xFFF;
psd_point = psd_point | (point << 16);
odm_set_bb_reg(dm, R_0x1b2c, MASKDWORD, psd_point);
odm_set_bb_reg(dm, R_0x1b34, MASKDWORD, 0x1);
odm_set_bb_reg(dm, R_0x1b34, MASKDWORD, 0x0);
for (i = 0; i < delay_time; i++)
ODM_delay_us(1);
if (dm->support_ic_type & (ODM_RTL8197G | ODM_RTL8198F)) {
if (dm->support_ic_type & ODM_RTL8197G)
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x001a0001);
else
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x00250001);
psd_val1 = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
psd_val1 = (psd_val1 & 0x001f0000) >> 16;
if (dm->support_ic_type & ODM_RTL8197G)
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x001b0001);
else
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x002e0001);
psd_val2 = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
psd_val = (psd_val1 << 27) + (psd_val2 >> 5);
} else {
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x00250001);
psd_val1 = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
psd_val1 = (psd_val1 & 0x07FF0000) >> 16;
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x002e0001);
psd_val2 = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
psd_val = (psd_val1 << 21) + (psd_val2 >> 11);
}
return psd_val;
}
void halrf_iqk_psd(
struct dm_struct *dm,
u32 point,
u32 start_point,
u32 stop_point,
u32 average)
{
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
u32 i = 0, j = 0, k = 0;
u32 psd_reg, avg_org, point_temp, average_tmp = 32, mode, reg_tmp = 5;
u64 data_tatal = 0, data_temp[64] = {0};
s32 s_point_tmp;
psd->buf_size = 256;
mode = average >> 16;
if (mode == 2) {
if (dm->support_ic_type & ODM_RTL8822C)
average_tmp = 1;
else {
reg_tmp = odm_get_bb_reg(dm, R_0x1b1c, 0x000e0000);
if (reg_tmp == 0)
average_tmp = 1;
else if (reg_tmp == 3)
average_tmp = 8;
else if (reg_tmp == 4)
average_tmp = 16;
else if (reg_tmp == 5)
average_tmp = 32;
odm_set_bb_reg(dm, R_0x1b1c, 0x000e0000, 0x0);
}
} else {
reg_tmp = odm_get_bb_reg(dm, R_0x1b1c, 0x000e0000);
if (reg_tmp == 0)
average_tmp = 1;
else if (reg_tmp == 3)
average_tmp = 8;
else if (reg_tmp == 4)
average_tmp = 16;
else if (reg_tmp == 5)
average_tmp = 32;
odm_set_bb_reg(dm, R_0x1b1c, 0x000e0000, 0x0);
}
#if 0
DbgPrint("[PSD]point=%d, start_point=%d, stop_point=%d, average=0x%x, average_tmp=%d, buf_size=%d, mode=%d\n",
point, start_point, stop_point, average, average_tmp, psd->buf_size, mode);
#endif
for (i = 0; i < psd->buf_size; i++)
psd->psd_data[i] = 0;
i = start_point;
while (i < stop_point) {
data_tatal = 0;
if (i >= point)
point_temp = i - point;
else
{
if (dm->support_ic_type & ODM_RTL8814B)
{
s_point_tmp = i - point - 1;
point_temp = s_point_tmp & 0xfff;
}
else
point_temp = i;
}
for (k = 0; k < average_tmp; k++) {
data_temp[k] = halrf_get_iqk_psd_data(dm, point_temp);
/*data_tatal = data_tatal + (data_temp[k] * data_temp[k]);*/
data_tatal = data_tatal + data_temp[k];
#if 0
if ((k % 20) == 0)
DbgPrint("\n ");
DbgPrint("0x%x ", data_temp[k]);
#endif
}
data_tatal = phydm_division64((data_tatal * 10), average_tmp);
psd->psd_data[j] = (u32)data_tatal;
i++;
j++;
}
if (dm->support_ic_type & (ODM_RTL8814B | ODM_RTL8198F | ODM_RTL8197G))
odm_set_bb_reg(dm, R_0x1b1c, 0x000e0000, reg_tmp);
#if 0
DbgPrint("\n [iqk psd]psd result:\n");
for (i = 0; i < psd->buf_size; i++) {
if ((i % 20) == 0)
DbgPrint("\n ");
DbgPrint("0x%x ", psd->psd_data[i]);
}
DbgPrint("\n\n");
#endif
}
u32
halrf_psd_init(
void *dm_void)
{
enum rt_status ret_status = RT_STATUS_SUCCESS;
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
#if 0
u32 bb_backup[12];
u32 backup_bb_reg[12] = {0x1b04, 0x1b08, 0x1b0c, 0x1b14, 0x1b18,
0x1b1c, 0x1b28, 0x1bcc, 0x1b2c, 0x1b34,
0x1bd4, 0x1bfc};
#endif
if (psd->psd_progress) {
ret_status = RT_STATUS_PENDING;
} else {
psd->psd_progress = 1;
if (dm->support_ic_type & (ODM_RTL8822C | ODM_RTL8814B | ODM_RTL8198F | ODM_RTL8197G)) {
/*backup_bb_register(dm, bb_backup, backup_bb_reg, 12);*/
_halrf_psd_iqk_init(dm);
halrf_iqk_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
/*restore_bb_register(dm, bb_backup, backup_bb_reg, 12);*/
} else
halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
psd->psd_progress = 0;
}
return ret_status;
}
u32
halrf_psd_query(
void *dm_void,
u32 *outbuf,
u32 buf_size)
{
enum rt_status ret_status = RT_STATUS_SUCCESS;
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
if (psd->psd_progress)
ret_status = RT_STATUS_PENDING;
else
odm_move_memory(dm, outbuf, psd->psd_data,
sizeof(u32) * psd->buf_size);
return ret_status;
}
u32
halrf_psd_init_query(
void *dm_void,
u32 *outbuf,
u32 point,
u32 start_point,
u32 stop_point,
u32 average,
u32 buf_size)
{
enum rt_status ret_status = RT_STATUS_SUCCESS;
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &(dm->rf_table);
struct _halrf_psd_data *psd = &(rf->halrf_psd_data);
psd->point = point;
psd->start_point = start_point;
psd->stop_point = stop_point;
psd->average = average;
if (psd->psd_progress) {
ret_status = RT_STATUS_PENDING;
} else {
psd->psd_progress = 1;
halrf_psd(dm, psd->point, psd->start_point, psd->stop_point, psd->average);
odm_move_memory(dm, outbuf, psd->psd_data, 0x400);
psd->psd_progress = 0;
}
return ret_status;
}
================================================
FILE: hal/phydm/halrf/halrf_psd.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef __HALRF_PSD_H__
#define __HALRF_PSD_H__
struct _halrf_psd_data {
u32 point;
u32 start_point;
u32 stop_point;
u32 average;
u32 buf_size;
u32 psd_data[256];
u32 psd_progress;
};
u32
halrf_psd_init(
void *dm_void);
u32
halrf_psd_query(
void *dm_void,
u32 *outbuf,
u32 buf_size);
u32
halrf_psd_init_query(
void *dm_void,
u32 *outbuf,
u32 point,
u32 start_point,
u32 stop_point,
u32 average,
u32 buf_size);
#endif /*#__HALRF_PSD_H__*/
================================================
FILE: hal/phydm/halrf/halrf_txgapcal.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#include "mp_precomp.h"
#include "phydm_precomp.h"
void odm_bub_sort(u32 *data, u32 n)
{
int i, j, temp, sp;
for (i = n - 1; i >= 0; i--) {
sp = 1;
for (j = 0; j < i; j++) {
if (data[j] < data[j + 1]) {
temp = data[j];
data[j] = data[j + 1];
data[j + 1] = temp;
sp = 0;
}
}
if (sp == 1)
break;
}
}
#if (RTL8197F_SUPPORT == 1)
u4Byte
odm_tx_gain_gap_psd_8197f(
void *dm_void,
u1Byte rf_path,
u4Byte rf56)
{
PDM_ODM_T dm = (PDM_ODM_T)dm_void;
u1Byte i, j;
u4Byte psd_vaule[5], psd_avg_time = 5, psd_vaule_temp;
u4Byte iqk_ctl_addr[2][6] = {{0xe30, 0xe34, 0xe50, 0xe54, 0xe38, 0xe3c},
{0xe50, 0xe54, 0xe30, 0xe34, 0xe58, 0xe5c}};
u4Byte psd_finish_bit[2] = {0x04000000, 0x20000000};
u4Byte psd_fail_bit[2] = {0x08000000, 0x40000000};
u4Byte psd_cntl_value[2][2] = {{0x38008c1c, 0x10008c1c},
{0x38008c2c, 0x10008c2c}};
u4Byte psd_report_addr[2] = {0xea0, 0xec0};
odm_set_rf_reg(dm, rf_path, RF_0xdf, bRFRegOffsetMask, 0x00e02);
ODM_delay_us(100);
odm_set_bb_reg(dm, R_0xe28, 0xffffffff, 0x0);
odm_set_rf_reg(dm, rf_path, RF_0x56, 0xfff, rf56);
while (rf56 != (odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff)))
odm_set_rf_reg(dm, rf_path, RF_0x56, 0xfff, rf56);
odm_set_bb_reg(dm, R_0xd94, 0xffffffff, 0x44FFBB44);
odm_set_bb_reg(dm, R_0xe70, 0xffffffff, 0x00400040);
odm_set_bb_reg(dm, R_0xc04, 0xffffffff, 0x6f005403);
odm_set_bb_reg(dm, R_0xc08, 0xffffffff, 0x000804e4);
odm_set_bb_reg(dm, R_0x874, 0xffffffff, 0x04203400);
odm_set_bb_reg(dm, R_0xe28, 0xffffffff, 0x80800000);
odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][0], 0xffffffff, psd_cntl_value[rf_path][0]);
odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][1], 0xffffffff, psd_cntl_value[rf_path][1]);
odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][2], 0xffffffff, psd_cntl_value[rf_path][0]);
odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][3], 0xffffffff, psd_cntl_value[rf_path][0]);
odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][4], 0xffffffff, 0x8215001F);
odm_set_bb_reg(dm, iqk_ctl_addr[rf_path][5], 0xffffffff, 0x2805001F);
odm_set_bb_reg(dm, R_0xe40, 0xffffffff, 0x81007C00);
odm_set_bb_reg(dm, R_0xe44, 0xffffffff, 0x81004800);
odm_set_bb_reg(dm, R_0xe4c, 0xffffffff, 0x0046a8d0);
for (i = 0; i < psd_avg_time; i++) {
for (j = 0; j < 1000; j++) {
odm_set_bb_reg(dm, R_0xe48, 0xffffffff, 0xfa005800);
odm_set_bb_reg(dm, R_0xe48, 0xffffffff, 0xf8005800);
while (!odm_get_bb_reg(dm, R_0xeac, psd_finish_bit[rf_path]))
; /*wait finish bit*/
if (!odm_get_bb_reg(dm, R_0xeac, psd_fail_bit[rf_path])) { /*check fail bit*/
psd_vaule[i] = odm_get_bb_reg(dm, psd_report_addr[rf_path], 0xffffffff);
if (psd_vaule[i] > 0xffff)
break;
}
}
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x time=%d psd_vaule=0x%x\n",
odm_get_rf_reg(dm, rf_path, RF_0x0, 0xff), rf56,
odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff), j,
psd_vaule[i]);
}
odm_bub_sort(psd_vaule, psd_avg_time);
psd_vaule_temp = psd_vaule[(UINT)(psd_avg_time / 2)];
odm_set_bb_reg(dm, R_0xd94, 0xffffffff, 0x44BBBB44);
odm_set_bb_reg(dm, R_0xe70, 0xffffffff, 0x80408040);
odm_set_bb_reg(dm, R_0xc04, 0xffffffff, 0x6f005433);
odm_set_bb_reg(dm, R_0xc08, 0xffffffff, 0x000004e4);
odm_set_bb_reg(dm, R_0x874, 0xffffffff, 0x04003400);
odm_set_bb_reg(dm, R_0xe28, 0xffffffff, 0x00000000);
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] rf0=0x%x rf56=0x%x rf56_reg=0x%x psd_vaule_temp=0x%x\n",
odm_get_rf_reg(dm, rf_path, RF_0x0, 0xff), rf56,
odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff), psd_vaule_temp);
odm_set_rf_reg(dm, rf_path, RF_0xdf, bRFRegOffsetMask, 0x00602);
return psd_vaule_temp;
}
void odm_tx_gain_gap_calibration_8197f(
void *dm_void)
{
PDM_ODM_T dm = (PDM_ODM_T)dm_void;
u1Byte rf_path, rf0_idx, rf0_idx_current, rf0_idx_next, i, delta_gain_retry = 3;
s1Byte delta_gain_gap_pre, delta_gain_gap[2][11];
u4Byte rf56_current, rf56_next, psd_value_current, psd_value_next;
u4Byte psd_gap, rf56_current_temp[2][11];
s4Byte rf33[2][11];
memset(rf33, 0x0, sizeof(rf33));
for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
if (rf_path == RF_PATH_A)
odm_set_bb_reg(dm, R_0x88c, (BIT(21) | BIT(20)), 0x3); /*disable 3-wire*/
else if (rf_path == RF_PATH_B)
odm_set_bb_reg(dm, R_0x88c, (BIT(23) | BIT(22)), 0x3); /*disable 3-wire*/
ODM_delay_us(100);
for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
rf0_idx_current = 3 * (rf0_idx - 1) + 1;
odm_set_rf_reg(dm, rf_path, RF_0x0, 0xff, rf0_idx_current);
ODM_delay_us(100);
rf56_current_temp[rf_path][rf0_idx] = odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff);
rf56_current = rf56_current_temp[rf_path][rf0_idx];
rf0_idx_next = 3 * rf0_idx + 1;
odm_set_rf_reg(dm, rf_path, RF_0x0, 0xff, rf0_idx_next);
ODM_delay_us(100);
rf56_next = odm_get_rf_reg(dm, rf_path, RF_0x56, 0xfff);
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] rf56_current[%d][%d]=0x%x rf56_next[%d][%d]=0x%x\n",
rf_path, rf0_idx, rf56_current, rf_path, rf0_idx,
rf56_next);
if ((rf56_current >> 5) == (rf56_next >> 5)) {
delta_gain_gap[rf_path][rf0_idx] = 0;
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] rf56_current[11:5] == rf56_next[%d][%d][11:5]=0x%x delta_gain_gap[%d][%d]=%d\n",
rf_path, rf0_idx, (rf56_next >> 5),
rf_path, rf0_idx,
delta_gain_gap[rf_path][rf0_idx]);
continue;
}
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] rf56_current[%d][%d][11:5]=0x%x != rf56_next[%d][%d][11:5]=0x%x\n",
rf_path, rf0_idx, (rf56_current >> 5), rf_path,
rf0_idx, (rf56_next >> 5));
for (i = 0; i < delta_gain_retry; i++) {
psd_value_current = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_current);
psd_value_next = odm_tx_gain_gap_psd_8197f(dm, rf_path, rf56_next - 2);
psd_gap = psd_value_next / (psd_value_current / 1000);
#if 0
if (psd_gap > 1413)
delta_gain_gap[rf_path][rf0_idx] = 1;
else if (psd_gap > 1122)
delta_gain_gap[rf_path][rf0_idx] = 0;
else
delta_gain_gap[rf_path][rf0_idx] = -1;
#endif
if (psd_gap > 1445)
delta_gain_gap[rf_path][rf0_idx] = 1;
else if (psd_gap > 1096)
delta_gain_gap[rf_path][rf0_idx] = 0;
else
delta_gain_gap[rf_path][rf0_idx] = -1;
if (i == 0)
delta_gain_gap_pre = delta_gain_gap[rf_path][rf0_idx];
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] psd_value_current=0x%x psd_value_next=0x%x psd_value_next/psd_value_current=%d delta_gain_gap[%d][%d]=%d\n",
psd_value_current, psd_value_next,
psd_gap, rf_path, rf0_idx,
delta_gain_gap[rf_path][rf0_idx]);
if (i == 0 && delta_gain_gap[rf_path][rf0_idx] == 0)
break;
if (delta_gain_gap_pre != delta_gain_gap[rf_path][rf0_idx]) {
delta_gain_gap[rf_path][rf0_idx] = 0;
RF_DBG(dm, DBG_RF_IQK, "[TGGC] delta_gain_gap_pre(%d) != delta_gain_gap[%d][%d](%d) time=%d\n",
delta_gain_gap_pre, rf_path, rf0_idx, delta_gain_gap[rf_path][rf0_idx], i);
break;
}
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] delta_gain_gap_pre(%d) == delta_gain_gap[%d][%d](%d) time=%d\n",
delta_gain_gap_pre, rf_path, rf0_idx,
delta_gain_gap[rf_path][rf0_idx], i);
}
}
if (rf_path == RF_PATH_A)
odm_set_bb_reg(dm, R_0x88c, (BIT(21) | BIT(20)), 0x0); /*enable 3-wire*/
else if (rf_path == RF_PATH_B)
odm_set_bb_reg(dm, R_0x88c, (BIT(23) | BIT(22)), 0x0); /*enable 3-wire*/
ODM_delay_us(100);
}
#if 0
/*odm_set_bb_reg(dm, R_0x88c, (BIT(23) | BIT(22) | BIT(21) | BIT(20)), 0x0);*/ /*enable 3-wire*/
#endif
for (rf_path = RF_PATH_A; rf_path <= RF_PATH_B; rf_path++) {
odm_set_rf_reg(dm, rf_path, RF_0xef, bRFRegOffsetMask, 0x00100);
for (rf0_idx = 1; rf0_idx <= 10; rf0_idx++) {
rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + (rf56_current_temp[rf_path][rf0_idx] & 0x1f);
for (i = rf0_idx; i <= 10; i++)
rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + delta_gain_gap[rf_path][i];
if (rf33[rf_path][rf0_idx] >= 0x1d)
rf33[rf_path][rf0_idx] = 0x1d;
else if (rf33[rf_path][rf0_idx] <= 0x2)
rf33[rf_path][rf0_idx] = 0x2;
rf33[rf_path][rf0_idx] = rf33[rf_path][rf0_idx] + ((rf0_idx - 1) * 0x4000) + (rf56_current_temp[rf_path][rf0_idx] & 0xfffe0);
RF_DBG(dm, DBG_RF_IQK,
"[TGGC] rf56[%d][%d]=0x%05x rf33[%d][%d]=0x%05x\n",
rf_path, rf0_idx,
rf56_current_temp[rf_path][rf0_idx], rf_path,
rf0_idx, rf33[rf_path][rf0_idx]);
odm_set_rf_reg(dm, rf_path, RF_0x33, bRFRegOffsetMask, rf33[rf_path][rf0_idx]);
}
odm_set_rf_reg(dm, rf_path, RF_0xef, bRFRegOffsetMask, 0x00000);
}
}
#endif
void odm_tx_gain_gap_calibration(void *dm_void)
{
PDM_ODM_T dm = (PDM_ODM_T)dm_void;
#if (RTL8197F_SUPPORT == 1)
if (dm->SupportICType & ODM_RTL8197F)
odm_tx_gain_gap_calibration_8197f(dm_void);
#endif
}
================================================
FILE: hal/phydm/halrf/halrf_txgapcal.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_TXGAPCAL_H__
#define __HALRF_TXGAPCAL_H__
void odm_tx_gain_gap_calibration(void *dm_void);
#endif /*__HALRF_TXGAPCAL_H__*/
================================================
FILE: hal/phydm/halrf/rtl8822c/halhwimg8822c_rf.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*Image2HeaderVersion: R3 1.5.8*/
#include "mp_precomp.h"
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
#if RT_PLATFORM == PLATFORM_MACOSX
#include "phydm_precomp.h"
#else
#include "../phydm_precomp.h"
#endif
#else
#include "../../phydm_precomp.h"
#endif
#define D_S_SIZE DELTA_SWINGIDX_SIZE
#define D_ST_SIZE DELTA_SWINTSSI_SIZE
#if (RTL8822C_SUPPORT == 1)
static boolean
check_positive(struct dm_struct *dm,
const u32 condition1,
const u32 condition2,
const u32 condition3,
const u32 condition4
)
{
u32 cond1 = condition1, cond2 = condition2,
cond3 = condition3, cond4 = condition4;
u8 cut_version_for_para =
(dm->cut_version == ODM_CUT_A) ? 15 : dm->cut_version;
u8 pkg_type_for_para =
(dm->package_type == 0) ? 15 : dm->package_type;
u32 driver1 = cut_version_for_para << 24 |
(dm->support_interface & 0xF0) << 16 |
dm->support_platform << 16 |
pkg_type_for_para << 12 |
(dm->support_interface & 0x0F) << 8 |
dm->rfe_type;
u32 driver2 = (dm->type_glna & 0xFF) << 0 |
(dm->type_gpa & 0xFF) << 8 |
(dm->type_alna & 0xFF) << 16 |
(dm->type_apa & 0xFF) << 24;
u32 driver3 = 0;
u32 driver4 = (dm->type_glna & 0xFF00) >> 8 |
(dm->type_gpa & 0xFF00) |
(dm->type_alna & 0xFF00) << 8 |
(dm->type_apa & 0xFF00) << 16;
PHYDM_DBG(dm, ODM_COMP_INIT,
"===> %s (cond1, cond2, cond3, cond4) = (0x%X 0x%X 0x%X 0x%X)\n",
__func__, cond1, cond2, cond3, cond4);
PHYDM_DBG(dm, ODM_COMP_INIT,
"===> %s (driver1, driver2, driver3, driver4) = (0x%X 0x%X 0x%X 0x%X)\n",
__func__, driver1, driver2, driver3, driver4);
PHYDM_DBG(dm, ODM_COMP_INIT,
" (Platform, Interface) = (0x%X, 0x%X)\n",
dm->support_platform, dm->support_interface);
PHYDM_DBG(dm, ODM_COMP_INIT, " (RFE, Package) = (0x%X, 0x%X)\n",
dm->rfe_type, dm->package_type);
/*============== value Defined Check ===============*/
/*cut version [27:24] need to do value check*/
if (((cond1 & 0x0F000000) != 0) &&
((cond1 & 0x0F000000) != (driver1 & 0x0F000000)))
return false;
/*pkg type [15:12] need to do value check*/
if (((cond1 & 0x0000F000) != 0) &&
((cond1 & 0x0000F000) != (driver1 & 0x0000F000)))
return false;
/*interface [11:8] need to do value check*/
if (((cond1 & 0x00000F00) != 0) &&
((cond1 & 0x00000F00) != (driver1 & 0x00000F00)))
return false;
/*=============== Bit Defined Check ================*/
/* We don't care [31:28] */
cond1 &= 0x000000FF;
driver1 &= 0x000000FF;
if (cond1 == driver1)
return true;
else
return false;
}
/******************************************************************************
* radioa.TXT
******************************************************************************/
const u32 array_mp_8822c_radioa[] = {
0x000, 0x00030000,
0x018, 0x00013124,
0x093, 0x0008483F,
0x0DE, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000B9140,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000B9140,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0xA0000000, 0x00000000,
0x08E, 0x000A5540,
0xB0000000, 0x00000000,
0x081, 0x0000FC01,
0x081, 0x0002FC01,
0x081, 0x0003FC01,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x085, 0x0006A06C,
0xA0000000, 0x00000000,
0x085, 0x0006A06C,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0xA0000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000003F,
0x033, 0x00000001,
0x03F, 0x0000003F,
0x033, 0x00000002,
0x03F, 0x0000003F,
0x0EE, 0x00000000,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x00000287,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000207,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x00000287,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000207,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773E8,
0x033, 0x0000000E,
0x03F, 0x000FF3A0,
0x033, 0x0000000D,
0x03F, 0x00000380,
0x033, 0x0000000C,
0x03F, 0x000FF380,
0x033, 0x0000000B,
0x03F, 0x00000300,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000003,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x00000287,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000207,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x00000287,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000207,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773E8,
0x033, 0x0000001E,
0x03F, 0x000FF3A0,
0x033, 0x0000001D,
0x03F, 0x00000380,
0x033, 0x0000001C,
0x03F, 0x000FF380,
0x033, 0x0000001B,
0x03F, 0x00000300,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000013,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x00000287,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000207,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x00000287,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000207,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773E8,
0x033, 0x0000002E,
0x03F, 0x000FF3A0,
0x033, 0x0000002D,
0x03F, 0x00000380,
0x033, 0x0000002C,
0x03F, 0x000FF380,
0x033, 0x0000002B,
0x03F, 0x00000300,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000023,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x00000287,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000207,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x00000287,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000207,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773E8,
0x033, 0x0000003E,
0x03F, 0x000FF3A0,
0x033, 0x0000003D,
0x03F, 0x00000380,
0x033, 0x0000003C,
0x03F, 0x000FF380,
0x033, 0x0000003B,
0x03F, 0x00000300,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000033,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x00000287,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000207,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x00000287,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000207,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773E8,
0x033, 0x0000004E,
0x03F, 0x000FF3A0,
0x033, 0x0000004D,
0x03F, 0x00000380,
0x033, 0x0000004C,
0x03F, 0x000FF380,
0x033, 0x0000004B,
0x03F, 0x00000300,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000043,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x00000287,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000207,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x00000287,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000207,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773E8,
0x033, 0x0000005E,
0x03F, 0x000FF3A0,
0x033, 0x0000005D,
0x03F, 0x00000380,
0x033, 0x0000005C,
0x03F, 0x000FF380,
0x033, 0x0000005B,
0x03F, 0x00000300,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000053,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0xA0000000, 0x00000000,
0x0EF, 0x00000000,
0xB0000000, 0x00000000,
0x08A, 0x000E7DE3,
0x08B, 0x0008FE00,
0x0EE, 0x00000008,
0x033, 0x00000000,
0x03F, 0x00000023,
0x033, 0x00000001,
0x03F, 0x00000023,
0x0EE, 0x00000000,
0x0EF, 0x00004000,
0x033, 0x00000000,
0x03F, 0x0000000F,
0x033, 0x00000002,
0x03F, 0x00000000,
0x0EF, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0xA0000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000010,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0xB0000000, 0x00000000,
0x0FE, 0x00000000,
0x01B, 0x00003A40,
0x061, 0x0000D233,
0x062, 0x0004D232,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0xA0000000, 0x00000000,
0x063, 0x00000C02,
0xB0000000, 0x00000000,
0x0EF, 0x00000200,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000238,
0x030, 0x00001238,
0x030, 0x00002238,
0x030, 0x00003238,
0x030, 0x00004228,
0x030, 0x00005238,
0x030, 0x00006238,
0x030, 0x00007238,
0x030, 0x00008228,
0x030, 0x00009238,
0x030, 0x0000A238,
0x030, 0x0000B238,
0x030, 0x0000C238,
0x030, 0x0000D238,
0x030, 0x0000E228,
0x030, 0x0000F238,
0x030, 0x00010238,
0x030, 0x00011238,
0x030, 0x00012228,
0x030, 0x00013238,
0x030, 0x00014238,
0x030, 0x00015238,
0x030, 0x00016228,
0x030, 0x00017238,
0x030, 0x00018228,
0x030, 0x00019238,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000238,
0x030, 0x00001238,
0x030, 0x00002238,
0x030, 0x00003238,
0x030, 0x00004228,
0x030, 0x00005238,
0x030, 0x00006238,
0x030, 0x00007238,
0x030, 0x00008228,
0x030, 0x00009238,
0x030, 0x0000A238,
0x030, 0x0000B238,
0x030, 0x0000C238,
0x030, 0x0000D238,
0x030, 0x0000E228,
0x030, 0x0000F238,
0x030, 0x00010238,
0x030, 0x00011238,
0x030, 0x00012228,
0x030, 0x00013238,
0x030, 0x00014238,
0x030, 0x00015238,
0x030, 0x00016228,
0x030, 0x00017238,
0x030, 0x00018228,
0x030, 0x00019238,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000239,
0x030, 0x00001239,
0x030, 0x00002239,
0x030, 0x00003239,
0x030, 0x00004239,
0x030, 0x00005239,
0x030, 0x00006239,
0x030, 0x00007239,
0x030, 0x00008239,
0x030, 0x00009239,
0x030, 0x0000A239,
0x030, 0x0000B239,
0x030, 0x0000C239,
0x030, 0x0000D239,
0x030, 0x0000E209,
0x030, 0x0000F239,
0x030, 0x00010239,
0x030, 0x00011239,
0x030, 0x00012209,
0x030, 0x00013239,
0x030, 0x00014239,
0x030, 0x00015239,
0x030, 0x00016209,
0x030, 0x00017239,
0x030, 0x00018209,
0x030, 0x00019239,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000239,
0x030, 0x00001239,
0x030, 0x00002239,
0x030, 0x00003239,
0x030, 0x00004239,
0x030, 0x00005239,
0x030, 0x00006239,
0x030, 0x00007239,
0x030, 0x00008239,
0x030, 0x00009239,
0x030, 0x0000A239,
0x030, 0x0000B239,
0x030, 0x0000C239,
0x030, 0x0000D239,
0x030, 0x0000E209,
0x030, 0x0000F239,
0x030, 0x00010239,
0x030, 0x00011239,
0x030, 0x00012209,
0x030, 0x00013239,
0x030, 0x00014239,
0x030, 0x00015239,
0x030, 0x00016209,
0x030, 0x00017239,
0x030, 0x00018209,
0x030, 0x00019239,
0xA0000000, 0x00000000,
0x030, 0x00000233,
0x030, 0x00001233,
0x030, 0x00002233,
0x030, 0x00003233,
0x030, 0x00004203,
0x030, 0x00005233,
0x030, 0x00006233,
0x030, 0x00007233,
0x030, 0x00008203,
0x030, 0x00009233,
0x030, 0x0000A233,
0x030, 0x0000B233,
0x030, 0x0000C233,
0x030, 0x0000D233,
0x030, 0x0000E203,
0x030, 0x0000F233,
0x030, 0x00010233,
0x030, 0x00011233,
0x030, 0x00012203,
0x030, 0x00013233,
0x030, 0x00014233,
0x030, 0x00015233,
0x030, 0x00016203,
0x030, 0x00017233,
0x030, 0x00018203,
0x030, 0x00019233,
0xB0000000, 0x00000000,
0x0EF, 0x00000000,
0x0EF, 0x00000080,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0xA0000000, 0x00000000,
0x030, 0x00000232,
0x030, 0x00001232,
0x030, 0x00002232,
0x030, 0x00003232,
0x030, 0x00004232,
0x030, 0x00005232,
0x030, 0x00006232,
0x030, 0x00007232,
0x030, 0x00008232,
0x030, 0x00009232,
0x030, 0x0000A232,
0x030, 0x0000B232,
0xB0000000, 0x00000000,
0x0EF, 0x00000000,
0x0EF, 0x00000040,
0x030, 0x00000770,
0x030, 0x00001770,
0x030, 0x00002440,
0x030, 0x00003440,
0x030, 0x00004330,
0x030, 0x00005330,
0x030, 0x00008770,
0x030, 0x0000A440,
0x030, 0x0000C330,
0x0EF, 0x00000000,
0x0EE, 0x00010000,
0x033, 0x00000200,
0x03F, 0x0000006A,
0x033, 0x00000201,
0x03F, 0x0000006D,
0x033, 0x00000202,
0x03F, 0x0000046A,
0x033, 0x00000203,
0x03F, 0x0000086A,
0x033, 0x00000204,
0x03F, 0x00000C89,
0x033, 0x00000205,
0x03F, 0x00000CE8,
0x033, 0x00000206,
0x03F, 0x00000CEB,
0x033, 0x00000207,
0x03F, 0x00000CEE,
0x033, 0x00000208,
0x03F, 0x00000CF1,
0x033, 0x00000209,
0x03F, 0x00000CF4,
0x033, 0x0000020A,
0x03F, 0x00000CF7,
0x033, 0x00000280,
0x03F, 0x0000006A,
0x033, 0x00000281,
0x03F, 0x0000006D,
0x033, 0x00000282,
0x03F, 0x0000046A,
0x033, 0x00000283,
0x03F, 0x0000086A,
0x033, 0x00000284,
0x03F, 0x00000C89,
0x033, 0x00000285,
0x03F, 0x00000CE8,
0x033, 0x00000286,
0x03F, 0x00000CEB,
0x033, 0x00000287,
0x03F, 0x00000CEE,
0x033, 0x00000288,
0x03F, 0x00000CF1,
0x033, 0x00000289,
0x03F, 0x00000CF4,
0x033, 0x0000028A,
0x03F, 0x00000CF7,
0x033, 0x00000300,
0x03F, 0x0000006A,
0x033, 0x00000301,
0x03F, 0x0000006D,
0x033, 0x00000302,
0x03F, 0x0000046A,
0x033, 0x00000303,
0x03F, 0x0000086A,
0x033, 0x00000304,
0x03F, 0x00000C89,
0x033, 0x00000305,
0x03F, 0x00000CE8,
0x033, 0x00000306,
0x03F, 0x00000CEB,
0x033, 0x00000307,
0x03F, 0x00000CEE,
0x033, 0x00000308,
0x03F, 0x00000CF1,
0x033, 0x00000309,
0x03F, 0x00000CF4,
0x033, 0x0000030A,
0x03F, 0x00000CF7,
0x0EE, 0x00000000,
0x051, 0x0003C800,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0xA0000000, 0x00000000,
0x052, 0x000942CA,
0xB0000000, 0x00000000,
0x053, 0x000090F9,
0x054, 0x00088000,
0x057, 0x0004C80A,
0x0EF, 0x00000020,
0x033, 0x00000000,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000001,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000002,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000003,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000004,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000005,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000006,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000007,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000008,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000009,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000000A,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000000B,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000000C,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000000D,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000000E,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00010E46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000000F,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000010,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00028246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000011,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00030246,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000012,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000013,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000014,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000015,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000016,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000017,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000018,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000019,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000001A,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000001B,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000001C,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000001D,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000001E,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000001F,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000020,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000021,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000022,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000023,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000024,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000025,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000026,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000027,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000028,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00025E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x00000029,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00031E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x033, 0x0000002A,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0000EA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00021E46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00021E46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00021E46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00021E46,
0xA0000000, 0x00000000,
0x03F, 0x00002A46,
0xB0000000, 0x00000000,
0x0EF, 0x00000000,
0x0EE, 0x00010000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0xA0000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000487,
0x033, 0x00000061,
0x03F, 0x00000887,
0x033, 0x00000062,
0x03F, 0x00000947,
0x033, 0x00000063,
0x03F, 0x00000D48,
0x033, 0x00000064,
0x03F, 0x00000D88,
0x033, 0x00000065,
0x03F, 0x00000DE8,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0xA0000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000487,
0x033, 0x00000021,
0x03F, 0x00000887,
0x033, 0x00000022,
0x03F, 0x00000947,
0x033, 0x00000023,
0x03F, 0x00000D48,
0x033, 0x00000024,
0x03F, 0x00000D88,
0x033, 0x00000025,
0x03F, 0x00000DE8,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0xB0000000, 0x00000000,
0x0EE, 0x00000000,
0x05C, 0x000FCC00,
0x067, 0x0000A505,
0x0D3, 0x00000542,
0x043, 0x00005000,
0x07F, 0x00000000,
0x0B0, 0x0001F0FC,
0x0B1, 0x0007DBE4,
0x0B2, 0x00022400,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0xA0000000, 0x00000000,
0x0B3, 0x0007C760,
0xB0000000, 0x00000000,
0x0B4, 0x00099D40,
0x0B5, 0x0004103F,
0x83000003, 0x00000000, 0x40000000, 0x00000000,
0x0B6, 0x000387F8,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0B6, 0x000387F8,
0xA0000000, 0x00000000,
0x0B6, 0x000187F8,
0xB0000000, 0x00000000,
0x0B7, 0x00030018,
0x0BC, 0x00000008,
0x0D3, 0x00000542,
0x0DD, 0x00000500,
0x0BB, 0x00040010,
0x0B0, 0x0001F0FA,
0x0FE, 0x00000000,
0x0CA, 0x00080000,
0x0CA, 0x00080001,
0x0FE, 0x00000000,
0x0B0, 0x0001F0F8,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C700,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C700,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C700,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C700,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0xA0000000, 0x00000000,
0x0B3, 0x0007C700,
0xB0000000, 0x00000000,
0x018, 0x0001B124,
0xFFE, 0x00000000,
0xFFE, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x0007C760,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0B3, 0x000FC760,
0xA0000000, 0x00000000,
0x0B3, 0x0007C760,
0xB0000000, 0x00000000,
0x018, 0x00013124,
0x0CC, 0x0000F000,
0x0CD, 0x00089600,
0x018, 0x00013108,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x0B8, 0x000C0440,
0x0BA, 0x000E840D,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x018, 0x00013124,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x059, 0x000A0000,
0x05A, 0x00060000,
0x05B, 0x00014000,
0x0ED, 0x00000008,
0x033, 0x00000001,
0x03F, 0x0000000F,
0x0ED, 0x00000000,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x0DD, 0x00000540,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0DD, 0x00000540,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0DD, 0x00000540,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0DD, 0x00000540,
0xA0000000, 0x00000000,
0x0DD, 0x00000500,
0xB0000000, 0x00000000,
0x0BC, 0x00000004,
0x0EE, 0x00000002,
0x033, 0x00000017,
0x03F, 0x0000003F,
0x033, 0x00000018,
0x03F, 0x0000003F,
0x033, 0x00000019,
0x03F, 0x00000000,
0x033, 0x0000001A,
0x03F, 0x0000003F,
0x033, 0x0000001B,
0x03F, 0x0000003F,
0x033, 0x0000001C,
0x03F, 0x0000003F,
0x0EE, 0x00000000,
0x0ED, 0x00000200,
0x033, 0x00000000,
0x03F, 0x000F45A4,
0x033, 0x00000001,
0x03F, 0x000F49A4,
0x033, 0x00000002,
0x03F, 0x000F49A4,
0x033, 0x00000003,
0x03F, 0x000F69A4,
0x033, 0x00000004,
0x03F, 0x000F69A4,
0x033, 0x00000005,
0x03F, 0x000F69A4,
0x033, 0x00000006,
0x03F, 0x000F6DA4,
0x033, 0x00000007,
0x03F, 0x000F6DA4,
0x033, 0x00000008,
0x03F, 0x000F6DA4,
0x033, 0x00000009,
0x03F, 0x000F8DA4,
0x033, 0x0000000A,
0x03F, 0x000F8DA4,
0x033, 0x0000000B,
0x03F, 0x000F8DA4,
0x033, 0x0000000C,
0x03F, 0x000F91A4,
0x033, 0x0000000D,
0x03F, 0x000F91A4,
0x033, 0x0000000E,
0x03F, 0x000F91A4,
0x033, 0x0000000F,
0x03F, 0x000FB1A4,
0x033, 0x00000010,
0x03F, 0x000FB1A4,
0x033, 0x00000011,
0x03F, 0x000FB1A4,
0x033, 0x00000012,
0x03F, 0x000FB5A4,
0x033, 0x00000013,
0x03F, 0x000FB5A4,
0x033, 0x00000014,
0x03F, 0x000FD9A4,
0x033, 0x00000015,
0x03F, 0x000FD9A4,
0x033, 0x00000016,
0x03F, 0x000FF9A4,
0x033, 0x00000017,
0x03F, 0x000FF9A4,
0x033, 0x00000018,
0x03F, 0x000FFDA4,
0x033, 0x00000019,
0x03F, 0x000FFDA4,
0x033, 0x0000001A,
0x03F, 0x000FFDA4,
0x0ED, 0x00000000,
0x092, 0x00084800,
0x092, 0x00084801,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x092, 0x00084800,
0x08F, 0x00001B4C,
0x088, 0x0004326B,
0x019, 0x00000005,
0x0EF, 0x00080000,
0x033, 0x00000004,
0x03E, 0x00000003,
0x03F, 0x000F60FF,
0x0EF, 0x00000000,
0x0EF, 0x00080000,
0x033, 0x00000006,
0x03E, 0x00000003,
0x03F, 0x000760FF,
0x0EF, 0x00000000,
0x0EF, 0x00080000,
0x033, 0x00000007,
0x03E, 0x00000003,
0x03F, 0x0007DEFF,
0x0EF, 0x00000000,
};
void
odm_read_and_config_mp_8822c_radioa(struct dm_struct *dm)
{
u32 i = 0;
u8 c_cond;
boolean is_matched = true, is_skipped = false;
u32 array_len =
sizeof(array_mp_8822c_radioa) / sizeof(u32);
u32 *array = (u32 *)array_mp_8822c_radioa;
u32 v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
u32 a1 = 0, a2 = 0, a3 = 0, a4 = 0;
PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
while ((i + 1) < array_len) {
v1 = array[i];
v2 = array[i + 1];
if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
if (v1 & BIT(31)) {/* positive condition*/
c_cond =
(u8)((v1 & (BIT(29) | BIT(28))) >> 28);
if (c_cond == COND_ENDIF) {/*end*/
is_matched = true;
is_skipped = false;
PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
} else if (c_cond == COND_ELSE) { /*else*/
is_matched = is_skipped ? false : true;
PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
} else {/*if , else if*/
pre_v1 = v1;
pre_v2 = v2;
PHYDM_DBG(dm, ODM_COMP_INIT,
"IF or ELSE IF\n");
}
} else if (v1 & BIT(30)) { /*negative condition*/
if (!is_skipped) {
a1 = pre_v1; a2 = pre_v2;
a3 = v1; a4 = v2;
if (check_positive(dm,
a1, a2, a3, a4)) {
is_matched = true;
is_skipped = true;
} else {
is_matched = false;
is_skipped = false;
}
} else {
is_matched = false;
}
}
} else {
if (is_matched)
odm_config_rf_radio_a_8822c(dm, v1, v2);
}
i = i + 2;
}
}
u32
odm_get_version_mp_8822c_radioa(void)
{
return 41;
}
/******************************************************************************
* radiob.TXT
******************************************************************************/
const u32 array_mp_8822c_radiob[] = {
0x000, 0x00030000,
0x018, 0x00013124,
0x093, 0x0008483F,
0x0EF, 0x00080000,
0x033, 0x00000001,
0x03F, 0x00091230,
0x0EF, 0x00000000,
0x0DE, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000B9140,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000B9140,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x08E, 0x000A5540,
0xA0000000, 0x00000000,
0x08E, 0x000A5540,
0xB0000000, 0x00000000,
0x081, 0x0000FC01,
0x081, 0x0002FC01,
0x081, 0x0003FC01,
0x085, 0x0006A06C,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000001,
0x03F, 0x0000002A,
0x033, 0x00000002,
0x03F, 0x0000002A,
0x0EE, 0x00000000,
0xA0000000, 0x00000000,
0x0EE, 0x00000010,
0x033, 0x00000001,
0x03F, 0x0000003F,
0x033, 0x00000001,
0x03F, 0x0000003F,
0x033, 0x00000002,
0x03F, 0x0000003F,
0x0EE, 0x00000000,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x000FF3A0,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x00000287,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000207,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773C0,
0x033, 0x0000000E,
0x03F, 0x000FF3C0,
0x033, 0x0000000D,
0x03F, 0x000773E8,
0x033, 0x0000000C,
0x03F, 0x000FF3E8,
0x033, 0x0000000B,
0x03F, 0x00000287,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000207,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x0EF, 0x00010000,
0x033, 0x0000000F,
0x03F, 0x000773E8,
0x033, 0x0000000E,
0x03F, 0x000FF3A0,
0x033, 0x0000000D,
0x03F, 0x00000380,
0x033, 0x0000000C,
0x03F, 0x000FF380,
0x033, 0x0000000B,
0x03F, 0x00000300,
0x033, 0x0000000A,
0x03F, 0x000002A8,
0x033, 0x00000009,
0x03F, 0x00000280,
0x033, 0x00000008,
0x03F, 0x000FF280,
0x033, 0x00000007,
0x03F, 0x00000200,
0x033, 0x00000006,
0x03F, 0x000001C0,
0x033, 0x00000005,
0x03F, 0x00000180,
0x033, 0x00000004,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000003,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x000FF3A0,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x00000287,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000207,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773C0,
0x033, 0x0000001E,
0x03F, 0x000FF3C0,
0x033, 0x0000001D,
0x03F, 0x000773E8,
0x033, 0x0000001C,
0x03F, 0x000FF3E8,
0x033, 0x0000001B,
0x03F, 0x00000287,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000207,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000001F,
0x03F, 0x000773E8,
0x033, 0x0000001E,
0x03F, 0x000FF3A0,
0x033, 0x0000001D,
0x03F, 0x00000380,
0x033, 0x0000001C,
0x03F, 0x000FF380,
0x033, 0x0000001B,
0x03F, 0x00000300,
0x033, 0x0000001A,
0x03F, 0x000002A8,
0x033, 0x00000019,
0x03F, 0x00000280,
0x033, 0x00000018,
0x03F, 0x000FF280,
0x033, 0x00000017,
0x03F, 0x00000200,
0x033, 0x00000016,
0x03F, 0x000001C0,
0x033, 0x00000015,
0x03F, 0x00000180,
0x033, 0x00000014,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000013,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x000FF3A0,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x00000287,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000207,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773C0,
0x033, 0x0000002E,
0x03F, 0x000FF3C0,
0x033, 0x0000002D,
0x03F, 0x000773E8,
0x033, 0x0000002C,
0x03F, 0x000FF3E8,
0x033, 0x0000002B,
0x03F, 0x00000287,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000207,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000002F,
0x03F, 0x000773E8,
0x033, 0x0000002E,
0x03F, 0x000FF3A0,
0x033, 0x0000002D,
0x03F, 0x00000380,
0x033, 0x0000002C,
0x03F, 0x000FF380,
0x033, 0x0000002B,
0x03F, 0x00000300,
0x033, 0x0000002A,
0x03F, 0x000002A8,
0x033, 0x00000029,
0x03F, 0x00000280,
0x033, 0x00000028,
0x03F, 0x000FF280,
0x033, 0x00000027,
0x03F, 0x00000200,
0x033, 0x00000026,
0x03F, 0x000001C0,
0x033, 0x00000025,
0x03F, 0x00000180,
0x033, 0x00000024,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000023,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x000FF3A0,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x00000287,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000207,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773C0,
0x033, 0x0000003E,
0x03F, 0x000FF3C0,
0x033, 0x0000003D,
0x03F, 0x000773E8,
0x033, 0x0000003C,
0x03F, 0x000FF3E8,
0x033, 0x0000003B,
0x03F, 0x00000287,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000207,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000003F,
0x03F, 0x000773E8,
0x033, 0x0000003E,
0x03F, 0x000FF3A0,
0x033, 0x0000003D,
0x03F, 0x00000380,
0x033, 0x0000003C,
0x03F, 0x000FF380,
0x033, 0x0000003B,
0x03F, 0x00000300,
0x033, 0x0000003A,
0x03F, 0x000002A8,
0x033, 0x00000039,
0x03F, 0x00000280,
0x033, 0x00000038,
0x03F, 0x000FF280,
0x033, 0x00000037,
0x03F, 0x00000200,
0x033, 0x00000036,
0x03F, 0x000001C0,
0x033, 0x00000035,
0x03F, 0x00000180,
0x033, 0x00000034,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000033,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x000FF3A0,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x00000287,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000207,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773C0,
0x033, 0x0000004E,
0x03F, 0x000FF3C0,
0x033, 0x0000004D,
0x03F, 0x000773E8,
0x033, 0x0000004C,
0x03F, 0x000FF3E8,
0x033, 0x0000004B,
0x03F, 0x00000287,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000207,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000004F,
0x03F, 0x000773E8,
0x033, 0x0000004E,
0x03F, 0x000FF3A0,
0x033, 0x0000004D,
0x03F, 0x00000380,
0x033, 0x0000004C,
0x03F, 0x000FF380,
0x033, 0x0000004B,
0x03F, 0x00000300,
0x033, 0x0000004A,
0x03F, 0x000002A8,
0x033, 0x00000049,
0x03F, 0x00000280,
0x033, 0x00000048,
0x03F, 0x000FF280,
0x033, 0x00000047,
0x03F, 0x00000200,
0x033, 0x00000046,
0x03F, 0x000001C0,
0x033, 0x00000045,
0x03F, 0x00000180,
0x033, 0x00000044,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000043,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x000FF3A0,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x00000287,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000207,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773C0,
0x033, 0x0000005E,
0x03F, 0x000FF3C0,
0x033, 0x0000005D,
0x03F, 0x000773E8,
0x033, 0x0000005C,
0x03F, 0x000FF3E8,
0x033, 0x0000005B,
0x03F, 0x00000287,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000207,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0xA0000000, 0x00000000,
0x033, 0x0000005F,
0x03F, 0x000773E8,
0x033, 0x0000005E,
0x03F, 0x000FF3A0,
0x033, 0x0000005D,
0x03F, 0x00000380,
0x033, 0x0000005C,
0x03F, 0x000FF380,
0x033, 0x0000005B,
0x03F, 0x00000300,
0x033, 0x0000005A,
0x03F, 0x000002A8,
0x033, 0x00000059,
0x03F, 0x00000280,
0x033, 0x00000058,
0x03F, 0x000FF280,
0x033, 0x00000057,
0x03F, 0x00000200,
0x033, 0x00000056,
0x03F, 0x000001C0,
0x033, 0x00000055,
0x03F, 0x00000180,
0x033, 0x00000054,
0x03F, 0x00000040,
0xB0000000, 0x00000000,
0x033, 0x00000053,
0x03F, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00000000,
0xA0000000, 0x00000000,
0x0EF, 0x00000000,
0xB0000000, 0x00000000,
0x08A, 0x000E7DE3,
0x08B, 0x0008FE00,
0x0EE, 0x00000008,
0x033, 0x00000000,
0x03F, 0x00000023,
0x033, 0x00000001,
0x03F, 0x00000023,
0x0EE, 0x00000000,
0x0EF, 0x00004000,
0x033, 0x00000000,
0x03F, 0x0000000F,
0x033, 0x00000002,
0x03F, 0x00000000,
0x0EF, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002F81C,
0x033, 0x00000010,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001C86,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0xA0000000, 0x00000000,
0x0EF, 0x00020000,
0x033, 0x00000000,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000001,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000002,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000003,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000004,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000005,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000006,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000007,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000008,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000009,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000000A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000000B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000000C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000000D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000000E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000000F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000010,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000011,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000012,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000013,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000014,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000015,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000016,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000017,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000018,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000019,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000001A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000001B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000001C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000001D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000001E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000001F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000020,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000021,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x00000022,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x00000023,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x00000024,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x00000025,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x00000026,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x00000027,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x033, 0x00000028,
0x03E, 0x00001910,
0x03F, 0x00020000,
0x033, 0x00000029,
0x03E, 0x00001C02,
0x03F, 0x00020000,
0x033, 0x0000002A,
0x03E, 0x00000F02,
0x03F, 0x00020000,
0x033, 0x0000002B,
0x03E, 0x00000F00,
0x03F, 0x00020000,
0x033, 0x0000002C,
0x03E, 0x00000086,
0x03F, 0x00020000,
0x033, 0x0000002D,
0x03E, 0x00000002,
0x03F, 0x00020000,
0x033, 0x0000002E,
0x03E, 0x00000000,
0x03F, 0x00020000,
0x033, 0x0000002F,
0x03E, 0x00000000,
0x03F, 0x0002C010,
0x0EF, 0x00000000,
0xB0000000, 0x00000000,
0x0FE, 0x00000000,
0x01B, 0x00003A40,
0x061, 0x0000D233,
0x062, 0x0004D232,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x063, 0x00000002,
0xA0000000, 0x00000000,
0x063, 0x00000C02,
0xB0000000, 0x00000000,
0x0EF, 0x00000200,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000237,
0x030, 0x00001237,
0x030, 0x00002237,
0x030, 0x00003237,
0x030, 0x00004207,
0x030, 0x00005237,
0x030, 0x00006237,
0x030, 0x00007237,
0x030, 0x00008207,
0x030, 0x00009237,
0x030, 0x0000A237,
0x030, 0x0000B237,
0x030, 0x0000C237,
0x030, 0x0000D237,
0x030, 0x0000E207,
0x030, 0x0000F237,
0x030, 0x00010237,
0x030, 0x00011237,
0x030, 0x00012207,
0x030, 0x00013237,
0x030, 0x00014237,
0x030, 0x00015237,
0x030, 0x00016207,
0x030, 0x00017237,
0x030, 0x00018207,
0x030, 0x00019237,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000238,
0x030, 0x00001238,
0x030, 0x00002238,
0x030, 0x00003238,
0x030, 0x00004228,
0x030, 0x00005238,
0x030, 0x00006238,
0x030, 0x00007238,
0x030, 0x00008228,
0x030, 0x00009238,
0x030, 0x0000A238,
0x030, 0x0000B238,
0x030, 0x0000C238,
0x030, 0x0000D238,
0x030, 0x0000E228,
0x030, 0x0000F238,
0x030, 0x00010238,
0x030, 0x00011238,
0x030, 0x00012228,
0x030, 0x00013238,
0x030, 0x00014238,
0x030, 0x00015238,
0x030, 0x00016228,
0x030, 0x00017238,
0x030, 0x00018228,
0x030, 0x00019238,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000238,
0x030, 0x00001238,
0x030, 0x00002238,
0x030, 0x00003238,
0x030, 0x00004228,
0x030, 0x00005238,
0x030, 0x00006238,
0x030, 0x00007238,
0x030, 0x00008228,
0x030, 0x00009238,
0x030, 0x0000A238,
0x030, 0x0000B238,
0x030, 0x0000C238,
0x030, 0x0000D238,
0x030, 0x0000E228,
0x030, 0x0000F238,
0x030, 0x00010238,
0x030, 0x00011238,
0x030, 0x00012228,
0x030, 0x00013238,
0x030, 0x00014238,
0x030, 0x00015238,
0x030, 0x00016228,
0x030, 0x00017238,
0x030, 0x00018228,
0x030, 0x00019238,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000239,
0x030, 0x00001239,
0x030, 0x00002239,
0x030, 0x00003239,
0x030, 0x00004239,
0x030, 0x00005239,
0x030, 0x00006239,
0x030, 0x00007239,
0x030, 0x00008239,
0x030, 0x00009239,
0x030, 0x0000A239,
0x030, 0x0000B239,
0x030, 0x0000C239,
0x030, 0x0000D239,
0x030, 0x0000E209,
0x030, 0x0000F239,
0x030, 0x00010239,
0x030, 0x00011239,
0x030, 0x00012209,
0x030, 0x00013239,
0x030, 0x00014239,
0x030, 0x00015239,
0x030, 0x00016209,
0x030, 0x00017239,
0x030, 0x00018209,
0x030, 0x00019239,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000239,
0x030, 0x00001239,
0x030, 0x00002239,
0x030, 0x00003239,
0x030, 0x00004239,
0x030, 0x00005239,
0x030, 0x00006239,
0x030, 0x00007239,
0x030, 0x00008239,
0x030, 0x00009239,
0x030, 0x0000A239,
0x030, 0x0000B239,
0x030, 0x0000C239,
0x030, 0x0000D239,
0x030, 0x0000E209,
0x030, 0x0000F239,
0x030, 0x00010239,
0x030, 0x00011239,
0x030, 0x00012209,
0x030, 0x00013239,
0x030, 0x00014239,
0x030, 0x00015239,
0x030, 0x00016209,
0x030, 0x00017239,
0x030, 0x00018209,
0x030, 0x00019239,
0xA0000000, 0x00000000,
0x030, 0x00000233,
0x030, 0x00001233,
0x030, 0x00002233,
0x030, 0x00003233,
0x030, 0x00004203,
0x030, 0x00005233,
0x030, 0x00006233,
0x030, 0x00007233,
0x030, 0x00008203,
0x030, 0x00009233,
0x030, 0x0000A233,
0x030, 0x0000B233,
0x030, 0x0000C233,
0x030, 0x0000D233,
0x030, 0x0000E203,
0x030, 0x0000F233,
0x030, 0x00010233,
0x030, 0x00011233,
0x030, 0x00012203,
0x030, 0x00013233,
0x030, 0x00014233,
0x030, 0x00015233,
0x030, 0x00016203,
0x030, 0x00017233,
0x030, 0x00018203,
0x030, 0x00019233,
0xB0000000, 0x00000000,
0x0EF, 0x00000000,
0x0EF, 0x00000080,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x030, 0x00000334,
0x030, 0x00001334,
0x030, 0x00002334,
0x030, 0x00003334,
0x030, 0x00004334,
0x030, 0x00005334,
0x030, 0x00006334,
0x030, 0x00007334,
0x030, 0x00008334,
0x030, 0x00009334,
0x030, 0x0000A334,
0x030, 0x0000B334,
0xA0000000, 0x00000000,
0x030, 0x00000232,
0x030, 0x00001232,
0x030, 0x00002232,
0x030, 0x00003232,
0x030, 0x00004232,
0x030, 0x00005232,
0x030, 0x00006232,
0x030, 0x00007232,
0x030, 0x00008232,
0x030, 0x00009232,
0x030, 0x0000A232,
0x030, 0x0000B232,
0xB0000000, 0x00000000,
0x0EF, 0x00000000,
0x0EF, 0x00000040,
0x030, 0x00000770,
0x030, 0x00001770,
0x030, 0x00002440,
0x030, 0x00003440,
0x030, 0x00004330,
0x030, 0x00005330,
0x030, 0x00008770,
0x030, 0x0000A440,
0x030, 0x0000C330,
0x0EF, 0x00000000,
0x0EE, 0x00010000,
0x033, 0x00000200,
0x03F, 0x0000006A,
0x033, 0x00000201,
0x03F, 0x0000006D,
0x033, 0x00000202,
0x03F, 0x0000046A,
0x033, 0x00000203,
0x03F, 0x0000086A,
0x033, 0x00000204,
0x03F, 0x00000C89,
0x033, 0x00000205,
0x03F, 0x00000CE8,
0x033, 0x00000206,
0x03F, 0x00000CEB,
0x033, 0x00000207,
0x03F, 0x00000CEE,
0x033, 0x00000208,
0x03F, 0x00000CF1,
0x033, 0x00000209,
0x03F, 0x00000CF4,
0x033, 0x0000020A,
0x03F, 0x00000CF7,
0x033, 0x00000280,
0x03F, 0x0000006A,
0x033, 0x00000281,
0x03F, 0x0000006D,
0x033, 0x00000282,
0x03F, 0x0000046A,
0x033, 0x00000283,
0x03F, 0x0000086A,
0x033, 0x00000284,
0x03F, 0x00000C89,
0x033, 0x00000285,
0x03F, 0x00000CE8,
0x033, 0x00000286,
0x03F, 0x00000CEB,
0x033, 0x00000287,
0x03F, 0x00000CEE,
0x033, 0x00000288,
0x03F, 0x00000CF1,
0x033, 0x00000289,
0x03F, 0x00000CF4,
0x033, 0x0000028A,
0x03F, 0x00000CF7,
0x033, 0x00000300,
0x03F, 0x0000006A,
0x033, 0x00000301,
0x03F, 0x0000006D,
0x033, 0x00000302,
0x03F, 0x0000046A,
0x033, 0x00000303,
0x03F, 0x0000086A,
0x033, 0x00000304,
0x03F, 0x00000C89,
0x033, 0x00000305,
0x03F, 0x00000CE8,
0x033, 0x00000306,
0x03F, 0x00000CEB,
0x033, 0x00000307,
0x03F, 0x00000CEE,
0x033, 0x00000308,
0x03F, 0x00000CF1,
0x033, 0x00000309,
0x03F, 0x00000CF4,
0x033, 0x0000030A,
0x03F, 0x00000CF7,
0x0EE, 0x00000000,
0x051, 0x0003C800,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x052, 0x000902CA,
0xA0000000, 0x00000000,
0x052, 0x000942C0,
0xB0000000, 0x00000000,
0x053, 0x000090F9,
0x054, 0x00088000,
0x057, 0x0004C80A,
0x0EF, 0x00000020,
0x033, 0x00000000,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000001,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000002,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000003,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000004,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000005,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000006,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000007,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000008,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0xA0000000, 0x00000000,
0x03F, 0x0000C246,
0xB0000000, 0x00000000,
0x033, 0x00000009,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000000A,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000000B,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000000C,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000000D,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000000E,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000000F,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000010,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000241C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000011,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x00024246,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002C246,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000012,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000013,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000014,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000015,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000016,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000017,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000018,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000019,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000001A,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000001B,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000001C,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000001D,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000001E,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000001F,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000020,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000021,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000022,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000023,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000020,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000020,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000020,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000020,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000024,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000025,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000026,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000027,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000028,
0x83000001, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03E, 0x00000030,
0xA0000000, 0x00000000,
0x03E, 0x00000020,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x000209C6,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x00000029,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0002CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x033, 0x0000002A,
0x03E, 0x00000020,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x03F, 0x0001CA46,
0xA0000000, 0x00000000,
0x03F, 0x00008E46,
0xB0000000, 0x00000000,
0x0EF, 0x00000000,
0x0EE, 0x00010000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000468,
0x033, 0x00000061,
0x03F, 0x00000868,
0x033, 0x00000062,
0x03F, 0x00000909,
0x033, 0x00000063,
0x03F, 0x00000D0A,
0x033, 0x00000064,
0x03F, 0x00000D4A,
0x033, 0x00000065,
0x03F, 0x00000D8B,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000467,
0x033, 0x00000061,
0x03F, 0x00000867,
0x033, 0x00000062,
0x03F, 0x00000908,
0x033, 0x00000063,
0x03F, 0x00000D09,
0x033, 0x00000064,
0x03F, 0x00000D49,
0x033, 0x00000065,
0x03F, 0x00000D8A,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0xA0000000, 0x00000000,
0x033, 0x00000060,
0x03F, 0x00000487,
0x033, 0x00000061,
0x03F, 0x00000887,
0x033, 0x00000062,
0x03F, 0x00000947,
0x033, 0x00000063,
0x03F, 0x00000D48,
0x033, 0x00000064,
0x03F, 0x00000D88,
0x033, 0x00000065,
0x03F, 0x00000DE8,
0x033, 0x00000066,
0x03F, 0x00000DEB,
0x033, 0x00000067,
0x03F, 0x00000DEE,
0x033, 0x00000068,
0x03F, 0x00000DF1,
0x033, 0x00000069,
0x03F, 0x00000DF4,
0x033, 0x0000006A,
0x03F, 0x00000DF7,
0xB0000000, 0x00000000,
0x81000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x91000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x92000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x92000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000468,
0x033, 0x00000021,
0x03F, 0x00000868,
0x033, 0x00000022,
0x03F, 0x00000909,
0x033, 0x00000023,
0x03F, 0x00000D0A,
0x033, 0x00000024,
0x03F, 0x00000D4A,
0x033, 0x00000025,
0x03F, 0x00000D8B,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000001, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000002, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000003, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0x93000004, 0x00000000, 0x40000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000467,
0x033, 0x00000021,
0x03F, 0x00000867,
0x033, 0x00000022,
0x03F, 0x00000908,
0x033, 0x00000023,
0x03F, 0x00000D09,
0x033, 0x00000024,
0x03F, 0x00000D49,
0x033, 0x00000025,
0x03F, 0x00000D8A,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0xA0000000, 0x00000000,
0x033, 0x00000020,
0x03F, 0x00000487,
0x033, 0x00000021,
0x03F, 0x00000887,
0x033, 0x00000022,
0x03F, 0x00000947,
0x033, 0x00000023,
0x03F, 0x00000D48,
0x033, 0x00000024,
0x03F, 0x00000D88,
0x033, 0x00000025,
0x03F, 0x00000DE8,
0x033, 0x00000026,
0x03F, 0x00000DEB,
0x033, 0x00000027,
0x03F, 0x00000DEE,
0x033, 0x00000028,
0x03F, 0x00000DF1,
0x033, 0x00000029,
0x03F, 0x00000DF4,
0x033, 0x0000002A,
0x03F, 0x00000DF7,
0xB0000000, 0x00000000,
0x0EE, 0x00000000,
0x05C, 0x000FCC00,
0x067, 0x0000A505,
0x0D3, 0x00000542,
0x043, 0x00005000,
0x059, 0x000A0000,
0x05A, 0x00060000,
0x05B, 0x00014000,
0x001, 0x00040000,
0x0EE, 0x00000002,
0x033, 0x00000017,
0x03F, 0x0000003F,
0x033, 0x00000018,
0x03F, 0x0000003F,
0x033, 0x00000019,
0x03F, 0x00000000,
0x033, 0x0000001A,
0x03F, 0x0000003F,
0x033, 0x0000001B,
0x03F, 0x0000003F,
0x033, 0x0000001C,
0x03F, 0x0000003F,
0x0EE, 0x00000000,
0x092, 0x00084800,
0x092, 0x00084801,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x0FE, 0x00000000,
0x092, 0x00084800,
0x08F, 0x00001B4C,
0x088, 0x0004326B,
0x019, 0x00000005,
0x0EF, 0x00080000,
0x033, 0x00000004,
0x03F, 0x000FD83F,
0x0EF, 0x00000000,
0x0EF, 0x00080000,
0x033, 0x00000006,
0x03F, 0x000DD83F,
0x0EF, 0x00000000,
0x0EF, 0x00080000,
0x033, 0x00000007,
0x03F, 0x000DF7BF,
0x0EF, 0x00000000,
0x0EF, 0x00040000,
0x033, 0x00000006,
0x03F, 0x00000002,
0x033, 0x00000007,
0x03F, 0x00000002,
0x0EF, 0x00000000,
};
void
odm_read_and_config_mp_8822c_radiob(struct dm_struct *dm)
{
u32 i = 0;
u8 c_cond;
boolean is_matched = true, is_skipped = false;
u32 array_len =
sizeof(array_mp_8822c_radiob) / sizeof(u32);
u32 *array = (u32 *)array_mp_8822c_radiob;
u32 v1 = 0, v2 = 0, pre_v1 = 0, pre_v2 = 0;
u32 a1 = 0, a2 = 0, a3 = 0, a4 = 0;
PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
while ((i + 1) < array_len) {
v1 = array[i];
v2 = array[i + 1];
if (v1 & (BIT(31) | BIT(30))) {/*positive & negative condition*/
if (v1 & BIT(31)) {/* positive condition*/
c_cond =
(u8)((v1 & (BIT(29) | BIT(28))) >> 28);
if (c_cond == COND_ENDIF) {/*end*/
is_matched = true;
is_skipped = false;
PHYDM_DBG(dm, ODM_COMP_INIT, "ENDIF\n");
} else if (c_cond == COND_ELSE) { /*else*/
is_matched = is_skipped ? false : true;
PHYDM_DBG(dm, ODM_COMP_INIT, "ELSE\n");
} else {/*if , else if*/
pre_v1 = v1;
pre_v2 = v2;
PHYDM_DBG(dm, ODM_COMP_INIT,
"IF or ELSE IF\n");
}
} else if (v1 & BIT(30)) { /*negative condition*/
if (!is_skipped) {
a1 = pre_v1; a2 = pre_v2;
a3 = v1; a4 = v2;
if (check_positive(dm,
a1, a2, a3, a4)) {
is_matched = true;
is_skipped = true;
} else {
is_matched = false;
is_skipped = false;
}
} else {
is_matched = false;
}
}
} else {
if (is_matched)
odm_config_rf_radio_b_8822c(dm, v1, v2);
}
i = i + 2;
}
}
u32
odm_get_version_mp_8822c_radiob(void)
{
return 41;
}
/******************************************************************************
* txpowertrack.TXT
******************************************************************************/
#ifdef CONFIG_8822C
const u8 delta_swingidx_mp_5gb_n_txpwrtrk_8822c[][D_S_SIZE] = {
{0, 1, 2, 3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 18,
19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 32},
{0, 1, 2, 3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 18,
19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 32},
{0, 1, 2, 3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 18,
19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 32},
};
const u8 delta_swingidx_mp_5gb_p_txpwrtrk_8822c[][D_S_SIZE] = {
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15,
16, 17, 18, 19, 20, 21, 22, 22, 23, 24, 25, 26, 27},
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15,
16, 17, 18, 19, 20, 21, 22, 22, 23, 24, 25, 26, 27},
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 11, 12, 13, 14, 15,
16, 17, 18, 19, 20, 21, 22, 22, 23, 24, 25, 26, 27},
};
const u8 delta_swingidx_mp_5ga_n_txpwrtrk_8822c[][D_S_SIZE] = {
{0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 13, 14, 15, 16, 17, 18,
19, 20, 21, 23, 24, 25, 26, 27, 28, 29, 30, 31, 33},
{0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 13, 14, 15, 16, 17, 18,
19, 20, 21, 23, 24, 25, 26, 27, 28, 29, 30, 31, 33},
{0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 13, 14, 15, 16, 17, 18,
19, 20, 21, 23, 24, 25, 26, 27, 28, 29, 30, 31, 33},
};
const u8 delta_swingidx_mp_5ga_p_txpwrtrk_8822c[][D_S_SIZE] = {
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
17, 18, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30},
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
17, 18, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30},
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
17, 18, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30},
};
const u8 delta_swingidx_mp_2gb_n_txpwrtrk_8822c[] = {
0, 1, 2, 3, 4, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14,
15, 15, 16, 17, 18, 19, 20, 20, 21, 22, 23, 24, 25};
const u8 delta_swingidx_mp_2gb_p_txpwrtrk_8822c[] = {
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 14, 15,
16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28};
const u8 delta_swingidx_mp_2ga_n_txpwrtrk_8822c[] = {
0, 1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 8, 8, 9, 9, 10, 11,
11, 12, 13, 13, 14, 15, 15, 16, 17, 17, 18, 19, 19};
const u8 delta_swingidx_mp_2ga_p_txpwrtrk_8822c[] = {
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14, 15,
16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 25, 26, 27};
const u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrk_8822c[] = {
0, 1, 2, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14,
15, 16, 17, 17, 18, 19, 20, 21, 22, 23, 23, 24, 25};
const u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrk_8822c[] = {
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29};
const u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrk_8822c[] = {
0, 1, 2, 3, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 11, 12, 12,
13, 14, 15, 15, 16, 17, 18, 18, 19, 20, 21, 21, 22};
const u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrk_8822c[] = {
0, 1, 2, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 11, 12, 13, 14,
15, 16, 17, 18, 18, 19, 20, 21, 22, 23, 24, 24, 25};
#endif
void
odm_read_and_config_mp_8822c_txpowertrack(struct dm_struct *dm)
{
#ifdef CONFIG_8822C
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822c\n");
odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p,
(void *)delta_swingidx_mp_2ga_p_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n,
(void *)delta_swingidx_mp_2ga_n_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p,
(void *)delta_swingidx_mp_2gb_p_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n,
(void *)delta_swingidx_mp_2gb_n_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p,
(void *)delta_swingidx_mp_2g_cck_a_p_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n,
(void *)delta_swingidx_mp_2g_cck_a_n_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p,
(void *)delta_swingidx_mp_2g_cck_b_p_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n,
(void *)delta_swingidx_mp_2g_cck_b_n_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p,
(void *)delta_swingidx_mp_5ga_p_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE * 3);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n,
(void *)delta_swingidx_mp_5ga_n_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE * 3);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p,
(void *)delta_swingidx_mp_5gb_p_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE * 3);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n,
(void *)delta_swingidx_mp_5gb_n_txpwrtrk_8822c,
DELTA_SWINGIDX_SIZE * 3);
#endif
}
/******************************************************************************
* txpowertracktssi.TXT
******************************************************************************/
#ifdef CONFIG_8822CTSSI
const u8 delta_swingidx_mp_5gb_n_txpwrtrktssi_8822c[][D_S_SIZE] = {
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9},
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9},
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 8, 8, 8, 9},
};
const u8 delta_swingidx_mp_5gb_p_txpwrtrktssi_8822c[][D_S_SIZE] = {
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9},
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9},
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9},
};
const u8 delta_swingidx_mp_5ga_n_txpwrtrktssi_8822c[][D_S_SIZE] = {
{0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 4, 4, 4, 5, 5,
5, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10},
{0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 4, 4, 4, 5, 5,
5, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10},
{0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 4, 4, 4, 5, 5,
5, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10},
};
const u8 delta_swingidx_mp_5ga_p_txpwrtrktssi_8822c[][D_S_SIZE] = {
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9},
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9},
{0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4,
5, 5, 5, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9},
};
const u8 delta_swingidx_mp_2gb_n_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 5, 6, 6,
7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 11, 11, 12};
const u8 delta_swingidx_mp_2gb_p_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 4, 5, 5, 6,
6, 6, 7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 11, 11};
const u8 delta_swingidx_mp_2ga_n_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 2, 2, 2, 3, 3, 4, 4, 5, 5, 5, 6, 6,
7, 7, 8, 8, 8, 9, 9, 10, 10, 10, 11, 11, 12};
const u8 delta_swingidx_mp_2ga_p_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4, 5, 5, 6, 6, 7,
7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12, 13};
const u8 delta_swingidx_mp_2g_cck_b_n_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 4, 4, 4, 5, 5,
5, 6, 6, 7, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10};
const u8 delta_swingidx_mp_2g_cck_b_p_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5,
6, 6, 6, 7, 7, 8, 8, 8, 9, 9, 9, 10, 10, 11};
const u8 delta_swingidx_mp_2g_cck_a_n_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 4, 5, 5, 6, 6, 7,
7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12, 13};
const u8 delta_swingidx_mp_2g_cck_a_p_txpwrtrktssi_8822c[] = {
0, 0, 0, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6, 6,
7, 7, 8, 8, 9, 9, 9, 10, 10, 11, 11, 12, 12};
#endif
void
odm_read_and_config_mp_8822c_txpowertracktssi(struct dm_struct *dm)
{
#ifdef CONFIG_8822CTSSI
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
PHYDM_DBG(dm, ODM_COMP_INIT, "===> ODM_ReadAndConfig_MP_mp_8822c\n");
odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_p,
(void *)delta_swingidx_mp_2ga_p_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2ga_n,
(void *)delta_swingidx_mp_2ga_n_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_p,
(void *)delta_swingidx_mp_2gb_p_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2gb_n,
(void *)delta_swingidx_mp_2gb_n_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_p,
(void *)delta_swingidx_mp_2g_cck_a_p_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_a_n,
(void *)delta_swingidx_mp_2g_cck_a_n_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_p,
(void *)delta_swingidx_mp_2g_cck_b_p_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_2g_cck_b_n,
(void *)delta_swingidx_mp_2g_cck_b_n_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_p,
(void *)delta_swingidx_mp_5ga_p_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE * 3);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5ga_n,
(void *)delta_swingidx_mp_5ga_n_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE * 3);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_p,
(void *)delta_swingidx_mp_5gb_p_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE * 3);
odm_move_memory(dm, cali_info->delta_swing_table_idx_5gb_n,
(void *)delta_swingidx_mp_5gb_n_txpwrtrktssi_8822c,
DELTA_SWINGIDX_SIZE * 3);
#endif
}
/******************************************************************************
* txpwr_lmt.TXT
******************************************************************************/
#ifdef CONFIG_8822C
const char *array_mp_8822c_txpwr_lmt[] = {
"FCC", "2.4G", "20M", "CCK", "1T", "01", "72",
"ETSI", "2.4G", "20M", "CCK", "1T", "01", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "01", "68",
"IC", "2.4G", "20M", "CCK", "1T", "01", "72",
"KCC", "2.4G", "20M", "CCK", "1T", "01", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "01", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "01", "72",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "01", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "01", "72",
"FCC", "2.4G", "20M", "CCK", "1T", "02", "72",
"ETSI", "2.4G", "20M", "CCK", "1T", "02", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "02", "68",
"IC", "2.4G", "20M", "CCK", "1T", "02", "72",
"KCC", "2.4G", "20M", "CCK", "1T", "02", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "02", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "02", "72",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "02", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "02", "72",
"FCC", "2.4G", "20M", "CCK", "1T", "03", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "03", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "03", "68",
"IC", "2.4G", "20M", "CCK", "1T", "03", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "03", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "03", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "03", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "03", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "03", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "04", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "04", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "04", "68",
"IC", "2.4G", "20M", "CCK", "1T", "04", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "04", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "04", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "04", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "04", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "04", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "05", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "05", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "05", "68",
"IC", "2.4G", "20M", "CCK", "1T", "05", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "05", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "05", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "05", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "05", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "05", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "06", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "06", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "06", "68",
"IC", "2.4G", "20M", "CCK", "1T", "06", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "06", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "06", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "06", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "06", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "06", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "07", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "07", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "07", "68",
"IC", "2.4G", "20M", "CCK", "1T", "07", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "07", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "07", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "07", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "07", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "07", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "08", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "08", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "08", "68",
"IC", "2.4G", "20M", "CCK", "1T", "08", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "08", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "08", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "08", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "08", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "08", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "09", "76",
"ETSI", "2.4G", "20M", "CCK", "1T", "09", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "09", "68",
"IC", "2.4G", "20M", "CCK", "1T", "09", "76",
"KCC", "2.4G", "20M", "CCK", "1T", "09", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "09", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "09", "76",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "09", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "09", "76",
"FCC", "2.4G", "20M", "CCK", "1T", "10", "72",
"ETSI", "2.4G", "20M", "CCK", "1T", "10", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "10", "68",
"IC", "2.4G", "20M", "CCK", "1T", "10", "72",
"KCC", "2.4G", "20M", "CCK", "1T", "10", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "10", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "10", "72",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "10", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "10", "72",
"FCC", "2.4G", "20M", "CCK", "1T", "11", "72",
"ETSI", "2.4G", "20M", "CCK", "1T", "11", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "11", "68",
"IC", "2.4G", "20M", "CCK", "1T", "11", "72",
"KCC", "2.4G", "20M", "CCK", "1T", "11", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "11", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "11", "72",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "11", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "11", "72",
"FCC", "2.4G", "20M", "CCK", "1T", "12", "52",
"ETSI", "2.4G", "20M", "CCK", "1T", "12", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "12", "68",
"IC", "2.4G", "20M", "CCK", "1T", "12", "52",
"KCC", "2.4G", "20M", "CCK", "1T", "12", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "12", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "12", "52",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "12", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "12", "52",
"FCC", "2.4G", "20M", "CCK", "1T", "13", "48",
"ETSI", "2.4G", "20M", "CCK", "1T", "13", "60",
"MKK", "2.4G", "20M", "CCK", "1T", "13", "68",
"IC", "2.4G", "20M", "CCK", "1T", "13", "48",
"KCC", "2.4G", "20M", "CCK", "1T", "13", "76",
"ACMA", "2.4G", "20M", "CCK", "1T", "13", "60",
"CHILE", "2.4G", "20M", "CCK", "1T", "13", "48",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "13", "60",
"MEXICO", "2.4G", "20M", "CCK", "1T", "13", "48",
"FCC", "2.4G", "20M", "CCK", "1T", "14", "127",
"ETSI", "2.4G", "20M", "CCK", "1T", "14", "127",
"MKK", "2.4G", "20M", "CCK", "1T", "14", "68",
"IC", "2.4G", "20M", "CCK", "1T", "14", "127",
"KCC", "2.4G", "20M", "CCK", "1T", "14", "127",
"ACMA", "2.4G", "20M", "CCK", "1T", "14", "127",
"CHILE", "2.4G", "20M", "CCK", "1T", "14", "127",
"UKRAINE", "2.4G", "20M", "CCK", "1T", "14", "127",
"MEXICO", "2.4G", "20M", "CCK", "1T", "14", "127",
"FCC", "2.4G", "20M", "CCK", "2T", "01", "72",
"ETSI", "2.4G", "20M", "CCK", "2T", "01", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "01", "56",
"IC", "2.4G", "20M", "CCK", "2T", "01", "72",
"KCC", "2.4G", "20M", "CCK", "2T", "01", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "01", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "01", "72",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "01", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "01", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "02", "72",
"ETSI", "2.4G", "20M", "CCK", "2T", "02", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "02", "56",
"IC", "2.4G", "20M", "CCK", "2T", "02", "72",
"KCC", "2.4G", "20M", "CCK", "2T", "02", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "02", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "02", "72",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "02", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "02", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "03", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "03", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "03", "56",
"IC", "2.4G", "20M", "CCK", "2T", "03", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "03", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "03", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "03", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "03", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "03", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "04", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "04", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "04", "56",
"IC", "2.4G", "20M", "CCK", "2T", "04", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "04", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "04", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "04", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "04", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "04", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "05", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "05", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "05", "56",
"IC", "2.4G", "20M", "CCK", "2T", "05", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "05", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "05", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "05", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "05", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "05", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "06", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "06", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "06", "56",
"IC", "2.4G", "20M", "CCK", "2T", "06", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "06", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "06", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "06", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "06", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "06", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "07", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "07", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "07", "56",
"IC", "2.4G", "20M", "CCK", "2T", "07", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "07", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "07", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "07", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "07", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "07", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "08", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "08", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "08", "56",
"IC", "2.4G", "20M", "CCK", "2T", "08", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "08", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "08", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "08", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "08", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "08", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "09", "76",
"ETSI", "2.4G", "20M", "CCK", "2T", "09", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "09", "56",
"IC", "2.4G", "20M", "CCK", "2T", "09", "76",
"KCC", "2.4G", "20M", "CCK", "2T", "09", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "09", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "09", "76",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "09", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "09", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "10", "72",
"ETSI", "2.4G", "20M", "CCK", "2T", "10", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "10", "56",
"IC", "2.4G", "20M", "CCK", "2T", "10", "72",
"KCC", "2.4G", "20M", "CCK", "2T", "10", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "10", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "10", "72",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "10", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "10", "62",
"FCC", "2.4G", "20M", "CCK", "2T", "11", "72",
"ETSI", "2.4G", "20M", "CCK", "2T", "11", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "11", "56",
"IC", "2.4G", "20M", "CCK", "2T", "11", "72",
"KCC", "2.4G", "20M", "CCK", "2T", "11", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "11", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "11", "72",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "11", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "11", "60",
"FCC", "2.4G", "20M", "CCK", "2T", "12", "52",
"ETSI", "2.4G", "20M", "CCK", "2T", "12", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "12", "56",
"IC", "2.4G", "20M", "CCK", "2T", "12", "52",
"KCC", "2.4G", "20M", "CCK", "2T", "12", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "12", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "12", "52",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "12", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "12", "52",
"FCC", "2.4G", "20M", "CCK", "2T", "13", "36",
"ETSI", "2.4G", "20M", "CCK", "2T", "13", "48",
"MKK", "2.4G", "20M", "CCK", "2T", "13", "56",
"IC", "2.4G", "20M", "CCK", "2T", "13", "36",
"KCC", "2.4G", "20M", "CCK", "2T", "13", "68",
"ACMA", "2.4G", "20M", "CCK", "2T", "13", "48",
"CHILE", "2.4G", "20M", "CCK", "2T", "13", "36",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "13", "48",
"MEXICO", "2.4G", "20M", "CCK", "2T", "13", "36",
"FCC", "2.4G", "20M", "CCK", "2T", "14", "127",
"ETSI", "2.4G", "20M", "CCK", "2T", "14", "127",
"MKK", "2.4G", "20M", "CCK", "2T", "14", "56",
"IC", "2.4G", "20M", "CCK", "2T", "14", "127",
"KCC", "2.4G", "20M", "CCK", "2T", "14", "127",
"ACMA", "2.4G", "20M", "CCK", "2T", "14", "127",
"CHILE", "2.4G", "20M", "CCK", "2T", "14", "127",
"UKRAINE", "2.4G", "20M", "CCK", "2T", "14", "127",
"MEXICO", "2.4G", "20M", "CCK", "2T", "14", "127",
"FCC", "2.4G", "20M", "OFDM", "1T", "01", "52",
"ETSI", "2.4G", "20M", "OFDM", "1T", "01", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "01", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "01", "52",
"KCC", "2.4G", "20M", "OFDM", "1T", "01", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "01", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "01", "52",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "01", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "01", "52",
"FCC", "2.4G", "20M", "OFDM", "1T", "02", "60",
"ETSI", "2.4G", "20M", "OFDM", "1T", "02", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "02", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "02", "60",
"KCC", "2.4G", "20M", "OFDM", "1T", "02", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "02", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "02", "60",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "02", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "02", "60",
"FCC", "2.4G", "20M", "OFDM", "1T", "03", "64",
"ETSI", "2.4G", "20M", "OFDM", "1T", "03", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "03", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "03", "64",
"KCC", "2.4G", "20M", "OFDM", "1T", "03", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "03", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "03", "64",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "03", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "03", "64",
"FCC", "2.4G", "20M", "OFDM", "1T", "04", "68",
"ETSI", "2.4G", "20M", "OFDM", "1T", "04", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "04", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "04", "68",
"KCC", "2.4G", "20M", "OFDM", "1T", "04", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "04", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "04", "68",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "04", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "04", "68",
"FCC", "2.4G", "20M", "OFDM", "1T", "05", "76",
"ETSI", "2.4G", "20M", "OFDM", "1T", "05", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "05", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "05", "76",
"KCC", "2.4G", "20M", "OFDM", "1T", "05", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "05", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "05", "76",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "05", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "05", "76",
"FCC", "2.4G", "20M", "OFDM", "1T", "06", "76",
"ETSI", "2.4G", "20M", "OFDM", "1T", "06", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "06", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "06", "76",
"KCC", "2.4G", "20M", "OFDM", "1T", "06", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "06", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "06", "76",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "06", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "06", "76",
"FCC", "2.4G", "20M", "OFDM", "1T", "07", "76",
"ETSI", "2.4G", "20M", "OFDM", "1T", "07", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "07", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "07", "76",
"KCC", "2.4G", "20M", "OFDM", "1T", "07", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "07", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "07", "76",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "07", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "07", "76",
"FCC", "2.4G", "20M", "OFDM", "1T", "08", "68",
"ETSI", "2.4G", "20M", "OFDM", "1T", "08", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "08", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "08", "68",
"KCC", "2.4G", "20M", "OFDM", "1T", "08", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "08", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "08", "68",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "08", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "08", "68",
"FCC", "2.4G", "20M", "OFDM", "1T", "09", "64",
"ETSI", "2.4G", "20M", "OFDM", "1T", "09", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "09", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "09", "64",
"KCC", "2.4G", "20M", "OFDM", "1T", "09", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "09", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "09", "64",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "09", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "09", "64",
"FCC", "2.4G", "20M", "OFDM", "1T", "10", "60",
"ETSI", "2.4G", "20M", "OFDM", "1T", "10", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "10", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "10", "60",
"KCC", "2.4G", "20M", "OFDM", "1T", "10", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "10", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "10", "60",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "10", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "10", "60",
"FCC", "2.4G", "20M", "OFDM", "1T", "11", "52",
"ETSI", "2.4G", "20M", "OFDM", "1T", "11", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "11", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "11", "52",
"KCC", "2.4G", "20M", "OFDM", "1T", "11", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "11", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "11", "52",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "11", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "11", "52",
"FCC", "2.4G", "20M", "OFDM", "1T", "12", "40",
"ETSI", "2.4G", "20M", "OFDM", "1T", "12", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "12", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "12", "40",
"KCC", "2.4G", "20M", "OFDM", "1T", "12", "76",
"ACMA", "2.4G", "20M", "OFDM", "1T", "12", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "12", "40",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "12", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "12", "40",
"FCC", "2.4G", "20M", "OFDM", "1T", "13", "28",
"ETSI", "2.4G", "20M", "OFDM", "1T", "13", "60",
"MKK", "2.4G", "20M", "OFDM", "1T", "13", "76",
"IC", "2.4G", "20M", "OFDM", "1T", "13", "28",
"KCC", "2.4G", "20M", "OFDM", "1T", "13", "70",
"ACMA", "2.4G", "20M", "OFDM", "1T", "13", "60",
"CHILE", "2.4G", "20M", "OFDM", "1T", "13", "28",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "13", "60",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "13", "28",
"FCC", "2.4G", "20M", "OFDM", "1T", "14", "127",
"ETSI", "2.4G", "20M", "OFDM", "1T", "14", "127",
"MKK", "2.4G", "20M", "OFDM", "1T", "14", "127",
"IC", "2.4G", "20M", "OFDM", "1T", "14", "127",
"KCC", "2.4G", "20M", "OFDM", "1T", "14", "127",
"ACMA", "2.4G", "20M", "OFDM", "1T", "14", "127",
"CHILE", "2.4G", "20M", "OFDM", "1T", "14", "127",
"UKRAINE", "2.4G", "20M", "OFDM", "1T", "14", "127",
"MEXICO", "2.4G", "20M", "OFDM", "1T", "14", "127",
"FCC", "2.4G", "20M", "OFDM", "2T", "01", "52",
"ETSI", "2.4G", "20M", "OFDM", "2T", "01", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "01", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "01", "52",
"KCC", "2.4G", "20M", "OFDM", "2T", "01", "68",
"ACMA", "2.4G", "20M", "OFDM", "2T", "01", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "01", "52",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "01", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "01", "52",
"FCC", "2.4G", "20M", "OFDM", "2T", "02", "60",
"ETSI", "2.4G", "20M", "OFDM", "2T", "02", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "02", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "02", "60",
"KCC", "2.4G", "20M", "OFDM", "2T", "02", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "02", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "02", "60",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "02", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "02", "60",
"FCC", "2.4G", "20M", "OFDM", "2T", "03", "64",
"ETSI", "2.4G", "20M", "OFDM", "2T", "03", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "03", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "03", "64",
"KCC", "2.4G", "20M", "OFDM", "2T", "03", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "03", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "03", "64",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "03", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "03", "64",
"FCC", "2.4G", "20M", "OFDM", "2T", "04", "68",
"ETSI", "2.4G", "20M", "OFDM", "2T", "04", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "04", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "04", "68",
"KCC", "2.4G", "20M", "OFDM", "2T", "04", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "04", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "04", "68",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "04", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "04", "68",
"FCC", "2.4G", "20M", "OFDM", "2T", "05", "76",
"ETSI", "2.4G", "20M", "OFDM", "2T", "05", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "05", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "05", "76",
"KCC", "2.4G", "20M", "OFDM", "2T", "05", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "05", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "05", "76",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "05", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "05", "76",
"FCC", "2.4G", "20M", "OFDM", "2T", "06", "76",
"ETSI", "2.4G", "20M", "OFDM", "2T", "06", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "06", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "06", "76",
"KCC", "2.4G", "20M", "OFDM", "2T", "06", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "06", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "06", "76",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "06", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "06", "76",
"FCC", "2.4G", "20M", "OFDM", "2T", "07", "76",
"ETSI", "2.4G", "20M", "OFDM", "2T", "07", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "07", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "07", "76",
"KCC", "2.4G", "20M", "OFDM", "2T", "07", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "07", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "07", "76",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "07", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "07", "76",
"FCC", "2.4G", "20M", "OFDM", "2T", "08", "68",
"ETSI", "2.4G", "20M", "OFDM", "2T", "08", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "08", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "08", "68",
"KCC", "2.4G", "20M", "OFDM", "2T", "08", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "08", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "08", "68",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "08", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "08", "68",
"FCC", "2.4G", "20M", "OFDM", "2T", "09", "64",
"ETSI", "2.4G", "20M", "OFDM", "2T", "09", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "09", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "09", "64",
"KCC", "2.4G", "20M", "OFDM", "2T", "09", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "09", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "09", "64",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "09", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "09", "64",
"FCC", "2.4G", "20M", "OFDM", "2T", "10", "60",
"ETSI", "2.4G", "20M", "OFDM", "2T", "10", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "10", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "10", "60",
"KCC", "2.4G", "20M", "OFDM", "2T", "10", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "10", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "10", "60",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "10", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "10", "60",
"FCC", "2.4G", "20M", "OFDM", "2T", "11", "52",
"ETSI", "2.4G", "20M", "OFDM", "2T", "11", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "11", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "11", "52",
"KCC", "2.4G", "20M", "OFDM", "2T", "11", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "11", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "11", "52",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "11", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "11", "52",
"FCC", "2.4G", "20M", "OFDM", "2T", "12", "40",
"ETSI", "2.4G", "20M", "OFDM", "2T", "12", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "12", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "12", "40",
"KCC", "2.4G", "20M", "OFDM", "2T", "12", "70",
"ACMA", "2.4G", "20M", "OFDM", "2T", "12", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "12", "40",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "12", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "12", "40",
"FCC", "2.4G", "20M", "OFDM", "2T", "13", "28",
"ETSI", "2.4G", "20M", "OFDM", "2T", "13", "48",
"MKK", "2.4G", "20M", "OFDM", "2T", "13", "64",
"IC", "2.4G", "20M", "OFDM", "2T", "13", "28",
"KCC", "2.4G", "20M", "OFDM", "2T", "13", "62",
"ACMA", "2.4G", "20M", "OFDM", "2T", "13", "48",
"CHILE", "2.4G", "20M", "OFDM", "2T", "13", "28",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "13", "48",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "13", "28",
"FCC", "2.4G", "20M", "OFDM", "2T", "14", "127",
"ETSI", "2.4G", "20M", "OFDM", "2T", "14", "127",
"MKK", "2.4G", "20M", "OFDM", "2T", "14", "127",
"IC", "2.4G", "20M", "OFDM", "2T", "14", "127",
"KCC", "2.4G", "20M", "OFDM", "2T", "14", "127",
"ACMA", "2.4G", "20M", "OFDM", "2T", "14", "127",
"CHILE", "2.4G", "20M", "OFDM", "2T", "14", "127",
"UKRAINE", "2.4G", "20M", "OFDM", "2T", "14", "127",
"MEXICO", "2.4G", "20M", "OFDM", "2T", "14", "127",
"FCC", "2.4G", "20M", "HT", "1T", "01", "52",
"ETSI", "2.4G", "20M", "HT", "1T", "01", "60",
"MKK", "2.4G", "20M", "HT", "1T", "01", "76",
"IC", "2.4G", "20M", "HT", "1T", "01", "52",
"KCC", "2.4G", "20M", "HT", "1T", "01", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "01", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "01", "52",
"UKRAINE", "2.4G", "20M", "HT", "1T", "01", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "01", "52",
"FCC", "2.4G", "20M", "HT", "1T", "02", "60",
"ETSI", "2.4G", "20M", "HT", "1T", "02", "60",
"MKK", "2.4G", "20M", "HT", "1T", "02", "76",
"IC", "2.4G", "20M", "HT", "1T", "02", "60",
"KCC", "2.4G", "20M", "HT", "1T", "02", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "02", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "02", "60",
"UKRAINE", "2.4G", "20M", "HT", "1T", "02", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "02", "60",
"FCC", "2.4G", "20M", "HT", "1T", "03", "64",
"ETSI", "2.4G", "20M", "HT", "1T", "03", "60",
"MKK", "2.4G", "20M", "HT", "1T", "03", "76",
"IC", "2.4G", "20M", "HT", "1T", "03", "64",
"KCC", "2.4G", "20M", "HT", "1T", "03", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "03", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "03", "64",
"UKRAINE", "2.4G", "20M", "HT", "1T", "03", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "03", "64",
"FCC", "2.4G", "20M", "HT", "1T", "04", "68",
"ETSI", "2.4G", "20M", "HT", "1T", "04", "60",
"MKK", "2.4G", "20M", "HT", "1T", "04", "76",
"IC", "2.4G", "20M", "HT", "1T", "04", "68",
"KCC", "2.4G", "20M", "HT", "1T", "04", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "04", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "04", "68",
"UKRAINE", "2.4G", "20M", "HT", "1T", "04", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "04", "68",
"FCC", "2.4G", "20M", "HT", "1T", "05", "76",
"ETSI", "2.4G", "20M", "HT", "1T", "05", "60",
"MKK", "2.4G", "20M", "HT", "1T", "05", "76",
"IC", "2.4G", "20M", "HT", "1T", "05", "76",
"KCC", "2.4G", "20M", "HT", "1T", "05", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "05", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "05", "76",
"UKRAINE", "2.4G", "20M", "HT", "1T", "05", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "05", "76",
"FCC", "2.4G", "20M", "HT", "1T", "06", "76",
"ETSI", "2.4G", "20M", "HT", "1T", "06", "60",
"MKK", "2.4G", "20M", "HT", "1T", "06", "76",
"IC", "2.4G", "20M", "HT", "1T", "06", "76",
"KCC", "2.4G", "20M", "HT", "1T", "06", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "06", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "06", "76",
"UKRAINE", "2.4G", "20M", "HT", "1T", "06", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "06", "76",
"FCC", "2.4G", "20M", "HT", "1T", "07", "76",
"ETSI", "2.4G", "20M", "HT", "1T", "07", "60",
"MKK", "2.4G", "20M", "HT", "1T", "07", "76",
"IC", "2.4G", "20M", "HT", "1T", "07", "76",
"KCC", "2.4G", "20M", "HT", "1T", "07", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "07", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "07", "76",
"UKRAINE", "2.4G", "20M", "HT", "1T", "07", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "07", "76",
"FCC", "2.4G", "20M", "HT", "1T", "08", "68",
"ETSI", "2.4G", "20M", "HT", "1T", "08", "60",
"MKK", "2.4G", "20M", "HT", "1T", "08", "76",
"IC", "2.4G", "20M", "HT", "1T", "08", "68",
"KCC", "2.4G", "20M", "HT", "1T", "08", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "08", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "08", "68",
"UKRAINE", "2.4G", "20M", "HT", "1T", "08", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "08", "68",
"FCC", "2.4G", "20M", "HT", "1T", "09", "64",
"ETSI", "2.4G", "20M", "HT", "1T", "09", "60",
"MKK", "2.4G", "20M", "HT", "1T", "09", "76",
"IC", "2.4G", "20M", "HT", "1T", "09", "64",
"KCC", "2.4G", "20M", "HT", "1T", "09", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "09", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "09", "64",
"UKRAINE", "2.4G", "20M", "HT", "1T", "09", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "09", "64",
"FCC", "2.4G", "20M", "HT", "1T", "10", "60",
"ETSI", "2.4G", "20M", "HT", "1T", "10", "60",
"MKK", "2.4G", "20M", "HT", "1T", "10", "76",
"IC", "2.4G", "20M", "HT", "1T", "10", "60",
"KCC", "2.4G", "20M", "HT", "1T", "10", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "10", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "10", "60",
"UKRAINE", "2.4G", "20M", "HT", "1T", "10", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "10", "60",
"FCC", "2.4G", "20M", "HT", "1T", "11", "52",
"ETSI", "2.4G", "20M", "HT", "1T", "11", "60",
"MKK", "2.4G", "20M", "HT", "1T", "11", "76",
"IC", "2.4G", "20M", "HT", "1T", "11", "52",
"KCC", "2.4G", "20M", "HT", "1T", "11", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "11", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "11", "52",
"UKRAINE", "2.4G", "20M", "HT", "1T", "11", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "11", "52",
"FCC", "2.4G", "20M", "HT", "1T", "12", "40",
"ETSI", "2.4G", "20M", "HT", "1T", "12", "60",
"MKK", "2.4G", "20M", "HT", "1T", "12", "76",
"IC", "2.4G", "20M", "HT", "1T", "12", "40",
"KCC", "2.4G", "20M", "HT", "1T", "12", "76",
"ACMA", "2.4G", "20M", "HT", "1T", "12", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "12", "40",
"UKRAINE", "2.4G", "20M", "HT", "1T", "12", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "12", "40",
"FCC", "2.4G", "20M", "HT", "1T", "13", "28",
"ETSI", "2.4G", "20M", "HT", "1T", "13", "60",
"MKK", "2.4G", "20M", "HT", "1T", "13", "76",
"IC", "2.4G", "20M", "HT", "1T", "13", "28",
"KCC", "2.4G", "20M", "HT", "1T", "13", "72",
"ACMA", "2.4G", "20M", "HT", "1T", "13", "60",
"CHILE", "2.4G", "20M", "HT", "1T", "13", "28",
"UKRAINE", "2.4G", "20M", "HT", "1T", "13", "60",
"MEXICO", "2.4G", "20M", "HT", "1T", "13", "28",
"FCC", "2.4G", "20M", "HT", "1T", "14", "127",
"ETSI", "2.4G", "20M", "HT", "1T", "14", "127",
"MKK", "2.4G", "20M", "HT", "1T", "14", "127",
"IC", "2.4G", "20M", "HT", "1T", "14", "127",
"KCC", "2.4G", "20M", "HT", "1T", "14", "127",
"ACMA", "2.4G", "20M", "HT", "1T", "14", "127",
"CHILE", "2.4G", "20M", "HT", "1T", "14", "127",
"UKRAINE", "2.4G", "20M", "HT", "1T", "14", "127",
"MEXICO", "2.4G", "20M", "HT", "1T", "14", "127",
"FCC", "2.4G", "20M", "HT", "2T", "01", "52",
"ETSI", "2.4G", "20M", "HT", "2T", "01", "36",
"MKK", "2.4G", "20M", "HT", "2T", "01", "66",
"IC", "2.4G", "20M", "HT", "2T", "01", "52",
"KCC", "2.4G", "20M", "HT", "2T", "01", "68",
"ACMA", "2.4G", "20M", "HT", "2T", "01", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "01", "52",
"UKRAINE", "2.4G", "20M", "HT", "2T", "01", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "01", "52",
"FCC", "2.4G", "20M", "HT", "2T", "02", "60",
"ETSI", "2.4G", "20M", "HT", "2T", "02", "36",
"MKK", "2.4G", "20M", "HT", "2T", "02", "66",
"IC", "2.4G", "20M", "HT", "2T", "02", "60",
"KCC", "2.4G", "20M", "HT", "2T", "02", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "02", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "02", "60",
"UKRAINE", "2.4G", "20M", "HT", "2T", "02", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "02", "60",
"FCC", "2.4G", "20M", "HT", "2T", "03", "64",
"ETSI", "2.4G", "20M", "HT", "2T", "03", "36",
"MKK", "2.4G", "20M", "HT", "2T", "03", "66",
"IC", "2.4G", "20M", "HT", "2T", "03", "64",
"KCC", "2.4G", "20M", "HT", "2T", "03", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "03", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "03", "64",
"UKRAINE", "2.4G", "20M", "HT", "2T", "03", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "03", "64",
"FCC", "2.4G", "20M", "HT", "2T", "04", "68",
"ETSI", "2.4G", "20M", "HT", "2T", "04", "36",
"MKK", "2.4G", "20M", "HT", "2T", "04", "66",
"IC", "2.4G", "20M", "HT", "2T", "04", "68",
"KCC", "2.4G", "20M", "HT", "2T", "04", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "04", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "04", "68",
"UKRAINE", "2.4G", "20M", "HT", "2T", "04", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "04", "68",
"FCC", "2.4G", "20M", "HT", "2T", "05", "76",
"ETSI", "2.4G", "20M", "HT", "2T", "05", "36",
"MKK", "2.4G", "20M", "HT", "2T", "05", "66",
"IC", "2.4G", "20M", "HT", "2T", "05", "76",
"KCC", "2.4G", "20M", "HT", "2T", "05", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "05", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "05", "76",
"UKRAINE", "2.4G", "20M", "HT", "2T", "05", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "05", "76",
"FCC", "2.4G", "20M", "HT", "2T", "06", "76",
"ETSI", "2.4G", "20M", "HT", "2T", "06", "36",
"MKK", "2.4G", "20M", "HT", "2T", "06", "66",
"IC", "2.4G", "20M", "HT", "2T", "06", "76",
"KCC", "2.4G", "20M", "HT", "2T", "06", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "06", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "06", "76",
"UKRAINE", "2.4G", "20M", "HT", "2T", "06", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "06", "76",
"FCC", "2.4G", "20M", "HT", "2T", "07", "76",
"ETSI", "2.4G", "20M", "HT", "2T", "07", "36",
"MKK", "2.4G", "20M", "HT", "2T", "07", "66",
"IC", "2.4G", "20M", "HT", "2T", "07", "76",
"KCC", "2.4G", "20M", "HT", "2T", "07", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "07", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "07", "76",
"UKRAINE", "2.4G", "20M", "HT", "2T", "07", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "07", "76",
"FCC", "2.4G", "20M", "HT", "2T", "08", "68",
"ETSI", "2.4G", "20M", "HT", "2T", "08", "36",
"MKK", "2.4G", "20M", "HT", "2T", "08", "66",
"IC", "2.4G", "20M", "HT", "2T", "08", "68",
"KCC", "2.4G", "20M", "HT", "2T", "08", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "08", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "08", "68",
"UKRAINE", "2.4G", "20M", "HT", "2T", "08", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "08", "68",
"FCC", "2.4G", "20M", "HT", "2T", "09", "64",
"ETSI", "2.4G", "20M", "HT", "2T", "09", "36",
"MKK", "2.4G", "20M", "HT", "2T", "09", "66",
"IC", "2.4G", "20M", "HT", "2T", "09", "64",
"KCC", "2.4G", "20M", "HT", "2T", "09", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "09", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "09", "64",
"UKRAINE", "2.4G", "20M", "HT", "2T", "09", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "09", "64",
"FCC", "2.4G", "20M", "HT", "2T", "10", "60",
"ETSI", "2.4G", "20M", "HT", "2T", "10", "36",
"MKK", "2.4G", "20M", "HT", "2T", "10", "66",
"IC", "2.4G", "20M", "HT", "2T", "10", "60",
"KCC", "2.4G", "20M", "HT", "2T", "10", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "10", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "10", "60",
"UKRAINE", "2.4G", "20M", "HT", "2T", "10", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "10", "60",
"FCC", "2.4G", "20M", "HT", "2T", "11", "52",
"ETSI", "2.4G", "20M", "HT", "2T", "11", "36",
"MKK", "2.4G", "20M", "HT", "2T", "11", "66",
"IC", "2.4G", "20M", "HT", "2T", "11", "52",
"KCC", "2.4G", "20M", "HT", "2T", "11", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "11", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "11", "52",
"UKRAINE", "2.4G", "20M", "HT", "2T", "11", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "11", "52",
"FCC", "2.4G", "20M", "HT", "2T", "12", "40",
"ETSI", "2.4G", "20M", "HT", "2T", "12", "36",
"MKK", "2.4G", "20M", "HT", "2T", "12", "66",
"IC", "2.4G", "20M", "HT", "2T", "12", "40",
"KCC", "2.4G", "20M", "HT", "2T", "12", "70",
"ACMA", "2.4G", "20M", "HT", "2T", "12", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "12", "40",
"UKRAINE", "2.4G", "20M", "HT", "2T", "12", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "12", "40",
"FCC", "2.4G", "20M", "HT", "2T", "13", "28",
"ETSI", "2.4G", "20M", "HT", "2T", "13", "36",
"MKK", "2.4G", "20M", "HT", "2T", "13", "66",
"IC", "2.4G", "20M", "HT", "2T", "13", "28",
"KCC", "2.4G", "20M", "HT", "2T", "13", "62",
"ACMA", "2.4G", "20M", "HT", "2T", "13", "36",
"CHILE", "2.4G", "20M", "HT", "2T", "13", "28",
"UKRAINE", "2.4G", "20M", "HT", "2T", "13", "36",
"MEXICO", "2.4G", "20M", "HT", "2T", "13", "28",
"FCC", "2.4G", "20M", "HT", "2T", "14", "127",
"ETSI", "2.4G", "20M", "HT", "2T", "14", "127",
"MKK", "2.4G", "20M", "HT", "2T", "14", "127",
"IC", "2.4G", "20M", "HT", "2T", "14", "127",
"KCC", "2.4G", "20M", "HT", "2T", "14", "127",
"ACMA", "2.4G", "20M", "HT", "2T", "14", "127",
"CHILE", "2.4G", "20M", "HT", "2T", "14", "127",
"UKRAINE", "2.4G", "20M", "HT", "2T", "14", "127",
"MEXICO", "2.4G", "20M", "HT", "2T", "14", "127",
"FCC", "2.4G", "40M", "HT", "1T", "01", "127",
"ETSI", "2.4G", "40M", "HT", "1T", "01", "127",
"MKK", "2.4G", "40M", "HT", "1T", "01", "127",
"IC", "2.4G", "40M", "HT", "1T", "01", "127",
"KCC", "2.4G", "40M", "HT", "1T", "01", "127",
"ACMA", "2.4G", "40M", "HT", "1T", "01", "127",
"CHILE", "2.4G", "40M", "HT", "1T", "01", "127",
"UKRAINE", "2.4G", "40M", "HT", "1T", "01", "127",
"MEXICO", "2.4G", "40M", "HT", "1T", "01", "127",
"FCC", "2.4G", "40M", "HT", "1T", "02", "127",
"ETSI", "2.4G", "40M", "HT", "1T", "02", "127",
"MKK", "2.4G", "40M", "HT", "1T", "02", "127",
"IC", "2.4G", "40M", "HT", "1T", "02", "127",
"KCC", "2.4G", "40M", "HT", "1T", "02", "127",
"ACMA", "2.4G", "40M", "HT", "1T", "02", "127",
"CHILE", "2.4G", "40M", "HT", "1T", "02", "127",
"UKRAINE", "2.4G", "40M", "HT", "1T", "02", "127",
"MEXICO", "2.4G", "40M", "HT", "1T", "02", "127",
"FCC", "2.4G", "40M", "HT", "1T", "03", "52",
"ETSI", "2.4G", "40M", "HT", "1T", "03", "60",
"MKK", "2.4G", "40M", "HT", "1T", "03", "72",
"IC", "2.4G", "40M", "HT", "1T", "03", "52",
"KCC", "2.4G", "40M", "HT", "1T", "03", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "03", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "03", "52",
"UKRAINE", "2.4G", "40M", "HT", "1T", "03", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "03", "52",
"FCC", "2.4G", "40M", "HT", "1T", "04", "52",
"ETSI", "2.4G", "40M", "HT", "1T", "04", "60",
"MKK", "2.4G", "40M", "HT", "1T", "04", "72",
"IC", "2.4G", "40M", "HT", "1T", "04", "52",
"KCC", "2.4G", "40M", "HT", "1T", "04", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "04", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "04", "52",
"UKRAINE", "2.4G", "40M", "HT", "1T", "04", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "04", "52",
"FCC", "2.4G", "40M", "HT", "1T", "05", "60",
"ETSI", "2.4G", "40M", "HT", "1T", "05", "60",
"MKK", "2.4G", "40M", "HT", "1T", "05", "72",
"IC", "2.4G", "40M", "HT", "1T", "05", "60",
"KCC", "2.4G", "40M", "HT", "1T", "05", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "05", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "05", "60",
"UKRAINE", "2.4G", "40M", "HT", "1T", "05", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "05", "60",
"FCC", "2.4G", "40M", "HT", "1T", "06", "64",
"ETSI", "2.4G", "40M", "HT", "1T", "06", "60",
"MKK", "2.4G", "40M", "HT", "1T", "06", "72",
"IC", "2.4G", "40M", "HT", "1T", "06", "64",
"KCC", "2.4G", "40M", "HT", "1T", "06", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "06", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "06", "64",
"UKRAINE", "2.4G", "40M", "HT", "1T", "06", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "06", "64",
"FCC", "2.4G", "40M", "HT", "1T", "07", "60",
"ETSI", "2.4G", "40M", "HT", "1T", "07", "60",
"MKK", "2.4G", "40M", "HT", "1T", "07", "72",
"IC", "2.4G", "40M", "HT", "1T", "07", "60",
"KCC", "2.4G", "40M", "HT", "1T", "07", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "07", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "07", "60",
"UKRAINE", "2.4G", "40M", "HT", "1T", "07", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "07", "60",
"FCC", "2.4G", "40M", "HT", "1T", "08", "52",
"ETSI", "2.4G", "40M", "HT", "1T", "08", "60",
"MKK", "2.4G", "40M", "HT", "1T", "08", "72",
"IC", "2.4G", "40M", "HT", "1T", "08", "52",
"KCC", "2.4G", "40M", "HT", "1T", "08", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "08", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "08", "52",
"UKRAINE", "2.4G", "40M", "HT", "1T", "08", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "08", "52",
"FCC", "2.4G", "40M", "HT", "1T", "09", "52",
"ETSI", "2.4G", "40M", "HT", "1T", "09", "60",
"MKK", "2.4G", "40M", "HT", "1T", "09", "72",
"IC", "2.4G", "40M", "HT", "1T", "09", "52",
"KCC", "2.4G", "40M", "HT", "1T", "09", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "09", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "09", "52",
"UKRAINE", "2.4G", "40M", "HT", "1T", "09", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "09", "52",
"FCC", "2.4G", "40M", "HT", "1T", "10", "40",
"ETSI", "2.4G", "40M", "HT", "1T", "10", "60",
"MKK", "2.4G", "40M", "HT", "1T", "10", "72",
"IC", "2.4G", "40M", "HT", "1T", "10", "40",
"KCC", "2.4G", "40M", "HT", "1T", "10", "72",
"ACMA", "2.4G", "40M", "HT", "1T", "10", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "10", "40",
"UKRAINE", "2.4G", "40M", "HT", "1T", "10", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "10", "40",
"FCC", "2.4G", "40M", "HT", "1T", "11", "28",
"ETSI", "2.4G", "40M", "HT", "1T", "11", "60",
"MKK", "2.4G", "40M", "HT", "1T", "11", "72",
"IC", "2.4G", "40M", "HT", "1T", "11", "28",
"KCC", "2.4G", "40M", "HT", "1T", "11", "70",
"ACMA", "2.4G", "40M", "HT", "1T", "11", "60",
"CHILE", "2.4G", "40M", "HT", "1T", "11", "28",
"UKRAINE", "2.4G", "40M", "HT", "1T", "11", "60",
"MEXICO", "2.4G", "40M", "HT", "1T", "11", "28",
"FCC", "2.4G", "40M", "HT", "1T", "12", "127",
"ETSI", "2.4G", "40M", "HT", "1T", "12", "127",
"MKK", "2.4G", "40M", "HT", "1T", "12", "127",
"IC", "2.4G", "40M", "HT", "1T", "12", "127",
"KCC", "2.4G", "40M", "HT", "1T", "12", "127",
"ACMA", "2.4G", "40M", "HT", "1T", "12", "127",
"CHILE", "2.4G", "40M", "HT", "1T", "12", "127",
"UKRAINE", "2.4G", "40M", "HT", "1T", "12", "127",
"MEXICO", "2.4G", "40M", "HT", "1T", "12", "127",
"FCC", "2.4G", "40M", "HT", "1T", "13", "127",
"ETSI", "2.4G", "40M", "HT", "1T", "13", "127",
"MKK", "2.4G", "40M", "HT", "1T", "13", "127",
"IC", "2.4G", "40M", "HT", "1T", "13", "127",
"KCC", "2.4G", "40M", "HT", "1T", "13", "127",
"ACMA", "2.4G", "40M", "HT", "1T", "13", "127",
"CHILE", "2.4G", "40M", "HT", "1T", "13", "127",
"UKRAINE", "2.4G", "40M", "HT", "1T", "13", "127",
"MEXICO", "2.4G", "40M", "HT", "1T", "13", "127",
"FCC", "2.4G", "40M", "HT", "1T", "14", "127",
"ETSI", "2.4G", "40M", "HT", "1T", "14", "127",
"MKK", "2.4G", "40M", "HT", "1T", "14", "127",
"IC", "2.4G", "40M", "HT", "1T", "14", "127",
"KCC", "2.4G", "40M", "HT", "1T", "14", "127",
"ACMA", "2.4G", "40M", "HT", "1T", "14", "127",
"CHILE", "2.4G", "40M", "HT", "1T", "14", "127",
"UKRAINE", "2.4G", "40M", "HT", "1T", "14", "127",
"MEXICO", "2.4G", "40M", "HT", "1T", "14", "127",
"FCC", "2.4G", "40M", "HT", "2T", "01", "127",
"ETSI", "2.4G", "40M", "HT", "2T", "01", "127",
"MKK", "2.4G", "40M", "HT", "2T", "01", "127",
"IC", "2.4G", "40M", "HT", "2T", "01", "127",
"KCC", "2.4G", "40M", "HT", "2T", "01", "127",
"ACMA", "2.4G", "40M", "HT", "2T", "01", "127",
"CHILE", "2.4G", "40M", "HT", "2T", "01", "127",
"UKRAINE", "2.4G", "40M", "HT", "2T", "01", "127",
"MEXICO", "2.4G", "40M", "HT", "2T", "01", "127",
"FCC", "2.4G", "40M", "HT", "2T", "02", "127",
"ETSI", "2.4G", "40M", "HT", "2T", "02", "127",
"MKK", "2.4G", "40M", "HT", "2T", "02", "127",
"IC", "2.4G", "40M", "HT", "2T", "02", "127",
"KCC", "2.4G", "40M", "HT", "2T", "02", "127",
"ACMA", "2.4G", "40M", "HT", "2T", "02", "127",
"CHILE", "2.4G", "40M", "HT", "2T", "02", "127",
"UKRAINE", "2.4G", "40M", "HT", "2T", "02", "127",
"MEXICO", "2.4G", "40M", "HT", "2T", "02", "127",
"FCC", "2.4G", "40M", "HT", "2T", "03", "48",
"ETSI", "2.4G", "40M", "HT", "2T", "03", "36",
"MKK", "2.4G", "40M", "HT", "2T", "03", "66",
"IC", "2.4G", "40M", "HT", "2T", "03", "48",
"KCC", "2.4G", "40M", "HT", "2T", "03", "66",
"ACMA", "2.4G", "40M", "HT", "2T", "03", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "03", "48",
"UKRAINE", "2.4G", "40M", "HT", "2T", "03", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "03", "48",
"FCC", "2.4G", "40M", "HT", "2T", "04", "48",
"ETSI", "2.4G", "40M", "HT", "2T", "04", "36",
"MKK", "2.4G", "40M", "HT", "2T", "04", "66",
"IC", "2.4G", "40M", "HT", "2T", "04", "48",
"KCC", "2.4G", "40M", "HT", "2T", "04", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "04", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "04", "48",
"UKRAINE", "2.4G", "40M", "HT", "2T", "04", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "04", "48",
"FCC", "2.4G", "40M", "HT", "2T", "05", "60",
"ETSI", "2.4G", "40M", "HT", "2T", "05", "36",
"MKK", "2.4G", "40M", "HT", "2T", "05", "66",
"IC", "2.4G", "40M", "HT", "2T", "05", "60",
"KCC", "2.4G", "40M", "HT", "2T", "05", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "05", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "05", "60",
"UKRAINE", "2.4G", "40M", "HT", "2T", "05", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "05", "60",
"FCC", "2.4G", "40M", "HT", "2T", "06", "64",
"ETSI", "2.4G", "40M", "HT", "2T", "06", "36",
"MKK", "2.4G", "40M", "HT", "2T", "06", "66",
"IC", "2.4G", "40M", "HT", "2T", "06", "64",
"KCC", "2.4G", "40M", "HT", "2T", "06", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "06", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "06", "64",
"UKRAINE", "2.4G", "40M", "HT", "2T", "06", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "06", "64",
"FCC", "2.4G", "40M", "HT", "2T", "07", "60",
"ETSI", "2.4G", "40M", "HT", "2T", "07", "36",
"MKK", "2.4G", "40M", "HT", "2T", "07", "66",
"IC", "2.4G", "40M", "HT", "2T", "07", "60",
"KCC", "2.4G", "40M", "HT", "2T", "07", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "07", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "07", "60",
"UKRAINE", "2.4G", "40M", "HT", "2T", "07", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "07", "60",
"FCC", "2.4G", "40M", "HT", "2T", "08", "52",
"ETSI", "2.4G", "40M", "HT", "2T", "08", "36",
"MKK", "2.4G", "40M", "HT", "2T", "08", "66",
"IC", "2.4G", "40M", "HT", "2T", "08", "52",
"KCC", "2.4G", "40M", "HT", "2T", "08", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "08", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "08", "52",
"UKRAINE", "2.4G", "40M", "HT", "2T", "08", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "08", "52",
"FCC", "2.4G", "40M", "HT", "2T", "09", "52",
"ETSI", "2.4G", "40M", "HT", "2T", "09", "36",
"MKK", "2.4G", "40M", "HT", "2T", "09", "66",
"IC", "2.4G", "40M", "HT", "2T", "09", "52",
"KCC", "2.4G", "40M", "HT", "2T", "09", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "09", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "09", "52",
"UKRAINE", "2.4G", "40M", "HT", "2T", "09", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "09", "52",
"FCC", "2.4G", "40M", "HT", "2T", "10", "40",
"ETSI", "2.4G", "40M", "HT", "2T", "10", "36",
"MKK", "2.4G", "40M", "HT", "2T", "10", "66",
"IC", "2.4G", "40M", "HT", "2T", "10", "40",
"KCC", "2.4G", "40M", "HT", "2T", "10", "70",
"ACMA", "2.4G", "40M", "HT", "2T", "10", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "10", "40",
"UKRAINE", "2.4G", "40M", "HT", "2T", "10", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "10", "40",
"FCC", "2.4G", "40M", "HT", "2T", "11", "26",
"ETSI", "2.4G", "40M", "HT", "2T", "11", "36",
"MKK", "2.4G", "40M", "HT", "2T", "11", "66",
"IC", "2.4G", "40M", "HT", "2T", "11", "26",
"KCC", "2.4G", "40M", "HT", "2T", "11", "66",
"ACMA", "2.4G", "40M", "HT", "2T", "11", "36",
"CHILE", "2.4G", "40M", "HT", "2T", "11", "26",
"UKRAINE", "2.4G", "40M", "HT", "2T", "11", "36",
"MEXICO", "2.4G", "40M", "HT", "2T", "11", "26",
"FCC", "2.4G", "40M", "HT", "2T", "12", "127",
"ETSI", "2.4G", "40M", "HT", "2T", "12", "127",
"MKK", "2.4G", "40M", "HT", "2T", "12", "127",
"IC", "2.4G", "40M", "HT", "2T", "12", "127",
"KCC", "2.4G", "40M", "HT", "2T", "12", "127",
"ACMA", "2.4G", "40M", "HT", "2T", "12", "127",
"CHILE", "2.4G", "40M", "HT", "2T", "12", "127",
"UKRAINE", "2.4G", "40M", "HT", "2T", "12", "127",
"MEXICO", "2.4G", "40M", "HT", "2T", "12", "127",
"FCC", "2.4G", "40M", "HT", "2T", "13", "127",
"ETSI", "2.4G", "40M", "HT", "2T", "13", "127",
"MKK", "2.4G", "40M", "HT", "2T", "13", "127",
"IC", "2.4G", "40M", "HT", "2T", "13", "127",
"KCC", "2.4G", "40M", "HT", "2T", "13", "127",
"ACMA", "2.4G", "40M", "HT", "2T", "13", "127",
"CHILE", "2.4G", "40M", "HT", "2T", "13", "127",
"UKRAINE", "2.4G", "40M", "HT", "2T", "13", "127",
"MEXICO", "2.4G", "40M", "HT", "2T", "13", "127",
"FCC", "2.4G", "40M", "HT", "2T", "14", "127",
"ETSI", "2.4G", "40M", "HT", "2T", "14", "127",
"MKK", "2.4G", "40M", "HT", "2T", "14", "127",
"IC", "2.4G", "40M", "HT", "2T", "14", "127",
"KCC", "2.4G", "40M", "HT", "2T", "14", "127",
"ACMA", "2.4G", "40M", "HT", "2T", "14", "127",
"CHILE", "2.4G", "40M", "HT", "2T", "14", "127",
"UKRAINE", "2.4G", "40M", "HT", "2T", "14", "127",
"MEXICO", "2.4G", "40M", "HT", "2T", "14", "127",
"FCC", "5G", "20M", "OFDM", "1T", "36", "74",
"ETSI", "5G", "20M", "OFDM", "1T", "36", "62",
"MKK", "5G", "20M", "OFDM", "1T", "36", "60",
"IC", "5G", "20M", "OFDM", "1T", "36", "62",
"KCC", "5G", "20M", "OFDM", "1T", "36", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "36", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "36", "64",
"UKRAINE", "5G", "20M", "OFDM", "1T", "36", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "36", "62",
"FCC", "5G", "20M", "OFDM", "1T", "40", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "40", "62",
"MKK", "5G", "20M", "OFDM", "1T", "40", "62",
"IC", "5G", "20M", "OFDM", "1T", "40", "62",
"KCC", "5G", "20M", "OFDM", "1T", "40", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "40", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "40", "64",
"UKRAINE", "5G", "20M", "OFDM", "1T", "40", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "40", "62",
"FCC", "5G", "20M", "OFDM", "1T", "44", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "44", "62",
"MKK", "5G", "20M", "OFDM", "1T", "44", "62",
"IC", "5G", "20M", "OFDM", "1T", "44", "62",
"KCC", "5G", "20M", "OFDM", "1T", "44", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "44", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "44", "64",
"UKRAINE", "5G", "20M", "OFDM", "1T", "44", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "44", "62",
"FCC", "5G", "20M", "OFDM", "1T", "48", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "48", "62",
"MKK", "5G", "20M", "OFDM", "1T", "48", "62",
"IC", "5G", "20M", "OFDM", "1T", "48", "62",
"KCC", "5G", "20M", "OFDM", "1T", "48", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "48", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "48", "64",
"UKRAINE", "5G", "20M", "OFDM", "1T", "48", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "48", "62",
"FCC", "5G", "20M", "OFDM", "1T", "52", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "52", "62",
"MKK", "5G", "20M", "OFDM", "1T", "52", "62",
"IC", "5G", "20M", "OFDM", "1T", "52", "64",
"KCC", "5G", "20M", "OFDM", "1T", "52", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "52", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "52", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "52", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "52", "76",
"FCC", "5G", "20M", "OFDM", "1T", "56", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "56", "62",
"MKK", "5G", "20M", "OFDM", "1T", "56", "62",
"IC", "5G", "20M", "OFDM", "1T", "56", "64",
"KCC", "5G", "20M", "OFDM", "1T", "56", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "56", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "56", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "56", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "56", "76",
"FCC", "5G", "20M", "OFDM", "1T", "60", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "60", "62",
"MKK", "5G", "20M", "OFDM", "1T", "60", "62",
"IC", "5G", "20M", "OFDM", "1T", "60", "64",
"KCC", "5G", "20M", "OFDM", "1T", "60", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "60", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "60", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "60", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "60", "76",
"FCC", "5G", "20M", "OFDM", "1T", "64", "74",
"ETSI", "5G", "20M", "OFDM", "1T", "64", "62",
"MKK", "5G", "20M", "OFDM", "1T", "64", "60",
"IC", "5G", "20M", "OFDM", "1T", "64", "64",
"KCC", "5G", "20M", "OFDM", "1T", "64", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "64", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "64", "74",
"UKRAINE", "5G", "20M", "OFDM", "1T", "64", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "64", "74",
"FCC", "5G", "20M", "OFDM", "1T", "100", "72",
"ETSI", "5G", "20M", "OFDM", "1T", "100", "62",
"MKK", "5G", "20M", "OFDM", "1T", "100", "76",
"IC", "5G", "20M", "OFDM", "1T", "100", "72",
"KCC", "5G", "20M", "OFDM", "1T", "100", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "100", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "100", "72",
"UKRAINE", "5G", "20M", "OFDM", "1T", "100", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "100", "72",
"FCC", "5G", "20M", "OFDM", "1T", "104", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "104", "62",
"MKK", "5G", "20M", "OFDM", "1T", "104", "76",
"IC", "5G", "20M", "OFDM", "1T", "104", "76",
"KCC", "5G", "20M", "OFDM", "1T", "104", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "104", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "104", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "104", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "104", "76",
"FCC", "5G", "20M", "OFDM", "1T", "108", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "108", "62",
"MKK", "5G", "20M", "OFDM", "1T", "108", "76",
"IC", "5G", "20M", "OFDM", "1T", "108", "76",
"KCC", "5G", "20M", "OFDM", "1T", "108", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "108", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "108", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "108", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "108", "76",
"FCC", "5G", "20M", "OFDM", "1T", "112", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "112", "62",
"MKK", "5G", "20M", "OFDM", "1T", "112", "76",
"IC", "5G", "20M", "OFDM", "1T", "112", "76",
"KCC", "5G", "20M", "OFDM", "1T", "112", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "112", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "112", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "112", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "112", "76",
"FCC", "5G", "20M", "OFDM", "1T", "116", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "116", "62",
"MKK", "5G", "20M", "OFDM", "1T", "116", "76",
"IC", "5G", "20M", "OFDM", "1T", "116", "76",
"KCC", "5G", "20M", "OFDM", "1T", "116", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "116", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "116", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "116", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "116", "76",
"FCC", "5G", "20M", "OFDM", "1T", "120", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "120", "62",
"MKK", "5G", "20M", "OFDM", "1T", "120", "76",
"IC", "5G", "20M", "OFDM", "1T", "120", "127",
"KCC", "5G", "20M", "OFDM", "1T", "120", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "120", "127",
"CHILE", "5G", "20M", "OFDM", "1T", "120", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "120", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "120", "76",
"FCC", "5G", "20M", "OFDM", "1T", "124", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "124", "62",
"MKK", "5G", "20M", "OFDM", "1T", "124", "76",
"IC", "5G", "20M", "OFDM", "1T", "124", "127",
"KCC", "5G", "20M", "OFDM", "1T", "124", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "124", "127",
"CHILE", "5G", "20M", "OFDM", "1T", "124", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "124", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "124", "76",
"FCC", "5G", "20M", "OFDM", "1T", "128", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "128", "62",
"MKK", "5G", "20M", "OFDM", "1T", "128", "76",
"IC", "5G", "20M", "OFDM", "1T", "128", "127",
"KCC", "5G", "20M", "OFDM", "1T", "128", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "128", "127",
"CHILE", "5G", "20M", "OFDM", "1T", "128", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "128", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "128", "76",
"FCC", "5G", "20M", "OFDM", "1T", "132", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "132", "62",
"MKK", "5G", "20M", "OFDM", "1T", "132", "76",
"IC", "5G", "20M", "OFDM", "1T", "132", "76",
"KCC", "5G", "20M", "OFDM", "1T", "132", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "132", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "132", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "132", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "132", "76",
"FCC", "5G", "20M", "OFDM", "1T", "136", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "136", "62",
"MKK", "5G", "20M", "OFDM", "1T", "136", "76",
"IC", "5G", "20M", "OFDM", "1T", "136", "76",
"KCC", "5G", "20M", "OFDM", "1T", "136", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "136", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "136", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "136", "127",
"MEXICO", "5G", "20M", "OFDM", "1T", "136", "76",
"FCC", "5G", "20M", "OFDM", "1T", "140", "72",
"ETSI", "5G", "20M", "OFDM", "1T", "140", "62",
"MKK", "5G", "20M", "OFDM", "1T", "140", "76",
"IC", "5G", "20M", "OFDM", "1T", "140", "72",
"KCC", "5G", "20M", "OFDM", "1T", "140", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "140", "62",
"CHILE", "5G", "20M", "OFDM", "1T", "140", "72",
"UKRAINE", "5G", "20M", "OFDM", "1T", "140", "127",
"MEXICO", "5G", "20M", "OFDM", "1T", "140", "72",
"FCC", "5G", "20M", "OFDM", "1T", "144", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "144", "127",
"MKK", "5G", "20M", "OFDM", "1T", "144", "127",
"IC", "5G", "20M", "OFDM", "1T", "144", "76",
"KCC", "5G", "20M", "OFDM", "1T", "144", "76",
"ACMA", "5G", "20M", "OFDM", "1T", "144", "127",
"CHILE", "5G", "20M", "OFDM", "1T", "144", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "144", "127",
"MEXICO", "5G", "20M", "OFDM", "1T", "144", "76",
"FCC", "5G", "20M", "OFDM", "1T", "149", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "149", "-128",
"MKK", "5G", "20M", "OFDM", "1T", "149", "127",
"IC", "5G", "20M", "OFDM", "1T", "149", "76",
"KCC", "5G", "20M", "OFDM", "1T", "149", "74",
"ACMA", "5G", "20M", "OFDM", "1T", "149", "76",
"CHILE", "5G", "20M", "OFDM", "1T", "149", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "149", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "149", "76",
"FCC", "5G", "20M", "OFDM", "1T", "153", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "153", "-128",
"MKK", "5G", "20M", "OFDM", "1T", "153", "127",
"IC", "5G", "20M", "OFDM", "1T", "153", "76",
"KCC", "5G", "20M", "OFDM", "1T", "153", "74",
"ACMA", "5G", "20M", "OFDM", "1T", "153", "76",
"CHILE", "5G", "20M", "OFDM", "1T", "153", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "153", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "153", "76",
"FCC", "5G", "20M", "OFDM", "1T", "157", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "157", "-128",
"MKK", "5G", "20M", "OFDM", "1T", "157", "127",
"IC", "5G", "20M", "OFDM", "1T", "157", "76",
"KCC", "5G", "20M", "OFDM", "1T", "157", "74",
"ACMA", "5G", "20M", "OFDM", "1T", "157", "76",
"CHILE", "5G", "20M", "OFDM", "1T", "157", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "157", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "157", "76",
"FCC", "5G", "20M", "OFDM", "1T", "161", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "161", "-128",
"MKK", "5G", "20M", "OFDM", "1T", "161", "127",
"IC", "5G", "20M", "OFDM", "1T", "161", "76",
"KCC", "5G", "20M", "OFDM", "1T", "161", "74",
"ACMA", "5G", "20M", "OFDM", "1T", "161", "76",
"CHILE", "5G", "20M", "OFDM", "1T", "161", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "161", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "161", "76",
"FCC", "5G", "20M", "OFDM", "1T", "165", "76",
"ETSI", "5G", "20M", "OFDM", "1T", "165", "-128",
"MKK", "5G", "20M", "OFDM", "1T", "165", "127",
"IC", "5G", "20M", "OFDM", "1T", "165", "76",
"KCC", "5G", "20M", "OFDM", "1T", "165", "74",
"ACMA", "5G", "20M", "OFDM", "1T", "165", "76",
"CHILE", "5G", "20M", "OFDM", "1T", "165", "76",
"UKRAINE", "5G", "20M", "OFDM", "1T", "165", "54",
"MEXICO", "5G", "20M", "OFDM", "1T", "165", "76",
"FCC", "5G", "20M", "OFDM", "2T", "36", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "36", "50",
"MKK", "5G", "20M", "OFDM", "2T", "36", "48",
"IC", "5G", "20M", "OFDM", "2T", "36", "40",
"KCC", "5G", "20M", "OFDM", "2T", "36", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "36", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "36", "52",
"UKRAINE", "5G", "20M", "OFDM", "2T", "36", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "36", "50",
"FCC", "5G", "20M", "OFDM", "2T", "40", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "40", "50",
"MKK", "5G", "20M", "OFDM", "2T", "40", "50",
"IC", "5G", "20M", "OFDM", "2T", "40", "40",
"KCC", "5G", "20M", "OFDM", "2T", "40", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "40", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "40", "52",
"UKRAINE", "5G", "20M", "OFDM", "2T", "40", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "40", "50",
"FCC", "5G", "20M", "OFDM", "2T", "44", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "44", "50",
"MKK", "5G", "20M", "OFDM", "2T", "44", "50",
"IC", "5G", "20M", "OFDM", "2T", "44", "40",
"KCC", "5G", "20M", "OFDM", "2T", "44", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "44", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "44", "52",
"UKRAINE", "5G", "20M", "OFDM", "2T", "44", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "44", "50",
"FCC", "5G", "20M", "OFDM", "2T", "48", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "48", "50",
"MKK", "5G", "20M", "OFDM", "2T", "48", "50",
"IC", "5G", "20M", "OFDM", "2T", "48", "40",
"KCC", "5G", "20M", "OFDM", "2T", "48", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "48", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "48", "52",
"UKRAINE", "5G", "20M", "OFDM", "2T", "48", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "48", "50",
"FCC", "5G", "20M", "OFDM", "2T", "52", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "52", "50",
"MKK", "5G", "20M", "OFDM", "2T", "52", "50",
"IC", "5G", "20M", "OFDM", "2T", "52", "52",
"KCC", "5G", "20M", "OFDM", "2T", "52", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "52", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "52", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "52", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "52", "68",
"FCC", "5G", "20M", "OFDM", "2T", "56", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "56", "50",
"MKK", "5G", "20M", "OFDM", "2T", "56", "50",
"IC", "5G", "20M", "OFDM", "2T", "56", "52",
"KCC", "5G", "20M", "OFDM", "2T", "56", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "56", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "56", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "56", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "56", "68",
"FCC", "5G", "20M", "OFDM", "2T", "60", "66",
"ETSI", "5G", "20M", "OFDM", "2T", "60", "50",
"MKK", "5G", "20M", "OFDM", "2T", "60", "50",
"IC", "5G", "20M", "OFDM", "2T", "60", "52",
"KCC", "5G", "20M", "OFDM", "2T", "60", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "60", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "60", "66",
"UKRAINE", "5G", "20M", "OFDM", "2T", "60", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "60", "66",
"FCC", "5G", "20M", "OFDM", "2T", "64", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "64", "50",
"MKK", "5G", "20M", "OFDM", "2T", "64", "48",
"IC", "5G", "20M", "OFDM", "2T", "64", "52",
"KCC", "5G", "20M", "OFDM", "2T", "64", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "64", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "64", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "64", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "64", "68",
"FCC", "5G", "20M", "OFDM", "2T", "100", "60",
"ETSI", "5G", "20M", "OFDM", "2T", "100", "50",
"MKK", "5G", "20M", "OFDM", "2T", "100", "70",
"IC", "5G", "20M", "OFDM", "2T", "100", "60",
"KCC", "5G", "20M", "OFDM", "2T", "100", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "100", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "100", "60",
"UKRAINE", "5G", "20M", "OFDM", "2T", "100", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "100", "60",
"FCC", "5G", "20M", "OFDM", "2T", "104", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "104", "50",
"MKK", "5G", "20M", "OFDM", "2T", "104", "70",
"IC", "5G", "20M", "OFDM", "2T", "104", "68",
"KCC", "5G", "20M", "OFDM", "2T", "104", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "104", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "104", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "104", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "104", "68",
"FCC", "5G", "20M", "OFDM", "2T", "108", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "108", "50",
"MKK", "5G", "20M", "OFDM", "2T", "108", "70",
"IC", "5G", "20M", "OFDM", "2T", "108", "68",
"KCC", "5G", "20M", "OFDM", "2T", "108", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "108", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "108", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "108", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "108", "68",
"FCC", "5G", "20M", "OFDM", "2T", "112", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "112", "50",
"MKK", "5G", "20M", "OFDM", "2T", "112", "70",
"IC", "5G", "20M", "OFDM", "2T", "112", "68",
"KCC", "5G", "20M", "OFDM", "2T", "112", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "112", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "112", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "112", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "112", "68",
"FCC", "5G", "20M", "OFDM", "2T", "116", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "116", "50",
"MKK", "5G", "20M", "OFDM", "2T", "116", "70",
"IC", "5G", "20M", "OFDM", "2T", "116", "68",
"KCC", "5G", "20M", "OFDM", "2T", "116", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "116", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "116", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "116", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "116", "68",
"FCC", "5G", "20M", "OFDM", "2T", "120", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "120", "50",
"MKK", "5G", "20M", "OFDM", "2T", "120", "70",
"IC", "5G", "20M", "OFDM", "2T", "120", "127",
"KCC", "5G", "20M", "OFDM", "2T", "120", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "120", "127",
"CHILE", "5G", "20M", "OFDM", "2T", "120", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "120", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "120", "68",
"FCC", "5G", "20M", "OFDM", "2T", "124", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "124", "50",
"MKK", "5G", "20M", "OFDM", "2T", "124", "70",
"IC", "5G", "20M", "OFDM", "2T", "124", "127",
"KCC", "5G", "20M", "OFDM", "2T", "124", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "124", "127",
"CHILE", "5G", "20M", "OFDM", "2T", "124", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "124", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "124", "68",
"FCC", "5G", "20M", "OFDM", "2T", "128", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "128", "50",
"MKK", "5G", "20M", "OFDM", "2T", "128", "70",
"IC", "5G", "20M", "OFDM", "2T", "128", "127",
"KCC", "5G", "20M", "OFDM", "2T", "128", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "128", "127",
"CHILE", "5G", "20M", "OFDM", "2T", "128", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "128", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "128", "68",
"FCC", "5G", "20M", "OFDM", "2T", "132", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "132", "50",
"MKK", "5G", "20M", "OFDM", "2T", "132", "70",
"IC", "5G", "20M", "OFDM", "2T", "132", "68",
"KCC", "5G", "20M", "OFDM", "2T", "132", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "132", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "132", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "132", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "132", "68",
"FCC", "5G", "20M", "OFDM", "2T", "136", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "136", "50",
"MKK", "5G", "20M", "OFDM", "2T", "136", "70",
"IC", "5G", "20M", "OFDM", "2T", "136", "68",
"KCC", "5G", "20M", "OFDM", "2T", "136", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "136", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "136", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "136", "127",
"MEXICO", "5G", "20M", "OFDM", "2T", "136", "68",
"FCC", "5G", "20M", "OFDM", "2T", "140", "60",
"ETSI", "5G", "20M", "OFDM", "2T", "140", "50",
"MKK", "5G", "20M", "OFDM", "2T", "140", "70",
"IC", "5G", "20M", "OFDM", "2T", "140", "60",
"KCC", "5G", "20M", "OFDM", "2T", "140", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "140", "50",
"CHILE", "5G", "20M", "OFDM", "2T", "140", "60",
"UKRAINE", "5G", "20M", "OFDM", "2T", "140", "127",
"MEXICO", "5G", "20M", "OFDM", "2T", "140", "60",
"FCC", "5G", "20M", "OFDM", "2T", "144", "68",
"ETSI", "5G", "20M", "OFDM", "2T", "144", "127",
"MKK", "5G", "20M", "OFDM", "2T", "144", "127",
"IC", "5G", "20M", "OFDM", "2T", "144", "68",
"KCC", "5G", "20M", "OFDM", "2T", "144", "66",
"ACMA", "5G", "20M", "OFDM", "2T", "144", "127",
"CHILE", "5G", "20M", "OFDM", "2T", "144", "68",
"UKRAINE", "5G", "20M", "OFDM", "2T", "144", "127",
"MEXICO", "5G", "20M", "OFDM", "2T", "144", "68",
"FCC", "5G", "20M", "OFDM", "2T", "149", "76",
"ETSI", "5G", "20M", "OFDM", "2T", "149", "-128",
"MKK", "5G", "20M", "OFDM", "2T", "149", "127",
"IC", "5G", "20M", "OFDM", "2T", "149", "76",
"KCC", "5G", "20M", "OFDM", "2T", "149", "64",
"ACMA", "5G", "20M", "OFDM", "2T", "149", "76",
"CHILE", "5G", "20M", "OFDM", "2T", "149", "76",
"UKRAINE", "5G", "20M", "OFDM", "2T", "149", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "149", "72",
"FCC", "5G", "20M", "OFDM", "2T", "153", "76",
"ETSI", "5G", "20M", "OFDM", "2T", "153", "-128",
"MKK", "5G", "20M", "OFDM", "2T", "153", "127",
"IC", "5G", "20M", "OFDM", "2T", "153", "76",
"KCC", "5G", "20M", "OFDM", "2T", "153", "64",
"ACMA", "5G", "20M", "OFDM", "2T", "153", "76",
"CHILE", "5G", "20M", "OFDM", "2T", "153", "76",
"UKRAINE", "5G", "20M", "OFDM", "2T", "153", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "153", "76",
"FCC", "5G", "20M", "OFDM", "2T", "157", "76",
"ETSI", "5G", "20M", "OFDM", "2T", "157", "-128",
"MKK", "5G", "20M", "OFDM", "2T", "157", "127",
"IC", "5G", "20M", "OFDM", "2T", "157", "76",
"KCC", "5G", "20M", "OFDM", "2T", "157", "64",
"ACMA", "5G", "20M", "OFDM", "2T", "157", "76",
"CHILE", "5G", "20M", "OFDM", "2T", "157", "76",
"UKRAINE", "5G", "20M", "OFDM", "2T", "157", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "157", "76",
"FCC", "5G", "20M", "OFDM", "2T", "161", "76",
"ETSI", "5G", "20M", "OFDM", "2T", "161", "-128",
"MKK", "5G", "20M", "OFDM", "2T", "161", "127",
"IC", "5G", "20M", "OFDM", "2T", "161", "76",
"KCC", "5G", "20M", "OFDM", "2T", "161", "64",
"ACMA", "5G", "20M", "OFDM", "2T", "161", "76",
"CHILE", "5G", "20M", "OFDM", "2T", "161", "76",
"UKRAINE", "5G", "20M", "OFDM", "2T", "161", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "161", "76",
"FCC", "5G", "20M", "OFDM", "2T", "165", "76",
"ETSI", "5G", "20M", "OFDM", "2T", "165", "-128",
"MKK", "5G", "20M", "OFDM", "2T", "165", "127",
"IC", "5G", "20M", "OFDM", "2T", "165", "76",
"KCC", "5G", "20M", "OFDM", "2T", "165", "64",
"ACMA", "5G", "20M", "OFDM", "2T", "165", "76",
"CHILE", "5G", "20M", "OFDM", "2T", "165", "76",
"UKRAINE", "5G", "20M", "OFDM", "2T", "165", "42",
"MEXICO", "5G", "20M", "OFDM", "2T", "165", "76",
"FCC", "5G", "20M", "HT", "1T", "36", "72",
"ETSI", "5G", "20M", "HT", "1T", "36", "62",
"MKK", "5G", "20M", "HT", "1T", "36", "62",
"IC", "5G", "20M", "HT", "1T", "36", "62",
"KCC", "5G", "20M", "HT", "1T", "36", "76",
"ACMA", "5G", "20M", "HT", "1T", "36", "62",
"CHILE", "5G", "20M", "HT", "1T", "36", "64",
"UKRAINE", "5G", "20M", "HT", "1T", "36", "54",
"MEXICO", "5G", "20M", "HT", "1T", "36", "62",
"FCC", "5G", "20M", "HT", "1T", "40", "76",
"ETSI", "5G", "20M", "HT", "1T", "40", "62",
"MKK", "5G", "20M", "HT", "1T", "40", "62",
"IC", "5G", "20M", "HT", "1T", "40", "62",
"KCC", "5G", "20M", "HT", "1T", "40", "76",
"ACMA", "5G", "20M", "HT", "1T", "40", "62",
"CHILE", "5G", "20M", "HT", "1T", "40", "64",
"UKRAINE", "5G", "20M", "HT", "1T", "40", "54",
"MEXICO", "5G", "20M", "HT", "1T", "40", "62",
"FCC", "5G", "20M", "HT", "1T", "44", "76",
"ETSI", "5G", "20M", "HT", "1T", "44", "62",
"MKK", "5G", "20M", "HT", "1T", "44", "62",
"IC", "5G", "20M", "HT", "1T", "44", "62",
"KCC", "5G", "20M", "HT", "1T", "44", "76",
"ACMA", "5G", "20M", "HT", "1T", "44", "62",
"CHILE", "5G", "20M", "HT", "1T", "44", "64",
"UKRAINE", "5G", "20M", "HT", "1T", "44", "54",
"MEXICO", "5G", "20M", "HT", "1T", "44", "62",
"FCC", "5G", "20M", "HT", "1T", "48", "76",
"ETSI", "5G", "20M", "HT", "1T", "48", "62",
"MKK", "5G", "20M", "HT", "1T", "48", "62",
"IC", "5G", "20M", "HT", "1T", "48", "62",
"KCC", "5G", "20M", "HT", "1T", "48", "76",
"ACMA", "5G", "20M", "HT", "1T", "48", "62",
"CHILE", "5G", "20M", "HT", "1T", "48", "64",
"UKRAINE", "5G", "20M", "HT", "1T", "48", "54",
"MEXICO", "5G", "20M", "HT", "1T", "48", "62",
"FCC", "5G", "20M", "HT", "1T", "52", "76",
"ETSI", "5G", "20M", "HT", "1T", "52", "62",
"MKK", "5G", "20M", "HT", "1T", "52", "62",
"IC", "5G", "20M", "HT", "1T", "52", "64",
"KCC", "5G", "20M", "HT", "1T", "52", "76",
"ACMA", "5G", "20M", "HT", "1T", "52", "62",
"CHILE", "5G", "20M", "HT", "1T", "52", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "52", "54",
"MEXICO", "5G", "20M", "HT", "1T", "52", "76",
"FCC", "5G", "20M", "HT", "1T", "56", "76",
"ETSI", "5G", "20M", "HT", "1T", "56", "62",
"MKK", "5G", "20M", "HT", "1T", "56", "62",
"IC", "5G", "20M", "HT", "1T", "56", "64",
"KCC", "5G", "20M", "HT", "1T", "56", "76",
"ACMA", "5G", "20M", "HT", "1T", "56", "62",
"CHILE", "5G", "20M", "HT", "1T", "56", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "56", "54",
"MEXICO", "5G", "20M", "HT", "1T", "56", "76",
"FCC", "5G", "20M", "HT", "1T", "60", "76",
"ETSI", "5G", "20M", "HT", "1T", "60", "62",
"MKK", "5G", "20M", "HT", "1T", "60", "62",
"IC", "5G", "20M", "HT", "1T", "60", "64",
"KCC", "5G", "20M", "HT", "1T", "60", "76",
"ACMA", "5G", "20M", "HT", "1T", "60", "62",
"CHILE", "5G", "20M", "HT", "1T", "60", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "60", "54",
"MEXICO", "5G", "20M", "HT", "1T", "60", "76",
"FCC", "5G", "20M", "HT", "1T", "64", "74",
"ETSI", "5G", "20M", "HT", "1T", "64", "62",
"MKK", "5G", "20M", "HT", "1T", "64", "60",
"IC", "5G", "20M", "HT", "1T", "64", "64",
"KCC", "5G", "20M", "HT", "1T", "64", "74",
"ACMA", "5G", "20M", "HT", "1T", "64", "62",
"CHILE", "5G", "20M", "HT", "1T", "64", "74",
"UKRAINE", "5G", "20M", "HT", "1T", "64", "54",
"MEXICO", "5G", "20M", "HT", "1T", "64", "74",
"FCC", "5G", "20M", "HT", "1T", "100", "70",
"ETSI", "5G", "20M", "HT", "1T", "100", "62",
"MKK", "5G", "20M", "HT", "1T", "100", "76",
"IC", "5G", "20M", "HT", "1T", "100", "70",
"KCC", "5G", "20M", "HT", "1T", "100", "76",
"ACMA", "5G", "20M", "HT", "1T", "100", "62",
"CHILE", "5G", "20M", "HT", "1T", "100", "70",
"UKRAINE", "5G", "20M", "HT", "1T", "100", "54",
"MEXICO", "5G", "20M", "HT", "1T", "100", "70",
"FCC", "5G", "20M", "HT", "1T", "104", "76",
"ETSI", "5G", "20M", "HT", "1T", "104", "62",
"MKK", "5G", "20M", "HT", "1T", "104", "76",
"IC", "5G", "20M", "HT", "1T", "104", "76",
"KCC", "5G", "20M", "HT", "1T", "104", "76",
"ACMA", "5G", "20M", "HT", "1T", "104", "62",
"CHILE", "5G", "20M", "HT", "1T", "104", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "104", "54",
"MEXICO", "5G", "20M", "HT", "1T", "104", "76",
"FCC", "5G", "20M", "HT", "1T", "108", "76",
"ETSI", "5G", "20M", "HT", "1T", "108", "62",
"MKK", "5G", "20M", "HT", "1T", "108", "76",
"IC", "5G", "20M", "HT", "1T", "108", "76",
"KCC", "5G", "20M", "HT", "1T", "108", "76",
"ACMA", "5G", "20M", "HT", "1T", "108", "62",
"CHILE", "5G", "20M", "HT", "1T", "108", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "108", "54",
"MEXICO", "5G", "20M", "HT", "1T", "108", "76",
"FCC", "5G", "20M", "HT", "1T", "112", "76",
"ETSI", "5G", "20M", "HT", "1T", "112", "62",
"MKK", "5G", "20M", "HT", "1T", "112", "76",
"IC", "5G", "20M", "HT", "1T", "112", "76",
"KCC", "5G", "20M", "HT", "1T", "112", "76",
"ACMA", "5G", "20M", "HT", "1T", "112", "62",
"CHILE", "5G", "20M", "HT", "1T", "112", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "112", "54",
"MEXICO", "5G", "20M", "HT", "1T", "112", "76",
"FCC", "5G", "20M", "HT", "1T", "116", "76",
"ETSI", "5G", "20M", "HT", "1T", "116", "62",
"MKK", "5G", "20M", "HT", "1T", "116", "76",
"IC", "5G", "20M", "HT", "1T", "116", "76",
"KCC", "5G", "20M", "HT", "1T", "116", "76",
"ACMA", "5G", "20M", "HT", "1T", "116", "62",
"CHILE", "5G", "20M", "HT", "1T", "116", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "116", "54",
"MEXICO", "5G", "20M", "HT", "1T", "116", "76",
"FCC", "5G", "20M", "HT", "1T", "120", "76",
"ETSI", "5G", "20M", "HT", "1T", "120", "62",
"MKK", "5G", "20M", "HT", "1T", "120", "76",
"IC", "5G", "20M", "HT", "1T", "120", "127",
"KCC", "5G", "20M", "HT", "1T", "120", "76",
"ACMA", "5G", "20M", "HT", "1T", "120", "127",
"CHILE", "5G", "20M", "HT", "1T", "120", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "120", "54",
"MEXICO", "5G", "20M", "HT", "1T", "120", "76",
"FCC", "5G", "20M", "HT", "1T", "124", "76",
"ETSI", "5G", "20M", "HT", "1T", "124", "62",
"MKK", "5G", "20M", "HT", "1T", "124", "76",
"IC", "5G", "20M", "HT", "1T", "124", "127",
"KCC", "5G", "20M", "HT", "1T", "124", "76",
"ACMA", "5G", "20M", "HT", "1T", "124", "127",
"CHILE", "5G", "20M", "HT", "1T", "124", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "124", "54",
"MEXICO", "5G", "20M", "HT", "1T", "124", "76",
"FCC", "5G", "20M", "HT", "1T", "128", "76",
"ETSI", "5G", "20M", "HT", "1T", "128", "62",
"MKK", "5G", "20M", "HT", "1T", "128", "76",
"IC", "5G", "20M", "HT", "1T", "128", "127",
"KCC", "5G", "20M", "HT", "1T", "128", "76",
"ACMA", "5G", "20M", "HT", "1T", "128", "127",
"CHILE", "5G", "20M", "HT", "1T", "128", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "128", "54",
"MEXICO", "5G", "20M", "HT", "1T", "128", "76",
"FCC", "5G", "20M", "HT", "1T", "132", "76",
"ETSI", "5G", "20M", "HT", "1T", "132", "62",
"MKK", "5G", "20M", "HT", "1T", "132", "76",
"IC", "5G", "20M", "HT", "1T", "132", "76",
"KCC", "5G", "20M", "HT", "1T", "132", "76",
"ACMA", "5G", "20M", "HT", "1T", "132", "62",
"CHILE", "5G", "20M", "HT", "1T", "132", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "132", "54",
"MEXICO", "5G", "20M", "HT", "1T", "132", "76",
"FCC", "5G", "20M", "HT", "1T", "136", "76",
"ETSI", "5G", "20M", "HT", "1T", "136", "62",
"MKK", "5G", "20M", "HT", "1T", "136", "76",
"IC", "5G", "20M", "HT", "1T", "136", "76",
"KCC", "5G", "20M", "HT", "1T", "136", "76",
"ACMA", "5G", "20M", "HT", "1T", "136", "62",
"CHILE", "5G", "20M", "HT", "1T", "136", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "136", "127",
"MEXICO", "5G", "20M", "HT", "1T", "136", "76",
"FCC", "5G", "20M", "HT", "1T", "140", "70",
"ETSI", "5G", "20M", "HT", "1T", "140", "62",
"MKK", "5G", "20M", "HT", "1T", "140", "76",
"IC", "5G", "20M", "HT", "1T", "140", "70",
"KCC", "5G", "20M", "HT", "1T", "140", "76",
"ACMA", "5G", "20M", "HT", "1T", "140", "62",
"CHILE", "5G", "20M", "HT", "1T", "140", "70",
"UKRAINE", "5G", "20M", "HT", "1T", "140", "127",
"MEXICO", "5G", "20M", "HT", "1T", "140", "70",
"FCC", "5G", "20M", "HT", "1T", "144", "76",
"ETSI", "5G", "20M", "HT", "1T", "144", "127",
"MKK", "5G", "20M", "HT", "1T", "144", "127",
"IC", "5G", "20M", "HT", "1T", "144", "76",
"KCC", "5G", "20M", "HT", "1T", "144", "76",
"ACMA", "5G", "20M", "HT", "1T", "144", "127",
"CHILE", "5G", "20M", "HT", "1T", "144", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "144", "127",
"MEXICO", "5G", "20M", "HT", "1T", "144", "76",
"FCC", "5G", "20M", "HT", "1T", "149", "76",
"ETSI", "5G", "20M", "HT", "1T", "149", "-128",
"MKK", "5G", "20M", "HT", "1T", "149", "127",
"IC", "5G", "20M", "HT", "1T", "149", "76",
"KCC", "5G", "20M", "HT", "1T", "149", "74",
"ACMA", "5G", "20M", "HT", "1T", "149", "76",
"CHILE", "5G", "20M", "HT", "1T", "149", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "149", "54",
"MEXICO", "5G", "20M", "HT", "1T", "149", "76",
"FCC", "5G", "20M", "HT", "1T", "153", "76",
"ETSI", "5G", "20M", "HT", "1T", "153", "-128",
"MKK", "5G", "20M", "HT", "1T", "153", "127",
"IC", "5G", "20M", "HT", "1T", "153", "76",
"KCC", "5G", "20M", "HT", "1T", "153", "74",
"ACMA", "5G", "20M", "HT", "1T", "153", "76",
"CHILE", "5G", "20M", "HT", "1T", "153", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "153", "54",
"MEXICO", "5G", "20M", "HT", "1T", "153", "76",
"FCC", "5G", "20M", "HT", "1T", "157", "76",
"ETSI", "5G", "20M", "HT", "1T", "157", "-128",
"MKK", "5G", "20M", "HT", "1T", "157", "127",
"IC", "5G", "20M", "HT", "1T", "157", "76",
"KCC", "5G", "20M", "HT", "1T", "157", "74",
"ACMA", "5G", "20M", "HT", "1T", "157", "76",
"CHILE", "5G", "20M", "HT", "1T", "157", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "157", "54",
"MEXICO", "5G", "20M", "HT", "1T", "157", "76",
"FCC", "5G", "20M", "HT", "1T", "161", "76",
"ETSI", "5G", "20M", "HT", "1T", "161", "-128",
"MKK", "5G", "20M", "HT", "1T", "161", "127",
"IC", "5G", "20M", "HT", "1T", "161", "76",
"KCC", "5G", "20M", "HT", "1T", "161", "74",
"ACMA", "5G", "20M", "HT", "1T", "161", "76",
"CHILE", "5G", "20M", "HT", "1T", "161", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "161", "54",
"MEXICO", "5G", "20M", "HT", "1T", "161", "76",
"FCC", "5G", "20M", "HT", "1T", "165", "76",
"ETSI", "5G", "20M", "HT", "1T", "165", "-128",
"MKK", "5G", "20M", "HT", "1T", "165", "127",
"IC", "5G", "20M", "HT", "1T", "165", "76",
"KCC", "5G", "20M", "HT", "1T", "165", "74",
"ACMA", "5G", "20M", "HT", "1T", "165", "76",
"CHILE", "5G", "20M", "HT", "1T", "165", "76",
"UKRAINE", "5G", "20M", "HT", "1T", "165", "54",
"MEXICO", "5G", "20M", "HT", "1T", "165", "76",
"FCC", "5G", "20M", "HT", "2T", "36", "68",
"ETSI", "5G", "20M", "HT", "2T", "36", "38",
"MKK", "5G", "20M", "HT", "2T", "36", "50",
"IC", "5G", "20M", "HT", "2T", "36", "38",
"KCC", "5G", "20M", "HT", "2T", "36", "66",
"ACMA", "5G", "20M", "HT", "2T", "36", "38",
"CHILE", "5G", "20M", "HT", "2T", "36", "52",
"UKRAINE", "5G", "20M", "HT", "2T", "36", "30",
"MEXICO", "5G", "20M", "HT", "2T", "36", "50",
"FCC", "5G", "20M", "HT", "2T", "40", "68",
"ETSI", "5G", "20M", "HT", "2T", "40", "38",
"MKK", "5G", "20M", "HT", "2T", "40", "50",
"IC", "5G", "20M", "HT", "2T", "40", "38",
"KCC", "5G", "20M", "HT", "2T", "40", "66",
"ACMA", "5G", "20M", "HT", "2T", "40", "38",
"CHILE", "5G", "20M", "HT", "2T", "40", "52",
"UKRAINE", "5G", "20M", "HT", "2T", "40", "30",
"MEXICO", "5G", "20M", "HT", "2T", "40", "50",
"FCC", "5G", "20M", "HT", "2T", "44", "68",
"ETSI", "5G", "20M", "HT", "2T", "44", "38",
"MKK", "5G", "20M", "HT", "2T", "44", "50",
"IC", "5G", "20M", "HT", "2T", "44", "38",
"KCC", "5G", "20M", "HT", "2T", "44", "66",
"ACMA", "5G", "20M", "HT", "2T", "44", "38",
"CHILE", "5G", "20M", "HT", "2T", "44", "52",
"UKRAINE", "5G", "20M", "HT", "2T", "44", "30",
"MEXICO", "5G", "20M", "HT", "2T", "44", "50",
"FCC", "5G", "20M", "HT", "2T", "48", "68",
"ETSI", "5G", "20M", "HT", "2T", "48", "38",
"MKK", "5G", "20M", "HT", "2T", "48", "50",
"IC", "5G", "20M", "HT", "2T", "48", "38",
"KCC", "5G", "20M", "HT", "2T", "48", "66",
"ACMA", "5G", "20M", "HT", "2T", "48", "38",
"CHILE", "5G", "20M", "HT", "2T", "48", "52",
"UKRAINE", "5G", "20M", "HT", "2T", "48", "30",
"MEXICO", "5G", "20M", "HT", "2T", "48", "50",
"FCC", "5G", "20M", "HT", "2T", "52", "68",
"ETSI", "5G", "20M", "HT", "2T", "52", "38",
"MKK", "5G", "20M", "HT", "2T", "52", "50",
"IC", "5G", "20M", "HT", "2T", "52", "40",
"KCC", "5G", "20M", "HT", "2T", "52", "66",
"ACMA", "5G", "20M", "HT", "2T", "52", "38",
"CHILE", "5G", "20M", "HT", "2T", "52", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "52", "30",
"MEXICO", "5G", "20M", "HT", "2T", "52", "68",
"FCC", "5G", "20M", "HT", "2T", "56", "68",
"ETSI", "5G", "20M", "HT", "2T", "56", "38",
"MKK", "5G", "20M", "HT", "2T", "56", "50",
"IC", "5G", "20M", "HT", "2T", "56", "40",
"KCC", "5G", "20M", "HT", "2T", "56", "66",
"ACMA", "5G", "20M", "HT", "2T", "56", "38",
"CHILE", "5G", "20M", "HT", "2T", "56", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "56", "30",
"MEXICO", "5G", "20M", "HT", "2T", "56", "68",
"FCC", "5G", "20M", "HT", "2T", "60", "66",
"ETSI", "5G", "20M", "HT", "2T", "60", "38",
"MKK", "5G", "20M", "HT", "2T", "60", "50",
"IC", "5G", "20M", "HT", "2T", "60", "40",
"KCC", "5G", "20M", "HT", "2T", "60", "66",
"ACMA", "5G", "20M", "HT", "2T", "60", "38",
"CHILE", "5G", "20M", "HT", "2T", "60", "66",
"UKRAINE", "5G", "20M", "HT", "2T", "60", "30",
"MEXICO", "5G", "20M", "HT", "2T", "60", "66",
"FCC", "5G", "20M", "HT", "2T", "64", "68",
"ETSI", "5G", "20M", "HT", "2T", "64", "38",
"MKK", "5G", "20M", "HT", "2T", "64", "50",
"IC", "5G", "20M", "HT", "2T", "64", "40",
"KCC", "5G", "20M", "HT", "2T", "64", "66",
"ACMA", "5G", "20M", "HT", "2T", "64", "38",
"CHILE", "5G", "20M", "HT", "2T", "64", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "64", "30",
"MEXICO", "5G", "20M", "HT", "2T", "64", "68",
"FCC", "5G", "20M", "HT", "2T", "100", "60",
"ETSI", "5G", "20M", "HT", "2T", "100", "38",
"MKK", "5G", "20M", "HT", "2T", "100", "70",
"IC", "5G", "20M", "HT", "2T", "100", "60",
"KCC", "5G", "20M", "HT", "2T", "100", "64",
"ACMA", "5G", "20M", "HT", "2T", "100", "38",
"CHILE", "5G", "20M", "HT", "2T", "100", "60",
"UKRAINE", "5G", "20M", "HT", "2T", "100", "30",
"MEXICO", "5G", "20M", "HT", "2T", "100", "60",
"FCC", "5G", "20M", "HT", "2T", "104", "68",
"ETSI", "5G", "20M", "HT", "2T", "104", "38",
"MKK", "5G", "20M", "HT", "2T", "104", "70",
"IC", "5G", "20M", "HT", "2T", "104", "68",
"KCC", "5G", "20M", "HT", "2T", "104", "64",
"ACMA", "5G", "20M", "HT", "2T", "104", "38",
"CHILE", "5G", "20M", "HT", "2T", "104", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "104", "30",
"MEXICO", "5G", "20M", "HT", "2T", "104", "68",
"FCC", "5G", "20M", "HT", "2T", "108", "68",
"ETSI", "5G", "20M", "HT", "2T", "108", "38",
"MKK", "5G", "20M", "HT", "2T", "108", "70",
"IC", "5G", "20M", "HT", "2T", "108", "68",
"KCC", "5G", "20M", "HT", "2T", "108", "64",
"ACMA", "5G", "20M", "HT", "2T", "108", "38",
"CHILE", "5G", "20M", "HT", "2T", "108", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "108", "30",
"MEXICO", "5G", "20M", "HT", "2T", "108", "68",
"FCC", "5G", "20M", "HT", "2T", "112", "68",
"ETSI", "5G", "20M", "HT", "2T", "112", "38",
"MKK", "5G", "20M", "HT", "2T", "112", "70",
"IC", "5G", "20M", "HT", "2T", "112", "68",
"KCC", "5G", "20M", "HT", "2T", "112", "64",
"ACMA", "5G", "20M", "HT", "2T", "112", "38",
"CHILE", "5G", "20M", "HT", "2T", "112", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "112", "30",
"MEXICO", "5G", "20M", "HT", "2T", "112", "68",
"FCC", "5G", "20M", "HT", "2T", "116", "68",
"ETSI", "5G", "20M", "HT", "2T", "116", "38",
"MKK", "5G", "20M", "HT", "2T", "116", "70",
"IC", "5G", "20M", "HT", "2T", "116", "68",
"KCC", "5G", "20M", "HT", "2T", "116", "64",
"ACMA", "5G", "20M", "HT", "2T", "116", "38",
"CHILE", "5G", "20M", "HT", "2T", "116", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "116", "30",
"MEXICO", "5G", "20M", "HT", "2T", "116", "68",
"FCC", "5G", "20M", "HT", "2T", "120", "68",
"ETSI", "5G", "20M", "HT", "2T", "120", "38",
"MKK", "5G", "20M", "HT", "2T", "120", "70",
"IC", "5G", "20M", "HT", "2T", "120", "127",
"KCC", "5G", "20M", "HT", "2T", "120", "64",
"ACMA", "5G", "20M", "HT", "2T", "120", "127",
"CHILE", "5G", "20M", "HT", "2T", "120", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "120", "30",
"MEXICO", "5G", "20M", "HT", "2T", "120", "68",
"FCC", "5G", "20M", "HT", "2T", "124", "68",
"ETSI", "5G", "20M", "HT", "2T", "124", "38",
"MKK", "5G", "20M", "HT", "2T", "124", "70",
"IC", "5G", "20M", "HT", "2T", "124", "127",
"KCC", "5G", "20M", "HT", "2T", "124", "64",
"ACMA", "5G", "20M", "HT", "2T", "124", "127",
"CHILE", "5G", "20M", "HT", "2T", "124", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "124", "30",
"MEXICO", "5G", "20M", "HT", "2T", "124", "68",
"FCC", "5G", "20M", "HT", "2T", "128", "68",
"ETSI", "5G", "20M", "HT", "2T", "128", "38",
"MKK", "5G", "20M", "HT", "2T", "128", "70",
"IC", "5G", "20M", "HT", "2T", "128", "127",
"KCC", "5G", "20M", "HT", "2T", "128", "64",
"ACMA", "5G", "20M", "HT", "2T", "128", "127",
"CHILE", "5G", "20M", "HT", "2T", "128", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "128", "30",
"MEXICO", "5G", "20M", "HT", "2T", "128", "68",
"FCC", "5G", "20M", "HT", "2T", "132", "68",
"ETSI", "5G", "20M", "HT", "2T", "132", "38",
"MKK", "5G", "20M", "HT", "2T", "132", "70",
"IC", "5G", "20M", "HT", "2T", "132", "68",
"KCC", "5G", "20M", "HT", "2T", "132", "64",
"ACMA", "5G", "20M", "HT", "2T", "132", "38",
"CHILE", "5G", "20M", "HT", "2T", "132", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "132", "30",
"MEXICO", "5G", "20M", "HT", "2T", "132", "68",
"FCC", "5G", "20M", "HT", "2T", "136", "68",
"ETSI", "5G", "20M", "HT", "2T", "136", "38",
"MKK", "5G", "20M", "HT", "2T", "136", "70",
"IC", "5G", "20M", "HT", "2T", "136", "68",
"KCC", "5G", "20M", "HT", "2T", "136", "64",
"ACMA", "5G", "20M", "HT", "2T", "136", "38",
"CHILE", "5G", "20M", "HT", "2T", "136", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "136", "127",
"MEXICO", "5G", "20M", "HT", "2T", "136", "68",
"FCC", "5G", "20M", "HT", "2T", "140", "60",
"ETSI", "5G", "20M", "HT", "2T", "140", "38",
"MKK", "5G", "20M", "HT", "2T", "140", "70",
"IC", "5G", "20M", "HT", "2T", "140", "60",
"KCC", "5G", "20M", "HT", "2T", "140", "64",
"ACMA", "5G", "20M", "HT", "2T", "140", "38",
"CHILE", "5G", "20M", "HT", "2T", "140", "60",
"UKRAINE", "5G", "20M", "HT", "2T", "140", "127",
"MEXICO", "5G", "20M", "HT", "2T", "140", "60",
"FCC", "5G", "20M", "HT", "2T", "144", "68",
"ETSI", "5G", "20M", "HT", "2T", "144", "127",
"MKK", "5G", "20M", "HT", "2T", "144", "127",
"IC", "5G", "20M", "HT", "2T", "144", "68",
"KCC", "5G", "20M", "HT", "2T", "144", "64",
"ACMA", "5G", "20M", "HT", "2T", "144", "127",
"CHILE", "5G", "20M", "HT", "2T", "144", "68",
"UKRAINE", "5G", "20M", "HT", "2T", "144", "127",
"MEXICO", "5G", "20M", "HT", "2T", "144", "68",
"FCC", "5G", "20M", "HT", "2T", "149", "76",
"ETSI", "5G", "20M", "HT", "2T", "149", "-128",
"MKK", "5G", "20M", "HT", "2T", "149", "127",
"IC", "5G", "20M", "HT", "2T", "149", "76",
"KCC", "5G", "20M", "HT", "2T", "149", "60",
"ACMA", "5G", "20M", "HT", "2T", "149", "76",
"CHILE", "5G", "20M", "HT", "2T", "149", "76",
"UKRAINE", "5G", "20M", "HT", "2T", "149", "30",
"MEXICO", "5G", "20M", "HT", "2T", "149", "72",
"FCC", "5G", "20M", "HT", "2T", "153", "76",
"ETSI", "5G", "20M", "HT", "2T", "153", "-128",
"MKK", "5G", "20M", "HT", "2T", "153", "127",
"IC", "5G", "20M", "HT", "2T", "153", "76",
"KCC", "5G", "20M", "HT", "2T", "153", "60",
"ACMA", "5G", "20M", "HT", "2T", "153", "76",
"CHILE", "5G", "20M", "HT", "2T", "153", "76",
"UKRAINE", "5G", "20M", "HT", "2T", "153", "30",
"MEXICO", "5G", "20M", "HT", "2T", "153", "76",
"FCC", "5G", "20M", "HT", "2T", "157", "76",
"ETSI", "5G", "20M", "HT", "2T", "157", "-128",
"MKK", "5G", "20M", "HT", "2T", "157", "127",
"IC", "5G", "20M", "HT", "2T", "157", "76",
"KCC", "5G", "20M", "HT", "2T", "157", "60",
"ACMA", "5G", "20M", "HT", "2T", "157", "76",
"CHILE", "5G", "20M", "HT", "2T", "157", "76",
"UKRAINE", "5G", "20M", "HT", "2T", "157", "30",
"MEXICO", "5G", "20M", "HT", "2T", "157", "76",
"FCC", "5G", "20M", "HT", "2T", "161", "76",
"ETSI", "5G", "20M", "HT", "2T", "161", "-128",
"MKK", "5G", "20M", "HT", "2T", "161", "127",
"IC", "5G", "20M", "HT", "2T", "161", "76",
"KCC", "5G", "20M", "HT", "2T", "161", "60",
"ACMA", "5G", "20M", "HT", "2T", "161", "76",
"CHILE", "5G", "20M", "HT", "2T", "161", "76",
"UKRAINE", "5G", "20M", "HT", "2T", "161", "30",
"MEXICO", "5G", "20M", "HT", "2T", "161", "76",
"FCC", "5G", "20M", "HT", "2T", "165", "76",
"ETSI", "5G", "20M", "HT", "2T", "165", "-128",
"MKK", "5G", "20M", "HT", "2T", "165", "127",
"IC", "5G", "20M", "HT", "2T", "165", "76",
"KCC", "5G", "20M", "HT", "2T", "165", "60",
"ACMA", "5G", "20M", "HT", "2T", "165", "76",
"CHILE", "5G", "20M", "HT", "2T", "165", "76",
"UKRAINE", "5G", "20M", "HT", "2T", "165", "30",
"MEXICO", "5G", "20M", "HT", "2T", "165", "76",
"FCC", "5G", "40M", "HT", "1T", "38", "66",
"ETSI", "5G", "40M", "HT", "1T", "38", "64",
"MKK", "5G", "40M", "HT", "1T", "38", "62",
"IC", "5G", "40M", "HT", "1T", "38", "64",
"KCC", "5G", "40M", "HT", "1T", "38", "72",
"ACMA", "5G", "40M", "HT", "1T", "38", "64",
"CHILE", "5G", "40M", "HT", "1T", "38", "64",
"UKRAINE", "5G", "40M", "HT", "1T", "38", "54",
"MEXICO", "5G", "40M", "HT", "1T", "38", "62",
"FCC", "5G", "40M", "HT", "1T", "46", "72",
"ETSI", "5G", "40M", "HT", "1T", "46", "64",
"MKK", "5G", "40M", "HT", "1T", "46", "62",
"IC", "5G", "40M", "HT", "1T", "46", "64",
"KCC", "5G", "40M", "HT", "1T", "46", "72",
"ACMA", "5G", "40M", "HT", "1T", "46", "64",
"CHILE", "5G", "40M", "HT", "1T", "46", "64",
"UKRAINE", "5G", "40M", "HT", "1T", "46", "54",
"MEXICO", "5G", "40M", "HT", "1T", "46", "62",
"FCC", "5G", "40M", "HT", "1T", "54", "72",
"ETSI", "5G", "40M", "HT", "1T", "54", "64",
"MKK", "5G", "40M", "HT", "1T", "54", "62",
"IC", "5G", "40M", "HT", "1T", "54", "64",
"KCC", "5G", "40M", "HT", "1T", "54", "72",
"ACMA", "5G", "40M", "HT", "1T", "54", "64",
"CHILE", "5G", "40M", "HT", "1T", "54", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "54", "54",
"MEXICO", "5G", "40M", "HT", "1T", "54", "72",
"FCC", "5G", "40M", "HT", "1T", "62", "64",
"ETSI", "5G", "40M", "HT", "1T", "62", "64",
"MKK", "5G", "40M", "HT", "1T", "62", "62",
"IC", "5G", "40M", "HT", "1T", "62", "64",
"KCC", "5G", "40M", "HT", "1T", "62", "70",
"ACMA", "5G", "40M", "HT", "1T", "62", "64",
"CHILE", "5G", "40M", "HT", "1T", "62", "64",
"UKRAINE", "5G", "40M", "HT", "1T", "62", "54",
"MEXICO", "5G", "40M", "HT", "1T", "62", "64",
"FCC", "5G", "40M", "HT", "1T", "102", "58",
"ETSI", "5G", "40M", "HT", "1T", "102", "64",
"MKK", "5G", "40M", "HT", "1T", "102", "72",
"IC", "5G", "40M", "HT", "1T", "102", "58",
"KCC", "5G", "40M", "HT", "1T", "102", "72",
"ACMA", "5G", "40M", "HT", "1T", "102", "64",
"CHILE", "5G", "40M", "HT", "1T", "102", "58",
"UKRAINE", "5G", "40M", "HT", "1T", "102", "54",
"MEXICO", "5G", "40M", "HT", "1T", "102", "58",
"FCC", "5G", "40M", "HT", "1T", "110", "72",
"ETSI", "5G", "40M", "HT", "1T", "110", "64",
"MKK", "5G", "40M", "HT", "1T", "110", "72",
"IC", "5G", "40M", "HT", "1T", "110", "72",
"KCC", "5G", "40M", "HT", "1T", "110", "72",
"ACMA", "5G", "40M", "HT", "1T", "110", "64",
"CHILE", "5G", "40M", "HT", "1T", "110", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "110", "54",
"MEXICO", "5G", "40M", "HT", "1T", "110", "72",
"FCC", "5G", "40M", "HT", "1T", "118", "72",
"ETSI", "5G", "40M", "HT", "1T", "118", "64",
"MKK", "5G", "40M", "HT", "1T", "118", "72",
"IC", "5G", "40M", "HT", "1T", "118", "127",
"KCC", "5G", "40M", "HT", "1T", "118", "72",
"ACMA", "5G", "40M", "HT", "1T", "118", "127",
"CHILE", "5G", "40M", "HT", "1T", "118", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "118", "54",
"MEXICO", "5G", "40M", "HT", "1T", "118", "72",
"FCC", "5G", "40M", "HT", "1T", "126", "72",
"ETSI", "5G", "40M", "HT", "1T", "126", "64",
"MKK", "5G", "40M", "HT", "1T", "126", "72",
"IC", "5G", "40M", "HT", "1T", "126", "127",
"KCC", "5G", "40M", "HT", "1T", "126", "72",
"ACMA", "5G", "40M", "HT", "1T", "126", "127",
"CHILE", "5G", "40M", "HT", "1T", "126", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "126", "54",
"MEXICO", "5G", "40M", "HT", "1T", "126", "72",
"FCC", "5G", "40M", "HT", "1T", "134", "72",
"ETSI", "5G", "40M", "HT", "1T", "134", "64",
"MKK", "5G", "40M", "HT", "1T", "134", "72",
"IC", "5G", "40M", "HT", "1T", "134", "72",
"KCC", "5G", "40M", "HT", "1T", "134", "72",
"ACMA", "5G", "40M", "HT", "1T", "134", "64",
"CHILE", "5G", "40M", "HT", "1T", "134", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "134", "127",
"MEXICO", "5G", "40M", "HT", "1T", "134", "72",
"FCC", "5G", "40M", "HT", "1T", "142", "72",
"ETSI", "5G", "40M", "HT", "1T", "142", "127",
"MKK", "5G", "40M", "HT", "1T", "142", "127",
"IC", "5G", "40M", "HT", "1T", "142", "72",
"KCC", "5G", "40M", "HT", "1T", "142", "72",
"ACMA", "5G", "40M", "HT", "1T", "142", "127",
"CHILE", "5G", "40M", "HT", "1T", "142", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "142", "127",
"MEXICO", "5G", "40M", "HT", "1T", "142", "72",
"FCC", "5G", "40M", "HT", "1T", "151", "72",
"ETSI", "5G", "40M", "HT", "1T", "151", "-128",
"MKK", "5G", "40M", "HT", "1T", "151", "127",
"IC", "5G", "40M", "HT", "1T", "151", "72",
"KCC", "5G", "40M", "HT", "1T", "151", "72",
"ACMA", "5G", "40M", "HT", "1T", "151", "72",
"CHILE", "5G", "40M", "HT", "1T", "151", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "151", "54",
"MEXICO", "5G", "40M", "HT", "1T", "151", "72",
"FCC", "5G", "40M", "HT", "1T", "159", "72",
"ETSI", "5G", "40M", "HT", "1T", "159", "-128",
"MKK", "5G", "40M", "HT", "1T", "159", "127",
"IC", "5G", "40M", "HT", "1T", "159", "72",
"KCC", "5G", "40M", "HT", "1T", "159", "72",
"ACMA", "5G", "40M", "HT", "1T", "159", "72",
"CHILE", "5G", "40M", "HT", "1T", "159", "72",
"UKRAINE", "5G", "40M", "HT", "1T", "159", "54",
"MEXICO", "5G", "40M", "HT", "1T", "159", "72",
"FCC", "5G", "40M", "HT", "2T", "38", "60",
"ETSI", "5G", "40M", "HT", "2T", "38", "40",
"MKK", "5G", "40M", "HT", "2T", "38", "50",
"IC", "5G", "40M", "HT", "2T", "38", "40",
"KCC", "5G", "40M", "HT", "2T", "38", "62",
"ACMA", "5G", "40M", "HT", "2T", "38", "40",
"CHILE", "5G", "40M", "HT", "2T", "38", "52",
"UKRAINE", "5G", "40M", "HT", "2T", "38", "30",
"MEXICO", "5G", "40M", "HT", "2T", "38", "50",
"FCC", "5G", "40M", "HT", "2T", "46", "68",
"ETSI", "5G", "40M", "HT", "2T", "46", "40",
"MKK", "5G", "40M", "HT", "2T", "46", "50",
"IC", "5G", "40M", "HT", "2T", "46", "40",
"KCC", "5G", "40M", "HT", "2T", "46", "62",
"ACMA", "5G", "40M", "HT", "2T", "46", "40",
"CHILE", "5G", "40M", "HT", "2T", "46", "52",
"UKRAINE", "5G", "40M", "HT", "2T", "46", "30",
"MEXICO", "5G", "40M", "HT", "2T", "46", "50",
"FCC", "5G", "40M", "HT", "2T", "54", "68",
"ETSI", "5G", "40M", "HT", "2T", "54", "40",
"MKK", "5G", "40M", "HT", "2T", "54", "50",
"IC", "5G", "40M", "HT", "2T", "54", "40",
"KCC", "5G", "40M", "HT", "2T", "54", "62",
"ACMA", "5G", "40M", "HT", "2T", "54", "40",
"CHILE", "5G", "40M", "HT", "2T", "54", "68",
"UKRAINE", "5G", "40M", "HT", "2T", "54", "30",
"MEXICO", "5G", "40M", "HT", "2T", "54", "68",
"FCC", "5G", "40M", "HT", "2T", "62", "58",
"ETSI", "5G", "40M", "HT", "2T", "62", "40",
"MKK", "5G", "40M", "HT", "2T", "62", "48",
"IC", "5G", "40M", "HT", "2T", "62", "40",
"KCC", "5G", "40M", "HT", "2T", "62", "58",
"ACMA", "5G", "40M", "HT", "2T", "62", "40",
"CHILE", "5G", "40M", "HT", "2T", "62", "58",
"UKRAINE", "5G", "40M", "HT", "2T", "62", "30",
"MEXICO", "5G", "40M", "HT", "2T", "62", "58",
"FCC", "5G", "40M", "HT", "2T", "102", "54",
"ETSI", "5G", "40M", "HT", "2T", "102", "40",
"MKK", "5G", "40M", "HT", "2T", "102", "70",
"IC", "5G", "40M", "HT", "2T", "102", "54",
"KCC", "5G", "40M", "HT", "2T", "102", "64",
"ACMA", "5G", "40M", "HT", "2T", "102", "40",
"CHILE", "5G", "40M", "HT", "2T", "102", "54",
"UKRAINE", "5G", "40M", "HT", "2T", "102", "30",
"MEXICO", "5G", "40M", "HT", "2T", "102", "54",
"FCC", "5G", "40M", "HT", "2T", "110", "68",
"ETSI", "5G", "40M", "HT", "2T", "110", "40",
"MKK", "5G", "40M", "HT", "2T", "110", "70",
"IC", "5G", "40M", "HT", "2T", "110", "68",
"KCC", "5G", "40M", "HT", "2T", "110", "64",
"ACMA", "5G", "40M", "HT", "2T", "110", "40",
"CHILE", "5G", "40M", "HT", "2T", "110", "68",
"UKRAINE", "5G", "40M", "HT", "2T", "110", "30",
"MEXICO", "5G", "40M", "HT", "2T", "110", "68",
"FCC", "5G", "40M", "HT", "2T", "118", "68",
"ETSI", "5G", "40M", "HT", "2T", "118", "40",
"MKK", "5G", "40M", "HT", "2T", "118", "70",
"IC", "5G", "40M", "HT", "2T", "118", "127",
"KCC", "5G", "40M", "HT", "2T", "118", "64",
"ACMA", "5G", "40M", "HT", "2T", "118", "127",
"CHILE", "5G", "40M", "HT", "2T", "118", "68",
"UKRAINE", "5G", "40M", "HT", "2T", "118", "30",
"MEXICO", "5G", "40M", "HT", "2T", "118", "68",
"FCC", "5G", "40M", "HT", "2T", "126", "68",
"ETSI", "5G", "40M", "HT", "2T", "126", "40",
"MKK", "5G", "40M", "HT", "2T", "126", "70",
"IC", "5G", "40M", "HT", "2T", "126", "127",
"KCC", "5G", "40M", "HT", "2T", "126", "64",
"ACMA", "5G", "40M", "HT", "2T", "126", "127",
"CHILE", "5G", "40M", "HT", "2T", "126", "68",
"UKRAINE", "5G", "40M", "HT", "2T", "126", "30",
"MEXICO", "5G", "40M", "HT", "2T", "126", "68",
"FCC", "5G", "40M", "HT", "2T", "134", "68",
"ETSI", "5G", "40M", "HT", "2T", "134", "40",
"MKK", "5G", "40M", "HT", "2T", "134", "70",
"IC", "5G", "40M", "HT", "2T", "134", "68",
"KCC", "5G", "40M", "HT", "2T", "134", "64",
"ACMA", "5G", "40M", "HT", "2T", "134", "40",
"CHILE", "5G", "40M", "HT", "2T", "134", "68",
"UKRAINE", "5G", "40M", "HT", "2T", "134", "127",
"MEXICO", "5G", "40M", "HT", "2T", "134", "68",
"FCC", "5G", "40M", "HT", "2T", "142", "68",
"ETSI", "5G", "40M", "HT", "2T", "142", "127",
"MKK", "5G", "40M", "HT", "2T", "142", "127",
"IC", "5G", "40M", "HT", "2T", "142", "68",
"KCC", "5G", "40M", "HT", "2T", "142", "64",
"ACMA", "5G", "40M", "HT", "2T", "142", "127",
"CHILE", "5G", "40M", "HT", "2T", "142", "68",
"UKRAINE", "5G", "40M", "HT", "2T", "142", "127",
"MEXICO", "5G", "40M", "HT", "2T", "142", "68",
"FCC", "5G", "40M", "HT", "2T", "151", "72",
"ETSI", "5G", "40M", "HT", "2T", "151", "-128",
"MKK", "5G", "40M", "HT", "2T", "151", "127",
"IC", "5G", "40M", "HT", "2T", "151", "72",
"KCC", "5G", "40M", "HT", "2T", "151", "66",
"ACMA", "5G", "40M", "HT", "2T", "151", "72",
"CHILE", "5G", "40M", "HT", "2T", "151", "72",
"UKRAINE", "5G", "40M", "HT", "2T", "151", "30",
"MEXICO", "5G", "40M", "HT", "2T", "151", "68",
"FCC", "5G", "40M", "HT", "2T", "159", "72",
"ETSI", "5G", "40M", "HT", "2T", "159", "-128",
"MKK", "5G", "40M", "HT", "2T", "159", "127",
"IC", "5G", "40M", "HT", "2T", "159", "72",
"KCC", "5G", "40M", "HT", "2T", "159", "66",
"ACMA", "5G", "40M", "HT", "2T", "159", "72",
"CHILE", "5G", "40M", "HT", "2T", "159", "72",
"UKRAINE", "5G", "40M", "HT", "2T", "159", "30",
"MEXICO", "5G", "40M", "HT", "2T", "159", "72",
"FCC", "5G", "80M", "VHT", "1T", "42", "64",
"ETSI", "5G", "80M", "VHT", "1T", "42", "64",
"MKK", "5G", "80M", "VHT", "1T", "42", "64",
"IC", "5G", "80M", "VHT", "1T", "42", "64",
"KCC", "5G", "80M", "VHT", "1T", "42", "68",
"ACMA", "5G", "80M", "VHT", "1T", "42", "64",
"CHILE", "5G", "80M", "VHT", "1T", "42", "64",
"UKRAINE", "5G", "80M", "VHT", "1T", "42", "54",
"MEXICO", "5G", "80M", "VHT", "1T", "42", "62",
"FCC", "5G", "80M", "VHT", "1T", "58", "62",
"ETSI", "5G", "80M", "VHT", "1T", "58", "64",
"MKK", "5G", "80M", "VHT", "1T", "58", "64",
"IC", "5G", "80M", "VHT", "1T", "58", "62",
"KCC", "5G", "80M", "VHT", "1T", "58", "64",
"ACMA", "5G", "80M", "VHT", "1T", "58", "64",
"CHILE", "5G", "80M", "VHT", "1T", "58", "62",
"UKRAINE", "5G", "80M", "VHT", "1T", "58", "54",
"MEXICO", "5G", "80M", "VHT", "1T", "58", "62",
"FCC", "5G", "80M", "VHT", "1T", "106", "58",
"ETSI", "5G", "80M", "VHT", "1T", "106", "64",
"MKK", "5G", "80M", "VHT", "1T", "106", "72",
"IC", "5G", "80M", "VHT", "1T", "106", "58",
"KCC", "5G", "80M", "VHT", "1T", "106", "66",
"ACMA", "5G", "80M", "VHT", "1T", "106", "64",
"CHILE", "5G", "80M", "VHT", "1T", "106", "58",
"UKRAINE", "5G", "80M", "VHT", "1T", "106", "54",
"MEXICO", "5G", "80M", "VHT", "1T", "106", "58",
"FCC", "5G", "80M", "VHT", "1T", "122", "72",
"ETSI", "5G", "80M", "VHT", "1T", "122", "64",
"MKK", "5G", "80M", "VHT", "1T", "122", "72",
"IC", "5G", "80M", "VHT", "1T", "122", "127",
"KCC", "5G", "80M", "VHT", "1T", "122", "68",
"ACMA", "5G", "80M", "VHT", "1T", "122", "127",
"CHILE", "5G", "80M", "VHT", "1T", "122", "72",
"UKRAINE", "5G", "80M", "VHT", "1T", "122", "54",
"MEXICO", "5G", "80M", "VHT", "1T", "122", "72",
"FCC", "5G", "80M", "VHT", "1T", "138", "72",
"ETSI", "5G", "80M", "VHT", "1T", "138", "127",
"MKK", "5G", "80M", "VHT", "1T", "138", "127",
"IC", "5G", "80M", "VHT", "1T", "138", "72",
"KCC", "5G", "80M", "VHT", "1T", "138", "68",
"ACMA", "5G", "80M", "VHT", "1T", "138", "127",
"CHILE", "5G", "80M", "VHT", "1T", "138", "72",
"UKRAINE", "5G", "80M", "VHT", "1T", "138", "127",
"MEXICO", "5G", "80M", "VHT", "1T", "138", "72",
"FCC", "5G", "80M", "VHT", "1T", "155", "72",
"ETSI", "5G", "80M", "VHT", "1T", "155", "-128",
"MKK", "5G", "80M", "VHT", "1T", "155", "127",
"IC", "5G", "80M", "VHT", "1T", "155", "72",
"KCC", "5G", "80M", "VHT", "1T", "155", "68",
"ACMA", "5G", "80M", "VHT", "1T", "155", "72",
"CHILE", "5G", "80M", "VHT", "1T", "155", "72",
"UKRAINE", "5G", "80M", "VHT", "1T", "155", "54",
"MEXICO", "5G", "80M", "VHT", "1T", "155", "68",
"FCC", "5G", "80M", "VHT", "2T", "42", "54",
"ETSI", "5G", "80M", "VHT", "2T", "42", "40",
"MKK", "5G", "80M", "VHT", "2T", "42", "50",
"IC", "5G", "80M", "VHT", "2T", "42", "40",
"KCC", "5G", "80M", "VHT", "2T", "42", "58",
"ACMA", "5G", "80M", "VHT", "2T", "42", "40",
"CHILE", "5G", "80M", "VHT", "2T", "42", "52",
"UKRAINE", "5G", "80M", "VHT", "2T", "42", "30",
"MEXICO", "5G", "80M", "VHT", "2T", "42", "50",
"FCC", "5G", "80M", "VHT", "2T", "58", "52",
"ETSI", "5G", "80M", "VHT", "2T", "58", "40",
"MKK", "5G", "80M", "VHT", "2T", "58", "50",
"IC", "5G", "80M", "VHT", "2T", "58", "40",
"KCC", "5G", "80M", "VHT", "2T", "58", "56",
"ACMA", "5G", "80M", "VHT", "2T", "58", "40",
"CHILE", "5G", "80M", "VHT", "2T", "58", "52",
"UKRAINE", "5G", "80M", "VHT", "2T", "58", "30",
"MEXICO", "5G", "80M", "VHT", "2T", "58", "52",
"FCC", "5G", "80M", "VHT", "2T", "106", "50",
"ETSI", "5G", "80M", "VHT", "2T", "106", "40",
"MKK", "5G", "80M", "VHT", "2T", "106", "72",
"IC", "5G", "80M", "VHT", "2T", "106", "50",
"KCC", "5G", "80M", "VHT", "2T", "106", "56",
"ACMA", "5G", "80M", "VHT", "2T", "106", "40",
"CHILE", "5G", "80M", "VHT", "2T", "106", "50",
"UKRAINE", "5G", "80M", "VHT", "2T", "106", "30",
"MEXICO", "5G", "80M", "VHT", "2T", "106", "50",
"FCC", "5G", "80M", "VHT", "2T", "122", "66",
"ETSI", "5G", "80M", "VHT", "2T", "122", "40",
"MKK", "5G", "80M", "VHT", "2T", "122", "72",
"IC", "5G", "80M", "VHT", "2T", "122", "127",
"KCC", "5G", "80M", "VHT", "2T", "122", "56",
"ACMA", "5G", "80M", "VHT", "2T", "122", "127",
"CHILE", "5G", "80M", "VHT", "2T", "122", "66",
"UKRAINE", "5G", "80M", "VHT", "2T", "122", "30",
"MEXICO", "5G", "80M", "VHT", "2T", "122", "66",
"FCC", "5G", "80M", "VHT", "2T", "138", "66",
"ETSI", "5G", "80M", "VHT", "2T", "138", "127",
"MKK", "5G", "80M", "VHT", "2T", "138", "127",
"IC", "5G", "80M", "VHT", "2T", "138", "66",
"KCC", "5G", "80M", "VHT", "2T", "138", "58",
"ACMA", "5G", "80M", "VHT", "2T", "138", "127",
"CHILE", "5G", "80M", "VHT", "2T", "138", "66",
"UKRAINE", "5G", "80M", "VHT", "2T", "138", "127",
"MEXICO", "5G", "80M", "VHT", "2T", "138", "66",
"FCC", "5G", "80M", "VHT", "2T", "155", "62",
"ETSI", "5G", "80M", "VHT", "2T", "155", "-128",
"MKK", "5G", "80M", "VHT", "2T", "155", "127",
"IC", "5G", "80M", "VHT", "2T", "155", "62",
"KCC", "5G", "80M", "VHT", "2T", "155", "58",
"ACMA", "5G", "80M", "VHT", "2T", "155", "72",
"CHILE", "5G", "80M", "VHT", "2T", "155", "62",
"UKRAINE", "5G", "80M", "VHT", "2T", "155", "30",
"MEXICO", "5G", "80M", "VHT", "2T", "155", "62"
};
#endif
void
odm_read_and_config_mp_8822c_txpwr_lmt(struct dm_struct *dm)
{
#ifdef CONFIG_8822C
u32 i = 0;
#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
u32 array_len =
sizeof(array_mp_8822c_txpwr_lmt) / sizeof(u8);
u8 *array = (u8 *)array_mp_8822c_txpwr_lmt;
#else
u32 array_len =
sizeof(array_mp_8822c_txpwr_lmt) / sizeof(u8 *);
u8 **array = (u8 **)array_mp_8822c_txpwr_lmt;
#endif
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
void *adapter = dm->adapter;
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
odm_memory_set(dm, hal_data->BufOfLinesPwrLmt, 0,
MAX_LINES_HWCONFIG_TXT *
MAX_BYTES_LINE_HWCONFIG_TXT);
hal_data->nLinesReadPwrLmt = array_len / 7;
#endif
PHYDM_DBG(dm, ODM_COMP_INIT, "===> %s\n", __func__);
for (i = 0; i < array_len; i += 7) {
#if (DM_ODM_SUPPORT_TYPE == ODM_IOT)
u8 regulation = array[i];
u8 band = array[i + 1];
u8 bandwidth = array[i + 2];
u8 rate = array[i + 3];
u8 rf_path = array[i + 4];
u8 chnl = array[i + 5];
u8 val = array[i + 6];
#else
u8 *regulation = array[i];
u8 *band = array[i + 1];
u8 *bandwidth = array[i + 2];
u8 *rate = array[i + 3];
u8 *rf_path = array[i + 4];
u8 *chnl = array[i + 5];
u8 *val = array[i + 6];
#endif
odm_config_bb_txpwr_lmt_8822c(dm, regulation, band, bandwidth,
rate, rf_path, chnl, val);
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
rsprintf((char *)hal_data->BufOfLinesPwrLmt[i / 7], 100, "\"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\", \"%s\",",
regulation, band, bandwidth, rate, rf_path, chnl, val);
#endif
}
#endif
}
#endif /* end of HWIMG_SUPPORT*/
================================================
FILE: hal/phydm/halrf/rtl8822c/halhwimg8822c_rf.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
/*Image2HeaderVersion: R3 1.5.8*/
#if (RTL8822C_SUPPORT == 1)
#ifndef __INC_MP_RF_HW_IMG_8822C_H
#define __INC_MP_RF_HW_IMG_8822C_H
/* Please add following compiler flags definition (#define CONFIG_XXX_DRV_DIS)
* into driver source code to reduce code size if necessary.
* #define CONFIG_8822C_DRV_DIS
* #define CONFIG_8822CTSSI_DRV_DIS
*/
#define CONFIG_8822C
#ifdef CONFIG_8822C_DRV_DIS
#undef CONFIG_8822C
#endif
#define CONFIG_8822CTSSI
#ifdef CONFIG_8822CTSSI_DRV_DIS
#undef CONFIG_8822CTSSI
#endif
/******************************************************************************
* radioa.TXT
******************************************************************************/
/* tc: Test Chip, mp: mp Chip*/
void
odm_read_and_config_mp_8822c_radioa(struct dm_struct *dm);
u32 odm_get_version_mp_8822c_radioa(void);
/******************************************************************************
* radiob.TXT
******************************************************************************/
/* tc: Test Chip, mp: mp Chip*/
void
odm_read_and_config_mp_8822c_radiob(struct dm_struct *dm);
u32 odm_get_version_mp_8822c_radiob(void);
/******************************************************************************
* txpowertrack.TXT
******************************************************************************/
/* tc: Test Chip, mp: mp Chip*/
void
odm_read_and_config_mp_8822c_txpowertrack(struct dm_struct *dm);
u32 odm_get_version_mp_8822c_txpowertrack(void);
/******************************************************************************
* txpowertracktssi.TXT
******************************************************************************/
/* tc: Test Chip, mp: mp Chip*/
void
odm_read_and_config_mp_8822c_txpowertracktssi(struct dm_struct *dm);
u32 odm_get_version_mp_8822c_txpowertracktssi(void);
/******************************************************************************
* txpwr_lmt.TXT
******************************************************************************/
/* tc: Test Chip, mp: mp Chip*/
void
odm_read_and_config_mp_8822c_txpwr_lmt(struct dm_struct *dm);
u32 odm_get_version_mp_8822c_txpwr_lmt(void);
#endif
#endif /* end of HWIMG_SUPPORT*/
================================================
FILE: hal/phydm/halrf/rtl8822c/halrf_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#include "mp_precomp.h"
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
#if RT_PLATFORM == PLATFORM_MACOSX
#include "phydm_precomp.h"
#else
#include "../phydm_precomp.h"
#endif
#else
#include "../../phydm_precomp.h"
#endif
#if (RTL8822C_SUPPORT == 1)
void halrf_rf_lna_setting_8822c(struct dm_struct *dm_void,
enum halrf_lna_set type)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 path = 0x0;
for (path = 0x0; path < 2; path++)
if (type == HALRF_LNA_DISABLE) {
/*S0*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xef, BIT(19),
0x1);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x33,
RFREGOFFSETMASK, 0x00003);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x3e,
RFREGOFFSETMASK, 0x00064);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x3f,
RFREGOFFSETMASK, 0x0afce);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xef, BIT(19),
0x0);
} else if (type == HALRF_LNA_ENABLE) {
/*S0*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xef, BIT(19),
0x1);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x33,
RFREGOFFSETMASK, 0x00003);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x3e,
RFREGOFFSETMASK, 0x00064);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x3f,
RFREGOFFSETMASK, 0x1afce);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xef, BIT(19),
0x0);
}
}
void odm_tx_pwr_track_set_pwr8822c(void *dm_void, enum pwrtrack_method method,
u8 rf_path, u8 channel_mapped_index)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &(dm->rf_calibrate_info);
u32 bitmask_6_0 = BIT(6) | BIT(5) | BIT(4) | BIT(3) |
BIT(2) | BIT(1) | BIT(0);
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"pRF->absolute_ofdm_swing_idx=%d pRF->remnant_ofdm_swing_idx=%d pRF->absolute_cck_swing_idx=%d pRF->remnant_cck_swing_idx=%d rf_path=%d\n",
cali_info->absolute_ofdm_swing_idx[rf_path], cali_info->remnant_ofdm_swing_idx[rf_path], cali_info->absolute_cck_swing_idx[rf_path], cali_info->remnant_cck_swing_idx, rf_path);
if (method == BBSWING) { /*use for mp driver clean power tracking status*/
switch (rf_path) {
case RF_PATH_A:
odm_set_bb_reg(dm, R_0x18a0, bitmask_6_0, (cali_info->absolute_ofdm_swing_idx[rf_path] & 0x7f));
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Path-%d 0x%x=0x%x\n", rf_path, R_0x18a0, odm_get_bb_reg(dm, R_0x18a0, bitmask_6_0));
break;
case RF_PATH_B:
odm_set_bb_reg(dm, R_0x41a0, bitmask_6_0, (cali_info->absolute_ofdm_swing_idx[rf_path] & 0x7f));
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Path-%d 0x%x=0x%x\n", rf_path, R_0x41a0, odm_get_bb_reg(dm, R_0x41a0, bitmask_6_0));
break;
default:
break;
}
} else if (method == MIX_MODE) {
switch (rf_path) {
case RF_PATH_A:
odm_set_bb_reg(dm, R_0x18a0, bitmask_6_0, (cali_info->absolute_ofdm_swing_idx[rf_path] & 0x7f));
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Path-%d 0x%x=0x%x\n", rf_path, R_0x18a0, odm_get_bb_reg(dm, R_0x18a0, bitmask_6_0));
break;
case RF_PATH_B:
odm_set_bb_reg(dm, R_0x41a0, bitmask_6_0, (cali_info->absolute_ofdm_swing_idx[rf_path] & 0x7f));
RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
"Path-%d 0x%x=0x%x\n", rf_path, R_0x41a0, odm_get_bb_reg(dm, R_0x41a0, bitmask_6_0));
break;
default:
break;
}
}
}
void get_delta_swing_table_8822c(void *dm_void,
u8 **temperature_up_a,
u8 **temperature_down_a,
u8 **temperature_up_b,
u8 **temperature_down_b)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
u8 channel = *dm->channel;
u8 tx_rate = phydm_get_tx_rate(dm);
if (channel >= 1 && channel <= 14) {
if (IS_CCK_RATE(tx_rate)) {
*temperature_up_a = cali_info->delta_swing_table_idx_2g_cck_a_p;
*temperature_down_a = cali_info->delta_swing_table_idx_2g_cck_a_n;
*temperature_up_b = cali_info->delta_swing_table_idx_2g_cck_b_p;
*temperature_down_b = cali_info->delta_swing_table_idx_2g_cck_b_n;
} else {
*temperature_up_a = cali_info->delta_swing_table_idx_2ga_p;
*temperature_down_a = cali_info->delta_swing_table_idx_2ga_n;
*temperature_up_b = cali_info->delta_swing_table_idx_2gb_p;
*temperature_down_b = cali_info->delta_swing_table_idx_2gb_n;
}
}
if (channel >= 36 && channel <= 64) {
*temperature_up_a = cali_info->delta_swing_table_idx_5ga_p[0];
*temperature_down_a = cali_info->delta_swing_table_idx_5ga_n[0];
*temperature_up_b = cali_info->delta_swing_table_idx_5gb_p[0];
*temperature_down_b = cali_info->delta_swing_table_idx_5gb_n[0];
} else if (channel >= 100 && channel <= 144) {
*temperature_up_a = cali_info->delta_swing_table_idx_5ga_p[1];
*temperature_down_a = cali_info->delta_swing_table_idx_5ga_n[1];
*temperature_up_b = cali_info->delta_swing_table_idx_5gb_p[1];
*temperature_down_b = cali_info->delta_swing_table_idx_5gb_n[1];
} else if (channel >= 149 && channel <= 177) {
*temperature_up_a = cali_info->delta_swing_table_idx_5ga_p[2];
*temperature_down_a = cali_info->delta_swing_table_idx_5ga_n[2];
*temperature_up_b = cali_info->delta_swing_table_idx_5gb_p[2];
*temperature_down_b = cali_info->delta_swing_table_idx_5gb_n[2];
}
}
void _phy_aac_calibrate_8822c(struct dm_struct *dm)
{
#if 1
u32 cnt = 0;
RF_DBG(dm, DBG_RF_LCK, "[AACK]AACK start!!!!!!!\n");
odm_set_rf_reg(dm, RF_PATH_A, 0xbb, RFREGOFFSETMASK, 0x80010);
odm_set_rf_reg(dm, RF_PATH_A, 0xb0, RFREGOFFSETMASK, 0x1F0FA);
ODM_delay_ms(1);
odm_set_rf_reg(dm, RF_PATH_A, RF_0xca, RFREGOFFSETMASK, 0x80000);
odm_set_rf_reg(dm, RF_PATH_A, RF_0xc9, RFREGOFFSETMASK, 0x80001);
for (cnt = 0; cnt < 100; cnt++) {
ODM_delay_ms(1);
if (odm_get_rf_reg(dm, RF_PATH_A, RF_0xca, 0x1000) != 0x1)
break;
}
odm_set_rf_reg(dm, RF_PATH_A, RF_0xb0, RFREGOFFSETMASK, 0x1F0F8);
odm_set_rf_reg(dm, RF_PATH_B, 0xbb, RFREGOFFSETMASK, 0x80010);
RF_DBG(dm, DBG_RF_IQK, "[AACK]AACK end!!!!!!!\n");
#endif
}
void _phy_rt_calibrate_8822c(struct dm_struct *dm)
{
RF_DBG(dm, DBG_RF_IQK, "[RTK]RTK start!!!!!!!\n");
odm_set_rf_reg(dm, RF_PATH_A, 0xcc, RFREGOFFSETMASK, 0x0f000);
odm_set_rf_reg(dm, RF_PATH_A, 0xcc, RFREGOFFSETMASK, 0x4f000);
ODM_delay_ms(1);
odm_set_rf_reg(dm, RF_PATH_A, 0xcc, RFREGOFFSETMASK, 0x0f000);
RF_DBG(dm, DBG_RF_IQK, "[RTK]RTK end!!!!!!!\n");
}
void halrf_reload_bp_8822c(struct dm_struct *dm, u32 *bp_reg, u32 *bp)
{
u32 i;
for (i = 0; i < DACK_REG_8822C; i++)
odm_write_4byte(dm, bp_reg[i], bp[i]);
}
void halrf_reload_bprf_8822c(struct dm_struct *dm, u32 *bp_reg, u32 bp[][2])
{
u32 i;
for (i = 0; i < DACK_RF_8822C; i++) {
odm_set_rf_reg(dm, RF_PATH_A, bp_reg[i], MASK20BITS,
bp[i][RF_PATH_A]);
odm_set_rf_reg(dm, RF_PATH_B, bp_reg[i], MASK20BITS,
bp[i][RF_PATH_B]);
}
}
void halrf_bp_8822c(struct dm_struct *dm, u32 *bp_reg, u32 *bp)
{
u32 i;
for (i = 0; i < DACK_REG_8822C; i++)
bp[i] = odm_read_4byte(dm, bp_reg[i]);
}
void halrf_bprf_8822c(struct dm_struct *dm, u32 *bp_reg, u32 bp[][2])
{
u32 i;
for (i = 0; i < DACK_RF_8822C; i++) {
bp[i][RF_PATH_A] =
odm_get_rf_reg(dm, RF_PATH_A, bp_reg[i], MASK20BITS);
bp[i][RF_PATH_B] =
odm_get_rf_reg(dm, RF_PATH_B, bp_reg[i], MASK20BITS);
}
}
void halrf_swap_8822c(struct dm_struct *dm, u32 *v1, u32 *v2)
{
u32 temp;
temp = *v1;
*v1 = *v2;
*v2 = temp;
}
void halrf_bubble_8822c(struct dm_struct *dm, u32 *v1, u32 *v2)
{
u32 temp;
if (*v1 >= 0x200 && *v2 >= 0x200) {
if (*v1 > *v2)
halrf_swap_8822c(dm, v1, v2);
} else if (*v1 < 0x200 && *v2 < 0x200) {
if (*v1 > *v2)
halrf_swap_8822c(dm, v1, v2);
} else if (*v1 < 0x200 && *v2 >= 0x200) {
halrf_swap_8822c(dm, v1, v2);
}
}
void halrf_b_sort_8822c(struct dm_struct *dm, u32 *iv, u32 *qv)
{
u32 temp;
u32 i, j;
RF_DBG(dm, DBG_RF_DACK, "[DACK]bubble!!!!!!!!!!!!");
for (i = 0; i < SN - 1; i++) {
for (j = 0; j < (SN - 1 - i) ; j++) {
halrf_bubble_8822c(dm, &iv[j], &iv[j + 1]);
halrf_bubble_8822c(dm, &qv[j], &qv[j + 1]);
}
}
}
void halrf_minmax_compare_8822c(struct dm_struct *dm, u32 value, u32 *min,
u32 *max)
{
if (value >= 0x200) {
if (*min >= 0x200) {
if (*min > value)
*min = value;
} else {
*min = value;
}
if (*max >= 0x200) {
if (*max < value)
*max = value;
}
} else {
if (*min < 0x200) {
if (*min > value)
*min = value;
}
if (*max >= 0x200) {
*max = value;
} else {
if (*max < value)
*max = value;
}
}
}
boolean halrf_compare_8822c(struct dm_struct *dm, u32 value)
{
boolean fail = false;
if (value >= 0x200 && (0x400 - value) > 0x64)
fail = true;
else if (value < 0x200 && value > 0x64)
fail = true;
if (fail)
RF_DBG(dm, DBG_RF_DACK, "[DACK]overflow!!!!!!!!!!!!!!!");
return fail;
}
void halrf_mode_8822c(struct dm_struct *dm, u32 *i_value, u32 *q_value)
{
u32 iv[SN], qv[SN], im[SN], qm[SN], temp, temp1, temp2;
u32 p, m, t;
u32 i_max = 0, q_max = 0, i_min = 0x0, q_min = 0x0, c = 0x0;
u32 i_delta, q_delta;
u8 i, j, ii = 0, qi = 0;
boolean fail = false;
// ODM_delay_ms(10);
RF_DBG(dm, DBG_RF_DACK, "[DACK]pathA RF0x0 = 0x%x",
odm_get_rf_reg(dm, 0x0, 0x0, 0xfffff));
RF_DBG(dm, DBG_RF_DACK, "[DACK]pathB RF0x0 = 0x%x",
odm_get_rf_reg(dm, 0x1, 0x0, 0xfffff));
for (i = 0; i < SN; i++) {
im[i] = 0;
qm[i] = 0;
}
i = 0;
c = 0;
while (i < SN && c < 10000) {
c++;
temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
iv[i] = (temp & 0x3ff000) >> 12;
qv[i] = temp & 0x3ff;
fail = false;
if (halrf_compare_8822c(dm, iv[i]))
fail = true;
if (halrf_compare_8822c(dm, qv[i]))
fail = true;
if (!fail)
i++;
}
c = 0;
do {
i_min = iv[0];
i_max = iv[0];
q_min = qv[0];
q_max = qv[0];
for (i = 0; i < SN; i++) {
halrf_minmax_compare_8822c(dm, iv[i], &i_min, &i_max);
halrf_minmax_compare_8822c(dm, qv[i], &q_min, &q_max);
}
c++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]i_min=0x%x, i_max=0x%x",
i_min, i_max);
RF_DBG(dm, DBG_RF_DACK, "[DACK]q_min=0x%x, q_max=0x%x",
q_min, q_max);
if (i_max < 0x200 && i_min < 0x200)
i_delta = i_max - i_min;
else if (i_max >= 0x200 && i_min >= 0x200)
i_delta = i_max - i_min;
else
i_delta = i_max + (0x400 - i_min);
if (q_max < 0x200 && q_min < 0x200)
q_delta = q_max - q_min;
else if (q_max >= 0x200 && q_min >= 0x200)
q_delta = q_max - q_min;
else
q_delta = q_max + (0x400 - q_min);
RF_DBG(dm, DBG_RF_DACK, "[DACK]i_delta=0x%x, q_delta=0x%x",
i_delta, q_delta);
halrf_b_sort_8822c(dm, iv, qv);
if (i_delta > 5 || q_delta > 5) {
// halrf_b_sort_8822c(dm, iv, qv);
temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
iv[0] = (temp & 0x3ff000) >> 12;
qv[0] = temp & 0x3ff;
temp = odm_get_bb_reg(dm, 0x2dbc, 0x3fffff);
iv[SN - 1] = (temp & 0x3ff000) >> 12;
qv[SN - 1] = temp & 0x3ff;
} else {
break;
}
} while (c < 100);
#if 0
for (i = 0; i < SN; i++) {
for (j = 0; j < SN; j++) {
if (i != j) {
if (iv[i] == iv[j])
im[i]++;
if (qv[i] == qv[j])
qm[i]++;
}
}
}
for (i = 0; i < SN; i++)
RF_DBG(dm, DBG_RF_DACK, "[DACK]iv[%d] = 0x%x\n", i, iv[i]);
for (i = 0; i < SN; i++)
RF_DBG(dm, DBG_RF_DACK, "[DACK]qv[%d] = 0x%x\n", i, qv[i]);
for (i = 1; i < SN; i++) {
if (im[ii] < im[i])
ii = i;
if (qm[qi] < qm[i])
qi = i;
}
*i_value = iv[ii];
*q_value = qv[qi];
#endif
#if 1
#if 0
for (i = 0; i < SN; i++)
RF_DBG(dm, DBG_RF_DACK, "[DACK]iv[%d] = 0x%x\n", i, iv[i]);
for (i = 0; i < SN; i++)
RF_DBG(dm, DBG_RF_DACK, "[DACK]qv[%d] = 0x%x\n", i, qv[i]);
#endif
/*i*/
m = 0;
p = 0;
for (i = 10; i < SN - 10; i++) {
if (iv[i] > 0x200)
m = (0x400 - iv[i]) + m;
else
p = iv[i] + p;
}
if (p > m) {
t = p - m;
t = t / (SN - 20);
} else {
t = m - p;
t = t / (SN - 20);
if (t != 0x0)
t = 0x400 - t;
}
*i_value = t;
/*q*/
m = 0;
p = 0;
for (i = 10; i < SN - 10; i++) {
if (qv[i] > 0x200)
m = (0x400 - qv[i]) + m;
else
p = qv[i] + p;
}
if (p > m) {
t = p - m;
t = t / (SN - 20);
} else {
t = m - p;
t = t / (SN - 20);
if (t != 0x0)
t = 0x400 - t;
}
*q_value = t;
#endif
}
void halrf_biask_backup_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
dack->biask_d[0][0]= (u8)odm_get_bb_reg(dm, 0x2810, 0x1ff8);
dack->biask_d[0][1]= (u8)odm_get_bb_reg(dm, 0x283c, 0x1ff8);
dack->biask_d[1][0]= (u8)odm_get_bb_reg(dm, 0x4510, 0x1ff8);
dack->biask_d[1][1]= (u8)odm_get_bb_reg(dm, 0x453c, 0x1ff8);
}
void halrf_dck_backup_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
dack->dck_d[0][0][0] = (u8)odm_get_bb_reg(dm, 0x18bc, 0xf0000000);
dack->dck_d[0][0][1] = (u8)odm_get_bb_reg(dm, 0x18c0, 0xf);
dack->dck_d[0][1][0] = (u8)odm_get_bb_reg(dm, 0x18d8, 0xf0000000);
dack->dck_d[0][1][1] = (u8)odm_get_bb_reg(dm, 0x18dc, 0xf);
dack->dck_d[1][0][0] = (u8)odm_get_bb_reg(dm, 0x41bc, 0xf0000000);
dack->dck_d[1][0][1] = (u8)odm_get_bb_reg(dm, 0x41c0, 0xf);
dack->dck_d[1][1][0] = (u8)odm_get_bb_reg(dm, 0x41d8, 0xf0000000);
dack->dck_d[1][1][1] = (u8)odm_get_bb_reg(dm, 0x41dc, 0xf);
}
void halrf_dack_backup_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
u8 i;
u32 temp1, temp2, temp3;
temp1 = odm_get_bb_reg(dm, 0x1860, MASKDWORD);
temp2 = odm_get_bb_reg(dm, 0x4160, MASKDWORD);
temp3 = odm_get_bb_reg(dm, 0x9b4, MASKDWORD);
odm_set_bb_reg(dm, 0x9b4, MASKDWORD, 0xdb66db00);
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x1860, 0xfc000000, 0x3c);
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18b0, 0xf0000000, i);
dack->msbk_d[0][0][i] = (u16)odm_get_bb_reg(dm, 0x2810,
0x7fc0000);
}
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18cc, 0xf0000000, i);
dack->msbk_d[0][1][i] = (u16)odm_get_bb_reg(dm, 0x283c,
0x7fc0000);
}
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x4160, 0xfc000000, 0x3c);
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41b0, 0xf0000000, i);
dack->msbk_d[1][0][i] = (u16)odm_get_bb_reg(dm, 0x4510,
0x7fc0000);
}
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41cc, 0xf0000000, i);
dack->msbk_d[1][1][i] = (u16)odm_get_bb_reg(dm, 0x453c,
0x7fc0000);
}
halrf_dck_backup_8822c(dm);
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x1860, MASKDWORD, temp1);
odm_set_bb_reg(dm, 0x4160, MASKDWORD, temp2);
odm_set_bb_reg(dm, 0x9b4, MASKDWORD, temp3);
halrf_biask_backup_8822c(dm);
}
void halrf_biask_restore_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
odm_set_bb_reg(dm, 0x18b0, 0x1ff8000, dack->biask_d[0][0]);
odm_set_bb_reg(dm, 0x18cc, 0x1ff8000, dack->biask_d[0][1]);
odm_set_bb_reg(dm, 0x41b0, 0x1ff8000, dack->biask_d[1][0]);
odm_set_bb_reg(dm, 0x41cc, 0x1ff8000, dack->biask_d[1][1]);
}
void halrf_dck_restore_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
odm_set_bb_reg(dm, 0x18bc, BIT(19), 0x1);
odm_set_bb_reg(dm, 0x18bc, 0xf0000000, dack->dck_d[0][0][0]);
odm_set_bb_reg(dm, 0x18c0, 0xf, dack->dck_d[0][0][1]);
odm_set_bb_reg(dm, 0x18d8, BIT(19), 0x1);
odm_set_bb_reg(dm, 0x18d8, 0xf0000000, dack->dck_d[0][1][0]);
odm_set_bb_reg(dm, 0x18dc, 0xf, dack->dck_d[0][1][1]);
odm_set_bb_reg(dm, 0x41bc, BIT(19), 0x1);
odm_set_bb_reg(dm, 0x41bc, 0xf0000000, dack->dck_d[1][0][0]);
odm_set_bb_reg(dm, 0x41c0, 0xf, dack->dck_d[1][0][1]);
odm_set_bb_reg(dm, 0x41d8, BIT(19), 0x1);
odm_set_bb_reg(dm, 0x41d8, 0xf0000000, dack->dck_d[1][1][0]);
odm_set_bb_reg(dm, 0x41dc, 0xf, dack->dck_d[1][1][1]);
}
void halrf_dack_restore_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
u8 i;
u32 c = 0x0;
u32 temp1, temp2, temp3;
if (dack->dack_en == false)
return;
temp1 = odm_get_bb_reg(dm, 0x1860, MASKDWORD);
temp2 = odm_get_bb_reg(dm, 0x4160, MASKDWORD);
temp3 = odm_get_bb_reg(dm, 0x9b4, MASKDWORD);
odm_set_bb_reg(dm, 0x9b4, MASKDWORD, 0xdb66db00);
odm_set_bb_reg(dm, 0x18b0, BIT(27), 0x0);
odm_set_bb_reg(dm, 0x18cc, BIT(27), 0x0);
odm_set_bb_reg(dm, 0x41b0, BIT(27), 0x0);
odm_set_bb_reg(dm, 0x41cc, BIT(27), 0x0);
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x1860, 0xfc000000, 0x3c);
odm_set_bb_reg(dm, 0x18b4, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x18d0, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x4160, 0xfc000000, 0x3c);
odm_set_bb_reg(dm, 0x41b4, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x41d0, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x18b0, 0xf00, 0x0);
odm_set_bb_reg(dm, 0x18c0, BIT(14), 0x0);
odm_set_bb_reg(dm, 0x18cc, 0xf00, 0x0);
odm_set_bb_reg(dm, 0x18dc, BIT(14), 0x0);
odm_set_bb_reg(dm, 0x18b0, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x18cc, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x18b0, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x18cc, BIT(0), 0x1);
halrf_dck_restore_8822c(dm);
odm_set_bb_reg(dm, 0x18c0, 0x38000, 0x7);
odm_set_bb_reg(dm, 0x18dc, 0x38000, 0x7);
odm_set_bb_reg(dm, 0x41c0, 0x38000, 0x7);
odm_set_bb_reg(dm, 0x41dc, 0x38000, 0x7);
odm_set_bb_reg(dm, 0x18b8, BIT(26) | BIT(25), 0x1);
odm_set_bb_reg(dm, 0x18d4, BIT(26) | BIT(25), 0x1);
odm_set_bb_reg(dm, 0x41b0, 0xf00, 0x0);
odm_set_bb_reg(dm, 0x41c0, BIT(14), 0x0);
odm_set_bb_reg(dm, 0x41cc, 0xf00, 0x0);
odm_set_bb_reg(dm, 0x41dc, BIT(14), 0x0);
odm_set_bb_reg(dm, 0x41b0, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x41cc, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x41b0, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x41cc, BIT(0), 0x1);
odm_set_bb_reg(dm, 0x41b8, BIT(26) | BIT(25), 0x1);
odm_set_bb_reg(dm, 0x41d4, BIT(26) | BIT(25), 0x1);
#if 1
c = 0x0;
while (c < 10000) {
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x2808=0x%x",
odm_get_bb_reg(dm, 0x2808, 0x7fff80));
c++;
if (odm_get_bb_reg(dm, 0x2808, 0x7fff80) == 0xffff)
break;
}
c = 0x0;
while (c < 10000) {
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x2834=0x%x",
odm_get_bb_reg(dm, 0x2834, 0x7fff80));
c++;
if (odm_get_bb_reg(dm, 0x2834, 0x7fff80) == 0xffff)
break;
}
c = 0x0;
while (c < 10000) {
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x4508=0x%x",
odm_get_bb_reg(dm, 0x4508, 0x7fff80));
c++;
if (odm_get_bb_reg(dm, 0x4508, 0x7fff80) == 0xffff)
break;
}
c = 0x0;
while (c < 10000) {
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x4534=0x%x",
odm_get_bb_reg(dm, 0x4534, 0x7fff80));
c++;
if (odm_get_bb_reg(dm, 0x4534, 0x7fff80) == 0xffff)
break;
}
#endif
odm_set_bb_reg(dm, 0x18b8, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x18b8, BIT(26) | BIT(25), 0x2);
c = 0x0;
while (c < 10000) {
c++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x2808=0x%x",
odm_get_bb_reg(dm, 0x2808, 0xff));
if (odm_get_bb_reg(dm, 0x2808, 0xf) == 0x6)
break;
odm_set_bb_reg(dm, 0x18b8, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x18b8, BIT(26) | BIT(25), 0x2);
}
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18b4, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x18b4, 0xff8, dack->msbk_d[0][0][i]);
odm_set_bb_reg(dm, 0x18b0, 0xf0000000, i);
odm_set_bb_reg(dm, 0x18b4, BIT(2), 0x1);
}
odm_set_bb_reg(dm, 0x18b4, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x18d4, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x18d4, BIT(26) | BIT(25), 0x2);
c = 0x0;
while (c < 10000) {
c++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x2834=0x%x",
odm_get_bb_reg(dm, 0x2834, 0xff));
if (odm_get_bb_reg(dm,0x2834,0xf) == 0x6)
break;
odm_set_bb_reg(dm, 0x18d4, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x18d4, BIT(26) | BIT(25), 0x2);
}
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18d0, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x18d0, 0xff8, dack->msbk_d[0][1][i]);
odm_set_bb_reg(dm, 0x18cc, 0xf0000000, i);
odm_set_bb_reg(dm, 0x18d0, BIT(2), 0x1);
}
odm_set_bb_reg(dm, 0x18d0, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x18b8, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x18d4, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x18b4, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x18d0, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x41b8, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x41b8, BIT(26) | BIT(25), 0x2);
c = 0x0;
while (c < 10000) {
c++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x4508=0x%x",
odm_get_bb_reg(dm, 0x4508, 0xff));
if (odm_get_bb_reg(dm,0x4508,0xf) == 0x6)
break;
odm_set_bb_reg(dm, 0x41b8, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x41b8, BIT(26) | BIT(25), 0x2);
}
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41b4, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x41b4, 0xff8, dack->msbk_d[1][0][i]);
odm_set_bb_reg(dm, 0x41b0, 0xf0000000, i);
odm_set_bb_reg(dm, 0x41b4, BIT(2), 0x1);
}
odm_set_bb_reg(dm, 0x41b4, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x41d4, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x41d4, BIT(26) | BIT(25), 0x2);
c = 0x0;
while (c < 10000) {
c++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x4534=0x%x",
odm_get_bb_reg(dm, 0x4534, 0xff));
if (odm_get_bb_reg(dm,0x4534,0xf) == 0x6)
break;
odm_set_bb_reg(dm, 0x41d4, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x41d4, BIT(26) | BIT(25), 0x2);
}
for (i = 0x0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41d0, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x41d0, 0xff8, dack->msbk_d[1][1][i]);
odm_set_bb_reg(dm, 0x41cc, 0xf0000000, i);
odm_set_bb_reg(dm, 0x41d0, BIT(2), 0x1);
}
odm_set_bb_reg(dm, 0x41d0, BIT(2), 0x0);
odm_set_bb_reg(dm, 0x41b8, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x41d4, BIT(26) | BIT(25), 0x0);
odm_set_bb_reg(dm, 0x41b4, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x41d0, BIT(0), 0x0);
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x1860, MASKDWORD, temp1);
odm_set_bb_reg(dm, 0x4160, MASKDWORD, temp2);
odm_set_bb_reg(dm, 0x18b0, BIT(27), 0x1);
odm_set_bb_reg(dm, 0x18cc, BIT(27), 0x1);
odm_set_bb_reg(dm, 0x41b0, BIT(27), 0x1);
odm_set_bb_reg(dm, 0x41cc, BIT(27), 0x1);
odm_set_bb_reg(dm, 0x9b4, MASKDWORD, temp3);
halrf_biask_restore_8822c(dm);
}
void halrf_polling_check(void *dm_void, u32 add, u32 bmask, u32 data)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 c = 0;
c = 0;
while (c < 100000) {
c++;
if (odm_get_bb_reg(dm, add, bmask) == data)
break;
}
RF_DBG(dm, DBG_RF_DACK, "[DACK]c=%d\n",c);
}
void halrf_dac_cal_8822c(void *dm_void, boolean force)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dack_info *dack = &dm->dack_info;
static u32 count = 1;
#if 1
u32 ic = 0, qc = 0, temp = 0, temp1 = 0, i = 0;
u32 bp[DACK_REG_8822C];
u32 bp_reg[DACK_REG_8822C] = {0x180c, 0x1810, 0x410c, 0x4110, 0x1c3c, 0x1c24,
0x1d70, 0x9b4, 0x1a00, 0x1a14, 0x1d58,
0x1c38, 0x1e24, 0x1e28, 0x1860, 0x4160};
u32 bp_rf[DACK_RF_8822C][2];
u32 bp_rfreg[DACK_RF_8822C] = {0x8f};
u32 i_a = 0x0, q_a = 0x0, i_b = 0x0, q_b = 0x0;
u32 ic_a = 0x0, qc_a = 0x0, ic_b = 0x0, qc_b = 0x0;
u32 adc_ic_a = 0x0, adc_qc_a = 0x0, adc_ic_b = 0x0, adc_qc_b = 0x0;
#if 1
if (dack->dack_en) {
if (!force) {
halrf_dack_restore_8822c(dm);
return;
}
} else {
dack->dack_en = true;
}
#endif
count++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]count = %d", count);
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK start!!!!!!!");
halrf_bp_8822c(dm, bp_reg, bp);
halrf_bprf_8822c(dm, bp_rfreg, bp_rf);
/*BB setting*/
odm_set_bb_reg(dm, 0x1d58, 0xff8, 0x1ff);
odm_set_bb_reg(dm, 0x1a00, 0x3, 0x2);
odm_set_bb_reg(dm, 0x1a14, 0x300, 0x3);
odm_write_4byte(dm, 0x1d70, 0x7e7e7e7e);
odm_set_bb_reg(dm, 0x180c, 0x3, 0x0);
odm_set_bb_reg(dm, 0x410c, 0x3, 0x0);
odm_write_4byte(dm, 0x1b00, 0x00000008);
odm_write_1byte(dm, 0x1bcc, 0x3f);
odm_write_4byte(dm, 0x1b00, 0x0000000a);
odm_write_1byte(dm, 0x1bcc, 0x3f);
odm_set_bb_reg(dm, 0x1e24, BIT(31), 0x0);
odm_set_bb_reg(dm, 0x1e28, 0xf, 0x3);
/*path-A*/
RF_DBG(dm, DBG_RF_DACK, "[DACK]pathA DACK!!!!!!!!!!!!!!!!!!!!!!!!!!!");
/*1.ADCK step1*/
RF_DBG(dm, DBG_RF_DACK, "[DACK]step1 ADCK!!!!!!!!!!!!!!!!!!!!!!!!!!!");
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x0);
odm_write_4byte(dm, 0x1860, 0xf0040ff0);
odm_write_4byte(dm, 0x180c, 0xdff00220);
odm_write_4byte(dm, 0x1810, 0x02dd08c4);
odm_write_4byte(dm, 0x180c, 0x10000260);
odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, 0x10000);
odm_set_rf_reg(dm, RF_PATH_B, 0x0, RFREGOFFSETMASK, 0x10000);
i = 0;
while (i < 10) {
i++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]ADCK count=%d", i);
odm_write_4byte(dm, 0x1c3c, 0x00088003);
odm_write_4byte(dm, 0x1c24, 0x00010002);
halrf_mode_8822c(dm, &ic, &qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]before ADCK i=0x%x, q=0x%x",
ic, qc);
/*compensation value*/
if (ic != 0x0) {
ic = 0x400 - ic;
adc_ic_a = ic;
}
if (qc != 0x0) {
qc = 0x400 - qc;
adc_qc_a = qc;
}
temp = (ic & 0x3ff) | ((qc & 0x3ff) << 10);
odm_write_4byte(dm, 0x1868, temp);
RF_DBG(dm, DBG_RF_DACK, "[DACK]ADCK 0x1868 =0x%x\n", temp);
#if 1
/*check ADC DC offset*/
odm_write_4byte(dm, 0x1c3c, 0x00088103);
halrf_mode_8822c(dm, &ic, &qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]after ADCK i=0x%x, q=0x%x",
ic, qc);
#endif
if (ic >= 0x200)
ic = 0x400 - ic;
if (qc >= 0x200)
qc = 0x400 - qc;
if (ic < 5 && qc < 5)
break;
}
/*2.ADCK step2*/
odm_write_4byte(dm, 0x1c3c, 0x00000003);
odm_write_4byte(dm, 0x180c, 0x10000260);
odm_write_4byte(dm, 0x1810, 0x02d508c4);
/*3.release pull low switch on IQ path*/
odm_set_rf_reg(dm, RF_PATH_A, 0x8f, BIT(13), 0x1);
RF_DBG(dm, DBG_RF_DACK, "[DACK]step2 DACK!!!!!!!!!!!!!!!!!!!!!!!!!!!");
i = 0;
while (i < 10) {
odm_write_4byte(dm, 0x1868, temp);
/*DACK step1*/
i++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK count=%d\n", i);
odm_write_4byte(dm, 0x180c, 0xdff00220);
odm_write_4byte(dm, 0x1860, 0xf0040ff0);
odm_write_4byte(dm, 0x1c38, 0xffffffff);
odm_write_4byte(dm, 0x1810, 0x02d508c5);
odm_write_4byte(dm, 0x9b4, 0xdb66db00);
odm_write_4byte(dm, 0x18b0, 0x0a11fb88);
odm_write_4byte(dm, 0x18bc, 0x0008ff81);
odm_write_4byte(dm, 0x18c0, 0x0003d208);
odm_write_4byte(dm, 0x18cc, 0x0a11fb88);
odm_write_4byte(dm, 0x18d8, 0x0008ff81);
odm_write_4byte(dm, 0x18dc, 0x0003d208);
odm_write_4byte(dm, 0x18b8, 0x60000000);
ODM_delay_ms(2);
odm_write_4byte(dm, 0x18bc, 0x000aff8d);
ODM_delay_ms(2);
odm_write_4byte(dm, 0x18b0, 0x0a11fb89);
odm_write_4byte(dm, 0x18cc, 0x0a11fb89);
ODM_delay_ms(1);
odm_write_4byte(dm, 0x18b8, 0x62000000);
// ODM_delay_ms(20);
odm_write_4byte(dm, 0x18d4, 0x62000000);
ODM_delay_ms(1);
halrf_polling_check(dm, 0x2808, 0x7fff80, 0xffff);
halrf_polling_check(dm, 0x2834, 0x7fff80, 0xffff);
odm_write_4byte(dm, 0x18b8, 0x02000000);
ODM_delay_ms(1);
odm_write_4byte(dm, 0x18bc, 0x0008ff87);
odm_write_4byte(dm, 0x9b4, 0xdb6db600);
odm_write_4byte(dm, 0x1810, 0x02d508c5);
odm_write_4byte(dm, 0x18bc, 0x0008ff87);
odm_write_4byte(dm, 0x1860, 0xf0000000);
/*4.DACK step2*/
odm_set_bb_reg(dm, 0x18bc, 0xf0000000, 0x0);
odm_set_bb_reg(dm, 0x18c0, 0xf, 0x8);
odm_set_bb_reg(dm, 0x18d8, 0xf0000000, 0x0);
odm_set_bb_reg(dm, 0x18dc, 0xf, 0x8);
odm_write_4byte(dm, 0x1b00, 0x00000008);
odm_write_1byte(dm, 0x1bcc, 0x03f);
odm_write_4byte(dm, 0x180c, 0xdff00220);
odm_write_4byte(dm, 0x1810, 0x02d508c5);
odm_write_4byte(dm, 0x1c3c, 0x00088103);
halrf_mode_8822c(dm, &ic, &qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]before DACK i =0x%x, q = 0x%x",
ic, qc);
/*compensation value*/
if (ic != 0x0)
ic = 0x400 - ic;
if (qc != 0x0)
qc = 0x400 - qc;
if (ic < 0x300) {
ic = ic * 2 * 6 / 5;
ic = ic + 0x80;
} else {
ic = (0x400 - ic) * 2 * 6 / 5;
ic = 0x7f - ic;
}
if (qc < 0x300) {
qc = qc * 2 * 6 / 5;
qc = qc + 0x80;
} else {
qc = (0x400 - qc) * 2 * 6 / 5;
qc = 0x7f - qc;
}
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK ic =0x%x, qc = 0x%x\n",
ic, qc);
ic_a = ic;
qc_a = qc;
/*5.DACK step3*/
odm_write_4byte(dm, 0x180c, 0xdff00220);
odm_write_4byte(dm, 0x1810, 0x02d508c5);
odm_write_4byte(dm, 0x9b4, 0xdb66db00);
odm_write_4byte(dm, 0x18b0, 0x0a11fb88);
odm_write_4byte(dm, 0x18bc, 0xc008ff81);
odm_write_4byte(dm, 0x18c0, 0x0003d208);
odm_set_bb_reg(dm, 0x18bc, 0xf0000000, ic & 0xf);
odm_set_bb_reg(dm, 0x18c0, 0xf, (ic & 0xf0) >> 4);
odm_write_4byte(dm, 0x18cc, 0x0a11fb88);
odm_write_4byte(dm, 0x18d8, 0xe008ff81);
odm_write_4byte(dm, 0x18dc, 0x0003d208);
odm_set_bb_reg(dm, 0x18d8, 0xf0000000, qc & 0xf);
odm_set_bb_reg(dm, 0x18dc, 0xf, (qc & 0xf0) >> 4);
odm_write_4byte(dm, 0x18b8, 0x60000000);
ODM_delay_ms(2);
odm_set_bb_reg(dm, 0x18bc, 0xe, 0x6);
ODM_delay_ms(2);
odm_write_4byte(dm, 0x18b0, 0x0a11fb89);
odm_write_4byte(dm, 0x18cc, 0x0a11fb89);
ODM_delay_ms(1);
odm_write_4byte(dm, 0x18b8, 0x62000000);
odm_write_4byte(dm, 0x18d4, 0x62000000);
ODM_delay_ms(1);
halrf_polling_check(dm, 0x2824, 0x07f80000, ic);
halrf_polling_check(dm, 0x2850, 0x07f80000, qc);
odm_write_4byte(dm, 0x18b8, 0x02000000);
ODM_delay_ms(1);
odm_set_bb_reg(dm, 0x18bc, 0xe, 0x3);
odm_write_4byte(dm, 0x9b4, 0xdb6db600);
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18bc =0x%x",
odm_read_4byte(dm, 0x18bc));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18c0 =0x%x",
odm_read_4byte(dm, 0x18c0));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18d8 =0x%x",
odm_read_4byte(dm, 0x18d8));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18dc =0x%x",
odm_read_4byte(dm, 0x18dc));
#if 1
/*check DAC DC offset*/
temp1 = ((adc_ic_a + 0x10) & 0x3ff) |
(((adc_qc_a + 0x10) & 0x3ff) << 10);
odm_write_4byte(dm, 0x1868, temp1);
RF_DBG(dm, DBG_RF_DACK, "[DACK]shift 0x1868 =0x%x",
odm_read_4byte(dm, 0x1868));
odm_write_4byte(dm, 0x1810, 0x02d508c5);
odm_write_4byte(dm, 0x1860, 0xf0000000);
halrf_mode_8822c(dm, &ic, &qc);
if (ic >= 0x10)
ic = ic - 0x10;
else
ic = 0x400 - (0x10 - ic);
if (qc >= 0x10)
qc = qc - 0x10;
else
qc = 0x400 - (0x10 - qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]after DACK i=0x%x, q=0x%x",
ic, qc);
i_a = ic;
q_a = qc;
if (ic >= 0x200)
ic = 0x400 - ic;
if (qc >= 0x200)
qc = 0x400 - qc;
if (ic < 5 && qc < 5)
break;
#endif
}
odm_write_4byte(dm, 0x1868, 0x0);
odm_write_4byte(dm, 0x1810, 0x02d508c4);
odm_set_bb_reg(dm, 0x18bc, 0x1, 0x0);
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x1);
#if 1
/*path-B*/
RF_DBG(dm, DBG_RF_DACK, "[DACK]pathB DACK!!!!!!!!!!!!!!!!!!!!!!!!!!!");
/*1.ADCK step1*/
RF_DBG(dm, DBG_RF_DACK, "[DACK]step1 ADCK!!!!!!!!!!!!!!!!!!!!!!!!!!!");
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x0);
odm_write_4byte(dm, 0x4130, 0x30db8041);
odm_write_4byte(dm, 0x4160, 0xf0040ff0);
odm_write_4byte(dm, 0x410c, 0xdff00220);
odm_write_4byte(dm, 0x4110, 0x02dd08c4);
odm_write_4byte(dm, 0x410c, 0x10000260);
odm_set_rf_reg(dm, RF_PATH_A, 0x0, RFREGOFFSETMASK, 0x10000);
odm_set_rf_reg(dm, RF_PATH_B, 0x0, RFREGOFFSETMASK, 0x10000);
i = 0;
while (i < 10) {
i++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]ADCK count=%d\n", i);
odm_write_4byte(dm, 0x1c3c, 0x000a8003);
odm_write_4byte(dm, 0x1c24, 0x00010002);
halrf_mode_8822c(dm, &ic, &qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]before ADCK i=0x%x, q=0x%x",
ic, qc);
/*compensation value*/
if (ic != 0x0) {
ic = 0x400 - ic;
adc_ic_b = ic;
}
if (qc != 0x0) {
qc = 0x400 - qc;
adc_qc_b = qc;
}
temp = (ic & 0x3ff) | ((qc & 0x3ff) << 10);
odm_write_4byte(dm, 0x4168, temp);
RF_DBG(dm, DBG_RF_DACK, "[DACK]ADCK 0x4168 =0x%x\n", temp);
#if 1
/*check ADC DC offset*/
odm_write_4byte(dm, 0x1c3c, 0x000a8103);
halrf_mode_8822c(dm, &ic, &qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]after ADCK i=0x%x, q=0x%x",
ic, qc);
#endif
if (ic >= 0x200)
ic = 0x400 - ic;
if (qc >= 0x200)
qc = 0x400 - qc;
if (ic < 5 && qc < 5)
break;
}
/*2.ADCK step2*/
odm_write_4byte(dm, 0x1c3c, 0x00000003);
odm_write_4byte(dm, 0x410c, 0x10000260);
odm_write_4byte(dm, 0x4110, 0x02d508c4);
/*3.release pull low switch on IQ path*/
odm_set_rf_reg(dm, RF_PATH_B, 0x8f, BIT(13), 0x1);
RF_DBG(dm, DBG_RF_DACK, "[DACK]step2 DACK!!!!!!!!!!!!!!!!!!!!!!!!!!!");
i = 0;
while (i < 10) {
odm_write_4byte(dm, 0x4168, temp);
/*DACK step1*/
i++;
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK count=%d\n", i);
odm_write_4byte(dm, 0x410c, 0xdff00220);
odm_write_4byte(dm, 0x4110, 0x02d508c5);
odm_write_4byte(dm, 0x9b4, 0xdb66db00);
odm_write_4byte(dm, 0x41b0, 0x0a11fb88);
odm_write_4byte(dm, 0x41bc, 0x0008ff81);
odm_write_4byte(dm, 0x41c0, 0x0003d208);
odm_write_4byte(dm, 0x41cc, 0x0a11fb88);
odm_write_4byte(dm, 0x41d8, 0x0008ff81);
odm_write_4byte(dm, 0x41dc, 0x0003d208);
odm_write_4byte(dm, 0x41b8, 0x60000000);
ODM_delay_ms(2);
odm_write_4byte(dm, 0x41bc, 0x000aff8d);
ODM_delay_ms(2);
odm_write_4byte(dm, 0x41b0, 0x0a11fb89);
odm_write_4byte(dm, 0x41cc, 0x0a11fb89);
ODM_delay_ms(1);
odm_write_4byte(dm, 0x41b8, 0x62000000);
odm_write_4byte(dm, 0x41d4, 0x62000000);
ODM_delay_ms(1);
halrf_polling_check(dm, 0x4508, 0x7fff80, 0xffff);
halrf_polling_check(dm, 0x4534, 0x7fff80, 0xffff);
odm_write_4byte(dm, 0x41b8, 0x02000000);
ODM_delay_ms(1);
odm_write_4byte(dm, 0x41bc, 0x0008ff87);
odm_write_4byte(dm, 0x9b4, 0xdb6db600);
odm_write_4byte(dm, 0x4110, 0x02d508c5);
odm_write_4byte(dm, 0x41bc, 0x0008ff87);
odm_write_4byte(dm, 0x4160, 0xf0000000);
/*4.DACK step2*/
odm_set_bb_reg(dm, 0x41bc, 0xf0000000, 0x0);
odm_set_bb_reg(dm, 0x41c0, 0xf, 0x8);
odm_set_bb_reg(dm, 0x41d8, 0xf0000000, 0x0);
odm_set_bb_reg(dm, 0x41dc, 0xf, 0x8);
odm_write_4byte(dm, 0x1b00, 0x0000000a);
odm_write_1byte(dm, 0x1bcc, 0x3f);
odm_write_4byte(dm, 0x410c, 0xdff00220);
odm_write_4byte(dm, 0x4110, 0x02d508c5);
odm_write_4byte(dm, 0x1c3c, 0x000a8103);
halrf_mode_8822c(dm, &ic, &qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]before DACK i=0x%x, q=0x%x",
ic, qc);
/*compensation value*/
if (ic != 0x0)
ic = 0x400 - ic;
if (qc != 0x0)
qc = 0x400 - qc;
if (ic < 0x300) {
ic = ic * 2 * 6 / 5;
ic = ic + 0x80;
} else {
ic = (0x400 - ic) * 2 * 6 / 5;
ic = 0x7f - ic;
}
if (qc < 0x300) {
qc = qc * 2 * 6 / 5;
qc = qc + 0x80;
} else {
qc = (0x400 - qc) * 2 * 6 / 5;
qc = 0x7f - qc;
}
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK ic=0x%x, qc=0x%x",
ic, qc);
ic_b = ic;
qc_b = qc;
/*5.DACK step3*/
odm_write_4byte(dm, 0x410c, 0xdff00220);
odm_write_4byte(dm, 0x4110, 0x02d508c5);
odm_write_4byte(dm, 0x9b4, 0xdb66db00);
odm_write_4byte(dm, 0x41b0, 0x0a11fb88);
odm_write_4byte(dm, 0x41bc, 0xc008ff81);
odm_write_4byte(dm, 0x41c0, 0x0003d208);
odm_set_bb_reg(dm, 0x41bc, 0xf0000000, ic & 0xf);
odm_set_bb_reg(dm, 0x41c0, 0xf, (ic & 0xf0) >> 4);
odm_write_4byte(dm, 0x41cc, 0x0a11fb88);
odm_write_4byte(dm, 0x41d8, 0xe008ff81);
odm_write_4byte(dm, 0x41dc, 0x0003d208);
odm_set_bb_reg(dm, 0x41d8, 0xf0000000, qc & 0xf);
odm_set_bb_reg(dm, 0x41dc, 0xf, (qc & 0xf0) >> 4);
odm_write_4byte(dm, 0x41b8, 0x60000000);
ODM_delay_ms(2);
odm_set_bb_reg(dm, 0x41bc, 0xe, 0x6);
ODM_delay_ms(2);
odm_write_4byte(dm, 0x41b0, 0x0a11fb89);
odm_write_4byte(dm, 0x41cc, 0x0a11fb89);
ODM_delay_ms(1);
odm_write_4byte(dm, 0x41b8, 0x62000000);
odm_write_4byte(dm, 0x41d4, 0x62000000);
ODM_delay_ms(1);
halrf_polling_check(dm, 0x4524, 0x07f80000, ic);
halrf_polling_check(dm, 0x4550, 0x07f80000, qc);
odm_write_4byte(dm, 0x41b8, 0x02000000);
ODM_delay_ms(1);
odm_set_bb_reg(dm, 0x41bc, 0xe, 0x3);
odm_write_4byte(dm, 0x9b4, 0xdb6db600);
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41bc =0x%x",
odm_read_4byte(dm, 0x41bc));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41c0 =0x%x",
odm_read_4byte(dm, 0x41c0));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41d8 =0x%x",
odm_read_4byte(dm, 0x41d8));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41dc =0x%x",
odm_read_4byte(dm, 0x41dc));
#if 1
/*check DAC DC offset*/
temp1 = ((adc_ic_b + 0x10) & 0x3ff) |
(((adc_qc_b + 0x10) & 0x3ff) << 10);
odm_write_4byte(dm, 0x4168, temp1);
RF_DBG(dm, DBG_RF_DACK, "[DACK]shift 0x4168 =0x%x\n",
odm_read_4byte(dm, 0x4168));
odm_write_4byte(dm, 0x4110, 0x02d508c5);
odm_write_4byte(dm, 0x4160, 0xf0000000);
halrf_mode_8822c(dm, &ic, &qc);
if (ic >= 0x10)
ic = ic - 0x10;
else
ic = 0x400 - (0x10 - ic);
if (qc >= 0x10)
qc = qc - 0x10;
else
qc = 0x400 - (0x10 - qc);
RF_DBG(dm, DBG_RF_DACK, "[DACK]after DACK i=0x%x, q=0x%x",
ic, qc);
i_b = ic;
q_b = qc;
#endif
if (ic >= 0x200)
ic = 0x400 - ic;
if (qc >= 0x200)
qc = 0x400 - qc;
if (ic < 5 && qc < 5)
break;
}
#endif
odm_write_4byte(dm, 0x4168, 0x0);
odm_write_4byte(dm, 0x4110, 0x02d508c4);
odm_set_bb_reg(dm, 0x41bc, 0x1, 0x0);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x1);
odm_write_4byte(dm, 0x1b00, 0x00000008);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x1);
odm_write_1byte(dm, 0x1bcc, 0x0);
odm_write_4byte(dm, 0x1b00, 0x0000000a);
odm_write_1byte(dm, 0x1bcc, 0x0);
i_b = ic;
q_b = qc;
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH A:ic=0x%x, qc=0x%x", ic_a, qc_a);
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH B:ic=0x%x, qc=0x%x", ic_b, qc_b);
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH A:i=0x%x, q=0x%x", i_a, q_a);
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH B:i=0x%x, q=0x%x", i_b, q_b);
halrf_reload_bp_8822c(dm, bp_reg, bp);
halrf_reload_bprf_8822c(dm, bp_rfreg, bp_rf);
halrf_dack_backup_8822c(dm);
RF_DBG(dm, DBG_RF_DACK, "[DACK]DACK end!!!!!!!\n");
#endif
}
void halrf_dack_dbg_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 i;
u32 temp1, temp2, temp3;
temp1 = odm_get_bb_reg(dm, 0x1860, MASKDWORD);
temp2 = odm_get_bb_reg(dm, 0x4160, MASKDWORD);
temp3 = odm_get_bb_reg(dm, 0x9b4, MASKDWORD);
odm_set_bb_reg(dm, 0x9b4, MASKDWORD, 0xdb66db00);
RF_DBG(dm, DBG_RF_DACK, "[DACK]MSBK result\n");
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH A\n");
//pathA
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x1860, 0xfc000000, 0x3c);
//i
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18b0, 0xf0000000, i);
RF_DBG(dm, DBG_RF_DACK, "[DACK]msbk_d[0][0][%d]=0x%x\n", i,
odm_get_bb_reg(dm,0x2810,0x7fc0000));
}
//q
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x18cc, 0xf0000000, i);
RF_DBG(dm, DBG_RF_DACK, "[DACK]msbk_d[0][1][%d]=0x%x\n", i,
odm_get_bb_reg(dm,0x283c,0x7fc0000));
}
//pathB
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH A\n");
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x0);
odm_set_bb_reg(dm, 0x4160, 0xfc000000, 0x3c);
//i
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41b0, 0xf0000000, i);
RF_DBG(dm, DBG_RF_DACK, "[DACK]msbk_d[1][0][%d]=0x%x\n", i,
odm_get_bb_reg(dm,0x4510,0x7fc0000));
}
//q
for (i = 0; i < 0xf; i++) {
odm_set_bb_reg(dm, 0x41cc, 0xf0000000, i);
RF_DBG(dm, DBG_RF_DACK, "[DACK]msbk_d[1][1][%d]=0x%x\n", i,
odm_get_bb_reg(dm,0x453c,0x7fc0000));
}
RF_DBG(dm, DBG_RF_DACK, "[DACK]DCK result\n");
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH A\n");
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18bc[31:28]=0x%x\n",
odm_get_bb_reg(dm,0x18bc,0xf0000000));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18c0[3:0]=0x%x\n",
odm_get_bb_reg(dm,0x18c0,0xf));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18d8[31:28]=0x%x\n",
odm_get_bb_reg(dm,0x18d8,0xf0000000));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x18dc[3:0]=0x%x\n",
odm_get_bb_reg(dm,0x18dc,0xf));
RF_DBG(dm, DBG_RF_DACK, "[DACK]PATH B\n");
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41bc[31:28]=0x%x\n",
odm_get_bb_reg(dm,0x41bc,0xf0000000));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41c0[3:0]=0x%x\n",
odm_get_bb_reg(dm,0x41c0,0xf));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41d8[31:28]=0x%x\n",
odm_get_bb_reg(dm,0x41d8,0xf0000000));
RF_DBG(dm, DBG_RF_DACK, "[DACK]0x41dc[3:0]=0x%x\n",
odm_get_bb_reg(dm,0x41dc,0xf));
//restore to normal
odm_set_bb_reg(dm, 0x1830, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x4130, BIT(30), 0x1);
odm_set_bb_reg(dm, 0x1860, MASKDWORD, temp1);
odm_set_bb_reg(dm, 0x4160, MASKDWORD, temp2);
odm_set_bb_reg(dm, 0x9b4, MASKDWORD, temp3);
}
void _phy_x2_calibrate_8822c(struct dm_struct *dm)
{
RF_DBG(dm, DBG_RF_IQK, "[X2K]X2K start!!!!!!!\n");
/*X2K*/
//Path A
odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, 0x13108);
ODM_delay_ms(1);
odm_set_rf_reg(dm, RF_PATH_A, 0xb8, RFREGOFFSETMASK, 0xC0440);
odm_set_rf_reg(dm, RF_PATH_A, 0xba, RFREGOFFSETMASK, 0xE840D);
ODM_delay_ms(1);
odm_set_rf_reg(dm, RF_PATH_A, 0x18, RFREGOFFSETMASK, 0x13124);
//Path B
// SYN is in the path A
RF_DBG(dm, DBG_RF_IQK, "[X2K]X2K end!!!!!!!\n");
}
void phy_x2_check_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u32 X2K_BUSY;
RF_DBG(dm, DBG_RF_IQK, "[X2K]X2K check start!!!!!!!\n");
/*X2K*/
//Path A
ODM_delay_ms(1);
X2K_BUSY = (u8) odm_get_rf_reg(dm, RF_PATH_A, 0xb8, BIT(15));
if (X2K_BUSY == 1) {
odm_set_rf_reg(dm, RF_PATH_A, 0xb8, RFREGOFFSETMASK, 0xC4440);
odm_set_rf_reg(dm, RF_PATH_A, 0xba, RFREGOFFSETMASK, 0x6840D);
odm_set_rf_reg(dm, RF_PATH_A, 0xb8, RFREGOFFSETMASK, 0x80440);
ODM_delay_ms(1);
}
//Path B
// SYN is in the path A
RF_DBG(dm, DBG_RF_IQK, "[X2K]X2K check end!!!!!!!\n");
}
/*LCK VERSION:0x1*/
void phy_lc_calibrate_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
#if 1
_phy_aac_calibrate_8822c(dm);
_phy_rt_calibrate_8822c(dm);
#endif
}
void configure_txpower_track_8822c(struct txpwrtrack_cfg *config)
{
config->swing_table_size_cck = TXSCALE_TABLE_SIZE;
config->swing_table_size_ofdm = TXSCALE_TABLE_SIZE;
config->threshold_iqk = IQK_THRESHOLD;
config->threshold_dpk = DPK_THRESHOLD;
config->average_thermal_num = AVG_THERMAL_NUM_8822C;
config->rf_path_count = MAX_PATH_NUM_8822C;
config->thermal_reg_addr = RF_T_METER_8822C;
config->odm_tx_pwr_track_set_pwr = odm_tx_pwr_track_set_pwr8822c;
config->do_iqk = do_iqk_8822c;
config->phy_lc_calibrate = halrf_lck_trigger;
config->get_delta_swing_table = get_delta_swing_table_8822c;
}
#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
void phy_set_rf_path_switch_8822c(struct dm_struct *dm, boolean is_main)
#else
void phy_set_rf_path_switch_8822c(void *adapter, boolean is_main)
#endif
{
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_struct *dm = &hal_data->DM_OutSrc;
#endif
#endif
/*BY mida Request */
if (is_main) {
/*WiFi*/
odm_set_bb_reg(dm, R_0x70, BIT(26), 0x1);
} else {
/*BT*/
odm_set_bb_reg(dm, R_0x70, BIT(26), 0x0);
}
}
#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
boolean _phy_query_rf_path_switch_8822c(struct dm_struct *dm)
#else
boolean _phy_query_rf_path_switch_8822c(void *adapter)
#endif
{
#if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
struct dm_struct *dm = &hal_data->DM_OutSrc;
#endif
#endif
if (odm_get_bb_reg(dm, R_0x70, BIT(26)) == 0x1)
return true; /*WiFi*/
else
return false;
}
#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
boolean phy_query_rf_path_switch_8822c(struct dm_struct *dm)
#else
boolean phy_query_rf_path_switch_8822c(void *adapter)
#endif
{
#if DISABLE_BB_RF
return true;
#endif
#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
return _phy_query_rf_path_switch_8822c(dm);
#else
return _phy_query_rf_path_switch_8822c(adapter);
#endif
}
void halrf_rxbb_dc_cal_8822c(void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
u8 path;
for (path = 0; path < 2; path++) {
odm_set_rf_reg(dm, (enum rf_path)path, 0x92, RFREG_MASK, 0x84800);
ODM_delay_us(5);
odm_set_rf_reg(dm, (enum rf_path)path, 0x92, RFREG_MASK, 0x84801);
ODM_delay_us(600);
odm_set_rf_reg(dm, (enum rf_path)path, 0x92, RFREG_MASK, 0x84800);
}
}
void halrf_rfk_handshake_8822c(void *dm_void, boolean is_before_k)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct _hal_rf_ *rf = &dm->rf_table;
u8 u1b_tmp, h2c_parameter;
u16 count;
if (is_before_k) {
RF_DBG(dm, DBG_RF_IQK | DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[RFK] WiFi / BT RFK handshake start!!\n");
if (!rf->is_bt_iqk_timeout) {
/* Check if BT request to do IQK (0xaa[6]) or is doing IQK (0xaa[5]), 600ms timeout*/
count = 0;
u1b_tmp = (u8)odm_get_mac_reg(dm, 0xa8, BIT(22) | BIT(21));
while (u1b_tmp != 0 && count < 30000) {
ODM_delay_us(20);
u1b_tmp = (u8)odm_get_mac_reg(dm, 0xa8, BIT(22) | BIT(21));
count++;
}
if (count >= 30000) {
RF_DBG(dm, DBG_RF_IQK | DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[RFK] Wait BT IQK finish timeout!!\n");
rf->is_bt_iqk_timeout = true;
}
}
/* Send RFK start H2C cmd*/
h2c_parameter = 1;
odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
/* Check 0x49c[0] or 100ms timeout*/
count = 0;
u1b_tmp = (u8)odm_get_mac_reg(dm, 0x49c, BIT(0));
while (u1b_tmp != 0x1 && count < 5000) {
ODM_delay_us(20);
u1b_tmp = (u8)odm_get_mac_reg(dm, 0x49c, BIT(0));
count++;
}
if (count >= 5000)
RF_DBG(dm, DBG_RF_IQK | DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[RFK] Send WiFi RFK start H2C cmd FAIL!!\n");
} else {
/* Send RFK finish H2C cmd*/
h2c_parameter = 0;
odm_fill_h2c_cmd(dm, ODM_H2C_WIFI_CALIBRATION, 1, &h2c_parameter);
/* Check 0x49c[0] or 100ms timeout*/
count = 0;
u1b_tmp = (u8)odm_get_mac_reg(dm, 0x49c, BIT(0));
while (u1b_tmp != 0 && count < 5000) {
ODM_delay_us(20);
u1b_tmp = (u8)odm_get_mac_reg(dm, 0x49c, BIT(0));
count++;
}
if (count >= 5000)
RF_DBG(dm, DBG_RF_IQK | DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[RFK] Send WiFi RFK finish H2C cmd FAIL!!\n");
RF_DBG(dm, DBG_RF_IQK | DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[RFK] WiFi / BT RFK handshake finish!!\n");
}
}
#endif /*(RTL8822C_SUPPORT == 0)*/
================================================
FILE: hal/phydm/halrf/rtl8822c/halrf_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#ifndef __HALRF_8822C_H__
#define __HALRF_8822C_H__
#define AVG_THERMAL_NUM_8822C 4
#define RF_T_METER_8822C 0x42
#define DACK_REG_8822C 16
#define DACK_RF_8822C 1
void halrf_rf_lna_setting_8822c(
struct dm_struct *p_dm_void,
enum halrf_lna_set type);
void configure_txpower_track_8822c(
struct txpwrtrack_cfg *config);
void odm_tx_pwr_track_set_pwr8822c(
void *dm_void,
enum pwrtrack_method method,
u8 rf_path,
u8 channel_mapped_index);
void get_delta_swing_table_8198f(
void *dm_void,
u8 **temperature_up_a,
u8 **temperature_down_a,
u8 **temperature_up_b,
u8 **temperature_down_b,
u8 **temperature_up_cck_a,
u8 **temperature_down_cck_a,
u8 **temperature_up_cck_b,
u8 **temperature_down_cck_b
);
void get_delta_swing_table_8822c_ex(
void *p_dm_void,
u8 **temperature_up_c,
u8 **temperature_down_c,
u8 **temperature_up_d,
u8 **temperature_down_d,
u8 **temperature_up_cck_c,
u8 **temperature_down_cck_c,
u8 **temperature_up_cck_d,
u8 **temperature_down_cck_d
);
void halrf_dac_cal_all_8822c(void *dm_void);
void halrf_dac_cal_8822c(void *dm_void, boolean force);
void halrf_dack_dbg_8822c(void *dm_void);
void phy_lc_calibrate_8822c(
void *dm_void);
void phy_x2_check_8822c(void *dm_void);
void phy_set_rf_path_switch_8822c(
#if ((DM_ODM_SUPPORT_TYPE & ODM_AP) || (DM_ODM_SUPPORT_TYPE == ODM_CE))
struct dm_struct *dm,
#else
void *adapter,
#endif
boolean is_main);
void halrf_rxbb_dc_cal_8822c(void *dm_void);
void halrf_rfk_handshake_8822c(void *dm_void, boolean is_before_k);
void halrf_dack_restore_8822c(void *dm_void);
#endif /*__HALRF_8822C_H__*/
================================================
FILE: hal/phydm/halrf/rtl8822c/halrf_dpk_8822c.c
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger
*
*****************************************************************************/
#include "mp_precomp.h"
#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
#if RT_PLATFORM == PLATFORM_MACOSX
#include "phydm_precomp.h"
#else
#include "../phydm_precomp.h"
#endif
#else
#include "../../phydm_precomp.h"
#endif
#if (RTL8822C_SUPPORT == 1)
/*---------------------------Define Local Constant---------------------------*/
/*8822C DPK ver:0x19 20190425*/
static u32
_btc_wait_indirect_reg_ready_8822c(
struct dm_struct *dm)
{
u32 delay_count = 0;
/* wait for ready bit before access 0x1700 */
while (1) {
if ((odm_read_1byte(dm, 0x1703) & BIT(5)) == 0) {
delay_ms(10);
if (++delay_count >= 10)
break;
} else {
break;
}
}
return delay_count;
}
static u32
_btc_read_indirect_reg_8822c(
struct dm_struct *dm,
u16 reg_addr)
{
u32 delay_count = 0;
/* wait for ready bit before access 0x1700 */
_btc_wait_indirect_reg_ready_8822c(dm);
odm_write_4byte(dm, 0x1700, 0x800F0000 | reg_addr);
return odm_read_4byte(dm, 0x1708); /* get read data */
}
static void
_btc_write_indirect_reg_8822c(
struct dm_struct *dm,
u16 reg_addr,
u32 bit_mask,
u32 reg_value)
{
u32 val, i = 0, bitpos = 0, delay_count = 0;
if (bit_mask == 0x0)
return;
if (bit_mask == 0xffffffff) {
/* wait for ready bit before access 0x1700 */
_btc_wait_indirect_reg_ready_8822c(dm);
/* put write data */
odm_write_4byte(dm, 0x1704, reg_value);
odm_write_4byte(dm, 0x1700, 0xc00F0000 | reg_addr);
} else {
for (i = 0; i <= 31; i++) {
if (((bit_mask >> i) & 0x1) == 0x1) {
bitpos = i;
break;
}
}
/* read back register value before write */
val = _btc_read_indirect_reg_8822c(dm, reg_addr);
val = (val & (~bit_mask)) | (reg_value << bitpos);
/* wait for ready bit before access 0x1700 */
_btc_wait_indirect_reg_ready_8822c(dm);
odm_write_4byte(dm, 0x1704, val); /* put write data */
odm_write_4byte(dm, 0x1700, 0xc00F0000 | reg_addr);
}
}
void btc_set_gnt_wl_bt_8822c(
void *dm_void,
boolean is_before_k)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
if (is_before_k) {
dpk_info->gnt_control = odm_get_mac_reg(dm, R_0x70, MASKDWORD);
dpk_info->gnt_value = _btc_read_indirect_reg_8822c(dm, 0x38);
/*force GNT control to WL*/
odm_set_mac_reg(dm, R_0x70, BIT(26), 0x1);
/*force GNT_WL=1, GNT_BT=0*/
_btc_write_indirect_reg_8822c(dm, 0x38, 0xFF00, 0x77);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] ori 0x70 / 0x38 = 0x%x / 0x%x\n",
dpk_info->gnt_control, dpk_info->gnt_value);
RF_DBG(dm, DBG_RF_DPK, "[DPK] set 0x70/0x38 = 0x%x/0x%x\n",
odm_get_mac_reg(dm, R_0x70, MASKDWORD),
_btc_read_indirect_reg_8822c(dm, 0x38));
#endif
} else {
_btc_write_indirect_reg_8822c(dm, 0x38, MASKDWORD, dpk_info->gnt_value);
odm_set_mac_reg(dm, R_0x70, MASKDWORD, dpk_info->gnt_control);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] load 0x70 / 0x38 = 0x%x / 0x%x\n",
odm_get_mac_reg(dm, R_0x70, MASKDWORD),
_btc_read_indirect_reg_8822c(dm, 0x38));
#endif
}
}
void _backup_mac_bb_registers_8822c(
struct dm_struct *dm,
u32 *reg,
u32 *reg_backup,
u32 reg_num)
{
u32 i;
for (i = 0; i < reg_num; i++) {
reg_backup[i] = odm_read_4byte(dm, reg[i]);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] Backup MAC/BB 0x%x = 0x%x\n",
reg[i], reg_backup[i]);
#endif
}
}
void _backup_rf_registers_8822c(
struct dm_struct *dm,
u32 *rf_reg,
u32 rf_reg_backup[][2])
{
u32 i;
for (i = 0; i < DPK_RF_REG_NUM_8822C; i++) {
rf_reg_backup[i][RF_PATH_A] = odm_get_rf_reg(dm, RF_PATH_A,
rf_reg[i], RFREG_MASK);
rf_reg_backup[i][RF_PATH_B] = odm_get_rf_reg(dm, RF_PATH_B,
rf_reg[i], RFREG_MASK);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] Backup RF_A 0x%x = 0x%x\n",
rf_reg[i], rf_reg_backup[i][RF_PATH_A]);
RF_DBG(dm, DBG_RF_DPK, "[DPK] Backup RF_B 0x%x = 0x%x\n",
rf_reg[i], rf_reg_backup[i][RF_PATH_B]);
#endif
}
}
void _reload_mac_bb_registers_8822c(
struct dm_struct *dm,
u32 *reg,
u32 *reg_backup,
u32 reg_num)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u32 i;
/*toggle IGI*/
odm_write_4byte(dm, 0x1d70, 0x50505050);
for (i = 0; i < reg_num; i++) {
odm_write_4byte(dm, reg[i], reg_backup[i]);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] Reload MAC/BB 0x%x = 0x%x\n",
reg[i], reg_backup[i]);
#endif
}
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc); /*subpage 2*/
odm_set_bb_reg(dm, R_0x1bd4, 0x000000f0, 0x4); /*force CLK off for power saving*/
}
void _reload_rf_registers_8822c(
struct dm_struct *dm,
u32 *rf_reg,
u32 rf_reg_backup[][2])
{
u32 i, rf_reg_8f[DPK_RF_PATH_NUM_8822C] = {0x0};
for (i = 0; i < DPK_RF_REG_NUM_8822C; i++) {
odm_set_rf_reg(dm, RF_PATH_A, rf_reg[i], RFREG_MASK,
rf_reg_backup[i][RF_PATH_A]);
odm_set_rf_reg(dm, RF_PATH_B, rf_reg[i], RFREG_MASK,
rf_reg_backup[i][RF_PATH_B]);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] Reload RF_A 0x%x = 0x%x\n",
rf_reg[i], rf_reg_backup[i][RF_PATH_A]);
RF_DBG(dm, DBG_RF_DPK, "[DPK] Reload RF_B 0x%x = 0x%x\n",
rf_reg[i], rf_reg_backup[i][RF_PATH_B]);
#endif
}
#if 0
/*reload RF 0x8f for non-saving power mode*/
for (i = 0; i < DPK_RF_PATH_NUM_8822C; i++) {
rf_reg_8f[i] = odm_get_rf_reg(dm, (enum rf_path)i,
RF_0x8f, 0x00fff);
odm_set_rf_reg(dm, (enum rf_path)i, RF_0x8f, RFREG_MASK,
0xa8000 | rf_reg_8f[i]);
}
#endif
}
void _dpk_information_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u32 reg_rf18;
if (odm_get_bb_reg(dm, R_0x1e7c, BIT(30)))
dpk_info->is_tssi_mode = true;
else
dpk_info->is_tssi_mode = false;
reg_rf18 = odm_get_rf_reg(dm, RF_PATH_A, RF_0x18, RFREG_MASK);
dpk_info->dpk_band = (u8)((reg_rf18 & BIT(16)) >> 16); /*0/1:G/A*/
dpk_info->dpk_ch = (u8)reg_rf18 & 0xff;
dpk_info->dpk_bw = (u8)((reg_rf18 & 0x3000) >> 12); /*3/2/1:20/40/80*/
RF_DBG(dm, DBG_RF_DPK, "[DPK] TSSI/ Band/ CH/ BW = %d / %s / %d / %s\n",
dpk_info->is_tssi_mode, dpk_info->dpk_band == 0 ? "2G" : "5G",
dpk_info->dpk_ch,
dpk_info->dpk_bw == 3 ? "20M" : (dpk_info->dpk_bw == 2 ? "40M" : "80M"));
}
void _dpk_rxbb_dc_cal_8822c(
struct dm_struct *dm,
u8 path)
{
odm_set_rf_reg(dm, (enum rf_path)path, 0x92, RFREG_MASK, 0x84800);
ODM_delay_us(5);
odm_set_rf_reg(dm, (enum rf_path)path, 0x92, RFREG_MASK, 0x84801);
ODM_delay_us(600);
odm_set_rf_reg(dm, (enum rf_path)path, 0x92, RFREG_MASK, 0x84800);
}
u8 _dpk_dc_corr_check_8822c(
struct dm_struct *dm,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u16 dc_i, dc_q;
u8 corr_val, corr_idx;
odm_write_4byte(dm, 0x1bd4, 0x000900F0);
dc_i = (u16)odm_get_bb_reg(dm, 0x1bfc, 0x0fff0000);
dc_q = (u16)odm_get_bb_reg(dm, 0x1bfc, 0x00000fff);
if (dc_i >> 11 == 1)
dc_i = 0x1000 - dc_i;
if (dc_q >> 11 == 1)
dc_q = 0x1000 - dc_q;
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d DC I/Q, = %d / %d\n", path, dc_i, dc_q);
odm_write_4byte(dm, 0x1bd4, 0x000000F0);
corr_idx = (u8)odm_get_bb_reg(dm, 0x1bfc, 0x000000ff);
corr_val = (u8)odm_get_bb_reg(dm, 0x1bfc, 0x0000ff00);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d Corr_idx / Corr_val = %d / %d\n",
path, corr_idx, corr_val);
if ((dc_i > 200) || (dc_q > 200) || (corr_idx < 40) || (corr_idx > 65))
return 1;
else
return 0;
}
void _dpk_tx_pause_8822c(
struct dm_struct *dm)
{
u8 reg_rf0_a, reg_rf0_b;
u16 count = 0;
odm_write_1byte(dm, R_0x522, 0xff);
odm_set_bb_reg(dm, R_0x1e70, 0x0000000f, 0x2); /*hw tx stop*/
reg_rf0_a = (u8)odm_get_rf_reg(dm, RF_PATH_A, RF_0x00, 0xF0000);
reg_rf0_b = (u8)odm_get_rf_reg(dm, RF_PATH_B, RF_0x00, 0xF0000);
while (((reg_rf0_a == 2) || (reg_rf0_b == 2)) && count < 2500) {
reg_rf0_a = (u8)odm_get_rf_reg(dm, RF_PATH_A, RF_0x00, 0xF0000);
reg_rf0_b = (u8)odm_get_rf_reg(dm, RF_PATH_B, RF_0x00, 0xF0000);
ODM_delay_us(2);
count++;
}
RF_DBG(dm, DBG_RF_DPK, "[DPK] Tx pause!!\n");
}
void _dpk_mac_bb_setting_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
_dpk_tx_pause_8822c(dm);
if (dpk_info->is_tssi_mode) {
odm_set_bb_reg(dm, R_0x1e7c, BIT(30), 0x0);
odm_set_bb_reg(dm, R_0x18a4, BIT(28), 0x0);
odm_set_bb_reg(dm, R_0x41a4, BIT(28), 0x0);
}
odm_set_bb_reg(dm, R_0x1e24, BIT(17), 0x1); /*r_gothrough_iqkdpk*/
odm_set_bb_reg(dm, R_0x1d58, 0xff8, 0x1ff); /*BB CCA off*/
/*r_rftxen_gck_force*/
odm_set_bb_reg(dm, R_0x1864, BIT(31), 0x1);
odm_set_bb_reg(dm, R_0x4164, BIT(31), 0x1);
/*r_dis_sharerx_txgat*/
odm_set_bb_reg(dm, R_0x180c, BIT(27), 0x1);
odm_set_bb_reg(dm, R_0x410c, BIT(27), 0x1);
odm_set_bb_reg(dm, R_0x186c, BIT(7), 0x1);
odm_set_bb_reg(dm, R_0x416c, BIT(7), 0x1);
odm_set_bb_reg(dm, R_0x180c, BIT(1) | BIT(0), 0x0);
odm_set_bb_reg(dm, R_0x410c, BIT(1) | BIT(0), 0x0);
odm_set_bb_reg(dm, R_0x1a14, 0x300, 0x3); /*CCK RXIQ weighting=0*/
odm_set_bb_reg(dm, R_0x80c, 0x0000000f, 0x8); /*freq shap filter*/
/*odm_write_1byte(dm, R_0x820, 0x33);*/
odm_set_bb_reg(dm, R_0x824, 0x000f0000, 0x3);
odm_set_bb_reg(dm, R_0x824, 0x0f000000, 0x3);
RF_DBG(dm, DBG_RF_DPK, "[DPK] MAC/BB setting for DPK mode\n");
}
void _dpk_manual_txagc_8822c(
struct dm_struct *dm,
boolean is_manual)
{
odm_set_bb_reg(dm, R_0x18a4, BIT(7), is_manual);
odm_set_bb_reg(dm, R_0x41a4, BIT(7), is_manual);
}
void _dpk_set_txagc_8822c(
struct dm_struct *dm)
{
odm_set_bb_reg(dm, R_0x18a0, 0x007C0000, 0x1f);
odm_set_bb_reg(dm, R_0x41a0, 0x007C0000, 0x1f);
odm_set_bb_reg(dm, 0x18e8, 0x0001F000, 0x1f);
odm_set_bb_reg(dm, 0x41e8, 0x0001F000, 0x1f);
}
void _dpk_afe_setting_8822c(
struct dm_struct *dm,
boolean is_do_dpk)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
if (is_do_dpk) {
odm_set_bb_reg(dm, R_0x1c38, MASKDWORD, 0xFFFFFFFF);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x700f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x700f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x701f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x702f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x703f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x704f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x705f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x706f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x707f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x708f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x709f0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70af0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70bf0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70cf0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70df0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70ef0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70ff0001);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70ff0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x700f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x700f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x701f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x702f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x703f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x704f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x705f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x706f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x707f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x708f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x709f0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70af0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70bf0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70cf0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70df0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70ef0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70ff0001);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70ff0001);
RF_DBG(dm, DBG_RF_DPK, "[DPK] AFE for DPK mode\n");
} else {
if (dpk_info->is_tssi_mode) {
odm_set_bb_reg(dm, R_0x1c38, MASKDWORD, 0xf7d5005e);
odm_set_bb_reg(dm, R_0x1860, 0x00007000, 0x4 >> dpk_info->dpk_band);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x700b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x701f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x702f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x703f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x704f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x705b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x706f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x700b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x701f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x702f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x703f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x704f0040 | (0x4 >> dpk_info->dpk_band));
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x705b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x706f0040 | (0x4 >> dpk_info->dpk_band));
RF_DBG(dm, DBG_RF_DPK, "[DPK] AFE for TSSI mode\n");
} else {
odm_set_bb_reg(dm, R_0x1c38, MASKDWORD, 0xFFA1005E);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x700b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70144041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70244041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70344041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70444041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x705b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70644041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x700b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70144041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70244041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70344041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70444041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x705b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70644041);
RF_DBG(dm, DBG_RF_DPK, "[DPK] AFE for non-TSSI mode\n");
}
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x707b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x708b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x709b8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70ab8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70bb8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70cb8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70db8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70eb8041);
odm_set_bb_reg(dm, R_0x1830, MASKDWORD, 0x70fb8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x707b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x708b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x709b8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70ab8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70bb8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70cb8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70db8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70eb8041);
odm_set_bb_reg(dm, R_0x4130, MASKDWORD, 0x70fb8041);
}
}
void _dpk_pre_setting_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 path;
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x19, RFREG_MASK, 0x0);
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0x8 | (path << 1));
if (dpk_info->dpk_band == 0x0) /*txagc bnd*/
odm_set_bb_reg(dm, R_0x1b60, MASKDWORD, 0x1f100000);
else
odm_set_bb_reg(dm, R_0x1b60, MASKDWORD, 0x1f0d0000);
odm_set_bb_reg(dm, R_0x1b44, 0x00007000, 0x4); /*GL = val*0.5+1*/
odm_set_bb_reg(dm, R_0x1b20, 0xc0000000, 0x3); /*CFIR to TX*/
}
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc); /*one-shot 6ms*/
odm_set_bb_reg(dm, R_0x1be4, MASKDWORD, 0x3b23170b);
odm_set_bb_reg(dm, R_0x1be8, MASKDWORD, 0x775f5347);
}
u32 _dpk_rf_setting_8822c(
struct dm_struct *dm,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
s8 txidx_offset = 0x0;
u32 value32 = 0, ori_txbb = 0;
#if 0
if (phydm_set_bb_dbg_port(dm, DBGPORT_PRI_1, 0x944 | (path << 9))) {
value32 = phydm_get_bb_dbg_port_val(dm);
phydm_release_bb_dbg_port(dm);
}
txidx_offset = (value32 >> 8) & 0x7f;
if ((txidx_offset >> 6) == 1)
txidx_offset = (txidx_offset - 0x80) / 4;
else
txidx_offset = txidx_offset / 4;
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d txidx_offset = 0x%x\n",
path, txidx_offset);
#endif
if (dpk_info->dpk_band == 0x0) { /*2G*/
/*TXAGC for gainloss*/
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x00, RFREG_MASK, 0x50017 + txidx_offset);
ori_txbb = odm_get_rf_reg(dm, (enum rf_path)path,
RF_0x56, RFREG_MASK);
/*debug TX Gain*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xde, BIT(16), 0x1);
/*debug power trim*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xde, BIT(19), 0x1);
/*set offset to zero*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x55, 0x7C000, 0x0);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x56,
RFREG_MASK, ori_txbb);
/*ATT Gain*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x55,
BIT(4) | BIT(3) | BIT(2), 0x1);
/*mixer*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x87,
BIT(18), 0x0);
/*PGA2*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x00,
0x003e0, 0xf);
} else { /*5G*/
/*TXAGC for gainloss*/
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x00, RFREG_MASK, 0x50017 + txidx_offset);
ori_txbb = odm_get_rf_reg(dm, (enum rf_path)path,
RF_0x56, RFREG_MASK);
/*debug TX Gain*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xde, BIT(16), 0x1);
/*debug power trim*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xde, BIT(19), 0x1);
/*set offset to zero*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x55, 0x7C000, 0x0);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x56,
RFREG_MASK, ori_txbb);
/*ATT Gain*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x63,
BIT(15) | BIT(14), 0x0);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x63,
BIT(4) | BIT(3) | BIT(2), 0x6);
/*switch*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x63,
BIT(13) | BIT(12), 0x1);
/*mixer*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x8a,
BIT(4) | BIT(3), 0x0);
/*PGA2*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x00,
0x003e0, 0xf);
}
/*Bypass RXBB filter*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0xde,
BIT(2), 0x1);
/*BW of RXBB*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x1a,
BIT(11) | BIT(10), 0x0);
/*BW of TXBB*/
if (dpk_info->dpk_bw == 0x1) /*80M*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x1a,
BIT(14) | BIT(13) | BIT(12), 0x2);
else
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x1a,
BIT(14) | BIT(13) | BIT(12), 0x1);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x8f,
BIT(1), 0x1);
RF_DBG(dm, DBG_RF_DPK, "[DPK] ori TXAGC/TXBB/offset = 0x%x / 0x%x / %+d\n",
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x00, 0x0001f),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x56, 0x0001f),
(ori_txbb & 0x1f) - 0xf); /*txagc 0x17 = txbb 0xf*/
ODM_delay_us(100); /*delay for TIA SV loop*/
return ori_txbb & 0x1f;
}
u8 _dpk_one_shot_8822c(
struct dm_struct *dm,
u8 path,
u8 action)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 temp = 0x0, bw = 0x0, reg_2d9c = 0x0, sync_done = 0x0, result = 0;
u16 dpk_cmd = 0x0, count = 0;
if (dpk_info->dpk_bw == 0x1) /*80M*/
bw = 2;
else
bw = 0;
if (action == GAIN_LOSS)
temp = 0x14 + path;
else if (action == DO_DPK)
temp = 0x16 + path + bw;
else if (action == DPK_ON)
temp = 0x1a + path;
else if (action == DAGC)
temp = 0x1c + path + bw;
btc_set_gnt_wl_bt_8822c(dm, true);
if (action ==0) {
odm_set_bb_reg(dm, R_0x1bb4, BIT(12), 0x1);
odm_set_bb_reg(dm, R_0x1bb4, BIT(12), 0x0);
odm_set_bb_reg(dm, R_0x1bd4, 0x001f0000, 0x0);
ODM_delay_us(20);
sync_done = (u8)odm_get_bb_reg(dm, R_0x1bfc, BIT(31));
while (sync_done != 0x1 && count < 1000) {
ODM_delay_us(20);
sync_done = (u8)odm_get_bb_reg(dm, R_0x1bfc, BIT(31));
count++;
}
} else {
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1bcc, 0x0000003f, 0x9); /*ItQt -6dB*/
dpk_cmd = (temp << 8) | 0x48;
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, dpk_cmd);
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, dpk_cmd + 1);
reg_2d9c = odm_read_1byte(dm, R_0x2d9c);
while (reg_2d9c != 0x55 && count < 1000) {
ODM_delay_us(20);
reg_2d9c = odm_read_1byte(dm, R_0x2d9c);
count++;
}
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1bcc, 0x0000003f, 0x0); /*ItQt 0dB*/
}
RF_DBG(dm, DBG_RF_DPK, "[DPK] one-shot for S%d %s = 0x%x (count=%d)\n",
path, action == 1 ? "GL" : (action == 2 ? "DO_DPK" :
(action == 3 ? "DPK_ON" : (action == 0 ? "Cal_PWR" : "DAGC"))),
dpk_cmd, count);
if (count == 1000) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] one-shot over 20ms!!!!\n");
result = 1;
}
btc_set_gnt_wl_bt_8822c(dm, false);
odm_write_1byte(dm, 0x1b10, 0x0);
return result;
}
u16 _dpk_dgain_read_8822c(
struct dm_struct *dm,
u8 path)
{
u16 dgain = 0x0;
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc); /*subpage 2*/
odm_set_bb_reg(dm, R_0x1bd4, 0x00ff0000, 0x0);
dgain = (u16)odm_get_bb_reg(dm, R_0x1bfc, 0x0FFF0000); /*[27:16]*/
RF_DBG(dm, DBG_RF_DPK, "[DPK] DGain = 0x%x (%d)\n", dgain, dgain);
return dgain;
}
u8 _dpk_thermal_read_8822c(
void *dm_void,
u8 path)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x42, BIT(19), 0x1);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x42, BIT(19), 0x0);
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x42, BIT(19), 0x1);
ODM_delay_us(15);
return (u8)odm_get_rf_reg(dm, (enum rf_path)path, RF_0x42, 0x0007e);
}
u32 _dpk_pas_read_8822c(
struct dm_struct *dm,
u8 path,
u8 action)
{
u8 k;
u32 reg_1bfc, i_val = 0, q_val = 0;
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1b48, BIT(14), 0x0);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x00060001);
odm_set_bb_reg(dm, R_0x1b4c, MASKDWORD, 0x00000000);
switch (action) {
case LOSS_CHK:
odm_set_bb_reg(dm, R_0x1b4c, MASKDWORD, 0x00080000);
q_val = odm_get_bb_reg(dm, R_0x1bfc, MASKHWORD);
i_val = odm_get_bb_reg(dm, R_0x1bfc, MASKLWORD);
if (i_val >> 15 != 0)
i_val = 0x10000 - i_val;
if (q_val >> 15 != 0)
q_val = 0x10000 - q_val;
#if (DPK_PAS_CHK_DBG_8822C)
RF_DBG(dm, DBG_RF_DPK, "[DPK][%s] i=0x%x,q=0x%x,i^2+q^2=0x%x\n",
"LOSS", i_val, q_val, i_val*i_val + q_val*q_val);
#endif
break;
case PAS_READ:
for (k = 0; k < 64; k++) {
odm_set_bb_reg(dm, R_0x1b4c, MASKDWORD,
(0x00080000 | (k << 24)));
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] 0x1b4c[%d] = 0x%x\n", k,
odm_get_bb_reg(dm, R_0x1b4c, MASKDWORD));
#endif
reg_1bfc = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
RF_DBG(dm, DBG_RF_DPK, "[DPK] PA scan_S%d = 0x%08x\n",
path, reg_1bfc);
}
break;
default:
break;
}
odm_set_bb_reg(dm, R_0x1b4c, MASKDWORD, 0x00000000);
return i_val*i_val + q_val*q_val;
}
u8 _dpk_gainloss_result_8822c(
struct dm_struct *dm,
u8 path)
{
u8 result;
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1b48, BIT(14), 0x1);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x00060000);
result = (u8)odm_get_bb_reg(dm, R_0x1bfc, 0x000000f0);
odm_set_bb_reg(dm, R_0x1b48, BIT(14), 0x0);
RF_DBG(dm, DBG_RF_DPK, "[DPK] tmp GL = %d\n", result);
return result;
}
u8 _dpk_agc_chk_8822c(
struct dm_struct *dm,
u8 path,
u8 limited_pga,
u8 check)
{
u8 result = 0;
u16 dgain =0;
u32 loss = 0;
u32 loss_db = 0;
if (check == GAIN_CHK) {
_dpk_one_shot_8822c(dm, path, DAGC);
dgain = _dpk_dgain_read_8822c(dm, path);
if ((dgain > 1535) && !limited_pga) { /*DGain > 1535 happen*/
RF_DBG(dm, DBG_RF_DPK, "[DPK] Small DGain!!\n");
result = 2;
return result;
} else if ((dgain < 768) && !limited_pga) { /*DGain < 768 happen*/
RF_DBG(dm, DBG_RF_DPK, "[DPK] Large DGain!!\n");
result = 1;
return result;
} else
return result;
} else if (check == LOSS_CHK) {
loss = _dpk_pas_read_8822c(dm, path, LOSS_CHK);
if (loss < 0x4000000) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] GLoss < 0dB happen!!\n");
result = 4;
return result;
}
loss_db = 3 * halrf_psd_log2base(loss >> 13);
#if (DPK_PAS_CHK_DBG_8822C)
RF_DBG(dm, DBG_RF_DPK, "[DPK] GLoss = %d.%02ddB\n",
(loss_db - 3870) / 100, (loss_db -3870) % 100);
#endif
if ((loss_db - 3870) > 1000) { /*GL > 10dB*/
RF_DBG(dm, DBG_RF_DPK, "[DPK] GLoss > 10dB happen!!\n");
result = 3;
return result;
} else if ((loss_db - 3870) < 250) { /*GL < 2.5dB*/
RF_DBG(dm, DBG_RF_DPK, "[DPK] GLoss < 2.5dB happen!!\n");
result = 4;
return result;
} else
return result;
} else
return result;
}
u8 _dpk_pas_agc_8822c(
struct dm_struct *dm,
u8 path,
u8 gain_only,
u8 loss_only)
{
u8 tmp_txbb = 0, tmp_pga = 0, i = 0;
u8 goout = 0, limited_pga = 0, agc_cnt = 0;
do {
switch (i) {
case 0: /*Gain check first*/
tmp_txbb = (u8)odm_get_rf_reg(dm, (enum rf_path)path,
RF_0x56, 0x0001f);
tmp_pga = (u8)odm_get_rf_reg(dm, (enum rf_path)path,
RF_0x00, 0x003e0);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] Start TXBB=0x%x, PGA=0x%x\n",
tmp_txbb, tmp_pga);
if (loss_only)
i = 5;
else {
i = _dpk_agc_chk_8822c(dm, path, limited_pga,
GAIN_CHK);
if ((i == 0) && gain_only)
goout = 1;
else if (i == 0)
i =5;
}
agc_cnt++;
break;
case 1: /*Gain > criterion*/
if (tmp_pga > 0xe) {
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x00, 0x003e0, 0xc);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] PGA(-1) = 0xc\n");
} else if ((0xb < tmp_pga) && (tmp_pga < 0xf)) {
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x00, 0x003e0, 0x0);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] PGA(-1) = 0x0\n");
} else if (tmp_pga < 0xc) {
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] PGA@ lower bound!!\n");
limited_pga = 1;
}
i = 0;
break;
case 2: /*Gain < criterion*/
if (tmp_pga < 0xc) {
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x00, 0x003e0, 0xc);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] PGA(+1) = 0xc\n");
} else if ((0xb < tmp_pga) && (tmp_pga < 0xf)) {
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x00, 0x003e0, 0xf);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] PGA(+1) = 0xf\n");
} else if (tmp_pga > 0xe) {
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] PGA@ upper bound!!\n");
limited_pga = 1;
}
i = 0;
break;
case 3: /*GL > criterion*/
if (tmp_txbb == 0x0) {
goout = 1;
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] TXBB@ lower bound!!\n");
break;
}
tmp_txbb = tmp_txbb - 2;
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x56, 0x0001f, tmp_txbb);
RF_DBG(dm, DBG_RF_DPK, "[DPK][AGC] TXBB(-2) = 0x%x\n",
tmp_txbb);
limited_pga = 0;
i = 0;
break;
case 4: /*GL < criterion*/
if (tmp_txbb == 0x1f) {
goout = 1;
RF_DBG(dm, DBG_RF_DPK,
"[DPK][AGC] TXBB@ upper bound!!\n");
break;
}
tmp_txbb = tmp_txbb + 3;
odm_set_rf_reg(dm, (enum rf_path)path,
RF_0x56, 0x0001f, tmp_txbb);
RF_DBG(dm, DBG_RF_DPK, "[DPK][AGC] TXBB(+3) = 0x%x\n",
tmp_txbb);
limited_pga = 0;
i = 0;
break;
case 5: /*Loss check*/
_dpk_one_shot_8822c(dm, path, GAIN_LOSS);
i = _dpk_agc_chk_8822c(dm, path, limited_pga, LOSS_CHK);
#if (DPK_PAS_DBG_8822C)
_dpk_pas_read_8822c(dm, path, PAS_READ);
#endif
if (i == 0)
goout = 1;
break;
default:
goout = 1;
break;
}
} while (!goout && (agc_cnt < 6));
return tmp_txbb;
}
boolean _dpk_coef_iq_check_8822c(
struct dm_struct *dm,
u16 coef_i,
u16 coef_q)
{
if ((coef_i == 0x1000) || (coef_i == 0x0fff) ||
(coef_q == 0x1000) || (coef_q == 0x0fff))
return 1;
else
return 0;
}
u32 _dpk_coef_transfer_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u32 reg_1bfc = 0;
u16 coef_i = 0, coef_q = 0;
reg_1bfc = odm_get_bb_reg(dm, R_0x1bfc, MASKDWORD);
#if (DPK_COEF_DBG_8822C)
RF_DBG(dm, DBG_RF_DPK,
"[DPK][coef_r] 0x1bfc = 0x%08x\n", reg_1bfc);
#endif
#if 1
coef_i = (u16)odm_get_bb_reg(dm, R_0x1bfc, MASKHWORD) & 0x1fff;
coef_q = (u16)odm_get_bb_reg(dm, R_0x1bfc, MASKLWORD) & 0x1fff;
coef_q = ((0x2000 - coef_q) & 0x1fff) - 1;
reg_1bfc = (coef_i << 16) | coef_q;
#endif
return reg_1bfc;
}
void _dpk_get_coef_8822c(
void *dm_void,
u8 path)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0x0000000c);
if (path == RF_PATH_A) {
odm_set_bb_reg(dm, R_0x1bb4, BIT(24), 0x0);
odm_set_bb_reg(dm, R_0x1b04, MASKDWORD, 0x30000080);
} else if (path == RF_PATH_B) {
odm_set_bb_reg(dm, R_0x1bb4, BIT(24), 0x1);
odm_set_bb_reg(dm, R_0x1b5c, MASKDWORD, 0x30000080);
}
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x000400F0);
dpk_info->coef[path][0] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x040400F0);
dpk_info->coef[path][1] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x080400F0);
dpk_info->coef[path][2] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x010400F0);
dpk_info->coef[path][3] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x050400F0);
dpk_info->coef[path][4] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x090400F0);
dpk_info->coef[path][5] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x020400F0);
dpk_info->coef[path][6] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x060400F0);
dpk_info->coef[path][7] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x0A0400F0);
dpk_info->coef[path][8] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x030400F0);
dpk_info->coef[path][9] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x070400F0);
dpk_info->coef[path][10] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x0B0400F0);
dpk_info->coef[path][11] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x0C0400F0);
dpk_info->coef[path][12] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x100400F0);
dpk_info->coef[path][13] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x0D0400F0);
dpk_info->coef[path][14] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x110400F0);
dpk_info->coef[path][15] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x0E0400F0);
dpk_info->coef[path][16] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x120400F0);
dpk_info->coef[path][17] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x0F0400F0);
dpk_info->coef[path][18] = _dpk_coef_transfer_8822c(dm);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x130400F0);
dpk_info->coef[path][19] = _dpk_coef_transfer_8822c(dm);
}
u8 _dpk_coef_read_8822c(
void *dm_void,
u8 path)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 addr, result = 1;
u16 coef_i, coef_q;
for (addr = 0; addr < 20; addr++) {
coef_i = (u16)((dpk_info->coef[path][addr] & 0x1fff0000) >> 16);
coef_q = (u16)(dpk_info->coef[path][addr] & 0x1fff);
if (_dpk_coef_iq_check_8822c(dm, coef_i, coef_q)) {
result = 0;
break;
}
}
return result;
}
void _dpk_coef_write_8822c(
void *dm_void,
u8 path,
u8 result)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 addr;
u16 tmp_reg;
u32 coef;
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0x0000000c);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x000000F0);
for (addr = 0; addr < 20; addr++) {
if (path == RF_PATH_A)
tmp_reg = 0x1b0c + addr * 4;
else
tmp_reg = 0x1b64 + addr * 4;
if (!result) {
if (addr == 3)
coef = 0x04001fff;
else
coef = 0x00001fff;
} else
coef = dpk_info->coef[path][addr];
odm_set_bb_reg(dm, tmp_reg, MASKDWORD, coef);
#if (DPK_COEF_DBG_8822C)
RF_DBG(dm, DBG_RF_DPK,
"[DPK][coef_w] S%d 0x%x = 0x%08x\n", path, tmp_reg, coef);
#endif
}
}
void _dpk_coef_default_8822c(
void *dm_void,
u8 path)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 addr;
u16 tmp_reg;
u32 coef;
odm_set_bb_reg(dm, R_0x1b00, MASKDWORD, 0x0000000c);
odm_set_bb_reg(dm, R_0x1bd4, MASKDWORD, 0x000000F0);
for (addr = 0; addr < 20; addr++) {
if (path == RF_PATH_A)
tmp_reg = 0x1b0c + addr * 4;
else
tmp_reg = 0x1b64 + addr * 4;
if (addr == 3)
coef = 0x04001fff;
else
coef = 0x00001fff;
odm_set_bb_reg(dm, tmp_reg, MASKDWORD, coef);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][Coef write] 0x%x = 0x%x\n", tmp_reg, coef);
}
}
void _dpk_fill_result_8822c(
void *dm_void,
u32 dpk_txagc,
u8 path,
u8 result)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
if (result) /*check PASS*/
odm_write_1byte(dm, R_0x1b67, (u8)(dpk_txagc - 6)); /*ItQt -6dB*/
else
odm_write_1byte(dm, R_0x1b67, 0x00);
dpk_info->result[path] = result;
dpk_info->dpk_txagc[path] = odm_read_1byte(dm, R_0x1b67);
RF_DBG(dm, DBG_RF_DPK,
"[DPK] S%d 0x1b67 = 0x%x\n", path, odm_read_1byte(dm, R_0x1b67));
_dpk_coef_write_8822c(dm, path, result);
}
u32 _dpk_gainloss_8822c(
struct dm_struct *dm,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 k = 0, tx_agc_search = 0x0, t1 = 0, t2 = 0;
u8 tx_agc, tx_bb, ori_txbb, ori_txagc;
s8 txidx_offset = 0x0;
ori_txbb = (u8)_dpk_rf_setting_8822c(dm, path);
ori_txagc = (u8)odm_get_rf_reg(dm, (enum rf_path)path, RF_0x00, 0x0001f);
_dpk_rxbb_dc_cal_8822c(dm, path); /*DCK for DPK*/
_dpk_one_shot_8822c(dm, path, DAGC);
_dpk_dgain_read_8822c(dm, path);
if (_dpk_dc_corr_check_8822c(dm, path)) {
_dpk_rxbb_dc_cal_8822c(dm, path); /*re-do DCK for DPK*/
_dpk_one_shot_8822c(dm, path, DAGC);
_dpk_dc_corr_check_8822c(dm, path);
}
t1 = _dpk_thermal_read_8822c(dm, path);
#if 1
tx_bb = _dpk_pas_agc_8822c(dm, path, false, true);
#else
_dpk_one_shot_8822c(dm, path, GAIN_LOSS);
#endif
#if 0
RF_DBG(dm, DBG_RF_DPK,
"[DPK][GL] S%d RF_0x0=0x%x, 0x63=0x%x, 0x8a=0x%x, 0x1a=0x%x, 0x8f=0x%x\n",
path, odm_get_rf_reg(dm, (enum rf_path)path, RF_0x00, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x63, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x8a, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x1a, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x8f, RFREG_MASK));
#endif
tx_agc_search = _dpk_gainloss_result_8822c(dm, path);
if (tx_bb < tx_agc_search) /*aviod txbb < 0*/
tx_bb = 0;
else
tx_bb = tx_bb - tx_agc_search;
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x56, 0x0001f, tx_bb);
tx_agc = ori_txagc - (ori_txbb - tx_bb);
RF_DBG(dm, DBG_RF_DPK, "[DPK][GL] S%d TXAGC=0x%x, TXBB=0x%x\n",
path, tx_agc, tx_bb);
t2 = _dpk_thermal_read_8822c(dm, path);
dpk_info->thermal_dpk_delta[path] = HALRF_ABS(t2, t1);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d thermal delta of GL = %d (%d - %d)\n",
path, dpk_info->thermal_dpk_delta[path], t2, t1);
return tx_agc;
}
u8 _dpk_by_path_8822c(
struct dm_struct *dm,
u32 tx_agc,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 result = 1;
u16 dc_i, dc_q;
#if 0
tx_agc = (odm_get_rf_reg(dm, (enum rf_path)path, RF_0x00,
RFREG_MASK) & ~0x1f) | tx_agc;
RF_DBG(dm, DBG_RF_DPK, "[DPK][DO_DPK] RF0x0 = 0x%x\n", tx_agc);
/*TXAGC for DPK*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x00, RFREG_MASK, tx_agc);
RF_DBG(dm, DBG_RF_DPK,
"[DPK][GL] S%d RF 0x63=0x%x, 0x8a=0x%x, 0x1a=0x%x, 0x8f=0x%x\n",
path, odm_get_rf_reg(dm, (enum rf_path)path, RF_0x63, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x8a, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x1a, RFREG_MASK),
odm_get_rf_reg(dm, (enum rf_path)path, RF_0x8f, RFREG_MASK));
#endif
result = _dpk_one_shot_8822c(dm, path, DO_DPK);
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
result = result | (u8)odm_get_bb_reg(dm, R_0x1b08, BIT(26));
RF_DBG(dm, DBG_RF_DPK, "[DPK][DO_DPK] DPK Fail = %x\n", result);
/*set RX high gain for RXBB DCK*/
odm_set_rf_reg(dm, (enum rf_path)path, RF_0x00, RFREG_MASK, 0x33e14);
_dpk_get_coef_8822c(dm, path);
#if 0
odm_write_4byte(dm, 0x1bd4, 0x000900F0);
dc_i = (u16)odm_get_bb_reg(dm, 0x1bfc, 0x0fff0000);
dc_q = (u16)odm_get_bb_reg(dm, 0x1bfc, 0x00000fff);
if (dc_i >> 11 == 1)
dc_i = 0x1000 - dc_i;
if (dc_q >> 11 == 1)
dc_q = 0x1000 - dc_q;
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d DC i/q = %d / %d\n", path, dc_i, dc_q);
#endif
#if (DPK_PAS_DBG_8822C)
_dpk_pas_read_8822c(dm, path, PAS_READ);
#endif
return result;
}
void _dpk_cal_pwr_8822c(
struct dm_struct *dm,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u16 tmp_gs = 0;
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1b20, BIT(25), 0x0); /*BypassDPD=0*/
odm_set_bb_reg(dm, R_0x1b20, 0xc0000000, 0x0); /* disable CFIR to TX*/
odm_set_bb_reg(dm, R_0x1bcc, 0xc000003f, 0x9); /* ItQt shift 1 bit*/
odm_set_bb_reg(dm, R_0x1bcc, BIT(21), 0x1); /* inner loopback*/
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc);
odm_set_bb_reg(dm, R_0x1bd4, 0x000000f0, 0xf);
if (path == RF_PATH_A) {
/*manual pwsf+gs*/
odm_set_bb_reg(dm, R_0x1b04, 0x0fffffff, 0x1066680);
/*enable MDPD*/
odm_set_bb_reg(dm, R_0x1b08, BIT(31), 0x1);
} else {
odm_set_bb_reg(dm, R_0x1b5c, 0x0fffffff, 0x1066680);
odm_set_bb_reg(dm, R_0x1b60, BIT(31), 0x1);
}
if (dpk_info->dpk_bw == 0x1) { /*80M*/
/*TPG DC*/
odm_write_4byte(dm, R_0x1bf8, 0x80001310);
odm_write_4byte(dm, R_0x1bf8, 0x00001310);
odm_write_4byte(dm, R_0x1bf8, 0x810000DB);
odm_write_4byte(dm, R_0x1bf8, 0x010000DB);
odm_write_4byte(dm, R_0x1bf8, 0x0000B428);
/*set TPG*/
odm_write_4byte(dm, R_0x1bf4, 0x05020000 | (BIT(path) << 28));
} else {
odm_write_4byte(dm, R_0x1bf8, 0x8200190C);
odm_write_4byte(dm, R_0x1bf8, 0x0200190C);
odm_write_4byte(dm, R_0x1bf8, 0x8301EE14);
odm_write_4byte(dm, R_0x1bf8, 0x0301EE14);
odm_write_4byte(dm, R_0x1bf8, 0x0000B428);
odm_write_4byte(dm, R_0x1bf4, 0x05020008 | (BIT(path) << 28));
}
odm_set_bb_reg(dm, R_0x1bb4, 0xff000000, 0x8 | path);
_dpk_one_shot_8822c(dm, path, 0);
/*restore*/
odm_set_bb_reg(dm, R_0x1bf4, 0xff000000, 0x0); /*TPG off*/
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1bcc, 0xc000003f, 0x0); /* ItQt*/
odm_set_bb_reg(dm, R_0x1bcc, BIT(21), 0x0); /* inner loopback off*/
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc);
if (path == RF_PATH_A)
odm_set_bb_reg(dm, R_0x1b04, 0x0fffffff, 0x5b);
else
odm_set_bb_reg(dm, R_0x1b5c, 0x0fffffff, 0x5b);
odm_set_bb_reg(dm, R_0x1bd4, 0x001f0000, 0x0);
tmp_gs = (u16)odm_get_bb_reg(dm, R_0x1bfc, 0x0FFF0000);
#if 0
RF_DBG(dm, DBG_RF_DPK, "[DPK] tmp_gs = 0x%x\n", tmp_gs);
#endif
tmp_gs = (tmp_gs * 910) >> 10; /*910 = 0x5b * 10*/
if ((tmp_gs % 10) >= 5)
tmp_gs = tmp_gs / 10 + 1;
else
tmp_gs = tmp_gs / 10;
if (path == RF_PATH_A)
odm_set_bb_reg(dm, R_0x1b04, 0x0fffffff, tmp_gs);
else
odm_set_bb_reg(dm, R_0x1b5c, 0x0fffffff, tmp_gs);
dpk_info->dpk_gs[path] = tmp_gs;
}
void _dpk_on_8822c(
struct dm_struct *dm,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
_dpk_one_shot_8822c(dm, path, DPK_ON);
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1b20, 0xc0000000, 0x0); /* disable CFIR to TX*/
if ((dpk_info->dpk_path_ok & BIT(path)) >> path)
_dpk_cal_pwr_8822c(dm, path);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d DPD on!!!\n\n", path);
}
void dpk_coef_read_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 path, addr;
RF_DBG(dm, DBG_RF_DPK, "[DPK] ========= Coef Read Start =========\n");
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
for (addr = 0; addr < 20; addr++)
RF_DBG(dm, DBG_RF_DPK,
"[DPK] Read S%d coef[%2d]= 0x%x\n",
path, addr, dpk_info->coef[path][addr]);
}
RF_DBG(dm, DBG_RF_DPK, "[DPK] ========= Coef Read Finish =========\n");
}
u8 _dpk_check_fail_8822c(
struct dm_struct *dm,
boolean is_fail,
u32 dpk_txagc,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 result;
if (!is_fail)
if (_dpk_coef_read_8822c(dm, path))
result = 1; /*check PASS*/
else
result = 0; /*check FAIL*/
else
result = 0; /*check FAIL*/
_dpk_fill_result_8822c(dm, dpk_txagc, path, result);
return result;
}
void _dpk_result_reset_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 path;
dpk_info->dpk_path_ok = 0;
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1b58, 0x0000007f, 0x0);
dpk_info->dpk_txagc[path] = 0;
dpk_info->result[path] = 0;
dpk_info->dpk_gs[path] = 0x5b;
dpk_info->pre_pwsf[path] = 0;
dpk_info->thermal_dpk[path] = _dpk_thermal_read_8822c(dm, path);
RF_DBG(dm, DBG_RF_DPK, "[DPK] init thermal S%d = %d\n", path,
dpk_info->thermal_dpk[path]);
#if 0
RF_DBG(dm, DBG_RF_DPK,
"[DPK][reset] S%d pwsf=0x%x, dpk_result=%d\n",
path, dpk_info->pwsf[path], dpk_info->result[path],
#endif
}
}
void _dpk_calibrate_8822c(
struct dm_struct *dm,
u8 path)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 dpk_fail = 1, retry_cnt;
u32 dpk_txagc = 0;
RF_DBG(dm, DBG_RF_DPK,
"[DPK] =========== S%d DPK Start ===========\n", path);
for (retry_cnt = 0; retry_cnt < 1; retry_cnt++) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] retry = %d\n", retry_cnt);
dpk_txagc = _dpk_gainloss_8822c(dm, path);
dpk_fail = _dpk_by_path_8822c(dm, dpk_txagc, path);
if (_dpk_check_fail_8822c(dm, dpk_fail, dpk_txagc, path))
break;
}
RF_DBG(dm, DBG_RF_DPK,
"[DPK] =========== S%d DPK Finish ==========\n", path);
if (dpk_info->result[path])
dpk_info->dpk_path_ok = dpk_info->dpk_path_ok | BIT(path);
}
void _dpk_path_select_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
#if (DPK_PATH_A_8822C)
_dpk_calibrate_8822c(dm, RF_PATH_A);
#endif
#if (DPK_PATH_B_8822C)
_dpk_calibrate_8822c(dm, RF_PATH_B);
#endif
_dpk_on_8822c(dm, RF_PATH_A);
_dpk_on_8822c(dm, RF_PATH_B);
}
void _dpk_result_summary_8822c(
struct dm_struct *dm)
{
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 path;
RF_DBG(dm, DBG_RF_DPK, "[DPK] ======== DPK Result Summary =======\n");
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
RF_DBG(dm, DBG_RF_DPK,
"[DPK] S%d dpk_txagc = 0x%x, dpk_result = %d\n",
path, dpk_info->dpk_txagc[path], dpk_info->result[path]);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d gain scaling = 0x%x\n",
path, dpk_info->dpk_gs[path]);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S%d DPK is %s\n", path,
((dpk_info->dpk_path_ok & BIT(path)) >> path) ?
"Success" : "Fail");
}
RF_DBG(dm, DBG_RF_DPK, "[DPK] dpk_path_ok = 0x%x\n",
dpk_info->dpk_path_ok);
RF_DBG(dm, DBG_RF_DPK, "[DPK] ======== DPK Result Summary =======\n");
}
void _dpk_reload_data_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 path;
if ((dpk_info->dpk_path_ok == 0) && (dpk_info->dpk_ch == 0))
return; /*never do DPK before*/
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
if (dpk_info->dpk_band == 0x0) /*txagc bnd*/
odm_set_bb_reg(dm, R_0x1b60, MASKDWORD, 0x1f100000);
else
odm_set_bb_reg(dm, R_0x1b60, MASKDWORD, 0x1f0d0000);
odm_write_1byte(dm, R_0x1b67, dpk_info->dpk_txagc[path]);
_dpk_coef_write_8822c(dm, path, (dpk_info->dpk_path_ok & BIT(path)) >> path);
_dpk_one_shot_8822c(dm, path, DPK_ON);
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc);
if (path == RF_PATH_A)
odm_set_bb_reg(dm, R_0x1b04, 0x0fffffff, dpk_info->dpk_gs[0]);
else
odm_set_bb_reg(dm, R_0x1b5c, 0x0fffffff, dpk_info->dpk_gs[1]);
}
}
u8 dpk_reload_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u8 channel;
dpk_info->is_reload = false;
channel = (u8)(odm_get_rf_reg(dm, RF_PATH_A, RF_0x18, RFREG_MASK) & 0xff);
if (channel == dpk_info->dpk_ch) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] DPK reload for CH%d!!\n", dpk_info->dpk_ch);
_dpk_reload_data_8822c(dm);
dpk_info->is_reload = true;
}
return dpk_info->is_reload;
}
void do_dpk_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
u32 bb_reg_backup[DPK_BB_REG_NUM_8822C];
u32 rf_reg_backup[DPK_RF_REG_NUM_8822C][DPK_RF_PATH_NUM_8822C];
u32 bb_reg[DPK_BB_REG_NUM_8822C] = {
R_0x520, R_0x820, R_0x824, R_0x1c3c, R_0x1d58,
R_0x1864, R_0x4164, R_0x180c, R_0x410c, R_0x186c,
R_0x416c, R_0x1a14, R_0x1e70, R_0x80c, R_0x1d70,
R_0x1e7c, R_0x18a4, R_0x41a4};
u32 rf_reg[DPK_RF_REG_NUM_8822C] = {
RF_0x19, RF_0x1a, RF_0x55, RF_0x63, RF_0x87,
RF_0x8f, RF_0xde};
if (dm->ext_pa && (*dm->band_type == ODM_BAND_2_4G)) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] Skip DPK due to ext_PA exist!!\n");
return;
} else if (dm->ext_pa_5g && (*dm->band_type == ODM_BAND_5G)) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] Skip DPK due to 5G_ext_PA exist!!\n");
return;
} else if (!dpk_info->is_dpk_pwr_on) {
RF_DBG(dm, DBG_RF_DPK, "[DPK] Skip DPK due to DPD PWR off !!\n");
return;
} else if (!(*dm->mp_mode) && dpk_reload_8822c(dm))
return;
RF_DBG(dm, DBG_RF_DPK,
"[DPK] ****** DPK Start (Ver: %s), Cut: %d ******\n",
DPK_VER_8822C, dm->cut_version);
_dpk_information_8822c(dm);
_backup_mac_bb_registers_8822c(dm, bb_reg, bb_reg_backup,
DPK_BB_REG_NUM_8822C);
_backup_rf_registers_8822c(dm, rf_reg, rf_reg_backup);
_dpk_mac_bb_setting_8822c(dm);
_dpk_afe_setting_8822c(dm, true);
_dpk_manual_txagc_8822c(dm, true);
_dpk_pre_setting_8822c(dm);
_dpk_result_reset_8822c(dm);
_dpk_path_select_8822c(dm);
_dpk_result_summary_8822c(dm);
_dpk_manual_txagc_8822c(dm, false);
_dpk_afe_setting_8822c(dm, false);
dpk_enable_disable_8822c(dm);
_reload_rf_registers_8822c(dm, rf_reg, rf_reg_backup);
halrf_rxbb_dc_cal_8822c(dm); /*DCK for Rx*/
_reload_mac_bb_registers_8822c(dm, bb_reg, bb_reg_backup,
DPK_BB_REG_NUM_8822C);
}
void dpk_enable_disable_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0xc); /*subpage 2*/
odm_set_bb_reg(dm, R_0x1b08, BIT(31), dpk_info->is_dpk_pwr_on);
odm_set_bb_reg(dm, R_0x1b60, BIT(31), dpk_info->is_dpk_pwr_on);
if (dpk_info->is_dpk_enable) {
if (dpk_info->dpk_path_ok & BIT(0)) {
odm_set_bb_reg(dm, R_0x1b08, BIT(15) | BIT(14), 0x1);
odm_set_bb_reg(dm, R_0x1b04, 0x0fffffff,
dpk_info->dpk_gs[RF_PATH_A]);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S0 DPK enable !!!\n");
}
if ((dpk_info->dpk_path_ok & BIT(1)) >> 1) {
odm_set_bb_reg(dm, R_0x1b60, BIT(15) | BIT(14), 0x1);
odm_set_bb_reg(dm, R_0x1b5c, 0x0fffffff,
dpk_info->dpk_gs[RF_PATH_B]);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S1 DPK enable !!!\n");
}
} else {
if (dpk_info->dpk_path_ok & BIT(0)) {
odm_set_bb_reg(dm, R_0x1b08, BIT(15) | BIT(14), 0x3);
odm_set_bb_reg(dm, R_0x1b04, 0x0fffffff,0x5b);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S0 DPK bypass !!!\n");
}
if ((dpk_info->dpk_path_ok & BIT(1)) >> 1) {
odm_set_bb_reg(dm, R_0x1b60, BIT(15) | BIT(14), 0x3);
odm_set_bb_reg(dm, R_0x1b5c, 0x0fffffff,0x5b);
RF_DBG(dm, DBG_RF_DPK, "[DPK] S1 DPK bypass !!!\n");
}
}
}
void dpk_track_8822c(
void *dm_void)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
struct _hal_rf_ *rf = &dm->rf_table;
u8 is_increase, i = 0, k = 0, path;
u8 thermal_dpk_avg_count = 0, thermal_value[2] = {0};
u32 thermal_dpk_avg[2] = {0};
s8 offset[2], delta_dpk[2];
if ((dpk_info->thermal_dpk[0] == 0) && (dpk_info->thermal_dpk[1] == 0)) {
RF_DBG(dm, DBG_RF_DPK, "[DPK_track] Bypass DPK tracking!!!!\n");
return;
} else
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] =======================================\n");
/*get thermal meter*/
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
thermal_value[path] = _dpk_thermal_read_8822c(dm, path);
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] S%d thermal now = %d\n", path, thermal_value[path]);
}
dpk_info->thermal_dpk_avg[0][dpk_info->thermal_dpk_avg_index] =
thermal_value[0];
dpk_info->thermal_dpk_avg[1][dpk_info->thermal_dpk_avg_index] =
thermal_value[1];
dpk_info->thermal_dpk_avg_index++;
/*Average times */
if (dpk_info->thermal_dpk_avg_index == THERMAL_DPK_AVG_NUM)
dpk_info->thermal_dpk_avg_index = 0;
for (i = 0; i < THERMAL_DPK_AVG_NUM; i++) {
if (dpk_info->thermal_dpk_avg[0][i] ||
dpk_info->thermal_dpk_avg[1][i]) {
thermal_dpk_avg[0] += dpk_info->thermal_dpk_avg[0][i];
thermal_dpk_avg[1] += dpk_info->thermal_dpk_avg[1][i];
thermal_dpk_avg_count++;
}
}
/*Calculate Average ThermalValue after average enough times*/
if (thermal_dpk_avg_count) {
#if 0
RF_DBG(dm, DBG_RF_DPK,
"[DPK_track] S0 ThermalValue_DPK_AVG (count) = %d (%d))\n",
thermal_dpk_avg[0], thermal_dpk_avg_count);
RF_DBG(dm, DBG_RF_DPK,
"[DPK_track] S1 ThermalValue_DPK_AVG (count) = %d (%d))\n",
thermal_dpk_avg[1], thermal_dpk_avg_count);
#endif
thermal_value[0] = (u8)(thermal_dpk_avg[0] / thermal_dpk_avg_count);
thermal_value[1] = (u8)(thermal_dpk_avg[1] / thermal_dpk_avg_count);
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] S0 thermal avg = %d (DPK @ %d)\n",
thermal_value[0], dpk_info->thermal_dpk[0]);
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] S1 thermal avg = %d (DPK @ %d)\n",
thermal_value[1], dpk_info->thermal_dpk[1]);
}
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
delta_dpk[path] = dpk_info->thermal_dpk[path] - thermal_value[path];
offset[path] = (delta_dpk[path] - dpk_info->thermal_dpk_delta[path]) & 0x7f;
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] S%d thermal_diff= %d, cal_diff= %d, offset= %d\n",
path, delta_dpk[path], dpk_info->thermal_dpk_delta[path],
offset[path] > 64 ? offset[path] - 128 : offset[path]);
}
if (rf->is_dpk_in_progress || dm->rf_calibrate_info.is_iqk_in_progress ||
rf->is_tssi_in_progress)
return;
for (path = 0; path < DPK_RF_PATH_NUM_8822C; path++) {
if (offset[path] != dpk_info->pre_pwsf[path]) {
odm_set_bb_reg(dm, R_0x1b00, 0x0000000f, 0x8 | (path << 1));
odm_set_bb_reg(dm, R_0x1b58, 0x0000007f, offset[path]);
dpk_info->pre_pwsf[path] = offset[path];
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] S%d new pwsf is 0x%x, 0x1b58=0x%x\n",
path, dpk_info->pre_pwsf[path],
odm_get_bb_reg(dm, R_0x1b58, MASKDWORD));
} else
RF_DBG(dm, DBG_RF_DPK | DBG_RF_TX_PWR_TRACK,
"[DPK_track] S%d pwsf unchanged (0x%x)\n",
path, dpk_info->pre_pwsf[path]);
}
}
void dpk_info_rsvd_page_8822c(
void *dm_void,
u8 *buf,
u32 *buf_size)
{
struct dm_struct *dm = (struct dm_struct *)dm_void;
struct dm_dpk_info *dpk_info = &dm->dpk_info;
if (buf) {
odm_move_memory(dm, buf, &(dpk_info->dpk_path_ok), 2);
odm_move_memory(dm, buf + 2, dpk_info->dpk_txagc, 2);
odm_move_memory(dm, buf + 4, dpk_info->dpk_gs, 4);
odm_move_memory(dm, buf + 8, dpk_info->coef, 160);
odm_move_memory(dm, buf + 168, &(dpk_info->dpk_ch), 1);
}
if (buf_size)
*buf_size = DPK_INFO_RSVD_LEN_8822C;
}
#endif
================================================
FILE: hal/phydm/halrf/rtl8822c/halrf_dpk_8822c.h
================================================
/******************************************************************************
*
* Copyright(c) 2007 - 2017 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* The full GNU General Public License is included in this distribution in the
* file called LICENSE.
*
* Contact Information:
* wlanfae
* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
* Hsinchu 300, Taiwan.
*
* Larry Finger